UNPKG

element-nice-ui

Version:

A Component Library for Vue.js.

669 lines (621 loc) 20.3 kB
module.exports = /******/ (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 = "/dist/"; /******/ /******/ /******/ // Load entry module and return exports /******/ return __webpack_require__(__webpack_require__.s = 260); /******/ }) /************************************************************************/ /******/ ({ /***/ 116: /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; /* harmony default export */ __webpack_exports__["a"] = ({ inject: ['rootMenu'], computed: { indexPath() { const path = [this.index]; let parent = this.$parent; while (parent.$options.componentName !== 'ElMenu') { if (parent.index) { path.unshift(parent.index); } parent = parent.$parent; } return path; }, parentMenu() { let parent = this.$parent; while (parent && ['ElMenu', 'ElSubmenu'].indexOf(parent.$options.componentName) === -1) { parent = parent.$parent; } return parent; }, paddingStyle() { if (this.rootMenu.mode !== 'vertical') return {}; let padding = 20; let parent = this.$parent; if (this.rootMenu.collapse) { padding = 20; } else { while (parent && parent.$options.componentName !== 'ElMenu') { if (parent.$options.componentName === 'ElSubmenu') { padding += 20; } parent = parent.$parent; } } return { paddingLeft: padding + 'px' }; } } }); /***/ }), /***/ 13: /***/ (function(module, exports) { module.exports = require("element-nice-ui/lib/mixins/emitter"); /***/ }), /***/ 17: /***/ (function(module, exports) { module.exports = require("element-nice-ui/lib/utils/vue-popper"); /***/ }), /***/ 2: /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; }); /* globals __VUE_SSR_CONTEXT__ */ // IMPORTANT: Do NOT use ES2015 features in this file (except for modules). // This module is a runtime utility for cleaner component module output and will // be included in the final webpack user bundle. function normalizeComponent( scriptExports, render, staticRenderFns, functionalTemplate, injectStyles, scopeId, moduleIdentifier /* server only */, shadowMode /* vue-cli only */ ) { // Vue.extend constructor export interop var options = typeof scriptExports === 'function' ? scriptExports.options : scriptExports // render functions if (render) { options.render = render options.staticRenderFns = staticRenderFns options._compiled = true } // functional template if (functionalTemplate) { options.functional = true } // scopedId if (scopeId) { options._scopeId = 'data-v-' + scopeId } var hook if (moduleIdentifier) { // server build hook = function (context) { // 2.3 injection context = context || // cached call (this.$vnode && this.$vnode.ssrContext) || // stateful (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional // 2.2 with runInNewContext: true if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') { context = __VUE_SSR_CONTEXT__ } // inject component styles if (injectStyles) { injectStyles.call(this, context) } // register component module identifier for async chunk inferrence if (context && context._registeredComponents) { context._registeredComponents.add(moduleIdentifier) } } // used by ssr in case component is cached and beforeCreate // never gets called options._ssrRegister = hook } else if (injectStyles) { hook = shadowMode ? function () { injectStyles.call( this, (options.functional ? this.parent : this).$root.$options.shadowRoot ) } : injectStyles } if (hook) { if (options.functional) { // for template-only hot-reload because in that case the render fn doesn't // go through the normalizer options._injectStyles = hook // register for functional component in vue file var originalRender = options.render options.render = function renderWithStyleInjection(h, context) { hook.call(context) return originalRender(h, context) } } else { // inject component registration as beforeCreate hook var existing = options.beforeCreate options.beforeCreate = existing ? [].concat(existing, hook) : [hook] } } return { exports: scriptExports, options: options } } /***/ }), /***/ 260: /***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; // ESM COMPAT FLAG __webpack_require__.r(__webpack_exports__); // EXTERNAL MODULE: external "element-nice-ui/lib/transitions/collapse-transition" var collapse_transition_ = __webpack_require__(50); var collapse_transition_default = /*#__PURE__*/__webpack_require__.n(collapse_transition_); // EXTERNAL MODULE: ./packages/menu/src/menu-mixin.js var menu_mixin = __webpack_require__(116); // EXTERNAL MODULE: external "element-nice-ui/lib/mixins/emitter" var emitter_ = __webpack_require__(13); var emitter_default = /*#__PURE__*/__webpack_require__.n(emitter_); // EXTERNAL MODULE: external "element-nice-ui/lib/utils/vue-popper" var vue_popper_ = __webpack_require__(17); var vue_popper_default = /*#__PURE__*/__webpack_require__.n(vue_popper_); // CONCATENATED MODULE: ./node_modules/.pnpm/babel-loader@8.4.1_@babel+core@7.28.0_webpack@4.47.0/node_modules/babel-loader/lib!./node_modules/.pnpm/vue-loader@15.11.1_@vue+compiler-sfc@3.5.18_css-loader@5.2.7_webpack@4.47.0__lodash@4.1_bb9a19950a80e648dc95ba33c71fa343/node_modules/vue-loader/lib??vue-loader-options!./packages/menu/src/submenu.vue?vue&type=script&lang=js const poperMixins = { props: { transformOrigin: { type: [Boolean, String], default: false }, offset: vue_popper_default.a.props.offset, boundariesPadding: vue_popper_default.a.props.boundariesPadding, popperOptions: vue_popper_default.a.props.popperOptions }, data: vue_popper_default.a.data, methods: vue_popper_default.a.methods, beforeDestroy: vue_popper_default.a.beforeDestroy, deactivated: vue_popper_default.a.deactivated }; /* harmony default export */ var submenuvue_type_script_lang_js = ({ name: 'ElSubmenu', componentName: 'ElSubmenu', mixins: [menu_mixin["a" /* default */], emitter_default.a, poperMixins], components: { ElCollapseTransition: collapse_transition_default.a }, props: { index: { type: String, required: true }, showTimeout: { type: Number, default: 300 }, hideTimeout: { type: Number, default: 300 }, popperClass: String, disabled: Boolean, popperAppendToBody: { type: Boolean, default: true } }, data() { return { popperJS: null, timeout: null, items: {}, submenus: {}, mouseInChild: false }; }, watch: { opened(val) { if (this.isMenuPopup) { this.$nextTick(_ => { this.updatePopper(); }); } } }, computed: { // popper option appendToBody() { return this.popperAppendToBody === undefined ? this.isFirstLevel : this.popperAppendToBody; }, menuTransitionName() { return this.rootMenu.collapse ? 'el-zoom-in-left' : 'el-zoom-in-top'; }, opened() { return this.rootMenu.openedMenus.indexOf(this.index) > -1; }, active() { let isActive = false; const submenus = this.submenus; const items = this.items; Object.keys(items).forEach(index => { if (items[index].active) { isActive = true; } }); Object.keys(submenus).forEach(index => { if (submenus[index].active) { isActive = true; } }); return isActive; }, hoverBackground() { return this.rootMenu.hoverBackground; }, backgroundColor() { return this.rootMenu.backgroundColor || ''; }, activeTextColor() { return this.rootMenu.activeTextColor || ''; }, textColor() { return this.rootMenu.textColor || ''; }, mode() { return this.rootMenu.mode; }, isMenuPopup() { return this.rootMenu.isMenuPopup; }, titleStyle() { if (this.mode !== 'horizontal') { return { color: this.textColor }; } return { borderBottomColor: this.active ? this.rootMenu.activeTextColor ? this.activeTextColor : '' : 'transparent', color: this.active ? this.activeTextColor : this.textColor }; }, isFirstLevel() { let isFirstLevel = true; let parent = this.$parent; let { recursiveMenuProp } = this.rootMenu; while (parent && parent !== this.rootMenu) { let menuData = parent[recursiveMenuProp]; if (['ElSubmenu', 'ElMenuItemGroup'].indexOf(parent.$options.componentName) > -1 || menuData && menuData.children && menuData.children.length) { isFirstLevel = false; break; } else { parent = parent.$parent; } } return isFirstLevel; } }, methods: { handleCollapseToggle(value) { if (value) { this.initPopper(); } else { this.doDestroy(); } }, addItem(item) { this.$set(this.items, item.index, item); }, removeItem(item) { delete this.items[item.index]; }, addSubmenu(item) { this.$set(this.submenus, item.index, item); }, removeSubmenu(item) { delete this.submenus[item.index]; }, handleClick() { const { rootMenu, disabled } = this; if (rootMenu.menuTrigger === 'hover' && rootMenu.mode === 'horizontal' || rootMenu.collapse && rootMenu.mode === 'vertical' || disabled) { return; } this.dispatch('ElMenu', 'submenu-click', this); }, /** * 鼠标移入 */ handleMouseenter(event) { let showTimeout = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.showTimeout; if (!('ActiveXObject' in window) && event.type === 'focus' && !event.relatedTarget) { return; } const { rootMenu, disabled } = this; if (rootMenu.menuTrigger === 'click' && rootMenu.mode === 'horizontal' || !rootMenu.collapse && rootMenu.mode === 'vertical' || disabled) { return; } this.dispatch('ElSubmenu', 'mouse-enter-child'); clearTimeout(this.timeout); this.timeout = setTimeout(() => { this.rootMenu.openMenu(this.index, this.indexPath); }, showTimeout); // 此处修复栈溢出的bug if (this.appendToBody && event.target !== this.$parent.$el) { this.$parent.$el.dispatchEvent(new MouseEvent('mouseenter')); } }, handleMouseleave() { let deepDispatch = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false; const { rootMenu } = this; if (rootMenu.menuTrigger === 'click' && rootMenu.mode === 'horizontal' || !rootMenu.collapse && rootMenu.mode === 'vertical') { return; } this.dispatch('ElSubmenu', 'mouse-leave-child'); clearTimeout(this.timeout); this.timeout = setTimeout(() => { !this.mouseInChild && this.rootMenu.closeMenu(this.index); }, this.hideTimeout); if (this.appendToBody && deepDispatch) { if (this.$parent.$options.name === 'ElSubmenu') { this.$parent.handleMouseleave(true); } } }, handleTitleMouseenter() { if (this.mode === 'horizontal' && !this.rootMenu.backgroundColor) return; const title = this.$refs['submenu-title']; title && (title.style.backgroundColor = this.rootMenu.hoverBackground); }, handleTitleMouseleave() { if (this.mode === 'horizontal' && !this.rootMenu.backgroundColor) return; const title = this.$refs['submenu-title']; title && (title.style.backgroundColor = this.rootMenu.backgroundColor || ''); }, updatePlacement() { this.currentPlacement = this.mode === 'horizontal' && this.isFirstLevel ? 'bottom-start' : 'right-start'; }, initPopper() { this.referenceElm = this.$el; this.popperElm = this.$refs.menu; this.updatePlacement(); } }, created() { this.$on('toggle-collapse', this.handleCollapseToggle); this.$on('mouse-enter-child', () => { this.mouseInChild = true; clearTimeout(this.timeout); }); this.$on('mouse-leave-child', () => { this.mouseInChild = false; clearTimeout(this.timeout); }); }, mounted() { this.parentMenu.addSubmenu(this); this.rootMenu.addSubmenu(this); this.initPopper(); }, inject: ['rootMenu'], beforeDestroy() { this.parentMenu.removeSubmenu(this); this.rootMenu.removeSubmenu(this); }, render(h) { const { active, opened, paddingStyle, titleStyle, backgroundColor, rootMenu, currentPlacement, menuTransitionName, mode, disabled, popperClass, $slots, isFirstLevel } = this; const { size } = this.rootMenu; let classes = ['el-menu el-menu--popup', "el-menu--popup-".concat(currentPlacement)]; ['small', 'large', 'medium'].includes(size) && classes.push("el-menu--".concat(size)); const popupMenu = h("transition", { "attrs": { "name": menuTransitionName } }, [h("div", { "ref": 'menu', "directives": [{ name: "show", value: opened }], "class": ["el-menu--".concat(mode), popperClass], "on": { "mouseenter": $event => this.handleMouseenter($event, 100), "mouseleave": () => this.handleMouseleave(true), "focus": $event => this.handleMouseenter($event, 100) } }, [h("ul", { "attrs": { "role": 'menu' }, "class": classes, "style": { backgroundColor: rootMenu.backgroundColor || '' } }, [$slots.default])])]); const inlineMenu = h("el-collapse-transition", [h("ul", { "attrs": { "role": 'menu' }, "class": 'el-menu el-menu--inline', "directives": [{ name: "show", value: opened }], "style": { backgroundColor: rootMenu.backgroundColor || '' } }, [$slots.default])]); const submenuTitleIcon = rootMenu.mode === 'horizontal' && isFirstLevel || rootMenu.mode === 'vertical' && !rootMenu.collapse ? 'el-icon-arrow-down' : 'el-icon-arrow-right'; return h("li", { "class": { 'el-submenu': true, 'is-active': active, 'is-opened': opened, 'is-disabled': disabled }, "attrs": { "role": 'menuitem', "aria-haspopup": 'true', "aria-expanded": opened }, "on": { "mouseenter": this.handleMouseenter, "mouseleave": () => this.handleMouseleave(false), "focus": this.handleMouseenter } }, [h("div", { "class": 'el-submenu__title', "ref": 'submenu-title', "on": { "click": this.handleClick, "mouseenter": this.handleTitleMouseenter, "mouseleave": this.handleTitleMouseleave }, "style": [paddingStyle, titleStyle, { backgroundColor }] }, [$slots.title, h("i", { "class": ['el-submenu__icon-arrow', submenuTitleIcon] })]), this.isMenuPopup ? popupMenu : inlineMenu]); } }); // CONCATENATED MODULE: ./packages/menu/src/submenu.vue?vue&type=script&lang=js /* harmony default export */ var src_submenuvue_type_script_lang_js = (submenuvue_type_script_lang_js); // EXTERNAL MODULE: ./node_modules/.pnpm/vue-loader@15.11.1_@vue+compiler-sfc@3.5.18_css-loader@5.2.7_webpack@4.47.0__lodash@4.1_bb9a19950a80e648dc95ba33c71fa343/node_modules/vue-loader/lib/runtime/componentNormalizer.js var componentNormalizer = __webpack_require__(2); // CONCATENATED MODULE: ./packages/menu/src/submenu.vue var render, staticRenderFns /* normalize component */ var component = Object(componentNormalizer["a" /* default */])( src_submenuvue_type_script_lang_js, render, staticRenderFns, false, null, null, null ) /* harmony default export */ var submenu = (component.exports); // CONCATENATED MODULE: ./packages/submenu/index.js /* istanbul ignore next */ submenu.install = function (Vue) { Vue.component(submenu.name, submenu); }; /* harmony default export */ var packages_submenu = __webpack_exports__["default"] = (submenu); /***/ }), /***/ 50: /***/ (function(module, exports) { module.exports = require("element-nice-ui/lib/transitions/collapse-transition"); /***/ }) /******/ });