Skip to content

Instantly share code, notes, and snippets.

@werpu
Created November 22, 2019 15:19
Show Gist options
  • Save werpu/d656d86cdc202f2e060d2e436e2d94ec to your computer and use it in GitHub Desktop.
Save werpu/d656d86cdc202f2e060d2e436e2d94ec to your computer and use it in GitHub Desktop.
(function(e, a) { for(var i in a) e[i] = a[i]; }(window, /******/ (function(modules) { // webpackBootstrap
/******/ // The module cache
/******/ var installedModules = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/
/******/ // Check if module is in cache
/******/ if(installedModules[moduleId]) {
/******/ return installedModules[moduleId].exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = installedModules[moduleId] = {
/******/ i: moduleId,
/******/ l: false,
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/ // Flag the module as loaded
/******/ module.l = true;
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/******/
/******/ // expose the modules object (__webpack_modules__)
/******/ __webpack_require__.m = modules;
/******/
/******/ // expose the module cache
/******/ __webpack_require__.c = installedModules;
/******/
/******/ // define getter function for harmony exports
/******/ __webpack_require__.d = function(exports, name, getter) {
/******/ if(!__webpack_require__.o(exports, name)) {
/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
/******/ }
/******/ };
/******/
/******/ // define __esModule on exports
/******/ __webpack_require__.r = function(exports) {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/
/******/ // create a fake namespace object
/******/ // mode & 1: value is a module id, require it
/******/ // mode & 2: merge all properties of value into the ns
/******/ // mode & 4: return value when already ns object
/******/ // mode & 8|1: behave like require
/******/ __webpack_require__.t = function(value, mode) {
/******/ if(mode & 1) value = __webpack_require__(value);
/******/ if(mode & 8) return value;
/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
/******/ var ns = Object.create(null);
/******/ __webpack_require__.r(ns);
/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
/******/ return ns;
/******/ };
/******/
/******/ // getDefaultExport function for compatibility with non-harmony modules
/******/ __webpack_require__.n = function(module) {
/******/ var getter = module && module.__esModule ?
/******/ function getDefault() { return module['default']; } :
/******/ function getModuleExports() { return module; };
/******/ __webpack_require__.d(getter, 'a', getter);
/******/ return getter;
/******/ };
/******/
/******/ // Object.prototype.hasOwnProperty.call
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
/******/
/******/ // __webpack_public_path__
/******/ __webpack_require__.p = "";
/******/
/******/
/******/ // Load entry module and return exports
/******/ return __webpack_require__(__webpack_require__.s = "./src/main/typescript/api/Jsf.ts");
/******/ })
/************************************************************************/
/******/ ({
/***/ "./src/main/typescript/api/Jsf.ts":
/*!****************************************!*\
!*** ./src/main/typescript/api/Jsf.ts ***!
\****************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nvar __spreadArrays = (this && this.__spreadArrays) || function () {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n};\r\nvar _a, _b, _c;\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\n///<reference path='./ApiInterfaces.ts'/>\r\n///<reference types='../../Types/Types'/>\r\nvar AjaxImpl_1 = __webpack_require__(/*! ../impl/AjaxImpl */ \"./src/main/typescript/impl/AjaxImpl.ts\");\r\nvar PushImpl_1 = __webpack_require__(/*! ../impl/PushImpl */ \"./src/main/typescript/impl/PushImpl.ts\");\r\nvar mf_impl = (_c = (_b = (_a = window) === null || _a === void 0 ? void 0 : _a.myfaces) === null || _b === void 0 ? void 0 : _b._impl, (_c !== null && _c !== void 0 ? _c : {}));\r\nvar jsf;\r\n(function (jsf) {\r\n \"use strict\";\r\n /*\r\n * Version of the implementation for the jsf.js.\r\n * <p />\r\n * as specified within the jsf specifications jsf.html:\r\n * <ul>\r\n * <li>left two digits major release number</li>\r\n * <li>middle two digits minor spec release number</li>\r\n * <li>right two digits bug release number</li>\r\n * </ul>\r\n * @constant\r\n */\r\n jsf.specversion = 220000;\r\n /**\r\n * Implementation version as specified within the jsf specification.\r\n * <p />\r\n * A number increased with every implementation version\r\n * and reset by moving to a new spec release number\r\n *\r\n * @constant\r\n */\r\n jsf.implversion = 0;\r\n /**\r\n * SeparatorChar as defined by UINamingContainer.getNamingContainerSeparatorChar()\r\n * @type {Char}\r\n */\r\n jsf.separatorchar = getSeparatorChar();\r\n /**\r\n * This method is responsible for the return of a given project stage as defined\r\n * by the jsf specification.\r\n * <p/>\r\n * Valid return values are:\r\n * <ul>\r\n * <li>&quot;Production&quot;</li>\r\n * <li>&quot;Development&quot;</li>\r\n * <li>&quot;SystemTest&quot;</li>\r\n * <li>&quot;UnitTest&quot;</li>\r\n * </li>\r\n *\r\n * @return {String} the current project state emitted by the server side method:\r\n * <i>javax.faces.application.Application.getProjectStage()</i>\r\n */\r\n function getProjectStage() {\r\n return AjaxImpl_1.Implementation.getProjectStage();\r\n }\r\n jsf.getProjectStage = getProjectStage;\r\n /**\r\n * collect and encode data for a given form element (must be of type form)\r\n * find the javax.faces.ViewState element and encode its value as well!\r\n * return a concatenated string of the encoded values!\r\n *\r\n * @throws an exception in case of the given element not being of type form!\r\n * https://issues.apache.org/jira/browse/MYFACES-2110\r\n */\r\n function getViewState(formElement) {\r\n return AjaxImpl_1.Implementation.getViewState(formElement);\r\n }\r\n jsf.getViewState = getViewState;\r\n /**\r\n * returns the window identifier for the given node / window\r\n * @param {optional String | DomNode} the node for which the client identifier has to be determined\r\n * @return the window identifier or null if none is found\r\n */\r\n function getClientWindow(rootNode) {\r\n return AjaxImpl_1.Implementation.getClientWindow(rootNode);\r\n }\r\n jsf.getClientWindow = getClientWindow;\r\n //private helper functions\r\n function getSeparatorChar() {\r\n return AjaxImpl_1.Implementation.getSeparatorChar();\r\n }\r\n //We hook the old namespace system into our npm system\r\n if (\"undefined\" == window.jsf) {\r\n window.jsf = jsf;\r\n }\r\n var ajax;\r\n (function (ajax) {\r\n \"use strict\";\r\n /**\r\n * this function has to send the ajax requests\r\n *\r\n * following requestInternal conditions must be met:\r\n * <ul>\r\n * <li> the requestInternal must be sent asynchronously! </li>\r\n * <li> the requestInternal must be a POST!!! requestInternal </li>\r\n * <li> the requestInternal url must be the form action attribute </li>\r\n * <li> all requests must be queued with a client side requestInternal queue to ensure the requestInternal ordering!</li>\r\n * </ul>\r\n *\r\n * @param {String|Node} element: any dom element no matter being it html or jsf, from which the event is emitted\r\n * @param {EVENT} event: any javascript event supported by that object\r\n * @param {Map} options : map of options being pushed into the ajax cycle\r\n */\r\n function request(element, event, options) {\r\n AjaxImpl_1.Implementation.request(element, event, options);\r\n //Implementation.getInstance().requestInternal(element, event, options);\r\n }\r\n ajax.request = request;\r\n /**\r\n * response handler\r\n * @param request the request object having triggered this response\r\n * @param context the request context\r\n *\r\n * TODO add info on what can be in the context\r\n */\r\n function response(request, context) {\r\n AjaxImpl_1.Implementation.response(request, context);\r\n }\r\n ajax.response = response;\r\n /**\r\n * Adds an error handler to our global error queue.\r\n * the error handler must be of the format <i>function errorListener(&lt;errorData&gt;)</i>\r\n * with errorData being of following format:\r\n * <ul>\r\n * <li> errorData.type : &quot;error&quot;</li>\r\n * <li> errorData.status : the error status message</li>\r\n * <li> errorData.serverErrorName : the server error name in case of a server error</li>\r\n * <li> errorData.serverErrorMessage : the server error message in case of a server error</li>\r\n * <li> errorData.source : the issuing source element which triggered the requestInternal </li>\r\n * <li> eventData.responseCode: the response code (aka http requestInternal response code, 401 etc...) </li>\r\n * <li> eventData.responseText: the requestInternal response text </li>\r\n * <li> eventData.responseXML: the requestInternal response xml </li>\r\n * </ul>\r\n *\r\n * @param {function} errorListener error handler must be of the format <i>function errorListener(&lt;errorData&gt;)</i>\r\n */\r\n function addOnError(errorFunc) {\r\n AjaxImpl_1.Implementation.addOnError(errorFunc);\r\n }\r\n ajax.addOnError = addOnError;\r\n /**\r\n * Adds a global event listener to the ajax event queue. The event listener must be a function\r\n * of following format: <i>function eventListener(&lt;eventData&gt;)</i>\r\n *\r\n * @param {function} eventListener event must be of the format <i>function eventListener(&lt;eventData&gt;)</i>\r\n */\r\n function addOnEvent(eventFunc) {\r\n AjaxImpl_1.Implementation.addOnEvent(eventFunc);\r\n }\r\n ajax.addOnEvent = addOnEvent;\r\n })(ajax = jsf.ajax || (jsf.ajax = {}));\r\n var util;\r\n (function (util) {\r\n /**\r\n * varargs function which executes a chain of code (functions or any other code)\r\n *\r\n * if any of the code returns false, the execution\r\n * is terminated prematurely skipping the rest of the code!\r\n *\r\n * @param {DomNode} source, the callee object\r\n * @param {Event} event, the event object of the callee event triggering this function\r\n * @param funcs ... arbitrary array of functions or strings\r\n * @returns true if the chain has succeeded false otherwise\r\n */\r\n function chain(source, event) {\r\n var funcs = [];\r\n for (var _i = 2; _i < arguments.length; _i++) {\r\n funcs[_i - 2] = arguments[_i];\r\n }\r\n return AjaxImpl_1.Implementation.chain.apply(AjaxImpl_1.Implementation, __spreadArrays([source, event], funcs));\r\n }\r\n util.chain = chain;\r\n })(util = jsf.util || (jsf.util = {}));\r\n var push;\r\n (function (push) {\r\n /**\r\n * @param {function} onopen The function to be invoked when the web socket is opened.\r\n * @param {function} onmessage The function to be invoked when a message is received.\r\n * @param {function} onclose The function to be invoked when the web socket is closed.\r\n * @param {boolean} autoconnect Whether or not to immediately open the socket. Defaults to <code>false</code>.\r\n */\r\n function init(socketClientId, uri, channel, onopen, onmessage, onclose, behaviorScripts, autoconnect) {\r\n PushImpl_1.PushImpl.init(socketClientId, uri, channel, onopen, onmessage, onclose, behaviorScripts, autoconnect);\r\n }\r\n push.init = init;\r\n /**\r\n * Open the web socket on the given channel.\r\n * @param {string} channel The name of the web socket channel.\r\n * @throws {Error} When channel is unknown.\r\n */\r\n function open(socketClientId) {\r\n PushImpl_1.PushImpl.open(socketClientId);\r\n }\r\n push.open = open;\r\n /**\r\n * Close the web socket on the given channel.\r\n * @param {string} channel The name of the web socket channel.\r\n * @throws {Error} When channel is unknown.\r\n */\r\n function close(socketClientId) {\r\n PushImpl_1.PushImpl.close(socketClientId);\r\n }\r\n push.close = close;\r\n })(push = jsf.push || (jsf.push = {}));\r\n})(jsf = exports.jsf || (exports.jsf = {}));\r\n//fullfill the window contract\r\nvar myfaces2;\r\n(function (myfaces2) {\r\n //legacy compatibility\r\n myfaces2._impl = mf_impl;\r\n /**\r\n * AB function similar to mojarra and Primefaces\r\n * not part of the spec but a convenience accesor method\r\n * Code provided by Thomas Andraschko\r\n *\r\n * @param source the event source\r\n * @param event the event\r\n * @param eventName event name for java.javax.faces.behavior.evemnt\r\n * @param execute execute list as passed down in jsf.ajax.request\r\n * @param render\r\n * @param options\r\n */\r\n function ab(source, event, eventName, execute, render, options) {\r\n if (options === void 0) { options = {}; }\r\n if (eventName) {\r\n options[\"javax.faces.behavior.event\"] = eventName;\r\n }\r\n if (execute) {\r\n options[\"execute\"] = execute;\r\n }\r\n if (render) {\r\n options[\"render\"] = render;\r\n }\r\n jsf.ajax.request(source, event, options);\r\n }\r\n myfaces2.ab = ab;\r\n})(myfaces2 = exports.myfaces2 || (exports.myfaces2 = {}));\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/main/typescript/api/Jsf.ts.js","sources":["webpack:///./src/main/typescript/api/Jsf.ts?4287"],"sourcesContent":["/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements.  See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License.  You may obtain a copy of the License at\r\n *\r\n *      http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\n///<reference path='./ApiInterfaces.ts'/>\r\n///<reference types='../../Types/Types'/>\r\n\r\nimport {Implementation} from \"../impl/AjaxImpl\";\r\nimport {PushImpl} from \"../impl/PushImpl\";\r\n\r\ndeclare let window: any;\r\ndeclare type Context = { [key: string]: any };\r\n\r\nlet mf_impl = window?.myfaces?._impl ?? {};\r\n\r\nexport module jsf {\r\n    \"use strict\";\r\n\r\n    /*\r\n     * Version of the implementation for the jsf.js.\r\n     * <p />\r\n     * as specified within the jsf specifications jsf.html:\r\n     * <ul>\r\n     * <li>left two digits major release number</li>\r\n     * <li>middle two digits minor spec release number</li>\r\n     * <li>right two digits bug release number</li>\r\n     * </ul>\r\n     * @constant\r\n     */\r\n    export var specversion = 220000;\r\n    /**\r\n     * Implementation version as specified within the jsf specification.\r\n     * <p />\r\n     * A number increased with every implementation version\r\n     * and reset by moving to a new spec release number\r\n     *\r\n     * @constant\r\n     */\r\n    export var implversion = 0;\r\n\r\n    /**\r\n     * SeparatorChar as defined by UINamingContainer.getNamingContainerSeparatorChar()\r\n     * @type {Char}\r\n     */\r\n    export var separatorchar = getSeparatorChar();\r\n\r\n    /**\r\n     * This method is responsible for the return of a given project stage as defined\r\n     * by the jsf specification.\r\n     * <p/>\r\n     * Valid return values are:\r\n     * <ul>\r\n     *     <li>&quot;Production&quot;</li>\r\n     *     <li>&quot;Development&quot;</li>\r\n     *     <li>&quot;SystemTest&quot;</li>\r\n     *     <li>&quot;UnitTest&quot;</li>\r\n     * </li>\r\n     *\r\n     * @return {String} the current project state emitted by the server side method:\r\n     * <i>javax.faces.application.Application.getProjectStage()</i>\r\n     */\r\n    export function getProjectStage(): string {\r\n        return Implementation.getProjectStage();\r\n    }\r\n\r\n    /**\r\n     * collect and encode data for a given form element (must be of type form)\r\n     * find the javax.faces.ViewState element and encode its value as well!\r\n     * return a concatenated string of the encoded values!\r\n     *\r\n     * @throws an exception in case of the given element not being of type form!\r\n     * https://issues.apache.org/jira/browse/MYFACES-2110\r\n     */\r\n    export function getViewState(formElement: Element | string): string {\r\n        return Implementation.getViewState(formElement);\r\n    }\r\n\r\n    /**\r\n     * returns the window identifier for the given node / window\r\n     * @param {optional String | DomNode}  the node for which the client identifier has to be determined\r\n     * @return the window identifier or null if none is found\r\n     */\r\n    export function getClientWindow(rootNode?: Element | string): string {\r\n        return Implementation.getClientWindow(rootNode);\r\n    }\r\n\r\n    //private helper functions\r\n    function getSeparatorChar() {\r\n        return Implementation.getSeparatorChar();\r\n    }\r\n\r\n    //We hook the old namespace system into our npm system\r\n    if (\"undefined\" == window.jsf) {\r\n        window.jsf = jsf;\r\n    }\r\n\r\n    export module ajax {\r\n        \"use strict\";\r\n\r\n        /**\r\n         * this function has to send the ajax requests\r\n         *\r\n         * following requestInternal conditions must be met:\r\n         * <ul>\r\n         *  <li> the requestInternal must be sent asynchronously! </li>\r\n         *  <li> the requestInternal must be a POST!!! requestInternal </li>\r\n         *  <li> the requestInternal url must be the form action attribute </li>\r\n         *  <li> all requests must be queued with a client side requestInternal queue to ensure the requestInternal ordering!</li>\r\n         * </ul>\r\n         *\r\n         * @param {String|Node} element: any dom element no matter being it html or jsf, from which the event is emitted\r\n         * @param {EVENT} event: any javascript event supported by that object\r\n         * @param {Map} options : map of options being pushed into the ajax cycle\r\n         */\r\n        export function request(element: Element, event?: Event, options?: Context) {\r\n            Implementation.request(element, event, options)\r\n            //Implementation.getInstance().requestInternal(element, event, options);\r\n        }\r\n\r\n        /**\r\n         * response handler\r\n         * @param request the request object having triggered this response\r\n         * @param context the request context\r\n         *\r\n         * TODO add info on what can be in the context\r\n         */\r\n        export function response(request: XMLHttpRequest, context?: Context) {\r\n            Implementation.response(request, context);\r\n        }\r\n\r\n        /**\r\n         * Adds an error handler to our global error queue.\r\n         * the error handler must be of the format <i>function errorListener(&lt;errorData&gt;)</i>\r\n         * with errorData being of following format:\r\n         * <ul>\r\n         *     <li> errorData.type : &quot;error&quot;</li>\r\n         *     <li> errorData.status : the error status message</li>\r\n         *     <li> errorData.serverErrorName : the server error name in case of a server error</li>\r\n         *     <li> errorData.serverErrorMessage : the server error message in case of a server error</li>\r\n         *     <li> errorData.source  : the issuing source element which triggered the requestInternal </li>\r\n         *     <li> eventData.responseCode: the response code (aka http requestInternal response code, 401 etc...) </li>\r\n         *     <li> eventData.responseText: the requestInternal response text </li>\r\n         *     <li> eventData.responseXML: the requestInternal response xml </li>\r\n         * </ul>\r\n         *\r\n         * @param {function} errorListener error handler must be of the format <i>function errorListener(&lt;errorData&gt;)</i>\r\n         */\r\n        export function addOnError(errorFunc: (data: _apiInterfaces.ErrorData) => void) {\r\n            Implementation.addOnError(<any>errorFunc);\r\n        }\r\n\r\n        /**\r\n         * Adds a global event listener to the ajax event queue. The event listener must be a function\r\n         * of following format: <i>function eventListener(&lt;eventData&gt;)</i>\r\n         *\r\n         * @param {function} eventListener event must be of the format <i>function eventListener(&lt;eventData&gt;)</i>\r\n         */\r\n        export function addOnEvent(eventFunc: (data: _apiInterfaces.EventData) => void) {\r\n            Implementation.addOnEvent(<any>eventFunc);\r\n        }\r\n    }\r\n\r\n    export module util {\r\n\r\n        /**\r\n         * varargs function which executes a chain of code (functions or any other code)\r\n         *\r\n         * if any of the code returns false, the execution\r\n         * is terminated prematurely skipping the rest of the code!\r\n         *\r\n         * @param {DomNode} source, the callee object\r\n         * @param {Event} event, the event object of the callee event triggering this function\r\n         * @param funcs ... arbitrary array of functions or strings\r\n         * @returns true if the chain has succeeded false otherwise\r\n         */\r\n        export function chain(source, event, ...funcs: Array<Function | string>): boolean {\r\n            return Implementation.chain(source, event, ...funcs);\r\n        }\r\n    }\r\n\r\n    export module push {\r\n        /**\r\n         * @param {function} onopen The function to be invoked when the web socket is opened.\r\n         * @param {function} onmessage The function to be invoked when a message is received.\r\n         * @param {function} onclose The function to be invoked when the web socket is closed.\r\n         * @param {boolean} autoconnect Whether or not to immediately open the socket. Defaults to <code>false</code>.\r\n         */\r\n        export function init(socketClientId: string,\r\n                    uri: string,\r\n                    channel: string,\r\n                    onopen: Function,\r\n                    onmessage: Function,\r\n                    onclose: Function,\r\n                    behaviorScripts: any,\r\n                    autoconnect: boolean) {\r\n            PushImpl.init(socketClientId, uri, channel, onopen, onmessage, onclose, behaviorScripts, autoconnect);\r\n        }\r\n\r\n        /**\r\n         * Open the web socket on the given channel.\r\n         * @param {string} channel The name of the web socket channel.\r\n         * @throws {Error} When channel is unknown.\r\n         */\r\n        export function open(socketClientId: string) {\r\n            PushImpl.open(socketClientId);\r\n        }\r\n\r\n        /**\r\n         * Close the web socket on the given channel.\r\n         * @param {string} channel The name of the web socket channel.\r\n         * @throws {Error} When channel is unknown.\r\n         */\r\n        export function close(socketClientId: string) {\r\n            PushImpl.close(socketClientId);\r\n        }\r\n\r\n    }\r\n\r\n}\r\n\r\n\r\n\r\n//fullfill the window contract\r\nexport module myfaces2 {\r\n\r\n    //legacy compatibility\r\n    export var _impl = mf_impl;\r\n\r\n    /**\r\n     * AB function similar to mojarra and Primefaces\r\n     * not part of the spec but a convenience accesor method\r\n     * Code provided by Thomas Andraschko\r\n     *\r\n     * @param source the event source\r\n     * @param event the event\r\n     * @param eventName event name for java.javax.faces.behavior.evemnt\r\n     * @param execute execute list as passed down in jsf.ajax.request\r\n     * @param render\r\n     * @param options\r\n     */\r\n    export function ab(source: Element, event: Event, eventName: string, execute: string, render: string, options: Context = {}) {\r\n        if (eventName) {\r\n            options[\"javax.faces.behavior.event\"] = eventName;\r\n        }\r\n        if (execute) {\r\n            options[\"execute\"] = execute;\r\n        }\r\n        if (render) {\r\n            options[\"render\"] = render;\r\n        }\r\n\r\n        jsf.ajax.request(source, event, options);\r\n    }\r\n}\r\n\r\n\r\n"],"mappings":";AAAA;;;;;;;;;;;;;;AAcA;;;;;;;;;;AAEA;AACA;AAEA;AACA;AAKA;AAEA;AAAA;AACA;AAEA;;;;;;;;;;AAUA;AACA;AACA;;;;;;;AAOA;AACA;AAEA;;;AAGA;AACA;AAEA;;;;;;;;;;;;;;AAcA;AACA;AACA;AACA;AAFA;AAIA;;;;;;;AAOA;AACA;AACA;AACA;AAFA;AAIA;;;;AAIA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAAA;AACA;AAEA;;;;;;;;;;;;;;AAcA;AACA;AACA;AACA;AACA;AAHA;AAKA;;;;;;AAMA;AACA;AACA;AACA;AAFA;AAIA;;;;;;;;;;;;;;;;AAgBA;AACA;AACA;AACA;AAFA;AAIA;;;;;AAKA;AACA;AACA;AACA;AAFA;AAGA;AAEA;AAAA;AAEA;;;;;;;;;;AAUA;AACA;AAAA;AAAA;AAAA;;AACA;AACA;AAFA;AAGA;AAEA;AAAA;AACA;;;;;AAKA;AACA;AAQA;AACA;AATA;AAWA;;;;AAIA;AACA;AACA;AACA;AAFA;AAIA;;;;AAIA;AACA;AACA;AACA;AAFA;AAIA;AAEA;AAIA;AACA;AAAA;AAEA;AACA;AAEA;;;;;;;;;;;AAWA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAZA;AAaA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/main/typescript/api/Jsf.ts\n");
/***/ }),
/***/ "./src/main/typescript/api/myfaces.ts":
/*!********************************************!*\
!*** ./src/main/typescript/api/myfaces.ts ***!
\********************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar myfaces;\r\n(function (myfaces) {\r\n var ConfigHolder = /** @class */ (function () {\r\n function ConfigHolder() {\r\n this.projectStage = null;\r\n this.separator = null;\r\n }\r\n return ConfigHolder;\r\n }());\r\n myfaces.ConfigHolder = ConfigHolder;\r\n myfaces.config = new ConfigHolder();\r\n //if (window && \"undefined\" == typeof window.myfaces) {\r\n // window.myfaces = myfaces;\r\n //}\r\n})(myfaces = exports.myfaces || (exports.myfaces = {}));\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbWFpbi90eXBlc2NyaXB0L2FwaS9teWZhY2VzLnRzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vLy4vc3JjL21haW4vdHlwZXNjcmlwdC9hcGkvbXlmYWNlcy50cz82MjlmIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIExpY2Vuc2VkIHRvIHRoZSBBcGFjaGUgU29mdHdhcmUgRm91bmRhdGlvbiAoQVNGKSB1bmRlciBvbmUgb3IgbW9yZVxyXG4gKiBjb250cmlidXRvciBsaWNlbnNlIGFncmVlbWVudHMuICBTZWUgdGhlIE5PVElDRSBmaWxlIGRpc3RyaWJ1dGVkIHdpdGhcclxuICogdGhpcyB3b3JrIGZvciBhZGRpdGlvbmFsIGluZm9ybWF0aW9uIHJlZ2FyZGluZyBjb3B5cmlnaHQgb3duZXJzaGlwLlxyXG4gKiBUaGUgQVNGIGxpY2Vuc2VzIHRoaXMgZmlsZSB0byB5b3UgdW5kZXIgdGhlIEFwYWNoZSBMaWNlbnNlLCBWZXJzaW9uIDIuMFxyXG4gKiAodGhlIFwiTGljZW5zZVwiKTsgeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoXHJcbiAqIHRoZSBMaWNlbnNlLiAgWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XHJcbiAqXHJcbiAqICAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXHJcbiAqXHJcbiAqIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcclxuICogZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIEJBU0lTLFxyXG4gKiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cclxuICogU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxyXG4gKiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cclxuICovXHJcblxyXG4vKipcclxuICogaW50ZXJuYWwgbXlmYWNlcyBjb25maWcgb3ZlcnJpZGUgcGFyYW1zXHJcbiAqL1xyXG5kZWNsYXJlIHZhciB3aW5kb3c6IGFueTtcclxuZXhwb3J0IG1vZHVsZSBteWZhY2VzIHtcclxuXHJcbiAgICBleHBvcnQgY2xhc3MgQ29uZmlnSG9sZGVyIHtcclxuICAgICAgICBwcm9qZWN0U3RhZ2U6IHN0cmluZyA9IG51bGw7XHJcbiAgICAgICAgc2VwYXJhdG9yOiBzdHJpbmcgPSBudWxsO1xyXG4gICAgfVxyXG5cclxuICAgIGV4cG9ydCB2YXIgY29uZmlnID0gbmV3IENvbmZpZ0hvbGRlcigpO1xyXG5cclxuICAgIC8vaWYgKHdpbmRvdyAmJiBcInVuZGVmaW5lZFwiID09IHR5cGVvZiB3aW5kb3cubXlmYWNlcykge1xyXG4gICAgLy8gICAgd2luZG93Lm15ZmFjZXMgPSBteWZhY2VzO1xyXG4gICAgLy99XHJcbn1cclxuIl0sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7Ozs7O0FBY0E7O0FBTUE7QUFBQTtBQUVBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUFBO0FBSEE7QUFLQTtBQUVBO0FBQ0E7QUFDQTtBQUNBOyIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/main/typescript/api/myfaces.ts\n");
/***/ }),
/***/ "./src/main/typescript/ext/monadish/DomQuery.ts":
/*!******************************************************!*\
!*** ./src/main/typescript/ext/monadish/DomQuery.ts ***!
\******************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nvar __extends = (this && this.__extends) || (function () {\r\n var extendStatics = function (d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n };\r\n return function (d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n };\r\n})();\r\nvar __spreadArrays = (this && this.__spreadArrays) || function () {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n};\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar Monad_1 = __webpack_require__(/*! ./Monad */ \"./src/main/typescript/ext/monadish/Monad.ts\");\r\nvar Stream_1 = __webpack_require__(/*! ./Stream */ \"./src/main/typescript/ext/monadish/Stream.ts\");\r\nvar Lang_1 = __webpack_require__(/*! ./Lang */ \"./src/main/typescript/ext/monadish/Lang.ts\");\r\nvar trim = Lang_1.Lang.trim;\r\nvar objToArray = Lang_1.Lang.objToArray;\r\nvar isString = Lang_1.Lang.isString;\r\nvar equalsIgnoreCase = Lang_1.Lang.equalsIgnoreCase;\r\n// @ts-ignore supression needed here due to fromnullable\r\nvar ElementAttribute = /** @class */ (function (_super) {\r\n __extends(ElementAttribute, _super);\r\n function ElementAttribute(element, name, defaultVal) {\r\n if (defaultVal === void 0) { defaultVal = null; }\r\n var _this = _super.call(this, element, name) || this;\r\n _this.element = element;\r\n _this.name = name;\r\n _this.defaultVal = defaultVal;\r\n return _this;\r\n }\r\n Object.defineProperty(ElementAttribute.prototype, \"value\", {\r\n get: function () {\r\n var _a;\r\n var val = (_a = this.element.get(0)).orElse.apply(_a, []).values;\r\n if (!val.length) {\r\n return this.defaultVal;\r\n }\r\n return val[0].getAttribute(this.name);\r\n },\r\n set: function (value) {\r\n var _a;\r\n var val = (_a = this.element.get(0)).orElse.apply(_a, []).values;\r\n for (var cnt = 0; cnt < val.length; cnt++) {\r\n val[cnt].setAttribute(this.name, value);\r\n }\r\n val[0].setAttribute(this.name, value);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n ElementAttribute.prototype.getClass = function () {\r\n return ElementAttribute;\r\n };\r\n ElementAttribute.fromNullable = function (value, valueKey) {\r\n if (valueKey === void 0) { valueKey = \"value\"; }\r\n return new ElementAttribute(value, valueKey);\r\n };\r\n return ElementAttribute;\r\n}(Monad_1.ValueEmbedder));\r\nexports.ElementAttribute = ElementAttribute;\r\n/**\r\n * small helper for the specialized jsf case\r\n * @param src\r\n * @constructor\r\n */\r\nvar DEFAULT_JSF_WHITELIST = function (src) {\r\n return (src.indexOf(\"ln=scripts\") == -1 &&\r\n src.indexOf(\"ln=javax.faces\") == -1) ||\r\n (src.indexOf(\"/jsf.js\") == -1 &&\r\n src.indexOf(\"/jsf-uncompressed.js\") == -1);\r\n};\r\n/**\r\n * Monadic DomNode representation, ala jquery\r\n * This is a thin wrapper over querySelectorAll\r\n * to get slim monadic support\r\n * to reduce implementation code on the users side.\r\n * This is vital for frameworks which want to rely on\r\n * plain dom but still do not want to lose\r\n * the reduced code footprint of querying dom trees and traversing\r\n * by using functional patterns.\r\n *\r\n * Also a few convenience methods are added to reduce\r\n * the code footprint of standard dom processing\r\n * operations like eval\r\n *\r\n * TODO add jquery fallback support, since it is supported\r\n * in most older systems\r\n * Note parts of this code still stem from the Dom.js I have written 10 years\r\n * ago, those parts look a little bit ancient and will be replaced over time.\r\n *\r\n */\r\nvar DomQuery = /** @class */ (function () {\r\n function DomQuery() {\r\n var _a;\r\n var rootNode = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n rootNode[_i] = arguments[_i];\r\n }\r\n this.rootNode = [];\r\n this.pos = -1;\r\n this._limits = -1;\r\n if (Monad_1.Optional.fromNullable(rootNode).isAbsent() || !rootNode.length) {\r\n return;\r\n }\r\n else {\r\n //we need to flatten out the arrays\r\n for (var cnt = 0; cnt < rootNode.length; cnt++) {\r\n if (isString(rootNode[cnt])) {\r\n var foundElement = DomQuery.querySelectorAll(rootNode[cnt]);\r\n if (!foundElement.isAbsent()) {\r\n rootNode.push.apply(rootNode, foundElement.values);\r\n }\r\n }\r\n else if (rootNode[cnt] instanceof DomQuery) {\r\n (_a = this.rootNode).push.apply(_a, rootNode[cnt].values);\r\n }\r\n else {\r\n this.rootNode.push(rootNode[cnt]);\r\n }\r\n }\r\n }\r\n }\r\n Object.defineProperty(DomQuery.prototype, \"value\", {\r\n /**\r\n * returns the first element\r\n */\r\n get: function () {\r\n return this.getAsElem(0);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DomQuery.prototype, \"values\", {\r\n get: function () {\r\n return this.allElems();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DomQuery.prototype, \"id\", {\r\n /**\r\n * returns the id of the first element\r\n */\r\n get: function () {\r\n return new ElementAttribute(this.get(0), \"id\");\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DomQuery.prototype, \"length\", {\r\n /**\r\n * length of the entire query set\r\n */\r\n get: function () {\r\n return this.rootNode.length;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DomQuery.prototype, \"tagName\", {\r\n /**\r\n * convenience method for tagName\r\n */\r\n get: function () {\r\n return this.getAsElem(0).getIf(\"tagName\");\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DomQuery.prototype, \"nodeName\", {\r\n /**\r\n * convenience method for nodeName\r\n */\r\n get: function () {\r\n return this.getAsElem(0).getIf(\"nodeName\");\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n DomQuery.prototype.isTag = function (tagName) {\r\n return !this.isAbsent()\r\n && (this.nodeName.orElse(\"__none___\")\r\n .value.toLowerCase() == tagName.toLowerCase()\r\n || this.tagName.orElse(\"__none___\")\r\n .value.toLowerCase() == tagName.toLowerCase());\r\n };\r\n Object.defineProperty(DomQuery.prototype, \"type\", {\r\n /**\r\n * convenience property for type\r\n *\r\n * returns null in case of no type existing otherwise\r\n * the type of the first element\r\n */\r\n get: function () {\r\n return this.getAsElem(0).getIf(\"type\");\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DomQuery.prototype, \"name\", {\r\n /**\r\n * convenience property for name\r\n *\r\n * returns null in case of no type existing otherwise\r\n * the name of the first element\r\n */\r\n get: function () {\r\n return new Monad_1.ValueEmbedder(this.getAsElem(0).value, \"name\");\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DomQuery.prototype, \"inputValue\", {\r\n /**\r\n * convenience property for value\r\n *\r\n * returns null in case of no type existing otherwise\r\n * the value of the first element\r\n */\r\n get: function () {\r\n if (this.getAsElem(0).getIf(\"value\").isPresent()) {\r\n return new Monad_1.ValueEmbedder(this.getAsElem(0).value);\r\n }\r\n else {\r\n return Monad_1.ValueEmbedder.absent;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DomQuery.prototype, \"checked\", {\r\n get: function () {\r\n return Stream_1.Stream.of.apply(Stream_1.Stream, this.values).allMatch(function (el) { return !!el.checked; });\r\n },\r\n set: function (newChecked) {\r\n this.eachElem(function (el) { return el.checked = newChecked; });\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DomQuery.prototype, \"elements\", {\r\n get: function () {\r\n var _this = this;\r\n var elements = this.stream.flatMap(function (item) {\r\n var formElement = item.value.value;\r\n return new Stream_1.Stream(formElement.elements ? objToArray(formElement.elements) : []);\r\n }).filter(function (item) { return !!item; }).collect(new DomQueryCollector());\r\n return elements\r\n .orElseLazy(function () { return _this.querySelectorAll(\"input, select, textarea, fieldset\"); });\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DomQuery.prototype, \"disabled\", {\r\n /**\r\n * todo align this api with the rest of the apis\r\n */\r\n get: function () {\r\n return this.attr(\"disabled\").isPresent();\r\n },\r\n set: function (disabled) {\r\n // this.attr(\"disabled\").value = disabled + \"\";\r\n if (!disabled) {\r\n this.removeAttribute(\"disabled\");\r\n }\r\n else {\r\n this.attr(\"disabled\").value = \"disabled\";\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n DomQuery.prototype.removeAttribute = function (name) {\r\n this.eachElem(function (item) { return item.removeAttribute(name); });\r\n };\r\n Object.defineProperty(DomQuery.prototype, \"childNodes\", {\r\n get: function () {\r\n var childNodeArr = [];\r\n this.eachElem(function (item) {\r\n childNodeArr = childNodeArr.concat(objToArray(item.childNodes));\r\n });\r\n return new (DomQuery.bind.apply(DomQuery, __spreadArrays([void 0], childNodeArr)))();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DomQuery.prototype, \"stream\", {\r\n /**\r\n * binding into stream\r\n */\r\n get: function () {\r\n return new (Stream_1.Stream.bind.apply(Stream_1.Stream, __spreadArrays([void 0], this.asArray)))();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DomQuery.prototype, \"lazyStream\", {\r\n /**\r\n * fetches a lazy stream representation\r\n * lazy should be applied if you have some filters etc\r\n * in between, this can reduce the number of post filter operations\r\n * and ram usage\r\n * significantly because the operations are done lazily and stop\r\n * once they hit a dead end.\r\n */\r\n get: function () {\r\n return Stream_1.LazyStream.ofStreamDataSource(this);\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DomQuery.prototype, \"asArray\", {\r\n get: function () {\r\n var ret = [];\r\n this.each(function (item) {\r\n ret.push(item);\r\n });\r\n return ret;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * easy query selector all producer\r\n *\r\n * @param selector the selector\r\n * @returns a results dom query object\r\n */\r\n DomQuery.querySelectorAll = function (selector) {\r\n return new DomQuery(document).querySelectorAll(selector);\r\n };\r\n /**\r\n * byId producer\r\n *\r\n * @param selector id\r\n * @return a DomQuery containing the found elements\r\n */\r\n DomQuery.byId = function (selector) {\r\n if (isString(selector)) {\r\n return new DomQuery(document).byId(selector);\r\n }\r\n else {\r\n return new DomQuery(selector);\r\n }\r\n };\r\n /**\r\n * byTagName producer\r\n *\r\n * @param selector name\r\n * @return a DomQuery containing the found elements\r\n */\r\n DomQuery.byTagName = function (selector) {\r\n if (isString(selector)) {\r\n return new DomQuery(document).byTagName(selector);\r\n }\r\n else {\r\n return new DomQuery(selector);\r\n }\r\n };\r\n DomQuery.globalEval = function (code, nonce) {\r\n return new DomQuery(document).globalEval(code, nonce);\r\n };\r\n /**\r\n * builds the ie nodes properly in a placeholder\r\n * and bypasses a non script insert bug that way\r\n * @param markup the marku code\r\n */\r\n DomQuery.fromMarkup = function (markup) {\r\n //https://developer.mozilla.org/de/docs/Web/API/DOMParser license creative commons\r\n var doc = document.implementation.createHTMLDocument(\"\");\r\n markup = trim(markup);\r\n var lowerMarkup = markup.toLowerCase();\r\n if (lowerMarkup.indexOf('<!doctype') != -1 ||\r\n lowerMarkup.indexOf('<html') != -1 ||\r\n lowerMarkup.indexOf('<head') != -1 || //TODO proper regexps here to avoid embedded tags with same element names to be triggered\r\n lowerMarkup.indexOf('<body') != -1) {\r\n doc.documentElement.innerHTML = markup;\r\n return new DomQuery(doc.documentElement);\r\n }\r\n else {\r\n var startsWithTag = function (str, tagName) {\r\n var tag1 = [\"<\", tagName, \">\"].join(\"\");\r\n var tag2 = [\"<\", tagName, \" \"].join(\"\");\r\n return (str.indexOf(tag1) == 0) || (str.indexOf(tag2) == 0);\r\n };\r\n var dummyPlaceHolder = new DomQuery(document.createElement(\"div\"));\r\n //table needs special treatment due to the browsers auto creation\r\n if (startsWithTag(lowerMarkup, \"thead\") || startsWithTag(lowerMarkup, \"tbody\")) {\r\n dummyPlaceHolder.html(\"<table>\" + markup + \"</table>\");\r\n return dummyPlaceHolder.querySelectorAll(\"table\").get(0).childNodes.detach();\r\n }\r\n else if (startsWithTag(lowerMarkup, \"tfoot\")) {\r\n dummyPlaceHolder.html(\"<table><thead></thead><tbody><tbody\" + markup + \"</table>\");\r\n return dummyPlaceHolder.querySelectorAll(\"table\").get(2).childNodes.detach();\r\n }\r\n else if (startsWithTag(lowerMarkup, \"tr\")) {\r\n dummyPlaceHolder.html(\"<table><tbody>\" + markup + \"</tbody></table>\");\r\n return dummyPlaceHolder.querySelectorAll(\"tbody\").get(0).childNodes.detach();\r\n }\r\n else if (startsWithTag(lowerMarkup, \"td\")) {\r\n dummyPlaceHolder.html(\"<table><tbody><tr>\" + markup + \"</tr></tbody></table>\");\r\n return dummyPlaceHolder.querySelectorAll(\"tr\").get(0).childNodes.detach();\r\n }\r\n dummyPlaceHolder.html(markup);\r\n return dummyPlaceHolder.childNodes.detach();\r\n }\r\n };\r\n /**\r\n * returns the nth element as domquery\r\n * from the internal elements\r\n * note if you try to reach a non existing element position\r\n * you will get back an absent entry\r\n *\r\n * @param index the nth index\r\n */\r\n DomQuery.prototype.get = function (index) {\r\n return (index < this.rootNode.length) ? new DomQuery(this.rootNode[index]) : DomQuery.absent;\r\n };\r\n /**\r\n * returns the nth element as optional of an Element object\r\n * @param index the number from the index\r\n * @param defaults the default value if the index is overrun default Optional.absent\r\n */\r\n DomQuery.prototype.getAsElem = function (index, defaults) {\r\n if (defaults === void 0) { defaults = Monad_1.Optional.absent; }\r\n return (index < this.rootNode.length) ? Monad_1.Optional.fromNullable(this.rootNode[index]) : defaults;\r\n };\r\n /**\r\n * returns the value array< of all elements\r\n */\r\n DomQuery.prototype.allElems = function () {\r\n return this.rootNode;\r\n };\r\n /**\r\n * absent no values reached?\r\n */\r\n DomQuery.prototype.isAbsent = function () {\r\n return this.length == 0;\r\n };\r\n /**\r\n * should make the code clearer\r\n * note if you pass a function\r\n * this refers to the active dopmquery object\r\n */\r\n DomQuery.prototype.isPresent = function (presentRunnable) {\r\n var absent = this.isAbsent();\r\n if (!absent && presentRunnable) {\r\n presentRunnable.call(this, this);\r\n }\r\n return !absent;\r\n };\r\n /**\r\n * should make the code clearer\r\n * note if you pass a function\r\n * this refers to the active dopmquery object\r\n *\r\n *\r\n * @param presentRunnable\r\n */\r\n DomQuery.prototype.ifPresentLazy = function (presentRunnable) {\r\n if (presentRunnable === void 0) { presentRunnable = function () {\r\n }; }\r\n this.isPresent.call(this, presentRunnable);\r\n return this;\r\n };\r\n /**\r\n * remove all affected nodes from this query object from the dom tree\r\n */\r\n DomQuery.prototype.delete = function () {\r\n this.eachElem(function (node) {\r\n if (node.parentNode) {\r\n node.parentNode.removeChild(node);\r\n }\r\n });\r\n };\r\n /**\r\n * query selector all on the existing dom query object\r\n *\r\n * @param selector the standard selector\r\n * @return a DomQuery with the results\r\n */\r\n DomQuery.prototype.querySelectorAll = function (selector) {\r\n var _a, _b, _c;\r\n if (!((_b = (_a = this) === null || _a === void 0 ? void 0 : _a.rootNode) === null || _b === void 0 ? void 0 : _b.length)) {\r\n return this;\r\n }\r\n var nodes = [];\r\n for (var cnt = 0; cnt < this.rootNode.length; cnt++) {\r\n if (!((_c = this.rootNode[cnt]) === null || _c === void 0 ? void 0 : _c.querySelectorAll)) {\r\n continue;\r\n }\r\n var res = this.rootNode[cnt].querySelectorAll(selector);\r\n nodes = nodes.concat(objToArray(res));\r\n }\r\n return new (DomQuery.bind.apply(DomQuery, __spreadArrays([void 0], nodes)))();\r\n };\r\n /**\r\n * core byId method\r\n * @param id the id to search for\r\n * @param includeRoot also match the root element?\r\n */\r\n DomQuery.prototype.byId = function (id, includeRoot) {\r\n var _a;\r\n var res = [];\r\n for (var cnt = 0; includeRoot && cnt < this.rootNode.length; cnt++) {\r\n if (((_a = this.rootNode[cnt]) === null || _a === void 0 ? void 0 : _a.id) == id) {\r\n res.push(new DomQuery(this.rootNode[cnt]));\r\n }\r\n }\r\n //for some strange kind of reason the # selector fails\r\n //on hidden elements we use the attributes match selector\r\n //that works\r\n res = res.concat(this.querySelectorAll(\"[id=\\\"\" + id + \"\\\"]\"));\r\n return new (DomQuery.bind.apply(DomQuery, __spreadArrays([void 0], res)))();\r\n };\r\n /**\r\n * same as byId just for the tag name\r\n * @param tagName\r\n * @param includeRoot\r\n */\r\n DomQuery.prototype.byTagName = function (tagName, includeRoot) {\r\n var _a;\r\n var res = [];\r\n for (var cnt = 0; includeRoot && cnt < this.rootNode.length; cnt++) {\r\n if (((_a = this.rootNode[cnt]) === null || _a === void 0 ? void 0 : _a.tagName) == tagName) {\r\n res.push(new DomQuery(this.rootNode[cnt]));\r\n }\r\n }\r\n res = res.concat(this.querySelectorAll(tagName));\r\n return new (DomQuery.bind.apply(DomQuery, __spreadArrays([void 0], res)))();\r\n };\r\n /**\r\n * attr accessor, usage myQuery.attr(\"class\").value = \"bla\"\r\n * or let value myQuery.attr(\"class\").value\r\n * @param attr the attribute to set\r\n * @param defaultValue the default value in case nothing is presented (defaults to null)\r\n */\r\n DomQuery.prototype.attr = function (attr, defaultValue) {\r\n if (defaultValue === void 0) { defaultValue = null; }\r\n return new ElementAttribute(this, attr, defaultValue);\r\n };\r\n /**\r\n * hasclass, checks for an existing class in the class attributes\r\n *\r\n * @param clazz the class to search for\r\n */\r\n DomQuery.prototype.hasClass = function (clazz) {\r\n var hasIt = false;\r\n this.each(function (item) {\r\n var oldClass = item.attr(\"class\").value || \"\";\r\n if (oldClass.toLowerCase().indexOf(clazz.toLowerCase()) == -1) {\r\n return;\r\n }\r\n else {\r\n var oldClasses = oldClass.split(/\\s+/gi);\r\n var found = false;\r\n for (var cnt = 0; cnt < oldClasses.length && !found; cnt++) {\r\n found = oldClasses[cnt].toLowerCase() == clazz.toLowerCase();\r\n }\r\n hasIt = hasIt || found;\r\n if (hasIt) {\r\n return false;\r\n }\r\n }\r\n });\r\n return hasIt;\r\n };\r\n /**\r\n * appends a class string if not already in the element(s)\r\n *\r\n * @param clazz the style class to append\r\n */\r\n DomQuery.prototype.addClass = function (clazz) {\r\n var _this = this;\r\n this.each(function (item) {\r\n var oldClass = item.attr(\"class\").value || \"\";\r\n if (!_this.hasClass(clazz)) {\r\n item.attr(\"class\").value = trim(oldClass + \" \" + clazz);\r\n return;\r\n }\r\n });\r\n return this;\r\n };\r\n /**\r\n * remove the style class if in the class definitions\r\n *\r\n * @param clazz\r\n */\r\n DomQuery.prototype.removeClass = function (clazz) {\r\n var _this = this;\r\n this.each(function (item) {\r\n if (_this.hasClass(clazz)) {\r\n var oldClass = item.attr(\"class\").value || \"\";\r\n var newClasses = [];\r\n var oldClasses = oldClass.split(/\\s+/gi);\r\n for (var cnt = 0; cnt < oldClasses.length; cnt++) {\r\n if (oldClasses[cnt].toLowerCase() != clazz.toLowerCase()) {\r\n newClasses.push(oldClasses[cnt]);\r\n }\r\n }\r\n item.attr(\"class\").value = newClasses.join(\" \");\r\n }\r\n });\r\n return this;\r\n };\r\n /**\r\n * checks whether we have a multipart element in our children\r\n */\r\n DomQuery.prototype.isMultipartCandidate = function () {\r\n return this.querySelectorAll(\"input[type='file']\").firstElem().isPresent();\r\n };\r\n /**\r\n * innerHtml equivalkent\r\n * equivalent to jqueries html\r\n * as setter the html is set and the\r\n * DomQuery is given back\r\n * as getter the html string is returned\r\n *\r\n * @param inval\r\n */\r\n DomQuery.prototype.html = function (inval) {\r\n if (Monad_1.Optional.fromNullable(inval).isAbsent()) {\r\n return this.isPresent() ? Monad_1.Optional.fromNullable(this.innerHtml) : Monad_1.Optional.absent;\r\n }\r\n this.innerHtml = inval;\r\n return this;\r\n };\r\n Object.defineProperty(DomQuery.prototype, \"innerHtml\", {\r\n get: function () {\r\n var retArr = [];\r\n this.eachElem(function (elem) { return retArr.push(elem.innerHTML); });\r\n return retArr.join(\"\");\r\n },\r\n set: function (inVal) {\r\n this.eachElem(function (elem) { return elem.innerHTML = inVal; });\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n //source: https://developer.mozilla.org/en-US/docs/Web/API/Element/matches\r\n //code snippet license: https://creativecommons.org/licenses/by-sa/2.5/\r\n DomQuery.prototype._mozMatchesSelector = function (toMatch, selector) {\r\n var prot = toMatch;\r\n var matchesSelector = prot.matchesSelector ||\r\n prot.mozMatchesSelector ||\r\n prot.msMatchesSelector ||\r\n prot.oMatchesSelector ||\r\n prot.webkitMatchesSelector ||\r\n function (s) {\r\n var matches = (document || window.ownerDocument).querySelectorAll(s), i = matches.length;\r\n while (--i >= 0 && matches.item(i) !== toMatch) {\r\n }\r\n return i > -1;\r\n };\r\n return matchesSelector.call(toMatch, selector);\r\n };\r\n /**\r\n * filters the current dom query elements\r\n * upon a given selector\r\n *\r\n * @param selector\r\n */\r\n DomQuery.prototype.filterSelector = function (selector) {\r\n var _this = this;\r\n var matched = [];\r\n this.eachElem(function (item) {\r\n if (_this._mozMatchesSelector(item, selector)) {\r\n matched.push(item);\r\n }\r\n });\r\n return new (DomQuery.bind.apply(DomQuery, __spreadArrays([void 0], matched)))();\r\n };\r\n DomQuery.prototype.matchesSelector = function (selector) {\r\n var _this = this;\r\n this.eachElem(function (item) {\r\n if (!_this._mozMatchesSelector(item, selector)) {\r\n return false;\r\n }\r\n });\r\n return true;\r\n };\r\n /**\r\n * easy node traversal, you can pass\r\n * a set of node selectors which are joined as direct childs\r\n *\r\n * not the rootnodes are not in the getIf, those are always the child nodes\r\n *\r\n * @param nodeSelector\r\n */\r\n DomQuery.prototype.getIf = function () {\r\n var nodeSelector = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n nodeSelector[_i] = arguments[_i];\r\n }\r\n var selectorStage = this.childNodes;\r\n for (var cnt = 0; cnt < nodeSelector.length; cnt++) {\r\n selectorStage = selectorStage.filterSelector(nodeSelector[cnt]);\r\n if (selectorStage.isAbsent()) {\r\n return selectorStage;\r\n }\r\n }\r\n return selectorStage;\r\n };\r\n DomQuery.prototype.eachElem = function (func) {\r\n for (var cnt = 0, len = this.rootNode.length; cnt < len; cnt++) {\r\n if (func(this.rootNode[cnt], cnt) === false) {\r\n break;\r\n }\r\n }\r\n return this;\r\n };\r\n DomQuery.prototype.firstElem = function (func) {\r\n if (func === void 0) { func = function (item) { return item; }; }\r\n if (this.rootNode.length > 1) {\r\n func(this.rootNode[0], 0);\r\n }\r\n return this;\r\n };\r\n DomQuery.prototype.each = function (func) {\r\n Stream_1.Stream.of.apply(Stream_1.Stream, this.rootNode).each(function (item, cnt) {\r\n //we could use a filter, but for the best performance we dont\r\n if (item == null) {\r\n return;\r\n }\r\n return func(DomQuery.byId(item), cnt);\r\n });\r\n return this;\r\n };\r\n /**\r\n * returns a new dom query containing only the first element max\r\n *\r\n * @param func a an optional callback function to perform an operation on the first element\r\n */\r\n DomQuery.prototype.first = function (func) {\r\n if (func === void 0) { func = function (item) { return item; }; }\r\n if (this.rootNode.length >= 1) {\r\n func(this.get(0), 0);\r\n return this.get(0);\r\n }\r\n return this;\r\n };\r\n /**\r\n * filter function which filters a subset\r\n *\r\n * @param func\r\n */\r\n DomQuery.prototype.filter = function (func) {\r\n var reArr = [];\r\n this.each(function (item) {\r\n func(item) ? reArr.push(item) : null;\r\n });\r\n return new (DomQuery.bind.apply(DomQuery, __spreadArrays([void 0], reArr)))();\r\n };\r\n //TODO append prepend\r\n /**\r\n * global eval head appendix method\r\n * no other methods are supported anymore\r\n * @param code the code to be evaled\r\n * @param nonce optional nonce key for higher security\r\n */\r\n DomQuery.prototype.globalEval = function (code, nonce) {\r\n var head = document.getElementsByTagName(\"head\")[0] || document.documentElement;\r\n var script = document.createElement(\"script\");\r\n if (nonce) {\r\n script.setAttribute(\"nonce\", nonce);\r\n }\r\n script.type = \"text/javascript\";\r\n script.innerHTML = code;\r\n var newScriptElement = head.appendChild(script);\r\n head.removeChild(newScriptElement);\r\n return this;\r\n };\r\n /**\r\n * detaches a set of nodes from their parent elements\r\n * in a browser independend manner\r\n * @param {Object} items the items which need to be detached\r\n * @return {Array} an array of nodes with the detached dom nodes\r\n */\r\n DomQuery.prototype.detach = function () {\r\n this.eachElem(function (item) {\r\n item.parentNode.removeChild(item);\r\n });\r\n return this;\r\n };\r\n /**\r\n * appends the current set of elements\r\n * to the element or first element passed via elem\r\n * @param elem\r\n */\r\n DomQuery.prototype.appendTo = function (elem) {\r\n this.eachElem(function (item) {\r\n var value1 = elem.getAsElem(0).orElseLazy(function () {\r\n return {\r\n appendChild: function (theItem) {\r\n }\r\n };\r\n }).value;\r\n value1.appendChild(item);\r\n });\r\n };\r\n /**\r\n * loads and evals a script from a source uri\r\n *\r\n * @param src the source to be loaded and evaled\r\n * @param defer in miliseconds execution default (0 == no defer)\r\n * @param charSet\r\n */\r\n DomQuery.prototype.loadScriptEval = function (src, defer, charSet) {\r\n var _this = this;\r\n if (defer === void 0) { defer = 0; }\r\n if (charSet === void 0) { charSet = \"utf-8\"; }\r\n var xhr = new XMLHttpRequest();\r\n xhr.open(\"GET\", src, false);\r\n if (charSet) {\r\n xhr.setRequestHeader(\"Content-Type\", \"application/x-javascript; charset:\" + charSet);\r\n }\r\n xhr.send(null);\r\n xhr.onload = function (responseData) {\r\n //defer also means we have to process after the ajax response\r\n //has been processed\r\n //we can achieve that with a small timeout, the timeout\r\n //triggers after the processing is done!\r\n if (!defer) {\r\n _this.globalEval(xhr.responseText.replace(\"\\n\", \"\\r\\n\") + \"\\r\\n//@ sourceURL=\" + src);\r\n }\r\n else {\r\n //TODO not ideal we maybe ought to move to something else here\r\n //but since it is not in use yet, it is ok\r\n setTimeout(function () {\r\n _this.globalEval(xhr.responseText + \"\\r\\n//@ sourceURL=\" + src);\r\n }, defer);\r\n }\r\n };\r\n xhr.onerror = function (data) {\r\n throw Error(data);\r\n };\r\n //since we are synchronous we do it after not with onReadyStateChange\r\n return this;\r\n };\r\n DomQuery.prototype.insertAfter = function () {\r\n var toInsertParams = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n toInsertParams[_i] = arguments[_i];\r\n }\r\n this.each(function (existingItem) {\r\n var existingElement = existingItem.getAsElem(0).value;\r\n var rootNode = existingElement.parentNode;\r\n var _loop_1 = function (cnt) {\r\n var nextSibling = existingElement.nextSibling;\r\n toInsertParams[cnt].eachElem(function (insertElem) {\r\n if (nextSibling) {\r\n rootNode.insertBefore(insertElem, nextSibling);\r\n existingElement = nextSibling;\r\n }\r\n else {\r\n rootNode.appendChild(insertElem);\r\n }\r\n });\r\n };\r\n for (var cnt = 0; cnt < toInsertParams.length; cnt++) {\r\n _loop_1(cnt);\r\n }\r\n });\r\n var res = [];\r\n res.push(this);\r\n res = res.concat(toInsertParams);\r\n return new (DomQuery.bind.apply(DomQuery, __spreadArrays([void 0], res)))();\r\n };\r\n DomQuery.prototype.insertBefore = function () {\r\n var toInsertParams = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n toInsertParams[_i] = arguments[_i];\r\n }\r\n this.each(function (existingItem) {\r\n var existingElement = existingItem.getAsElem(0).value;\r\n var rootNode = existingElement.parentNode;\r\n for (var cnt = 0; cnt < toInsertParams.length; cnt++) {\r\n toInsertParams[cnt].eachElem(function (insertElem) {\r\n rootNode.insertBefore(insertElem, existingElement);\r\n });\r\n }\r\n });\r\n var res = [];\r\n res.push(this);\r\n res = res.concat(toInsertParams);\r\n return new (DomQuery.bind.apply(DomQuery, __spreadArrays([void 0], res)))();\r\n };\r\n DomQuery.prototype.orElse = function () {\r\n var elseValue = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n elseValue[_i] = arguments[_i];\r\n }\r\n if (this.isPresent()) {\r\n return this;\r\n }\r\n else {\r\n return new (DomQuery.bind.apply(DomQuery, __spreadArrays([void 0], elseValue)))();\r\n }\r\n };\r\n DomQuery.prototype.orElseLazy = function (func) {\r\n if (this.isPresent()) {\r\n return this;\r\n }\r\n else {\r\n return new DomQuery(func());\r\n }\r\n };\r\n DomQuery.prototype.parents = function (tagName) {\r\n var retSet = new Set();\r\n var retArr = [];\r\n var lowerTagName = tagName.toLowerCase();\r\n var resolveItem = function (item) {\r\n if ((item.tagName || \"\").toLowerCase() == lowerTagName && !retSet.has(item)) {\r\n retSet.add(item);\r\n retArr.push(item);\r\n }\r\n };\r\n this.eachElem(function (item) {\r\n while (item.parentNode) {\r\n item = item.parentNode;\r\n resolveItem(item);\r\n //nested forms not possible, performance shortcut\r\n if (tagName == \"form\" && retArr.length) {\r\n return false;\r\n }\r\n }\r\n });\r\n return new (DomQuery.bind.apply(DomQuery, __spreadArrays([void 0], retArr)))();\r\n };\r\n DomQuery.prototype.copyAttrs = function (sourceItem) {\r\n var _this = this;\r\n sourceItem.eachElem(function (sourceNode) {\r\n var attrs = objToArray(sourceNode.attributes);\r\n for (var _i = 0, attrs_1 = attrs; _i < attrs_1.length; _i++) {\r\n var item = attrs_1[_i];\r\n var value = item.value;\r\n var name_1 = item.name;\r\n switch (name_1) {\r\n case \"id\":\r\n _this.id.value = value;\r\n break;\r\n case \"disabled\":\r\n _this.resolveAttributeHolder(\"disabled\").disabled = value;\r\n break;\r\n case \"checked\":\r\n _this.resolveAttributeHolder(\"checked\").checked = value;\r\n break;\r\n default:\r\n _this.attr(name_1).value = value;\r\n }\r\n }\r\n });\r\n return this;\r\n };\r\n /**\r\n * resolves an attribute holder compared\r\n * @param attr\r\n */\r\n DomQuery.prototype.resolveAttributeHolder = function (attrName) {\r\n if (attrName === void 0) { attrName = \"value\"; }\r\n var ret = [];\r\n ret[attrName] = null;\r\n return (attrName in this.getAsElem(0).value) ?\r\n this.getAsElem(0).value :\r\n ret;\r\n };\r\n /**\r\n * outerhtml convenience method\r\n * browsers only support innerHTML but\r\n * for instance for your jsf.js we have a full\r\n * replace pattern which needs outerHTML processing\r\n *\r\n * @param markup\r\n * @param runEmbeddedScripts\r\n * @param runEmbeddedCss\r\n */\r\n DomQuery.prototype.outerHTML = function (markup, runEmbeddedScripts, runEmbeddedCss) {\r\n if (this.isAbsent()) {\r\n return;\r\n }\r\n var nodes = DomQuery.fromMarkup(markup);\r\n var res = [];\r\n var toReplace = this.getAsElem(0).value;\r\n var firstInsert = nodes.get(0);\r\n var parentNode = toReplace.parentNode;\r\n var replaced = firstInsert.getAsElem(0).value;\r\n parentNode.replaceChild(replaced, toReplace);\r\n res.push(new DomQuery(replaced));\r\n //no replacement possible\r\n if (this.isAbsent()) {\r\n return this;\r\n }\r\n var insertAdditionalItems = [];\r\n if (nodes.length > 1) {\r\n insertAdditionalItems = insertAdditionalItems.concat.apply(insertAdditionalItems, nodes.values.slice(1));\r\n res.push(DomQuery.byId(replaced).insertAfter(new (DomQuery.bind.apply(DomQuery, __spreadArrays([void 0], insertAdditionalItems)))()));\r\n }\r\n if (runEmbeddedScripts) {\r\n this.runScripts();\r\n }\r\n if (runEmbeddedCss) {\r\n this.runCss();\r\n }\r\n return nodes;\r\n };\r\n /**\r\n * Run through the given nodes in the DomQuery execute the inline scripts\r\n * @param whilteListed: optional whitelist function which can filter out script tags which are not processed\r\n * defaults to the standard jsf.js exclusion (we use this code for myfaces)\r\n */\r\n DomQuery.prototype.runScripts = function (whilteListed) {\r\n var _this = this;\r\n if (whilteListed === void 0) { whilteListed = DEFAULT_JSF_WHITELIST; }\r\n var finalScripts = [], equi = equalsIgnoreCase, execScrpt = function (item) {\r\n var tagName = item.tagName;\r\n var itemType = item.type || \"\";\r\n if (tagName && equi(tagName, \"script\") &&\r\n (itemType === \"\" || equi(itemType, \"text/javascript\") ||\r\n equi(itemType, \"javascript\") ||\r\n equi(itemType, \"text/ecmascript\") ||\r\n equi(itemType, \"ecmascript\"))) {\r\n var src = item.getAttribute('src');\r\n if ('undefined' != typeof src\r\n && null != src\r\n && src.length > 0) {\r\n //we have to move this into an inner if because chrome otherwise chokes\r\n //due to changing the and order instead of relying on left to right\r\n //if jsf.js is already registered we do not replace it anymore\r\n if (whilteListed(src)) {\r\n if (finalScripts.length) {\r\n //script source means we have to eval the existing\r\n //scripts before running the include\r\n _this.globalEval(finalScripts.join(\"\\n\"));\r\n finalScripts = [];\r\n }\r\n _this.loadScriptEval(src, 0, \"UTF-8\");\r\n }\r\n }\r\n else {\r\n // embedded script auto eval\r\n //TODO this probably needs to be changed due to our new parsing structures\r\n //probably not needed anymore\r\n var evalText = trim(item.text || item.innerText || item.innerHTML);\r\n var go = true;\r\n while (go) {\r\n go = false;\r\n if (evalText.substring(0, 4) == \"<!--\") {\r\n evalText = evalText.substring(4);\r\n go = true;\r\n }\r\n if (evalText.substring(0, 4) == \"//<!--\") {\r\n evalText = evalText.substring(6);\r\n go = true;\r\n }\r\n if (evalText.substring(0, 11) == \"//<![CDATA[\") {\r\n evalText = evalText.substring(11);\r\n go = true;\r\n }\r\n }\r\n // we have to run the script under a global context\r\n //we store the script for less calls to eval\r\n finalScripts.push(evalText);\r\n }\r\n }\r\n };\r\n try {\r\n var scriptElements = new DomQuery(this.filterSelector(\"script\"), this.querySelectorAll(\"script\"));\r\n //script execution order by relative pos in their dom tree\r\n scriptElements.stream\r\n .flatMap(function (item) {\r\n return Stream_1.Stream.of(item.values);\r\n })\r\n .sort(function (node1, node2) {\r\n return node1.compareDocumentPosition(node2) - 3; //preceding 2, following == 4\r\n })\r\n .each(function (item) { return execScrpt(item); });\r\n if (finalScripts.length) {\r\n this.globalEval(finalScripts.join(\"\\n\"));\r\n }\r\n }\r\n catch (e) {\r\n if (window.console && window.console.error) {\r\n //not sure if we\r\n //should use our standard\r\n //error mechanisms here\r\n //because in the head appendix\r\n //method only a console\r\n //error would be raised as well\r\n console.error(e.message || e.description);\r\n }\r\n }\r\n finally {\r\n //the usual ie6 fix code\r\n //the IE6 garbage collector is broken\r\n //nulling closures helps somewhat to reduce\r\n //mem leaks, which are impossible to avoid\r\n //at this browser\r\n execScrpt = null;\r\n }\r\n return this;\r\n };\r\n DomQuery.prototype.runCss = function () {\r\n var applyStyle = function (item, style) {\r\n var _a, _b, _c, _d, _e;\r\n var newSS = document.createElement(\"style\");\r\n document.getElementsByTagName(\"head\")[0].appendChild(newSS);\r\n var styleSheet = (_a = newSS.sheet, (_a !== null && _a !== void 0 ? _a : newSS.styleSheet));\r\n newSS.setAttribute(\"rel\", (_b = item.getAttribute(\"rel\"), (_b !== null && _b !== void 0 ? _b : \"stylesheet\")));\r\n newSS.setAttribute(\"type\", (_c = item.getAttribute(\"type\"), (_c !== null && _c !== void 0 ? _c : \"text/css\")));\r\n if (_e = (_d = styleSheet) === null || _d === void 0 ? void 0 : _d.cssText, (_e !== null && _e !== void 0 ? _e : false)) {\r\n styleSheet.cssText = style;\r\n }\r\n else {\r\n newSS.appendChild(document.createTextNode(style));\r\n }\r\n }, execCss = function (item) {\r\n var tagName = item.tagName;\r\n if (tagName && equalsIgnoreCase(tagName, \"link\") && equalsIgnoreCase(item.getAttribute(\"type\"), \"text/css\")) {\r\n applyStyle(item, \"@import url('\" + item.getAttribute(\"href\") + \"');\");\r\n }\r\n else if (tagName && equalsIgnoreCase(tagName, \"style\") && equalsIgnoreCase(item.getAttribute(\"type\"), \"text/css\")) {\r\n var innerText = [];\r\n //compliant browsers know child nodes\r\n var childNodes = item.childNodes;\r\n if (childNodes) {\r\n var len = childNodes.length;\r\n for (var cnt = 0; cnt < len; cnt++) {\r\n innerText.push(childNodes[cnt].innerHTML || childNodes[cnt].data);\r\n }\r\n //non compliant ones innerHTML\r\n }\r\n else if (item.innerHTML) {\r\n innerText.push(item.innerHTML);\r\n }\r\n applyStyle(item, innerText.join(\"\"));\r\n }\r\n };\r\n var scriptElements = new DomQuery(this.filterSelector(\"link, style\"), this.querySelectorAll(\"link, style\"));\r\n scriptElements.stream\r\n .flatMap(function (item) {\r\n return Stream_1.Stream.of(item.values);\r\n })\r\n .sort(function (node1, node2) {\r\n return node1.compareDocumentPosition(node2) - 3; //preceding 2, following == 4\r\n })\r\n .each(function (item) { return execCss(item); });\r\n return this;\r\n };\r\n /**\r\n * fires a click event on the underlying dom elements\r\n */\r\n DomQuery.prototype.click = function () {\r\n this.fireEvent(\"click\");\r\n return this;\r\n };\r\n DomQuery.prototype.addEventListener = function (type, listener, options) {\r\n this.eachElem(function (node) {\r\n node.addEventListener(type, listener, options);\r\n });\r\n return this;\r\n };\r\n DomQuery.prototype.removeEventListener = function (type, listener, options) {\r\n this.eachElem(function (node) {\r\n node.removeEventListener(type, listener, options);\r\n });\r\n return this;\r\n };\r\n /**\r\n * fires an event\r\n */\r\n DomQuery.prototype.fireEvent = function (eventName) {\r\n this.eachElem(function (node) {\r\n var doc;\r\n if (node.ownerDocument) {\r\n doc = node.ownerDocument;\r\n }\r\n else if (node.nodeType == 9) {\r\n // the node may be the document itself, nodeType 9 = DOCUMENT_NODE\r\n doc = node;\r\n }\r\n else {\r\n throw new Error(\"Invalid node passed to fireEvent: \" + node.id);\r\n }\r\n if (node.dispatchEvent) {\r\n // Gecko-style approach (now the standard) takes more work\r\n var eventClass = \"\";\r\n // Different events have different event classes.\r\n // If this switch statement can't map an eventName to an eventClass,\r\n // the event firing is going to fail.\r\n switch (eventName) {\r\n case \"click\": // Dispatching of 'click' appears to not work correctly in Safari. Use 'mousedown' or 'mouseup' instead.\r\n case \"mousedown\":\r\n case \"mouseup\":\r\n eventClass = \"MouseEvents\";\r\n break;\r\n case \"focus\":\r\n case \"change\":\r\n case \"blur\":\r\n case \"select\":\r\n eventClass = \"HTMLEvents\";\r\n break;\r\n default:\r\n throw \"fireEvent: Couldn't find an event class for event '\" + eventName + \"'.\";\r\n break;\r\n }\r\n var event_1 = doc.createEvent(eventClass);\r\n event_1.initEvent(eventName, true, true); // All events created as bubbling and cancelable.\r\n event_1.synthetic = true; // allow detection of synthetic events\r\n // The second parameter says go ahead with the default action\r\n node.dispatchEvent(event_1);\r\n }\r\n else if (node.fireEvent) {\r\n // IE-old school style, you can drop this if you don't need to support IE8 and lower\r\n var event = doc.createEventObject();\r\n event.synthetic = true; // allow detection of synthetic events\r\n node.fireEvent(\"on\" + eventName, event);\r\n }\r\n });\r\n };\r\n DomQuery.prototype.textContent = function (joinstr) {\r\n if (joinstr === void 0) { joinstr = \"\"; }\r\n return this.stream\r\n .map(function (value) {\r\n var item = value.getAsElem(0).orElseLazy(function () {\r\n return {\r\n textContent: \"\"\r\n };\r\n }).value;\r\n return item.textContent || \"\";\r\n })\r\n .reduce(function (text1, text2) { return text1 + joinstr + text2; }, \"\").value;\r\n };\r\n DomQuery.prototype.innerText = function (joinstr) {\r\n if (joinstr === void 0) { joinstr = \"\"; }\r\n return this.stream\r\n .map(function (value) {\r\n var item = value.getAsElem(0).orElseLazy(function () {\r\n return {\r\n innerText: \"\"\r\n };\r\n }).value;\r\n return item.innerText || \"\";\r\n })\r\n .reduce(function (text1, text2) { return [text1, text2].join(joinstr); }, \"\").value;\r\n };\r\n /**\r\n * encodes all input elements properly into respective\r\n * config entries, this can be used\r\n * for legacy systems, for newer usecases, use the\r\n * HTML5 Form class which all newer browsers provide\r\n *\r\n * @param toMerge optional config which can be merged in\r\n * @return a copy pf\r\n */\r\n DomQuery.prototype.encodeFormElement = function (toMerge) {\r\n if (toMerge === void 0) { toMerge = new Monad_1.Config({}); }\r\n //browser behavior no element name no encoding (normal submit fails in that case)\r\n //https://issues.apache.org/jira/browse/MYFACES-2847\r\n if (this.name.isAbsent()) {\r\n return;\r\n }\r\n //lets keep it sideffects free\r\n var target = toMerge.shallowCopy;\r\n this.each(function (element) {\r\n if (element.name.isAbsent()) { //no name, no encoding\r\n return;\r\n }\r\n var name = element.name.value;\r\n var tagName = element.tagName.orElse(\"__none__\").value.toLowerCase();\r\n var elemType = element.type.orElse(\"__none__\").value.toLowerCase();\r\n elemType = elemType.toLowerCase();\r\n // routine for all elements\r\n // rules:\r\n // - process only inputs, textareas and selects\r\n // - elements muest have attribute \"name\"\r\n // - elements must not be disabled\r\n if (((tagName == \"input\" || tagName == \"textarea\" || tagName == \"select\") &&\r\n (name != null && name != \"\")) && !element.disabled) {\r\n // routine for select elements\r\n // rules:\r\n // - if select-one and value-Attribute exist => \"name=value\"\r\n // (also if value empty => \"name=\")\r\n // - if select-one and value-Attribute don't exist =>\r\n // \"name=DisplayValue\"\r\n // - if select multi and multple selected => \"name=value1&name=value2\"\r\n // - if select and selectedIndex=-1 don't submit\r\n if (tagName == \"select\") {\r\n // selectedIndex must be >= 0 sein to be submittet\r\n var selectElem = element.getAsElem(0).value;\r\n if (selectElem.selectedIndex >= 0) {\r\n var uLen = selectElem.options.length;\r\n for (var u = 0; u < uLen; u++) {\r\n // find all selected options\r\n //let subBuf = [];\r\n if (selectElem.options[u].selected) {\r\n var elementOption = selectElem.options[u];\r\n target.assign(name).value = (elementOption.getAttribute(\"value\") != null) ?\r\n elementOption.value : elementOption.text;\r\n }\r\n }\r\n }\r\n }\r\n // routine for remaining elements\r\n // rules:\r\n // - don't submit no selects (processed above), buttons, reset buttons, submit buttons,\r\n // - submit checkboxes and radio inputs only if checked\r\n if ((tagName != \"select\" && elemType != \"button\"\r\n && elemType != \"reset\" && elemType != \"submit\" && elemType != \"image\")\r\n && ((elemType != \"checkbox\" && elemType != \"radio\") || element.checked)) {\r\n var files = element.value.files;\r\n if (files && files.length) {\r\n //xhr level2\r\n target.assign(name).value = files[0];\r\n }\r\n else {\r\n target.assign(name).value = element.inputValue.value;\r\n }\r\n }\r\n }\r\n });\r\n return target;\r\n };\r\n Object.defineProperty(DomQuery.prototype, \"cDATAAsString\", {\r\n get: function () {\r\n var cDataBlock = [];\r\n // response may contain several blocks\r\n return this.stream\r\n .flatMap(function (item) { return item.childNodes.stream; }).reduce(function (reduced, item) {\r\n var _a, _b, _c, _d;\r\n reduced.push((_d = (_c = (_b = (_a = item) === null || _a === void 0 ? void 0 : _a.value) === null || _b === void 0 ? void 0 : _b.value) === null || _c === void 0 ? void 0 : _c.data, (_d !== null && _d !== void 0 ? _d : \"\")));\r\n return reduced;\r\n }, []).value.join(\"\");\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n DomQuery.prototype.subNodes = function (from, to) {\r\n if (Monad_1.Optional.fromNullable(to).isAbsent()) {\r\n to = this.length;\r\n }\r\n return new (DomQuery.bind.apply(DomQuery, __spreadArrays([void 0], this.rootNode.slice(from, Math.min(to, this.length)))))();\r\n };\r\n DomQuery.prototype.limits = function (end) {\r\n this._limits = end;\r\n return this;\r\n };\r\n //-- internally exposed methods needed for the interconnectivity\r\n DomQuery.prototype.hasNext = function () {\r\n var isLimitsReached = this._limits != -1 && this.pos >= this._limits - 1;\r\n var isEndOfArray = this.pos >= this.values.length - 1;\r\n return !(isLimitsReached ||\r\n isEndOfArray);\r\n };\r\n DomQuery.prototype.next = function () {\r\n if (!this.hasNext()) {\r\n return null;\r\n }\r\n this.pos++;\r\n return new DomQuery(this.values[this.pos]);\r\n };\r\n DomQuery.prototype.reset = function () {\r\n this.pos = -1;\r\n };\r\n DomQuery.absent = new DomQuery();\r\n return DomQuery;\r\n}());\r\nexports.DomQuery = DomQuery;\r\n/**\r\n * Various collectors\r\n * which can be used in conjunction with Streams\r\n */\r\n/**\r\n * A collector which bundles a full dom query stream into a single dom query element\r\n *\r\n * This connects basically our stream back into DomQuery\r\n */\r\nvar DomQueryCollector = /** @class */ (function () {\r\n function DomQueryCollector() {\r\n this.data = [];\r\n }\r\n DomQueryCollector.prototype.collect = function (element) {\r\n this.data.push(element);\r\n };\r\n Object.defineProperty(DomQueryCollector.prototype, \"finalValue\", {\r\n get: function () {\r\n return new (DomQuery.bind.apply(DomQuery, __spreadArrays([void 0], this.data)))();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n return DomQueryCollector;\r\n}());\r\nexports.DomQueryCollector = DomQueryCollector;\r\n/**\r\n * abbreviation for DomQuery\r\n */\r\nexports.DQ = DomQuery;\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/main/typescript/ext/monadish/DomQuery.ts.js","sources":["webpack:///./src/main/typescript/ext/monadish/DomQuery.ts?bf09"],"sourcesContent":["/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements.  See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License.  You may obtain a copy of the License at\r\n *\r\n *      http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\nimport {Config, Optional, ValueEmbedder} from \"./Monad\";\r\nimport {XMLQuery} from \"./XmlQuery\";\r\nimport {IStream, LazyStream, Stream} from \"./Stream\";\r\nimport {ICollector, IStreamDataSource} from \"./SourcesCollectors\";\r\nimport {Lang} from \"./Lang\";\r\nimport trim = Lang.trim;\r\nimport objToArray = Lang.objToArray;\r\nimport isString = Lang.isString;\r\nimport equalsIgnoreCase = Lang.equalsIgnoreCase;\r\n\r\n// @ts-ignore supression needed here due to fromnullable\r\nexport class ElementAttribute extends ValueEmbedder<string> {\r\n\r\n    constructor(private element: DomQuery, private name: string, private defaultVal: string = null) {\r\n        super(element, name);\r\n    }\r\n\r\n    get value(): string {\r\n        let val: Element[] = this.element.get(0).orElse(...[]).values;\r\n        if (!val.length) {\r\n            return this.defaultVal;\r\n        }\r\n        return val[0].getAttribute(this.name);\r\n    }\r\n\r\n    set value(value: string) {\r\n        let val: Element[] = this.element.get(0).orElse(...[]).values;\r\n        for (let cnt = 0; cnt < val.length; cnt++) {\r\n            val[cnt].setAttribute(this.name, value);\r\n        }\r\n        val[0].setAttribute(this.name, value);\r\n    }\r\n\r\n    protected getClass(): any {\r\n        return ElementAttribute;\r\n    }\r\n\r\n    static fromNullable(value?: any, valueKey: string = \"value\"): ElementAttribute {\r\n        return new ElementAttribute(value, valueKey);\r\n    }\r\n\r\n}\r\n\r\n/**\r\n * small helper for the specialized jsf case\r\n * @param src\r\n * @constructor\r\n */\r\nconst DEFAULT_JSF_WHITELIST = (src: string) => {\r\n    return (src.indexOf(\"ln=scripts\") == -1 &&\r\n        src.indexOf(\"ln=javax.faces\") == -1) ||\r\n        (src.indexOf(\"/jsf.js\") == -1 &&\r\n            src.indexOf(\"/jsf-uncompressed.js\") == -1);\r\n};\r\n\r\ninterface IDomQuery {\r\n    /**\r\n     * reads the first element if it exists and returns an optional\r\n     */\r\n    readonly value: Optional<Element>;\r\n    /**\r\n     * All elements as array\r\n     */\r\n    readonly values: Element[];\r\n    /**\r\n     * returns the id as settable value (See also ValueEmbedder)\r\n     */\r\n    readonly id: ValueEmbedder<string>;\r\n    /**\r\n     * returns the length of embedded nodes (top level)\r\n     */\r\n    readonly length: number;\r\n    /**\r\n     * the tag name of the first element\r\n     */\r\n    readonly tagName: Optional<string>;\r\n    /**\r\n     * the node name of the first element\r\n     */\r\n    readonly nodeName: Optional<string>;\r\n    /**\r\n     * the type of the first element\r\n     */\r\n    readonly type: Optional<string>;\r\n    /**\r\n     * The name as changeable value\r\n     */\r\n    readonly name: ValueEmbedder<string>;\r\n    /**\r\n     * The the value in case of inputs as changeable value\r\n     */\r\n    readonly inputValue: ValueEmbedder<string | boolean>;\r\n    /**\r\n     * the underlying form elements as domquery object\r\n     */\r\n    readonly elements: DomQuery;\r\n    /**\r\n     * settable flag for disabled\r\n     */\r\n    disabled: boolean;\r\n    /**\r\n     * The child nodes of this node collection as readonly attribute\r\n     */\r\n    readonly childNodes: DomQuery;\r\n    /**\r\n     * an early stream representation for this DomQuery\r\n     */\r\n    readonly stream: Stream<DomQuery>;\r\n    /**\r\n     * lazy stream representation for this DomQuery\r\n     */\r\n    readonly lazyStream: LazyStream<DomQuery>;\r\n    /**\r\n     * transform this node collection to an array\r\n     */\r\n    readonly asArray: Array<DomQuery>;\r\n\r\n    /**\r\n     * returns true if the elements have the tag *tagName* as tag embedded (highest level)\r\n     * @param tagName\r\n     */\r\n    isTag(tagName: string): boolean;\r\n\r\n    /**\r\n     * returns the nth element as domquery\r\n     * from the internal elements\r\n     * note if you try to reach a non existing element position\r\n     * you will get back an absent entry\r\n     *\r\n     * @param index the nth index\r\n     */\r\n    get(index: number): DomQuery;\r\n\r\n    /**\r\n     * returns the nth element as optional of an Element object\r\n     * @param index the number from the index\r\n     * @param defaults the default value if the index is overrun default Optional.absent\r\n     */\r\n    getAsElem(index: number, defaults: Optional<any>): Optional<Element>;\r\n\r\n    /**\r\n     * returns the value array< of all elements\r\n     */\r\n    allElems(): Array<Element>;\r\n\r\n    /**\r\n     * absent no values reached?\r\n     */\r\n    isAbsent(): boolean;\r\n\r\n    /**\r\n     * should make the code clearer\r\n     * note if you pass a function\r\n     * this refers to the active dopmquery object\r\n     */\r\n    isPresent(presentRunnable ?: (elem ?: DomQuery) => void): boolean;\r\n\r\n    /**\r\n     * should make the code clearer\r\n     * note if you pass a function\r\n     * this refers to the active dopmquery object\r\n     *\r\n     *\r\n     * @param presentRunnable\r\n     */\r\n    ifPresentLazy(presentRunnable: (elem ?: DomQuery) => void): DomQuery;\r\n\r\n    /**\r\n     * remove all affected nodes from this query object from the dom tree\r\n     */\r\n    delete(): void;\r\n\r\n    /**\r\n     * query selector all on the existing dom query object\r\n     *\r\n     * @param selector the standard selector\r\n     * @return a DomQuery with the results\r\n     */\r\n    querySelectorAll(selector): DomQuery;\r\n\r\n    /**\r\n     * core byId method\r\n     * @param id the id to search for\r\n     * @param includeRoot also match the root element?\r\n     */\r\n    byId(id: string, includeRoot?: boolean): DomQuery;\r\n\r\n    /**\r\n     * same as byId just for the tag name\r\n     * @param tagName\r\n     * @param includeRoot\r\n     */\r\n    byTagName(tagName: string, includeRoot ?: boolean): DomQuery;\r\n\r\n    /**\r\n     * attr accessor, usage myQuery.attr(\"class\").value = \"bla\"\r\n     * or let value myQuery.attr(\"class\").value\r\n     * @param attr the attribute to set\r\n     * @param defaultValue the default value in case nothing is presented (defaults to null)\r\n     */\r\n    attr(attr: string, defaultValue: string): ElementAttribute;\r\n\r\n    /**\r\n     * hasclass, checks for an existing class in the class attributes\r\n     *\r\n     * @param clazz the class to search for\r\n     */\r\n    hasClass(clazz: string): boolean;\r\n\r\n    /**\r\n     * appends a class string if not already in the element(s)\r\n     *\r\n     * @param clazz the style class to append\r\n     */\r\n    addClass(clazz: string): DomQuery;\r\n\r\n    /**\r\n     * remove the style class if in the class definitions\r\n     *\r\n     * @param clazz\r\n     */\r\n    removeClass(clazz: string): DomQuery;\r\n\r\n    /**\r\n     * checks whether we have a multipart element in our children\r\n     */\r\n    isMultipartCandidate(): boolean;\r\n\r\n    /**\r\n     * innerHtml equivalkent\r\n     * equivalent to jqueries html\r\n     * as setter the html is set and the\r\n     * DomQuery is given back\r\n     * as getter the html string is returned\r\n     *\r\n     * @param inval\r\n     */\r\n    html(inval?: string): DomQuery | Optional<string>;\r\n\r\n    /**\r\n     * easy node traversal, you can pass\r\n     * a set of node selectors which are joined as direct childs\r\n     *\r\n     * not the rootnodes are not in the getIf, those are always the child nodes\r\n     *\r\n     * @param nodeSelector\r\n     */\r\n    getIf(...nodeSelector: Array<string>): DomQuery;\r\n\r\n    /**\r\n     * iterate over each element and perform something on the element\r\n     * (Dom element is passed instead of DomQuery)\r\n     * @param func\r\n     */\r\n    eachElem(func: (item: Element, cnt?: number) => any): DomQuery;\r\n\r\n    /**\r\n     * perform an operation on the first element\r\n     * returns a DomQuery on the first element only\r\n     * @param func\r\n     */\r\n    firstElem(func: (item: Element, cnt?: number) => any): DomQuery;\r\n\r\n    /**\r\n     * same as eachElem, but a DomQuery object is passed down\r\n     *\r\n     * @param func\r\n     */\r\n    each(func: (item: DomQuery, cnt?: number) => any): DomQuery;\r\n\r\n    /**\r\n     * returns a new dom query containing only the first element max\r\n     *\r\n     * @param func a an optional callback function to perform an operation on the first element\r\n     */\r\n    first(func: (item: DomQuery, cnt?: number) => any): DomQuery;\r\n\r\n    /**\r\n     * filter function which filters a subset\r\n     *\r\n     * @param func\r\n     */\r\n    filter(func: (item: DomQuery) => boolean): DomQuery;\r\n\r\n    /**\r\n     * global eval head appendix method\r\n     * no other methods are supported anymore\r\n     * @param code the code to be evaled\r\n     * @param  nonce optional  nonce key for higher security\r\n     */\r\n    globalEval(code: string, nonce ?: string): DomQuery;\r\n\r\n    /**\r\n     * detaches a set of nodes from their parent elements\r\n     * in a browser independend manner\r\n     * @param {Object} items the items which need to be detached\r\n     * @return {Array} an array of nodes with the detached dom nodes\r\n     */\r\n    detach(): DomQuery;\r\n\r\n    /**\r\n     * appends the current set of elements\r\n     * to the element or first element passed via elem\r\n     * @param elem\r\n     */\r\n    appendTo(elem: DomQuery): void;\r\n\r\n    /**\r\n     * loads and evals a script from a source uri\r\n     *\r\n     * @param src the source to be loaded and evaled\r\n     * @param defer in miliseconds execution default (0 == no defer)\r\n     * @param charSet\r\n     */\r\n    loadScriptEval(src: string, defer: number, charSet: string): void;\r\n\r\n    /**\r\n     * insert toInsert after the current element\r\n     *\r\n     * @param toInsert an array of DomQuery objects\r\n     */\r\n    insertAfter(...toInsert: Array<DomQuery>): DomQuery;\r\n\r\n    /**\r\n     * inserts the elements before the current element\r\n     *\r\n     * @param toInsert\r\n     */\r\n    insertBefore(...toInsert: Array<DomQuery>): DomQuery;\r\n\r\n    /**\r\n     * in case the domquery is pointing to nothing the else value is taken into consideration\r\n     * als alternative\r\n     *\r\n     * @param elseValue the else value\r\n     */\r\n    orElse(...elseValue: any): DomQuery;\r\n\r\n    /**\r\n     * the same with lazy evaluation for cases where getting the else value\r\n     * is a heavy operation\r\n     *\r\n     * @param func the else provider function\r\n     */\r\n    orElseLazy(func: () => any): DomQuery;\r\n\r\n    /**\r\n     * all parents with TagName\r\n     * @param tagName\r\n     */\r\n    parents(tagName: string): DomQuery;\r\n\r\n    /**\r\n     * copy all attributes of sourceItem to this DomQuery items\r\n     *\r\n     * @param sourceItem the source item to copy over (can be another domquery or a parsed XML Query item)\r\n     */\r\n    copyAttrs(sourceItem: DomQuery | XMLQuery): DomQuery;\r\n\r\n    /**\r\n     * outerhtml convenience method\r\n     * browsers only support innerHTML but\r\n     * for instance for your jsf.js we have a full\r\n     * replace pattern which needs outerHTML processing\r\n     *\r\n     * @param markup\r\n     * @param runEmbeddedScripts\r\n     * @param runEmbeddedCss\r\n     */\r\n    outerHTML(markup: string, runEmbeddedScripts ?: boolean, runEmbeddedCss ?: boolean): DomQuery;\r\n\r\n    /**\r\n     * Run through the given nodes in the DomQuery execute the inline scripts\r\n     * @param whilteListed: optional whitelist function which can filter out script tags which are not processed\r\n     * defaults to the standard jsf.js exclusion (we use this code for myfaces)\r\n     */\r\n    runScripts(whilteListed: (val: string) => boolean): DomQuery;\r\n\r\n    /**\r\n     * runs the embedded css\r\n     */\r\n    runCss(): DomQuery;\r\n\r\n    /**\r\n     * fires a click event on the underlying dom elements\r\n     */\r\n    click(): DomQuery;\r\n\r\n    /**\r\n     * adds an event listener\r\n     *\r\n     * @param type\r\n     * @param listener\r\n     * @param options\r\n     */\r\n    addEventListener(type: string, listener: (evt: Event) => void, options?: boolean | EventListenerOptions): DomQuery;\r\n\r\n    /**\r\n     * removes an event listener\r\n     *\r\n     * @param type\r\n     * @param listener\r\n     * @param options\r\n     */\r\n    removeEventListener(type: string, listener: (evt: Event) => void, options?: boolean | EventListenerOptions): DomQuery;\r\n\r\n    /**\r\n     * fires an event\r\n     */\r\n    fireEvent(eventName: string): void;\r\n\r\n    /*\r\n     * pushes  in optionally a new textContent, and/or returns the current text content\r\n     */\r\n    textContent(joinstr?: string): string;\r\n\r\n    /*\r\n     * pushes  in optionally a new innerText, and/or returns the current innerText\r\n     */\r\n    innerText(joinstr?: string): string;\r\n\r\n    /**\r\n     * encodes all input elements properly into respective\r\n     * config entries, this can be used\r\n     * for legacy systems, for newer usecases, use the\r\n     * HTML5 Form class which all newer browsers provide\r\n     *\r\n     * @param toMerge optional config which can be merged in\r\n     * @return a copy pf\r\n     */\r\n    encodeFormElement(toMerge): Config;\r\n\r\n    /**\r\n     * fetches the subnodes from ... to..\r\n     * @param from\r\n     * @param to\r\n     */\r\n    subNodes(from: number, to?: number): DomQuery;\r\n}\r\n\r\n/**\r\n * Monadic DomNode representation, ala jquery\r\n * This is a thin wrapper over querySelectorAll\r\n * to get slim monadic support\r\n * to reduce implementation code on the users side.\r\n * This is vital for frameworks which want to rely on\r\n * plain dom but still do not want to lose\r\n * the reduced code footprint of querying dom trees and traversing\r\n * by using functional patterns.\r\n *\r\n * Also a few convenience methods are added to reduce\r\n * the code footprint of standard dom processing\r\n * operations like eval\r\n *\r\n * TODO add jquery fallback support, since it is supported\r\n * in most older systems\r\n * Note parts of this code still stem from the Dom.js I have written 10 years\r\n * ago, those parts look a little bit ancient and will be replaced over time.\r\n *\r\n */\r\nexport class DomQuery implements IDomQuery, IStreamDataSource<DomQuery> {\r\n\r\n    static absent = new DomQuery();\r\n\r\n    private rootNode: Array<Element> = [];\r\n\r\n    pos = -1;\r\n\r\n    constructor(...rootNode: Array<Element | DomQuery | Document | Array<any> | string>) {\r\n\r\n        if (Optional.fromNullable(rootNode).isAbsent() || !rootNode.length) {\r\n            return;\r\n        } else {\r\n            //we need to flatten out the arrays\r\n\r\n            for (let cnt = 0; cnt < rootNode.length; cnt++) {\r\n                if (isString(rootNode[cnt])) {\r\n                    let foundElement = DomQuery.querySelectorAll(<string>rootNode[cnt]);\r\n                    if (!foundElement.isAbsent()) {\r\n                        rootNode.push(...foundElement.values)\r\n                    }\r\n                } else if (rootNode[cnt] instanceof DomQuery) {\r\n                    this.rootNode.push(...(<any>rootNode[cnt]).values);\r\n                } else {\r\n                    this.rootNode.push(<any>rootNode[cnt]);\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * returns the first element\r\n     */\r\n    get value(): Optional<Element> {\r\n        return this.getAsElem(0);\r\n    }\r\n\r\n    get values(): Element[] {\r\n        return this.allElems();\r\n    }\r\n\r\n    /**\r\n     * returns the id of the first element\r\n     */\r\n    get id(): ValueEmbedder<string> {\r\n        return new ElementAttribute(this.get(0), \"id\");\r\n    }\r\n\r\n    /**\r\n     * length of the entire query set\r\n     */\r\n    get length(): number {\r\n        return this.rootNode.length\r\n    }\r\n\r\n    /**\r\n     * convenience method for tagName\r\n     */\r\n    get tagName(): Optional<string> {\r\n        return <Optional<string>>this.getAsElem(0).getIf(\"tagName\");\r\n    }\r\n\r\n    /**\r\n     * convenience method for nodeName\r\n     */\r\n    get nodeName(): Optional<string> {\r\n        return <Optional<string>>this.getAsElem(0).getIf(\"nodeName\");\r\n    }\r\n\r\n    isTag(tagName: string): boolean {\r\n        return !this.isAbsent()\r\n            && (this.nodeName.orElse(\"__none___\")\r\n                    .value.toLowerCase() == tagName.toLowerCase()\r\n                || this.tagName.orElse(\"__none___\")\r\n                    .value.toLowerCase() == tagName.toLowerCase()\r\n            )\r\n    }\r\n\r\n    /**\r\n     * convenience property for type\r\n     *\r\n     * returns null in case of no type existing otherwise\r\n     * the type of the first element\r\n     */\r\n    get type(): Optional<string> {\r\n        return this.getAsElem(0).getIf(\"type\");\r\n    }\r\n\r\n    /**\r\n     * convenience property for name\r\n     *\r\n     * returns null in case of no type existing otherwise\r\n     * the name of the first element\r\n     */\r\n    get name(): ValueEmbedder<string> {\r\n        return new ValueEmbedder(this.getAsElem(0).value, \"name\");\r\n    }\r\n\r\n    /**\r\n     * convenience property for value\r\n     *\r\n     * returns null in case of no type existing otherwise\r\n     * the value of the first element\r\n     */\r\n    get inputValue(): ValueEmbedder<string | boolean> {\r\n        if (this.getAsElem(0).getIf(\"value\").isPresent()) {\r\n            return new ValueEmbedder<string>(this.getAsElem(0).value);\r\n        } else {\r\n            return <any>ValueEmbedder.absent;\r\n        }\r\n    }\r\n\r\n    get checked(): boolean {\r\n        return Stream.of(...this.values).allMatch(el => !!(<any>el).checked);\r\n    }\r\n\r\n    set checked(newChecked: boolean) {\r\n        this.eachElem(el => (<any>el).checked = newChecked);\r\n    }\r\n\r\n    get elements(): DomQuery {\r\n        let elements: DomQuery = this.stream.flatMap((item: DomQuery) => {\r\n            let formElement: HTMLFormElement = <HTMLFormElement>item.value.value;\r\n            return new Stream(formElement.elements ? objToArray(formElement.elements) : []);\r\n        }).filter(item => !!item).collect(new DomQueryCollector());\r\n\r\n        return elements\r\n            .orElseLazy(() => this.querySelectorAll(\"input, select, textarea, fieldset\"));\r\n    }\r\n\r\n    /**\r\n     * todo align this api with the rest of the apis\r\n     */\r\n    get disabled(): boolean {\r\n        return this.attr(\"disabled\").isPresent();\r\n    }\r\n\r\n    set disabled(disabled: boolean) {\r\n        // this.attr(\"disabled\").value = disabled + \"\";\r\n        if (!disabled) {\r\n            this.removeAttribute(\"disabled\");\r\n        } else {\r\n            this.attr(\"disabled\").value = \"disabled\";\r\n        }\r\n\r\n    }\r\n\r\n    removeAttribute(name: string) {\r\n        this.eachElem(item => item.removeAttribute(name));\r\n    }\r\n\r\n    get childNodes(): DomQuery {\r\n        let childNodeArr: Array<Element> = [];\r\n        this.eachElem((item: Element) => {\r\n            childNodeArr = childNodeArr.concat(objToArray(item.childNodes));\r\n        });\r\n        return new DomQuery(...childNodeArr);\r\n    }\r\n\r\n    /**\r\n     * binding into stream\r\n     */\r\n    get stream(): Stream<DomQuery> {\r\n        return new Stream<DomQuery>(...this.asArray);\r\n    }\r\n\r\n    /**\r\n     * fetches a lazy stream representation\r\n     * lazy should be applied if you have some filters etc\r\n     * in between, this can reduce the number of post filter operations\r\n     * and ram usage\r\n     * significantly because the operations are done lazily and stop\r\n     * once they hit a dead end.\r\n     */\r\n    get lazyStream(): LazyStream<DomQuery> {\r\n        return LazyStream.ofStreamDataSource(this);\r\n    }\r\n\r\n    get asArray(): Array<DomQuery> {\r\n        let ret: Array<DomQuery> = [];\r\n        this.each((item) => {\r\n            ret.push(item);\r\n        });\r\n        return ret;\r\n    }\r\n\r\n    /**\r\n     * easy query selector all producer\r\n     *\r\n     * @param selector the selector\r\n     * @returns a results dom query object\r\n     */\r\n    static querySelectorAll(selector: string): DomQuery {\r\n        return new DomQuery(document).querySelectorAll(selector);\r\n    }\r\n\r\n    /**\r\n     * byId producer\r\n     *\r\n     * @param selector id\r\n     * @return a DomQuery containing the found elements\r\n     */\r\n    static byId(selector: string | DomQuery | Element): DomQuery {\r\n        if (isString(selector)) {\r\n            return new DomQuery(document).byId(<string>selector);\r\n        } else {\r\n            return new DomQuery(<any>selector);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * byTagName producer\r\n     *\r\n     * @param selector name\r\n     * @return a DomQuery containing the found elements\r\n     */\r\n    static byTagName(selector: string | DomQuery | Element): DomQuery {\r\n        if (isString(selector)) {\r\n            return new DomQuery(document).byTagName(<string>selector);\r\n        } else {\r\n            return new DomQuery(<any>selector);\r\n        }\r\n    }\r\n\r\n    static globalEval(code: string, nonce?: string): DomQuery {\r\n        return new DomQuery(document).globalEval(code, nonce);\r\n    }\r\n\r\n    /**\r\n     * builds the ie nodes properly in a placeholder\r\n     * and bypasses a non script insert bug that way\r\n     * @param markup the marku code\r\n     */\r\n    static fromMarkup(markup: string): DomQuery {\r\n\r\n        //https://developer.mozilla.org/de/docs/Web/API/DOMParser license creative commons\r\n        const doc = document.implementation.createHTMLDocument(\"\");\r\n        markup = trim(markup);\r\n        let lowerMarkup = markup.toLowerCase();\r\n        if (lowerMarkup.indexOf('<!doctype') != -1 ||\r\n            lowerMarkup.indexOf('<html') != -1 ||\r\n            lowerMarkup.indexOf('<head') != -1 || //TODO proper regexps here to avoid embedded tags with same element names to be triggered\r\n            lowerMarkup.indexOf('<body') != -1) {\r\n            doc.documentElement.innerHTML = markup;\r\n            return new DomQuery(doc.documentElement);\r\n        } else {\r\n            let startsWithTag = function (str: string, tagName: string) {\r\n                let tag1 = [\"<\", tagName, \">\"].join(\"\");\r\n                let tag2 = [\"<\", tagName, \" \"].join(\"\");\r\n                return (str.indexOf(tag1) == 0) || (str.indexOf(tag2) == 0);\r\n            };\r\n\r\n            let dummyPlaceHolder = new DomQuery(document.createElement(\"div\"));\r\n\r\n            //table needs special treatment due to the browsers auto creation\r\n            if (startsWithTag(lowerMarkup, \"thead\") || startsWithTag(lowerMarkup, \"tbody\")) {\r\n                dummyPlaceHolder.html(`<table>${markup}</table>`);\r\n                return dummyPlaceHolder.querySelectorAll(\"table\").get(0).childNodes.detach();\r\n            } else if (startsWithTag(lowerMarkup, \"tfoot\")) {\r\n                dummyPlaceHolder.html(`<table><thead></thead><tbody><tbody${markup}</table>`);\r\n                return dummyPlaceHolder.querySelectorAll(\"table\").get(2).childNodes.detach();\r\n            } else if (startsWithTag(lowerMarkup, \"tr\")) {\r\n                dummyPlaceHolder.html(`<table><tbody>${markup}</tbody></table>`);\r\n                return dummyPlaceHolder.querySelectorAll(\"tbody\").get(0).childNodes.detach();\r\n            } else if (startsWithTag(lowerMarkup, \"td\")) {\r\n                dummyPlaceHolder.html(`<table><tbody><tr>${markup}</tr></tbody></table>`);\r\n                return dummyPlaceHolder.querySelectorAll(\"tr\").get(0).childNodes.detach();\r\n            }\r\n\r\n            dummyPlaceHolder.html(markup);\r\n            return dummyPlaceHolder.childNodes.detach();\r\n        }\r\n\r\n    }\r\n\r\n\r\n    /**\r\n     * returns the nth element as domquery\r\n     * from the internal elements\r\n     * note if you try to reach a non existing element position\r\n     * you will get back an absent entry\r\n     *\r\n     * @param index the nth index\r\n     */\r\n    get(index: number): DomQuery {\r\n        return (index < this.rootNode.length) ? new DomQuery(this.rootNode[index]) : DomQuery.absent;\r\n    }\r\n\r\n    /**\r\n     * returns the nth element as optional of an Element object\r\n     * @param index the number from the index\r\n     * @param defaults the default value if the index is overrun default Optional.absent\r\n     */\r\n    getAsElem(index: number, defaults: Optional<any> = Optional.absent): Optional<Element> {\r\n        return (index < this.rootNode.length) ? Optional.fromNullable(this.rootNode[index]) : defaults;\r\n    }\r\n\r\n    /**\r\n     * returns the value array< of all elements\r\n     */\r\n    allElems(): Array<Element> {\r\n        return this.rootNode;\r\n    }\r\n\r\n    /**\r\n     * absent no values reached?\r\n     */\r\n    isAbsent(): boolean {\r\n        return this.length == 0;\r\n    }\r\n\r\n    /**\r\n     * should make the code clearer\r\n     * note if you pass a function\r\n     * this refers to the active dopmquery object\r\n     */\r\n    isPresent(presentRunnable ?: (elem ?: DomQuery) => void): boolean {\r\n        let absent = this.isAbsent();\r\n        if (!absent && presentRunnable) {\r\n            presentRunnable.call(this, this)\r\n        }\r\n        return !absent;\r\n    }\r\n\r\n    /**\r\n     * should make the code clearer\r\n     * note if you pass a function\r\n     * this refers to the active dopmquery object\r\n     *\r\n     *\r\n     * @param presentRunnable\r\n     */\r\n    ifPresentLazy(presentRunnable: (elem ?: DomQuery) => void = function () {\r\n    }): DomQuery {\r\n        this.isPresent.call(this, presentRunnable);\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * remove all affected nodes from this query object from the dom tree\r\n     */\r\n    delete() {\r\n        this.eachElem((node: Element) => {\r\n            if (node.parentNode) {\r\n                node.parentNode.removeChild(node);\r\n            }\r\n        });\r\n    }\r\n\r\n    /**\r\n     * query selector all on the existing dom query object\r\n     *\r\n     * @param selector the standard selector\r\n     * @return a DomQuery with the results\r\n     */\r\n    querySelectorAll(selector): DomQuery {\r\n        if (!this?.rootNode?.length) {\r\n            return this;\r\n        }\r\n        let nodes = [];\r\n        for (let cnt = 0; cnt < this.rootNode.length; cnt++) {\r\n            if (!this.rootNode[cnt]?.querySelectorAll) {\r\n                continue;\r\n            }\r\n            let res = this.rootNode[cnt].querySelectorAll(selector);\r\n            nodes = nodes.concat(objToArray(res));\r\n        }\r\n\r\n        return new DomQuery(...nodes);\r\n    }\r\n\r\n    /**\r\n     * core byId method\r\n     * @param id the id to search for\r\n     * @param includeRoot also match the root element?\r\n     */\r\n    byId(id: string, includeRoot?: boolean): DomQuery {\r\n        let res: Array<DomQuery> = [];\r\n        for (let cnt = 0; includeRoot && cnt < this.rootNode.length; cnt++) {\r\n            if (this.rootNode[cnt]?.id == id) {\r\n                res.push(new DomQuery(this.rootNode[cnt]));\r\n            }\r\n        }\r\n        //for some strange kind of reason the # selector fails\r\n        //on hidden elements we use the attributes match selector\r\n        //that works\r\n        res = res.concat(this.querySelectorAll(`[id=\"${id}\"]`));\r\n        return new DomQuery(...res);\r\n    }\r\n\r\n    /**\r\n     * same as byId just for the tag name\r\n     * @param tagName\r\n     * @param includeRoot\r\n     */\r\n    byTagName(tagName: string, includeRoot ?: boolean): DomQuery {\r\n        let res = [];\r\n        for (let cnt = 0; includeRoot && cnt < this.rootNode.length; cnt++) {\r\n            if (this.rootNode[cnt]?.tagName == tagName) {\r\n                res.push(new DomQuery(this.rootNode[cnt]));\r\n            }\r\n        }\r\n        res = res.concat(this.querySelectorAll(tagName));\r\n        return new DomQuery(...res);\r\n    }\r\n\r\n    /**\r\n     * attr accessor, usage myQuery.attr(\"class\").value = \"bla\"\r\n     * or let value myQuery.attr(\"class\").value\r\n     * @param attr the attribute to set\r\n     * @param defaultValue the default value in case nothing is presented (defaults to null)\r\n     */\r\n    attr(attr: string, defaultValue: string = null): ElementAttribute {\r\n        return new ElementAttribute(this, attr, defaultValue);\r\n    }\r\n\r\n    /**\r\n     * hasclass, checks for an existing class in the class attributes\r\n     *\r\n     * @param clazz the class to search for\r\n     */\r\n    hasClass(clazz: string) {\r\n        let hasIt = false;\r\n\r\n        this.each((item) => {\r\n            let oldClass = item.attr(\"class\").value || \"\";\r\n            if (oldClass.toLowerCase().indexOf(clazz.toLowerCase()) == -1) {\r\n                return;\r\n            } else {\r\n                let oldClasses = oldClass.split(/\\s+/gi);\r\n                let found = false;\r\n                for (let cnt = 0; cnt < oldClasses.length && !found; cnt++) {\r\n                    found = oldClasses[cnt].toLowerCase() == clazz.toLowerCase();\r\n                }\r\n                hasIt = hasIt || found;\r\n                if (hasIt) {\r\n                    return false;\r\n                }\r\n            }\r\n        });\r\n        return hasIt;\r\n    }\r\n\r\n    /**\r\n     * appends a class string if not already in the element(s)\r\n     *\r\n     * @param clazz the style class to append\r\n     */\r\n    addClass(clazz: string): DomQuery {\r\n        this.each((item) => {\r\n            let oldClass = item.attr(\"class\").value || \"\";\r\n            if (!this.hasClass(clazz)) {\r\n                item.attr(\"class\").value = trim(oldClass + \" \" + clazz);\r\n                return;\r\n            }\r\n        });\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * remove the style class if in the class definitions\r\n     *\r\n     * @param clazz\r\n     */\r\n    removeClass(clazz: string): DomQuery {\r\n        this.each((item) => {\r\n            if (this.hasClass(clazz)) {\r\n                let oldClass = item.attr(\"class\").value || \"\";\r\n                let newClasses = [];\r\n                let oldClasses = oldClass.split(/\\s+/gi);\r\n                for (let cnt = 0; cnt < oldClasses.length; cnt++) {\r\n                    if (oldClasses[cnt].toLowerCase() != clazz.toLowerCase()) {\r\n                        newClasses.push(oldClasses[cnt]);\r\n                    }\r\n                }\r\n                item.attr(\"class\").value = newClasses.join(\" \");\r\n            }\r\n        });\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * checks whether we have a multipart element in our children\r\n     */\r\n    isMultipartCandidate(): boolean {\r\n        return this.querySelectorAll(\"input[type='file']\").firstElem().isPresent();\r\n    }\r\n\r\n    /**\r\n     * innerHtml equivalkent\r\n     * equivalent to jqueries html\r\n     * as setter the html is set and the\r\n     * DomQuery is given back\r\n     * as getter the html string is returned\r\n     *\r\n     * @param inval\r\n     */\r\n    html(inval?: string): DomQuery | Optional<string> {\r\n        if (Optional.fromNullable(inval).isAbsent()) {\r\n            return this.isPresent() ? Optional.fromNullable(this.innerHtml) : Optional.absent;\r\n        }\r\n        this.innerHtml = inval;\r\n\r\n        return this;\r\n    }\r\n\r\n    set innerHtml(inVal: string) {\r\n        this.eachElem(elem => elem.innerHTML = inVal);\r\n    }\r\n\r\n    get innerHtml(): string {\r\n        let retArr = [];\r\n        this.eachElem(elem => retArr.push(elem.innerHTML));\r\n        return retArr.join(\"\");\r\n    }\r\n\r\n    //source: https://developer.mozilla.org/en-US/docs/Web/API/Element/matches\r\n    //code snippet license: https://creativecommons.org/licenses/by-sa/2.5/\r\n    private _mozMatchesSelector(toMatch: Element, selector: string): boolean {\r\n        let prot: { [key: string]: Function } = (<any>toMatch);\r\n        let matchesSelector: Function = prot.matchesSelector ||\r\n            prot.mozMatchesSelector ||\r\n            prot.msMatchesSelector ||\r\n            prot.oMatchesSelector ||\r\n            prot.webkitMatchesSelector ||\r\n            function (s: string) {\r\n                let matches: NodeListOf<HTMLElement> = (document || (<any>window).ownerDocument).querySelectorAll(s),\r\n                    i = matches.length;\r\n                while (--i >= 0 && matches.item(i) !== toMatch) {\r\n                }\r\n                return i > -1;\r\n            };\r\n        return matchesSelector.call(toMatch, selector);\r\n    }\r\n\r\n    /**\r\n     * filters the current dom query elements\r\n     * upon a given selector\r\n     *\r\n     * @param selector\r\n     */\r\n    filterSelector(selector: string): DomQuery {\r\n        let matched = [];\r\n\r\n        this.eachElem(item => {\r\n            if (this._mozMatchesSelector(item, selector)) {\r\n                matched.push(item)\r\n            }\r\n        });\r\n        return new DomQuery(...matched);\r\n    }\r\n\r\n    matchesSelector(selector: string): boolean {\r\n        this.eachElem(item => {\r\n            if (!this._mozMatchesSelector(item, selector)) {\r\n                return false;\r\n            }\r\n        });\r\n        return true;\r\n    }\r\n\r\n    /**\r\n     * easy node traversal, you can pass\r\n     * a set of node selectors which are joined as direct childs\r\n     *\r\n     * not the rootnodes are not in the getIf, those are always the child nodes\r\n     *\r\n     * @param nodeSelector\r\n     */\r\n    getIf(...nodeSelector: Array<string>): DomQuery {\r\n\r\n        let selectorStage: DomQuery = this.childNodes;\r\n        for (let cnt = 0; cnt < nodeSelector.length; cnt++) {\r\n            selectorStage = selectorStage.filterSelector(nodeSelector[cnt]);\r\n            if (selectorStage.isAbsent()) {\r\n                return selectorStage;\r\n            }\r\n        }\r\n        return selectorStage;\r\n    }\r\n\r\n    eachElem(func: (item: Element, cnt?: number) => any): DomQuery {\r\n        for (let cnt = 0, len = this.rootNode.length; cnt < len; cnt++) {\r\n            if (func(this.rootNode[cnt], cnt) === false) {\r\n                break;\r\n            }\r\n        }\r\n        return this;\r\n    }\r\n\r\n    firstElem(func: (item: Element, cnt?: number) => any = item => item): DomQuery {\r\n        if (this.rootNode.length > 1) {\r\n            func(this.rootNode[0], 0);\r\n        }\r\n        return this;\r\n    }\r\n\r\n    each(func: (item: DomQuery, cnt?: number) => any): DomQuery {\r\n        Stream.of(...this.rootNode)\r\n            .each((item, cnt) => {\r\n                //we could use a filter, but for the best performance we dont\r\n                if (item == null) {\r\n                    return;\r\n                }\r\n                return func(DomQuery.byId(item), cnt);\r\n            });\r\n\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * returns a new dom query containing only the first element max\r\n     *\r\n     * @param func a an optional callback function to perform an operation on the first element\r\n     */\r\n    first(func: (item: DomQuery, cnt?: number) => any = (item) => item): DomQuery {\r\n        if (this.rootNode.length >= 1) {\r\n            func(this.get(0), 0);\r\n            return this.get(0);\r\n        }\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * filter function which filters a subset\r\n     *\r\n     * @param func\r\n     */\r\n    filter(func: (item: DomQuery) => boolean): DomQuery {\r\n        let reArr: Array<DomQuery> = [];\r\n        this.each((item: DomQuery) => {\r\n            func(item) ? reArr.push(item) : null;\r\n        });\r\n        return new DomQuery(...<any>reArr);\r\n    }\r\n\r\n    //TODO append prepend\r\n\r\n    /**\r\n     * global eval head appendix method\r\n     * no other methods are supported anymore\r\n     * @param code the code to be evaled\r\n     * @param  nonce optional  nonce key for higher security\r\n     */\r\n    globalEval(code: string, nonce ?: string): DomQuery {\r\n        let head = document.getElementsByTagName(\"head\")[0] || document.documentElement;\r\n        let script = document.createElement(\"script\");\r\n        if (nonce) {\r\n            script.setAttribute(\"nonce\", nonce);\r\n        }\r\n        script.type = \"text/javascript\";\r\n        script.innerHTML = code;\r\n        let newScriptElement = head.appendChild(script);\r\n        head.removeChild(newScriptElement);\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * detaches a set of nodes from their parent elements\r\n     * in a browser independend manner\r\n     * @param {Object} items the items which need to be detached\r\n     * @return {Array} an array of nodes with the detached dom nodes\r\n     */\r\n    detach(): DomQuery {\r\n        this.eachElem((item: Element) => {\r\n            item.parentNode.removeChild(item);\r\n        });\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * appends the current set of elements\r\n     * to the element or first element passed via elem\r\n     * @param elem\r\n     */\r\n    appendTo(elem: DomQuery) {\r\n        this.eachElem((item) => {\r\n            let value1: Element = <Element>elem.getAsElem(0).orElseLazy(() => {\r\n                return {\r\n                    appendChild: (theItem: any) => {\r\n                    }\r\n                }\r\n            }).value;\r\n            value1.appendChild(item);\r\n        });\r\n    }\r\n\r\n    /**\r\n     * loads and evals a script from a source uri\r\n     *\r\n     * @param src the source to be loaded and evaled\r\n     * @param defer in miliseconds execution default (0 == no defer)\r\n     * @param charSet\r\n     */\r\n    loadScriptEval(src: string, defer: number = 0, charSet: string = \"utf-8\") {\r\n        let xhr = new XMLHttpRequest();\r\n        xhr.open(\"GET\", src, false);\r\n\r\n        if (charSet) {\r\n            xhr.setRequestHeader(\"Content-Type\", \"application/x-javascript; charset:\" + charSet);\r\n        }\r\n\r\n        xhr.send(null);\r\n\r\n        xhr.onload = (responseData: any) => {\r\n            //defer also means we have to process after the ajax response\r\n            //has been processed\r\n            //we can achieve that with a small timeout, the timeout\r\n            //triggers after the processing is done!\r\n            if (!defer) {\r\n                this.globalEval(xhr.responseText.replace(\"\\n\", \"\\r\\n\") + \"\\r\\n//@ sourceURL=\" + src);\r\n            } else {\r\n                //TODO not ideal we maybe ought to move to something else here\r\n                //but since it is not in use yet, it is ok\r\n                setTimeout(() => {\r\n                    this.globalEval(xhr.responseText + \"\\r\\n//@ sourceURL=\" + src);\r\n                }, defer);\r\n            }\r\n        };\r\n\r\n        xhr.onerror = (data: any) => {\r\n            throw Error(data);\r\n        };\r\n        //since we are synchronous we do it after not with onReadyStateChange\r\n\r\n        return this;\r\n    }\r\n\r\n    insertAfter(...toInsertParams: Array<DomQuery>): DomQuery {\r\n\r\n\r\n        this.each(existingItem => {\r\n            let existingElement = existingItem.getAsElem(0).value;\r\n            let rootNode = existingElement.parentNode;\r\n            for (let cnt = 0; cnt < toInsertParams.length; cnt++) {\r\n                let nextSibling: Element = <any>existingElement.nextSibling;\r\n                toInsertParams[cnt].eachElem(insertElem => {\r\n                    if (nextSibling) {\r\n                        rootNode.insertBefore(insertElem, nextSibling);\r\n                        existingElement = nextSibling;\r\n                    } else {\r\n                        rootNode.appendChild(insertElem);\r\n                    }\r\n                });\r\n\r\n            }\r\n        });\r\n\r\n        let res = [];\r\n        res.push(this);\r\n        res = res.concat(toInsertParams);\r\n        return new DomQuery(...res);\r\n    }\r\n\r\n    insertBefore(...toInsertParams: Array<DomQuery>): DomQuery {\r\n        this.each(existingItem => {\r\n            let existingElement = existingItem.getAsElem(0).value;\r\n            let rootNode = existingElement.parentNode;\r\n            for (let cnt = 0; cnt < toInsertParams.length; cnt++) {\r\n                toInsertParams[cnt].eachElem(insertElem => {\r\n                    rootNode.insertBefore(insertElem, existingElement);\r\n                });\r\n            }\r\n        });\r\n        let res = [];\r\n        res.push(this);\r\n        res = res.concat(toInsertParams);\r\n        return new DomQuery(...res);\r\n    }\r\n\r\n    orElse(...elseValue: any): DomQuery {\r\n        if (this.isPresent()) {\r\n            return this;\r\n        } else {\r\n            return new DomQuery(...elseValue);\r\n        }\r\n    }\r\n\r\n    orElseLazy(func: () => any): DomQuery {\r\n        if (this.isPresent()) {\r\n            return this;\r\n        } else {\r\n            return new DomQuery(func());\r\n        }\r\n    }\r\n\r\n    parents(tagName: string): DomQuery {\r\n        const retSet: Set<Element> = new Set();\r\n        const retArr: Array<Element> = [];\r\n        const lowerTagName = tagName.toLowerCase();\r\n\r\n        let resolveItem = (item: Element) => {\r\n            if ((item.tagName || \"\").toLowerCase() == lowerTagName && !retSet.has(item)) {\r\n                retSet.add(item);\r\n                retArr.push(item);\r\n            }\r\n        };\r\n\r\n        this.eachElem((item: Element) => {\r\n            while (item.parentNode) {\r\n                item = <Element>item.parentNode;\r\n                resolveItem(item);\r\n                //nested forms not possible, performance shortcut\r\n                if (tagName == \"form\" && retArr.length) {\r\n                    return false;\r\n                }\r\n            }\r\n        });\r\n\r\n        return new DomQuery(...retArr);\r\n    }\r\n\r\n    copyAttrs(sourceItem: DomQuery | XMLQuery): DomQuery {\r\n        sourceItem.eachElem((sourceNode: Element) => {\r\n            let attrs: Array<Attr> = objToArray(sourceNode.attributes);\r\n            for (let item of attrs) {\r\n                let value: string = item.value;\r\n                let name: string = item.name;\r\n\r\n                switch (name) {\r\n                    case \"id\":\r\n                        this.id.value = value;\r\n                        break;\r\n                    case \"disabled\":\r\n                        this.resolveAttributeHolder(\"disabled\").disabled = value;\r\n                        break;\r\n                    case \"checked\":\r\n                        this.resolveAttributeHolder(\"checked\").checked = value;\r\n                        break;\r\n                    default:\r\n                        this.attr(name).value = value;\r\n                }\r\n            }\r\n        });\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * resolves an attribute holder compared\r\n     * @param attr\r\n     */\r\n    private resolveAttributeHolder(attrName: string = \"value\"): HTMLFormElement | any {\r\n        let ret = [];\r\n        ret[attrName] = null;\r\n        return (attrName in this.getAsElem(0).value) ?\r\n            this.getAsElem(0).value :\r\n            ret;\r\n    }\r\n\r\n    /**\r\n     * outerhtml convenience method\r\n     * browsers only support innerHTML but\r\n     * for instance for your jsf.js we have a full\r\n     * replace pattern which needs outerHTML processing\r\n     *\r\n     * @param markup\r\n     * @param runEmbeddedScripts\r\n     * @param runEmbeddedCss\r\n     */\r\n    outerHTML(markup: string, runEmbeddedScripts ?: boolean, runEmbeddedCss ?: boolean): DomQuery {\r\n        if(this.isAbsent()) {\r\n            return;\r\n        }\r\n\r\n        let nodes = DomQuery.fromMarkup(markup);\r\n        let res = [];\r\n        let toReplace = this.getAsElem(0).value;\r\n        let firstInsert = nodes.get(0);\r\n        let parentNode = toReplace.parentNode;\r\n        let replaced = firstInsert.getAsElem(0).value;\r\n        parentNode.replaceChild(replaced, toReplace);\r\n        res.push(new DomQuery(replaced));\r\n        //no replacement possible\r\n        if(this.isAbsent()) {\r\n            return this;\r\n        }\r\n\r\n        let insertAdditionalItems = [];\r\n\r\n        if (nodes.length > 1) {\r\n            insertAdditionalItems = insertAdditionalItems.concat(...nodes.values.slice(1));\r\n            res.push(DomQuery.byId(replaced).insertAfter(new DomQuery(...insertAdditionalItems)));\r\n        }\r\n\r\n        if (runEmbeddedScripts) {\r\n            this.runScripts();\r\n        }\r\n        if (runEmbeddedCss) {\r\n            this.runCss();\r\n        }\r\n\r\n        return nodes;\r\n    }\r\n\r\n    /**\r\n     * Run through the given nodes in the DomQuery execute the inline scripts\r\n     * @param whilteListed: optional whitelist function which can filter out script tags which are not processed\r\n     * defaults to the standard jsf.js exclusion (we use this code for myfaces)\r\n     */\r\n    runScripts(whilteListed: (val: string) => boolean = DEFAULT_JSF_WHITELIST): DomQuery {\r\n        let finalScripts = [],\r\n            equi = equalsIgnoreCase,\r\n            execScrpt = (item) => {\r\n                let tagName = item.tagName;\r\n                let itemType = item.type || \"\";\r\n                if (tagName && equi(tagName, \"script\") &&\r\n                    (itemType === \"\" || equi(itemType, \"text/javascript\") ||\r\n                        equi(itemType, \"javascript\") ||\r\n                        equi(itemType, \"text/ecmascript\") ||\r\n                        equi(itemType, \"ecmascript\"))) {\r\n                    let src = item.getAttribute('src');\r\n                    if ('undefined' != typeof src\r\n                        && null != src\r\n                        && src.length > 0\r\n                    ) {\r\n                        //we have to move this into an inner if because chrome otherwise chokes\r\n                        //due to changing the and order instead of relying on left to right\r\n                        //if jsf.js is already registered we do not replace it anymore\r\n                        if (whilteListed(src)) {\r\n                            if (finalScripts.length) {\r\n                                //script source means we have to eval the existing\r\n                                //scripts before running the include\r\n                                this.globalEval(finalScripts.join(\"\\n\"));\r\n\r\n                                finalScripts = [];\r\n                            }\r\n                            this.loadScriptEval(src, 0, \"UTF-8\");\r\n                        }\r\n\r\n                    } else {\r\n                        // embedded script auto eval\r\n                        //TODO this probably needs to be changed due to our new parsing structures\r\n                        //probably not needed anymore\r\n                        let evalText = trim(item.text || item.innerText || item.innerHTML);\r\n                        let go = true;\r\n\r\n                        while (go) {\r\n                            go = false;\r\n                            if (evalText.substring(0, 4) == \"<!--\") {\r\n                                evalText = evalText.substring(4);\r\n                                go = true;\r\n                            }\r\n                            if (evalText.substring(0, 4) == \"//<!--\") {\r\n                                evalText = evalText.substring(6);\r\n                                go = true;\r\n                            }\r\n                            if (evalText.substring(0, 11) == \"//<![CDATA[\") {\r\n                                evalText = evalText.substring(11);\r\n                                go = true;\r\n                            }\r\n                        }\r\n                        // we have to run the script under a global context\r\n                        //we store the script for less calls to eval\r\n                        finalScripts.push(evalText);\r\n\r\n                    }\r\n                }\r\n            };\r\n        try {\r\n            let scriptElements = new DomQuery(this.filterSelector(\"script\"), this.querySelectorAll(\"script\"));\r\n            //script execution order by relative pos in their dom tree\r\n            scriptElements.stream\r\n                .flatMap(item => {\r\n                    return Stream.of(item.values)\r\n                })\r\n                .sort((node1, node2) => {\r\n                    return node1.compareDocumentPosition(node2) - 3; //preceding 2, following == 4\r\n                })\r\n                .each(item => execScrpt(item));\r\n\r\n            if (finalScripts.length) {\r\n                this.globalEval(finalScripts.join(\"\\n\"));\r\n            }\r\n        } catch (e) {\r\n            if (window.console && window.console.error) {\r\n                //not sure if we\r\n                //should use our standard\r\n                //error mechanisms here\r\n                //because in the head appendix\r\n                //method only a console\r\n                //error would be raised as well\r\n                console.error(e.message || e.description);\r\n            }\r\n        } finally {\r\n            //the usual ie6 fix code\r\n            //the IE6 garbage collector is broken\r\n            //nulling closures helps somewhat to reduce\r\n            //mem leaks, which are impossible to avoid\r\n            //at this browser\r\n            execScrpt = null;\r\n        }\r\n        return this;\r\n    }\r\n\r\n    runCss(): DomQuery {\r\n\r\n        const applyStyle = (item: Element, style: string) => {\r\n                let newSS: HTMLStyleElement = document.createElement(\"style\");\r\n                document.getElementsByTagName(\"head\")[0].appendChild(newSS);\r\n\r\n                let styleSheet = newSS.sheet ?? (<any>newSS).styleSheet;\r\n\r\n                newSS.setAttribute(\"rel\", item.getAttribute(\"rel\") ?? \"stylesheet\");\r\n                newSS.setAttribute(\"type\", item.getAttribute(\"type\") ?? \"text/css\");\r\n\r\n                if (styleSheet?.cssText ?? false) {\r\n                    styleSheet.cssText = style;\r\n                } else {\r\n                    newSS.appendChild(document.createTextNode(style));\r\n                }\r\n            },\r\n\r\n            execCss = (item: Element) => {\r\n                const tagName = item.tagName;\r\n                if (tagName && equalsIgnoreCase(tagName, \"link\") && equalsIgnoreCase(item.getAttribute(\"type\"), \"text/css\")) {\r\n                    applyStyle(item, \"@import url('\" + item.getAttribute(\"href\") + \"');\");\r\n                } else if (tagName && equalsIgnoreCase(tagName, \"style\") && equalsIgnoreCase(item.getAttribute(\"type\"), \"text/css\")) {\r\n                    let innerText = [];\r\n                    //compliant browsers know child nodes\r\n                    let childNodes: NodeList = item.childNodes;\r\n                    if (childNodes) {\r\n                        const len = childNodes.length;\r\n                        for (let cnt = 0; cnt < len; cnt++) {\r\n                            innerText.push((<Element>childNodes[cnt]).innerHTML || (<CharacterData>childNodes[cnt]).data);\r\n                        }\r\n                        //non compliant ones innerHTML\r\n                    } else if (item.innerHTML) {\r\n                        innerText.push(item.innerHTML);\r\n                    }\r\n\r\n                    applyStyle(item, innerText.join(\"\"));\r\n                }\r\n            };\r\n\r\n        const scriptElements: DomQuery = new DomQuery(this.filterSelector(\"link, style\"), this.querySelectorAll(\"link, style\"));\r\n\r\n        scriptElements.stream\r\n            .flatMap(item => {\r\n                return Stream.of(item.values)\r\n            })\r\n            .sort((node1, node2) => {\r\n                return node1.compareDocumentPosition(node2) - 3; //preceding 2, following == 4\r\n            })\r\n            .each(item => execCss(item));\r\n\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * fires a click event on the underlying dom elements\r\n     */\r\n    click(): DomQuery {\r\n        this.fireEvent(\"click\");\r\n        return this;\r\n    }\r\n\r\n    addEventListener(type: string, listener: (evt: Event) => void, options?: boolean | EventListenerOptions): DomQuery {\r\n        this.eachElem((node: Element) => {\r\n            node.addEventListener(type, listener, options);\r\n        });\r\n        return this;\r\n    }\r\n\r\n    removeEventListener(type: string, listener: (evt: Event) => void, options?: boolean | EventListenerOptions): DomQuery {\r\n        this.eachElem((node: Element) => {\r\n            node.removeEventListener(type, listener, options);\r\n        });\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * fires an event\r\n     */\r\n    fireEvent(eventName: string) {\r\n        this.eachElem((node: Element) => {\r\n            var doc;\r\n            if (node.ownerDocument) {\r\n                doc = node.ownerDocument;\r\n            } else if (node.nodeType == 9) {\r\n                // the node may be the document itself, nodeType 9 = DOCUMENT_NODE\r\n                doc = node;\r\n            } else {\r\n                throw new Error(\"Invalid node passed to fireEvent: \" + node.id);\r\n            }\r\n\r\n            if (node.dispatchEvent) {\r\n                // Gecko-style approach (now the standard) takes more work\r\n                var eventClass = \"\";\r\n\r\n                // Different events have different event classes.\r\n                // If this switch statement can't map an eventName to an eventClass,\r\n                // the event firing is going to fail.\r\n                switch (eventName) {\r\n                    case \"click\": // Dispatching of 'click' appears to not work correctly in Safari. Use 'mousedown' or 'mouseup' instead.\r\n                    case \"mousedown\":\r\n                    case \"mouseup\":\r\n                        eventClass = \"MouseEvents\";\r\n                        break;\r\n\r\n                    case \"focus\":\r\n                    case \"change\":\r\n                    case \"blur\":\r\n                    case \"select\":\r\n                        eventClass = \"HTMLEvents\";\r\n                        break;\r\n\r\n                    default:\r\n                        throw \"fireEvent: Couldn't find an event class for event '\" + eventName + \"'.\";\r\n                        break;\r\n                }\r\n                let event = doc.createEvent(eventClass);\r\n                event.initEvent(eventName, true, true); // All events created as bubbling and cancelable.\r\n\r\n                event.synthetic = true; // allow detection of synthetic events\r\n                // The second parameter says go ahead with the default action\r\n                node.dispatchEvent(event);\r\n            } else if ((<any>node).fireEvent) {\r\n                // IE-old school style, you can drop this if you don't need to support IE8 and lower\r\n                var event = doc.createEventObject();\r\n                event.synthetic = true; // allow detection of synthetic events\r\n                (<any>node).fireEvent(\"on\" + eventName, event);\r\n            }\r\n        })\r\n    }\r\n\r\n    textContent(joinstr: string = \"\"): string {\r\n        return this.stream\r\n            .map((value: DomQuery) => {\r\n                let item = value.getAsElem(0).orElseLazy(() => {\r\n                    return <any>{\r\n                        textContent: \"\"\r\n                    };\r\n                }).value;\r\n                return (<any>item).textContent || \"\";\r\n            })\r\n            .reduce((text1, text2) => text1 + joinstr + text2, \"\").value;\r\n    }\r\n\r\n    innerText(joinstr: string = \"\"): string {\r\n        return this.stream\r\n            .map((value: DomQuery) => {\r\n                let item = value.getAsElem(0).orElseLazy(() => {\r\n                    return <any>{\r\n                        innerText: \"\"\r\n                    };\r\n                }).value;\r\n                return (<any>item).innerText || \"\";\r\n            })\r\n            .reduce((text1, text2) => [text1, text2].join(joinstr), \"\").value;\r\n\r\n    }\r\n\r\n    /**\r\n     * encodes all input elements properly into respective\r\n     * config entries, this can be used\r\n     * for legacy systems, for newer usecases, use the\r\n     * HTML5 Form class which all newer browsers provide\r\n     *\r\n     * @param toMerge optional config which can be merged in\r\n     * @return a copy pf\r\n     */\r\n    encodeFormElement(toMerge = new Config({})): Config {\r\n\r\n        //browser behavior no element name no encoding (normal submit fails in that case)\r\n        //https://issues.apache.org/jira/browse/MYFACES-2847\r\n        if (this.name.isAbsent()) {\r\n            return;\r\n        }\r\n\r\n        //lets keep it sideffects free\r\n        let target = toMerge.shallowCopy;\r\n\r\n        this.each((element: DomQuery) => {\r\n            if (element.name.isAbsent()) {//no name, no encoding\r\n                return;\r\n            }\r\n            let name = element.name.value;\r\n            let tagName = element.tagName.orElse(\"__none__\").value.toLowerCase();\r\n            let elemType = element.type.orElse(\"__none__\").value.toLowerCase();\r\n\r\n            elemType = elemType.toLowerCase();\r\n\r\n            // routine for all elements\r\n            // rules:\r\n            // - process only inputs, textareas and selects\r\n            // - elements muest have attribute \"name\"\r\n            // - elements must not be disabled\r\n            if (((tagName == \"input\" || tagName == \"textarea\" || tagName == \"select\") &&\r\n                (name != null && name != \"\")) && !element.disabled) {\r\n\r\n                // routine for select elements\r\n                // rules:\r\n                // - if select-one and value-Attribute exist => \"name=value\"\r\n                // (also if value empty => \"name=\")\r\n                // - if select-one and value-Attribute don't exist =>\r\n                // \"name=DisplayValue\"\r\n                // - if select multi and multple selected => \"name=value1&name=value2\"\r\n                // - if select and selectedIndex=-1 don't submit\r\n                if (tagName == \"select\") {\r\n                    // selectedIndex must be >= 0 sein to be submittet\r\n                    let selectElem: HTMLSelectElement = <HTMLSelectElement>element.getAsElem(0).value;\r\n                    if (selectElem.selectedIndex >= 0) {\r\n                        let uLen = selectElem.options.length;\r\n                        for (let u = 0; u < uLen; u++) {\r\n                            // find all selected options\r\n                            //let subBuf = [];\r\n                            if (selectElem.options[u].selected) {\r\n                                let elementOption = selectElem.options[u];\r\n                                target.assign(name).value = (elementOption.getAttribute(\"value\") != null) ?\r\n                                    elementOption.value : elementOption.text;\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n\r\n                // routine for remaining elements\r\n                // rules:\r\n                // - don't submit no selects (processed above), buttons, reset buttons, submit buttons,\r\n                // - submit checkboxes and radio inputs only if checked\r\n                if ((tagName != \"select\" && elemType != \"button\"\r\n                    && elemType != \"reset\" && elemType != \"submit\" && elemType != \"image\")\r\n                    && ((elemType != \"checkbox\" && elemType != \"radio\") || element.checked)) {\r\n                    let files: any = (<any>element.value).files;\r\n                    if (files && files.length) {\r\n                        //xhr level2\r\n                        target.assign(name).value = files[0];\r\n                    } else {\r\n                        target.assign(name).value = element.inputValue.value;\r\n                    }\r\n                }\r\n\r\n            }\r\n        });\r\n\r\n        return target;\r\n\r\n    }\r\n\r\n    get cDATAAsString(): string {\r\n        let cDataBlock = [];\r\n        // response may contain several blocks\r\n        return this.stream\r\n            .flatMap(item => item.childNodes.stream).reduce((reduced: Array<any>, item: DomQuery) => {\r\n                reduced.push((<any>item?.value?.value)?.data ?? \"\");\r\n                return reduced;\r\n            }, []).value.join(\"\");\r\n\r\n    }\r\n\r\n    subNodes(from: number, to?: number): DomQuery {\r\n        if (Optional.fromNullable(to).isAbsent()) {\r\n            to = this.length;\r\n        }\r\n        return new DomQuery(...this.rootNode.slice(from, Math.min(to, this.length)));\r\n    }\r\n\r\n    _limits = -1;\r\n\r\n    limits(end: number): IStream<DomQuery> {\r\n        this._limits = end;\r\n        return <any>this;\r\n    }\r\n\r\n    //-- internally exposed methods needed for the interconnectivity\r\n    hasNext() {\r\n        let isLimitsReached = this._limits != -1 && this.pos >= this._limits - 1;\r\n        let isEndOfArray = this.pos >= this.values.length - 1;\r\n        return !(isLimitsReached ||\r\n            isEndOfArray);\r\n    }\r\n\r\n    next(): DomQuery {\r\n        if (!this.hasNext()) {\r\n            return null;\r\n        }\r\n        this.pos++;\r\n        return new DomQuery(this.values[this.pos]);\r\n    }\r\n\r\n    reset() {\r\n        this.pos = -1;\r\n    }\r\n}\r\n\r\n/**\r\n * Various collectors\r\n * which can be used in conjunction with Streams\r\n */\r\n\r\n/**\r\n * A collector which bundles a full dom query stream into a single dom query element\r\n *\r\n * This connects basically our stream back into DomQuery\r\n */\r\nexport class DomQueryCollector implements ICollector<DomQuery, DomQuery> {\r\n\r\n    data: DomQuery[] = [];\r\n\r\n    collect(element: DomQuery) {\r\n        this.data.push(element);\r\n    }\r\n\r\n    get finalValue(): DomQuery {\r\n        return new DomQuery(...this.data);\r\n    }\r\n}\r\n\r\n/**\r\n * abbreviation for DomQuery\r\n */\r\nexport const DQ = DomQuery;\r\nexport type DQ = DomQuery;\r\n"],"mappings":";AAAA;;;;;;;;;;;;;;AAcA;;;;;;;;;;;;;;;;;;;;;;AAEA;AAEA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AAAA;AAEA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAEA;AAEA;AAAA;;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;AACA;AACA;AACA;AACA;AACA;AACA;;;AARA;AAUA;AACA;AACA;AAEA;AAAA;AACA;AACA;AAEA;AAAA;AA9BA;AAgCA;;;;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AAmYA;;;;;;;;;;;;;;;;;;;AAmBA;AACA;AAQA;;AAAA;AAAA;AAAA;;AAJA;AAEA;AAkuCA;AA9tCA;AACA;AACA;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAKA;AAHA;;AAEA;AACA;AACA;AACA;;;AAAA;AAEA;AAAA;AACA;AACA;;;AAAA;AAKA;AAHA;;AAEA;AACA;AACA;AACA;;;AAAA;AAKA;AAHA;;AAEA;AACA;AACA;AACA;;;AAAA;AAKA;AAHA;;AAEA;AACA;AACA;AACA;;;AAAA;AAKA;AAHA;;AAEA;AACA;AACA;AACA;;;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AAQA;AANA;;;;;AAKA;AACA;AACA;AACA;;;AAAA;AAQA;AANA;;;;;AAKA;AACA;AACA;AACA;;;AAAA;AAQA;AANA;;;;;AAKA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;;;AAAA;AAEA;AAAA;AACA;AACA;AAEA;AACA;AACA;;;AAJA;AAMA;AAAA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;;;AAAA;AAKA;AAHA;;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAEA;;;AAVA;AAYA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAAA;AAKA;AAHA;;AAEA;AACA;AACA;AACA;;;AAAA;AAUA;AARA;;;;;;;AAOA;AACA;AACA;AACA;;;AAAA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAAA;AAEA;;;;;AAKA;AACA;AACA;AACA;AAEA;;;;;AAKA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAEA;;;;;AAKA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;;;;AAIA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAGA;;;;;;;AAOA;AACA;AACA;AACA;AAEA;;;;AAIA;AACA;AAAA;AACA;AACA;AAEA;;AAEA;AACA;AACA;AACA;AAEA;;AAEA;AACA;AACA;AACA;AAEA;;;;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;;;AAOA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;AAKA;AACA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;;;;AAIA;AACA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;AAIA;AACA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;AAKA;AACA;AAAA;AACA;AACA;AAEA;;;;AAIA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;AAIA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;AAIA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;AAEA;AACA;AACA;AACA;AAEA;;;;;;;;AAQA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAIA;AACA;AACA;AACA;AACA;AARA;AACA;AACA;;;AAAA;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;AAKA;AACA;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;;;AAOA;AACA;AAAA;AAAA;AAAA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;;;;AAIA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;;;;;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;;AAMA;AACA;AAAA;AAAA;AAAA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAAA;AAAA;AAAA;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;;AATA;AAAA;AAWA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAAA;AAAA;AAAA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AAAA;AAAA;;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;AAGA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;;;;;AASA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;;;;AAIA;AACA;AAAA;AAAA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AAAA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;;;;;;;;AAQA;AACA;AAAA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AAEA;AAAA;AACA;AACA;AACA;AACA;;AACA;AACA;AACA;AAEA;;;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AA/vCA;AAgwCA;AAAA;AAlwCA;AAowCA;;;AAGA;AAEA;;;;AAIA;AACA;AAAA;AAEA;AASA;AAPA;AACA;AACA;AAEA;AAAA;AACA;AACA;;;AAAA;AACA;AAAA;AAXA;AAaA;;AAEA;AACA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/main/typescript/ext/monadish/DomQuery.ts\n");
/***/ }),
/***/ "./src/main/typescript/ext/monadish/Lang.ts":
/*!**************************************************!*\
!*** ./src/main/typescript/ext/monadish/Lang.ts ***!
\**************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar Promise_1 = __webpack_require__(/*! ./Promise */ \"./src/main/typescript/ext/monadish/Promise.ts\");\r\nvar Monad_1 = __webpack_require__(/*! ./Monad */ \"./src/main/typescript/ext/monadish/Monad.ts\");\r\n/**\r\n * Lang helpers crossported from the apache myfaces project\r\n */\r\nvar Lang;\r\n(function (Lang) {\r\n //should be in lang, but for now here to avoid recursive imports, not sure if typescript still has a problem with those\r\n /**\r\n * helper function to savely resolve anything\r\n * this is not an elvis operator, it resolves\r\n * a value without exception in a tree and if\r\n * it is not resolvable then an optional of\r\n * a default value is restored or Optional.empty\r\n * if none is given\r\n *\r\n * usage\r\n * <code>\r\n * let var: Optiona<string> = saveResolve(() => a.b.c.d.e, \"foobaz\")\r\n * </code>\r\n *\r\n * @param resolverProducer a lambda which can produce the value\r\n * @param defaultValue an optional default value if the producer failes to produce anything\r\n * @returns an Optional of the produced value\r\n */\r\n function saveResolve(resolverProducer, defaultValue) {\r\n if (defaultValue === void 0) { defaultValue = null; }\r\n try {\r\n var result = resolverProducer();\r\n return Monad_1.Optional.fromNullable((result !== null && result !== void 0 ? result : defaultValue));\r\n }\r\n catch (e) {\r\n return Monad_1.Optional.absent;\r\n }\r\n }\r\n Lang.saveResolve = saveResolve;\r\n function saveResolveLazy(resolverProducer, defaultValue) {\r\n if (defaultValue === void 0) { defaultValue = null; }\r\n try {\r\n var result = resolverProducer();\r\n return Monad_1.Optional.fromNullable((result !== null && result !== void 0 ? result : defaultValue()));\r\n }\r\n catch (e) {\r\n return Monad_1.Optional.absent;\r\n }\r\n }\r\n Lang.saveResolveLazy = saveResolveLazy;\r\n /**\r\n * String to array function performs a string to array transformation\r\n * @param {String} it the string which has to be changed into an array\r\n * @param {RegExp} splitter our splitter reglar expression\r\n * @return a trimmed array of the splitted string\r\n */\r\n function strToArray(it, splitter) {\r\n if (splitter === void 0) { splitter = /\\./gi; }\r\n var ret = [];\r\n it.split(splitter).forEach((function (element) {\r\n ret.push(trim(element));\r\n }));\r\n return ret;\r\n }\r\n Lang.strToArray = strToArray;\r\n /**\r\n * hyperfast trim\r\n * http://blog.stevenlevithan.com/archives/faster-trim-javascript\r\n * crossported from dojo\r\n */\r\n function trim(str) {\r\n str = str.replace(/^\\s\\s*/, '');\r\n var ws = /\\s/, i = str.length;\r\n while (ws.test(str.charAt(--i))) {\r\n //do nothing\r\n }\r\n return str.slice(0, i + 1);\r\n }\r\n Lang.trim = trim;\r\n /**\r\n * generic object arrays like dom definitions to array conversion method which\r\n * transforms any object to something array like\r\n * @param obj\r\n * @param offset\r\n * @param pack\r\n * @returns an array converted from the object\r\n */\r\n function objToArray(obj, offset, pack) {\r\n if (offset === void 0) { offset = 0; }\r\n if (pack === void 0) { pack = []; }\r\n if (((obj !== null && obj !== void 0 ? obj : \"__undefined__\")) == \"__undefined__\") {\r\n return (pack !== null && pack !== void 0 ? pack : null);\r\n }\r\n //since offset is numeric we cannot use the shortcut due to 0 being false\r\n //special condition array delivered no offset no pack\r\n if (obj instanceof Array && !offset && !pack)\r\n return obj;\r\n return pack.concat(Array.prototype.slice.call(obj, offset));\r\n }\r\n Lang.objToArray = objToArray;\r\n /**\r\n * equalsIgnoreCase, case insensitive comparison of two strings\r\n *\r\n * @param source\r\n * @param destination\r\n */\r\n function equalsIgnoreCase(source, destination) {\r\n var finalSource = (source !== null && source !== void 0 ? source : \"___no_value__\");\r\n var finalDest = (destination !== null && destination !== void 0 ? destination : \"___no_value__\");\r\n //in any other case we do a strong string comparison\r\n return finalSource.toLowerCase() === finalDest.toLowerCase();\r\n }\r\n Lang.equalsIgnoreCase = equalsIgnoreCase;\r\n /*\r\n * Promise wrappers for timeout and interval\r\n */\r\n function timeout(timeout) {\r\n var handler = null;\r\n return new Promise_1.CancellablePromise(function (apply, reject) {\r\n handler = setTimeout(function () { return apply(); }, timeout);\r\n }, function () {\r\n if (handler) {\r\n clearTimeout(handler);\r\n handler = null;\r\n }\r\n });\r\n }\r\n Lang.timeout = timeout;\r\n function interval(timeout) {\r\n var handler = null;\r\n return new Promise_1.CancellablePromise(function (apply, reject) {\r\n handler = setInterval(function () {\r\n apply();\r\n }, timeout);\r\n }, function () {\r\n if (handler) {\r\n clearInterval(handler);\r\n handler = null;\r\n }\r\n });\r\n }\r\n Lang.interval = interval;\r\n /**\r\n * runtime type assertion\r\n *\r\n * @param probe the probe to be tested for a type\r\n * @param theType the type to be tested for\r\n */\r\n function assertType(probe, theType) {\r\n return isString(theType) ? typeof probe == theType : probe instanceof theType;\r\n }\r\n Lang.assertType = assertType;\r\n /**\r\n * Backported from dojo\r\n * a failsafe string determination method\r\n * (since in javascript String != \"\" typeof alone fails!)\r\n * @param it {|Object|} the object to be checked for being a string\r\n * @return true in case of being a string false otherwise\r\n */\r\n function isString(it) {\r\n //\tsummary:\r\n //\t\tReturn true if it is a String\r\n return !!arguments.length && it != null && (typeof it == \"string\" || it instanceof String); // Boolean\r\n }\r\n Lang.isString = isString;\r\n function isFunc(it) {\r\n return it instanceof Function || typeof it === \"function\";\r\n }\r\n Lang.isFunc = isFunc;\r\n // code from https://developer.mozilla.org/de/docs/Web/JavaScript/Reference/Global_Objects/Object/assign\r\n // license https://creativecommons.org/licenses/by-sa/2.5/\r\n function objAssign(target) {\r\n var theArgs = [];\r\n for (var _i = 1; _i < arguments.length; _i++) {\r\n theArgs[_i - 1] = arguments[_i];\r\n }\r\n if (target == null) { // TypeError if undefined or null\r\n throw new TypeError('Cannot convert undefined or null to object');\r\n }\r\n var to = Object(target);\r\n if (Object.assign) {\r\n theArgs.forEach(function (item) { return Object.assign(to, item); });\r\n return to;\r\n }\r\n theArgs.forEach(function (item) {\r\n var nextSource = item;\r\n if (nextSource != null) { // Skip over if undefined or null\r\n for (var nextKey in nextSource) {\r\n // Avoid bugs when hasOwnProperty is shadowed\r\n if (Object.prototype.hasOwnProperty.call(nextSource, nextKey)) {\r\n to[nextKey] = nextSource[nextKey];\r\n }\r\n }\r\n }\r\n });\r\n return to;\r\n }\r\n Lang.objAssign = objAssign;\r\n})(Lang = exports.Lang || (exports.Lang = {}));\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/main/typescript/ext/monadish/Lang.ts.js","sources":["webpack:///./src/main/typescript/ext/monadish/Lang.ts?98d5"],"sourcesContent":["/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements.  See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License.  You may obtain a copy of the License at\r\n *\r\n *      http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\nimport {CancellablePromise} from \"./Promise\";\r\nimport {Optional} from \"./Monad\";\r\n\r\n/**\r\n * Lang helpers crossported from the apache myfaces project\r\n */\r\nexport module Lang {\r\n    \r\n\r\n    //should be in lang, but for now here to avoid recursive imports, not sure if typescript still has a problem with those\r\n    /**\r\n     * helper function to savely resolve anything\r\n     * this is not an elvis operator, it resolves\r\n     * a value without exception in a tree and if\r\n     * it is not resolvable then an optional of\r\n     * a default value is restored or Optional.empty\r\n     * if none is given\r\n     *\r\n     * usage\r\n     * <code>\r\n     *     let var: Optiona<string> = saveResolve(() => a.b.c.d.e, \"foobaz\")\r\n     * </code>\r\n     *\r\n     * @param resolverProducer a lambda which can produce the value\r\n     * @param defaultValue an optional default value if the producer failes to produce anything\r\n     * @returns an Optional of the produced value\r\n     */\r\n    export function saveResolve<T>(resolverProducer: () => T, defaultValue: T = null): Optional<T> {\r\n        try {\r\n            let result = resolverProducer();\r\n            return Optional.fromNullable(result ?? defaultValue);\r\n        } catch (e) {\r\n            return Optional.absent;\r\n        }\r\n    }\r\n\r\n    export function saveResolveLazy<T>(resolverProducer: () => T, defaultValue: () => T = null): Optional<T> {\r\n        try {\r\n            let result = resolverProducer();\r\n            return Optional.fromNullable(result ?? defaultValue());\r\n        } catch (e) {\r\n            return Optional.absent;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * String to array function performs a string to array transformation\r\n     * @param {String} it the string which has to be changed into an array\r\n     * @param {RegExp} splitter our splitter reglar expression\r\n     * @return a trimmed array of the splitted string\r\n     */\r\n    export function strToArray(it: string, splitter: string | RegExp = /\\./gi): Array<string> {\r\n\r\n        let ret = [];\r\n        it.split(splitter).forEach((element => {\r\n            ret.push(trim(element));\r\n        }));\r\n        return ret;\r\n    }\r\n\r\n    /**\r\n     * hyperfast trim\r\n     * http://blog.stevenlevithan.com/archives/faster-trim-javascript\r\n     * crossported from dojo\r\n     */\r\n    export function trim(str: string): string {\r\n        str = str.replace(/^\\s\\s*/, '');\r\n        let ws = /\\s/, i = str.length;\r\n\r\n        while (ws.test(str.charAt(--i))) {\r\n            //do nothing\r\n        }\r\n        return str.slice(0, i + 1);\r\n    }\r\n\r\n    /**\r\n     * generic object arrays like dom definitions to array conversion method which\r\n     * transforms any object to something array like\r\n     * @param obj\r\n     * @param offset\r\n     * @param pack\r\n     * @returns an array converted from the object\r\n     */\r\n    export function objToArray<T>(obj: any, offset: number = 0, pack: Array<T> = []): Array<T> {\r\n        if ((obj ?? \"__undefined__\") == \"__undefined__\") {\r\n            return pack ?? null;\r\n        }\r\n        //since offset is numeric we cannot use the shortcut due to 0 being false\r\n        //special condition array delivered no offset no pack\r\n        if ((<any>obj) instanceof Array && !offset && !pack) return obj;\r\n\r\n        return pack.concat(Array.prototype.slice.call(obj, offset));\r\n    }\r\n\r\n    /**\r\n     * equalsIgnoreCase, case insensitive comparison of two strings\r\n     *\r\n     * @param source\r\n     * @param destination\r\n     */\r\n    export function equalsIgnoreCase(source?: string, destination?: string): boolean {\r\n        let finalSource = source ?? \"___no_value__\";\r\n        let finalDest = destination ?? \"___no_value__\";\r\n\r\n        //in any other case we do a strong string comparison\r\n        return finalSource.toLowerCase() === finalDest.toLowerCase();\r\n    }\r\n\r\n    /*\r\n     * Promise wrappers for timeout and interval\r\n     */\r\n    export function timeout(timeout: number): CancellablePromise {\r\n        let handler: any = null;\r\n        return new CancellablePromise((apply: Function, reject: Function) => {\r\n            handler = setTimeout(() => apply(), timeout);\r\n        }, () => {\r\n            if (handler) {\r\n                clearTimeout(handler);\r\n                handler = null;\r\n            }\r\n        });\r\n    }\r\n\r\n    export function interval(timeout: number): CancellablePromise {\r\n        let handler: any = null;\r\n        return new CancellablePromise((apply: Function, reject: Function) => {\r\n            handler = setInterval(() => {\r\n                apply();\r\n            }, timeout);\r\n        }, () => {\r\n            if (handler) {\r\n                clearInterval(handler);\r\n                handler = null;\r\n            }\r\n        });\r\n    }\r\n\r\n    /**\r\n     * runtime type assertion\r\n     *\r\n     * @param probe the probe to be tested for a type\r\n     * @param theType the type to be tested for\r\n     */\r\n    export function assertType(probe: any, theType: any): boolean {\r\n        return isString(theType) ? typeof probe == theType : probe instanceof theType;\r\n    }\r\n\r\n    /**\r\n     * Backported from dojo\r\n     * a failsafe string determination method\r\n     * (since in javascript String != \"\" typeof alone fails!)\r\n     * @param it {|Object|} the object to be checked for being a string\r\n     * @return true in case of being a string false otherwise\r\n     */\r\n    export function isString(it?: any): boolean {\r\n        //\tsummary:\r\n        //\t\tReturn true if it is a String\r\n        return !!arguments.length && it != null && (typeof it == \"string\" || it instanceof String); // Boolean\r\n    }\r\n\r\n    export function isFunc(it: any): boolean {\r\n        return it instanceof Function || typeof it === \"function\";\r\n    }\r\n\r\n    // code from https://developer.mozilla.org/de/docs/Web/JavaScript/Reference/Global_Objects/Object/assign\r\n    // license https://creativecommons.org/licenses/by-sa/2.5/\r\n    export function objAssign(target: any, ...theArgs: any) { // .length of function is 2\r\n        if (target == null) { // TypeError if undefined or null\r\n            throw new TypeError('Cannot convert undefined or null to object');\r\n        }\r\n\r\n        let to = Object(target);\r\n        if((<any>Object).assign) {\r\n            theArgs.forEach(item => (<any>Object).assign(to, item));\r\n            return to;\r\n        }\r\n\r\n        theArgs.forEach(item => {\r\n            let nextSource = item;\r\n            if (nextSource != null) { // Skip over if undefined or null\r\n                for (let nextKey in nextSource) {\r\n                    // Avoid bugs when hasOwnProperty is shadowed\r\n                    if (Object.prototype.hasOwnProperty.call(nextSource, nextKey)) {\r\n                        to[nextKey] = nextSource[nextKey];\r\n                    }\r\n                }\r\n            }\r\n        });\r\n        return to;\r\n    }\r\n}\r\n\r\n"],"mappings":";AAAA;;;;;;;;;;;;;;AAcA;;AAEA;AACA;AAEA;;AAEA;AACA;AAAA;AAGA;AACA;;;;;;;;;;;;;;;;AAgBA;AACA;AAAA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAPA;AASA;AAAA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAPA;AASA;;;;;AAKA;AACA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AAPA;AASA;;;;AAIA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AARA;AAUA;;;;;;;AAOA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAEA;AACA;AATA;AAWA;;;;;AAKA;AACA;AACA;AACA;AAEA;AACA;AACA;AANA;AAQA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAVA;AAYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAZA;AAcA;;;;;AAKA;AACA;AACA;AACA;AAFA;AAIA;;;;;;AAMA;AACA;AACA;AACA;AACA;AACA;AAJA;AAMA;AACA;AACA;AAFA;AAIA;AACA;AACA;AAAA;AAAA;AAAA;;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAvBA;AAwBA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/main/typescript/ext/monadish/Lang.ts\n");
/***/ }),
/***/ "./src/main/typescript/ext/monadish/Monad.ts":
/*!***************************************************!*\
!*** ./src/main/typescript/ext/monadish/Monad.ts ***!
\***************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nvar __extends = (this && this.__extends) || (function () {\r\n var extendStatics = function (d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n };\r\n return function (d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n };\r\n})();\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\n/**\r\n * A module which keeps basic monadish like definitions in place without any sidedependencies to other modules.\r\n * Useful if you need the functions in another library to keep its dependencies down\r\n */\r\n/*IMonad definitions*/\r\nvar Lang_1 = __webpack_require__(/*! ./Lang */ \"./src/main/typescript/ext/monadish/Lang.ts\");\r\nvar SourcesCollectors_1 = __webpack_require__(/*! ./SourcesCollectors */ \"./src/main/typescript/ext/monadish/SourcesCollectors.ts\");\r\nvar Stream_1 = __webpack_require__(/*! ./Stream */ \"./src/main/typescript/ext/monadish/Stream.ts\");\r\nvar objAssign = Lang_1.Lang.objAssign;\r\n/**\r\n * Implementation of a monad\r\n * (Sideffect free), no write allowed directly on the monads\r\n * value state\r\n */\r\nvar Monad = /** @class */ (function () {\r\n function Monad(value) {\r\n this._value = value;\r\n }\r\n Object.defineProperty(Monad.prototype, \"value\", {\r\n get: function () {\r\n return this._value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Monad.prototype.map = function (fn) {\r\n if (!fn) {\r\n fn = function (inval) { return inval; };\r\n }\r\n var result = fn(this.value);\r\n return new Monad(result);\r\n };\r\n Monad.prototype.flatMap = function (fn) {\r\n var _a;\r\n var mapped = this.map(fn);\r\n while (((_a = mapped) === null || _a === void 0 ? void 0 : _a.value) instanceof Monad) {\r\n mapped = mapped.value;\r\n }\r\n return mapped;\r\n };\r\n return Monad;\r\n}());\r\nexports.Monad = Monad;\r\n/**\r\n * optional implementation, an optional is basically an implementation of a Monad with additional syntactic\r\n * sugar on top\r\n * (Sideeffect free, since value assignment is not allowed)\r\n * */\r\nvar Optional = /** @class */ (function (_super) {\r\n __extends(Optional, _super);\r\n function Optional(value) {\r\n return _super.call(this, value) || this;\r\n }\r\n Object.defineProperty(Optional.prototype, \"value\", {\r\n get: function () {\r\n if (this._value instanceof Monad) {\r\n return this._value.flatMap().value;\r\n }\r\n return this._value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Optional.fromNullable = function (value) {\r\n return new Optional(value);\r\n };\r\n /*syntactic sugar for absent and present checks*/\r\n Optional.prototype.isAbsent = function () {\r\n return \"undefined\" == typeof this.value || null == this.value;\r\n };\r\n /**\r\n * any value present\r\n */\r\n Optional.prototype.isPresent = function (presentRunnable) {\r\n var absent = this.isAbsent();\r\n if (!absent && presentRunnable) {\r\n presentRunnable.call(this, this);\r\n }\r\n return !absent;\r\n };\r\n Optional.prototype.ifPresentLazy = function (presentRunnable) {\r\n if (presentRunnable === void 0) { presentRunnable = function () {\r\n }; }\r\n this.isPresent.call(this, presentRunnable);\r\n return this;\r\n };\r\n Optional.prototype.orElse = function (elseValue) {\r\n if (this.isPresent()) {\r\n return this;\r\n }\r\n else {\r\n //shortcut\r\n if (elseValue == null) {\r\n return Optional.absent;\r\n }\r\n return this.flatMap(function () { return elseValue; });\r\n }\r\n };\r\n /**\r\n * lazy, passes a function which then is lazily evaluated\r\n * instead of a direct value\r\n * @param func\r\n */\r\n Optional.prototype.orElseLazy = function (func) {\r\n if (this.isPresent()) {\r\n return this;\r\n }\r\n else {\r\n return this.flatMap(func);\r\n }\r\n };\r\n /*\r\n * we need to implement it to fullfill the contract, although it is used only internally\r\n * all values are flattened when accessed anyway, so there is no need to call this methiod\r\n */\r\n Optional.prototype.flatMap = function (fn) {\r\n var val = _super.prototype.flatMap.call(this, fn);\r\n if (!(val instanceof Optional)) {\r\n return Optional.fromNullable(val.value);\r\n }\r\n return val.flatMap();\r\n };\r\n /*\r\n * elvis operation, take care, if you use this you lose typesafety and refactoring\r\n * capabilites, unfortunately typesceript does not allow to have its own elvis operator\r\n * this is some syntactic sugar however which is quite useful*/\r\n Optional.prototype.getIf = function () {\r\n var key = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n key[_i] = arguments[_i];\r\n }\r\n var currentPos = this;\r\n for (var cnt = 0; cnt < key.length; cnt++) {\r\n var currKey = this.keyVal(key[cnt]);\r\n var arrPos = this.arrayIndex(key[cnt]);\r\n if (currKey === \"\" && arrPos >= 0) {\r\n currentPos = this.getClass().fromNullable(!(currentPos.value instanceof Array) ? null : (currentPos.value.length < arrPos ? null : currentPos.value[arrPos]));\r\n if (currentPos.isAbsent()) {\r\n return currentPos;\r\n }\r\n continue;\r\n }\r\n else if (currKey && arrPos >= 0) {\r\n if (currentPos.getIfPresent(currKey).isAbsent()) {\r\n return currentPos;\r\n }\r\n currentPos = (currentPos.getIfPresent(currKey).value instanceof Array) ? this.getClass().fromNullable(currentPos.getIfPresent(currKey).value[arrPos]) : this.getClass().absent;\r\n if (currentPos.isAbsent()) {\r\n return currentPos;\r\n }\r\n continue;\r\n }\r\n else {\r\n currentPos = currentPos.getIfPresent(currKey);\r\n }\r\n if (currentPos.isAbsent()) {\r\n return currentPos;\r\n }\r\n else if (arrPos > -1) {\r\n currentPos = this.getClass().fromNullable(currentPos.value[arrPos]);\r\n }\r\n }\r\n var retVal = currentPos;\r\n return retVal;\r\n };\r\n /**\r\n * simple match, if the first order function call returns\r\n * true then there is a match, if the value is not present\r\n * it never matches\r\n *\r\n * @param fn the first order function performing the match\r\n */\r\n Optional.prototype.match = function (fn) {\r\n if (this.isAbsent()) {\r\n return false;\r\n }\r\n return fn(this.value);\r\n };\r\n /**\r\n * convenience function to flatmap the internal value\r\n * and replace it with a default in case of being absent\r\n *\r\n * @param defaultVal\r\n * @returns {Optional<any>}\r\n */\r\n Optional.prototype.get = function (defaultVal) {\r\n if (defaultVal === void 0) { defaultVal = Optional.absent; }\r\n if (this.isAbsent()) {\r\n return this.getClass().fromNullable(defaultVal).flatMap();\r\n }\r\n return this.getClass().fromNullable(this.value).flatMap();\r\n };\r\n Optional.prototype.toJson = function () {\r\n return JSON.stringify(this.value);\r\n };\r\n /**\r\n * helper to override several implementations in a more fluent way\r\n * by having a getClass operation we can avoid direct calls into the constructor or\r\n * static methods and do not have to implement several methods which rely on the type\r\n * of \"this\"\r\n * @returns {Monadish.Optional}\r\n */\r\n Optional.prototype.getClass = function () {\r\n return Optional;\r\n };\r\n /*helper method for getIf with array access aka <name>[<indexPos>]*/\r\n Optional.prototype.arrayIndex = function (key) {\r\n var start = key.indexOf(\"[\");\r\n var end = key.indexOf(\"]\");\r\n if (start >= 0 && end > 0 && start < end) {\r\n return parseInt(key.substring(start + 1, end));\r\n }\r\n else {\r\n return -1;\r\n }\r\n };\r\n /*helper method for getIf with array access aka <name>[<indexPos>]*/\r\n Optional.prototype.keyVal = function (key) {\r\n var start = key.indexOf(\"[\");\r\n if (start >= 0) {\r\n return key.substring(0, start);\r\n }\r\n else {\r\n return key;\r\n }\r\n };\r\n /**\r\n * additional syntactic sugar which is not part of the usual optional implementation\r\n * but makes life easier, if you want to sacrifice typesafety and refactoring\r\n * capabilities in typescript\r\n */\r\n Optional.prototype.getIfPresent = function (key) {\r\n if (this.isAbsent()) {\r\n return this.getClass().absent;\r\n }\r\n return this.getClass().fromNullable(this.value[key]).flatMap();\r\n };\r\n /**\r\n * elvis like typesafe functional save resolver\r\n * a typesafe option for getIfPresent\r\n *\r\n * usage myOptional.resolve(value => value.subAttr.subAttr2).orElseLazy(....)\r\n * if this is resolvable without any errors an Optional with the value is returned\r\n * if not, then an Optional absent is returned, also if you return Optional absent\r\n * it is flatmapped into absent\r\n *\r\n * @param resolver the resolver function, can throw any arbitrary errors, int the error case\r\n * the resolution goes towards absent\r\n */\r\n Optional.prototype.resolve = function (resolver) {\r\n if (this.isAbsent()) {\r\n return Optional.absent;\r\n }\r\n try {\r\n return Optional.fromNullable(resolver(this.value));\r\n }\r\n catch (e) {\r\n return Optional.absent;\r\n }\r\n };\r\n /*default value for absent*/\r\n Optional.absent = Optional.fromNullable(null);\r\n return Optional;\r\n}(Monad));\r\nexports.Optional = Optional;\r\n// --------------------- From here onwards we break out the sideffects free limits ------------\r\n/**\r\n * ValueEmbedder is the writeable version\r\n * of optional, it basically is a wrappber\r\n * around a construct which has a state\r\n * and can be written to.\r\n *\r\n * For the readonly version see Optional\r\n */\r\nvar ValueEmbedder = /** @class */ (function (_super) {\r\n __extends(ValueEmbedder, _super);\r\n function ValueEmbedder(rootElem, valueKey) {\r\n if (valueKey === void 0) { valueKey = \"value\"; }\r\n var _this = _super.call(this, rootElem) || this;\r\n _this.key = valueKey;\r\n return _this;\r\n }\r\n Object.defineProperty(ValueEmbedder.prototype, \"value\", {\r\n get: function () {\r\n return this._value ? this._value[this.key] : null;\r\n },\r\n set: function (newVal) {\r\n if (!this._value) {\r\n return;\r\n }\r\n this._value[this.key] = newVal;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n ValueEmbedder.prototype.orElse = function (elseValue) {\r\n var alternative = {};\r\n alternative[this.key] = elseValue;\r\n return this.isPresent() ? this : new ValueEmbedder(alternative, this.key);\r\n };\r\n ValueEmbedder.prototype.orElseLazy = function (func) {\r\n if (this.isPresent()) {\r\n return this;\r\n }\r\n else {\r\n var alternative = {};\r\n alternative[this.key] = func();\r\n return new ValueEmbedder(alternative, this.key);\r\n }\r\n };\r\n /**\r\n * helper to override several implementations in a more fluent way\r\n * by having a getClass operation we can avoid direct calls into the constructor or\r\n * static methods and do not have to implement several methods which rely on the type\r\n * of \"this\"\r\n * @returns {Monadish.Optional}\r\n */\r\n ValueEmbedder.prototype.getClass = function () {\r\n return ValueEmbedder;\r\n };\r\n ValueEmbedder.fromNullable = function (value, valueKey) {\r\n if (valueKey === void 0) { valueKey = \"value\"; }\r\n return new ValueEmbedder(value, valueKey);\r\n };\r\n /*default value for absent*/\r\n ValueEmbedder.absent = ValueEmbedder.fromNullable(null);\r\n return ValueEmbedder;\r\n}(Optional));\r\nexports.ValueEmbedder = ValueEmbedder;\r\n/**\r\n * specialized value embedder\r\n * for our Configuration\r\n */\r\nvar ConfigEntry = /** @class */ (function (_super) {\r\n __extends(ConfigEntry, _super);\r\n function ConfigEntry(rootElem, key, arrPos) {\r\n var _this = _super.call(this, rootElem, key) || this;\r\n _this.arrPos = (arrPos !== null && arrPos !== void 0 ? arrPos : -1);\r\n return _this;\r\n }\r\n Object.defineProperty(ConfigEntry.prototype, \"value\", {\r\n get: function () {\r\n if (this.key == \"\" && this.arrPos >= 0) {\r\n return this._value[this.arrPos];\r\n }\r\n else if (this.key && this.arrPos >= 0) {\r\n return this._value[this.key][this.arrPos];\r\n }\r\n return this._value[this.key];\r\n },\r\n set: function (val) {\r\n if (this.key == \"\" && this.arrPos >= 0) {\r\n this._value[this.arrPos] = val;\r\n return;\r\n }\r\n else if (this.key && this.arrPos >= 0) {\r\n this._value[this.key][this.arrPos] = val;\r\n return;\r\n }\r\n this._value[this.key] = val;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /*default value for absent*/\r\n ConfigEntry.absent = ConfigEntry.fromNullable(null);\r\n return ConfigEntry;\r\n}(ValueEmbedder));\r\n/**\r\n * Config, basically an optional wrapper for a json structure\r\n * (not sideeffect free, since we can alter the internal config state\r\n * without generating a new config), not sure if we should make it sideffect free\r\n * since this would swallow a lot of performane and ram\r\n */\r\nvar Config = /** @class */ (function (_super) {\r\n __extends(Config, _super);\r\n function Config(root) {\r\n return _super.call(this, root) || this;\r\n }\r\n Object.defineProperty(Config.prototype, \"shallowCopy\", {\r\n get: function () {\r\n return new Config(Stream_1.Stream.ofAssoc(this.value).collect(new SourcesCollectors_1.AssocArrayCollector()));\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(Config.prototype, \"deepCopy\", {\r\n get: function () {\r\n return new Config(objAssign({}, this.value));\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Config.fromNullable = function (value) {\r\n return new Config(value);\r\n };\r\n /**\r\n * simple merge for the root configs\r\n */\r\n Config.prototype.shallowMerge = function (other, overwrite) {\r\n if (overwrite === void 0) { overwrite = true; }\r\n for (var key in other.value) {\r\n if (overwrite || !(key in this.value)) {\r\n this.assign(key).value = other.getIf(key).value;\r\n }\r\n }\r\n };\r\n Config.prototype.assign = function () {\r\n var keys = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n keys[_i] = arguments[_i];\r\n }\r\n if (keys.length < 1) {\r\n return;\r\n }\r\n this.buildPath(keys);\r\n var currKey = this.keyVal(keys[keys.length - 1]);\r\n var arrPos = this.arrayIndex(keys[keys.length - 1]);\r\n var retVal = new ConfigEntry(keys.length == 1 ? this.value : this.getIf.apply(this, keys.slice(0, keys.length - 1)).value, currKey, arrPos);\r\n return retVal;\r\n };\r\n Config.prototype.assignIf = function (condition) {\r\n var keys = [];\r\n for (var _i = 1; _i < arguments.length; _i++) {\r\n keys[_i - 1] = arguments[_i];\r\n }\r\n return condition ? this.assign.apply(this, keys) : { value: null };\r\n };\r\n Config.prototype.getIf = function () {\r\n var keys = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n keys[_i] = arguments[_i];\r\n }\r\n return this.getClass().fromNullable(_super.prototype.getIf.apply(this, keys).value);\r\n };\r\n Config.prototype.get = function (defaultVal) {\r\n return this.getClass().fromNullable(_super.prototype.get.call(this, defaultVal).value);\r\n };\r\n //empties the current config entry\r\n Config.prototype.delete = function (key) {\r\n if (key in this.value) {\r\n delete this.value[key];\r\n }\r\n return this;\r\n };\r\n Config.prototype.toJson = function () {\r\n return JSON.stringify(this.value);\r\n };\r\n Config.prototype.getClass = function () {\r\n return Config;\r\n };\r\n Config.prototype.setVal = function (val) {\r\n this._value = val;\r\n };\r\n Config.prototype.buildPath = function (keys) {\r\n var val = this;\r\n var parentVal = this.getClass().fromNullable(null);\r\n var parentPos = -1;\r\n var alloc = function (arr, length) {\r\n var length1 = arr.length;\r\n var length2 = length1 + length;\r\n for (var cnt = length1; cnt < length2; cnt++) {\r\n arr.push({});\r\n }\r\n };\r\n for (var cnt = 0; cnt < keys.length; cnt++) {\r\n var currKey = this.keyVal(keys[cnt]);\r\n var arrPos = this.arrayIndex(keys[cnt]);\r\n if (currKey === \"\" && arrPos >= 0) {\r\n val.setVal((val.value instanceof Array) ? val.value : []);\r\n alloc(val.value, arrPos + 1);\r\n if (parentPos >= 0) {\r\n parentVal.value[parentPos] = val.value;\r\n }\r\n parentVal = val;\r\n parentPos = arrPos;\r\n val = this.getClass().fromNullable(val.value[arrPos]);\r\n continue;\r\n }\r\n var tempVal = val.getIf(currKey);\r\n if (arrPos == -1) {\r\n if (tempVal.isAbsent()) {\r\n tempVal = this.getClass().fromNullable(val.value[currKey] = {});\r\n }\r\n else {\r\n val = tempVal;\r\n }\r\n }\r\n else {\r\n var arr = (tempVal.value instanceof Array) ? tempVal.value : [];\r\n alloc(arr, arrPos + 1);\r\n val.value[currKey] = arr;\r\n tempVal = this.getClass().fromNullable(arr[arrPos]);\r\n }\r\n parentVal = val;\r\n parentPos = arrPos;\r\n val = tempVal;\r\n }\r\n return this;\r\n };\r\n return Config;\r\n}(Optional));\r\nexports.Config = Config;\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/main/typescript/ext/monadish/Monad.ts.js","sources":["webpack:///./src/main/typescript/ext/monadish/Monad.ts?1109"],"sourcesContent":["/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements.  See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License.  You may obtain a copy of the License at\r\n *\r\n *      http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\n/**\r\n * A module which keeps  basic monadish like definitions in place without any sidedependencies to other modules.\r\n * Useful if you need the functions in another library to keep its dependencies down\r\n */\r\n\r\n/*IMonad definitions*/\r\n\r\nimport {Lang} from \"./Lang\";\r\nimport {AssocArrayCollector} from \"./SourcesCollectors\";\r\nimport {Stream} from \"./Stream\";\r\nimport objAssign = Lang.objAssign;\r\n\r\n/**\r\n * IFunctor interface,\r\n * defines an interface which allows to map a functor\r\n * via a first order function to another functor\r\n */\r\nexport interface IFunctor<T> {\r\n    map<R>(fn: (data: T) => R): IFunctor<R>;\r\n}\r\n\r\n/**\r\n * IMonad definition, basically a functor with a flaptmap implementation (flatmap reduces all nested monads after a\r\n * function call f into a monad with the nesting level of 1\r\n *\r\n * flatmap flats nested Monads into a IMonad of the deepest nested implementation\r\n */\r\nexport interface IMonad<T, M extends IMonad<any, any>> extends IFunctor<T> {\r\n    flatMap<T, M>(f: (T) => M): IMonad<any, any>;\r\n}\r\n\r\n/**\r\n * a stateful functor which holds a value upn which a\r\n * function can be applied\r\n *\r\n * as value holder of type T\r\n */\r\nexport interface IIdentity<T> extends IFunctor<T> {\r\n    readonly value: T;\r\n}\r\n\r\n/**\r\n *  custom value holder definition, since we are not pure functional\r\n *  but iterative we have structures which allow the assignment of a value\r\n *  also not all structures are sideffect free\r\n */\r\nexport interface IValueHolder<T> {\r\n    value: T | Array<T>;\r\n}\r\n\r\n/**\r\n * Implementation of a monad\r\n * (Sideffect free), no write allowed directly on the monads\r\n * value state\r\n */\r\nexport class Monad<T> implements IMonad<T, Monad<any>>, IValueHolder<T> {\r\n    constructor(value: T) {\r\n        this._value = value;\r\n    }\r\n\r\n    protected _value: T;\r\n\r\n    get value(): T {\r\n        return this._value;\r\n    }\r\n\r\n    map<R>(fn?: (data: T) => R): Monad<R> {\r\n        if (!fn) {\r\n            fn = (inval: any) => <R>inval;\r\n        }\r\n        let result: R = fn(this.value);\r\n        return new Monad(result);\r\n    }\r\n\r\n    flatMap<R>(fn?: (data: T) => R): Monad<any> {\r\n        let mapped: Monad<any> = this.map(fn);\r\n        while (mapped?.value instanceof Monad) {\r\n            mapped = mapped.value\r\n        }\r\n        return mapped;\r\n    }\r\n\r\n}\r\n\r\n\r\n\r\n\r\n/**\r\n * optional implementation, an optional is basically an implementation of a Monad with additional syntactic\r\n * sugar on top\r\n * (Sideeffect free, since value assignment is not allowed)\r\n * */\r\nexport class Optional<T> extends Monad<T> {\r\n\r\n    /*default value for absent*/\r\n    static absent = Optional.fromNullable(null);\r\n\r\n    constructor(value: T) {\r\n        super(value);\r\n    }\r\n\r\n    get value(): T {\r\n        if (this._value instanceof Monad) {\r\n            return this._value.flatMap().value\r\n        }\r\n        return this._value;\r\n    }\r\n\r\n    static fromNullable<T>(value?: T): Optional<T> {\r\n        return new Optional(value);\r\n    }\r\n\r\n    /*syntactic sugar for absent and present checks*/\r\n    isAbsent(): boolean {\r\n        return \"undefined\" == typeof this.value || null == this.value;\r\n    }\r\n\r\n    /**\r\n     * any value present\r\n     */\r\n    isPresent(presentRunnable ?: (val ?: Monad<T>) => void): boolean {\r\n        let absent = this.isAbsent();\r\n        if (!absent && presentRunnable) {\r\n            presentRunnable.call(this, this)\r\n        }\r\n        return !absent;\r\n    }\r\n\r\n    ifPresentLazy(presentRunnable: (val ?: Monad<T>) => void = () => {\r\n    }): Monad<T> {\r\n        this.isPresent.call(this, presentRunnable);\r\n        return this;\r\n    }\r\n\r\n    orElse(elseValue: any): Optional<any> {\r\n        if (this.isPresent()) {\r\n            return this;\r\n        } else {\r\n            //shortcut\r\n            if (elseValue == null) {\r\n                return Optional.absent;\r\n            }\r\n            return this.flatMap(() => elseValue);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * lazy, passes a function which then is lazily evaluated\r\n     * instead of a direct value\r\n     * @param func\r\n     */\r\n    orElseLazy(func: () => any): Optional<any> {\r\n        if (this.isPresent()) {\r\n            return this;\r\n        } else {\r\n            return this.flatMap(func);\r\n        }\r\n    }\r\n\r\n    /*\r\n     * we need to implement it to fullfill the contract, although it is used only internally\r\n     * all values are flattened when accessed anyway, so there is no need to call this methiod\r\n     */\r\n    flatMap<R>(fn?: (data: T) => R): Optional<any> {\r\n        let val = super.flatMap(fn);\r\n        if (!(val instanceof Optional)) {\r\n            return Optional.fromNullable(val.value);\r\n        }\r\n\r\n        return <Optional<any>>val.flatMap();\r\n    }\r\n\r\n    /*\r\n     * elvis operation, take care, if you use this you lose typesafety and refactoring\r\n     * capabilites, unfortunately typesceript does not allow to have its own elvis operator\r\n     * this is some syntactic sugar however which is quite useful*/\r\n    getIf<R>(...key: string[]): Optional<R> {\r\n\r\n        let currentPos: Optional<any> = this;\r\n        for (let cnt = 0; cnt < key.length; cnt++) {\r\n            let currKey = this.keyVal(key[cnt]);\r\n            let arrPos = this.arrayIndex(key[cnt]);\r\n\r\n            if (currKey === \"\" && arrPos >= 0) {\r\n                currentPos = this.getClass().fromNullable(!(currentPos.value instanceof Array) ? null : (currentPos.value.length < arrPos ? null : currentPos.value[arrPos]));\r\n                if (currentPos.isAbsent()) {\r\n                    return currentPos;\r\n                }\r\n                continue;\r\n            } else if (currKey && arrPos >= 0) {\r\n                if (currentPos.getIfPresent(currKey).isAbsent()) {\r\n                    return currentPos;\r\n                }\r\n                currentPos = (currentPos.getIfPresent(currKey).value instanceof Array) ? this.getClass().fromNullable(currentPos.getIfPresent(currKey).value[arrPos]) : this.getClass().absent;\r\n                if (currentPos.isAbsent()) {\r\n                    return currentPos;\r\n                }\r\n                continue;\r\n\r\n            } else {\r\n                currentPos = currentPos.getIfPresent(currKey);\r\n            }\r\n            if (currentPos.isAbsent()) {\r\n                return currentPos;\r\n            } else if (arrPos > -1) {\r\n                currentPos = this.getClass().fromNullable(currentPos.value[arrPos]);\r\n            }\r\n        }\r\n        let retVal = currentPos;\r\n\r\n        return retVal;\r\n    }\r\n\r\n    /**\r\n     * simple match, if the first order function call returns\r\n     * true then there is a match, if the value is not present\r\n     * it never matches\r\n     *\r\n     * @param fn the first order function performing the match\r\n     */\r\n    match(fn: (item: T) => boolean): boolean {\r\n        if (this.isAbsent()) {\r\n            return false\r\n        }\r\n        return fn(this.value);\r\n    }\r\n\r\n    /**\r\n     * convenience function to flatmap the internal value\r\n     * and replace it with a default in case of being absent\r\n     *\r\n     * @param defaultVal\r\n     * @returns {Optional<any>}\r\n     */\r\n    get<R>(defaultVal: any = Optional.absent): Optional<R> {\r\n        if (this.isAbsent()) {\r\n            return this.getClass().fromNullable(defaultVal).flatMap();\r\n        }\r\n\r\n        return this.getClass().fromNullable(this.value).flatMap();\r\n    }\r\n\r\n    toJson(): string {\r\n        return JSON.stringify(this.value);\r\n    }\r\n\r\n    /**\r\n     * helper to override several implementations in a more fluent way\r\n     * by having a getClass operation we can avoid direct calls into the constructor or\r\n     * static methods and do not have to implement several methods which rely on the type\r\n     * of \"this\"\r\n     * @returns {Monadish.Optional}\r\n     */\r\n    protected getClass(): any {\r\n        return Optional;\r\n    }\r\n\r\n    /*helper method for getIf with array access aka <name>[<indexPos>]*/\r\n    protected arrayIndex(key: string): number {\r\n        let start = key.indexOf(\"[\");\r\n        let end = key.indexOf(\"]\");\r\n        if (start >= 0 && end > 0 && start < end) {\r\n            return parseInt(key.substring(start + 1, end));\r\n        } else {\r\n            return -1;\r\n        }\r\n    }\r\n\r\n    /*helper method for getIf with array access aka <name>[<indexPos>]*/\r\n    protected keyVal(key: string): string {\r\n        let start = key.indexOf(\"[\");\r\n\r\n        if (start >= 0) {\r\n            return key.substring(0, start);\r\n        } else {\r\n            return key;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * additional syntactic sugar which is not part of the usual optional implementation\r\n     * but makes life easier, if you want to sacrifice typesafety and refactoring\r\n     * capabilities in typescript\r\n     */\r\n    getIfPresent<R>(key: string): Optional<R> {\r\n        if (this.isAbsent()) {\r\n            return this.getClass().absent;\r\n        }\r\n        return this.getClass().fromNullable(this.value[key]).flatMap();\r\n    }\r\n\r\n    /**\r\n     * elvis like typesafe functional save resolver\r\n     * a typesafe option for getIfPresent\r\n     *\r\n     * usage myOptional.resolve(value => value.subAttr.subAttr2).orElseLazy(....)\r\n     * if this is resolvable without any errors an Optional with the value is returned\r\n     * if not, then an Optional absent is returned, also if you return Optional absent\r\n     * it is flatmapped into absent\r\n     *\r\n     * @param resolver the resolver function, can throw any arbitrary errors, int  the error case\r\n     * the resolution goes towards absent\r\n     */\r\n    resolve<V>(resolver: (item: T) => V): Optional<V> {\r\n        if(this.isAbsent()) {\r\n            return Optional.absent;\r\n        }\r\n        try {\r\n            return Optional.fromNullable(resolver(this.value))\r\n        } catch(e) {\r\n            return Optional.absent;\r\n        }\r\n    }\r\n\r\n}\r\n\r\n\r\n// --------------------- From here onwards we break out the sideffects free limits ------------\r\n\r\n\r\n/**\r\n * ValueEmbedder is the writeable version\r\n * of optional, it basically is a wrappber\r\n * around a construct which has a state\r\n * and can be written to.\r\n *\r\n * For the readonly version see Optional\r\n */\r\nexport class ValueEmbedder<T> extends Optional<T> implements IValueHolder<T> {\r\n\r\n    /*default value for absent*/\r\n    static absent =  ValueEmbedder.fromNullable(null);\r\n\r\n    protected key: string;\r\n\r\n    constructor(rootElem: any, valueKey: string = \"value\") {\r\n        super(rootElem);\r\n\r\n        this.key = valueKey;\r\n    }\r\n\r\n    get value(): T {\r\n        return this._value ? <T>this._value[this.key] : null;\r\n    }\r\n\r\n    set value(newVal: T) {\r\n        if(!this._value) {\r\n            return;\r\n        }\r\n        this._value[this.key] = newVal\r\n    }\r\n\r\n    orElse(elseValue: any): Optional<any> {\r\n        let alternative = {};\r\n        alternative[this.key] = elseValue;\r\n        return this.isPresent() ? this : new ValueEmbedder(alternative, this.key);\r\n    }\r\n\r\n    orElseLazy(func: () => any): Optional<any> {\r\n        if (this.isPresent()) {\r\n            return this;\r\n        } else {\r\n            let alternative = {};\r\n            alternative[this.key] = func();\r\n            return new ValueEmbedder(alternative, this.key);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * helper to override several implementations in a more fluent way\r\n     * by having a getClass operation we can avoid direct calls into the constructor or\r\n     * static methods and do not have to implement several methods which rely on the type\r\n     * of \"this\"\r\n     * @returns {Monadish.Optional}\r\n     */\r\n    protected getClass(): any {\r\n        return ValueEmbedder;\r\n    }\r\n\r\n    static fromNullable<T>(value?: any, valueKey: string = \"value\"): ValueEmbedder<T> {\r\n        return new ValueEmbedder(value, valueKey);\r\n    }\r\n\r\n}\r\n\r\n\r\n\r\n/**\r\n * specialized value embedder\r\n * for our Configuration\r\n */\r\nclass ConfigEntry<T> extends ValueEmbedder<T> {\r\n\r\n    /*default value for absent*/\r\n    static absent = ConfigEntry.fromNullable(null);\r\n\r\n    arrPos: number;\r\n\r\n    constructor(rootElem: any, key: any, arrPos?: number) {\r\n        super(rootElem, key);\r\n\r\n        this.arrPos =  arrPos ?? -1;\r\n    }\r\n\r\n    get value() {\r\n        if (this.key == \"\" && this.arrPos >= 0) {\r\n            return this._value[this.arrPos];\r\n        } else if (this.key && this.arrPos >= 0) {\r\n            return this._value[this.key][this.arrPos];\r\n        }\r\n        return this._value[this.key];\r\n    }\r\n\r\n    set value(val: T) {\r\n        if (this.key == \"\" && this.arrPos >= 0) {\r\n            this._value[this.arrPos] = val;\r\n            return;\r\n        } else if (this.key && this.arrPos >= 0) {\r\n            this._value[this.key][this.arrPos] = val;\r\n            return;\r\n        }\r\n        this._value[this.key] = val;\r\n    }\r\n}\r\n\r\n/**\r\n * Config, basically an optional wrapper for a json structure\r\n * (not sideeffect free, since we can alter the internal config state\r\n * without generating a new config), not sure if we should make it sideffect free\r\n * since this would swallow a lot of performane and ram\r\n */\r\nexport class Config extends Optional<any> {\r\n    constructor(root: any) {\r\n        super(root);\r\n    }\r\n\r\n    get shallowCopy(): Config {\r\n        return new Config(Stream.ofAssoc(this.value).collect(new AssocArrayCollector()));\r\n    }\r\n\r\n    get deepCopy(): Config {\r\n        return new Config(objAssign({}, this.value));\r\n    }\r\n\r\n    static fromNullable<T>(value?: any): Config {\r\n        return new Config(value);\r\n    }\r\n\r\n    /**\r\n     * simple merge for the root configs\r\n     */\r\n    shallowMerge(other: Config, overwrite = true) {\r\n        for (let key in other.value) {\r\n            if (overwrite || !(key in this.value)) {\r\n                this.assign(key).value = other.getIf(key).value;\r\n            }\r\n        }\r\n    }\r\n\r\n    assign(...keys): IValueHolder<any> {\r\n        if (keys.length < 1) {\r\n            return;\r\n        }\r\n\r\n        this.buildPath(keys);\r\n\r\n        let currKey = this.keyVal(keys[keys.length - 1]);\r\n        let arrPos = this.arrayIndex(keys[keys.length - 1]);\r\n        let retVal = new ConfigEntry(keys.length == 1 ? this.value : this.getIf.apply(this, keys.slice(0, keys.length - 1)).value,\r\n            currKey, arrPos\r\n        );\r\n\r\n        return retVal;\r\n    }\r\n\r\n    assignIf(condition: boolean, ...keys: Array<any>): IValueHolder<any> {\r\n        return condition ? this.assign(...keys) : {value: null};\r\n    }\r\n\r\n\r\n    getIf(...keys: Array<string>): Config {\r\n        return this.getClass().fromNullable(super.getIf.apply(this, keys).value);\r\n    }\r\n\r\n    get(defaultVal: any): Config {\r\n        return this.getClass().fromNullable(super.get(defaultVal).value);\r\n    }\r\n\r\n    //empties the current config entry\r\n    delete(key: string): Config {\r\n        if (key in this.value) {\r\n            delete this.value[key];\r\n        }\r\n        return this;\r\n    }\r\n\r\n    toJson(): any {\r\n        return JSON.stringify(this.value);\r\n    }\r\n\r\n    protected getClass(): any {\r\n        return Config;\r\n    }\r\n\r\n    private setVal(val: any) {\r\n        this._value = val;\r\n    }\r\n\r\n    private buildPath(keys: Array<any>): Config {\r\n        let val = this;\r\n        let parentVal = this.getClass().fromNullable(null);\r\n        let parentPos = -1;\r\n        let alloc = function (arr: Array<any>, length: number) {\r\n            let length1 = arr.length;\r\n            let length2 = length1 + length;\r\n            for(let cnt = length1; cnt < length2; cnt++) {\r\n                arr.push({});\r\n            }\r\n        };\r\n\r\n        for (let cnt = 0; cnt < keys.length; cnt++) {\r\n            let currKey = this.keyVal(keys[cnt]);\r\n            let arrPos = this.arrayIndex(keys[cnt]);\r\n\r\n            if (currKey === \"\" && arrPos >= 0) {\r\n\r\n                val.setVal((val.value instanceof Array) ? val.value : []);\r\n                alloc(val.value, arrPos + 1);\r\n                if (parentPos >= 0) {\r\n                    parentVal.value[parentPos] = val.value;\r\n                }\r\n                parentVal = val;\r\n                parentPos = arrPos;\r\n                val = this.getClass().fromNullable(val.value[arrPos]);\r\n                continue;\r\n            }\r\n\r\n            let tempVal = <Config>val.getIf(currKey);\r\n            if (arrPos == -1) {\r\n                if (tempVal.isAbsent()) {\r\n                    tempVal = <Config>this.getClass().fromNullable(val.value[currKey] = {});\r\n                } else {\r\n                    val = <any>tempVal;\r\n                }\r\n            } else {\r\n                let arr = (tempVal.value instanceof Array) ? tempVal.value : [];\r\n                alloc(arr, arrPos + 1);\r\n                val.value[currKey] = arr;\r\n                tempVal = this.getClass().fromNullable(arr[arrPos]);\r\n            }\r\n            parentVal = val;\r\n            parentPos = arrPos;\r\n            val = <any>tempVal;\r\n        }\r\n\r\n        return this;\r\n    }\r\n}\r\n\r\n\r\n"],"mappings":";AAAA;;;;;;;;;;;;;;AAcA;;;;;;;;;;;;;;;AAEA;;;AAGA;AAEA;AAEA;AACA;AACA;AACA;AAwCA;;;;AAIA;AACA;AACA;AACA;AACA;AAIA;AAAA;AACA;AACA;;;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AA3BA;AAgCA;;;;AAIA;AACA;AAAA;AAKA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;;;AAAA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;AAIA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAEA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;;;AAGA;AACA;AAAA;AAAA;AAAA;;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;;;;;;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;;AAMA;AACA;AAAA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;;;;;;AAMA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAAA;AACA;AACA;AACA;AAEA;;;;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;;;;;;;AAWA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AA1NA;AACA;AA2NA;AAAA;AA9NA;AAiOA;AAGA;;;;;;;AAOA;AACA;AAAA;AAOA;AAAA;AAAA;AAGA;;AACA;AAEA;AAAA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;;;AAPA;AASA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;;AAMA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AAnDA;AACA;AAoDA;AAAA;AAvDA;AA2DA;;;AAGA;AACA;AAAA;AAOA;AAAA;AAGA;;AACA;AAEA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;;;AAXA;AAlBA;AACA;AA6BA;AAAA;AAEA;;;;;AAKA;AACA;AAAA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;;;AAAA;AAEA;AAAA;AACA;AACA;;;AAAA;AAEA;AACA;AACA;AAEA;;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AAAA;AAAA;;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAIA;AACA;AAEA;AAAA;AAAA;AAAA;;AACA;AACA;AAGA;AAAA;AAAA;AAAA;;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAAA;AA9HA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/main/typescript/ext/monadish/Monad.ts\n");
/***/ }),
/***/ "./src/main/typescript/ext/monadish/Promise.ts":
/*!*****************************************************!*\
!*** ./src/main/typescript/ext/monadish/Promise.ts ***!
\*****************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\nvar __extends = (this && this.__extends) || (function () {\r\n var extendStatics = function (d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n };\r\n return function (d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n };\r\n})();\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar Monad_1 = __webpack_require__(/*! ./Monad */ \"./src/main/typescript/ext/monadish/Monad.ts\");\r\nvar PromiseStatus;\r\n(function (PromiseStatus) {\r\n PromiseStatus[PromiseStatus[\"PENDING\"] = 0] = \"PENDING\";\r\n PromiseStatus[PromiseStatus[\"FULLFILLED\"] = 1] = \"FULLFILLED\";\r\n PromiseStatus[PromiseStatus[\"REJECTED\"] = 2] = \"REJECTED\";\r\n})(PromiseStatus = exports.PromiseStatus || (exports.PromiseStatus = {}));\r\n/**\r\n * a small (probably not 100% correct, although I tried to be correct as possible) Promise implementation\r\n * for systems which do not have a promise implemented\r\n * Note, although an internal state is kept, this is sideffect free since\r\n * is value is a function to operate on, hence no real state is kept internally, except for the then\r\n * and catch calling order\r\n */\r\nvar Promise = /** @class */ (function () {\r\n function Promise(executor) {\r\n var _this = this;\r\n this.status = PromiseStatus.PENDING;\r\n this.allFuncs = [];\r\n //super(executor);\r\n this.value = executor;\r\n this.value(function (data) { return _this.resolve(data); }, function (data) { return _this.reject(data); });\r\n }\r\n Promise.all = function () {\r\n var promises = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n promises[_i] = arguments[_i];\r\n }\r\n var promiseCnt = 0;\r\n var myapply;\r\n var myPromise = new Promise(function (apply, reject) {\r\n myapply = apply;\r\n });\r\n var executor = function () {\r\n promiseCnt++;\r\n if (promises.length == promiseCnt) {\r\n myapply();\r\n }\r\n };\r\n executor.__last__ = true;\r\n for (var cnt = 0; cnt < promises.length; cnt++) {\r\n promises[cnt].finally(executor);\r\n }\r\n return myPromise;\r\n };\r\n Promise.race = function () {\r\n var promises = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n promises[_i] = arguments[_i];\r\n }\r\n var promiseCnt = 0;\r\n var myapply;\r\n var myreject;\r\n var myPromise = new Promise(function (apply, reject) {\r\n myapply = apply;\r\n myreject = reject;\r\n });\r\n var thenexecutor = function () {\r\n if (!!myapply) {\r\n myapply();\r\n }\r\n myapply = null;\r\n myreject = null;\r\n return null;\r\n };\r\n thenexecutor.__last__ = true;\r\n var catchexeutor = function () {\r\n if (!!myreject) {\r\n myreject();\r\n }\r\n myreject = null;\r\n myapply = null;\r\n return null;\r\n };\r\n catchexeutor.__last__ = true;\r\n for (var cnt = 0; cnt < promises.length; cnt++) {\r\n promises[cnt].then(thenexecutor);\r\n promises[cnt].catch(catchexeutor);\r\n }\r\n return myPromise;\r\n };\r\n Promise.reject = function (reason) {\r\n var retVal = new Promise(function (resolve, reject) {\r\n //not really doable without a hack\r\n if (reason instanceof Promise) {\r\n reason.then(function (val) {\r\n reject(val);\r\n });\r\n }\r\n else {\r\n setTimeout(function () {\r\n reject(reason);\r\n }, 1);\r\n }\r\n });\r\n return retVal;\r\n };\r\n Promise.resolve = function (reason) {\r\n var retVal = new Promise(function (resolve, reject) {\r\n //not really doable without a hack\r\n if (reason instanceof Promise) {\r\n reason.then(function (val) { return resolve(val); });\r\n }\r\n else {\r\n setTimeout(function () {\r\n resolve(reason);\r\n }, 1);\r\n }\r\n });\r\n return retVal;\r\n };\r\n Promise.prototype.then = function (executorFunc, catchfunc) {\r\n this.allFuncs.push({ \"then\": executorFunc });\r\n if (catchfunc) {\r\n this.allFuncs.push({ \"catch\": catchfunc });\r\n }\r\n this.spliceLastFuncs();\r\n return this;\r\n };\r\n Promise.prototype.catch = function (executorFunc) {\r\n this.allFuncs.push({ \"catch\": executorFunc });\r\n this.spliceLastFuncs();\r\n return this;\r\n };\r\n Promise.prototype.finally = function (executorFunc) {\r\n if (this.__reason__) {\r\n this.__reason__.finally(executorFunc);\r\n return;\r\n }\r\n this.allFuncs.push({ \"finally\": executorFunc });\r\n this.spliceLastFuncs();\r\n return this;\r\n };\r\n Promise.prototype.resolve = function (val) {\r\n while (this.allFuncs.length) {\r\n if (!this.allFuncs[0].then) {\r\n break;\r\n }\r\n var fn = this.allFuncs.shift();\r\n var funcResult = Monad_1.Optional.fromNullable(fn.then(val));\r\n if (funcResult.isPresent()) {\r\n funcResult = funcResult.flatMap();\r\n val = funcResult.value;\r\n if (val instanceof Promise) {\r\n //var func = (newVal: any) => {this.resolve(newVal)};\r\n //func.__last__ = true;\r\n //val.then(func);\r\n this.transferIntoNewPromise(val);\r\n return;\r\n }\r\n }\r\n else {\r\n break;\r\n }\r\n }\r\n this.appyFinally();\r\n this.status = PromiseStatus.FULLFILLED;\r\n };\r\n Promise.prototype.reject = function (val) {\r\n while (this.allFuncs.length) {\r\n if (this.allFuncs[0].finally) {\r\n break;\r\n }\r\n var fn = this.allFuncs.shift();\r\n if (fn.catch) {\r\n var funcResult = Monad_1.Optional.fromNullable(fn.catch(val));\r\n if (funcResult.isPresent()) {\r\n funcResult = funcResult.flatMap();\r\n val = funcResult.value;\r\n if (val instanceof Promise) {\r\n //val.then((newVal: any) => {this.resolve(newVal)});\r\n this.transferIntoNewPromise(val);\r\n return;\r\n }\r\n this.status = PromiseStatus.REJECTED;\r\n break;\r\n }\r\n else {\r\n break;\r\n }\r\n }\r\n }\r\n this.status = PromiseStatus.REJECTED;\r\n this.appyFinally();\r\n };\r\n Promise.prototype.appyFinally = function () {\r\n while (this.allFuncs.length) {\r\n var fn = this.allFuncs.shift();\r\n if (fn.finally) {\r\n fn.finally();\r\n }\r\n }\r\n };\r\n Promise.prototype.spliceLastFuncs = function () {\r\n var lastFuncs = [];\r\n var rest = [];\r\n for (var cnt = 0; cnt < this.allFuncs.length; cnt++) {\r\n for (var key in this.allFuncs[cnt]) {\r\n if (this.allFuncs[cnt][key].__last__) {\r\n lastFuncs.push(this.allFuncs[cnt]);\r\n }\r\n else {\r\n rest.push(this.allFuncs[cnt]);\r\n }\r\n }\r\n }\r\n this.allFuncs = rest.concat(lastFuncs);\r\n };\r\n Promise.prototype.transferIntoNewPromise = function (val) {\r\n for (var cnt = 0; cnt < this.allFuncs.length; cnt++) {\r\n for (var key in this.allFuncs[cnt]) {\r\n val[key](this.allFuncs[cnt][key]);\r\n }\r\n }\r\n };\r\n return Promise;\r\n}());\r\nexports.Promise = Promise;\r\n/**\r\n * a cancellable promise\r\n * a Promise with a cancel function, which can be cancellend any time\r\n * this is useful for promises which use cancellable asynchronous operations\r\n * note, even in a cancel state, the finally of the promise is executed, however\r\n * subsequent thens are not anymore.\r\n * The current then however is fished or a catch is called depending on how the outer\r\n * operation reacts to a cancel order.\r\n */\r\nvar CancellablePromise = /** @class */ (function (_super) {\r\n __extends(CancellablePromise, _super);\r\n /**\r\n * @param executor asynchronous callback operation which triggers the callback\r\n * @param cancellator cancel operation, separate from the trigger operation\r\n */\r\n function CancellablePromise(executor, cancellator) {\r\n var _this = _super.call(this, executor) || this;\r\n _this.cancellator = function () {\r\n };\r\n _this.cancellator = cancellator;\r\n return _this;\r\n }\r\n CancellablePromise.prototype.cancel = function () {\r\n this.status = PromiseStatus.REJECTED;\r\n this.appyFinally();\r\n //lets terminate it once and for all, the finally has been applied\r\n this.allFuncs = [];\r\n };\r\n CancellablePromise.prototype.then = function (executorFunc, catchfunc) {\r\n return _super.prototype.then.call(this, executorFunc, catchfunc);\r\n };\r\n CancellablePromise.prototype.catch = function (executorFunc) {\r\n return _super.prototype.catch.call(this, executorFunc);\r\n };\r\n CancellablePromise.prototype.finally = function (executorFunc) {\r\n return _super.prototype.finally.call(this, executorFunc);\r\n };\r\n return CancellablePromise;\r\n}(Promise));\r\nexports.CancellablePromise = CancellablePromise;\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/main/typescript/ext/monadish/Promise.ts.js","sources":["webpack:///./src/main/typescript/ext/monadish/Promise.ts?215e"],"sourcesContent":["import {Optional} from \"./Monad\";\r\n\r\nexport enum PromiseStatus {\r\n    PENDING, FULLFILLED, REJECTED\r\n}\r\n\r\nexport interface IPromise {\r\n    then(executorFunc: (val: any) => any): IPromise;\r\n\r\n    catch(executorFunc: (val: any) => any): IPromise\r\n\r\n    finally(executorFunc: () => void): IPromise;\r\n\r\n}\r\n\r\n/**\r\n * a small (probably not 100% correct, although I tried to be correct as possible) Promise implementation\r\n * for systems which do not have a promise implemented\r\n * Note, although an internal state is kept, this is sideffect free since\r\n * is value is a function to operate on, hence no real state is kept internally, except for the then\r\n * and catch calling order\r\n */\r\nexport class Promise implements IPromise {\r\n\r\n    status = PromiseStatus.PENDING;\r\n    protected allFuncs: Array<any> = [];\r\n    private value: (resolve: (val?: any) => void, reject: (val?: any) => void) => void;\r\n\r\n    constructor(executor: (resolve: (val?: any) => void, reject: (val?: any) => void) => void) {\r\n        //super(executor);\r\n        this.value = executor;\r\n        this.value((data: any) => this.resolve(data), (data: any) => this.reject(data));\r\n    }\r\n\r\n    static all(...promises: Array<IPromise>): IPromise {\r\n\r\n        let promiseCnt = 0;\r\n        let myapply: Function;\r\n\r\n        let myPromise = new Promise((apply: Function, reject: Function) => {\r\n            myapply = apply;\r\n        });\r\n        let executor = () => {\r\n            promiseCnt++;\r\n\r\n            if (promises.length == promiseCnt) {\r\n                myapply();\r\n            }\r\n        };\r\n        (<any>executor).__last__ = true;\r\n\r\n        for (let cnt = 0; cnt < promises.length; cnt++) {\r\n            promises[cnt].finally(executor);\r\n        }\r\n        return myPromise;\r\n    }\r\n\r\n    static race(...promises: Array<IPromise>): IPromise {\r\n\r\n        let promiseCnt = 0;\r\n        let myapply: Function;\r\n        let myreject: Function;\r\n\r\n        let myPromise = new Promise((apply: Function, reject: Function) => {\r\n            myapply = apply;\r\n            myreject = reject;\r\n        });\r\n\r\n        let thenexecutor = (): IPromise => {\r\n            if (!!myapply) {\r\n                myapply();\r\n            }\r\n            myapply = null;\r\n            myreject = null;\r\n            return null;\r\n        };\r\n        (<any>thenexecutor).__last__ = true;\r\n\r\n        let catchexeutor = (): IPromise => {\r\n            if (!!myreject) {\r\n                myreject();\r\n            }\r\n            myreject = null;\r\n            myapply = null;\r\n            return null;\r\n        };\r\n        (<any>catchexeutor).__last__ = true;\r\n\r\n        for (let cnt = 0; cnt < promises.length; cnt++) {\r\n            promises[cnt].then(thenexecutor);\r\n            promises[cnt].catch(catchexeutor);\r\n        }\r\n        return myPromise;\r\n    }\r\n\r\n    static reject(reason: any): Promise {\r\n        let retVal = new Promise((resolve: any, reject: any) => {\r\n            //not really doable without a hack\r\n            if (reason instanceof Promise) {\r\n                reason.then((val: any) => {\r\n                    reject(val);\r\n                });\r\n            } else {\r\n                setTimeout(() => {\r\n                    reject(reason);\r\n                }, 1);\r\n            }\r\n        });\r\n\r\n        return retVal;\r\n    }\r\n\r\n    static resolve(reason: any): Promise {\r\n        let retVal = new Promise((resolve: any, reject: any) => {\r\n            //not really doable without a hack\r\n            if (reason instanceof Promise) {\r\n                reason.then((val) => resolve(val));\r\n            } else {\r\n                setTimeout(() => {\r\n                    resolve(reason);\r\n                }, 1);\r\n            }\r\n        });\r\n\r\n        return retVal;\r\n\r\n    }\r\n\r\n    then(executorFunc: (val?: any) => any, catchfunc?: (val?: any) => any): Promise {\r\n        this.allFuncs.push({\"then\": executorFunc});\r\n        if (catchfunc) {\r\n            this.allFuncs.push({\"catch\": catchfunc});\r\n        }\r\n        this.spliceLastFuncs();\r\n        return this;\r\n    }\r\n\r\n    catch(executorFunc: (val?: any) => void): Promise {\r\n        this.allFuncs.push({\"catch\": executorFunc});\r\n        this.spliceLastFuncs();\r\n        return this;\r\n    }\r\n\r\n    finally(executorFunc: () => void): Promise {\r\n        if ((<any>this).__reason__) {\r\n            (<any>this).__reason__.finally(executorFunc);\r\n            return;\r\n        }\r\n\r\n        this.allFuncs.push({\"finally\": executorFunc});\r\n        this.spliceLastFuncs();\r\n        return this;\r\n    }\r\n\r\n    protected resolve(val?: any) {\r\n\r\n        while (this.allFuncs.length) {\r\n            if (!this.allFuncs[0].then) {\r\n                break;\r\n            }\r\n            let fn = this.allFuncs.shift();\r\n\r\n            let funcResult = Optional.fromNullable(fn.then(val));\r\n\r\n            if (funcResult.isPresent()) {\r\n                funcResult = funcResult.flatMap();\r\n                val = funcResult.value;\r\n                if (val instanceof Promise) {\r\n                    //var func = (newVal: any) => {this.resolve(newVal)};\r\n                    //func.__last__  = true;\r\n                    //val.then(func);\r\n                    this.transferIntoNewPromise(val);\r\n\r\n                    return;\r\n                }\r\n            } else {\r\n                break;\r\n            }\r\n        }\r\n\r\n        this.appyFinally();\r\n        this.status = PromiseStatus.FULLFILLED;\r\n    }\r\n\r\n    protected reject(val?: any) {\r\n\r\n        while (this.allFuncs.length) {\r\n            if (this.allFuncs[0].finally) {\r\n                break;\r\n            }\r\n            var fn = this.allFuncs.shift();\r\n            if (fn.catch) {\r\n                var funcResult = Optional.fromNullable(fn.catch(val));\r\n                if (funcResult.isPresent()) {\r\n                    funcResult = funcResult.flatMap();\r\n                    val = funcResult.value;\r\n                    if (val instanceof Promise) {\r\n                        //val.then((newVal: any) => {this.resolve(newVal)});\r\n                        this.transferIntoNewPromise(val);\r\n                        return;\r\n                    }\r\n                    this.status = PromiseStatus.REJECTED;\r\n                    break;\r\n                } else {\r\n                    break;\r\n                }\r\n            }\r\n        }\r\n\r\n        this.status = PromiseStatus.REJECTED;\r\n        this.appyFinally();\r\n    }\r\n\r\n    protected appyFinally() {\r\n        while (this.allFuncs.length) {\r\n            var fn = this.allFuncs.shift();\r\n            if (fn.finally) {\r\n                fn.finally();\r\n            }\r\n        }\r\n    }\r\n\r\n    private spliceLastFuncs() {\r\n        let lastFuncs = [];\r\n        let rest = [];\r\n        for (let cnt = 0; cnt < this.allFuncs.length; cnt++) {\r\n            for (let key in this.allFuncs[cnt]) {\r\n                if (this.allFuncs[cnt][key].__last__) {\r\n                    lastFuncs.push(this.allFuncs[cnt]);\r\n                } else {\r\n                    rest.push(this.allFuncs[cnt]);\r\n                }\r\n            }\r\n        }\r\n        this.allFuncs = rest.concat(lastFuncs);\r\n    }\r\n\r\n    private transferIntoNewPromise(val: any) {\r\n        for (var cnt = 0; cnt < this.allFuncs.length; cnt++) {\r\n            for (let key in this.allFuncs[cnt]) {\r\n                val[key](this.allFuncs[cnt][key]);\r\n            }\r\n        }\r\n    }\r\n}\r\n\r\n/**\r\n * a cancellable promise\r\n * a Promise with a cancel function, which can be cancellend any time\r\n * this is useful for promises which use cancellable asynchronous operations\r\n * note, even in a cancel state, the finally of the promise is executed, however\r\n * subsequent thens are not anymore.\r\n * The current then however is fished or a catch is called depending on how the outer\r\n * operation reacts to a cancel order.\r\n */\r\nexport class CancellablePromise extends Promise {\r\n\r\n    /**\r\n     * @param executor asynchronous callback operation which triggers the callback\r\n     * @param cancellator cancel operation, separate from the trigger operation\r\n     */\r\n    constructor(executor: (resolve: (val?: any) => void, reject: (val?: any) => void) => void, cancellator: () => void) {\r\n        super(executor);\r\n        this.cancellator = cancellator;\r\n    }\r\n\r\n    cancel() {\r\n        this.status = PromiseStatus.REJECTED;\r\n        this.appyFinally();\r\n        //lets terminate it once and for all, the finally has been applied\r\n        this.allFuncs = [];\r\n    }\r\n\r\n    then(executorFunc: (val?: any) => any, catchfunc?: (val?: any) => any): CancellablePromise {\r\n        return <CancellablePromise>super.then(executorFunc, catchfunc);\r\n    }\r\n\r\n    catch(executorFunc: (val?: any) => void): CancellablePromise {\r\n        return <CancellablePromise>super.catch(executorFunc);\r\n    }\r\n\r\n    finally(executorFunc: () => void): CancellablePromise {\r\n        return <CancellablePromise>super.finally(executorFunc);\r\n    }\r\n\r\n    private cancellator = () => {\r\n    };\r\n}\r\n\r\n\r\n\r\n"],"mappings":";;;;;;;;;;;;;;;AAAA;AAEA;AAAA;AACA;AAAA;AAAA;AACA;AAWA;;;;;;AAMA;AACA;AAMA;AAAA;AAJA;AACA;AAIA;AACA;AACA;AACA;AAEA;AAAA;AAAA;AAAA;;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAAA;AAAA;AAAA;;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AA9NA;AAgOA;;;;;;;;AAQA;AACA;AAAA;AAEA;;;AAGA;AACA;AAAA;AAwBA;AACA;AAvBA;;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAIA;AAAA;AAhCA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/main/typescript/ext/monadish/Promise.ts\n");
/***/ }),
/***/ "./src/main/typescript/ext/monadish/SourcesCollectors.ts":
/*!***************************************************************!*\
!*** ./src/main/typescript/ext/monadish/SourcesCollectors.ts ***!
\***************************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nvar __spreadArrays = (this && this.__spreadArrays) || function () {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n};\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar Stream_1 = __webpack_require__(/*! ./Stream */ \"./src/main/typescript/ext/monadish/Stream.ts\");\r\n/**\r\n * implementation of iteratable on top of array\r\n */\r\nvar ArrayStreamDataSource = /** @class */ (function () {\r\n function ArrayStreamDataSource() {\r\n var value = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n value[_i] = arguments[_i];\r\n }\r\n this.dataPos = -1;\r\n this.value = value;\r\n }\r\n ArrayStreamDataSource.prototype.hasNext = function () {\r\n return this.value.length - 1 > this.dataPos;\r\n };\r\n ArrayStreamDataSource.prototype.next = function () {\r\n this.dataPos++;\r\n return this.value[this.dataPos];\r\n };\r\n ArrayStreamDataSource.prototype.reset = function () {\r\n this.dataPos = -1;\r\n };\r\n return ArrayStreamDataSource;\r\n}());\r\nexports.ArrayStreamDataSource = ArrayStreamDataSource;\r\n/**\r\n * an intermediate data source wich prefilters\r\n * incoming stream data\r\n * and lets only the data out which\r\n * passes the filter function check\r\n */\r\nvar FilteredStreamDatasource = /** @class */ (function () {\r\n function FilteredStreamDatasource(filterFunc, parent) {\r\n this.filteredNext = null;\r\n this.filterFunc = filterFunc;\r\n this.inputDataSource = parent;\r\n }\r\n /**\r\n * in order to filter we have to make a look ahead until the\r\n * first next allowed element\r\n * hence we prefetch the element and then\r\n * serve it via next\r\n */\r\n FilteredStreamDatasource.prototype.hasNext = function () {\r\n while (this.filteredNext == null && this.inputDataSource.hasNext()) {\r\n var next = this.inputDataSource.next();\r\n if (this.filterFunc(next)) {\r\n this.filteredNext = next;\r\n return true;\r\n }\r\n else {\r\n this.filteredNext = null;\r\n }\r\n }\r\n return this.filteredNext != null;\r\n };\r\n /**\r\n * serve the next element\r\n */\r\n FilteredStreamDatasource.prototype.next = function () {\r\n var ret = this.filteredNext;\r\n this.filteredNext = null;\r\n //We have to call hasNext, to roll another\r\n //prefetch in case someone runs next\r\n //sequentially without calling hasNext\r\n this.hasNext();\r\n return ret;\r\n };\r\n FilteredStreamDatasource.prototype.reset = function () {\r\n this.filteredNext = null;\r\n this.inputDataSource.reset();\r\n };\r\n return FilteredStreamDatasource;\r\n}());\r\nexports.FilteredStreamDatasource = FilteredStreamDatasource;\r\n/**\r\n * an intermediate datasource which maps the items from\r\n * one into another\r\n */\r\nvar MappedStreamDataSource = /** @class */ (function () {\r\n function MappedStreamDataSource(mapFunc, parent) {\r\n this.mapFunc = mapFunc;\r\n this.inputDataSource = parent;\r\n }\r\n MappedStreamDataSource.prototype.hasNext = function () {\r\n return this.inputDataSource.hasNext();\r\n };\r\n MappedStreamDataSource.prototype.next = function () {\r\n return this.mapFunc(this.inputDataSource.next());\r\n };\r\n MappedStreamDataSource.prototype.reset = function () {\r\n this.inputDataSource.reset();\r\n };\r\n return MappedStreamDataSource;\r\n}());\r\nexports.MappedStreamDataSource = MappedStreamDataSource;\r\n/**\r\n * Same for flatmap to deal with element -> stream mappings\r\n */\r\nvar FlatMapStreamDataSource = /** @class */ (function () {\r\n function FlatMapStreamDataSource(func, parent) {\r\n this.mapFunc = func;\r\n this.inputDataSource = parent;\r\n }\r\n FlatMapStreamDataSource.prototype.hasNext = function () {\r\n return this.resolveCurrentNext() || this.resolveNextNext();\r\n };\r\n FlatMapStreamDataSource.prototype.resolveCurrentNext = function () {\r\n var next = false;\r\n if (this.activeDataSource) {\r\n next = this.activeDataSource.hasNext();\r\n }\r\n return next;\r\n };\r\n FlatMapStreamDataSource.prototype.resolveNextNext = function () {\r\n var next = false;\r\n while (!next && this.inputDataSource.hasNext()) {\r\n var mapped = this.mapFunc(this.inputDataSource.next());\r\n if (Array.isArray(mapped)) {\r\n this.activeDataSource = new (ArrayStreamDataSource.bind.apply(ArrayStreamDataSource, __spreadArrays([void 0], mapped)))();\r\n }\r\n else {\r\n this.activeDataSource = mapped;\r\n }\r\n next = this.activeDataSource.hasNext();\r\n }\r\n return next;\r\n };\r\n FlatMapStreamDataSource.prototype.next = function () {\r\n return this.activeDataSource.next();\r\n };\r\n FlatMapStreamDataSource.prototype.reset = function () {\r\n this.inputDataSource.reset();\r\n };\r\n return FlatMapStreamDataSource;\r\n}());\r\nexports.FlatMapStreamDataSource = FlatMapStreamDataSource;\r\n/**\r\n * For the time being we only need one collector\r\n * a collector which collects a stream back into arrays\r\n */\r\nvar ArrayCollector = /** @class */ (function () {\r\n function ArrayCollector() {\r\n this.data = [];\r\n }\r\n ArrayCollector.prototype.collect = function (element) {\r\n this.data.push(element);\r\n };\r\n Object.defineProperty(ArrayCollector.prototype, \"finalValue\", {\r\n get: function () {\r\n return this.data;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n return ArrayCollector;\r\n}());\r\nexports.ArrayCollector = ArrayCollector;\r\n/**\r\n * collects an assoc stream back to an assoc array\r\n */\r\nvar AssocArrayCollector = /** @class */ (function () {\r\n function AssocArrayCollector() {\r\n this.finalValue = {};\r\n }\r\n AssocArrayCollector.prototype.collect = function (element) {\r\n var _a, _b;\r\n this.finalValue[_a = element[0], (_a !== null && _a !== void 0 ? _a : element)] = (_b = element[1], (_b !== null && _b !== void 0 ? _b : true));\r\n };\r\n return AssocArrayCollector;\r\n}());\r\nexports.AssocArrayCollector = AssocArrayCollector;\r\n/**\r\n * Form data collector for key value pair streams\r\n */\r\nvar FormDataCollector = /** @class */ (function () {\r\n function FormDataCollector() {\r\n this.finalValue = new FormData();\r\n }\r\n FormDataCollector.prototype.collect = function (element) {\r\n this.finalValue.append(element.key, element.value);\r\n };\r\n return FormDataCollector;\r\n}());\r\nexports.FormDataCollector = FormDataCollector;\r\n/**\r\n * Form data collector for DomQuery streams\r\n */\r\nvar QueryFormDataCollector = /** @class */ (function () {\r\n function QueryFormDataCollector() {\r\n this.finalValue = new FormData();\r\n }\r\n QueryFormDataCollector.prototype.collect = function (element) {\r\n var toMerge = element.encodeFormElement();\r\n if (toMerge.isPresent()) {\r\n this.finalValue.append(element.name.value, toMerge.get(element.name).value);\r\n }\r\n };\r\n return QueryFormDataCollector;\r\n}());\r\nexports.QueryFormDataCollector = QueryFormDataCollector;\r\n/**\r\n * Encoded String collector from dom query streams\r\n */\r\nvar QueryFormStringCollector = /** @class */ (function () {\r\n function QueryFormStringCollector() {\r\n this.formData = [];\r\n }\r\n QueryFormStringCollector.prototype.collect = function (element) {\r\n var toMerge = element.encodeFormElement();\r\n if (toMerge.isPresent()) {\r\n this.formData.push([element.name.value, toMerge.get(element.name).value]);\r\n }\r\n };\r\n Object.defineProperty(QueryFormStringCollector.prototype, \"finalValue\", {\r\n get: function () {\r\n return Stream_1.Stream.of.apply(Stream_1.Stream, this.formData).map(function (keyVal) { return keyVal.join(\"=\"); })\r\n .reduce(function (item1, item2) { return [item1, item2].join(\"&\"); })\r\n .orElse(\"\").value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n return QueryFormStringCollector;\r\n}());\r\nexports.QueryFormStringCollector = QueryFormStringCollector;\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/main/typescript/ext/monadish/SourcesCollectors.ts.js","sources":["webpack:///./src/main/typescript/ext/monadish/SourcesCollectors.ts?fa08"],"sourcesContent":["/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements.  See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License.  You may obtain a copy of the License at\r\n *\r\n *      http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\nimport {Stream, StreamMapper} from \"./Stream\";\r\nimport {DomQuery} from \"./DomQuery\";\r\n\r\n/**\r\n * Every data source wich feeds data into the lazy stream\r\n * or stream generally must implement this interface\r\n *\r\n * It is basically an iteratable to the core\r\n */\r\nexport interface IStreamDataSource<T> {\r\n\r\n    /**\r\n     * @returns true if additional data is present\r\n     */\r\n    hasNext(): boolean;\r\n\r\n    /**\r\n     * false if not\r\n     */\r\n    next(): T;\r\n\r\n    /**\r\n     * resets the position to the beginning\r\n     */\r\n    reset(): void;\r\n}\r\n\r\n/**\r\n * A collector, needs to be implemented\r\n */\r\nexport interface ICollector<T, S> {\r\n    /**\r\n     * this method basically takes a single stream element\r\n     * and does something with it (collecting it one way or the other\r\n     * in most cases)\r\n     *\r\n     * @param element\r\n     */\r\n    collect(element: T);\r\n\r\n    /**\r\n     * the final result after all the collecting is done\r\n     */\r\n    finalValue: S;\r\n}\r\n\r\n/**\r\n * implementation of iteratable on top of array\r\n */\r\nexport class ArrayStreamDataSource<T> implements IStreamDataSource<T> {\r\n    value: Array<T>;\r\n    dataPos = -1;\r\n\r\n    constructor(...value: Array<T>) {\r\n        this.value = value;\r\n    }\r\n\r\n    hasNext(): boolean {\r\n        return this.value.length - 1 > this.dataPos;\r\n    }\r\n\r\n    next(): T {\r\n        this.dataPos++;\r\n        return this.value[this.dataPos];\r\n    }\r\n\r\n    reset() {\r\n        this.dataPos = -1;\r\n    }\r\n}\r\n\r\n/**\r\n * an intermediate data source wich prefilters\r\n * incoming stream data\r\n * and lets only the data out which\r\n * passes the filter function check\r\n */\r\nexport class FilteredStreamDatasource<T> implements IStreamDataSource<T> {\r\n\r\n    filterFunc: (T) => boolean;\r\n    inputDataSource: IStreamDataSource<T>;\r\n\r\n    filteredNext: T = null;\r\n\r\n    constructor(filterFunc: (T) => boolean, parent: IStreamDataSource<T>) {\r\n        this.filterFunc = filterFunc;\r\n        this.inputDataSource = parent;\r\n    }\r\n\r\n    /**\r\n     * in order to filter we have to make a look ahead until the\r\n     * first next allowed element\r\n     * hence we prefetch the element and then\r\n     * serve it via next\r\n     */\r\n    hasNext(): boolean {\r\n        while (this.filteredNext == null && this.inputDataSource.hasNext()) {\r\n            let next: T = <T>this.inputDataSource.next();\r\n            if (this.filterFunc(next)) {\r\n                this.filteredNext = next;\r\n                return true;\r\n            } else {\r\n                this.filteredNext = null;\r\n            }\r\n        }\r\n        return this.filteredNext != null;\r\n\r\n    }\r\n\r\n    /**\r\n     * serve the next element\r\n     */\r\n    next(): T {\r\n        let ret = this.filteredNext;\r\n        this.filteredNext = null;\r\n        //We have to call hasNext, to roll another\r\n        //prefetch in case someone runs next\r\n        //sequentially without calling hasNext\r\n        this.hasNext();\r\n        return ret;\r\n    }\r\n\r\n    reset(): void {\r\n        this.filteredNext = null;\r\n        this.inputDataSource.reset();\r\n    }\r\n}\r\n\r\n/**\r\n * an intermediate datasource which maps the items from\r\n * one into another\r\n */\r\nexport class MappedStreamDataSource<T, S> implements IStreamDataSource<S> {\r\n\r\n    mapFunc: (T) => S;\r\n    inputDataSource: IStreamDataSource<T>;\r\n\r\n    constructor(mapFunc: (T) => S, parent: IStreamDataSource<T>) {\r\n        this.mapFunc = mapFunc;\r\n        this.inputDataSource = parent;\r\n    }\r\n\r\n    hasNext(): boolean {\r\n        return this.inputDataSource.hasNext();\r\n    }\r\n\r\n    next(): S {\r\n        return this.mapFunc(this.inputDataSource.next());\r\n    }\r\n\r\n    reset(): void {\r\n        this.inputDataSource.reset();\r\n    }\r\n}\r\n\r\n/**\r\n * Same for flatmap to deal with element -> stream mappings\r\n */\r\nexport class FlatMapStreamDataSource<T, S> implements IStreamDataSource<S> {\r\n\r\n    mapFunc: StreamMapper<T>;\r\n\r\n    inputDataSource: IStreamDataSource<T>;\r\n\r\n    /**\r\n     * the currently active stream\r\n     * coming from an incoming element\r\n     * once the end of this one is reached\r\n     * it is swapped out by another one\r\n     * from the next element\r\n     */\r\n    activeDataSource: IStreamDataSource<S>;\r\n\r\n    constructor(func: StreamMapper<T>, parent: IStreamDataSource<T>) {\r\n        this.mapFunc = func;\r\n        this.inputDataSource = parent;\r\n    }\r\n\r\n    hasNext(): boolean {\r\n        return this.resolveCurrentNext() || this.resolveNextNext();\r\n    }\r\n\r\n    private resolveCurrentNext() {\r\n        let next = false;\r\n        if (this.activeDataSource) {\r\n            next = this.activeDataSource.hasNext();\r\n        }\r\n        return next;\r\n    }\r\n\r\n    private resolveNextNext() {\r\n        let next = false;\r\n        while (!next && this.inputDataSource.hasNext()) {\r\n            let mapped =  this.mapFunc(this.inputDataSource.next());\r\n            if(Array.isArray(mapped)) {\r\n                this.activeDataSource = new ArrayStreamDataSource(...mapped);\r\n            } else {\r\n                this.activeDataSource = mapped;\r\n            }\r\n            next = this.activeDataSource.hasNext();\r\n        }\r\n        return next;\r\n    }\r\n\r\n    next(): S {\r\n        return this.activeDataSource.next();\r\n    }\r\n\r\n    reset(): void {\r\n        this.inputDataSource.reset();\r\n    }\r\n}\r\n\r\n/**\r\n * For the time being we only need one collector\r\n * a collector which collects a stream back into arrays\r\n */\r\nexport class ArrayCollector<S> implements ICollector<S, Array<S>> {\r\n    private data: Array<S> = [];\r\n\r\n    collect(element: S) {\r\n        this.data.push(element);\r\n    }\r\n\r\n    get finalValue(): Array<S> {\r\n        return this.data;\r\n    }\r\n}\r\n\r\n/**\r\n * collects an assoc stream back to an assoc array\r\n */\r\nexport class AssocArrayCollector<S> implements ICollector<[string, S] | string, {[key:string]:S}> {\r\n\r\n    finalValue: {[key:string]:any} = {};\r\n\r\n    collect(element: [string, S] | string) {\r\n        this.finalValue[element[0] ?? <string>element] = element[1] ?? true;\r\n    }\r\n}\r\n\r\n/**\r\n * Form data collector for key value pair streams\r\n */\r\nexport class FormDataCollector implements ICollector<{ key: string, value: any }, FormData> {\r\n    finalValue: FormData = new FormData();\r\n\r\n    collect(element: { key: string; value: any }) {\r\n        this.finalValue.append(element.key, element.value);\r\n    }\r\n}\r\n\r\n/**\r\n * Form data collector for DomQuery streams\r\n */\r\nexport class QueryFormDataCollector implements ICollector<DomQuery, FormData> {\r\n    finalValue: FormData = new FormData();\r\n\r\n    collect(element: DomQuery) {\r\n        let toMerge = element.encodeFormElement();\r\n        if (toMerge.isPresent()) {\r\n            this.finalValue.append(element.name.value, toMerge.get(element.name).value);\r\n        }\r\n    }\r\n}\r\n\r\n/**\r\n * Encoded String collector from dom query streams\r\n */\r\nexport class QueryFormStringCollector implements ICollector<DomQuery, string> {\r\n\r\n    formData: [[string, string]] = <any>[];\r\n\r\n    collect(element: DomQuery) {\r\n        let toMerge = element.encodeFormElement();\r\n        if (toMerge.isPresent()) {\r\n            this.formData.push([element.name.value, toMerge.get(element.name).value]);\r\n        }\r\n    }\r\n\r\n    get finalValue(): string {\r\n        return Stream.of(...this.formData)\r\n            .map<string>(keyVal => keyVal.join(\"=\"))\r\n            .reduce((item1, item2) => [item1, item2].join(\"&\"))\r\n            .orElse(\"\").value;\r\n    }\r\n}"],"mappings":";AAAA;;;;;;;;;;;;;;AAcA;;;;;;;;;AAEA;AA8CA;;AAEA;AACA;AAIA;AAAA;AAAA;AAAA;;AAFA;AAGA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAAA;AApBA;AAsBA;;;;;AAKA;AACA;AAOA;AAFA;AAGA;AACA;AACA;AAEA;;;;;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAAA;AAjDA;AAmDA;;;AAGA;AACA;AAKA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAAA;AArBA;AAuBA;;AAEA;AACA;AAeA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAAA;AArDA;AAuDA;;;AAGA;AACA;AAAA;AACA;AASA;AAPA;AACA;AACA;AAEA;AAAA;AACA;AACA;;;AAAA;AACA;AAAA;AAVA;AAYA;;AAEA;AACA;AAAA;AAEA;AAKA;AAHA;;AACA;AACA;AACA;AAAA;AAPA;AASA;;AAEA;AACA;AAAA;AACA;AAKA;AAHA;AACA;AACA;AACA;AAAA;AANA;AAQA;;AAEA;AACA;AAAA;AACA;AAQA;AANA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AATA;AAWA;;AAEA;AACA;AAAA;AAEA;AAeA;AAbA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AACA;AAEA;AACA;AACA;;;AAAA;AACA;AAAA;AAjBA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/main/typescript/ext/monadish/SourcesCollectors.ts\n");
/***/ }),
/***/ "./src/main/typescript/ext/monadish/Stream.ts":
/*!****************************************************!*\
!*** ./src/main/typescript/ext/monadish/Stream.ts ***!
\****************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nvar __spreadArrays = (this && this.__spreadArrays) || function () {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n};\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\n/*\r\n * A small stream implementation\r\n */\r\nvar Monad_1 = __webpack_require__(/*! ./Monad */ \"./src/main/typescript/ext/monadish/Monad.ts\");\r\nvar SourcesCollectors_1 = __webpack_require__(/*! ./SourcesCollectors */ \"./src/main/typescript/ext/monadish/SourcesCollectors.ts\");\r\n/**\r\n * A simple typescript based reimplementation of streams\r\n *\r\n * This is the early eval version\r\n * for a lazy eval version check, LazyStream, which is api compatible\r\n * to this implementation, however with the benefit of being able\r\n * to provide infinite data sources and generic data providers, the downside\r\n * is, it might be a tad slower in some situations\r\n */\r\nvar Stream = /** @class */ (function () {\r\n function Stream() {\r\n var value = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n value[_i] = arguments[_i];\r\n }\r\n this._limits = -1;\r\n this.pos = -1;\r\n this.value = value;\r\n }\r\n Stream.of = function () {\r\n var data = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n data[_i] = arguments[_i];\r\n }\r\n return new (Stream.bind.apply(Stream, __spreadArrays([void 0], data)))();\r\n };\r\n Stream.ofAssoc = function (data) {\r\n return this.of.apply(this, Object.keys(data)).map(function (key) { return [key, data[key]]; });\r\n };\r\n Stream.ofDataSource = function (dataSource) {\r\n var value = [];\r\n while (dataSource.hasNext()) {\r\n value.push(dataSource.next());\r\n }\r\n return new (Stream.bind.apply(Stream, __spreadArrays([void 0], value)))();\r\n };\r\n Stream.prototype.limits = function (end) {\r\n this._limits = end;\r\n return this;\r\n };\r\n Stream.prototype.onElem = function (fn) {\r\n for (var cnt = 0; cnt < this.value.length && (this._limits == -1 || cnt < this._limits); cnt++) {\r\n if (fn(this.value[cnt], cnt) === false) {\r\n break;\r\n }\r\n }\r\n return this;\r\n };\r\n Stream.prototype.each = function (fn) {\r\n this.onElem(fn);\r\n };\r\n Stream.prototype.map = function (fn) {\r\n if (!fn) {\r\n fn = function (inval) { return inval; };\r\n }\r\n var res = [];\r\n this.each(function (item, cnt) {\r\n res.push(fn(item));\r\n });\r\n return new (Stream.bind.apply(Stream, __spreadArrays([void 0], res)))();\r\n };\r\n /*\r\n * we need to implement it to fullfill the contract, although it is used only internally\r\n * all values are flattened when accessed anyway, so there is no need to call this methiod\r\n */\r\n Stream.prototype.flatMap = function (fn) {\r\n var ret = [];\r\n this.each(function (item) {\r\n var strmR = fn(item);\r\n ret = Array.isArray(strmR) ? ret.concat(strmR) : ret.concat.apply(ret, strmR.value);\r\n });\r\n return Stream.of.apply(Stream, ret);\r\n };\r\n Stream.prototype.filter = function (fn) {\r\n var res = [];\r\n this.each(function (data) {\r\n if (fn(data)) {\r\n res.push(data);\r\n }\r\n });\r\n return new (Stream.bind.apply(Stream, __spreadArrays([void 0], res)))();\r\n };\r\n Stream.prototype.reduce = function (fn, startVal) {\r\n if (startVal === void 0) { startVal = null; }\r\n var offset = startVal != null ? 0 : 1;\r\n var val1 = startVal != null ? startVal : this.value.length ? this.value[0] : null;\r\n for (var cnt = offset; cnt < this.value.length && (this._limits == -1 || cnt < this._limits); cnt++) {\r\n val1 = fn(val1, this.value[cnt]);\r\n }\r\n return Monad_1.Optional.fromNullable(val1);\r\n };\r\n Stream.prototype.first = function () {\r\n return this.value && this.value.length ? Monad_1.Optional.fromNullable(this.value[0]) : Monad_1.Optional.absent;\r\n };\r\n Stream.prototype.last = function () {\r\n //could be done via reduce, but is faster this way\r\n var length = this._limits > 0 ? Math.min(this._limits, this.value.length) : this.value.length;\r\n return Monad_1.Optional.fromNullable(length ? this.value[length - 1] : null);\r\n };\r\n Stream.prototype.anyMatch = function (fn) {\r\n for (var cnt = 0; cnt < this.value.length && (this._limits == -1 || cnt < this._limits); cnt++) {\r\n if (fn(this.value[cnt])) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n };\r\n Stream.prototype.allMatch = function (fn) {\r\n if (!this.value.length) {\r\n return false;\r\n }\r\n var matches = 0;\r\n for (var cnt = 0; cnt < this.value.length; cnt++) {\r\n if (fn(this.value[cnt])) {\r\n matches++;\r\n }\r\n }\r\n return matches == this.value.length;\r\n };\r\n Stream.prototype.noneMatch = function (fn) {\r\n var matches = 0;\r\n for (var cnt = 0; cnt < this.value.length; cnt++) {\r\n if (!fn(this.value[cnt])) {\r\n matches++;\r\n }\r\n }\r\n return matches == this.value.length;\r\n };\r\n Stream.prototype.sort = function (comparator) {\r\n var newArr = this.value.slice().sort(comparator);\r\n return Stream.of.apply(Stream, newArr);\r\n };\r\n Stream.prototype.collect = function (collector) {\r\n this.each(function (data) { return collector.collect(data); });\r\n return collector.finalValue;\r\n };\r\n //-- internally exposed methods needed for the interconnectivity\r\n Stream.prototype.hasNext = function () {\r\n var isLimitsReached = this._limits != -1 && this.pos >= this._limits - 1;\r\n var isEndOfArray = this.pos >= this.value.length - 1;\r\n return !(isLimitsReached || isEndOfArray);\r\n };\r\n Stream.prototype.next = function () {\r\n if (!this.hasNext()) {\r\n return null;\r\n }\r\n this.pos++;\r\n return this.value[this.pos];\r\n };\r\n Stream.prototype.reset = function () {\r\n this.pos = -1;\r\n };\r\n return Stream;\r\n}());\r\nexports.Stream = Stream;\r\n/**\r\n * Lazy implementation of a Stream\r\n * The idea is to connect the intermediate\r\n * streams as datasources like a linked list\r\n * with reverse referencing and for special\r\n * operations like filtering flatmapping\r\n * have intermediate datasources in the list\r\n * with specialized functions.\r\n *\r\n * Sort of a modified pipe valve pattern\r\n * the streams are the pipes the intermediate\r\n * data sources are the valves\r\n *\r\n * We then can use passed in functions to control\r\n * the flow in the valves\r\n *\r\n * That way we can have a lazy evaluating stream\r\n *\r\n * So if an endpoint requests data\r\n * a callback trace goes back the stream list\r\n * which triggers an operation upwards\r\n * which sends data down the drain which then is processed\r\n * and filtered until one element hits the endpoint.\r\n *\r\n * That is repeated, until all elements are processed\r\n * or an internal limit is hit.\r\n *\r\n */\r\nvar LazyStream = /** @class */ (function () {\r\n function LazyStream(parent) {\r\n this._limits = -1;\r\n /*\r\n * needed to have the limits check working\r\n * we need to keep track of the current position\r\n * in the stream\r\n */\r\n this.pos = -1;\r\n this.dataSource = parent;\r\n }\r\n LazyStream.of = function () {\r\n var values = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n values[_i] = arguments[_i];\r\n }\r\n return new LazyStream(new (SourcesCollectors_1.ArrayStreamDataSource.bind.apply(SourcesCollectors_1.ArrayStreamDataSource, __spreadArrays([void 0], values)))());\r\n };\r\n LazyStream.ofAssoc = function (data) {\r\n return this.of.apply(this, Object.keys(data)).map(function (key) { return [key, data[key]]; });\r\n };\r\n LazyStream.ofStreamDataSource = function (value) {\r\n return new LazyStream(value);\r\n };\r\n LazyStream.prototype.hasNext = function () {\r\n if (this.isOverLimits()) {\r\n return false;\r\n }\r\n return this.dataSource.hasNext();\r\n };\r\n LazyStream.prototype.next = function () {\r\n var next = this.dataSource.next();\r\n // @ts-ignore\r\n this.pos++;\r\n return next;\r\n };\r\n LazyStream.prototype.reset = function () {\r\n this.dataSource.reset();\r\n this.pos = 0;\r\n this._limits = -1;\r\n };\r\n LazyStream.prototype.nextFilter = function (fn) {\r\n if (this.hasNext()) {\r\n var newVal = this.next();\r\n if (!fn(newVal)) {\r\n return this.nextFilter(fn);\r\n }\r\n return newVal;\r\n }\r\n return null;\r\n };\r\n LazyStream.prototype.limits = function (max) {\r\n this._limits = max;\r\n return this;\r\n };\r\n //main stream methods\r\n LazyStream.prototype.collect = function (collector) {\r\n while (this.hasNext()) {\r\n var t = this.next();\r\n collector.collect(t);\r\n }\r\n return collector.finalValue;\r\n };\r\n LazyStream.prototype.onElem = function (fn) {\r\n var _this = this;\r\n return new LazyStream(new SourcesCollectors_1.MappedStreamDataSource(function (el) {\r\n if (fn(el, _this.pos) === false) {\r\n _this.stop();\r\n }\r\n return el;\r\n }, this));\r\n };\r\n LazyStream.prototype.filter = function (fn) {\r\n return new LazyStream(new SourcesCollectors_1.FilteredStreamDatasource(fn, this));\r\n };\r\n LazyStream.prototype.map = function (fn) {\r\n return new LazyStream(new SourcesCollectors_1.MappedStreamDataSource(fn, this));\r\n };\r\n LazyStream.prototype.flatMap = function (fn) {\r\n return new LazyStream(new SourcesCollectors_1.FlatMapStreamDataSource(fn, this));\r\n };\r\n //endpoint\r\n LazyStream.prototype.each = function (fn) {\r\n while (this.hasNext()) {\r\n if (fn(this.next()) === false) {\r\n this.stop();\r\n }\r\n }\r\n };\r\n LazyStream.prototype.reduce = function (fn, startVal) {\r\n if (startVal === void 0) { startVal = null; }\r\n if (!this.hasNext()) {\r\n return Monad_1.Optional.absent;\r\n }\r\n var value1 = null;\r\n var value2 = null;\r\n if (startVal != null) {\r\n value1 = startVal;\r\n value2 = this.next();\r\n }\r\n else {\r\n value1 = this.next();\r\n if (!this.hasNext()) {\r\n return Monad_1.Optional.fromNullable(value1);\r\n }\r\n value2 = this.next();\r\n }\r\n value1 = fn(value1, value2);\r\n while (this.hasNext()) {\r\n value2 = this.next();\r\n value1 = fn(value1, value2);\r\n }\r\n return Monad_1.Optional.fromNullable(value1);\r\n };\r\n LazyStream.prototype.last = function () {\r\n if (!this.hasNext()) {\r\n return Monad_1.Optional.absent;\r\n }\r\n return this.reduce(function (el1, el2) { return el2; });\r\n };\r\n LazyStream.prototype.first = function () {\r\n this.reset();\r\n if (!this.hasNext()) {\r\n return Monad_1.Optional.absent;\r\n }\r\n return Monad_1.Optional.fromNullable(this.next());\r\n };\r\n LazyStream.prototype.anyMatch = function (fn) {\r\n while (this.hasNext()) {\r\n if (fn(this.next())) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n };\r\n LazyStream.prototype.allMatch = function (fn) {\r\n while (this.hasNext()) {\r\n if (!fn(this.next())) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n LazyStream.prototype.noneMatch = function (fn) {\r\n while (this.hasNext()) {\r\n if (fn(this.next())) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n };\r\n LazyStream.prototype.sort = function (comparator) {\r\n var arr = this.collect(new SourcesCollectors_1.ArrayCollector());\r\n arr = arr.sort(comparator);\r\n return LazyStream.of.apply(LazyStream, arr);\r\n };\r\n Object.defineProperty(LazyStream.prototype, \"value\", {\r\n get: function () {\r\n return this.collect(new SourcesCollectors_1.ArrayCollector());\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n LazyStream.prototype.stop = function () {\r\n this.pos = this._limits + 1000000000;\r\n };\r\n LazyStream.prototype.isOverLimits = function () {\r\n return this._limits != -1 && this.pos >= this._limits - 1;\r\n };\r\n return LazyStream;\r\n}());\r\nexports.LazyStream = LazyStream;\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/main/typescript/ext/monadish/Stream.ts.js","sources":["webpack:///./src/main/typescript/ext/monadish/Stream.ts?945b"],"sourcesContent":["/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements.  See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License.  You may obtain a copy of the License at\r\n *\r\n *      http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\n/*\r\n * A small stream implementation\r\n */\r\nimport {IMonad, IValueHolder, Optional} from \"./Monad\";\r\nimport {\r\n    ArrayCollector,\r\n    ArrayStreamDataSource,\r\n    FilteredStreamDatasource, FlatMapStreamDataSource,\r\n    ICollector,\r\n    IStreamDataSource,\r\n    MappedStreamDataSource\r\n} from \"./SourcesCollectors\";\r\n\r\n/*\r\n * some typedefs to make the code more reabable\r\n */\r\nexport type StreamMapper<T> = (data: T) => IStreamDataSource<any>;\r\nexport type ArrayMapper<T> = (data: T) => Array<any>;\r\nexport type IteratableConsumer<T> = (data: T, pos ?: number) => void | boolean;\r\nexport type Reducable<T> = (val1: T, val2: T) => T;\r\nexport type Matchable<T> = (data: T) => boolean;\r\nexport type Mappable<T, R> = (data: T) => R;\r\nexport type Comparator<T> = (el1: T, el2: T) => number;\r\n\r\n/**\r\n * Generic interface defining a stream\r\n */\r\nexport interface IStream<T> {\r\n    /**\r\n     * Perform the operation fn on a single element in the stream at a time\r\n     * then pass the stream over for further processing\r\n     * This is basically an intermediate point in the stream\r\n     * with further processing happening later, do not use\r\n     * this method to gather data or iterate over all date for processing\r\n     * (for the second case each has to be used)\r\n     *\r\n     * @param fn the processing function, if it returns false, further processing is stopped\r\n     */\r\n    onElem(fn: IteratableConsumer<T>): IStream<T>;\r\n\r\n    /**\r\n     * Iterate over all elements in the stream and do some processing via fn\r\n     *\r\n     * @param fn takes a single element and if it returns false\r\n     * then further processing is stopped\r\n     */\r\n    each(fn: IteratableConsumer<T>): void;\r\n\r\n    /**\r\n     * maps a single element into another via fn\r\n     * @param fn function which takes one element in and returns another\r\n     */\r\n    map<R>(fn?: Mappable<T, R>): IStream<R>;\r\n\r\n    /**\r\n     * Takes an element in and returns a set of something\r\n     * the set then is flatted into a single stream to be further processed\r\n     *\r\n     * @param fn\r\n     */\r\n    flatMap<R>(fn?: StreamMapper<T> | ArrayMapper<T>): IStream<R>;\r\n\r\n    /**\r\n     * filtering, takes an element in and is processed by fn.\r\n     * If it returns false then further processing on this element is skipped\r\n     * if it returns true it is passed down the chain.\r\n     *\r\n     * @param fn\r\n     */\r\n    filter(fn?: Matchable<T>): IStream<T>;\r\n\r\n    /**\r\n     * functional reduce... takes two elements in the stream and reduces to\r\n     * one from left to right\r\n     *\r\n     * @param fn the reduction function for instance (val1,val2) => val1l+val2\r\n     * @param startVal an optional starting value, if provided the the processing starts with this element\r\n     * and further goes down into the stream, if not, then the first two elements are taken as reduction starting point\r\n     */\r\n    reduce(fn: Reducable<T>, startVal: T): Optional<T>;\r\n\r\n    /**\r\n     * returns the first element in the stream is given as Optional\r\n     */\r\n    first(): Optional<T>;\r\n\r\n    /**\r\n     * Returns the last stream element (note in endless streams without filtering and limiting you will never reach that\r\n     * point hence producing an endless loop)\r\n     */\r\n    last(): Optional<T>;\r\n\r\n    /**\r\n     * returns true if there is at least one element where a call fn(element) produces true\r\n     *\r\n     * @param fn\r\n     */\r\n    anyMatch(fn: Matchable<T>): boolean;\r\n\r\n    /**\r\n     * returns true if all elmements produce true on a call to fn(element)\r\n     *\r\n     * @param fn\r\n     */\r\n    allMatch(fn: Matchable<T>): boolean;\r\n\r\n    /**\r\n     * returns true if no elmements produce true on a call to fn(element)\r\n     *\r\n     * @param fn\r\n     */\r\n    noneMatch(fn: Matchable<T>): boolean;\r\n\r\n    /**\r\n     * Collect the elements with a collector given\r\n     * There are a number of collectors provided\r\n     *\r\n     * @param collector\r\n     */\r\n    collect(collector: ICollector<T, any>): any;\r\n\r\n    /**\r\n     * sort on the stream, this is a special case\r\n     * of an endpoint, so your data which is fed in needs\r\n     * to be limited otherwise it will fail\r\n     * it still returns a stream for further processing\r\n     *\r\n     * @param comparator\r\n     */\r\n    sort(comparator: Comparator<T>): IStream<T>;\r\n\r\n    /**\r\n     * Limits the stream to a certain number of elements\r\n     *\r\n     * @param end the limit of the stream\r\n     */\r\n    limits(end: number): IStream<T>;\r\n\r\n    /**\r\n     * returns the stream collected into an array (90% use-case abbreviation\r\n     */\r\n    value: Array<T>;\r\n}\r\n\r\n/**\r\n * A simple typescript based reimplementation of streams\r\n *\r\n * This is the early eval version\r\n * for a lazy eval version check, LazyStream, which is api compatible\r\n * to this implementation, however with the benefit of being able\r\n * to provide infinite data sources and generic data providers, the downside\r\n * is, it might be a tad slower in some situations\r\n */\r\nexport class Stream<T> implements IMonad<T, Stream<any>>, IValueHolder<Array<T>>, IStream<T> {\r\n\r\n    value: Array<T>;\r\n    _limits = -1;\r\n\r\n    private pos = -1;\r\n\r\n    constructor(...value: T[]) {\r\n        this.value = value;\r\n    }\r\n\r\n    static of<T>(...data: Array<T>): Stream<T> {\r\n        return new Stream<T>(...data);\r\n    }\r\n\r\n    static ofAssoc<T>(data: {[key: string]: T}): Stream<[string, T]> {\r\n        return this.of(...Object.keys(data)).map(key => [key, data[key]]);\r\n    }\r\n\r\n    static ofDataSource<T>(dataSource: IStreamDataSource<T>) {\r\n        let value: T[] = [];\r\n        while (dataSource.hasNext()) {\r\n            value.push(dataSource.next());\r\n        }\r\n\r\n        return new Stream(...value);\r\n    }\r\n\r\n    limits(end: number): Stream<T> {\r\n        this._limits = end;\r\n        return this;\r\n    }\r\n\r\n    onElem(fn: (data: T, pos ?: number) => void | boolean): Stream<T> {\r\n        for (let cnt = 0; cnt < this.value.length && (this._limits == -1 || cnt < this._limits); cnt++) {\r\n            if (fn(this.value[cnt], cnt) === false) {\r\n                break;\r\n            }\r\n        }\r\n        return this;\r\n    }\r\n\r\n    each(fn: (data: T, pos ?: number) => void | boolean) {\r\n        this.onElem(fn);\r\n    }\r\n\r\n    map<R>(fn?: (data: T) => R): Stream<R> {\r\n        if (!fn) {\r\n            fn = (inval: any) => <R>inval;\r\n        }\r\n        let res: R[] = [];\r\n        this.each((item, cnt) => {\r\n            res.push(fn(item))\r\n        });\r\n\r\n        return new Stream<R>(...res);\r\n    }\r\n\r\n    /*\r\n     * we need to implement it to fullfill the contract, although it is used only internally\r\n     * all values are flattened when accessed anyway, so there is no need to call this methiod\r\n     */\r\n\r\n    flatMap<IStreamDataSource>(fn: (data: T) => IStreamDataSource | Array<any>): Stream<any> {\r\n        let ret = [];\r\n        this.each(item => {\r\n            let strmR: any = fn(item);\r\n            ret = Array.isArray(strmR) ? ret.concat(strmR) : ret.concat(...strmR.value);\r\n        });\r\n        return <Stream<any>>Stream.of(...ret);\r\n    }\r\n\r\n    filter(fn?: (data: T) => boolean): Stream<T> {\r\n        let res: Array<T> = [];\r\n        this.each((data) => {\r\n            if (fn(data)) {\r\n                res.push(data);\r\n            }\r\n        });\r\n        return new Stream<T>(...res);\r\n    }\r\n\r\n    reduce(fn: Reducable<T>, startVal: T = null): Optional<T> {\r\n        let offset = startVal != null ? 0 : 1;\r\n        let val1 = startVal != null ? startVal : this.value.length ? this.value[0] : null;\r\n\r\n        for (let cnt = offset; cnt < this.value.length && (this._limits == -1 || cnt < this._limits); cnt++) {\r\n            val1 = fn(val1, this.value[cnt]);\r\n        }\r\n        return Optional.fromNullable(val1);\r\n    }\r\n\r\n    first(): Optional<T> {\r\n        return this.value && this.value.length ? Optional.fromNullable(this.value[0]) : Optional.absent;\r\n    }\r\n\r\n    last(): Optional<T> {\r\n        //could be done via reduce, but is faster this way\r\n        let length = this._limits > 0 ? Math.min(this._limits, this.value.length) : this.value.length;\r\n\r\n        return Optional.fromNullable(length ? this.value[length - 1] : null);\r\n    }\r\n\r\n    anyMatch(fn: Matchable<T>): boolean {\r\n        for (let cnt = 0; cnt < this.value.length && (this._limits == -1 || cnt < this._limits); cnt++) {\r\n            if (fn(this.value[cnt])) {\r\n                return true;\r\n            }\r\n        }\r\n        return false;\r\n    }\r\n\r\n    allMatch(fn: Matchable<T>): boolean {\r\n        if (!this.value.length) {\r\n            return false;\r\n        }\r\n        let matches = 0;\r\n        for (let cnt = 0; cnt < this.value.length; cnt++) {\r\n            if (fn(this.value[cnt])) {\r\n                matches++;\r\n            }\r\n        }\r\n        return matches == this.value.length;\r\n    }\r\n\r\n    noneMatch(fn: Matchable<T>): boolean {\r\n        let matches = 0;\r\n        for (let cnt = 0; cnt < this.value.length; cnt++) {\r\n            if (!fn(this.value[cnt])) {\r\n                matches++;\r\n            }\r\n        }\r\n        return matches == this.value.length;\r\n    }\r\n\r\n    sort(comparator: Comparator<T>): IStream<T> {\r\n        let newArr = this.value.slice().sort(comparator);\r\n        return Stream.of(...newArr);\r\n    }\r\n\r\n\r\n    collect(collector: ICollector<T, any>): any {\r\n        this.each(data => collector.collect(data));\r\n        return collector.finalValue;\r\n    }\r\n\r\n    //-- internally exposed methods needed for the interconnectivity\r\n    hasNext() {\r\n        let isLimitsReached = this._limits != -1 && this.pos >= this._limits - 1;\r\n        let isEndOfArray = this.pos >= this.value.length - 1;\r\n        return !(isLimitsReached || isEndOfArray);\r\n    }\r\n\r\n    next(): T {\r\n        if (!this.hasNext()) {\r\n            return null;\r\n        }\r\n        this.pos++;\r\n        return this.value[this.pos];\r\n    }\r\n\r\n    reset() {\r\n        this.pos = -1;\r\n    }\r\n\r\n}\r\n\r\n/**\r\n * Lazy implementation of a Stream\r\n * The idea is to connect the intermediate\r\n * streams as datasources like a linked list\r\n * with reverse referencing and for special\r\n * operations like filtering flatmapping\r\n * have intermediate datasources in the list\r\n * with specialized functions.\r\n *\r\n * Sort of a modified pipe valve pattern\r\n * the streams are the pipes the intermediate\r\n * data sources are the valves\r\n *\r\n * We then can use passed in functions to control\r\n * the flow in the valves\r\n *\r\n * That way we can have a lazy evaluating stream\r\n *\r\n * So if an endpoint requests data\r\n * a callback trace goes back the stream list\r\n * which triggers an operation upwards\r\n * which sends data down the drain which then is processed\r\n * and filtered until one element hits the endpoint.\r\n *\r\n * That is repeated, until all elements are processed\r\n * or an internal limit is hit.\r\n *\r\n */\r\nexport class LazyStream<T> implements IStreamDataSource<T>, IStream<T>, IMonad<T, LazyStream<any>> {\r\n\r\n    protected dataSource: IStreamDataSource<T>;\r\n    _limits = -1;\r\n\r\n    /*\r\n     * needed to have the limits check working\r\n     * we need to keep track of the current position\r\n     * in the stream\r\n     */\r\n    pos = -1;\r\n\r\n    static of<T>(...values: Array<T>): LazyStream<T> {\r\n        return new LazyStream<T>(new ArrayStreamDataSource(...values));\r\n    }\r\n\r\n    static ofAssoc<T>(data: {[key: string]: T}): LazyStream<[string, T]> {\r\n        return this.of(...Object.keys(data)).map(key => [key, data[key]]);\r\n    }\r\n\r\n    static ofStreamDataSource<T>(value: IStreamDataSource<T>): LazyStream<T> {\r\n        return new LazyStream(value);\r\n    }\r\n\r\n    constructor(parent: IStreamDataSource<T>) {\r\n        this.dataSource = parent;\r\n\r\n    }\r\n\r\n    hasNext(): boolean {\r\n        if (this.isOverLimits()) {\r\n            return false;\r\n        }\r\n\r\n        return this.dataSource.hasNext();\r\n    }\r\n\r\n    next(): T {\r\n        let next = this.dataSource.next();\r\n        // @ts-ignore\r\n        this.pos++;\r\n        return next;\r\n    }\r\n\r\n    reset(): void {\r\n        this.dataSource.reset();\r\n        this.pos = 0;\r\n        this._limits = -1;\r\n    }\r\n\r\n    nextFilter(fn: Matchable<T>): T {\r\n        if (this.hasNext()) {\r\n            let newVal: T = this.next();\r\n            if (!fn(newVal)) {\r\n                return this.nextFilter(fn);\r\n            }\r\n            return <T>newVal;\r\n        }\r\n        return null;\r\n    }\r\n\r\n    limits(max: number): LazyStream<T> {\r\n        this._limits = max;\r\n        return this;\r\n    }\r\n\r\n    //main stream methods\r\n    collect(collector: ICollector<T, any>): any {\r\n        while (this.hasNext()) {\r\n            let t = this.next();\r\n            collector.collect(<T>t);\r\n        }\r\n        return collector.finalValue;\r\n    }\r\n\r\n    onElem(fn: IteratableConsumer<T>): LazyStream<T> {\r\n        return new LazyStream(new MappedStreamDataSource((el) => {\r\n            if (fn(el, this.pos) === false) {\r\n                this.stop();\r\n            }\r\n            return el;\r\n        }, this));\r\n    }\r\n\r\n    filter(fn: Matchable<T>): LazyStream<T> {\r\n        return <LazyStream<T>>new LazyStream<T>(new FilteredStreamDatasource<any>(fn, this));\r\n    }\r\n\r\n    map<R>(fn: Mappable<T, R>): LazyStream<any> {\r\n        return new LazyStream(new MappedStreamDataSource(fn, this));\r\n    }\r\n\r\n    flatMap<StreamMapper>(fn: StreamMapper | ArrayMapper<any>): LazyStream<any> {\r\n\r\n        return new LazyStream<any>(new FlatMapStreamDataSource(<any>fn, this));\r\n    }\r\n\r\n    //endpoint\r\n    each(fn: IteratableConsumer<T>) {\r\n        while (this.hasNext()) {\r\n            if (fn(this.next()) === false) {\r\n                this.stop();\r\n            }\r\n        }\r\n    }\r\n\r\n    reduce(fn: Reducable<T>, startVal: T = null): Optional<T> {\r\n        if (!this.hasNext()) {\r\n            return Optional.absent;\r\n        }\r\n        let value1 = null;\r\n        let value2 = null;\r\n        if (startVal != null) {\r\n            value1 = startVal;\r\n            value2 = this.next();\r\n        } else {\r\n            value1 = this.next();\r\n            if (!this.hasNext()) {\r\n                return Optional.fromNullable(value1);\r\n            }\r\n            value2 = this.next();\r\n        }\r\n        value1 = fn(value1, value2);\r\n        while (this.hasNext()) {\r\n            value2 = this.next();\r\n            value1 = fn(value1, value2);\r\n        }\r\n\r\n        return Optional.fromNullable(value1);\r\n    }\r\n\r\n    last(): Optional<T> {\r\n        if (!this.hasNext()) {\r\n            return Optional.absent;\r\n        }\r\n        return this.reduce((el1, el2) => el2);\r\n    }\r\n\r\n    first(): Optional<T> {\r\n        this.reset();\r\n        if (!this.hasNext()) {\r\n            return Optional.absent;\r\n        }\r\n        return Optional.fromNullable(this.next());\r\n    }\r\n\r\n    anyMatch(fn: Matchable<T>): boolean {\r\n        while (this.hasNext()) {\r\n            if (fn(this.next())) {\r\n                return true;\r\n            }\r\n        }\r\n        return false;\r\n    }\r\n\r\n    allMatch(fn: Matchable<T>): boolean {\r\n        while (this.hasNext()) {\r\n            if (!fn(this.next())) {\r\n                return false;\r\n            }\r\n        }\r\n        return true;\r\n    }\r\n\r\n    noneMatch(fn: Matchable<T>): boolean {\r\n        while (this.hasNext()) {\r\n            if (fn(this.next())) {\r\n                return false;\r\n            }\r\n        }\r\n        return true;\r\n    }\r\n\r\n    sort(comparator: Comparator<T>): IStream<T> {\r\n        let arr = this.collect(new ArrayCollector());\r\n        arr = arr.sort(comparator);\r\n        return LazyStream.of(...arr);\r\n    }\r\n\r\n    get value(): Array<T> {\r\n        return this.collect(new ArrayCollector<T>());\r\n    }\r\n\r\n    private stop() {\r\n        this.pos = this._limits + 1000000000;\r\n    }\r\n\r\n    private isOverLimits() {\r\n        return this._limits != -1 && this.pos >= this._limits - 1;\r\n    }\r\n\r\n}\r\n\r\n\r\n"],"mappings":";AAAA;;;;;;;;;;;;;;AAcA;;;;;;;;;AAEA;;AAEA;AACA;AACA;AA4IA;;;;;;;;AAQA;AACA;AAOA;AAAA;AAAA;AAAA;;AAJA;AAEA;AAGA;AACA;AAEA;AAAA;AAAA;AAAA;;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;;;AAGA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAAA;AArKA;AAuKA;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2BA;AACA;AAwBA;AArBA;AAEA;;;;AAIA;AACA;AAeA;AAEA;AAfA;AAAA;AAAA;AAAA;;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAOA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;;;AAAA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAAA;AA/LA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/main/typescript/ext/monadish/Stream.ts\n");
/***/ }),
/***/ "./src/main/typescript/ext/monadish/XmlQuery.ts":
/*!******************************************************!*\
!*** ./src/main/typescript/ext/monadish/XmlQuery.ts ***!
\******************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nvar __extends = (this && this.__extends) || (function () {\r\n var extendStatics = function (d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n };\r\n return function (d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n };\r\n})();\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar Lang_1 = __webpack_require__(/*! ./Lang */ \"./src/main/typescript/ext/monadish/Lang.ts\");\r\nvar DomQuery_1 = __webpack_require__(/*! ./DomQuery */ \"./src/main/typescript/ext/monadish/DomQuery.ts\");\r\nvar isString = Lang_1.Lang.isString;\r\n/**\r\n * xml query as specialized case for DomQuery\r\n */\r\nvar XMLQuery = /** @class */ (function (_super) {\r\n __extends(XMLQuery, _super);\r\n function XMLQuery(rootNode, docType) {\r\n if (docType === void 0) { docType = \"text/xml\"; }\r\n var _this = this;\r\n var createIe11DomQueryShim = function () {\r\n //at the time if wroting ie11 is the only relevant browser\r\n //left withut any DomQuery support\r\n var parser = new ActiveXObject(\"Microsoft.XMLDOM\");\r\n parser.async = false;\r\n //we shim th dom parser from ie in\r\n return {\r\n parseFromString: function (text, contentType) {\r\n return parser.loadXML(text);\r\n }\r\n };\r\n };\r\n var parseXML = function (xml) {\r\n if (xml == null) {\r\n return null;\r\n }\r\n var domParser = Lang_1.Lang.saveResolveLazy(function () { return new window.DOMParser(); }, function () { return createIe11DomQueryShim(); }).value;\r\n return domParser.parseFromString(xml, docType);\r\n };\r\n if (isString(rootNode)) {\r\n _this = _super.call(this, parseXML(rootNode)) || this;\r\n }\r\n else {\r\n _this = _super.call(this, rootNode) || this;\r\n }\r\n return _this;\r\n }\r\n XMLQuery.prototype.isXMLParserError = function () {\r\n return this.querySelectorAll(\"parsererror\").isPresent();\r\n };\r\n XMLQuery.prototype.toString = function () {\r\n var ret = [];\r\n this.eachElem(function (node) {\r\n var _a, _b, _c, _d, _e;\r\n var serialized = (_d = (_c = (_b = (_a = window) === null || _a === void 0 ? void 0 : _a.XMLSerializer) === null || _b === void 0 ? void 0 : _b.constructor()) === null || _c === void 0 ? void 0 : _c.serializeToString(node), (_d !== null && _d !== void 0 ? _d : (_e = node) === null || _e === void 0 ? void 0 : _e.xml));\r\n if (!!serialized) {\r\n ret.push(serialized);\r\n }\r\n });\r\n return ret.join(\"\");\r\n };\r\n XMLQuery.prototype.parserErrorText = function (joinstr) {\r\n return this.querySelectorAll(\"parsererror\").textContent(joinstr);\r\n };\r\n XMLQuery.parseXML = function (txt) {\r\n return new XMLQuery(txt);\r\n };\r\n XMLQuery.parseHTML = function (txt) {\r\n return new XMLQuery(txt, \"text/html\");\r\n };\r\n XMLQuery.fromString = function (txt, parseType) {\r\n if (parseType === void 0) { parseType = \"text/xml\"; }\r\n return new XMLQuery(txt, parseType);\r\n };\r\n return XMLQuery;\r\n}(DomQuery_1.DomQuery));\r\nexports.XMLQuery = XMLQuery;\r\nexports.XQ = XMLQuery;\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbWFpbi90eXBlc2NyaXB0L2V4dC9tb25hZGlzaC9YbWxRdWVyeS50cy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9tYWluL3R5cGVzY3JpcHQvZXh0L21vbmFkaXNoL1htbFF1ZXJ5LnRzPzY0NGQiXSwic291cmNlc0NvbnRlbnQiOlsiLyogTGljZW5zZWQgdG8gdGhlIEFwYWNoZSBTb2Z0d2FyZSBGb3VuZGF0aW9uIChBU0YpIHVuZGVyIG9uZSBvciBtb3JlXHJcbiAqIGNvbnRyaWJ1dG9yIGxpY2Vuc2UgYWdyZWVtZW50cy4gIFNlZSB0aGUgTk9USUNFIGZpbGUgZGlzdHJpYnV0ZWQgd2l0aFxyXG4gKiB0aGlzIHdvcmsgZm9yIGFkZGl0aW9uYWwgaW5mb3JtYXRpb24gcmVnYXJkaW5nIGNvcHlyaWdodCBvd25lcnNoaXAuXHJcbiAqIFRoZSBBU0YgbGljZW5zZXMgdGhpcyBmaWxlIHRvIHlvdSB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wXHJcbiAqICh0aGUgXCJMaWNlbnNlXCIpOyB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGhcclxuICogdGhlIExpY2Vuc2UuICBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2YgdGhlIExpY2Vuc2UgYXRcclxuICpcclxuICogICAgICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcclxuICpcclxuICogVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxyXG4gKiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgQkFTSVMsXHJcbiAqIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxyXG4gKiBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kXHJcbiAqIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxyXG4gKi9cclxuXHJcbmltcG9ydCB7TGFuZ30gZnJvbSBcIi4vTGFuZ1wiO1xyXG5pbXBvcnQge0RvbVF1ZXJ5fSBmcm9tIFwiLi9Eb21RdWVyeVwiO1xyXG5pbXBvcnQgaXNTdHJpbmcgPSBMYW5nLmlzU3RyaW5nO1xyXG5cclxuZGVjbGFyZSBsZXQgQWN0aXZlWE9iamVjdDogYW55O1xyXG5cclxuLyoqXHJcbiAqIHhtbCBxdWVyeSBhcyBzcGVjaWFsaXplZCBjYXNlIGZvciBEb21RdWVyeVxyXG4gKi9cclxuZXhwb3J0IGNsYXNzIFhNTFF1ZXJ5IGV4dGVuZHMgRG9tUXVlcnkge1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKHJvb3ROb2RlOiBEb2N1bWVudCB8IHN0cmluZyB8IERvbVF1ZXJ5LCBkb2NUeXBlOiBTdXBwb3J0ZWRUeXBlID0gXCJ0ZXh0L3htbFwiKSB7XHJcblxyXG5cclxuICAgICAgICBsZXQgY3JlYXRlSWUxMURvbVF1ZXJ5U2hpbSA9ICgpOiBET01QYXJzZXIgPT4ge1xyXG4gICAgICAgICAgICAvL2F0IHRoZSB0aW1lIGlmIHdyb3RpbmcgaWUxMSBpcyB0aGUgb25seSByZWxldmFudCBicm93c2VyXHJcbiAgICAgICAgICAgIC8vbGVmdCB3aXRodXQgYW55IERvbVF1ZXJ5IHN1cHBvcnRcclxuICAgICAgICAgICAgbGV0IHBhcnNlciA9IG5ldyBBY3RpdmVYT2JqZWN0KFwiTWljcm9zb2Z0LlhNTERPTVwiKTtcclxuICAgICAgICAgICAgcGFyc2VyLmFzeW5jID0gZmFsc2U7XHJcbiAgICAgICAgICAgIC8vd2Ugc2hpbSB0aCBkb20gcGFyc2VyIGZyb20gaWUgaW5cclxuICAgICAgICAgICAgcmV0dXJuIDxhbnk+IHtcclxuICAgICAgICAgICAgICAgIHBhcnNlRnJvbVN0cmluZzogKHRleHQ6IHN0cmluZywgY29udGVudFR5cGU6IHN0cmluZyk6IERvY3VtZW50ID0+IHtcclxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gcGFyc2VyLmxvYWRYTUwodGV4dCk7XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9O1xyXG5cclxuICAgICAgICBsZXQgcGFyc2VYTUwgPSAoeG1sOiBzdHJpbmcpOiBEb2N1bWVudCA9PiB7XHJcbiAgICAgICAgICAgIGlmKHhtbCA9PSBudWxsKSB7XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gbnVsbDtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICBsZXQgZG9tUGFyc2VyOiBET01QYXJzZXIgPSBMYW5nLnNhdmVSZXNvbHZlTGF6eTxET01QYXJzZXI+KFxyXG4gICAgICAgICAgICAgICAgKCkgPT4gbmV3IHdpbmRvdy5ET01QYXJzZXIoKSxcclxuICAgICAgICAgICAgICAgICgpOiBET01QYXJzZXIgPT4gIGNyZWF0ZUllMTFEb21RdWVyeVNoaW0oKVxyXG4gICAgICAgICAgICApLnZhbHVlO1xyXG4gICAgICAgICAgICByZXR1cm4gZG9tUGFyc2VyLnBhcnNlRnJvbVN0cmluZyh4bWwsIGRvY1R5cGUpO1xyXG4gICAgICAgIH07XHJcblxyXG4gICAgICAgIGlmKGlzU3RyaW5nKHJvb3ROb2RlKSkge1xyXG4gICAgICAgICAgICBzdXBlcihwYXJzZVhNTCg8c3RyaW5nPnJvb3ROb2RlKSlcclxuICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgICBzdXBlcihyb290Tm9kZSk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuXHJcbiAgICBpc1hNTFBhcnNlckVycm9yKCk6IGJvb2xlYW4ge1xyXG4gICAgICAgIHJldHVybiB0aGlzLnF1ZXJ5U2VsZWN0b3JBbGwoXCJwYXJzZXJlcnJvclwiKS5pc1ByZXNlbnQoKTtcclxuICAgIH1cclxuXHJcblxyXG5cclxuICAgIHRvU3RyaW5nKCk6IHN0cmluZyB7XHJcbiAgICAgICAgbGV0IHJldCA9IFtdO1xyXG4gICAgICAgIHRoaXMuZWFjaEVsZW0oKG5vZGU6IGFueSkgPT4ge1xyXG4gICAgICAgICAgICBsZXQgc2VyaWFsaXplZCA9ICg8YW55PndpbmRvdyk/LlhNTFNlcmlhbGl6ZXI/LmNvbnN0cnVjdG9yKCk/LnNlcmlhbGl6ZVRvU3RyaW5nKG5vZGUpID8/IG5vZGU/LnhtbDtcclxuICAgICAgICAgICAgaWYoISFzZXJpYWxpemVkKSB7XHJcbiAgICAgICAgICAgICAgICByZXQucHVzaChzZXJpYWxpemVkKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH0pO1xyXG4gICAgICAgIHJldHVybiByZXQuam9pbihcIlwiKTtcclxuICAgIH1cclxuXHJcblxyXG4gICAgcGFyc2VyRXJyb3JUZXh0KGpvaW5zdHI6IHN0cmluZyk6IHN0cmluZyB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMucXVlcnlTZWxlY3RvckFsbChcInBhcnNlcmVycm9yXCIpLnRleHRDb250ZW50KGpvaW5zdHIpO1xyXG4gICAgfVxyXG5cclxuICAgIHN0YXRpYyBwYXJzZVhNTCh0eHQ6IHN0cmluZyk6IFhNTFF1ZXJ5IHtcclxuICAgICAgICByZXR1cm4gbmV3ICBYTUxRdWVyeSh0eHQpO1xyXG4gICAgfVxyXG4gICAgc3RhdGljIHBhcnNlSFRNTCh0eHQ6IHN0cmluZyk6IFhNTFF1ZXJ5IHtcclxuICAgICAgICByZXR1cm4gbmV3ICBYTUxRdWVyeSh0eHQsIFwidGV4dC9odG1sXCIpO1xyXG4gICAgfVxyXG5cclxuICAgIHN0YXRpYyBmcm9tU3RyaW5nKHR4dDogc3RyaW5nLCBwYXJzZVR5cGU6IFN1cHBvcnRlZFR5cGUgPSBcInRleHQveG1sXCIpOiBYTUxRdWVyeSB7XHJcbiAgICAgICAgcmV0dXJuIG5ldyAgWE1MUXVlcnkodHh0LHBhcnNlVHlwZSk7XHJcbiAgICB9XHJcbn1cclxuXHJcbmV4cG9ydCBjb25zdCBYUSA9IFhNTFF1ZXJ5O1xyXG5leHBvcnQgdHlwZSBYUSA9IFhNTFF1ZXJ5OyJdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7Ozs7OztBQWNBOzs7Ozs7Ozs7Ozs7Ozs7QUFFQTtBQUNBO0FBQ0E7QUFJQTs7QUFFQTtBQUNBO0FBQUE7QUFFQTtBQUFBO0FBQUE7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBSUE7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUFBO0FBQ0E7QUFDQTs7QUFDQTtBQUdBO0FBQ0E7QUFDQTtBQUlBO0FBQ0E7QUFDQTs7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUdBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQXJFQTtBQXVFQTsiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/main/typescript/ext/monadish/XmlQuery.ts\n");
/***/ }),
/***/ "./src/main/typescript/ext/monadish/index.ts":
/*!***************************************************!*\
!*** ./src/main/typescript/ext/monadish/index.ts ***!
\***************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar DomQuery_1 = __webpack_require__(/*! ./DomQuery */ \"./src/main/typescript/ext/monadish/DomQuery.ts\");\r\nexports.DomQuery = DomQuery_1.DomQuery;\r\nexports.ElementAttribute = DomQuery_1.ElementAttribute;\r\nexports.DomQueryCollector = DomQuery_1.DomQueryCollector;\r\nexports.DQ = DomQuery_1.DQ;\r\nvar Lang_1 = __webpack_require__(/*! ./Lang */ \"./src/main/typescript/ext/monadish/Lang.ts\");\r\nexports.Lang = Lang_1.Lang;\r\nvar Monad_1 = __webpack_require__(/*! ./Monad */ \"./src/main/typescript/ext/monadish/Monad.ts\");\r\nexports.Config = Monad_1.Config;\r\nexports.Monad = Monad_1.Monad;\r\nexports.Optional = Monad_1.Optional;\r\nexports.ValueEmbedder = Monad_1.ValueEmbedder;\r\nvar Promise_1 = __webpack_require__(/*! ./Promise */ \"./src/main/typescript/ext/monadish/Promise.ts\");\r\nexports.CancellablePromise = Promise_1.CancellablePromise;\r\nexports.Promise = Promise_1.Promise;\r\nexports.PromiseStatus = Promise_1.PromiseStatus;\r\nvar XmlQuery_1 = __webpack_require__(/*! ./XmlQuery */ \"./src/main/typescript/ext/monadish/XmlQuery.ts\");\r\nexports.XMLQuery = XmlQuery_1.XMLQuery;\r\nexports.XQ = XmlQuery_1.XQ;\r\nvar Stream_1 = __webpack_require__(/*! ./Stream */ \"./src/main/typescript/ext/monadish/Stream.ts\");\r\nexports.Stream = Stream_1.Stream;\r\nexports.LazyStream = Stream_1.LazyStream;\r\nvar SourcesCollectors_1 = __webpack_require__(/*! ./SourcesCollectors */ \"./src/main/typescript/ext/monadish/SourcesCollectors.ts\");\r\nexports.ArrayStreamDataSource = SourcesCollectors_1.ArrayStreamDataSource;\r\nexports.MappedStreamDataSource = SourcesCollectors_1.MappedStreamDataSource;\r\nexports.FilteredStreamDatasource = SourcesCollectors_1.FilteredStreamDatasource;\r\nexports.FlatMapStreamDataSource = SourcesCollectors_1.FlatMapStreamDataSource;\r\nexports.QueryFormStringCollector = SourcesCollectors_1.QueryFormStringCollector;\r\nexports.ArrayCollector = SourcesCollectors_1.ArrayCollector;\r\nexports.AssocArrayCollector = SourcesCollectors_1.AssocArrayCollector;\r\nexports.FormDataCollector = SourcesCollectors_1.FormDataCollector;\r\nexports.QueryFormDataCollector = SourcesCollectors_1.QueryFormDataCollector;\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbWFpbi90eXBlc2NyaXB0L2V4dC9tb25hZGlzaC9pbmRleC50cy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9tYWluL3R5cGVzY3JpcHQvZXh0L21vbmFkaXNoL2luZGV4LnRzP2E2MjYiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHtEb21RdWVyeSwgRWxlbWVudEF0dHJpYnV0ZSwgRG9tUXVlcnlDb2xsZWN0b3IsIERRfSBmcm9tIFwiLi9Eb21RdWVyeVwiO1xyXG5leHBvcnQge0xhbmd9IGZyb20gXCIuL0xhbmdcIjtcclxuZXhwb3J0IHtDb25maWcsIE1vbmFkLCBJVmFsdWVIb2xkZXIsIElGdW5jdG9yLCBJTW9uYWQsIElJZGVudGl0eSwgT3B0aW9uYWwsIFZhbHVlRW1iZWRkZXJ9IGZyb20gXCIuL01vbmFkXCI7XHJcbmV4cG9ydCB7Q2FuY2VsbGFibGVQcm9taXNlLCBQcm9taXNlLCBJUHJvbWlzZSwgUHJvbWlzZVN0YXR1c30gZnJvbSBcIi4vUHJvbWlzZVwiO1xyXG5leHBvcnQge1hNTFF1ZXJ5LCBYUX0gZnJvbSBcIi4vWG1sUXVlcnlcIjtcclxuZXhwb3J0IHtTdHJlYW0sIExhenlTdHJlYW0sIEl0ZXJhdGFibGVDb25zdW1lciwgSVN0cmVhbX0gZnJvbSBcIi4vU3RyZWFtXCI7XHJcbmV4cG9ydCB7XHJcbiAgICBBcnJheVN0cmVhbURhdGFTb3VyY2UsXHJcbiAgICBNYXBwZWRTdHJlYW1EYXRhU291cmNlLFxyXG4gICAgRmlsdGVyZWRTdHJlYW1EYXRhc291cmNlLFxyXG4gICAgRmxhdE1hcFN0cmVhbURhdGFTb3VyY2UsXHJcbiAgICBRdWVyeUZvcm1TdHJpbmdDb2xsZWN0b3IsXHJcbiAgICBJU3RyZWFtRGF0YVNvdXJjZSxcclxuICAgIElDb2xsZWN0b3IsXHJcbiAgICBBcnJheUNvbGxlY3RvcixcclxuICAgIEFzc29jQXJyYXlDb2xsZWN0b3IsXHJcbiAgICBGb3JtRGF0YUNvbGxlY3RvcixcclxuICAgIFF1ZXJ5Rm9ybURhdGFDb2xsZWN0b3JcclxufSBmcm9tIFwiLi9Tb3VyY2VzQ29sbGVjdG9yc1wiO1xyXG5cclxuXHJcbiJdLCJtYXBwaW5ncyI6Ijs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQ0E7QUFBQTtBQUNBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFDQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQUE7QUFBQTtBQUNBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUdBO0FBQ0E7QUFDQTtBQUNBOyIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/main/typescript/ext/monadish/index.ts\n");
/***/ }),
/***/ "./src/main/typescript/impl/AjaxImpl.ts":
/*!**********************************************!*\
!*** ./src/main/typescript/impl/AjaxImpl.ts ***!
\**********************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar myfacesConfig = __webpack_require__(/*! ../api/myfaces */ \"./src/main/typescript/api/myfaces.ts\");\r\nvar Response_1 = __webpack_require__(/*! ./xhrCore/Response */ \"./src/main/typescript/impl/xhrCore/Response.ts\");\r\nvar XhrRequest_1 = __webpack_require__(/*! ./xhrCore/XhrRequest */ \"./src/main/typescript/impl/xhrCore/XhrRequest.ts\");\r\nvar AsyncQueue_1 = __webpack_require__(/*! ./util/AsyncQueue */ \"./src/main/typescript/impl/util/AsyncQueue.ts\");\r\nvar Monad_1 = __webpack_require__(/*! ../ext/monadish/Monad */ \"./src/main/typescript/ext/monadish/Monad.ts\");\r\nvar Const_1 = __webpack_require__(/*! ./core/Const */ \"./src/main/typescript/impl/core/Const.ts\");\r\nvar Assertions_1 = __webpack_require__(/*! ./util/Assertions */ \"./src/main/typescript/impl/util/Assertions.ts\");\r\nvar XhrFormData_1 = __webpack_require__(/*! ./xhrCore/XhrFormData */ \"./src/main/typescript/impl/xhrCore/XhrFormData.ts\");\r\nvar ExtDomQuery_1 = __webpack_require__(/*! ./util/ExtDomQuery */ \"./src/main/typescript/impl/util/ExtDomQuery.ts\");\r\nvar ErrorData_1 = __webpack_require__(/*! ./xhrCore/ErrorData */ \"./src/main/typescript/impl/xhrCore/ErrorData.ts\");\r\nvar DomQuery_1 = __webpack_require__(/*! ../ext/monadish/DomQuery */ \"./src/main/typescript/ext/monadish/DomQuery.ts\");\r\nvar monadish_1 = __webpack_require__(/*! ../ext/monadish */ \"./src/main/typescript/ext/monadish/index.ts\");\r\nvar SourcesCollectors_1 = __webpack_require__(/*! ../ext/monadish/SourcesCollectors */ \"./src/main/typescript/ext/monadish/SourcesCollectors.ts\");\r\nvar Lang_1 = __webpack_require__(/*! ./util/Lang */ \"./src/main/typescript/impl/util/Lang.ts\");\r\n/*\r\n * allowed project stages\r\n */\r\nvar ProjectStages;\r\n(function (ProjectStages) {\r\n ProjectStages[\"Production\"] = \"Production\";\r\n ProjectStages[\"Development\"] = \"Development\";\r\n ProjectStages[\"SystemTest\"] = \"SystemTest\";\r\n ProjectStages[\"UnitTest\"] = \"UnitTest\";\r\n})(ProjectStages || (ProjectStages = {}));\r\n/*\r\n * blockfilter for the passthrough filtering; the attributes given here\r\n * will not be transmitted from the options into the passthrough\r\n */\r\nvar BlockFilter;\r\n(function (BlockFilter) {\r\n BlockFilter[\"onerror\"] = \"onerror\";\r\n BlockFilter[\"onevent\"] = \"onevent\";\r\n BlockFilter[\"render\"] = \"render\";\r\n BlockFilter[\"execute\"] = \"execute\";\r\n BlockFilter[\"myfaces\"] = \"myfaces\";\r\n BlockFilter[\"delay\"] = \"delay\";\r\n BlockFilter[\"timeout\"] = \"timeout\";\r\n BlockFilter[\"windowId\"] = \"windowId\";\r\n})(BlockFilter || (BlockFilter = {}));\r\n/**\r\n * Core Implementation\r\n * to distinct between api and impl\r\n *\r\n * The original idea was to make the implementation pluggable\r\n * but this is pointless, you always can overwrite the thin api layer\r\n * however a dedicated api makes sense for readability reasons\r\n */\r\nvar Implementation;\r\n(function (Implementation) {\r\n var trim = monadish_1.Lang.trim;\r\n var getMessage = Lang_1.ExtLang.getMessage;\r\n var getForm = Lang_1.ExtLang.getForm;\r\n var getLocalOrGlobalConfig = Lang_1.ExtLang.getLocalOrGlobalConfig;\r\n var getEvent = Lang_1.ExtLang.getEvent;\r\n var getGlobalConfig = Lang_1.ExtLang.getGlobalConfig;\r\n var assert = Assertions_1.Assertions.assert;\r\n var CTX_PARAM_PASS_THR = Const_1.Const.CTX_PARAM_PASS_THR;\r\n var P_EVT = Const_1.Const.P_EVT;\r\n var SOURCE = Const_1.Const.SOURCE;\r\n var ON_EVENT = Const_1.Const.ON_EVENT;\r\n var ON_ERROR = Const_1.Const.ON_ERROR;\r\n var MYFACES = Const_1.Const.MYFACES;\r\n var MF_NONE = Const_1.Const.MF_NONE;\r\n var P_PARTIAL_SOURCE = Const_1.Const.P_PARTIAL_SOURCE;\r\n var P_AJAX = Const_1.Const.P_AJAX;\r\n var P_RESET_VALUES = Const_1.Const.P_RESET_VALUES;\r\n var CTX_PARAM_SRC_FRM_ID = Const_1.Const.CTX_PARAM_SRC_FRM_ID;\r\n var CTX_PARAM_SRC_CTL_ID = Const_1.Const.CTX_PARAM_SRC_CTL_ID;\r\n var CTX_PARAM_TR_TYPE = Const_1.Const.CTX_PARAM_TR_TYPE;\r\n var REQ_TYPE_POST = Const_1.Const.REQ_TYPE_POST;\r\n var P_WIN_ID = Const_1.Const.P_WIN_ID;\r\n var CTX_PARAM_EXECUTE = Const_1.Const.CTX_PARAM_EXECUTE;\r\n var P_EXECUTE = Const_1.Const.P_EXECUTE;\r\n var P_WINDOW_ID = Const_1.Const.P_WINDOW_ID;\r\n var P_RENDER = Const_1.Const.P_RENDER;\r\n var IDENT_ALL = Const_1.Const.IDENT_ALL;\r\n var IDENT_NONE = Const_1.Const.IDENT_NONE;\r\n var IDENT_FORM = Const_1.Const.IDENT_FORM;\r\n var IDENT_THIS = Const_1.Const.IDENT_THIS;\r\n var P_CLIENTWINDOW = Const_1.Const.P_CLIENTWINDOW;\r\n var CTX_PARAM_TIMEOUT = Const_1.Const.CTX_PARAM_TIMEOUT;\r\n var CTX_PARAM_DELAY = Const_1.Const.CTX_PARAM_DELAY;\r\n var globalConfig = myfacesConfig.myfaces.config;\r\n var projectStage = null;\r\n var separator = null;\r\n var eventQueue = [];\r\n var errorQueue = [];\r\n var requestQueue = null;\r\n /*error reporting threshold*/\r\n var threshold = \"ERROR\";\r\n //we need to proxy this in the tests\r\n Implementation.queueHandler = {\r\n /**\r\n * public to make it shimmable for tests\r\n */\r\n addRequestToQueue: function (elem, form, reqCtx, respPassThr, delay, timeout) {\r\n if (delay === void 0) { delay = 0; }\r\n if (timeout === void 0) { timeout = 0; }\r\n requestQueue = (requestQueue !== null && requestQueue !== void 0 ? requestQueue : new AsyncQueue_1.AsynchronouseQueue());\r\n requestQueue.enqueue(new XhrRequest_1.XhrRequest(elem, form, reqCtx, respPassThr, [], timeout), delay);\r\n }\r\n };\r\n /**\r\n * fetches the separator char from the given script tags\r\n *\r\n * @return {char} the separator char for the given script tags\r\n */\r\n function getSeparatorChar() {\r\n var _a, _b, _c, _d, _e;\r\n return _e = (_c = (_b = (_a = this) === null || _a === void 0 ? void 0 : _a.globalConfig) === null || _b === void 0 ? void 0 : _b.separator, (_c !== null && _c !== void 0 ? _c : (_d = this) === null || _d === void 0 ? void 0 : _d.separator)), (_e !== null && _e !== void 0 ? _e : (separator = ExtDomQuery_1.ExtDomquery.searchJsfJsFor(/separator=([^&;]*)/).orElse(\":\").value));\r\n }\r\n Implementation.getSeparatorChar = getSeparatorChar;\r\n //for testing only\r\n function reset() {\r\n globalConfig = myfacesConfig.myfaces.config;\r\n projectStage = null;\r\n separator = null;\r\n eventQueue = [];\r\n errorQueue = [];\r\n requestQueue = null;\r\n }\r\n Implementation.reset = reset;\r\n /**\r\n * @return the project stage also emitted by the server:\r\n * it cannot be cached and must be delivered over the server\r\n * The value for it comes from the requestInternal parameter of the jsf.js script called \"stage\".\r\n */\r\n function getProjectStage() {\r\n var _a, _b, _c, _d, _e;\r\n return _e = (_c = (_b = (_a = this) === null || _a === void 0 ? void 0 : _a.globalConfig) === null || _b === void 0 ? void 0 : _b.projectStage, (_c !== null && _c !== void 0 ? _c : (_d = this) === null || _d === void 0 ? void 0 : _d.projectStage)), (_e !== null && _e !== void 0 ? _e : (projectStage = resolveProjectStateFromURL()));\r\n }\r\n Implementation.getProjectStage = getProjectStage;\r\n function resolveProjectStateFromURL() {\r\n /* run through all script tags and try to find the one that includes jsf.js */\r\n var foundStage = ExtDomQuery_1.ExtDomquery.searchJsfJsFor(/stage=([^&;]*)/).value;\r\n return (foundStage in ProjectStages) ? foundStage : null;\r\n }\r\n Implementation.resolveProjectStateFromURL = resolveProjectStateFromURL;\r\n function chain(source, event) {\r\n var funcs = [];\r\n for (var _i = 2; _i < arguments.length; _i++) {\r\n funcs[_i - 2] = arguments[_i];\r\n }\r\n var ret = true;\r\n var resolveAndExecute = function (func) {\r\n if (\"string\" != typeof func) {\r\n return (ret = ret && (func.call(source, event) !== false));\r\n }\r\n else {\r\n //either a function or a string can be passed in case of a string we have to wrap it into another function\r\n //it it is not a plain executable code but a definition\r\n var sourceCode = trim(func);\r\n if (sourceCode.indexOf(\"function \") == 0) {\r\n sourceCode = \"return \" + sourceCode + \" (event)\";\r\n }\r\n return (ret = ret && (new Function(\"event\", sourceCode).call(source, event) !== false));\r\n }\r\n };\r\n monadish_1.Stream.of.apply(monadish_1.Stream, funcs).each(function (func) { return resolveAndExecute(func); });\r\n return ret;\r\n }\r\n Implementation.chain = chain;\r\n /**\r\n * this function has to send the ajax requests\r\n *\r\n * following request conditions must be met:\r\n * <ul>\r\n * <li> the request must be sent asynchronously! </li>\r\n * <li> the request must be a POST!!! request </li>\r\n * <li> the request url must be the form action attribute </li>\r\n * <li> all requests must be queued with a client side request queue to ensure the request ordering!</li>\r\n * </ul>\r\n *\r\n * @param {String|Node} elem any dom element no matter being it html or jsf, from which the event is emitted\r\n * @param {|Event|} event any javascript event supported by that object\r\n * @param {|Object|} options map of options being pushed into the ajax cycle\r\n *\r\n *\r\n * a) transformArguments out of the function\r\n * b) passThrough handling with a map copy with a filter map block map\r\n */\r\n function request(el, event, opts) {\r\n var _a, _b, _c, _d, _e, _f, _g, _h;\r\n /*\r\n *namespace remap for our local function context we mix the entire function namespace into\r\n *a local function variable so that we do not have to write the entire namespace\r\n *all the time\r\n */\r\n event = getEvent(event);\r\n //options not set we define a default one with nothing\r\n var options = new Monad_1.Config(opts).deepCopy;\r\n var elem = DomQuery_1.DQ.byId(el || event.target);\r\n var elementId = elem.id;\r\n var requestCtx = new Monad_1.Config({});\r\n var internalCtx = new Monad_1.Config({});\r\n Assertions_1.Assertions.assertRequestIntegrity(options, elem);\r\n applyWindowId(options);\r\n requestCtx.assign(CTX_PARAM_PASS_THR).value = fetchPassthroughValues(options.value);\r\n requestCtx.assignIf(!!event, CTX_PARAM_PASS_THR, P_EVT).value = (_a = event) === null || _a === void 0 ? void 0 : _a.type;\r\n /**\r\n * ajax pass through context with the source\r\n * onevent and onerror\r\n */\r\n requestCtx.assign(SOURCE).value = elementId.value;\r\n /**\r\n * on event and onError...\r\n * those values will be traversed later on\r\n * also into the response context\r\n */\r\n requestCtx.assign(ON_EVENT).value = (_b = options.value) === null || _b === void 0 ? void 0 : _b.onevent;\r\n requestCtx.assign(ON_ERROR).value = (_c = options.value) === null || _c === void 0 ? void 0 : _c.onerror;\r\n /**\r\n * lets drag the myfaces config params also in\r\n */\r\n requestCtx.assign(MYFACES).value = (_d = options.value) === null || _d === void 0 ? void 0 : _d.myfaces;\r\n /**\r\n * fetch the parent form\r\n *\r\n * note we also add an override possibility here\r\n * so that people can use dummy forms and work\r\n * with detached objects\r\n */\r\n var configId = (_g = (_f = (_e = requestCtx.value) === null || _e === void 0 ? void 0 : _e.myfaces) === null || _f === void 0 ? void 0 : _f.form, (_g !== null && _g !== void 0 ? _g : MF_NONE));\r\n var form = resolveForm(requestCtx, elem, event);\r\n /**\r\n * binding contract the javax.faces.source must be set\r\n */\r\n requestCtx.assign(CTX_PARAM_PASS_THR, P_PARTIAL_SOURCE).value = elementId.value;\r\n /**\r\n * javax.faces.partial.ajax must be set to true\r\n */\r\n requestCtx.assign(CTX_PARAM_PASS_THR, P_AJAX).value = true;\r\n /**\r\n * binding contract the javax.faces.source must be set\r\n */\r\n requestCtx.assign(CTX_PARAM_PASS_THR, P_PARTIAL_SOURCE).value = elementId.value;\r\n /**\r\n * if resetValues is set to true\r\n * then we have to set javax.faces.resetValues as well\r\n * as pass through parameter\r\n * the value has to be explicitly true, according to\r\n * the specs jsdoc\r\n */\r\n requestCtx.assignIf(true === ((_h = options.value) === null || _h === void 0 ? void 0 : _h.resetValues), CTX_PARAM_PASS_THR, P_RESET_VALUES).value = true;\r\n //additional meta information to speed things up, note internal non jsf\r\n //pass through options are stored under _mfInternal in the context\r\n internalCtx.assign(CTX_PARAM_SRC_FRM_ID).value = form.id.value;\r\n internalCtx.assign(CTX_PARAM_SRC_CTL_ID).value = elementId.value;\r\n internalCtx.assign(CTX_PARAM_TR_TYPE).value = REQ_TYPE_POST;\r\n //mojarra compatibility, mojarra is sending the form id as well\r\n //this is not documented behavior but can be determined by running\r\n //mojarra under blackbox conditions\r\n //i assume it does the same as our formId_submit=1 so leaving it out\r\n //wont hurt but for the sake of compatibility we are going to add it\r\n requestCtx.assign(CTX_PARAM_PASS_THR, form.id.value).value = form.id.value;\r\n applyClientWindowId(form, requestCtx);\r\n applyExecute(options, requestCtx, form, elementId.value);\r\n applyRender(options, requestCtx, form, elementId.value);\r\n var delay = resolveDelay(options, requestCtx);\r\n var timeout = resolveTimeout(options, requestCtx);\r\n //now we enqueue the request as asynchronous runnable into our request\r\n //queue and let the queue take over the rest\r\n Implementation.queueHandler.addRequestToQueue(elem, form, requestCtx, internalCtx, delay, timeout);\r\n }\r\n Implementation.request = request;\r\n /**\r\n * Spec. 13.3.3\r\n * Examining the response markup and updating the DOM tree\r\n * @param {XMLHttpRequest} request - the ajax request\r\n * @param {Object} context - the ajax context\r\n */\r\n function response(request, context) {\r\n Response_1.Response.processResponse(request, context);\r\n }\r\n Implementation.response = response;\r\n function addOnError(errorListener) {\r\n /*error handling already done in the assert of the queue*/\r\n errorQueue.push(errorListener);\r\n }\r\n Implementation.addOnError = addOnError;\r\n function addOnEvent(eventListener) {\r\n /*error handling already done in the assert of the queue*/\r\n eventQueue.push(eventListener);\r\n }\r\n Implementation.addOnEvent = addOnEvent;\r\n /**\r\n * sends an event\r\n */\r\n function sendEvent(data, localHandler) {\r\n if (localHandler === void 0) { localHandler = function (data) { }; }\r\n /*now we serve the queue as well*/\r\n localHandler(data);\r\n eventQueue.forEach(function (fn) { return fn(data); });\r\n }\r\n Implementation.sendEvent = sendEvent;\r\n function registerPromise() {\r\n var _a, _b;\r\n window[\"Promise\"] = (_b = (_a = window) === null || _a === void 0 ? void 0 : _a.Promise, (_b !== null && _b !== void 0 ? _b : monadish_1.Promise));\r\n }\r\n Implementation.registerPromise = registerPromise;\r\n /**\r\n * error handler behavior called internally\r\n * and only into the impl it takes care of the\r\n * internal message transformation to a myfaces internal error\r\n * and then uses the standard send error mechanisms\r\n * also a double error logging prevention is done as well\r\n *\r\n * @param request the request currently being processed\r\n * @param context the context affected by this error\r\n * @param exception the exception being thrown\r\n * @param clearRequestQueue if set to true, clears the request queue of all pending requests\r\n */\r\n function stdErrorHandler(request, context, exception, clearRequestQueue) {\r\n if (clearRequestQueue === void 0) { clearRequestQueue = false; }\r\n //newer browsers do not allow to hold additional values on native objects like exceptions\r\n //we hence capsule it into the request, which is gced automatically\r\n //on ie as well, since the stdErrorHandler usually is called between requests\r\n //this is a valid approach\r\n try {\r\n if (threshold == \"ERROR\") {\r\n var errorData = ErrorData_1.ErrorData.fromClient(exception);\r\n sendError(errorData);\r\n }\r\n }\r\n finally {\r\n if (clearRequestQueue) {\r\n requestQueue.cleanup();\r\n }\r\n }\r\n }\r\n Implementation.stdErrorHandler = stdErrorHandler;\r\n /**\r\n * implementation triggering the error chain\r\n *\r\n * @param {Object} request the request object which comes from the xhr cycle\r\n * @param {Object} context (Map) the context object being pushed over the xhr cycle keeping additional metadata\r\n * @param {String} errorName the error name\r\n * @param {String} errorMessage the error name\r\n * @param {String} responseCode response Code\r\n * @param {String} responseMessage response Message\r\n *\r\n * @param {String} serverErrorName the server error name in case of a server error\r\n * @param {String} serverErrorMessage the server error message in case of a server error\r\n * @param {String} caller optional caller reference for extended error messages\r\n * @param {String} callFunc optional caller Function reference for extended error messages\r\n *\r\n * handles the errors, in case of an onError exists within the context the onError is called as local error handler\r\n * the registered error handlers in the queue receiv an error message to be dealt with\r\n * and if the projectStage is at development an alert box is displayed\r\n *\r\n * note: we have additional functionality here, via the global config myfaces.config.defaultErrorOutput a function can be provided\r\n * which changes the default output behavior from alert to something else\r\n *\r\n *\r\n */\r\n function sendError(errorData, localHandler) {\r\n if (localHandler === void 0) { localHandler = function (data) { }; }\r\n localHandler(errorData);\r\n errorQueue.forEach(function (errorCallback) {\r\n errorCallback(errorData);\r\n });\r\n var displayError = getGlobalConfig(\"defaultErrorOutput\", (console ? console.error : alert));\r\n displayError(errorData);\r\n }\r\n Implementation.sendError = sendError;\r\n /**\r\n * @return the client window id of the current window, if one is given\r\n */\r\n function getClientWindow(node) {\r\n var _a;\r\n var ALTERED = \"___mf_id_altered__\";\r\n var INIT = \"___init____\";\r\n /**\r\n * the search root for the dom element search\r\n */\r\n var searchRoot = new DomQuery_1.DQ(node || document.body);\r\n /**\r\n * a set of input elements holding the window id over the entire document\r\n */\r\n var windowIdHolders = searchRoot.querySelectorAll(\"form #\" + P_WIN_ID);\r\n /**\r\n * lazy helper to fetch the window id from the window url\r\n */\r\n var fetchWindowIdFromUrl = function () { return ExtDomQuery_1.ExtDomquery.searchJsfJsFor(/jfwid=([^&;]*)/).orElse(null).value; };\r\n /**\r\n * functional double check based on stream reduction\r\n * the values should be identical or on INIT value which is a premise to\r\n * skip the first check\r\n *\r\n * @param value1\r\n * @param value2\r\n */\r\n var doubleCheck = function (value1, value2) {\r\n if (value1 == ALTERED) {\r\n return value1;\r\n }\r\n else if (value1 == INIT) {\r\n return value2;\r\n }\r\n else if (value1 != value2) {\r\n return ALTERED;\r\n }\r\n return value2;\r\n };\r\n /**\r\n * helper for cleaner code, maps the value from an item\r\n *\r\n * @param item\r\n */\r\n var getValue = function (item) { return item.attr(\"value\").value; };\r\n /**\r\n * fetch the window id from the forms\r\n * window ids must be present in all forms\r\n * or non existent. If they exist all of them must be the same\r\n */\r\n var formWindowId = searchRoot.stream.map(getValue).reduce(doubleCheck, INIT);\r\n //if the resulting window id is set on altered then we have an unresolvable problem\r\n assert(formWindowId.value != ALTERED, \"Multiple different windowIds found in document\");\r\n /**\r\n * return the window id or null\r\n * prio, forms under node/document and if not given then from the url\r\n */\r\n return _a = formWindowId.value, (_a !== null && _a !== void 0 ? _a : fetchWindowIdFromUrl());\r\n }\r\n Implementation.getClientWindow = getClientWindow;\r\n /**\r\n * collect and encode data for a given form element (must be of type form)\r\n * find the javax.faces.ViewState element and encode its value as well!\r\n * return a concatenated string of the encoded values!\r\n *\r\n * @throws Error in case of the given element not being of type form!\r\n * https://issues.apache.org/jira/browse/MYFACES-2110\r\n */\r\n function getViewState(form) {\r\n /**\r\n * typecheck assert!, we opt for strong typing here\r\n * because it makes it easier to detect bugs\r\n */\r\n var element = DomQuery_1.DQ.byId(form);\r\n if (!element.isTag(\"form\")) {\r\n throw new Error(getMessage(\"ERR_VIEWSTATE\"));\r\n }\r\n var formData = new XhrFormData_1.XhrFormData(element);\r\n return formData.toString();\r\n }\r\n Implementation.getViewState = getViewState;\r\n //----------------------------------------------- Methods ---------------------------------------------------------------------\r\n function applyWindowId(options) {\r\n var _a, _b, _c;\r\n var windowId = (_c = (_b = (_a = options) === null || _a === void 0 ? void 0 : _a.value) === null || _b === void 0 ? void 0 : _b.windowId, (_c !== null && _c !== void 0 ? _c : ExtDomQuery_1.ExtDomquery.windowId));\r\n options.assignIf(!!windowId, P_WINDOW_ID).value = windowId;\r\n options.delete(\"windowId\");\r\n }\r\n function applyRender(options, ctx, form, elementId) {\r\n if (options.getIf(\"render\").isPresent()) {\r\n transformValues(ctx.getIf(CTX_PARAM_PASS_THR).get({}), P_RENDER, options.getIf(\"render\").value, form, elementId);\r\n }\r\n }\r\n function applyExecute(options, ctx, form, elementId) {\r\n var PARAM_EXECUTE = CTX_PARAM_EXECUTE;\r\n var PARAM_PASS_THR = CTX_PARAM_PASS_THR;\r\n if (options.getIf(PARAM_EXECUTE).isPresent()) {\r\n /*the options must be a blank delimited list of strings*/\r\n /*compliance with Mojarra which automatically adds @this to an execute\r\n * the spec rev 2.0a however states, if none is issued nothing at all should be sent down\r\n */\r\n options.assign(PARAM_EXECUTE).value = options.getIf(PARAM_EXECUTE).value + \" @this\";\r\n transformValues(ctx.getIf(PARAM_PASS_THR).get({}), P_EXECUTE, options.getIf(PARAM_EXECUTE).value, form, elementId);\r\n }\r\n else {\r\n ctx.assign(PARAM_PASS_THR, P_EXECUTE).value = elementId;\r\n }\r\n }\r\n function applyClientWindowId(form, ctx) {\r\n var clientWindow = jsf.getClientWindow(form.getAsElem(0).value);\r\n if (clientWindow) {\r\n ctx.assign(CTX_PARAM_PASS_THR, P_CLIENTWINDOW).value = clientWindow;\r\n }\r\n }\r\n /**\r\n * transforms the user values to the expected one\r\n * with the proper none all form and this handling\r\n * (note we also could use a simple string replace but then\r\n * we would have had double entries under some circumstances)\r\n *\r\n * there are several standardized constants which need a special treatment\r\n * like @all, @none, @form, @this\r\n *\r\n * @param targetConfig the target configuration receiving the final values\r\n * @param targetKey the target key\r\n * @param userValues the passed user values (aka input string which needs to be transformed)\r\n * @param issuingForm the form where the issuing element originates\r\n * @param issuingElementId the issuing element\r\n */\r\n function transformValues(targetConfig, targetKey, userValues, issuingForm, issuingElementId) {\r\n //a cleaner implementation of the transform list method\r\n var iterValues = (userValues) ? trim(userValues).split(/\\s+/gi) : [];\r\n var ret = [];\r\n var processed = {};\r\n //TODO make this code cleaner\r\n //the idea is simply to loop over all values and then replace\r\n //their generic values and filter out doubles\r\n //this is more readable than the old indexed based solution\r\n //and not really slower because we had to build up the index in our old solution\r\n //anyway\r\n for (var cnt = 0; cnt < iterValues.length; cnt++) {\r\n //avoid doubles\r\n if (iterValues[cnt] in processed) {\r\n continue;\r\n }\r\n switch (iterValues[cnt]) {\r\n //@none no values should be sent\r\n case IDENT_NONE:\r\n return targetConfig.delete(targetKey);\r\n //@all is a pass through case according to the spec\r\n case IDENT_ALL:\r\n targetConfig.assign(targetKey).value = IDENT_ALL;\r\n return targetConfig;\r\n //@form pushes the issuing form id into our list\r\n case IDENT_FORM:\r\n ret.push(issuingForm.id.value);\r\n processed[issuingForm.id.value] = true;\r\n break;\r\n //@this is replaced with the current issuing element id\r\n case IDENT_THIS:\r\n if (!(issuingElementId in processed)) {\r\n ret.push(issuingElementId);\r\n processed[issuingElementId] = true;\r\n }\r\n break;\r\n default:\r\n ret.push(iterValues[cnt]);\r\n processed[iterValues[cnt]] = true;\r\n }\r\n }\r\n //We now add the target as joined list\r\n targetConfig.assign(targetKey).value = ret.join(\" \");\r\n return targetConfig;\r\n }\r\n function fetchPassthroughValues(mappedOpts) {\r\n return monadish_1.Stream.ofAssoc(mappedOpts)\r\n .filter(function (item) { return !(item[0] in BlockFilter); })\r\n .collect(new SourcesCollectors_1.AssocArrayCollector());\r\n }\r\n function resolveForm(requestCtx, elem, event) {\r\n var _a, _b, _c;\r\n var configId = (_c = (_b = (_a = requestCtx.value) === null || _a === void 0 ? void 0 : _a.myfaces) === null || _b === void 0 ? void 0 : _b.form, (_c !== null && _c !== void 0 ? _c : MF_NONE)); //requestCtx.getIf(MYFACES, \"form\").orElse(MF_NONE).value;\r\n var form = DomQuery_1.DQ\r\n .byId(configId)\r\n .orElseLazy(function () { return getForm(elem.getAsElem(0).value, event); });\r\n return form;\r\n }\r\n function resolveTimeout(options, requestCtx) {\r\n var _a;\r\n var getCfg = getLocalOrGlobalConfig;\r\n return _a = options.getIf(CTX_PARAM_TIMEOUT).value, (_a !== null && _a !== void 0 ? _a : getCfg(requestCtx.value, CTX_PARAM_TIMEOUT, 0));\r\n }\r\n function resolveDelay(options, requestCtx) {\r\n var _a;\r\n var getCfg = getLocalOrGlobalConfig;\r\n return _a = options.getIf(CTX_PARAM_DELAY).value, (_a !== null && _a !== void 0 ? _a : getCfg(requestCtx.value, CTX_PARAM_DELAY, 0));\r\n }\r\n})(Implementation = exports.Implementation || (exports.Implementation = {}));\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/main/typescript/impl/AjaxImpl.ts.js","sources":["webpack:///./src/main/typescript/impl/AjaxImpl.ts?29d9"],"sourcesContent":["/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements.  See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License.  You may obtain a copy of the License at\r\n *\r\n *      http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\nimport * as myfacesConfig from \"../api/myfaces\";\r\n\r\nimport {IListener} from \"./util/ListenerQueue\";\r\nimport {Response} from \"./xhrCore/Response\";\r\nimport {XhrRequest} from \"./xhrCore/XhrRequest\";\r\nimport {AsynchronouseQueue} from \"./util/AsyncQueue\";\r\nimport {Config, Optional} from \"../ext/monadish/Monad\";\r\n\r\nimport {Const} from \"./core/Const\";\r\nimport {Assertions} from \"./util/Assertions\";\r\nimport {XhrFormData} from \"./xhrCore/XhrFormData\";\r\nimport {ExtDomquery} from \"./util/ExtDomQuery\";\r\nimport {ErrorData} from \"./xhrCore/ErrorData\";\r\nimport {EventData} from \"./xhrCore/EventData\";\r\nimport {DQ} from \"../ext/monadish/DomQuery\";\r\nimport {Lang, Promise, Stream} from \"../ext/monadish\";\r\nimport {AssocArrayCollector} from \"../ext/monadish/SourcesCollectors\";\r\nimport {ExtLang} from \"./util/Lang\";\r\n\r\ndeclare var jsf: any;\r\n\r\n/*\r\n * allowed project stages\r\n */\r\nenum ProjectStages {\r\n    Production = \"Production\",\r\n    Development = \"Development\",\r\n    SystemTest = \"SystemTest\",\r\n    UnitTest = \"UnitTest\"\r\n}\r\n\r\n/*\r\n *   blockfilter for the passthrough filtering; the attributes given here\r\n *   will not be transmitted from the options into the passthrough\r\n */\r\nenum BlockFilter {\r\n    onerror = \"onerror\",\r\n    onevent = \"onevent\",\r\n    render = \"render\",\r\n    execute = \"execute\",\r\n    myfaces = \"myfaces\",\r\n    delay = \"delay\",\r\n    timeout = \"timeout\",\r\n    windowId = \"windowId\"\r\n}\r\n\r\n/**\r\n * Core Implementation\r\n * to distinct between api and impl\r\n *\r\n * The original idea was to make the implementation pluggable\r\n * but this is pointless, you always can overwrite the thin api layer\r\n * however a dedicated api makes sense for readability reasons\r\n */\r\nexport module Implementation {\r\n\r\n    import trim = Lang.trim;\r\n    import getMessage = ExtLang.getMessage;\r\n    import getForm = ExtLang.getForm;\r\n    import getLocalOrGlobalConfig = ExtLang.getLocalOrGlobalConfig;\r\n    import getEvent = ExtLang.getEvent;\r\n    import getGlobalConfig = ExtLang.getGlobalConfig;\r\n    import assert = Assertions.assert;\r\n    import CTX_PARAM_PASS_THR = Const.CTX_PARAM_PASS_THR;\r\n    import P_EVT = Const.P_EVT;\r\n    import SOURCE = Const.SOURCE;\r\n    import ON_EVENT = Const.ON_EVENT;\r\n    import ON_ERROR = Const.ON_ERROR;\r\n    import MYFACES = Const.MYFACES;\r\n    import MF_NONE = Const.MF_NONE;\r\n    import P_PARTIAL_SOURCE = Const.P_PARTIAL_SOURCE;\r\n    import P_AJAX = Const.P_AJAX;\r\n    import P_RESET_VALUES = Const.P_RESET_VALUES;\r\n    import CTX_PARAM_SRC_FRM_ID = Const.CTX_PARAM_SRC_FRM_ID;\r\n    import CTX_PARAM_SRC_CTL_ID = Const.CTX_PARAM_SRC_CTL_ID;\r\n    import CTX_PARAM_TR_TYPE = Const.CTX_PARAM_TR_TYPE;\r\n    import REQ_TYPE_POST = Const.REQ_TYPE_POST;\r\n    import P_WIN_ID = Const.P_WIN_ID;\r\n    import CTX_PARAM_EXECUTE = Const.CTX_PARAM_EXECUTE;\r\n    import P_EXECUTE = Const.P_EXECUTE;\r\n    import P_WINDOW_ID = Const.P_WINDOW_ID;\r\n    import P_RENDER = Const.P_RENDER;\r\n    import IDENT_ALL = Const.IDENT_ALL;\r\n    import IDENT_NONE = Const.IDENT_NONE;\r\n    import IDENT_FORM = Const.IDENT_FORM;\r\n    import IDENT_THIS = Const.IDENT_THIS;\r\n    import P_CLIENTWINDOW = Const.P_CLIENTWINDOW;\r\n    import CTX_PARAM_TIMEOUT = Const.CTX_PARAM_TIMEOUT;\r\n    import CTX_PARAM_DELAY = Const.CTX_PARAM_DELAY;\r\n    let globalConfig = myfacesConfig.myfaces.config;\r\n\r\n    let projectStage: string = null;\r\n    let separator: string = null;\r\n    let eventQueue = [];\r\n    let errorQueue = [];\r\n    let requestQueue = null;\r\n    /*error reporting threshold*/\r\n    let threshold = \"ERROR\";\r\n\r\n    //we need to proxy this in the tests\r\n    export let queueHandler = {\r\n        /**\r\n         * public to make it shimmable for tests\r\n         */\r\n        addRequestToQueue: function (elem: DQ, form: DQ, reqCtx: Config, respPassThr: Config, delay = 0, timeout = 0) {\r\n            requestQueue = requestQueue ?? new AsynchronouseQueue<XhrRequest>();\r\n            requestQueue.enqueue(new XhrRequest(elem, form, reqCtx, respPassThr, [], timeout), delay);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * fetches the separator char from the given script tags\r\n     *\r\n     * @return {char} the separator char for the given script tags\r\n     */\r\n    export function getSeparatorChar(): string {\r\n        return this?.globalConfig?.separator ??\r\n            this?.separator ??\r\n            (separator = ExtDomquery.searchJsfJsFor(/separator=([^&;]*)/).orElse(\":\").value);\r\n    }\r\n\r\n    //for testing only\r\n    export function reset() {\r\n        globalConfig = myfacesConfig.myfaces.config;\r\n\r\n        projectStage = null;\r\n        separator = null;\r\n        eventQueue = [];\r\n        errorQueue = [];\r\n        requestQueue = null;\r\n    }\r\n\r\n    /**\r\n     * @return the project stage also emitted by the server:\r\n     * it cannot be cached and must be delivered over the server\r\n     * The value for it comes from the requestInternal parameter of the jsf.js script called \"stage\".\r\n     */\r\n    export function getProjectStage(): string | null {\r\n        return this?.globalConfig?.projectStage ??\r\n            this?.projectStage ??\r\n            (projectStage = resolveProjectStateFromURL());\r\n    }\r\n\r\n    export function resolveProjectStateFromURL(): string | null {\r\n\r\n        /* run through all script tags and try to find the one that includes jsf.js */\r\n        let foundStage = <string>ExtDomquery.searchJsfJsFor(/stage=([^&;]*)/).value;\r\n        return (foundStage in ProjectStages) ? foundStage : null;\r\n    }\r\n\r\n    export function chain(source: any, event: Event, ...funcs: EvalFuncs): boolean {\r\n\r\n        let ret = true;\r\n        let resolveAndExecute = function (func: Function | string) {\r\n            if (\"string\" != typeof func) {\r\n                return (ret = ret && ((<Function>func).call(source, event) !== false));\r\n            } else {\r\n                //either a function or a string can be passed in case of a string we have to wrap it into another function\r\n                //it it is not a plain executable code but a definition\r\n                let sourceCode = trim(<string>func);\r\n                if (sourceCode.indexOf(\"function \") == 0) {\r\n                    sourceCode = `return ${sourceCode} (event)`;\r\n                }\r\n                return (ret = ret && (new Function(\"event\", sourceCode).call(source, event) !== false));\r\n            }\r\n        };\r\n\r\n        <any>Stream.of(...funcs).each(func => resolveAndExecute(func));\r\n        return ret;\r\n    }\r\n\r\n    /**\r\n     * this function has to send the ajax requests\r\n     *\r\n     * following request conditions must be met:\r\n     * <ul>\r\n     *  <li> the request must be sent asynchronously! </li>\r\n     *  <li> the request must be a POST!!! request </li>\r\n     *  <li> the request url must be the form action attribute </li>\r\n     *  <li> all requests must be queued with a client side request queue to ensure the request ordering!</li>\r\n     * </ul>\r\n     *\r\n     * @param {String|Node} elem any dom element no matter being it html or jsf, from which the event is emitted\r\n     * @param {|Event|} event any javascript event supported by that object\r\n     * @param {|Object|} options  map of options being pushed into the ajax cycle\r\n     *\r\n     *\r\n     * a) transformArguments out of the function\r\n     * b) passThrough handling with a map copy with a filter map block map\r\n     */\r\n    export function request(el: ElemDef, event?: Event, opts ?: Options) {\r\n\r\n        /*\r\n         *namespace remap for our local function context we mix the entire function namespace into\r\n         *a local function variable so that we do not have to write the entire namespace\r\n         *all the time\r\n         */\r\n        event = getEvent(event);\r\n\r\n        //options not set we define a default one with nothing\r\n        const options = new Config(opts).deepCopy;\r\n        const elem = DQ.byId(el || <Element>event.target);\r\n        const elementId = elem.id;\r\n        const requestCtx = new Config({});\r\n        const internalCtx = new Config({});\r\n\r\n        Assertions.assertRequestIntegrity(options, elem);\r\n\r\n        applyWindowId(options);\r\n\r\n        requestCtx.assign(CTX_PARAM_PASS_THR).value = fetchPassthroughValues(options.value);\r\n\r\n        requestCtx.assignIf(!!event, CTX_PARAM_PASS_THR, P_EVT).value = event?.type;\r\n\r\n        /**\r\n         * ajax pass through context with the source\r\n         * onevent and onerror\r\n         */\r\n        requestCtx.assign(SOURCE).value = elementId.value;\r\n\r\n        /**\r\n         * on event and onError...\r\n         * those values will be traversed later on\r\n         * also into the response context\r\n         */\r\n        requestCtx.assign(ON_EVENT).value = options.value?.onevent;\r\n        requestCtx.assign(ON_ERROR).value = options.value?.onerror;\r\n\r\n        /**\r\n         * lets drag the myfaces config params also in\r\n         */\r\n        requestCtx.assign(MYFACES).value = options.value?.myfaces;\r\n        /**\r\n         * fetch the parent form\r\n         *\r\n         * note we also add an override possibility here\r\n         * so that people can use dummy forms and work\r\n         * with detached objects\r\n         */\r\n        const configId = requestCtx.value?.myfaces?.form ?? MF_NONE;\r\n        let form: DQ = resolveForm(requestCtx, elem, event);\r\n\r\n        /**\r\n         * binding contract the javax.faces.source must be set\r\n         */\r\n        requestCtx.assign(CTX_PARAM_PASS_THR, P_PARTIAL_SOURCE).value = elementId.value;\r\n\r\n        /**\r\n         * javax.faces.partial.ajax must be set to true\r\n         */\r\n        requestCtx.assign(CTX_PARAM_PASS_THR, P_AJAX).value = true;\r\n\r\n        /**\r\n         * binding contract the javax.faces.source must be set\r\n         */\r\n        requestCtx.assign(CTX_PARAM_PASS_THR, P_PARTIAL_SOURCE).value = elementId.value;\r\n\r\n        /**\r\n         * if resetValues is set to true\r\n         * then we have to set javax.faces.resetValues as well\r\n         * as pass through parameter\r\n         * the value has to be explicitly true, according to\r\n         * the specs jsdoc\r\n         */\r\n        requestCtx.assignIf(true === options.value?.resetValues,\r\n            CTX_PARAM_PASS_THR, P_RESET_VALUES).value = true;\r\n\r\n        //additional meta information to speed things up, note internal non jsf\r\n        //pass through options are stored under _mfInternal in the context\r\n        internalCtx.assign(CTX_PARAM_SRC_FRM_ID).value = form.id.value;\r\n        internalCtx.assign(CTX_PARAM_SRC_CTL_ID).value = elementId.value;\r\n        internalCtx.assign(CTX_PARAM_TR_TYPE).value = REQ_TYPE_POST;\r\n\r\n        //mojarra compatibility, mojarra is sending the form id as well\r\n        //this is not documented behavior but can be determined by running\r\n        //mojarra under blackbox conditions\r\n        //i assume it does the same as our formId_submit=1 so leaving it out\r\n        //wont hurt but for the sake of compatibility we are going to add it\r\n\r\n        requestCtx.assign(CTX_PARAM_PASS_THR, form.id.value).value = form.id.value;\r\n\r\n        applyClientWindowId(form, requestCtx);\r\n\r\n        applyExecute(options, requestCtx, form, elementId.value);\r\n        applyRender(options, requestCtx, form, elementId.value);\r\n\r\n        let delay: number = resolveDelay(options, requestCtx);\r\n        let timeout: number = resolveTimeout(options, requestCtx);\r\n\r\n        //now we enqueue the request as asynchronous runnable into our request\r\n        //queue and let the queue take over the rest\r\n        queueHandler.addRequestToQueue(elem, form, requestCtx, internalCtx, delay, timeout);\r\n    }\r\n\r\n    /**\r\n     * Spec. 13.3.3\r\n     * Examining the response markup and updating the DOM tree\r\n     * @param {XMLHttpRequest} request - the ajax request\r\n     * @param {Object} context - the ajax context\r\n     */\r\n    export function response(request: XMLHttpRequest, context: Context) {\r\n        Response.processResponse(request, context);\r\n    }\r\n\r\n    export function addOnError(errorListener: IListener<ErrorData>) {\r\n        /*error handling already done in the assert of the queue*/\r\n        errorQueue.push(errorListener);\r\n    }\r\n\r\n    export function addOnEvent(eventListener: IListener<EventData>) {\r\n        /*error handling already done in the assert of the queue*/\r\n        eventQueue.push(eventListener);\r\n    }\r\n\r\n    /**\r\n     * sends an event\r\n     */\r\n    export function sendEvent(data: EventData, localHandler = function(data: EventData) {}) {\r\n        /*now we serve the queue as well*/\r\n        localHandler(data);\r\n        eventQueue.forEach(fn => fn(data));\r\n    }\r\n\r\n    export function registerPromise() {\r\n        window[\"Promise\"] = (<any>window)?.Promise ?? Promise;\r\n    }\r\n\r\n    /**\r\n     * error handler behavior called internally\r\n     * and only into the impl it takes care of the\r\n     * internal message transformation to a myfaces internal error\r\n     * and then uses the standard send error mechanisms\r\n     * also a double error logging prevention is done as well\r\n     *\r\n     * @param request the request currently being processed\r\n     * @param context the context affected by this error\r\n     * @param exception the exception being thrown\r\n     * @param clearRequestQueue if set to true, clears the request queue of all pending requests\r\n     */\r\n    export function stdErrorHandler(request: XMLHttpRequest,\r\n                                    context: Config,\r\n                                    exception: any,\r\n                                    clearRequestQueue = false) {\r\n        //newer browsers do not allow to hold additional values on native objects like exceptions\r\n        //we hence capsule it into the request, which is gced automatically\r\n        //on ie as well, since the stdErrorHandler usually is called between requests\r\n        //this is a valid approach\r\n        try {\r\n            if (threshold == \"ERROR\") {\r\n                let errorData = ErrorData.fromClient(exception);\r\n                sendError(errorData);\r\n            }\r\n        } finally {\r\n            if (clearRequestQueue) {\r\n                requestQueue.cleanup();\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * implementation triggering the error chain\r\n     *\r\n     * @param {Object} request the request object which comes from the xhr cycle\r\n     * @param {Object} context (Map) the context object being pushed over the xhr cycle keeping additional metadata\r\n     * @param {String} errorName the error name\r\n     * @param {String} errorMessage the error name\r\n     * @param {String} responseCode response Code\r\n     * @param {String} responseMessage response Message\r\n     *\r\n     * @param {String} serverErrorName the server error name in case of a server error\r\n     * @param {String} serverErrorMessage the server error message in case of a server error\r\n     * @param {String} caller optional caller reference for extended error messages\r\n     * @param {String} callFunc optional caller Function reference for extended error messages\r\n     *\r\n     *  handles the errors, in case of an onError exists within the context the onError is called as local error handler\r\n     *  the registered error handlers in the queue receiv an error message to be dealt with\r\n     *  and if the projectStage is at development an alert box is displayed\r\n     *\r\n     *  note: we have additional functionality here, via the global config myfaces.config.defaultErrorOutput a function can be provided\r\n     *  which changes the default output behavior from alert to something else\r\n     *\r\n     *\r\n     */\r\n    export function sendError(errorData: any, localHandler = function(data: any) {}) {\r\n\r\n        localHandler(errorData);\r\n        errorQueue.forEach((errorCallback: Function) => {\r\n            errorCallback(errorData);\r\n        });\r\n        let displayError: (string) => void = getGlobalConfig(\"defaultErrorOutput\", (console ? console.error : alert));\r\n        displayError(errorData);\r\n    }\r\n\r\n    /**\r\n     * @return the client window id of the current window, if one is given\r\n     */\r\n    export function getClientWindow(node ?: Element | string): string {\r\n        const ALTERED = \"___mf_id_altered__\";\r\n        const INIT = \"___init____\";\r\n\r\n        /**\r\n         * the search root for the dom element search\r\n         */\r\n        let searchRoot = new DQ(node || document.body);\r\n\r\n        /**\r\n         * a set of input elements holding the window id over the entire document\r\n         */\r\n        let windowIdHolders = searchRoot.querySelectorAll(`form #${P_WIN_ID}`);\r\n\r\n        /**\r\n         * lazy helper to fetch the window id from the window url\r\n         */\r\n        let fetchWindowIdFromUrl = () => ExtDomquery.searchJsfJsFor(/jfwid=([^&;]*)/).orElse(null).value;\r\n\r\n        /**\r\n         * functional double check based on stream reduction\r\n         * the values should be identical or on INIT value which is a premise to\r\n         * skip the first check\r\n         *\r\n         * @param value1\r\n         * @param value2\r\n         */\r\n        let doubleCheck = (value1: string, value2: string) => {\r\n            if (value1 == ALTERED) {\r\n                return value1;\r\n            } else if (value1 == INIT) {\r\n                return value2;\r\n            } else if (value1 != value2) {\r\n                return ALTERED;\r\n            }\r\n            return value2;\r\n        };\r\n\r\n        /**\r\n         * helper for cleaner code, maps the value from an item\r\n         *\r\n         * @param item\r\n         */\r\n        let getValue = (item: DQ) => item.attr(\"value\").value;\r\n        /**\r\n         * fetch the window id from the forms\r\n         * window ids must be present in all forms\r\n         * or non existent. If they exist all of them must be the same\r\n         */\r\n        let formWindowId: Optional<string> = searchRoot.stream.map<string>(getValue).reduce(doubleCheck, INIT);\r\n\r\n        //if the resulting window id is set on altered then we have an unresolvable problem\r\n        assert(formWindowId.value != ALTERED, \"Multiple different windowIds found in document\");\r\n\r\n        /**\r\n         * return the window id or null\r\n         * prio, forms under node/document and if not given then from the url\r\n         */\r\n        return formWindowId.value ?? fetchWindowIdFromUrl();\r\n    }\r\n\r\n    /**\r\n     * collect and encode data for a given form element (must be of type form)\r\n     * find the javax.faces.ViewState element and encode its value as well!\r\n     * return a concatenated string of the encoded values!\r\n     *\r\n     * @throws Error in case of the given element not being of type form!\r\n     * https://issues.apache.org/jira/browse/MYFACES-2110\r\n     */\r\n    export function getViewState(form: Element | string) {\r\n        /**\r\n         *  typecheck assert!, we opt for strong typing here\r\n         *  because it makes it easier to detect bugs\r\n         */\r\n\r\n        let element: DQ = DQ.byId(form);\r\n        if (!element.isTag(\"form\")) {\r\n            throw new Error(getMessage(\"ERR_VIEWSTATE\"));\r\n        }\r\n\r\n        let formData = new XhrFormData(element);\r\n        return formData.toString();\r\n    }\r\n\r\n    //----------------------------------------------- Methods ---------------------------------------------------------------------\r\n\r\n    function applyWindowId(options: Config) {\r\n        let windowId = options?.value?.windowId ?? ExtDomquery.windowId;\r\n        options.assignIf(!!windowId, P_WINDOW_ID).value = windowId;\r\n        options.delete(\"windowId\");\r\n    }\r\n\r\n    function applyRender(options: Config, ctx: Config, form: DQ, elementId: string) {\r\n        if (options.getIf(\"render\").isPresent()) {\r\n            transformValues(ctx.getIf(CTX_PARAM_PASS_THR).get({}), P_RENDER, <string>options.getIf(\"render\").value, form, <any>elementId);\r\n        }\r\n    }\r\n\r\n    function applyExecute(options: Config, ctx: Config, form: DQ, elementId: string) {\r\n        const PARAM_EXECUTE = CTX_PARAM_EXECUTE;\r\n        const PARAM_PASS_THR = CTX_PARAM_PASS_THR;\r\n\r\n        if (options.getIf(PARAM_EXECUTE).isPresent()) {\r\n            /*the options must be a blank delimited list of strings*/\r\n            /*compliance with Mojarra which automatically adds @this to an execute\r\n             * the spec rev 2.0a however states, if none is issued nothing at all should be sent down\r\n             */\r\n            options.assign(PARAM_EXECUTE).value = options.getIf(PARAM_EXECUTE).value + \" @this\";\r\n            transformValues(ctx.getIf(PARAM_PASS_THR).get({}), P_EXECUTE, <string>options.getIf(PARAM_EXECUTE).value, form, <any>elementId);\r\n        } else {\r\n            ctx.assign(PARAM_PASS_THR, P_EXECUTE).value = elementId;\r\n        }\r\n    }\r\n\r\n    function applyClientWindowId(form: DQ, ctx: Config) {\r\n        let clientWindow = jsf.getClientWindow(form.getAsElem(0).value);\r\n        if (clientWindow) {\r\n            ctx.assign(CTX_PARAM_PASS_THR, P_CLIENTWINDOW).value = clientWindow;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * transforms the user values to the expected one\r\n     * with the proper none all form and this handling\r\n     * (note we also could use a simple string replace but then\r\n     * we would have had double entries under some circumstances)\r\n     *\r\n     * there are several standardized constants which need a special treatment\r\n     * like @all, @none, @form, @this\r\n     *\r\n     * @param targetConfig the target configuration receiving the final values\r\n     * @param targetKey the target key\r\n     * @param userValues the passed user values (aka input string which needs to be transformed)\r\n     * @param issuingForm the form where the issuing element originates\r\n     * @param issuingElementId the issuing element\r\n     */\r\n    function transformValues(targetConfig: Config, targetKey: string, userValues: string, issuingForm: DQ, issuingElementId: string): Config {\r\n        //a cleaner implementation of the transform list method\r\n\r\n        let iterValues = (userValues) ? trim(userValues).split(/\\s+/gi) : [];\r\n        let ret = [];\r\n\r\n        let processed = {};\r\n\r\n        //TODO make this code cleaner\r\n\r\n        //the idea is simply to loop over all values and then replace\r\n        //their generic values and filter out doubles\r\n        //this is more readable than the old indexed based solution\r\n        //and not really slower because we had to build up the index in our old solution\r\n        //anyway\r\n        for (let cnt = 0; cnt < iterValues.length; cnt++) {\r\n            //avoid doubles\r\n            if (iterValues[cnt] in processed) {\r\n                continue;\r\n            }\r\n            switch (iterValues[cnt]) {\r\n                //@none no values should be sent\r\n                case IDENT_NONE:\r\n                    return targetConfig.delete(targetKey);\r\n                //@all is a pass through case according to the spec\r\n                case IDENT_ALL:\r\n                    targetConfig.assign(targetKey).value = IDENT_ALL;\r\n                    return targetConfig;\r\n                //@form pushes the issuing form id into our list\r\n                case IDENT_FORM:\r\n                    ret.push(issuingForm.id.value);\r\n                    processed[issuingForm.id.value] = true;\r\n                    break;\r\n                //@this is replaced with the current issuing element id\r\n                case IDENT_THIS:\r\n                    if (!(issuingElementId in processed)) {\r\n                        ret.push(issuingElementId);\r\n                        processed[issuingElementId] = true;\r\n                    }\r\n                    break;\r\n                default:\r\n                    ret.push(iterValues[cnt]);\r\n                    processed[iterValues[cnt]] = true;\r\n            }\r\n        }\r\n        //We now add the target as joined list\r\n        targetConfig.assign(targetKey).value = ret.join(\" \");\r\n        return targetConfig;\r\n    }\r\n\r\n    function fetchPassthroughValues(mappedOpts: { [key: string]: any }) {\r\n        return Stream.ofAssoc(mappedOpts)\r\n            .filter(item => !(item[0] in BlockFilter))\r\n            .collect(new AssocArrayCollector());\r\n    }\r\n\r\n    function resolveForm(requestCtx: Config, elem: DQ, event: Event): DQ {\r\n        const configId = requestCtx.value?.myfaces?.form ?? MF_NONE; //requestCtx.getIf(MYFACES, \"form\").orElse(MF_NONE).value;\r\n        let form: DQ = DQ\r\n            .byId(configId)\r\n            .orElseLazy(() => getForm(elem.getAsElem(0).value, event));\r\n        return form\r\n    }\r\n\r\n    function resolveTimeout(options: Config, requestCtx: Config): number {\r\n        let getCfg = getLocalOrGlobalConfig;\r\n        return options.getIf(CTX_PARAM_TIMEOUT).value ?? getCfg(requestCtx.value, CTX_PARAM_TIMEOUT, 0);\r\n    }\r\n\r\n    function resolveDelay(options: Config, requestCtx: Config): number {\r\n        let getCfg = getLocalOrGlobalConfig;\r\n\r\n        return options.getIf(CTX_PARAM_DELAY).value ?? getCfg(requestCtx.value, CTX_PARAM_DELAY, 0);\r\n    }\r\n\r\n}\r\n"],"mappings":";AAAA;;;;;;;;;;;;;;AAcA;;AAEA;AAGA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAIA;;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;;;AAGA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;;;AAOA;AACA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;;AAEA;AACA;AAAA;AAAA;AACA;AACA;AACA;AACA;AAEA;;;;AAIA;AACA;;AACA;AAGA;AAJA;AAMA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AARA;AAUA;;;;AAIA;AACA;;AACA;AAGA;AAJA;AAMA;AAEA;AACA;AACA;AACA;AALA;AAOA;AAAA;AAAA;AAAA;;AAEA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAnBA;AAqBA;;;;;;;;;;;;;;;;;;AAkBA;AACA;;AAEA;;;;AAIA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AAEA;AAEA;AAEA;;;AAGA;AACA;AAEA;;;;AAIA;AACA;AACA;AAEA;;AAEA;AACA;AACA;;;;;;AAMA;AACA;AACA;AAEA;;AAEA;AACA;AAEA;;AAEA;AACA;AAEA;;AAEA;AACA;AAEA;;;;;;AAMA;AACA;AAGA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAtGA;AAwGA;;;;;AAKA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AAHA;AAKA;;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AAJA;AAMA;;AACA;AACA;AAFA;AAIA;;;;;;;;;;;AAWA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAlBA;AAoBA;;;;;;;;;;;;;;;;;;;;;;;AAuBA;AACA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AARA;AAUA;;AAEA;AACA;;AACA;AACA;AAEA;;AAEA;AACA;AAEA;;AAEA;AACA;AAEA;;AAEA;AACA;AAEA;;;;;;;AAOA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;;;;AAIA;AACA;AACA;;;;AAIA;AACA;AAEA;AACA;AAEA;;;AAGA;AACA;AACA;AA3DA;AA6DA;;;;;;;AAOA;AACA;AACA;;;AAGA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAbA;AAeA;AAEA;;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;;;;;;;;;;AAcA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;AACA;AACA;AACA;AAEA;;AACA;AAEA;AACA;AAEA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/main/typescript/impl/AjaxImpl.ts\n");
/***/ }),
/***/ "./src/main/typescript/impl/PushImpl.ts":
/*!**********************************************!*\
!*** ./src/main/typescript/impl/PushImpl.ts ***!
\**********************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/**\r\n * Typescript port of the jsf.push part in the myfaces implementation\r\n */\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\n//TODO still work in progress\r\n//this is a 1:1 port for the time being\r\nvar Jsf_1 = __webpack_require__(/*! ../api/Jsf */ \"./src/main/typescript/api/Jsf.ts\");\r\nvar Const_1 = __webpack_require__(/*! ./core/Const */ \"./src/main/typescript/impl/core/Const.ts\");\r\n/**\r\n * Implementation class for the push functionality\r\n */\r\nvar PushImpl;\r\n(function (PushImpl) {\r\n var REASON_EXPIRED = Const_1.Const.REASON_EXPIRED;\r\n var MAX_RECONNECT_ATTEMPTS = Const_1.Const.MAX_RECONNECT_ATTEMPTS;\r\n var RECONNECT_INTERVAL = Const_1.Const.RECONNECT_INTERVAL;\r\n var URL_PROTOCOL = window.location.protocol.replace(\"http\", \"ws\") + \"//\";\r\n //we expose the member variables for testing purposes\r\n //they are not directly touched outside of tests\r\n /* socket map by token */\r\n PushImpl.sockets = {};\r\n /* component attributes by clientId */\r\n PushImpl.components = {};\r\n /* client ids by token (share websocket connection) */\r\n PushImpl.clientIdsByTokens = {};\r\n //needed for testing\r\n function reset() {\r\n PushImpl.sockets = {};\r\n PushImpl.components = {};\r\n PushImpl.clientIdsByTokens = {};\r\n }\r\n PushImpl.reset = reset;\r\n /*\r\n * Api implementations, exposed functions\r\n */\r\n /**\r\n *\r\n * @param {function} onopen The function to be invoked when the web socket is opened.\r\n * @param {function} onmessage The function to be invoked when a message is received.\r\n * @param {function} onclose The function to be invoked when the web socket is closed.\r\n * @param {boolean} autoconnect Whether or not to immediately open the socket. Defaults to <code>false</code>.\r\n */\r\n function init(socketClientId, uri, channel, onopen, onmessage, onclose, behaviorScripts, autoconnect) {\r\n onclose = resolveFunction(onclose);\r\n if (!window.WebSocket) { // IE6-9.\r\n onclose(-1, channel);\r\n return;\r\n }\r\n var channelToken = uri.substr(uri.indexOf('?') + 1);\r\n if (!PushImpl.components[socketClientId]) {\r\n PushImpl.components[socketClientId] = {\r\n 'channelToken': channelToken,\r\n 'onopen': resolveFunction(onopen),\r\n 'onmessage': resolveFunction(onmessage),\r\n 'onclose': onclose,\r\n 'behaviors': behaviorScripts,\r\n 'autoconnect': autoconnect\r\n };\r\n if (!PushImpl.clientIdsByTokens[channelToken]) {\r\n PushImpl.clientIdsByTokens[channelToken] = [];\r\n }\r\n PushImpl.clientIdsByTokens[channelToken].push(socketClientId);\r\n if (!PushImpl.sockets[channelToken]) {\r\n PushImpl.sockets[channelToken] = new Socket(channelToken, getBaseURL(uri), channel);\r\n }\r\n }\r\n if (autoconnect) {\r\n Jsf_1.jsf.push.open(socketClientId);\r\n }\r\n }\r\n PushImpl.init = init;\r\n function open(socketClientId) {\r\n var _a, _b;\r\n getSocket((_b = (_a = PushImpl.components) === null || _a === void 0 ? void 0 : _a[socketClientId]) === null || _b === void 0 ? void 0 : _b.channelToken).open();\r\n }\r\n PushImpl.open = open;\r\n function close(socketClientId) {\r\n var _a;\r\n getSocket((_a = PushImpl.components) === null || _a === void 0 ? void 0 : _a[socketClientId].channelToken).close();\r\n }\r\n PushImpl.close = close;\r\n // Private helper classes\r\n // Private classes functions ----------------------------------------------------------------------------------\r\n /**\r\n * Creates a reconnecting web socket. When the web socket successfully connects on first attempt, then it will\r\n * automatically reconnect on timeout with cumulative intervals of 500ms with a maximum of 25 attempts (~3 minutes).\r\n * The <code>onclose</code> function will be called with the error code of the last attempt.\r\n * @constructor\r\n * @param {string} channelToken the channel token associated with this websocket connection\r\n * @param {string} url The URL of the web socket\r\n * @param {string} channel The name of the web socket channel.\r\n */\r\n var Socket = /** @class */ (function () {\r\n function Socket(channelToken, url, channel) {\r\n this.channelToken = channelToken;\r\n this.url = url;\r\n this.channel = channel;\r\n this.reconnectAttempts = 0;\r\n }\r\n Socket.prototype.open = function () {\r\n if (this.socket && this.socket.readyState == 1) {\r\n return;\r\n }\r\n this.socket = new WebSocket(this.url);\r\n this.bindCallbacks();\r\n };\r\n Socket.prototype.onopen = function (event) {\r\n if (!this.reconnectAttempts) {\r\n var clientIds = PushImpl.clientIdsByTokens[this.channelToken];\r\n for (var i = clientIds.length - 1; i >= 0; i--) {\r\n var socketClientId = clientIds[i];\r\n PushImpl.components[socketClientId]['onopen'](this.channel);\r\n }\r\n }\r\n this.reconnectAttempts = 0;\r\n };\r\n Socket.prototype.onmmessage = function (event) {\r\n var message = JSON.parse(event.data);\r\n for (var i = PushImpl.clientIdsByTokens[this.channelToken].length - 1; i >= 0; i--) {\r\n var socketClientId = PushImpl.clientIdsByTokens[this.channelToken][i];\r\n if (document.getElementById(socketClientId)) {\r\n try {\r\n PushImpl.components[socketClientId]['onmessage'](message, this.channel, event);\r\n }\r\n catch (e) {\r\n //Ignore\r\n }\r\n var behaviors = PushImpl.components[socketClientId]['behaviors'];\r\n var functions = behaviors[message];\r\n if (functions && functions.length) {\r\n for (var j = 0; j < functions.length; j++) {\r\n try {\r\n functions[j](null);\r\n }\r\n catch (e) {\r\n //Ignore\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n PushImpl.clientIdsByTokens[this.channelToken].splice(i, 1);\r\n }\r\n }\r\n if (PushImpl.clientIdsByTokens[this.channelToken].length == 0) {\r\n //tag dissapeared\r\n this.close();\r\n }\r\n };\r\n Socket.prototype.onclose = function (event) {\r\n var _a, _b;\r\n if (!this.socket\r\n || (event.code == 1000 && event.reason == REASON_EXPIRED)\r\n || (event.code == 1008)\r\n || (!this.reconnectAttempts)\r\n || (this.reconnectAttempts >= MAX_RECONNECT_ATTEMPTS)) {\r\n var clientIds = PushImpl.clientIdsByTokens[this.channelToken];\r\n for (var i = clientIds.length - 1; i >= 0; i--) {\r\n var socketClientId = clientIds[i];\r\n PushImpl.components[socketClientId]['onclose']((_a = event) === null || _a === void 0 ? void 0 : _a.code, (_b = this) === null || _b === void 0 ? void 0 : _b.channel, event);\r\n }\r\n }\r\n else {\r\n setTimeout(this.open, RECONNECT_INTERVAL * this.reconnectAttempts++);\r\n }\r\n };\r\n ;\r\n Socket.prototype.close = function () {\r\n if (this.socket) {\r\n var s = this.socket;\r\n this.socket = null;\r\n s.close();\r\n }\r\n };\r\n /**\r\n * bind the callbacks to the socket callbacks\r\n */\r\n Socket.prototype.bindCallbacks = function () {\r\n var _this = this;\r\n this.socket.onopen = function (event) { return _this.onopen(event); };\r\n this.socket.onmessage = function (event) { return _this.onmmessage(event); };\r\n this.socket.onclose = function (event) { return _this.onclose(event); };\r\n };\r\n return Socket;\r\n }());\r\n // Private static functions ---------------------------------------------------------------------------------------\r\n function getBaseURL(url) {\r\n if (url.indexOf(\"://\") < 0) {\r\n var base = window.location.hostname + \":\" + window.location.port;\r\n return URL_PROTOCOL + base + url;\r\n }\r\n else {\r\n return url;\r\n }\r\n }\r\n /**\r\n * Get socket associated with given channelToken.\r\n * @param {string} channelToken The name of the web socket channelToken.\r\n * @return {Socket} Socket associated with given channelToken.\r\n * @throws {Error} When channelToken is unknown, you may need to initialize\r\n * it first via <code>init()</code> function.\r\n */\r\n function getSocket(channelToken) {\r\n var socket = PushImpl.sockets[channelToken];\r\n if (socket) {\r\n return socket;\r\n }\r\n else {\r\n throw new Error(\"Unknown channelToken: \" + channelToken);\r\n }\r\n }\r\n function resolveFunction(fn) {\r\n if (fn === void 0) { fn = function () {\r\n }; }\r\n return ((typeof fn !== \"function\") && (fn = window[fn]), fn);\r\n }\r\n})(PushImpl = exports.PushImpl || (exports.PushImpl = {}));\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/main/typescript/impl/PushImpl.ts.js","sources":["webpack:///./src/main/typescript/impl/PushImpl.ts?9166"],"sourcesContent":["/**\r\n * Typescript port of the jsf.push part in the myfaces implementation\r\n */\r\n\r\n//TODO still work in progress\r\n//this is a 1:1 port for the time being\r\nimport {jsf} from \"../api/Jsf\";\r\nimport {Const} from \"./core/Const\";\r\n\r\n\r\n/**\r\n * Implementation class for the push functionality\r\n */\r\nexport module PushImpl {\r\n\r\n    import REASON_EXPIRED = Const.REASON_EXPIRED;\r\n    import MAX_RECONNECT_ATTEMPTS = Const.MAX_RECONNECT_ATTEMPTS;\r\n    import RECONNECT_INTERVAL = Const.RECONNECT_INTERVAL;\r\n\r\n    const URL_PROTOCOL = window.location.protocol.replace(\"http\", \"ws\") + \"//\";\r\n\r\n\r\n    //we expose the member variables for testing purposes\r\n    //they are not directly touched outside of tests\r\n\r\n    /* socket map by token */\r\n    export let sockets = {};\r\n    /* component attributes by clientId */\r\n    export let components = {};\r\n    /* client ids by token (share websocket connection) */\r\n    export let clientIdsByTokens = {};\r\n\r\n\r\n    //needed for testing\r\n    export function reset() {\r\n        sockets = {};\r\n        components = {}\r\n        clientIdsByTokens = {}\r\n    }\r\n\r\n    /*\r\n     * Api implementations, exposed functions\r\n     */\r\n\r\n    /**\r\n     *\r\n     * @param {function} onopen The function to be invoked when the web socket is opened.\r\n     * @param {function} onmessage The function to be invoked when a message is received.\r\n     * @param {function} onclose The function to be invoked when the web socket is closed.\r\n     * @param {boolean} autoconnect Whether or not to immediately open the socket. Defaults to <code>false</code>.\r\n     */\r\n    export function init(socketClientId: string,\r\n                         uri: string,\r\n                         channel: string,\r\n                         onopen: Function,\r\n                         onmessage: Function,\r\n                         onclose: Function,\r\n                         behaviorScripts: any,\r\n                         autoconnect: boolean) {\r\n        onclose = resolveFunction(onclose);\r\n\r\n        if (!window.WebSocket) { // IE6-9.\r\n            onclose(-1, channel);\r\n            return;\r\n        }\r\n\r\n        let channelToken = uri.substr(uri.indexOf('?') + 1);\r\n\r\n        if (!components[socketClientId]) {\r\n            components[socketClientId] = {\r\n                'channelToken': channelToken,\r\n                'onopen': resolveFunction(onopen),\r\n                'onmessage' : resolveFunction(onmessage),\r\n                'onclose': onclose,\r\n                'behaviors': behaviorScripts,\r\n                'autoconnect': autoconnect};\r\n            if (!clientIdsByTokens[channelToken]) {\r\n                clientIdsByTokens[channelToken] = [];\r\n            }\r\n            clientIdsByTokens[channelToken].push(socketClientId);\r\n            if (!sockets[channelToken]){\r\n                sockets[channelToken] = new Socket(channelToken,\r\n                    getBaseURL(uri), channel);\r\n            }\r\n        }\r\n\r\n        if (autoconnect) {\r\n            jsf.push.open(socketClientId);\r\n        }\r\n    }\r\n\r\n    export function open(socketClientId: string) {\r\n        getSocket(components?.[socketClientId]?.channelToken).open();\r\n    }\r\n\r\n    export function close(socketClientId: string) {\r\n        getSocket(components?.[socketClientId].channelToken).close();\r\n    }\r\n\r\n    // Private helper classes\r\n    // Private classes functions ----------------------------------------------------------------------------------\r\n    /**\r\n     * Creates a reconnecting web socket. When the web socket successfully connects on first attempt, then it will\r\n     * automatically reconnect on timeout with cumulative intervals of 500ms with a maximum of 25 attempts (~3 minutes).\r\n     * The <code>onclose</code> function will be called with the error code of the last attempt.\r\n     * @constructor\r\n     * @param {string} channelToken the channel token associated with this websocket connection\r\n     * @param {string} url The URL of the web socket\r\n     * @param {string} channel The name of the web socket channel.\r\n     */\r\n\r\n    class Socket {\r\n\r\n        socket: WebSocket;\r\n        reconnectAttempts = 0;\r\n\r\n        constructor(private channelToken: string, private url: string, private channel: string) {\r\n        }\r\n\r\n        open() {\r\n            if (this.socket && this.socket.readyState == 1) {\r\n                return;\r\n            }\r\n            this.socket = new WebSocket(this.url);\r\n\r\n            this.bindCallbacks();\r\n        }\r\n\r\n        onopen(event: any) {\r\n            if (!this.reconnectAttempts) {\r\n                let clientIds = clientIdsByTokens[this.channelToken];\r\n                for (let i = clientIds.length - 1; i >= 0; i--) {\r\n                    let socketClientId = clientIds[i];\r\n                    components[socketClientId]['onopen'](this.channel);\r\n                }\r\n            }\r\n            this.reconnectAttempts = 0;\r\n        }\r\n\r\n        onmmessage(event: any) {\r\n            let message = JSON.parse(event.data);\r\n            for (let i = clientIdsByTokens[this.channelToken].length - 1; i >= 0; i--) {\r\n                let socketClientId = clientIdsByTokens[this.channelToken][i];\r\n                if (document.getElementById(socketClientId)) {\r\n                    try {\r\n                        components[socketClientId]['onmessage'](message, this.channel, event);\r\n                    } catch (e) {\r\n                        //Ignore\r\n                    }\r\n                    let behaviors = components[socketClientId]['behaviors'];\r\n                    let functions = behaviors[message];\r\n                    if (functions && functions.length) {\r\n                        for (let j = 0; j < functions.length; j++) {\r\n                            try {\r\n                                functions[j](null);\r\n                            } catch (e) {\r\n                                //Ignore\r\n                            }\r\n                        }\r\n                    }\r\n                } else {\r\n                    clientIdsByTokens[this.channelToken].splice(i, 1);\r\n                }\r\n            }\r\n            if (clientIdsByTokens[this.channelToken].length == 0) {\r\n                //tag dissapeared\r\n                this.close();\r\n            }\r\n        }\r\n\r\n        onclose(event: any) {\r\n            if (!this.socket\r\n                || (event.code == 1000 && event.reason == REASON_EXPIRED)\r\n                || (event.code == 1008)\r\n                || (!this.reconnectAttempts)\r\n                || (this.reconnectAttempts >= MAX_RECONNECT_ATTEMPTS)) {\r\n                let clientIds = clientIdsByTokens[this.channelToken];\r\n                for (let i = clientIds.length - 1; i >= 0; i--) {\r\n                    let socketClientId = clientIds[i];\r\n                    components[socketClientId]['onclose'](event?.code, this?.channel, event);\r\n                }\r\n            } else {\r\n                setTimeout(this.open, RECONNECT_INTERVAL * this.reconnectAttempts++);\r\n            }\r\n        };\r\n\r\n        close() {\r\n            if (this.socket) {\r\n                let s = this.socket;\r\n                this.socket = null;\r\n                s.close();\r\n            }\r\n        }\r\n\r\n        /**\r\n         * bind the callbacks to the socket callbacks\r\n         */\r\n        private bindCallbacks() {\r\n            this.socket.onopen = (event: Event) => this.onopen(event);\r\n            this.socket.onmessage = (event: Event) => this.onmmessage(event);\r\n            this.socket.onclose = (event: Event) => this.onclose(event);\r\n        }\r\n    }\r\n\r\n    // Private static functions ---------------------------------------------------------------------------------------\r\n\r\n    function getBaseURL(url: string) {\r\n        if (url.indexOf(\"://\") < 0) {\r\n            let base = window.location.hostname + \":\" + window.location.port;\r\n            return URL_PROTOCOL + base + url;\r\n        } else {\r\n            return url;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Get socket associated with given channelToken.\r\n     * @param {string} channelToken The name of the web socket channelToken.\r\n     * @return {Socket} Socket associated with given channelToken.\r\n     * @throws {Error} When channelToken is unknown, you may need to initialize\r\n     *                 it first via <code>init()</code> function.\r\n     */\r\n    function getSocket(channelToken: string): Socket {\r\n        let socket = sockets[channelToken];\r\n        if (socket) {\r\n            return socket;\r\n        } else {\r\n            throw new Error(\"Unknown channelToken: \" + channelToken);\r\n        }\r\n    }\r\n\r\n    function resolveFunction(fn: Function | string = () => {\r\n    }): Function {\r\n        return <Function>((typeof fn !== \"function\") && (fn = window[fn]), fn);\r\n    }\r\n\r\n}"],"mappings":";AAAA;;AAEA;;AAEA;AACA;AACA;AACA;AAGA;;AAEA;AACA;AAAA;AAEA;AACA;AACA;AAEA;AAGA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AAJA;AAMA;;AAEA;AAEA;;;;;;AAMA;AACA;AAQA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAtCA;AAwCA;;AACA;AACA;AAFA;AAIA;;AACA;AACA;AAFA;AAIA;AACA;AACA;;;;;;;;AAQA;AAEA;AAKA;AAAA;AAAA;AAAA;AAFA;AAGA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;AAEA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AAAA;AAEA;AAEA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAEA;;;;;;AAMA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AAEA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/main/typescript/impl/PushImpl.ts\n");
/***/ }),
/***/ "./src/main/typescript/impl/core/Const.ts":
/*!************************************************!*\
!*** ./src/main/typescript/impl/core/Const.ts ***!
\************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar Const;\r\n(function (Const) {\r\n /*internal identifiers for options*/\r\n Const.IDENT_ALL = \"@all\";\r\n Const.IDENT_NONE = \"@none\";\r\n Const.IDENT_THIS = \"@this\";\r\n Const.IDENT_FORM = \"@form\";\r\n /*\r\n * [export const] constants\r\n */\r\n Const.P_PARTIAL_SOURCE = \"javax.faces.source\";\r\n Const.PARTIAL_ID = \"partialId\";\r\n Const.P_VIEWSTATE = \"javax.faces.ViewState\";\r\n Const.P_VIEWROOT = \"javax.faces.ViewRoot\";\r\n Const.P_VIEWHEAD = \"javax.faces.ViewHead\";\r\n Const.P_VIEWBODY = \"javax.faces.ViewBody\";\r\n Const.P_CLIENTWINDOW = \"javax.faces.ClientWindow\";\r\n Const.P_AJAX = \"javax.faces.partial.ajax\";\r\n Const.P_EXECUTE = \"javax.faces.partial.execute\";\r\n Const.P_RENDER = \"javax.faces.partial.render\";\r\n Const.P_EVT = \"javax.faces.partial.event\";\r\n Const.P_CLIENT_WINDOW = \"javax.faces.ClientWindow\";\r\n Const.P_RESET_VALUES = \"javax.faces.partial.resetValues\";\r\n Const.P_WIN_ID = \"javax.faces.WindowId\";\r\n Const.P_WINDOW_ID = \"javax.faces.windowId\";\r\n /* message types */\r\n Const.ERROR = \"error\";\r\n Const.EVENT = \"event\";\r\n Const.ON_ERROR = \"onerror\";\r\n Const.ON_EVENT = \"onevent\";\r\n /* event emitting stages */\r\n Const.BEGIN = \"begin\";\r\n Const.COMPLETE = \"complete\";\r\n Const.SUCCESS = \"success\";\r\n Const.SOURCE = \"source\";\r\n Const.STATUS = \"status\";\r\n Const.ERROR_NAME = \"error-name\";\r\n Const.ERROR_MESSAGE = \"error-message\";\r\n Const.RESPONSE_TEXT = \"responseText\";\r\n Const.RESPONSE_XML = \"responseXML\";\r\n /*ajax errors spec 14.4.2*/\r\n Const.HTTPERROR = \"httpError\";\r\n Const.EMPTY_RESPONSE = \"emptyResponse\";\r\n Const.MALFORMEDXML = \"malformedXML\";\r\n Const.SERVER_ERROR = \"serverError\";\r\n Const.CLIENT_ERROR = \"clientError\";\r\n Const.TIMEOUT_EVENT = \"timeout\";\r\n Const.CTX_PARAM_MF_INTERNAL = \"_mfInternal\";\r\n Const.CTX_PARAM_SRC_FRM_ID = \"_mfSourceFormId\";\r\n Const.CTX_PARAM_SRC_CTL_ID = \"_mfSourceControlId\";\r\n Const.CTX_PARAM_TR_TYPE = \"_mfTransportType\";\r\n Const.CTX_PARAM_PASS_THR = \"passThrgh\";\r\n Const.CTX_PARAM_DELAY = \"delay\";\r\n Const.CTX_PARAM_TIMEOUT = \"timeout\";\r\n Const.CTX_PARAM_RST = \"resetValues\";\r\n Const.CTX_PARAM_EXECUTE = \"execute\";\r\n Const.STAGE_DEVELOPMENT = \"Development\";\r\n Const.CONTENT_TYPE = \"Content-Type\";\r\n Const.HEAD_FACES_REQ = \"Faces-Request\";\r\n Const.REQ_ACCEPT = \"Accept\";\r\n Const.VAL_AJAX = \"partial/ajax\";\r\n Const.ENCODED_URL = \"javax.faces.encodedURL\";\r\n Const.REQ_TYPE_GET = \"GET\";\r\n Const.REQ_TYPE_POST = \"POST\";\r\n Const.STATE_EVT_BEGIN = \"begin\"; //TODO remove this\r\n Const.STATE_EVT_TIMEOUT = \"TIMEOUT_EVENT\";\r\n Const.STATE_EVT_COMPLETE = \"complete\"; //TODO remove this\r\n Const.URL_ENCODED = \"application/x-www-form-urlencoded\";\r\n Const.MULTIPART = \"multipart/form-data\";\r\n Const.NO_TIMEOUT = 0;\r\n Const.STD_ACCEPT = \"text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8\";\r\n Const.TAG_HEAD = \"head\";\r\n Const.TAG_FORM = \"form\";\r\n Const.TAG_BODY = \"body\";\r\n Const.TAG_BEFORE = \"before\";\r\n Const.TAG_AFTER = \"after\";\r\n Const.TAG_ATTR = \"attribute\";\r\n Const.SEL_VIEWSTATE_ELEM = \"[name='\" + Const.P_VIEWSTATE + \"']\";\r\n Const.SEL_RESPONSE_XML = \"responseXML\";\r\n Const.PHASE_PROCESS_RESPONSE = \"processResponse\";\r\n Const.ERR_NO_PARTIAL_RESPONSE = \"Partial response not set\";\r\n Const.ATTR_URL = \"url\";\r\n Const.ATTR_NAME = \"name\";\r\n Const.ATTR_VALUE = \"value\";\r\n Const.ATTR_ID = \"id\";\r\n /*partial response types*/\r\n Const.RESP_PARTIAL = \"partial-response\";\r\n Const.RESP_TYPE_ERROR = \"error\";\r\n Const.RESP_TYPE_REDIRECT = \"redirect\";\r\n Const.RESP_TYPE_CHANGES = \"changes\";\r\n /*partial commands*/\r\n Const.CMD_CHANGES = \"changes\";\r\n Const.CMD_UPDATE = \"update\";\r\n Const.CMD_DELETE = \"delete\";\r\n Const.CMD_INSERT = \"insert\";\r\n Const.CMD_EVAL = \"eval\";\r\n Const.CMD_ERROR = \"error\";\r\n Const.CMD_ATTRIBUTES = \"attributes\";\r\n Const.CMD_EXTENSION = \"extension\";\r\n Const.CMD_REDIRECT = \"redirect\";\r\n /*other constants*/\r\n Const.UPDATE_FORMS = \"_updateForms\";\r\n Const.UPDATE_ELEMS = \"_updateElems\";\r\n Const.MYFACES = \"myfaces\";\r\n Const.SEL_SCRIPTS_STYLES = \"script, style, link\";\r\n Const.MF_NONE = \"__mf_none__\";\r\n Const.REASON_EXPIRED = \"Expired\";\r\n Const.APPLIED_VST = \"appliedViewState\";\r\n Const.RECONNECT_INTERVAL = 500;\r\n Const.MAX_RECONNECT_ATTEMPTS = 25;\r\n Const.HTML_VIEWSTATE = [\"<input type='hidden'\", \"id='\", Const.P_VIEWSTATE, \"' name='\", Const.P_VIEWSTATE, \"' value='' />\"].join(\"\");\r\n Const.EMPTY_FUNC = Object.freeze(function () { });\r\n Const.EMPTY_STR = \"\";\r\n Const.EMPTY_MAP = Object.freeze({});\r\n})(Const = exports.Const || (exports.Const = {}));\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/main/typescript/impl/core/Const.ts.js","sources":["webpack:///./src/main/typescript/impl/core/Const.ts?79a5"],"sourcesContent":["/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements.  See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License.  You may obtain a copy of the License at\r\n *\r\n *      http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\nexport module Const {\r\n    /*internal identifiers for options*/\r\n    export const IDENT_ALL = \"@all\";\r\n    export const IDENT_NONE = \"@none\";\r\n    export const IDENT_THIS = \"@this\";\r\n    export const IDENT_FORM = \"@form\";\r\n\r\n    /*\r\n     * [export const] constants\r\n     */\r\n\r\n    export const P_PARTIAL_SOURCE = \"javax.faces.source\";\r\n    export const PARTIAL_ID = \"partialId\";\r\n    export const P_VIEWSTATE = \"javax.faces.ViewState\";\r\n    export const P_VIEWROOT = \"javax.faces.ViewRoot\";\r\n    export const P_VIEWHEAD = \"javax.faces.ViewHead\";\r\n    export const P_VIEWBODY = \"javax.faces.ViewBody\";\r\n\r\n\r\n    export const P_CLIENTWINDOW = \"javax.faces.ClientWindow\";\r\n    export const P_AJAX = \"javax.faces.partial.ajax\";\r\n    export const P_EXECUTE = \"javax.faces.partial.execute\";\r\n    export const P_RENDER = \"javax.faces.partial.render\";\r\n    export const P_EVT = \"javax.faces.partial.event\";\r\n    export const P_CLIENT_WINDOW = \"javax.faces.ClientWindow\";\r\n    export const P_RESET_VALUES = \"javax.faces.partial.resetValues\";\r\n    export const P_WIN_ID = \"javax.faces.WindowId\";\r\n\r\n    export const P_WINDOW_ID = \"javax.faces.windowId\";\r\n\r\n    /* message types */\r\n    export const ERROR = \"error\";\r\n    export const EVENT = \"event\";\r\n\r\n    export const ON_ERROR = \"onerror\";\r\n    export const ON_EVENT = \"onevent\";\r\n\r\n    /* event emitting stages */\r\n    export const BEGIN = \"begin\";\r\n    export const COMPLETE = \"complete\";\r\n    export const SUCCESS = \"success\";\r\n\r\n    export const SOURCE = \"source\";\r\n    export const STATUS = \"status\";\r\n\r\n\r\n    export const ERROR_NAME = \"error-name\";\r\n    export const ERROR_MESSAGE = \"error-message\";\r\n\r\n\r\n    export const RESPONSE_TEXT = \"responseText\";\r\n    export const RESPONSE_XML = \"responseXML\";\r\n\r\n    /*ajax errors spec 14.4.2*/\r\n    export const HTTPERROR = \"httpError\";\r\n    export const EMPTY_RESPONSE = \"emptyResponse\";\r\n    export const MALFORMEDXML = \"malformedXML\";\r\n    export const SERVER_ERROR = \"serverError\";\r\n    export const CLIENT_ERROR = \"clientError\";\r\n    export const TIMEOUT_EVENT = \"timeout\";\r\n\r\n    export const CTX_PARAM_MF_INTERNAL = \"_mfInternal\";\r\n\r\n    export const CTX_PARAM_SRC_FRM_ID = \"_mfSourceFormId\";\r\n    export const CTX_PARAM_SRC_CTL_ID = \"_mfSourceControlId\";\r\n    export const CTX_PARAM_TR_TYPE = \"_mfTransportType\";\r\n    export const CTX_PARAM_PASS_THR = \"passThrgh\";\r\n    export const CTX_PARAM_DELAY = \"delay\";\r\n    export const CTX_PARAM_TIMEOUT = \"timeout\";\r\n    export const CTX_PARAM_RST = \"resetValues\";\r\n    export const CTX_PARAM_EXECUTE = \"execute\";\r\n\r\n    export const STAGE_DEVELOPMENT = \"Development\";\r\n\r\n\r\n\r\n    export const CONTENT_TYPE= \"Content-Type\";\r\n    export const HEAD_FACES_REQ= \"Faces-Request\";\r\n    export const REQ_ACCEPT = \"Accept\";\r\n    export const VAL_AJAX= \"partial/ajax\";\r\n    export const ENCODED_URL= \"javax.faces.encodedURL\";\r\n    export const REQ_TYPE_GET = \"GET\";\r\n    export const REQ_TYPE_POST = \"POST\";\r\n    export const STATE_EVT_BEGIN = \"begin\"; //TODO remove this\r\n    export const STATE_EVT_TIMEOUT = \"TIMEOUT_EVENT\";\r\n    export const STATE_EVT_COMPLETE = \"complete\"; //TODO remove this\r\n    export const URL_ENCODED = \"application/x-www-form-urlencoded\";\r\n    export const MULTIPART = \"multipart/form-data\";\r\n    export const NO_TIMEOUT = 0;\r\n    export const STD_ACCEPT = \"text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8\";\r\n\r\n    export const TAG_HEAD = \"head\";\r\n    export const TAG_FORM = \"form\";\r\n    export const TAG_BODY = \"body\";\r\n    export const TAG_BEFORE = \"before\";\r\n    export const TAG_AFTER = \"after\";\r\n\r\n    export const TAG_ATTR = \"attribute\";\r\n\r\n\r\n    export const SEL_VIEWSTATE_ELEM = \"[name='\" + Const.P_VIEWSTATE + \"']\";\r\n    export const SEL_RESPONSE_XML = \"responseXML\";\r\n\r\n    export const PHASE_PROCESS_RESPONSE = \"processResponse\";\r\n\r\n\r\n    export const ERR_NO_PARTIAL_RESPONSE = \"Partial response not set\";\r\n\r\n    export const ATTR_URL = \"url\";\r\n    export const ATTR_NAME = \"name\";\r\n    export const ATTR_VALUE = \"value\";\r\n    export const ATTR_ID = \"id\";\r\n\r\n    /*partial response types*/\r\n    export const RESP_PARTIAL = \"partial-response\";\r\n    export const RESP_TYPE_ERROR = \"error\";\r\n    export const RESP_TYPE_REDIRECT = \"redirect\";\r\n    export const RESP_TYPE_CHANGES = \"changes\";\r\n\r\n    /*partial commands*/\r\n    export const CMD_CHANGES = \"changes\";\r\n    export const CMD_UPDATE = \"update\";\r\n    export const CMD_DELETE = \"delete\";\r\n    export const CMD_INSERT = \"insert\";\r\n    export const CMD_EVAL = \"eval\";\r\n    export const CMD_ERROR = \"error\";\r\n    export const CMD_ATTRIBUTES = \"attributes\";\r\n    export const CMD_EXTENSION = \"extension\";\r\n    export const CMD_REDIRECT = \"redirect\";\r\n\r\n    /*other constants*/\r\n\r\n    export const UPDATE_FORMS = \"_updateForms\";\r\n    export const UPDATE_ELEMS = \"_updateElems\";\r\n\r\n    export const MYFACES = \"myfaces\";\r\n\r\n    export const SEL_SCRIPTS_STYLES = \"script, style, link\";\r\n\r\n    export const MF_NONE = \"__mf_none__\";\r\n\r\n    export const REASON_EXPIRED = \"Expired\";\r\n\r\n    export const APPLIED_VST = \"appliedViewState\";\r\n\r\n    export const RECONNECT_INTERVAL = 500;\r\n    export const MAX_RECONNECT_ATTEMPTS = 25;\r\n\r\n    export const HTML_VIEWSTATE = [\"<input type='hidden'\", \"id='\", P_VIEWSTATE, \"' name='\", P_VIEWSTATE, \"' value='' />\"].join(\"\");\r\n\r\n    export const EMPTY_FUNC = Object.freeze(() => {});\r\n    export const EMPTY_STR = \"\";\r\n    export const EMPTY_MAP = Object.freeze({});\r\n}"],"mappings":";AAAA;;;;;;;;;;;;;;AAcA;;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAGA;AACA;AAGA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAGA;AACA;AAEA;AAGA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AAEA;AAEA;AAEA;AAEA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AACA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/main/typescript/impl/core/Const.ts\n");
/***/ }),
/***/ "./src/main/typescript/impl/core/ImplTypes.ts":
/*!****************************************************!*\
!*** ./src/main/typescript/impl/core/ImplTypes.ts ***!
\****************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar Const_1 = __webpack_require__(/*! ./Const */ \"./src/main/typescript/impl/core/Const.ts\");\r\nvar P_VIEWSTATE = Const_1.Const.P_VIEWSTATE;\r\n/**\r\n * a helper class to isolate the\r\n * view state data processing\r\n */\r\nvar ViewState = /** @class */ (function () {\r\n function ViewState(id, value) {\r\n this.id = id;\r\n this.value = value;\r\n var viewStatePos = id.indexOf(P_VIEWSTATE);\r\n this.nameSpace = viewStatePos > 0 ? id.substr(0, viewStatePos - 1) : \"\";\r\n }\r\n Object.defineProperty(ViewState.prototype, \"hasNameSpace\", {\r\n get: function () {\r\n var _a, _b;\r\n return !!(_b = (_a = this) === null || _a === void 0 ? void 0 : _a.nameSpace, (_b !== null && _b !== void 0 ? _b : \"\")).length;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n return ViewState;\r\n}());\r\nexports.ViewState = ViewState;\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbWFpbi90eXBlc2NyaXB0L2ltcGwvY29yZS9JbXBsVHlwZXMudHMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9zcmMvbWFpbi90eXBlc2NyaXB0L2ltcGwvY29yZS9JbXBsVHlwZXMudHM/NDc2OSJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBMaWNlbnNlZCB0byB0aGUgQXBhY2hlIFNvZnR3YXJlIEZvdW5kYXRpb24gKEFTRikgdW5kZXIgb25lIG9yIG1vcmVcbiAqIGNvbnRyaWJ1dG9yIGxpY2Vuc2UgYWdyZWVtZW50cy4gIFNlZSB0aGUgTk9USUNFIGZpbGUgZGlzdHJpYnV0ZWQgd2l0aFxuICogdGhpcyB3b3JrIGZvciBhZGRpdGlvbmFsIGluZm9ybWF0aW9uIHJlZ2FyZGluZyBjb3B5cmlnaHQgb3duZXJzaGlwLlxuICogVGhlIEFTRiBsaWNlbnNlcyB0aGlzIGZpbGUgdG8geW91IHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjBcbiAqICh0aGUgXCJMaWNlbnNlXCIpOyB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGhcbiAqIHRoZSBMaWNlbnNlLiAgWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogICAgICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbiAqXG4gKiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gKiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgQkFTSVMsXG4gKiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbiAqIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAqIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbmltcG9ydCB7Q29uc3R9IGZyb20gXCIuL0NvbnN0XCI7XG5pbXBvcnQgUF9WSUVXU1RBVEUgPSBDb25zdC5QX1ZJRVdTVEFURTtcblxuZXhwb3J0IGludGVyZmFjZSBJZFZhbHVlSG9sZGVyIHtcblxuICAgIHJlYWRvbmx5IGlkOiBzdHJpbmc7XG4gICAgcmVhZG9ubHkgdmFsdWU6IHN0cmluZztcblxufVxuXG4vKipcbiAqIGEgaGVscGVyIGNsYXNzIHRvIGlzb2xhdGUgdGhlXG4gKiB2aWV3IHN0YXRlIGRhdGEgcHJvY2Vzc2luZ1xuICovXG5leHBvcnQgY2xhc3MgVmlld1N0YXRlIGltcGxlbWVudHMgSWRWYWx1ZUhvbGRlciB7XG5cbiAgICBuYW1lU3BhY2U6IHN0cmluZztcblxuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyBpZDogc3RyaW5nLCBwdWJsaWMgdmFsdWU6IHN0cmluZykge1xuICAgICAgICBsZXQgdmlld1N0YXRlUG9zID0gaWQuaW5kZXhPZihQX1ZJRVdTVEFURSk7XG4gICAgICAgIHRoaXMubmFtZVNwYWNlID0gdmlld1N0YXRlUG9zID4gMCA/IGlkLnN1YnN0cigwLCB2aWV3U3RhdGVQb3MgLSAxKSA6IFwiXCI7XG4gICAgfVxuXG4gICAgZ2V0IGhhc05hbWVTcGFjZSgpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuICEhKHRoaXM/Lm5hbWVTcGFjZSA/PyBcIlwiKS5sZW5ndGg7XG4gICAgfVxufSJdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7Ozs7OztBQWNBOztBQUVBO0FBQ0E7QUFTQTs7O0FBR0E7QUFDQTtBQUlBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQUE7O0FBQ0E7QUFDQTs7O0FBQUE7QUFDQTtBQUFBO0FBWkE7Iiwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/main/typescript/impl/core/ImplTypes.ts\n");
/***/ }),
/***/ "./src/main/typescript/impl/i18n/Messages.ts":
/*!***************************************************!*\
!*** ./src/main/typescript/impl/i18n/Messages.ts ***!
\***************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar Messages = /** @class */ (function () {\r\n function Messages() {\r\n this.MSG_TEST = \"Testmessage\";\r\n /*Messages*/\r\n /** @constant */\r\n this.MSG_DEV_MODE = \"Note, this message is only sent, because project stage is development and no \" +\r\n \"other error listeners are registered.\";\r\n /** @constant */\r\n this.MSG_AFFECTED_CLASS = \"Affected Class=\";\r\n /** @constant */\r\n this.MSG_AFFECTED_METHOD = \"Affected Method=\";\r\n /** @constant */\r\n this.MSG_ERROR_NAME = \"Error Name=\";\r\n /** @constant */\r\n this.MSG_ERROR_MESSAGE = \"Error Message=\";\r\n /** @constant */\r\n this.MSG_SERVER_ERROR_NAME = \"Server Error Name=\";\r\n /** @constant */\r\n this.MSG_ERROR_DESC = \"Error Description=\";\r\n /** @constant */\r\n this.MSG_ERROR_NO = \"Error Number=\";\r\n /** @constant */\r\n this.MSG_ERROR_LINENO = \"Error Line Number=\";\r\n /*Errors and messages*/\r\n /** @constant */\r\n this.ERR_FORM = \"Sourceform could not be determined, either because element is not attached to a form or we have multiple forms with named elements of the same identifier or name, stopping the ajax processing\";\r\n /** @constant */\r\n this.ERR_VIEWSTATE = \"jsf.viewState= param value not of type form!\";\r\n /** @constant */\r\n this.ERR_TRANSPORT = \"Transport type {0} does not exist\";\r\n /** @constant */\r\n this.ERR_EVT_PASS = \"an event must be passed down (either a an event object null or undefined) \";\r\n /** @constant */\r\n this.ERR_CONSTRUCT = \"Parts of the response couldn't be retrieved when constructing the event data= {0} \";\r\n /** @constant */\r\n this.ERR_MALFORMEDXML = \"The server response could not be parsed, the server has returned with a response which is not xml !\";\r\n /** @constant */\r\n this.ERR_SOURCE_FUNC = \"source cannot be a function (probably source and event were not defined or set to null\";\r\n /** @constant */\r\n this.ERR_EV_OR_UNKNOWN = \"An event object or unknown must be passed as second parameter\";\r\n /** @constant */\r\n this.ERR_SOURCE_NOSTR = \"source cannot be a string\";\r\n /** @constant */\r\n this.ERR_SOURCE_DEF_NULL = \"source must be defined or null\";\r\n //_Lang.js\r\n /** @constant */\r\n this.ERR_MUST_STRING = \"{0}: {1} namespace must be of type String\";\r\n /** @constant */\r\n this.ERR_REF_OR_ID = \"{0}: {1} a reference node or identifier must be provided\";\r\n /** @constant */\r\n this.ERR_PARAM_GENERIC = \"{0}: parameter {1} must be of type {2}\";\r\n /** @constant */\r\n this.ERR_PARAM_STR = \"{0}: {1} param must be of type string\";\r\n /** @constant */\r\n this.ERR_PARAM_STR_RE = \"{0}: {1} param must be of type string or a regular expression\";\r\n /** @constant */\r\n this.ERR_PARAM_MIXMAPS = \"{0}: both a source as well as a destination map must be provided\";\r\n /** @constant */\r\n this.ERR_MUST_BE_PROVIDED = \"{0}: an {1} and a {2} must be provided\";\r\n /** @constant */\r\n this.ERR_MUST_BE_PROVIDED1 = \"{0}: {1} must be set\";\r\n /** @constant */\r\n this.ERR_REPLACE_EL = \"replaceElements called while evalNodes is not an array\";\r\n /** @constant */\r\n this.ERR_EMPTY_RESPONSE = \"{0}: The response cannot be null or empty!\";\r\n /** @constant */\r\n this.ERR_ITEM_ID_NOTFOUND = \"{0}: item with identifier {1} could not be found\";\r\n /** @constant */\r\n this.ERR_PPR_IDREQ = \"{0}: Error in PPR Insert, id must be present\";\r\n /** @constant */\r\n this.ERR_PPR_INSERTBEFID = \"{0}: Error in PPR Insert, before id or after id must be present\";\r\n /** @constant */\r\n this.ERR_PPR_INSERTBEFID_1 = \"{0}: Error in PPR Insert, before node of id {1} does not exist in document\";\r\n /** @constant */\r\n this.ERR_PPR_INSERTBEFID_2 = \"{0}: Error in PPR Insert, after node of id {1} does not exist in document\";\r\n /** @constant */\r\n this.ERR_PPR_DELID = \"{0}: Error in delete, id not in xml markup\";\r\n /** @constant */\r\n this.ERR_PPR_UNKNOWNCID = \"{0}: Unknown Html-Component-ID= {1}\";\r\n /** @constant */\r\n this.ERR_NO_VIEWROOTATTR = \"{0}: Changing of ViewRoot attributes is not supported\";\r\n /** @constant */\r\n this.ERR_NO_HEADATTR = \"{0}: Changing of Head attributes is not supported\";\r\n /** @constant */\r\n this.ERR_RED_URL = \"{0}: Redirect without url\";\r\n /** @constant */\r\n this.ERR_REQ_FAILED_UNKNOWN = \"Request failed with unknown status\";\r\n /** @constant */\r\n this.ERR_REQU_FAILED = \"Request failed with status {0} and reason {1}\";\r\n /** @constant */\r\n this.UNKNOWN = \"UNKNOWN\";\r\n }\r\n return Messages;\r\n}());\r\nexports.Messages = Messages;\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/main/typescript/impl/i18n/Messages.ts.js","sources":["webpack:///./src/main/typescript/impl/i18n/Messages.ts?923a"],"sourcesContent":["/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements.  See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License.  You may obtain a copy of the License at\r\n *\r\n *      http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\nexport class Messages {\r\n    MSG_TEST = \"Testmessage\";\r\n\r\n    /*Messages*/\r\n    /** @constant */\r\n    MSG_DEV_MODE = \"Note, this message is only sent, because project stage is development and no \" +\r\n        \"other error listeners are registered.\";\r\n    /** @constant */\r\n    MSG_AFFECTED_CLASS = \"Affected Class=\";\r\n    /** @constant */\r\n    MSG_AFFECTED_METHOD = \"Affected Method=\";\r\n    /** @constant */\r\n    MSG_ERROR_NAME = \"Error Name=\";\r\n    /** @constant */\r\n    MSG_ERROR_MESSAGE = \"Error Message=\";\r\n    /** @constant */\r\n    MSG_SERVER_ERROR_NAME = \"Server Error Name=\";\r\n\r\n    /** @constant */\r\n    MSG_ERROR_DESC = \"Error Description=\";\r\n    /** @constant */\r\n    MSG_ERROR_NO = \"Error Number=\";\r\n    /** @constant */\r\n    MSG_ERROR_LINENO = \"Error Line Number=\";\r\n\r\n    /*Errors and messages*/\r\n    /** @constant */\r\n    ERR_FORM = \"Sourceform could not be determined, either because element is not attached to a form or we have multiple forms with named elements of the same identifier or name, stopping the ajax processing\";\r\n    /** @constant */\r\n    ERR_VIEWSTATE = \"jsf.viewState= param value not of type form!\";\r\n    /** @constant */\r\n    ERR_TRANSPORT = \"Transport type {0} does not exist\";\r\n    /** @constant */\r\n    ERR_EVT_PASS = \"an event must be passed down (either a an event object null or undefined) \";\r\n    /** @constant */\r\n    ERR_CONSTRUCT = \"Parts of the response couldn't be retrieved when constructing the event data= {0} \";\r\n    /** @constant */\r\n    ERR_MALFORMEDXML = \"The server response could not be parsed, the server has returned with a response which is not xml !\";\r\n    /** @constant */\r\n    ERR_SOURCE_FUNC = \"source cannot be a function (probably source and event were not defined or set to null\";\r\n    /** @constant */\r\n    ERR_EV_OR_UNKNOWN = \"An event object or unknown must be passed as second parameter\";\r\n    /** @constant */\r\n    ERR_SOURCE_NOSTR = \"source cannot be a string\";\r\n    /** @constant */\r\n    ERR_SOURCE_DEF_NULL = \"source must be defined or null\";\r\n\r\n    //_Lang.js\r\n    /** @constant */\r\n    ERR_MUST_STRING = \"{0}: {1} namespace must be of type String\";\r\n    /** @constant */\r\n    ERR_REF_OR_ID = \"{0}: {1} a reference node or identifier must be provided\";\r\n    /** @constant */\r\n    ERR_PARAM_GENERIC = \"{0}: parameter {1} must be of type {2}\";\r\n    /** @constant */\r\n    ERR_PARAM_STR = \"{0}: {1} param must be of type string\";\r\n    /** @constant */\r\n    ERR_PARAM_STR_RE = \"{0}: {1} param must be of type string or a regular expression\";\r\n    /** @constant */\r\n    ERR_PARAM_MIXMAPS = \"{0}: both a source as well as a destination map must be provided\";\r\n    /** @constant */\r\n    ERR_MUST_BE_PROVIDED = \"{0}: an {1} and a {2} must be provided\";\r\n    /** @constant */\r\n    ERR_MUST_BE_PROVIDED1 = \"{0}: {1} must be set\";\r\n\r\n    /** @constant */\r\n    ERR_REPLACE_EL = \"replaceElements called while evalNodes is not an array\";\r\n\r\n    /** @constant */\r\n    ERR_EMPTY_RESPONSE = \"{0}: The response cannot be null or empty!\";\r\n    /** @constant */\r\n    ERR_ITEM_ID_NOTFOUND = \"{0}: item with identifier {1} could not be found\";\r\n    /** @constant */\r\n    ERR_PPR_IDREQ = \"{0}: Error in PPR Insert, id must be present\";\r\n    /** @constant */\r\n    ERR_PPR_INSERTBEFID = \"{0}: Error in PPR Insert, before id or after id must be present\";\r\n    /** @constant */\r\n    ERR_PPR_INSERTBEFID_1 = \"{0}: Error in PPR Insert, before  node of id {1} does not exist in document\";\r\n    /** @constant */\r\n    ERR_PPR_INSERTBEFID_2 = \"{0}: Error in PPR Insert, after  node of id {1} does not exist in document\";\r\n\r\n    /** @constant */\r\n    ERR_PPR_DELID = \"{0}: Error in delete, id not in xml markup\";\r\n    /** @constant */\r\n    ERR_PPR_UNKNOWNCID = \"{0}:  Unknown Html-Component-ID= {1}\";\r\n\r\n    /** @constant */\r\n    ERR_NO_VIEWROOTATTR = \"{0}: Changing of ViewRoot attributes is not supported\";\r\n    /** @constant */\r\n    ERR_NO_HEADATTR = \"{0}: Changing of Head attributes is not supported\";\r\n    /** @constant */\r\n    ERR_RED_URL = \"{0}: Redirect without url\";\r\n\r\n    /** @constant */\r\n    ERR_REQ_FAILED_UNKNOWN = \"Request failed with unknown status\";\r\n\r\n    /** @constant */\r\n    ERR_REQU_FAILED = \"Request failed with status {0} and reason {1}\";\r\n\r\n    /** @constant */\r\n    UNKNOWN = \"UNKNOWN\";\r\n}"],"mappings":";AAAA;;;;;;;;;;;;;;AAcA;;AAEA;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAAA;AAAA;AArGA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/main/typescript/impl/i18n/Messages.ts\n");
/***/ }),
/***/ "./src/main/typescript/impl/util/Assertions.ts":
/*!*****************************************************!*\
!*** ./src/main/typescript/impl/util/Assertions.ts ***!
\*****************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar monadish_1 = __webpack_require__(/*! ../../ext/monadish */ \"./src/main/typescript/ext/monadish/index.ts\");\r\nvar Const_1 = __webpack_require__(/*! ../core/Const */ \"./src/main/typescript/impl/core/Const.ts\");\r\nvar Lang_1 = __webpack_require__(/*! ./Lang */ \"./src/main/typescript/impl/util/Lang.ts\");\r\nvar getMessage = Lang_1.ExtLang.getMessage;\r\nvar makeException = Lang_1.ExtLang.makeException;\r\n/**\r\n * a set of internal code assertions\r\n * which raise an error\r\n *\r\n */\r\nvar Assertions;\r\n(function (Assertions) {\r\n function assertRequestIntegrity(options, elem) {\r\n /*assert if the onerror is set and once if it is set it must be of type function*/\r\n assertFunction(options.getIf(Const_1.Const.ON_ERROR).value);\r\n /*assert if the onevent is set and once if it is set it must be of type function*/\r\n assertFunction(options.getIf(Const_1.Const.ON_EVENT).value);\r\n //improve the error messages if an empty elem is passed\r\n //Assertions.assertElementExists(elem);\r\n assert(elem.isPresent(), getMessage(\"ERR_MUST_BE_PROVIDED1\", \"{0}: source must be provided or exist\", \"source element id\"), \"jsf.ajax.request\", \"ArgNotSet\");\r\n }\r\n Assertions.assertRequestIntegrity = assertRequestIntegrity;\r\n function assertUrlExists(node) {\r\n if (node.attr(Const_1.Const.ATTR_URL).isAbsent()) {\r\n throw Assertions.raiseError(new Error(), getMessage(\"ERR_RED_URL\", null, \"_Ajaxthis.processRedirect\"), \"processRedirect\");\r\n }\r\n }\r\n Assertions.assertUrlExists = assertUrlExists;\r\n /**\r\n * checks the xml for various issues which can occur\r\n * and prevent a proper processing\r\n */\r\n function assertValidXMLResponse(responseXML) {\r\n assert(!responseXML.isAbsent(), Const_1.Const.EMPTY_RESPONSE, Const_1.Const.PHASE_PROCESS_RESPONSE);\r\n assert(!responseXML.isXMLParserError(), responseXML.parserErrorText(\"\"), Const_1.Const.PHASE_PROCESS_RESPONSE);\r\n assert(responseXML.querySelectorAll(Const_1.Const.RESP_PARTIAL).isPresent(), Const_1.Const.ERR_NO_PARTIAL_RESPONSE, Const_1.Const.PHASE_PROCESS_RESPONSE);\r\n }\r\n Assertions.assertValidXMLResponse = assertValidXMLResponse;\r\n /**\r\n * internal helper which raises an error in the\r\n * format we need for further processing\r\n *\r\n * @param message the message\r\n * @param title the title of the error (optional)\r\n * @param name the name of the error (optional)\r\n */\r\n function raiseError(error, message, caller, title, name) {\r\n var finalTitle = (title !== null && title !== void 0 ? title : Const_1.Const.MALFORMEDXML);\r\n var finalName = (name !== null && name !== void 0 ? name : Const_1.Const.MALFORMEDXML);\r\n var finalMessage = (message !== null && message !== void 0 ? message : \"\");\r\n //TODO clean up the messy makeException, this is a perfect case for encapsulation and sane defaults\r\n return makeException(error, finalTitle, finalName, \"Response\", caller || ((arguments.caller) ? arguments.caller.toString() : \"_raiseError\"), finalMessage);\r\n }\r\n Assertions.raiseError = raiseError;\r\n /*\r\n * using the new typescript 3.7 compiler assertion functionality to improve compiler hinting\r\n * we are not fully there yet, but soon\r\n */\r\n function assert(value, msg, caller, title) {\r\n if (msg === void 0) { msg = \"\"; }\r\n if (caller === void 0) { caller = \"\"; }\r\n if (title === void 0) { title = \"Assertion Error\"; }\r\n if (!value) {\r\n throw Assertions.raiseError(new Error(), msg, caller, title);\r\n }\r\n }\r\n Assertions.assert = assert;\r\n function assertType(value, theType, msg, caller, title) {\r\n if (msg === void 0) { msg = \"\"; }\r\n if (caller === void 0) { caller = \"\"; }\r\n if (title === void 0) { title = \"Type Assertion Error\"; }\r\n if ((!!value) && !monadish_1.Lang.assertType(value, theType)) {\r\n throw Assertions.raiseError(new Error(), msg, caller, title);\r\n }\r\n }\r\n Assertions.assertType = assertType;\r\n function assertFunction(value, msg, caller, title) {\r\n if (msg === void 0) { msg = \"\"; }\r\n if (caller === void 0) { caller = \"\"; }\r\n if (title === void 0) { title = \"Assertion Error\"; }\r\n assertType(value, \"function\", msg, caller, title);\r\n }\r\n Assertions.assertFunction = assertFunction;\r\n})(Assertions = exports.Assertions || (exports.Assertions = {}));\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbWFpbi90eXBlc2NyaXB0L2ltcGwvdXRpbC9Bc3NlcnRpb25zLnRzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vLy4vc3JjL21haW4vdHlwZXNjcmlwdC9pbXBsL3V0aWwvQXNzZXJ0aW9ucy50cz9mYzQyIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29uZmlnLCBMYW5nLCBYTUxRdWVyeX0gZnJvbSBcIi4uLy4uL2V4dC9tb25hZGlzaFwiO1xyXG5pbXBvcnQge0NvbnN0fSBmcm9tIFwiLi4vY29yZS9Db25zdFwiO1xyXG5cclxuaW1wb3J0IHtEUX0gZnJvbSBcIi4uLy4uL2V4dC9tb25hZGlzaC9Eb21RdWVyeVwiO1xyXG5pbXBvcnQge0V4dExhbmd9IGZyb20gXCIuL0xhbmdcIjtcclxuaW1wb3J0IGdldE1lc3NhZ2UgPSBFeHRMYW5nLmdldE1lc3NhZ2U7XHJcbmltcG9ydCBtYWtlRXhjZXB0aW9uID0gRXh0TGFuZy5tYWtlRXhjZXB0aW9uO1xyXG5cclxuLyoqXHJcbiAqIGEgc2V0IG9mIGludGVybmFsIGNvZGUgYXNzZXJ0aW9uc1xyXG4gKiB3aGljaCByYWlzZSBhbiBlcnJvclxyXG4gKlxyXG4gKi9cclxuZXhwb3J0IG1vZHVsZSBBc3NlcnRpb25zIHtcclxuXHJcbiAgICBleHBvcnQgZnVuY3Rpb24gYXNzZXJ0UmVxdWVzdEludGVncml0eShvcHRpb25zOiBDb25maWcsIGVsZW06IERRKTogdm9pZCB8IG5ldmVyIHtcclxuICAgICAgICAvKmFzc2VydCBpZiB0aGUgb25lcnJvciBpcyBzZXQgYW5kIG9uY2UgaWYgaXQgaXMgc2V0IGl0IG11c3QgYmUgb2YgdHlwZSBmdW5jdGlvbiovXHJcbiAgICAgICAgYXNzZXJ0RnVuY3Rpb24ob3B0aW9ucy5nZXRJZihDb25zdC5PTl9FUlJPUikudmFsdWUpO1xyXG4gICAgICAgIC8qYXNzZXJ0IGlmIHRoZSBvbmV2ZW50IGlzIHNldCBhbmQgb25jZSBpZiBpdCBpcyBzZXQgaXQgbXVzdCBiZSBvZiB0eXBlIGZ1bmN0aW9uKi9cclxuICAgICAgICBhc3NlcnRGdW5jdGlvbihvcHRpb25zLmdldElmKENvbnN0Lk9OX0VWRU5UKS52YWx1ZSk7XHJcbiAgICAgICAgLy9pbXByb3ZlIHRoZSBlcnJvciBtZXNzYWdlcyBpZiBhbiBlbXB0eSBlbGVtIGlzIHBhc3NlZFxyXG4gICAgICAgIC8vQXNzZXJ0aW9ucy5hc3NlcnRFbGVtZW50RXhpc3RzKGVsZW0pO1xyXG4gICAgICAgIGFzc2VydChlbGVtLmlzUHJlc2VudCgpLCBnZXRNZXNzYWdlKFwiRVJSX01VU1RfQkVfUFJPVklERUQxXCIsIFwiezB9OiBzb3VyY2UgIG11c3QgYmUgcHJvdmlkZWQgb3IgZXhpc3RcIiwgXCJzb3VyY2UgZWxlbWVudCBpZFwiKSwgXCJqc2YuYWpheC5yZXF1ZXN0XCIsIFwiQXJnTm90U2V0XCIsICApXHJcbiAgICB9XHJcblxyXG4gICAgZXhwb3J0IGZ1bmN0aW9uIGFzc2VydFVybEV4aXN0cyhub2RlOiBYTUxRdWVyeSk6IHZvaWQgfCBuZXZlciB7XHJcbiAgICAgICAgaWYgKG5vZGUuYXR0cihDb25zdC5BVFRSX1VSTCkuaXNBYnNlbnQoKSkge1xyXG4gICAgICAgICAgICB0aHJvdyBBc3NlcnRpb25zLnJhaXNlRXJyb3IobmV3IEVycm9yKCksIGdldE1lc3NhZ2UoXCJFUlJfUkVEX1VSTFwiLCBudWxsLCBcIl9BamF4dGhpcy5wcm9jZXNzUmVkaXJlY3RcIiksIFwicHJvY2Vzc1JlZGlyZWN0XCIpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICAvKipcclxuICAgICAqIGNoZWNrcyB0aGUgeG1sIGZvciB2YXJpb3VzIGlzc3VlcyB3aGljaCBjYW4gb2NjdXJcclxuICAgICAqIGFuZCBwcmV2ZW50IGEgcHJvcGVyIHByb2Nlc3NpbmdcclxuICAgICAqL1xyXG4gICAgZXhwb3J0IGZ1bmN0aW9uIGFzc2VydFZhbGlkWE1MUmVzcG9uc2UocmVzcG9uc2VYTUw6IFhNTFF1ZXJ5KSA6IHZvaWQgfCBuZXZlciAge1xyXG4gICAgICAgIGFzc2VydCghcmVzcG9uc2VYTUwuaXNBYnNlbnQoKSwgQ29uc3QuRU1QVFlfUkVTUE9OU0UsIENvbnN0LlBIQVNFX1BST0NFU1NfUkVTUE9OU0UpO1xyXG4gICAgICAgIGFzc2VydCghcmVzcG9uc2VYTUwuaXNYTUxQYXJzZXJFcnJvcigpLCAgcmVzcG9uc2VYTUwucGFyc2VyRXJyb3JUZXh0KFwiXCIpLCBDb25zdC5QSEFTRV9QUk9DRVNTX1JFU1BPTlNFKTtcclxuICAgICAgICBhc3NlcnQocmVzcG9uc2VYTUwucXVlcnlTZWxlY3RvckFsbChDb25zdC5SRVNQX1BBUlRJQUwpLmlzUHJlc2VudCgpLCBDb25zdC5FUlJfTk9fUEFSVElBTF9SRVNQT05TRSwgQ29uc3QuUEhBU0VfUFJPQ0VTU19SRVNQT05TRSk7XHJcbiAgICB9XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBpbnRlcm5hbCBoZWxwZXIgd2hpY2ggcmFpc2VzIGFuIGVycm9yIGluIHRoZVxyXG4gICAgICogZm9ybWF0IHdlIG5lZWQgZm9yIGZ1cnRoZXIgcHJvY2Vzc2luZ1xyXG4gICAgICpcclxuICAgICAqIEBwYXJhbSBtZXNzYWdlIHRoZSBtZXNzYWdlXHJcbiAgICAgKiBAcGFyYW0gdGl0bGUgdGhlIHRpdGxlIG9mIHRoZSBlcnJvciAob3B0aW9uYWwpXHJcbiAgICAgKiBAcGFyYW0gbmFtZSB0aGUgbmFtZSBvZiB0aGUgZXJyb3IgKG9wdGlvbmFsKVxyXG4gICAgICovXHJcbiAgICBleHBvcnQgZnVuY3Rpb24gcmFpc2VFcnJvcihlcnJvcjogYW55LCBtZXNzYWdlOiBzdHJpbmcsIGNhbGxlciA/OiBzdHJpbmcsIHRpdGxlID86IHN0cmluZywgbmFtZSA/OiBzdHJpbmcpOiBFcnJvciB7XHJcblxyXG4gICAgICAgIGxldCBmaW5hbFRpdGxlID0gdGl0bGUgPz8gQ29uc3QuTUFMRk9STUVEWE1MO1xyXG4gICAgICAgIGxldCBmaW5hbE5hbWUgPSBuYW1lID8/IENvbnN0Lk1BTEZPUk1FRFhNTDtcclxuICAgICAgICBsZXQgZmluYWxNZXNzYWdlID0gbWVzc2FnZSA/PyBcIlwiO1xyXG5cclxuICAgICAgICAvL1RPRE8gY2xlYW4gdXAgdGhlIG1lc3N5IG1ha2VFeGNlcHRpb24sIHRoaXMgaXMgYSBwZXJmZWN0IGNhc2UgZm9yIGVuY2Fwc3VsYXRpb24gYW5kIHNhbmUgZGVmYXVsdHNcclxuICAgICAgICByZXR1cm4gbWFrZUV4Y2VwdGlvbihlcnJvciwgZmluYWxUaXRsZSwgZmluYWxOYW1lLCBcIlJlc3BvbnNlXCIsIGNhbGxlciB8fCAoKCg8YW55PmFyZ3VtZW50cykuY2FsbGVyKSA/ICg8YW55PmFyZ3VtZW50cykuY2FsbGVyLnRvU3RyaW5nKCkgOiBcIl9yYWlzZUVycm9yXCIpLCBmaW5hbE1lc3NhZ2UpO1xyXG4gICAgfVxyXG5cclxuICAgIC8qXHJcbiAgICAgKiB1c2luZyB0aGUgbmV3IHR5cGVzY3JpcHQgMy43IGNvbXBpbGVyIGFzc2VydGlvbiBmdW5jdGlvbmFsaXR5IHRvIGltcHJvdmUgY29tcGlsZXIgaGludGluZ1xyXG4gICAgICogd2UgYXJlIG5vdCBmdWxseSB0aGVyZSB5ZXQsIGJ1dCBzb29uXHJcbiAgICAgKi9cclxuXHJcbiAgICBleHBvcnQgZnVuY3Rpb24gYXNzZXJ0KHZhbHVlOiBhbnksIG1zZyA9IFwiXCIsIGNhbGxlcj1cIlwiLCB0aXRsZT1cIkFzc2VydGlvbiBFcnJvclwiKTogYXNzZXJ0cyB2YWx1ZSB7XHJcbiAgICAgICAgaWYoIXZhbHVlKSB7XHJcbiAgICAgICAgICAgIHRocm93IEFzc2VydGlvbnMucmFpc2VFcnJvcihuZXcgRXJyb3IoKSwgbXNnICxjYWxsZXIsIHRpdGxlKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG5cclxuICAgIGV4cG9ydCBmdW5jdGlvbiBhc3NlcnRUeXBlKHZhbHVlOiBhbnksIHRoZVR5cGU6IGFueSwgbXNnID0gXCJcIiwgY2FsbGVyPVwiXCIsIHRpdGxlPVwiVHlwZSBBc3NlcnRpb24gRXJyb3JcIik6IGFzc2VydHMgdmFsdWUge1xyXG4gICAgICAgIGlmKCghIXZhbHVlKSAmJiAhTGFuZy5hc3NlcnRUeXBlKHZhbHVlLHRoZVR5cGUpKSB7XHJcbiAgICAgICAgICAgIHRocm93IEFzc2VydGlvbnMucmFpc2VFcnJvcihuZXcgRXJyb3IoKSwgbXNnICxjYWxsZXIsIHRpdGxlKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgZXhwb3J0IGZ1bmN0aW9uIGFzc2VydEZ1bmN0aW9uKHZhbHVlOiBhbnksIG1zZyA9IFwiXCIsIGNhbGxlcj1cIlwiLCB0aXRsZT1cIkFzc2VydGlvbiBFcnJvclwiKTogYXNzZXJ0cyB2YWx1ZSBpcyBGdW5jdGlvbiB7XHJcbiAgICAgICAgYXNzZXJ0VHlwZSh2YWx1ZSwgXCJmdW5jdGlvblwiLCBtc2csIGNhbGxlciwgdGl0bGUpO1xyXG4gICAgfVxyXG59XHJcblxyXG5cclxuIl0sIm1hcHBpbmdzIjoiOztBQUFBO0FBQ0E7QUFHQTtBQUNBO0FBQ0E7QUFFQTs7OztBQUlBO0FBQ0E7QUFBQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQVJBO0FBVUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUpBO0FBTUE7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUpBO0FBTUE7Ozs7Ozs7QUFPQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBUkE7QUFVQTs7O0FBR0E7QUFFQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBSkE7QUFPQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBSkE7QUFNQTtBQUFBO0FBQUE7QUFBQTtBQUNBO0FBQ0E7QUFGQTtBQUdBOyIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/main/typescript/impl/util/Assertions.ts\n");
/***/ }),
/***/ "./src/main/typescript/impl/util/AsyncQueue.ts":
/*!*****************************************************!*\
!*** ./src/main/typescript/impl/util/AsyncQueue.ts ***!
\*****************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\n/**\r\n * Asynchronous queue which starts to work\r\n * through the callbacks until the queue is empty\r\n *\r\n * Every callback must be of async runnable\r\n * which is sort of an extended promise which has\r\n * added a decicated cancel and start point\r\n *\r\n * This interface can be used as wrapper contract\r\n * for normal promises if needed.\r\n */\r\nvar AsynchronouseQueue = /** @class */ (function () {\r\n function AsynchronouseQueue() {\r\n this.runnableQueue = [];\r\n }\r\n Object.defineProperty(AsynchronouseQueue.prototype, \"isEmpty\", {\r\n get: function () {\r\n return !this.runnableQueue.length;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * enequeues an element and starts the\r\n * asynchronous work loop if not already running\r\n *\r\n * @param element the element to be queued and processed\r\n * @param delay possible delay after our usual process or drop if something newer is incoming algorithm\r\n */\r\n AsynchronouseQueue.prototype.enqueue = function (element, delay) {\r\n var _this = this;\r\n if (delay === void 0) { delay = 0; }\r\n if (this.delayTimeout) {\r\n clearTimeout(this.delayTimeout);\r\n this.delayTimeout = null;\r\n }\r\n if (delay) {\r\n this.delayTimeout = setTimeout(function () {\r\n _this.appendElement(element);\r\n });\r\n }\r\n else {\r\n this.appendElement(element);\r\n }\r\n };\r\n AsynchronouseQueue.prototype.dequeue = function () {\r\n return this.runnableQueue.shift();\r\n };\r\n AsynchronouseQueue.prototype.cleanup = function () {\r\n this.currentlyRunning = null;\r\n this.runnableQueue.length = 0;\r\n };\r\n AsynchronouseQueue.prototype.appendElement = function (element) {\r\n //only if the first element is added we start with a trigger\r\n //otherwise a process already is running and not finished yet at that\r\n //time\r\n this.runnableQueue.push(element);\r\n if (!this.currentlyRunning) {\r\n this.runEntry();\r\n }\r\n };\r\n AsynchronouseQueue.prototype.runEntry = function () {\r\n var _this = this;\r\n if (this.isEmpty) {\r\n this.currentlyRunning = null;\r\n return;\r\n }\r\n this.currentlyRunning = this.dequeue();\r\n this.currentlyRunning\r\n .catch(function (e) {\r\n //in case of an error we always clean up the remaining calls\r\n //to allow a clean recovery of the application\r\n _this.cleanup();\r\n throw e;\r\n })\r\n .then(\r\n //the idea is to trigger the next over an event to reduce\r\n //the number of recursive calls (stacks might be limited\r\n //compared to ram)\r\n //naturally give we have a DOM, the DOM is the natural event dispatch system\r\n //which we can use, to decouple the calls from a recursive stack call\r\n //(the browser engine will take care of that)\r\n function () { return _this.callForNextElementToProcess(); }).start();\r\n };\r\n AsynchronouseQueue.prototype.cancel = function () {\r\n try {\r\n if (this.currentlyRunning) {\r\n this.currentlyRunning.cancel();\r\n }\r\n }\r\n finally {\r\n this.cleanup();\r\n }\r\n };\r\n AsynchronouseQueue.prototype.callForNextElementToProcess = function () {\r\n this.runEntry();\r\n };\r\n AsynchronouseQueue.prototype.processNextElement = function () {\r\n this.currentlyRunning = null;\r\n if (!this.isEmpty) {\r\n this.runEntry();\r\n }\r\n };\r\n AsynchronouseQueue.EVT_NEXT = \"__mf_queue_next__\";\r\n return AsynchronouseQueue;\r\n}());\r\nexports.AsynchronouseQueue = AsynchronouseQueue;\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbWFpbi90eXBlc2NyaXB0L2ltcGwvdXRpbC9Bc3luY1F1ZXVlLnRzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vLy4vc3JjL21haW4vdHlwZXNjcmlwdC9pbXBsL3V0aWwvQXN5bmNRdWV1ZS50cz84NTBmIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QXN5bmNSdW5uYWJsZX0gZnJvbSBcIi4vQXN5bmNSdW5uYWJsZVwiO1xyXG5cclxuXHJcbi8qKlxyXG4gKiBBc3luY2hyb25vdXMgcXVldWUgd2hpY2ggc3RhcnRzIHRvIHdvcmtcclxuICogdGhyb3VnaCB0aGUgY2FsbGJhY2tzIHVudGlsIHRoZSBxdWV1ZSBpcyBlbXB0eVxyXG4gKlxyXG4gKiBFdmVyeSBjYWxsYmFjayBtdXN0IGJlIG9mIGFzeW5jIHJ1bm5hYmxlXHJcbiAqIHdoaWNoIGlzIHNvcnQgb2YgYW4gZXh0ZW5kZWQgcHJvbWlzZSB3aGljaCBoYXNcclxuICogYWRkZWQgYSBkZWNpY2F0ZWQgY2FuY2VsIGFuZCBzdGFydCBwb2ludFxyXG4gKlxyXG4gKiBUaGlzIGludGVyZmFjZSBjYW4gYmUgdXNlZCBhcyB3cmFwcGVyIGNvbnRyYWN0XHJcbiAqIGZvciBub3JtYWwgcHJvbWlzZXMgaWYgbmVlZGVkLlxyXG4gKi9cclxuZXhwb3J0IGNsYXNzIEFzeW5jaHJvbm91c2VRdWV1ZTxUIGV4dGVuZHMgQXN5bmNSdW5uYWJsZTxhbnk+PiB7XHJcbiAgICBzdGF0aWMgRVZUX05FWFQgPSBcIl9fbWZfcXVldWVfbmV4dF9fXCI7XHJcblxyXG4gICAgcHJpdmF0ZSBydW5uYWJsZVF1ZXVlID0gW107XHJcbiAgICBwcml2YXRlIGRlbGF5VGltZW91dDogbnVtYmVyO1xyXG5cclxuICAgIGN1cnJlbnRseVJ1bm5pbmc6IEFzeW5jUnVubmFibGU8YW55PjtcclxuXHJcbiAgICBjb25zdHJ1Y3RvcigpIHtcclxuICAgIH1cclxuXHJcbiAgICBnZXQgaXNFbXB0eSgpOiBib29sZWFuIHtcclxuICAgICAgICByZXR1cm4gIXRoaXMucnVubmFibGVRdWV1ZS5sZW5ndGg7XHJcbiAgICB9XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBlbmVxdWV1ZXMgYW4gZWxlbWVudCBhbmQgc3RhcnRzIHRoZVxyXG4gICAgICogYXN5bmNocm9ub3VzIHdvcmsgbG9vcCBpZiBub3QgYWxyZWFkeSBydW5uaW5nXHJcbiAgICAgKlxyXG4gICAgICogQHBhcmFtIGVsZW1lbnQgdGhlIGVsZW1lbnQgdG8gYmUgcXVldWVkIGFuZCBwcm9jZXNzZWRcclxuICAgICAqIEBwYXJhbSBkZWxheSBwb3NzaWJsZSBkZWxheSBhZnRlciBvdXIgdXN1YWwgcHJvY2VzcyBvciBkcm9wIGlmIHNvbWV0aGluZyBuZXdlciBpcyBpbmNvbWluZyBhbGdvcml0aG1cclxuICAgICAqL1xyXG4gICAgZW5xdWV1ZShlbGVtZW50OiBULCBkZWxheSA9IDApIHtcclxuICAgICAgICBpZiAodGhpcy5kZWxheVRpbWVvdXQpIHtcclxuICAgICAgICAgICAgY2xlYXJUaW1lb3V0KHRoaXMuZGVsYXlUaW1lb3V0KTtcclxuICAgICAgICAgICAgdGhpcy5kZWxheVRpbWVvdXQgPSBudWxsO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAoZGVsYXkpIHtcclxuICAgICAgICAgICAgdGhpcy5kZWxheVRpbWVvdXQgPSBzZXRUaW1lb3V0KCgpID0+IHtcclxuICAgICAgICAgICAgICAgIHRoaXMuYXBwZW5kRWxlbWVudChlbGVtZW50KTtcclxuICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgICAgdGhpcy5hcHBlbmRFbGVtZW50KGVsZW1lbnQpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBkZXF1ZXVlKCk6IFQge1xyXG4gICAgICAgIHJldHVybiB0aGlzLnJ1bm5hYmxlUXVldWUuc2hpZnQoKTtcclxuICAgIH1cclxuXHJcbiAgICBjbGVhbnVwKCkge1xyXG4gICAgICAgIHRoaXMuY3VycmVudGx5UnVubmluZyA9IG51bGw7XHJcbiAgICAgICAgdGhpcy5ydW5uYWJsZVF1ZXVlLmxlbmd0aCA9IDA7XHJcbiAgICB9XHJcblxyXG4gICAgcHJpdmF0ZSBhcHBlbmRFbGVtZW50KGVsZW1lbnQ6IFQpIHtcclxuICAgICAgICAvL29ubHkgaWYgdGhlIGZpcnN0IGVsZW1lbnQgaXMgYWRkZWQgd2Ugc3RhcnQgd2l0aCBhIHRyaWdnZXJcclxuICAgICAgICAvL290aGVyd2lzZSBhIHByb2Nlc3MgYWxyZWFkeSBpcyBydW5uaW5nIGFuZCBub3QgZmluaXNoZWQgeWV0IGF0IHRoYXRcclxuICAgICAgICAvL3RpbWVcclxuICAgICAgICB0aGlzLnJ1bm5hYmxlUXVldWUucHVzaChlbGVtZW50KTtcclxuICAgICAgICBpZiAoIXRoaXMuY3VycmVudGx5UnVubmluZykge1xyXG4gICAgICAgICAgICB0aGlzLnJ1bkVudHJ5KCk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgcnVuRW50cnkoKSB7XHJcbiAgICAgICAgaWYgKHRoaXMuaXNFbXB0eSkge1xyXG4gICAgICAgICAgICB0aGlzLmN1cnJlbnRseVJ1bm5pbmcgPSBudWxsO1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHRoaXMuY3VycmVudGx5UnVubmluZyA9IHRoaXMuZGVxdWV1ZSgpO1xyXG4gICAgICAgIHRoaXMuY3VycmVudGx5UnVubmluZ1xyXG4gICAgICAgICAgICAuY2F0Y2goKGUpID0+IHtcclxuICAgICAgICAgICAgICAgIC8vaW4gY2FzZSBvZiBhbiBlcnJvciB3ZSBhbHdheXMgY2xlYW4gdXAgdGhlIHJlbWFpbmluZyBjYWxsc1xyXG4gICAgICAgICAgICAgICAgLy90byBhbGxvdyBhIGNsZWFuIHJlY292ZXJ5IG9mIHRoZSBhcHBsaWNhdGlvblxyXG4gICAgICAgICAgICAgICAgdGhpcy5jbGVhbnVwKCk7XHJcbiAgICAgICAgICAgICAgICB0aHJvdyBlO1xyXG4gICAgICAgICAgICB9KVxyXG4gICAgICAgICAgICAudGhlbihcclxuICAgICAgICAgICAgICAgIC8vdGhlIGlkZWEgaXMgdG8gdHJpZ2dlciB0aGUgbmV4dCBvdmVyIGFuIGV2ZW50IHRvIHJlZHVjZVxyXG4gICAgICAgICAgICAgICAgLy90aGUgbnVtYmVyIG9mIHJlY3Vyc2l2ZSBjYWxscyAoc3RhY2tzIG1pZ2h0IGJlIGxpbWl0ZWRcclxuICAgICAgICAgICAgICAgIC8vY29tcGFyZWQgdG8gcmFtKVxyXG4gICAgICAgICAgICAgICAgLy9uYXR1cmFsbHkgZ2l2ZSB3ZSBoYXZlIGEgRE9NLCB0aGUgRE9NIGlzIHRoZSBuYXR1cmFsIGV2ZW50IGRpc3BhdGNoIHN5c3RlbVxyXG4gICAgICAgICAgICAgICAgLy93aGljaCB3ZSBjYW4gdXNlLCB0byBkZWNvdXBsZSB0aGUgY2FsbHMgZnJvbSBhIHJlY3Vyc2l2ZSBzdGFjayBjYWxsXHJcbiAgICAgICAgICAgICAgICAvLyh0aGUgYnJvd3NlciBlbmdpbmUgd2lsbCB0YWtlIGNhcmUgb2YgdGhhdClcclxuICAgICAgICAgICAgICAgICgpID0+IHRoaXMuY2FsbEZvck5leHRFbGVtZW50VG9Qcm9jZXNzKClcclxuICAgICAgICAgICAgKS5zdGFydCgpO1xyXG4gICAgfVxyXG5cclxuICAgIGNhbmNlbCgpIHtcclxuICAgICAgICB0cnkge1xyXG4gICAgICAgICAgICBpZiAodGhpcy5jdXJyZW50bHlSdW5uaW5nKSB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLmN1cnJlbnRseVJ1bm5pbmcuY2FuY2VsKCk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9IGZpbmFsbHkge1xyXG4gICAgICAgICAgICB0aGlzLmNsZWFudXAoKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgcHJpdmF0ZSBjYWxsRm9yTmV4dEVsZW1lbnRUb1Byb2Nlc3MoKSB7XHJcbiAgICAgICAgdGhpcy5ydW5FbnRyeSgpO1xyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgcHJvY2Vzc05leHRFbGVtZW50KCkge1xyXG4gICAgICAgIHRoaXMuY3VycmVudGx5UnVubmluZyA9IG51bGw7XHJcbiAgICAgICAgaWYgKCF0aGlzLmlzRW1wdHkpIHtcclxuICAgICAgICAgICAgdGhpcy5ydW5FbnRyeSgpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbn0iXSwibWFwcGluZ3MiOiI7O0FBR0E7Ozs7Ozs7Ozs7QUFVQTtBQUNBO0FBUUE7QUFMQTtBQU1BO0FBRUE7QUFBQTtBQUNBO0FBQ0E7OztBQUFBO0FBRUE7Ozs7OztBQU1BO0FBQ0E7QUFBQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQWpHQTtBQW1HQTtBQUFBO0FBcEdBOyIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/main/typescript/impl/util/AsyncQueue.ts\n");
/***/ }),
/***/ "./src/main/typescript/impl/util/ExtDomQuery.ts":
/*!******************************************************!*\
!*** ./src/main/typescript/impl/util/ExtDomQuery.ts ***!
\******************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\nvar __extends = (this && this.__extends) || (function () {\r\n var extendStatics = function (d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n };\r\n return function (d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n };\r\n})();\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar Monad_1 = __webpack_require__(/*! ../../ext/monadish/Monad */ \"./src/main/typescript/ext/monadish/Monad.ts\");\r\nvar Const_1 = __webpack_require__(/*! ../core/Const */ \"./src/main/typescript/impl/core/Const.ts\");\r\nvar DomQuery_1 = __webpack_require__(/*! ../../ext/monadish/DomQuery */ \"./src/main/typescript/ext/monadish/DomQuery.ts\");\r\n/**\r\n * Extension which adds implementation specific\r\n * meta data to our dom qury\r\n *\r\n * Usage\r\n * el = new ExtDQ(oldReference)\r\n * nonce = el.nonce\r\n * windowId = el.getWindowId\r\n */\r\nvar ExtDomquery = /** @class */ (function (_super) {\r\n __extends(ExtDomquery, _super);\r\n function ExtDomquery() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n Object.defineProperty(ExtDomquery, \"windowId\", {\r\n get: function () {\r\n return new ExtDomquery(document.body).windowId;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ExtDomquery, \"nonce\", {\r\n get: function () {\r\n return new ExtDomquery(document.body).nonce;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ExtDomquery.prototype, \"windowId\", {\r\n get: function () {\r\n var fetchWindowIdFromURL = function () {\r\n var href = window.location.href;\r\n var windowId = \"windowId\";\r\n var regex = new RegExp(\"[\\\\?&]\" + windowId + \"=([^&#\\\\;]*)\");\r\n var results = regex.exec(href);\r\n //initial trial over the url and a regexp\r\n if (results != null)\r\n return results[1];\r\n return null;\r\n };\r\n //byId ($)\r\n if (this.value.isPresent()) {\r\n var result = this.querySelectorAll(\"form input[name='\" + Const_1.Const.P_WIN_ID + \"']\");\r\n if (result.length > 0) {\r\n throw Error(\"Multiple different windowIds found in document\");\r\n }\r\n return (result.isPresent()) ? result.getAsElem(0).value.value : fetchWindowIdFromURL();\r\n }\r\n else {\r\n return fetchWindowIdFromURL();\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(ExtDomquery.prototype, \"nonce\", {\r\n /*\r\n determines the jsfjs nonce and adds them to the namespace\r\n * this is done once and only lazily\r\n */\r\n get: function () {\r\n //already processed\r\n var myfacesConfig = new Monad_1.Config(window.myfaces);\r\n var nonce = myfacesConfig.assign(\"config\", \"cspMeta\", \"nonce\");\r\n if (nonce.value) {\r\n return nonce.value;\r\n }\r\n var curScript = new DomQuery_1.DQ(document.currentScript);\r\n //since our baseline atm is ie11 we cannot use document.currentScript globally\r\n if (curScript.attr(\"nonce\").value != null) {\r\n //fastpath for modern browsers\r\n return curScript.attr(\"nonce\").value;\r\n }\r\n var nonceScript = DomQuery_1.DQ.querySelectorAll(\"script[src], link[src]\").lazyStream\r\n .filter(function (item) { return item.attr(\"nonce\").value != null && item.attr(\"src\") != null; })\r\n .map((function (item) { return !item.attr(\"src\").value.match(/jsf\\.js\\?ln\\=javax\\.faces/gi); }))\r\n .first();\r\n if (nonceScript.isPresent()) {\r\n nonce.value = DomQuery_1.DomQuery.byId(nonceScript.value).attr(\"nonce\").value;\r\n }\r\n return nonce.value;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n ExtDomquery.searchJsfJsFor = function (item) {\r\n return new ExtDomquery(document).searchJsfJsFor(item);\r\n };\r\n ExtDomquery.prototype.searchJsfJsFor = function (rexp) {\r\n //perfect application for lazy stream\r\n return DomQuery_1.DQ.querySelectorAll(\"script\").lazyStream\r\n .filter(function (item) {\r\n var _a;\r\n return (_a = item.attr(\"src\").value, (_a !== null && _a !== void 0 ? _a : \"\")).search(/\\/javax\\.faces\\.resource.*\\/jsf\\.js.*separator/) != -1;\r\n }).map(function (item) {\r\n var result = item.attr(\"src\").value.match(rexp);\r\n return decodeURIComponent(result[1]);\r\n }).first();\r\n };\r\n ExtDomquery.prototype.globalEval = function (code, nonce) {\r\n return _super.prototype.globalEval.call(this, code, (nonce !== null && nonce !== void 0 ? nonce : this.nonce));\r\n };\r\n return ExtDomquery;\r\n}(DomQuery_1.DQ));\r\nexports.ExtDomquery = ExtDomquery;\r\nexports.ExtDQ = DomQuery_1.DQ;\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbWFpbi90eXBlc2NyaXB0L2ltcGwvdXRpbC9FeHREb21RdWVyeS50cy5qcyIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL3NyYy9tYWluL3R5cGVzY3JpcHQvaW1wbC91dGlsL0V4dERvbVF1ZXJ5LnRzP2VlYjciXSwic291cmNlc0NvbnRlbnQiOlsiXHJcbmltcG9ydCB7Q29uZmlnLCBJVmFsdWVIb2xkZXIsIE9wdGlvbmFsfSBmcm9tIFwiLi4vLi4vZXh0L21vbmFkaXNoL01vbmFkXCI7XHJcbmltcG9ydCB7Q29uc3R9IGZyb20gXCIuLi9jb3JlL0NvbnN0XCI7XHJcbmltcG9ydCB7RG9tUXVlcnksIERRfSBmcm9tIFwiLi4vLi4vZXh0L21vbmFkaXNoL0RvbVF1ZXJ5XCI7XHJcblxyXG5kZWNsYXJlIGxldCB3aW5kb3c6IGFueTtcclxuXHJcbi8qKlxyXG4gKiBFeHRlbnNpb24gd2hpY2ggYWRkcyBpbXBsZW1lbnRhdGlvbiBzcGVjaWZpY1xyXG4gKiBtZXRhIGRhdGEgdG8gb3VyIGRvbSBxdXJ5XHJcbiAqXHJcbiAqIFVzYWdlXHJcbiAqIGVsID0gbmV3IEV4dERRKG9sZFJlZmVyZW5jZSlcclxuICogbm9uY2UgPSBlbC5ub25jZVxyXG4gKiB3aW5kb3dJZCA9IGVsLmdldFdpbmRvd0lkXHJcbiAqL1xyXG5leHBvcnQgY2xhc3MgRXh0RG9tcXVlcnkgZXh0ZW5kcyBEUSB7XHJcblxyXG4gICAgc3RhdGljIGdldCB3aW5kb3dJZCgpIHtcclxuICAgICAgICByZXR1cm4gbmV3IEV4dERvbXF1ZXJ5KGRvY3VtZW50LmJvZHkpLndpbmRvd0lkO1xyXG4gICAgfVxyXG5cclxuICAgIHN0YXRpYyBnZXQgbm9uY2UoKTogc3RyaW5nIHtcclxuICAgICAgICByZXR1cm4gbmV3IEV4dERvbXF1ZXJ5KGRvY3VtZW50LmJvZHkpLm5vbmNlO1xyXG4gICAgfVxyXG5cclxuICAgIGdldCB3aW5kb3dJZCgpIHtcclxuXHJcbiAgICAgICAgY29uc3QgZmV0Y2hXaW5kb3dJZEZyb21VUkwgPSBmdW5jdGlvbiAoKSB7XHJcbiAgICAgICAgICAgIGxldCBocmVmID0gd2luZG93LmxvY2F0aW9uLmhyZWY7XHJcbiAgICAgICAgICAgIGxldCB3aW5kb3dJZCA9IFwid2luZG93SWRcIjtcclxuICAgICAgICAgICAgbGV0IHJlZ2V4ID0gbmV3IFJlZ0V4cChcIltcXFxcPyZdXCIgKyB3aW5kb3dJZCArIFwiPShbXiYjXFxcXDtdKilcIik7XHJcbiAgICAgICAgICAgIGxldCByZXN1bHRzID0gcmVnZXguZXhlYyhocmVmKTtcclxuICAgICAgICAgICAgLy9pbml0aWFsIHRyaWFsIG92ZXIgdGhlIHVybCBhbmQgYSByZWdleHBcclxuICAgICAgICAgICAgaWYgKHJlc3VsdHMgIT0gbnVsbCkgcmV0dXJuIHJlc3VsdHNbMV07XHJcbiAgICAgICAgICAgIHJldHVybiBudWxsO1xyXG4gICAgICAgIH07XHJcblxyXG4gICAgICAgIC8vYnlJZCAoJClcclxuICAgICAgICBpZiAodGhpcy52YWx1ZS5pc1ByZXNlbnQoKSkge1xyXG4gICAgICAgICAgICBsZXQgcmVzdWx0ID0gdGhpcy5xdWVyeVNlbGVjdG9yQWxsKFwiZm9ybSBpbnB1dFtuYW1lPSdcIiArIENvbnN0LlBfV0lOX0lEICsgXCInXVwiKTtcclxuICAgICAgICAgICAgaWYgKHJlc3VsdC5sZW5ndGggPiAwKSB7XHJcbiAgICAgICAgICAgICAgICB0aHJvdyBFcnJvcihcIk11bHRpcGxlIGRpZmZlcmVudCB3aW5kb3dJZHMgZm91bmQgaW4gZG9jdW1lbnRcIik7XHJcbiAgICAgICAgICAgIH1cclxuXHJcbiAgICAgICAgICAgIHJldHVybiAocmVzdWx0LmlzUHJlc2VudCgpKSA/ICg8SFRNTElucHV0RWxlbWVudD5yZXN1bHQuZ2V0QXNFbGVtKDApLnZhbHVlKS52YWx1ZSA6IGZldGNoV2luZG93SWRGcm9tVVJMKCk7XHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgICAgcmV0dXJuIGZldGNoV2luZG93SWRGcm9tVVJMKCk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuICAgIC8qXHJcbiAgICBkZXRlcm1pbmVzIHRoZSBqc2ZqcyBub25jZSBhbmQgYWRkcyB0aGVtIHRvIHRoZSBuYW1lc3BhY2VcclxuICAgICogdGhpcyBpcyBkb25lIG9uY2UgYW5kIG9ubHkgbGF6aWx5XHJcbiAgICAqL1xyXG4gICAgZ2V0IG5vbmNlKCk6IHN0cmluZyB7XHJcbiAgICAgICAgLy9hbHJlYWR5IHByb2Nlc3NlZFxyXG4gICAgICAgIGxldCBteWZhY2VzQ29uZmlnID0gbmV3IENvbmZpZyh3aW5kb3cubXlmYWNlcyk7XHJcbiAgICAgICAgbGV0IG5vbmNlOiBJVmFsdWVIb2xkZXI8c3RyaW5nPiA9IG15ZmFjZXNDb25maWcuYXNzaWduKFwiY29uZmlnXCIsIFwiY3NwTWV0YVwiLCBcIm5vbmNlXCIpO1xyXG4gICAgICAgIGlmIChub25jZS52YWx1ZSkge1xyXG4gICAgICAgICAgICByZXR1cm4gPHN0cmluZz5ub25jZS52YWx1ZTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGxldCBjdXJTY3JpcHQgPSBuZXcgRFEoZG9jdW1lbnQuY3VycmVudFNjcmlwdCk7XHJcbiAgICAgICAgLy9zaW5jZSBvdXIgYmFzZWxpbmUgYXRtIGlzIGllMTEgd2UgY2Fubm90IHVzZSBkb2N1bWVudC5jdXJyZW50U2NyaXB0IGdsb2JhbGx5XHJcbiAgICAgICAgaWYgKGN1clNjcmlwdC5hdHRyKFwibm9uY2VcIikudmFsdWUgIT0gbnVsbCkge1xyXG4gICAgICAgICAgICAvL2Zhc3RwYXRoIGZvciBtb2Rlcm4gYnJvd3NlcnNcclxuICAgICAgICAgICAgcmV0dXJuIGN1clNjcmlwdC5hdHRyKFwibm9uY2VcIikudmFsdWU7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBsZXQgbm9uY2VTY3JpcHQgPSBEUS5xdWVyeVNlbGVjdG9yQWxsKFwic2NyaXB0W3NyY10sIGxpbmtbc3JjXVwiKS5sYXp5U3RyZWFtXHJcbiAgICAgICAgICAgIC5maWx0ZXIoKGl0ZW0pID0+IGl0ZW0uYXR0cihcIm5vbmNlXCIpLnZhbHVlICE9IG51bGwgJiYgaXRlbS5hdHRyKFwic3JjXCIpICE9IG51bGwpXHJcbiAgICAgICAgICAgIC5tYXAoKGl0ZW0gPT4gIWl0ZW0uYXR0cihcInNyY1wiKS52YWx1ZS5tYXRjaCgvanNmXFwuanNcXD9sblxcPWphdmF4XFwuZmFjZXMvZ2kpKSlcclxuICAgICAgICAgICAgLmZpcnN0KCk7XHJcblxyXG4gICAgICAgIGlmIChub25jZVNjcmlwdC5pc1ByZXNlbnQoKSkge1xyXG4gICAgICAgICAgICBub25jZS52YWx1ZSA9IERvbVF1ZXJ5LmJ5SWQobm9uY2VTY3JpcHQudmFsdWUpLmF0dHIoXCJub25jZVwiKS52YWx1ZTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIDxzdHJpbmc+bm9uY2UudmFsdWU7XHJcbiAgICB9XHJcblxyXG4gICAgc3RhdGljIHNlYXJjaEpzZkpzRm9yKGl0ZW06IFJlZ0V4cCk6IE9wdGlvbmFsPFN0cmluZz4ge1xyXG4gICAgICAgIHJldHVybiBuZXcgRXh0RG9tcXVlcnkoZG9jdW1lbnQpLnNlYXJjaEpzZkpzRm9yKGl0ZW0pO1xyXG4gICAgfVxyXG5cclxuICAgIHNlYXJjaEpzZkpzRm9yKHJleHA6IFJlZ0V4cCk6IE9wdGlvbmFsPHN0cmluZz4ge1xyXG4gICAgICAgIC8vcGVyZmVjdCBhcHBsaWNhdGlvbiBmb3IgbGF6eSBzdHJlYW1cclxuICAgICAgICByZXR1cm4gRFEucXVlcnlTZWxlY3RvckFsbChcInNjcmlwdFwiKS5sYXp5U3RyZWFtXHJcbiAgICAgICAgICAgICAgICAuZmlsdGVyKGl0ZW0gPT4ge1xyXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiAoaXRlbS5hdHRyKFwic3JjXCIpLnZhbHVlID8/wqBcIlwiKS5zZWFyY2goL1xcL2phdmF4XFwuZmFjZXNcXC5yZXNvdXJjZS4qXFwvanNmXFwuanMuKnNlcGFyYXRvci8pICE9IC0xO1xyXG4gICAgICAgICAgICAgICAgfSkubWFwKChpdGVtOiBEUSkgPT4ge1xyXG4gICAgICAgICAgICAgICAgICAgIGxldCByZXN1bHQgPSBpdGVtLmF0dHIoXCJzcmNcIikudmFsdWUubWF0Y2gocmV4cCk7XHJcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIGRlY29kZVVSSUNvbXBvbmVudChyZXN1bHRbMV0pO1xyXG4gICAgICAgICAgICAgICAgfSkuZmlyc3QoKTtcclxuICAgIH1cclxuXHJcbiAgICBnbG9iYWxFdmFsKGNvZGU6IHN0cmluZywgbm9uY2UgPzogc3RyaW5nKTogRFEge1xyXG4gICAgICAgIHJldHVybiBzdXBlci5nbG9iYWxFdmFsKGNvZGUsIG5vbmNlID8/IHRoaXMubm9uY2UpO1xyXG4gICAgfVxyXG59XHJcblxyXG5leHBvcnQgY29uc3QgRXh0RFEgPSBEUTsiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7OztBQUNBO0FBQ0E7QUFDQTtBQUlBOzs7Ozs7OztBQVFBO0FBQ0E7QUFBQTtBQUFBOztBQW1GQTtBQWpGQTtBQUFBO0FBQ0E7QUFDQTs7O0FBQUE7QUFFQTtBQUFBO0FBQ0E7QUFDQTs7O0FBQUE7QUFFQTtBQUFBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFBQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQUE7QUFDQTtBQUNBO0FBQ0E7OztBQUFBO0FBTUE7QUFKQTs7O0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7O0FBQUE7QUFFQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTs7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBbkZBO0FBcUZBOyIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/main/typescript/impl/util/ExtDomQuery.ts\n");
/***/ }),
/***/ "./src/main/typescript/impl/util/Lang.ts":
/*!***********************************************!*\
!*** ./src/main/typescript/impl/util/Lang.ts ***!
\***********************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n *\r\n * todo replace singleton with module definition\r\n *\r\n */\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar Lang_1 = __webpack_require__(/*! ../../ext/monadish/Lang */ \"./src/main/typescript/ext/monadish/Lang.ts\");\r\nvar Messages_1 = __webpack_require__(/*! ../i18n/Messages */ \"./src/main/typescript/impl/i18n/Messages.ts\");\r\nvar Promise_1 = __webpack_require__(/*! ../../ext/monadish/Promise */ \"./src/main/typescript/ext/monadish/Promise.ts\");\r\nvar DomQuery_1 = __webpack_require__(/*! ../../ext/monadish/DomQuery */ \"./src/main/typescript/ext/monadish/DomQuery.ts\");\r\nvar monadish_1 = __webpack_require__(/*! ../../ext/monadish */ \"./src/main/typescript/ext/monadish/index.ts\");\r\nvar ExtLang;\r\n(function (ExtLang) {\r\n var installedLocale;\r\n var nameSpace = \"impl/util/Lang/\";\r\n /**\r\n * instead of Polyfills we rely on class\r\n * producers\r\n * @constructor\r\n */\r\n function getPromise() {\r\n return (Promise !== null && Promise !== void 0 ? Promise : Promise_1.CancellablePromise);\r\n }\r\n ExtLang.getPromise = getPromise;\r\n function getLanguage() {\r\n //TODO global config override\r\n var _a, _b, _c;\r\n var language = (_b = (_a = navigator.languages) === null || _a === void 0 ? void 0 : _a[0], (_b !== null && _b !== void 0 ? _b : (_c = navigator) === null || _c === void 0 ? void 0 : _c.language));\r\n language = language.split(\"-\")[0];\r\n return language;\r\n }\r\n ExtLang.getLanguage = getLanguage;\r\n //should be in lang, but for now here to avoid recursive imports, not sure if typescript still has a problem with those\r\n /**\r\n * helper function to savely resolve anything\r\n * this is not an elvis operator, it resolves\r\n * a value without exception in a tree and if\r\n * it is not resolvable then an optional of\r\n * a default value is restored or Optional.empty\r\n * if none is given\r\n *\r\n * usage\r\n * <code>\r\n * let var: Optional<string> = saveResolve(() => a.b.c.d.e, \"foobaz\")\r\n * </code>\r\n *\r\n * @param resolverProducer a lambda which can produce the value\r\n * @param defaultValue an optional default value if the producer failes to produce anything\r\n * @returns an Optional of the produced value\r\n */\r\n function failSaveResolve(resolverProducer, defaultValue) {\r\n if (defaultValue === void 0) { defaultValue = null; }\r\n return Lang_1.Lang.saveResolve(resolverProducer, defaultValue);\r\n }\r\n ExtLang.failSaveResolve = failSaveResolve;\r\n function failSaveExecute(resolverProducer, defaultValue) {\r\n if (defaultValue === void 0) { defaultValue = null; }\r\n Lang_1.Lang.saveResolve(resolverProducer, defaultValue);\r\n }\r\n ExtLang.failSaveExecute = failSaveExecute;\r\n /**\r\n * returns a given localized message upon a given key\r\n * basic java log like templating functionality is included\r\n *\r\n * @param {String} key the key for the message\r\n * @param {String} defaultMessage optional default message if none was found\r\n *\r\n * Additionally you can pass additional arguments, which are used\r\n * in the same way java log templates use the params\r\n *\r\n * @param templateParams the param list to be filled in\r\n */\r\n function getMessage(key, defaultMessage) {\r\n var templateParams = [];\r\n for (var _i = 2; _i < arguments.length; _i++) {\r\n templateParams[_i - 2] = arguments[_i];\r\n }\r\n var _a, _b;\r\n installedLocale = (installedLocale !== null && installedLocale !== void 0 ? installedLocale : new Messages_1.Messages());\r\n var msg = (_b = (_a = installedLocale[key], (_a !== null && _a !== void 0 ? _a : defaultMessage)), (_b !== null && _b !== void 0 ? _b : key + \" - undefined message\"));\r\n monadish_1.Stream.of.apply(monadish_1.Stream, templateParams).each(function (param, cnt) {\r\n msg = msg.replace(new RegExp([\"\\\\{\", cnt, \"\\\\}\"].join(\"\"), \"g\"), param);\r\n });\r\n return msg;\r\n }\r\n ExtLang.getMessage = getMessage;\r\n /**\r\n * transforms a key value pair into a string\r\n * @param key the key\r\n * @param val the value\r\n * @param delimiter the delimiter\r\n */\r\n function keyValToStr(key, val, delimiter) {\r\n if (delimiter === void 0) { delimiter = \"\\n\"; }\r\n return [key, val].join(delimiter);\r\n }\r\n ExtLang.keyValToStr = keyValToStr;\r\n /**\r\n * determines the correct event depending\r\n * on the browsers state\r\n *\r\n * @param evt incoming event object (note not all browsers\r\n * have this)\r\n *\r\n * @return an event object no matter what is incoming\r\n */\r\n function getEvent(evt) {\r\n var _a, _b;\r\n return _b = (evt !== null && evt !== void 0 ? evt : (_a = window) === null || _a === void 0 ? void 0 : _a.event), (_b !== null && _b !== void 0 ? _b : {});\r\n }\r\n ExtLang.getEvent = getEvent;\r\n /**\r\n * cross port from the dojo lib\r\n * browser save event resolution\r\n * @param evt the event object\r\n * (with a fallback for ie events if none is present)\r\n */\r\n function getEventTarget(evt) {\r\n var _a, _b, _c, _d, _e;\r\n //ie6 and 7 fallback\r\n evt = getEvent(evt);\r\n /**\r\n * evt source is defined in the jsf events\r\n * seems like some component authors use our code\r\n * so we add it here see also\r\n * https://issues.apache.org/jira/browse/MYFACES-2458\r\n * not entirely a bug but makes sense to add this\r\n * behavior. I dont use it that way but nevertheless it\r\n * does not break anything so why not\r\n * */\r\n var t = (_d = (_b = (_a = evt) === null || _a === void 0 ? void 0 : _a.srcElement, (_b !== null && _b !== void 0 ? _b : (_c = evt) === null || _c === void 0 ? void 0 : _c.target)), (_d !== null && _d !== void 0 ? _d : (_e = evt) === null || _e === void 0 ? void 0 : _e.source));\r\n while ((t) && (t.nodeType != 1)) {\r\n t = t.parentNode;\r\n }\r\n return t;\r\n }\r\n ExtLang.getEventTarget = getEventTarget;\r\n /**\r\n * creates an exeption with additional internal parameters\r\n * for extra information\r\n *\r\n * @param {String} title the exception title\r\n * @param {String} name the exception name\r\n * @param {String} callerCls the caller class\r\n * @param {String} callFunc the caller function\r\n * @param {String} message the message for the exception\r\n */\r\n function makeException(error, title, name, callerCls, callFunc, message) {\r\n var _a;\r\n return new Error((_a = message + ((callerCls !== null && callerCls !== void 0 ? callerCls : nameSpace)) + callFunc, (_a !== null && _a !== void 0 ? _a : (\"\" + arguments.caller.toString()))));\r\n }\r\n ExtLang.makeException = makeException;\r\n /**\r\n * fetches a global config entry\r\n * @param {String} configName the name of the configuration entry\r\n * @param {Object} defaultValue\r\n *\r\n * @return either the config entry or if none is given the default value\r\n */\r\n function getGlobalConfig(configName, defaultValue) {\r\n var _a, _b, _c, _d;\r\n /**\r\n * note we could use exists but this is an heavy operation, since the config name usually\r\n * given this function here is called very often\r\n * is a single entry without . in between we can do the lighter shortcut\r\n */\r\n return _d = (_c = (_b = (_a = window) === null || _a === void 0 ? void 0 : _a.myfaces) === null || _b === void 0 ? void 0 : _b.config) === null || _c === void 0 ? void 0 : _c[configName], (_d !== null && _d !== void 0 ? _d : defaultValue);\r\n }\r\n ExtLang.getGlobalConfig = getGlobalConfig;\r\n /**\r\n * gets the local or global options with local ones having higher priority\r\n * if no local or global one was found then the default value is given back\r\n *\r\n * @param {String} configName the name of the configuration entry\r\n * @param {String} localOptions the local options root for the configuration myfaces as default marker is added implicitely\r\n *\r\n * @param {Object} defaultValue\r\n *\r\n * @return either the config entry or if none is given the default value\r\n */\r\n function getLocalOrGlobalConfig(localOptions, configName, defaultValue) {\r\n var _a, _b, _c, _d, _e, _f, _g, _h;\r\n return _h = (_d = (_c = (_b = (_a = localOptions.value) === null || _a === void 0 ? void 0 : _a.myfaces) === null || _b === void 0 ? void 0 : _b.config) === null || _c === void 0 ? void 0 : _c[configName], (_d !== null && _d !== void 0 ? _d : (_g = (_f = (_e = window) === null || _e === void 0 ? void 0 : _e.myfaces) === null || _f === void 0 ? void 0 : _f.config) === null || _g === void 0 ? void 0 : _g[configName])), (_h !== null && _h !== void 0 ? _h : defaultValue);\r\n }\r\n ExtLang.getLocalOrGlobalConfig = getLocalOrGlobalConfig;\r\n ;\r\n /**\r\n * fetches the form in an unprecise manner depending\r\n * on an element or event target\r\n *\r\n * @param elem\r\n * @param event\r\n */\r\n function getForm(elem, event) {\r\n var FORM = \"form\";\r\n var queryElem = new DomQuery_1.DQ(elem);\r\n var eventTarget = new DomQuery_1.DQ(ExtLang.getEventTarget(event));\r\n if (queryElem.isTag(FORM)) {\r\n return queryElem;\r\n }\r\n //html 5 for handling\r\n if (queryElem.attr(FORM).isPresent()) {\r\n var formId = queryElem.attr(FORM).value;\r\n var foundForm = DomQuery_1.DQ.byId(formId);\r\n if (foundForm.isPresent()) {\r\n return foundForm;\r\n }\r\n }\r\n var form = queryElem.parents(FORM)\r\n .orElseLazy(function () { return queryElem.byTagName(FORM, true); })\r\n .orElseLazy(function () { return eventTarget.parents(FORM); })\r\n .orElseLazy(function () { return eventTarget.byTagName(FORM); })\r\n .first();\r\n assertFormExists(form);\r\n return form;\r\n }\r\n ExtLang.getForm = getForm;\r\n function assertFormExists(form) {\r\n if (form.isAbsent()) {\r\n throw makeException(new Error(), null, null, \"Impl\", \"getForm\", getMessage(\"ERR_FORM\"));\r\n }\r\n }\r\n})(ExtLang = exports.ExtLang || (exports.ExtLang = {}));\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/main/typescript/impl/util/Lang.ts.js","sources":["webpack:///./src/main/typescript/impl/util/Lang.ts?0add"],"sourcesContent":["/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements.  See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License.  You may obtain a copy of the License at\r\n *\r\n *      http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n *\r\n * todo replace singleton with module definition\r\n *\r\n */\r\n\r\nimport {Lang as LangBase} from \"../../ext/monadish/Lang\";\r\nimport {Messages} from \"../i18n/Messages\";\r\nimport {Config, Optional} from \"../../ext/monadish/Monad\";\r\nimport {CancellablePromise} from \"../../ext/monadish/Promise\";\r\nimport {DomQuery, DQ} from \"../../ext/monadish/DomQuery\";\r\nimport {Stream} from \"../../ext/monadish\";\r\n\r\n\r\nexport module ExtLang {\r\n\r\n     let installedLocale: Messages;\r\n     let nameSpace = \"impl/util/Lang/\";\r\n\r\n    /**\r\n     * instead of Polyfills we rely on class\r\n     * producers\r\n     * @constructor\r\n     */\r\n    export function getPromise(): any {\r\n        return Promise ?? CancellablePromise;\r\n    }\r\n\r\n    export function getLanguage(): string {\r\n        //TODO global config override\r\n\r\n        let language: string = (<any>navigator).languages?.[0] ?? navigator?.language;\r\n        language = language.split(\"-\")[0];\r\n        return language;\r\n    }\r\n\r\n    //should be in lang, but for now here to avoid recursive imports, not sure if typescript still has a problem with those\r\n    /**\r\n     * helper function to savely resolve anything\r\n     * this is not an elvis operator, it resolves\r\n     * a value without exception in a tree and if\r\n     * it is not resolvable then an optional of\r\n     * a default value is restored or Optional.empty\r\n     * if none is given\r\n     *\r\n     * usage\r\n     * <code>\r\n     *     let var: Optional<string> = saveResolve(() => a.b.c.d.e, \"foobaz\")\r\n     * </code>\r\n     *\r\n     * @param resolverProducer a lambda which can produce the value\r\n     * @param defaultValue an optional default value if the producer failes to produce anything\r\n     * @returns an Optional of the produced value\r\n     */\r\n    export function failSaveResolve<T>(resolverProducer: () => T, defaultValue: T = null): Optional<T> {\r\n        return LangBase.saveResolve(resolverProducer, defaultValue);\r\n    }\r\n\r\n    export function failSaveExecute<T>(resolverProducer: () => any, defaultValue: T = null): void {\r\n        LangBase.saveResolve(resolverProducer, defaultValue);\r\n    }\r\n\r\n    /**\r\n     * returns a given localized message upon a given key\r\n     * basic java log like templating functionality is included\r\n     *\r\n     * @param {String} key the key for the message\r\n     * @param {String} defaultMessage optional default message if none was found\r\n     *\r\n     * Additionally you can pass additional arguments, which are used\r\n     * in the same way java log templates use the params\r\n     *\r\n     * @param templateParams the param list to be filled in\r\n     */\r\n    export function getMessage(key: string, defaultMessage?: string, ...templateParams: Array<string>): string {\r\n        installedLocale = installedLocale ?? new Messages();\r\n\r\n        let msg = installedLocale[key] ?? defaultMessage ?? key + \" - undefined message\";\r\n\r\n        Stream.of(...templateParams).each((param, cnt) => {\r\n            msg = msg.replace(new RegExp([\"\\\\{\", cnt, \"\\\\}\"].join(\"\"), \"g\"), param);\r\n        });\r\n\r\n        return msg;\r\n    }\r\n\r\n\r\n\r\n    /**\r\n     * transforms a key value pair into a string\r\n     * @param key the key\r\n     * @param val the value\r\n     * @param delimiter the delimiter\r\n     */\r\n    export function keyValToStr(key: string, val: string, delimiter: string = \"\\n\") {\r\n        return [key, val].join(delimiter);\r\n    }\r\n\r\n    /**\r\n     * determines the correct event depending\r\n     * on the browsers state\r\n     *\r\n     * @param evt incoming event object (note not all browsers\r\n     * have this)\r\n     *\r\n     * @return an event object no matter what is incoming\r\n     */\r\n    export function getEvent(evt: Event): Event {\r\n        return evt ?? <any>window?.event ?? {};\r\n    }\r\n\r\n    /**\r\n     * cross port from the dojo lib\r\n     * browser save event resolution\r\n     * @param evt the event object\r\n     * (with a fallback for ie events if none is present)\r\n     */\r\n    export function getEventTarget(evt: Event): Element {\r\n        //ie6 and 7 fallback\r\n        evt = getEvent(evt);\r\n        /**\r\n         * evt source is defined in the jsf events\r\n         * seems like some component authors use our code\r\n         * so we add it here see also\r\n         * https://issues.apache.org/jira/browse/MYFACES-2458\r\n         * not entirely a bug but makes sense to add this\r\n         * behavior. I dont use it that way but nevertheless it\r\n         * does not break anything so why not\r\n         * */\r\n        let t = evt?.srcElement ?? evt?.target ?? (<any>evt)?.source;\r\n        while ((t) && (t.nodeType != 1)) {\r\n            t = t.parentNode;\r\n        }\r\n        return t;\r\n    }\r\n\r\n    /**\r\n     * creates an exeption with additional internal parameters\r\n     * for extra information\r\n     *\r\n     * @param {String} title the exception title\r\n     * @param {String} name  the exception name\r\n     * @param {String} callerCls the caller class\r\n     * @param {String} callFunc the caller function\r\n     * @param {String} message the message for the exception\r\n     */\r\n    export function makeException(error: Error, title: string, name: string, callerCls: string, callFunc: string, message: string): Error {\r\n\r\n        return new Error(message + (callerCls ?? nameSpace) + callFunc ?? (\"\" + (<any>arguments).caller.toString()));\r\n\r\n    }\r\n\r\n    /**\r\n     * fetches a global config entry\r\n     * @param {String} configName the name of the configuration entry\r\n     * @param {Object} defaultValue\r\n     *\r\n     * @return either the config entry or if none is given the default value\r\n     */\r\n    export function getGlobalConfig(configName: string, defaultValue: any): any {\r\n        /**\r\n         * note we could use exists but this is an heavy operation, since the config name usually\r\n         * given this function here is called very often\r\n         * is a single entry without . in between we can do the lighter shortcut\r\n         */\r\n        return (<any>window)?.myfaces?.config?.[configName] ?? defaultValue;\r\n    }\r\n\r\n    /**\r\n     * gets the local or global options with local ones having higher priority\r\n     * if no local or global one was found then the default value is given back\r\n     *\r\n     * @param {String} configName the name of the configuration entry\r\n     * @param {String} localOptions the local options root for the configuration myfaces as default marker is added implicitely\r\n     *\r\n     * @param {Object} defaultValue\r\n     *\r\n     * @return either the config entry or if none is given the default value\r\n     */\r\n    export function getLocalOrGlobalConfig(localOptions: Config, configName: string, defaultValue: any): any {\r\n        return localOptions.value?.myfaces?.config?.[configName] ??\r\n            (<any>window)?.myfaces?.config?.[configName] ??\r\n            defaultValue;\r\n    };\r\n\r\n\r\n    /**\r\n     * fetches the form in an unprecise manner depending\r\n     * on an element or event target\r\n     *\r\n     * @param elem\r\n     * @param event\r\n     */\r\n    export function getForm(elem: Element, event ?: Event): DQ | never {\r\n\r\n        const FORM = \"form\";\r\n\r\n        let queryElem = new DQ(elem);\r\n        let eventTarget = new DQ(ExtLang.getEventTarget(event));\r\n\r\n        if (queryElem.isTag(FORM)) {\r\n            return queryElem;\r\n        }\r\n\r\n        //html 5 for handling\r\n        if (queryElem.attr(FORM).isPresent()) {\r\n            let formId = queryElem.attr(FORM).value;\r\n            let foundForm = DQ.byId(formId);\r\n            if (foundForm.isPresent()) {\r\n                return foundForm;\r\n            }\r\n        }\r\n\r\n        let form = queryElem.parents(FORM)\r\n            .orElseLazy(() => queryElem.byTagName(FORM, true))\r\n            .orElseLazy(() => eventTarget.parents(FORM))\r\n            .orElseLazy(() => eventTarget.byTagName(FORM))\r\n            .first();\r\n\r\n        assertFormExists(form);\r\n\r\n        return form;\r\n    }\r\n\r\n    function assertFormExists(form: DomQuery): void | never {\r\n        if (form.isAbsent()) {\r\n            throw makeException(new Error(), null, null, \"Impl\", \"getForm\", getMessage(\"ERR_FORM\"));\r\n        }\r\n    }\r\n\r\n}"],"mappings":";AAAA;;;;;;;;;;;;;;;;;AAiBA;;AAEA;AACA;AAEA;AACA;AACA;AAGA;AAAA;AAEA;AACA;AAEA;;;;AAIA;AACA;AACA;AACA;AAFA;AAIA;AACA;;AAEA;AACA;AACA;AACA;AANA;AAQA;AACA;;;;;;;;;;;;;;;;AAgBA;AACA;AAAA;AACA;AACA;AAFA;AAIA;AAAA;AACA;AACA;AAFA;AAIA;;;;;;;;;;;AAWA;AACA;AAAA;AAAA;AAAA;;;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AAVA;AAcA;;;;;AAKA;AACA;AAAA;AACA;AACA;AAFA;AAIA;;;;;;;;AAQA;AACA;;AACA;AACA;AAFA;AAIA;;;;;AAKA;AACA;;AACA;AACA;AACA;;;;;;;;AAQA;AACA;AACA;AACA;AACA;AACA;AACA;AAjBA;AAmBA;;;;;;;;;AASA;AACA;;AAEA;AAEA;AAJA;AAMA;;;;;;AAMA;AACA;;AACA;;;;AAIA;AACA;AACA;AAPA;AASA;;;;;;;;;;AAUA;AACA;;AACA;AAGA;AAJA;AAIA;AAGA;;;;;;AAMA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AA7BA;AA+BA;AACA;AACA;AACA;AACA;AAEA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/main/typescript/impl/util/Lang.ts\n");
/***/ }),
/***/ "./src/main/typescript/impl/xhrCore/ErrorData.ts":
/*!*******************************************************!*\
!*** ./src/main/typescript/impl/xhrCore/ErrorData.ts ***!
\*******************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\nvar __extends = (this && this.__extends) || (function () {\r\n var extendStatics = function (d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n };\r\n return function (d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n };\r\n})();\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar Const_1 = __webpack_require__(/*! ../core/Const */ \"./src/main/typescript/impl/core/Const.ts\");\r\nvar EventData_1 = __webpack_require__(/*! ./EventData */ \"./src/main/typescript/impl/xhrCore/EventData.ts\");\r\nvar Lang_1 = __webpack_require__(/*! ../util/Lang */ \"./src/main/typescript/impl/util/Lang.ts\");\r\nvar getMessage = Lang_1.ExtLang.getMessage;\r\nvar SOURCE = Const_1.Const.SOURCE;\r\nvar ERROR_NAME = Const_1.Const.ERROR_NAME;\r\nvar ERROR_MESSAGE = Const_1.Const.ERROR_MESSAGE;\r\nvar STATUS = Const_1.Const.STATUS;\r\nvar RESPONSE_TEXT = Const_1.Const.RESPONSE_TEXT;\r\nvar RESPONSE_XML = Const_1.Const.RESPONSE_XML;\r\nvar ErrorType;\r\n(function (ErrorType) {\r\n ErrorType[\"SERVER_ERROR\"] = \"serverError\";\r\n ErrorType[\"HTTP_ERROR\"] = \"httpError\";\r\n ErrorType[\"CLIENT_ERROR\"] = \"clientErrror\";\r\n ErrorType[\"TIMEOUT\"] = \"timeout\";\r\n})(ErrorType = exports.ErrorType || (exports.ErrorType = {}));\r\n/**\r\n * the spec has a problem of having the error\r\n * object somewhat underspecified, there is no clear\r\n * description of the required contents.\r\n * I want to streamline it with mojarra here\r\n * hence we are going to move\r\n * everything into the same attributes,\r\n * I will add deprecated myfaces backwards compatibility attributes as well\r\n */\r\nvar ErrorData = /** @class */ (function (_super) {\r\n __extends(ErrorData, _super);\r\n function ErrorData(source, errorName, errorMessage, responseText, responseXML, responseCode, status, type) {\r\n if (responseText === void 0) { responseText = null; }\r\n if (responseXML === void 0) { responseXML = null; }\r\n if (responseCode === void 0) { responseCode = \"200\"; }\r\n if (status === void 0) { status = \"UNKNOWN\"; }\r\n if (type === void 0) { type = ErrorType.CLIENT_ERROR; }\r\n var _this = _super.call(this) || this;\r\n _this.type = \"error\";\r\n _this.source = source;\r\n _this.type = \"error\";\r\n _this.errorName = errorName;\r\n _this.message = _this.errorMessage = errorMessage;\r\n _this.responseCode = responseCode;\r\n _this.responseText = responseText;\r\n _this.status = status;\r\n _this.typeDetails = type;\r\n if (type == ErrorType.SERVER_ERROR) {\r\n _this.serverErrorName = _this.errorName;\r\n _this.serverErrorMessage = _this.errorMessage;\r\n }\r\n return _this;\r\n }\r\n ErrorData.fromClient = function (e) {\r\n return new ErrorData(\"client\", e.name, e.message, e.stack);\r\n };\r\n ErrorData.fromHttpConnection = function (source, name, message, responseText, responseCode) {\r\n return new ErrorData(source, name, message, responseText, responseCode, null, \"UNKNOWN\", ErrorType.HTTP_ERROR);\r\n };\r\n ErrorData.fromGeneric = function (context, errorCode, errorType) {\r\n var UNKNOWN = \"UNKNOWN\";\r\n var getMsg = this.getMsg;\r\n var source = getMsg(context, SOURCE);\r\n var errorName = getMsg(context, ERROR_NAME);\r\n var errorMessage = getMsg(context, ERROR_MESSAGE);\r\n var status = getMsg(context, STATUS);\r\n var responseText = getMsg(context, RESPONSE_TEXT);\r\n var responseXML = getMsg(context, RESPONSE_XML);\r\n return new ErrorData(source, name, errorMessage, responseText, responseXML, errorCode + \"\", status, ErrorType.SERVER_ERROR);\r\n };\r\n ErrorData.getMsg = function (context, param) {\r\n var UNKNOWN = \"UNKNOWN\";\r\n return getMessage(context.getIf(param).orElse(UNKNOWN).value);\r\n };\r\n ErrorData.fromServerError = function (context) {\r\n return this.fromGeneric(context, -1, ErrorType.SERVER_ERROR);\r\n };\r\n return ErrorData;\r\n}(EventData_1.EventData));\r\nexports.ErrorData = ErrorData;\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbWFpbi90eXBlc2NyaXB0L2ltcGwveGhyQ29yZS9FcnJvckRhdGEudHMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9zcmMvbWFpbi90eXBlc2NyaXB0L2ltcGwveGhyQ29yZS9FcnJvckRhdGEudHM/NTNjYiJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbnN0fSBmcm9tIFwiLi4vY29yZS9Db25zdFwiO1xyXG5pbXBvcnQge0NvbmZpZ30gZnJvbSBcIi4uLy4uL2V4dC9tb25hZGlzaFwiO1xyXG5cclxuaW1wb3J0IHtFdmVudERhdGF9IGZyb20gXCIuL0V2ZW50RGF0YVwiO1xyXG5pbXBvcnQge0V4dExhbmd9IGZyb20gXCIuLi91dGlsL0xhbmdcIjtcclxuaW1wb3J0IGdldE1lc3NhZ2UgPSBFeHRMYW5nLmdldE1lc3NhZ2U7XHJcbmltcG9ydCBTT1VSQ0UgPSBDb25zdC5TT1VSQ0U7XHJcbmltcG9ydCBFUlJPUl9OQU1FID0gQ29uc3QuRVJST1JfTkFNRTtcclxuaW1wb3J0IEVSUk9SX01FU1NBR0UgPSBDb25zdC5FUlJPUl9NRVNTQUdFO1xyXG5pbXBvcnQgU1RBVFVTID0gQ29uc3QuU1RBVFVTO1xyXG5pbXBvcnQgUkVTUE9OU0VfVEVYVCA9IENvbnN0LlJFU1BPTlNFX1RFWFQ7XHJcbmltcG9ydCBSRVNQT05TRV9YTUwgPSBDb25zdC5SRVNQT05TRV9YTUw7XHJcblxyXG5cclxuZXhwb3J0IGVudW0gRXJyb3JUeXBlIHtcclxuICAgIFNFUlZFUl9FUlJPUiA9IFwic2VydmVyRXJyb3JcIixcclxuICAgIEhUVFBfRVJST1IgPSBcImh0dHBFcnJvclwiLFxyXG4gICAgQ0xJRU5UX0VSUk9SID0gXCJjbGllbnRFcnJyb3JcIixcclxuICAgIFRJTUVPVVQgPSBcInRpbWVvdXRcIlxyXG59XHJcblxyXG4vKipcclxuICogdGhlIHNwZWMgaGFzIGEgcHJvYmxlbSBvZiBoYXZpbmcgdGhlIGVycm9yXHJcbiAqIG9iamVjdCBzb21ld2hhdCB1bmRlcnNwZWNpZmllZCwgdGhlcmUgaXMgbm8gY2xlYXJcclxuICogZGVzY3JpcHRpb24gb2YgdGhlIHJlcXVpcmVkIGNvbnRlbnRzLlxyXG4gKiBJIHdhbnQgdG8gc3RyZWFtbGluZSBpdCB3aXRoIG1vamFycmEgaGVyZVxyXG4gKiBoZW5jZSB3ZSBhcmUgZ29pbmcgdG8gbW92ZVxyXG4gKiBldmVyeXRoaW5nIGludG8gdGhlIHNhbWUgYXR0cmlidXRlcyxcclxuICogSSB3aWxsIGFkZCBkZXByZWNhdGVkIG15ZmFjZXMgYmFja3dhcmRzIGNvbXBhdGliaWxpdHkgYXR0cmlidXRlcyBhcyB3ZWxsXHJcbiAqL1xyXG5leHBvcnQgY2xhc3MgRXJyb3JEYXRhIGV4dGVuZHMgRXZlbnREYXRhIHtcclxuXHJcbiAgICB0eXBlOiBzdHJpbmcgPSBcImVycm9yXCI7XHJcbiAgICBzb3VyY2U6IHN0cmluZztcclxuICAgIGVycm9yTmFtZTogc3RyaW5nO1xyXG4gICAgZXJyb3JNZXNzYWdlOiBzdHJpbmc7XHJcblxyXG4gICAgcmVzcG9uc2VUZXh0OiBzdHJpbmc7XHJcbiAgICByZXNwb25zZVhNTDogYW55O1xyXG5cclxuICAgIHN0YXR1czogc3RyaW5nO1xyXG4gICAgdHlwZURldGFpbHM6IEVycm9yVHlwZTtcclxuXHJcbiAgICAvL1RPRE8gYmFja3dhcmRzIGNvbXBhdGlibGUgYXR0cmlidXRlc1xyXG4gICAgc2VydmVyRXJyb3JOYW1lOiBzdHJpbmc7XHJcbiAgICBzZXJ2ZXJFcnJvck1lc3NhZ2U6IHN0cmluZztcclxuICAgIG1lc3NhZ2U6IHN0cmluZztcclxuXHJcbiAgICBjb25zdHJ1Y3Rvcihzb3VyY2U6IHN0cmluZywgZXJyb3JOYW1lOiBzdHJpbmcsIGVycm9yTWVzc2FnZTogc3RyaW5nLCByZXNwb25zZVRleHQ6IHN0cmluZyA9IG51bGwsIHJlc3BvbnNlWE1MOiBhbnkgPSBudWxsLCByZXNwb25zZUNvZGU6IHN0cmluZyA9IFwiMjAwXCIsIHN0YXR1czogc3RyaW5nID0gXCJVTktOT1dOXCIsIHR5cGUgPSBFcnJvclR5cGUuQ0xJRU5UX0VSUk9SKSB7XHJcbiAgICAgICAgc3VwZXIoKTtcclxuICAgICAgICB0aGlzLnNvdXJjZSA9IHNvdXJjZTtcclxuICAgICAgICB0aGlzLnR5cGUgPSBcImVycm9yXCI7XHJcbiAgICAgICAgdGhpcy5lcnJvck5hbWUgPSBlcnJvck5hbWU7XHJcbiAgICAgICAgdGhpcy5tZXNzYWdlID0gdGhpcy5lcnJvck1lc3NhZ2UgPSBlcnJvck1lc3NhZ2U7XHJcbiAgICAgICAgdGhpcy5yZXNwb25zZUNvZGUgPSByZXNwb25zZUNvZGU7XHJcbiAgICAgICAgdGhpcy5yZXNwb25zZVRleHQgPSByZXNwb25zZVRleHQ7XHJcbiAgICAgICAgdGhpcy5zdGF0dXMgPSBzdGF0dXM7XHJcbiAgICAgICAgdGhpcy50eXBlRGV0YWlscyA9IHR5cGU7XHJcblxyXG4gICAgICAgIGlmICh0eXBlID09IEVycm9yVHlwZS5TRVJWRVJfRVJST1IpIHtcclxuICAgICAgICAgICAgdGhpcy5zZXJ2ZXJFcnJvck5hbWUgPSB0aGlzLmVycm9yTmFtZTtcclxuICAgICAgICAgICAgdGhpcy5zZXJ2ZXJFcnJvck1lc3NhZ2UgPSB0aGlzLmVycm9yTWVzc2FnZTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgc3RhdGljIGZyb21DbGllbnQoZTogRXJyb3IpOiBFcnJvckRhdGEge1xyXG4gICAgICAgIHJldHVybiBuZXcgRXJyb3JEYXRhKFwiY2xpZW50XCIsIGUubmFtZSwgZS5tZXNzYWdlLCBlLnN0YWNrKTtcclxuICAgIH1cclxuXHJcbiAgICBzdGF0aWMgZnJvbUh0dHBDb25uZWN0aW9uKHNvdXJjZTogc3RyaW5nLCBuYW1lOiBzdHJpbmcsIG1lc3NhZ2U6IHN0cmluZywgcmVzcG9uc2VUZXh0LCByZXNwb25zZUNvZGU6IG51bWJlcik6IEVycm9yRGF0YSB7XHJcbiAgICAgICAgcmV0dXJuIG5ldyBFcnJvckRhdGEoc291cmNlLCBuYW1lLCBtZXNzYWdlLCByZXNwb25zZVRleHQsIHJlc3BvbnNlQ29kZSwgbnVsbCwgXCJVTktOT1dOXCIsIEVycm9yVHlwZS5IVFRQX0VSUk9SKTtcclxuICAgIH1cclxuXHJcbiAgICBzdGF0aWMgZnJvbUdlbmVyaWMoY29udGV4dDogQ29uZmlnLCBlcnJvckNvZGU6IG51bWJlciwgZXJyb3JUeXBlOiBTdHJpbmcpOiBFcnJvckRhdGEge1xyXG5cclxuICAgICAgICBsZXQgVU5LTk9XTiA9IFwiVU5LTk9XTlwiO1xyXG4gICAgICAgIGxldCBnZXRNc2cgPSB0aGlzLmdldE1zZztcclxuXHJcbiAgICAgICAgbGV0IHNvdXJjZSA9ICBnZXRNc2coY29udGV4dCxTT1VSQ0UpO1xyXG4gICAgICAgIGxldCBlcnJvck5hbWUgPSAgZ2V0TXNnKGNvbnRleHQsRVJST1JfTkFNRSk7XHJcbiAgICAgICAgbGV0IGVycm9yTWVzc2FnZSA9ICBnZXRNc2coY29udGV4dCwgRVJST1JfTUVTU0FHRSk7XHJcbiAgICAgICAgbGV0IHN0YXR1cyA9ICBnZXRNc2coY29udGV4dCxTVEFUVVMpO1xyXG4gICAgICAgIGxldCByZXNwb25zZVRleHQgPSAgZ2V0TXNnKGNvbnRleHQsUkVTUE9OU0VfVEVYVCk7XHJcbiAgICAgICAgbGV0IHJlc3BvbnNlWE1MID0gIGdldE1zZyhjb250ZXh0LFJFU1BPTlNFX1hNTCk7XHJcbiAgICAgICAgcmV0dXJuIG5ldyBFcnJvckRhdGEoc291cmNlLCBuYW1lLCBlcnJvck1lc3NhZ2UsIHJlc3BvbnNlVGV4dCwgcmVzcG9uc2VYTUwsIGVycm9yQ29kZStcIlwiLCBzdGF0dXMsIEVycm9yVHlwZS5TRVJWRVJfRVJST1IpO1xyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgc3RhdGljIGdldE1zZyhjb250ZXh0LCBwYXJhbSkge1xyXG4gICAgICAgIGxldCBVTktOT1dOID0gXCJVTktOT1dOXCI7XHJcbiAgICAgICAgcmV0dXJuIGdldE1lc3NhZ2UoY29udGV4dC5nZXRJZihwYXJhbSkub3JFbHNlKFVOS05PV04pLnZhbHVlKTtcclxuICAgIH1cclxuXHJcbiAgICBzdGF0aWMgZnJvbVNlcnZlckVycm9yKGNvbnRleHQ6IENvbmZpZyk6IEVycm9yRGF0YSB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuZnJvbUdlbmVyaWMoY29udGV4dCwgLTEsIEVycm9yVHlwZS5TRVJWRVJfRVJST1IpO1xyXG4gICAgfVxyXG5cclxufSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFHQTtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBOzs7Ozs7OztBQVFBO0FBQ0E7QUFBQTtBQWtCQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQWhCQTtBQWtCQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7O0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFFQTtBQUVBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUNBO0FBQ0E7QUFFQTtBQUFBO0FBbEVBOyIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/main/typescript/impl/xhrCore/ErrorData.ts\n");
/***/ }),
/***/ "./src/main/typescript/impl/xhrCore/EventData.ts":
/*!*******************************************************!*\
!*** ./src/main/typescript/impl/xhrCore/EventData.ts ***!
\*******************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar monadish_1 = __webpack_require__(/*! ../../ext/monadish */ \"./src/main/typescript/ext/monadish/index.ts\");\r\nvar Const_1 = __webpack_require__(/*! ../core/Const */ \"./src/main/typescript/impl/core/Const.ts\");\r\nvar Lang_1 = __webpack_require__(/*! ../util/Lang */ \"./src/main/typescript/impl/util/Lang.ts\");\r\nvar getMessage = Lang_1.ExtLang.getMessage;\r\nvar EVENT = Const_1.Const.EVENT;\r\nvar P_PARTIAL_SOURCE = Const_1.Const.P_PARTIAL_SOURCE;\r\nvar BEGIN = Const_1.Const.BEGIN;\r\nvar CTX_PARAM_PASS_THR = Const_1.Const.CTX_PARAM_PASS_THR;\r\nvar SOURCE = Const_1.Const.SOURCE;\r\nvar EventData = /** @class */ (function () {\r\n function EventData() {\r\n }\r\n EventData.createFromRequest = function (request, context, /*event name*/ name) {\r\n var _a, _b, _c, _d;\r\n var eventData = new EventData();\r\n var UNKNOWN = getMessage(\"UNKNOWN\");\r\n eventData.type = EVENT;\r\n eventData.status = name;\r\n var sourceId = context.getIf(SOURCE)\r\n .orElse(context.getIf(P_PARTIAL_SOURCE).value)\r\n .orElse(context.getIf(CTX_PARAM_PASS_THR, P_PARTIAL_SOURCE).value).value;\r\n if (sourceId) {\r\n eventData.source = monadish_1.DQ.byId(sourceId).first().value.value;\r\n }\r\n if (name !== BEGIN) {\r\n eventData.responseCode = (_b = (_a = request) === null || _a === void 0 ? void 0 : _a.status) === null || _b === void 0 ? void 0 : _b.toString();\r\n eventData.responseText = (_c = request) === null || _c === void 0 ? void 0 : _c.responseText;\r\n eventData.responseXML = (_d = request) === null || _d === void 0 ? void 0 : _d.responseXML;\r\n }\r\n return eventData;\r\n };\r\n return EventData;\r\n}());\r\nexports.EventData = EventData;\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbWFpbi90eXBlc2NyaXB0L2ltcGwveGhyQ29yZS9FdmVudERhdGEudHMuanMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9zcmMvbWFpbi90eXBlc2NyaXB0L2ltcGwveGhyQ29yZS9FdmVudERhdGEudHM/MzNjMyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbmZpZywgRFF9IGZyb20gXCIuLi8uLi9leHQvbW9uYWRpc2hcIjtcclxuaW1wb3J0IHtDb25zdH0gZnJvbSBcIi4uL2NvcmUvQ29uc3RcIjtcclxuaW1wb3J0IHtFeHRMYW5nfSBmcm9tIFwiLi4vdXRpbC9MYW5nXCI7XHJcbmltcG9ydCBnZXRNZXNzYWdlID0gRXh0TGFuZy5nZXRNZXNzYWdlO1xyXG5pbXBvcnQgRVZFTlQgPSBDb25zdC5FVkVOVDtcclxuaW1wb3J0IFBfUEFSVElBTF9TT1VSQ0UgPSBDb25zdC5QX1BBUlRJQUxfU09VUkNFO1xyXG5pbXBvcnQgQkVHSU4gPSBDb25zdC5CRUdJTjtcclxuaW1wb3J0IENUWF9QQVJBTV9QQVNTX1RIUiA9IENvbnN0LkNUWF9QQVJBTV9QQVNTX1RIUjtcclxuaW1wb3J0IFNPVVJDRSA9IENvbnN0LlNPVVJDRTtcclxuXHJcbmV4cG9ydCBjbGFzcyBFdmVudERhdGEge1xyXG4gICAgdHlwZTogc3RyaW5nO1xyXG4gICAgc3RhdHVzOiBzdHJpbmc7XHJcbiAgICBzb3VyY2U6IGFueTtcclxuICAgIHJlc3BvbnNlQ29kZTogc3RyaW5nO1xyXG4gICAgcmVzcG9uc2VUZXh0OiBzdHJpbmc7XHJcbiAgICByZXNwb25zZVhNTDogRG9jdW1lbnQ7XHJcblxyXG4gICAgc3RhdGljIGNyZWF0ZUZyb21SZXF1ZXN0KHJlcXVlc3Q6IFhNTEh0dHBSZXF1ZXN0LCBjb250ZXh0OiBDb25maWcsIC8qZXZlbnQgbmFtZSovIG5hbWU6IHN0cmluZyk6IEV2ZW50RGF0YSB7XHJcblxyXG4gICAgICAgIGxldCBldmVudERhdGEgPSBuZXcgRXZlbnREYXRhKCk7XHJcbiAgICAgICAgbGV0IFVOS05PV04gPSBnZXRNZXNzYWdlKFwiVU5LTk9XTlwiKTtcclxuXHJcbiAgICAgICAgZXZlbnREYXRhLnR5cGUgPSBFVkVOVDtcclxuICAgICAgICBldmVudERhdGEuc3RhdHVzID0gbmFtZTtcclxuXHJcbiAgICAgICAgbGV0IHNvdXJjZUlkOiBzdHJpbmcgPSBjb250ZXh0LmdldElmKFNPVVJDRSlcclxuICAgICAgICAgICAgLm9yRWxzZShjb250ZXh0LmdldElmKFBfUEFSVElBTF9TT1VSQ0UpLnZhbHVlKVxyXG4gICAgICAgICAgICAub3JFbHNlKGNvbnRleHQuZ2V0SWYoQ1RYX1BBUkFNX1BBU1NfVEhSLCBQX1BBUlRJQUxfU09VUkNFKS52YWx1ZSkudmFsdWU7XHJcbiAgICAgICAgaWYoc291cmNlSWQpIHtcclxuICAgICAgICAgICAgZXZlbnREYXRhLnNvdXJjZSA9IERRLmJ5SWQoc291cmNlSWQpLmZpcnN0KCkudmFsdWUudmFsdWU7XHJcbiAgICAgICAgfVxyXG5cclxuXHJcbiAgICAgICAgaWYgKG5hbWUgIT09IEJFR0lOKSB7XHJcbiAgICAgICAgICAgIGV2ZW50RGF0YS5yZXNwb25zZUNvZGUgPSByZXF1ZXN0Py5zdGF0dXM/LnRvU3RyaW5nKCk7XHJcbiAgICAgICAgICAgIGV2ZW50RGF0YS5yZXNwb25zZVRleHQgPSByZXF1ZXN0Py5yZXNwb25zZVRleHQ7XHJcbiAgICAgICAgICAgIGV2ZW50RGF0YS5yZXNwb25zZVhNTCA9IHJlcXVlc3Q/LnJlc3BvbnNlWE1MO1xyXG4gICAgICAgIH1cclxuICAgICAgICByZXR1cm4gZXZlbnREYXRhO1xyXG4gICAgfVxyXG59XHJcbiJdLCJtYXBwaW5ncyI6Ijs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTtBQUFBO0FBK0JBO0FBdkJBOztBQUVBO0FBQ0E7QUFFQTtBQUNBO0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUFBO0FBL0JBOyIsInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///./src/main/typescript/impl/xhrCore/EventData.ts\n");
/***/ }),
/***/ "./src/main/typescript/impl/xhrCore/ResonseDataResolver.ts":
/*!*****************************************************************!*\
!*** ./src/main/typescript/impl/xhrCore/ResonseDataResolver.ts ***!
\*****************************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar monadish_1 = __webpack_require__(/*! ../../ext/monadish */ \"./src/main/typescript/ext/monadish/index.ts\");\r\nvar Const_1 = __webpack_require__(/*! ../core/Const */ \"./src/main/typescript/impl/core/Const.ts\");\r\nvar Assertions_1 = __webpack_require__(/*! ../util/Assertions */ \"./src/main/typescript/impl/util/Assertions.ts\");\r\nvar DomQuery_1 = __webpack_require__(/*! ../../ext/monadish/DomQuery */ \"./src/main/typescript/ext/monadish/DomQuery.ts\");\r\nvar CTX_PARAM_SRC_FRM_ID = Const_1.Const.CTX_PARAM_SRC_FRM_ID;\r\nvar TAG_FORM = Const_1.Const.TAG_FORM;\r\nvar CTX_PARAM_SRC_CTL_ID = Const_1.Const.CTX_PARAM_SRC_CTL_ID;\r\nvar SOURCE = Const_1.Const.SOURCE;\r\nvar CTX_PARAM_MF_INTERNAL = Const_1.Const.CTX_PARAM_MF_INTERNAL;\r\nvar UPDATE_FORMS = Const_1.Const.UPDATE_FORMS;\r\nvar UPDATE_ELEMS = Const_1.Const.UPDATE_ELEMS;\r\nvar SEL_RESPONSE_XML = Const_1.Const.SEL_RESPONSE_XML;\r\n/**\r\n * Resolver for various aspects of the response data\r\n *\r\n * stateless because it might be called from various\r\n * parts of the response classes\r\n */\r\nvar ResonseDataResolver;\r\n(function (ResonseDataResolver) {\r\n /**\r\n * fetches the response XML\r\n * as XML Query object\r\n *\r\n * @param request the request hosting the responseXML\r\n *\r\n * Throws an error in case of non existent or wrong xml data\r\n *\r\n */\r\n function resolveResponseXML(request) {\r\n var ret = new monadish_1.XMLQuery(request.getIf(SEL_RESPONSE_XML).value);\r\n Assertions_1.Assertions.assertValidXMLResponse(ret);\r\n return ret;\r\n }\r\n ResonseDataResolver.resolveResponseXML = resolveResponseXML;\r\n /**\r\n * Splits the incoming passthrough context apart\r\n * in an internal and an external nomalized context\r\n * the internal one is just for our internal processing\r\n *\r\n * @param context the root context as associative array\r\n */\r\n function resolveContexts(context) {\r\n /**\r\n * we split the context apart into the external one and\r\n * some internal values\r\n */\r\n var externalContext = monadish_1.Config.fromNullable(context);\r\n var internalContext = externalContext.getIf(CTX_PARAM_MF_INTERNAL);\r\n if (!internalContext.isPresent()) {\r\n internalContext = monadish_1.Config.fromNullable({});\r\n }\r\n /**\r\n * prepare storage for some deferred operations\r\n */\r\n internalContext.assign(UPDATE_FORMS).value = [];\r\n internalContext.assign(UPDATE_ELEMS).value = [];\r\n return { externalContext: externalContext, internalContext: internalContext };\r\n }\r\n ResonseDataResolver.resolveContexts = resolveContexts;\r\n /**\r\n * fetches the source element out of our conexts\r\n *\r\n * @param context the external context which shpuld host the source id\r\n * @param internalContext internal passthrough fall back\r\n *\r\n */\r\n function resolveSourceElement(context, internalContext) {\r\n var elemId = resolveSourceElementId(context, internalContext);\r\n var elem = DomQuery_1.DQ.byId(elemId.value);\r\n return elem;\r\n }\r\n ResonseDataResolver.resolveSourceElement = resolveSourceElement;\r\n /**\r\n * fetches the source form if it still exists\r\n * also embedded forms and parent forms are taken into consideration\r\n * as fallbacks\r\n *\r\n * @param internalContext\r\n * @param elem\r\n */\r\n function resolveSourceForm(internalContext, elem) {\r\n var sourceFormId = internalContext.getIf(CTX_PARAM_SRC_FRM_ID);\r\n var sourceForm = new DomQuery_1.DQ(sourceFormId.isPresent() ? document.forms[sourceFormId.value] : null);\r\n sourceForm = sourceForm.orElse(elem.parents(TAG_FORM))\r\n .orElse(elem.querySelectorAll(TAG_FORM))\r\n .orElse(DomQuery_1.DQ.querySelectorAll(TAG_FORM));\r\n return sourceForm;\r\n }\r\n ResonseDataResolver.resolveSourceForm = resolveSourceForm;\r\n function resolveSourceElementId(context, internalContext) {\r\n //?internal context?? used to be external one\r\n return internalContext.getIf(CTX_PARAM_SRC_CTL_ID)\r\n .orElseLazy(function () { return context.getIf(SOURCE, \"id\").value; });\r\n }\r\n})(ResonseDataResolver = exports.ResonseDataResolver || (exports.ResonseDataResolver = {}));\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvbWFpbi90eXBlc2NyaXB0L2ltcGwveGhyQ29yZS9SZXNvbnNlRGF0YVJlc29sdmVyLnRzLmpzIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vLy4vc3JjL21haW4vdHlwZXNjcmlwdC9pbXBsL3hockNvcmUvUmVzb25zZURhdGFSZXNvbHZlci50cz84Njg3Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIExpY2Vuc2VkIHRvIHRoZSBBcGFjaGUgU29mdHdhcmUgRm91bmRhdGlvbiAoQVNGKSB1bmRlciBvbmUgb3IgbW9yZVxyXG4gKiBjb250cmlidXRvciBsaWNlbnNlIGFncmVlbWVudHMuICBTZWUgdGhlIE5PVElDRSBmaWxlIGRpc3RyaWJ1dGVkIHdpdGhcclxuICogdGhpcyB3b3JrIGZvciBhZGRpdGlvbmFsIGluZm9ybWF0aW9uIHJlZ2FyZGluZyBjb3B5cmlnaHQgb3duZXJzaGlwLlxyXG4gKiBUaGUgQVNGIGxpY2Vuc2VzIHRoaXMgZmlsZSB0byB5b3UgdW5kZXIgdGhlIEFwYWNoZSBMaWNlbnNlLCBWZXJzaW9uIDIuMFxyXG4gKiAodGhlIFwiTGljZW5zZVwiKTsgeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoXHJcbiAqIHRoZSBMaWNlbnNlLiAgWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XHJcbiAqXHJcbiAqICAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXHJcbiAqXHJcbiAqIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcclxuICogZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIEJBU0lTLFxyXG4gKiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cclxuICogU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxyXG4gKiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cclxuICovXHJcblxyXG5pbXBvcnQge0NvbmZpZywgT3B0aW9uYWwsIFhNTFF1ZXJ5fSBmcm9tIFwiLi4vLi4vZXh0L21vbmFkaXNoXCI7XHJcbmltcG9ydCB7Q29uc3R9IGZyb20gXCIuLi9jb3JlL0NvbnN0XCI7XHJcbmltcG9ydCB7QXNzZXJ0aW9uc30gZnJvbSBcIi4uL3V0aWwvQXNzZXJ0aW9uc1wiO1xyXG5pbXBvcnQge0RRfSBmcm9tIFwiLi4vLi4vZXh0L21vbmFkaXNoL0RvbVF1ZXJ5XCI7XHJcbmltcG9ydCBDVFhfUEFSQU1fU1JDX0ZSTV9JRCA9IENvbnN0LkNUWF9QQVJBTV9TUkNfRlJNX0lEO1xyXG5pbXBvcnQgVEFHX0ZPUk0gPSBDb25zdC5UQUdfRk9STTtcclxuaW1wb3J0IENUWF9QQVJBTV9TUkNfQ1RMX0lEID0gQ29uc3QuQ1RYX1BBUkFNX1NSQ19DVExfSUQ7XHJcbmltcG9ydCBTT1VSQ0UgPSBDb25zdC5TT1VSQ0U7XHJcbmltcG9ydCBDVFhfUEFSQU1fTUZfSU5URVJOQUwgPSBDb25zdC5DVFhfUEFSQU1fTUZfSU5URVJOQUw7XHJcbmltcG9ydCBVUERBVEVfRk9STVMgPSBDb25zdC5VUERBVEVfRk9STVM7XHJcbmltcG9ydCBVUERBVEVfRUxFTVMgPSBDb25zdC5VUERBVEVfRUxFTVM7XHJcbmltcG9ydCBTRUxfUkVTUE9OU0VfWE1MID0gQ29uc3QuU0VMX1JFU1BPTlNFX1hNTDtcclxuXHJcbi8qKlxyXG4gKiBSZXNvbHZlciBmb3IgdmFyaW91cyBhc3BlY3RzIG9mIHRoZSByZXNwb25zZSBkYXRhXHJcbiAqXHJcbiAqIHN0YXRlbGVzcyBiZWNhdXNlIGl0IG1pZ2h0IGJlIGNhbGxlZCBmcm9tIHZhcmlvdXNcclxuICogcGFydHMgb2YgdGhlIHJlc3BvbnNlIGNsYXNzZXNcclxuICovXHJcbmV4cG9ydCBtb2R1bGUgUmVzb25zZURhdGFSZXNvbHZlciB7XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBmZXRjaGVzIHRoZSByZXNwb25zZSBYTUxcclxuICAgICAqIGFzIFhNTCBRdWVyeSBvYmplY3RcclxuICAgICAqXHJcbiAgICAgKiBAcGFyYW0gcmVxdWVzdCB0aGUgcmVxdWVzdCBob3N0aW5nIHRoZSByZXNwb25zZVhNTFxyXG4gICAgICpcclxuICAgICAqIFRocm93cyBhbiBlcnJvciBpbiBjYXNlIG9mIG5vbiBleGlzdGVudCBvciB3cm9uZyB4bWwgZGF0YVxyXG4gICAgICpcclxuICAgICAqL1xyXG4gICAgZXhwb3J0IGZ1bmN0aW9uIHJlc29sdmVSZXNwb25zZVhNTChyZXF1ZXN0OiBDb25maWcpOiBYTUxRdWVyeSB7XHJcbiAgICAgICAgbGV0IHJldCA9IG5ldyBYTUxRdWVyeShyZXF1ZXN0LmdldElmKFNFTF9SRVNQT05TRV9YTUwpLnZhbHVlKTtcclxuICAgICAgICBBc3NlcnRpb25zLmFzc2VydFZhbGlkWE1MUmVzcG9uc2UocmV0KTtcclxuXHJcbiAgICAgICAgcmV0dXJuIHJldDtcclxuICAgIH1cclxuXHJcbiAgICAvKipcclxuICAgICAqIFNwbGl0cyB0aGUgaW5jb21pbmcgcGFzc3Rocm91Z2ggY29udGV4dCBhcGFydFxyXG4gICAgICogaW4gYW4gaW50ZXJuYWwgYW5kIGFuIGV4dGVybmFsIG5vbWFsaXplZCBjb250ZXh0XHJcbiAgICAgKiB0aGUgaW50ZXJuYWwgb25lIGlzIGp1c3QgZm9yIG91ciBpbnRlcm5hbCBwcm9jZXNzaW5nXHJcbiAgICAgKlxyXG4gICAgICogQHBhcmFtIGNvbnRleHQgdGhlIHJvb3QgY29udGV4dCBhcyBhc3NvY2lhdGl2ZSBhcnJheVxyXG4gICAgICovXHJcbiAgICBleHBvcnQgZnVuY3Rpb24gcmVzb2x2ZUNvbnRleHRzKGNvbnRleHQ6IHsgW3A6IHN0cmluZ106IGFueSB9KTogYW55IHtcclxuICAgICAgICAvKipcclxuICAgICAgICAgKiB3ZSBzcGxpdCB0aGUgY29udGV4dCBhcGFydCBpbnRvIHRoZSBleHRlcm5hbCBvbmUgYW5kXHJcbiAgICAgICAgICogc29tZSBpbnRlcm5hbCB2YWx1ZXNcclxuICAgICAgICAgKi9cclxuICAgICAgICBsZXQgZXh0ZXJuYWxDb250ZXh0ID0gQ29uZmlnLmZyb21OdWxsYWJsZShjb250ZXh0KTtcclxuICAgICAgICBsZXQgaW50ZXJuYWxDb250ZXh0ID0gZXh0ZXJuYWxDb250ZXh0LmdldElmKENUWF9QQVJBTV9NRl9JTlRFUk5BTCk7XHJcbiAgICAgICAgaWYoIWludGVybmFsQ29udGV4dC5pc1ByZXNlbnQoKSkge1xyXG4gICAgICAgICAgICBpbnRlcm5hbENvbnRleHQgPSBDb25maWcuZnJvbU51bGxhYmxlKHt9KTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIC8qKlxyXG4gICAgICAgICAqIHByZXBhcmUgc3RvcmFnZSBmb3Igc29tZSBkZWZlcnJlZCBvcGVyYXRpb25zXHJcbiAgICAgICAgICovXHJcbiAgICAgICAgaW50ZXJuYWxDb250ZXh0LmFzc2lnbihVUERBVEVfRk9STVMpLnZhbHVlID0gW107XHJcbiAgICAgICAgaW50ZXJuYWxDb250ZXh0LmFzc2lnbihVUERBVEVfRUxFTVMpLnZhbHVlID0gW107XHJcbiAgICAgICAgcmV0dXJuIHtleHRlcm5hbENvbnRleHQsIGludGVybmFsQ29udGV4dH07XHJcbiAgICB9XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBmZXRjaGVzIHRoZSBzb3VyY2UgZWxlbWVudCBvdXQgb2Ygb3VyIGNvbmV4dHNcclxuICAgICAqXHJcbiAgICAgKiBAcGFyYW0gY29udGV4dCB0aGUgZXh0ZXJuYWwgY29udGV4dCB3aGljaCBzaHB1bGQgaG9zdCB0aGUgc291cmNlIGlkXHJcbiAgICAgKiBAcGFyYW0gaW50ZXJuYWxDb250ZXh0IGludGVybmFsIHBhc3N0aHJvdWdoIGZhbGwgYmFja1xyXG4gICAgICpcclxuICAgICAqL1xyXG4gICAgZXhwb3J0IGZ1bmN0aW9uIHJlc29sdmVTb3VyY2VFbGVtZW50KGNvbnRleHQ6IENvbmZpZywgaW50ZXJuYWxDb250ZXh0OiBDb25maWcpOiBEUSB7XHJcbiAgICAgICAgbGV0IGVsZW1JZCA9IHJlc29sdmVTb3VyY2VFbGVtZW50SWQoY29udGV4dCwgaW50ZXJuYWxDb250ZXh0KTtcclxuICAgICAgICBsZXQgZWxlbSA9IERRLmJ5SWQoZWxlbUlkLnZhbHVlKTtcclxuICAgICAgICByZXR1cm4gZWxlbTtcclxuICAgIH1cclxuXHJcbiAgICAvKipcclxuICAgICAqIGZldGNoZXMgdGhlIHNvdXJjZSBmb3JtIGlmIGl0IHN0aWxsIGV4aXN0c1xyXG4gICAgICogYWxzbyBlbWJlZGRlZCBmb3JtcyBhbmQgcGFyZW50IGZvcm1zIGFyZSB0YWtlbiBpbnRvIGNvbnNpZGVyYXRpb25cclxuICAgICAqIGFzIGZhbGxiYWNrc1xyXG4gICAgICpcclxuICAgICAqIEBwYXJhbSBpbnRlcm5hbENvbnRleHRcclxuICAgICAqIEBwYXJhbSBlbGVtXHJcbiAgICAgKi9cclxuICAgIGV4cG9ydCBmdW5jdGlvbiByZXNvbHZlU291cmNlRm9ybShpbnRlcm5hbENvbnRleHQ6IENvbmZpZywgZWxlbTogRFEpOiBEUSB7XHJcbiAgICAgICAgbGV0IHNvdXJjZUZvcm1JZCA9IGludGVybmFsQ29udGV4dC5nZXRJZihDVFhfUEFSQU1fU1JDX0ZSTV9JRCk7XHJcbiAgICAgICAgbGV0IHNvdXJjZUZvcm0gPSBuZXcgRFEoc291cmNlRm9ybUlkLmlzUHJlc2VudCgpID8gZG9jdW1lbnQuZm9ybXNbc291cmNlRm9ybUlkLnZhbHVlXSA6IG51bGwpO1xyXG5cclxuICAgICAgICBzb3VyY2VGb3JtID0gc291cmNlRm9ybS5vckVsc2UoZWxlbS5wYXJlbnRzKFRBR19GT1JNKSlcclxuICAgICAgICAgICAgLm9yRWxzZShlbGVtLnF1ZXJ5U2VsZWN0b3JBbGwoVEFHX0ZPUk0pKVxyXG4gICAgICAgICAgICAub3JFbHNlKERRLnF1ZXJ5U2VsZWN0b3JBbGwoVEFHX0ZPUk0pKTtcclxuXHJcbiAgICAgICAgcmV0dXJuIHNvdXJjZUZvcm07XHJcbiAgICB9XHJcblxyXG5cclxuICAgIGZ1bmN0aW9uIHJlc29sdmVTb3VyY2VFbGVtZW50SWQoY29udGV4dDogQ29uZmlnLCBpbnRlcm5hbENvbnRleHQ6IENvbmZpZyk6IE9wdGlvbmFsPHN0cmluZz4ge1xyXG4gICAgICAgIC8vP2ludGVybmFsIGNvbnRleHQ/PyB1c2VkIHRvIGJlIGV4dGVybmFsIG9uZVxyXG4gICAgICAgIHJldHVybiBpbnRlcm5hbENvbnRleHQuZ2V0SWYoQ1RYX1BBUkFNX1NSQ19DVExfSUQpXHJcbiAgICAgICAgICAgIC5vckVsc2VMYXp5KCgpID0+IGNvbnRleHQuZ2V0SWYoU09VUkNFLCBcImlkXCIpLnZhbHVlKTtcclxuICAgIH1cclxuXHJcbn0iXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7Ozs7Ozs7Ozs7QUFjQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTs7Ozs7QUFLQTtBQUNBO0FBQUE7QUFFQTs7Ozs7Ozs7QUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFMQTtBQU9BOzs7Ozs7QUFNQTtBQUNBO0FBQ0E7OztBQUdBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUVBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFqQkE7QUFtQkE7Ozs7OztBQU1BO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUpBO0FBTUE7Ozs7Ozs7QUFPQTtBQUNBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFDQTtBQUVBO0FBQ0E7QUFUQTtBQVlBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFFQTsiLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/main/typescript/impl/xhrCore/ResonseDataResolver.ts\n");
/***/ }),
/***/ "./src/main/typescript/impl/xhrCore/Response.ts":
/*!******************************************************!*\
!*** ./src/main/typescript/impl/xhrCore/Response.ts ***!
\******************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar monadish_1 = __webpack_require__(/*! ../../ext/monadish */ \"./src/main/typescript/ext/monadish/index.ts\");\r\nvar Const_1 = __webpack_require__(/*! ../core/Const */ \"./src/main/typescript/impl/core/Const.ts\");\r\nvar ResponseProcessor_1 = __webpack_require__(/*! ./ResponseProcessor */ \"./src/main/typescript/impl/xhrCore/ResponseProcessor.ts\");\r\nvar ResonseDataResolver_1 = __webpack_require__(/*! ./ResonseDataResolver */ \"./src/main/typescript/impl/xhrCore/ResonseDataResolver.ts\");\r\nvar RESPONSE_XML = Const_1.Const.RESPONSE_XML;\r\nvar RESP_PARTIAL = Const_1.Const.RESP_PARTIAL;\r\nvar PARTIAL_ID = Const_1.Const.PARTIAL_ID;\r\nvar CMD_ERROR = Const_1.Const.CMD_ERROR;\r\nvar CMD_REDIRECT = Const_1.Const.CMD_REDIRECT;\r\nvar CMD_CHANGES = Const_1.Const.CMD_CHANGES;\r\nvar CMD_UPDATE = Const_1.Const.CMD_UPDATE;\r\nvar CMD_EVAL = Const_1.Const.CMD_EVAL;\r\nvar CMD_INSERT = Const_1.Const.CMD_INSERT;\r\nvar CMD_DELETE = Const_1.Const.CMD_DELETE;\r\nvar CMD_ATTRIBUTES = Const_1.Const.CMD_ATTRIBUTES;\r\nvar CMD_EXTENSION = Const_1.Const.CMD_EXTENSION;\r\nvar P_VIEWROOT = Const_1.Const.P_VIEWROOT;\r\nvar P_VIEWHEAD = Const_1.Const.P_VIEWHEAD;\r\nvar P_VIEWBODY = Const_1.Const.P_VIEWBODY;\r\nvar Response;\r\n(function (Response) {\r\n var resolveResponseXML = ResonseDataResolver_1.ResonseDataResolver.resolveResponseXML;\r\n var resolveContexts = ResonseDataResolver_1.ResonseDataResolver.resolveContexts;\r\n var TAG_BEFORE = Const_1.Const.TAG_BEFORE;\r\n var TAG_AFTER = Const_1.Const.TAG_AFTER;\r\n /**\r\n * Standardized jsf.js response\r\n * this one is called straight from jsf.js.response\r\n *\r\n * The processing follows the spec by going for the responseXML\r\n * and processing its tags\r\n *\r\n * @param {XMLHttpRequest} request (xhrRequest) - xhr request object\r\n * @param {[key: string]: any} context (Map) - AJAX context\r\n *\r\n */\r\n function processResponse(request, context) {\r\n var req = monadish_1.Config.fromNullable(request);\r\n var _a = resolveContexts(context), externalContext = _a.externalContext, internalContext = _a.internalContext;\r\n var responseXML = resolveResponseXML(req);\r\n var responseProcessor = new ResponseProcessor_1.ResponseProcessor(req, externalContext, internalContext);\r\n internalContext.assign(RESPONSE_XML).value = responseXML;\r\n //we now process the partial tags, or in none given raise an error\r\n responseXML.querySelectorAll(RESP_PARTIAL)\r\n .each(function (item) { return processPartialTag(item, responseProcessor, internalContext); });\r\n //we now process the viewstates and the evals deferred\r\n //the reason for this is that often it is better\r\n //to wait until the document has caught up before\r\n //doing any evals even on embedded scripts\r\n responseProcessor.fixViewStates();\r\n responseProcessor.globalEval();\r\n responseProcessor.done();\r\n }\r\n Response.processResponse = processResponse;\r\n /**\r\n * highest node partial-response from there the main operations are triggered\r\n */\r\n function processPartialTag(node, responseProcessor, internalContext) {\r\n internalContext.assign(PARTIAL_ID).value = node.id;\r\n var SEL_SUB_TAGS = [CMD_ERROR, CMD_REDIRECT, CMD_CHANGES].join(\",\");\r\n //now we can process the main operations\r\n node.getIf(SEL_SUB_TAGS).each(function (node) {\r\n switch (node.tagName.value) {\r\n case CMD_ERROR:\r\n responseProcessor.error(node);\r\n break;\r\n case CMD_REDIRECT:\r\n responseProcessor.redirect(node);\r\n break;\r\n case CMD_CHANGES:\r\n processChangesTag(node, responseProcessor);\r\n break;\r\n }\r\n });\r\n }\r\n var processInsert = function (responseProcessor, node) {\r\n //path1 insert after as child tags\r\n if (node.querySelectorAll([TAG_BEFORE, TAG_AFTER].join(\",\")).length) {\r\n responseProcessor.insertWithSubtags(node);\r\n }\r\n else { //insert before after with id\r\n responseProcessor.insert(node);\r\n }\r\n };\r\n /**\r\n * next level changes tag\r\n *\r\n * @param node\r\n * @param responseProcessor\r\n */\r\n function processChangesTag(node, responseProcessor) {\r\n var ALLOWED_TAGS = [CMD_UPDATE, CMD_EVAL, CMD_INSERT, CMD_DELETE, CMD_ATTRIBUTES, CMD_EXTENSION].join(\",\");\r\n node.getIf(ALLOWED_TAGS).each(function (node) {\r\n switch (node.tagName.value) {\r\n case CMD_UPDATE:\r\n processUpdateTag(node, responseProcessor);\r\n break;\r\n case CMD_EVAL:\r\n responseProcessor.eval(node);\r\n break;\r\n case CMD_INSERT:\r\n processInsert(responseProcessor, node);\r\n break;\r\n case CMD_DELETE:\r\n responseProcessor.delete(node);\r\n break;\r\n case CMD_ATTRIBUTES:\r\n responseProcessor.attributes(node);\r\n break;\r\n case CMD_EXTENSION:\r\n break;\r\n }\r\n });\r\n return true;\r\n }\r\n /**\r\n * branch tag update.. drill further down into the updates\r\n * special case viewstate in that case it is a leaf\r\n * and the viewstate must be processed\r\n *\r\n * @param node\r\n * @param responseProcessor\r\n */\r\n function processUpdateTag(node, responseProcessor) {\r\n if (!responseProcessor.processViewState(node)) {\r\n handleElementUpdate(node, responseProcessor);\r\n }\r\n }\r\n /**\r\n * element update\r\n *\r\n * @param node\r\n * @param responseProcessor\r\n */\r\n function handleElementUpdate(node, responseProcessor) {\r\n var cdataBlock = node.cDATAAsString;\r\n switch (node.id.value) {\r\n case P_VIEWROOT:\r\n responseProcessor.replaceViewRoot(monadish_1.DQ.fromMarkup(cdataBlock.substring(cdataBlock.indexOf(\"<html\"))));\r\n break;\r\n case P_VIEWHEAD:\r\n responseProcessor.replaceHead(monadish_1.DQ.fromMarkup(cdataBlock));\r\n break;\r\n case P_VIEWBODY:\r\n responseProcessor.replaceBody(monadish_1.DQ.fromMarkup(cdataBlock));\r\n break;\r\n default: //htmlItem replacement\r\n responseProcessor.update(node, cdataBlock);\r\n break;\r\n }\r\n }\r\n})(Response = exports.Response || (exports.Response = {}));\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/main/typescript/impl/xhrCore/Response.ts.js","sources":["webpack:///./src/main/typescript/impl/xhrCore/Response.ts?e9f6"],"sourcesContent":["/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements.  See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License.  You may obtain a copy of the License at\r\n *\r\n *      http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\nimport {Config, DQ,XMLQuery} from \"../../ext/monadish\";\r\nimport {Const} from \"../core/Const\";\r\nimport {ResponseProcessor} from \"./ResponseProcessor\";\r\nimport {ResonseDataResolver} from \"./ResonseDataResolver\";\r\nimport {IResponseProcessor} from \"./IResponseProcessor\";\r\nimport RESPONSE_XML = Const.RESPONSE_XML;\r\nimport RESP_PARTIAL = Const.RESP_PARTIAL;\r\nimport PARTIAL_ID = Const.PARTIAL_ID;\r\nimport CMD_ERROR = Const.CMD_ERROR;\r\nimport CMD_REDIRECT = Const.CMD_REDIRECT;\r\nimport CMD_CHANGES = Const.CMD_CHANGES;\r\nimport CMD_UPDATE = Const.CMD_UPDATE;\r\nimport CMD_EVAL = Const.CMD_EVAL;\r\nimport CMD_INSERT = Const.CMD_INSERT;\r\nimport CMD_DELETE = Const.CMD_DELETE;\r\nimport CMD_ATTRIBUTES = Const.CMD_ATTRIBUTES;\r\nimport CMD_EXTENSION = Const.CMD_EXTENSION;\r\nimport P_VIEWROOT = Const.P_VIEWROOT;\r\nimport P_VIEWHEAD = Const.P_VIEWHEAD;\r\nimport P_VIEWBODY = Const.P_VIEWBODY;\r\nimport P_VIEWSTATE = Const.P_VIEWSTATE;\r\n\r\nexport module Response {\r\n\r\n    import resolveResponseXML = ResonseDataResolver.resolveResponseXML;\r\n    import resolveContexts = ResonseDataResolver.resolveContexts;\r\n    import TAG_BEFORE = Const.TAG_BEFORE;\r\n    import TAG_AFTER = Const.TAG_AFTER;\r\n\r\n    /**\r\n     * Standardized jsf.js response\r\n     * this one is called straight from jsf.js.response\r\n     *\r\n     * The processing follows the spec by going for the responseXML\r\n     * and processing its tags\r\n     *\r\n     * @param {XMLHttpRequest} request (xhrRequest) - xhr request object\r\n     * @param {[key: string]: any} context (Map) - AJAX context\r\n     *\r\n     */\r\n    export function processResponse(request: XMLHttpRequest, context: { [key: string]: any }) {\r\n\r\n        let req = Config.fromNullable(request);\r\n        let {externalContext, internalContext} = resolveContexts(context);\r\n        let responseXML: XMLQuery = resolveResponseXML(req);\r\n        let responseProcessor = new ResponseProcessor(req, externalContext, internalContext);\r\n\r\n        internalContext.assign(RESPONSE_XML).value = responseXML;\r\n\r\n        //we now process the partial tags, or in none given raise an error\r\n        responseXML.querySelectorAll(RESP_PARTIAL)\r\n            .each(item => processPartialTag(<XMLQuery>item, responseProcessor, internalContext));\r\n\r\n        //we now process the viewstates and the evals deferred\r\n        //the reason for this is that often it is better\r\n        //to wait until the document has caught up before\r\n        //doing any evals even on embedded scripts\r\n        responseProcessor.fixViewStates();\r\n        responseProcessor.globalEval();\r\n\r\n        responseProcessor.done();\r\n    }\r\n\r\n    /**\r\n     * highest node partial-response from there the main operations are triggered\r\n     */\r\n     function processPartialTag(node: XMLQuery, responseProcessor: IResponseProcessor, internalContext) {\r\n\r\n        internalContext.assign(PARTIAL_ID).value = node.id;\r\n        const SEL_SUB_TAGS = [CMD_ERROR, CMD_REDIRECT, CMD_CHANGES].join(\",\");\r\n\r\n        //now we can process the main operations\r\n        node.getIf(SEL_SUB_TAGS).each((node: XMLQuery) => {\r\n            switch (node.tagName.value) {\r\n                case CMD_ERROR:\r\n                    responseProcessor.error(node);\r\n                    break;\r\n                case CMD_REDIRECT:\r\n                    responseProcessor.redirect(node);\r\n                    break;\r\n                case CMD_CHANGES:\r\n                    processChangesTag(node, responseProcessor);\r\n                    break;\r\n            }\r\n        });\r\n\r\n    }\r\n\r\n    let processInsert = function (responseProcessor: IResponseProcessor, node: XMLQuery) {\r\n         //path1 insert after as child tags\r\n         if(node.querySelectorAll([TAG_BEFORE, TAG_AFTER].join(\",\")).length) {\r\n             responseProcessor.insertWithSubtags(node);\r\n         } else { //insert before after with id\r\n             responseProcessor.insert(node);\r\n         }\r\n\r\n    };\r\n\r\n    /**\r\n     * next level changes tag\r\n     *\r\n     * @param node\r\n     * @param responseProcessor\r\n     */\r\n     function processChangesTag(node: XMLQuery, responseProcessor: IResponseProcessor): boolean {\r\n        const ALLOWED_TAGS = [CMD_UPDATE, CMD_EVAL, CMD_INSERT, CMD_DELETE, CMD_ATTRIBUTES, CMD_EXTENSION].join(\",\");\r\n        node.getIf(ALLOWED_TAGS).each(\r\n            (node: XMLQuery) => {\r\n                switch (node.tagName.value) {\r\n                    case CMD_UPDATE:\r\n                        processUpdateTag(node, responseProcessor);\r\n                        break;\r\n\r\n                    case CMD_EVAL:\r\n                        responseProcessor.eval(node);\r\n                        break;\r\n\r\n                    case CMD_INSERT:\r\n                        processInsert(responseProcessor, node);\r\n                        break;\r\n\r\n                    case CMD_DELETE:\r\n                        responseProcessor.delete(node);\r\n                        break;\r\n\r\n                    case CMD_ATTRIBUTES:\r\n                        responseProcessor.attributes(node);\r\n                        break;\r\n\r\n                    case CMD_EXTENSION:\r\n                        break;\r\n                }\r\n            }\r\n        );\r\n        return true;\r\n    }\r\n\r\n    /**\r\n     * branch tag update.. drill further down into the updates\r\n     * special case viewstate in that case it is a leaf\r\n     * and the viewstate must be processed\r\n     *\r\n     * @param node\r\n     * @param responseProcessor\r\n     */\r\n     function processUpdateTag(node: XMLQuery, responseProcessor: IResponseProcessor) {\r\n        if (!responseProcessor.processViewState(node)) {\r\n            handleElementUpdate(node, responseProcessor);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * element update\r\n     *\r\n     * @param node\r\n     * @param responseProcessor\r\n     */\r\n     function handleElementUpdate(node: XMLQuery, responseProcessor: IResponseProcessor) {\r\n        let cdataBlock = node.cDATAAsString;\r\n        switch (node.id.value) {\r\n            case P_VIEWROOT :\r\n                responseProcessor.replaceViewRoot(DQ.fromMarkup(cdataBlock.substring(cdataBlock.indexOf(\"<html\"))));\r\n                break;\r\n\r\n            case P_VIEWHEAD:\r\n                responseProcessor.replaceHead(DQ.fromMarkup(cdataBlock));\r\n                break;\r\n\r\n            case P_VIEWBODY:\r\n                responseProcessor.replaceBody(DQ.fromMarkup(cdataBlock));\r\n                break;\r\n\r\n            default://htmlItem replacement\r\n                responseProcessor.update(node, cdataBlock);\r\n                break;\r\n\r\n        }\r\n    }\r\n}"],"mappings":";AAAA;;;;;;;;;;;;;;AAcA;;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AAAA;AAEA;AACA;AACA;AACA;AAEA;;;;;;;;;;AAUA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AArBA;AAuBA;;AAEA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAEA;AAEA;;;;;AAKA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;;;;;;;AAOA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;AAKA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/main/typescript/impl/xhrCore/Response.ts\n");
/***/ }),
/***/ "./src/main/typescript/impl/xhrCore/ResponseProcessor.ts":
/*!***************************************************************!*\
!*** ./src/main/typescript/impl/xhrCore/ResponseProcessor.ts ***!
\***************************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nvar __spreadArrays = (this && this.__spreadArrays) || function () {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n};\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar monadish_1 = __webpack_require__(/*! ../../ext/monadish */ \"./src/main/typescript/ext/monadish/index.ts\");\r\nvar Const_1 = __webpack_require__(/*! ../core/Const */ \"./src/main/typescript/impl/core/Const.ts\");\r\nvar AjaxImpl_1 = __webpack_require__(/*! ../AjaxImpl */ \"./src/main/typescript/impl/AjaxImpl.ts\");\r\nvar Assertions_1 = __webpack_require__(/*! ../util/Assertions */ \"./src/main/typescript/impl/util/Assertions.ts\");\r\nvar ErrorData_1 = __webpack_require__(/*! ./ErrorData */ \"./src/main/typescript/impl/xhrCore/ErrorData.ts\");\r\nvar DomQuery_1 = __webpack_require__(/*! ../../ext/monadish/DomQuery */ \"./src/main/typescript/ext/monadish/DomQuery.ts\");\r\nvar Lang_1 = __webpack_require__(/*! ../util/Lang */ \"./src/main/typescript/impl/util/Lang.ts\");\r\nvar trim = monadish_1.Lang.trim;\r\nvar getLocalOrGlobalConfig = Lang_1.ExtLang.getLocalOrGlobalConfig;\r\nvar TAG_HEAD = Const_1.Const.TAG_HEAD;\r\nvar SEL_SCRIPTS_STYLES = Const_1.Const.SEL_SCRIPTS_STYLES;\r\nvar TAG_BODY = Const_1.Const.TAG_BODY;\r\nvar TAG_FORM = Const_1.Const.TAG_FORM;\r\nvar SOURCE = Const_1.Const.SOURCE;\r\nvar ERROR_NAME = Const_1.Const.ERROR_NAME;\r\nvar ERROR_MESSAGE = Const_1.Const.ERROR_MESSAGE;\r\nvar P_PARTIAL_SOURCE = Const_1.Const.P_PARTIAL_SOURCE;\r\nvar RESPONSE_XML = Const_1.Const.RESPONSE_XML;\r\nvar ON_ERROR = Const_1.Const.ON_ERROR;\r\nvar TAG_BEFORE = Const_1.Const.TAG_BEFORE;\r\nvar TAG_AFTER = Const_1.Const.TAG_AFTER;\r\nvar UPDATE_ELEMS = Const_1.Const.UPDATE_ELEMS;\r\nvar UPDATE_FORMS = Const_1.Const.UPDATE_FORMS;\r\nvar SEL_VIEWSTATE_ELEM = Const_1.Const.SEL_VIEWSTATE_ELEM;\r\nvar P_VIEWSTATE = Const_1.Const.P_VIEWSTATE;\r\nvar ATTR_URL = Const_1.Const.ATTR_URL;\r\nvar EMPTY_FUNC = Const_1.Const.EMPTY_FUNC;\r\nvar TAG_ATTR = Const_1.Const.TAG_ATTR;\r\nvar ATTR_NAME = Const_1.Const.ATTR_NAME;\r\nvar ATTR_VALUE = Const_1.Const.ATTR_VALUE;\r\nvar HTML_VIEWSTATE = Const_1.Const.HTML_VIEWSTATE;\r\nvar APPLIED_VST = Const_1.Const.APPLIED_VST;\r\nvar ATTR_ID = Const_1.Const.ATTR_ID;\r\nvar ImplTypes_1 = __webpack_require__(/*! ../core/ImplTypes */ \"./src/main/typescript/impl/core/ImplTypes.ts\");\r\nvar EventData_1 = __webpack_require__(/*! ./EventData */ \"./src/main/typescript/impl/xhrCore/EventData.ts\");\r\nvar SUCCESS = Const_1.Const.SUCCESS;\r\nvar ON_EVENT = Const_1.Const.ON_EVENT;\r\n/**\r\n * Response processor\r\n *\r\n * Each XML tag is either a node or a leaf\r\n * or both\r\n *\r\n * the processor provides a set of operations\r\n * which are executed on a single leaf node per operation\r\n * and present the core functionality of our response\r\n *\r\n */\r\nvar ResponseProcessor = /** @class */ (function () {\r\n function ResponseProcessor(request, externalContext, internalContext) {\r\n this.request = request;\r\n this.externalContext = externalContext;\r\n this.internalContext = internalContext;\r\n }\r\n ResponseProcessor.prototype.replaceHead = function (shadowDocument) {\r\n var shadowHead = shadowDocument.querySelectorAll(TAG_HEAD);\r\n if (!shadowHead.isPresent()) {\r\n return;\r\n }\r\n var shadowInnerHTML = shadowHead.html().value;\r\n var oldHead = DomQuery_1.DQ.querySelectorAll(TAG_HEAD);\r\n //delete all to avoid script and style overlays\r\n oldHead.querySelectorAll(SEL_SCRIPTS_STYLES).delete();\r\n this.storeForEval(shadowHead);\r\n };\r\n /**\r\n * replaces the body in the expected manner\r\n * which means the entire body content is refreshed\r\n * however also the body attributes must be transferred\r\n * keeping event handlers etc... in place\r\n *\r\n * @param shadowDocument .. an incoming shadow document hosting the new nodes\r\n */\r\n ResponseProcessor.prototype.replaceBody = function (shadowDocument) {\r\n var shadowBody = shadowDocument.querySelectorAll(TAG_BODY);\r\n if (!shadowBody.isPresent()) {\r\n return;\r\n }\r\n var shadowInnerHTML = shadowBody.html().value;\r\n var resultingBody = DomQuery_1.DQ.querySelectorAll(TAG_BODY).html(shadowInnerHTML);\r\n var updateForms = resultingBody.querySelectorAll(TAG_FORM);\r\n resultingBody.copyAttrs(shadowBody);\r\n this.storeForPostProcessing(updateForms, resultingBody);\r\n };\r\n /**\r\n * Leaf Tag eval... process whatever is in the evals cdata block\r\n *\r\n * @param node the node to eval\r\n */\r\n ResponseProcessor.prototype.eval = function (node) {\r\n DomQuery_1.DQ.globalEval(node.cDATAAsString);\r\n };\r\n /**\r\n * processes an incoming error from the response\r\n * which is hosted under the &lt;error&gt; tag\r\n * @param request the current request\r\n * @param context the context object\r\n * @param node the node in the xml hosting the error message\r\n */\r\n ResponseProcessor.prototype.error = function (node) {\r\n /**\r\n * <error>\r\n * <error-name>String</error-name>\r\n * <error-message><![CDATA[message]]></error-message>\r\n * <error>\r\n */\r\n var mergedErrorData = new monadish_1.Config({});\r\n mergedErrorData.assign(SOURCE).value = this.externalContext.getIf(P_PARTIAL_SOURCE).get(0).value;\r\n mergedErrorData.assign(ERROR_NAME).value = node.getIf(ERROR_NAME).textContent(\"\");\r\n mergedErrorData.assign(ERROR_MESSAGE).value = node.getIf(ERROR_MESSAGE).cDATAAsString;\r\n var hasResponseXML = this.internalContext.get(RESPONSE_XML).isPresent();\r\n mergedErrorData.assignIf(hasResponseXML, RESPONSE_XML).value = this.internalContext.getIf(RESPONSE_XML).value.get(0).value;\r\n var errorData = ErrorData_1.ErrorData.fromServerError(mergedErrorData);\r\n this.externalContext.getIf(ON_ERROR).orElse(this.internalContext.getIf(ON_ERROR).value).orElse(EMPTY_FUNC).value(errorData);\r\n AjaxImpl_1.Implementation.sendError(errorData);\r\n };\r\n /**\r\n * process the redirect operation\r\n *\r\n * @param node\r\n */\r\n ResponseProcessor.prototype.redirect = function (node) {\r\n Assertions_1.Assertions.assertUrlExists(node);\r\n var redirectUrl = trim(node.attr(ATTR_URL).value);\r\n if (redirectUrl != \"\") {\r\n window.location.href = redirectUrl;\r\n }\r\n };\r\n /**\r\n * processes the update operation and updates the node with the cdata block\r\n * @param context\r\n * @param internalContext\r\n * @param node\r\n * @param cdataBlock\r\n */\r\n ResponseProcessor.prototype.update = function (node, cdataBlock) {\r\n var _a;\r\n var result = DomQuery_1.DQ.byId(node.id.value).outerHTML(cdataBlock, false, false);\r\n var sourceForm = (_a = result) === null || _a === void 0 ? void 0 : _a.parents(TAG_FORM).orElse(result.byTagName(TAG_FORM, true));\r\n if (sourceForm) {\r\n this.storeForPostProcessing(sourceForm, result);\r\n }\r\n };\r\n ResponseProcessor.prototype.delete = function (node) {\r\n DomQuery_1.DQ.byId(node.id.value).delete();\r\n };\r\n /**\r\n * attributes leaf tag... process the attributes\r\n *\r\n * @param node\r\n */\r\n ResponseProcessor.prototype.attributes = function (node) {\r\n var elem = DomQuery_1.DQ.byId(node.id.value);\r\n node.byTagName(TAG_ATTR).each(function (item) {\r\n elem.attr(item.attr(ATTR_NAME).value).value = item.attr(ATTR_VALUE).value;\r\n });\r\n };\r\n /**\r\n * @param shadownResponse\r\n */\r\n ResponseProcessor.prototype.replaceViewRoot = function (shadowDocument) {\r\n this.replaceHead(shadowDocument);\r\n this.replaceBody(shadowDocument);\r\n };\r\n /**\r\n * insert handling, either before or after\r\n *\r\n * @param node\r\n */\r\n ResponseProcessor.prototype.insert = function (node) {\r\n //let insertId = node.id; //not used atm\r\n var before = node.attr(TAG_BEFORE);\r\n var after = node.attr(TAG_AFTER);\r\n var insertNodes = DomQuery_1.DQ.fromMarkup(node.cDATAAsString);\r\n if (before.isPresent()) {\r\n var res = DomQuery_1.DQ.byId(before.value).insertBefore(insertNodes);\r\n this.internalContext.assign(UPDATE_ELEMS).value.push(insertNodes);\r\n }\r\n if (after.isPresent()) {\r\n var domQuery = DomQuery_1.DQ.byId(after.value);\r\n domQuery.insertAfter(insertNodes);\r\n this.internalContext.assign(UPDATE_ELEMS).value.push(insertNodes);\r\n }\r\n };\r\n ResponseProcessor.prototype.insertWithSubtags = function (node) {\r\n var _this = this;\r\n var before = node.querySelectorAll(TAG_BEFORE);\r\n var after = node.querySelectorAll(TAG_AFTER);\r\n before.each(function (item) {\r\n var insertId = item.attr(ATTR_ID);\r\n var insertNodes = DomQuery_1.DQ.fromMarkup(item.cDATAAsString);\r\n if (insertId.isPresent()) {\r\n DomQuery_1.DQ.byId(insertId.value).insertBefore(insertNodes);\r\n _this.internalContext.assign(UPDATE_ELEMS).value.push(insertNodes);\r\n }\r\n });\r\n after.each(function (item) {\r\n var insertId = item.attr(ATTR_ID);\r\n var insertNodes = DomQuery_1.DQ.fromMarkup(item.cDATAAsString);\r\n if (insertId.isPresent()) {\r\n DomQuery_1.DQ.byId(insertId.value).insertAfter(insertNodes);\r\n _this.internalContext.assign(UPDATE_ELEMS).value.push(insertNodes);\r\n }\r\n });\r\n };\r\n /**\r\n * process the viewState update, update the affected\r\n * forms with their respective new viewstate values\r\n *\r\n */\r\n ResponseProcessor.prototype.processViewState = function (node) {\r\n if (this.isViewStateNode(node)) {\r\n var viewStateValue = node.textContent();\r\n this.internalContext.assign(APPLIED_VST, node.id.value).value = new ImplTypes_1.ViewState(node.id.value, viewStateValue);\r\n return true;\r\n }\r\n return false;\r\n };\r\n ResponseProcessor.prototype.globalEval = function () {\r\n var updateElems = new (DomQuery_1.DQ.bind.apply(DomQuery_1.DQ, __spreadArrays([void 0], this.internalContext.getIf(UPDATE_ELEMS).value)))();\r\n updateElems.runCss();\r\n updateElems.runScripts();\r\n };\r\n ResponseProcessor.prototype.fixViewStates = function () {\r\n var _this = this;\r\n monadish_1.Stream.ofAssoc(this.internalContext.getIf(APPLIED_VST).orElse({}).value)\r\n .each(function (item) {\r\n var key = item[0];\r\n var value = item[1];\r\n var nameSpace = DomQuery_1.DQ.byId(value.nameSpace).orElse(document.body);\r\n var affectedForms = nameSpace.byTagName(TAG_FORM);\r\n var affectedForms2 = nameSpace.filter(function (item) { return item.tagName.orElse(\"\").value.toLowerCase() == TAG_FORM; });\r\n _this.appendViewStateToForms(new monadish_1.DomQuery(affectedForms, affectedForms2), value.value);\r\n });\r\n };\r\n ResponseProcessor.prototype.done = function () {\r\n var eventData = EventData_1.EventData.createFromRequest(this.request.value, this.externalContext, SUCCESS);\r\n //because some frameworks might decorate them over the context in the response\r\n var eventHandler = this.externalContext.getIf(ON_EVENT).orElse(this.internalContext.getIf(ON_EVENT).value).orElse(EMPTY_FUNC).value;\r\n AjaxImpl_1.Implementation.sendEvent(eventData, eventHandler);\r\n };\r\n ResponseProcessor.prototype.isAllFormResolution = function (context) {\r\n return getLocalOrGlobalConfig(context, \"no_portlet_env\", false);\r\n };\r\n ResponseProcessor.prototype.appendViewStateToForms = function (forms, viewState) {\r\n var _this = this;\r\n forms.each(function (form) {\r\n var viewStateElems = form.querySelectorAll(SEL_VIEWSTATE_ELEM)\r\n .orElseLazy(function () { return _this.newViewStateElement(form); });\r\n viewStateElems.attr(\"value\").value = viewState;\r\n });\r\n };\r\n /**\r\n * Helper to Create a new JSF ViewState Element\r\n *\r\n * @param parent, the parent node to attach the viewstate element to\r\n * (usually a form node)\r\n */\r\n ResponseProcessor.prototype.newViewStateElement = function (parent) {\r\n var newViewState = DomQuery_1.DQ.fromMarkup(HTML_VIEWSTATE);\r\n newViewState.appendTo(parent);\r\n return newViewState;\r\n };\r\n /**\r\n * Stores certain aspects of the dom for later post processing\r\n *\r\n * @param updateForms the update forms which should receive standardized internal jsf data\r\n * @param toBeEvaled the resulting elements which should be evaled\r\n */\r\n ResponseProcessor.prototype.storeForPostProcessing = function (updateForms, toBeEvaled) {\r\n this.storeForUpdate(updateForms);\r\n this.storeForEval(toBeEvaled);\r\n };\r\n ResponseProcessor.prototype.storeForUpdate = function (updateForms) {\r\n this.internalContext.assign(UPDATE_FORMS).value.push(updateForms);\r\n };\r\n ResponseProcessor.prototype.storeForEval = function (toBeEvaled) {\r\n this.internalContext.assign(UPDATE_ELEMS).value.push(toBeEvaled);\r\n };\r\n ResponseProcessor.prototype.isViewStateNode = function (node) {\r\n var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;\r\n var separatorchar = window.jsf.separatorchar;\r\n return \"undefined\" != typeof ((_b = (_a = node) === null || _a === void 0 ? void 0 : _a.id) === null || _b === void 0 ? void 0 : _b.value) && (((_d = (_c = node) === null || _c === void 0 ? void 0 : _c.id) === null || _d === void 0 ? void 0 : _d.value) == P_VIEWSTATE ||\r\n ((_g = (_f = (_e = node) === null || _e === void 0 ? void 0 : _e.id) === null || _f === void 0 ? void 0 : _f.value) === null || _g === void 0 ? void 0 : _g.indexOf([separatorchar, P_VIEWSTATE].join(\"\"))) != -1 ||\r\n ((_k = (_j = (_h = node) === null || _h === void 0 ? void 0 : _h.id) === null || _j === void 0 ? void 0 : _j.value) === null || _k === void 0 ? void 0 : _k.indexOf([P_VIEWSTATE, separatorchar].join(\"\"))) != -1);\r\n };\r\n return ResponseProcessor;\r\n}());\r\nexports.ResponseProcessor = ResponseProcessor;\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/main/typescript/impl/xhrCore/ResponseProcessor.ts.js","sources":["webpack:///./src/main/typescript/impl/xhrCore/ResponseProcessor.ts?d4cb"],"sourcesContent":["/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements.  See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License.  You may obtain a copy of the License at\r\n *\r\n *      http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\nimport {Config, DomQuery, Lang, Stream, XMLQuery} from \"../../ext/monadish\";\r\nimport {Const} from \"../core/Const\";\r\nimport {Implementation} from \"../AjaxImpl\";\r\nimport {Assertions} from \"../util/Assertions\";\r\n\r\nimport {ResonseDataResolver} from \"./ResonseDataResolver\";\r\nimport {IResponseProcessor} from \"./IResponseProcessor\";\r\nimport {ErrorData} from \"./ErrorData\";\r\nimport {DQ} from \"../../ext/monadish/DomQuery\";\r\nimport {ExtLang} from \"../util/Lang\";\r\nimport trim = Lang.trim;\r\nimport getLocalOrGlobalConfig = ExtLang.getLocalOrGlobalConfig;\r\nimport resolveSourceElement = ResonseDataResolver.resolveSourceElement;\r\nimport resolveSourceForm = ResonseDataResolver.resolveSourceForm;\r\n\r\nimport TAG_HEAD = Const.TAG_HEAD;\r\nimport SEL_SCRIPTS_STYLES = Const.SEL_SCRIPTS_STYLES;\r\nimport TAG_BODY = Const.TAG_BODY;\r\nimport TAG_FORM = Const.TAG_FORM;\r\nimport SOURCE = Const.SOURCE;\r\nimport ERROR_NAME = Const.ERROR_NAME;\r\nimport ERROR_MESSAGE = Const.ERROR_MESSAGE;\r\nimport P_PARTIAL_SOURCE = Const.P_PARTIAL_SOURCE;\r\nimport RESPONSE_XML = Const.RESPONSE_XML;\r\nimport ON_ERROR = Const.ON_ERROR;\r\nimport TAG_BEFORE = Const.TAG_BEFORE;\r\nimport TAG_AFTER = Const.TAG_AFTER;\r\nimport UPDATE_ELEMS = Const.UPDATE_ELEMS;\r\nimport UPDATE_FORMS = Const.UPDATE_FORMS;\r\nimport SEL_VIEWSTATE_ELEM = Const.SEL_VIEWSTATE_ELEM;\r\nimport P_VIEWSTATE = Const.P_VIEWSTATE;\r\nimport ATTR_URL = Const.ATTR_URL;\r\nimport EMPTY_FUNC = Const.EMPTY_FUNC;\r\nimport TAG_ATTR = Const.TAG_ATTR;\r\nimport ATTR_NAME = Const.ATTR_NAME;\r\nimport ATTR_VALUE = Const.ATTR_VALUE;\r\nimport HTML_VIEWSTATE = Const.HTML_VIEWSTATE;\r\nimport APPLIED_VST = Const.APPLIED_VST;\r\nimport ATTR_ID = Const.ATTR_ID;\r\n\r\nimport {ViewState} from \"../core/ImplTypes\";\r\nimport {EventData} from \"./EventData\";\r\nimport SUCCESS = Const.SUCCESS;\r\nimport ON_EVENT = Const.ON_EVENT;\r\n\r\n/**\r\n * Response processor\r\n *\r\n * Each  XML tag is either a node or a leaf\r\n * or both\r\n *\r\n * the processor provides a set of operations\r\n * which are executed on a single leaf node per operation\r\n * and present the core functionality of our response\r\n *\r\n */\r\nexport class ResponseProcessor implements IResponseProcessor {\r\n\r\n    constructor(private request: Config, private externalContext: Config, private internalContext: Config) {\r\n\r\n    }\r\n\r\n    replaceHead(shadowDocument: XMLQuery | DQ) {\r\n        let shadowHead = shadowDocument.querySelectorAll(TAG_HEAD);\r\n        if (!shadowHead.isPresent()) {\r\n            return;\r\n        }\r\n        let shadowInnerHTML: string = <string>shadowHead.html().value;\r\n        let oldHead = DQ.querySelectorAll(TAG_HEAD);\r\n\r\n        //delete all to avoid script and style overlays\r\n        oldHead.querySelectorAll(SEL_SCRIPTS_STYLES).delete();\r\n\r\n        this.storeForEval(shadowHead);\r\n    }\r\n\r\n    /**\r\n     * replaces the body in the expected manner\r\n     * which means the entire body content is refreshed\r\n     * however also the body attributes must be transferred\r\n     * keeping event handlers etc... in place\r\n     *\r\n     * @param shadowDocument .. an incoming shadow document hosting the new nodes\r\n     */\r\n    replaceBody(shadowDocument: XMLQuery | DQ) {\r\n\r\n        let shadowBody = shadowDocument.querySelectorAll(TAG_BODY);\r\n        if (!shadowBody.isPresent()) {\r\n            return;\r\n        }\r\n\r\n        let shadowInnerHTML: string = <string>shadowBody.html().value;\r\n\r\n        let resultingBody = <DQ>DQ.querySelectorAll(TAG_BODY).html(shadowInnerHTML);\r\n        let updateForms = resultingBody.querySelectorAll(TAG_FORM);\r\n\r\n        resultingBody.copyAttrs(shadowBody);\r\n\r\n        this.storeForPostProcessing(updateForms, resultingBody);\r\n    }\r\n\r\n    /**\r\n     * Leaf Tag eval... process whatever is in the evals cdata block\r\n     *\r\n     * @param node the node to eval\r\n     */\r\n    eval(node: XMLQuery) {\r\n        DQ.globalEval(node.cDATAAsString);\r\n    }\r\n\r\n    /**\r\n     * processes an incoming error from the response\r\n     * which is hosted under the &lt;error&gt; tag\r\n     * @param request the current request\r\n     * @param context the context object\r\n     * @param node the node in the xml hosting the error message\r\n     */\r\n    error(node: XMLQuery) {\r\n        /**\r\n         * <error>\r\n         *      <error-name>String</error-name>\r\n         *      <error-message><![CDATA[message]]></error-message>\r\n         * <error>\r\n         */\r\n\r\n        let mergedErrorData = new Config({});\r\n        mergedErrorData.assign(SOURCE).value = this.externalContext.getIf(P_PARTIAL_SOURCE).get(0).value;\r\n        mergedErrorData.assign(ERROR_NAME).value = node.getIf(ERROR_NAME).textContent(\"\");\r\n        mergedErrorData.assign(ERROR_MESSAGE).value = node.getIf(ERROR_MESSAGE).cDATAAsString;\r\n\r\n        let hasResponseXML = this.internalContext.get(RESPONSE_XML).isPresent();\r\n        mergedErrorData.assignIf(hasResponseXML, RESPONSE_XML).value = this.internalContext.getIf(RESPONSE_XML).value.get(0).value;\r\n\r\n        let errorData = ErrorData.fromServerError(mergedErrorData);\r\n\r\n        this.externalContext.getIf(ON_ERROR).orElse(this.internalContext.getIf(ON_ERROR).value).orElse(EMPTY_FUNC).value(errorData);\r\n        Implementation.sendError(errorData);\r\n    }\r\n\r\n    /**\r\n     * process the redirect operation\r\n     *\r\n     * @param node\r\n     */\r\n    redirect(node: XMLQuery) {\r\n        Assertions.assertUrlExists(node);\r\n\r\n        let redirectUrl = trim(node.attr(ATTR_URL).value);\r\n        if (redirectUrl != \"\") {\r\n            (<any>window).location.href = redirectUrl;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * processes the update operation and updates the node with the cdata block\r\n     * @param context\r\n     * @param internalContext\r\n     * @param node\r\n     * @param cdataBlock\r\n     */\r\n    update(node: XMLQuery, cdataBlock: string) {\r\n        let result = DQ.byId(node.id.value).outerHTML(cdataBlock, false, false);\r\n        let sourceForm = result?.parents(TAG_FORM).orElse(result.byTagName(TAG_FORM, true));\r\n        if(sourceForm) {\r\n            this.storeForPostProcessing(sourceForm, result);\r\n        }\r\n    }\r\n\r\n\r\n    delete(node: XMLQuery) {\r\n        DQ.byId(node.id.value).delete();\r\n    }\r\n\r\n    /**\r\n     * attributes leaf tag... process the attributes\r\n     *\r\n     * @param node\r\n     */\r\n    attributes(node: XMLQuery) {\r\n        let elem = DQ.byId(node.id.value);\r\n\r\n        node.byTagName(TAG_ATTR).each((item: XMLQuery) => {\r\n            elem.attr(item.attr(ATTR_NAME).value).value = item.attr(ATTR_VALUE).value;\r\n        });\r\n    }\r\n\r\n    /**\r\n     * @param shadownResponse\r\n     */\r\n    replaceViewRoot(shadowDocument: XMLQuery) {\r\n        this.replaceHead(shadowDocument);\r\n        this.replaceBody(shadowDocument);\r\n    }\r\n\r\n    /**\r\n     * insert handling, either before or after\r\n     *\r\n     * @param node\r\n     */\r\n    insert(node: XMLQuery) {\r\n        //let insertId = node.id; //not used atm\r\n\r\n        let before = node.attr(TAG_BEFORE);\r\n        let after = node.attr(TAG_AFTER);\r\n\r\n        let insertNodes = DQ.fromMarkup(<any>node.cDATAAsString);\r\n\r\n        if (before.isPresent()) {\r\n            let res = DQ.byId(before.value).insertBefore(insertNodes);\r\n            this.internalContext.assign(UPDATE_ELEMS).value.push(insertNodes);\r\n        }\r\n        if (after.isPresent()) {\r\n            let domQuery = DQ.byId(after.value);\r\n            domQuery.insertAfter(insertNodes);\r\n\r\n            this.internalContext.assign(UPDATE_ELEMS).value.push(insertNodes);\r\n        }\r\n    }\r\n\r\n    insertWithSubtags(node: XMLQuery) {\r\n        let before = node.querySelectorAll(TAG_BEFORE);\r\n        let after = node.querySelectorAll(TAG_AFTER);\r\n\r\n        before.each(item => {\r\n            let insertId = item.attr(ATTR_ID);\r\n            let insertNodes = DQ.fromMarkup(<any>item.cDATAAsString);\r\n            if(insertId.isPresent()) {\r\n                DQ.byId(insertId.value).insertBefore(insertNodes);\r\n                this.internalContext.assign(UPDATE_ELEMS).value.push(insertNodes);\r\n            }\r\n        });\r\n\r\n        after.each(item => {\r\n            let insertId = item.attr(ATTR_ID);\r\n            let insertNodes = DQ.fromMarkup(<any>item.cDATAAsString);\r\n            if(insertId.isPresent()) {\r\n                DQ.byId(insertId.value).insertAfter(insertNodes);\r\n                this.internalContext.assign(UPDATE_ELEMS).value.push(insertNodes);\r\n            }\r\n        });\r\n    }\r\n\r\n    /**\r\n     * process the viewState update, update the affected\r\n     * forms with their respective new viewstate values\r\n     *\r\n     */\r\n    processViewState(node: XMLQuery): boolean {\r\n        if( this.isViewStateNode(node)) {\r\n            let viewStateValue = node.textContent();\r\n            this.internalContext.assign(APPLIED_VST, node.id.value).value = new ViewState(node.id.value, viewStateValue);\r\n            return true;\r\n        }\r\n        return false;\r\n    }\r\n\r\n    globalEval() {\r\n        let updateElems = new DQ(...this.internalContext.getIf(UPDATE_ELEMS).value);\r\n        updateElems.runCss();\r\n        updateElems.runScripts();\r\n    }\r\n\r\n    fixViewStates() {\r\n        Stream.ofAssoc<ViewState>(this.internalContext.getIf(APPLIED_VST).orElse({}).value)\r\n            .each((item: Array<any>) => {\r\n                let key = item[0];\r\n                let value: ViewState =item[1];\r\n                let nameSpace = DQ.byId(value.nameSpace).orElse(document.body);\r\n                let affectedForms = nameSpace.byTagName(TAG_FORM);\r\n                let affectedForms2 = nameSpace.filter(item => item.tagName.orElse(\"\").value.toLowerCase() == TAG_FORM);\r\n\r\n\r\n                this.appendViewStateToForms(new DomQuery(affectedForms, affectedForms2), value.value);\r\n            });\r\n    }\r\n\r\n    done() {\r\n        let eventData = EventData.createFromRequest(this.request.value, this.externalContext, SUCCESS);\r\n\r\n        //because some frameworks might decorate them over the context in the response\r\n        let eventHandler = this.externalContext.getIf(ON_EVENT).orElse(this.internalContext.getIf(ON_EVENT).value).orElse(EMPTY_FUNC).value;\r\n        Implementation.sendEvent(eventData,  eventHandler);\r\n    }\r\n\r\n\r\n    private isAllFormResolution(context: Config) {\r\n        return getLocalOrGlobalConfig(context, \"no_portlet_env\", false);\r\n    }\r\n\r\n    private appendViewStateToForms(forms: DQ, viewState: string) {\r\n        forms.each((form: DQ) => {\r\n            let viewStateElems = form.querySelectorAll(SEL_VIEWSTATE_ELEM)\r\n                .orElseLazy(() => this.newViewStateElement(form));\r\n\r\n            viewStateElems.attr(\"value\").value = viewState;\r\n        });\r\n    }\r\n\r\n    /**\r\n     * Helper to Create a new JSF ViewState Element\r\n     *\r\n     * @param parent, the parent node to attach the viewstate element to\r\n     * (usually a form node)\r\n     */\r\n    private newViewStateElement(parent: DQ): DQ {\r\n        let newViewState = DQ.fromMarkup(HTML_VIEWSTATE);\r\n        newViewState.appendTo(parent);\r\n        return newViewState;\r\n    }\r\n\r\n    /**\r\n     * Stores certain aspects of the dom for later post processing\r\n     *\r\n     * @param updateForms the update forms which should receive standardized internal jsf data\r\n     * @param toBeEvaled the resulting elements which should be evaled\r\n     */\r\n    private storeForPostProcessing(updateForms: DQ, toBeEvaled: DQ) {\r\n        this.storeForUpdate(updateForms);\r\n        this.storeForEval(toBeEvaled);\r\n    }\r\n\r\n    private storeForUpdate(updateForms: DQ) {\r\n        this.internalContext.assign(UPDATE_FORMS).value.push(updateForms);\r\n    }\r\n\r\n    private storeForEval(toBeEvaled: DQ) {\r\n        this.internalContext.assign(UPDATE_ELEMS).value.push(toBeEvaled);\r\n    }\r\n\r\n    private isViewStateNode(node: XMLQuery) {\r\n        let separatorchar = (<any>window).jsf.separatorchar;\r\n        return \"undefined\" != typeof node?.id?.value && ( node?.id?.value == P_VIEWSTATE ||\r\n            node?.id?.value?.indexOf([separatorchar, P_VIEWSTATE].join(\"\")) != -1 ||\r\n            node?.id?.value?.indexOf([P_VIEWSTATE, separatorchar].join(\"\")) != -1 );\r\n    }\r\n\r\n}"],"mappings":";AAAA;;;;;;;;;;;;;;AAcA;;;;;;;;;AAEA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;;;;;;;;;;AAUA;AACA;AAEA;AAAA;AAAA;AAAA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAEA;;;;;;;AAOA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AAEA;AACA;AAEA;;;;AAIA;AACA;AACA;AACA;AAEA;;;;;;AAMA;AACA;AACA;;;;;AAKA;AAEA;AACA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AAEA;;;;AAIA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;;;;;;AAMA;AACA;;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AAEA;;;;AAIA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;;AAEA;AACA;AACA;AACA;AACA;AAEA;;;;AAIA;AACA;AACA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAAA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAGA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;;;;;AAKA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;AAKA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AAxRA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/main/typescript/impl/xhrCore/ResponseProcessor.ts\n");
/***/ }),
/***/ "./src/main/typescript/impl/xhrCore/XhrFormData.ts":
/*!*********************************************************!*\
!*** ./src/main/typescript/impl/xhrCore/XhrFormData.ts ***!
\*********************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nvar __extends = (this && this.__extends) || (function () {\r\n var extendStatics = function (d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n };\r\n return function (d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n };\r\n})();\r\nvar __spreadArrays = (this && this.__spreadArrays) || function () {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n};\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar monadish_1 = __webpack_require__(/*! ../../ext/monadish */ \"./src/main/typescript/ext/monadish/index.ts\");\r\nvar Const_1 = __webpack_require__(/*! ../core/Const */ \"./src/main/typescript/impl/core/Const.ts\");\r\nvar Stream_1 = __webpack_require__(/*! ../../ext/monadish/Stream */ \"./src/main/typescript/ext/monadish/Stream.ts\");\r\nvar DomQuery_1 = __webpack_require__(/*! ../../ext/monadish/DomQuery */ \"./src/main/typescript/ext/monadish/DomQuery.ts\");\r\nvar isString = monadish_1.Lang.isString;\r\nvar P_VIEWSTATE = Const_1.Const.P_VIEWSTATE;\r\n/**\r\n * we simplify now compared to the old form handling\r\n * given that we have a configuration in place we can recycle that\r\n * for the entire parameter generation\r\n * then we have two fallbacks one for the non multipart case\r\n * the other one for the multipart case\r\n *\r\n * From outside we work on a single form configuration\r\n * which we can use like any other config\r\n *\r\n * TODO make this code smaller we might have\r\n * enough leverage in the streams collectors\r\n * api just to do that.\r\n */\r\nvar XhrFormData = /** @class */ (function (_super) {\r\n __extends(XhrFormData, _super);\r\n /**\r\n * by the time we hit this code, datasource alöready must be of type form\r\n *\r\n * @param dataSource either a form as domquery object or an encoded url string\r\n * @param partialIdsArray partial ids to collect\r\n */\r\n function XhrFormData(dataSource, partialIdsArray) {\r\n var _this = _super.call(this, {}) || this;\r\n _this.dataSource = dataSource;\r\n _this.partialIdsArray = partialIdsArray;\r\n //a call to getViewState before must pass the encoded line\r\n //a call from getViewState passes the form element as datasource\r\n //so we have two call points\r\n if (isString(dataSource)) {\r\n _this.handleStringSource();\r\n }\r\n else {\r\n _this.handleFormSource();\r\n }\r\n return _this;\r\n }\r\n XhrFormData.prototype.handleFormSource = function () {\r\n //encode and append the issuing item if not a partial ids array of ids is passed\r\n /*\r\n * Spec. 13.3.1\r\n * Collect and encode input elements.\r\n * Additionally the hidden element javax.faces.ViewState\r\n * Enhancement partial page submit\r\n *\r\n */\r\n this.encodeSubmittableFields(this, this.dataSource, this.partialIdsArray);\r\n if (this.getIf(P_VIEWSTATE).isPresent()) {\r\n return;\r\n }\r\n this.applyViewState(this.dataSource);\r\n };\r\n XhrFormData.prototype.handleStringSource = function () {\r\n this.mergeEncodedString(this.dataSource);\r\n return;\r\n };\r\n XhrFormData.prototype.applyViewState = function (form) {\r\n var _this = this;\r\n form.byId(Const_1.Const.P_VIEWSTATE)\r\n .ifPresentLazy(function (elem) {\r\n var value = elem.inputValue.value;\r\n _this.assignIf(!!value, Const_1.Const.P_VIEWSTATE).value = value;\r\n });\r\n };\r\n XhrFormData.prototype.mergeEncodedString = function (encoded) {\r\n var _this = this;\r\n var splittedEntries = encoded.split(/\\&/gi);\r\n Stream_1.Stream.of.apply(Stream_1.Stream, splittedEntries).map(function (line) { return line.split(/\\=/gi); })\r\n .each(function (keyVal) {\r\n _this.assign(keyVal[0]).value = keyVal[1] || null;\r\n });\r\n };\r\n // noinspection JSUnusedGlobalSymbols\r\n /**\r\n * @returns a Form data representation\r\n */\r\n XhrFormData.prototype.toFormData = function () {\r\n var ret = new FormData();\r\n for (var key in this.value) {\r\n if (this.value.hasOwnProperty(key)) {\r\n ret.append(key, this.value[key]);\r\n }\r\n }\r\n return ret;\r\n };\r\n /**\r\n * returns an encoded string representation of our xhr form data\r\n *\r\n * @param defaultStr optional default value if nothing is there to encode\r\n */\r\n XhrFormData.prototype.toString = function (defaultStr) {\r\n if (defaultStr === void 0) { defaultStr = \"\"; }\r\n if (this.isAbsent()) {\r\n return defaultStr;\r\n }\r\n var entries = [];\r\n for (var key in this.value) {\r\n if (this.value.hasOwnProperty(key)) {\r\n //key value already encoded so no need to reencode them again\r\n entries.push(key + \"=\" + this.value[key]);\r\n }\r\n }\r\n return entries.join(\"&\");\r\n };\r\n /**\r\n * determines fields to submit\r\n * @param {Object} targetBuf - the target form buffer receiving the data\r\n * @param {Node} parentItem - form element item is nested in\r\n * @param {Array} partialIds - ids fo PPS\r\n */\r\n XhrFormData.prototype.encodeSubmittableFields = function (targetBuf, parentItem, partialIds) {\r\n var toEncode = null;\r\n if (this.partialIdsArray && this.partialIdsArray.length) {\r\n //in case of our myfaces reduced ppr we only\r\n //only submit the partials\r\n //TODO maybe also the window id and other defaults lets see\r\n //this is not a spec case anyway\r\n this._value = {};\r\n toEncode = new (DomQuery_1.DQ.bind.apply(DomQuery_1.DQ, __spreadArrays([void 0], this.partialIdsArray)))();\r\n }\r\n else {\r\n if (parentItem.isAbsent())\r\n throw \"NO_PARITEM\";\r\n toEncode = parentItem;\r\n }\r\n //lets encode the form elements\r\n this.shallowMerge(toEncode.querySelectorAll(\"input, checkbox, select, textarea\").encodeFormElement());\r\n };\r\n Object.defineProperty(XhrFormData.prototype, \"isMultipartRequest\", {\r\n get: function () {\r\n return this.dataSource instanceof DomQuery_1.DQ && this.dataSource.querySelectorAll(\"input[type='file']\").isPresent();\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n return XhrFormData;\r\n}(monadish_1.Config));\r\nexports.XhrFormData = XhrFormData;\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/main/typescript/impl/xhrCore/XhrFormData.ts.js","sources":["webpack:///./src/main/typescript/impl/xhrCore/XhrFormData.ts?b50b"],"sourcesContent":["/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements.  See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License.  You may obtain a copy of the License at\r\n *\r\n *      http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\nimport {Config, Lang} from \"../../ext/monadish\";\r\nimport {Const} from \"../core/Const\";\r\nimport {Implementation} from \"../AjaxImpl\";\r\n\r\nimport {Stream} from \"../../ext/monadish/Stream\";\r\nimport {DQ} from \"../../ext/monadish/DomQuery\";\r\nimport isString = Lang.isString;\r\nimport P_VIEWSTATE = Const.P_VIEWSTATE;\r\n\r\ndeclare let jsf: any;\r\n\r\n/**\r\n * we simplify now compared to the old form handling\r\n * given that we have a configuration in place we can recycle that\r\n * for the entire parameter generation\r\n * then we have two fallbacks one for the non multipart case\r\n * the other one for the multipart case\r\n *\r\n * From outside we work on a single form configuration\r\n * which we can use like any other config\r\n *\r\n * TODO make this code smaller we might have\r\n * enough leverage in the streams collectors\r\n * api just to do that.\r\n */\r\nexport class XhrFormData extends Config {\r\n\r\n    /**\r\n     * by the time we hit this code, datasource alöready must be of type form\r\n     *\r\n     * @param dataSource either a form as domquery object or an encoded url string\r\n     * @param partialIdsArray partial ids to collect\r\n     */\r\n    constructor(private dataSource: DQ | string, private partialIdsArray?: string[]) {\r\n        super({});\r\n        //a call to getViewState before must pass the encoded line\r\n        //a call from getViewState passes the form element as datasource\r\n        //so we have two call points\r\n        if (isString(dataSource)) {\r\n            this.handleStringSource();\r\n        } else {\r\n            this.handleFormSource();\r\n        }\r\n    }\r\n\r\n    private handleFormSource() {\r\n        //encode and append the issuing item if not a partial ids array of ids is passed\r\n        /*\r\n         * Spec. 13.3.1\r\n         * Collect and encode input elements.\r\n         * Additionally the hidden element javax.faces.ViewState\r\n         * Enhancement partial page submit\r\n         *\r\n         */\r\n\r\n        this.encodeSubmittableFields(this, <DQ>this.dataSource, this.partialIdsArray);\r\n\r\n        if (this.getIf(P_VIEWSTATE).isPresent()) {\r\n            return;\r\n        }\r\n\r\n        this.applyViewState(<DQ>this.dataSource);\r\n    }\r\n\r\n    private handleStringSource() {\r\n        this.mergeEncodedString(<string>this.dataSource);\r\n        return;\r\n    }\r\n\r\n    private applyViewState(form: DQ) {\r\n        form.byId(Const.P_VIEWSTATE)\r\n            .ifPresentLazy((elem: DQ) => {\r\n                let value = elem.inputValue.value;\r\n                this.assignIf(!!value ,Const.P_VIEWSTATE).value = value;\r\n            });\r\n    }\r\n\r\n    mergeEncodedString(encoded: string) {\r\n        let splittedEntries = encoded.split(/\\&/gi);\r\n        Stream.of(...splittedEntries)\r\n            .map(line => line.split(/\\=/gi))\r\n            .each(keyVal => {\r\n                this.assign(keyVal [0]).value = keyVal[1] || null;\r\n            });\r\n    }\r\n\r\n    // noinspection JSUnusedGlobalSymbols\r\n    /**\r\n     * @returns a Form data representation\r\n     */\r\n    toFormData(): FormData {\r\n        let ret: any = new FormData();\r\n        for (let key in this.value) {\r\n            if (this.value.hasOwnProperty(key)) {\r\n                ret.append(key, this.value[key])\r\n            }\r\n        }\r\n        return ret;\r\n    }\r\n\r\n    /**\r\n     * returns an encoded string representation of our xhr form data\r\n     *\r\n     * @param defaultStr optional default value if nothing is there to encode\r\n     */\r\n    toString(defaultStr = \"\"): string {\r\n        if (this.isAbsent()) {\r\n            return defaultStr;\r\n        }\r\n        let entries = [];\r\n        for (let key in this.value) {\r\n            if (this.value.hasOwnProperty(key)) {\r\n                //key value already encoded so no need to reencode them again\r\n                entries.push(`${key}=${this.value[key]}`)\r\n            }\r\n        }\r\n        return entries.join(\"&\")\r\n    }\r\n\r\n    /**\r\n     * determines fields to submit\r\n     * @param {Object} targetBuf - the target form buffer receiving the data\r\n     * @param {Node} parentItem - form element item is nested in\r\n     * @param {Array} partialIds - ids fo PPS\r\n     */\r\n    private encodeSubmittableFields(targetBuf: Config,\r\n                                    parentItem: DQ, partialIds ?: string[]) {\r\n        let toEncode = null;\r\n        if (this.partialIdsArray && this.partialIdsArray.length) {\r\n            //in case of our myfaces reduced ppr we only\r\n            //only submit the partials\r\n\r\n            //TODO maybe also the window id and other defaults lets see\r\n            //this is not a spec case anyway\r\n            this._value = {};\r\n            toEncode = new DQ(...this.partialIdsArray);\r\n\r\n        } else {\r\n            if (parentItem.isAbsent()) throw \"NO_PARITEM\";\r\n            toEncode = parentItem;\r\n        }\r\n\r\n        //lets encode the form elements\r\n        this.shallowMerge(toEncode.querySelectorAll(\"input, checkbox, select, textarea\").encodeFormElement());\r\n    }\r\n\r\n    get isMultipartRequest(): boolean {\r\n        return  this.dataSource instanceof DQ && (<DQ> this.dataSource).querySelectorAll(\"input[type='file']\").isPresent();\r\n    }\r\n\r\n}"],"mappings":";AAAA;;;;;;;;;;;;;;AAcA;;;;;;;;;;;;;;;;;;;;;;AAEA;AACA;AAGA;AACA;AACA;AACA;AAIA;;;;;;;;;;;;;AAaA;AACA;AAAA;AAEA;;;;;AAKA;AACA;AAAA;AAAA;AAAA;AAEA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;;AACA;AAEA;AACA;AACA;;;;;;AAMA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AAAA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;AAIA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;AAKA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAAA;AACA;AAAA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAAA;AACA;AACA;;;AAAA;AAEA;AAAA;AA7HA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/main/typescript/impl/xhrCore/XhrFormData.ts\n");
/***/ }),
/***/ "./src/main/typescript/impl/xhrCore/XhrRequest.ts":
/*!********************************************************!*\
!*** ./src/main/typescript/impl/xhrCore/XhrRequest.ts ***!
\********************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
"use strict";
eval("\r\n/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements. See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nvar AjaxImpl_1 = __webpack_require__(/*! ../AjaxImpl */ \"./src/main/typescript/impl/AjaxImpl.ts\");\r\nvar Const_1 = __webpack_require__(/*! ../core/Const */ \"./src/main/typescript/impl/core/Const.ts\");\r\nvar XhrFormData_1 = __webpack_require__(/*! ./XhrFormData */ \"./src/main/typescript/impl/xhrCore/XhrFormData.ts\");\r\nvar ErrorData_1 = __webpack_require__(/*! ./ErrorData */ \"./src/main/typescript/impl/xhrCore/ErrorData.ts\");\r\nvar EventData_1 = __webpack_require__(/*! ./EventData */ \"./src/main/typescript/impl/xhrCore/EventData.ts\");\r\nvar Lang_1 = __webpack_require__(/*! ../util/Lang */ \"./src/main/typescript/impl/util/Lang.ts\");\r\nvar failSaveExecute = Lang_1.ExtLang.failSaveExecute;\r\nvar getPromise = Lang_1.ExtLang.getPromise;\r\nvar COMPLETE = Const_1.Const.COMPLETE;\r\nvar NO_TIMEOUT = Const_1.Const.NO_TIMEOUT;\r\nvar REQ_TYPE_POST = Const_1.Const.REQ_TYPE_POST;\r\nvar URL_ENCODED = Const_1.Const.URL_ENCODED;\r\nvar ON_EVENT = Const_1.Const.ON_EVENT;\r\nvar ON_ERROR = Const_1.Const.ON_ERROR;\r\nvar MULTIPART = Const_1.Const.MULTIPART;\r\nvar CTX_PARAM_PASS_THR = Const_1.Const.CTX_PARAM_PASS_THR;\r\nvar CTX_PARAM_MF_INTERNAL = Const_1.Const.CTX_PARAM_MF_INTERNAL;\r\nvar CONTENT_TYPE = Const_1.Const.CONTENT_TYPE;\r\nvar HEAD_FACES_REQ = Const_1.Const.HEAD_FACES_REQ;\r\nvar VAL_AJAX = Const_1.Const.VAL_AJAX;\r\nvar STATE_EVT_TIMEOUT = Const_1.Const.STATE_EVT_TIMEOUT;\r\nvar REQ_ACCEPT = Const_1.Const.REQ_ACCEPT;\r\nvar STD_ACCEPT = Const_1.Const.STD_ACCEPT;\r\nvar REQ_TYPE_GET = Const_1.Const.REQ_TYPE_GET;\r\nvar ENCODED_URL = Const_1.Const.ENCODED_URL;\r\nvar BEGIN = Const_1.Const.BEGIN;\r\nvar MALFORMEDXML = Const_1.Const.MALFORMEDXML;\r\nvar ERROR = Const_1.Const.ERROR;\r\nvar EMPTY_FUNC = Const_1.Const.EMPTY_FUNC;\r\nvar XhrRequest = /** @class */ (function () {\r\n /**\r\n * Reqired Parameters\r\n *\r\n * @param source the issuing element\r\n * @param sourceForm the form which is related to the issuing element\r\n * @param requestContext the request context with allö pass through values\r\n *\r\n * Optional Parameters\r\n *\r\n * @param partialIdsArray an optional restricting partial ids array for encoding\r\n * @param timeout optional xhr timeout\r\n * @param ajaxType optional request type, default \"POST\"\r\n * @param contentType optional content type, default \"application/x-www-form-urlencoded\"\r\n * @param xhrObject optional xhr object which must fullfill the XMLHTTPRequest api, default XMLHttpRequest\r\n */\r\n function XhrRequest(source, sourceForm, requestContext, internalContext, partialIdsArray, timeout, ajaxType, contentType, xhrObject) {\r\n if (partialIdsArray === void 0) { partialIdsArray = []; }\r\n if (timeout === void 0) { timeout = NO_TIMEOUT; }\r\n if (ajaxType === void 0) { ajaxType = REQ_TYPE_POST; }\r\n if (contentType === void 0) { contentType = URL_ENCODED; }\r\n if (xhrObject === void 0) { xhrObject = new XMLHttpRequest(); }\r\n this.source = source;\r\n this.sourceForm = sourceForm;\r\n this.requestContext = requestContext;\r\n this.internalContext = internalContext;\r\n this.partialIdsArray = partialIdsArray;\r\n this.timeout = timeout;\r\n this.ajaxType = ajaxType;\r\n this.contentType = contentType;\r\n this.xhrObject = xhrObject;\r\n this.stopProgress = false;\r\n }\r\n XhrRequest.prototype.start = function () {\r\n var _this = this;\r\n var fsExec = failSaveExecute;\r\n var xhrObject = this.xhrObject;\r\n try {\r\n var viewState = jsf.getViewState(this.sourceForm.getAsElem(0).value);\r\n var formData = new XhrFormData_1.XhrFormData(viewState);\r\n this.contentType = formData.isMultipartRequest ? MULTIPART : this.contentType;\r\n //next step the pass through parameters are merged in for post params\r\n var requestContext = this.requestContext;\r\n var passThroughParams = requestContext.getIf(CTX_PARAM_PASS_THR);\r\n formData.shallowMerge(passThroughParams);\r\n this.responseContext = passThroughParams.deepCopy;\r\n //we have to shift the internal passthroughs around to build up our response context\r\n var responseContext = this.responseContext;\r\n responseContext.assign(CTX_PARAM_MF_INTERNAL).value = this.internalContext.value;\r\n //per spec the onevent and onerrors must be passed through to the response\r\n responseContext.assign(ON_EVENT).value = requestContext.getIf(ON_EVENT).value;\r\n responseContext.assign(ON_ERROR).value = requestContext.getIf(ON_ERROR).value;\r\n xhrObject.open(this.ajaxType, this.resolveFinalUrl(formData), true);\r\n //adding timeout\r\n this.timeout ? xhrObject.timeout = this.timeout : null;\r\n //a bug in the xhr stub library prevents the setRequestHeader to be properly executed on fake xhr objects\r\n //normal browsers should resolve this\r\n //tests can quietly fail on this one\r\n fsExec(function () { return xhrObject.setRequestHeader(CONTENT_TYPE, _this.contentType + \"; charset=utf-8\"); });\r\n fsExec(function () { return xhrObject.setRequestHeader(HEAD_FACES_REQ, VAL_AJAX); });\r\n //probably not needed anymore, will test this\r\n //some webkit based mobile browsers do not follow the w3c spec of\r\n // setting the accept headers automatically\r\n fsExec(function () { return xhrObject.setRequestHeader(REQ_ACCEPT, STD_ACCEPT); });\r\n this.sendEvent(BEGIN);\r\n this.sendRequest(formData);\r\n }\r\n catch (e) {\r\n //_onError//_onError\r\n this.handleError(e);\r\n }\r\n return this;\r\n };\r\n XhrRequest.prototype.cancel = function () {\r\n try {\r\n this.xhrObject.abort();\r\n }\r\n catch (e) {\r\n this.handleError(e);\r\n }\r\n };\r\n Object.defineProperty(XhrRequest.prototype, \"$promise\", {\r\n /*\r\n * Promise bindings\r\n *\r\n * We have to delegate a few calls to our promise\r\n * to make the callback from the outside and inside work with our\r\n * xhr promise\r\n *\r\n */\r\n get: function () {\r\n var _this = this;\r\n if (!this.xhrPromise) {\r\n this.xhrPromise = new (getPromise())(function (resolve, reject) {\r\n //to allow callback into xhr over promises\r\n //we have to register the callbacks\r\n //accordingly\r\n _this.registerXhrCallbacks(resolve, reject);\r\n });\r\n }\r\n return this.xhrPromise;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n XhrRequest.prototype.catch = function (func) {\r\n this.$promise.catch(func);\r\n return this;\r\n };\r\n XhrRequest.prototype.finally = function (func) {\r\n //no ie11 support we probably are going to revert to shims for that one\r\n this.$promise.then(func).catch(func);\r\n //(<any>this.$promise).then(func);\r\n return this;\r\n };\r\n XhrRequest.prototype.then = function (func) {\r\n this.$promise.then(func);\r\n return this;\r\n };\r\n /**\r\n * attaches the internal event and processing\r\n * callback within the promise to our xhr object\r\n *\r\n * @param resolve\r\n * @param reject\r\n */\r\n XhrRequest.prototype.registerXhrCallbacks = function (resolve, reject) {\r\n var _this = this;\r\n var xhrObject = this.xhrObject;\r\n xhrObject.onabort = function () {\r\n _this.onAbort(resolve, reject);\r\n };\r\n xhrObject.ontimeout = function () {\r\n _this.onTimeout(resolve, reject);\r\n };\r\n xhrObject.onload = function () {\r\n _this.onSuccess(_this.xhrObject, resolve, reject);\r\n };\r\n xhrObject.onloadend = function () {\r\n _this.onDone(_this.xhrObject, resolve, reject);\r\n };\r\n xhrObject.onerror = function (errorData) {\r\n _this.onError(errorData, resolve, reject);\r\n };\r\n };\r\n /*\r\n * xhr processing callbacks\r\n *\r\n * Those methods are the callbacks called by\r\n * the xhr object depending on its own state\r\n */\r\n XhrRequest.prototype.onAbort = function (resolve, reject) {\r\n reject();\r\n };\r\n XhrRequest.prototype.onTimeout = function (resolve, reject) {\r\n this.sendEvent(STATE_EVT_TIMEOUT);\r\n reject();\r\n };\r\n XhrRequest.prototype.onSuccess = function (data, resolve, reject) {\r\n var _a, _b, _c;\r\n this.sendEvent(COMPLETE);\r\n //malforms always result in empty response xml\r\n if (!((_b = (_a = this) === null || _a === void 0 ? void 0 : _a.xhrObject) === null || _b === void 0 ? void 0 : _b.responseXML)) {\r\n this.handleMalFormedXML(resolve);\r\n return;\r\n }\r\n jsf.ajax.response(this.xhrObject, (_c = this.responseContext.value, (_c !== null && _c !== void 0 ? _c : {})));\r\n };\r\n XhrRequest.prototype.handleMalFormedXML = function (resolve) {\r\n var _a;\r\n this.stopProgress = true;\r\n var errorData = {\r\n type: ERROR,\r\n status: MALFORMEDXML,\r\n responseCode: 200,\r\n responseText: (_a = this.xhrObject) === null || _a === void 0 ? void 0 : _a.responseText,\r\n source: {\r\n id: this.source.id.value\r\n }\r\n };\r\n try {\r\n AjaxImpl_1.Implementation.sendError(errorData);\r\n }\r\n finally {\r\n resolve(errorData);\r\n }\r\n //non blocking non clearing\r\n };\r\n XhrRequest.prototype.onDone = function (data, resolve, reject) {\r\n if (this.stopProgress) {\r\n return;\r\n }\r\n resolve(data);\r\n };\r\n XhrRequest.prototype.onError = function (errorData, resolve, reject) {\r\n this.handleError(errorData);\r\n reject();\r\n };\r\n /*\r\n * other helpers\r\n */\r\n XhrRequest.prototype.sendEvent = function (evtType) {\r\n var eventData = EventData_1.EventData.createFromRequest(this.xhrObject, this.requestContext, evtType);\r\n try {\r\n //user code error, we might cover\r\n //this in onError but also we cannot swallow it\r\n //we need to resolve the local handlers lazyly,\r\n //because some frameworks might decorate them over the context in the response\r\n var eventHandler = this.resolveHandlerFunc(ON_EVENT);\r\n ;\r\n AjaxImpl_1.Implementation.sendEvent(eventData, eventHandler);\r\n }\r\n catch (e) {\r\n this.handleError(e);\r\n throw e;\r\n }\r\n };\r\n XhrRequest.prototype.handleError = function (exception) {\r\n var errorData = ErrorData_1.ErrorData.fromClient(exception);\r\n var eventHandler = this.resolveHandlerFunc(ON_ERROR);\r\n AjaxImpl_1.Implementation.sendError(errorData, eventHandler);\r\n };\r\n /**\r\n * resolves the event handlers lazly\r\n * so that if some decoration happens in between we can deal with it\r\n *\r\n * @param funcName\r\n */\r\n XhrRequest.prototype.resolveHandlerFunc = function (funcName) {\r\n return this.responseContext.getIf(funcName)\r\n .orElse(this.requestContext.getIf(funcName).value)\r\n .orElse(EMPTY_FUNC).value;\r\n };\r\n XhrRequest.prototype.resolveTargetUrl = function (srcFormElement) {\r\n return (typeof srcFormElement.elements[ENCODED_URL] == 'undefined') ?\r\n srcFormElement.action :\r\n srcFormElement.elements[ENCODED_URL].value;\r\n };\r\n XhrRequest.prototype.sendRequest = function (formData) {\r\n var isPost = this.ajaxType != REQ_TYPE_GET;\r\n if (formData.isMultipartRequest) {\r\n this.xhrObject.send((isPost) ? formData.toFormData() : null);\r\n }\r\n else {\r\n this.xhrObject.send((isPost) ? formData.toString() : null);\r\n }\r\n };\r\n XhrRequest.prototype.resolveFinalUrl = function (formData) {\r\n var targetUrl = this.resolveTargetUrl(this.sourceForm.getAsElem(0).value);\r\n return targetUrl + (this.ajaxType == REQ_TYPE_GET ? \"?\" + formData.toString() : \"\");\r\n };\r\n return XhrRequest;\r\n}());\r\nexports.XhrRequest = XhrRequest;\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/main/typescript/impl/xhrCore/XhrRequest.ts.js","sources":["webpack:///./src/main/typescript/impl/xhrCore/XhrRequest.ts?7d1e"],"sourcesContent":["/* Licensed to the Apache Software Foundation (ASF) under one or more\r\n * contributor license agreements.  See the NOTICE file distributed with\r\n * this work for additional information regarding copyright ownership.\r\n * The ASF licenses this file to you under the Apache License, Version 2.0\r\n * (the \"License\"); you may not use this file except in compliance with\r\n * the License.  You may obtain a copy of the License at\r\n *\r\n *      http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software\r\n * distributed under the License is distributed on an \"AS IS\" BASIS,\r\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n * See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\n\r\nimport {AsyncRunnable} from \"../util/AsyncRunnable\";\r\nimport {Config} from \"../../ext/monadish/Monad\";\r\nimport {Implementation} from \"../AjaxImpl\";\r\n\r\nimport {Const} from \"../core/Const\";\r\nimport {XhrFormData} from \"./XhrFormData\";\r\nimport {ErrorData} from \"./ErrorData\";\r\nimport {EventData} from \"./EventData\";\r\nimport {DQ} from \"../../ext/monadish/DomQuery\";\r\nimport {ExtLang} from \"../util/Lang\";\r\nimport {Assertions} from \"../util/Assertions\";\r\nimport failSaveExecute = ExtLang.failSaveExecute;\r\nimport getPromise = ExtLang.getPromise;\r\nimport COMPLETE = Const.COMPLETE;\r\nimport NO_TIMEOUT = Const.NO_TIMEOUT;\r\nimport REQ_TYPE_POST = Const.REQ_TYPE_POST;\r\nimport URL_ENCODED = Const.URL_ENCODED;\r\nimport ON_EVENT = Const.ON_EVENT;\r\nimport ON_ERROR = Const.ON_ERROR;\r\nimport MULTIPART = Const.MULTIPART;\r\nimport CTX_PARAM_PASS_THR = Const.CTX_PARAM_PASS_THR;\r\nimport CTX_PARAM_MF_INTERNAL = Const.CTX_PARAM_MF_INTERNAL;\r\nimport CONTENT_TYPE = Const.CONTENT_TYPE;\r\nimport HEAD_FACES_REQ = Const.HEAD_FACES_REQ;\r\nimport VAL_AJAX = Const.VAL_AJAX;\r\nimport STATE_EVT_TIMEOUT = Const.STATE_EVT_TIMEOUT;\r\nimport REQ_ACCEPT = Const.REQ_ACCEPT;\r\nimport STD_ACCEPT = Const.STD_ACCEPT;\r\nimport REQ_TYPE_GET = Const.REQ_TYPE_GET;\r\nimport ENCODED_URL = Const.ENCODED_URL;\r\nimport BEGIN = Const.BEGIN;\r\nimport MALFORMEDXML = Const.MALFORMEDXML;\r\nimport ERROR = Const.ERROR;\r\nimport EMPTY_FUNC = Const.EMPTY_FUNC;\r\n\r\n\r\n/**\r\n * JSFed XHR Request Wrapper\r\n * as Asyncrunnable for our Asynchronous queue\r\n *\r\n * The idea is that we basically just enqueue\r\n * a single ajax request into our queue\r\n * and let the queue do the processing.\r\n *\r\n */\r\n\r\ndeclare let jsf: any;\r\n\r\nexport class XhrRequest implements AsyncRunnable<XMLHttpRequest> {\r\n\r\n    /** predefined method */\r\n\r\n\r\n    private xhrPromise: Promise<XMLHttpRequest>;\r\n\r\n\r\n\r\n    private responseContext: Config;\r\n\r\n    private stopProgress = false;\r\n\r\n    /**\r\n     * Reqired Parameters\r\n     *\r\n     * @param source the issuing element\r\n     * @param sourceForm the form which is related to the issuing element\r\n     * @param requestContext the request context with allö pass through values\r\n     *\r\n     * Optional Parameters\r\n     *\r\n     * @param partialIdsArray an optional restricting partial ids array for encoding\r\n     * @param timeout optional xhr timeout\r\n     * @param ajaxType optional request type, default \"POST\"\r\n     * @param contentType optional content type, default \"application/x-www-form-urlencoded\"\r\n     * @param xhrObject optional xhr object which must fullfill the XMLHTTPRequest api, default XMLHttpRequest\r\n     */\r\n    constructor(\r\n        private source: DQ,\r\n        private sourceForm: DQ,\r\n        private requestContext: Config,\r\n        private internalContext: Config,\r\n        private partialIdsArray = [],\r\n        private timeout = NO_TIMEOUT,\r\n        private ajaxType = REQ_TYPE_POST,\r\n        private contentType = URL_ENCODED,\r\n        private xhrObject = new XMLHttpRequest()\r\n    ) {\r\n\r\n    }\r\n\r\n    start(): AsyncRunnable<XMLHttpRequest> {\r\n\r\n        let fsExec = failSaveExecute;\r\n        let xhrObject = this.xhrObject;\r\n\r\n        try {\r\n\r\n            let viewState = jsf.getViewState(this.sourceForm.getAsElem(0).value);\r\n            let formData: XhrFormData = new XhrFormData(viewState);\r\n\r\n            this.contentType = formData.isMultipartRequest ? MULTIPART : this.contentType;\r\n\r\n            //next step the pass through parameters are merged in for post params\r\n            let requestContext = this.requestContext;\r\n            let passThroughParams = requestContext.getIf(CTX_PARAM_PASS_THR);\r\n            formData.shallowMerge(passThroughParams);\r\n\r\n            this.responseContext = passThroughParams.deepCopy;\r\n\r\n            //we have to shift the internal passthroughs around to build up our response context\r\n            let responseContext = this.responseContext;\r\n\r\n            responseContext.assign(CTX_PARAM_MF_INTERNAL).value = this.internalContext.value;\r\n\r\n            //per spec the onevent and onerrors must be passed through to the response\r\n            responseContext.assign(ON_EVENT).value = requestContext.getIf(ON_EVENT).value;\r\n            responseContext.assign(ON_ERROR).value = requestContext.getIf(ON_ERROR).value;\r\n\r\n            xhrObject.open(this.ajaxType, this.resolveFinalUrl(formData), true);\r\n\r\n            //adding timeout\r\n            this.timeout ? xhrObject.timeout = this.timeout : null;\r\n\r\n            //a bug in the xhr stub library prevents the setRequestHeader to be properly executed on fake xhr objects\r\n            //normal browsers should resolve this\r\n            //tests can quietly fail on this one\r\n\r\n            fsExec(() => xhrObject.setRequestHeader(CONTENT_TYPE, `${this.contentType}; charset=utf-8`));\r\n            fsExec(() => xhrObject.setRequestHeader(HEAD_FACES_REQ, VAL_AJAX));\r\n\r\n            //probably not needed anymore, will test this\r\n            //some webkit based mobile browsers do not follow the w3c spec of\r\n            // setting the accept headers automatically\r\n            fsExec(() => xhrObject.setRequestHeader(REQ_ACCEPT, STD_ACCEPT));\r\n\r\n            this.sendEvent(BEGIN);\r\n\r\n            this.sendRequest(formData);\r\n\r\n        } catch (e) {\r\n            //_onError//_onError\r\n            this.handleError(e);\r\n        }\r\n        return this;\r\n    }\r\n\r\n    cancel() {\r\n        try {\r\n            this.xhrObject.abort();\r\n        } catch (e) {\r\n            this.handleError(e);\r\n        }\r\n    }\r\n\r\n    /*\r\n     * Promise bindings\r\n     *\r\n     * We have to delegate a few calls to our promise\r\n     * to make the callback from the outside and inside work with our\r\n     * xhr promise\r\n     *\r\n     */\r\n    protected get $promise(): Promise<any> {\r\n        if (!this.xhrPromise) {\r\n            this.xhrPromise = new (getPromise())((resolve: Consumer<any>, reject: Consumer<any>) => {\r\n                //to allow callback into xhr over promises\r\n                //we have to register the callbacks\r\n                //accordingly\r\n                this.registerXhrCallbacks(resolve, reject);\r\n            });\r\n        }\r\n        return this.xhrPromise;\r\n    }\r\n\r\n    catch(func: (data: any) => any): AsyncRunnable<XMLHttpRequest> {\r\n        this.$promise.catch(func);\r\n        return this;\r\n    }\r\n\r\n    finally(func: () => void): AsyncRunnable<XMLHttpRequest> {\r\n        //no ie11 support we probably are going to revert to shims for that one\r\n        (<any>this.$promise).then(func).catch(func);\r\n        //(<any>this.$promise).then(func);\r\n        return this;\r\n    }\r\n\r\n    then(func: (data: any) => any): AsyncRunnable<XMLHttpRequest> {\r\n        this.$promise.then(func);\r\n        return this;\r\n    }\r\n\r\n    /**\r\n     * attaches the internal event and processing\r\n     * callback within the promise to our xhr object\r\n     *\r\n     * @param resolve\r\n     * @param reject\r\n     */\r\n    protected registerXhrCallbacks(resolve: Consumer<any>, reject: Consumer<any>) {\r\n        let xhrObject = this.xhrObject;\r\n\r\n        xhrObject.onabort = () => {\r\n            this.onAbort(resolve, reject);\r\n        };\r\n        xhrObject.ontimeout = () => {\r\n            this.onTimeout(resolve, reject);\r\n        };\r\n        xhrObject.onload = () => {\r\n            this.onSuccess(this.xhrObject, resolve, reject)\r\n        };\r\n        xhrObject.onloadend = () => {\r\n            this.onDone(this.xhrObject, resolve, reject);\r\n        };\r\n        xhrObject.onerror = (errorData: any) => {\r\n            this.onError(errorData, resolve, reject);\r\n        };\r\n    }\r\n\r\n    /*\r\n     * xhr processing callbacks\r\n     *\r\n     * Those methods are the callbacks called by\r\n     * the xhr object depending on its own state\r\n     */\r\n\r\n    protected onAbort(resolve: Consumer<any>, reject: Consumer<any>) {\r\n        reject();\r\n    }\r\n\r\n    protected onTimeout(resolve: Consumer<any>, reject: Consumer<any>) {\r\n        this.sendEvent(STATE_EVT_TIMEOUT);\r\n        reject();\r\n    }\r\n\r\n    protected onSuccess(data: any, resolve: Consumer<any>, reject: Consumer<any>) {\r\n\r\n        this.sendEvent(COMPLETE);\r\n\r\n        //malforms always result in empty response xml\r\n        if(!this?.xhrObject?.responseXML) {\r\n            this.handleMalFormedXML(resolve);\r\n            return;\r\n        }\r\n\r\n        jsf.ajax.response(this.xhrObject, this.responseContext.value ?? {});\r\n    }\r\n\r\n    private handleMalFormedXML(resolve: Function) {\r\n        this.stopProgress = true;\r\n        let errorData = {\r\n            type: ERROR,\r\n            status: MALFORMEDXML,\r\n            responseCode: 200,\r\n            responseText: this.xhrObject?.responseText,\r\n            source: {\r\n                id: this.source.id.value\r\n            }\r\n        };\r\n        try {\r\n            Implementation.sendError(errorData);\r\n        } finally {\r\n            resolve(errorData);\r\n        }\r\n        //non blocking non clearing\r\n    }\r\n\r\n    protected onDone(data: any, resolve: Consumer<any>, reject: Consumer<any>) {\r\n        if(this.stopProgress) {\r\n            return;\r\n        }\r\n        resolve(data);\r\n    }\r\n\r\n    protected onError(errorData: any, resolve: Consumer<any>, reject: Consumer<any>) {\r\n        this.handleError(errorData);\r\n        reject();\r\n    }\r\n\r\n    /*\r\n     * other helpers\r\n     */\r\n    private sendEvent(evtType: string) {\r\n        let eventData = EventData.createFromRequest(this.xhrObject, this.requestContext, evtType);\r\n        try {\r\n            //user code error, we might cover\r\n            //this in onError but also we cannot swallow it\r\n            //we need to resolve the local handlers lazyly,\r\n            //because some frameworks might decorate them over the context in the response\r\n            let eventHandler = this.resolveHandlerFunc(ON_EVENT);;\r\n            Implementation.sendEvent(eventData,  eventHandler);\r\n        } catch (e) {\r\n            this.handleError(e);\r\n            throw e;\r\n        }\r\n    }\r\n\r\n    private handleError(exception) {\r\n        let errorData = ErrorData.fromClient(exception);\r\n\r\n        let eventHandler = this.resolveHandlerFunc(ON_ERROR);\r\n        Implementation.sendError(errorData, eventHandler);\r\n    }\r\n\r\n    /**\r\n     * resolves the event handlers lazly\r\n     * so that if some decoration happens in between we can deal with it\r\n     *\r\n     * @param funcName\r\n     */\r\n    private resolveHandlerFunc(funcName: string) {\r\n        return this.responseContext.getIf(funcName)\r\n                .orElse(this.requestContext.getIf(funcName).value)\r\n                .orElse(EMPTY_FUNC).value;\r\n    }\r\n\r\n    private resolveTargetUrl(srcFormElement: HTMLFormElement) {\r\n        return (typeof srcFormElement.elements[ENCODED_URL] == 'undefined') ?\r\n            srcFormElement.action :\r\n            srcFormElement.elements[ENCODED_URL].value;\r\n    }\r\n\r\n    protected sendRequest(formData: XhrFormData) {\r\n        let isPost = this.ajaxType != REQ_TYPE_GET;\r\n        if(formData.isMultipartRequest) {\r\n            this.xhrObject.send((isPost) ? formData.toFormData() : null);\r\n        } else {\r\n            this.xhrObject.send((isPost) ? formData.toString() : null);\r\n        }\r\n    }\r\n\r\n    private resolveFinalUrl(formData: XhrFormData) {\r\n        let targetUrl = this.resolveTargetUrl(<HTMLFormElement>this.sourceForm.getAsElem(0).value);\r\n\r\n        return targetUrl + (this.ajaxType == REQ_TYPE_GET ? \"?\" + formData.toString() : \"\");\r\n    }\r\n\r\n\r\n\r\n}"],"mappings":";AAAA;;;;;;;;;;;;;;AAcA;;AAKA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAeA;AAaA;;;;;;;;;;;;;;AAcA;AACA;AAKA;AACA;AACA;AACA;AACA;AARA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AA1BA;AA6BA;AAEA;AAAA;AAEA;AACA;AAEA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AACA;AAEA;AAEA;AAEA;AAAA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAUA;AARA;;;;;;;AAOA;AACA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAAA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;;;;;;AAMA;AACA;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;;;;AAKA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;;AAEA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AAEA;;;;;AAKA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AAEA;AACA;AAEA;AACA;AAIA;AAAA;AAlSA;","sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/main/typescript/impl/xhrCore/XhrRequest.ts\n");
/***/ })
/******/ })));
//# sourceMappingURL=jsf.js.map
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment