UNPKG

surveyjs-widgets

Version:

Custom widgets for the SurveyJS library

250 lines (228 loc) 21.1 kB
(function webpackUniversalModuleDefinition(root, factory) { if(typeof exports === 'object' && typeof module === 'object') module.exports = factory(); else if(typeof define === 'function' && define.amd) define("widgets/pretty-checkbox", [], factory); else if(typeof exports === 'object') exports["widgets/pretty-checkbox"] = factory(); else root["widgets/pretty-checkbox"] = 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/pretty-checkbox.js ***! \********************************/ __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); function init(Survey) { var widget = { settings: { supportedTypes: ["radiogroup", "checkbox", "boolean"], radiogroup: { rootClass: "pretty p-default p-round", inputType: "radio", states: [{ stateClass: "state p-success", addOn: "" }], }, checkbox: { rootClass: "pretty p-default", inputType: "checkbox", states: [{ stateClass: "state p-success", addOn: "" }], }, boolean: { rootClass: "pretty p-icon p-default p-has-indeterminate", inputType: "checkbox", states: [ { stateClass: "state p-success", addOn: "" }, { stateClass: "state p-success p-is-indeterminate", iconClass: "icon mdi mdi-minus", addOn: "", }, ], }, }, name: "pretty-checkbox", activatedBy: "property", widgetIsLoaded: function () { return true; }, htmlTemplate: "<fieldset></fieldset>", isFit: function (question) { var isFitByType = widget.settings.supportedTypes.indexOf(question.getType()) !== -1; if (widget.activatedBy === "property") { return question["renderAs"] === "prettycheckbox" && isFitByType; } else if (widget.activatedBy === "type") { return isFitByType; } return false; }, activatedByChanged: function (value) { if (this.widgetIsLoaded()) { widget.activatedBy = value; } }, isDefaultRender: false, afterRender: function (question, element) { var itemInputs = {}; var questionType = question.getType(); var options = this.settings[questionType]; var checkboxType = questionType === "checkbox"; var radiogroupType = questionType === "radiogroup"; var booleanType = questionType === "boolean"; var inChangeHandler = false; var changeHandler = function (event) { inChangeHandler = true; try { var target = arguments[0].target; var targetValue = target.value; var targetChecked = target.checked; if (checkboxType) { var questionValue = question.createValueCopy() || []; var valueIndex = questionValue.indexOf(targetValue); if (targetChecked) { if (valueIndex === -1) { questionValue.push(targetValue); } } else { if (valueIndex !== -1) { questionValue.splice(valueIndex, 1); } } question.value = questionValue; } else if (radiogroupType) { question.value = targetValue; } else { question.value = targetChecked; } } finally { inChangeHandler = false; } }; var itemWidth = question.colCount > 0 ? 100 / question.colCount + "%" : ""; var choices = booleanType ? [{ locText: question.locTitle, value: !!question.value }] : question.visibleChoices; choices.forEach(function (choiceItem, index) { var input = document.createElement("input"); input.type = options.inputType; input.name = question.name + (checkboxType ? "" + index : ""); input.onchange = changeHandler; input.value = choiceItem.value; if (booleanType && question.value === null) { input.indeterminate = question.defaultValue === "indeterminate"; } var controlRoot = document.createElement("div"); controlRoot.className = options.rootClass; controlRoot.appendChild(input); options.states.forEach(function (state) { var stateRoot = document.createElement("div"); stateRoot.className = state.stateClass; if (!!state.iconClass) { var icon = document.createElement("i"); icon.className = state.iconClass; stateRoot.appendChild(icon); } var label = document.createElement("label"); if (choiceItem.locText.hasHtml) { label.innerHTML = choiceItem.locText.html; } else { label.textContent = choiceItem.locText.renderedText; } stateRoot.appendChild(label); controlRoot.appendChild(stateRoot); if (!!state.addOn) { stateRoot.insertAdjacentHTML("afterbegin", state.addOn); } }); var itemRoot = document.createElement("div"); itemRoot.className = "sv_cw_pretty_checkbox_" + questionType; itemRoot.style.display = "inline-block"; itemRoot.style.width = itemWidth; itemRoot.appendChild(controlRoot); element.appendChild(itemRoot); itemInputs[choiceItem.value] = input; }); var updateValueHandler = function (newValue) { if (!inChangeHandler) { var checkedItems = newValue || []; if (radiogroupType || booleanType) { checkedItems = [newValue && newValue.toString()]; } Object.values(itemInputs).forEach(function (inputItem) { if (checkedItems.indexOf(inputItem.value) !== -1) { inputItem.setAttribute("checked", undefined); } else { inputItem.removeAttribute("checked"); } }); } }; var readOnlyHandler = function () { Object.values(itemInputs).forEach(function (inputItem) { if (question.isReadOnly) { inputItem.setAttribute("disabled", true); } else { inputItem.removeAttribute("disabled"); } }); }; question.valueChangedCallback = updateValueHandler; question.readOnlyChangedCallback = readOnlyHandler; updateValueHandler(question.value); readOnlyHandler(); }, willUnmount: function (question, el) { question.valueChangedCallback = undefined; question.readOnlyChangedCallback = undefined; }, }; Survey.CustomWidgetCollection.Instance.addCustomWidget(widget, "property"); } 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/pretty-checkbox.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,mBAAmB,0CAA0C;AAC7D,OAAO;AACP;AACA;AACA;AACA,mBAAmB,0CAA0C;AAC7D,OAAO;AACP;AACA;AACA;AACA;AACA,YAAY,0CAA0C;AACtD;AACA;AACA;AACA;AACA,WAAW;AACX;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA,QAAQ;AACR;AACA;;AAEA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;;AAEA;AACA,YAAY;AACZ;AACA,YAAY;AACZ;AACA;AACA,UAAU;AACV;AACA;AACA;;AAEA;AACA;;AAEA;AACA,aAAa,qDAAqD;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;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/pretty-checkbox.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/pretty-checkbox\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"widgets/pretty-checkbox\"] = factory();\n\telse\n\t\troot[\"widgets/pretty-checkbox\"] = 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  var widget = {\n    settings: {\n      supportedTypes: [\"radiogroup\", \"checkbox\", \"boolean\"],\n      radiogroup: {\n        rootClass: \"pretty p-default p-round\",\n        inputType: \"radio\",\n        states: [{ stateClass: \"state p-success\", addOn: \"\" }],\n      },\n      checkbox: {\n        rootClass: \"pretty p-default\",\n        inputType: \"checkbox\",\n        states: [{ stateClass: \"state p-success\", addOn: \"\" }],\n      },\n      boolean: {\n        rootClass: \"pretty p-icon p-default p-has-indeterminate\",\n        inputType: \"checkbox\",\n        states: [\n          { stateClass: \"state p-success\", addOn: \"\" },\n          {\n            stateClass: \"state p-success p-is-indeterminate\",\n            iconClass: \"icon mdi mdi-minus\",\n            addOn: \"\",\n          },\n        ],\n      },\n    },\n    name: \"pretty-checkbox\",\n    activatedBy: \"property\",\n    widgetIsLoaded: function () {\n      return true;\n    },\n    htmlTemplate: \"<fieldset></fieldset>\",\n    isFit: function (question) {\n      var isFitByType =\n        widget.settings.supportedTypes.indexOf(question.getType()) !== -1;\n\n      if (widget.activatedBy === \"property\") {\n        return question[\"renderAs\"] === \"prettycheckbox\" && isFitByType;\n      } else if (widget.activatedBy === \"type\") {\n        return isFitByType;\n      }\n\n      return false;\n    },\n    activatedByChanged: function (value) {\n      if (this.widgetIsLoaded()) {\n        widget.activatedBy = value;\n      }\n    },\n    isDefaultRender: false,\n    afterRender: function (question, element) {\n      var itemInputs = {};\n      var questionType = question.getType();\n      var options = this.settings[questionType];\n      var checkboxType = questionType === \"checkbox\";\n      var radiogroupType = questionType === \"radiogroup\";\n      var booleanType = questionType === \"boolean\";\n\n      var inChangeHandler = false;\n      var changeHandler = function (event) {\n        inChangeHandler = true;\n        try {\n          var target = arguments[0].target;\n          var targetValue = target.value;\n          var targetChecked = target.checked;\n\n          if (checkboxType) {\n            var questionValue = question.createValueCopy() || [];\n            var valueIndex = questionValue.indexOf(targetValue);\n            if (targetChecked) {\n              if (valueIndex === -1) {\n                questionValue.push(targetValue);\n              }\n            } else {\n              if (valueIndex !== -1) {\n                questionValue.splice(valueIndex, 1);\n              }\n            }\n\n            question.value = questionValue;\n          } else if (radiogroupType) {\n            question.value = targetValue;\n          } else {\n            question.value = targetChecked;\n          }\n        } finally {\n          inChangeHandler = false;\n        }\n      };\n\n      var itemWidth =\n        question.colCount > 0 ? 100 / question.colCount + \"%\" : \"\";\n\n      var choices = booleanType\n        ? [{ locText: question.locTitle, value: !!question.value }]\n        : question.visibleChoices;\n      choices.forEach(function (choiceItem, index) {\n        var input = document.createElement(\"input\");\n        input.type = options.inputType;\n        input.name = question.name + (checkboxType ? \"\" + index : \"\");\n        input.onchange = changeHandler;\n        input.value = choiceItem.value;\n\n        if (booleanType && question.value === null) {\n          input.indeterminate = question.defaultValue === \"indeterminate\";\n        }\n\n        var controlRoot = document.createElement(\"div\");\n        controlRoot.className = options.rootClass;\n        controlRoot.appendChild(input);\n\n        options.states.forEach(function (state) {\n          var stateRoot = document.createElement(\"div\");\n          stateRoot.className = state.stateClass;\n          if (!!state.iconClass) {\n            var icon = document.createElement(\"i\");\n            icon.className = state.iconClass;\n            stateRoot.appendChild(icon);\n          }\n\n          var label = document.createElement(\"label\");\n          if (choiceItem.locText.hasHtml) {\n            label.innerHTML = choiceItem.locText.html;\n          } else {\n            label.textContent = choiceItem.locText.renderedText;\n          }\n          stateRoot.appendChild(label);\n\n          controlRoot.appendChild(stateRoot);\n          if (!!state.addOn) {\n            stateRoot.insertAdjacentHTML(\"afterbegin\", state.addOn);\n          }\n        });\n\n        var itemRoot = document.createElement(\"div\");\n        itemRoot.className = \"sv_cw_pretty_checkbox_\" + questionType;\n        itemRoot.style.display = \"inline-block\";\n        itemRoot.style.width = itemWidth;\n        itemRoot.appendChild(controlRoot);\n\n        element.appendChild(itemRoot);\n\n        itemInputs[choiceItem.value] = input;\n      });\n\n      var updateValueHandler = function (newValue) {\n        if (!inChangeHandler) {\n          var checkedItems = newValue || [];\n          if (radiogroupType || booleanType) {\n            checkedItems = [newValue && newValue.toString()];\n          }\n\n          Object.values(itemInputs).forEach(function (inputItem) {\n            if (checkedItems.indexOf(inputItem.value) !== -1) {\n              inputItem.setAttribute(\"checked\", undefined);\n            } else {\n              inputItem.removeAttribute(\"checked\");\n            }\n          });\n        }\n      };\n      var readOnlyHandler = function () {\n        Object.values(itemInputs).forEach(function (inputItem) {\n          if (question.isReadOnly) {\n            inputItem.setAttribute(\"disabled\", true);\n          } else {\n            inputItem.removeAttribute(\"disabled\");\n          }\n        });\n      };\n\n      question.valueChangedCallback = updateValueHandler;\n      question.readOnlyChangedCallback = readOnlyHandler;\n      updateValueHandler(question.value);\n      readOnlyHandler();\n    },\n    willUnmount: function (question, el) {\n      question.valueChangedCallback = undefined;\n      question.readOnlyChangedCallback = undefined;\n    },\n  };\n\n  Survey.CustomWidgetCollection.Instance.addCustomWidget(widget, \"property\");\n}\n\nif (typeof Survey !== \"undefined\") {\n  init(Survey);\n}\n\nexport default init;\n"],"names":[],"sourceRoot":""}