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