surveyjs-widgets
Version:
Custom widgets for the SurveyJS library
372 lines (358 loc) • 32.3 kB
JavaScript
(function webpackUniversalModuleDefinition(root, factory) {
if(typeof exports === 'object' && typeof module === 'object')
module.exports = factory(require("nouislider"));
else if(typeof define === 'function' && define.amd)
define("widgets/nouislider", ["nouislider"], factory);
else if(typeof exports === 'object')
exports["widgets/nouislider"] = factory(require("nouislider"));
else
root["widgets/nouislider"] = factory(root["noUiSlider"]);
})(self, (__WEBPACK_EXTERNAL_MODULE_nouislider__) => {
return /******/ (() => { // webpackBootstrap
/******/ var __webpack_modules__ = ({
/***/ "./node_modules/svg-inline-loader/index.js?classPrefix!./src/images/nouislider.svg":
/*!*****************************************************************************************!*\
!*** ./node_modules/svg-inline-loader/index.js?classPrefix!./src/images/nouislider.svg ***!
\*****************************************************************************************/
/***/ ((module) => {
module.exports = "<svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><rect y=\"10\" width=\"16\" height=\"2\"></rect><polygon points=\"2,4 2,7 4,9 6,7 6,4 \"></polygon><polygon points=\"10,4 10,7 12,9 14,7 14,4 \"></polygon></svg>"
/***/ }),
/***/ "nouislider":
/*!**********************************************************************************************************!*\
!*** external {"root":"noUiSlider","commonjs2":"nouislider","commonjs":"nouislider","amd":"nouislider"} ***!
\**********************************************************************************************************/
/***/ ((module) => {
"use strict";
module.exports = __WEBPACK_EXTERNAL_MODULE_nouislider__;
/***/ })
/******/ });
/************************************************************************/
/******/ // 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 in strict mode.
(() => {
"use strict";
/*!***************************!*\
!*** ./src/nouislider.js ***!
\***************************/
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
/* harmony import */ var nouislider__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! nouislider */ "nouislider");
/* harmony import */ var nouislider__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(nouislider__WEBPACK_IMPORTED_MODULE_0__);
function init(Survey) {
const iconId = "icon-nouislider";
const componentName = "nouislider";
Survey.SvgRegistry && Survey.SvgRegistry.registerIconFromSvg(iconId, __webpack_require__(/*! svg-inline-loader?classPrefix!./images/nouislider.svg */ "./node_modules/svg-inline-loader/index.js?classPrefix!./src/images/nouislider.svg"), "");
var widget = {
name: componentName,
title: "noUiSlider",
iconName: iconId,
widgetIsLoaded: function () {
return typeof (nouislider__WEBPACK_IMPORTED_MODULE_0___default()) != "undefined";
},
isFit: function (question) {
return question.getType() === componentName;
},
htmlTemplate:
"<div><div></div></div>",
activatedByChanged: function (activatedBy) {
Survey.Serializer.addClass(componentName, [], null, "empty");
let registerQuestion = Survey.ElementFactory.Instance.registerCustomQuestion;
if (!!registerQuestion) registerQuestion(componentName);
Survey.Serializer.addProperties(componentName, [
{
name: "step:number",
category: "slider",
categoryIndex: 1,
default: 1,
},
{
name: "rangeMin:number",
category: "slider",
default: 0,
},
{
name: "rangeMax:number",
category: "slider",
default: 100,
},
{
name: "pipsMode",
category: "slider",
default: "positions",
},
{
name: "pipsValues:itemvalues",
category: "slider",
default: [0, 25, 50, 75, 100],
},
{
name: "pipsText:itemvalues",
category: "slider",
default: [0, 25, 50, 75, 100],
},
{
name: "pipsDensity:number",
category: "slider",
default: 5,
},
{
name: "orientation",
category: "slider",
default: "horizontal",
choices: ["horizontal", "vertical"]
},
{
name: "direction:string",
category: "slider",
default: "ltr",
},
{
name: "tooltips:boolean",
category: "slider",
default: true,
},
]);
},
afterRender: function (question, el) {
el.style.paddingBottom = "19px";
el.style.paddingLeft = "20px";
el.style.paddingRight = "20px";
el.style.paddingTop = "44px";
el = el.children[0];
el.style.marginBottom = "60px";
if (question.orientation === "vertical") {
el.style.height = "250px";
el.style.marginLeft = "60px";
}
var slider = nouislider__WEBPACK_IMPORTED_MODULE_0___default().create(el, {
start: question.rangeMin <= question.value && question.value <= question.rangeMax ?
question.value : (question.rangeMin + question.rangeMax) / 2,
connect: [true, false],
step: question.step,
tooltips: question.tooltips,
pips: {
mode: question.pipsMode || "positions",
values: question.pipsValues.map(function (pVal) {
var pipValue = pVal;
if (pVal.value !== undefined) {
pipValue = pVal.value;
}
return parseInt(pipValue);
}),
density: question.pipsDensity || 5,
format: {
to: function (pVal) {
var pipText = pVal;
question.pipsText.map(function (el) {
if (el.text !== undefined && pVal === el.value) {
pipText = el.text;
}
});
return pipText;
},
},
},
range: {
min: question.rangeMin,
max: question.rangeMax,
},
orientation: question.orientation,
direction: question.direction,
});
slider.on("change", function () {
question.value = Number(slider.get());
});
question.updateSliderProperties = function () {
const elems = document.getElementsByClassName("noUi-pips");
if (elems.length > 0) elems[elems.length - 1].style.display = "none";
if (elems.length > 1) elems[elems.length - 2].style.display = "none";
var getStart = function (currentStart) {
return question.rangeMin + Math.round((currentStart - question.rangeMin) / question.step) * question.step;
}
slider.updateOptions(
{
step: question.step,
start: question.rangeMin <= question.value && question.value <= question.rangeMax ?
getStart(question.value) : getStart((question.rangeMin + question.rangeMax) / 2),
range: {
min: question.rangeMin,
max: question.rangeMax
}
}, true);
slider.pips(
{
mode: question.pipsMode || "positions",
values: question.pipsValues.map(function (pVal) {
var pipValue = pVal;
if (pVal.value !== undefined) {
pipValue = pVal.value;
}
return parseInt(pipValue);
}),
density: question.pipsDensity || 5,
format: {
to: function (pVal) {
var pipText = pVal;
question.pipsText.map(function (el) {
if (el.text !== undefined && pVal === el.value) {
pipText = el.text;
}
});
return pipText;
},
},
});
};
var updateValueHandler = function () {
slider.set(question.value);
};
if (question.isReadOnly) {
el.setAttribute("disabled", true);
}
updateValueHandler();
question.noUiSlider = slider;
question.registerFunctionOnPropertiesValueChanged(
["pipsValues", "step", "rangeMin", "rangeMax", "pipsMode", "pipsDensity"],
question.updateSliderProperties
);
question.valueChangedCallback = updateValueHandler;
question.readOnlyChangedCallback = function () {
if (question.isReadOnly) {
el.setAttribute("disabled", true);
} else {
el.removeAttribute("disabled");
}
};
},
willUnmount: function (question, el) {
if (!!question.noUiSlider) {
question.noUiSlider.destroy();
question.noUiSlider = null;
}
question.readOnlyChangedCallback = null;
question.valueChangedCallback = null;
if (!question.updateSliderProperties) return;
question.unRegisterFunctionOnPropertiesValueChanged(
["pipsValues", "step", "rangeMin", "rangeMax", "pipsMode", "pipsDensity"],
question.updateSliderProperties
);
question.updateSliderProperties = undefined
},
pdfRender: function (_, options) {
if (options.question.getType() === componentName) {
var point = options.module.SurveyHelper.createPoint(
options.module.SurveyHelper.mergeRects.apply(null, options.bricks)
);
point.xLeft += options.controller.unitWidth;
point.yTop +=
options.controller.unitHeight *
options.module.FlatQuestion.CONTENT_GAP_VERT_SCALE;
var rect = options.module.SurveyHelper.createTextFieldRect(
point,
options.controller
);
if (options.module.SurveyHelper.shouldRenderReadOnly(this.question, this.controller)) {
options.bricks.push(new options.module.TextFieldBrick(
options.question,
options.controller,
rect,
true,
options.question.id,
options.question.value || options.question.defaultValue || "",
"",
options.question.isReadOnly,
false,
"text"
));
} else {
return new Promise(resolve => {
options.module.SurveyHelper.createCommentFlat(point, options.question,
options.controller, true, { rows: options.module.FlatTextbox.MULTILINE_TEXT_ROWS_COUNT }).then((brick) => {
options.bricks.push(brick);
resolve();
})
})
}
}
},
};
Survey.CustomWidgetCollection.Instance.addCustomWidget(widget, "customtype");
}
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/nouislider.js","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;;;;;;;;;ACVA;;;;;;;;;;;ACAA;;;;;;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;;;;;;;;;;;;;;;;;ACNoC;;AAEpC;AACA;AACA;AACA,uEAAuE,mBAAO,CAAC,gJAAuD;AACtI;AACA;AACA;AACA;AACA;AACA,oBAAoB,mDAAU;AAC9B,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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,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,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,wDAAiB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe;AACf;AACA,aAAa;AACb,WAAW;AACX,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,OAAO;AACP;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA,eAAe;AACf,aAAa;AACb,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,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,UAAU;AACV;AACA;AACA,0CAA0C,4DAA4D;AACtG;AACA;AACA,eAAe;AACf,WAAW;AACX;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;;AAEA,iEAAe,IAAI,EAAC","sources":["webpack://surveyjs-widgets/webpack/universalModuleDefinition","webpack://surveyjs-widgets/./src/images/nouislider.svg","webpack://surveyjs-widgets/external umd {\"root\":\"noUiSlider\",\"commonjs2\":\"nouislider\",\"commonjs\":\"nouislider\",\"amd\":\"nouislider\"}","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/nouislider.js"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"nouislider\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"widgets/nouislider\", [\"nouislider\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"widgets/nouislider\"] = factory(require(\"nouislider\"));\n\telse\n\t\troot[\"widgets/nouislider\"] = factory(root[\"noUiSlider\"]);\n})(self, (__WEBPACK_EXTERNAL_MODULE_nouislider__) => {\nreturn ","module.exports = \"<svg viewBox=\\\"0 0 16 16\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\"><rect y=\\\"10\\\" width=\\\"16\\\" height=\\\"2\\\"></rect><polygon points=\\\"2,4 2,7 4,9 6,7 6,4 \\\"></polygon><polygon points=\\\"10,4 10,7 12,9 14,7 14,4 \\\"></polygon></svg>\"","module.exports = __WEBPACK_EXTERNAL_MODULE_nouislider__;","// 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 noUiSlider from \"nouislider\";\n\nfunction init(Survey) {\n  const iconId = \"icon-nouislider\";\n  const componentName = \"nouislider\";\n  Survey.SvgRegistry && Survey.SvgRegistry.registerIconFromSvg(iconId, require('svg-inline-loader?classPrefix!./images/nouislider.svg'), \"\");\n  var widget = {\n    name: componentName,\n    title: \"noUiSlider\",\n    iconName: iconId,\n    widgetIsLoaded: function () {\n      return typeof noUiSlider != \"undefined\";\n    },\n    isFit: function (question) {\n      return question.getType() === componentName;\n    },\n    htmlTemplate:\n      \"<div><div></div></div>\",\n    activatedByChanged: function (activatedBy) {\n      Survey.Serializer.addClass(componentName, [], null, \"empty\");\n      let registerQuestion = Survey.ElementFactory.Instance.registerCustomQuestion;\n      if (!!registerQuestion) registerQuestion(componentName);\n      Survey.Serializer.addProperties(componentName, [\n        {\n          name: \"step:number\",\n          category: \"slider\",\n          categoryIndex: 1,\n          default: 1,\n        },\n        {\n          name: \"rangeMin:number\",\n          category: \"slider\",\n          default: 0,\n        },\n        {\n          name: \"rangeMax:number\",\n          category: \"slider\",\n          default: 100,\n        },\n        {\n          name: \"pipsMode\",\n          category: \"slider\",\n          default: \"positions\",\n        },\n        {\n          name: \"pipsValues:itemvalues\",\n          category: \"slider\",\n          default: [0, 25, 50, 75, 100],\n        },\n        {\n          name: \"pipsText:itemvalues\",\n          category: \"slider\",\n          default: [0, 25, 50, 75, 100],\n        },\n        {\n          name: \"pipsDensity:number\",\n          category: \"slider\",\n          default: 5,\n        },\n        {\n          name: \"orientation\",\n          category: \"slider\",\n          default: \"horizontal\",\n          choices: [\"horizontal\", \"vertical\"]\n        },\n        {\n          name: \"direction:string\",\n          category: \"slider\",\n          default: \"ltr\",\n        },\n        {\n          name: \"tooltips:boolean\",\n          category: \"slider\",\n          default: true,\n        },\n      ]);\n    },\n    afterRender: function (question, el) {\n      el.style.paddingBottom = \"19px\";\n      el.style.paddingLeft = \"20px\";\n      el.style.paddingRight = \"20px\";\n      el.style.paddingTop = \"44px\";\n      el = el.children[0];\n      el.style.marginBottom = \"60px\";\n      if (question.orientation === \"vertical\") {\n        el.style.height = \"250px\";\n        el.style.marginLeft = \"60px\";\n      }\n      var slider = noUiSlider.create(el, {\n        start: question.rangeMin <= question.value && question.value <= question.rangeMax ?\n          question.value : (question.rangeMin + question.rangeMax) / 2,\n        connect: [true, false],\n        step: question.step,\n        tooltips: question.tooltips,\n        pips: {\n          mode: question.pipsMode || \"positions\",\n          values: question.pipsValues.map(function (pVal) {\n            var pipValue = pVal;\n            if (pVal.value !== undefined) {\n              pipValue = pVal.value;\n            }\n            return parseInt(pipValue);\n          }),\n          density: question.pipsDensity || 5,\n          format: {\n            to: function (pVal) {\n              var pipText = pVal;\n              question.pipsText.map(function (el) {\n                if (el.text !== undefined && pVal === el.value) {\n                  pipText = el.text;\n                }\n              });\n              return pipText;\n            },\n          },\n        },\n        range: {\n          min: question.rangeMin,\n          max: question.rangeMax,\n        },\n        orientation: question.orientation,\n        direction: question.direction,\n      });\n      slider.on(\"change\", function () {\n        question.value = Number(slider.get());\n      });\n      question.updateSliderProperties = function () {\n        const elems = document.getElementsByClassName(\"noUi-pips\");\n        if (elems.length > 0) elems[elems.length - 1].style.display = \"none\";\n        if (elems.length > 1) elems[elems.length - 2].style.display = \"none\";\n        var getStart = function (currentStart) {\n          return question.rangeMin + Math.round((currentStart - question.rangeMin) / question.step) * question.step;\n        }\n        slider.updateOptions(\n          {\n            step: question.step,\n            start: question.rangeMin <= question.value && question.value <= question.rangeMax ?\n              getStart(question.value) : getStart((question.rangeMin + question.rangeMax) / 2),\n            range: {\n              min: question.rangeMin,\n              max: question.rangeMax\n            }\n          }, true);\n        slider.pips(\n          {\n            mode: question.pipsMode || \"positions\",\n            values: question.pipsValues.map(function (pVal) {\n              var pipValue = pVal;\n              if (pVal.value !== undefined) {\n                pipValue = pVal.value;\n              }\n              return parseInt(pipValue);\n            }),\n            density: question.pipsDensity || 5,\n            format: {\n              to: function (pVal) {\n                var pipText = pVal;\n                question.pipsText.map(function (el) {\n                  if (el.text !== undefined && pVal === el.value) {\n                    pipText = el.text;\n                  }\n                });\n                return pipText;\n              },\n            },\n          });\n      };\n      var updateValueHandler = function () {\n        slider.set(question.value);\n      };\n      if (question.isReadOnly) {\n        el.setAttribute(\"disabled\", true);\n      }\n      updateValueHandler();\n      question.noUiSlider = slider;\n      question.registerFunctionOnPropertiesValueChanged(\n        [\"pipsValues\", \"step\", \"rangeMin\", \"rangeMax\", \"pipsMode\", \"pipsDensity\"],\n        question.updateSliderProperties\n      );\n      question.valueChangedCallback = updateValueHandler;\n      question.readOnlyChangedCallback = function () {\n        if (question.isReadOnly) {\n          el.setAttribute(\"disabled\", true);\n        } else {\n          el.removeAttribute(\"disabled\");\n        }\n      };\n    },\n    willUnmount: function (question, el) {\n      if (!!question.noUiSlider) {\n        question.noUiSlider.destroy();\n        question.noUiSlider = null;\n      }\n      question.readOnlyChangedCallback = null;\n      question.valueChangedCallback = null;\n\n      if (!question.updateSliderProperties) return;\n      question.unRegisterFunctionOnPropertiesValueChanged(\n        [\"pipsValues\", \"step\", \"rangeMin\", \"rangeMax\", \"pipsMode\", \"pipsDensity\"],\n        question.updateSliderProperties\n      );\n      question.updateSliderProperties = undefined\n    },\n    pdfRender: function (_, options) {\n      if (options.question.getType() === componentName) {\n        var point = options.module.SurveyHelper.createPoint(\n          options.module.SurveyHelper.mergeRects.apply(null, options.bricks)\n        );\n        point.xLeft += options.controller.unitWidth;\n        point.yTop +=\n          options.controller.unitHeight *\n          options.module.FlatQuestion.CONTENT_GAP_VERT_SCALE;\n        var rect = options.module.SurveyHelper.createTextFieldRect(\n          point,\n          options.controller\n        );\n        if (options.module.SurveyHelper.shouldRenderReadOnly(this.question, this.controller)) {\n          options.bricks.push(new options.module.TextFieldBrick(\n            options.question,\n            options.controller,\n            rect,\n            true,\n            options.question.id,\n            options.question.value || options.question.defaultValue || \"\",\n            \"\",\n            options.question.isReadOnly,\n            false,\n            \"text\"\n          ));\n        } else {\n          return new Promise(resolve => {\n            options.module.SurveyHelper.createCommentFlat(point, options.question,\n              options.controller, true, { rows: options.module.FlatTextbox.MULTILINE_TEXT_ROWS_COUNT }).then((brick) => {\n                options.bricks.push(brick);\n                resolve();\n              })\n          })\n        }\n      }\n    },\n  };\n  Survey.CustomWidgetCollection.Instance.addCustomWidget(widget, \"customtype\");\n}\n\nif (typeof Survey !== \"undefined\") {\n  init(Survey);\n}\n\nexport default init;\n"],"names":[],"sourceRoot":""}