Sindbad~EG File Manager

Current Path : /home/escuelai/public_html/biblioteca.escuelaintegral.edu.uy/javascript/vuejs/portal/
Upload File :
Current File : /home/escuelai/public_html/biblioteca.escuelaintegral.edu.uy/javascript/vuejs/portal/build.js

/******/ (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(\"&#x2697;&#xFE0F\"), 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 \"&eacute;\" 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  '&lt;': '<',\n  '&gt;': '>',\n  '&quot;': '\"',\n  '&amp;': '&',\n  '&#10;': '\\n',\n  '&#9;': '\\t',\n  '&#39;': \"'\"\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('&#10;') > 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