cy-element-ui 1.1.16 → 1.1.17
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 +8 -8
- package/lib/{alert.js → Alert.js} +2 -2
- package/lib/{aside.js → Aside.js} +2 -2
- package/lib/Autocomplete.js +2051 -0
- package/lib/{avatar.js → Avatar.js} +2 -2
- package/lib/{backtop.js → Backtop.js} +4 -4
- package/lib/{badge.js → Badge.js} +2 -2
- package/lib/{breadcrumb.js → Breadcrumb.js} +2 -2
- package/lib/{breadcrumb-item.js → BreadcrumbItem.js} +2 -2
- package/lib/{button.js → Button.js} +2 -2
- package/lib/{button-group.js → ButtonGroup.js} +2 -2
- package/lib/{calendar.js → Calendar.js} +238 -25
- package/lib/{card.js → Card.js} +2 -2
- package/lib/{carousel.js → Carousel.js} +12 -12
- package/lib/{carousel-item.js → CarouselItem.js} +2 -2
- package/lib/Cascader.js +4641 -0
- package/lib/{cascader-panel.js → CascaderPanel.js} +1101 -57
- package/lib/{checkbox.js → Checkbox.js} +9 -9
- package/lib/{checkbox-button.js → CheckboxButton.js} +2 -2
- package/lib/{checkbox-group.js → CheckboxGroup.js} +9 -9
- package/lib/{col.js → Col.js} +2 -2
- package/lib/{collapse.js → Collapse.js} +2 -2
- package/lib/{collapse-item.js → CollapseItem.js} +4 -4
- package/lib/{color-picker.js → ColorPicker.js} +967 -25
- package/lib/{container.js → Container.js} +2 -2
- package/lib/{selectDisplayInput.js → CySelectDisplayInput.js} +8 -8
- package/lib/{subTitle.js → CySubTitle.js} +8 -8
- package/lib/{tabDialog.js → CyTabDialog.js} +26 -26
- package/lib/{treeSelect.js → CyTreeSelect.js} +3161 -3169
- package/lib/{date-picker.js → DatePicker.js} +1372 -139
- package/lib/{descriptions.js → Descriptions.js} +4 -4
- package/lib/{descriptions-item.js → DescriptionsItem.js} +2 -2
- package/lib/{dialog.js → Dialog.js} +12 -12
- package/lib/{divider.js → Divider.js} +2 -2
- package/lib/{drawer.js → Drawer.js} +4 -4
- package/lib/{dropdown.js → Dropdown.js} +244 -31
- package/lib/{dropdown-item.js → DropdownItem.js} +2 -2
- package/lib/{dropdown-menu.js → DropdownMenu.js} +2 -2
- package/lib/{empty.js → Empty.js} +4 -4
- package/lib/{footer.js → Footer.js} +2 -2
- package/lib/{form.js → Form.js} +10 -10
- package/lib/{form-item.js → FormItem.js} +12 -12
- package/lib/{header.js → Header.js} +2 -2
- package/lib/{icon.js → Icon.js} +2 -2
- package/lib/{image.js → Image.js} +22 -22
- package/lib/{infinite-scroll.js → InfiniteScroll.js} +16 -16
- package/lib/{input.js → Input.js} +27 -26
- package/lib/InputNumber.js +1552 -0
- package/lib/{link.js → Link.js} +2 -2
- package/lib/{loading.js → Loading.js} +15 -15
- package/lib/{main.js → Main.js} +2 -2
- package/lib/{menu.js → Menu.js} +10 -10
- package/lib/{menu-item.js → MenuItem.js} +339 -12
- package/lib/{menu-item-group.js → MenuItemGroup.js} +2 -2
- package/lib/{message.js → Message.js} +16 -16
- package/lib/{message-box.js → MessageBox.js} +973 -31
- package/lib/{notification.js → Notification.js} +11 -11
- package/lib/{option.js → Option.js} +11 -11
- package/lib/{option-group.js → OptionGroup.js} +2 -2
- package/lib/{page-header.js → PageHeader.js} +4 -4
- package/lib/Pagination.js +4123 -0
- package/lib/Popconfirm.js +1025 -0
- package/lib/{popover.js → Popover.js} +6 -6
- package/lib/{progress.js → Progress.js} +2 -2
- package/lib/{radio.js → Radio.js} +9 -9
- package/lib/{radio-button.js → RadioButton.js} +2 -2
- package/lib/{radio-group.js → RadioGroup.js} +2 -2
- package/lib/{rate.js → Rate.js} +20 -20
- package/lib/{result.js → Result.js} +2 -2
- package/lib/{row.js → Row.js} +2 -2
- package/lib/{scrollbar.js → Scrollbar.js} +26 -26
- package/lib/{select.js → Select.js} +1371 -170
- package/lib/{skeleton.js → Skeleton.js} +2 -2
- package/lib/{skeleton-item.js → SkeletonItem.js} +2 -2
- package/lib/Slider.js +2854 -0
- package/lib/{spinner.js → Spinner.js} +2 -2
- package/lib/{statistic.js → Statistic.js} +4 -4
- package/lib/{step.js → Step.js} +2 -2
- package/lib/{steps.js → Steps.js} +4 -4
- package/lib/{submenu.js → Submenu.js} +13 -13
- package/lib/{switch.js → Switch.js} +10 -10
- package/lib/{tab-pane.js → TabPane.js} +2 -2
- package/lib/{table.js → Table.js} +1231 -121
- package/lib/{table-column.js → TableColumn.js} +824 -295
- package/lib/{tabs.js → Tabs.js} +4 -4
- package/lib/{tag.js → Tag.js} +2 -2
- package/lib/{time-picker.js → TimePicker.js} +1183 -91
- package/lib/{time-select.js → TimeSelect.js} +1132 -26
- package/lib/{timeline.js → Timeline.js} +2 -2
- package/lib/{timeline-item.js → TimelineItem.js} +2 -2
- package/lib/{tooltip.js → Tooltip.js} +27 -27
- package/lib/Transfer.js +2557 -0
- package/lib/{tree.js → Tree.js} +436 -19
- package/lib/{upload.js → Upload.js} +411 -19
- package/lib/directives/mousewheel.js +26 -0
- package/lib/directives/repeat-click.js +33 -0
- package/lib/element-ui.common.js +32181 -32331
- package/lib/index.js +1 -1
- package/lib/locale/format.js +55 -0
- package/lib/locale/index.js +63 -0
- package/lib/locale/lang/zh-CN.js +126 -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/theme-chalk/BreadcrumbItem.css +0 -0
- package/lib/theme-chalk/ButtonGroup.css +0 -0
- package/lib/theme-chalk/CarouselItem.css +0 -0
- package/lib/theme-chalk/CascaderPanel.css +0 -0
- package/lib/theme-chalk/CheckboxButton.css +0 -0
- package/lib/theme-chalk/CheckboxGroup.css +0 -0
- package/lib/theme-chalk/CollapseItem.css +0 -0
- package/lib/theme-chalk/ColorPicker.css +0 -0
- package/lib/theme-chalk/DatePicker.css +0 -0
- package/lib/theme-chalk/DescriptionsItem.css +0 -0
- package/lib/theme-chalk/DropdownItem.css +0 -0
- package/lib/theme-chalk/DropdownMenu.css +0 -0
- package/lib/theme-chalk/FormItem.css +0 -0
- package/lib/theme-chalk/InputNumber.css +0 -0
- package/lib/theme-chalk/MenuItem.css +0 -0
- package/lib/theme-chalk/MenuItemGroup.css +0 -0
- package/lib/theme-chalk/MessageBox.css +0 -0
- package/lib/theme-chalk/OptionGroup.css +0 -0
- package/lib/theme-chalk/PageHeader.css +0 -0
- package/lib/theme-chalk/RadioButton.css +0 -0
- package/lib/theme-chalk/RadioGroup.css +0 -0
- package/lib/theme-chalk/SkeletonItem.css +0 -0
- package/lib/theme-chalk/TabPane.css +0 -0
- package/lib/theme-chalk/TableColumn.css +0 -0
- package/lib/theme-chalk/TimePicker.css +0 -0
- package/lib/theme-chalk/TimeSelect.css +0 -0
- package/lib/theme-chalk/TimelineItem.css +0 -0
- package/lib/transitions/collapse-transition.js +91 -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 +6 -23
- package/packages/{tabDialog → cy/tabDialog}/src/main.vue +1 -1
- package/packages/{treeSelect → cy/treeSelect}/src/main.vue +4 -4
- package/packages/theme-chalk/src/BreadcrumbItem.scss +0 -0
- package/packages/theme-chalk/src/ButtonGroup.scss +0 -0
- package/packages/theme-chalk/src/CarouselItem.scss +0 -0
- package/packages/theme-chalk/src/CascaderPanel.scss +0 -0
- package/packages/theme-chalk/src/CheckboxButton.scss +0 -0
- package/packages/theme-chalk/src/CheckboxGroup.scss +0 -0
- package/packages/theme-chalk/src/CollapseItem.scss +0 -0
- package/packages/theme-chalk/src/ColorPicker.scss +0 -0
- package/packages/theme-chalk/src/DatePicker.scss +0 -0
- package/packages/theme-chalk/src/DescriptionsItem.scss +0 -0
- package/packages/theme-chalk/src/DropdownItem.scss +0 -0
- package/packages/theme-chalk/src/DropdownMenu.scss +0 -0
- package/packages/theme-chalk/src/FormItem.scss +0 -0
- package/packages/theme-chalk/src/InputNumber.scss +0 -0
- package/packages/theme-chalk/src/MenuItem.scss +0 -0
- package/packages/theme-chalk/src/MenuItemGroup.scss +0 -0
- package/packages/theme-chalk/src/MessageBox.scss +0 -0
- package/packages/theme-chalk/src/OptionGroup.scss +0 -0
- package/packages/theme-chalk/src/PageHeader.scss +0 -0
- package/packages/theme-chalk/src/RadioButton.scss +0 -0
- package/packages/theme-chalk/src/RadioGroup.scss +0 -0
- package/packages/theme-chalk/src/SkeletonItem.scss +0 -0
- package/packages/theme-chalk/src/TabPane.scss +0 -0
- package/packages/theme-chalk/src/TableColumn.scss +0 -0
- package/packages/theme-chalk/src/TimePicker.scss +0 -0
- package/packages/theme-chalk/src/TimeSelect.scss +0 -0
- package/packages/theme-chalk/src/TimelineItem.scss +0 -0
- package/packages/theme-chalk/src/index.scss +89 -87
- package/src/index.js +15 -15
- package/types/cy/cy-element-ui.d.ts +31 -0
- package/types/cy/cy-select-display-input.d.ts +7 -0
- package/types/cy/cy-sub-title.d.ts +7 -0
- package/types/cy/cy-tab-dialog.d.ts +7 -0
- package/types/cy/cy-tree-select.d.ts +7 -0
- package/types/cy/index.d.ts +1 -0
- package/types/cy/select-display-input.d.ts +19 -0
- package/types/cy/sub-title.d.ts +10 -0
- package/types/cy/tab-dialog.d.ts +51 -0
- package/types/cy/tree-select.d.ts +44 -0
- package/types/index.d.ts +1 -0
- package/lib/autocomplete.js +0 -952
- package/lib/cascader.js +0 -1439
- package/lib/input-number.js +0 -757
- package/lib/pagination.js +0 -950
- package/lib/popconfirm.js +0 -457
- package/lib/slider.js +0 -1199
- package/lib/transfer.js +0 -1102
- package/lib/umd/locale/en.js +0 -142
- package/lib/umd/locale/zh-TW.js +0 -142
- package/src/locale/lang/en.js +0 -123
- package/src/locale/lang/zh-TW.js +0 -123
- /package/packages/{selectDisplayInput → cy/selectDisplayInput}/index.js +0 -0
- /package/packages/{selectDisplayInput → cy/selectDisplayInput}/src/main.vue +0 -0
- /package/packages/{subTitle → cy/subTitle}/index.js +0 -0
- /package/packages/{subTitle → cy/subTitle}/src/main.vue +0 -0
- /package/packages/{tabDialog → cy/tabDialog}/index.js +0 -0
- /package/packages/{tabDialog → cy/tabDialog}/src/dialog/drag.js +0 -0
- /package/packages/{tabDialog → cy/tabDialog}/src/dialog/dragHeight.js +0 -0
- /package/packages/{tabDialog → cy/tabDialog}/src/dialog/dragWidth.js +0 -0
- /package/packages/{treeSelect → cy/treeSelect}/index.js +0 -0
|
@@ -0,0 +1,233 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
exports.__esModule = true;
|
|
4
|
+
exports.PopupManager = undefined;
|
|
5
|
+
|
|
6
|
+
var _vue = require('vue');
|
|
7
|
+
|
|
8
|
+
var _vue2 = _interopRequireDefault(_vue);
|
|
9
|
+
|
|
10
|
+
var _merge = require('element-ui/lib/utils/merge');
|
|
11
|
+
|
|
12
|
+
var _merge2 = _interopRequireDefault(_merge);
|
|
13
|
+
|
|
14
|
+
var _popupManager = require('element-ui/lib/utils/popup/popup-manager');
|
|
15
|
+
|
|
16
|
+
var _popupManager2 = _interopRequireDefault(_popupManager);
|
|
17
|
+
|
|
18
|
+
var _scrollbarWidth = require('../scrollbar-width');
|
|
19
|
+
|
|
20
|
+
var _scrollbarWidth2 = _interopRequireDefault(_scrollbarWidth);
|
|
21
|
+
|
|
22
|
+
var _dom = require('../dom');
|
|
23
|
+
|
|
24
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
25
|
+
|
|
26
|
+
var idSeed = 1;
|
|
27
|
+
|
|
28
|
+
var scrollBarWidth = void 0;
|
|
29
|
+
|
|
30
|
+
exports.default = {
|
|
31
|
+
props: {
|
|
32
|
+
visible: {
|
|
33
|
+
type: Boolean,
|
|
34
|
+
default: false
|
|
35
|
+
},
|
|
36
|
+
openDelay: {},
|
|
37
|
+
closeDelay: {},
|
|
38
|
+
zIndex: {},
|
|
39
|
+
modal: {
|
|
40
|
+
type: Boolean,
|
|
41
|
+
default: false
|
|
42
|
+
},
|
|
43
|
+
modalFade: {
|
|
44
|
+
type: Boolean,
|
|
45
|
+
default: true
|
|
46
|
+
},
|
|
47
|
+
modalClass: {},
|
|
48
|
+
modalAppendToBody: {
|
|
49
|
+
type: Boolean,
|
|
50
|
+
default: false
|
|
51
|
+
},
|
|
52
|
+
lockScroll: {
|
|
53
|
+
type: Boolean,
|
|
54
|
+
default: true
|
|
55
|
+
},
|
|
56
|
+
closeOnPressEscape: {
|
|
57
|
+
type: Boolean,
|
|
58
|
+
default: false
|
|
59
|
+
},
|
|
60
|
+
closeOnClickModal: {
|
|
61
|
+
type: Boolean,
|
|
62
|
+
default: false
|
|
63
|
+
}
|
|
64
|
+
},
|
|
65
|
+
|
|
66
|
+
beforeMount: function beforeMount() {
|
|
67
|
+
this._popupId = 'popup-' + idSeed++;
|
|
68
|
+
_popupManager2.default.register(this._popupId, this);
|
|
69
|
+
},
|
|
70
|
+
beforeDestroy: function beforeDestroy() {
|
|
71
|
+
_popupManager2.default.deregister(this._popupId);
|
|
72
|
+
_popupManager2.default.closeModal(this._popupId);
|
|
73
|
+
|
|
74
|
+
this.restoreBodyStyle();
|
|
75
|
+
},
|
|
76
|
+
data: function data() {
|
|
77
|
+
return {
|
|
78
|
+
opened: false,
|
|
79
|
+
bodyPaddingRight: null,
|
|
80
|
+
computedBodyPaddingRight: 0,
|
|
81
|
+
withoutHiddenClass: true,
|
|
82
|
+
rendered: false
|
|
83
|
+
};
|
|
84
|
+
},
|
|
85
|
+
|
|
86
|
+
|
|
87
|
+
watch: {
|
|
88
|
+
visible: function visible(val) {
|
|
89
|
+
var _this = this;
|
|
90
|
+
|
|
91
|
+
if (val) {
|
|
92
|
+
if (this._opening) return;
|
|
93
|
+
if (!this.rendered) {
|
|
94
|
+
this.rendered = true;
|
|
95
|
+
_vue2.default.nextTick(function () {
|
|
96
|
+
_this.open();
|
|
97
|
+
});
|
|
98
|
+
} else {
|
|
99
|
+
this.open();
|
|
100
|
+
}
|
|
101
|
+
} else {
|
|
102
|
+
this.close();
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
},
|
|
106
|
+
|
|
107
|
+
methods: {
|
|
108
|
+
open: function open(options) {
|
|
109
|
+
var _this2 = this;
|
|
110
|
+
|
|
111
|
+
if (!this.rendered) {
|
|
112
|
+
this.rendered = true;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
var props = (0, _merge2.default)({}, this.$props || this, options);
|
|
116
|
+
|
|
117
|
+
if (this._closeTimer) {
|
|
118
|
+
clearTimeout(this._closeTimer);
|
|
119
|
+
this._closeTimer = null;
|
|
120
|
+
}
|
|
121
|
+
clearTimeout(this._openTimer);
|
|
122
|
+
|
|
123
|
+
var openDelay = Number(props.openDelay);
|
|
124
|
+
if (openDelay > 0) {
|
|
125
|
+
this._openTimer = setTimeout(function () {
|
|
126
|
+
_this2._openTimer = null;
|
|
127
|
+
_this2.doOpen(props);
|
|
128
|
+
}, openDelay);
|
|
129
|
+
} else {
|
|
130
|
+
this.doOpen(props);
|
|
131
|
+
}
|
|
132
|
+
},
|
|
133
|
+
doOpen: function doOpen(props) {
|
|
134
|
+
if (this.$isServer) return;
|
|
135
|
+
if (this.willOpen && !this.willOpen()) return;
|
|
136
|
+
if (this.opened) return;
|
|
137
|
+
|
|
138
|
+
this._opening = true;
|
|
139
|
+
|
|
140
|
+
var dom = this.$el;
|
|
141
|
+
|
|
142
|
+
var modal = props.modal;
|
|
143
|
+
|
|
144
|
+
var zIndex = props.zIndex;
|
|
145
|
+
if (zIndex) {
|
|
146
|
+
_popupManager2.default.zIndex = zIndex;
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
if (modal) {
|
|
150
|
+
if (this._closing) {
|
|
151
|
+
_popupManager2.default.closeModal(this._popupId);
|
|
152
|
+
this._closing = false;
|
|
153
|
+
}
|
|
154
|
+
_popupManager2.default.openModal(this._popupId, _popupManager2.default.nextZIndex(), this.modalAppendToBody ? undefined : dom, props.modalClass, props.modalFade);
|
|
155
|
+
if (props.lockScroll) {
|
|
156
|
+
this.withoutHiddenClass = !(0, _dom.hasClass)(document.body, 'el-popup-parent--hidden');
|
|
157
|
+
if (this.withoutHiddenClass) {
|
|
158
|
+
this.bodyPaddingRight = document.body.style.paddingRight;
|
|
159
|
+
this.computedBodyPaddingRight = parseInt((0, _dom.getStyle)(document.body, 'paddingRight'), 10);
|
|
160
|
+
}
|
|
161
|
+
scrollBarWidth = (0, _scrollbarWidth2.default)();
|
|
162
|
+
var bodyHasOverflow = document.documentElement.clientHeight < document.body.scrollHeight;
|
|
163
|
+
var bodyOverflowY = (0, _dom.getStyle)(document.body, 'overflowY');
|
|
164
|
+
if (scrollBarWidth > 0 && (bodyHasOverflow || bodyOverflowY === 'scroll') && this.withoutHiddenClass) {
|
|
165
|
+
document.body.style.paddingRight = this.computedBodyPaddingRight + scrollBarWidth + 'px';
|
|
166
|
+
}
|
|
167
|
+
(0, _dom.addClass)(document.body, 'el-popup-parent--hidden');
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
if (getComputedStyle(dom).position === 'static') {
|
|
172
|
+
dom.style.position = 'absolute';
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
dom.style.zIndex = _popupManager2.default.nextZIndex();
|
|
176
|
+
this.opened = true;
|
|
177
|
+
|
|
178
|
+
this.onOpen && this.onOpen();
|
|
179
|
+
|
|
180
|
+
this.doAfterOpen();
|
|
181
|
+
},
|
|
182
|
+
doAfterOpen: function doAfterOpen() {
|
|
183
|
+
this._opening = false;
|
|
184
|
+
},
|
|
185
|
+
close: function close() {
|
|
186
|
+
var _this3 = this;
|
|
187
|
+
|
|
188
|
+
if (this.willClose && !this.willClose()) return;
|
|
189
|
+
|
|
190
|
+
if (this._openTimer !== null) {
|
|
191
|
+
clearTimeout(this._openTimer);
|
|
192
|
+
this._openTimer = null;
|
|
193
|
+
}
|
|
194
|
+
clearTimeout(this._closeTimer);
|
|
195
|
+
|
|
196
|
+
var closeDelay = Number(this.closeDelay);
|
|
197
|
+
|
|
198
|
+
if (closeDelay > 0) {
|
|
199
|
+
this._closeTimer = setTimeout(function () {
|
|
200
|
+
_this3._closeTimer = null;
|
|
201
|
+
_this3.doClose();
|
|
202
|
+
}, closeDelay);
|
|
203
|
+
} else {
|
|
204
|
+
this.doClose();
|
|
205
|
+
}
|
|
206
|
+
},
|
|
207
|
+
doClose: function doClose() {
|
|
208
|
+
this._closing = true;
|
|
209
|
+
|
|
210
|
+
this.onClose && this.onClose();
|
|
211
|
+
|
|
212
|
+
if (this.lockScroll) {
|
|
213
|
+
setTimeout(this.restoreBodyStyle, 200);
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
this.opened = false;
|
|
217
|
+
|
|
218
|
+
this.doAfterClose();
|
|
219
|
+
},
|
|
220
|
+
doAfterClose: function doAfterClose() {
|
|
221
|
+
_popupManager2.default.closeModal(this._popupId);
|
|
222
|
+
this._closing = false;
|
|
223
|
+
},
|
|
224
|
+
restoreBodyStyle: function restoreBodyStyle() {
|
|
225
|
+
if (this.modal && this.withoutHiddenClass) {
|
|
226
|
+
document.body.style.paddingRight = this.bodyPaddingRight;
|
|
227
|
+
(0, _dom.removeClass)(document.body, 'el-popup-parent--hidden');
|
|
228
|
+
}
|
|
229
|
+
this.withoutHiddenClass = true;
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
};
|
|
233
|
+
exports.PopupManager = _popupManager2.default;
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
exports.__esModule = true;
|
|
4
|
+
|
|
5
|
+
var _vue = require('vue');
|
|
6
|
+
|
|
7
|
+
var _vue2 = _interopRequireDefault(_vue);
|
|
8
|
+
|
|
9
|
+
var _dom = require('element-ui/lib/utils/dom');
|
|
10
|
+
|
|
11
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
12
|
+
|
|
13
|
+
var hasModal = false;
|
|
14
|
+
var hasInitZIndex = false;
|
|
15
|
+
var zIndex = void 0;
|
|
16
|
+
|
|
17
|
+
var getModal = function getModal() {
|
|
18
|
+
if (_vue2.default.prototype.$isServer) return;
|
|
19
|
+
var modalDom = PopupManager.modalDom;
|
|
20
|
+
if (modalDom) {
|
|
21
|
+
hasModal = true;
|
|
22
|
+
} else {
|
|
23
|
+
hasModal = false;
|
|
24
|
+
modalDom = document.createElement('div');
|
|
25
|
+
PopupManager.modalDom = modalDom;
|
|
26
|
+
|
|
27
|
+
modalDom.addEventListener('touchmove', function (event) {
|
|
28
|
+
event.preventDefault();
|
|
29
|
+
event.stopPropagation();
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
modalDom.addEventListener('click', function () {
|
|
33
|
+
PopupManager.doOnModalClick && PopupManager.doOnModalClick();
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
return modalDom;
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
var instances = {};
|
|
41
|
+
|
|
42
|
+
var PopupManager = {
|
|
43
|
+
modalFade: true,
|
|
44
|
+
|
|
45
|
+
getInstance: function getInstance(id) {
|
|
46
|
+
return instances[id];
|
|
47
|
+
},
|
|
48
|
+
|
|
49
|
+
register: function register(id, instance) {
|
|
50
|
+
if (id && instance) {
|
|
51
|
+
instances[id] = instance;
|
|
52
|
+
}
|
|
53
|
+
},
|
|
54
|
+
|
|
55
|
+
deregister: function deregister(id) {
|
|
56
|
+
if (id) {
|
|
57
|
+
instances[id] = null;
|
|
58
|
+
delete instances[id];
|
|
59
|
+
}
|
|
60
|
+
},
|
|
61
|
+
|
|
62
|
+
nextZIndex: function nextZIndex() {
|
|
63
|
+
return PopupManager.zIndex++;
|
|
64
|
+
},
|
|
65
|
+
|
|
66
|
+
modalStack: [],
|
|
67
|
+
|
|
68
|
+
doOnModalClick: function doOnModalClick() {
|
|
69
|
+
var topItem = PopupManager.modalStack[PopupManager.modalStack.length - 1];
|
|
70
|
+
if (!topItem) return;
|
|
71
|
+
|
|
72
|
+
var instance = PopupManager.getInstance(topItem.id);
|
|
73
|
+
if (instance && instance.closeOnClickModal) {
|
|
74
|
+
instance.close();
|
|
75
|
+
}
|
|
76
|
+
},
|
|
77
|
+
|
|
78
|
+
openModal: function openModal(id, zIndex, dom, modalClass, modalFade) {
|
|
79
|
+
if (_vue2.default.prototype.$isServer) return;
|
|
80
|
+
if (!id || zIndex === undefined) return;
|
|
81
|
+
this.modalFade = modalFade;
|
|
82
|
+
|
|
83
|
+
var modalStack = this.modalStack;
|
|
84
|
+
|
|
85
|
+
for (var i = 0, j = modalStack.length; i < j; i++) {
|
|
86
|
+
var item = modalStack[i];
|
|
87
|
+
if (item.id === id) {
|
|
88
|
+
return;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
var modalDom = getModal();
|
|
93
|
+
|
|
94
|
+
(0, _dom.addClass)(modalDom, 'v-modal');
|
|
95
|
+
if (this.modalFade && !hasModal) {
|
|
96
|
+
(0, _dom.addClass)(modalDom, 'v-modal-enter');
|
|
97
|
+
}
|
|
98
|
+
if (modalClass) {
|
|
99
|
+
var classArr = modalClass.trim().split(/\s+/);
|
|
100
|
+
classArr.forEach(function (item) {
|
|
101
|
+
return (0, _dom.addClass)(modalDom, item);
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
setTimeout(function () {
|
|
105
|
+
(0, _dom.removeClass)(modalDom, 'v-modal-enter');
|
|
106
|
+
}, 200);
|
|
107
|
+
|
|
108
|
+
if (dom && dom.parentNode && dom.parentNode.nodeType !== 11) {
|
|
109
|
+
dom.parentNode.appendChild(modalDom);
|
|
110
|
+
} else {
|
|
111
|
+
document.body.appendChild(modalDom);
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
if (zIndex) {
|
|
115
|
+
modalDom.style.zIndex = zIndex;
|
|
116
|
+
}
|
|
117
|
+
modalDom.tabIndex = 0;
|
|
118
|
+
modalDom.style.display = '';
|
|
119
|
+
|
|
120
|
+
this.modalStack.push({ id: id, zIndex: zIndex, modalClass: modalClass });
|
|
121
|
+
},
|
|
122
|
+
|
|
123
|
+
closeModal: function closeModal(id) {
|
|
124
|
+
var modalStack = this.modalStack;
|
|
125
|
+
var modalDom = getModal();
|
|
126
|
+
|
|
127
|
+
if (modalStack.length > 0) {
|
|
128
|
+
var topItem = modalStack[modalStack.length - 1];
|
|
129
|
+
if (topItem.id === id) {
|
|
130
|
+
if (topItem.modalClass) {
|
|
131
|
+
var classArr = topItem.modalClass.trim().split(/\s+/);
|
|
132
|
+
classArr.forEach(function (item) {
|
|
133
|
+
return (0, _dom.removeClass)(modalDom, item);
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
modalStack.pop();
|
|
138
|
+
if (modalStack.length > 0) {
|
|
139
|
+
modalDom.style.zIndex = modalStack[modalStack.length - 1].zIndex;
|
|
140
|
+
}
|
|
141
|
+
} else {
|
|
142
|
+
for (var i = modalStack.length - 1; i >= 0; i--) {
|
|
143
|
+
if (modalStack[i].id === id) {
|
|
144
|
+
modalStack.splice(i, 1);
|
|
145
|
+
break;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
if (modalStack.length === 0) {
|
|
152
|
+
if (this.modalFade) {
|
|
153
|
+
(0, _dom.addClass)(modalDom, 'v-modal-leave');
|
|
154
|
+
}
|
|
155
|
+
setTimeout(function () {
|
|
156
|
+
if (modalStack.length === 0) {
|
|
157
|
+
if (modalDom.parentNode) modalDom.parentNode.removeChild(modalDom);
|
|
158
|
+
modalDom.style.display = 'none';
|
|
159
|
+
PopupManager.modalDom = undefined;
|
|
160
|
+
}
|
|
161
|
+
(0, _dom.removeClass)(modalDom, 'v-modal-leave');
|
|
162
|
+
}, 200);
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
};
|
|
166
|
+
|
|
167
|
+
Object.defineProperty(PopupManager, 'zIndex', {
|
|
168
|
+
configurable: true,
|
|
169
|
+
get: function get() {
|
|
170
|
+
if (!hasInitZIndex) {
|
|
171
|
+
zIndex = zIndex || (_vue2.default.prototype.$ELEMENT || {}).zIndex || 2000;
|
|
172
|
+
hasInitZIndex = true;
|
|
173
|
+
}
|
|
174
|
+
return zIndex;
|
|
175
|
+
},
|
|
176
|
+
set: function set(value) {
|
|
177
|
+
zIndex = value;
|
|
178
|
+
}
|
|
179
|
+
});
|
|
180
|
+
|
|
181
|
+
var getTopPopup = function getTopPopup() {
|
|
182
|
+
if (_vue2.default.prototype.$isServer) return;
|
|
183
|
+
if (PopupManager.modalStack.length > 0) {
|
|
184
|
+
var topPopup = PopupManager.modalStack[PopupManager.modalStack.length - 1];
|
|
185
|
+
if (!topPopup) return;
|
|
186
|
+
var instance = PopupManager.getInstance(topPopup.id);
|
|
187
|
+
|
|
188
|
+
return instance;
|
|
189
|
+
}
|
|
190
|
+
};
|
|
191
|
+
|
|
192
|
+
if (!_vue2.default.prototype.$isServer) {
|
|
193
|
+
// handle `esc` key when the popup is shown
|
|
194
|
+
window.addEventListener('keydown', function (event) {
|
|
195
|
+
if (event.keyCode === 27) {
|
|
196
|
+
var topPopup = getTopPopup();
|
|
197
|
+
|
|
198
|
+
if (topPopup && topPopup.closeOnPressEscape) {
|
|
199
|
+
topPopup.handleClose ? topPopup.handleClose() : topPopup.handleAction ? topPopup.handleAction('cancel') : topPopup.close();
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
});
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
exports.default = PopupManager;
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
exports.__esModule = true;
|
|
4
|
+
exports.removeResizeListener = exports.addResizeListener = undefined;
|
|
5
|
+
|
|
6
|
+
var _resizeObserverPolyfill = require('resize-observer-polyfill');
|
|
7
|
+
|
|
8
|
+
var _resizeObserverPolyfill2 = _interopRequireDefault(_resizeObserverPolyfill);
|
|
9
|
+
|
|
10
|
+
var _throttleDebounce = require('throttle-debounce');
|
|
11
|
+
|
|
12
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
13
|
+
|
|
14
|
+
var isServer = typeof window === 'undefined';
|
|
15
|
+
|
|
16
|
+
/* istanbul ignore next */
|
|
17
|
+
var resizeHandler = function resizeHandler(entries) {
|
|
18
|
+
for (var _iterator = entries, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
|
|
19
|
+
var _ref;
|
|
20
|
+
|
|
21
|
+
if (_isArray) {
|
|
22
|
+
if (_i >= _iterator.length) break;
|
|
23
|
+
_ref = _iterator[_i++];
|
|
24
|
+
} else {
|
|
25
|
+
_i = _iterator.next();
|
|
26
|
+
if (_i.done) break;
|
|
27
|
+
_ref = _i.value;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
var entry = _ref;
|
|
31
|
+
|
|
32
|
+
var listeners = entry.target.__resizeListeners__ || [];
|
|
33
|
+
if (listeners.length) {
|
|
34
|
+
listeners.forEach(function (fn) {
|
|
35
|
+
fn();
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
/* istanbul ignore next */
|
|
42
|
+
var addResizeListener = exports.addResizeListener = function addResizeListener(element, fn) {
|
|
43
|
+
if (isServer) return;
|
|
44
|
+
if (!element.__resizeListeners__) {
|
|
45
|
+
element.__resizeListeners__ = [];
|
|
46
|
+
element.__ro__ = new _resizeObserverPolyfill2.default((0, _throttleDebounce.debounce)(16, resizeHandler));
|
|
47
|
+
element.__ro__.observe(element);
|
|
48
|
+
}
|
|
49
|
+
element.__resizeListeners__.push(fn);
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
/* istanbul ignore next */
|
|
53
|
+
var removeResizeListener = exports.removeResizeListener = function removeResizeListener(element, fn) {
|
|
54
|
+
if (!element || !element.__resizeListeners__) return;
|
|
55
|
+
element.__resizeListeners__.splice(element.__resizeListeners__.indexOf(fn), 1);
|
|
56
|
+
if (!element.__resizeListeners__.length) {
|
|
57
|
+
element.__ro__.disconnect();
|
|
58
|
+
}
|
|
59
|
+
};
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
exports.__esModule = true;
|
|
4
|
+
exports.default = scrollIntoView;
|
|
5
|
+
|
|
6
|
+
var _vue = require('vue');
|
|
7
|
+
|
|
8
|
+
var _vue2 = _interopRequireDefault(_vue);
|
|
9
|
+
|
|
10
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
11
|
+
|
|
12
|
+
function scrollIntoView(container, selected) {
|
|
13
|
+
if (_vue2.default.prototype.$isServer) return;
|
|
14
|
+
|
|
15
|
+
if (!selected) {
|
|
16
|
+
container.scrollTop = 0;
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
var offsetParents = [];
|
|
21
|
+
var pointer = selected.offsetParent;
|
|
22
|
+
while (pointer && container !== pointer && container.contains(pointer)) {
|
|
23
|
+
offsetParents.push(pointer);
|
|
24
|
+
pointer = pointer.offsetParent;
|
|
25
|
+
}
|
|
26
|
+
var top = selected.offsetTop + offsetParents.reduce(function (prev, curr) {
|
|
27
|
+
return prev + curr.offsetTop;
|
|
28
|
+
}, 0);
|
|
29
|
+
var bottom = top + selected.offsetHeight;
|
|
30
|
+
var viewRectTop = container.scrollTop;
|
|
31
|
+
var viewRectBottom = viewRectTop + container.clientHeight;
|
|
32
|
+
|
|
33
|
+
if (top < viewRectTop) {
|
|
34
|
+
container.scrollTop = top;
|
|
35
|
+
} else if (bottom > viewRectBottom) {
|
|
36
|
+
container.scrollTop = bottom - container.clientHeight;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
exports.__esModule = true;
|
|
4
|
+
|
|
5
|
+
exports.default = function () {
|
|
6
|
+
if (_vue2.default.prototype.$isServer) return 0;
|
|
7
|
+
if (scrollBarWidth !== undefined) return scrollBarWidth;
|
|
8
|
+
|
|
9
|
+
var outer = document.createElement('div');
|
|
10
|
+
outer.className = 'el-scrollbar__wrap';
|
|
11
|
+
outer.style.visibility = 'hidden';
|
|
12
|
+
outer.style.width = '100px';
|
|
13
|
+
outer.style.position = 'absolute';
|
|
14
|
+
outer.style.top = '-9999px';
|
|
15
|
+
document.body.appendChild(outer);
|
|
16
|
+
|
|
17
|
+
var widthNoScroll = outer.offsetWidth;
|
|
18
|
+
outer.style.overflow = 'scroll';
|
|
19
|
+
|
|
20
|
+
var inner = document.createElement('div');
|
|
21
|
+
inner.style.width = '100%';
|
|
22
|
+
outer.appendChild(inner);
|
|
23
|
+
|
|
24
|
+
var widthWithScroll = inner.offsetWidth;
|
|
25
|
+
outer.parentNode.removeChild(outer);
|
|
26
|
+
scrollBarWidth = widthNoScroll - widthWithScroll;
|
|
27
|
+
|
|
28
|
+
return scrollBarWidth;
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
var _vue = require('vue');
|
|
32
|
+
|
|
33
|
+
var _vue2 = _interopRequireDefault(_vue);
|
|
34
|
+
|
|
35
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
36
|
+
|
|
37
|
+
var scrollBarWidth = void 0;
|
|
38
|
+
|
|
39
|
+
;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
exports.__esModule = true;
|
|
4
|
+
exports.isDef = isDef;
|
|
5
|
+
exports.isKorean = isKorean;
|
|
6
|
+
function isDef(val) {
|
|
7
|
+
return val !== undefined && val !== null;
|
|
8
|
+
}
|
|
9
|
+
function isKorean(text) {
|
|
10
|
+
var reg = /([(\uAC00-\uD7AF)|(\u3130-\u318F)])+/gi;
|
|
11
|
+
return reg.test(text);
|
|
12
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
exports.__esModule = true;
|
|
4
|
+
exports.isDefined = exports.isUndefined = exports.isFunction = undefined;
|
|
5
|
+
|
|
6
|
+
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
|
|
7
|
+
|
|
8
|
+
exports.isString = isString;
|
|
9
|
+
exports.isObject = isObject;
|
|
10
|
+
exports.isHtmlElement = isHtmlElement;
|
|
11
|
+
|
|
12
|
+
var _vue = require('vue');
|
|
13
|
+
|
|
14
|
+
var _vue2 = _interopRequireDefault(_vue);
|
|
15
|
+
|
|
16
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
17
|
+
|
|
18
|
+
function isString(obj) {
|
|
19
|
+
return Object.prototype.toString.call(obj) === '[object String]';
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
function isObject(obj) {
|
|
23
|
+
return Object.prototype.toString.call(obj) === '[object Object]';
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
function isHtmlElement(node) {
|
|
27
|
+
return node && node.nodeType === Node.ELEMENT_NODE;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* - Inspired:
|
|
32
|
+
* https://github.com/jashkenas/underscore/blob/master/modules/isFunction.js
|
|
33
|
+
*/
|
|
34
|
+
var isFunction = function isFunction(functionToCheck) {
|
|
35
|
+
var getType = {};
|
|
36
|
+
return functionToCheck && getType.toString.call(functionToCheck) === '[object Function]';
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
if (typeof /./ !== 'function' && (typeof Int8Array === 'undefined' ? 'undefined' : _typeof(Int8Array)) !== 'object' && (_vue2.default.prototype.$isServer || typeof document.childNodes !== 'function')) {
|
|
40
|
+
exports.isFunction = isFunction = function isFunction(obj) {
|
|
41
|
+
return typeof obj === 'function' || false;
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
exports.isFunction = isFunction;
|
|
46
|
+
var isUndefined = exports.isUndefined = function isUndefined(val) {
|
|
47
|
+
return val === void 0;
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
var isDefined = exports.isDefined = function isDefined(val) {
|
|
51
|
+
return val !== undefined && val !== null;
|
|
52
|
+
};
|