eoss-ui 0.7.93 → 0.7.94

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 (319) hide show
  1. package/lib/calogin.js +233 -233
  2. package/lib/eoss-ui.common.js +921 -920
  3. package/lib/flow-list.js +96 -96
  4. package/lib/flow.js +285 -284
  5. package/lib/index.js +1 -1
  6. package/lib/main.js +288 -288
  7. package/lib/qr-code.js +13 -13
  8. package/package.json +1 -1
  9. package/packages/button/index.js +5 -5
  10. package/packages/button/src/main.vue +418 -418
  11. package/packages/button-group/index.js +5 -5
  12. package/packages/button-group/src/main.vue +346 -346
  13. package/packages/calendar/index.js +5 -5
  14. package/packages/calogin/index.js +5 -5
  15. package/packages/calogin/src/main.vue +412 -412
  16. package/packages/calogin/src/plugin.js +915 -915
  17. package/packages/card/index.js +5 -5
  18. package/packages/card/src/main.vue +156 -156
  19. package/packages/cascader/index.js +5 -5
  20. package/packages/cascader/src/main.vue +168 -168
  21. package/packages/checkbox-group/index.js +5 -5
  22. package/packages/checkbox-group/src/main.vue +333 -333
  23. package/packages/clients/index.js +5 -5
  24. package/packages/clients/src/main.vue +151 -151
  25. package/packages/data-table/index.js +5 -5
  26. package/packages/data-table/src/children.vue +39 -39
  27. package/packages/data-table/src/main.vue +1845 -1845
  28. package/packages/data-table/src/sizer.vue +195 -195
  29. package/packages/data-table-form/index.js +5 -5
  30. package/packages/data-table-form/src/checkbox.vue +101 -101
  31. package/packages/data-table-form/src/colgroup.vue +17 -17
  32. package/packages/data-table-form/src/main.vue +181 -181
  33. package/packages/data-table-form/src/radio.vue +65 -65
  34. package/packages/data-table-form/src/table.vue +233 -233
  35. package/packages/data-table-form/src/tbody.vue +336 -336
  36. package/packages/data-table-form/src/thead.vue +68 -68
  37. package/packages/date-picker/index.js +5 -5
  38. package/packages/date-picker/src/main.vue +236 -236
  39. package/packages/dialog/index.js +5 -5
  40. package/packages/enable-drag/index.js +5 -5
  41. package/packages/enterprise/index.js +5 -5
  42. package/packages/enterprise/src/main.vue +66 -66
  43. package/packages/error-page/index.js +5 -5
  44. package/packages/error-page/src/main.vue +44 -44
  45. package/packages/flow/index.js +5 -5
  46. package/packages/flow/src/component/Circulate.vue +417 -417
  47. package/packages/flow/src/component/CommonOpinions.vue +376 -376
  48. package/packages/flow/src/component/CustomPreset.vue +324 -324
  49. package/packages/flow/src/component/FileList.vue +97 -97
  50. package/packages/flow/src/component/FreeCirculation.vue +244 -244
  51. package/packages/flow/src/component/Preset.vue +257 -257
  52. package/packages/flow/src/component/SendMsg.vue +242 -242
  53. package/packages/flow/src/component/SortFlow.vue +110 -110
  54. package/packages/flow/src/component/TimeLimit.vue +190 -190
  55. package/packages/flow/src/component/taskUnionExamine.vue +761 -761
  56. package/packages/flow/src/form.vue +123 -123
  57. package/packages/flow/src/freeStartFlow.vue +2855 -2855
  58. package/packages/flow/src/main.vue +4144 -4144
  59. package/packages/flow/src/processForm.vue +1680 -1680
  60. package/packages/flow/src/processReject.vue +309 -309
  61. package/packages/flow/src/reset.vue +946 -946
  62. package/packages/flow/src/startTaskRead.vue +695 -695
  63. package/packages/flow/src/supervise.vue +159 -159
  64. package/packages/flow/src/table.vue +58 -58
  65. package/packages/flow-group/index.js +5 -5
  66. package/packages/flow-group/src/main.vue +750 -750
  67. package/packages/flow-list/index.js +5 -5
  68. package/packages/flow-list/src/main.vue +2337 -2337
  69. package/packages/form/index.js +5 -5
  70. package/packages/form/src/main.vue +3901 -3901
  71. package/packages/form/src/table.vue +1512 -1512
  72. package/packages/handle-user/index.js +5 -5
  73. package/packages/handle-user/src/main.vue +137 -137
  74. package/packages/handler/index.js +5 -5
  75. package/packages/handler/src/main.vue +499 -499
  76. package/packages/icon/index.js +5 -5
  77. package/packages/icon/src/main.vue +104 -104
  78. package/packages/icons/index.js +5 -5
  79. package/packages/icons/src/main.vue +81 -81
  80. package/packages/input/index.js +5 -5
  81. package/packages/input/src/main.vue +356 -356
  82. package/packages/input-number/index.js +5 -5
  83. package/packages/input-number/src/main.vue +106 -106
  84. package/packages/label/index.js +5 -5
  85. package/packages/label/src/main.vue +457 -457
  86. package/packages/layout/index.js +5 -5
  87. package/packages/layout/src/item.vue +152 -152
  88. package/packages/layout/src/main.vue +31 -31
  89. package/packages/login/index.js +5 -5
  90. package/packages/login/src/main.vue +2088 -2088
  91. package/packages/login/src/resetPassword.vue +557 -557
  92. package/packages/main/index.js +5 -5
  93. package/packages/main/src/default/message.vue +249 -249
  94. package/packages/main/src/default/notice.vue +157 -157
  95. package/packages/main/src/default/userinfo.vue +513 -513
  96. package/packages/main/src/public/online.vue +89 -89
  97. package/packages/main/src/public/search.vue +464 -464
  98. package/packages/main/src/public/settings.vue +273 -273
  99. package/packages/main/src/simplicity/apps.vue +388 -388
  100. package/packages/main/src/simplicity/avatar.vue +82 -82
  101. package/packages/main/src/simplicity/handler.vue +158 -158
  102. package/packages/main/src/simplicity/index.vue +2335 -2335
  103. package/packages/main/src/simplicity/lists.vue +84 -84
  104. package/packages/main/src/simplicity/menu-list.vue +135 -135
  105. package/packages/main/src/simplicity/message.vue +293 -293
  106. package/packages/main/src/simplicity/notice.vue +222 -222
  107. package/packages/main/src/simplicity/router-page.vue +45 -45
  108. package/packages/main/src/simplicity/sub-menu.vue +276 -276
  109. package/packages/main/src/simplicity/user.vue +259 -259
  110. package/packages/main/src/simplicity/userinfo.vue +408 -408
  111. package/packages/main/src/simplicityTop/apps.vue +388 -388
  112. package/packages/main/src/simplicityTop/avatar.vue +82 -82
  113. package/packages/main/src/simplicityTop/handler.vue +215 -215
  114. package/packages/main/src/simplicityTop/index.vue +2620 -2620
  115. package/packages/main/src/simplicityTop/lists.vue +84 -84
  116. package/packages/main/src/simplicityTop/menu-list.vue +135 -135
  117. package/packages/main/src/simplicityTop/message.vue +293 -293
  118. package/packages/main/src/simplicityTop/notice.vue +222 -222
  119. package/packages/main/src/simplicityTop/router-page.vue +45 -45
  120. package/packages/main/src/simplicityTop/sub-menu.vue +274 -274
  121. package/packages/main/src/simplicityTop/user.vue +259 -259
  122. package/packages/main/src/simplicityTop/userinfo.vue +408 -408
  123. package/packages/menu/index.js +5 -5
  124. package/packages/menu/src/main.vue +595 -595
  125. package/packages/nav/index.js +5 -5
  126. package/packages/nav/src/main.vue +351 -351
  127. package/packages/notify/index.js +5 -5
  128. package/packages/notify/src/main.vue +538 -538
  129. package/packages/page/index.js +5 -5
  130. package/packages/page/src/main.vue +167 -167
  131. package/packages/pagination/index.js +5 -5
  132. package/packages/pagination/src/main.vue +96 -96
  133. package/packages/player/index.js +5 -5
  134. package/packages/player/src/main.vue +194 -194
  135. package/packages/qr-code/index.js +5 -5
  136. package/packages/qr-code/src/main.vue +170 -170
  137. package/packages/radio-group/index.js +6 -6
  138. package/packages/radio-group/src/main.vue +319 -319
  139. package/packages/retrial-auth/index.js +5 -5
  140. package/packages/retrial-auth/src/main.vue +299 -299
  141. package/packages/select/index.js +5 -5
  142. package/packages/select-ganged/index.js +5 -5
  143. package/packages/select-ganged/src/main.vue +724 -724
  144. package/packages/selector/index.js +5 -5
  145. package/packages/selector/src/main.vue +761 -761
  146. package/packages/selector-panel/index.js +5 -5
  147. package/packages/selector-panel/src/main.vue +1036 -1036
  148. package/packages/selector-panel/src/selection.vue +174 -174
  149. package/packages/selector-panel/src/tree.vue +129 -129
  150. package/packages/sizer/index.js +5 -5
  151. package/packages/sizer/src/main.vue +254 -254
  152. package/packages/steps/index.js +5 -5
  153. package/packages/steps/src/main.vue +181 -181
  154. package/packages/switch/index.js +5 -5
  155. package/packages/switch/src/main.vue +170 -170
  156. package/packages/table-form/index.js +5 -5
  157. package/packages/tabs/index.js +5 -5
  158. package/packages/tabs/src/main.vue +788 -788
  159. package/packages/tabs-panel/index.js +5 -5
  160. package/packages/tabs-panel/src/main.vue +29 -29
  161. package/packages/theme-chalk/gulpfile.js +25 -0
  162. package/packages/theme-chalk/src/base.scss +261 -261
  163. package/packages/theme-chalk/src/button-group.scss +176 -176
  164. package/packages/theme-chalk/src/button.scss +24 -24
  165. package/packages/theme-chalk/src/calendar.scss +113 -113
  166. package/packages/theme-chalk/src/card.scss +99 -99
  167. package/packages/theme-chalk/src/checkbox-group.scss +8 -8
  168. package/packages/theme-chalk/src/clients.scss +87 -87
  169. package/packages/theme-chalk/src/data-table-form.scss +67 -67
  170. package/packages/theme-chalk/src/data-table.scss +297 -297
  171. package/packages/theme-chalk/src/date-picker.scss +7 -7
  172. package/packages/theme-chalk/src/dialog.scss +77 -77
  173. package/packages/theme-chalk/src/enable-drag.scss +181 -181
  174. package/packages/theme-chalk/src/enterprise.scss +5 -5
  175. package/packages/theme-chalk/src/error-page.scss +18 -18
  176. package/packages/theme-chalk/src/flow-group.scss +110 -110
  177. package/packages/theme-chalk/src/flow-list.scss +55 -55
  178. package/packages/theme-chalk/src/flow.scss +373 -373
  179. package/packages/theme-chalk/src/form.scss +501 -501
  180. package/packages/theme-chalk/src/handle-user.scss +40 -40
  181. package/packages/theme-chalk/src/handler.scss +148 -148
  182. package/packages/theme-chalk/src/icon.scss +3452 -3452
  183. package/packages/theme-chalk/src/icons.scss +99 -99
  184. package/packages/theme-chalk/src/input.scss +9 -9
  185. package/packages/theme-chalk/src/label.scss +24 -24
  186. package/packages/theme-chalk/src/layout.scss +46 -46
  187. package/packages/theme-chalk/src/login.scss +1006 -1006
  188. package/packages/theme-chalk/src/main.scss +664 -664
  189. package/packages/theme-chalk/src/menu.scss +224 -224
  190. package/packages/theme-chalk/src/mixins/color.scss +117 -117
  191. package/packages/theme-chalk/src/nav.scss +111 -111
  192. package/packages/theme-chalk/src/page.scss +3 -3
  193. package/packages/theme-chalk/src/pagination.scss +29 -29
  194. package/packages/theme-chalk/src/player.scss +9 -9
  195. package/packages/theme-chalk/src/qr-code.scss +17 -17
  196. package/packages/theme-chalk/src/radio-group.scss +9 -9
  197. package/packages/theme-chalk/src/retrial-auth.scss +38 -38
  198. package/packages/theme-chalk/src/select-ganged.scss +8 -8
  199. package/packages/theme-chalk/src/select.scss +8 -8
  200. package/packages/theme-chalk/src/selector-panel.scss +204 -204
  201. package/packages/theme-chalk/src/selector.scss +114 -114
  202. package/packages/theme-chalk/src/simplicity-top.scss +1845 -1845
  203. package/packages/theme-chalk/src/simplicity.scss +1403 -1403
  204. package/packages/theme-chalk/src/sizer.scss +36 -36
  205. package/packages/theme-chalk/src/steps.scss +88 -88
  206. package/packages/theme-chalk/src/switch.scss +3 -3
  207. package/packages/theme-chalk/src/table-form.scss +1 -1
  208. package/packages/theme-chalk/src/tabs.scss +87 -87
  209. package/packages/theme-chalk/src/tips.scss +7 -7
  210. package/packages/theme-chalk/src/toolbar.scss +179 -179
  211. package/packages/theme-chalk/src/tree-group.scss +72 -72
  212. package/packages/theme-chalk/src/tree.scss +165 -165
  213. package/packages/theme-chalk/src/upload.scss +172 -172
  214. package/packages/theme-chalk/src/wxlogin.scss +3 -3
  215. package/packages/tips/index.js +5 -5
  216. package/packages/tips/src/main.vue +141 -141
  217. package/packages/toolbar/index.js +5 -5
  218. package/packages/toolbar/src/main.vue +430 -430
  219. package/packages/tree/index.js +5 -5
  220. package/packages/tree-group/index.js +5 -5
  221. package/packages/upload/index.js +5 -5
  222. package/packages/upload/src/main.vue +1344 -1344
  223. package/packages/upload/src/picture.js +15 -15
  224. package/packages/wujie/index.js +5 -5
  225. package/packages/wujie/src/main.vue +146 -146
  226. package/packages/wxlogin/index.js +5 -5
  227. package/packages/wxlogin/src/main.vue +128 -128
  228. package/src/config/api.js +348 -348
  229. package/src/config/image.js +2 -2
  230. package/src/index.js +163 -163
  231. package/src/utils/bus.js +3 -3
  232. package/src/utils/date-util.js +312 -312
  233. package/src/utils/http.js +50 -50
  234. package/src/utils/rules.js +18 -18
  235. package/src/utils/store.js +21 -21
  236. package/src/utils/webSocket.js +107 -107
  237. package/packages/.DS_Store +0 -0
  238. package/packages/calogin/.DS_Store +0 -0
  239. package/packages/date-picker/.DS_Store +0 -0
  240. package/packages/date-picker/src/.DS_Store +0 -0
  241. package/packages/dialog/.DS_Store +0 -0
  242. package/packages/flow/.DS_Store +0 -0
  243. package/packages/flow/src/.DS_Store +0 -0
  244. package/packages/flow-list/.DS_Store +0 -0
  245. package/packages/form/.DS_Store +0 -0
  246. package/packages/icon/.DS_Store +0 -0
  247. package/packages/login/.DS_Store +0 -0
  248. package/packages/main/.DS_Store +0 -0
  249. package/packages/main/src/.DS_Store +0 -0
  250. package/packages/menu/.DS_Store +0 -0
  251. package/packages/select/.DS_Store +0 -0
  252. package/packages/selector/.DS_Store +0 -0
  253. package/packages/selector-panel/.DS_Store +0 -0
  254. package/packages/theme-chalk/lib/base.css +0 -1
  255. package/packages/theme-chalk/lib/button-group.css +0 -1
  256. package/packages/theme-chalk/lib/button.css +0 -1
  257. package/packages/theme-chalk/lib/calendar.css +0 -1
  258. package/packages/theme-chalk/lib/calogin.css +0 -0
  259. package/packages/theme-chalk/lib/card.css +0 -1
  260. package/packages/theme-chalk/lib/cascader.css +0 -0
  261. package/packages/theme-chalk/lib/checkbox-group.css +0 -1
  262. package/packages/theme-chalk/lib/clients.css +0 -1
  263. package/packages/theme-chalk/lib/data-table-form.css +0 -1
  264. package/packages/theme-chalk/lib/data-table.css +0 -1
  265. package/packages/theme-chalk/lib/date-picker.css +0 -1
  266. package/packages/theme-chalk/lib/dialog.css +0 -1
  267. package/packages/theme-chalk/lib/enable-drag.css +0 -1
  268. package/packages/theme-chalk/lib/enterprise.css +0 -1
  269. package/packages/theme-chalk/lib/error-page.css +0 -1
  270. package/packages/theme-chalk/lib/flow-chart.css +0 -0
  271. package/packages/theme-chalk/lib/flow-group.css +0 -1
  272. package/packages/theme-chalk/lib/flow-list.css +0 -1
  273. package/packages/theme-chalk/lib/flow.css +0 -1
  274. package/packages/theme-chalk/lib/fonts/iconfont.ttf +0 -0
  275. package/packages/theme-chalk/lib/fonts/iconfont.woff +0 -0
  276. package/packages/theme-chalk/lib/form.css +0 -1
  277. package/packages/theme-chalk/lib/handle-user.css +0 -1
  278. package/packages/theme-chalk/lib/handler.css +0 -1
  279. package/packages/theme-chalk/lib/icon.css +0 -1
  280. package/packages/theme-chalk/lib/icons.css +0 -1
  281. package/packages/theme-chalk/lib/index.css +0 -1
  282. package/packages/theme-chalk/lib/input-number.css +0 -0
  283. package/packages/theme-chalk/lib/input.css +0 -1
  284. package/packages/theme-chalk/lib/label.css +0 -1
  285. package/packages/theme-chalk/lib/layout.css +0 -1
  286. package/packages/theme-chalk/lib/login.css +0 -1
  287. package/packages/theme-chalk/lib/main.css +0 -1
  288. package/packages/theme-chalk/lib/menu.css +0 -1
  289. package/packages/theme-chalk/lib/nav.css +0 -1
  290. package/packages/theme-chalk/lib/notify.css +0 -0
  291. package/packages/theme-chalk/lib/page.css +0 -1
  292. package/packages/theme-chalk/lib/pagination.css +0 -1
  293. package/packages/theme-chalk/lib/player.css +0 -1
  294. package/packages/theme-chalk/lib/qr-code.css +0 -1
  295. package/packages/theme-chalk/lib/radio-group.css +0 -1
  296. package/packages/theme-chalk/lib/retrial-auth.css +0 -1
  297. package/packages/theme-chalk/lib/select-ganged.css +0 -1
  298. package/packages/theme-chalk/lib/select.css +0 -1
  299. package/packages/theme-chalk/lib/selector-panel.css +0 -1
  300. package/packages/theme-chalk/lib/selector.css +0 -1
  301. package/packages/theme-chalk/lib/simplicity-top.css +0 -1
  302. package/packages/theme-chalk/lib/simplicity.css +0 -1
  303. package/packages/theme-chalk/lib/sizer.css +0 -1
  304. package/packages/theme-chalk/lib/steps.css +0 -1
  305. package/packages/theme-chalk/lib/switch.css +0 -1
  306. package/packages/theme-chalk/lib/table-form.css +0 -0
  307. package/packages/theme-chalk/lib/tabs-panel.css +0 -0
  308. package/packages/theme-chalk/lib/tabs.css +0 -1
  309. package/packages/theme-chalk/lib/tips.css +0 -1
  310. package/packages/theme-chalk/lib/toolbar.css +0 -1
  311. package/packages/theme-chalk/lib/tree-group.css +0 -1
  312. package/packages/theme-chalk/lib/tree.css +0 -1
  313. package/packages/theme-chalk/lib/upload.css +0 -1
  314. package/packages/theme-chalk/lib/wujie.css +0 -0
  315. package/packages/theme-chalk/lib/wxlogin.css +0 -1
  316. package/packages/theme-chalk/src/.DS_Store +0 -0
  317. package/packages/upload/.DS_Store +0 -0
  318. package/src/.DS_Store +0 -0
  319. package/src/utils/.DS_Store +0 -0
@@ -1,170 +1,170 @@
1
- <template>
2
- <div class="es-qrcode-box" id="qrcode" ref="qrcode">
3
- <template v-if="mwidth && mheight">
4
- <img
5
- class="es-qrcode-img"
6
- :width="mwidth"
7
- :height="mheight"
8
- ref="qrcodeImg"
9
- alt="二维码图片"
10
- />
11
- <!-- <img
12
- v-if="logo"
13
- class="es-qrcode-logo"
14
- ref="qrcodeLogo"
15
- :src="logo"
16
- alt="二维码logo"
17
- /> -->
18
- <canvas
19
- :width="mwidth"
20
- :height="mheight"
21
- class="canvas"
22
- ref="canvas"
23
- ></canvas>
24
- </template>
25
- </div>
26
- </template>
27
-
28
- <script>
29
- import util from 'eoss-ui/src/utils/util';
30
- const QRCode = require('qrcode');
31
- export default {
32
- name: 'EsQrCode',
33
- props: {
34
- content: {
35
- type: String,
36
- required: true
37
- },
38
- logo: String,
39
- text: String,
40
- width: {
41
- type: Number,
42
- default: 300
43
- },
44
- height: {
45
- type: Number,
46
- default: 300
47
- },
48
- auto: Boolean,
49
- option: {
50
- type: Object,
51
- default: () => {
52
- return {
53
- errorCorrectionLevel: 'H', //纠错等级
54
- color: {
55
- dark: '#000000',
56
- light: '#ffffff'
57
- }
58
- };
59
- }
60
- }
61
- },
62
- computed: {},
63
- data() {
64
- return {
65
- mwidth: 0,
66
- mheight: 0
67
- };
68
- },
69
- watch: {
70
- logo: function (val) {
71
- this.$nextTick(() => {
72
- this.createQRCode();
73
- });
74
- },
75
- content: {
76
- immediate: true,
77
- handler(val) {
78
- if (val) {
79
- this.createQRCode();
80
- }
81
- }
82
- }
83
- },
84
- created() {},
85
- mounted() {
86
- if (this.auto) {
87
- let h =
88
- (this.$refs.qrcode.offsetHeight || this.$refs.qrcode.offsetWidth) -
89
- parseInt(util.getStyle(this.$refs.qrcode, 'padding-top'), 10) -
90
- parseInt(util.getStyle(this.$refs.qrcode, 'padding-bottom'), 10);
91
- if (h > 0) {
92
- this.mwidth = h;
93
- this.mheight = h;
94
- }
95
- } else {
96
- this.mwidth = this.width;
97
- this.mheight = this.height;
98
- }
99
- this.$nextTick(() => {
100
- this.createQRCode();
101
- });
102
- },
103
- methods: {
104
- createQRCode() {
105
- let qrcodeImg = this.$refs.qrcodeImg;
106
- //let qrcodeLogo = this.$refs.qrcodeLogo;
107
- let canvas = this.$refs.canvas;
108
- let option = util.extend({}, this.option, {
109
- width: this.mwidth,
110
- height: this.mheight
111
- });
112
- if (!qrcodeImg) {
113
- return false;
114
- }
115
- QRCode.toDataURL(this.content, option, (err, url) => {
116
- if (this.content && url) {
117
- qrcodeImg.src = url;
118
- // 画二维码里的logo// 在canvas里进行拼接
119
- let ctx = canvas.getContext('2d');
120
- setTimeout(() => {
121
- //获取图片
122
- ctx.drawImage(qrcodeImg, 0, 0, this.mwidth, this.mheight);
123
- if (this.logo && this.logo.indexOf('.') > -1) {
124
- let logo = new Image();
125
- logo.src = this.logo;
126
- //设置logo大小
127
- let logoPosition = (this.mwidth - 46) / 2; //logo相对于canvas居中定位
128
- //设置获取的logo将其变为圆角以及添加白色背景
129
- /* ctx.fillStyle = "#fff";
130
- ctx.beginPath();
131
- let h = 46; //圆角高 10为基数(logo四周白色背景为10/2)
132
- let w = 46; //圆角宽
133
- let x = logoPosition - 5;
134
- let y = logoPosition - 5;
135
- let r = 5; //圆角半径
136
- ctx.moveTo(x + r, y);
137
- ctx.arcTo(x + w, y, x + w, y + h, r);
138
- ctx.arcTo(x + w, y + h, x, y + h, r);
139
- ctx.arcTo(x, y + h, x, y, r);
140
- ctx.arcTo(x, y, x + w, y, r);
141
- ctx.closePath();
142
- ctx.fill(); */
143
- logo.onload = () => {
144
- ctx.drawImage(logo, logoPosition, logoPosition, 46, 46);
145
- qrcodeImg.src = canvas.toDataURL();
146
- };
147
- } else if (this.text) {
148
- //设置字体
149
- let fpadd = 10; //规定内间距
150
- ctx.font = 'bold 16px Arial';
151
- let tw = ctx.measureText(this.text).width; //文字真实宽度
152
- let ftop = (this.mheight - 16) / 2; //根据字体大小计算文字top
153
- let fleft = (this.mwidth - tw) / 2; //根据字体大小计算文字left
154
- let tp = 16 / 2; //字体边距为字体大小的一半可以自己设置
155
- ctx.fillStyle = '#fff';
156
- ctx.fillRect(fleft - tp / 2, ftop - tp / 2, tw + tp, 16 + tp);
157
- ctx.textBaseline = 'top'; //设置绘制文本时的文本基线。
158
- ctx.fillStyle = '#f40';
159
- ctx.fillText(this.text, fleft, ftop);
160
- }
161
- canvas.style.display = 'none';
162
- qrcodeImg.src = canvas.toDataURL();
163
- qrcodeImg.style.display = 'inline-block';
164
- }, 500);
165
- }
166
- });
167
- }
168
- }
169
- };
170
- </script>
1
+ <template>
2
+ <div class="es-qrcode-box" id="qrcode" ref="qrcode">
3
+ <template v-if="mwidth && mheight">
4
+ <img
5
+ class="es-qrcode-img"
6
+ :width="mwidth"
7
+ :height="mheight"
8
+ ref="qrcodeImg"
9
+ alt="二维码图片"
10
+ />
11
+ <!-- <img
12
+ v-if="logo"
13
+ class="es-qrcode-logo"
14
+ ref="qrcodeLogo"
15
+ :src="logo"
16
+ alt="二维码logo"
17
+ /> -->
18
+ <canvas
19
+ :width="mwidth"
20
+ :height="mheight"
21
+ class="canvas"
22
+ ref="canvas"
23
+ ></canvas>
24
+ </template>
25
+ </div>
26
+ </template>
27
+
28
+ <script>
29
+ import util from 'eoss-ui/src/utils/util';
30
+ const QRCode = require('qrcode');
31
+ export default {
32
+ name: 'EsQrCode',
33
+ props: {
34
+ content: {
35
+ type: String,
36
+ required: true
37
+ },
38
+ logo: String,
39
+ text: String,
40
+ width: {
41
+ type: Number,
42
+ default: 300
43
+ },
44
+ height: {
45
+ type: Number,
46
+ default: 300
47
+ },
48
+ auto: Boolean,
49
+ option: {
50
+ type: Object,
51
+ default: () => {
52
+ return {
53
+ errorCorrectionLevel: 'H', //纠错等级
54
+ color: {
55
+ dark: '#000000',
56
+ light: '#ffffff'
57
+ }
58
+ };
59
+ }
60
+ }
61
+ },
62
+ computed: {},
63
+ data() {
64
+ return {
65
+ mwidth: 0,
66
+ mheight: 0
67
+ };
68
+ },
69
+ watch: {
70
+ logo: function (val) {
71
+ this.$nextTick(() => {
72
+ this.createQRCode();
73
+ });
74
+ },
75
+ content: {
76
+ immediate: true,
77
+ handler(val) {
78
+ if (val) {
79
+ this.createQRCode();
80
+ }
81
+ }
82
+ }
83
+ },
84
+ created() {},
85
+ mounted() {
86
+ if (this.auto) {
87
+ let h =
88
+ (this.$refs.qrcode.offsetHeight || this.$refs.qrcode.offsetWidth) -
89
+ parseInt(util.getStyle(this.$refs.qrcode, 'padding-top'), 10) -
90
+ parseInt(util.getStyle(this.$refs.qrcode, 'padding-bottom'), 10);
91
+ if (h > 0) {
92
+ this.mwidth = h;
93
+ this.mheight = h;
94
+ }
95
+ } else {
96
+ this.mwidth = this.width;
97
+ this.mheight = this.height;
98
+ }
99
+ this.$nextTick(() => {
100
+ this.createQRCode();
101
+ });
102
+ },
103
+ methods: {
104
+ createQRCode() {
105
+ let qrcodeImg = this.$refs.qrcodeImg;
106
+ //let qrcodeLogo = this.$refs.qrcodeLogo;
107
+ let canvas = this.$refs.canvas;
108
+ let option = util.extend({}, this.option, {
109
+ width: this.mwidth,
110
+ height: this.mheight
111
+ });
112
+ if (!qrcodeImg) {
113
+ return false;
114
+ }
115
+ QRCode.toDataURL(this.content, option, (err, url) => {
116
+ if (this.content && url) {
117
+ qrcodeImg.src = url;
118
+ // 画二维码里的logo// 在canvas里进行拼接
119
+ let ctx = canvas.getContext('2d');
120
+ setTimeout(() => {
121
+ //获取图片
122
+ ctx.drawImage(qrcodeImg, 0, 0, this.mwidth, this.mheight);
123
+ if (this.logo && this.logo.indexOf('.') > -1) {
124
+ let logo = new Image();
125
+ logo.src = this.logo;
126
+ //设置logo大小
127
+ let logoPosition = (this.mwidth - 46) / 2; //logo相对于canvas居中定位
128
+ //设置获取的logo将其变为圆角以及添加白色背景
129
+ /* ctx.fillStyle = "#fff";
130
+ ctx.beginPath();
131
+ let h = 46; //圆角高 10为基数(logo四周白色背景为10/2)
132
+ let w = 46; //圆角宽
133
+ let x = logoPosition - 5;
134
+ let y = logoPosition - 5;
135
+ let r = 5; //圆角半径
136
+ ctx.moveTo(x + r, y);
137
+ ctx.arcTo(x + w, y, x + w, y + h, r);
138
+ ctx.arcTo(x + w, y + h, x, y + h, r);
139
+ ctx.arcTo(x, y + h, x, y, r);
140
+ ctx.arcTo(x, y, x + w, y, r);
141
+ ctx.closePath();
142
+ ctx.fill(); */
143
+ logo.onload = () => {
144
+ ctx.drawImage(logo, logoPosition, logoPosition, 46, 46);
145
+ qrcodeImg.src = canvas.toDataURL();
146
+ };
147
+ } else if (this.text) {
148
+ //设置字体
149
+ let fpadd = 10; //规定内间距
150
+ ctx.font = 'bold 16px Arial';
151
+ let tw = ctx.measureText(this.text).width; //文字真实宽度
152
+ let ftop = (this.mheight - 16) / 2; //根据字体大小计算文字top
153
+ let fleft = (this.mwidth - tw) / 2; //根据字体大小计算文字left
154
+ let tp = 16 / 2; //字体边距为字体大小的一半可以自己设置
155
+ ctx.fillStyle = '#fff';
156
+ ctx.fillRect(fleft - tp / 2, ftop - tp / 2, tw + tp, 16 + tp);
157
+ ctx.textBaseline = 'top'; //设置绘制文本时的文本基线。
158
+ ctx.fillStyle = '#f40';
159
+ ctx.fillText(this.text, fleft, ftop);
160
+ }
161
+ canvas.style.display = 'none';
162
+ qrcodeImg.src = canvas.toDataURL();
163
+ qrcodeImg.style.display = 'inline-block';
164
+ }, 500);
165
+ }
166
+ });
167
+ }
168
+ }
169
+ };
170
+ </script>
@@ -1,6 +1,6 @@
1
- import EsRadioGroup from './src/main';
2
-
3
- /* istanbul ignore next */
4
- EsRadioGroup.install = function(Vue) {Vue.component(EsRadioGroup.name, EsRadioGroup);};
5
-
6
- export default EsRadioGroup;
1
+ import EsRadioGroup from './src/main';
2
+
3
+ /* istanbul ignore next */
4
+ EsRadioGroup.install = function(Vue) {Vue.component(EsRadioGroup.name, EsRadioGroup);};
5
+
6
+ export default EsRadioGroup;