surveyjs-widgets
Version:
Custom widgets for the SurveyJS library
370 lines (355 loc) • 30 kB
JavaScript
(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":""}