custom-metrosurvey-widgets
Version:
Custom widgets for the SurveyJS library
350 lines (330 loc) • 31.9 kB
JavaScript
(function webpackUniversalModuleDefinition(root, factory) {
if(typeof exports === 'object' && typeof module === 'object')
module.exports = factory(require("sortablejs"));
else if(typeof define === 'function' && define.amd)
define("widgets/sortablejs", ["sortablejs"], factory);
else if(typeof exports === 'object')
exports["widgets/sortablejs"] = factory(require("sortablejs"));
else
root["widgets/sortablejs"] = factory(root["Sortable"]);
})(window, function(__WEBPACK_EXTERNAL_MODULE_sortablejs__) {
return /******/ (function(modules) { // webpackBootstrap
/******/ // The module cache
/******/ var installedModules = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/
/******/ // Check if module is in cache
/******/ if(installedModules[moduleId]) {
/******/ return installedModules[moduleId].exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = installedModules[moduleId] = {
/******/ i: moduleId,
/******/ l: false,
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/ // Flag the module as loaded
/******/ module.l = true;
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/******/
/******/ // expose the modules object (__webpack_modules__)
/******/ __webpack_require__.m = modules;
/******/
/******/ // expose the module cache
/******/ __webpack_require__.c = installedModules;
/******/
/******/ // define getter function for harmony exports
/******/ __webpack_require__.d = function(exports, name, getter) {
/******/ if(!__webpack_require__.o(exports, name)) {
/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
/******/ }
/******/ };
/******/
/******/ // define __esModule on exports
/******/ __webpack_require__.r = function(exports) {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/
/******/ // create a fake namespace object
/******/ // mode & 1: value is a module id, require it
/******/ // mode & 2: merge all properties of value into the ns
/******/ // mode & 4: return value when already ns object
/******/ // mode & 8|1: behave like require
/******/ __webpack_require__.t = function(value, mode) {
/******/ if(mode & 1) value = __webpack_require__(value);
/******/ if(mode & 8) return value;
/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
/******/ var ns = Object.create(null);
/******/ __webpack_require__.r(ns);
/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
/******/ return ns;
/******/ };
/******/
/******/ // getDefaultExport function for compatibility with non-harmony modules
/******/ __webpack_require__.n = function(module) {
/******/ var getter = module && module.__esModule ?
/******/ function getDefault() { return module['default']; } :
/******/ function getModuleExports() { return module; };
/******/ __webpack_require__.d(getter, 'a', getter);
/******/ return getter;
/******/ };
/******/
/******/ // Object.prototype.hasOwnProperty.call
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
/******/
/******/ // __webpack_public_path__
/******/ __webpack_require__.p = "";
/******/
/******/
/******/ // Load entry module and return exports
/******/ return __webpack_require__(__webpack_require__.s = "./src/sortablejs.js");
/******/ })
/************************************************************************/
/******/ ({
/***/ "./node_modules/svg-inline-loader/index.js?classPrefix!./src/images/sortablejs.svg":
/*!********************************************************************************!*\
!*** ./node_modules/svg-inline-loader?classPrefix!./src/images/sortablejs.svg ***!
\********************************************************************************/
/*! no static exports found */
/***/ (function(module, exports) {
module.exports = "<svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M7 1h9v2H7zM9 6h7v2H9zM11 11h5v2h-5zM5 10l1 1c-2.2 0-4-1.8-4-4 0-1.9 1.3-3.4 3-3.9v-2C2.2 1.5 0 4 0 7c0 3.3 2.7 6 5.9 6H6l-1 1 1 1 3-3-3-3-1 1z\"></path></svg>"
/***/ }),
/***/ "./src/sortablejs.js":
/*!***************************!*\
!*** ./src/sortablejs.js ***!
\***************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony import */ var sortablejs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! sortablejs */ "sortablejs");
/* harmony import */ var sortablejs__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(sortablejs__WEBPACK_IMPORTED_MODULE_0__);
function init(Survey) {
const iconId = "icon-sortablejs";
Survey.SvgRegistry && Survey.SvgRegistry.registerIconFromSvg(iconId, __webpack_require__(/*! svg-inline-loader?classPrefix!./images/sortablejs.svg */ "./node_modules/svg-inline-loader/index.js?classPrefix!./src/images/sortablejs.svg"), "");
var widget = {
name: "sortablelist",
title: "Sortable list",
iconName: iconId,
widgetIsLoaded: function () {
return typeof sortablejs__WEBPACK_IMPORTED_MODULE_0___default.a != "undefined";
},
defaultJSON: { choices: ["Item 1", "Item 2", "Item 3"] },
rootStyle: "width:100%:",
areaStyle:
"border: 1px solid #1ab394; width:100%; min-height:50px; margin-top:10px;",
itemStyle: "background-color:#1ab394;color:#fff;margin:5px;padding:10px;",
isFit: function (question) {
return question.getType() === "sortablelist";
},
htmlTemplate: "<div></div>",
activatedByChanged: function (activatedBy) {
Survey.JsonObject.metaData.addClass(
"sortablelist",
[
{ name: "hasOther", visible: false },
{ name: "storeOthersAsComment", visible: false },
{ name: "hasNone", visible: false },
{ name: "renderAs", visible: false },
{ name: "checkboxClass", visible: false },
{ name: "hasSelectAll", visible: false },
{ name: "noneText", visible: false },
{ name: "selectAllText", visible: false },
],
null,
"checkbox"
);
Survey.JsonObject.metaData.addProperty("sortablelist", {
name: "emptyText",
default: "Move items here.",
category: "general",
});
Survey.JsonObject.metaData.addProperty("sortablelist", {
name: "useDefaultTheme:switch",
default: true,
category: "general",
});
Survey.JsonObject.metaData.addProperty("sortablelist", {
name: "maxAnswersCount:number",
default: -1,
category: "general",
});
},
afterRender: function (question, el) {
var self = this;
if (!question.useDefaultTheme) {
self.rootStyle = "";
self.itemStyle = "";
self.areaStyle = "";
}
el.style.cssText = self.rootStyle;
el.className = "sjs-sortablejs-root";
var source, result;
var resultEl = document.createElement("div");
var emptyEl = document.createElement("span");
var sourceEl = document.createElement("div");
resultEl.style.cssText = self.areaStyle;
resultEl.style.boxSizing = "border-box";
resultEl.className = "sjs-sortablejs-result";
emptyEl.innerHTML = question.emptyText;
resultEl.appendChild(emptyEl);
sourceEl.style.cssText = self.areaStyle;
sourceEl.style.boxSizing = "border-box";
sourceEl.className = "sjs-sortablejs-source";
el.appendChild(resultEl);
el.appendChild(sourceEl);
var hasValueInResults = function (val) {
var res = question.value;
if (!Array.isArray(res)) return false;
for (var i = 0; i < res.length; i++) {
if (res[i] == val) return true;
}
return false;
};
var addChoiceToWidget = function (choice, inResults) {
var srcEl = inResults ? resultEl : sourceEl;
var newEl = document.createElement("div");
newEl.className = "sjs-sortablejs-item";
newEl.style.cssText = self.itemStyle;
newEl.innerText = choice.text;
newEl.dataset["value"] = choice.value;
srcEl.appendChild(newEl);
choice.onPropertyChanged.add(function (sender, options) {
newEl.innerText = sender.text;
});
};
var getChoicesNotInResults = function () {
var res = [];
question.visibleChoices.forEach(function (choice) {
if (!hasValueInResults(choice.value)) {
res.push(choice);
}
});
return res;
};
var getChoicesInResults = function () {
var res = [];
var val = question.value;
if (!Array.isArray(val)) return res;
for (var i = 0; i < val.length; i++) {
var item = Survey.ItemValue.getItemByValue(
question.visibleChoices,
val[i]
);
if (!!item) {
res.push(item);
}
}
return res;
};
var isUpdatingQuestionValue = false;
var updateValueHandler = function () {
if (isUpdatingQuestionValue) return;
resultEl.innerHTML = "";
resultEl.appendChild(emptyEl);
sourceEl.innerHTML = "";
var notInResults = getChoicesNotInResults();
var inResults = getChoicesInResults();
emptyEl.style.display = inResults.length > 0 ? "none" : "";
inResults.forEach(function (choice) {
addChoiceToWidget(choice, true);
});
notInResults.forEach(function (choice) {
addChoiceToWidget(choice, false);
});
};
result = question.resultEl = sortablejs__WEBPACK_IMPORTED_MODULE_0___default.a.create(resultEl, {
animation: 150,
disabled: question.isReadOnly,
group: {
name: question.name,
put: function (to, from) {
return (
to.options.group && from.options.group && to.options.group.name === from.options.group.name &&
(question.maxAnswersCount < 0 ||
to.el.children.length <= question.maxAnswersCount)
);
},
},
onSort: function (evt) {
var result = [];
if (resultEl.children.length === 1) {
emptyEl.style.display = "";
} else {
emptyEl.style.display = "none";
for (var i = 0; i < resultEl.children.length; i++) {
if (typeof resultEl.children[i].dataset.value === "undefined")
continue;
result.push(resultEl.children[i].dataset.value);
}
}
isUpdatingQuestionValue = true;
question.value = result;
isUpdatingQuestionValue = false;
},
});
source = question.sourceEl = sortablejs__WEBPACK_IMPORTED_MODULE_0___default.a.create(sourceEl, {
animation: 150,
disabled: question.isReadOnly,
group: question.name,
});
question.valueChangedCallback = updateValueHandler;
question.onPropertyChanged.add(function (sender, options) {
if (options.name == "emptyText") {
emptyEl.innerHTML = question.emptyText;
}
});
question.readOnlyChangedCallback = function () {
if (question.isReadOnly) {
result.options.disabled = true;
source.options.disabled = true;
} else {
result.options.disabled = false;
source.options.disabled = false;
}
};
question.registerFunctionOnPropertyValueChanged(
"visibleChoices",
updateValueHandler
);
updateValueHandler();
},
willUnmount: function (question, el) {
question.resultEl.destroy();
question.sourceEl.destroy();
question.readOnlyChangedCallback = null;
},
pdfQuestionType: "checkbox",
};
Survey.CustomWidgetCollection.Instance.addCustomWidget(widget, "customtype");
}
if (typeof Survey !== "undefined") {
init(Survey);
}
/* harmony default export */ __webpack_exports__["default"] = (init);
/***/ }),
/***/ "sortablejs":
/*!********************************************************************************************************!*\
!*** external {"root":"Sortable","commonjs2":"sortablejs","commonjs":"sortablejs","amd":"sortablejs"} ***!
\********************************************************************************************************/
/*! no static exports found */
/***/ (function(module, exports) {
module.exports = __WEBPACK_EXTERNAL_MODULE_sortablejs__;
/***/ })
/******/ });
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://[name]/webpack/universalModuleDefinition","webpack://[name]/webpack/bootstrap","webpack://[name]/./src/images/sortablejs.svg","webpack://[name]/./src/sortablejs.js","webpack://[name]/external {\"root\":\"Sortable\",\"commonjs2\":\"sortablejs\",\"commonjs\":\"sortablejs\",\"amd\":\"sortablejs\"}"],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;QCVA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;;QAEA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;;;QAGA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA,0CAA0C,gCAAgC;QAC1E;QACA;;QAEA;QACA;QACA;QACA,wDAAwD,kBAAkB;QAC1E;QACA,iDAAiD,cAAc;QAC/D;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,yCAAyC,iCAAiC;QAC1E,gHAAgH,mBAAmB,EAAE;QACrI;QACA;;QAEA;QACA;QACA;QACA,2BAA2B,0BAA0B,EAAE;QACvD,iCAAiC,eAAe;QAChD;QACA;QACA;;QAEA;QACA,sDAAsD,+DAA+D;;QAErH;QACA;;;QAGA;QACA;;;;;;;;;;;;AClFA,4P;;;;;;;;;;;;ACAA;AAAA;AAAA;AAAkC;;AAElC;AACA;AACA,uEAAuE,mBAAO,CAAC,gJAAuD;AACtI;AACA;AACA;AACA;AACA;AACA,oBAAoB,iDAAQ;AAC5B,KAAK;AACL,kBAAkB,0CAA0C;AAC5D;AACA;AACA,iCAAiC,YAAY,iBAAiB,iBAAiB;AAC/E,yCAAyC,WAAW,WAAW,aAAa;AAC5E;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,WAAW,mCAAmC;AAC9C,WAAW,+CAA+C;AAC1D,WAAW,kCAAkC;AAC7C,WAAW,mCAAmC;AAC9C,WAAW,wCAAwC;AACnD,WAAW,uCAAuC;AAClD,WAAW,mCAAmC;AAC9C,WAAW,wCAAwC;AACnD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,gBAAgB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,gBAAgB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA,mCAAmC,iDAAQ;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,SAAS;AACT;AACA;AACA;AACA;AACA,WAAW;AACX;AACA,2BAA2B,8BAA8B;AACzD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,mCAAmC,iDAAQ;AAC3C;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEe,mEAAI,EAAC;;;;;;;;;;;;ACnNpB,wD","file":"widgets/sortablejs.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"sortablejs\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"widgets/sortablejs\", [\"sortablejs\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"widgets/sortablejs\"] = factory(require(\"sortablejs\"));\n\telse\n\t\troot[\"widgets/sortablejs\"] = factory(root[\"Sortable\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE_sortablejs__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/sortablejs.js\");\n","module.exports = \"<svg viewBox=\\\"0 0 16 16\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\"><path d=\\\"M7 1h9v2H7zM9 6h7v2H9zM11 11h5v2h-5zM5 10l1 1c-2.2 0-4-1.8-4-4 0-1.9 1.3-3.4 3-3.9v-2C2.2 1.5 0 4 0 7c0 3.3 2.7 6 5.9 6H6l-1 1 1 1 3-3-3-3-1 1z\\\"></path></svg>\"","import Sortable from \"sortablejs\";\n\nfunction init(Survey) {\n  const iconId = \"icon-sortablejs\";\n  Survey.SvgRegistry && Survey.SvgRegistry.registerIconFromSvg(iconId, require('svg-inline-loader?classPrefix!./images/sortablejs.svg'), \"\");\n  var widget = {\n    name: \"sortablelist\",\n    title: \"Sortable list\",\n    iconName: iconId,\n    widgetIsLoaded: function () {\n      return typeof Sortable != \"undefined\";\n    },\n    defaultJSON: { choices: [\"Item 1\", \"Item 2\", \"Item 3\"] },\n    rootStyle: \"width:100%:\",\n    areaStyle:\n      \"border: 1px solid #1ab394; width:100%; min-height:50px; margin-top:10px;\",\n    itemStyle: \"background-color:#1ab394;color:#fff;margin:5px;padding:10px;\",\n    isFit: function (question) {\n      return question.getType() === \"sortablelist\";\n    },\n    htmlTemplate: \"<div></div>\",\n    activatedByChanged: function (activatedBy) {\n      Survey.JsonObject.metaData.addClass(\n        \"sortablelist\",\n        [\n          { name: \"hasOther\", visible: false },\n          { name: \"storeOthersAsComment\", visible: false },\n          { name: \"hasNone\", visible: false },\n          { name: \"renderAs\", visible: false },\n          { name: \"checkboxClass\", visible: false },\n          { name: \"hasSelectAll\", visible: false },\n          { name: \"noneText\", visible: false },\n          { name: \"selectAllText\", visible: false },\n        ],\n        null,\n        \"checkbox\"\n      );\n      Survey.JsonObject.metaData.addProperty(\"sortablelist\", {\n        name: \"emptyText\",\n        default: \"Move items here.\",\n        category: \"general\",\n      });\n      Survey.JsonObject.metaData.addProperty(\"sortablelist\", {\n        name: \"useDefaultTheme:switch\",\n        default: true,\n        category: \"general\",\n      });\n      Survey.JsonObject.metaData.addProperty(\"sortablelist\", {\n        name: \"maxAnswersCount:number\",\n        default: -1,\n        category: \"general\",\n      });\n    },\n    afterRender: function (question, el) {\n      var self = this;\n\n      if (!question.useDefaultTheme) {\n        self.rootStyle = \"\";\n        self.itemStyle = \"\";\n        self.areaStyle = \"\";\n      }\n      el.style.cssText = self.rootStyle;\n      el.className = \"sjs-sortablejs-root\";\n      var source, result;\n      var resultEl = document.createElement(\"div\");\n      var emptyEl = document.createElement(\"span\");\n      var sourceEl = document.createElement(\"div\");\n\n      resultEl.style.cssText = self.areaStyle;\n      resultEl.style.boxSizing = \"border-box\";\n      resultEl.className = \"sjs-sortablejs-result\";\n\n      emptyEl.innerHTML = question.emptyText;\n      resultEl.appendChild(emptyEl);\n\n      sourceEl.style.cssText = self.areaStyle;\n      sourceEl.style.boxSizing = \"border-box\";\n      sourceEl.className = \"sjs-sortablejs-source\";\n      el.appendChild(resultEl);\n      el.appendChild(sourceEl);\n      var hasValueInResults = function (val) {\n        var res = question.value;\n        if (!Array.isArray(res)) return false;\n        for (var i = 0; i < res.length; i++) {\n          if (res[i] == val) return true;\n        }\n        return false;\n      };\n      var addChoiceToWidget = function (choice, inResults) {\n        var srcEl = inResults ? resultEl : sourceEl;\n        var newEl = document.createElement(\"div\");\n        newEl.className = \"sjs-sortablejs-item\";\n        newEl.style.cssText = self.itemStyle;\n        newEl.innerText = choice.text;\n        newEl.dataset[\"value\"] = choice.value;\n        srcEl.appendChild(newEl);\n        choice.onPropertyChanged.add(function (sender, options) {\n          newEl.innerText = sender.text;\n        });\n      };\n      var getChoicesNotInResults = function () {\n        var res = [];\n        question.visibleChoices.forEach(function (choice) {\n          if (!hasValueInResults(choice.value)) {\n            res.push(choice);\n          }\n        });\n        return res;\n      };\n      var getChoicesInResults = function () {\n        var res = [];\n        var val = question.value;\n        if (!Array.isArray(val)) return res;\n        for (var i = 0; i < val.length; i++) {\n          var item = Survey.ItemValue.getItemByValue(\n            question.visibleChoices,\n            val[i]\n          );\n          if (!!item) {\n            res.push(item);\n          }\n        }\n        return res;\n      };\n      var isUpdatingQuestionValue = false;\n      var updateValueHandler = function () {\n        if (isUpdatingQuestionValue) return;\n        resultEl.innerHTML = \"\";\n        resultEl.appendChild(emptyEl);\n        sourceEl.innerHTML = \"\";\n        var notInResults = getChoicesNotInResults();\n        var inResults = getChoicesInResults();\n        emptyEl.style.display = inResults.length > 0 ? \"none\" : \"\";\n        inResults.forEach(function (choice) {\n          addChoiceToWidget(choice, true);\n        });\n        notInResults.forEach(function (choice) {\n          addChoiceToWidget(choice, false);\n        });\n      };\n      result = question.resultEl = Sortable.create(resultEl, {\n        animation: 150,\n        disabled: question.isReadOnly,\n        group: {\n          name: question.name,\n          put: function (to, from) {\n            return (\n              to.options.group && from.options.group && to.options.group.name === from.options.group.name &&\n              (question.maxAnswersCount < 0 ||\n              to.el.children.length <= question.maxAnswersCount)\n            );\n          },\n        },\n        onSort: function (evt) {\n          var result = [];\n          if (resultEl.children.length === 1) {\n            emptyEl.style.display = \"\";\n          } else {\n            emptyEl.style.display = \"none\";\n            for (var i = 0; i < resultEl.children.length; i++) {\n              if (typeof resultEl.children[i].dataset.value === \"undefined\")\n                continue;\n              result.push(resultEl.children[i].dataset.value);\n            }\n          }\n          isUpdatingQuestionValue = true;\n          question.value = result;\n          isUpdatingQuestionValue = false;\n        },\n      });\n      source = question.sourceEl = Sortable.create(sourceEl, {\n        animation: 150,\n        disabled: question.isReadOnly,\n        group: question.name,\n      });\n      question.valueChangedCallback = updateValueHandler;\n      question.onPropertyChanged.add(function (sender, options) {\n        if (options.name == \"emptyText\") {\n          emptyEl.innerHTML = question.emptyText;\n        }\n      });\n      question.readOnlyChangedCallback = function () {\n        if (question.isReadOnly) {\n          result.options.disabled = true;\n          source.options.disabled = true;\n        } else {\n          result.options.disabled = false;\n          source.options.disabled = false;\n        }\n      };\n      question.registerFunctionOnPropertyValueChanged(\n        \"visibleChoices\",\n        updateValueHandler\n      );\n      updateValueHandler();\n    },\n    willUnmount: function (question, el) {\n      question.resultEl.destroy();\n      question.sourceEl.destroy();\n      question.readOnlyChangedCallback = null;\n    },\n    pdfQuestionType: \"checkbox\",\n  };\n\n  Survey.CustomWidgetCollection.Instance.addCustomWidget(widget, \"customtype\");\n}\n\nif (typeof Survey !== \"undefined\") {\n  init(Survey);\n}\n\nexport default init;\n","module.exports = __WEBPACK_EXTERNAL_MODULE_sortablejs__;"],"sourceRoot":""}