surveyjs-widgets
Version:
Custom widgets for the SurveyJS library
201 lines (188 loc) • 17.4 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/ck-editor", [], factory);
else if(typeof exports === 'object')
exports["widgets/ck-editor"] = factory();
else
root["widgets/ck-editor"] = factory();
})(self, () => {
return /******/ (() => { // webpackBootstrap
/******/ var __webpack_modules__ = ({
/***/ "./node_modules/svg-inline-loader/index.js!./src/images/editor.svg":
/*!*************************************************************************!*\
!*** ./node_modules/svg-inline-loader/index.js!./src/images/editor.svg ***!
\*************************************************************************/
/***/ ((module) => {
module.exports = "<svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><g><polygon points=\"1,3 3,3 3,8 2,8 2,9 3,9 5,9 6,9 6,8 5,8 5,3 7,3 7,4 8,4 8,1 7,1 0,1 0,2 0,3 0,4 1,4 \"></polygon><rect x=\"10\" y=\"5\" width=\"6\" height=\"1\"></rect><rect x=\"10\" y=\"8\" width=\"6\" height=\"1\"></rect><rect y=\"11\" width=\"16\" height=\"1\"></rect><rect y=\"14\" width=\"16\" height=\"1\"></rect></g></svg>"
/***/ })
/******/ });
/************************************************************************/
/******/ // The module cache
/******/ var __webpack_module_cache__ = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/ // Check if module is in cache
/******/ var cachedModule = __webpack_module_cache__[moduleId];
/******/ if (cachedModule !== undefined) {
/******/ return cachedModule.exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = __webpack_module_cache__[moduleId] = {
/******/ // no module.id needed
/******/ // no module.loaded needed
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/************************************************************************/
/******/ /* 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__ = {};
// This entry need to be wrapped in an IIFE because it need to be in strict mode.
(() => {
"use strict";
/*!**************************!*\
!*** ./src/ck-editor.js ***!
\**************************/
__webpack_require__.r(__webpack_exports__);
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
/* harmony export */ });
function init(Survey) {
const iconId = "icon-editor";
const componentName = "editor";
Survey.SvgRegistry && Survey.SvgRegistry.registerIconFromSvg(iconId, __webpack_require__(/*! svg-inline-loader!./images/editor.svg */ "./node_modules/svg-inline-loader/index.js!./src/images/editor.svg"), "");
var widget = {
name: componentName,
title: "Editor",
iconName: iconId,
widgetIsLoaded: function () {
return typeof CKEDITOR != "undefined";
},
isFit: function (question) {
return question.getType() === componentName;
},
htmlTemplate:
"<textarea rows='10' cols='80' style: {width:'100%'}></textarea>",
activatedByChanged: function (activatedBy) {
Survey.Serializer.addClass(componentName, [], null, "empty");
let registerQuestion = Survey.ElementFactory.Instance.registerCustomQuestion;
if(!!registerQuestion) registerQuestion(componentName);
Survey.Serializer.addProperty(componentName, {
name: "height",
default: 300,
category: "general",
});
},
afterRender: function (question, el) {
var name = question.inputId;
CKEDITOR.editorConfig = function (config) {
config.language = "es";
config.height = question.height;
config.toolbarCanCollapse = true;
};
el.name = name;
if (CKEDITOR.instances[name]) {
CKEDITOR.instances[name].removeAllListeners();
CKEDITOR.remove(CKEDITOR.instances[name]);
}
var editor = CKEDITOR.replace(el);
CKEDITOR.instances[name].config.readOnly = question.isReadOnly;
var isValueChanging = false;
var updateValueHandler = function () {
if (isValueChanging || typeof question.value === "undefined") return;
editor.setData(question.value);
};
editor.on("change", function () {
isValueChanging = true;
question.value = editor.getData();
isValueChanging = false;
});
question.valueChangedCallback = updateValueHandler;
question.readOnlyChangedCallback = function () {
if (question.isReadOnly) {
editor.setReadOnly(true);
} else {
editor.setReadOnly(false);
}
};
updateValueHandler();
},
willUnmount: function (question, el) {
question.readOnlyChangedCallback = null;
CKEDITOR.instances[question.inputId].destroy(false);
},
pdfRender: function (survey, options) {
if (options.question.getType() === componentName) {
const loc = new Survey.LocalizableString(survey, true);
loc.text = options.question.value || options.question.defaultValue;
options.question["locHtml"] = loc;
if (
options.question.renderAs === "standard" ||
options.question.renderAs === "image"
) {
options.question["renderAs"] = options.question.renderAs;
} else options.question["renderAs"] = "auto";
const flatHtml = options.repository.create(
survey,
options.question,
options.controller,
"html"
);
return new Promise(function (resolve) {
flatHtml.generateFlats(options.point).then(function (htmlBricks) {
options.bricks = htmlBricks;
resolve();
});
});
}
},
};
Survey.CustomWidgetCollection.Instance.addCustomWidget(widget, "customtype");
}
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/ck-editor.js","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;;;;;;;;;ACVA;;;;;;UCAA;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;WCtBA;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,uEAAuE,mBAAO,CAAC,gHAAuC;AACtH;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA,6CAA6C,aAAa;AAC1D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX,SAAS;AACT;AACA,KAAK;AACL;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA,iEAAe,IAAI,EAAC","sources":["webpack://surveyjs-widgets/webpack/universalModuleDefinition","webpack://surveyjs-widgets/./src/images/editor.svg","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/ck-editor.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/ck-editor\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"widgets/ck-editor\"] = factory();\n\telse\n\t\troot[\"widgets/ck-editor\"] = factory();\n})(self, () => {\nreturn ","module.exports = \"<svg viewBox=\\\"0 0 16 16\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\"><g><polygon points=\\\"1,3 3,3 3,8 2,8 2,9 3,9 5,9 6,9 6,8 5,8 5,3 7,3 7,4 8,4 8,1 7,1 0,1 0,2 0,3 0,4 1,4 \\\"></polygon><rect x=\\\"10\\\" y=\\\"5\\\" width=\\\"6\\\" height=\\\"1\\\"></rect><rect x=\\\"10\\\" y=\\\"8\\\" width=\\\"6\\\" height=\\\"1\\\"></rect><rect y=\\\"11\\\" width=\\\"16\\\" height=\\\"1\\\"></rect><rect y=\\\"14\\\" width=\\\"16\\\" height=\\\"1\\\"></rect></g></svg>\"","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\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  const iconId = \"icon-editor\";\n  const componentName = \"editor\";\n  Survey.SvgRegistry && Survey.SvgRegistry.registerIconFromSvg(iconId, require('svg-inline-loader!./images/editor.svg'), \"\");\n  var widget = {\n    name: componentName,\n    title: \"Editor\",\n    iconName: iconId,\n    widgetIsLoaded: function () {\n      return typeof CKEDITOR != \"undefined\";\n    },\n    isFit: function (question) {\n      return question.getType() === componentName;\n    },\n    htmlTemplate:\n      \"<textarea rows='10' cols='80' style: {width:'100%'}></textarea>\",\n    activatedByChanged: function (activatedBy) {\n      Survey.Serializer.addClass(componentName, [], null, \"empty\");\n      let registerQuestion = Survey.ElementFactory.Instance.registerCustomQuestion;\n      if(!!registerQuestion) registerQuestion(componentName);\n      Survey.Serializer.addProperty(componentName, {\n        name: \"height\",\n        default: 300,\n        category: \"general\",\n      });\n    },\n    afterRender: function (question, el) {\n      var name = question.inputId;\n      CKEDITOR.editorConfig = function (config) {\n        config.language = \"es\";\n        config.height = question.height;\n        config.toolbarCanCollapse = true;\n      };\n      el.name = name;\n\n      if (CKEDITOR.instances[name]) {\n        CKEDITOR.instances[name].removeAllListeners();\n        CKEDITOR.remove(CKEDITOR.instances[name]);\n      }\n\n      var editor = CKEDITOR.replace(el);\n      CKEDITOR.instances[name].config.readOnly = question.isReadOnly;\n\n      var isValueChanging = false;\n      var updateValueHandler = function () {\n        if (isValueChanging || typeof question.value === \"undefined\") return;\n        editor.setData(question.value);\n      };\n      editor.on(\"change\", function () {\n        isValueChanging = true;\n        question.value = editor.getData();\n        isValueChanging = false;\n      });\n\n      question.valueChangedCallback = updateValueHandler;\n      question.readOnlyChangedCallback = function () {\n        if (question.isReadOnly) {\n          editor.setReadOnly(true);\n        } else {\n          editor.setReadOnly(false);\n        }\n      };\n      updateValueHandler();\n    },\n    willUnmount: function (question, el) {\n      question.readOnlyChangedCallback = null;\n      CKEDITOR.instances[question.inputId].destroy(false);\n    },\n    pdfRender: function (survey, options) {\n      if (options.question.getType() === componentName) {\n        const loc = new Survey.LocalizableString(survey, true);\n        loc.text = options.question.value || options.question.defaultValue;\n        options.question[\"locHtml\"] = loc;\n        if (\n          options.question.renderAs === \"standard\" ||\n          options.question.renderAs === \"image\"\n        ) {\n          options.question[\"renderAs\"] = options.question.renderAs;\n        } else options.question[\"renderAs\"] = \"auto\";\n        const flatHtml = options.repository.create(\n          survey,\n          options.question,\n          options.controller,\n          \"html\"\n        );\n        return new Promise(function (resolve) {\n          flatHtml.generateFlats(options.point).then(function (htmlBricks) {\n            options.bricks = htmlBricks;\n            resolve();\n          });\n        });\n      }\n    },\n  };\n\n  Survey.CustomWidgetCollection.Instance.addCustomWidget(widget, \"customtype\");\n}\n\nif (typeof Survey !== \"undefined\") {\n  init(Survey);\n}\n\nexport default init;\n"],"names":[],"sourceRoot":""}