Sindbad~EG File Manager
/******/ (() => { // webpackBootstrap
/******/ "use strict";
/******/ var __webpack_modules__ = ({
/***/ "./assets/src/js/utils.js":
/*!********************************!*\
!*** ./assets/src/js/utils.js ***!
\********************************/
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ listenElementCreated: () => (/* binding */ listenElementCreated),
/* harmony export */ listenElementViewed: () => (/* binding */ listenElementViewed),
/* harmony export */ lpAddQueryArgs: () => (/* binding */ lpAddQueryArgs),
/* harmony export */ lpAjaxParseJsonOld: () => (/* binding */ lpAjaxParseJsonOld),
/* harmony export */ lpClassName: () => (/* binding */ lpClassName),
/* harmony export */ lpFetchAPI: () => (/* binding */ lpFetchAPI),
/* harmony export */ lpGetCurrentURLNoParam: () => (/* binding */ lpGetCurrentURLNoParam),
/* harmony export */ lpOnElementReady: () => (/* binding */ lpOnElementReady),
/* harmony export */ lpSetLoadingEl: () => (/* binding */ lpSetLoadingEl),
/* harmony export */ lpShowHideEl: () => (/* binding */ lpShowHideEl)
/* harmony export */ });
/**
* Utils functions
*
* @param url
* @param data
* @param functions
* @since 4.2.5.1
* @version 1.0.3
*/
const lpClassName = {
hidden: 'lp-hidden',
loading: 'loading'
};
const lpFetchAPI = (url, data = {}, functions = {}) => {
if ('function' === typeof functions.before) {
functions.before();
}
fetch(url, {
method: 'GET',
...data
}).then(response => response.json()).then(response => {
if ('function' === typeof functions.success) {
functions.success(response);
}
}).catch(err => {
if ('function' === typeof functions.error) {
functions.error(err);
}
}).finally(() => {
if ('function' === typeof functions.completed) {
functions.completed();
}
});
};
/**
* Get current URL without params.
*
* @since 4.2.5.1
*/
const lpGetCurrentURLNoParam = () => {
let currentUrl = window.location.href;
const hasParams = currentUrl.includes('?');
if (hasParams) {
currentUrl = currentUrl.split('?')[0];
}
return currentUrl;
};
const lpAddQueryArgs = (endpoint, args) => {
const url = new URL(endpoint);
Object.keys(args).forEach(arg => {
url.searchParams.set(arg, args[arg]);
});
return url;
};
/**
* Listen element viewed.
*
* @param el
* @param callback
* @since 4.2.5.8
*/
const listenElementViewed = (el, callback) => {
const observerSeeItem = new IntersectionObserver(function (entries) {
for (const entry of entries) {
if (entry.isIntersecting) {
callback(entry);
}
}
});
observerSeeItem.observe(el);
};
/**
* Listen element created.
*
* @param callback
* @since 4.2.5.8
*/
const listenElementCreated = callback => {
const observerCreateItem = new MutationObserver(function (mutations) {
mutations.forEach(function (mutation) {
if (mutation.addedNodes) {
mutation.addedNodes.forEach(function (node) {
if (node.nodeType === 1) {
callback(node);
}
});
}
});
});
observerCreateItem.observe(document, {
childList: true,
subtree: true
});
// End.
};
/**
* Listen element created.
*
* @param selector
* @param callback
* @since 4.2.7.1
*/
const lpOnElementReady = (selector, callback) => {
const element = document.querySelector(selector);
if (element) {
callback(element);
return;
}
const observer = new MutationObserver((mutations, obs) => {
const element = document.querySelector(selector);
if (element) {
obs.disconnect();
callback(element);
}
});
observer.observe(document.documentElement, {
childList: true,
subtree: true
});
};
// Parse JSON from string with content include LP_AJAX_START.
const lpAjaxParseJsonOld = data => {
if (typeof data !== 'string') {
return data;
}
const m = String.raw({
raw: data
}).match(/<-- LP_AJAX_START -->(.*)<-- LP_AJAX_END -->/s);
try {
if (m) {
data = JSON.parse(m[1].replace(/(?:\r\n|\r|\n)/g, ''));
} else {
data = JSON.parse(data);
}
} catch (e) {
data = {};
}
return data;
};
// status 0: hide, 1: show
const lpShowHideEl = (el, status = 0) => {
if (!el) {
return;
}
if (!status) {
el.classList.add(lpClassName.hidden);
} else {
el.classList.remove(lpClassName.hidden);
}
};
// status 0: hide, 1: show
const lpSetLoadingEl = (el, status) => {
if (!el) {
return;
}
if (!status) {
el.classList.remove(lpClassName.loading);
} else {
el.classList.add(lpClassName.loading);
}
};
/***/ })
/******/ });
/************************************************************************/
/******/ // 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] = {
/******/ // no module.id needed
/******/ // no module.loaded needed
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/************************************************************************/
/******/ /* 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/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 });
/******/ };
/******/ })();
/******/
/************************************************************************/
var __webpack_exports__ = {};
/*!***********************************!*\
!*** ./assets/src/js/loadAJAX.js ***!
\***********************************/
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
/* harmony import */ var _utils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./utils.js */ "./assets/src/js/utils.js");
/**
* Load all you need via AJAX
*
* @since 4.2.5.7
* @version 1.0.6
*/
// Handle general parameter in the Frontend and Backend
let lpSettings = {};
if ('undefined' !== typeof lpDataAdmin) {
lpSettings = lpDataAdmin;
} else if ('undefined' !== typeof lpData) {
lpSettings = lpData;
}
// End Handle general parameter in the Frontend and Backend
const lpAJAX = () => {
const classLPTarget = '.lp-target';
const urlCurrent = (0,_utils_js__WEBPACK_IMPORTED_MODULE_0__.lpGetCurrentURLNoParam)();
return {
autoLoadAPIs: () => {
console.log('autoLoadAPIs');
},
fetchAPI: (url, params, callBack) => {
const option = {
headers: {}
};
if (0 !== parseInt(lpSettings.user_id)) {
option.headers['X-WP-Nonce'] = lpSettings.nonce;
}
if ('undefined' !== typeof params.args.method_request) {
option.method = params.args.method_request;
} else {
option.method = 'POST';
}
//params.args = { ...params.args, ...lpData.urlParams };
if ('POST' === option.method) {
option.body = JSON.stringify(params);
option.headers['Content-Type'] = 'application/json';
} else {
params.args = JSON.stringify(params.args);
params.callback = JSON.stringify(params.callback);
url = (0,_utils_js__WEBPACK_IMPORTED_MODULE_0__.lpAddQueryArgs)(url, params);
}
(0,_utils_js__WEBPACK_IMPORTED_MODULE_0__.lpFetchAPI)(url, option, callBack);
},
fetchAJAX: (params, callBack, urlAjax = '') => {
urlAjax = urlAjax || lpSettings.lpAjaxUrl;
// Set param id_url for identify.
if (params.hasOwnProperty('args') && params.args.hasOwnProperty('id_url')) {
urlAjax = (0,_utils_js__WEBPACK_IMPORTED_MODULE_0__.lpAddQueryArgs)(urlAjax, {
id_url: params.args.id_url
});
}
// Set param lang here if exits, for detect translate
if (lpSettings.urlParams.hasOwnProperty('lang')) {
urlAjax = (0,_utils_js__WEBPACK_IMPORTED_MODULE_0__.lpAddQueryArgs)(urlAjax, {
lang: lpSettings.urlParams.lang
});
}
const formData = new FormData();
formData.append('nonce', lpSettings.nonce);
formData.append('lp-load-ajax', 'load_content_via_ajax');
formData.append('data', JSON.stringify(params));
const dataSend = {
method: 'POST',
headers: {},
body: formData
};
if (0 !== parseInt(lpSettings.user_id)) {
dataSend.headers['X-WP-Nonce'] = lpSettings.nonce;
}
(0,_utils_js__WEBPACK_IMPORTED_MODULE_0__.lpFetchAPI)(urlAjax, dataSend, callBack);
},
getElements: () => {
// Finds all elements with the class '.lp-load-ajax-element'
const elements = document.querySelectorAll('.lp-load-ajax-element:not(.loaded)');
//console.log( 'getElements', elements );
if (elements.length) {
elements.forEach(element => {
//console.log( 'Element handing', element );
const elTarget = element.querySelector(`${classLPTarget}`);
if (!elTarget) {
return;
}
const dataObj = JSON.parse(elTarget.dataset.send);
const dataSend = {
...dataObj
};
const elLoadingFirst = element.querySelector('.loading-first');
const callBack = {
success: response => {
const {
status,
message,
data
} = response;
if ('success' === status) {
elTarget.innerHTML = data.content;
} else if ('error' === status) {
elTarget.innerHTML = message;
}
},
error: error => {
console.log(error);
},
completed: () => {
window.lpAJAXG.getElements();
//console.log( 'completed' );
if (elLoadingFirst) {
elLoadingFirst.remove();
}
}
};
// Call via AJAX
window.lpAJAXG.fetchAJAX(dataSend, callBack);
element.classList.add('loaded');
});
}
},
clickNumberPage: (e, target) => {
const btnNumber = target.closest('.page-numbers:not(.disabled)');
if (!btnNumber) {
return;
}
const elLPTarget = btnNumber.closest(`${classLPTarget}`);
if (!elLPTarget) {
return;
}
const dataObj = JSON.parse(elLPTarget.dataset.send);
const dataSend = {
...dataObj
};
if (!dataSend.args.hasOwnProperty('paged')) {
dataSend.args.paged = 1;
}
e.preventDefault();
if (btnNumber.classList.contains('prev')) {
dataSend.args.paged--;
} else if (btnNumber.classList.contains('next')) {
dataSend.args.paged++;
} else {
dataSend.args.paged = btnNumber.textContent;
}
elLPTarget.dataset.send = JSON.stringify(dataSend);
// Set url params to reload page.
// Todo: need check allow set url params.
lpData.urlParams.paged = dataSend.args.paged;
window.history.pushState({}, '', (0,_utils_js__WEBPACK_IMPORTED_MODULE_0__.lpAddQueryArgs)(urlCurrent, lpData.urlParams));
// End.
// Show loading
const elLoading = elLPTarget.closest(`div:not(${classLPTarget})`).querySelector('.lp-loading-change');
if (elLoading) {
elLoading.style.display = 'block';
}
// End
// Scroll to archive element
const elLPTargetY = elLPTarget.getBoundingClientRect().top + window.scrollY - 100;
window.scrollTo({
top: elLPTargetY
});
const callBack = {
success: response => {
//console.log( 'response', response );
const {
status,
message,
data
} = response;
elLPTarget.innerHTML = data.content || '';
},
error: error => {
console.log(error);
},
completed: () => {
//console.log( 'completed' );
if (elLoading) {
elLoading.style.display = 'none';
}
}
};
window.lpAJAXG.fetchAJAX(dataSend, callBack);
},
getDataSetCurrent: elLPTarget => {
return JSON.parse(elLPTarget.dataset.send);
},
setDataSetCurrent: (elLPTarget, dataSend) => {
return elLPTarget.dataset.send = JSON.stringify(dataSend);
}
};
};
window.lpAJAXG = lpAJAX();
window.lpAJAXG.getElements();
// Events
document.addEventListener('click', function (e) {
const target = e.target;
window.lpAJAXG.clickNumberPage(e, target);
});
// Listen element created
(0,_utils_js__WEBPACK_IMPORTED_MODULE_0__.listenElementCreated)(node => {
if (node.classList.contains('lp-load-ajax-element')) {
//console.log( 'Element created', node );
window.lpAJAXG.getElements();
}
});
// Listen element ready
(0,_utils_js__WEBPACK_IMPORTED_MODULE_0__.lpOnElementReady)('.lp-load-ajax-element', element => {
//console.log( 'Element ready', element );
window.lpAJAXG.getElements();
});
// Case 2: readystatechange, find all elements with the class '.lp-load-ajax-element' not have class 'loaded'
document.addEventListener('readystatechange', event => {
//console.log( 'readystatechange' );
window.lpAJAXG.getElements();
});
// Case 3: DOMContentLoaded, find all elements with the class '.lp-load-ajax-element' not have class 'loaded'
document.addEventListener('DOMContentLoaded', () => {
//console.log( 'DOMContentLoaded' );
window.lpAJAXG.getElements();
});
/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (lpAJAX);
/******/ })()
;
//# sourceMappingURL=loadAJAX.js.map
Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists