Sindbad~EG File Manager
/******/ (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 = "./includes/templates/vuejs/portal/build/build.js");
/******/ })
/************************************************************************/
/******/ ({
/***/ "./includes/templates/vuejs/portal/build/build.js":
/*!********************************************************!*\
!*** ./includes/templates/vuejs/portal/build/build.js ***!
\********************************************************/
/*! no exports provided */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! vue */ \"./node_modules/vue/dist/vue.esm.js\");\n/* harmony import */ var _classes_Cms_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./classes/Cms.js */ \"./includes/templates/vuejs/portal/build/classes/Cms.js\");\n/* harmony import */ var _classes_Egg_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./classes/Egg.js */ \"./includes/templates/vuejs/portal/build/classes/Egg.js\");\n/* harmony import */ var _components_loader_vue__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./components/loader.vue */ \"./includes/templates/vuejs/portal/build/components/loader.vue\");\n/* harmony import */ var _components_accordion_accordion_vue__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./components/accordion/accordion.vue */ \"./includes/templates/vuejs/portal/build/components/accordion/accordion.vue\");\n/* harmony import */ var _components_nav_nav_vue__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./components/nav/nav.vue */ \"./includes/templates/vuejs/portal/build/components/nav/nav.vue\");\n/* harmony import */ var _components_page_pageForm_vue__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./components/page/pageForm.vue */ \"./includes/templates/vuejs/portal/build/components/page/pageForm.vue\");\n/* harmony import */ var _components_gabarit_gabaritForm_vue__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./components/gabarit/gabaritForm.vue */ \"./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue\");\n/* harmony import */ var _components_frame_frameForm_vue__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./components/frame/frameForm.vue */ \"./includes/templates/vuejs/portal/build/components/frame/frameForm.vue\");\n/* harmony import */ var _components_layout_layout_vue__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./components/layout/layout.vue */ \"./includes/templates/vuejs/portal/build/components/layout/layout.vue\");\n/* harmony import */ var _components_preview_preview_vue__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./components/preview/preview.vue */ \"./includes/templates/vuejs/portal/build/components/preview/preview.vue\");\n/* harmony import */ var _components_page_pageTypeForm_vue__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./components/page/pageTypeForm.vue */ \"./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue\");\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n // Do not remove !\n\n\n/**\n * Components\n */\n\n\n\n\n\n\n\n\n\n\n/**\n * Cms est un plugin fait pour être utilisé dans Vuejs\n * Pour l'utiliser dans le composant, il faut faire \"this.$cms\"\n */\n\nvue__WEBPACK_IMPORTED_MODULE_0__[\"default\"].use(_classes_Cms_js__WEBPACK_IMPORTED_MODULE_1__[\"default\"], _objectSpread({}, $data, {}, $cmsData));\nwindow.addEventListener(\"load\", function () {\n Object(_classes_Egg_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])();\n var input = document.createElement(\"input\");\n input.id = \"cms_build_info\";\n input.name = \"cms_build_info\";\n input.type = \"hidden\";\n\n if ($data.cms_build_info) {\n input.value = $data.cms_build_info;\n }\n\n document.head.appendChild(input);\n new vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"]({\n el: \"#portal\",\n components: {\n loader: _components_loader_vue__WEBPACK_IMPORTED_MODULE_3__[\"default\"],\n accordion: _components_accordion_accordion_vue__WEBPACK_IMPORTED_MODULE_4__[\"default\"],\n navigation: _components_nav_nav_vue__WEBPACK_IMPORTED_MODULE_5__[\"default\"],\n page_form: _components_page_pageForm_vue__WEBPACK_IMPORTED_MODULE_6__[\"default\"],\n gabarit_form: _components_gabarit_gabaritForm_vue__WEBPACK_IMPORTED_MODULE_7__[\"default\"],\n frame_form: _components_frame_frameForm_vue__WEBPACK_IMPORTED_MODULE_8__[\"default\"],\n layout: _components_layout_layout_vue__WEBPACK_IMPORTED_MODULE_9__[\"default\"],\n preview: _components_preview_preview_vue__WEBPACK_IMPORTED_MODULE_10__[\"default\"],\n page_type_form: _components_page_pageTypeForm_vue__WEBPACK_IMPORTED_MODULE_11__[\"default\"]\n },\n mounted: function mounted() {\n this.$el.style = \"\";\n },\n computed: {\n container: function container() {\n return this.$cms.container;\n }\n }\n });\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/build.js?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/classes/Cms.js":
/*!**************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/classes/Cms.js ***!
\**************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _CmsModel_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./CmsModel.js */ \"./includes/templates/vuejs/portal/build/classes/CmsModel.js\");\nfunction _createForOfIteratorHelper(o) { if (typeof Symbol === \"undefined\" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (o = _unsupportedIterableToArray(o))) { var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var it, normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it[\"return\"] != null) it[\"return\"](); } finally { if (didErr) throw err; } } }; }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(n); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }\n\nfunction _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err); } _next(undefined); }); }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\n\nvar proxyHandler = {\n get: function get(cms, prop, receiver) {\n if (typeof cms.store.$data[prop] != \"undefined\") {\n return Reflect.get(cms.store.$data, prop, receiver);\n }\n\n if (typeof cms[prop] != \"undefined\") {\n return Reflect.get.apply(Reflect, arguments);\n }\n\n return undefined;\n },\n set: function set(cms, prop, value) {\n if (typeof cms.store.$data[prop] != \"undefined\") {\n return Reflect.set(cms.store.$data, prop, value);\n }\n\n return Reflect.set.apply(Reflect, arguments);\n }\n};\n\nvar Cms = /*#__PURE__*/function () {\n function Cms(Vue, options) {\n var _this = this;\n\n _classCallCheck(this, Cms);\n\n // Définir ici toutes les propriétés \n var properties = {\n container: {\n title: \"\",\n component: \"\",\n data: {\n type: \"\",\n item: {\n contexts: []\n },\n component: \"\"\n }\n },\n itemNavActive: -1,\n itemsNav: [],\n framesClassements: [],\n gabaritsClassements: [],\n zoneList: [],\n refreshFrameList: false,\n gabaritsDisplayType: 0,\n showUnusedGabarit: 1\n }; // On récupère les paramètres donnés au plugin\n\n for (var prop in options) {\n properties[prop] = this.cloneObject(options[prop]);\n }\n\n this.store = new Vue({\n data: function data() {\n return properties;\n }\n }); // Cela nous permet d'avoir un plugin réactif :\n // getter et setter \"magique\"\n\n this.proxy = new Proxy(this, proxyHandler);\n\n var _loop = function _loop(_prop) {\n _this.__defineGetter__([_prop], function () {\n return _this.proxy[_prop];\n });\n\n _this.__defineSetter__([_prop], function (value) {\n return _this.proxy[_prop] = value;\n });\n };\n\n for (var _prop in properties) {\n _loop(_prop);\n }\n\n return this.proxy;\n }\n\n _createClass(Cms, [{\n key: \"init\",\n value: function init() {\n var model = new _CmsModel_js__WEBPACK_IMPORTED_MODULE_0__[\"default\"](this.url_base, this.portal.version_num);\n this.model = new Proxy(model, {\n get: function get(model, prop, receiver) {\n var result = undefined;\n\n if (typeof model[prop] != \"undefined\") {\n result = Reflect.get.apply(Reflect, arguments);\n }\n\n if (typeof model.ws[prop] != \"undefined\") {\n result = Reflect.get(model.ws, prop, receiver);\n }\n\n if (result.error) {\n throw result.errorMessage;\n }\n\n return result;\n }\n });\n }\n }, {\n key: \"cloneObject\",\n value: function cloneObject(obj) {\n if (obj instanceof Array) {\n var clone = new Array();\n\n for (var index in obj) {\n clone[index] = this.cloneObject(obj[index]);\n }\n\n return clone;\n } else if (obj instanceof Object) {\n // On clone object on fait en sorte d'avoir les getter/setter\n var clone = Object.create(Object.getPrototypeOf(obj));\n var descriptors = Object.getOwnPropertyDescriptors(obj);\n Object.defineProperties(clone, descriptors);\n return clone;\n }\n\n return obj;\n }\n }, {\n key: \"getMessage\",\n value: function getMessage(code) {\n var _pmbDojo$messages$get;\n\n return (_pmbDojo$messages$get = pmbDojo.messages.getMessage('portal', code)) !== null && _pmbDojo$messages$get !== void 0 ? _pmbDojo$messages$get : '';\n }\n }, {\n key: \"getImage\",\n value: function getImage(image) {\n var _pmbDojo$images$getIm;\n\n var imgName = image.replace(/\\.[a-zA-Z]+/, \"\");\n\n if (this.img[imgName]) {\n var _this$img$imgName;\n\n return (_this$img$imgName = this.img[imgName]) !== null && _this$img$imgName !== void 0 ? _this$img$imgName : '';\n }\n\n return (_pmbDojo$images$getIm = pmbDojo.images.getImage(image)) !== null && _pmbDojo$images$getIm !== void 0 ? _pmbDojo$images$getIm : '';\n }\n }, {\n key: \"getTypeFromSubType\",\n value: function getTypeFromSubType(sub_type) {\n var type_code = parseInt(sub_type / 100);\n\n switch (type_code) {\n case 40:\n // cas spécifique pour les animations\n return 39;\n\n case 33:\n // cas spécifique pour les univers\n return 34;\n\n case 34:\n // cas spécifique pour les segments\n return 35;\n\n default:\n return type_code;\n }\n }\n }, {\n key: \"getFormatedChildren\",\n value: function getFormatedChildren(gabaritId) {\n var _this2 = this;\n\n var children = [];\n var gabaritInheritance = this.getGabaritInheritanceOf(gabaritId);\n\n if (this.showUnusedGabarit == 0) {\n gabaritInheritance = gabaritInheritance.filter(function (gabarit) {\n return _this2.gabaritIsUsed(gabarit.id);\n });\n }\n\n gabaritInheritance.forEach(function (gabarit) {\n var isEdited = false;\n\n if (gabarit.legacy_layout != null && gabarit.children.length > 0) {\n isEdited = true;\n }\n\n children.push({\n title: gabarit.name,\n isTag: false,\n isEdited: isEdited,\n children: _this2.getFormatedChildren(gabarit.id),\n data: {\n type: \"gabarit\",\n name: gabarit.name,\n item: gabarit\n }\n });\n });\n return children;\n }\n }, {\n key: \"getGabaritInheritanceOf\",\n value: function getGabaritInheritanceOf(gabaritId) {\n return this.gabarits.filter(function (gabarit) {\n return gabarit.legacy_layout != null && gabarit.legacy_layout.id == gabaritId;\n }) || [];\n }\n }, {\n key: \"gabaritIsUsed\",\n value: function gabaritIsUsed(gabarit_id) {\n var gabaritInheritance = this.getGabaritInheritanceOf(gabarit_id);\n\n for (var index in gabaritInheritance) {\n if (this.gabaritIsUsed(gabaritInheritance[index].id)) {\n return true;\n }\n }\n\n return this.getPagesUsingGabarit(gabarit_id).length > 0;\n }\n /**\n * tree_view = 1 : vue en arbre\n * tree_view = 0 : vue en classement\n */\n\n }, {\n key: \"formatGabaritsAccordion\",\n value: function formatGabaritsAccordion() {\n var _this3 = this;\n\n var tree_view = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n var default_classement = this.getMessage('default_classement');\n var gabarits = {};\n var gabaritList = this.gabarits;\n\n if (this.showUnusedGabarit == 0) {\n var gabaritList = this.gabarits.filter(function (gabarit) {\n return _this3.gabaritIsUsed(gabarit.id);\n });\n }\n\n gabaritList.forEach(function (gabarit) {\n if (gabarit.legacy_layout && tree_view > 0) {\n return;\n }\n\n var classement = gabarit.classement && gabarit.classement != \"\" ? gabarit.classement : default_classement;\n\n if (tree_view > 0) {\n classement = _this3.getMessage('tree_classement');\n }\n\n if (!gabarits[classement]) {\n gabarits[classement] = {\n title: classement,\n isTag: true,\n children: []\n };\n }\n\n var isEdited = false;\n\n if (gabarit.legacy_layout != null) {\n var index = gabarit.legacy_layout[\"class\"] + \"_\" + gabarit.legacy_layout.id;\n\n if (gabarit.layouts[index] && gabarit.layouts[index].length > 0) {\n isEdited = true;\n }\n }\n\n gabarits[classement].children.push({\n title: gabarit.name,\n isTag: false,\n isEdited: isEdited,\n classement: classement,\n data: {\n type: \"gabarit\",\n name: gabarit.name,\n item: gabarit\n },\n children: tree_view > 0 ? _this3.getFormatedChildren(gabarit.id) : []\n });\n }); // On récupère tout les classements définis\n\n this.gabaritsClassements = Object.keys(gabarits);\n return Object.values(gabarits);\n }\n }, {\n key: \"formatPagesAccordion\",\n value: function formatPagesAccordion() {\n var _this4 = this;\n\n var formatedPages = {};\n this.portal.types.forEach(function (type) {\n formatedPages[type.value] = {\n title: type.label,\n isTag: true,\n children: [],\n data: {\n type: \"pageType\",\n name: type.label,\n item: {\n type: type.value\n }\n }\n };\n });\n this.portal.sub_types.forEach(function (sub_type) {\n var type_code = _this4.getTypeFromSubType(sub_type.value);\n\n var type = formatedPages[type_code] !== undefined ? formatedPages[type_code] : null;\n\n if (type) {\n var page = null;\n var children = [];\n\n var pages = _this4.getPages(type_code, sub_type.value);\n\n if (pages.length > 0) {\n var indexPage = pages.findIndex(function (page) {\n return page.conditions.length == 0;\n });\n\n if (0 <= indexPage && indexPage <= pages.length) {\n var _pages$indexPage;\n\n page = (_pages$indexPage = pages[indexPage]) !== null && _pages$indexPage !== void 0 ? _pages$indexPage : null;\n pages.splice(indexPage, 1);\n }\n\n pages.forEach(function (page) {\n // Page de portail\n var name = page.name;\n\n if (type_code == 25) {\n var id = parseInt(page.sub_type.toString().substr(2), 10);\n\n if (id) {\n name += \" id: \".concat(id);\n }\n }\n\n children.push({\n title: page.name,\n isTag: false,\n isEdited: _this4.pageIsEdited(page),\n data: {\n type: \"page\",\n name: name,\n item: page\n },\n children: []\n });\n });\n }\n\n if (!page) {\n var dataName = sub_type.label;\n page = {\n \"class\": \"Pmb\\\\CMS\\\\Models\\\\PageModel\",\n id: 0,\n name: sub_type.label,\n conditions: [],\n gabarit_layout: {},\n parent_page: {},\n page_layout: {\n layouts: {}\n },\n type: type_code,\n sub_type: sub_type.value\n };\n } else {\n var dataName = page.name;\n } // Page de portail\n\n\n if (type_code == 25) {\n var id = parseInt(page.sub_type.toString().substr(2), 10);\n\n if (id) {\n dataName += \" id: \".concat(id);\n }\n }\n\n var sub_page = {\n title: page.name,\n isTag: false,\n isEdited: _this4.pageIsEdited(page),\n data: {\n type: \"page\",\n name: dataName,\n item: page\n },\n children: children\n };\n type.children.push(sub_page);\n }\n });\n return Object.values(formatedPages);\n }\n }, {\n key: \"formatFramesAccordion\",\n value: function formatFramesAccordion() {\n var opac = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;\n var default_classement = this.getMessage('default_classement');\n var frames = {};\n\n for (var index in this.frames) {\n var frame = this.frames[index];\n\n if (!opac && frame && frame[\"class\"].includes('FrameOpac')) {\n continue;\n }\n\n var classement = frame.classement && frame.classement != \"\" ? frame.classement : default_classement;\n\n if (!frames[classement]) {\n frames[classement] = {\n title: classement,\n isTag: true,\n children: []\n };\n }\n\n frames[classement].children.push({\n title: frame.name,\n isTag: false,\n isEdited: false,\n classement: classement,\n data: {\n type: \"frame\",\n name: frame.name,\n item: frame\n },\n children: []\n });\n } // On récupère tout les classements définis\t\t\n\n\n this.framesClassements = Object.keys(frames);\n return Object.values(frames);\n }\n }, {\n key: \"addPage\",\n value: function addPage() {\n this.resetNav();\n this.itemsNav.push({\n title: this.getMessage(\"nav_prop_page\"),\n component: 'prop-page',\n data: {\n type: \"page\",\n name: \"\"\n }\n });\n }\n }, {\n key: \"addFrame\",\n value: function addFrame() {\n this.resetNav();\n this.itemsNav.push({\n title: this.getMessage(\"nav_prop_frame\"),\n data: {\n type: \"frame\",\n name: \"\"\n },\n component: 'prop-frame'\n });\n }\n }, {\n key: \"addGabarit\",\n value: function addGabarit() {\n this.resetNav();\n this.itemsNav.push({\n title: this.getMessage(\"nav_prop_gabarit\"),\n component: 'prop-gabarit',\n data: {\n type: \"gabarit\",\n name: \"\"\n }\n });\n }\n }, {\n key: \"openPage\",\n value: function openPage(page) {\n var subNav = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n this.pageOpen = page;\n this.pageOpen.subNav = subNav;\n\n if (!subNav) {\n this.closeGabarit();\n }\n\n this.closePageType();\n }\n }, {\n key: \"closePage\",\n value: function closePage() {\n this.pageOpen = undefined;\n }\n }, {\n key: \"openGabarit\",\n value: function openGabarit(gabarit) {\n this.gabaritOpen = gabarit;\n this.closePage();\n this.closePageType();\n }\n }, {\n key: \"closeGabarit\",\n value: function closeGabarit() {\n this.gabaritOpen = undefined;\n }\n }, {\n key: \"openFrame\",\n value: function openFrame(frame) {\n this.frameOpen = frame;\n this.closePageType();\n }\n }, {\n key: \"closeFrame\",\n value: function closeFrame() {\n this.frameOpen = undefined;\n }\n }, {\n key: \"openPageType\",\n value: function openPageType(pageType) {\n this.pageTypeOpen = pageType;\n this.closePage();\n this.closeGabarit();\n }\n }, {\n key: \"closePageType\",\n value: function closePageType() {\n this.pageTypeOpen = undefined;\n }\n }, {\n key: \"openItem\",\n value: function openItem(data) {\n var fromBanner = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n\n if (fromBanner) {\n this.resetNav();\n this.clearContainer();\n }\n\n switch (data['type']) {\n case \"pageType\":\n this.openPageType(data);\n break;\n\n case \"page\":\n this.openPage(data);\n break;\n\n case \"frame\":\n this.openFrame(data);\n break;\n\n case \"gabarit\":\n this.openGabarit(data);\n break;\n\n case \"pageSubNav\":\n this.openPage(data, true);\n break;\n }\n\n this.generateItemsNav();\n }\n }, {\n key: \"refreshItemOpen\",\n value: function refreshItemOpen() {\n var _this5 = this;\n\n if (this.pageOpen) {\n this.pageOpen.item = this.pages.find(function (page) {\n return page.id == _this5.pageOpen.item.id;\n });\n }\n\n if (this.gabaritOpen) {\n this.gabaritOpen.item = this.gabarits.find(function (gabarit) {\n return gabarit.id == _this5.gabaritOpen.item.id;\n });\n }\n\n if (this.frameOpen) {\n this.frameOpen.item = this.frames.find(function (frame) {\n return frame.id == _this5.frameOpen.item.id;\n });\n }\n\n this.generateItemsNav();\n }\n }, {\n key: \"generateItemsNav\",\n value: function generateItemsNav() {\n var itemsNav = [];\n\n if (this.pageTypeOpen) {\n itemsNav.push({\n title: this.getMessage(\"nav_prop_page_type\"),\n data: this.pageTypeOpen,\n component: 'prop-page-type'\n });\n } else {\n if (this.gabaritOpen) {\n itemsNav.push({\n title: this.getMessage(\"nav_prop_gabarit\"),\n data: this.gabaritOpen,\n component: 'prop-gabarit'\n });\n\n if (this.gabaritOpen.item.id > 0) {\n itemsNav.push({\n title: this.getMessage(\"nav_layout\"),\n data: this.gabaritOpen,\n component: 'layout'\n });\n }\n }\n\n var pageNav = [];\n\n if (this.pageOpen) {\n pageNav.push({\n title: this.getMessage(\"nav_prop_page\"),\n data: this.pageOpen,\n component: 'prop-page'\n });\n\n if (this.pageOpen.item.id > 0) {\n pageNav.push({\n title: this.getMessage(\"nav_layout\"),\n data: this.pageOpen,\n component: 'layout'\n });\n pageNav.push({\n title: this.getMessage(\"nav_prev\"),\n data: this.pageOpen,\n component: 'prev'\n });\n }\n }\n\n if (this.pageOpen && this.pageOpen.subNav) {\n itemsNav.push({\n title: this.getMessage(\"gabarit_page_label\"),\n data: this.pageOpen,\n component: 'prop-page',\n subNav: pageNav\n });\n } else {\n itemsNav.push.apply(itemsNav, pageNav);\n }\n }\n\n if (this.frameOpen) {\n itemsNav.push({\n title: this.getMessage(\"nav_prop_frame\"),\n data: this.frameOpen,\n component: 'prop-frame'\n });\n }\n\n this.itemsNav = itemsNav;\n }\n }, {\n key: \"resetNav\",\n value: function resetNav() {\n this.itemNavActive = -1;\n this.itemsNav = [];\n this.closePage();\n this.closeFrame();\n this.closeGabarit();\n }\n }, {\n key: \"resetVue\",\n value: function resetVue() {\n this.resetNav();\n this.clearContainer();\n this.generateItemsNav();\n }\n }, {\n key: \"getPages\",\n value: function getPages(type, sub_type) {\n return this.pages.filter(function (page) {\n return page.type == type && page.sub_type == sub_type;\n });\n }\n }, {\n key: \"getPagesUsingGabarit\",\n value: function getPagesUsingGabarit(gabaritId) {\n return this.pages.filter(function (page) {\n return page.gabarit_layout && page.gabarit_layout.id && page.gabarit_layout.id == gabaritId;\n });\n }\n }, {\n key: \"updateGabarit\",\n value: function () {\n var _updateGabarit = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(data) {\n var result, gabarit;\n return regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n this.showLoader();\n\n if (!data.gabarit.id) {\n _context.next = 7;\n break;\n }\n\n _context.next = 4;\n return this.model.updateGabarit(data.gabarit.id, data);\n\n case 4:\n result = _context.sent;\n _context.next = 10;\n break;\n\n case 7:\n _context.next = 9;\n return this.model.createGabarit(data);\n\n case 9:\n result = _context.sent;\n\n case 10:\n if (result.error) {\n _context.next = 19;\n break;\n }\n\n _context.next = 13;\n return this.model.getPageList();\n\n case 13:\n this.pages = _context.sent;\n _context.next = 16;\n return this.model.getGabaritList();\n\n case 16:\n this.gabarits = _context.sent;\n\n if (data.gabarit.id) {\n gabarit = this.gabarits.find(function (gabarit) {\n return gabarit.id == data.gabarit.id;\n });\n } else {\n gabarit = this.gabarits.find(function (gabarit) {\n return gabarit.name == data.gabarit.name;\n });\n }\n\n this.reloadVue({\n type: \"gabarit\",\n name: gabarit.name,\n item: gabarit\n });\n\n case 19:\n this.hiddenLoader();\n return _context.abrupt(\"return\", result);\n\n case 21:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function updateGabarit(_x) {\n return _updateGabarit.apply(this, arguments);\n }\n\n return updateGabarit;\n }()\n }, {\n key: \"reloadVue\",\n value: function reloadVue(item) {\n if (!item) {\n this.resetNav();\n this.clearContainer();\n this.generateItemsNav();\n return true;\n } // Backup\n\n\n var itemsNav = this.cloneObject(this.itemsNav);\n var itemNavActive = this.cloneObject(this.itemNavActive);\n\n if (this.pageTypeOpen) {\n var pageTypeOpen = this.cloneObject(this.pageTypeOpen);\n }\n\n if (this.pageOpen) {\n var pageOpen = this.cloneObject(this.pageOpen);\n pageOpen.item = this.pages.find(function (page) {\n return page.id == pageOpen.item.id;\n });\n }\n\n if (this.gabaritOpen) {\n var gabaritOpen = this.cloneObject(this.gabaritOpen);\n gabaritOpen.item = this.gabarits.find(function (gabarit) {\n return gabarit.id == gabaritOpen.item.id;\n });\n }\n\n if (this.frameOpen) {\n var frameOpen = this.cloneObject(this.frameOpen);\n frameOpen.item = this.frames.find(function (frame) {\n return frame.id == frameOpen.item.id;\n });\n }\n\n this.resetNav();\n var isOpen = [];\n\n for (var i = 0; i < itemsNav.length; i++) {\n var itemNav = itemsNav[i];\n\n if (isOpen.includes(itemNav.data.type)) {\n continue;\n }\n\n var useItem = false;\n\n if (item.type == itemNav.data.type) {\n useItem = true;\n }\n\n switch (itemNav.data.type) {\n case \"pageType\":\n this.openPageType(useItem ? item : pageTypeOpen);\n break;\n\n case \"page\":\n var page = useItem ? item : pageOpen;\n this.openPage(page, page.subNav);\n break;\n\n case \"frame\":\n this.openFrame(useItem ? item : frameOpen);\n break;\n\n case \"gabarit\":\n this.openGabarit(useItem ? item : gabaritOpen);\n break;\n\n case \"pageSubNav\":\n this.openPage(useItem ? item : pageOpen, true);\n break;\n }\n\n isOpen.push(itemNav.data.type);\n }\n\n this.itemNavActive = itemNavActive;\n this.generateItemsNav();\n return true;\n }\n }, {\n key: \"removeGabarit\",\n value: function () {\n var _removeGabarit = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2(id) {\n var _this6 = this;\n\n var result;\n return regeneratorRuntime.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n this.showLoader();\n _context2.next = 3;\n return this.model.removeGabarit(id);\n\n case 3:\n result = _context2.sent;\n\n if (result.error) {\n _context2.next = 10;\n break;\n }\n\n _context2.next = 7;\n return this.model.getGabaritList();\n\n case 7:\n this.gabarits = _context2.sent;\n this.model.getPageList().then(function (pages) {\n return _this6.pages = pages;\n });\n this.resetVue();\n\n case 10:\n this.hiddenLoader();\n return _context2.abrupt(\"return\", result);\n\n case 12:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2, this);\n }));\n\n function removeGabarit(_x2) {\n return _removeGabarit.apply(this, arguments);\n }\n\n return removeGabarit;\n }()\n }, {\n key: \"updatePage\",\n value: function () {\n var _updatePage = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee3(data) {\n var view,\n result,\n page,\n name,\n id,\n _args3 = arguments;\n return regeneratorRuntime.wrap(function _callee3$(_context3) {\n while (1) {\n switch (_context3.prev = _context3.next) {\n case 0:\n view = _args3.length > 1 && _args3[1] !== undefined ? _args3[1] : \"page\";\n this.showLoader();\n\n if (!data.id) {\n _context3.next = 8;\n break;\n }\n\n _context3.next = 5;\n return this.model.updatePage(data.id, data);\n\n case 5:\n result = _context3.sent;\n _context3.next = 11;\n break;\n\n case 8:\n _context3.next = 10;\n return this.model.createPage(data);\n\n case 10:\n result = _context3.sent;\n\n case 11:\n if (result.error) {\n _context3.next = 22;\n break;\n }\n\n _context3.next = 14;\n return this.model.getPageList();\n\n case 14:\n this.pages = _context3.sent;\n\n if (data.id) {\n page = this.pages.find(function (page) {\n return page.id == data.id;\n });\n } else {\n page = this.pages.find(function (page) {\n return page.name == data.name && page.type == data.type && page.sub_type == data.sub_type;\n });\n }\n\n if (page) {\n _context3.next = 19;\n break;\n }\n\n this.hiddenLoader();\n return _context3.abrupt(\"return\", this.clearContainer());\n\n case 19:\n // Page de portail\n name = page.name;\n\n if (page.type == 25) {\n id = parseInt(page.sub_type.toString().substr(2), 10);\n\n if (id) {\n name += \" id: \".concat(id);\n }\n }\n\n if (view == \"page\") {\n this.reloadVue({\n type: view,\n name: name,\n item: page\n });\n } else if (view == \"layout\") {\n this.updateContainer({\n type: view,\n name: name,\n item: page\n });\n }\n\n case 22:\n this.hiddenLoader();\n return _context3.abrupt(\"return\", result);\n\n case 24:\n case \"end\":\n return _context3.stop();\n }\n }\n }, _callee3, this);\n }));\n\n function updatePage(_x3) {\n return _updatePage.apply(this, arguments);\n }\n\n return updatePage;\n }()\n }, {\n key: \"removePage\",\n value: function () {\n var _removePage = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee4(id) {\n var result;\n return regeneratorRuntime.wrap(function _callee4$(_context4) {\n while (1) {\n switch (_context4.prev = _context4.next) {\n case 0:\n this.showLoader();\n _context4.next = 3;\n return this.model.removePage(id);\n\n case 3:\n result = _context4.sent;\n\n if (result.error) {\n _context4.next = 9;\n break;\n }\n\n _context4.next = 7;\n return this.model.getPageList();\n\n case 7:\n this.pages = _context4.sent;\n this.resetVue();\n\n case 9:\n this.hiddenLoader();\n return _context4.abrupt(\"return\", result);\n\n case 11:\n case \"end\":\n return _context4.stop();\n }\n }\n }, _callee4, this);\n }));\n\n function removePage(_x4) {\n return _removePage.apply(this, arguments);\n }\n\n return removePage;\n }()\n }, {\n key: \"updateFrame\",\n value: function () {\n var _updateFrame = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee5() {\n var index, _index;\n\n return regeneratorRuntime.wrap(function _callee5$(_context5) {\n while (1) {\n switch (_context5.prev = _context5.next) {\n case 0:\n this.showLoader();\n _context5.next = 3;\n return this.model.getFrameList();\n\n case 3:\n this.frames = _context5.sent;\n\n for (index in this.pages) {\n this.pages[index].tree = [];\n }\n\n for (_index in this.gabarits) {\n this.gabarits[_index].tree = [];\n }\n\n this.hiddenLoader();\n return _context5.abrupt(\"return\", this.frames);\n\n case 8:\n case \"end\":\n return _context5.stop();\n }\n }\n }, _callee5, this);\n }));\n\n function updateFrame() {\n return _updateFrame.apply(this, arguments);\n }\n\n return updateFrame;\n }()\n }, {\n key: \"updateParent\",\n value: function () {\n var _updateParent = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee6(data) {\n var result, page, gabarit;\n return regeneratorRuntime.wrap(function _callee6$(_context6) {\n while (1) {\n switch (_context6.prev = _context6.next) {\n case 0:\n this.showLoader();\n\n if (!data.page_id) {\n _context6.next = 13;\n break;\n }\n\n _context6.next = 4;\n return this.model.updateTreePage(data.page_id, data);\n\n case 4:\n result = _context6.sent;\n\n if (result.error) {\n _context6.next = 11;\n break;\n }\n\n _context6.next = 8;\n return this.model.getPageList();\n\n case 8:\n this.pages = _context6.sent;\n page = this.pages.find(function (page) {\n return page.id == data.page_id;\n });\n this.updateContainer({\n type: 'layout',\n name: page.name,\n item: page\n });\n\n case 11:\n _context6.next = 22;\n break;\n\n case 13:\n _context6.next = 15;\n return this.model.updateTreeGabarit(data.gabarit_id, data);\n\n case 15:\n result = _context6.sent;\n\n if (result.error) {\n _context6.next = 22;\n break;\n }\n\n _context6.next = 19;\n return this.model.getGabaritList();\n\n case 19:\n this.gabarits = _context6.sent;\n gabarit = this.gabarits.find(function (gabarit) {\n return gabarit.id == data.gabarit_id;\n });\n this.updateContainer({\n type: 'layout',\n name: gabarit.name,\n item: gabarit\n });\n\n case 22:\n this.hiddenLoader();\n\n case 23:\n case \"end\":\n return _context6.stop();\n }\n }\n }, _callee6, this);\n }));\n\n function updateParent(_x5) {\n return _updateParent.apply(this, arguments);\n }\n\n return updateParent;\n }()\n }, {\n key: \"hideElementLayout\",\n value: function () {\n var _hideElementLayout = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee7(data) {\n var result, page, gabarit;\n return regeneratorRuntime.wrap(function _callee7$(_context7) {\n while (1) {\n switch (_context7.prev = _context7.next) {\n case 0:\n this.showLoader();\n\n if (!data.page_id) {\n _context7.next = 13;\n break;\n }\n\n _context7.next = 4;\n return this.model.hideElementPageLayout(data.page_id, data);\n\n case 4:\n result = _context7.sent;\n\n if (result.error) {\n _context7.next = 11;\n break;\n }\n\n _context7.next = 8;\n return this.model.getPageList();\n\n case 8:\n this.pages = _context7.sent;\n page = this.pages.find(function (page) {\n return page.id == data.page_id;\n });\n this.updateContainer({\n type: 'layout',\n name: page.name,\n item: page\n });\n\n case 11:\n _context7.next = 25;\n break;\n\n case 13:\n _context7.next = 15;\n return this.model.hideElementGabaritLayout(data.gabarit_id, data);\n\n case 15:\n result = _context7.sent;\n\n if (result.error) {\n _context7.next = 25;\n break;\n }\n\n _context7.next = 19;\n return this.model.getPageList();\n\n case 19:\n this.pages = _context7.sent;\n _context7.next = 22;\n return this.model.getGabaritList();\n\n case 22:\n this.gabarits = _context7.sent;\n gabarit = this.gabarits.find(function (gabarit) {\n return gabarit.id == data.gabarit_id;\n });\n this.updateContainer({\n type: 'layout',\n name: gabarit.name,\n item: gabarit\n });\n\n case 25:\n this.hiddenLoader();\n\n case 26:\n case \"end\":\n return _context7.stop();\n }\n }\n }, _callee7, this);\n }));\n\n function hideElementLayout(_x6) {\n return _hideElementLayout.apply(this, arguments);\n }\n\n return hideElementLayout;\n }()\n }, {\n key: \"removeElementLayout\",\n value: function () {\n var _removeElementLayout = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee8(data) {\n var _this7 = this;\n\n var result, page, gabarit, pageFound;\n return regeneratorRuntime.wrap(function _callee8$(_context8) {\n while (1) {\n switch (_context8.prev = _context8.next) {\n case 0:\n this.showLoader();\n\n if (!data.page_id) {\n _context8.next = 13;\n break;\n }\n\n _context8.next = 4;\n return this.model.removeElementPageLayout(data.page_id, data);\n\n case 4:\n result = _context8.sent;\n\n if (result.error) {\n _context8.next = 11;\n break;\n }\n\n _context8.next = 8;\n return this.model.getPageList();\n\n case 8:\n this.pages = _context8.sent;\n page = this.pages.find(function (page) {\n return page.id == data.page_id;\n });\n this.updateContainer({\n type: this.container.data.type,\n name: page.name,\n item: page\n });\n\n case 11:\n _context8.next = 30;\n break;\n\n case 13:\n if (!data.item[\"class\"].toLocaleLowerCase().includes(\"zone\")) {\n _context8.next = 19;\n break;\n }\n\n _context8.next = 16;\n return this.model.gabaritRemoveZone(data.gabarit_id, data.item.semantic.id_tag);\n\n case 16:\n result = _context8.sent;\n _context8.next = 22;\n break;\n\n case 19:\n _context8.next = 21;\n return this.model.gabaritRemoveFrame(data.gabarit_id, data.item.semantic.id_tag);\n\n case 21:\n result = _context8.sent;\n\n case 22:\n if (result.error) {\n _context8.next = 30;\n break;\n }\n\n _context8.next = 25;\n return this.model.getGabaritList();\n\n case 25:\n this.gabarits = _context8.sent;\n gabarit = this.gabarits.find(function (gabarit) {\n return gabarit.id == data.gabarit_id;\n });\n pageFound = this.pages.find(function (page) {\n return page.gabarit_layout.id == gabarit.id;\n });\n\n if (pageFound != undefined) {\n // le gabarit utilise des page on les mets à jours\n this.model.getPageList().then(function (pages) {\n _this7.pages = pages;\n });\n }\n\n this.updateContainer({\n type: this.container.data.type,\n name: gabarit.name,\n item: gabarit\n });\n\n case 30:\n this.hiddenLoader();\n\n case 31:\n case \"end\":\n return _context8.stop();\n }\n }\n }, _callee8, this);\n }));\n\n function removeElementLayout(_x7) {\n return _removeElementLayout.apply(this, arguments);\n }\n\n return removeElementLayout;\n }()\n }, {\n key: \"updateTagElementLayout\",\n value: function () {\n var _updateTagElementLayout = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee9(data) {\n var result, page, gabarit;\n return regeneratorRuntime.wrap(function _callee9$(_context9) {\n while (1) {\n switch (_context9.prev = _context9.next) {\n case 0:\n this.showLoader();\n\n if (!data.page_id) {\n _context9.next = 13;\n break;\n }\n\n _context9.next = 4;\n return this.model.updateTagElementPageLayout(data.page_id, data);\n\n case 4:\n result = _context9.sent;\n\n if (result.error) {\n _context9.next = 11;\n break;\n }\n\n _context9.next = 8;\n return this.model.getPageList();\n\n case 8:\n this.pages = _context9.sent;\n page = this.pages.find(function (page) {\n return page.id == data.page_id;\n });\n this.updateContainer({\n type: 'layout',\n name: page.name,\n item: page\n });\n\n case 11:\n _context9.next = 22;\n break;\n\n case 13:\n _context9.next = 15;\n return this.model.updateTagElementGabaritLayout(data.gabarit_id, data);\n\n case 15:\n result = _context9.sent;\n\n if (result.error) {\n _context9.next = 22;\n break;\n }\n\n _context9.next = 19;\n return this.model.getGabaritList();\n\n case 19:\n this.gabarits = _context9.sent;\n gabarit = this.gabarits.find(function (gabarit) {\n return gabarit.id == data.gabarit_id;\n });\n this.updateContainer({\n type: 'layout',\n name: gabarit.name,\n item: gabarit\n });\n\n case 22:\n this.hiddenLoader();\n\n case 23:\n case \"end\":\n return _context9.stop();\n }\n }\n }, _callee9, this);\n }));\n\n function updateTagElementLayout(_x8) {\n return _updateTagElementLayout.apply(this, arguments);\n }\n\n return updateTagElementLayout;\n }()\n }, {\n key: \"refreshZones\",\n value: function () {\n var _refreshZones = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee10(data) {\n var result;\n return regeneratorRuntime.wrap(function _callee10$(_context10) {\n while (1) {\n switch (_context10.prev = _context10.next) {\n case 0:\n if (!data[\"class\"].includes(\"PagePortalModel\")) {\n _context10.next = 6;\n break;\n }\n\n _context10.next = 3;\n return this.model.getZonesInPage(data.id);\n\n case 3:\n result = _context10.sent;\n _context10.next = 9;\n break;\n\n case 6:\n _context10.next = 8;\n return this.model.getZonesInGabarit(data.id);\n\n case 8:\n result = _context10.sent;\n\n case 9:\n this.zoneList = result;\n return _context10.abrupt(\"return\", result);\n\n case 11:\n case \"end\":\n return _context10.stop();\n }\n }\n }, _callee10, this);\n }));\n\n function refreshZones(_x9) {\n return _refreshZones.apply(this, arguments);\n }\n\n return refreshZones;\n }()\n }, {\n key: \"clearContainer\",\n value: function clearContainer() {\n this.container = {\n title: \"\",\n component: \"\",\n data: {}\n };\n }\n }, {\n key: \"updateContainer\",\n value: function updateContainer(container) {\n this.refreshItemOpen();\n this.container.data = container;\n }\n }, {\n key: \"showLoader\",\n value: function (_showLoader) {\n function showLoader() {\n return _showLoader.apply(this, arguments);\n }\n\n showLoader.toString = function () {\n return _showLoader.toString();\n };\n\n return showLoader;\n }(function () {\n if (typeof showLoader == \"function\") {\n showLoader();\n }\n })\n }, {\n key: \"hiddenLoader\",\n value: function (_hiddenLoader) {\n function hiddenLoader() {\n return _hiddenLoader.apply(this, arguments);\n }\n\n hiddenLoader.toString = function () {\n return _hiddenLoader.toString();\n };\n\n return hiddenLoader;\n }(function () {\n if (typeof hiddenLoader == \"function\") {\n hiddenLoader();\n }\n })\n }, {\n key: \"editFrameClassement\",\n value: function editFrameClassement(accordionframe) {\n var _this8 = this;\n\n var default_classement = this.getMessage('default_classement');\n\n if (!accordionframe.classement) {\n accordionframe.classement = default_classement;\n }\n\n var promise = this.model.editFrameClassement(accordionframe);\n promise.then(function (response) {\n if (response && !response.error) {\n var frame = _this8.frames.find(function (frame) {\n return frame.id == accordionframe.data.item.id;\n });\n\n frame.classement = accordionframe.classement;\n _this8.refreshFrameList = true;\n } else {\n throw response.errorMessage;\n }\n });\n }\n }, {\n key: \"editGabaritClassement\",\n value: function editGabaritClassement(accordionGabarit) {\n var _this9 = this;\n\n var default_classement = this.getMessage('default_classement');\n\n if (!accordionGabarit.classement) {\n accordionGabarit.classement = default_classement;\n }\n\n var promise = this.model.editGabaritClassement(accordionGabarit);\n promise.then(function (response) {\n if (response && !response.error) {\n var gabarit = _this9.gabarits.find(function (gabarit) {\n return gabarit.id == accordionGabarit.data.item.id;\n });\n\n gabarit.classement = accordionGabarit.classement;\n } else {\n throw response.errorMessage;\n }\n });\n }\n }, {\n key: \"addZoneClasses\",\n value: function addZoneClasses(zone, classes) {\n var _this10 = this;\n\n var promise = this.model.addZoneClasses(zone.semantic.id_tag, {\n classes: classes,\n item: {\n \"class\": this.container.data.item[\"class\"],\n id: this.container.data.item.id\n }\n });\n promise.then( /*#__PURE__*/function () {\n var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee11(response) {\n return regeneratorRuntime.wrap(function _callee11$(_context11) {\n while (1) {\n switch (_context11.prev = _context11.next) {\n case 0:\n _context11.next = 2;\n return _this10.model.getPageList();\n\n case 2:\n _this10.pages = _context11.sent;\n _context11.next = 5;\n return _this10.model.getGabaritList();\n\n case 5:\n _this10.gabarits = _context11.sent;\n\n case 6:\n case \"end\":\n return _context11.stop();\n }\n }\n }, _callee11);\n }));\n\n return function (_x10) {\n return _ref.apply(this, arguments);\n };\n }());\n }\n }, {\n key: \"addFrameClasses\",\n value: function addFrameClasses(frame, classes) {\n var _this11 = this;\n\n var promise = this.model.addFrameClasses(frame.semantic.id_tag, {\n classes: classes,\n item: {\n \"class\": this.container.data.item[\"class\"],\n id: this.container.data.item.id\n }\n });\n promise.then( /*#__PURE__*/function () {\n var _ref2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee12(response) {\n return regeneratorRuntime.wrap(function _callee12$(_context12) {\n while (1) {\n switch (_context12.prev = _context12.next) {\n case 0:\n _context12.next = 2;\n return _this11.model.getPageList();\n\n case 2:\n _this11.pages = _context12.sent;\n _context12.next = 5;\n return _this11.model.getGabaritList();\n\n case 5:\n _this11.gabarits = _context12.sent;\n\n case 6:\n case \"end\":\n return _context12.stop();\n }\n }\n }, _callee12);\n }));\n\n return function (_x11) {\n return _ref2.apply(this, arguments);\n };\n }());\n }\n }, {\n key: \"addFrameAttributes\",\n value: function addFrameAttributes(frame, attributes) {\n var _this12 = this;\n\n var promise = this.model.addFrameAttributes(frame.semantic.id_tag, {\n attributes: attributes,\n item: {\n \"class\": this.container.data.item[\"class\"],\n id: this.container.data.item.id\n }\n });\n promise.then( /*#__PURE__*/function () {\n var _ref3 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee13(response) {\n return regeneratorRuntime.wrap(function _callee13$(_context13) {\n while (1) {\n switch (_context13.prev = _context13.next) {\n case 0:\n _context13.next = 2;\n return _this12.model.getPageList();\n\n case 2:\n _this12.pages = _context13.sent;\n _context13.next = 5;\n return _this12.model.getGabaritList();\n\n case 5:\n _this12.gabarits = _context13.sent;\n\n case 6:\n case \"end\":\n return _context13.stop();\n }\n }\n }, _callee13);\n }));\n\n return function (_x12) {\n return _ref3.apply(this, arguments);\n };\n }());\n }\n }, {\n key: \"addZoneAttributes\",\n value: function addZoneAttributes(zone, attributes) {\n var _this13 = this;\n\n var promise = this.model.addZoneAttributes(zone.semantic.id_tag, {\n attributes: attributes,\n item: {\n \"class\": this.container.data.item[\"class\"],\n id: this.container.data.item.id\n }\n });\n promise.then( /*#__PURE__*/function () {\n var _ref4 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee14(response) {\n return regeneratorRuntime.wrap(function _callee14$(_context14) {\n while (1) {\n switch (_context14.prev = _context14.next) {\n case 0:\n _context14.next = 2;\n return _this13.model.getPageList();\n\n case 2:\n _this13.pages = _context14.sent;\n _context14.next = 5;\n return _this13.model.getGabaritList();\n\n case 5:\n _this13.gabarits = _context14.sent;\n\n case 6:\n case \"end\":\n return _context14.stop();\n }\n }\n }, _callee14);\n }));\n\n return function (_x13) {\n return _ref4.apply(this, arguments);\n };\n }());\n }\n }, {\n key: \"addElementlayout\",\n value: function () {\n var _addElementlayout = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee15(data) {\n var _this14 = this;\n\n var view,\n result,\n page,\n gabarit,\n pageFound,\n _args15 = arguments;\n return regeneratorRuntime.wrap(function _callee15$(_context15) {\n while (1) {\n switch (_context15.prev = _context15.next) {\n case 0:\n view = _args15.length > 1 && _args15[1] !== undefined ? _args15[1] : '';\n this.showLoader();\n\n if (!data.page_id) {\n _context15.next = 14;\n break;\n }\n\n _context15.next = 5;\n return this.model.addElementPageLayout(data.page_id, data);\n\n case 5:\n result = _context15.sent;\n\n if (result.error) {\n _context15.next = 12;\n break;\n }\n\n _context15.next = 9;\n return this.model.getPageList();\n\n case 9:\n this.pages = _context15.sent;\n page = this.pages.find(function (page) {\n return page.id == data.page_id;\n });\n\n if (view == \"page\") {\n this.reloadVue({\n type: view,\n name: page.name,\n item: page\n });\n } else if (view == \"layout\") {\n this.updateContainer({\n type: view,\n name: page.name,\n item: page\n });\n }\n\n case 12:\n _context15.next = 25;\n break;\n\n case 14:\n _context15.next = 16;\n return this.model.addElementGabaritLayout(data.gabarit_id, data);\n\n case 16:\n result = _context15.sent;\n\n if (result.error) {\n _context15.next = 25;\n break;\n }\n\n _context15.next = 20;\n return this.model.getGabaritList();\n\n case 20:\n this.gabarits = _context15.sent;\n gabarit = this.gabarits.find(function (gabarit) {\n return gabarit.id == data.gabarit_id;\n });\n pageFound = this.pages.find(function (page) {\n return page.gabarit_layout.id == gabarit.id;\n });\n\n if (pageFound != undefined) {\n // le gabarit utilise des page on les mets à jours\n this.model.getPageList().then(function (pages) {\n _this14.pages = pages;\n });\n }\n\n if (view != \"\") {\n this.updateContainer({\n type: view,\n name: gabarit.name,\n item: gabarit\n });\n }\n\n case 25:\n this.hiddenLoader();\n return _context15.abrupt(\"return\", result);\n\n case 27:\n case \"end\":\n return _context15.stop();\n }\n }\n }, _callee15, this);\n }));\n\n function addElementlayout(_x14) {\n return _addElementlayout.apply(this, arguments);\n }\n\n return addElementlayout;\n }()\n }, {\n key: \"getDefaultGabarit\",\n value: function getDefaultGabarit() {\n var _this$gabarits$find;\n\n return (_this$gabarits$find = this.gabarits.find(function (gabarit) {\n return gabarit[\"default\"] == 1;\n })) !== null && _this$gabarits$find !== void 0 ? _this$gabarits$find : null;\n }\n }, {\n key: \"updatePages\",\n value: function () {\n var _updatePages = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee16(pages) {\n var valid, success, i, page, result;\n return regeneratorRuntime.wrap(function _callee16$(_context16) {\n while (1) {\n switch (_context16.prev = _context16.next) {\n case 0:\n this.showLoader();\n valid = true;\n success = {};\n i = 0;\n\n case 4:\n if (!(i < pages.length)) {\n _context16.next = 14;\n break;\n }\n\n page = pages[i];\n _context16.next = 8;\n return this.model.updatePage(page.id, page);\n\n case 8:\n result = _context16.sent;\n success[page.id] = result.error ? false : true;\n valid &= result.error ? false : true;\n\n case 11:\n i++;\n _context16.next = 4;\n break;\n\n case 14:\n if (!valid) {\n _context16.next = 18;\n break;\n }\n\n _context16.next = 17;\n return this.model.getPageList();\n\n case 17:\n this.pages = _context16.sent;\n\n case 18:\n this.hiddenLoader();\n return _context16.abrupt(\"return\", success);\n\n case 20:\n case \"end\":\n return _context16.stop();\n }\n }\n }, _callee16, this);\n }));\n\n function updatePages(_x15) {\n return _updatePages.apply(this, arguments);\n }\n\n return updatePages;\n }()\n }, {\n key: \"gabaritRemoveFrame\",\n value: function () {\n var _gabaritRemoveFrame = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee17(idGabarit, idTagFrame) {\n var response;\n return regeneratorRuntime.wrap(function _callee17$(_context17) {\n while (1) {\n switch (_context17.prev = _context17.next) {\n case 0:\n _context17.next = 2;\n return this.model.gabaritRemoveFrame(idGabarit, idTagFrame);\n\n case 2:\n response = _context17.sent;\n\n if (response.error) {\n _context17.next = 7;\n break;\n }\n\n _context17.next = 6;\n return this.model.getGabaritList();\n\n case 6:\n this.gabarits = _context17.sent;\n\n case 7:\n return _context17.abrupt(\"return\", response);\n\n case 8:\n case \"end\":\n return _context17.stop();\n }\n }\n }, _callee17, this);\n }));\n\n function gabaritRemoveFrame(_x16, _x17) {\n return _gabaritRemoveFrame.apply(this, arguments);\n }\n\n return gabaritRemoveFrame;\n }()\n }, {\n key: \"pageRemoveFrame\",\n value: function () {\n var _pageRemoveFrame = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee18(idPage, idTagFrame) {\n var response;\n return regeneratorRuntime.wrap(function _callee18$(_context18) {\n while (1) {\n switch (_context18.prev = _context18.next) {\n case 0:\n _context18.next = 2;\n return this.model.pageRemoveFrame(idPage, idTagFrame);\n\n case 2:\n response = _context18.sent;\n\n if (response.error) {\n _context18.next = 7;\n break;\n }\n\n _context18.next = 6;\n return this.model.getPageList();\n\n case 6:\n this.pages = _context18.sent;\n\n case 7:\n return _context18.abrupt(\"return\", response);\n\n case 8:\n case \"end\":\n return _context18.stop();\n }\n }\n }, _callee18, this);\n }));\n\n function pageRemoveFrame(_x18, _x19) {\n return _pageRemoveFrame.apply(this, arguments);\n }\n\n return pageRemoveFrame;\n }()\n }, {\n key: \"haveElementOpac\",\n value: function haveElementOpac(element) {\n if (element[\"class\"].includes('Frame')) {\n if (element[\"class\"].includes('Opac')) {\n return true;\n }\n } else {\n var _iterator = _createForOfIteratorHelper(element.children),\n _step;\n\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var child = _step.value;\n\n if (child[\"class\"].includes('Opac')) {\n return true;\n }\n\n if (child[\"class\"].includes('Zone') && this.haveElementOpac(child)) {\n return true;\n }\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n }\n\n return false;\n }\n }, {\n key: \"duplicateGabarit\",\n value: function () {\n var _duplicateGabarit = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee19(idGabarit) {\n var find, result;\n return regeneratorRuntime.wrap(function _callee19$(_context19) {\n while (1) {\n switch (_context19.prev = _context19.next) {\n case 0:\n this.showLoader();\n find = this.gabarits.find(function (gabarit) {\n return gabarit.id == idGabarit;\n });\n\n if (!(find == undefined)) {\n _context19.next = 4;\n break;\n }\n\n return _context19.abrupt(\"return\", false);\n\n case 4:\n _context19.next = 6;\n return this.model.duplicateGabarit(idGabarit);\n\n case 6:\n result = _context19.sent;\n\n if (!result.error) {\n _context19.next = 10;\n break;\n }\n\n this.hiddenLoader();\n return _context19.abrupt(\"return\", false);\n\n case 10:\n _context19.next = 12;\n return this.model.getGabaritList();\n\n case 12:\n this.gabarits = _context19.sent;\n this.hiddenLoader();\n return _context19.abrupt(\"return\", true);\n\n case 15:\n case \"end\":\n return _context19.stop();\n }\n }\n }, _callee19, this);\n }));\n\n function duplicateGabarit(_x20) {\n return _duplicateGabarit.apply(this, arguments);\n }\n\n return duplicateGabarit;\n }()\n }, {\n key: \"removeLayout\",\n value: function () {\n var _removeLayout = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee20(element) {\n var gabarit;\n return regeneratorRuntime.wrap(function _callee20$(_context20) {\n while (1) {\n switch (_context20.prev = _context20.next) {\n case 0:\n this.showLoader();\n _context20.next = 3;\n return this.model.removeLayout(element);\n\n case 3:\n _context20.next = 5;\n return this.model.getPageList();\n\n case 5:\n this.pages = _context20.sent;\n _context20.next = 8;\n return this.model.getGabaritList();\n\n case 8:\n this.gabarits = _context20.sent;\n gabarit = this.gabarits.find(function (gabarit) {\n return gabarit.id == element.gabarit;\n });\n this.reloadVue({\n type: \"gabarit\",\n name: gabarit.name,\n item: gabarit\n });\n this.hiddenLoader();\n\n case 12:\n case \"end\":\n return _context20.stop();\n }\n }\n }, _callee20, this);\n }));\n\n function removeLayout(_x21) {\n return _removeLayout.apply(this, arguments);\n }\n\n return removeLayout;\n }()\n }, {\n key: \"removePageLayout\",\n value: function () {\n var _removePageLayout = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee21(element) {\n var page;\n return regeneratorRuntime.wrap(function _callee21$(_context21) {\n while (1) {\n switch (_context21.prev = _context21.next) {\n case 0:\n this.showLoader();\n _context21.next = 3;\n return this.model.removePageLayout(element);\n\n case 3:\n _context21.next = 5;\n return this.model.getPageList();\n\n case 5:\n this.pages = _context21.sent;\n page = this.pages.find(function (page) {\n return page.id == element.page;\n });\n this.reloadVue({\n type: \"page\",\n name: page.name,\n item: page\n });\n this.hiddenLoader();\n\n case 9:\n case \"end\":\n return _context21.stop();\n }\n }\n }, _callee21, this);\n }));\n\n function removePageLayout(_x22) {\n return _removePageLayout.apply(this, arguments);\n }\n\n return removePageLayout;\n }()\n }, {\n key: \"pageIsEdited\",\n value: function pageIsEdited(page) {\n var layouts = page.page_layout.layouts || {};\n\n if (page.parent_page != null) {\n var index = page.parent_page[\"class\"] + \"_\" + page.parent_page.id;\n } else {\n var index = page.gabarit_layout[\"class\"] + \"_\" + page.gabarit_layout.id;\n }\n\n return layouts[index] && layouts[index].length > 0 ? true : false;\n }\n }, {\n key: \"fecthLayout\",\n value: function () {\n var _fecthLayout = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee22(item) {\n var layout, index, _index2;\n\n return regeneratorRuntime.wrap(function _callee22$(_context22) {\n while (1) {\n switch (_context22.prev = _context22.next) {\n case 0:\n this.showLoader();\n _context22.next = 3;\n return this.model.fecthLayout(item);\n\n case 3:\n layout = _context22.sent;\n\n if (!layout.error) {\n _context22.next = 8;\n break;\n }\n\n console.error(layout.errorMessage);\n this.hiddenLoader();\n return _context22.abrupt(\"return\", []);\n\n case 8:\n if (item[\"class\"].toLowerCase().includes(\"page\")) {\n index = this.pages.findIndex(function (page) {\n return page.id == item.id;\n });\n if (index != -1) this.pages[index].tree = layout;\n } else {\n _index2 = this.gabarits.findIndex(function (gabarit) {\n return gabarit.id == item.id;\n });\n if (_index2 != -1) this.gabarits[_index2].tree = layout;\n }\n\n this.hiddenLoader();\n return _context22.abrupt(\"return\", layout);\n\n case 11:\n case \"end\":\n return _context22.stop();\n }\n }\n }, _callee22, this);\n }));\n\n function fecthLayout(_x23) {\n return _fecthLayout.apply(this, arguments);\n }\n\n return fecthLayout;\n }()\n }, {\n key: \"shareLayout\",\n value: function () {\n var _shareLayout = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee23(item, zone) {\n var className, result;\n return regeneratorRuntime.wrap(function _callee23$(_context23) {\n while (1) {\n switch (_context23.prev = _context23.next) {\n case 0:\n if (zone[\"class\"].toLocaleLowerCase().includes(\"zone\")) {\n _context23.next = 3;\n break;\n }\n\n console.log(zone[\"class\"]);\n return _context23.abrupt(\"return\", false);\n\n case 3:\n className = item[\"class\"].toLocaleLowerCase();\n\n if (!(!className.includes(\"page\") && !className.includes(\"gabarit\"))) {\n _context23.next = 7;\n break;\n }\n\n console.log(className);\n return _context23.abrupt(\"return\", false);\n\n case 7:\n this.showLoader();\n _context23.next = 10;\n return this.model.shareLayout(item, zone);\n\n case 10:\n result = _context23.sent;\n this.hiddenLoader();\n return _context23.abrupt(\"return\", result);\n\n case 13:\n case \"end\":\n return _context23.stop();\n }\n }\n }, _callee23, this);\n }));\n\n function shareLayout(_x24, _x25) {\n return _shareLayout.apply(this, arguments);\n }\n\n return shareLayout;\n }()\n }, {\n key: \"frameRemove\",\n value: function () {\n var _frameRemove = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee24(frame) {\n var result;\n return regeneratorRuntime.wrap(function _callee24$(_context24) {\n while (1) {\n switch (_context24.prev = _context24.next) {\n case 0:\n this.showLoader();\n _context24.next = 3;\n return this.model.frameRemove(frame.semantic.id_tag);\n\n case 3:\n result = _context24.sent;\n _context24.next = 6;\n return this.model.getPageList();\n\n case 6:\n this.pages = _context24.sent;\n _context24.next = 9;\n return this.model.getGabaritList();\n\n case 9:\n this.gabarits = _context24.sent;\n this.hiddenLoader();\n return _context24.abrupt(\"return\", result);\n\n case 12:\n case \"end\":\n return _context24.stop();\n }\n }\n }, _callee24, this);\n }));\n\n function frameRemove(_x26) {\n return _frameRemove.apply(this, arguments);\n }\n\n return frameRemove;\n }()\n }, {\n key: \"itemsAccordion\",\n get: function get() {\n var _this15 = this;\n\n return [{\n title: this.getMessage('banner_title_pages'),\n children: this.formatPagesAccordion(),\n component: \"accordionItem\",\n add: function add() {\n _this15.addPage();\n }\n }, {\n title: this.getMessage('banner_title_frame'),\n children: this.formatFramesAccordion(),\n component: \"accordionFrameItem\",\n add: function add() {\n _this15.addFrame();\n }\n }, {\n title: this.getMessage('banner_title_gabarit'),\n children: this.formatGabaritsAccordion(this.gabaritsDisplayType),\n component: \"accordionGabaritItem\",\n add: function add() {\n _this15.addGabarit();\n }\n }];\n }\n }, {\n key: \"properties\",\n get: function get() {\n return this.store.$data || {};\n },\n set: function set(value) {\n throw \"[CMS] don't do this !\";\n }\n }]);\n\n return Cms;\n}();\n\nvar CMS_PLUGIN = {\n install: function install(Vue, options) {\n var cms = new Cms(Vue, options);\n cms.init();\n Vue.prototype.$cms = cms;\n }\n};\n/* harmony default export */ __webpack_exports__[\"default\"] = (CMS_PLUGIN);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/classes/Cms.js?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/classes/CmsModel.js":
/*!*******************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/classes/CmsModel.js ***!
\*******************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _WebService_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./WebService.js */ \"./includes/templates/vuejs/portal/build/classes/WebService.js\");\nfunction asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }\n\nfunction _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err); } _next(undefined); }); }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\n\n\nvar CmsModel = /*#__PURE__*/function () {\n function CmsModel(url_base, version_num) {\n _classCallCheck(this, CmsModel);\n\n this.ws = new _WebService_js__WEBPACK_IMPORTED_MODULE_0__[\"default\"](url_base, version_num);\n this.cache = {};\n }\n\n _createClass(CmsModel, [{\n key: \"getMessage\",\n value: function getMessage(group, code) {\n var _pmbDojo$messages$get;\n\n return (_pmbDojo$messages$get = pmbDojo.messages.getMessage(group, code)) !== null && _pmbDojo$messages$get !== void 0 ? _pmbDojo$messages$get : '';\n }\n }, {\n key: \"empty\",\n value: function empty(value) {\n if (typeof value == \"undefined\") {\n return true;\n }\n\n if (typeof value == \"string\") {\n var value_clean = value.trim();\n\n if (value_clean && value_clean.length == 0) {\n return true;\n }\n\n if (value == false) {\n return true;\n }\n }\n\n return false;\n }\n }, {\n key: \"clearCache\",\n value: function clearCache() {\n this.cache = {};\n }\n }, {\n key: \"removeCache\",\n value: function removeCache(key) {\n if (!this.cache || !this.cache[key]) {\n return false;\n }\n\n this.cache[key] = undefined;\n return true;\n }\n }, {\n key: \"setCache\",\n value: function setCache(key, item) {\n this.cache[key] = {\n time: Date.now(),\n item: item\n };\n }\n }, {\n key: \"getCache\",\n value: function getCache(key) {\n if (this.cache[key]) {\n var minutes = (Date.now() - this.cache[key].time) / 1000 / 60;\n\n if (minutes < 1) {\n var _this$cache$key$item;\n\n return (_this$cache$key$item = this.cache[key].item) !== null && _this$cache$key$item !== void 0 ? _this$cache$key$item : false;\n }\n }\n\n return false;\n }\n }, {\n key: \"updatePage\",\n value: function updatePage(id, data) {\n if (!id) {\n return {\n error: true,\n errorMessage: \"id page need for update\"\n };\n }\n\n var result = this.checkPage(data);\n\n if (result === true) {\n this.clearCache();\n return this.ws.updatePage(id, data);\n } else {\n return result;\n }\n }\n }, {\n key: \"createPage\",\n value: function createPage(data) {\n if (!data || Object.values(data).length == 0) {\n return {\n error: true,\n errorMessage: this.getMessage('portal', 'page_no_data_set')\n };\n }\n\n var result = this.checkPage(data);\n\n if (result === true) {\n return this.ws.createPage(data);\n } else {\n return result;\n }\n }\n }, {\n key: \"getPagesUsingGabarit\",\n value: function () {\n var _getPagesUsingGabarit = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(id) {\n var key_cache, result;\n return regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n key_cache = \"pagesUsingGabarit_\".concat(id);\n\n if (!this.getCache(key_cache)) {\n _context.next = 3;\n break;\n }\n\n return _context.abrupt(\"return\", this.getCache(key_cache));\n\n case 3:\n _context.next = 5;\n return this.ws.getPagesUsingGabarit(id);\n\n case 5:\n result = _context.sent;\n // Pour éviter le spam on met le résultat en cache\n this.setCache(key_cache, result);\n return _context.abrupt(\"return\", result);\n\n case 8:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function getPagesUsingGabarit(_x) {\n return _getPagesUsingGabarit.apply(this, arguments);\n }\n\n return getPagesUsingGabarit;\n }()\n }, {\n key: \"updateGabarit\",\n value: function updateGabarit(id, data) {\n if (!id) {\n return {\n error: true,\n errorMessage: \"id gabarit need for update\"\n };\n }\n\n var result = this.checkGabarit(data.gabarit);\n\n if (result === true) {\n this.clearCache();\n return this.ws.updateGabarit(id, data);\n } else {\n return result;\n }\n }\n }, {\n key: \"createGabarit\",\n value: function createGabarit(data) {\n if (!data || Object.values(data).length == 0 || !data.gabarit) {\n return {\n error: true,\n errorMessage: this.getMessage('portal', 'gabarit_no_data_set')\n };\n }\n\n var result = this.checkGabarit(data.gabarit);\n\n if (result === true) {\n return this.ws.createGabarit(data);\n } else {\n return result;\n }\n }\n }, {\n key: \"checkGabarit\",\n value: function checkGabarit(gabarit) {\n if (this.empty(gabarit.name)) {\n return {\n error: true,\n errorMessage: this.getMessage('portal', 'gabarit_no_name_set')\n };\n }\n\n return true;\n }\n }, {\n key: \"checkPage\",\n value: function checkPage(data) {\n if (this.empty(data.name)) {\n return {\n error: true,\n errorMessage: this.getMessage('portal', 'page_no_name_set')\n };\n }\n\n if (this.empty(data.type)) {\n return {\n error: true,\n errorMessage: this.getMessage('portal', 'page_no_pagetype_set')\n };\n }\n\n if (this.empty(data.sub_type)) {\n return {\n error: true,\n errorMessage: this.getMessage('portal', 'page_no_pagesubtype_set')\n };\n }\n\n return true;\n }\n }, {\n key: \"getOpacViews\",\n value: function () {\n var _getOpacViews = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2() {\n var key_cache, result;\n return regeneratorRuntime.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n key_cache = \"opac_views\";\n\n if (!this.getCache(key_cache)) {\n _context2.next = 3;\n break;\n }\n\n return _context2.abrupt(\"return\", this.getCache(key_cache));\n\n case 3:\n _context2.next = 5;\n return this.ws.getOpacViews();\n\n case 5:\n result = _context2.sent;\n this.setCache(key_cache, result);\n return _context2.abrupt(\"return\", result);\n\n case 8:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2, this);\n }));\n\n function getOpacViews() {\n return _getOpacViews.apply(this, arguments);\n }\n\n return getOpacViews;\n }()\n }]);\n\n return CmsModel;\n}();\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (CmsModel);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/classes/CmsModel.js?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/classes/Egg.js":
/*!**************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/classes/Egg.js ***!
\**************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/*\n \n Welcome ! \n This is Dinosaur Land ! \n \n \n ████████ \n ██ ██ \n ██▒▒▒▒ ██ \n ██▒▒▒▒▒▒ ▒▒▒▒██ \n ██▒▒▒▒▒▒ ▒▒▒▒██ \n ██ ▒▒▒▒ ▒▒▒▒▒▒██ \n ██ ▒▒▒▒██ \n ██▒▒ ▒▒▒▒▒▒ ██ \n ██ ▒▒▒▒▒▒▒▒▒▒ ██ \n ██ ▒▒▒▒▒▒▒▒▒▒ ▒▒▒▒██ \n ██▒▒▒▒ ▒▒▒▒▒▒▒▒▒▒ ▒▒▒▒▒▒██ \n ██▒▒▒▒ ▒▒▒▒▒▒ ▒▒▒▒██ \n ██▒▒▒▒ ▒▒▒▒██ \n ██▒▒ ██ \n ████ ████ \n ████████ \n \n \n Easter Egg succesfully Loaded ! \n \n*/\nvar easterEggEnabled = false;\nvar keys = new Array();\nvar canvas = null;\nvar context = null;\nvar size = 24;\n\nfunction parseHTML(encodedStr) {\n var parser = new DOMParser();\n var dom = parser.parseFromString(encodedStr, \"text/html\");\n return dom.body.textContent.trim();\n}\n\nfunction shortcuts(e) {\n if (!e) {\n return false;\n }\n\n if (e.type === \"keydown\") {\n if (!keys.includes(e.keyCode)) keys.push(e.keyCode);\n } else {\n var index = keys.findIndex(function (key) {\n return key == e.keyCode;\n });\n\n if (index != -1) {\n keys.splice(index, 1);\n }\n }\n\n if (match()) {\n e.preventDefault();\n EasterEgg();\n }\n}\n\nfunction match() {\n // Ctrl + Alt + P\n var needle = [17, 18, 80];\n\n if (keys.length != needle.length) {\n return false;\n }\n\n for (var index in keys) {\n if (!needle.includes(keys[index])) {\n return false;\n }\n }\n\n return true;\n}\n\nfunction EasterEgg() {\n if (easterEggEnabled) {\n window.document.body.style.setProperty(\"cursor\", \"\");\n easterEggEnabled = false;\n } else {\n context.clearRect(0, 0, canvas.width, canvas.height);\n context.fillText(parseHTML(\"⚗️\"), size / 2, size / 2);\n var imgDataURL = canvas.toDataURL();\n var offset = size / 2 + \" 0\";\n window.document.body.style.setProperty(\"cursor\", \"url(\" + imgDataURL + \") \" + offset + \", auto\", \"important\");\n keys = [];\n easterEggEnabled = true;\n }\n}\n\nfunction init() {\n // Initialize event listener\n window.addEventListener(\"keydown\", shortcuts);\n window.addEventListener(\"keyup\", shortcuts); // Initialize canvas\n\n canvas = document.createElement(\"canvas\");\n canvas.width = size;\n canvas.height = size;\n canvas.style.setProperty(\"display\", \"hidden\"); // Store context & set styling\n\n context = canvas.getContext(\"2d\");\n context.font = size + \"px sans-serif\";\n context.textBaseline = \"middle\";\n context.textAlign = \"center\";\n}\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (init);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/classes/Egg.js?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/classes/WebService.js":
/*!*********************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/classes/WebService.js ***!
\*********************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\nfunction _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }\n\nfunction _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err); } _next(undefined); }); }; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nvar WebService = /*#__PURE__*/function () {\n function WebService(url_base, version_num) {\n _classCallCheck(this, WebService);\n\n this.url = url_base;\n this.setVersion(version_num);\n }\n\n _createClass(WebService, [{\n key: \"getVersion\",\n value: function getVersion() {\n return sessionStorage.getItem('version_num');\n }\n }, {\n key: \"setVersion\",\n value: function setVersion(version) {\n sessionStorage.setItem('version_num', version.toString());\n }\n }, {\n key: \"fetch\",\n value: function (_fetch) {\n function fetch(_x, _x2, _x3) {\n return _fetch.apply(this, arguments);\n }\n\n fetch.toString = function () {\n return _fetch.toString();\n };\n\n return fetch;\n }( /*#__PURE__*/function () {\n var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(http_method, fetch_url, data) {\n var url, init, post, prop, _prop, response, result, new_version_num;\n\n return regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n if (this.getVersion()) {\n _context.next = 2;\n break;\n }\n\n throw new Error(\"[Webservice] Version not set !\");\n\n case 2:\n url = this.url + fetch_url;\n init = {\n method: this.HTTP_GET,\n cache: 'no-cache'\n };\n\n if (http_method == this.HTTP_POST) {\n post = new URLSearchParams();\n post.append(\"version_num\", this.getVersion());\n\n for (prop in data) {\n post.append(prop, JSON.stringify(data[prop]));\n }\n\n init['method'] = this.HTTP_POST;\n init['body'] = post;\n } else {\n url += '?';\n\n for (_prop in data) {\n url += '&' + _prop + '=' + data[_prop];\n }\n }\n\n _context.prev = 5;\n _context.next = 8;\n return fetch(url, init);\n\n case 8:\n response = _context.sent;\n _context.next = 11;\n return response.json();\n\n case 11:\n result = _context.sent;\n\n if (!result.error) {\n _context.next = 14;\n break;\n }\n\n throw result.errorMessage;\n\n case 14:\n if (_typeof(result) == \"object\") {\n if (result.version_num) {\n new_version_num = parseInt(result.version_num);\n }\n } else {\n new_version_num = parseInt(result);\n }\n\n if (new_version_num && this.getVersion() < new_version_num) {\n this.setVersion(new_version_num);\n }\n\n return _context.abrupt(\"return\", result);\n\n case 19:\n _context.prev = 19;\n _context.t0 = _context[\"catch\"](5);\n return _context.abrupt(\"return\", {\n error: true,\n errorMessage: _context.t0\n });\n\n case 22:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this, [[5, 19]]);\n }));\n\n return function (_x4, _x5, _x6) {\n return _ref.apply(this, arguments);\n };\n }())\n /*\n * List Methods\n */\n\n }, {\n key: \"getPageList\",\n value: function getPageList() {\n return this.fetch(this.HTTP_POST, 'page/list');\n }\n }, {\n key: \"getGabaritList\",\n value: function getGabaritList() {\n return this.fetch(this.HTTP_POST, 'gabarit/list');\n }\n }, {\n key: \"getFrameList\",\n value: function getFrameList() {\n return this.fetch(this.HTTP_POST, 'frame/list');\n }\n /*\n * Create/Remove/Update d'une Page/Modèle\n */\n\n }, {\n key: \"createPage\",\n value: function createPage(data) {\n return this.fetch(this.HTTP_POST, 'page/create', {\n data: data\n });\n }\n }, {\n key: \"createGabarit\",\n value: function createGabarit(data) {\n return this.fetch(this.HTTP_POST, 'gabarit/create', {\n data: data\n });\n }\n }, {\n key: \"removePage\",\n value: function removePage(id, data) {\n return this.fetch(this.HTTP_POST, \"page/remove/\".concat(id));\n }\n }, {\n key: \"removeGabarit\",\n value: function removeGabarit(id, data) {\n return this.fetch(this.HTTP_POST, \"gabarit/remove/\".concat(id));\n }\n }, {\n key: \"updatePage\",\n value: function updatePage(id, data) {\n return this.fetch(this.HTTP_POST, \"page/update/\".concat(id), {\n data: data\n });\n }\n }, {\n key: \"updateGabarit\",\n value: function updateGabarit(id, data) {\n return this.fetch(this.HTTP_POST, \"gabarit/update/\".concat(id), {\n data: data\n });\n }\n /*\n * Update de l'arbre\n */\n\n }, {\n key: \"updateTreePage\",\n value: function updateTreePage(id, data) {\n return this.fetch(this.HTTP_POST, \"page/\".concat(id, \"/update/tree\"), {\n data: data\n });\n }\n }, {\n key: \"updateTreeGabarit\",\n value: function updateTreeGabarit(id, data) {\n return this.fetch(this.HTTP_POST, \"gabarit/\".concat(id, \"/update/tree\"), {\n data: data\n });\n }\n /*\n * Masquer une Zone/Cadre\n */\n\n }, {\n key: \"hideElementPageLayout\",\n value: function hideElementPageLayout(id, data) {\n return this.fetch(this.HTTP_POST, \"page/\".concat(id, \"/hide/element\"), {\n data: data\n });\n }\n }, {\n key: \"hideElementGabaritLayout\",\n value: function hideElementGabaritLayout(id, data) {\n return this.fetch(this.HTTP_POST, \"gabarit/\".concat(id, \"/hide/element\"), {\n data: data\n });\n }\n /*\n * Suppression de Zone/Cadre\n */\n\n }, {\n key: \"removeElementPageLayout\",\n value: function removeElementPageLayout(id, data) {\n return this.fetch(this.HTTP_POST, \"page/\".concat(id, \"/remove/element\"), {\n data: data\n });\n }\n }, {\n key: \"removeZone\",\n value: function removeZone(id, data) {\n return this.fetch(this.HTTP_POST, \"zone/remove/\".concat(id), {\n data: data\n });\n }\n /*\n * Semantique\n */\n\n }, {\n key: \"updateTagElementPageLayout\",\n value: function updateTagElementPageLayout(id, data) {\n return this.fetch(this.HTTP_POST, \"page/\".concat(id, \"/update/tag/element\"), {\n data: data\n });\n }\n }, {\n key: \"updateTagElementGabaritLayout\",\n value: function updateTagElementGabaritLayout(id, data) {\n return this.fetch(this.HTTP_POST, \"gabarit/\".concat(id, \"/update/tag/element\"), {\n data: data\n });\n }\n /*\n * Classes CSS\n */\n\n }, {\n key: \"addElementPageLayout\",\n value: function addElementPageLayout(id, data) {\n return this.fetch(this.HTTP_POST, \"page/\".concat(id, \"/create/element\"), {\n data: data\n });\n }\n }, {\n key: \"addElementGabaritLayout\",\n value: function addElementGabaritLayout(id, data) {\n return this.fetch(this.HTTP_POST, \"gabarit/\".concat(id, \"/create/element\"), {\n data: data\n });\n }\n /*\n * Récupération d'un liste\n */\n\n }, {\n key: \"getFramesInGabarit\",\n value: function getFramesInGabarit(id) {\n return this.fetch(this.HTTP_POST, \"gabarit/\".concat(id, \"/frame/list\"));\n }\n }, {\n key: \"getFramesInPage\",\n value: function getFramesInPage(id) {\n return this.fetch(this.HTTP_POST, \"page/\".concat(id, \"/frame/list\"));\n }\n }, {\n key: \"getZonesInPage\",\n value: function getZonesInPage(id) {\n return this.fetch(this.HTTP_POST, \"page/\".concat(id, \"/zone/list\"));\n }\n }, {\n key: \"getZonesInGabarit\",\n value: function getZonesInGabarit(id) {\n return this.fetch(this.HTTP_POST, \"gabarit/\".concat(id, \"/zone/list\"));\n }\n }, {\n key: \"getPagesUsingFrame\",\n value: function getPagesUsingFrame(data) {\n return this.fetch(this.HTTP_POST, \"frame/page/list\", {\n data: data\n });\n }\n }, {\n key: \"getGabaritsUsingFrame\",\n value: function getGabaritsUsingFrame(data) {\n return this.fetch(this.HTTP_POST, \"frame/gabarit/list\", {\n data: data\n });\n }\n /*\n * Cache\n */\n\n }, {\n key: \"clearCacheInPage\",\n value: function clearCacheInPage(id) {\n return this.fetch(this.HTTP_POST, \"page/\".concat(id, \"/clear/cache\"));\n }\n }, {\n key: \"clearCacheFrame\",\n value: function clearCacheFrame(id) {\n return this.fetch(this.HTTP_POST, \"frame/\".concat(id, \"/clear/cache\"));\n }\n /*\n * Classement\n */\n\n }, {\n key: \"editFrameClassement\",\n value: function editFrameClassement(frame) {\n return this.fetch(this.HTTP_POST, \"frame/classement\", {\n data: frame\n });\n }\n }, {\n key: \"editGabaritClassement\",\n value: function editGabaritClassement(gabarit) {\n return this.fetch(this.HTTP_POST, \"gabarit/classement\", {\n data: gabarit\n });\n }\n /*\n * Classes CSS\n */\n\n }, {\n key: \"addZoneClasses\",\n value: function addZoneClasses(id, data) {\n return this.fetch(this.HTTP_POST, \"zone/classes/\".concat(id), {\n data: data\n });\n }\n }, {\n key: \"addFrameClasses\",\n value: function addFrameClasses(id, data) {\n return this.fetch(this.HTTP_POST, \"frame/classes/\".concat(id), {\n data: data\n });\n }\n /*\n * attributs\n */\n\n }, {\n key: \"addZoneAttributes\",\n value: function addZoneAttributes(id, data) {\n return this.fetch(this.HTTP_POST, \"zone/attributes/\".concat(id), {\n data: data\n });\n }\n }, {\n key: \"addFrameAttributes\",\n value: function addFrameAttributes(id, data) {\n return this.fetch(this.HTTP_POST, \"frame/attributes/\".concat(id), {\n data: data\n });\n }\n }, {\n key: \"gabaritRemoveFrame\",\n value: function gabaritRemoveFrame(idGabarit, idTag) {\n return this.fetch(this.HTTP_POST, \"gabarit/\".concat(idGabarit, \"/remove/frame\"), {\n data: {\n idTag: idTag\n }\n });\n }\n }, {\n key: \"gabaritRemoveZone\",\n value: function gabaritRemoveZone(idGabarit, idTag) {\n return this.fetch(this.HTTP_POST, \"gabarit/\".concat(idGabarit, \"/remove/zone\"), {\n data: {\n idTag: idTag\n }\n });\n }\n }, {\n key: \"pageRemoveFrame\",\n value: function pageRemoveFrame(idPage, idTagFrame) {\n return this.fetch(this.HTTP_POST, \"page/\".concat(idPage, \"/remove/frame\"), {\n data: {\n idTag: idTagFrame\n }\n });\n }\n }, {\n key: \"pageSaveContext\",\n value: function pageSaveContext(id, data) {\n return this.fetch(this.HTTP_POST, \"page/save/context/\".concat(id), {\n data: data\n });\n }\n }, {\n key: \"pageEditContext\",\n value: function pageEditContext(id, data) {\n return this.fetch(this.HTTP_POST, \"page/edit/context/\".concat(id), {\n data: data\n });\n }\n }, {\n key: \"pageRemoveContext\",\n value: function pageRemoveContext(id, data) {\n return this.fetch(this.HTTP_POST, \"page/remove/context/\".concat(id), {\n data: data\n });\n }\n }, {\n key: \"getOpacViews\",\n value: function getOpacViews() {\n return this.fetch(this.HTTP_GET, \"opac_views\", {});\n }\n }, {\n key: \"pageBookmarkContext\",\n value: function pageBookmarkContext(id, data) {\n return this.fetch(this.HTTP_POST, \"page/bookmark/context/\".concat(id), {\n data: data\n });\n }\n /*\n * Duplication\n */\n\n }, {\n key: \"duplicateGabarit\",\n value: function duplicateGabarit(idGabarit) {\n return this.fetch(this.HTTP_POST, \"gabarit/duplicate/\".concat(idGabarit));\n }\n }, {\n key: \"removeLayout\",\n value: function removeLayout(data) {\n return this.fetch(this.HTTP_POST, \"gabarit/\".concat(data.gabarit, \"/remove/layout\"), {\n data: {\n layout: data.layout\n }\n });\n }\n }, {\n key: \"removePageLayout\",\n value: function removePageLayout(data) {\n return this.fetch(this.HTTP_POST, \"page/\".concat(data.page, \"/remove/layout\"), {\n data: {\n layout: data.layout\n }\n });\n }\n }, {\n key: \"fecthLayout\",\n value: function fecthLayout(item) {\n return this.fetch(this.HTTP_POST, \"fecth/layout\", {\n data: item\n });\n }\n }, {\n key: \"shareLayout\",\n value: function shareLayout(item, zone) {\n return this.fetch(this.HTTP_POST, \"share/layout\", {\n data: {\n item: item,\n zone: zone\n }\n });\n }\n }, {\n key: \"frameRemove\",\n value: function frameRemove(id) {\n return this.fetch(this.HTTP_POST, \"frame/remove/\".concat(id));\n }\n }, {\n key: \"HTTP_POST\",\n get: function get() {\n return \"POST\";\n }\n }, {\n key: \"HTTP_GET\",\n get: function get() {\n return \"GET\";\n }\n }]);\n\n return WebService;\n}();\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (WebService);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/classes/WebService.js?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordion.vue":
/*!**********************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordion.vue ***!
\**********************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _accordion_vue_vue_type_template_id_f0309300___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./accordion.vue?vue&type=template&id=f0309300& */ \"./includes/templates/vuejs/portal/build/components/accordion/accordion.vue?vue&type=template&id=f0309300&\");\n/* harmony import */ var _accordion_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./accordion.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/accordion/accordion.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _accordion_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _accordion_vue_vue_type_template_id_f0309300___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _accordion_vue_vue_type_template_id_f0309300___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/accordion/accordion.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordion.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordion.vue?vue&type=script&lang=js&":
/*!***********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordion.vue?vue&type=script&lang=js& ***!
\***********************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_accordion_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./accordion.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordion.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_accordion_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordion.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordion.vue?vue&type=template&id=f0309300&":
/*!*****************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordion.vue?vue&type=template&id=f0309300& ***!
\*****************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordion_vue_vue_type_template_id_f0309300___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./accordion.vue?vue&type=template&id=f0309300& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordion.vue?vue&type=template&id=f0309300&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordion_vue_vue_type_template_id_f0309300___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordion_vue_vue_type_template_id_f0309300___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordion.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue":
/*!*****************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue ***!
\*****************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _accordionContent_vue_vue_type_template_id_4eccf189___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./accordionContent.vue?vue&type=template&id=4eccf189& */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue?vue&type=template&id=4eccf189&\");\n/* harmony import */ var _accordionContent_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./accordionContent.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _accordionContent_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _accordionContent_vue_vue_type_template_id_4eccf189___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _accordionContent_vue_vue_type_template_id_4eccf189___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue?vue&type=script&lang=js&":
/*!******************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue?vue&type=script&lang=js& ***!
\******************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionContent_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./accordionContent.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionContent_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue?vue&type=template&id=4eccf189&":
/*!************************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue?vue&type=template&id=4eccf189& ***!
\************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionContent_vue_vue_type_template_id_4eccf189___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./accordionContent.vue?vue&type=template&id=4eccf189& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue?vue&type=template&id=4eccf189&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionContent_vue_vue_type_template_id_4eccf189___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionContent_vue_vue_type_template_id_4eccf189___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue":
/*!**********************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue ***!
\**********************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _accordionFrameContent_vue_vue_type_template_id_2fca76ec___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./accordionFrameContent.vue?vue&type=template&id=2fca76ec& */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue?vue&type=template&id=2fca76ec&\");\n/* harmony import */ var _accordionFrameContent_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./accordionFrameContent.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _accordionFrameContent_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _accordionFrameContent_vue_vue_type_template_id_2fca76ec___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _accordionFrameContent_vue_vue_type_template_id_2fca76ec___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue?vue&type=script&lang=js&":
/*!***********************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue?vue&type=script&lang=js& ***!
\***********************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionFrameContent_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./accordionFrameContent.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionFrameContent_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue?vue&type=template&id=2fca76ec&":
/*!*****************************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue?vue&type=template&id=2fca76ec& ***!
\*****************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionFrameContent_vue_vue_type_template_id_2fca76ec___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./accordionFrameContent.vue?vue&type=template&id=2fca76ec& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue?vue&type=template&id=2fca76ec&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionFrameContent_vue_vue_type_template_id_2fca76ec___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionFrameContent_vue_vue_type_template_id_2fca76ec___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue":
/*!*******************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue ***!
\*******************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _accordionFrameItem_vue_vue_type_template_id_63f464a0___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./accordionFrameItem.vue?vue&type=template&id=63f464a0& */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue?vue&type=template&id=63f464a0&\");\n/* harmony import */ var _accordionFrameItem_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./accordionFrameItem.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _accordionFrameItem_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _accordionFrameItem_vue_vue_type_template_id_63f464a0___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _accordionFrameItem_vue_vue_type_template_id_63f464a0___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue?vue&type=script&lang=js&":
/*!********************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue?vue&type=script&lang=js& ***!
\********************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionFrameItem_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./accordionFrameItem.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionFrameItem_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue?vue&type=template&id=63f464a0&":
/*!**************************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue?vue&type=template&id=63f464a0& ***!
\**************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionFrameItem_vue_vue_type_template_id_63f464a0___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./accordionFrameItem.vue?vue&type=template&id=63f464a0& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue?vue&type=template&id=63f464a0&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionFrameItem_vue_vue_type_template_id_63f464a0___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionFrameItem_vue_vue_type_template_id_63f464a0___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue":
/*!************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue ***!
\************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _accordionGabaritContent_vue_vue_type_template_id_99c7bbd6___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./accordionGabaritContent.vue?vue&type=template&id=99c7bbd6& */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue?vue&type=template&id=99c7bbd6&\");\n/* harmony import */ var _accordionGabaritContent_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./accordionGabaritContent.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _accordionGabaritContent_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _accordionGabaritContent_vue_vue_type_template_id_99c7bbd6___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _accordionGabaritContent_vue_vue_type_template_id_99c7bbd6___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue?vue&type=script&lang=js&":
/*!*************************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue?vue&type=script&lang=js& ***!
\*************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionGabaritContent_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./accordionGabaritContent.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionGabaritContent_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue?vue&type=template&id=99c7bbd6&":
/*!*******************************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue?vue&type=template&id=99c7bbd6& ***!
\*******************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionGabaritContent_vue_vue_type_template_id_99c7bbd6___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./accordionGabaritContent.vue?vue&type=template&id=99c7bbd6& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue?vue&type=template&id=99c7bbd6&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionGabaritContent_vue_vue_type_template_id_99c7bbd6___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionGabaritContent_vue_vue_type_template_id_99c7bbd6___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue":
/*!*********************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue ***!
\*********************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _accordionGabaritItem_vue_vue_type_template_id_4869c9b2___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./accordionGabaritItem.vue?vue&type=template&id=4869c9b2& */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue?vue&type=template&id=4869c9b2&\");\n/* harmony import */ var _accordionGabaritItem_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./accordionGabaritItem.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _accordionGabaritItem_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _accordionGabaritItem_vue_vue_type_template_id_4869c9b2___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _accordionGabaritItem_vue_vue_type_template_id_4869c9b2___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue?vue&type=script&lang=js&":
/*!**********************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue?vue&type=script&lang=js& ***!
\**********************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionGabaritItem_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./accordionGabaritItem.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionGabaritItem_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue?vue&type=template&id=4869c9b2&":
/*!****************************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue?vue&type=template&id=4869c9b2& ***!
\****************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionGabaritItem_vue_vue_type_template_id_4869c9b2___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./accordionGabaritItem.vue?vue&type=template&id=4869c9b2& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue?vue&type=template&id=4869c9b2&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionGabaritItem_vue_vue_type_template_id_4869c9b2___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionGabaritItem_vue_vue_type_template_id_4869c9b2___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue":
/*!**************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue ***!
\**************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _accordionItem_vue_vue_type_template_id_8f54bf9a___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./accordionItem.vue?vue&type=template&id=8f54bf9a& */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue?vue&type=template&id=8f54bf9a&\");\n/* harmony import */ var _accordionItem_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./accordionItem.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _accordionItem_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _accordionItem_vue_vue_type_template_id_8f54bf9a___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _accordionItem_vue_vue_type_template_id_8f54bf9a___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue?vue&type=script&lang=js&":
/*!***************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue?vue&type=script&lang=js& ***!
\***************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionItem_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./accordionItem.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionItem_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue?vue&type=template&id=8f54bf9a&":
/*!*********************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue?vue&type=template&id=8f54bf9a& ***!
\*********************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionItem_vue_vue_type_template_id_8f54bf9a___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./accordionItem.vue?vue&type=template&id=8f54bf9a& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue?vue&type=template&id=8f54bf9a&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionItem_vue_vue_type_template_id_8f54bf9a___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_accordionItem_vue_vue_type_template_id_8f54bf9a___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/alertError.vue":
/*!*************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/alertError.vue ***!
\*************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _alertError_vue_vue_type_template_id_843520c6___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./alertError.vue?vue&type=template&id=843520c6& */ \"./includes/templates/vuejs/portal/build/components/alertError.vue?vue&type=template&id=843520c6&\");\n/* harmony import */ var _alertError_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./alertError.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/alertError.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _alertError_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _alertError_vue_vue_type_template_id_843520c6___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _alertError_vue_vue_type_template_id_843520c6___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/alertError.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/alertError.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/alertError.vue?vue&type=script&lang=js&":
/*!**************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/alertError.vue?vue&type=script&lang=js& ***!
\**************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_alertError_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../node_modules/vue-loader/lib??vue-loader-options!./alertError.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/alertError.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_alertError_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/alertError.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/alertError.vue?vue&type=template&id=843520c6&":
/*!********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/alertError.vue?vue&type=template&id=843520c6& ***!
\********************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_alertError_vue_vue_type_template_id_843520c6___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../node_modules/vue-loader/lib??vue-loader-options!./alertError.vue?vue&type=template&id=843520c6& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/alertError.vue?vue&type=template&id=843520c6&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_alertError_vue_vue_type_template_id_843520c6___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_alertError_vue_vue_type_template_id_843520c6___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/alertError.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/frame/addForm.vue":
/*!****************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/frame/addForm.vue ***!
\****************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _addForm_vue_vue_type_template_id_73fdd83c___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./addForm.vue?vue&type=template&id=73fdd83c& */ \"./includes/templates/vuejs/portal/build/components/frame/addForm.vue?vue&type=template&id=73fdd83c&\");\n/* harmony import */ var _addForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./addForm.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/frame/addForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _addForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _addForm_vue_vue_type_template_id_73fdd83c___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _addForm_vue_vue_type_template_id_73fdd83c___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/frame/addForm.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/frame/addForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/frame/addForm.vue?vue&type=script&lang=js&":
/*!*****************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/frame/addForm.vue?vue&type=script&lang=js& ***!
\*****************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_addForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./addForm.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/frame/addForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_addForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/frame/addForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/frame/addForm.vue?vue&type=template&id=73fdd83c&":
/*!***********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/frame/addForm.vue?vue&type=template&id=73fdd83c& ***!
\***********************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_addForm_vue_vue_type_template_id_73fdd83c___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./addForm.vue?vue&type=template&id=73fdd83c& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/frame/addForm.vue?vue&type=template&id=73fdd83c&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_addForm_vue_vue_type_template_id_73fdd83c___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_addForm_vue_vue_type_template_id_73fdd83c___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/frame/addForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/frame/frameForm.vue":
/*!******************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/frame/frameForm.vue ***!
\******************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _frameForm_vue_vue_type_template_id_0eab1b6e___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./frameForm.vue?vue&type=template&id=0eab1b6e& */ \"./includes/templates/vuejs/portal/build/components/frame/frameForm.vue?vue&type=template&id=0eab1b6e&\");\n/* harmony import */ var _frameForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./frameForm.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/frame/frameForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _frameForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _frameForm_vue_vue_type_template_id_0eab1b6e___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _frameForm_vue_vue_type_template_id_0eab1b6e___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/frame/frameForm.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/frame/frameForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/frame/frameForm.vue?vue&type=script&lang=js&":
/*!*******************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/frame/frameForm.vue?vue&type=script&lang=js& ***!
\*******************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_frameForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./frameForm.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/frame/frameForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_frameForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/frame/frameForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/frame/frameForm.vue?vue&type=template&id=0eab1b6e&":
/*!*************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/frame/frameForm.vue?vue&type=template&id=0eab1b6e& ***!
\*************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_frameForm_vue_vue_type_template_id_0eab1b6e___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./frameForm.vue?vue&type=template&id=0eab1b6e& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/frame/frameForm.vue?vue&type=template&id=0eab1b6e&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_frameForm_vue_vue_type_template_id_0eab1b6e___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_frameForm_vue_vue_type_template_id_0eab1b6e___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/frame/frameForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/frameList.vue":
/*!************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/frameList.vue ***!
\************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _frameList_vue_vue_type_template_id_41943eac___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./frameList.vue?vue&type=template&id=41943eac& */ \"./includes/templates/vuejs/portal/build/components/frameList.vue?vue&type=template&id=41943eac&\");\n/* harmony import */ var _frameList_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./frameList.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/frameList.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _frameList_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _frameList_vue_vue_type_template_id_41943eac___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _frameList_vue_vue_type_template_id_41943eac___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/frameList.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/frameList.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/frameList.vue?vue&type=script&lang=js&":
/*!*************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/frameList.vue?vue&type=script&lang=js& ***!
\*************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_frameList_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../node_modules/vue-loader/lib??vue-loader-options!./frameList.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/frameList.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_frameList_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/frameList.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/frameList.vue?vue&type=template&id=41943eac&":
/*!*******************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/frameList.vue?vue&type=template&id=41943eac& ***!
\*******************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_frameList_vue_vue_type_template_id_41943eac___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../node_modules/vue-loader/lib??vue-loader-options!./frameList.vue?vue&type=template&id=41943eac& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/frameList.vue?vue&type=template&id=41943eac&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_frameList_vue_vue_type_template_id_41943eac___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_frameList_vue_vue_type_template_id_41943eac___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/frameList.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue":
/*!**********************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue ***!
\**********************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _gabaritForm_vue_vue_type_template_id_2ffc205c___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./gabaritForm.vue?vue&type=template&id=2ffc205c& */ \"./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue?vue&type=template&id=2ffc205c&\");\n/* harmony import */ var _gabaritForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./gabaritForm.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _gabaritForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _gabaritForm_vue_vue_type_template_id_2ffc205c___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _gabaritForm_vue_vue_type_template_id_2ffc205c___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue?vue&type=script&lang=js&":
/*!***********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue?vue&type=script&lang=js& ***!
\***********************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_gabaritForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./gabaritForm.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_gabaritForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue?vue&type=template&id=2ffc205c&":
/*!*****************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue?vue&type=template&id=2ffc205c& ***!
\*****************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_gabaritForm_vue_vue_type_template_id_2ffc205c___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./gabaritForm.vue?vue&type=template&id=2ffc205c& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue?vue&type=template&id=2ffc205c&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_gabaritForm_vue_vue_type_template_id_2ffc205c___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_gabaritForm_vue_vue_type_template_id_2ffc205c___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue":
/*!**************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue ***!
\**************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _gabaritHeritage_vue_vue_type_template_id_ff7d2fd2___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./gabaritHeritage.vue?vue&type=template&id=ff7d2fd2& */ \"./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue?vue&type=template&id=ff7d2fd2&\");\n/* harmony import */ var _gabaritHeritage_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./gabaritHeritage.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _gabaritHeritage_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _gabaritHeritage_vue_vue_type_template_id_ff7d2fd2___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _gabaritHeritage_vue_vue_type_template_id_ff7d2fd2___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue?vue&type=script&lang=js&":
/*!***************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue?vue&type=script&lang=js& ***!
\***************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_gabaritHeritage_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./gabaritHeritage.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_gabaritHeritage_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue?vue&type=template&id=ff7d2fd2&":
/*!*********************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue?vue&type=template&id=ff7d2fd2& ***!
\*********************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_gabaritHeritage_vue_vue_type_template_id_ff7d2fd2___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./gabaritHeritage.vue?vue&type=template&id=ff7d2fd2& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue?vue&type=template&id=ff7d2fd2&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_gabaritHeritage_vue_vue_type_template_id_ff7d2fd2___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_gabaritHeritage_vue_vue_type_template_id_ff7d2fd2___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue":
/*!**************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue ***!
\**************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _gabaritPageForm_vue_vue_type_template_id_314d2fea___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./gabaritPageForm.vue?vue&type=template&id=314d2fea& */ \"./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue?vue&type=template&id=314d2fea&\");\n/* harmony import */ var _gabaritPageForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./gabaritPageForm.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _gabaritPageForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _gabaritPageForm_vue_vue_type_template_id_314d2fea___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _gabaritPageForm_vue_vue_type_template_id_314d2fea___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue?vue&type=script&lang=js&":
/*!***************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue?vue&type=script&lang=js& ***!
\***************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_gabaritPageForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./gabaritPageForm.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_gabaritPageForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue?vue&type=template&id=314d2fea&":
/*!*********************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue?vue&type=template&id=314d2fea& ***!
\*********************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_gabaritPageForm_vue_vue_type_template_id_314d2fea___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./gabaritPageForm.vue?vue&type=template&id=314d2fea& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue?vue&type=template&id=314d2fea&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_gabaritPageForm_vue_vue_type_template_id_314d2fea___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_gabaritPageForm_vue_vue_type_template_id_314d2fea___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue":
/*!***********************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue ***!
\***********************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _attributeForm_vue_vue_type_template_id_76a433a8___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./attributeForm.vue?vue&type=template&id=76a433a8& */ \"./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue?vue&type=template&id=76a433a8&\");\n/* harmony import */ var _attributeForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./attributeForm.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _attributeForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _attributeForm_vue_vue_type_template_id_76a433a8___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _attributeForm_vue_vue_type_template_id_76a433a8___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/layout/attributeForm.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue?vue&type=script&lang=js&":
/*!************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue?vue&type=script&lang=js& ***!
\************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_attributeForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./attributeForm.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_attributeForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue?vue&type=template&id=76a433a8&":
/*!******************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue?vue&type=template&id=76a433a8& ***!
\******************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_attributeForm_vue_vue_type_template_id_76a433a8___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./attributeForm.vue?vue&type=template&id=76a433a8& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue?vue&type=template&id=76a433a8&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_attributeForm_vue_vue_type_template_id_76a433a8___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_attributeForm_vue_vue_type_template_id_76a433a8___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue":
/*!********************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue ***!
\********************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _classesCSS_vue_vue_type_template_id_3d4ee281___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./classesCSS.vue?vue&type=template&id=3d4ee281& */ \"./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue?vue&type=template&id=3d4ee281&\");\n/* harmony import */ var _classesCSS_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./classesCSS.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _classesCSS_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _classesCSS_vue_vue_type_template_id_3d4ee281___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _classesCSS_vue_vue_type_template_id_3d4ee281___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/layout/classesCSS.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue?vue&type=script&lang=js&":
/*!*********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue?vue&type=script&lang=js& ***!
\*********************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_classesCSS_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./classesCSS.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_classesCSS_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue?vue&type=template&id=3d4ee281&":
/*!***************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue?vue&type=template&id=3d4ee281& ***!
\***************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_classesCSS_vue_vue_type_template_id_3d4ee281___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./classesCSS.vue?vue&type=template&id=3d4ee281& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue?vue&type=template&id=3d4ee281&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_classesCSS_vue_vue_type_template_id_3d4ee281___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_classesCSS_vue_vue_type_template_id_3d4ee281___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/commonParams.vue":
/*!**********************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/commonParams.vue ***!
\**********************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _commonParams_vue_vue_type_template_id_2d56ccd5___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./commonParams.vue?vue&type=template&id=2d56ccd5& */ \"./includes/templates/vuejs/portal/build/components/layout/commonParams.vue?vue&type=template&id=2d56ccd5&\");\n/* harmony import */ var _commonParams_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./commonParams.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/layout/commonParams.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _commonParams_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _commonParams_vue_vue_type_template_id_2d56ccd5___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _commonParams_vue_vue_type_template_id_2d56ccd5___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/layout/commonParams.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/commonParams.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/commonParams.vue?vue&type=script&lang=js&":
/*!***********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/commonParams.vue?vue&type=script&lang=js& ***!
\***********************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_commonParams_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./commonParams.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/commonParams.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_commonParams_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/commonParams.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/commonParams.vue?vue&type=template&id=2d56ccd5&":
/*!*****************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/commonParams.vue?vue&type=template&id=2d56ccd5& ***!
\*****************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_commonParams_vue_vue_type_template_id_2d56ccd5___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./commonParams.vue?vue&type=template&id=2d56ccd5& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/commonParams.vue?vue&type=template&id=2d56ccd5&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_commonParams_vue_vue_type_template_id_2d56ccd5___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_commonParams_vue_vue_type_template_id_2d56ccd5___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/commonParams.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/frame.vue":
/*!***************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/frame.vue ***!
\***************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _frame_vue_vue_type_template_id_22f5a799___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./frame.vue?vue&type=template&id=22f5a799& */ \"./includes/templates/vuejs/portal/build/components/layout/frame.vue?vue&type=template&id=22f5a799&\");\n/* harmony import */ var _frame_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./frame.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/layout/frame.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _frame_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _frame_vue_vue_type_template_id_22f5a799___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _frame_vue_vue_type_template_id_22f5a799___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/layout/frame.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/frame.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/frame.vue?vue&type=script&lang=js&":
/*!****************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/frame.vue?vue&type=script&lang=js& ***!
\****************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_frame_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./frame.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/frame.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_frame_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/frame.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/frame.vue?vue&type=template&id=22f5a799&":
/*!**********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/frame.vue?vue&type=template&id=22f5a799& ***!
\**********************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_frame_vue_vue_type_template_id_22f5a799___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./frame.vue?vue&type=template&id=22f5a799& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/frame.vue?vue&type=template&id=22f5a799&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_frame_vue_vue_type_template_id_22f5a799___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_frame_vue_vue_type_template_id_22f5a799___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/frame.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/frameForm.vue":
/*!*******************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/frameForm.vue ***!
\*******************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _frameForm_vue_vue_type_template_id_206fadfd___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./frameForm.vue?vue&type=template&id=206fadfd& */ \"./includes/templates/vuejs/portal/build/components/layout/frameForm.vue?vue&type=template&id=206fadfd&\");\n/* harmony import */ var _frameForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./frameForm.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/layout/frameForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _frameForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _frameForm_vue_vue_type_template_id_206fadfd___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _frameForm_vue_vue_type_template_id_206fadfd___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/layout/frameForm.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/frameForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/frameForm.vue?vue&type=script&lang=js&":
/*!********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/frameForm.vue?vue&type=script&lang=js& ***!
\********************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_frameForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./frameForm.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/frameForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_frameForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/frameForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/frameForm.vue?vue&type=template&id=206fadfd&":
/*!**************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/frameForm.vue?vue&type=template&id=206fadfd& ***!
\**************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_frameForm_vue_vue_type_template_id_206fadfd___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./frameForm.vue?vue&type=template&id=206fadfd& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/frameForm.vue?vue&type=template&id=206fadfd&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_frameForm_vue_vue_type_template_id_206fadfd___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_frameForm_vue_vue_type_template_id_206fadfd___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/frameForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/layout.vue":
/*!****************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/layout.vue ***!
\****************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _layout_vue_vue_type_template_id_62dc812e___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./layout.vue?vue&type=template&id=62dc812e& */ \"./includes/templates/vuejs/portal/build/components/layout/layout.vue?vue&type=template&id=62dc812e&\");\n/* harmony import */ var _layout_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./layout.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/layout/layout.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _layout_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _layout_vue_vue_type_template_id_62dc812e___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _layout_vue_vue_type_template_id_62dc812e___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/layout/layout.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/layout.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/layout.vue?vue&type=script&lang=js&":
/*!*****************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/layout.vue?vue&type=script&lang=js& ***!
\*****************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_layout_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./layout.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/layout.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_layout_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/layout.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/layout.vue?vue&type=template&id=62dc812e&":
/*!***********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/layout.vue?vue&type=template&id=62dc812e& ***!
\***********************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_layout_vue_vue_type_template_id_62dc812e___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./layout.vue?vue&type=template&id=62dc812e& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/layout.vue?vue&type=template&id=62dc812e&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_layout_vue_vue_type_template_id_62dc812e___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_layout_vue_vue_type_template_id_62dc812e___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/layout.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue":
/*!*********************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue ***!
\*********************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _shareLayout_vue_vue_type_template_id_01ebd5d6___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./shareLayout.vue?vue&type=template&id=01ebd5d6& */ \"./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue?vue&type=template&id=01ebd5d6&\");\n/* harmony import */ var _shareLayout_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./shareLayout.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _shareLayout_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _shareLayout_vue_vue_type_template_id_01ebd5d6___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _shareLayout_vue_vue_type_template_id_01ebd5d6___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/layout/shareLayout.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue?vue&type=script&lang=js&":
/*!**********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue?vue&type=script&lang=js& ***!
\**********************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_shareLayout_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./shareLayout.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_shareLayout_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue?vue&type=template&id=01ebd5d6&":
/*!****************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue?vue&type=template&id=01ebd5d6& ***!
\****************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_shareLayout_vue_vue_type_template_id_01ebd5d6___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./shareLayout.vue?vue&type=template&id=01ebd5d6& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue?vue&type=template&id=01ebd5d6&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_shareLayout_vue_vue_type_template_id_01ebd5d6___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_shareLayout_vue_vue_type_template_id_01ebd5d6___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/zone.vue":
/*!**************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/zone.vue ***!
\**************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _zone_vue_vue_type_template_id_e52c78a0___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./zone.vue?vue&type=template&id=e52c78a0& */ \"./includes/templates/vuejs/portal/build/components/layout/zone.vue?vue&type=template&id=e52c78a0&\");\n/* harmony import */ var _zone_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./zone.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/layout/zone.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _zone_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _zone_vue_vue_type_template_id_e52c78a0___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _zone_vue_vue_type_template_id_e52c78a0___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/layout/zone.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/zone.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/zone.vue?vue&type=script&lang=js&":
/*!***************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/zone.vue?vue&type=script&lang=js& ***!
\***************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_zone_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./zone.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/zone.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_zone_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/zone.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/zone.vue?vue&type=template&id=e52c78a0&":
/*!*********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/zone.vue?vue&type=template&id=e52c78a0& ***!
\*********************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_zone_vue_vue_type_template_id_e52c78a0___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./zone.vue?vue&type=template&id=e52c78a0& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/zone.vue?vue&type=template&id=e52c78a0&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_zone_vue_vue_type_template_id_e52c78a0___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_zone_vue_vue_type_template_id_e52c78a0___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/zone.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue":
/*!******************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue ***!
\******************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _zoneForm_vue_vue_type_template_id_868c32d8___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./zoneForm.vue?vue&type=template&id=868c32d8& */ \"./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue?vue&type=template&id=868c32d8&\");\n/* harmony import */ var _zoneForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./zoneForm.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _zoneForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _zoneForm_vue_vue_type_template_id_868c32d8___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _zoneForm_vue_vue_type_template_id_868c32d8___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/layout/zoneForm.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue?vue&type=script&lang=js&":
/*!*******************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue?vue&type=script&lang=js& ***!
\*******************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_zoneForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./zoneForm.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_zoneForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue?vue&type=template&id=868c32d8&":
/*!*************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue?vue&type=template&id=868c32d8& ***!
\*************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_zoneForm_vue_vue_type_template_id_868c32d8___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./zoneForm.vue?vue&type=template&id=868c32d8& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue?vue&type=template&id=868c32d8&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_zoneForm_vue_vue_type_template_id_868c32d8___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_zoneForm_vue_vue_type_template_id_868c32d8___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/list.vue":
/*!*******************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/list.vue ***!
\*******************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _list_vue_vue_type_template_id_134923ef___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./list.vue?vue&type=template&id=134923ef& */ \"./includes/templates/vuejs/portal/build/components/list.vue?vue&type=template&id=134923ef&\");\n/* harmony import */ var _list_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./list.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/list.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _list_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _list_vue_vue_type_template_id_134923ef___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _list_vue_vue_type_template_id_134923ef___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/list.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/list.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/list.vue?vue&type=script&lang=js&":
/*!********************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/list.vue?vue&type=script&lang=js& ***!
\********************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_list_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../node_modules/vue-loader/lib??vue-loader-options!./list.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/list.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_list_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/list.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/list.vue?vue&type=template&id=134923ef&":
/*!**************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/list.vue?vue&type=template&id=134923ef& ***!
\**************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_list_vue_vue_type_template_id_134923ef___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../node_modules/vue-loader/lib??vue-loader-options!./list.vue?vue&type=template&id=134923ef& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/list.vue?vue&type=template&id=134923ef&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_list_vue_vue_type_template_id_134923ef___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_list_vue_vue_type_template_id_134923ef___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/list.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/loader.vue":
/*!*********************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/loader.vue ***!
\*********************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _loader_vue_vue_type_template_id_bf1852b8___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./loader.vue?vue&type=template&id=bf1852b8& */ \"./includes/templates/vuejs/portal/build/components/loader.vue?vue&type=template&id=bf1852b8&\");\n/* harmony import */ var _loader_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./loader.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/loader.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _loader_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _loader_vue_vue_type_template_id_bf1852b8___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _loader_vue_vue_type_template_id_bf1852b8___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/loader.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/loader.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/loader.vue?vue&type=script&lang=js&":
/*!**********************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/loader.vue?vue&type=script&lang=js& ***!
\**********************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_loader_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../node_modules/vue-loader/lib??vue-loader-options!./loader.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/loader.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_loader_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/loader.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/loader.vue?vue&type=template&id=bf1852b8&":
/*!****************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/loader.vue?vue&type=template&id=bf1852b8& ***!
\****************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_loader_vue_vue_type_template_id_bf1852b8___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../node_modules/vue-loader/lib??vue-loader-options!./loader.vue?vue&type=template&id=bf1852b8& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/loader.vue?vue&type=template&id=bf1852b8&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_loader_vue_vue_type_template_id_bf1852b8___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_loader_vue_vue_type_template_id_bf1852b8___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/loader.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/nav/nav.vue":
/*!**********************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/nav/nav.vue ***!
\**********************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _nav_vue_vue_type_template_id_b292c214___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./nav.vue?vue&type=template&id=b292c214& */ \"./includes/templates/vuejs/portal/build/components/nav/nav.vue?vue&type=template&id=b292c214&\");\n/* harmony import */ var _nav_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./nav.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/nav/nav.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _nav_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _nav_vue_vue_type_template_id_b292c214___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _nav_vue_vue_type_template_id_b292c214___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/nav/nav.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/nav/nav.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/nav/nav.vue?vue&type=script&lang=js&":
/*!***********************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/nav/nav.vue?vue&type=script&lang=js& ***!
\***********************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_nav_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./nav.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/nav/nav.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_nav_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/nav/nav.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/nav/nav.vue?vue&type=template&id=b292c214&":
/*!*****************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/nav/nav.vue?vue&type=template&id=b292c214& ***!
\*****************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_nav_vue_vue_type_template_id_b292c214___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./nav.vue?vue&type=template&id=b292c214& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/nav/nav.vue?vue&type=template&id=b292c214&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_nav_vue_vue_type_template_id_b292c214___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_nav_vue_vue_type_template_id_b292c214___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/nav/nav.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/nav/navItem.vue":
/*!**************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/nav/navItem.vue ***!
\**************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _navItem_vue_vue_type_template_id_e82144ae___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./navItem.vue?vue&type=template&id=e82144ae& */ \"./includes/templates/vuejs/portal/build/components/nav/navItem.vue?vue&type=template&id=e82144ae&\");\n/* harmony import */ var _navItem_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./navItem.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/nav/navItem.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _navItem_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _navItem_vue_vue_type_template_id_e82144ae___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _navItem_vue_vue_type_template_id_e82144ae___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/nav/navItem.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/nav/navItem.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/nav/navItem.vue?vue&type=script&lang=js&":
/*!***************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/nav/navItem.vue?vue&type=script&lang=js& ***!
\***************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_navItem_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./navItem.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/nav/navItem.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_navItem_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/nav/navItem.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/nav/navItem.vue?vue&type=template&id=e82144ae&":
/*!*********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/nav/navItem.vue?vue&type=template&id=e82144ae& ***!
\*********************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_navItem_vue_vue_type_template_id_e82144ae___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./navItem.vue?vue&type=template&id=e82144ae& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/nav/navItem.vue?vue&type=template&id=e82144ae&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_navItem_vue_vue_type_template_id_e82144ae___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_navItem_vue_vue_type_template_id_e82144ae___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/nav/navItem.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/nav/subNav.vue":
/*!*************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/nav/subNav.vue ***!
\*************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _subNav_vue_vue_type_template_id_53e55940___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./subNav.vue?vue&type=template&id=53e55940& */ \"./includes/templates/vuejs/portal/build/components/nav/subNav.vue?vue&type=template&id=53e55940&\");\n/* harmony import */ var _subNav_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./subNav.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/nav/subNav.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _subNav_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _subNav_vue_vue_type_template_id_53e55940___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _subNav_vue_vue_type_template_id_53e55940___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/nav/subNav.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/nav/subNav.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/nav/subNav.vue?vue&type=script&lang=js&":
/*!**************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/nav/subNav.vue?vue&type=script&lang=js& ***!
\**************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_subNav_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./subNav.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/nav/subNav.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_subNav_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/nav/subNav.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/nav/subNav.vue?vue&type=template&id=53e55940&":
/*!********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/nav/subNav.vue?vue&type=template&id=53e55940& ***!
\********************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_subNav_vue_vue_type_template_id_53e55940___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./subNav.vue?vue&type=template&id=53e55940& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/nav/subNav.vue?vue&type=template&id=53e55940&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_subNav_vue_vue_type_template_id_53e55940___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_subNav_vue_vue_type_template_id_53e55940___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/nav/subNav.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue":
/*!*******************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue ***!
\*******************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _cmsPageForm_vue_vue_type_template_id_31ab47ad___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./cmsPageForm.vue?vue&type=template&id=31ab47ad& */ \"./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue?vue&type=template&id=31ab47ad&\");\n/* harmony import */ var _cmsPageForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./cmsPageForm.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _cmsPageForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _cmsPageForm_vue_vue_type_template_id_31ab47ad___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _cmsPageForm_vue_vue_type_template_id_31ab47ad___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue?vue&type=script&lang=js&":
/*!********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue?vue&type=script&lang=js& ***!
\********************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_cmsPageForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./cmsPageForm.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_cmsPageForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue?vue&type=template&id=31ab47ad&":
/*!**************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue?vue&type=template&id=31ab47ad& ***!
\**************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_cmsPageForm_vue_vue_type_template_id_31ab47ad___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./cmsPageForm.vue?vue&type=template&id=31ab47ad& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue?vue&type=template&id=31ab47ad&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_cmsPageForm_vue_vue_type_template_id_31ab47ad___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_cmsPageForm_vue_vue_type_template_id_31ab47ad___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/conditions.vue":
/*!******************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/conditions.vue ***!
\******************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _conditions_vue_vue_type_template_id_47050112___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./conditions.vue?vue&type=template&id=47050112& */ \"./includes/templates/vuejs/portal/build/components/page/conditions.vue?vue&type=template&id=47050112&\");\n/* harmony import */ var _conditions_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./conditions.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/page/conditions.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _conditions_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _conditions_vue_vue_type_template_id_47050112___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _conditions_vue_vue_type_template_id_47050112___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/page/conditions.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/conditions.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/conditions.vue?vue&type=script&lang=js&":
/*!*******************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/conditions.vue?vue&type=script&lang=js& ***!
\*******************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_conditions_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./conditions.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/conditions.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_conditions_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/conditions.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/conditions.vue?vue&type=template&id=47050112&":
/*!*************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/conditions.vue?vue&type=template&id=47050112& ***!
\*************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_conditions_vue_vue_type_template_id_47050112___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./conditions.vue?vue&type=template&id=47050112& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/conditions.vue?vue&type=template&id=47050112&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_conditions_vue_vue_type_template_id_47050112___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_conditions_vue_vue_type_template_id_47050112___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/conditions.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue":
/*!************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue ***!
\************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _ConditionEnvModel_vue_vue_type_template_id_ea228c82___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ConditionEnvModel.vue?vue&type=template&id=ea228c82& */ \"./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue?vue&type=template&id=ea228c82&\");\n/* harmony import */ var _ConditionEnvModel_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ConditionEnvModel.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _ConditionEnvModel_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _ConditionEnvModel_vue_vue_type_template_id_ea228c82___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _ConditionEnvModel_vue_vue_type_template_id_ea228c82___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue?vue&type=script&lang=js&":
/*!*************************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue?vue&type=script&lang=js& ***!
\*************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_ConditionEnvModel_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./ConditionEnvModel.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_ConditionEnvModel_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue?vue&type=template&id=ea228c82&":
/*!*******************************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue?vue&type=template&id=ea228c82& ***!
\*******************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_ConditionEnvModel_vue_vue_type_template_id_ea228c82___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./ConditionEnvModel.vue?vue&type=template&id=ea228c82& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue?vue&type=template&id=ea228c82&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_ConditionEnvModel_vue_vue_type_template_id_ea228c82___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_ConditionEnvModel_vue_vue_type_template_id_ea228c82___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue":
/*!*****************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue ***!
\*****************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _ConditionOpacViewModel_vue_vue_type_template_id_025639e4___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ConditionOpacViewModel.vue?vue&type=template&id=025639e4& */ \"./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue?vue&type=template&id=025639e4&\");\n/* harmony import */ var _ConditionOpacViewModel_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ConditionOpacViewModel.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _ConditionOpacViewModel_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _ConditionOpacViewModel_vue_vue_type_template_id_025639e4___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _ConditionOpacViewModel_vue_vue_type_template_id_025639e4___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue?vue&type=script&lang=js&":
/*!******************************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue?vue&type=script&lang=js& ***!
\******************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_ConditionOpacViewModel_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./ConditionOpacViewModel.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_ConditionOpacViewModel_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue?vue&type=template&id=025639e4&":
/*!************************************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue?vue&type=template&id=025639e4& ***!
\************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_ConditionOpacViewModel_vue_vue_type_template_id_025639e4___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./ConditionOpacViewModel.vue?vue&type=template&id=025639e4& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue?vue&type=template&id=025639e4&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_ConditionOpacViewModel_vue_vue_type_template_id_025639e4___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_ConditionOpacViewModel_vue_vue_type_template_id_025639e4___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/pageForm.vue":
/*!****************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/pageForm.vue ***!
\****************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _pageForm_vue_vue_type_template_id_13c294f2___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./pageForm.vue?vue&type=template&id=13c294f2& */ \"./includes/templates/vuejs/portal/build/components/page/pageForm.vue?vue&type=template&id=13c294f2&\");\n/* harmony import */ var _pageForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./pageForm.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/page/pageForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _pageForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _pageForm_vue_vue_type_template_id_13c294f2___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _pageForm_vue_vue_type_template_id_13c294f2___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/page/pageForm.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/pageForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/pageForm.vue?vue&type=script&lang=js&":
/*!*****************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/pageForm.vue?vue&type=script&lang=js& ***!
\*****************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_pageForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./pageForm.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/pageForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_pageForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/pageForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/pageForm.vue?vue&type=template&id=13c294f2&":
/*!***********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/pageForm.vue?vue&type=template&id=13c294f2& ***!
\***********************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_pageForm_vue_vue_type_template_id_13c294f2___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./pageForm.vue?vue&type=template&id=13c294f2& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/pageForm.vue?vue&type=template&id=13c294f2&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_pageForm_vue_vue_type_template_id_13c294f2___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_pageForm_vue_vue_type_template_id_13c294f2___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/pageForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue":
/*!********************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue ***!
\********************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _pageHeritage_vue_vue_type_template_id_7befa1ad___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./pageHeritage.vue?vue&type=template&id=7befa1ad& */ \"./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue?vue&type=template&id=7befa1ad&\");\n/* harmony import */ var _pageHeritage_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./pageHeritage.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _pageHeritage_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _pageHeritage_vue_vue_type_template_id_7befa1ad___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _pageHeritage_vue_vue_type_template_id_7befa1ad___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/page/pageHeritage.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue?vue&type=script&lang=js&":
/*!*********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue?vue&type=script&lang=js& ***!
\*********************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_pageHeritage_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./pageHeritage.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_pageHeritage_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue?vue&type=template&id=7befa1ad&":
/*!***************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue?vue&type=template&id=7befa1ad& ***!
\***************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_pageHeritage_vue_vue_type_template_id_7befa1ad___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./pageHeritage.vue?vue&type=template&id=7befa1ad& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue?vue&type=template&id=7befa1ad&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_pageHeritage_vue_vue_type_template_id_7befa1ad___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_pageHeritage_vue_vue_type_template_id_7befa1ad___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue":
/*!********************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue ***!
\********************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _pageTypeForm_vue_vue_type_template_id_e4581968___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./pageTypeForm.vue?vue&type=template&id=e4581968& */ \"./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue?vue&type=template&id=e4581968&\");\n/* harmony import */ var _pageTypeForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./pageTypeForm.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _pageTypeForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _pageTypeForm_vue_vue_type_template_id_e4581968___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _pageTypeForm_vue_vue_type_template_id_e4581968___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue?vue&type=script&lang=js&":
/*!*********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue?vue&type=script&lang=js& ***!
\*********************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_pageTypeForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./pageTypeForm.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_pageTypeForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue?vue&type=template&id=e4581968&":
/*!***************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue?vue&type=template&id=e4581968& ***!
\***************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_pageTypeForm_vue_vue_type_template_id_e4581968___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./pageTypeForm.vue?vue&type=template&id=e4581968& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue?vue&type=template&id=e4581968&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_pageTypeForm_vue_vue_type_template_id_e4581968___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_pageTypeForm_vue_vue_type_template_id_e4581968___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/preview/contextForm.vue":
/*!**********************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/preview/contextForm.vue ***!
\**********************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _contextForm_vue_vue_type_template_id_0dc501ea___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./contextForm.vue?vue&type=template&id=0dc501ea& */ \"./includes/templates/vuejs/portal/build/components/preview/contextForm.vue?vue&type=template&id=0dc501ea&\");\n/* harmony import */ var _contextForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./contextForm.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/preview/contextForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _contextForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _contextForm_vue_vue_type_template_id_0dc501ea___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _contextForm_vue_vue_type_template_id_0dc501ea___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/preview/contextForm.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/preview/contextForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/preview/contextForm.vue?vue&type=script&lang=js&":
/*!***********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/preview/contextForm.vue?vue&type=script&lang=js& ***!
\***********************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_contextForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./contextForm.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/preview/contextForm.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_contextForm_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/preview/contextForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/preview/contextForm.vue?vue&type=template&id=0dc501ea&":
/*!*****************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/preview/contextForm.vue?vue&type=template&id=0dc501ea& ***!
\*****************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_contextForm_vue_vue_type_template_id_0dc501ea___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./contextForm.vue?vue&type=template&id=0dc501ea& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/preview/contextForm.vue?vue&type=template&id=0dc501ea&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_contextForm_vue_vue_type_template_id_0dc501ea___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_contextForm_vue_vue_type_template_id_0dc501ea___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/preview/contextForm.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/preview/preview.vue":
/*!******************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/preview/preview.vue ***!
\******************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _preview_vue_vue_type_template_id_64e5ad80___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./preview.vue?vue&type=template&id=64e5ad80& */ \"./includes/templates/vuejs/portal/build/components/preview/preview.vue?vue&type=template&id=64e5ad80&\");\n/* harmony import */ var _preview_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./preview.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/preview/preview.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _preview_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _preview_vue_vue_type_template_id_64e5ad80___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _preview_vue_vue_type_template_id_64e5ad80___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/preview/preview.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/preview/preview.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/preview/preview.vue?vue&type=script&lang=js&":
/*!*******************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/preview/preview.vue?vue&type=script&lang=js& ***!
\*******************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_preview_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./preview.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/preview/preview.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_preview_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/preview/preview.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/preview/preview.vue?vue&type=template&id=64e5ad80&":
/*!*************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/preview/preview.vue?vue&type=template&id=64e5ad80& ***!
\*************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_preview_vue_vue_type_template_id_64e5ad80___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./preview.vue?vue&type=template&id=64e5ad80& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/preview/preview.vue?vue&type=template&id=64e5ad80&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_preview_vue_vue_type_template_id_64e5ad80___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_preview_vue_vue_type_template_id_64e5ad80___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/preview/preview.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue":
/*!*************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue ***!
\*************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _HtmlSemantic_vue_vue_type_template_id_1418f2b8___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./HtmlSemantic.vue?vue&type=template&id=1418f2b8& */ \"./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue?vue&type=template&id=1418f2b8&\");\n/* harmony import */ var _HtmlSemantic_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./HtmlSemantic.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _HtmlSemantic_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _HtmlSemantic_vue_vue_type_template_id_1418f2b8___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _HtmlSemantic_vue_vue_type_template_id_1418f2b8___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue?vue&type=script&lang=js&":
/*!**************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue?vue&type=script&lang=js& ***!
\**************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_HtmlSemantic_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./HtmlSemantic.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_HtmlSemantic_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue?vue&type=template&id=1418f2b8&":
/*!********************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue?vue&type=template&id=1418f2b8& ***!
\********************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_HtmlSemantic_vue_vue_type_template_id_1418f2b8___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./HtmlSemantic.vue?vue&type=template&id=1418f2b8& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue?vue&type=template&id=1418f2b8&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_HtmlSemantic_vue_vue_type_template_id_1418f2b8___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_HtmlSemantic_vue_vue_type_template_id_1418f2b8___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/semantics/semantics.vue":
/*!**********************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/semantics/semantics.vue ***!
\**********************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _semantics_vue_vue_type_template_id_42c9038a___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./semantics.vue?vue&type=template&id=42c9038a& */ \"./includes/templates/vuejs/portal/build/components/semantics/semantics.vue?vue&type=template&id=42c9038a&\");\n/* harmony import */ var _semantics_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./semantics.vue?vue&type=script&lang=js& */ \"./includes/templates/vuejs/portal/build/components/semantics/semantics.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport *//* harmony import */ var _node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js */ \"./node_modules/vue-loader/lib/runtime/componentNormalizer.js\");\n\n\n\n\n\n/* normalize component */\n\nvar component = Object(_node_modules_vue_loader_lib_runtime_componentNormalizer_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(\n _semantics_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n _semantics_vue_vue_type_template_id_42c9038a___WEBPACK_IMPORTED_MODULE_0__[\"render\"],\n _semantics_vue_vue_type_template_id_42c9038a___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"],\n false,\n null,\n null,\n null\n \n)\n\n/* hot reload */\nif (false) { var api; }\ncomponent.options.__file = \"includes/templates/vuejs/portal/build/components/semantics/semantics.vue\"\n/* harmony default export */ __webpack_exports__[\"default\"] = (component.exports);\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/semantics/semantics.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/semantics/semantics.vue?vue&type=script&lang=js&":
/*!***********************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/semantics/semantics.vue?vue&type=script&lang=js& ***!
\***********************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_semantics_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/babel-loader/lib??ref--0!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./semantics.vue?vue&type=script&lang=js& */ \"./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/semantics/semantics.vue?vue&type=script&lang=js&\");\n/* empty/unused harmony star reexport */ /* harmony default export */ __webpack_exports__[\"default\"] = (_node_modules_babel_loader_lib_index_js_ref_0_node_modules_vue_loader_lib_index_js_vue_loader_options_semantics_vue_vue_type_script_lang_js___WEBPACK_IMPORTED_MODULE_0__[\"default\"]); \n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/semantics/semantics.vue?");
/***/ }),
/***/ "./includes/templates/vuejs/portal/build/components/semantics/semantics.vue?vue&type=template&id=42c9038a&":
/*!*****************************************************************************************************************!*\
!*** ./includes/templates/vuejs/portal/build/components/semantics/semantics.vue?vue&type=template&id=42c9038a& ***!
\*****************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_semantics_vue_vue_type_template_id_42c9038a___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! -!../../../../../../../node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!../../../../../../../node_modules/vue-loader/lib??vue-loader-options!./semantics.vue?vue&type=template&id=42c9038a& */ \"./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/semantics/semantics.vue?vue&type=template&id=42c9038a&\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_semantics_vue_vue_type_template_id_42c9038a___WEBPACK_IMPORTED_MODULE_0__[\"render\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return _node_modules_vue_loader_lib_loaders_templateLoader_js_vue_loader_options_node_modules_vue_loader_lib_index_js_vue_loader_options_semantics_vue_vue_type_template_id_42c9038a___WEBPACK_IMPORTED_MODULE_0__[\"staticRenderFns\"]; });\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/semantics/semantics.vue?");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordion.vue?vue&type=script&lang=js&":
/*!*****************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/accordion/accordion.vue?vue&type=script&lang=js& ***!
\*****************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _accordionItem_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./accordionItem.vue */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue\");\n/* harmony import */ var _accordionGabaritItem_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./accordionGabaritItem.vue */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue\");\n/* harmony import */ var _accordionFrameItem_vue__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./accordionFrameItem.vue */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue\");\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n components: {\n accordionItem: _accordionItem_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"],\n accordionGabaritItem: _accordionGabaritItem_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n accordionFrameItem: _accordionFrameItem_vue__WEBPACK_IMPORTED_MODULE_2__[\"default\"]\n },\n data: function data() {\n return {\n itemActive: 0\n };\n },\n computed: {\n items: function items() {\n var items = [];\n\n for (var index in this.$cms.itemsAccordion) {\n var item = this.$cms.itemsAccordion[index];\n item.children = this.arrayOrderAlphaRecursive(item.children);\n item.active = this.itemActive == index;\n items.push(item);\n }\n\n return items;\n }\n },\n methods: {\n arrayOrderAlphaRecursive: function arrayOrderAlphaRecursive(list) {\n var _this = this;\n\n list.sort(function (a, b) {\n var titleA = a.title.toLowerCase();\n var titleB = b.title.toLowerCase();\n\n if (a.children.length > 0) {\n a.children = _this.arrayOrderAlphaRecursive(a.children);\n }\n\n if (b.children.length > 0) {\n b.children = _this.arrayOrderAlphaRecursive(b.children);\n }\n\n if (titleA < titleB) {\n return -1;\n }\n\n if (titleA > titleB) {\n return 1;\n }\n\n return 0;\n });\n return list;\n },\n showItem: function showItem(value) {\n if (this.itemActive == value) {\n this.itemActive = -1;\n } else {\n this.itemActive = value;\n }\n },\n componentExist: function componentExist(name) {\n return name && typeof this.$options.components[name] != \"undefined\";\n },\n getComponentName: function getComponentName(component_name) {\n return this.componentExist(component_name) ? component_name : 'accordionItem';\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordion.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue?vue&type=script&lang=js&":
/*!************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue?vue&type=script&lang=js& ***!
\************************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n name: 'accordion_content',\n props: ['active', 'item'],\n computed: {\n classes: function classes() {\n var classes = 'portal-accordion-sub-header';\n classes += this.item.isTag ? ' is-tag' : ' is-entity';\n classes += this.item.isEdited ? ' is-edited' : '';\n classes += this.item.data ? ' cursor-pointer' : '';\n return classes;\n },\n title: function title() {\n return this.item.isEdited ? this.$cms.getMessage('is_edited') : \"\";\n }\n },\n methods: {\n openItemAccordion: function openItemAccordion() {\n if (this.item.data) {\n this.$cms.openItem(this.item.data, true);\n }\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue?vue&type=script&lang=js&":
/*!*****************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue?vue&type=script&lang=js& ***!
\*****************************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n name: 'accordion_frame_content',\n props: ['active', 'item'],\n data: function data() {\n return {\n showFormClassement: false,\n styleClassement: \"\"\n };\n },\n created: function created() {\n var _this = this;\n\n document.body.addEventListener('click', function () {\n _this.showFormClassement = false;\n });\n window.addEventListener(\"hiddenEditClassment\", function () {\n _this.showFormClassement = false;\n });\n },\n computed: {\n classes: function classes() {\n var classes = 'portal-accordion-sub-header';\n classes += this.item.isTag ? ' is-tag' : ' is-entity';\n classes += this.item.isEdited ? ' is-edited' : '';\n return classes;\n },\n title: function title() {\n return this.item.isEdited ? this.$cms.getMessage('is_edited') : \"\";\n }\n },\n methods: {\n openItemAccordion: function openItemAccordion() {\n if (!this.item.isTag) {\n this.$cms.openItem(this.item.data, true);\n }\n },\n editClassement: function editClassement(event) {\n var _this2 = this;\n\n var isHidden = !this.showFormClassement;\n window.dispatchEvent(new Event(\"hiddenEditClassment\"));\n\n if (isHidden) {\n var target = event.target.nodeName == \"I\" ? event.target.parentNode : event.target;\n var node = document.querySelector('div.portal-accordion-content.active');\n var scrollTop = node ? node.scrollTop : 0;\n var top = target.offsetTop + target.offsetHeight - scrollTop;\n this.styleClassement = \"top: \".concat(top, \"px; left: \").concat(target.offsetLeft, \"px\");\n this.showFormClassement = true;\n this.$nextTick(function () {\n _this2.$refs.input_classement.focus();\n });\n }\n },\n saveClassement: function saveClassement(event) {\n this.showFormClassement = false;\n this.$cms.editFrameClassement(this.item);\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue?vue&type=script&lang=js&":
/*!**************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue?vue&type=script&lang=js& ***!
\**************************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _accordionFrameContent_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./accordionFrameContent.vue */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue\");\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\n\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(n); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && Symbol.iterator in Object(iter)) return Array.from(iter); }\n\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['item', 'index'],\n data: function data() {\n return {\n filter: \"\",\n search: \"\"\n };\n },\n components: {\n accordion_frame_content: _accordionFrameContent_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"]\n },\n computed: {\n filters: function filters() {\n var filters = [];\n\n if (this.children) {\n var children = this.item.children.filter(function (child) {\n return child.children.length > 0;\n });\n\n for (var index in children) {\n filters.push(children[index].title);\n }\n\n var default_classement = this.$cms.getMessage('default_classement');\n var classementIndex = filters.findIndex(function (classement) {\n return classement.toLowerCase() == default_classement.toLowerCase();\n });\n\n if (-1 != classementIndex) {\n filters.splice(classementIndex, 1);\n filters.splice(0, 0, default_classement);\n }\n }\n\n if (!filters.includes(this.filter)) {\n this.filter = \"\";\n }\n\n return filters;\n },\n children: function children() {\n var _this = this;\n\n var default_classement = this.$cms.getMessage('default_classement');\n var children = this.$cms.cloneObject(this.item.children);\n var childIndex = children.findIndex(function (child) {\n return child.title.toLowerCase() == default_classement.toLowerCase();\n });\n\n if (-1 != childIndex) {\n var child = this.$cms.cloneObject(children[childIndex]);\n children.splice(childIndex, 1);\n children.splice(0, 0, child);\n }\n\n if (this.filter != \"\") {\n children = children.filter(function (child) {\n return child.title.trim() == _this.filter.trim();\n });\n }\n\n if (this.search != \"\") {\n var i;\n\n (function () {\n var regexDefault = new RegExp(_this.search.trim(), 'i');\n var regexID = new RegExp(\"_\".concat(_this.search.trim(), \"$\"), 'i');\n var DEFAULT_SEARCH = 0;\n var SEARCH_BY_NODE_ID = 1;\n var SEARCH_BY_ID = 2;\n var search;\n\n if (_this.search.match('cms_module_')) {\n search = SEARCH_BY_NODE_ID;\n } else if (!isNaN(_this.search)) {\n search = SEARCH_BY_ID;\n } else {\n search = DEFAULT_SEARCH;\n }\n\n for (i = 0; i < children.length; i++) {\n switch (search) {\n case SEARCH_BY_NODE_ID:\n children[i].children = children[i].children.filter(function (child) {\n return child.data.item.semantic.id_tag == _this.search.trim();\n });\n break;\n\n case SEARCH_BY_ID:\n var search1 = children[i].children.filter(function (child) {\n return regexID.exec(child.data.item.semantic.id_tag);\n });\n var search2 = children[i].children.filter(function (child) {\n return regexDefault.exec(child.title.trim());\n });\n children[i].children = [].concat(_toConsumableArray(search1), _toConsumableArray(search2));\n break;\n\n case DEFAULT_SEARCH:\n default:\n children[i].children = children[i].children.filter(function (child) {\n return regexDefault.exec(child.title.trim());\n });\n break;\n }\n }\n })();\n }\n\n return children.filter(function (child) {\n return child.children.length > 0;\n });\n }\n },\n methods: {\n add: function add(event) {\n event.stopPropagation();\n\n if (typeof this.item['add'] == 'function') {\n this.item.add();\n }\n },\n hiddenEditClassment: function hiddenEditClassment(event) {\n window.dispatchEvent(new Event(\"hiddenEditClassment\"));\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue?vue&type=script&lang=js&":
/*!*******************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue?vue&type=script&lang=js& ***!
\*******************************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n name: 'accordion_gabarit_content',\n props: ['active', 'item'],\n data: function data() {\n return {\n showFormClassement: false,\n styleClassement: \"\"\n };\n },\n created: function created() {\n var _this = this;\n\n document.body.addEventListener('click', function () {\n _this.showFormClassement = false;\n });\n window.addEventListener(\"hiddenEditClassment\", function () {\n _this.showFormClassement = false;\n });\n },\n computed: {\n gabarit: function gabarit() {\n return this.item.data && this.item.data.item ? this.item.data.item : {};\n },\n classes: function classes() {\n var classes = 'portal-accordion-sub-header';\n classes += this.item.isTag ? ' is-tag' : ' is-entity';\n classes += this.item.isEdited ? ' is-edited' : '';\n return classes;\n },\n isUsed: function isUsed() {\n return this.$cms.getPagesUsingGabarit(this.gabarit.id).length > 0;\n },\n isUsedTitle: function isUsedTitle() {\n return this.isUsed ? this.$cms.getMessage('gabarit_used') : \"\";\n },\n isEditedTitle: function isEditedTitle() {\n return this.item.isEdited ? this.$cms.getMessage('is_edited') : \"\";\n }\n },\n methods: {\n openItemAccordion: function openItemAccordion() {\n if (!this.item.isTag) {\n this.$cms.openItem(this.item.data, true);\n }\n },\n getPages: function getPages() {\n var _this$$cms$pages;\n\n return (_this$$cms$pages = this.$cms.pages) !== null && _this$$cms$pages !== void 0 ? _this$$cms$pages : [];\n },\n editClassment: function editClassment(event) {\n var _this2 = this;\n\n var isHidden = !this.showFormClassement;\n window.dispatchEvent(new Event(\"hiddenEditClassment\"));\n\n if (isHidden) {\n var target = event.target.nodeName == \"I\" ? event.target.parentNode : event.target;\n var node = document.querySelector('div.portal-accordion-content.active');\n var scrollTop = node ? node.scrollTop : 0;\n var top = target.offsetTop + target.offsetHeight - scrollTop;\n this.styleClassement = \"top: \".concat(top, \"px; left: \").concat(target.offsetLeft, \"px\");\n this.showFormClassement = true;\n this.$nextTick(function () {\n _this2.$refs.input_classement.focus();\n });\n }\n },\n saveClassment: function saveClassment(event) {\n this.showFormClassement = false;\n this.$cms.editGabaritClassement(this.item);\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue?vue&type=script&lang=js&":
/*!****************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue?vue&type=script&lang=js& ***!
\****************************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _accordionGabaritContent_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./accordionGabaritContent.vue */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue\");\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['item', 'index'],\n data: function data() {\n return {\n filter: \"\",\n display_type: 0\n };\n },\n components: {\n accordion_gabarit_content: _accordionGabaritContent_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"]\n },\n computed: {\n filters: function filters() {\n var filters = [];\n\n if (this.item.children) {\n for (var index in this.item.children) {\n filters.push(this.item.children[index].title);\n }\n }\n\n if (!filters.includes(this.filter)) {\n this.filter = \"\";\n }\n\n return filters;\n },\n children: function children() {\n var _this = this;\n\n var children = this.item.children;\n\n if (this.$cms.gabaritsDisplayType != 0) {\n return children;\n }\n\n return this.filter == \"\" ? children : children.filter(function (child) {\n return child.title.trim() == _this.filter.trim();\n });\n }\n },\n methods: {\n add: function add(event) {\n event.stopPropagation();\n\n if (typeof this.item['add'] == 'function') {\n this.item.add();\n }\n },\n hiddenEditClassment: function hiddenEditClassment(event) {\n window.dispatchEvent(new Event(\"hiddenEditClassment\"));\n },\n updateDisplay: function updateDisplay() {\n this.$cms.formatGabaritsAccordion(this.display_type);\n }\n },\n watch: {\n display_type: function display_type() {//this.$cms.gabaritsDisplayType = this.display_type;\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue?vue&type=script&lang=js&":
/*!*********************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue?vue&type=script&lang=js& ***!
\*********************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _accordionContent_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./accordionContent.vue */ \"./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue\");\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['item', 'index'],\n data: function data() {\n return {\n filter: \"\"\n };\n },\n components: {\n accordion_content: _accordionContent_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"]\n },\n computed: {\n filters: function filters() {\n var filters = [];\n\n if (this.item.children) {\n for (var index in this.item.children) {\n filters.push(this.item.children[index]);\n }\n }\n\n return filters;\n },\n children: function children() {\n var _this = this;\n\n var children = this.item.children;\n return this.filter == \"\" ? children : children.filter(function (child) {\n return child.title.trim() == _this.filter.trim();\n });\n }\n },\n methods: {\n add: function add(event) {\n event.stopPropagation();\n\n if (typeof this.item['add'] == 'function') {\n this.item.add();\n }\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/alertError.vue?vue&type=script&lang=js&":
/*!********************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/alertError.vue?vue&type=script&lang=js& ***!
\********************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['message'],\n data: function data() {\n return {\n show: true\n };\n },\n watch: {\n 'errorMessage': function errorMessage(newValue, oldValue) {\n this.errorMessage = newValue;\n this.openError();\n }\n },\n methods: {\n openError: function openError() {\n this.show = true;\n },\n closeError: function closeError() {\n this.show = false;\n this.$emit('close', true);\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/alertError.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/frame/addForm.vue?vue&type=script&lang=js&":
/*!***********************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/frame/addForm.vue?vue&type=script&lang=js& ***!
\***********************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _alertError_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../alertError.vue */ \"./includes/templates/vuejs/portal/build/components/alertError.vue\");\n/* harmony import */ var _semantics_semantics_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../semantics/semantics.vue */ \"./includes/templates/vuejs/portal/build/components/semantics/semantics.vue\");\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }\n\nfunction _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err); } _next(undefined); }); }; }\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['title', 'id_tag', 'init_name', 'pageList', 'gabaritList'],\n components: {\n alert_error: _alertError_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"],\n semantics: _semantics_semantics_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"]\n },\n data: function data() {\n return {\n name: \"\",\n parent: \"\",\n layout: \"\",\n semantic: {\n id: 0,\n \"class\": \"Pmb\\\\CMS\\\\Semantics\\\\HtmlSemantic\",\n classes: [],\n id_tag: \"\",\n tag: \"\"\n },\n zoneList: {},\n errorMessage: \"\",\n dragging: false,\n x: 0,\n y: 0,\n startX: 0,\n startY: 0,\n dragStyle: \"\"\n };\n },\n mounted: function mounted() {\n var _this$init_name,\n _this = this;\n\n window.addEventListener('mouseup', this.stopDrag);\n window.addEventListener('mousemove', this.doDrag);\n this.name = (_this$init_name = this.init_name) !== null && _this$init_name !== void 0 ? _this$init_name : \"\";\n this.layout = this.firstLayout;\n this.updateParent();\n this.$nextTick(function () {\n _this.$refs.input_name.focus();\n });\n },\n computed: {\n noLayout: function noLayout() {\n return this.pages.length == 0 && this.gabarits.length == 0;\n },\n pages: function pages() {\n return this.pageList && this.pageList.length > 0 ? this.pageList : [];\n },\n gabarits: function gabarits() {\n return this.gabaritList && this.gabaritList.length > 0 ? this.gabaritList : [];\n },\n firstLayout: function firstLayout() {\n if (this.pages && this.pages.length > 0) {\n return \"page_\".concat(this.pages[0].id);\n }\n\n if (this.gabarits && this.gabarits.length > 0) {\n return \"gabarit_\".concat(this.gabarits[0].id);\n }\n\n return \"\";\n },\n layoutLabel: function layoutLabel() {\n if (this.pages && this.pages.length > 0) {\n return this.$cms.getMessage('pages_list');\n }\n\n if (this.gabarits && this.gabarits.length > 0) {\n return this.$cms.getMessage('gabarits_list');\n }\n\n return '';\n }\n },\n methods: {\n updateParent: function () {\n var _updateParent = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {\n var layout;\n return regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n if (this.layout) {\n _context.next = 2;\n break;\n }\n\n return _context.abrupt(\"return\");\n\n case 2:\n if (!(typeof this.zoneList[this.layout] != \"undefined\")) {\n _context.next = 6;\n break;\n }\n\n this.zoneList[this.layout];\n _context.next = 10;\n break;\n\n case 6:\n layout = this.layout.split(\"_\");\n _context.next = 9;\n return this.$cms.refreshZones({\n id: layout[1],\n \"class\": layout[0] == \"page\" ? \"Pmb\\\\CMS\\\\Models\\\\PagePortalModel\" : \"Pmb\\\\CMS\\\\Models\\\\GabaritLayoutModel\"\n });\n\n case 9:\n this.zoneList[this.layout] = _context.sent;\n\n case 10:\n this.parent = this.zoneList[this.layout][0].semantic.id_tag;\n\n case 11:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function updateParent() {\n return _updateParent.apply(this, arguments);\n }\n\n return updateParent;\n }(),\n updateSemantic: function updateSemantic(semanticUpdated) {\n this.semantic = semanticUpdated;\n },\n closeModal: function closeModal(event) {\n if (this.$refs.modal && event.target.id == this.$refs.modal.id) {\n this.$emit('closeFrameForm', true);\n }\n },\n getLayoutIndex: function getLayoutIndex() {\n return this.layout.substr(0, 4) == \"page\" ? 'page_id' : 'gabarit_id';\n },\n getLayoutId: function getLayoutId() {\n var layout = this.layout.split(\"_\");\n return layout[1];\n },\n submit: function submit() {\n var _this2 = this;\n\n this.semantic.id_tag = this.id_tag;\n\n var formData = _defineProperty({\n \"name\": this.name,\n \"cadre_id\": this.id_tag,\n \"parent\": this.parent,\n \"class\": \"Pmb\\\\CMS\\\\Models\\\\FrameCMSModel\",\n \"semantic\": this.semantic\n }, this.getLayoutIndex(), this.getLayoutId());\n\n var promise = this.$cms.addElementlayout(formData);\n promise.then(function (result) {\n if (!result.error) {\n _this2.$emit('submit', true);\n } else {\n _this2.errorMessage = result.errorMessage;\n }\n });\n },\n startDrag: function startDrag(event) {\n this.dragging = true;\n this.dragStyle = \"cursor: grabbing;\";\n this.startX = event.clientX;\n this.startY = event.clientY;\n },\n stopDrag: function stopDrag(event) {\n this.dragging = false;\n this.dragStyle = \"\";\n this.x = this.y = 0;\n },\n doDrag: function doDrag(event) {\n if (this.dragging) {\n this.x = this.startX - event.clientX;\n this.y = this.startY - event.clientY;\n this.startX = event.clientX;\n this.startY = event.clientY;\n this.$refs.modal_frame.style.position = \"absolute\";\n this.$refs.modal_frame.style.left = this.$refs.modal_frame.offsetLeft - this.x + \"px\";\n this.$refs.modal_frame.style.top = this.$refs.modal_frame.offsetTop - this.y + \"px\";\n }\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/frame/addForm.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/frame/frameForm.vue?vue&type=script&lang=js&":
/*!*************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/frame/frameForm.vue?vue&type=script&lang=js& ***!
\*************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _addForm_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./addForm.vue */ \"./includes/templates/vuejs/portal/build/components/frame/addForm.vue\");\n/* harmony import */ var _alertError_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../alertError.vue */ \"./includes/templates/vuejs/portal/build/components/alertError.vue\");\n/* harmony import */ var _list_vue__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../list.vue */ \"./includes/templates/vuejs/portal/build/components/list.vue\");\nfunction asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }\n\nfunction _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err); } _next(undefined); }); }; }\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: [\"data\"],\n components: {\n alert_error: _alertError_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n list: _list_vue__WEBPACK_IMPORTED_MODULE_2__[\"default\"],\n add_form: _addForm_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"]\n },\n data: function data() {\n var _this = this;\n\n return {\n id: 0,\n name: \"\",\n errorMessage: \"\",\n pageList: [],\n gabaritList: [],\n pagesWithoutFrame: [],\n gabaritWithoutFrame: [],\n showForm: false,\n addForm: false,\n modalTitle: \"\",\n events: {\n \"save_module\": function save_module(event) {\n _this.save(event.detail);\n },\n \"save_new_module\": function save_new_module(event) {\n _this.save_new_module(event.detail);\n },\n \"delete_module\": function delete_module() {\n _this.remove();\n },\n \"cancel_module\": function cancel_module() {\n _this.cancel();\n },\n \"cancel_new_module\": function cancel_new_module() {\n _this.cancel_new_module();\n }\n }\n };\n },\n mounted: function mounted() {\n this.load();\n\n for (event in this.events) {\n window.addEventListener(event, this.events[event]);\n }\n },\n destroyed: function destroyed() {\n for (event in this.events) {\n window.removeEventListener(event, this.events[event]);\n }\n },\n watch: {\n \"data\": function data(newValue, oldValue) {\n this.load();\n }\n },\n computed: {\n pageAddable: function pageAddable() {\n return this.getPagesWithoutFrame().length > 0 ? true : false;\n },\n gabaritAddable: function gabaritAddable() {\n return this.getGabaritsWithoutFrame().length > 0 ? true : false;\n },\n isEntity: function isEntity() {\n var _ref;\n\n return (_ref = this.data && this.data.item && this.data.item.id != 0) !== null && _ref !== void 0 ? _ref : false;\n },\n isOpacFrame: function isOpacFrame() {\n var _ref2;\n\n return (_ref2 = this.isEntity && this.data.item && this.data.item['class'] && this.data.item['class'] == \"Pmb\\\\CMS\\\\Models\\\\FrameOpacModel\") !== null && _ref2 !== void 0 ? _ref2 : false;\n }\n },\n methods: {\n getForm: function getForm(moduleName) {\n var _this2 = this;\n\n if (typeof cms_build_load_module != \"function\") {\n throw \"cms_build_load_module is not a function!\";\n }\n\n if (moduleName == \"\") {\n return false;\n } // On supprime tout les widgets DOJO qui ont �t� cr��\n\n\n destroyWidget();\n this.addForm = true;\n this.$nextTick(function () {\n cms_build_load_module(moduleName, \"get_form\", _this2.id, _this2.$cms.getMessage(\"cms_build_modules\"));\n });\n },\n closeError: function closeError() {\n this.errorMessage = \"\";\n },\n load: function () {\n var _load = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {\n var _this3 = this;\n\n return regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n // On supprime tout les widgets DOJO qui ont �t� cr��\n destroyWidget();\n\n if (!this.isEntity) {\n _context.next = 13;\n break;\n }\n\n this.id = this.data.item.id;\n this.name = this.data.item.name;\n\n if (!this.isOpacFrame) {\n this.$nextTick(function () {\n var module = _this3.data.item.semantic.id_tag.replace(/_[0-9]+/, '');\n\n edit_module(module, _this3.data.item.semantic.id_tag);\n });\n }\n\n _context.next = 7;\n return this.getPageList();\n\n case 7:\n this.pageList = _context.sent;\n _context.next = 10;\n return this.getGabaritList();\n\n case 10:\n this.gabaritList = _context.sent;\n _context.next = 17;\n break;\n\n case 13:\n this.id = 0;\n this.name = \"\";\n this.pageList = [];\n this.gabaritList = [];\n\n case 17:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function load() {\n return _load.apply(this, arguments);\n }\n\n return load;\n }(),\n remove: function remove() {\n this.$cms.updateFrame();\n this.$cms.resetNav();\n this.$cms.clearContainer();\n this.$cms.frameRemove(this.data.item);\n },\n save: function () {\n var _save = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2(data) {\n var frame, item;\n return regeneratorRuntime.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n _context2.next = 2;\n return this.$cms.updateFrame();\n\n case 2:\n if (this.isEntity && data && this.data.item.semantic.id_tag != data.dom_id) {\n destroyWidget(); // On a dupliquer le cadre\n\n frame = this.$cms.frames.find(function (frame) {\n return frame.name == data.name;\n });\n\n if (frame) {\n item = {\n item: frame,\n name: frame.name,\n type: \"frame\"\n };\n this.$cms.updateContainer(item);\n } else {\n // On n'a pas retrouver le nouveau cadre\n // On vide tout car des champs sont modifi�s par dojo � la sauvegarde/dupli\n this.$cms.resetNav();\n this.$cms.clearContainer();\n }\n }\n\n case 3:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2, this);\n }));\n\n function save(_x) {\n return _save.apply(this, arguments);\n }\n\n return save;\n }(),\n save_new_module: function () {\n var _save_new_module = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee3(data) {\n var frame, item;\n return regeneratorRuntime.wrap(function _callee3$(_context3) {\n while (1) {\n switch (_context3.prev = _context3.next) {\n case 0:\n // On vide la page\n this.$cms.resetNav();\n this.$cms.clearContainer();\n _context3.next = 4;\n return this.$cms.updateFrame();\n\n case 4:\n // Si on trouve le nouveau cadre cr�er on ouvre le formulaire\n frame = this.$cms.frames.find(function (frame) {\n return frame.semantic.id_tag == data.dom_id;\n });\n\n if (frame) {\n item = {\n item: frame,\n name: frame.name,\n type: \"frame\"\n };\n this.$cms.openItem(item);\n } else {\n destroyWidget();\n }\n\n case 6:\n case \"end\":\n return _context3.stop();\n }\n }\n }, _callee3, this);\n }));\n\n function save_new_module(_x2) {\n return _save_new_module.apply(this, arguments);\n }\n\n return save_new_module;\n }(),\n cancel: function cancel() {\n this.$cms.resetNav(true);\n this.$cms.clearContainer();\n },\n cancel_new_module: function cancel_new_module() {\n this.addForm = false;\n this.$nextTick(function () {\n // On supprime tout les widgets DOJO qui ont �t� cr��\n destroyWidget();\n });\n },\n cleanCache: function cleanCache() {\n if (this.isEntity && !this.isOpacFrame) {\n var promise = this.$cms.model.clearCacheFrame(this.data.item.semantic.id_tag);\n promise.then(function (response) {\n dojo.topic.publish('dGrowl', response.msg);\n });\n }\n },\n getPageList: function getPageList() {\n var _this$data$item$seman;\n\n return this.$cms.model.getPagesUsingFrame({\n idTag: (_this$data$item$seman = this.data.item.semantic.id_tag) !== null && _this$data$item$seman !== void 0 ? _this$data$item$seman : \"\"\n }) || [];\n },\n getGabaritList: function getGabaritList() {\n var _this$data$item$seman2;\n\n return this.$cms.model.getGabaritsUsingFrame({\n idTag: (_this$data$item$seman2 = this.data.item.semantic.id_tag) !== null && _this$data$item$seman2 !== void 0 ? _this$data$item$seman2 : \"\"\n }) || [];\n },\n removePage: function () {\n var _removePage = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee4(page) {\n var msg, result;\n return regeneratorRuntime.wrap(function _callee4$(_context4) {\n while (1) {\n switch (_context4.prev = _context4.next) {\n case 0:\n msg = this.$cms.getMessage('confirm_remove_frame_in_layout').replace('%s', page.name);\n\n if (!confirm(msg)) {\n _context4.next = 13;\n break;\n }\n\n _context4.next = 4;\n return this.$cms.pageRemoveFrame(page.id, this.data.item.semantic.id_tag);\n\n case 4:\n result = _context4.sent;\n\n if (result.error) {\n _context4.next = 13;\n break;\n }\n\n _context4.next = 8;\n return this.getPageList();\n\n case 8:\n this.pageList = _context4.sent;\n _context4.next = 11;\n return this.getGabaritList();\n\n case 11:\n this.gabaritList = _context4.sent;\n this.pagesWithoutFrame = this.getPagesWithoutFrame();\n\n case 13:\n case \"end\":\n return _context4.stop();\n }\n }\n }, _callee4, this);\n }));\n\n function removePage(_x3) {\n return _removePage.apply(this, arguments);\n }\n\n return removePage;\n }(),\n removeGabarit: function () {\n var _removeGabarit = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee5(gabarit) {\n var msg, result;\n return regeneratorRuntime.wrap(function _callee5$(_context5) {\n while (1) {\n switch (_context5.prev = _context5.next) {\n case 0:\n msg = this.$cms.getMessage('confirm_remove_frame_in_layout').replace('%s', gabarit.name);\n\n if (!confirm(msg)) {\n _context5.next = 13;\n break;\n }\n\n _context5.next = 4;\n return this.$cms.gabaritRemoveFrame(gabarit.id, this.data.item.semantic.id_tag);\n\n case 4:\n result = _context5.sent;\n\n if (result.error) {\n _context5.next = 13;\n break;\n }\n\n _context5.next = 8;\n return this.getPageList();\n\n case 8:\n this.pageList = _context5.sent;\n _context5.next = 11;\n return this.getGabaritList();\n\n case 11:\n this.gabaritList = _context5.sent;\n this.gabaritWithoutFrame = this.getGabaritsWithoutFrame();\n\n case 13:\n case \"end\":\n return _context5.stop();\n }\n }\n }, _callee5, this);\n }));\n\n function removeGabarit(_x4) {\n return _removeGabarit.apply(this, arguments);\n }\n\n return removeGabarit;\n }(),\n addPage: function addPage() {\n this.modalTitle = this.$cms.getMessage('add_frame_page');\n this.pagesWithoutFrame = this.getPagesWithoutFrame();\n this.gabaritWithoutFrame = [];\n this.showForm = true;\n },\n addGabarit: function addGabarit() {\n this.modalTitle = this.$cms.getMessage('add_frame_gabarit');\n this.gabaritWithoutFrame = this.getGabaritsWithoutFrame();\n this.pagesWithoutFrame = [];\n this.showForm = true;\n },\n closeForm: function closeForm() {\n this.showForm = false;\n },\n getPagesWithoutFrame: function getPagesWithoutFrame() {\n var pageIds = [];\n this.pageList.forEach(function (page) {\n return pageIds.push(page.id);\n });\n return this.$cms.pages.filter(function (page) {\n return pageIds.includes(page.id) == false;\n });\n },\n getGabaritsWithoutFrame: function getGabaritsWithoutFrame() {\n var gabaritIds = [];\n this.gabaritList.forEach(function (gabarit) {\n return gabaritIds.push(gabarit.id);\n });\n return this.$cms.gabarits.filter(function (gabarit) {\n return gabaritIds.includes(gabarit.id) == false;\n });\n },\n formSubmit: function () {\n var _formSubmit = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee6() {\n return regeneratorRuntime.wrap(function _callee6$(_context6) {\n while (1) {\n switch (_context6.prev = _context6.next) {\n case 0:\n _context6.next = 2;\n return this.getPageList();\n\n case 2:\n this.pageList = _context6.sent;\n _context6.next = 5;\n return this.getGabaritList();\n\n case 5:\n this.gabaritList = _context6.sent;\n this.closeForm();\n\n case 7:\n case \"end\":\n return _context6.stop();\n }\n }\n }, _callee6, this);\n }));\n\n function formSubmit() {\n return _formSubmit.apply(this, arguments);\n }\n\n return formSubmit;\n }(),\n openPage: function openPage(eventPage) {\n var page = this.$cms.pages.find(function (page) {\n return page.id == eventPage.id;\n });\n this.$cms.openItem({\n type: \"page\",\n name: page.name,\n item: page,\n subNav: false\n }, true);\n },\n openGabarit: function openGabarit(eventGabarit) {\n var gabarit = this.$cms.gabarits.find(function (gabarit) {\n return gabarit.id == eventGabarit.id;\n });\n this.$cms.openItem({\n type: \"gabarit\",\n name: gabarit.name,\n item: gabarit\n }, true);\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/frame/frameForm.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/frameList.vue?vue&type=script&lang=js&":
/*!*******************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/frameList.vue?vue&type=script&lang=js& ***!
\*******************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _layout_frameForm_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./layout/frameForm.vue */ \"./includes/templates/vuejs/portal/build/components/layout/frameForm.vue\");\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['list', 'title', 'is_entity'],\n components: {\n frame_form: _layout_frameForm_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"]\n },\n data: function data() {\n return {\n items: [],\n showFrameForm: false\n };\n },\n created: function created() {\n this.updateItems();\n\n if (this.is_entity) {\n this.$cms.refreshZones(this.$root.container.data.item);\n }\n },\n watch: {\n 'list': function list(newValue, oldValue) {\n this.list = newValue;\n this.updateItems();\n }\n },\n computed: {\n classements: function classements() {\n var default_classement = this.$cms.getMessage('default_classement');\n var classements = {};\n\n for (var index in this.items) {\n var frame = this.items[index];\n var classement = frame.classement && frame.classement != \"\" ? frame.classement : default_classement;\n\n if (!classements[classement]) {\n classements[classement] = {\n title: classement,\n children: []\n };\n }\n\n classements[classement].children.push(frame);\n }\n\n return classements;\n }\n },\n methods: {\n itemClicked: function itemClicked(item) {\n this.$cms.openItem({\n type: \"frame\",\n name: item.name,\n item: item\n }, true);\n },\n updateItems: function updateItems() {\n var _this = this;\n\n if (this.list instanceof Promise) {\n this.list.then(function (result) {\n _this.items = result;\n });\n } else {\n this.items = this.list;\n }\n },\n openFrameForm: function openFrameForm() {\n this.showFrameForm = true;\n },\n closeFrameForm: function closeFrameForm(event, submit) {\n var classList = event.target.classList;\n\n if (submit || classList.contains(\"portal-modal\") || classList.contains(\"close-form\") || classList.contains(\"fa-times\")) {\n this.showFrameForm = false;\n }\n },\n itemRemove: function itemRemove(frame) {\n if (this.isRemovable(frame)) {\n this.$emit('frameRemove', frame);\n }\n },\n isRemovable: function isRemovable(frame) {\n return frame['class'].toLowerCase().includes('framecmsmodel');\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/frameList.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue?vue&type=script&lang=js&":
/*!*****************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue?vue&type=script&lang=js& ***!
\*****************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _list_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../list.vue */ \"./includes/templates/vuejs/portal/build/components/list.vue\");\n/* harmony import */ var _frameList_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../frameList.vue */ \"./includes/templates/vuejs/portal/build/components/frameList.vue\");\n/* harmony import */ var _alertError_vue__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../alertError.vue */ \"./includes/templates/vuejs/portal/build/components/alertError.vue\");\n/* harmony import */ var _gabaritPageForm_vue__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./gabaritPageForm.vue */ \"./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue\");\n/* harmony import */ var _gabaritHeritage_vue__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./gabaritHeritage.vue */ \"./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue\");\nfunction _createForOfIteratorHelper(o) { if (typeof Symbol === \"undefined\" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (o = _unsupportedIterableToArray(o))) { var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var it, normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it[\"return\"] != null) it[\"return\"](); } finally { if (didErr) throw err; } } }; }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(n); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: [\"data\"],\n components: {\n list: _list_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"],\n alert_error: _alertError_vue__WEBPACK_IMPORTED_MODULE_2__[\"default\"],\n frame_list: _frameList_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n page_form: _gabaritPageForm_vue__WEBPACK_IMPORTED_MODULE_3__[\"default\"],\n gabarit_heritage: _gabaritHeritage_vue__WEBPACK_IMPORTED_MODULE_4__[\"default\"]\n },\n data: function data() {\n return {\n id: 0,\n name: \"\",\n isDefault: 0,\n errorMessage: \"\",\n frameList: [],\n pages_selected: [],\n showPageForm: false,\n legacy_layout: null,\n layouts_list: {}\n };\n },\n created: function created() {\n this.load();\n },\n watch: {\n \"data\": function data(newValue, oldValue) {\n this.load();\n }\n },\n computed: {\n inheritedModel: function inheritedModel() {\n var _this = this;\n\n var legacyElements = this.$cms.gabarits.filter(function (gabarit) {\n if (gabarit.legacy_layout) {\n return gabarit.legacy_layout.id == _this.id && gabarit.legacy_layout['class'] == _this.data.item['class'];\n }\n\n return false;\n });\n return legacyElements;\n },\n isEntity: function isEntity() {\n return this.data && this.data.item && this.data.item.id != 0;\n },\n pages: function pages() {\n var _this$getPages$filter,\n _this2 = this;\n\n return (_this$getPages$filter = this.getPages().filter(function (page) {\n return _this2.pages_selected.includes(page.id);\n })) !== null && _this$getPages$filter !== void 0 ? _this$getPages$filter : [];\n },\n title: function title() {\n var title = this.$cms.getMessage(\"heritage_has_frame\");\n\n if (this.frameList.length == 0) {\n title = this.$cms.getMessage(\"heritage_no_frame\");\n }\n\n return title;\n },\n listPageId: function listPageId() {\n var listId = [];\n\n var _iterator = _createForOfIteratorHelper(this.pages),\n _step;\n\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var page = _step.value;\n listId.push(page.id);\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n\n return listId;\n },\n pageIsAddable: function pageIsAddable() {\n return this.pages.length != this.$cms.pages.length;\n },\n cannotDelete: function cannotDelete() {\n var _this3 = this;\n\n var legacyElements = this.$cms.gabarits.findIndex(function (gabarit) {\n if (gabarit.legacy_layout) {\n return gabarit.legacy_layout.id == _this3.id && gabarit.legacy_layout['class'] == _this3.data.item['class'];\n }\n\n return false;\n });\n\n if (legacyElements !== -1) {\n return true;\n }\n\n return this.isDefaultGabarit;\n },\n isDefaultGabarit: function isDefaultGabarit() {\n return this.data && this.data.item && this.data.item[\"default\"] == 1;\n },\n hasLayoutsList: function hasLayoutsList() {\n return Object.keys(this.layouts_list).length > 0;\n }\n },\n methods: {\n getPages: function getPages() {\n var _this$$cms$pages;\n\n return (_this$$cms$pages = this.$cms.pages) !== null && _this$$cms$pages !== void 0 ? _this$$cms$pages : [];\n },\n closeError: function closeError() {\n this.errorMessage = \"\";\n },\n load: function load() {\n var _this4 = this;\n\n this.frameList = [];\n\n if (this.isEntity) {\n this.id = this.data.item.id;\n this.name = this.data.item.name;\n this.isDefault = this.data.item[\"default\"];\n this.legacy_layout = this.data.item.legacy_layout;\n this.getSelectedPages();\n this.layouts_list = this.data.item.layouts_list;\n var promise = this.$cms.model.getFramesInGabarit(this.id);\n promise.then(function (result) {\n if (result.error) {\n _this4.frameList = [];\n throw result.errorMessage;\n } else {\n _this4.frameList = result;\n }\n }, function () {\n _this4.frameList = [];\n });\n } else {\n this.id = 0;\n this.name = \"\";\n this.isDefault = 0;\n this.legacy_layout = null;\n this.pages_selected = [];\n this.layouts_list = {}; // Focus sur le premier input du formulaire\n\n this.$nextTick(function () {\n _this4.$refs.gabarit_input_name.focus();\n });\n }\n },\n getSelectedPages: function getSelectedPages() {\n var _this5 = this;\n\n if (!this.isEntity) {\n return;\n }\n\n this.pages_selected = [];\n this.$cms.getPagesUsingGabarit(this.id).forEach(function (page) {\n _this5.pages_selected.push(page.id);\n });\n },\n remove: function remove() {\n var _this6 = this;\n\n if (!this.isEntity) {\n retrun;\n }\n\n if (this.pages_selected.length > 0) {\n if (!confirm(this.$cms.getMessage(\"gabarit_confirm_delete_pages\"))) {\n return;\n }\n }\n\n if (confirm(this.$cms.getMessage(\"gabarit_confirm_delete\"))) {\n var promise = this.$cms.removeGabarit(this.id);\n promise.then(function (result) {\n if (result.error) {\n _this6.errorMessage = result.errorMessage;\n }\n });\n }\n },\n submit: function submit() {\n var _this$id,\n _this7 = this;\n\n if (this.pages) {\n var pages_selected = [];\n this.pages.forEach(function (page) {\n pages_selected.push(page.id);\n });\n this.pages_selected = pages_selected;\n }\n\n var legacy_layout = {\n 'id': 0,\n 'class': ''\n };\n\n if (this.legacy_layout != null) {\n legacy_layout = {\n 'id': this.legacy_layout.id,\n 'class': this.legacy_layout['class']\n };\n }\n\n var promise = this.$cms.updateGabarit({\n gabarit: {\n id: (_this$id = this.id) !== null && _this$id !== void 0 ? _this$id : 0,\n name: this.name,\n \"default\": this.isDefault,\n legacy_layout: legacy_layout\n },\n pages: this.pages_selected\n });\n promise.then(function (result) {\n if (result.error) {\n _this7.errorMessage = result.errorMessage;\n }\n });\n },\n frameRemove: function frameRemove(frame) {\n if (confirm(this.$cms.getMessage(\"layout_element_confirm_delete\"))) {\n this.$cms.removeElementLayout({\n item: frame,\n parent: null,\n gabarit_id: this.$cms.container.data.item.id\n });\n }\n },\n addPage: function addPage(pageId) {\n this.pages_selected.push(pageId);\n this.submit();\n },\n openPageForm: function openPageForm() {\n this.showPageForm = true;\n },\n closePageForm: function closePageForm(event, submit) {\n var classList = event.target.classList;\n\n if (submit || classList.contains(\"portal-modal\") || classList.contains(\"close-form\")) {\n this.showPageForm = false;\n }\n },\n openSubNav: function openSubNav(item) {\n this.$cms.openItem({\n item: item,\n name: item.name,\n type: \"pageSubNav\"\n });\n this.$cms.itemNavActive = 2;\n },\n duplicate: function duplicate() {\n var _this8 = this;\n\n if (!this.isEntity) {\n return false;\n }\n\n this.$cms.duplicateGabarit(this.id).then(function (response) {\n if (response) {\n dojo.topic.publish('dGrowl', _this8.$cms.getMessage('duplicate_successfully'));\n } else {\n dojo.topic.publish('dGrowl', _this8.$cms.getMessage('duplicate_failed'));\n }\n });\n },\n changeHeritage: function changeHeritage(gabarit) {\n this.legacy_layout = gabarit || null;\n },\n removeLayout: function removeLayout(index) {\n this.$cms.removeLayout({\n gabarit: this.id,\n layout: index\n });\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue?vue&type=script&lang=js&":
/*!*********************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue?vue&type=script&lang=js& ***!
\*********************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['data'],\n data: function data() {\n return {\n heritageSelected: \"\"\n };\n },\n mounted: function mounted() {\n this.heritageSelected = this.currentHeritage;\n },\n watch: {\n data: function data(newValue, OldValue) {\n if (newValue.item && newValue.item.legacy_layout && newValue.item.legacy_layout.id) {\n this.heritageSelected = newValue.item.legacy_layout.id;\n } else {\n this.heritageSelected = \"\";\n }\n }\n },\n computed: {\n currentHeritage: function currentHeritage() {\n if (this.data.item && this.data.item.legacy_layout && this.data.item.legacy_layout.id) {\n return this.data.item.legacy_layout.id;\n }\n\n return \"\";\n },\n id: function id() {\n return this.data.item && this.data.item.id ? this.data.item.id : 0;\n },\n heritageList: function heritageList() {\n var _this = this;\n\n var list = [];\n\n if (this.id) {\n this.$cms.gabarits.forEach(function (gabarit) {\n if (_this.id != gabarit.id) {\n var nextGabarit = gabarit.legacy_layout;\n var isLoop = false;\n\n while (nextGabarit && nextGabarit.id) {\n if (nextGabarit.id == _this.id) {\n isLoop = true;\n break;\n }\n\n nextGabarit = nextGabarit.legacy_layout;\n }\n\n if (!isLoop) {\n list.push(gabarit);\n }\n }\n });\n return list;\n } else {\n return this.$cms.gabarits;\n }\n }\n },\n methods: {\n changeHeritage: function changeHeritage() {\n var _this2 = this;\n\n var newHeritage = null;\n\n if (this.heritageSelected) {\n newHeritage = this.$cms.gabarits.find(function (gabarit) {\n return gabarit.id == _this2.heritageSelected;\n });\n }\n\n this.$emit('change', newHeritage);\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue?vue&type=script&lang=js&":
/*!*********************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue?vue&type=script&lang=js& ***!
\*********************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _alertError_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../alertError.vue */ \"./includes/templates/vuejs/portal/build/components/alertError.vue\");\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: [\"pagesSelected\"],\n components: {\n alert_error: _alertError_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"]\n },\n data: function data() {\n return {\n pageId: \"\",\n errorMessage: \"\",\n search: \"\",\n dragging: false,\n x: 0,\n y: 0,\n startX: 0,\n startY: 0,\n dragStyle: \"\"\n };\n },\n mounted: function mounted() {\n var _this = this;\n\n window.addEventListener('mouseup', this.stopDrag);\n window.addEventListener('mousemove', this.doDrag); // Focus sur le premier input du formulaire\n\n this.$nextTick(function () {\n _this.$refs.page_input_search.focus();\n });\n },\n computed: {\n filteredList: function filteredList() {\n var _this2 = this;\n\n var pages = this.$cms.cloneObject(this.$cms.pages);\n\n if (this.search != \"\") {\n var regex = new RegExp(this.search.trim(), 'i');\n pages = pages.filter(function (page) {\n return regex.exec(page.name.trim());\n });\n }\n\n pages = pages.filter(function (page) {\n return !_this2.pagesSelected.includes(page.id);\n });\n\n if (pages.length > 0) {\n this.pageId = pages[0].id;\n }\n\n return pages;\n }\n },\n methods: {\n submit: function submit(event) {\n event.preventDefault();\n this.$emit('addPage', this.pageId);\n },\n startDrag: function startDrag(event) {\n this.dragging = true;\n this.dragStyle = \"cursor: grabbing;\";\n this.startX = event.clientX;\n this.startY = event.clientY;\n },\n stopDrag: function stopDrag(event) {\n this.dragging = false;\n this.dragStyle = \"\";\n this.x = this.y = 0;\n },\n doDrag: function doDrag(event) {\n if (this.dragging) {\n this.x = this.startX - event.clientX;\n this.y = this.startY - event.clientY;\n this.startX = event.clientX;\n this.startY = event.clientY;\n this.$refs.modal_frame.style.position = \"absolute\";\n this.$refs.modal_frame.style.left = this.$refs.modal_frame.offsetLeft - this.x + \"px\";\n this.$refs.modal_frame.style.top = this.$refs.modal_frame.offsetTop - this.y + \"px\";\n }\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue?vue&type=script&lang=js&":
/*!******************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue?vue&type=script&lang=js& ***!
\******************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['parentAuto', 'item'],\n data: function data() {\n return {\n dragging: false,\n x: 0,\n y: 0,\n startX: 0,\n startY: 0,\n dragStyle: \"\"\n };\n },\n mounted: function mounted() {\n window.addEventListener('mouseup', this.stopDrag);\n window.addEventListener('mousemove', this.doDrag);\n },\n destroyed: function destroyed() {\n window.removeEventListener('mouseup', this.stopDrag);\n window.removeEventListener('mousemove', this.doDrag);\n },\n methods: {\n startDrag: function startDrag(event) {\n this.dragging = true;\n this.dragStyle = \"cursor: grabbing;\";\n this.startX = event.clientX;\n this.startY = event.clientY;\n },\n stopDrag: function stopDrag(event) {\n this.dragging = false;\n this.dragStyle = \"\";\n this.x = this.y = 0;\n },\n doDrag: function doDrag(event) {\n if (this.dragging) {\n this.x = this.startX - event.clientX;\n this.y = this.startY - event.clientY;\n this.startX = event.clientX;\n this.startY = event.clientY;\n this.$refs.modal_attribute.style.position = \"absolute\";\n this.$refs.modal_attribute.style.left = this.$refs.modal_attribute.offsetLeft - this.x + \"px\";\n this.$refs.modal_attribute.style.top = this.$refs.modal_attribute.offsetTop - this.y + \"px\";\n }\n },\n removeAttribute: function removeAttribute(name) {\n var i = this.item.semantic.attributes.findIndex(function (a) {\n return a.name == name;\n });\n this.item.semantic.attributes.splice(i, 1);\n },\n addAttribute: function addAttribute() {\n this.item.semantic.attributes.push({\n name: \"\",\n value: \"\"\n });\n },\n saveAttributes: function saveAttributes(e) {\n var parentClass = this.item[\"class\"];\n\n if (parentClass.toLowerCase().includes('frame')) {\n this.$cms.addFrameAttributes(this.item, this.item.semantic.attributes);\n } else {\n this.$cms.addZoneAttributes(this.item, this.item.semantic.attributes);\n }\n\n this.$emit('update', this.item);\n this.$emit('closeAttributeForm', e, true);\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue?vue&type=script&lang=js&":
/*!***************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue?vue&type=script&lang=js& ***!
\***************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\n\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(n); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && Symbol.iterator in Object(iter)) return Array.from(iter); }\n\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n name: \"class_css\",\n props: [\"classes\"],\n data: function data() {\n return {\n show: false,\n newClasses: \"\",\n classesList: []\n };\n },\n mounted: function mounted() {\n this.classesList = this.classes;\n },\n watch: {\n \"classes\": function classes(newValue, oldValue) {\n this.classesList = newValue;\n }\n },\n methods: {\n addClasses: function addClasses() {\n var classesList = this.newClasses.split(' ');\n\n for (var i = 0; i < classesList.length; i++) {\n var classe = classesList[i];\n\n if (classe[0] == \".\") {\n classesList[i] = classe.slice(1, classe.length).trim();\n }\n } // On regroupe toutes les classes\n\n\n classesList = [].concat(_toConsumableArray(this.classesList), _toConsumableArray(classesList)); // [...new Set(classesList)] == array_unique\n\n classesList = _toConsumableArray(new Set(classesList));\n\n if (classesList.join(\",\") != this.classesList.join(\",\")) {\n this.classesList = classesList;\n this.emitChange();\n }\n\n this.close();\n },\n close: function close() {\n this.newClasses = \"\";\n this.show = false;\n },\n open: function open() {\n var _this = this;\n\n this.show = true;\n this.$nextTick(function () {\n _this.$refs.input.focus();\n });\n },\n removeClass: function removeClass(index) {\n this.classesList.splice(index, 1);\n this.emitChange();\n },\n emitChange: function emitChange() {\n this.$emit('change_classes', this.classesList);\n },\n submit: function submit() {\n if (this.$refs.input.checkValidity()) {\n this.$refs.form.submit();\n }\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/commonParams.vue?vue&type=script&lang=js&":
/*!*****************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/commonParams.vue?vue&type=script&lang=js& ***!
\*****************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n name: \"common_params\",\n props: [\"id_tag\", \"parent\", \"children_parent\", \"placing_before\"],\n data: function data() {\n return {\n newParent: \"\",\n newPlacingBefore: \"\"\n };\n },\n computed: {\n // element correspond a une page ou un gabarit\n element: function element() {\n return this.$root.container && this.$root.container.data && this.$root.container.data.item ? this.$root.container.data.item : null;\n }\n },\n mounted: function mounted() {\n this.load();\n },\n beforeUpdate: function beforeUpdate() {\n this.load();\n },\n methods: {\n load: function load() {\n this.newParent = this.parent;\n this.newPlacingBefore = this.placing_before;\n },\n arrayOrderAlpha: function arrayOrderAlpha(list) {\n list.sort(function (a, b) {\n var titleA = a.name.toLowerCase();\n var titleB = b.name.toLowerCase();\n\n if (titleA < titleB) {\n return -1;\n }\n\n if (titleA > titleB) {\n return 1;\n }\n\n return 0;\n });\n return list;\n },\n isNotMe: function isNotMe(element) {\n return element && element.semantic.id_tag != this.id_tag;\n },\n emitChangeParent: function emitChangeParent() {\n this.$emit('change_parent', this.newParent);\n },\n emitChangeOrder: function emitChangeOrder() {\n this.$emit('change_order', this.newPlacingBefore);\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/commonParams.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/frame.vue?vue&type=script&lang=js&":
/*!**********************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/frame.vue?vue&type=script&lang=js& ***!
\**********************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _classesCSS_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./classesCSS.vue */ \"./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue\");\n/* harmony import */ var _commonParams_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./commonParams.vue */ \"./includes/templates/vuejs/portal/build/components/layout/commonParams.vue\");\n/* harmony import */ var _attributeForm_vue__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./attributeForm.vue */ \"./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue\");\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['frame', 'parent', 'parentHidden', 'showHidden', 'nextChild'],\n components: {\n class_css: _classesCSS_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"],\n common_params: _commonParams_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n attribute_form: _attributeForm_vue__WEBPACK_IMPORTED_MODULE_2__[\"default\"]\n },\n data: function data() {\n return {\n item: {\n \"class\": \"\",\n classement: \"\",\n id: 0,\n is_hidden: false,\n name: \"\",\n semantic: {\n \"class\": \"\",\n classes: [],\n id: 0,\n id_tag: \"\",\n tag: \"\",\n attributes: []\n }\n },\n currentParent: \"\",\n placingBefore: \"\",\n showAttributeForm: false\n };\n },\n created: function created() {\n this.load();\n },\n beforeUpdate: function beforeUpdate() {\n this.load();\n },\n computed: {\n isHidden: function isHidden() {\n return !this.parentHidden && this.item.is_hidden;\n },\n isActive: function isActive() {\n return !this.showHidden && !this.item.is_hidden || this.showHidden;\n },\n attributes: function attributes() {\n return this.item.semantic.attributes || [];\n }\n },\n methods: {\n load: function load() {\n this.item = this.$cms.cloneObject(this.frame);\n this.currentParent = this.parent;\n this.placingBefore = this.nextChild ? this.nextChild.semantic.id_tag : '';\n },\n changeClasses: function changeClasses(classes) {\n this.item.semantic.classes = classes;\n this.$cms.addFrameClasses(this.item, classes);\n this.update();\n },\n update: function update() {\n this.$emit('update', this.item);\n },\n updateParent: function updateParent(newParent) {\n this.currentParent = newParent;\n this.$emit('updateParent', this.currentParent);\n },\n updateOrder: function updateOrder(placingBefore) {\n this.placingBefore = placingBefore;\n\n if (placingBefore != \"\") {\n var newIndex = this.$parent.zone.children.findIndex(function (child) {\n return child.semantic.id_tag == placingBefore;\n });\n } else {\n var newIndex = this.$parent.zone.children.length;\n }\n\n if (0 <= newIndex && newIndex <= this.$parent.zone.children.length) {\n this.$emit('updateOrder', newIndex);\n }\n },\n updateTag: function updateTag() {\n this.$emit('updateTag', this.item.semantic.tag);\n },\n isNotMe: function isNotMe(frame) {\n return frame.semantic.id_tag != this.item.semantic.id_tag;\n },\n isFrameOpac: function isFrameOpac() {\n return this.frame[\"class\"].includes('FrameOpacModel');\n },\n pageOrGabarit: function pageOrGabarit() {\n return this.$root.container.data.item[\"class\"].includes('PagePortalModel') ? 'page_id' : 'gabarit_id';\n },\n hide: function hide() {\n var item = this.pageOrGabarit();\n this.$cms.hideElementLayout(_defineProperty({\n item: this.frame,\n parent: this.parent\n }, item, this.$root.container.data.item.id));\n },\n remove: function remove() {\n if (confirm(this.$cms.getMessage(\"layout_element_confirm_delete\"))) {\n var item = this.pageOrGabarit();\n this.$cms.removeElementLayout(_defineProperty({\n item: this.frame,\n parent: this.parent\n }, item, this.$root.container.data.item.id));\n }\n },\n openAttributeForm: function openAttributeForm(parent) {\n this.showAttributeForm = true;\n },\n closeAttributeForm: function closeAttributeForm(event, submit) {\n var classList = event.target.classList;\n\n if (submit || classList.contains(\"portal-modal\") || classList.contains(\"close-form\")) {\n this.showAttributeForm = false;\n }\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/frame.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/frameForm.vue?vue&type=script&lang=js&":
/*!**************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/frameForm.vue?vue&type=script&lang=js& ***!
\**************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _alertError_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../alertError.vue */ \"./includes/templates/vuejs/portal/build/components/alertError.vue\");\n/* harmony import */ var _semantics_semantics_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../semantics/semantics.vue */ \"./includes/templates/vuejs/portal/build/components/semantics/semantics.vue\");\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\n\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(n); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && Symbol.iterator in Object(iter)) return Array.from(iter); }\n\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }\n\nfunction _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err); } _next(undefined); }); }; }\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: [\"parentAuto\", \"view\"],\n components: {\n alert_error: _alertError_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"],\n semantics: _semantics_semantics_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"]\n },\n data: function data() {\n return {\n name: \"\",\n cadre_id: \"\",\n parent: \"\",\n semantic: {\n id: 0,\n \"class\": \"Pmb\\\\CMS\\\\Semantics\\\\HtmlSemantic\",\n classes: [],\n id_tag: \"\",\n tag: \"\"\n },\n errorMessage: \"\",\n framesAlreadyExist: [],\n search: \"\",\n dragging: false,\n x: 0,\n y: 0,\n startX: 0,\n startY: 0,\n dragStyle: \"\"\n };\n },\n mounted: function () {\n var _mounted = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {\n var _this = this;\n\n return regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n window.addEventListener('mouseup', this.stopDrag);\n window.addEventListener('mousemove', this.doDrag);\n _context.next = 4;\n return this.$cms.refreshZones(this.$root.container.data.item);\n\n case 4:\n this.getFramesAlreadyExist();\n this.parentAuto ? this.parent = this.parentAuto : this.parent = this.$cms.zoneList.filter(function (zone) {\n return zone.semantic.id_tag == \"container\";\n })[0].semantic.id_tag;\n this.semantic.tag = this.$cms.semantic[0]; // Focus sur le premier input du formulaire\n\n this.$nextTick(function () {\n _this.$refs.frame_input_search.focus();\n });\n\n case 8:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function mounted() {\n return _mounted.apply(this, arguments);\n }\n\n return mounted;\n }(),\n destroyed: function destroyed() {\n window.removeEventListener('mouseup', this.stopDrag);\n window.removeEventListener('mousemove', this.doDrag);\n },\n computed: {\n filteredList: function filteredList() {\n var _this2 = this;\n\n if (!this.frameList) {\n return [];\n }\n\n var list = this.$cms.cloneObject(this.frameList);\n\n if (this.search != \"\") {\n var classement;\n\n (function () {\n var regexDefault = new RegExp(_this2.search.trim(), 'i');\n var regexID = new RegExp(\"_\".concat(_this2.search.trim(), \"$\"), 'i');\n var DEFAULT_SEARCH = 0;\n var SEARCH_BY_NODE_ID = 1;\n var SEARCH_BY_ID = 2;\n var search;\n\n if (_this2.search.match('cms_module_')) {\n search = SEARCH_BY_NODE_ID;\n } else if (!isNaN(_this2.search)) {\n search = SEARCH_BY_ID;\n } else {\n search = DEFAULT_SEARCH;\n }\n\n var search_id = _this2.search.match('cms_module_') ? true : false;\n\n for (classement in list) {\n switch (search) {\n case SEARCH_BY_NODE_ID:\n list[classement] = list[classement].filter(function (child) {\n return child.semantic.id_tag == _this2.search.trim();\n });\n break;\n\n case SEARCH_BY_ID:\n var search1 = list[classement].filter(function (child) {\n return regexID.exec(child.semantic.id_tag);\n });\n var search2 = list[classement].filter(function (child) {\n return regexDefault.exec(child.name.trim());\n });\n list[classement] = [].concat(_toConsumableArray(search1), _toConsumableArray(search2));\n break;\n\n case DEFAULT_SEARCH:\n default:\n list[classement] = list[classement].filter(function (child) {\n return regexDefault.exec(child.name.trim());\n });\n break;\n }\n }\n })();\n }\n\n var orderList = {};\n var orderKeys = this.arrayOrderAlpha(Object.keys(list));\n\n if (orderKeys.length == 0) {\n return list;\n }\n\n for (var i = 0; i < orderKeys.length; i++) {\n var index = orderKeys[i];\n orderList[index] = this.arrayOrderAlpha(list[index]);\n }\n\n var key = orderKeys[0];\n\n if (orderList[key].length > 0) {\n this.cadre_id = orderList[key][0].semantic.id_tag;\n this.name = orderList[key][0].name;\n }\n\n return list;\n },\n framesAlreadyUsed: function framesAlreadyUsed() {\n var frames = [];\n\n for (var i = 0; i < this.framesAlreadyExist.length; i++) {\n if (this.framesAlreadyExist[i]['class'].includes(\"FrameCMSModel\")) {\n frames.push(this.framesAlreadyExist[i].semantic.id_tag);\n }\n }\n\n return frames;\n },\n frameList: function frameList() {\n var default_classement = this.$cms.getMessage('default_classement');\n var frames = {};\n\n for (var index in this.$cms.frames) {\n var frame = this.$cms.frames[index];\n\n if (this.framesAlreadyUsed.includes(frame.semantic.id_tag)) {\n continue;\n }\n\n if (frame && frame[\"class\"].includes('FrameOpac')) {\n continue;\n }\n\n var classement = frame.classement && frame.classement != \"\" ? frame.classement : default_classement;\n\n if (!frames[classement]) {\n frames[classement] = [];\n }\n\n frames[classement].push(frame);\n }\n\n return frames;\n }\n },\n methods: {\n getPageOrGabarit: function getPageOrGabarit() {\n return this.$root.container.data.item[\"class\"].includes('PagePortalModel') ? 'page_id' : 'gabarit_id';\n },\n submit: function submit(event) {\n var _this3 = this;\n\n event.preventDefault();\n var item = this.getPageOrGabarit();\n var promise = this.$cms.addElementlayout(_defineProperty({\n name: this.name,\n cadre_id: this.cadre_id,\n parent: this.parent,\n \"class\": \"Pmb\\\\CMS\\\\Models\\\\FrameCMSModel\",\n semantic: this.semantic\n }, item, this.$root.container.data.item.id), this.view);\n promise.then(function (result) {\n if (!result.error) {\n _this3.$emit('closeFrameForm', event, true);\n } else {\n _this3.errorMessage = result.errorMessage;\n }\n });\n },\n changeName: function changeName(event) {\n this.name = event.target.options[event.target.selectedIndex].text;\n },\n updateSemantic: function updateSemantic(semanticUpdated) {\n this.semantic = semanticUpdated;\n },\n arrayOrderAlpha: function arrayOrderAlpha(array) {\n array.sort(function (a, b) {\n var titleA = a.name ? a.name.toLowerCase() : \"\";\n var titleB = b.name ? b.name.toLowerCase() : \"\";\n\n if (titleA < titleB) {\n return -1;\n }\n\n if (titleA > titleB) {\n return 1;\n }\n\n return 0;\n });\n return array;\n },\n getFramesAlreadyExist: function getFramesAlreadyExist() {\n var _this4 = this;\n\n var id = this.$cms.container.data.item.id;\n var className = this.$cms.container.data.item[\"class\"];\n\n if (className == \"Pmb\\\\CMS\\\\Models\\\\PagePortalModel\") {\n var promise = this.$cms.model.getFramesInPage(id);\n } else {\n var promise = this.$cms.model.getFramesInGabarit(id);\n }\n\n promise.then(function (result) {\n if (result.error) {\n _this4.framesAlreadyExist = [];\n throw result.errorMessage;\n } else {\n _this4.framesAlreadyExist = result;\n }\n }, function () {\n _this4.framesAlreadyExist = [];\n });\n },\n startDrag: function startDrag(event) {\n this.dragging = true;\n this.dragStyle = \"cursor: grabbing;\";\n this.startX = event.clientX;\n this.startY = event.clientY;\n },\n stopDrag: function stopDrag(event) {\n this.dragging = false;\n this.dragStyle = \"\";\n this.x = this.y = 0;\n },\n doDrag: function doDrag(event) {\n if (this.dragging) {\n this.x = this.startX - event.clientX;\n this.y = this.startY - event.clientY;\n this.startX = event.clientX;\n this.startY = event.clientY;\n this.$refs.modal_frame.style.position = \"absolute\";\n this.$refs.modal_frame.style.left = this.$refs.modal_frame.offsetLeft - this.x + \"px\";\n this.$refs.modal_frame.style.top = this.$refs.modal_frame.offsetTop - this.y + \"px\";\n }\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/frameForm.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/layout.vue?vue&type=script&lang=js&":
/*!***********************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/layout.vue?vue&type=script&lang=js& ***!
\***********************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _zone_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./zone.vue */ \"./includes/templates/vuejs/portal/build/components/layout/zone.vue\");\n/* harmony import */ var _zoneForm_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./zoneForm.vue */ \"./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue\");\n/* harmony import */ var _frameForm_vue__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./frameForm.vue */ \"./includes/templates/vuejs/portal/build/components/layout/frameForm.vue\");\n/* harmony import */ var _page_pageHeritage_vue__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../page/pageHeritage.vue */ \"./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue\");\n/* harmony import */ var _shareLayout_vue__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./shareLayout.vue */ \"./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue\");\nfunction asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }\n\nfunction _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err); } _next(undefined); }); }; }\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['data'],\n components: {\n zone: _zone_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"],\n page_heritage: _page_pageHeritage_vue__WEBPACK_IMPORTED_MODULE_3__[\"default\"],\n zone_form: _zoneForm_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n frame_form: _frameForm_vue__WEBPACK_IMPORTED_MODULE_2__[\"default\"],\n share_layout: _shareLayout_vue__WEBPACK_IMPORTED_MODULE_4__[\"default\"]\n },\n data: function data() {\n return {\n container: {\n \"class\": \"\",\n id: 0,\n is_hidden: false,\n is_edited: false,\n name: \"\",\n children: [],\n semantic: {\n \"class\": \"\",\n classes: [],\n id: 0,\n id_tag: \"\",\n tag: \"\",\n attributes: []\n },\n tree: []\n },\n zoneList: [],\n showHidden: false,\n showZoneForm: false,\n showFrameForm: false,\n showAttributeForm: false,\n parent: null,\n shareLayoutResult: {}\n };\n },\n watch: {\n \"data\": function data(newValue, oldValue) {\n this.load();\n }\n },\n created: function created() {\n this.load();\n },\n computed: {\n isPage: function isPage() {\n return this.data.item['class'] == \"Pmb\\\\CMS\\\\Models\\\\PagePortalModel\";\n },\n containerCSS: function containerCSS() {\n var classeCss = \"portal-layout-container\";\n\n if (this.data.item.legacy_layout) {\n classeCss += \" has-parent-layout\";\n }\n\n return classeCss;\n }\n },\n methods: {\n load: function () {\n var _load = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {\n return regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n if (this.data.item == undefined) {\n this.data.item = {};\n }\n\n if (!(this.data.item && this.data.item.id != 0 && this.data.item.tree.length == 0)) {\n _context.next = 5;\n break;\n }\n\n _context.next = 4;\n return this.$cms.fecthLayout(this.data.item);\n\n case 4:\n this.data.item.tree = _context.sent;\n\n case 5:\n if (this.data.item.tree) {\n this.container = this.$cms.cloneObject(this.data.item.tree);\n }\n\n this.$cms.refreshZones(this.$root.container.data.item);\n\n case 7:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function load() {\n return _load.apply(this, arguments);\n }\n\n return load;\n }(),\n closeZoneForm: function closeZoneForm(event, submit) {\n var classList = event.target.classList;\n\n if (submit || classList.contains(\"portal-modal\") || classList.contains(\"close-form\")) {\n this.showZoneForm = false;\n }\n },\n closeFrameForm: function closeFrameForm(event, submit) {\n var classList = event.target.classList;\n\n if (submit || classList.contains(\"portal-modal\") || classList.contains(\"close-form\")) {\n this.showFrameForm = false;\n this.parent = null;\n }\n },\n zoneCreated: function zoneCreated(event, submit) {\n this.closeZoneForm.apply(this, arguments);\n this.$cms.refreshZones(this.$root.container.data.item);\n },\n openFrameForm: function openFrameForm(parent) {\n if (typeof parent === 'string') {\n this.parent = parent;\n }\n\n this.showFrameForm = true;\n },\n openZoneForm: function openZoneForm(parent) {\n if (typeof parent === 'string') {\n this.parent = parent;\n }\n\n this.showZoneForm = true;\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/layout.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue?vue&type=script&lang=js&":
/*!****************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue?vue&type=script&lang=js& ***!
\****************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _alertError_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../alertError.vue */ \"./includes/templates/vuejs/portal/build/components/alertError.vue\");\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n components: {\n alert_error: _alertError_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"]\n },\n data: function data() {\n var _this = this;\n\n return {\n x: 0,\n y: 0,\n startX: 0,\n startY: 0,\n dragStyle: \"\",\n show: false,\n result: {\n detail: {},\n error: false,\n errorMessage: \"\"\n },\n open: function open(event) {\n _this.show = true;\n _this.result = event.detail || {};\n },\n hidden: function hidden(event) {\n _this.show = false;\n _this.result = {};\n }\n };\n },\n computed: {\n errorMessage: function errorMessage() {\n return this.result && this.result.error ? this.result.errorMessage : \"\";\n },\n details: function details() {\n return this.result && this.result.details ? this.result.details : [];\n }\n },\n mounted: function mounted() {\n window.addEventListener(\"showShareLayout\", this.open.bind(this));\n window.addEventListener(\"hiddenShareLayout\", this.hidden.bind(this));\n window.addEventListener('mouseup', this.stopDrag);\n window.addEventListener('mousemove', this.doDrag);\n },\n destroyed: function destroyed() {\n window.removeEventListener(\"showShareLayout\", this.open.bind(this));\n window.removeEventListener(\"hiddenShareLayout\", this.hidden.bind(this));\n window.removeEventListener('mouseup', this.stopDrag);\n window.removeEventListener('mousemove', this.doDrag);\n },\n methods: {\n hiddenModal: function hiddenModal() {\n this.show = false;\n },\n startDrag: function startDrag(event) {\n this.dragging = true;\n this.dragStyle = \"cursor: grabbing;\";\n this.startX = event.clientX;\n this.startY = event.clientY;\n },\n stopDrag: function stopDrag(event) {\n this.dragging = false;\n this.dragStyle = \"\";\n this.x = this.y = 0;\n },\n doDrag: function doDrag(event) {\n if (this.dragging) {\n this.x = this.startX - event.clientX;\n this.y = this.startY - event.clientY;\n this.startX = event.clientX;\n this.startY = event.clientY;\n this.$refs.modal_zone.style.position = \"absolute\";\n this.$refs.modal_zone.style.left = this.$refs.modal_zone.offsetLeft - this.x + \"px\";\n this.$refs.modal_zone.style.top = this.$refs.modal_zone.offsetTop - this.y + \"px\";\n }\n }\n }\n});\n\nwindow.showShareLayout = function (data) {\n window.dispatchEvent(new CustomEvent(\"showShareLayout\", {\n detail: _objectSpread({}, data)\n }));\n};\n\nwindow.hiddenShareLayout = function (data) {\n window.dispatchEvent(new CustomEvent(\"hiddenShareLayout\", {\n detail: _objectSpread({}, data)\n }));\n};\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/zone.vue?vue&type=script&lang=js&":
/*!*********************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/zone.vue?vue&type=script&lang=js& ***!
\*********************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _frame_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./frame.vue */ \"./includes/templates/vuejs/portal/build/components/layout/frame.vue\");\n/* harmony import */ var _classesCSS_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./classesCSS.vue */ \"./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue\");\n/* harmony import */ var _commonParams_vue__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./commonParams.vue */ \"./includes/templates/vuejs/portal/build/components/layout/commonParams.vue\");\n/* harmony import */ var _attributeForm_vue__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./attributeForm.vue */ \"./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue\");\nfunction asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }\n\nfunction _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err); } _next(undefined); }); }; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n name: \"zone\",\n props: ['root', 'zone', 'parent', 'parentHidden', 'showHidden', 'nextChild'],\n components: {\n frame: _frame_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"],\n class_css: _classesCSS_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n common_params: _commonParams_vue__WEBPACK_IMPORTED_MODULE_2__[\"default\"],\n attribute_form: _attributeForm_vue__WEBPACK_IMPORTED_MODULE_3__[\"default\"]\n },\n data: function data() {\n return {\n item: {\n \"class\": \"\",\n id: 0,\n is_hidden: false,\n is_edited: false,\n name: \"\",\n children: [],\n semantic: {\n \"class\": \"\",\n classes: [],\n id: 0,\n id_tag: \"\",\n tag: \"\",\n attributes: []\n }\n },\n classes: [],\n currentParent: \"\",\n placingBefore: \"\",\n showAttributeForm: false\n };\n },\n created: function created() {\n this.load();\n },\n beforeUpdate: function beforeUpdate() {\n this.load();\n },\n watch: {\n zone: function zone(newValue, oldValue) {\n this.item = this.$cms.cloneObject(newValue);\n },\n parent: function parent(newValue, oldValue) {\n this.currentParent = newValue;\n },\n nextChild: function nextChild(newValue, oldValue) {\n this.placingBefore = newValue ? newValue.semantic.id_tag : '';\n }\n },\n computed: {\n isHidden: function isHidden() {\n return !this.parentHidden && this.item.is_hidden;\n },\n isActive: function isActive() {\n return !this.showHidden && !this.item.is_hidden || this.showHidden;\n },\n isRemovable: function isRemovable() {\n return !this.isZoneOpac() && !this.$cms.haveElementOpac(this.item);\n },\n deleteLabel: function deleteLabel() {\n return !this.isRemovable ? this.$cms.getMessage(\"confirm_remove_zone_has_element_opac\") : \"\";\n },\n attributes: function attributes() {\n return this.item.semantic.attributes || [];\n },\n classeCss: function classeCss() {\n var classeCss = \"portal-zone\";\n\n if (this.item.is_edited) {\n classeCss += \" portal-zone-edited\";\n }\n\n return classeCss;\n }\n },\n methods: {\n load: function load() {\n this.item = this.$cms.cloneObject(this.zone);\n this.currentParent = this.parent;\n this.placingBefore = this.nextChild ? this.nextChild.semantic.id_tag : '';\n },\n changeClasses: function changeClasses(classes) {\n this.item.semantic.classes = classes;\n this.$cms.addZoneClasses(this.item, classes);\n this.update();\n },\n update: function update() {\n this.$emit('update', this.item);\n },\n updateParent: function updateParent(newParent) {\n this.currentParent = newParent;\n this.$emit('updateParent', this.currentParent);\n },\n updateOrder: function updateOrder(placingBefore) {\n this.placingBefore = placingBefore;\n var newIndex = null;\n\n if (placingBefore != \"\") {\n newIndex = this.$parent.zone.children.findIndex(function (child) {\n return child.semantic.id_tag == placingBefore;\n });\n } else {\n newIndex = this.$parent.zone.children.length;\n }\n\n if (0 <= newIndex && newIndex <= this.$parent.zone.children.length) {\n this.$emit('updateOrder', newIndex);\n }\n },\n updateTag: function updateTag() {\n this.$emit('updateTag', this.item.semantic.tag);\n },\n updateChild: function updateChild(index, child) {\n this.item.children[index] = child;\n this.update();\n },\n updateChildParent: function updateChildParent(indexElement, newParent) {\n var index = this.getPageOrGabarit();\n this.$cms.updateParent(_defineProperty({\n parent: this.item,\n index_element: indexElement,\n new_parent: newParent\n }, index, this.$root.container.data.item.id));\n },\n updateChildTag: function updateChildTag(indexElement, newTag) {\n var index = this.getPageOrGabarit();\n this.$cms.updateTagElementLayout(_defineProperty({\n parent: this.item,\n index_element: indexElement,\n tag_element: newTag\n }, index, this.$root.container.data.item.id));\n },\n updateChildOrder: function updateChildOrder(indexElement, newIndexChild) {\n var index = this.getPageOrGabarit();\n this.$cms.updateParent(_defineProperty({\n parent: this.item,\n index_element: indexElement,\n new_index_element: newIndexChild,\n new_parent: this.item.semantic.id_tag\n }, index, this.$root.container.data.item.id));\n },\n getPageOrGabarit: function getPageOrGabarit() {\n return this.$root.container.data.item[\"class\"].includes('PagePortalModel') ? 'page_id' : 'gabarit_id';\n },\n hide: function hide() {\n var index = this.getPageOrGabarit();\n this.$cms.hideElementLayout(_defineProperty({\n item: this.zone,\n parent: this.parent\n }, index, this.$root.container.data.item.id));\n },\n remove: function remove() {\n if (confirm(this.$cms.getMessage(\"layout_element_confirm_delete\"))) {\n if (this.$cms.haveElementOpac(this.zone)) {\n confirm(this.$cms.getMessage(\"confirm_remove_zone_has_element_opac\"));\n return false;\n }\n\n if (this.zone.children.length && !confirm(this.$cms.getMessage(\"confirm_remove_zone_has_children\"))) {\n return false;\n }\n\n var index = this.getPageOrGabarit();\n this.$cms.removeElementLayout(_defineProperty({\n item: this.zone,\n parent: this.parent\n }, index, this.$root.container.data.item.id));\n }\n },\n isZoneOpac: function isZoneOpac() {\n return this.zone[\"class\"].includes('ZoneOpacModel');\n },\n getNextChildren: function getNextChildren(currentIndex) {\n var nextIndex = currentIndex + 1;\n\n if (nextIndex == this.item.children.length) {\n return null;\n }\n\n return this.item.children[nextIndex] ? this.item.children[nextIndex] : null;\n },\n openFrameForm: function openFrameForm(parent) {\n this.$emit('openFrameForm', parent);\n },\n openZoneForm: function openZoneForm(parent) {\n this.$emit('openZoneForm', parent);\n },\n openAttributeForm: function openAttributeForm(parent) {\n this.showAttributeForm = true;\n },\n closeAttributeForm: function closeAttributeForm(event, submit) {\n var classList = event.target.classList;\n\n if (submit || classList.contains(\"portal-modal\") || classList.contains(\"close-form\")) {\n this.showAttributeForm = false;\n }\n },\n shareLayout: function () {\n var _shareLayout = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {\n var shareLayoutResult;\n return regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n _context.next = 2;\n return this.$cms.shareLayout(this.$root.container.data.item, this.item);\n\n case 2:\n shareLayoutResult = _context.sent;\n if (typeof showShareLayout == \"function\") showShareLayout(shareLayoutResult);\n\n case 4:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function shareLayout() {\n return _shareLayout.apply(this, arguments);\n }\n\n return shareLayout;\n }()\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/zone.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue?vue&type=script&lang=js&":
/*!*************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue?vue&type=script&lang=js& ***!
\*************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _alertError_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../alertError.vue */ \"./includes/templates/vuejs/portal/build/components/alertError.vue\");\n/* harmony import */ var _semantics_semantics_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../semantics/semantics.vue */ \"./includes/templates/vuejs/portal/build/components/semantics/semantics.vue\");\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: [\"parentAuto\"],\n components: {\n alert_error: _alertError_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"],\n semantics: _semantics_semantics_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"]\n },\n data: function data() {\n return {\n name: \"\",\n parent: \"\",\n semantic: {\n id: 0,\n \"class\": \"\",\n classes: [],\n id_tag: \"\",\n tag: \"\"\n },\n errorMessage: \"\",\n dragging: false,\n x: 0,\n y: 0,\n startX: 0,\n startY: 0,\n dragStyle: \"\"\n };\n },\n mounted: function mounted() {\n var _this = this;\n\n window.addEventListener('mouseup', this.stopDrag);\n window.addEventListener('mousemove', this.doDrag);\n this.parentAuto ? this.parent = this.parentAuto : this.parent = this.$cms.zoneList[0].semantic.id_tag; // Focus sur le premier input du formulaire\n\n this.$nextTick(function () {\n _this.$refs.zone_input_name.focus();\n });\n },\n destroyed: function destroyed() {\n window.removeEventListener('mouseup', this.stopDrag);\n window.removeEventListener('mousemove', this.doDrag);\n },\n methods: {\n getPageOrGabarit: function getPageOrGabarit() {\n return this.$root.container.data.item[\"class\"].includes('PagePortalModel') ? 'page_id' : 'gabarit_id';\n },\n submit: function submit(event) {\n var _this2 = this;\n\n var item = this.getPageOrGabarit();\n var promise = this.$cms.addElementlayout(_defineProperty({\n name: this.name,\n parent: this.parent,\n \"class\": \"Pmb\\\\CMS\\\\Models\\\\ZoneCMSModel\",\n semantic: this.semantic\n }, item, this.$root.container.data.item.id), \"layout\");\n promise.then(function (result) {\n if (!result.error) {\n _this2.$emit('submitForm', event, true);\n }\n });\n },\n updateSemantic: function updateSemantic(semanticUpdated) {\n this.semantic = semanticUpdated;\n },\n startDrag: function startDrag(event) {\n this.dragging = true;\n this.dragStyle = \"cursor: grabbing;\";\n this.startX = event.clientX;\n this.startY = event.clientY;\n },\n stopDrag: function stopDrag(event) {\n this.dragging = false;\n this.dragStyle = \"\";\n this.x = this.y = 0;\n },\n doDrag: function doDrag(event) {\n if (this.dragging) {\n this.x = this.startX - event.clientX;\n this.y = this.startY - event.clientY;\n this.startX = event.clientX;\n this.startY = event.clientY;\n this.$refs.modal_zone.style.position = \"absolute\";\n this.$refs.modal_zone.style.left = this.$refs.modal_zone.offsetLeft - this.x + \"px\";\n this.$refs.modal_zone.style.top = this.$refs.modal_zone.offsetTop - this.y + \"px\";\n }\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/list.vue?vue&type=script&lang=js&":
/*!**************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/list.vue?vue&type=script&lang=js& ***!
\**************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['list', 'title', 'empty_msg', 'removable', 'addable', 'add_msg'],\n data: function data() {\n return {\n items: []\n };\n },\n created: function created() {\n this.updateItems();\n },\n watch: {\n 'list': function list(newValue, oldValue) {\n this.list = newValue;\n this.updateItems();\n }\n },\n computed: {\n isRemovable: function isRemovable() {\n return this.removable == \"true\" || this.removable == true ? true : false;\n },\n isAddable: function isAddable() {\n return this.addable == \"true\" || this.addable == true ? true : false;\n }\n },\n methods: {\n add: function add() {\n if (this.isAddable) {\n this.$emit('add', true);\n }\n },\n itemClicked: function itemClicked(item) {\n this.$emit('itemClicked', item);\n },\n itemRemove: function itemRemove(item) {\n if (this.isRemovable) {\n this.$emit('itemRemove', item);\n }\n },\n updateItems: function updateItems() {\n var _this = this;\n\n if (this.list instanceof Promise) {\n this.list.then(function (result) {\n _this.items = result;\n });\n } else {\n this.items = this.list;\n }\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/list.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/loader.vue?vue&type=script&lang=js&":
/*!****************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/loader.vue?vue&type=script&lang=js& ***!
\****************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['message'],\n data: function data() {\n return {\n show: false\n };\n },\n created: function created() {\n var _this = this;\n\n window.addEventListener(\"showLoader\", function () {\n _this.showLoader();\n });\n window.addEventListener(\"hiddenLoader\", function () {\n _this.hiddenLoader();\n });\n },\n methods: {\n showLoader: function showLoader() {\n this.show = true;\n },\n hiddenLoader: function hiddenLoader() {\n this.show = false;\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/loader.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/nav/nav.vue?vue&type=script&lang=js&":
/*!*****************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/nav/nav.vue?vue&type=script&lang=js& ***!
\*****************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _navItem_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./navItem.vue */ \"./includes/templates/vuejs/portal/build/components/nav/navItem.vue\");\n/* harmony import */ var _subNav_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./subNav.vue */ \"./includes/templates/vuejs/portal/build/components/nav/subNav.vue\");\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n name: \"navigation\",\n props: [\"subItem\"],\n components: {\n nav_item: _navItem_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"],\n sub_nav: _subNav_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"]\n },\n data: function data() {\n return {};\n },\n mounted: function mounted() {\n var _this = this;\n\n this.$nextTick(function () {\n var parser = dojo.require('dojo.parser');\n\n parser.parse();\n var node = document.getElementById('clean_cache_button');\n\n if (node) {\n node.title = _this.formatString(_this.$cms.clean_cache.title);\n node.addEventListener('click', function () {\n if (confirm(_this.$cms.clean_cache.confirm)) {\n cms_clean_cache();\n node.title = \"\";\n }\n });\n }\n\n node = document.getElementById('clean_cache_button_img');\n\n if (node) {\n node.addEventListener('click', function () {\n if (confirm(_this.$cms.clean_cache_img.confirm)) {\n cms_clean_img_cache();\n }\n });\n }\n });\n },\n computed: {\n items: function items() {\n var items = [];\n\n for (var index in this.$cms.itemsNav) {\n items.push(this.$cms.itemsNav[index]);\n }\n\n return items;\n },\n itemActive: function itemActive() {\n return this.items[this.$cms.itemNavActive];\n }\n },\n beforeUpdate: function beforeUpdate() {\n if (this.items.length > 0) {\n if (this.$cms.itemNavActive == -1) {\n this.$cms.itemNavActive = 0;\n }\n\n if (!(JSON.stringify(this.$cms.container.component) === JSON.stringify(this.itemActive))) {\n this.$cms.container = this.itemActive;\n }\n }\n },\n methods: {\n changeActive: function changeActive(index) {\n if (this.$cms.itemNavActive != index) {\n this.$cms.itemNavActive = index;\n }\n\n this.$cms.container = this.itemActive;\n },\n closeSubNav: function closeSubNav(index) {\n this.$cms.itemsNav.splice(index, 1);\n\n if (this.$cms.itemNavActive == index) {\n this.$cms.itemNavActive = index - 1;\n }\n },\n formatString: function formatString(encodedStr) {\n var parser = new DOMParser(); // convertie les \"é\" en \"�\", etc.\n\n var dom = parser.parseFromString(encodedStr, 'text/html'); // remplace les multiples espaces en 1 seul\n\n var str = dom.body.textContent.replace(/(\\s){2,}/gm, ' ');\n return str.trim();\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/nav/nav.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/nav/navItem.vue?vue&type=script&lang=js&":
/*!*********************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/nav/navItem.vue?vue&type=script&lang=js& ***!
\*********************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['item', 'isActive', 'index']\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/nav/navItem.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/nav/subNav.vue?vue&type=script&lang=js&":
/*!********************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/nav/subNav.vue?vue&type=script&lang=js& ***!
\********************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _navItem_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./navItem.vue */ \"./includes/templates/vuejs/portal/build/components/nav/navItem.vue\");\nfunction _createForOfIteratorHelper(o) { if (typeof Symbol === \"undefined\" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (o = _unsupportedIterableToArray(o))) { var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var it, normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it[\"return\"] != null) it[\"return\"](); } finally { if (didErr) throw err; } } }; }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(n); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n name: \"sous_navigation\",\n props: [\"item\"],\n components: {\n nav_item: _navItem_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"]\n },\n data: function data() {\n return {\n navActive: \"\"\n };\n },\n created: function created() {\n this.navActive = 0;\n },\n computed: {\n items: function items() {\n var items = [];\n\n var _iterator = _createForOfIteratorHelper(this.item.subNav),\n _step;\n\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var item = _step.value;\n items.push(item);\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n\n return items;\n },\n itemActive: function itemActive() {\n return this.items[this.navActive];\n }\n },\n beforeUpdate: function beforeUpdate() {\n if (this.items.length > 0) {\n if (this.navActive == -1) {\n this.navActive = 0;\n }\n\n if (!(JSON.stringify(this.$cms.container.component) === JSON.stringify(this.itemActive))) {\n this.$cms.container = this.itemActive;\n }\n }\n },\n methods: {\n changeActive: function changeActive(index) {\n if (this.navActive != index) {\n this.navActive = index;\n }\n\n this.$cms.container = this.itemActive;\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/nav/subNav.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue?vue&type=script&lang=js&":
/*!**************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue?vue&type=script&lang=js& ***!
\**************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\nfunction _createForOfIteratorHelper(o) { if (typeof Symbol === \"undefined\" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (o = _unsupportedIterableToArray(o))) { var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); } var it, normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it[\"return\"] != null) it[\"return\"](); } finally { if (didErr) throw err; } } }; }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(n); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: [\"data\"],\n data: function data() {\n return {\n id: 0,\n name: \"\",\n summary: \"\",\n vars: [{\n name: \"\",\n comment: \"\"\n }],\n dragging: false,\n x: 0,\n y: 0,\n startX: 0,\n startY: 0,\n dragStyle: \"\"\n };\n },\n mounted: function mounted() {\n var _this = this;\n\n window.addEventListener('mouseup', this.stopDrag);\n window.addEventListener('mousemove', this.doDrag);\n\n if (this.data && this.data.id) {\n this.id = this.data.id;\n this.name = this.data.name;\n this.summary = this.data.description;\n\n if (this.data.vars.length != 0) {\n this.vars = this.data.vars;\n }\n } // Focus sur le premier input du formulaire\n\n\n this.$nextTick(function () {\n _this.$refs.page_input_name.focus();\n });\n },\n computed: {\n isEntity: function isEntity() {\n return this.data && this.data.id && this.data.id != 0;\n },\n title: function title() {\n return this.isEntity ? this.$cms.getMessage(\"cms_edit_page_title\") : this.$cms.getMessage(\"cms_page_title\");\n }\n },\n methods: {\n reset: function reset(index) {\n if (index == 0) {\n this.vars[index].name = \"\";\n this.vars[index].comment = \"\";\n } else {\n this.vars.splice(index, 1);\n }\n },\n add: function add() {\n this.vars.push({\n name: \"\",\n summary: \"\"\n });\n },\n getFormValues: function getFormValues() {\n var formValues = {\n name: this.name,\n description: this.summary,\n var_count: this.vars.length.toString()\n };\n\n for (var i = 0; i < this.vars.length; i++) {\n formValues[\"var_name_\" + (i + 1)] = this.vars[i].name;\n formValues[\"var_comment_\" + (i + 1)] = this.vars[i].comment;\n }\n\n return formValues;\n },\n submit: function submit(event) {\n var _this2 = this;\n\n this.$cms.showLoader();\n var post = new URLSearchParams();\n var formValues = this.getFormValues();\n\n for (var index in formValues) {\n post.append(index, formValues[index]);\n }\n\n var options = {\n method: 'POST',\n body: post\n };\n fetch('./ajax.php?module=cms&categ=pages&sub=save&id=' + this.id, options).then(function (response) {\n response.json().then(function (result) {\n if (!result.error) {\n var value = parseInt('25' + ('0' + result).slice(-2));\n\n var _index = _this2.$cms.portal.sub_types.findIndex(function (sub_type) {\n return sub_type.value == value;\n });\n\n if (_index != -1) {\n _this2.$cms.portal.sub_types[_index]['label'] = _this2.name;\n _this2.$cms.portal.sub_types[_index]['value'] = value;\n } else {\n _this2.$cms.portal.sub_types.push({\n label: _this2.name,\n value: value\n });\n }\n\n _this2.$emit('changeSubType', value);\n\n _this2.$emit('closeCmsForm', event, true);\n\n _this2.$cms.hiddenLoader();\n }\n });\n });\n },\n remove: function remove(event) {\n var _this3 = this;\n\n if (confirm(this.$cms.getMessage(\"confirm_remove_cms_page\"))) {\n this.$cms.showLoader();\n fetch('./ajax.php?module=cms&categ=pages&sub=del&id=' + this.id, {\n method: 'GET'\n }).then(function (response) {\n response.json().then(function (result) {\n if (result == 0) {\n var pages = _this3.$cms.pages.filter(function (page) {\n return page.sub_type == _this3.data.subType;\n });\n\n var _iterator = _createForOfIteratorHelper(pages),\n _step;\n\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var page = _step.value;\n\n _this3.$cms.removePage(page.id);\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n\n var value = parseInt('25' + ('0' + _this3.id).slice(-2));\n\n _this3.$emit('removeSubType', value);\n\n _this3.$emit('closeCmsForm', event, true);\n\n _this3.$cms.hiddenLoader();\n }\n });\n });\n }\n },\n startDrag: function startDrag(event) {\n this.dragging = true;\n this.dragStyle = \"cursor: grabbing;\";\n this.startX = event.clientX;\n this.startY = event.clientY;\n },\n stopDrag: function stopDrag(event) {\n this.dragging = false;\n this.dragStyle = \"\";\n this.x = this.y = 0;\n },\n doDrag: function doDrag(event) {\n if (this.dragging) {\n this.x = this.startX - event.clientX;\n this.y = this.startY - event.clientY;\n this.startX = event.clientX;\n this.startY = event.clientY;\n this.$refs.modal_cms.style.position = \"absolute\";\n this.$refs.modal_cms.style.left = this.$refs.modal_cms.offsetLeft - this.x + \"px\";\n this.$refs.modal_cms.style.top = this.$refs.modal_cms.offsetTop - this.y + \"px\";\n }\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/conditions.vue?vue&type=script&lang=js&":
/*!*************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/page/conditions.vue?vue&type=script&lang=js& ***!
\*************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _conditions_ConditionEnvModel_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./conditions/ConditionEnvModel.vue */ \"./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue\");\n/* harmony import */ var _conditions_ConditionOpacViewModel_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./conditions/ConditionOpacViewModel.vue */ \"./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue\");\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['conditions'],\n data: function data() {\n return {\n newCondition: \"\"\n };\n },\n components: {\n ConditionEnvModel: _conditions_ConditionEnvModel_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"],\n ConditionOpacViewModel: _conditions_ConditionOpacViewModel_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"]\n },\n methods: {\n add: function add() {\n this.$emit(\"add\", this.newCondition);\n this.newCondition = \"\";\n },\n getComponent: function getComponent(condition) {\n var component = condition['class'].replace('Pmb\\\\CMS\\\\Models\\\\', '');\n\n if (!this.$options.components[component]) {\n throw \"component \".concat(component, \" not imported\");\n }\n\n return component;\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/conditions.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue?vue&type=script&lang=js&":
/*!*******************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue?vue&type=script&lang=js& ***!
\*******************************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['condition', 'index'],\n data: function data() {\n return {\n global: \"\"\n };\n },\n computed: {\n idGlobal: function idGlobal() {\n return \"global_\".concat(this.index);\n }\n },\n mounted: function mounted() {\n if (this.condition.data && this.condition.data.global) {\n this.global = this.condition.data.global;\n }\n },\n watch: {\n \"condition\": function condition(newValue, oldValue) {\n if (newValue.data && newValue.data.global) {\n this.global = newValue.data.global;\n }\n }\n },\n methods: {\n remove: function remove() {\n this.$emit('remove', this.index);\n },\n change: function change() {\n this.$emit('update', {\n global: this.global\n });\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue?vue&type=script&lang=js&":
/*!************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue?vue&type=script&lang=js& ***!
\************************************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\nfunction asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }\n\nfunction _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err); } _next(undefined); }); }; }\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['condition', 'index'],\n data: function data() {\n return {\n opac_view: \"\",\n opac_views: []\n };\n },\n created: function () {\n var _created = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {\n return regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n _context.next = 2;\n return this.$cms.model.getOpacViews();\n\n case 2:\n this.opac_views = _context.sent;\n\n case 3:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function created() {\n return _created.apply(this, arguments);\n }\n\n return created;\n }(),\n computed: {\n idSelect: function idSelect() {\n return \"select_view_\".concat(this.index);\n }\n },\n mounted: function mounted() {\n if (this.condition.data && this.condition.data.opac_view) {\n this.opac_view = this.condition.data.opac_view;\n }\n },\n watch: {\n \"condition\": function condition(newValue, oldValue) {\n if (newValue.data && newValue.data.opac_view) {\n this.opac_view = newValue.data.opac_view;\n }\n }\n },\n methods: {\n remove: function remove() {\n this.$emit('remove', this.index);\n },\n change: function change() {\n this.$emit('update', {\n opac_view: this.opac_view\n });\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/pageForm.vue?vue&type=script&lang=js&":
/*!***********************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/page/pageForm.vue?vue&type=script&lang=js& ***!
\***********************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _conditions_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./conditions.vue */ \"./includes/templates/vuejs/portal/build/components/page/conditions.vue\");\n/* harmony import */ var _pageHeritage_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./pageHeritage.vue */ \"./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue\");\n/* harmony import */ var _alertError_vue__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../alertError.vue */ \"./includes/templates/vuejs/portal/build/components/alertError.vue\");\n/* harmony import */ var _cmsPageForm_vue__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./cmsPageForm.vue */ \"./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue\");\n/* harmony import */ var _frameList_vue__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../frameList.vue */ \"./includes/templates/vuejs/portal/build/components/frameList.vue\");\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n\n\n\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: [\"data\"],\n components: {\n page_heritage: _pageHeritage_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n alert_error: _alertError_vue__WEBPACK_IMPORTED_MODULE_2__[\"default\"],\n conditions: _conditions_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"],\n cms_form: _cmsPageForm_vue__WEBPACK_IMPORTED_MODULE_3__[\"default\"],\n frame_list: _frameList_vue__WEBPACK_IMPORTED_MODULE_4__[\"default\"]\n },\n data: function data() {\n return {\n id: 0,\n name: \"\",\n conditions: [],\n gabarit_layout: {\n \"class\": \"\",\n id: 0\n },\n page_layout: {\n \"class\": \"\",\n id: 0\n },\n parent_page: {\n \"class\": \"\",\n id: 0\n },\n type: \"\",\n sub_type: \"\",\n errorMessage: \"\",\n showCmsForm: false,\n cmsFormData: {},\n frameList: [],\n layouts_list: {}\n };\n },\n mounted: function mounted() {\n this.load();\n },\n watch: {\n \"data\": function data(newValue, oldValue) {\n this.load();\n }\n },\n computed: {\n title: function title() {\n var title = this.$cms.getMessage(\"heritage_has_frame\");\n\n if (this.frameList.length == 0) {\n title = this.$cms.getMessage(\"heritage_no_frame\");\n }\n\n return title;\n },\n isEntity: function isEntity() {\n return this.data && this.data.item && this.data.item.id != 0;\n },\n typesOrderAsc: function typesOrderAsc() {\n return this.sortAscType(this.$cms.portal.types);\n },\n sub_types: function sub_types() {\n var _this = this;\n\n var sub_types = this.$cms.portal.sub_types.filter(function (sub_type) {\n var type_code = _this.$cms.getTypeFromSubType(sub_type.value);\n\n return type_code == _this.type;\n });\n sub_types = this.sortAscType(sub_types);\n\n if (sub_types.length == 0) {\n this.sub_type = null;\n } else {\n if (!sub_types.find(function (sub_type) {\n return sub_type.value == _this.sub_type;\n })) {\n this.sub_type = sub_types[0].value;\n }\n }\n\n return sub_types;\n },\n hasLayoutsList: function hasLayoutsList() {\n return Object.keys(this.layouts_list).length > 0;\n }\n },\n methods: {\n load: function load() {\n var _this2 = this;\n\n this.frameList = [];\n this.name = \"\";\n\n if (this.data && this.data.item) {\n var _this$data$item$name;\n\n this.name = (_this$data$item$name = this.data.item.name) !== null && _this$data$item$name !== void 0 ? _this$data$item$name : \"\";\n }\n\n var first_type = this.typesOrderAsc[0].value;\n this.type = first_type;\n\n if (this.data && this.data.item) {\n var _this$data$item$type;\n\n this.type = (_this$data$item$type = this.data.item.type) !== null && _this$data$item$type !== void 0 ? _this$data$item$type : first_type;\n }\n\n var first_sub_type = this.sub_types[0].value;\n this.sub_type = first_sub_type;\n\n if (this.data && this.data.item) {\n var _this$data$item$sub_t;\n\n this.sub_type = (_this$data$item$sub_t = this.data.item.sub_type) !== null && _this$data$item$sub_t !== void 0 ? _this$data$item$sub_t : first_sub_type;\n }\n\n if (this.isEntity) {\n this.id = this.data.item.id;\n this.conditions = this.data.item.conditions;\n this.gabarit_layout = this.data.item.gabarit_layout;\n this.page_layout = this.data.item.page_layout;\n this.parent_page = this.data.item.parent_page;\n this.layouts_list = this.data.item.page_layout.layouts_list;\n var promise;\n\n if (this.parent_page) {\n promise = this.$cms.model.getFramesInPage(this.id);\n } else {\n promise = this.$cms.model.getFramesInGabarit(this.gabarit_layout.id);\n }\n\n promise.then(function (result) {\n if (result.error) {\n throw result.errorMessage;\n } else {\n _this2.frameList = result;\n }\n }, function () {\n _this2.frameList = [];\n });\n } else {\n this.id = 0;\n this.conditions = [];\n this.gabarit_layout = this.$cms.getDefaultGabarit();\n this.page_layout = {};\n this.parent_page = {};\n this.layouts_list = {}; // Focus sur le premier input du formulaire\n\n this.$nextTick(function () {\n _this2.$refs.page_input_name.focus();\n });\n }\n },\n closeError: function closeError() {\n this.errorMessage = \"\";\n },\n updateHeritage: function updateHeritage(heritage) {\n if (this.data.item == undefined) {\n this.data.item = {};\n }\n\n if (heritage['class'].toLowerCase().includes('page')) {\n this.parent_page = heritage;\n this.gabarit_layout = null;\n } else {\n this.gabarit_layout = heritage;\n this.parent_page = null;\n }\n },\n sortAscType: function sortAscType(array) {\n array.sort(function (a, b) {\n var labelA = a.label.toLocaleLowerCase();\n var labelB = b.label.toLocaleLowerCase();\n\n if (labelA == labelB) {\n return 0;\n }\n\n return labelA < labelB ? -1 : 1;\n });\n return array;\n },\n submit: function submit(event) {\n var _this3 = this;\n\n event.preventDefault();\n var promise = this.$cms.updatePage({\n \"id\": this.id,\n \"class\": \"Pmb\\\\CMS\\\\Models\\\\PagePortalModel\",\n \"name\": this.name,\n \"type\": this.type,\n \"sub_type\": this.sub_type,\n \"parent_page\": this.parent_page,\n \"gabarit_layout\": this.gabarit_layout,\n \"page_layout\": this.page_layout,\n \"conditions\": this.conditions\n });\n promise.then(function (result) {\n if (result.error) {\n _this3.errorMessage = result.errorMessage;\n }\n });\n },\n remove: function remove() {\n var _this4 = this;\n\n if (!this.isEntity) {\n return;\n }\n\n if (confirm(this.$cms.getMessage(\"page_confirm_delete\"))) {\n var promise = this.$cms.removePage(this.id);\n promise.then(function (result) {\n if (result.error) {\n _this4.errorMessage = result.errorMessage;\n }\n });\n }\n },\n cleanCache: function cleanCache() {\n var promise = this.$cms.model.clearCacheInPage(this.id);\n promise.then(function (response) {\n dojo.topic.publish('dGrowl', response.msg);\n });\n },\n addCondition: function addCondition(condition) {\n this.conditions.push({\n \"id\": 0,\n \"class\": condition,\n \"data\": {}\n });\n },\n removeCondition: function removeCondition(index) {\n this.conditions.splice(index, 1);\n },\n updateCondition: function updateCondition(conditionData, index) {\n this.conditions[index].data = conditionData;\n },\n openCmsForm: function openCmsForm(event) {\n var _this5 = this;\n\n var edit = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n\n if (edit) {\n var id = parseInt(this.sub_type.toString().substr(2), 10);\n fetch('./ajax.php?module=cms&categ=pages&sub=edit&id=' + id, {\n method: 'GET'\n }).then(function (response) {\n response.json().then(function (result) {\n _this5.cmsFormData = result;\n _this5.cmsFormData.subType = _this5.sub_type;\n _this5.showCmsForm = true;\n });\n });\n } else {\n this.cmsFormData = {};\n this.showCmsForm = true;\n }\n },\n closeCmsForm: function closeCmsForm(event, submit) {\n var classList = event.target.classList;\n\n if (submit || classList.contains(\"portal-modal\") || classList.contains(\"close-form\")) {\n this.showCmsForm = false;\n }\n },\n changeSubType: function changeSubType(value) {\n this.sub_type = value;\n },\n removeSubType: function removeSubType(value) {\n var index = this.$cms.portal.sub_types.findIndex(function (sub_type) {\n return sub_type.value == value;\n });\n this.$cms.portal.sub_types.splice(index, 1);\n this.sub_type = this.sub_types[0].value;\n },\n frameRemove: function frameRemove(frame) {\n if (confirm(this.$cms.getMessage(\"layout_element_confirm_delete\"))) {\n this.$cms.removeElementLayout({\n item: frame,\n parent: null,\n page_id: this.id\n });\n }\n },\n setFrameList: function setFrameList(frameList) {\n this.frameList = frameList;\n },\n removeLayout: function removeLayout(index) {\n this.$cms.removePageLayout({\n page: this.id,\n layout: index\n });\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/pageForm.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue?vue&type=script&lang=js&":
/*!***************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue?vue&type=script&lang=js& ***!
\***************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['data'],\n data: function data() {\n return {\n heritageSelected: \"\",\n parent_page: 0,\n gabarit: 0\n };\n },\n mounted: function mounted() {\n var _this = this;\n\n this.$nextTick(function () {\n _this.load();\n });\n },\n watch: {\n data: function data(newValue, OldValue) {\n this.load();\n }\n },\n computed: {\n pageId: function pageId() {\n return this.data && this.data.item ? this.data.item.id : 0;\n },\n isEntity: function isEntity() {\n return this.data && this.data.item && this.data.item.id != 0;\n },\n pageList: function pageList() {\n var _this2 = this;\n\n var list = [];\n\n if (this.pageId) {\n this.$cms.pages.forEach(function (page) {\n if (_this2.pageId != page.id) {\n var nextPage = page.parent_page;\n var isLoop = false;\n\n while (nextPage && nextPage.id) {\n if (nextPage.id == _this2.pageId) {\n isLoop = true;\n }\n\n nextPage = nextPage.parent_page;\n }\n\n if (!isLoop) {\n list.push(page);\n }\n }\n });\n return list;\n } else {\n return this.$cms.pages;\n }\n },\n currentHeritage: function currentHeritage() {\n if (this.gabarit) {\n return \"gabarit_\".concat(this.gabarit);\n }\n\n if (this.parent_page) {\n return \"page_\".concat(this.parent_page);\n }\n\n return false;\n }\n },\n methods: {\n load: function load() {\n if (this.isEntity) {\n if (this.data.item.parent_page && this.data.item.parent_page.id) {\n this.parent_page = this.data.item.parent_page.id;\n } else {\n this.gabarit = this.data.item.gabarit_layout.id;\n }\n } else {\n this.parent_page = 0;\n this.gabarit = 0;\n }\n\n if (this.currentHeritage === false) {\n this.setDefault();\n } else {\n this.heritageSelected = this.currentHeritage;\n }\n },\n setDefault: function setDefault() {\n var gabarit = this.$cms.getDefaultGabarit();\n this.heritageSelected = \"gabarit_\".concat(gabarit.id);\n this.changeHeritage();\n },\n changeHeritage: function changeHeritage() {\n var heritageSplitted = this.heritageSelected.split('_');\n var heritage = null;\n\n if (this.heritageSelected.toLowerCase().includes('page')) {\n heritage = this.$cms.pages.find(function (page) {\n return page.id == heritageSplitted[1];\n });\n } else {\n heritage = this.$cms.gabarits.find(function (gabarit) {\n return gabarit.id == heritageSplitted[1];\n });\n }\n\n this.$emit('change', heritage);\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue?vue&type=script&lang=js&":
/*!***************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue?vue&type=script&lang=js& ***!
\***************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _cmsPageForm_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./cmsPageForm.vue */ \"./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue\");\nfunction asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }\n\nfunction _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err); } _next(undefined); }); }; }\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: [\"data\"],\n components: {\n cms_form: _cmsPageForm_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"]\n },\n data: function data() {\n return {\n layout: \"\",\n layouts: {},\n type: \"\",\n checked: [],\n status: {},\n errorMessage: \"\",\n showCmsForm: false,\n cmsFormData: {}\n };\n },\n mounted: function mounted() {\n this.load();\n },\n watch: {\n \"data\": function data(newValue, oldValue) {\n this.load();\n }\n },\n computed: {\n available: function available() {\n return this.checked.length > 0;\n },\n pages: function pages() {\n var _this = this;\n\n var pages = this.$cms.pages.filter(function (page) {\n return page.id != 0 && page.type == _this.type;\n });\n\n for (var i = 0; i < pages.length; i++) {\n this.layouts[pages[i].id] = this.getLayoutByPage(pages[i]);\n }\n\n return pages;\n },\n pageList: function pageList() {\n var pageIds = [];\n this.pages.forEach(function (page) {\n pageIds.push(page.id);\n });\n var list = [];\n this.$cms.pages.forEach(function (page) {\n if (!pageIds.includes(page.id)) {\n var nextPage = page.parent_page;\n var isLoop = false;\n\n while (nextPage && nextPage.id) {\n if (pageIds.includes(nextPage.id)) {\n isLoop = true;\n }\n\n nextPage = nextPage.parent_page;\n }\n\n if (!isLoop) {\n list.push(page);\n }\n }\n });\n return list;\n }\n },\n methods: {\n load: function load() {\n this.status = {};\n this.checked = [];\n\n if (this.data && this.data.item) {\n var _this$data$item$type;\n\n this.type = (_this$data$item$type = this.data.item.type) !== null && _this$data$item$type !== void 0 ? _this$data$item$type : first_type;\n }\n\n this.layout = \"gabarit_\".concat(this.$cms.gabarits[0].id);\n },\n updateHeritage: function () {\n var _updateHeritage = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(pageId) {\n var page, msg, tmp;\n return regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n page = this.$cms.cloneObject(this.pages.find(function (page) {\n return page.id == pageId;\n }));\n msg = this.$cms.getMessage('change_page_layout').replace('%s', page.name);\n\n if (!(this.layouts[pageId] && confirm(msg))) {\n _context.next = 10;\n break;\n }\n\n this.status = {};\n this.status[pageId] = \"wait\";\n tmp = this.layouts[pageId].split(\"_\");\n page = this.updatedPage(page, {\n id: tmp[1],\n \"class\": tmp[0] == \"page\" ? \"Pmb\\\\CMS\\\\Models\\\\PagePortalModel\" : \"Pmb\\\\CMS\\\\Models\\\\GabaritLayoutModel\"\n });\n _context.next = 9;\n return this.$cms.updatePages([page]);\n\n case 9:\n this.status = _context.sent;\n\n case 10:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function updateHeritage(_x) {\n return _updateHeritage.apply(this, arguments);\n }\n\n return updateHeritage;\n }(),\n apply: function () {\n var _apply = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2() {\n var _this2 = this;\n\n var tmp, heritage, pages, i;\n return regeneratorRuntime.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n this.status = {};\n tmp = this.layout.split(\"_\");\n heritage = {\n id: tmp[1],\n \"class\": tmp[0] == \"page\" ? \"Pmb\\\\CMS\\\\Models\\\\PagePortalModel\" : \"Pmb\\\\CMS\\\\Models\\\\GabaritLayoutModel\"\n };\n pages = this.$cms.cloneObject(this.pages.filter(function (page) {\n return _this2.checked.includes(page.id);\n }));\n\n if (!pages) {\n _context2.next = 9;\n break;\n }\n\n for (i = 0; i < pages.length; i++) {\n this.status[pages[i].id] = \"wait\";\n pages[i] = this.updatedPage(pages[i], heritage);\n }\n\n _context2.next = 8;\n return this.$cms.updatePages(pages);\n\n case 8:\n this.status = _context2.sent;\n\n case 9:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2, this);\n }));\n\n function apply() {\n return _apply.apply(this, arguments);\n }\n\n return apply;\n }(),\n updatedPage: function updatedPage(page, layout) {\n if (layout['class'] == \"Pmb\\\\CMS\\\\Models\\\\PagePortalModel\") {\n page.parent_page = layout;\n page.gabarit_layout = {};\n } else {\n page.gabarit_layout = layout;\n page.parent_page = {};\n }\n\n return page;\n },\n checkAll: function checkAll() {\n var _this3 = this;\n\n this.status = {};\n this.pages.forEach(function (page) {\n if (!_this3.checked.includes(page.id)) {\n _this3.checked.push(page.id);\n }\n });\n },\n uncheckAll: function uncheckAll() {\n this.status = {};\n this.checked = [];\n },\n changeCheck: function changeCheck(pageId) {\n this.status = {};\n\n if (this.checked.includes(pageId)) {\n var index = this.checked.findIndex(function (id) {\n return id == pageId;\n });\n this.checked.splice(index, 1);\n } else {\n this.checked.push(pageId);\n }\n },\n getLayoutByPage: function getLayoutByPage(page) {\n if (page.gabarit_layout && page.gabarit_layout.id) {\n return \"gabarit_\".concat(page.gabarit_layout.id);\n }\n\n if (page.parent_page && page.parent_page.id) {\n return \"page_\".concat(page.parent_page.id);\n }\n\n return \"\";\n },\n getImage: function getImage(pageId) {\n if (this.status[pageId] == \"wait\") {\n return this.$cms.getImage(\"patience.gif\");\n } else if (this.status[pageId] == true) {\n return this.$cms.getImage(\"tick.gif\");\n } else if (this.status[pageId] == false) {\n return this.$cms.getImage(\"error.png\");\n }\n\n return false;\n },\n getPageList: function getPageList(pageId) {\n var list = [];\n this.$cms.pages.forEach(function (page) {\n if (pageId != page.id) {\n var nextPage = page.parent_page;\n var isLoop = false;\n\n while (nextPage && nextPage.id) {\n if (nextPage.id == pageId) {\n isLoop = true;\n }\n\n nextPage = nextPage.parent_page;\n }\n\n if (!isLoop) {\n list.push(page);\n }\n }\n });\n return list;\n },\n openCmsForm: function openCmsForm(event) {\n var _this4 = this;\n\n var edit = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n\n if (edit) {\n var id = parseInt(this.sub_type.toString().substr(2), 10);\n fetch('./ajax.php?module=cms&categ=pages&sub=edit&id=' + id, {\n method: 'GET'\n }).then(function (response) {\n response.json().then(function (result) {\n _this4.cmsFormData = result;\n _this4.showCmsForm = true;\n });\n });\n } else {\n this.cmsFormData = {};\n this.showCmsForm = true;\n }\n },\n closeCmsForm: function closeCmsForm(event, submit) {\n var classList = event.target.classList;\n\n if (submit || classList.contains(\"portal-modal\") || classList.contains(\"close-form\")) {\n this.showCmsForm = false;\n }\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/preview/contextForm.vue?vue&type=script&lang=js&":
/*!*****************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/preview/contextForm.vue?vue&type=script&lang=js& ***!
\*****************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: [\"contexts\", \"bookmarkContext\"],\n data: function data() {\n return {\n name: \"\",\n editedContexts: [],\n dragging: false,\n x: 0,\n y: 0,\n startX: 0,\n startY: 0,\n dragStyle: \"\",\n contextsList: []\n };\n },\n mounted: function mounted() {\n window.addEventListener('mouseup', this.stopDrag);\n window.addEventListener('mousemove', this.doDrag);\n this.contextsList = this.$cms.cloneObject(this.contexts);\n },\n methods: {\n startDrag: function startDrag(event) {\n this.dragging = true;\n this.dragStyle = \"cursor: grabbing;\";\n this.startX = event.clientX;\n this.startY = event.clientY;\n },\n stopDrag: function stopDrag(event) {\n this.dragging = false;\n this.dragStyle = \"\";\n this.x = this.y = 0;\n },\n doDrag: function doDrag(event) {\n if (this.dragging) {\n this.x = this.startX - event.clientX;\n this.y = this.startY - event.clientY;\n this.startX = event.clientX;\n this.startY = event.clientY;\n this.$refs.modal_context.style.position = \"absolute\";\n this.$refs.modal_context.style.left = this.$refs.modal_context.offsetLeft - this.x + \"px\";\n this.$refs.modal_context.style.top = this.$refs.modal_context.offsetTop - this.y + \"px\";\n }\n },\n editContext: function editContext(index) {\n var _this = this;\n\n this.editedContexts.push(index);\n this.$nextTick(function () {\n _this.$refs[\"context_input_\".concat(index)][0].focus();\n });\n },\n saveContext: function saveContext(index) {\n if (this.contexts[index].name != this.contextsList[index].name) {\n this.$emit('saveContext', index, this.contextsList[index]);\n }\n\n this.unEditContext(index);\n },\n removeContext: function removeContext(index) {\n if (confirm(this.$cms.getMessage('confirm_remove_context'))) {\n this.unEditContext(index);\n this.contextsList.splice(index, 1);\n this.$emit('removeContext', index);\n }\n },\n sendContext: function sendContext(index) {\n this.$emit(\"sendContext\", index);\n },\n unEditContext: function unEditContext(index) {\n var findIndex = this.editedContexts.findIndex(function (contextIndex) {\n return contextIndex == index;\n });\n this.editedContexts.splice(findIndex, 1);\n },\n getClassesFav: function getClassesFav(index) {\n return this.isFavContext(index) ? 'fav fa fa-star' : 'fav fa fa-star-o';\n },\n isFavContext: function isFavContext(index) {\n return this.bookmarkContext == index;\n },\n changeBookmark: function changeBookmark(index) {\n this.$emit('changeBookmark', index);\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/preview/contextForm.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/preview/preview.vue?vue&type=script&lang=js&":
/*!*************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/preview/preview.vue?vue&type=script&lang=js& ***!
\*************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _contextForm_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./contextForm.vue */ \"./includes/templates/vuejs/portal/build/components/preview/contextForm.vue\");\nfunction asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }\n\nfunction _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err); } _next(undefined); }); }; }\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: [\"data\"],\n components: {\n context_form: _contextForm_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"]\n },\n data: function data() {\n return {\n url: \"\",\n home_url: \"\",\n init: false,\n context: \"\",\n applyContext: false,\n showForm: false,\n showFormContext: false,\n currentContext: {\n name: \"\",\n value: \"\",\n url: \"\"\n },\n newContextPage: 0,\n newContext: {\n name: \"\",\n value: \"\",\n url: \"\"\n }\n };\n },\n mounted: function mounted() {\n var _this = this;\n\n window.addEventListener('click', function () {\n _this.showForm = false;\n });\n this.url = this.base_url;\n this.home_url = this.base_url;\n\n if (this.item.bookmark_context !== null && this.item.contexts[this.item.bookmark_context]) {\n this.context = this.$cms.cloneObject(this.item.bookmark_context);\n this.$nextTick(function () {\n _this.setContext(true);\n });\n } else {\n this.getIframe().src = this.initUrl;\n }\n },\n computed: {\n item: function item() {\n return this.$cms.cloneObject(this.$cms.container.data.item);\n },\n base_url: function base_url() {\n var _this2 = this;\n\n var sub_type = this.$cms.portal.sub_types.find(function (subtype) {\n return subtype.value == _this2.item.sub_type;\n });\n return sub_type && sub_type.url ? sub_type.url : this.$cms.url_base_opac;\n },\n valid_url: function valid_url() {\n var url = this.base_url;\n\n if (this.currentContext.url != \"\") {\n url = this.generateUrlContext();\n }\n\n if (this.data.item.sub_type == 2801) {\n // 2801 == Page d'accueil\n return url == this.$cms.url_base_opac;\n }\n\n return url != this.$cms.url_base_opac;\n },\n initUrl: function initUrl() {\n var urlBase = new URL(this.base_url);\n var urlSearch = new URLSearchParams(urlBase.search);\n var url = this.base_url.replace(urlBase.search, \"\");\n\n if (!urlSearch.has('database')) {\n urlSearch.append('database', this.$cms.portal.database);\n }\n\n if (!urlSearch.has('cms_build_activate')) {\n urlSearch.append('cms_build_activate', '1');\n }\n\n if (!urlSearch.has('opac_view')) {\n urlSearch.append('opac_view', '-1');\n }\n\n return url + '?' + urlSearch.toString();\n }\n },\n methods: {\n getPOSTContext: function getPOSTContext() {\n var _JSON$parse, _valueDecode$post;\n\n if (this.currentContext.value == \"\") {\n return {};\n }\n\n var valueDecode = (_JSON$parse = JSON.parse(this.currentContext.value)) !== null && _JSON$parse !== void 0 ? _JSON$parse : {};\n return (_valueDecode$post = valueDecode['post']) !== null && _valueDecode$post !== void 0 ? _valueDecode$post : {};\n },\n generateUrlContext: function generateUrlContext() {\n if (this.currentContext.url == \"\") {\n return this.$cms.url_base_opac;\n }\n\n var valueDecode = JSON.parse(this.currentContext.value);\n\n if (typeof valueDecode.shorturl != \"undefined\" && valueDecode.shorturl != \"\") {\n return valueDecode.shorturl;\n }\n\n var urlBase = new URL(this.currentContext.url);\n var urlSearch = new URLSearchParams(urlBase.search);\n var url = this.$cms.url_base_opac.replace(urlBase.search, \"\");\n\n if (typeof url == \"undefined\" || url == \"\") {\n debugger;\n return this.$cms.url_base_opac;\n }\n\n for (var prop in valueDecode['get']) {\n if (!urlSearch.has(prop)) {\n urlSearch.append(prop, valueDecode['get'][prop]);\n }\n }\n\n if (!this.init) {\n if (!urlSearch.has('database')) {\n urlSearch.append('database', this.$cms.portal.database);\n }\n\n if (!urlSearch.has('cms_build_activate')) {\n urlSearch.append('cms_build_activate', '1');\n }\n\n if (!urlSearch.has('opac_view')) {\n urlSearch.append('opac_view', '-1');\n }\n }\n\n return url + '?' + urlSearch.toString();\n },\n getIframe: function getIframe() {\n var _document$getElementB;\n\n return (_document$getElementB = document.getElementById('preview_frame')) !== null && _document$getElementB !== void 0 ? _document$getElementB : undefined;\n },\n reload: function reload() {\n if (this.currentContext.url && this.currentContext.url == this.getIframe().contentWindow.location.href) {\n this.setContext(true);\n } else {\n this.getIframe().contentDocument.location.reload(true);\n }\n },\n send: function send() {\n this.context = \"\";\n this.getIframe().src = this.url;\n },\n home: function home() {\n this.context = \"\";\n this.getIframe().src = this.home_url;\n },\n getPageTitle: function getPageTitle() {\n if (typeof this.getIframe() == \"undefined\") {\n return \"\";\n }\n\n var title = this.getIframe().contentDocument.querySelector('title');\n\n if (title) {\n var _title$innerText;\n\n return (_title$innerText = title.innerText) !== null && _title$innerText !== void 0 ? _title$innerText : \"\";\n }\n\n return \"\";\n },\n getCmsBuildInfo: function getCmsBuildInfo() {\n if (typeof this.getIframe() == \"undefined\") {\n return \"\";\n }\n\n var input = this.getIframe().contentDocument.getElementById('cms_build_info');\n\n if (input) {\n var _input$value;\n\n return (_input$value = input.value) !== null && _input$value !== void 0 ? _input$value : \"\";\n }\n\n return \"\";\n },\n iframeLoaded: function iframeLoaded() {\n var _this3 = this;\n\n this.url = \"\"; // Permet de recaculer le template\n\n if (this.init) {\n this.url = this.getIframe().contentWindow.location.href;\n } else {\n if (this.item.bookmark_context !== null && this.item.contexts[this.item.bookmark_context]) {\n this.url = this.currentContext.url;\n } else {\n this.url = this.base_url;\n }\n\n this.init = true;\n }\n\n this.$nextTick(function () {\n if (_this3.getContextPages().length == 0) {\n _this3.showForm = false;\n }\n\n _this3.newContext.name = _this3.getPageTitle();\n _this3.newContext.value = _this3.getCmsBuildInfo();\n _this3.newContext.url = _this3.url;\n });\n },\n showAddFormContext: function showAddFormContext() {\n var _this4 = this;\n\n this.showForm = !this.showForm;\n this.$nextTick(function () {\n if (_this4.showForm) {\n _this4.$refs.context_input.focus();\n }\n });\n },\n setContext: function setContext() {\n var _this5 = this;\n\n var force = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;\n\n if (force || confirm(this.$cms.getMessage('preview_confirm_apply_context'))) {\n this.currentContext = this.$cms.cloneObject(this.item.contexts[this.context]);\n var valueDecode = JSON.parse(this.currentContext.value);\n\n if (typeof valueDecode.shorturl != \"undefined\" && valueDecode.shorturl != \"\") {\n this.getIframe().src = valueDecode.shorturl;\n } else {\n this.$nextTick(function () {\n _this5.$refs.formContext.submit();\n });\n }\n } else {\n this.context = \"\";\n }\n },\n saveContext: function () {\n var _saveContext = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {\n var context, contextPages, contextPage, result, pageIndex;\n return regeneratorRuntime.wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n this.showForm = false;\n this.newContext.url = this.url;\n context = this.$cms.cloneObject(this.newContext);\n\n if (context.value) {\n _context.next = 5;\n break;\n }\n\n return _context.abrupt(\"return\", false);\n\n case 5:\n contextPages = this.getContextPages();\n\n if (!(contextPages.length <= 0 && !contextPages[this.newContextPage])) {\n _context.next = 8;\n break;\n }\n\n return _context.abrupt(\"return\", false);\n\n case 8:\n contextPage = contextPages[this.newContextPage];\n _context.next = 11;\n return this.$cms.model.pageSaveContext(contextPage.id, context);\n\n case 11:\n result = _context.sent;\n\n if (!result.error) {\n _context.next = 14;\n break;\n }\n\n return _context.abrupt(\"return\", false);\n\n case 14:\n this.newContext.name = this.getPageTitle();\n this.newContext.value = this.getCmsBuildInfo();\n pageIndex = this.$cms.pages.findIndex(function (page) {\n return page.id == contextPage.id;\n });\n this.$cms.pages[pageIndex].contexts.push(context);\n\n case 18:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, this);\n }));\n\n function saveContext() {\n return _saveContext.apply(this, arguments);\n }\n\n return saveContext;\n }(),\n closeContextForm: function closeContextForm() {\n this.showFormContext = false;\n },\n openContextForm: function openContextForm(parent) {\n if (typeof parent === 'string') {\n this.parent = parent;\n }\n\n this.showFormContext = true;\n },\n editContext: function () {\n var _editContext = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2(index, context) {\n var _this6 = this;\n\n var newContext, result, pageIndex;\n return regeneratorRuntime.wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n newContext = this.$cms.cloneObject(context);\n\n if (newContext.value) {\n _context2.next = 3;\n break;\n }\n\n return _context2.abrupt(\"return\", false);\n\n case 3:\n _context2.next = 5;\n return this.$cms.model.pageEditContext(this.item.id, {\n index_context: index,\n context: newContext\n });\n\n case 5:\n result = _context2.sent;\n\n if (!result.error) {\n _context2.next = 8;\n break;\n }\n\n return _context2.abrupt(\"return\", false);\n\n case 8:\n pageIndex = this.$cms.pages.findIndex(function (page) {\n return page.id == _this6.item.id;\n });\n\n if (this.item.bookmark_context == index) {\n this.$cms.pages[pageIndex].bookmark_context = null;\n }\n\n this.$cms.pages[pageIndex].contexts.splice(index, 1, newContext);\n\n case 11:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2, this);\n }));\n\n function editContext(_x, _x2) {\n return _editContext.apply(this, arguments);\n }\n\n return editContext;\n }(),\n removeContext: function () {\n var _removeContext = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee3(index) {\n var _this7 = this;\n\n var result, pageIndex;\n return regeneratorRuntime.wrap(function _callee3$(_context3) {\n while (1) {\n switch (_context3.prev = _context3.next) {\n case 0:\n _context3.next = 2;\n return this.$cms.model.pageRemoveContext(this.item.id, {\n index_context: index\n });\n\n case 2:\n result = _context3.sent;\n\n if (!result.error) {\n _context3.next = 5;\n break;\n }\n\n return _context3.abrupt(\"return\", false);\n\n case 5:\n pageIndex = this.$cms.pages.findIndex(function (page) {\n return page.id == _this7.item.id;\n });\n this.$cms.pages[pageIndex].contexts.splice(index, 1);\n\n if (this.context == index) {\n this.context = \"\";\n this.currentContext = {\n name: \"\",\n value: \"\",\n url: \"\"\n };\n }\n\n if (!this.$cms.pages[pageIndex].contexts.length) {\n this.showFormContext = false;\n }\n\n case 9:\n case \"end\":\n return _context3.stop();\n }\n }\n }, _callee3, this);\n }));\n\n function removeContext(_x3) {\n return _removeContext.apply(this, arguments);\n }\n\n return removeContext;\n }(),\n sendContext: function sendContext(index) {\n var _this8 = this;\n\n this.showFormContext = false;\n this.context = index;\n var context = this.item.contexts[this.context];\n this.currentContext = context;\n this.$nextTick(function () {\n _this8.$refs.formContext.submit();\n });\n },\n getContextPages: function getContextPages() {\n var cms_build_infos_string = this.getCmsBuildInfo();\n\n if (cms_build_infos_string) {\n var pages = this.$cms.cloneObject(this.$cms.pages);\n var cms_build_infos = JSON.parse(cms_build_infos_string);\n return pages.filter(function (page) {\n return page.type == cms_build_infos.type && page.sub_type == cms_build_infos.subType;\n });\n }\n\n return [];\n },\n changeBookmark: function () {\n var _changeBookmark = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee4(indexBookmark) {\n var _this9 = this;\n\n var result, pageIndex;\n return regeneratorRuntime.wrap(function _callee4$(_context4) {\n while (1) {\n switch (_context4.prev = _context4.next) {\n case 0:\n if (!(typeof this.item.contexts[indexBookmark] == \"undefined\")) {\n _context4.next = 2;\n break;\n }\n\n return _context4.abrupt(\"return\", false);\n\n case 2:\n _context4.next = 4;\n return this.$cms.model.pageBookmarkContext(this.item.id, {\n index_context: indexBookmark\n });\n\n case 4:\n result = _context4.sent;\n\n if (!result.error) {\n _context4.next = 7;\n break;\n }\n\n return _context4.abrupt(\"return\", false);\n\n case 7:\n pageIndex = this.$cms.pages.findIndex(function (page) {\n return page.id == _this9.item.id;\n });\n\n if (this.item.bookmark_context == indexBookmark) {\n this.$cms.pages[pageIndex].bookmark_context = null;\n } else {\n this.$cms.pages[pageIndex].bookmark_context = indexBookmark;\n }\n\n case 9:\n case \"end\":\n return _context4.stop();\n }\n }\n }, _callee4, this);\n }));\n\n function changeBookmark(_x4) {\n return _changeBookmark.apply(this, arguments);\n }\n\n return changeBookmark;\n }(),\n getSaveContextMessage: function getSaveContextMessage() {\n if (this.getContextPages().length > 0) {\n return this.$cms.getMessage('context_save');\n }\n\n return this.$cms.getMessage('context_save_unavailable');\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/preview/preview.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue?vue&type=script&lang=js&":
/*!********************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue?vue&type=script&lang=js& ***!
\********************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['semantic'],\n data: function data() {\n return {\n tag: \"\"\n };\n },\n mounted: function mounted() {\n if (this.semantic && this.semantic.tag) {\n this.tag = this.semantic.tag;\n } else {\n this.tag = this.firstTag;\n this.update();\n }\n },\n watch: {\n \"semantic\": function semantic(newValue, oldValue) {\n if (newValue && newValue.tag) {\n this.tag = newValue.tag;\n } else {\n this.tag = this.firstTag;\n this.update();\n }\n }\n },\n computed: {\n firstTag: function firstTag() {\n var _this$$cms$semantic$;\n\n return (_this$$cms$semantic$ = this.$cms.semantic[0]) !== null && _this$$cms$semantic$ !== void 0 ? _this$$cms$semantic$ : \"\";\n }\n },\n methods: {\n update: function update() {\n var semantic = this.$cms.cloneObject(this.semantic);\n semantic.tag = this.tag;\n this.$emit(\"update\", semantic);\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/babel-loader/lib/index.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/semantics/semantics.vue?vue&type=script&lang=js&":
/*!*****************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/semantics/semantics.vue?vue&type=script&lang=js& ***!
\*****************************************************************************************************************************************************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _HtmlSemantic_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./HtmlSemantic.vue */ \"./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue\");\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n props: ['semantic', 'editable'],\n data: function data() {\n return {\n selectedSemantic: \"\",\n isEditable: true,\n isForm: true\n };\n },\n components: {\n HtmlSemantic: _HtmlSemantic_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"]\n },\n mounted: function mounted() {\n if (typeof this.editable != \"undefined\") {\n this.isEditable = this.boolval(this.editable);\n }\n\n if (!this.semantic || !this.semantic[\"class\"]) {\n this.selectedSemantic = this.firstComponent;\n this.changeSemantic();\n } else {\n this.selectedSemantic = this.getClassName(this.semantic['class']);\n }\n },\n watch: {\n \"semantic\": function semantic(newValue, oldValue) {\n if (!newValue || !newValue[\"class\"]) {\n this.selectedSemantic = this.defaultSemantic;\n this.changeSemantic();\n } else {\n this.selectedSemantic = this.getClassName(newValue['class']);\n }\n }\n },\n computed: {\n defaultStructure: function defaultStructure() {\n if (this.componentName) {\n return {\n id: 0,\n \"class\": \"Pmb\\\\CMS\\\\Semantics\\\\\" + this.componentName,\n classes: [],\n id_tag: \"\",\n tag: \"\"\n };\n }\n\n return null;\n },\n label: function label() {\n var _this$$cms$getMessage;\n\n return (_this$$cms$getMessage = this.$cms.getMessage('zone_class_semantic')) !== null && _this$$cms$getMessage !== void 0 ? _this$$cms$getMessage : \"\";\n },\n firstComponent: function firstComponent() {\n var _components$;\n\n var components = Object.keys(this.$options.components);\n return (_components$ = components[0]) !== null && _components$ !== void 0 ? _components$ : \"\";\n },\n componentName: function componentName() {\n if (!this.selectedSemantic) {\n return \"\";\n }\n\n var component = this.getClassName(this.selectedSemantic);\n\n if (!this.$options.components[component]) {\n throw \"Component \".concat(component, \" not imported\");\n }\n\n return component;\n }\n },\n methods: {\n boolval: function boolval(bool) {\n return bool == \"true\" || bool == true ? true : false;\n },\n getClassName: function getClassName(namespace) {\n return namespace.replace('Pmb\\\\CMS\\\\Semantics\\\\', '');\n },\n changeSemantic: function changeSemantic() {\n if (this.defaultStructure) {\n this.$emit(\"change\", this.defaultStructure);\n }\n }\n }\n});\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/semantics/semantics.vue?./node_modules/babel-loader/lib??ref--0!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/process/browser.js":
/*!*****************************************!*\
!*** ./node_modules/process/browser.js ***!
\*****************************************/
/*! no static exports found */
/***/ (function(module, exports) {
eval("// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n throw new Error('clearTimeout has not been defined');\n}\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n} ())\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n }\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch(e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch(e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n\n\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n }\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n\n\n//# sourceURL=webpack:///./node_modules/process/browser.js?");
/***/ }),
/***/ "./node_modules/setimmediate/setImmediate.js":
/*!***************************************************!*\
!*** ./node_modules/setimmediate/setImmediate.js ***!
\***************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
eval("/* WEBPACK VAR INJECTION */(function(global, process) {(function (global, undefined) {\n \"use strict\";\n\n if (global.setImmediate) {\n return;\n }\n\n var nextHandle = 1; // Spec says greater than zero\n var tasksByHandle = {};\n var currentlyRunningATask = false;\n var doc = global.document;\n var registerImmediate;\n\n function setImmediate(callback) {\n // Callback can either be a function or a string\n if (typeof callback !== \"function\") {\n callback = new Function(\"\" + callback);\n }\n // Copy function arguments\n var args = new Array(arguments.length - 1);\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i + 1];\n }\n // Store and register the task\n var task = { callback: callback, args: args };\n tasksByHandle[nextHandle] = task;\n registerImmediate(nextHandle);\n return nextHandle++;\n }\n\n function clearImmediate(handle) {\n delete tasksByHandle[handle];\n }\n\n function run(task) {\n var callback = task.callback;\n var args = task.args;\n switch (args.length) {\n case 0:\n callback();\n break;\n case 1:\n callback(args[0]);\n break;\n case 2:\n callback(args[0], args[1]);\n break;\n case 3:\n callback(args[0], args[1], args[2]);\n break;\n default:\n callback.apply(undefined, args);\n break;\n }\n }\n\n function runIfPresent(handle) {\n // From the spec: \"Wait until any invocations of this algorithm started before this one have completed.\"\n // So if we're currently running a task, we'll need to delay this invocation.\n if (currentlyRunningATask) {\n // Delay by doing a setTimeout. setImmediate was tried instead, but in Firefox 7 it generated a\n // \"too much recursion\" error.\n setTimeout(runIfPresent, 0, handle);\n } else {\n var task = tasksByHandle[handle];\n if (task) {\n currentlyRunningATask = true;\n try {\n run(task);\n } finally {\n clearImmediate(handle);\n currentlyRunningATask = false;\n }\n }\n }\n }\n\n function installNextTickImplementation() {\n registerImmediate = function(handle) {\n process.nextTick(function () { runIfPresent(handle); });\n };\n }\n\n function canUsePostMessage() {\n // The test against `importScripts` prevents this implementation from being installed inside a web worker,\n // where `global.postMessage` means something completely different and can't be used for this purpose.\n if (global.postMessage && !global.importScripts) {\n var postMessageIsAsynchronous = true;\n var oldOnMessage = global.onmessage;\n global.onmessage = function() {\n postMessageIsAsynchronous = false;\n };\n global.postMessage(\"\", \"*\");\n global.onmessage = oldOnMessage;\n return postMessageIsAsynchronous;\n }\n }\n\n function installPostMessageImplementation() {\n // Installs an event handler on `global` for the `message` event: see\n // * https://developer.mozilla.org/en/DOM/window.postMessage\n // * http://www.whatwg.org/specs/web-apps/current-work/multipage/comms.html#crossDocumentMessages\n\n var messagePrefix = \"setImmediate$\" + Math.random() + \"$\";\n var onGlobalMessage = function(event) {\n if (event.source === global &&\n typeof event.data === \"string\" &&\n event.data.indexOf(messagePrefix) === 0) {\n runIfPresent(+event.data.slice(messagePrefix.length));\n }\n };\n\n if (global.addEventListener) {\n global.addEventListener(\"message\", onGlobalMessage, false);\n } else {\n global.attachEvent(\"onmessage\", onGlobalMessage);\n }\n\n registerImmediate = function(handle) {\n global.postMessage(messagePrefix + handle, \"*\");\n };\n }\n\n function installMessageChannelImplementation() {\n var channel = new MessageChannel();\n channel.port1.onmessage = function(event) {\n var handle = event.data;\n runIfPresent(handle);\n };\n\n registerImmediate = function(handle) {\n channel.port2.postMessage(handle);\n };\n }\n\n function installReadyStateChangeImplementation() {\n var html = doc.documentElement;\n registerImmediate = function(handle) {\n // Create a <script> element; its readystatechange event will be fired asynchronously once it is inserted\n // into the document. Do so, thus queuing up the task. Remember to clean up once it's been called.\n var script = doc.createElement(\"script\");\n script.onreadystatechange = function () {\n runIfPresent(handle);\n script.onreadystatechange = null;\n html.removeChild(script);\n script = null;\n };\n html.appendChild(script);\n };\n }\n\n function installSetTimeoutImplementation() {\n registerImmediate = function(handle) {\n setTimeout(runIfPresent, 0, handle);\n };\n }\n\n // If supported, we should attach to the prototype of global, since that is where setTimeout et al. live.\n var attachTo = Object.getPrototypeOf && Object.getPrototypeOf(global);\n attachTo = attachTo && attachTo.setTimeout ? attachTo : global;\n\n // Don't get fooled by e.g. browserify environments.\n if ({}.toString.call(global.process) === \"[object process]\") {\n // For Node.js before 0.9\n installNextTickImplementation();\n\n } else if (canUsePostMessage()) {\n // For non-IE10 modern browsers\n installPostMessageImplementation();\n\n } else if (global.MessageChannel) {\n // For web workers, where supported\n installMessageChannelImplementation();\n\n } else if (doc && \"onreadystatechange\" in doc.createElement(\"script\")) {\n // For IE 6–8\n installReadyStateChangeImplementation();\n\n } else {\n // For older browsers\n installSetTimeoutImplementation();\n }\n\n attachTo.setImmediate = setImmediate;\n attachTo.clearImmediate = clearImmediate;\n}(typeof self === \"undefined\" ? typeof global === \"undefined\" ? this : global : self));\n\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../webpack/buildin/global.js */ \"./node_modules/webpack/buildin/global.js\"), __webpack_require__(/*! ./../process/browser.js */ \"./node_modules/process/browser.js\")))\n\n//# sourceURL=webpack:///./node_modules/setimmediate/setImmediate.js?");
/***/ }),
/***/ "./node_modules/timers-browserify/main.js":
/*!************************************************!*\
!*** ./node_modules/timers-browserify/main.js ***!
\************************************************/
/*! no static exports found */
/***/ (function(module, exports, __webpack_require__) {
eval("/* WEBPACK VAR INJECTION */(function(global) {var scope = (typeof global !== \"undefined\" && global) ||\n (typeof self !== \"undefined\" && self) ||\n window;\nvar apply = Function.prototype.apply;\n\n// DOM APIs, for completeness\n\nexports.setTimeout = function() {\n return new Timeout(apply.call(setTimeout, scope, arguments), clearTimeout);\n};\nexports.setInterval = function() {\n return new Timeout(apply.call(setInterval, scope, arguments), clearInterval);\n};\nexports.clearTimeout =\nexports.clearInterval = function(timeout) {\n if (timeout) {\n timeout.close();\n }\n};\n\nfunction Timeout(id, clearFn) {\n this._id = id;\n this._clearFn = clearFn;\n}\nTimeout.prototype.unref = Timeout.prototype.ref = function() {};\nTimeout.prototype.close = function() {\n this._clearFn.call(scope, this._id);\n};\n\n// Does not start the time, just sets up the members needed.\nexports.enroll = function(item, msecs) {\n clearTimeout(item._idleTimeoutId);\n item._idleTimeout = msecs;\n};\n\nexports.unenroll = function(item) {\n clearTimeout(item._idleTimeoutId);\n item._idleTimeout = -1;\n};\n\nexports._unrefActive = exports.active = function(item) {\n clearTimeout(item._idleTimeoutId);\n\n var msecs = item._idleTimeout;\n if (msecs >= 0) {\n item._idleTimeoutId = setTimeout(function onTimeout() {\n if (item._onTimeout)\n item._onTimeout();\n }, msecs);\n }\n};\n\n// setimmediate attaches itself to the global object\n__webpack_require__(/*! setimmediate */ \"./node_modules/setimmediate/setImmediate.js\");\n// On some exotic environments, it's not clear which object `setimmediate` was\n// able to install onto. Search each possibility in the same order as the\n// `setimmediate` library.\nexports.setImmediate = (typeof self !== \"undefined\" && self.setImmediate) ||\n (typeof global !== \"undefined\" && global.setImmediate) ||\n (this && this.setImmediate);\nexports.clearImmediate = (typeof self !== \"undefined\" && self.clearImmediate) ||\n (typeof global !== \"undefined\" && global.clearImmediate) ||\n (this && this.clearImmediate);\n\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../webpack/buildin/global.js */ \"./node_modules/webpack/buildin/global.js\")))\n\n//# sourceURL=webpack:///./node_modules/timers-browserify/main.js?");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordion.vue?vue&type=template&id=f0309300&":
/*!***********************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/accordion/accordion.vue?vue&type=template&id=f0309300& ***!
\***********************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n { staticClass: \"portal-accordion\" },\n _vm._l(_vm.items, function(item, key) {\n return _c(_vm.getComponentName(item.component), {\n key: \"item_\" + key,\n tag: \"component\",\n attrs: { item: item, index: key },\n on: {\n showItem: function($event) {\n return _vm.showItem($event)\n }\n }\n })\n }),\n 1\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordion.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue?vue&type=template&id=4eccf189&":
/*!******************************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue?vue&type=template&id=4eccf189& ***!
\******************************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n { class: [\"portal-accordion-sub-content\", _vm.active ? \"active\" : \"\"] },\n [\n _c(\n \"div\",\n {\n class: _vm.classes,\n attrs: { title: _vm.item.title },\n on: { click: _vm.openItemAccordion }\n },\n [\n _c(\"p\", { staticClass: \"portal-accordion-sub-title\" }, [\n _vm._v(\"\\n\\t\\t\\t\" + _vm._s(_vm.item.title) + \"\\n\\t\\t\")\n ]),\n _vm._v(\" \"),\n _c(\n \"span\",\n {\n staticClass: \"portal-accordion-icon\",\n attrs: { title: _vm.title }\n },\n [\n _c(\"i\", {\n class: [\"portal-icon\", _vm.item.isEdited ? \"icon-edited\" : \"\"]\n })\n ]\n )\n ]\n ),\n _vm._v(\" \"),\n _vm._l(_vm.item.children, function(child, key) {\n return _c(\"accordion_content\", {\n key: \"content_\" + key,\n attrs: { active: _vm.active, item: child }\n })\n })\n ],\n 2\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionContent.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue?vue&type=template&id=2fca76ec&":
/*!***********************************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue?vue&type=template&id=2fca76ec& ***!
\***********************************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n { class: [\"portal-accordion-sub-content\", _vm.active ? \"active\" : \"\"] },\n [\n _c(\n \"div\",\n {\n class: _vm.classes,\n attrs: { title: _vm.item.title },\n on: { click: _vm.openItemAccordion }\n },\n [\n _c(\"p\", { class: \"portal-accordion-sub-title\" }, [\n _vm._v(\"\\n\\t\\t\\t\" + _vm._s(_vm.item.title) + \"\\n\\t\\t\")\n ]),\n _vm._v(\" \"),\n !_vm.item.isTag\n ? _c(\"span\", { staticClass: \"portal-accordion-icon\" }, [\n _c(\n \"button\",\n {\n staticClass: \"bouton cursor-pointer\",\n attrs: { type: \"button\" },\n on: {\n click: function($event) {\n $event.stopPropagation()\n return _vm.editClassement($event)\n }\n }\n },\n [_c(\"i\", { staticClass: \"portal-icon fa fa-caret-down\" })]\n ),\n _vm._v(\" \"),\n _vm.showFormClassement\n ? _c(\n \"div\",\n {\n staticClass: \"classement\",\n style: _vm.styleClassement,\n on: {\n click: function($event) {\n $event.stopPropagation()\n }\n }\n },\n [\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model.trim\",\n value: _vm.item.classement,\n expression: \"item.classement\",\n modifiers: { trim: true }\n }\n ],\n ref: \"input_classement\",\n attrs: {\n type: \"text\",\n list: \"classements\",\n name: \"classement\",\n id: \"classement\"\n },\n domProps: { value: _vm.item.classement },\n on: {\n keyup: function($event) {\n if (\n !$event.type.indexOf(\"key\") &&\n _vm._k(\n $event.keyCode,\n \"enter\",\n 13,\n $event.key,\n \"Enter\"\n )\n ) {\n return null\n }\n return _vm.saveClassement($event)\n },\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.$set(\n _vm.item,\n \"classement\",\n $event.target.value.trim()\n )\n },\n blur: function($event) {\n return _vm.$forceUpdate()\n }\n }\n }),\n _vm._v(\" \"),\n _c(\n \"datalist\",\n { attrs: { id: \"classements\" } },\n _vm._l(_vm.$cms.framesClassements, function(\n classement,\n key\n ) {\n return _c(\"option\", {\n key: \"classement_\" + key,\n domProps: { value: classement }\n })\n }),\n 0\n ),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: { type: \"button\" },\n on: { click: _vm.saveClassement }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"save\")))]\n )\n ]\n )\n : _vm._e()\n ])\n : _vm._e()\n ]\n ),\n _vm._v(\" \"),\n _vm.item.children\n ? _vm._l(_vm.item.children, function(child, key) {\n return _c(\"accordion_frame_content\", {\n key: \"frame_content_\" + key,\n attrs: { active: _vm.active, item: child }\n })\n })\n : _c(\"p\", [_vm._v(_vm._s(_vm.$cms.getMessage(\"no_frame\")))])\n ],\n 2\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionFrameContent.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue?vue&type=template&id=63f464a0&":
/*!********************************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue?vue&type=template&id=63f464a0& ***!
\********************************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n { class: [\"portal-accordion-item\", _vm.item.active ? \"active\" : \"\"] },\n [\n _c(\n \"h3\",\n {\n staticClass: \"portal-accordion-title cursor-pointer\",\n on: {\n click: function($event) {\n return _vm.$emit(\"showItem\", _vm.index)\n }\n }\n },\n [\n _vm._v(\"\\n\\t\\t\" + _vm._s(_vm.item.title) + \"\\n\\t\\t\"),\n _c(\"span\", { staticClass: \"portal-accordion-icon\" }, [\n _c(\"i\", {\n staticClass: \"portal-accordion-icon-add fa fa-plus-circle\",\n attrs: {\n \"aria-hidden\": \"true\",\n title: _vm.$cms.getMessage(\"accordion_add\")\n },\n on: { click: _vm.add }\n }),\n _vm._v(\" \"),\n _c(\"i\", {\n class: [\n \"fa cursor-pointer\",\n _vm.item.active ? \"fa-caret-down\" : \"fa-caret-left\"\n ],\n attrs: { \"aria-hidden\": \"true\" },\n on: {\n click: function($event) {\n return _vm.$emit(\"showItem\", _vm.index)\n }\n }\n })\n ])\n ]\n ),\n _vm._v(\" \"),\n _vm.item.active\n ? _c(\"nav\", { staticClass: \"portal-accordion-filters\" }, [\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.search,\n expression: \"search\"\n }\n ],\n staticClass: \"portal-accordion-filter\",\n attrs: {\n name: \"search\",\n type: \"text\",\n placeholder: _vm.$cms.getMessage(\"frame_filter_placeholder\")\n },\n domProps: { value: _vm.search },\n on: {\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.search = $event.target.value\n }\n }\n }),\n _vm._v(\" \"),\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.filter,\n expression: \"filter\"\n }\n ],\n staticClass: \"portal-accordion-filter\",\n on: {\n change: function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.filter = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n }\n }\n },\n [\n _c(\"option\", { attrs: { value: \"\" } }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"filter_all\")))\n ]),\n _vm._v(\" \"),\n _vm._l(_vm.filters, function(filter, key) {\n return _c(\n \"option\",\n { key: key, domProps: { value: filter } },\n [_vm._v(_vm._s(filter))]\n )\n })\n ],\n 2\n )\n ])\n : _vm._e(),\n _vm._v(\" \"),\n _c(\n \"div\",\n {\n directives: [\n {\n name: \"show\",\n rawName: \"v-show\",\n value: _vm.item.active,\n expression: \"item.active\"\n }\n ],\n class: [\"portal-accordion-content\", _vm.item.active ? \"active\" : \"\"],\n on: { scroll: _vm.hiddenEditClassment }\n },\n _vm._l(_vm.children, function(child, key) {\n return _c(\"accordion_frame_content\", {\n key: \"frame_\" + key,\n attrs: { item: child, active: _vm.item.active }\n })\n }),\n 1\n )\n ]\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionFrameItem.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue?vue&type=template&id=99c7bbd6&":
/*!*************************************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue?vue&type=template&id=99c7bbd6& ***!
\*************************************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n { class: [\"portal-accordion-sub-content\", _vm.active ? \"active\" : \"\"] },\n [\n _c(\n \"div\",\n {\n class: _vm.classes,\n attrs: { title: _vm.item.title },\n on: { click: _vm.openItemAccordion }\n },\n [\n _c(\"p\", { class: \"portal-accordion-sub-title\" }, [\n _vm._v(\"\\n\\t\\t\\t\" + _vm._s(_vm.item.title) + \"\\n\\t\\t\")\n ]),\n _vm._v(\" \"),\n _c(\n \"span\",\n { staticClass: \"portal-accordion-icon\" },\n [\n _c(\"i\", {\n class: [\n \"portal-icon\",\n _vm.isUsed ? \"fa fa-check-circle-o\" : \"\"\n ],\n attrs: { title: _vm.isUsedTitle }\n }),\n _vm._v(\" \"),\n _c(\"i\", {\n class: [\"portal-icon\", _vm.item.isEdited ? \"icon-edited\" : \"\"],\n attrs: { title: _vm.isEditedTitle }\n }),\n _vm._v(\" \"),\n !_vm.item.isTag\n ? [\n _c(\n \"button\",\n {\n staticClass: \"bouton cursor-pointer\",\n attrs: { type: \"button\" },\n on: {\n click: function($event) {\n $event.stopPropagation()\n return _vm.editClassment($event)\n }\n }\n },\n [_c(\"i\", { staticClass: \"portal-icon fa fa-caret-down\" })]\n ),\n _vm._v(\" \"),\n _c(\n \"div\",\n {\n directives: [\n {\n name: \"show\",\n rawName: \"v-show\",\n value: _vm.showFormClassement,\n expression: \"showFormClassement\"\n }\n ],\n staticClass: \"classement\",\n style: _vm.styleClassement,\n on: {\n click: function($event) {\n $event.stopPropagation()\n }\n }\n },\n [\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model.trim\",\n value: _vm.item.classement,\n expression: \"item.classement\",\n modifiers: { trim: true }\n }\n ],\n ref: \"input_classement\",\n attrs: {\n type: \"text\",\n list: \"classements\",\n name: \"classement\",\n id: \"classement\"\n },\n domProps: { value: _vm.item.classement },\n on: {\n keyup: function($event) {\n if (\n !$event.type.indexOf(\"key\") &&\n _vm._k(\n $event.keyCode,\n \"enter\",\n 13,\n $event.key,\n \"Enter\"\n )\n ) {\n return null\n }\n return _vm.saveClassment($event)\n },\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.$set(\n _vm.item,\n \"classement\",\n $event.target.value.trim()\n )\n },\n blur: function($event) {\n return _vm.$forceUpdate()\n }\n }\n }),\n _vm._v(\" \"),\n _c(\n \"datalist\",\n { attrs: { id: \"classements\" } },\n _vm._l(_vm.$cms.gabaritsClassements, function(\n classement,\n key\n ) {\n return _c(\"option\", {\n key: \"classement_\" + key,\n domProps: { value: classement }\n })\n }),\n 0\n ),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: { type: \"button\" },\n on: { click: _vm.saveClassment }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"save\")))]\n )\n ]\n )\n ]\n : _vm._e()\n ],\n 2\n )\n ]\n ),\n _vm._v(\" \"),\n _vm.item.children\n ? _vm._l(_vm.item.children, function(child, key) {\n return _c(\"accordion_gabarit_content\", {\n key: \"gabarit_content_\" + key,\n attrs: { active: _vm.active, item: child }\n })\n })\n : _c(\"p\", [_vm._v(_vm._s(_vm.$cms.getMessage(\"no_frame\")))])\n ],\n 2\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritContent.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue?vue&type=template&id=4869c9b2&":
/*!**********************************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue?vue&type=template&id=4869c9b2& ***!
\**********************************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n { class: [\"portal-accordion-item\", _vm.item.active ? \"active\" : \"\"] },\n [\n _c(\n \"h3\",\n {\n staticClass: \"portal-accordion-title cursor-pointer\",\n on: {\n click: function($event) {\n return _vm.$emit(\"showItem\", _vm.index)\n }\n }\n },\n [\n _vm._v(\"\\n\\t\\t\" + _vm._s(_vm.item.title) + \"\\n\\t\\t\"),\n _c(\"span\", { staticClass: \"portal-accordion-icon\" }, [\n _c(\"i\", {\n staticClass: \"portal-accordion-icon-add fa fa-plus-circle\",\n attrs: {\n \"aria-hidden\": \"true\",\n title: _vm.$cms.getMessage(\"accordion_add\")\n },\n on: { click: _vm.add }\n }),\n _vm._v(\" \"),\n _c(\"i\", {\n class: [\n \"fa cursor-pointer\",\n _vm.item.active ? \"fa-caret-down\" : \"fa-caret-left\"\n ],\n attrs: { \"aria-hidden\": \"true\" },\n on: {\n click: function($event) {\n return _vm.$emit(\"showItem\", _vm.index)\n }\n }\n })\n ])\n ]\n ),\n _vm._v(\" \"),\n _vm.item.active\n ? _c(\"nav\", { staticClass: \"portal-accordion-filters\" }, [\n _c(\"div\", [\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.$cms.gabaritsDisplayType,\n expression: \"$cms.gabaritsDisplayType\"\n }\n ],\n attrs: {\n id: \"radio_classement\",\n name: \"radio_display_type\",\n type: \"radio\",\n value: \"0\"\n },\n domProps: {\n checked: _vm._q(_vm.$cms.gabaritsDisplayType, \"0\")\n },\n on: {\n change: function($event) {\n return _vm.$set(_vm.$cms, \"gabaritsDisplayType\", \"0\")\n }\n }\n }),\n _vm._v(\" \"),\n _c(\"label\", { attrs: { for: \"radio_classement\" } }, [\n _vm._v(_vm._s(this.$cms.getMessage(\"radio_classement\")))\n ]),\n _vm._v(\" \"),\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.$cms.gabaritsDisplayType,\n expression: \"$cms.gabaritsDisplayType\"\n }\n ],\n attrs: {\n id: \"radio_tree\",\n name: \"radio_display_type\",\n type: \"radio\",\n value: \"1\"\n },\n domProps: {\n checked: _vm._q(_vm.$cms.gabaritsDisplayType, \"1\")\n },\n on: {\n change: function($event) {\n return _vm.$set(_vm.$cms, \"gabaritsDisplayType\", \"1\")\n }\n }\n }),\n _vm._v(\" \"),\n _c(\"label\", { attrs: { for: \"radio_tree\" } }, [\n _vm._v(_vm._s(this.$cms.getMessage(\"radio_tree\")))\n ])\n ]),\n _vm._v(\" \"),\n _c(\"div\", [\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.$cms.showUnusedGabarit,\n expression: \"$cms.showUnusedGabarit\"\n }\n ],\n attrs: {\n id: \"show_unused_gabarit\",\n name: \"show_unused_gabarit\",\n type: \"checkbox\",\n value: \"1\"\n },\n domProps: {\n checked: Array.isArray(_vm.$cms.showUnusedGabarit)\n ? _vm._i(_vm.$cms.showUnusedGabarit, \"1\") > -1\n : _vm.$cms.showUnusedGabarit\n },\n on: {\n change: function($event) {\n var $$a = _vm.$cms.showUnusedGabarit,\n $$el = $event.target,\n $$c = $$el.checked ? true : false\n if (Array.isArray($$a)) {\n var $$v = \"1\",\n $$i = _vm._i($$a, $$v)\n if ($$el.checked) {\n $$i < 0 &&\n _vm.$set(\n _vm.$cms,\n \"showUnusedGabarit\",\n $$a.concat([$$v])\n )\n } else {\n $$i > -1 &&\n _vm.$set(\n _vm.$cms,\n \"showUnusedGabarit\",\n $$a.slice(0, $$i).concat($$a.slice($$i + 1))\n )\n }\n } else {\n _vm.$set(_vm.$cms, \"showUnusedGabarit\", $$c)\n }\n }\n }\n }),\n _vm._v(\" \"),\n _c(\"label\", { attrs: { for: \"show_unused_gabarit\" } }, [\n _vm._v(_vm._s(this.$cms.getMessage(\"show_unused_gabarit\")))\n ])\n ]),\n _vm._v(\" \"),\n _vm.$cms.gabaritsDisplayType == 0\n ? _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.filter,\n expression: \"filter\"\n }\n ],\n staticClass: \"portal-accordion-filter\",\n on: {\n change: function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.filter = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n }\n }\n },\n [\n _c(\"option\", { attrs: { value: \"\" } }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"filter_all\")))\n ]),\n _vm._v(\" \"),\n _vm._l(_vm.filters, function(filter, key) {\n return _c(\n \"option\",\n { key: key, domProps: { value: filter } },\n [_vm._v(_vm._s(filter))]\n )\n })\n ],\n 2\n )\n : _vm._e()\n ])\n : _vm._e(),\n _vm._v(\" \"),\n _c(\n \"div\",\n {\n directives: [\n {\n name: \"show\",\n rawName: \"v-show\",\n value: _vm.item.active,\n expression: \"item.active\"\n }\n ],\n class: [\"portal-accordion-content\", _vm.item.active ? \"active\" : \"\"],\n on: { scroll: _vm.hiddenEditClassment }\n },\n _vm._l(_vm.children, function(child, key) {\n return _c(\"accordion_gabarit_content\", {\n key: key,\n attrs: { item: child, active: _vm.item.active }\n })\n }),\n 1\n )\n ]\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionGabaritItem.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue?vue&type=template&id=8f54bf9a&":
/*!***************************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue?vue&type=template&id=8f54bf9a& ***!
\***************************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n { class: [\"portal-accordion-item\", _vm.item.active ? \"active\" : \"\"] },\n [\n _c(\n \"h3\",\n {\n staticClass: \"portal-accordion-title cursor-pointer\",\n on: {\n click: function($event) {\n return _vm.$emit(\"showItem\", _vm.index)\n }\n }\n },\n [\n _vm._v(\"\\n\\t\\t\" + _vm._s(_vm.item.title) + \"\\n\\t\\t\"),\n _c(\"span\", { staticClass: \"portal-accordion-icon\" }, [\n _c(\"i\", {\n staticClass: \"portal-accordion-icon-add fa fa-plus-circle\",\n attrs: {\n \"aria-hidden\": \"true\",\n title: _vm.$cms.getMessage(\"accordion_add\")\n },\n on: { click: _vm.add }\n }),\n _vm._v(\" \"),\n _c(\"i\", {\n class: [\n \"fa cursor-pointer\",\n _vm.item.active ? \"fa-caret-down\" : \"fa-caret-left\"\n ],\n attrs: { \"aria-hidden\": \"true\" },\n on: {\n click: function($event) {\n return _vm.$emit(\"showItem\", _vm.index)\n }\n }\n })\n ])\n ]\n ),\n _vm._v(\" \"),\n _vm.item.active\n ? _c(\"nav\", { staticClass: \"portal-accordion-filters\" }, [\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.filter,\n expression: \"filter\"\n }\n ],\n staticClass: \"portal-accordion-filter\",\n on: {\n change: function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.filter = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n }\n }\n },\n [\n _c(\"option\", { attrs: { value: \"\" } }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"filter_all\")))\n ]),\n _vm._v(\" \"),\n _vm._l(_vm.filters, function(filter, key) {\n return _c(\n \"option\",\n { key: key, domProps: { value: filter.title } },\n [_vm._v(_vm._s(filter.title))]\n )\n })\n ],\n 2\n )\n ])\n : _vm._e(),\n _vm._v(\" \"),\n _c(\n \"div\",\n {\n directives: [\n {\n name: \"show\",\n rawName: \"v-show\",\n value: _vm.item.active,\n expression: \"item.active\"\n }\n ],\n class: [\"portal-accordion-content\", _vm.item.active ? \"active\" : \"\"]\n },\n _vm._l(_vm.children, function(child, key) {\n return _c(\"accordion_content\", {\n key: key,\n attrs: { item: child, active: _vm.item.active }\n })\n }),\n 1\n )\n ]\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/accordion/accordionItem.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/alertError.vue?vue&type=template&id=843520c6&":
/*!**************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/alertError.vue?vue&type=template&id=843520c6& ***!
\**************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _vm.show\n ? _c(\"div\", { staticClass: \"portal-error\" }, [\n _c(\"p\", [_vm._v(_vm._s(_vm.message))]),\n _vm._v(\" \"),\n _c(\"i\", {\n staticClass: \"close fa fa-times\",\n attrs: { \"aria-hidden\": \"true\" },\n on: { click: _vm.closeError }\n })\n ])\n : _vm._e()\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/alertError.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/frame/addForm.vue?vue&type=template&id=73fdd83c&":
/*!*****************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/frame/addForm.vue?vue&type=template&id=73fdd83c& ***!
\*****************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n {\n ref: \"modal\",\n staticClass: \"portal-modal\",\n attrs: { id: \"modal\" },\n on: { click: _vm.closeModal }\n },\n [\n _c(\"div\", { ref: \"modal_frame\", staticClass: \"portal-modal-container\" }, [\n _c(\n \"div\",\n {\n staticClass: \"portal-modal-header\",\n style: _vm.dragStyle,\n on: {\n mousedown: function($event) {\n $event.preventDefault()\n return _vm.startDrag($event)\n }\n }\n },\n [\n _vm.title\n ? _c(\"h3\", { staticClass: \"portal-modal-title\" }, [\n _vm._v(_vm._s(_vm.title))\n ])\n : _vm._e(),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton close-form cursor-pointer\",\n attrs: { type: \"button\" },\n on: {\n click: function($event) {\n return _vm.$emit(\"closeFrameForm\", true)\n }\n }\n },\n [_vm._v(\"x\")]\n )\n ]\n ),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-modal-content\" }, [\n _c(\n \"form\",\n {\n staticClass: \"portal-form\",\n on: {\n submit: function($event) {\n $event.preventDefault()\n return _vm.submit($event)\n }\n }\n },\n [\n _vm.errorMessage\n ? _c(\n \"div\",\n { staticClass: \"portal-form-group\" },\n [\n _c(\"alert_error\", {\n attrs: { message: _vm.errorMessage },\n on: {\n close: function($event) {\n _vm.errorMessage = \"\"\n }\n }\n })\n ],\n 1\n )\n : _vm._e(),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"name\" }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"frame_name\")))]\n ),\n _vm._v(\" \"),\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model.trim\",\n value: _vm.name,\n expression: \"name\",\n modifiers: { trim: true }\n }\n ],\n ref: \"input_name\",\n attrs: {\n id: \"name\",\n name: \"name\",\n type: \"text\",\n required: \"\"\n },\n domProps: { value: _vm.name },\n on: {\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.name = $event.target.value.trim()\n },\n blur: function($event) {\n return _vm.$forceUpdate()\n }\n }\n })\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"layout\" }\n },\n [_vm._v(_vm._s(_vm.layoutLabel))]\n ),\n _vm._v(\" \"),\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.layout,\n expression: \"layout\"\n }\n ],\n attrs: { id: \"layout\", disabled: _vm.noLayout },\n on: {\n change: [\n function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.layout = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n },\n _vm.updateParent\n ]\n }\n },\n [\n _vm.pages.length != 0\n ? _c(\n \"optgroup\",\n {\n attrs: {\n label: _vm.$cms.getMessage(\n \"heritage_label_group_page\"\n )\n }\n },\n _vm._l(_vm.pages, function(page, key) {\n return _c(\n \"option\",\n {\n key: \"page_\" + key,\n domProps: { value: \"page_\" + page.id }\n },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\\t\" +\n _vm._s(page.name) +\n \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\"\n )\n ]\n )\n }),\n 0\n )\n : _vm._e(),\n _vm._v(\" \"),\n _vm.gabarits.length != 0\n ? _c(\n \"optgroup\",\n {\n attrs: {\n label: _vm.$cms.getMessage(\n \"heritage_label_group_model\"\n )\n }\n },\n _vm._l(_vm.gabarits, function(gabarit, key) {\n return _c(\n \"option\",\n {\n key: key,\n domProps: { value: \"gabarit_\" + gabarit.id }\n },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\\t\\t\" +\n _vm._s(gabarit.name) +\n \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\"\n )\n ]\n )\n }),\n 0\n )\n : _vm._e()\n ]\n )\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"parent\" }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"frame_parent\")))]\n ),\n _vm._v(\" \"),\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.parent,\n expression: \"parent\"\n }\n ],\n attrs: {\n id: \"parent\",\n name: \"frame_parent\",\n required: \"\",\n disabled: _vm.noLayout\n },\n on: {\n change: function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.parent = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n }\n }\n },\n _vm._l(_vm.$cms.zoneList, function(parent, key) {\n return _c(\n \"option\",\n { key: key, domProps: { value: parent.semantic.id_tag } },\n [_vm._v(_vm._s(parent.name))]\n )\n }),\n 0\n )\n ]),\n _vm._v(\" \"),\n _c(\"semantics\", {\n attrs: { semantic: _vm.semantic, editable: \"false\" },\n on: { change: _vm.updateSemantic, update: _vm.updateSemantic }\n }),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-buttons\" }, [\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: { type: \"submit\", disabled: _vm.noLayout }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"save\")))]\n )\n ])\n ],\n 1\n )\n ])\n ])\n ]\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/frame/addForm.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/frame/frameForm.vue?vue&type=template&id=0eab1b6e&":
/*!*******************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/frame/frameForm.vue?vue&type=template&id=0eab1b6e& ***!
\*******************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n [\n this.isEntity && !this.isOpacFrame\n ? _c(\"div\", { staticClass: \"portal-form-group-btn\" }, [\n _c(\n \"button\",\n {\n staticClass: \"bouton clear-btn\",\n attrs: { type: \"button\" },\n on: { click: _vm.cleanCache }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"frame_clean_cache\")))]\n )\n ])\n : _vm._e(),\n _vm._v(\" \"),\n _vm.errorMessage\n ? _c(\n \"div\",\n { staticClass: \"portal-form-group\" },\n [\n _c(\"alert_error\", {\n attrs: { message: _vm.errorMessage },\n on: {\n close: function($event) {\n _vm.errorMessage = \"\"\n }\n }\n })\n ],\n 1\n )\n : _vm._e(),\n _vm._v(\" \"),\n _vm.showForm\n ? _c(\"add_form\", {\n attrs: {\n id_tag: _vm.data.item.semantic.id_tag,\n init_name: _vm.name,\n pageList: _vm.pagesWithoutFrame,\n gabaritList: _vm.gabaritWithoutFrame,\n title: _vm.modalTitle\n },\n on: { closeFrameForm: _vm.closeForm, submit: _vm.formSubmit }\n })\n : _vm._e(),\n _vm._v(\" \"),\n _vm.isOpacFrame\n ? [\n _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"frame-name\" }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"gabarit_name\")))]\n ),\n _vm._v(\" \"),\n _c(\"input\", {\n attrs: {\n id: \"frame-name\",\n name: \"frame_name\",\n type: \"text\",\n readonly: \"readonly\"\n },\n domProps: { value: _vm.name }\n }),\n _vm._v(\" \"),\n _c(\n \"div\",\n [\n _c(\"list\", {\n attrs: {\n list: _vm.getPageList(),\n title: _vm.$cms.getMessage(\"pages_list\"),\n empty_msg: _vm.$cms.getMessage(\"no_pages_using_frame\"),\n add_msg: _vm.$cms.getMessage(\"add_page\"),\n removable: false\n },\n on: { add: _vm.addPage }\n }),\n _vm._v(\" \"),\n _c(\"list\", {\n attrs: {\n list: _vm.getGabaritList(),\n title: _vm.$cms.getMessage(\"gabarits_list\"),\n empty_msg: _vm.$cms.getMessage(\"no_gabraits_using_frame\"),\n add_msg: _vm.$cms.getMessage(\"add_gabarit\"),\n removable: false\n },\n on: { add: _vm.addGabarit }\n })\n ],\n 1\n )\n ])\n ]\n : _vm.isEntity && !_vm.isOpacFrame\n ? [\n _c(\"div\", { attrs: { id: \"frame_container\" } }),\n _vm._v(\" \"),\n _c(\n \"div\",\n [\n _c(\"list\", {\n attrs: {\n list: _vm.pageList,\n title: _vm.$cms.getMessage(\"pages_list\"),\n empty_msg: _vm.$cms.getMessage(\"no_pages_using_frame\"),\n removable: true,\n addable: _vm.pageAddable,\n add_msg: _vm.$cms.getMessage(\"add_page\")\n },\n on: {\n add: _vm.addPage,\n itemRemove: _vm.removePage,\n itemClicked: _vm.openPage\n }\n }),\n _vm._v(\" \"),\n _c(\"list\", {\n attrs: {\n list: _vm.gabaritList,\n title: _vm.$cms.getMessage(\"gabarits_list\"),\n empty_msg: _vm.$cms.getMessage(\"no_gabraits_using_frame\"),\n removable: true,\n addable: _vm.gabaritAddable,\n add_msg: _vm.$cms.getMessage(\"add_gabarit\")\n },\n on: {\n add: _vm.addGabarit,\n itemRemove: _vm.removeGabarit,\n itemClicked: _vm.openGabarit\n }\n })\n ],\n 1\n )\n ]\n : [\n _vm.addForm\n ? _c(\"div\", { attrs: { id: \"add_frame_container\" } })\n : [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"frame-module\" }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"frame_module\")))]\n ),\n _vm._v(\" \"),\n _vm._l(_vm.$cms.modules, function(module, key) {\n return _c(\n \"p\",\n {\n key: key,\n staticClass: \"portal-module\",\n on: {\n click: function($event) {\n return _vm.getForm(key)\n }\n }\n },\n [_vm._v(_vm._s(module.name))]\n )\n })\n ]\n ]\n ],\n 2\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/frame/frameForm.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/frameList.vue?vue&type=template&id=41943eac&":
/*!*************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/frameList.vue?vue&type=template&id=41943eac& ***!
\*************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n { staticClass: \"portal-list\" },\n [\n _vm.showFrameForm\n ? _c(\"frame_form\", {\n attrs: { view: \"page\" },\n on: { closeFrameForm: _vm.closeFrameForm }\n })\n : _vm._e(),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-frame-list\" }, [\n _c(\n \"h4\",\n {\n directives: [\n {\n name: \"show\",\n rawName: \"v-show\",\n value: _vm.title,\n expression: \"title\"\n }\n ],\n staticClass: \"portal-frame-list-title\"\n },\n [_vm._v(_vm._s(_vm.title))]\n ),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n directives: [\n {\n name: \"show\",\n rawName: \"v-show\",\n value: _vm.is_entity,\n expression: \"is_entity\"\n }\n ],\n staticClass: \"bouton\",\n attrs: { type: \"button\" },\n on: { click: _vm.openFrameForm }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"add_frame\")))]\n )\n ]),\n _vm._v(\" \"),\n _c(\n \"div\",\n { staticClass: \"frame-classements\" },\n _vm._l(_vm.classements, function(classement, index) {\n return _c(\n \"fieldset\",\n { key: \"classement_\" + index, staticClass: \"frame-classement\" },\n [\n _c(\"legend\", { staticClass: \"frame-classement-title\" }, [\n _vm._v(_vm._s(classement.title))\n ]),\n _vm._v(\" \"),\n _c(\n \"div\",\n { staticClass: \"frame-classement-container\" },\n _vm._l(classement.children, function(item, key) {\n return _c(\n \"div\",\n {\n key: key,\n staticClass: \"frame-classement-item cursor-pointer\",\n on: {\n click: function($event) {\n return _vm.itemClicked(item)\n }\n }\n },\n [\n _c(\n \"span\",\n {\n staticClass: \"portal-list-item-title\",\n attrs: { title: item.name }\n },\n [_vm._v(_vm._s(item.name))]\n ),\n _vm._v(\" \"),\n _vm.isRemovable(item)\n ? _c(\"i\", {\n staticClass: \"fa fa-times remove-icon\",\n attrs: { title: _vm.$cms.getMessage(\"delete\") },\n on: {\n click: function($event) {\n $event.stopPropagation()\n return _vm.itemRemove(item)\n }\n }\n })\n : _vm._e()\n ]\n )\n }),\n 0\n )\n ]\n )\n }),\n 0\n )\n ],\n 1\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/frameList.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue?vue&type=template&id=2ffc205c&":
/*!***********************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue?vue&type=template&id=2ffc205c& ***!
\***********************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"div\", { staticClass: \"gabarit-form\" }, [\n _c(\n \"form\",\n {\n staticClass: \"portal-form\",\n attrs: { action: \"\", method: \"post\", name: \"portal_form\" },\n on: {\n submit: function($event) {\n $event.preventDefault()\n return _vm.submit($event)\n }\n }\n },\n [\n _vm.errorMessage\n ? _c(\n \"div\",\n { staticClass: \"portal-form-group\" },\n [\n _c(\"alert_error\", {\n attrs: { message: _vm.errorMessage },\n on: {\n close: function($event) {\n _vm.errorMessage = \"\"\n }\n }\n })\n ],\n 1\n )\n : _vm._e(),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"gabarit-name\" }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"gabarit_name\")))]\n ),\n _vm._v(\" \"),\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model.trim\",\n value: _vm.name,\n expression: \"name\",\n modifiers: { trim: true }\n }\n ],\n ref: \"gabarit_input_name\",\n attrs: { id: \"gabarit-name\", name: \"gabarit_name\", type: \"text\" },\n domProps: { value: _vm.name },\n on: {\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.name = $event.target.value.trim()\n },\n blur: function($event) {\n return _vm.$forceUpdate()\n }\n }\n })\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"cursor-pointer\",\n attrs: { for: \"gabarit-default\" }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"gabarit_default\")))]\n ),\n _vm._v(\" \"),\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.isDefault,\n expression: \"isDefault\"\n }\n ],\n attrs: {\n id: \"gabarit-default\",\n name: \"gabarit_default\",\n type: \"checkbox\",\n value: \"1\",\n disabled: _vm.isDefaultGabarit\n },\n domProps: {\n checked: Array.isArray(_vm.isDefault)\n ? _vm._i(_vm.isDefault, \"1\") > -1\n : _vm.isDefault\n },\n on: {\n change: function($event) {\n var $$a = _vm.isDefault,\n $$el = $event.target,\n $$c = $$el.checked ? true : false\n if (Array.isArray($$a)) {\n var $$v = \"1\",\n $$i = _vm._i($$a, $$v)\n if ($$el.checked) {\n $$i < 0 && (_vm.isDefault = $$a.concat([$$v]))\n } else {\n $$i > -1 &&\n (_vm.isDefault = $$a\n .slice(0, $$i)\n .concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.isDefault = $$c\n }\n }\n }\n })\n ]),\n _vm._v(\" \"),\n _c(\n \"div\",\n { staticClass: \"portal-form-group\" },\n [\n _c(\"label\", { attrs: { for: \"heritage-selector\" } }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"heritage_label\")))\n ]),\n _vm._v(\" \"),\n _c(\"gabarit_heritage\", {\n attrs: { data: _vm.data },\n on: { change: _vm.changeHeritage }\n })\n ],\n 1\n ),\n _vm._v(\" \"),\n _vm.hasLayoutsList\n ? _c(\n \"div\",\n { staticClass: \"portal-form-group\" },\n [\n _c(\"label\", { attrs: { for: \"heritage-list\" } }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"layouts_list\")))\n ]),\n _vm._v(\" \"),\n _vm._l(_vm.layouts_list, function(layout, index) {\n return [\n _c(\"p\", [\n _vm._v(_vm._s(layout) + \" \"),\n _c(\"i\", {\n staticClass: \"fa fa-times cursor-pointer remove\",\n attrs: { \"aria-hidden\": \"true\" },\n on: {\n click: function($event) {\n return _vm.removeLayout(index)\n }\n }\n })\n ])\n ]\n })\n ],\n 2\n )\n : _vm._e(),\n _vm._v(\" \"),\n _vm.id > 0\n ? _c(\n \"div\",\n { staticClass: \"portal-form-group\" },\n [\n _vm.showPageForm\n ? _c(\"page_form\", {\n attrs: { pagesSelected: _vm.listPageId },\n on: {\n addPage: _vm.addPage,\n closePageForm: _vm.closePageForm\n }\n })\n : _vm._e(),\n _vm._v(\" \"),\n _vm.$cms.pages.length > 0\n ? _c(\"list\", {\n attrs: {\n list: _vm.pages,\n addable: _vm.pageIsAddable,\n title: _vm.$cms.getMessage(\"gabarit_page_list\"),\n add_msg: _vm.$cms.getMessage(\"add_page\")\n },\n on: { add: _vm.openPageForm, itemClicked: _vm.openSubNav }\n })\n : _vm._e()\n ],\n 1\n )\n : _vm._e(),\n _vm._v(\" \"),\n _vm.id > 0\n ? _c(\n \"div\",\n { staticClass: \"portal-form-group\" },\n [\n _c(\"frame_list\", {\n attrs: {\n list: _vm.frameList,\n title: _vm.title,\n is_entity: _vm.isEntity\n },\n on: { frameRemove: _vm.frameRemove }\n })\n ],\n 1\n )\n : _vm._e(),\n _vm._v(\" \"),\n _vm.id > 0\n ? _c(\n \"div\",\n { staticClass: \"portal-form-group\" },\n [\n _c(\"list\", {\n attrs: {\n list: _vm.inheritedModel,\n addable: false,\n title: _vm.$cms.getMessage(\"gabarit_legacy_heritage\"),\n empty_msg: _vm.$cms.getMessage(\"gabarit_no_legacy_heritage\")\n }\n })\n ],\n 1\n )\n : _vm._e(),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-buttons\" }, [\n _c(\"div\", { staticClass: \"left\" }, [\n _c(\"button\", { staticClass: \"bouton\", attrs: { type: \"submit\" } }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"save\")))\n ])\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"right\" }, [\n _vm.isEntity\n ? _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: { type: \"button\" },\n on: { click: _vm.duplicate }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"duplicate\")))]\n )\n : _vm._e(),\n _vm._v(\" \"),\n _vm.isEntity\n ? _c(\n \"button\",\n {\n staticClass: \"bouton delete\",\n attrs: { type: \"button\", disabled: _vm.cannotDelete },\n on: { click: _vm.remove }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"delete\")))]\n )\n : _vm._e()\n ])\n ])\n ]\n )\n ])\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/gabarit/gabaritForm.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue?vue&type=template&id=ff7d2fd2&":
/*!***************************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue?vue&type=template&id=ff7d2fd2& ***!
\***************************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"div\", { staticClass: \"portal-heritage\" }, [\n _vm.heritageList.length > 0\n ? _c(\"div\", [\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.heritageSelected,\n expression: \"heritageSelected\"\n }\n ],\n attrs: { id: \"heritage-selector\", name: \"heritage_selector\" },\n on: {\n change: [\n function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.heritageSelected = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n },\n _vm.changeHeritage\n ]\n }\n },\n [\n _c(\"option\", { attrs: { value: \"\" } }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"make_no_heritage\")))\n ]),\n _vm._v(\" \"),\n _vm._l(_vm.heritageList, function(gabarit, key) {\n return _c(\n \"option\",\n { key: key, domProps: { value: gabarit.id } },\n [_vm._v(\"\\n\\t\\t\\t\\t\" + _vm._s(gabarit.name) + \"\\n\\t\\t\\t\")]\n )\n })\n ],\n 2\n )\n ])\n : _c(\"div\", [\n _c(\"p\", [_vm._v(_vm._s(_vm.$cms.getMessage(\"no_heritage\")))])\n ])\n ])\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/gabarit/gabaritHeritage.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue?vue&type=template&id=314d2fea&":
/*!***************************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue?vue&type=template&id=314d2fea& ***!
\***************************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n {\n staticClass: \"portal-modal\",\n on: {\n click: function($event) {\n return _vm.$emit(\"closePageForm\", $event, false)\n }\n }\n },\n [\n _c(\"div\", { ref: \"modal_frame\", staticClass: \"portal-modal-container\" }, [\n _c(\n \"div\",\n {\n staticClass: \"portal-modal-header\",\n style: _vm.dragStyle,\n on: {\n mousedown: function($event) {\n $event.preventDefault()\n return _vm.startDrag($event)\n }\n }\n },\n [\n _c(\"h3\", { staticClass: \"portal-modal-title\" }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"gabarit_page_add\")))\n ]),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton close-form cursor-pointer\",\n on: {\n click: function($event) {\n return _vm.$emit(\"closePageForm\", $event, false)\n }\n }\n },\n [_vm._v(\"x\")]\n )\n ]\n ),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-modal-content\" }, [\n _c(\n \"form\",\n { staticClass: \"portal-form\", on: { submit: _vm.submit } },\n [\n _vm.errorMessage\n ? _c(\n \"div\",\n { staticClass: \"portal-form-group\" },\n [\n _c(\"alert_error\", {\n attrs: { message: _vm.errorMessage },\n on: {\n close: function($event) {\n _vm.errorMessage = \"\"\n }\n }\n })\n ],\n 1\n )\n : _vm._e(),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"frame-parent-heritage\" }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"gabarit_page_label\")))]\n ),\n _vm._v(\" \"),\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.search,\n expression: \"search\"\n }\n ],\n ref: \"page_input_search\",\n staticClass: \"portal-modal-filter\",\n attrs: {\n id: \"search_frame_form\",\n name: \"search\",\n type: \"text\",\n placeholder: _vm.$cms.getMessage(\"frame_filter_placeholder\")\n },\n domProps: { value: _vm.search },\n on: {\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.search = $event.target.value\n }\n }\n }),\n _vm._v(\" \"),\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.pageId,\n expression: \"pageId\"\n }\n ],\n ref: \"frameInputSelector\",\n staticClass: \"portal-modal-frame-list\",\n attrs: {\n id: \"frame-parent-heritage\",\n name: \"frame_cadre_id\",\n required: \"\"\n },\n on: {\n change: function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.pageId = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n }\n }\n },\n _vm._l(_vm.filteredList, function(page, key) {\n return _c(\n \"option\",\n { key: key, domProps: { value: page.id } },\n [_vm._v(_vm._s(page.name))]\n )\n }),\n 0\n )\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-buttons\" }, [\n _c(\n \"button\",\n { staticClass: \"bouton\", attrs: { type: \"submit\" } },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"cms_page_add\")))]\n )\n ])\n ]\n )\n ])\n ])\n ]\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/gabarit/gabaritPageForm.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue?vue&type=template&id=76a433a8&":
/*!************************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue?vue&type=template&id=76a433a8& ***!
\************************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n {\n staticClass: \"portal-modal\",\n on: {\n click: function($event) {\n return _vm.$emit(\"closeAttributeForm\", $event, false)\n }\n }\n },\n [\n _c(\n \"div\",\n { ref: \"modal_attribute\", staticClass: \"portal-modal-container\" },\n [\n _c(\n \"div\",\n {\n staticClass: \"portal-modal-header\",\n style: _vm.dragStyle,\n on: {\n mousedown: function($event) {\n $event.preventDefault()\n return _vm.startDrag($event)\n }\n }\n },\n [\n _c(\"h3\", { staticClass: \"portal-modal-title\" }, [\n _vm._v(\n \"\\n\\t\\t\\t\\t\" +\n _vm._s(_vm.$cms.getMessage(\"attributes\")) +\n \"\\n\\t\\t\\t\"\n )\n ]),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton close-form cursor-pointer\",\n on: {\n click: function($event) {\n return _vm.$emit(\"closeAttributeForm\", $event, false)\n }\n }\n },\n [\n _c(\"i\", {\n staticClass: \"fa fa-times\",\n attrs: { \"aria-hidden\": \"true\" }\n })\n ]\n )\n ]\n ),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-modal-content\" }, [\n _c(\n \"form\",\n {\n attrs: { id: \"portal_attributes_form\" },\n on: {\n submit: function($event) {\n $event.preventDefault()\n return _vm.saveAttributes($event)\n }\n }\n },\n [\n _vm._l(_vm.item.semantic.attributes, function(\n attribute,\n index\n ) {\n return _c(\"div\", { key: index, staticClass: \"flex\" }, [\n _c(\"label\", { attrs: { for: \"attribute_name\" } }, [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\\t\" +\n _vm._s(_vm.$cms.getMessage(\"attribute\")) +\n \"\\n\\t\\t\\t\\t\\t\"\n )\n ]),\n _vm._v(\" \"),\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: attribute.name,\n expression: \"attribute.name\"\n }\n ],\n attrs: { type: \"text\", name: \"attribute_name\" },\n domProps: { value: attribute.name },\n on: {\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.$set(attribute, \"name\", $event.target.value)\n }\n }\n }),\n _vm._v(\" \"),\n _c(\"label\", { attrs: { for: \"attribute_value\" } }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"value\")))\n ]),\n _vm._v(\" \"),\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: attribute.value,\n expression: \"attribute.value\"\n }\n ],\n attrs: { type: \"text\", name: \"attribute_value\" },\n domProps: { value: attribute.value },\n on: {\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.$set(attribute, \"value\", $event.target.value)\n }\n }\n }),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: { type: \"button\" },\n on: {\n click: function($event) {\n return _vm.removeAttribute(attribute.name)\n }\n }\n },\n [_c(\"i\", { staticClass: \"fa fa-trash\" })]\n )\n ])\n }),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"modal-buttons-container\" }, [\n _c(\"div\", { staticClass: \"modal-buttons-margin\" }, [\n _c(\n \"button\",\n {\n staticClass: \"bouton modal-add-button\",\n on: {\n click: function($event) {\n $event.preventDefault()\n return _vm.addAttribute($event)\n }\n }\n },\n [\n _c(\"i\", {\n staticClass: \"fa fa-plus\",\n attrs: { \"aria-hidden\": \"true\" }\n })\n ]\n )\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"modal-buttons-margin\" }, [\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n on: {\n click: function($event) {\n $event.preventDefault()\n return _vm.saveAttributes($event)\n }\n }\n },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\\t\\t\" +\n _vm._s(_vm.$cms.getMessage(\"save\")) +\n \"\\n\\t\\t\\t\\t\\t\\t\"\n )\n ]\n )\n ])\n ])\n ],\n 2\n )\n ])\n ]\n )\n ]\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/attributeForm.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue?vue&type=template&id=3d4ee281&":
/*!*********************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue?vue&type=template&id=3d4ee281& ***!
\*********************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"div\", { staticClass: \"classes-parameters\" }, [\n _c(\"div\", { staticClass: \"add-classes\" }, [\n _vm.show\n ? _c(\"div\", { staticClass: \"add-classes-container-input\" }, [\n _c(\n \"form\",\n {\n ref: \"form\",\n on: {\n submit: function($event) {\n $event.preventDefault()\n return _vm.addClasses($event)\n }\n }\n },\n [\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model.trim\",\n value: _vm.newClasses,\n expression: \"newClasses\",\n modifiers: { trim: true }\n }\n ],\n ref: \"input\",\n staticClass: \"add-classes-input\",\n attrs: { type: \"text\", required: \"\" },\n domProps: { value: _vm.newClasses },\n on: {\n keyup: function($event) {\n if (\n !$event.type.indexOf(\"key\") &&\n _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")\n ) {\n return null\n }\n return _vm.submit($event)\n },\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.newClasses = $event.target.value.trim()\n },\n blur: function($event) {\n return _vm.$forceUpdate()\n }\n }\n }),\n _vm._v(\" \"),\n _c(\"i\", {\n staticClass: \"add-classes-close fa fa-times\",\n attrs: { \"aria-hidden\": \"true\" },\n on: { click: _vm.close }\n })\n ]\n )\n ])\n : _c(\n \"button\",\n { staticClass: \"bouton portal-badge-add\", on: { click: _vm.open } },\n [\n _vm._v(\n \"\\n\\t\\t\\t\" +\n _vm._s(_vm.$cms.getMessage(\"add_classes_css\")) +\n \" \\n\\t\\t\"\n )\n ]\n )\n ]),\n _vm._v(\" \"),\n _c(\n \"div\",\n { staticClass: \"classes-list\" },\n _vm._l(_vm.classesList, function(classe, index) {\n return _c(\n \"div\",\n {\n key: \"class_\" + index,\n staticClass: \"portal-badge\",\n attrs: {\n title: _vm.$cms.getMessage(\"classe_css\").replace(\"%s\", classe)\n }\n },\n [\n _vm._v(\"\\n\\t\\t\\t\" + _vm._s(classe) + \" \\n\\t\\t\\t\"),\n _c(\"i\", {\n staticClass: \"remove fa fa-trash\",\n attrs: { \"aria-hidden\": \"true\" },\n on: {\n click: function($event) {\n return _vm.removeClass(index)\n }\n }\n })\n ]\n )\n }),\n 0\n )\n ])\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/classesCSS.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/commonParams.vue?vue&type=template&id=2d56ccd5&":
/*!***********************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/commonParams.vue?vue&type=template&id=2d56ccd5& ***!
\***********************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"div\", [\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.newPlacingBefore,\n expression: \"newPlacingBefore\"\n }\n ],\n attrs: { title: _vm.$cms.getMessage(\"title_select_order\") },\n on: {\n change: [\n function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.newPlacingBefore = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n },\n _vm.emitChangeOrder\n ]\n }\n },\n [\n _vm._l(_vm.children_parent, function(child, key) {\n return _vm.isNotMe(child)\n ? _c(\"option\", { domProps: { value: child.semantic.id_tag } }, [\n _vm._v(\n \"\\n\\t\\t\\t\" +\n _vm._s(\n _vm.$cms\n .getMessage(\"placing_before\")\n .replace(\"%s\", child.name)\n ) +\n \"\\n\\t\\t\"\n )\n ])\n : _vm._e()\n }),\n _vm._v(\" \"),\n _c(\"option\", { attrs: { value: \"\" } }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"put_in_last\")))\n ])\n ],\n 2\n ),\n _vm._v(\" \"),\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.newParent,\n expression: \"newParent\"\n }\n ],\n attrs: { title: _vm.$cms.getMessage(\"title_select_parent\") },\n on: {\n change: [\n function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.newParent = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n },\n _vm.emitChangeParent\n ]\n }\n },\n _vm._l(_vm.$cms.zoneList, function(zone, key) {\n return _vm.isNotMe(zone)\n ? _c(\n \"option\",\n {\n key: \"parent_\" + key,\n domProps: { value: zone.semantic.id_tag }\n },\n [_vm._v(\"\\n\\t\\t\\t\" + _vm._s(zone.name) + \"\\n\\t\\t\")]\n )\n : _vm._e()\n }),\n 0\n )\n ])\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/commonParams.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/frame.vue?vue&type=template&id=22f5a799&":
/*!****************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/frame.vue?vue&type=template&id=22f5a799& ***!
\****************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _vm.isActive\n ? _c(\n \"div\",\n { staticClass: \"portal-frame\" },\n [\n _vm.showAttributeForm\n ? _c(\"attribute_form\", {\n attrs: {\n parentAuto: _vm.parent,\n item: _vm.item,\n view: \"layout\"\n },\n on: {\n closeAttributeForm: _vm.closeAttributeForm,\n update: _vm.update\n }\n })\n : _vm._e(),\n _vm._v(\" \"),\n _c(\"span\", {\n directives: [\n {\n name: \"show\",\n rawName: \"v-show\",\n value: _vm.isHidden,\n expression: \"isHidden\"\n }\n ],\n staticClass: \"content-background\"\n }),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-frame-menu\" }, [\n _c(\n \"p\",\n { staticClass: \"title\" },\n [\n _vm._v(\"\\n\\t\\t\\t\" + _vm._s(_vm.item.name) + \"\\n\\t\\t\\t\"),\n _vm.attributes.length > 0\n ? [\n _c(\"i\", {\n staticClass: \"fa fa-tags\",\n attrs: {\n \"aria-hidden\": \"true\",\n title: _vm.$cms.getMessage(\"attributes_on_item\")\n }\n })\n ]\n : _vm._e()\n ],\n 2\n ),\n _vm._v(\" \"),\n _c(\n \"div\",\n { staticClass: \"parameters\" },\n [\n _c(\n \"div\",\n { staticClass: \"global-parameters\" },\n [\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.item.semantic.tag,\n expression: \"item.semantic.tag\"\n }\n ],\n attrs: { name: \"tag\" },\n on: {\n change: [\n function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.$set(\n _vm.item.semantic,\n \"tag\",\n $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n )\n },\n _vm.updateTag\n ]\n }\n },\n _vm._l(_vm.$cms.semantic, function(tag, key) {\n return _c(\"option\", { key: key }, [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\\t\" + _vm._s(tag) + \"\\n\\t\\t\\t\\t\\t\"\n )\n ])\n }),\n 0\n ),\n _vm._v(\" \"),\n _c(\"common_params\", {\n attrs: {\n id_tag: _vm.item.semantic.id_tag,\n children_parent: _vm.$parent.zone.children,\n parent: _vm.currentParent,\n placing_before: _vm.placingBefore\n },\n on: {\n change_order: _vm.updateOrder,\n change_parent: _vm.updateParent\n }\n }),\n _vm._v(\" \"),\n _c(\"div\", [\n _c(\n \"button\",\n {\n class: [\n \"bouton portal-zone-hidden\",\n !_vm.parentHidden ||\n (!_vm.parentHidden && _vm.item.is_hidden)\n ? \"hidden-btn\"\n : \"\"\n ],\n on: { click: _vm.hide }\n },\n [\n _c(\"i\", {\n class: [\n \"fa\",\n _vm.item.is_hidden ? \"fa-eye-slash\" : \"fa-eye\"\n ]\n })\n ]\n ),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n directives: [\n {\n name: \"show\",\n rawName: \"v-show\",\n value: !_vm.isFrameOpac(),\n expression: \"!isFrameOpac()\"\n }\n ],\n staticClass: \"bouton\",\n attrs: { type: \"button\" },\n on: { click: _vm.remove }\n },\n [_c(\"i\", { staticClass: \"fa fa-trash\" })]\n )\n ])\n ],\n 1\n ),\n _vm._v(\" \"),\n _c(\"class_css\", {\n attrs: { classes: _vm.item.semantic.classes },\n on: { change_classes: _vm.changeClasses }\n }),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"classes-parameters\" }, [\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: { type: \"button\" },\n on: {\n click: function($event) {\n return _vm.openAttributeForm(_vm.item.semantic.id_tag)\n }\n }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"attributes\")))]\n )\n ])\n ],\n 1\n )\n ])\n ],\n 1\n )\n : _vm._e()\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/frame.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/frameForm.vue?vue&type=template&id=206fadfd&":
/*!********************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/frameForm.vue?vue&type=template&id=206fadfd& ***!
\********************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n {\n staticClass: \"portal-modal\",\n on: {\n click: function($event) {\n return _vm.$emit(\"closeFrameForm\", $event, false)\n }\n }\n },\n [\n _c(\"div\", { ref: \"modal_frame\", staticClass: \"portal-modal-container\" }, [\n _c(\n \"div\",\n {\n staticClass: \"portal-modal-header\",\n style: _vm.dragStyle,\n on: {\n mousedown: function($event) {\n $event.preventDefault()\n return _vm.startDrag($event)\n }\n }\n },\n [\n _c(\"h3\", { staticClass: \"portal-modal-title\" }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"frame_form_title\")))\n ]),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton close-form cursor-pointer\",\n on: {\n click: function($event) {\n return _vm.$emit(\"closeFrameForm\", $event, false)\n }\n }\n },\n [\n _c(\"i\", {\n staticClass: \"fa fa-times\",\n attrs: { \"aria-hidden\": \"true\" }\n })\n ]\n )\n ]\n ),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-modal-content\" }, [\n _c(\n \"form\",\n { staticClass: \"portal-form\", on: { submit: _vm.submit } },\n [\n _vm.errorMessage\n ? _c(\n \"div\",\n { staticClass: \"portal-form-group\" },\n [\n _c(\"alert_error\", {\n attrs: { message: _vm.errorMessage },\n on: {\n close: function($event) {\n _vm.errorMessage = \"\"\n }\n }\n })\n ],\n 1\n )\n : _vm._e(),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"frame-parent-heritage\" }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"frame_parent_heritage\")))]\n ),\n _vm._v(\" \"),\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.search,\n expression: \"search\"\n }\n ],\n ref: \"frame_input_search\",\n staticClass: \"portal-modal-filter\",\n attrs: {\n id: \"search_frame_form\",\n name: \"search\",\n type: \"text\",\n placeholder: _vm.$cms.getMessage(\"frame_filter_placeholder\")\n },\n domProps: { value: _vm.search },\n on: {\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.search = $event.target.value\n }\n }\n }),\n _vm._v(\" \"),\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.cadre_id,\n expression: \"cadre_id\"\n }\n ],\n ref: \"frameInputSelector\",\n staticClass: \"portal-modal-frame-list\",\n attrs: {\n id: \"frame-parent-heritage\",\n name: \"frame_cadre_id\",\n required: \"\"\n },\n on: {\n change: [\n function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.cadre_id = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n },\n function($event) {\n return _vm.changeName($event)\n }\n ]\n }\n },\n _vm._l(_vm.filteredList, function(frames, classement) {\n return _c(\n \"optgroup\",\n { key: classement, attrs: { label: classement } },\n _vm._l(frames, function(frame, key) {\n return _c(\n \"option\",\n {\n key: key,\n domProps: { value: frame.semantic.id_tag }\n },\n [_vm._v(_vm._s(frame.name) + \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\")]\n )\n }),\n 0\n )\n }),\n 0\n )\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"frame-name\" }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"frame_name\")))]\n ),\n _vm._v(\" \"),\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model.trim\",\n value: _vm.name,\n expression: \"name\",\n modifiers: { trim: true }\n }\n ],\n ref: \"frame_input_name\",\n attrs: {\n id: \"frame-name\",\n name: \"frame_name\",\n type: \"text\",\n required: \"\"\n },\n domProps: { value: _vm.name },\n on: {\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.name = $event.target.value.trim()\n },\n blur: function($event) {\n return _vm.$forceUpdate()\n }\n }\n })\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"frame-parent\" }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"frame_parent\")))]\n ),\n _vm._v(\" \"),\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.parent,\n expression: \"parent\"\n }\n ],\n attrs: {\n id: \"frame-parent\",\n name: \"frame_parent\",\n required: \"\"\n },\n on: {\n change: function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.parent = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n }\n }\n },\n _vm._l(_vm.$cms.zoneList, function(parent, key) {\n return _c(\n \"option\",\n { key: key, domProps: { value: parent.semantic.id_tag } },\n [_vm._v(_vm._s(parent.name))]\n )\n }),\n 0\n )\n ]),\n _vm._v(\" \"),\n _c(\"semantics\", {\n attrs: { semantic: _vm.semantic, editable: \"false\" },\n on: { change: _vm.updateSemantic, update: _vm.updateSemantic }\n }),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-buttons\" }, [\n _c(\n \"button\",\n { staticClass: \"bouton\", attrs: { type: \"submit\" } },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"save\")))]\n )\n ])\n ],\n 1\n )\n ])\n ])\n ]\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/frameForm.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/layout.vue?vue&type=template&id=62dc812e&":
/*!*****************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/layout.vue?vue&type=template&id=62dc812e& ***!
\*****************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n { staticClass: \"portal-layout\" },\n [\n _c(\"share_layout\"),\n _vm._v(\" \"),\n _vm.showZoneForm\n ? _c(\"zone_form\", {\n attrs: { parentAuto: _vm.parent },\n on: {\n closeZoneForm: _vm.closeZoneForm,\n submitForm: _vm.zoneCreated\n }\n })\n : _vm._e(),\n _vm._v(\" \"),\n _vm.showFrameForm\n ? _c(\"frame_form\", {\n attrs: { parentAuto: _vm.parent, view: \"layout\" },\n on: { closeFrameForm: _vm.closeFrameForm }\n })\n : _vm._e(),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"menu\" }, [\n _c(\"div\", { staticClass: \"button-group\" }, [\n _c(\n \"button\",\n {\n staticClass: \"bouton cursor-pointer\",\n attrs: { type: \"button\" },\n on: { click: _vm.openZoneForm }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"add_zone\")))]\n ),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton cursor-pointer\",\n attrs: { type: \"button\" },\n on: { click: _vm.openFrameForm }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"add_frame\")))]\n )\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"show-hidden\" }, [\n _c(\n \"label\",\n { staticClass: \"cursor-pointer\", attrs: { for: \"show-hidden\" } },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"show_hidden\")))]\n ),\n _vm._v(\" \"),\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.showHidden,\n expression: \"showHidden\"\n }\n ],\n attrs: {\n id: \"show-hidden\",\n name: \"show-hidden\",\n type: \"checkbox\",\n value: \"1\"\n },\n domProps: {\n checked: Array.isArray(_vm.showHidden)\n ? _vm._i(_vm.showHidden, \"1\") > -1\n : _vm.showHidden\n },\n on: {\n change: function($event) {\n var $$a = _vm.showHidden,\n $$el = $event.target,\n $$c = $$el.checked ? true : false\n if (Array.isArray($$a)) {\n var $$v = \"1\",\n $$i = _vm._i($$a, $$v)\n if ($$el.checked) {\n $$i < 0 && (_vm.showHidden = $$a.concat([$$v]))\n } else {\n $$i > -1 &&\n (_vm.showHidden = $$a\n .slice(0, $$i)\n .concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.showHidden = $$c\n }\n }\n }\n })\n ])\n ]),\n _vm._v(\" \"),\n _c(\n \"div\",\n { class: _vm.containerCSS },\n [\n _vm.container\n ? _c(\"zone\", {\n attrs: {\n root: \"1\",\n parent: \"\",\n zone: _vm.container,\n parentHidden: _vm.data.item.is_hidden,\n showHidden: _vm.showHidden\n },\n on: {\n update: function($event) {\n _vm.container = $event\n },\n openFrameForm: function($event) {\n return _vm.openFrameForm($event)\n },\n openZoneForm: function($event) {\n return _vm.openZoneForm($event)\n },\n openAttributeForm: function($event) {\n return _vm.openAttributeForm($event)\n }\n }\n })\n : _vm._e()\n ],\n 1\n )\n ],\n 1\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/layout.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue?vue&type=template&id=01ebd5d6&":
/*!**********************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue?vue&type=template&id=01ebd5d6& ***!
\**********************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n {\n directives: [\n { name: \"show\", rawName: \"v-show\", value: _vm.show, expression: \"show\" }\n ],\n staticClass: \"portal-modal\",\n on: {\n click: function($event) {\n if ($event.target !== $event.currentTarget) {\n return null\n }\n return _vm.hiddenModal($event)\n }\n }\n },\n [\n _c(\"div\", { ref: \"modal_zone\", staticClass: \"portal-modal-container\" }, [\n _c(\n \"div\",\n {\n staticClass: \"portal-modal-header\",\n style: _vm.dragStyle,\n on: {\n mousedown: function($event) {\n $event.preventDefault()\n return _vm.startDrag($event)\n }\n }\n },\n [\n _c(\"h3\", { staticClass: \"portal-modal-title\" }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"share_layout_detail\")))\n ]),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton close-form cursor-pointer\",\n on: {\n click: function($event) {\n if ($event.target !== $event.currentTarget) {\n return null\n }\n return _vm.hiddenModal($event)\n }\n }\n },\n [\n _c(\"i\", {\n staticClass: \"fa fa-times\",\n attrs: { \"aria-hidden\": \"true\" }\n })\n ]\n )\n ]\n ),\n _vm._v(\" \"),\n _c(\n \"div\",\n { staticClass: \"portal-modal-content\" },\n [\n _vm.errorMessage\n ? _c(\"alert_error\", { attrs: { message: _vm.errorMessage } })\n : _vm._e(),\n _vm._v(\" \"),\n _vm._l(_vm.details, function(succes, label) {\n return _c(\"div\", [\n _c(\"p\", { staticClass: \"margin\" }, [\n _vm._v(\n \"\\n \\t\\t\\t\" + _vm._s(label) + \"\\n\\t \\t\\t\"\n ),\n succes\n ? _c(\"i\", {\n staticClass: \"fa fa-check-circle succes\",\n attrs: { \"aria-hidden\": \"true\" }\n })\n : _c(\"i\", {\n staticClass: \"fa fa-times remove\",\n attrs: { \"aria-hidden\": \"true\" }\n })\n ])\n ])\n })\n ],\n 2\n )\n ])\n ]\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/shareLayout.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/zone.vue?vue&type=template&id=e52c78a0&":
/*!***************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/zone.vue?vue&type=template&id=e52c78a0& ***!
\***************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _vm.isActive\n ? _c(\n \"div\",\n { class: _vm.classeCss },\n [\n _vm.showAttributeForm\n ? _c(\"attribute_form\", {\n attrs: {\n parentAuto: _vm.parent,\n item: _vm.item,\n view: \"layout\"\n },\n on: {\n closeAttributeForm: _vm.closeAttributeForm,\n update: _vm.update\n }\n })\n : _vm._e(),\n _vm._v(\" \"),\n _c(\"span\", {\n directives: [\n {\n name: \"show\",\n rawName: \"v-show\",\n value: _vm.isHidden,\n expression: \"isHidden\"\n }\n ],\n staticClass: \"content-background\"\n }),\n _vm._v(\" \"),\n _vm.root == 0\n ? _c(\"div\", { staticClass: \"portal-zone-menu\" }, [\n _c(\n \"p\",\n { staticClass: \"title\" },\n [\n _vm._v(\"\\n\\t\\t\\t\" + _vm._s(_vm.item.name) + \" \\n\\t\\t\\t\"),\n _vm.attributes.length > 0\n ? [\n _c(\"i\", {\n staticClass: \"fa fa-tags\",\n attrs: {\n \"aria-hidden\": \"true\",\n title: _vm.$cms.getMessage(\"attributes_on_item\")\n }\n })\n ]\n : _vm._e()\n ],\n 2\n ),\n _vm._v(\" \"),\n _c(\n \"div\",\n { staticClass: \"parameters\" },\n [\n _c(\n \"div\",\n { staticClass: \"global-parameters\" },\n [\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.item.semantic.tag,\n expression: \"item.semantic.tag\"\n }\n ],\n attrs: { name: \"tag\" },\n on: {\n change: [\n function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val =\n \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.$set(\n _vm.item.semantic,\n \"tag\",\n $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n )\n },\n _vm.updateTag\n ]\n }\n },\n _vm._l(_vm.$cms.semantic, function(tag, key) {\n return _c(\"option\", { key: key }, [\n _vm._v(_vm._s(tag))\n ])\n }),\n 0\n ),\n _vm._v(\" \"),\n _c(\"common_params\", {\n attrs: {\n id_tag: _vm.item.semantic.id_tag,\n parent: _vm.currentParent,\n placing_before: _vm.placingBefore,\n children_parent: _vm.$parent.zone.children\n },\n on: {\n change_order: _vm.updateOrder,\n change_parent: _vm.updateParent\n }\n }),\n _vm._v(\" \"),\n _c(\"div\", [\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n on: { click: _vm.shareLayout }\n },\n [_c(\"i\", { staticClass: \"fa fa-share\" })]\n ),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n class: [\n \"bouton portal-zone-hidden\",\n _vm.isHidden ? \"hidden-btn\" : \"\"\n ],\n on: { click: _vm.hide }\n },\n [\n _c(\"i\", {\n class: [\n \"fa\",\n _vm.item.is_hidden ? \"fa-eye-slash\" : \"fa-eye\"\n ]\n })\n ]\n ),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n directives: [\n {\n name: \"show\",\n rawName: \"v-show\",\n value: !_vm.isZoneOpac(),\n expression: \"!isZoneOpac()\"\n }\n ],\n staticClass: \"bouton\",\n attrs: {\n type: \"button\",\n title: _vm.deleteLabel,\n disabled: !_vm.isRemovable\n },\n on: { click: _vm.remove }\n },\n [_c(\"i\", { staticClass: \"fa fa-trash\" })]\n )\n ])\n ],\n 1\n ),\n _vm._v(\" \"),\n _c(\"class_css\", {\n attrs: { classes: _vm.item.semantic.classes },\n on: { change_classes: _vm.changeClasses }\n }),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"other-parameters\" }, [\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: { type: \"button\" },\n on: {\n click: function($event) {\n return _vm.openZoneForm(_vm.item.semantic.id_tag)\n }\n }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"add_zone\")))]\n ),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: { type: \"button\" },\n on: {\n click: function($event) {\n return _vm.openFrameForm(_vm.item.semantic.id_tag)\n }\n }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"add_frame\")))]\n ),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: { type: \"button\" },\n on: {\n click: function($event) {\n return _vm.openAttributeForm(\n _vm.item.semantic.id_tag\n )\n }\n }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"attributes\")))]\n )\n ])\n ],\n 1\n )\n ])\n : _vm._e(),\n _vm._v(\" \"),\n _c(\n \"div\",\n { staticClass: \"portal-zone-container\" },\n [\n _vm._l(_vm.item.children, function(child, key) {\n return [\n child.class.toLowerCase().includes(\"zone\")\n ? _c(\"zone\", {\n key: \"child_\" + key,\n attrs: {\n root: \"0\",\n zone: child,\n parent: _vm.item.semantic.id_tag,\n nextChild: _vm.getNextChildren(key),\n parentHidden: _vm.parentHidden\n ? _vm.parentHidden\n : _vm.item.is_hidden,\n showHidden: _vm.showHidden\n },\n on: {\n update: function($event) {\n return _vm.updateChild(key, $event)\n },\n updateParent: function($event) {\n return _vm.updateChildParent(key, $event)\n },\n updateOrder: function($event) {\n return _vm.updateChildOrder(key, $event)\n },\n updateTag: function($event) {\n return _vm.updateChildTag(key, $event)\n },\n openFrameForm: _vm.openFrameForm,\n openZoneForm: _vm.openZoneForm,\n openAttributeForm: _vm.openAttributeForm\n }\n })\n : child.class.toLowerCase().includes(\"frame\")\n ? _c(\"frame\", {\n key: \"child_\" + key,\n attrs: {\n frame: child,\n parent: _vm.item.semantic.id_tag,\n nextChild: _vm.getNextChildren(key),\n parentHidden: _vm.parentHidden\n ? _vm.parentHidden\n : _vm.item.is_hidden,\n showHidden: _vm.showHidden\n },\n on: {\n update: function($event) {\n return _vm.updateChild(key, $event)\n },\n updateParent: function($event) {\n return _vm.updateChildParent(key, $event)\n },\n updateOrder: function($event) {\n return _vm.updateChildOrder(key, $event)\n },\n updateTag: function($event) {\n return _vm.updateChildTag(key, $event)\n }\n }\n })\n : _vm._e()\n ]\n })\n ],\n 2\n )\n ],\n 1\n )\n : _vm._e()\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/zone.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue?vue&type=template&id=868c32d8&":
/*!*******************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue?vue&type=template&id=868c32d8& ***!
\*******************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n {\n staticClass: \"portal-modal\",\n on: {\n click: function($event) {\n return _vm.$emit(\"closeZoneForm\", $event, false)\n }\n }\n },\n [\n _c(\"div\", { ref: \"modal_zone\", staticClass: \"portal-modal-container\" }, [\n _c(\n \"div\",\n {\n staticClass: \"portal-modal-header\",\n style: _vm.dragStyle,\n on: {\n mousedown: function($event) {\n $event.preventDefault()\n return _vm.startDrag($event)\n }\n }\n },\n [\n _c(\"h3\", { staticClass: \"portal-modal-title\" }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"zone_form_title\")))\n ]),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton close-form cursor-pointer\",\n on: {\n click: function($event) {\n return _vm.$emit(\"closeZoneForm\", $event, false)\n }\n }\n },\n [\n _c(\"i\", {\n staticClass: \"fa fa-times\",\n attrs: { \"aria-hidden\": \"true\" }\n })\n ]\n )\n ]\n ),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-modal-content\" }, [\n _c(\n \"form\",\n {\n staticClass: \"portal-form\",\n on: {\n submit: function($event) {\n $event.preventDefault()\n return _vm.submit($event)\n }\n }\n },\n [\n _vm.errorMessage\n ? _c(\n \"div\",\n { staticClass: \"portal-form-group\" },\n [\n _c(\"alert_error\", {\n attrs: { message: _vm.errorMessage },\n on: {\n close: function($event) {\n _vm.errorMessage = \"\"\n }\n }\n })\n ],\n 1\n )\n : _vm._e(),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"zone-name\" }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"zone_name\")))]\n ),\n _vm._v(\" \"),\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model.trim\",\n value: _vm.name,\n expression: \"name\",\n modifiers: { trim: true }\n }\n ],\n ref: \"zone_input_name\",\n attrs: {\n id: \"zone-name\",\n name: \"zone_name\",\n type: \"text\",\n required: \"\"\n },\n domProps: { value: _vm.name },\n on: {\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.name = $event.target.value.trim()\n },\n blur: function($event) {\n return _vm.$forceUpdate()\n }\n }\n })\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"zone-parent\" }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"zone_parent\")))]\n ),\n _vm._v(\" \"),\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.parent,\n expression: \"parent\"\n }\n ],\n attrs: {\n id: \"zone-parent\",\n name: \"zone_parent\",\n required: \"\"\n },\n on: {\n change: function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.parent = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n }\n }\n },\n _vm._l(_vm.$cms.zoneList, function(parent, key) {\n return _c(\n \"option\",\n { key: key, domProps: { value: parent.semantic.id_tag } },\n [_vm._v(_vm._s(parent.name))]\n )\n }),\n 0\n )\n ]),\n _vm._v(\" \"),\n _c(\"semantics\", {\n attrs: { semantic: _vm.semantic },\n on: { change: _vm.updateSemantic, update: _vm.updateSemantic }\n }),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-buttons\" }, [\n _c(\n \"button\",\n { staticClass: \"bouton\", attrs: { type: \"submit\" } },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"save\")))]\n )\n ])\n ],\n 1\n )\n ])\n ])\n ]\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/layout/zoneForm.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/list.vue?vue&type=template&id=134923ef&":
/*!********************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/list.vue?vue&type=template&id=134923ef& ***!
\********************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"div\", { staticClass: \"portal-list\" }, [\n _c(\"div\", { staticClass: \"portal-frame-list\" }, [\n _vm.title\n ? _c(\"h3\", { staticClass: \"portal-list-title\" }, [\n _vm._v(_vm._s(_vm.title))\n ])\n : _vm._e(),\n _vm._v(\" \"),\n _vm.add_msg && _vm.isAddable\n ? _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: { type: \"button\" },\n on: { click: _vm.add }\n },\n [_vm._v(\"\\n\\t\\t\\t\" + _vm._s(_vm.add_msg) + \"\\n\\t\\t\")]\n )\n : _vm._e()\n ]),\n _vm._v(\" \"),\n _c(\n \"div\",\n { staticClass: \"portal-list-container\" },\n [\n _vm.empty_msg && _vm.items.length == 0\n ? _c(\"p\", [_vm._v(_vm._s(_vm.empty_msg))])\n : _vm._e(),\n _vm._v(\" \"),\n _vm._l(_vm.items, function(item, key) {\n return _c(\n \"div\",\n {\n key: key,\n staticClass: \"portal-list-item cursor-pointer\",\n attrs: { title: item.name },\n on: {\n click: function($event) {\n return _vm.itemClicked(item)\n }\n }\n },\n [\n _c(\"span\", { staticClass: \"portal-list-item-title\" }, [\n _vm._v(_vm._s(item.name))\n ]),\n _vm._v(\" \"),\n _vm.isRemovable\n ? _c(\"i\", {\n staticClass: \"fa fa-times remove-icon\",\n attrs: { title: _vm.$cms.getMessage(\"delete\") },\n on: {\n click: function($event) {\n $event.stopPropagation()\n return _vm.itemRemove(item)\n }\n }\n })\n : _vm._e()\n ]\n )\n })\n ],\n 2\n )\n ])\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/list.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/loader.vue?vue&type=template&id=bf1852b8&":
/*!**********************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/loader.vue?vue&type=template&id=bf1852b8& ***!
\**********************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _vm.show\n ? _c(\n \"div\",\n {\n staticClass: \"portal-loader\",\n attrs: { title: _vm.$cms.getMessage(\"loading\") }\n },\n [\n _c(\"div\", { staticClass: \"portal-loader-container\" }, [\n _c(\"i\", { staticClass: \"fa fa-spinner fa-spin fa-3x fa-fw\" }),\n _vm._v(\" \"),\n _c(\"span\", { staticClass: \"sr-only\" }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"loading\")))\n ])\n ])\n ]\n )\n : _vm._e()\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/loader.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/nav/nav.vue?vue&type=template&id=b292c214&":
/*!***********************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/nav/nav.vue?vue&type=template&id=b292c214& ***!
\***********************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n { attrs: { id: \"nav\" } },\n [\n _c(\"nav\", { staticClass: \"portal-nav\" }, [\n _c(\n \"section\",\n { staticClass: \"portal-nav-items\" },\n _vm._l(_vm.items, function(item, key) {\n return _c(\"nav_item\", {\n key: key,\n attrs: {\n index: key,\n item: item,\n isActive: _vm.$cms.itemNavActive == key\n },\n on: {\n closeSubNav: _vm.closeSubNav,\n changeActive: function($event) {\n return _vm.changeActive($event)\n }\n }\n })\n }),\n 1\n ),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"cache\" }, [\n _c(\n \"div\",\n {\n attrs: {\n \"data-dojo-type\": \"dijit/form/Button\",\n \"data-dojo-props\": 'id:\"clean_cache_button_img\"'\n }\n },\n [_vm._v(_vm._s(_vm.$cms.clean_cache_img.name))]\n ),\n _vm._v(\" \"),\n _c(\n \"div\",\n {\n attrs: {\n \"data-dojo-type\": \"dijit/form/Button\",\n \"data-dojo-props\": 'id:\"clean_cache_button\"'\n }\n },\n [_vm._v(_vm._s(_vm.$cms.clean_cache.name))]\n )\n ])\n ]),\n _vm._v(\" \"),\n _vm.itemActive && _vm.itemActive.subNav\n ? _c(\"sub_nav\", { attrs: { item: _vm.itemActive } })\n : _vm._e()\n ],\n 1\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/nav/nav.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/nav/navItem.vue?vue&type=template&id=e82144ae&":
/*!***************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/nav/navItem.vue?vue&type=template&id=e82144ae& ***!
\***************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"div\", { staticClass: \"portal-nav-item\" }, [\n _c(\n \"h3\",\n {\n class: [\"portal-nav-item-title\", _vm.isActive ? \"active\" : \"\"],\n on: {\n click: function($event) {\n return _vm.$emit(\"changeActive\", _vm.index)\n }\n }\n },\n [_vm._v(\"\\n\\t\\t\" + _vm._s(_vm.item.title) + \"\\n\\t\")]\n ),\n _vm._v(\" \"),\n _vm.item && _vm.item.subNav\n ? _c(\"span\", { staticClass: \"portal-sub-nav-icon cursor-pointer\" }, [\n _c(\"i\", {\n staticClass: \"fa fa-times remove-icon\",\n attrs: { title: _vm.$cms.getMessage(\"delete\") },\n on: {\n click: function($event) {\n $event.stopPropagation()\n return _vm.$emit(\"closeSubNav\", _vm.index)\n }\n }\n })\n ])\n : _vm._e()\n ])\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/nav/navItem.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/nav/subNav.vue?vue&type=template&id=53e55940&":
/*!**************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/nav/subNav.vue?vue&type=template&id=53e55940& ***!
\**************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"nav\", { staticClass: \"portal-sub-nav\" }, [\n _c(\n \"div\",\n { staticClass: \"portal-nav-items\" },\n _vm._l(_vm.items, function(item, key) {\n return _c(\"nav_item\", {\n key: key,\n attrs: { index: key, item: item, isActive: _vm.navActive == key },\n on: {\n changeActive: function($event) {\n return _vm.changeActive($event)\n }\n }\n })\n }),\n 1\n )\n ])\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/nav/subNav.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue?vue&type=template&id=31ab47ad&":
/*!********************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue?vue&type=template&id=31ab47ad& ***!
\********************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n {\n staticClass: \"portal-modal\",\n on: {\n click: function($event) {\n return _vm.$emit(\"closeCmsForm\", $event, false)\n }\n }\n },\n [\n _c(\n \"div\",\n {\n ref: \"modal_cms\",\n staticClass: \"portal-modal-container portal-cms-modal-container\"\n },\n [\n _c(\n \"div\",\n {\n staticClass: \"portal-modal-header\",\n style: _vm.dragStyle,\n on: {\n mousedown: function($event) {\n $event.preventDefault()\n return _vm.startDrag($event)\n }\n }\n },\n [\n _c(\"h3\", { staticClass: \"portal-modal-title\" }, [\n _vm._v(_vm._s(_vm.title))\n ]),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton close-form cursor-pointer\",\n on: {\n click: function($event) {\n return _vm.$emit(\"closeFrameForm\", $event, false)\n }\n }\n },\n [_vm._v(\"x\")]\n )\n ]\n ),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-modal-content\" }, [\n _c(\"div\", { staticClass: \"page-form\" }, [\n _c(\n \"form\",\n {\n staticClass: \"portal-form\",\n attrs: { action: \"\", method: \"post\" },\n on: {\n submit: function($event) {\n $event.preventDefault()\n return _vm.submit($event)\n }\n }\n },\n [\n _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"page-name\" }\n },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\" +\n _vm._s(\n _vm.$cms.getMessage(\"infopage_title_infopage\")\n ) +\n \"\\n\\t\\t\\t\\t\\t\\t\\t\"\n )\n ]\n ),\n _vm._v(\" \"),\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.name,\n expression: \"name\"\n },\n {\n name: \"model\",\n rawName: \"v-model.trim\",\n value: _vm.name,\n expression: \"name\",\n modifiers: { trim: true }\n }\n ],\n ref: \"page_input_name\",\n attrs: {\n id: \"name\",\n name: \"name\",\n type: \"text\",\n required: \"\"\n },\n domProps: { value: _vm.name, value: _vm.name },\n on: {\n input: [\n function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.name = $event.target.value.trim()\n },\n function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.name = $event.target.value\n }\n ],\n blur: function($event) {\n return _vm.$forceUpdate()\n }\n }\n })\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"page-summary\" }\n },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\" +\n _vm._s(\n _vm.$cms.getMessage(\"cms_page_description\")\n ) +\n \"\\n\\t\\t\\t\\t\\t\\t\\t\"\n )\n ]\n ),\n _vm._v(\" \"),\n _c(\"textarea\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model.trim\",\n value: _vm.summary,\n expression: \"summary\",\n modifiers: { trim: true }\n }\n ],\n attrs: {\n id: \"description\",\n name: \"description\",\n cols: \"120\",\n rows: \"5\"\n },\n domProps: { value: _vm.summary },\n on: {\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.summary = $event.target.value.trim()\n },\n blur: function($event) {\n return _vm.$forceUpdate()\n }\n }\n })\n ]),\n _vm._v(\" \"),\n _c(\n \"div\",\n { staticClass: \"portal-form-group\" },\n [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"var_name_0\" }\n },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\" +\n _vm._s(\n _vm.$cms.getMessage(\"cms_page_variables\")\n ) +\n \"\\n\\t\\t\\t\\t\\t\\t\\t\"\n )\n ]\n ),\n _vm._v(\" \"),\n _vm._l(_vm.vars, function(env_var, index) {\n return _c(\n \"div\",\n {\n key: \"env_var_\" + index,\n staticClass: \"page-form-var\"\n },\n [\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model.trim\",\n value: env_var.name,\n expression: \"env_var.name\",\n modifiers: { trim: true }\n }\n ],\n attrs: {\n type: \"text\",\n id: \"var_name_\" + index,\n name: \"var_name_\" + index,\n placeholder: _vm.$cms.getMessage(\n \"cms_page_var_name\"\n )\n },\n domProps: { value: env_var.name },\n on: {\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.$set(\n env_var,\n \"name\",\n $event.target.value.trim()\n )\n },\n blur: function($event) {\n return _vm.$forceUpdate()\n }\n }\n }),\n _vm._v(\" \"),\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model.trim\",\n value: env_var.comment,\n expression: \"env_var.comment\",\n modifiers: { trim: true }\n }\n ],\n attrs: {\n type: \"text\",\n id: \"var_comment_\" + index,\n name: \"var_comment_\" + index,\n placeholder: _vm.$cms.getMessage(\n \"cms_page_var_summary\"\n )\n },\n domProps: { value: env_var.comment },\n on: {\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.$set(\n env_var,\n \"comment\",\n $event.target.value.trim()\n )\n },\n blur: function($event) {\n return _vm.$forceUpdate()\n }\n }\n }),\n _vm._v(\" \"),\n index + 1 == _vm.vars.length\n ? _c(\"div\", { staticClass: \"groupe-button\" }, [\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: { type: \"button\" },\n on: {\n click: function($event) {\n return _vm.reset(index)\n }\n }\n },\n [_vm._v(\"X\")]\n ),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: { type: \"button\" },\n on: { click: _vm.add }\n },\n [_vm._v(\"+\")]\n )\n ])\n : _vm._e()\n ]\n )\n })\n ],\n 2\n ),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-buttons\" }, [\n _c(\"div\", { staticClass: \"left\" }, [\n _c(\n \"button\",\n { staticClass: \"bouton\", attrs: { type: \"submit\" } },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"save\")))]\n )\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"right\" }, [\n _vm.isEntity\n ? _c(\n \"button\",\n {\n staticClass: \"bouton delete\",\n attrs: { type: \"button\" },\n on: { click: _vm.remove }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"delete\")))]\n )\n : _vm._e()\n ])\n ])\n ]\n )\n ])\n ])\n ]\n )\n ]\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/cmsPageForm.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/conditions.vue?vue&type=template&id=47050112&":
/*!*******************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/page/conditions.vue?vue&type=template&id=47050112& ***!
\*******************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"conditions\" }\n },\n [\n _vm._v(\n \"\\n\\t\\t\" +\n _vm._s(_vm.$cms.getMessage(\"portal_conditions_label\")) +\n \"\\n\\t\"\n )\n ]\n ),\n _vm._v(\" \"),\n _c(\"div\", [\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.newCondition,\n expression: \"newCondition\"\n }\n ],\n attrs: { id: \"conditions\", name: \"condition\" },\n on: {\n change: [\n function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.newCondition = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n },\n _vm.add\n ]\n }\n },\n [\n _c(\"option\", { attrs: { value: \"\", disabled: \"\" } }, [\n _vm._v(\n \"\\n\\t\\t\\t\\t\" +\n _vm._s(_vm.$cms.getMessage(\"portal_condition_default_option\")) +\n \"\\n\\t\\t\\t\"\n )\n ]),\n _vm._v(\" \"),\n _vm._l(_vm.$cms.conditions, function(condition, index) {\n return _c(\n \"option\",\n {\n key: \"condition_\" + index,\n domProps: { value: condition.namespace }\n },\n [_vm._v(\"\\n\\t\\t\\t\\t\" + _vm._s(condition.label) + \"\\n\\t\\t\\t\")]\n )\n })\n ],\n 2\n )\n ]),\n _vm._v(\" \"),\n _c(\n \"div\",\n { staticClass: \"conditions\" },\n _vm._l(_vm.conditions, function(condition, index) {\n return _c(_vm.getComponent(condition), {\n key: index,\n tag: \"component\",\n attrs: { condition: condition, index: index },\n on: {\n remove: function($event) {\n return _vm.$emit(\"remove\", $event)\n },\n update: function($event) {\n return _vm.$emit(\"update\", $event, index)\n }\n }\n })\n }),\n 1\n )\n ])\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/conditions.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue?vue&type=template&id=ea228c82&":
/*!*************************************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue?vue&type=template&id=ea228c82& ***!
\*************************************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"fieldset\", { staticClass: \"condition\" }, [\n _c(\"div\", { staticClass: \"condition-fields\" }, [\n _c(\"div\", { staticClass: \"condition-field\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: _vm.idGlobal }\n },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\" +\n _vm._s(_vm.$cms.getMessage(\"portal_condition_global_label\")) +\n \"\\n\\t\\t\\t\"\n )\n ]\n ),\n _vm._v(\" \"),\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model.trim\",\n value: _vm.global,\n expression: \"global\",\n modifiers: { trim: true }\n }\n ],\n attrs: {\n name: \"global\",\n type: \"text\",\n id: _vm.idGlobal,\n placeholder: _vm.$cms.getMessage(\"portal_condition_global_label\"),\n required: \"\"\n },\n domProps: { value: _vm.global },\n on: {\n change: _vm.change,\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.global = $event.target.value.trim()\n },\n blur: function($event) {\n return _vm.$forceUpdate()\n }\n }\n })\n ]),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton remove\",\n attrs: { type: \"button\" },\n on: { click: _vm.remove }\n },\n [_vm._v(\"X\")]\n )\n ])\n ])\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/conditions/ConditionEnvModel.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue?vue&type=template&id=025639e4&":
/*!******************************************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue?vue&type=template&id=025639e4& ***!
\******************************************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"fieldset\", { staticClass: \"condition\" }, [\n _c(\"div\", { staticClass: \"condition-fields\" }, [\n _c(\"div\", { staticClass: \"condition-field\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: _vm.idSelect }\n },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\" +\n _vm._s(_vm.$cms.getMessage(\"portal_condition_view_label\")) +\n \"\\n\\t\\t\\t\"\n )\n ]\n ),\n _vm._v(\" \"),\n _vm.opac_views.length > 0\n ? _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.opac_view,\n expression: \"opac_view\"\n }\n ],\n attrs: { id: _vm.idSelect, required: \"\" },\n on: {\n change: [\n function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.opac_view = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n },\n _vm.change\n ]\n }\n },\n [\n _c(\"option\", { attrs: { value: \"\", disabled: \"\" } }, [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\" +\n _vm._s(\n _vm.$cms.getMessage(\n \"portal_condition_view_default_option\"\n )\n ) +\n \"\\n\\t\\t\\t\\t\"\n )\n ]),\n _vm._v(\" \"),\n _vm._l(_vm.opac_views, function(opac_view, index) {\n return _c(\n \"option\",\n { key: index, domProps: { value: opac_view.value } },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\" + _vm._s(opac_view.label) + \"\\n\\t\\t\\t\\t\"\n )\n ]\n )\n })\n ],\n 2\n )\n : _c(\"p\", [\n _vm._v(\n _vm._s(_vm.$cms.getMessage(\"portal_condition_view_no_view\"))\n )\n ])\n ]),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton remove\",\n attrs: { type: \"button\" },\n on: { click: _vm.remove }\n },\n [_vm._v(\"X\")]\n )\n ])\n ])\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/conditions/ConditionOpacViewModel.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/pageForm.vue?vue&type=template&id=13c294f2&":
/*!*****************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/page/pageForm.vue?vue&type=template&id=13c294f2& ***!
\*****************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n { staticClass: \"page-form\" },\n [\n _vm.showCmsForm\n ? _c(\"cms_form\", {\n attrs: { data: _vm.cmsFormData },\n on: {\n changeSubType: _vm.changeSubType,\n removeSubType: _vm.removeSubType,\n closeCmsForm: _vm.closeCmsForm\n }\n })\n : _vm._e(),\n _vm._v(\" \"),\n _vm.isEntity\n ? _c(\"div\", { staticClass: \"portal-form-group-clear\" }, [\n _c(\n \"button\",\n {\n staticClass: \"bouton clear-btn\",\n attrs: { type: \"button\" },\n on: { click: _vm.cleanCache }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"page_clean_cache\")))]\n )\n ])\n : _vm._e(),\n _vm._v(\" \"),\n _c(\n \"form\",\n {\n staticClass: \"portal-form\",\n attrs: { action: \"\", method: \"post\" },\n on: { submit: _vm.submit }\n },\n [\n _vm.errorMessage\n ? _c(\n \"div\",\n { staticClass: \"portal-form-group\" },\n [\n _c(\"alert_error\", {\n attrs: { message: _vm.errorMessage },\n on: {\n close: function($event) {\n _vm.errorMessage = \"\"\n }\n }\n })\n ],\n 1\n )\n : _vm._e(),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"page-name\" }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"page_name\")))]\n ),\n _vm._v(\" \"),\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model.trim\",\n value: _vm.name,\n expression: \"name\",\n modifiers: { trim: true }\n }\n ],\n ref: \"page_input_name\",\n attrs: { id: \"page-name\", name: \"page_name\", type: \"text\" },\n domProps: { value: _vm.name },\n on: {\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.name = $event.target.value.trim()\n },\n blur: function($event) {\n return _vm.$forceUpdate()\n }\n }\n })\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"page-type\" }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"page_type\")))]\n ),\n _vm._v(\" \"),\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.type,\n expression: \"type\"\n }\n ],\n attrs: {\n id: \"page-type\",\n name: \"page_type\",\n required: \"\",\n disabled: _vm.isEntity\n },\n on: {\n change: function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.type = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n }\n }\n },\n _vm._l(_vm.typesOrderAsc, function(type, key) {\n return _c(\n \"option\",\n { key: key, domProps: { value: type.value } },\n [_vm._v(_vm._s(type.label))]\n )\n }),\n 0\n )\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"page-sub-type\" }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"page_sub_type\")))]\n ),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-page-sub-type\" }, [\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.sub_type,\n expression: \"sub_type\"\n }\n ],\n attrs: {\n id: \"page-sub-type\",\n name: \"page_sub_type\",\n required: \"\",\n disabled: _vm.sub_types.length == 0 || _vm.isEntity\n },\n on: {\n change: function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.sub_type = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n }\n }\n },\n _vm._l(_vm.sub_types, function(sub_type, key) {\n return _c(\n \"option\",\n { key: key, domProps: { value: sub_type.value } },\n [_vm._v(_vm._s(sub_type.label))]\n )\n }),\n 0\n ),\n _vm._v(\" \"),\n _c(\n \"span\",\n {\n directives: [\n {\n name: \"show\",\n rawName: \"v-show\",\n value: _vm.type == 25,\n expression: \"type==25\"\n }\n ],\n staticClass: \"portal-page-icon\"\n },\n [\n _c(\"i\", {\n staticClass: \"portal-page-icon-add fa fa-plus-circle\",\n attrs: {\n title: _vm.$cms.getMessage(\"cms_page_add\"),\n \"aria-hidden\": \"true\"\n },\n on: { click: _vm.openCmsForm }\n })\n ]\n ),\n _vm._v(\" \"),\n _c(\n \"span\",\n {\n directives: [\n {\n name: \"show\",\n rawName: \"v-show\",\n value: _vm.type == 25 && _vm.sub_type != 2500,\n expression: \"type==25 && sub_type!=2500\"\n }\n ],\n staticClass: \"portal-page-icon\"\n },\n [\n _c(\"i\", {\n staticClass: \"portal-page-icon-add fa fa-pencil\",\n attrs: {\n title: _vm.$cms.getMessage(\"cms_page_edit\"),\n \"aria-hidden\": \"true\"\n },\n on: {\n click: function($event) {\n return _vm.openCmsForm($event, true)\n }\n }\n })\n ]\n )\n ])\n ]),\n _vm._v(\" \"),\n _vm.type != 25\n ? _c(\"conditions\", {\n attrs: { conditions: _vm.conditions },\n on: {\n add: _vm.addCondition,\n remove: _vm.removeCondition,\n update: _vm.updateCondition\n }\n })\n : _vm._e(),\n _vm._v(\" \"),\n _c(\n \"div\",\n { staticClass: \"portal-form-group\" },\n [\n _c(\"label\", { attrs: { for: \"heritage-selector\" } }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"heritage_label\")))\n ]),\n _vm._v(\" \"),\n _c(\"page_heritage\", {\n attrs: { data: _vm.data },\n on: { change: _vm.updateHeritage }\n })\n ],\n 1\n ),\n _vm._v(\" \"),\n _vm.hasLayoutsList\n ? _c(\n \"div\",\n { staticClass: \"portal-form-group\" },\n [\n _c(\"label\", { attrs: { for: \"heritage-list\" } }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"layouts_list\")))\n ]),\n _vm._v(\" \"),\n _vm._l(_vm.layouts_list, function(layout, index) {\n return [\n _c(\"p\", [\n _vm._v(_vm._s(layout) + \" \"),\n _c(\"i\", {\n staticClass: \"fa fa-times cursor-pointer remove\",\n attrs: { \"aria-hidden\": \"true\" },\n on: {\n click: function($event) {\n return _vm.removeLayout(index)\n }\n }\n })\n ])\n ]\n })\n ],\n 2\n )\n : _vm._e(),\n _vm._v(\" \"),\n _c(\n \"div\",\n { staticClass: \"portal-form-group\" },\n [\n _c(\"frame_list\", {\n attrs: {\n list: _vm.frameList,\n title: _vm.title,\n is_entity: _vm.isEntity\n },\n on: { frameRemove: _vm.frameRemove }\n })\n ],\n 1\n ),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-form-buttons\" }, [\n _c(\"div\", { staticClass: \"left\" }, [\n _c(\n \"button\",\n { staticClass: \"bouton\", attrs: { type: \"submit\" } },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"save\")))]\n )\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"right\" }, [\n _vm.isEntity\n ? _c(\n \"button\",\n {\n staticClass: \"bouton delete\",\n attrs: { type: \"button\" },\n on: { click: _vm.remove }\n },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"delete\")))]\n )\n : _vm._e()\n ])\n ])\n ],\n 1\n )\n ],\n 1\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/pageForm.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue?vue&type=template&id=7befa1ad&":
/*!*********************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue?vue&type=template&id=7befa1ad& ***!
\*********************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"div\", { staticClass: \"portal-heritage\" }, [\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.heritageSelected,\n expression: \"heritageSelected\"\n }\n ],\n attrs: {\n id: \"heritage-selector\",\n name: \"heritage_selector\",\n required: \"\"\n },\n on: {\n change: [\n function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.heritageSelected = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n },\n _vm.changeHeritage\n ]\n }\n },\n [\n _vm.pageList.length != 0\n ? _c(\n \"optgroup\",\n {\n attrs: {\n label: _vm.$cms.getMessage(\"heritage_label_group_page\")\n }\n },\n _vm._l(_vm.pageList, function(page, key) {\n return _c(\n \"option\",\n { key: key, domProps: { value: \"page_\" + page.id } },\n [_vm._v(_vm._s(page.name))]\n )\n }),\n 0\n )\n : _vm._e(),\n _vm._v(\" \"),\n _c(\n \"optgroup\",\n {\n attrs: { label: _vm.$cms.getMessage(\"heritage_label_group_model\") }\n },\n _vm._l(_vm.$cms.gabarits, function(gabarit, key) {\n return _c(\n \"option\",\n { key: key, domProps: { value: \"gabarit_\" + gabarit.id } },\n [_vm._v(_vm._s(gabarit.name))]\n )\n }),\n 0\n )\n ]\n )\n ])\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/pageHeritage.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue?vue&type=template&id=e4581968&":
/*!*********************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue?vue&type=template&id=e4581968& ***!
\*********************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n { staticClass: \"page-type\" },\n [\n _vm.showCmsForm\n ? _c(\"cms_form\", {\n attrs: { data: _vm.cmsFormData },\n on: { closeCmsForm: _vm.closeCmsForm }\n })\n : _vm._e(),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"menu\" }, [\n _c(\"div\", { staticClass: \"check\" }, [\n _c(\"i\", {\n staticClass: \"fa fa-plus-square cursor-pointer\",\n attrs: { title: _vm.$cms.getMessage(\"check_all\") },\n on: { click: _vm.checkAll }\n }),\n _vm._v(\" \"),\n _c(\"i\", {\n staticClass: \"fa fa-minus-square cursor-pointer\",\n attrs: { title: _vm.$cms.getMessage(\"uncheck_all\") },\n on: { click: _vm.uncheckAll }\n })\n ]),\n _vm._v(\" \"),\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.layout,\n expression: \"layout\"\n }\n ],\n on: {\n change: [\n function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.layout = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n },\n function($event) {\n _vm.status = {}\n }\n ]\n }\n },\n [\n _vm.pageList.length != 0\n ? _c(\n \"optgroup\",\n {\n attrs: {\n label: _vm.$cms.getMessage(\"heritage_label_group_page\")\n }\n },\n _vm._l(_vm.pageList, function(page, key) {\n return _c(\n \"option\",\n {\n key: \"page_\" + key,\n domProps: { value: \"page_\" + page.id }\n },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\" + _vm._s(page.name) + \"\\n\\t\\t\\t\\t\"\n )\n ]\n )\n }),\n 0\n )\n : _vm._e(),\n _vm._v(\" \"),\n _c(\n \"optgroup\",\n {\n attrs: {\n label: _vm.$cms.getMessage(\"heritage_label_group_model\")\n }\n },\n _vm._l(_vm.$cms.gabarits, function(gabarit, key) {\n return _c(\n \"option\",\n { key: key, domProps: { value: \"gabarit_\" + gabarit.id } },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\\t\" + _vm._s(gabarit.name) + \"\\n\\t\\t\\t\\t\"\n )\n ]\n )\n }),\n 0\n )\n ]\n ),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n class: [\"bouton\", _vm.available ? \"cursor-pointer\" : \"\"],\n attrs: { type: \"button\", disabled: !_vm.available },\n on: { click: _vm.apply }\n },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\" +\n _vm._s(_vm.$cms.getMessage(\"apply_in_checkbox\")) +\n \"\\n\\t\\t\"\n )\n ]\n ),\n _vm._v(\" \"),\n _vm.type == 25\n ? _c(\n \"button\",\n {\n staticClass: \"bouton cursor-pointer\",\n attrs: { type: \"button\" },\n on: { click: _vm.openCmsForm }\n },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\" +\n _vm._s(_vm.$cms.getMessage(\"cms_page_add_subtype\")) +\n \"\\n\\t\\t\"\n )\n ]\n )\n : _vm._e()\n ]),\n _vm._v(\" \"),\n _c(\n \"fieldset\",\n { staticClass: \"pages\" },\n [\n _c(\"legend\", { staticClass: \"title\" }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"pages_list\")))\n ]),\n _vm._v(\" \"),\n _vm.pages.length == 0\n ? _c(\"p\", [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"no_subpages_created\")))\n ])\n : _vm._l(_vm.pages, function(page, index) {\n return _c(\n \"div\",\n { key: \"page_\" + index, staticClass: \"page\" },\n [\n _c(\"div\", [\n _c(\"input\", {\n attrs: {\n id: \"page_\" + index,\n type: \"checkbox\",\n value: \"1\"\n },\n domProps: { checked: _vm.checked.includes(page.id) },\n on: {\n change: function($event) {\n return _vm.changeCheck(page.id)\n }\n }\n })\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"page-info\" }, [\n _c(\"div\", { staticClass: \"page-name\" }, [\n _c(\n \"label\",\n {\n staticClass: \"cursor-pointer\",\n attrs: { for: \"page_\" + index }\n },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\\t\" +\n _vm._s(page.name) +\n \"\\n\\t\\t\\t\\t\\t\"\n )\n ]\n )\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"page-layout\" }, [\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.layouts[page.id],\n expression: \"layouts[page.id]\"\n }\n ],\n on: {\n change: [\n function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val =\n \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.$set(\n _vm.layouts,\n page.id,\n $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n )\n },\n function($event) {\n return _vm.updateHeritage(page.id)\n }\n ]\n }\n },\n [\n _vm.getPageList(page.id).length != 0\n ? _c(\n \"optgroup\",\n {\n attrs: {\n label: _vm.$cms.getMessage(\n \"heritage_label_group_page\"\n )\n }\n },\n _vm._l(_vm.getPageList(page.id), function(\n page,\n key\n ) {\n return _c(\n \"option\",\n {\n key: \"page_\" + key,\n domProps: { value: \"page_\" + page.id }\n },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\" +\n _vm._s(page.name) +\n \"\\n\\t\\t\\t\\t\\t\\t\\t\"\n )\n ]\n )\n }),\n 0\n )\n : _vm._e(),\n _vm._v(\" \"),\n _c(\n \"optgroup\",\n {\n attrs: {\n label: _vm.$cms.getMessage(\n \"heritage_label_group_model\"\n )\n }\n },\n _vm._l(_vm.$cms.gabarits, function(gabarit, key) {\n return _c(\n \"option\",\n {\n key: \"gabarit_\" + key,\n domProps: { value: \"gabarit_\" + gabarit.id }\n },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\" +\n _vm._s(gabarit.name) +\n \"\\n\\t\\t\\t\\t\\t\\t\\t\"\n )\n ]\n )\n }),\n 0\n )\n ]\n ),\n _vm._v(\" \"),\n _vm.getImage(page.id)\n ? _c(\"img\", {\n staticClass: \"icon\",\n attrs: {\n src: _vm.getImage(page.id),\n alt: _vm.getImage(page.id)\n }\n })\n : _vm._e()\n ])\n ])\n ]\n )\n })\n ],\n 2\n )\n ],\n 1\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/page/pageTypeForm.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/preview/contextForm.vue?vue&type=template&id=0dc501ea&":
/*!***********************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/preview/contextForm.vue?vue&type=template&id=0dc501ea& ***!
\***********************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n {\n staticClass: \"portal-modal\",\n on: {\n click: function($event) {\n $event.stopPropagation()\n return _vm.$emit(\"closeContextForm\", $event)\n }\n }\n },\n [\n _c(\n \"div\",\n {\n ref: \"modal_context\",\n staticClass: \"portal-modal-container portal-context-modal-container\",\n on: {\n click: function($event) {\n $event.stopPropagation()\n }\n }\n },\n [\n _c(\n \"div\",\n {\n staticClass: \"portal-modal-header\",\n style: _vm.dragStyle,\n on: {\n mousedown: function($event) {\n $event.preventDefault()\n return _vm.startDrag($event)\n }\n }\n },\n [\n _c(\"h3\", { staticClass: \"portal-modal-title\" }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"context_form_title\")))\n ]),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton close-form cursor-pointer\",\n on: {\n click: function($event) {\n $event.stopPropagation()\n return _vm.$emit(\"closeContextForm\", $event)\n }\n }\n },\n [_vm._v(\"x\")]\n )\n ]\n ),\n _vm._v(\" \"),\n _c(\n \"div\",\n {\n staticClass: \"portal-modal-content\",\n on: {\n click: function($event) {\n $event.stopPropagation()\n }\n }\n },\n _vm._l(_vm.contextsList, function(context, index) {\n return _c(\n \"div\",\n { key: \"context_\" + index, staticClass: \"portal-context\" },\n [\n _c(\n \"form\",\n {\n staticClass: \"portal-form-context\",\n on: {\n submit: function($event) {\n $event.preventDefault()\n return _vm.saveContext(index)\n }\n }\n },\n [\n _c(\"div\", { staticClass: \"portal-context-info\" }, [\n !_vm.editedContexts.includes(index)\n ? _c(\"div\", { staticClass: \"context-name\" }, [\n _c(\"i\", {\n class: _vm.getClassesFav(index),\n attrs: { \"aria-hidden\": \"true\" },\n on: {\n click: function($event) {\n return _vm.changeBookmark(index)\n }\n }\n }),\n _vm._v(\" \"),\n _c(\n \"label\",\n {\n staticClass: \"cursor-pointer\",\n attrs: { for: \"context_\" + index }\n },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\" +\n _vm._s(context.name) +\n \"\\n\\t\\t\\t\\t\\t\\t\\t\"\n )\n ]\n )\n ])\n : _c(\"div\", { staticClass: \"context-name\" }, [\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: context.name,\n expression: \"context.name\"\n }\n ],\n ref: \"context_input_\" + index,\n refInFor: true,\n staticClass: \"context-edited-name\",\n attrs: { type: \"text\", required: \"\" },\n domProps: { value: context.name },\n on: {\n keyup: function($event) {\n if (\n !$event.type.indexOf(\"key\") &&\n _vm._k(\n $event.keyCode,\n \"enter\",\n 13,\n $event.key,\n \"Enter\"\n )\n ) {\n return null\n }\n return $event.form.submit()\n },\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.$set(\n context,\n \"name\",\n $event.target.value\n )\n }\n }\n })\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"context-menu\" }, [\n _c(\n \"button\",\n {\n directives: [\n {\n name: \"show\",\n rawName: \"v-show\",\n value: _vm.editedContexts.includes(index),\n expression: \"editedContexts.includes(index)\"\n }\n ],\n staticClass: \"edit-context cursor-pointer bouton\",\n attrs: { type: \"submit\" }\n },\n [\n _c(\"i\", {\n staticClass: \"fa fa-save\",\n attrs: {\n \"aria-hidden\": \"true\",\n title: _vm.$cms.getMessage(\"save\")\n }\n })\n ]\n ),\n _vm._v(\" \"),\n !_vm.editedContexts.includes(index)\n ? _c(\n \"button\",\n {\n staticClass:\n \"edit-context cursor-pointer bouton\",\n attrs: { type: \"button\" },\n on: {\n click: function($event) {\n return _vm.editContext(index)\n }\n }\n },\n [\n _c(\"i\", {\n staticClass: \"fa fa-pencil\",\n attrs: {\n \"aria-hidden\": \"true\",\n title: _vm.$cms.getMessage(\n \"cms_page_edit\"\n )\n }\n })\n ]\n )\n : _vm._e(),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass:\n \"edit-context cursor-pointer bouton delete\",\n attrs: { type: \"button\" },\n on: {\n click: function($event) {\n return _vm.removeContext(index)\n }\n }\n },\n [\n _c(\"i\", {\n staticClass: \"fa fa-trash\",\n attrs: {\n \"aria-hidden\": \"true\",\n title: _vm.$cms.getMessage(\"delete\")\n }\n })\n ]\n )\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"context-others\" }, [\n _c(\n \"button\",\n {\n staticClass: \"edit-context cursor-pointer bouton\",\n attrs: { type: \"button\" },\n on: {\n click: function($event) {\n return _vm.sendContext(index)\n }\n }\n },\n [\n _c(\"i\", {\n staticClass: \"fa fa-arrow-right\",\n attrs: {\n \"aria-hidden\": \"true\",\n title: _vm.$cms.getMessage(\n \"portal_send_preview\"\n )\n }\n })\n ]\n )\n ])\n ])\n ]\n )\n ]\n )\n }),\n 0\n )\n ]\n )\n ]\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/preview/contextForm.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/preview/preview.vue?vue&type=template&id=64e5ad80&":
/*!*******************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/preview/preview.vue?vue&type=template&id=64e5ad80& ***!
\*******************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n { staticClass: \"portal-preview\" },\n [\n _vm.showFormContext\n ? _c(\"context_form\", {\n attrs: {\n contexts: _vm.item.contexts,\n bookmarkContext: _vm.item.bookmark_context\n },\n on: {\n closeContextForm: _vm.closeContextForm,\n saveContext: _vm.editContext,\n removeContext: _vm.removeContext,\n sendContext: _vm.sendContext,\n changeBookmark: _vm.changeBookmark\n }\n })\n : _vm._e(),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-preview-menu\" }, [\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: { type: \"button\", disabled: _vm.item.contexts.length == 0 },\n on: { click: _vm.openContextForm }\n },\n [\n _c(\"i\", {\n staticClass: \"fa fa-cogs\",\n attrs: {\n \"aria-hidden\": \"true\",\n title: _vm.$cms.getMessage(\"context_manage_title\")\n }\n })\n ]\n ),\n _vm._v(\" \"),\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.context,\n expression: \"context\"\n }\n ],\n on: {\n change: [\n function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.context = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n },\n _vm.setContext\n ]\n }\n },\n [\n _c(\"option\", { attrs: { value: \"\", disabled: \"\" } }, [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\" +\n _vm._s(_vm.$cms.getMessage(\"preview_default_context\")) +\n \"\\n\\t\\t\\t\\t\"\n )\n ]),\n _vm._v(\" \"),\n _vm._l(_vm.item.contexts, function(context, index) {\n return _c(\"option\", { key: index, domProps: { value: index } }, [\n _vm._v(\"\\n\\t\\t\\t\\t\\t\" + _vm._s(context.name) + \"\\n\\t\\t\\t\\t\")\n ])\n })\n ],\n 2\n ),\n _vm._v(\" \"),\n _c(\n \"label\",\n { staticClass: \"cursor-pointer\", attrs: { for: \"preview-url\" } },\n [_vm._v(_vm._s(_vm.$cms.getMessage(\"portal_url_preview\")))]\n ),\n _vm._v(\" \"),\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model.trim\",\n value: _vm.url,\n expression: \"url\",\n modifiers: { trim: true }\n }\n ],\n attrs: {\n id: \"preview-url\",\n name: \"preview_url\",\n type: \"text\",\n placeholder: _vm.$cms.url_base_opac\n },\n domProps: { value: _vm.url },\n on: {\n keyup: function($event) {\n if (\n !$event.type.indexOf(\"key\") &&\n _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")\n ) {\n return null\n }\n return _vm.send($event)\n },\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.url = $event.target.value.trim()\n },\n blur: function($event) {\n return _vm.$forceUpdate()\n }\n }\n }),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: {\n type: \"button\",\n title: _vm.$cms.getMessage(\"portal_send_preview\")\n },\n on: { click: _vm.send }\n },\n [\n _c(\"i\", {\n staticClass: \"fa fa-arrow-right\",\n attrs: { \"aria-hidden\": \"true\" }\n })\n ]\n ),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: {\n type: \"button\",\n title: _vm.$cms.getMessage(\"portal_reload_preview\")\n },\n on: { click: _vm.reload }\n },\n [\n _c(\"i\", {\n staticClass: \"fa fa-refresh\",\n attrs: { \"aria-hidden\": \"true\" }\n })\n ]\n ),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: { type: \"button\" },\n on: { click: _vm.home }\n },\n [\n _c(\"i\", {\n staticClass: \"fa fa-home\",\n attrs: { \"aria-hidden\": \"true\" }\n })\n ]\n ),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"add-context\" }, [\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: {\n type: \"button\",\n title: _vm.getSaveContextMessage(),\n disabled: _vm.getContextPages().length == 0\n },\n on: {\n click: function($event) {\n $event.stopPropagation()\n return _vm.showAddFormContext($event)\n }\n }\n },\n [\n _c(\"i\", {\n staticClass: \"fa fa-floppy-o\",\n attrs: { \"aria-hidden\": \"true\" }\n })\n ]\n ),\n _vm._v(\" \"),\n _c(\n \"div\",\n {\n directives: [\n {\n name: \"show\",\n rawName: \"v-show\",\n value: _vm.showForm,\n expression: \"showForm\"\n }\n ],\n staticClass: \"context-form\",\n on: {\n click: function($event) {\n $event.stopPropagation()\n }\n }\n },\n [\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.newContextPage,\n expression: \"newContextPage\"\n }\n ],\n on: {\n change: function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.newContextPage = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n }\n }\n },\n _vm._l(_vm.getContextPages(), function(page, index) {\n return _c(\"option\", { domProps: { value: index } }, [\n _vm._v(_vm._s(page.name))\n ])\n }),\n 0\n ),\n _vm._v(\" \"),\n _c(\"input\", {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.newContext.name,\n expression: \"newContext.name\"\n }\n ],\n ref: \"context_input\",\n attrs: {\n type: \"text\",\n placeholder: _vm.$cms.getMessage(\"context_name\")\n },\n domProps: { value: _vm.newContext.name },\n on: {\n keyup: function($event) {\n if (\n !$event.type.indexOf(\"key\") &&\n _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")\n ) {\n return null\n }\n return _vm.saveContext($event)\n },\n input: function($event) {\n if ($event.target.composing) {\n return\n }\n _vm.$set(_vm.newContext, \"name\", $event.target.value)\n }\n }\n }),\n _vm._v(\" \"),\n _c(\n \"button\",\n {\n staticClass: \"bouton\",\n attrs: { type: \"button\" },\n on: { click: _vm.saveContext }\n },\n [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\\t\" +\n _vm._s(_vm.$cms.getMessage(\"save\")) +\n \"\\n\\t\\t\\t\\t\\t\"\n )\n ]\n )\n ]\n )\n ])\n ]),\n _vm._v(\" \"),\n !_vm.valid_url\n ? _c(\"p\", { staticClass: \"preview-url-error\" }, [\n _vm._v(_vm._s(_vm.$cms.getMessage(\"preview_url_not_valid\")))\n ])\n : _vm._e(),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"portal-preview-frame\" }, [\n _c(\n \"form\",\n {\n ref: \"formContext\",\n staticStyle: { border: \"0px\", margin: \"0\", background: \"none\" },\n attrs: {\n action: _vm.generateUrlContext(),\n method: \"post\",\n target: \"preview_frame\"\n }\n },\n _vm._l(_vm.getPOSTContext(), function(value, prop) {\n return _c(\"input\", {\n key: prop,\n attrs: { type: \"hidden\", name: prop },\n domProps: { value: value }\n })\n }),\n 0\n ),\n _vm._v(\" \"),\n _c(\"iframe\", {\n attrs: { name: \"preview_frame\", id: \"preview_frame\" },\n on: { load: _vm.iframeLoaded }\n })\n ])\n ],\n 1\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/preview/preview.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue?vue&type=template&id=1418f2b8&":
/*!**************************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue?vue&type=template&id=1418f2b8& ***!
\**************************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"zone-semantic\" }\n },\n [_vm._v(\"\\n\\t\\t\" + _vm._s(_vm.$cms.getMessage(\"zone_semantic\")) + \"\\n\\t\")]\n ),\n _vm._v(\" \"),\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.tag,\n expression: \"tag\"\n }\n ],\n attrs: { id: \"zone-semantic\", name: \"zone_semantic\", required: \"\" },\n on: {\n change: [\n function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.tag = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n },\n _vm.update\n ]\n }\n },\n _vm._l(_vm.$cms.semantic, function(tag, key) {\n return _c(\"option\", { key: key, domProps: { value: tag } }, [\n _vm._v(_vm._s(tag))\n ])\n }),\n 0\n )\n ])\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/semantics/HtmlSemantic.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/loaders/templateLoader.js?!./node_modules/vue-loader/lib/index.js?!./includes/templates/vuejs/portal/build/components/semantics/semantics.vue?vue&type=template&id=42c9038a&":
/*!***********************************************************************************************************************************************************************************************************************************************!*\
!*** ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./includes/templates/vuejs/portal/build/components/semantics/semantics.vue?vue&type=template&id=42c9038a& ***!
\***********************************************************************************************************************************************************************************************************************************************/
/*! exports provided: render, staticRenderFns */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"render\", function() { return render; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"staticRenderFns\", function() { return staticRenderFns; });\nvar render = function() {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\n \"div\",\n [\n _vm.isEditable\n ? _c(\"div\", { staticClass: \"portal-form-group\" }, [\n _vm.isForm\n ? _c(\n \"label\",\n {\n staticClass: \"portal-form-group-title cursor-pointer\",\n attrs: { for: \"zone-semantic\" }\n },\n [_vm._v(\"\\n\\t\\t\\t\" + _vm._s(_vm.label) + \"\\n\\t\\t\")]\n )\n : _vm._e(),\n _vm._v(\" \"),\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.selectedSemantic,\n expression: \"selectedSemantic\"\n }\n ],\n attrs: {\n id: \"zone-class-semantic\",\n name: \"zone_class_semantic\",\n required: \"\"\n },\n on: {\n change: [\n function($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function(o) {\n return o.selected\n })\n .map(function(o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.selectedSemantic = $event.target.multiple\n ? $$selectedVal\n : $$selectedVal[0]\n },\n _vm.changeSemantic\n ]\n }\n },\n _vm._l(_vm.$cms.class_semantic, function(semantic, key) {\n return _c(\n \"option\",\n { key: key, domProps: { value: semantic.class_name } },\n [_vm._v(\"\\n\\t\\t\\t\\t\" + _vm._s(semantic.label) + \"\\n\\t\\t\\t\")]\n )\n }),\n 0\n )\n ])\n : _vm._e(),\n _vm._v(\" \"),\n _vm.componentName\n ? _c(_vm.componentName, {\n tag: \"component\",\n attrs: { semantic: _vm.semantic },\n on: {\n update: function($event) {\n return _vm.$emit(\"update\", $event)\n }\n }\n })\n : _vm._e()\n ],\n 1\n )\n}\nvar staticRenderFns = []\nrender._withStripped = true\n\n\n\n//# sourceURL=webpack:///./includes/templates/vuejs/portal/build/components/semantics/semantics.vue?./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options");
/***/ }),
/***/ "./node_modules/vue-loader/lib/runtime/componentNormalizer.js":
/*!********************************************************************!*\
!*** ./node_modules/vue-loader/lib/runtime/componentNormalizer.js ***!
\********************************************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return normalizeComponent; });\n/* globals __VUE_SSR_CONTEXT__ */\n\n// IMPORTANT: Do NOT use ES2015 features in this file (except for modules).\n// This module is a runtime utility for cleaner component module output and will\n// be included in the final webpack user bundle.\n\nfunction normalizeComponent (\n scriptExports,\n render,\n staticRenderFns,\n functionalTemplate,\n injectStyles,\n scopeId,\n moduleIdentifier, /* server only */\n shadowMode /* vue-cli only */\n) {\n // Vue.extend constructor export interop\n var options = typeof scriptExports === 'function'\n ? scriptExports.options\n : scriptExports\n\n // render functions\n if (render) {\n options.render = render\n options.staticRenderFns = staticRenderFns\n options._compiled = true\n }\n\n // functional template\n if (functionalTemplate) {\n options.functional = true\n }\n\n // scopedId\n if (scopeId) {\n options._scopeId = 'data-v-' + scopeId\n }\n\n var hook\n if (moduleIdentifier) { // server build\n hook = function (context) {\n // 2.3 injection\n context =\n context || // cached call\n (this.$vnode && this.$vnode.ssrContext) || // stateful\n (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional\n // 2.2 with runInNewContext: true\n if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {\n context = __VUE_SSR_CONTEXT__\n }\n // inject component styles\n if (injectStyles) {\n injectStyles.call(this, context)\n }\n // register component module identifier for async chunk inferrence\n if (context && context._registeredComponents) {\n context._registeredComponents.add(moduleIdentifier)\n }\n }\n // used by ssr in case component is cached and beforeCreate\n // never gets called\n options._ssrRegister = hook\n } else if (injectStyles) {\n hook = shadowMode\n ? function () { injectStyles.call(this, this.$root.$options.shadowRoot) }\n : injectStyles\n }\n\n if (hook) {\n if (options.functional) {\n // for template-only hot-reload because in that case the render fn doesn't\n // go through the normalizer\n options._injectStyles = hook\n // register for functional component in vue file\n var originalRender = options.render\n options.render = function renderWithStyleInjection (h, context) {\n hook.call(context)\n return originalRender(h, context)\n }\n } else {\n // inject component registration as beforeCreate hook\n var existing = options.beforeCreate\n options.beforeCreate = existing\n ? [].concat(existing, hook)\n : [hook]\n }\n }\n\n return {\n exports: scriptExports,\n options: options\n }\n}\n\n\n//# sourceURL=webpack:///./node_modules/vue-loader/lib/runtime/componentNormalizer.js?");
/***/ }),
/***/ "./node_modules/vue/dist/vue.esm.js":
/*!******************************************!*\
!*** ./node_modules/vue/dist/vue.esm.js ***!
\******************************************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
eval("__webpack_require__.r(__webpack_exports__);\n/* WEBPACK VAR INJECTION */(function(global, setImmediate) {/*!\n * Vue.js v2.6.11\n * (c) 2014-2019 Evan You\n * Released under the MIT License.\n */\n/* */\n\nvar emptyObject = Object.freeze({});\n\n// These helpers produce better VM code in JS engines due to their\n// explicitness and function inlining.\nfunction isUndef (v) {\n return v === undefined || v === null\n}\n\nfunction isDef (v) {\n return v !== undefined && v !== null\n}\n\nfunction isTrue (v) {\n return v === true\n}\n\nfunction isFalse (v) {\n return v === false\n}\n\n/**\n * Check if value is primitive.\n */\nfunction isPrimitive (value) {\n return (\n typeof value === 'string' ||\n typeof value === 'number' ||\n // $flow-disable-line\n typeof value === 'symbol' ||\n typeof value === 'boolean'\n )\n}\n\n/**\n * Quick object check - this is primarily used to tell\n * Objects from primitive values when we know the value\n * is a JSON-compliant type.\n */\nfunction isObject (obj) {\n return obj !== null && typeof obj === 'object'\n}\n\n/**\n * Get the raw type string of a value, e.g., [object Object].\n */\nvar _toString = Object.prototype.toString;\n\nfunction toRawType (value) {\n return _toString.call(value).slice(8, -1)\n}\n\n/**\n * Strict object type check. Only returns true\n * for plain JavaScript objects.\n */\nfunction isPlainObject (obj) {\n return _toString.call(obj) === '[object Object]'\n}\n\nfunction isRegExp (v) {\n return _toString.call(v) === '[object RegExp]'\n}\n\n/**\n * Check if val is a valid array index.\n */\nfunction isValidArrayIndex (val) {\n var n = parseFloat(String(val));\n return n >= 0 && Math.floor(n) === n && isFinite(val)\n}\n\nfunction isPromise (val) {\n return (\n isDef(val) &&\n typeof val.then === 'function' &&\n typeof val.catch === 'function'\n )\n}\n\n/**\n * Convert a value to a string that is actually rendered.\n */\nfunction toString (val) {\n return val == null\n ? ''\n : Array.isArray(val) || (isPlainObject(val) && val.toString === _toString)\n ? JSON.stringify(val, null, 2)\n : String(val)\n}\n\n/**\n * Convert an input value to a number for persistence.\n * If the conversion fails, return original string.\n */\nfunction toNumber (val) {\n var n = parseFloat(val);\n return isNaN(n) ? val : n\n}\n\n/**\n * Make a map and return a function for checking if a key\n * is in that map.\n */\nfunction makeMap (\n str,\n expectsLowerCase\n) {\n var map = Object.create(null);\n var list = str.split(',');\n for (var i = 0; i < list.length; i++) {\n map[list[i]] = true;\n }\n return expectsLowerCase\n ? function (val) { return map[val.toLowerCase()]; }\n : function (val) { return map[val]; }\n}\n\n/**\n * Check if a tag is a built-in tag.\n */\nvar isBuiltInTag = makeMap('slot,component', true);\n\n/**\n * Check if an attribute is a reserved attribute.\n */\nvar isReservedAttribute = makeMap('key,ref,slot,slot-scope,is');\n\n/**\n * Remove an item from an array.\n */\nfunction remove (arr, item) {\n if (arr.length) {\n var index = arr.indexOf(item);\n if (index > -1) {\n return arr.splice(index, 1)\n }\n }\n}\n\n/**\n * Check whether an object has the property.\n */\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nfunction hasOwn (obj, key) {\n return hasOwnProperty.call(obj, key)\n}\n\n/**\n * Create a cached version of a pure function.\n */\nfunction cached (fn) {\n var cache = Object.create(null);\n return (function cachedFn (str) {\n var hit = cache[str];\n return hit || (cache[str] = fn(str))\n })\n}\n\n/**\n * Camelize a hyphen-delimited string.\n */\nvar camelizeRE = /-(\\w)/g;\nvar camelize = cached(function (str) {\n return str.replace(camelizeRE, function (_, c) { return c ? c.toUpperCase() : ''; })\n});\n\n/**\n * Capitalize a string.\n */\nvar capitalize = cached(function (str) {\n return str.charAt(0).toUpperCase() + str.slice(1)\n});\n\n/**\n * Hyphenate a camelCase string.\n */\nvar hyphenateRE = /\\B([A-Z])/g;\nvar hyphenate = cached(function (str) {\n return str.replace(hyphenateRE, '-$1').toLowerCase()\n});\n\n/**\n * Simple bind polyfill for environments that do not support it,\n * e.g., PhantomJS 1.x. Technically, we don't need this anymore\n * since native bind is now performant enough in most browsers.\n * But removing it would mean breaking code that was able to run in\n * PhantomJS 1.x, so this must be kept for backward compatibility.\n */\n\n/* istanbul ignore next */\nfunction polyfillBind (fn, ctx) {\n function boundFn (a) {\n var l = arguments.length;\n return l\n ? l > 1\n ? fn.apply(ctx, arguments)\n : fn.call(ctx, a)\n : fn.call(ctx)\n }\n\n boundFn._length = fn.length;\n return boundFn\n}\n\nfunction nativeBind (fn, ctx) {\n return fn.bind(ctx)\n}\n\nvar bind = Function.prototype.bind\n ? nativeBind\n : polyfillBind;\n\n/**\n * Convert an Array-like object to a real Array.\n */\nfunction toArray (list, start) {\n start = start || 0;\n var i = list.length - start;\n var ret = new Array(i);\n while (i--) {\n ret[i] = list[i + start];\n }\n return ret\n}\n\n/**\n * Mix properties into target object.\n */\nfunction extend (to, _from) {\n for (var key in _from) {\n to[key] = _from[key];\n }\n return to\n}\n\n/**\n * Merge an Array of Objects into a single Object.\n */\nfunction toObject (arr) {\n var res = {};\n for (var i = 0; i < arr.length; i++) {\n if (arr[i]) {\n extend(res, arr[i]);\n }\n }\n return res\n}\n\n/* eslint-disable no-unused-vars */\n\n/**\n * Perform no operation.\n * Stubbing args to make Flow happy without leaving useless transpiled code\n * with ...rest (https://flow.org/blog/2017/05/07/Strict-Function-Call-Arity/).\n */\nfunction noop (a, b, c) {}\n\n/**\n * Always return false.\n */\nvar no = function (a, b, c) { return false; };\n\n/* eslint-enable no-unused-vars */\n\n/**\n * Return the same value.\n */\nvar identity = function (_) { return _; };\n\n/**\n * Generate a string containing static keys from compiler modules.\n */\nfunction genStaticKeys (modules) {\n return modules.reduce(function (keys, m) {\n return keys.concat(m.staticKeys || [])\n }, []).join(',')\n}\n\n/**\n * Check if two values are loosely equal - that is,\n * if they are plain objects, do they have the same shape?\n */\nfunction looseEqual (a, b) {\n if (a === b) { return true }\n var isObjectA = isObject(a);\n var isObjectB = isObject(b);\n if (isObjectA && isObjectB) {\n try {\n var isArrayA = Array.isArray(a);\n var isArrayB = Array.isArray(b);\n if (isArrayA && isArrayB) {\n return a.length === b.length && a.every(function (e, i) {\n return looseEqual(e, b[i])\n })\n } else if (a instanceof Date && b instanceof Date) {\n return a.getTime() === b.getTime()\n } else if (!isArrayA && !isArrayB) {\n var keysA = Object.keys(a);\n var keysB = Object.keys(b);\n return keysA.length === keysB.length && keysA.every(function (key) {\n return looseEqual(a[key], b[key])\n })\n } else {\n /* istanbul ignore next */\n return false\n }\n } catch (e) {\n /* istanbul ignore next */\n return false\n }\n } else if (!isObjectA && !isObjectB) {\n return String(a) === String(b)\n } else {\n return false\n }\n}\n\n/**\n * Return the first index at which a loosely equal value can be\n * found in the array (if value is a plain object, the array must\n * contain an object of the same shape), or -1 if it is not present.\n */\nfunction looseIndexOf (arr, val) {\n for (var i = 0; i < arr.length; i++) {\n if (looseEqual(arr[i], val)) { return i }\n }\n return -1\n}\n\n/**\n * Ensure a function is called only once.\n */\nfunction once (fn) {\n var called = false;\n return function () {\n if (!called) {\n called = true;\n fn.apply(this, arguments);\n }\n }\n}\n\nvar SSR_ATTR = 'data-server-rendered';\n\nvar ASSET_TYPES = [\n 'component',\n 'directive',\n 'filter'\n];\n\nvar LIFECYCLE_HOOKS = [\n 'beforeCreate',\n 'created',\n 'beforeMount',\n 'mounted',\n 'beforeUpdate',\n 'updated',\n 'beforeDestroy',\n 'destroyed',\n 'activated',\n 'deactivated',\n 'errorCaptured',\n 'serverPrefetch'\n];\n\n/* */\n\n\n\nvar config = ({\n /**\n * Option merge strategies (used in core/util/options)\n */\n // $flow-disable-line\n optionMergeStrategies: Object.create(null),\n\n /**\n * Whether to suppress warnings.\n */\n silent: false,\n\n /**\n * Show production mode tip message on boot?\n */\n productionTip: \"development\" !== 'production',\n\n /**\n * Whether to enable devtools\n */\n devtools: \"development\" !== 'production',\n\n /**\n * Whether to record perf\n */\n performance: false,\n\n /**\n * Error handler for watcher errors\n */\n errorHandler: null,\n\n /**\n * Warn handler for watcher warns\n */\n warnHandler: null,\n\n /**\n * Ignore certain custom elements\n */\n ignoredElements: [],\n\n /**\n * Custom user key aliases for v-on\n */\n // $flow-disable-line\n keyCodes: Object.create(null),\n\n /**\n * Check if a tag is reserved so that it cannot be registered as a\n * component. This is platform-dependent and may be overwritten.\n */\n isReservedTag: no,\n\n /**\n * Check if an attribute is reserved so that it cannot be used as a component\n * prop. This is platform-dependent and may be overwritten.\n */\n isReservedAttr: no,\n\n /**\n * Check if a tag is an unknown element.\n * Platform-dependent.\n */\n isUnknownElement: no,\n\n /**\n * Get the namespace of an element\n */\n getTagNamespace: noop,\n\n /**\n * Parse the real tag name for the specific platform.\n */\n parsePlatformTagName: identity,\n\n /**\n * Check if an attribute must be bound using property, e.g. value\n * Platform-dependent.\n */\n mustUseProp: no,\n\n /**\n * Perform updates asynchronously. Intended to be used by Vue Test Utils\n * This will significantly reduce performance if set to false.\n */\n async: true,\n\n /**\n * Exposed for legacy reasons\n */\n _lifecycleHooks: LIFECYCLE_HOOKS\n});\n\n/* */\n\n/**\n * unicode letters used for parsing html tags, component names and property paths.\n * using https://www.w3.org/TR/html53/semantics-scripting.html#potentialcustomelementname\n * skipping \\u10000-\\uEFFFF due to it freezing up PhantomJS\n */\nvar unicodeRegExp = /a-zA-Z\\u00B7\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u203F-\\u2040\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD/;\n\n/**\n * Check if a string starts with $ or _\n */\nfunction isReserved (str) {\n var c = (str + '').charCodeAt(0);\n return c === 0x24 || c === 0x5F\n}\n\n/**\n * Define a property.\n */\nfunction def (obj, key, val, enumerable) {\n Object.defineProperty(obj, key, {\n value: val,\n enumerable: !!enumerable,\n writable: true,\n configurable: true\n });\n}\n\n/**\n * Parse simple path.\n */\nvar bailRE = new RegExp((\"[^\" + (unicodeRegExp.source) + \".$_\\\\d]\"));\nfunction parsePath (path) {\n if (bailRE.test(path)) {\n return\n }\n var segments = path.split('.');\n return function (obj) {\n for (var i = 0; i < segments.length; i++) {\n if (!obj) { return }\n obj = obj[segments[i]];\n }\n return obj\n }\n}\n\n/* */\n\n// can we use __proto__?\nvar hasProto = '__proto__' in {};\n\n// Browser environment sniffing\nvar inBrowser = typeof window !== 'undefined';\nvar inWeex = typeof WXEnvironment !== 'undefined' && !!WXEnvironment.platform;\nvar weexPlatform = inWeex && WXEnvironment.platform.toLowerCase();\nvar UA = inBrowser && window.navigator.userAgent.toLowerCase();\nvar isIE = UA && /msie|trident/.test(UA);\nvar isIE9 = UA && UA.indexOf('msie 9.0') > 0;\nvar isEdge = UA && UA.indexOf('edge/') > 0;\nvar isAndroid = (UA && UA.indexOf('android') > 0) || (weexPlatform === 'android');\nvar isIOS = (UA && /iphone|ipad|ipod|ios/.test(UA)) || (weexPlatform === 'ios');\nvar isChrome = UA && /chrome\\/\\d+/.test(UA) && !isEdge;\nvar isPhantomJS = UA && /phantomjs/.test(UA);\nvar isFF = UA && UA.match(/firefox\\/(\\d+)/);\n\n// Firefox has a \"watch\" function on Object.prototype...\nvar nativeWatch = ({}).watch;\n\nvar supportsPassive = false;\nif (inBrowser) {\n try {\n var opts = {};\n Object.defineProperty(opts, 'passive', ({\n get: function get () {\n /* istanbul ignore next */\n supportsPassive = true;\n }\n })); // https://github.com/facebook/flow/issues/285\n window.addEventListener('test-passive', null, opts);\n } catch (e) {}\n}\n\n// this needs to be lazy-evaled because vue may be required before\n// vue-server-renderer can set VUE_ENV\nvar _isServer;\nvar isServerRendering = function () {\n if (_isServer === undefined) {\n /* istanbul ignore if */\n if (!inBrowser && !inWeex && typeof global !== 'undefined') {\n // detect presence of vue-server-renderer and avoid\n // Webpack shimming the process\n _isServer = global['process'] && global['process'].env.VUE_ENV === 'server';\n } else {\n _isServer = false;\n }\n }\n return _isServer\n};\n\n// detect devtools\nvar devtools = inBrowser && window.__VUE_DEVTOOLS_GLOBAL_HOOK__;\n\n/* istanbul ignore next */\nfunction isNative (Ctor) {\n return typeof Ctor === 'function' && /native code/.test(Ctor.toString())\n}\n\nvar hasSymbol =\n typeof Symbol !== 'undefined' && isNative(Symbol) &&\n typeof Reflect !== 'undefined' && isNative(Reflect.ownKeys);\n\nvar _Set;\n/* istanbul ignore if */ // $flow-disable-line\nif (typeof Set !== 'undefined' && isNative(Set)) {\n // use native Set when available.\n _Set = Set;\n} else {\n // a non-standard Set polyfill that only works with primitive keys.\n _Set = /*@__PURE__*/(function () {\n function Set () {\n this.set = Object.create(null);\n }\n Set.prototype.has = function has (key) {\n return this.set[key] === true\n };\n Set.prototype.add = function add (key) {\n this.set[key] = true;\n };\n Set.prototype.clear = function clear () {\n this.set = Object.create(null);\n };\n\n return Set;\n }());\n}\n\n/* */\n\nvar warn = noop;\nvar tip = noop;\nvar generateComponentTrace = (noop); // work around flow check\nvar formatComponentName = (noop);\n\nif (true) {\n var hasConsole = typeof console !== 'undefined';\n var classifyRE = /(?:^|[-_])(\\w)/g;\n var classify = function (str) { return str\n .replace(classifyRE, function (c) { return c.toUpperCase(); })\n .replace(/[-_]/g, ''); };\n\n warn = function (msg, vm) {\n var trace = vm ? generateComponentTrace(vm) : '';\n\n if (config.warnHandler) {\n config.warnHandler.call(null, msg, vm, trace);\n } else if (hasConsole && (!config.silent)) {\n console.error((\"[Vue warn]: \" + msg + trace));\n }\n };\n\n tip = function (msg, vm) {\n if (hasConsole && (!config.silent)) {\n console.warn(\"[Vue tip]: \" + msg + (\n vm ? generateComponentTrace(vm) : ''\n ));\n }\n };\n\n formatComponentName = function (vm, includeFile) {\n if (vm.$root === vm) {\n return '<Root>'\n }\n var options = typeof vm === 'function' && vm.cid != null\n ? vm.options\n : vm._isVue\n ? vm.$options || vm.constructor.options\n : vm;\n var name = options.name || options._componentTag;\n var file = options.__file;\n if (!name && file) {\n var match = file.match(/([^/\\\\]+)\\.vue$/);\n name = match && match[1];\n }\n\n return (\n (name ? (\"<\" + (classify(name)) + \">\") : \"<Anonymous>\") +\n (file && includeFile !== false ? (\" at \" + file) : '')\n )\n };\n\n var repeat = function (str, n) {\n var res = '';\n while (n) {\n if (n % 2 === 1) { res += str; }\n if (n > 1) { str += str; }\n n >>= 1;\n }\n return res\n };\n\n generateComponentTrace = function (vm) {\n if (vm._isVue && vm.$parent) {\n var tree = [];\n var currentRecursiveSequence = 0;\n while (vm) {\n if (tree.length > 0) {\n var last = tree[tree.length - 1];\n if (last.constructor === vm.constructor) {\n currentRecursiveSequence++;\n vm = vm.$parent;\n continue\n } else if (currentRecursiveSequence > 0) {\n tree[tree.length - 1] = [last, currentRecursiveSequence];\n currentRecursiveSequence = 0;\n }\n }\n tree.push(vm);\n vm = vm.$parent;\n }\n return '\\n\\nfound in\\n\\n' + tree\n .map(function (vm, i) { return (\"\" + (i === 0 ? '---> ' : repeat(' ', 5 + i * 2)) + (Array.isArray(vm)\n ? ((formatComponentName(vm[0])) + \"... (\" + (vm[1]) + \" recursive calls)\")\n : formatComponentName(vm))); })\n .join('\\n')\n } else {\n return (\"\\n\\n(found in \" + (formatComponentName(vm)) + \")\")\n }\n };\n}\n\n/* */\n\nvar uid = 0;\n\n/**\n * A dep is an observable that can have multiple\n * directives subscribing to it.\n */\nvar Dep = function Dep () {\n this.id = uid++;\n this.subs = [];\n};\n\nDep.prototype.addSub = function addSub (sub) {\n this.subs.push(sub);\n};\n\nDep.prototype.removeSub = function removeSub (sub) {\n remove(this.subs, sub);\n};\n\nDep.prototype.depend = function depend () {\n if (Dep.target) {\n Dep.target.addDep(this);\n }\n};\n\nDep.prototype.notify = function notify () {\n // stabilize the subscriber list first\n var subs = this.subs.slice();\n if ( true && !config.async) {\n // subs aren't sorted in scheduler if not running async\n // we need to sort them now to make sure they fire in correct\n // order\n subs.sort(function (a, b) { return a.id - b.id; });\n }\n for (var i = 0, l = subs.length; i < l; i++) {\n subs[i].update();\n }\n};\n\n// The current target watcher being evaluated.\n// This is globally unique because only one watcher\n// can be evaluated at a time.\nDep.target = null;\nvar targetStack = [];\n\nfunction pushTarget (target) {\n targetStack.push(target);\n Dep.target = target;\n}\n\nfunction popTarget () {\n targetStack.pop();\n Dep.target = targetStack[targetStack.length - 1];\n}\n\n/* */\n\nvar VNode = function VNode (\n tag,\n data,\n children,\n text,\n elm,\n context,\n componentOptions,\n asyncFactory\n) {\n this.tag = tag;\n this.data = data;\n this.children = children;\n this.text = text;\n this.elm = elm;\n this.ns = undefined;\n this.context = context;\n this.fnContext = undefined;\n this.fnOptions = undefined;\n this.fnScopeId = undefined;\n this.key = data && data.key;\n this.componentOptions = componentOptions;\n this.componentInstance = undefined;\n this.parent = undefined;\n this.raw = false;\n this.isStatic = false;\n this.isRootInsert = true;\n this.isComment = false;\n this.isCloned = false;\n this.isOnce = false;\n this.asyncFactory = asyncFactory;\n this.asyncMeta = undefined;\n this.isAsyncPlaceholder = false;\n};\n\nvar prototypeAccessors = { child: { configurable: true } };\n\n// DEPRECATED: alias for componentInstance for backwards compat.\n/* istanbul ignore next */\nprototypeAccessors.child.get = function () {\n return this.componentInstance\n};\n\nObject.defineProperties( VNode.prototype, prototypeAccessors );\n\nvar createEmptyVNode = function (text) {\n if ( text === void 0 ) text = '';\n\n var node = new VNode();\n node.text = text;\n node.isComment = true;\n return node\n};\n\nfunction createTextVNode (val) {\n return new VNode(undefined, undefined, undefined, String(val))\n}\n\n// optimized shallow clone\n// used for static nodes and slot nodes because they may be reused across\n// multiple renders, cloning them avoids errors when DOM manipulations rely\n// on their elm reference.\nfunction cloneVNode (vnode) {\n var cloned = new VNode(\n vnode.tag,\n vnode.data,\n // #7975\n // clone children array to avoid mutating original in case of cloning\n // a child.\n vnode.children && vnode.children.slice(),\n vnode.text,\n vnode.elm,\n vnode.context,\n vnode.componentOptions,\n vnode.asyncFactory\n );\n cloned.ns = vnode.ns;\n cloned.isStatic = vnode.isStatic;\n cloned.key = vnode.key;\n cloned.isComment = vnode.isComment;\n cloned.fnContext = vnode.fnContext;\n cloned.fnOptions = vnode.fnOptions;\n cloned.fnScopeId = vnode.fnScopeId;\n cloned.asyncMeta = vnode.asyncMeta;\n cloned.isCloned = true;\n return cloned\n}\n\n/*\n * not type checking this file because flow doesn't play well with\n * dynamically accessing methods on Array prototype\n */\n\nvar arrayProto = Array.prototype;\nvar arrayMethods = Object.create(arrayProto);\n\nvar methodsToPatch = [\n 'push',\n 'pop',\n 'shift',\n 'unshift',\n 'splice',\n 'sort',\n 'reverse'\n];\n\n/**\n * Intercept mutating methods and emit events\n */\nmethodsToPatch.forEach(function (method) {\n // cache original method\n var original = arrayProto[method];\n def(arrayMethods, method, function mutator () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var result = original.apply(this, args);\n var ob = this.__ob__;\n var inserted;\n switch (method) {\n case 'push':\n case 'unshift':\n inserted = args;\n break\n case 'splice':\n inserted = args.slice(2);\n break\n }\n if (inserted) { ob.observeArray(inserted); }\n // notify change\n ob.dep.notify();\n return result\n });\n});\n\n/* */\n\nvar arrayKeys = Object.getOwnPropertyNames(arrayMethods);\n\n/**\n * In some cases we may want to disable observation inside a component's\n * update computation.\n */\nvar shouldObserve = true;\n\nfunction toggleObserving (value) {\n shouldObserve = value;\n}\n\n/**\n * Observer class that is attached to each observed\n * object. Once attached, the observer converts the target\n * object's property keys into getter/setters that\n * collect dependencies and dispatch updates.\n */\nvar Observer = function Observer (value) {\n this.value = value;\n this.dep = new Dep();\n this.vmCount = 0;\n def(value, '__ob__', this);\n if (Array.isArray(value)) {\n if (hasProto) {\n protoAugment(value, arrayMethods);\n } else {\n copyAugment(value, arrayMethods, arrayKeys);\n }\n this.observeArray(value);\n } else {\n this.walk(value);\n }\n};\n\n/**\n * Walk through all properties and convert them into\n * getter/setters. This method should only be called when\n * value type is Object.\n */\nObserver.prototype.walk = function walk (obj) {\n var keys = Object.keys(obj);\n for (var i = 0; i < keys.length; i++) {\n defineReactive$$1(obj, keys[i]);\n }\n};\n\n/**\n * Observe a list of Array items.\n */\nObserver.prototype.observeArray = function observeArray (items) {\n for (var i = 0, l = items.length; i < l; i++) {\n observe(items[i]);\n }\n};\n\n// helpers\n\n/**\n * Augment a target Object or Array by intercepting\n * the prototype chain using __proto__\n */\nfunction protoAugment (target, src) {\n /* eslint-disable no-proto */\n target.__proto__ = src;\n /* eslint-enable no-proto */\n}\n\n/**\n * Augment a target Object or Array by defining\n * hidden properties.\n */\n/* istanbul ignore next */\nfunction copyAugment (target, src, keys) {\n for (var i = 0, l = keys.length; i < l; i++) {\n var key = keys[i];\n def(target, key, src[key]);\n }\n}\n\n/**\n * Attempt to create an observer instance for a value,\n * returns the new observer if successfully observed,\n * or the existing observer if the value already has one.\n */\nfunction observe (value, asRootData) {\n if (!isObject(value) || value instanceof VNode) {\n return\n }\n var ob;\n if (hasOwn(value, '__ob__') && value.__ob__ instanceof Observer) {\n ob = value.__ob__;\n } else if (\n shouldObserve &&\n !isServerRendering() &&\n (Array.isArray(value) || isPlainObject(value)) &&\n Object.isExtensible(value) &&\n !value._isVue\n ) {\n ob = new Observer(value);\n }\n if (asRootData && ob) {\n ob.vmCount++;\n }\n return ob\n}\n\n/**\n * Define a reactive property on an Object.\n */\nfunction defineReactive$$1 (\n obj,\n key,\n val,\n customSetter,\n shallow\n) {\n var dep = new Dep();\n\n var property = Object.getOwnPropertyDescriptor(obj, key);\n if (property && property.configurable === false) {\n return\n }\n\n // cater for pre-defined getter/setters\n var getter = property && property.get;\n var setter = property && property.set;\n if ((!getter || setter) && arguments.length === 2) {\n val = obj[key];\n }\n\n var childOb = !shallow && observe(val);\n Object.defineProperty(obj, key, {\n enumerable: true,\n configurable: true,\n get: function reactiveGetter () {\n var value = getter ? getter.call(obj) : val;\n if (Dep.target) {\n dep.depend();\n if (childOb) {\n childOb.dep.depend();\n if (Array.isArray(value)) {\n dependArray(value);\n }\n }\n }\n return value\n },\n set: function reactiveSetter (newVal) {\n var value = getter ? getter.call(obj) : val;\n /* eslint-disable no-self-compare */\n if (newVal === value || (newVal !== newVal && value !== value)) {\n return\n }\n /* eslint-enable no-self-compare */\n if ( true && customSetter) {\n customSetter();\n }\n // #7981: for accessor properties without setter\n if (getter && !setter) { return }\n if (setter) {\n setter.call(obj, newVal);\n } else {\n val = newVal;\n }\n childOb = !shallow && observe(newVal);\n dep.notify();\n }\n });\n}\n\n/**\n * Set a property on an object. Adds the new property and\n * triggers change notification if the property doesn't\n * already exist.\n */\nfunction set (target, key, val) {\n if ( true &&\n (isUndef(target) || isPrimitive(target))\n ) {\n warn((\"Cannot set reactive property on undefined, null, or primitive value: \" + ((target))));\n }\n if (Array.isArray(target) && isValidArrayIndex(key)) {\n target.length = Math.max(target.length, key);\n target.splice(key, 1, val);\n return val\n }\n if (key in target && !(key in Object.prototype)) {\n target[key] = val;\n return val\n }\n var ob = (target).__ob__;\n if (target._isVue || (ob && ob.vmCount)) {\n true && warn(\n 'Avoid adding reactive properties to a Vue instance or its root $data ' +\n 'at runtime - declare it upfront in the data option.'\n );\n return val\n }\n if (!ob) {\n target[key] = val;\n return val\n }\n defineReactive$$1(ob.value, key, val);\n ob.dep.notify();\n return val\n}\n\n/**\n * Delete a property and trigger change if necessary.\n */\nfunction del (target, key) {\n if ( true &&\n (isUndef(target) || isPrimitive(target))\n ) {\n warn((\"Cannot delete reactive property on undefined, null, or primitive value: \" + ((target))));\n }\n if (Array.isArray(target) && isValidArrayIndex(key)) {\n target.splice(key, 1);\n return\n }\n var ob = (target).__ob__;\n if (target._isVue || (ob && ob.vmCount)) {\n true && warn(\n 'Avoid deleting properties on a Vue instance or its root $data ' +\n '- just set it to null.'\n );\n return\n }\n if (!hasOwn(target, key)) {\n return\n }\n delete target[key];\n if (!ob) {\n return\n }\n ob.dep.notify();\n}\n\n/**\n * Collect dependencies on array elements when the array is touched, since\n * we cannot intercept array element access like property getters.\n */\nfunction dependArray (value) {\n for (var e = (void 0), i = 0, l = value.length; i < l; i++) {\n e = value[i];\n e && e.__ob__ && e.__ob__.dep.depend();\n if (Array.isArray(e)) {\n dependArray(e);\n }\n }\n}\n\n/* */\n\n/**\n * Option overwriting strategies are functions that handle\n * how to merge a parent option value and a child option\n * value into the final value.\n */\nvar strats = config.optionMergeStrategies;\n\n/**\n * Options with restrictions\n */\nif (true) {\n strats.el = strats.propsData = function (parent, child, vm, key) {\n if (!vm) {\n warn(\n \"option \\\"\" + key + \"\\\" can only be used during instance \" +\n 'creation with the `new` keyword.'\n );\n }\n return defaultStrat(parent, child)\n };\n}\n\n/**\n * Helper that recursively merges two data objects together.\n */\nfunction mergeData (to, from) {\n if (!from) { return to }\n var key, toVal, fromVal;\n\n var keys = hasSymbol\n ? Reflect.ownKeys(from)\n : Object.keys(from);\n\n for (var i = 0; i < keys.length; i++) {\n key = keys[i];\n // in case the object is already observed...\n if (key === '__ob__') { continue }\n toVal = to[key];\n fromVal = from[key];\n if (!hasOwn(to, key)) {\n set(to, key, fromVal);\n } else if (\n toVal !== fromVal &&\n isPlainObject(toVal) &&\n isPlainObject(fromVal)\n ) {\n mergeData(toVal, fromVal);\n }\n }\n return to\n}\n\n/**\n * Data\n */\nfunction mergeDataOrFn (\n parentVal,\n childVal,\n vm\n) {\n if (!vm) {\n // in a Vue.extend merge, both should be functions\n if (!childVal) {\n return parentVal\n }\n if (!parentVal) {\n return childVal\n }\n // when parentVal & childVal are both present,\n // we need to return a function that returns the\n // merged result of both functions... no need to\n // check if parentVal is a function here because\n // it has to be a function to pass previous merges.\n return function mergedDataFn () {\n return mergeData(\n typeof childVal === 'function' ? childVal.call(this, this) : childVal,\n typeof parentVal === 'function' ? parentVal.call(this, this) : parentVal\n )\n }\n } else {\n return function mergedInstanceDataFn () {\n // instance merge\n var instanceData = typeof childVal === 'function'\n ? childVal.call(vm, vm)\n : childVal;\n var defaultData = typeof parentVal === 'function'\n ? parentVal.call(vm, vm)\n : parentVal;\n if (instanceData) {\n return mergeData(instanceData, defaultData)\n } else {\n return defaultData\n }\n }\n }\n}\n\nstrats.data = function (\n parentVal,\n childVal,\n vm\n) {\n if (!vm) {\n if (childVal && typeof childVal !== 'function') {\n true && warn(\n 'The \"data\" option should be a function ' +\n 'that returns a per-instance value in component ' +\n 'definitions.',\n vm\n );\n\n return parentVal\n }\n return mergeDataOrFn(parentVal, childVal)\n }\n\n return mergeDataOrFn(parentVal, childVal, vm)\n};\n\n/**\n * Hooks and props are merged as arrays.\n */\nfunction mergeHook (\n parentVal,\n childVal\n) {\n var res = childVal\n ? parentVal\n ? parentVal.concat(childVal)\n : Array.isArray(childVal)\n ? childVal\n : [childVal]\n : parentVal;\n return res\n ? dedupeHooks(res)\n : res\n}\n\nfunction dedupeHooks (hooks) {\n var res = [];\n for (var i = 0; i < hooks.length; i++) {\n if (res.indexOf(hooks[i]) === -1) {\n res.push(hooks[i]);\n }\n }\n return res\n}\n\nLIFECYCLE_HOOKS.forEach(function (hook) {\n strats[hook] = mergeHook;\n});\n\n/**\n * Assets\n *\n * When a vm is present (instance creation), we need to do\n * a three-way merge between constructor options, instance\n * options and parent options.\n */\nfunction mergeAssets (\n parentVal,\n childVal,\n vm,\n key\n) {\n var res = Object.create(parentVal || null);\n if (childVal) {\n true && assertObjectType(key, childVal, vm);\n return extend(res, childVal)\n } else {\n return res\n }\n}\n\nASSET_TYPES.forEach(function (type) {\n strats[type + 's'] = mergeAssets;\n});\n\n/**\n * Watchers.\n *\n * Watchers hashes should not overwrite one\n * another, so we merge them as arrays.\n */\nstrats.watch = function (\n parentVal,\n childVal,\n vm,\n key\n) {\n // work around Firefox's Object.prototype.watch...\n if (parentVal === nativeWatch) { parentVal = undefined; }\n if (childVal === nativeWatch) { childVal = undefined; }\n /* istanbul ignore if */\n if (!childVal) { return Object.create(parentVal || null) }\n if (true) {\n assertObjectType(key, childVal, vm);\n }\n if (!parentVal) { return childVal }\n var ret = {};\n extend(ret, parentVal);\n for (var key$1 in childVal) {\n var parent = ret[key$1];\n var child = childVal[key$1];\n if (parent && !Array.isArray(parent)) {\n parent = [parent];\n }\n ret[key$1] = parent\n ? parent.concat(child)\n : Array.isArray(child) ? child : [child];\n }\n return ret\n};\n\n/**\n * Other object hashes.\n */\nstrats.props =\nstrats.methods =\nstrats.inject =\nstrats.computed = function (\n parentVal,\n childVal,\n vm,\n key\n) {\n if (childVal && \"development\" !== 'production') {\n assertObjectType(key, childVal, vm);\n }\n if (!parentVal) { return childVal }\n var ret = Object.create(null);\n extend(ret, parentVal);\n if (childVal) { extend(ret, childVal); }\n return ret\n};\nstrats.provide = mergeDataOrFn;\n\n/**\n * Default strategy.\n */\nvar defaultStrat = function (parentVal, childVal) {\n return childVal === undefined\n ? parentVal\n : childVal\n};\n\n/**\n * Validate component names\n */\nfunction checkComponents (options) {\n for (var key in options.components) {\n validateComponentName(key);\n }\n}\n\nfunction validateComponentName (name) {\n if (!new RegExp((\"^[a-zA-Z][\\\\-\\\\.0-9_\" + (unicodeRegExp.source) + \"]*$\")).test(name)) {\n warn(\n 'Invalid component name: \"' + name + '\". Component names ' +\n 'should conform to valid custom element name in html5 specification.'\n );\n }\n if (isBuiltInTag(name) || config.isReservedTag(name)) {\n warn(\n 'Do not use built-in or reserved HTML elements as component ' +\n 'id: ' + name\n );\n }\n}\n\n/**\n * Ensure all props option syntax are normalized into the\n * Object-based format.\n */\nfunction normalizeProps (options, vm) {\n var props = options.props;\n if (!props) { return }\n var res = {};\n var i, val, name;\n if (Array.isArray(props)) {\n i = props.length;\n while (i--) {\n val = props[i];\n if (typeof val === 'string') {\n name = camelize(val);\n res[name] = { type: null };\n } else if (true) {\n warn('props must be strings when using array syntax.');\n }\n }\n } else if (isPlainObject(props)) {\n for (var key in props) {\n val = props[key];\n name = camelize(key);\n res[name] = isPlainObject(val)\n ? val\n : { type: val };\n }\n } else if (true) {\n warn(\n \"Invalid value for option \\\"props\\\": expected an Array or an Object, \" +\n \"but got \" + (toRawType(props)) + \".\",\n vm\n );\n }\n options.props = res;\n}\n\n/**\n * Normalize all injections into Object-based format\n */\nfunction normalizeInject (options, vm) {\n var inject = options.inject;\n if (!inject) { return }\n var normalized = options.inject = {};\n if (Array.isArray(inject)) {\n for (var i = 0; i < inject.length; i++) {\n normalized[inject[i]] = { from: inject[i] };\n }\n } else if (isPlainObject(inject)) {\n for (var key in inject) {\n var val = inject[key];\n normalized[key] = isPlainObject(val)\n ? extend({ from: key }, val)\n : { from: val };\n }\n } else if (true) {\n warn(\n \"Invalid value for option \\\"inject\\\": expected an Array or an Object, \" +\n \"but got \" + (toRawType(inject)) + \".\",\n vm\n );\n }\n}\n\n/**\n * Normalize raw function directives into object format.\n */\nfunction normalizeDirectives (options) {\n var dirs = options.directives;\n if (dirs) {\n for (var key in dirs) {\n var def$$1 = dirs[key];\n if (typeof def$$1 === 'function') {\n dirs[key] = { bind: def$$1, update: def$$1 };\n }\n }\n }\n}\n\nfunction assertObjectType (name, value, vm) {\n if (!isPlainObject(value)) {\n warn(\n \"Invalid value for option \\\"\" + name + \"\\\": expected an Object, \" +\n \"but got \" + (toRawType(value)) + \".\",\n vm\n );\n }\n}\n\n/**\n * Merge two option objects into a new one.\n * Core utility used in both instantiation and inheritance.\n */\nfunction mergeOptions (\n parent,\n child,\n vm\n) {\n if (true) {\n checkComponents(child);\n }\n\n if (typeof child === 'function') {\n child = child.options;\n }\n\n normalizeProps(child, vm);\n normalizeInject(child, vm);\n normalizeDirectives(child);\n\n // Apply extends and mixins on the child options,\n // but only if it is a raw options object that isn't\n // the result of another mergeOptions call.\n // Only merged options has the _base property.\n if (!child._base) {\n if (child.extends) {\n parent = mergeOptions(parent, child.extends, vm);\n }\n if (child.mixins) {\n for (var i = 0, l = child.mixins.length; i < l; i++) {\n parent = mergeOptions(parent, child.mixins[i], vm);\n }\n }\n }\n\n var options = {};\n var key;\n for (key in parent) {\n mergeField(key);\n }\n for (key in child) {\n if (!hasOwn(parent, key)) {\n mergeField(key);\n }\n }\n function mergeField (key) {\n var strat = strats[key] || defaultStrat;\n options[key] = strat(parent[key], child[key], vm, key);\n }\n return options\n}\n\n/**\n * Resolve an asset.\n * This function is used because child instances need access\n * to assets defined in its ancestor chain.\n */\nfunction resolveAsset (\n options,\n type,\n id,\n warnMissing\n) {\n /* istanbul ignore if */\n if (typeof id !== 'string') {\n return\n }\n var assets = options[type];\n // check local registration variations first\n if (hasOwn(assets, id)) { return assets[id] }\n var camelizedId = camelize(id);\n if (hasOwn(assets, camelizedId)) { return assets[camelizedId] }\n var PascalCaseId = capitalize(camelizedId);\n if (hasOwn(assets, PascalCaseId)) { return assets[PascalCaseId] }\n // fallback to prototype chain\n var res = assets[id] || assets[camelizedId] || assets[PascalCaseId];\n if ( true && warnMissing && !res) {\n warn(\n 'Failed to resolve ' + type.slice(0, -1) + ': ' + id,\n options\n );\n }\n return res\n}\n\n/* */\n\n\n\nfunction validateProp (\n key,\n propOptions,\n propsData,\n vm\n) {\n var prop = propOptions[key];\n var absent = !hasOwn(propsData, key);\n var value = propsData[key];\n // boolean casting\n var booleanIndex = getTypeIndex(Boolean, prop.type);\n if (booleanIndex > -1) {\n if (absent && !hasOwn(prop, 'default')) {\n value = false;\n } else if (value === '' || value === hyphenate(key)) {\n // only cast empty string / same name to boolean if\n // boolean has higher priority\n var stringIndex = getTypeIndex(String, prop.type);\n if (stringIndex < 0 || booleanIndex < stringIndex) {\n value = true;\n }\n }\n }\n // check default value\n if (value === undefined) {\n value = getPropDefaultValue(vm, prop, key);\n // since the default value is a fresh copy,\n // make sure to observe it.\n var prevShouldObserve = shouldObserve;\n toggleObserving(true);\n observe(value);\n toggleObserving(prevShouldObserve);\n }\n if (\n true\n ) {\n assertProp(prop, key, value, vm, absent);\n }\n return value\n}\n\n/**\n * Get the default value of a prop.\n */\nfunction getPropDefaultValue (vm, prop, key) {\n // no default, return undefined\n if (!hasOwn(prop, 'default')) {\n return undefined\n }\n var def = prop.default;\n // warn against non-factory defaults for Object & Array\n if ( true && isObject(def)) {\n warn(\n 'Invalid default value for prop \"' + key + '\": ' +\n 'Props with type Object/Array must use a factory function ' +\n 'to return the default value.',\n vm\n );\n }\n // the raw prop value was also undefined from previous render,\n // return previous default value to avoid unnecessary watcher trigger\n if (vm && vm.$options.propsData &&\n vm.$options.propsData[key] === undefined &&\n vm._props[key] !== undefined\n ) {\n return vm._props[key]\n }\n // call factory function for non-Function types\n // a value is Function if its prototype is function even across different execution context\n return typeof def === 'function' && getType(prop.type) !== 'Function'\n ? def.call(vm)\n : def\n}\n\n/**\n * Assert whether a prop is valid.\n */\nfunction assertProp (\n prop,\n name,\n value,\n vm,\n absent\n) {\n if (prop.required && absent) {\n warn(\n 'Missing required prop: \"' + name + '\"',\n vm\n );\n return\n }\n if (value == null && !prop.required) {\n return\n }\n var type = prop.type;\n var valid = !type || type === true;\n var expectedTypes = [];\n if (type) {\n if (!Array.isArray(type)) {\n type = [type];\n }\n for (var i = 0; i < type.length && !valid; i++) {\n var assertedType = assertType(value, type[i]);\n expectedTypes.push(assertedType.expectedType || '');\n valid = assertedType.valid;\n }\n }\n\n if (!valid) {\n warn(\n getInvalidTypeMessage(name, value, expectedTypes),\n vm\n );\n return\n }\n var validator = prop.validator;\n if (validator) {\n if (!validator(value)) {\n warn(\n 'Invalid prop: custom validator check failed for prop \"' + name + '\".',\n vm\n );\n }\n }\n}\n\nvar simpleCheckRE = /^(String|Number|Boolean|Function|Symbol)$/;\n\nfunction assertType (value, type) {\n var valid;\n var expectedType = getType(type);\n if (simpleCheckRE.test(expectedType)) {\n var t = typeof value;\n valid = t === expectedType.toLowerCase();\n // for primitive wrapper objects\n if (!valid && t === 'object') {\n valid = value instanceof type;\n }\n } else if (expectedType === 'Object') {\n valid = isPlainObject(value);\n } else if (expectedType === 'Array') {\n valid = Array.isArray(value);\n } else {\n valid = value instanceof type;\n }\n return {\n valid: valid,\n expectedType: expectedType\n }\n}\n\n/**\n * Use function string name to check built-in types,\n * because a simple equality check will fail when running\n * across different vms / iframes.\n */\nfunction getType (fn) {\n var match = fn && fn.toString().match(/^\\s*function (\\w+)/);\n return match ? match[1] : ''\n}\n\nfunction isSameType (a, b) {\n return getType(a) === getType(b)\n}\n\nfunction getTypeIndex (type, expectedTypes) {\n if (!Array.isArray(expectedTypes)) {\n return isSameType(expectedTypes, type) ? 0 : -1\n }\n for (var i = 0, len = expectedTypes.length; i < len; i++) {\n if (isSameType(expectedTypes[i], type)) {\n return i\n }\n }\n return -1\n}\n\nfunction getInvalidTypeMessage (name, value, expectedTypes) {\n var message = \"Invalid prop: type check failed for prop \\\"\" + name + \"\\\".\" +\n \" Expected \" + (expectedTypes.map(capitalize).join(', '));\n var expectedType = expectedTypes[0];\n var receivedType = toRawType(value);\n var expectedValue = styleValue(value, expectedType);\n var receivedValue = styleValue(value, receivedType);\n // check if we need to specify expected value\n if (expectedTypes.length === 1 &&\n isExplicable(expectedType) &&\n !isBoolean(expectedType, receivedType)) {\n message += \" with value \" + expectedValue;\n }\n message += \", got \" + receivedType + \" \";\n // check if we need to specify received value\n if (isExplicable(receivedType)) {\n message += \"with value \" + receivedValue + \".\";\n }\n return message\n}\n\nfunction styleValue (value, type) {\n if (type === 'String') {\n return (\"\\\"\" + value + \"\\\"\")\n } else if (type === 'Number') {\n return (\"\" + (Number(value)))\n } else {\n return (\"\" + value)\n }\n}\n\nfunction isExplicable (value) {\n var explicitTypes = ['string', 'number', 'boolean'];\n return explicitTypes.some(function (elem) { return value.toLowerCase() === elem; })\n}\n\nfunction isBoolean () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return args.some(function (elem) { return elem.toLowerCase() === 'boolean'; })\n}\n\n/* */\n\nfunction handleError (err, vm, info) {\n // Deactivate deps tracking while processing error handler to avoid possible infinite rendering.\n // See: https://github.com/vuejs/vuex/issues/1505\n pushTarget();\n try {\n if (vm) {\n var cur = vm;\n while ((cur = cur.$parent)) {\n var hooks = cur.$options.errorCaptured;\n if (hooks) {\n for (var i = 0; i < hooks.length; i++) {\n try {\n var capture = hooks[i].call(cur, err, vm, info) === false;\n if (capture) { return }\n } catch (e) {\n globalHandleError(e, cur, 'errorCaptured hook');\n }\n }\n }\n }\n }\n globalHandleError(err, vm, info);\n } finally {\n popTarget();\n }\n}\n\nfunction invokeWithErrorHandling (\n handler,\n context,\n args,\n vm,\n info\n) {\n var res;\n try {\n res = args ? handler.apply(context, args) : handler.call(context);\n if (res && !res._isVue && isPromise(res) && !res._handled) {\n res.catch(function (e) { return handleError(e, vm, info + \" (Promise/async)\"); });\n // issue #9511\n // avoid catch triggering multiple times when nested calls\n res._handled = true;\n }\n } catch (e) {\n handleError(e, vm, info);\n }\n return res\n}\n\nfunction globalHandleError (err, vm, info) {\n if (config.errorHandler) {\n try {\n return config.errorHandler.call(null, err, vm, info)\n } catch (e) {\n // if the user intentionally throws the original error in the handler,\n // do not log it twice\n if (e !== err) {\n logError(e, null, 'config.errorHandler');\n }\n }\n }\n logError(err, vm, info);\n}\n\nfunction logError (err, vm, info) {\n if (true) {\n warn((\"Error in \" + info + \": \\\"\" + (err.toString()) + \"\\\"\"), vm);\n }\n /* istanbul ignore else */\n if ((inBrowser || inWeex) && typeof console !== 'undefined') {\n console.error(err);\n } else {\n throw err\n }\n}\n\n/* */\n\nvar isUsingMicroTask = false;\n\nvar callbacks = [];\nvar pending = false;\n\nfunction flushCallbacks () {\n pending = false;\n var copies = callbacks.slice(0);\n callbacks.length = 0;\n for (var i = 0; i < copies.length; i++) {\n copies[i]();\n }\n}\n\n// Here we have async deferring wrappers using microtasks.\n// In 2.5 we used (macro) tasks (in combination with microtasks).\n// However, it has subtle problems when state is changed right before repaint\n// (e.g. #6813, out-in transitions).\n// Also, using (macro) tasks in event handler would cause some weird behaviors\n// that cannot be circumvented (e.g. #7109, #7153, #7546, #7834, #8109).\n// So we now use microtasks everywhere, again.\n// A major drawback of this tradeoff is that there are some scenarios\n// where microtasks have too high a priority and fire in between supposedly\n// sequential events (e.g. #4521, #6690, which have workarounds)\n// or even between bubbling of the same event (#6566).\nvar timerFunc;\n\n// The nextTick behavior leverages the microtask queue, which can be accessed\n// via either native Promise.then or MutationObserver.\n// MutationObserver has wider support, however it is seriously bugged in\n// UIWebView in iOS >= 9.3.3 when triggered in touch event handlers. It\n// completely stops working after triggering a few times... so, if native\n// Promise is available, we will use it:\n/* istanbul ignore next, $flow-disable-line */\nif (typeof Promise !== 'undefined' && isNative(Promise)) {\n var p = Promise.resolve();\n timerFunc = function () {\n p.then(flushCallbacks);\n // In problematic UIWebViews, Promise.then doesn't completely break, but\n // it can get stuck in a weird state where callbacks are pushed into the\n // microtask queue but the queue isn't being flushed, until the browser\n // needs to do some other work, e.g. handle a timer. Therefore we can\n // \"force\" the microtask queue to be flushed by adding an empty timer.\n if (isIOS) { setTimeout(noop); }\n };\n isUsingMicroTask = true;\n} else if (!isIE && typeof MutationObserver !== 'undefined' && (\n isNative(MutationObserver) ||\n // PhantomJS and iOS 7.x\n MutationObserver.toString() === '[object MutationObserverConstructor]'\n)) {\n // Use MutationObserver where native Promise is not available,\n // e.g. PhantomJS, iOS7, Android 4.4\n // (#6466 MutationObserver is unreliable in IE11)\n var counter = 1;\n var observer = new MutationObserver(flushCallbacks);\n var textNode = document.createTextNode(String(counter));\n observer.observe(textNode, {\n characterData: true\n });\n timerFunc = function () {\n counter = (counter + 1) % 2;\n textNode.data = String(counter);\n };\n isUsingMicroTask = true;\n} else if (typeof setImmediate !== 'undefined' && isNative(setImmediate)) {\n // Fallback to setImmediate.\n // Technically it leverages the (macro) task queue,\n // but it is still a better choice than setTimeout.\n timerFunc = function () {\n setImmediate(flushCallbacks);\n };\n} else {\n // Fallback to setTimeout.\n timerFunc = function () {\n setTimeout(flushCallbacks, 0);\n };\n}\n\nfunction nextTick (cb, ctx) {\n var _resolve;\n callbacks.push(function () {\n if (cb) {\n try {\n cb.call(ctx);\n } catch (e) {\n handleError(e, ctx, 'nextTick');\n }\n } else if (_resolve) {\n _resolve(ctx);\n }\n });\n if (!pending) {\n pending = true;\n timerFunc();\n }\n // $flow-disable-line\n if (!cb && typeof Promise !== 'undefined') {\n return new Promise(function (resolve) {\n _resolve = resolve;\n })\n }\n}\n\n/* */\n\nvar mark;\nvar measure;\n\nif (true) {\n var perf = inBrowser && window.performance;\n /* istanbul ignore if */\n if (\n perf &&\n perf.mark &&\n perf.measure &&\n perf.clearMarks &&\n perf.clearMeasures\n ) {\n mark = function (tag) { return perf.mark(tag); };\n measure = function (name, startTag, endTag) {\n perf.measure(name, startTag, endTag);\n perf.clearMarks(startTag);\n perf.clearMarks(endTag);\n // perf.clearMeasures(name)\n };\n }\n}\n\n/* not type checking this file because flow doesn't play well with Proxy */\n\nvar initProxy;\n\nif (true) {\n var allowedGlobals = makeMap(\n 'Infinity,undefined,NaN,isFinite,isNaN,' +\n 'parseFloat,parseInt,decodeURI,decodeURIComponent,encodeURI,encodeURIComponent,' +\n 'Math,Number,Date,Array,Object,Boolean,String,RegExp,Map,Set,JSON,Intl,' +\n 'require' // for Webpack/Browserify\n );\n\n var warnNonPresent = function (target, key) {\n warn(\n \"Property or method \\\"\" + key + \"\\\" is not defined on the instance but \" +\n 'referenced during render. Make sure that this property is reactive, ' +\n 'either in the data option, or for class-based components, by ' +\n 'initializing the property. ' +\n 'See: https://vuejs.org/v2/guide/reactivity.html#Declaring-Reactive-Properties.',\n target\n );\n };\n\n var warnReservedPrefix = function (target, key) {\n warn(\n \"Property \\\"\" + key + \"\\\" must be accessed with \\\"$data.\" + key + \"\\\" because \" +\n 'properties starting with \"$\" or \"_\" are not proxied in the Vue instance to ' +\n 'prevent conflicts with Vue internals. ' +\n 'See: https://vuejs.org/v2/api/#data',\n target\n );\n };\n\n var hasProxy =\n typeof Proxy !== 'undefined' && isNative(Proxy);\n\n if (hasProxy) {\n var isBuiltInModifier = makeMap('stop,prevent,self,ctrl,shift,alt,meta,exact');\n config.keyCodes = new Proxy(config.keyCodes, {\n set: function set (target, key, value) {\n if (isBuiltInModifier(key)) {\n warn((\"Avoid overwriting built-in modifier in config.keyCodes: .\" + key));\n return false\n } else {\n target[key] = value;\n return true\n }\n }\n });\n }\n\n var hasHandler = {\n has: function has (target, key) {\n var has = key in target;\n var isAllowed = allowedGlobals(key) ||\n (typeof key === 'string' && key.charAt(0) === '_' && !(key in target.$data));\n if (!has && !isAllowed) {\n if (key in target.$data) { warnReservedPrefix(target, key); }\n else { warnNonPresent(target, key); }\n }\n return has || !isAllowed\n }\n };\n\n var getHandler = {\n get: function get (target, key) {\n if (typeof key === 'string' && !(key in target)) {\n if (key in target.$data) { warnReservedPrefix(target, key); }\n else { warnNonPresent(target, key); }\n }\n return target[key]\n }\n };\n\n initProxy = function initProxy (vm) {\n if (hasProxy) {\n // determine which proxy handler to use\n var options = vm.$options;\n var handlers = options.render && options.render._withStripped\n ? getHandler\n : hasHandler;\n vm._renderProxy = new Proxy(vm, handlers);\n } else {\n vm._renderProxy = vm;\n }\n };\n}\n\n/* */\n\nvar seenObjects = new _Set();\n\n/**\n * Recursively traverse an object to evoke all converted\n * getters, so that every nested property inside the object\n * is collected as a \"deep\" dependency.\n */\nfunction traverse (val) {\n _traverse(val, seenObjects);\n seenObjects.clear();\n}\n\nfunction _traverse (val, seen) {\n var i, keys;\n var isA = Array.isArray(val);\n if ((!isA && !isObject(val)) || Object.isFrozen(val) || val instanceof VNode) {\n return\n }\n if (val.__ob__) {\n var depId = val.__ob__.dep.id;\n if (seen.has(depId)) {\n return\n }\n seen.add(depId);\n }\n if (isA) {\n i = val.length;\n while (i--) { _traverse(val[i], seen); }\n } else {\n keys = Object.keys(val);\n i = keys.length;\n while (i--) { _traverse(val[keys[i]], seen); }\n }\n}\n\n/* */\n\nvar normalizeEvent = cached(function (name) {\n var passive = name.charAt(0) === '&';\n name = passive ? name.slice(1) : name;\n var once$$1 = name.charAt(0) === '~'; // Prefixed last, checked first\n name = once$$1 ? name.slice(1) : name;\n var capture = name.charAt(0) === '!';\n name = capture ? name.slice(1) : name;\n return {\n name: name,\n once: once$$1,\n capture: capture,\n passive: passive\n }\n});\n\nfunction createFnInvoker (fns, vm) {\n function invoker () {\n var arguments$1 = arguments;\n\n var fns = invoker.fns;\n if (Array.isArray(fns)) {\n var cloned = fns.slice();\n for (var i = 0; i < cloned.length; i++) {\n invokeWithErrorHandling(cloned[i], null, arguments$1, vm, \"v-on handler\");\n }\n } else {\n // return handler return value for single handlers\n return invokeWithErrorHandling(fns, null, arguments, vm, \"v-on handler\")\n }\n }\n invoker.fns = fns;\n return invoker\n}\n\nfunction updateListeners (\n on,\n oldOn,\n add,\n remove$$1,\n createOnceHandler,\n vm\n) {\n var name, def$$1, cur, old, event;\n for (name in on) {\n def$$1 = cur = on[name];\n old = oldOn[name];\n event = normalizeEvent(name);\n if (isUndef(cur)) {\n true && warn(\n \"Invalid handler for event \\\"\" + (event.name) + \"\\\": got \" + String(cur),\n vm\n );\n } else if (isUndef(old)) {\n if (isUndef(cur.fns)) {\n cur = on[name] = createFnInvoker(cur, vm);\n }\n if (isTrue(event.once)) {\n cur = on[name] = createOnceHandler(event.name, cur, event.capture);\n }\n add(event.name, cur, event.capture, event.passive, event.params);\n } else if (cur !== old) {\n old.fns = cur;\n on[name] = old;\n }\n }\n for (name in oldOn) {\n if (isUndef(on[name])) {\n event = normalizeEvent(name);\n remove$$1(event.name, oldOn[name], event.capture);\n }\n }\n}\n\n/* */\n\nfunction mergeVNodeHook (def, hookKey, hook) {\n if (def instanceof VNode) {\n def = def.data.hook || (def.data.hook = {});\n }\n var invoker;\n var oldHook = def[hookKey];\n\n function wrappedHook () {\n hook.apply(this, arguments);\n // important: remove merged hook to ensure it's called only once\n // and prevent memory leak\n remove(invoker.fns, wrappedHook);\n }\n\n if (isUndef(oldHook)) {\n // no existing hook\n invoker = createFnInvoker([wrappedHook]);\n } else {\n /* istanbul ignore if */\n if (isDef(oldHook.fns) && isTrue(oldHook.merged)) {\n // already a merged invoker\n invoker = oldHook;\n invoker.fns.push(wrappedHook);\n } else {\n // existing plain hook\n invoker = createFnInvoker([oldHook, wrappedHook]);\n }\n }\n\n invoker.merged = true;\n def[hookKey] = invoker;\n}\n\n/* */\n\nfunction extractPropsFromVNodeData (\n data,\n Ctor,\n tag\n) {\n // we are only extracting raw values here.\n // validation and default values are handled in the child\n // component itself.\n var propOptions = Ctor.options.props;\n if (isUndef(propOptions)) {\n return\n }\n var res = {};\n var attrs = data.attrs;\n var props = data.props;\n if (isDef(attrs) || isDef(props)) {\n for (var key in propOptions) {\n var altKey = hyphenate(key);\n if (true) {\n var keyInLowerCase = key.toLowerCase();\n if (\n key !== keyInLowerCase &&\n attrs && hasOwn(attrs, keyInLowerCase)\n ) {\n tip(\n \"Prop \\\"\" + keyInLowerCase + \"\\\" is passed to component \" +\n (formatComponentName(tag || Ctor)) + \", but the declared prop name is\" +\n \" \\\"\" + key + \"\\\". \" +\n \"Note that HTML attributes are case-insensitive and camelCased \" +\n \"props need to use their kebab-case equivalents when using in-DOM \" +\n \"templates. You should probably use \\\"\" + altKey + \"\\\" instead of \\\"\" + key + \"\\\".\"\n );\n }\n }\n checkProp(res, props, key, altKey, true) ||\n checkProp(res, attrs, key, altKey, false);\n }\n }\n return res\n}\n\nfunction checkProp (\n res,\n hash,\n key,\n altKey,\n preserve\n) {\n if (isDef(hash)) {\n if (hasOwn(hash, key)) {\n res[key] = hash[key];\n if (!preserve) {\n delete hash[key];\n }\n return true\n } else if (hasOwn(hash, altKey)) {\n res[key] = hash[altKey];\n if (!preserve) {\n delete hash[altKey];\n }\n return true\n }\n }\n return false\n}\n\n/* */\n\n// The template compiler attempts to minimize the need for normalization by\n// statically analyzing the template at compile time.\n//\n// For plain HTML markup, normalization can be completely skipped because the\n// generated render function is guaranteed to return Array<VNode>. There are\n// two cases where extra normalization is needed:\n\n// 1. When the children contains components - because a functional component\n// may return an Array instead of a single root. In this case, just a simple\n// normalization is needed - if any child is an Array, we flatten the whole\n// thing with Array.prototype.concat. It is guaranteed to be only 1-level deep\n// because functional components already normalize their own children.\nfunction simpleNormalizeChildren (children) {\n for (var i = 0; i < children.length; i++) {\n if (Array.isArray(children[i])) {\n return Array.prototype.concat.apply([], children)\n }\n }\n return children\n}\n\n// 2. When the children contains constructs that always generated nested Arrays,\n// e.g. <template>, <slot>, v-for, or when the children is provided by user\n// with hand-written render functions / JSX. In such cases a full normalization\n// is needed to cater to all possible types of children values.\nfunction normalizeChildren (children) {\n return isPrimitive(children)\n ? [createTextVNode(children)]\n : Array.isArray(children)\n ? normalizeArrayChildren(children)\n : undefined\n}\n\nfunction isTextNode (node) {\n return isDef(node) && isDef(node.text) && isFalse(node.isComment)\n}\n\nfunction normalizeArrayChildren (children, nestedIndex) {\n var res = [];\n var i, c, lastIndex, last;\n for (i = 0; i < children.length; i++) {\n c = children[i];\n if (isUndef(c) || typeof c === 'boolean') { continue }\n lastIndex = res.length - 1;\n last = res[lastIndex];\n // nested\n if (Array.isArray(c)) {\n if (c.length > 0) {\n c = normalizeArrayChildren(c, ((nestedIndex || '') + \"_\" + i));\n // merge adjacent text nodes\n if (isTextNode(c[0]) && isTextNode(last)) {\n res[lastIndex] = createTextVNode(last.text + (c[0]).text);\n c.shift();\n }\n res.push.apply(res, c);\n }\n } else if (isPrimitive(c)) {\n if (isTextNode(last)) {\n // merge adjacent text nodes\n // this is necessary for SSR hydration because text nodes are\n // essentially merged when rendered to HTML strings\n res[lastIndex] = createTextVNode(last.text + c);\n } else if (c !== '') {\n // convert primitive to vnode\n res.push(createTextVNode(c));\n }\n } else {\n if (isTextNode(c) && isTextNode(last)) {\n // merge adjacent text nodes\n res[lastIndex] = createTextVNode(last.text + c.text);\n } else {\n // default key for nested array children (likely generated by v-for)\n if (isTrue(children._isVList) &&\n isDef(c.tag) &&\n isUndef(c.key) &&\n isDef(nestedIndex)) {\n c.key = \"__vlist\" + nestedIndex + \"_\" + i + \"__\";\n }\n res.push(c);\n }\n }\n }\n return res\n}\n\n/* */\n\nfunction initProvide (vm) {\n var provide = vm.$options.provide;\n if (provide) {\n vm._provided = typeof provide === 'function'\n ? provide.call(vm)\n : provide;\n }\n}\n\nfunction initInjections (vm) {\n var result = resolveInject(vm.$options.inject, vm);\n if (result) {\n toggleObserving(false);\n Object.keys(result).forEach(function (key) {\n /* istanbul ignore else */\n if (true) {\n defineReactive$$1(vm, key, result[key], function () {\n warn(\n \"Avoid mutating an injected value directly since the changes will be \" +\n \"overwritten whenever the provided component re-renders. \" +\n \"injection being mutated: \\\"\" + key + \"\\\"\",\n vm\n );\n });\n } else {}\n });\n toggleObserving(true);\n }\n}\n\nfunction resolveInject (inject, vm) {\n if (inject) {\n // inject is :any because flow is not smart enough to figure out cached\n var result = Object.create(null);\n var keys = hasSymbol\n ? Reflect.ownKeys(inject)\n : Object.keys(inject);\n\n for (var i = 0; i < keys.length; i++) {\n var key = keys[i];\n // #6574 in case the inject object is observed...\n if (key === '__ob__') { continue }\n var provideKey = inject[key].from;\n var source = vm;\n while (source) {\n if (source._provided && hasOwn(source._provided, provideKey)) {\n result[key] = source._provided[provideKey];\n break\n }\n source = source.$parent;\n }\n if (!source) {\n if ('default' in inject[key]) {\n var provideDefault = inject[key].default;\n result[key] = typeof provideDefault === 'function'\n ? provideDefault.call(vm)\n : provideDefault;\n } else if (true) {\n warn((\"Injection \\\"\" + key + \"\\\" not found\"), vm);\n }\n }\n }\n return result\n }\n}\n\n/* */\n\n\n\n/**\n * Runtime helper for resolving raw children VNodes into a slot object.\n */\nfunction resolveSlots (\n children,\n context\n) {\n if (!children || !children.length) {\n return {}\n }\n var slots = {};\n for (var i = 0, l = children.length; i < l; i++) {\n var child = children[i];\n var data = child.data;\n // remove slot attribute if the node is resolved as a Vue slot node\n if (data && data.attrs && data.attrs.slot) {\n delete data.attrs.slot;\n }\n // named slots should only be respected if the vnode was rendered in the\n // same context.\n if ((child.context === context || child.fnContext === context) &&\n data && data.slot != null\n ) {\n var name = data.slot;\n var slot = (slots[name] || (slots[name] = []));\n if (child.tag === 'template') {\n slot.push.apply(slot, child.children || []);\n } else {\n slot.push(child);\n }\n } else {\n (slots.default || (slots.default = [])).push(child);\n }\n }\n // ignore slots that contains only whitespace\n for (var name$1 in slots) {\n if (slots[name$1].every(isWhitespace)) {\n delete slots[name$1];\n }\n }\n return slots\n}\n\nfunction isWhitespace (node) {\n return (node.isComment && !node.asyncFactory) || node.text === ' '\n}\n\n/* */\n\nfunction normalizeScopedSlots (\n slots,\n normalSlots,\n prevSlots\n) {\n var res;\n var hasNormalSlots = Object.keys(normalSlots).length > 0;\n var isStable = slots ? !!slots.$stable : !hasNormalSlots;\n var key = slots && slots.$key;\n if (!slots) {\n res = {};\n } else if (slots._normalized) {\n // fast path 1: child component re-render only, parent did not change\n return slots._normalized\n } else if (\n isStable &&\n prevSlots &&\n prevSlots !== emptyObject &&\n key === prevSlots.$key &&\n !hasNormalSlots &&\n !prevSlots.$hasNormal\n ) {\n // fast path 2: stable scoped slots w/ no normal slots to proxy,\n // only need to normalize once\n return prevSlots\n } else {\n res = {};\n for (var key$1 in slots) {\n if (slots[key$1] && key$1[0] !== '$') {\n res[key$1] = normalizeScopedSlot(normalSlots, key$1, slots[key$1]);\n }\n }\n }\n // expose normal slots on scopedSlots\n for (var key$2 in normalSlots) {\n if (!(key$2 in res)) {\n res[key$2] = proxyNormalSlot(normalSlots, key$2);\n }\n }\n // avoriaz seems to mock a non-extensible $scopedSlots object\n // and when that is passed down this would cause an error\n if (slots && Object.isExtensible(slots)) {\n (slots)._normalized = res;\n }\n def(res, '$stable', isStable);\n def(res, '$key', key);\n def(res, '$hasNormal', hasNormalSlots);\n return res\n}\n\nfunction normalizeScopedSlot(normalSlots, key, fn) {\n var normalized = function () {\n var res = arguments.length ? fn.apply(null, arguments) : fn({});\n res = res && typeof res === 'object' && !Array.isArray(res)\n ? [res] // single vnode\n : normalizeChildren(res);\n return res && (\n res.length === 0 ||\n (res.length === 1 && res[0].isComment) // #9658\n ) ? undefined\n : res\n };\n // this is a slot using the new v-slot syntax without scope. although it is\n // compiled as a scoped slot, render fn users would expect it to be present\n // on this.$slots because the usage is semantically a normal slot.\n if (fn.proxy) {\n Object.defineProperty(normalSlots, key, {\n get: normalized,\n enumerable: true,\n configurable: true\n });\n }\n return normalized\n}\n\nfunction proxyNormalSlot(slots, key) {\n return function () { return slots[key]; }\n}\n\n/* */\n\n/**\n * Runtime helper for rendering v-for lists.\n */\nfunction renderList (\n val,\n render\n) {\n var ret, i, l, keys, key;\n if (Array.isArray(val) || typeof val === 'string') {\n ret = new Array(val.length);\n for (i = 0, l = val.length; i < l; i++) {\n ret[i] = render(val[i], i);\n }\n } else if (typeof val === 'number') {\n ret = new Array(val);\n for (i = 0; i < val; i++) {\n ret[i] = render(i + 1, i);\n }\n } else if (isObject(val)) {\n if (hasSymbol && val[Symbol.iterator]) {\n ret = [];\n var iterator = val[Symbol.iterator]();\n var result = iterator.next();\n while (!result.done) {\n ret.push(render(result.value, ret.length));\n result = iterator.next();\n }\n } else {\n keys = Object.keys(val);\n ret = new Array(keys.length);\n for (i = 0, l = keys.length; i < l; i++) {\n key = keys[i];\n ret[i] = render(val[key], key, i);\n }\n }\n }\n if (!isDef(ret)) {\n ret = [];\n }\n (ret)._isVList = true;\n return ret\n}\n\n/* */\n\n/**\n * Runtime helper for rendering <slot>\n */\nfunction renderSlot (\n name,\n fallback,\n props,\n bindObject\n) {\n var scopedSlotFn = this.$scopedSlots[name];\n var nodes;\n if (scopedSlotFn) { // scoped slot\n props = props || {};\n if (bindObject) {\n if ( true && !isObject(bindObject)) {\n warn(\n 'slot v-bind without argument expects an Object',\n this\n );\n }\n props = extend(extend({}, bindObject), props);\n }\n nodes = scopedSlotFn(props) || fallback;\n } else {\n nodes = this.$slots[name] || fallback;\n }\n\n var target = props && props.slot;\n if (target) {\n return this.$createElement('template', { slot: target }, nodes)\n } else {\n return nodes\n }\n}\n\n/* */\n\n/**\n * Runtime helper for resolving filters\n */\nfunction resolveFilter (id) {\n return resolveAsset(this.$options, 'filters', id, true) || identity\n}\n\n/* */\n\nfunction isKeyNotMatch (expect, actual) {\n if (Array.isArray(expect)) {\n return expect.indexOf(actual) === -1\n } else {\n return expect !== actual\n }\n}\n\n/**\n * Runtime helper for checking keyCodes from config.\n * exposed as Vue.prototype._k\n * passing in eventKeyName as last argument separately for backwards compat\n */\nfunction checkKeyCodes (\n eventKeyCode,\n key,\n builtInKeyCode,\n eventKeyName,\n builtInKeyName\n) {\n var mappedKeyCode = config.keyCodes[key] || builtInKeyCode;\n if (builtInKeyName && eventKeyName && !config.keyCodes[key]) {\n return isKeyNotMatch(builtInKeyName, eventKeyName)\n } else if (mappedKeyCode) {\n return isKeyNotMatch(mappedKeyCode, eventKeyCode)\n } else if (eventKeyName) {\n return hyphenate(eventKeyName) !== key\n }\n}\n\n/* */\n\n/**\n * Runtime helper for merging v-bind=\"object\" into a VNode's data.\n */\nfunction bindObjectProps (\n data,\n tag,\n value,\n asProp,\n isSync\n) {\n if (value) {\n if (!isObject(value)) {\n true && warn(\n 'v-bind without argument expects an Object or Array value',\n this\n );\n } else {\n if (Array.isArray(value)) {\n value = toObject(value);\n }\n var hash;\n var loop = function ( key ) {\n if (\n key === 'class' ||\n key === 'style' ||\n isReservedAttribute(key)\n ) {\n hash = data;\n } else {\n var type = data.attrs && data.attrs.type;\n hash = asProp || config.mustUseProp(tag, type, key)\n ? data.domProps || (data.domProps = {})\n : data.attrs || (data.attrs = {});\n }\n var camelizedKey = camelize(key);\n var hyphenatedKey = hyphenate(key);\n if (!(camelizedKey in hash) && !(hyphenatedKey in hash)) {\n hash[key] = value[key];\n\n if (isSync) {\n var on = data.on || (data.on = {});\n on[(\"update:\" + key)] = function ($event) {\n value[key] = $event;\n };\n }\n }\n };\n\n for (var key in value) loop( key );\n }\n }\n return data\n}\n\n/* */\n\n/**\n * Runtime helper for rendering static trees.\n */\nfunction renderStatic (\n index,\n isInFor\n) {\n var cached = this._staticTrees || (this._staticTrees = []);\n var tree = cached[index];\n // if has already-rendered static tree and not inside v-for,\n // we can reuse the same tree.\n if (tree && !isInFor) {\n return tree\n }\n // otherwise, render a fresh tree.\n tree = cached[index] = this.$options.staticRenderFns[index].call(\n this._renderProxy,\n null,\n this // for render fns generated for functional component templates\n );\n markStatic(tree, (\"__static__\" + index), false);\n return tree\n}\n\n/**\n * Runtime helper for v-once.\n * Effectively it means marking the node as static with a unique key.\n */\nfunction markOnce (\n tree,\n index,\n key\n) {\n markStatic(tree, (\"__once__\" + index + (key ? (\"_\" + key) : \"\")), true);\n return tree\n}\n\nfunction markStatic (\n tree,\n key,\n isOnce\n) {\n if (Array.isArray(tree)) {\n for (var i = 0; i < tree.length; i++) {\n if (tree[i] && typeof tree[i] !== 'string') {\n markStaticNode(tree[i], (key + \"_\" + i), isOnce);\n }\n }\n } else {\n markStaticNode(tree, key, isOnce);\n }\n}\n\nfunction markStaticNode (node, key, isOnce) {\n node.isStatic = true;\n node.key = key;\n node.isOnce = isOnce;\n}\n\n/* */\n\nfunction bindObjectListeners (data, value) {\n if (value) {\n if (!isPlainObject(value)) {\n true && warn(\n 'v-on without argument expects an Object value',\n this\n );\n } else {\n var on = data.on = data.on ? extend({}, data.on) : {};\n for (var key in value) {\n var existing = on[key];\n var ours = value[key];\n on[key] = existing ? [].concat(existing, ours) : ours;\n }\n }\n }\n return data\n}\n\n/* */\n\nfunction resolveScopedSlots (\n fns, // see flow/vnode\n res,\n // the following are added in 2.6\n hasDynamicKeys,\n contentHashKey\n) {\n res = res || { $stable: !hasDynamicKeys };\n for (var i = 0; i < fns.length; i++) {\n var slot = fns[i];\n if (Array.isArray(slot)) {\n resolveScopedSlots(slot, res, hasDynamicKeys);\n } else if (slot) {\n // marker for reverse proxying v-slot without scope on this.$slots\n if (slot.proxy) {\n slot.fn.proxy = true;\n }\n res[slot.key] = slot.fn;\n }\n }\n if (contentHashKey) {\n (res).$key = contentHashKey;\n }\n return res\n}\n\n/* */\n\nfunction bindDynamicKeys (baseObj, values) {\n for (var i = 0; i < values.length; i += 2) {\n var key = values[i];\n if (typeof key === 'string' && key) {\n baseObj[values[i]] = values[i + 1];\n } else if ( true && key !== '' && key !== null) {\n // null is a special value for explicitly removing a binding\n warn(\n (\"Invalid value for dynamic directive argument (expected string or null): \" + key),\n this\n );\n }\n }\n return baseObj\n}\n\n// helper to dynamically append modifier runtime markers to event names.\n// ensure only append when value is already string, otherwise it will be cast\n// to string and cause the type check to miss.\nfunction prependModifier (value, symbol) {\n return typeof value === 'string' ? symbol + value : value\n}\n\n/* */\n\nfunction installRenderHelpers (target) {\n target._o = markOnce;\n target._n = toNumber;\n target._s = toString;\n target._l = renderList;\n target._t = renderSlot;\n target._q = looseEqual;\n target._i = looseIndexOf;\n target._m = renderStatic;\n target._f = resolveFilter;\n target._k = checkKeyCodes;\n target._b = bindObjectProps;\n target._v = createTextVNode;\n target._e = createEmptyVNode;\n target._u = resolveScopedSlots;\n target._g = bindObjectListeners;\n target._d = bindDynamicKeys;\n target._p = prependModifier;\n}\n\n/* */\n\nfunction FunctionalRenderContext (\n data,\n props,\n children,\n parent,\n Ctor\n) {\n var this$1 = this;\n\n var options = Ctor.options;\n // ensure the createElement function in functional components\n // gets a unique context - this is necessary for correct named slot check\n var contextVm;\n if (hasOwn(parent, '_uid')) {\n contextVm = Object.create(parent);\n // $flow-disable-line\n contextVm._original = parent;\n } else {\n // the context vm passed in is a functional context as well.\n // in this case we want to make sure we are able to get a hold to the\n // real context instance.\n contextVm = parent;\n // $flow-disable-line\n parent = parent._original;\n }\n var isCompiled = isTrue(options._compiled);\n var needNormalization = !isCompiled;\n\n this.data = data;\n this.props = props;\n this.children = children;\n this.parent = parent;\n this.listeners = data.on || emptyObject;\n this.injections = resolveInject(options.inject, parent);\n this.slots = function () {\n if (!this$1.$slots) {\n normalizeScopedSlots(\n data.scopedSlots,\n this$1.$slots = resolveSlots(children, parent)\n );\n }\n return this$1.$slots\n };\n\n Object.defineProperty(this, 'scopedSlots', ({\n enumerable: true,\n get: function get () {\n return normalizeScopedSlots(data.scopedSlots, this.slots())\n }\n }));\n\n // support for compiled functional template\n if (isCompiled) {\n // exposing $options for renderStatic()\n this.$options = options;\n // pre-resolve slots for renderSlot()\n this.$slots = this.slots();\n this.$scopedSlots = normalizeScopedSlots(data.scopedSlots, this.$slots);\n }\n\n if (options._scopeId) {\n this._c = function (a, b, c, d) {\n var vnode = createElement(contextVm, a, b, c, d, needNormalization);\n if (vnode && !Array.isArray(vnode)) {\n vnode.fnScopeId = options._scopeId;\n vnode.fnContext = parent;\n }\n return vnode\n };\n } else {\n this._c = function (a, b, c, d) { return createElement(contextVm, a, b, c, d, needNormalization); };\n }\n}\n\ninstallRenderHelpers(FunctionalRenderContext.prototype);\n\nfunction createFunctionalComponent (\n Ctor,\n propsData,\n data,\n contextVm,\n children\n) {\n var options = Ctor.options;\n var props = {};\n var propOptions = options.props;\n if (isDef(propOptions)) {\n for (var key in propOptions) {\n props[key] = validateProp(key, propOptions, propsData || emptyObject);\n }\n } else {\n if (isDef(data.attrs)) { mergeProps(props, data.attrs); }\n if (isDef(data.props)) { mergeProps(props, data.props); }\n }\n\n var renderContext = new FunctionalRenderContext(\n data,\n props,\n children,\n contextVm,\n Ctor\n );\n\n var vnode = options.render.call(null, renderContext._c, renderContext);\n\n if (vnode instanceof VNode) {\n return cloneAndMarkFunctionalResult(vnode, data, renderContext.parent, options, renderContext)\n } else if (Array.isArray(vnode)) {\n var vnodes = normalizeChildren(vnode) || [];\n var res = new Array(vnodes.length);\n for (var i = 0; i < vnodes.length; i++) {\n res[i] = cloneAndMarkFunctionalResult(vnodes[i], data, renderContext.parent, options, renderContext);\n }\n return res\n }\n}\n\nfunction cloneAndMarkFunctionalResult (vnode, data, contextVm, options, renderContext) {\n // #7817 clone node before setting fnContext, otherwise if the node is reused\n // (e.g. it was from a cached normal slot) the fnContext causes named slots\n // that should not be matched to match.\n var clone = cloneVNode(vnode);\n clone.fnContext = contextVm;\n clone.fnOptions = options;\n if (true) {\n (clone.devtoolsMeta = clone.devtoolsMeta || {}).renderContext = renderContext;\n }\n if (data.slot) {\n (clone.data || (clone.data = {})).slot = data.slot;\n }\n return clone\n}\n\nfunction mergeProps (to, from) {\n for (var key in from) {\n to[camelize(key)] = from[key];\n }\n}\n\n/* */\n\n/* */\n\n/* */\n\n/* */\n\n// inline hooks to be invoked on component VNodes during patch\nvar componentVNodeHooks = {\n init: function init (vnode, hydrating) {\n if (\n vnode.componentInstance &&\n !vnode.componentInstance._isDestroyed &&\n vnode.data.keepAlive\n ) {\n // kept-alive components, treat as a patch\n var mountedNode = vnode; // work around flow\n componentVNodeHooks.prepatch(mountedNode, mountedNode);\n } else {\n var child = vnode.componentInstance = createComponentInstanceForVnode(\n vnode,\n activeInstance\n );\n child.$mount(hydrating ? vnode.elm : undefined, hydrating);\n }\n },\n\n prepatch: function prepatch (oldVnode, vnode) {\n var options = vnode.componentOptions;\n var child = vnode.componentInstance = oldVnode.componentInstance;\n updateChildComponent(\n child,\n options.propsData, // updated props\n options.listeners, // updated listeners\n vnode, // new parent vnode\n options.children // new children\n );\n },\n\n insert: function insert (vnode) {\n var context = vnode.context;\n var componentInstance = vnode.componentInstance;\n if (!componentInstance._isMounted) {\n componentInstance._isMounted = true;\n callHook(componentInstance, 'mounted');\n }\n if (vnode.data.keepAlive) {\n if (context._isMounted) {\n // vue-router#1212\n // During updates, a kept-alive component's child components may\n // change, so directly walking the tree here may call activated hooks\n // on incorrect children. Instead we push them into a queue which will\n // be processed after the whole patch process ended.\n queueActivatedComponent(componentInstance);\n } else {\n activateChildComponent(componentInstance, true /* direct */);\n }\n }\n },\n\n destroy: function destroy (vnode) {\n var componentInstance = vnode.componentInstance;\n if (!componentInstance._isDestroyed) {\n if (!vnode.data.keepAlive) {\n componentInstance.$destroy();\n } else {\n deactivateChildComponent(componentInstance, true /* direct */);\n }\n }\n }\n};\n\nvar hooksToMerge = Object.keys(componentVNodeHooks);\n\nfunction createComponent (\n Ctor,\n data,\n context,\n children,\n tag\n) {\n if (isUndef(Ctor)) {\n return\n }\n\n var baseCtor = context.$options._base;\n\n // plain options object: turn it into a constructor\n if (isObject(Ctor)) {\n Ctor = baseCtor.extend(Ctor);\n }\n\n // if at this stage it's not a constructor or an async component factory,\n // reject.\n if (typeof Ctor !== 'function') {\n if (true) {\n warn((\"Invalid Component definition: \" + (String(Ctor))), context);\n }\n return\n }\n\n // async component\n var asyncFactory;\n if (isUndef(Ctor.cid)) {\n asyncFactory = Ctor;\n Ctor = resolveAsyncComponent(asyncFactory, baseCtor);\n if (Ctor === undefined) {\n // return a placeholder node for async component, which is rendered\n // as a comment node but preserves all the raw information for the node.\n // the information will be used for async server-rendering and hydration.\n return createAsyncPlaceholder(\n asyncFactory,\n data,\n context,\n children,\n tag\n )\n }\n }\n\n data = data || {};\n\n // resolve constructor options in case global mixins are applied after\n // component constructor creation\n resolveConstructorOptions(Ctor);\n\n // transform component v-model data into props & events\n if (isDef(data.model)) {\n transformModel(Ctor.options, data);\n }\n\n // extract props\n var propsData = extractPropsFromVNodeData(data, Ctor, tag);\n\n // functional component\n if (isTrue(Ctor.options.functional)) {\n return createFunctionalComponent(Ctor, propsData, data, context, children)\n }\n\n // extract listeners, since these needs to be treated as\n // child component listeners instead of DOM listeners\n var listeners = data.on;\n // replace with listeners with .native modifier\n // so it gets processed during parent component patch.\n data.on = data.nativeOn;\n\n if (isTrue(Ctor.options.abstract)) {\n // abstract components do not keep anything\n // other than props & listeners & slot\n\n // work around flow\n var slot = data.slot;\n data = {};\n if (slot) {\n data.slot = slot;\n }\n }\n\n // install component management hooks onto the placeholder node\n installComponentHooks(data);\n\n // return a placeholder vnode\n var name = Ctor.options.name || tag;\n var vnode = new VNode(\n (\"vue-component-\" + (Ctor.cid) + (name ? (\"-\" + name) : '')),\n data, undefined, undefined, undefined, context,\n { Ctor: Ctor, propsData: propsData, listeners: listeners, tag: tag, children: children },\n asyncFactory\n );\n\n return vnode\n}\n\nfunction createComponentInstanceForVnode (\n vnode, // we know it's MountedComponentVNode but flow doesn't\n parent // activeInstance in lifecycle state\n) {\n var options = {\n _isComponent: true,\n _parentVnode: vnode,\n parent: parent\n };\n // check inline-template render functions\n var inlineTemplate = vnode.data.inlineTemplate;\n if (isDef(inlineTemplate)) {\n options.render = inlineTemplate.render;\n options.staticRenderFns = inlineTemplate.staticRenderFns;\n }\n return new vnode.componentOptions.Ctor(options)\n}\n\nfunction installComponentHooks (data) {\n var hooks = data.hook || (data.hook = {});\n for (var i = 0; i < hooksToMerge.length; i++) {\n var key = hooksToMerge[i];\n var existing = hooks[key];\n var toMerge = componentVNodeHooks[key];\n if (existing !== toMerge && !(existing && existing._merged)) {\n hooks[key] = existing ? mergeHook$1(toMerge, existing) : toMerge;\n }\n }\n}\n\nfunction mergeHook$1 (f1, f2) {\n var merged = function (a, b) {\n // flow complains about extra args which is why we use any\n f1(a, b);\n f2(a, b);\n };\n merged._merged = true;\n return merged\n}\n\n// transform component v-model info (value and callback) into\n// prop and event handler respectively.\nfunction transformModel (options, data) {\n var prop = (options.model && options.model.prop) || 'value';\n var event = (options.model && options.model.event) || 'input'\n ;(data.attrs || (data.attrs = {}))[prop] = data.model.value;\n var on = data.on || (data.on = {});\n var existing = on[event];\n var callback = data.model.callback;\n if (isDef(existing)) {\n if (\n Array.isArray(existing)\n ? existing.indexOf(callback) === -1\n : existing !== callback\n ) {\n on[event] = [callback].concat(existing);\n }\n } else {\n on[event] = callback;\n }\n}\n\n/* */\n\nvar SIMPLE_NORMALIZE = 1;\nvar ALWAYS_NORMALIZE = 2;\n\n// wrapper function for providing a more flexible interface\n// without getting yelled at by flow\nfunction createElement (\n context,\n tag,\n data,\n children,\n normalizationType,\n alwaysNormalize\n) {\n if (Array.isArray(data) || isPrimitive(data)) {\n normalizationType = children;\n children = data;\n data = undefined;\n }\n if (isTrue(alwaysNormalize)) {\n normalizationType = ALWAYS_NORMALIZE;\n }\n return _createElement(context, tag, data, children, normalizationType)\n}\n\nfunction _createElement (\n context,\n tag,\n data,\n children,\n normalizationType\n) {\n if (isDef(data) && isDef((data).__ob__)) {\n true && warn(\n \"Avoid using observed data object as vnode data: \" + (JSON.stringify(data)) + \"\\n\" +\n 'Always create fresh vnode data objects in each render!',\n context\n );\n return createEmptyVNode()\n }\n // object syntax in v-bind\n if (isDef(data) && isDef(data.is)) {\n tag = data.is;\n }\n if (!tag) {\n // in case of component :is set to falsy value\n return createEmptyVNode()\n }\n // warn against non-primitive key\n if ( true &&\n isDef(data) && isDef(data.key) && !isPrimitive(data.key)\n ) {\n {\n warn(\n 'Avoid using non-primitive value as key, ' +\n 'use string/number value instead.',\n context\n );\n }\n }\n // support single function children as default scoped slot\n if (Array.isArray(children) &&\n typeof children[0] === 'function'\n ) {\n data = data || {};\n data.scopedSlots = { default: children[0] };\n children.length = 0;\n }\n if (normalizationType === ALWAYS_NORMALIZE) {\n children = normalizeChildren(children);\n } else if (normalizationType === SIMPLE_NORMALIZE) {\n children = simpleNormalizeChildren(children);\n }\n var vnode, ns;\n if (typeof tag === 'string') {\n var Ctor;\n ns = (context.$vnode && context.$vnode.ns) || config.getTagNamespace(tag);\n if (config.isReservedTag(tag)) {\n // platform built-in elements\n if ( true && isDef(data) && isDef(data.nativeOn)) {\n warn(\n (\"The .native modifier for v-on is only valid on components but it was used on <\" + tag + \">.\"),\n context\n );\n }\n vnode = new VNode(\n config.parsePlatformTagName(tag), data, children,\n undefined, undefined, context\n );\n } else if ((!data || !data.pre) && isDef(Ctor = resolveAsset(context.$options, 'components', tag))) {\n // component\n vnode = createComponent(Ctor, data, context, children, tag);\n } else {\n // unknown or unlisted namespaced elements\n // check at runtime because it may get assigned a namespace when its\n // parent normalizes children\n vnode = new VNode(\n tag, data, children,\n undefined, undefined, context\n );\n }\n } else {\n // direct component options / constructor\n vnode = createComponent(tag, data, context, children);\n }\n if (Array.isArray(vnode)) {\n return vnode\n } else if (isDef(vnode)) {\n if (isDef(ns)) { applyNS(vnode, ns); }\n if (isDef(data)) { registerDeepBindings(data); }\n return vnode\n } else {\n return createEmptyVNode()\n }\n}\n\nfunction applyNS (vnode, ns, force) {\n vnode.ns = ns;\n if (vnode.tag === 'foreignObject') {\n // use default namespace inside foreignObject\n ns = undefined;\n force = true;\n }\n if (isDef(vnode.children)) {\n for (var i = 0, l = vnode.children.length; i < l; i++) {\n var child = vnode.children[i];\n if (isDef(child.tag) && (\n isUndef(child.ns) || (isTrue(force) && child.tag !== 'svg'))) {\n applyNS(child, ns, force);\n }\n }\n }\n}\n\n// ref #5318\n// necessary to ensure parent re-render when deep bindings like :style and\n// :class are used on slot nodes\nfunction registerDeepBindings (data) {\n if (isObject(data.style)) {\n traverse(data.style);\n }\n if (isObject(data.class)) {\n traverse(data.class);\n }\n}\n\n/* */\n\nfunction initRender (vm) {\n vm._vnode = null; // the root of the child tree\n vm._staticTrees = null; // v-once cached trees\n var options = vm.$options;\n var parentVnode = vm.$vnode = options._parentVnode; // the placeholder node in parent tree\n var renderContext = parentVnode && parentVnode.context;\n vm.$slots = resolveSlots(options._renderChildren, renderContext);\n vm.$scopedSlots = emptyObject;\n // bind the createElement fn to this instance\n // so that we get proper render context inside it.\n // args order: tag, data, children, normalizationType, alwaysNormalize\n // internal version is used by render functions compiled from templates\n vm._c = function (a, b, c, d) { return createElement(vm, a, b, c, d, false); };\n // normalization is always applied for the public version, used in\n // user-written render functions.\n vm.$createElement = function (a, b, c, d) { return createElement(vm, a, b, c, d, true); };\n\n // $attrs & $listeners are exposed for easier HOC creation.\n // they need to be reactive so that HOCs using them are always updated\n var parentData = parentVnode && parentVnode.data;\n\n /* istanbul ignore else */\n if (true) {\n defineReactive$$1(vm, '$attrs', parentData && parentData.attrs || emptyObject, function () {\n !isUpdatingChildComponent && warn(\"$attrs is readonly.\", vm);\n }, true);\n defineReactive$$1(vm, '$listeners', options._parentListeners || emptyObject, function () {\n !isUpdatingChildComponent && warn(\"$listeners is readonly.\", vm);\n }, true);\n } else {}\n}\n\nvar currentRenderingInstance = null;\n\nfunction renderMixin (Vue) {\n // install runtime convenience helpers\n installRenderHelpers(Vue.prototype);\n\n Vue.prototype.$nextTick = function (fn) {\n return nextTick(fn, this)\n };\n\n Vue.prototype._render = function () {\n var vm = this;\n var ref = vm.$options;\n var render = ref.render;\n var _parentVnode = ref._parentVnode;\n\n if (_parentVnode) {\n vm.$scopedSlots = normalizeScopedSlots(\n _parentVnode.data.scopedSlots,\n vm.$slots,\n vm.$scopedSlots\n );\n }\n\n // set parent vnode. this allows render functions to have access\n // to the data on the placeholder node.\n vm.$vnode = _parentVnode;\n // render self\n var vnode;\n try {\n // There's no need to maintain a stack because all render fns are called\n // separately from one another. Nested component's render fns are called\n // when parent component is patched.\n currentRenderingInstance = vm;\n vnode = render.call(vm._renderProxy, vm.$createElement);\n } catch (e) {\n handleError(e, vm, \"render\");\n // return error render result,\n // or previous vnode to prevent render error causing blank component\n /* istanbul ignore else */\n if ( true && vm.$options.renderError) {\n try {\n vnode = vm.$options.renderError.call(vm._renderProxy, vm.$createElement, e);\n } catch (e) {\n handleError(e, vm, \"renderError\");\n vnode = vm._vnode;\n }\n } else {\n vnode = vm._vnode;\n }\n } finally {\n currentRenderingInstance = null;\n }\n // if the returned array contains only a single node, allow it\n if (Array.isArray(vnode) && vnode.length === 1) {\n vnode = vnode[0];\n }\n // return empty vnode in case the render function errored out\n if (!(vnode instanceof VNode)) {\n if ( true && Array.isArray(vnode)) {\n warn(\n 'Multiple root nodes returned from render function. Render function ' +\n 'should return a single root node.',\n vm\n );\n }\n vnode = createEmptyVNode();\n }\n // set parent\n vnode.parent = _parentVnode;\n return vnode\n };\n}\n\n/* */\n\nfunction ensureCtor (comp, base) {\n if (\n comp.__esModule ||\n (hasSymbol && comp[Symbol.toStringTag] === 'Module')\n ) {\n comp = comp.default;\n }\n return isObject(comp)\n ? base.extend(comp)\n : comp\n}\n\nfunction createAsyncPlaceholder (\n factory,\n data,\n context,\n children,\n tag\n) {\n var node = createEmptyVNode();\n node.asyncFactory = factory;\n node.asyncMeta = { data: data, context: context, children: children, tag: tag };\n return node\n}\n\nfunction resolveAsyncComponent (\n factory,\n baseCtor\n) {\n if (isTrue(factory.error) && isDef(factory.errorComp)) {\n return factory.errorComp\n }\n\n if (isDef(factory.resolved)) {\n return factory.resolved\n }\n\n var owner = currentRenderingInstance;\n if (owner && isDef(factory.owners) && factory.owners.indexOf(owner) === -1) {\n // already pending\n factory.owners.push(owner);\n }\n\n if (isTrue(factory.loading) && isDef(factory.loadingComp)) {\n return factory.loadingComp\n }\n\n if (owner && !isDef(factory.owners)) {\n var owners = factory.owners = [owner];\n var sync = true;\n var timerLoading = null;\n var timerTimeout = null\n\n ;(owner).$on('hook:destroyed', function () { return remove(owners, owner); });\n\n var forceRender = function (renderCompleted) {\n for (var i = 0, l = owners.length; i < l; i++) {\n (owners[i]).$forceUpdate();\n }\n\n if (renderCompleted) {\n owners.length = 0;\n if (timerLoading !== null) {\n clearTimeout(timerLoading);\n timerLoading = null;\n }\n if (timerTimeout !== null) {\n clearTimeout(timerTimeout);\n timerTimeout = null;\n }\n }\n };\n\n var resolve = once(function (res) {\n // cache resolved\n factory.resolved = ensureCtor(res, baseCtor);\n // invoke callbacks only if this is not a synchronous resolve\n // (async resolves are shimmed as synchronous during SSR)\n if (!sync) {\n forceRender(true);\n } else {\n owners.length = 0;\n }\n });\n\n var reject = once(function (reason) {\n true && warn(\n \"Failed to resolve async component: \" + (String(factory)) +\n (reason ? (\"\\nReason: \" + reason) : '')\n );\n if (isDef(factory.errorComp)) {\n factory.error = true;\n forceRender(true);\n }\n });\n\n var res = factory(resolve, reject);\n\n if (isObject(res)) {\n if (isPromise(res)) {\n // () => Promise\n if (isUndef(factory.resolved)) {\n res.then(resolve, reject);\n }\n } else if (isPromise(res.component)) {\n res.component.then(resolve, reject);\n\n if (isDef(res.error)) {\n factory.errorComp = ensureCtor(res.error, baseCtor);\n }\n\n if (isDef(res.loading)) {\n factory.loadingComp = ensureCtor(res.loading, baseCtor);\n if (res.delay === 0) {\n factory.loading = true;\n } else {\n timerLoading = setTimeout(function () {\n timerLoading = null;\n if (isUndef(factory.resolved) && isUndef(factory.error)) {\n factory.loading = true;\n forceRender(false);\n }\n }, res.delay || 200);\n }\n }\n\n if (isDef(res.timeout)) {\n timerTimeout = setTimeout(function () {\n timerTimeout = null;\n if (isUndef(factory.resolved)) {\n reject(\n true\n ? (\"timeout (\" + (res.timeout) + \"ms)\")\n : undefined\n );\n }\n }, res.timeout);\n }\n }\n }\n\n sync = false;\n // return in case resolved synchronously\n return factory.loading\n ? factory.loadingComp\n : factory.resolved\n }\n}\n\n/* */\n\nfunction isAsyncPlaceholder (node) {\n return node.isComment && node.asyncFactory\n}\n\n/* */\n\nfunction getFirstComponentChild (children) {\n if (Array.isArray(children)) {\n for (var i = 0; i < children.length; i++) {\n var c = children[i];\n if (isDef(c) && (isDef(c.componentOptions) || isAsyncPlaceholder(c))) {\n return c\n }\n }\n }\n}\n\n/* */\n\n/* */\n\nfunction initEvents (vm) {\n vm._events = Object.create(null);\n vm._hasHookEvent = false;\n // init parent attached events\n var listeners = vm.$options._parentListeners;\n if (listeners) {\n updateComponentListeners(vm, listeners);\n }\n}\n\nvar target;\n\nfunction add (event, fn) {\n target.$on(event, fn);\n}\n\nfunction remove$1 (event, fn) {\n target.$off(event, fn);\n}\n\nfunction createOnceHandler (event, fn) {\n var _target = target;\n return function onceHandler () {\n var res = fn.apply(null, arguments);\n if (res !== null) {\n _target.$off(event, onceHandler);\n }\n }\n}\n\nfunction updateComponentListeners (\n vm,\n listeners,\n oldListeners\n) {\n target = vm;\n updateListeners(listeners, oldListeners || {}, add, remove$1, createOnceHandler, vm);\n target = undefined;\n}\n\nfunction eventsMixin (Vue) {\n var hookRE = /^hook:/;\n Vue.prototype.$on = function (event, fn) {\n var vm = this;\n if (Array.isArray(event)) {\n for (var i = 0, l = event.length; i < l; i++) {\n vm.$on(event[i], fn);\n }\n } else {\n (vm._events[event] || (vm._events[event] = [])).push(fn);\n // optimize hook:event cost by using a boolean flag marked at registration\n // instead of a hash lookup\n if (hookRE.test(event)) {\n vm._hasHookEvent = true;\n }\n }\n return vm\n };\n\n Vue.prototype.$once = function (event, fn) {\n var vm = this;\n function on () {\n vm.$off(event, on);\n fn.apply(vm, arguments);\n }\n on.fn = fn;\n vm.$on(event, on);\n return vm\n };\n\n Vue.prototype.$off = function (event, fn) {\n var vm = this;\n // all\n if (!arguments.length) {\n vm._events = Object.create(null);\n return vm\n }\n // array of events\n if (Array.isArray(event)) {\n for (var i$1 = 0, l = event.length; i$1 < l; i$1++) {\n vm.$off(event[i$1], fn);\n }\n return vm\n }\n // specific event\n var cbs = vm._events[event];\n if (!cbs) {\n return vm\n }\n if (!fn) {\n vm._events[event] = null;\n return vm\n }\n // specific handler\n var cb;\n var i = cbs.length;\n while (i--) {\n cb = cbs[i];\n if (cb === fn || cb.fn === fn) {\n cbs.splice(i, 1);\n break\n }\n }\n return vm\n };\n\n Vue.prototype.$emit = function (event) {\n var vm = this;\n if (true) {\n var lowerCaseEvent = event.toLowerCase();\n if (lowerCaseEvent !== event && vm._events[lowerCaseEvent]) {\n tip(\n \"Event \\\"\" + lowerCaseEvent + \"\\\" is emitted in component \" +\n (formatComponentName(vm)) + \" but the handler is registered for \\\"\" + event + \"\\\". \" +\n \"Note that HTML attributes are case-insensitive and you cannot use \" +\n \"v-on to listen to camelCase events when using in-DOM templates. \" +\n \"You should probably use \\\"\" + (hyphenate(event)) + \"\\\" instead of \\\"\" + event + \"\\\".\"\n );\n }\n }\n var cbs = vm._events[event];\n if (cbs) {\n cbs = cbs.length > 1 ? toArray(cbs) : cbs;\n var args = toArray(arguments, 1);\n var info = \"event handler for \\\"\" + event + \"\\\"\";\n for (var i = 0, l = cbs.length; i < l; i++) {\n invokeWithErrorHandling(cbs[i], vm, args, vm, info);\n }\n }\n return vm\n };\n}\n\n/* */\n\nvar activeInstance = null;\nvar isUpdatingChildComponent = false;\n\nfunction setActiveInstance(vm) {\n var prevActiveInstance = activeInstance;\n activeInstance = vm;\n return function () {\n activeInstance = prevActiveInstance;\n }\n}\n\nfunction initLifecycle (vm) {\n var options = vm.$options;\n\n // locate first non-abstract parent\n var parent = options.parent;\n if (parent && !options.abstract) {\n while (parent.$options.abstract && parent.$parent) {\n parent = parent.$parent;\n }\n parent.$children.push(vm);\n }\n\n vm.$parent = parent;\n vm.$root = parent ? parent.$root : vm;\n\n vm.$children = [];\n vm.$refs = {};\n\n vm._watcher = null;\n vm._inactive = null;\n vm._directInactive = false;\n vm._isMounted = false;\n vm._isDestroyed = false;\n vm._isBeingDestroyed = false;\n}\n\nfunction lifecycleMixin (Vue) {\n Vue.prototype._update = function (vnode, hydrating) {\n var vm = this;\n var prevEl = vm.$el;\n var prevVnode = vm._vnode;\n var restoreActiveInstance = setActiveInstance(vm);\n vm._vnode = vnode;\n // Vue.prototype.__patch__ is injected in entry points\n // based on the rendering backend used.\n if (!prevVnode) {\n // initial render\n vm.$el = vm.__patch__(vm.$el, vnode, hydrating, false /* removeOnly */);\n } else {\n // updates\n vm.$el = vm.__patch__(prevVnode, vnode);\n }\n restoreActiveInstance();\n // update __vue__ reference\n if (prevEl) {\n prevEl.__vue__ = null;\n }\n if (vm.$el) {\n vm.$el.__vue__ = vm;\n }\n // if parent is an HOC, update its $el as well\n if (vm.$vnode && vm.$parent && vm.$vnode === vm.$parent._vnode) {\n vm.$parent.$el = vm.$el;\n }\n // updated hook is called by the scheduler to ensure that children are\n // updated in a parent's updated hook.\n };\n\n Vue.prototype.$forceUpdate = function () {\n var vm = this;\n if (vm._watcher) {\n vm._watcher.update();\n }\n };\n\n Vue.prototype.$destroy = function () {\n var vm = this;\n if (vm._isBeingDestroyed) {\n return\n }\n callHook(vm, 'beforeDestroy');\n vm._isBeingDestroyed = true;\n // remove self from parent\n var parent = vm.$parent;\n if (parent && !parent._isBeingDestroyed && !vm.$options.abstract) {\n remove(parent.$children, vm);\n }\n // teardown watchers\n if (vm._watcher) {\n vm._watcher.teardown();\n }\n var i = vm._watchers.length;\n while (i--) {\n vm._watchers[i].teardown();\n }\n // remove reference from data ob\n // frozen object may not have observer.\n if (vm._data.__ob__) {\n vm._data.__ob__.vmCount--;\n }\n // call the last hook...\n vm._isDestroyed = true;\n // invoke destroy hooks on current rendered tree\n vm.__patch__(vm._vnode, null);\n // fire destroyed hook\n callHook(vm, 'destroyed');\n // turn off all instance listeners.\n vm.$off();\n // remove __vue__ reference\n if (vm.$el) {\n vm.$el.__vue__ = null;\n }\n // release circular reference (#6759)\n if (vm.$vnode) {\n vm.$vnode.parent = null;\n }\n };\n}\n\nfunction mountComponent (\n vm,\n el,\n hydrating\n) {\n vm.$el = el;\n if (!vm.$options.render) {\n vm.$options.render = createEmptyVNode;\n if (true) {\n /* istanbul ignore if */\n if ((vm.$options.template && vm.$options.template.charAt(0) !== '#') ||\n vm.$options.el || el) {\n warn(\n 'You are using the runtime-only build of Vue where the template ' +\n 'compiler is not available. Either pre-compile the templates into ' +\n 'render functions, or use the compiler-included build.',\n vm\n );\n } else {\n warn(\n 'Failed to mount component: template or render function not defined.',\n vm\n );\n }\n }\n }\n callHook(vm, 'beforeMount');\n\n var updateComponent;\n /* istanbul ignore if */\n if ( true && config.performance && mark) {\n updateComponent = function () {\n var name = vm._name;\n var id = vm._uid;\n var startTag = \"vue-perf-start:\" + id;\n var endTag = \"vue-perf-end:\" + id;\n\n mark(startTag);\n var vnode = vm._render();\n mark(endTag);\n measure((\"vue \" + name + \" render\"), startTag, endTag);\n\n mark(startTag);\n vm._update(vnode, hydrating);\n mark(endTag);\n measure((\"vue \" + name + \" patch\"), startTag, endTag);\n };\n } else {\n updateComponent = function () {\n vm._update(vm._render(), hydrating);\n };\n }\n\n // we set this to vm._watcher inside the watcher's constructor\n // since the watcher's initial patch may call $forceUpdate (e.g. inside child\n // component's mounted hook), which relies on vm._watcher being already defined\n new Watcher(vm, updateComponent, noop, {\n before: function before () {\n if (vm._isMounted && !vm._isDestroyed) {\n callHook(vm, 'beforeUpdate');\n }\n }\n }, true /* isRenderWatcher */);\n hydrating = false;\n\n // manually mounted instance, call mounted on self\n // mounted is called for render-created child components in its inserted hook\n if (vm.$vnode == null) {\n vm._isMounted = true;\n callHook(vm, 'mounted');\n }\n return vm\n}\n\nfunction updateChildComponent (\n vm,\n propsData,\n listeners,\n parentVnode,\n renderChildren\n) {\n if (true) {\n isUpdatingChildComponent = true;\n }\n\n // determine whether component has slot children\n // we need to do this before overwriting $options._renderChildren.\n\n // check if there are dynamic scopedSlots (hand-written or compiled but with\n // dynamic slot names). Static scoped slots compiled from template has the\n // \"$stable\" marker.\n var newScopedSlots = parentVnode.data.scopedSlots;\n var oldScopedSlots = vm.$scopedSlots;\n var hasDynamicScopedSlot = !!(\n (newScopedSlots && !newScopedSlots.$stable) ||\n (oldScopedSlots !== emptyObject && !oldScopedSlots.$stable) ||\n (newScopedSlots && vm.$scopedSlots.$key !== newScopedSlots.$key)\n );\n\n // Any static slot children from the parent may have changed during parent's\n // update. Dynamic scoped slots may also have changed. In such cases, a forced\n // update is necessary to ensure correctness.\n var needsForceUpdate = !!(\n renderChildren || // has new static slots\n vm.$options._renderChildren || // has old static slots\n hasDynamicScopedSlot\n );\n\n vm.$options._parentVnode = parentVnode;\n vm.$vnode = parentVnode; // update vm's placeholder node without re-render\n\n if (vm._vnode) { // update child tree's parent\n vm._vnode.parent = parentVnode;\n }\n vm.$options._renderChildren = renderChildren;\n\n // update $attrs and $listeners hash\n // these are also reactive so they may trigger child update if the child\n // used them during render\n vm.$attrs = parentVnode.data.attrs || emptyObject;\n vm.$listeners = listeners || emptyObject;\n\n // update props\n if (propsData && vm.$options.props) {\n toggleObserving(false);\n var props = vm._props;\n var propKeys = vm.$options._propKeys || [];\n for (var i = 0; i < propKeys.length; i++) {\n var key = propKeys[i];\n var propOptions = vm.$options.props; // wtf flow?\n props[key] = validateProp(key, propOptions, propsData, vm);\n }\n toggleObserving(true);\n // keep a copy of raw propsData\n vm.$options.propsData = propsData;\n }\n\n // update listeners\n listeners = listeners || emptyObject;\n var oldListeners = vm.$options._parentListeners;\n vm.$options._parentListeners = listeners;\n updateComponentListeners(vm, listeners, oldListeners);\n\n // resolve slots + force update if has children\n if (needsForceUpdate) {\n vm.$slots = resolveSlots(renderChildren, parentVnode.context);\n vm.$forceUpdate();\n }\n\n if (true) {\n isUpdatingChildComponent = false;\n }\n}\n\nfunction isInInactiveTree (vm) {\n while (vm && (vm = vm.$parent)) {\n if (vm._inactive) { return true }\n }\n return false\n}\n\nfunction activateChildComponent (vm, direct) {\n if (direct) {\n vm._directInactive = false;\n if (isInInactiveTree(vm)) {\n return\n }\n } else if (vm._directInactive) {\n return\n }\n if (vm._inactive || vm._inactive === null) {\n vm._inactive = false;\n for (var i = 0; i < vm.$children.length; i++) {\n activateChildComponent(vm.$children[i]);\n }\n callHook(vm, 'activated');\n }\n}\n\nfunction deactivateChildComponent (vm, direct) {\n if (direct) {\n vm._directInactive = true;\n if (isInInactiveTree(vm)) {\n return\n }\n }\n if (!vm._inactive) {\n vm._inactive = true;\n for (var i = 0; i < vm.$children.length; i++) {\n deactivateChildComponent(vm.$children[i]);\n }\n callHook(vm, 'deactivated');\n }\n}\n\nfunction callHook (vm, hook) {\n // #7573 disable dep collection when invoking lifecycle hooks\n pushTarget();\n var handlers = vm.$options[hook];\n var info = hook + \" hook\";\n if (handlers) {\n for (var i = 0, j = handlers.length; i < j; i++) {\n invokeWithErrorHandling(handlers[i], vm, null, vm, info);\n }\n }\n if (vm._hasHookEvent) {\n vm.$emit('hook:' + hook);\n }\n popTarget();\n}\n\n/* */\n\nvar MAX_UPDATE_COUNT = 100;\n\nvar queue = [];\nvar activatedChildren = [];\nvar has = {};\nvar circular = {};\nvar waiting = false;\nvar flushing = false;\nvar index = 0;\n\n/**\n * Reset the scheduler's state.\n */\nfunction resetSchedulerState () {\n index = queue.length = activatedChildren.length = 0;\n has = {};\n if (true) {\n circular = {};\n }\n waiting = flushing = false;\n}\n\n// Async edge case #6566 requires saving the timestamp when event listeners are\n// attached. However, calling performance.now() has a perf overhead especially\n// if the page has thousands of event listeners. Instead, we take a timestamp\n// every time the scheduler flushes and use that for all event listeners\n// attached during that flush.\nvar currentFlushTimestamp = 0;\n\n// Async edge case fix requires storing an event listener's attach timestamp.\nvar getNow = Date.now;\n\n// Determine what event timestamp the browser is using. Annoyingly, the\n// timestamp can either be hi-res (relative to page load) or low-res\n// (relative to UNIX epoch), so in order to compare time we have to use the\n// same timestamp type when saving the flush timestamp.\n// All IE versions use low-res event timestamps, and have problematic clock\n// implementations (#9632)\nif (inBrowser && !isIE) {\n var performance = window.performance;\n if (\n performance &&\n typeof performance.now === 'function' &&\n getNow() > document.createEvent('Event').timeStamp\n ) {\n // if the event timestamp, although evaluated AFTER the Date.now(), is\n // smaller than it, it means the event is using a hi-res timestamp,\n // and we need to use the hi-res version for event listener timestamps as\n // well.\n getNow = function () { return performance.now(); };\n }\n}\n\n/**\n * Flush both queues and run the watchers.\n */\nfunction flushSchedulerQueue () {\n currentFlushTimestamp = getNow();\n flushing = true;\n var watcher, id;\n\n // Sort queue before flush.\n // This ensures that:\n // 1. Components are updated from parent to child. (because parent is always\n // created before the child)\n // 2. A component's user watchers are run before its render watcher (because\n // user watchers are created before the render watcher)\n // 3. If a component is destroyed during a parent component's watcher run,\n // its watchers can be skipped.\n queue.sort(function (a, b) { return a.id - b.id; });\n\n // do not cache length because more watchers might be pushed\n // as we run existing watchers\n for (index = 0; index < queue.length; index++) {\n watcher = queue[index];\n if (watcher.before) {\n watcher.before();\n }\n id = watcher.id;\n has[id] = null;\n watcher.run();\n // in dev build, check and stop circular updates.\n if ( true && has[id] != null) {\n circular[id] = (circular[id] || 0) + 1;\n if (circular[id] > MAX_UPDATE_COUNT) {\n warn(\n 'You may have an infinite update loop ' + (\n watcher.user\n ? (\"in watcher with expression \\\"\" + (watcher.expression) + \"\\\"\")\n : \"in a component render function.\"\n ),\n watcher.vm\n );\n break\n }\n }\n }\n\n // keep copies of post queues before resetting state\n var activatedQueue = activatedChildren.slice();\n var updatedQueue = queue.slice();\n\n resetSchedulerState();\n\n // call component updated and activated hooks\n callActivatedHooks(activatedQueue);\n callUpdatedHooks(updatedQueue);\n\n // devtool hook\n /* istanbul ignore if */\n if (devtools && config.devtools) {\n devtools.emit('flush');\n }\n}\n\nfunction callUpdatedHooks (queue) {\n var i = queue.length;\n while (i--) {\n var watcher = queue[i];\n var vm = watcher.vm;\n if (vm._watcher === watcher && vm._isMounted && !vm._isDestroyed) {\n callHook(vm, 'updated');\n }\n }\n}\n\n/**\n * Queue a kept-alive component that was activated during patch.\n * The queue will be processed after the entire tree has been patched.\n */\nfunction queueActivatedComponent (vm) {\n // setting _inactive to false here so that a render function can\n // rely on checking whether it's in an inactive tree (e.g. router-view)\n vm._inactive = false;\n activatedChildren.push(vm);\n}\n\nfunction callActivatedHooks (queue) {\n for (var i = 0; i < queue.length; i++) {\n queue[i]._inactive = true;\n activateChildComponent(queue[i], true /* true */);\n }\n}\n\n/**\n * Push a watcher into the watcher queue.\n * Jobs with duplicate IDs will be skipped unless it's\n * pushed when the queue is being flushed.\n */\nfunction queueWatcher (watcher) {\n var id = watcher.id;\n if (has[id] == null) {\n has[id] = true;\n if (!flushing) {\n queue.push(watcher);\n } else {\n // if already flushing, splice the watcher based on its id\n // if already past its id, it will be run next immediately.\n var i = queue.length - 1;\n while (i > index && queue[i].id > watcher.id) {\n i--;\n }\n queue.splice(i + 1, 0, watcher);\n }\n // queue the flush\n if (!waiting) {\n waiting = true;\n\n if ( true && !config.async) {\n flushSchedulerQueue();\n return\n }\n nextTick(flushSchedulerQueue);\n }\n }\n}\n\n/* */\n\n\n\nvar uid$2 = 0;\n\n/**\n * A watcher parses an expression, collects dependencies,\n * and fires callback when the expression value changes.\n * This is used for both the $watch() api and directives.\n */\nvar Watcher = function Watcher (\n vm,\n expOrFn,\n cb,\n options,\n isRenderWatcher\n) {\n this.vm = vm;\n if (isRenderWatcher) {\n vm._watcher = this;\n }\n vm._watchers.push(this);\n // options\n if (options) {\n this.deep = !!options.deep;\n this.user = !!options.user;\n this.lazy = !!options.lazy;\n this.sync = !!options.sync;\n this.before = options.before;\n } else {\n this.deep = this.user = this.lazy = this.sync = false;\n }\n this.cb = cb;\n this.id = ++uid$2; // uid for batching\n this.active = true;\n this.dirty = this.lazy; // for lazy watchers\n this.deps = [];\n this.newDeps = [];\n this.depIds = new _Set();\n this.newDepIds = new _Set();\n this.expression = true\n ? expOrFn.toString()\n : undefined;\n // parse expression for getter\n if (typeof expOrFn === 'function') {\n this.getter = expOrFn;\n } else {\n this.getter = parsePath(expOrFn);\n if (!this.getter) {\n this.getter = noop;\n true && warn(\n \"Failed watching path: \\\"\" + expOrFn + \"\\\" \" +\n 'Watcher only accepts simple dot-delimited paths. ' +\n 'For full control, use a function instead.',\n vm\n );\n }\n }\n this.value = this.lazy\n ? undefined\n : this.get();\n};\n\n/**\n * Evaluate the getter, and re-collect dependencies.\n */\nWatcher.prototype.get = function get () {\n pushTarget(this);\n var value;\n var vm = this.vm;\n try {\n value = this.getter.call(vm, vm);\n } catch (e) {\n if (this.user) {\n handleError(e, vm, (\"getter for watcher \\\"\" + (this.expression) + \"\\\"\"));\n } else {\n throw e\n }\n } finally {\n // \"touch\" every property so they are all tracked as\n // dependencies for deep watching\n if (this.deep) {\n traverse(value);\n }\n popTarget();\n this.cleanupDeps();\n }\n return value\n};\n\n/**\n * Add a dependency to this directive.\n */\nWatcher.prototype.addDep = function addDep (dep) {\n var id = dep.id;\n if (!this.newDepIds.has(id)) {\n this.newDepIds.add(id);\n this.newDeps.push(dep);\n if (!this.depIds.has(id)) {\n dep.addSub(this);\n }\n }\n};\n\n/**\n * Clean up for dependency collection.\n */\nWatcher.prototype.cleanupDeps = function cleanupDeps () {\n var i = this.deps.length;\n while (i--) {\n var dep = this.deps[i];\n if (!this.newDepIds.has(dep.id)) {\n dep.removeSub(this);\n }\n }\n var tmp = this.depIds;\n this.depIds = this.newDepIds;\n this.newDepIds = tmp;\n this.newDepIds.clear();\n tmp = this.deps;\n this.deps = this.newDeps;\n this.newDeps = tmp;\n this.newDeps.length = 0;\n};\n\n/**\n * Subscriber interface.\n * Will be called when a dependency changes.\n */\nWatcher.prototype.update = function update () {\n /* istanbul ignore else */\n if (this.lazy) {\n this.dirty = true;\n } else if (this.sync) {\n this.run();\n } else {\n queueWatcher(this);\n }\n};\n\n/**\n * Scheduler job interface.\n * Will be called by the scheduler.\n */\nWatcher.prototype.run = function run () {\n if (this.active) {\n var value = this.get();\n if (\n value !== this.value ||\n // Deep watchers and watchers on Object/Arrays should fire even\n // when the value is the same, because the value may\n // have mutated.\n isObject(value) ||\n this.deep\n ) {\n // set new value\n var oldValue = this.value;\n this.value = value;\n if (this.user) {\n try {\n this.cb.call(this.vm, value, oldValue);\n } catch (e) {\n handleError(e, this.vm, (\"callback for watcher \\\"\" + (this.expression) + \"\\\"\"));\n }\n } else {\n this.cb.call(this.vm, value, oldValue);\n }\n }\n }\n};\n\n/**\n * Evaluate the value of the watcher.\n * This only gets called for lazy watchers.\n */\nWatcher.prototype.evaluate = function evaluate () {\n this.value = this.get();\n this.dirty = false;\n};\n\n/**\n * Depend on all deps collected by this watcher.\n */\nWatcher.prototype.depend = function depend () {\n var i = this.deps.length;\n while (i--) {\n this.deps[i].depend();\n }\n};\n\n/**\n * Remove self from all dependencies' subscriber list.\n */\nWatcher.prototype.teardown = function teardown () {\n if (this.active) {\n // remove self from vm's watcher list\n // this is a somewhat expensive operation so we skip it\n // if the vm is being destroyed.\n if (!this.vm._isBeingDestroyed) {\n remove(this.vm._watchers, this);\n }\n var i = this.deps.length;\n while (i--) {\n this.deps[i].removeSub(this);\n }\n this.active = false;\n }\n};\n\n/* */\n\nvar sharedPropertyDefinition = {\n enumerable: true,\n configurable: true,\n get: noop,\n set: noop\n};\n\nfunction proxy (target, sourceKey, key) {\n sharedPropertyDefinition.get = function proxyGetter () {\n return this[sourceKey][key]\n };\n sharedPropertyDefinition.set = function proxySetter (val) {\n this[sourceKey][key] = val;\n };\n Object.defineProperty(target, key, sharedPropertyDefinition);\n}\n\nfunction initState (vm) {\n vm._watchers = [];\n var opts = vm.$options;\n if (opts.props) { initProps(vm, opts.props); }\n if (opts.methods) { initMethods(vm, opts.methods); }\n if (opts.data) {\n initData(vm);\n } else {\n observe(vm._data = {}, true /* asRootData */);\n }\n if (opts.computed) { initComputed(vm, opts.computed); }\n if (opts.watch && opts.watch !== nativeWatch) {\n initWatch(vm, opts.watch);\n }\n}\n\nfunction initProps (vm, propsOptions) {\n var propsData = vm.$options.propsData || {};\n var props = vm._props = {};\n // cache prop keys so that future props updates can iterate using Array\n // instead of dynamic object key enumeration.\n var keys = vm.$options._propKeys = [];\n var isRoot = !vm.$parent;\n // root instance props should be converted\n if (!isRoot) {\n toggleObserving(false);\n }\n var loop = function ( key ) {\n keys.push(key);\n var value = validateProp(key, propsOptions, propsData, vm);\n /* istanbul ignore else */\n if (true) {\n var hyphenatedKey = hyphenate(key);\n if (isReservedAttribute(hyphenatedKey) ||\n config.isReservedAttr(hyphenatedKey)) {\n warn(\n (\"\\\"\" + hyphenatedKey + \"\\\" is a reserved attribute and cannot be used as component prop.\"),\n vm\n );\n }\n defineReactive$$1(props, key, value, function () {\n if (!isRoot && !isUpdatingChildComponent) {\n warn(\n \"Avoid mutating a prop directly since the value will be \" +\n \"overwritten whenever the parent component re-renders. \" +\n \"Instead, use a data or computed property based on the prop's \" +\n \"value. Prop being mutated: \\\"\" + key + \"\\\"\",\n vm\n );\n }\n });\n } else {}\n // static props are already proxied on the component's prototype\n // during Vue.extend(). We only need to proxy props defined at\n // instantiation here.\n if (!(key in vm)) {\n proxy(vm, \"_props\", key);\n }\n };\n\n for (var key in propsOptions) loop( key );\n toggleObserving(true);\n}\n\nfunction initData (vm) {\n var data = vm.$options.data;\n data = vm._data = typeof data === 'function'\n ? getData(data, vm)\n : data || {};\n if (!isPlainObject(data)) {\n data = {};\n true && warn(\n 'data functions should return an object:\\n' +\n 'https://vuejs.org/v2/guide/components.html#data-Must-Be-a-Function',\n vm\n );\n }\n // proxy data on instance\n var keys = Object.keys(data);\n var props = vm.$options.props;\n var methods = vm.$options.methods;\n var i = keys.length;\n while (i--) {\n var key = keys[i];\n if (true) {\n if (methods && hasOwn(methods, key)) {\n warn(\n (\"Method \\\"\" + key + \"\\\" has already been defined as a data property.\"),\n vm\n );\n }\n }\n if (props && hasOwn(props, key)) {\n true && warn(\n \"The data property \\\"\" + key + \"\\\" is already declared as a prop. \" +\n \"Use prop default value instead.\",\n vm\n );\n } else if (!isReserved(key)) {\n proxy(vm, \"_data\", key);\n }\n }\n // observe data\n observe(data, true /* asRootData */);\n}\n\nfunction getData (data, vm) {\n // #7573 disable dep collection when invoking data getters\n pushTarget();\n try {\n return data.call(vm, vm)\n } catch (e) {\n handleError(e, vm, \"data()\");\n return {}\n } finally {\n popTarget();\n }\n}\n\nvar computedWatcherOptions = { lazy: true };\n\nfunction initComputed (vm, computed) {\n // $flow-disable-line\n var watchers = vm._computedWatchers = Object.create(null);\n // computed properties are just getters during SSR\n var isSSR = isServerRendering();\n\n for (var key in computed) {\n var userDef = computed[key];\n var getter = typeof userDef === 'function' ? userDef : userDef.get;\n if ( true && getter == null) {\n warn(\n (\"Getter is missing for computed property \\\"\" + key + \"\\\".\"),\n vm\n );\n }\n\n if (!isSSR) {\n // create internal watcher for the computed property.\n watchers[key] = new Watcher(\n vm,\n getter || noop,\n noop,\n computedWatcherOptions\n );\n }\n\n // component-defined computed properties are already defined on the\n // component prototype. We only need to define computed properties defined\n // at instantiation here.\n if (!(key in vm)) {\n defineComputed(vm, key, userDef);\n } else if (true) {\n if (key in vm.$data) {\n warn((\"The computed property \\\"\" + key + \"\\\" is already defined in data.\"), vm);\n } else if (vm.$options.props && key in vm.$options.props) {\n warn((\"The computed property \\\"\" + key + \"\\\" is already defined as a prop.\"), vm);\n }\n }\n }\n}\n\nfunction defineComputed (\n target,\n key,\n userDef\n) {\n var shouldCache = !isServerRendering();\n if (typeof userDef === 'function') {\n sharedPropertyDefinition.get = shouldCache\n ? createComputedGetter(key)\n : createGetterInvoker(userDef);\n sharedPropertyDefinition.set = noop;\n } else {\n sharedPropertyDefinition.get = userDef.get\n ? shouldCache && userDef.cache !== false\n ? createComputedGetter(key)\n : createGetterInvoker(userDef.get)\n : noop;\n sharedPropertyDefinition.set = userDef.set || noop;\n }\n if ( true &&\n sharedPropertyDefinition.set === noop) {\n sharedPropertyDefinition.set = function () {\n warn(\n (\"Computed property \\\"\" + key + \"\\\" was assigned to but it has no setter.\"),\n this\n );\n };\n }\n Object.defineProperty(target, key, sharedPropertyDefinition);\n}\n\nfunction createComputedGetter (key) {\n return function computedGetter () {\n var watcher = this._computedWatchers && this._computedWatchers[key];\n if (watcher) {\n if (watcher.dirty) {\n watcher.evaluate();\n }\n if (Dep.target) {\n watcher.depend();\n }\n return watcher.value\n }\n }\n}\n\nfunction createGetterInvoker(fn) {\n return function computedGetter () {\n return fn.call(this, this)\n }\n}\n\nfunction initMethods (vm, methods) {\n var props = vm.$options.props;\n for (var key in methods) {\n if (true) {\n if (typeof methods[key] !== 'function') {\n warn(\n \"Method \\\"\" + key + \"\\\" has type \\\"\" + (typeof methods[key]) + \"\\\" in the component definition. \" +\n \"Did you reference the function correctly?\",\n vm\n );\n }\n if (props && hasOwn(props, key)) {\n warn(\n (\"Method \\\"\" + key + \"\\\" has already been defined as a prop.\"),\n vm\n );\n }\n if ((key in vm) && isReserved(key)) {\n warn(\n \"Method \\\"\" + key + \"\\\" conflicts with an existing Vue instance method. \" +\n \"Avoid defining component methods that start with _ or $.\"\n );\n }\n }\n vm[key] = typeof methods[key] !== 'function' ? noop : bind(methods[key], vm);\n }\n}\n\nfunction initWatch (vm, watch) {\n for (var key in watch) {\n var handler = watch[key];\n if (Array.isArray(handler)) {\n for (var i = 0; i < handler.length; i++) {\n createWatcher(vm, key, handler[i]);\n }\n } else {\n createWatcher(vm, key, handler);\n }\n }\n}\n\nfunction createWatcher (\n vm,\n expOrFn,\n handler,\n options\n) {\n if (isPlainObject(handler)) {\n options = handler;\n handler = handler.handler;\n }\n if (typeof handler === 'string') {\n handler = vm[handler];\n }\n return vm.$watch(expOrFn, handler, options)\n}\n\nfunction stateMixin (Vue) {\n // flow somehow has problems with directly declared definition object\n // when using Object.defineProperty, so we have to procedurally build up\n // the object here.\n var dataDef = {};\n dataDef.get = function () { return this._data };\n var propsDef = {};\n propsDef.get = function () { return this._props };\n if (true) {\n dataDef.set = function () {\n warn(\n 'Avoid replacing instance root $data. ' +\n 'Use nested data properties instead.',\n this\n );\n };\n propsDef.set = function () {\n warn(\"$props is readonly.\", this);\n };\n }\n Object.defineProperty(Vue.prototype, '$data', dataDef);\n Object.defineProperty(Vue.prototype, '$props', propsDef);\n\n Vue.prototype.$set = set;\n Vue.prototype.$delete = del;\n\n Vue.prototype.$watch = function (\n expOrFn,\n cb,\n options\n ) {\n var vm = this;\n if (isPlainObject(cb)) {\n return createWatcher(vm, expOrFn, cb, options)\n }\n options = options || {};\n options.user = true;\n var watcher = new Watcher(vm, expOrFn, cb, options);\n if (options.immediate) {\n try {\n cb.call(vm, watcher.value);\n } catch (error) {\n handleError(error, vm, (\"callback for immediate watcher \\\"\" + (watcher.expression) + \"\\\"\"));\n }\n }\n return function unwatchFn () {\n watcher.teardown();\n }\n };\n}\n\n/* */\n\nvar uid$3 = 0;\n\nfunction initMixin (Vue) {\n Vue.prototype._init = function (options) {\n var vm = this;\n // a uid\n vm._uid = uid$3++;\n\n var startTag, endTag;\n /* istanbul ignore if */\n if ( true && config.performance && mark) {\n startTag = \"vue-perf-start:\" + (vm._uid);\n endTag = \"vue-perf-end:\" + (vm._uid);\n mark(startTag);\n }\n\n // a flag to avoid this being observed\n vm._isVue = true;\n // merge options\n if (options && options._isComponent) {\n // optimize internal component instantiation\n // since dynamic options merging is pretty slow, and none of the\n // internal component options needs special treatment.\n initInternalComponent(vm, options);\n } else {\n vm.$options = mergeOptions(\n resolveConstructorOptions(vm.constructor),\n options || {},\n vm\n );\n }\n /* istanbul ignore else */\n if (true) {\n initProxy(vm);\n } else {}\n // expose real self\n vm._self = vm;\n initLifecycle(vm);\n initEvents(vm);\n initRender(vm);\n callHook(vm, 'beforeCreate');\n initInjections(vm); // resolve injections before data/props\n initState(vm);\n initProvide(vm); // resolve provide after data/props\n callHook(vm, 'created');\n\n /* istanbul ignore if */\n if ( true && config.performance && mark) {\n vm._name = formatComponentName(vm, false);\n mark(endTag);\n measure((\"vue \" + (vm._name) + \" init\"), startTag, endTag);\n }\n\n if (vm.$options.el) {\n vm.$mount(vm.$options.el);\n }\n };\n}\n\nfunction initInternalComponent (vm, options) {\n var opts = vm.$options = Object.create(vm.constructor.options);\n // doing this because it's faster than dynamic enumeration.\n var parentVnode = options._parentVnode;\n opts.parent = options.parent;\n opts._parentVnode = parentVnode;\n\n var vnodeComponentOptions = parentVnode.componentOptions;\n opts.propsData = vnodeComponentOptions.propsData;\n opts._parentListeners = vnodeComponentOptions.listeners;\n opts._renderChildren = vnodeComponentOptions.children;\n opts._componentTag = vnodeComponentOptions.tag;\n\n if (options.render) {\n opts.render = options.render;\n opts.staticRenderFns = options.staticRenderFns;\n }\n}\n\nfunction resolveConstructorOptions (Ctor) {\n var options = Ctor.options;\n if (Ctor.super) {\n var superOptions = resolveConstructorOptions(Ctor.super);\n var cachedSuperOptions = Ctor.superOptions;\n if (superOptions !== cachedSuperOptions) {\n // super option changed,\n // need to resolve new options.\n Ctor.superOptions = superOptions;\n // check if there are any late-modified/attached options (#4976)\n var modifiedOptions = resolveModifiedOptions(Ctor);\n // update base extend options\n if (modifiedOptions) {\n extend(Ctor.extendOptions, modifiedOptions);\n }\n options = Ctor.options = mergeOptions(superOptions, Ctor.extendOptions);\n if (options.name) {\n options.components[options.name] = Ctor;\n }\n }\n }\n return options\n}\n\nfunction resolveModifiedOptions (Ctor) {\n var modified;\n var latest = Ctor.options;\n var sealed = Ctor.sealedOptions;\n for (var key in latest) {\n if (latest[key] !== sealed[key]) {\n if (!modified) { modified = {}; }\n modified[key] = latest[key];\n }\n }\n return modified\n}\n\nfunction Vue (options) {\n if ( true &&\n !(this instanceof Vue)\n ) {\n warn('Vue is a constructor and should be called with the `new` keyword');\n }\n this._init(options);\n}\n\ninitMixin(Vue);\nstateMixin(Vue);\neventsMixin(Vue);\nlifecycleMixin(Vue);\nrenderMixin(Vue);\n\n/* */\n\nfunction initUse (Vue) {\n Vue.use = function (plugin) {\n var installedPlugins = (this._installedPlugins || (this._installedPlugins = []));\n if (installedPlugins.indexOf(plugin) > -1) {\n return this\n }\n\n // additional parameters\n var args = toArray(arguments, 1);\n args.unshift(this);\n if (typeof plugin.install === 'function') {\n plugin.install.apply(plugin, args);\n } else if (typeof plugin === 'function') {\n plugin.apply(null, args);\n }\n installedPlugins.push(plugin);\n return this\n };\n}\n\n/* */\n\nfunction initMixin$1 (Vue) {\n Vue.mixin = function (mixin) {\n this.options = mergeOptions(this.options, mixin);\n return this\n };\n}\n\n/* */\n\nfunction initExtend (Vue) {\n /**\n * Each instance constructor, including Vue, has a unique\n * cid. This enables us to create wrapped \"child\n * constructors\" for prototypal inheritance and cache them.\n */\n Vue.cid = 0;\n var cid = 1;\n\n /**\n * Class inheritance\n */\n Vue.extend = function (extendOptions) {\n extendOptions = extendOptions || {};\n var Super = this;\n var SuperId = Super.cid;\n var cachedCtors = extendOptions._Ctor || (extendOptions._Ctor = {});\n if (cachedCtors[SuperId]) {\n return cachedCtors[SuperId]\n }\n\n var name = extendOptions.name || Super.options.name;\n if ( true && name) {\n validateComponentName(name);\n }\n\n var Sub = function VueComponent (options) {\n this._init(options);\n };\n Sub.prototype = Object.create(Super.prototype);\n Sub.prototype.constructor = Sub;\n Sub.cid = cid++;\n Sub.options = mergeOptions(\n Super.options,\n extendOptions\n );\n Sub['super'] = Super;\n\n // For props and computed properties, we define the proxy getters on\n // the Vue instances at extension time, on the extended prototype. This\n // avoids Object.defineProperty calls for each instance created.\n if (Sub.options.props) {\n initProps$1(Sub);\n }\n if (Sub.options.computed) {\n initComputed$1(Sub);\n }\n\n // allow further extension/mixin/plugin usage\n Sub.extend = Super.extend;\n Sub.mixin = Super.mixin;\n Sub.use = Super.use;\n\n // create asset registers, so extended classes\n // can have their private assets too.\n ASSET_TYPES.forEach(function (type) {\n Sub[type] = Super[type];\n });\n // enable recursive self-lookup\n if (name) {\n Sub.options.components[name] = Sub;\n }\n\n // keep a reference to the super options at extension time.\n // later at instantiation we can check if Super's options have\n // been updated.\n Sub.superOptions = Super.options;\n Sub.extendOptions = extendOptions;\n Sub.sealedOptions = extend({}, Sub.options);\n\n // cache constructor\n cachedCtors[SuperId] = Sub;\n return Sub\n };\n}\n\nfunction initProps$1 (Comp) {\n var props = Comp.options.props;\n for (var key in props) {\n proxy(Comp.prototype, \"_props\", key);\n }\n}\n\nfunction initComputed$1 (Comp) {\n var computed = Comp.options.computed;\n for (var key in computed) {\n defineComputed(Comp.prototype, key, computed[key]);\n }\n}\n\n/* */\n\nfunction initAssetRegisters (Vue) {\n /**\n * Create asset registration methods.\n */\n ASSET_TYPES.forEach(function (type) {\n Vue[type] = function (\n id,\n definition\n ) {\n if (!definition) {\n return this.options[type + 's'][id]\n } else {\n /* istanbul ignore if */\n if ( true && type === 'component') {\n validateComponentName(id);\n }\n if (type === 'component' && isPlainObject(definition)) {\n definition.name = definition.name || id;\n definition = this.options._base.extend(definition);\n }\n if (type === 'directive' && typeof definition === 'function') {\n definition = { bind: definition, update: definition };\n }\n this.options[type + 's'][id] = definition;\n return definition\n }\n };\n });\n}\n\n/* */\n\n\n\nfunction getComponentName (opts) {\n return opts && (opts.Ctor.options.name || opts.tag)\n}\n\nfunction matches (pattern, name) {\n if (Array.isArray(pattern)) {\n return pattern.indexOf(name) > -1\n } else if (typeof pattern === 'string') {\n return pattern.split(',').indexOf(name) > -1\n } else if (isRegExp(pattern)) {\n return pattern.test(name)\n }\n /* istanbul ignore next */\n return false\n}\n\nfunction pruneCache (keepAliveInstance, filter) {\n var cache = keepAliveInstance.cache;\n var keys = keepAliveInstance.keys;\n var _vnode = keepAliveInstance._vnode;\n for (var key in cache) {\n var cachedNode = cache[key];\n if (cachedNode) {\n var name = getComponentName(cachedNode.componentOptions);\n if (name && !filter(name)) {\n pruneCacheEntry(cache, key, keys, _vnode);\n }\n }\n }\n}\n\nfunction pruneCacheEntry (\n cache,\n key,\n keys,\n current\n) {\n var cached$$1 = cache[key];\n if (cached$$1 && (!current || cached$$1.tag !== current.tag)) {\n cached$$1.componentInstance.$destroy();\n }\n cache[key] = null;\n remove(keys, key);\n}\n\nvar patternTypes = [String, RegExp, Array];\n\nvar KeepAlive = {\n name: 'keep-alive',\n abstract: true,\n\n props: {\n include: patternTypes,\n exclude: patternTypes,\n max: [String, Number]\n },\n\n created: function created () {\n this.cache = Object.create(null);\n this.keys = [];\n },\n\n destroyed: function destroyed () {\n for (var key in this.cache) {\n pruneCacheEntry(this.cache, key, this.keys);\n }\n },\n\n mounted: function mounted () {\n var this$1 = this;\n\n this.$watch('include', function (val) {\n pruneCache(this$1, function (name) { return matches(val, name); });\n });\n this.$watch('exclude', function (val) {\n pruneCache(this$1, function (name) { return !matches(val, name); });\n });\n },\n\n render: function render () {\n var slot = this.$slots.default;\n var vnode = getFirstComponentChild(slot);\n var componentOptions = vnode && vnode.componentOptions;\n if (componentOptions) {\n // check pattern\n var name = getComponentName(componentOptions);\n var ref = this;\n var include = ref.include;\n var exclude = ref.exclude;\n if (\n // not included\n (include && (!name || !matches(include, name))) ||\n // excluded\n (exclude && name && matches(exclude, name))\n ) {\n return vnode\n }\n\n var ref$1 = this;\n var cache = ref$1.cache;\n var keys = ref$1.keys;\n var key = vnode.key == null\n // same constructor may get registered as different local components\n // so cid alone is not enough (#3269)\n ? componentOptions.Ctor.cid + (componentOptions.tag ? (\"::\" + (componentOptions.tag)) : '')\n : vnode.key;\n if (cache[key]) {\n vnode.componentInstance = cache[key].componentInstance;\n // make current key freshest\n remove(keys, key);\n keys.push(key);\n } else {\n cache[key] = vnode;\n keys.push(key);\n // prune oldest entry\n if (this.max && keys.length > parseInt(this.max)) {\n pruneCacheEntry(cache, keys[0], keys, this._vnode);\n }\n }\n\n vnode.data.keepAlive = true;\n }\n return vnode || (slot && slot[0])\n }\n};\n\nvar builtInComponents = {\n KeepAlive: KeepAlive\n};\n\n/* */\n\nfunction initGlobalAPI (Vue) {\n // config\n var configDef = {};\n configDef.get = function () { return config; };\n if (true) {\n configDef.set = function () {\n warn(\n 'Do not replace the Vue.config object, set individual fields instead.'\n );\n };\n }\n Object.defineProperty(Vue, 'config', configDef);\n\n // exposed util methods.\n // NOTE: these are not considered part of the public API - avoid relying on\n // them unless you are aware of the risk.\n Vue.util = {\n warn: warn,\n extend: extend,\n mergeOptions: mergeOptions,\n defineReactive: defineReactive$$1\n };\n\n Vue.set = set;\n Vue.delete = del;\n Vue.nextTick = nextTick;\n\n // 2.6 explicit observable API\n Vue.observable = function (obj) {\n observe(obj);\n return obj\n };\n\n Vue.options = Object.create(null);\n ASSET_TYPES.forEach(function (type) {\n Vue.options[type + 's'] = Object.create(null);\n });\n\n // this is used to identify the \"base\" constructor to extend all plain-object\n // components with in Weex's multi-instance scenarios.\n Vue.options._base = Vue;\n\n extend(Vue.options.components, builtInComponents);\n\n initUse(Vue);\n initMixin$1(Vue);\n initExtend(Vue);\n initAssetRegisters(Vue);\n}\n\ninitGlobalAPI(Vue);\n\nObject.defineProperty(Vue.prototype, '$isServer', {\n get: isServerRendering\n});\n\nObject.defineProperty(Vue.prototype, '$ssrContext', {\n get: function get () {\n /* istanbul ignore next */\n return this.$vnode && this.$vnode.ssrContext\n }\n});\n\n// expose FunctionalRenderContext for ssr runtime helper installation\nObject.defineProperty(Vue, 'FunctionalRenderContext', {\n value: FunctionalRenderContext\n});\n\nVue.version = '2.6.11';\n\n/* */\n\n// these are reserved for web because they are directly compiled away\n// during template compilation\nvar isReservedAttr = makeMap('style,class');\n\n// attributes that should be using props for binding\nvar acceptValue = makeMap('input,textarea,option,select,progress');\nvar mustUseProp = function (tag, type, attr) {\n return (\n (attr === 'value' && acceptValue(tag)) && type !== 'button' ||\n (attr === 'selected' && tag === 'option') ||\n (attr === 'checked' && tag === 'input') ||\n (attr === 'muted' && tag === 'video')\n )\n};\n\nvar isEnumeratedAttr = makeMap('contenteditable,draggable,spellcheck');\n\nvar isValidContentEditableValue = makeMap('events,caret,typing,plaintext-only');\n\nvar convertEnumeratedValue = function (key, value) {\n return isFalsyAttrValue(value) || value === 'false'\n ? 'false'\n // allow arbitrary string value for contenteditable\n : key === 'contenteditable' && isValidContentEditableValue(value)\n ? value\n : 'true'\n};\n\nvar isBooleanAttr = makeMap(\n 'allowfullscreen,async,autofocus,autoplay,checked,compact,controls,declare,' +\n 'default,defaultchecked,defaultmuted,defaultselected,defer,disabled,' +\n 'enabled,formnovalidate,hidden,indeterminate,inert,ismap,itemscope,loop,multiple,' +\n 'muted,nohref,noresize,noshade,novalidate,nowrap,open,pauseonexit,readonly,' +\n 'required,reversed,scoped,seamless,selected,sortable,translate,' +\n 'truespeed,typemustmatch,visible'\n);\n\nvar xlinkNS = 'http://www.w3.org/1999/xlink';\n\nvar isXlink = function (name) {\n return name.charAt(5) === ':' && name.slice(0, 5) === 'xlink'\n};\n\nvar getXlinkProp = function (name) {\n return isXlink(name) ? name.slice(6, name.length) : ''\n};\n\nvar isFalsyAttrValue = function (val) {\n return val == null || val === false\n};\n\n/* */\n\nfunction genClassForVnode (vnode) {\n var data = vnode.data;\n var parentNode = vnode;\n var childNode = vnode;\n while (isDef(childNode.componentInstance)) {\n childNode = childNode.componentInstance._vnode;\n if (childNode && childNode.data) {\n data = mergeClassData(childNode.data, data);\n }\n }\n while (isDef(parentNode = parentNode.parent)) {\n if (parentNode && parentNode.data) {\n data = mergeClassData(data, parentNode.data);\n }\n }\n return renderClass(data.staticClass, data.class)\n}\n\nfunction mergeClassData (child, parent) {\n return {\n staticClass: concat(child.staticClass, parent.staticClass),\n class: isDef(child.class)\n ? [child.class, parent.class]\n : parent.class\n }\n}\n\nfunction renderClass (\n staticClass,\n dynamicClass\n) {\n if (isDef(staticClass) || isDef(dynamicClass)) {\n return concat(staticClass, stringifyClass(dynamicClass))\n }\n /* istanbul ignore next */\n return ''\n}\n\nfunction concat (a, b) {\n return a ? b ? (a + ' ' + b) : a : (b || '')\n}\n\nfunction stringifyClass (value) {\n if (Array.isArray(value)) {\n return stringifyArray(value)\n }\n if (isObject(value)) {\n return stringifyObject(value)\n }\n if (typeof value === 'string') {\n return value\n }\n /* istanbul ignore next */\n return ''\n}\n\nfunction stringifyArray (value) {\n var res = '';\n var stringified;\n for (var i = 0, l = value.length; i < l; i++) {\n if (isDef(stringified = stringifyClass(value[i])) && stringified !== '') {\n if (res) { res += ' '; }\n res += stringified;\n }\n }\n return res\n}\n\nfunction stringifyObject (value) {\n var res = '';\n for (var key in value) {\n if (value[key]) {\n if (res) { res += ' '; }\n res += key;\n }\n }\n return res\n}\n\n/* */\n\nvar namespaceMap = {\n svg: 'http://www.w3.org/2000/svg',\n math: 'http://www.w3.org/1998/Math/MathML'\n};\n\nvar isHTMLTag = makeMap(\n 'html,body,base,head,link,meta,style,title,' +\n 'address,article,aside,footer,header,h1,h2,h3,h4,h5,h6,hgroup,nav,section,' +\n 'div,dd,dl,dt,figcaption,figure,picture,hr,img,li,main,ol,p,pre,ul,' +\n 'a,b,abbr,bdi,bdo,br,cite,code,data,dfn,em,i,kbd,mark,q,rp,rt,rtc,ruby,' +\n 's,samp,small,span,strong,sub,sup,time,u,var,wbr,area,audio,map,track,video,' +\n 'embed,object,param,source,canvas,script,noscript,del,ins,' +\n 'caption,col,colgroup,table,thead,tbody,td,th,tr,' +\n 'button,datalist,fieldset,form,input,label,legend,meter,optgroup,option,' +\n 'output,progress,select,textarea,' +\n 'details,dialog,menu,menuitem,summary,' +\n 'content,element,shadow,template,blockquote,iframe,tfoot'\n);\n\n// this map is intentionally selective, only covering SVG elements that may\n// contain child elements.\nvar isSVG = makeMap(\n 'svg,animate,circle,clippath,cursor,defs,desc,ellipse,filter,font-face,' +\n 'foreignObject,g,glyph,image,line,marker,mask,missing-glyph,path,pattern,' +\n 'polygon,polyline,rect,switch,symbol,text,textpath,tspan,use,view',\n true\n);\n\nvar isPreTag = function (tag) { return tag === 'pre'; };\n\nvar isReservedTag = function (tag) {\n return isHTMLTag(tag) || isSVG(tag)\n};\n\nfunction getTagNamespace (tag) {\n if (isSVG(tag)) {\n return 'svg'\n }\n // basic support for MathML\n // note it doesn't support other MathML elements being component roots\n if (tag === 'math') {\n return 'math'\n }\n}\n\nvar unknownElementCache = Object.create(null);\nfunction isUnknownElement (tag) {\n /* istanbul ignore if */\n if (!inBrowser) {\n return true\n }\n if (isReservedTag(tag)) {\n return false\n }\n tag = tag.toLowerCase();\n /* istanbul ignore if */\n if (unknownElementCache[tag] != null) {\n return unknownElementCache[tag]\n }\n var el = document.createElement(tag);\n if (tag.indexOf('-') > -1) {\n // http://stackoverflow.com/a/28210364/1070244\n return (unknownElementCache[tag] = (\n el.constructor === window.HTMLUnknownElement ||\n el.constructor === window.HTMLElement\n ))\n } else {\n return (unknownElementCache[tag] = /HTMLUnknownElement/.test(el.toString()))\n }\n}\n\nvar isTextInputType = makeMap('text,number,password,search,email,tel,url');\n\n/* */\n\n/**\n * Query an element selector if it's not an element already.\n */\nfunction query (el) {\n if (typeof el === 'string') {\n var selected = document.querySelector(el);\n if (!selected) {\n true && warn(\n 'Cannot find element: ' + el\n );\n return document.createElement('div')\n }\n return selected\n } else {\n return el\n }\n}\n\n/* */\n\nfunction createElement$1 (tagName, vnode) {\n var elm = document.createElement(tagName);\n if (tagName !== 'select') {\n return elm\n }\n // false or null will remove the attribute but undefined will not\n if (vnode.data && vnode.data.attrs && vnode.data.attrs.multiple !== undefined) {\n elm.setAttribute('multiple', 'multiple');\n }\n return elm\n}\n\nfunction createElementNS (namespace, tagName) {\n return document.createElementNS(namespaceMap[namespace], tagName)\n}\n\nfunction createTextNode (text) {\n return document.createTextNode(text)\n}\n\nfunction createComment (text) {\n return document.createComment(text)\n}\n\nfunction insertBefore (parentNode, newNode, referenceNode) {\n parentNode.insertBefore(newNode, referenceNode);\n}\n\nfunction removeChild (node, child) {\n node.removeChild(child);\n}\n\nfunction appendChild (node, child) {\n node.appendChild(child);\n}\n\nfunction parentNode (node) {\n return node.parentNode\n}\n\nfunction nextSibling (node) {\n return node.nextSibling\n}\n\nfunction tagName (node) {\n return node.tagName\n}\n\nfunction setTextContent (node, text) {\n node.textContent = text;\n}\n\nfunction setStyleScope (node, scopeId) {\n node.setAttribute(scopeId, '');\n}\n\nvar nodeOps = /*#__PURE__*/Object.freeze({\n createElement: createElement$1,\n createElementNS: createElementNS,\n createTextNode: createTextNode,\n createComment: createComment,\n insertBefore: insertBefore,\n removeChild: removeChild,\n appendChild: appendChild,\n parentNode: parentNode,\n nextSibling: nextSibling,\n tagName: tagName,\n setTextContent: setTextContent,\n setStyleScope: setStyleScope\n});\n\n/* */\n\nvar ref = {\n create: function create (_, vnode) {\n registerRef(vnode);\n },\n update: function update (oldVnode, vnode) {\n if (oldVnode.data.ref !== vnode.data.ref) {\n registerRef(oldVnode, true);\n registerRef(vnode);\n }\n },\n destroy: function destroy (vnode) {\n registerRef(vnode, true);\n }\n};\n\nfunction registerRef (vnode, isRemoval) {\n var key = vnode.data.ref;\n if (!isDef(key)) { return }\n\n var vm = vnode.context;\n var ref = vnode.componentInstance || vnode.elm;\n var refs = vm.$refs;\n if (isRemoval) {\n if (Array.isArray(refs[key])) {\n remove(refs[key], ref);\n } else if (refs[key] === ref) {\n refs[key] = undefined;\n }\n } else {\n if (vnode.data.refInFor) {\n if (!Array.isArray(refs[key])) {\n refs[key] = [ref];\n } else if (refs[key].indexOf(ref) < 0) {\n // $flow-disable-line\n refs[key].push(ref);\n }\n } else {\n refs[key] = ref;\n }\n }\n}\n\n/**\n * Virtual DOM patching algorithm based on Snabbdom by\n * Simon Friis Vindum (@paldepind)\n * Licensed under the MIT License\n * https://github.com/paldepind/snabbdom/blob/master/LICENSE\n *\n * modified by Evan You (@yyx990803)\n *\n * Not type-checking this because this file is perf-critical and the cost\n * of making flow understand it is not worth it.\n */\n\nvar emptyNode = new VNode('', {}, []);\n\nvar hooks = ['create', 'activate', 'update', 'remove', 'destroy'];\n\nfunction sameVnode (a, b) {\n return (\n a.key === b.key && (\n (\n a.tag === b.tag &&\n a.isComment === b.isComment &&\n isDef(a.data) === isDef(b.data) &&\n sameInputType(a, b)\n ) || (\n isTrue(a.isAsyncPlaceholder) &&\n a.asyncFactory === b.asyncFactory &&\n isUndef(b.asyncFactory.error)\n )\n )\n )\n}\n\nfunction sameInputType (a, b) {\n if (a.tag !== 'input') { return true }\n var i;\n var typeA = isDef(i = a.data) && isDef(i = i.attrs) && i.type;\n var typeB = isDef(i = b.data) && isDef(i = i.attrs) && i.type;\n return typeA === typeB || isTextInputType(typeA) && isTextInputType(typeB)\n}\n\nfunction createKeyToOldIdx (children, beginIdx, endIdx) {\n var i, key;\n var map = {};\n for (i = beginIdx; i <= endIdx; ++i) {\n key = children[i].key;\n if (isDef(key)) { map[key] = i; }\n }\n return map\n}\n\nfunction createPatchFunction (backend) {\n var i, j;\n var cbs = {};\n\n var modules = backend.modules;\n var nodeOps = backend.nodeOps;\n\n for (i = 0; i < hooks.length; ++i) {\n cbs[hooks[i]] = [];\n for (j = 0; j < modules.length; ++j) {\n if (isDef(modules[j][hooks[i]])) {\n cbs[hooks[i]].push(modules[j][hooks[i]]);\n }\n }\n }\n\n function emptyNodeAt (elm) {\n return new VNode(nodeOps.tagName(elm).toLowerCase(), {}, [], undefined, elm)\n }\n\n function createRmCb (childElm, listeners) {\n function remove$$1 () {\n if (--remove$$1.listeners === 0) {\n removeNode(childElm);\n }\n }\n remove$$1.listeners = listeners;\n return remove$$1\n }\n\n function removeNode (el) {\n var parent = nodeOps.parentNode(el);\n // element may have already been removed due to v-html / v-text\n if (isDef(parent)) {\n nodeOps.removeChild(parent, el);\n }\n }\n\n function isUnknownElement$$1 (vnode, inVPre) {\n return (\n !inVPre &&\n !vnode.ns &&\n !(\n config.ignoredElements.length &&\n config.ignoredElements.some(function (ignore) {\n return isRegExp(ignore)\n ? ignore.test(vnode.tag)\n : ignore === vnode.tag\n })\n ) &&\n config.isUnknownElement(vnode.tag)\n )\n }\n\n var creatingElmInVPre = 0;\n\n function createElm (\n vnode,\n insertedVnodeQueue,\n parentElm,\n refElm,\n nested,\n ownerArray,\n index\n ) {\n if (isDef(vnode.elm) && isDef(ownerArray)) {\n // This vnode was used in a previous render!\n // now it's used as a new node, overwriting its elm would cause\n // potential patch errors down the road when it's used as an insertion\n // reference node. Instead, we clone the node on-demand before creating\n // associated DOM element for it.\n vnode = ownerArray[index] = cloneVNode(vnode);\n }\n\n vnode.isRootInsert = !nested; // for transition enter check\n if (createComponent(vnode, insertedVnodeQueue, parentElm, refElm)) {\n return\n }\n\n var data = vnode.data;\n var children = vnode.children;\n var tag = vnode.tag;\n if (isDef(tag)) {\n if (true) {\n if (data && data.pre) {\n creatingElmInVPre++;\n }\n if (isUnknownElement$$1(vnode, creatingElmInVPre)) {\n warn(\n 'Unknown custom element: <' + tag + '> - did you ' +\n 'register the component correctly? For recursive components, ' +\n 'make sure to provide the \"name\" option.',\n vnode.context\n );\n }\n }\n\n vnode.elm = vnode.ns\n ? nodeOps.createElementNS(vnode.ns, tag)\n : nodeOps.createElement(tag, vnode);\n setScope(vnode);\n\n /* istanbul ignore if */\n {\n createChildren(vnode, children, insertedVnodeQueue);\n if (isDef(data)) {\n invokeCreateHooks(vnode, insertedVnodeQueue);\n }\n insert(parentElm, vnode.elm, refElm);\n }\n\n if ( true && data && data.pre) {\n creatingElmInVPre--;\n }\n } else if (isTrue(vnode.isComment)) {\n vnode.elm = nodeOps.createComment(vnode.text);\n insert(parentElm, vnode.elm, refElm);\n } else {\n vnode.elm = nodeOps.createTextNode(vnode.text);\n insert(parentElm, vnode.elm, refElm);\n }\n }\n\n function createComponent (vnode, insertedVnodeQueue, parentElm, refElm) {\n var i = vnode.data;\n if (isDef(i)) {\n var isReactivated = isDef(vnode.componentInstance) && i.keepAlive;\n if (isDef(i = i.hook) && isDef(i = i.init)) {\n i(vnode, false /* hydrating */);\n }\n // after calling the init hook, if the vnode is a child component\n // it should've created a child instance and mounted it. the child\n // component also has set the placeholder vnode's elm.\n // in that case we can just return the element and be done.\n if (isDef(vnode.componentInstance)) {\n initComponent(vnode, insertedVnodeQueue);\n insert(parentElm, vnode.elm, refElm);\n if (isTrue(isReactivated)) {\n reactivateComponent(vnode, insertedVnodeQueue, parentElm, refElm);\n }\n return true\n }\n }\n }\n\n function initComponent (vnode, insertedVnodeQueue) {\n if (isDef(vnode.data.pendingInsert)) {\n insertedVnodeQueue.push.apply(insertedVnodeQueue, vnode.data.pendingInsert);\n vnode.data.pendingInsert = null;\n }\n vnode.elm = vnode.componentInstance.$el;\n if (isPatchable(vnode)) {\n invokeCreateHooks(vnode, insertedVnodeQueue);\n setScope(vnode);\n } else {\n // empty component root.\n // skip all element-related modules except for ref (#3455)\n registerRef(vnode);\n // make sure to invoke the insert hook\n insertedVnodeQueue.push(vnode);\n }\n }\n\n function reactivateComponent (vnode, insertedVnodeQueue, parentElm, refElm) {\n var i;\n // hack for #4339: a reactivated component with inner transition\n // does not trigger because the inner node's created hooks are not called\n // again. It's not ideal to involve module-specific logic in here but\n // there doesn't seem to be a better way to do it.\n var innerNode = vnode;\n while (innerNode.componentInstance) {\n innerNode = innerNode.componentInstance._vnode;\n if (isDef(i = innerNode.data) && isDef(i = i.transition)) {\n for (i = 0; i < cbs.activate.length; ++i) {\n cbs.activate[i](emptyNode, innerNode);\n }\n insertedVnodeQueue.push(innerNode);\n break\n }\n }\n // unlike a newly created component,\n // a reactivated keep-alive component doesn't insert itself\n insert(parentElm, vnode.elm, refElm);\n }\n\n function insert (parent, elm, ref$$1) {\n if (isDef(parent)) {\n if (isDef(ref$$1)) {\n if (nodeOps.parentNode(ref$$1) === parent) {\n nodeOps.insertBefore(parent, elm, ref$$1);\n }\n } else {\n nodeOps.appendChild(parent, elm);\n }\n }\n }\n\n function createChildren (vnode, children, insertedVnodeQueue) {\n if (Array.isArray(children)) {\n if (true) {\n checkDuplicateKeys(children);\n }\n for (var i = 0; i < children.length; ++i) {\n createElm(children[i], insertedVnodeQueue, vnode.elm, null, true, children, i);\n }\n } else if (isPrimitive(vnode.text)) {\n nodeOps.appendChild(vnode.elm, nodeOps.createTextNode(String(vnode.text)));\n }\n }\n\n function isPatchable (vnode) {\n while (vnode.componentInstance) {\n vnode = vnode.componentInstance._vnode;\n }\n return isDef(vnode.tag)\n }\n\n function invokeCreateHooks (vnode, insertedVnodeQueue) {\n for (var i$1 = 0; i$1 < cbs.create.length; ++i$1) {\n cbs.create[i$1](emptyNode, vnode);\n }\n i = vnode.data.hook; // Reuse variable\n if (isDef(i)) {\n if (isDef(i.create)) { i.create(emptyNode, vnode); }\n if (isDef(i.insert)) { insertedVnodeQueue.push(vnode); }\n }\n }\n\n // set scope id attribute for scoped CSS.\n // this is implemented as a special case to avoid the overhead\n // of going through the normal attribute patching process.\n function setScope (vnode) {\n var i;\n if (isDef(i = vnode.fnScopeId)) {\n nodeOps.setStyleScope(vnode.elm, i);\n } else {\n var ancestor = vnode;\n while (ancestor) {\n if (isDef(i = ancestor.context) && isDef(i = i.$options._scopeId)) {\n nodeOps.setStyleScope(vnode.elm, i);\n }\n ancestor = ancestor.parent;\n }\n }\n // for slot content they should also get the scopeId from the host instance.\n if (isDef(i = activeInstance) &&\n i !== vnode.context &&\n i !== vnode.fnContext &&\n isDef(i = i.$options._scopeId)\n ) {\n nodeOps.setStyleScope(vnode.elm, i);\n }\n }\n\n function addVnodes (parentElm, refElm, vnodes, startIdx, endIdx, insertedVnodeQueue) {\n for (; startIdx <= endIdx; ++startIdx) {\n createElm(vnodes[startIdx], insertedVnodeQueue, parentElm, refElm, false, vnodes, startIdx);\n }\n }\n\n function invokeDestroyHook (vnode) {\n var i, j;\n var data = vnode.data;\n if (isDef(data)) {\n if (isDef(i = data.hook) && isDef(i = i.destroy)) { i(vnode); }\n for (i = 0; i < cbs.destroy.length; ++i) { cbs.destroy[i](vnode); }\n }\n if (isDef(i = vnode.children)) {\n for (j = 0; j < vnode.children.length; ++j) {\n invokeDestroyHook(vnode.children[j]);\n }\n }\n }\n\n function removeVnodes (vnodes, startIdx, endIdx) {\n for (; startIdx <= endIdx; ++startIdx) {\n var ch = vnodes[startIdx];\n if (isDef(ch)) {\n if (isDef(ch.tag)) {\n removeAndInvokeRemoveHook(ch);\n invokeDestroyHook(ch);\n } else { // Text node\n removeNode(ch.elm);\n }\n }\n }\n }\n\n function removeAndInvokeRemoveHook (vnode, rm) {\n if (isDef(rm) || isDef(vnode.data)) {\n var i;\n var listeners = cbs.remove.length + 1;\n if (isDef(rm)) {\n // we have a recursively passed down rm callback\n // increase the listeners count\n rm.listeners += listeners;\n } else {\n // directly removing\n rm = createRmCb(vnode.elm, listeners);\n }\n // recursively invoke hooks on child component root node\n if (isDef(i = vnode.componentInstance) && isDef(i = i._vnode) && isDef(i.data)) {\n removeAndInvokeRemoveHook(i, rm);\n }\n for (i = 0; i < cbs.remove.length; ++i) {\n cbs.remove[i](vnode, rm);\n }\n if (isDef(i = vnode.data.hook) && isDef(i = i.remove)) {\n i(vnode, rm);\n } else {\n rm();\n }\n } else {\n removeNode(vnode.elm);\n }\n }\n\n function updateChildren (parentElm, oldCh, newCh, insertedVnodeQueue, removeOnly) {\n var oldStartIdx = 0;\n var newStartIdx = 0;\n var oldEndIdx = oldCh.length - 1;\n var oldStartVnode = oldCh[0];\n var oldEndVnode = oldCh[oldEndIdx];\n var newEndIdx = newCh.length - 1;\n var newStartVnode = newCh[0];\n var newEndVnode = newCh[newEndIdx];\n var oldKeyToIdx, idxInOld, vnodeToMove, refElm;\n\n // removeOnly is a special flag used only by <transition-group>\n // to ensure removed elements stay in correct relative positions\n // during leaving transitions\n var canMove = !removeOnly;\n\n if (true) {\n checkDuplicateKeys(newCh);\n }\n\n while (oldStartIdx <= oldEndIdx && newStartIdx <= newEndIdx) {\n if (isUndef(oldStartVnode)) {\n oldStartVnode = oldCh[++oldStartIdx]; // Vnode has been moved left\n } else if (isUndef(oldEndVnode)) {\n oldEndVnode = oldCh[--oldEndIdx];\n } else if (sameVnode(oldStartVnode, newStartVnode)) {\n patchVnode(oldStartVnode, newStartVnode, insertedVnodeQueue, newCh, newStartIdx);\n oldStartVnode = oldCh[++oldStartIdx];\n newStartVnode = newCh[++newStartIdx];\n } else if (sameVnode(oldEndVnode, newEndVnode)) {\n patchVnode(oldEndVnode, newEndVnode, insertedVnodeQueue, newCh, newEndIdx);\n oldEndVnode = oldCh[--oldEndIdx];\n newEndVnode = newCh[--newEndIdx];\n } else if (sameVnode(oldStartVnode, newEndVnode)) { // Vnode moved right\n patchVnode(oldStartVnode, newEndVnode, insertedVnodeQueue, newCh, newEndIdx);\n canMove && nodeOps.insertBefore(parentElm, oldStartVnode.elm, nodeOps.nextSibling(oldEndVnode.elm));\n oldStartVnode = oldCh[++oldStartIdx];\n newEndVnode = newCh[--newEndIdx];\n } else if (sameVnode(oldEndVnode, newStartVnode)) { // Vnode moved left\n patchVnode(oldEndVnode, newStartVnode, insertedVnodeQueue, newCh, newStartIdx);\n canMove && nodeOps.insertBefore(parentElm, oldEndVnode.elm, oldStartVnode.elm);\n oldEndVnode = oldCh[--oldEndIdx];\n newStartVnode = newCh[++newStartIdx];\n } else {\n if (isUndef(oldKeyToIdx)) { oldKeyToIdx = createKeyToOldIdx(oldCh, oldStartIdx, oldEndIdx); }\n idxInOld = isDef(newStartVnode.key)\n ? oldKeyToIdx[newStartVnode.key]\n : findIdxInOld(newStartVnode, oldCh, oldStartIdx, oldEndIdx);\n if (isUndef(idxInOld)) { // New element\n createElm(newStartVnode, insertedVnodeQueue, parentElm, oldStartVnode.elm, false, newCh, newStartIdx);\n } else {\n vnodeToMove = oldCh[idxInOld];\n if (sameVnode(vnodeToMove, newStartVnode)) {\n patchVnode(vnodeToMove, newStartVnode, insertedVnodeQueue, newCh, newStartIdx);\n oldCh[idxInOld] = undefined;\n canMove && nodeOps.insertBefore(parentElm, vnodeToMove.elm, oldStartVnode.elm);\n } else {\n // same key but different element. treat as new element\n createElm(newStartVnode, insertedVnodeQueue, parentElm, oldStartVnode.elm, false, newCh, newStartIdx);\n }\n }\n newStartVnode = newCh[++newStartIdx];\n }\n }\n if (oldStartIdx > oldEndIdx) {\n refElm = isUndef(newCh[newEndIdx + 1]) ? null : newCh[newEndIdx + 1].elm;\n addVnodes(parentElm, refElm, newCh, newStartIdx, newEndIdx, insertedVnodeQueue);\n } else if (newStartIdx > newEndIdx) {\n removeVnodes(oldCh, oldStartIdx, oldEndIdx);\n }\n }\n\n function checkDuplicateKeys (children) {\n var seenKeys = {};\n for (var i = 0; i < children.length; i++) {\n var vnode = children[i];\n var key = vnode.key;\n if (isDef(key)) {\n if (seenKeys[key]) {\n warn(\n (\"Duplicate keys detected: '\" + key + \"'. This may cause an update error.\"),\n vnode.context\n );\n } else {\n seenKeys[key] = true;\n }\n }\n }\n }\n\n function findIdxInOld (node, oldCh, start, end) {\n for (var i = start; i < end; i++) {\n var c = oldCh[i];\n if (isDef(c) && sameVnode(node, c)) { return i }\n }\n }\n\n function patchVnode (\n oldVnode,\n vnode,\n insertedVnodeQueue,\n ownerArray,\n index,\n removeOnly\n ) {\n if (oldVnode === vnode) {\n return\n }\n\n if (isDef(vnode.elm) && isDef(ownerArray)) {\n // clone reused vnode\n vnode = ownerArray[index] = cloneVNode(vnode);\n }\n\n var elm = vnode.elm = oldVnode.elm;\n\n if (isTrue(oldVnode.isAsyncPlaceholder)) {\n if (isDef(vnode.asyncFactory.resolved)) {\n hydrate(oldVnode.elm, vnode, insertedVnodeQueue);\n } else {\n vnode.isAsyncPlaceholder = true;\n }\n return\n }\n\n // reuse element for static trees.\n // note we only do this if the vnode is cloned -\n // if the new node is not cloned it means the render functions have been\n // reset by the hot-reload-api and we need to do a proper re-render.\n if (isTrue(vnode.isStatic) &&\n isTrue(oldVnode.isStatic) &&\n vnode.key === oldVnode.key &&\n (isTrue(vnode.isCloned) || isTrue(vnode.isOnce))\n ) {\n vnode.componentInstance = oldVnode.componentInstance;\n return\n }\n\n var i;\n var data = vnode.data;\n if (isDef(data) && isDef(i = data.hook) && isDef(i = i.prepatch)) {\n i(oldVnode, vnode);\n }\n\n var oldCh = oldVnode.children;\n var ch = vnode.children;\n if (isDef(data) && isPatchable(vnode)) {\n for (i = 0; i < cbs.update.length; ++i) { cbs.update[i](oldVnode, vnode); }\n if (isDef(i = data.hook) && isDef(i = i.update)) { i(oldVnode, vnode); }\n }\n if (isUndef(vnode.text)) {\n if (isDef(oldCh) && isDef(ch)) {\n if (oldCh !== ch) { updateChildren(elm, oldCh, ch, insertedVnodeQueue, removeOnly); }\n } else if (isDef(ch)) {\n if (true) {\n checkDuplicateKeys(ch);\n }\n if (isDef(oldVnode.text)) { nodeOps.setTextContent(elm, ''); }\n addVnodes(elm, null, ch, 0, ch.length - 1, insertedVnodeQueue);\n } else if (isDef(oldCh)) {\n removeVnodes(oldCh, 0, oldCh.length - 1);\n } else if (isDef(oldVnode.text)) {\n nodeOps.setTextContent(elm, '');\n }\n } else if (oldVnode.text !== vnode.text) {\n nodeOps.setTextContent(elm, vnode.text);\n }\n if (isDef(data)) {\n if (isDef(i = data.hook) && isDef(i = i.postpatch)) { i(oldVnode, vnode); }\n }\n }\n\n function invokeInsertHook (vnode, queue, initial) {\n // delay insert hooks for component root nodes, invoke them after the\n // element is really inserted\n if (isTrue(initial) && isDef(vnode.parent)) {\n vnode.parent.data.pendingInsert = queue;\n } else {\n for (var i = 0; i < queue.length; ++i) {\n queue[i].data.hook.insert(queue[i]);\n }\n }\n }\n\n var hydrationBailed = false;\n // list of modules that can skip create hook during hydration because they\n // are already rendered on the client or has no need for initialization\n // Note: style is excluded because it relies on initial clone for future\n // deep updates (#7063).\n var isRenderedModule = makeMap('attrs,class,staticClass,staticStyle,key');\n\n // Note: this is a browser-only function so we can assume elms are DOM nodes.\n function hydrate (elm, vnode, insertedVnodeQueue, inVPre) {\n var i;\n var tag = vnode.tag;\n var data = vnode.data;\n var children = vnode.children;\n inVPre = inVPre || (data && data.pre);\n vnode.elm = elm;\n\n if (isTrue(vnode.isComment) && isDef(vnode.asyncFactory)) {\n vnode.isAsyncPlaceholder = true;\n return true\n }\n // assert node match\n if (true) {\n if (!assertNodeMatch(elm, vnode, inVPre)) {\n return false\n }\n }\n if (isDef(data)) {\n if (isDef(i = data.hook) && isDef(i = i.init)) { i(vnode, true /* hydrating */); }\n if (isDef(i = vnode.componentInstance)) {\n // child component. it should have hydrated its own tree.\n initComponent(vnode, insertedVnodeQueue);\n return true\n }\n }\n if (isDef(tag)) {\n if (isDef(children)) {\n // empty element, allow client to pick up and populate children\n if (!elm.hasChildNodes()) {\n createChildren(vnode, children, insertedVnodeQueue);\n } else {\n // v-html and domProps: innerHTML\n if (isDef(i = data) && isDef(i = i.domProps) && isDef(i = i.innerHTML)) {\n if (i !== elm.innerHTML) {\n /* istanbul ignore if */\n if ( true &&\n typeof console !== 'undefined' &&\n !hydrationBailed\n ) {\n hydrationBailed = true;\n console.warn('Parent: ', elm);\n console.warn('server innerHTML: ', i);\n console.warn('client innerHTML: ', elm.innerHTML);\n }\n return false\n }\n } else {\n // iterate and compare children lists\n var childrenMatch = true;\n var childNode = elm.firstChild;\n for (var i$1 = 0; i$1 < children.length; i$1++) {\n if (!childNode || !hydrate(childNode, children[i$1], insertedVnodeQueue, inVPre)) {\n childrenMatch = false;\n break\n }\n childNode = childNode.nextSibling;\n }\n // if childNode is not null, it means the actual childNodes list is\n // longer than the virtual children list.\n if (!childrenMatch || childNode) {\n /* istanbul ignore if */\n if ( true &&\n typeof console !== 'undefined' &&\n !hydrationBailed\n ) {\n hydrationBailed = true;\n console.warn('Parent: ', elm);\n console.warn('Mismatching childNodes vs. VNodes: ', elm.childNodes, children);\n }\n return false\n }\n }\n }\n }\n if (isDef(data)) {\n var fullInvoke = false;\n for (var key in data) {\n if (!isRenderedModule(key)) {\n fullInvoke = true;\n invokeCreateHooks(vnode, insertedVnodeQueue);\n break\n }\n }\n if (!fullInvoke && data['class']) {\n // ensure collecting deps for deep class bindings for future updates\n traverse(data['class']);\n }\n }\n } else if (elm.data !== vnode.text) {\n elm.data = vnode.text;\n }\n return true\n }\n\n function assertNodeMatch (node, vnode, inVPre) {\n if (isDef(vnode.tag)) {\n return vnode.tag.indexOf('vue-component') === 0 || (\n !isUnknownElement$$1(vnode, inVPre) &&\n vnode.tag.toLowerCase() === (node.tagName && node.tagName.toLowerCase())\n )\n } else {\n return node.nodeType === (vnode.isComment ? 8 : 3)\n }\n }\n\n return function patch (oldVnode, vnode, hydrating, removeOnly) {\n if (isUndef(vnode)) {\n if (isDef(oldVnode)) { invokeDestroyHook(oldVnode); }\n return\n }\n\n var isInitialPatch = false;\n var insertedVnodeQueue = [];\n\n if (isUndef(oldVnode)) {\n // empty mount (likely as component), create new root element\n isInitialPatch = true;\n createElm(vnode, insertedVnodeQueue);\n } else {\n var isRealElement = isDef(oldVnode.nodeType);\n if (!isRealElement && sameVnode(oldVnode, vnode)) {\n // patch existing root node\n patchVnode(oldVnode, vnode, insertedVnodeQueue, null, null, removeOnly);\n } else {\n if (isRealElement) {\n // mounting to a real element\n // check if this is server-rendered content and if we can perform\n // a successful hydration.\n if (oldVnode.nodeType === 1 && oldVnode.hasAttribute(SSR_ATTR)) {\n oldVnode.removeAttribute(SSR_ATTR);\n hydrating = true;\n }\n if (isTrue(hydrating)) {\n if (hydrate(oldVnode, vnode, insertedVnodeQueue)) {\n invokeInsertHook(vnode, insertedVnodeQueue, true);\n return oldVnode\n } else if (true) {\n warn(\n 'The client-side rendered virtual DOM tree is not matching ' +\n 'server-rendered content. This is likely caused by incorrect ' +\n 'HTML markup, for example nesting block-level elements inside ' +\n '<p>, or missing <tbody>. Bailing hydration and performing ' +\n 'full client-side render.'\n );\n }\n }\n // either not server-rendered, or hydration failed.\n // create an empty node and replace it\n oldVnode = emptyNodeAt(oldVnode);\n }\n\n // replacing existing element\n var oldElm = oldVnode.elm;\n var parentElm = nodeOps.parentNode(oldElm);\n\n // create new node\n createElm(\n vnode,\n insertedVnodeQueue,\n // extremely rare edge case: do not insert if old element is in a\n // leaving transition. Only happens when combining transition +\n // keep-alive + HOCs. (#4590)\n oldElm._leaveCb ? null : parentElm,\n nodeOps.nextSibling(oldElm)\n );\n\n // update parent placeholder node element, recursively\n if (isDef(vnode.parent)) {\n var ancestor = vnode.parent;\n var patchable = isPatchable(vnode);\n while (ancestor) {\n for (var i = 0; i < cbs.destroy.length; ++i) {\n cbs.destroy[i](ancestor);\n }\n ancestor.elm = vnode.elm;\n if (patchable) {\n for (var i$1 = 0; i$1 < cbs.create.length; ++i$1) {\n cbs.create[i$1](emptyNode, ancestor);\n }\n // #6513\n // invoke insert hooks that may have been merged by create hooks.\n // e.g. for directives that uses the \"inserted\" hook.\n var insert = ancestor.data.hook.insert;\n if (insert.merged) {\n // start at index 1 to avoid re-invoking component mounted hook\n for (var i$2 = 1; i$2 < insert.fns.length; i$2++) {\n insert.fns[i$2]();\n }\n }\n } else {\n registerRef(ancestor);\n }\n ancestor = ancestor.parent;\n }\n }\n\n // destroy old node\n if (isDef(parentElm)) {\n removeVnodes([oldVnode], 0, 0);\n } else if (isDef(oldVnode.tag)) {\n invokeDestroyHook(oldVnode);\n }\n }\n }\n\n invokeInsertHook(vnode, insertedVnodeQueue, isInitialPatch);\n return vnode.elm\n }\n}\n\n/* */\n\nvar directives = {\n create: updateDirectives,\n update: updateDirectives,\n destroy: function unbindDirectives (vnode) {\n updateDirectives(vnode, emptyNode);\n }\n};\n\nfunction updateDirectives (oldVnode, vnode) {\n if (oldVnode.data.directives || vnode.data.directives) {\n _update(oldVnode, vnode);\n }\n}\n\nfunction _update (oldVnode, vnode) {\n var isCreate = oldVnode === emptyNode;\n var isDestroy = vnode === emptyNode;\n var oldDirs = normalizeDirectives$1(oldVnode.data.directives, oldVnode.context);\n var newDirs = normalizeDirectives$1(vnode.data.directives, vnode.context);\n\n var dirsWithInsert = [];\n var dirsWithPostpatch = [];\n\n var key, oldDir, dir;\n for (key in newDirs) {\n oldDir = oldDirs[key];\n dir = newDirs[key];\n if (!oldDir) {\n // new directive, bind\n callHook$1(dir, 'bind', vnode, oldVnode);\n if (dir.def && dir.def.inserted) {\n dirsWithInsert.push(dir);\n }\n } else {\n // existing directive, update\n dir.oldValue = oldDir.value;\n dir.oldArg = oldDir.arg;\n callHook$1(dir, 'update', vnode, oldVnode);\n if (dir.def && dir.def.componentUpdated) {\n dirsWithPostpatch.push(dir);\n }\n }\n }\n\n if (dirsWithInsert.length) {\n var callInsert = function () {\n for (var i = 0; i < dirsWithInsert.length; i++) {\n callHook$1(dirsWithInsert[i], 'inserted', vnode, oldVnode);\n }\n };\n if (isCreate) {\n mergeVNodeHook(vnode, 'insert', callInsert);\n } else {\n callInsert();\n }\n }\n\n if (dirsWithPostpatch.length) {\n mergeVNodeHook(vnode, 'postpatch', function () {\n for (var i = 0; i < dirsWithPostpatch.length; i++) {\n callHook$1(dirsWithPostpatch[i], 'componentUpdated', vnode, oldVnode);\n }\n });\n }\n\n if (!isCreate) {\n for (key in oldDirs) {\n if (!newDirs[key]) {\n // no longer present, unbind\n callHook$1(oldDirs[key], 'unbind', oldVnode, oldVnode, isDestroy);\n }\n }\n }\n}\n\nvar emptyModifiers = Object.create(null);\n\nfunction normalizeDirectives$1 (\n dirs,\n vm\n) {\n var res = Object.create(null);\n if (!dirs) {\n // $flow-disable-line\n return res\n }\n var i, dir;\n for (i = 0; i < dirs.length; i++) {\n dir = dirs[i];\n if (!dir.modifiers) {\n // $flow-disable-line\n dir.modifiers = emptyModifiers;\n }\n res[getRawDirName(dir)] = dir;\n dir.def = resolveAsset(vm.$options, 'directives', dir.name, true);\n }\n // $flow-disable-line\n return res\n}\n\nfunction getRawDirName (dir) {\n return dir.rawName || ((dir.name) + \".\" + (Object.keys(dir.modifiers || {}).join('.')))\n}\n\nfunction callHook$1 (dir, hook, vnode, oldVnode, isDestroy) {\n var fn = dir.def && dir.def[hook];\n if (fn) {\n try {\n fn(vnode.elm, dir, vnode, oldVnode, isDestroy);\n } catch (e) {\n handleError(e, vnode.context, (\"directive \" + (dir.name) + \" \" + hook + \" hook\"));\n }\n }\n}\n\nvar baseModules = [\n ref,\n directives\n];\n\n/* */\n\nfunction updateAttrs (oldVnode, vnode) {\n var opts = vnode.componentOptions;\n if (isDef(opts) && opts.Ctor.options.inheritAttrs === false) {\n return\n }\n if (isUndef(oldVnode.data.attrs) && isUndef(vnode.data.attrs)) {\n return\n }\n var key, cur, old;\n var elm = vnode.elm;\n var oldAttrs = oldVnode.data.attrs || {};\n var attrs = vnode.data.attrs || {};\n // clone observed objects, as the user probably wants to mutate it\n if (isDef(attrs.__ob__)) {\n attrs = vnode.data.attrs = extend({}, attrs);\n }\n\n for (key in attrs) {\n cur = attrs[key];\n old = oldAttrs[key];\n if (old !== cur) {\n setAttr(elm, key, cur);\n }\n }\n // #4391: in IE9, setting type can reset value for input[type=radio]\n // #6666: IE/Edge forces progress value down to 1 before setting a max\n /* istanbul ignore if */\n if ((isIE || isEdge) && attrs.value !== oldAttrs.value) {\n setAttr(elm, 'value', attrs.value);\n }\n for (key in oldAttrs) {\n if (isUndef(attrs[key])) {\n if (isXlink(key)) {\n elm.removeAttributeNS(xlinkNS, getXlinkProp(key));\n } else if (!isEnumeratedAttr(key)) {\n elm.removeAttribute(key);\n }\n }\n }\n}\n\nfunction setAttr (el, key, value) {\n if (el.tagName.indexOf('-') > -1) {\n baseSetAttr(el, key, value);\n } else if (isBooleanAttr(key)) {\n // set attribute for blank value\n // e.g. <option disabled>Select one</option>\n if (isFalsyAttrValue(value)) {\n el.removeAttribute(key);\n } else {\n // technically allowfullscreen is a boolean attribute for <iframe>,\n // but Flash expects a value of \"true\" when used on <embed> tag\n value = key === 'allowfullscreen' && el.tagName === 'EMBED'\n ? 'true'\n : key;\n el.setAttribute(key, value);\n }\n } else if (isEnumeratedAttr(key)) {\n el.setAttribute(key, convertEnumeratedValue(key, value));\n } else if (isXlink(key)) {\n if (isFalsyAttrValue(value)) {\n el.removeAttributeNS(xlinkNS, getXlinkProp(key));\n } else {\n el.setAttributeNS(xlinkNS, key, value);\n }\n } else {\n baseSetAttr(el, key, value);\n }\n}\n\nfunction baseSetAttr (el, key, value) {\n if (isFalsyAttrValue(value)) {\n el.removeAttribute(key);\n } else {\n // #7138: IE10 & 11 fires input event when setting placeholder on\n // <textarea>... block the first input event and remove the blocker\n // immediately.\n /* istanbul ignore if */\n if (\n isIE && !isIE9 &&\n el.tagName === 'TEXTAREA' &&\n key === 'placeholder' && value !== '' && !el.__ieph\n ) {\n var blocker = function (e) {\n e.stopImmediatePropagation();\n el.removeEventListener('input', blocker);\n };\n el.addEventListener('input', blocker);\n // $flow-disable-line\n el.__ieph = true; /* IE placeholder patched */\n }\n el.setAttribute(key, value);\n }\n}\n\nvar attrs = {\n create: updateAttrs,\n update: updateAttrs\n};\n\n/* */\n\nfunction updateClass (oldVnode, vnode) {\n var el = vnode.elm;\n var data = vnode.data;\n var oldData = oldVnode.data;\n if (\n isUndef(data.staticClass) &&\n isUndef(data.class) && (\n isUndef(oldData) || (\n isUndef(oldData.staticClass) &&\n isUndef(oldData.class)\n )\n )\n ) {\n return\n }\n\n var cls = genClassForVnode(vnode);\n\n // handle transition classes\n var transitionClass = el._transitionClasses;\n if (isDef(transitionClass)) {\n cls = concat(cls, stringifyClass(transitionClass));\n }\n\n // set the class\n if (cls !== el._prevClass) {\n el.setAttribute('class', cls);\n el._prevClass = cls;\n }\n}\n\nvar klass = {\n create: updateClass,\n update: updateClass\n};\n\n/* */\n\nvar validDivisionCharRE = /[\\w).+\\-_$\\]]/;\n\nfunction parseFilters (exp) {\n var inSingle = false;\n var inDouble = false;\n var inTemplateString = false;\n var inRegex = false;\n var curly = 0;\n var square = 0;\n var paren = 0;\n var lastFilterIndex = 0;\n var c, prev, i, expression, filters;\n\n for (i = 0; i < exp.length; i++) {\n prev = c;\n c = exp.charCodeAt(i);\n if (inSingle) {\n if (c === 0x27 && prev !== 0x5C) { inSingle = false; }\n } else if (inDouble) {\n if (c === 0x22 && prev !== 0x5C) { inDouble = false; }\n } else if (inTemplateString) {\n if (c === 0x60 && prev !== 0x5C) { inTemplateString = false; }\n } else if (inRegex) {\n if (c === 0x2f && prev !== 0x5C) { inRegex = false; }\n } else if (\n c === 0x7C && // pipe\n exp.charCodeAt(i + 1) !== 0x7C &&\n exp.charCodeAt(i - 1) !== 0x7C &&\n !curly && !square && !paren\n ) {\n if (expression === undefined) {\n // first filter, end of expression\n lastFilterIndex = i + 1;\n expression = exp.slice(0, i).trim();\n } else {\n pushFilter();\n }\n } else {\n switch (c) {\n case 0x22: inDouble = true; break // \"\n case 0x27: inSingle = true; break // '\n case 0x60: inTemplateString = true; break // `\n case 0x28: paren++; break // (\n case 0x29: paren--; break // )\n case 0x5B: square++; break // [\n case 0x5D: square--; break // ]\n case 0x7B: curly++; break // {\n case 0x7D: curly--; break // }\n }\n if (c === 0x2f) { // /\n var j = i - 1;\n var p = (void 0);\n // find first non-whitespace prev char\n for (; j >= 0; j--) {\n p = exp.charAt(j);\n if (p !== ' ') { break }\n }\n if (!p || !validDivisionCharRE.test(p)) {\n inRegex = true;\n }\n }\n }\n }\n\n if (expression === undefined) {\n expression = exp.slice(0, i).trim();\n } else if (lastFilterIndex !== 0) {\n pushFilter();\n }\n\n function pushFilter () {\n (filters || (filters = [])).push(exp.slice(lastFilterIndex, i).trim());\n lastFilterIndex = i + 1;\n }\n\n if (filters) {\n for (i = 0; i < filters.length; i++) {\n expression = wrapFilter(expression, filters[i]);\n }\n }\n\n return expression\n}\n\nfunction wrapFilter (exp, filter) {\n var i = filter.indexOf('(');\n if (i < 0) {\n // _f: resolveFilter\n return (\"_f(\\\"\" + filter + \"\\\")(\" + exp + \")\")\n } else {\n var name = filter.slice(0, i);\n var args = filter.slice(i + 1);\n return (\"_f(\\\"\" + name + \"\\\")(\" + exp + (args !== ')' ? ',' + args : args))\n }\n}\n\n/* */\n\n\n\n/* eslint-disable no-unused-vars */\nfunction baseWarn (msg, range) {\n console.error((\"[Vue compiler]: \" + msg));\n}\n/* eslint-enable no-unused-vars */\n\nfunction pluckModuleFunction (\n modules,\n key\n) {\n return modules\n ? modules.map(function (m) { return m[key]; }).filter(function (_) { return _; })\n : []\n}\n\nfunction addProp (el, name, value, range, dynamic) {\n (el.props || (el.props = [])).push(rangeSetItem({ name: name, value: value, dynamic: dynamic }, range));\n el.plain = false;\n}\n\nfunction addAttr (el, name, value, range, dynamic) {\n var attrs = dynamic\n ? (el.dynamicAttrs || (el.dynamicAttrs = []))\n : (el.attrs || (el.attrs = []));\n attrs.push(rangeSetItem({ name: name, value: value, dynamic: dynamic }, range));\n el.plain = false;\n}\n\n// add a raw attr (use this in preTransforms)\nfunction addRawAttr (el, name, value, range) {\n el.attrsMap[name] = value;\n el.attrsList.push(rangeSetItem({ name: name, value: value }, range));\n}\n\nfunction addDirective (\n el,\n name,\n rawName,\n value,\n arg,\n isDynamicArg,\n modifiers,\n range\n) {\n (el.directives || (el.directives = [])).push(rangeSetItem({\n name: name,\n rawName: rawName,\n value: value,\n arg: arg,\n isDynamicArg: isDynamicArg,\n modifiers: modifiers\n }, range));\n el.plain = false;\n}\n\nfunction prependModifierMarker (symbol, name, dynamic) {\n return dynamic\n ? (\"_p(\" + name + \",\\\"\" + symbol + \"\\\")\")\n : symbol + name // mark the event as captured\n}\n\nfunction addHandler (\n el,\n name,\n value,\n modifiers,\n important,\n warn,\n range,\n dynamic\n) {\n modifiers = modifiers || emptyObject;\n // warn prevent and passive modifier\n /* istanbul ignore if */\n if (\n true && warn &&\n modifiers.prevent && modifiers.passive\n ) {\n warn(\n 'passive and prevent can\\'t be used together. ' +\n 'Passive handler can\\'t prevent default event.',\n range\n );\n }\n\n // normalize click.right and click.middle since they don't actually fire\n // this is technically browser-specific, but at least for now browsers are\n // the only target envs that have right/middle clicks.\n if (modifiers.right) {\n if (dynamic) {\n name = \"(\" + name + \")==='click'?'contextmenu':(\" + name + \")\";\n } else if (name === 'click') {\n name = 'contextmenu';\n delete modifiers.right;\n }\n } else if (modifiers.middle) {\n if (dynamic) {\n name = \"(\" + name + \")==='click'?'mouseup':(\" + name + \")\";\n } else if (name === 'click') {\n name = 'mouseup';\n }\n }\n\n // check capture modifier\n if (modifiers.capture) {\n delete modifiers.capture;\n name = prependModifierMarker('!', name, dynamic);\n }\n if (modifiers.once) {\n delete modifiers.once;\n name = prependModifierMarker('~', name, dynamic);\n }\n /* istanbul ignore if */\n if (modifiers.passive) {\n delete modifiers.passive;\n name = prependModifierMarker('&', name, dynamic);\n }\n\n var events;\n if (modifiers.native) {\n delete modifiers.native;\n events = el.nativeEvents || (el.nativeEvents = {});\n } else {\n events = el.events || (el.events = {});\n }\n\n var newHandler = rangeSetItem({ value: value.trim(), dynamic: dynamic }, range);\n if (modifiers !== emptyObject) {\n newHandler.modifiers = modifiers;\n }\n\n var handlers = events[name];\n /* istanbul ignore if */\n if (Array.isArray(handlers)) {\n important ? handlers.unshift(newHandler) : handlers.push(newHandler);\n } else if (handlers) {\n events[name] = important ? [newHandler, handlers] : [handlers, newHandler];\n } else {\n events[name] = newHandler;\n }\n\n el.plain = false;\n}\n\nfunction getRawBindingAttr (\n el,\n name\n) {\n return el.rawAttrsMap[':' + name] ||\n el.rawAttrsMap['v-bind:' + name] ||\n el.rawAttrsMap[name]\n}\n\nfunction getBindingAttr (\n el,\n name,\n getStatic\n) {\n var dynamicValue =\n getAndRemoveAttr(el, ':' + name) ||\n getAndRemoveAttr(el, 'v-bind:' + name);\n if (dynamicValue != null) {\n return parseFilters(dynamicValue)\n } else if (getStatic !== false) {\n var staticValue = getAndRemoveAttr(el, name);\n if (staticValue != null) {\n return JSON.stringify(staticValue)\n }\n }\n}\n\n// note: this only removes the attr from the Array (attrsList) so that it\n// doesn't get processed by processAttrs.\n// By default it does NOT remove it from the map (attrsMap) because the map is\n// needed during codegen.\nfunction getAndRemoveAttr (\n el,\n name,\n removeFromMap\n) {\n var val;\n if ((val = el.attrsMap[name]) != null) {\n var list = el.attrsList;\n for (var i = 0, l = list.length; i < l; i++) {\n if (list[i].name === name) {\n list.splice(i, 1);\n break\n }\n }\n }\n if (removeFromMap) {\n delete el.attrsMap[name];\n }\n return val\n}\n\nfunction getAndRemoveAttrByRegex (\n el,\n name\n) {\n var list = el.attrsList;\n for (var i = 0, l = list.length; i < l; i++) {\n var attr = list[i];\n if (name.test(attr.name)) {\n list.splice(i, 1);\n return attr\n }\n }\n}\n\nfunction rangeSetItem (\n item,\n range\n) {\n if (range) {\n if (range.start != null) {\n item.start = range.start;\n }\n if (range.end != null) {\n item.end = range.end;\n }\n }\n return item\n}\n\n/* */\n\n/**\n * Cross-platform code generation for component v-model\n */\nfunction genComponentModel (\n el,\n value,\n modifiers\n) {\n var ref = modifiers || {};\n var number = ref.number;\n var trim = ref.trim;\n\n var baseValueExpression = '$$v';\n var valueExpression = baseValueExpression;\n if (trim) {\n valueExpression =\n \"(typeof \" + baseValueExpression + \" === 'string'\" +\n \"? \" + baseValueExpression + \".trim()\" +\n \": \" + baseValueExpression + \")\";\n }\n if (number) {\n valueExpression = \"_n(\" + valueExpression + \")\";\n }\n var assignment = genAssignmentCode(value, valueExpression);\n\n el.model = {\n value: (\"(\" + value + \")\"),\n expression: JSON.stringify(value),\n callback: (\"function (\" + baseValueExpression + \") {\" + assignment + \"}\")\n };\n}\n\n/**\n * Cross-platform codegen helper for generating v-model value assignment code.\n */\nfunction genAssignmentCode (\n value,\n assignment\n) {\n var res = parseModel(value);\n if (res.key === null) {\n return (value + \"=\" + assignment)\n } else {\n return (\"$set(\" + (res.exp) + \", \" + (res.key) + \", \" + assignment + \")\")\n }\n}\n\n/**\n * Parse a v-model expression into a base path and a final key segment.\n * Handles both dot-path and possible square brackets.\n *\n * Possible cases:\n *\n * - test\n * - test[key]\n * - test[test1[key]]\n * - test[\"a\"][key]\n * - xxx.test[a[a].test1[key]]\n * - test.xxx.a[\"asa\"][test1[key]]\n *\n */\n\nvar len, str, chr, index$1, expressionPos, expressionEndPos;\n\n\n\nfunction parseModel (val) {\n // Fix https://github.com/vuejs/vue/pull/7730\n // allow v-model=\"obj.val \" (trailing whitespace)\n val = val.trim();\n len = val.length;\n\n if (val.indexOf('[') < 0 || val.lastIndexOf(']') < len - 1) {\n index$1 = val.lastIndexOf('.');\n if (index$1 > -1) {\n return {\n exp: val.slice(0, index$1),\n key: '\"' + val.slice(index$1 + 1) + '\"'\n }\n } else {\n return {\n exp: val,\n key: null\n }\n }\n }\n\n str = val;\n index$1 = expressionPos = expressionEndPos = 0;\n\n while (!eof()) {\n chr = next();\n /* istanbul ignore if */\n if (isStringStart(chr)) {\n parseString(chr);\n } else if (chr === 0x5B) {\n parseBracket(chr);\n }\n }\n\n return {\n exp: val.slice(0, expressionPos),\n key: val.slice(expressionPos + 1, expressionEndPos)\n }\n}\n\nfunction next () {\n return str.charCodeAt(++index$1)\n}\n\nfunction eof () {\n return index$1 >= len\n}\n\nfunction isStringStart (chr) {\n return chr === 0x22 || chr === 0x27\n}\n\nfunction parseBracket (chr) {\n var inBracket = 1;\n expressionPos = index$1;\n while (!eof()) {\n chr = next();\n if (isStringStart(chr)) {\n parseString(chr);\n continue\n }\n if (chr === 0x5B) { inBracket++; }\n if (chr === 0x5D) { inBracket--; }\n if (inBracket === 0) {\n expressionEndPos = index$1;\n break\n }\n }\n}\n\nfunction parseString (chr) {\n var stringQuote = chr;\n while (!eof()) {\n chr = next();\n if (chr === stringQuote) {\n break\n }\n }\n}\n\n/* */\n\nvar warn$1;\n\n// in some cases, the event used has to be determined at runtime\n// so we used some reserved tokens during compile.\nvar RANGE_TOKEN = '__r';\nvar CHECKBOX_RADIO_TOKEN = '__c';\n\nfunction model (\n el,\n dir,\n _warn\n) {\n warn$1 = _warn;\n var value = dir.value;\n var modifiers = dir.modifiers;\n var tag = el.tag;\n var type = el.attrsMap.type;\n\n if (true) {\n // inputs with type=\"file\" are read only and setting the input's\n // value will throw an error.\n if (tag === 'input' && type === 'file') {\n warn$1(\n \"<\" + (el.tag) + \" v-model=\\\"\" + value + \"\\\" type=\\\"file\\\">:\\n\" +\n \"File inputs are read only. Use a v-on:change listener instead.\",\n el.rawAttrsMap['v-model']\n );\n }\n }\n\n if (el.component) {\n genComponentModel(el, value, modifiers);\n // component v-model doesn't need extra runtime\n return false\n } else if (tag === 'select') {\n genSelect(el, value, modifiers);\n } else if (tag === 'input' && type === 'checkbox') {\n genCheckboxModel(el, value, modifiers);\n } else if (tag === 'input' && type === 'radio') {\n genRadioModel(el, value, modifiers);\n } else if (tag === 'input' || tag === 'textarea') {\n genDefaultModel(el, value, modifiers);\n } else if (!config.isReservedTag(tag)) {\n genComponentModel(el, value, modifiers);\n // component v-model doesn't need extra runtime\n return false\n } else if (true) {\n warn$1(\n \"<\" + (el.tag) + \" v-model=\\\"\" + value + \"\\\">: \" +\n \"v-model is not supported on this element type. \" +\n 'If you are working with contenteditable, it\\'s recommended to ' +\n 'wrap a library dedicated for that purpose inside a custom component.',\n el.rawAttrsMap['v-model']\n );\n }\n\n // ensure runtime directive metadata\n return true\n}\n\nfunction genCheckboxModel (\n el,\n value,\n modifiers\n) {\n var number = modifiers && modifiers.number;\n var valueBinding = getBindingAttr(el, 'value') || 'null';\n var trueValueBinding = getBindingAttr(el, 'true-value') || 'true';\n var falseValueBinding = getBindingAttr(el, 'false-value') || 'false';\n addProp(el, 'checked',\n \"Array.isArray(\" + value + \")\" +\n \"?_i(\" + value + \",\" + valueBinding + \")>-1\" + (\n trueValueBinding === 'true'\n ? (\":(\" + value + \")\")\n : (\":_q(\" + value + \",\" + trueValueBinding + \")\")\n )\n );\n addHandler(el, 'change',\n \"var $$a=\" + value + \",\" +\n '$$el=$event.target,' +\n \"$$c=$$el.checked?(\" + trueValueBinding + \"):(\" + falseValueBinding + \");\" +\n 'if(Array.isArray($$a)){' +\n \"var $$v=\" + (number ? '_n(' + valueBinding + ')' : valueBinding) + \",\" +\n '$$i=_i($$a,$$v);' +\n \"if($$el.checked){$$i<0&&(\" + (genAssignmentCode(value, '$$a.concat([$$v])')) + \")}\" +\n \"else{$$i>-1&&(\" + (genAssignmentCode(value, '$$a.slice(0,$$i).concat($$a.slice($$i+1))')) + \")}\" +\n \"}else{\" + (genAssignmentCode(value, '$$c')) + \"}\",\n null, true\n );\n}\n\nfunction genRadioModel (\n el,\n value,\n modifiers\n) {\n var number = modifiers && modifiers.number;\n var valueBinding = getBindingAttr(el, 'value') || 'null';\n valueBinding = number ? (\"_n(\" + valueBinding + \")\") : valueBinding;\n addProp(el, 'checked', (\"_q(\" + value + \",\" + valueBinding + \")\"));\n addHandler(el, 'change', genAssignmentCode(value, valueBinding), null, true);\n}\n\nfunction genSelect (\n el,\n value,\n modifiers\n) {\n var number = modifiers && modifiers.number;\n var selectedVal = \"Array.prototype.filter\" +\n \".call($event.target.options,function(o){return o.selected})\" +\n \".map(function(o){var val = \\\"_value\\\" in o ? o._value : o.value;\" +\n \"return \" + (number ? '_n(val)' : 'val') + \"})\";\n\n var assignment = '$event.target.multiple ? $$selectedVal : $$selectedVal[0]';\n var code = \"var $$selectedVal = \" + selectedVal + \";\";\n code = code + \" \" + (genAssignmentCode(value, assignment));\n addHandler(el, 'change', code, null, true);\n}\n\nfunction genDefaultModel (\n el,\n value,\n modifiers\n) {\n var type = el.attrsMap.type;\n\n // warn if v-bind:value conflicts with v-model\n // except for inputs with v-bind:type\n if (true) {\n var value$1 = el.attrsMap['v-bind:value'] || el.attrsMap[':value'];\n var typeBinding = el.attrsMap['v-bind:type'] || el.attrsMap[':type'];\n if (value$1 && !typeBinding) {\n var binding = el.attrsMap['v-bind:value'] ? 'v-bind:value' : ':value';\n warn$1(\n binding + \"=\\\"\" + value$1 + \"\\\" conflicts with v-model on the same element \" +\n 'because the latter already expands to a value binding internally',\n el.rawAttrsMap[binding]\n );\n }\n }\n\n var ref = modifiers || {};\n var lazy = ref.lazy;\n var number = ref.number;\n var trim = ref.trim;\n var needCompositionGuard = !lazy && type !== 'range';\n var event = lazy\n ? 'change'\n : type === 'range'\n ? RANGE_TOKEN\n : 'input';\n\n var valueExpression = '$event.target.value';\n if (trim) {\n valueExpression = \"$event.target.value.trim()\";\n }\n if (number) {\n valueExpression = \"_n(\" + valueExpression + \")\";\n }\n\n var code = genAssignmentCode(value, valueExpression);\n if (needCompositionGuard) {\n code = \"if($event.target.composing)return;\" + code;\n }\n\n addProp(el, 'value', (\"(\" + value + \")\"));\n addHandler(el, event, code, null, true);\n if (trim || number) {\n addHandler(el, 'blur', '$forceUpdate()');\n }\n}\n\n/* */\n\n// normalize v-model event tokens that can only be determined at runtime.\n// it's important to place the event as the first in the array because\n// the whole point is ensuring the v-model callback gets called before\n// user-attached handlers.\nfunction normalizeEvents (on) {\n /* istanbul ignore if */\n if (isDef(on[RANGE_TOKEN])) {\n // IE input[type=range] only supports `change` event\n var event = isIE ? 'change' : 'input';\n on[event] = [].concat(on[RANGE_TOKEN], on[event] || []);\n delete on[RANGE_TOKEN];\n }\n // This was originally intended to fix #4521 but no longer necessary\n // after 2.5. Keeping it for backwards compat with generated code from < 2.4\n /* istanbul ignore if */\n if (isDef(on[CHECKBOX_RADIO_TOKEN])) {\n on.change = [].concat(on[CHECKBOX_RADIO_TOKEN], on.change || []);\n delete on[CHECKBOX_RADIO_TOKEN];\n }\n}\n\nvar target$1;\n\nfunction createOnceHandler$1 (event, handler, capture) {\n var _target = target$1; // save current target element in closure\n return function onceHandler () {\n var res = handler.apply(null, arguments);\n if (res !== null) {\n remove$2(event, onceHandler, capture, _target);\n }\n }\n}\n\n// #9446: Firefox <= 53 (in particular, ESR 52) has incorrect Event.timeStamp\n// implementation and does not fire microtasks in between event propagation, so\n// safe to exclude.\nvar useMicrotaskFix = isUsingMicroTask && !(isFF && Number(isFF[1]) <= 53);\n\nfunction add$1 (\n name,\n handler,\n capture,\n passive\n) {\n // async edge case #6566: inner click event triggers patch, event handler\n // attached to outer element during patch, and triggered again. This\n // happens because browsers fire microtask ticks between event propagation.\n // the solution is simple: we save the timestamp when a handler is attached,\n // and the handler would only fire if the event passed to it was fired\n // AFTER it was attached.\n if (useMicrotaskFix) {\n var attachedTimestamp = currentFlushTimestamp;\n var original = handler;\n handler = original._wrapper = function (e) {\n if (\n // no bubbling, should always fire.\n // this is just a safety net in case event.timeStamp is unreliable in\n // certain weird environments...\n e.target === e.currentTarget ||\n // event is fired after handler attachment\n e.timeStamp >= attachedTimestamp ||\n // bail for environments that have buggy event.timeStamp implementations\n // #9462 iOS 9 bug: event.timeStamp is 0 after history.pushState\n // #9681 QtWebEngine event.timeStamp is negative value\n e.timeStamp <= 0 ||\n // #9448 bail if event is fired in another document in a multi-page\n // electron/nw.js app, since event.timeStamp will be using a different\n // starting reference\n e.target.ownerDocument !== document\n ) {\n return original.apply(this, arguments)\n }\n };\n }\n target$1.addEventListener(\n name,\n handler,\n supportsPassive\n ? { capture: capture, passive: passive }\n : capture\n );\n}\n\nfunction remove$2 (\n name,\n handler,\n capture,\n _target\n) {\n (_target || target$1).removeEventListener(\n name,\n handler._wrapper || handler,\n capture\n );\n}\n\nfunction updateDOMListeners (oldVnode, vnode) {\n if (isUndef(oldVnode.data.on) && isUndef(vnode.data.on)) {\n return\n }\n var on = vnode.data.on || {};\n var oldOn = oldVnode.data.on || {};\n target$1 = vnode.elm;\n normalizeEvents(on);\n updateListeners(on, oldOn, add$1, remove$2, createOnceHandler$1, vnode.context);\n target$1 = undefined;\n}\n\nvar events = {\n create: updateDOMListeners,\n update: updateDOMListeners\n};\n\n/* */\n\nvar svgContainer;\n\nfunction updateDOMProps (oldVnode, vnode) {\n if (isUndef(oldVnode.data.domProps) && isUndef(vnode.data.domProps)) {\n return\n }\n var key, cur;\n var elm = vnode.elm;\n var oldProps = oldVnode.data.domProps || {};\n var props = vnode.data.domProps || {};\n // clone observed objects, as the user probably wants to mutate it\n if (isDef(props.__ob__)) {\n props = vnode.data.domProps = extend({}, props);\n }\n\n for (key in oldProps) {\n if (!(key in props)) {\n elm[key] = '';\n }\n }\n\n for (key in props) {\n cur = props[key];\n // ignore children if the node has textContent or innerHTML,\n // as these will throw away existing DOM nodes and cause removal errors\n // on subsequent patches (#3360)\n if (key === 'textContent' || key === 'innerHTML') {\n if (vnode.children) { vnode.children.length = 0; }\n if (cur === oldProps[key]) { continue }\n // #6601 work around Chrome version <= 55 bug where single textNode\n // replaced by innerHTML/textContent retains its parentNode property\n if (elm.childNodes.length === 1) {\n elm.removeChild(elm.childNodes[0]);\n }\n }\n\n if (key === 'value' && elm.tagName !== 'PROGRESS') {\n // store value as _value as well since\n // non-string values will be stringified\n elm._value = cur;\n // avoid resetting cursor position when value is the same\n var strCur = isUndef(cur) ? '' : String(cur);\n if (shouldUpdateValue(elm, strCur)) {\n elm.value = strCur;\n }\n } else if (key === 'innerHTML' && isSVG(elm.tagName) && isUndef(elm.innerHTML)) {\n // IE doesn't support innerHTML for SVG elements\n svgContainer = svgContainer || document.createElement('div');\n svgContainer.innerHTML = \"<svg>\" + cur + \"</svg>\";\n var svg = svgContainer.firstChild;\n while (elm.firstChild) {\n elm.removeChild(elm.firstChild);\n }\n while (svg.firstChild) {\n elm.appendChild(svg.firstChild);\n }\n } else if (\n // skip the update if old and new VDOM state is the same.\n // `value` is handled separately because the DOM value may be temporarily\n // out of sync with VDOM state due to focus, composition and modifiers.\n // This #4521 by skipping the unnecesarry `checked` update.\n cur !== oldProps[key]\n ) {\n // some property updates can throw\n // e.g. `value` on <progress> w/ non-finite value\n try {\n elm[key] = cur;\n } catch (e) {}\n }\n }\n}\n\n// check platforms/web/util/attrs.js acceptValue\n\n\nfunction shouldUpdateValue (elm, checkVal) {\n return (!elm.composing && (\n elm.tagName === 'OPTION' ||\n isNotInFocusAndDirty(elm, checkVal) ||\n isDirtyWithModifiers(elm, checkVal)\n ))\n}\n\nfunction isNotInFocusAndDirty (elm, checkVal) {\n // return true when textbox (.number and .trim) loses focus and its value is\n // not equal to the updated value\n var notInFocus = true;\n // #6157\n // work around IE bug when accessing document.activeElement in an iframe\n try { notInFocus = document.activeElement !== elm; } catch (e) {}\n return notInFocus && elm.value !== checkVal\n}\n\nfunction isDirtyWithModifiers (elm, newVal) {\n var value = elm.value;\n var modifiers = elm._vModifiers; // injected by v-model runtime\n if (isDef(modifiers)) {\n if (modifiers.number) {\n return toNumber(value) !== toNumber(newVal)\n }\n if (modifiers.trim) {\n return value.trim() !== newVal.trim()\n }\n }\n return value !== newVal\n}\n\nvar domProps = {\n create: updateDOMProps,\n update: updateDOMProps\n};\n\n/* */\n\nvar parseStyleText = cached(function (cssText) {\n var res = {};\n var listDelimiter = /;(?![^(]*\\))/g;\n var propertyDelimiter = /:(.+)/;\n cssText.split(listDelimiter).forEach(function (item) {\n if (item) {\n var tmp = item.split(propertyDelimiter);\n tmp.length > 1 && (res[tmp[0].trim()] = tmp[1].trim());\n }\n });\n return res\n});\n\n// merge static and dynamic style data on the same vnode\nfunction normalizeStyleData (data) {\n var style = normalizeStyleBinding(data.style);\n // static style is pre-processed into an object during compilation\n // and is always a fresh object, so it's safe to merge into it\n return data.staticStyle\n ? extend(data.staticStyle, style)\n : style\n}\n\n// normalize possible array / string values into Object\nfunction normalizeStyleBinding (bindingStyle) {\n if (Array.isArray(bindingStyle)) {\n return toObject(bindingStyle)\n }\n if (typeof bindingStyle === 'string') {\n return parseStyleText(bindingStyle)\n }\n return bindingStyle\n}\n\n/**\n * parent component style should be after child's\n * so that parent component's style could override it\n */\nfunction getStyle (vnode, checkChild) {\n var res = {};\n var styleData;\n\n if (checkChild) {\n var childNode = vnode;\n while (childNode.componentInstance) {\n childNode = childNode.componentInstance._vnode;\n if (\n childNode && childNode.data &&\n (styleData = normalizeStyleData(childNode.data))\n ) {\n extend(res, styleData);\n }\n }\n }\n\n if ((styleData = normalizeStyleData(vnode.data))) {\n extend(res, styleData);\n }\n\n var parentNode = vnode;\n while ((parentNode = parentNode.parent)) {\n if (parentNode.data && (styleData = normalizeStyleData(parentNode.data))) {\n extend(res, styleData);\n }\n }\n return res\n}\n\n/* */\n\nvar cssVarRE = /^--/;\nvar importantRE = /\\s*!important$/;\nvar setProp = function (el, name, val) {\n /* istanbul ignore if */\n if (cssVarRE.test(name)) {\n el.style.setProperty(name, val);\n } else if (importantRE.test(val)) {\n el.style.setProperty(hyphenate(name), val.replace(importantRE, ''), 'important');\n } else {\n var normalizedName = normalize(name);\n if (Array.isArray(val)) {\n // Support values array created by autoprefixer, e.g.\n // {display: [\"-webkit-box\", \"-ms-flexbox\", \"flex\"]}\n // Set them one by one, and the browser will only set those it can recognize\n for (var i = 0, len = val.length; i < len; i++) {\n el.style[normalizedName] = val[i];\n }\n } else {\n el.style[normalizedName] = val;\n }\n }\n};\n\nvar vendorNames = ['Webkit', 'Moz', 'ms'];\n\nvar emptyStyle;\nvar normalize = cached(function (prop) {\n emptyStyle = emptyStyle || document.createElement('div').style;\n prop = camelize(prop);\n if (prop !== 'filter' && (prop in emptyStyle)) {\n return prop\n }\n var capName = prop.charAt(0).toUpperCase() + prop.slice(1);\n for (var i = 0; i < vendorNames.length; i++) {\n var name = vendorNames[i] + capName;\n if (name in emptyStyle) {\n return name\n }\n }\n});\n\nfunction updateStyle (oldVnode, vnode) {\n var data = vnode.data;\n var oldData = oldVnode.data;\n\n if (isUndef(data.staticStyle) && isUndef(data.style) &&\n isUndef(oldData.staticStyle) && isUndef(oldData.style)\n ) {\n return\n }\n\n var cur, name;\n var el = vnode.elm;\n var oldStaticStyle = oldData.staticStyle;\n var oldStyleBinding = oldData.normalizedStyle || oldData.style || {};\n\n // if static style exists, stylebinding already merged into it when doing normalizeStyleData\n var oldStyle = oldStaticStyle || oldStyleBinding;\n\n var style = normalizeStyleBinding(vnode.data.style) || {};\n\n // store normalized style under a different key for next diff\n // make sure to clone it if it's reactive, since the user likely wants\n // to mutate it.\n vnode.data.normalizedStyle = isDef(style.__ob__)\n ? extend({}, style)\n : style;\n\n var newStyle = getStyle(vnode, true);\n\n for (name in oldStyle) {\n if (isUndef(newStyle[name])) {\n setProp(el, name, '');\n }\n }\n for (name in newStyle) {\n cur = newStyle[name];\n if (cur !== oldStyle[name]) {\n // ie9 setting to null has no effect, must use empty string\n setProp(el, name, cur == null ? '' : cur);\n }\n }\n}\n\nvar style = {\n create: updateStyle,\n update: updateStyle\n};\n\n/* */\n\nvar whitespaceRE = /\\s+/;\n\n/**\n * Add class with compatibility for SVG since classList is not supported on\n * SVG elements in IE\n */\nfunction addClass (el, cls) {\n /* istanbul ignore if */\n if (!cls || !(cls = cls.trim())) {\n return\n }\n\n /* istanbul ignore else */\n if (el.classList) {\n if (cls.indexOf(' ') > -1) {\n cls.split(whitespaceRE).forEach(function (c) { return el.classList.add(c); });\n } else {\n el.classList.add(cls);\n }\n } else {\n var cur = \" \" + (el.getAttribute('class') || '') + \" \";\n if (cur.indexOf(' ' + cls + ' ') < 0) {\n el.setAttribute('class', (cur + cls).trim());\n }\n }\n}\n\n/**\n * Remove class with compatibility for SVG since classList is not supported on\n * SVG elements in IE\n */\nfunction removeClass (el, cls) {\n /* istanbul ignore if */\n if (!cls || !(cls = cls.trim())) {\n return\n }\n\n /* istanbul ignore else */\n if (el.classList) {\n if (cls.indexOf(' ') > -1) {\n cls.split(whitespaceRE).forEach(function (c) { return el.classList.remove(c); });\n } else {\n el.classList.remove(cls);\n }\n if (!el.classList.length) {\n el.removeAttribute('class');\n }\n } else {\n var cur = \" \" + (el.getAttribute('class') || '') + \" \";\n var tar = ' ' + cls + ' ';\n while (cur.indexOf(tar) >= 0) {\n cur = cur.replace(tar, ' ');\n }\n cur = cur.trim();\n if (cur) {\n el.setAttribute('class', cur);\n } else {\n el.removeAttribute('class');\n }\n }\n}\n\n/* */\n\nfunction resolveTransition (def$$1) {\n if (!def$$1) {\n return\n }\n /* istanbul ignore else */\n if (typeof def$$1 === 'object') {\n var res = {};\n if (def$$1.css !== false) {\n extend(res, autoCssTransition(def$$1.name || 'v'));\n }\n extend(res, def$$1);\n return res\n } else if (typeof def$$1 === 'string') {\n return autoCssTransition(def$$1)\n }\n}\n\nvar autoCssTransition = cached(function (name) {\n return {\n enterClass: (name + \"-enter\"),\n enterToClass: (name + \"-enter-to\"),\n enterActiveClass: (name + \"-enter-active\"),\n leaveClass: (name + \"-leave\"),\n leaveToClass: (name + \"-leave-to\"),\n leaveActiveClass: (name + \"-leave-active\")\n }\n});\n\nvar hasTransition = inBrowser && !isIE9;\nvar TRANSITION = 'transition';\nvar ANIMATION = 'animation';\n\n// Transition property/event sniffing\nvar transitionProp = 'transition';\nvar transitionEndEvent = 'transitionend';\nvar animationProp = 'animation';\nvar animationEndEvent = 'animationend';\nif (hasTransition) {\n /* istanbul ignore if */\n if (window.ontransitionend === undefined &&\n window.onwebkittransitionend !== undefined\n ) {\n transitionProp = 'WebkitTransition';\n transitionEndEvent = 'webkitTransitionEnd';\n }\n if (window.onanimationend === undefined &&\n window.onwebkitanimationend !== undefined\n ) {\n animationProp = 'WebkitAnimation';\n animationEndEvent = 'webkitAnimationEnd';\n }\n}\n\n// binding to window is necessary to make hot reload work in IE in strict mode\nvar raf = inBrowser\n ? window.requestAnimationFrame\n ? window.requestAnimationFrame.bind(window)\n : setTimeout\n : /* istanbul ignore next */ function (fn) { return fn(); };\n\nfunction nextFrame (fn) {\n raf(function () {\n raf(fn);\n });\n}\n\nfunction addTransitionClass (el, cls) {\n var transitionClasses = el._transitionClasses || (el._transitionClasses = []);\n if (transitionClasses.indexOf(cls) < 0) {\n transitionClasses.push(cls);\n addClass(el, cls);\n }\n}\n\nfunction removeTransitionClass (el, cls) {\n if (el._transitionClasses) {\n remove(el._transitionClasses, cls);\n }\n removeClass(el, cls);\n}\n\nfunction whenTransitionEnds (\n el,\n expectedType,\n cb\n) {\n var ref = getTransitionInfo(el, expectedType);\n var type = ref.type;\n var timeout = ref.timeout;\n var propCount = ref.propCount;\n if (!type) { return cb() }\n var event = type === TRANSITION ? transitionEndEvent : animationEndEvent;\n var ended = 0;\n var end = function () {\n el.removeEventListener(event, onEnd);\n cb();\n };\n var onEnd = function (e) {\n if (e.target === el) {\n if (++ended >= propCount) {\n end();\n }\n }\n };\n setTimeout(function () {\n if (ended < propCount) {\n end();\n }\n }, timeout + 1);\n el.addEventListener(event, onEnd);\n}\n\nvar transformRE = /\\b(transform|all)(,|$)/;\n\nfunction getTransitionInfo (el, expectedType) {\n var styles = window.getComputedStyle(el);\n // JSDOM may return undefined for transition properties\n var transitionDelays = (styles[transitionProp + 'Delay'] || '').split(', ');\n var transitionDurations = (styles[transitionProp + 'Duration'] || '').split(', ');\n var transitionTimeout = getTimeout(transitionDelays, transitionDurations);\n var animationDelays = (styles[animationProp + 'Delay'] || '').split(', ');\n var animationDurations = (styles[animationProp + 'Duration'] || '').split(', ');\n var animationTimeout = getTimeout(animationDelays, animationDurations);\n\n var type;\n var timeout = 0;\n var propCount = 0;\n /* istanbul ignore if */\n if (expectedType === TRANSITION) {\n if (transitionTimeout > 0) {\n type = TRANSITION;\n timeout = transitionTimeout;\n propCount = transitionDurations.length;\n }\n } else if (expectedType === ANIMATION) {\n if (animationTimeout > 0) {\n type = ANIMATION;\n timeout = animationTimeout;\n propCount = animationDurations.length;\n }\n } else {\n timeout = Math.max(transitionTimeout, animationTimeout);\n type = timeout > 0\n ? transitionTimeout > animationTimeout\n ? TRANSITION\n : ANIMATION\n : null;\n propCount = type\n ? type === TRANSITION\n ? transitionDurations.length\n : animationDurations.length\n : 0;\n }\n var hasTransform =\n type === TRANSITION &&\n transformRE.test(styles[transitionProp + 'Property']);\n return {\n type: type,\n timeout: timeout,\n propCount: propCount,\n hasTransform: hasTransform\n }\n}\n\nfunction getTimeout (delays, durations) {\n /* istanbul ignore next */\n while (delays.length < durations.length) {\n delays = delays.concat(delays);\n }\n\n return Math.max.apply(null, durations.map(function (d, i) {\n return toMs(d) + toMs(delays[i])\n }))\n}\n\n// Old versions of Chromium (below 61.0.3163.100) formats floating pointer numbers\n// in a locale-dependent way, using a comma instead of a dot.\n// If comma is not replaced with a dot, the input will be rounded down (i.e. acting\n// as a floor function) causing unexpected behaviors\nfunction toMs (s) {\n return Number(s.slice(0, -1).replace(',', '.')) * 1000\n}\n\n/* */\n\nfunction enter (vnode, toggleDisplay) {\n var el = vnode.elm;\n\n // call leave callback now\n if (isDef(el._leaveCb)) {\n el._leaveCb.cancelled = true;\n el._leaveCb();\n }\n\n var data = resolveTransition(vnode.data.transition);\n if (isUndef(data)) {\n return\n }\n\n /* istanbul ignore if */\n if (isDef(el._enterCb) || el.nodeType !== 1) {\n return\n }\n\n var css = data.css;\n var type = data.type;\n var enterClass = data.enterClass;\n var enterToClass = data.enterToClass;\n var enterActiveClass = data.enterActiveClass;\n var appearClass = data.appearClass;\n var appearToClass = data.appearToClass;\n var appearActiveClass = data.appearActiveClass;\n var beforeEnter = data.beforeEnter;\n var enter = data.enter;\n var afterEnter = data.afterEnter;\n var enterCancelled = data.enterCancelled;\n var beforeAppear = data.beforeAppear;\n var appear = data.appear;\n var afterAppear = data.afterAppear;\n var appearCancelled = data.appearCancelled;\n var duration = data.duration;\n\n // activeInstance will always be the <transition> component managing this\n // transition. One edge case to check is when the <transition> is placed\n // as the root node of a child component. In that case we need to check\n // <transition>'s parent for appear check.\n var context = activeInstance;\n var transitionNode = activeInstance.$vnode;\n while (transitionNode && transitionNode.parent) {\n context = transitionNode.context;\n transitionNode = transitionNode.parent;\n }\n\n var isAppear = !context._isMounted || !vnode.isRootInsert;\n\n if (isAppear && !appear && appear !== '') {\n return\n }\n\n var startClass = isAppear && appearClass\n ? appearClass\n : enterClass;\n var activeClass = isAppear && appearActiveClass\n ? appearActiveClass\n : enterActiveClass;\n var toClass = isAppear && appearToClass\n ? appearToClass\n : enterToClass;\n\n var beforeEnterHook = isAppear\n ? (beforeAppear || beforeEnter)\n : beforeEnter;\n var enterHook = isAppear\n ? (typeof appear === 'function' ? appear : enter)\n : enter;\n var afterEnterHook = isAppear\n ? (afterAppear || afterEnter)\n : afterEnter;\n var enterCancelledHook = isAppear\n ? (appearCancelled || enterCancelled)\n : enterCancelled;\n\n var explicitEnterDuration = toNumber(\n isObject(duration)\n ? duration.enter\n : duration\n );\n\n if ( true && explicitEnterDuration != null) {\n checkDuration(explicitEnterDuration, 'enter', vnode);\n }\n\n var expectsCSS = css !== false && !isIE9;\n var userWantsControl = getHookArgumentsLength(enterHook);\n\n var cb = el._enterCb = once(function () {\n if (expectsCSS) {\n removeTransitionClass(el, toClass);\n removeTransitionClass(el, activeClass);\n }\n if (cb.cancelled) {\n if (expectsCSS) {\n removeTransitionClass(el, startClass);\n }\n enterCancelledHook && enterCancelledHook(el);\n } else {\n afterEnterHook && afterEnterHook(el);\n }\n el._enterCb = null;\n });\n\n if (!vnode.data.show) {\n // remove pending leave element on enter by injecting an insert hook\n mergeVNodeHook(vnode, 'insert', function () {\n var parent = el.parentNode;\n var pendingNode = parent && parent._pending && parent._pending[vnode.key];\n if (pendingNode &&\n pendingNode.tag === vnode.tag &&\n pendingNode.elm._leaveCb\n ) {\n pendingNode.elm._leaveCb();\n }\n enterHook && enterHook(el, cb);\n });\n }\n\n // start enter transition\n beforeEnterHook && beforeEnterHook(el);\n if (expectsCSS) {\n addTransitionClass(el, startClass);\n addTransitionClass(el, activeClass);\n nextFrame(function () {\n removeTransitionClass(el, startClass);\n if (!cb.cancelled) {\n addTransitionClass(el, toClass);\n if (!userWantsControl) {\n if (isValidDuration(explicitEnterDuration)) {\n setTimeout(cb, explicitEnterDuration);\n } else {\n whenTransitionEnds(el, type, cb);\n }\n }\n }\n });\n }\n\n if (vnode.data.show) {\n toggleDisplay && toggleDisplay();\n enterHook && enterHook(el, cb);\n }\n\n if (!expectsCSS && !userWantsControl) {\n cb();\n }\n}\n\nfunction leave (vnode, rm) {\n var el = vnode.elm;\n\n // call enter callback now\n if (isDef(el._enterCb)) {\n el._enterCb.cancelled = true;\n el._enterCb();\n }\n\n var data = resolveTransition(vnode.data.transition);\n if (isUndef(data) || el.nodeType !== 1) {\n return rm()\n }\n\n /* istanbul ignore if */\n if (isDef(el._leaveCb)) {\n return\n }\n\n var css = data.css;\n var type = data.type;\n var leaveClass = data.leaveClass;\n var leaveToClass = data.leaveToClass;\n var leaveActiveClass = data.leaveActiveClass;\n var beforeLeave = data.beforeLeave;\n var leave = data.leave;\n var afterLeave = data.afterLeave;\n var leaveCancelled = data.leaveCancelled;\n var delayLeave = data.delayLeave;\n var duration = data.duration;\n\n var expectsCSS = css !== false && !isIE9;\n var userWantsControl = getHookArgumentsLength(leave);\n\n var explicitLeaveDuration = toNumber(\n isObject(duration)\n ? duration.leave\n : duration\n );\n\n if ( true && isDef(explicitLeaveDuration)) {\n checkDuration(explicitLeaveDuration, 'leave', vnode);\n }\n\n var cb = el._leaveCb = once(function () {\n if (el.parentNode && el.parentNode._pending) {\n el.parentNode._pending[vnode.key] = null;\n }\n if (expectsCSS) {\n removeTransitionClass(el, leaveToClass);\n removeTransitionClass(el, leaveActiveClass);\n }\n if (cb.cancelled) {\n if (expectsCSS) {\n removeTransitionClass(el, leaveClass);\n }\n leaveCancelled && leaveCancelled(el);\n } else {\n rm();\n afterLeave && afterLeave(el);\n }\n el._leaveCb = null;\n });\n\n if (delayLeave) {\n delayLeave(performLeave);\n } else {\n performLeave();\n }\n\n function performLeave () {\n // the delayed leave may have already been cancelled\n if (cb.cancelled) {\n return\n }\n // record leaving element\n if (!vnode.data.show && el.parentNode) {\n (el.parentNode._pending || (el.parentNode._pending = {}))[(vnode.key)] = vnode;\n }\n beforeLeave && beforeLeave(el);\n if (expectsCSS) {\n addTransitionClass(el, leaveClass);\n addTransitionClass(el, leaveActiveClass);\n nextFrame(function () {\n removeTransitionClass(el, leaveClass);\n if (!cb.cancelled) {\n addTransitionClass(el, leaveToClass);\n if (!userWantsControl) {\n if (isValidDuration(explicitLeaveDuration)) {\n setTimeout(cb, explicitLeaveDuration);\n } else {\n whenTransitionEnds(el, type, cb);\n }\n }\n }\n });\n }\n leave && leave(el, cb);\n if (!expectsCSS && !userWantsControl) {\n cb();\n }\n }\n}\n\n// only used in dev mode\nfunction checkDuration (val, name, vnode) {\n if (typeof val !== 'number') {\n warn(\n \"<transition> explicit \" + name + \" duration is not a valid number - \" +\n \"got \" + (JSON.stringify(val)) + \".\",\n vnode.context\n );\n } else if (isNaN(val)) {\n warn(\n \"<transition> explicit \" + name + \" duration is NaN - \" +\n 'the duration expression might be incorrect.',\n vnode.context\n );\n }\n}\n\nfunction isValidDuration (val) {\n return typeof val === 'number' && !isNaN(val)\n}\n\n/**\n * Normalize a transition hook's argument length. The hook may be:\n * - a merged hook (invoker) with the original in .fns\n * - a wrapped component method (check ._length)\n * - a plain function (.length)\n */\nfunction getHookArgumentsLength (fn) {\n if (isUndef(fn)) {\n return false\n }\n var invokerFns = fn.fns;\n if (isDef(invokerFns)) {\n // invoker\n return getHookArgumentsLength(\n Array.isArray(invokerFns)\n ? invokerFns[0]\n : invokerFns\n )\n } else {\n return (fn._length || fn.length) > 1\n }\n}\n\nfunction _enter (_, vnode) {\n if (vnode.data.show !== true) {\n enter(vnode);\n }\n}\n\nvar transition = inBrowser ? {\n create: _enter,\n activate: _enter,\n remove: function remove$$1 (vnode, rm) {\n /* istanbul ignore else */\n if (vnode.data.show !== true) {\n leave(vnode, rm);\n } else {\n rm();\n }\n }\n} : {};\n\nvar platformModules = [\n attrs,\n klass,\n events,\n domProps,\n style,\n transition\n];\n\n/* */\n\n// the directive module should be applied last, after all\n// built-in modules have been applied.\nvar modules = platformModules.concat(baseModules);\n\nvar patch = createPatchFunction({ nodeOps: nodeOps, modules: modules });\n\n/**\n * Not type checking this file because flow doesn't like attaching\n * properties to Elements.\n */\n\n/* istanbul ignore if */\nif (isIE9) {\n // http://www.matts411.com/post/internet-explorer-9-oninput/\n document.addEventListener('selectionchange', function () {\n var el = document.activeElement;\n if (el && el.vmodel) {\n trigger(el, 'input');\n }\n });\n}\n\nvar directive = {\n inserted: function inserted (el, binding, vnode, oldVnode) {\n if (vnode.tag === 'select') {\n // #6903\n if (oldVnode.elm && !oldVnode.elm._vOptions) {\n mergeVNodeHook(vnode, 'postpatch', function () {\n directive.componentUpdated(el, binding, vnode);\n });\n } else {\n setSelected(el, binding, vnode.context);\n }\n el._vOptions = [].map.call(el.options, getValue);\n } else if (vnode.tag === 'textarea' || isTextInputType(el.type)) {\n el._vModifiers = binding.modifiers;\n if (!binding.modifiers.lazy) {\n el.addEventListener('compositionstart', onCompositionStart);\n el.addEventListener('compositionend', onCompositionEnd);\n // Safari < 10.2 & UIWebView doesn't fire compositionend when\n // switching focus before confirming composition choice\n // this also fixes the issue where some browsers e.g. iOS Chrome\n // fires \"change\" instead of \"input\" on autocomplete.\n el.addEventListener('change', onCompositionEnd);\n /* istanbul ignore if */\n if (isIE9) {\n el.vmodel = true;\n }\n }\n }\n },\n\n componentUpdated: function componentUpdated (el, binding, vnode) {\n if (vnode.tag === 'select') {\n setSelected(el, binding, vnode.context);\n // in case the options rendered by v-for have changed,\n // it's possible that the value is out-of-sync with the rendered options.\n // detect such cases and filter out values that no longer has a matching\n // option in the DOM.\n var prevOptions = el._vOptions;\n var curOptions = el._vOptions = [].map.call(el.options, getValue);\n if (curOptions.some(function (o, i) { return !looseEqual(o, prevOptions[i]); })) {\n // trigger change event if\n // no matching option found for at least one value\n var needReset = el.multiple\n ? binding.value.some(function (v) { return hasNoMatchingOption(v, curOptions); })\n : binding.value !== binding.oldValue && hasNoMatchingOption(binding.value, curOptions);\n if (needReset) {\n trigger(el, 'change');\n }\n }\n }\n }\n};\n\nfunction setSelected (el, binding, vm) {\n actuallySetSelected(el, binding, vm);\n /* istanbul ignore if */\n if (isIE || isEdge) {\n setTimeout(function () {\n actuallySetSelected(el, binding, vm);\n }, 0);\n }\n}\n\nfunction actuallySetSelected (el, binding, vm) {\n var value = binding.value;\n var isMultiple = el.multiple;\n if (isMultiple && !Array.isArray(value)) {\n true && warn(\n \"<select multiple v-model=\\\"\" + (binding.expression) + \"\\\"> \" +\n \"expects an Array value for its binding, but got \" + (Object.prototype.toString.call(value).slice(8, -1)),\n vm\n );\n return\n }\n var selected, option;\n for (var i = 0, l = el.options.length; i < l; i++) {\n option = el.options[i];\n if (isMultiple) {\n selected = looseIndexOf(value, getValue(option)) > -1;\n if (option.selected !== selected) {\n option.selected = selected;\n }\n } else {\n if (looseEqual(getValue(option), value)) {\n if (el.selectedIndex !== i) {\n el.selectedIndex = i;\n }\n return\n }\n }\n }\n if (!isMultiple) {\n el.selectedIndex = -1;\n }\n}\n\nfunction hasNoMatchingOption (value, options) {\n return options.every(function (o) { return !looseEqual(o, value); })\n}\n\nfunction getValue (option) {\n return '_value' in option\n ? option._value\n : option.value\n}\n\nfunction onCompositionStart (e) {\n e.target.composing = true;\n}\n\nfunction onCompositionEnd (e) {\n // prevent triggering an input event for no reason\n if (!e.target.composing) { return }\n e.target.composing = false;\n trigger(e.target, 'input');\n}\n\nfunction trigger (el, type) {\n var e = document.createEvent('HTMLEvents');\n e.initEvent(type, true, true);\n el.dispatchEvent(e);\n}\n\n/* */\n\n// recursively search for possible transition defined inside the component root\nfunction locateNode (vnode) {\n return vnode.componentInstance && (!vnode.data || !vnode.data.transition)\n ? locateNode(vnode.componentInstance._vnode)\n : vnode\n}\n\nvar show = {\n bind: function bind (el, ref, vnode) {\n var value = ref.value;\n\n vnode = locateNode(vnode);\n var transition$$1 = vnode.data && vnode.data.transition;\n var originalDisplay = el.__vOriginalDisplay =\n el.style.display === 'none' ? '' : el.style.display;\n if (value && transition$$1) {\n vnode.data.show = true;\n enter(vnode, function () {\n el.style.display = originalDisplay;\n });\n } else {\n el.style.display = value ? originalDisplay : 'none';\n }\n },\n\n update: function update (el, ref, vnode) {\n var value = ref.value;\n var oldValue = ref.oldValue;\n\n /* istanbul ignore if */\n if (!value === !oldValue) { return }\n vnode = locateNode(vnode);\n var transition$$1 = vnode.data && vnode.data.transition;\n if (transition$$1) {\n vnode.data.show = true;\n if (value) {\n enter(vnode, function () {\n el.style.display = el.__vOriginalDisplay;\n });\n } else {\n leave(vnode, function () {\n el.style.display = 'none';\n });\n }\n } else {\n el.style.display = value ? el.__vOriginalDisplay : 'none';\n }\n },\n\n unbind: function unbind (\n el,\n binding,\n vnode,\n oldVnode,\n isDestroy\n ) {\n if (!isDestroy) {\n el.style.display = el.__vOriginalDisplay;\n }\n }\n};\n\nvar platformDirectives = {\n model: directive,\n show: show\n};\n\n/* */\n\nvar transitionProps = {\n name: String,\n appear: Boolean,\n css: Boolean,\n mode: String,\n type: String,\n enterClass: String,\n leaveClass: String,\n enterToClass: String,\n leaveToClass: String,\n enterActiveClass: String,\n leaveActiveClass: String,\n appearClass: String,\n appearActiveClass: String,\n appearToClass: String,\n duration: [Number, String, Object]\n};\n\n// in case the child is also an abstract component, e.g. <keep-alive>\n// we want to recursively retrieve the real component to be rendered\nfunction getRealChild (vnode) {\n var compOptions = vnode && vnode.componentOptions;\n if (compOptions && compOptions.Ctor.options.abstract) {\n return getRealChild(getFirstComponentChild(compOptions.children))\n } else {\n return vnode\n }\n}\n\nfunction extractTransitionData (comp) {\n var data = {};\n var options = comp.$options;\n // props\n for (var key in options.propsData) {\n data[key] = comp[key];\n }\n // events.\n // extract listeners and pass them directly to the transition methods\n var listeners = options._parentListeners;\n for (var key$1 in listeners) {\n data[camelize(key$1)] = listeners[key$1];\n }\n return data\n}\n\nfunction placeholder (h, rawChild) {\n if (/\\d-keep-alive$/.test(rawChild.tag)) {\n return h('keep-alive', {\n props: rawChild.componentOptions.propsData\n })\n }\n}\n\nfunction hasParentTransition (vnode) {\n while ((vnode = vnode.parent)) {\n if (vnode.data.transition) {\n return true\n }\n }\n}\n\nfunction isSameChild (child, oldChild) {\n return oldChild.key === child.key && oldChild.tag === child.tag\n}\n\nvar isNotTextNode = function (c) { return c.tag || isAsyncPlaceholder(c); };\n\nvar isVShowDirective = function (d) { return d.name === 'show'; };\n\nvar Transition = {\n name: 'transition',\n props: transitionProps,\n abstract: true,\n\n render: function render (h) {\n var this$1 = this;\n\n var children = this.$slots.default;\n if (!children) {\n return\n }\n\n // filter out text nodes (possible whitespaces)\n children = children.filter(isNotTextNode);\n /* istanbul ignore if */\n if (!children.length) {\n return\n }\n\n // warn multiple elements\n if ( true && children.length > 1) {\n warn(\n '<transition> can only be used on a single element. Use ' +\n '<transition-group> for lists.',\n this.$parent\n );\n }\n\n var mode = this.mode;\n\n // warn invalid mode\n if ( true &&\n mode && mode !== 'in-out' && mode !== 'out-in'\n ) {\n warn(\n 'invalid <transition> mode: ' + mode,\n this.$parent\n );\n }\n\n var rawChild = children[0];\n\n // if this is a component root node and the component's\n // parent container node also has transition, skip.\n if (hasParentTransition(this.$vnode)) {\n return rawChild\n }\n\n // apply transition data to child\n // use getRealChild() to ignore abstract components e.g. keep-alive\n var child = getRealChild(rawChild);\n /* istanbul ignore if */\n if (!child) {\n return rawChild\n }\n\n if (this._leaving) {\n return placeholder(h, rawChild)\n }\n\n // ensure a key that is unique to the vnode type and to this transition\n // component instance. This key will be used to remove pending leaving nodes\n // during entering.\n var id = \"__transition-\" + (this._uid) + \"-\";\n child.key = child.key == null\n ? child.isComment\n ? id + 'comment'\n : id + child.tag\n : isPrimitive(child.key)\n ? (String(child.key).indexOf(id) === 0 ? child.key : id + child.key)\n : child.key;\n\n var data = (child.data || (child.data = {})).transition = extractTransitionData(this);\n var oldRawChild = this._vnode;\n var oldChild = getRealChild(oldRawChild);\n\n // mark v-show\n // so that the transition module can hand over the control to the directive\n if (child.data.directives && child.data.directives.some(isVShowDirective)) {\n child.data.show = true;\n }\n\n if (\n oldChild &&\n oldChild.data &&\n !isSameChild(child, oldChild) &&\n !isAsyncPlaceholder(oldChild) &&\n // #6687 component root is a comment node\n !(oldChild.componentInstance && oldChild.componentInstance._vnode.isComment)\n ) {\n // replace old child transition data with fresh one\n // important for dynamic transitions!\n var oldData = oldChild.data.transition = extend({}, data);\n // handle transition mode\n if (mode === 'out-in') {\n // return placeholder node and queue update when leave finishes\n this._leaving = true;\n mergeVNodeHook(oldData, 'afterLeave', function () {\n this$1._leaving = false;\n this$1.$forceUpdate();\n });\n return placeholder(h, rawChild)\n } else if (mode === 'in-out') {\n if (isAsyncPlaceholder(child)) {\n return oldRawChild\n }\n var delayedLeave;\n var performLeave = function () { delayedLeave(); };\n mergeVNodeHook(data, 'afterEnter', performLeave);\n mergeVNodeHook(data, 'enterCancelled', performLeave);\n mergeVNodeHook(oldData, 'delayLeave', function (leave) { delayedLeave = leave; });\n }\n }\n\n return rawChild\n }\n};\n\n/* */\n\nvar props = extend({\n tag: String,\n moveClass: String\n}, transitionProps);\n\ndelete props.mode;\n\nvar TransitionGroup = {\n props: props,\n\n beforeMount: function beforeMount () {\n var this$1 = this;\n\n var update = this._update;\n this._update = function (vnode, hydrating) {\n var restoreActiveInstance = setActiveInstance(this$1);\n // force removing pass\n this$1.__patch__(\n this$1._vnode,\n this$1.kept,\n false, // hydrating\n true // removeOnly (!important, avoids unnecessary moves)\n );\n this$1._vnode = this$1.kept;\n restoreActiveInstance();\n update.call(this$1, vnode, hydrating);\n };\n },\n\n render: function render (h) {\n var tag = this.tag || this.$vnode.data.tag || 'span';\n var map = Object.create(null);\n var prevChildren = this.prevChildren = this.children;\n var rawChildren = this.$slots.default || [];\n var children = this.children = [];\n var transitionData = extractTransitionData(this);\n\n for (var i = 0; i < rawChildren.length; i++) {\n var c = rawChildren[i];\n if (c.tag) {\n if (c.key != null && String(c.key).indexOf('__vlist') !== 0) {\n children.push(c);\n map[c.key] = c\n ;(c.data || (c.data = {})).transition = transitionData;\n } else if (true) {\n var opts = c.componentOptions;\n var name = opts ? (opts.Ctor.options.name || opts.tag || '') : c.tag;\n warn((\"<transition-group> children must be keyed: <\" + name + \">\"));\n }\n }\n }\n\n if (prevChildren) {\n var kept = [];\n var removed = [];\n for (var i$1 = 0; i$1 < prevChildren.length; i$1++) {\n var c$1 = prevChildren[i$1];\n c$1.data.transition = transitionData;\n c$1.data.pos = c$1.elm.getBoundingClientRect();\n if (map[c$1.key]) {\n kept.push(c$1);\n } else {\n removed.push(c$1);\n }\n }\n this.kept = h(tag, null, kept);\n this.removed = removed;\n }\n\n return h(tag, null, children)\n },\n\n updated: function updated () {\n var children = this.prevChildren;\n var moveClass = this.moveClass || ((this.name || 'v') + '-move');\n if (!children.length || !this.hasMove(children[0].elm, moveClass)) {\n return\n }\n\n // we divide the work into three loops to avoid mixing DOM reads and writes\n // in each iteration - which helps prevent layout thrashing.\n children.forEach(callPendingCbs);\n children.forEach(recordPosition);\n children.forEach(applyTranslation);\n\n // force reflow to put everything in position\n // assign to this to avoid being removed in tree-shaking\n // $flow-disable-line\n this._reflow = document.body.offsetHeight;\n\n children.forEach(function (c) {\n if (c.data.moved) {\n var el = c.elm;\n var s = el.style;\n addTransitionClass(el, moveClass);\n s.transform = s.WebkitTransform = s.transitionDuration = '';\n el.addEventListener(transitionEndEvent, el._moveCb = function cb (e) {\n if (e && e.target !== el) {\n return\n }\n if (!e || /transform$/.test(e.propertyName)) {\n el.removeEventListener(transitionEndEvent, cb);\n el._moveCb = null;\n removeTransitionClass(el, moveClass);\n }\n });\n }\n });\n },\n\n methods: {\n hasMove: function hasMove (el, moveClass) {\n /* istanbul ignore if */\n if (!hasTransition) {\n return false\n }\n /* istanbul ignore if */\n if (this._hasMove) {\n return this._hasMove\n }\n // Detect whether an element with the move class applied has\n // CSS transitions. Since the element may be inside an entering\n // transition at this very moment, we make a clone of it and remove\n // all other transition classes applied to ensure only the move class\n // is applied.\n var clone = el.cloneNode();\n if (el._transitionClasses) {\n el._transitionClasses.forEach(function (cls) { removeClass(clone, cls); });\n }\n addClass(clone, moveClass);\n clone.style.display = 'none';\n this.$el.appendChild(clone);\n var info = getTransitionInfo(clone);\n this.$el.removeChild(clone);\n return (this._hasMove = info.hasTransform)\n }\n }\n};\n\nfunction callPendingCbs (c) {\n /* istanbul ignore if */\n if (c.elm._moveCb) {\n c.elm._moveCb();\n }\n /* istanbul ignore if */\n if (c.elm._enterCb) {\n c.elm._enterCb();\n }\n}\n\nfunction recordPosition (c) {\n c.data.newPos = c.elm.getBoundingClientRect();\n}\n\nfunction applyTranslation (c) {\n var oldPos = c.data.pos;\n var newPos = c.data.newPos;\n var dx = oldPos.left - newPos.left;\n var dy = oldPos.top - newPos.top;\n if (dx || dy) {\n c.data.moved = true;\n var s = c.elm.style;\n s.transform = s.WebkitTransform = \"translate(\" + dx + \"px,\" + dy + \"px)\";\n s.transitionDuration = '0s';\n }\n}\n\nvar platformComponents = {\n Transition: Transition,\n TransitionGroup: TransitionGroup\n};\n\n/* */\n\n// install platform specific utils\nVue.config.mustUseProp = mustUseProp;\nVue.config.isReservedTag = isReservedTag;\nVue.config.isReservedAttr = isReservedAttr;\nVue.config.getTagNamespace = getTagNamespace;\nVue.config.isUnknownElement = isUnknownElement;\n\n// install platform runtime directives & components\nextend(Vue.options.directives, platformDirectives);\nextend(Vue.options.components, platformComponents);\n\n// install platform patch function\nVue.prototype.__patch__ = inBrowser ? patch : noop;\n\n// public mount method\nVue.prototype.$mount = function (\n el,\n hydrating\n) {\n el = el && inBrowser ? query(el) : undefined;\n return mountComponent(this, el, hydrating)\n};\n\n// devtools global hook\n/* istanbul ignore next */\nif (inBrowser) {\n setTimeout(function () {\n if (config.devtools) {\n if (devtools) {\n devtools.emit('init', Vue);\n } else if (\n true\n ) {\n console[console.info ? 'info' : 'log'](\n 'Download the Vue Devtools extension for a better development experience:\\n' +\n 'https://github.com/vuejs/vue-devtools'\n );\n }\n }\n if ( true &&\n config.productionTip !== false &&\n typeof console !== 'undefined'\n ) {\n console[console.info ? 'info' : 'log'](\n \"You are running Vue in development mode.\\n\" +\n \"Make sure to turn on production mode when deploying for production.\\n\" +\n \"See more tips at https://vuejs.org/guide/deployment.html\"\n );\n }\n }, 0);\n}\n\n/* */\n\nvar defaultTagRE = /\\{\\{((?:.|\\r?\\n)+?)\\}\\}/g;\nvar regexEscapeRE = /[-.*+?^${}()|[\\]\\/\\\\]/g;\n\nvar buildRegex = cached(function (delimiters) {\n var open = delimiters[0].replace(regexEscapeRE, '\\\\$&');\n var close = delimiters[1].replace(regexEscapeRE, '\\\\$&');\n return new RegExp(open + '((?:.|\\\\n)+?)' + close, 'g')\n});\n\n\n\nfunction parseText (\n text,\n delimiters\n) {\n var tagRE = delimiters ? buildRegex(delimiters) : defaultTagRE;\n if (!tagRE.test(text)) {\n return\n }\n var tokens = [];\n var rawTokens = [];\n var lastIndex = tagRE.lastIndex = 0;\n var match, index, tokenValue;\n while ((match = tagRE.exec(text))) {\n index = match.index;\n // push text token\n if (index > lastIndex) {\n rawTokens.push(tokenValue = text.slice(lastIndex, index));\n tokens.push(JSON.stringify(tokenValue));\n }\n // tag token\n var exp = parseFilters(match[1].trim());\n tokens.push((\"_s(\" + exp + \")\"));\n rawTokens.push({ '@binding': exp });\n lastIndex = index + match[0].length;\n }\n if (lastIndex < text.length) {\n rawTokens.push(tokenValue = text.slice(lastIndex));\n tokens.push(JSON.stringify(tokenValue));\n }\n return {\n expression: tokens.join('+'),\n tokens: rawTokens\n }\n}\n\n/* */\n\nfunction transformNode (el, options) {\n var warn = options.warn || baseWarn;\n var staticClass = getAndRemoveAttr(el, 'class');\n if ( true && staticClass) {\n var res = parseText(staticClass, options.delimiters);\n if (res) {\n warn(\n \"class=\\\"\" + staticClass + \"\\\": \" +\n 'Interpolation inside attributes has been removed. ' +\n 'Use v-bind or the colon shorthand instead. For example, ' +\n 'instead of <div class=\"{{ val }}\">, use <div :class=\"val\">.',\n el.rawAttrsMap['class']\n );\n }\n }\n if (staticClass) {\n el.staticClass = JSON.stringify(staticClass);\n }\n var classBinding = getBindingAttr(el, 'class', false /* getStatic */);\n if (classBinding) {\n el.classBinding = classBinding;\n }\n}\n\nfunction genData (el) {\n var data = '';\n if (el.staticClass) {\n data += \"staticClass:\" + (el.staticClass) + \",\";\n }\n if (el.classBinding) {\n data += \"class:\" + (el.classBinding) + \",\";\n }\n return data\n}\n\nvar klass$1 = {\n staticKeys: ['staticClass'],\n transformNode: transformNode,\n genData: genData\n};\n\n/* */\n\nfunction transformNode$1 (el, options) {\n var warn = options.warn || baseWarn;\n var staticStyle = getAndRemoveAttr(el, 'style');\n if (staticStyle) {\n /* istanbul ignore if */\n if (true) {\n var res = parseText(staticStyle, options.delimiters);\n if (res) {\n warn(\n \"style=\\\"\" + staticStyle + \"\\\": \" +\n 'Interpolation inside attributes has been removed. ' +\n 'Use v-bind or the colon shorthand instead. For example, ' +\n 'instead of <div style=\"{{ val }}\">, use <div :style=\"val\">.',\n el.rawAttrsMap['style']\n );\n }\n }\n el.staticStyle = JSON.stringify(parseStyleText(staticStyle));\n }\n\n var styleBinding = getBindingAttr(el, 'style', false /* getStatic */);\n if (styleBinding) {\n el.styleBinding = styleBinding;\n }\n}\n\nfunction genData$1 (el) {\n var data = '';\n if (el.staticStyle) {\n data += \"staticStyle:\" + (el.staticStyle) + \",\";\n }\n if (el.styleBinding) {\n data += \"style:(\" + (el.styleBinding) + \"),\";\n }\n return data\n}\n\nvar style$1 = {\n staticKeys: ['staticStyle'],\n transformNode: transformNode$1,\n genData: genData$1\n};\n\n/* */\n\nvar decoder;\n\nvar he = {\n decode: function decode (html) {\n decoder = decoder || document.createElement('div');\n decoder.innerHTML = html;\n return decoder.textContent\n }\n};\n\n/* */\n\nvar isUnaryTag = makeMap(\n 'area,base,br,col,embed,frame,hr,img,input,isindex,keygen,' +\n 'link,meta,param,source,track,wbr'\n);\n\n// Elements that you can, intentionally, leave open\n// (and which close themselves)\nvar canBeLeftOpenTag = makeMap(\n 'colgroup,dd,dt,li,options,p,td,tfoot,th,thead,tr,source'\n);\n\n// HTML5 tags https://html.spec.whatwg.org/multipage/indices.html#elements-3\n// Phrasing Content https://html.spec.whatwg.org/multipage/dom.html#phrasing-content\nvar isNonPhrasingTag = makeMap(\n 'address,article,aside,base,blockquote,body,caption,col,colgroup,dd,' +\n 'details,dialog,div,dl,dt,fieldset,figcaption,figure,footer,form,' +\n 'h1,h2,h3,h4,h5,h6,head,header,hgroup,hr,html,legend,li,menuitem,meta,' +\n 'optgroup,option,param,rp,rt,source,style,summary,tbody,td,tfoot,th,thead,' +\n 'title,tr,track'\n);\n\n/**\n * Not type-checking this file because it's mostly vendor code.\n */\n\n// Regular Expressions for parsing tags and attributes\nvar attribute = /^\\s*([^\\s\"'<>\\/=]+)(?:\\s*(=)\\s*(?:\"([^\"]*)\"+|'([^']*)'+|([^\\s\"'=<>`]+)))?/;\nvar dynamicArgAttribute = /^\\s*((?:v-[\\w-]+:|@|:|#)\\[[^=]+\\][^\\s\"'<>\\/=]*)(?:\\s*(=)\\s*(?:\"([^\"]*)\"+|'([^']*)'+|([^\\s\"'=<>`]+)))?/;\nvar ncname = \"[a-zA-Z_][\\\\-\\\\.0-9_a-zA-Z\" + (unicodeRegExp.source) + \"]*\";\nvar qnameCapture = \"((?:\" + ncname + \"\\\\:)?\" + ncname + \")\";\nvar startTagOpen = new RegExp((\"^<\" + qnameCapture));\nvar startTagClose = /^\\s*(\\/?)>/;\nvar endTag = new RegExp((\"^<\\\\/\" + qnameCapture + \"[^>]*>\"));\nvar doctype = /^<!DOCTYPE [^>]+>/i;\n// #7298: escape - to avoid being passed as HTML comment when inlined in page\nvar comment = /^<!\\--/;\nvar conditionalComment = /^<!\\[/;\n\n// Special Elements (can contain anything)\nvar isPlainTextElement = makeMap('script,style,textarea', true);\nvar reCache = {};\n\nvar decodingMap = {\n '<': '<',\n '>': '>',\n '"': '\"',\n '&': '&',\n ' ': '\\n',\n '	': '\\t',\n ''': \"'\"\n};\nvar encodedAttr = /&(?:lt|gt|quot|amp|#39);/g;\nvar encodedAttrWithNewLines = /&(?:lt|gt|quot|amp|#39|#10|#9);/g;\n\n// #5992\nvar isIgnoreNewlineTag = makeMap('pre,textarea', true);\nvar shouldIgnoreFirstNewline = function (tag, html) { return tag && isIgnoreNewlineTag(tag) && html[0] === '\\n'; };\n\nfunction decodeAttr (value, shouldDecodeNewlines) {\n var re = shouldDecodeNewlines ? encodedAttrWithNewLines : encodedAttr;\n return value.replace(re, function (match) { return decodingMap[match]; })\n}\n\nfunction parseHTML (html, options) {\n var stack = [];\n var expectHTML = options.expectHTML;\n var isUnaryTag$$1 = options.isUnaryTag || no;\n var canBeLeftOpenTag$$1 = options.canBeLeftOpenTag || no;\n var index = 0;\n var last, lastTag;\n while (html) {\n last = html;\n // Make sure we're not in a plaintext content element like script/style\n if (!lastTag || !isPlainTextElement(lastTag)) {\n var textEnd = html.indexOf('<');\n if (textEnd === 0) {\n // Comment:\n if (comment.test(html)) {\n var commentEnd = html.indexOf('-->');\n\n if (commentEnd >= 0) {\n if (options.shouldKeepComment) {\n options.comment(html.substring(4, commentEnd), index, index + commentEnd + 3);\n }\n advance(commentEnd + 3);\n continue\n }\n }\n\n // http://en.wikipedia.org/wiki/Conditional_comment#Downlevel-revealed_conditional_comment\n if (conditionalComment.test(html)) {\n var conditionalEnd = html.indexOf(']>');\n\n if (conditionalEnd >= 0) {\n advance(conditionalEnd + 2);\n continue\n }\n }\n\n // Doctype:\n var doctypeMatch = html.match(doctype);\n if (doctypeMatch) {\n advance(doctypeMatch[0].length);\n continue\n }\n\n // End tag:\n var endTagMatch = html.match(endTag);\n if (endTagMatch) {\n var curIndex = index;\n advance(endTagMatch[0].length);\n parseEndTag(endTagMatch[1], curIndex, index);\n continue\n }\n\n // Start tag:\n var startTagMatch = parseStartTag();\n if (startTagMatch) {\n handleStartTag(startTagMatch);\n if (shouldIgnoreFirstNewline(startTagMatch.tagName, html)) {\n advance(1);\n }\n continue\n }\n }\n\n var text = (void 0), rest = (void 0), next = (void 0);\n if (textEnd >= 0) {\n rest = html.slice(textEnd);\n while (\n !endTag.test(rest) &&\n !startTagOpen.test(rest) &&\n !comment.test(rest) &&\n !conditionalComment.test(rest)\n ) {\n // < in plain text, be forgiving and treat it as text\n next = rest.indexOf('<', 1);\n if (next < 0) { break }\n textEnd += next;\n rest = html.slice(textEnd);\n }\n text = html.substring(0, textEnd);\n }\n\n if (textEnd < 0) {\n text = html;\n }\n\n if (text) {\n advance(text.length);\n }\n\n if (options.chars && text) {\n options.chars(text, index - text.length, index);\n }\n } else {\n var endTagLength = 0;\n var stackedTag = lastTag.toLowerCase();\n var reStackedTag = reCache[stackedTag] || (reCache[stackedTag] = new RegExp('([\\\\s\\\\S]*?)(</' + stackedTag + '[^>]*>)', 'i'));\n var rest$1 = html.replace(reStackedTag, function (all, text, endTag) {\n endTagLength = endTag.length;\n if (!isPlainTextElement(stackedTag) && stackedTag !== 'noscript') {\n text = text\n .replace(/<!\\--([\\s\\S]*?)-->/g, '$1') // #7298\n .replace(/<!\\[CDATA\\[([\\s\\S]*?)]]>/g, '$1');\n }\n if (shouldIgnoreFirstNewline(stackedTag, text)) {\n text = text.slice(1);\n }\n if (options.chars) {\n options.chars(text);\n }\n return ''\n });\n index += html.length - rest$1.length;\n html = rest$1;\n parseEndTag(stackedTag, index - endTagLength, index);\n }\n\n if (html === last) {\n options.chars && options.chars(html);\n if ( true && !stack.length && options.warn) {\n options.warn((\"Mal-formatted tag at end of template: \\\"\" + html + \"\\\"\"), { start: index + html.length });\n }\n break\n }\n }\n\n // Clean up any remaining tags\n parseEndTag();\n\n function advance (n) {\n index += n;\n html = html.substring(n);\n }\n\n function parseStartTag () {\n var start = html.match(startTagOpen);\n if (start) {\n var match = {\n tagName: start[1],\n attrs: [],\n start: index\n };\n advance(start[0].length);\n var end, attr;\n while (!(end = html.match(startTagClose)) && (attr = html.match(dynamicArgAttribute) || html.match(attribute))) {\n attr.start = index;\n advance(attr[0].length);\n attr.end = index;\n match.attrs.push(attr);\n }\n if (end) {\n match.unarySlash = end[1];\n advance(end[0].length);\n match.end = index;\n return match\n }\n }\n }\n\n function handleStartTag (match) {\n var tagName = match.tagName;\n var unarySlash = match.unarySlash;\n\n if (expectHTML) {\n if (lastTag === 'p' && isNonPhrasingTag(tagName)) {\n parseEndTag(lastTag);\n }\n if (canBeLeftOpenTag$$1(tagName) && lastTag === tagName) {\n parseEndTag(tagName);\n }\n }\n\n var unary = isUnaryTag$$1(tagName) || !!unarySlash;\n\n var l = match.attrs.length;\n var attrs = new Array(l);\n for (var i = 0; i < l; i++) {\n var args = match.attrs[i];\n var value = args[3] || args[4] || args[5] || '';\n var shouldDecodeNewlines = tagName === 'a' && args[1] === 'href'\n ? options.shouldDecodeNewlinesForHref\n : options.shouldDecodeNewlines;\n attrs[i] = {\n name: args[1],\n value: decodeAttr(value, shouldDecodeNewlines)\n };\n if ( true && options.outputSourceRange) {\n attrs[i].start = args.start + args[0].match(/^\\s*/).length;\n attrs[i].end = args.end;\n }\n }\n\n if (!unary) {\n stack.push({ tag: tagName, lowerCasedTag: tagName.toLowerCase(), attrs: attrs, start: match.start, end: match.end });\n lastTag = tagName;\n }\n\n if (options.start) {\n options.start(tagName, attrs, unary, match.start, match.end);\n }\n }\n\n function parseEndTag (tagName, start, end) {\n var pos, lowerCasedTagName;\n if (start == null) { start = index; }\n if (end == null) { end = index; }\n\n // Find the closest opened tag of the same type\n if (tagName) {\n lowerCasedTagName = tagName.toLowerCase();\n for (pos = stack.length - 1; pos >= 0; pos--) {\n if (stack[pos].lowerCasedTag === lowerCasedTagName) {\n break\n }\n }\n } else {\n // If no tag name is provided, clean shop\n pos = 0;\n }\n\n if (pos >= 0) {\n // Close all the open elements, up the stack\n for (var i = stack.length - 1; i >= pos; i--) {\n if ( true &&\n (i > pos || !tagName) &&\n options.warn\n ) {\n options.warn(\n (\"tag <\" + (stack[i].tag) + \"> has no matching end tag.\"),\n { start: stack[i].start, end: stack[i].end }\n );\n }\n if (options.end) {\n options.end(stack[i].tag, start, end);\n }\n }\n\n // Remove the open elements from the stack\n stack.length = pos;\n lastTag = pos && stack[pos - 1].tag;\n } else if (lowerCasedTagName === 'br') {\n if (options.start) {\n options.start(tagName, [], true, start, end);\n }\n } else if (lowerCasedTagName === 'p') {\n if (options.start) {\n options.start(tagName, [], false, start, end);\n }\n if (options.end) {\n options.end(tagName, start, end);\n }\n }\n }\n}\n\n/* */\n\nvar onRE = /^@|^v-on:/;\nvar dirRE = /^v-|^@|^:|^#/;\nvar forAliasRE = /([\\s\\S]*?)\\s+(?:in|of)\\s+([\\s\\S]*)/;\nvar forIteratorRE = /,([^,\\}\\]]*)(?:,([^,\\}\\]]*))?$/;\nvar stripParensRE = /^\\(|\\)$/g;\nvar dynamicArgRE = /^\\[.*\\]$/;\n\nvar argRE = /:(.*)$/;\nvar bindRE = /^:|^\\.|^v-bind:/;\nvar modifierRE = /\\.[^.\\]]+(?=[^\\]]*$)/g;\n\nvar slotRE = /^v-slot(:|$)|^#/;\n\nvar lineBreakRE = /[\\r\\n]/;\nvar whitespaceRE$1 = /\\s+/g;\n\nvar invalidAttributeRE = /[\\s\"'<>\\/=]/;\n\nvar decodeHTMLCached = cached(he.decode);\n\nvar emptySlotScopeToken = \"_empty_\";\n\n// configurable state\nvar warn$2;\nvar delimiters;\nvar transforms;\nvar preTransforms;\nvar postTransforms;\nvar platformIsPreTag;\nvar platformMustUseProp;\nvar platformGetTagNamespace;\nvar maybeComponent;\n\nfunction createASTElement (\n tag,\n attrs,\n parent\n) {\n return {\n type: 1,\n tag: tag,\n attrsList: attrs,\n attrsMap: makeAttrsMap(attrs),\n rawAttrsMap: {},\n parent: parent,\n children: []\n }\n}\n\n/**\n * Convert HTML string to AST.\n */\nfunction parse (\n template,\n options\n) {\n warn$2 = options.warn || baseWarn;\n\n platformIsPreTag = options.isPreTag || no;\n platformMustUseProp = options.mustUseProp || no;\n platformGetTagNamespace = options.getTagNamespace || no;\n var isReservedTag = options.isReservedTag || no;\n maybeComponent = function (el) { return !!el.component || !isReservedTag(el.tag); };\n\n transforms = pluckModuleFunction(options.modules, 'transformNode');\n preTransforms = pluckModuleFunction(options.modules, 'preTransformNode');\n postTransforms = pluckModuleFunction(options.modules, 'postTransformNode');\n\n delimiters = options.delimiters;\n\n var stack = [];\n var preserveWhitespace = options.preserveWhitespace !== false;\n var whitespaceOption = options.whitespace;\n var root;\n var currentParent;\n var inVPre = false;\n var inPre = false;\n var warned = false;\n\n function warnOnce (msg, range) {\n if (!warned) {\n warned = true;\n warn$2(msg, range);\n }\n }\n\n function closeElement (element) {\n trimEndingWhitespace(element);\n if (!inVPre && !element.processed) {\n element = processElement(element, options);\n }\n // tree management\n if (!stack.length && element !== root) {\n // allow root elements with v-if, v-else-if and v-else\n if (root.if && (element.elseif || element.else)) {\n if (true) {\n checkRootConstraints(element);\n }\n addIfCondition(root, {\n exp: element.elseif,\n block: element\n });\n } else if (true) {\n warnOnce(\n \"Component template should contain exactly one root element. \" +\n \"If you are using v-if on multiple elements, \" +\n \"use v-else-if to chain them instead.\",\n { start: element.start }\n );\n }\n }\n if (currentParent && !element.forbidden) {\n if (element.elseif || element.else) {\n processIfConditions(element, currentParent);\n } else {\n if (element.slotScope) {\n // scoped slot\n // keep it in the children list so that v-else(-if) conditions can\n // find it as the prev node.\n var name = element.slotTarget || '\"default\"'\n ;(currentParent.scopedSlots || (currentParent.scopedSlots = {}))[name] = element;\n }\n currentParent.children.push(element);\n element.parent = currentParent;\n }\n }\n\n // final children cleanup\n // filter out scoped slots\n element.children = element.children.filter(function (c) { return !(c).slotScope; });\n // remove trailing whitespace node again\n trimEndingWhitespace(element);\n\n // check pre state\n if (element.pre) {\n inVPre = false;\n }\n if (platformIsPreTag(element.tag)) {\n inPre = false;\n }\n // apply post-transforms\n for (var i = 0; i < postTransforms.length; i++) {\n postTransforms[i](element, options);\n }\n }\n\n function trimEndingWhitespace (el) {\n // remove trailing whitespace node\n if (!inPre) {\n var lastNode;\n while (\n (lastNode = el.children[el.children.length - 1]) &&\n lastNode.type === 3 &&\n lastNode.text === ' '\n ) {\n el.children.pop();\n }\n }\n }\n\n function checkRootConstraints (el) {\n if (el.tag === 'slot' || el.tag === 'template') {\n warnOnce(\n \"Cannot use <\" + (el.tag) + \"> as component root element because it may \" +\n 'contain multiple nodes.',\n { start: el.start }\n );\n }\n if (el.attrsMap.hasOwnProperty('v-for')) {\n warnOnce(\n 'Cannot use v-for on stateful component root element because ' +\n 'it renders multiple elements.',\n el.rawAttrsMap['v-for']\n );\n }\n }\n\n parseHTML(template, {\n warn: warn$2,\n expectHTML: options.expectHTML,\n isUnaryTag: options.isUnaryTag,\n canBeLeftOpenTag: options.canBeLeftOpenTag,\n shouldDecodeNewlines: options.shouldDecodeNewlines,\n shouldDecodeNewlinesForHref: options.shouldDecodeNewlinesForHref,\n shouldKeepComment: options.comments,\n outputSourceRange: options.outputSourceRange,\n start: function start (tag, attrs, unary, start$1, end) {\n // check namespace.\n // inherit parent ns if there is one\n var ns = (currentParent && currentParent.ns) || platformGetTagNamespace(tag);\n\n // handle IE svg bug\n /* istanbul ignore if */\n if (isIE && ns === 'svg') {\n attrs = guardIESVGBug(attrs);\n }\n\n var element = createASTElement(tag, attrs, currentParent);\n if (ns) {\n element.ns = ns;\n }\n\n if (true) {\n if (options.outputSourceRange) {\n element.start = start$1;\n element.end = end;\n element.rawAttrsMap = element.attrsList.reduce(function (cumulated, attr) {\n cumulated[attr.name] = attr;\n return cumulated\n }, {});\n }\n attrs.forEach(function (attr) {\n if (invalidAttributeRE.test(attr.name)) {\n warn$2(\n \"Invalid dynamic argument expression: attribute names cannot contain \" +\n \"spaces, quotes, <, >, / or =.\",\n {\n start: attr.start + attr.name.indexOf(\"[\"),\n end: attr.start + attr.name.length\n }\n );\n }\n });\n }\n\n if (isForbiddenTag(element) && !isServerRendering()) {\n element.forbidden = true;\n true && warn$2(\n 'Templates should only be responsible for mapping the state to the ' +\n 'UI. Avoid placing tags with side-effects in your templates, such as ' +\n \"<\" + tag + \">\" + ', as they will not be parsed.',\n { start: element.start }\n );\n }\n\n // apply pre-transforms\n for (var i = 0; i < preTransforms.length; i++) {\n element = preTransforms[i](element, options) || element;\n }\n\n if (!inVPre) {\n processPre(element);\n if (element.pre) {\n inVPre = true;\n }\n }\n if (platformIsPreTag(element.tag)) {\n inPre = true;\n }\n if (inVPre) {\n processRawAttrs(element);\n } else if (!element.processed) {\n // structural directives\n processFor(element);\n processIf(element);\n processOnce(element);\n }\n\n if (!root) {\n root = element;\n if (true) {\n checkRootConstraints(root);\n }\n }\n\n if (!unary) {\n currentParent = element;\n stack.push(element);\n } else {\n closeElement(element);\n }\n },\n\n end: function end (tag, start, end$1) {\n var element = stack[stack.length - 1];\n // pop stack\n stack.length -= 1;\n currentParent = stack[stack.length - 1];\n if ( true && options.outputSourceRange) {\n element.end = end$1;\n }\n closeElement(element);\n },\n\n chars: function chars (text, start, end) {\n if (!currentParent) {\n if (true) {\n if (text === template) {\n warnOnce(\n 'Component template requires a root element, rather than just text.',\n { start: start }\n );\n } else if ((text = text.trim())) {\n warnOnce(\n (\"text \\\"\" + text + \"\\\" outside root element will be ignored.\"),\n { start: start }\n );\n }\n }\n return\n }\n // IE textarea placeholder bug\n /* istanbul ignore if */\n if (isIE &&\n currentParent.tag === 'textarea' &&\n currentParent.attrsMap.placeholder === text\n ) {\n return\n }\n var children = currentParent.children;\n if (inPre || text.trim()) {\n text = isTextTag(currentParent) ? text : decodeHTMLCached(text);\n } else if (!children.length) {\n // remove the whitespace-only node right after an opening tag\n text = '';\n } else if (whitespaceOption) {\n if (whitespaceOption === 'condense') {\n // in condense mode, remove the whitespace node if it contains\n // line break, otherwise condense to a single space\n text = lineBreakRE.test(text) ? '' : ' ';\n } else {\n text = ' ';\n }\n } else {\n text = preserveWhitespace ? ' ' : '';\n }\n if (text) {\n if (!inPre && whitespaceOption === 'condense') {\n // condense consecutive whitespaces into single space\n text = text.replace(whitespaceRE$1, ' ');\n }\n var res;\n var child;\n if (!inVPre && text !== ' ' && (res = parseText(text, delimiters))) {\n child = {\n type: 2,\n expression: res.expression,\n tokens: res.tokens,\n text: text\n };\n } else if (text !== ' ' || !children.length || children[children.length - 1].text !== ' ') {\n child = {\n type: 3,\n text: text\n };\n }\n if (child) {\n if ( true && options.outputSourceRange) {\n child.start = start;\n child.end = end;\n }\n children.push(child);\n }\n }\n },\n comment: function comment (text, start, end) {\n // adding anyting as a sibling to the root node is forbidden\n // comments should still be allowed, but ignored\n if (currentParent) {\n var child = {\n type: 3,\n text: text,\n isComment: true\n };\n if ( true && options.outputSourceRange) {\n child.start = start;\n child.end = end;\n }\n currentParent.children.push(child);\n }\n }\n });\n return root\n}\n\nfunction processPre (el) {\n if (getAndRemoveAttr(el, 'v-pre') != null) {\n el.pre = true;\n }\n}\n\nfunction processRawAttrs (el) {\n var list = el.attrsList;\n var len = list.length;\n if (len) {\n var attrs = el.attrs = new Array(len);\n for (var i = 0; i < len; i++) {\n attrs[i] = {\n name: list[i].name,\n value: JSON.stringify(list[i].value)\n };\n if (list[i].start != null) {\n attrs[i].start = list[i].start;\n attrs[i].end = list[i].end;\n }\n }\n } else if (!el.pre) {\n // non root node in pre blocks with no attributes\n el.plain = true;\n }\n}\n\nfunction processElement (\n element,\n options\n) {\n processKey(element);\n\n // determine whether this is a plain element after\n // removing structural attributes\n element.plain = (\n !element.key &&\n !element.scopedSlots &&\n !element.attrsList.length\n );\n\n processRef(element);\n processSlotContent(element);\n processSlotOutlet(element);\n processComponent(element);\n for (var i = 0; i < transforms.length; i++) {\n element = transforms[i](element, options) || element;\n }\n processAttrs(element);\n return element\n}\n\nfunction processKey (el) {\n var exp = getBindingAttr(el, 'key');\n if (exp) {\n if (true) {\n if (el.tag === 'template') {\n warn$2(\n \"<template> cannot be keyed. Place the key on real elements instead.\",\n getRawBindingAttr(el, 'key')\n );\n }\n if (el.for) {\n var iterator = el.iterator2 || el.iterator1;\n var parent = el.parent;\n if (iterator && iterator === exp && parent && parent.tag === 'transition-group') {\n warn$2(\n \"Do not use v-for index as key on <transition-group> children, \" +\n \"this is the same as not using keys.\",\n getRawBindingAttr(el, 'key'),\n true /* tip */\n );\n }\n }\n }\n el.key = exp;\n }\n}\n\nfunction processRef (el) {\n var ref = getBindingAttr(el, 'ref');\n if (ref) {\n el.ref = ref;\n el.refInFor = checkInFor(el);\n }\n}\n\nfunction processFor (el) {\n var exp;\n if ((exp = getAndRemoveAttr(el, 'v-for'))) {\n var res = parseFor(exp);\n if (res) {\n extend(el, res);\n } else if (true) {\n warn$2(\n (\"Invalid v-for expression: \" + exp),\n el.rawAttrsMap['v-for']\n );\n }\n }\n}\n\n\n\nfunction parseFor (exp) {\n var inMatch = exp.match(forAliasRE);\n if (!inMatch) { return }\n var res = {};\n res.for = inMatch[2].trim();\n var alias = inMatch[1].trim().replace(stripParensRE, '');\n var iteratorMatch = alias.match(forIteratorRE);\n if (iteratorMatch) {\n res.alias = alias.replace(forIteratorRE, '').trim();\n res.iterator1 = iteratorMatch[1].trim();\n if (iteratorMatch[2]) {\n res.iterator2 = iteratorMatch[2].trim();\n }\n } else {\n res.alias = alias;\n }\n return res\n}\n\nfunction processIf (el) {\n var exp = getAndRemoveAttr(el, 'v-if');\n if (exp) {\n el.if = exp;\n addIfCondition(el, {\n exp: exp,\n block: el\n });\n } else {\n if (getAndRemoveAttr(el, 'v-else') != null) {\n el.else = true;\n }\n var elseif = getAndRemoveAttr(el, 'v-else-if');\n if (elseif) {\n el.elseif = elseif;\n }\n }\n}\n\nfunction processIfConditions (el, parent) {\n var prev = findPrevElement(parent.children);\n if (prev && prev.if) {\n addIfCondition(prev, {\n exp: el.elseif,\n block: el\n });\n } else if (true) {\n warn$2(\n \"v-\" + (el.elseif ? ('else-if=\"' + el.elseif + '\"') : 'else') + \" \" +\n \"used on element <\" + (el.tag) + \"> without corresponding v-if.\",\n el.rawAttrsMap[el.elseif ? 'v-else-if' : 'v-else']\n );\n }\n}\n\nfunction findPrevElement (children) {\n var i = children.length;\n while (i--) {\n if (children[i].type === 1) {\n return children[i]\n } else {\n if ( true && children[i].text !== ' ') {\n warn$2(\n \"text \\\"\" + (children[i].text.trim()) + \"\\\" between v-if and v-else(-if) \" +\n \"will be ignored.\",\n children[i]\n );\n }\n children.pop();\n }\n }\n}\n\nfunction addIfCondition (el, condition) {\n if (!el.ifConditions) {\n el.ifConditions = [];\n }\n el.ifConditions.push(condition);\n}\n\nfunction processOnce (el) {\n var once$$1 = getAndRemoveAttr(el, 'v-once');\n if (once$$1 != null) {\n el.once = true;\n }\n}\n\n// handle content being passed to a component as slot,\n// e.g. <template slot=\"xxx\">, <div slot-scope=\"xxx\">\nfunction processSlotContent (el) {\n var slotScope;\n if (el.tag === 'template') {\n slotScope = getAndRemoveAttr(el, 'scope');\n /* istanbul ignore if */\n if ( true && slotScope) {\n warn$2(\n \"the \\\"scope\\\" attribute for scoped slots have been deprecated and \" +\n \"replaced by \\\"slot-scope\\\" since 2.5. The new \\\"slot-scope\\\" attribute \" +\n \"can also be used on plain elements in addition to <template> to \" +\n \"denote scoped slots.\",\n el.rawAttrsMap['scope'],\n true\n );\n }\n el.slotScope = slotScope || getAndRemoveAttr(el, 'slot-scope');\n } else if ((slotScope = getAndRemoveAttr(el, 'slot-scope'))) {\n /* istanbul ignore if */\n if ( true && el.attrsMap['v-for']) {\n warn$2(\n \"Ambiguous combined usage of slot-scope and v-for on <\" + (el.tag) + \"> \" +\n \"(v-for takes higher priority). Use a wrapper <template> for the \" +\n \"scoped slot to make it clearer.\",\n el.rawAttrsMap['slot-scope'],\n true\n );\n }\n el.slotScope = slotScope;\n }\n\n // slot=\"xxx\"\n var slotTarget = getBindingAttr(el, 'slot');\n if (slotTarget) {\n el.slotTarget = slotTarget === '\"\"' ? '\"default\"' : slotTarget;\n el.slotTargetDynamic = !!(el.attrsMap[':slot'] || el.attrsMap['v-bind:slot']);\n // preserve slot as an attribute for native shadow DOM compat\n // only for non-scoped slots.\n if (el.tag !== 'template' && !el.slotScope) {\n addAttr(el, 'slot', slotTarget, getRawBindingAttr(el, 'slot'));\n }\n }\n\n // 2.6 v-slot syntax\n {\n if (el.tag === 'template') {\n // v-slot on <template>\n var slotBinding = getAndRemoveAttrByRegex(el, slotRE);\n if (slotBinding) {\n if (true) {\n if (el.slotTarget || el.slotScope) {\n warn$2(\n \"Unexpected mixed usage of different slot syntaxes.\",\n el\n );\n }\n if (el.parent && !maybeComponent(el.parent)) {\n warn$2(\n \"<template v-slot> can only appear at the root level inside \" +\n \"the receiving component\",\n el\n );\n }\n }\n var ref = getSlotName(slotBinding);\n var name = ref.name;\n var dynamic = ref.dynamic;\n el.slotTarget = name;\n el.slotTargetDynamic = dynamic;\n el.slotScope = slotBinding.value || emptySlotScopeToken; // force it into a scoped slot for perf\n }\n } else {\n // v-slot on component, denotes default slot\n var slotBinding$1 = getAndRemoveAttrByRegex(el, slotRE);\n if (slotBinding$1) {\n if (true) {\n if (!maybeComponent(el)) {\n warn$2(\n \"v-slot can only be used on components or <template>.\",\n slotBinding$1\n );\n }\n if (el.slotScope || el.slotTarget) {\n warn$2(\n \"Unexpected mixed usage of different slot syntaxes.\",\n el\n );\n }\n if (el.scopedSlots) {\n warn$2(\n \"To avoid scope ambiguity, the default slot should also use \" +\n \"<template> syntax when there are other named slots.\",\n slotBinding$1\n );\n }\n }\n // add the component's children to its default slot\n var slots = el.scopedSlots || (el.scopedSlots = {});\n var ref$1 = getSlotName(slotBinding$1);\n var name$1 = ref$1.name;\n var dynamic$1 = ref$1.dynamic;\n var slotContainer = slots[name$1] = createASTElement('template', [], el);\n slotContainer.slotTarget = name$1;\n slotContainer.slotTargetDynamic = dynamic$1;\n slotContainer.children = el.children.filter(function (c) {\n if (!c.slotScope) {\n c.parent = slotContainer;\n return true\n }\n });\n slotContainer.slotScope = slotBinding$1.value || emptySlotScopeToken;\n // remove children as they are returned from scopedSlots now\n el.children = [];\n // mark el non-plain so data gets generated\n el.plain = false;\n }\n }\n }\n}\n\nfunction getSlotName (binding) {\n var name = binding.name.replace(slotRE, '');\n if (!name) {\n if (binding.name[0] !== '#') {\n name = 'default';\n } else if (true) {\n warn$2(\n \"v-slot shorthand syntax requires a slot name.\",\n binding\n );\n }\n }\n return dynamicArgRE.test(name)\n // dynamic [name]\n ? { name: name.slice(1, -1), dynamic: true }\n // static name\n : { name: (\"\\\"\" + name + \"\\\"\"), dynamic: false }\n}\n\n// handle <slot/> outlets\nfunction processSlotOutlet (el) {\n if (el.tag === 'slot') {\n el.slotName = getBindingAttr(el, 'name');\n if ( true && el.key) {\n warn$2(\n \"`key` does not work on <slot> because slots are abstract outlets \" +\n \"and can possibly expand into multiple elements. \" +\n \"Use the key on a wrapping element instead.\",\n getRawBindingAttr(el, 'key')\n );\n }\n }\n}\n\nfunction processComponent (el) {\n var binding;\n if ((binding = getBindingAttr(el, 'is'))) {\n el.component = binding;\n }\n if (getAndRemoveAttr(el, 'inline-template') != null) {\n el.inlineTemplate = true;\n }\n}\n\nfunction processAttrs (el) {\n var list = el.attrsList;\n var i, l, name, rawName, value, modifiers, syncGen, isDynamic;\n for (i = 0, l = list.length; i < l; i++) {\n name = rawName = list[i].name;\n value = list[i].value;\n if (dirRE.test(name)) {\n // mark element as dynamic\n el.hasBindings = true;\n // modifiers\n modifiers = parseModifiers(name.replace(dirRE, ''));\n // support .foo shorthand syntax for the .prop modifier\n if (modifiers) {\n name = name.replace(modifierRE, '');\n }\n if (bindRE.test(name)) { // v-bind\n name = name.replace(bindRE, '');\n value = parseFilters(value);\n isDynamic = dynamicArgRE.test(name);\n if (isDynamic) {\n name = name.slice(1, -1);\n }\n if (\n true &&\n value.trim().length === 0\n ) {\n warn$2(\n (\"The value for a v-bind expression cannot be empty. Found in \\\"v-bind:\" + name + \"\\\"\")\n );\n }\n if (modifiers) {\n if (modifiers.prop && !isDynamic) {\n name = camelize(name);\n if (name === 'innerHtml') { name = 'innerHTML'; }\n }\n if (modifiers.camel && !isDynamic) {\n name = camelize(name);\n }\n if (modifiers.sync) {\n syncGen = genAssignmentCode(value, \"$event\");\n if (!isDynamic) {\n addHandler(\n el,\n (\"update:\" + (camelize(name))),\n syncGen,\n null,\n false,\n warn$2,\n list[i]\n );\n if (hyphenate(name) !== camelize(name)) {\n addHandler(\n el,\n (\"update:\" + (hyphenate(name))),\n syncGen,\n null,\n false,\n warn$2,\n list[i]\n );\n }\n } else {\n // handler w/ dynamic event name\n addHandler(\n el,\n (\"\\\"update:\\\"+(\" + name + \")\"),\n syncGen,\n null,\n false,\n warn$2,\n list[i],\n true // dynamic\n );\n }\n }\n }\n if ((modifiers && modifiers.prop) || (\n !el.component && platformMustUseProp(el.tag, el.attrsMap.type, name)\n )) {\n addProp(el, name, value, list[i], isDynamic);\n } else {\n addAttr(el, name, value, list[i], isDynamic);\n }\n } else if (onRE.test(name)) { // v-on\n name = name.replace(onRE, '');\n isDynamic = dynamicArgRE.test(name);\n if (isDynamic) {\n name = name.slice(1, -1);\n }\n addHandler(el, name, value, modifiers, false, warn$2, list[i], isDynamic);\n } else { // normal directives\n name = name.replace(dirRE, '');\n // parse arg\n var argMatch = name.match(argRE);\n var arg = argMatch && argMatch[1];\n isDynamic = false;\n if (arg) {\n name = name.slice(0, -(arg.length + 1));\n if (dynamicArgRE.test(arg)) {\n arg = arg.slice(1, -1);\n isDynamic = true;\n }\n }\n addDirective(el, name, rawName, value, arg, isDynamic, modifiers, list[i]);\n if ( true && name === 'model') {\n checkForAliasModel(el, value);\n }\n }\n } else {\n // literal attribute\n if (true) {\n var res = parseText(value, delimiters);\n if (res) {\n warn$2(\n name + \"=\\\"\" + value + \"\\\": \" +\n 'Interpolation inside attributes has been removed. ' +\n 'Use v-bind or the colon shorthand instead. For example, ' +\n 'instead of <div id=\"{{ val }}\">, use <div :id=\"val\">.',\n list[i]\n );\n }\n }\n addAttr(el, name, JSON.stringify(value), list[i]);\n // #6887 firefox doesn't update muted state if set via attribute\n // even immediately after element creation\n if (!el.component &&\n name === 'muted' &&\n platformMustUseProp(el.tag, el.attrsMap.type, name)) {\n addProp(el, name, 'true', list[i]);\n }\n }\n }\n}\n\nfunction checkInFor (el) {\n var parent = el;\n while (parent) {\n if (parent.for !== undefined) {\n return true\n }\n parent = parent.parent;\n }\n return false\n}\n\nfunction parseModifiers (name) {\n var match = name.match(modifierRE);\n if (match) {\n var ret = {};\n match.forEach(function (m) { ret[m.slice(1)] = true; });\n return ret\n }\n}\n\nfunction makeAttrsMap (attrs) {\n var map = {};\n for (var i = 0, l = attrs.length; i < l; i++) {\n if (\n true &&\n map[attrs[i].name] && !isIE && !isEdge\n ) {\n warn$2('duplicate attribute: ' + attrs[i].name, attrs[i]);\n }\n map[attrs[i].name] = attrs[i].value;\n }\n return map\n}\n\n// for script (e.g. type=\"x/template\") or style, do not decode content\nfunction isTextTag (el) {\n return el.tag === 'script' || el.tag === 'style'\n}\n\nfunction isForbiddenTag (el) {\n return (\n el.tag === 'style' ||\n (el.tag === 'script' && (\n !el.attrsMap.type ||\n el.attrsMap.type === 'text/javascript'\n ))\n )\n}\n\nvar ieNSBug = /^xmlns:NS\\d+/;\nvar ieNSPrefix = /^NS\\d+:/;\n\n/* istanbul ignore next */\nfunction guardIESVGBug (attrs) {\n var res = [];\n for (var i = 0; i < attrs.length; i++) {\n var attr = attrs[i];\n if (!ieNSBug.test(attr.name)) {\n attr.name = attr.name.replace(ieNSPrefix, '');\n res.push(attr);\n }\n }\n return res\n}\n\nfunction checkForAliasModel (el, value) {\n var _el = el;\n while (_el) {\n if (_el.for && _el.alias === value) {\n warn$2(\n \"<\" + (el.tag) + \" v-model=\\\"\" + value + \"\\\">: \" +\n \"You are binding v-model directly to a v-for iteration alias. \" +\n \"This will not be able to modify the v-for source array because \" +\n \"writing to the alias is like modifying a function local variable. \" +\n \"Consider using an array of objects and use v-model on an object property instead.\",\n el.rawAttrsMap['v-model']\n );\n }\n _el = _el.parent;\n }\n}\n\n/* */\n\nfunction preTransformNode (el, options) {\n if (el.tag === 'input') {\n var map = el.attrsMap;\n if (!map['v-model']) {\n return\n }\n\n var typeBinding;\n if (map[':type'] || map['v-bind:type']) {\n typeBinding = getBindingAttr(el, 'type');\n }\n if (!map.type && !typeBinding && map['v-bind']) {\n typeBinding = \"(\" + (map['v-bind']) + \").type\";\n }\n\n if (typeBinding) {\n var ifCondition = getAndRemoveAttr(el, 'v-if', true);\n var ifConditionExtra = ifCondition ? (\"&&(\" + ifCondition + \")\") : \"\";\n var hasElse = getAndRemoveAttr(el, 'v-else', true) != null;\n var elseIfCondition = getAndRemoveAttr(el, 'v-else-if', true);\n // 1. checkbox\n var branch0 = cloneASTElement(el);\n // process for on the main node\n processFor(branch0);\n addRawAttr(branch0, 'type', 'checkbox');\n processElement(branch0, options);\n branch0.processed = true; // prevent it from double-processed\n branch0.if = \"(\" + typeBinding + \")==='checkbox'\" + ifConditionExtra;\n addIfCondition(branch0, {\n exp: branch0.if,\n block: branch0\n });\n // 2. add radio else-if condition\n var branch1 = cloneASTElement(el);\n getAndRemoveAttr(branch1, 'v-for', true);\n addRawAttr(branch1, 'type', 'radio');\n processElement(branch1, options);\n addIfCondition(branch0, {\n exp: \"(\" + typeBinding + \")==='radio'\" + ifConditionExtra,\n block: branch1\n });\n // 3. other\n var branch2 = cloneASTElement(el);\n getAndRemoveAttr(branch2, 'v-for', true);\n addRawAttr(branch2, ':type', typeBinding);\n processElement(branch2, options);\n addIfCondition(branch0, {\n exp: ifCondition,\n block: branch2\n });\n\n if (hasElse) {\n branch0.else = true;\n } else if (elseIfCondition) {\n branch0.elseif = elseIfCondition;\n }\n\n return branch0\n }\n }\n}\n\nfunction cloneASTElement (el) {\n return createASTElement(el.tag, el.attrsList.slice(), el.parent)\n}\n\nvar model$1 = {\n preTransformNode: preTransformNode\n};\n\nvar modules$1 = [\n klass$1,\n style$1,\n model$1\n];\n\n/* */\n\nfunction text (el, dir) {\n if (dir.value) {\n addProp(el, 'textContent', (\"_s(\" + (dir.value) + \")\"), dir);\n }\n}\n\n/* */\n\nfunction html (el, dir) {\n if (dir.value) {\n addProp(el, 'innerHTML', (\"_s(\" + (dir.value) + \")\"), dir);\n }\n}\n\nvar directives$1 = {\n model: model,\n text: text,\n html: html\n};\n\n/* */\n\nvar baseOptions = {\n expectHTML: true,\n modules: modules$1,\n directives: directives$1,\n isPreTag: isPreTag,\n isUnaryTag: isUnaryTag,\n mustUseProp: mustUseProp,\n canBeLeftOpenTag: canBeLeftOpenTag,\n isReservedTag: isReservedTag,\n getTagNamespace: getTagNamespace,\n staticKeys: genStaticKeys(modules$1)\n};\n\n/* */\n\nvar isStaticKey;\nvar isPlatformReservedTag;\n\nvar genStaticKeysCached = cached(genStaticKeys$1);\n\n/**\n * Goal of the optimizer: walk the generated template AST tree\n * and detect sub-trees that are purely static, i.e. parts of\n * the DOM that never needs to change.\n *\n * Once we detect these sub-trees, we can:\n *\n * 1. Hoist them into constants, so that we no longer need to\n * create fresh nodes for them on each re-render;\n * 2. Completely skip them in the patching process.\n */\nfunction optimize (root, options) {\n if (!root) { return }\n isStaticKey = genStaticKeysCached(options.staticKeys || '');\n isPlatformReservedTag = options.isReservedTag || no;\n // first pass: mark all non-static nodes.\n markStatic$1(root);\n // second pass: mark static roots.\n markStaticRoots(root, false);\n}\n\nfunction genStaticKeys$1 (keys) {\n return makeMap(\n 'type,tag,attrsList,attrsMap,plain,parent,children,attrs,start,end,rawAttrsMap' +\n (keys ? ',' + keys : '')\n )\n}\n\nfunction markStatic$1 (node) {\n node.static = isStatic(node);\n if (node.type === 1) {\n // do not make component slot content static. this avoids\n // 1. components not able to mutate slot nodes\n // 2. static slot content fails for hot-reloading\n if (\n !isPlatformReservedTag(node.tag) &&\n node.tag !== 'slot' &&\n node.attrsMap['inline-template'] == null\n ) {\n return\n }\n for (var i = 0, l = node.children.length; i < l; i++) {\n var child = node.children[i];\n markStatic$1(child);\n if (!child.static) {\n node.static = false;\n }\n }\n if (node.ifConditions) {\n for (var i$1 = 1, l$1 = node.ifConditions.length; i$1 < l$1; i$1++) {\n var block = node.ifConditions[i$1].block;\n markStatic$1(block);\n if (!block.static) {\n node.static = false;\n }\n }\n }\n }\n}\n\nfunction markStaticRoots (node, isInFor) {\n if (node.type === 1) {\n if (node.static || node.once) {\n node.staticInFor = isInFor;\n }\n // For a node to qualify as a static root, it should have children that\n // are not just static text. Otherwise the cost of hoisting out will\n // outweigh the benefits and it's better off to just always render it fresh.\n if (node.static && node.children.length && !(\n node.children.length === 1 &&\n node.children[0].type === 3\n )) {\n node.staticRoot = true;\n return\n } else {\n node.staticRoot = false;\n }\n if (node.children) {\n for (var i = 0, l = node.children.length; i < l; i++) {\n markStaticRoots(node.children[i], isInFor || !!node.for);\n }\n }\n if (node.ifConditions) {\n for (var i$1 = 1, l$1 = node.ifConditions.length; i$1 < l$1; i$1++) {\n markStaticRoots(node.ifConditions[i$1].block, isInFor);\n }\n }\n }\n}\n\nfunction isStatic (node) {\n if (node.type === 2) { // expression\n return false\n }\n if (node.type === 3) { // text\n return true\n }\n return !!(node.pre || (\n !node.hasBindings && // no dynamic bindings\n !node.if && !node.for && // not v-if or v-for or v-else\n !isBuiltInTag(node.tag) && // not a built-in\n isPlatformReservedTag(node.tag) && // not a component\n !isDirectChildOfTemplateFor(node) &&\n Object.keys(node).every(isStaticKey)\n ))\n}\n\nfunction isDirectChildOfTemplateFor (node) {\n while (node.parent) {\n node = node.parent;\n if (node.tag !== 'template') {\n return false\n }\n if (node.for) {\n return true\n }\n }\n return false\n}\n\n/* */\n\nvar fnExpRE = /^([\\w$_]+|\\([^)]*?\\))\\s*=>|^function(?:\\s+[\\w$]+)?\\s*\\(/;\nvar fnInvokeRE = /\\([^)]*?\\);*$/;\nvar simplePathRE = /^[A-Za-z_$][\\w$]*(?:\\.[A-Za-z_$][\\w$]*|\\['[^']*?']|\\[\"[^\"]*?\"]|\\[\\d+]|\\[[A-Za-z_$][\\w$]*])*$/;\n\n// KeyboardEvent.keyCode aliases\nvar keyCodes = {\n esc: 27,\n tab: 9,\n enter: 13,\n space: 32,\n up: 38,\n left: 37,\n right: 39,\n down: 40,\n 'delete': [8, 46]\n};\n\n// KeyboardEvent.key aliases\nvar keyNames = {\n // #7880: IE11 and Edge use `Esc` for Escape key name.\n esc: ['Esc', 'Escape'],\n tab: 'Tab',\n enter: 'Enter',\n // #9112: IE11 uses `Spacebar` for Space key name.\n space: [' ', 'Spacebar'],\n // #7806: IE11 uses key names without `Arrow` prefix for arrow keys.\n up: ['Up', 'ArrowUp'],\n left: ['Left', 'ArrowLeft'],\n right: ['Right', 'ArrowRight'],\n down: ['Down', 'ArrowDown'],\n // #9112: IE11 uses `Del` for Delete key name.\n 'delete': ['Backspace', 'Delete', 'Del']\n};\n\n// #4868: modifiers that prevent the execution of the listener\n// need to explicitly return null so that we can determine whether to remove\n// the listener for .once\nvar genGuard = function (condition) { return (\"if(\" + condition + \")return null;\"); };\n\nvar modifierCode = {\n stop: '$event.stopPropagation();',\n prevent: '$event.preventDefault();',\n self: genGuard(\"$event.target !== $event.currentTarget\"),\n ctrl: genGuard(\"!$event.ctrlKey\"),\n shift: genGuard(\"!$event.shiftKey\"),\n alt: genGuard(\"!$event.altKey\"),\n meta: genGuard(\"!$event.metaKey\"),\n left: genGuard(\"'button' in $event && $event.button !== 0\"),\n middle: genGuard(\"'button' in $event && $event.button !== 1\"),\n right: genGuard(\"'button' in $event && $event.button !== 2\")\n};\n\nfunction genHandlers (\n events,\n isNative\n) {\n var prefix = isNative ? 'nativeOn:' : 'on:';\n var staticHandlers = \"\";\n var dynamicHandlers = \"\";\n for (var name in events) {\n var handlerCode = genHandler(events[name]);\n if (events[name] && events[name].dynamic) {\n dynamicHandlers += name + \",\" + handlerCode + \",\";\n } else {\n staticHandlers += \"\\\"\" + name + \"\\\":\" + handlerCode + \",\";\n }\n }\n staticHandlers = \"{\" + (staticHandlers.slice(0, -1)) + \"}\";\n if (dynamicHandlers) {\n return prefix + \"_d(\" + staticHandlers + \",[\" + (dynamicHandlers.slice(0, -1)) + \"])\"\n } else {\n return prefix + staticHandlers\n }\n}\n\nfunction genHandler (handler) {\n if (!handler) {\n return 'function(){}'\n }\n\n if (Array.isArray(handler)) {\n return (\"[\" + (handler.map(function (handler) { return genHandler(handler); }).join(',')) + \"]\")\n }\n\n var isMethodPath = simplePathRE.test(handler.value);\n var isFunctionExpression = fnExpRE.test(handler.value);\n var isFunctionInvocation = simplePathRE.test(handler.value.replace(fnInvokeRE, ''));\n\n if (!handler.modifiers) {\n if (isMethodPath || isFunctionExpression) {\n return handler.value\n }\n return (\"function($event){\" + (isFunctionInvocation ? (\"return \" + (handler.value)) : handler.value) + \"}\") // inline statement\n } else {\n var code = '';\n var genModifierCode = '';\n var keys = [];\n for (var key in handler.modifiers) {\n if (modifierCode[key]) {\n genModifierCode += modifierCode[key];\n // left/right\n if (keyCodes[key]) {\n keys.push(key);\n }\n } else if (key === 'exact') {\n var modifiers = (handler.modifiers);\n genModifierCode += genGuard(\n ['ctrl', 'shift', 'alt', 'meta']\n .filter(function (keyModifier) { return !modifiers[keyModifier]; })\n .map(function (keyModifier) { return (\"$event.\" + keyModifier + \"Key\"); })\n .join('||')\n );\n } else {\n keys.push(key);\n }\n }\n if (keys.length) {\n code += genKeyFilter(keys);\n }\n // Make sure modifiers like prevent and stop get executed after key filtering\n if (genModifierCode) {\n code += genModifierCode;\n }\n var handlerCode = isMethodPath\n ? (\"return \" + (handler.value) + \"($event)\")\n : isFunctionExpression\n ? (\"return (\" + (handler.value) + \")($event)\")\n : isFunctionInvocation\n ? (\"return \" + (handler.value))\n : handler.value;\n return (\"function($event){\" + code + handlerCode + \"}\")\n }\n}\n\nfunction genKeyFilter (keys) {\n return (\n // make sure the key filters only apply to KeyboardEvents\n // #9441: can't use 'keyCode' in $event because Chrome autofill fires fake\n // key events that do not have keyCode property...\n \"if(!$event.type.indexOf('key')&&\" +\n (keys.map(genFilterCode).join('&&')) + \")return null;\"\n )\n}\n\nfunction genFilterCode (key) {\n var keyVal = parseInt(key, 10);\n if (keyVal) {\n return (\"$event.keyCode!==\" + keyVal)\n }\n var keyCode = keyCodes[key];\n var keyName = keyNames[key];\n return (\n \"_k($event.keyCode,\" +\n (JSON.stringify(key)) + \",\" +\n (JSON.stringify(keyCode)) + \",\" +\n \"$event.key,\" +\n \"\" + (JSON.stringify(keyName)) +\n \")\"\n )\n}\n\n/* */\n\nfunction on (el, dir) {\n if ( true && dir.modifiers) {\n warn(\"v-on without argument does not support modifiers.\");\n }\n el.wrapListeners = function (code) { return (\"_g(\" + code + \",\" + (dir.value) + \")\"); };\n}\n\n/* */\n\nfunction bind$1 (el, dir) {\n el.wrapData = function (code) {\n return (\"_b(\" + code + \",'\" + (el.tag) + \"',\" + (dir.value) + \",\" + (dir.modifiers && dir.modifiers.prop ? 'true' : 'false') + (dir.modifiers && dir.modifiers.sync ? ',true' : '') + \")\")\n };\n}\n\n/* */\n\nvar baseDirectives = {\n on: on,\n bind: bind$1,\n cloak: noop\n};\n\n/* */\n\n\n\n\n\nvar CodegenState = function CodegenState (options) {\n this.options = options;\n this.warn = options.warn || baseWarn;\n this.transforms = pluckModuleFunction(options.modules, 'transformCode');\n this.dataGenFns = pluckModuleFunction(options.modules, 'genData');\n this.directives = extend(extend({}, baseDirectives), options.directives);\n var isReservedTag = options.isReservedTag || no;\n this.maybeComponent = function (el) { return !!el.component || !isReservedTag(el.tag); };\n this.onceId = 0;\n this.staticRenderFns = [];\n this.pre = false;\n};\n\n\n\nfunction generate (\n ast,\n options\n) {\n var state = new CodegenState(options);\n var code = ast ? genElement(ast, state) : '_c(\"div\")';\n return {\n render: (\"with(this){return \" + code + \"}\"),\n staticRenderFns: state.staticRenderFns\n }\n}\n\nfunction genElement (el, state) {\n if (el.parent) {\n el.pre = el.pre || el.parent.pre;\n }\n\n if (el.staticRoot && !el.staticProcessed) {\n return genStatic(el, state)\n } else if (el.once && !el.onceProcessed) {\n return genOnce(el, state)\n } else if (el.for && !el.forProcessed) {\n return genFor(el, state)\n } else if (el.if && !el.ifProcessed) {\n return genIf(el, state)\n } else if (el.tag === 'template' && !el.slotTarget && !state.pre) {\n return genChildren(el, state) || 'void 0'\n } else if (el.tag === 'slot') {\n return genSlot(el, state)\n } else {\n // component or element\n var code;\n if (el.component) {\n code = genComponent(el.component, el, state);\n } else {\n var data;\n if (!el.plain || (el.pre && state.maybeComponent(el))) {\n data = genData$2(el, state);\n }\n\n var children = el.inlineTemplate ? null : genChildren(el, state, true);\n code = \"_c('\" + (el.tag) + \"'\" + (data ? (\",\" + data) : '') + (children ? (\",\" + children) : '') + \")\";\n }\n // module transforms\n for (var i = 0; i < state.transforms.length; i++) {\n code = state.transforms[i](el, code);\n }\n return code\n }\n}\n\n// hoist static sub-trees out\nfunction genStatic (el, state) {\n el.staticProcessed = true;\n // Some elements (templates) need to behave differently inside of a v-pre\n // node. All pre nodes are static roots, so we can use this as a location to\n // wrap a state change and reset it upon exiting the pre node.\n var originalPreState = state.pre;\n if (el.pre) {\n state.pre = el.pre;\n }\n state.staticRenderFns.push((\"with(this){return \" + (genElement(el, state)) + \"}\"));\n state.pre = originalPreState;\n return (\"_m(\" + (state.staticRenderFns.length - 1) + (el.staticInFor ? ',true' : '') + \")\")\n}\n\n// v-once\nfunction genOnce (el, state) {\n el.onceProcessed = true;\n if (el.if && !el.ifProcessed) {\n return genIf(el, state)\n } else if (el.staticInFor) {\n var key = '';\n var parent = el.parent;\n while (parent) {\n if (parent.for) {\n key = parent.key;\n break\n }\n parent = parent.parent;\n }\n if (!key) {\n true && state.warn(\n \"v-once can only be used inside v-for that is keyed. \",\n el.rawAttrsMap['v-once']\n );\n return genElement(el, state)\n }\n return (\"_o(\" + (genElement(el, state)) + \",\" + (state.onceId++) + \",\" + key + \")\")\n } else {\n return genStatic(el, state)\n }\n}\n\nfunction genIf (\n el,\n state,\n altGen,\n altEmpty\n) {\n el.ifProcessed = true; // avoid recursion\n return genIfConditions(el.ifConditions.slice(), state, altGen, altEmpty)\n}\n\nfunction genIfConditions (\n conditions,\n state,\n altGen,\n altEmpty\n) {\n if (!conditions.length) {\n return altEmpty || '_e()'\n }\n\n var condition = conditions.shift();\n if (condition.exp) {\n return (\"(\" + (condition.exp) + \")?\" + (genTernaryExp(condition.block)) + \":\" + (genIfConditions(conditions, state, altGen, altEmpty)))\n } else {\n return (\"\" + (genTernaryExp(condition.block)))\n }\n\n // v-if with v-once should generate code like (a)?_m(0):_m(1)\n function genTernaryExp (el) {\n return altGen\n ? altGen(el, state)\n : el.once\n ? genOnce(el, state)\n : genElement(el, state)\n }\n}\n\nfunction genFor (\n el,\n state,\n altGen,\n altHelper\n) {\n var exp = el.for;\n var alias = el.alias;\n var iterator1 = el.iterator1 ? (\",\" + (el.iterator1)) : '';\n var iterator2 = el.iterator2 ? (\",\" + (el.iterator2)) : '';\n\n if ( true &&\n state.maybeComponent(el) &&\n el.tag !== 'slot' &&\n el.tag !== 'template' &&\n !el.key\n ) {\n state.warn(\n \"<\" + (el.tag) + \" v-for=\\\"\" + alias + \" in \" + exp + \"\\\">: component lists rendered with \" +\n \"v-for should have explicit keys. \" +\n \"See https://vuejs.org/guide/list.html#key for more info.\",\n el.rawAttrsMap['v-for'],\n true /* tip */\n );\n }\n\n el.forProcessed = true; // avoid recursion\n return (altHelper || '_l') + \"((\" + exp + \"),\" +\n \"function(\" + alias + iterator1 + iterator2 + \"){\" +\n \"return \" + ((altGen || genElement)(el, state)) +\n '})'\n}\n\nfunction genData$2 (el, state) {\n var data = '{';\n\n // directives first.\n // directives may mutate the el's other properties before they are generated.\n var dirs = genDirectives(el, state);\n if (dirs) { data += dirs + ','; }\n\n // key\n if (el.key) {\n data += \"key:\" + (el.key) + \",\";\n }\n // ref\n if (el.ref) {\n data += \"ref:\" + (el.ref) + \",\";\n }\n if (el.refInFor) {\n data += \"refInFor:true,\";\n }\n // pre\n if (el.pre) {\n data += \"pre:true,\";\n }\n // record original tag name for components using \"is\" attribute\n if (el.component) {\n data += \"tag:\\\"\" + (el.tag) + \"\\\",\";\n }\n // module data generation functions\n for (var i = 0; i < state.dataGenFns.length; i++) {\n data += state.dataGenFns[i](el);\n }\n // attributes\n if (el.attrs) {\n data += \"attrs:\" + (genProps(el.attrs)) + \",\";\n }\n // DOM props\n if (el.props) {\n data += \"domProps:\" + (genProps(el.props)) + \",\";\n }\n // event handlers\n if (el.events) {\n data += (genHandlers(el.events, false)) + \",\";\n }\n if (el.nativeEvents) {\n data += (genHandlers(el.nativeEvents, true)) + \",\";\n }\n // slot target\n // only for non-scoped slots\n if (el.slotTarget && !el.slotScope) {\n data += \"slot:\" + (el.slotTarget) + \",\";\n }\n // scoped slots\n if (el.scopedSlots) {\n data += (genScopedSlots(el, el.scopedSlots, state)) + \",\";\n }\n // component v-model\n if (el.model) {\n data += \"model:{value:\" + (el.model.value) + \",callback:\" + (el.model.callback) + \",expression:\" + (el.model.expression) + \"},\";\n }\n // inline-template\n if (el.inlineTemplate) {\n var inlineTemplate = genInlineTemplate(el, state);\n if (inlineTemplate) {\n data += inlineTemplate + \",\";\n }\n }\n data = data.replace(/,$/, '') + '}';\n // v-bind dynamic argument wrap\n // v-bind with dynamic arguments must be applied using the same v-bind object\n // merge helper so that class/style/mustUseProp attrs are handled correctly.\n if (el.dynamicAttrs) {\n data = \"_b(\" + data + \",\\\"\" + (el.tag) + \"\\\",\" + (genProps(el.dynamicAttrs)) + \")\";\n }\n // v-bind data wrap\n if (el.wrapData) {\n data = el.wrapData(data);\n }\n // v-on data wrap\n if (el.wrapListeners) {\n data = el.wrapListeners(data);\n }\n return data\n}\n\nfunction genDirectives (el, state) {\n var dirs = el.directives;\n if (!dirs) { return }\n var res = 'directives:[';\n var hasRuntime = false;\n var i, l, dir, needRuntime;\n for (i = 0, l = dirs.length; i < l; i++) {\n dir = dirs[i];\n needRuntime = true;\n var gen = state.directives[dir.name];\n if (gen) {\n // compile-time directive that manipulates AST.\n // returns true if it also needs a runtime counterpart.\n needRuntime = !!gen(el, dir, state.warn);\n }\n if (needRuntime) {\n hasRuntime = true;\n res += \"{name:\\\"\" + (dir.name) + \"\\\",rawName:\\\"\" + (dir.rawName) + \"\\\"\" + (dir.value ? (\",value:(\" + (dir.value) + \"),expression:\" + (JSON.stringify(dir.value))) : '') + (dir.arg ? (\",arg:\" + (dir.isDynamicArg ? dir.arg : (\"\\\"\" + (dir.arg) + \"\\\"\"))) : '') + (dir.modifiers ? (\",modifiers:\" + (JSON.stringify(dir.modifiers))) : '') + \"},\";\n }\n }\n if (hasRuntime) {\n return res.slice(0, -1) + ']'\n }\n}\n\nfunction genInlineTemplate (el, state) {\n var ast = el.children[0];\n if ( true && (\n el.children.length !== 1 || ast.type !== 1\n )) {\n state.warn(\n 'Inline-template components must have exactly one child element.',\n { start: el.start }\n );\n }\n if (ast && ast.type === 1) {\n var inlineRenderFns = generate(ast, state.options);\n return (\"inlineTemplate:{render:function(){\" + (inlineRenderFns.render) + \"},staticRenderFns:[\" + (inlineRenderFns.staticRenderFns.map(function (code) { return (\"function(){\" + code + \"}\"); }).join(',')) + \"]}\")\n }\n}\n\nfunction genScopedSlots (\n el,\n slots,\n state\n) {\n // by default scoped slots are considered \"stable\", this allows child\n // components with only scoped slots to skip forced updates from parent.\n // but in some cases we have to bail-out of this optimization\n // for example if the slot contains dynamic names, has v-if or v-for on them...\n var needsForceUpdate = el.for || Object.keys(slots).some(function (key) {\n var slot = slots[key];\n return (\n slot.slotTargetDynamic ||\n slot.if ||\n slot.for ||\n containsSlotChild(slot) // is passing down slot from parent which may be dynamic\n )\n });\n\n // #9534: if a component with scoped slots is inside a conditional branch,\n // it's possible for the same component to be reused but with different\n // compiled slot content. To avoid that, we generate a unique key based on\n // the generated code of all the slot contents.\n var needsKey = !!el.if;\n\n // OR when it is inside another scoped slot or v-for (the reactivity may be\n // disconnected due to the intermediate scope variable)\n // #9438, #9506\n // TODO: this can be further optimized by properly analyzing in-scope bindings\n // and skip force updating ones that do not actually use scope variables.\n if (!needsForceUpdate) {\n var parent = el.parent;\n while (parent) {\n if (\n (parent.slotScope && parent.slotScope !== emptySlotScopeToken) ||\n parent.for\n ) {\n needsForceUpdate = true;\n break\n }\n if (parent.if) {\n needsKey = true;\n }\n parent = parent.parent;\n }\n }\n\n var generatedSlots = Object.keys(slots)\n .map(function (key) { return genScopedSlot(slots[key], state); })\n .join(',');\n\n return (\"scopedSlots:_u([\" + generatedSlots + \"]\" + (needsForceUpdate ? \",null,true\" : \"\") + (!needsForceUpdate && needsKey ? (\",null,false,\" + (hash(generatedSlots))) : \"\") + \")\")\n}\n\nfunction hash(str) {\n var hash = 5381;\n var i = str.length;\n while(i) {\n hash = (hash * 33) ^ str.charCodeAt(--i);\n }\n return hash >>> 0\n}\n\nfunction containsSlotChild (el) {\n if (el.type === 1) {\n if (el.tag === 'slot') {\n return true\n }\n return el.children.some(containsSlotChild)\n }\n return false\n}\n\nfunction genScopedSlot (\n el,\n state\n) {\n var isLegacySyntax = el.attrsMap['slot-scope'];\n if (el.if && !el.ifProcessed && !isLegacySyntax) {\n return genIf(el, state, genScopedSlot, \"null\")\n }\n if (el.for && !el.forProcessed) {\n return genFor(el, state, genScopedSlot)\n }\n var slotScope = el.slotScope === emptySlotScopeToken\n ? \"\"\n : String(el.slotScope);\n var fn = \"function(\" + slotScope + \"){\" +\n \"return \" + (el.tag === 'template'\n ? el.if && isLegacySyntax\n ? (\"(\" + (el.if) + \")?\" + (genChildren(el, state) || 'undefined') + \":undefined\")\n : genChildren(el, state) || 'undefined'\n : genElement(el, state)) + \"}\";\n // reverse proxy v-slot without scope on this.$slots\n var reverseProxy = slotScope ? \"\" : \",proxy:true\";\n return (\"{key:\" + (el.slotTarget || \"\\\"default\\\"\") + \",fn:\" + fn + reverseProxy + \"}\")\n}\n\nfunction genChildren (\n el,\n state,\n checkSkip,\n altGenElement,\n altGenNode\n) {\n var children = el.children;\n if (children.length) {\n var el$1 = children[0];\n // optimize single v-for\n if (children.length === 1 &&\n el$1.for &&\n el$1.tag !== 'template' &&\n el$1.tag !== 'slot'\n ) {\n var normalizationType = checkSkip\n ? state.maybeComponent(el$1) ? \",1\" : \",0\"\n : \"\";\n return (\"\" + ((altGenElement || genElement)(el$1, state)) + normalizationType)\n }\n var normalizationType$1 = checkSkip\n ? getNormalizationType(children, state.maybeComponent)\n : 0;\n var gen = altGenNode || genNode;\n return (\"[\" + (children.map(function (c) { return gen(c, state); }).join(',')) + \"]\" + (normalizationType$1 ? (\",\" + normalizationType$1) : ''))\n }\n}\n\n// determine the normalization needed for the children array.\n// 0: no normalization needed\n// 1: simple normalization needed (possible 1-level deep nested array)\n// 2: full normalization needed\nfunction getNormalizationType (\n children,\n maybeComponent\n) {\n var res = 0;\n for (var i = 0; i < children.length; i++) {\n var el = children[i];\n if (el.type !== 1) {\n continue\n }\n if (needsNormalization(el) ||\n (el.ifConditions && el.ifConditions.some(function (c) { return needsNormalization(c.block); }))) {\n res = 2;\n break\n }\n if (maybeComponent(el) ||\n (el.ifConditions && el.ifConditions.some(function (c) { return maybeComponent(c.block); }))) {\n res = 1;\n }\n }\n return res\n}\n\nfunction needsNormalization (el) {\n return el.for !== undefined || el.tag === 'template' || el.tag === 'slot'\n}\n\nfunction genNode (node, state) {\n if (node.type === 1) {\n return genElement(node, state)\n } else if (node.type === 3 && node.isComment) {\n return genComment(node)\n } else {\n return genText(node)\n }\n}\n\nfunction genText (text) {\n return (\"_v(\" + (text.type === 2\n ? text.expression // no need for () because already wrapped in _s()\n : transformSpecialNewlines(JSON.stringify(text.text))) + \")\")\n}\n\nfunction genComment (comment) {\n return (\"_e(\" + (JSON.stringify(comment.text)) + \")\")\n}\n\nfunction genSlot (el, state) {\n var slotName = el.slotName || '\"default\"';\n var children = genChildren(el, state);\n var res = \"_t(\" + slotName + (children ? (\",\" + children) : '');\n var attrs = el.attrs || el.dynamicAttrs\n ? genProps((el.attrs || []).concat(el.dynamicAttrs || []).map(function (attr) { return ({\n // slot props are camelized\n name: camelize(attr.name),\n value: attr.value,\n dynamic: attr.dynamic\n }); }))\n : null;\n var bind$$1 = el.attrsMap['v-bind'];\n if ((attrs || bind$$1) && !children) {\n res += \",null\";\n }\n if (attrs) {\n res += \",\" + attrs;\n }\n if (bind$$1) {\n res += (attrs ? '' : ',null') + \",\" + bind$$1;\n }\n return res + ')'\n}\n\n// componentName is el.component, take it as argument to shun flow's pessimistic refinement\nfunction genComponent (\n componentName,\n el,\n state\n) {\n var children = el.inlineTemplate ? null : genChildren(el, state, true);\n return (\"_c(\" + componentName + \",\" + (genData$2(el, state)) + (children ? (\",\" + children) : '') + \")\")\n}\n\nfunction genProps (props) {\n var staticProps = \"\";\n var dynamicProps = \"\";\n for (var i = 0; i < props.length; i++) {\n var prop = props[i];\n var value = transformSpecialNewlines(prop.value);\n if (prop.dynamic) {\n dynamicProps += (prop.name) + \",\" + value + \",\";\n } else {\n staticProps += \"\\\"\" + (prop.name) + \"\\\":\" + value + \",\";\n }\n }\n staticProps = \"{\" + (staticProps.slice(0, -1)) + \"}\";\n if (dynamicProps) {\n return (\"_d(\" + staticProps + \",[\" + (dynamicProps.slice(0, -1)) + \"])\")\n } else {\n return staticProps\n }\n}\n\n// #3895, #4268\nfunction transformSpecialNewlines (text) {\n return text\n .replace(/\\u2028/g, '\\\\u2028')\n .replace(/\\u2029/g, '\\\\u2029')\n}\n\n/* */\n\n\n\n// these keywords should not appear inside expressions, but operators like\n// typeof, instanceof and in are allowed\nvar prohibitedKeywordRE = new RegExp('\\\\b' + (\n 'do,if,for,let,new,try,var,case,else,with,await,break,catch,class,const,' +\n 'super,throw,while,yield,delete,export,import,return,switch,default,' +\n 'extends,finally,continue,debugger,function,arguments'\n).split(',').join('\\\\b|\\\\b') + '\\\\b');\n\n// these unary operators should not be used as property/method names\nvar unaryOperatorsRE = new RegExp('\\\\b' + (\n 'delete,typeof,void'\n).split(',').join('\\\\s*\\\\([^\\\\)]*\\\\)|\\\\b') + '\\\\s*\\\\([^\\\\)]*\\\\)');\n\n// strip strings in expressions\nvar stripStringRE = /'(?:[^'\\\\]|\\\\.)*'|\"(?:[^\"\\\\]|\\\\.)*\"|`(?:[^`\\\\]|\\\\.)*\\$\\{|\\}(?:[^`\\\\]|\\\\.)*`|`(?:[^`\\\\]|\\\\.)*`/g;\n\n// detect problematic expressions in a template\nfunction detectErrors (ast, warn) {\n if (ast) {\n checkNode(ast, warn);\n }\n}\n\nfunction checkNode (node, warn) {\n if (node.type === 1) {\n for (var name in node.attrsMap) {\n if (dirRE.test(name)) {\n var value = node.attrsMap[name];\n if (value) {\n var range = node.rawAttrsMap[name];\n if (name === 'v-for') {\n checkFor(node, (\"v-for=\\\"\" + value + \"\\\"\"), warn, range);\n } else if (name === 'v-slot' || name[0] === '#') {\n checkFunctionParameterExpression(value, (name + \"=\\\"\" + value + \"\\\"\"), warn, range);\n } else if (onRE.test(name)) {\n checkEvent(value, (name + \"=\\\"\" + value + \"\\\"\"), warn, range);\n } else {\n checkExpression(value, (name + \"=\\\"\" + value + \"\\\"\"), warn, range);\n }\n }\n }\n }\n if (node.children) {\n for (var i = 0; i < node.children.length; i++) {\n checkNode(node.children[i], warn);\n }\n }\n } else if (node.type === 2) {\n checkExpression(node.expression, node.text, warn, node);\n }\n}\n\nfunction checkEvent (exp, text, warn, range) {\n var stripped = exp.replace(stripStringRE, '');\n var keywordMatch = stripped.match(unaryOperatorsRE);\n if (keywordMatch && stripped.charAt(keywordMatch.index - 1) !== '$') {\n warn(\n \"avoid using JavaScript unary operator as property name: \" +\n \"\\\"\" + (keywordMatch[0]) + \"\\\" in expression \" + (text.trim()),\n range\n );\n }\n checkExpression(exp, text, warn, range);\n}\n\nfunction checkFor (node, text, warn, range) {\n checkExpression(node.for || '', text, warn, range);\n checkIdentifier(node.alias, 'v-for alias', text, warn, range);\n checkIdentifier(node.iterator1, 'v-for iterator', text, warn, range);\n checkIdentifier(node.iterator2, 'v-for iterator', text, warn, range);\n}\n\nfunction checkIdentifier (\n ident,\n type,\n text,\n warn,\n range\n) {\n if (typeof ident === 'string') {\n try {\n new Function((\"var \" + ident + \"=_\"));\n } catch (e) {\n warn((\"invalid \" + type + \" \\\"\" + ident + \"\\\" in expression: \" + (text.trim())), range);\n }\n }\n}\n\nfunction checkExpression (exp, text, warn, range) {\n try {\n new Function((\"return \" + exp));\n } catch (e) {\n var keywordMatch = exp.replace(stripStringRE, '').match(prohibitedKeywordRE);\n if (keywordMatch) {\n warn(\n \"avoid using JavaScript keyword as property name: \" +\n \"\\\"\" + (keywordMatch[0]) + \"\\\"\\n Raw expression: \" + (text.trim()),\n range\n );\n } else {\n warn(\n \"invalid expression: \" + (e.message) + \" in\\n\\n\" +\n \" \" + exp + \"\\n\\n\" +\n \" Raw expression: \" + (text.trim()) + \"\\n\",\n range\n );\n }\n }\n}\n\nfunction checkFunctionParameterExpression (exp, text, warn, range) {\n try {\n new Function(exp, '');\n } catch (e) {\n warn(\n \"invalid function parameter expression: \" + (e.message) + \" in\\n\\n\" +\n \" \" + exp + \"\\n\\n\" +\n \" Raw expression: \" + (text.trim()) + \"\\n\",\n range\n );\n }\n}\n\n/* */\n\nvar range = 2;\n\nfunction generateCodeFrame (\n source,\n start,\n end\n) {\n if ( start === void 0 ) start = 0;\n if ( end === void 0 ) end = source.length;\n\n var lines = source.split(/\\r?\\n/);\n var count = 0;\n var res = [];\n for (var i = 0; i < lines.length; i++) {\n count += lines[i].length + 1;\n if (count >= start) {\n for (var j = i - range; j <= i + range || end > count; j++) {\n if (j < 0 || j >= lines.length) { continue }\n res.push((\"\" + (j + 1) + (repeat$1(\" \", 3 - String(j + 1).length)) + \"| \" + (lines[j])));\n var lineLength = lines[j].length;\n if (j === i) {\n // push underline\n var pad = start - (count - lineLength) + 1;\n var length = end > count ? lineLength - pad : end - start;\n res.push(\" | \" + repeat$1(\" \", pad) + repeat$1(\"^\", length));\n } else if (j > i) {\n if (end > count) {\n var length$1 = Math.min(end - count, lineLength);\n res.push(\" | \" + repeat$1(\"^\", length$1));\n }\n count += lineLength + 1;\n }\n }\n break\n }\n }\n return res.join('\\n')\n}\n\nfunction repeat$1 (str, n) {\n var result = '';\n if (n > 0) {\n while (true) { // eslint-disable-line\n if (n & 1) { result += str; }\n n >>>= 1;\n if (n <= 0) { break }\n str += str;\n }\n }\n return result\n}\n\n/* */\n\n\n\nfunction createFunction (code, errors) {\n try {\n return new Function(code)\n } catch (err) {\n errors.push({ err: err, code: code });\n return noop\n }\n}\n\nfunction createCompileToFunctionFn (compile) {\n var cache = Object.create(null);\n\n return function compileToFunctions (\n template,\n options,\n vm\n ) {\n options = extend({}, options);\n var warn$$1 = options.warn || warn;\n delete options.warn;\n\n /* istanbul ignore if */\n if (true) {\n // detect possible CSP restriction\n try {\n new Function('return 1');\n } catch (e) {\n if (e.toString().match(/unsafe-eval|CSP/)) {\n warn$$1(\n 'It seems you are using the standalone build of Vue.js in an ' +\n 'environment with Content Security Policy that prohibits unsafe-eval. ' +\n 'The template compiler cannot work in this environment. Consider ' +\n 'relaxing the policy to allow unsafe-eval or pre-compiling your ' +\n 'templates into render functions.'\n );\n }\n }\n }\n\n // check cache\n var key = options.delimiters\n ? String(options.delimiters) + template\n : template;\n if (cache[key]) {\n return cache[key]\n }\n\n // compile\n var compiled = compile(template, options);\n\n // check compilation errors/tips\n if (true) {\n if (compiled.errors && compiled.errors.length) {\n if (options.outputSourceRange) {\n compiled.errors.forEach(function (e) {\n warn$$1(\n \"Error compiling template:\\n\\n\" + (e.msg) + \"\\n\\n\" +\n generateCodeFrame(template, e.start, e.end),\n vm\n );\n });\n } else {\n warn$$1(\n \"Error compiling template:\\n\\n\" + template + \"\\n\\n\" +\n compiled.errors.map(function (e) { return (\"- \" + e); }).join('\\n') + '\\n',\n vm\n );\n }\n }\n if (compiled.tips && compiled.tips.length) {\n if (options.outputSourceRange) {\n compiled.tips.forEach(function (e) { return tip(e.msg, vm); });\n } else {\n compiled.tips.forEach(function (msg) { return tip(msg, vm); });\n }\n }\n }\n\n // turn code into functions\n var res = {};\n var fnGenErrors = [];\n res.render = createFunction(compiled.render, fnGenErrors);\n res.staticRenderFns = compiled.staticRenderFns.map(function (code) {\n return createFunction(code, fnGenErrors)\n });\n\n // check function generation errors.\n // this should only happen if there is a bug in the compiler itself.\n // mostly for codegen development use\n /* istanbul ignore if */\n if (true) {\n if ((!compiled.errors || !compiled.errors.length) && fnGenErrors.length) {\n warn$$1(\n \"Failed to generate render function:\\n\\n\" +\n fnGenErrors.map(function (ref) {\n var err = ref.err;\n var code = ref.code;\n\n return ((err.toString()) + \" in\\n\\n\" + code + \"\\n\");\n }).join('\\n'),\n vm\n );\n }\n }\n\n return (cache[key] = res)\n }\n}\n\n/* */\n\nfunction createCompilerCreator (baseCompile) {\n return function createCompiler (baseOptions) {\n function compile (\n template,\n options\n ) {\n var finalOptions = Object.create(baseOptions);\n var errors = [];\n var tips = [];\n\n var warn = function (msg, range, tip) {\n (tip ? tips : errors).push(msg);\n };\n\n if (options) {\n if ( true && options.outputSourceRange) {\n // $flow-disable-line\n var leadingSpaceLength = template.match(/^\\s*/)[0].length;\n\n warn = function (msg, range, tip) {\n var data = { msg: msg };\n if (range) {\n if (range.start != null) {\n data.start = range.start + leadingSpaceLength;\n }\n if (range.end != null) {\n data.end = range.end + leadingSpaceLength;\n }\n }\n (tip ? tips : errors).push(data);\n };\n }\n // merge custom modules\n if (options.modules) {\n finalOptions.modules =\n (baseOptions.modules || []).concat(options.modules);\n }\n // merge custom directives\n if (options.directives) {\n finalOptions.directives = extend(\n Object.create(baseOptions.directives || null),\n options.directives\n );\n }\n // copy other options\n for (var key in options) {\n if (key !== 'modules' && key !== 'directives') {\n finalOptions[key] = options[key];\n }\n }\n }\n\n finalOptions.warn = warn;\n\n var compiled = baseCompile(template.trim(), finalOptions);\n if (true) {\n detectErrors(compiled.ast, warn);\n }\n compiled.errors = errors;\n compiled.tips = tips;\n return compiled\n }\n\n return {\n compile: compile,\n compileToFunctions: createCompileToFunctionFn(compile)\n }\n }\n}\n\n/* */\n\n// `createCompilerCreator` allows creating compilers that use alternative\n// parser/optimizer/codegen, e.g the SSR optimizing compiler.\n// Here we just export a default compiler using the default parts.\nvar createCompiler = createCompilerCreator(function baseCompile (\n template,\n options\n) {\n var ast = parse(template.trim(), options);\n if (options.optimize !== false) {\n optimize(ast, options);\n }\n var code = generate(ast, options);\n return {\n ast: ast,\n render: code.render,\n staticRenderFns: code.staticRenderFns\n }\n});\n\n/* */\n\nvar ref$1 = createCompiler(baseOptions);\nvar compile = ref$1.compile;\nvar compileToFunctions = ref$1.compileToFunctions;\n\n/* */\n\n// check whether current browser encodes a char inside attribute values\nvar div;\nfunction getShouldDecode (href) {\n div = div || document.createElement('div');\n div.innerHTML = href ? \"<a href=\\\"\\n\\\"/>\" : \"<div a=\\\"\\n\\\"/>\";\n return div.innerHTML.indexOf(' ') > 0\n}\n\n// #3663: IE encodes newlines inside attribute values while other browsers don't\nvar shouldDecodeNewlines = inBrowser ? getShouldDecode(false) : false;\n// #6828: chrome encodes content in a[href]\nvar shouldDecodeNewlinesForHref = inBrowser ? getShouldDecode(true) : false;\n\n/* */\n\nvar idToTemplate = cached(function (id) {\n var el = query(id);\n return el && el.innerHTML\n});\n\nvar mount = Vue.prototype.$mount;\nVue.prototype.$mount = function (\n el,\n hydrating\n) {\n el = el && query(el);\n\n /* istanbul ignore if */\n if (el === document.body || el === document.documentElement) {\n true && warn(\n \"Do not mount Vue to <html> or <body> - mount to normal elements instead.\"\n );\n return this\n }\n\n var options = this.$options;\n // resolve template/el and convert to render function\n if (!options.render) {\n var template = options.template;\n if (template) {\n if (typeof template === 'string') {\n if (template.charAt(0) === '#') {\n template = idToTemplate(template);\n /* istanbul ignore if */\n if ( true && !template) {\n warn(\n (\"Template element not found or is empty: \" + (options.template)),\n this\n );\n }\n }\n } else if (template.nodeType) {\n template = template.innerHTML;\n } else {\n if (true) {\n warn('invalid template option:' + template, this);\n }\n return this\n }\n } else if (el) {\n template = getOuterHTML(el);\n }\n if (template) {\n /* istanbul ignore if */\n if ( true && config.performance && mark) {\n mark('compile');\n }\n\n var ref = compileToFunctions(template, {\n outputSourceRange: \"development\" !== 'production',\n shouldDecodeNewlines: shouldDecodeNewlines,\n shouldDecodeNewlinesForHref: shouldDecodeNewlinesForHref,\n delimiters: options.delimiters,\n comments: options.comments\n }, this);\n var render = ref.render;\n var staticRenderFns = ref.staticRenderFns;\n options.render = render;\n options.staticRenderFns = staticRenderFns;\n\n /* istanbul ignore if */\n if ( true && config.performance && mark) {\n mark('compile end');\n measure((\"vue \" + (this._name) + \" compile\"), 'compile', 'compile end');\n }\n }\n }\n return mount.call(this, el, hydrating)\n};\n\n/**\n * Get outerHTML of elements, taking care\n * of SVG elements in IE as well.\n */\nfunction getOuterHTML (el) {\n if (el.outerHTML) {\n return el.outerHTML\n } else {\n var container = document.createElement('div');\n container.appendChild(el.cloneNode(true));\n return container.innerHTML\n }\n}\n\nVue.compile = compileToFunctions;\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (Vue);\n\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../../webpack/buildin/global.js */ \"./node_modules/webpack/buildin/global.js\"), __webpack_require__(/*! ./../../timers-browserify/main.js */ \"./node_modules/timers-browserify/main.js\").setImmediate))\n\n//# sourceURL=webpack:///./node_modules/vue/dist/vue.esm.js?");
/***/ }),
/***/ "./node_modules/webpack/buildin/global.js":
/*!***********************************!*\
!*** (webpack)/buildin/global.js ***!
\***********************************/
/*! no static exports found */
/***/ (function(module, exports) {
eval("var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n\n\n//# sourceURL=webpack:///(webpack)/buildin/global.js?");
/***/ })
/******/ });
Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists