UNPKG

surveyjs-widgets

Version:

Custom widgets for the SurveyJS library

370 lines (355 loc) 30 kB
(function webpackUniversalModuleDefinition(root, factory) { if(typeof exports === 'object' && typeof module === 'object') module.exports = factory(require("inputmask")); else if(typeof define === 'function' && define.amd) define("widgets/inputmask", ["inputmask"], factory); else if(typeof exports === 'object') exports["widgets/inputmask"] = factory(require("inputmask")); else root["widgets/inputmask"] = factory(root["Inputmask"]); })(self, (__WEBPACK_EXTERNAL_MODULE_inputmask__) => { return /******/ (() => { // webpackBootstrap /******/ "use strict"; /******/ var __webpack_modules__ = ({ /***/ "inputmask": /*!******************************************************************************************************!*\ !*** external {"root":"Inputmask","commonjs2":"inputmask","commonjs":"inputmask","amd":"inputmask"} ***! \******************************************************************************************************/ /***/ ((module) => { module.exports = __WEBPACK_EXTERNAL_MODULE_inputmask__; /***/ }) /******/ }); /************************************************************************/ /******/ // The module cache /******/ var __webpack_module_cache__ = {}; /******/ /******/ // The require function /******/ function __webpack_require__(moduleId) { /******/ // Check if module is in cache /******/ var cachedModule = __webpack_module_cache__[moduleId]; /******/ if (cachedModule !== undefined) { /******/ return cachedModule.exports; /******/ } /******/ // Create a new module (and put it into the cache) /******/ var module = __webpack_module_cache__[moduleId] = { /******/ // no module.id needed /******/ // no module.loaded needed /******/ exports: {} /******/ }; /******/ /******/ // Execute the module function /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); /******/ /******/ // Return the exports of the module /******/ return module.exports; /******/ } /******/ /************************************************************************/ /******/ /* webpack/runtime/compat get default export */ /******/ (() => { /******/ // getDefaultExport function for compatibility with non-harmony modules /******/ __webpack_require__.n = (module) => { /******/ var getter = module && module.__esModule ? /******/ () => (module['default']) : /******/ () => (module); /******/ __webpack_require__.d(getter, { a: getter }); /******/ return getter; /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/define property getters */ /******/ (() => { /******/ // define getter functions for harmony exports /******/ __webpack_require__.d = (exports, definition) => { /******/ for(var key in definition) { /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); /******/ } /******/ } /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/hasOwnProperty shorthand */ /******/ (() => { /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) /******/ })(); /******/ /******/ /* webpack/runtime/make namespace object */ /******/ (() => { /******/ // define __esModule on exports /******/ __webpack_require__.r = (exports) => { /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); /******/ } /******/ Object.defineProperty(exports, '__esModule', { value: true }); /******/ }; /******/ })(); /******/ /************************************************************************/ var __webpack_exports__ = {}; // This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk. (() => { /*!**************************!*\ !*** ./src/inputmask.js ***! \**************************/ __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var inputmask__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! inputmask */ "inputmask"); /* harmony import */ var inputmask__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(inputmask__WEBPACK_IMPORTED_MODULE_0__); function init(Survey) { const updateTextItemPropInfo = function (propJSON) { const name = propJSON.name; propJSON.onGetValue = (obj) => { return !!obj.editor ? obj.editor[name] : obj[name]; }; propJSON.onSetValue = (obj, val) => { if(!!obj.editor) { obj.editor[name] = val; } else { obj[name] = val; } } } const updateColumnPropInfo = function (propJSON) { const name = propJSON.name; propJSON.visibleIf = (obj) => { return obj.cellType === "text"; }; propJSON.onGetValue = (obj) => { return obj.templateQuestion[name]; }; propJSON.onSetValue = (obj, val) => { obj.templateQuestion[name] = val; } } var widget = { name: "maskedit", numericGroupSeparator: ",", numericRadixPoint: undefined, numericAutoGroup: true, numericDigits: 2, numericDigitsOptional: false, numericPlaceholder: "0", autoUnmask: true, clearIncomplete: true, showMaskOnHover: true, unmaskAsNumber: false, widgetIsLoaded: function () { return typeof (inputmask__WEBPACK_IMPORTED_MODULE_0___default()) != "undefined"; }, isFit: function (question) { if (question.getType() == "multipletext") return true; return ( question.getType() == "text" && (question.inputMask != "none" || question.inputFormat) ); }, isDefaultRender: true, activatedByChanged: function (activatedBy) { if (Survey.Serializer.findProperty("text", "inputMask")) return; var properties = [ { name: "autoUnmask", type: "boolean", category: "general", showMode: "form", default: true, }, { name: "clearIncomplete", type: "boolean", category: "general", showMode: "form", default: true, }, { name: "showMaskOnHover", type: "boolean", category: "general", showMode: "form", default: true, }, { name: "inputFormat", showMode: "form", category: "general" }, { name: "inputMask", showMode: "form", category: "general", default: "none", choices: [ "none", "datetime", "currency", "decimal", "email", "phone", "ip", ], }, { name: "numericDigits", category: "general", visible: false, }, { name: "numericGroupSeparator", category: "general", default: ",", visible: false, }, { name: "options", category: "general", visible: false, }, { name: "unmaskAsNumber:boolean", category: "general", visible: false, }, { name: "prefix", category: "general", visible: false, }, { name: "suffix", category: "general", visible: false, }, ]; Survey.Serializer.addProperties("text", properties); properties.forEach(prop => { if(prop.visible !== false) { updateTextItemPropInfo(prop); } }); Survey.Serializer.addProperties("multipletextitem", properties); properties.forEach(prop => { if(prop.visible !== false) { updateColumnPropInfo(prop); } }); }, applyInputMask: function (surveyElement, el) { var rootWidget = this; var mask = surveyElement.inputMask !== "none" ? surveyElement.inputMask : surveyElement.inputFormat; var options = {}; if (typeof surveyElement.options === "object") { for (var option in surveyElement.options) { options[option] = surveyElement.options[option]; } } options.autoUnmask = typeof surveyElement.autoUnmask !== "undefined" ? surveyElement.autoUnmask : rootWidget.autoUnmask; options.clearIncomplete = typeof surveyElement.clearIncomplete !== "undefined" ? surveyElement.clearIncomplete : rootWidget.clearIncomplete; options.showMaskOnHover = typeof surveyElement.showMaskOnHover !== "undefined" ? surveyElement.showMaskOnHover : rootWidget.showMaskOnHover; options.unmaskAsNumber = typeof surveyElement.unmaskAsNumber !== "undefined" ? surveyElement.unmaskAsNumber : rootWidget.unmaskAsNumber; if (surveyElement.inputMask !== "none") { options.inputFormat = surveyElement.inputFormat; } if ( surveyElement.inputMask === "currency" || surveyElement.inputMask === "decimal" ) { options.groupSeparator = surveyElement.numericGroupSeparator || rootWidget.numericGroupSeparator; options.radixPoint = rootWidget.numericRadixPoint; options.autoGroup = rootWidget.numericAutoGroup; options.placeholder = rootWidget.numericPlaceholder; } if (surveyElement.inputMask === "currency") { options.digits = surveyElement.numericDigits || rootWidget.numericDigits; options.digitsOptional = rootWidget.numericDigitsOptional; options.prefix = surveyElement.prefix || ""; options.suffix = surveyElement.suffix || ""; options.placeholder = rootWidget.numericPlaceholder; } // if (surveyElement.inputMask == "datetime") { // mask = surveyElement.inputFormat; // } if (surveyElement.inputMask === "phone" && !!surveyElement.inputFormat) { mask = surveyElement.inputFormat; } inputmask__WEBPACK_IMPORTED_MODULE_0___default()(mask, options).mask(el); el.onblur = function () { if (!el.inputmask) return; if (surveyElement.value === el.inputmask.getemptymask()) { surveyElement.value = ""; } }; var customWidgetData = surveyElement.getType() === "multipletextitem" ? surveyElement.editorValue.customWidgetData : surveyElement.customWidgetData; el.oninput = function () { customWidgetData.isNeedRender = true; }; var pushValueHandler = function () { if (!el.inputmask) return; if (el.inputmask.isComplete()) { surveyElement.value = options.autoUnmask ? el.inputmask.unmaskedvalue() : el.value; } else { surveyElement.value = null; } }; el.onfocusout = el.onchange = pushValueHandler; var updateHandler = function () { el.value = surveyElement.value === undefined || surveyElement.value === null ? "" : surveyElement.value; }; surveyElement.valueChangedCallback = updateHandler; updateHandler(); }, afterRender: function (question, el) { if (question.getType() != "multipletext") { var input = el.querySelector("input") || el; this.applyInputMask(question, input); } else { for (var i = 0; i < question.items.length; i++) { var item = question.items[i]; if (item.inputMask != "none" || item.inputFormat) { var input = el.querySelector("#" + item.editor.inputId); if (input) { this.applyInputMask(item, input); } } } } }, willUnmount: function (question, el) { var input = el.querySelector("input") || el; if (!!input && !!input.inputmask) { input.inputmask.remove(); } }, }; Survey.CustomWidgetCollection.Instance.addCustomWidget(widget); } if (typeof Survey !== "undefined") { init(Survey); } /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (init); })(); /******/ return __webpack_exports__; /******/ })() ; }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"widgets/inputmask.js","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;;;;;;;;;;ACVA;;;;;;UCAA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;WCtBA;WACA;WACA;WACA;WACA;WACA,iCAAiC,WAAW;WAC5C;WACA;;;;;WCPA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA;;;;;WCPA;;;;;WCAA;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D;;;;;;;;;;;;;;;;ACNkC;;AAElC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;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,oBAAoB,kDAAS;AAC7B,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,+BAA+B;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM,gDAAS;;AAEf;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,QAAQ;AACR,wBAAwB,2BAA2B;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA,iEAAe,IAAI,EAAC","sources":["webpack://surveyjs-widgets/webpack/universalModuleDefinition","webpack://surveyjs-widgets/external umd {\"root\":\"Inputmask\",\"commonjs2\":\"inputmask\",\"commonjs\":\"inputmask\",\"amd\":\"inputmask\"}","webpack://surveyjs-widgets/webpack/bootstrap","webpack://surveyjs-widgets/webpack/runtime/compat get default export","webpack://surveyjs-widgets/webpack/runtime/define property getters","webpack://surveyjs-widgets/webpack/runtime/hasOwnProperty shorthand","webpack://surveyjs-widgets/webpack/runtime/make namespace object","webpack://surveyjs-widgets/./src/inputmask.js"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"inputmask\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"widgets/inputmask\", [\"inputmask\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"widgets/inputmask\"] = factory(require(\"inputmask\"));\n\telse\n\t\troot[\"widgets/inputmask\"] = factory(root[\"Inputmask\"]);\n})(self, (__WEBPACK_EXTERNAL_MODULE_inputmask__) => {\nreturn ","module.exports = __WEBPACK_EXTERNAL_MODULE_inputmask__;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","import Inputmask from \"inputmask\";\n\nfunction init(Survey) {\n  const updateTextItemPropInfo = function (propJSON) {\n    const name = propJSON.name;\n    propJSON.onGetValue = (obj) => {\n      return !!obj.editor ? obj.editor[name] : obj[name];\n    };\n    propJSON.onSetValue = (obj, val) => {\n      if(!!obj.editor) {\n        obj.editor[name] = val;\n      } else {\n        obj[name] = val;\n      }\n    }    \n  }\n  const updateColumnPropInfo = function (propJSON) {\n    const name = propJSON.name;\n    propJSON.visibleIf = (obj) => {\n      return obj.cellType === \"text\";\n    };\n    propJSON.onGetValue = (obj) => {\n      return obj.templateQuestion[name];\n    };\n    propJSON.onSetValue = (obj, val) => {\n      obj.templateQuestion[name] = val;\n    }    \n  }\n  var widget = {\n    name: \"maskedit\",\n    numericGroupSeparator: \",\",\n    numericRadixPoint: undefined,\n    numericAutoGroup: true,\n    numericDigits: 2,\n    numericDigitsOptional: false,\n    numericPlaceholder: \"0\",\n    autoUnmask: true,\n    clearIncomplete: true,\n    showMaskOnHover: true,\n    unmaskAsNumber: false,    \n    widgetIsLoaded: function () {\n      return typeof Inputmask != \"undefined\";\n    },\n    isFit: function (question) {\n      if (question.getType() == \"multipletext\") return true;\n      return (\n        question.getType() == \"text\" &&\n        (question.inputMask != \"none\" || question.inputFormat)\n      );\n    },\n    isDefaultRender: true,\n    activatedByChanged: function (activatedBy) {\n      if (Survey.Serializer.findProperty(\"text\", \"inputMask\")) return;\n      var properties = [\n        {\n          name: \"autoUnmask\",\n          type: \"boolean\",\n          category: \"general\",\n          showMode: \"form\",\n          default: true,\n        },\n        {\n          name: \"clearIncomplete\",\n          type: \"boolean\",\n          category: \"general\",\n          showMode: \"form\",\n          default: true,\n        },\n        {\n          name: \"showMaskOnHover\",\n          type: \"boolean\",\n          category: \"general\",\n          showMode: \"form\",\n          default: true,\n        },\n        { \n          name: \"inputFormat\", \n          showMode: \"form\",\n          category: \"general\" },\n        {\n          name: \"inputMask\",\n          showMode: \"form\",\n          category: \"general\",\n          default: \"none\",\n          choices: [\n            \"none\",\n            \"datetime\",\n            \"currency\",\n            \"decimal\",\n            \"email\",\n            \"phone\",\n            \"ip\",\n          ],\n        },\n        {\n          name: \"numericDigits\",\n          category: \"general\",\n          visible: false,\n        },\n        {\n          name: \"numericGroupSeparator\",\n          category: \"general\",\n          default: \",\",\n          visible: false,\n        },\n        {\n          name: \"options\",\n          category: \"general\",\n          visible: false,\n        },\n        {\n          name: \"unmaskAsNumber:boolean\",\n          category: \"general\",\n          visible: false,\n        },\n        {\n          name: \"prefix\",\n          category: \"general\",\n          visible: false,\n        },\n        {\n          name: \"suffix\",\n          category: \"general\",\n          visible: false,\n        },\n      ];\n      Survey.Serializer.addProperties(\"text\", properties);\n      properties.forEach(prop => {\n        if(prop.visible !== false) {\n          updateTextItemPropInfo(prop);\n        }\n      });\n      Survey.Serializer.addProperties(\"multipletextitem\", properties);\n      properties.forEach(prop => {\n        if(prop.visible !== false) {\n          updateColumnPropInfo(prop);\n        }\n      });\n    },\n    applyInputMask: function (surveyElement, el) {\n      var rootWidget = this;\n      var mask =\n        surveyElement.inputMask !== \"none\"\n          ? surveyElement.inputMask\n          : surveyElement.inputFormat;\n      var options = {};\n      if (typeof surveyElement.options === \"object\") {\n        for (var option in surveyElement.options) {\n          options[option] = surveyElement.options[option];\n        }\n      }\n      options.autoUnmask = typeof surveyElement.autoUnmask !== \"undefined\"\n        ? surveyElement.autoUnmask\n        : rootWidget.autoUnmask;\n      options.clearIncomplete = typeof surveyElement.clearIncomplete !== \"undefined\"\n        ? surveyElement.clearIncomplete\n        : rootWidget.clearIncomplete;\n      options.showMaskOnHover = typeof surveyElement.showMaskOnHover !== \"undefined\"\n        ? surveyElement.showMaskOnHover\n        : rootWidget.showMaskOnHover;\n      options.unmaskAsNumber = typeof surveyElement.unmaskAsNumber !== \"undefined\"\n          ? surveyElement.unmaskAsNumber\n          : rootWidget.unmaskAsNumber;\n      if (surveyElement.inputMask !== \"none\") {\n        options.inputFormat = surveyElement.inputFormat;\n      }\n      if (\n        surveyElement.inputMask === \"currency\" ||\n        surveyElement.inputMask === \"decimal\"\n      ) {\n        options.groupSeparator = surveyElement.numericGroupSeparator || rootWidget.numericGroupSeparator;\n        options.radixPoint = rootWidget.numericRadixPoint;\n        options.autoGroup = rootWidget.numericAutoGroup;\n        options.placeholder = rootWidget.numericPlaceholder;        \n      }\n      if (surveyElement.inputMask === \"currency\") {\n        options.digits = surveyElement.numericDigits || rootWidget.numericDigits;\n        options.digitsOptional = rootWidget.numericDigitsOptional;\n        options.prefix = surveyElement.prefix || \"\";\n        options.suffix = surveyElement.suffix || \"\";\n        options.placeholder = rootWidget.numericPlaceholder;        \n      }\n      // if (surveyElement.inputMask == \"datetime\") {\n      //   mask = surveyElement.inputFormat;\n      // }\n      if (surveyElement.inputMask === \"phone\" && !!surveyElement.inputFormat) {\n        mask = surveyElement.inputFormat;\n      }\n      Inputmask(mask, options).mask(el);\n\n      el.onblur = function () {\n        if (!el.inputmask) return;\n        if (surveyElement.value === el.inputmask.getemptymask()) {\n          surveyElement.value = \"\";\n        }\n      };\n\n      var customWidgetData =\n        surveyElement.getType() === \"multipletextitem\"\n          ? surveyElement.editorValue.customWidgetData\n          : surveyElement.customWidgetData;\n      el.oninput = function () {\n        customWidgetData.isNeedRender = true;\n      };\n\n      var pushValueHandler = function () {        \n        if (!el.inputmask) return;\n        if (el.inputmask.isComplete()) {\n          surveyElement.value = options.autoUnmask\n            ? el.inputmask.unmaskedvalue()\n            : el.value;\n        } else {\n          surveyElement.value = null;\n        }\n      };\n      el.onfocusout = el.onchange = pushValueHandler;\n\n      var updateHandler = function () {\n        el.value =\n          surveyElement.value === undefined || surveyElement.value === null\n            ? \"\"\n            : surveyElement.value;\n      };\n      surveyElement.valueChangedCallback = updateHandler;\n      updateHandler();\n    },\n    afterRender: function (question, el) {      \n      if (question.getType() != \"multipletext\") {\n        var input = el.querySelector(\"input\") || el;\n        this.applyInputMask(question, input);\n      } else {\n        for (var i = 0; i < question.items.length; i++) {\n          var item = question.items[i];\n          if (item.inputMask != \"none\" || item.inputFormat) {\n            var input = el.querySelector(\"#\" + item.editor.inputId);\n            if (input) {\n              this.applyInputMask(item, input);\n            }\n          }\n        }\n      }\n    },\n    willUnmount: function (question, el) {\n      var input = el.querySelector(\"input\") || el;\n      if (!!input && !!input.inputmask) {\n        input.inputmask.remove();\n      }\n    },\n  };\n\n  Survey.CustomWidgetCollection.Instance.addCustomWidget(widget);\n}\n\nif (typeof Survey !== \"undefined\") {\n  init(Survey);\n}\n\nexport default init;\n"],"names":[],"sourceRoot":""}