evui 2.1.0 → 2.1.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.
Files changed (189) hide show
  1. package/dist/{adac9fa4f723f9d2cb5b6640517114a9.png → 0b8d1200e71cae8d747dce4e69c4efb6.png} +0 -0
  2. package/dist/1.css +4 -0
  3. package/dist/1.css.map +1 -0
  4. package/dist/1.evui.min.js +2 -0
  5. package/dist/1.evui.min.js.map +1 -0
  6. package/dist/1ba679c05036b34bf359aa2e6c450faa.ttf +0 -0
  7. package/dist/2.css +4 -0
  8. package/dist/2.css.map +1 -0
  9. package/dist/2.evui.min.js +2 -0
  10. package/dist/2.evui.min.js.map +1 -0
  11. package/dist/{e8c322de9658cbeb8a774b6624167c2c.woff2 → 278156e41e0ad908cf7f841b17130502.woff2} +0 -0
  12. package/dist/3.evui.min.js +2 -0
  13. package/dist/3.evui.min.js.map +1 -0
  14. package/dist/32be89b11725274cd3e801192ba88361.ttf +0 -0
  15. package/dist/{0ab54153eeeca0ce03978cc463b257f7.woff2 → 38c6d8bab26db77d8c806813e1497763.woff2} +0 -0
  16. package/dist/4.evui.min.js +2 -0
  17. package/dist/4.evui.min.js.map +1 -0
  18. package/dist/{faff92145777a3cbaf8e7367b4807987.woff → 425399f81e4ce7cbd967685402ba0260.woff} +0 -0
  19. package/dist/4730076470a665bbc7b783c56d29a72e.svg +261 -0
  20. package/dist/52e9a7f6ff3af5ad261e5292d07ebdca.eot +0 -0
  21. package/dist/{ad97afd3337e8cda302d10ff5a4026b8.ttf → 5367103510b27b78482794590e1ce3b0.ttf} +0 -0
  22. package/dist/{65363c4d55617bbeb57d8ce6dcd46099.svg → 57e963e3d6dd0a9cf05150b40eebf69b.svg} +0 -0
  23. package/dist/{c5ebe0b32dc1b5cc449a76c4204d13bb.ttf → 65a2fb6d9aaa164b41a039302093995b.ttf} +0 -0
  24. package/dist/{cd6c777f1945164224dee082abaea03a.woff2 → 687a4990ea22bb1a49d469a5d9319790.woff2} +0 -0
  25. package/dist/{7583da5c07275cd5eb364507616f998f.ttf → 6c1d906bf5ba48676f65b2d65e935e1a.ttf} +0 -0
  26. package/dist/6dafca5a4f1e31f2bdf11939b24ff422.ttf +0 -0
  27. package/dist/{701ae6abd4719e9c2ada3535a497b341.eot → 752905fa5edf21fc52a10a0c1ca9c7a4.eot} +0 -0
  28. package/dist/76c05d80dda67cdc5d03f345b7bd063f.ttf +0 -0
  29. package/dist/{b551b554a67e86a840bc80cbb8066c30.svg → 7d62eb50e7bb05eedb2a4656f7fe8f3b.svg} +0 -0
  30. package/dist/{8e3c7f5520f5ae906c6cf6d7f3ddcd19.eot → a01e3f2d6c83dc3aee175e2482b3f777.eot} +0 -0
  31. package/dist/{448f2aaa315fa9dce7b2cf6ce31caed6.svg → b30fd8419d7e6d5918856c7531d33482.svg} +0 -0
  32. package/dist/c57dd55fa982e8940f69ca1d69a8a999.woff +0 -0
  33. package/dist/{b87b9ba532ace76ae9f6edfe9f72ded2.ttf → c656b8caa454ed19b9a2ef7f4f5b8fea.ttf} +0 -0
  34. package/dist/{a046592bac8f2fd96e994733faf3858c.woff → cac87dc00c87a5d74711d0276713808a.woff} +0 -0
  35. package/dist/{13db00b7a34fee4d819ab7f9838cc428.eot → d68fa3e67dbb653a13cec44b1bcabcfe.eot} +0 -0
  36. package/dist/{ef60a4f6c25ef7f39f2d25a748dbecfe.woff → ddae9b1ba9b0b42f58809904b0b21349.woff} +0 -0
  37. package/dist/evui.min.js +6 -86054
  38. package/dist/evui.min.js.gz +0 -0
  39. package/dist/evui.min.js.map +1 -1
  40. package/dist/main.css +43 -5541
  41. package/dist/main.css.gz +0 -0
  42. package/dist/main.css.map +1 -1
  43. package/package.json +56 -76
  44. package/src/common/emitter.js +20 -0
  45. package/src/common/utils.debounce.js +223 -0
  46. package/src/common/utils.js +51 -17
  47. package/src/common/utils.throttle.js +83 -0
  48. package/src/common/utils.tree.js +18 -0
  49. package/src/components/button/button.vue +316 -241
  50. package/src/components/chart/chart.core.js +378 -85
  51. package/src/components/chart/chart.vue +133 -115
  52. package/src/components/chart/element/element.bar.js +219 -25
  53. package/src/components/chart/element/element.bar.time.js +115 -0
  54. package/src/components/chart/element/element.line.js +172 -21
  55. package/src/components/chart/element/element.pie.js +86 -0
  56. package/src/components/chart/element/element.scatter.js +9 -2
  57. package/src/components/chart/element/element.tip.js +356 -0
  58. package/src/components/chart/helpers/helpers.canvas.js +94 -0
  59. package/src/components/chart/helpers/helpers.constant.js +25 -6
  60. package/src/components/chart/helpers/helpers.util.js +83 -38
  61. package/src/components/chart/index.js +0 -1
  62. package/src/components/chart/model/model.series.js +43 -14
  63. package/src/components/chart/model/model.store.js +440 -46
  64. package/src/components/chart/plugins/plugins.interaction.js +324 -0
  65. package/src/components/chart/plugins/plugins.legend.js +233 -91
  66. package/src/components/chart/plugins/plugins.pie.js +179 -0
  67. package/src/components/chart/plugins/plugins.title.js +25 -2
  68. package/src/components/chart/plugins/plugins.tooltip.js +384 -0
  69. package/src/components/chart/scale/scale.js +91 -29
  70. package/src/components/chart/scale/scale.linear.js +12 -0
  71. package/src/components/chart/scale/scale.logarithmic.js +25 -0
  72. package/src/components/chart/scale/scale.step.js +89 -52
  73. package/src/components/chart/scale/scale.time.category.js +204 -0
  74. package/src/components/chart/scale/scale.time.js +19 -1
  75. package/src/components/checkbox/checkbox-group.vue +15 -11
  76. package/src/components/checkbox/checkbox.vue +210 -138
  77. package/src/components/codeview/code.vue +42 -29
  78. package/src/components/contextmenu/contextmenu.child.vue +79 -0
  79. package/src/components/contextmenu/contextmenu.vue +276 -0
  80. package/src/components/contextmenu/contextmenu.wrap.vue +189 -0
  81. package/src/components/contextmenu/index.js +3 -0
  82. package/src/components/datepicker/calendar.core.js +588 -492
  83. package/src/components/datepicker/calendar.vue +0 -3
  84. package/src/components/datepicker/datepicker.vue +43 -15
  85. package/src/components/datepicker/index.js +5 -1
  86. package/src/components/grid/grid.filter.vue +290 -0
  87. package/src/components/grid/grid.filter.window.vue +411 -0
  88. package/src/components/grid/grid.render.vue +45 -0
  89. package/src/components/grid/grid.vue +1338 -0
  90. package/src/components/icon/icon.vue +22 -7
  91. package/src/components/input/input.number.vue +309 -277
  92. package/src/components/label/label.vue +2 -2
  93. package/src/components/loadingmask/loadingmask.vue +6 -13
  94. package/src/components/loginfield/loginfield.vue +46 -37
  95. package/src/components/markdown/index.js +3 -0
  96. package/src/components/markdown/markdown.vue +1001 -0
  97. package/src/components/menu/index.js +1 -3
  98. package/src/components/menu/menu.nav.item.vue +115 -0
  99. package/src/components/menu/menu.nav.sub.vue +42 -0
  100. package/src/components/menu/menu.nav.vue +71 -98
  101. package/src/components/message/index.js +3 -0
  102. package/src/components/message/message.js +63 -0
  103. package/src/components/message/message.vue +191 -0
  104. package/src/components/message-box/index.js +3 -0
  105. package/src/components/message-box/message-box.js +31 -0
  106. package/src/components/message-box/message-box.vue +298 -0
  107. package/src/components/notification/index.js +3 -0
  108. package/src/components/notification/notification.js +75 -0
  109. package/src/components/notification/notification.vue +242 -0
  110. package/src/components/radio/radio-group.vue +6 -2
  111. package/src/components/radio/radio.vue +156 -76
  112. package/src/components/selectbox/dropdown.vue +86 -40
  113. package/src/components/selectbox/listbox.vue +47 -18
  114. package/src/components/selectbox/option.vue +1 -1
  115. package/src/components/selectbox/selectbox.vue +304 -316
  116. package/src/components/slider/slider-tooltip.vue +7 -7
  117. package/src/components/slider/slider.vue +20 -25
  118. package/src/components/splitter/splitter.vue +104 -94
  119. package/src/components/table/table.black.css +1 -1
  120. package/src/components/table/table.filter.lite.vue +7 -7
  121. package/src/components/table/table.filter.vue +1 -1
  122. package/src/components/table/table.grey.css +5 -6
  123. package/src/components/table/table.navy.css +1 -1
  124. package/src/components/table/table.vue +55 -48
  125. package/src/components/tabs/tab-panel.vue +19 -5
  126. package/src/components/tabs/tabs.vue +182 -87
  127. package/src/components/textfield/textfield.vue +110 -87
  128. package/src/components/timepicker/index.js +2 -2
  129. package/src/components/timepicker/spinner.vue +15 -17
  130. package/src/components/timepicker/timepicker.vue +98 -53
  131. package/src/components/toggle/toggle.vue +148 -109
  132. package/src/components/tree/index.js +2 -6
  133. package/src/components/tree/render.js +17 -0
  134. package/src/components/tree/tree-node.vue +214 -0
  135. package/src/components/tree/tree.vue +296 -0
  136. package/src/components/tree-table/index.js +7 -0
  137. package/src/components/{tree → tree-table}/tree.table.black.css +0 -0
  138. package/src/components/{tree → tree-table}/tree.table.grey.css +0 -0
  139. package/src/components/{tree → tree-table}/tree.table.vue +36 -41
  140. package/src/components/{tree → tree-table}/tree.util.js +0 -0
  141. package/src/components/window/window.vue +238 -191
  142. package/src/index.js +25 -12
  143. package/src/styles/base/base.scss +50 -0
  144. package/src/styles/base/index.scss +1 -0
  145. package/src/styles/default.scss +5 -0
  146. package/src/styles/{codemirror.css → lib/codemirror.css} +0 -0
  147. package/src/styles/{all.css → lib/fontawesome.css} +1 -1
  148. package/src/styles/lib/icon.css +792 -0
  149. package/src/styles/themes/index.scss +2 -0
  150. package/src/styles/themes/mixin.scss +33 -0
  151. package/src/styles/themes/variables.scss +206 -0
  152. package/src/styles/utils/colors.scss +222 -0
  153. package/src/styles/utils/index.scss +2 -0
  154. package/src/styles/utils/mixins.scss +34 -0
  155. package/src/styles/utils/variables.scss +27 -0
  156. package/src/webfonts/EVUI.eot +0 -0
  157. package/src/webfonts/EVUI.svg +251 -173
  158. package/src/webfonts/EVUI.ttf +0 -0
  159. package/src/webfonts/EVUI.woff +0 -0
  160. package/src/webfonts/Roboto-Bold.ttf +0 -0
  161. package/src/webfonts/Roboto-Medium.ttf +0 -0
  162. package/src/webfonts/Roboto-Regular.ttf +0 -0
  163. package/dist/3c9453211570a4ede66a4b4954a32bbb.ttf +0 -0
  164. package/dist/8634884f932627fc43782e6963b64ccd.svg +0 -183
  165. package/dist/b9e64d9b5fa6b500eb5df6fa980d3e5b.eot +0 -0
  166. package/dist/f0ac0c8b3c9cd3ef9002749985ae546f.woff +0 -0
  167. package/src/components/chart/charts/chart.bar.js +0 -334
  168. package/src/components/chart/charts/chart.base.js +0 -1075
  169. package/src/components/chart/charts/chart.line.js +0 -262
  170. package/src/components/chart/charts/chart.pie.js +0 -383
  171. package/src/components/chart/charts/chart.scatter.js +0 -349
  172. package/src/components/chart/charts/chart.sunburst.js +0 -193
  173. package/src/components/chart/core/axis/axis.js +0 -217
  174. package/src/components/chart/core/axis/axis.scale.auto.js +0 -69
  175. package/src/components/chart/core/axis/axis.scale.fixed.js +0 -65
  176. package/src/components/chart/core/axis/axis.scale.steps.js +0 -149
  177. package/src/components/chart/core/core.constant.js +0 -116
  178. package/src/components/chart/core/core.legend.js +0 -473
  179. package/src/components/chart/core/core.util.js +0 -66
  180. package/src/components/chart/core/data/data.js +0 -412
  181. package/src/components/chart/core/data/data.pie.js +0 -70
  182. package/src/components/chart/core/data/data.stack.js +0 -222
  183. package/src/components/chart/core/data/data.sunburst.js +0 -172
  184. package/src/components/menu/menu.context.children.vue +0 -201
  185. package/src/components/menu/menu.context.vue +0 -144
  186. package/src/components/tabs/jun/tab.vue +0 -123
  187. package/src/components/tabs/jun/tabs.vue +0 -484
  188. package/src/styles/evui.css +0 -386
  189. package/src/styles/icon.css +0 -557
@@ -1,5 +1,3 @@
1
1
  import NavMenu from './menu.nav';
2
- import ContextMenu from './menu.context';
3
- import ContextMenuChildren from './menu.context.children';
4
2
 
5
- export { NavMenu, ContextMenu, ContextMenuChildren };
3
+ export default NavMenu;
@@ -0,0 +1,115 @@
1
+ <template>
2
+ <div
3
+ v-if="!hidden"
4
+ :class="{ first: depth === 1 }"
5
+ >
6
+ <div
7
+ :class="classes"
8
+ @click="onClick"
9
+ >
10
+ <ev-icon
11
+ v-if="firstIcon"
12
+ :cls="firstIcon"
13
+ style="margin-right: 5px;"
14
+ />
15
+ {{ name }}
16
+ <ev-icon
17
+ v-if="lastIcon"
18
+ :cls="lastIcon"
19
+ style="margin-left: auto;"
20
+ />
21
+ <template v-if="children.length">
22
+ <ev-icon
23
+ v-if="isExpanded"
24
+ :key="'down'"
25
+ :cls="'ei-s ei-arrow-down'"
26
+ style="margin-left: auto; opacity: .5;"
27
+ />
28
+ <ev-icon
29
+ v-else
30
+ :key="'up'"
31
+ :cls="'ei-s ei-arrow-up'"
32
+ style="margin-left: auto; opacity: .5;"
33
+ />
34
+ </template>
35
+ </div>
36
+ <template v-if="isExpanded">
37
+ <sub-menu
38
+ v-if="children.length"
39
+ :menu="children"
40
+ :depth="depth + 1"
41
+ :selected-name="selectedName"
42
+ @menu-click="onEmitClick"
43
+ />
44
+ </template>
45
+ </div>
46
+ </template>
47
+ <script>
48
+ export default {
49
+ components: {
50
+ SubMenu: () => import('./menu.nav.sub'),
51
+ },
52
+ props: {
53
+ name: {
54
+ type: String,
55
+ default: '',
56
+ },
57
+ firstIcon: {
58
+ type: String,
59
+ default: '',
60
+ },
61
+ lastIcon: {
62
+ type: String,
63
+ default: '',
64
+ },
65
+ children: {
66
+ type: Array,
67
+ default: () => [],
68
+ },
69
+ selectedName: {
70
+ type: String,
71
+ default: '',
72
+ },
73
+ active: {
74
+ type: Boolean,
75
+ default: true,
76
+ },
77
+ depth: {
78
+ type: Number,
79
+ default: 1,
80
+ },
81
+ hidden: {
82
+ type: Boolean,
83
+ default: false,
84
+ },
85
+ },
86
+ data() {
87
+ return {
88
+ isExpanded: true,
89
+ };
90
+ },
91
+ computed: {
92
+ classes() {
93
+ return {
94
+ 'ev-menu-item': true,
95
+ // bold: this.children.length,
96
+ first: this.depth === 1,
97
+ active: this.active,
98
+ selected: !this.children.length && this.name === this.selectedName,
99
+ };
100
+ },
101
+ },
102
+ methods: {
103
+ onClick() {
104
+ if (this.children.length) {
105
+ this.isExpanded = !this.isExpanded;
106
+ } else {
107
+ this.$emit('menu-click', this.name);
108
+ }
109
+ },
110
+ onEmitClick(name) {
111
+ this.$emit('menu-click', name);
112
+ },
113
+ },
114
+ };
115
+ </script>
@@ -0,0 +1,42 @@
1
+ <template>
2
+ <ul>
3
+ <li
4
+ v-for="menuItem in menu"
5
+ :key="menuItem.name"
6
+ class="ev-menu-sub"
7
+ >
8
+ <menu-item
9
+ v-bind="menuItem"
10
+ :depth="depth"
11
+ :selected-name="selectedName"
12
+ @menu-click="onClick"
13
+ />
14
+ </li>
15
+ </ul>
16
+ </template>
17
+ <script>
18
+ export default {
19
+ components: {
20
+ MenuItem: () => import('./menu.nav.item.vue'),
21
+ },
22
+ props: {
23
+ menu: {
24
+ type: Array,
25
+ default: () => [],
26
+ },
27
+ depth: {
28
+ type: Number,
29
+ default: 1,
30
+ },
31
+ selectedName: {
32
+ type: String,
33
+ default: '',
34
+ },
35
+ },
36
+ methods: {
37
+ onClick(selectedName) {
38
+ this.$emit('menu-click', selectedName);
39
+ },
40
+ },
41
+ };
42
+ </script>
@@ -1,123 +1,96 @@
1
1
  <template>
2
- <div class="evui-left-navigation">
3
- <ul class="evui-menu">
4
- <li
5
- v-for="(menu, index) in store"
6
- :key="menu.name + index"
7
- class="evui-menu-group"
8
- >
9
- <div
10
- class="evui-menu-group-title"
11
- >
12
- <i
13
- v-show="menu.cls"
14
- :class="menu.cls"
15
- /> {{ menu.name }}
16
- </div>
17
- <ul
18
- v-for="(submenu, index) in menu.children"
19
- v-show="menu.children"
20
- :key="submenu.name + index"
21
- class="evui-menu-group-sub"
22
- >
23
- <li
24
- :class="selectedMenu.name === submenu.name ? 'active' : ''"
25
- class="evui-menu-item"
26
- @click="setSelectedMenu(menu.name, submenu.name, index)"
27
- >
28
- {{ submenu.name }}
29
- </li>
30
- </ul>
31
- </li>
32
- </ul>
33
- </div>
2
+ <ul
3
+ :style="`width: ${width}`"
4
+ class="ev-menu"
5
+ >
6
+ <li
7
+ v-for="menuItem in menu"
8
+ :key="menuItem.name"
9
+ :class="{split: menuItem.hidden === true ? false : true, 'ev-menu-sub': true}"
10
+ >
11
+ <menu-item
12
+ v-bind="menuItem"
13
+ :depth="1"
14
+ :selected-name="value"
15
+ @menu-click="onClick"
16
+ />
17
+ </li>
18
+ </ul>
34
19
  </template>
35
-
36
20
  <script>
37
21
  export default {
38
- model: {
22
+ components: {
23
+ MenuItem: () => import('./menu.nav.item.vue'),
39
24
  },
40
25
  props: {
41
- store: {
26
+ menu: {
42
27
  type: Array,
43
28
  default: () => [],
44
29
  },
30
+ value: {
31
+ type: String,
32
+ default: '',
33
+ },
34
+ width: {
35
+ type: String,
36
+ default: '240px',
37
+ },
45
38
  },
46
39
  data() {
47
- return {
48
- selectedMenu: {
49
- parentName: '',
50
- name: '',
51
- index: '',
52
- },
53
- };
54
- },
55
- computed: {
40
+ return {};
56
41
  },
57
42
  methods: {
58
- initSelectedMenu() {
59
- this.selectedMenu.parentName = '';
60
- this.selectedMenu.name = '';
61
- this.selectedMenu.index = '';
62
- },
63
- setSelectedMenu(parentMenu, childMenu, childIndex) {
64
- this.selectedMenu.parentName = parentMenu;
65
- this.selectedMenu.name = childMenu;
66
- this.selectedMenu.index = childIndex;
43
+ onClick(selectedName) {
44
+ this.$emit('input', selectedName);
67
45
  },
68
46
  },
69
47
  };
70
48
  </script>
49
+ <style lang="scss">
50
+ @import '~@/styles/default';
71
51
 
72
- <style scoped>
73
- .evui-left-navigation {
74
- width: 240px;
75
- border-right: 1px solid #dddee0;
76
- }
77
- .evui-menu {
78
- display: block;
79
- width: 100%;
80
- background: #fff;
81
- z-index: 900;
52
+ .ev-menu {
53
+ @include evThemify() {
54
+ color: evThemed('menu-color');
55
+ }
82
56
  }
83
- .evui-menu-group {
84
- list-style-type: none;
85
- }
86
- .evui-menu-group-sub {
57
+
58
+ .ev-menu-sub {
87
59
  list-style-type: none;
60
+
61
+ @include evThemify() {
62
+ color: evThemed('menu-color');
63
+ }
64
+
65
+ &.split:not(:first-child) {
66
+ @include evThemify() {
67
+ padding-top: 18px;
68
+ border-top: 1px solid evThemed('menu-sub-split');
69
+ }
70
+ }
71
+
72
+ & > .first {
73
+ padding: 0 18px;
74
+ }
88
75
  }
89
- .evui-menu-group-title {
90
- height: 48px;
91
- line-height: 48px;
92
- padding-left: 20px;
93
- font-weight: bold;
76
+
77
+ .ev-menu-item {
78
+ display: flex;
79
+ align-items: center;
94
80
  user-select: none;
95
- }
96
- .evui-menu-group-title > i {
97
- margin-right: 10px;
98
- }
99
- .evui-menu-item {
100
- height: 35px;
101
- line-height: 35px;
102
- padding-left: 30px;
103
- border-right: 2px solid transparent;
104
- color: #888888;
105
- background-color: #ffffff;
106
- z-index: 1;
107
81
  cursor: pointer;
108
- }
109
- .evui-menu-item:hover {
110
- border-right: 4px solid #2D89EF;
111
- color: #2d8cf0;
112
- }
113
- .evui-menu-item.active {
114
- border-right: 4px solid #2D89EF;
115
- color: #f1f1f1;
116
- background-color: #2D89EF;
117
- transition: background-color 600ms ease;
118
- z-index: 2;
119
- }
120
- a:hover {
121
- color: #2D89EF;
82
+ list-style-type: none;
83
+ padding-bottom: 18px;
84
+ font-size: 13px;
85
+
86
+ &.first {
87
+ font-size: 16px;
88
+ }
89
+
90
+ &.selected {
91
+ @include evThemify() {
92
+ color: evThemed('menu-selected-bg');
93
+ }
94
+ }
122
95
  }
123
96
  </style>
@@ -0,0 +1,3 @@
1
+ import Message from './message';
2
+
3
+ export default Message;
@@ -0,0 +1,63 @@
1
+ import Vue from 'vue';
2
+ import MessageVue from './message.vue';
3
+
4
+ const MsgVue = Vue.extend(MessageVue);
5
+
6
+ let seq = 1;
7
+ const root = document.createElement('div');
8
+ root.classList.add('ev-message-root');
9
+ document.body.appendChild(root);
10
+
11
+ const messageManager = {
12
+ items: [],
13
+ increaseOffsetVal: 10,
14
+ boxHeight: 0,
15
+ lastOffset: {
16
+ x: 0,
17
+ y: 0,
18
+ },
19
+ getNextOffset() {
20
+ return {
21
+ x: this.lastOffset.x,
22
+ y: this.lastOffset.y,
23
+ };
24
+ },
25
+ pushItem(item) {
26
+ this.items.push(item);
27
+ if (this.boxHeight === 0) {
28
+ this.boxHeight = item.height + this.increaseOffsetVal;
29
+ }
30
+ this.lastOffset.y += this.boxHeight;
31
+ },
32
+ removeItem() {
33
+ this.lastOffset.y -= this.boxHeight;
34
+ },
35
+ onBeforeClosed() {
36
+ this.removeItem();
37
+ let el;
38
+ for (let ix = 0; ix < this.items.length; ix++) {
39
+ el = this.items[ix].$el;
40
+ el.style.top = `${parseInt(el.style.top, 10) - this.boxHeight}px`;
41
+ }
42
+ },
43
+ closeAll() {
44
+ for (let ix = 0; ix < this.items.length; ix++) {
45
+ this.items[ix].close();
46
+ }
47
+ },
48
+ };
49
+
50
+ export default function message(options = {}) {
51
+ const instance = new MsgVue({
52
+ data: options,
53
+ methods: {
54
+ onBeforeClosed: messageManager.onBeforeClosed.bind(messageManager),
55
+ },
56
+ });
57
+ instance.id = `ev-message-${seq++}`;
58
+ instance.$mount();
59
+ root.appendChild(instance.$el);
60
+ instance.visible = true;
61
+ messageManager.pushItem(instance);
62
+ instance.offset = messageManager.getNextOffset();
63
+ }
@@ -0,0 +1,191 @@
1
+ <template>
2
+ <transition
3
+ name="ev-message-fade"
4
+ @after-leave="onAfterLeave"
5
+ >
6
+ <div
7
+ v-show="visible"
8
+ :class="[
9
+ 'ev-message',
10
+ `ev-message-${ type }`,
11
+ center ? 'is-center' : '',
12
+ showClose ? 'is-closable' : '',
13
+ customClass
14
+ ]"
15
+ :style="positionStyle"
16
+ role="alert"
17
+ @mouseenter="clearTimer"
18
+ @mouseleave="startTimer"
19
+ >
20
+ <i
21
+ v-if="iconClass"
22
+ :class="iconClass"
23
+ />
24
+ <slot>
25
+ <p
26
+ v-if="!useHTMLString"
27
+ class="el-message-content"
28
+ >
29
+ {{ message }}
30
+ </p>
31
+ <p
32
+ v-else
33
+ class="el-message-content"
34
+ v-html="message"
35
+ />
36
+ </slot>
37
+ <i
38
+ v-if="showClose"
39
+ class="ei ei-close"
40
+ @click="close"
41
+ />
42
+ </div>
43
+ </transition>
44
+ </template>
45
+ <script>
46
+ // const typeMap = {
47
+ // info: 'info',
48
+ // success: 'success',
49
+ // warning: 'warning',
50
+ // error: 'error',
51
+ // };
52
+ export default {
53
+ data() {
54
+ return {
55
+ type: 'info',
56
+ visible: false,
57
+ height: 60,
58
+ offset: {
59
+ x: 0,
60
+ y: 0,
61
+ },
62
+ message: '',
63
+ duration: 3000,
64
+ iconClass: '',
65
+ customClass: '',
66
+ onClose: null,
67
+ showClose: false,
68
+ closed: false,
69
+ timer: null,
70
+ useHTMLString: false,
71
+ center: false,
72
+ };
73
+ },
74
+ computed: {
75
+ positionStyle() {
76
+ return {
77
+ top: `${this.offset.y}px`,
78
+ height: `${this.height}px`,
79
+ };
80
+ },
81
+ },
82
+ watch: {
83
+ closed(newVal) {
84
+ if (newVal) {
85
+ this.visible = false;
86
+ }
87
+ },
88
+ },
89
+ mounted() {
90
+ this.startTimer();
91
+ document.addEventListener('keydown', this.keydown);
92
+ },
93
+ beforeDestroy() {
94
+ document.removeEventListener('keydown', this.keydown);
95
+ },
96
+ methods: {
97
+ onAfterLeave() {
98
+ this.$destroy(true);
99
+ this.$el.parentNode.removeChild(this.$el);
100
+ },
101
+ close() {
102
+ this.closed = true;
103
+ if (this.onClose) {
104
+ this.onClose(this);
105
+ }
106
+ if (this.onBeforeClosed) {
107
+ this.onBeforeClosed(this);
108
+ }
109
+ },
110
+ clearTimer() {
111
+ clearTimeout(this.timer);
112
+ },
113
+ startTimer() {
114
+ if (this.duration > 0) {
115
+ this.timer = setTimeout(() => {
116
+ if (!this.closed) {
117
+ this.close();
118
+ }
119
+ }, this.duration);
120
+ }
121
+ },
122
+ keydown(e) {
123
+ if (e.keyCode === 27) {
124
+ if (!this.closed) {
125
+ this.close();
126
+ }
127
+ }
128
+ },
129
+ },
130
+ };
131
+ </script>
132
+ <style>
133
+ .ev-message-root {
134
+ position: absolute;
135
+ top: 0;
136
+ left: 0;
137
+ }
138
+ .ev-message {
139
+ display: flex;
140
+ position: fixed;
141
+ left: 50%;
142
+ top: 20px;
143
+ z-index: 900;
144
+ min-width: 380px;
145
+ padding: 15px 15px 15px 20px;
146
+ box-sizing: border-box;
147
+ border-radius: 4px;
148
+ border: 1px solid #EBEEF5;
149
+ background-color: #EDF2FC;
150
+ align-items: center;
151
+ overflow: hidden;
152
+ transform: translateX(-50%);
153
+ transition: opacity .3s, transform .3s, top .3s;
154
+ }
155
+ .ev-message-fade-enter,
156
+ .ev-message-fade-leave-active {
157
+ opacity: 0;
158
+ transform: translate(-50%, -100%);
159
+ }
160
+ .ev-message-info {
161
+ background-color: #FDFDFD;
162
+ border-color: #EEEEEE;
163
+ }
164
+ .ev-message-success {
165
+ background-color: #F0F9EB;
166
+ border-color: #E1F3D8;
167
+ }
168
+ .ev-message-warning {
169
+ background-color: #FDF6EC;
170
+ border-color: #FAECD8;
171
+ }
172
+ .ev-message-error {
173
+ background-color: #FEF0F0;
174
+ border-color: #FDE2E2;
175
+ }
176
+ .ev-message-info .el-message-content {
177
+ color: #111111;
178
+ }
179
+ .ev-message-success .el-message-content {
180
+ color: #67C23A;
181
+ }
182
+ .ev-message-warning .el-message-content {
183
+ color: #E6A23C;
184
+ }
185
+ .ev-message-error .el-message-content {
186
+ color: #F56C6C;
187
+ }
188
+ .el-message-content {
189
+ width: 100%;
190
+ }
191
+ </style>
@@ -0,0 +1,3 @@
1
+ import MessageBox from './message-box';
2
+
3
+ export default MessageBox;
@@ -0,0 +1,31 @@
1
+ import Vue from 'vue';
2
+ import MessageBoxVue from './message-box.vue';
3
+
4
+ const MsgVue = Vue.extend(MessageBoxVue);
5
+
6
+ const root = document.createElement('div');
7
+ root.classList.add('ev-message-box-root');
8
+ document.body.appendChild(root);
9
+
10
+ let instance;
11
+ export default function messageBox(options = {}) {
12
+ const dataOptions = Object.assign(
13
+ {
14
+ title: '',
15
+ message: '',
16
+ type: 'info',
17
+ onClosed: null,
18
+ },
19
+ options,
20
+ );
21
+
22
+ if (!instance) {
23
+ instance = new MsgVue({
24
+ data: dataOptions,
25
+ });
26
+ instance.$mount();
27
+ root.appendChild(instance.$el);
28
+ }
29
+ Object.assign(instance._data, dataOptions);
30
+ instance.visible = true;
31
+ }