mdm-client 1.0.0

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 (262) hide show
  1. package/README.md +92 -0
  2. package/index.js +35 -0
  3. package/package.json +41 -0
  4. package/src/App.vue +246 -0
  5. package/src/assets/audio/moon_light.ogg +0 -0
  6. package/src/assets/font/DINPro-Medium.otf +0 -0
  7. package/src/assets/font/FZZhengHeiS-B-GB.ttf +0 -0
  8. package/src/assets/font/PingFang Regular.otf +0 -0
  9. package/src/assets/font/SourceHanSansCN-Regular.otf +0 -0
  10. package/src/assets/image/common/add_other_icon.png +0 -0
  11. package/src/assets/image/common/bottomFrame.png +0 -0
  12. package/src/assets/image/common/broadcastOn.png +0 -0
  13. package/src/assets/image/common/broadcastTask.png +0 -0
  14. package/src/assets/image/common/call.png +0 -0
  15. package/src/assets/image/common/call_user_mic_off_icon.png +0 -0
  16. package/src/assets/image/common/call_user_mic_on_icon.png +0 -0
  17. package/src/assets/image/common/cam-off.png +0 -0
  18. package/src/assets/image/common/cam-on.png +0 -0
  19. package/src/assets/image/common/cam_off_small.png +0 -0
  20. package/src/assets/image/common/camera.png +0 -0
  21. package/src/assets/image/common/cameraBtn1.png +0 -0
  22. package/src/assets/image/common/cameraBtn2.png +0 -0
  23. package/src/assets/image/common/cameraBtn3.png +0 -0
  24. package/src/assets/image/common/cameraBtn4.png +0 -0
  25. package/src/assets/image/common/cameraBtn5.png +0 -0
  26. package/src/assets/image/common/cameraBtn6.png +0 -0
  27. package/src/assets/image/common/cameraBtn7.png +0 -0
  28. package/src/assets/image/common/cameraClose.png +0 -0
  29. package/src/assets/image/common/cameraFull.png +0 -0
  30. package/src/assets/image/common/cameraOff.png +0 -0
  31. package/src/assets/image/common/cancel_icon.png +0 -0
  32. package/src/assets/image/common/card_blue.png +0 -0
  33. package/src/assets/image/common/card_grey.png +0 -0
  34. package/src/assets/image/common/chosen_icon.png +0 -0
  35. package/src/assets/image/common/chosen_icon_slided.png +0 -0
  36. package/src/assets/image/common/custom_layout_equipment_avatar.png +0 -0
  37. package/src/assets/image/common/custom_layout_user_avatar.png +0 -0
  38. package/src/assets/image/common/default_avatar.png +0 -0
  39. package/src/assets/image/common/default_avatar_mini.png +0 -0
  40. package/src/assets/image/common/delete-number.svg +3 -0
  41. package/src/assets/image/common/deviceIcon.png +0 -0
  42. package/src/assets/image/common/fourOff.png +0 -0
  43. package/src/assets/image/common/fourOn.png +0 -0
  44. package/src/assets/image/common/group.png +0 -0
  45. package/src/assets/image/common/groupManage.png +0 -0
  46. package/src/assets/image/common/histroy_meeting_icon.png +0 -0
  47. package/src/assets/image/common/icon-device.svg +12 -0
  48. package/src/assets/image/common/icon-monitor.svg +12 -0
  49. package/src/assets/image/common/icon-/345/260/217/347/250/213/345/272/217.svg +5 -0
  50. package/src/assets/image/common/icon-/345/272/224/347/255/224.svg +5 -0
  51. package/src/assets/image/common/icon-/350/247/206/351/242/221.svg +7 -0
  52. package/src/assets/image/common/input_search_icon.png +0 -0
  53. package/src/assets/image/common/launch_icon.png +0 -0
  54. package/src/assets/image/common/layout-active1.png +0 -0
  55. package/src/assets/image/common/layout-active2.png +0 -0
  56. package/src/assets/image/common/layout1.png +0 -0
  57. package/src/assets/image/common/layout2.png +0 -0
  58. package/src/assets/image/common/loading.png +0 -0
  59. package/src/assets/image/common/login/checked_icon.png +0 -0
  60. package/src/assets/image/common/login/login_bg.png +0 -0
  61. package/src/assets/image/common/login/login_form_left_icon.png +0 -0
  62. package/src/assets/image/common/login/pwd_icon.png +0 -0
  63. package/src/assets/image/common/login/user_icon.png +0 -0
  64. package/src/assets/image/common/login/verify_icon.png +0 -0
  65. package/src/assets/image/common/logo.png +0 -0
  66. package/src/assets/image/common/ltypeOff.png +0 -0
  67. package/src/assets/image/common/ltypeOn.png +0 -0
  68. package/src/assets/image/common/manager_cam_off_icon.png +0 -0
  69. package/src/assets/image/common/manager_mic_off_icon.png +0 -0
  70. package/src/assets/image/common/map-cicle-icon.svg +6 -0
  71. package/src/assets/image/common/map-icon-search-info.svg +11 -0
  72. package/src/assets/image/common/map-location.svg +37 -0
  73. package/src/assets/image/common/map.png +0 -0
  74. package/src/assets/image/common/mic-off.png +0 -0
  75. package/src/assets/image/common/mic-on.png +0 -0
  76. package/src/assets/image/common/mic_off_small.png +0 -0
  77. package/src/assets/image/common/minum_cam_off_icon.png +0 -0
  78. package/src/assets/image/common/minum_cam_on_icon.png +0 -0
  79. package/src/assets/image/common/minum_expand_icon.png +0 -0
  80. package/src/assets/image/common/minum_mic_off_icon.png +0 -0
  81. package/src/assets/image/common/minum_mic_on_icon.png +0 -0
  82. package/src/assets/image/common/minum_reset_icon.png +0 -0
  83. package/src/assets/image/common/minum_slide_icon.png +0 -0
  84. package/src/assets/image/common/more_icon.png +0 -0
  85. package/src/assets/image/common/mute.png +0 -0
  86. package/src/assets/image/common/newFolder.png +0 -0
  87. package/src/assets/image/common/newTask.png +0 -0
  88. package/src/assets/image/common/nineOff.png +0 -0
  89. package/src/assets/image/common/nineOn.png +0 -0
  90. package/src/assets/image/common/none.png +0 -0
  91. package/src/assets/image/common/offline.png +0 -0
  92. package/src/assets/image/common/oneOff.png +0 -0
  93. package/src/assets/image/common/oneOn.png +0 -0
  94. package/src/assets/image/common/online.png +0 -0
  95. package/src/assets/image/common/output_off_small.png +0 -0
  96. package/src/assets/image/common/playOff.png +0 -0
  97. package/src/assets/image/common/playOn.png +0 -0
  98. package/src/assets/image/common/playStop.png +0 -0
  99. package/src/assets/image/common/preview_icon.png +0 -0
  100. package/src/assets/image/common/preview_meet_icon.png +0 -0
  101. package/src/assets/image/common/scan-map.png +0 -0
  102. package/src/assets/image/common/screen_blue.png +0 -0
  103. package/src/assets/image/common/screen_gray.png +0 -0
  104. package/src/assets/image/common/screen_white.png +0 -0
  105. package/src/assets/image/common/select_item_check.png +0 -0
  106. package/src/assets/image/common/select_item_checked.png +0 -0
  107. package/src/assets/image/common/selector.png +0 -0
  108. package/src/assets/image/common/selectorOn.png +0 -0
  109. package/src/assets/image/common/share_icon.png +0 -0
  110. package/src/assets/image/common/signal_good.png +0 -0
  111. package/src/assets/image/common/signal_poor.png +0 -0
  112. package/src/assets/image/common/sixteenOff.png +0 -0
  113. package/src/assets/image/common/sixteenOn.png +0 -0
  114. package/src/assets/image/common/slide-bth-expand.png +0 -0
  115. package/src/assets/image/common/slide_btn.png +0 -0
  116. package/src/assets/image/common/speak.png +0 -0
  117. package/src/assets/image/common/speakOn.png +0 -0
  118. package/src/assets/image/common/speaker-off.png +0 -0
  119. package/src/assets/image/common/speaker-on.png +0 -0
  120. package/src/assets/image/common/speaking.png +0 -0
  121. package/src/assets/image/common/speed-left.svg +5 -0
  122. package/src/assets/image/common/speed-right.svg +5 -0
  123. package/src/assets/image/common/tree_checked_icon.png +0 -0
  124. package/src/assets/image/common/tree_expand_icon.png +0 -0
  125. package/src/assets/image/common/tree_slide_icon.png +0 -0
  126. package/src/assets/image/common/tree_uncheck_icon.png +0 -0
  127. package/src/assets/image/common/unchosen_icon.png +0 -0
  128. package/src/assets/image/common/up.png +0 -0
  129. package/src/assets/image/common/volume.png +0 -0
  130. package/src/assets/image/common/warning.png +0 -0
  131. package/src/assets/image/screenBlue/a1.png +0 -0
  132. package/src/assets/image/screenBlue/a2.png +0 -0
  133. package/src/assets/image/screenBlue/a3.png +0 -0
  134. package/src/assets/image/screenBlue/a4.png +0 -0
  135. package/src/assets/image/screenBlue/a5.png +0 -0
  136. package/src/assets/image/screenBlue/a6.png +0 -0
  137. package/src/assets/image/screenBlue/add.png +0 -0
  138. package/src/assets/image/screenBlue/add_group_icon.png +0 -0
  139. package/src/assets/image/screenBlue/add_to_group_icon.png +0 -0
  140. package/src/assets/image/screenBlue/arrow_icon.png +0 -0
  141. package/src/assets/image/screenBlue/audio_level_icon.png +0 -0
  142. package/src/assets/image/screenBlue/b1.png +0 -0
  143. package/src/assets/image/screenBlue/b2.png +0 -0
  144. package/src/assets/image/screenBlue/b3.png +0 -0
  145. package/src/assets/image/screenBlue/b4.png +0 -0
  146. package/src/assets/image/screenBlue/b5.png +0 -0
  147. package/src/assets/image/screenBlue/b6.png +0 -0
  148. package/src/assets/image/screenBlue/bottom_footer_bg.png +0 -0
  149. package/src/assets/image/screenBlue/call_clear_icon.png +0 -0
  150. package/src/assets/image/screenBlue/call_duration_icon.png +0 -0
  151. package/src/assets/image/screenBlue/call_fullscreen_icon.png +0 -0
  152. package/src/assets/image/screenBlue/call_mini_icon.png +0 -0
  153. package/src/assets/image/screenBlue/call_video_icon.png +0 -0
  154. package/src/assets/image/screenBlue/call_voice_icon.png +0 -0
  155. package/src/assets/image/screenBlue/cam_on_small.png +0 -0
  156. package/src/assets/image/screenBlue/close_icon.png +0 -0
  157. package/src/assets/image/screenBlue/copy-icon.png +0 -0
  158. package/src/assets/image/screenBlue/custom_layout_drag_icon.png +0 -0
  159. package/src/assets/image/screenBlue/custom_layout_grid16_active_icon.png +0 -0
  160. package/src/assets/image/screenBlue/custom_layout_grid16_icon.png +0 -0
  161. package/src/assets/image/screenBlue/custom_layout_grid4_active_icon.png +0 -0
  162. package/src/assets/image/screenBlue/custom_layout_grid4_icon.png +0 -0
  163. package/src/assets/image/screenBlue/custom_layout_grid9_active_icon.png +0 -0
  164. package/src/assets/image/screenBlue/custom_layout_grid9_icon.png +0 -0
  165. package/src/assets/image/screenBlue/custom_layout_header_icon.png +0 -0
  166. package/src/assets/image/screenBlue/custom_layout_placeholder_bg.png +0 -0
  167. package/src/assets/image/screenBlue/custom_layout_refresh_icon.png +0 -0
  168. package/src/assets/image/screenBlue/custom_layout_rightside_active_icon.png +0 -0
  169. package/src/assets/image/screenBlue/custom_layout_rightside_icon.png +0 -0
  170. package/src/assets/image/screenBlue/custom_layout_ring_active_icon.png +0 -0
  171. package/src/assets/image/screenBlue/custom_layout_ring_icon.png +0 -0
  172. package/src/assets/image/screenBlue/custom_layout_topside_active_icon.png +0 -0
  173. package/src/assets/image/screenBlue/custom_layout_topside_icon.png +0 -0
  174. package/src/assets/image/screenBlue/date_picker_icon.png +0 -0
  175. package/src/assets/image/screenBlue/dialog_check_icon.png +0 -0
  176. package/src/assets/image/screenBlue/emoji-logo.png +0 -0
  177. package/src/assets/image/screenBlue/header_alert_icon.png +0 -0
  178. package/src/assets/image/screenBlue/manager_cam_on_icon.png +0 -0
  179. package/src/assets/image/screenBlue/manager_mic_on_icon.png +0 -0
  180. package/src/assets/image/screenBlue/manager_more_icon.png +0 -0
  181. package/src/assets/image/screenBlue/meeting_board_bg.png +0 -0
  182. package/src/assets/image/screenBlue/meeting_chat_emoji_icon.png +0 -0
  183. package/src/assets/image/screenBlue/meeting_chat_icon.png +0 -0
  184. package/src/assets/image/screenBlue/meeting_chat_image_icon.png +0 -0
  185. package/src/assets/image/screenBlue/meeting_chat_logo.png +0 -0
  186. package/src/assets/image/screenBlue/meeting_copy_icon.png +0 -0
  187. package/src/assets/image/screenBlue/meeting_invite_icon.png +0 -0
  188. package/src/assets/image/screenBlue/meeting_layout_icon.png +0 -0
  189. package/src/assets/image/screenBlue/meeting_member_icon.png +0 -0
  190. package/src/assets/image/screenBlue/meeting_mode_icon.png +0 -0
  191. package/src/assets/image/screenBlue/meeting_record_icon.png +0 -0
  192. package/src/assets/image/screenBlue/meeting_setting_icon.png +0 -0
  193. package/src/assets/image/screenBlue/meeting_share_icon.png +0 -0
  194. package/src/assets/image/screenBlue/meeting_slide_small_icon.png +0 -0
  195. package/src/assets/image/screenBlue/mic_on_small.png +0 -0
  196. package/src/assets/image/screenBlue/module_bg1.png +0 -0
  197. package/src/assets/image/screenBlue/module_bg2.png +0 -0
  198. package/src/assets/image/screenBlue/monitor/circle data.png +0 -0
  199. package/src/assets/image/screenBlue/monitor/circle.png +0 -0
  200. package/src/assets/image/screenBlue/output_on_small.png +0 -0
  201. package/src/assets/image/screenBlue/page_bg.png +0 -0
  202. package/src/assets/image/screenBlue/pic-logo.png +0 -0
  203. package/src/assets/image/screenBlue/preview_date_icon.png +0 -0
  204. package/src/assets/image/screenBlue/preview_empty_icon.png +0 -0
  205. package/src/assets/image/screenBlue/preview_more_icon.png +0 -0
  206. package/src/assets/image/screenBlue/receive_hang_off_icon.png +0 -0
  207. package/src/assets/image/screenBlue/receive_hang_on_icon.png +0 -0
  208. package/src/assets/image/screenBlue/receive_video_icon.png +0 -0
  209. package/src/assets/image/screenBlue/receive_voice_icon.png +0 -0
  210. package/src/assets/image/screenBlue/send-logo.png +0 -0
  211. package/src/assets/image/screenBlue/slide_menu_bg.png +0 -0
  212. package/src/assets/image/screenBlue/top_header_bg.png +0 -0
  213. package/src/assets/image/screenBlue/yq.png +0 -0
  214. package/src/assets/json/emoji.json +222 -0
  215. package/src/assets/style/base.scss +217 -0
  216. package/src/assets/style/elForm.scss +80 -0
  217. package/src/assets/style/font.scss +16 -0
  218. package/src/assets/style/index.scss +5 -0
  219. package/src/assets/style/math.scss +11 -0
  220. package/src/assets/style/mixin.scss +69 -0
  221. package/src/components/LiveCallBoard/LiveCallBoard.vue +237 -0
  222. package/src/components/LiveInviteReceive/LiveInviteReceive.vue +150 -0
  223. package/src/components/LiveMulti/LiveMulti.vue +303 -0
  224. package/src/components/LiveMultipleMeeting/LiveMultipleMeeting.vue +4469 -0
  225. package/src/components/LiveMultipleMeeting/style/index.scss +337 -0
  226. package/src/components/LivePoint/LivePoint.vue +372 -0
  227. package/src/components/LivePointMeeting/LivePointMeeting.vue +1134 -0
  228. package/src/components/LivePointMeeting/style/index.scss +202 -0
  229. package/src/components/MeetingReadyDialog/MeetingReadyDialog.vue +583 -0
  230. package/src/components/MiniumVideoDialog/MiniumVideoDialog.vue +449 -0
  231. package/src/components/other/LayoutPlaceholder.vue +184 -0
  232. package/src/components/other/addressBook.vue +1121 -0
  233. package/src/components/other/appointDialog.vue +208 -0
  234. package/src/components/other/callBoard.vue +191 -0
  235. package/src/components/other/chatArea.vue +727 -0
  236. package/src/components/other/customGroupDialog.vue +180 -0
  237. package/src/components/other/customLayout.vue +1112 -0
  238. package/src/components/other/editGroupDialog.vue +290 -0
  239. package/src/components/other/inviteNonContactDialog.vue +160 -0
  240. package/src/components/other/layoutSwitch.vue +183 -0
  241. package/src/components/other/leaveOptionDialog.vue +90 -0
  242. package/src/components/other/memberManage.vue +502 -0
  243. package/src/components/other/moreOptionDialog.vue +291 -0
  244. package/src/components/other/screenShareBoard.vue +121 -0
  245. package/src/components/other/selectDialog.vue +279 -0
  246. package/src/components/other/selectSpecialDialog.vue +234 -0
  247. package/src/components/other/settingDialog.vue +756 -0
  248. package/src/components/other/themeDialog.vue +180 -0
  249. package/src/components/other/updateNameDialog.vue +162 -0
  250. package/src/directive/clickOutside.js +58 -0
  251. package/src/directive/drag.js +165 -0
  252. package/src/directive/scale.js +22 -0
  253. package/src/directive/throttle.js +77 -0
  254. package/src/main.js +21 -0
  255. package/src/request/index.js +27 -0
  256. package/src/utils/api.js +82 -0
  257. package/src/utils/index.js +4 -0
  258. package/src/utils/livekit/live-client-esm-old.js +1 -0
  259. package/src/utils/livekit/live-client-esm.js +1 -0
  260. package/src/utils/message.js +24 -0
  261. package/src/utils/mitt.js +4 -0
  262. package/src/utils/tool.js +154 -0
@@ -0,0 +1,208 @@
1
+ <template>
2
+ <div class="appoint-dialog" :style="position">
3
+ <div class="appoint-dialog-title">{{ title }}</div>
4
+ <div class="member-list">
5
+ <div
6
+ :class="['member-item', { 'member-item-checked': tempHostList?.ownerId === item.identity }]"
7
+ v-for="(item, index) of memberList"
8
+ :key="'p' + index"
9
+ @click="setToHost(item)"
10
+ >
11
+ <div class="member-item-avatar"></div>
12
+ <span class="member-item-name">{{ item.name }}</span>
13
+ <div class="member-item-check"></div>
14
+ </div>
15
+ </div>
16
+ <div class="appoint-dialog-foot">
17
+ <div class="foot-btn" v-throttle-click:500="appoint">指定并离开</div>
18
+ </div>
19
+ </div>
20
+ </template>
21
+
22
+ <script>
23
+ import { ShowMessage } from "@/utils/index";
24
+
25
+ export default {
26
+ name: "AppointDialog",
27
+ props: {
28
+ position: {
29
+ type: Object,
30
+ default: () => {
31
+ return {
32
+ right: "127px",
33
+ bottom: "84px",
34
+ };
35
+ },
36
+ },
37
+ title: {
38
+ type: String,
39
+ default: "指定主持人",
40
+ },
41
+ participants: {
42
+ type: Array
43
+ },
44
+ meetingHost: {
45
+ type: Object
46
+ }
47
+ },
48
+ data() {
49
+ return {
50
+ showMessage: null,
51
+ memberList: [],
52
+ tempHostList: null,
53
+ };
54
+ },
55
+ computed: {
56
+ participantNum() {
57
+ return this.participants.length;
58
+ }
59
+ },
60
+ watch: {
61
+ participantNum: {
62
+ handler() {
63
+ this.updateMemberList();
64
+ },
65
+ immediate: true
66
+ },
67
+ participants: {
68
+ handler() {
69
+ this.updateMemberList();
70
+ },
71
+ deep: true
72
+ }
73
+ },
74
+ created() {
75
+ this.showMessage = new ShowMessage();
76
+ },
77
+ mounted() {
78
+ this.tempHostList = this.meetingHost;
79
+ },
80
+ methods: {
81
+ judgeParticipantIsHost(identity) {
82
+ return this.meetingHost?.ownerId === identity;
83
+ },
84
+
85
+ appoint() {
86
+ if (this.judgeParticipantIsHost(this.tempHostList.ownerId)) {
87
+ this.showMessage.message("info", "当前与会者为已存在的会议主持人,无法更改");
88
+ return;
89
+ }
90
+ this.$emit("appointHost", this.tempHostList);
91
+ this.$emit("closeDialog");
92
+ },
93
+
94
+ setToHost(member) {
95
+ this.tempHostList = {
96
+ ownerId: member.identity,
97
+ ownerName: member.name,
98
+ };
99
+ },
100
+
101
+ updateMemberList() {
102
+ if (this.participantNum > 0) {
103
+ // 直接根据 props.participants 重新构建 memberList
104
+ this.memberList = this.participants.filter(participant => {
105
+ // 过滤掉非pc端和app端与会者,因为pc端和app端可以设置主持人
106
+ return participant.metadata.platformID == 0 || participant.metadata.platformID == 1;
107
+ }).map((participant) => {
108
+ return {
109
+ identity: participant.identity,
110
+ name: participant.name,
111
+ metadata: participant.metadata
112
+ };
113
+ });
114
+ } else {
115
+ this.memberList = [];
116
+ }
117
+ },
118
+ }
119
+ }
120
+ </script>
121
+
122
+ <style lang="scss" scoped>
123
+ .appoint-dialog {
124
+ width: 220px;
125
+ position: absolute;
126
+ z-index: 100;
127
+ background: var(--dialog-bg);
128
+ box-shadow: 0px 0px 8px 0px var(--dialog-shadow-color);
129
+ border-radius: 8px;
130
+ border: 1px solid var(--dialog-border-color);
131
+ font-weight: 500;
132
+ color: var(--theme-font-color);
133
+ padding: 0 12px 12px;
134
+ &-title {
135
+ width: 100%;
136
+ line-height: 40px;
137
+ padding-left: 12px;
138
+ white-space: nowrap;
139
+ font-size: 16px;
140
+ font-weight: 500;
141
+ border-bottom: 1px solid var(--dialog-border-color);
142
+ }
143
+ .member-list {
144
+ width: 100%;
145
+ height: 121px;
146
+ overflow-y: auto;
147
+ padding: 10px 12px;
148
+ .member-item {
149
+ width: 100%;
150
+ height: 32px;
151
+ cursor: pointer;
152
+ font-size: 14px;
153
+ font-weight: 400;
154
+ display: flex;
155
+ align-items: center;
156
+ flex-wrap: nowrap;
157
+ padding-left: 8px;
158
+ &:not(:last-child) {
159
+ margin-bottom: 12px;
160
+ }
161
+ &-avatar {
162
+ flex-shrink: 0;
163
+ width: 18px;
164
+ height: 18px;
165
+ margin-right: 9px;
166
+ background: url("../../assets/image/common/default_avatar.png") no-repeat center / 100% 100%;
167
+ }
168
+ &-name {
169
+ display: inline-block;
170
+ flex-shrink: 0;
171
+ white-space: nowrap;
172
+ width: calc(100% - 45px);
173
+ max-width: calc(100% - 45px);
174
+ overflow: hidden;
175
+ text-overflow: ellipsis;
176
+ }
177
+ &-checked {
178
+ // background: #1f63fb;
179
+ // border-radius: 8px;
180
+ .member-item-check {
181
+ background: var(--dialog-item-checked-icon) no-repeat center / 100% 100%;
182
+ }
183
+ }
184
+ &:hover {
185
+ background: var(--dialog-item-hover);
186
+ }
187
+ &-check {
188
+ flex-shrink: 0;
189
+ width: 16px;
190
+ height: 16px;
191
+ }
192
+ }
193
+ }
194
+ &-foot {
195
+ width: 100%;
196
+ .foot-btn {
197
+ background: var(--btn-primary-bg);
198
+ box-shadow: 0px 2px 12px 0px rgba(42, 104, 246, 0.15);
199
+ border-radius: 8px;
200
+ cursor: pointer;
201
+ line-height: 40px;
202
+ text-align: center;
203
+ font-weight: 500;
204
+ font-size: 16px;
205
+ }
206
+ }
207
+ }
208
+ </style>
@@ -0,0 +1,191 @@
1
+ <template>
2
+ <div class="call-board">
3
+ <div class="call-board-title">
4
+ <span>拨号盘</span>
5
+ <div class="title-close-icon" @click="$emit('closeCallBoard')"></div>
6
+ </div>
7
+ <div class="input-box">
8
+ <el-input v-model="callNum" type="mobile" placeholder="请输入号码" clearable autofocus>
9
+ <div slot="suffix" class="del-icon" @click="delCallNum"></div>
10
+ </el-input>
11
+ </div>
12
+ <div class="call-board-list">
13
+ <div class="call-board-list-item" v-for="item of '123456789*0#'" @click="inputCallNum(item)">
14
+ {{ item }}
15
+ </div>
16
+ </div>
17
+ <div class="call-board-foot">
18
+ <div class="call-board-foot-btn call-btn" v-throttle-click:500="call">
19
+ <div class="btn-icon"></div>
20
+ </div>
21
+ <div class="call-board-foot-btn mini-btn" v-throttle-click:500="miniCall">
22
+ <div class="btn-icon"></div>
23
+ </div>
24
+ </div>
25
+ </div>
26
+ </template>
27
+
28
+ <script>
29
+ import { ShowMessage } from "@/utils/index";
30
+
31
+ export default {
32
+ name: "CallBoard",
33
+ props: {
34
+ position: {
35
+ type: Object,
36
+ default: () => {
37
+ return {
38
+ right: "127px",
39
+ bottom: "84px",
40
+ };
41
+ },
42
+ },
43
+ },
44
+ data() {
45
+ return {
46
+ showMessage: null,
47
+ callNum: "",
48
+ };
49
+ },
50
+ created() {
51
+ this.showMessage = new ShowMessage();
52
+ },
53
+ methods: {
54
+ verifyMobile(num) {
55
+ const reg = /^[\d#*]+$/;
56
+ return reg.test(num);
57
+ },
58
+
59
+ inputCallNum(item) {
60
+ // if(this.verifyMobile(item)) {
61
+ // this.callNum += item
62
+ // } else {
63
+ // this.showMessage.message("error", "请输入合法的字符")
64
+ // }
65
+ this.callNum += item;
66
+ },
67
+
68
+ delCallNum() {
69
+ if(this.callNum.length > 0) {
70
+ this.callNum = this.callNum.substring(0, this.callNum.length - 1);
71
+ }
72
+ },
73
+
74
+ call() {
75
+ if (!this.callNum) {
76
+ this.showMessage.message("error", "联系方式不能为空");
77
+ } else {
78
+ if (this.verifyMobile(this.callNum)) {
79
+ this.$emit("phoneCall", this.callNum);
80
+ } else {
81
+ this.showMessage.message("error", "手机号中包含不合法字符");
82
+ }
83
+ }
84
+ },
85
+
86
+ miniCall() {
87
+ if (!this.callNum) {
88
+ this.showMessage.message("error", "联系方式不能为空");
89
+ } else {
90
+ this.$emit("miniCall", this.callNum);
91
+ }
92
+ },
93
+ }
94
+ }
95
+ </script>
96
+
97
+ <style lang="scss" scoped>
98
+ @import "../../assets/style/mixin.scss";
99
+ .call-board {
100
+ position: absolute;
101
+ width: 270px;
102
+ background: var(--dialog-bg);
103
+ box-shadow: 0px 0px 8px 0px var(--dialog-shadow-color);
104
+ border-radius: 8px;
105
+ border: 1px solid var(--dialog-border-color);
106
+ padding: 0 12px;
107
+ font-weight: 500;
108
+ font-size: 16px;
109
+ color: var(--theme-font-color);
110
+ z-index: 20000;
111
+ bottom: 40px;
112
+ left: -135px;
113
+ &-title {
114
+ width: 100%;
115
+ height: 43px;
116
+ display: flex;
117
+ align-items: center;
118
+ justify-content: space-between;
119
+ border-bottom: 1px solid var(--dialog-border-color);
120
+ margin-bottom: 12px;
121
+ .title-close-icon {
122
+ width: 16px;
123
+ height: 16px;
124
+ cursor: pointer;
125
+ background: var(--close-icon) no-repeat center / 100% 100%;
126
+ }
127
+ }
128
+ .input-box {
129
+ margin-bottom: 12px;
130
+ :deep(.el-input) {
131
+ width: 100%;
132
+ height: 42px;
133
+ @include elInput;
134
+ }
135
+ }
136
+ &-list {
137
+ width: 100%;
138
+ display: grid;
139
+ grid-template-columns: repeat(3, 1fr);
140
+ grid-gap: 10px 12px;
141
+ margin-bottom: 10px;
142
+ &-item {
143
+ cursor: pointer;
144
+ height: 36px;
145
+ line-height: 36px;
146
+ text-align: center;
147
+ font-weight: 500;
148
+ font-size: 24px;
149
+ background: var(--call-border-item-bg);
150
+ border-radius: 6px 6px 6px 6px;
151
+ }
152
+ }
153
+ &-foot {
154
+ width: 100%;
155
+ display: flex;
156
+ align-items: center;
157
+ justify-content: space-between;
158
+ margin-bottom: 12px;
159
+ &-btn {
160
+ width: 117px;
161
+ height: 36px;
162
+ display: flex;
163
+ align-items: center;
164
+ justify-content: center;
165
+ background: var(--call-border-item-bg);
166
+ border-radius: 6px 6px 6px 6px;
167
+ .btn-icon {
168
+ width: 24px;
169
+ height: 24px;
170
+ cursor: pointer;
171
+ }
172
+ }
173
+ .call-btn {
174
+ .btn-icon {
175
+ background: url("../../assets/image/screenBlue/call_video_icon.png") no-repeat center / 100% 100%;
176
+ }
177
+ }
178
+ .mini-btn {
179
+ .btn-icon {
180
+ background: url("../../assets/image/screenBlue/call_mini_icon.png") no-repeat center / 100% 100%;
181
+ }
182
+ }
183
+ }
184
+ .del-icon {
185
+ width: 17px;
186
+ height: 17px;
187
+ cursor: pointer;
188
+ background: var(--call-border-del-icon) no-repeat center / 100% 100%;
189
+ }
190
+ }
191
+ </style>