n20-common-lib 1.1.98

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 (196) hide show
  1. package/README.md +27 -0
  2. package/package.json +87 -0
  3. package/src/_qiankun/index.js +113 -0
  4. package/src/_qiankun/postMessage.js +48 -0
  5. package/src/assets/css/_coreLib.scss +35 -0
  6. package/src/assets/css/cl-anchor.scss +24 -0
  7. package/src/assets/css/cl-approve-card.scss +58 -0
  8. package/src/assets/css/cl-dialog.scss +99 -0
  9. package/src/assets/css/cl-drag-list.scss +22 -0
  10. package/src/assets/css/cl-empty.scss +10 -0
  11. package/src/assets/css/cl-expandable-pane.scss +25 -0
  12. package/src/assets/css/cl-expandable.scss +23 -0
  13. package/src/assets/css/cl-file-upload-table.scss +11 -0
  14. package/src/assets/css/cl-filter.scss +4 -0
  15. package/src/assets/css/cl-flow-step.scss +186 -0
  16. package/src/assets/css/cl-footer-box.scss +10 -0
  17. package/src/assets/css/cl-form-item.scss +322 -0
  18. package/src/assets/css/cl-general-card.scss +12 -0
  19. package/src/assets/css/cl-layout-aside.scss +88 -0
  20. package/src/assets/css/cl-layout-content.scss +16 -0
  21. package/src/assets/css/cl-layout-header.scss +73 -0
  22. package/src/assets/css/cl-layout-tabs.scss +87 -0
  23. package/src/assets/css/cl-layout.scss +97 -0
  24. package/src/assets/css/cl-login-temporary.scss +37 -0
  25. package/src/assets/css/cl-message.scss +75 -0
  26. package/src/assets/css/cl-more-tab.scss +98 -0
  27. package/src/assets/css/cl-nav-menu.scss +5 -0
  28. package/src/assets/css/cl-pagination.scss +65 -0
  29. package/src/assets/css/cl-secondary-tab.scss +39 -0
  30. package/src/assets/css/cl-showcolumn.scss +23 -0
  31. package/src/assets/css/cl-sifting.scss +51 -0
  32. package/src/assets/css/cl-statis.scss +42 -0
  33. package/src/assets/css/cl-step.scss +73 -0
  34. package/src/assets/css/cl-suspend.scss +19 -0
  35. package/src/assets/css/cl-tertiary-tab.scss +9 -0
  36. package/src/assets/css/cl-upload.scss +41 -0
  37. package/src/assets/css/cl-worn-pagination.scss +50 -0
  38. package/src/assets/css/el-button.scss +169 -0
  39. package/src/assets/css/el-table.scss +79 -0
  40. package/src/assets/css/element-variables.scss +1061 -0
  41. package/src/assets/css/element.dev.scss +21 -0
  42. package/src/assets/css/font-icon.scss +26 -0
  43. package/src/assets/css/index.dev.scss +4 -0
  44. package/src/assets/css/index.scss +11 -0
  45. package/src/assets/css/normalize.scss +723 -0
  46. package/src/assets/css/rootvar.scss +139 -0
  47. package/src/assets/css/select.scss +26 -0
  48. package/src/assets/css/title-pop.scss +4 -0
  49. package/src/assets/getJsonc.js +50 -0
  50. package/src/assets/realUrl.js +12 -0
  51. package/src/components/Anchor/AnchorItem.vue +30 -0
  52. package/src/components/Anchor/index.vue +185 -0
  53. package/src/components/ApprovalButtons/index.vue +232 -0
  54. package/src/components/ApprovalCard/index.vue +128 -0
  55. package/src/components/ApprovalRecord/approvalImg.vue +39 -0
  56. package/src/components/ApprovalRecord/index.vue +59 -0
  57. package/src/components/Button/button-group.vue +150 -0
  58. package/src/components/Button/icon-group-button.vue +61 -0
  59. package/src/components/Button/index.vue +56 -0
  60. package/src/components/ContentLoading/index.vue +41 -0
  61. package/src/components/ContentNull/index.vue +19 -0
  62. package/src/components/DatePicker/index.vue +27 -0
  63. package/src/components/DatePicker/por.vue +169 -0
  64. package/src/components/Dialog/index.vue +26 -0
  65. package/src/components/Dialog/indexO.vue +116 -0
  66. package/src/components/DragList/index.vue +68 -0
  67. package/src/components/Empty/img/404.png +0 -0
  68. package/src/components/Empty/img/abnormal.svg +109 -0
  69. package/src/components/Empty/img/dispose.svg +72 -0
  70. package/src/components/Empty/img/empty.svg +58 -0
  71. package/src/components/Empty/img/general.svg +59 -0
  72. package/src/components/Empty/img/lock.svg +58 -0
  73. package/src/components/Empty/img/network.svg +60 -0
  74. package/src/components/Empty/img/relevant.svg +69 -0
  75. package/src/components/Empty/img/search.svg +73 -0
  76. package/src/components/Empty/index.vue +92 -0
  77. package/src/components/Expandable/index.vue +49 -0
  78. package/src/components/Expandable/main.vue +52 -0
  79. package/src/components/FileUploadTable/index.vue +484 -0
  80. package/src/components/Filters/index.vue +358 -0
  81. package/src/components/Filters/indexO.vue +104 -0
  82. package/src/components/FlowStep/index.vue +69 -0
  83. package/src/components/FooterBox/index.vue +21 -0
  84. package/src/components/GeneralCard/index.vue +15 -0
  85. package/src/components/InputNumber/index.vue +153 -0
  86. package/src/components/InputNumber/numberRange.vue +47 -0
  87. package/src/components/InputSearch/index.vue +75 -0
  88. package/src/components/Layout/AsideNav/index.vue +144 -0
  89. package/src/components/Layout/HeaderWrap/changePwd.vue +215 -0
  90. package/src/components/Layout/HeaderWrap/index.vue +336 -0
  91. package/src/components/Layout/HeaderWrap/noticePop.vue +300 -0
  92. package/src/components/Layout/SubContent/index.vue +131 -0
  93. package/src/components/Layout/TabsNav/index.vue +170 -0
  94. package/src/components/Layout/index.vue +529 -0
  95. package/src/components/Layout/utils.js +12 -0
  96. package/src/components/LoginTemporary/form.vue +511 -0
  97. package/src/components/LoginTemporary/index.vue +122 -0
  98. package/src/components/LoginTemporary/qr.png +0 -0
  99. package/src/components/LoginTemporary/qrcode.vue +90 -0
  100. package/src/components/LoginTemporary/qrt.png +0 -0
  101. package/src/components/LoginTemporary/retrievePw.vue +28 -0
  102. package/src/components/LoginTemporary/utils.js +73 -0
  103. package/src/components/MicroApp/index.js +67 -0
  104. package/src/components/MicroFrame/index.vue +95 -0
  105. package/src/components/MoreTab/index.vue +232 -0
  106. package/src/components/NavMenu/index.vue +60 -0
  107. package/src/components/NstcG6Components/NstcApprovel/NstcApprovel.vue +13 -0
  108. package/src/components/NstcG6Components/NstcDialog/NstcDialog.vue +185 -0
  109. package/src/components/NstcG6Components/Progress/progress.vue +134 -0
  110. package/src/components/PageLayout/page.vue +15 -0
  111. package/src/components/Pagination/index.vue +96 -0
  112. package/src/components/SecondaryTab/index.vue +58 -0
  113. package/src/components/SelectLazy/index.vue +75 -0
  114. package/src/components/SelectTree/SelectTreeLazy.vue +241 -0
  115. package/src/components/SelectTree/index.vue +208 -0
  116. package/src/components/ShowColumn/index.vue +188 -0
  117. package/src/components/Sifting/index.vue +99 -0
  118. package/src/components/Statis/index.vue +97 -0
  119. package/src/components/Statis/statisItem.vue +54 -0
  120. package/src/components/Statis/statisPopover.vue +55 -0
  121. package/src/components/Step/index.vue +38 -0
  122. package/src/components/Suspend/index.vue +72 -0
  123. package/src/components/Table/index.vue +131 -0
  124. package/src/components/Table/indexO.vue +149 -0
  125. package/src/components/Task/index.vue +26 -0
  126. package/src/components/TertiaryTab/index.vue +53 -0
  127. package/src/components/TimePicker/index.vue +28 -0
  128. package/src/components/Upload/index.vue +242 -0
  129. package/src/components/WornPagination/index.vue +73 -0
  130. package/src/directives/VClickOutside/index.js +19 -0
  131. package/src/directives/VDrag/index.js +72 -0
  132. package/src/directives/VHas/index.js +27 -0
  133. package/src/directives/VMove/index.js +42 -0
  134. package/src/directives/VTitle/index.js +56 -0
  135. package/src/directives/VTitle/tooltip.vue +21 -0
  136. package/src/index.js +225 -0
  137. package/src/plugins/CompatibleOld/index.js +57 -0
  138. package/src/plugins/Print/index.js +4 -0
  139. package/src/plugins/Print/print-js/.babelrc +12 -0
  140. package/src/plugins/Print/print-js/LICENSE +21 -0
  141. package/src/plugins/Print/print-js/README.md +98 -0
  142. package/src/plugins/Print/print-js/dist/print.css +97 -0
  143. package/src/plugins/Print/print-js/dist/print.js +991 -0
  144. package/src/plugins/Print/print-js/dist/print.map +1 -0
  145. package/src/plugins/Print/print-js/package.json +60 -0
  146. package/src/plugins/Print/print-js/src/index.d.ts +45 -0
  147. package/src/plugins/Print/print-js/src/index.js +10 -0
  148. package/src/plugins/Print/print-js/src/js/browser.js +33 -0
  149. package/src/plugins/Print/print-js/src/js/functions.js +103 -0
  150. package/src/plugins/Print/print-js/src/js/html.js +70 -0
  151. package/src/plugins/Print/print-js/src/js/image.js +48 -0
  152. package/src/plugins/Print/print-js/src/js/init.js +168 -0
  153. package/src/plugins/Print/print-js/src/js/json.js +109 -0
  154. package/src/plugins/Print/print-js/src/js/modal.js +62 -0
  155. package/src/plugins/Print/print-js/src/js/pdf.js +62 -0
  156. package/src/plugins/Print/print-js/src/js/print.js +102 -0
  157. package/src/plugins/Print/print-js/src/js/raw-html.js +15 -0
  158. package/src/plugins/Print/print-js/src/sass/index.scss +14 -0
  159. package/src/plugins/Print/print-js/src/sass/modules/_colors.scss +10 -0
  160. package/src/plugins/Print/print-js/src/sass/partials/_modal.scss +41 -0
  161. package/src/plugins/Print/print-js/src/sass/partials/_spinner.scss +46 -0
  162. package/src/plugins/Print/print.js +2 -0
  163. package/src/plugins/Print/print.scss +1 -0
  164. package/src/plugins/SetMenuTree/index.vue +41 -0
  165. package/src/plugins/SetMenuTree/logoIcon.vue +37 -0
  166. package/src/plugins/SetMenuTree/setmenutree.vue +427 -0
  167. package/src/plugins/SetMenuTree/utils.js +74 -0
  168. package/src/plugins/Sign/InfosecNetSignCNGAgent.min.js +2000 -0
  169. package/src/plugins/Sign/index.js +65 -0
  170. package/src/plugins/Sign/sign.js +1 -0
  171. package/src/plugins/setTabsForSub.js +2 -0
  172. package/src/utils/auth.js +53 -0
  173. package/src/utils/axios.js +203 -0
  174. package/src/utils/downloadBlob.js +19 -0
  175. package/src/utils/forEachs.js +16 -0
  176. package/src/utils/getScrollContainer.js +43 -0
  177. package/src/utils/i18n/cn2hk.json +1270 -0
  178. package/src/utils/i18n/index.js +54 -0
  179. package/src/utils/list2tree.js +36 -0
  180. package/src/utils/msgboxPor.js +26 -0
  181. package/src/utils/print.js +161 -0
  182. package/src/utils/relaNo.js +35 -0
  183. package/src/utils/repairElementUI.js +66 -0
  184. package/src/utils/urlToGo.js +82 -0
  185. package/style/css/normalize.scss +723 -0
  186. package/style/fonts/element-icons.535877f5.woff +0 -0
  187. package/style/fonts/element-icons.732389de.ttf +0 -0
  188. package/style/index.css +3 -0
  189. package/style/index.css.map +1 -0
  190. package/style/index.umd.min.js +2 -0
  191. package/style/index.umd.min.js.map +1 -0
  192. package/style/pageDemo/demo-1.vue +130 -0
  193. package/style/pageDemo/demo-2.vue +35 -0
  194. package/style/pageDemo/demo-3.vue +22 -0
  195. package/style/pageDemo/seeCode.js +20 -0
  196. package/style/server-config.jsonc +663 -0
@@ -0,0 +1,128 @@
1
+ /* 审批进度 */
2
+ <template>
3
+ <div class="n20-approve-wrap">
4
+ <el-timeline :reverse="true">
5
+ <el-timeline-item
6
+ v-for="(item, i) in approvalData"
7
+ :key="i"
8
+ :type="item | typeF(status)"
9
+ :hide-timestamp="true"
10
+ >
11
+ <div class="n20-time">
12
+ <div>{{ item.endTime | dataF }}</div>
13
+ <div>{{ item.endTime | timeF }}</div>
14
+ </div>
15
+ <div class="flex-box">
16
+ <div class="n20-worker m-r-s">
17
+ <span class="worker-icon cl-icon-user"></span>
18
+ <span>{{ item.assignee }}</span>
19
+ </div>
20
+ <div class="n20-approval m-r-s">
21
+ <template v-if="item.result == status.submit">提交</template>
22
+ <template v-else-if="item.result == status.end">结束</template>
23
+ <template v-else-if="item.result == status.approval">
24
+ 审批意见:批准
25
+ </template>
26
+ <template v-else-if="item.result == status.reject">
27
+ 审批意见:<span class="n20-approval-reject">驳回</span></template
28
+ >
29
+ </div>
30
+ <div v-if="item.suggestion" class="n20-description-c flex-item">
31
+ {{ item.suggestion }}
32
+ </div>
33
+ </div>
34
+ </el-timeline-item>
35
+ </el-timeline>
36
+ </div>
37
+ </template>
38
+
39
+ <script>
40
+ import axios from '../../utils/axios'
41
+ export default {
42
+ name: 'ApproveCard',
43
+ filters: {
44
+ typeF(item, status) {
45
+ let result = item.result
46
+ switch (result) {
47
+ case status.submit:
48
+ return 'primary'
49
+ case status.approval:
50
+ return 'primary'
51
+ case status.reject:
52
+ return 'danger'
53
+ default:
54
+ return undefined
55
+ }
56
+ },
57
+ dataF(_t) {
58
+ let t = _t || ''
59
+ let ts = t.split(' ') || ['', '']
60
+ return ts[0]
61
+ },
62
+ timeF(_t) {
63
+ let t = _t || ''
64
+ let ts = t.split(' ') || ['', '']
65
+ return ts[1]
66
+ }
67
+ },
68
+ props: {
69
+ close: {
70
+ type: Boolean,
71
+ default: false
72
+ },
73
+ status: {
74
+ type: Object,
75
+ default: () => ({
76
+ waiting: 0,
77
+ submit: 1,
78
+ approval: 2,
79
+ reject: 3,
80
+ end: 4
81
+ })
82
+ },
83
+ approvalData: {
84
+ type: Array,
85
+ default: () => []
86
+ },
87
+ procInstId: {
88
+ type: String,
89
+ default: undefined
90
+ }
91
+ },
92
+ created() {
93
+ if (this.procInstId) {
94
+ axios
95
+ .get('/bems/activiti/sample/Q003', {
96
+ procInstId: this.procInstId
97
+ })
98
+ .then(({ data = [] }) => {
99
+ let approvalData = []
100
+ data.forEach((item) => {
101
+ let _item = {
102
+ endTime: item.endTime || '',
103
+ assignee: item.assignee,
104
+ suggestion: item.suggestion
105
+ }
106
+ if ('approvalState' in item) {
107
+ _item.result = item.approvalState
108
+ } else {
109
+ if (item.taskName === '开始') {
110
+ _item.result = 1
111
+ } else if (item.taskName === '结束') {
112
+ _item.result = 4
113
+ } else if (!item.endTime) {
114
+ _item.result = 0
115
+ } else if (item.rejectFlag === 1) {
116
+ _item.result = 3
117
+ } else {
118
+ _item.result = 2
119
+ }
120
+ }
121
+ approvalData.push(_item)
122
+ })
123
+ this.approvalData.push(...approvalData)
124
+ })
125
+ }
126
+ }
127
+ }
128
+ </script>
@@ -0,0 +1,39 @@
1
+ /* 审批流程图 */
2
+ <template>
3
+ <div class="approve-img">
4
+ <img v-if="blobUrl" :src="blobUrl" />
5
+ </div>
6
+ </template>
7
+
8
+ <script>
9
+ import axios from '../../utils/axios'
10
+
11
+ export default {
12
+ name: 'ApprovalImg',
13
+ props: {
14
+ // blobUrl: {
15
+ // type: String,
16
+ // default: undefined
17
+ // }
18
+ },
19
+ data() {
20
+ return {
21
+ blobUrl: undefined
22
+ }
23
+ },
24
+ created() {
25
+ axios
26
+ .get('/bems/activiti/sample/Q004', {
27
+ procInstId: this.$route.query.processInstanceId
28
+ })
29
+ .then(({ data }) => {
30
+ if (data) {
31
+ let file = new File([data], '流程图.svg', {
32
+ type: 'image/svg+xml'
33
+ })
34
+ this.blobUrl = URL.createObjectURL(file)
35
+ }
36
+ })
37
+ }
38
+ }
39
+ </script>
@@ -0,0 +1,59 @@
1
+ /* 审批记录 */
2
+ <template>
3
+ <div>
4
+ <expandableWrap title="审批记录" :show-expand="false">
5
+ <template slot="tips">
6
+ <el-button plain size="mini" :disabled="false" @click="cardV = true"
7
+ >审批进度查看</el-button
8
+ >
9
+ <el-button plain size="mini" :disabled="false" @click="imgV = true"
10
+ >流程图查看</el-button
11
+ >
12
+ </template>
13
+ </expandableWrap>
14
+ <el-dialog
15
+ title="审批记录"
16
+ :visible.sync="cardV"
17
+ width="700"
18
+ class="p-a-0"
19
+ append-to-body
20
+ top="10vh"
21
+ >
22
+ <approvalCard
23
+ class="p-a"
24
+ :proc-inst-id="$route.query.processInstanceId"
25
+ style="height: 70vh; overflow: auto"
26
+ />
27
+ </el-dialog>
28
+ <el-dialog
29
+ title="查看流程"
30
+ :visible.sync="imgV"
31
+ width="65%"
32
+ class="p-a-0"
33
+ append-to-body
34
+ top="10vh"
35
+ >
36
+ <approvalImg class="text-c p-a" style="height: 70vh; overflow: auto" />
37
+ </el-dialog>
38
+ </div>
39
+ </template>
40
+
41
+ <script>
42
+ import expandableWrap from '../Expandable/index.vue'
43
+ import approvalCard from '../ApprovalCard/index.vue'
44
+ import approvalImg from './approvalImg.vue'
45
+ export default {
46
+ name: 'ApprovalRecord',
47
+ components: {
48
+ expandableWrap,
49
+ approvalCard,
50
+ approvalImg
51
+ },
52
+ data() {
53
+ return {
54
+ cardV: false,
55
+ imgV: false
56
+ }
57
+ }
58
+ }
59
+ </script>
@@ -0,0 +1,150 @@
1
+ <template>
2
+ <div class="text-c m-t">
3
+ <el-button
4
+ v-for="item in btns"
5
+ :key="item.label"
6
+ :type="item.type"
7
+ :plain="item.plain"
8
+ size="small"
9
+ @click="$emit(item.emit)"
10
+ >{{ item.label }}</el-button
11
+ >
12
+ </div>
13
+ </template>
14
+
15
+ <script>
16
+ export default {
17
+ name: 'ButtonGroup',
18
+ props: {
19
+ include: {
20
+ type: Array,
21
+ default: () => ['back']
22
+ }
23
+ },
24
+ computed: {
25
+ btns() {
26
+ let btns = []
27
+ let btnt = this.include || []
28
+ if (btnt.includes('back')) {
29
+ btns.push({ emit: 'back', label: '返回', plain: true })
30
+ }
31
+
32
+ if (btnt.includes('preStep')) {
33
+ btns.push({
34
+ emit: 'preStep',
35
+ label: '上一步',
36
+ type: 'primary',
37
+ plain: false
38
+ })
39
+ }
40
+
41
+ if (btnt.includes('refuse')) {
42
+ btns.push({ emit: 'refuse', label: '驳回', plain: true })
43
+ }
44
+
45
+ if (btnt.includes('copy')) {
46
+ btns.push({ emit: 'copy', label: '复制', plain: true })
47
+ }
48
+
49
+ if (btnt.includes('rejected')) {
50
+ btns.push({ emit: 'rejected', label: '拒绝', plain: true })
51
+ }
52
+
53
+ if (btnt.includes('pass')) {
54
+ btns.push({
55
+ emit: 'pass',
56
+ label: '通过',
57
+ type: 'primary',
58
+ plain: false
59
+ })
60
+ }
61
+
62
+ if (btnt.includes('agree')) {
63
+ btns.push({
64
+ emit: 'agree',
65
+ label: '同意',
66
+ type: 'primary',
67
+ plain: false
68
+ })
69
+ }
70
+
71
+ if (btnt.includes('reset')) {
72
+ btns.push({
73
+ emit: 'reset',
74
+ label: '重置',
75
+ type: 'warning',
76
+ plain: true
77
+ })
78
+ }
79
+
80
+ if (btnt.includes('stash')) {
81
+ btns.push({
82
+ emit: 'stash',
83
+ label: '暂存',
84
+ type: 'primary',
85
+ plain: true
86
+ })
87
+ }
88
+
89
+ if (btnt.includes('save')) {
90
+ btns.push({
91
+ emit: 'save',
92
+ label: '保存',
93
+ type: 'primary',
94
+ plain: false
95
+ })
96
+ }
97
+
98
+ if (btnt.includes('submit')) {
99
+ btns.push({
100
+ emit: 'submit',
101
+ label: '提交',
102
+ type: 'primary',
103
+ plain: false
104
+ })
105
+ }
106
+
107
+ if (btnt.includes('fileInfo')) {
108
+ btns.push({ emit: 'fileInfo', label: '附件信息', plain: true })
109
+ }
110
+
111
+ if (btnt.includes('information')) {
112
+ btns.push({ emit: 'information', label: '附件信息', plain: true })
113
+ }
114
+
115
+ if (btnt.includes('print')) {
116
+ btns.push({
117
+ emit: 'print',
118
+ label: '打印',
119
+ type: 'primary',
120
+ plain: false
121
+ })
122
+ }
123
+
124
+ if (btnt.includes('nextStep')) {
125
+ btns.push({
126
+ emit: 'nextStep',
127
+ label: '下一步',
128
+ type: 'primary',
129
+ plain: false
130
+ })
131
+ }
132
+
133
+ if (btnt.includes('orderCancel')) {
134
+ btns.push({
135
+ emit: 'orderCancel',
136
+ label: '预约取消',
137
+ type: 'warning',
138
+ plain: true
139
+ })
140
+ }
141
+
142
+ if (btnt.includes('cancle')) {
143
+ btns.push({ emit: 'cancle', label: '取消', plain: true })
144
+ }
145
+
146
+ return btns
147
+ }
148
+ }
149
+ }
150
+ </script>
@@ -0,0 +1,61 @@
1
+ <template>
2
+ <el-button-group class="n20-icon-group-button">
3
+ <el-button
4
+ :icon="leftIcon"
5
+ :plain="left === 'default'"
6
+ :type="left"
7
+ size="mini"
8
+ style="width: 31.5px"
9
+ @click="handleClick(active)"
10
+ />
11
+ <el-button
12
+ :icon="rightIcon"
13
+ :plain="right === 'default'"
14
+ :type="right"
15
+ size="mini"
16
+ style="width: 31.5px"
17
+ @click="handleClick(!active)"
18
+ />
19
+ </el-button-group>
20
+ </template>
21
+
22
+ <script>
23
+ export default {
24
+ name: 'IconGroupButton',
25
+ props: {
26
+ leftIcon: {
27
+ type: String,
28
+ default: 'n20-icon-a-quanjiedianxuanzhong'
29
+ },
30
+ rightIcon: {
31
+ type: String,
32
+ default: 'n20-icon-zishenbanlijiedian'
33
+ },
34
+ active: {
35
+ type: Boolean,
36
+ default: true
37
+ }
38
+ },
39
+ data() {
40
+ return {
41
+ left: 'default',
42
+ right: 'default'
43
+ }
44
+ },
45
+ mounted() {
46
+ this.handleClick(this.active)
47
+ },
48
+ methods: {
49
+ handleClick(t) {
50
+ this.$emit('click', t)
51
+ if (t) {
52
+ this.left = 'primary'
53
+ this.right = 'default'
54
+ } else {
55
+ this.left = 'default'
56
+ this.right = 'primary'
57
+ }
58
+ }
59
+ }
60
+ }
61
+ </script>
@@ -0,0 +1,56 @@
1
+ <template>
2
+ <el-button
3
+ :type="oType"
4
+ :plain="plain"
5
+ :disabled="disabled"
6
+ v-bind="$attrs"
7
+ v-on="$listeners"
8
+ >
9
+ <slot></slot>
10
+ </el-button>
11
+ </template>
12
+
13
+ <script>
14
+ export default {
15
+ name: 'Button',
16
+ props: {
17
+ type: {
18
+ type: String,
19
+ default: 'primary',
20
+ validator(v) {
21
+ return ['default', 'primary', 'info', 'danger', 'warning'].includes(v)
22
+ }
23
+ },
24
+ disabled: {
25
+ type: Boolean,
26
+ default: false
27
+ }
28
+ },
29
+ computed: {
30
+ oType() {
31
+ switch (this.type) {
32
+ case 'default':
33
+ case 'primary':
34
+ return 'primary'
35
+ case 'info':
36
+ return undefined
37
+ case 'danger':
38
+ return 'danger'
39
+ case 'warning':
40
+ return 'warning'
41
+ default:
42
+ return 'primary'
43
+ }
44
+ },
45
+ plain() {
46
+ switch (this.type) {
47
+ case 'default':
48
+ case 'primary':
49
+ return false
50
+ default:
51
+ return true
52
+ }
53
+ }
54
+ }
55
+ }
56
+ </script>
@@ -0,0 +1,41 @@
1
+ <template>
2
+ <div v-loading="loading" :element-loading-text="loadingText"></div>
3
+ </template>
4
+
5
+ <script>
6
+ export default {
7
+ name: 'ContentLoading',
8
+ data() {
9
+ return {
10
+ loading: true,
11
+ loadingText: '加载中',
12
+ timeout: 12000
13
+ }
14
+ },
15
+ mounted() {
16
+ this.setTimeOut()
17
+ },
18
+ activated() {
19
+ this.setTimeOut()
20
+ },
21
+ deactivated() {
22
+ this.clearTimeOut()
23
+ },
24
+ beforeDestroy() {
25
+ this.clearTimeOut()
26
+ },
27
+ methods: {
28
+ setTimeOut() {
29
+ clearTimeout(this.sT)
30
+
31
+ this.sT = setTimeout(() => {
32
+ this.loadingText = '请求超时,请刷新尝试'
33
+ }, this.timeout)
34
+ },
35
+ clearTimeOut() {
36
+ this.loadingText = '加载中'
37
+ clearTimeout(this.sT)
38
+ }
39
+ }
40
+ }
41
+ </script>
@@ -0,0 +1,19 @@
1
+ <template>
2
+ <empty-box type="404">
3
+ <div slot="content">暂无访问权限</div>
4
+ </empty-box>
5
+ </template>
6
+
7
+ <script>
8
+ import EmptyBox from '../Empty/index.vue'
9
+ export default {
10
+ name: 'ContentNull',
11
+ components: {
12
+ EmptyBox
13
+ },
14
+ data() {
15
+ this.isNull = true
16
+ return {}
17
+ }
18
+ }
19
+ </script>
@@ -0,0 +1,27 @@
1
+ <template>
2
+ <el-date-picker
3
+ ref="date-picker"
4
+ class="n20-date-editor"
5
+ :class="{ 'has-value': clearable && value }"
6
+ v-bind="$attrs"
7
+ :value="value"
8
+ :clearable="clearable"
9
+ v-on="$listeners"
10
+ />
11
+ </template>
12
+
13
+ <script>
14
+ export default {
15
+ name: 'DatePicker',
16
+ props: {
17
+ value: {
18
+ type: [String, Number, Date],
19
+ default: undefined
20
+ },
21
+ clearable: {
22
+ type: Boolean,
23
+ default: true
24
+ }
25
+ }
26
+ }
27
+ </script>