<div class="narrow"> <?= partial('partials/header') ?> <div style="clear: both;"> <div class="alert alert-success hidden" id="test_success"><strong>Success! </strong><a href="" id="post_href">View your post</a></div> <div class="alert alert-danger hidden" id="test_error"><strong>Something went wrong!</strong><br>Your Micropub endpoint indicated that something went wrong creating the post.</div> </div> <form role="form" style="margin-top: 20px;" id="note_form"> <div class="form-group" style="margin-top: 18px;"> <label>Event Name</label> <input type="text" class="form-control" id="event_name" placeholder="" value=""> </div> <div class="form-group" style="margin-top: 18px;"> <label>Location</label> <input type="text" class="form-control" id="event_location" placeholder="" value=""> <span class="help-block" id="location_preview"></span> </div> <div id="map" class="hidden" style="width: 100%; height: 180px; border-radius: 4px; border: 1px #ccc solid;"></div> <div class="form-group" id="start_date" style="margin-top: 18px;"> <label>Start Date/Time</label> <div class="form-group"> <input type="text" class="form-control date" placeholder="<?= date('Y-m-d') ?>" value="" style="max-width: 40%; margin-right: 4px; float: left;"> <input type="text" class="form-control time" placeholder="14:30" value="" style="max-width: 40%; margin-right: 4px; float: left;"> <input type="text" class="form-control timezone" placeholder="-08:00" style="max-width: 15%;"> </div> </div> <div class="form-group" id="end_date" style="margin-top: 18px;"> <label>End Date/Time (Optional)</label> <div class="form-group"> <input type="text" class="form-control date" placeholder="<?= date('Y-m-d') ?>" value="" style="max-width: 40%; margin-right: 4px; float: left;"> <input type="text" class="form-control time" placeholder="14:30" value="" style="max-width: 40%; margin-right: 4px; float: left;"> <input type="text" class="form-control timezone" placeholder="-08:00" style="max-width: 15%;"> </div> </div> <div id="presentation-fields" class="hidden"> <div class="form-group" style="margin-top: 18px;"> <label>Link to Slides</label> <input type="url" class="form-control" id="slides"> </div> <div class="form-group"> <label for="slides-embed">Slides Embed Code</label> <textarea id="slides-embed" class="form-control" style="height: 4em;"></textarea> </div> <div class="form-group" style="margin-top: 18px;"> <label>Link to Video</label> <input type="url" class="form-control" id="video-link"> </div> <div class="form-group"> <label for="video-embed">Video Embed Code</label> <textarea id="video-embed" class="form-control" style="height: 4em;"></textarea> </div> <div class="form-group" style="margin-top: 18px;"> <label>Conference</label> <div class="form-group"> <input type="text" id="conference-name" class="form-control" style="max-width: 48%; margin-right: 4px; float: left;" placeholder="Conference Name"> <input type="url" id="conference-url" class="form-control" style="max-width: 48%; margin-right: 4px; float: left;" placeholder="https://example.com"> </div> <div style="clear:both;"></div> </div> </div> <div class="form-group"> <label for="note_content">Content</label> <textarea id="note_content" value="" class="form-control" rows="6"></textarea> </div> <div class="form-group hidden" id="content-type-selection"> <label for="note_content_type">Content Type</label> <select class="form-control" id="note_content_type"> <option value="text/plain">Text</option> <option value="text/markdown">Markdown</option> </select> </div> <div class="form-group" style="margin-top: 18px;"> <label for="note_category">Tags</label> <input type="text" id="note_category" value="" class="form-control"> </div> <?php if($this->channels): ?> <div class="form-group"> <label for="note_channel">Channel</label> <div id="channel-container"> <?php echo '<select class="form-control" id="note_channel">'; echo '<option value="none"></option>'; foreach($this->channels as $ch) { echo '<option value="'.htmlspecialchars($ch).'" '.($ch == 'events' ? 'selected' : '').'>' . htmlspecialchars($ch) . '</option>'; } echo '</select>'; ?> </div> </div> <?php endif; ?> <div style="float: right; margin-top: 6px;"> <button class="btn btn-success" id="btn_post">Post</button> </div> </form> </div> <link rel="stylesheet" href="/libs/bootstrap-typeahead/typeahead.css"> <script src="/libs/bootstrap-typeahead/typeahead.min.js"></script> <?php if(Config::$googleMapsAPIKey): ?> <script src="https://maps.googleapis.com/maps/api/js?key=<?= Config::$googleMapsAPIKey ?>&libraries=places"></script> <?php endif ?> <script> <?php if(Config::$googleMapsAPIKey): ?> var map = new google.maps.Map(document.getElementById('map'), { center: new google.maps.LatLng(-45,122), zoom: 15 }); <?php else: ?> var map = null; <?php endif ?> var d = new Date(); var tzOffset = tz_seconds_to_offset(d.getTimezoneOffset() * 60 * -1); var selectedPlace; if(map) { var gservice = new google.maps.places.AutocompleteService(); var gplaces = new google.maps.places.PlacesService(map); var selectedPlacePin; } $(document).bind('keydown', function(e){ // Easter egg: press ctrl+shift+c to reveal a content type selection if(e.keyCode == 67 && e.ctrlKey && e.shiftKey) { $("#content-type-selection").removeClass("hidden"); } // Easter egg: press ctrl+shift+m to switch to markdown if(e.keyCode == 77 && e.ctrlKey && e.shiftKey) { switchToMarkdown(); } // Enable "presentation mode" which adds a few fields if(e.keyCode == 80 && e.ctrlKey && e.shiftKey) { enablePresentationMode(); } }); function switchToMarkdown() { $("#content-type-selection select").val("text/markdown"); $("#content-type-selection").removeClass("hidden"); } function enablePresentationMode() { $("#presentation-fields").removeClass("hidden"); } $(function(){ // Start the event timezone offset in the browser's timezone $("#start_date .timezone").attr("placeholder", tzOffset); $("#end_date .timezone").attr("placeholder", tzOffset); // As soon as a time is entered, move the placeholder offset to the value $("#start_date .time").on("keydown", function(){ $("#start_date .timezone").val($("#start_date .timezone").attr("placeholder")); }); $("#end_date .time").on("keydown", function(){ $("#end_date .timezone").val($("#end_date .timezone").attr("placeholder")); }); if(map) { $("#event_location").typeahead({ minLength: 3, highlight: true }, { limit: 5, async: true, source: function(query, sync, async) { gservice.getPlacePredictions({ input: query }, function(predictions, status) { if (status == google.maps.places.PlacesServiceStatus.OK) { async(predictions); } }); }, display: function(item) { return item.description; }, templates: { suggestion: function(item) { return '<span>'+item.description+'</span>'; } } }).bind('typeahead:select', function(ev, suggestion) { gplaces.getDetails({ placeId: suggestion.place_id, fields: ["geometry", "name", "address_component", "url", "utc_offset"] }, function(result, status) { if(status != google.maps.places.PlacesServiceStatus.OK) { alert('Cannot find address'); return; } console.log(result); map.setCenter(result.geometry.location); if(selectedPlacePin) { selectedPlacePin.setMap(null); selectedPlacePin = null; } selectedPlacePin = new google.maps.Marker({ position: result.geometry.location, map: map }); selectedPlace = { type: ["h-card"], properties: { name: [result.name], latitude: [result.geometry.location.lat()], longitude: [result.geometry.location.lng()], } }; address = ''; locality = ''; region = ''; country = ''; for(var i in result.address_components) { if(result.address_components[i].types.includes('street_number')) { address += ' '+result.address_components[i].short_name; } if(result.address_components[i].types.includes('route')) { address += ' '+result.address_components[i].short_name; } if(result.address_components[i].types.includes('locality')) { locality = result.address_components[i].long_name; } if(result.address_components[i].types.includes('administrative_area_level_1')) { region = result.address_components[i].long_name; } if(result.address_components[i].types.includes('country')) { country = result.address_components[i].short_name; } } if(address) { selectedPlace['properties']['street-address'] = [address.trim()]; } if(locality) { selectedPlace['properties']['locality'] = [locality]; } if(region) { selectedPlace['properties']['region'] = [region]; } if(country) { selectedPlace['properties']['country-name'] = [country]; } if(result.utc_offset) { tzOffset = tz_seconds_to_offset(result.utc_offset * 60); $("#start_date .timezone").attr("placeholder", tzOffset); $("#end_date .timezone").attr("placeholder", tzOffset); if($("#start_date .timezone").val()) { $("#start_date .timezone").val($("#start_date .timezone").attr("placeholder")); } if($("#end_date .timezone").val()) { $("#end_date .timezone").val($("#end_date .timezone").attr("placeholder")); } } $("#map").removeClass("hidden"); $("#location_preview").text(''); }); }); } }); $("#note_category").tokenfield({ createTokensOnBlur: true, beautify: true }); $("#btn_post").click(function(){ var event_start = $("#start_date .date").val(); if($("#start_date .time").val()) { event_start += "T"+$("#start_date .time").val()+$("#start_date .timezone").val(); } var event_end; if($("#end_date .date").val()) { event_end = $("#end_date .date").val(); if($("#end_date .time").val()) { event_end += "T"+$("#end_date .time").val()+$("#end_date .timezone").val(); } } var properties = { name: [$("#event_name").val()], start: [event_start], location: (selectedPlace ? selectedPlace : $("#event_location").val()), category: tokenfieldToArray("#note_category"), content: $("#note_content").val() }; if(event_end) { properties.end = event_end; } if($("#note_channel").val()) { properties['p3k-channel'] = $("#note_channel").val(); } if(!$("#content-type-selection").hasClass("hidden")) { properties['p3k-content-type'] = $("#note_content_type").val(); } if(!$("#presentation-fields").hasClass("hidden")) { properties['slides'] = $("#slides").val(); properties['slides-embed'] = $("#slides-embed").val(); properties['video-link'] = $("#video-link").val(); properties['video-embed'] = $("#video-embed").val(); if($("#conference-name").val()) { properties['conference'] = { type: 'h-event', properties: { name: $("#conference-name").val(), url: $("#conference-url").val() } }; } } $.post("/micropub/postjson", { data: JSON.stringify({ "type": ["h-event"], "properties": properties }) }, function(response){ if(response.location != false) { $("#test_success").removeClass('hidden'); $("#test_error").addClass('hidden'); $("#post_href").attr("href", response.location); $("#note_form").slideUp(200, function(){ $(window).scrollTop($("#test_success").position().top); }); } else { $("#test_success").addClass('hidden'); $("#test_error").removeClass('hidden'); } }); return false; }); </script>