/*! Bundled by webpack from entry point: ./_Scripts/LegacyJS/mobile.js */
/******/ (() => { // webpackBootstrap
/******/ // The require scope
/******/ var __webpack_require__ = {};
/******/
/************************************************************************/
/******/ /* webpack/runtime/make namespace object */
/******/ (() => {
/******/ // define __esModule on exports
/******/ __webpack_require__.r = (exports) => {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/ })();
/******/
/******/ /* webpack/runtime/publicPath */
/******/ (() => {
/******/ __webpack_require__.p = "";
/******/ })();
/******/
/************************************************************************/
var __webpack_exports__ = {};
// This entry need to be wrapped in an IIFE because it need to be in strict mode.
(() => {
"use strict";
var __webpack_exports__ = {};
/*!***************************************************!*\
!*** ./_Scripts/_Includes/set-public-path.mod.ts ***!
\***************************************************/
__webpack_require__.r(__webpack_exports__);
// We need to set the public path at runtime based on the GlobalRoot site setting.
// (We don't know at build time where the static files will be,
// since we could be deployed on-premise.)
// The value of that site setting gets written out to the dom in Master.cshtml
// (see JavaScriptHelper.PublicPath()) so that we can read it here
__webpack_require__.p = document.getElementById("webpack-public-path").innerText + "Js/";
})();
// This entry need to be wrapped in an IIFE because it need to be isolated against other entry modules.
(() => {
/*!*************************************!*\
!*** ./_Scripts/LegacyJS/mobile.js ***!
\*************************************/
/*** IMPORTS FROM imports-loader ***/
StackExchange = window.StackExchange = (window.StackExchange || {});
StackOverflow = window.StackOverflow = (window.StackOverflow || {});
"use strict";
// Served only as part of the mobile skin.
// Does all the custom UI bits. Generally,
// we try to re-use javascript from full(-anon),
// syntax highlighting, and so on. Having to re-implement
// the site's javascript just for mobile would
// be brutal.
StackExchange.mobile = function () {
var unreadNotifications;
// common idiom is to submit a form after an input change on mobile.
var initSubmitOnChanges =
function () {
$('.submit-on-change').change(
function () {
$(this).closest('form').submit();
}
);
};
// hook up search box
function initSearchBox($container) {
if ($container === undefined) {
$container = $('.js-search-container').closest('.subheader');
}
$container.on('submit', '.js-search-container.js-no-submit', function (e) {
e.preventDefault();
e.stopPropagation();
});
$container.on('click', '.js-search-trigger', function (e) {
$container.find('.js-search-container').show();
$container.find('.js-search-input').focus();
e.preventDefault();
});
$container.on('click', '.js-search-container .icon-clear', function (e) {
$container.find('.js-search-container .js-search-input').val('');
e.preventDefault();
});
$container.on('click', '.js-search-container .js-cancel', function (e) {
$container.find('.js-search-container').hide();
e.preventDefault();
});
}
var spinnerInterval = null;
// Animates spinners, kicks up a new timeout if needed
var startSpinner = function () {
if (spinnerInterval != null) return;
spinnerInterval =
setInterval(
function () {
var dots1 = $('.dot1');
var dots2 = $('.dot2');
var dots3 = $('.dot3');
var dots4 = $('.dot4');
if (!(shiftLeft(dots1, '.dot2') || shiftLeft(dots2, '.dot3') || shiftLeft(dots3, '.dot4') || shiftLeft(dots4))) {
$.each(dots1,
function (index, item) {
var defPadding = $(item).closest('.mobile-spinner').attr('spinnerPadding');
$(item).css({ paddingLeft: defPadding + 'px' });
}
);
}
},
20);
};
// Kills spinner animations if there aren't any left in the DOM
var stopSpinner = function () {
if (spinnerInterval != null && $('.mobile-spinner').length == 0) {
clearInterval(spinnerInterval);
spinnerInterval = null;
}
};
var shiftLeft = function (items, shiftRight) {
var ret = false;
$.each(items,
function (index, item) {
var dot = $(item);
var curPadding = dot.css('padding-left');
if (curPadding == null || curPadding == '0px') return;
var newPadding = +curPadding.substring(0, curPadding.length - 2);
newPadding--;
dot.css({ paddingLeft: newPadding + 'px' });
if (shiftRight) {
var next = dot.siblings(shiftRight);
var padding = next.css('padding-left');
padding = +padding.substring(0, padding.length - 2);
padding++;
next.css({ paddingLeft: padding + 'px' });
}
ret = true;
}
);
return ret;
};
// replace all .spoiler's with a "click to show" box
var hideSpoilers = function () {
$('.spoiler').each(
function (index, i) {
var item = $(i);
item.removeClass('spoiler').addClass('spoiler-overlay');
var children = item.children();
children.remove();
item.append('
' + __tr(["Click to show spoiler"], undefined, "en", []) + '
');
item.one(
'click',
function () {
item.empty();
item.append(children);
item.removeClass('spoiler-overlay').addClass('spoiler').addClass("is-visible");
}
);
}
);
};
function flagShowPopup(popup, clicked) {
showPopup(popup, clicked, popup.data('postid'));
}
function closeShowPopup(popup, clicked) {
showPopup(popup, clicked, popup.data('questionid'));
}
function showPopup(popup, clicked, postId) {
var container = getMenuContainerForPost(postId);
// flag and close will clean up after themselves
container.children().not('#popup-flag-post, #popup-close-question').remove();
popup.detach().appendTo(container);
scrollTo(0, clicked.offset().top);
clicked.addClass('util-link-active');
popup.on('popupClose', function() {
$('.util-link-active').removeClass('util-link-active');
container.empty();
});
container.show();
}
function getMenuContainerForPost(postId) {
return $('.menu-popup-container[data-postid=' + postId + ']');
}
var initDeleteLinks = function () {
$('.js-delete-post').each(
function (index, i) {
var link = $(i);
var postId = link.closest('.js-post-menu').attr('data-post-id');
link.click(
function (e) {
e.stopPropagation(); // prevents execution of .live handlers in 04_Vote.js
if (!confirm(__tr(["Vote to delete this post?"], undefined, "en", []))) return;
StackExchange.vote.submit({
$target: link,
postId: postId,
voteTypeId: StackExchange.vote.voteTypeIds.deletion,
success: function () { window.location.reload(); }
});
}
);
}
);
$('.js-restore-post').each(
function (index, i) {
var link = $(i);
var postId = link.closest('.js-post-menu').attr('data-post-id');
link.click(
function (e) {
e.stopPropagation();
if (!confirm(__tr(["Vote to undelete this post?"], undefined, "en", []))) return;
StackExchange.vote.submit({
$target: link,
postId: postId,
voteTypeId: StackExchange.vote.voteTypeIds.undeletion,
success: function () { window.location.reload(); }
});
}
);
}
);
};
function initModeratorLinks() {
if ($('[data-controller="se-mod-button"]').length > 0) {
StackExchange.moderator.initMenus();
return;
}
}
return {
// Set the number of unread notifications
setUnreadNotificationsCount: function (count) {
unreadNotifications = count;
},
// Init draft monitoring, and fill in any old draft values if they're in localStorage
initDraft: function (type, formSelector, submitSelector, immediateSave) {
if (!window.localStorage) return; // utterly dependent on localStorage for this on mobile, so bail if its not around
var form = $(formSelector);
var body = $(form.find('.wmd-input')[0]);
var tags = form.find('.tagnames');
var title = form.find('.title');
if (tags.length > 0) {
tags = $(tags[0]);
}
if (title.length > 0) {
title = $(title[0]);
}
var storageKey = "mobile-draft-" + type;
var draft = window.localStorage[storageKey];
if (draft) {
draft = JSON.parse(draft);
body.val(draft.body);
title.val(draft.title);
tags.val(draft.tags);
}
var save = function () {
if (body.val() || title.val() || tags.val()) {
window.localStorage[storageKey] = JSON.stringify({ body: body.val(), title: title.val(), tags: tags.val() });
} else {
window.localStorage.removeItem(storageKey);
}
};
if (immediateSave) {
save();
}
var saveInterval = setInterval(
save,
5000
);
$(submitSelector).click(
function () {
clearInterval(saveInterval);
window.localStorage.removeItem(storageKey);
}
);
body.blur(save);
tags.blur(save);
title.blur(save);
},
// Highlights interesting tags, and dims or hides ignored tags
applyTagPrefs: function (interesting, ignored, hideIgnored, dontApply) {
var wIgnored = [],
wInteresting = [];
if (dontApply) {
var nInt = [],
nIgn = [];
if (interesting) {
for (var i = 0; i < interesting.length; i++) {
if (dontApply.indexOf(interesting[i]) == -1) {
if (/\*/.test(interesting[i]))
wInteresting.push(new RegExp(interesting[i].replace(/([.+])/g, "\\$1").replace(/\*/g, ".*")));
else
nInt.push(interesting[i]);
}
}
interesting = nInt;
}
if (ignored) {
for (var i = 0; i < ignored.length; i++) {
if (dontApply.indexOf(ignored[i]) == -1) {
if (/\*/.test(ignored[i]))
wIgnored.push(new RegExp(ignored[i].replace(/([.+])/g, "\\$1").replace(/\*/g, ".*")));
else
nIgn.push(ignored[i]);
}
}
ignored = nIgn;
}
}
$('.post-tag').each(
function (index, ii) {
var item = $(ii),
text = item.text();
if (ignored) {
var isIgnored = false;
for (var i = 0; i < ignored.length; i++) {
if (text == ignored[i]) {
isIgnored = true;
break;
}
}
for (var i = 0; i < wIgnored.length; i++) {
if (wIgnored[i].test(text) && dontApply.indexOf(text) == -1) {
isIgnored = true;
break;
}
}
if (isIgnored) {
var onQ = item.parents('.-summary').addClass('tagged-ignored');
if (hideIgnored) {
onQ.hide();
}
}
}
if (interesting) {
var isInteresting = false;
for (var i = 0; i < interesting.length; i++) {
if (text == interesting[i]) {
isInteresting = true;
break;
}
}
for (var i = 0; i < wInteresting.length; i++) {
if (wInteresting[i].test(text) && dontApply.indexOf(text) == -1) {
isInteresting = true;
break;
}
}
if (isInteresting) {
item.parents('.-summary').addClass('tagged-interesting');
}
}
}
);
},
// For all items in the selector, shrink them if they are larger than maxHeight (overflow:hidden style) and add a show more link.
shrinkAndShowMore: function (selector, maxPixelHeight) {
$(selector).each(
function (index, item) {
var i = $(item);
if (i.height() <= maxPixelHeight) return;
var resetTo = { overflowY: i.css('overflow-y'), maxHeight: i.css('max-height') };
i.css({ overflowY: 'hidden', maxHeight: maxPixelHeight + 'px' });
var showMore = $('');
i.after(showMore);
showMore.click(
function () {
showMore.remove();
i.css(resetTo);
}
);
// For now, do the CSS-s-s-ing in code. May rely purely on styles in the future.
showMore.css({ backgroundColor: i.css('background-color'), fontSize: '12px' });
}
);
},
// Add a spinner to everything matched by selector (or just pass in a DOM object)
// The displayed message = msg, or 'loading' if msg is not set
addSpinner: function (selector, msg) {
$(selector).each(
function (index, item) {
if (!msg) msg = "loading";
var spinner = $('....');
$(item).append(spinner);
$(spinner).find('.spinner-message').text(msg);
var dotWidth = $(spinner).find('.dot1').width() + $(spinner).find('.dot2').width() + $(spinner).find('.dot3').width();
var messageWidth = $(spinner).find('.spinner-message').width();
var clipWidth = messageWidth + (dotWidth);
$(spinner).css({ width: clipWidth + 'px', overflow: 'hidden', display: 'block' });
$(spinner).find('.dot1').css({ paddingLeft: (dotWidth * 2) + 'px' });
$(spinner).find('.dot2').css({ paddingLeft: '0px' });
$(spinner).find('.dot3').css({ paddingLeft: '0px' });
$(spinner).find('.dot4').css({ paddingLeft: '0px' });
$(spinner).attr('spinnerPadding', dotWidth * 2);
}
);
startSpinner();
},
// Remove all spinners from the passed in selector (or DOM object)
removeSpinner: function (selector) {
$(selector).find('.mobile-spinner').remove();
stopSpinner();
},
init: function () {
$(
function () {
initSubmitOnChanges();
initSearchBox();
hideSpoilers();
if (StackExchange.vote_closingAndFlagging) {
StackExchange.vote_closingAndFlagging.init({
closeShowPopup: closeShowPopup,
flagShowPopup: flagShowPopup
});
}
initDeleteLinks();
initModeratorLinks();
}
);
},
// Gotta re-export this for ajax search
initSearchBox: initSearchBox
};
}();
StackExchange.mobile.overlay = function () {
var $overlay, $overlayTrigger, $overlayCloseTrigger;
function checkOverlay() {
$overlayTrigger.on('change', function () {
var cssClass = "_blocked";
if ($(this).hasClass("js-stop-scrolling")) {
cssClass = "stop-scrolling-mobile";
}
if ($(this).is(':checked')) {
$('body').addClass(cssClass);
} else {
$('body').removeClass(cssClass);
}
});
}
function closeOverlay() {
$overlayCloseTrigger.on('click', function () {
hideOverlay();
});
}
function closeAndScrollTo(scrollToElem) {
hideOverlay();
if (scrollToElem) {
$('html, body').scrollTop(scrollToElem.offset().top);
}
}
function hideOverlay() {
$overlayTrigger.prop("checked", false).trigger('change');
}
return {
init: function () {
$overlay = $('.overlay');
$overlayTrigger = $('.js-overlay-trigger');
$overlayCloseTrigger = $overlay.find('.js-close');
checkOverlay();
closeOverlay();
},
close: closeOverlay,
hide: hideOverlay,
closeAndScrollTo: closeAndScrollTo
}
}();
StackExchange.mobile.uploader = function() {
var $imgUrl, $imgUrlField, $imgUrlInput, $imgUrlInfo, $area, $filePreview, $fileInput, $errorTarget, $button, $file, $scrollToTarget;
function showUrlField() {
$imgUrlInfo.addClass('hidden-important');
$imgUrlField
.removeClass('hidden-important')
.find('[type="url"]').focus();
}
function hideUrlField() {
$imgUrlInfo.removeClass('hidden-important');
$imgUrlField
.addClass('hidden-important')
.find('[type="url"]').val('');
}
function toggleNote() {
$imgUrl.toggleClass('hidden-important');
$('.js-restart').toggleClass('hidden-important');
}
function togglePreview(action) {
if (action == true) {
$area
.find('figure').addClass('hidden-important').end()
.find('label').removeClass('hidden-important');
} else if (action == false) {
$area
.find('figure').removeClass('hidden-important').end()
.find('label').addClass('hidden-important');
}
}
function selectFile() {
$fileInput.on('change', function () {
var input = this;
if (input.files && input.files[0]) {
var reader = new FileReader();
var inputFile = input.files[0];
reader.onloadend = function (e) {
$filePreview.attr('src', e.target.result);
$file = inputFile;
togglePreview(false);
toggleNote();
}
reader.readAsDataURL(inputFile);
}
});
}
function resetForm() {
$button.removeClass('loading');
$imgUrlInput.val('');
$fileInput.val('');
$file = '';
$errorTarget.hide();
togglePreview(true);
hideUrlField();
toggleNote();
}
function appendMarkdown(url) {
var wmdInput = $("#wmd-input");
var existingText = wmdInput.val();
existingText += '![' + __tr(["enter image description here"], undefined, "en", []) +'](' + url + ')';
wmdInput.val(existingText);
}
function doUpload() {
if ($imgUrlInput.val().length) {
appendMarkdown($imgUrlInput.val()); // append URL to editor
resetForm();
StackExchange.mobile.overlay.closeAndScrollTo($scrollToTarget); // close popup
} else if ($file) {
var formData = new window.FormData();
$errorTarget.hide();
$button.addClass('loading');
formData.append('file', $file);
formData.append('fkey', StackExchange.options.user.fkey);
$.ajax({
url: "/upload/image/json",
data: formData,
cache: false,
contentType: false,
processData: false,
type: 'POST',
success: function(data) {
if (data && data.Success) {
appendMarkdown(data.UploadedImage);
resetForm();
StackExchange.mobile.overlay.closeAndScrollTo($scrollToTarget);
} else {
$errorTarget.text(data.ErrorMessage).show();
}
},
complete: function() {
$button.removeClass('loading');
}
});
}
}
return {
init: function () {
$button = $('.js-submit');
$imgUrl = $('.js-image-url');
$imgUrlInfo = $imgUrl.find('.js-image-url-info');
$imgUrlField = $imgUrl.find('.js-image-url-field');
$imgUrlInput = $imgUrl.find('input[type=url]');
$area = $('.js-area');
$fileInput = $area.find('.js-image-input');
$filePreview = $area.find('figure > img');
$errorTarget = $(".uploader-error");
$scrollToTarget = $('[data-role="uploader-scrolltotarget"]');
selectFile();
$('.js-image-url-trigger').on('click', function(e) {
e.preventDefault();
showUrlField();
});
$('.js-restart-trigger').on('click', function(e) {
e.preventDefault();
resetForm();
});
$('.js-image-url-cancel').on('click', function(e) {
e.preventDefault();
hideUrlField();
});
$(".js-close").on("click", function () {
StackExchange.mobile.overlay.closeAndScrollTo($scrollToTarget);
});
$button.click(doUpload);
}
}
}();
})();
/******/ })()
;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"mobile.[locale:b64b2e3f].js","mappings":";;UAAA;UACA;;;;;WCDA;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D;;;;;WCNA;;;;;;;;;;;;;ACAA,kFAAkF;AAClF,+DAA+D;AAC/D,0CAA0C;AAC1C,8EAA8E;AAC9E,kEAAkE;AAClE,qBAAuB,GAAG,QAAQ,CAAC,cAAc,CAAC,qBAAqB,CAAC,CAAC,SAAS,GAAG,KAAK,CAAC;;;;;;;;;;ACL3F;;;AAGA,kEAAkE;AAClE,kEAAkE;;;AAGlE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,gCAAgC;AAC9E;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,gCAAgC;AAC1D;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,6BAA6B;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oEAAoE,sFAA2B;AAC/F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C;AAC7C,qCAAqC,0FAA+B;AACpE;AACA;AACA;AACA;AACA;AACA,mDAAmD;AACnD,yBAAyB;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC,4FAAiC;AACtE;AACA;AACA;AACA;AACA;AACA,mDAAmD;AACnD,yBAAyB;AACzB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,8CAA8C;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uEAAuE,wDAAwD;AAC/H,kBAAkB;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,wBAAwB;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,oBAAoB;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC,oBAAoB;AAC5D;AACA;AACA;AACA;AACA;AACA,wCAAwC,qBAAqB;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC,wBAAwB;AAChE;AACA;AACA;AACA;AACA;AACA,wCAAwC,yBAAyB;AACjE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC;AACpC;AACA,4BAA4B,uDAAuD;AACnF,4EAA4E,0EAAe;AAC3F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,8DAA8D;AACjG;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC,+DAA+D;AACpG,mDAAmD,oCAAoC;AACvF,mDAAmD,oBAAoB;AACvE,mDAAmD,oBAAoB;AACvE,mDAAmD,oBAAoB;AACvE;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB;AACzB;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,EAAE;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,6FAAkC;AACjE;AACA;AACA;AACA;AACA;AACA,gDAAgD;AAChD;AACA,4EAA4E;AAC5E,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,CAAC","sources":["webpack://stackoverflow/webpack/bootstrap","webpack://stackoverflow/webpack/runtime/make namespace object","webpack://stackoverflow/webpack/runtime/publicPath","webpack://stackoverflow/./_Scripts/_Includes/set-public-path.mod.ts","webpack://stackoverflow/./_Scripts/LegacyJS/mobile.js"],"sourcesContent":["// The require scope\nvar __webpack_require__ = {};\n\n","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.p = \"\";","// We need to set the public path at runtime based on the GlobalRoot site setting.\r\n// (We don't know at build time where the static files will be,\r\n// since we could be deployed on-premise.)\r\n// The value of that site setting gets written out to the dom in Master.cshtml\r\n// (see JavaScriptHelper.PublicPath()) so that we can read it here\r\n__webpack_public_path__ = document.getElementById(\"webpack-public-path\").innerText + \"Js/\";\r\n\r\nexport { };\r\n","/*** IMPORTS FROM imports-loader ***/\n\n\nStackExchange = window.StackExchange = (window.StackExchange || {});\nStackOverflow = window.StackOverflow = (window.StackOverflow || {});\n\n\n\"use strict\";\r\n\r\n// Served only as part of the mobile skin.\r\n//   Does all the custom UI bits.  Generally,\r\n//   we try to re-use javascript from full(-anon),\r\n//   syntax highlighting, and so on.  Having to re-implement\r\n//   the site's javascript just for mobile would\r\n//   be brutal.\r\n\r\nStackExchange.mobile = function () {\r\n    var unreadNotifications;\r\n\r\n    // common idiom is to submit a form after an input change on mobile.\r\n    var initSubmitOnChanges =\r\n        function () {\r\n            $('.submit-on-change').change(\r\n                function () {\r\n                    $(this).closest('form').submit();\r\n                }\r\n            );\r\n        };\r\n\r\n    // hook up search box\r\n    function initSearchBox($container) {\r\n\r\n        if ($container === undefined) {\r\n            $container = $('.js-search-container').closest('.subheader');\r\n        }\r\n\r\n        $container.on('submit', '.js-search-container.js-no-submit', function (e) {\r\n            e.preventDefault();\r\n            e.stopPropagation();\r\n        });\r\n\r\n        $container.on('click', '.js-search-trigger', function (e) {\r\n            $container.find('.js-search-container').show();\r\n            $container.find('.js-search-input').focus();\r\n            e.preventDefault();\r\n        });\r\n\r\n        $container.on('click', '.js-search-container .icon-clear', function (e) {\r\n            $container.find('.js-search-container .js-search-input').val('');\r\n            e.preventDefault();\r\n        });\r\n\r\n        $container.on('click', '.js-search-container .js-cancel', function (e) {\r\n            $container.find('.js-search-container').hide();\r\n            e.preventDefault();\r\n        });\r\n    }\r\n\r\n    var spinnerInterval = null;\r\n\r\n    // Animates spinners, kicks up a new timeout if needed\r\n    var startSpinner = function () {\r\n        if (spinnerInterval != null) return;\r\n\r\n        spinnerInterval =\r\n            setInterval(\r\n                function () {\r\n                    var dots1 = $('.dot1');\r\n                    var dots2 = $('.dot2');\r\n                    var dots3 = $('.dot3');\r\n                    var dots4 = $('.dot4');\r\n\r\n                    if (!(shiftLeft(dots1, '.dot2') || shiftLeft(dots2, '.dot3') || shiftLeft(dots3, '.dot4') || shiftLeft(dots4))) {\r\n                        $.each(dots1,\r\n                            function (index, item) {\r\n                                var defPadding = $(item).closest('.mobile-spinner').attr('spinnerPadding');\r\n\r\n                                $(item).css({ paddingLeft: defPadding + 'px' });\r\n                            }\r\n                        );\r\n                    }\r\n                },\r\n            20);\r\n    };\r\n\r\n    // Kills spinner animations if there aren't any left in the DOM\r\n    var stopSpinner = function () {\r\n        if (spinnerInterval != null && $('.mobile-spinner').length == 0) {\r\n            clearInterval(spinnerInterval);\r\n            spinnerInterval = null;\r\n        }\r\n    };\r\n\r\n    var shiftLeft = function (items, shiftRight) {\r\n        var ret = false;\r\n\r\n        $.each(items,\r\n            function (index, item) {\r\n                var dot = $(item);\r\n                var curPadding = dot.css('padding-left');\r\n                if (curPadding == null || curPadding == '0px') return;\r\n\r\n                var newPadding = +curPadding.substring(0, curPadding.length - 2);\r\n                newPadding--;\r\n\r\n                dot.css({ paddingLeft: newPadding + 'px' });\r\n\r\n                if (shiftRight) {\r\n                    var next = dot.siblings(shiftRight);\r\n                    var padding = next.css('padding-left');\r\n                    padding = +padding.substring(0, padding.length - 2);\r\n                    padding++;\r\n                    next.css({ paddingLeft: padding + 'px' });\r\n                }\r\n\r\n                ret = true;\r\n            }\r\n        );\r\n\r\n        return ret;\r\n    };\r\n\r\n    // replace all .spoiler's with a \"click to show\" box\r\n    var hideSpoilers = function () {\r\n        $('.spoiler').each(\r\n            function (index, i) {\r\n                var item = $(i);\r\n\r\n                item.removeClass('spoiler').addClass('spoiler-overlay');\r\n                var children = item.children();\r\n\r\n                children.remove();\r\n\r\n                item.append('<div class=\"spoiler-click-to-show\">' + _s('Click to show spoiler') + '</div>');\r\n\r\n                item.one(\r\n                    'click',\r\n                    function () {\r\n                        item.empty();\r\n                        item.append(children);\r\n                        item.removeClass('spoiler-overlay').addClass('spoiler').addClass(\"is-visible\");\r\n                    }\r\n                );\r\n            }\r\n        );\r\n    };\r\n\r\n    function flagShowPopup(popup, clicked) {\r\n        showPopup(popup, clicked, popup.data('postid'));\r\n    }\r\n    \r\n    function closeShowPopup(popup, clicked) {\r\n        showPopup(popup, clicked, popup.data('questionid'));\r\n    }\r\n    \r\n    function showPopup(popup, clicked, postId) {\r\n        var container = getMenuContainerForPost(postId);\r\n\r\n        // flag and close will clean up after themselves\r\n        container.children().not('#popup-flag-post, #popup-close-question').remove();\r\n        popup.detach().appendTo(container);\r\n        scrollTo(0, clicked.offset().top);\r\n        clicked.addClass('util-link-active');\r\n\r\n        popup.on('popupClose', function() {\r\n            $('.util-link-active').removeClass('util-link-active');\r\n            container.empty();\r\n        });\r\n\r\n        container.show();\r\n    }\r\n\r\n    function getMenuContainerForPost(postId) {\r\n        return $('.menu-popup-container[data-postid=' + postId + ']');\r\n    }\r\n\r\n    var initDeleteLinks = function () {\r\n        $('.js-delete-post').each(\r\n            function (index, i) {\r\n                var link = $(i);\r\n                var postId = link.closest('.js-post-menu').attr('data-post-id');\r\n\r\n                link.click(\r\n                    function (e) {\r\n                        e.stopPropagation(); // prevents execution of .live handlers in 04_Vote.js\r\n                        if (!confirm(_s(\"Vote to delete this post?\"))) return;\r\n\r\n                        StackExchange.vote.submit({\r\n                            $target: link,\r\n                            postId: postId,\r\n                            voteTypeId: StackExchange.vote.voteTypeIds.deletion,\r\n                            success: function () { window.location.reload(); }\r\n                        });\r\n                    }\r\n                );\r\n            }\r\n        );\r\n\r\n        $('.js-restore-post').each(\r\n            function (index, i) {\r\n                var link = $(i);\r\n\r\n                var postId = link.closest('.js-post-menu').attr('data-post-id');\r\n\r\n                link.click(\r\n                    function (e) {\r\n                        e.stopPropagation();\r\n                        if (!confirm(_s(\"Vote to undelete this post?\"))) return;\r\n\r\n                        StackExchange.vote.submit({\r\n                            $target: link,\r\n                            postId: postId,\r\n                            voteTypeId: StackExchange.vote.voteTypeIds.undeletion,\r\n                            success: function () { window.location.reload(); }\r\n                        });\r\n                    }\r\n                );\r\n            }\r\n        );\r\n    };\r\n\r\n    function initModeratorLinks() {\r\n        if ($('[data-controller=\"se-mod-button\"]').length > 0) {\r\n            StackExchange.moderator.initMenus();\r\n            return;\r\n        }\r\n    }\r\n\r\n    return {\r\n        // Set the number of unread notifications\r\n        setUnreadNotificationsCount: function (count) {\r\n            unreadNotifications = count;\r\n        },\r\n\r\n        // Init draft monitoring, and fill in any old draft values if they're in localStorage\r\n        initDraft: function (type, formSelector, submitSelector, immediateSave) {\r\n            if (!window.localStorage) return; // utterly dependent on localStorage for this on mobile, so bail if its not around\r\n\r\n            var form = $(formSelector);\r\n\r\n            var body = $(form.find('.wmd-input')[0]);\r\n            var tags = form.find('.tagnames');\r\n            var title = form.find('.title');\r\n\r\n            if (tags.length > 0) {\r\n                tags = $(tags[0]);\r\n            }\r\n\r\n            if (title.length > 0) {\r\n                title = $(title[0]);\r\n            }\r\n\r\n            var storageKey = \"mobile-draft-\" + type;\r\n\r\n            var draft = window.localStorage[storageKey];\r\n\r\n            if (draft) {\r\n                draft = JSON.parse(draft);\r\n\r\n                body.val(draft.body);\r\n                title.val(draft.title);\r\n                tags.val(draft.tags);\r\n            }\r\n\r\n            var save = function () {\r\n                if (body.val() || title.val() || tags.val()) {\r\n                    window.localStorage[storageKey] = JSON.stringify({ body: body.val(), title: title.val(), tags: tags.val() });\r\n                } else {\r\n                    window.localStorage.removeItem(storageKey);\r\n                }\r\n            };\r\n\r\n            if (immediateSave) {\r\n                save();\r\n            }\r\n\r\n            var saveInterval = setInterval(\r\n                save,\r\n                5000\r\n            );\r\n\r\n            $(submitSelector).click(\r\n                function () {\r\n                    clearInterval(saveInterval);\r\n\r\n                    window.localStorage.removeItem(storageKey);\r\n                }\r\n            );\r\n\r\n            body.blur(save);\r\n            tags.blur(save);\r\n            title.blur(save);\r\n        },\r\n\r\n        // Highlights interesting tags, and dims or hides ignored tags\r\n        applyTagPrefs: function (interesting, ignored, hideIgnored, dontApply) {\r\n            var wIgnored = [],\r\n                wInteresting = [];\r\n\r\n            if (dontApply) {\r\n                var nInt = [],\r\n                    nIgn = [];\r\n\r\n                if (interesting) {\r\n                    for (var i = 0; i < interesting.length; i++) {\r\n                        if (dontApply.indexOf(interesting[i]) == -1) {\r\n                            if (/\\*/.test(interesting[i]))\r\n                                wInteresting.push(new RegExp(interesting[i].replace(/([.+])/g, \"\\\\$1\").replace(/\\*/g, \".*\")));\r\n                            else\r\n                                nInt.push(interesting[i]);\r\n                        }\r\n                    }\r\n                    interesting = nInt;\r\n                }\r\n\r\n                if (ignored) {\r\n                    for (var i = 0; i < ignored.length; i++) {\r\n                        if (dontApply.indexOf(ignored[i]) == -1) {\r\n                            if (/\\*/.test(ignored[i]))\r\n                                wIgnored.push(new RegExp(ignored[i].replace(/([.+])/g, \"\\\\$1\").replace(/\\*/g, \".*\")));\r\n                            else\r\n                                nIgn.push(ignored[i]);\r\n                        }\r\n                    }\r\n                    ignored = nIgn;\r\n                }\r\n            }\r\n\r\n            $('.post-tag').each(\r\n                function (index, ii) {\r\n                    var item = $(ii),\r\n                        text = item.text();\r\n\r\n                    if (ignored) {\r\n                        var isIgnored = false;\r\n\r\n                        for (var i = 0; i < ignored.length; i++) {\r\n                            if (text == ignored[i]) {\r\n                                isIgnored = true;\r\n                                break;\r\n                            }\r\n                        }\r\n                        for (var i = 0; i < wIgnored.length; i++) {\r\n                            if (wIgnored[i].test(text) && dontApply.indexOf(text) == -1) {\r\n                                isIgnored = true;\r\n                                break;\r\n                            }\r\n                        }\r\n\r\n                        if (isIgnored) {\r\n                            var onQ = item.parents('.-summary').addClass('tagged-ignored');\r\n\r\n                            if (hideIgnored) {\r\n                                onQ.hide();\r\n                            }\r\n                        }\r\n                    }\r\n\r\n                    if (interesting) {\r\n                        var isInteresting = false;\r\n\r\n                        for (var i = 0; i < interesting.length; i++) {\r\n                            if (text == interesting[i]) {\r\n                                isInteresting = true;\r\n                                break;\r\n                            }\r\n                        }\r\n                        for (var i = 0; i < wInteresting.length; i++) {\r\n                            if (wInteresting[i].test(text) && dontApply.indexOf(text) == -1) {\r\n                                isInteresting = true;\r\n                                break;\r\n                            }\r\n                        }\r\n\r\n                        if (isInteresting) {\r\n                            item.parents('.-summary').addClass('tagged-interesting');\r\n                        }\r\n                    }\r\n                }\r\n            );\r\n        },\r\n\r\n        // For all items in the selector, shrink them if they are larger than maxHeight (overflow:hidden style) and add a show more link.\r\n        shrinkAndShowMore: function (selector, maxPixelHeight) {\r\n            $(selector).each(\r\n                function (index, item) {\r\n                    var i = $(item);\r\n                    if (i.height() <= maxPixelHeight) return;\r\n\r\n                    var resetTo = { overflowY: i.css('overflow-y'), maxHeight: i.css('max-height') };\r\n\r\n                    i.css({ overflowY: 'hidden', maxHeight: maxPixelHeight + 'px' });\r\n                    var showMore = $('<div class=\"generic-show-more\"><a>' + _s('show more') + '</a></div>');\r\n                    i.after(showMore);\r\n\r\n                    showMore.click(\r\n                        function () {\r\n                            showMore.remove();\r\n                            i.css(resetTo);\r\n                        }\r\n                    );\r\n\r\n                    // For now, do the CSS-s-s-ing in code.  May rely purely on styles in the future.\r\n                    showMore.css({ backgroundColor: i.css('background-color'), fontSize: '12px' });\r\n                }\r\n            );\r\n\r\n        },\r\n\r\n        // Add a spinner to everything matched by selector (or just pass in a DOM object)\r\n        //    The displayed message = msg, or 'loading' if msg is not set\r\n        addSpinner: function (selector, msg) {\r\n            $(selector).each(\r\n                function (index, item) {\r\n                    if (!msg) msg = \"loading\";\r\n\r\n                    var spinner = $('<span class=\"mobile-spinner\"><span class=\"spinner-message\"></span><span class=\"dot1\">.</span><span class=\"dot2\">.</span><span class=\"dot3\">.</span><span class=\"dot4\">.</span></span>');\r\n\r\n                    $(item).append(spinner);\r\n                    $(spinner).find('.spinner-message').text(msg);\r\n\r\n                    var dotWidth = $(spinner).find('.dot1').width() + $(spinner).find('.dot2').width() + $(spinner).find('.dot3').width();\r\n                    var messageWidth = $(spinner).find('.spinner-message').width();\r\n\r\n                    var clipWidth = messageWidth + (dotWidth);\r\n\r\n                    $(spinner).css({ width: clipWidth + 'px', overflow: 'hidden', display: 'block' });\r\n                    $(spinner).find('.dot1').css({ paddingLeft: (dotWidth * 2) + 'px' });\r\n                    $(spinner).find('.dot2').css({ paddingLeft: '0px' });\r\n                    $(spinner).find('.dot3').css({ paddingLeft: '0px' });\r\n                    $(spinner).find('.dot4').css({ paddingLeft: '0px' });\r\n\r\n                    $(spinner).attr('spinnerPadding', dotWidth * 2);\r\n                }\r\n            );\r\n\r\n            startSpinner();\r\n        },\r\n\r\n        // Remove all spinners from the passed in selector (or DOM object)\r\n        removeSpinner: function (selector) {\r\n            $(selector).find('.mobile-spinner').remove();\r\n\r\n            stopSpinner();\r\n        },\r\n\r\n        init: function () {\r\n            $(\r\n                function () {\r\n                    initSubmitOnChanges();\r\n                    initSearchBox();\r\n                    hideSpoilers();\r\n\r\n                    if (StackExchange.vote_closingAndFlagging) {\r\n                        StackExchange.vote_closingAndFlagging.init({\r\n                             closeShowPopup: closeShowPopup,\r\n                             flagShowPopup: flagShowPopup\r\n                        });\r\n                    }\r\n\r\n                    initDeleteLinks();\r\n                    initModeratorLinks();\r\n                }\r\n            );\r\n        },\r\n        // Gotta re-export this for ajax search\r\n        initSearchBox: initSearchBox\r\n    };\r\n}();\r\n\r\nStackExchange.mobile.overlay = function () {\r\n    var $overlay, $overlayTrigger, $overlayCloseTrigger;\r\n    function checkOverlay() {\r\n        $overlayTrigger.on('change', function () {\r\n            var cssClass = \"_blocked\";\r\n            if ($(this).hasClass(\"js-stop-scrolling\")) {\r\n                cssClass = \"stop-scrolling-mobile\";\r\n            }\r\n\r\n            if ($(this).is(':checked')) {\r\n                $('body').addClass(cssClass);\r\n            } else {\r\n                $('body').removeClass(cssClass);\r\n            }\r\n        });\r\n    }\r\n \r\n    function closeOverlay() {\r\n        $overlayCloseTrigger.on('click', function () {\r\n            hideOverlay();\r\n        });\r\n    }\r\n\r\n    function closeAndScrollTo(scrollToElem) {\r\n        hideOverlay();\r\n        if (scrollToElem) {\r\n            $('html, body').scrollTop(scrollToElem.offset().top);\r\n        }\r\n    }\r\n\r\n    function hideOverlay() {\r\n        $overlayTrigger.prop(\"checked\", false).trigger('change');\r\n    }\r\n \r\n    return {\r\n        init: function () {\r\n            $overlay = $('.overlay');\r\n            $overlayTrigger = $('.js-overlay-trigger');\r\n            $overlayCloseTrigger = $overlay.find('.js-close');\r\n\r\n            checkOverlay();\r\n            closeOverlay();\r\n        },\r\n        close: closeOverlay,\r\n        hide: hideOverlay,\r\n        closeAndScrollTo: closeAndScrollTo\r\n    }\r\n }();\r\n\r\nStackExchange.mobile.uploader = function() {\r\n    var $imgUrl, $imgUrlField, $imgUrlInput, $imgUrlInfo, $area, $filePreview, $fileInput, $errorTarget, $button, $file, $scrollToTarget;\r\n\r\n    function showUrlField() {\r\n        $imgUrlInfo.addClass('hidden-important');\r\n        $imgUrlField\r\n            .removeClass('hidden-important')\r\n            .find('[type=\"url\"]').focus();\r\n    }\r\n\r\n    function hideUrlField() {\r\n        $imgUrlInfo.removeClass('hidden-important');\r\n        $imgUrlField\r\n            .addClass('hidden-important')\r\n            .find('[type=\"url\"]').val('');\r\n    }\r\n\r\n    function toggleNote() {\r\n        $imgUrl.toggleClass('hidden-important');\r\n        $('.js-restart').toggleClass('hidden-important');\r\n    }\r\n\r\n    function togglePreview(action) {\r\n        if (action == true) {\r\n            $area\r\n                .find('figure').addClass('hidden-important').end()\r\n                .find('label').removeClass('hidden-important');\r\n        } else if (action == false) {\r\n            $area\r\n                .find('figure').removeClass('hidden-important').end()\r\n                .find('label').addClass('hidden-important');\r\n        }\r\n    }\r\n\r\n    function selectFile() {\r\n        $fileInput.on('change', function () {\r\n            var input = this;\r\n\r\n            if (input.files && input.files[0]) {\r\n                var reader = new FileReader();\r\n                var inputFile = input.files[0];\r\n\r\n                reader.onloadend = function (e) {\r\n                    $filePreview.attr('src', e.target.result);\r\n                    $file = inputFile;\r\n\r\n                    togglePreview(false);\r\n                    toggleNote();\r\n                }\r\n\r\n                reader.readAsDataURL(inputFile);\r\n            }\r\n        });\r\n    }\r\n\r\n    function resetForm() {\r\n        $button.removeClass('loading');\r\n\r\n        $imgUrlInput.val('');\r\n        $fileInput.val(''); \r\n        $file = '';\r\n\r\n        $errorTarget.hide();\r\n        togglePreview(true);\r\n        hideUrlField();\r\n        toggleNote();\r\n    }\r\n\r\n    function appendMarkdown(url) {\r\n        var wmdInput = $(\"#wmd-input\");\r\n        var existingText = wmdInput.val();\r\n        existingText += '![' + _s(\"enter image description here\") +'](' + url + ')';\r\n        wmdInput.val(existingText);\r\n    }\r\n    \r\n    function doUpload() {\r\n        if ($imgUrlInput.val().length) {\r\n            appendMarkdown($imgUrlInput.val()); // append URL to editor\r\n            resetForm();\r\n            StackExchange.mobile.overlay.closeAndScrollTo($scrollToTarget); // close popup\r\n        } else if ($file) {\r\n            var formData = new window.FormData();\r\n            $errorTarget.hide();\r\n            $button.addClass('loading');\r\n\r\n            formData.append('file', $file);\r\n            formData.append('fkey', StackExchange.options.user.fkey);\r\n            $.ajax({\r\n                url: \"/upload/image/json\",\r\n                data: formData,\r\n                cache: false,\r\n                contentType: false,\r\n                processData: false,\r\n                type: 'POST',\r\n                success: function(data) {\r\n                    if (data && data.Success) {\r\n                        appendMarkdown(data.UploadedImage);\r\n                        resetForm();\r\n                        StackExchange.mobile.overlay.closeAndScrollTo($scrollToTarget);\r\n                    } else {\r\n                        $errorTarget.text(data.ErrorMessage).show();\r\n                    }\r\n                }, \r\n                complete: function() {\r\n                    $button.removeClass('loading');\r\n                }\r\n            });\r\n        }\r\n    }\r\n\r\n    return {\r\n        init: function () {\r\n            $button = $('.js-submit');\r\n            $imgUrl = $('.js-image-url');\r\n            $imgUrlInfo = $imgUrl.find('.js-image-url-info');\r\n            $imgUrlField = $imgUrl.find('.js-image-url-field');\r\n            $imgUrlInput = $imgUrl.find('input[type=url]');\r\n\r\n            $area = $('.js-area');\r\n            $fileInput = $area.find('.js-image-input');\r\n            $filePreview = $area.find('figure > img');\r\n\r\n            $errorTarget = $(\".uploader-error\");\r\n            $scrollToTarget = $('[data-role=\"uploader-scrolltotarget\"]');\r\n        \r\n            selectFile();\r\n\r\n            $('.js-image-url-trigger').on('click', function(e) {\r\n                e.preventDefault();\r\n                showUrlField();\r\n            });\r\n\r\n            $('.js-restart-trigger').on('click', function(e) {\r\n                e.preventDefault();\r\n                resetForm();\r\n            });\r\n\r\n            $('.js-image-url-cancel').on('click', function(e) {\r\n                e.preventDefault();\r\n                hideUrlField();\r\n            });\r\n\r\n            $(\".js-close\").on(\"click\", function () {\r\n                StackExchange.mobile.overlay.closeAndScrollTo($scrollToTarget);\r\n            });\r\n\r\n            $button.click(doUpload);\r\n        }\r\n    }\r\n}();"],"names":[],"sourceRoot":""}