UNPKG

surveyjs-widgets

Version:

Custom widgets for the SurveyJS library

232 lines (223 loc) 19.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/icheck", [], factory); else if(typeof exports === 'object') exports["widgets/icheck"] = factory(); else root["widgets/icheck"] = 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/icheck.js ***! \***********************/ __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); function escValue(val) { if (typeof val === "string") { return (val || "").replace(/(['])/g, "\\$1"); } return val; } function init(Survey, $) { $ = $ || window.$; var widget = { className: "iradio_square-blue", checkboxClass: "iradio_square-blue", radioClass: "iradio_square-blue", name: "icheck", widgetIsLoaded: function () { return typeof $ == "function" && !!$.fn.iCheck; }, isFit: function (question) { var t = question.getType(); return t === "radiogroup" || t === "checkbox" || t === "matrix"; }, isDefaultRender: true, afterRender: function (question, el) { var rootWidget = this; var $el = $(el); $el.find(".sv-item__decorator").hide(); $el.find("input").data({ iCheck: undefined, }); function getIndexByValue(arr, value) { if (!Array.isArray(arr)) return -1; for (var i = 0; i < arr.length; i++) { if (arr[i] == value) return i; if (!!arr[i] && arr[i].toString().toLowerCase() == value) return i; } return -1; } var frozeUpdating = false; var makeChoicesICheck = function () { var inputs = $el.find("input"); inputs.iCheck({ checkboxClass: question.checkboxClass || rootWidget.checkboxClass || rootWidget.className, radioClass: question.radioClass || rootWidget.radioClass || rootWidget.className, }); inputs.on("ifChecked", function (event) { if (frozeUpdating) return; if (question.getType() === "matrix") { question.generatedVisibleRows.forEach(function (row, index, rows) { if (row.fullName === event.target.name) { row.value = event.target.value; } }); } else if (question.getType() === "checkbox") { var oldValue = question.value || []; var index = getIndexByValue(oldValue, event.target.value); if (index === -1) { question.value = oldValue.concat([event.target.value]); } } else { question.value = event.target.value; } }); inputs.on("ifUnchecked", function (event) { if (frozeUpdating) return; if (question.getType() === "checkbox") { var oldValue = (question.value || []).slice(); var index = getIndexByValue(oldValue, event.target.value); if (index >= 0) { oldValue.splice(index, 1); question.value = oldValue; } } }); }; function uncheckIcheck(cEl) { cEl.iCheck("uncheck"); cEl[0].parentElement.classList.remove("checked"); } var select = function () { frozeUpdating = true; if (question.getType() !== "matrix") { var values = question.value; if (!Array.isArray(values)) { values = [values]; } if (question.getType() == "checkbox") { var qValue = question.value; question.visibleChoices.forEach(function (item) { var inEl = $el.find( "input[value='" + escValue(item.value) + "']" ); if (!inEl) return; var isChecked = getIndexByValue(qValue, item.value) > -1; if (isChecked) { inEl.iCheck("check"); } else { var cEl = inEl[0]; var wasChecked = !!cEl["checked"]; if (wasChecked) { inEl.removeAttr("checked"); if (!inEl.parent().hasClass("checked")) setTimeout(function () { uncheckIcheck(inEl); }); else uncheckIcheck(inEl); } } }); } else { values.forEach(function (value) { $el .find("input[value='" + escValue(value) + "']") .iCheck("check"); }); } } else { question.generatedVisibleRows.forEach(function (row, index, rows) { if (row.value) { $(el) .find( "input[name='" + row.fullName + "'][value='" + escValue(row.value) + "']" ) .iCheck("check"); } }); } frozeUpdating = false; }; makeChoicesICheck(); question.visibleChoicesChangedCallback = function () { makeChoicesICheck(); $el.find(".sv-item__decorator").hide(); }; question.valueChangedCallback = select; select(); }, willUnmount: function (question, el) { var $el = $(el); $el.find("input").iCheck("destroy"); question.visibleChoicesChangedCallback = null; }, }; Survey.Serializer.addProperty("radiogroup", { name: "radioClass", category: "general", }); Survey.Serializer.addProperty("checkbox", { name: "checkboxClass", category: "general", }); Survey.CustomWidgetCollection.Instance.addCustomWidget(widget, "type"); } 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/icheck.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;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA,aAAa;AACb,YAAY;AACZ;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;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/icheck.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/icheck\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"widgets/icheck\"] = factory();\n\telse\n\t\troot[\"widgets/icheck\"] = 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 escValue(val) {\n  if (typeof val === \"string\") {\n    return (val || \"\").replace(/(['])/g, \"\\\\$1\");\n  }\n  return val;\n}\n\nfunction init(Survey, $) {\n  $ = $ || window.$;\n  var widget = {\n    className: \"iradio_square-blue\",\n    checkboxClass: \"iradio_square-blue\",\n    radioClass: \"iradio_square-blue\",\n    name: \"icheck\",\n    widgetIsLoaded: function () {\n      return typeof $ == \"function\" && !!$.fn.iCheck;\n    },\n    isFit: function (question) {\n      var t = question.getType();\n      return t === \"radiogroup\" || t === \"checkbox\" || t === \"matrix\";\n    },\n    isDefaultRender: true,\n    afterRender: function (question, el) {\n      var rootWidget = this;\n      var $el = $(el);\n\n      $el.find(\".sv-item__decorator\").hide();\n\n      $el.find(\"input\").data({\n        iCheck: undefined,\n      });\n      function getIndexByValue(arr, value) {\n        if (!Array.isArray(arr)) return -1;\n        for (var i = 0; i < arr.length; i++) {\n          if (arr[i] == value) return i;\n          if (!!arr[i] && arr[i].toString().toLowerCase() == value) return i;\n        }\n        return -1;\n      }\n      var frozeUpdating = false;\n      var makeChoicesICheck = function () {\n        var inputs = $el.find(\"input\");\n        inputs.iCheck({\n          checkboxClass:\n            question.checkboxClass ||\n            rootWidget.checkboxClass ||\n            rootWidget.className,\n          radioClass:\n            question.radioClass ||\n            rootWidget.radioClass ||\n            rootWidget.className,\n        });\n        inputs.on(\"ifChecked\", function (event) {\n          if (frozeUpdating) return;\n          if (question.getType() === \"matrix\") {\n            question.generatedVisibleRows.forEach(function (row, index, rows) {\n              if (row.fullName === event.target.name) {\n                row.value = event.target.value;\n              }\n            });\n          } else if (question.getType() === \"checkbox\") {\n            var oldValue = question.value || [];\n            var index = getIndexByValue(oldValue, event.target.value);\n            if (index === -1) {\n              question.value = oldValue.concat([event.target.value]);\n            }\n          } else {\n            question.value = event.target.value;\n          }\n        });\n\n        inputs.on(\"ifUnchecked\", function (event) {\n          if (frozeUpdating) return;\n          if (question.getType() === \"checkbox\") {\n            var oldValue = (question.value || []).slice();\n            var index = getIndexByValue(oldValue, event.target.value);\n            if (index >= 0) {\n              oldValue.splice(index, 1);\n              question.value = oldValue;\n            }\n          }\n        });\n      };\n      function uncheckIcheck(cEl) {\n        cEl.iCheck(\"uncheck\");\n        cEl[0].parentElement.classList.remove(\"checked\");\n      }\n      var select = function () {\n        frozeUpdating = true;\n        if (question.getType() !== \"matrix\") {\n          var values = question.value;\n          if (!Array.isArray(values)) {\n            values = [values];\n          }\n          if (question.getType() == \"checkbox\") {\n            var qValue = question.value;\n            question.visibleChoices.forEach(function (item) {\n              var inEl = $el.find(\n                \"input[value='\" + escValue(item.value) + \"']\"\n              );\n              if (!inEl) return;\n              var isChecked = getIndexByValue(qValue, item.value) > -1;\n              if (isChecked) {\n                inEl.iCheck(\"check\");\n              } else {\n                var cEl = inEl[0];\n                var wasChecked = !!cEl[\"checked\"];\n                if (wasChecked) {\n                  inEl.removeAttr(\"checked\");\n                  if (!inEl.parent().hasClass(\"checked\"))\n                    setTimeout(function () {\n                      uncheckIcheck(inEl);\n                    });\n                  else uncheckIcheck(inEl);\n                }\n              }\n            });\n          } else {\n            values.forEach(function (value) {\n              $el\n                .find(\"input[value='\" + escValue(value) + \"']\")\n                .iCheck(\"check\");\n            });\n          }\n        } else {\n          question.generatedVisibleRows.forEach(function (row, index, rows) {\n            if (row.value) {\n              $(el)\n                .find(\n                  \"input[name='\" +\n                    row.fullName +\n                    \"'][value='\" +\n                    escValue(row.value) +\n                    \"']\"\n                )\n                .iCheck(\"check\");\n            }\n          });\n        }\n        frozeUpdating = false;\n      };\n      makeChoicesICheck();\n\n      question.visibleChoicesChangedCallback = function () {\n        makeChoicesICheck();\n        $el.find(\".sv-item__decorator\").hide();\n      };\n      question.valueChangedCallback = select;\n      select();\n    },\n    willUnmount: function (question, el) {\n      var $el = $(el);\n      $el.find(\"input\").iCheck(\"destroy\");\n      question.visibleChoicesChangedCallback = null;\n    },\n  };\n\n  Survey.Serializer.addProperty(\"radiogroup\", {\n    name: \"radioClass\",\n    category: \"general\",\n  });\n  Survey.Serializer.addProperty(\"checkbox\", {\n    name: \"checkboxClass\",\n    category: \"general\",\n  });\n  Survey.CustomWidgetCollection.Instance.addCustomWidget(widget, \"type\");\n}\n\nif (typeof Survey !== \"undefined\") {\n  init(Survey, window.jQuery);\n}\n\nexport default init;\n"],"names":[],"sourceRoot":""}