diff --git a/CHANGELOG.md b/CHANGELOG.md index 16813227..171b862e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,6 +7,7 @@ * Moved preset CSS compile to earlier in the process to ensure compilation happens in time. * Prevent Save actions from Flex Objects to trigger the unsaved unload notice [#2125](https://github.com/getgrav/grav-plugin-admin/issues/2125) * Fixed audit vulnerabilities in module dependencies and house cleanup [#2096](https://github.com/getgrav/grav-plugin-admin/issues/2096) + * Fixed issue preventing Drag & Drop of media files while in Expert Mode [#1927](https://github.com/getgrav/grav-plugin-admin/issues/1927) # v1.10.12 ## 04/15/2021 diff --git a/themes/grav/app/pages/page/media.js b/themes/grav/app/pages/page/media.js index 17e46982..832b7eda 100644 --- a/themes/grav/app/pages/page/media.js +++ b/themes/grav/app/pages/page/media.js @@ -108,7 +108,9 @@ export default class PageMedia extends FilesField { onDropzoneComplete(file) { super.onDropzoneComplete(file); - this.sortable.options.onSort(); + if (this.sortable) { + this.sortable.options.onSort(); + } // accepted $('.dz-preview').prop('draggable', 'true'); @@ -116,7 +118,9 @@ export default class PageMedia extends FilesField { onDropzoneRemovedFile(file, ...extra) { super.onDropzoneRemovedFile(file, ...extra); - this.sortable.options.onSort(); + if (this.sortable) { + this.sortable.options.onSort(); + } } attachDragDrop() { diff --git a/themes/grav/js/admin.min.js b/themes/grav/js/admin.min.js index cb3d93a2..36c9c7ba 100644 --- a/themes/grav/js/admin.min.js +++ b/themes/grav/js/admin.min.js @@ -1,14798 +1,1161 @@ +/* + * ATTENTION: An "eval-source-map" devtool has been used. + * This devtool is neither made for production nor for readable output files. + * It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools. + * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/) + * or disable the default devtool with "devtool: false". + * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/). + */ var Grav; /******/ (() => { // webpackBootstrap /******/ var __webpack_modules__ = ({ -/***/ 469: +/***/ "./app/dashboard/backup.js": +/*!*********************************!*\ + !*** ./app/dashboard/backup.js ***! + \*********************************/ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; -// ESM COMPAT FLAG -__webpack_require__.r(__webpack_exports__); - -// EXPORTS -__webpack_require__.d(__webpack_exports__, { - "default": () => (/* binding */ main) -}); - -// EXTERNAL MODULE: ./node_modules/@babel/polyfill/lib/index.js -var lib = __webpack_require__(26981); -// EXTERNAL MODULE: external "jQuery" -var external_jQuery_ = __webpack_require__(73609); -var external_jQuery_default = /*#__PURE__*/__webpack_require__.n(external_jQuery_); -;// CONCATENATED MODULE: ./app/utils/remodal.js -/* Remodal from https://github.com/vodkabears/Remodal - * With Stackable option from https://github.com/antstorm/Remodal patch - */ - -!function (root, factory) { - return factory(root, (external_jQuery_default())); -}(undefined, function (global, $) { - 'use strict'; - /** - * Name of the plugin - * @private - * @const - * @type {String} - */ - - var PLUGIN_NAME = 'remodal'; - /** - * Namespace for CSS and events - * @private - * @const - * @type {String} - */ - - var NAMESPACE = window.REMODAL_GLOBALS && window.REMODAL_GLOBALS.NAMESPACE || PLUGIN_NAME; - /** - * Animationstart event with vendor prefixes - * @private - * @const - * @type {String} - */ - - var ANIMATIONSTART_EVENTS = $.map(['animationstart', 'webkitAnimationStart', 'MSAnimationStart', 'oAnimationStart'], function (eventName) { - return eventName + '.' + NAMESPACE; - }).join(' '); - /** - * Animationend event with vendor prefixes - * @private - * @const - * @type {String} - */ - - var ANIMATIONEND_EVENTS = $.map(['animationend', 'webkitAnimationEnd', 'MSAnimationEnd', 'oAnimationEnd'], function (eventName) { - return eventName + '.' + NAMESPACE; - }).join(' '); - /** - * Default settings - * @private - * @const - * @type {Object} - */ - - var DEFAULTS = $.extend({ - hashTracking: true, - closeOnConfirm: true, - closeOnCancel: true, - closeOnEscape: true, - closeOnOutsideClick: true, - modifier: '', - stack: false, - appendTo: null - }, window.REMODAL_GLOBALS && window.REMODAL_GLOBALS.DEFAULTS); - /** - * States of the Remodal - * @private - * @const - * @enum {String} - */ - - var STATES = { - CLOSING: 'closing', - CLOSED: 'closed', - OPENING: 'opening', - OPENED: 'opened' - }; - /** - * Reasons of the state change. - * @private - * @const - * @enum {String} - */ - - var STATE_CHANGE_REASONS = { - CONFIRMATION: 'confirmation', - CANCELLATION: 'cancellation' - }; - /** - * Is animation supported? - * @private - * @const - * @type {Boolean} - */ - - var IS_ANIMATION = function () { - var style = document.createElement('div').style; - return style.animationName !== undefined || style.WebkitAnimationName !== undefined || style.MozAnimationName !== undefined || style.msAnimationName !== undefined || style.OAnimationName !== undefined; - }(); - /** - * Is iOS? - * @private - * @const - * @type {Boolean} - */ - - - var IS_IOS = /iPad|iPhone|iPod/.test(navigator.platform); - /** - * Current modal - * @private - * @type {Remodal} - */ - - var openModals = []; - /** - * Scrollbar position - * @private - * @type {Number} - */ - - var scrollTop; - /** - * Returns an animation duration - * @private - * @param {jQuery} $elem - * @returns {Number} - */ - - function getAnimationDuration($elem) { - if (IS_ANIMATION && $elem.css('animation-name') === 'none' && $elem.css('-webkit-animation-name') === 'none' && $elem.css('-moz-animation-name') === 'none' && $elem.css('-o-animation-name') === 'none' && $elem.css('-ms-animation-name') === 'none') { - return 0; - } - - var duration = $elem.css('animation-duration') || $elem.css('-webkit-animation-duration') || $elem.css('-moz-animation-duration') || $elem.css('-o-animation-duration') || $elem.css('-ms-animation-duration') || '0s'; - var delay = $elem.css('animation-delay') || $elem.css('-webkit-animation-delay') || $elem.css('-moz-animation-delay') || $elem.css('-o-animation-delay') || $elem.css('-ms-animation-delay') || '0s'; - var iterationCount = $elem.css('animation-iteration-count') || $elem.css('-webkit-animation-iteration-count') || $elem.css('-moz-animation-iteration-count') || $elem.css('-o-animation-iteration-count') || $elem.css('-ms-animation-iteration-count') || '1'; - var max; - var len; - var num; - var i; - duration = duration.split(', '); - delay = delay.split(', '); - iterationCount = iterationCount.split(', '); // The 'duration' size is the same as the 'delay' size - - for (i = 0, len = duration.length, max = Number.NEGATIVE_INFINITY; i < len; i++) { - num = parseFloat(duration[i]) * parseInt(iterationCount[i], 10) + parseFloat(delay[i]); - - if (num > max) { - max = num; - } - } - - return max; - } - /** - * Returns a scrollbar width - * @private - * @returns {Number} - */ - - - function getScrollbarWidth() { - if ($(document).height() <= $(window).height()) { - return 0; - } - - var outer = document.createElement('div'); - var inner = document.createElement('div'); - var widthNoScroll; - var widthWithScroll; - outer.style.visibility = 'hidden'; - outer.style.width = '100px'; - document.body.appendChild(outer); - widthNoScroll = outer.offsetWidth; // Force scrollbars - - outer.style.overflow = 'scroll'; // Add inner div - - inner.style.width = '100%'; - outer.appendChild(inner); - widthWithScroll = inner.offsetWidth; // Remove divs - - outer.parentNode.removeChild(outer); - return widthNoScroll - widthWithScroll; - } - /** - * Locks the screen - * @private - */ - - - function lockScreen() { - if (IS_IOS) { - return; - } - - var $html = $('html'); - var lockedClass = namespacify('is-locked'); - var paddingRight; - var $body; - - if (!$html.hasClass(lockedClass)) { - $body = $(document.body); // Zepto does not support '-=', '+=' in the `css` method - - paddingRight = parseInt($body.css('padding-right'), 10) + getScrollbarWidth(); - $body.css('padding-right', paddingRight + 'px'); - $html.addClass(lockedClass); - } - } - /** - * Unlocks the screen - * @private - */ - - - function unlockScreen() { - if (IS_IOS) { - return; - } - - var $html = $('html'); - var lockedClass = namespacify('is-locked'); - var paddingRight; - var $body; - - if ($html.hasClass(lockedClass)) { - $body = $(document.body); // Zepto does not support '-=', '+=' in the `css` method - - paddingRight = parseInt($body.css('padding-right'), 10) - getScrollbarWidth(); - $body.css('padding-right', paddingRight + 'px'); - $html.removeClass(lockedClass); - } - } - /** - * Sets a state for an instance - * @private - * @param {Remodal} instance - * @param {STATES} state - * @param {Boolean} isSilent If true, Remodal does not trigger events - * @param {String} Reason of a state change. - */ - - - function setState(instance, state, isSilent, reason) { - var newState = namespacify('is', state); - var allStates = [namespacify('is', STATES.CLOSING), namespacify('is', STATES.OPENING), namespacify('is', STATES.CLOSED), namespacify('is', STATES.OPENED)].join(' '); - instance.$bg.removeClass(allStates).addClass(newState); - instance.$overlay.removeClass(allStates).addClass(newState); - instance.$wrapper.removeClass(allStates).addClass(newState); - instance.$modal.removeClass(allStates).addClass(newState); - instance.state = state; - !isSilent && instance.$modal.trigger({ - type: state, - reason: reason - }, [{ - reason: reason - }]); - } - /** - * Synchronizes with the animation - * @param {Function} doBeforeAnimation - * @param {Function} doAfterAnimation - * @param {Remodal} instance - */ - - - function syncWithAnimation(doBeforeAnimation, doAfterAnimation, instance) { - var runningAnimationsCount = 0; - - var handleAnimationStart = function handleAnimationStart(e) { - if (e.target !== this) { - return; - } - - runningAnimationsCount++; - }; - - var handleAnimationEnd = function handleAnimationEnd(e) { - if (e.target !== this) { - return; - } - - if (--runningAnimationsCount === 0) { - // Remove event listeners - $.each(['$bg', '$overlay', '$wrapper', '$modal'], function (index, elemName) { - instance[elemName].off(ANIMATIONSTART_EVENTS + ' ' + ANIMATIONEND_EVENTS); - }); - doAfterAnimation(); - } - }; - - $.each(['$bg', '$overlay', '$wrapper', '$modal'], function (index, elemName) { - instance[elemName].on(ANIMATIONSTART_EVENTS, handleAnimationStart).on(ANIMATIONEND_EVENTS, handleAnimationEnd); - }); - doBeforeAnimation(); // If the animation is not supported by a browser or its duration is 0 - - if (getAnimationDuration(instance.$bg) === 0 && getAnimationDuration(instance.$overlay) === 0 && getAnimationDuration(instance.$wrapper) === 0 && getAnimationDuration(instance.$modal) === 0) { - // Remove event listeners - $.each(['$bg', '$overlay', '$wrapper', '$modal'], function (index, elemName) { - instance[elemName].off(ANIMATIONSTART_EVENTS + ' ' + ANIMATIONEND_EVENTS); - }); - doAfterAnimation(); - } - } - /** - * Closes immediately - * @private - * @param {Remodal} instance - */ - - - function halt(instance) { - if (instance.state === STATES.CLOSED) { - return; - } - - $.each(['$bg', '$overlay', '$wrapper', '$modal'], function (index, elemName) { - instance[elemName].off(ANIMATIONSTART_EVENTS + ' ' + ANIMATIONEND_EVENTS); - }); - removeModal(instance); - instance.$bg.removeClass(instance.settings.modifier); - instance.$overlay.removeClass(instance.settings.modifier).hide(); - instance.$wrapper.hide(); - - if (openModals.length === 0) { - unlockScreen(); - } - - setState(instance, STATES.CLOSED, true); - } - /** - * Parses a string with options - * @private - * @param str - * @returns {Object} - */ - - - function parseOptions(str) { - var obj = {}; - var arr; - var len; - var val; - var i; // Remove spaces before and after delimiters - - str = str.replace(/\s*:\s*/g, ':').replace(/\s*,\s*/g, ','); // Parse a string - - arr = str.split(','); - - for (i = 0, len = arr.length; i < len; i++) { - arr[i] = arr[i].split(':'); - val = arr[i][1]; // Convert a string value if it is like a boolean - - if (typeof val === 'string' || val instanceof String) { - val = val === 'true' || (val === 'false' ? false : val); - } // Convert a string value if it is like a number - - - if (typeof val === 'string' || val instanceof String) { - val = !isNaN(val) ? +val : val; - } - - obj[arr[i][0]] = val; - } - - return obj; - } - /** - * Generates a string separated by dashes and prefixed with NAMESPACE - * @private - * @param {...String} - * @returns {String} - */ - - - function namespacify() { - var result = NAMESPACE; - - for (var i = 0; i < arguments.length; ++i) { - result += '-' + arguments[i]; - } - - return result; - } - /** - * Handles the hashchange event - * @private - * @listens hashchange - */ - - - function handleHashChangeEvent() { - var id = location.hash.replace('#', ''); - var instance; - var $elem; - var current = currentModal(); - - if (!id) { - // Check if we have currently opened modal and animation was completed - if (current && current.state === STATES.OPENED && current.settings.hashTracking) { - current.close(); - } - } else { - if (!current || current.id !== id) { - // Catch syntax error if your hash is bad - try { - $elem = $('[data-' + PLUGIN_NAME + '-id="' + id + '"]'); - } catch (err) {} - - if ($elem && $elem.length) { - instance = $[PLUGIN_NAME].lookup[$elem.data(PLUGIN_NAME)]; - - if (instance && instance.settings.hashTracking) { - instance.open(); - } - } - } - } - } - - function currentModal() { - return openModals[openModals.length - 1]; - } - - function removeModal(remodal) { - var index = openModals.indexOf(remodal); - - if (index >= 0) { - openModals.slice(index, 1); - } - } - /** - * Remodal constructor - * @constructor - * @param {jQuery} $modal - * @param {Object} options - */ - - - function Remodal($modal, options) { - var $body = $(document.body); - var $appendTo = $body; - var remodal = this; - remodal.id = $modal.attr('data-' + PLUGIN_NAME + '-id'); - remodal.settings = $.extend({}, DEFAULTS, options); - remodal.index = $[PLUGIN_NAME].lookup.push(remodal) - 1; - remodal.state = STATES.CLOSED; // remodal.$overlay = $('.' + namespacify('overlay')); - - if (remodal.settings.appendTo !== null && remodal.settings.appendTo.length) { - $appendTo = $(remodal.settings.appendTo); - } - - if (!remodal.$overlay) { - remodal.$overlay = $('
".concat(error.stack, "") : '';
- utils_toastr.error("Fetch Failed: \n ").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.UPDATE, " ").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.ALL, " ").concat(type_translation, "\n \n ").concat(length, " ").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.OF_YOUR, " ").concat(type_translation.toLowerCase(), " ").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.HAVE_AN_UPDATE_AVAILABLE, "\n
\n ")); - var existing_slugs = external_jQuery_default()('[data-update-packages]').attr('data-packages-slugs') || ''; - - if (existing_slugs) { - existing_slugs = existing_slugs.split(','); - } else { - existing_slugs = []; - } - - var slugs = unique_default()(existing_slugs.concat(Object.keys(resources))).join(); - external_jQuery_default()('[data-update-packages]').attr('data-packages-slugs', "".concat(slugs)); - Object.keys(resources).forEach(function (item) { - // listing page - var container = external_jQuery_default()("[data-gpm-".concat(singles[index], "=\"").concat(item, "\"]")); - var element = container.find('.gpm-name'); - var url = element.find('a'); - var content_wrapper = container.parents('.content-wrapper'); - - if (type === 'plugins' && !element.find('.badge.update').length) { - element.append("").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.UPDATE_AVAILABLE, "!")); - content_wrapper.addClass('has-updates'); - } else if (type === 'themes') { - element.append("")); - content_wrapper.addClass('has-updates'); - } // details page - - - if (container.length) { - var details = external_jQuery_default()(".grav-update.".concat(singles[index])); - - if (details.length) { - var releaseType = resources[item].type === 'testing' ? 'test release' : ''; - details.html("\n\n ").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.UPDATE, " ").concat(singles[index].charAt(0).toUpperCase() + singles[index].substr(1).toLowerCase(), "\n \n v").concat(resources[item].available, " ").concat(releaseType, " ").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.OF_THIS, " ").concat(singles[index], " ").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.IS_NOW_AVAILABLE, "!\n
\n ")).css('display', 'block'); - is_current_package_latest = false; - } - } - }); - external_jQuery_default()('[data-update-packages]').removeClass('hidden'); - }); - external_jQuery_default()('.content-wrapper').addClass('updates-checked'); - - if (!is_current_package_latest) { - external_jQuery_default()('.warning-reinstall-not-latest-release').removeClass('hidden'); - } - } - }]); - - return Updates; -}(); - - -var updates_Instance = new Updates(); - // automatically refresh UI for updates (graph, sidebar, plugin/themes pages) after every fetch - -Instance.on('fetched', function (response, raw) { - updates_Instance.setPayload(response.payload || {}); - updates_Instance.grav().resources(); -}); - -if (external_GravAdmin_namespaceObject.config.enable_auto_updates_check === '1') { - Instance.fetch(); -} -// EXTERNAL MODULE: ./node_modules/chartist/dist/chartist.js -var chartist = __webpack_require__(69259); -var chartist_default = /*#__PURE__*/__webpack_require__.n(chartist); -;// CONCATENATED MODULE: ./app/dashboard/chart.js -function chart_typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { chart_typeof = function _typeof(obj) { return typeof obj; }; } else { chart_typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return chart_typeof(obj); } - -function _get(target, property, receiver) { if (typeof Reflect !== "undefined" && Reflect.get) { _get = Reflect.get; } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(receiver); } return desc.value; }; } return _get(target, property, receiver || target); } - -function _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = chart_getPrototypeOf(object); if (object === null) break; } return object; } - -function chart_inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) chart_setPrototypeOf(subClass, superClass); } - -function chart_setPrototypeOf(o, p) { chart_setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return chart_setPrototypeOf(o, p); } - -function chart_createSuper(Derived) { var hasNativeReflectConstruct = chart_isNativeReflectConstruct(); return function _createSuperInternal() { var Super = chart_getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = chart_getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return chart_possibleConstructorReturn(this, result); }; } - -function chart_possibleConstructorReturn(self, call) { if (call && (chart_typeof(call) === "object" || typeof call === "function")) { return call; } return chart_assertThisInitialized(self); } - -function chart_assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } - -function chart_isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } - -function chart_getPrototypeOf(o) { chart_getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return chart_getPrototypeOf(o); } - -function chart_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function chart_defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function chart_createClass(Constructor, protoProps, staticProps) { if (protoProps) chart_defineProperties(Constructor.prototype, protoProps); if (staticProps) chart_defineProperties(Constructor, staticProps); return Constructor; } - - - - - - // let isFirefox = navigator.userAgent.toLowerCase().indexOf('firefox') > -1; - -var defaults = { - data: { - series: [100, 0] - }, - options: { - Pie: { - donut: true, - donutWidth: 10, - startAngle: 0, - total: 100, - showLabel: false, - height: 150, - // chartPadding: !isFirefox ? 10 : 25 // workaround for older versions of firefox - chartPadding: 5 - }, - Bar: { - height: 164, - chartPadding: 20, - // workaround for older versions of firefox - axisX: { - showGrid: false, - labelOffset: { - x: 0, - y: 0 - } - }, - axisY: { - offset: 15, - showLabel: true, - showGrid: true, - labelOffset: { - x: 5, - y: 5 - }, - scaleMinSpace: 25 - } - } - } -}; - -var Chart = /*#__PURE__*/function () { - function Chart(element) { - var _this = this; - - var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - var data = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; - - chart_classCallCheck(this, Chart); - - this.element = external_jQuery_default()(element) || []; - - if (!this.element[0]) { - return; - } - - var type = (this.element.data('chart-type') || 'pie').toLowerCase(); - this.type = type.charAt(0).toUpperCase() + type.substr(1).toLowerCase(); - options = Object.assign({}, defaults.options[this.type], options); - data = Object.assign({}, defaults.data, data); - Object.assign(this, { - options: options, - data: data - }); - this.chart = (chartist_default())[this.type](this.element.find('.ct-chart').empty()[0], this.data, this.options); - this.chart.on('created', function () { - _this.element.find('.hidden').removeClass('hidden'); // FIX: workaround for chartist issue not allowing HTML in labels anymore - // https://github.com/gionkunz/chartist-js/issues/937 - - - _this.element.find('.ct-label').each(function (index, label) { - label = external_jQuery_default()(label); - var text = label.html().replace('<', '<').replace('>', '>'); - label.html(text); - }); - }); - } - - chart_createClass(Chart, [{ - key: "updateData", - value: function updateData(data) { - Object.assign(this.data, data); - this.chart.update(this.data); - } - }]); - - return Chart; -}(); - - -; -var UpdatesChart = /*#__PURE__*/function (_Chart) { - chart_inherits(UpdatesChart, _Chart); - - var _super = chart_createSuper(UpdatesChart); - - function UpdatesChart(element) { - var _this2; - - var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - var data = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; - - chart_classCallCheck(this, UpdatesChart); - - _this2 = _super.call(this, element, options, data); - - _this2.chart.on('draw', function (data) { - return _this2.draw(data); - }); - - Instance.on('fetched', function (response) { - if (!response.payload) { - return; - } - - var payload = response.payload.grav; - var missing = (response.payload.resources.total + (payload.isUpdatable ? 1 : 0)) * 100 / (response.payload.installed + (payload.isUpdatable ? 1 : 0)); - var updated = 100 - missing; - - _this2.updateData({ - series: [updated, missing] - }); - - if (response.payload.resources.total) { - updates_Instance.maintenance('show'); - } - }); - return _this2; - } - - chart_createClass(UpdatesChart, [{ - key: "draw", - value: function draw(data) { - if (data.index) { - return; - } - - var notice = external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN[data.value === 100 ? 'FULLY_UPDATED' : 'UPDATES_AVAILABLE']; - this.element.find('.numeric span').text("".concat(Math.round(data.value), "%")); - this.element.find('.js__updates-available-description').html(notice); - this.element.find('.hidden').removeClass('hidden'); - } - }, { - key: "updateData", - value: function updateData(data) { - _get(chart_getPrototypeOf(UpdatesChart.prototype), "updateData", this).call(this, data); // missing updates - - - if (this.data.series[0] < 100) { - this.element.closest('#updates').find('[data-update-packages]').fadeIn(); - } - } - }]); - - return UpdatesChart; -}(Chart); -var charts = {}; -external_jQuery_default()('[data-chart-name]').each(function () { - var element = external_jQuery_default()(this); - var name = element.data('chart-name') || ''; - var options = element.data('chart-options') || {}; - var data = element.data('chart-data') || {}; - - if (name === 'updates') { - charts[name] = new UpdatesChart(element, options, data); - } else { - charts[name] = new Chart(element, options, data); - } -}); -var Instances = charts; -;// CONCATENATED MODULE: ./app/dashboard/cache.js -function cache_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function cache_defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function cache_createClass(Constructor, protoProps, staticProps) { if (protoProps) cache_defineProperties(Constructor.prototype, protoProps); if (staticProps) cache_defineProperties(Constructor, staticProps); return Constructor; } - - - - - -var getUrl = function getUrl() { - var type = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; - - if (type) { - type = "cleartype:".concat(type, "/"); - } - - return "".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/cache.json/task").concat(external_GravAdmin_namespaceObject.config.param_sep, "clearCache/").concat(type, "admin-nonce").concat(external_GravAdmin_namespaceObject.config.param_sep).concat(external_GravAdmin_namespaceObject.config.admin_nonce); -}; - -var Cache = /*#__PURE__*/function () { - function Cache() { - var _this = this; - - cache_classCallCheck(this, Cache); - - this.element = external_jQuery_default()('[data-clear-cache]'); - external_jQuery_default()('body').on('click', '[data-clear-cache]', function (event) { - return _this.clear(event, event.target); - }); - } - - cache_createClass(Cache, [{ - key: "clear", - value: function clear(event, element) { - var _this2 = this; - - var type = ''; - - if (event && event.preventDefault) { - event.preventDefault(); - } - - if (typeof event === 'string') { - type = event; - } - - element = element ? external_jQuery_default()(element) : external_jQuery_default()("[data-clear-cache-type=\"".concat(type, "\"]")); - type = type || external_jQuery_default()(element).data('clear-cache-type') || ''; - var url = element.data('clearCache') || getUrl(type); - this.disable(); - utils_request(url, function () { - return _this2.enable(); - }); - } - }, { - key: "enable", - value: function enable() { - this.element.removeAttr('disabled').find('> .fa').removeClass('fa-refresh fa-spin fa-retweet').addClass('fa-retweet'); - } - }, { - key: "disable", - value: function disable() { - this.element.attr('disabled', 'disabled').find('> .fa').removeClass('fa-retweet').addClass('fa-refresh fa-spin'); - } - }]); - - return Cache; -}(); - - -var cache_Instance = new Cache(); - -;// CONCATENATED MODULE: ./app/dashboard/backup.js - - - - -external_jQuery_default()('[data-backup][data-ajax*="backup/"]').on('click', function () { - var element = external_jQuery_default()(this); - var url = element.data('ajax'); - var inDropdown = element.closest('.dropdown-menu'); - (inDropdown.length ? inDropdown : element).closest('.button-group').find('> button:first').attr('disabled', 'disabled').find('> .fa').removeClass('fa-life-ring').addClass('fa-spin fa-refresh'); - utils_request(url, function () - /* response */ - { - if (Instances && Instances.backups) { - Instances.backups.updateData({ - series: [0, 100] - }); - Instances.backups.element.find('.numeric').html("0 ".concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.DAYS.toLowerCase(), "")); - } - - (inDropdown.length ? inDropdown : element).closest('.button-group').find('> button:first').removeAttr('disabled').find('> .fa').removeClass('fa-spin fa-refresh').addClass('fa-life-ring'); - }); -}); -external_jQuery_default()('[data-backup][data-ajax*="backupDelete"]').on('click', function () { - var element = external_jQuery_default()(this); - var url = element.data('ajax'); - var tr = element.closest('tr'); - tr.addClass('deleting'); - utils_request(url, function (response) { - if (response.status === 'success') { - tr.remove(); - } else { - tr.removeClass('deleting'); - } - }); -}); -;// CONCATENATED MODULE: ./app/dashboard/index.js - - - -/* harmony default export */ const dashboard = ({ - Chart: { - Chart: Chart, - UpdatesChart: UpdatesChart, - Instances: Instances - }, - Cache: cache_Instance -}); -// EXTERNAL MODULE: ./node_modules/sortablejs/modular/sortable.esm.js -var sortable_esm = __webpack_require__(51474); -// EXTERNAL MODULE: ./node_modules/debounce/index.js -var debounce = __webpack_require__(20296); -var debounce_default = /*#__PURE__*/__webpack_require__.n(debounce); -// EXTERNAL MODULE: ./app/utils/storage.js -var storage = __webpack_require__(92511); -;// CONCATENATED MODULE: ./app/pages/tree.js -function tree_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function tree_defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function tree_createClass(Constructor, protoProps, staticProps) { if (protoProps) tree_defineProperties(Constructor.prototype, protoProps); if (staticProps) tree_defineProperties(Constructor, staticProps); return Constructor; } - - - -var sessionKey = 'grav:admin:pages'; - -if (!sessionStorage.getItem(sessionKey)) { - sessionStorage.setItem(sessionKey, '{}'); -} - -var PagesTree = /*#__PURE__*/function () { - function PagesTree(query) { - var _this = this; - - var elements = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : undefined; - - tree_classCallCheck(this, PagesTree); - - this.query = query; - this.elements = external_jQuery_default()(elements !== undefined ? elements : this.query); - this.session = JSON.parse(sessionStorage.getItem(sessionKey) || '{}'); - - if (!this.elements.length) { - return; - } - - this.restore(); - this.elements.find('.page-icon').on('click', function (event) { - return _this.toggle(event.target); - }); - this.elements.data('tree_init', 1); - external_jQuery_default()('[data-page-toggleall]').on('click', function (event) { - var element = external_jQuery_default()(event.target).closest('[data-page-toggleall]'); - var action = element.data('page-toggleall'); - - _this[action](); - }); - } - - tree_createClass(PagesTree, [{ - key: "reload", - value: function reload() { - var elements = external_jQuery_default()(this.query).filter(function (index, element) { - return !external_jQuery_default()(element).data('tree_init'); - }); - - if (!elements.length) { - return; - } - - this.constructor(this.query, elements); - } - }, { - key: "toggle", - value: function toggle(elements) { - var _this2 = this; - - var dontStore = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; - - if (typeof elements === 'string') { - elements = external_jQuery_default()("[data-nav-id=\"".concat(elements, "\"]")).find('[data-toggle="children"]'); - } - - elements = external_jQuery_default()(elements || this.elements); - elements.each(function (index, element) { - element = external_jQuery_default()(element); - - var state = _this2.getState(element.closest('[data-toggle="children"]')); - - _this2[state.isOpen ? 'collapse' : 'expand'](state.id, dontStore); - }); - } - }, { - key: "collapse", - value: function collapse(elements) { - var _this3 = this; - - var dontStore = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; - - if (typeof elements === 'string') { - elements = external_jQuery_default()("[data-nav-id=\"".concat(elements, "\"]")).find('[data-toggle="children"]'); - } - - elements = external_jQuery_default()(elements || this.elements); - elements.each(function (index, element) { - element = external_jQuery_default()(element); - - var state = _this3.getState(element); - - if (state.isOpen) { - state.children.hide(); - state.icon.removeClass('children-open').addClass('children-closed'); - - if (!dontStore) { - delete _this3.session[state.id]; - } - } - }); - - if (!dontStore) { - this.save(); - } - } - }, { - key: "expand", - value: function expand(elements) { - var _this4 = this; - - var dontStore = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; - - if (typeof elements === 'string') { - var element = external_jQuery_default()("[data-nav-id=\"".concat(elements, "\"]")); - var parents = element.parents('[data-nav-id]'); // loop back through parents, we don't want to expand an hidden child - - if (parents.length) { - parents = parents.find('[data-toggle="children"]:first'); - parents = parents.add(element.find('[data-toggle="children"]:first')); - return this.expand(parents, dontStore); - } - - elements = element.find('[data-toggle="children"]:first'); - } - - elements = external_jQuery_default()(elements || this.elements); - elements.each(function (index, element) { - element = external_jQuery_default()(element); - - var state = _this4.getState(element); - - if (!state.isOpen) { - state.children.show(); - state.icon.removeClass('children-closed').addClass('children-open'); - - if (!dontStore) { - _this4.session[state.id] = 1; - } - } - }); - - if (!dontStore) { - this.save(); - } - } - }, { - key: "restore", - value: function restore() { - var _this5 = this; - - this.collapse(null, true); - Object.keys(this.session).forEach(function (key) { - _this5.expand(key, 'no-store'); - }); - } - }, { - key: "save", - value: function save() { - return sessionStorage.setItem(sessionKey, JSON.stringify(this.session)); - } - }, { - key: "getState", - value: function getState(element) { - element = external_jQuery_default()(element); - return { - id: element.closest('[data-nav-id]').data('nav-id'), - children: element.closest('li.page-item').find('ul:first'), - icon: element.find('.page-icon'), - - get isOpen() { - return this.icon.hasClass('children-open'); - } - - }; - } - }]); - - return PagesTree; -}(); - - -var tree_Instance = new PagesTree('[data-toggle="children"]'); - -// EXTERNAL MODULE: ./node_modules/selectize/dist/js/selectize.js -var selectize = __webpack_require__(25703); -var selectize_default = /*#__PURE__*/__webpack_require__.n(selectize); -;// CONCATENATED MODULE: ./app/utils/selectize-required-fix.js -/** - * This is a plugin to override the `.refreshValidityState` method of - * the Selectize library (https://selectize.github.io/selectize.js/). - * The library is not maintained anymore (as of 2017-09-13) and contains - * a bug which causes Microsoft Edge to not work with selectized [required] - * form fields. This plugin should be removed if - * https://github.com/selectize/selectize.js/pull/1320 is ever merged - * and a new version of Selectize gets released. - */ - -selectize_default().define('required-fix', function (options) { - var _this = this; - - this.refreshValidityState = function () { - if (!_this.isRequired) return false; - var invalid = !_this.items.length; - _this.isInvalid = invalid; - - if (invalid) { - _this.$control_input.attr('required', ''); - - _this.$input.removeAttr('required'); - } else { - _this.$control_input.removeAttr('required'); - - _this.$input.attr('required'); - } - }; -}); -;// CONCATENATED MODULE: ./app/pages/filter.js -function filter_typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { filter_typeof = function _typeof(obj) { return typeof obj; }; } else { filter_typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return filter_typeof(obj); } - -function filter_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function filter_defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function filter_createClass(Constructor, protoProps, staticProps) { if (protoProps) filter_defineProperties(Constructor.prototype, protoProps); if (staticProps) filter_defineProperties(Constructor, staticProps); return Constructor; } - - - - - - - - - -/* @formatter:off */ - -/* eslint-disable */ - -var options = [{ - flag: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.MODULE, - key: 'Module', - cat: 'mode' -}, { - flag: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.VISIBLE, - key: 'Visible', - cat: 'mode' -}, { - flag: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.ROUTABLE, - key: 'Routable', - cat: 'mode' -}, { - flag: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.PUBLISHED, - key: 'Published', - cat: 'mode' -}, { - flag: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.NON_MODULE, - key: 'NonModule', - cat: 'mode' -}, { - flag: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.NON_VISIBLE, - key: 'NonVisible', - cat: 'mode' -}, { - flag: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.NON_ROUTABLE, - key: 'NonRoutable', - cat: 'mode' -}, { - flag: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.NON_PUBLISHED, - key: 'NonPublished', - cat: 'mode' -}]; -/* @formatter:on */ - -/* eslint-enable */ - -var PagesFilter = /*#__PURE__*/function () { - function PagesFilter(filters, search) { - var _this = this; - - filter_classCallCheck(this, PagesFilter); - - this.filters = external_jQuery_default()(filters); - this.search = external_jQuery_default()(search); - this.options = options; - this.tree = tree_Instance; - var storage = JSON.parse(localStorage.getItem('grav:admin:pages:filter') || '{}'); - - if (!this.filters.length || !this.search.length) { - return; - } - - this.labels = this.filters.data('filter-labels'); - this.search.on('input', debounce_default()(function () { - return _this.filter(); - }, 250)); - this.filters.on('change', function () { - return _this.filter(); - }); // restore state - - if (storage.flags || storage.query) { - this.setValues(storage); - this.filter(); - } - - this._initSelectize(); - } - - filter_createClass(PagesFilter, [{ - key: "filter", - value: function filter(value) { - var _this2 = this; - - var data = { - flags: '', - query: '' - }; - - if (filter_typeof(value) === 'object') { - Object.assign(data, value); - } - - if (typeof value === 'string') { - data.query = value; - } - - if (typeof value === 'undefined') { - data.flags = this.filters.val(); - data.query = this.search.val(); - } - - if (!Object.keys(data).filter(function (key) { - return data[key] !== ''; - }).length) { - this.resetValues(); - return; - } - - data.flags = data.flags.replace(/(\s{1,})?,(\s{1,})?/g, ','); - this.setValues({ - flags: data.flags, - query: data.query - }, 'silent'); - utils_request("".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/pages-filter.json/task").concat(external_GravAdmin_namespaceObject.config.param_sep, "filterPages"), { - method: 'post', - body: data - }, function (response) { - _this2.refreshDOM(response); - }); - } - }, { - key: "refreshDOM", - value: function refreshDOM(response) { - var _this3 = this; - - var items = external_jQuery_default()('[data-nav-id]'); - - if (!response) { - items.removeClass('search-match').show(); - this.tree.restore(); - return; - } - - items.removeClass('search-match').hide(); - response.results.forEach(function (page) { - var match = items.filter("[data-nav-id=\"".concat(page, "\"]")).addClass('search-match').show(); - match.parents('[data-nav-id]').addClass('search-match').show(); - - _this3.tree.expand(page, 'no-store'); - }); - } - }, { - key: "setValues", - value: function setValues(_ref, silent) { - var _ref$flags = _ref.flags, - flags = _ref$flags === void 0 ? '' : _ref$flags, - _ref$query = _ref.query, - query = _ref$query === void 0 ? '' : _ref$query; - var flagsArray = flags.replace(/(\s{1,})?,(\s{1,})?/g, ',').split(','); - - if (this.filters.val() !== flags) { - var selectize = this.filters.data('selectize'); - this.filters[selectize ? 'setValue' : 'val'](flagsArray, silent); - } - - if (this.search.val() !== query) { - this.search.val(query); - } - - localStorage.setItem('grav:admin:pages:filter', JSON.stringify({ - flags: flags, - query: query - })); - } - }, { - key: "resetValues", - value: function resetValues() { - this.setValues('', 'silent'); - this.refreshDOM(); - } - }, { - key: "_initSelectize", - value: function _initSelectize() { - var _this4 = this; - - var extras = { - type: this.filters.data('filter-types') || {}, - access: this.filters.data('filter-access-levels') || {} - }; - Object.keys(extras).forEach(function (cat) { - Object.keys(extras[cat]).forEach(function (key) { - _this4.options.push({ - cat: cat, - key: key, - flag: extras[cat][key] - }); - }); - }); - this.filters.selectize({ - maxItems: null, - valueField: 'key', - labelField: 'flag', - searchField: ['flag', 'key'], - options: this.options, - optgroups: this.labels, - optgroupField: 'cat', - optgroupLabelField: 'name', - optgroupValueField: 'id', - optgroupOrder: this.labels.map(function (item) { - return item.id; - }), - plugins: ['optgroup_columns', 'required-fix'] - }); - } - }]); - - return PagesFilter; -}(); - - -var filter_Instance = new PagesFilter('input[name="page-filter"]', 'input[name="page-search"]'); - -// EXTERNAL MODULE: ./node_modules/speakingurl/index.js -var speakingurl = __webpack_require__(989); -var speakingurl_default = /*#__PURE__*/__webpack_require__.n(speakingurl); -;// CONCATENATED MODULE: ./app/utils/jquery-utils.js -var _this = undefined; - - - // jQuery no parents filter - -(external_jQuery_default()).expr[":"].noparents = external_jQuery_default().expr.createPseudo(function (text) { - return function (element) { - return external_jQuery_default()(element).parents(text).length < 1; - }; -}); // Slugify -// CommonJS and ES6 version of https://github.com/madflow/jquery-slugify - -(external_jQuery_default()).fn.slugify = function (source, options) { - return _this.each(function (element) { - var target = external_jQuery_default()(element); - var source = external_jQuery_default()(source); - target.on('keyup change', function () { - target.data('locked', target.val() !== '' && target.val() !== undefined); - }); - source.on('keyup change', function () { - if (target.data('locked') === true) { - return true; - } - - var isInput = target.is('input') || target.is('textarea'); - target[isInput ? 'val' : 'text'](external_jQuery_default().slugify(source.val(), options)); - }); - }); -}; // Static method. - - -(external_jQuery_default()).slugify = function (sourceString, options) { - options = external_jQuery_default().extend({}, (external_jQuery_default()).slugify.options, options); - options.lang = options.lang || external_jQuery_default()('html').prop('lang'); - - if (typeof options.preSlug === 'function') { - sourceString = options.preSlug(sourceString); - } - - sourceString = options.slugFunc(sourceString, options); - - if (typeof options.postSlug === 'function') { - sourceString = options.postSlug(sourceString); - } - - return sourceString; -}; // Default plugin options - - -(external_jQuery_default()).slugify.options = { - preSlug: null, - postSlug: null, - slugFunc: function slugFunc(input, opts) { - return speakingurl_default()(input, opts); - } -}; -;// CONCATENATED MODULE: ./app/pages/page/add.js - - - - -var custom = false; -var folder = external_jQuery_default()('[data-remodal-id="modal"] input[name="data[folder]"], [data-remodal-id="module"] input[name="data[folder]"]'); -var title = external_jQuery_default()('[data-remodal-id="modal"] input[name="data[title]"], [data-remodal-id="module"] input[name="data[title]"]'); - -var getFields = function getFields(type, target) { - target = external_jQuery_default()(target); - var query = "[data-remodal-id=\"".concat(target.closest('[data-remodal-id]').data('remodal-id'), "\"]"); - return { - title: type === 'title' ? external_jQuery_default()(target) : external_jQuery_default()("".concat(query, " input[name=\"data[title]\"]")), - folder: type === 'folder' ? external_jQuery_default()(target) : external_jQuery_default()("".concat(query, " input[name=\"data[folder]\"]")) - }; -}; - -title.on('input focus blur', function (event) { - if (custom) { - return true; - } - - var elements = getFields('title', event.currentTarget); - var slug = external_jQuery_default().slugify(elements.title.val(), { - custom: { - "'": '' - } - }); - elements.folder.val(slug); -}); -folder.on('input', function (event) { - var elements = getFields('folder', event.currentTarget); - var input = elements.folder.get(0); - var value = elements.folder.val(); - var selection = { - start: input.selectionStart, - end: input.selectionEnd - }; - value = value.toLowerCase().replace(/\s/g, '-').replace(/[^a-z0-9_\-]/g, ''); - elements.folder.val(value); - custom = !!value; // restore cursor position - - input.setSelectionRange(selection.start, selection.end); -}); -folder.on('focus blur', function (event) { - return getFields('title', event.currentTarget).title.trigger('input'); -}); -external_jQuery_default()(document).on('change', '[name="data[route]"]', function (event) { - var rawroute = external_jQuery_default()(event.currentTarget).val(); - var pageTemplate = external_jQuery_default()('[name="data[name]"]'); - var URI = "".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/ajax.json/task").concat(external_GravAdmin_namespaceObject.config.param_sep, "getChildTypes"); - - if (pageTemplate.length === 0) { - return; - } - - utils_request(URI, { - method: 'post', - body: { - rawroute: rawroute - } - }, function (response) { - var type = response.child_type; - - if (type !== '' && type !== 'default') { - pageTemplate.val(type); - pageTemplate.data('selectize').setValue(type); - } - }); -}); -;// CONCATENATED MODULE: ./app/pages/page/move.js - -external_jQuery_default()(document).on('click', '[data-page-move] button[name="task"][value="save"]', function (event) { - /* let route = $('form#blueprints:first select[name="data[route]"]'); - let moveTo = $('[data-page-move] select').val(); - if (route.length && route.val() !== moveTo) { - let selectize = route.data('selectize'); - route.val(moveTo); - if (selectize) selectize.setValue(moveTo); - }*/ - var modal = external_jQuery_default()(event.currentTarget).closest('[data-remodal-id]'); - var parents = modal.data('parents') || {}; - var finder = parents.finder; - - if (!parents || !finder) { - return true; - } - - var field = parents.field; - var parentLabel = parents.parentLabel; - var parentName = parents.parentName; - var selection = finder.findLastActive().item[0]; - var value = selection._item[finder.config.valueKey]; - var name = selection._item[finder.config.labelKey]; - field.val(value); - parentLabel.text(value); - parentName.text(name); - finder.config.defaultPath = value; - external_jQuery_default()('').css({ - backgroundColor: 'rgba(255, 255, 255, 0.1)', - position: 'fixed', - top: 0, - left: 0, - width: '100vw', - height: '100vh', - zIndex: 15000 - }).appendTo(external_jQuery_default()('body')); -}); -/* -$(document).on('click', '[data-remodal-id="parents"] [data-parents-select]', (event) => { - const modal = $(event.currentTarget).closest('[data-remodal-id]'); - const parents = modal.data('parents'); - const finder = parents.finder; - const field = parents.field; - const parentLabel = parents.parentLabel; - const parentName = parents.parentName; - const selection = finder.findLastActive().item[0]; - const value = selection._item[finder.config.valueKey]; - const name = selection._item[finder.config.labelKey]; - - field.val(value); - parentLabel.text(value); - parentName.text(name); - finder.config.defaultPath = value; - - const remodal = $.remodal.lookup[$(`[data-remodal-id="${modal.data('remodalId')}"]`).data('remodal')]; - remodal.close(); -}); -*/ -;// CONCATENATED MODULE: ./app/pages/page/delete.js - -external_jQuery_default()(document).on('click', '[data-remodal-target="delete"]', function () { - var confirm = external_jQuery_default()('[data-remodal-id="delete"] [data-delete-action]'); - var link = external_jQuery_default()(this).data('delete-url'); - confirm.data('delete-action', link); -}); -external_jQuery_default()(document).on('click', '[data-delete-action]', function () { - var remodal = (external_jQuery_default()).remodal.lookup[external_jQuery_default()('[data-remodal-id="delete"]').data('remodal')]; - __webpack_require__.g.location.href = external_jQuery_default()(this).data('delete-action'); - remodal.close(); -}); -;// CONCATENATED MODULE: ./app/pages/page/unset.js - -external_jQuery_default()(document).on('click', '.dz-unset', function () { - var file_upload = external_jQuery_default()(this).closest('.files-upload'); - external_jQuery_default()(this).closest('.dz-image-preview').remove(); - var unset_image = external_jQuery_default()(this).closest('.dz-image-preview').find('[data-dz-name]').text().trim(); - var images = JSON.parse(file_upload.find('input[data-grav-field="hidden"]').val()) || {}; - var image_array = {}; - external_jQuery_default().each(images, function (ind, obj) { - if (!ind.endsWith(unset_image)) { - image_array[ind] = obj; - } - }); - file_upload.find('input[data-grav-field="hidden"]').val(JSON.stringify(image_array)); -}); -;// CONCATENATED MODULE: ./app/pages/page/disable-buttons.js - -external_jQuery_default()('.disable-after-click').on('click', function () { - external_jQuery_default()(this).addClass('pointer-events-disabled'); -}); -// EXTERNAL MODULE: ./node_modules/dropzone/dist/dropzone.js -var dist_dropzone = __webpack_require__(32025); -var dropzone_default = /*#__PURE__*/__webpack_require__.n(dist_dropzone); -;// CONCATENATED MODULE: ./app/forms/fields/files.js -function files_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function files_defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function files_createClass(Constructor, protoProps, staticProps) { if (protoProps) files_defineProperties(Constructor.prototype, protoProps); if (staticProps) files_defineProperties(Constructor, staticProps); return Constructor; } - - - // import EXIF from 'exif-js'; - - - // translations - -var Dictionary = { - dictCancelUpload: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.DROPZONE_CANCEL_UPLOAD, - dictCancelUploadConfirmation: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.DROPZONE_CANCEL_UPLOAD_CONFIRMATION, - dictDefaultMessage: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.DROPZONE_DEFAULT_MESSAGE, - dictFallbackMessage: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.DROPZONE_FALLBACK_MESSAGE, - dictFallbackText: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.DROPZONE_FALLBACK_TEXT, - dictFileTooBig: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.DROPZONE_FILE_TOO_BIG, - dictInvalidFileType: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.DROPZONE_INVALID_FILE_TYPE, - dictMaxFilesExceeded: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.DROPZONE_MAX_FILES_EXCEEDED, - dictRemoveFile: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.DROPZONE_REMOVE_FILE, - dictResponseError: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.DROPZONE_RESPONSE_ERROR -}; -(dropzone_default()).autoDiscover = false; -(dropzone_default()).options.gravPageDropzone = {}; - -(dropzone_default()).confirm = function (question, accepted, rejected) { - var doc = external_jQuery_default()(document); - var modalSelector = '[data-remodal-id="delete-media"]'; - - var removeEvents = function removeEvents() { - doc.off('confirmation', modalSelector, accept); - doc.off('cancellation', modalSelector, reject); - external_jQuery_default()(modalSelector).find('.remodal-confirm').removeClass('pointer-events-disabled'); - }; - - var accept = function accept() { - accepted && accepted(); - removeEvents(); - }; - - var reject = function reject() { - rejected && rejected(); - removeEvents(); - }; - - (external_jQuery_default()).remodal.lookup[external_jQuery_default()(modalSelector).data('remodal')].open(); - doc.on('confirmation', modalSelector, accept); - doc.on('cancellation', modalSelector, reject); -}; - -var DropzoneMediaConfig = { - timeout: 0, - thumbnailWidth: 200, - thumbnailHeight: 150, - addRemoveLinks: false, - dictDefaultMessage: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.DROP_FILES_HERE_TO_UPLOAD.replace(/</g, '<').replace(/>/g, '>'), - dictRemoveFileConfirmation: '[placeholder]', - previewTemplate: "\n".concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.FILE_ERROR_UPLOAD, " ").concat(file.name, "
\n").concat(response.message, "") - }); - } - }, { - key: "onDropzoneComplete", - value: function onDropzoneComplete(file) { - if (!file.accepted && !file.rejected) { - var data = { - status: 'error', - message: "".concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.FILE_UNSUPPORTED, ": ").concat(file.name.match(/\..+/).join('')) - }; - return this.handleError({ - file: file, - data: data, - mode: 'removeFile', - msg: "
".concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.FILE_ERROR_ADD, " ").concat(file.name, "
\n").concat(data.message, "") - }); - } - - if (this.options.reloadPage) { - __webpack_require__.g.location.reload(); - } - } - }, { - key: "b64_to_utf8", - value: function b64_to_utf8(str) { - str = str.replace(/\s/g, ''); - return decodeURIComponent(escape(window.atob(str))); - } - }, { - key: "onDropzoneRemovedFile", - value: function onDropzoneRemovedFile(file) { - var _this5 = this; - - if (!file.accepted || file.rejected) { - return; - } - - var url = file.removeUrl || this.urls["delete"] || this.options.url; - var path = (url || '').match(/path:(.*)\//); - var body = { - filename: file.name, - uri: this.getURI() - }; - - if (file.sessionParams) { - body.task = 'filessessionremove'; - body.session = file.sessionParams; - } - - var customPost = this.container.data('filePostRemove') || {}; - - if (Object.keys(customPost).length) { - body = {}; - Object.keys(customPost).forEach(function (key) { - body[key] = customPost[key]; - }); - } - - body['filename'] = file.name; - body['admin-nonce'] = external_GravAdmin_namespaceObject.config.admin_nonce; - utils_request(url, { - method: 'post', - body: body - }, function () { - if (!path) { - return; - } - - path = _this5.b64_to_utf8(path[1]); - - var input = _this5.container.find('[name][type="hidden"]'); - - var data = JSON.parse(input.val() || '{}'); - delete data[path]; - input.val(JSON.stringify(data)); - }); - } - }, { - key: "onDropzoneError", - value: function onDropzoneError(file, response, xhr) { - var message = xhr ? response.error.message : response; - external_jQuery_default()(file.previewElement).find('[data-dz-errormessage]').html(message); - return this.handleError({ - file: file, - data: { - status: 'error' - }, - msg: "
".concat(message, "") - }); - } - }, { - key: "handleError", - value: function handleError(options) { - var file = options.file, - data = options.data, - mode = options.mode, - msg = options.msg; - - if (data.status !== 'error' && data.status !== 'unauthorized') { - return; - } - - switch (mode) { - case 'addBack': - if (file instanceof File) { - this.dropzone.addFile.call(this.dropzone, file); - } else { - this.dropzone.files.push(file); - this.dropzone.options.addedfile.call(this.dropzone, file); - this.dropzone.options.thumbnail.call(this.dropzone, file, file.extras.url); - } - - break; - - case 'removeFile': - default: - if (~this.dropzone.files.indexOf(file)) { - file.rejected = true; - this.dropzone.removeFile.call(this.dropzone, file, { - silent: true - }); - } - - break; - } - - var modal = external_jQuery_default()('[data-remodal-id="generic"]'); - modal.find('.error-content').html(msg); - (external_jQuery_default()).remodal.lookup[modal.data('remodal')].open(); - } - }]); - - return FilesField; -}(); - - -function UriToMarkdown(uri) { - uri = uri.replace(/@3x|@2x|@1x/, ''); - uri = uri.replace(/\(/g, '%28'); - uri = uri.replace(/\)/g, '%29'); - var title = uri.split('.').slice(0, -1).join('.'); - return uri.match(/\.(jpe?g|png|gif|svg|mp4|webm|ogv|mov)$/i) ? ".concat(uri, " \"").concat(title, "\")") : "[".concat(decodeURI(uri), "](").concat(uri, ")"); -} -var instances = []; -var cache = external_jQuery_default()(); - -var onAddedNodes = function onAddedNodes(event, target -/* , record, instance */ -) { - var files = external_jQuery_default()(target).find('.dropzone.files-upload'); - - if (!files.length) { - return; - } - - files.each(function (index, file) { - file = external_jQuery_default()(file); - - if (!~cache.index(file)) { - addNode(file); - } - }); -}; - -var addNode = function addNode(container) { - container = external_jQuery_default()(container); - var input = container.find('input[type="file"]'); - var settings = container.data('grav-file-settings') || {}; - - if (settings.accept && ~settings.accept.indexOf('*')) { - settings.accept = ['']; - } - - var options = { - url: container.data('file-url-add') || (container.closest('form').attr('action') || external_GravAdmin_namespaceObject.config.current_url) + '.json', - paramName: settings.paramName || 'file', - dotNotation: settings.name || 'file', - acceptedFiles: settings.accept ? settings.accept.join(',') : input.attr('accept') || container.data('media-types'), - maxFilesize: typeof settings.filesize !== 'undefined' ? settings.filesize : 256, - maxFiles: settings.limit || null, - resizeWidth: settings.resizeWidth || null, - resizeHeight: settings.resizeHeight || null, - resizeQuality: settings.resizeQuality || null, - resolution: settings.resolution || null, - accept: function accept(file, done) { - ACCEPT_FUNC(file, done, settings); - } - }; - cache = cache.add(container); - container = container[0]; - instances.push(new FilesField({ - container: container, - options: options - })); -}; - -var files_Instance = function () { - external_jQuery_default()('.dropzone.files-upload').each(function (i, container) { - return addNode(container); - }); - external_jQuery_default()('body').on('mutation._grav', onAddedNodes); - return instances; -}(); -;// CONCATENATED MODULE: ./app/forms/fields/editor/buttons.js - - - - -var replacer = function replacer(_ref) { - var name = _ref.name, - replace = _ref.replace, - codemirror = _ref.codemirror, - button = _ref.button, - _ref$mode = _ref.mode, - mode = _ref$mode === void 0 ? 'replaceSelections' : _ref$mode, - runner = _ref.runner; - button.on("click.editor.".concat(name), function () { - strategies[mode]({ - token: '$1', - template: replace, - codemirror: codemirror, - runner: runner - }); - }); -}; - -var strategies = { - replaceSelections: function replaceSelections(_ref2) { - var template = _ref2.template, - token = _ref2.token, - codemirror = _ref2.codemirror, - runner = _ref2.runner; - var replacements = []; - var ranges = []; - var selections = codemirror.getSelections(); - var list = codemirror.listSelections(); - var accumulator = {}; - selections.forEach(function (selection, index) { - var markup = template.replace(token, selection); - var cursor = markup.indexOf('$cur'); - var _list$index$anchor = list[index].anchor, - line = _list$index$anchor.line, - ch = _list$index$anchor.ch; - markup = markup.replace('$cur', ''); - markup = runner ? runner(selection, markup, list) : markup; - replacements.push(markup); - - if (!accumulator[line]) { - accumulator[line] = 0; - } - - ch += accumulator[line] + (cursor === -1 ? markup.length : cursor); - var range = { - ch: ch, - line: line - }; - ranges.push({ - anchor: range, - head: range - }); - accumulator[line] += markup.length - selection.length; - }); - codemirror.replaceSelections(replacements); - codemirror.setSelections(ranges); - codemirror.focus(); - }, - replaceLine: function replaceLine(_ref3) { - var template = _ref3.template, - token = _ref3.token, - codemirror = _ref3.codemirror, - runner = _ref3.runner; - var list = codemirror.listSelections(); - var range; - list.forEach(function (selection) { - var lines = { - min: Math.min(selection.anchor.line, selection.head.line), - max: Math.max(selection.anchor.line, selection.head.line) - }; - codemirror.eachLine(lines.min, lines.max + 1, function (handler) { - var markup = template.replace(token, handler.text); - var line = codemirror.getLineNumber(handler); - markup = runner ? runner(handler, markup) : markup; - codemirror.replaceRange(markup, { - line: line, - ch: 0 - }, { - line: line, - ch: markup.length - }); - range = { - line: line, - ch: markup.length - }; - }); - }); - codemirror.setSelection(range, range, 'end'); - codemirror.focus(); - }, - replaceRange: function replaceRange() {} -}; - -var flipDisabled = function flipDisabled(codemirror, button, type) { - var hasHistory = codemirror.historySize()[type]; - var element = button.find('a'); - button[hasHistory ? 'removeClass' : 'addClass']('button-disabled'); - - if (!hasHistory) { - element.attr('title-disabled', element.attr('title')); - element.attr('data-hint-disabled', element.attr('data-hint')); - element.removeAttr('title').removeAttr('data-hint'); - } else { - element.attr('title', element.attr('title-disabled')); - element.attr('data-hint', element.attr('data-hint-disabled')); - element.removeAttr('title-disabled').removeAttr('data-hint-disabled'); - } -}; - -/* harmony default export */ const buttons = ({ - navigation: [{ - undo: { - identifier: 'undo', - title: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.UNDO, - label: '', - modes: [], - action: function action(_ref4) { - var codemirror = _ref4.codemirror, - button = _ref4.button, - textarea = _ref4.textarea; - button.addClass('button-disabled'); - codemirror.on('change', function () { - return flipDisabled(codemirror, button, 'undo'); - }); - button.on('click.editor.undo', function () { - codemirror.undo(); - }); - } - } - }, { - redo: { - identifier: 'redo', - title: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.REDO, - label: '', - modes: [], - action: function action(_ref5) { - var codemirror = _ref5.codemirror, - button = _ref5.button, - textarea = _ref5.textarea; - button.addClass('button-disabled'); - codemirror.on('change', function () { - return flipDisabled(codemirror, button, 'redo'); - }); - button.on('click.editor.redo', function () { - codemirror.redo(); - }); - } - } - }, { - headers: { - identifier: 'headers', - title: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.HEADERS, - label: '', - modes: ['gfm', 'markdown'], - children: [{ - h1: { - identifier: 'h1', - label: '1', - modes: ['gfm', 'markdown'], - action: function action(_ref6) { - var codemirror = _ref6.codemirror, - button = _ref6.button, - textarea = _ref6.textarea; - replacer({ - name: 'h1', - replace: '# $1', - codemirror: codemirror, - button: button, - mode: 'replaceLine' - }); - } - } - }, { - h2: { - identifier: 'h2', - label: '2', - modes: ['gfm', 'markdown'], - action: function action(_ref7) { - var codemirror = _ref7.codemirror, - button = _ref7.button, - textarea = _ref7.textarea; - replacer({ - name: 'h2', - replace: '## $1', - codemirror: codemirror, - button: button, - mode: 'replaceLine' - }); - } - } - }, { - h3: { - identifier: 'h3', - label: '3', - modes: ['gfm', 'markdown'], - action: function action(_ref8) { - var codemirror = _ref8.codemirror, - button = _ref8.button, - textarea = _ref8.textarea; - replacer({ - name: 'h3', - replace: '### $1', - codemirror: codemirror, - button: button, - mode: 'replaceLine' - }); - } - } - }, { - h4: { - identifier: 'h4', - label: '4', - modes: ['gfm', 'markdown'], - action: function action(_ref9) { - var codemirror = _ref9.codemirror, - button = _ref9.button, - textarea = _ref9.textarea; - replacer({ - name: 'h4', - replace: '#### $1', - codemirror: codemirror, - button: button, - mode: 'replaceLine' - }); - } - } - }, { - h5: { - identifier: 'h5', - label: '5', - modes: ['gfm', 'markdown'], - action: function action(_ref10) { - var codemirror = _ref10.codemirror, - button = _ref10.button, - textarea = _ref10.textarea; - replacer({ - name: 'h5', - replace: '##### $1', - codemirror: codemirror, - button: button, - mode: 'replaceLine' - }); - } - } - }, { - h6: { - identifier: 'h6', - label: '6', - modes: ['gfm', 'markdown'], - action: function action(_ref11) { - var codemirror = _ref11.codemirror, - button = _ref11.button, - textarea = _ref11.textarea; - replacer({ - name: 'h6', - replace: '###### $1', - codemirror: codemirror, - button: button, - mode: 'replaceLine' - }); - } - } - }] - } - }, { - bold: { - identifier: 'bold', - title: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.BOLD, - label: '', - modes: ['gfm', 'markdown'], - shortcut: ['Ctrl-B', 'Cmd-B'], - action: function action(_ref12) { - var codemirror = _ref12.codemirror, - button = _ref12.button, - textarea = _ref12.textarea; - replacer({ - name: 'bold', - replace: '**$1$cur**', - codemirror: codemirror, - button: button - }); - } - } - }, { - italic: { - identifier: 'italic', - title: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.ITALIC, - label: '', - modes: ['gfm', 'markdown'], - shortcut: ['Ctrl-I', 'Cmd-I'], - action: function action(_ref13) { - var codemirror = _ref13.codemirror, - button = _ref13.button, - textarea = _ref13.textarea; - replacer({ - name: 'italic', - replace: '_$1$cur_', - codemirror: codemirror, - button: button - }); - } - } - }, { - strike: { - identifier: 'strike', - title: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.STRIKETHROUGH, - label: '', - modes: ['gfm', 'markdown'], - action: function action(_ref14) { - var codemirror = _ref14.codemirror, - button = _ref14.button, - textarea = _ref14.textarea; - replacer({ - name: 'strike', - replace: '~~$1$cur~~', - codemirror: codemirror, - button: button - }); - } - } - }, { - delimiter: { - identifier: 'delimiter', - title: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.SUMMARY_DELIMITER, - label: '', - modes: ['gfm', 'markdown'], - action: function action(_ref15) { - var codemirror = _ref15.codemirror, - button = _ref15.button, - textarea = _ref15.textarea; - replacer({ - name: 'delimiter', - replace: "".concat(external_GravAdmin_namespaceObject.config.site.delimiter, "$1"), - codemirror: codemirror, - button: button, - mode: 'replaceLine' - }); - } - } - }, { - link: { - identifier: 'link', - title: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.LINK, - label: '', - modes: ['gfm', 'markdown'], - shortcut: ['Ctrl-K', 'Cmd-K'], - action: function action(_ref16) { - var codemirror = _ref16.codemirror, - button = _ref16.button, - textarea = _ref16.textarea; - replacer({ - name: 'link', - replace: '[$1]($cur)', - codemirror: codemirror, - button: button - }); - } - } - }, { - image: { - identifier: 'image', - title: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.IMAGE, - label: '', - modes: ['gfm', 'markdown'], - action: function action(_ref17) { - var codemirror = _ref17.codemirror, - button = _ref17.button, - textarea = _ref17.textarea; - replacer({ - name: 'image', - replace: '', - codemirror: codemirror, - button: button - }); - } - } - }, { - blockquote: { - identifier: 'blockquote', - title: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.BLOCKQUOTE, - label: '', - modes: ['gfm', 'markdown'], - action: function action(_ref18) { - var codemirror = _ref18.codemirror, - button = _ref18.button, - textarea = _ref18.textarea; - replacer({ - name: 'blockquote', - replace: '> $1', - codemirror: codemirror, - button: button, - mode: 'replaceLine' - }); - } - } - }, { - listUl: { - identifier: 'listUl', - title: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.UNORDERED_LIST, - label: '', - modes: ['gfm', 'markdown'], - action: function action(_ref19) { - var codemirror = _ref19.codemirror, - button = _ref19.button, - textarea = _ref19.textarea; - replacer({ - name: 'listUl', - replace: '* $1', - codemirror: codemirror, - button: button, - mode: 'replaceLine' - }); - } - } - }, { - listOl: { - identifier: 'listOl', - title: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.ORDERED_LIST, - label: '', - modes: ['gfm', 'markdown'], - action: function action(_ref20) { - var codemirror = _ref20.codemirror, - button = _ref20.button, - textarea = _ref20.textarea; - replacer({ - name: 'listOl', - replace: '. $1', - codemirror: codemirror, - button: button, - mode: 'replaceLine', - runner: function runner(line, markup) { - var lineNo = codemirror.getLineNumber(line); - var previousLine = codemirror.getLine(lineNo - 1) || ''; - var match = previousLine.match(/^(\d+)\./); - var prefix = 1 + (match ? Number(match[1]) : 0); - return "".concat(prefix).concat(markup); - } - }); - } - } - }], - states: [{ - code: { - identifier: 'editor', - title: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.EDITOR, - label: '', - action: function action(_ref21) { - var codemirror = _ref21.codemirror, - button = _ref21.button, - textarea = _ref21.textarea, - ui = _ref21.ui; - - if (textarea.data('grav-editor-mode') === 'editor') { - button.addClass('editor-active'); - } - - button.on('click.states.editor', function () { - button.siblings().removeClass('editor-active'); - button.addClass('editor-active'); - textarea.data('grav-editor-mode', 'editor'); - var previewContainer = textarea.data('grav-editor-preview-container'); - var content = textarea.parent('.grav-editor-content'); - content.addClass('is-active'); - ui.navigation.find('.grav-editor-actions').css('visibility', 'visible'); - - if (previewContainer) { - previewContainer.removeClass('is-active'); - } - }); - } - } - }, { - preview: { - identifier: 'preview', - title: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.PREVIEW, - label: '', - modes: ['gfm', 'markdown'], - action: function action(_ref22) { - var codemirror = _ref22.codemirror, - button = _ref22.button, - textarea = _ref22.textarea, - ui = _ref22.ui; - - if (textarea.data('grav-editor-mode') === 'preview') { - button.addClass('editor-active'); - } - - button.on('click.states.preview', function () { - var previewContainer = textarea.data('grav-editor-preview-container'); - var content = textarea.parent('.grav-editor-content'); - button.siblings().removeClass('editor-active'); - button.addClass('editor-active'); - textarea.data('grav-editor-mode', 'preview'); - - if (!previewContainer) { - previewContainer = external_jQuery_default()(''); - content.after(previewContainer); - textarea.data('grav-editor-preview-container', previewContainer); - } - - previewContainer.css({ - height: content.height() - }); - previewContainer.addClass('is-active'); - content.removeClass('is-active'); - ui.navigation.find('.grav-editor-actions').css('visibility', 'hidden'); - var url = "".concat(textarea.data('grav-urlpreview'), "/task").concat(external_GravAdmin_namespaceObject.config.param_sep, "processmarkdown"); - var params = textarea.closest('form').serializeArray(); - var body = {}; - params.map(function (obj) { - body[obj.name] = obj.value; - }); - utils_request(url, { - method: 'post', - body: body - }, function (response) { - return previewContainer.html(response.preview); - }); - }); - } - } - }, { - fullscreen: { - identifier: 'fullscreen', - title: external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.FULLSCREEN, - label: '', - action: function action(_ref23) { - var codemirror = _ref23.codemirror, - button = _ref23.button, - textarea = _ref23.textarea; - button.on('click.editor.fullscreen', function () { - var container = textarea.closest('.grav-editor'); - var wrapper = codemirror.getWrapperElement(); - var contentWrapper = external_jQuery_default()('.content-wrapper'); - - if (!container.hasClass('grav-editor-fullscreen')) { - textarea.data('fullScreenRestore', { - scrollTop: __webpack_require__.g.pageYOffset, - scrollLeft: __webpack_require__.g.pageXOffset, - width: wrapper.style.width, - height: wrapper.style.height - }); - wrapper.style.width = ''; - wrapper.style.height = textarea.parent('.grav-editor-content').height() + 'px'; - __webpack_require__.g.document.documentElement.style.overflow = 'hidden'; - var hints = container.find('.grav-editor-toolbar .hint--top'); - - if (hints) { - hints.removeClass('hint--top').addClass('hint--bottom'); - external_jQuery_default()(hints[hints.length - 1]).addClass('hint--bottom-left'); - } - - if (contentWrapper) { - contentWrapper.css('overflow', 'visible'); - } - } else { - __webpack_require__.g.document.documentElement.style.overflow = ''; - var state = textarea.data('fullScreenRestore'); - wrapper.style.width = state.width; - wrapper.style.height = state.height; - __webpack_require__.g.scrollTo(state.scrollLeft, state.scrollTop); - - var _hints = container.find('.grav-editor-toolbar .hint--bottom'); - - if (_hints) { - _hints.removeClass('hint--bottom').addClass('hint--top'); - - external_jQuery_default()(_hints[_hints.length - 1]).removeClass('hint--bottom-left'); - } - - if (contentWrapper) { - contentWrapper.css('overflow', 'auto'); - } - } - - container.toggleClass('grav-editor-fullscreen'); - setTimeout(function () { - codemirror.refresh(); // this.preview.parent().css('height', this.code.height()); - - external_jQuery_default()(__webpack_require__.g).trigger('resize'); - }, 5); - }); - } - } - }] -}); -// EXTERNAL MODULE: ./node_modules/codemirror/lib/codemirror.js -var codemirror = __webpack_require__(4631); -var codemirror_default = /*#__PURE__*/__webpack_require__.n(codemirror); -// EXTERNAL MODULE: ./node_modules/watchjs/src/watch.js -var watch = __webpack_require__(29950); -// EXTERNAL MODULE: ./node_modules/js-yaml/dist/js-yaml.mjs -var js_yaml = __webpack_require__(47180); -// EXTERNAL MODULE: ./node_modules/codemirror/mode/css/css.js -var css = __webpack_require__(36629); -// EXTERNAL MODULE: ./node_modules/codemirror/mode/gfm/gfm.js -var gfm = __webpack_require__(42425); -// EXTERNAL MODULE: ./node_modules/codemirror/mode/htmlmixed/htmlmixed.js -var htmlmixed = __webpack_require__(16531); -// EXTERNAL MODULE: ./node_modules/codemirror/mode/javascript/javascript.js -var javascript = __webpack_require__(96876); -// EXTERNAL MODULE: ./node_modules/codemirror/mode/markdown/markdown.js -var markdown = __webpack_require__(49047); -// EXTERNAL MODULE: ./node_modules/codemirror/mode/php/php.js -var php = __webpack_require__(36702); -// EXTERNAL MODULE: ./node_modules/codemirror/mode/sass/sass.js -var sass = __webpack_require__(81201); -// EXTERNAL MODULE: ./node_modules/codemirror/mode/twig/twig.js -var twig = __webpack_require__(54702); -// EXTERNAL MODULE: ./node_modules/codemirror/mode/xml/xml.js -var xml = __webpack_require__(29589); -// EXTERNAL MODULE: ./node_modules/codemirror/mode/yaml/yaml.js -var yaml = __webpack_require__(53631); -// EXTERNAL MODULE: ./node_modules/codemirror/addon/edit/continuelist.js -var continuelist = __webpack_require__(23350); -// EXTERNAL MODULE: ./node_modules/codemirror/addon/mode/overlay.js -var overlay = __webpack_require__(14146); -// EXTERNAL MODULE: ./node_modules/codemirror/addon/selection/active-line.js -var active_line = __webpack_require__(20017); -// EXTERNAL MODULE: ./node_modules/codemirror/addon/lint/lint.js -var lint = __webpack_require__(3256); -// EXTERNAL MODULE: ./node_modules/codemirror/addon/lint/lint.css -var lint_lint = __webpack_require__(46226); -// EXTERNAL MODULE: ./node_modules/codemirror/addon/lint/css-lint.js -var css_lint = __webpack_require__(41423); -// EXTERNAL MODULE: ./node_modules/codemirror/addon/lint/javascript-lint.js -var javascript_lint = __webpack_require__(96477); -// EXTERNAL MODULE: ./node_modules/codemirror/addon/lint/json-lint.js -var json_lint = __webpack_require__(62193); -// EXTERNAL MODULE: ./node_modules/codemirror/addon/lint/yaml-lint.js -var yaml_lint = __webpack_require__(82783); -;// CONCATENATED MODULE: ./app/forms/fields/editor.js -function editor_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function editor_defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } - -function editor_createClass(Constructor, protoProps, staticProps) { if (protoProps) editor_defineProperties(Constructor.prototype, protoProps); if (staticProps) editor_defineProperties(Constructor, staticProps); return Constructor; } - - - - - - -__webpack_require__.g.jsyaml = js_yaml/* default */.ZP; // Modes - - - - - - - - - - - // Add-ons - - - - - - - - - - -var IS_MOUSEDOWN = false; -var ThemesMap = ['paper']; -var Defaults = { - codemirror: { - mode: 'htmlmixed', - theme: 'paper', - lineWrapping: true, - dragDrop: true, - autoCloseTags: true, - matchTags: true, - autoCloseBrackets: true, - matchBrackets: true, - indentUnit: 4, - indentWithTabs: false, - tabSize: 4, - hintOptions: { - completionSingle: false - }, - extraKeys: { - 'Enter': 'newlineAndIndentContinueMarkdownList' - } - } -}; - -var EditorField = /*#__PURE__*/function () { - function EditorField(options) { - var _this = this; - - editor_classCallCheck(this, EditorField); - - var body = external_jQuery_default()('body'); - this.editors = external_jQuery_default()(); - this.options = Object.assign({}, Defaults, options); - this.buttons = buttons; - this.buttonStrategies = strategies; - (0,watch.watch)(buttons, function () - /* key, modifier, prev, next */ - { - _this.editors.each(function (index, editor) { - return external_jQuery_default()(editor).data('toolbar').renderButtons(); - }); - }); - external_jQuery_default()('[data-grav-editor]').each(function (index, editor) { - return _this.addEditor(editor); - }); - external_jQuery_default()(function () { - body.trigger('grav-editor-ready'); - }); - body.on('mutation._grav', this._onAddedNodes.bind(this)); - body.on('mouseup._grav', function () { - if (!IS_MOUSEDOWN) { - return true; - } - - body.unbind('mousemove._grav'); - IS_MOUSEDOWN = false; - }); - body.on('mousedown._grav', '.grav-editor-resizer', function (event) { - event && event.preventDefault(); - IS_MOUSEDOWN = true; - var target = external_jQuery_default()(event.currentTarget); - var container = target.siblings('.grav-editor-content'); - var editor = container.find('.CodeMirror'); - var codemirror = container.find('textarea').data('codemirror'); - body.on('mousemove._grav', function (event) { - editor.css('height', Math.max(100, event.pageY - container.offset().top)); - codemirror.refresh(); - }); - }); - } - - editor_createClass(EditorField, [{ - key: "addButton", - value: function addButton(button, options) { - if (options && (options.before || options.after)) { - var index = this.buttons.navigation.findIndex(function (obj) { - var key = Object.keys(obj).shift(); - return obj[key].identifier === (options.before || options.after); - }); - - if (!~index) { - options = 'end'; - } else { - this.buttons.navigation.splice(options.before ? index : index + 1, 0, button); - } - } - - if (options === 'start') { - this.buttons.navigation.splice(0, 0, button); - } - - if (!options || options === 'end') { - this.buttons.navigation.push(button); - } - } - }, { - key: "addEditor", - value: function addEditor(textarea) { - textarea = external_jQuery_default()(textarea); - var options = Object.assign({}, this.options.codemirror, textarea.data('grav-editor').codemirror); - var theme = options.theme || 'paper'; - this.editors = this.editors.add(textarea); - - if (theme && !~ThemesMap.indexOf(theme)) { - ThemesMap.push(theme); // let themeCSS = `https://cdnjs.cloudflare.com/ajax/libs/codemirror/5.12.0/theme/${theme}.min.css`; - // $('head').append($('').attr('href', themeCSS)); - } - - if (options.mode === 'yaml') { - Object.assign(options.extraKeys, { - Tab: function Tab(cm) { - cm.replaceSelection(' ', 'end'); - } - }); - } - - var editor = codemirror_default().fromTextArea(textarea.get(0), options); - textarea.data('codemirror', editor); - textarea.data('toolbar', new Toolbar(textarea)); - textarea.addClass('code-mirrored'); - - if (options.toolbar === false) { - textarea.data('toolbar').ui.navigation.addClass('grav-editor-hide-toolbar'); - } - - editor.on('change', function () { - return editor.save(); - }); - } - }, { - key: "_onAddedNodes", - value: function _onAddedNodes(event, target - /* , record, instance */ - ) { - var _this2 = this; - - var editors = external_jQuery_default()(target).find('[data-grav-editor]'); - - if (!editors.length) { - return; - } - - editors.each(function (index, editor) { - editor = external_jQuery_default()(editor); - - if (!~_this2.editors.index(editor)) { - _this2.addEditor(editor); - } - }); - } - }]); - - return EditorField; -}(); - - -var Toolbar = /*#__PURE__*/function () { - function Toolbar(editor) { - editor_classCallCheck(this, Toolbar); - - this.editor = external_jQuery_default()(editor); - this.codemirror = this.editor.data('codemirror'); - this.buttons = buttons.navigation; - this.ui = { - navigation: external_jQuery_default()(Toolbar.templates().navigation) - }; - this.editor.parent('.grav-editor-content').before(this.ui.navigation).after(this.ui.states); - this.renderButtons(); - } - - editor_createClass(Toolbar, [{ - key: "renderButtons", - value: function renderButtons() { - var _this3 = this; - - var map = { - 'actions': 'navigation', - 'modes': 'states' - }; - ['actions', 'modes'].forEach(function (type) { - _this3.ui.navigation.find(".grav-editor-".concat(type)).empty().append('
No media found
'); -}; - -var filterFiles = function filterFiles() { - cleanFilesList(); - global_index = 0; - files_ended = false; - external_jQuery_default()('.empty-space').remove(); - loadMedia(filters, function (content) { - if (!content.trim().length) { - showEmptyState(); - } else { - if (!filters.page && (!filters.date || filters.date === '*') && (!filters.type || filters.type === '*')) { - external_jQuery_default()('.js__files').trigger('fillView'); - } - } - }); -}; -/* handle changing page */ - - -external_jQuery_default()('body').on('click', '.pages-list-container .js__page-link', function (event) { - var page = external_jQuery_default()(event.target).data('page'); - filters['page'] = page; - external_jQuery_default()('.media-list-title .page-indicator').html(page); // set indication - - external_jQuery_default()('.js__reset-pages-filter').removeClass('hidden'); // activate reset pages icon - - resetActiveStateInSidebar(); - external_jQuery_default()(event.target).parents('.row').addClass('active'); // set active state in sidebar - - external_jQuery_default()('.js__file-uploader').removeClass('hidden'); // customize processing URL, as the page changes dynamically - - if (external_jQuery_default()('.dropzone')[0]) { - external_jQuery_default()('.dropzone')[0].dropzone.on('processing', function (file) { - this.options.url = "".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/media-manager").concat(page, ".json/task").concat(external_GravAdmin_namespaceObject.config.param_sep, "addmedia"); - }); - } - - external_jQuery_default()('.js__button-clear-media-cache').addClass('hidden'); - filterFiles(); - disableInfiniteScrolling(); // only infinite scroll on main list, not inside single pages -}); -/* handle clearing page filter */ - -external_jQuery_default()('body').on('click', '.js__reset-pages-filter', function (event) { - external_jQuery_default()('.media-list-title .page-indicator').html('All Pages'); // set indication - - cleanFilesList(); - resetActiveStateInSidebar(); - external_jQuery_default()('.js__reset-pages-filter').addClass('hidden'); // remove reset pages icon - - external_jQuery_default()('.js__file-uploader').addClass('hidden'); - external_jQuery_default()('.js__button-clear-media-cache').removeClass('hidden'); - delete filters['page']; - filterFiles(); -}); -/* handle infinite loading */ - -var enableInfiniteScrolling = function enableInfiniteScrolling() { - external_jQuery_default()('.spinning-wheel').hide(); - var view = external_jQuery_default()('.mediapicker-scroll').last(); - - if (!view.length) { - return; - } - - external_jQuery_default()(view).on('scroll', function () { - if (external_jQuery_default()(this).scrollTop() + external_jQuery_default()(this).innerHeight() + 100 >= external_jQuery_default()(this)[0].scrollHeight) { - fillView(); - } - }); -}; - -var loadNextBatch = function loadNextBatch(callback) { - if (files_ended) { - return; - } - - loadMedia({}, function (content) { - if (!external_jQuery_default()(content).length || content.split('card-item').length - 1 < MEDIA_PAGINATION_INTERVAL) { - files_ended = true; - } else { - if (callback) { - callback(); - } - } - - external_jQuery_default()('.media-container .media-range').trigger('input'); - }); -}; - -var fillView = function fillView() { - if (!external_jQuery_default()('.js__files').find('.card-item').last().offset()) { - setTimeout(function () { - // retry later - fillView(); - }, 300); - return; - } - - if (external_jQuery_default()('.js__files').find('.card-item').last().offset().top - 1 <= external_jQuery_default()('.media-container').height()) { - loadNextBatch(function () { - fillView(); - }); - } -}; -/* disable infinite loading */ - - -var disableInfiniteScrolling = function disableInfiniteScrolling() { - external_jQuery_default()('.spinning-wheel').hide(); - external_jQuery_default()('.content-wrapper').unbind('scroll'); -}; - -external_jQuery_default()('.js__files').on('fillView', function (event) { - // the first batch got the max number of media files, try loading more - if (external_jQuery_default()('.js__files')[0].innerHTML.split('card-item').length - 1 === MEDIA_PAGINATION_INTERVAL) { - fillView(); - enableInfiniteScrolling(); - } -}); -;// CONCATENATED MODULE: ./app/utils/2fa.js - - - -var _2fa_body = external_jQuery_default()('body'); // Dashboard update and Grav update - -_2fa_body.on('click', '[data-2fa-regenerate]', function (event) { - event.preventDefault(); - var element = external_jQuery_default()(this); - var url = "".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/ajax.json/task").concat(external_GravAdmin_namespaceObject.config.param_sep, "regenerate2FASecret"); - element.attr('disabled', 'disabled').find('> .fa').addClass('fa-spin'); - utils_request(url, { - method: 'post' - }, function (response) { - external_jQuery_default()('[data-2fa-image]').attr('src', response.image); - external_jQuery_default()('[data-2fa-secret]').text(response.secret); - external_jQuery_default()('[data-2fa-value]').val(response.secret.replace(' ', '')); - element.removeAttr('disabled').find('> .fa').removeClass('fa-spin'); - }); -}); - -var toggleSecret = function toggleSecret() { - var toggle = external_jQuery_default()('#toggle_twofa_enabled1'); - var secret = external_jQuery_default()('.twofa-secret'); - secret[toggle.is(':checked') ? 'addClass' : 'removeClass']('show'); -}; - -_2fa_body.on('click', '.twofa-toggle input', toggleSecret); -toggleSecret(); -// EXTERNAL MODULE: ./node_modules/mout/queryString.js -var queryString = __webpack_require__(85407); -;// CONCATENATED MODULE: ./app/tools/logs.js - - - -var prepareQuery = function prepareQuery(key, value) { - return (0,queryString.setParam)(__webpack_require__.g.location.href, key, value); -}; - -external_jQuery_default()(document).on('change', '.logs-content .block-select select[name]', function (event) { - var target = external_jQuery_default()(event.currentTarget); - var name = target.attr('name'); - var value = target.val(); - __webpack_require__.g.location.href = prepareQuery(name, value); -}); -;// CONCATENATED MODULE: ./app/tools/index.js - -;// CONCATENATED MODULE: ./app/whitelabel/compile.js - - -/* harmony default export */ const compile = (function () { - var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, - _ref$preview = _ref.preview, - preview = _ref$preview === void 0 ? false : _ref$preview, - _ref$exportScss = _ref.exportScss, - exportScss = _ref$exportScss === void 0 ? false : _ref$exportScss, - _ref$color_scheme = _ref.color_scheme, - color_scheme = _ref$color_scheme === void 0 ? {} : _ref$color_scheme, - _ref$fonts = _ref.fonts, - fonts = _ref$fonts === void 0 ? {} : _ref$fonts, - _ref$callback = _ref.callback, - callback = _ref$callback === void 0 ? function () {} : _ref$callback; - - var task = exportScss ? 'exportScss' : 'compileScss'; // console.log(config); - - var URI = "".concat(external_GravAdmin_namespaceObject.config.base_url_relative, ".json/task:").concat(task); - utils_request(URI, { - method: 'post', - body: Object.assign({}, preview ? { - preview: preview - } : null, color_scheme) - }, callback); -}); -var prepareElement = function prepareElement(element) { - element.data('busy_right_now', true); - - if (!element.data('current_icon')) { - element.data('current_icon', element.find('.fa').attr('class')); - } - - element.find('.fa').attr('class', 'fa fa-fw fa-spin fa-refresh'); -}; -var resetElement = function resetElement(element) { - element.data('busy_right_now', false); - element.find('.fa').attr('class', element.data('current_icon')); -}; -;// CONCATENATED MODULE: ./app/whitelabel/presets.js - - -var presets_body = external_jQuery_default()('body'); -var presets_fields = []; -var presets_FormState = app_forms.FormState.Instance; - -var setField = function setField(field, value) { - var name = field.prop('name'); - var tag = field.prop('tagName').toLowerCase(); - var type = field.prop('type'); - presets_fields.push(name); - - switch (tag) { - case 'select': - field.val(value); - field.data('selectize').setValue(value); - field.trigger('change'); - break; - - case 'input': - if (type === 'radio') { - var strValue = value ? '1' : '0'; - field.filter(function (index, radio) { - return external_jQuery_default()(radio).val() === strValue; - }).prop('checked', true); - break; - } - - if (type === 'checkbox') { - field.prop('checked', value); - break; - } - - field.val(value); - field.trigger('keyup'); - } -}; - -presets_body.on('click', '[data-preset-values]', function (event) { - var target = external_jQuery_default()(event.currentTarget); - var data = target.data('preset-values'); - Object.keys(data).forEach(function (section) { - if (typeof data[section] === 'string') { - return; - } - - Object.keys(data[section]).forEach(function (key) { - var field = external_jQuery_default()("[name=\"data[whitelabel][color_scheme][".concat(section, "][").concat(key, "]\"], [name=\"data[").concat(section, "][").concat(key, "]\"]")); - var value = data[section][key]; - setField(field, value); - }); - }); -}); -presets_body.on('click', '[data-reset-scss]', function (event) { - event && event.preventDefault(); - var element = external_jQuery_default()(event.currentTarget); - var links = external_jQuery_default()('link[id^=admin-pro-preview-]'); - element.remove(); - links.remove(); - presets_fields.forEach(function (field) { - var value = presets_FormState.loadState.get(field); - setField(external_jQuery_default()("[name=\"".concat(field, "\"]")), value); - }); - presets_fields = []; -}); // Horizontal Scroll Functionality - -(external_jQuery_default()).fn.hscrollarrows = function () { - return this.each(function () { - var navNext = external_jQuery_default()(''); - var navPrev = external_jQuery_default()(''); - var scrollTime = null; - var resizeTime = null; - var scrolling = false; - var elm_w = 0; - var elem_data_w = 0; - var max_scroll = 0; - var inc_scroll = 0; - - var calcData = function calcData() { - elm_w = elem.width(); - elem_data_w = elem_data.get(0).scrollWidth; - max_scroll = elem_data_w - elm_w; - inc_scroll = elm_w * 0.3; // 20% - }; - - var revalidate = function revalidate() { - calcData(); - stateNavs(); - }; - - var run = function run() { - calcData(); - setupNavs(); - }; - - var setupNavs = function setupNavs() { - elem.parent().prepend(navNext); - elem.parent().prepend(navPrev); - navNext.on('click', next); - navPrev.on('click', prev); - stateNavs(); - external_jQuery_default()(elem).scroll(function () { - if (!scrolling) { - clearTimeout(scrollTime); - scrollTime = setTimeout(function () { - stateNavs(); - }, 250); - } - }); - external_jQuery_default()(window).resize(function () { - clearTimeout(resizeTime); - resizeTime = setTimeout(function () { - revalidate(); - }, 250); - }); - }; - - var stateNavs = function stateNavs() { - var current_scroll = elem.scrollLeft(); - - if (current_scroll < max_scroll) { - navNext.removeClass('hide'); - } else { - navNext.addClass('hide'); - } - - if (current_scroll > 0) { - navPrev.removeClass('hide'); - } else { - navPrev.addClass('hide'); - } - - scrolling = false; - }; - - var next = function next() { - var current_scroll = elem.scrollLeft(); - - if (current_scroll < max_scroll) { - scrolling = true; - elem.stop().animate({ - scrollLeft: current_scroll + inc_scroll - }, stateNavs); - } - }; - - var prev = function prev() { - var current_scroll = elem.scrollLeft(); - - if (current_scroll > 0) { - scrolling = true; - elem.stop().animate({ - scrollLeft: current_scroll - inc_scroll - }, stateNavs); - } - }; - - var elem = external_jQuery_default()(this); - var elem_data = external_jQuery_default()(':first-child', elem); - run(); - }); -}; - -external_jQuery_default()(document).ready(function () { - external_jQuery_default()('.jquery-horizontal-scroll').hscrollarrows(); -}); -;// CONCATENATED MODULE: ./app/whitelabel/index.js - - - - - -var whitelabel_body = external_jQuery_default()('body'); -var whitelabel_FormState = app_forms.FormState.Instance; - -var compiler = function compiler(element) { - var preview = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; - var exportScss = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - - var _callback = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : function () {}; - - prepareElement(element); - var fields = whitelabel_FormState.collect(); - compile({ - preview: preview, - exportScss: exportScss, - color_scheme: !fields ? [] : fields.filter(function (value, key) { - return key.match(/^data\[whitelabel]\[color_scheme]/); - }).toJS(), - callback: function callback(response) { - _callback.call(_callback, response); - - resetElement(element); - } - }); -}; - -whitelabel_body.on('click', '[data-preview-scss]', function (event) { - event && event.preventDefault(); - var element = external_jQuery_default()(event.currentTarget); - - if (element.data('busy_right_now')) { - return false; - } - - compiler(element, true, false, function (response) { - if (response.files) { - Object.keys(response.files).forEach(function (key) { - var file = external_jQuery_default()("#admin-pro-preview-".concat(key)); - var timestamp = Date.now(); - - if (!file.length) { - file = external_jQuery_default()("")); - external_jQuery_default()('head').append(file); - - if (!external_jQuery_default()('[data-reset-scss]').length) { - var reset = external_jQuery_default()(''); - reset.insertAfter(element); - } - } - - file.attr('href', "".concat(response.files[key], "?").concat(timestamp)); - }); - } - }); -}); -whitelabel_body.on('click', '[data-recompile-scss]', function (event) { - event && event.preventDefault(); - var element = external_jQuery_default()(event.currentTarget); - - if (element.data('busy_right_now')) { - return false; - } - - compiler(element, true, false); -}); -whitelabel_body.on('click', '[data-export-scss]', function (event) { - event && event.preventDefault(); - var element = external_jQuery_default()(event.currentTarget); - - if (element.data('busy_right_now')) { - return false; - } - - compiler(element, true, true, function (response) { - if (response.files) { - Object.keys(response.files).forEach(function (key) { - if (key === 'download') { - var _element = document.createElement('a'); - - _element.setAttribute('href', response.files[key]); - - _element.setAttribute('download', ''); - - _element.style.display = 'none'; - document.body.appendChild(_element); - - _element.click(); - - document.body.removeChild(_element); - } - }); - } - }); -}); -whitelabel_body.on('change._grav_colorpicker', '[data-grav-colorpicker]', function (event, input, hex, opacity) { - var RGB = hex2rgb(hex); - var YIQ = (RGB.r * 299 + RGB.g * 587 + RGB.b * 114) / 1000; - var contrast = YIQ >= 128 || opacity <= 0.50 ? 'dark' : 'light'; - input.parent().removeClass('dark-text light-text').addClass("".concat(contrast, "-text")); -}); -whitelabel_body.ready(function () { - external_jQuery_default()('[data-grav-colorpicker]').trigger('keyup'); -}); -;// CONCATENATED MODULE: ./app/utils/bootstrap-transition.js - -+function ($) { - 'use strict'; // CSS TRANSITION SUPPORT (Shoutout: http://www.modernizr.com/) - // ============================================================ - - function transitionEnd() { - var el = document.createElement('bootstrap'); - var transEndEventNames = { - WebkitTransition: 'webkitTransitionEnd', - MozTransition: 'transitionend', - OTransition: 'oTransitionEnd otransitionend', - transition: 'transitionend' - }; - - for (var name in transEndEventNames) { - if (el.style[name] !== undefined) { - return { - end: transEndEventNames[name] - }; - } - } - - return false; // explicit for ie8 ( ._.) - } // http://blog.alexmaccaw.com/css-transitions - - - $.fn.emulateTransitionEnd = function (duration) { - var called = false; - var $el = this; - $(this).one('bsTransitionEnd', function () { - called = true; - }); - - var callback = function callback() { - if (!called) $($el).trigger($.support.transition.end); - }; - - setTimeout(callback, duration); - return this; - }; - - $(function () { - $.support.transition = transitionEnd(); - if (!$.support.transition) return; - $.event.special.bsTransitionEnd = { - bindType: $.support.transition.end, - delegateType: $.support.transition.end, - handle: function handle(e) { - if ($(e.target).is(this)) return e.handleObj.handler.apply(this, arguments); - } - }; - }); -}((external_jQuery_default())); -;// CONCATENATED MODULE: ./app/utils/bootstrap-collapse.js -function bootstrap_collapse_typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { bootstrap_collapse_typeof = function _typeof(obj) { return typeof obj; }; } else { bootstrap_collapse_typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return bootstrap_collapse_typeof(obj); } - - -/* ======================================================================== - * Bootstrap: collapse.js v3.4.0 - * http://getbootstrap.com/javascript/#collapse - * ======================================================================== - * Copyright 2011-2016 Twitter, Inc. - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) - * ======================================================================== */ - -/* jshint latedef: false */ - -+function ($) { - 'use strict'; // COLLAPSE PUBLIC CLASS DEFINITION - // ================================ - - var Collapse = function Collapse(element, options) { - this.$element = $(element); - this.options = $.extend({}, Collapse.DEFAULTS, options); - this.$trigger = $('[data-toggle="collapse"][href="#' + element.id + '"],' + '[data-toggle="collapse"][data-target="#' + element.id + '"]'); - this.transitioning = null; - - if (this.options.parent) { - this.$parent = this.getParent(); - } else { - this.addAriaAndCollapsedClass(this.$element, this.$trigger); - } - - if (this.options.toggle) this.toggle(); - }; - - Collapse.VERSION = '3.4.0'; - Collapse.TRANSITION_DURATION = 350; - Collapse.DEFAULTS = { - toggle: true - }; - - Collapse.prototype.dimension = function () { - var hasWidth = this.$element.hasClass('width'); - return hasWidth ? 'width' : 'height'; - }; - - Collapse.prototype.show = function () { - if (this.transitioning || this.$element.hasClass('in')) return; - var activesData; - var actives = this.$parent && this.$parent.children('.panel').children('.in, .collapsing'); - - if (actives && actives.length) { - activesData = actives.data('bs.collapse'); - if (activesData && activesData.transitioning) return; - } - - var startEvent = $.Event('show.bs.collapse'); - this.$element.trigger(startEvent); - if (startEvent.isDefaultPrevented()) return; - - if (actives && actives.length) { - Plugin.call(actives, 'hide'); - activesData || actives.data('bs.collapse', null); - } - - var dimension = this.dimension(); - this.$element.removeClass('collapse').addClass('collapsing')[dimension](0).attr('aria-expanded', true); - this.$trigger.removeClass('collapsed').attr('aria-expanded', true); - this.transitioning = 1; - - var complete = function complete() { - this.$element.removeClass('collapsing').addClass('collapse in')[dimension](''); - this.transitioning = 0; - this.$element.trigger('shown.bs.collapse'); - }; - - if (!$.support.transition) return complete.call(this); - var scrollSize = $.camelCase(['scroll', dimension].join('-')); - this.$element.one('bsTransitionEnd', $.proxy(complete, this)).emulateTransitionEnd(Collapse.TRANSITION_DURATION)[dimension](this.$element[0][scrollSize]); - }; - - Collapse.prototype.hide = function () { - if (this.transitioning || !this.$element.hasClass('in')) return; - var startEvent = $.Event('hide.bs.collapse'); - this.$element.trigger(startEvent); - if (startEvent.isDefaultPrevented()) return; - var dimension = this.dimension(); - this.$element[dimension](this.$element[dimension]())[0].offsetHeight; - this.$element.addClass('collapsing').removeClass('collapse in').attr('aria-expanded', false); - this.$trigger.addClass('collapsed').attr('aria-expanded', false); - this.transitioning = 1; - - var complete = function complete() { - this.transitioning = 0; - this.$element.removeClass('collapsing').addClass('collapse').trigger('hidden.bs.collapse'); - }; - - if (!$.support.transition) return complete.call(this); - this.$element[dimension](0).one('bsTransitionEnd', $.proxy(complete, this)).emulateTransitionEnd(Collapse.TRANSITION_DURATION); - }; - - Collapse.prototype.toggle = function () { - this[this.$element.hasClass('in') ? 'hide' : 'show'](); - }; - - Collapse.prototype.getParent = function () { - return $(this.options.parent).find('[data-toggle="collapse"][data-parent="' + this.options.parent + '"]').each($.proxy(function (i, element) { - var $element = $(element); - this.addAriaAndCollapsedClass(getTargetFromTrigger($element), $element); - }, this)).end(); - }; - - Collapse.prototype.addAriaAndCollapsedClass = function ($element, $trigger) { - var isOpen = $element.hasClass('in'); - $element.attr('aria-expanded', isOpen); - $trigger.toggleClass('collapsed', !isOpen).attr('aria-expanded', isOpen); - }; - - function getTargetFromTrigger($trigger) { - var href; - var target = $trigger.attr('data-target') || (href = $trigger.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, ''); // strip for ie7 - - return $(target); - } // COLLAPSE PLUGIN DEFINITION - // ========================== - - - function Plugin(option) { - return this.each(function () { - var $this = $(this); - var data = $this.data('bs.collapse'); - var options = $.extend({}, Collapse.DEFAULTS, $this.data(), bootstrap_collapse_typeof(option) === 'object' && option); - if (!data && options.toggle && /show|hide/.test(option)) options.toggle = false; - if (!data) $this.data('bs.collapse', data = new Collapse(this, options)); - if (typeof option === 'string') data[option](); - }); - } - - var old = $.fn.collapse; - $.fn.collapse = Plugin; - $.fn.collapse.Constructor = Collapse; // COLLAPSE NO CONFLICT - // ==================== - - $.fn.collapse.noConflict = function () { - $.fn.collapse = old; - return this; - }; // COLLAPSE DATA-API - // ================= - - - $(document).on('click.bs.collapse.data-api', '[data-toggle="collapse"]', function (e) { - var $this = $(this); - if (!$this.attr('data-target')) e.preventDefault(); - var $target = getTargetFromTrigger($this); - var data = $target.data('bs.collapse'); - var option = data ? 'toggle' : $this.data(); - Plugin.call($target, option); - }); -}((external_jQuery_default())); -;// CONCATENATED MODULE: ./app/utils/bootstrap-dropdown.js - -/* ======================================================================== - * Bootstrap: dropdown.js v3.4.1 - * https://getbootstrap.com/docs/3.4/javascript/#dropdowns - * ======================================================================== - * Copyright 2011-2019 Twitter, Inc. - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/v3-dev/LICENSE) - * ======================================================================== */ - -+function ($) { - 'use strict'; // DROPDOWN CLASS DEFINITION - // ========================= - - var backdrop = '.dropdown-backdrop'; - var toggle = '[data-toggle="dropdown"]'; - - var Dropdown = function Dropdown(element) { - $(element).on('click.bs.dropdown', this.toggle); - }; - - Dropdown.VERSION = '3.4.1'; - - function getParent($this) { - var selector = $this.attr('data-target'); - - if (!selector) { - selector = $this.attr('href'); - selector = selector && /#[A-Za-z]/.test(selector) && selector.replace(/.*(?=#[^\s]*$)/, ''); // strip for ie7 - } - - var $parent = selector !== '#' ? $(document).find(selector) : null; - return $parent && $parent.length ? $parent : $this.parent(); - } - - function clearMenus(e) { - if (e && e.which === 3) { - return; - } - - $(backdrop).remove(); - $(toggle).each(function () { - var $this = $(this); - var $parent = getParent($this); - var relatedTarget = { - relatedTarget: this - }; - - if (!$parent.hasClass('open')) { - return; - } - - if (e && e.type === 'click' && /input|textarea/i.test(e.target.tagName) && $.contains($parent[0], e.target)) { - return; - } - - $parent.trigger(e = $.Event('hide.bs.dropdown', relatedTarget)); - - if (e.isDefaultPrevented()) { - return; - } - - $this.attr('aria-expanded', 'false'); - $parent.removeClass('open').trigger($.Event('hidden.bs.dropdown', relatedTarget)); - }); - } - - Dropdown.prototype.toggle = function (e) { - var $this = $(this); - - if ($this.is('.disabled, :disabled')) { - return; - } - - var $parent = getParent($this); - var isActive = $parent.hasClass('open'); - clearMenus(); - - if (!isActive) { - if ('ontouchstart' in document.documentElement && !$parent.closest('.navbar-nav').length) { - // if mobile we use a backdrop because click events don't delegate - $(document.createElement('div')).addClass('dropdown-backdrop').insertAfter($(this)).on('click', clearMenus); - } - - var relatedTarget = { - relatedTarget: this - }; - $parent.trigger(e = $.Event('show.bs.dropdown', relatedTarget)); - - if (e.isDefaultPrevented()) { - return; - } - - $this.trigger('focus').attr('aria-expanded', 'true'); - $parent.toggleClass('open').trigger($.Event('shown.bs.dropdown', relatedTarget)); - } - - return false; - }; - - Dropdown.prototype.keydown = function (e) { - if (!/(38|40|27|32)/.test(e.which) || /input|textarea/i.test(e.target.tagName)) return; - var $this = $(this); - e.preventDefault(); - e.stopPropagation(); - - if ($this.is('.disabled, :disabled')) { - return; - } - - var $parent = getParent($this); - var isActive = $parent.hasClass('open'); - - if (!isActive && e.which !== 27 || isActive && e.which === 27) { - if (e.which === 27) { - $parent.find(toggle).trigger('focus'); - } - - return $this.trigger('click'); - } - - var desc = ' li:not(.disabled):visible a'; - var $items = $parent.find('.dropdown-menu' + desc); - - if (!$items.length) { - return; - } - - var index = $items.index(e.target); - - if (e.which === 38 && index > 0) { - index--; - } // up - - - if (e.which === 40 && index < $items.length - 1) { - index++; - } // down - - - if (!~index) { - index = 0; - } - - $items.eq(index).trigger('focus'); - }; // DROPDOWN PLUGIN DEFINITION - // ========================== - - - function Plugin(option) { - return this.each(function () { - var $this = $(this); - var data = $this.data('bs.dropdown'); - if (!data) $this.data('bs.dropdown', data = new Dropdown(this)); - if (typeof option === 'string') data[option].call($this); - }); - } - - var old = $.fn.dropdown; - $.fn.dropdown = Plugin; - $.fn.dropdown.Constructor = Dropdown; // DROPDOWN NO CONFLICT - // ==================== - - $.fn.dropdown.noConflict = function () { - $.fn.dropdown = old; - return this; - }; // APPLY TO STANDARD DROPDOWN ELEMENTS - // =================================== - - - $(document).on('click.bs.dropdown.data-api', clearMenus).on('click.bs.dropdown.data-api', '.dropdown form', function (e) { - e.stopPropagation(); - }).on('click.bs.dropdown.data-api', toggle, Dropdown.prototype.toggle).on('keydown.bs.dropdown.data-api', toggle, Dropdown.prototype.keydown).on('keydown.bs.dropdown.data-api', '.dropdown-menu', Dropdown.prototype.keydown); -}((external_jQuery_default())); -;// CONCATENATED MODULE: ./app/utils/tabs-memory.js - - - -var tabs_memory_Data = JSON.parse(cookies.get('grav-tabs-state') || '{}'); -external_jQuery_default()('body').on('touchstart click', '[data-tabid]', function (event) { - event && event.stopPropagation(); - var target = external_jQuery_default()(event.currentTarget); - tabs_memory_Data[target.data('tabkey')] = target.data('scope'); - cookies.set('grav-tabs-state', JSON.stringify(tabs_memory_Data), { - expires: Infinity - }); - var panel = external_jQuery_default()("[id=\"".concat(target.data('tabid'), "\"]")); - target.siblings('[data-tabid]').removeClass('active'); - target.addClass('active'); - panel.siblings('[id]').removeClass('active'); - panel.addClass('active'); - editor_Instance.editors.each(function (index, editor) { - var codemirror = external_jQuery_default()(editor).data('codemirror'); - - if (!codemirror) { - return; - } - - if (codemirror.display.lastWrapWidth === 0) { - codemirror.refresh(); - } - }); -}); -;// CONCATENATED MODULE: ./app/utils/changelog.js -/* eslint-disable */ - -var TRIGGER = null; -external_jQuery_default()(document).on('click', '[data-remodal-changelog]', function (event) { - TRIGGER = event.currentTarget; -}); -external_jQuery_default()(document).on('opened', '[data-remodal-id="changelog"]', function () { - var instance = (external_jQuery_default()).remodal.lookup[external_jQuery_default()('[data-remodal-id=changelog]').data('remodal')]; - instance.$modal.html('\".concat(grav_config__WEBPACK_IMPORTED_MODULE_3__.translations.PLUGIN_ADMIN.FILE_ERROR_UPLOAD, \" \").concat(file.name, \"
\\n\").concat(response.message, \"\")\n });\n }\n }, {\n key: \"onDropzoneComplete\",\n value: function onDropzoneComplete(file) {\n if (!file.accepted && !file.rejected) {\n var data = {\n status: 'error',\n message: \"\".concat(grav_config__WEBPACK_IMPORTED_MODULE_3__.translations.PLUGIN_ADMIN.FILE_UNSUPPORTED, \": \").concat(file.name.match(/\\..+/).join(''))\n };\n return this.handleError({\n file: file,\n data: data,\n mode: 'removeFile',\n msg: \"
\".concat(grav_config__WEBPACK_IMPORTED_MODULE_3__.translations.PLUGIN_ADMIN.FILE_ERROR_ADD, \" \").concat(file.name, \"
\\n\").concat(data.message, \"\")\n });\n }\n\n if (this.options.reloadPage) {\n __webpack_require__.g.location.reload();\n }\n }\n }, {\n key: \"b64_to_utf8\",\n value: function b64_to_utf8(str) {\n str = str.replace(/\\s/g, '');\n return decodeURIComponent(escape(window.atob(str)));\n }\n }, {\n key: \"onDropzoneRemovedFile\",\n value: function onDropzoneRemovedFile(file) {\n var _this5 = this;\n\n if (!file.accepted || file.rejected) {\n return;\n }\n\n var url = file.removeUrl || this.urls[\"delete\"] || this.options.url;\n var path = (url || '').match(/path:(.*)\\//);\n var body = {\n filename: file.name,\n uri: this.getURI()\n };\n\n if (file.sessionParams) {\n body.task = 'filessessionremove';\n body.session = file.sessionParams;\n }\n\n var customPost = this.container.data('filePostRemove') || {};\n\n if (Object.keys(customPost).length) {\n body = {};\n Object.keys(customPost).forEach(function (key) {\n body[key] = customPost[key];\n });\n }\n\n body['filename'] = file.name;\n body['admin-nonce'] = grav_config__WEBPACK_IMPORTED_MODULE_3__.config.admin_nonce;\n (0,_utils_request__WEBPACK_IMPORTED_MODULE_2__.default)(url, {\n method: 'post',\n body: body\n }, function () {\n if (!path) {\n return;\n }\n\n path = _this5.b64_to_utf8(path[1]);\n\n var input = _this5.container.find('[name][type=\"hidden\"]');\n\n var data = JSON.parse(input.val() || '{}');\n delete data[path];\n input.val(JSON.stringify(data));\n });\n }\n }, {\n key: \"onDropzoneError\",\n value: function onDropzoneError(file, response, xhr) {\n var message = xhr ? response.error.message : response;\n jquery__WEBPACK_IMPORTED_MODULE_0___default()(file.previewElement).find('[data-dz-errormessage]').html(message);\n return this.handleError({\n file: file,\n data: {\n status: 'error'\n },\n msg: \"
\".concat(message, \"\")\n });\n }\n }, {\n key: \"handleError\",\n value: function handleError(options) {\n var file = options.file,\n data = options.data,\n mode = options.mode,\n msg = options.msg;\n\n if (data.status !== 'error' && data.status !== 'unauthorized') {\n return;\n }\n\n switch (mode) {\n case 'addBack':\n if (file instanceof File) {\n this.dropzone.addFile.call(this.dropzone, file);\n } else {\n this.dropzone.files.push(file);\n this.dropzone.options.addedfile.call(this.dropzone, file);\n this.dropzone.options.thumbnail.call(this.dropzone, file, file.extras.url);\n }\n\n break;\n\n case 'removeFile':\n default:\n if (~this.dropzone.files.indexOf(file)) {\n file.rejected = true;\n this.dropzone.removeFile.call(this.dropzone, file, {\n silent: true\n });\n }\n\n break;\n }\n\n var modal = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-remodal-id=\"generic\"]');\n modal.find('.error-content').html(msg);\n (jquery__WEBPACK_IMPORTED_MODULE_0___default().remodal.lookup)[modal.data('remodal')].open();\n }\n }]);\n\n return FilesField;\n}();\n\n\nfunction UriToMarkdown(uri) {\n uri = uri.replace(/@3x|@2x|@1x/, '');\n uri = uri.replace(/\\(/g, '%28');\n uri = uri.replace(/\\)/g, '%29');\n var title = uri.split('.').slice(0, -1).join('.');\n return uri.match(/\\.(jpe?g|png|gif|svg|mp4|webm|ogv|mov)$/i) ? \".concat(uri, \" \\\"\").concat(title, \"\\\")\") : \"[\".concat(decodeURI(uri), \"](\").concat(uri, \")\");\n}\nvar instances = [];\nvar cache = jquery__WEBPACK_IMPORTED_MODULE_0___default()();\n\nvar onAddedNodes = function onAddedNodes(event, target\n/* , record, instance */\n) {\n var files = jquery__WEBPACK_IMPORTED_MODULE_0___default()(target).find('.dropzone.files-upload');\n\n if (!files.length) {\n return;\n }\n\n files.each(function (index, file) {\n file = jquery__WEBPACK_IMPORTED_MODULE_0___default()(file);\n\n if (!~cache.index(file)) {\n addNode(file);\n }\n });\n};\n\nvar addNode = function addNode(container) {\n container = jquery__WEBPACK_IMPORTED_MODULE_0___default()(container);\n var input = container.find('input[type=\"file\"]');\n var settings = container.data('grav-file-settings') || {};\n\n if (settings.accept && ~settings.accept.indexOf('*')) {\n settings.accept = [''];\n }\n\n var options = {\n url: container.data('file-url-add') || (container.closest('form').attr('action') || grav_config__WEBPACK_IMPORTED_MODULE_3__.config.current_url) + '.json',\n paramName: settings.paramName || 'file',\n dotNotation: settings.name || 'file',\n acceptedFiles: settings.accept ? settings.accept.join(',') : input.attr('accept') || container.data('media-types'),\n maxFilesize: typeof settings.filesize !== 'undefined' ? settings.filesize : 256,\n maxFiles: settings.limit || null,\n resizeWidth: settings.resizeWidth || null,\n resizeHeight: settings.resizeHeight || null,\n resizeQuality: settings.resizeQuality || null,\n resolution: settings.resolution || null,\n accept: function accept(file, done) {\n ACCEPT_FUNC(file, done, settings);\n }\n };\n cache = cache.add(container);\n container = container[0];\n instances.push(new FilesField({\n container: container,\n options: options\n }));\n};\n\nvar Instance = function () {\n jquery__WEBPACK_IMPORTED_MODULE_0___default()('.dropzone.files-upload').each(function (i, container) {\n return addNode(container);\n });\n jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').on('mutation._grav', onAddedNodes);\n return instances;\n}();//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://Grav/./app/forms/fields/files.js?6179"],"names":["Dictionary","dictCancelUpload","translations","dictCancelUploadConfirmation","dictDefaultMessage","dictFallbackMessage","dictFallbackText","dictFileTooBig","dictInvalidFileType","dictMaxFilesExceeded","dictRemoveFile","dictResponseError","DROPZONE_RESPONSE_ERROR","Dropzone","question","accepted","rejected","doc","$","document","modalSelector","removeEvents","off","accept","reject","find","removeClass","data","open","on","DropzoneMediaConfig","timeout","thumbnailWidth","thumbnailHeight","addRemoveLinks","replace","dictRemoveFileConfirmation","previewTemplate","trim","ACCEPT_FUNC","file","done","settings","resolution","reader","FileReader","error","hasMin","min","width","height","hasMax","max","resizeWidth","resizeHeight","onload","event","image","Image","src","target","result","onerror","Object","keys","forEach","attr","URL","revokeObjectURL","readAsDataURL","FilesField","container","options","length","urls","customPost","assign","klass","url","config","acceptedFiles","init","initDropzone","dropzone","onDropzoneComplete","bind","onDropzoneSuccess","onDropzoneRemovedFile","onDropzoneSending","onDropzoneError","e","value","JSON","parse","val","currentTarget","parent","filename","encodeURI","text","filter","key","name","shift","files","each","index","mock","size","type","status","removeUrl","remove","push","addedfile","call","match","thumbnail","path","createThumbnailFromUrl","xhr","formData","append","dotNotation","getURI","response","reloadPage","global","location","reload","session","sessionParams","input","handleError","mode","msg","message","join","str","decodeURIComponent","escape","window","atob","body","uri","task","request","method","b64_to_utf8","stringify","previewElement","html","File","addFile","extras","indexOf","removeFile","silent","modal","UriToMarkdown","title","split","slice","decodeURI","instances","cache","onAddedNodes","addNode","closest","paramName","maxFilesize","filesize","maxFiles","limit","resizeQuality","add","Instance","i"],"mappings":"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","file":"./app/forms/fields/files.js.js","sourcesContent":["import $ from 'jquery';\nimport Dropzone from 'dropzone';\n// import EXIF from 'exif-js';\nimport request from '../../utils/request';\nimport { config, translations } from 'grav-config';\n\n// translations\nconst Dictionary = {\n    dictCancelUpload: translations.PLUGIN_ADMIN.DROPZONE_CANCEL_UPLOAD,\n    dictCancelUploadConfirmation: translations.PLUGIN_ADMIN.DROPZONE_CANCEL_UPLOAD_CONFIRMATION,\n    dictDefaultMessage: translations.PLUGIN_ADMIN.DROPZONE_DEFAULT_MESSAGE,\n    dictFallbackMessage: translations.PLUGIN_ADMIN.DROPZONE_FALLBACK_MESSAGE,\n    dictFallbackText: translations.PLUGIN_ADMIN.DROPZONE_FALLBACK_TEXT,\n    dictFileTooBig: translations.PLUGIN_ADMIN.DROPZONE_FILE_TOO_BIG,\n    dictInvalidFileType: translations.PLUGIN_ADMIN.DROPZONE_INVALID_FILE_TYPE,\n    dictMaxFilesExceeded: translations.PLUGIN_ADMIN.DROPZONE_MAX_FILES_EXCEEDED,\n    dictRemoveFile: translations.PLUGIN_ADMIN.DROPZONE_REMOVE_FILE,\n    dictResponseError: translations.PLUGIN_ADMIN.DROPZONE_RESPONSE_ERROR\n};\n\nDropzone.autoDiscover = false;\nDropzone.options.gravPageDropzone = {};\nDropzone.confirm = (question, accepted, rejected) => {\n    let doc = $(document);\n    let modalSelector = '[data-remodal-id=\"delete-media\"]';\n\n    let removeEvents = () => {\n        doc.off('confirmation', modalSelector, accept);\n        doc.off('cancellation', modalSelector, reject);\n\n        $(modalSelector).find('.remodal-confirm').removeClass('pointer-events-disabled');\n    };\n\n    let accept = () => {\n        accepted && accepted();\n        removeEvents();\n    };\n\n    let reject = () => {\n        rejected && rejected();\n        removeEvents();\n    };\n\n    $.remodal.lookup[$(modalSelector).data('remodal')].open();\n    doc.on('confirmation', modalSelector, accept);\n    doc.on('cancellation', modalSelector, reject);\n};\n\nconst DropzoneMediaConfig = {\n    timeout: 0,\n    thumbnailWidth: 200,\n    thumbnailHeight: 150,\n    addRemoveLinks: false,\n    dictDefaultMessage: translations.PLUGIN_ADMIN.DROP_FILES_HERE_TO_UPLOAD.replace(/&lt;/g, '<').replace(/&gt;/g, '>'),\n    dictRemoveFileConfirmation: '[placeholder]',\n    previewTemplate: `\n        <div class=\"dz-preview dz-file-preview dz-no-editor\">\n          <div class=\"dz-details\">\n            <div class=\"dz-filename\"><span data-dz-name></span></div>\n            <div class=\"dz-size\" data-dz-size></div>\n            <img data-dz-thumbnail />\n          </div>\n          <div class=\"dz-progress\"><span class=\"dz-upload\" data-dz-uploadprogress></span></div>\n          <div class=\"dz-success-mark\"><span>✔</span></div>\n          <div class=\"dz-error-mark\"><span>✘</span></div>\n          <div class=\"dz-error-message\"><span data-dz-errormessage></span></div>\n          <a class=\"dz-unset\" title=\"${translations.PLUGIN_ADMIN.UNSET}\" href=\"#\" data-dz-unset>${translations.PLUGIN_ADMIN.UNSET}</a>\n          <a class=\"dz-remove\" title=\"${translations.PLUGIN_ADMIN.DELETE}\" href=\"javascript:undefined;\" data-dz-remove>${translations.PLUGIN_ADMIN.DELETE}</a>\n          <a class=\"dz-metadata\" title=\"${translations.PLUGIN_ADMIN.METADATA}\" href=\"#\" target=\"_blank\" data-dz-metadata>${translations.PLUGIN_ADMIN.METADATA}</a>\n          <a class=\"dz-view\" title=\"${translations.PLUGIN_ADMIN.VIEW}\" href=\"#\" target=\"_blank\" data-dz-view>${translations.PLUGIN_ADMIN.VIEW}</a>\n        </div>`.trim()\n};\n\n// global.EXIF = EXIF;\n\nconst ACCEPT_FUNC = function(file, done, settings) {\n    const resolution = settings.resolution;\n    if (!resolution) return done();\n\n    const reader = new FileReader();\n    let error = '';\n    const hasMin = (resolution.min && (resolution.min.width || resolution.min.height));\n    const hasMax = (resolution.max && (resolution.max.width || resolution.max.height));\n    if (hasMin || (!(settings.resizeWidth || settings.resizeHeight) && hasMax)) {\n        reader.onload = function(event) {\n            const image = new Image();\n            image.src = event.target.result;\n            image.onerror = function() {\n                done(translations.PLUGIN_ADMIN.FILE_ERROR_UPLOAD);\n            };\n            image.onload = function() {\n                if (resolution.min) {\n                    Object.keys(resolution.min).forEach((attr) => {\n                        if (resolution.min[attr] && this[attr] < resolution.min[attr]) {\n                            error += translations.PLUGIN_FORM.RESOLUTION_MIN.replace(/{{attr}}/g, attr).replace(/{{min}}/g, resolution.min[attr]);\n                        }\n                    });\n                }\n\n                if (!(settings.resizeWidth || settings.resizeHeight)) {\n                    if (resolution.max) {\n                        Object.keys(resolution.max).forEach((attr) => {\n                            if (resolution.max[attr] && this[attr] > resolution.max[attr]) {\n                                error += translations.PLUGIN_FORM.RESOLUTION_MAX.replace(/{{attr}}/g, attr).replace(/{{max}}/g, resolution.max[attr]);\n                            }\n                        });\n                    }\n                }\n\n                URL.revokeObjectURL(image.src); // release memory\n                return error ? done(error) : done();\n            };\n        };\n\n        reader.readAsDataURL(file);\n    } else {\n        return error ? done(error) : done();\n    }\n};\n\nexport default class FilesField {\n    constructor({ container = '.dropzone.files-upload', options = {} } = {}) {\n        this.container = $(container);\n        if (!this.container.length) { return; }\n\n        this.urls = {};\n        this.customPost = this.container.data('filePostAdd') || {};\n        this.options = Object.assign({}, Dictionary, DropzoneMediaConfig, {\n            klass: this,\n            url: this.container.data('file-url-add') || config.current_url,\n            acceptedFiles: this.container.data('media-types'),\n            init: this.initDropzone\n        }, this.container.data('dropzone-options'), options);\n\n        this.options = Object.assign({}, this.options, {\n            accept: function(file, done) { ACCEPT_FUNC(file, done, this.options); }\n        });\n\n        this.dropzone = new Dropzone(container, this.options);\n        this.dropzone.on('complete', this.onDropzoneComplete.bind(this));\n        this.dropzone.on('success', this.onDropzoneSuccess.bind(this));\n        this.dropzone.on('removedfile', this.onDropzoneRemovedFile.bind(this));\n        this.dropzone.on('sending', this.onDropzoneSending.bind(this));\n        this.dropzone.on('error', this.onDropzoneError.bind(this));\n\n        this.container.on('mouseenter', '[data-dz-view]', (e) => {\n            const value = JSON.parse(this.container.find('[name][type=\"hidden\"]').val() || '{}');\n            const target = $(e.currentTarget);\n            const file = target.parent('.dz-preview').find('.dz-filename');\n            const filename = encodeURI(file.text());\n\n            const URL = Object.keys(value).filter((key) => value[key].name === filename).shift();\n            target.attr('href', `${config.base_url_simple}/${URL}`);\n        });\n\n    }\n\n    initDropzone() {\n        let files = this.options.klass.container.find('[data-file]');\n        let dropzone = this;\n        if (!files.length) { return; }\n\n        files.each((index, file) => {\n            file = $(file);\n            let data = file.data('file');\n            let mock = {\n                name: data.name,\n                size: data.size,\n                type: data.type,\n                status: Dropzone.ADDED,\n                accepted: true,\n                url: this.options.url,\n                removeUrl: data.remove\n            };\n\n            dropzone.files.push(mock);\n            dropzone.options.addedfile.call(dropzone, mock);\n            if (mock.type.match(/^image\\//)) {\n                dropzone.options.thumbnail.call(dropzone, mock, data.path);\n                dropzone.createThumbnailFromUrl(mock, data.path);\n            }\n\n            file.remove();\n        });\n\n    }\n\n    getURI() {\n        return this.container.data('mediaUri') || '';\n    }\n\n    onDropzoneSending(file, xhr, formData) {\n        if (Object.keys(this.customPost).length) {\n            Object.keys(this.customPost).forEach((key) => {\n                formData.append(key, this.customPost[key]);\n            });\n        } else {\n            formData.append('name', this.options.dotNotation);\n            formData.append('task', 'filesupload');\n            formData.append('uri', this.getURI());\n        }\n\n        formData.append('admin-nonce', config.admin_nonce);\n    }\n\n    onDropzoneSuccess(file, response, xhr) {\n        response = typeof response === 'string' ? JSON.parse(response) : response;\n        if (this.options.reloadPage) {\n            global.location.reload();\n        }\n\n        // store params for removing file from session before it gets saved\n        if (response.session) {\n            file.sessionParams = response.session;\n            file.removeUrl = this.options.url;\n\n            // Touch field value to force a mutation detection\n            const input = this.container.find('[name][type=\"hidden\"]');\n            const value = input.val();\n            input.val(value + ' ');\n        }\n\n        return this.handleError({\n            file,\n            data: response,\n            mode: 'removeFile',\n            msg: `<p>${translations.PLUGIN_ADMIN.FILE_ERROR_UPLOAD} <strong>${file.name}</strong></p>\n            <pre>${response.message}</pre>`\n        });\n    }\n\n    onDropzoneComplete(file) {\n        if (!file.accepted && !file.rejected) {\n            let data = {\n                status: 'error',\n                message: `${translations.PLUGIN_ADMIN.FILE_UNSUPPORTED}: ${file.name.match(/\\..+/).join('')}`\n            };\n\n            return this.handleError({\n                file,\n                data,\n                mode: 'removeFile',\n                msg: `<p>${translations.PLUGIN_ADMIN.FILE_ERROR_ADD} <strong>${file.name}</strong></p>\n                <pre>${data.message}</pre>`\n            });\n        }\n\n        if (this.options.reloadPage) {\n            global.location.reload();\n        }\n    }\n\n    b64_to_utf8(str) {\n        str = str.replace(/\\s/g, '');\n        return decodeURIComponent(escape(window.atob(str)));\n    }\n\n    onDropzoneRemovedFile(file, ...extra) {\n        if (!file.accepted || file.rejected) { return; }\n        let url = file.removeUrl || this.urls.delete || this.options.url;\n        let path = (url || '').match(/path:(.*)\\//);\n        let body = { filename: file.name, uri: this.getURI() };\n\n        if (file.sessionParams) {\n            body.task = 'filessessionremove';\n            body.session = file.sessionParams;\n        }\n\n        const customPost = this.container.data('filePostRemove') || {};\n        if (Object.keys(customPost).length) {\n            body = {};\n            Object.keys(customPost).forEach((key) => {\n                body[key] = customPost[key];\n            });\n        }\n\n        body['filename'] = file.name;\n        body['admin-nonce'] = config.admin_nonce;\n\n        request(url, { method: 'post', body }, () => {\n            if (!path) { return; }\n\n            path = this.b64_to_utf8(path[1]);\n            let input = this.container.find('[name][type=\"hidden\"]');\n            let data = JSON.parse(input.val() || '{}');\n            delete data[path];\n            input.val(JSON.stringify(data));\n        });\n    }\n\n    onDropzoneError(file, response, xhr) {\n        let message = xhr ? response.error.message : response;\n        $(file.previewElement).find('[data-dz-errormessage]').html(message);\n\n        return this.handleError({\n            file,\n            data: { status: 'error' },\n            msg: `<pre>${message}</pre>`\n        });\n    }\n\n    handleError(options) {\n        let { file, data, mode, msg } = options;\n        if (data.status !== 'error' && data.status !== 'unauthorized') { return; }\n\n        switch (mode) {\n            case 'addBack':\n                if (file instanceof File) {\n                    this.dropzone.addFile.call(this.dropzone, file);\n                } else {\n                    this.dropzone.files.push(file);\n                    this.dropzone.options.addedfile.call(this.dropzone, file);\n                    this.dropzone.options.thumbnail.call(this.dropzone, file, file.extras.url);\n                }\n\n                break;\n            case 'removeFile':\n            default:\n                if (~this.dropzone.files.indexOf(file)) {\n                    file.rejected = true;\n                    this.dropzone.removeFile.call(this.dropzone, file, { silent: true });\n                }\n\n                break;\n        }\n\n        let modal = $('[data-remodal-id=\"generic\"]');\n        modal.find('.error-content').html(msg);\n        $.remodal.lookup[modal.data('remodal')].open();\n    }\n}\n\nexport function UriToMarkdown(uri) {\n    uri = uri.replace(/@3x|@2x|@1x/, '');\n    uri = uri.replace(/\\(/g, '%28');\n    uri = uri.replace(/\\)/g, '%29');\n\n    const title = uri.split('.').slice(0, -1).join('.');\n\n    return uri.match(/\\.(jpe?g|png|gif|svg|mp4|webm|ogv|mov)$/i) ? `![${title}](${uri} \"${title}\")` : `[${decodeURI(uri)}](${uri})`;\n}\n\nlet instances = [];\nlet cache = $();\nconst onAddedNodes = (event, target/* , record, instance */) => {\n    let files = $(target).find('.dropzone.files-upload');\n    if (!files.length) { return; }\n\n    files.each((index, file) => {\n        file = $(file);\n        if (!~cache.index(file)) {\n            addNode(file);\n        }\n    });\n};\n\nconst addNode = (container) => {\n    container = $(container);\n    let input = container.find('input[type=\"file\"]');\n    let settings = container.data('grav-file-settings') || {};\n\n    if (settings.accept && ~settings.accept.indexOf('*')) {\n        settings.accept = [''];\n    }\n\n    let options = {\n        url: container.data('file-url-add') || (container.closest('form').attr('action') || config.current_url) + '.json',\n        paramName: settings.paramName || 'file',\n        dotNotation: settings.name || 'file',\n        acceptedFiles: settings.accept ? settings.accept.join(',') : input.attr('accept') || container.data('media-types'),\n        maxFilesize: typeof settings.filesize !== 'undefined' ? settings.filesize : 256,\n        maxFiles: settings.limit || null,\n        resizeWidth: settings.resizeWidth || null,\n        resizeHeight: settings.resizeHeight || null,\n        resizeQuality: settings.resizeQuality || null,\n        resolution: settings.resolution || null,\n        accept: function(file, done) { ACCEPT_FUNC(file, done, settings); }\n    };\n\n    cache = cache.add(container);\n    container = container[0];\n    instances.push(new FilesField({ container, options }));\n};\n\nexport let Instance = (() => {\n    $('.dropzone.files-upload').each((i, container) => addNode(container));\n    $('body').on('mutation._grav', onAddedNodes);\n\n    return instances;\n})();\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./app/forms/fields/files.js\n"); + +/***/ }), + +/***/ "./app/forms/fields/iconpicker.js": +/*!****************************************!*\ + !*** ./app/forms/fields/iconpicker.js ***! + \****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ IconpickerField),\n/* harmony export */ \"Instance\": () => (/* binding */ Instance)\n/* harmony export */ });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\n\n/* Icon Picker by QueryLoop\n * Author: @eliorivero\n * URL: http://queryloop.com/\n * License: GPLv2\n */\n\nvar defaults = {\n 'mode': 'dialog',\n // show overlay 'dialog' panel or slide down 'inline' panel\n 'closeOnPick': true,\n // whether to close panel after picking or 'no'\n 'save': 'class',\n // save icon 'class' or 'code'\n 'size': '',\n 'classes': {\n 'launcher': '',\n // extra classes for launcher buttons\n 'clear': 'remove-times',\n // extra classes for button that removes preview and clears field\n 'highlight': '',\n // extra classes when highlighting an icon\n 'close': '' // extra classes for close button\n\n },\n 'iconSets': {\n // example data structure. Used to specify which launchers will be created\n 'genericon': 'Genericon',\n // create a launcher to pick genericon icons\n 'fa': 'FontAwesome' // create a launcher to pick fontawesome icons\n\n }\n};\n\nvar QL_Icon_Picker = /*#__PURE__*/function () {\n function QL_Icon_Picker(element, options) {\n _classCallCheck(this, QL_Icon_Picker);\n\n this.iconSet = '';\n this.iconSetName = '';\n this.$field = '';\n this.element = element;\n this.settings = jquery__WEBPACK_IMPORTED_MODULE_0___default().extend({}, defaults, options);\n this._defaults = defaults;\n this.init();\n }\n\n _createClass(QL_Icon_Picker, [{\n key: \"init\",\n value: function init() {\n var $brick = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.element);\n var pickerId = $brick.data('pickerid');\n var $preview = jquery__WEBPACK_IMPORTED_MODULE_0___default()('');\n this.$field = $brick.find('input'); // Add preview area\n\n this.makePreview($brick, pickerId, $preview); // Make button to clear field and remove preview\n\n this.makeClear(pickerId, $preview); // Make buttons that open the panel of icons\n\n this.makeLaunchers($brick, pickerId); // Prepare display styles, inline and dialog\n\n this.makeDisplay($brick);\n }\n }, {\n key: \"makePreview\",\n value: function makePreview($brick, pickerId, $preview) {\n var $icon = jquery__WEBPACK_IMPORTED_MODULE_0___default()('');\n var iconValue = this.$field.val();\n $preview.prependTo($brick);\n $icon.prependTo($preview);\n\n if (iconValue !== '') {\n $preview.addClass('icon-preview-on');\n $icon.addClass(iconValue);\n }\n }\n }, {\n key: \"makeClear\",\n value: function makeClear(pickerId, $preview) {\n var base = this;\n var $clear = jquery__WEBPACK_IMPORTED_MODULE_0___default()(''); // Hide button to remove icon and preview and append it to preview area\n\n $clear.hide().prependTo($preview); // If there's a icon saved in the field, show remove icon button\n\n if (base.$field.val() !== '') {\n $clear.show();\n }\n\n $preview.on('click', '.remove-icon', function (e) {\n e.preventDefault();\n base.$field.val('');\n $preview.removeClass('icon-preview-on').find('i').removeClass();\n jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).hide();\n });\n }\n }, {\n key: \"makeDisplay\",\n value: function makeDisplay($brick) {\n var base = this;\n var close = base.settings.classes.close;\n var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()('body');\n var $close = jquery__WEBPACK_IMPORTED_MODULE_0___default()('');\n\n if (base.settings.mode === 'inline') {\n $brick.find('.icon-set').append($close).removeClass('dialog').addClass('ip-inline ' + base.settings.size).parent().addClass('icon-set-wrap');\n } else if (base.settings.mode === 'dialog') {\n jquery__WEBPACK_IMPORTED_MODULE_0___default()('.icon-set').addClass('dialog ' + base.settings.size);\n\n if (jquery__WEBPACK_IMPORTED_MODULE_0___default()('.icon-picker-overlay').length <= 0) {\n $body.append('