UNPKG

surveyjs-widgets

Version:

Custom widgets for the SurveyJS library

263 lines (256 loc) 22.6 kB
(function webpackUniversalModuleDefinition(root, factory) { if(typeof exports === 'object' && typeof module === 'object') module.exports = factory(); else if(typeof define === 'function' && define.amd) define("widgets/select2", [], factory); else if(typeof exports === 'object') exports["widgets/select2"] = factory(); else root["widgets/select2"] = factory(); })(self, () => { return /******/ (() => { // webpackBootstrap /******/ "use strict"; /******/ // The require scope /******/ var __webpack_require__ = {}; /******/ /************************************************************************/ /******/ /* 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__ = {}; /*!************************!*\ !*** ./src/select2.js ***! \************************/ __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); function init(Survey, $) { $ = $ || window.$; const componentName = "select2"; var widget = { activatedBy: "property", name: componentName, widgetIsLoaded: function () { return typeof $ == "function" && !!$.fn.select2; }, isFit: function (question) { if (widget.activatedBy == "property") return ( question["renderAs"] === componentName && question.getType() === "dropdown" ); if (widget.activatedBy == "type") return question.getType() === "dropdown"; if (widget.activatedBy == "customtype") return question.getType() === componentName; return false; }, activatedByChanged: function (activatedBy) { if (!this.widgetIsLoaded()) return; widget.activatedBy = activatedBy; Survey.Serializer.removeProperty("dropdown", "renderAs"); if (activatedBy == "property") { Survey.Serializer.addProperty("dropdown", { name: "renderAs", category: "general", default: "default", choices: [componentName, "default"], }); Survey.Serializer.addProperty("dropdown", { dependsOn: "renderAs", category: "general", name: "select2Config", visibleIf: function (obj) { return obj.renderAs == componentName; }, }); } if (activatedBy == "customtype") { if(Survey.Serializer.findClass(componentName)) return; Survey.Serializer.addClass(componentName, [], null, "dropdown"); let registerQuestion = Survey.ElementFactory.Instance.registerCustomQuestion; if(!!registerQuestion) registerQuestion(componentName); Survey.Serializer.addProperty(componentName, { name: "select2Config", category: "general", default: null, }); } }, htmlTemplate: "<div><select style='width: 100%;'></select><textarea></textarea></div>", afterRender: function (question, el) { var select2Config = question.select2Config; var settings = select2Config && typeof select2Config == "string" ? JSON.parse(select2Config) : select2Config; if (!settings) settings = {}; var $el = $(el).is("select") ? $(el) : $(el).find("select"); var $otherElement = $(el).find("textarea"); $otherElement.addClass(question.cssClasses.other); $otherElement.bind("input propertychange", function () { if (isSettingValue) return; question.comment = $otherElement.val(); }); var updateComment = function () { $otherElement.val(question.comment); if (question.isOtherSelected) { $otherElement.show(); } else { $otherElement.hide(); } }; var isSettingValue = false; var updateValueHandler = function () { if (isSettingValue) return; isSettingValue = true; if ($el.find('option[value="' + (question.value || "") + '"]').length) { $el.val(question.value).trigger("change"); } else { if ( question.value !== null && question.value !== undefined && !question.isOtherSelected ) { var newOption = new Option( question.value, //TODO if question value is object then need to improve question.value, true, true ); $el.append(newOption).trigger("change"); } } updateComment(); isSettingValue = false; }; var updateChoices = function () { $el.select2().empty(); if (!settings.placeholder && question.showOptionsCaption) { settings.placeholder = question.optionsCaption; settings.allowClear = true; } if (!settings.theme) { settings.theme = "classic"; } settings.disabled = question.isReadOnly; if (settings.ajax) { $el.select2(settings); question.keepIncorrectValues = true; } else { var data = []; if (!!settings.placeholder || question.showOptionsCaption) { data.push({ id: "", text: "" }); } settings.data = data.concat( question.visibleChoices.map(function (choice) { return { id: choice.value, text: choice.text, }; }) ); question.clearIncorrectValues(); $el.select2(settings); } // fixed width accrording to https://stackoverflow.com/questions/45276778/select2-not-responsive-width-larger-than-container if (!!el.querySelector(".select2")) { el.querySelector(".select2").style.width = "100%"; } if (!!el.nextElementSibling) { el.nextElementSibling.style.marginBottom = "1px"; } updateValueHandler(); }; $otherElement.prop("disabled", question.isReadOnly); question.readOnlyChangedCallback = function () { $el.prop("disabled", question.isReadOnly); $otherElement.prop("disabled", question.isReadOnly); }; question.registerFunctionOnPropertyValueChanged( "visibleChoices", function () { updateChoices(); } ); updateChoices(); $el.on("change", function (e) { setTimeout(function () { question.renderedValue = e.target.value; updateComment(); }, 1); }); $el.on("select2:select", function (e) { setTimeout(function () { question.renderedValue = e.target.value; updateComment(); }, 1); }); $el.on("select2:opening", function (e) { if ($(this).data("unselecting")) { $(this).removeData("unselecting"); e.preventDefault(); } }); $el.on("select2:unselecting", function (e) { $(this).data("unselecting", true); setTimeout(function () { question.renderedValue = null; updateComment(); }, 1); }); question.valueChangedCallback = updateValueHandler; updateValueHandler(); }, willUnmount: function (question, el) { question.readOnlyChangedCallback = null; question.valueChangedCallback = null; var $select2 = $(el).find("select"); if (!!$select2.data(componentName)) { $select2 .off("select2:select") .off("select2:unselecting") .off("select2:opening") .select2("destroy"); } }, }; Survey.CustomWidgetCollection.Instance.addCustomWidget(widget); } if (typeof Survey !== "undefined") { init(Survey, window.jQuery); } /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (init); /******/ return __webpack_exports__; /******/ })() ; }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"widgets/select2.js","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;;UCVA;UACA;;;;;WCDA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA;;;;;WCPA;;;;;WCAA;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D;;;;;;;;;;;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;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,WAAW;AACX,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL;AACA,uCAAuC;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;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,UAAU;AACV;AACA;AACA,wBAAwB,kBAAkB;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;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/webpack/bootstrap","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/select2.js"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"widgets/select2\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"widgets/select2\"] = factory();\n\telse\n\t\troot[\"widgets/select2\"] = factory();\n})(self, () => {\nreturn ","// The require scope\nvar __webpack_require__ = {};\n\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};","function init(Survey, $) {\n  $ = $ || window.$;\n  const componentName = \"select2\";\n  var widget = {\n    activatedBy: \"property\",\n    name: componentName,\n    widgetIsLoaded: function () {\n      return typeof $ == \"function\" && !!$.fn.select2;\n    },\n    isFit: function (question) {\n      if (widget.activatedBy == \"property\")\n        return (\n          question[\"renderAs\"] === componentName &&\n          question.getType() === \"dropdown\"\n        );\n      if (widget.activatedBy == \"type\")\n        return question.getType() === \"dropdown\";\n      if (widget.activatedBy == \"customtype\")\n        return question.getType() === componentName;\n      return false;\n    },\n    activatedByChanged: function (activatedBy) {\n      if (!this.widgetIsLoaded()) return;\n      widget.activatedBy = activatedBy;\n      Survey.Serializer.removeProperty(\"dropdown\", \"renderAs\");\n      if (activatedBy == \"property\") {\n        Survey.Serializer.addProperty(\"dropdown\", {\n          name: \"renderAs\",\n          category: \"general\",\n          default: \"default\",\n          choices: [componentName, \"default\"],\n        });\n        Survey.Serializer.addProperty(\"dropdown\", {\n          dependsOn: \"renderAs\",\n          category: \"general\",\n          name: \"select2Config\",\n          visibleIf: function (obj) {\n            return obj.renderAs == componentName;\n          },\n        });\n      }\n      if (activatedBy == \"customtype\") {\n        if(Survey.Serializer.findClass(componentName)) return;\n        Survey.Serializer.addClass(componentName, [], null, \"dropdown\");\n        let registerQuestion = Survey.ElementFactory.Instance.registerCustomQuestion;\n        if(!!registerQuestion) registerQuestion(componentName);\n          Survey.Serializer.addProperty(componentName, {\n          name: \"select2Config\",\n          category: \"general\",\n          default: null,\n        });\n      }\n    },\n    htmlTemplate:\n      \"<div><select style='width: 100%;'></select><textarea></textarea></div>\",\n    afterRender: function (question, el) {\n      var select2Config = question.select2Config;\n      var settings =\n        select2Config && typeof select2Config == \"string\"\n          ? JSON.parse(select2Config)\n          : select2Config;\n      if (!settings) settings = {};\n      var $el = $(el).is(\"select\") ? $(el) : $(el).find(\"select\");\n      var $otherElement = $(el).find(\"textarea\");\n      $otherElement.addClass(question.cssClasses.other);\n      $otherElement.bind(\"input propertychange\", function () {\n        if (isSettingValue) return;\n        question.comment = $otherElement.val();\n      });\n\n      var updateComment = function () {\n        $otherElement.val(question.comment);\n        if (question.isOtherSelected) {\n          $otherElement.show();\n        } else {\n          $otherElement.hide();\n        }\n      };\n      var isSettingValue = false;\n      var updateValueHandler = function () {\n        if (isSettingValue) return;\n        isSettingValue = true;\n        if ($el.find('option[value=\"' + (question.value || \"\") + '\"]').length) {\n          $el.val(question.value).trigger(\"change\");\n        } else {\n          if (\n            question.value !== null &&\n            question.value !== undefined &&\n            !question.isOtherSelected\n          ) {\n            var newOption = new Option(\n              question.value, //TODO if question value is object then need to improve\n              question.value,\n              true,\n              true\n            );\n            $el.append(newOption).trigger(\"change\");\n          }\n        }\n        updateComment();\n        isSettingValue = false;\n      };\n      var updateChoices = function () {\n        $el.select2().empty();\n        if (!settings.placeholder && question.showOptionsCaption) {\n          settings.placeholder = question.optionsCaption;\n          settings.allowClear = true;\n        }\n        if (!settings.theme) {\n          settings.theme = \"classic\";\n        }\n        settings.disabled = question.isReadOnly;\n        if (settings.ajax) {\n          $el.select2(settings);\n          question.keepIncorrectValues = true;\n        } else {\n          var data = [];\n          if (!!settings.placeholder || question.showOptionsCaption) {\n            data.push({ id: \"\", text: \"\" });\n          }\n          settings.data = data.concat(\n            question.visibleChoices.map(function (choice) {\n              return {\n                id: choice.value,\n                text: choice.text,\n              };\n            })\n          );\n          question.clearIncorrectValues();\n          $el.select2(settings);\n        }\n        // fixed width accrording to https://stackoverflow.com/questions/45276778/select2-not-responsive-width-larger-than-container\n        if (!!el.querySelector(\".select2\")) {\n          el.querySelector(\".select2\").style.width = \"100%\";\n        }\n        if (!!el.nextElementSibling) {\n          el.nextElementSibling.style.marginBottom = \"1px\";\n        }\n        updateValueHandler();\n      };\n\n      $otherElement.prop(\"disabled\", question.isReadOnly);\n      question.readOnlyChangedCallback = function () {\n        $el.prop(\"disabled\", question.isReadOnly);\n        $otherElement.prop(\"disabled\", question.isReadOnly);\n      };\n\n      question.registerFunctionOnPropertyValueChanged(\n        \"visibleChoices\",\n        function () {\n          updateChoices();\n        }\n      );\n      updateChoices();\n      $el.on(\"change\", function (e) {\n        setTimeout(function () {\n          question.renderedValue = e.target.value;\n          updateComment();\n        }, 1);\n      });\n      $el.on(\"select2:select\", function (e) {\n        setTimeout(function () {\n          question.renderedValue = e.target.value;\n          updateComment();\n        }, 1);\n      });\n      $el.on(\"select2:opening\", function (e) {\n        if ($(this).data(\"unselecting\")) {\n          $(this).removeData(\"unselecting\");\n          e.preventDefault();\n        }\n      });\n      $el.on(\"select2:unselecting\", function (e) {\n        $(this).data(\"unselecting\", true);\n        setTimeout(function () {\n          question.renderedValue = null;\n          updateComment();\n        }, 1);\n      });\n      question.valueChangedCallback = updateValueHandler;\n      updateValueHandler();\n    },\n    willUnmount: function (question, el) {\n      question.readOnlyChangedCallback = null;\n      question.valueChangedCallback = null;\n      var $select2 = $(el).find(\"select\");\n      if (!!$select2.data(componentName)) {\n        $select2\n          .off(\"select2:select\")\n          .off(\"select2:unselecting\")\n          .off(\"select2:opening\")\n          .select2(\"destroy\");\n      }\n    },\n  };\n\n  Survey.CustomWidgetCollection.Instance.addCustomWidget(widget);\n}\n\nif (typeof Survey !== \"undefined\") {\n  init(Survey, window.jQuery);\n}\n\nexport default init;\n"],"names":[],"sourceRoot":""}