cy-element-ui 1.0.0 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +0 -29
- package/lib/alert.js +420 -0
- package/lib/aside.js +277 -0
- package/lib/autocomplete.js +952 -0
- package/lib/avatar.js +363 -0
- package/lib/backtop.js +404 -0
- package/lib/badge.js +334 -0
- package/lib/breadcrumb-item.js +322 -0
- package/lib/breadcrumb.js +293 -0
- package/lib/button-group.js +262 -0
- package/lib/button.js +357 -0
- package/lib/calendar.js +933 -0
- package/lib/card.js +297 -0
- package/lib/carousel-item.js +434 -0
- package/lib/carousel.js +707 -0
- package/lib/cascader-panel.js +1558 -0
- package/lib/cascader.js +1439 -0
- package/lib/checkbox-button.js +583 -0
- package/lib/checkbox-group.js +313 -0
- package/lib/checkbox.js +627 -0
- package/lib/col.js +177 -0
- package/lib/collapse-item.js +497 -0
- package/lib/collapse.js +329 -0
- package/lib/color-picker.js +1943 -0
- package/lib/container.js +288 -0
- package/lib/date-picker.js +6335 -0
- package/lib/descriptions-item.js +140 -0
- package/lib/descriptions.js +457 -0
- package/lib/dialog.js +598 -0
- package/lib/directives/mousewheel.js +26 -0
- package/lib/directives/repeat-click.js +33 -0
- package/lib/divider.js +313 -0
- package/lib/drawer.js +592 -0
- package/lib/dropdown-item.js +316 -0
- package/lib/dropdown-menu.js +351 -0
- package/lib/dropdown.js +643 -0
- package/lib/element-ui.common.js +44032 -0
- package/lib/empty.js +730 -0
- package/lib/footer.js +277 -0
- package/lib/form-item.js +826 -0
- package/lib/form.js +466 -0
- package/lib/header.js +277 -0
- package/lib/icon.js +265 -0
- package/lib/image.js +1138 -0
- package/lib/index.js +1 -0
- package/lib/infinite-scroll.js +301 -0
- package/lib/input-number.js +752 -0
- package/lib/input.js +998 -0
- package/lib/link.js +332 -0
- package/lib/loading.js +631 -0
- package/lib/locale/format.js +56 -0
- package/lib/locale/index.js +63 -0
- package/lib/locale/lang/af-ZA.js +126 -0
- package/lib/locale/lang/ar.js +125 -0
- package/lib/locale/lang/az.js +126 -0
- package/lib/locale/lang/bg.js +126 -0
- package/lib/locale/lang/bn.js +126 -0
- package/lib/locale/lang/ca.js +125 -0
- package/lib/locale/lang/cs-CZ.js +128 -0
- package/lib/locale/lang/da.js +125 -0
- package/lib/locale/lang/de.js +127 -0
- package/lib/locale/lang/ee.js +126 -0
- package/lib/locale/lang/el.js +126 -0
- package/lib/locale/lang/en.js +126 -0
- package/lib/locale/lang/eo.js +126 -0
- package/lib/locale/lang/es.js +125 -0
- package/lib/locale/lang/eu.js +126 -0
- package/lib/locale/lang/fa.js +126 -0
- package/lib/locale/lang/fi.js +126 -0
- package/lib/locale/lang/fr.js +125 -0
- package/lib/locale/lang/he.js +126 -0
- package/lib/locale/lang/hr.js +126 -0
- package/lib/locale/lang/hu.js +125 -0
- package/lib/locale/lang/hy-AM.js +126 -0
- package/lib/locale/lang/id.js +126 -0
- package/lib/locale/lang/is.js +126 -0
- package/lib/locale/lang/it.js +125 -0
- package/lib/locale/lang/ja.js +126 -0
- package/lib/locale/lang/kg.js +126 -0
- package/lib/locale/lang/km.js +126 -0
- package/lib/locale/lang/ko.js +126 -0
- package/lib/locale/lang/ku.js +126 -0
- package/lib/locale/lang/kz.js +126 -0
- package/lib/locale/lang/lo-LA.js +126 -0
- package/lib/locale/lang/lt.js +126 -0
- package/lib/locale/lang/lv.js +126 -0
- package/lib/locale/lang/mn.js +126 -0
- package/lib/locale/lang/ms.js +125 -0
- package/lib/locale/lang/nb-NO.js +125 -0
- package/lib/locale/lang/nl.js +126 -0
- package/lib/locale/lang/pl.js +126 -0
- package/lib/locale/lang/pt-br.js +126 -0
- package/lib/locale/lang/pt.js +126 -0
- package/lib/locale/lang/ro.js +126 -0
- package/lib/locale/lang/ru-RU.js +126 -0
- package/lib/locale/lang/si.js +126 -0
- package/lib/locale/lang/sk.js +128 -0
- package/lib/locale/lang/sl.js +126 -0
- package/lib/locale/lang/sr-Latn.js +126 -0
- package/lib/locale/lang/sr.js +126 -0
- package/lib/locale/lang/sv-SE.js +126 -0
- package/lib/locale/lang/sw.js +126 -0
- package/lib/locale/lang/ta.js +125 -0
- package/lib/locale/lang/th.js +126 -0
- package/lib/locale/lang/tk.js +126 -0
- package/lib/locale/lang/tr-TR.js +126 -0
- package/lib/locale/lang/ua.js +126 -0
- package/lib/locale/lang/ug-CN.js +126 -0
- package/lib/locale/lang/uz-UZ.js +126 -0
- package/lib/locale/lang/vi.js +126 -0
- package/lib/locale/lang/zh-CN.js +126 -0
- package/lib/locale/lang/zh-TW.js +126 -0
- package/lib/main.js +264 -0
- package/lib/menu-item-group.js +308 -0
- package/lib/menu-item.js +491 -0
- package/lib/menu.js +865 -0
- package/lib/message-box.js +1192 -0
- package/lib/message.js +548 -0
- package/lib/mixins/emitter.js +36 -0
- package/lib/mixins/focus.js +15 -0
- package/lib/mixins/locale.js +17 -0
- package/lib/mixins/migrating.js +69 -0
- package/lib/notification.js +615 -0
- package/lib/option-group.js +344 -0
- package/lib/option.js +474 -0
- package/lib/page-header.js +319 -0
- package/lib/pagination.js +950 -0
- package/lib/popconfirm.js +457 -0
- package/lib/popover.js +617 -0
- package/lib/progress.js +595 -0
- package/lib/radio-button.js +463 -0
- package/lib/radio-group.js +391 -0
- package/lib/radio.js +497 -0
- package/lib/rate.js +670 -0
- package/lib/result.js +578 -0
- package/lib/row.js +149 -0
- package/lib/scrollbar.js +423 -0
- package/lib/select.js +2167 -0
- package/lib/skeleton-item.js +342 -0
- package/lib/skeleton.js +372 -0
- package/lib/slider.js +1199 -0
- package/lib/spinner.js +301 -0
- package/lib/statistic.js +533 -0
- package/lib/step.js +522 -0
- package/lib/steps.js +342 -0
- package/lib/submenu.js +701 -0
- package/lib/switch.js +554 -0
- package/lib/tab-pane.js +332 -0
- package/lib/table-column.js +952 -0
- package/lib/table.js +5010 -0
- package/lib/tabs.js +920 -0
- package/lib/tag.js +304 -0
- package/lib/theme-chalk/README.md +33 -0
- package/lib/theme-chalk/package.json +35 -0
- package/lib/theme-chalk/src/alert.scss +147 -0
- package/lib/theme-chalk/src/aside.scss +7 -0
- package/lib/theme-chalk/src/autocomplete.scss +80 -0
- package/lib/theme-chalk/src/avatar.scss +51 -0
- package/lib/theme-chalk/src/backtop.scss +22 -0
- package/lib/theme-chalk/src/badge.scss +57 -0
- package/lib/theme-chalk/src/base.scss +2 -0
- package/lib/theme-chalk/src/breadcrumb-item.scss +0 -0
- package/lib/theme-chalk/src/breadcrumb.scss +55 -0
- package/lib/theme-chalk/src/button-group.scss +0 -0
- package/lib/theme-chalk/src/button.scss +262 -0
- package/lib/theme-chalk/src/calendar.scss +79 -0
- package/lib/theme-chalk/src/card.scss +32 -0
- package/lib/theme-chalk/src/carousel-item.scss +50 -0
- package/lib/theme-chalk/src/carousel.scss +161 -0
- package/lib/theme-chalk/src/cascader-panel.scss +120 -0
- package/lib/theme-chalk/src/cascader.scss +182 -0
- package/lib/theme-chalk/src/checkbox-button.scss +0 -0
- package/lib/theme-chalk/src/checkbox-group.scss +0 -0
- package/lib/theme-chalk/src/checkbox.scss +359 -0
- package/lib/theme-chalk/src/col.scss +156 -0
- package/lib/theme-chalk/src/collapse-item.scss +0 -0
- package/lib/theme-chalk/src/collapse.scss +63 -0
- package/lib/theme-chalk/src/color-picker.scss +384 -0
- package/lib/theme-chalk/src/common/popup.scss +42 -0
- package/lib/theme-chalk/src/common/transition.scss +99 -0
- package/lib/theme-chalk/src/common/var.scss +1028 -0
- package/lib/theme-chalk/src/container.scss +14 -0
- package/lib/theme-chalk/src/date-picker/date-picker.scss +97 -0
- package/lib/theme-chalk/src/date-picker/date-range-picker.scss +101 -0
- package/lib/theme-chalk/src/date-picker/date-table.scss +151 -0
- package/lib/theme-chalk/src/date-picker/month-table.scss +82 -0
- package/lib/theme-chalk/src/date-picker/picker-panel.scss +117 -0
- package/lib/theme-chalk/src/date-picker/picker.scss +197 -0
- package/lib/theme-chalk/src/date-picker/time-picker.scss +85 -0
- package/lib/theme-chalk/src/date-picker/time-range-picker.scss +31 -0
- package/lib/theme-chalk/src/date-picker/time-spinner.scss +110 -0
- package/lib/theme-chalk/src/date-picker/year-table.scss +51 -0
- package/lib/theme-chalk/src/date-picker.scss +12 -0
- package/lib/theme-chalk/src/descriptions-item.scss +42 -0
- package/lib/theme-chalk/src/descriptions.scss +111 -0
- package/lib/theme-chalk/src/dialog.scss +123 -0
- package/lib/theme-chalk/src/display.scss +12 -0
- package/lib/theme-chalk/src/divider.scss +47 -0
- package/lib/theme-chalk/src/drawer.scss +219 -0
- package/lib/theme-chalk/src/dropdown-item.scss +0 -0
- package/lib/theme-chalk/src/dropdown-menu.scss +0 -0
- package/lib/theme-chalk/src/dropdown.scss +182 -0
- package/lib/theme-chalk/src/empty.scss +45 -0
- package/lib/theme-chalk/src/fonts/element-icons.ttf +0 -0
- package/lib/theme-chalk/src/fonts/element-icons.woff +0 -0
- package/lib/theme-chalk/src/footer.scss +8 -0
- package/lib/theme-chalk/src/form-item.scss +0 -0
- package/lib/theme-chalk/src/form.scss +167 -0
- package/lib/theme-chalk/src/header.scss +8 -0
- package/lib/theme-chalk/src/icon.scss +1167 -0
- package/lib/theme-chalk/src/image.scss +179 -0
- package/lib/theme-chalk/src/index.scss +87 -0
- package/lib/theme-chalk/src/infinite-scroll.scss +0 -0
- package/lib/theme-chalk/src/infiniteScroll.scss +0 -0
- package/lib/theme-chalk/src/input-number.scss +180 -0
- package/lib/theme-chalk/src/input.scss +360 -0
- package/lib/theme-chalk/src/link.scss +81 -0
- package/lib/theme-chalk/src/loading.scss +96 -0
- package/lib/theme-chalk/src/main.scss +12 -0
- package/lib/theme-chalk/src/menu-item-group.scss +0 -0
- package/lib/theme-chalk/src/menu-item.scss +0 -0
- package/lib/theme-chalk/src/menu.scss +289 -0
- package/lib/theme-chalk/src/message-box.scss +226 -0
- package/lib/theme-chalk/src/message.scss +120 -0
- package/lib/theme-chalk/src/mixins/_button.scss +81 -0
- package/lib/theme-chalk/src/mixins/config.scss +4 -0
- package/lib/theme-chalk/src/mixins/function.scss +44 -0
- package/lib/theme-chalk/src/mixins/mixins.scss +190 -0
- package/lib/theme-chalk/src/mixins/utils.scss +39 -0
- package/lib/theme-chalk/src/notification.scss +99 -0
- package/lib/theme-chalk/src/option-group.scss +42 -0
- package/lib/theme-chalk/src/option.scss +36 -0
- package/lib/theme-chalk/src/page-header.scss +41 -0
- package/lib/theme-chalk/src/pagination.scss +295 -0
- package/lib/theme-chalk/src/popconfirm.scss +16 -0
- package/lib/theme-chalk/src/popover.scss +40 -0
- package/lib/theme-chalk/src/popper.scss +101 -0
- package/lib/theme-chalk/src/progress.scss +141 -0
- package/lib/theme-chalk/src/radio-button.scss +113 -0
- package/lib/theme-chalk/src/radio-group.scss +9 -0
- package/lib/theme-chalk/src/radio.scss +199 -0
- package/lib/theme-chalk/src/rate.scss +49 -0
- package/lib/theme-chalk/src/reset.scss +79 -0
- package/lib/theme-chalk/src/result.scss +61 -0
- package/lib/theme-chalk/src/row.scss +43 -0
- package/lib/theme-chalk/src/scrollbar.scss +72 -0
- package/lib/theme-chalk/src/select-dropdown.scss +62 -0
- package/lib/theme-chalk/src/select.scss +152 -0
- package/lib/theme-chalk/src/skeleton-item.scss +84 -0
- package/lib/theme-chalk/src/skeleton.scss +40 -0
- package/lib/theme-chalk/src/slider.scss +250 -0
- package/lib/theme-chalk/src/spinner.scss +44 -0
- package/lib/theme-chalk/src/statistic.scss +38 -0
- package/lib/theme-chalk/src/step.scss +317 -0
- package/lib/theme-chalk/src/steps.scss +20 -0
- package/lib/theme-chalk/src/submenu.scss +0 -0
- package/lib/theme-chalk/src/switch.scss +116 -0
- package/lib/theme-chalk/src/tab-pane.scss +0 -0
- package/lib/theme-chalk/src/table-column.scss +97 -0
- package/lib/theme-chalk/src/table.scss +564 -0
- package/lib/theme-chalk/src/tabs.scss +602 -0
- package/lib/theme-chalk/src/tag.scss +163 -0
- package/lib/theme-chalk/src/time-picker.scss +8 -0
- package/lib/theme-chalk/src/time-select.scss +37 -0
- package/lib/theme-chalk/src/timeline-item.scss +86 -0
- package/lib/theme-chalk/src/timeline.scss +14 -0
- package/lib/theme-chalk/src/tooltip.scss +141 -0
- package/lib/theme-chalk/src/transfer.scss +227 -0
- package/lib/theme-chalk/src/tree.scss +123 -0
- package/lib/theme-chalk/src/upload.scss +603 -0
- package/lib/time-picker.js +2967 -0
- package/lib/time-select.js +1765 -0
- package/lib/timeline-item.js +371 -0
- package/lib/timeline.js +275 -0
- package/lib/tooltip.js +425 -0
- package/lib/transfer.js +1102 -0
- package/lib/transitions/collapse-transition.js +91 -0
- package/lib/tree.js +2263 -0
- package/lib/treeselect.js +682 -0
- package/lib/umd/locale/af-ZA.js +142 -0
- package/lib/umd/locale/ar.js +141 -0
- package/lib/umd/locale/az.js +141 -0
- package/lib/umd/locale/bg.js +142 -0
- package/lib/umd/locale/bn.js +141 -0
- package/lib/umd/locale/ca.js +141 -0
- package/lib/umd/locale/cs-CZ.js +144 -0
- package/lib/umd/locale/da.js +141 -0
- package/lib/umd/locale/de.js +143 -0
- package/lib/umd/locale/ee.js +142 -0
- package/lib/umd/locale/el.js +142 -0
- package/lib/umd/locale/en.js +142 -0
- package/lib/umd/locale/eo.js +142 -0
- package/lib/umd/locale/es.js +141 -0
- package/lib/umd/locale/eu.js +142 -0
- package/lib/umd/locale/fa.js +142 -0
- package/lib/umd/locale/fi.js +142 -0
- package/lib/umd/locale/fr.js +141 -0
- package/lib/umd/locale/he.js +142 -0
- package/lib/umd/locale/hr.js +142 -0
- package/lib/umd/locale/hu.js +141 -0
- package/lib/umd/locale/hy-AM.js +142 -0
- package/lib/umd/locale/id.js +142 -0
- package/lib/umd/locale/is.js +142 -0
- package/lib/umd/locale/it.js +141 -0
- package/lib/umd/locale/ja.js +142 -0
- package/lib/umd/locale/kg.js +142 -0
- package/lib/umd/locale/km.js +142 -0
- package/lib/umd/locale/ko.js +142 -0
- package/lib/umd/locale/ku.js +142 -0
- package/lib/umd/locale/kz.js +142 -0
- package/lib/umd/locale/lo-LA.js +141 -0
- package/lib/umd/locale/lt.js +142 -0
- package/lib/umd/locale/lv.js +142 -0
- package/lib/umd/locale/mn.js +142 -0
- package/lib/umd/locale/ms.js +141 -0
- package/lib/umd/locale/nb-NO.js +141 -0
- package/lib/umd/locale/nl.js +142 -0
- package/lib/umd/locale/pl.js +142 -0
- package/lib/umd/locale/pt-br.js +142 -0
- package/lib/umd/locale/pt.js +142 -0
- package/lib/umd/locale/ro.js +142 -0
- package/lib/umd/locale/ru-RU.js +142 -0
- package/lib/umd/locale/si.js +142 -0
- package/lib/umd/locale/sk.js +144 -0
- package/lib/umd/locale/sl.js +142 -0
- package/lib/umd/locale/sr-Latn.js +142 -0
- package/lib/umd/locale/sr.js +142 -0
- package/lib/umd/locale/sv-SE.js +142 -0
- package/lib/umd/locale/sw.js +142 -0
- package/lib/umd/locale/ta.js +141 -0
- package/lib/umd/locale/th.js +142 -0
- package/lib/umd/locale/tk.js +142 -0
- package/lib/umd/locale/tr-TR.js +142 -0
- package/lib/umd/locale/ua.js +142 -0
- package/lib/umd/locale/ug-CN.js +142 -0
- package/lib/umd/locale/uz-UZ.js +142 -0
- package/lib/umd/locale/vi.js +142 -0
- package/lib/umd/locale/zh-CN.js +142 -0
- package/lib/umd/locale/zh-TW.js +142 -0
- package/lib/upload.js +1390 -0
- package/lib/utils/after-leave.js +35 -0
- package/lib/utils/aria-dialog.js +104 -0
- package/lib/utils/aria-utils.js +126 -0
- package/lib/utils/clickoutside.js +79 -0
- package/lib/utils/date-util.js +310 -0
- package/lib/utils/date.js +369 -0
- package/lib/utils/dom.js +234 -0
- package/lib/utils/lodash.js +9421 -0
- package/lib/utils/menu/aria-menubar.js +24 -0
- package/lib/utils/menu/aria-menuitem.js +62 -0
- package/lib/utils/menu/aria-submenu.js +69 -0
- package/lib/utils/merge.js +21 -0
- package/lib/utils/popper.js +1261 -0
- package/lib/utils/popup/index.js +233 -0
- package/lib/utils/popup/popup-manager.js +205 -0
- package/lib/utils/resize-event.js +59 -0
- package/lib/utils/scroll-into-view.js +38 -0
- package/lib/utils/scrollbar-width.js +39 -0
- package/lib/utils/shared.js +12 -0
- package/lib/utils/types.js +52 -0
- package/lib/utils/util.js +272 -0
- package/lib/utils/vdom.js +13 -0
- package/lib/utils/vue-popper.js +202 -0
- package/package.json +1 -1
- package/packages/theme-cy/lib/base.css +0 -0
- package/packages/theme-cy/lib/index.css +1 -0
- package/packages/theme-cy/lib/treeselect.css +1 -0
- package/packages/theme-cy/src/treeselect.scss +84 -1
- package/packages/treeselect/src/main.vue +0 -88
- package/src/index.js +1 -1
package/lib/tabs.js
ADDED
|
@@ -0,0 +1,920 @@
|
|
|
1
|
+
module.exports =
|
|
2
|
+
/******/ (function(modules) { // webpackBootstrap
|
|
3
|
+
/******/ // The module cache
|
|
4
|
+
/******/ var installedModules = {};
|
|
5
|
+
/******/
|
|
6
|
+
/******/ // The require function
|
|
7
|
+
/******/ function __webpack_require__(moduleId) {
|
|
8
|
+
/******/
|
|
9
|
+
/******/ // Check if module is in cache
|
|
10
|
+
/******/ if(installedModules[moduleId]) {
|
|
11
|
+
/******/ return installedModules[moduleId].exports;
|
|
12
|
+
/******/ }
|
|
13
|
+
/******/ // Create a new module (and put it into the cache)
|
|
14
|
+
/******/ var module = installedModules[moduleId] = {
|
|
15
|
+
/******/ i: moduleId,
|
|
16
|
+
/******/ l: false,
|
|
17
|
+
/******/ exports: {}
|
|
18
|
+
/******/ };
|
|
19
|
+
/******/
|
|
20
|
+
/******/ // Execute the module function
|
|
21
|
+
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
|
22
|
+
/******/
|
|
23
|
+
/******/ // Flag the module as loaded
|
|
24
|
+
/******/ module.l = true;
|
|
25
|
+
/******/
|
|
26
|
+
/******/ // Return the exports of the module
|
|
27
|
+
/******/ return module.exports;
|
|
28
|
+
/******/ }
|
|
29
|
+
/******/
|
|
30
|
+
/******/
|
|
31
|
+
/******/ // expose the modules object (__webpack_modules__)
|
|
32
|
+
/******/ __webpack_require__.m = modules;
|
|
33
|
+
/******/
|
|
34
|
+
/******/ // expose the module cache
|
|
35
|
+
/******/ __webpack_require__.c = installedModules;
|
|
36
|
+
/******/
|
|
37
|
+
/******/ // define getter function for harmony exports
|
|
38
|
+
/******/ __webpack_require__.d = function(exports, name, getter) {
|
|
39
|
+
/******/ if(!__webpack_require__.o(exports, name)) {
|
|
40
|
+
/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
|
|
41
|
+
/******/ }
|
|
42
|
+
/******/ };
|
|
43
|
+
/******/
|
|
44
|
+
/******/ // define __esModule on exports
|
|
45
|
+
/******/ __webpack_require__.r = function(exports) {
|
|
46
|
+
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
|
|
47
|
+
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
48
|
+
/******/ }
|
|
49
|
+
/******/ Object.defineProperty(exports, '__esModule', { value: true });
|
|
50
|
+
/******/ };
|
|
51
|
+
/******/
|
|
52
|
+
/******/ // create a fake namespace object
|
|
53
|
+
/******/ // mode & 1: value is a module id, require it
|
|
54
|
+
/******/ // mode & 2: merge all properties of value into the ns
|
|
55
|
+
/******/ // mode & 4: return value when already ns object
|
|
56
|
+
/******/ // mode & 8|1: behave like require
|
|
57
|
+
/******/ __webpack_require__.t = function(value, mode) {
|
|
58
|
+
/******/ if(mode & 1) value = __webpack_require__(value);
|
|
59
|
+
/******/ if(mode & 8) return value;
|
|
60
|
+
/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
|
|
61
|
+
/******/ var ns = Object.create(null);
|
|
62
|
+
/******/ __webpack_require__.r(ns);
|
|
63
|
+
/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
|
|
64
|
+
/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
|
|
65
|
+
/******/ return ns;
|
|
66
|
+
/******/ };
|
|
67
|
+
/******/
|
|
68
|
+
/******/ // getDefaultExport function for compatibility with non-harmony modules
|
|
69
|
+
/******/ __webpack_require__.n = function(module) {
|
|
70
|
+
/******/ var getter = module && module.__esModule ?
|
|
71
|
+
/******/ function getDefault() { return module['default']; } :
|
|
72
|
+
/******/ function getModuleExports() { return module; };
|
|
73
|
+
/******/ __webpack_require__.d(getter, 'a', getter);
|
|
74
|
+
/******/ return getter;
|
|
75
|
+
/******/ };
|
|
76
|
+
/******/
|
|
77
|
+
/******/ // Object.prototype.hasOwnProperty.call
|
|
78
|
+
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
|
|
79
|
+
/******/
|
|
80
|
+
/******/ // __webpack_public_path__
|
|
81
|
+
/******/ __webpack_require__.p = "/dist/";
|
|
82
|
+
/******/
|
|
83
|
+
/******/
|
|
84
|
+
/******/ // Load entry module and return exports
|
|
85
|
+
/******/ return __webpack_require__(__webpack_require__.s = 63);
|
|
86
|
+
/******/ })
|
|
87
|
+
/************************************************************************/
|
|
88
|
+
/******/ ({
|
|
89
|
+
|
|
90
|
+
/***/ 0:
|
|
91
|
+
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
92
|
+
|
|
93
|
+
"use strict";
|
|
94
|
+
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
|
|
95
|
+
/* globals __VUE_SSR_CONTEXT__ */
|
|
96
|
+
|
|
97
|
+
// IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
|
|
98
|
+
// This module is a runtime utility for cleaner component module output and will
|
|
99
|
+
// be included in the final webpack user bundle.
|
|
100
|
+
|
|
101
|
+
function normalizeComponent(
|
|
102
|
+
scriptExports,
|
|
103
|
+
render,
|
|
104
|
+
staticRenderFns,
|
|
105
|
+
functionalTemplate,
|
|
106
|
+
injectStyles,
|
|
107
|
+
scopeId,
|
|
108
|
+
moduleIdentifier /* server only */,
|
|
109
|
+
shadowMode /* vue-cli only */
|
|
110
|
+
) {
|
|
111
|
+
// Vue.extend constructor export interop
|
|
112
|
+
var options =
|
|
113
|
+
typeof scriptExports === 'function' ? scriptExports.options : scriptExports
|
|
114
|
+
|
|
115
|
+
// render functions
|
|
116
|
+
if (render) {
|
|
117
|
+
options.render = render
|
|
118
|
+
options.staticRenderFns = staticRenderFns
|
|
119
|
+
options._compiled = true
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
// functional template
|
|
123
|
+
if (functionalTemplate) {
|
|
124
|
+
options.functional = true
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
// scopedId
|
|
128
|
+
if (scopeId) {
|
|
129
|
+
options._scopeId = 'data-v-' + scopeId
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
var hook
|
|
133
|
+
if (moduleIdentifier) {
|
|
134
|
+
// server build
|
|
135
|
+
hook = function (context) {
|
|
136
|
+
// 2.3 injection
|
|
137
|
+
context =
|
|
138
|
+
context || // cached call
|
|
139
|
+
(this.$vnode && this.$vnode.ssrContext) || // stateful
|
|
140
|
+
(this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
|
|
141
|
+
// 2.2 with runInNewContext: true
|
|
142
|
+
if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
|
|
143
|
+
context = __VUE_SSR_CONTEXT__
|
|
144
|
+
}
|
|
145
|
+
// inject component styles
|
|
146
|
+
if (injectStyles) {
|
|
147
|
+
injectStyles.call(this, context)
|
|
148
|
+
}
|
|
149
|
+
// register component module identifier for async chunk inferrence
|
|
150
|
+
if (context && context._registeredComponents) {
|
|
151
|
+
context._registeredComponents.add(moduleIdentifier)
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
// used by ssr in case component is cached and beforeCreate
|
|
155
|
+
// never gets called
|
|
156
|
+
options._ssrRegister = hook
|
|
157
|
+
} else if (injectStyles) {
|
|
158
|
+
hook = shadowMode
|
|
159
|
+
? function () {
|
|
160
|
+
injectStyles.call(
|
|
161
|
+
this,
|
|
162
|
+
(options.functional ? this.parent : this).$root.$options.shadowRoot
|
|
163
|
+
)
|
|
164
|
+
}
|
|
165
|
+
: injectStyles
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
if (hook) {
|
|
169
|
+
if (options.functional) {
|
|
170
|
+
// for template-only hot-reload because in that case the render fn doesn't
|
|
171
|
+
// go through the normalizer
|
|
172
|
+
options._injectStyles = hook
|
|
173
|
+
// register for functional component in vue file
|
|
174
|
+
var originalRender = options.render
|
|
175
|
+
options.render = function renderWithStyleInjection(h, context) {
|
|
176
|
+
hook.call(context)
|
|
177
|
+
return originalRender(h, context)
|
|
178
|
+
}
|
|
179
|
+
} else {
|
|
180
|
+
// inject component registration as beforeCreate hook
|
|
181
|
+
var existing = options.beforeCreate
|
|
182
|
+
options.beforeCreate = existing ? [].concat(existing, hook) : [hook]
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
return {
|
|
187
|
+
exports: scriptExports,
|
|
188
|
+
options: options
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
|
|
193
|
+
/***/ }),
|
|
194
|
+
|
|
195
|
+
/***/ 17:
|
|
196
|
+
/***/ (function(module, exports) {
|
|
197
|
+
|
|
198
|
+
module.exports = require("element-ui/lib/utils/resize-event");
|
|
199
|
+
|
|
200
|
+
/***/ }),
|
|
201
|
+
|
|
202
|
+
/***/ 3:
|
|
203
|
+
/***/ (function(module, exports) {
|
|
204
|
+
|
|
205
|
+
module.exports = require("element-ui/lib/utils/util");
|
|
206
|
+
|
|
207
|
+
/***/ }),
|
|
208
|
+
|
|
209
|
+
/***/ 63:
|
|
210
|
+
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
211
|
+
|
|
212
|
+
"use strict";
|
|
213
|
+
// ESM COMPAT FLAG
|
|
214
|
+
__webpack_require__.r(__webpack_exports__);
|
|
215
|
+
|
|
216
|
+
// CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/tabs/src/tab-bar.vue?vue&type=template&id=5d75b80d
|
|
217
|
+
var render = function () {
|
|
218
|
+
var _vm = this
|
|
219
|
+
var _h = _vm.$createElement
|
|
220
|
+
var _c = _vm._self._c || _h
|
|
221
|
+
return _c("div", {
|
|
222
|
+
staticClass: "el-tabs__active-bar",
|
|
223
|
+
class: "is-" + _vm.rootTabs.tabPosition,
|
|
224
|
+
style: _vm.barStyle,
|
|
225
|
+
})
|
|
226
|
+
}
|
|
227
|
+
var staticRenderFns = []
|
|
228
|
+
render._withStripped = true
|
|
229
|
+
|
|
230
|
+
|
|
231
|
+
// CONCATENATED MODULE: ./packages/tabs/src/tab-bar.vue?vue&type=template&id=5d75b80d
|
|
232
|
+
|
|
233
|
+
// EXTERNAL MODULE: external "element-ui/lib/utils/util"
|
|
234
|
+
var util_ = __webpack_require__(3);
|
|
235
|
+
|
|
236
|
+
// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tabs/src/tab-bar.vue?vue&type=script&lang=js
|
|
237
|
+
//
|
|
238
|
+
//
|
|
239
|
+
//
|
|
240
|
+
|
|
241
|
+
|
|
242
|
+
/* harmony default export */ var tab_barvue_type_script_lang_js = ({
|
|
243
|
+
name: 'TabBar',
|
|
244
|
+
|
|
245
|
+
props: {
|
|
246
|
+
tabs: Array
|
|
247
|
+
},
|
|
248
|
+
|
|
249
|
+
inject: ['rootTabs'],
|
|
250
|
+
|
|
251
|
+
computed: {
|
|
252
|
+
barStyle: {
|
|
253
|
+
get: function get() {
|
|
254
|
+
var _this = this;
|
|
255
|
+
|
|
256
|
+
var style = {};
|
|
257
|
+
var offset = 0;
|
|
258
|
+
var tabSize = 0;
|
|
259
|
+
var sizeName = ['top', 'bottom'].indexOf(this.rootTabs.tabPosition) !== -1 ? 'width' : 'height';
|
|
260
|
+
var sizeDir = sizeName === 'width' ? 'x' : 'y';
|
|
261
|
+
var firstUpperCase = function firstUpperCase(str) {
|
|
262
|
+
return str.toLowerCase().replace(/( |^)[a-z]/g, function (L) {
|
|
263
|
+
return L.toUpperCase();
|
|
264
|
+
});
|
|
265
|
+
};
|
|
266
|
+
this.tabs.every(function (tab, index) {
|
|
267
|
+
var $el = Object(util_["arrayFind"])(_this.$parent.$refs.tabs || [], function (t) {
|
|
268
|
+
return t.id.replace('tab-', '') === tab.paneName;
|
|
269
|
+
});
|
|
270
|
+
if (!$el) {
|
|
271
|
+
return false;
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
if (!tab.active) {
|
|
275
|
+
offset += $el['client' + firstUpperCase(sizeName)];
|
|
276
|
+
return true;
|
|
277
|
+
} else {
|
|
278
|
+
tabSize = $el['client' + firstUpperCase(sizeName)];
|
|
279
|
+
var tabStyles = window.getComputedStyle($el);
|
|
280
|
+
if (sizeName === 'width' && _this.tabs.length > 1) {
|
|
281
|
+
tabSize -= parseFloat(tabStyles.paddingLeft) + parseFloat(tabStyles.paddingRight);
|
|
282
|
+
}
|
|
283
|
+
if (sizeName === 'width') {
|
|
284
|
+
offset += parseFloat(tabStyles.paddingLeft);
|
|
285
|
+
}
|
|
286
|
+
return false;
|
|
287
|
+
}
|
|
288
|
+
});
|
|
289
|
+
|
|
290
|
+
var transform = 'translate' + firstUpperCase(sizeDir) + '(' + offset + 'px)';
|
|
291
|
+
style[sizeName] = tabSize + 'px';
|
|
292
|
+
style.transform = transform;
|
|
293
|
+
style.msTransform = transform;
|
|
294
|
+
style.webkitTransform = transform;
|
|
295
|
+
|
|
296
|
+
return style;
|
|
297
|
+
}
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
});
|
|
301
|
+
// CONCATENATED MODULE: ./packages/tabs/src/tab-bar.vue?vue&type=script&lang=js
|
|
302
|
+
/* harmony default export */ var src_tab_barvue_type_script_lang_js = (tab_barvue_type_script_lang_js);
|
|
303
|
+
// EXTERNAL MODULE: ./node_modules/vue-loader/lib/runtime/componentNormalizer.js
|
|
304
|
+
var componentNormalizer = __webpack_require__(0);
|
|
305
|
+
|
|
306
|
+
// CONCATENATED MODULE: ./packages/tabs/src/tab-bar.vue
|
|
307
|
+
|
|
308
|
+
|
|
309
|
+
|
|
310
|
+
|
|
311
|
+
|
|
312
|
+
/* normalize component */
|
|
313
|
+
|
|
314
|
+
var component = Object(componentNormalizer["a" /* default */])(
|
|
315
|
+
src_tab_barvue_type_script_lang_js,
|
|
316
|
+
render,
|
|
317
|
+
staticRenderFns,
|
|
318
|
+
false,
|
|
319
|
+
null,
|
|
320
|
+
null,
|
|
321
|
+
null
|
|
322
|
+
|
|
323
|
+
)
|
|
324
|
+
|
|
325
|
+
/* harmony default export */ var tab_bar = (component.exports);
|
|
326
|
+
// EXTERNAL MODULE: external "element-ui/lib/utils/resize-event"
|
|
327
|
+
var resize_event_ = __webpack_require__(17);
|
|
328
|
+
|
|
329
|
+
// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tabs/src/tab-nav.vue?vue&type=script&lang=js
|
|
330
|
+
|
|
331
|
+
|
|
332
|
+
|
|
333
|
+
|
|
334
|
+
function noop() {}
|
|
335
|
+
var tab_navvue_type_script_lang_js_firstUpperCase = function firstUpperCase(str) {
|
|
336
|
+
return str.toLowerCase().replace(/( |^)[a-z]/g, function (L) {
|
|
337
|
+
return L.toUpperCase();
|
|
338
|
+
});
|
|
339
|
+
};
|
|
340
|
+
|
|
341
|
+
/* harmony default export */ var tab_navvue_type_script_lang_js = ({
|
|
342
|
+
name: 'TabNav',
|
|
343
|
+
|
|
344
|
+
components: {
|
|
345
|
+
TabBar: tab_bar
|
|
346
|
+
},
|
|
347
|
+
|
|
348
|
+
inject: ['rootTabs'],
|
|
349
|
+
|
|
350
|
+
props: {
|
|
351
|
+
panes: Array,
|
|
352
|
+
currentName: String,
|
|
353
|
+
editable: Boolean,
|
|
354
|
+
onTabClick: {
|
|
355
|
+
type: Function,
|
|
356
|
+
default: noop
|
|
357
|
+
},
|
|
358
|
+
onTabRemove: {
|
|
359
|
+
type: Function,
|
|
360
|
+
default: noop
|
|
361
|
+
},
|
|
362
|
+
type: String,
|
|
363
|
+
stretch: Boolean
|
|
364
|
+
},
|
|
365
|
+
|
|
366
|
+
data: function data() {
|
|
367
|
+
return {
|
|
368
|
+
scrollable: false,
|
|
369
|
+
navOffset: 0,
|
|
370
|
+
isFocus: false,
|
|
371
|
+
focusable: true
|
|
372
|
+
};
|
|
373
|
+
},
|
|
374
|
+
|
|
375
|
+
|
|
376
|
+
computed: {
|
|
377
|
+
navStyle: function navStyle() {
|
|
378
|
+
var dir = ['top', 'bottom'].indexOf(this.rootTabs.tabPosition) !== -1 ? 'X' : 'Y';
|
|
379
|
+
return {
|
|
380
|
+
transform: 'translate' + dir + '(-' + this.navOffset + 'px)'
|
|
381
|
+
};
|
|
382
|
+
},
|
|
383
|
+
sizeName: function sizeName() {
|
|
384
|
+
return ['top', 'bottom'].indexOf(this.rootTabs.tabPosition) !== -1 ? 'width' : 'height';
|
|
385
|
+
}
|
|
386
|
+
},
|
|
387
|
+
|
|
388
|
+
methods: {
|
|
389
|
+
scrollPrev: function scrollPrev() {
|
|
390
|
+
var containerSize = this.$refs.navScroll['offset' + tab_navvue_type_script_lang_js_firstUpperCase(this.sizeName)];
|
|
391
|
+
var currentOffset = this.navOffset;
|
|
392
|
+
|
|
393
|
+
if (!currentOffset) return;
|
|
394
|
+
|
|
395
|
+
var newOffset = currentOffset > containerSize ? currentOffset - containerSize : 0;
|
|
396
|
+
|
|
397
|
+
this.navOffset = newOffset;
|
|
398
|
+
},
|
|
399
|
+
scrollNext: function scrollNext() {
|
|
400
|
+
var navSize = this.$refs.nav['offset' + tab_navvue_type_script_lang_js_firstUpperCase(this.sizeName)];
|
|
401
|
+
var containerSize = this.$refs.navScroll['offset' + tab_navvue_type_script_lang_js_firstUpperCase(this.sizeName)];
|
|
402
|
+
var currentOffset = this.navOffset;
|
|
403
|
+
|
|
404
|
+
if (navSize - currentOffset <= containerSize) return;
|
|
405
|
+
|
|
406
|
+
var newOffset = navSize - currentOffset > containerSize * 2 ? currentOffset + containerSize : navSize - containerSize;
|
|
407
|
+
|
|
408
|
+
this.navOffset = newOffset;
|
|
409
|
+
},
|
|
410
|
+
scrollToActiveTab: function scrollToActiveTab() {
|
|
411
|
+
if (!this.scrollable) return;
|
|
412
|
+
var nav = this.$refs.nav;
|
|
413
|
+
var activeTab = this.$el.querySelector('.is-active');
|
|
414
|
+
if (!activeTab) return;
|
|
415
|
+
var navScroll = this.$refs.navScroll;
|
|
416
|
+
var isHorizontal = ['top', 'bottom'].indexOf(this.rootTabs.tabPosition) !== -1;
|
|
417
|
+
var activeTabBounding = activeTab.getBoundingClientRect();
|
|
418
|
+
var navScrollBounding = navScroll.getBoundingClientRect();
|
|
419
|
+
var maxOffset = isHorizontal ? nav.offsetWidth - navScrollBounding.width : nav.offsetHeight - navScrollBounding.height;
|
|
420
|
+
var currentOffset = this.navOffset;
|
|
421
|
+
var newOffset = currentOffset;
|
|
422
|
+
|
|
423
|
+
if (isHorizontal) {
|
|
424
|
+
if (activeTabBounding.left < navScrollBounding.left) {
|
|
425
|
+
newOffset = currentOffset - (navScrollBounding.left - activeTabBounding.left);
|
|
426
|
+
}
|
|
427
|
+
if (activeTabBounding.right > navScrollBounding.right) {
|
|
428
|
+
newOffset = currentOffset + activeTabBounding.right - navScrollBounding.right;
|
|
429
|
+
}
|
|
430
|
+
} else {
|
|
431
|
+
if (activeTabBounding.top < navScrollBounding.top) {
|
|
432
|
+
newOffset = currentOffset - (navScrollBounding.top - activeTabBounding.top);
|
|
433
|
+
}
|
|
434
|
+
if (activeTabBounding.bottom > navScrollBounding.bottom) {
|
|
435
|
+
newOffset = currentOffset + (activeTabBounding.bottom - navScrollBounding.bottom);
|
|
436
|
+
}
|
|
437
|
+
}
|
|
438
|
+
newOffset = Math.max(newOffset, 0);
|
|
439
|
+
this.navOffset = Math.min(newOffset, maxOffset);
|
|
440
|
+
},
|
|
441
|
+
update: function update() {
|
|
442
|
+
if (!this.$refs.nav) return;
|
|
443
|
+
var sizeName = this.sizeName;
|
|
444
|
+
var navSize = this.$refs.nav['offset' + tab_navvue_type_script_lang_js_firstUpperCase(sizeName)];
|
|
445
|
+
var containerSize = this.$refs.navScroll['offset' + tab_navvue_type_script_lang_js_firstUpperCase(sizeName)];
|
|
446
|
+
var currentOffset = this.navOffset;
|
|
447
|
+
|
|
448
|
+
if (containerSize < navSize) {
|
|
449
|
+
var _currentOffset = this.navOffset;
|
|
450
|
+
this.scrollable = this.scrollable || {};
|
|
451
|
+
this.scrollable.prev = _currentOffset;
|
|
452
|
+
this.scrollable.next = _currentOffset + containerSize < navSize;
|
|
453
|
+
if (navSize - _currentOffset < containerSize) {
|
|
454
|
+
this.navOffset = navSize - containerSize;
|
|
455
|
+
}
|
|
456
|
+
} else {
|
|
457
|
+
this.scrollable = false;
|
|
458
|
+
if (currentOffset > 0) {
|
|
459
|
+
this.navOffset = 0;
|
|
460
|
+
}
|
|
461
|
+
}
|
|
462
|
+
},
|
|
463
|
+
changeTab: function changeTab(e) {
|
|
464
|
+
var keyCode = e.keyCode;
|
|
465
|
+
var nextIndex = void 0;
|
|
466
|
+
var currentIndex = void 0,
|
|
467
|
+
tabList = void 0;
|
|
468
|
+
if ([37, 38, 39, 40].indexOf(keyCode) !== -1) {
|
|
469
|
+
// 左右上下键更换tab
|
|
470
|
+
tabList = e.currentTarget.querySelectorAll('[role=tab]');
|
|
471
|
+
currentIndex = Array.prototype.indexOf.call(tabList, e.target);
|
|
472
|
+
} else {
|
|
473
|
+
return;
|
|
474
|
+
}
|
|
475
|
+
if (keyCode === 37 || keyCode === 38) {
|
|
476
|
+
// left
|
|
477
|
+
if (currentIndex === 0) {
|
|
478
|
+
// first
|
|
479
|
+
nextIndex = tabList.length - 1;
|
|
480
|
+
} else {
|
|
481
|
+
nextIndex = currentIndex - 1;
|
|
482
|
+
}
|
|
483
|
+
} else {
|
|
484
|
+
// right
|
|
485
|
+
if (currentIndex < tabList.length - 1) {
|
|
486
|
+
// not last
|
|
487
|
+
nextIndex = currentIndex + 1;
|
|
488
|
+
} else {
|
|
489
|
+
nextIndex = 0;
|
|
490
|
+
}
|
|
491
|
+
}
|
|
492
|
+
tabList[nextIndex].focus(); // 改变焦点元素
|
|
493
|
+
tabList[nextIndex].click(); // 选中下一个tab
|
|
494
|
+
this.setFocus();
|
|
495
|
+
},
|
|
496
|
+
setFocus: function setFocus() {
|
|
497
|
+
if (this.focusable) {
|
|
498
|
+
this.isFocus = true;
|
|
499
|
+
}
|
|
500
|
+
},
|
|
501
|
+
removeFocus: function removeFocus() {
|
|
502
|
+
this.isFocus = false;
|
|
503
|
+
},
|
|
504
|
+
visibilityChangeHandler: function visibilityChangeHandler() {
|
|
505
|
+
var _this = this;
|
|
506
|
+
|
|
507
|
+
var visibility = document.visibilityState;
|
|
508
|
+
if (visibility === 'hidden') {
|
|
509
|
+
this.focusable = false;
|
|
510
|
+
} else if (visibility === 'visible') {
|
|
511
|
+
setTimeout(function () {
|
|
512
|
+
_this.focusable = true;
|
|
513
|
+
}, 50);
|
|
514
|
+
}
|
|
515
|
+
},
|
|
516
|
+
windowBlurHandler: function windowBlurHandler() {
|
|
517
|
+
this.focusable = false;
|
|
518
|
+
},
|
|
519
|
+
windowFocusHandler: function windowFocusHandler() {
|
|
520
|
+
var _this2 = this;
|
|
521
|
+
|
|
522
|
+
setTimeout(function () {
|
|
523
|
+
_this2.focusable = true;
|
|
524
|
+
}, 50);
|
|
525
|
+
}
|
|
526
|
+
},
|
|
527
|
+
|
|
528
|
+
updated: function updated() {
|
|
529
|
+
this.update();
|
|
530
|
+
},
|
|
531
|
+
render: function render(h) {
|
|
532
|
+
var _this3 = this;
|
|
533
|
+
|
|
534
|
+
var type = this.type,
|
|
535
|
+
panes = this.panes,
|
|
536
|
+
editable = this.editable,
|
|
537
|
+
stretch = this.stretch,
|
|
538
|
+
onTabClick = this.onTabClick,
|
|
539
|
+
onTabRemove = this.onTabRemove,
|
|
540
|
+
navStyle = this.navStyle,
|
|
541
|
+
scrollable = this.scrollable,
|
|
542
|
+
scrollNext = this.scrollNext,
|
|
543
|
+
scrollPrev = this.scrollPrev,
|
|
544
|
+
changeTab = this.changeTab,
|
|
545
|
+
setFocus = this.setFocus,
|
|
546
|
+
removeFocus = this.removeFocus;
|
|
547
|
+
|
|
548
|
+
var scrollBtn = scrollable ? [h(
|
|
549
|
+
'span',
|
|
550
|
+
{ 'class': ['el-tabs__nav-prev', scrollable.prev ? '' : 'is-disabled'], on: {
|
|
551
|
+
'click': scrollPrev
|
|
552
|
+
}
|
|
553
|
+
},
|
|
554
|
+
[h('i', { 'class': 'el-icon-arrow-left' })]
|
|
555
|
+
), h(
|
|
556
|
+
'span',
|
|
557
|
+
{ 'class': ['el-tabs__nav-next', scrollable.next ? '' : 'is-disabled'], on: {
|
|
558
|
+
'click': scrollNext
|
|
559
|
+
}
|
|
560
|
+
},
|
|
561
|
+
[h('i', { 'class': 'el-icon-arrow-right' })]
|
|
562
|
+
)] : null;
|
|
563
|
+
|
|
564
|
+
var tabs = this._l(panes, function (pane, index) {
|
|
565
|
+
var _ref;
|
|
566
|
+
|
|
567
|
+
var tabName = pane.name || pane.index || index;
|
|
568
|
+
var closable = pane.isClosable || editable;
|
|
569
|
+
|
|
570
|
+
pane.index = '' + index;
|
|
571
|
+
|
|
572
|
+
var btnClose = closable ? h('span', { 'class': 'el-icon-close', on: {
|
|
573
|
+
'click': function click(ev) {
|
|
574
|
+
onTabRemove(pane, ev);
|
|
575
|
+
}
|
|
576
|
+
}
|
|
577
|
+
}) : null;
|
|
578
|
+
|
|
579
|
+
var tabLabelContent = pane.$slots.label || pane.label;
|
|
580
|
+
var tabindex = pane.active ? 0 : -1;
|
|
581
|
+
return h(
|
|
582
|
+
'div',
|
|
583
|
+
{
|
|
584
|
+
'class': (_ref = {
|
|
585
|
+
'el-tabs__item': true
|
|
586
|
+
}, _ref['is-' + _this3.rootTabs.tabPosition] = true, _ref['is-active'] = pane.active, _ref['is-disabled'] = pane.disabled, _ref['is-closable'] = closable, _ref['is-focus'] = _this3.isFocus, _ref),
|
|
587
|
+
attrs: { id: 'tab-' + tabName,
|
|
588
|
+
|
|
589
|
+
'aria-controls': 'pane-' + tabName,
|
|
590
|
+
role: 'tab',
|
|
591
|
+
'aria-selected': pane.active,
|
|
592
|
+
|
|
593
|
+
tabindex: tabindex
|
|
594
|
+
},
|
|
595
|
+
key: 'tab-' + tabName, ref: 'tabs', refInFor: true,
|
|
596
|
+
on: {
|
|
597
|
+
'focus': function focus() {
|
|
598
|
+
setFocus();
|
|
599
|
+
},
|
|
600
|
+
'blur': function blur() {
|
|
601
|
+
removeFocus();
|
|
602
|
+
},
|
|
603
|
+
'click': function click(ev) {
|
|
604
|
+
removeFocus();onTabClick(pane, tabName, ev);
|
|
605
|
+
},
|
|
606
|
+
'keydown': function keydown(ev) {
|
|
607
|
+
if (closable && (ev.keyCode === 46 || ev.keyCode === 8)) {
|
|
608
|
+
onTabRemove(pane, ev);
|
|
609
|
+
}
|
|
610
|
+
}
|
|
611
|
+
}
|
|
612
|
+
},
|
|
613
|
+
[tabLabelContent, btnClose]
|
|
614
|
+
);
|
|
615
|
+
});
|
|
616
|
+
return h(
|
|
617
|
+
'div',
|
|
618
|
+
{ 'class': ['el-tabs__nav-wrap', scrollable ? 'is-scrollable' : '', 'is-' + this.rootTabs.tabPosition] },
|
|
619
|
+
[scrollBtn, h(
|
|
620
|
+
'div',
|
|
621
|
+
{ 'class': ['el-tabs__nav-scroll'], ref: 'navScroll' },
|
|
622
|
+
[h(
|
|
623
|
+
'div',
|
|
624
|
+
{
|
|
625
|
+
'class': ['el-tabs__nav', 'is-' + this.rootTabs.tabPosition, stretch && ['top', 'bottom'].indexOf(this.rootTabs.tabPosition) !== -1 ? 'is-stretch' : ''],
|
|
626
|
+
ref: 'nav',
|
|
627
|
+
style: navStyle,
|
|
628
|
+
attrs: { role: 'tablist'
|
|
629
|
+
},
|
|
630
|
+
on: {
|
|
631
|
+
'keydown': changeTab
|
|
632
|
+
}
|
|
633
|
+
},
|
|
634
|
+
[!type ? h('tab-bar', {
|
|
635
|
+
attrs: { tabs: panes }
|
|
636
|
+
}) : null, tabs]
|
|
637
|
+
)]
|
|
638
|
+
)]
|
|
639
|
+
);
|
|
640
|
+
},
|
|
641
|
+
mounted: function mounted() {
|
|
642
|
+
var _this4 = this;
|
|
643
|
+
|
|
644
|
+
Object(resize_event_["addResizeListener"])(this.$el, this.update);
|
|
645
|
+
document.addEventListener('visibilitychange', this.visibilityChangeHandler);
|
|
646
|
+
window.addEventListener('blur', this.windowBlurHandler);
|
|
647
|
+
window.addEventListener('focus', this.windowFocusHandler);
|
|
648
|
+
setTimeout(function () {
|
|
649
|
+
_this4.scrollToActiveTab();
|
|
650
|
+
}, 0);
|
|
651
|
+
},
|
|
652
|
+
beforeDestroy: function beforeDestroy() {
|
|
653
|
+
if (this.$el && this.update) Object(resize_event_["removeResizeListener"])(this.$el, this.update);
|
|
654
|
+
document.removeEventListener('visibilitychange', this.visibilityChangeHandler);
|
|
655
|
+
window.removeEventListener('blur', this.windowBlurHandler);
|
|
656
|
+
window.removeEventListener('focus', this.windowFocusHandler);
|
|
657
|
+
}
|
|
658
|
+
});
|
|
659
|
+
// CONCATENATED MODULE: ./packages/tabs/src/tab-nav.vue?vue&type=script&lang=js
|
|
660
|
+
/* harmony default export */ var src_tab_navvue_type_script_lang_js = (tab_navvue_type_script_lang_js);
|
|
661
|
+
// CONCATENATED MODULE: ./packages/tabs/src/tab-nav.vue
|
|
662
|
+
var tab_nav_render, tab_nav_staticRenderFns
|
|
663
|
+
|
|
664
|
+
|
|
665
|
+
|
|
666
|
+
|
|
667
|
+
/* normalize component */
|
|
668
|
+
|
|
669
|
+
var tab_nav_component = Object(componentNormalizer["a" /* default */])(
|
|
670
|
+
src_tab_navvue_type_script_lang_js,
|
|
671
|
+
tab_nav_render,
|
|
672
|
+
tab_nav_staticRenderFns,
|
|
673
|
+
false,
|
|
674
|
+
null,
|
|
675
|
+
null,
|
|
676
|
+
null
|
|
677
|
+
|
|
678
|
+
)
|
|
679
|
+
|
|
680
|
+
/* harmony default export */ var tab_nav = (tab_nav_component.exports);
|
|
681
|
+
// CONCATENATED MODULE: ./node_modules/babel-loader/lib!./node_modules/vue-loader/lib??vue-loader-options!./packages/tabs/src/tabs.vue?vue&type=script&lang=js
|
|
682
|
+
|
|
683
|
+
|
|
684
|
+
|
|
685
|
+
/* harmony default export */ var tabsvue_type_script_lang_js = ({
|
|
686
|
+
name: 'ElTabs',
|
|
687
|
+
|
|
688
|
+
components: {
|
|
689
|
+
TabNav: tab_nav
|
|
690
|
+
},
|
|
691
|
+
|
|
692
|
+
props: {
|
|
693
|
+
type: String,
|
|
694
|
+
activeName: String,
|
|
695
|
+
closable: Boolean,
|
|
696
|
+
addable: Boolean,
|
|
697
|
+
value: {},
|
|
698
|
+
editable: Boolean,
|
|
699
|
+
tabPosition: {
|
|
700
|
+
type: String,
|
|
701
|
+
default: 'top'
|
|
702
|
+
},
|
|
703
|
+
beforeLeave: Function,
|
|
704
|
+
stretch: Boolean
|
|
705
|
+
},
|
|
706
|
+
|
|
707
|
+
provide: function provide() {
|
|
708
|
+
return {
|
|
709
|
+
rootTabs: this
|
|
710
|
+
};
|
|
711
|
+
},
|
|
712
|
+
data: function data() {
|
|
713
|
+
return {
|
|
714
|
+
currentName: this.value || this.activeName,
|
|
715
|
+
panes: []
|
|
716
|
+
};
|
|
717
|
+
},
|
|
718
|
+
|
|
719
|
+
|
|
720
|
+
watch: {
|
|
721
|
+
activeName: function activeName(value) {
|
|
722
|
+
this.setCurrentName(value);
|
|
723
|
+
},
|
|
724
|
+
value: function value(_value) {
|
|
725
|
+
this.setCurrentName(_value);
|
|
726
|
+
},
|
|
727
|
+
currentName: function currentName(value) {
|
|
728
|
+
var _this = this;
|
|
729
|
+
|
|
730
|
+
if (this.$refs.nav) {
|
|
731
|
+
this.$nextTick(function () {
|
|
732
|
+
_this.$refs.nav.$nextTick(function (_) {
|
|
733
|
+
_this.$refs.nav.scrollToActiveTab();
|
|
734
|
+
});
|
|
735
|
+
});
|
|
736
|
+
}
|
|
737
|
+
}
|
|
738
|
+
},
|
|
739
|
+
|
|
740
|
+
methods: {
|
|
741
|
+
calcPaneInstances: function calcPaneInstances() {
|
|
742
|
+
var _this2 = this;
|
|
743
|
+
|
|
744
|
+
var isForceUpdate = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
|
|
745
|
+
|
|
746
|
+
if (this.$slots.default) {
|
|
747
|
+
var paneSlots = this.$slots.default.filter(function (vnode) {
|
|
748
|
+
return vnode.tag && vnode.componentOptions && vnode.componentOptions.Ctor.options.name === 'ElTabPane';
|
|
749
|
+
});
|
|
750
|
+
// update indeed
|
|
751
|
+
var panes = paneSlots.map(function (_ref) {
|
|
752
|
+
var componentInstance = _ref.componentInstance;
|
|
753
|
+
return componentInstance;
|
|
754
|
+
});
|
|
755
|
+
var panesChanged = !(panes.length === this.panes.length && panes.every(function (pane, index) {
|
|
756
|
+
return pane === _this2.panes[index];
|
|
757
|
+
}));
|
|
758
|
+
if (isForceUpdate || panesChanged) {
|
|
759
|
+
this.panes = panes;
|
|
760
|
+
}
|
|
761
|
+
} else if (this.panes.length !== 0) {
|
|
762
|
+
this.panes = [];
|
|
763
|
+
}
|
|
764
|
+
},
|
|
765
|
+
handleTabClick: function handleTabClick(tab, tabName, event) {
|
|
766
|
+
if (tab.disabled) return;
|
|
767
|
+
this.setCurrentName(tabName);
|
|
768
|
+
this.$emit('tab-click', tab, event);
|
|
769
|
+
},
|
|
770
|
+
handleTabRemove: function handleTabRemove(pane, ev) {
|
|
771
|
+
if (pane.disabled) return;
|
|
772
|
+
ev.stopPropagation();
|
|
773
|
+
this.$emit('edit', pane.name, 'remove');
|
|
774
|
+
this.$emit('tab-remove', pane.name);
|
|
775
|
+
},
|
|
776
|
+
handleTabAdd: function handleTabAdd() {
|
|
777
|
+
this.$emit('edit', null, 'add');
|
|
778
|
+
this.$emit('tab-add');
|
|
779
|
+
},
|
|
780
|
+
setCurrentName: function setCurrentName(value) {
|
|
781
|
+
var _this3 = this;
|
|
782
|
+
|
|
783
|
+
var changeCurrentName = function changeCurrentName() {
|
|
784
|
+
_this3.currentName = value;
|
|
785
|
+
_this3.$emit('input', value);
|
|
786
|
+
};
|
|
787
|
+
if (this.currentName !== value && this.beforeLeave) {
|
|
788
|
+
var before = this.beforeLeave(value, this.currentName);
|
|
789
|
+
if (before && before.then) {
|
|
790
|
+
before.then(function () {
|
|
791
|
+
changeCurrentName();
|
|
792
|
+
_this3.$refs.nav && _this3.$refs.nav.removeFocus();
|
|
793
|
+
}, function () {
|
|
794
|
+
// https://github.com/ElemeFE/element/pull/14816
|
|
795
|
+
// ignore promise rejection in `before-leave` hook
|
|
796
|
+
});
|
|
797
|
+
} else if (before !== false) {
|
|
798
|
+
changeCurrentName();
|
|
799
|
+
}
|
|
800
|
+
} else {
|
|
801
|
+
changeCurrentName();
|
|
802
|
+
}
|
|
803
|
+
}
|
|
804
|
+
},
|
|
805
|
+
|
|
806
|
+
render: function render(h) {
|
|
807
|
+
var _ref2;
|
|
808
|
+
|
|
809
|
+
var type = this.type,
|
|
810
|
+
handleTabClick = this.handleTabClick,
|
|
811
|
+
handleTabRemove = this.handleTabRemove,
|
|
812
|
+
handleTabAdd = this.handleTabAdd,
|
|
813
|
+
currentName = this.currentName,
|
|
814
|
+
panes = this.panes,
|
|
815
|
+
editable = this.editable,
|
|
816
|
+
addable = this.addable,
|
|
817
|
+
tabPosition = this.tabPosition,
|
|
818
|
+
stretch = this.stretch;
|
|
819
|
+
|
|
820
|
+
|
|
821
|
+
var newButton = editable || addable ? h(
|
|
822
|
+
'span',
|
|
823
|
+
{
|
|
824
|
+
'class': 'el-tabs__new-tab',
|
|
825
|
+
on: {
|
|
826
|
+
'click': handleTabAdd,
|
|
827
|
+
'keydown': function keydown(ev) {
|
|
828
|
+
if (ev.keyCode === 13) {
|
|
829
|
+
handleTabAdd();
|
|
830
|
+
}
|
|
831
|
+
}
|
|
832
|
+
},
|
|
833
|
+
attrs: {
|
|
834
|
+
tabindex: '0'
|
|
835
|
+
}
|
|
836
|
+
},
|
|
837
|
+
[h('i', { 'class': 'el-icon-plus' })]
|
|
838
|
+
) : null;
|
|
839
|
+
|
|
840
|
+
var navData = {
|
|
841
|
+
props: {
|
|
842
|
+
currentName: currentName,
|
|
843
|
+
onTabClick: handleTabClick,
|
|
844
|
+
onTabRemove: handleTabRemove,
|
|
845
|
+
editable: editable,
|
|
846
|
+
type: type,
|
|
847
|
+
panes: panes,
|
|
848
|
+
stretch: stretch
|
|
849
|
+
},
|
|
850
|
+
ref: 'nav'
|
|
851
|
+
};
|
|
852
|
+
var header = h(
|
|
853
|
+
'div',
|
|
854
|
+
{ 'class': ['el-tabs__header', 'is-' + tabPosition] },
|
|
855
|
+
[newButton, h('tab-nav', navData)]
|
|
856
|
+
);
|
|
857
|
+
var panels = h(
|
|
858
|
+
'div',
|
|
859
|
+
{ 'class': 'el-tabs__content' },
|
|
860
|
+
[this.$slots.default]
|
|
861
|
+
);
|
|
862
|
+
|
|
863
|
+
return h(
|
|
864
|
+
'div',
|
|
865
|
+
{ 'class': (_ref2 = {
|
|
866
|
+
'el-tabs': true,
|
|
867
|
+
'el-tabs--card': type === 'card'
|
|
868
|
+
}, _ref2['el-tabs--' + tabPosition] = true, _ref2['el-tabs--border-card'] = type === 'border-card', _ref2) },
|
|
869
|
+
[tabPosition !== 'bottom' ? [header, panels] : [panels, header]]
|
|
870
|
+
);
|
|
871
|
+
},
|
|
872
|
+
created: function created() {
|
|
873
|
+
if (!this.currentName) {
|
|
874
|
+
this.setCurrentName('0');
|
|
875
|
+
}
|
|
876
|
+
|
|
877
|
+
this.$on('tab-nav-update', this.calcPaneInstances.bind(null, true));
|
|
878
|
+
},
|
|
879
|
+
mounted: function mounted() {
|
|
880
|
+
this.calcPaneInstances();
|
|
881
|
+
},
|
|
882
|
+
updated: function updated() {
|
|
883
|
+
this.calcPaneInstances();
|
|
884
|
+
}
|
|
885
|
+
});
|
|
886
|
+
// CONCATENATED MODULE: ./packages/tabs/src/tabs.vue?vue&type=script&lang=js
|
|
887
|
+
/* harmony default export */ var src_tabsvue_type_script_lang_js = (tabsvue_type_script_lang_js);
|
|
888
|
+
// CONCATENATED MODULE: ./packages/tabs/src/tabs.vue
|
|
889
|
+
var tabs_render, tabs_staticRenderFns
|
|
890
|
+
|
|
891
|
+
|
|
892
|
+
|
|
893
|
+
|
|
894
|
+
/* normalize component */
|
|
895
|
+
|
|
896
|
+
var tabs_component = Object(componentNormalizer["a" /* default */])(
|
|
897
|
+
src_tabsvue_type_script_lang_js,
|
|
898
|
+
tabs_render,
|
|
899
|
+
tabs_staticRenderFns,
|
|
900
|
+
false,
|
|
901
|
+
null,
|
|
902
|
+
null,
|
|
903
|
+
null
|
|
904
|
+
|
|
905
|
+
)
|
|
906
|
+
|
|
907
|
+
/* harmony default export */ var tabs = (tabs_component.exports);
|
|
908
|
+
// CONCATENATED MODULE: ./packages/tabs/index.js
|
|
909
|
+
|
|
910
|
+
|
|
911
|
+
/* istanbul ignore next */
|
|
912
|
+
tabs.install = function (Vue) {
|
|
913
|
+
Vue.component(tabs.name, tabs);
|
|
914
|
+
};
|
|
915
|
+
|
|
916
|
+
/* harmony default export */ var packages_tabs = __webpack_exports__["default"] = (tabs);
|
|
917
|
+
|
|
918
|
+
/***/ })
|
|
919
|
+
|
|
920
|
+
/******/ });
|