15269 lines
515 KiB
JavaScript
15269 lines
515 KiB
JavaScript
![]() |
var Grav;
|
|||
|
/******/ (() => { // webpackBootstrap
|
|||
|
/******/ var __webpack_modules__ = ({
|
|||
|
|
|||
|
/***/ 56299:
|
|||
|
/***/ ((__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__(65311);
|
|||
|
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 = $('<div>').addClass(namespacify('overlay') + ' ' + namespacify('is', STATES.CLOSED)).hide();
|
|||
|
$appendTo.append(remodal.$overlay);
|
|||
|
}
|
|||
|
|
|||
|
remodal.$bg = $('.' + namespacify('bg')).addClass(namespacify('is', STATES.CLOSED));
|
|||
|
remodal.$modal = $modal.addClass(NAMESPACE + ' ' + namespacify('is-initialized') + ' ' + remodal.settings.modifier + ' ' + namespacify('is', STATES.CLOSED)).attr('tabindex', '-1');
|
|||
|
remodal.$wrapper = $('<div>').addClass(namespacify('wrapper') + ' ' + remodal.settings.modifier + ' ' + namespacify('is', STATES.CLOSED)).hide().append(remodal.$modal);
|
|||
|
$appendTo.append(remodal.$wrapper); // Add the event listener for the close button
|
|||
|
|
|||
|
remodal.$wrapper.on('click.' + NAMESPACE, '[data-' + PLUGIN_NAME + '-action="close"]', function (e) {
|
|||
|
e.preventDefault();
|
|||
|
remodal.close();
|
|||
|
}); // Add the event listener for the cancel button
|
|||
|
|
|||
|
remodal.$wrapper.on('click.' + NAMESPACE, '[data-' + PLUGIN_NAME + '-action="cancel"]', function (e) {
|
|||
|
e.preventDefault();
|
|||
|
remodal.$modal.trigger(STATE_CHANGE_REASONS.CANCELLATION);
|
|||
|
|
|||
|
if (remodal.settings.closeOnCancel) {
|
|||
|
remodal.close(STATE_CHANGE_REASONS.CANCELLATION);
|
|||
|
}
|
|||
|
}); // Add the event listener for the confirm button
|
|||
|
|
|||
|
remodal.$wrapper.on('click.' + NAMESPACE, '[data-' + PLUGIN_NAME + '-action="confirm"]', function (e) {
|
|||
|
e.preventDefault();
|
|||
|
remodal.$modal.trigger(STATE_CHANGE_REASONS.CONFIRMATION);
|
|||
|
|
|||
|
if (remodal.settings.closeOnConfirm) {
|
|||
|
remodal.close(STATE_CHANGE_REASONS.CONFIRMATION);
|
|||
|
}
|
|||
|
}); // Add the event listener for the overlay
|
|||
|
|
|||
|
remodal.$wrapper.on('click.' + NAMESPACE, function (e) {
|
|||
|
var $target = $(e.target);
|
|||
|
var isWrapper = $target.hasClass(namespacify('wrapper'));
|
|||
|
var isWithin = $target.closest('.' + namespacify('is', STATES.OPENED)).length;
|
|||
|
|
|||
|
if (!isWrapper && isWithin) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
if (remodal.settings.closeOnOutsideClick) {
|
|||
|
remodal.close();
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
/**
|
|||
|
* Opens a modal window
|
|||
|
* @public
|
|||
|
*/
|
|||
|
|
|||
|
|
|||
|
Remodal.prototype.open = function () {
|
|||
|
var remodal = this;
|
|||
|
var current;
|
|||
|
var modalCount; // Check if the animation was completed
|
|||
|
|
|||
|
if (remodal.state === STATES.OPENING || remodal.state === STATES.CLOSING) {
|
|||
|
return;
|
|||
|
} // id = remodal.$modal.attr('data-' + PLUGIN_NAME + '-id');
|
|||
|
|
|||
|
|
|||
|
if (remodal.id && remodal.settings.hashTracking) {
|
|||
|
scrollTop = $(window).scrollTop();
|
|||
|
location.hash = remodal.id;
|
|||
|
}
|
|||
|
|
|||
|
if (!remodal.settings.stack) {
|
|||
|
current = currentModal();
|
|||
|
|
|||
|
if (current && current !== remodal) {
|
|||
|
halt(current);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
modalCount = openModals.push(remodal);
|
|||
|
remodal.$overlay.css('z-index', function (_, value) {
|
|||
|
return parseInt(value, 10) + modalCount;
|
|||
|
});
|
|||
|
remodal.$wrapper.css('z-index', function (_, value) {
|
|||
|
return parseInt(value, 10) + modalCount;
|
|||
|
});
|
|||
|
lockScreen();
|
|||
|
remodal.$bg.addClass(remodal.settings.modifier);
|
|||
|
remodal.$overlay.addClass(remodal.settings.modifier).show();
|
|||
|
remodal.$wrapper.show().scrollTop(0);
|
|||
|
remodal.$modal.focus();
|
|||
|
syncWithAnimation(function () {
|
|||
|
setState(remodal, STATES.OPENING);
|
|||
|
}, function () {
|
|||
|
setState(remodal, STATES.OPENED);
|
|||
|
}, remodal);
|
|||
|
};
|
|||
|
/**
|
|||
|
* Closes a modal window
|
|||
|
* @public
|
|||
|
* @param {String} reason
|
|||
|
*/
|
|||
|
|
|||
|
|
|||
|
Remodal.prototype.close = function (reason) {
|
|||
|
var remodal = this;
|
|||
|
var current; // Check if the animation was completed
|
|||
|
|
|||
|
if (remodal.state === STATES.OPENING || remodal.state === STATES.CLOSING || remodal.state === STATES.CLOSED) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
removeModal(remodal);
|
|||
|
|
|||
|
if (remodal.settings.hashTracking && remodal.id === location.hash.substr(1)) {
|
|||
|
current = currentModal();
|
|||
|
|
|||
|
if (current) {
|
|||
|
location.hash = current.id;
|
|||
|
} else {
|
|||
|
location.hash = '';
|
|||
|
$(window).scrollTop(scrollTop);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
syncWithAnimation(function () {
|
|||
|
setState(remodal, STATES.CLOSING, false, reason);
|
|||
|
}, function () {
|
|||
|
remodal.$bg.removeClass(remodal.settings.modifier);
|
|||
|
remodal.$overlay.removeClass(remodal.settings.modifier).hide();
|
|||
|
remodal.$wrapper.hide();
|
|||
|
|
|||
|
if (openModals.length === 0) {
|
|||
|
unlockScreen();
|
|||
|
}
|
|||
|
|
|||
|
setState(remodal, STATES.CLOSED, false, reason);
|
|||
|
}, remodal);
|
|||
|
};
|
|||
|
/**
|
|||
|
* Returns a current state of a modal
|
|||
|
* @public
|
|||
|
* @returns {STATES}
|
|||
|
*/
|
|||
|
|
|||
|
|
|||
|
Remodal.prototype.getState = function () {
|
|||
|
return this.state;
|
|||
|
};
|
|||
|
/**
|
|||
|
* Destroys a modal
|
|||
|
* @public
|
|||
|
*/
|
|||
|
|
|||
|
|
|||
|
Remodal.prototype.destroy = function () {
|
|||
|
var lookup = $[PLUGIN_NAME].lookup;
|
|||
|
var instanceCount;
|
|||
|
halt(this);
|
|||
|
this.$wrapper.remove();
|
|||
|
delete lookup[this.index];
|
|||
|
instanceCount = $.grep(lookup, function (instance) {
|
|||
|
return !!instance;
|
|||
|
}).length;
|
|||
|
|
|||
|
if (instanceCount === 0) {
|
|||
|
this.$overlay.remove();
|
|||
|
this.$bg.removeClass(namespacify('is', STATES.CLOSING) + ' ' + namespacify('is', STATES.OPENING) + ' ' + namespacify('is', STATES.CLOSED) + ' ' + namespacify('is', STATES.OPENED));
|
|||
|
}
|
|||
|
};
|
|||
|
/**
|
|||
|
* Special plugin object for instances
|
|||
|
* @public
|
|||
|
* @type {Object}
|
|||
|
*/
|
|||
|
|
|||
|
|
|||
|
$[PLUGIN_NAME] = {
|
|||
|
lookup: []
|
|||
|
};
|
|||
|
/**
|
|||
|
* Plugin constructor
|
|||
|
* @constructor
|
|||
|
* @param {Object} options
|
|||
|
* @returns {JQuery}
|
|||
|
*/
|
|||
|
|
|||
|
$.fn[PLUGIN_NAME] = function (opts) {
|
|||
|
var instance;
|
|||
|
var $elem;
|
|||
|
this.each(function (index, elem) {
|
|||
|
$elem = $(elem);
|
|||
|
|
|||
|
if ($elem.data(PLUGIN_NAME) == null) {
|
|||
|
instance = new Remodal($elem, opts);
|
|||
|
$elem.data(PLUGIN_NAME, instance.index);
|
|||
|
|
|||
|
if (instance.settings.hashTracking && instance.id === location.hash.substr(1)) {
|
|||
|
instance.open();
|
|||
|
}
|
|||
|
} else {
|
|||
|
instance = $[PLUGIN_NAME].lookup[$elem.data(PLUGIN_NAME)];
|
|||
|
}
|
|||
|
});
|
|||
|
return instance;
|
|||
|
};
|
|||
|
|
|||
|
$(document).ready(function () {
|
|||
|
// data-remodal-target opens a modal window with the special Id
|
|||
|
$(document).on('click', '[data-' + PLUGIN_NAME + '-target]', function (e) {
|
|||
|
e.preventDefault();
|
|||
|
var elem = e.currentTarget;
|
|||
|
var id = elem.getAttribute('data-' + PLUGIN_NAME + '-target');
|
|||
|
var $target = $('[data-' + PLUGIN_NAME + '-id="' + id + '"]');
|
|||
|
$[PLUGIN_NAME].lookup[$target.data(PLUGIN_NAME)].open();
|
|||
|
}); // Auto initialization of modal windows
|
|||
|
// They should have the 'remodal' class attribute
|
|||
|
// Also you can write the `data-remodal-options` attribute to pass params into the modal
|
|||
|
|
|||
|
$(document).find('.' + NAMESPACE).each(function (i, container) {
|
|||
|
var $container = $(container);
|
|||
|
var options = $container.data(PLUGIN_NAME + '-options');
|
|||
|
|
|||
|
if (!options) {
|
|||
|
options = {};
|
|||
|
} else if (typeof options === 'string' || options instanceof String) {
|
|||
|
options = parseOptions(options);
|
|||
|
}
|
|||
|
|
|||
|
$container[PLUGIN_NAME](options);
|
|||
|
}); // Handles the keydown event
|
|||
|
|
|||
|
$(document).on('keydown.' + NAMESPACE, function (e) {
|
|||
|
var current = currentModal();
|
|||
|
|
|||
|
if (current && current.settings.closeOnEscape && current.state === STATES.OPENED && e.keyCode === 27) {
|
|||
|
current.close();
|
|||
|
}
|
|||
|
}); // Handles the hashchange event
|
|||
|
|
|||
|
$(window).on('hashchange.' + NAMESPACE, handleHashChangeEvent);
|
|||
|
});
|
|||
|
});
|
|||
|
// EXTERNAL MODULE: ./node_modules/simplebar/dist/simplebar.min.js
|
|||
|
var simplebar_min = __webpack_require__(85766);
|
|||
|
// EXTERNAL MODULE: ./node_modules/toastr/toastr.js
|
|||
|
var toastr = __webpack_require__(8901);
|
|||
|
var toastr_default = /*#__PURE__*/__webpack_require__.n(toastr);
|
|||
|
;// CONCATENATED MODULE: ./app/utils/toastr.js
|
|||
|
|
|||
|
(toastr_default()).options.positionClass = 'toast-top-right';
|
|||
|
(toastr_default()).options.preventDuplicates = true;
|
|||
|
/* harmony default export */ const utils_toastr = ((toastr_default()));
|
|||
|
;// CONCATENATED MODULE: ./app/utils/offline.js
|
|||
|
|
|||
|
|
|||
|
var offlineElement = external_jQuery_default()('#offline-status');
|
|||
|
external_jQuery_default()(window).on('offline', function () {
|
|||
|
offlineElement.slideDown();
|
|||
|
});
|
|||
|
external_jQuery_default()(window).on('online', function () {
|
|||
|
offlineElement.slideUp();
|
|||
|
});
|
|||
|
external_jQuery_default()(document).ready(function () {
|
|||
|
if (!offline) {
|
|||
|
offlineElement.slideDown();
|
|||
|
}
|
|||
|
}); // assume online if can't check
|
|||
|
|
|||
|
/* harmony default export */ const offline = (typeof __webpack_require__.g.navigator.onLine !== 'undefined' ? __webpack_require__.g.navigator.onLine : true);
|
|||
|
;// CONCATENATED MODULE: external "GravAdmin"
|
|||
|
const external_GravAdmin_namespaceObject = GravAdmin;
|
|||
|
// EXTERNAL MODULE: ./node_modules/mout/string/trim.js
|
|||
|
var trim = __webpack_require__(78579);
|
|||
|
var trim_default = /*#__PURE__*/__webpack_require__.n(trim);
|
|||
|
;// CONCATENATED MODULE: ./app/utils/response.js
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var UNLOADING = false;
|
|||
|
|
|||
|
var error = function error(response) {
|
|||
|
var error = new Error(response.statusText || response || '');
|
|||
|
error.response = response;
|
|||
|
return error;
|
|||
|
};
|
|||
|
|
|||
|
function parseStatus(response) {
|
|||
|
return response;
|
|||
|
/* Whoops can handle JSON responses so we don't need this for now.
|
|||
|
if (response.status >= 200 && response.status < 300) {
|
|||
|
return response;
|
|||
|
} else {
|
|||
|
throw error(response);
|
|||
|
}
|
|||
|
*/
|
|||
|
}
|
|||
|
function parseJSON(response) {
|
|||
|
return response.text().then(function (text) {
|
|||
|
var parsed = text;
|
|||
|
|
|||
|
try {
|
|||
|
parsed = JSON.parse(text);
|
|||
|
} catch (error) {
|
|||
|
var content = document.createElement('div');
|
|||
|
content.innerHTML = text;
|
|||
|
var the_error = new Error();
|
|||
|
the_error.stack = trim_default()(content.innerText);
|
|||
|
throw the_error;
|
|||
|
}
|
|||
|
|
|||
|
return parsed;
|
|||
|
});
|
|||
|
}
|
|||
|
function userFeedback(response) {
|
|||
|
if (UNLOADING) {
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
var status = response.status || (response.error ? 'error' : '');
|
|||
|
var message = response.message || (response.error ? response.error.message : null);
|
|||
|
var settings = response.toastr || null;
|
|||
|
var backup;
|
|||
|
|
|||
|
switch (status) {
|
|||
|
case 'unauthenticated':
|
|||
|
document.location.href = external_GravAdmin_namespaceObject.config.base_url_relative;
|
|||
|
throw error('Logged out');
|
|||
|
|
|||
|
case 'unauthorized':
|
|||
|
status = 'error';
|
|||
|
message = message || 'Unauthorized.';
|
|||
|
break;
|
|||
|
|
|||
|
case 'error':
|
|||
|
status = 'error';
|
|||
|
message = message || 'Unknown error.';
|
|||
|
break;
|
|||
|
|
|||
|
case 'success':
|
|||
|
status = 'success';
|
|||
|
message = message || '';
|
|||
|
break;
|
|||
|
|
|||
|
default:
|
|||
|
status = 'error';
|
|||
|
message = message || 'Invalid AJAX response.';
|
|||
|
break;
|
|||
|
}
|
|||
|
|
|||
|
if (settings) {
|
|||
|
backup = Object.assign({}, utils_toastr.options);
|
|||
|
Object.keys(settings).forEach(function (key) {
|
|||
|
utils_toastr.options[key] = settings[key];
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
if (message && (offline || !offline && status !== 'error')) {
|
|||
|
utils_toastr[status === 'success' ? 'success' : 'error'](message);
|
|||
|
}
|
|||
|
|
|||
|
if (settings) {
|
|||
|
utils_toastr.options = backup;
|
|||
|
}
|
|||
|
|
|||
|
return response;
|
|||
|
}
|
|||
|
function userFeedbackError(error) {
|
|||
|
if (UNLOADING) {
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
var stack = error.stack ? "<pre><code>".concat(error.stack, "</code></pre>") : '';
|
|||
|
utils_toastr.error("Fetch Failed: <br /> ".concat(error.message, " ").concat(stack));
|
|||
|
console.error("".concat(error.message, " at ").concat(error.stack));
|
|||
|
}
|
|||
|
external_jQuery_default()(__webpack_require__.g).on('beforeunload._ajax', function () {
|
|||
|
UNLOADING = true;
|
|||
|
});
|
|||
|
// EXTERNAL MODULE: ./node_modules/events/events.js
|
|||
|
var events = __webpack_require__(17187);
|
|||
|
var events_default = /*#__PURE__*/__webpack_require__.n(events);
|
|||
|
;// CONCATENATED MODULE: ./app/utils/gpm.js
|
|||
|
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|||
|
|
|||
|
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function _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 _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
function _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 } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
|||
|
|
|||
|
function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
|||
|
|
|||
|
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|||
|
|
|||
|
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
|||
|
|
|||
|
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
|||
|
|
|||
|
function _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 _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var GPM = /*#__PURE__*/function (_EventEmitter) {
|
|||
|
_inherits(GPM, _EventEmitter);
|
|||
|
|
|||
|
var _super = _createSuper(GPM);
|
|||
|
|
|||
|
function GPM() {
|
|||
|
var _this;
|
|||
|
|
|||
|
var action = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'getUpdates';
|
|||
|
|
|||
|
_classCallCheck(this, GPM);
|
|||
|
|
|||
|
_this = _super.call(this);
|
|||
|
_this.payload = {};
|
|||
|
_this.raw = {};
|
|||
|
_this.action = action;
|
|||
|
return _this;
|
|||
|
}
|
|||
|
|
|||
|
_createClass(GPM, [{
|
|||
|
key: "setPayload",
|
|||
|
value: function setPayload() {
|
|||
|
var payload = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|||
|
this.payload = payload;
|
|||
|
this.emit('payload', payload);
|
|||
|
return this;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "setAction",
|
|||
|
value: function setAction() {
|
|||
|
var action = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'getUpdates';
|
|||
|
this.action = action;
|
|||
|
this.emit('action', action);
|
|||
|
return this;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "fetch",
|
|||
|
value: function (_fetch) {
|
|||
|
function fetch() {
|
|||
|
return _fetch.apply(this, arguments);
|
|||
|
}
|
|||
|
|
|||
|
fetch.toString = function () {
|
|||
|
return _fetch.toString();
|
|||
|
};
|
|||
|
|
|||
|
return fetch;
|
|||
|
}(function () {
|
|||
|
var _this2 = this;
|
|||
|
|
|||
|
var callback = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : function () {
|
|||
|
return true;
|
|||
|
};
|
|||
|
var flush = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
|
|||
|
var data = new FormData();
|
|||
|
data.append('admin-nonce', external_GravAdmin_namespaceObject.config.admin_nonce);
|
|||
|
|
|||
|
if (flush) {
|
|||
|
data.append('flush', true);
|
|||
|
}
|
|||
|
|
|||
|
this.emit('fetching', this);
|
|||
|
fetch("".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/update.json/task").concat(external_GravAdmin_namespaceObject.config.param_sep, "getUpdates"), {
|
|||
|
credentials: 'same-origin',
|
|||
|
method: 'post',
|
|||
|
body: data
|
|||
|
}).then(function (response) {
|
|||
|
_this2.raw = response;
|
|||
|
return response;
|
|||
|
}).then(parseStatus).then(parseJSON).then(function (response) {
|
|||
|
return _this2.response(response);
|
|||
|
}).then(function (response) {
|
|||
|
return callback(response, _this2.raw);
|
|||
|
}).then(function (response) {
|
|||
|
return _this2.emit('fetched', _this2.payload, _this2.raw, _this2);
|
|||
|
})["catch"](userFeedbackError);
|
|||
|
})
|
|||
|
}, {
|
|||
|
key: "response",
|
|||
|
value: function response(_response) {
|
|||
|
this.payload = _response;
|
|||
|
return _response;
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return GPM;
|
|||
|
}((events_default()));
|
|||
|
|
|||
|
|
|||
|
var Instance = new GPM();
|
|||
|
;// CONCATENATED MODULE: ./app/utils/keepalive.js
|
|||
|
function keepalive_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function keepalive_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 keepalive_createClass(Constructor, protoProps, staticProps) { if (protoProps) keepalive_defineProperties(Constructor.prototype, protoProps); if (staticProps) keepalive_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var MAX_SAFE_DELAY = 2147483647;
|
|||
|
|
|||
|
var KeepAlive = /*#__PURE__*/function () {
|
|||
|
function KeepAlive() {
|
|||
|
keepalive_classCallCheck(this, KeepAlive);
|
|||
|
|
|||
|
this.active = false;
|
|||
|
}
|
|||
|
|
|||
|
keepalive_createClass(KeepAlive, [{
|
|||
|
key: "start",
|
|||
|
value: function start() {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
var timeout = external_GravAdmin_namespaceObject.config.admin_timeout / 1.5 * 1000;
|
|||
|
this.timer = setInterval(function () {
|
|||
|
return _this.fetch();
|
|||
|
}, Math.min(timeout, MAX_SAFE_DELAY));
|
|||
|
this.active = true;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "stop",
|
|||
|
value: function stop() {
|
|||
|
clearInterval(this.timer);
|
|||
|
this.active = false;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "fetch",
|
|||
|
value: function (_fetch) {
|
|||
|
function fetch() {
|
|||
|
return _fetch.apply(this, arguments);
|
|||
|
}
|
|||
|
|
|||
|
fetch.toString = function () {
|
|||
|
return _fetch.toString();
|
|||
|
};
|
|||
|
|
|||
|
return fetch;
|
|||
|
}(function () {
|
|||
|
var data = new FormData();
|
|||
|
data.append('admin-nonce', external_GravAdmin_namespaceObject.config.admin_nonce);
|
|||
|
fetch("".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/task").concat(external_GravAdmin_namespaceObject.config.param_sep, "keepAlive"), {
|
|||
|
credentials: 'same-origin',
|
|||
|
method: 'post',
|
|||
|
body: data
|
|||
|
})["catch"](userFeedbackError);
|
|||
|
})
|
|||
|
}]);
|
|||
|
|
|||
|
return KeepAlive;
|
|||
|
}();
|
|||
|
|
|||
|
/* harmony default export */ const keepalive = (new KeepAlive());
|
|||
|
// EXTERNAL MODULE: ./node_modules/mout/array/unique.js
|
|||
|
var unique = __webpack_require__(79863);
|
|||
|
var unique_default = /*#__PURE__*/__webpack_require__.n(unique);
|
|||
|
;// CONCATENATED MODULE: ./app/utils/request.js
|
|||
|
|
|||
|
|
|||
|
var raw;
|
|||
|
|
|||
|
var request = function request(url) {
|
|||
|
var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|||
|
var callback = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : function () {
|
|||
|
return true;
|
|||
|
};
|
|||
|
|
|||
|
if (typeof options === 'function') {
|
|||
|
callback = options;
|
|||
|
options = {};
|
|||
|
}
|
|||
|
|
|||
|
if (options.method && options.method === 'post') {
|
|||
|
var data = new FormData();
|
|||
|
options.body = Object.assign({
|
|||
|
'admin-nonce': external_GravAdmin_namespaceObject.config.admin_nonce
|
|||
|
}, options.body || {});
|
|||
|
Object.keys(options.body).map(function (key) {
|
|||
|
return data.append(key, options.body[key]);
|
|||
|
});
|
|||
|
options.body = data;
|
|||
|
}
|
|||
|
|
|||
|
options = Object.assign({
|
|||
|
credentials: 'same-origin',
|
|||
|
headers: {
|
|||
|
'Accept': 'application/json'
|
|||
|
}
|
|||
|
}, options);
|
|||
|
return fetch(url, options).then(function (response) {
|
|||
|
raw = response;
|
|||
|
return response;
|
|||
|
}).then(parseStatus).then(parseJSON).then(userFeedback).then(function (response) {
|
|||
|
return callback(response, raw);
|
|||
|
})["catch"](userFeedbackError);
|
|||
|
};
|
|||
|
|
|||
|
/* harmony default export */ const utils_request = (request);
|
|||
|
;// CONCATENATED MODULE: ./app/updates/notifications.js
|
|||
|
function notifications_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function notifications_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 notifications_createClass(Constructor, protoProps, staticProps) { if (protoProps) notifications_defineProperties(Constructor.prototype, protoProps); if (staticProps) notifications_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var canFetchNotifications = function canFetchNotifications() {
|
|||
|
return external_GravAdmin_namespaceObject.config.notifications.enabled;
|
|||
|
};
|
|||
|
|
|||
|
var notificationsFilters = function notificationsFilters() {
|
|||
|
return external_GravAdmin_namespaceObject.config.notifications.filters;
|
|||
|
};
|
|||
|
|
|||
|
var Notifications = /*#__PURE__*/function () {
|
|||
|
function Notifications() {
|
|||
|
notifications_classCallCheck(this, Notifications);
|
|||
|
}
|
|||
|
|
|||
|
notifications_createClass(Notifications, [{
|
|||
|
key: "fetch",
|
|||
|
value: // Grav.default.Notifications.fetch()
|
|||
|
function fetch() {
|
|||
|
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
|
|||
|
_ref$filter = _ref.filter,
|
|||
|
filter = _ref$filter === void 0 ? notificationsFilters() : _ref$filter,
|
|||
|
_ref$refresh = _ref.refresh,
|
|||
|
refresh = _ref$refresh === void 0 ? false : _ref$refresh;
|
|||
|
|
|||
|
if (!canFetchNotifications()) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
var feed = external_jQuery_default()('#notifications');
|
|||
|
var loader = feed.find('.widget-loader');
|
|||
|
var content = feed.find('.widget-content > ul');
|
|||
|
loader.find('div').remove();
|
|||
|
loader.find('.fa-warning').removeClass('fa-warning').addClass('fa-refresh fa-spin');
|
|||
|
loader.show();
|
|||
|
content.hide();
|
|||
|
|
|||
|
var processNotifications = function processNotifications(response) {
|
|||
|
var notifications = response.notifications;
|
|||
|
external_jQuery_default()('#notifications').find('.widget-content > ul').empty();
|
|||
|
|
|||
|
if (notifications) {
|
|||
|
Object.keys(notifications).forEach(function (location) {
|
|||
|
return Notifications.processLocation(location, notifications[location]);
|
|||
|
});
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
utils_request("".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/task").concat(external_GravAdmin_namespaceObject.config.param_sep, "getNotifications"), {
|
|||
|
method: 'post',
|
|||
|
body: {
|
|||
|
refresh: refresh,
|
|||
|
filter: filter
|
|||
|
}
|
|||
|
}, function (response) {
|
|||
|
processNotifications(response);
|
|||
|
})["catch"](function () {
|
|||
|
var widget = external_jQuery_default()('#notifications .widget-content');
|
|||
|
widget.find('.widget-loader').find('div').remove();
|
|||
|
widget.find('.widget-loader').append('<div>Failed to retrieve notifications</div>').find('.fa-spin').removeClass('fa-spin fa-refresh').addClass('fa-warning');
|
|||
|
});
|
|||
|
}
|
|||
|
}], [{
|
|||
|
key: "addShowAllInFeed",
|
|||
|
value: function addShowAllInFeed() {
|
|||
|
external_jQuery_default()('#notifications ul').append('<li class="show-all" data-notification-action="show-all-notifications">Show all</li>');
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "showNotificationInFeed",
|
|||
|
value: function showNotificationInFeed(notification) {
|
|||
|
var notifications = external_jQuery_default()('#notifications').removeClass('hidden');
|
|||
|
var loader = notifications.find('.widget-loader').hide();
|
|||
|
var content = notifications.find('.widget-content > ul').show();
|
|||
|
loader.find('div').remove();
|
|||
|
loader.find('.fa-warning').removeClass('fa-warning').addClass('fa-refresh fa-spin');
|
|||
|
content.append(notification).find('li:nth-child(n+11)').addClass('hidden'); // hide all items > 10
|
|||
|
|
|||
|
if (content.find('li.hidden').length) {
|
|||
|
Notifications.addShowAllInFeed();
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "showNotificationInTop",
|
|||
|
value: function showNotificationInTop(notification) {
|
|||
|
var container = external_jQuery_default()('.top-notifications-container');
|
|||
|
var dummy = external_jQuery_default()('<div />').html(notification);
|
|||
|
container.removeClass('hidden').append(dummy.children());
|
|||
|
dummy.children().slideDown(150);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "showNotificationInDashboard",
|
|||
|
value: function showNotificationInDashboard(notification) {
|
|||
|
var container = external_jQuery_default()('.dashboard-notifications-container');
|
|||
|
var dummy = external_jQuery_default()('<div />').html(notification);
|
|||
|
container.removeClass('hidden').append(dummy.children());
|
|||
|
dummy.children().slideDown(150);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "showNotificationInPlugins",
|
|||
|
value: function showNotificationInPlugins(notification) {
|
|||
|
var container = external_jQuery_default()('.plugins-notifications-container');
|
|||
|
var dummy = external_jQuery_default()('<div />').html(notification);
|
|||
|
container.removeClass('hidden').append(dummy.children());
|
|||
|
dummy.children().slideDown(150);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "showNotificationInThemes",
|
|||
|
value: function showNotificationInThemes(notification) {
|
|||
|
var container = external_jQuery_default()('.themes-notifications-container');
|
|||
|
var dummy = external_jQuery_default()('<div />').html(notification);
|
|||
|
container.removeClass('hidden').append(dummy.children());
|
|||
|
dummy.children().slideDown(150);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "processLocation",
|
|||
|
value: function processLocation(location, notification) {
|
|||
|
switch (location) {
|
|||
|
case 'feed':
|
|||
|
Notifications.showNotificationInFeed(notification);
|
|||
|
break;
|
|||
|
|
|||
|
case 'top':
|
|||
|
if (!notification.read) {
|
|||
|
Notifications.showNotificationInTop(notification);
|
|||
|
}
|
|||
|
|
|||
|
break;
|
|||
|
|
|||
|
case 'dashboard':
|
|||
|
if (!notification.read) {
|
|||
|
Notifications.showNotificationInDashboard(notification);
|
|||
|
}
|
|||
|
|
|||
|
break;
|
|||
|
|
|||
|
case 'plugins':
|
|||
|
if (!notification.read) {
|
|||
|
Notifications.showNotificationInPlugins(notification);
|
|||
|
}
|
|||
|
|
|||
|
break;
|
|||
|
|
|||
|
case 'themes':
|
|||
|
if (!notification.read) {
|
|||
|
Notifications.showNotificationInThemes(notification);
|
|||
|
}
|
|||
|
|
|||
|
break;
|
|||
|
}
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return Notifications;
|
|||
|
}();
|
|||
|
|
|||
|
var notifications = new Notifications();
|
|||
|
/* harmony default export */ const updates_notifications = (notifications);
|
|||
|
|
|||
|
if (canFetchNotifications()) {
|
|||
|
notifications.fetch();
|
|||
|
/* Hide a notification and store it hidden */
|
|||
|
// <a href="#" data-notification-action="hide-notification" data-notification-id="${notification.id}" class="close hide-notification"><i class="fa fa-close"></i></a>
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', '[data-notification-action="hide-notification"]', function (event) {
|
|||
|
var notification_id = external_jQuery_default()(event.target).parents('.hide-notification').data('notification-id');
|
|||
|
var url = "".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/notifications.json/task").concat(external_GravAdmin_namespaceObject.config.param_sep, "hideNotification/notification_id").concat(external_GravAdmin_namespaceObject.config.param_sep).concat(notification_id);
|
|||
|
utils_request(url, {
|
|||
|
method: 'post'
|
|||
|
}, function () {});
|
|||
|
external_jQuery_default()(event.target).parents('.single-notification').hide();
|
|||
|
});
|
|||
|
external_jQuery_default()(document).on('click', '[data-notification-action="hide-notification"]', function (event) {
|
|||
|
var target = external_jQuery_default()(event.currentTarget);
|
|||
|
var notification = target.parent();
|
|||
|
notification.slideUp(function () {
|
|||
|
return notification.remove();
|
|||
|
});
|
|||
|
});
|
|||
|
external_jQuery_default()(document).on('click', '[data-notification-action="show-all-notifications"]', function (event) {
|
|||
|
external_jQuery_default()('#notifications .show-all').hide();
|
|||
|
external_jQuery_default()('#notifications .hidden').removeClass('hidden');
|
|||
|
});
|
|||
|
external_jQuery_default()(document).on('click', '[data-refresh="notifications"]', function (event) {
|
|||
|
event.preventDefault();
|
|||
|
notifications.fetch({
|
|||
|
filter: ['feed'],
|
|||
|
refresh: true
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
;// CONCATENATED MODULE: ./app/updates/feed.js
|
|||
|
function feed_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function feed_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 feed_createClass(Constructor, protoProps, staticProps) { if (protoProps) feed_defineProperties(Constructor.prototype, protoProps); if (staticProps) feed_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var URI = "".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/ajax.json/task").concat(external_GravAdmin_namespaceObject.config.param_sep, "getNewsFeed");
|
|||
|
|
|||
|
var Feed = /*#__PURE__*/function () {
|
|||
|
function Feed() {
|
|||
|
feed_classCallCheck(this, Feed);
|
|||
|
|
|||
|
this.data = null;
|
|||
|
}
|
|||
|
|
|||
|
feed_createClass(Feed, [{
|
|||
|
key: "fetch",
|
|||
|
value: function fetch() {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
var refresh = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
|
|||
|
var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : function () {};
|
|||
|
utils_request(URI, {
|
|||
|
method: 'post',
|
|||
|
body: {
|
|||
|
refresh: refresh
|
|||
|
}
|
|||
|
}, function (response) {
|
|||
|
_this.data = response;
|
|||
|
callback(response);
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "refresh",
|
|||
|
value: function refresh() {
|
|||
|
var _refresh = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
|
|||
|
|
|||
|
var feed = external_jQuery_default()('#news-feed .widget-content');
|
|||
|
|
|||
|
if (!feed.length) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var loader = feed.find('.widget-loader');
|
|||
|
loader.find('div').remove();
|
|||
|
loader.find('.fa-warning').removeClass('fa-warning').addClass('fa-refresh fa-spin');
|
|||
|
loader.show();
|
|||
|
feed.find('> ul').hide();
|
|||
|
|
|||
|
if (!this.data || this.data.error || _refresh) {
|
|||
|
this.fetch(_refresh, this.updateContent.bind(this));
|
|||
|
} else {
|
|||
|
this.updateContent();
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "updateContent",
|
|||
|
value: function updateContent() {
|
|||
|
var feed = external_jQuery_default()('#news-feed .widget-content');
|
|||
|
|
|||
|
if (!feed.length) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var loader = feed.find('.widget-loader').hide();
|
|||
|
var content = feed.find('> ul').empty().show();
|
|||
|
|
|||
|
if (this.data.error || this.data.status === 'error') {
|
|||
|
loader.show().find('div').remove();
|
|||
|
loader.find('.fa-refresh').removeClass('fa-refresh fa-spin').addClass('fa-warning');
|
|||
|
loader.append("<div>".concat(this.data.error ? this.data.error.message : this.data.message || 'Unable to download news feed', "</div>"));
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
if (this.data && this.data.feed_data) {
|
|||
|
content.append(this.data.feed_data);
|
|||
|
}
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return Feed;
|
|||
|
}();
|
|||
|
|
|||
|
var feed = new Feed();
|
|||
|
external_jQuery_default()(document).ready(function () {
|
|||
|
return feed.refresh();
|
|||
|
});
|
|||
|
external_jQuery_default()(document).on('click', '[data-refresh="feed"]', function (event) {
|
|||
|
event.preventDefault();
|
|||
|
feed.refresh(true);
|
|||
|
});
|
|||
|
/* harmony default export */ const updates_feed = (feed);
|
|||
|
;// CONCATENATED MODULE: ./app/updates/check.js
|
|||
|
|
|||
|
|
|||
|
|
|||
|
// Check for updates trigger
|
|||
|
|
|||
|
external_jQuery_default()('[data-gpm-checkupdates]').on('click', function () {
|
|||
|
var element = external_jQuery_default()(this);
|
|||
|
element.find('i').addClass('fa-spin');
|
|||
|
Instance.fetch(function (response) {
|
|||
|
element.find('i').removeClass('fa-spin');
|
|||
|
var payload = response.payload;
|
|||
|
|
|||
|
if (!payload) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
if (!payload.grav.isUpdatable && !payload.resources.total) {
|
|||
|
utils_toastr.success(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.EVERYTHING_UP_TO_DATE);
|
|||
|
} else {
|
|||
|
var grav = payload.grav.isUpdatable ? 'Grav v' + payload.grav.available : '';
|
|||
|
var resources = payload.resources.total ? payload.resources.total + ' ' + external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.UPDATES_ARE_AVAILABLE : '';
|
|||
|
|
|||
|
if (!resources) {
|
|||
|
grav += ' ' + external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.IS_AVAILABLE_FOR_UPDATE;
|
|||
|
}
|
|||
|
|
|||
|
utils_toastr.info(grav + (grav && resources ? ' ' + external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.AND + ' ' : '') + resources);
|
|||
|
}
|
|||
|
}, true);
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/utils/formatbytes.js
|
|||
|
var sizes = ['Bytes', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'];
|
|||
|
function formatBytes(bytes, decimals) {
|
|||
|
if (bytes === 0) return '0 Byte';
|
|||
|
var k = 1000;
|
|||
|
var value = Math.floor(Math.log(bytes) / Math.log(k));
|
|||
|
var decimal = decimals + 1 || 3;
|
|||
|
return (bytes / Math.pow(k, value)).toPrecision(decimal) + ' ' + sizes[value];
|
|||
|
}
|
|||
|
;// CONCATENATED MODULE: ./app/updates/update.js
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
// Dashboard update and Grav update
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click.remodal', '[data-remodal-id="update-grav"] [data-remodal-action="confirm"]', function () {
|
|||
|
var element = external_jQuery_default()('#grav-update-button');
|
|||
|
element.html("".concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.UPDATING_PLEASE_WAIT, " ").concat(formatBytes(updates_Instance.payload.grav.assets["grav-update"].size), ".."));
|
|||
|
element.attr('disabled', 'disabled').find('> .fa').removeClass('fa-cloud-download').addClass('fa-refresh fa-spin');
|
|||
|
utils_request(updates_Instance.updateURL, function (response) {
|
|||
|
if (response.type === 'updategrav') {
|
|||
|
external_jQuery_default()('[data-gpm-grav]').remove();
|
|||
|
external_jQuery_default()('#footer .grav-version').html(response.version);
|
|||
|
}
|
|||
|
|
|||
|
element.removeAttr('disabled').find('> .fa').removeClass('fa-refresh fa-spin').addClass('fa-cloud-download');
|
|||
|
});
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/updates/channel-switcher.js
|
|||
|
|
|||
|
|
|||
|
var switcher = external_jQuery_default()('input[type="radio"][name="channel-switch"]');
|
|||
|
|
|||
|
if (switcher) {
|
|||
|
switcher.on('change', function (event) {
|
|||
|
var radio = external_jQuery_default()(event.target);
|
|||
|
var url = "".concat(radio.parent('[data-url]').data('url'));
|
|||
|
utils_request(url, {
|
|||
|
method: 'post',
|
|||
|
body: {
|
|||
|
task: 'gpmRelease',
|
|||
|
release: radio.val()
|
|||
|
}
|
|||
|
}, function (response) {
|
|||
|
if (response.reload) {
|
|||
|
__webpack_require__.g.location.reload();
|
|||
|
}
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
;// CONCATENATED MODULE: ./app/updates/index.js
|
|||
|
function updates_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function updates_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 updates_createClass(Constructor, protoProps, staticProps) { if (protoProps) updates_defineProperties(Constructor.prototype, protoProps); if (staticProps) updates_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var Updates = /*#__PURE__*/function () {
|
|||
|
function Updates() {
|
|||
|
var payload = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|||
|
|
|||
|
updates_classCallCheck(this, Updates);
|
|||
|
|
|||
|
this.setPayload(payload);
|
|||
|
this.task = "task".concat(external_GravAdmin_namespaceObject.config.param_sep);
|
|||
|
this.updateURL = '';
|
|||
|
}
|
|||
|
|
|||
|
updates_createClass(Updates, [{
|
|||
|
key: "setPayload",
|
|||
|
value: function setPayload() {
|
|||
|
var payload = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|||
|
this.payload = payload;
|
|||
|
return this;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "fetch",
|
|||
|
value: function fetch() {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
var force = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
|
|||
|
Instance.fetch(function (response) {
|
|||
|
return _this.setPayload(response);
|
|||
|
}, force);
|
|||
|
return this;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "maintenance",
|
|||
|
value: function maintenance() {
|
|||
|
var mode = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'hide';
|
|||
|
var element = external_jQuery_default()('#updates [data-update-packages]');
|
|||
|
element[mode === 'show' ? 'fadeIn' : 'fadeOut']();
|
|||
|
|
|||
|
if (mode === 'hide') {
|
|||
|
external_jQuery_default()('.badges.with-updates').removeClass('with-updates').find('.badge.updates').remove();
|
|||
|
}
|
|||
|
|
|||
|
return this;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "grav",
|
|||
|
value: function grav() {
|
|||
|
var payload = this.payload.grav;
|
|||
|
|
|||
|
if (payload && payload.isUpdatable) {
|
|||
|
var task = this.task;
|
|||
|
var bar = '';
|
|||
|
|
|||
|
if (!payload.isSymlink) {
|
|||
|
this.updateURL = "".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/update.json/").concat(task, "updategrav/admin-nonce").concat(external_GravAdmin_namespaceObject.config.param_sep).concat(external_GravAdmin_namespaceObject.config.admin_nonce);
|
|||
|
bar += "<button data-remodal-target=\"update-grav\" class=\"button button-small secondary pointer-events-none\" id=\"grav-update-button\">".concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.UPDATE_GRAV_NOW, " <span class=\"cnt-down\">(5s)</span></button>");
|
|||
|
} else {
|
|||
|
bar += "<span class=\"hint--left\" style=\"float: right;\" data-hint=\"".concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.GRAV_SYMBOLICALLY_LINKED, "\"><i class=\"fa fa-fw fa-link\"></i></span>");
|
|||
|
}
|
|||
|
|
|||
|
bar += "\n Grav <b>v".concat(payload.available, "</b> ").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.IS_NOW_AVAILABLE, "! <span class=\"less\">(").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.CURRENT, " v").concat(payload.version, ")</span>\n ");
|
|||
|
var element = external_jQuery_default()('[data-gpm-grav]').removeClass('hidden');
|
|||
|
|
|||
|
if (element.is(':empty')) {
|
|||
|
element.hide();
|
|||
|
}
|
|||
|
|
|||
|
element.addClass('grav').html("".concat(bar)).slideDown(150, function () {
|
|||
|
var c = 5;
|
|||
|
var x = setInterval(function () {
|
|||
|
c -= 1;
|
|||
|
element.find('.pointer-events-none .cnt-down').text('(' + c + 's)');
|
|||
|
}, 1000);
|
|||
|
setTimeout(function () {
|
|||
|
clearInterval(x);
|
|||
|
element.find('.pointer-events-none .cnt-down').remove();
|
|||
|
element.find('.pointer-events-none').removeClass('pointer-events-none');
|
|||
|
}, 5000);
|
|||
|
}).parent('#messages').addClass('default-box-shadow');
|
|||
|
}
|
|||
|
|
|||
|
return this;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "resources",
|
|||
|
value: function resources() {
|
|||
|
if (!this.payload || !this.payload.resources || !this.payload.resources.total) {
|
|||
|
return this.maintenance('hide');
|
|||
|
}
|
|||
|
|
|||
|
var is_current_package_latest = true;
|
|||
|
var map = ['plugins', 'themes'];
|
|||
|
var singles = ['plugin', 'theme'];
|
|||
|
var _this$payload$resourc = this.payload.resources,
|
|||
|
plugins = _this$payload$resourc.plugins,
|
|||
|
themes = _this$payload$resourc.themes;
|
|||
|
|
|||
|
if (!this.payload.resources.total) {
|
|||
|
return this;
|
|||
|
}
|
|||
|
|
|||
|
[plugins, themes].forEach(function (resources, index) {
|
|||
|
if (!resources || Array.isArray(resources)) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var length = Object.keys(resources).length;
|
|||
|
var type = map[index]; // sidebar
|
|||
|
|
|||
|
external_jQuery_default()("#admin-menu a[href$=\"/".concat(map[index], "\"]")).find('.badges').addClass('with-updates').find('.badge.updates').text(length);
|
|||
|
var type_translation = ''; // update all
|
|||
|
|
|||
|
if (type === 'plugins') {
|
|||
|
type_translation = external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.PLUGINS;
|
|||
|
} else {
|
|||
|
type_translation = external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.THEMES;
|
|||
|
}
|
|||
|
|
|||
|
var updateAll = external_jQuery_default()(".grav-update.".concat(type));
|
|||
|
updateAll.css('display', 'block').html("\n <p>\n <a href=\"#\" class=\"button button-small secondary\" data-remodal-target=\"update-packages\" data-packages-slugs=\"".concat(Object.keys(resources).join(), "\" data-").concat(singles[index], "-action=\"start-packages-update\">").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.UPDATE, " ").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.ALL, " ").concat(type_translation, "</a>\n <i class=\"fa fa-bullhorn\"></i>\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 </p>\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("<a class=\"plugin-update-button\" href=\"".concat(url.attr('href'), "\"><span class=\"badge update\">").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.UPDATE_AVAILABLE, "!</span></a>"));
|
|||
|
content_wrapper.addClass('has-updates');
|
|||
|
} else if (type === 'themes') {
|
|||
|
element.append("<div class=\"gpm-ribbon\"><a href=\"".concat(url.attr('href'), "\">").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.UPDATE.toUpperCase(), "</a></div>"));
|
|||
|
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' ? '<span class="gpm-testing">test release</span>' : '';
|
|||
|
details.html("\n <p>\n <a href=\"#\" class=\"button button-small secondary\" data-remodal-target=\"update-packages\" data-packages-slugs=\"".concat(item, "\" data-").concat(singles[index], "-action=\"start-package-installation\">").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.UPDATE, " ").concat(singles[index].charAt(0).toUpperCase() + singles[index].substr(1).toLowerCase(), "</a>\n <i class=\"fa fa-bullhorn\"></i>\n <strong>v").concat(resources[item].available, "</strong> ").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 </p>\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"; return chart_typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, chart_typeof(obj); }
|
|||
|
|
|||
|
function _get() { 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(arguments.length < 3 ? target : receiver); } return desc.value; }; } return _get.apply(this, arguments); }
|
|||
|
|
|||
|
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 } }); Object.defineProperty(subClass, "prototype", { writable: false }); 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; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } 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); Object.defineProperty(Constructor, "prototype", { writable: false }); 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); Object.defineProperty(Constructor, "prototype", { writable: false }); 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 <em>".concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.DAYS.toLowerCase(), "</em>"));
|
|||
|
}
|
|||
|
|
|||
|
(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__(31619);
|
|||
|
;// 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); Object.defineProperty(Constructor, "prototype", { writable: false }); 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"; return filter_typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, 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); Object.defineProperty(Constructor, "prototype", { writable: false }); 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]"], [data-remodal-id="modal-page-copy"] 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]"], [data-remodal-id="modal-page-copy"] 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) {
|
|||
|
getFields('title').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()('<div />').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');
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/utils/cookies.js
|
|||
|
function cookies_typeof(obj) { "@babel/helpers - typeof"; return cookies_typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, cookies_typeof(obj); }
|
|||
|
|
|||
|
/*
|
|||
|
* Cookies.js - 1.2.3-grav
|
|||
|
* https://github.com/ScottHamper/Cookies
|
|||
|
*
|
|||
|
* With SameSite support by Grav
|
|||
|
*
|
|||
|
* This is free and unencumbered software released into the public domain.
|
|||
|
*/
|
|||
|
var factory = function factory(window) {
|
|||
|
var _arguments = arguments;
|
|||
|
|
|||
|
if (cookies_typeof(window.document) !== 'object') {
|
|||
|
throw new Error('Cookies.js requires a `window` with a `document` object');
|
|||
|
}
|
|||
|
|
|||
|
var Cookies = function Cookies(key, value, options) {
|
|||
|
return _arguments.length === 1 ? Cookies.get(key) : Cookies.set(key, value, options);
|
|||
|
}; // Allows for setter injection in unit tests
|
|||
|
|
|||
|
|
|||
|
Cookies._document = window.document; // Used to ensure cookie keys do not collide with
|
|||
|
// built-in `Object` properties
|
|||
|
|
|||
|
Cookies._cacheKeyPrefix = 'cookey.'; // Hurr hurr, :)
|
|||
|
|
|||
|
Cookies._maxExpireDate = new Date('Fri, 31 Dec 9999 23:59:59 UTC');
|
|||
|
Cookies.defaults = {
|
|||
|
path: '/',
|
|||
|
secure: false,
|
|||
|
sameSite: 'Lax'
|
|||
|
};
|
|||
|
|
|||
|
Cookies.get = function (key) {
|
|||
|
if (Cookies._cachedDocumentCookie !== Cookies._document.cookie) {
|
|||
|
Cookies._renewCache();
|
|||
|
}
|
|||
|
|
|||
|
var value = Cookies._cache[Cookies._cacheKeyPrefix + key];
|
|||
|
return value === undefined ? undefined : decodeURIComponent(value);
|
|||
|
};
|
|||
|
|
|||
|
Cookies.set = function (key, value, options) {
|
|||
|
options = Cookies._getExtendedOptions(options);
|
|||
|
options.expires = Cookies._getExpiresDate(value === undefined ? -1 : options.expires);
|
|||
|
Cookies._document.cookie = Cookies._generateCookieString(key, value, options);
|
|||
|
return Cookies;
|
|||
|
};
|
|||
|
|
|||
|
Cookies.expire = function (key, options) {
|
|||
|
return Cookies.set(key, undefined, options);
|
|||
|
};
|
|||
|
|
|||
|
Cookies._getExtendedOptions = function (options) {
|
|||
|
return {
|
|||
|
path: options && options.path || Cookies.defaults.path,
|
|||
|
domain: options && options.domain || Cookies.defaults.domain,
|
|||
|
expires: options && options.expires || Cookies.defaults.expires,
|
|||
|
secure: options && options.secure !== undefined ? options.secure : Cookies.defaults.secure,
|
|||
|
sameSite: options && options.sameSite || Cookies.defaults.sameSite
|
|||
|
};
|
|||
|
};
|
|||
|
|
|||
|
Cookies._isValidDate = function (date) {
|
|||
|
return Object.prototype.toString.call(date) === '[object Date]' && !isNaN(date.getTime());
|
|||
|
};
|
|||
|
|
|||
|
Cookies._getExpiresDate = function (expires, now) {
|
|||
|
now = now || new Date();
|
|||
|
|
|||
|
if (typeof expires === 'number') {
|
|||
|
expires = expires === Infinity ? Cookies._maxExpireDate : new Date(now.getTime() + expires * 1000);
|
|||
|
} else if (typeof expires === 'string') {
|
|||
|
expires = new Date(expires);
|
|||
|
}
|
|||
|
|
|||
|
if (expires && !Cookies._isValidDate(expires)) {
|
|||
|
throw new Error('`expires` parameter cannot be converted to a valid Date instance');
|
|||
|
}
|
|||
|
|
|||
|
return expires;
|
|||
|
};
|
|||
|
|
|||
|
Cookies._generateCookieString = function (key, value, options) {
|
|||
|
key = key.replace(/[^#$&+\^`|]/g, encodeURIComponent);
|
|||
|
key = key.replace(/\(/g, '%28').replace(/\)/g, '%29');
|
|||
|
value = (value + '').replace(/[^!#$&-+\--:<-\[\]-~]/g, encodeURIComponent);
|
|||
|
options = options || {};
|
|||
|
var cookieString = key + '=' + value;
|
|||
|
cookieString += options.path ? ';path=' + options.path : '';
|
|||
|
cookieString += options.domain ? ';domain=' + options.domain : '';
|
|||
|
cookieString += options.expires ? ';expires=' + options.expires.toUTCString() : '';
|
|||
|
cookieString += options.secure ? ';secure' : '';
|
|||
|
cookieString += options.sameSite ? ';SameSite=' + options.sameSite : '';
|
|||
|
return cookieString;
|
|||
|
};
|
|||
|
|
|||
|
Cookies._getCacheFromString = function (documentCookie) {
|
|||
|
var cookieCache = {};
|
|||
|
var cookiesArray = documentCookie ? documentCookie.split('; ') : [];
|
|||
|
|
|||
|
for (var i = 0; i < cookiesArray.length; i++) {
|
|||
|
var cookieKvp = Cookies._getKeyValuePairFromCookieString(cookiesArray[i]);
|
|||
|
|
|||
|
if (cookieCache[Cookies._cacheKeyPrefix + cookieKvp.key] === undefined) {
|
|||
|
cookieCache[Cookies._cacheKeyPrefix + cookieKvp.key] = cookieKvp.value;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
return cookieCache;
|
|||
|
};
|
|||
|
|
|||
|
Cookies._getKeyValuePairFromCookieString = function (cookieString) {
|
|||
|
// "=" is a valid character in a cookie value according to RFC6265, so cannot `split('=')`
|
|||
|
var separatorIndex = cookieString.indexOf('='); // IE omits the "=" when the cookie value is an empty string
|
|||
|
|
|||
|
separatorIndex = separatorIndex < 0 ? cookieString.length : separatorIndex;
|
|||
|
var key = cookieString.substr(0, separatorIndex);
|
|||
|
var decodedKey;
|
|||
|
|
|||
|
try {
|
|||
|
decodedKey = decodeURIComponent(key);
|
|||
|
} catch (e) {
|
|||
|
if (console && typeof console.error === 'function') {
|
|||
|
console.error('Could not decode cookie with key "' + key + '"', e);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
return {
|
|||
|
key: decodedKey,
|
|||
|
value: cookieString.substr(separatorIndex + 1) // Defer decoding value until accessed
|
|||
|
|
|||
|
};
|
|||
|
};
|
|||
|
|
|||
|
Cookies._renewCache = function () {
|
|||
|
Cookies._cache = Cookies._getCacheFromString(Cookies._document.cookie);
|
|||
|
Cookies._cachedDocumentCookie = Cookies._document.cookie;
|
|||
|
};
|
|||
|
|
|||
|
Cookies._areEnabled = function () {
|
|||
|
var testKey = 'cookies.js';
|
|||
|
var areEnabled = Cookies.set(testKey, 1).get(testKey) === '1';
|
|||
|
Cookies.expire(testKey);
|
|||
|
return areEnabled;
|
|||
|
};
|
|||
|
|
|||
|
Cookies.enabled = Cookies._areEnabled();
|
|||
|
return Cookies;
|
|||
|
};
|
|||
|
|
|||
|
__webpack_require__.g.Cookies = __webpack_require__.g && cookies_typeof(__webpack_require__.g.document) === 'object' ? factory(__webpack_require__.g) : factory;
|
|||
|
/* harmony default export */ const cookies = (__webpack_require__.g.Cookies);
|
|||
|
// 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); Object.defineProperty(Constructor, "prototype", { writable: false }); 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 <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>\u2714</span></div>\n <div class=\"dz-error-mark\"><span>\u2718</span></div>\n <div class=\"dz-error-message\"><span data-dz-errormessage></span></div>\n <a class=\"dz-unset\" title=\"".concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.UNSET, "\" href=\"#\" data-dz-unset>").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.UNSET, "</a>\n <a class=\"dz-remove\" title=\"").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.DELETE, "\" href=\"javascript:undefined;\" data-dz-remove>").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.DELETE, "</a>\n <a class=\"dz-metadata\" title=\"").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.METADATA, "\" href=\"#\" target=\"_blank\" data-dz-metadata>").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.METADATA, "</a>\n <a class=\"dz-view\" title=\"").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.VIEW, "\" href=\"#\" target=\"_blank\" data-dz-view>").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.VIEW, "</a>\n </div>").trim()
|
|||
|
}; // global.EXIF = EXIF;
|
|||
|
|
|||
|
var ACCEPT_FUNC = function ACCEPT_FUNC(file, done, settings) {
|
|||
|
var resolution = settings.resolution;
|
|||
|
if (!resolution) return done();
|
|||
|
var reader = new FileReader();
|
|||
|
var error = '';
|
|||
|
var hasMin = resolution.min && (resolution.min.width || resolution.min.height);
|
|||
|
var hasMax = resolution.max && (resolution.max.width || resolution.max.height);
|
|||
|
|
|||
|
if (hasMin || !(settings.resizeWidth || settings.resizeHeight) && hasMax) {
|
|||
|
reader.onload = function (event) {
|
|||
|
if (!/image\//.test(file.type)) {
|
|||
|
done();
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var image = new Image();
|
|||
|
image.src = event.target.result;
|
|||
|
|
|||
|
image.onerror = function () {
|
|||
|
done(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.FILE_ERROR_UPLOAD);
|
|||
|
};
|
|||
|
|
|||
|
image.onload = function () {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
if (resolution.min) {
|
|||
|
Object.keys(resolution.min).forEach(function (attr) {
|
|||
|
if (resolution.min[attr] && _this[attr] < resolution.min[attr]) {
|
|||
|
error += external_GravAdmin_namespaceObject.translations.PLUGIN_FORM.RESOLUTION_MIN.replace(/{{attr}}/g, attr).replace(/{{min}}/g, resolution.min[attr]);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
if (!(settings.resizeWidth || settings.resizeHeight)) {
|
|||
|
if (resolution.max) {
|
|||
|
Object.keys(resolution.max).forEach(function (attr) {
|
|||
|
if (resolution.max[attr] && _this[attr] > resolution.max[attr]) {
|
|||
|
error += external_GravAdmin_namespaceObject.translations.PLUGIN_FORM.RESOLUTION_MAX.replace(/{{attr}}/g, attr).replace(/{{max}}/g, resolution.max[attr]);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
URL.revokeObjectURL(image.src); // release memory
|
|||
|
|
|||
|
return error ? done(error) : done();
|
|||
|
};
|
|||
|
};
|
|||
|
|
|||
|
reader.readAsDataURL(file);
|
|||
|
} else {
|
|||
|
return error ? done(error) : done();
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
var FilesField = /*#__PURE__*/function () {
|
|||
|
function FilesField() {
|
|||
|
var _this2 = this;
|
|||
|
|
|||
|
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
|
|||
|
_ref$container = _ref.container,
|
|||
|
container = _ref$container === void 0 ? '.dropzone.files-upload' : _ref$container,
|
|||
|
_ref$options = _ref.options,
|
|||
|
options = _ref$options === void 0 ? {} : _ref$options;
|
|||
|
|
|||
|
files_classCallCheck(this, FilesField);
|
|||
|
|
|||
|
this.container = external_jQuery_default()(container);
|
|||
|
|
|||
|
if (!this.container.length) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
this.urls = {};
|
|||
|
this.customPost = this.container.data('filePostAdd') || {};
|
|||
|
this.options = Object.assign({}, Dictionary, DropzoneMediaConfig, {
|
|||
|
klass: this,
|
|||
|
url: this.container.data('file-url-add') || external_GravAdmin_namespaceObject.config.current_url,
|
|||
|
acceptedFiles: this.container.data('media-types'),
|
|||
|
init: this.initDropzone
|
|||
|
}, this.container.data('dropzone-options'), options);
|
|||
|
this.options = Object.assign({}, this.options, {
|
|||
|
accept: function accept(file, done) {
|
|||
|
ACCEPT_FUNC(file, done, this.options);
|
|||
|
}
|
|||
|
});
|
|||
|
this.dropzone = new (dropzone_default())(container, this.options);
|
|||
|
this.dropzone.on('complete', this.onDropzoneComplete.bind(this));
|
|||
|
this.dropzone.on('success', this.onDropzoneSuccess.bind(this));
|
|||
|
this.dropzone.on('addedfile', this.onDropzoneAddedFile.bind(this));
|
|||
|
this.dropzone.on('removedfile', this.onDropzoneRemovedFile.bind(this));
|
|||
|
this.dropzone.on('sending', this.onDropzoneSending.bind(this));
|
|||
|
this.dropzone.on('error', this.onDropzoneError.bind(this));
|
|||
|
this.container.on('mouseenter', '[data-dz-view]', function (e) {
|
|||
|
var value = JSON.parse(_this2.container.find('[name][type="hidden"]').val() || '{}');
|
|||
|
var target = external_jQuery_default()(e.currentTarget);
|
|||
|
var file = target.parent('.dz-preview').find('.dz-filename');
|
|||
|
var filename = encodeURI(file.text());
|
|||
|
var URL = Object.keys(value).filter(function (key) {
|
|||
|
return value[key].name === filename;
|
|||
|
}).shift();
|
|||
|
target.attr('href', "".concat(external_GravAdmin_namespaceObject.config.base_url_simple, "/").concat(URL));
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
files_createClass(FilesField, [{
|
|||
|
key: "initDropzone",
|
|||
|
value: function initDropzone() {
|
|||
|
var _this3 = this;
|
|||
|
|
|||
|
var files = this.options.klass.container.find('[data-file]');
|
|||
|
var dropzone = this;
|
|||
|
|
|||
|
if (!files.length) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
files.each(function (index, file) {
|
|||
|
file = external_jQuery_default()(file);
|
|||
|
var data = file.data('file');
|
|||
|
var mock = {
|
|||
|
name: data.name,
|
|||
|
size: data.size,
|
|||
|
type: data.type,
|
|||
|
status: (dropzone_default()).ADDED,
|
|||
|
accepted: true,
|
|||
|
url: _this3.options.url,
|
|||
|
removeUrl: data.remove
|
|||
|
};
|
|||
|
dropzone.files.push(mock);
|
|||
|
dropzone.options.addedfile.call(dropzone, mock);
|
|||
|
|
|||
|
if (mock.type.match(/^image\//)) {
|
|||
|
dropzone.options.thumbnail.call(dropzone, mock, data.path);
|
|||
|
dropzone.createThumbnailFromUrl(mock, data.path);
|
|||
|
}
|
|||
|
|
|||
|
file.remove();
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "getURI",
|
|||
|
value: function getURI() {
|
|||
|
return this.container.data('mediaUri') || '';
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "onDropzoneSending",
|
|||
|
value: function onDropzoneSending(file, xhr, formData) {
|
|||
|
var _this4 = this;
|
|||
|
|
|||
|
if (Object.keys(this.customPost).length) {
|
|||
|
Object.keys(this.customPost).forEach(function (key) {
|
|||
|
formData.append(key, _this4.customPost[key]);
|
|||
|
});
|
|||
|
} else {
|
|||
|
formData.append('name', this.options.dotNotation);
|
|||
|
formData.append('task', 'filesupload');
|
|||
|
formData.append('uri', this.getURI());
|
|||
|
}
|
|||
|
|
|||
|
formData.append('admin-nonce', external_GravAdmin_namespaceObject.config.admin_nonce);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "onDropzoneSuccess",
|
|||
|
value: function onDropzoneSuccess(file, response, xhr) {
|
|||
|
response = typeof response === 'string' ? JSON.parse(response) : response;
|
|||
|
|
|||
|
if (this.options.reloadPage) {
|
|||
|
__webpack_require__.g.location.reload();
|
|||
|
} // store params for removing file from session before it gets saved
|
|||
|
|
|||
|
|
|||
|
if (response.session) {
|
|||
|
file.sessionParams = response.session;
|
|||
|
file.removeUrl = this.options.url; // Touch field value to force a mutation detection
|
|||
|
|
|||
|
var input = this.container.find('[name][type="hidden"]');
|
|||
|
var value = input.val();
|
|||
|
input.val(value + ' ');
|
|||
|
}
|
|||
|
|
|||
|
return this.handleError({
|
|||
|
file: file,
|
|||
|
data: response,
|
|||
|
mode: 'removeFile',
|
|||
|
msg: "<p>".concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.FILE_ERROR_UPLOAD, " <strong>{{fileName}}</strong></p>\n <pre>").concat(response.message, "</pre>")
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
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: "<p>".concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.FILE_ERROR_ADD, " <strong>{{fileName}}</strong></p>\n <pre>").concat(data.message, "</pre>")
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
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: "onDropzoneAddedFile",
|
|||
|
value: function onDropzoneAddedFile(file) {
|
|||
|
return this.dropzone.options.addedfile(file);
|
|||
|
}
|
|||
|
}, {
|
|||
|
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: "<pre>".concat(message, "</pre>")
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
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"]');
|
|||
|
var cleanName = file.name.replace('<', '<').replace('>', '>');
|
|||
|
modal.find('.error-content').html(msg.replace('{{fileName}}', cleanName));
|
|||
|
(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|webp|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: '<i class="fa fa-fw fa-undo"></i>',
|
|||
|
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: '<i class="fa fa-fw fa-repeat"></i>',
|
|||
|
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: '<i class="fa fa-fw fa-header"></i>',
|
|||
|
modes: ['gfm', 'markdown'],
|
|||
|
children: [{
|
|||
|
h1: {
|
|||
|
identifier: 'h1',
|
|||
|
label: '<i class="fa fa-fw fa-header"></i>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: '<i class="fa fa-fw fa-header"></i>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: '<i class="fa fa-fw fa-header"></i>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: '<i class="fa fa-fw fa-header"></i>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: '<i class="fa fa-fw fa-header"></i>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: '<i class="fa fa-fw fa-header"></i>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: '<i class="fa fa-fw fa-bold"></i>',
|
|||
|
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: '<i class="fa fa-fw fa-italic"></i>',
|
|||
|
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: '<i class="fa fa-fw fa-strikethrough"></i>',
|
|||
|
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: '<i class="fa fa-fw fa-minus"></i>',
|
|||
|
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: '<i class="fa fa-fw fa-link"></i>',
|
|||
|
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: '<i class="fa fa-fw fa-picture-o"></i>',
|
|||
|
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: '<i class="fa fa-fw fa-quote-right"></i>',
|
|||
|
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: '<i class="fa fa-fw fa-list-ul"></i>',
|
|||
|
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: '<i class="fa fa-fw fa-list-ol"></i>',
|
|||
|
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: '<i class="fa fa-fw fa-code"></i>',
|
|||
|
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: '<i class="fa fa-fw fa-eye"></i>',
|
|||
|
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()('<div class="grav-editor-preview" />');
|
|||
|
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: '<i class="fa fa-fw fa-expand"></i>',
|
|||
|
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__(1272);
|
|||
|
// 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); Object.defineProperty(Constructor, "prototype", { writable: false }); 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($('<link rel="stylesheet" type="text/css" />').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('<ul />');
|
|||
|
|
|||
|
buttons[map[type]].forEach(function (button) {
|
|||
|
return _this3.renderButton(button, type);
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "renderButton",
|
|||
|
value: function renderButton(button, type) {
|
|||
|
var _this4 = this;
|
|||
|
|
|||
|
var location = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null;
|
|||
|
Object.keys(button).forEach(function (key) {
|
|||
|
var obj = button[key];
|
|||
|
|
|||
|
if (!obj.modes) {
|
|||
|
obj.modes = [];
|
|||
|
}
|
|||
|
|
|||
|
if (!~_this4.codemirror.options.ignore.indexOf(key) && (!obj.modes.length || obj.modes.indexOf(_this4.codemirror.options.mode) > -1)) {
|
|||
|
var hint = obj.title ? "data-hint=\"".concat(obj.title, "\"") : '';
|
|||
|
var element = external_jQuery_default()("<li class=\"grav-editor-button-".concat(key, "\"><a class=\"hint--top\" ").concat(hint, ">").concat(obj.label, "</a></li>"));
|
|||
|
|
|||
|
(location || _this4.ui.navigation.find(".grav-editor-".concat(type, " ul:not(.dropdown-menu)"))).append(element);
|
|||
|
|
|||
|
if (obj.shortcut) {
|
|||
|
_this4.addShortcut(obj.identifier, obj.shortcut, element);
|
|||
|
}
|
|||
|
|
|||
|
obj.action && obj.action.call(obj.action, {
|
|||
|
codemirror: _this4.codemirror,
|
|||
|
button: element,
|
|||
|
textarea: _this4.editor,
|
|||
|
ui: _this4.ui
|
|||
|
});
|
|||
|
|
|||
|
if (obj.children) {
|
|||
|
var childrenContainer = external_jQuery_default()('<ul class="dropdown-menu" />');
|
|||
|
element.addClass('button-group').find('a').wrap('<div class="dropdown-toggle" data-toggle="dropdown"></div>');
|
|||
|
element.find('a').append(' <i class="fa fa-caret-down"></i>');
|
|||
|
element.append(childrenContainer);
|
|||
|
obj.children.forEach(function (child) {
|
|||
|
return _this4.renderButton(child, type, childrenContainer);
|
|||
|
});
|
|||
|
}
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "addShortcut",
|
|||
|
value: function addShortcut(identifier, shortcut, element) {
|
|||
|
var _this5 = this;
|
|||
|
|
|||
|
var map = {};
|
|||
|
|
|||
|
if (!Array.isArray(shortcut)) {
|
|||
|
shortcut = [shortcut];
|
|||
|
}
|
|||
|
|
|||
|
shortcut.forEach(function (key) {
|
|||
|
map[key] = function () {
|
|||
|
element.trigger("click.editor.".concat(identifier), [_this5.codemirror]);
|
|||
|
};
|
|||
|
});
|
|||
|
this.codemirror.addKeyMap(map);
|
|||
|
}
|
|||
|
}], [{
|
|||
|
key: "templates",
|
|||
|
value: function templates() {
|
|||
|
return {
|
|||
|
navigation: "\n <div class=\"grav-editor-toolbar\">\n <div class=\"grav-editor-actions\"></div>\n <div class=\"grav-editor-modes\"></div>\n </div>\n "
|
|||
|
};
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return Toolbar;
|
|||
|
}();
|
|||
|
var editor_Instance = new EditorField();
|
|||
|
;// CONCATENATED MODULE: ./app/pages/page/media.js
|
|||
|
function media_typeof(obj) { "@babel/helpers - typeof"; return media_typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, media_typeof(obj); }
|
|||
|
|
|||
|
function media_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function media_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 media_createClass(Constructor, protoProps, staticProps) { if (protoProps) media_defineProperties(Constructor.prototype, protoProps); if (staticProps) media_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
function media_get() { if (typeof Reflect !== "undefined" && Reflect.get) { media_get = Reflect.get; } else { media_get = function _get(target, property, receiver) { var base = media_superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(arguments.length < 3 ? target : receiver); } return desc.value; }; } return media_get.apply(this, arguments); }
|
|||
|
|
|||
|
function media_superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = media_getPrototypeOf(object); if (object === null) break; } return object; }
|
|||
|
|
|||
|
function media_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 } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) media_setPrototypeOf(subClass, superClass); }
|
|||
|
|
|||
|
function media_setPrototypeOf(o, p) { media_setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return media_setPrototypeOf(o, p); }
|
|||
|
|
|||
|
function media_createSuper(Derived) { var hasNativeReflectConstruct = media_isNativeReflectConstruct(); return function _createSuperInternal() { var Super = media_getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = media_getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return media_possibleConstructorReturn(this, result); }; }
|
|||
|
|
|||
|
function media_possibleConstructorReturn(self, call) { if (call && (media_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return media_assertThisInitialized(self); }
|
|||
|
|
|||
|
function media_assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
|||
|
|
|||
|
function media_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 media_getPrototypeOf(o) { media_getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return media_getPrototypeOf(o); }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var previewTemplate = "\n <div class=\"dz-preview dz-file-preview\">\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>\u2714</span></div>\n <div class=\"dz-error-mark\"><span>\u2718</span></div>\n <div class=\"dz-error-message\"><span data-dz-errormessage></span></div>\n <a class=\"dz-remove\" title=\"".concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.DELETE, "\" href=\"javascript:undefined;\" data-dz-remove>").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.DELETE, "</a>\n <a class=\"dz-metadata\" title=\"").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.METADATA, "\" href=\"#\" target=\"_blank\" data-dz-metadata>").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.METADATA, "</a>\n <a class=\"dz-view\" title=\"").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.VIEW, "\" href=\"#\" target=\"_blank\" data-dz-view>").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.VIEW, "</a>\n <a class=\"dz-insert\" title=\"").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.INSERT, "\" href=\"javascript:undefined;\" data-dz-insert>").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.INSERT, "</a>\n </div>").trim();
|
|||
|
|
|||
|
var PageMedia = /*#__PURE__*/function (_FilesField) {
|
|||
|
media_inherits(PageMedia, _FilesField);
|
|||
|
|
|||
|
var _super = media_createSuper(PageMedia);
|
|||
|
|
|||
|
function PageMedia() {
|
|||
|
var _this;
|
|||
|
|
|||
|
var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
|
|||
|
_ref$container = _ref.container,
|
|||
|
container = _ref$container === void 0 ? '#grav-dropzone' : _ref$container,
|
|||
|
_ref$options = _ref.options,
|
|||
|
options = _ref$options === void 0 ? {} : _ref$options;
|
|||
|
|
|||
|
media_classCallCheck(this, PageMedia);
|
|||
|
|
|||
|
options = Object.assign(options, {
|
|||
|
previewTemplate: previewTemplate
|
|||
|
});
|
|||
|
_this = _super.call(this, {
|
|||
|
container: container,
|
|||
|
options: options
|
|||
|
});
|
|||
|
|
|||
|
if (!_this.container.length) {
|
|||
|
return media_possibleConstructorReturn(_this);
|
|||
|
}
|
|||
|
|
|||
|
_this.urls = {
|
|||
|
fetch: "".concat(_this.container.data('media-url'), "/task").concat(external_GravAdmin_namespaceObject.config.param_sep, "listmedia"),
|
|||
|
add: "".concat(_this.container.data('media-url'), "/task").concat(external_GravAdmin_namespaceObject.config.param_sep, "addmedia"),
|
|||
|
"delete": "".concat(_this.container.data('media-url'), "/task").concat(external_GravAdmin_namespaceObject.config.param_sep, "delmedia")
|
|||
|
};
|
|||
|
_this.dropzone.options.url = _this.urls.add;
|
|||
|
|
|||
|
if (typeof _this.options.fetchMedia === 'undefined' || _this.options.fetchMedia) {
|
|||
|
_this.fetchMedia();
|
|||
|
}
|
|||
|
|
|||
|
if (typeof _this.options.attachDragDrop === 'undefined' || _this.options.attachDragDrop) {
|
|||
|
_this.attachDragDrop();
|
|||
|
}
|
|||
|
|
|||
|
var field = external_jQuery_default()("[name=\"".concat(_this.container.data('dropzone-field'), "\"]"));
|
|||
|
|
|||
|
if (field.length) {
|
|||
|
_this.sortable = new sortable_esm/* default */.ZP(_this.container.get(0), {
|
|||
|
animation: 150,
|
|||
|
// forceFallback: true,
|
|||
|
setData: function setData(dataTransfer, target) {
|
|||
|
target = external_jQuery_default()(target);
|
|||
|
var uri = encodeURI(target.find('.dz-filename').text());
|
|||
|
var shortcode = UriToMarkdown(uri);
|
|||
|
|
|||
|
_this.dropzone.disable();
|
|||
|
|
|||
|
target.addClass('hide-backface');
|
|||
|
dataTransfer.effectAllowed = 'copy';
|
|||
|
dataTransfer.setData('text', shortcode);
|
|||
|
},
|
|||
|
onSort: function onSort() {
|
|||
|
var names = [];
|
|||
|
|
|||
|
_this.container.find('[data-dz-name]').each(function (index, file) {
|
|||
|
file = external_jQuery_default()(file);
|
|||
|
var name = file.text().trim();
|
|||
|
names.push(name);
|
|||
|
});
|
|||
|
|
|||
|
field.val(names.join(','));
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
return _this;
|
|||
|
}
|
|||
|
|
|||
|
media_createClass(PageMedia, [{
|
|||
|
key: "fetchMedia",
|
|||
|
value: function fetchMedia() {
|
|||
|
var _this2 = this;
|
|||
|
|
|||
|
var order = this.container.closest('.form-field').find('[name="data[header][media_order]"]').val();
|
|||
|
var body = {
|
|||
|
uri: this.getURI(),
|
|||
|
order: order
|
|||
|
};
|
|||
|
var url = this.urls.fetch;
|
|||
|
utils_request(url, {
|
|||
|
method: 'post',
|
|||
|
body: body
|
|||
|
}, function (response) {
|
|||
|
var results = response.results;
|
|||
|
Object.keys(results).forEach(function (name) {
|
|||
|
var data = results[name];
|
|||
|
var mock = {
|
|||
|
name: name,
|
|||
|
size: data.size,
|
|||
|
accepted: true,
|
|||
|
extras: data
|
|||
|
};
|
|||
|
|
|||
|
_this2.dropzone.files.push(mock);
|
|||
|
|
|||
|
_this2.dropzone.options.addedfile.call(_this2.dropzone, mock);
|
|||
|
|
|||
|
_this2.dropzone.options.thumbnail.call(_this2.dropzone, mock, data.url);
|
|||
|
});
|
|||
|
|
|||
|
_this2.updateThumbsSize();
|
|||
|
|
|||
|
_this2.container.find('.dz-preview').prop('draggable', 'true');
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "onDropzoneSending",
|
|||
|
value: function onDropzoneSending(file, xhr, formData) {
|
|||
|
/*
|
|||
|
// Cannot call super because Safari and IE API don't implement `delete`
|
|||
|
super.onDropzoneSending(file, xhr, formData);
|
|||
|
formData.delete('task');
|
|||
|
*/
|
|||
|
formData.append('name', this.options.dotNotation || file.name);
|
|||
|
formData.append('admin-nonce', external_GravAdmin_namespaceObject.config.admin_nonce);
|
|||
|
formData.append('uri', this.getURI());
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "onDropzoneComplete",
|
|||
|
value: function onDropzoneComplete(file) {
|
|||
|
media_get(media_getPrototypeOf(PageMedia.prototype), "onDropzoneComplete", this).call(this, file);
|
|||
|
|
|||
|
if (this.sortable) {
|
|||
|
this.sortable.options.onSort();
|
|||
|
} // accepted
|
|||
|
|
|||
|
|
|||
|
this.updateThumbsSize();
|
|||
|
this.updateMediaCount();
|
|||
|
external_jQuery_default()('.dz-preview').prop('draggable', 'true');
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "onDropzoneAddedFile",
|
|||
|
value: function onDropzoneAddedFile(file) {
|
|||
|
for (var _len = arguments.length, extra = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
|
|||
|
extra[_key - 1] = arguments[_key];
|
|||
|
}
|
|||
|
|
|||
|
media_get(media_getPrototypeOf(PageMedia.prototype), "onDropzoneAddedFile", this).call(this, file, extra);
|
|||
|
|
|||
|
this.updateThumbsSize();
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "onDropzoneRemovedFile",
|
|||
|
value: function onDropzoneRemovedFile(file) {
|
|||
|
var _get2;
|
|||
|
|
|||
|
for (var _len2 = arguments.length, extra = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {
|
|||
|
extra[_key2 - 1] = arguments[_key2];
|
|||
|
}
|
|||
|
|
|||
|
(_get2 = media_get(media_getPrototypeOf(PageMedia.prototype), "onDropzoneRemovedFile", this)).call.apply(_get2, [this, file].concat(extra));
|
|||
|
|
|||
|
this.updateMediaCount();
|
|||
|
|
|||
|
if (this.sortable) {
|
|||
|
this.sortable.options.onSort();
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "updateThumbsSize",
|
|||
|
value: function updateThumbsSize() {
|
|||
|
var status = JSON.parse(cookies.get('grav-admin-pagemedia') || '{}');
|
|||
|
|
|||
|
if (status.width) {
|
|||
|
var input = this.container.closest('.pagemedia-field').find('.media-resizer');
|
|||
|
updateMediaSizes(input, status.width, false);
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "updateMediaCount",
|
|||
|
value: function updateMediaCount() {
|
|||
|
var element = this.container.closest('.pagemedia-field').find('[data-pagemedia-count]');
|
|||
|
element.text("(".concat(this.dropzone.files.length, ")"));
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "attachDragDrop",
|
|||
|
value: function attachDragDrop() {
|
|||
|
var _this3 = this;
|
|||
|
|
|||
|
this.container.delegate('[data-dz-insert]', 'click', function (e) {
|
|||
|
var target = external_jQuery_default()(e.currentTarget).parent('.dz-preview').find('.dz-filename');
|
|||
|
var editor = editor_Instance.editors.filter(function (index, editor) {
|
|||
|
return external_jQuery_default()(editor).attr('name') === 'data[content]';
|
|||
|
});
|
|||
|
|
|||
|
if (editor.length) {
|
|||
|
editor = editor.data('codemirror');
|
|||
|
editor.focus();
|
|||
|
var filename = encodeURI(target.text());
|
|||
|
var shortcode = UriToMarkdown(filename);
|
|||
|
editor.doc.replaceSelection(shortcode);
|
|||
|
}
|
|||
|
});
|
|||
|
this.container.delegate('[data-dz-view]', 'mouseenter', function (e) {
|
|||
|
var target = external_jQuery_default()(e.currentTarget);
|
|||
|
var file = target.parent('.dz-preview').find('.dz-filename');
|
|||
|
var filename = encodeURI(file.text());
|
|||
|
var URL = target.closest('[data-media-path]').data('media-path');
|
|||
|
|
|||
|
var original = _this3.dropzone.files.filter(function (file) {
|
|||
|
return encodeURI(file.name) === filename;
|
|||
|
}).shift();
|
|||
|
|
|||
|
original = original && (original.extras && original.extras.original || encodeURI(original.name));
|
|||
|
target.attr('href', "".concat(URL, "/").concat(original));
|
|||
|
});
|
|||
|
this.container.delegate('[data-dz-metadata]', 'click', function (e) {
|
|||
|
e.preventDefault();
|
|||
|
var target = external_jQuery_default()(e.currentTarget);
|
|||
|
var file = target.parent('.dz-preview').find('.dz-filename');
|
|||
|
var filename = encodeURI(file.text());
|
|||
|
var cleanName = file.text().replace('<', '<').replace('>', '>');
|
|||
|
var fileObj = _this3.dropzone.files.filter(function (file) {
|
|||
|
return file.name === __webpack_require__.g.decodeURI(filename);
|
|||
|
}).shift() || {};
|
|||
|
|
|||
|
if (!fileObj.extras) {
|
|||
|
fileObj.extras = {
|
|||
|
metadata: []
|
|||
|
};
|
|||
|
}
|
|||
|
|
|||
|
if (Array.isArray(fileObj.extras.metadata) && !fileObj.extras.metadata.length) {
|
|||
|
fileObj.extras.metadata = {
|
|||
|
'': "".concat(cleanName, ".meta.yaml doesn't exist")
|
|||
|
};
|
|||
|
}
|
|||
|
|
|||
|
fileObj = fileObj.extras;
|
|||
|
var modal_element = external_jQuery_default()('body').find('[data-remodal-id="metadata"]');
|
|||
|
var modal = (external_jQuery_default()).remodal.lookup[modal_element.data('remodal')];
|
|||
|
modal_element.find('h1 strong').html(cleanName);
|
|||
|
|
|||
|
if (fileObj.url) {
|
|||
|
modal_element.find('.meta-preview').html("<img src=\"".concat(fileObj.url, "\" />"));
|
|||
|
}
|
|||
|
|
|||
|
var container = modal_element.find('.meta-content').html('<ul />').find('ul');
|
|||
|
Object.keys(fileObj.metadata).forEach(function (meta) {
|
|||
|
var cleanMeta = fileObj.metadata[meta].replace('<', '<').replace('>', '>');
|
|||
|
container.append("<li><strong>".concat(meta ? meta + ':' : '', "</strong> ").concat(cleanMeta, "</li>"));
|
|||
|
});
|
|||
|
modal.open();
|
|||
|
});
|
|||
|
this.container.delegate('.dz-preview', 'dragstart', function (e) {
|
|||
|
var target = external_jQuery_default()(e.currentTarget);
|
|||
|
var uri = encodeURI(target.find('.dz-filename').text());
|
|||
|
var shortcode = UriToMarkdown(uri);
|
|||
|
|
|||
|
_this3.dropzone.disable();
|
|||
|
|
|||
|
target.addClass('hide-backface');
|
|||
|
e.originalEvent.dataTransfer.effectAllowed = 'copy';
|
|||
|
e.originalEvent.dataTransfer.setData('text', shortcode);
|
|||
|
});
|
|||
|
this.container.delegate('.dz-preview', 'dragend', function (e) {
|
|||
|
var target = external_jQuery_default()(e.currentTarget);
|
|||
|
|
|||
|
_this3.dropzone.enable();
|
|||
|
|
|||
|
target.removeClass('hide-backface');
|
|||
|
});
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return PageMedia;
|
|||
|
}(FilesField);
|
|||
|
|
|||
|
|
|||
|
var updateMediaSizes = function updateMediaSizes(input, width) {
|
|||
|
var store = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;
|
|||
|
var status = JSON.parse(cookies.get('grav-admin-pagemedia') || '{}');
|
|||
|
var height = 150 * width / 200;
|
|||
|
var media = input.closest('.pagemedia-field').find('.dz-details, [data-dz-thumbnail]');
|
|||
|
media.css({
|
|||
|
width: width,
|
|||
|
height: height
|
|||
|
});
|
|||
|
|
|||
|
if (store) {
|
|||
|
var data = Object.assign({}, status, {
|
|||
|
width: width
|
|||
|
});
|
|||
|
cookies.set('grav-admin-pagemedia', JSON.stringify(data), {
|
|||
|
expires: Infinity
|
|||
|
});
|
|||
|
}
|
|||
|
};
|
|||
|
var updateMediaCollapseStatus = function updateMediaCollapseStatus(element) {
|
|||
|
var store = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
|
|||
|
var status = JSON.parse(cookies.get('grav-admin-pagemedia') || '{}');
|
|||
|
element = external_jQuery_default()(element);
|
|||
|
var icon = element.find('i.fa');
|
|||
|
var container = element.closest('.pagemedia-field');
|
|||
|
var panel = container.find('.form-data');
|
|||
|
var slider = container.find('.media-resizer').parent();
|
|||
|
var isCollapsed = !icon.hasClass('fa-chevron-down');
|
|||
|
var collapsed = !isCollapsed;
|
|||
|
icon.removeClass('fa-chevron-down fa-chevron-right').addClass(isCollapsed ? 'fa-chevron-down' : 'fa-chevron-right');
|
|||
|
slider[isCollapsed ? 'removeClass' : 'addClass']('hidden');
|
|||
|
panel[isCollapsed ? 'slideDown' : 'slideUp']();
|
|||
|
|
|||
|
if (store) {
|
|||
|
var data = Object.assign({}, status, {
|
|||
|
collapsed: collapsed
|
|||
|
});
|
|||
|
cookies.set('grav-admin-pagemedia', JSON.stringify(data), {
|
|||
|
expires: Infinity
|
|||
|
});
|
|||
|
}
|
|||
|
};
|
|||
|
external_jQuery_default()(document).on('input', '.media-resizer', function (event) {
|
|||
|
var target = external_jQuery_default()(event.currentTarget);
|
|||
|
var width = target.val();
|
|||
|
updateMediaSizes(target, width);
|
|||
|
});
|
|||
|
external_jQuery_default()(document).on('click', '.media-collapser', function (event) {
|
|||
|
updateMediaCollapseStatus(event.currentTarget);
|
|||
|
});
|
|||
|
external_jQuery_default()(document).ready(function () {
|
|||
|
var status = JSON.parse(cookies.get('grav-admin-pagemedia') || '{}');
|
|||
|
|
|||
|
if (status.width) {
|
|||
|
external_jQuery_default()('.media-resizer').each(function (index, input) {
|
|||
|
input = external_jQuery_default()(input);
|
|||
|
updateMediaSizes(input, status.width, false);
|
|||
|
});
|
|||
|
}
|
|||
|
});
|
|||
|
var media_Instance = new PageMedia();
|
|||
|
;// CONCATENATED MODULE: ./app/pages/page/multilang.js
|
|||
|
|
|||
|
external_jQuery_default()('[name="task"][value="saveas"], [name="task"][value="switchlanguage"]').on('mousedown touchstart', function (event) {
|
|||
|
var fields = ['lang', 'redirect'];
|
|||
|
var element = external_jQuery_default()(event.currentTarget);
|
|||
|
var form = external_jQuery_default()("#".concat(element.attr('form')));
|
|||
|
|
|||
|
if (!form.length) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
fields.forEach(function (field) {
|
|||
|
var value = element.attr(field);
|
|||
|
|
|||
|
if (!value) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var input = form.find("[name=\"data[".concat(field, "]\"]"));
|
|||
|
|
|||
|
if (!input.length) {
|
|||
|
input = external_jQuery_default()("<input type=\"hidden\" name=\"data[".concat(field, "]\" value=\"\" />"));
|
|||
|
form.append(input);
|
|||
|
}
|
|||
|
|
|||
|
input.val(value);
|
|||
|
});
|
|||
|
return true;
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/pages/page/index.js
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var page_switcher = external_jQuery_default()('input[type="radio"][name="mode-switch"]');
|
|||
|
|
|||
|
if (page_switcher) {
|
|||
|
var page_link = page_switcher.closest(':checked').data('leave-url');
|
|||
|
var fakeLink = external_jQuery_default()("<a href=\"".concat(page_link, "\" />"));
|
|||
|
page_switcher.parent().append(fakeLink);
|
|||
|
page_switcher.siblings('label').on('mousedown touchdown', function (event) {
|
|||
|
event.preventDefault(); // let remodal = $.remodal.lookup[$('[data-remodal-id="changes"]').data('remodal')];
|
|||
|
|
|||
|
var confirm = external_jQuery_default()('[data-remodal-id="changes"] [data-leave-action="continue"]');
|
|||
|
confirm.one('click', function () {
|
|||
|
external_jQuery_default()(__webpack_require__.g).on('beforeunload._grav');
|
|||
|
fakeLink.off('click._grav');
|
|||
|
external_jQuery_default()(event.target).trigger('click');
|
|||
|
});
|
|||
|
fakeLink.trigger('click._grav');
|
|||
|
});
|
|||
|
page_switcher.on('change', function (event) {
|
|||
|
var radio = external_jQuery_default()(event.target);
|
|||
|
page_link = radio.data('leave-url');
|
|||
|
setTimeout(function () {
|
|||
|
return fakeLink.attr('href', page_link).get(0).click();
|
|||
|
}, 5);
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
/* harmony default export */ const page = ({
|
|||
|
Media: {
|
|||
|
PageMedia: PageMedia,
|
|||
|
PageMediaInstances: media_Instance
|
|||
|
}
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/pages/index.js
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var pad = function pad(n, s) {
|
|||
|
return "000".concat(n).substr(-s);
|
|||
|
}; // Pages Ordering
|
|||
|
|
|||
|
|
|||
|
var Ordering = null;
|
|||
|
var orderingElement = external_jQuery_default()('#ordering');
|
|||
|
|
|||
|
if (orderingElement.length) {
|
|||
|
Ordering = new sortable_esm/* default */.ZP(orderingElement.get(0), {
|
|||
|
filter: '.ignore',
|
|||
|
onUpdate: function onUpdate() {
|
|||
|
/* Old single page index behavior
|
|||
|
let item = $(event.item);
|
|||
|
let index = orderingElement.children().index(item) + 1;
|
|||
|
$('[data-order]').val(index);
|
|||
|
*/
|
|||
|
var indexes = [];
|
|||
|
var children = orderingElement.children();
|
|||
|
var padZero = (children.length + '').split('').length;
|
|||
|
children.each(function (index, item) {
|
|||
|
item = external_jQuery_default()(item);
|
|||
|
indexes.push(item.data('id'));
|
|||
|
item.find('.page-order').text("".concat(pad(index + 1, padZero), "."));
|
|||
|
});
|
|||
|
external_jQuery_default()('[data-order]').val(indexes.join(','));
|
|||
|
}
|
|||
|
});
|
|||
|
external_jQuery_default()(document).on('input', '[name="data[folder]"]', function (event) {
|
|||
|
var target = external_jQuery_default()(event.currentTarget);
|
|||
|
var activeOrder = external_jQuery_default()('[data-id][data-active-id]');
|
|||
|
activeOrder.data('id', target.val());
|
|||
|
Ordering.options.onUpdate();
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
/* harmony default export */ const pages = ({
|
|||
|
Ordering: Ordering,
|
|||
|
Page: page,
|
|||
|
PageFilters: {
|
|||
|
PageFilters: PagesFilter,
|
|||
|
Instance: filter_Instance
|
|||
|
}
|
|||
|
});
|
|||
|
// EXTERNAL MODULE: ./node_modules/immutable/dist/immutable.es.js
|
|||
|
var immutable_es = __webpack_require__(35369);
|
|||
|
// EXTERNAL MODULE: ./node_modules/immutablediff/src/diff.js
|
|||
|
var src_diff = __webpack_require__(64847);
|
|||
|
var diff_default = /*#__PURE__*/__webpack_require__.n(src_diff);
|
|||
|
;// CONCATENATED MODULE: ./app/forms/state.js
|
|||
|
function state_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function state_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 state_createClass(Constructor, protoProps, staticProps) { if (protoProps) state_defineProperties(Constructor.prototype, protoProps); if (staticProps) state_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var FormLoadState = {};
|
|||
|
var DOMBehaviors = {
|
|||
|
attach: function attach() {
|
|||
|
this.preventUnload();
|
|||
|
this.preventClickAway();
|
|||
|
},
|
|||
|
preventUnload: function preventUnload() {
|
|||
|
var selector = '[name="task"][value^="save"], [data-delete-action], [data-flex-safe-action]';
|
|||
|
|
|||
|
if (external_jQuery_default()._data(window, 'events') && (external_jQuery_default()._data(window, 'events').beforeunload || []).filter(function (event) {
|
|||
|
return event.namespace === '_grav';
|
|||
|
}).length) {
|
|||
|
return;
|
|||
|
} // Allow some elements to leave the page without native confirmation
|
|||
|
|
|||
|
|
|||
|
external_jQuery_default()(selector).on('click._grav', function (event) {
|
|||
|
external_jQuery_default()(__webpack_require__.g).off('beforeunload');
|
|||
|
}); // Catch browser uri change / refresh attempt and stop it if the form state is dirty
|
|||
|
|
|||
|
external_jQuery_default()(__webpack_require__.g).on('beforeunload._grav', function () {
|
|||
|
if (state_Instance.equals() === false) {
|
|||
|
return 'You have made changes on this page that you have not yet confirmed. If you navigate away from this page you will lose your unsaved changes.';
|
|||
|
}
|
|||
|
});
|
|||
|
},
|
|||
|
preventClickAway: function preventClickAway() {
|
|||
|
var selector = 'a[href]:not([href^="#"]):not([target="_blank"]):not([href^="javascript:"])';
|
|||
|
|
|||
|
if (external_jQuery_default()._data(external_jQuery_default()(selector).get(0), 'events') && (external_jQuery_default()._data(external_jQuery_default()(selector).get(0), 'events').click || []).filter(function (event) {
|
|||
|
return event.namespace === '_grav';
|
|||
|
})) {
|
|||
|
return;
|
|||
|
} // Prevent clicking away if the form state is dirty
|
|||
|
// instead, display a confirmation before continuing
|
|||
|
|
|||
|
|
|||
|
external_jQuery_default()(selector).on('click._grav', function (event) {
|
|||
|
var isClean = state_Instance.equals();
|
|||
|
|
|||
|
if (isClean === null || isClean) {
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
event.preventDefault();
|
|||
|
var destination = external_jQuery_default()(this).attr('href');
|
|||
|
var modal = external_jQuery_default()('[data-remodal-id="changes"]');
|
|||
|
var lookup = (external_jQuery_default()).remodal.lookup[modal.data('remodal')];
|
|||
|
var buttons = external_jQuery_default()('a.button', modal);
|
|||
|
|
|||
|
var handler = function handler(event) {
|
|||
|
event.preventDefault();
|
|||
|
var action = external_jQuery_default()(this).data('leave-action');
|
|||
|
buttons.off('click', handler);
|
|||
|
lookup.close();
|
|||
|
|
|||
|
if (action === 'continue') {
|
|||
|
external_jQuery_default()(__webpack_require__.g).off('beforeunload');
|
|||
|
__webpack_require__.g.location.href = destination;
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
buttons.on('click', handler);
|
|||
|
lookup.open();
|
|||
|
});
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
var FormState = /*#__PURE__*/function () {
|
|||
|
function FormState() {
|
|||
|
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {
|
|||
|
ignore: [],
|
|||
|
form_id: 'blueprints'
|
|||
|
};
|
|||
|
|
|||
|
state_classCallCheck(this, FormState);
|
|||
|
|
|||
|
this.options = options;
|
|||
|
this.refresh();
|
|||
|
|
|||
|
if (!this.form || !this.fields.length) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
FormLoadState = this.collect();
|
|||
|
this.loadState = FormLoadState;
|
|||
|
DOMBehaviors.attach();
|
|||
|
}
|
|||
|
|
|||
|
state_createClass(FormState, [{
|
|||
|
key: "refresh",
|
|||
|
value: function refresh() {
|
|||
|
this.form = external_jQuery_default()("form#".concat(this.options.form_id)).filter(':noparents(.remodal)');
|
|||
|
this.fields = external_jQuery_default()("form#".concat(this.options.form_id, " *, [form=\"").concat(this.options.form_id, "\"]")).filter(':input:not(.no-form)').filter(':noparents(.remodal)');
|
|||
|
return this;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "collect",
|
|||
|
value: function collect() {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
if (!this.form || !this.fields.length) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var values = {};
|
|||
|
this.refresh().fields.each(function (index, field) {
|
|||
|
field = external_jQuery_default()(field);
|
|||
|
var name = field.prop('name');
|
|||
|
var type = field.prop('type');
|
|||
|
var tag = field.prop('tagName').toLowerCase();
|
|||
|
var value;
|
|||
|
|
|||
|
if (name.startsWith('toggleable_') || name === 'data[lang]' || name === 'data[redirect]') {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
switch (type) {
|
|||
|
case 'checkbox':
|
|||
|
value = field.is(':checked');
|
|||
|
break;
|
|||
|
|
|||
|
case 'radio':
|
|||
|
if (!field.is(':checked')) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
value = field.val();
|
|||
|
break;
|
|||
|
|
|||
|
default:
|
|||
|
value = field.val();
|
|||
|
}
|
|||
|
|
|||
|
if (tag === 'select' && value === null) {
|
|||
|
value = '';
|
|||
|
}
|
|||
|
|
|||
|
if (Array.isArray(value)) {
|
|||
|
value = value.join('|');
|
|||
|
}
|
|||
|
|
|||
|
if (name && !~_this.options.ignore.indexOf(name)) {
|
|||
|
values[name] = value;
|
|||
|
}
|
|||
|
});
|
|||
|
return immutable_es/* default.OrderedMap */.ZP.OrderedMap(values);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "diff",
|
|||
|
value: function diff() {
|
|||
|
return diff_default()(FormLoadState, this.collect());
|
|||
|
} // When the form doesn't exist or there are no fields, `equals` returns `null`
|
|||
|
// for this reason, _NEVER_ check with !Instance.equals(), use Instance.equals() === false
|
|||
|
|
|||
|
}, {
|
|||
|
key: "equals",
|
|||
|
value: function equals() {
|
|||
|
if (!this.form || !this.fields.length) {
|
|||
|
return null;
|
|||
|
}
|
|||
|
|
|||
|
return immutable_es/* default.is */.ZP.is(FormLoadState, this.collect());
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return FormState;
|
|||
|
}();
|
|||
|
|
|||
|
|
|||
|
;
|
|||
|
var state_Instance = new FormState();
|
|||
|
|
|||
|
;// CONCATENATED MODULE: ./app/forms/form.js
|
|||
|
function form_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function form_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 form_createClass(Constructor, protoProps, staticProps) { if (protoProps) form_defineProperties(Constructor.prototype, protoProps); if (staticProps) form_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
/* Dependencies for checking if changes happened since load on a form
|
|||
|
import toastr from '../utils/toastr';
|
|||
|
import { translations } from 'grav-config';
|
|||
|
import { Instance as FormState } from './state';
|
|||
|
*/
|
|||
|
|
|||
|
var Form = /*#__PURE__*/function () {
|
|||
|
function Form(form) {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
form_classCallCheck(this, Form);
|
|||
|
|
|||
|
this.form = external_jQuery_default()(form);
|
|||
|
|
|||
|
if (!this.form.length || this.form.prop('tagName').toLowerCase() !== 'form') {
|
|||
|
return;
|
|||
|
}
|
|||
|
/* Option for not saving while nothing in a form has changed
|
|||
|
this.form.on('submit', (event) => {
|
|||
|
if (FormState.equals()) {
|
|||
|
event.preventDefault();
|
|||
|
toastr.info(translations.PLUGIN_ADMIN.NOTHING_TO_SAVE);
|
|||
|
}
|
|||
|
}); */
|
|||
|
|
|||
|
|
|||
|
this._attachShortcuts();
|
|||
|
|
|||
|
this._attachToggleables();
|
|||
|
|
|||
|
this._attachDisabledFields();
|
|||
|
|
|||
|
this._submitUncheckedFields();
|
|||
|
|
|||
|
this.observer = new MutationObserver(this.addedNodes);
|
|||
|
this.form.each(function (index, form) {
|
|||
|
return _this.observer.observe(form, {
|
|||
|
subtree: true,
|
|||
|
childList: true
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
form_createClass(Form, [{
|
|||
|
key: "_attachShortcuts",
|
|||
|
value: function _attachShortcuts() {
|
|||
|
// CTRL + S / CMD + S - shortcut for [Save] when available
|
|||
|
var saveTask = external_jQuery_default()('#titlebar [name="task"][value="save"][form="blueprints"]');
|
|||
|
|
|||
|
if (saveTask.length) {
|
|||
|
external_jQuery_default()(__webpack_require__.g).on('keydown', function (event) {
|
|||
|
var key = String.fromCharCode(event.which).toLowerCase();
|
|||
|
|
|||
|
if (!event.shiftKey && (event.ctrlKey && !event.altKey || event.metaKey) && key === 's') {
|
|||
|
event.preventDefault();
|
|||
|
saveTask.click();
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "_attachToggleables",
|
|||
|
value: function _attachToggleables() {
|
|||
|
var query = '[data-grav-field="toggleable"] input[type="checkbox"]';
|
|||
|
this.form.on('change', query, function (event) {
|
|||
|
var toggle = external_jQuery_default()(event.target);
|
|||
|
var enabled = toggle.is(':checked');
|
|||
|
var parent = toggle.closest('.form-field');
|
|||
|
var label = parent.find('label.toggleable');
|
|||
|
var fields = parent.find('.form-data');
|
|||
|
var inputs = fields.find('input, select, textarea, button');
|
|||
|
label.add(fields).css('opacity', enabled ? '' : 0.7);
|
|||
|
inputs.map(function (index, input) {
|
|||
|
var isSelectize = input.selectize;
|
|||
|
input = external_jQuery_default()(input);
|
|||
|
|
|||
|
if (isSelectize) {
|
|||
|
isSelectize[enabled ? 'enable' : 'disable']();
|
|||
|
} else {
|
|||
|
input.prop('disabled', !enabled);
|
|||
|
}
|
|||
|
});
|
|||
|
});
|
|||
|
this.form.find(query).trigger('change');
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "_attachDisabledFields",
|
|||
|
value: function _attachDisabledFields() {
|
|||
|
var prefix = '.form-field-toggleable .form-data';
|
|||
|
var query = [];
|
|||
|
['input', 'select', 'label[for]', 'textarea', '.selectize-control'].forEach(function (item) {
|
|||
|
query.push("".concat(prefix, " ").concat(item));
|
|||
|
});
|
|||
|
this.form.on('mousedown', query.join(', '), function (event) {
|
|||
|
var input = external_jQuery_default()(event.target);
|
|||
|
var isFor = input.prop('for');
|
|||
|
var isSelectize = (input.hasClass('selectize-control') || input.parents('.selectize-control')).length;
|
|||
|
|
|||
|
if (isFor) {
|
|||
|
input = external_jQuery_default()("[id=\"".concat(isFor, "\"]"));
|
|||
|
}
|
|||
|
|
|||
|
if (isSelectize) {
|
|||
|
input = input.closest('.selectize-control').siblings('select[name]');
|
|||
|
}
|
|||
|
|
|||
|
if (!input.prop('disabled')) {
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
var toggle = input.closest('.form-field').find('[data-grav-field="toggleable"] input[type="checkbox"]');
|
|||
|
toggle.trigger('click');
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "_submitUncheckedFields",
|
|||
|
value: function _submitUncheckedFields() {
|
|||
|
var submitted = false;
|
|||
|
this.form.each(function (index, form) {
|
|||
|
form = external_jQuery_default()(form);
|
|||
|
form.on('submit', function () {
|
|||
|
// workaround for MS Edge, submitting multiple forms at the same time
|
|||
|
if (submitted) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
var formId = form.attr('id');
|
|||
|
var unchecked = form.find('input[type="checkbox"]:not(:checked):not(:disabled)');
|
|||
|
var submit = form.find('[type="submit"]').add("[form=\"".concat(formId, "\"][type=\"submit\"]"));
|
|||
|
|
|||
|
if (!unchecked.length) {
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
submit.addClass('pointer-events-disabled');
|
|||
|
unchecked.each(function (index, element) {
|
|||
|
element = external_jQuery_default()(element);
|
|||
|
var name = element.prop('name');
|
|||
|
var fake = external_jQuery_default()("<input type=\"hidden\" name=\"".concat(name, "\" value=\"0\" />"));
|
|||
|
form.append(fake);
|
|||
|
});
|
|||
|
submitted = true;
|
|||
|
return true;
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "addedNodes",
|
|||
|
value: function addedNodes(mutations) {
|
|||
|
var _this2 = this;
|
|||
|
|
|||
|
mutations.forEach(function (mutation) {
|
|||
|
if (mutation.type !== 'childList') {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
if (mutation.addedNodes) {
|
|||
|
external_jQuery_default()('body').trigger('mutation._grav', mutation.target, mutation, _this2);
|
|||
|
}
|
|||
|
|
|||
|
if (mutation.removedNodes) {
|
|||
|
external_jQuery_default()('body').trigger('mutation_removed._grav', {
|
|||
|
target: mutation.target,
|
|||
|
mutation: mutation
|
|||
|
}, _this2);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return Form;
|
|||
|
}();
|
|||
|
|
|||
|
|
|||
|
var form_Instance = new Form('form#blueprints');
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/filepicker.js
|
|||
|
function filepicker_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function filepicker_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 filepicker_createClass(Constructor, protoProps, staticProps) { if (protoProps) filepicker_defineProperties(Constructor.prototype, protoProps); if (staticProps) filepicker_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
// const insertTextAt = (string, index, text) => [string.slice(0, index), text, string.slice(index)].join('');
|
|||
|
|
|||
|
var FilePickerField = /*#__PURE__*/function () {
|
|||
|
function FilePickerField(options) {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
filepicker_classCallCheck(this, FilePickerField);
|
|||
|
|
|||
|
this.items = external_jQuery_default()();
|
|||
|
this.options = Object.assign({}, this.defaults, options);
|
|||
|
external_jQuery_default()('[data-grav-filepicker]').each(function (index, element) {
|
|||
|
return _this.addItem(element);
|
|||
|
});
|
|||
|
external_jQuery_default()('body').on('mutation._grav', this._onAddedNodes.bind(this));
|
|||
|
}
|
|||
|
|
|||
|
filepicker_createClass(FilePickerField, [{
|
|||
|
key: "_onAddedNodes",
|
|||
|
value: function _onAddedNodes(event, target
|
|||
|
/* , record, instance */
|
|||
|
) {
|
|||
|
var _this2 = this;
|
|||
|
|
|||
|
var fields = external_jQuery_default()(target).find('[data-grav-filepicker]');
|
|||
|
|
|||
|
if (!fields.length) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
fields.each(function (index, field) {
|
|||
|
field = external_jQuery_default()(field);
|
|||
|
|
|||
|
if (!~_this2.items.index(field)) {
|
|||
|
_this2.addItem(field);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "addItem",
|
|||
|
value: function addItem(element) {
|
|||
|
element = external_jQuery_default()(element);
|
|||
|
this.items = this.items.add(element);
|
|||
|
var tag = element.prop('tagName').toLowerCase();
|
|||
|
var isInput = tag === 'input' || tag === 'select';
|
|||
|
var field = isInput ? element : element.find('input, select');
|
|||
|
var folder = '';
|
|||
|
var thumbs = {};
|
|||
|
var onDemand = field.closest('[data-ondemand]').length > 0;
|
|||
|
|
|||
|
if (!field.length || field.get(0).selectize) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var getData = function getData(field, callback) {
|
|||
|
var mode = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'all';
|
|||
|
var url = external_GravAdmin_namespaceObject.config.current_url + ".json/task".concat(external_GravAdmin_namespaceObject.config.param_sep, "getFilesInFolder");
|
|||
|
var parent = field.closest('[data-grav-filepicker]');
|
|||
|
var name = parent.data('name');
|
|||
|
var value = parent.data('value');
|
|||
|
var params = JSON.stringify(external_GravAdmin_namespaceObject.uri_params || '{}');
|
|||
|
utils_request(url, {
|
|||
|
method: 'post',
|
|||
|
body: {
|
|||
|
name: name,
|
|||
|
params: params
|
|||
|
}
|
|||
|
}, function (response) {
|
|||
|
if (typeof response.files === 'undefined') {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var data = [];
|
|||
|
thumbs = response.thumbs || {};
|
|||
|
|
|||
|
for (var i = 0; i < response.files.length; i++) {
|
|||
|
if (mode === 'selected' && response.files[i] !== value) {
|
|||
|
continue;
|
|||
|
}
|
|||
|
|
|||
|
data.push({
|
|||
|
'name': response.files[i],
|
|||
|
'status': 'available',
|
|||
|
thumb: thumbs[response.files[i]] || ''
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
for (var _i = 0; _i < response.pending.length; _i++) {
|
|||
|
if (mode === 'selected' && response.pending[_i] !== value) {
|
|||
|
continue;
|
|||
|
}
|
|||
|
|
|||
|
data.push({
|
|||
|
'name': response.pending[_i],
|
|||
|
'status': 'pending',
|
|||
|
thumb: thumbs[response.pending[_i]] || ''
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
folder = response.folder;
|
|||
|
callback(data, value);
|
|||
|
});
|
|||
|
};
|
|||
|
|
|||
|
var imagesPreview = field.closest('[data-preview-images]').length > 0;
|
|||
|
var selectedIsRendered = false;
|
|||
|
|
|||
|
var renderOption = function renderOption(item, escape) {
|
|||
|
var image = '';
|
|||
|
|
|||
|
if (imagesPreview && folder && (!item.status || item.status === 'available') && item.name.match(/\.(jpg|jpeg|png|gif|webp)$/i)) {
|
|||
|
// const fallback2x = insertTextAt(`${config.base_url_relative}/../${folder}/${item.name}`, -4, '@2x');
|
|||
|
// const fallback3x = insertTextAt(`${config.base_url_relative}/../${folder}/${item.name}`, -4, '@3x');
|
|||
|
var source = thumbs[item.name] || "".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/../").concat(folder, "/").concat(item.name); // onerror="if(this.src==='${fallback2x}'){this.src='${fallback3x}';}else{this.src='${fallback2x}'}"
|
|||
|
|
|||
|
image = "<img class=\"filepicker-field-image\" src=\"".concat(source, "\" />");
|
|||
|
}
|
|||
|
|
|||
|
return "<div>\n <span class=\"title\">\n ".concat(image, " <span class=\"name filepicker-field-name\">").concat(escape(item.name), "</span>\n </span>\n </div>");
|
|||
|
};
|
|||
|
|
|||
|
field.selectize({
|
|||
|
plugins: ['required-fix'],
|
|||
|
valueField: 'name',
|
|||
|
labelField: 'name',
|
|||
|
searchField: 'name',
|
|||
|
optgroups: [{
|
|||
|
$order: 1,
|
|||
|
value: 'pending',
|
|||
|
label: 'Pending'
|
|||
|
}, {
|
|||
|
$order: 2,
|
|||
|
value: 'available',
|
|||
|
label: 'Available'
|
|||
|
}],
|
|||
|
optgroupField: 'status',
|
|||
|
// lockOptgroupOrder: true,
|
|||
|
create: false,
|
|||
|
preload: false,
|
|||
|
// 'focus',
|
|||
|
render: {
|
|||
|
option: function option(item, escape) {
|
|||
|
return renderOption(item, escape);
|
|||
|
},
|
|||
|
item: function item(_item, escape) {
|
|||
|
return renderOption(_item, escape);
|
|||
|
}
|
|||
|
},
|
|||
|
onInitialize: function onInitialize() {
|
|||
|
if (!onDemand) {
|
|||
|
this.load(function (callback) {
|
|||
|
return getData(field, function (data) {
|
|||
|
return callback(data);
|
|||
|
}, 'selected');
|
|||
|
});
|
|||
|
}
|
|||
|
},
|
|||
|
onLoad: function
|
|||
|
/* data */
|
|||
|
onLoad() {
|
|||
|
if (!selectedIsRendered) {
|
|||
|
var name = this.getValue();
|
|||
|
this.updateOption(name, {
|
|||
|
name: name
|
|||
|
});
|
|||
|
selectedIsRendered = true;
|
|||
|
}
|
|||
|
},
|
|||
|
onFocus: function onFocus() {
|
|||
|
this.load(function (callback) {
|
|||
|
return getData(field, function (data) {
|
|||
|
return callback(data);
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return FilePickerField;
|
|||
|
}();
|
|||
|
|
|||
|
|
|||
|
var filepicker_Instance = new FilePickerField();
|
|||
|
;// CONCATENATED MODULE: ./app/utils/selectize-option-click.js
|
|||
|
|
|||
|
|
|||
|
selectize_default().define('option_click', function (options) {
|
|||
|
var self = this;
|
|||
|
var setup = self.setup;
|
|||
|
|
|||
|
this.setup = function () {
|
|||
|
setup.apply(self, arguments);
|
|||
|
var clicking = false; // Detect click on a .clickable
|
|||
|
|
|||
|
self.$dropdown_content.on('mousedown click', function (e) {
|
|||
|
var target = external_jQuery_default()(e.target);
|
|||
|
|
|||
|
if (target.hasClass('clickable') || target.closest('.clickable').length) {
|
|||
|
if (e.type === 'mousedown') {
|
|||
|
clicking = true;
|
|||
|
self.isFocused = false; // awful hack to defuse the document mousedown listener
|
|||
|
} else {
|
|||
|
self.isFocused = true;
|
|||
|
setTimeout(function () {
|
|||
|
clicking = false; // wait until blur has been preempted
|
|||
|
});
|
|||
|
}
|
|||
|
} else {
|
|||
|
// cleanup in case user right-clicked or dragged off the element
|
|||
|
clicking = false;
|
|||
|
self.isFocused = true;
|
|||
|
}
|
|||
|
}); // Intercept default handlers
|
|||
|
|
|||
|
self.$dropdown.off('mousedown click', '[data-selectable]').on('mousedown click', '[data-selectable]', function () {
|
|||
|
if (!clicking) {
|
|||
|
return self.onOptionSelect.apply(self, arguments);
|
|||
|
}
|
|||
|
});
|
|||
|
self.$control_input.off('blur').on('blur', function () {
|
|||
|
if (!clicking) {
|
|||
|
return self.onBlur.apply(self, arguments);
|
|||
|
}
|
|||
|
});
|
|||
|
};
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/selectize.js
|
|||
|
function selectize_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function selectize_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 selectize_createClass(Constructor, protoProps, staticProps) { if (protoProps) selectize_defineProperties(Constructor.prototype, protoProps); if (staticProps) selectize_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var PagesRoute = {
|
|||
|
option: function option(item, escape) {
|
|||
|
var label = escape(item.text).split(' ');
|
|||
|
var arrows = label.shift();
|
|||
|
var slug = label.shift();
|
|||
|
return "<div class=\"selectize-route-option\">\n <span class=\"text-grey\">".concat(arrows, "</span>\n <span>\n <span class=\"text-update\">").concat(slug.replace('(', '/').replace(')', ''), "</span>\n <span>").concat(label.join(' '), "</span>\n </span>\n </div>");
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
var SelectizeField = /*#__PURE__*/function () {
|
|||
|
function SelectizeField() {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|||
|
|
|||
|
selectize_classCallCheck(this, SelectizeField);
|
|||
|
|
|||
|
this.options = Object.assign({}, options);
|
|||
|
this.elements = [];
|
|||
|
external_jQuery_default()('[data-grav-selectize]').each(function (index, element) {
|
|||
|
return _this.add(element);
|
|||
|
});
|
|||
|
external_jQuery_default()('body').on('mutation._grav', this._onAddedNodes.bind(this));
|
|||
|
}
|
|||
|
|
|||
|
selectize_createClass(SelectizeField, [{
|
|||
|
key: "add",
|
|||
|
value: function add(element) {
|
|||
|
element = external_jQuery_default()(element);
|
|||
|
|
|||
|
if (element.closest('template').length) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
var tag = element.prop('tagName').toLowerCase();
|
|||
|
var isInput = tag === 'input' || tag === 'select';
|
|||
|
var data = (isInput ? element.closest('[data-grav-selectize]') : element).data('grav-selectize') || {};
|
|||
|
var field = isInput ? element : element.find('input, select');
|
|||
|
|
|||
|
if (field.attr('name') === 'data[route]') {
|
|||
|
data = external_jQuery_default().extend({}, data, {
|
|||
|
render: PagesRoute
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
if (!field.length || field.get(0).selectize) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var plugins = external_jQuery_default().merge(data.plugins ? data.plugins : [], ['required-fix']);
|
|||
|
field.selectize(external_jQuery_default().extend({}, data, {
|
|||
|
plugins: plugins
|
|||
|
}));
|
|||
|
this.elements.push(field.data('selectize'));
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "_onAddedNodes",
|
|||
|
value: function _onAddedNodes(event, target
|
|||
|
/* , record, instance */
|
|||
|
) {
|
|||
|
var _this2 = this;
|
|||
|
|
|||
|
var fields = external_jQuery_default()(target).find('select.fancy, input.fancy, [data-grav-selectize]').filter(function (index, element) {
|
|||
|
return !external_jQuery_default()(element).closest('template').length;
|
|||
|
});
|
|||
|
|
|||
|
if (!fields.length) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
fields.each(function (index, field) {
|
|||
|
return _this2.add(field);
|
|||
|
});
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return SelectizeField;
|
|||
|
}();
|
|||
|
|
|||
|
|
|||
|
var selectize_Instance = new SelectizeField();
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/array.js
|
|||
|
function array_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function array_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 array_createClass(Constructor, protoProps, staticProps) { if (protoProps) array_defineProperties(Constructor.prototype, protoProps); if (staticProps) array_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var body = external_jQuery_default()('body');
|
|||
|
|
|||
|
var Template = /*#__PURE__*/function () {
|
|||
|
function Template(container) {
|
|||
|
array_classCallCheck(this, Template);
|
|||
|
|
|||
|
this.container = external_jQuery_default()(container);
|
|||
|
|
|||
|
if (this.getName() === undefined) {
|
|||
|
this.container = this.container.closest('[data-grav-array-name]');
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
array_createClass(Template, [{
|
|||
|
key: "getName",
|
|||
|
value: function getName() {
|
|||
|
return this.container.data('grav-array-name') || '';
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "getKeyPlaceholder",
|
|||
|
value: function getKeyPlaceholder() {
|
|||
|
return this.container.data('grav-array-keyname') || 'Key';
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "getValuePlaceholder",
|
|||
|
value: function getValuePlaceholder() {
|
|||
|
return this.container.data('grav-array-valuename') || 'Value';
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "isValueOnly",
|
|||
|
value: function isValueOnly() {
|
|||
|
return this.container.find('[data-grav-array-mode="value_only"]:first').length || false;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "isTextArea",
|
|||
|
value: function isTextArea() {
|
|||
|
return this.container.data('grav-array-textarea') || false;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "shouldBeDisabled",
|
|||
|
value: function shouldBeDisabled() {
|
|||
|
// check for toggleables, if field is toggleable and it's not enabled, render disabled
|
|||
|
var toggle = this.container.closest('.form-field').find('[data-grav-field="toggleable"] input[type="checkbox"]');
|
|||
|
return toggle.length && toggle.is(':not(:checked)');
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "getNewRow",
|
|||
|
value: function getNewRow() {
|
|||
|
var tpl = '';
|
|||
|
var value = this.isTextArea() ? "<textarea ".concat(this.shouldBeDisabled() ? 'disabled="disabled"' : '', " data-grav-array-type=\"value\" name=\"\" placeholder=\"").concat(this.getValuePlaceholder(), "\"></textarea>") : "<input ".concat(this.shouldBeDisabled() ? 'disabled="disabled"' : '', " data-grav-array-type=\"value\" type=\"text\" name=\"\" value=\"\" placeholder=\"").concat(this.getValuePlaceholder(), "\" />");
|
|||
|
|
|||
|
if (this.isValueOnly()) {
|
|||
|
tpl += "\n <div class=\"form-row array-field-value_only\" data-grav-array-type=\"row\">\n <span data-grav-array-action=\"sort\" class=\"fa fa-bars\"></span>\n ".concat(value, "\n ");
|
|||
|
} else {
|
|||
|
tpl += "\n <div class=\"form-row\" data-grav-array-type=\"row\">\n <span data-grav-array-action=\"sort\" class=\"fa fa-bars\"></span>\n <input ".concat(this.shouldBeDisabled() ? 'disabled="disabled"' : '', " data-grav-array-type=\"key\" type=\"text\" value=\"\" placeholder=\"").concat(this.getKeyPlaceholder(), "\" />\n ").concat(value, "\n ");
|
|||
|
}
|
|||
|
|
|||
|
tpl += "\n <span data-grav-array-action=\"rem\" class=\"fa fa-minus\"></span>\n <span data-grav-array-action=\"add\" class=\"fa fa-plus\"></span>\n </div>";
|
|||
|
return tpl;
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return Template;
|
|||
|
}();
|
|||
|
|
|||
|
var ArrayField = /*#__PURE__*/function () {
|
|||
|
function ArrayField() {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
array_classCallCheck(this, ArrayField);
|
|||
|
|
|||
|
body.on('input', '[data-grav-array-type="key"], [data-grav-array-type="value"]', function (event) {
|
|||
|
return _this.actionInput(event);
|
|||
|
});
|
|||
|
body.on('click touch', '[data-grav-array-action]:not([data-grav-array-action="sort"])', function (event) {
|
|||
|
return _this.actionEvent(event);
|
|||
|
});
|
|||
|
this.arrays = external_jQuery_default()();
|
|||
|
external_jQuery_default()('[data-grav-field="array"]').each(function (index, list) {
|
|||
|
return _this.addArray(list);
|
|||
|
});
|
|||
|
external_jQuery_default()('body').on('mutation._grav', this._onAddedNodes.bind(this));
|
|||
|
}
|
|||
|
|
|||
|
array_createClass(ArrayField, [{
|
|||
|
key: "addArray",
|
|||
|
value: function addArray(list) {
|
|||
|
var _this2 = this;
|
|||
|
|
|||
|
list = external_jQuery_default()(list);
|
|||
|
list.find('[data-grav-array-type="container"]').each(function (index, container) {
|
|||
|
container = external_jQuery_default()(container);
|
|||
|
|
|||
|
if (container.data('array-sort') || container[0].hasAttribute('data-array-nosort')) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
container.data('array-sort', new sortable_esm/* default */.ZP(container.get(0), {
|
|||
|
handle: '.fa-bars',
|
|||
|
animation: 150,
|
|||
|
onUpdate: function onUpdate() {
|
|||
|
var item = container.find('[data-grav-array-type="row"]:first');
|
|||
|
|
|||
|
_this2._setTemplate(item);
|
|||
|
|
|||
|
var template = item.data('array-template');
|
|||
|
|
|||
|
_this2.refreshNames(template);
|
|||
|
}
|
|||
|
}));
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "actionInput",
|
|||
|
value: function actionInput(event) {
|
|||
|
var element = external_jQuery_default()(event.target);
|
|||
|
var type = element.data('grav-array-type');
|
|||
|
|
|||
|
this._setTemplate(element);
|
|||
|
|
|||
|
var template = element.data('array-template');
|
|||
|
var keyElement = type === 'key' ? element : element.siblings('[data-grav-array-type="key"]:first');
|
|||
|
var valueElement = type === 'value' ? element : element.siblings('[data-grav-array-type="value"]:first');
|
|||
|
var escaped_name = !template.isValueOnly() ? keyElement.val() : this.getIndexFor(element);
|
|||
|
escaped_name = escaped_name.toString().replace(/\[/g, '%5B').replace(/]/g, '%5D');
|
|||
|
var name = "".concat(template.getName(), "[").concat(escaped_name, "]");
|
|||
|
|
|||
|
if (!template.isValueOnly() && !keyElement.val() && !valueElement.val()) {
|
|||
|
valueElement.attr('name', '');
|
|||
|
} else {
|
|||
|
// valueElement.attr('name', !valueElement.val() ? template.getName() : name);
|
|||
|
valueElement.attr('name', name);
|
|||
|
}
|
|||
|
|
|||
|
this.refreshNames(template);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "actionEvent",
|
|||
|
value: function actionEvent(event) {
|
|||
|
event && event.preventDefault();
|
|||
|
var element = external_jQuery_default()(event.target);
|
|||
|
var action = element.data('grav-array-action');
|
|||
|
var container = element.parents('[data-grav-array-type="container"]');
|
|||
|
|
|||
|
this._setTemplate(element);
|
|||
|
|
|||
|
this["".concat(action, "Action")](element);
|
|||
|
var siblings = container.find('> div');
|
|||
|
container[siblings.length > 1 ? 'removeClass' : 'addClass']('one-child');
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "addAction",
|
|||
|
value: function addAction(element) {
|
|||
|
var template = element.data('array-template');
|
|||
|
var row = element.closest('[data-grav-array-type="row"]');
|
|||
|
row.after(template.getNewRow());
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "remAction",
|
|||
|
value: function remAction(element) {
|
|||
|
var template = element.data('array-template');
|
|||
|
var row = element.closest('[data-grav-array-type="row"]');
|
|||
|
var isLast = !row.siblings().length;
|
|||
|
|
|||
|
if (isLast) {
|
|||
|
var newRow = external_jQuery_default()(template.getNewRow());
|
|||
|
row.after(newRow);
|
|||
|
newRow.find('[data-grav-array-type="value"]:last').attr('name', template.getName());
|
|||
|
}
|
|||
|
|
|||
|
row.remove();
|
|||
|
this.refreshNames(template);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "refreshNames",
|
|||
|
value: function refreshNames(template) {
|
|||
|
if (!template.isValueOnly()) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var row = template.container.find('> div > [data-grav-array-type="row"]');
|
|||
|
var inputs = row.find('[name]:not([name=""])');
|
|||
|
inputs.each(function (index, input) {
|
|||
|
input = external_jQuery_default()(input);
|
|||
|
var preserved_name = input.closest('[data-grav-array-name]');
|
|||
|
var name = "".concat(preserved_name.attr('data-grav-array-name'), "[").concat(index, "]");
|
|||
|
input.attr('name', name);
|
|||
|
});
|
|||
|
|
|||
|
if (!inputs.length) {
|
|||
|
row.find('[data-grav-array-type="value"]').attr('name', template.getName());
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "getIndexFor",
|
|||
|
value: function getIndexFor(element) {
|
|||
|
var template = element.data('array-template');
|
|||
|
var row = element.closest('[data-grav-array-type="row"]');
|
|||
|
return template.container.find("".concat(template.isValueOnly() ? '> div ' : '', " > [data-grav-array-type=\"row\"]")).index(row);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "_setTemplate",
|
|||
|
value: function _setTemplate(element) {
|
|||
|
if (!element.data('array-template')) {
|
|||
|
element.data('array-template', new Template(element.closest('[data-grav-array-name]')));
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "_onAddedNodes",
|
|||
|
value: function _onAddedNodes(event, target
|
|||
|
/* , record, instance */
|
|||
|
) {
|
|||
|
var _this3 = this;
|
|||
|
|
|||
|
var arrays = external_jQuery_default()(target).find('[data-grav-field="array"]');
|
|||
|
|
|||
|
if (!arrays.length) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
arrays.each(function (index, list) {
|
|||
|
list = external_jQuery_default()(list);
|
|||
|
|
|||
|
if (!~_this3.arrays.index(list)) {
|
|||
|
_this3.addArray(list);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return ArrayField;
|
|||
|
}();
|
|||
|
|
|||
|
|
|||
|
var array_Instance = new ArrayField();
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/collections.js
|
|||
|
function collections_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function collections_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 collections_createClass(Constructor, protoProps, staticProps) { if (protoProps) collections_defineProperties(Constructor.prototype, protoProps); if (staticProps) collections_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var CollectionsField = /*#__PURE__*/function () {
|
|||
|
function CollectionsField() {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
collections_classCallCheck(this, CollectionsField);
|
|||
|
|
|||
|
this.lists = external_jQuery_default()();
|
|||
|
var body = external_jQuery_default()('body');
|
|||
|
external_jQuery_default()('[data-type="collection"]').each(function (index, list) {
|
|||
|
return _this.addList(list);
|
|||
|
});
|
|||
|
body.on('mutation._grav', this._onAddedNodes.bind(this));
|
|||
|
body.on('click', function (event) {
|
|||
|
var target = external_jQuery_default()(event.target);
|
|||
|
|
|||
|
if (!(target.is('[data-action="confirm"], [data-action="delete"]') || target.closest('[data-action="confirm"], [data-action="delete"]').length)) {
|
|||
|
CollectionsField.closeConfirmations();
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
collections_createClass(CollectionsField, [{
|
|||
|
key: "addList",
|
|||
|
value: function addList(list) {
|
|||
|
var _this2 = this;
|
|||
|
|
|||
|
list = external_jQuery_default()(list);
|
|||
|
this.lists = this.lists.add(list);
|
|||
|
list.on('click', '> .collection-actions [data-action="add"]', function (event) {
|
|||
|
return _this2.addItem(event);
|
|||
|
});
|
|||
|
list.on('click', '> ul > li > .item-actions [data-action="confirm"]', function (event) {
|
|||
|
return _this2.confirmRemove(event);
|
|||
|
});
|
|||
|
list.on('click', '> ul > li > .item-actions [data-action="delete"]', function (event) {
|
|||
|
return _this2.removeItem(event);
|
|||
|
});
|
|||
|
list.on('click', '> ul > li > .item-actions [data-action="collapse"]', function (event) {
|
|||
|
return _this2.collapseItem(event);
|
|||
|
});
|
|||
|
list.on('click', '> ul > li > .item-actions [data-action="expand"]', function (event) {
|
|||
|
return _this2.expandItem(event);
|
|||
|
});
|
|||
|
list.on('click', '> .collection-actions [data-action-sort="date"]', function (event) {
|
|||
|
return _this2.sortItems(event);
|
|||
|
});
|
|||
|
list.on('click', '> .collection-actions [data-action="collapse_all"]', function (event) {
|
|||
|
return _this2.collapseItems(event);
|
|||
|
});
|
|||
|
list.on('click', '> .collection-actions [data-action="expand_all"]', function (event) {
|
|||
|
return _this2.expandItems(event);
|
|||
|
});
|
|||
|
list.on('input change', '[data-key-observe]', function (event) {
|
|||
|
return _this2.observeKey(event);
|
|||
|
});
|
|||
|
list.find('[data-collection-holder]').each(function (index, container) {
|
|||
|
container = external_jQuery_default()(container);
|
|||
|
|
|||
|
if (container.data('collection-sort') || container[0].hasAttribute('data-collection-nosort')) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
container.data('collection-sort', new sortable_esm/* default */.ZP(container.get(0), {
|
|||
|
forceFallback: false,
|
|||
|
handle: '.collection-sort',
|
|||
|
animation: 150,
|
|||
|
onUpdate: function onUpdate() {
|
|||
|
return _this2.reindex(container);
|
|||
|
}
|
|||
|
}));
|
|||
|
});
|
|||
|
|
|||
|
this._updateActionsStateBasedOnMinMax(list);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "addItem",
|
|||
|
value: function addItem(event) {
|
|||
|
var button = external_jQuery_default()(event.currentTarget);
|
|||
|
var position = button.data('action-add') || 'bottom';
|
|||
|
var list = external_jQuery_default()(button.closest('[data-type="collection"]'));
|
|||
|
var template = external_jQuery_default()(list.find('> [data-collection-template="new"]').data('collection-template-html'));
|
|||
|
|
|||
|
this._updateActionsStateBasedOnMinMax(list);
|
|||
|
|
|||
|
var items = list.closest('[data-type="collection"]').find('> ul > [data-collection-item]');
|
|||
|
var maxItems = list.data('max');
|
|||
|
|
|||
|
if (typeof maxItems !== 'undefined' && items.length >= maxItems) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
list.find('> [data-collection-holder]')[position === 'top' ? 'prepend' : 'append'](template);
|
|||
|
this.reindex(list);
|
|||
|
items = list.closest('[data-type="collection"]').find('> ul > [data-collection-item]');
|
|||
|
var topAction = list.closest('[data-type="collection"]').find('[data-action-add="top"]');
|
|||
|
var sortAction = list.closest('[data-type="collection"]').find('[data-action="sort"]');
|
|||
|
|
|||
|
if (items.length) {
|
|||
|
if (topAction.length) {
|
|||
|
topAction.parent().removeClass('hidden');
|
|||
|
}
|
|||
|
|
|||
|
if (sortAction.length && items.length > 1) {
|
|||
|
sortAction.removeClass('hidden');
|
|||
|
}
|
|||
|
} // refresh toggleables in a list
|
|||
|
|
|||
|
|
|||
|
external_jQuery_default()('[data-grav-field="toggleable"] input[type="checkbox"]').trigger('change');
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "confirmRemove",
|
|||
|
value: function confirmRemove(event) {
|
|||
|
var button = external_jQuery_default()(event.currentTarget);
|
|||
|
var list = external_jQuery_default()(button.closest('.item-actions'));
|
|||
|
var action = list.find('.list-confirm-deletion[data-action="delete"]');
|
|||
|
var isHidden = action.hasClass('hidden');
|
|||
|
CollectionsField.closeConfirmations();
|
|||
|
action[isHidden ? 'removeClass' : 'addClass']('hidden');
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "removeItem",
|
|||
|
value: function removeItem(event) {
|
|||
|
var button = external_jQuery_default()(event.currentTarget);
|
|||
|
var item = button.closest('[data-collection-item]');
|
|||
|
var list = external_jQuery_default()(button.closest('[data-type="collection"]'));
|
|||
|
var items = list.closest('[data-type="collection"]').find('> ul > [data-collection-item]');
|
|||
|
var minItems = list.data('min');
|
|||
|
|
|||
|
if (typeof minItems !== 'undefined' && items.length <= minItems) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
item.remove();
|
|||
|
this.reindex(list);
|
|||
|
items = list.closest('[data-type="collection"]').find('> ul > [data-collection-item]');
|
|||
|
var topAction = list.closest('[data-type="collection"]').find('[data-action-add="top"]');
|
|||
|
var sortAction = list.closest('[data-type="collection"]').find('[data-action="sort"]');
|
|||
|
|
|||
|
if (!items.length) {
|
|||
|
if (topAction.length) {
|
|||
|
topAction.parent().addClass('hidden');
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if (sortAction.length && items.length <= 1) {
|
|||
|
sortAction.addClass('hidden');
|
|||
|
}
|
|||
|
|
|||
|
this._updateActionsStateBasedOnMinMax(list);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "collapseItems",
|
|||
|
value: function collapseItems(event) {
|
|||
|
var button = external_jQuery_default()(event.currentTarget);
|
|||
|
var items = external_jQuery_default()(button.closest('[data-type="collection"]')).find('> ul > [data-collection-item] > .item-actions [data-action="collapse"]');
|
|||
|
items.click();
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "collapseItem",
|
|||
|
value: function collapseItem(event) {
|
|||
|
var button = external_jQuery_default()(event.currentTarget);
|
|||
|
var item = button.closest('[data-collection-item]');
|
|||
|
button.attr('data-action', 'expand').removeClass('fa-chevron-circle-down').addClass('fa-chevron-circle-right');
|
|||
|
item.addClass('collection-collapsed');
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "expandItems",
|
|||
|
value: function expandItems(event) {
|
|||
|
var button = external_jQuery_default()(event.currentTarget);
|
|||
|
var items = external_jQuery_default()(button.closest('[data-type="collection"]')).find('> ul > [data-collection-item] > .item-actions [data-action="expand"]');
|
|||
|
items.click();
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "expandItem",
|
|||
|
value: function expandItem(event) {
|
|||
|
var button = external_jQuery_default()(event.currentTarget);
|
|||
|
var item = button.closest('[data-collection-item]');
|
|||
|
button.attr('data-action', 'collapse').removeClass('fa-chevron-circle-right').addClass('fa-chevron-circle-down');
|
|||
|
item.removeClass('collection-collapsed');
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "sortItems",
|
|||
|
value: function sortItems(event) {
|
|||
|
var button = external_jQuery_default()(event.currentTarget);
|
|||
|
var sortby = button.data('action-sort');
|
|||
|
var sortby_dir = button.data('action-sort-dir') || 'asc';
|
|||
|
var list = external_jQuery_default()(button.closest('[data-type="collection"]'));
|
|||
|
var items = list.closest('[data-type="collection"]').find('> ul > [data-collection-item]');
|
|||
|
items.sort(function (a, b) {
|
|||
|
var A = external_jQuery_default()(a).find('[name$="[' + sortby + ']"]');
|
|||
|
var B = external_jQuery_default()(b).find('[name$="[' + sortby + ']"]');
|
|||
|
var sort;
|
|||
|
|
|||
|
if (sortby_dir === 'asc') {
|
|||
|
sort = A.val() < B.val() ? -1 : A.val() > B.val() ? 1 : 0;
|
|||
|
} else {
|
|||
|
sort = A.val() > B.val() ? -1 : A.val() < B.val() ? 1 : 0;
|
|||
|
}
|
|||
|
|
|||
|
return sort;
|
|||
|
}).each(function (_, container) {
|
|||
|
external_jQuery_default()(container).parent().append(container);
|
|||
|
});
|
|||
|
this.reindex(list);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "observeKey",
|
|||
|
value: function observeKey(event) {
|
|||
|
var input = external_jQuery_default()(event.target);
|
|||
|
var value = input.val();
|
|||
|
var item = input.closest('[data-collection-key]');
|
|||
|
item.data('collection-key-backup', item.data('collection-key')).data('collection-key', value);
|
|||
|
this.reindex(null, item);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "reindex",
|
|||
|
value: function reindex(list, items) {
|
|||
|
items = items || external_jQuery_default()(list).closest('[data-type="collection"]').find('> ul > [data-collection-item]');
|
|||
|
items.each(function (index, item) {
|
|||
|
item = external_jQuery_default()(item);
|
|||
|
var observed = item.find('[data-key-observe]');
|
|||
|
var observedValue = observed.val();
|
|||
|
var hasCustomKey = observed.length;
|
|||
|
var currentKey = item.data('collection-key-backup');
|
|||
|
item.attr('data-collection-key', hasCustomKey ? observedValue : index);
|
|||
|
['name', 'data-grav-field-name', 'for', 'id', 'data-grav-file-settings', 'data-file-post-add', 'data-file-post-remove', 'data-grav-array-name', 'data-grav-elements'].forEach(function (prop) {
|
|||
|
item.find('[' + prop + '], [_' + prop + ']').each(function () {
|
|||
|
var element = external_jQuery_default()(this);
|
|||
|
var indexes = [];
|
|||
|
var array_index = null;
|
|||
|
var regexps = [new RegExp('\\[(\\d+|\\*|' + currentKey + ')\\]', 'g'), new RegExp('\\.(\\d+|\\*|' + currentKey + ')\\.', 'g')]; // special case to preserve array field index keys
|
|||
|
|
|||
|
if (prop === 'name' && element.data('gravArrayType')) {
|
|||
|
var match_index = element.attr(prop).match(/\[[0-9]{1,}\]$/);
|
|||
|
var pattern = element[0].closest('[data-grav-array-name]').dataset.gravArrayName;
|
|||
|
|
|||
|
if (match_index && pattern) {
|
|||
|
array_index = match_index[0];
|
|||
|
element.attr(prop, "".concat(pattern).concat(match_index[0]));
|
|||
|
return;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if (hasCustomKey && !observedValue) {
|
|||
|
element.attr("_".concat(prop), element.attr(prop));
|
|||
|
element.attr(prop, null);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
if (element.attr("_".concat(prop))) {
|
|||
|
element.attr(prop, element.attr("_".concat(prop)));
|
|||
|
element.attr("_".concat(prop), null);
|
|||
|
}
|
|||
|
|
|||
|
element.parents('[data-collection-key]').map(function (idx, parent) {
|
|||
|
return indexes.push(external_jQuery_default()(parent).attr('data-collection-key'));
|
|||
|
});
|
|||
|
indexes.reverse();
|
|||
|
var matchedKey = currentKey;
|
|||
|
var replaced = element.attr(prop).replace(regexps[0], function
|
|||
|
/* str, p1, offset */
|
|||
|
() {
|
|||
|
var extras = '';
|
|||
|
|
|||
|
if (array_index) {
|
|||
|
extras = array_index;
|
|||
|
console.log(indexes, extras);
|
|||
|
}
|
|||
|
|
|||
|
matchedKey = indexes.shift() || matchedKey;
|
|||
|
return "[".concat(matchedKey, "]").concat(extras);
|
|||
|
});
|
|||
|
replaced = replaced.replace(regexps[1], function
|
|||
|
/* str, p1, offset */
|
|||
|
() {
|
|||
|
matchedKey = indexes.shift() || matchedKey;
|
|||
|
return ".".concat(matchedKey, ".");
|
|||
|
});
|
|||
|
element.attr(prop, replaced);
|
|||
|
});
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "_onAddedNodes",
|
|||
|
value: function _onAddedNodes(event, target
|
|||
|
/* , record, instance */
|
|||
|
) {
|
|||
|
var _this3 = this;
|
|||
|
|
|||
|
var collections = external_jQuery_default()(target).find('[data-type="collection"]');
|
|||
|
|
|||
|
if (!collections.length) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
collections.each(function (index, collection) {
|
|||
|
collection = external_jQuery_default()(collection);
|
|||
|
|
|||
|
if (!~_this3.lists.index(collection)) {
|
|||
|
_this3.addList(collection);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "_updateActionsStateBasedOnMinMax",
|
|||
|
value: function _updateActionsStateBasedOnMinMax(list) {
|
|||
|
var items = list.closest('[data-type="collection"]').find('> ul > [data-collection-item]');
|
|||
|
var minItems = list.data('min');
|
|||
|
var maxItems = list.data('max');
|
|||
|
list.find('> .collection-actions [data-action="add"]').attr('disabled', false);
|
|||
|
list.find('> ul > li > .item-actions [data-action="delete"]').attr('disabled', false);
|
|||
|
|
|||
|
if (typeof minItems !== 'undefined' && items.length <= minItems) {
|
|||
|
list.find('> ul > li > .item-actions [data-action="delete"]').attr('disabled', true);
|
|||
|
}
|
|||
|
|
|||
|
if (typeof maxItems !== 'undefined' && items.length >= maxItems) {
|
|||
|
list.find('> .collection-actions [data-action="add"]').attr('disabled', true);
|
|||
|
}
|
|||
|
}
|
|||
|
}], [{
|
|||
|
key: "closeConfirmations",
|
|||
|
value: function closeConfirmations() {
|
|||
|
external_jQuery_default()('.list-confirm-deletion[data-action="delete"]').addClass('hidden');
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return CollectionsField;
|
|||
|
}();
|
|||
|
|
|||
|
|
|||
|
var collections_Instance = new CollectionsField();
|
|||
|
// EXTERNAL MODULE: ./app/utils/bootstrap-datetimepicker.js
|
|||
|
var bootstrap_datetimepicker = __webpack_require__(19912);
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/datetime.js
|
|||
|
function datetime_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function datetime_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 datetime_createClass(Constructor, protoProps, staticProps) { if (protoProps) datetime_defineProperties(Constructor.prototype, protoProps); if (staticProps) datetime_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var DateTimeField = /*#__PURE__*/function () {
|
|||
|
function DateTimeField(options) {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
datetime_classCallCheck(this, DateTimeField);
|
|||
|
|
|||
|
this.items = external_jQuery_default()();
|
|||
|
this.options = Object.assign({}, this.defaults, options);
|
|||
|
external_jQuery_default()('[data-grav-datetime]').each(function (index, field) {
|
|||
|
return _this.addItem(field);
|
|||
|
});
|
|||
|
external_jQuery_default()('body').on('mutation._grav', this._onAddedNodes.bind(this));
|
|||
|
}
|
|||
|
|
|||
|
datetime_createClass(DateTimeField, [{
|
|||
|
key: "defaults",
|
|||
|
get: function get() {
|
|||
|
return {
|
|||
|
showTodayButton: true,
|
|||
|
showClear: true,
|
|||
|
locale: external_GravAdmin_namespaceObject.config.language || 'en',
|
|||
|
icons: {
|
|||
|
time: 'fa fa-clock-o',
|
|||
|
date: 'fa fa-calendar-o',
|
|||
|
up: 'fa fa-chevron-up',
|
|||
|
down: 'fa fa-chevron-down',
|
|||
|
previous: 'fa fa-chevron-left',
|
|||
|
next: 'fa fa-chevron-right',
|
|||
|
today: 'fa fa-bullseye',
|
|||
|
clear: 'fa fa-trash-o',
|
|||
|
close: 'fa fa-remove'
|
|||
|
}
|
|||
|
};
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "addItem",
|
|||
|
value: function addItem(list) {
|
|||
|
list = external_jQuery_default()(list);
|
|||
|
this.items = this.items.add(list);
|
|||
|
|
|||
|
if (list.data('DateTimePicker')) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var options = Object.assign({}, this.options, list.data('grav-datetime') || {});
|
|||
|
list.datetimepicker(options).on('dp.show dp.update', this._disableDecades);
|
|||
|
list.siblings('.field-icons').on('click', function () {
|
|||
|
return list.mousedown().focus();
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "_onAddedNodes",
|
|||
|
value: function _onAddedNodes(event, target
|
|||
|
/* , record, instance */
|
|||
|
) {
|
|||
|
var _this2 = this;
|
|||
|
|
|||
|
var fields = external_jQuery_default()(target).find('[data-grav-datetime]');
|
|||
|
|
|||
|
if (!fields.length) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
fields.each(function (index, field) {
|
|||
|
field = external_jQuery_default()(field);
|
|||
|
|
|||
|
if (!~_this2.items.index(field)) {
|
|||
|
_this2.addItem(field);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "_disableDecades",
|
|||
|
value: function _disableDecades() {
|
|||
|
external_jQuery_default()('.datepicker-years .picker-switch').removeAttr('title').on('click', function (e) {
|
|||
|
return e.stopPropagation();
|
|||
|
});
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return DateTimeField;
|
|||
|
}();
|
|||
|
|
|||
|
|
|||
|
var datetime_Instance = new DateTimeField();
|
|||
|
// EXTERNAL MODULE: ./node_modules/mout/math/clamp.js
|
|||
|
var clamp = __webpack_require__(19188);
|
|||
|
var clamp_default = /*#__PURE__*/__webpack_require__.n(clamp);
|
|||
|
// EXTERNAL MODULE: ./node_modules/mout/function/bind.js
|
|||
|
var bind = __webpack_require__(84596);
|
|||
|
var bind_default = /*#__PURE__*/__webpack_require__.n(bind);
|
|||
|
;// CONCATENATED MODULE: ./app/utils/colors.js
|
|||
|
// Parses a string and returns a valid hex string when possible
|
|||
|
// parseHex('#fff') => '#ffffff'
|
|||
|
var parseHex = function parseHex(string) {
|
|||
|
string = string.replace(/[^A-F0-9]/ig, '');
|
|||
|
if (string.length !== 3 && string.length !== 6) return '';
|
|||
|
|
|||
|
if (string.length === 3) {
|
|||
|
string = string[0] + string[0] + string[1] + string[1] + string[2] + string[2];
|
|||
|
}
|
|||
|
|
|||
|
return '#' + string.toLowerCase();
|
|||
|
}; // Converts an HSB object to an RGB object
|
|||
|
// hsb2rgb({h: 0, s: 0, b: 100}) => {r: 255, g: 255, b: 255}
|
|||
|
|
|||
|
var hsb2rgb = function hsb2rgb(hsb) {
|
|||
|
var rgb = {};
|
|||
|
var h = Math.round(hsb.h);
|
|||
|
var s = Math.round(hsb.s * 255 / 100);
|
|||
|
var v = Math.round(hsb.b * 255 / 100);
|
|||
|
|
|||
|
if (s === 0) {
|
|||
|
rgb.r = rgb.g = rgb.b = v;
|
|||
|
} else {
|
|||
|
var t1 = v;
|
|||
|
var t2 = (255 - s) * v / 255;
|
|||
|
var t3 = (t1 - t2) * (h % 60) / 60;
|
|||
|
if (h === 360) h = 0;
|
|||
|
|
|||
|
if (h < 60) {
|
|||
|
rgb.r = t1;
|
|||
|
rgb.b = t2;
|
|||
|
rgb.g = t2 + t3;
|
|||
|
} else if (h < 120) {
|
|||
|
rgb.g = t1;
|
|||
|
rgb.b = t2;
|
|||
|
rgb.r = t1 - t3;
|
|||
|
} else if (h < 180) {
|
|||
|
rgb.g = t1;
|
|||
|
rgb.r = t2;
|
|||
|
rgb.b = t2 + t3;
|
|||
|
} else if (h < 240) {
|
|||
|
rgb.b = t1;
|
|||
|
rgb.r = t2;
|
|||
|
rgb.g = t1 - t3;
|
|||
|
} else if (h < 300) {
|
|||
|
rgb.b = t1;
|
|||
|
rgb.g = t2;
|
|||
|
rgb.r = t2 + t3;
|
|||
|
} else if (h < 360) {
|
|||
|
rgb.r = t1;
|
|||
|
rgb.g = t2;
|
|||
|
rgb.b = t1 - t3;
|
|||
|
} else {
|
|||
|
rgb.r = 0;
|
|||
|
rgb.g = 0;
|
|||
|
rgb.b = 0;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
return {
|
|||
|
r: Math.round(rgb.r),
|
|||
|
g: Math.round(rgb.g),
|
|||
|
b: Math.round(rgb.b)
|
|||
|
};
|
|||
|
}; // Converts an RGB object to a HEX string
|
|||
|
// rgb2hex({r: 255, g: 255, b: 255}) => #ffffff
|
|||
|
|
|||
|
var rgb2hex = function rgb2hex(rgb) {
|
|||
|
var hex = [rgb.r.toString(16), rgb.g.toString(16), rgb.b.toString(16)];
|
|||
|
hex.forEach(function (val, nr) {
|
|||
|
if (val.length === 1) hex[nr] = '0' + val;
|
|||
|
});
|
|||
|
return '#' + hex.join('');
|
|||
|
}; // Converts and RGB(a) string to a HEX string
|
|||
|
// rgbstr2hex('rgba(255, 255, 255, 0.5)') => #ffffff
|
|||
|
|
|||
|
var rgbstr2hex = function rgbstr2hex(rgb) {
|
|||
|
rgb = rgb.match(/^rgba?[\s+]?\([\s+]?(\d+)[\s+]?,[\s+]?(\d+)[\s+]?,[\s+]?(\d+)[\s+]?/i);
|
|||
|
return rgb && rgb.length === 4 ? '#' + ('0' + parseInt(rgb[1], 10).toString(16)).slice(-2) + ('0' + parseInt(rgb[2], 10).toString(16)).slice(-2) + ('0' + parseInt(rgb[3], 10).toString(16)).slice(-2) : '';
|
|||
|
}; // Converts an HSB object to a HEX string
|
|||
|
// hsb2hex({h: 0, s: 0, b: 100}) => #ffffff
|
|||
|
|
|||
|
var hsb2hex = function hsb2hex(hsb) {
|
|||
|
return rgb2hex(hsb2rgb(hsb));
|
|||
|
}; // Converts a HEX string to an HSB object
|
|||
|
// hex2hsb('#ffffff') => {h: 0, s: 0, b: 100}
|
|||
|
|
|||
|
var hex2hsb = function hex2hsb(hex) {
|
|||
|
var hsb = rgb2hsb(hex2rgb(hex));
|
|||
|
if (hsb.s === 0) hsb.h = 360;
|
|||
|
return hsb;
|
|||
|
}; // Converts an RGB object to an HSB object
|
|||
|
// rgb2hsb({r: 255, g: 255, b: 255}) => {h: 0, s: 0, b: 100}
|
|||
|
|
|||
|
var rgb2hsb = function rgb2hsb(rgb) {
|
|||
|
var hsb = {
|
|||
|
h: 0,
|
|||
|
s: 0,
|
|||
|
b: 0
|
|||
|
};
|
|||
|
var min = Math.min(rgb.r, rgb.g, rgb.b);
|
|||
|
var max = Math.max(rgb.r, rgb.g, rgb.b);
|
|||
|
var delta = max - min;
|
|||
|
hsb.b = max;
|
|||
|
hsb.s = max !== 0 ? 255 * delta / max : 0;
|
|||
|
|
|||
|
if (hsb.s !== 0) {
|
|||
|
if (rgb.r === max) {
|
|||
|
hsb.h = (rgb.g - rgb.b) / delta;
|
|||
|
} else if (rgb.g === max) {
|
|||
|
hsb.h = 2 + (rgb.b - rgb.r) / delta;
|
|||
|
} else {
|
|||
|
hsb.h = 4 + (rgb.r - rgb.g) / delta;
|
|||
|
}
|
|||
|
} else {
|
|||
|
hsb.h = -1;
|
|||
|
}
|
|||
|
|
|||
|
hsb.h *= 60;
|
|||
|
|
|||
|
if (hsb.h < 0) {
|
|||
|
hsb.h += 360;
|
|||
|
}
|
|||
|
|
|||
|
hsb.s *= 100 / 255;
|
|||
|
hsb.b *= 100 / 255;
|
|||
|
return hsb;
|
|||
|
}; // Converts a HEX string to an RGB object
|
|||
|
// hex2rgb('#ffffff') => {r: 255, g: 255, b: 255}
|
|||
|
|
|||
|
var hex2rgb = function hex2rgb(hex) {
|
|||
|
hex = parseInt(hex.indexOf('#') > -1 ? hex.substring(1) : hex, 16);
|
|||
|
return {
|
|||
|
/* jshint ignore:start */
|
|||
|
r: hex >> 16,
|
|||
|
g: (hex & 0x00FF00) >> 8,
|
|||
|
b: hex & 0x0000FF
|
|||
|
/* jshint ignore:end */
|
|||
|
|
|||
|
};
|
|||
|
};
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/colorpicker.js
|
|||
|
function colorpicker_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function colorpicker_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 colorpicker_createClass(Constructor, protoProps, staticProps) { if (protoProps) colorpicker_defineProperties(Constructor.prototype, protoProps); if (staticProps) colorpicker_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var isFirefox = navigator.userAgent.toLowerCase().indexOf('firefox') > -1;
|
|||
|
var colorpicker_body = external_jQuery_default()('body');
|
|||
|
var MOUSEDOWN = 'mousedown touchstart MSPointerDown pointerdown';
|
|||
|
var MOUSEMOVE = 'mousemove touchmove MSPointerMove pointermove';
|
|||
|
var MOUSEUP = 'mouseup touchend MSPointerUp pointerup';
|
|||
|
var FOCUSIN = isFirefox ? 'focus' : 'focusin';
|
|||
|
|
|||
|
var ColorpickerField = /*#__PURE__*/function () {
|
|||
|
function ColorpickerField(selector) {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
colorpicker_classCallCheck(this, ColorpickerField);
|
|||
|
|
|||
|
this.selector = selector;
|
|||
|
this.field = external_jQuery_default()(this.selector);
|
|||
|
this.options = Object.assign({}, this.field.data('grav-colorpicker'));
|
|||
|
this.built = false;
|
|||
|
this.attach();
|
|||
|
|
|||
|
if (this.options.update) {
|
|||
|
this.field.on('change._grav_colorpicker', function (event, field, hex, opacity) {
|
|||
|
var backgroundColor = hex;
|
|||
|
var rgb = hex2rgb(hex);
|
|||
|
|
|||
|
if (opacity < 1) {
|
|||
|
backgroundColor = 'rgba(' + rgb.r + ', ' + rgb.g + ', ' + rgb.b + ', ' + opacity + ')';
|
|||
|
}
|
|||
|
|
|||
|
var target = field.closest(_this.options.update);
|
|||
|
|
|||
|
if (!target.length) {
|
|||
|
target = field.siblings(_this.options.update);
|
|||
|
}
|
|||
|
|
|||
|
if (!target.length) {
|
|||
|
target = field.parent('.g-colorpicker').find(_this.options.update);
|
|||
|
}
|
|||
|
|
|||
|
target.css({
|
|||
|
backgroundColor: backgroundColor
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
colorpicker_createClass(ColorpickerField, [{
|
|||
|
key: "attach",
|
|||
|
value: function attach() {
|
|||
|
var _this2 = this;
|
|||
|
|
|||
|
colorpicker_body.on(FOCUSIN, this.selector, function (event) {
|
|||
|
return _this2.show(event, event.currentTarget);
|
|||
|
});
|
|||
|
colorpicker_body.on(MOUSEDOWN, this.selector + ' .g-colorpicker, ' + this.selector + ' .g-colorpicker i', this.bound('iconClick'));
|
|||
|
colorpicker_body.on('keydown', this.selector, function (event) {
|
|||
|
switch (event.keyCode) {
|
|||
|
case 9:
|
|||
|
// tab
|
|||
|
_this2.hide();
|
|||
|
|
|||
|
break;
|
|||
|
|
|||
|
case 13: // enter
|
|||
|
|
|||
|
case 27:
|
|||
|
// esc
|
|||
|
_this2.hide();
|
|||
|
|
|||
|
event.currentTarget.blur();
|
|||
|
break;
|
|||
|
}
|
|||
|
|
|||
|
return true;
|
|||
|
}); // Update on keyup
|
|||
|
|
|||
|
colorpicker_body.on('keyup', this.selector, function (event) {
|
|||
|
_this2.updateFromInput(true, event.currentTarget);
|
|||
|
|
|||
|
return true;
|
|||
|
}); // Update on paste
|
|||
|
|
|||
|
colorpicker_body.on('paste', this.selector, function (event) {
|
|||
|
setTimeout(function () {
|
|||
|
return _this2.updateFromInput(true, event.currentTarget);
|
|||
|
}, 1);
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "show",
|
|||
|
value: function show(event, target) {
|
|||
|
target = external_jQuery_default()(target);
|
|||
|
|
|||
|
if (!this.built) {
|
|||
|
this.build();
|
|||
|
}
|
|||
|
|
|||
|
this.element = target;
|
|||
|
this.reposition();
|
|||
|
this.wrapper.addClass('cp-visible');
|
|||
|
this.updateFromInput();
|
|||
|
this.wrapper.on(MOUSEDOWN, '.cp-grid, .cp-slider, .cp-opacity-slider', this.bound('bodyDown'));
|
|||
|
colorpicker_body.on(MOUSEMOVE, this.bound('bodyMove'));
|
|||
|
colorpicker_body.on(MOUSEDOWN, this.bound('bodyClick'));
|
|||
|
colorpicker_body.on(MOUSEUP, this.bound('targetReset'));
|
|||
|
external_jQuery_default()('#admin-main > .content-wrapper').on('scroll', this.bound('reposition'));
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "hide",
|
|||
|
value: function hide() {
|
|||
|
if (!this.built) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
this.wrapper.removeClass('cp-visible');
|
|||
|
this.wrapper.undelegate(MOUSEDOWN, '.cp-grid, .cp-slider, .cp-opacity-slider', this.bound('bodyDown'));
|
|||
|
colorpicker_body.off(MOUSEMOVE, this.bound('bodyMove'));
|
|||
|
colorpicker_body.off(MOUSEDOWN, this.bound('bodyClick'));
|
|||
|
colorpicker_body.off(MOUSEUP, this.bound('targetReset'));
|
|||
|
external_jQuery_default()('#admin-main > .content-wrapper').on('scroll', this.bound('reposition'));
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "build",
|
|||
|
value: function build() {
|
|||
|
var _this3 = this;
|
|||
|
|
|||
|
this.wrapper = external_jQuery_default()('<div class="cp-wrapper cp-with-opacity cp-mode-hue" />');
|
|||
|
this.slider = external_jQuery_default()('<div class="cp-slider cp-sprite" />').appendTo(this.wrapper).append(external_jQuery_default()('<div class="cp-picker" />'));
|
|||
|
this.opacitySlider = external_jQuery_default()('<div class="cp-opacity-slider cp-sprite" />').appendTo(this.wrapper).append(external_jQuery_default()('<div class="cp-picker" />'));
|
|||
|
this.grid = external_jQuery_default()('<div class="cp-grid cp-sprite" />').appendTo(this.wrapper).append(external_jQuery_default()('<div class="cp-grid-inner" />')).append(external_jQuery_default()('<div class="cp-picker" />'));
|
|||
|
external_jQuery_default()('<div />').appendTo(this.grid.find('.cp-picker'));
|
|||
|
var tabs = external_jQuery_default()('<div class="cp-tabs" />').appendTo(this.wrapper);
|
|||
|
this.tabs = {
|
|||
|
hue: external_jQuery_default()('<div class="cp-tab-hue active" />').text('HUE').appendTo(tabs),
|
|||
|
brightness: external_jQuery_default()('<div class="cp-tab-brightness" />').text('BRI').appendTo(tabs),
|
|||
|
saturation: external_jQuery_default()('<div class="cp-tab-saturation" />').text('SAT').appendTo(tabs),
|
|||
|
wheel: external_jQuery_default()('<div class="cp-tab-wheel" />').text('WHEEL').appendTo(tabs),
|
|||
|
transparent: external_jQuery_default()('<div class="cp-tab-transp" />').text('TRANSPARENT').appendTo(tabs)
|
|||
|
};
|
|||
|
tabs.on(MOUSEDOWN, '> div', function (event) {
|
|||
|
var element = external_jQuery_default()(event.currentTarget);
|
|||
|
|
|||
|
if (element.is(_this3.tabs.transparent)) {
|
|||
|
var sliderHeight = _this3.opacitySlider.height();
|
|||
|
|
|||
|
_this3.opacity = 0;
|
|||
|
|
|||
|
_this3.opacitySlider.find('.cp-picker').css({
|
|||
|
'top': clamp_default()(sliderHeight - sliderHeight * _this3.opacity, 0, sliderHeight)
|
|||
|
});
|
|||
|
|
|||
|
_this3.move(_this3.opacitySlider, {
|
|||
|
manualOpacity: true
|
|||
|
});
|
|||
|
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var active = tabs.find('.active');
|
|||
|
var mode = active.attr('class').replace(/\s|active|cp-tab-/g, '');
|
|||
|
var newMode = element.attr('class').replace(/\s|active|cp-tab-/g, '');
|
|||
|
|
|||
|
_this3.wrapper.removeClass('cp-mode-' + mode).addClass('cp-mode-' + newMode);
|
|||
|
|
|||
|
active.removeClass('active');
|
|||
|
element.addClass('active');
|
|||
|
_this3.mode = newMode;
|
|||
|
|
|||
|
_this3.updateFromInput();
|
|||
|
});
|
|||
|
this.wrapper.appendTo('.content-wrapper');
|
|||
|
this.built = true;
|
|||
|
this.mode = 'hue';
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "reposition",
|
|||
|
value: function reposition() {
|
|||
|
var ct = external_jQuery_default()('.content-wrapper')[0];
|
|||
|
var offset = this.element[0].getBoundingClientRect();
|
|||
|
var ctOffset = ct.getBoundingClientRect();
|
|||
|
var delta = {
|
|||
|
x: 0,
|
|||
|
y: 0
|
|||
|
};
|
|||
|
|
|||
|
if (this.options.offset) {
|
|||
|
delta.x = this.options.offset.x || 0;
|
|||
|
delta.y = this.options.offset.y || 0;
|
|||
|
}
|
|||
|
|
|||
|
this.wrapper.css({
|
|||
|
top: offset.top + offset.height + ct.scrollTop - ctOffset.top + delta.y,
|
|||
|
left: offset.left + ct.scrollLeft - ctOffset.left + delta.x
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "iconClick",
|
|||
|
value: function iconClick(event) {
|
|||
|
if (this.wrapper && this.wrapper.hasClass('cp-visible')) {
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
event && event.preventDefault();
|
|||
|
var input = external_jQuery_default()(event.currentTarget).find('input');
|
|||
|
setTimeout(function () {
|
|||
|
return input.focus();
|
|||
|
}, 50);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "bodyMove",
|
|||
|
value: function bodyMove(event) {
|
|||
|
event && event.preventDefault();
|
|||
|
|
|||
|
if (this.target) {
|
|||
|
this.move(this.target, event);
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "bodyClick",
|
|||
|
value: function bodyClick(event) {
|
|||
|
var target = external_jQuery_default()(event.target);
|
|||
|
|
|||
|
if (!target.closest('.cp-wrapper').length && !target.is(this.selector)) {
|
|||
|
this.hide();
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "bodyDown",
|
|||
|
value: function bodyDown(event) {
|
|||
|
event && event.preventDefault();
|
|||
|
this.target = external_jQuery_default()(event.currentTarget);
|
|||
|
this.move(this.target, event, true);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "targetReset",
|
|||
|
value: function targetReset(event) {
|
|||
|
event && event.preventDefault();
|
|||
|
this.target = null;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "move",
|
|||
|
value: function move(target, event) {
|
|||
|
var input = this.element;
|
|||
|
var picker = target.find('.cp-picker');
|
|||
|
var clientRect = target[0].getBoundingClientRect();
|
|||
|
var offsetX = clientRect.left + window.scrollX;
|
|||
|
var offsetY = clientRect.top + window.scrollY;
|
|||
|
var x = Math.round((event ? event.pageX : 0) - offsetX);
|
|||
|
var y = Math.round((event ? event.pageY : 0) - offsetY);
|
|||
|
var wx;
|
|||
|
var wy;
|
|||
|
var r;
|
|||
|
var phi; // Touch support
|
|||
|
|
|||
|
var touchEvents = event.changedTouches || event.originalEvent && event.originalEvent.changedTouches;
|
|||
|
|
|||
|
if (event && touchEvents) {
|
|||
|
x = (touchEvents ? touchEvents[0].pageX : 0) - offsetX;
|
|||
|
y = (touchEvents ? touchEvents[0].pageY : 0) - offsetY;
|
|||
|
}
|
|||
|
|
|||
|
if (event && event.manualOpacity) {
|
|||
|
y = clientRect.height;
|
|||
|
} // Constrain picker to its container
|
|||
|
|
|||
|
|
|||
|
if (x < 0) x = 0;
|
|||
|
if (y < 0) y = 0;
|
|||
|
if (x > clientRect.width) x = clientRect.width;
|
|||
|
if (y > clientRect.height) y = clientRect.height; // Constrain color wheel values to the wheel
|
|||
|
|
|||
|
if (target.parent('.cp-mode-wheel').length && picker.parent('.cp-grid').length) {
|
|||
|
wx = 75 - x;
|
|||
|
wy = 75 - y;
|
|||
|
r = Math.sqrt(wx * wx + wy * wy);
|
|||
|
phi = Math.atan2(wy, wx);
|
|||
|
if (phi < 0) phi += Math.PI * 2;
|
|||
|
|
|||
|
if (r > 75) {
|
|||
|
x = 75 - 75 * Math.cos(phi);
|
|||
|
y = 75 - 75 * Math.sin(phi);
|
|||
|
}
|
|||
|
|
|||
|
x = Math.round(x);
|
|||
|
y = Math.round(y);
|
|||
|
} // Move the picker
|
|||
|
|
|||
|
|
|||
|
if (target.hasClass('cp-grid')) {
|
|||
|
picker.css({
|
|||
|
top: y,
|
|||
|
left: x
|
|||
|
});
|
|||
|
this.updateFromPicker(input, target);
|
|||
|
} else {
|
|||
|
picker.css({
|
|||
|
top: y
|
|||
|
});
|
|||
|
this.updateFromPicker(input, target);
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "updateFromInput",
|
|||
|
value: function updateFromInput(dontFireEvent, element) {
|
|||
|
element = element ? external_jQuery_default()(element) : this.element;
|
|||
|
var value = element.val();
|
|||
|
var opacity = value.replace(/\s/g, '').match(/^rgba?\([0-9]{1,3},[0-9]{1,3},[0-9]{1,3},(.+)\)/);
|
|||
|
var hex;
|
|||
|
var hsb;
|
|||
|
value = rgbstr2hex(value) || value;
|
|||
|
opacity = opacity ? clamp_default()(opacity[1], 0, 1) : 1;
|
|||
|
|
|||
|
if (!(hex = parseHex(value))) {
|
|||
|
hex = '#ffffff';
|
|||
|
}
|
|||
|
|
|||
|
hsb = hex2hsb(hex);
|
|||
|
|
|||
|
if (this.built) {
|
|||
|
// opacity
|
|||
|
this.opacity = opacity;
|
|||
|
var sliderHeight = this.opacitySlider.height();
|
|||
|
this.opacitySlider.find('.cp-picker').css({
|
|||
|
'top': clamp_default()(sliderHeight - sliderHeight * this.opacity, 0, sliderHeight)
|
|||
|
}); // bg color
|
|||
|
|
|||
|
var gridHeight = this.grid.height();
|
|||
|
var gridWidth = this.grid.width();
|
|||
|
var r;
|
|||
|
var phi;
|
|||
|
var x;
|
|||
|
var y;
|
|||
|
sliderHeight = this.slider.height();
|
|||
|
|
|||
|
switch (this.mode) {
|
|||
|
case 'wheel':
|
|||
|
// Set grid position
|
|||
|
r = clamp_default()(Math.ceil(hsb.s * 0.75), 0, gridHeight / 2);
|
|||
|
phi = hsb.h * Math.PI / 180;
|
|||
|
x = clamp_default()(75 - Math.cos(phi) * r, 0, gridWidth);
|
|||
|
y = clamp_default()(75 - Math.sin(phi) * r, 0, gridHeight);
|
|||
|
this.grid.css({
|
|||
|
backgroundColor: 'transparent'
|
|||
|
}).find('.cp-picker').css({
|
|||
|
top: y,
|
|||
|
left: x
|
|||
|
}); // Set slider position
|
|||
|
|
|||
|
y = 150 - hsb.b / (100 / gridHeight);
|
|||
|
if (hex === '') y = 0;
|
|||
|
this.slider.find('.cp-picker').css({
|
|||
|
top: y
|
|||
|
}); // Update panel color
|
|||
|
|
|||
|
this.slider.css({
|
|||
|
backgroundColor: hsb2hex({
|
|||
|
h: hsb.h,
|
|||
|
s: hsb.s,
|
|||
|
b: 100
|
|||
|
})
|
|||
|
});
|
|||
|
break;
|
|||
|
|
|||
|
case 'saturation':
|
|||
|
// Set grid position
|
|||
|
x = clamp_default()(5 * hsb.h / 12, 0, 150);
|
|||
|
y = clamp_default()(gridHeight - Math.ceil(hsb.b / (100 / gridHeight)), 0, gridHeight);
|
|||
|
this.grid.find('.cp-picker').css({
|
|||
|
top: y,
|
|||
|
left: x
|
|||
|
}); // Set slider position
|
|||
|
|
|||
|
y = clamp_default()(sliderHeight - hsb.s * (sliderHeight / 100), 0, sliderHeight);
|
|||
|
this.slider.find('.cp-picker').css({
|
|||
|
top: y
|
|||
|
}); // Update UI
|
|||
|
|
|||
|
this.slider.css({
|
|||
|
backgroundColor: hsb2hex({
|
|||
|
h: hsb.h,
|
|||
|
s: 100,
|
|||
|
b: hsb.b
|
|||
|
})
|
|||
|
});
|
|||
|
this.grid.find('.cp-grid-inner').css({
|
|||
|
opacity: hsb.s / 100
|
|||
|
});
|
|||
|
break;
|
|||
|
|
|||
|
case 'brightness':
|
|||
|
// Set grid position
|
|||
|
x = clamp_default()(5 * hsb.h / 12, 0, 150);
|
|||
|
y = clamp_default()(gridHeight - Math.ceil(hsb.s / (100 / gridHeight)), 0, gridHeight);
|
|||
|
this.grid.find('.cp-picker').css({
|
|||
|
top: y,
|
|||
|
left: x
|
|||
|
}); // Set slider position
|
|||
|
|
|||
|
y = clamp_default()(sliderHeight - hsb.b * (sliderHeight / 100), 0, sliderHeight);
|
|||
|
this.slider.find('.cp-picker').css({
|
|||
|
top: y
|
|||
|
}); // Update UI
|
|||
|
|
|||
|
this.slider.css({
|
|||
|
backgroundColor: hsb2hex({
|
|||
|
h: hsb.h,
|
|||
|
s: hsb.s,
|
|||
|
b: 100
|
|||
|
})
|
|||
|
});
|
|||
|
this.grid.find('.cp-grid-inner').css({
|
|||
|
opacity: 1 - hsb.b / 100
|
|||
|
});
|
|||
|
break;
|
|||
|
|
|||
|
case 'hue':
|
|||
|
default:
|
|||
|
// Set grid position
|
|||
|
x = clamp_default()(Math.ceil(hsb.s / (100 / gridWidth)), 0, gridWidth);
|
|||
|
y = clamp_default()(gridHeight - Math.ceil(hsb.b / (100 / gridHeight)), 0, gridHeight);
|
|||
|
this.grid.find('.cp-picker').css({
|
|||
|
top: y,
|
|||
|
left: x
|
|||
|
}); // Set slider position
|
|||
|
|
|||
|
y = clamp_default()(sliderHeight - hsb.h / (360 / sliderHeight), 0, sliderHeight);
|
|||
|
this.slider.find('.cp-picker').css({
|
|||
|
top: y
|
|||
|
}); // Update panel color
|
|||
|
|
|||
|
this.grid.css({
|
|||
|
backgroundColor: hsb2hex({
|
|||
|
h: hsb.h,
|
|||
|
s: 100,
|
|||
|
b: 100
|
|||
|
})
|
|||
|
});
|
|||
|
break;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if (!dontFireEvent) {
|
|||
|
element.val(this.getValue(hex));
|
|||
|
}
|
|||
|
|
|||
|
(this.element || element).trigger('change._grav_colorpicker', [element, hex, opacity]);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "updateFromPicker",
|
|||
|
value: function updateFromPicker(input, target) {
|
|||
|
var getCoords = function getCoords(picker, container) {
|
|||
|
var left, top;
|
|||
|
if (!picker.length || !container) return null;
|
|||
|
left = picker[0].getBoundingClientRect().left;
|
|||
|
top = picker[0].getBoundingClientRect().top;
|
|||
|
return {
|
|||
|
x: left - container[0].getBoundingClientRect().left + picker[0].offsetWidth / 2,
|
|||
|
y: top - container[0].getBoundingClientRect().top + picker[0].offsetHeight / 2
|
|||
|
};
|
|||
|
};
|
|||
|
|
|||
|
var hex;
|
|||
|
var hue;
|
|||
|
var saturation;
|
|||
|
var brightness;
|
|||
|
var x;
|
|||
|
var y;
|
|||
|
var r;
|
|||
|
var phi; // Panel objects
|
|||
|
|
|||
|
var grid = this.wrapper.find('.cp-grid');
|
|||
|
var slider = this.wrapper.find('.cp-slider');
|
|||
|
var opacitySlider = this.wrapper.find('.cp-opacity-slider'); // Picker objects
|
|||
|
|
|||
|
var gridPicker = grid.find('.cp-picker');
|
|||
|
var sliderPicker = slider.find('.cp-picker');
|
|||
|
var opacityPicker = opacitySlider.find('.cp-picker'); // Picker positions
|
|||
|
|
|||
|
var gridPos = getCoords(gridPicker, grid);
|
|||
|
var sliderPos = getCoords(sliderPicker, slider);
|
|||
|
var opacityPos = getCoords(opacityPicker, opacitySlider); // Sizes
|
|||
|
|
|||
|
var gridWidth = grid[0].getBoundingClientRect().width;
|
|||
|
var gridHeight = grid[0].getBoundingClientRect().height;
|
|||
|
var sliderHeight = slider[0].getBoundingClientRect().height;
|
|||
|
var opacitySliderHeight = opacitySlider[0].getBoundingClientRect().height;
|
|||
|
var value = this.element.val();
|
|||
|
value = rgbstr2hex(value) || value;
|
|||
|
|
|||
|
if (!(hex = parseHex(value))) {
|
|||
|
hex = '#ffffff';
|
|||
|
} // Handle colors
|
|||
|
|
|||
|
|
|||
|
if (target.hasClass('cp-grid') || target.hasClass('cp-slider')) {
|
|||
|
// Determine HSB values
|
|||
|
switch (this.mode) {
|
|||
|
case 'wheel':
|
|||
|
// Calculate hue, saturation, and brightness
|
|||
|
x = gridWidth / 2 - gridPos.x;
|
|||
|
y = gridHeight / 2 - gridPos.y;
|
|||
|
r = Math.sqrt(x * x + y * y);
|
|||
|
phi = Math.atan2(y, x);
|
|||
|
if (phi < 0) phi += Math.PI * 2;
|
|||
|
|
|||
|
if (r > 75) {
|
|||
|
r = 75;
|
|||
|
gridPos.x = 69 - 75 * Math.cos(phi);
|
|||
|
gridPos.y = 69 - 75 * Math.sin(phi);
|
|||
|
}
|
|||
|
|
|||
|
saturation = clamp_default()(r / 0.75, 0, 100);
|
|||
|
hue = clamp_default()(phi * 180 / Math.PI, 0, 360);
|
|||
|
brightness = clamp_default()(100 - Math.floor(sliderPos.y * (100 / sliderHeight)), 0, 100);
|
|||
|
hex = hsb2hex({
|
|||
|
h: hue,
|
|||
|
s: saturation,
|
|||
|
b: brightness
|
|||
|
}); // Update UI
|
|||
|
|
|||
|
slider.css({
|
|||
|
backgroundColor: hsb2hex({
|
|||
|
h: hue,
|
|||
|
s: saturation,
|
|||
|
b: 100
|
|||
|
})
|
|||
|
});
|
|||
|
break;
|
|||
|
|
|||
|
case 'saturation':
|
|||
|
// Calculate hue, saturation, and brightness
|
|||
|
hue = clamp_default()(parseInt(gridPos.x * (360 / gridWidth), 10), 0, 360);
|
|||
|
saturation = clamp_default()(100 - Math.floor(sliderPos.y * (100 / sliderHeight)), 0, 100);
|
|||
|
brightness = clamp_default()(100 - Math.floor(gridPos.y * (100 / gridHeight)), 0, 100);
|
|||
|
hex = hsb2hex({
|
|||
|
h: hue,
|
|||
|
s: saturation,
|
|||
|
b: brightness
|
|||
|
}); // Update UI
|
|||
|
|
|||
|
slider.css({
|
|||
|
backgroundColor: hsb2hex({
|
|||
|
h: hue,
|
|||
|
s: 100,
|
|||
|
b: brightness
|
|||
|
})
|
|||
|
});
|
|||
|
grid.find('.cp-grid-inner').css({
|
|||
|
opacity: saturation / 100
|
|||
|
});
|
|||
|
break;
|
|||
|
|
|||
|
case 'brightness':
|
|||
|
// Calculate hue, saturation, and brightness
|
|||
|
hue = clamp_default()(parseInt(gridPos.x * (360 / gridWidth), 10), 0, 360);
|
|||
|
saturation = clamp_default()(100 - Math.floor(gridPos.y * (100 / gridHeight)), 0, 100);
|
|||
|
brightness = clamp_default()(100 - Math.floor(sliderPos.y * (100 / sliderHeight)), 0, 100);
|
|||
|
hex = hsb2hex({
|
|||
|
h: hue,
|
|||
|
s: saturation,
|
|||
|
b: brightness
|
|||
|
}); // Update UI
|
|||
|
|
|||
|
slider.css({
|
|||
|
backgroundColor: hsb2hex({
|
|||
|
h: hue,
|
|||
|
s: saturation,
|
|||
|
b: 100
|
|||
|
})
|
|||
|
});
|
|||
|
grid.find('.cp-grid-inner').css({
|
|||
|
opacity: 1 - brightness / 100
|
|||
|
});
|
|||
|
break;
|
|||
|
|
|||
|
default:
|
|||
|
// Calculate hue, saturation, and brightness
|
|||
|
hue = clamp_default()(360 - parseInt(sliderPos.y * (360 / sliderHeight), 10), 0, 360);
|
|||
|
saturation = clamp_default()(Math.floor(gridPos.x * (100 / gridWidth)), 0, 100);
|
|||
|
brightness = clamp_default()(100 - Math.floor(gridPos.y * (100 / gridHeight)), 0, 100);
|
|||
|
hex = hsb2hex({
|
|||
|
h: hue,
|
|||
|
s: saturation,
|
|||
|
b: brightness
|
|||
|
}); // Update UI
|
|||
|
|
|||
|
grid.css({
|
|||
|
backgroundColor: hsb2hex({
|
|||
|
h: hue,
|
|||
|
s: 100,
|
|||
|
b: 100
|
|||
|
})
|
|||
|
});
|
|||
|
break;
|
|||
|
}
|
|||
|
} // Handle opacity
|
|||
|
|
|||
|
|
|||
|
if (target.hasClass('cp-opacity-slider')) {
|
|||
|
this.opacity = parseFloat(1 - opacityPos.y / opacitySliderHeight).toFixed(2);
|
|||
|
} // Adjust case
|
|||
|
|
|||
|
|
|||
|
input.val(this.getValue(hex)); // Handle change event
|
|||
|
|
|||
|
this.element.trigger('change._grav_colorpicker', [this.element, hex, this.opacity]);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "getValue",
|
|||
|
value: function getValue(hex) {
|
|||
|
if (this.opacity === 1) {
|
|||
|
return hex;
|
|||
|
}
|
|||
|
|
|||
|
var rgb = hex2rgb(hex);
|
|||
|
return 'rgba(' + rgb.r + ', ' + rgb.g + ', ' + rgb.b + ', ' + this.opacity + ')';
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "bound",
|
|||
|
value: function bound(name) {
|
|||
|
var bound = this._bound || (this._bound = {});
|
|||
|
return bound[name] || (bound[name] = bind_default()(this[name], this));
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return ColorpickerField;
|
|||
|
}();
|
|||
|
|
|||
|
|
|||
|
var colorpicker_Instance = new ColorpickerField('[data-grav-colorpicker]');
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/folder.js
|
|||
|
|
|||
|
|
|||
|
var Regenerate = function Regenerate() {
|
|||
|
var field = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '[name="data[folder]"]';
|
|||
|
var element = external_jQuery_default()(field);
|
|||
|
var title = external_jQuery_default()('[name="data[header][title]"]');
|
|||
|
var slug = external_jQuery_default().slugify(title.val(), {
|
|||
|
custom: {
|
|||
|
"'": ''
|
|||
|
}
|
|||
|
});
|
|||
|
element.addClass('highlight').val(slug);
|
|||
|
setTimeout(function () {
|
|||
|
return element.removeClass('highlight');
|
|||
|
}, 500);
|
|||
|
};
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', '[data-regenerate]', function (event) {
|
|||
|
var target = external_jQuery_default()(event.currentTarget);
|
|||
|
var field = external_jQuery_default()(target.data('regenerate'));
|
|||
|
Regenerate(field);
|
|||
|
});
|
|||
|
/* harmony default export */ const fields_folder = (Regenerate);
|
|||
|
// EXTERNAL MODULE: ./node_modules/mout/object/forIn.js
|
|||
|
var forIn = __webpack_require__(15473);
|
|||
|
var forIn_default = /*#__PURE__*/__webpack_require__.n(forIn);
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/selectunique.js
|
|||
|
function selectunique_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function selectunique_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 selectunique_createClass(Constructor, protoProps, staticProps) { if (protoProps) selectunique_defineProperties(Constructor.prototype, protoProps); if (staticProps) selectunique_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
// import { config } from 'grav-config';
|
|||
|
|
|||
|
var Data = {};
|
|||
|
|
|||
|
var SelectUniqueField = /*#__PURE__*/function () {
|
|||
|
function SelectUniqueField(options) {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
selectunique_classCallCheck(this, SelectUniqueField);
|
|||
|
|
|||
|
var body = external_jQuery_default()('body');
|
|||
|
this.items = external_jQuery_default()();
|
|||
|
this.options = Object.assign({}, this.defaults, options);
|
|||
|
external_jQuery_default()('[data-select-observe]').each(function (index, element) {
|
|||
|
return _this.addSelect(element);
|
|||
|
}).last().trigger('change', {
|
|||
|
load: true
|
|||
|
});
|
|||
|
body.on('mutation._grav', this._onAddedNodes.bind(this));
|
|||
|
body.on('mutation_removed._grav', this._onRemovedNodes.bind(this));
|
|||
|
}
|
|||
|
|
|||
|
selectunique_createClass(SelectUniqueField, [{
|
|||
|
key: "_onAddedNodes",
|
|||
|
value: function _onAddedNodes(event, target, record, instance) {
|
|||
|
var _this2 = this;
|
|||
|
|
|||
|
var fields = external_jQuery_default()(target).find('[data-select-observe]');
|
|||
|
|
|||
|
if (!fields.length) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
fields.each(function (index, field) {
|
|||
|
field = external_jQuery_default()(field);
|
|||
|
|
|||
|
if (!~_this2.items.index(field)) {
|
|||
|
_this2.addSelect(field);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "_onRemovedNodes",
|
|||
|
value: function _onRemovedNodes(event, data
|
|||
|
/* , instance */
|
|||
|
) {
|
|||
|
var _this3 = this;
|
|||
|
|
|||
|
var target = external_jQuery_default()(data.target);
|
|||
|
var holder = target.data('collectionHolder');
|
|||
|
|
|||
|
if (!holder) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
var node = external_jQuery_default()(data.mutation.removedNodes);
|
|||
|
var value = node.find('[data-select-observe]').val();
|
|||
|
|
|||
|
if (value) {
|
|||
|
Data[holder].state[value] = value;
|
|||
|
}
|
|||
|
|
|||
|
target.find('[data-select-observe]').each(function (index, field) {
|
|||
|
field = external_jQuery_default()(field);
|
|||
|
|
|||
|
if (field.val() !== value) {
|
|||
|
_this3.updateOptions(field);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "addSelect",
|
|||
|
value: function addSelect(element) {
|
|||
|
var _this4 = this;
|
|||
|
|
|||
|
this.items = this.items.add(element);
|
|||
|
element = external_jQuery_default()(element);
|
|||
|
var value = element.attr('value');
|
|||
|
var holder = element.closest('[data-collection-holder]').data('collectionHolder');
|
|||
|
var options = element.closest('[data-select-unique]').data('selectUnique');
|
|||
|
|
|||
|
if (!Data[holder]) {
|
|||
|
var data = {};
|
|||
|
|
|||
|
if (Array.isArray(options)) {
|
|||
|
options.slice(0).map(function (item) {
|
|||
|
data[item] = item;
|
|||
|
});
|
|||
|
} else {
|
|||
|
data = Object.assign({}, options);
|
|||
|
}
|
|||
|
|
|||
|
Data[holder] = {
|
|||
|
original: null,
|
|||
|
state: null
|
|||
|
};
|
|||
|
Data[holder].original = Object.assign({}, data);
|
|||
|
Data[holder].state = Object.assign({}, data);
|
|||
|
}
|
|||
|
|
|||
|
this.updateOptions(element);
|
|||
|
element.data('originalValue', value);
|
|||
|
element.on('change', function (event, extras) {
|
|||
|
var target = external_jQuery_default()(event.currentTarget);
|
|||
|
|
|||
|
if (target.data('dummyChange')) {
|
|||
|
target.data('dummyChange', false);
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
_this4.refreshOptions(target, extras && extras.load ? null : element.data('originalValue'));
|
|||
|
|
|||
|
element.data('originalValue', target.val());
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "updateOptions",
|
|||
|
value: function updateOptions(element) {
|
|||
|
element = external_jQuery_default()(element);
|
|||
|
var value = element.attr('value');
|
|||
|
var holder = element.closest('[data-collection-holder]').data('collectionHolder');
|
|||
|
forIn_default()(Data[holder].state, function (v, k) {
|
|||
|
var selected = k === value ? 'selected="selected"' : '';
|
|||
|
|
|||
|
if (element.get(0).selectize) {
|
|||
|
var selectize = element.data('selectize');
|
|||
|
selectize.removeOption(k);
|
|||
|
selectize.addOption({
|
|||
|
value: k,
|
|||
|
text: v
|
|||
|
});
|
|||
|
} else {
|
|||
|
element.append("<option value=\"".concat(k, "\" ").concat(selected, ">").concat(v, "</option>"));
|
|||
|
}
|
|||
|
|
|||
|
if (selected) {
|
|||
|
if (element.get(0).selectize) {
|
|||
|
var _selectize = element.data('selectize');
|
|||
|
|
|||
|
_selectize.setValue(k);
|
|||
|
}
|
|||
|
|
|||
|
delete Data[holder].state[value];
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "refreshOptions",
|
|||
|
value: function refreshOptions(element, originalValue) {
|
|||
|
var value = element.val();
|
|||
|
var holder = element.closest('[data-collection-holder]').data('collectionHolder');
|
|||
|
delete Data[holder].state[value];
|
|||
|
|
|||
|
if (originalValue && Data[holder].original[originalValue]) {
|
|||
|
Data[holder].state[originalValue] = Data[holder].original[originalValue];
|
|||
|
}
|
|||
|
|
|||
|
this.items.each(function (index, select) {
|
|||
|
select = external_jQuery_default()(select);
|
|||
|
|
|||
|
if (select[0] === element[0]) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var selectedValue = select.val();
|
|||
|
select.data('dummyChange', true);
|
|||
|
|
|||
|
if (select.get(0).selectize) {
|
|||
|
var selectize = select.data('selectize');
|
|||
|
|
|||
|
if (selectize) {
|
|||
|
selectize.clearOptions();
|
|||
|
|
|||
|
if (selectedValue) {
|
|||
|
selectize.addOption({
|
|||
|
value: selectedValue,
|
|||
|
text: Data[holder].original[selectedValue] || selectedValue
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
forIn_default()(Data[holder].state, function (v, k) {
|
|||
|
selectize.addOption({
|
|||
|
value: k,
|
|||
|
text: v
|
|||
|
});
|
|||
|
});
|
|||
|
selectize.setValue(selectedValue, true);
|
|||
|
}
|
|||
|
} else {
|
|||
|
select.empty();
|
|||
|
forIn_default()(Data[holder].state, function (v, k) {
|
|||
|
var selected = k === selectedValue ? 'selected="selected"' : '';
|
|||
|
select.append("<option value=\"".concat(k, "\" ").concat(selected, ">").concat(v, "</option>"));
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
select.data('dummyChange', false);
|
|||
|
});
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return SelectUniqueField;
|
|||
|
}();
|
|||
|
|
|||
|
|
|||
|
var selectunique_Instance = new SelectUniqueField();
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/iconpicker.js
|
|||
|
function iconpicker_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function iconpicker_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 iconpicker_createClass(Constructor, protoProps, staticProps) { if (protoProps) iconpicker_defineProperties(Constructor.prototype, protoProps); if (staticProps) iconpicker_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
/* Icon Picker by QueryLoop
|
|||
|
* Author: @eliorivero
|
|||
|
* URL: http://queryloop.com/
|
|||
|
* License: GPLv2
|
|||
|
*/
|
|||
|
|
|||
|
var iconpicker_defaults = {
|
|||
|
'mode': 'dialog',
|
|||
|
// show overlay 'dialog' panel or slide down 'inline' panel
|
|||
|
'closeOnPick': true,
|
|||
|
// whether to close panel after picking or 'no'
|
|||
|
'save': 'class',
|
|||
|
// save icon 'class' or 'code'
|
|||
|
'size': '',
|
|||
|
'classes': {
|
|||
|
'launcher': '',
|
|||
|
// extra classes for launcher buttons
|
|||
|
'clear': 'remove-times',
|
|||
|
// extra classes for button that removes preview and clears field
|
|||
|
'highlight': '',
|
|||
|
// extra classes when highlighting an icon
|
|||
|
'close': '' // extra classes for close button
|
|||
|
|
|||
|
},
|
|||
|
'iconSets': {
|
|||
|
// example data structure. Used to specify which launchers will be created
|
|||
|
'genericon': 'Genericon',
|
|||
|
// create a launcher to pick genericon icons
|
|||
|
'fa': 'FontAwesome' // create a launcher to pick fontawesome icons
|
|||
|
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
var QL_Icon_Picker = /*#__PURE__*/function () {
|
|||
|
function QL_Icon_Picker(element, options) {
|
|||
|
iconpicker_classCallCheck(this, QL_Icon_Picker);
|
|||
|
|
|||
|
this.iconSet = '';
|
|||
|
this.iconSetName = '';
|
|||
|
this.$field = '';
|
|||
|
this.element = element;
|
|||
|
this.settings = external_jQuery_default().extend({}, iconpicker_defaults, options);
|
|||
|
this._defaults = iconpicker_defaults;
|
|||
|
this.init();
|
|||
|
}
|
|||
|
|
|||
|
iconpicker_createClass(QL_Icon_Picker, [{
|
|||
|
key: "init",
|
|||
|
value: function init() {
|
|||
|
var $brick = external_jQuery_default()(this.element);
|
|||
|
var pickerId = $brick.data('pickerid');
|
|||
|
var $preview = external_jQuery_default()('<div class="icon-preview icon-preview-' + pickerId + '" />');
|
|||
|
this.$field = $brick.find('input'); // Add preview area
|
|||
|
|
|||
|
this.makePreview($brick, pickerId, $preview); // Make button to clear field and remove preview
|
|||
|
|
|||
|
this.makeClear(pickerId, $preview); // Make buttons that open the panel of icons
|
|||
|
|
|||
|
this.makeLaunchers($brick, pickerId); // Prepare display styles, inline and dialog
|
|||
|
|
|||
|
this.makeDisplay($brick);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "makePreview",
|
|||
|
value: function makePreview($brick, pickerId, $preview) {
|
|||
|
var $icon = external_jQuery_default()('<i />');
|
|||
|
var iconValue = this.$field.val();
|
|||
|
$preview.prependTo($brick);
|
|||
|
$icon.prependTo($preview);
|
|||
|
|
|||
|
if (iconValue !== '') {
|
|||
|
$preview.addClass('icon-preview-on');
|
|||
|
$icon.addClass(iconValue);
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "makeClear",
|
|||
|
value: function makeClear(pickerId, $preview) {
|
|||
|
var base = this;
|
|||
|
var $clear = external_jQuery_default()('<a class="remove-icon ' + base.settings.classes.clear + '" />'); // Hide button to remove icon and preview and append it to preview area
|
|||
|
|
|||
|
$clear.hide().prependTo($preview); // If there's a icon saved in the field, show remove icon button
|
|||
|
|
|||
|
if (base.$field.val() !== '') {
|
|||
|
$clear.show();
|
|||
|
}
|
|||
|
|
|||
|
$preview.on('click', '.remove-icon', function (e) {
|
|||
|
e.preventDefault();
|
|||
|
base.$field.val('');
|
|||
|
$preview.removeClass('icon-preview-on').find('i').removeClass();
|
|||
|
external_jQuery_default()(this).hide();
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "makeDisplay",
|
|||
|
value: function makeDisplay($brick) {
|
|||
|
var base = this;
|
|||
|
var close = base.settings.classes.close;
|
|||
|
var $body = external_jQuery_default()('body');
|
|||
|
var $close = external_jQuery_default()('<a href="#" class="icon-picker-close"/>');
|
|||
|
|
|||
|
if (base.settings.mode === 'inline') {
|
|||
|
$brick.find('.icon-set').append($close).removeClass('dialog').addClass('ip-inline ' + base.settings.size).parent().addClass('icon-set-wrap');
|
|||
|
} else if (base.settings.mode === 'dialog') {
|
|||
|
external_jQuery_default()('.icon-set').addClass('dialog ' + base.settings.size);
|
|||
|
|
|||
|
if (external_jQuery_default()('.icon-picker-overlay').length <= 0) {
|
|||
|
$body.append('<div class="icon-picker-overlay"/>').append($close);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
$body.on('click', '.icon-picker-close, .icon-picker-overlay', function (e) {
|
|||
|
e.preventDefault();
|
|||
|
base.closePicker($brick, external_jQuery_default()(base.iconSet), base.settings.mode);
|
|||
|
}).on('mouseenter mouseleave', '.icon-picker-close', function (e) {
|
|||
|
if (e.type === 'mouseenter') {
|
|||
|
external_jQuery_default()(this).addClass(close);
|
|||
|
} else {
|
|||
|
external_jQuery_default()(this).removeClass(close);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "makeLaunchers",
|
|||
|
value: function makeLaunchers($brick) {
|
|||
|
var base = this;
|
|||
|
var dataIconSets = $brick.data('iconsets');
|
|||
|
var iconSet;
|
|||
|
|
|||
|
if (typeof dataIconSets === 'undefined') {
|
|||
|
dataIconSets = base.settings.iconSets;
|
|||
|
}
|
|||
|
|
|||
|
for (iconSet in dataIconSets) {
|
|||
|
if (dataIconSets.hasOwnProperty(iconSet)) {
|
|||
|
$brick.append('<a class="launch-icons button ' + base.settings.classes.launcher + '" data-icons="' + iconSet + '">' + dataIconSets[iconSet] + '</a>');
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
$brick.find('.launch-icons').on('click', function (e) {
|
|||
|
e.preventDefault();
|
|||
|
var $self = external_jQuery_default()(this);
|
|||
|
var theseIcons = $self.data('icons');
|
|||
|
base.iconSetName = theseIcons;
|
|||
|
base.iconSet = '.' + theseIcons + '-set'; // Initialize picker
|
|||
|
|
|||
|
base.iconPick($brick); // Show icon picker
|
|||
|
|
|||
|
base.showPicker($brick, external_jQuery_default()(base.iconSet), base.settings.mode);
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "iconPick",
|
|||
|
value: function iconPick($brick) {
|
|||
|
var base = this;
|
|||
|
var highlight = 'icon-highlight ' + base.settings.classes.highlight;
|
|||
|
external_jQuery_default()(base.iconSet).on('click', 'li', function (e) {
|
|||
|
e.preventDefault();
|
|||
|
var $icon = external_jQuery_default()(this);
|
|||
|
var icon = $icon.data(base.settings.save); // Mark as selected
|
|||
|
|
|||
|
external_jQuery_default()('.icon-selected').removeClass('icon-selected');
|
|||
|
$icon.addClass('icon-selected');
|
|||
|
|
|||
|
if (base.$field.data('format') === 'short') {
|
|||
|
icon = icon.slice(6);
|
|||
|
} // Save icon value to field
|
|||
|
|
|||
|
|
|||
|
base.$field.val(icon); // Close icon picker
|
|||
|
|
|||
|
if (base.settings.closeOnPick) {
|
|||
|
base.closePicker($brick, $icon.closest(base.iconSet), base.settings.mode);
|
|||
|
} // Set preview
|
|||
|
|
|||
|
|
|||
|
base.setPreview($icon.data('class')); // Broadcast event passing the selected icon.
|
|||
|
|
|||
|
external_jQuery_default()('body').trigger('iconselected.queryloop', icon);
|
|||
|
});
|
|||
|
external_jQuery_default()(base.iconSet).on('mouseenter mouseleave', 'li', function (e) {
|
|||
|
if (e.type === 'mouseenter') {
|
|||
|
external_jQuery_default()(this).addClass(highlight);
|
|||
|
} else {
|
|||
|
external_jQuery_default()(this).removeClass(highlight);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "showPicker",
|
|||
|
value: function showPicker($brick, $icons, mode) {
|
|||
|
if (mode === 'inline') {
|
|||
|
external_jQuery_default()('.icon-set').removeClass('ip-inline-open');
|
|||
|
$brick.find($icons).toggleClass('ip-inline-open');
|
|||
|
} else if (mode === 'dialog') {
|
|||
|
$brick.find('.icon-picker-close').addClass('make-visible');
|
|||
|
$brick.find('.icon-picker-overlay').addClass('make-visible');
|
|||
|
$icons.addClass('dialog-open');
|
|||
|
}
|
|||
|
|
|||
|
$icons.find('.icon-selected').removeClass('icon-selected');
|
|||
|
var selectedIcon = this.$field.val().replace(' ', '.');
|
|||
|
|
|||
|
if (selectedIcon !== '') {
|
|||
|
if (this.settings.save === 'class') {
|
|||
|
$icons.find('.' + selectedIcon).addClass('icon-selected');
|
|||
|
} else {
|
|||
|
$icons.find('[data-code="' + selectedIcon + '"]').addClass('icon-selected');
|
|||
|
}
|
|||
|
} // Broadcast event when the picker is shown passing the picker mode.
|
|||
|
|
|||
|
|
|||
|
external_jQuery_default()('body').trigger('iconpickershow.queryloop', mode);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "closePicker",
|
|||
|
value: function closePicker($brick, $icons, mode) {
|
|||
|
// Remove event so they don't fire from a different picker
|
|||
|
external_jQuery_default()(this.iconSet).off('click', 'li');
|
|||
|
|
|||
|
if (mode === 'inline') {
|
|||
|
$brick.find($icons).removeClass('ip-inline-open');
|
|||
|
} else if (mode === 'dialog') {
|
|||
|
external_jQuery_default()('.icon-picker-close, .icon-picker-overlay').removeClass('make-visible');
|
|||
|
} // Broadcast event when the picker is closed passing the picker mode.
|
|||
|
|
|||
|
|
|||
|
external_jQuery_default()('body').trigger('iconpickerclose.queryloop', mode);
|
|||
|
external_jQuery_default()('.icon-set').removeClass('dialog-open');
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "setPreview",
|
|||
|
value: function setPreview(preview) {
|
|||
|
var $preview = external_jQuery_default()(this.element).find('.icon-preview');
|
|||
|
$preview.addClass('icon-preview-on').find('i').removeClass().addClass(this.iconSetName).addClass(preview);
|
|||
|
$preview.find('a').show();
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return QL_Icon_Picker;
|
|||
|
}();
|
|||
|
/* Grav */
|
|||
|
// extend $ with 3rd party QL Icon Picker
|
|||
|
|
|||
|
|
|||
|
(external_jQuery_default()).fn.qlIconPicker = function (options) {
|
|||
|
this.each(function () {
|
|||
|
if (!external_jQuery_default().data(this, 'plugin_qlIconPicker')) {
|
|||
|
external_jQuery_default().data(this, 'plugin_qlIconPicker', new QL_Icon_Picker(this, options));
|
|||
|
}
|
|||
|
});
|
|||
|
return this;
|
|||
|
};
|
|||
|
|
|||
|
var IconpickerField = /*#__PURE__*/function () {
|
|||
|
function IconpickerField(options) {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
iconpicker_classCallCheck(this, IconpickerField);
|
|||
|
|
|||
|
this.items = external_jQuery_default()();
|
|||
|
this.options = Object.assign({}, this.defaults, options);
|
|||
|
external_jQuery_default()('[data-grav-iconpicker]').each(function (index, element) {
|
|||
|
return _this.addItem(element);
|
|||
|
});
|
|||
|
external_jQuery_default()('body').on('mutation._grav', this._onAddedNodes.bind(this));
|
|||
|
}
|
|||
|
|
|||
|
iconpicker_createClass(IconpickerField, [{
|
|||
|
key: "_onAddedNodes",
|
|||
|
value: function _onAddedNodes(event, target
|
|||
|
/* , record, instance */
|
|||
|
) {
|
|||
|
var _this2 = this;
|
|||
|
|
|||
|
var fields = external_jQuery_default()(target).find('[data-grav-iconpicker]');
|
|||
|
|
|||
|
if (!fields.length) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
fields.each(function (index, field) {
|
|||
|
field = external_jQuery_default()(field);
|
|||
|
|
|||
|
if (!~_this2.items.index(field)) {
|
|||
|
_this2.addItem(field);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "addItem",
|
|||
|
value: function addItem(element) {
|
|||
|
element = external_jQuery_default()(element);
|
|||
|
this.items = this.items.add(element);
|
|||
|
element.find('.icon-picker').qlIconPicker({
|
|||
|
'save': 'class'
|
|||
|
}); // hack to remove extra icon sets that are just copies
|
|||
|
|
|||
|
external_jQuery_default()('.icon-set:not(:first)').remove();
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return IconpickerField;
|
|||
|
}();
|
|||
|
|
|||
|
|
|||
|
var iconpicker_Instance = new IconpickerField(); // Fix to close the dialog when clicking outside
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', function (event) {
|
|||
|
var target = external_jQuery_default()(event.target);
|
|||
|
var match = '.icon-set.dialog-open, .launch-icons[data-icons]';
|
|||
|
|
|||
|
if (!target.is(match) && !target.closest(match).length) {
|
|||
|
var dialogs = external_jQuery_default()('.icon-set.dialog-open'); // skip if there's no dialog open
|
|||
|
|
|||
|
if (dialogs.length) {
|
|||
|
dialogs.each(function (index, dialog) {
|
|||
|
var picker = external_jQuery_default()(dialog).siblings('.icon-picker');
|
|||
|
var data = picker.data('plugin_qlIconPicker');
|
|||
|
data.closePicker(picker, external_jQuery_default()(data.iconSet), data.settings.mode);
|
|||
|
});
|
|||
|
}
|
|||
|
}
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/utils/cron-ui.js
|
|||
|
function cron_ui_typeof(obj) { "@babel/helpers - typeof"; return cron_ui_typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, cron_ui_typeof(obj); }
|
|||
|
|
|||
|
/* eslint-disable */
|
|||
|
|
|||
|
/*
|
|||
|
* This file is part of the Arnapou jqCron package.
|
|||
|
*
|
|||
|
* (c) Arnaud Buathier <arnaud@arnapou.net>
|
|||
|
*
|
|||
|
* For the full copyright and license information, please view the LICENSE
|
|||
|
* file that was distributed with this source code.
|
|||
|
*/
|
|||
|
|
|||
|
/**
|
|||
|
* Default settings
|
|||
|
*/
|
|||
|
|
|||
|
var jqCronDefaultSettings = {
|
|||
|
texts: {},
|
|||
|
monthdays: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31],
|
|||
|
hours: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23],
|
|||
|
hour_labels: ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "15", "16", "17", "18", "19", "20", "21", "22", "23"],
|
|||
|
minutes: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59],
|
|||
|
lang: 'en',
|
|||
|
enabled_minute: false,
|
|||
|
enabled_hour: true,
|
|||
|
enabled_day: true,
|
|||
|
enabled_week: true,
|
|||
|
enabled_month: true,
|
|||
|
enabled_year: true,
|
|||
|
multiple_dom: false,
|
|||
|
multiple_month: false,
|
|||
|
multiple_mins: false,
|
|||
|
multiple_dow: false,
|
|||
|
multiple_time_hours: false,
|
|||
|
multiple_time_minutes: false,
|
|||
|
numeric_zero_pad: false,
|
|||
|
default_period: 'day',
|
|||
|
default_value: '',
|
|||
|
no_reset_button: true,
|
|||
|
disabled: false,
|
|||
|
bind_to: null,
|
|||
|
bind_method: {
|
|||
|
set: function set($element, value) {
|
|||
|
$element.is(':input') ? $element.val(value) : $element.data('jqCronValue', value);
|
|||
|
},
|
|||
|
get: function get($element) {
|
|||
|
return $element.is(':input') ? $element.val() : $element.data('jqCronValue');
|
|||
|
}
|
|||
|
}
|
|||
|
};
|
|||
|
/**
|
|||
|
* Custom extend of json for jqCron settings.
|
|||
|
* We don't use jQuery.extend because simple extend does not fit our needs, and deep extend has a bad
|
|||
|
* feature for us : it replaces keys of "Arrays" instead of replacing the full array.
|
|||
|
*/
|
|||
|
|
|||
|
(function ($) {
|
|||
|
var extend = function extend(dst, src) {
|
|||
|
for (var i in src) {
|
|||
|
if ($.isPlainObject(src[i])) {
|
|||
|
dst[i] = extend(dst[i] && $.isPlainObject(dst[i]) ? dst[i] : {}, src[i]);
|
|||
|
} else if ($.isArray(src[i])) {
|
|||
|
dst[i] = src[i].slice(0);
|
|||
|
} else if (src[i] !== undefined) {
|
|||
|
dst[i] = src[i];
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
return dst;
|
|||
|
};
|
|||
|
|
|||
|
this.jqCronMergeSettings = function (obj) {
|
|||
|
return extend(extend({}, jqCronDefaultSettings), obj || {});
|
|||
|
};
|
|||
|
}).call(window, (external_jQuery_default()));
|
|||
|
/**
|
|||
|
* Shortcut to get the instance of jqCron instance from one jquery object
|
|||
|
*/
|
|||
|
|
|||
|
(function ($) {
|
|||
|
$.fn.jqCronGetInstance = function () {
|
|||
|
return this.data('jqCron');
|
|||
|
};
|
|||
|
}).call(window, (external_jQuery_default()));
|
|||
|
/**
|
|||
|
* Main plugin
|
|||
|
*/
|
|||
|
|
|||
|
(function ($) {
|
|||
|
$.fn.jqCron = function (settings) {
|
|||
|
var saved_settings = settings;
|
|||
|
return this.each(function () {
|
|||
|
var cron, saved;
|
|||
|
var $this = $(this);
|
|||
|
var settings = jqCronMergeSettings(saved_settings); // clone settings
|
|||
|
|
|||
|
var translations = settings.texts[settings.lang];
|
|||
|
|
|||
|
if (cron_ui_typeof(translations) !== 'object' || $.isEmptyObject(translations)) {
|
|||
|
console && console.error('Missing translations for language "' + settings.lang + '". ' + 'Please include jqCron.' + settings.lang + '.js or manually provide ' + 'the necessary translations when calling $.fn.jqCron().');
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
if (!settings.jquery_container) {
|
|||
|
if ($this.is(':container')) {
|
|||
|
settings.jquery_element = $this.uniqueId('jqCron');
|
|||
|
} else if ($this.is(':autoclose')) {
|
|||
|
// delete already generated dom if exists
|
|||
|
if ($this.next('.jqCron').length == 1) {
|
|||
|
$this.next('.jqCron').remove();
|
|||
|
} // generate new
|
|||
|
|
|||
|
|
|||
|
settings.jquery_element = $('<span class="jqCron"></span>').uniqueId('jqCron').insertAfter($this);
|
|||
|
} else {
|
|||
|
console && console.error(settings.texts[settings.lang].error1.replace('%s', this.tagName));
|
|||
|
return;
|
|||
|
}
|
|||
|
} // autoset bind_to if it is an input
|
|||
|
|
|||
|
|
|||
|
if ($this.is(':input')) {
|
|||
|
settings.bind_to = settings.bind_to || $this;
|
|||
|
} // init cron object
|
|||
|
|
|||
|
|
|||
|
if (settings.bind_to) {
|
|||
|
if (settings.bind_to.is(':input')) {
|
|||
|
// auto bind from input to object if an input, textarea ...
|
|||
|
settings.bind_to.blur(function () {
|
|||
|
var value = settings.bind_method.get(settings.bind_to);
|
|||
|
$this.jqCronGetInstance().setCron(value);
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
saved = settings.bind_method.get(settings.bind_to);
|
|||
|
cron = new jqCron(settings);
|
|||
|
cron.setCron(saved);
|
|||
|
} else {
|
|||
|
cron = new jqCron(settings);
|
|||
|
}
|
|||
|
|
|||
|
$(this).data('jqCron', cron);
|
|||
|
});
|
|||
|
};
|
|||
|
}).call(window, (external_jQuery_default()));
|
|||
|
/**
|
|||
|
* jqCron class
|
|||
|
*/
|
|||
|
|
|||
|
(function ($) {
|
|||
|
var jqCronInstances = [];
|
|||
|
|
|||
|
function jqCron(settings) {
|
|||
|
var _initialized = false;
|
|||
|
|
|||
|
var _self = this;
|
|||
|
|
|||
|
var _$elt = this;
|
|||
|
|
|||
|
var _$obj = $('<span class="jqCron-container"></span>');
|
|||
|
|
|||
|
var _$blocks = $('<span class="jqCron-blocks"></span>');
|
|||
|
|
|||
|
var _$blockPERIOD = $('<span class="jqCron-period"></span>');
|
|||
|
|
|||
|
var _$blockDOM = $('<span class="jqCron-dom"></span>');
|
|||
|
|
|||
|
var _$blockMONTH = $('<span class="jqCron-month"></span>');
|
|||
|
|
|||
|
var _$blockMINS = $('<span class="jqCron-mins"></span>');
|
|||
|
|
|||
|
var _$blockDOW = $('<span class="jqCron-dow"></span>');
|
|||
|
|
|||
|
var _$blockTIME = $('<span class="jqCron-time"></span>');
|
|||
|
|
|||
|
var _$cross = $('<span class="jqCron-cross">✘</span>');
|
|||
|
|
|||
|
var _selectors = [];
|
|||
|
|
|||
|
var _selectorPeriod, _selectorMins, _selectorTimeH, _selectorTimeM, _selectorDow, _selectorDom, _selectorMonth; // instanciate a new selector
|
|||
|
|
|||
|
|
|||
|
function newSelector($block, multiple, type) {
|
|||
|
var selector = new jqCronSelector(_self, $block, multiple, type);
|
|||
|
selector.$.bind('selector:open', function () {
|
|||
|
// we close all opened selectors of all other jqCron
|
|||
|
for (var n = jqCronInstances.length; n--;) {
|
|||
|
if (jqCronInstances[n] != _self) {
|
|||
|
jqCronInstances[n].closeSelectors();
|
|||
|
} else {
|
|||
|
// we close all other opened selectors of this jqCron
|
|||
|
for (var o = _selectors.length; o--;) {
|
|||
|
if (_selectors[o] != selector) {
|
|||
|
_selectors[o].close();
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
});
|
|||
|
selector.$.bind('selector:change', function () {
|
|||
|
var boundChanged = false; // don't propagate if not initialized
|
|||
|
|
|||
|
if (!_initialized) return; // bind data between two minute selectors (only if they have the same multiple settings)
|
|||
|
|
|||
|
if (settings.multiple_mins == settings.multiple_time_minutes) {
|
|||
|
if (selector == _selectorMins) {
|
|||
|
boundChanged = _selectorTimeM.setValue(_selectorMins.getValue());
|
|||
|
} else if (selector == _selectorTimeM) {
|
|||
|
boundChanged = _selectorMins.setValue(_selectorTimeM.getValue());
|
|||
|
}
|
|||
|
} // we propagate the change event to the main object
|
|||
|
|
|||
|
|
|||
|
boundChanged || _$obj.trigger('cron:change', _self.getCron());
|
|||
|
});
|
|||
|
|
|||
|
_selectors.push(selector);
|
|||
|
|
|||
|
return selector;
|
|||
|
} // disable the selector
|
|||
|
|
|||
|
|
|||
|
this.disable = function () {
|
|||
|
_$obj.addClass('disable');
|
|||
|
|
|||
|
settings.disable = true;
|
|||
|
|
|||
|
_self.closeSelectors();
|
|||
|
}; // return if the selector is disabled
|
|||
|
|
|||
|
|
|||
|
this.isDisabled = function () {
|
|||
|
return settings.disable == true;
|
|||
|
}; // enable the selector
|
|||
|
|
|||
|
|
|||
|
this.enable = function () {
|
|||
|
_$obj.removeClass('disable');
|
|||
|
|
|||
|
settings.disable = false;
|
|||
|
}; // get cron value
|
|||
|
|
|||
|
|
|||
|
this.getCron = function () {
|
|||
|
var period = _selectorPeriod.getValue();
|
|||
|
|
|||
|
var items = ['*', '*', '*', '*', '*'];
|
|||
|
|
|||
|
if (period == 'hour') {
|
|||
|
items[0] = _selectorMins.getCronValue();
|
|||
|
}
|
|||
|
|
|||
|
if (period == 'day' || period == 'week' || period == 'month' || period == 'year') {
|
|||
|
items[0] = _selectorTimeM.getCronValue();
|
|||
|
items[1] = _selectorTimeH.getCronValue();
|
|||
|
}
|
|||
|
|
|||
|
if (period == 'month' || period == 'year') {
|
|||
|
items[2] = _selectorDom.getCronValue();
|
|||
|
}
|
|||
|
|
|||
|
if (period == 'year') {
|
|||
|
items[3] = _selectorMonth.getCronValue();
|
|||
|
}
|
|||
|
|
|||
|
if (period == 'week') {
|
|||
|
items[4] = _selectorDow.getCronValue();
|
|||
|
}
|
|||
|
|
|||
|
return items.join(' ');
|
|||
|
}; // set cron (string like * * * * *)
|
|||
|
|
|||
|
|
|||
|
this.setCron = function (str) {
|
|||
|
if (!str) return;
|
|||
|
|
|||
|
try {
|
|||
|
str = str.replace(/\s+/g, ' ').replace(/^ +/, '').replace(/ +$/, ''); // sanitize
|
|||
|
|
|||
|
var mask = str.replace(/[^\* ]/g, '-').replace(/-+/g, '-').replace(/ +/g, '');
|
|||
|
var items = str.split(' ');
|
|||
|
if (items.length != 5) _self.error(_self.getText('error2'));
|
|||
|
|
|||
|
if (mask == '*****') {
|
|||
|
// 1 possibility
|
|||
|
_selectorPeriod.setValue('minute');
|
|||
|
} else if (mask == '-****') {
|
|||
|
// 1 possibility
|
|||
|
_selectorPeriod.setValue('hour');
|
|||
|
|
|||
|
_selectorMins.setCronValue(items[0]);
|
|||
|
|
|||
|
_selectorTimeM.setCronValue(items[0]);
|
|||
|
} else if (mask.substring(2, mask.length) == '***') {
|
|||
|
// 4 possibilities
|
|||
|
_selectorPeriod.setValue('day');
|
|||
|
|
|||
|
_selectorMins.setCronValue(items[0]);
|
|||
|
|
|||
|
_selectorTimeM.setCronValue(items[0]);
|
|||
|
|
|||
|
_selectorTimeH.setCronValue(items[1]);
|
|||
|
} else if (mask.substring(2, mask.length) == '-**') {
|
|||
|
// 4 possibilities
|
|||
|
_selectorPeriod.setValue('month');
|
|||
|
|
|||
|
_selectorMins.setCronValue(items[0]);
|
|||
|
|
|||
|
_selectorTimeM.setCronValue(items[0]);
|
|||
|
|
|||
|
_selectorTimeH.setCronValue(items[1]);
|
|||
|
|
|||
|
_selectorDom.setCronValue(items[2]);
|
|||
|
} else if (mask.substring(2, mask.length) == '**-') {
|
|||
|
// 4 possibilities
|
|||
|
_selectorPeriod.setValue('week');
|
|||
|
|
|||
|
_selectorMins.setCronValue(items[0]);
|
|||
|
|
|||
|
_selectorTimeM.setCronValue(items[0]);
|
|||
|
|
|||
|
_selectorTimeH.setCronValue(items[1]);
|
|||
|
|
|||
|
_selectorDow.setCronValue(items[4]);
|
|||
|
} else if (mask.substring(3, mask.length) == '-*') {
|
|||
|
// 8 possibilities
|
|||
|
_selectorPeriod.setValue('year');
|
|||
|
|
|||
|
_selectorMins.setCronValue(items[0]);
|
|||
|
|
|||
|
_selectorTimeM.setCronValue(items[0]);
|
|||
|
|
|||
|
_selectorTimeH.setCronValue(items[1]);
|
|||
|
|
|||
|
_selectorDom.setCronValue(items[2]);
|
|||
|
|
|||
|
_selectorMonth.setCronValue(items[3]);
|
|||
|
} else {
|
|||
|
_self.error(_self.getText('error4'));
|
|||
|
}
|
|||
|
|
|||
|
_self.clearError();
|
|||
|
} catch (e) {}
|
|||
|
}; // close all child selectors
|
|||
|
|
|||
|
|
|||
|
this.closeSelectors = function () {
|
|||
|
for (var n = _selectors.length; n--;) {
|
|||
|
_selectors[n].close();
|
|||
|
}
|
|||
|
}; // get the main element id
|
|||
|
|
|||
|
|
|||
|
this.getId = function () {
|
|||
|
return _$elt.attr('id');
|
|||
|
}; // get the translated text
|
|||
|
|
|||
|
|
|||
|
this.getText = function (key) {
|
|||
|
var text = settings.texts[settings.lang][key] || null;
|
|||
|
|
|||
|
if (typeof text == "string" && text.match('<b')) {
|
|||
|
text = text.replace(/(<b *\/>)/gi, '</span><b /><span class="jqCron-text">');
|
|||
|
text = '<span class="jqCron-text">' + text + '</span>';
|
|||
|
}
|
|||
|
|
|||
|
return text;
|
|||
|
}; // get the human readable text
|
|||
|
|
|||
|
|
|||
|
this.getHumanText = function () {
|
|||
|
var texts = [];
|
|||
|
|
|||
|
_$obj.find('> span > span:visible').find('.jqCron-text, .jqCron-selector > span').each(function () {
|
|||
|
var text = $(this).text().replace(/\s+$/g, '').replace(/^\s+/g, '');
|
|||
|
text && texts.push(text);
|
|||
|
});
|
|||
|
|
|||
|
return texts.join(' ').replace(/\s:\s/g, ':');
|
|||
|
}; // get settings
|
|||
|
|
|||
|
|
|||
|
this.getSettings = function () {
|
|||
|
return settings;
|
|||
|
}; // display an error
|
|||
|
|
|||
|
|
|||
|
this.error = function (msg) {
|
|||
|
console && console.error('[jqCron Error] ' + msg);
|
|||
|
|
|||
|
_$obj.addClass('jqCron-error').attr('title', msg);
|
|||
|
|
|||
|
throw msg;
|
|||
|
}; // clear error
|
|||
|
|
|||
|
|
|||
|
this.clearError = function () {
|
|||
|
_$obj.attr('title', '').removeClass('jqCron-error');
|
|||
|
}; // clear
|
|||
|
|
|||
|
|
|||
|
this.clear = function () {
|
|||
|
_selectorDom.setValue([]);
|
|||
|
|
|||
|
_selectorDow.setValue([]);
|
|||
|
|
|||
|
_selectorMins.setValue([]);
|
|||
|
|
|||
|
_selectorMonth.setValue([]);
|
|||
|
|
|||
|
_selectorTimeH.setValue([]);
|
|||
|
|
|||
|
_selectorTimeM.setValue([]);
|
|||
|
|
|||
|
_self.triggerChange();
|
|||
|
}; // init (called in constructor)
|
|||
|
|
|||
|
|
|||
|
this.init = function () {
|
|||
|
var n, i, labelsList, list;
|
|||
|
if (_initialized) return;
|
|||
|
settings = jqCronMergeSettings(settings);
|
|||
|
settings.jquery_element || _self.error(_self.getText('error3'));
|
|||
|
_$elt = settings.jquery_element;
|
|||
|
|
|||
|
_$elt.append(_$obj);
|
|||
|
|
|||
|
_$obj.data('id', settings.id);
|
|||
|
|
|||
|
_$obj.data('jqCron', _self);
|
|||
|
|
|||
|
_$obj.append(_$blocks);
|
|||
|
|
|||
|
settings.no_reset_button || _$obj.append(_$cross);
|
|||
|
!settings.disable || _$obj.addClass('disable');
|
|||
|
|
|||
|
_$blocks.append(_$blockPERIOD);
|
|||
|
|
|||
|
if (/^(ko)$/i.test(settings.lang)) {
|
|||
|
_$blocks.append(_$blockMONTH, _$blockDOM);
|
|||
|
} else {
|
|||
|
_$blocks.append(_$blockDOM, _$blockMONTH);
|
|||
|
}
|
|||
|
|
|||
|
_$blocks.append(_$blockMINS);
|
|||
|
|
|||
|
_$blocks.append(_$blockDOW);
|
|||
|
|
|||
|
_$blocks.append(_$blockTIME); // various binding
|
|||
|
|
|||
|
|
|||
|
_$cross.click(function () {
|
|||
|
_self.isDisabled() || _self.clear();
|
|||
|
}); // binding from cron to target
|
|||
|
|
|||
|
|
|||
|
_$obj.bind('cron:change', function (evt, value) {
|
|||
|
if (!settings.bind_to) return;
|
|||
|
settings.bind_method.set && settings.bind_method.set(settings.bind_to, value);
|
|||
|
|
|||
|
_self.clearError();
|
|||
|
}); // PERIOD
|
|||
|
|
|||
|
|
|||
|
_$blockPERIOD.append(_self.getText('text_period'));
|
|||
|
|
|||
|
_selectorPeriod = newSelector(_$blockPERIOD, false, 'period');
|
|||
|
settings.enabled_minute && _selectorPeriod.add('minute', _self.getText('name_minute'));
|
|||
|
settings.enabled_hour && _selectorPeriod.add('hour', _self.getText('name_hour'));
|
|||
|
settings.enabled_day && _selectorPeriod.add('day', _self.getText('name_day'));
|
|||
|
settings.enabled_week && _selectorPeriod.add('week', _self.getText('name_week'));
|
|||
|
settings.enabled_month && _selectorPeriod.add('month', _self.getText('name_month'));
|
|||
|
settings.enabled_year && _selectorPeriod.add('year', _self.getText('name_year'));
|
|||
|
|
|||
|
_selectorPeriod.$.bind('selector:change', function (e, value) {
|
|||
|
_$blockDOM.hide();
|
|||
|
|
|||
|
_$blockMONTH.hide();
|
|||
|
|
|||
|
_$blockMINS.hide();
|
|||
|
|
|||
|
_$blockDOW.hide();
|
|||
|
|
|||
|
_$blockTIME.hide();
|
|||
|
|
|||
|
if (value == 'hour') {
|
|||
|
_$blockMINS.show();
|
|||
|
} else if (value == 'day') {
|
|||
|
_$blockTIME.show();
|
|||
|
} else if (value == 'week') {
|
|||
|
_$blockDOW.show();
|
|||
|
|
|||
|
_$blockTIME.show();
|
|||
|
} else if (value == 'month') {
|
|||
|
_$blockDOM.show();
|
|||
|
|
|||
|
_$blockTIME.show();
|
|||
|
} else if (value == 'year') {
|
|||
|
_$blockDOM.show();
|
|||
|
|
|||
|
_$blockMONTH.show();
|
|||
|
|
|||
|
_$blockTIME.show();
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
_selectorPeriod.setValue(settings.default_period); // MINS (minutes)
|
|||
|
|
|||
|
|
|||
|
_$blockMINS.append(_self.getText('text_mins'));
|
|||
|
|
|||
|
_selectorMins = newSelector(_$blockMINS, settings.multiple_mins, 'minutes');
|
|||
|
|
|||
|
for (i = 0, list = settings.minutes; i < list.length; i++) {
|
|||
|
_selectorMins.add(list[i], list[i]);
|
|||
|
} // TIME (hour:min)
|
|||
|
|
|||
|
|
|||
|
_$blockTIME.append(_self.getText('text_time'));
|
|||
|
|
|||
|
_selectorTimeH = newSelector(_$blockTIME, settings.multiple_time_hours, 'time_hours');
|
|||
|
|
|||
|
for (i = 0, list = settings.hours, labelsList = settings.hour_labels; i < list.length; i++) {
|
|||
|
_selectorTimeH.add(list[i], labelsList[i]);
|
|||
|
}
|
|||
|
|
|||
|
_selectorTimeM = newSelector(_$blockTIME, settings.multiple_time_minutes, 'time_minutes');
|
|||
|
|
|||
|
for (i = 0, list = settings.minutes; i < list.length; i++) {
|
|||
|
_selectorTimeM.add(list[i], list[i]);
|
|||
|
} // DOW (day of week)
|
|||
|
|
|||
|
|
|||
|
_$blockDOW.append(_self.getText('text_dow'));
|
|||
|
|
|||
|
_selectorDow = newSelector(_$blockDOW, settings.multiple_dow, 'day_of_week');
|
|||
|
|
|||
|
for (i = 0, list = _self.getText('weekdays'); i < list.length; i++) {
|
|||
|
_selectorDow.add(i + 1, list[i]);
|
|||
|
} // DOM (day of month)
|
|||
|
|
|||
|
|
|||
|
_$blockDOM.append(_self.getText('text_dom'));
|
|||
|
|
|||
|
_selectorDom = newSelector(_$blockDOM, settings.multiple_dom, 'day_of_month');
|
|||
|
|
|||
|
for (i = 0, list = settings.monthdays; i < list.length; i++) {
|
|||
|
_selectorDom.add(list[i], list[i]);
|
|||
|
} // MONTH (day of week)
|
|||
|
|
|||
|
|
|||
|
_$blockMONTH.append(_self.getText('text_month'));
|
|||
|
|
|||
|
_selectorMonth = newSelector(_$blockMONTH, settings.multiple_month, 'month');
|
|||
|
|
|||
|
for (i = 0, list = _self.getText('months'); i < list.length; i++) {
|
|||
|
_selectorMonth.add(i + 1, list[i]);
|
|||
|
} // close all selectors when we click in body
|
|||
|
|
|||
|
|
|||
|
$('body').click(function () {
|
|||
|
var i,
|
|||
|
n = _selectors.length;
|
|||
|
|
|||
|
for (i = 0; i < n; i++) {
|
|||
|
_selectors[i].close();
|
|||
|
}
|
|||
|
});
|
|||
|
_initialized = true; // default value
|
|||
|
|
|||
|
if (settings.default_value) {
|
|||
|
_self.setCron(settings.default_value);
|
|||
|
}
|
|||
|
}; // trigger a change event
|
|||
|
|
|||
|
|
|||
|
this.triggerChange = function () {
|
|||
|
_$obj.trigger('cron:change', _self.getCron());
|
|||
|
}; // store instance in array
|
|||
|
|
|||
|
|
|||
|
jqCronInstances.push(this); // expose main jquery object
|
|||
|
|
|||
|
this.$ = _$obj; // init
|
|||
|
|
|||
|
try {
|
|||
|
this.init();
|
|||
|
|
|||
|
_self.triggerChange();
|
|||
|
} catch (e) {}
|
|||
|
}
|
|||
|
|
|||
|
this.jqCron = jqCron;
|
|||
|
}).call(window, (external_jQuery_default()));
|
|||
|
/**
|
|||
|
* jqCronSelector class
|
|||
|
*/
|
|||
|
|
|||
|
(function ($) {
|
|||
|
function jqCronSelector(_cron, _$block, _multiple, _type) {
|
|||
|
var _self = this;
|
|||
|
|
|||
|
var _$list = $('<ul class="jqCron-selector-list"></ul>');
|
|||
|
|
|||
|
var _$title = $('<span class="jqCron-selector-title"></span>');
|
|||
|
|
|||
|
var _$selector = $('<span class="jqCron-selector"></span>');
|
|||
|
|
|||
|
var _values = {};
|
|||
|
var _value = [];
|
|||
|
var _hasNumericTexts = true;
|
|||
|
|
|||
|
var _numeric_zero_pad = _cron.getSettings().numeric_zero_pad; // return an array without doublon
|
|||
|
|
|||
|
|
|||
|
function array_unique(l) {
|
|||
|
var i = 0,
|
|||
|
n = l.length,
|
|||
|
k = {},
|
|||
|
a = [];
|
|||
|
|
|||
|
while (i < n) {
|
|||
|
k[l[i]] || (k[l[i]] = true && a.push(l[i]));
|
|||
|
i++;
|
|||
|
}
|
|||
|
|
|||
|
return a;
|
|||
|
} // get the value (an array if multiple, else a single value)
|
|||
|
|
|||
|
|
|||
|
this.getValue = function () {
|
|||
|
return _multiple ? _value : _value[0];
|
|||
|
}; // get a correct string for cron
|
|||
|
|
|||
|
|
|||
|
this.getCronValue = function () {
|
|||
|
if (_value.length == 0) return '*';
|
|||
|
var cron = [_value[0]],
|
|||
|
i,
|
|||
|
s = _value[0],
|
|||
|
c = _value[0],
|
|||
|
n = _value.length;
|
|||
|
|
|||
|
for (i = 1; i < n; i++) {
|
|||
|
if (_value[i] == c + 1) {
|
|||
|
c = _value[i];
|
|||
|
cron[cron.length - 1] = s + '-' + c;
|
|||
|
} else {
|
|||
|
s = c = _value[i];
|
|||
|
cron.push(c);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
return cron.join(',');
|
|||
|
}; // set the cron value
|
|||
|
|
|||
|
|
|||
|
this.setCronValue = function (str) {
|
|||
|
var values = [],
|
|||
|
m,
|
|||
|
i,
|
|||
|
n;
|
|||
|
|
|||
|
if (str !== '*') {
|
|||
|
while (str != '') {
|
|||
|
// test "*/n" expression
|
|||
|
m = str.match(/^\*\/([0-9]+),?/);
|
|||
|
|
|||
|
if (m && m.length == 2) {
|
|||
|
for (i = 0; i <= 59; i += m[1] | 0) {
|
|||
|
values.push(i);
|
|||
|
}
|
|||
|
|
|||
|
str = str.replace(m[0], '');
|
|||
|
continue;
|
|||
|
} // test "a-b/n" expression
|
|||
|
|
|||
|
|
|||
|
m = str.match(/^([0-9]+)-([0-9]+)\/([0-9]+),?/);
|
|||
|
|
|||
|
if (m && m.length == 4) {
|
|||
|
for (i = m[1] | 0; i <= (m[2] | 0); i += m[3] | 0) {
|
|||
|
values.push(i);
|
|||
|
}
|
|||
|
|
|||
|
str = str.replace(m[0], '');
|
|||
|
continue;
|
|||
|
} // test "a-b" expression
|
|||
|
|
|||
|
|
|||
|
m = str.match(/^([0-9]+)-([0-9]+),?/);
|
|||
|
|
|||
|
if (m && m.length == 3) {
|
|||
|
for (i = m[1] | 0; i <= (m[2] | 0); i++) {
|
|||
|
values.push(i);
|
|||
|
}
|
|||
|
|
|||
|
str = str.replace(m[0], '');
|
|||
|
continue;
|
|||
|
} // test "c" expression
|
|||
|
|
|||
|
|
|||
|
m = str.match(/^([0-9]+),?/);
|
|||
|
|
|||
|
if (m && m.length == 2) {
|
|||
|
values.push(m[1] | 0);
|
|||
|
str = str.replace(m[0], '');
|
|||
|
continue;
|
|||
|
} // something goes wrong in the expression
|
|||
|
|
|||
|
|
|||
|
return;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
_self.setValue(values);
|
|||
|
}; // close the selector
|
|||
|
|
|||
|
|
|||
|
this.close = function () {
|
|||
|
_$selector.trigger('selector:close');
|
|||
|
}; // open the selector
|
|||
|
|
|||
|
|
|||
|
this.open = function () {
|
|||
|
_$selector.trigger('selector:open');
|
|||
|
}; // whether the selector is open
|
|||
|
|
|||
|
|
|||
|
this.isOpened = function () {
|
|||
|
return _$list.is(':visible');
|
|||
|
}; // add a selected value to the list
|
|||
|
|
|||
|
|
|||
|
this.addValue = function (key) {
|
|||
|
var values = _multiple ? _value.slice(0) : []; // clone array
|
|||
|
|
|||
|
values.push(key);
|
|||
|
|
|||
|
_self.setValue(values);
|
|||
|
}; // remove a selected value from the list
|
|||
|
|
|||
|
|
|||
|
this.removeValue = function (key) {
|
|||
|
if (_multiple) {
|
|||
|
var i,
|
|||
|
newValue = [];
|
|||
|
|
|||
|
for (i = 0; i < _value.length; i++) {
|
|||
|
if (key != [_value[i]]) {
|
|||
|
newValue.push(_value[i]);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
_self.setValue(newValue);
|
|||
|
} else {
|
|||
|
_self.clear();
|
|||
|
}
|
|||
|
}; // set the selected value(s) of the list
|
|||
|
|
|||
|
|
|||
|
this.setValue = function (keys) {
|
|||
|
var i,
|
|||
|
newKeys = [],
|
|||
|
saved = _value.join(' ');
|
|||
|
|
|||
|
if (!$.isArray(keys)) keys = [keys];
|
|||
|
|
|||
|
_$list.find('li').removeClass('selected');
|
|||
|
|
|||
|
keys = array_unique(keys);
|
|||
|
keys.sort(function (a, b) {
|
|||
|
var ta = cron_ui_typeof(a);
|
|||
|
|
|||
|
var tb = cron_ui_typeof(b);
|
|||
|
|
|||
|
if (ta == tb && ta == "number") return a - b;else return String(a) == String(b) ? 0 : String(a) < String(b) ? -1 : 1;
|
|||
|
});
|
|||
|
|
|||
|
if (_multiple) {
|
|||
|
for (i = 0; i < keys.length; i++) {
|
|||
|
if (keys[i] in _values) {
|
|||
|
_values[keys[i]].addClass('selected');
|
|||
|
|
|||
|
newKeys.push(keys[i]);
|
|||
|
}
|
|||
|
}
|
|||
|
} else {
|
|||
|
if (keys[0] in _values) {
|
|||
|
_values[keys[0]].addClass('selected');
|
|||
|
|
|||
|
newKeys.push(keys[0]);
|
|||
|
}
|
|||
|
} // remove unallowed values
|
|||
|
|
|||
|
|
|||
|
_value = newKeys;
|
|||
|
|
|||
|
if (saved != _value.join(' ')) {
|
|||
|
_$selector.trigger('selector:change', _multiple ? keys : keys[0]);
|
|||
|
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
return false;
|
|||
|
}; // get the title text
|
|||
|
|
|||
|
|
|||
|
this.getTitleText = function () {
|
|||
|
var getValueText = function getValueText(key) {
|
|||
|
return key in _values ? _values[key].text() : key;
|
|||
|
};
|
|||
|
|
|||
|
if (_value.length == 0) {
|
|||
|
return _cron.getText('empty_' + _type) || _cron.getText('empty');
|
|||
|
}
|
|||
|
|
|||
|
var cron = [getValueText(_value[0])],
|
|||
|
i,
|
|||
|
s = _value[0],
|
|||
|
c = _value[0],
|
|||
|
n = _value.length;
|
|||
|
|
|||
|
for (i = 1; i < n; i++) {
|
|||
|
if (_value[i] == c + 1) {
|
|||
|
c = _value[i];
|
|||
|
cron[cron.length - 1] = getValueText(s) + '-' + getValueText(c);
|
|||
|
} else {
|
|||
|
s = c = _value[i];
|
|||
|
cron.push(getValueText(c));
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
return cron.join(',');
|
|||
|
}; // clear list
|
|||
|
|
|||
|
|
|||
|
this.clear = function () {
|
|||
|
_values = {};
|
|||
|
|
|||
|
_self.setValue([]);
|
|||
|
|
|||
|
_$list.empty();
|
|||
|
}; // add a (key, value) pair
|
|||
|
|
|||
|
|
|||
|
this.add = function (key, value) {
|
|||
|
if (!(value + '').match(/^[0-9]+$/)) _hasNumericTexts = false;
|
|||
|
|
|||
|
if (_numeric_zero_pad && _hasNumericTexts && value < 10) {
|
|||
|
value = '0' + value;
|
|||
|
}
|
|||
|
|
|||
|
var $item = $('<li>' + value + '</li>');
|
|||
|
|
|||
|
_$list.append($item);
|
|||
|
|
|||
|
_values[key] = $item;
|
|||
|
$item.click(function () {
|
|||
|
if (_multiple && $(this).hasClass('selected')) {
|
|||
|
_self.removeValue(key);
|
|||
|
} else {
|
|||
|
_self.addValue(key);
|
|||
|
|
|||
|
if (!_multiple) _self.close();
|
|||
|
}
|
|||
|
});
|
|||
|
}; // expose main jquery object
|
|||
|
|
|||
|
|
|||
|
this.$ = _$selector; // constructor
|
|||
|
|
|||
|
_$block.find('b:eq(0)').after(_$selector).remove();
|
|||
|
|
|||
|
_$selector.addClass('jqCron-selector-' + _$block.find('.jqCron-selector').length).append(_$title).append(_$list).bind('selector:open', function () {
|
|||
|
if (_hasNumericTexts) {
|
|||
|
var nbcols = 1,
|
|||
|
n = _$list.find('li').length;
|
|||
|
|
|||
|
if (n > 5 && n <= 16) nbcols = 2;else if (n > 16 && n <= 23) nbcols = 3;else if (n > 23 && n <= 40) nbcols = 4;else if (n > 40) nbcols = 5;
|
|||
|
|
|||
|
_$list.addClass('cols' + nbcols);
|
|||
|
}
|
|||
|
|
|||
|
_$list.show();
|
|||
|
}).bind('selector:close', function () {
|
|||
|
_$list.hide();
|
|||
|
}).bind('selector:change', function () {
|
|||
|
_$title.html(_self.getTitleText());
|
|||
|
}).click(function (e) {
|
|||
|
e.stopPropagation();
|
|||
|
}).trigger('selector:change');
|
|||
|
|
|||
|
$.fn.disableSelection && _$selector.disableSelection(); // only work with jQuery UI
|
|||
|
|
|||
|
_$title.click(function (e) {
|
|||
|
_self.isOpened() || _cron.isDisabled() ? _self.close() : _self.open();
|
|||
|
});
|
|||
|
|
|||
|
_self.close();
|
|||
|
|
|||
|
_self.clear();
|
|||
|
}
|
|||
|
|
|||
|
this.jqCronSelector = jqCronSelector;
|
|||
|
}).call(window, (external_jQuery_default()));
|
|||
|
/**
|
|||
|
* Generate unique id for each element.
|
|||
|
* Skip elements which have already an id.
|
|||
|
*/
|
|||
|
|
|||
|
(function ($) {
|
|||
|
var jqUID = 0;
|
|||
|
|
|||
|
var jqGetUID = function jqGetUID(prefix) {
|
|||
|
var id;
|
|||
|
|
|||
|
while (1) {
|
|||
|
jqUID++;
|
|||
|
id = (prefix || 'JQUID') + '' + jqUID;
|
|||
|
if (!document.getElementById(id)) return id;
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
$.fn.uniqueId = function (prefix) {
|
|||
|
return this.each(function () {
|
|||
|
if ($(this).attr('id')) return;
|
|||
|
var id = jqGetUID(prefix);
|
|||
|
$(this).attr('id', id);
|
|||
|
});
|
|||
|
};
|
|||
|
}).call(window, (external_jQuery_default()));
|
|||
|
/**
|
|||
|
* Extends jQuery selectors with new block selector
|
|||
|
*/
|
|||
|
|
|||
|
(function ($) {
|
|||
|
$.extend($.expr[':'], {
|
|||
|
container: function container(a) {
|
|||
|
return (a.tagName + '').toLowerCase() in {
|
|||
|
a: 1,
|
|||
|
abbr: 1,
|
|||
|
acronym: 1,
|
|||
|
address: 1,
|
|||
|
b: 1,
|
|||
|
big: 1,
|
|||
|
blockquote: 1,
|
|||
|
button: 1,
|
|||
|
cite: 1,
|
|||
|
code: 1,
|
|||
|
dd: 1,
|
|||
|
del: 1,
|
|||
|
dfn: 1,
|
|||
|
div: 1,
|
|||
|
dt: 1,
|
|||
|
em: 1,
|
|||
|
fieldset: 1,
|
|||
|
form: 1,
|
|||
|
h1: 1,
|
|||
|
h2: 1,
|
|||
|
h3: 1,
|
|||
|
h4: 1,
|
|||
|
h5: 1,
|
|||
|
h6: 1,
|
|||
|
i: 1,
|
|||
|
ins: 1,
|
|||
|
kbd: 1,
|
|||
|
label: 1,
|
|||
|
li: 1,
|
|||
|
p: 1,
|
|||
|
pre: 1,
|
|||
|
q: 1,
|
|||
|
samp: 1,
|
|||
|
small: 1,
|
|||
|
span: 1,
|
|||
|
strong: 1,
|
|||
|
sub: 1,
|
|||
|
sup: 1,
|
|||
|
td: 1,
|
|||
|
tt: 1
|
|||
|
};
|
|||
|
},
|
|||
|
autoclose: function autoclose(a) {
|
|||
|
return (a.tagName + '').toLowerCase() in {
|
|||
|
area: 1,
|
|||
|
base: 1,
|
|||
|
basefont: 1,
|
|||
|
br: 1,
|
|||
|
col: 1,
|
|||
|
frame: 1,
|
|||
|
hr: 1,
|
|||
|
img: 1,
|
|||
|
input: 1,
|
|||
|
link: 1,
|
|||
|
meta: 1,
|
|||
|
param: 1
|
|||
|
};
|
|||
|
}
|
|||
|
});
|
|||
|
}).call(window, (external_jQuery_default()));
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/cron.js
|
|||
|
function cron_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function cron_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 cron_createClass(Constructor, protoProps, staticProps) { if (protoProps) cron_defineProperties(Constructor.prototype, protoProps); if (staticProps) cron_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var CronField = /*#__PURE__*/function () {
|
|||
|
function CronField() {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
cron_classCallCheck(this, CronField);
|
|||
|
|
|||
|
this.items = external_jQuery_default()();
|
|||
|
external_jQuery_default()('[data-grav-field="cron"]').each(function (index, cron) {
|
|||
|
return _this.addCron(cron);
|
|||
|
});
|
|||
|
external_jQuery_default()('body').on('mutation._grav', this._onAddedNodes.bind(this));
|
|||
|
}
|
|||
|
|
|||
|
cron_createClass(CronField, [{
|
|||
|
key: "addCron",
|
|||
|
value: function addCron(cron) {
|
|||
|
cron = external_jQuery_default()(cron);
|
|||
|
this.items = this.items.add(cron);
|
|||
|
cron.find('.cron-selector').each(function (index, container) {
|
|||
|
container = external_jQuery_default()(container);
|
|||
|
var input = container.closest('[data-grav-field]').find('input');
|
|||
|
container.jqCron({
|
|||
|
numeric_zero_pad: true,
|
|||
|
enabled_minute: true,
|
|||
|
multiple_dom: true,
|
|||
|
multiple_month: true,
|
|||
|
multiple_mins: true,
|
|||
|
multiple_dow: true,
|
|||
|
multiple_time_hours: true,
|
|||
|
multiple_time_minutes: true,
|
|||
|
default_period: 'hour',
|
|||
|
default_value: input.val() || '* * * * *',
|
|||
|
no_reset_button: false,
|
|||
|
bind_to: input,
|
|||
|
bind_method: {
|
|||
|
set: function set($element, value) {
|
|||
|
$element.val(value);
|
|||
|
}
|
|||
|
},
|
|||
|
texts: {
|
|||
|
en: {
|
|||
|
empty: external_GravAdmin_namespaceObject.translations.GRAV_CORE["CRON.EVERY"],
|
|||
|
empty_minutes: external_GravAdmin_namespaceObject.translations.GRAV_CORE["CRON.EVERY"],
|
|||
|
empty_time_hours: external_GravAdmin_namespaceObject.translations.GRAV_CORE["CRON.EVERY_HOUR"],
|
|||
|
empty_time_minutes: external_GravAdmin_namespaceObject.translations.GRAV_CORE["CRON.EVERY_MINUTE"],
|
|||
|
empty_day_of_week: external_GravAdmin_namespaceObject.translations.GRAV_CORE["CRON.EVERY_DAY_OF_WEEK"],
|
|||
|
empty_day_of_month: external_GravAdmin_namespaceObject.translations.GRAV_CORE["CRON.EVERY_DAY_OF_MONTH"],
|
|||
|
empty_month: external_GravAdmin_namespaceObject.translations.GRAV_CORE["CRON.EVERY_MONTH"],
|
|||
|
name_minute: external_GravAdmin_namespaceObject.translations.GRAV_CORE["NICETIME.MINUTE"],
|
|||
|
name_hour: external_GravAdmin_namespaceObject.translations.GRAV_CORE["NICETIME.HOUR"],
|
|||
|
name_day: external_GravAdmin_namespaceObject.translations.GRAV_CORE["NICETIME.DAY"],
|
|||
|
name_week: external_GravAdmin_namespaceObject.translations.GRAV_CORE["NICETIME.WEEK"],
|
|||
|
name_month: external_GravAdmin_namespaceObject.translations.GRAV_CORE["NICETIME.MONTH"],
|
|||
|
name_year: external_GravAdmin_namespaceObject.translations.GRAV_CORE["NICETIME.YEAR"],
|
|||
|
text_period: external_GravAdmin_namespaceObject.translations.GRAV_CORE["CRON.TEXT_PERIOD"],
|
|||
|
text_mins: external_GravAdmin_namespaceObject.translations.GRAV_CORE["CRON.TEXT_MINS"],
|
|||
|
text_time: external_GravAdmin_namespaceObject.translations.GRAV_CORE["CRON.TEXT_TIME"],
|
|||
|
text_dow: external_GravAdmin_namespaceObject.translations.GRAV_CORE["CRON.TEXT_DOW"],
|
|||
|
text_month: external_GravAdmin_namespaceObject.translations.GRAV_CORE["CRON.TEXT_MONTH"],
|
|||
|
text_dom: external_GravAdmin_namespaceObject.translations.GRAV_CORE["CRON.TEXT_DOM"],
|
|||
|
error1: external_GravAdmin_namespaceObject.translations.GRAV_CORE["CRON.ERROR1"],
|
|||
|
error2: external_GravAdmin_namespaceObject.translations.GRAV_CORE["CRON.ERROR2"],
|
|||
|
error3: external_GravAdmin_namespaceObject.translations.GRAV_CORE["CRON.ERROR3"],
|
|||
|
error4: external_GravAdmin_namespaceObject.translations.GRAV_CORE["CRON.ERROR4"],
|
|||
|
weekdays: external_GravAdmin_namespaceObject.translations.GRAV_CORE.DAYS_OF_THE_WEEK,
|
|||
|
months: external_GravAdmin_namespaceObject.translations.GRAV_CORE.MONTHS_OF_THE_YEAR
|
|||
|
}
|
|||
|
}
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "_onAddedNodes",
|
|||
|
value: function _onAddedNodes(event, target
|
|||
|
/* , record, instance */
|
|||
|
) {
|
|||
|
var _this2 = this;
|
|||
|
|
|||
|
var crons = external_jQuery_default()(target).find('[data-grav-field="cron"]');
|
|||
|
|
|||
|
if (!crons.length) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
crons.each(function (index, list) {
|
|||
|
list = external_jQuery_default()(list);
|
|||
|
|
|||
|
if (!~_this2.items.index(list)) {
|
|||
|
_this2.addCron(list);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return CronField;
|
|||
|
}();
|
|||
|
|
|||
|
|
|||
|
var cron_Instance = new CronField();
|
|||
|
// EXTERNAL MODULE: ./node_modules/eventemitter3/index.js
|
|||
|
var eventemitter3 = __webpack_require__(26729);
|
|||
|
var eventemitter3_default = /*#__PURE__*/__webpack_require__.n(eventemitter3);
|
|||
|
;// CONCATENATED MODULE: ./app/utils/finderjs.js
|
|||
|
function finderjs_typeof(obj) { "@babel/helpers - typeof"; return finderjs_typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, finderjs_typeof(obj); }
|
|||
|
|
|||
|
function finderjs_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function finderjs_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 finderjs_createClass(Constructor, protoProps, staticProps) { if (protoProps) finderjs_defineProperties(Constructor.prototype, protoProps); if (staticProps) finderjs_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
/**
|
|||
|
* (c) Trilby Media, LLC
|
|||
|
* Author Djamil Legato
|
|||
|
*
|
|||
|
* Based on Mark Matyas's Finderjs
|
|||
|
* MIT License
|
|||
|
*/
|
|||
|
|
|||
|
|
|||
|
var DEFAULTS = {
|
|||
|
labelKey: 'name',
|
|||
|
valueKey: 'value',
|
|||
|
// new
|
|||
|
childKey: 'children',
|
|||
|
iconKey: 'icon',
|
|||
|
// new
|
|||
|
itemKey: 'item-key',
|
|||
|
// new
|
|||
|
pathBar: true,
|
|||
|
className: {
|
|||
|
container: 'fjs-container',
|
|||
|
pathBar: 'fjs-path-bar',
|
|||
|
col: 'fjs-col',
|
|||
|
list: 'fjs-list',
|
|||
|
item: 'fjs-item',
|
|||
|
active: 'fjs-active',
|
|||
|
children: 'fjs-has-children',
|
|||
|
url: 'fjs-url',
|
|||
|
itemPrepend: 'fjs-item-prepend',
|
|||
|
itemContent: 'fjs-item-content',
|
|||
|
itemAppend: 'fjs-item-append'
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
var Finder = /*#__PURE__*/function () {
|
|||
|
function Finder(container, data, options) {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
finderjs_classCallCheck(this, Finder);
|
|||
|
|
|||
|
this.$emitter = new (eventemitter3_default())();
|
|||
|
this.container = external_jQuery_default()(container);
|
|||
|
this.data = data;
|
|||
|
this.config = external_jQuery_default().extend({}, DEFAULTS, options); // dom events
|
|||
|
|
|||
|
this.container.on('click', this.clickEvent.bind(this));
|
|||
|
this.container.on('keydown', this.keydownEvent.bind(this)); // internal events
|
|||
|
|
|||
|
this.$emitter.on('item-selected', this.itemSelected.bind(this));
|
|||
|
this.$emitter.on('create-column', this.addColumn.bind(this));
|
|||
|
this.$emitter.on('navigate', this.navigate.bind(this));
|
|||
|
this.$emitter.on('go-to', this.goTo.bind(this, this.data));
|
|||
|
this.container.addClass(this.config.className.container).attr('tabindex', 0);
|
|||
|
this.createColumn(this.data);
|
|||
|
|
|||
|
if (this.config.pathBar) {
|
|||
|
this.pathBar = this.createPathBar();
|
|||
|
this.pathBar.on('click', '[data-breadcrumb-node]', function (event) {
|
|||
|
event.preventDefault();
|
|||
|
var location = external_jQuery_default()(event.currentTarget).data('breadcrumbNode');
|
|||
|
|
|||
|
_this.goTo(_this.data, location);
|
|||
|
});
|
|||
|
} // '' is <Root>
|
|||
|
|
|||
|
|
|||
|
if (this.config.defaultPath || this.config.defaultPath === '') {
|
|||
|
this.goTo(this.data, this.config.defaultPath);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
finderjs_createClass(Finder, [{
|
|||
|
key: "reload",
|
|||
|
value: function reload() {
|
|||
|
var data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.data;
|
|||
|
this.createColumn(data); // '' is <Root>
|
|||
|
|
|||
|
if (this.config.defaultPath || this.config.defaultPath === '') {
|
|||
|
this.goTo(data, this.config.defaultPath);
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "createColumn",
|
|||
|
value: function createColumn(data, parent) {
|
|||
|
var _this2 = this;
|
|||
|
|
|||
|
var callback = function callback(data) {
|
|||
|
return _this2.createColumn(data, parent);
|
|||
|
};
|
|||
|
|
|||
|
if (typeof data === 'function') {
|
|||
|
data.call(this, parent, callback);
|
|||
|
} else if (Array.isArray(data) || finderjs_typeof(data) === 'object') {
|
|||
|
if (finderjs_typeof(data) === 'object') {
|
|||
|
data = Array.from(data);
|
|||
|
}
|
|||
|
|
|||
|
var list = this.createList(data);
|
|||
|
var div = external_jQuery_default()('<div />');
|
|||
|
div.append(list).addClass(this.config.className.col);
|
|||
|
this.$emitter.emit('create-column', div);
|
|||
|
return div;
|
|||
|
} else {
|
|||
|
throw new Error('Unknown data type');
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "createPathBar",
|
|||
|
value: function createPathBar() {
|
|||
|
this.container.siblings(".".concat(this.config.className.pathBar)).remove();
|
|||
|
var pathBar = external_jQuery_default()("<div class=\"".concat(this.config.className.pathBar, "\" />"));
|
|||
|
pathBar.insertAfter(this.container);
|
|||
|
return pathBar;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "clickEvent",
|
|||
|
value: function clickEvent(event) {
|
|||
|
event.stopPropagation();
|
|||
|
event.preventDefault();
|
|||
|
var target = external_jQuery_default()(event.target);
|
|||
|
var column = target.closest(".".concat(this.config.className.col));
|
|||
|
var item = target.closest(".".concat(this.config.className.item));
|
|||
|
|
|||
|
if (item.length) {
|
|||
|
this.$emitter.emit('item-selected', {
|
|||
|
column: column,
|
|||
|
item: item
|
|||
|
});
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "keydownEvent",
|
|||
|
value: function keydownEvent(event) {
|
|||
|
var codes = {
|
|||
|
37: 'left',
|
|||
|
38: 'up',
|
|||
|
39: 'right',
|
|||
|
40: 'down'
|
|||
|
};
|
|||
|
|
|||
|
if (event.keyCode in codes) {
|
|||
|
event.stopPropagation();
|
|||
|
event.preventDefault();
|
|||
|
this.$emitter.emit('navigate', {
|
|||
|
direction: codes[event.keyCode]
|
|||
|
});
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "itemSelected",
|
|||
|
value: function itemSelected(value) {
|
|||
|
var element = value.item;
|
|||
|
|
|||
|
if (!element.length) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
var item = element[0]._item;
|
|||
|
var column = value.column;
|
|||
|
var data = item[this.config.childKey] || this.data;
|
|||
|
var active = external_jQuery_default()(column).find(".".concat(this.config.className.active));
|
|||
|
|
|||
|
if (active.length) {
|
|||
|
active.removeClass(this.config.className.active);
|
|||
|
}
|
|||
|
|
|||
|
element.addClass(this.config.className.active);
|
|||
|
column.nextAll().remove(); // ?!?!?
|
|||
|
|
|||
|
this.container[0].focus();
|
|||
|
window.scrollTo(window.pageXOffset, window.pageYOffset);
|
|||
|
this.updatePathBar();
|
|||
|
var newColumn;
|
|||
|
|
|||
|
if (data) {
|
|||
|
newColumn = this.createColumn(data, item);
|
|||
|
this.$emitter.emit('interior-selected', item);
|
|||
|
} else {
|
|||
|
this.$emitter.emit('leaf-selected', item);
|
|||
|
}
|
|||
|
|
|||
|
return newColumn;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "addColumn",
|
|||
|
value: function addColumn(column) {
|
|||
|
this.container.append(column);
|
|||
|
this.$emitter.emit('column-created', column);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "navigate",
|
|||
|
value: function navigate(value) {
|
|||
|
var active = this.findLastActive();
|
|||
|
var direction = value.direction;
|
|||
|
var column;
|
|||
|
var item;
|
|||
|
var target;
|
|||
|
|
|||
|
if (active) {
|
|||
|
item = active.item;
|
|||
|
column = active.column;
|
|||
|
|
|||
|
if (direction === 'up' && item.prev().length) {
|
|||
|
target = item.prev();
|
|||
|
} else if (direction === 'down' && item.next().length) {
|
|||
|
target = item.next();
|
|||
|
} else if (direction === 'right' && column.next().length) {
|
|||
|
column = column.next();
|
|||
|
target = column.find(".".concat(this.config.className.item)).first();
|
|||
|
} else if (direction === 'left' && column.prev().length) {
|
|||
|
column = column.prev();
|
|||
|
target = column.find(".".concat(this.config.className.active)).first() || column.find(".".concat(this.config.className.item));
|
|||
|
}
|
|||
|
} else {
|
|||
|
column = this.container.find(".".concat(this.config.className.col)).first();
|
|||
|
target = column.find(".".concat(this.config.className.item)).first();
|
|||
|
}
|
|||
|
|
|||
|
if (target) {
|
|||
|
this.$emitter.emit('item-selected', {
|
|||
|
column: column,
|
|||
|
item: target
|
|||
|
});
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "goTo",
|
|||
|
value: function goTo(data, path) {
|
|||
|
var _this3 = this;
|
|||
|
|
|||
|
path = Array.isArray(path) ? path : path.split('/').map(function (bit) {
|
|||
|
return bit.trim();
|
|||
|
}).filter(Boolean);
|
|||
|
|
|||
|
if (path.length) {
|
|||
|
this.container.children().remove();
|
|||
|
}
|
|||
|
|
|||
|
if (typeof data === 'function') {
|
|||
|
data.call(this, null, function (data) {
|
|||
|
return _this3.selectPath(path, data);
|
|||
|
});
|
|||
|
} else {
|
|||
|
this.selectPath(path, data);
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "selectPath",
|
|||
|
value: function selectPath(path, data, column) {
|
|||
|
var _this4 = this;
|
|||
|
|
|||
|
column = column || (path.length ? this.createColumn(data) : this.container.find("> .".concat(this.config.className.col)));
|
|||
|
var current = path[0] || '';
|
|||
|
var children = data.find(function (item) {
|
|||
|
return item[_this4.config.itemKey] === current;
|
|||
|
});
|
|||
|
var newColumn = this.itemSelected({
|
|||
|
column: column,
|
|||
|
item: column.find("[data-fjs-item=\"".concat(current, "\"]")).first()
|
|||
|
});
|
|||
|
path.shift();
|
|||
|
|
|||
|
if (path.length && children) {
|
|||
|
this.selectPath(path, children[this.config.childKey], newColumn);
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "findLastActive",
|
|||
|
value: function findLastActive() {
|
|||
|
var active = this.container.find(".".concat(this.config.className.active));
|
|||
|
|
|||
|
if (!active.length) {
|
|||
|
return null;
|
|||
|
}
|
|||
|
|
|||
|
var item = active.last();
|
|||
|
var column = item.closest(".".concat(this.config.className.col));
|
|||
|
return {
|
|||
|
item: item,
|
|||
|
column: column
|
|||
|
};
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "createList",
|
|||
|
value: function createList(data) {
|
|||
|
var _this5 = this;
|
|||
|
|
|||
|
var list = external_jQuery_default()('<ul />');
|
|||
|
var items = data.map(function (item) {
|
|||
|
return _this5.createItem(item);
|
|||
|
});
|
|||
|
var fragments = items.reduce(function (fragment, current) {
|
|||
|
fragment.appendChild(current[0] || current);
|
|||
|
return fragment;
|
|||
|
}, document.createDocumentFragment());
|
|||
|
list.append(fragments).addClass(this.config.className.list);
|
|||
|
return list;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "createItem",
|
|||
|
value: function createItem(item) {
|
|||
|
var listItem = external_jQuery_default()('<li />');
|
|||
|
var listItemClasses = [this.config.className.item];
|
|||
|
var link = external_jQuery_default()('<a />');
|
|||
|
var createItemContent = this.config.createItemContent || this.createItemContent;
|
|||
|
var fragment = createItemContent.call(this, item);
|
|||
|
link.append(fragment).attr('href', '').attr('tabindex', -1);
|
|||
|
|
|||
|
if (item.url) {
|
|||
|
link.attr('href', item.url);
|
|||
|
listItemClasses.push(item.className);
|
|||
|
}
|
|||
|
|
|||
|
if (item[this.config.childKey]) {
|
|||
|
listItemClasses.push(this.config.className[this.config.childKey]);
|
|||
|
}
|
|||
|
|
|||
|
listItemClasses.push("fjs-item-".concat(item.type));
|
|||
|
listItem.addClass(listItemClasses.join(' '));
|
|||
|
listItem.append(link).attr('data-fjs-item', item[this.config.itemKey]);
|
|||
|
listItem[0]._item = item;
|
|||
|
return listItem;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "updatePathBar",
|
|||
|
value: function updatePathBar() {
|
|||
|
var _this6 = this;
|
|||
|
|
|||
|
if (!this.config.pathBar) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
var activeItems = this.container.find(".".concat(this.config.className.active));
|
|||
|
var itemKeys = '';
|
|||
|
this.pathBar.children().empty();
|
|||
|
activeItems.each(function (index, activeItem) {
|
|||
|
var item = activeItem._item;
|
|||
|
var isLast = index + 1 === activeItems.length;
|
|||
|
itemKeys += "/".concat(item[_this6.config.itemKey]);
|
|||
|
|
|||
|
_this6.pathBar.append("\n <span class=\"breadcrumb-node breadcrumb-node-".concat(item.type, "\" ").concat(item.type === 'dir' ? "data-breadcrumb-node=\"".concat(itemKeys, "\"") : '', ">\n <i class=\"fa fa-fw ").concat(_this6.getIcon(item.type), "\"></i>\n <span class=\"breadcrumb-node-name\">").concat(external_jQuery_default()('<div />').html(item[_this6.config.labelKey]).html(), "</span>\n ").concat(!isLast ? '<i class="fa fa-fw fa-chevron-right"></i>' : '', "\n </span>\n "));
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "getIcon",
|
|||
|
value: function getIcon(type) {
|
|||
|
switch (type) {
|
|||
|
case 'root':
|
|||
|
return 'fa-sitemap';
|
|||
|
|
|||
|
case 'file':
|
|||
|
return 'fa-file-o';
|
|||
|
|
|||
|
case 'dir':
|
|||
|
default:
|
|||
|
return 'fa-folder';
|
|||
|
}
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return Finder;
|
|||
|
}();
|
|||
|
|
|||
|
/* harmony default export */ const finderjs = (Finder);
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/parents.js
|
|||
|
function parents_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function parents_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 parents_createClass(Constructor, protoProps, staticProps) { if (protoProps) parents_defineProperties(Constructor.prototype, protoProps); if (staticProps) parents_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var XHRUUID = 0;
|
|||
|
var parents_Instances = {};
|
|||
|
|
|||
|
var Parents = /*#__PURE__*/function () {
|
|||
|
function Parents(container, field, data) {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
parents_classCallCheck(this, Parents);
|
|||
|
|
|||
|
this.container = external_jQuery_default()(container);
|
|||
|
this.fieldName = field.attr('name');
|
|||
|
this.field = external_jQuery_default()("[name=\"".concat(this.fieldName, "\"]"));
|
|||
|
this.data = data;
|
|||
|
this.parentLabel = external_jQuery_default()("[data-parents-field-label=\"".concat(this.fieldName, "\"]"));
|
|||
|
this.parentName = external_jQuery_default()("[data-parents-field-name=\"".concat(this.fieldName, "\"]"));
|
|||
|
var dataLoad = this.dataLoad;
|
|||
|
this.finder = new finderjs(this.container, function (parent, callback) {
|
|||
|
return dataLoad.call(_this, parent, callback);
|
|||
|
}, {
|
|||
|
labelKey: 'name',
|
|||
|
defaultPath: this.field.val(),
|
|||
|
createItemContent: function createItemContent(item) {
|
|||
|
return Parents.createItemContent(this.config, item);
|
|||
|
}
|
|||
|
});
|
|||
|
/*
|
|||
|
this.finder.$emitter.on('leaf-selected', (item) => {
|
|||
|
console.log('selected', item);
|
|||
|
this.finder.emit('create-column', () => this.createSimpleColumn(item));
|
|||
|
});
|
|||
|
this.finder.$emitter.on('item-selected', (selected) => {
|
|||
|
console.log('selected', selected);
|
|||
|
// for future use only - create column-card creation for file with details like in macOS finder
|
|||
|
// this.finder.$emitter('create-column', () => this.createSimpleColumn(selected));
|
|||
|
}); */
|
|||
|
|
|||
|
this.finder.$emitter.on('column-created', function () {
|
|||
|
_this.container[0].scrollLeft = _this.container[0].scrollWidth - _this.container[0].clientWidth;
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
parents_createClass(Parents, [{
|
|||
|
key: "createSimpleColumn",
|
|||
|
value: function createSimpleColumn(item) {}
|
|||
|
}, {
|
|||
|
key: "dataLoad",
|
|||
|
value: function dataLoad(parent, callback) {
|
|||
|
var _this2 = this;
|
|||
|
|
|||
|
if (!parent) {
|
|||
|
return callback(this.data);
|
|||
|
}
|
|||
|
|
|||
|
if (parent.type !== 'dir' || !parent['has-children']) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
var UUID = ++XHRUUID;
|
|||
|
this.startLoader();
|
|||
|
external_jQuery_default().ajax({
|
|||
|
url: "".concat(external_GravAdmin_namespaceObject.config.current_url),
|
|||
|
method: 'post',
|
|||
|
data: Object.assign({}, getExtraFormData(this.container), {
|
|||
|
route: b64_encode_unicode(parent.value),
|
|||
|
field: this.field.data('fieldName'),
|
|||
|
action: 'getLevelListing',
|
|||
|
'admin-nonce': external_GravAdmin_namespaceObject.config.admin_nonce
|
|||
|
}),
|
|||
|
success: function success(response) {
|
|||
|
_this2.stopLoader();
|
|||
|
|
|||
|
if (response.status === 'error') {
|
|||
|
_this2.finder.$emitter.emit('create-column', Parents.createErrorColumn(response.message)[0]);
|
|||
|
|
|||
|
return false;
|
|||
|
} // stale request
|
|||
|
|
|||
|
|
|||
|
if (UUID !== XHRUUID) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
return callback(response.data);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "startLoader",
|
|||
|
value: function startLoader() {
|
|||
|
this.loadingIndicator = Parents.createLoadingColumn();
|
|||
|
this.finder.$emitter.emit('create-column', this.loadingIndicator[0]);
|
|||
|
return this.loadingIndicator;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "stopLoader",
|
|||
|
value: function stopLoader() {
|
|||
|
return this.loadingIndicator && this.loadingIndicator.remove();
|
|||
|
}
|
|||
|
}], [{
|
|||
|
key: "createItemContent",
|
|||
|
value: function createItemContent(config, item) {
|
|||
|
var frag = document.createDocumentFragment();
|
|||
|
var label = external_jQuery_default()("<span title=\"".concat(item[config.labelKey], "\" />"));
|
|||
|
var infoContainer = external_jQuery_default()('<span class="info-container" />');
|
|||
|
var iconPrepend = external_jQuery_default()('<i />');
|
|||
|
var iconAppend = external_jQuery_default()('<i />');
|
|||
|
var badge = external_jQuery_default()('<span class="badge" />');
|
|||
|
var prependClasses = ['fa'];
|
|||
|
var appendClasses = ['fa']; // prepend icon
|
|||
|
|
|||
|
if (item.children || item.type === 'dir') {
|
|||
|
prependClasses.push('fa-folder');
|
|||
|
} else if (item.type === 'root') {
|
|||
|
prependClasses.push('fa-sitemap');
|
|||
|
} else if (item.type === 'file') {
|
|||
|
prependClasses.push('fa-file-o');
|
|||
|
}
|
|||
|
|
|||
|
iconPrepend.addClass(prependClasses.join(' ')); // text label
|
|||
|
|
|||
|
label.text(item[config.labelKey]).prepend(iconPrepend);
|
|||
|
label.appendTo(frag); // append icon
|
|||
|
|
|||
|
if (item.children || item['has-children']) {
|
|||
|
appendClasses.push('fa-caret-right');
|
|||
|
badge.text(item.size || item.count || 0);
|
|||
|
badge.appendTo(infoContainer);
|
|||
|
}
|
|||
|
|
|||
|
iconAppend.addClass(appendClasses.join(' '));
|
|||
|
iconAppend.appendTo(infoContainer);
|
|||
|
infoContainer.appendTo(frag);
|
|||
|
return frag;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "createLoadingColumn",
|
|||
|
value: function createLoadingColumn() {
|
|||
|
return external_jQuery_default()("\n <div class=\"fjs-col leaf-col\" style=\"overflow: hidden;\">\n <div class=\"leaf-row\">\n <div class=\"grav-loading\"><div class=\"grav-loader\">Loading...</div></div>\n </div>\n </div>\n ");
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "createErrorColumn",
|
|||
|
value: function createErrorColumn(error) {
|
|||
|
return external_jQuery_default()("\n <div class=\"fjs-col leaf-col\" style=\"overflow: hidden;\">\n <div class=\"leaf-row error\">\n <i class=\"fa fa-fw fa-warning\"></i>\n <span>".concat(error, "</span>\n </div>\n </div>\n "));
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return Parents;
|
|||
|
}();
|
|||
|
|
|||
|
|
|||
|
var b64_encode_unicode = function b64_encode_unicode(str) {
|
|||
|
return btoa(encodeURIComponent(str).replace(/%([0-9A-F]{2})/g, function toSolidBytes(match, p1) {
|
|||
|
return String.fromCharCode('0x' + p1);
|
|||
|
}));
|
|||
|
};
|
|||
|
var b64_decode_unicode = function b64_decode_unicode(str) {
|
|||
|
return decodeURIComponent(atob(str).split('').map(function (c) {
|
|||
|
return '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2);
|
|||
|
}).join(''));
|
|||
|
};
|
|||
|
|
|||
|
var getExtraFormData = function getExtraFormData(container) {
|
|||
|
var form = container.closest('form');
|
|||
|
|
|||
|
if (container.closest('[data-remodal-id]').length) {
|
|||
|
form = external_jQuery_default()('form#blueprints');
|
|||
|
}
|
|||
|
|
|||
|
var data = {};
|
|||
|
var unique_id = form.find('[name="__unique_form_id__"]');
|
|||
|
data['__form-name__'] = form.find('[name="__form-name__"]').val();
|
|||
|
data['form-nonce'] = form.find('[name="form-nonce"]').val();
|
|||
|
|
|||
|
if (unique_id.length) {
|
|||
|
data['__unique_form_id__'] = unique_id.val();
|
|||
|
}
|
|||
|
|
|||
|
return data;
|
|||
|
};
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', '[data-parents]', function (event) {
|
|||
|
event.preventDefault();
|
|||
|
event.stopPropagation();
|
|||
|
var target = external_jQuery_default()(event.currentTarget);
|
|||
|
var field = target.closest('.parents-wrapper').find('input[name]');
|
|||
|
var fieldName = field.attr('name');
|
|||
|
|
|||
|
if (!field.length) {
|
|||
|
fieldName = target.data('parents');
|
|||
|
field = external_jQuery_default()("[name=\"".concat(target.data('parents'), "\"]")).first();
|
|||
|
}
|
|||
|
|
|||
|
var modal = external_jQuery_default()("[data-remodal-id=\"".concat(target.data('remodalTarget') || 'parents', "\"]"));
|
|||
|
var loader = modal.find('.grav-loading');
|
|||
|
var content = modal.find('.parents-content');
|
|||
|
loader.css('display', 'block');
|
|||
|
content.html('');
|
|||
|
external_jQuery_default().ajax({
|
|||
|
url: "".concat(external_GravAdmin_namespaceObject.config.current_url),
|
|||
|
method: 'post',
|
|||
|
data: Object.assign({}, getExtraFormData(target), {
|
|||
|
route: b64_encode_unicode(field.val()),
|
|||
|
field: field.data('fieldName'),
|
|||
|
action: 'getLevelListing',
|
|||
|
'admin-nonce': external_GravAdmin_namespaceObject.config.admin_nonce,
|
|||
|
initial: true
|
|||
|
}),
|
|||
|
success: function success(response) {
|
|||
|
loader.css('display', 'none');
|
|||
|
|
|||
|
if (response.status === 'error') {
|
|||
|
content.html(response.message);
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
if (!parents_Instances["".concat(fieldName, "-").concat(modal.data('remodalId'))]) {
|
|||
|
parents_Instances["".concat(fieldName, "-").concat(modal.data('remodalId'))] = new Parents(content, field, response.data);
|
|||
|
} else {
|
|||
|
parents_Instances["".concat(fieldName, "-").concat(modal.data('remodalId'))].finder.reload(response.data);
|
|||
|
}
|
|||
|
|
|||
|
modal.data('parents', parents_Instances["".concat(fieldName, "-").concat(modal.data('remodalId'))]);
|
|||
|
modal.data('parents-selectedField', field);
|
|||
|
}
|
|||
|
});
|
|||
|
}); // apply finder selection to field
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', '[data-remodal-id].parents-container [data-parents-select]', function (event) {
|
|||
|
var modal = external_jQuery_default()(event.currentTarget).closest('[data-remodal-id]');
|
|||
|
var parents = modal.data('parents');
|
|||
|
var selectedField = modal.data('parentsSelectedField');
|
|||
|
var finder = parents.finder;
|
|||
|
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];
|
|||
|
|
|||
|
if (selectedField.closest('.remodal').length) {
|
|||
|
var index = field.index(selectedField);
|
|||
|
selectedField.val(value);
|
|||
|
external_jQuery_default()(parentLabel[index]).text(value);
|
|||
|
external_jQuery_default()(parentName[index]).text(name);
|
|||
|
} else {
|
|||
|
field.val(value);
|
|||
|
parentLabel.text(value);
|
|||
|
parentName.text(name);
|
|||
|
finder.config.defaultPath = value;
|
|||
|
}
|
|||
|
|
|||
|
var remodal = (external_jQuery_default()).remodal.lookup[external_jQuery_default()("[data-remodal-id=\"".concat(modal.data('remodalId'), "\"]")).data('remodal')];
|
|||
|
remodal.close();
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/acl-picker.js
|
|||
|
|
|||
|
var acl_picker_body = external_jQuery_default()('body');
|
|||
|
acl_picker_body.on('change', '[data-acl_picker] select', function (event) {
|
|||
|
var target = external_jQuery_default()(event.currentTarget);
|
|||
|
var value = target.val();
|
|||
|
var item = target.closest('.permissions-item');
|
|||
|
var inputs = item.find('input[type="checkbox"], input[type="radio"]');
|
|||
|
var hidden = item.find('input[type="hidden"][name]');
|
|||
|
var wrapper = target.closest('[data-acl_picker_id]');
|
|||
|
var type = item.data('fieldType');
|
|||
|
|
|||
|
if (type === 'access') {
|
|||
|
inputs.each(function (index, input) {
|
|||
|
input = external_jQuery_default()(input);
|
|||
|
var name = input.prop('name');
|
|||
|
input.prop('name', name.replace(/(.*)(\[[^\]]*\])/, "$1[".concat(value, "]")));
|
|||
|
});
|
|||
|
} else if (type === 'permissions') {
|
|||
|
var crudpContainer = item.find('[data-field-name]');
|
|||
|
inputs.each(function (index, input) {
|
|||
|
input = external_jQuery_default()(input);
|
|||
|
var rand = Math.round(Math.random() * 500);
|
|||
|
var name = crudpContainer.data('fieldName');
|
|||
|
var id = input.prop('id').split('_').slice(0, -1).join('_') + "_".concat(value, "+").concat(rand); // const key = input.data('crudpKey');
|
|||
|
|
|||
|
hidden.prop('name', name.replace(/(.*)(\[[^\]]*\])/, "$1[".concat(value, "]")));
|
|||
|
input.prop('id', id);
|
|||
|
input.next('label').prop('for', id);
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
wrapper.find('.permissions-item .button.add-item')[!value ? 'addClass' : 'removeClass']('disabled').prop('disabled', !value ? 'disabled' : null);
|
|||
|
});
|
|||
|
acl_picker_body.on('input', 'input[data-crudp-key]', function (event) {
|
|||
|
var target = external_jQuery_default()(event.currentTarget);
|
|||
|
var container = target.closest('.crudp-container');
|
|||
|
var hidden = container.find('input[type="hidden"][name]');
|
|||
|
var key = target.data('crudpKey');
|
|||
|
var json = JSON.parse(hidden.val() || '{}');
|
|||
|
json[key] = target.val();
|
|||
|
hidden.val(JSON.stringify(json));
|
|||
|
});
|
|||
|
acl_picker_body.on('click', '[data-acl_picker] .remove-item', function (event) {
|
|||
|
event.preventDefault();
|
|||
|
var target = external_jQuery_default()(event.currentTarget);
|
|||
|
var container = target.closest('.permissions-item');
|
|||
|
var wrapper = target.closest('[data-acl_picker_id]');
|
|||
|
container.remove();
|
|||
|
var empty = wrapper.find('.permissions-item').length === 1; // show the initial + button
|
|||
|
|
|||
|
if (empty) {
|
|||
|
wrapper.find('.permissions-item.empty-list').removeClass('hidden');
|
|||
|
}
|
|||
|
});
|
|||
|
acl_picker_body.on('click', '[data-acl_picker] .add-item', function (event) {
|
|||
|
event.preventDefault();
|
|||
|
var target = external_jQuery_default()(event.currentTarget);
|
|||
|
var item = target.closest('.permissions-item');
|
|||
|
var wrapper = target.closest('[data-acl_picker_id]');
|
|||
|
var ID = wrapper.data('acl_picker_id');
|
|||
|
var template = document.querySelector("template[data-id=\"acl_picker-".concat(ID, "\"]"));
|
|||
|
var clone = external_jQuery_default()(template.content.firstElementChild).clone();
|
|||
|
clone.insertAfter(item); // randomize ids
|
|||
|
|
|||
|
clone.find('.switch-toggle input[type="radio"]').each(function (index, input) {
|
|||
|
input = external_jQuery_default()(input);
|
|||
|
var id = input.prop('id');
|
|||
|
var label = input.next('label');
|
|||
|
var rand = (Date.now().toString(36) + Math.random().toString(36).substr(2, 5)).toLowerCase();
|
|||
|
input.prop('id', "".concat(id).concat(rand));
|
|||
|
label.prop('for', "".concat(id).concat(rand));
|
|||
|
}); // hide the initial + button
|
|||
|
|
|||
|
wrapper.find('.permissions-item.empty-list').addClass('hidden'); // disable all + buttons until one is selected
|
|||
|
|
|||
|
wrapper.find('.permissions-item .button.add-item').addClass('disabled').prop('disabled', 'disabled');
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/permissions.js
|
|||
|
|
|||
|
var permissions_body = external_jQuery_default()('body');
|
|||
|
var radioSelector = '.permission-container.parent-section input[type="radio"]';
|
|||
|
|
|||
|
var handleParent = function handleParent(event) {
|
|||
|
var target = external_jQuery_default()(event.currentTarget);
|
|||
|
var value = target.val();
|
|||
|
var container = target.closest('.parent-section');
|
|||
|
var fieldset = container.next('fieldset');
|
|||
|
var radios = fieldset.find("input[type=\"radio\"][value=\"".concat(value, "\"]"));
|
|||
|
|
|||
|
if (container.data('isLocked') !== false) {
|
|||
|
container.data('isUpdating', true);
|
|||
|
radios.each(function (index, radio) {
|
|||
|
var ID = radio.id;
|
|||
|
external_jQuery_default()(radio).siblings("[for=\"".concat(ID, "\"]")).trigger('click');
|
|||
|
});
|
|||
|
container.data('isUpdating', false);
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
var boundHandleParent = handleParent.bind(handleParent);
|
|||
|
permissions_body.on('click', '.permission-container.parent-section label', function (event) {
|
|||
|
var target = external_jQuery_default()(event.currentTarget);
|
|||
|
var container = target.closest('.parent-section');
|
|||
|
container.data('isLocked', true);
|
|||
|
});
|
|||
|
permissions_body.on('input', radioSelector, boundHandleParent);
|
|||
|
permissions_body.on('input', '.permissions-container input[type="radio"][data-parent-id]', function (event) {
|
|||
|
var target = external_jQuery_default()(event.currentTarget);
|
|||
|
var parent = external_jQuery_default()("[for=\"".concat(target.data('parentId'), "\"]"));
|
|||
|
var container = target.closest('fieldset').prev('.permission-container.parent-section');
|
|||
|
|
|||
|
if (container.data('isUpdating') === true) {
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
permissions_body.off('input', radioSelector, boundHandleParent);
|
|||
|
container.data('isLocked', false);
|
|||
|
parent.trigger('click');
|
|||
|
permissions_body.on('input', radioSelector, boundHandleParent);
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/indeterminate.js
|
|||
|
|
|||
|
document.addEventListener('click', function (event) {
|
|||
|
if (document.querySelector('#pages-filters')) {
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
var wrapper = event.target.closest('.checkboxes.indeterminate');
|
|||
|
|
|||
|
if (wrapper) {
|
|||
|
event.preventDefault();
|
|||
|
var checkbox = wrapper.querySelector('input[type="checkbox"]:not([disabled])');
|
|||
|
var checkStatus = wrapper.dataset._checkStatus;
|
|||
|
wrapper.classList.remove('status-checked', 'status-unchecked', 'status-indeterminate');
|
|||
|
|
|||
|
switch (checkStatus) {
|
|||
|
// checked, going indeterminate
|
|||
|
case '1':
|
|||
|
wrapper.dataset._checkStatus = '2';
|
|||
|
checkbox.indeterminate = true;
|
|||
|
checkbox.checked = false;
|
|||
|
checkbox.value = 0;
|
|||
|
wrapper.classList.add('status-indeterminate');
|
|||
|
break;
|
|||
|
// indeterminate, going unchecked
|
|||
|
|
|||
|
case '2':
|
|||
|
wrapper.dataset._checkStatus = '0';
|
|||
|
checkbox.indeterminate = false;
|
|||
|
checkbox.checked = false;
|
|||
|
checkbox.value = '';
|
|||
|
wrapper.classList.add('status-unchecked');
|
|||
|
break;
|
|||
|
// unchecked, going checked
|
|||
|
|
|||
|
case '0':
|
|||
|
default:
|
|||
|
wrapper.dataset._checkStatus = '1';
|
|||
|
checkbox.indeterminate = false;
|
|||
|
checkbox.checked = true;
|
|||
|
checkbox.value = 1;
|
|||
|
wrapper.classList.add('status-checked');
|
|||
|
break;
|
|||
|
} // const input = new CustomEvent('input', { detail: { target: checkbox }});
|
|||
|
// document.dispatchEvent(input);
|
|||
|
|
|||
|
|
|||
|
external_jQuery_default()(checkbox).trigger('input');
|
|||
|
}
|
|||
|
});
|
|||
|
(document.querySelectorAll('input[type="checkbox"][indeterminate="true"]') || []).forEach(function (input) {
|
|||
|
input.indeterminate = true;
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/mediapicker.js
|
|||
|
|
|||
|
|
|||
|
external_jQuery_default()(function () {
|
|||
|
var modal = '';
|
|||
|
var body = external_jQuery_default()('body'); // Thumb Resizer
|
|||
|
|
|||
|
external_jQuery_default()(document).on('input change', '.media-container .media-range', function (event) {
|
|||
|
var target = external_jQuery_default()(event.currentTarget);
|
|||
|
var container = target.closest('.remodal');
|
|||
|
var cards = container.find('.media-container div.card-item');
|
|||
|
var width = target.val() + 'px';
|
|||
|
cards.each(function () {
|
|||
|
external_jQuery_default()(this).css('width', width);
|
|||
|
});
|
|||
|
});
|
|||
|
body.on('click', '[data-mediapicker-modal-trigger]', function (event) {
|
|||
|
var element = external_jQuery_default()(event.currentTarget);
|
|||
|
var modal_identifier = external_jQuery_default()(this).data('grav-mediapicker-unique-identifier');
|
|||
|
var modal_element = body.find("[data-remodal-unique-identifier=\"".concat(modal_identifier, "\"]"));
|
|||
|
modal = (external_jQuery_default()).remodal.lookup[modal_element.data('remodal')];
|
|||
|
|
|||
|
if (!modal) {
|
|||
|
modal_element.remodal();
|
|||
|
modal = (external_jQuery_default()).remodal.lookup[modal_element.data('remodal')];
|
|||
|
}
|
|||
|
|
|||
|
modal.open();
|
|||
|
modal.dataField = element.find('input'); // load all media
|
|||
|
|
|||
|
modal_element.find('.js__files').trigger('fillView');
|
|||
|
setTimeout(function () {
|
|||
|
return tree_Instance.reload();
|
|||
|
}, 100);
|
|||
|
});
|
|||
|
/* handle media modal click actions */
|
|||
|
|
|||
|
body.on('click', '[data-remodal-mediapicker] .media-container.in-modal .admin-media-details a', function (event) {
|
|||
|
event.preventDefault();
|
|||
|
event.stopPropagation();
|
|||
|
var val = external_jQuery_default()(event.target).parents('.js__media-element').data('file-url');
|
|||
|
var string = val.replace(/ /g, '%20');
|
|||
|
modal.dataField.val(string);
|
|||
|
modal.close();
|
|||
|
});
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/multilevel.js
|
|||
|
|
|||
|
external_jQuery_default()(function () {
|
|||
|
var getField = function getField(level, name) {
|
|||
|
var levelMargin = level * 50;
|
|||
|
var top = level === 0 ? 'top' : '';
|
|||
|
var the_name = 'name="' + name + '"';
|
|||
|
|
|||
|
if (level === 0) {
|
|||
|
// top
|
|||
|
the_name = 'data-attr-name="' + name + '"';
|
|||
|
}
|
|||
|
|
|||
|
var marginDir = window.getComputedStyle(document.body).direction === 'ltr' ? 'margin-left' : 'margin-right';
|
|||
|
var field = "\n <div class=\"element-wrapper\">\n <div class=\"form-row array-field-value_only js__multilevel-field ".concat(top, "\"\n data-grav-array-type=\"row\">\n <input\n type=\"text\"\n ").concat(the_name, "\n placeholder=\"Enter value\"\n style=\"").concat(marginDir, ": ").concat(levelMargin, "px\"\n value=\"\" />\n\n <span class=\"fa fa-minus js__remove-item\"></span>\n <span class=\"fa fa-plus js__add-sibling hidden\" data-level=\"").concat(level, "\" ></span>\n <span class=\"fa fa-plus-circle js__add-children hidden\" data-level=\"").concat(level, "\"></span>\n </div>\n </div>\n ");
|
|||
|
return field;
|
|||
|
};
|
|||
|
|
|||
|
var hasChildInputs = function hasChildInputs($element) {
|
|||
|
if ($element.attr('name')) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
return true;
|
|||
|
};
|
|||
|
|
|||
|
var getTopItems = function getTopItems(element) {
|
|||
|
return external_jQuery_default()(element + ' .js__multilevel-field.top');
|
|||
|
};
|
|||
|
|
|||
|
var refreshControls = function refreshControls(unique_identifier) {
|
|||
|
var element = '[data-grav-multilevel-field]';
|
|||
|
|
|||
|
if (unique_identifier) {
|
|||
|
element = '[data-grav-multilevel-field][data-id="' + unique_identifier + '"]';
|
|||
|
}
|
|||
|
|
|||
|
var hideButtons = function hideButtons() {
|
|||
|
external_jQuery_default()(element + ' .js__add-sibling').addClass('hidden');
|
|||
|
external_jQuery_default()(element + ' .js__add-children').addClass('hidden');
|
|||
|
};
|
|||
|
|
|||
|
var restoreAddSiblingButtons = function restoreAddSiblingButtons() {
|
|||
|
external_jQuery_default()(element + ' .children-wrapper').each(function () {
|
|||
|
var elements = external_jQuery_default()(this).children();
|
|||
|
elements.last().each(function () {
|
|||
|
var field = external_jQuery_default()(this);
|
|||
|
|
|||
|
if (!external_jQuery_default()(this).hasClass('js__multilevel-field')) {
|
|||
|
field = external_jQuery_default()(this).find('.js__multilevel-field').first();
|
|||
|
}
|
|||
|
|
|||
|
field.find('.js__add-sibling').removeClass('hidden');
|
|||
|
});
|
|||
|
}); // add sibling to the last top element
|
|||
|
|
|||
|
external_jQuery_default()(element + ' .js__multilevel-field.top').last().find('.js__add-sibling').removeClass('hidden');
|
|||
|
};
|
|||
|
|
|||
|
var restoreAddChildrenButtons = function restoreAddChildrenButtons() {
|
|||
|
external_jQuery_default()(element + ' .js__multilevel-field').each(function () {
|
|||
|
if (external_jQuery_default()(this).siblings('.children-wrapper').length === 0 || external_jQuery_default()(this).siblings('.children-wrapper').find('.js__multilevel-field').length === 0) {
|
|||
|
external_jQuery_default()(this).find('.js__add-children').removeClass('hidden');
|
|||
|
}
|
|||
|
});
|
|||
|
};
|
|||
|
|
|||
|
var preventRemovingLastTopItem = function preventRemovingLastTopItem() {
|
|||
|
var top_items = getTopItems(element);
|
|||
|
|
|||
|
if (top_items.length === 1) {
|
|||
|
top_items.first().find('.js__remove-item').addClass('hidden');
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
hideButtons();
|
|||
|
restoreAddSiblingButtons();
|
|||
|
restoreAddChildrenButtons();
|
|||
|
preventRemovingLastTopItem();
|
|||
|
};
|
|||
|
|
|||
|
var changeAllOccurrencesInTree = function changeAllOccurrencesInTree($el, current_name, new_name) {
|
|||
|
$el.parents('[data-grav-multilevel-field]').find('input').each(function () {
|
|||
|
var $input = external_jQuery_default()(this);
|
|||
|
|
|||
|
if ($input.attr('name')) {
|
|||
|
$input.attr('name', $input.attr('name').replace(current_name, new_name));
|
|||
|
}
|
|||
|
|
|||
|
if ($input.attr('data-attr-name')) {
|
|||
|
$input.attr('data-attr-name', $input.attr('data-attr-name').replace(current_name, new_name));
|
|||
|
}
|
|||
|
});
|
|||
|
};
|
|||
|
|
|||
|
external_jQuery_default()(document).ready(function () {
|
|||
|
refreshControls();
|
|||
|
});
|
|||
|
external_jQuery_default()(document).on('mouseleave', '[data-grav-multilevel-field]', function (event) {
|
|||
|
var top_items = getTopItems('[data-id="' + external_jQuery_default()(this).data('id') + '"]');
|
|||
|
var has_top_items_without_children = false;
|
|||
|
var element_content = '';
|
|||
|
top_items.each(function () {
|
|||
|
var item = external_jQuery_default()(this);
|
|||
|
|
|||
|
if (external_jQuery_default()(item).siblings('.children-wrapper').find('input').length === 0) {
|
|||
|
has_top_items_without_children = true;
|
|||
|
element_content = item.find('input').val();
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
if (has_top_items_without_children) {
|
|||
|
if (element_content) {
|
|||
|
alert('Warning: if you save now, the element ' + element_content + ', without children, will be removed, because it\'s invalid YAML');
|
|||
|
} else {
|
|||
|
alert('Warning: if you save now, the top elements without children will be removed, because it\'s invalid YAML');
|
|||
|
}
|
|||
|
}
|
|||
|
});
|
|||
|
external_jQuery_default()(document).on('click', '[data-grav-multilevel-field] .js__add-children', function (event) {
|
|||
|
var element = external_jQuery_default()(this);
|
|||
|
var unique_container_id = element.closest('.js__multilevel-field').data('id');
|
|||
|
var level = element.data('level') + 1;
|
|||
|
|
|||
|
var getParentOfElement = function getParentOfElement(element) {
|
|||
|
var parent = element.closest('.js__multilevel-field').parent().first();
|
|||
|
|
|||
|
if (parent.find('.children-wrapper').length === 0) {
|
|||
|
external_jQuery_default()(parent).append('<div class="children-wrapper"></div>');
|
|||
|
}
|
|||
|
|
|||
|
parent = parent.find('.children-wrapper').first();
|
|||
|
return parent;
|
|||
|
};
|
|||
|
|
|||
|
var getNameFromParentInput = function getNameFromParentInput(parentInput, attr) {
|
|||
|
if (parentInput.hasClass('children-wrapper')) {
|
|||
|
parentInput = parentInput.siblings('.js__multilevel-field').first().find('input');
|
|||
|
}
|
|||
|
|
|||
|
return parentInput.attr(attr) + '[' + parentInput.val() + ']';
|
|||
|
};
|
|||
|
|
|||
|
var getInputFromChildrenWrapper = function getInputFromChildrenWrapper(parentChildrenWrapper) {
|
|||
|
return parentChildrenWrapper.siblings('.js__multilevel-field').first().find('input');
|
|||
|
};
|
|||
|
|
|||
|
var parentChildrenWrapper = getParentOfElement(element);
|
|||
|
var parentInput = getInputFromChildrenWrapper(parentChildrenWrapper);
|
|||
|
var attr = 'name';
|
|||
|
|
|||
|
if (parentInput.closest('.js__multilevel-field').hasClass('top')) {
|
|||
|
attr = 'data-attr-name';
|
|||
|
}
|
|||
|
|
|||
|
parentInput.attr(attr, parentInput.attr(attr).replace('[]', ''));
|
|||
|
var name = getNameFromParentInput(parentInput, attr);
|
|||
|
var field = getField(level, name);
|
|||
|
external_jQuery_default()(parentChildrenWrapper).append(field);
|
|||
|
refreshControls(unique_container_id);
|
|||
|
});
|
|||
|
external_jQuery_default()(document).on('click', '[data-grav-multilevel-field] .js__add-sibling', function (event) {
|
|||
|
var element = external_jQuery_default()(this);
|
|||
|
var unique_container_id = element.closest('.js__multilevel-field').data('id');
|
|||
|
var level = element.data('level');
|
|||
|
element.closest('.children-wrapper').find('.js__add-sibling').addClass('hidden');
|
|||
|
var sibling = null;
|
|||
|
var is_top = false;
|
|||
|
|
|||
|
if (element.closest('.js__multilevel-field').hasClass('top')) {
|
|||
|
is_top = true;
|
|||
|
}
|
|||
|
|
|||
|
if (is_top) {
|
|||
|
sibling = element.closest('.js__multilevel-field').first().find('input').last();
|
|||
|
} else {
|
|||
|
sibling = element.siblings('input').first();
|
|||
|
|
|||
|
if (!sibling) {
|
|||
|
sibling = element.closest('.children-wrapper').first().find('input').last();
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
var getParentOfElement = function getParentOfElement(element) {
|
|||
|
var parent = element.closest('.js__multilevel-field').parent().first();
|
|||
|
|
|||
|
if (!parent.hasClass('element-wrapper')) {
|
|||
|
if (parent.find('.element-wrapper').length === 0) {
|
|||
|
external_jQuery_default()(parent).append('<div class="element-wrapper"></div>');
|
|||
|
}
|
|||
|
|
|||
|
parent = parent.find('.element-wrapper').first();
|
|||
|
}
|
|||
|
|
|||
|
return parent;
|
|||
|
};
|
|||
|
|
|||
|
var getNameFromSibling = function getNameFromSibling(parent, sibling) {
|
|||
|
var is_top = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
|
|||
|
var name = sibling.attr('name');
|
|||
|
|
|||
|
if (hasChildInputs(sibling)) {
|
|||
|
var val = sibling.data('attr-name') + '[]';
|
|||
|
sibling.removeAttr('name');
|
|||
|
return val;
|
|||
|
}
|
|||
|
|
|||
|
var last_index = name.lastIndexOf('[');
|
|||
|
var almost_there = name.substr(last_index + 1);
|
|||
|
var last_tag = almost_there.substr(0, almost_there.length - 1);
|
|||
|
|
|||
|
if (external_jQuery_default().isNumeric(last_tag)) {
|
|||
|
name = name.replace('[' + last_tag + ']', '[' + (parseInt(last_tag, 10) + 1) + ']');
|
|||
|
} else {
|
|||
|
if (is_top) {
|
|||
|
name = name.replace('[' + last_tag + ']', '');
|
|||
|
} else {
|
|||
|
name = name + '[1]'; // change sibling name attr if necessary
|
|||
|
|
|||
|
if (sibling.attr('name').slice('-2') !== '[0]') {
|
|||
|
changeAllOccurrencesInTree(sibling, sibling.attr('name'), sibling.attr('name') + '[0]');
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
return name;
|
|||
|
};
|
|||
|
|
|||
|
var parent = getParentOfElement(element);
|
|||
|
var name = getNameFromSibling(parent, sibling, is_top);
|
|||
|
var field = getField(level, name);
|
|||
|
external_jQuery_default()(field).insertAfter(parent);
|
|||
|
refreshControls(unique_container_id);
|
|||
|
});
|
|||
|
external_jQuery_default()(document).on('click', '[data-grav-multilevel-field] .js__remove-item', function (event) {
|
|||
|
external_jQuery_default()(this).parents('.element-wrapper').first().remove();
|
|||
|
var unique_container_id = external_jQuery_default()(this).closest('.js__multilevel-field').data('id');
|
|||
|
refreshControls(unique_container_id);
|
|||
|
}); // Store old value before editing a field
|
|||
|
|
|||
|
external_jQuery_default()(document).on('focusin', '[data-grav-multilevel-field] input', function (event) {
|
|||
|
external_jQuery_default()(this).data('current-value', external_jQuery_default()(this).val());
|
|||
|
}); // Handle field edited event
|
|||
|
|
|||
|
external_jQuery_default()(document).on('change', '[data-grav-multilevel-field] input', function (event) {
|
|||
|
var $el = external_jQuery_default()(this);
|
|||
|
var old_value = $el.data('current-value');
|
|||
|
var new_value = $el.val();
|
|||
|
var full_name = $el.attr('name') || $el.attr('data-attr-name'); // first-level items have `data-attr-name` instead of `name`
|
|||
|
|
|||
|
var old_name_attr = full_name + '[' + old_value + ']';
|
|||
|
var new_name_attr = full_name + '[' + new_value + ']';
|
|||
|
changeAllOccurrencesInTree($el, old_name_attr, new_name_attr);
|
|||
|
});
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/text.js
|
|||
|
|
|||
|
external_jQuery_default()(document).ready(function () {
|
|||
|
external_jQuery_default()('.copy-to-clipboard').click(function (event) {
|
|||
|
var $tempElement = external_jQuery_default()('<input>');
|
|||
|
external_jQuery_default()('body').append($tempElement);
|
|||
|
$tempElement.val(external_jQuery_default()(this).prev('input').val()).select();
|
|||
|
document.execCommand('Copy');
|
|||
|
$tempElement.remove();
|
|||
|
external_jQuery_default()(this).attr('data-hint', 'Copied to clipboard!').addClass('hint--left');
|
|||
|
});
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/range.js
|
|||
|
|
|||
|
external_jQuery_default()(document).on('input', '[type="range"].rangefield, [type="number"].rangefield', function (event) {
|
|||
|
var target = external_jQuery_default()(event.currentTarget);
|
|||
|
var type = target.attr('type').toLowerCase();
|
|||
|
var sibling = type === 'range' ? 'number' : 'range';
|
|||
|
var feedback = target.siblings("[type=\"".concat(sibling, "\"].rangefield"));
|
|||
|
feedback.val(target.val());
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/elements.js
|
|||
|
|
|||
|
external_jQuery_default()(document).on('change', '[data-grav-elements] select', function (event) {
|
|||
|
var target = external_jQuery_default()(event.currentTarget);
|
|||
|
var value = target.val();
|
|||
|
var id = target.closest('[data-grav-elements]').data('gravElements');
|
|||
|
external_jQuery_default()("[id^=\"".concat(id, "_\"]")).css('display', 'none');
|
|||
|
external_jQuery_default()("[id=\"".concat(id, "__").concat(value, "\"]")).css('display', 'inherit');
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/forms/fields/index.js
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
/* harmony default export */ const fields = ({
|
|||
|
FilepickerField: {
|
|||
|
FilepickerField: FilePickerField,
|
|||
|
Instance: filepicker_Instance
|
|||
|
},
|
|||
|
SelectizeField: {
|
|||
|
SelectizeField: SelectizeField,
|
|||
|
Instance: selectize_Instance
|
|||
|
},
|
|||
|
ArrayField: {
|
|||
|
ArrayField: ArrayField,
|
|||
|
Instance: array_Instance
|
|||
|
},
|
|||
|
CollectionsField: {
|
|||
|
CollectionsField: CollectionsField,
|
|||
|
Instance: collections_Instance
|
|||
|
},
|
|||
|
DateTimeField: {
|
|||
|
DateTimeField: DateTimeField,
|
|||
|
Instance: datetime_Instance
|
|||
|
},
|
|||
|
EditorField: {
|
|||
|
EditorField: EditorField,
|
|||
|
Instance: editor_Instance
|
|||
|
},
|
|||
|
ColorpickerField: {
|
|||
|
ColorpickerField: ColorpickerField,
|
|||
|
Instance: colorpicker_Instance
|
|||
|
},
|
|||
|
FilesField: {
|
|||
|
FilesField: FilesField,
|
|||
|
Instance: files_Instance
|
|||
|
},
|
|||
|
FolderField: {
|
|||
|
Regenerate: fields_folder
|
|||
|
},
|
|||
|
SelectUniqueField: {
|
|||
|
SelectUniqueField: SelectUniqueField,
|
|||
|
Instance: selectunique_Instance
|
|||
|
},
|
|||
|
IconpickerField: {
|
|||
|
IconpickerField: IconpickerField,
|
|||
|
Instance: iconpicker_Instance
|
|||
|
},
|
|||
|
CronField: {
|
|||
|
CronField: CronField,
|
|||
|
Instance: cron_Instance
|
|||
|
},
|
|||
|
ParentsField: {
|
|||
|
ParentsField: Parents,
|
|||
|
Instance: parents_Instances
|
|||
|
}
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/forms/index.js
|
|||
|
|
|||
|
|
|||
|
|
|||
|
/* harmony default export */ const app_forms = ({
|
|||
|
Form: {
|
|||
|
Form: Form,
|
|||
|
Instance: form_Instance
|
|||
|
},
|
|||
|
Fields: fields,
|
|||
|
FormState: {
|
|||
|
FormState: FormState,
|
|||
|
Instance: state_Instance
|
|||
|
}
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/utils/packages.js
|
|||
|
function packages_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function packages_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 packages_createClass(Constructor, protoProps, staticProps) { if (protoProps) packages_defineProperties(Constructor.prototype, protoProps); if (staticProps) packages_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var Sorter = /*#__PURE__*/function () {
|
|||
|
function Sorter() {
|
|||
|
packages_classCallCheck(this, Sorter);
|
|||
|
}
|
|||
|
|
|||
|
packages_createClass(Sorter, [{
|
|||
|
key: "getElements",
|
|||
|
value: function getElements(elements, container) {
|
|||
|
this.elements = elements || document.querySelectorAll('[data-gpm-plugin], [data-gpm-theme]');
|
|||
|
this.container = container || document.querySelector('.gpm-plugins > table > tbody, .gpm-themes > .themes.card-row');
|
|||
|
return this.elements;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "byCommon",
|
|||
|
value: function byCommon() {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
var direction = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'asc';
|
|||
|
var data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
|
|||
|
var elements = this.getElements();
|
|||
|
this.removeGumroad();
|
|||
|
Array.from(elements).sort(function (a, b) {
|
|||
|
var A = a.dataset[data].toString().toLowerCase();
|
|||
|
var B = b.dataset[data].toString().toLowerCase();
|
|||
|
return Sorter.sort(A, B, direction);
|
|||
|
}).forEach(function (element) {
|
|||
|
_this.container.appendChild(element);
|
|||
|
});
|
|||
|
this.addGumroad();
|
|||
|
return this.container;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "byName",
|
|||
|
value: function byName() {
|
|||
|
var direction = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'asc';
|
|||
|
var data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'gpmName';
|
|||
|
return this.byCommon(direction, data);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "byAuthor",
|
|||
|
value: function byAuthor() {
|
|||
|
var direction = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'asc';
|
|||
|
var data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'gpmAuthor';
|
|||
|
return this.byCommon(direction, data);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "byOfficial",
|
|||
|
value: function byOfficial() {
|
|||
|
var direction = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'asc';
|
|||
|
var data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'gpmOfficial';
|
|||
|
return this.byCommon(direction, data);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "byPremium",
|
|||
|
value: function byPremium() {
|
|||
|
var direction = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'asc';
|
|||
|
var data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'gpmPremium';
|
|||
|
return this.byCommon(direction, data);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "byReleaseDate",
|
|||
|
value: function byReleaseDate() {
|
|||
|
var _this2 = this;
|
|||
|
|
|||
|
var direction = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'asc';
|
|||
|
var data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'gpmReleaseDate';
|
|||
|
var elements = this.getElements();
|
|||
|
this.removeGumroad();
|
|||
|
Array.from(elements).sort(function (a, b) {
|
|||
|
var A = new Date(a.dataset[data]).getTime();
|
|||
|
var B = new Date(b.dataset[data]).getTime();
|
|||
|
return Sorter.sort(A, B, direction === 'asc' ? 'desc' : 'asc');
|
|||
|
}).forEach(function (element) {
|
|||
|
_this2.container.appendChild(element);
|
|||
|
});
|
|||
|
this.addGumroad();
|
|||
|
return this.container;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "byUpdatable",
|
|||
|
value: function byUpdatable() {
|
|||
|
var direction = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'asc';
|
|||
|
var data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'gpmUpdatable';
|
|||
|
return this.byCommon(direction, data);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "byEnabled",
|
|||
|
value: function byEnabled() {
|
|||
|
var direction = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'asc';
|
|||
|
var data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'gpmEnabled';
|
|||
|
return this.byCommon(direction, data);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "byTesting",
|
|||
|
value: function byTesting() {
|
|||
|
var direction = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'asc';
|
|||
|
var data = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'gpmTesting';
|
|||
|
return this.byCommon(direction, data);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "addGumroad",
|
|||
|
value: function addGumroad() {
|
|||
|
if (window.GumroadOverlay) {
|
|||
|
window.GumroadOverlay.startNodeAdditionObserver();
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "removeGumroad",
|
|||
|
value: function removeGumroad() {
|
|||
|
if (window.GumroadOverlay) {
|
|||
|
window.GumroadOverlay.nodeAdditionObserver.disconnect();
|
|||
|
}
|
|||
|
}
|
|||
|
}], [{
|
|||
|
key: "sort",
|
|||
|
value: function sort(A, B) {
|
|||
|
var direction = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'asc';
|
|||
|
|
|||
|
if (A > B) {
|
|||
|
return direction === 'asc' ? 1 : -1;
|
|||
|
}
|
|||
|
|
|||
|
if (A < B) {
|
|||
|
return direction === 'asc' ? -1 : 1;
|
|||
|
}
|
|||
|
|
|||
|
return 0;
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return Sorter;
|
|||
|
}();
|
|||
|
|
|||
|
var Packages = /*#__PURE__*/function () {
|
|||
|
function Packages() {
|
|||
|
packages_classCallCheck(this, Packages);
|
|||
|
|
|||
|
this.Sort = new Sorter();
|
|||
|
}
|
|||
|
|
|||
|
packages_createClass(Packages, [{
|
|||
|
key: "addDependenciesToList",
|
|||
|
value: function addDependenciesToList(dependencies) {
|
|||
|
var slug = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
|
|||
|
dependencies.forEach(function (dependency) {
|
|||
|
Packages.addDependencyToList('plugin', dependency.name || dependency, slug);
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "removePackage",
|
|||
|
value: function removePackage(type, slug) {
|
|||
|
var _this3 = this;
|
|||
|
|
|||
|
var url = Packages.getRemovePackageUrl(type);
|
|||
|
utils_request(url, {
|
|||
|
method: 'post',
|
|||
|
body: {
|
|||
|
"package": slug
|
|||
|
}
|
|||
|
}, function (response) {
|
|||
|
if (response.status === 'success') {
|
|||
|
external_jQuery_default()('.remove-package-confirm').addClass('hidden');
|
|||
|
|
|||
|
if (response.dependencies && response.dependencies.length > 0) {
|
|||
|
_this3.addDependenciesToList(response.dependencies);
|
|||
|
|
|||
|
external_jQuery_default()('.remove-package-dependencies').removeClass('hidden');
|
|||
|
} else {
|
|||
|
external_jQuery_default()('.remove-package-done').removeClass('hidden');
|
|||
|
} // The package was removed. When the modal closes, move to the packages list
|
|||
|
|
|||
|
|
|||
|
external_jQuery_default()(document).on('closing', '[data-remodal-id="remove-package"]', function () {
|
|||
|
Packages.getBackToList(type);
|
|||
|
});
|
|||
|
} else {
|
|||
|
external_jQuery_default()('.remove-package-confirm').addClass('hidden');
|
|||
|
external_jQuery_default()('.remove-package-error').removeClass('hidden');
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "reinstallPackage",
|
|||
|
value: function reinstallPackage(type, slug, package_name, current_version) {
|
|||
|
external_jQuery_default()('.button-bar button').addClass('hidden');
|
|||
|
external_jQuery_default()('.button-bar .spinning-wheel').removeClass('hidden');
|
|||
|
var url = Packages.getReinstallPackageUrl(type);
|
|||
|
utils_request(url, {
|
|||
|
method: 'post',
|
|||
|
body: {
|
|||
|
slug: slug,
|
|||
|
type: type,
|
|||
|
package_name: package_name,
|
|||
|
current_version: current_version
|
|||
|
}
|
|||
|
}, function (response) {
|
|||
|
if (response.status === 'success') {
|
|||
|
external_jQuery_default()('.reinstall-package-confirm').addClass('hidden');
|
|||
|
external_jQuery_default()('.reinstall-package-done').removeClass('hidden');
|
|||
|
} else {
|
|||
|
external_jQuery_default()('.reinstall-package-confirm').addClass('hidden');
|
|||
|
external_jQuery_default()('.reinstall-package-error').removeClass('hidden');
|
|||
|
}
|
|||
|
|
|||
|
window.location.reload();
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "removeDependency",
|
|||
|
value: function removeDependency(type, slug, button) {
|
|||
|
var _this4 = this;
|
|||
|
|
|||
|
var url = Packages.getRemovePackageUrl(type);
|
|||
|
utils_request(url, {
|
|||
|
method: 'post',
|
|||
|
body: {
|
|||
|
"package": slug
|
|||
|
}
|
|||
|
}, function (response) {
|
|||
|
if (response.status === 'success') {
|
|||
|
button.removeClass('button');
|
|||
|
button.replaceWith(external_jQuery_default()('<span>Removed successfully</span>'));
|
|||
|
|
|||
|
if (response.dependencies && response.dependencies.length > 0) {
|
|||
|
_this4.addDependenciesToList(response.dependencies, slug);
|
|||
|
}
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "getPackagesDependencies",
|
|||
|
value: function getPackagesDependencies(type, slugs, finishedLoadingCallback) {
|
|||
|
var url = Packages.getGetPackagesDependenciesUrl(type);
|
|||
|
utils_request(url, {
|
|||
|
method: 'post',
|
|||
|
body: {
|
|||
|
packages: slugs
|
|||
|
}
|
|||
|
}, function (response) {
|
|||
|
finishedLoadingCallback();
|
|||
|
|
|||
|
if (response.status === 'success') {
|
|||
|
if (response.dependencies) {
|
|||
|
var hasDependencies = false;
|
|||
|
|
|||
|
for (var dependency in response.dependencies) {
|
|||
|
if (response.dependencies.hasOwnProperty(dependency)) {
|
|||
|
if (dependency === 'grav') {
|
|||
|
continue;
|
|||
|
}
|
|||
|
|
|||
|
hasDependencies = true;
|
|||
|
var dependencyName = dependency;
|
|||
|
var action = response.dependencies[dependency];
|
|||
|
Packages.addNeededDependencyToList(action, dependencyName);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if (hasDependencies) {
|
|||
|
external_jQuery_default()('[data-packages-modal] .install-dependencies-package-container').removeClass('hidden');
|
|||
|
} else {
|
|||
|
external_jQuery_default()('[data-packages-modal] .install-package-container').removeClass('hidden');
|
|||
|
}
|
|||
|
} else {
|
|||
|
external_jQuery_default()('[data-packages-modal] .install-package-container').removeClass('hidden');
|
|||
|
}
|
|||
|
} else {
|
|||
|
external_jQuery_default()('[data-packages-modal] .install-package-error').removeClass('hidden');
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "installDependenciesOfPackages",
|
|||
|
value: function installDependenciesOfPackages(type, slugs, callbackSuccess, callbackError) {
|
|||
|
var url = Packages.getInstallDependenciesOfPackagesUrl(type);
|
|||
|
utils_request(url, {
|
|||
|
method: 'post',
|
|||
|
body: {
|
|||
|
packages: slugs
|
|||
|
}
|
|||
|
}, callbackSuccess);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "installPackages",
|
|||
|
value: function installPackages(type, slugs, callbackSuccess) {
|
|||
|
var url = Packages.getInstallPackageUrl(type);
|
|||
|
__webpack_require__.g.Promise.all(slugs.map(function (slug) {
|
|||
|
return new __webpack_require__.g.Promise(function (resolve, reject) {
|
|||
|
utils_request(url, {
|
|||
|
method: 'post',
|
|||
|
body: {
|
|||
|
"package": slug,
|
|||
|
type: type
|
|||
|
}
|
|||
|
}, function (response) {
|
|||
|
resolve(response);
|
|||
|
});
|
|||
|
});
|
|||
|
})).then(callbackSuccess);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "handleGettingPackageDependencies",
|
|||
|
value: function handleGettingPackageDependencies(type, event) {
|
|||
|
var action = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'update';
|
|||
|
var slugs = Packages.getSlugsFromEvent(event);
|
|||
|
|
|||
|
if (!slugs) {
|
|||
|
alert('No slug set');
|
|||
|
return;
|
|||
|
} // Cleanup
|
|||
|
|
|||
|
|
|||
|
external_jQuery_default()('.packages-names-list').html('');
|
|||
|
external_jQuery_default()('.install-dependencies-package-container li').remove();
|
|||
|
slugs.forEach(function (slug) {
|
|||
|
if (action === 'update') {
|
|||
|
var current_version = '';
|
|||
|
var available_version = '';
|
|||
|
var _name = '';
|
|||
|
var resources = Instance.payload.payload.resources;
|
|||
|
|
|||
|
if (resources.plugins[slug]) {
|
|||
|
available_version = resources.plugins[slug].available;
|
|||
|
current_version = resources.plugins[slug].version;
|
|||
|
_name = resources.plugins[slug].name;
|
|||
|
} else if (resources.themes[slug]) {
|
|||
|
available_version = resources.themes[slug].available;
|
|||
|
current_version = resources.themes[slug].version;
|
|||
|
_name = resources.themes[slug].name;
|
|||
|
}
|
|||
|
|
|||
|
external_jQuery_default()('.packages-names-list').append("<li>".concat(_name ? _name : slug, ", ").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.FROM, " v<strong>").concat(current_version, "</strong> ").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.TO, " v<strong>").concat(available_version, "</strong></li>"));
|
|||
|
} else {
|
|||
|
external_jQuery_default()('.packages-names-list').append("<li>".concat(name ? name : slug, "</li>"));
|
|||
|
}
|
|||
|
});
|
|||
|
event.preventDefault();
|
|||
|
event.stopPropagation(); // fix mismatching types when sharing install modal between plugins/themes
|
|||
|
|
|||
|
var query = '[data-packages-modal] [data-theme-action], [data-packages-modal] [data-plugin-action]';
|
|||
|
var data = external_jQuery_default()(query).data('themeAction') || external_jQuery_default()(query).data('pluginAction');
|
|||
|
external_jQuery_default()(query).removeAttr('data-theme-action').removeAttr('data-plugin-action').attr("data-".concat(type, "-action"), data); // Restore original state
|
|||
|
|
|||
|
external_jQuery_default()('[data-packages-modal] .loading').removeClass('hidden');
|
|||
|
external_jQuery_default()('[data-packages-modal] .install-dependencies-package-container').addClass('hidden');
|
|||
|
external_jQuery_default()('[data-packages-modal] .install-package-container').addClass('hidden');
|
|||
|
external_jQuery_default()('[data-packages-modal] .installing-dependencies').addClass('hidden');
|
|||
|
external_jQuery_default()('[data-packages-modal] .installing-package').addClass('hidden');
|
|||
|
external_jQuery_default()('[data-packages-modal] .installation-complete').addClass('hidden');
|
|||
|
external_jQuery_default()('[data-packages-modal] .install-package-error').addClass('hidden');
|
|||
|
this.getPackagesDependencies(type, slugs, function () {
|
|||
|
var slugs_string = slugs.join();
|
|||
|
external_jQuery_default()("[data-packages-modal] [data-".concat(type, "-action=\"install-dependencies-and-package\"]")).attr('data-packages-slugs', slugs_string);
|
|||
|
external_jQuery_default()("[data-packages-modal] [data-".concat(type, "-action=\"install-package\"]")).attr('data-packages-slugs', slugs_string);
|
|||
|
external_jQuery_default()('[data-packages-modal] .loading').addClass('hidden');
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "handleInstallingDependenciesAndPackage",
|
|||
|
value: function handleInstallingDependenciesAndPackage(type, event) {
|
|||
|
var _this5 = this;
|
|||
|
|
|||
|
var slugs = Packages.getSlugsFromEvent(event);
|
|||
|
event.preventDefault();
|
|||
|
event.stopPropagation();
|
|||
|
external_jQuery_default()('[data-packages-modal] .install-dependencies-package-container').addClass('hidden');
|
|||
|
external_jQuery_default()('[data-packages-modal] .install-package-container').addClass('hidden');
|
|||
|
external_jQuery_default()('[data-packages-modal] .installing-dependencies').removeClass('hidden');
|
|||
|
this.installDependenciesOfPackages(type, slugs, function (response) {
|
|||
|
external_jQuery_default()('[data-packages-modal] .installing-dependencies').addClass('hidden');
|
|||
|
external_jQuery_default()('[data-packages-modal] .installing-package').removeClass('hidden');
|
|||
|
|
|||
|
_this5.installPackages(type, slugs, function () {
|
|||
|
external_jQuery_default()('[data-packages-modal] .installing-package').addClass('hidden');
|
|||
|
external_jQuery_default()('[data-packages-modal] .installation-complete').removeClass('hidden');
|
|||
|
|
|||
|
if (response.status === 'error') {
|
|||
|
var remodal = (external_jQuery_default()).remodal.lookup[external_jQuery_default()('[data-packages-modal]').data('remodal')];
|
|||
|
remodal.close();
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
setTimeout(function () {
|
|||
|
if (slugs.length === 1) {
|
|||
|
__webpack_require__.g.location.href = "".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/").concat(type, "s/").concat(slugs[0]);
|
|||
|
} else {
|
|||
|
__webpack_require__.g.location.href = "".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/").concat(type, "s");
|
|||
|
}
|
|||
|
}, 1000);
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "handleInstallingPackage",
|
|||
|
value: function handleInstallingPackage(type, event) {
|
|||
|
var slugs = Packages.getSlugsFromEvent(event);
|
|||
|
event.preventDefault();
|
|||
|
event.stopPropagation();
|
|||
|
external_jQuery_default()('[data-packages-modal] .install-package-container').addClass('hidden');
|
|||
|
external_jQuery_default()('[data-packages-modal] .installing-package').removeClass('hidden');
|
|||
|
this.installPackages(type, slugs, function (response) {
|
|||
|
external_jQuery_default()('[data-packages-modal] .installing-package').addClass('hidden');
|
|||
|
external_jQuery_default()('[data-packages-modal] .installation-complete').removeClass('hidden');
|
|||
|
var errors = Array.from(response).filter(function (r) {
|
|||
|
return r.status === 'error';
|
|||
|
});
|
|||
|
|
|||
|
if (errors && errors.length) {
|
|||
|
var remodal = (external_jQuery_default()).remodal.lookup[external_jQuery_default()('[data-packages-modal].remodal-is-opened').data('remodal')];
|
|||
|
remodal.close();
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
if (slugs.length === 1) {
|
|||
|
__webpack_require__.g.location.href = "".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/").concat(type, "s/").concat(slugs[0]);
|
|||
|
} else {
|
|||
|
__webpack_require__.g.location.href = "".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/").concat(type, "s");
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "handleRemovingPackage",
|
|||
|
value: function handleRemovingPackage(type, event) {
|
|||
|
var slug = external_jQuery_default()(event.target).attr('data-packages-slugs');
|
|||
|
event.preventDefault();
|
|||
|
event.stopPropagation();
|
|||
|
this.removePackage(type, slug);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "handleReinstallPackage",
|
|||
|
value: function handleReinstallPackage(type, event) {
|
|||
|
var target = external_jQuery_default()(event.target);
|
|||
|
var slug = target.attr('data-package-slug');
|
|||
|
var package_name = target.attr('data-package-name');
|
|||
|
var current_version = target.attr('data-package-current-version');
|
|||
|
event.preventDefault();
|
|||
|
event.stopPropagation();
|
|||
|
this.reinstallPackage(type, slug, package_name, current_version);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "handleRemovingDependency",
|
|||
|
value: function handleRemovingDependency(type, event) {
|
|||
|
var slug = external_jQuery_default()(event.target).attr('data-dependency-slug');
|
|||
|
var button = external_jQuery_default()(event.target);
|
|||
|
event.preventDefault();
|
|||
|
event.stopPropagation();
|
|||
|
this.removeDependency(type, slug, button);
|
|||
|
}
|
|||
|
}], [{
|
|||
|
key: "getBackToList",
|
|||
|
value: function getBackToList(type) {
|
|||
|
__webpack_require__.g.location.href = "".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/").concat(type, "s");
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "addDependencyToList",
|
|||
|
value: function addDependencyToList(type, dependency) {
|
|||
|
var slug = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '';
|
|||
|
|
|||
|
if (['admin', 'form', 'login', 'email', 'grav'].indexOf(dependency) !== -1) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var container = external_jQuery_default()('.package-dependencies-container');
|
|||
|
var text = "".concat(dependency, " <a href=\"#\" class=\"button\" data-dependency-slug=\"").concat(dependency, "\" data-").concat(type, "-action=\"remove-dependency-package\">Remove</a>");
|
|||
|
|
|||
|
if (slug) {
|
|||
|
text += " (was needed by ".concat(slug, ")");
|
|||
|
}
|
|||
|
|
|||
|
container.append("<li>".concat(text, "</li>"));
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "getTaskUrl",
|
|||
|
value: function getTaskUrl(type, task) {
|
|||
|
var url = "".concat(external_GravAdmin_namespaceObject.config.base_url_relative);
|
|||
|
url += "/".concat(type, "s.json");
|
|||
|
url += "/task".concat(external_GravAdmin_namespaceObject.config.param_sep).concat(task);
|
|||
|
return url;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "getRemovePackageUrl",
|
|||
|
value: function getRemovePackageUrl(type) {
|
|||
|
return "".concat(Packages.getTaskUrl(type, 'removePackage'));
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "getReinstallPackageUrl",
|
|||
|
value: function getReinstallPackageUrl(type) {
|
|||
|
return "".concat(Packages.getTaskUrl(type, 'reinstallPackage'));
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "getGetPackagesDependenciesUrl",
|
|||
|
value: function getGetPackagesDependenciesUrl(type) {
|
|||
|
return "".concat(Packages.getTaskUrl(type, 'getPackagesDependencies'));
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "getInstallDependenciesOfPackagesUrl",
|
|||
|
value: function getInstallDependenciesOfPackagesUrl(type) {
|
|||
|
return "".concat(Packages.getTaskUrl(type, 'installDependenciesOfPackages'));
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "getInstallPackageUrl",
|
|||
|
value: function getInstallPackageUrl(type) {
|
|||
|
return "".concat(Packages.getTaskUrl(type, 'installPackage'));
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "addNeededDependencyToList",
|
|||
|
value: function addNeededDependencyToList(action, slug) {
|
|||
|
external_jQuery_default()('.install-dependencies-package-container .type-' + action).removeClass('hidden');
|
|||
|
var list = external_jQuery_default()('.install-dependencies-package-container .type-' + action + ' ul');
|
|||
|
|
|||
|
if (action !== 'install') {
|
|||
|
var current_version = '';
|
|||
|
var available_version = '';
|
|||
|
var _name2 = '';
|
|||
|
var resources = Instance.payload.payload.resources;
|
|||
|
|
|||
|
if (resources.plugins[slug]) {
|
|||
|
available_version = resources.plugins[slug].available;
|
|||
|
current_version = resources.plugins[slug].version;
|
|||
|
_name2 = resources.plugins[slug].name;
|
|||
|
} else if (resources.themes[slug]) {
|
|||
|
available_version = resources.themes[slug].available;
|
|||
|
current_version = resources.themes[slug].version;
|
|||
|
_name2 = resources.themes[slug].name;
|
|||
|
}
|
|||
|
|
|||
|
list.append("<li>".concat(_name2 ? _name2 : slug, ", ").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.FROM, " v<strong>").concat(current_version, "</strong> ").concat(external_GravAdmin_namespaceObject.translations.PLUGIN_ADMIN.TO, " v<strong>").concat(available_version, "</strong></li>"));
|
|||
|
} else {
|
|||
|
list.append("<li>".concat(name ? name : slug, "</li>"));
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "getSlugsFromEvent",
|
|||
|
value: function getSlugsFromEvent(event) {
|
|||
|
var slugs = '';
|
|||
|
|
|||
|
if (external_jQuery_default()(event.target).is('[data-packages-slugs]')) {
|
|||
|
slugs = external_jQuery_default()(event.target).attr('data-packages-slugs');
|
|||
|
} else {
|
|||
|
slugs = external_jQuery_default()(event.target).parent('[data-packages-slugs]').attr('data-packages-slugs');
|
|||
|
}
|
|||
|
|
|||
|
if (typeof slugs === 'undefined') {
|
|||
|
return null;
|
|||
|
}
|
|||
|
|
|||
|
slugs = slugs.split(',');
|
|||
|
return typeof slugs === 'string' ? [slugs] : slugs;
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return Packages;
|
|||
|
}();
|
|||
|
|
|||
|
/* harmony default export */ const utils_packages = (new Packages());
|
|||
|
// EXTERNAL MODULE: ./node_modules/mout/string/camelCase.js
|
|||
|
var camelCase = __webpack_require__(71047);
|
|||
|
var camelCase_default = /*#__PURE__*/__webpack_require__.n(camelCase);
|
|||
|
// EXTERNAL MODULE: ./node_modules/mout/string/contains.js
|
|||
|
var contains = __webpack_require__(85286);
|
|||
|
var contains_default = /*#__PURE__*/__webpack_require__.n(contains);
|
|||
|
;// CONCATENATED MODULE: ./app/plugins/index.js
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
// Plugins sliders details
|
|||
|
|
|||
|
external_jQuery_default()('.gpm-name, .gpm-actions').on('click', function (e) {
|
|||
|
var element = external_jQuery_default()(this);
|
|||
|
var target = external_jQuery_default()(e.target);
|
|||
|
var tag = target.prop('tagName').toLowerCase();
|
|||
|
|
|||
|
if (tag === 'a' || element.parent('a').length || target.parent('a').length) {
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
var wrapper = element.siblings('.gpm-details').find('.table-wrapper');
|
|||
|
wrapper.slideToggle({
|
|||
|
duration: 350,
|
|||
|
complete: function complete() {
|
|||
|
var visible = wrapper.is(':visible');
|
|||
|
wrapper.closest('tr').find('.gpm-details-expand i').removeClass('fa-chevron-' + (visible ? 'down' : 'up')).addClass('fa-chevron-' + (visible ? 'up' : 'down'));
|
|||
|
}
|
|||
|
});
|
|||
|
}); // Removing plugin
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', '[data-plugin-action="remove-package"]', function (event) {
|
|||
|
utils_packages.handleRemovingPackage('plugin', event);
|
|||
|
}); // Reinstall plugin
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', '[data-plugin-action="reinstall-package"]', function (event) {
|
|||
|
utils_packages.handleReinstallPackage('plugin', event);
|
|||
|
});
|
|||
|
external_jQuery_default()(document).on('click', '[data-plugin-action="remove-dependency-package"]', function (event) {
|
|||
|
utils_packages.handleRemovingDependency('plugin', event);
|
|||
|
}); // Trigger the add new plugin / update plugin modal
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', '[data-plugin-action="start-package-installation"]', function (event) {
|
|||
|
utils_packages.handleGettingPackageDependencies('plugin', event, 'install');
|
|||
|
}); // Trigger the update all plugins modal
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', '[data-plugin-action="start-packages-update"]', function (event) {
|
|||
|
utils_packages.handleGettingPackageDependencies('plugin', event);
|
|||
|
}); // Install a plugin dependencies and the plugin
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', '[data-plugin-action="install-dependencies-and-package"]', function (event) {
|
|||
|
utils_packages.handleInstallingDependenciesAndPackage('plugin', event);
|
|||
|
}); // Install a plugin
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', '[data-plugin-action="install-package"]', function (event) {
|
|||
|
utils_packages.handleInstallingPackage('plugin', event);
|
|||
|
}); // Sort plugins/themes dropdown
|
|||
|
|
|||
|
external_jQuery_default()(document).on('change', '.sort-actions select', function (event) {
|
|||
|
var direction = external_jQuery_default()('.sort-actions .sort-icon .fa').hasClass('fa-sort-amount-desc') ? 'desc' : 'asc';
|
|||
|
var sorting = external_jQuery_default()(event.currentTarget).val();
|
|||
|
utils_packages.Sort[camelCase_default()("by-".concat(sorting))](direction);
|
|||
|
}); // Sort plugins/themes icon
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', '.sort-icon', function (event) {
|
|||
|
var icon = external_jQuery_default()(event.currentTarget).find('.fa');
|
|||
|
var current = icon.hasClass('fa-sort-amount-asc') ? 'asc' : 'desc';
|
|||
|
var opposite = current === 'asc' ? 'desc' : 'asc';
|
|||
|
icon.removeClass("fa-sort-amount-".concat(current)).addClass("fa-sort-amount-".concat(opposite));
|
|||
|
external_jQuery_default()('.sort-actions select').trigger('change');
|
|||
|
}); // Filter plugin/theme
|
|||
|
|
|||
|
external_jQuery_default()(document).on('input', '[data-gpm-filter]', debounce_default()(function (event) {
|
|||
|
var value = external_jQuery_default()(external_jQuery_default()(event.currentTarget)).val();
|
|||
|
var items = external_jQuery_default()('[data-gpm-plugin], [data-gpm-theme]');
|
|||
|
items.hide().filter(function (index, item) {
|
|||
|
item = external_jQuery_default()(item);
|
|||
|
return contains_default()(item.data('gpm-plugin'), value) || contains_default()(item.data('gpm-theme'), value) || contains_default()(item.data('gpm-name').toLowerCase(), value.toLowerCase());
|
|||
|
}).show();
|
|||
|
}, 250));
|
|||
|
;// CONCATENATED MODULE: ./app/themes/index.js
|
|||
|
|
|||
|
// Themes Switcher Warning
|
|||
|
|
|||
|
external_jQuery_default()(document).on('mousedown', '[data-remodal-target="theme-switch-warn"]', function (event) {
|
|||
|
var name = external_jQuery_default()(event.target).closest('[data-gpm-theme]').find('.gpm-name a:first').text();
|
|||
|
var remodal = external_jQuery_default()('.remodal.theme-switcher');
|
|||
|
remodal.find('strong').text(name);
|
|||
|
remodal.find('.button.continue').attr('href', external_jQuery_default()(event.target).attr('href'));
|
|||
|
}); // Removing theme
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', '[data-theme-action="remove-package"]', function (event) {
|
|||
|
utils_packages.handleRemovingPackage('theme', event);
|
|||
|
}); // Reinstall theme
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', '[data-theme-action="reinstall-package"]', function (event) {
|
|||
|
utils_packages.handleReinstallPackage('theme', event);
|
|||
|
});
|
|||
|
external_jQuery_default()(document).on('click', '[data-theme-action="remove-dependency-package"]', function (event) {
|
|||
|
utils_packages.handleRemovingDependency('theme', event);
|
|||
|
}); // Opened the add new theme / update theme modal
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', '[data-theme-action="start-package-installation"]', function (event) {
|
|||
|
utils_packages.handleGettingPackageDependencies('theme', event, 'install');
|
|||
|
}); // Trigger the update all themes modal
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', '[data-theme-action="start-packages-update"]', function (event) {
|
|||
|
utils_packages.handleGettingPackageDependencies('theme', event);
|
|||
|
}); // Install a theme dependencies and the theme
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', '[data-theme-action="install-dependencies-and-package"]', function (event) {
|
|||
|
utils_packages.handleInstallingDependenciesAndPackage('theme', event);
|
|||
|
}); // Install a theme
|
|||
|
|
|||
|
external_jQuery_default()(document).on('click', '[data-theme-action="install-package"]', function (event) {
|
|||
|
utils_packages.handleInstallingPackage('theme', event);
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/media/index.js
|
|||
|
function app_media_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function app_media_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 app_media_createClass(Constructor, protoProps, staticProps) { if (protoProps) app_media_defineProperties(Constructor.prototype, protoProps); if (staticProps) app_media_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var Filter = /*#__PURE__*/function () {
|
|||
|
function Filter() {
|
|||
|
app_media_classCallCheck(this, Filter);
|
|||
|
|
|||
|
this.URI = "".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/media-manager/");
|
|||
|
}
|
|||
|
|
|||
|
app_media_createClass(Filter, [{
|
|||
|
key: "filter",
|
|||
|
value: function filter(name, value) {
|
|||
|
var filtered = [];
|
|||
|
var keys = Object.keys(external_GravAdmin_namespaceObject.uri_params);
|
|||
|
|
|||
|
if (!~keys.indexOf(name)) {
|
|||
|
keys.push(name);
|
|||
|
}
|
|||
|
|
|||
|
keys.forEach(function (key) {
|
|||
|
var filter = Filter.cleanValue(key === name ? value : external_GravAdmin_namespaceObject.uri_params[key]);
|
|||
|
|
|||
|
if (filter !== '*') {
|
|||
|
filtered.push("".concat(key).concat(external_GravAdmin_namespaceObject.config.param_sep).concat(filter));
|
|||
|
}
|
|||
|
});
|
|||
|
__webpack_require__.g.location = this.URI + filtered.join('/');
|
|||
|
}
|
|||
|
}], [{
|
|||
|
key: "cleanValue",
|
|||
|
value: function cleanValue(value) {
|
|||
|
return encodeURIComponent(value.replace('/', '\\'));
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return Filter;
|
|||
|
}();
|
|||
|
|
|||
|
|
|||
|
var app_media_Instance = new Filter();
|
|||
|
var isLoading = false;
|
|||
|
var filters = {};
|
|||
|
var global_index = 1;
|
|||
|
var files_ended = false;
|
|||
|
var MEDIA_PAGINATION_INTERVAL = 20;
|
|||
|
/* handle changing file type / date filter */
|
|||
|
|
|||
|
external_jQuery_default()('body').on('change', '.thumbs-list-container select.filter', function (event) {
|
|||
|
var target = external_jQuery_default()(event.currentTarget);
|
|||
|
var filterName = target.data('name');
|
|||
|
var filterValue = target.val();
|
|||
|
|
|||
|
if (filterValue) {
|
|||
|
filters[filterName] = filterValue;
|
|||
|
} else {
|
|||
|
delete filters[filterName];
|
|||
|
}
|
|||
|
|
|||
|
filterFiles();
|
|||
|
});
|
|||
|
/* initialize media uploader */
|
|||
|
|
|||
|
if (external_jQuery_default()('.thumbs-list-container .dropzone')[0]) {
|
|||
|
external_jQuery_default()('.thumbs-list-container .dropzone')[0].dropzone.on('queuecomplete', function () {
|
|||
|
var body = {};
|
|||
|
|
|||
|
if (filters.page) {
|
|||
|
body.page = filters.page;
|
|||
|
}
|
|||
|
|
|||
|
if (filters.date) {
|
|||
|
body.date = filters.date;
|
|||
|
}
|
|||
|
|
|||
|
if (filters.type) {
|
|||
|
body.type = filters.type;
|
|||
|
}
|
|||
|
|
|||
|
external_jQuery_default()('.dropzone')[0].dropzone.files.forEach(function (file) {
|
|||
|
file.previewElement.remove();
|
|||
|
});
|
|||
|
external_jQuery_default()('.dropzone').first().removeClass('dz-started');
|
|||
|
utils_request("".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/media-manager.json/task").concat(external_GravAdmin_namespaceObject.config.param_sep, "clearMediaCache"), {
|
|||
|
method: 'post',
|
|||
|
body: body
|
|||
|
}, function () {
|
|||
|
filterFiles();
|
|||
|
});
|
|||
|
});
|
|||
|
}
|
|||
|
/* handle loading media */
|
|||
|
|
|||
|
|
|||
|
var loadMedia = function loadMedia(filters, callback) {
|
|||
|
var url = "".concat(external_GravAdmin_namespaceObject.config.base_url_relative, "/media.json/tmpl").concat(external_GravAdmin_namespaceObject.config.param_sep, "media-list-content/index").concat(external_GravAdmin_namespaceObject.config.param_sep).concat(global_index);
|
|||
|
|
|||
|
if (filters.page) {
|
|||
|
url += "/page".concat(external_GravAdmin_namespaceObject.config.param_sep).concat(filters.page.split('/').join('%5C'));
|
|||
|
}
|
|||
|
|
|||
|
if (filters.type && filters.type !== '*') {
|
|||
|
url += "/type".concat(external_GravAdmin_namespaceObject.config.param_sep).concat(filters.type);
|
|||
|
}
|
|||
|
|
|||
|
if (filters.date && filters.date !== '*') {
|
|||
|
url += "/date".concat(external_GravAdmin_namespaceObject.config.param_sep).concat(filters.date);
|
|||
|
}
|
|||
|
|
|||
|
if (!isLoading) {
|
|||
|
isLoading = true;
|
|||
|
external_jQuery_default()('.spinning-wheel').show();
|
|||
|
external_jQuery_default().get(url, function (content) {
|
|||
|
external_jQuery_default()('.js__files').append(content);
|
|||
|
external_jQuery_default()('.spinning-wheel').hide();
|
|||
|
external_jQuery_default()('.media-container .media-range').trigger('change');
|
|||
|
isLoading = false;
|
|||
|
global_index++;
|
|||
|
callback(content);
|
|||
|
});
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
var cleanFilesList = function cleanFilesList() {
|
|||
|
external_jQuery_default()('.js__files .card-item').remove();
|
|||
|
};
|
|||
|
|
|||
|
var resetActiveStateInSidebar = function resetActiveStateInSidebar() {
|
|||
|
external_jQuery_default()('.pages-list-container .row').removeClass('active'); // clear active state in sidebar
|
|||
|
};
|
|||
|
|
|||
|
var showEmptyState = function showEmptyState() {
|
|||
|
external_jQuery_default()('.thumbs-list-container').append('<p class="card-item empty-space">No media found</p>');
|
|||
|
};
|
|||
|
|
|||
|
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()('<a class="nav-next hide"></a>');
|
|||
|
var navPrev = external_jQuery_default()('<a class="nav-prev hide"></a>');
|
|||
|
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()("<link id=\"admin-pro-preview-".concat(key, "\" type=\"text/css\" rel=\"stylesheet\" />"));
|
|||
|
external_jQuery_default()('head').append(file);
|
|||
|
|
|||
|
if (!external_jQuery_default()('[data-reset-scss]').length) {
|
|||
|
var reset = external_jQuery_default()('<button class="button" data-reset-scss style="margin-left: 5px;"><i class="fa fa-fw fa-history"></i> Reset</button>');
|
|||
|
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"; return bootstrap_collapse_typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, 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('<div class="changelog-overflow center" style="padding:5rem 0;text-align:center;"><i class="fa fa-spinner fa-spin fa-3x fa-fw"></i></div>');
|
|||
|
|
|||
|
if (!TRIGGER) {
|
|||
|
return true;
|
|||
|
}
|
|||
|
|
|||
|
var url = external_jQuery_default()(TRIGGER).data('remodalChangelog');
|
|||
|
external_jQuery_default().ajax({
|
|||
|
url: url
|
|||
|
}).done(function (data) {
|
|||
|
instance.$modal.html(data);
|
|||
|
});
|
|||
|
});
|
|||
|
external_jQuery_default()(document).on('closed', '[data-remodal-id="changelog"]', function () {
|
|||
|
var instance = (external_jQuery_default()).remodal.lookup[external_jQuery_default()('[data-remodal-id=changelog]').data('remodal')];
|
|||
|
instance.$modal.html('');
|
|||
|
});
|
|||
|
;// CONCATENATED MODULE: ./app/utils/sidebar.js
|
|||
|
function sidebar_classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|||
|
|
|||
|
function sidebar_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 sidebar_createClass(Constructor, protoProps, staticProps) { if (protoProps) sidebar_defineProperties(Constructor.prototype, protoProps); if (staticProps) sidebar_defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|||
|
|
|||
|
|
|||
|
|
|||
|
var MOBILE_BREAKPOINT = 48 - 0.062;
|
|||
|
var DESKTOP_BREAKPOINT = 75 + 0.063;
|
|||
|
var EVENTS = 'touchstart._grav click._grav';
|
|||
|
var TARGETS = '[data-sidebar-mobile-toggle], #overlay';
|
|||
|
var MOBILE_QUERY = "(max-width: ".concat(MOBILE_BREAKPOINT, "em)");
|
|||
|
var DESKTOP_QUERY = "(min-width: ".concat(DESKTOP_BREAKPOINT, "em)");
|
|||
|
var map = new __webpack_require__.g.Map();
|
|||
|
|
|||
|
var Sidebar = /*#__PURE__*/function () {
|
|||
|
function Sidebar() {
|
|||
|
sidebar_classCallCheck(this, Sidebar);
|
|||
|
|
|||
|
this.timeout = null;
|
|||
|
this.isOpen = false;
|
|||
|
this.body = external_jQuery_default()('body');
|
|||
|
this.matchMedia = __webpack_require__.g.matchMedia(MOBILE_QUERY);
|
|||
|
this.enable();
|
|||
|
}
|
|||
|
|
|||
|
sidebar_createClass(Sidebar, [{
|
|||
|
key: "enable",
|
|||
|
value: function enable() {
|
|||
|
var sidebar = external_jQuery_default()('#admin-sidebar');
|
|||
|
this.matchMedia.addListener(this._getBound('checkMatch'));
|
|||
|
this.checkMatch(this.matchMedia);
|
|||
|
this.body.on(EVENTS, '[data-sidebar-toggle]', this._getBound('toggleSidebarState'));
|
|||
|
|
|||
|
if (sidebar.data('quickopen')) {
|
|||
|
sidebar.hover(this._getBound('quickOpenIn'), this._getBound('quickOpenOut'));
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "disable",
|
|||
|
value: function disable() {
|
|||
|
var sidebar = external_jQuery_default()('#admin-sidebar');
|
|||
|
this.close();
|
|||
|
this.matchMedia.removeListener(this._getBound('checkMatch'));
|
|||
|
this.body.off(EVENTS, '[data-sidebar-toggle]', this._getBound('toggleSidebarState'));
|
|||
|
|
|||
|
if (sidebar.data('quickopen')) {
|
|||
|
sidebar.off('mouseenter mouseleave');
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "attach",
|
|||
|
value: function attach() {
|
|||
|
this.body.on(EVENTS, TARGETS, this._getBound('toggle'));
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "detach",
|
|||
|
value: function detach() {
|
|||
|
this.body.off(EVENTS, TARGETS, this._getBound('toggle'));
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "quickOpenIn",
|
|||
|
value: function
|
|||
|
/* event */
|
|||
|
quickOpenIn() {
|
|||
|
var _this = this;
|
|||
|
|
|||
|
var isDesktop = __webpack_require__.g.matchMedia(DESKTOP_QUERY).matches;
|
|||
|
var delay = external_jQuery_default()('#admin-sidebar').data('quickopen-delay') || 500;
|
|||
|
|
|||
|
if (this.body.hasClass('sidebar-mobile-open')) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var shouldQuickOpen = isDesktop ? this.body.hasClass('sidebar-closed') : !this.body.hasClass('sidebar-open');
|
|||
|
|
|||
|
if (!shouldQuickOpen && !this.body.hasClass('sidebar-quickopen')) {
|
|||
|
return this.quickOpenOut();
|
|||
|
}
|
|||
|
|
|||
|
this.timeout = setTimeout(function () {
|
|||
|
_this.body.addClass('sidebar-open sidebar-quickopen');
|
|||
|
|
|||
|
external_jQuery_default()(__webpack_require__.g).trigger('sidebar_state._grav', isDesktop);
|
|||
|
}, delay);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "quickOpenOut",
|
|||
|
value: function
|
|||
|
/* event */
|
|||
|
quickOpenOut() {
|
|||
|
clearTimeout(this.timeout);
|
|||
|
|
|||
|
if (this.body.hasClass('sidebar-quickopen')) {
|
|||
|
this.body.removeClass('sidebar-open sidebar-quickopen');
|
|||
|
}
|
|||
|
|
|||
|
return true;
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "open",
|
|||
|
value: function open(event) {
|
|||
|
var _this2 = this;
|
|||
|
|
|||
|
var quick = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
|
|||
|
|
|||
|
if (event) {
|
|||
|
event.preventDefault();
|
|||
|
}
|
|||
|
|
|||
|
var overlay = external_jQuery_default()('#overlay');
|
|||
|
var sidebar = external_jQuery_default()('#admin-sidebar');
|
|||
|
this.body.addClass('sidebar-mobile-open');
|
|||
|
overlay.css('display', 'block');
|
|||
|
|
|||
|
if (!quick) {
|
|||
|
sidebar.css('display', 'block').animate({
|
|||
|
opacity: 1
|
|||
|
}, 200, function () {
|
|||
|
_this2.isOpen = true;
|
|||
|
});
|
|||
|
} else {
|
|||
|
sidebar.css({
|
|||
|
display: 'block',
|
|||
|
opacity: 1
|
|||
|
});
|
|||
|
this.isOpen = true;
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "close",
|
|||
|
value: function close(event) {
|
|||
|
var _this3 = this;
|
|||
|
|
|||
|
var quick = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
|
|||
|
|
|||
|
if (event) {
|
|||
|
event.preventDefault();
|
|||
|
}
|
|||
|
|
|||
|
var overlay = external_jQuery_default()('#overlay');
|
|||
|
var sidebar = external_jQuery_default()('#admin-sidebar');
|
|||
|
this.body.removeClass('sidebar-mobile-open');
|
|||
|
overlay.css('display', 'none');
|
|||
|
|
|||
|
if (!quick) {
|
|||
|
sidebar.animate({
|
|||
|
opacity: 0
|
|||
|
}, 200, function () {
|
|||
|
sidebar.css('display', 'none');
|
|||
|
_this3.isOpen = false;
|
|||
|
});
|
|||
|
} else {
|
|||
|
sidebar.css({
|
|||
|
opacity: 0,
|
|||
|
display: 'none'
|
|||
|
});
|
|||
|
this.isOpen = false;
|
|||
|
}
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "toggle",
|
|||
|
value: function toggle(event) {
|
|||
|
if (event) {
|
|||
|
event.preventDefault();
|
|||
|
}
|
|||
|
|
|||
|
return this[this.isOpen ? 'close' : 'open'](event);
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "toggleSidebarState",
|
|||
|
value: function toggleSidebarState(event) {
|
|||
|
if (event) {
|
|||
|
event.preventDefault();
|
|||
|
}
|
|||
|
|
|||
|
clearTimeout(this.timeout);
|
|||
|
var isDesktop = __webpack_require__.g.matchMedia(DESKTOP_QUERY).matches;
|
|||
|
var cookie = null;
|
|||
|
|
|||
|
if (isDesktop) {
|
|||
|
this.body.removeClass('sidebar-open');
|
|||
|
}
|
|||
|
|
|||
|
if (!isDesktop) {
|
|||
|
this.body.removeClass('sidebar-closed');
|
|||
|
this.body.removeClass('sidebar-mobile-open');
|
|||
|
}
|
|||
|
|
|||
|
this.body.toggleClass("sidebar-".concat(isDesktop ? 'closed' : 'open'));
|
|||
|
external_jQuery_default()(__webpack_require__.g).trigger('sidebar_state._grav', isDesktop);
|
|||
|
|
|||
|
if (isDesktop) {
|
|||
|
cookie = !this.body.hasClass('sidebar-closed');
|
|||
|
} else {
|
|||
|
cookie = this.body.hasClass('sidebar-open');
|
|||
|
}
|
|||
|
|
|||
|
cookies.set('grav-admin-sidebar', cookie, {
|
|||
|
expires: Infinity
|
|||
|
});
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "checkMatch",
|
|||
|
value: function checkMatch(data) {
|
|||
|
var sidebar = external_jQuery_default()('#admin-sidebar');
|
|||
|
var overlay = external_jQuery_default()('#overlay');
|
|||
|
this.isOpen = false;
|
|||
|
overlay.css('display', 'none');
|
|||
|
sidebar.css({
|
|||
|
display: data.matches ? 'none' : 'inherit',
|
|||
|
opacity: data.matches ? 0 : 1
|
|||
|
});
|
|||
|
|
|||
|
if (data.matches) {
|
|||
|
this.body.removeClass('sidebar-open sidebar-closed');
|
|||
|
}
|
|||
|
|
|||
|
this[data.matches ? 'attach' : 'detach']();
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "_resetMap",
|
|||
|
value: function _resetMap() {
|
|||
|
return map.clear();
|
|||
|
}
|
|||
|
}, {
|
|||
|
key: "_getBound",
|
|||
|
value: function _getBound(fn) {
|
|||
|
if (map.has(fn)) {
|
|||
|
return map.get(fn);
|
|||
|
}
|
|||
|
|
|||
|
return map.set(fn, this[fn].bind(this)).get(fn);
|
|||
|
}
|
|||
|
}]);
|
|||
|
|
|||
|
return Sidebar;
|
|||
|
}();
|
|||
|
|
|||
|
|
|||
|
var sidebar_Instance = new Sidebar();
|
|||
|
;// CONCATENATED MODULE: ./app/main.js
|
|||
|
// polyfills
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
// bootstrap jQuery extensions
|
|||
|
|
|||
|
|
|||
|
|
|||
|
// tabs memory
|
|||
|
|
|||
|
// changelog
|
|||
|
|
|||
|
// Main Sidebar
|
|||
|
|
|||
|
// starts the keep alive, auto runs every X seconds
|
|||
|
|
|||
|
keepalive.start(); // global event to catch sidebar_state changes
|
|||
|
|
|||
|
external_jQuery_default()(__webpack_require__.g).on('sidebar_state._grav', function () {
|
|||
|
Object.keys(dashboard.Chart.Instances).forEach(function (chart) {
|
|||
|
setTimeout(function () {
|
|||
|
return dashboard.Chart.Instances[chart].chart.update();
|
|||
|
}, 10);
|
|||
|
});
|
|||
|
});
|
|||
|
/* harmony default export */ const main = ({
|
|||
|
GPM: {
|
|||
|
GPM: GPM,
|
|||
|
Instance: Instance
|
|||
|
},
|
|||
|
KeepAlive: keepalive,
|
|||
|
Dashboard: dashboard,
|
|||
|
Pages: pages,
|
|||
|
Forms: app_forms,
|
|||
|
Updates: {
|
|||
|
Updates: Updates,
|
|||
|
Notifications: updates_notifications,
|
|||
|
Feed: updates_feed,
|
|||
|
Instance: updates_Instance
|
|||
|
},
|
|||
|
Sidebar: {
|
|||
|
Sidebar: Sidebar,
|
|||
|
Instance: sidebar_Instance
|
|||
|
},
|
|||
|
MediaFilter: {
|
|||
|
MediaFilter: Filter,
|
|||
|
Instance: app_media_Instance
|
|||
|
},
|
|||
|
Scrollbar: {
|
|||
|
Scrollbar: {
|
|||
|
deprecated: true
|
|||
|
},
|
|||
|
Instance: {
|
|||
|
deprecated: true
|
|||
|
}
|
|||
|
},
|
|||
|
Utils: {
|
|||
|
request: utils_request,
|
|||
|
toastr: utils_toastr,
|
|||
|
Cookies: cookies
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
/***/ }),
|
|||
|
|
|||
|
/***/ 19912:
|
|||
|
/***/ ((module, exports, __webpack_require__) => {
|
|||
|
|
|||
|
var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|||
|
|
|||
|
/*! version : 4.17.47
|
|||
|
=========================================================
|
|||
|
bootstrap-datetimejs
|
|||
|
https://github.com/Eonasdan/bootstrap-datetimepicker
|
|||
|
Copyright (c) 2015 Jonathan Peterson
|
|||
|
=========================================================
|
|||
|
*/
|
|||
|
|
|||
|
/*
|
|||
|
The MIT License (MIT)
|
|||
|
|
|||
|
Copyright (c) 2015 Jonathan Peterson
|
|||
|
|
|||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|||
|
of this software and associated documentation files (the "Software"), to deal
|
|||
|
in the Software without restriction, including without limitation the rights
|
|||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|||
|
copies of the Software, and to permit persons to whom the Software is
|
|||
|
furnished to do so, subject to the following conditions:
|
|||
|
|
|||
|
The above copyright notice and this permission notice shall be included in
|
|||
|
all copies or substantial portions of the Software.
|
|||
|
|
|||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|||
|
THE SOFTWARE.
|
|||
|
*/
|
|||
|
|
|||
|
/* global define:false */
|
|||
|
|
|||
|
/* global jQuery:false */
|
|||
|
|
|||
|
/* global moment:false */
|
|||
|
(function (factory) {
|
|||
|
'use strict';
|
|||
|
|
|||
|
if (true) {
|
|||
|
// AMD is used - Register as an anonymous module.
|
|||
|
!(__WEBPACK_AMD_DEFINE_ARRAY__ = [__webpack_require__(65311), __webpack_require__(30381)], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory),
|
|||
|
__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?
|
|||
|
(__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__),
|
|||
|
__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
|
|||
|
} else {}
|
|||
|
})(function ($, moment) {
|
|||
|
'use strict';
|
|||
|
|
|||
|
if (!moment) {
|
|||
|
throw new Error('bootstrap-datetimepicker requires Moment.js to be loaded first');
|
|||
|
}
|
|||
|
|
|||
|
var dateTimePicker = function dateTimePicker(element, options) {
|
|||
|
var picker = {};
|
|||
|
var date;
|
|||
|
var viewDate;
|
|||
|
var unset = true;
|
|||
|
var input;
|
|||
|
var component = false;
|
|||
|
var widget = false;
|
|||
|
var use24Hours;
|
|||
|
var minViewModeNumber = 0;
|
|||
|
var actualFormat;
|
|||
|
var parseFormats;
|
|||
|
var currentViewMode;
|
|||
|
var datePickerModes = [{
|
|||
|
clsName: 'days',
|
|||
|
navFnc: 'M',
|
|||
|
navStep: 1
|
|||
|
}, {
|
|||
|
clsName: 'months',
|
|||
|
navFnc: 'y',
|
|||
|
navStep: 1
|
|||
|
}, {
|
|||
|
clsName: 'years',
|
|||
|
navFnc: 'y',
|
|||
|
navStep: 10
|
|||
|
}, {
|
|||
|
clsName: 'decades',
|
|||
|
navFnc: 'y',
|
|||
|
navStep: 100
|
|||
|
}];
|
|||
|
var viewModes = ['days', 'months', 'years', 'decades'];
|
|||
|
var verticalModes = ['top', 'bottom', 'auto'];
|
|||
|
var horizontalModes = ['left', 'right', 'auto'];
|
|||
|
var toolbarPlacements = ['default', 'top', 'bottom'];
|
|||
|
var keyMap = {
|
|||
|
'up': 38,
|
|||
|
38: 'up',
|
|||
|
'down': 40,
|
|||
|
40: 'down',
|
|||
|
'left': 37,
|
|||
|
37: 'left',
|
|||
|
'right': 39,
|
|||
|
39: 'right',
|
|||
|
'tab': 9,
|
|||
|
9: 'tab',
|
|||
|
'escape': 27,
|
|||
|
27: 'escape',
|
|||
|
'enter': 13,
|
|||
|
13: 'enter',
|
|||
|
'pageUp': 33,
|
|||
|
33: 'pageUp',
|
|||
|
'pageDown': 34,
|
|||
|
34: 'pageDown',
|
|||
|
'shift': 16,
|
|||
|
16: 'shift',
|
|||
|
'control': 17,
|
|||
|
17: 'control',
|
|||
|
'space': 32,
|
|||
|
32: 'space',
|
|||
|
't': 84,
|
|||
|
84: 't',
|
|||
|
'delete': 46,
|
|||
|
46: 'delete'
|
|||
|
};
|
|||
|
var keyState = {};
|
|||
|
/** ******************************************************************************
|
|||
|
*
|
|||
|
* Private functions
|
|||
|
*
|
|||
|
********************************************************************************/
|
|||
|
|
|||
|
var hasTimeZone = function hasTimeZone() {
|
|||
|
return moment.tz !== undefined && options.timeZone !== undefined && options.timeZone !== null && options.timeZone !== '';
|
|||
|
};
|
|||
|
|
|||
|
var getMoment = function getMoment(d) {
|
|||
|
var returnMoment;
|
|||
|
|
|||
|
if (d === undefined || d === null) {
|
|||
|
returnMoment = moment(); // TODO should this use format? and locale?
|
|||
|
} else if (moment.isDate(d) || moment.isMoment(d)) {
|
|||
|
// If the date that is passed in is already a Date() or moment() object,
|
|||
|
// pass it directly to moment.
|
|||
|
returnMoment = moment(d);
|
|||
|
} else if (hasTimeZone()) {
|
|||
|
// There is a string to parse and a default time zone
|
|||
|
// parse with the tz function which takes a default time zone if it is not in the format string
|
|||
|
returnMoment = moment.tz(d, parseFormats, options.useStrict, options.timeZone);
|
|||
|
} else {
|
|||
|
returnMoment = moment(d, parseFormats, options.useStrict);
|
|||
|
}
|
|||
|
|
|||
|
if (hasTimeZone()) {
|
|||
|
returnMoment.tz(options.timeZone);
|
|||
|
}
|
|||
|
|
|||
|
return returnMoment;
|
|||
|
};
|
|||
|
|
|||
|
var isEnabled = function isEnabled(granularity) {
|
|||
|
if (typeof granularity !== 'string' || granularity.length > 1) {
|
|||
|
throw new TypeError('isEnabled expects a single character string parameter');
|
|||
|
}
|
|||
|
|
|||
|
switch (granularity) {
|
|||
|
case 'y':
|
|||
|
return actualFormat.indexOf('Y') !== -1;
|
|||
|
|
|||
|
case 'M':
|
|||
|
return actualFormat.indexOf('M') !== -1;
|
|||
|
|
|||
|
case 'd':
|
|||
|
return actualFormat.toLowerCase().indexOf('d') !== -1;
|
|||
|
|
|||
|
case 'h':
|
|||
|
case 'H':
|
|||
|
return actualFormat.toLowerCase().indexOf('h') !== -1;
|
|||
|
|
|||
|
case 'm':
|
|||
|
return actualFormat.indexOf('m') !== -1;
|
|||
|
|
|||
|
case 's':
|
|||
|
return actualFormat.indexOf('s') !== -1;
|
|||
|
|
|||
|
default:
|
|||
|
return false;
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
var hasTime = function hasTime() {
|
|||
|
return isEnabled('h') || isEnabled('m') || isEnabled('s');
|
|||
|
};
|
|||
|
|
|||
|
var hasDate = function hasDate() {
|
|||
|
return isEnabled('y') || isEnabled('M') || isEnabled('d');
|
|||
|
};
|
|||
|
|
|||
|
var getDatePickerTemplate = function getDatePickerTemplate() {
|
|||
|
var headTemplate = $('<thead>').append($('<tr>').append($('<th>').addClass('prev').attr('data-action', 'previous').append($('<span>').addClass(options.icons.previous))).append($('<th>').addClass('picker-switch').attr('data-action', 'pickerSwitch').attr('colspan', options.calendarWeeks ? '6' : '5')).append($('<th>').addClass('next').attr('data-action', 'next').append($('<span>').addClass(options.icons.next))));
|
|||
|
var contTemplate = $('<tbody>').append($('<tr>').append($('<td>').attr('colspan', options.calendarWeeks ? '8' : '7')));
|
|||
|
return [$('<div>').addClass('datepicker-days').append($('<table>').addClass('table-condensed').append(headTemplate).append($('<tbody>'))), $('<div>').addClass('datepicker-months').append($('<table>').addClass('table-condensed').append(headTemplate.clone()).append(contTemplate.clone())), $('<div>').addClass('datepicker-years').append($('<table>').addClass('table-condensed').append(headTemplate.clone()).append(contTemplate.clone())), $('<div>').addClass('datepicker-decades').append($('<table>').addClass('table-condensed').append(headTemplate.clone()).append(contTemplate.clone()))];
|
|||
|
};
|
|||
|
|
|||
|
var getTimePickerMainTemplate = function getTimePickerMainTemplate() {
|
|||
|
var topRow = $('<tr>');
|
|||
|
var middleRow = $('<tr>');
|
|||
|
var bottomRow = $('<tr>');
|
|||
|
|
|||
|
if (isEnabled('h')) {
|
|||
|
topRow.append($('<td>').append($('<a>').attr({
|
|||
|
href: '#',
|
|||
|
tabindex: '-1',
|
|||
|
'title': options.tooltips.incrementHour
|
|||
|
}).addClass('btn').attr('data-action', 'incrementHours').append($('<span>').addClass(options.icons.up))));
|
|||
|
middleRow.append($('<td>').append($('<span>').addClass('timepicker-hour').attr({
|
|||
|
'data-time-component': 'hours',
|
|||
|
'title': options.tooltips.pickHour
|
|||
|
}).attr('data-action', 'showHours')));
|
|||
|
bottomRow.append($('<td>').append($('<a>').attr({
|
|||
|
href: '#',
|
|||
|
tabindex: '-1',
|
|||
|
'title': options.tooltips.decrementHour
|
|||
|
}).addClass('btn').attr('data-action', 'decrementHours').append($('<span>').addClass(options.icons.down))));
|
|||
|
}
|
|||
|
|
|||
|
if (isEnabled('m')) {
|
|||
|
if (isEnabled('h')) {
|
|||
|
topRow.append($('<td>').addClass('separator'));
|
|||
|
middleRow.append($('<td>').addClass('separator').html(':'));
|
|||
|
bottomRow.append($('<td>').addClass('separator'));
|
|||
|
}
|
|||
|
|
|||
|
topRow.append($('<td>').append($('<a>').attr({
|
|||
|
href: '#',
|
|||
|
tabindex: '-1',
|
|||
|
'title': options.tooltips.incrementMinute
|
|||
|
}).addClass('btn').attr('data-action', 'incrementMinutes').append($('<span>').addClass(options.icons.up))));
|
|||
|
middleRow.append($('<td>').append($('<span>').addClass('timepicker-minute').attr({
|
|||
|
'data-time-component': 'minutes',
|
|||
|
'title': options.tooltips.pickMinute
|
|||
|
}).attr('data-action', 'showMinutes')));
|
|||
|
bottomRow.append($('<td>').append($('<a>').attr({
|
|||
|
href: '#',
|
|||
|
tabindex: '-1',
|
|||
|
'title': options.tooltips.decrementMinute
|
|||
|
}).addClass('btn').attr('data-action', 'decrementMinutes').append($('<span>').addClass(options.icons.down))));
|
|||
|
}
|
|||
|
|
|||
|
if (isEnabled('s')) {
|
|||
|
if (isEnabled('m')) {
|
|||
|
topRow.append($('<td>').addClass('separator'));
|
|||
|
middleRow.append($('<td>').addClass('separator').html(':'));
|
|||
|
bottomRow.append($('<td>').addClass('separator'));
|
|||
|
}
|
|||
|
|
|||
|
topRow.append($('<td>').append($('<a>').attr({
|
|||
|
href: '#',
|
|||
|
tabindex: '-1',
|
|||
|
'title': options.tooltips.incrementSecond
|
|||
|
}).addClass('btn').attr('data-action', 'incrementSeconds').append($('<span>').addClass(options.icons.up))));
|
|||
|
middleRow.append($('<td>').append($('<span>').addClass('timepicker-second').attr({
|
|||
|
'data-time-component': 'seconds',
|
|||
|
'title': options.tooltips.pickSecond
|
|||
|
}).attr('data-action', 'showSeconds')));
|
|||
|
bottomRow.append($('<td>').append($('<a>').attr({
|
|||
|
href: '#',
|
|||
|
tabindex: '-1',
|
|||
|
'title': options.tooltips.decrementSecond
|
|||
|
}).addClass('btn').attr('data-action', 'decrementSeconds').append($('<span>').addClass(options.icons.down))));
|
|||
|
}
|
|||
|
|
|||
|
if (!use24Hours) {
|
|||
|
topRow.append($('<td>').addClass('separator'));
|
|||
|
middleRow.append($('<td>').append($('<button>').addClass('btn btn-primary').attr({
|
|||
|
'data-action': 'togglePeriod',
|
|||
|
tabindex: '-1',
|
|||
|
'title': options.tooltips.togglePeriod
|
|||
|
})));
|
|||
|
bottomRow.append($('<td>').addClass('separator'));
|
|||
|
}
|
|||
|
|
|||
|
return $('<div>').addClass('timepicker-picker').append($('<table>').addClass('table-condensed').append([topRow, middleRow, bottomRow]));
|
|||
|
};
|
|||
|
|
|||
|
var getTimePickerTemplate = function getTimePickerTemplate() {
|
|||
|
var hoursView = $('<div>').addClass('timepicker-hours').append($('<table>').addClass('table-condensed'));
|
|||
|
var minutesView = $('<div>').addClass('timepicker-minutes').append($('<table>').addClass('table-condensed'));
|
|||
|
var secondsView = $('<div>').addClass('timepicker-seconds').append($('<table>').addClass('table-condensed'));
|
|||
|
var ret = [getTimePickerMainTemplate()];
|
|||
|
|
|||
|
if (isEnabled('h')) {
|
|||
|
ret.push(hoursView);
|
|||
|
}
|
|||
|
|
|||
|
if (isEnabled('m')) {
|
|||
|
ret.push(minutesView);
|
|||
|
}
|
|||
|
|
|||
|
if (isEnabled('s')) {
|
|||
|
ret.push(secondsView);
|
|||
|
}
|
|||
|
|
|||
|
return ret;
|
|||
|
};
|
|||
|
|
|||
|
var getToolbar = function getToolbar() {
|
|||
|
var row = [];
|
|||
|
|
|||
|
if (options.showTodayButton) {
|
|||
|
row.push($('<td>').append($('<a>').attr({
|
|||
|
'data-action': 'today',
|
|||
|
'title': options.tooltips.today
|
|||
|
}).append($('<span>').addClass(options.icons.today))));
|
|||
|
}
|
|||
|
|
|||
|
if (!options.sideBySide && hasDate() && hasTime()) {
|
|||
|
row.push($('<td>').append($('<a>').attr({
|
|||
|
'data-action': 'togglePicker',
|
|||
|
'title': options.tooltips.selectTime
|
|||
|
}).append($('<span>').addClass(options.icons.time))));
|
|||
|
}
|
|||
|
|
|||
|
if (options.showClear) {
|
|||
|
row.push($('<td>').append($('<a>').attr({
|
|||
|
'data-action': 'clear',
|
|||
|
'title': options.tooltips.clear
|
|||
|
}).append($('<span>').addClass(options.icons.clear))));
|
|||
|
}
|
|||
|
|
|||
|
if (options.showClose) {
|
|||
|
row.push($('<td>').append($('<a>').attr({
|
|||
|
'data-action': 'close',
|
|||
|
'title': options.tooltips.close
|
|||
|
}).append($('<span>').addClass(options.icons.close))));
|
|||
|
}
|
|||
|
|
|||
|
return $('<table>').addClass('table-condensed').append($('<tbody>').append($('<tr>').append(row)));
|
|||
|
};
|
|||
|
|
|||
|
var getTemplate = function getTemplate() {
|
|||
|
var template = $('<div>').addClass('bootstrap-datetimepicker-widget dropdown-menu');
|
|||
|
var dateView = $('<div>').addClass('datepicker').append(getDatePickerTemplate());
|
|||
|
var timeView = $('<div>').addClass('timepicker').append(getTimePickerTemplate());
|
|||
|
var content = $('<ul>').addClass('list-unstyled');
|
|||
|
var toolbar = $('<li>').addClass('picker-switch' + (options.collapse ? ' accordion-toggle' : '')).append(getToolbar());
|
|||
|
|
|||
|
if (options.inline) {
|
|||
|
template.removeClass('dropdown-menu');
|
|||
|
}
|
|||
|
|
|||
|
if (use24Hours) {
|
|||
|
template.addClass('usetwentyfour');
|
|||
|
}
|
|||
|
|
|||
|
if (isEnabled('s') && !use24Hours) {
|
|||
|
template.addClass('wider');
|
|||
|
}
|
|||
|
|
|||
|
if (options.sideBySide && hasDate() && hasTime()) {
|
|||
|
template.addClass('timepicker-sbs');
|
|||
|
|
|||
|
if (options.toolbarPlacement === 'top') {
|
|||
|
template.append(toolbar);
|
|||
|
}
|
|||
|
|
|||
|
template.append($('<div>').addClass('row').append(dateView.addClass('col-md-6')).append(timeView.addClass('col-md-6')));
|
|||
|
|
|||
|
if (options.toolbarPlacement === 'bottom') {
|
|||
|
template.append(toolbar);
|
|||
|
}
|
|||
|
|
|||
|
return template;
|
|||
|
}
|
|||
|
|
|||
|
if (options.toolbarPlacement === 'top') {
|
|||
|
content.append(toolbar);
|
|||
|
}
|
|||
|
|
|||
|
if (hasDate()) {
|
|||
|
content.append($('<li>').addClass(options.collapse && hasTime() ? 'collapse in' : '').append(dateView));
|
|||
|
}
|
|||
|
|
|||
|
if (options.toolbarPlacement === 'default') {
|
|||
|
content.append(toolbar);
|
|||
|
}
|
|||
|
|
|||
|
if (hasTime()) {
|
|||
|
content.append($('<li>').addClass(options.collapse && hasDate() ? 'collapse' : '').append(timeView));
|
|||
|
}
|
|||
|
|
|||
|
if (options.toolbarPlacement === 'bottom') {
|
|||
|
content.append(toolbar);
|
|||
|
}
|
|||
|
|
|||
|
return template.append(content);
|
|||
|
};
|
|||
|
|
|||
|
var dataToOptions = function dataToOptions() {
|
|||
|
var eData;
|
|||
|
var dataOptions = {};
|
|||
|
|
|||
|
if (element.is('input') || options.inline) {
|
|||
|
eData = element.data();
|
|||
|
} else {
|
|||
|
eData = element.find('input').data();
|
|||
|
}
|
|||
|
|
|||
|
if (eData.dateOptions && eData.dateOptions instanceof Object) {
|
|||
|
dataOptions = $.extend(true, dataOptions, eData.dateOptions);
|
|||
|
}
|
|||
|
|
|||
|
$.each(options, function (key) {
|
|||
|
var attributeName = 'date' + key.charAt(0).toUpperCase() + key.slice(1);
|
|||
|
|
|||
|
if (eData[attributeName] !== undefined) {
|
|||
|
dataOptions[key] = eData[attributeName];
|
|||
|
}
|
|||
|
});
|
|||
|
return dataOptions;
|
|||
|
};
|
|||
|
|
|||
|
var place = function place() {
|
|||
|
var position = (component || element).position();
|
|||
|
var offset = (component || element).offset();
|
|||
|
var vertical = options.widgetPositioning.vertical;
|
|||
|
var horizontal = options.widgetPositioning.horizontal;
|
|||
|
var parent;
|
|||
|
|
|||
|
if (options.widgetParent) {
|
|||
|
parent = options.widgetParent.append(widget);
|
|||
|
} else if (element.is('input')) {
|
|||
|
parent = element.after(widget).parent();
|
|||
|
} else if (options.inline) {
|
|||
|
parent = element.append(widget);
|
|||
|
return;
|
|||
|
} else {
|
|||
|
parent = element;
|
|||
|
element.children().first().after(widget);
|
|||
|
} // Top and bottom logic
|
|||
|
|
|||
|
|
|||
|
if (vertical === 'auto') {
|
|||
|
if (offset.top + widget.height() * 1.5 >= $(window).height() + $(window).scrollTop() && widget.height() + element.outerHeight() < offset.top) {
|
|||
|
vertical = 'top';
|
|||
|
} else {
|
|||
|
vertical = 'bottom';
|
|||
|
}
|
|||
|
} // Left and right logic
|
|||
|
|
|||
|
|
|||
|
if (horizontal === 'auto') {
|
|||
|
if (parent.width() < offset.left + widget.outerWidth() / 2 && offset.left + widget.outerWidth() > $(window).width()) {
|
|||
|
horizontal = 'right';
|
|||
|
} else {
|
|||
|
horizontal = 'left';
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if (vertical === 'top') {
|
|||
|
widget.addClass('top').removeClass('bottom');
|
|||
|
} else {
|
|||
|
widget.addClass('bottom').removeClass('top');
|
|||
|
}
|
|||
|
|
|||
|
if (horizontal === 'right') {
|
|||
|
widget.addClass('pull-right');
|
|||
|
} else {
|
|||
|
widget.removeClass('pull-right');
|
|||
|
} // find the first parent element that has a non-static css positioning
|
|||
|
|
|||
|
|
|||
|
if (parent.css('position') === 'static') {
|
|||
|
parent = parent.parents().filter(function () {
|
|||
|
return $(this).css('position') !== 'static';
|
|||
|
}).first();
|
|||
|
}
|
|||
|
|
|||
|
if (parent.length === 0) {
|
|||
|
throw new Error('datetimepicker component should be placed within a non-static positioned container');
|
|||
|
}
|
|||
|
|
|||
|
widget.css({
|
|||
|
top: vertical === 'top' ? 'auto' : position.top + element.outerHeight(),
|
|||
|
bottom: vertical === 'top' ? parent.outerHeight() - (parent === element ? 0 : position.top) : 'auto',
|
|||
|
left: horizontal === 'left' ? parent === element ? 0 : position.left : 'auto',
|
|||
|
right: horizontal === 'left' ? 'auto' : parent.outerWidth() - element.outerWidth() - (parent === element ? 0 : position.left)
|
|||
|
});
|
|||
|
};
|
|||
|
|
|||
|
var notifyEvent = function notifyEvent(e) {
|
|||
|
if (e.type === 'dp.change' && (e.date && e.date.isSame(e.oldDate) || !e.date && !e.oldDate)) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
element.trigger(e);
|
|||
|
};
|
|||
|
|
|||
|
var viewUpdate = function viewUpdate(e) {
|
|||
|
if (e === 'y') {
|
|||
|
e = 'YYYY';
|
|||
|
}
|
|||
|
|
|||
|
notifyEvent({
|
|||
|
type: 'dp.update',
|
|||
|
change: e,
|
|||
|
viewDate: viewDate.clone()
|
|||
|
});
|
|||
|
};
|
|||
|
|
|||
|
var showMode = function showMode(dir) {
|
|||
|
if (!widget) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
if (dir) {
|
|||
|
currentViewMode = Math.max(minViewModeNumber, Math.min(3, currentViewMode + dir));
|
|||
|
}
|
|||
|
|
|||
|
widget.find('.datepicker > div').hide().filter('.datepicker-' + datePickerModes[currentViewMode].clsName).show();
|
|||
|
};
|
|||
|
|
|||
|
var fillDow = function fillDow() {
|
|||
|
var row = $('<tr>');
|
|||
|
var currentDate = viewDate.clone().startOf('w').startOf('d');
|
|||
|
|
|||
|
if (options.calendarWeeks === true) {
|
|||
|
row.append($('<th>').addClass('cw').text('#'));
|
|||
|
}
|
|||
|
|
|||
|
while (currentDate.isBefore(viewDate.clone().endOf('w'))) {
|
|||
|
row.append($('<th>').addClass('dow').text(currentDate.format('dd')));
|
|||
|
currentDate.add(1, 'd');
|
|||
|
}
|
|||
|
|
|||
|
widget.find('.datepicker-days thead').append(row);
|
|||
|
};
|
|||
|
|
|||
|
var isInDisabledDates = function isInDisabledDates(testDate) {
|
|||
|
return options.disabledDates[testDate.format('YYYY-MM-DD')] === true;
|
|||
|
};
|
|||
|
|
|||
|
var isInEnabledDates = function isInEnabledDates(testDate) {
|
|||
|
return options.enabledDates[testDate.format('YYYY-MM-DD')] === true;
|
|||
|
};
|
|||
|
|
|||
|
var isInDisabledHours = function isInDisabledHours(testDate) {
|
|||
|
return options.disabledHours[testDate.format('H')] === true;
|
|||
|
};
|
|||
|
|
|||
|
var isInEnabledHours = function isInEnabledHours(testDate) {
|
|||
|
return options.enabledHours[testDate.format('H')] === true;
|
|||
|
};
|
|||
|
|
|||
|
var isValid = function isValid(targetMoment, granularity) {
|
|||
|
if (!targetMoment.isValid()) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
if (options.disabledDates && granularity === 'd' && isInDisabledDates(targetMoment)) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
if (options.enabledDates && granularity === 'd' && !isInEnabledDates(targetMoment)) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
if (options.minDate && targetMoment.isBefore(options.minDate, granularity)) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
if (options.maxDate && targetMoment.isAfter(options.maxDate, granularity)) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
if (options.daysOfWeekDisabled && granularity === 'd' && options.daysOfWeekDisabled.indexOf(targetMoment.day()) !== -1) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
if (options.disabledHours && (granularity === 'h' || granularity === 'm' || granularity === 's') && isInDisabledHours(targetMoment)) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
if (options.enabledHours && (granularity === 'h' || granularity === 'm' || granularity === 's') && !isInEnabledHours(targetMoment)) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
if (options.disabledTimeIntervals && (granularity === 'h' || granularity === 'm' || granularity === 's')) {
|
|||
|
var found = false;
|
|||
|
$.each(options.disabledTimeIntervals, function () {
|
|||
|
if (targetMoment.isBetween(this[0], this[1])) {
|
|||
|
found = true;
|
|||
|
return false;
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
if (found) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
return true;
|
|||
|
};
|
|||
|
|
|||
|
var fillMonths = function fillMonths() {
|
|||
|
var spans = [];
|
|||
|
var monthsShort = viewDate.clone().startOf('y').startOf('d');
|
|||
|
|
|||
|
while (monthsShort.isSame(viewDate, 'y')) {
|
|||
|
spans.push($('<span>').attr('data-action', 'selectMonth').addClass('month').text(monthsShort.format('MMM')));
|
|||
|
monthsShort.add(1, 'M');
|
|||
|
}
|
|||
|
|
|||
|
widget.find('.datepicker-months td').empty().append(spans);
|
|||
|
};
|
|||
|
|
|||
|
var updateMonths = function updateMonths() {
|
|||
|
var monthsView = widget.find('.datepicker-months');
|
|||
|
var monthsViewHeader = monthsView.find('th');
|
|||
|
var months = monthsView.find('tbody').find('span');
|
|||
|
monthsViewHeader.eq(0).find('span').attr('title', options.tooltips.prevYear);
|
|||
|
monthsViewHeader.eq(1).attr('title', options.tooltips.selectYear);
|
|||
|
monthsViewHeader.eq(2).find('span').attr('title', options.tooltips.nextYear);
|
|||
|
monthsView.find('.disabled').removeClass('disabled');
|
|||
|
|
|||
|
if (!isValid(viewDate.clone().subtract(1, 'y'), 'y')) {
|
|||
|
monthsViewHeader.eq(0).addClass('disabled');
|
|||
|
}
|
|||
|
|
|||
|
monthsViewHeader.eq(1).text(viewDate.year());
|
|||
|
|
|||
|
if (!isValid(viewDate.clone().add(1, 'y'), 'y')) {
|
|||
|
monthsViewHeader.eq(2).addClass('disabled');
|
|||
|
}
|
|||
|
|
|||
|
months.removeClass('active');
|
|||
|
|
|||
|
if (date.isSame(viewDate, 'y') && !unset) {
|
|||
|
months.eq(date.month()).addClass('active');
|
|||
|
}
|
|||
|
|
|||
|
months.each(function (index) {
|
|||
|
if (!isValid(viewDate.clone().month(index), 'M')) {
|
|||
|
$(this).addClass('disabled');
|
|||
|
}
|
|||
|
});
|
|||
|
};
|
|||
|
|
|||
|
var updateYears = function updateYears() {
|
|||
|
var yearsView = widget.find('.datepicker-years');
|
|||
|
var yearsViewHeader = yearsView.find('th');
|
|||
|
var startYear = viewDate.clone().subtract(5, 'y');
|
|||
|
var endYear = viewDate.clone().add(6, 'y');
|
|||
|
var html = '';
|
|||
|
yearsViewHeader.eq(0).find('span').attr('title', options.tooltips.prevDecade);
|
|||
|
yearsViewHeader.eq(1).attr('title', options.tooltips.selectDecade);
|
|||
|
yearsViewHeader.eq(2).find('span').attr('title', options.tooltips.nextDecade);
|
|||
|
yearsView.find('.disabled').removeClass('disabled');
|
|||
|
|
|||
|
if (options.minDate && options.minDate.isAfter(startYear, 'y')) {
|
|||
|
yearsViewHeader.eq(0).addClass('disabled');
|
|||
|
}
|
|||
|
|
|||
|
yearsViewHeader.eq(1).text(startYear.year() + '-' + endYear.year());
|
|||
|
|
|||
|
if (options.maxDate && options.maxDate.isBefore(endYear, 'y')) {
|
|||
|
yearsViewHeader.eq(2).addClass('disabled');
|
|||
|
}
|
|||
|
|
|||
|
while (!startYear.isAfter(endYear, 'y')) {
|
|||
|
html += '<span data-action="selectYear" class="year' + (startYear.isSame(date, 'y') && !unset ? ' active' : '') + (!isValid(startYear, 'y') ? ' disabled' : '') + '">' + startYear.year() + '</span>';
|
|||
|
startYear.add(1, 'y');
|
|||
|
}
|
|||
|
|
|||
|
yearsView.find('td').html(html);
|
|||
|
};
|
|||
|
|
|||
|
var updateDecades = function updateDecades() {
|
|||
|
var decadesView = widget.find('.datepicker-decades');
|
|||
|
var decadesViewHeader = decadesView.find('th');
|
|||
|
var startDecade = moment({
|
|||
|
y: viewDate.year() - viewDate.year() % 100 - 1
|
|||
|
});
|
|||
|
var endDecade = startDecade.clone().add(100, 'y');
|
|||
|
var startedAt = startDecade.clone();
|
|||
|
var minDateDecade = false;
|
|||
|
var maxDateDecade = false;
|
|||
|
var endDecadeYear;
|
|||
|
var html = '';
|
|||
|
decadesViewHeader.eq(0).find('span').attr('title', options.tooltips.prevCentury);
|
|||
|
decadesViewHeader.eq(2).find('span').attr('title', options.tooltips.nextCentury);
|
|||
|
decadesView.find('.disabled').removeClass('disabled');
|
|||
|
|
|||
|
if (startDecade.isSame(moment({
|
|||
|
y: 1900
|
|||
|
})) || options.minDate && options.minDate.isAfter(startDecade, 'y')) {
|
|||
|
decadesViewHeader.eq(0).addClass('disabled');
|
|||
|
}
|
|||
|
|
|||
|
decadesViewHeader.eq(1).text(startDecade.year() + '-' + endDecade.year());
|
|||
|
|
|||
|
if (startDecade.isSame(moment({
|
|||
|
y: 2000
|
|||
|
})) || options.maxDate && options.maxDate.isBefore(endDecade, 'y')) {
|
|||
|
decadesViewHeader.eq(2).addClass('disabled');
|
|||
|
}
|
|||
|
|
|||
|
while (!startDecade.isAfter(endDecade, 'y')) {
|
|||
|
endDecadeYear = startDecade.year() + 12;
|
|||
|
minDateDecade = options.minDate && options.minDate.isAfter(startDecade, 'y') && options.minDate.year() <= endDecadeYear;
|
|||
|
maxDateDecade = options.maxDate && options.maxDate.isAfter(startDecade, 'y') && options.maxDate.year() <= endDecadeYear;
|
|||
|
html += '<span data-action="selectDecade" class="decade' + (date.isAfter(startDecade) && date.year() <= endDecadeYear ? ' active' : '') + (!isValid(startDecade, 'y') && !minDateDecade && !maxDateDecade ? ' disabled' : '') + '" data-selection="' + (startDecade.year() + 6) + '">' + (startDecade.year() + 1) + ' - ' + (startDecade.year() + 12) + '</span>';
|
|||
|
startDecade.add(12, 'y');
|
|||
|
}
|
|||
|
|
|||
|
html += '<span></span><span></span><span></span>'; // push the dangling block over, at least this way it's even
|
|||
|
|
|||
|
decadesView.find('td').html(html);
|
|||
|
decadesViewHeader.eq(1).text(startedAt.year() + 1 + '-' + startDecade.year());
|
|||
|
};
|
|||
|
|
|||
|
var fillDate = function fillDate() {
|
|||
|
var daysView = widget.find('.datepicker-days');
|
|||
|
var daysViewHeader = daysView.find('th');
|
|||
|
var currentDate;
|
|||
|
var html = [];
|
|||
|
var row;
|
|||
|
var clsNames = [];
|
|||
|
var i;
|
|||
|
|
|||
|
if (!hasDate()) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
daysViewHeader.eq(0).find('span').attr('title', options.tooltips.prevMonth);
|
|||
|
daysViewHeader.eq(1).attr('title', options.tooltips.selectMonth);
|
|||
|
daysViewHeader.eq(2).find('span').attr('title', options.tooltips.nextMonth);
|
|||
|
daysView.find('.disabled').removeClass('disabled');
|
|||
|
daysViewHeader.eq(1).text(viewDate.format(options.dayViewHeaderFormat));
|
|||
|
|
|||
|
if (!isValid(viewDate.clone().subtract(1, 'M'), 'M')) {
|
|||
|
daysViewHeader.eq(0).addClass('disabled');
|
|||
|
}
|
|||
|
|
|||
|
if (!isValid(viewDate.clone().add(1, 'M'), 'M')) {
|
|||
|
daysViewHeader.eq(2).addClass('disabled');
|
|||
|
}
|
|||
|
|
|||
|
currentDate = viewDate.clone().startOf('M').startOf('w').startOf('d');
|
|||
|
|
|||
|
for (i = 0; i < 42; i++) {
|
|||
|
// always display 42 days (should show 6 weeks)
|
|||
|
if (currentDate.weekday() === 0) {
|
|||
|
row = $('<tr>');
|
|||
|
|
|||
|
if (options.calendarWeeks) {
|
|||
|
row.append('<td class="cw">' + currentDate.week() + '</td>');
|
|||
|
}
|
|||
|
|
|||
|
html.push(row);
|
|||
|
}
|
|||
|
|
|||
|
clsNames = ['day'];
|
|||
|
|
|||
|
if (currentDate.isBefore(viewDate, 'M')) {
|
|||
|
clsNames.push('old');
|
|||
|
}
|
|||
|
|
|||
|
if (currentDate.isAfter(viewDate, 'M')) {
|
|||
|
clsNames.push('new');
|
|||
|
}
|
|||
|
|
|||
|
if (currentDate.isSame(date, 'd') && !unset) {
|
|||
|
clsNames.push('active');
|
|||
|
}
|
|||
|
|
|||
|
if (!isValid(currentDate, 'd')) {
|
|||
|
clsNames.push('disabled');
|
|||
|
}
|
|||
|
|
|||
|
if (currentDate.isSame(getMoment(), 'd')) {
|
|||
|
clsNames.push('today');
|
|||
|
}
|
|||
|
|
|||
|
if (currentDate.day() === 0 || currentDate.day() === 6) {
|
|||
|
clsNames.push('weekend');
|
|||
|
}
|
|||
|
|
|||
|
notifyEvent({
|
|||
|
type: 'dp.classify',
|
|||
|
date: currentDate,
|
|||
|
classNames: clsNames
|
|||
|
});
|
|||
|
row.append('<td data-action="selectDay" data-day="' + currentDate.format('L') + '" class="' + clsNames.join(' ') + '">' + currentDate.date() + '</td>');
|
|||
|
currentDate.add(1, 'd');
|
|||
|
}
|
|||
|
|
|||
|
daysView.find('tbody').empty().append(html);
|
|||
|
updateMonths();
|
|||
|
updateYears();
|
|||
|
updateDecades();
|
|||
|
};
|
|||
|
|
|||
|
var fillHours = function fillHours() {
|
|||
|
var table = widget.find('.timepicker-hours table');
|
|||
|
var currentHour = viewDate.clone().startOf('d');
|
|||
|
var html = [];
|
|||
|
var row = $('<tr>');
|
|||
|
|
|||
|
if (viewDate.hour() > 11 && !use24Hours) {
|
|||
|
currentHour.hour(12);
|
|||
|
}
|
|||
|
|
|||
|
while (currentHour.isSame(viewDate, 'd') && (use24Hours || viewDate.hour() < 12 && currentHour.hour() < 12 || viewDate.hour() > 11)) {
|
|||
|
if (currentHour.hour() % 4 === 0) {
|
|||
|
row = $('<tr>');
|
|||
|
html.push(row);
|
|||
|
}
|
|||
|
|
|||
|
row.append('<td data-action="selectHour" class="hour' + (!isValid(currentHour, 'h') ? ' disabled' : '') + '">' + currentHour.format(use24Hours ? 'HH' : 'hh') + '</td>');
|
|||
|
currentHour.add(1, 'h');
|
|||
|
}
|
|||
|
|
|||
|
table.empty().append(html);
|
|||
|
};
|
|||
|
|
|||
|
var fillMinutes = function fillMinutes() {
|
|||
|
var table = widget.find('.timepicker-minutes table');
|
|||
|
var currentMinute = viewDate.clone().startOf('h');
|
|||
|
var html = [];
|
|||
|
var row = $('<tr>');
|
|||
|
var step = options.stepping === 1 ? 5 : options.stepping;
|
|||
|
|
|||
|
while (viewDate.isSame(currentMinute, 'h')) {
|
|||
|
if (currentMinute.minute() % (step * 4) === 0) {
|
|||
|
row = $('<tr>');
|
|||
|
html.push(row);
|
|||
|
}
|
|||
|
|
|||
|
row.append('<td data-action="selectMinute" class="minute' + (!isValid(currentMinute, 'm') ? ' disabled' : '') + '">' + currentMinute.format('mm') + '</td>');
|
|||
|
currentMinute.add(step, 'm');
|
|||
|
}
|
|||
|
|
|||
|
table.empty().append(html);
|
|||
|
};
|
|||
|
|
|||
|
var fillSeconds = function fillSeconds() {
|
|||
|
var table = widget.find('.timepicker-seconds table');
|
|||
|
var currentSecond = viewDate.clone().startOf('m');
|
|||
|
var html = [];
|
|||
|
var row = $('<tr>');
|
|||
|
|
|||
|
while (viewDate.isSame(currentSecond, 'm')) {
|
|||
|
if (currentSecond.second() % 20 === 0) {
|
|||
|
row = $('<tr>');
|
|||
|
html.push(row);
|
|||
|
}
|
|||
|
|
|||
|
row.append('<td data-action="selectSecond" class="second' + (!isValid(currentSecond, 's') ? ' disabled' : '') + '">' + currentSecond.format('ss') + '</td>');
|
|||
|
currentSecond.add(5, 's');
|
|||
|
}
|
|||
|
|
|||
|
table.empty().append(html);
|
|||
|
};
|
|||
|
|
|||
|
var fillTime = function fillTime() {
|
|||
|
var toggle;
|
|||
|
var newDate;
|
|||
|
var timeComponents = widget.find('.timepicker span[data-time-component]');
|
|||
|
|
|||
|
if (!use24Hours) {
|
|||
|
toggle = widget.find('.timepicker [data-action=togglePeriod]');
|
|||
|
newDate = date.clone().add(date.hours() >= 12 ? -12 : 12, 'h');
|
|||
|
toggle.text(date.format('A'));
|
|||
|
|
|||
|
if (isValid(newDate, 'h')) {
|
|||
|
toggle.removeClass('disabled');
|
|||
|
} else {
|
|||
|
toggle.addClass('disabled');
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
timeComponents.filter('[data-time-component=hours]').text(date.format(use24Hours ? 'HH' : 'hh'));
|
|||
|
timeComponents.filter('[data-time-component=minutes]').text(date.format('mm'));
|
|||
|
timeComponents.filter('[data-time-component=seconds]').text(date.format('ss'));
|
|||
|
fillHours();
|
|||
|
fillMinutes();
|
|||
|
fillSeconds();
|
|||
|
};
|
|||
|
|
|||
|
var update = function update() {
|
|||
|
if (!widget) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
fillDate();
|
|||
|
fillTime();
|
|||
|
};
|
|||
|
|
|||
|
var setValue = function setValue(targetMoment) {
|
|||
|
var oldDate = unset ? null : date; // case of calling setValue(null or false)
|
|||
|
|
|||
|
if (!targetMoment) {
|
|||
|
unset = true;
|
|||
|
input.val('');
|
|||
|
element.data('date', '');
|
|||
|
notifyEvent({
|
|||
|
type: 'dp.change',
|
|||
|
date: false,
|
|||
|
oldDate: oldDate
|
|||
|
});
|
|||
|
update();
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
targetMoment = targetMoment.clone().locale(options.locale);
|
|||
|
|
|||
|
if (hasTimeZone()) {
|
|||
|
targetMoment.tz(options.timeZone);
|
|||
|
}
|
|||
|
|
|||
|
if (options.stepping !== 1) {
|
|||
|
targetMoment.minutes(Math.round(targetMoment.minutes() / options.stepping) * options.stepping).seconds(0);
|
|||
|
|
|||
|
while (options.minDate && targetMoment.isBefore(options.minDate)) {
|
|||
|
targetMoment.add(options.stepping, 'minutes');
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if (isValid(targetMoment)) {
|
|||
|
date = targetMoment;
|
|||
|
viewDate = date.clone();
|
|||
|
input.val(date.format(actualFormat));
|
|||
|
element.data('date', date.format(actualFormat));
|
|||
|
unset = false;
|
|||
|
update();
|
|||
|
notifyEvent({
|
|||
|
type: 'dp.change',
|
|||
|
date: date.clone(),
|
|||
|
oldDate: oldDate
|
|||
|
});
|
|||
|
} else {
|
|||
|
if (!options.keepInvalid) {
|
|||
|
input.val(unset ? '' : date.format(actualFormat));
|
|||
|
} else {
|
|||
|
notifyEvent({
|
|||
|
type: 'dp.change',
|
|||
|
date: targetMoment,
|
|||
|
oldDate: oldDate
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
notifyEvent({
|
|||
|
type: 'dp.error',
|
|||
|
date: targetMoment,
|
|||
|
oldDate: oldDate
|
|||
|
});
|
|||
|
}
|
|||
|
};
|
|||
|
/**
|
|||
|
* Hides the widget. Possibly will emit dp.hide
|
|||
|
*/
|
|||
|
|
|||
|
|
|||
|
var hide = function hide() {
|
|||
|
var transitioning = false;
|
|||
|
|
|||
|
if (!widget) {
|
|||
|
return picker;
|
|||
|
} // Ignore event if in the middle of a picker transition
|
|||
|
|
|||
|
|
|||
|
widget.find('.collapse').each(function () {
|
|||
|
var collapseData = $(this).data('collapse');
|
|||
|
|
|||
|
if (collapseData && collapseData.transitioning) {
|
|||
|
transitioning = true;
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
return true;
|
|||
|
});
|
|||
|
|
|||
|
if (transitioning) {
|
|||
|
return picker;
|
|||
|
}
|
|||
|
|
|||
|
if (component && component.hasClass('btn')) {
|
|||
|
component.toggleClass('active');
|
|||
|
}
|
|||
|
|
|||
|
widget.hide();
|
|||
|
$(window).off('resize', place);
|
|||
|
widget.off('click', '[data-action]');
|
|||
|
widget.off('mousedown', false);
|
|||
|
widget.remove();
|
|||
|
widget = false;
|
|||
|
notifyEvent({
|
|||
|
type: 'dp.hide',
|
|||
|
date: date.clone()
|
|||
|
});
|
|||
|
input.blur();
|
|||
|
viewDate = date.clone();
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
var clear = function clear() {
|
|||
|
setValue(null);
|
|||
|
};
|
|||
|
|
|||
|
var parseInputDate = function parseInputDate(inputDate) {
|
|||
|
if (options.parseInputDate === undefined) {
|
|||
|
if (!moment.isMoment(inputDate) || inputDate instanceof Date) {
|
|||
|
inputDate = getMoment(inputDate);
|
|||
|
}
|
|||
|
} else {
|
|||
|
inputDate = options.parseInputDate(inputDate);
|
|||
|
} // inputDate.locale(options.locale);
|
|||
|
|
|||
|
|
|||
|
return inputDate;
|
|||
|
};
|
|||
|
/** ******************************************************************************
|
|||
|
*
|
|||
|
* Widget UI interaction functions
|
|||
|
*
|
|||
|
********************************************************************************/
|
|||
|
|
|||
|
|
|||
|
var actions = {
|
|||
|
next: function next() {
|
|||
|
var navFnc = datePickerModes[currentViewMode].navFnc;
|
|||
|
viewDate.add(datePickerModes[currentViewMode].navStep, navFnc);
|
|||
|
fillDate();
|
|||
|
viewUpdate(navFnc);
|
|||
|
},
|
|||
|
previous: function previous() {
|
|||
|
var navFnc = datePickerModes[currentViewMode].navFnc;
|
|||
|
viewDate.subtract(datePickerModes[currentViewMode].navStep, navFnc);
|
|||
|
fillDate();
|
|||
|
viewUpdate(navFnc);
|
|||
|
},
|
|||
|
pickerSwitch: function pickerSwitch() {
|
|||
|
showMode(1);
|
|||
|
},
|
|||
|
selectMonth: function selectMonth(e) {
|
|||
|
var month = $(e.target).closest('tbody').find('span').index($(e.target));
|
|||
|
viewDate.month(month);
|
|||
|
|
|||
|
if (currentViewMode === minViewModeNumber) {
|
|||
|
setValue(date.clone().year(viewDate.year()).month(viewDate.month()));
|
|||
|
|
|||
|
if (!options.inline) {
|
|||
|
hide();
|
|||
|
}
|
|||
|
} else {
|
|||
|
showMode(-1);
|
|||
|
fillDate();
|
|||
|
}
|
|||
|
|
|||
|
viewUpdate('M');
|
|||
|
},
|
|||
|
selectYear: function selectYear(e) {
|
|||
|
var year = parseInt($(e.target).text(), 10) || 0;
|
|||
|
viewDate.year(year);
|
|||
|
|
|||
|
if (currentViewMode === minViewModeNumber) {
|
|||
|
setValue(date.clone().year(viewDate.year()));
|
|||
|
|
|||
|
if (!options.inline) {
|
|||
|
hide();
|
|||
|
}
|
|||
|
} else {
|
|||
|
showMode(-1);
|
|||
|
fillDate();
|
|||
|
}
|
|||
|
|
|||
|
viewUpdate('YYYY');
|
|||
|
},
|
|||
|
selectDecade: function selectDecade(e) {
|
|||
|
var year = parseInt($(e.target).data('selection'), 10) || 0;
|
|||
|
viewDate.year(year);
|
|||
|
|
|||
|
if (currentViewMode === minViewModeNumber) {
|
|||
|
setValue(date.clone().year(viewDate.year()));
|
|||
|
|
|||
|
if (!options.inline) {
|
|||
|
hide();
|
|||
|
}
|
|||
|
} else {
|
|||
|
showMode(-1);
|
|||
|
fillDate();
|
|||
|
}
|
|||
|
|
|||
|
viewUpdate('YYYY');
|
|||
|
},
|
|||
|
selectDay: function selectDay(e) {
|
|||
|
var day = viewDate.clone();
|
|||
|
|
|||
|
if ($(e.target).is('.old')) {
|
|||
|
day.subtract(1, 'M');
|
|||
|
}
|
|||
|
|
|||
|
if ($(e.target).is('.new')) {
|
|||
|
day.add(1, 'M');
|
|||
|
}
|
|||
|
|
|||
|
setValue(day.date(parseInt($(e.target).text(), 10)));
|
|||
|
|
|||
|
if (!hasTime() && !options.keepOpen && !options.inline) {
|
|||
|
hide();
|
|||
|
}
|
|||
|
},
|
|||
|
incrementHours: function incrementHours() {
|
|||
|
var newDate = date.clone().add(1, 'h');
|
|||
|
|
|||
|
if (isValid(newDate, 'h')) {
|
|||
|
setValue(newDate);
|
|||
|
}
|
|||
|
},
|
|||
|
incrementMinutes: function incrementMinutes() {
|
|||
|
var newDate = date.clone().add(options.stepping, 'm');
|
|||
|
|
|||
|
if (isValid(newDate, 'm')) {
|
|||
|
setValue(newDate);
|
|||
|
}
|
|||
|
},
|
|||
|
incrementSeconds: function incrementSeconds() {
|
|||
|
var newDate = date.clone().add(1, 's');
|
|||
|
|
|||
|
if (isValid(newDate, 's')) {
|
|||
|
setValue(newDate);
|
|||
|
}
|
|||
|
},
|
|||
|
decrementHours: function decrementHours() {
|
|||
|
var newDate = date.clone().subtract(1, 'h');
|
|||
|
|
|||
|
if (isValid(newDate, 'h')) {
|
|||
|
setValue(newDate);
|
|||
|
}
|
|||
|
},
|
|||
|
decrementMinutes: function decrementMinutes() {
|
|||
|
var newDate = date.clone().subtract(options.stepping, 'm');
|
|||
|
|
|||
|
if (isValid(newDate, 'm')) {
|
|||
|
setValue(newDate);
|
|||
|
}
|
|||
|
},
|
|||
|
decrementSeconds: function decrementSeconds() {
|
|||
|
var newDate = date.clone().subtract(1, 's');
|
|||
|
|
|||
|
if (isValid(newDate, 's')) {
|
|||
|
setValue(newDate);
|
|||
|
}
|
|||
|
},
|
|||
|
togglePeriod: function togglePeriod() {
|
|||
|
setValue(date.clone().add(date.hours() >= 12 ? -12 : 12, 'h'));
|
|||
|
},
|
|||
|
togglePicker: function togglePicker(e) {
|
|||
|
var $this = $(e.target);
|
|||
|
var $parent = $this.closest('ul');
|
|||
|
var expanded = $parent.find('.in');
|
|||
|
var closed = $parent.find('.collapse:not(.in)');
|
|||
|
var collapseData;
|
|||
|
|
|||
|
if (expanded && expanded.length) {
|
|||
|
collapseData = expanded.data('collapse');
|
|||
|
|
|||
|
if (collapseData && collapseData.transitioning) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
if (expanded.collapse) {
|
|||
|
// if collapse plugin is available through bootstrap.js then use it
|
|||
|
expanded.collapse('hide');
|
|||
|
closed.collapse('show');
|
|||
|
} else {
|
|||
|
// otherwise just toggle in class on the two views
|
|||
|
expanded.removeClass('in');
|
|||
|
closed.addClass('in');
|
|||
|
}
|
|||
|
|
|||
|
if ($this.is('span')) {
|
|||
|
$this.toggleClass(options.icons.time + ' ' + options.icons.date);
|
|||
|
} else {
|
|||
|
$this.find('span').toggleClass(options.icons.time + ' ' + options.icons.date);
|
|||
|
} // NOTE: uncomment if toggled state will be restored in show()
|
|||
|
// if (component) {
|
|||
|
// component.find('span').toggleClass(options.icons.time + ' ' + options.icons.date);
|
|||
|
// }
|
|||
|
|
|||
|
}
|
|||
|
},
|
|||
|
showPicker: function showPicker() {
|
|||
|
widget.find('.timepicker > div:not(.timepicker-picker)').hide();
|
|||
|
widget.find('.timepicker .timepicker-picker').show();
|
|||
|
},
|
|||
|
showHours: function showHours() {
|
|||
|
widget.find('.timepicker .timepicker-picker').hide();
|
|||
|
widget.find('.timepicker .timepicker-hours').show();
|
|||
|
},
|
|||
|
showMinutes: function showMinutes() {
|
|||
|
widget.find('.timepicker .timepicker-picker').hide();
|
|||
|
widget.find('.timepicker .timepicker-minutes').show();
|
|||
|
},
|
|||
|
showSeconds: function showSeconds() {
|
|||
|
widget.find('.timepicker .timepicker-picker').hide();
|
|||
|
widget.find('.timepicker .timepicker-seconds').show();
|
|||
|
},
|
|||
|
selectHour: function selectHour(e) {
|
|||
|
var hour = parseInt($(e.target).text(), 10);
|
|||
|
|
|||
|
if (!use24Hours) {
|
|||
|
if (date.hours() >= 12) {
|
|||
|
if (hour !== 12) {
|
|||
|
hour += 12;
|
|||
|
}
|
|||
|
} else {
|
|||
|
if (hour === 12) {
|
|||
|
hour = 0;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
setValue(date.clone().hours(hour));
|
|||
|
actions.showPicker.call(picker);
|
|||
|
},
|
|||
|
selectMinute: function selectMinute(e) {
|
|||
|
setValue(date.clone().minutes(parseInt($(e.target).text(), 10)));
|
|||
|
actions.showPicker.call(picker);
|
|||
|
},
|
|||
|
selectSecond: function selectSecond(e) {
|
|||
|
setValue(date.clone().seconds(parseInt($(e.target).text(), 10)));
|
|||
|
actions.showPicker.call(picker);
|
|||
|
},
|
|||
|
clear: clear,
|
|||
|
today: function today() {
|
|||
|
var todaysDate = getMoment();
|
|||
|
|
|||
|
if (isValid(todaysDate, 'd')) {
|
|||
|
setValue(todaysDate);
|
|||
|
}
|
|||
|
},
|
|||
|
close: hide
|
|||
|
};
|
|||
|
|
|||
|
var doAction = function doAction(e) {
|
|||
|
if ($(e.currentTarget).is('.disabled')) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
|
|||
|
actions[$(e.currentTarget).data('action')].apply(picker, arguments);
|
|||
|
return false;
|
|||
|
};
|
|||
|
/**
|
|||
|
* Shows the widget. Possibly will emit dp.show and dp.change
|
|||
|
*/
|
|||
|
|
|||
|
|
|||
|
var show = function show() {
|
|||
|
var currentMoment;
|
|||
|
var useCurrentGranularity = {
|
|||
|
'year': function year(m) {
|
|||
|
return m.month(0).date(1).hours(0).seconds(0).minutes(0);
|
|||
|
},
|
|||
|
'month': function month(m) {
|
|||
|
return m.date(1).hours(0).seconds(0).minutes(0);
|
|||
|
},
|
|||
|
'day': function day(m) {
|
|||
|
return m.hours(0).seconds(0).minutes(0);
|
|||
|
},
|
|||
|
'hour': function hour(m) {
|
|||
|
return m.seconds(0).minutes(0);
|
|||
|
},
|
|||
|
'minute': function minute(m) {
|
|||
|
return m.seconds(0);
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
if (input.prop('disabled') || !options.ignoreReadonly && input.prop('readonly') || widget) {
|
|||
|
return picker;
|
|||
|
}
|
|||
|
|
|||
|
if (input.val() !== undefined && input.val().trim().length !== 0) {
|
|||
|
setValue(parseInputDate(input.val().trim()));
|
|||
|
} else if (unset && options.useCurrent && (options.inline || input.is('input') && input.val().trim().length === 0)) {
|
|||
|
currentMoment = getMoment();
|
|||
|
|
|||
|
if (typeof options.useCurrent === 'string') {
|
|||
|
currentMoment = useCurrentGranularity[options.useCurrent](currentMoment);
|
|||
|
}
|
|||
|
|
|||
|
setValue(currentMoment);
|
|||
|
}
|
|||
|
|
|||
|
widget = getTemplate();
|
|||
|
fillDow();
|
|||
|
fillMonths();
|
|||
|
widget.find('.timepicker-hours').hide();
|
|||
|
widget.find('.timepicker-minutes').hide();
|
|||
|
widget.find('.timepicker-seconds').hide();
|
|||
|
update();
|
|||
|
showMode();
|
|||
|
$(window).on('resize', place);
|
|||
|
widget.on('click', '[data-action]', doAction); // this handles clicks on the widget
|
|||
|
|
|||
|
widget.on('mousedown', false);
|
|||
|
|
|||
|
if (component && component.hasClass('btn')) {
|
|||
|
component.toggleClass('active');
|
|||
|
}
|
|||
|
|
|||
|
place();
|
|||
|
widget.show();
|
|||
|
|
|||
|
if (options.focusOnShow && !input.is(':focus')) {
|
|||
|
input.focus();
|
|||
|
}
|
|||
|
|
|||
|
notifyEvent({
|
|||
|
type: 'dp.show'
|
|||
|
});
|
|||
|
return picker;
|
|||
|
};
|
|||
|
/**
|
|||
|
* Shows or hides the widget
|
|||
|
*/
|
|||
|
|
|||
|
|
|||
|
var toggle = function toggle() {
|
|||
|
return widget ? hide() : show();
|
|||
|
};
|
|||
|
|
|||
|
var keydown = function keydown(e) {
|
|||
|
var handler = null;
|
|||
|
var index;
|
|||
|
var index2;
|
|||
|
var pressedKeys = [];
|
|||
|
var pressedModifiers = {};
|
|||
|
var currentKey = e.which;
|
|||
|
var keyBindKeys;
|
|||
|
var allModifiersPressed;
|
|||
|
var pressed = 'p';
|
|||
|
keyState[currentKey] = pressed;
|
|||
|
|
|||
|
for (index in keyState) {
|
|||
|
if (keyState.hasOwnProperty(index) && keyState[index] === pressed) {
|
|||
|
pressedKeys.push(index);
|
|||
|
|
|||
|
if (parseInt(index, 10) !== currentKey) {
|
|||
|
pressedModifiers[index] = true;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
for (index in options.keyBinds) {
|
|||
|
if (options.keyBinds.hasOwnProperty(index) && typeof options.keyBinds[index] === 'function') {
|
|||
|
keyBindKeys = index.split(' ');
|
|||
|
|
|||
|
if (keyBindKeys.length === pressedKeys.length && keyMap[currentKey] === keyBindKeys[keyBindKeys.length - 1]) {
|
|||
|
allModifiersPressed = true;
|
|||
|
|
|||
|
for (index2 = keyBindKeys.length - 2; index2 >= 0; index2--) {
|
|||
|
if (!(keyMap[keyBindKeys[index2]] in pressedModifiers)) {
|
|||
|
allModifiersPressed = false;
|
|||
|
break;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if (allModifiersPressed) {
|
|||
|
handler = options.keyBinds[index];
|
|||
|
break;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if (handler) {
|
|||
|
handler.call(picker, widget);
|
|||
|
e.stopPropagation();
|
|||
|
e.preventDefault();
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
var keyup = function keyup(e) {
|
|||
|
keyState[e.which] = 'r';
|
|||
|
e.stopPropagation();
|
|||
|
e.preventDefault();
|
|||
|
};
|
|||
|
|
|||
|
var change = function change(e) {
|
|||
|
var val = $(e.target).val().trim();
|
|||
|
var parsedDate = val ? parseInputDate(val) : null;
|
|||
|
setValue(parsedDate);
|
|||
|
e.stopImmediatePropagation();
|
|||
|
return false;
|
|||
|
};
|
|||
|
|
|||
|
var attachDatePickerElementEvents = function attachDatePickerElementEvents() {
|
|||
|
input.on({
|
|||
|
'change': change,
|
|||
|
'blur': options.debug ? '' : hide,
|
|||
|
'keydown': keydown,
|
|||
|
'keyup': keyup,
|
|||
|
'focus': options.allowInputToggle ? show : ''
|
|||
|
});
|
|||
|
|
|||
|
if (element.is('input')) {
|
|||
|
input.on({
|
|||
|
'focus': show
|
|||
|
});
|
|||
|
} else if (component) {
|
|||
|
component.on('click', toggle);
|
|||
|
component.on('mousedown', false);
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
var detachDatePickerElementEvents = function detachDatePickerElementEvents() {
|
|||
|
input.off({
|
|||
|
'change': change,
|
|||
|
'blur': blur,
|
|||
|
'keydown': keydown,
|
|||
|
'keyup': keyup,
|
|||
|
'focus': options.allowInputToggle ? hide : ''
|
|||
|
});
|
|||
|
|
|||
|
if (element.is('input')) {
|
|||
|
input.off({
|
|||
|
'focus': show
|
|||
|
});
|
|||
|
} else if (component) {
|
|||
|
component.off('click', toggle);
|
|||
|
component.off('mousedown', false);
|
|||
|
}
|
|||
|
};
|
|||
|
|
|||
|
var indexGivenDates = function indexGivenDates(givenDatesArray) {
|
|||
|
// Store given enabledDates and disabledDates as keys.
|
|||
|
// This way we can check their existence in O(1) time instead of looping through whole array.
|
|||
|
// (for example: options.enabledDates['2014-02-27'] === true)
|
|||
|
var givenDatesIndexed = {};
|
|||
|
$.each(givenDatesArray, function () {
|
|||
|
var dDate = parseInputDate(this);
|
|||
|
|
|||
|
if (dDate.isValid()) {
|
|||
|
givenDatesIndexed[dDate.format('YYYY-MM-DD')] = true;
|
|||
|
}
|
|||
|
});
|
|||
|
return Object.keys(givenDatesIndexed).length ? givenDatesIndexed : false;
|
|||
|
};
|
|||
|
|
|||
|
var indexGivenHours = function indexGivenHours(givenHoursArray) {
|
|||
|
// Store given enabledHours and disabledHours as keys.
|
|||
|
// This way we can check their existence in O(1) time instead of looping through whole array.
|
|||
|
// (for example: options.enabledHours['2014-02-27'] === true)
|
|||
|
var givenHoursIndexed = {};
|
|||
|
$.each(givenHoursArray, function () {
|
|||
|
givenHoursIndexed[this] = true;
|
|||
|
});
|
|||
|
return Object.keys(givenHoursIndexed).length ? givenHoursIndexed : false;
|
|||
|
};
|
|||
|
|
|||
|
var initFormatting = function initFormatting() {
|
|||
|
var format = options.format || 'L LT';
|
|||
|
actualFormat = format.replace(/(\[[^\[]*\])|(\\)?(LTS|LT|LL?L?L?|l{1,4})/g, function (formatInput) {
|
|||
|
var newinput = date.localeData().longDateFormat(formatInput) || formatInput;
|
|||
|
return newinput.replace(/(\[[^\[]*\])|(\\)?(LTS|LT|LL?L?L?|l{1,4})/g, function (formatInput2) {
|
|||
|
// temp fix for #740
|
|||
|
return date.localeData().longDateFormat(formatInput2) || formatInput2;
|
|||
|
});
|
|||
|
});
|
|||
|
parseFormats = options.extraFormats ? options.extraFormats.slice() : [];
|
|||
|
|
|||
|
if (parseFormats.indexOf(format) < 0 && parseFormats.indexOf(actualFormat) < 0) {
|
|||
|
parseFormats.push(actualFormat);
|
|||
|
}
|
|||
|
|
|||
|
use24Hours = actualFormat.toLowerCase().indexOf('a') < 1 && actualFormat.replace(/\[.*?\]/g, '').indexOf('h') < 1;
|
|||
|
|
|||
|
if (isEnabled('y')) {
|
|||
|
minViewModeNumber = 2;
|
|||
|
}
|
|||
|
|
|||
|
if (isEnabled('M')) {
|
|||
|
minViewModeNumber = 1;
|
|||
|
}
|
|||
|
|
|||
|
if (isEnabled('d')) {
|
|||
|
minViewModeNumber = 0;
|
|||
|
}
|
|||
|
|
|||
|
currentViewMode = Math.max(minViewModeNumber, currentViewMode);
|
|||
|
|
|||
|
if (!unset) {
|
|||
|
setValue(date);
|
|||
|
}
|
|||
|
};
|
|||
|
/** ******************************************************************************
|
|||
|
*
|
|||
|
* Public API functions
|
|||
|
* =====================
|
|||
|
*
|
|||
|
* Important: Do not expose direct references to private objects or the options
|
|||
|
* object to the outer world. Always return a clone when returning values or make
|
|||
|
* a clone when setting a private variable.
|
|||
|
*
|
|||
|
********************************************************************************/
|
|||
|
|
|||
|
|
|||
|
picker.destroy = function () {
|
|||
|
// /<summary>Destroys the widget and removes all attached event listeners</summary>
|
|||
|
hide();
|
|||
|
detachDatePickerElementEvents();
|
|||
|
element.removeData('DateTimePicker');
|
|||
|
element.removeData('date');
|
|||
|
};
|
|||
|
|
|||
|
picker.toggle = toggle;
|
|||
|
picker.show = show;
|
|||
|
picker.hide = hide;
|
|||
|
|
|||
|
picker.disable = function () {
|
|||
|
// /<summary>Disables the input element, the component is attached to, by adding a disabled="true" attribute to it.
|
|||
|
// /If the widget was visible before that call it is hidden. Possibly emits dp.hide</summary>
|
|||
|
hide();
|
|||
|
|
|||
|
if (component && component.hasClass('btn')) {
|
|||
|
component.addClass('disabled');
|
|||
|
}
|
|||
|
|
|||
|
input.prop('disabled', true);
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.enable = function () {
|
|||
|
// /<summary>Enables the input element, the component is attached to, by removing disabled attribute from it.</summary>
|
|||
|
if (component && component.hasClass('btn')) {
|
|||
|
component.removeClass('disabled');
|
|||
|
}
|
|||
|
|
|||
|
input.prop('disabled', false);
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.ignoreReadonly = function (ignoreReadonly) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.ignoreReadonly;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof ignoreReadonly !== 'boolean') {
|
|||
|
throw new TypeError('ignoreReadonly () expects a boolean parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.ignoreReadonly = ignoreReadonly;
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.options = function (newOptions) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return $.extend(true, {}, options);
|
|||
|
}
|
|||
|
|
|||
|
if (!(newOptions instanceof Object)) {
|
|||
|
throw new TypeError('options() options parameter should be an object');
|
|||
|
}
|
|||
|
|
|||
|
$.extend(true, options, newOptions);
|
|||
|
$.each(options, function (key, value) {
|
|||
|
if (picker[key] !== undefined) {
|
|||
|
picker[key](value);
|
|||
|
} else {
|
|||
|
throw new TypeError('option ' + key + ' is not recognized!');
|
|||
|
}
|
|||
|
});
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.date = function (newDate) {
|
|||
|
// /<signature helpKeyword="$.fn.datetimepicker.date">
|
|||
|
// /<summary>Returns the component's model current date, a moment object or null if not set.</summary>
|
|||
|
// /<returns type="Moment">date.clone()</returns>
|
|||
|
// /</signature>
|
|||
|
// /<signature>
|
|||
|
// /<summary>Sets the components model current moment to it. Passing a null value unsets the components model current moment. Parsing of the newDate parameter is made using moment library with the options.format and options.useStrict components configuration.</summary>
|
|||
|
// /<param name="newDate" locid="$.fn.datetimepicker.date_p:newDate">Takes string, Date, moment, null parameter.</param>
|
|||
|
// /</signature>
|
|||
|
if (arguments.length === 0) {
|
|||
|
if (unset) {
|
|||
|
return null;
|
|||
|
}
|
|||
|
|
|||
|
return date.clone();
|
|||
|
}
|
|||
|
|
|||
|
if (newDate !== null && typeof newDate !== 'string' && !moment.isMoment(newDate) && !(newDate instanceof Date)) {
|
|||
|
throw new TypeError('date() parameter must be one of [null, string, moment or Date]');
|
|||
|
}
|
|||
|
|
|||
|
setValue(newDate === null ? null : parseInputDate(newDate));
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.format = function (newFormat) {
|
|||
|
// /<summary>test su</summary>
|
|||
|
// /<param name="newFormat">info about para</param>
|
|||
|
// /<returns type="string|boolean">returns foo</returns>
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.format;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof newFormat !== 'string' && (typeof newFormat !== 'boolean' || newFormat !== false)) {
|
|||
|
throw new TypeError('format() expects a string or boolean:false parameter ' + newFormat);
|
|||
|
}
|
|||
|
|
|||
|
options.format = newFormat;
|
|||
|
|
|||
|
if (actualFormat) {
|
|||
|
initFormatting(); // reinit formatting
|
|||
|
}
|
|||
|
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.timeZone = function (newZone) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.timeZone;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof newZone !== 'string') {
|
|||
|
throw new TypeError('newZone() expects a string parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.timeZone = newZone;
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.dayViewHeaderFormat = function (newFormat) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.dayViewHeaderFormat;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof newFormat !== 'string') {
|
|||
|
throw new TypeError('dayViewHeaderFormat() expects a string parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.dayViewHeaderFormat = newFormat;
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.extraFormats = function (formats) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.extraFormats;
|
|||
|
}
|
|||
|
|
|||
|
if (formats !== false && !(formats instanceof Array)) {
|
|||
|
throw new TypeError('extraFormats() expects an array or false parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.extraFormats = formats;
|
|||
|
|
|||
|
if (parseFormats) {
|
|||
|
initFormatting(); // reinit formatting
|
|||
|
}
|
|||
|
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.disabledDates = function (dates) {
|
|||
|
// /<signature helpKeyword="$.fn.datetimepicker.disabledDates">
|
|||
|
// /<summary>Returns an array with the currently set disabled dates on the component.</summary>
|
|||
|
// /<returns type="array">options.disabledDates</returns>
|
|||
|
// /</signature>
|
|||
|
// /<signature>
|
|||
|
// /<summary>Setting this takes precedence over options.minDate, options.maxDate configuration. Also calling this function removes the configuration of
|
|||
|
// /options.enabledDates if such exist.</summary>
|
|||
|
// /<param name="dates" locid="$.fn.datetimepicker.disabledDates_p:dates">Takes an [ string or Date or moment ] of values and allows the user to select only from those days.</param>
|
|||
|
// /</signature>
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.disabledDates ? $.extend({}, options.disabledDates) : options.disabledDates;
|
|||
|
}
|
|||
|
|
|||
|
if (!dates) {
|
|||
|
options.disabledDates = false;
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
}
|
|||
|
|
|||
|
if (!(dates instanceof Array)) {
|
|||
|
throw new TypeError('disabledDates() expects an array parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.disabledDates = indexGivenDates(dates);
|
|||
|
options.enabledDates = false;
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.enabledDates = function (dates) {
|
|||
|
// /<signature helpKeyword="$.fn.datetimepicker.enabledDates">
|
|||
|
// /<summary>Returns an array with the currently set enabled dates on the component.</summary>
|
|||
|
// /<returns type="array">options.enabledDates</returns>
|
|||
|
// /</signature>
|
|||
|
// /<signature>
|
|||
|
// /<summary>Setting this takes precedence over options.minDate, options.maxDate configuration. Also calling this function removes the configuration of options.disabledDates if such exist.</summary>
|
|||
|
// /<param name="dates" locid="$.fn.datetimepicker.enabledDates_p:dates">Takes an [ string or Date or moment ] of values and allows the user to select only from those days.</param>
|
|||
|
// /</signature>
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.enabledDates ? $.extend({}, options.enabledDates) : options.enabledDates;
|
|||
|
}
|
|||
|
|
|||
|
if (!dates) {
|
|||
|
options.enabledDates = false;
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
}
|
|||
|
|
|||
|
if (!(dates instanceof Array)) {
|
|||
|
throw new TypeError('enabledDates() expects an array parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.enabledDates = indexGivenDates(dates);
|
|||
|
options.disabledDates = false;
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.daysOfWeekDisabled = function (daysOfWeekDisabled) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.daysOfWeekDisabled.splice(0);
|
|||
|
}
|
|||
|
|
|||
|
if (typeof daysOfWeekDisabled === 'boolean' && !daysOfWeekDisabled) {
|
|||
|
options.daysOfWeekDisabled = false;
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
}
|
|||
|
|
|||
|
if (!(daysOfWeekDisabled instanceof Array)) {
|
|||
|
throw new TypeError('daysOfWeekDisabled() expects an array parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.daysOfWeekDisabled = daysOfWeekDisabled.reduce(function (previousValue, currentValue) {
|
|||
|
currentValue = parseInt(currentValue, 10);
|
|||
|
|
|||
|
if (currentValue > 6 || currentValue < 0 || isNaN(currentValue)) {
|
|||
|
return previousValue;
|
|||
|
}
|
|||
|
|
|||
|
if (previousValue.indexOf(currentValue) === -1) {
|
|||
|
previousValue.push(currentValue);
|
|||
|
}
|
|||
|
|
|||
|
return previousValue;
|
|||
|
}, []).sort();
|
|||
|
|
|||
|
if (options.useCurrent && !options.keepInvalid) {
|
|||
|
var tries = 0;
|
|||
|
|
|||
|
while (!isValid(date, 'd')) {
|
|||
|
date.add(1, 'd');
|
|||
|
|
|||
|
if (tries === 31) {
|
|||
|
throw new Error('Tried 31 times to find a valid date');
|
|||
|
}
|
|||
|
|
|||
|
tries++;
|
|||
|
}
|
|||
|
|
|||
|
setValue(date);
|
|||
|
}
|
|||
|
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.maxDate = function (maxDate) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.maxDate ? options.maxDate.clone() : options.maxDate;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof maxDate === 'boolean' && maxDate === false) {
|
|||
|
options.maxDate = false;
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof maxDate === 'string') {
|
|||
|
if (maxDate === 'now' || maxDate === 'moment') {
|
|||
|
maxDate = getMoment();
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
var parsedDate = parseInputDate(maxDate);
|
|||
|
|
|||
|
if (!parsedDate.isValid()) {
|
|||
|
throw new TypeError('maxDate() Could not parse date parameter: ' + maxDate);
|
|||
|
}
|
|||
|
|
|||
|
if (options.minDate && parsedDate.isBefore(options.minDate)) {
|
|||
|
throw new TypeError('maxDate() date parameter is before options.minDate: ' + parsedDate.format(actualFormat));
|
|||
|
}
|
|||
|
|
|||
|
options.maxDate = parsedDate;
|
|||
|
|
|||
|
if (options.useCurrent && !options.keepInvalid && date.isAfter(maxDate)) {
|
|||
|
setValue(options.maxDate);
|
|||
|
}
|
|||
|
|
|||
|
if (viewDate.isAfter(parsedDate)) {
|
|||
|
viewDate = parsedDate.clone().subtract(options.stepping, 'm');
|
|||
|
}
|
|||
|
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.minDate = function (minDate) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.minDate ? options.minDate.clone() : options.minDate;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof minDate === 'boolean' && minDate === false) {
|
|||
|
options.minDate = false;
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof minDate === 'string') {
|
|||
|
if (minDate === 'now' || minDate === 'moment') {
|
|||
|
minDate = getMoment();
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
var parsedDate = parseInputDate(minDate);
|
|||
|
|
|||
|
if (!parsedDate.isValid()) {
|
|||
|
throw new TypeError('minDate() Could not parse date parameter: ' + minDate);
|
|||
|
}
|
|||
|
|
|||
|
if (options.maxDate && parsedDate.isAfter(options.maxDate)) {
|
|||
|
throw new TypeError('minDate() date parameter is after options.maxDate: ' + parsedDate.format(actualFormat));
|
|||
|
}
|
|||
|
|
|||
|
options.minDate = parsedDate;
|
|||
|
|
|||
|
if (options.useCurrent && !options.keepInvalid && date.isBefore(minDate)) {
|
|||
|
setValue(options.minDate);
|
|||
|
}
|
|||
|
|
|||
|
if (viewDate.isBefore(parsedDate)) {
|
|||
|
viewDate = parsedDate.clone().add(options.stepping, 'm');
|
|||
|
}
|
|||
|
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.defaultDate = function (defaultDate) {
|
|||
|
// /<signature helpKeyword="$.fn.datetimepicker.defaultDate">
|
|||
|
// /<summary>Returns a moment with the options.defaultDate option configuration or false if not set</summary>
|
|||
|
// /<returns type="Moment">date.clone()</returns>
|
|||
|
// /</signature>
|
|||
|
// /<signature>
|
|||
|
// /<summary>Will set the picker's inital date. If a boolean:false value is passed the options.defaultDate parameter is cleared.</summary>
|
|||
|
// /<param name="defaultDate" locid="$.fn.datetimepicker.defaultDate_p:defaultDate">Takes a string, Date, moment, boolean:false</param>
|
|||
|
// /</signature>
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.defaultDate ? options.defaultDate.clone() : options.defaultDate;
|
|||
|
}
|
|||
|
|
|||
|
if (!defaultDate) {
|
|||
|
options.defaultDate = false;
|
|||
|
return picker;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof defaultDate === 'string') {
|
|||
|
if (defaultDate === 'now' || defaultDate === 'moment') {
|
|||
|
defaultDate = getMoment();
|
|||
|
} else {
|
|||
|
defaultDate = getMoment(defaultDate);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
var parsedDate = parseInputDate(defaultDate);
|
|||
|
|
|||
|
if (!parsedDate.isValid()) {
|
|||
|
throw new TypeError('defaultDate() Could not parse date parameter: ' + defaultDate);
|
|||
|
}
|
|||
|
|
|||
|
if (!isValid(parsedDate)) {
|
|||
|
throw new TypeError('defaultDate() date passed is invalid according to component setup validations');
|
|||
|
}
|
|||
|
|
|||
|
options.defaultDate = parsedDate;
|
|||
|
|
|||
|
if (options.defaultDate && options.inline || input.val().trim() === '') {
|
|||
|
setValue(options.defaultDate);
|
|||
|
}
|
|||
|
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.locale = function (locale) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.locale;
|
|||
|
}
|
|||
|
|
|||
|
if (!moment.localeData(locale)) {
|
|||
|
throw new TypeError('locale() locale ' + locale + ' is not loaded from moment locales!');
|
|||
|
}
|
|||
|
|
|||
|
options.locale = locale;
|
|||
|
date.locale(options.locale);
|
|||
|
viewDate.locale(options.locale);
|
|||
|
|
|||
|
if (actualFormat) {
|
|||
|
initFormatting(); // reinit formatting
|
|||
|
}
|
|||
|
|
|||
|
if (widget) {
|
|||
|
hide();
|
|||
|
show();
|
|||
|
}
|
|||
|
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.stepping = function (stepping) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.stepping;
|
|||
|
}
|
|||
|
|
|||
|
stepping = parseInt(stepping, 10);
|
|||
|
|
|||
|
if (isNaN(stepping) || stepping < 1) {
|
|||
|
stepping = 1;
|
|||
|
}
|
|||
|
|
|||
|
options.stepping = stepping;
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.useCurrent = function (useCurrent) {
|
|||
|
var useCurrentOptions = ['year', 'month', 'day', 'hour', 'minute'];
|
|||
|
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.useCurrent;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof useCurrent !== 'boolean' && typeof useCurrent !== 'string') {
|
|||
|
throw new TypeError('useCurrent() expects a boolean or string parameter');
|
|||
|
}
|
|||
|
|
|||
|
if (typeof useCurrent === 'string' && useCurrentOptions.indexOf(useCurrent.toLowerCase()) === -1) {
|
|||
|
throw new TypeError('useCurrent() expects a string parameter of ' + useCurrentOptions.join(', '));
|
|||
|
}
|
|||
|
|
|||
|
options.useCurrent = useCurrent;
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.collapse = function (collapse) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.collapse;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof collapse !== 'boolean') {
|
|||
|
throw new TypeError('collapse() expects a boolean parameter');
|
|||
|
}
|
|||
|
|
|||
|
if (options.collapse === collapse) {
|
|||
|
return picker;
|
|||
|
}
|
|||
|
|
|||
|
options.collapse = collapse;
|
|||
|
|
|||
|
if (widget) {
|
|||
|
hide();
|
|||
|
show();
|
|||
|
}
|
|||
|
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.icons = function (icons) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return $.extend({}, options.icons);
|
|||
|
}
|
|||
|
|
|||
|
if (!(icons instanceof Object)) {
|
|||
|
throw new TypeError('icons() expects parameter to be an Object');
|
|||
|
}
|
|||
|
|
|||
|
$.extend(options.icons, icons);
|
|||
|
|
|||
|
if (widget) {
|
|||
|
hide();
|
|||
|
show();
|
|||
|
}
|
|||
|
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.tooltips = function (tooltips) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return $.extend({}, options.tooltips);
|
|||
|
}
|
|||
|
|
|||
|
if (!(tooltips instanceof Object)) {
|
|||
|
throw new TypeError('tooltips() expects parameter to be an Object');
|
|||
|
}
|
|||
|
|
|||
|
$.extend(options.tooltips, tooltips);
|
|||
|
|
|||
|
if (widget) {
|
|||
|
hide();
|
|||
|
show();
|
|||
|
}
|
|||
|
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.useStrict = function (useStrict) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.useStrict;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof useStrict !== 'boolean') {
|
|||
|
throw new TypeError('useStrict() expects a boolean parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.useStrict = useStrict;
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.sideBySide = function (sideBySide) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.sideBySide;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof sideBySide !== 'boolean') {
|
|||
|
throw new TypeError('sideBySide() expects a boolean parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.sideBySide = sideBySide;
|
|||
|
|
|||
|
if (widget) {
|
|||
|
hide();
|
|||
|
show();
|
|||
|
}
|
|||
|
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.viewMode = function (viewMode) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.viewMode;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof viewMode !== 'string') {
|
|||
|
throw new TypeError('viewMode() expects a string parameter');
|
|||
|
}
|
|||
|
|
|||
|
if (viewModes.indexOf(viewMode) === -1) {
|
|||
|
throw new TypeError('viewMode() parameter must be one of (' + viewModes.join(', ') + ') value');
|
|||
|
}
|
|||
|
|
|||
|
options.viewMode = viewMode;
|
|||
|
currentViewMode = Math.max(viewModes.indexOf(viewMode), minViewModeNumber);
|
|||
|
showMode();
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.toolbarPlacement = function (toolbarPlacement) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.toolbarPlacement;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof toolbarPlacement !== 'string') {
|
|||
|
throw new TypeError('toolbarPlacement() expects a string parameter');
|
|||
|
}
|
|||
|
|
|||
|
if (toolbarPlacements.indexOf(toolbarPlacement) === -1) {
|
|||
|
throw new TypeError('toolbarPlacement() parameter must be one of (' + toolbarPlacements.join(', ') + ') value');
|
|||
|
}
|
|||
|
|
|||
|
options.toolbarPlacement = toolbarPlacement;
|
|||
|
|
|||
|
if (widget) {
|
|||
|
hide();
|
|||
|
show();
|
|||
|
}
|
|||
|
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.widgetPositioning = function (widgetPositioning) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return $.extend({}, options.widgetPositioning);
|
|||
|
}
|
|||
|
|
|||
|
if ({}.toString.call(widgetPositioning) !== '[object Object]') {
|
|||
|
throw new TypeError('widgetPositioning() expects an object variable');
|
|||
|
}
|
|||
|
|
|||
|
if (widgetPositioning.horizontal) {
|
|||
|
if (typeof widgetPositioning.horizontal !== 'string') {
|
|||
|
throw new TypeError('widgetPositioning() horizontal variable must be a string');
|
|||
|
}
|
|||
|
|
|||
|
widgetPositioning.horizontal = widgetPositioning.horizontal.toLowerCase();
|
|||
|
|
|||
|
if (horizontalModes.indexOf(widgetPositioning.horizontal) === -1) {
|
|||
|
throw new TypeError('widgetPositioning() expects horizontal parameter to be one of (' + horizontalModes.join(', ') + ')');
|
|||
|
}
|
|||
|
|
|||
|
options.widgetPositioning.horizontal = widgetPositioning.horizontal;
|
|||
|
}
|
|||
|
|
|||
|
if (widgetPositioning.vertical) {
|
|||
|
if (typeof widgetPositioning.vertical !== 'string') {
|
|||
|
throw new TypeError('widgetPositioning() vertical variable must be a string');
|
|||
|
}
|
|||
|
|
|||
|
widgetPositioning.vertical = widgetPositioning.vertical.toLowerCase();
|
|||
|
|
|||
|
if (verticalModes.indexOf(widgetPositioning.vertical) === -1) {
|
|||
|
throw new TypeError('widgetPositioning() expects vertical parameter to be one of (' + verticalModes.join(', ') + ')');
|
|||
|
}
|
|||
|
|
|||
|
options.widgetPositioning.vertical = widgetPositioning.vertical;
|
|||
|
}
|
|||
|
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.calendarWeeks = function (calendarWeeks) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.calendarWeeks;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof calendarWeeks !== 'boolean') {
|
|||
|
throw new TypeError('calendarWeeks() expects parameter to be a boolean value');
|
|||
|
}
|
|||
|
|
|||
|
options.calendarWeeks = calendarWeeks;
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.showTodayButton = function (showTodayButton) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.showTodayButton;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof showTodayButton !== 'boolean') {
|
|||
|
throw new TypeError('showTodayButton() expects a boolean parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.showTodayButton = showTodayButton;
|
|||
|
|
|||
|
if (widget) {
|
|||
|
hide();
|
|||
|
show();
|
|||
|
}
|
|||
|
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.showClear = function (showClear) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.showClear;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof showClear !== 'boolean') {
|
|||
|
throw new TypeError('showClear() expects a boolean parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.showClear = showClear;
|
|||
|
|
|||
|
if (widget) {
|
|||
|
hide();
|
|||
|
show();
|
|||
|
}
|
|||
|
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.widgetParent = function (widgetParent) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.widgetParent;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof widgetParent === 'string') {
|
|||
|
widgetParent = $(widgetParent);
|
|||
|
}
|
|||
|
|
|||
|
if (widgetParent !== null && typeof widgetParent !== 'string' && !(widgetParent instanceof $)) {
|
|||
|
throw new TypeError('widgetParent() expects a string or a jQuery object parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.widgetParent = widgetParent;
|
|||
|
|
|||
|
if (widget) {
|
|||
|
hide();
|
|||
|
show();
|
|||
|
}
|
|||
|
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.keepOpen = function (keepOpen) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.keepOpen;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof keepOpen !== 'boolean') {
|
|||
|
throw new TypeError('keepOpen() expects a boolean parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.keepOpen = keepOpen;
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.focusOnShow = function (focusOnShow) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.focusOnShow;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof focusOnShow !== 'boolean') {
|
|||
|
throw new TypeError('focusOnShow() expects a boolean parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.focusOnShow = focusOnShow;
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.inline = function (inline) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.inline;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof inline !== 'boolean') {
|
|||
|
throw new TypeError('inline() expects a boolean parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.inline = inline;
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.clear = function () {
|
|||
|
clear();
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.keyBinds = function (keyBinds) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.keyBinds;
|
|||
|
}
|
|||
|
|
|||
|
options.keyBinds = keyBinds;
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.getMoment = function (d) {
|
|||
|
return getMoment(d);
|
|||
|
};
|
|||
|
|
|||
|
picker.debug = function (debug) {
|
|||
|
if (typeof debug !== 'boolean') {
|
|||
|
throw new TypeError('debug() expects a boolean parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.debug = debug;
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.allowInputToggle = function (allowInputToggle) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.allowInputToggle;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof allowInputToggle !== 'boolean') {
|
|||
|
throw new TypeError('allowInputToggle() expects a boolean parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.allowInputToggle = allowInputToggle;
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.showClose = function (showClose) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.showClose;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof showClose !== 'boolean') {
|
|||
|
throw new TypeError('showClose() expects a boolean parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.showClose = showClose;
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.keepInvalid = function (keepInvalid) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.keepInvalid;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof keepInvalid !== 'boolean') {
|
|||
|
throw new TypeError('keepInvalid() expects a boolean parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.keepInvalid = keepInvalid;
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.datepickerInput = function (datepickerInput) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.datepickerInput;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof datepickerInput !== 'string') {
|
|||
|
throw new TypeError('datepickerInput() expects a string parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.datepickerInput = datepickerInput;
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.parseInputDate = function (parseInputDate) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.parseInputDate;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof parseInputDate !== 'function') {
|
|||
|
throw new TypeError('parseInputDate() sholud be as function');
|
|||
|
}
|
|||
|
|
|||
|
options.parseInputDate = parseInputDate;
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.disabledTimeIntervals = function (disabledTimeIntervals) {
|
|||
|
// /<signature helpKeyword="$.fn.datetimepicker.disabledTimeIntervals">
|
|||
|
// /<summary>Returns an array with the currently set disabled dates on the component.</summary>
|
|||
|
// /<returns type="array">options.disabledTimeIntervals</returns>
|
|||
|
// /</signature>
|
|||
|
// /<signature>
|
|||
|
// /<summary>Setting this takes precedence over options.minDate, options.maxDate configuration. Also calling this function removes the configuration of
|
|||
|
// /options.enabledDates if such exist.</summary>
|
|||
|
// /<param name="dates" locid="$.fn.datetimepicker.disabledTimeIntervals_p:dates">Takes an [ string or Date or moment ] of values and allows the user to select only from those days.</param>
|
|||
|
// /</signature>
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.disabledTimeIntervals ? $.extend({}, options.disabledTimeIntervals) : options.disabledTimeIntervals;
|
|||
|
}
|
|||
|
|
|||
|
if (!disabledTimeIntervals) {
|
|||
|
options.disabledTimeIntervals = false;
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
}
|
|||
|
|
|||
|
if (!(disabledTimeIntervals instanceof Array)) {
|
|||
|
throw new TypeError('disabledTimeIntervals() expects an array parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.disabledTimeIntervals = disabledTimeIntervals;
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.disabledHours = function (hours) {
|
|||
|
// /<signature helpKeyword="$.fn.datetimepicker.disabledHours">
|
|||
|
// /<summary>Returns an array with the currently set disabled hours on the component.</summary>
|
|||
|
// /<returns type="array">options.disabledHours</returns>
|
|||
|
// /</signature>
|
|||
|
// /<signature>
|
|||
|
// /<summary>Setting this takes precedence over options.minDate, options.maxDate configuration. Also calling this function removes the configuration of
|
|||
|
// /options.enabledHours if such exist.</summary>
|
|||
|
// /<param name="hours" locid="$.fn.datetimepicker.disabledHours_p:hours">Takes an [ int ] of values and disallows the user to select only from those hours.</param>
|
|||
|
// /</signature>
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.disabledHours ? $.extend({}, options.disabledHours) : options.disabledHours;
|
|||
|
}
|
|||
|
|
|||
|
if (!hours) {
|
|||
|
options.disabledHours = false;
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
}
|
|||
|
|
|||
|
if (!(hours instanceof Array)) {
|
|||
|
throw new TypeError('disabledHours() expects an array parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.disabledHours = indexGivenHours(hours);
|
|||
|
options.enabledHours = false;
|
|||
|
|
|||
|
if (options.useCurrent && !options.keepInvalid) {
|
|||
|
var tries = 0;
|
|||
|
|
|||
|
while (!isValid(date, 'h')) {
|
|||
|
date.add(1, 'h');
|
|||
|
|
|||
|
if (tries === 24) {
|
|||
|
throw new Error('Tried 24 times to find a valid date');
|
|||
|
}
|
|||
|
|
|||
|
tries++;
|
|||
|
}
|
|||
|
|
|||
|
setValue(date);
|
|||
|
}
|
|||
|
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
};
|
|||
|
|
|||
|
picker.enabledHours = function (hours) {
|
|||
|
// /<signature helpKeyword="$.fn.datetimepicker.enabledHours">
|
|||
|
// /<summary>Returns an array with the currently set enabled hours on the component.</summary>
|
|||
|
// /<returns type="array">options.enabledHours</returns>
|
|||
|
// /</signature>
|
|||
|
// /<signature>
|
|||
|
// /<summary>Setting this takes precedence over options.minDate, options.maxDate configuration. Also calling this function removes the configuration of options.disabledHours if such exist.</summary>
|
|||
|
// /<param name="hours" locid="$.fn.datetimepicker.enabledHours_p:hours">Takes an [ int ] of values and allows the user to select only from those hours.</param>
|
|||
|
// /</signature>
|
|||
|
if (arguments.length === 0) {
|
|||
|
return options.enabledHours ? $.extend({}, options.enabledHours) : options.enabledHours;
|
|||
|
}
|
|||
|
|
|||
|
if (!hours) {
|
|||
|
options.enabledHours = false;
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
}
|
|||
|
|
|||
|
if (!(hours instanceof Array)) {
|
|||
|
throw new TypeError('enabledHours() expects an array parameter');
|
|||
|
}
|
|||
|
|
|||
|
options.enabledHours = indexGivenHours(hours);
|
|||
|
options.disabledHours = false;
|
|||
|
|
|||
|
if (options.useCurrent && !options.keepInvalid) {
|
|||
|
var tries = 0;
|
|||
|
|
|||
|
while (!isValid(date, 'h')) {
|
|||
|
date.add(1, 'h');
|
|||
|
|
|||
|
if (tries === 24) {
|
|||
|
throw new Error('Tried 24 times to find a valid date');
|
|||
|
}
|
|||
|
|
|||
|
tries++;
|
|||
|
}
|
|||
|
|
|||
|
setValue(date);
|
|||
|
}
|
|||
|
|
|||
|
update();
|
|||
|
return picker;
|
|||
|
};
|
|||
|
/**
|
|||
|
* Returns the component's model current viewDate, a moment object or null if not set. Passing a null value unsets the components model current moment. Parsing of the newDate parameter is made using moment library with the options.format and options.useStrict components configuration.
|
|||
|
* @param {Takes string, viewDate, moment, null parameter.} newDate
|
|||
|
* @returns {viewDate.clone()}
|
|||
|
*/
|
|||
|
|
|||
|
|
|||
|
picker.viewDate = function (newDate) {
|
|||
|
if (arguments.length === 0) {
|
|||
|
return viewDate.clone();
|
|||
|
}
|
|||
|
|
|||
|
if (!newDate) {
|
|||
|
viewDate = date.clone();
|
|||
|
return picker;
|
|||
|
}
|
|||
|
|
|||
|
if (typeof newDate !== 'string' && !moment.isMoment(newDate) && !(newDate instanceof Date)) {
|
|||
|
throw new TypeError('viewDate() parameter must be one of [string, moment or Date]');
|
|||
|
}
|
|||
|
|
|||
|
viewDate = parseInputDate(newDate);
|
|||
|
viewUpdate();
|
|||
|
return picker;
|
|||
|
}; // initializing element and component attributes
|
|||
|
|
|||
|
|
|||
|
if (element.is('input')) {
|
|||
|
input = element;
|
|||
|
} else {
|
|||
|
input = element.find(options.datepickerInput);
|
|||
|
|
|||
|
if (input.length === 0) {
|
|||
|
input = element.find('input');
|
|||
|
} else if (!input.is('input')) {
|
|||
|
throw new Error('CSS class "' + options.datepickerInput + '" cannot be applied to non input element');
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if (element.hasClass('input-group')) {
|
|||
|
// in case there is more then one 'input-group-addon' Issue #48
|
|||
|
if (element.find('.datepickerbutton').length === 0) {
|
|||
|
component = element.find('.input-group-addon');
|
|||
|
} else {
|
|||
|
component = element.find('.datepickerbutton');
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if (!options.inline && !input.is('input')) {
|
|||
|
throw new Error('Could not initialize DateTimePicker without an input element');
|
|||
|
} // Set defaults for date here now instead of in var declaration
|
|||
|
|
|||
|
|
|||
|
date = getMoment();
|
|||
|
viewDate = date.clone();
|
|||
|
$.extend(true, options, dataToOptions());
|
|||
|
picker.options(options);
|
|||
|
initFormatting();
|
|||
|
attachDatePickerElementEvents();
|
|||
|
|
|||
|
if (input.prop('disabled')) {
|
|||
|
picker.disable();
|
|||
|
}
|
|||
|
|
|||
|
if (input.is('input') && input.val().trim().length !== 0) {
|
|||
|
setValue(parseInputDate(input.val().trim()));
|
|||
|
} else if (options.defaultDate && input.attr('placeholder') === undefined) {
|
|||
|
setValue(options.defaultDate);
|
|||
|
}
|
|||
|
|
|||
|
if (options.inline) {
|
|||
|
show();
|
|||
|
}
|
|||
|
|
|||
|
return picker;
|
|||
|
};
|
|||
|
/** ******************************************************************************
|
|||
|
*
|
|||
|
* jQuery plugin constructor and defaults object
|
|||
|
*
|
|||
|
********************************************************************************/
|
|||
|
|
|||
|
/**
|
|||
|
* See (http://jquery.com/).
|
|||
|
* @name jQuery
|
|||
|
* @class
|
|||
|
* See the jQuery Library (http://jquery.com/) for full details. This just
|
|||
|
* documents the function and classes that are added to jQuery by this plug-in.
|
|||
|
*/
|
|||
|
|
|||
|
/**
|
|||
|
* See (http://jquery.com/)
|
|||
|
* @name fn
|
|||
|
* @class
|
|||
|
* See the jQuery Library (http://jquery.com/) for full details. This just
|
|||
|
* documents the function and classes that are added to jQuery by this plug-in.
|
|||
|
* @memberOf jQuery
|
|||
|
*/
|
|||
|
|
|||
|
/**
|
|||
|
* Show comments
|
|||
|
* @class datetimepicker
|
|||
|
* @memberOf jQuery.fn
|
|||
|
*/
|
|||
|
|
|||
|
|
|||
|
$.fn.datetimepicker = function (options) {
|
|||
|
options = options || {};
|
|||
|
var args = Array.prototype.slice.call(arguments, 1);
|
|||
|
var isInstance = true;
|
|||
|
var thisMethods = ['destroy', 'hide', 'show', 'toggle'];
|
|||
|
var returnValue;
|
|||
|
|
|||
|
if (_typeof(options) === 'object') {
|
|||
|
return this.each(function () {
|
|||
|
var $this = $(this);
|
|||
|
|
|||
|
var _options;
|
|||
|
|
|||
|
if (!$this.data('DateTimePicker')) {
|
|||
|
// create a private copy of the defaults object
|
|||
|
_options = $.extend(true, {}, $.fn.datetimepicker.defaults, options);
|
|||
|
$this.data('DateTimePicker', dateTimePicker($this, _options));
|
|||
|
}
|
|||
|
});
|
|||
|
} else if (typeof options === 'string') {
|
|||
|
this.each(function () {
|
|||
|
var $this = $(this);
|
|||
|
var instance = $this.data('DateTimePicker');
|
|||
|
|
|||
|
if (!instance) {
|
|||
|
throw new Error('bootstrap-datetimepicker("' + options + '") method was called on an element that is not using DateTimePicker');
|
|||
|
}
|
|||
|
|
|||
|
returnValue = instance[options].apply(instance, args);
|
|||
|
isInstance = returnValue === instance;
|
|||
|
});
|
|||
|
|
|||
|
if (isInstance || $.inArray(options, thisMethods) > -1) {
|
|||
|
return this;
|
|||
|
}
|
|||
|
|
|||
|
return returnValue;
|
|||
|
}
|
|||
|
|
|||
|
throw new TypeError('Invalid arguments for DateTimePicker: ' + options);
|
|||
|
};
|
|||
|
|
|||
|
$.fn.datetimepicker.defaults = {
|
|||
|
timeZone: '',
|
|||
|
format: false,
|
|||
|
dayViewHeaderFormat: 'MMMM YYYY',
|
|||
|
extraFormats: false,
|
|||
|
stepping: 1,
|
|||
|
minDate: false,
|
|||
|
maxDate: false,
|
|||
|
useCurrent: true,
|
|||
|
collapse: true,
|
|||
|
locale: moment.locale(),
|
|||
|
defaultDate: false,
|
|||
|
disabledDates: false,
|
|||
|
enabledDates: false,
|
|||
|
icons: {
|
|||
|
time: 'glyphicon glyphicon-time',
|
|||
|
date: 'glyphicon glyphicon-calendar',
|
|||
|
up: 'glyphicon glyphicon-chevron-up',
|
|||
|
down: 'glyphicon glyphicon-chevron-down',
|
|||
|
previous: 'glyphicon glyphicon-chevron-left',
|
|||
|
next: 'glyphicon glyphicon-chevron-right',
|
|||
|
today: 'glyphicon glyphicon-screenshot',
|
|||
|
clear: 'glyphicon glyphicon-trash',
|
|||
|
close: 'glyphicon glyphicon-remove'
|
|||
|
},
|
|||
|
tooltips: {
|
|||
|
today: 'Go to today',
|
|||
|
clear: 'Clear selection',
|
|||
|
close: 'Close the picker',
|
|||
|
selectMonth: 'Select Month',
|
|||
|
prevMonth: 'Previous Month',
|
|||
|
nextMonth: 'Next Month',
|
|||
|
selectYear: 'Select Year',
|
|||
|
prevYear: 'Previous Year',
|
|||
|
nextYear: 'Next Year',
|
|||
|
selectDecade: 'Select Decade',
|
|||
|
prevDecade: 'Previous Decade',
|
|||
|
nextDecade: 'Next Decade',
|
|||
|
prevCentury: 'Previous Century',
|
|||
|
nextCentury: 'Next Century',
|
|||
|
pickHour: 'Pick Hour',
|
|||
|
incrementHour: 'Increment Hour',
|
|||
|
decrementHour: 'Decrement Hour',
|
|||
|
pickMinute: 'Pick Minute',
|
|||
|
incrementMinute: 'Increment Minute',
|
|||
|
decrementMinute: 'Decrement Minute',
|
|||
|
pickSecond: 'Pick Second',
|
|||
|
incrementSecond: 'Increment Second',
|
|||
|
decrementSecond: 'Decrement Second',
|
|||
|
togglePeriod: 'Toggle Period',
|
|||
|
selectTime: 'Select Time'
|
|||
|
},
|
|||
|
useStrict: false,
|
|||
|
sideBySide: false,
|
|||
|
daysOfWeekDisabled: false,
|
|||
|
calendarWeeks: false,
|
|||
|
viewMode: 'days',
|
|||
|
toolbarPlacement: 'default',
|
|||
|
showTodayButton: false,
|
|||
|
showClear: false,
|
|||
|
showClose: false,
|
|||
|
widgetPositioning: {
|
|||
|
horizontal: 'auto',
|
|||
|
vertical: 'auto'
|
|||
|
},
|
|||
|
widgetParent: null,
|
|||
|
ignoreReadonly: false,
|
|||
|
keepOpen: false,
|
|||
|
focusOnShow: true,
|
|||
|
inline: false,
|
|||
|
keepInvalid: false,
|
|||
|
datepickerInput: '.datepickerinput',
|
|||
|
keyBinds: {
|
|||
|
up: function up(widget) {
|
|||
|
if (!widget) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var d = this.date() || this.getMoment();
|
|||
|
|
|||
|
if (widget.find('.datepicker').is(':visible')) {
|
|||
|
this.date(d.clone().subtract(7, 'd'));
|
|||
|
} else {
|
|||
|
this.date(d.clone().add(this.stepping(), 'm'));
|
|||
|
}
|
|||
|
},
|
|||
|
down: function down(widget) {
|
|||
|
if (!widget) {
|
|||
|
this.show();
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var d = this.date() || this.getMoment();
|
|||
|
|
|||
|
if (widget.find('.datepicker').is(':visible')) {
|
|||
|
this.date(d.clone().add(7, 'd'));
|
|||
|
} else {
|
|||
|
this.date(d.clone().subtract(this.stepping(), 'm'));
|
|||
|
}
|
|||
|
},
|
|||
|
'control up': function controlUp(widget) {
|
|||
|
if (!widget) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var d = this.date() || this.getMoment();
|
|||
|
|
|||
|
if (widget.find('.datepicker').is(':visible')) {
|
|||
|
this.date(d.clone().subtract(1, 'y'));
|
|||
|
} else {
|
|||
|
this.date(d.clone().add(1, 'h'));
|
|||
|
}
|
|||
|
},
|
|||
|
'control down': function controlDown(widget) {
|
|||
|
if (!widget) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var d = this.date() || this.getMoment();
|
|||
|
|
|||
|
if (widget.find('.datepicker').is(':visible')) {
|
|||
|
this.date(d.clone().add(1, 'y'));
|
|||
|
} else {
|
|||
|
this.date(d.clone().subtract(1, 'h'));
|
|||
|
}
|
|||
|
},
|
|||
|
left: function left(widget) {
|
|||
|
if (!widget) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var d = this.date() || this.getMoment();
|
|||
|
|
|||
|
if (widget.find('.datepicker').is(':visible')) {
|
|||
|
this.date(d.clone().subtract(1, 'd'));
|
|||
|
}
|
|||
|
},
|
|||
|
right: function right(widget) {
|
|||
|
if (!widget) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var d = this.date() || this.getMoment();
|
|||
|
|
|||
|
if (widget.find('.datepicker').is(':visible')) {
|
|||
|
this.date(d.clone().add(1, 'd'));
|
|||
|
}
|
|||
|
},
|
|||
|
pageUp: function pageUp(widget) {
|
|||
|
if (!widget) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var d = this.date() || this.getMoment();
|
|||
|
|
|||
|
if (widget.find('.datepicker').is(':visible')) {
|
|||
|
this.date(d.clone().subtract(1, 'M'));
|
|||
|
}
|
|||
|
},
|
|||
|
pageDown: function pageDown(widget) {
|
|||
|
if (!widget) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
var d = this.date() || this.getMoment();
|
|||
|
|
|||
|
if (widget.find('.datepicker').is(':visible')) {
|
|||
|
this.date(d.clone().add(1, 'M'));
|
|||
|
}
|
|||
|
},
|
|||
|
enter: function enter() {
|
|||
|
this.hide();
|
|||
|
},
|
|||
|
escape: function escape() {
|
|||
|
this.hide();
|
|||
|
},
|
|||
|
// tab: function (widget) { //this break the flow of the form. disabling for now
|
|||
|
// var toggle = widget.find('.picker-switch a[data-action="togglePicker"]');
|
|||
|
// if(toggle.length > 0) toggle.click();
|
|||
|
// },
|
|||
|
'control space': function controlSpace(widget) {
|
|||
|
if (!widget) {
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
if (widget.find('.timepicker').is(':visible')) {
|
|||
|
widget.find('.btn[data-action="togglePeriod"]').click();
|
|||
|
}
|
|||
|
},
|
|||
|
t: function t() {
|
|||
|
this.date(this.getMoment());
|
|||
|
},
|
|||
|
'delete': function _delete() {
|
|||
|
this.clear();
|
|||
|
}
|
|||
|
},
|
|||
|
debug: false,
|
|||
|
allowInputToggle: false,
|
|||
|
disabledTimeIntervals: false,
|
|||
|
disabledHours: false,
|
|||
|
enabledHours: false,
|
|||
|
viewDate: false
|
|||
|
};
|
|||
|
return $.fn.datetimepicker;
|
|||
|
});
|
|||
|
|
|||
|
/***/ }),
|
|||
|
|
|||
|
/***/ 31619:
|
|||
|
/***/ (() => {
|
|||
|
|
|||
|
// localStorage
|
|||
|
(function () {
|
|||
|
function isSupported() {
|
|||
|
var item = 'localStoragePollyfill';
|
|||
|
|
|||
|
try {
|
|||
|
localStorage.setItem(item, item);
|
|||
|
localStorage.removeItem(item);
|
|||
|
sessionStorage.setItem(item, item);
|
|||
|
sessionStorage.removeItem(item);
|
|||
|
return true;
|
|||
|
} catch (e) {
|
|||
|
return false;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if (!isSupported()) {
|
|||
|
try {
|
|||
|
Storage.prototype._data = {};
|
|||
|
|
|||
|
Storage.prototype.setItem = function (id, val) {
|
|||
|
this._data[id] = String(val);
|
|||
|
return this._data[id];
|
|||
|
};
|
|||
|
|
|||
|
Storage.prototype.getItem = function (id) {
|
|||
|
return this._data.hasOwnProperty(id) ? this._data[id] : undefined;
|
|||
|
};
|
|||
|
|
|||
|
Storage.prototype.removeItem = function (id) {
|
|||
|
return delete this._data[id];
|
|||
|
};
|
|||
|
|
|||
|
Storage.prototype.clear = function () {
|
|||
|
this._data = {};
|
|||
|
return this._data;
|
|||
|
};
|
|||
|
} catch (e) {
|
|||
|
console.error('localStorage pollyfill error: ', e);
|
|||
|
}
|
|||
|
}
|
|||
|
})();
|
|||
|
|
|||
|
/***/ }),
|
|||
|
|
|||
|
/***/ 46700:
|
|||
|
/***/ ((module, __unused_webpack_exports, __webpack_require__) => {
|
|||
|
|
|||
|
var map = {
|
|||
|
"./af": 42786,
|
|||
|
"./af.js": 42786,
|
|||
|
"./ar": 30867,
|
|||
|
"./ar-dz": 14130,
|
|||
|
"./ar-dz.js": 14130,
|
|||
|
"./ar-kw": 96135,
|
|||
|
"./ar-kw.js": 96135,
|
|||
|
"./ar-ly": 56440,
|
|||
|
"./ar-ly.js": 56440,
|
|||
|
"./ar-ma": 47702,
|
|||
|
"./ar-ma.js": 47702,
|
|||
|
"./ar-sa": 16040,
|
|||
|
"./ar-sa.js": 16040,
|
|||
|
"./ar-tn": 37100,
|
|||
|
"./ar-tn.js": 37100,
|
|||
|
"./ar.js": 30867,
|
|||
|
"./az": 31083,
|
|||
|
"./az.js": 31083,
|
|||
|
"./be": 9808,
|
|||
|
"./be.js": 9808,
|
|||
|
"./bg": 68338,
|
|||
|
"./bg.js": 68338,
|
|||
|
"./bm": 67438,
|
|||
|
"./bm.js": 67438,
|
|||
|
"./bn": 8905,
|
|||
|
"./bn-bd": 76225,
|
|||
|
"./bn-bd.js": 76225,
|
|||
|
"./bn.js": 8905,
|
|||
|
"./bo": 11560,
|
|||
|
"./bo.js": 11560,
|
|||
|
"./br": 1278,
|
|||
|
"./br.js": 1278,
|
|||
|
"./bs": 80622,
|
|||
|
"./bs.js": 80622,
|
|||
|
"./ca": 2468,
|
|||
|
"./ca.js": 2468,
|
|||
|
"./cs": 5822,
|
|||
|
"./cs.js": 5822,
|
|||
|
"./cv": 50877,
|
|||
|
"./cv.js": 50877,
|
|||
|
"./cy": 47373,
|
|||
|
"./cy.js": 47373,
|
|||
|
"./da": 24780,
|
|||
|
"./da.js": 24780,
|
|||
|
"./de": 59740,
|
|||
|
"./de-at": 60217,
|
|||
|
"./de-at.js": 60217,
|
|||
|
"./de-ch": 60894,
|
|||
|
"./de-ch.js": 60894,
|
|||
|
"./de.js": 59740,
|
|||
|
"./dv": 5300,
|
|||
|
"./dv.js": 5300,
|
|||
|
"./el": 50837,
|
|||
|
"./el.js": 50837,
|
|||
|
"./en-au": 78348,
|
|||
|
"./en-au.js": 78348,
|
|||
|
"./en-ca": 77925,
|
|||
|
"./en-ca.js": 77925,
|
|||
|
"./en-gb": 22243,
|
|||
|
"./en-gb.js": 22243,
|
|||
|
"./en-ie": 46436,
|
|||
|
"./en-ie.js": 46436,
|
|||
|
"./en-il": 47207,
|
|||
|
"./en-il.js": 47207,
|
|||
|
"./en-in": 44175,
|
|||
|
"./en-in.js": 44175,
|
|||
|
"./en-nz": 76319,
|
|||
|
"./en-nz.js": 76319,
|
|||
|
"./en-sg": 31662,
|
|||
|
"./en-sg.js": 31662,
|
|||
|
"./eo": 92915,
|
|||
|
"./eo.js": 92915,
|
|||
|
"./es": 55655,
|
|||
|
"./es-do": 55251,
|
|||
|
"./es-do.js": 55251,
|
|||
|
"./es-mx": 96112,
|
|||
|
"./es-mx.js": 96112,
|
|||
|
"./es-us": 71146,
|
|||
|
"./es-us.js": 71146,
|
|||
|
"./es.js": 55655,
|
|||
|
"./et": 5603,
|
|||
|
"./et.js": 5603,
|
|||
|
"./eu": 77763,
|
|||
|
"./eu.js": 77763,
|
|||
|
"./fa": 76959,
|
|||
|
"./fa.js": 76959,
|
|||
|
"./fi": 11897,
|
|||
|
"./fi.js": 11897,
|
|||
|
"./fil": 42549,
|
|||
|
"./fil.js": 42549,
|
|||
|
"./fo": 94694,
|
|||
|
"./fo.js": 94694,
|
|||
|
"./fr": 94470,
|
|||
|
"./fr-ca": 63049,
|
|||
|
"./fr-ca.js": 63049,
|
|||
|
"./fr-ch": 52330,
|
|||
|
"./fr-ch.js": 52330,
|
|||
|
"./fr.js": 94470,
|
|||
|
"./fy": 5044,
|
|||
|
"./fy.js": 5044,
|
|||
|
"./ga": 29295,
|
|||
|
"./ga.js": 29295,
|
|||
|
"./gd": 2101,
|
|||
|
"./gd.js": 2101,
|
|||
|
"./gl": 38794,
|
|||
|
"./gl.js": 38794,
|
|||
|
"./gom-deva": 27884,
|
|||
|
"./gom-deva.js": 27884,
|
|||
|
"./gom-latn": 23168,
|
|||
|
"./gom-latn.js": 23168,
|
|||
|
"./gu": 95349,
|
|||
|
"./gu.js": 95349,
|
|||
|
"./he": 24206,
|
|||
|
"./he.js": 24206,
|
|||
|
"./hi": 30094,
|
|||
|
"./hi.js": 30094,
|
|||
|
"./hr": 30316,
|
|||
|
"./hr.js": 30316,
|
|||
|
"./hu": 22138,
|
|||
|
"./hu.js": 22138,
|
|||
|
"./hy-am": 11423,
|
|||
|
"./hy-am.js": 11423,
|
|||
|
"./id": 29218,
|
|||
|
"./id.js": 29218,
|
|||
|
"./is": 90135,
|
|||
|
"./is.js": 90135,
|
|||
|
"./it": 90626,
|
|||
|
"./it-ch": 10150,
|
|||
|
"./it-ch.js": 10150,
|
|||
|
"./it.js": 90626,
|
|||
|
"./ja": 39183,
|
|||
|
"./ja.js": 39183,
|
|||
|
"./jv": 24286,
|
|||
|
"./jv.js": 24286,
|
|||
|
"./ka": 12105,
|
|||
|
"./ka.js": 12105,
|
|||
|
"./kk": 47772,
|
|||
|
"./kk.js": 47772,
|
|||
|
"./km": 18758,
|
|||
|
"./km.js": 18758,
|
|||
|
"./kn": 79282,
|
|||
|
"./kn.js": 79282,
|
|||
|
"./ko": 33730,
|
|||
|
"./ko.js": 33730,
|
|||
|
"./ku": 1408,
|
|||
|
"./ku.js": 1408,
|
|||
|
"./ky": 33291,
|
|||
|
"./ky.js": 33291,
|
|||
|
"./lb": 36841,
|
|||
|
"./lb.js": 36841,
|
|||
|
"./lo": 55466,
|
|||
|
"./lo.js": 55466,
|
|||
|
"./lt": 57010,
|
|||
|
"./lt.js": 57010,
|
|||
|
"./lv": 37595,
|
|||
|
"./lv.js": 37595,
|
|||
|
"./me": 39861,
|
|||
|
"./me.js": 39861,
|
|||
|
"./mi": 35493,
|
|||
|
"./mi.js": 35493,
|
|||
|
"./mk": 95966,
|
|||
|
"./mk.js": 95966,
|
|||
|
"./ml": 87341,
|
|||
|
"./ml.js": 87341,
|
|||
|
"./mn": 5115,
|
|||
|
"./mn.js": 5115,
|
|||
|
"./mr": 10370,
|
|||
|
"./mr.js": 10370,
|
|||
|
"./ms": 9847,
|
|||
|
"./ms-my": 41237,
|
|||
|
"./ms-my.js": 41237,
|
|||
|
"./ms.js": 9847,
|
|||
|
"./mt": 72126,
|
|||
|
"./mt.js": 72126,
|
|||
|
"./my": 56165,
|
|||
|
"./my.js": 56165,
|
|||
|
"./nb": 64924,
|
|||
|
"./nb.js": 64924,
|
|||
|
"./ne": 16744,
|
|||
|
"./ne.js": 16744,
|
|||
|
"./nl": 93901,
|
|||
|
"./nl-be": 59814,
|
|||
|
"./nl-be.js": 59814,
|
|||
|
"./nl.js": 93901,
|
|||
|
"./nn": 83877,
|
|||
|
"./nn.js": 83877,
|
|||
|
"./oc-lnc": 92135,
|
|||
|
"./oc-lnc.js": 92135,
|
|||
|
"./pa-in": 15858,
|
|||
|
"./pa-in.js": 15858,
|
|||
|
"./pl": 64495,
|
|||
|
"./pl.js": 64495,
|
|||
|
"./pt": 89520,
|
|||
|
"./pt-br": 57971,
|
|||
|
"./pt-br.js": 57971,
|
|||
|
"./pt.js": 89520,
|
|||
|
"./ro": 96459,
|
|||
|
"./ro.js": 96459,
|
|||
|
"./ru": 21793,
|
|||
|
"./ru.js": 21793,
|
|||
|
"./sd": 40950,
|
|||
|
"./sd.js": 40950,
|
|||
|
"./se": 10490,
|
|||
|
"./se.js": 10490,
|
|||
|
"./si": 90124,
|
|||
|
"./si.js": 90124,
|
|||
|
"./sk": 64249,
|
|||
|
"./sk.js": 64249,
|
|||
|
"./sl": 14985,
|
|||
|
"./sl.js": 14985,
|
|||
|
"./sq": 51104,
|
|||
|
"./sq.js": 51104,
|
|||
|
"./sr": 49131,
|
|||
|
"./sr-cyrl": 79915,
|
|||
|
"./sr-cyrl.js": 79915,
|
|||
|
"./sr.js": 49131,
|
|||
|
"./ss": 85893,
|
|||
|
"./ss.js": 85893,
|
|||
|
"./sv": 98760,
|
|||
|
"./sv.js": 98760,
|
|||
|
"./sw": 91172,
|
|||
|
"./sw.js": 91172,
|
|||
|
"./ta": 27333,
|
|||
|
"./ta.js": 27333,
|
|||
|
"./te": 23110,
|
|||
|
"./te.js": 23110,
|
|||
|
"./tet": 52095,
|
|||
|
"./tet.js": 52095,
|
|||
|
"./tg": 27321,
|
|||
|
"./tg.js": 27321,
|
|||
|
"./th": 9041,
|
|||
|
"./th.js": 9041,
|
|||
|
"./tk": 19005,
|
|||
|
"./tk.js": 19005,
|
|||
|
"./tl-ph": 75768,
|
|||
|
"./tl-ph.js": 75768,
|
|||
|
"./tlh": 89444,
|
|||
|
"./tlh.js": 89444,
|
|||
|
"./tr": 72397,
|
|||
|
"./tr.js": 72397,
|
|||
|
"./tzl": 28254,
|
|||
|
"./tzl.js": 28254,
|
|||
|
"./tzm": 51106,
|
|||
|
"./tzm-latn": 30699,
|
|||
|
"./tzm-latn.js": 30699,
|
|||
|
"./tzm.js": 51106,
|
|||
|
"./ug-cn": 9288,
|
|||
|
"./ug-cn.js": 9288,
|
|||
|
"./uk": 67691,
|
|||
|
"./uk.js": 67691,
|
|||
|
"./ur": 13795,
|
|||
|
"./ur.js": 13795,
|
|||
|
"./uz": 6791,
|
|||
|
"./uz-latn": 60588,
|
|||
|
"./uz-latn.js": 60588,
|
|||
|
"./uz.js": 6791,
|
|||
|
"./vi": 65666,
|
|||
|
"./vi.js": 65666,
|
|||
|
"./x-pseudo": 14378,
|
|||
|
"./x-pseudo.js": 14378,
|
|||
|
"./yo": 75805,
|
|||
|
"./yo.js": 75805,
|
|||
|
"./zh-cn": 83839,
|
|||
|
"./zh-cn.js": 83839,
|
|||
|
"./zh-hk": 55726,
|
|||
|
"./zh-hk.js": 55726,
|
|||
|
"./zh-mo": 99807,
|
|||
|
"./zh-mo.js": 99807,
|
|||
|
"./zh-tw": 74152,
|
|||
|
"./zh-tw.js": 74152
|
|||
|
};
|
|||
|
|
|||
|
|
|||
|
function webpackContext(req) {
|
|||
|
var id = webpackContextResolve(req);
|
|||
|
return __webpack_require__(id);
|
|||
|
}
|
|||
|
function webpackContextResolve(req) {
|
|||
|
if(!__webpack_require__.o(map, req)) {
|
|||
|
var e = new Error("Cannot find module '" + req + "'");
|
|||
|
e.code = 'MODULE_NOT_FOUND';
|
|||
|
throw e;
|
|||
|
}
|
|||
|
return map[req];
|
|||
|
}
|
|||
|
webpackContext.keys = function webpackContextKeys() {
|
|||
|
return Object.keys(map);
|
|||
|
};
|
|||
|
webpackContext.resolve = webpackContextResolve;
|
|||
|
module.exports = webpackContext;
|
|||
|
webpackContext.id = 46700;
|
|||
|
|
|||
|
/***/ }),
|
|||
|
|
|||
|
/***/ 56089:
|
|||
|
/***/ ((module) => {
|
|||
|
|
|||
|
"use strict";
|
|||
|
module.exports = "";
|
|||
|
|
|||
|
/***/ }),
|
|||
|
|
|||
|
/***/ 17735:
|
|||
|
/***/ ((module) => {
|
|||
|
|
|||
|
"use strict";
|
|||
|
module.exports = "";
|
|||
|
|
|||
|
/***/ }),
|
|||
|
|
|||
|
/***/ 96192:
|
|||
|
/***/ ((module) => {
|
|||
|
|
|||
|
"use strict";
|
|||
|
module.exports = "";
|
|||
|
|
|||
|
/***/ }),
|
|||
|
|
|||
|
/***/ 71090:
|
|||
|
/***/ ((module) => {
|
|||
|
|
|||
|
"use strict";
|
|||
|
module.exports = "";
|
|||
|
|
|||
|
/***/ }),
|
|||
|
|
|||
|
/***/ 46050:
|
|||
|
/***/ ((module) => {
|
|||
|
|
|||
|
"use strict";
|
|||
|
module.exports = "";
|
|||
|
|
|||
|
/***/ }),
|
|||
|
|
|||
|
/***/ 65311:
|
|||
|
/***/ ((module) => {
|
|||
|
|
|||
|
"use strict";
|
|||
|
module.exports = jQuery;
|
|||
|
|
|||
|
/***/ })
|
|||
|
|
|||
|
/******/ });
|
|||
|
/************************************************************************/
|
|||
|
/******/ // The module cache
|
|||
|
/******/ var __webpack_module_cache__ = {};
|
|||
|
/******/
|
|||
|
/******/ // The require function
|
|||
|
/******/ function __webpack_require__(moduleId) {
|
|||
|
/******/ // Check if module is in cache
|
|||
|
/******/ var cachedModule = __webpack_module_cache__[moduleId];
|
|||
|
/******/ if (cachedModule !== undefined) {
|
|||
|
/******/ return cachedModule.exports;
|
|||
|
/******/ }
|
|||
|
/******/ // Create a new module (and put it into the cache)
|
|||
|
/******/ var module = __webpack_module_cache__[moduleId] = {
|
|||
|
/******/ id: moduleId,
|
|||
|
/******/ loaded: false,
|
|||
|
/******/ exports: {}
|
|||
|
/******/ };
|
|||
|
/******/
|
|||
|
/******/ // Execute the module function
|
|||
|
/******/ __webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
|||
|
/******/
|
|||
|
/******/ // Flag the module as loaded
|
|||
|
/******/ module.loaded = true;
|
|||
|
/******/
|
|||
|
/******/ // Return the exports of the module
|
|||
|
/******/ return module.exports;
|
|||
|
/******/ }
|
|||
|
/******/
|
|||
|
/******/ // expose the modules object (__webpack_modules__)
|
|||
|
/******/ __webpack_require__.m = __webpack_modules__;
|
|||
|
/******/
|
|||
|
/************************************************************************/
|
|||
|
/******/ /* webpack/runtime/amd define */
|
|||
|
/******/ (() => {
|
|||
|
/******/ __webpack_require__.amdD = function () {
|
|||
|
/******/ throw new Error('define cannot be used indirect');
|
|||
|
/******/ };
|
|||
|
/******/ })();
|
|||
|
/******/
|
|||
|
/******/ /* webpack/runtime/chunk loaded */
|
|||
|
/******/ (() => {
|
|||
|
/******/ var deferred = [];
|
|||
|
/******/ __webpack_require__.O = (result, chunkIds, fn, priority) => {
|
|||
|
/******/ if(chunkIds) {
|
|||
|
/******/ priority = priority || 0;
|
|||
|
/******/ for(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];
|
|||
|
/******/ deferred[i] = [chunkIds, fn, priority];
|
|||
|
/******/ return;
|
|||
|
/******/ }
|
|||
|
/******/ var notFulfilled = Infinity;
|
|||
|
/******/ for (var i = 0; i < deferred.length; i++) {
|
|||
|
/******/ var [chunkIds, fn, priority] = deferred[i];
|
|||
|
/******/ var fulfilled = true;
|
|||
|
/******/ for (var j = 0; j < chunkIds.length; j++) {
|
|||
|
/******/ if ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every((key) => (__webpack_require__.O[key](chunkIds[j])))) {
|
|||
|
/******/ chunkIds.splice(j--, 1);
|
|||
|
/******/ } else {
|
|||
|
/******/ fulfilled = false;
|
|||
|
/******/ if(priority < notFulfilled) notFulfilled = priority;
|
|||
|
/******/ }
|
|||
|
/******/ }
|
|||
|
/******/ if(fulfilled) {
|
|||
|
/******/ deferred.splice(i--, 1)
|
|||
|
/******/ var r = fn();
|
|||
|
/******/ if (r !== undefined) result = r;
|
|||
|
/******/ }
|
|||
|
/******/ }
|
|||
|
/******/ return result;
|
|||
|
/******/ };
|
|||
|
/******/ })();
|
|||
|
/******/
|
|||
|
/******/ /* webpack/runtime/compat get default export */
|
|||
|
/******/ (() => {
|
|||
|
/******/ // getDefaultExport function for compatibility with non-harmony modules
|
|||
|
/******/ __webpack_require__.n = (module) => {
|
|||
|
/******/ var getter = module && module.__esModule ?
|
|||
|
/******/ () => (module['default']) :
|
|||
|
/******/ () => (module);
|
|||
|
/******/ __webpack_require__.d(getter, { a: getter });
|
|||
|
/******/ return getter;
|
|||
|
/******/ };
|
|||
|
/******/ })();
|
|||
|
/******/
|
|||
|
/******/ /* webpack/runtime/define property getters */
|
|||
|
/******/ (() => {
|
|||
|
/******/ // define getter functions for harmony exports
|
|||
|
/******/ __webpack_require__.d = (exports, definition) => {
|
|||
|
/******/ for(var key in definition) {
|
|||
|
/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
|
|||
|
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
|
|||
|
/******/ }
|
|||
|
/******/ }
|
|||
|
/******/ };
|
|||
|
/******/ })();
|
|||
|
/******/
|
|||
|
/******/ /* webpack/runtime/global */
|
|||
|
/******/ (() => {
|
|||
|
/******/ __webpack_require__.g = (function() {
|
|||
|
/******/ if (typeof globalThis === 'object') return globalThis;
|
|||
|
/******/ try {
|
|||
|
/******/ return this || new Function('return this')();
|
|||
|
/******/ } catch (e) {
|
|||
|
/******/ if (typeof window === 'object') return window;
|
|||
|
/******/ }
|
|||
|
/******/ })();
|
|||
|
/******/ })();
|
|||
|
/******/
|
|||
|
/******/ /* webpack/runtime/hasOwnProperty shorthand */
|
|||
|
/******/ (() => {
|
|||
|
/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
|
|||
|
/******/ })();
|
|||
|
/******/
|
|||
|
/******/ /* webpack/runtime/make namespace object */
|
|||
|
/******/ (() => {
|
|||
|
/******/ // define __esModule on exports
|
|||
|
/******/ __webpack_require__.r = (exports) => {
|
|||
|
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
|
|||
|
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|||
|
/******/ }
|
|||
|
/******/ Object.defineProperty(exports, '__esModule', { value: true });
|
|||
|
/******/ };
|
|||
|
/******/ })();
|
|||
|
/******/
|
|||
|
/******/ /* webpack/runtime/node module decorator */
|
|||
|
/******/ (() => {
|
|||
|
/******/ __webpack_require__.nmd = (module) => {
|
|||
|
/******/ module.paths = [];
|
|||
|
/******/ if (!module.children) module.children = [];
|
|||
|
/******/ return module;
|
|||
|
/******/ };
|
|||
|
/******/ })();
|
|||
|
/******/
|
|||
|
/******/ /* webpack/runtime/jsonp chunk loading */
|
|||
|
/******/ (() => {
|
|||
|
/******/ __webpack_require__.b = document.baseURI || self.location.href;
|
|||
|
/******/
|
|||
|
/******/ // object to store loaded and loading chunks
|
|||
|
/******/ // undefined = chunk not loaded, null = chunk preloaded/prefetched
|
|||
|
/******/ // [resolve, reject, Promise] = chunk loading, 0 = chunk loaded
|
|||
|
/******/ var installedChunks = {
|
|||
|
/******/ 328: 0
|
|||
|
/******/ };
|
|||
|
/******/
|
|||
|
/******/ // no chunk on demand loading
|
|||
|
/******/
|
|||
|
/******/ // no prefetching
|
|||
|
/******/
|
|||
|
/******/ // no preloaded
|
|||
|
/******/
|
|||
|
/******/ // no HMR
|
|||
|
/******/
|
|||
|
/******/ // no HMR manifest
|
|||
|
/******/
|
|||
|
/******/ __webpack_require__.O.j = (chunkId) => (installedChunks[chunkId] === 0);
|
|||
|
/******/
|
|||
|
/******/ // install a JSONP callback for chunk loading
|
|||
|
/******/ var webpackJsonpCallback = (parentChunkLoadingFunction, data) => {
|
|||
|
/******/ var [chunkIds, moreModules, runtime] = data;
|
|||
|
/******/ // add "moreModules" to the modules object,
|
|||
|
/******/ // then flag all "chunkIds" as loaded and fire callback
|
|||
|
/******/ var moduleId, chunkId, i = 0;
|
|||
|
/******/ if(chunkIds.some((id) => (installedChunks[id] !== 0))) {
|
|||
|
/******/ for(moduleId in moreModules) {
|
|||
|
/******/ if(__webpack_require__.o(moreModules, moduleId)) {
|
|||
|
/******/ __webpack_require__.m[moduleId] = moreModules[moduleId];
|
|||
|
/******/ }
|
|||
|
/******/ }
|
|||
|
/******/ if(runtime) var result = runtime(__webpack_require__);
|
|||
|
/******/ }
|
|||
|
/******/ if(parentChunkLoadingFunction) parentChunkLoadingFunction(data);
|
|||
|
/******/ for(;i < chunkIds.length; i++) {
|
|||
|
/******/ chunkId = chunkIds[i];
|
|||
|
/******/ if(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {
|
|||
|
/******/ installedChunks[chunkId][0]();
|
|||
|
/******/ }
|
|||
|
/******/ installedChunks[chunkId] = 0;
|
|||
|
/******/ }
|
|||
|
/******/ return __webpack_require__.O(result);
|
|||
|
/******/ }
|
|||
|
/******/
|
|||
|
/******/ var chunkLoadingGlobal = self["webpackChunkGrav"] = self["webpackChunkGrav"] || [];
|
|||
|
/******/ chunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));
|
|||
|
/******/ chunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));
|
|||
|
/******/ })();
|
|||
|
/******/
|
|||
|
/************************************************************************/
|
|||
|
/******/
|
|||
|
/******/ // startup
|
|||
|
/******/ // Load entry module and return exports
|
|||
|
/******/ // This entry module depends on other loaded chunks and execution need to be delayed
|
|||
|
/******/ var __webpack_exports__ = __webpack_require__.O(undefined, [736], () => (__webpack_require__(56299)))
|
|||
|
/******/ __webpack_exports__ = __webpack_require__.O(__webpack_exports__);
|
|||
|
/******/ Grav = __webpack_exports__;
|
|||
|
/******/
|
|||
|
/******/ })()
|
|||
|
;
|