surveyjs-widgets
Version:
Custom widgets for the SurveyJS library
286 lines (275 loc) • 24.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/jquery-ui-datepicker", [], factory);
else if(typeof exports === 'object')
exports["widgets/jquery-ui-datepicker"] = factory();
else
root["widgets/jquery-ui-datepicker"] = factory();
})(self, () => {
return /******/ (() => { // webpackBootstrap
/******/ var __webpack_modules__ = ({
/***/ "./node_modules/svg-inline-loader/index.js?classPrefix!./src/images/datepicker.svg":
/*!*****************************************************************************************!*\
!*** ./node_modules/svg-inline-loader/index.js?classPrefix!./src/images/datepicker.svg ***!
\*****************************************************************************************/
/***/ ((module) => {
module.exports = "<svg viewBox=\"0 0 16 16\" xmlns=\"http://www.w3.org/2000/svg\"><g><rect x=\"3\" y=\"7\" width=\"2\" height=\"2\"></rect><rect x=\"7\" y=\"11\" width=\"2\" height=\"2\"></rect><rect x=\"3\" y=\"11\" width=\"2\" height=\"2\"></rect><rect x=\"11\" y=\"11\" width=\"2\" height=\"2\"></rect><rect x=\"11\" y=\"7\" width=\"2\" height=\"2\"></rect><path d=\"M10,6H6v4h4V6z M9,9H7V7h2V9z\"></path><rect x=\"4\" width=\"1\" height=\"3\"></rect><rect x=\"11\" width=\"1\" height=\"3\"></rect><path d=\"M13,2v2h-3V2H6v2H3V2H0v14h16V2H13z M15,15H1V5h14V15z\"></path></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.
(() => {
;
/*!*************************************!*\
!*** ./src/jquery-ui-datepicker.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-datepicker";
const componentName = "datepicker";
Survey.SvgRegistry && Survey.SvgRegistry.registerIconFromSvg(iconId, __webpack_require__(/*! svg-inline-loader?classPrefix!./images/datepicker.svg */ "./node_modules/svg-inline-loader/index.js?classPrefix!./src/images/datepicker.svg"), "");
$ = $ || window.$;
if (
!!$ &&
!$.fn.bootstrapDP &&
!!$.fn.datepicker &&
!!$.fn.datepicker.noConflict
) {
$.fn.bootstrapDP = $.fn.datepicker.noConflict();
if (!$.fn.datepicker) {
$.fn.datepicker = $.fn.bootstrapDP;
}
}
var widget = {
name: componentName,
title: "Date picker",
iconName: iconId,
widgetIsLoaded: function () {
return !!$ && !!$.fn.datepicker && !$.fn.datepicker.noConflict;
},
isFit: function (question) {
return question.getType() === componentName;
},
htmlTemplate: "<input class='form-control widget-datepicker' type='text'>",
activatedByChanged: function (activatedBy) {
Survey.Serializer.addClass(
componentName,
[
{ name: "inputType", visible: false },
{ name: "inputFormat", visible: false },
{ name: "inputMask", visible: false },
],
null,
"text"
);
let registerQuestion = Survey.ElementFactory.Instance.registerCustomQuestion;
if(!!registerQuestion) registerQuestion(componentName);
Survey.Serializer.addProperty(componentName, {
name: "dateFormat",
category: "general",
});
Survey.Serializer.addProperty(componentName, {
name: "config",
category: "general",
visible: false,
default: null,
});
Survey.Serializer.addProperty(componentName, {
name: "maxDate",
category: "general",
});
Survey.Serializer.addProperty(componentName, {
name: "minDate",
category: "general",
});
Survey.Serializer.addProperty(componentName, {
name: "disableInput:boolean",
category: "general",
});
},
afterRender: function (question, el) {
var $el = $(el).is(".widget-datepicker")
? $(el)
: $(el).find(".widget-datepicker");
$el.addClass(question.css.text.root);
var isSelecting = false;
var config = $.extend(true, {}, question.config || {});
if (!!question.placeHolder) {
$el.attr("placeholder", question.placeHolder);
}
if (config.dateFormat === undefined) {
config.dateFormat = !!question.dateFormat
? question.dateFormat
: undefined;
}
if (config.option === undefined) {
config.option = {
minDate: null,
maxDate: null,
};
}
if (!!question.minDate) {
config.minDate = question.minDate;
}
if (!!question.maxDate) {
config.maxDate = question.maxDate;
}
if (!!question.renderedMin) {
config.minDate = new Date(question.renderedMin);
}
if (!!question.renderedMax) {
config.maxDate = new Date(question.renderedMax);
}
config.disabled = question.isReadOnly;
if (config.onSelect === undefined) {
config.onSelect = function (dateText) {
isSelecting = true;
setDateIntoQuestion();
isSelecting = false;
this.fixFocusIE = true;
};
}
config.fixFocusIE = false;
config.onClose = function (dateText, inst) {
this.fixFocusIE = true;
};
config.beforeShow = function (input, inst) {
var result = !!navigator.userAgent.match(/Trident\/7\./)
? !this.fixFocusIE
: true;
this.fixFocusIE = false;
return result;
};
function setDateIntoQuestion() {
var val = $el.datepicker('getDate');
var d = new Date();
val.setHours(d.getHours());
val.setMinutes(d.getMinutes());
val.setSeconds(d.getSeconds());
question.value = val;
}
var pickerWidget = $el.datepicker(config).on("change", function (e) {
setDateIntoQuestion();
});
$el.keyup(function (e) {
if (e.keyCode == 8 || e.keyCode == 46) {
$.datepicker._clearDate(this);
}
});
if(question.disableInput) {
$el.attr("readOnly", "true");
}
question.readOnlyChangedCallback = function () {
$el.datepicker("option", "disabled", question.isReadOnly);
};
function updateDate() {
if (!question.isEmpty()) {
var val = question.value;
if(typeof val === "string") {
val = new Date(val);
}
pickerWidget.datepicker("setDate", val);
} else {
pickerWidget.datepicker("setDate", null);
}
}
question.registerFunctionOnPropertyValueChanged(
"dateFormat",
function () {
question.dateFormat &&
pickerWidget.datepicker(
"option",
"dateFormat",
question.dateFormat
);
updateDate();
}
);
question.valueChangedCallback = function () {
if (!isSelecting) {
updateDate();
$el.blur();
}
};
question.valueChangedCallback();
},
willUnmount: function (question, el) {
var $el = $(el).is(".widget-datepicker")
? $(el)
: $(el).find(".widget-datepicker");
$el.datepicker("destroy");
},
pdfQuestionType: "text",
};
Survey.CustomWidgetCollection.Instance.addCustomWidget(widget, "customtype");
}
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/jquery-ui-datepicker.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,gJAAuD;AACtI;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,YAAY,mCAAmC;AAC/C,YAAY,qCAAqC;AACjD,YAAY,mCAAmC;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,uBAAuB;AAC3D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA,iEAAe,IAAI,EAAC","sources":["webpack://surveyjs-widgets/webpack/universalModuleDefinition","webpack://surveyjs-widgets/./src/images/datepicker.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/jquery-ui-datepicker.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/jquery-ui-datepicker\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"widgets/jquery-ui-datepicker\"] = factory();\n\telse\n\t\troot[\"widgets/jquery-ui-datepicker\"] = factory();\n})(self, () => {\nreturn ","module.exports = \"<svg viewBox=\\\"0 0 16 16\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\"><g><rect x=\\\"3\\\" y=\\\"7\\\" width=\\\"2\\\" height=\\\"2\\\"></rect><rect x=\\\"7\\\" y=\\\"11\\\" width=\\\"2\\\" height=\\\"2\\\"></rect><rect x=\\\"3\\\" y=\\\"11\\\" width=\\\"2\\\" height=\\\"2\\\"></rect><rect x=\\\"11\\\" y=\\\"11\\\" width=\\\"2\\\" height=\\\"2\\\"></rect><rect x=\\\"11\\\" y=\\\"7\\\" width=\\\"2\\\" height=\\\"2\\\"></rect><path d=\\\"M10,6H6v4h4V6z M9,9H7V7h2V9z\\\"></path><rect x=\\\"4\\\" width=\\\"1\\\" height=\\\"3\\\"></rect><rect x=\\\"11\\\" width=\\\"1\\\" height=\\\"3\\\"></rect><path d=\\\"M13,2v2h-3V2H6v2H3V2H0v14h16V2H13z M15,15H1V5h14V15z\\\"></path></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-datepicker\";\n  const componentName = \"datepicker\";\n  Survey.SvgRegistry && Survey.SvgRegistry.registerIconFromSvg(iconId, require('svg-inline-loader?classPrefix!./images/datepicker.svg'), \"\");\n  $ = $ || window.$;\n  if (\n    !!$ &&\n    !$.fn.bootstrapDP &&\n    !!$.fn.datepicker &&\n    !!$.fn.datepicker.noConflict\n  ) {\n    $.fn.bootstrapDP = $.fn.datepicker.noConflict();\n    if (!$.fn.datepicker) {\n      $.fn.datepicker = $.fn.bootstrapDP;\n    }\n  }\n  var widget = {\n    name: componentName,\n    title: \"Date picker\",\n    iconName: iconId,\n    widgetIsLoaded: function () {\n      return !!$ && !!$.fn.datepicker && !$.fn.datepicker.noConflict;\n    },\n    isFit: function (question) {\n      return question.getType() === componentName;\n    },\n    htmlTemplate: \"<input class='form-control widget-datepicker' type='text'>\",\n    activatedByChanged: function (activatedBy) {\n      Survey.Serializer.addClass(\n        componentName,\n        [\n          { name: \"inputType\", visible: false },\n          { name: \"inputFormat\", visible: false },\n          { name: \"inputMask\", visible: false },\n        ],\n        null,\n        \"text\"\n      );\n      let registerQuestion = Survey.ElementFactory.Instance.registerCustomQuestion;\n      if(!!registerQuestion) registerQuestion(componentName);\n      Survey.Serializer.addProperty(componentName, {\n        name: \"dateFormat\",\n        category: \"general\",\n      });\n      Survey.Serializer.addProperty(componentName, {\n        name: \"config\",\n        category: \"general\",\n        visible: false,\n        default: null,\n      });\n      Survey.Serializer.addProperty(componentName, {\n        name: \"maxDate\",\n        category: \"general\",\n      });\n      Survey.Serializer.addProperty(componentName, {\n        name: \"minDate\",\n        category: \"general\",\n      });\n      Survey.Serializer.addProperty(componentName, {\n        name: \"disableInput:boolean\",\n        category: \"general\",\n      });\n    },\n    afterRender: function (question, el) {\n      var $el = $(el).is(\".widget-datepicker\")\n        ? $(el)\n        : $(el).find(\".widget-datepicker\");\n      $el.addClass(question.css.text.root);\n      var isSelecting = false;\n      var config = $.extend(true, {}, question.config || {});\n      if (!!question.placeHolder) {\n        $el.attr(\"placeholder\", question.placeHolder);\n      }\n      if (config.dateFormat === undefined) {\n        config.dateFormat = !!question.dateFormat\n          ? question.dateFormat\n          : undefined;\n      }\n      if (config.option === undefined) {\n        config.option = {\n          minDate: null,\n          maxDate: null,\n        };\n      }\n      if (!!question.minDate) {\n        config.minDate = question.minDate;\n      }\n      if (!!question.maxDate) {\n        config.maxDate = question.maxDate;\n      }\n      if (!!question.renderedMin) {\n        config.minDate = new Date(question.renderedMin);\n      }\n      if (!!question.renderedMax) {\n        config.maxDate = new Date(question.renderedMax);\n      }\n      config.disabled = question.isReadOnly;\n      if (config.onSelect === undefined) {\n        config.onSelect = function (dateText) {\n          isSelecting = true;\n          setDateIntoQuestion();\n          isSelecting = false;\n          this.fixFocusIE = true;\n        };\n      }\n      config.fixFocusIE = false;\n      config.onClose = function (dateText, inst) {\n        this.fixFocusIE = true;\n      };\n      config.beforeShow = function (input, inst) {\n        var result = !!navigator.userAgent.match(/Trident\\/7\\./)\n          ? !this.fixFocusIE\n          : true;\n        this.fixFocusIE = false;\n        return result;\n      };\n      function setDateIntoQuestion() {\n        var val = $el.datepicker('getDate');\n        var d = new Date();\n        val.setHours(d.getHours());\n        val.setMinutes(d.getMinutes());\n        val.setSeconds(d.getSeconds());\n        question.value = val;\n      }\n      var pickerWidget = $el.datepicker(config).on(\"change\", function (e) {\n        setDateIntoQuestion();\n      });\n\n      $el.keyup(function (e) {\n        if (e.keyCode == 8 || e.keyCode == 46) {\n          $.datepicker._clearDate(this);\n        }\n      });\n      if(question.disableInput) {\n        $el.attr(\"readOnly\", \"true\");\n      }\n\n      question.readOnlyChangedCallback = function () {\n        $el.datepicker(\"option\", \"disabled\", question.isReadOnly);\n      };\n      function updateDate() {\n        if (!question.isEmpty()) {\n          var val = question.value;\n          if(typeof val === \"string\") {\n            val = new Date(val);\n          }\n          pickerWidget.datepicker(\"setDate\", val);\n        } else {\n          pickerWidget.datepicker(\"setDate\", null);\n        }\n      }\n      question.registerFunctionOnPropertyValueChanged(\n        \"dateFormat\",\n        function () {\n          question.dateFormat &&\n            pickerWidget.datepicker(\n              \"option\",\n              \"dateFormat\",\n              question.dateFormat\n            );\n          updateDate();\n        }\n      );\n      question.valueChangedCallback = function () {\n        if (!isSelecting) {\n          updateDate();\n          $el.blur();\n        }\n      };\n      question.valueChangedCallback();\n    },\n    willUnmount: function (question, el) {\n      var $el = $(el).is(\".widget-datepicker\")\n        ? $(el)\n        : $(el).find(\".widget-datepicker\");\n      $el.datepicker(\"destroy\");\n    },\n    pdfQuestionType: \"text\",\n  };\n\n  Survey.CustomWidgetCollection.Instance.addCustomWidget(widget, \"customtype\");\n}\n\nif (typeof Survey !== \"undefined\") {\n  init(Survey, window.jQuery);\n}\n\nexport default init;\n"],"names":[],"sourceRoot":""}