@zfqh/uniapp 0.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 (310) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/LICENSE +21 -0
  3. package/README.md +39 -0
  4. package/docs/api/apis/core.md +189 -0
  5. package/docs/api/apis/index.md +82 -0
  6. package/docs/api/apis/request.md +369 -0
  7. package/docs/api/configs/api.md +32 -0
  8. package/docs/api/configs/app.md +43 -0
  9. package/docs/api/configs/brand.md +43 -0
  10. package/docs/api/configs/cdn.md +35 -0
  11. package/docs/api/configs/color.md +144 -0
  12. package/docs/api/configs/env.md +120 -0
  13. package/docs/api/configs/index.md +394 -0
  14. package/docs/api/configs/link.md +33 -0
  15. package/docs/api/configs/log.md +27 -0
  16. package/docs/api/configs/mp.md +34 -0
  17. package/docs/api/configs/navigate.md +27 -0
  18. package/docs/api/configs/page.md +32 -0
  19. package/docs/api/configs/path.md +27 -0
  20. package/docs/api/configs/storage.md +24 -0
  21. package/docs/api/configs/tabbar.md +29 -0
  22. package/docs/api/configs/toast.md +35 -0
  23. package/docs/api/configs/update.md +25 -0
  24. package/docs/api/configs/upload.md +45 -0
  25. package/docs/api/configs/ver.md +32 -0
  26. package/docs/api/configs/web.md +28 -0
  27. package/docs/api/hooks/index.md +182 -0
  28. package/docs/api/hooks/useI18n.md +27 -0
  29. package/docs/api/hooks/useOverlay.md +37 -0
  30. package/docs/api/hooks/usePopup.md +35 -0
  31. package/docs/api/hooks/useVersion.md +23 -0
  32. package/docs/api/index.md +269 -0
  33. package/docs/api/mixins/app.md +29 -0
  34. package/docs/api/mixins/badge.md +23 -0
  35. package/docs/api/mixins/debounce.md +32 -0
  36. package/docs/api/mixins/deep.md +29 -0
  37. package/docs/api/mixins/index.md +23 -0
  38. package/docs/api/mixins/login.md +22 -0
  39. package/docs/api/mixins/model.md +26 -0
  40. package/docs/api/mixins/redirect.md +26 -0
  41. package/docs/api/mixins/share.md +29 -0
  42. package/docs/api/mixins/show.md +27 -0
  43. package/docs/api/mixins/webview.md +27 -0
  44. package/docs/api/modules/app.md +30 -0
  45. package/docs/api/modules/dict.md +28 -0
  46. package/docs/api/modules/im.md +22 -0
  47. package/docs/api/modules/index.md +44 -0
  48. package/docs/api/modules/launch.md +26 -0
  49. package/docs/api/modules/location.md +25 -0
  50. package/docs/api/modules/login.md +35 -0
  51. package/docs/api/modules/network.md +26 -0
  52. package/docs/api/modules/system.md +29 -0
  53. package/docs/api/utils/audio.md +84 -0
  54. package/docs/api/utils/consts.md +201 -0
  55. package/docs/api/utils/cos.md +269 -0
  56. package/docs/api/utils/debounce.md +89 -0
  57. package/docs/api/utils/file.md +78 -0
  58. package/docs/api/utils/index.md +547 -0
  59. package/docs/api/utils/locale.md +32 -0
  60. package/docs/api/utils/message.md +81 -0
  61. package/docs/api/utils/navigate.md +267 -0
  62. package/docs/api/utils/pages.md +205 -0
  63. package/docs/api/utils/permission.md +28 -0
  64. package/docs/api/utils/permit.md +62 -0
  65. package/docs/api/utils/query.md +89 -0
  66. package/docs/api/utils/request.md +34 -0
  67. package/docs/api/utils/storage.md +145 -0
  68. package/docs/api/utils/subscribe.md +77 -0
  69. package/docs/api/utils/throttle.md +101 -0
  70. package/docs/api/utils/toast.md +164 -0
  71. package/docs/api/utils/uni.md +28 -0
  72. package/docs/api/utils/update.md +165 -0
  73. package/docs/components/g-back-button.md +76 -0
  74. package/docs/components/g-checkbox-list.md +101 -0
  75. package/docs/components/g-container.md +93 -0
  76. package/docs/components/g-data-list.md +106 -0
  77. package/docs/components/g-dot-text.md +79 -0
  78. package/docs/components/g-env.md +75 -0
  79. package/docs/components/g-float.md +83 -0
  80. package/docs/components/g-grid-image.md +91 -0
  81. package/docs/components/g-grid-swiper.md +99 -0
  82. package/docs/components/g-icon.md +106 -0
  83. package/docs/components/g-mask.md +82 -0
  84. package/docs/components/g-money.md +90 -0
  85. package/docs/components/g-more.md +78 -0
  86. package/docs/components/g-page-container.md +170 -0
  87. package/docs/components/g-permission-popup.md +117 -0
  88. package/docs/components/g-polyline-chat.md +102 -0
  89. package/docs/components/g-polyline-view.md +67 -0
  90. package/docs/components/g-popup.md +144 -0
  91. package/docs/components/g-refresh-view.md +118 -0
  92. package/docs/components/g-render-image.md +83 -0
  93. package/docs/components/g-search.md +120 -0
  94. package/docs/components/g-share-photo.md +77 -0
  95. package/docs/components/g-share-view.md +83 -0
  96. package/docs/components/g-share-weixin.md +81 -0
  97. package/docs/components/g-skeleton-view.md +71 -0
  98. package/docs/components/g-skeleton.md +64 -0
  99. package/docs/components/g-tag-editor.md +134 -0
  100. package/docs/components/g-timer.md +72 -0
  101. package/docs/components/g-trtc-room.md +116 -0
  102. package/docs/components/g-trtc-tui.md +84 -0
  103. package/docs/components/g-trtc.md +124 -0
  104. package/docs/components/g-upload.md +117 -0
  105. package/docs/components/g-waterfall.md +84 -0
  106. package/docs/components/index.md +109 -0
  107. package/docs/components/styles/base-styles.md +367 -0
  108. package/docs/components/styles/global-vars.md +150 -0
  109. package/docs/components/usage.md +112 -0
  110. package/docs/faq/index.md +78 -0
  111. package/docs/guide/getting-started.md +195 -0
  112. package/docs/guide/project-frame.md +297 -0
  113. package/docs/index.md +80 -0
  114. package/lib/apis/core.d.ts +12 -0
  115. package/lib/apis/core.js +13 -0
  116. package/lib/apis/index.d.ts +2 -0
  117. package/lib/apis/index.js +2 -0
  118. package/lib/apis/request.d.ts +4 -0
  119. package/lib/apis/request.js +27 -0
  120. package/lib/components/g-back-button/g-back-button.vue +141 -0
  121. package/lib/components/g-checkbox-list/g-checkbox-list.vue +156 -0
  122. package/lib/components/g-container/g-container.vue +159 -0
  123. package/lib/components/g-data-list/g-data-list.vue +192 -0
  124. package/lib/components/g-dot-text/g-dot-text.vue +114 -0
  125. package/lib/components/g-env/g-env.vue +123 -0
  126. package/lib/components/g-float/g-float.vue +131 -0
  127. package/lib/components/g-grid-image/g-grid-image.vue +84 -0
  128. package/lib/components/g-grid-swiper/g-grid-swiper.vue +224 -0
  129. package/lib/components/g-icon/g-icon.vue +72 -0
  130. package/lib/components/g-mask/g-mask.vue +126 -0
  131. package/lib/components/g-money/g-money.vue +174 -0
  132. package/lib/components/g-more/g-more.vue +68 -0
  133. package/lib/components/g-page-container/g-page-container.vue +470 -0
  134. package/lib/components/g-permission-popup/g-permission-popup.vue +80 -0
  135. package/lib/components/g-polyline-chat/g-polyline-chat.vue +255 -0
  136. package/lib/components/g-polyline-view/g-polyline-view.vue +104 -0
  137. package/lib/components/g-popup/g-popup.vue +449 -0
  138. package/lib/components/g-refresh-view/g-refresh-view.vue +213 -0
  139. package/lib/components/g-render-image/g-render-image.vue +222 -0
  140. package/lib/components/g-search/g-search.vue +274 -0
  141. package/lib/components/g-share-photo/g-share-photo.vue +75 -0
  142. package/lib/components/g-share-view/g-share-view.vue +157 -0
  143. package/lib/components/g-share-weixin/g-share-weixin.vue +106 -0
  144. package/lib/components/g-skeleton/g-skeleton.vue +55 -0
  145. package/lib/components/g-skeleton-view/g-skeleton-view.vue +78 -0
  146. package/lib/components/g-tag-editor/g-tag-editor.vue +482 -0
  147. package/lib/components/g-timer/g-timer.vue +61 -0
  148. package/lib/components/g-trtc/g-trtc.vue +347 -0
  149. package/lib/components/g-trtc-room/g-trtc-room.vue +524 -0
  150. package/lib/components/g-trtc-room/iconfont.scss +59 -0
  151. package/lib/components/g-trtc-tui/g-trtc-tui.vue +245 -0
  152. package/lib/components/g-upload/g-upload.vue +294 -0
  153. package/lib/components/g-waterfall/g-waterfall.vue +101 -0
  154. package/lib/configs/api.d.ts +7 -0
  155. package/lib/configs/api.js +6 -0
  156. package/lib/configs/app.d.ts +26 -0
  157. package/lib/configs/app.js +50 -0
  158. package/lib/configs/brand.d.ts +22 -0
  159. package/lib/configs/brand.js +26 -0
  160. package/lib/configs/cdn.d.ts +13 -0
  161. package/lib/configs/cdn.js +12 -0
  162. package/lib/configs/color.d.ts +62 -0
  163. package/lib/configs/color.js +66 -0
  164. package/lib/configs/env.d.ts +37 -0
  165. package/lib/configs/env.js +71 -0
  166. package/lib/configs/index.d.ts +170 -0
  167. package/lib/configs/index.js +82 -0
  168. package/lib/configs/link.d.ts +11 -0
  169. package/lib/configs/link.js +3 -0
  170. package/lib/configs/log.d.ts +9 -0
  171. package/lib/configs/log.js +8 -0
  172. package/lib/configs/mp.d.ts +15 -0
  173. package/lib/configs/mp.js +9 -0
  174. package/lib/configs/navigate.d.ts +17 -0
  175. package/lib/configs/navigate.js +5 -0
  176. package/lib/configs/page.d.ts +18 -0
  177. package/lib/configs/page.js +14 -0
  178. package/lib/configs/path.d.ts +11 -0
  179. package/lib/configs/path.js +10 -0
  180. package/lib/configs/storage.d.ts +7 -0
  181. package/lib/configs/storage.js +6 -0
  182. package/lib/configs/tabbar.d.ts +7 -0
  183. package/lib/configs/tabbar.js +6 -0
  184. package/lib/configs/toast.d.ts +18 -0
  185. package/lib/configs/toast.js +29 -0
  186. package/lib/configs/update.d.ts +45 -0
  187. package/lib/configs/update.js +6 -0
  188. package/lib/configs/upload.d.ts +30 -0
  189. package/lib/configs/upload.js +7 -0
  190. package/lib/configs/ver.d.ts +8 -0
  191. package/lib/configs/ver.js +28 -0
  192. package/lib/configs/web.d.ts +5 -0
  193. package/lib/configs/web.js +2 -0
  194. package/lib/hooks/index.d.ts +4 -0
  195. package/lib/hooks/index.js +4 -0
  196. package/lib/hooks/useI18n.d.ts +2 -0
  197. package/lib/hooks/useI18n.js +19 -0
  198. package/lib/hooks/useOverlay.d.ts +1 -0
  199. package/lib/hooks/useOverlay.js +17 -0
  200. package/lib/hooks/usePopup.d.ts +1 -0
  201. package/lib/hooks/usePopup.js +14 -0
  202. package/lib/hooks/useVersion.d.ts +6 -0
  203. package/lib/hooks/useVersion.js +21 -0
  204. package/lib/index.d.ts +26 -0
  205. package/lib/index.js +33 -0
  206. package/lib/mixins/app.d.ts +14 -0
  207. package/lib/mixins/app.js +105 -0
  208. package/lib/mixins/badge.d.ts +24 -0
  209. package/lib/mixins/badge.js +44 -0
  210. package/lib/mixins/debounce.d.ts +6 -0
  211. package/lib/mixins/debounce.js +11 -0
  212. package/lib/mixins/deep.d.ts +6 -0
  213. package/lib/mixins/deep.js +8 -0
  214. package/lib/mixins/index.d.ts +8 -0
  215. package/lib/mixins/index.js +8 -0
  216. package/lib/mixins/login.d.ts +4 -0
  217. package/lib/mixins/login.js +25 -0
  218. package/lib/mixins/model.d.ts +22 -0
  219. package/lib/mixins/model.js +29 -0
  220. package/lib/mixins/redirect.d.ts +8 -0
  221. package/lib/mixins/redirect.js +94 -0
  222. package/lib/mixins/share.d.ts +15 -0
  223. package/lib/mixins/share.js +55 -0
  224. package/lib/mixins/show.d.ts +9 -0
  225. package/lib/mixins/show.js +16 -0
  226. package/lib/mixins/webview.d.ts +26 -0
  227. package/lib/mixins/webview.js +225 -0
  228. package/lib/modules/app.d.ts +5 -0
  229. package/lib/modules/app.js +19 -0
  230. package/lib/modules/dict.d.ts +8 -0
  231. package/lib/modules/dict.js +43 -0
  232. package/lib/modules/im.d.ts +6 -0
  233. package/lib/modules/im.js +105 -0
  234. package/lib/modules/index.d.ts +8 -0
  235. package/lib/modules/index.js +8 -0
  236. package/lib/modules/launch.d.ts +5 -0
  237. package/lib/modules/launch.js +32 -0
  238. package/lib/modules/location.d.ts +5 -0
  239. package/lib/modules/location.js +57 -0
  240. package/lib/modules/login.d.ts +5 -0
  241. package/lib/modules/login.js +72 -0
  242. package/lib/modules/network.d.ts +5 -0
  243. package/lib/modules/network.js +39 -0
  244. package/lib/modules/system.d.ts +5 -0
  245. package/lib/modules/system.js +65 -0
  246. package/lib/styles/animate-vue.scss +3 -0
  247. package/lib/styles/animate.scss +27 -0
  248. package/lib/styles/bg-vue.scss +21 -0
  249. package/lib/styles/bg.scss +93 -0
  250. package/lib/styles/border.scss +218 -0
  251. package/lib/styles/flex-nvue.scss +64 -0
  252. package/lib/styles/flex-vue.scss +75 -0
  253. package/lib/styles/font.scss +59 -0
  254. package/lib/styles/index.scss +25 -0
  255. package/lib/styles/layout-nvue.scss +24 -0
  256. package/lib/styles/layout-vue.scss +30 -0
  257. package/lib/styles/layout.scss +76 -0
  258. package/lib/styles/opacity.scss +10 -0
  259. package/lib/styles/reset-vue.scss +46 -0
  260. package/lib/styles/shadow.scss +12 -0
  261. package/lib/styles/sizing-vue.scss +21 -0
  262. package/lib/styles/sizing.scss +21 -0
  263. package/lib/styles/spacing.scss +234 -0
  264. package/lib/styles/text-nvue.scss +21 -0
  265. package/lib/styles/text-vue.scss +70 -0
  266. package/lib/styles/text.scss +122 -0
  267. package/lib/styles/var.module.scss +29 -0
  268. package/lib/utils/audio.d.ts +14 -0
  269. package/lib/utils/audio.js +43 -0
  270. package/lib/utils/consts.d.ts +30 -0
  271. package/lib/utils/consts.js +52 -0
  272. package/lib/utils/cos.d.ts +15 -0
  273. package/lib/utils/cos.js +140 -0
  274. package/lib/utils/debounce.d.ts +2 -0
  275. package/lib/utils/debounce.js +30 -0
  276. package/lib/utils/file.d.ts +28 -0
  277. package/lib/utils/file.js +292 -0
  278. package/lib/utils/index.d.ts +166 -0
  279. package/lib/utils/index.js +485 -0
  280. package/lib/utils/locale.d.ts +6 -0
  281. package/lib/utils/locale.js +19 -0
  282. package/lib/utils/message.d.ts +9 -0
  283. package/lib/utils/message.js +63 -0
  284. package/lib/utils/navigate.d.ts +27 -0
  285. package/lib/utils/navigate.js +183 -0
  286. package/lib/utils/pages.d.ts +21 -0
  287. package/lib/utils/pages.js +79 -0
  288. package/lib/utils/permission.d.ts +16 -0
  289. package/lib/utils/permission.js +291 -0
  290. package/lib/utils/permit.d.ts +30 -0
  291. package/lib/utils/permit.js +181 -0
  292. package/lib/utils/query.d.ts +13 -0
  293. package/lib/utils/query.js +14 -0
  294. package/lib/utils/request.d.ts +8 -0
  295. package/lib/utils/request.js +126 -0
  296. package/lib/utils/storage.d.ts +53 -0
  297. package/lib/utils/storage.js +145 -0
  298. package/lib/utils/subscribe.d.ts +7 -0
  299. package/lib/utils/subscribe.js +94 -0
  300. package/lib/utils/throttle.d.ts +2 -0
  301. package/lib/utils/throttle.js +32 -0
  302. package/lib/utils/toast.d.ts +17 -0
  303. package/lib/utils/toast.js +66 -0
  304. package/lib/utils/uni.d.ts +1 -0
  305. package/lib/utils/uni.js +147 -0
  306. package/lib/utils/update.d.ts +9 -0
  307. package/lib/utils/update.js +376 -0
  308. package/package.json +49 -0
  309. package/types/index.d.ts +25 -0
  310. package/types/virtual.d.ts +1 -0
@@ -0,0 +1,524 @@
1
+ <template>
2
+ <view
3
+ class="trtc-room"
4
+ :class="{ 'trtc-room-zoom': zoom, 'trtc-room-zoom-video': zoom && enableCamera }"
5
+ :style="[roomStyle]"
6
+ @click="handler('zoom')"
7
+ @touchstart="touchStart"
8
+ @touchmove="touchMove"
9
+ @touchend="touchEnd"
10
+ >
11
+ <view class="trtc-room-header" :style="[headerStyle]">
12
+ <view @click.stop="zoom = true">
13
+ <g-icon v-if="enableZoom" font="rtc" name="zoom" size="46rpx" />
14
+ </view>
15
+ <view :style="[titleStyle]">
16
+ <slot v-if="!start || !enableCamera" name="title">
17
+ <view class="flex flex-col justify-center">
18
+ <uv-avatar :src="avatar" size="120rpx" mode="aspectFill" class="u-flex" />
19
+ <text v-if="title" class="text-28rpx mt-12rpx"> {{ title }} </text>
20
+ <text v-if="description" :class="[title ? 'mt-6rpx' : 'mt-12rpx']" class="text-24rpx">
21
+ {{ description }}
22
+ </text>
23
+ </view>
24
+ </slot>
25
+ </view>
26
+ </view>
27
+ <view class="trtc-room-handler">
28
+ <view>
29
+ <g-icon v-if="zoom" font="rtc" name="calling" size="56rpx" />
30
+ <view>
31
+ <g-timer v-if="start" :start="start" @change="timerChange" />
32
+ <text v-else> {{ tips }} </text>
33
+ </view>
34
+ </view>
35
+ <view>
36
+ <view
37
+ v-for="btn in buttons"
38
+ :key="btn.key"
39
+ class="trtc-room-button"
40
+ :class="{ light: btn.light }"
41
+ @click="handler(btn.key)"
42
+ >
43
+ <view>
44
+ <g-icon font="rtc" :name="btn.icon" size="54rpx" />
45
+ </view>
46
+ <text> {{ btn.text }} </text>
47
+ </view>
48
+ </view>
49
+ <view>
50
+ <template v-if="start">
51
+ <view></view>
52
+ <view>
53
+ <view class="trtc-room-button error" @click="handler('hangup')">
54
+ <view>
55
+ <g-icon font="rtc" name="hangup" size="54rpx" />
56
+ </view>
57
+ </view>
58
+ </view>
59
+ <view>
60
+ <g-icon
61
+ v-if="enableCamera"
62
+ font="rtc"
63
+ name="switch-camera"
64
+ size="46rpx"
65
+ @click="handler('switch-camera')"
66
+ />
67
+ </view>
68
+ </template>
69
+ <template v-else>
70
+ <view>
71
+ <view class="trtc-room-button error" @click="handler('hangup')">
72
+ <view>
73
+ <g-icon font="rtc" name="hangup" size="54rpx" />
74
+ </view>
75
+ </view>
76
+ </view>
77
+ <view>
78
+ <view class="trtc-room-button success" @click="handler('accept')">
79
+ <view>
80
+ <g-icon font="rtc" name="call" size="54rpx" />
81
+ </view>
82
+ </view>
83
+ </view>
84
+ </template>
85
+ </view>
86
+ </view>
87
+ <g-trtc
88
+ ref="trtc"
89
+ :roomId="roomId"
90
+ :appId="appId"
91
+ :userId="userId"
92
+ :userSig="userSig"
93
+ :customStyle="trtcStyle"
94
+ :enableCamera="enableCamera"
95
+ :enableMic="enableMic"
96
+ :enableSpeaker="enableSpeaker"
97
+ :frontCamera="frontCamera"
98
+ :autopush="!!start"
99
+ @leave="leave"
100
+ @join="join"
101
+ />
102
+ </view>
103
+ </template>
104
+
105
+ <script>
106
+ import cdn from '../../configs/cdn';
107
+
108
+ export default {
109
+ // #ifdef MP
110
+ options: {
111
+ styleIsolation: 'shared',
112
+ },
113
+ // #endif
114
+ props: {
115
+ // 房间ID
116
+ roomId: {
117
+ type: [String, Number],
118
+ default: 0,
119
+ },
120
+ // 应用APPID
121
+ appId: {
122
+ type: [String, Number],
123
+ default: 0,
124
+ },
125
+ // 用户IMID
126
+ userId: {
127
+ type: [String, Number],
128
+ default: '',
129
+ },
130
+ // 用户签名
131
+ userSig: {
132
+ type: String,
133
+ default: '',
134
+ },
135
+ // 房间名称
136
+ title: {
137
+ type: String,
138
+ default: '',
139
+ },
140
+ // 房间简介
141
+ description: {
142
+ type: String,
143
+ default: '',
144
+ },
145
+ // 房间头像
146
+ avatar: {
147
+ type: String,
148
+ default: '',
149
+ },
150
+ // 开启缩放功能
151
+ enableZoom: {
152
+ type: Boolean,
153
+ default: true,
154
+ },
155
+ // 通话类型 1语音,2视频
156
+ callType: {
157
+ type: [String, Number],
158
+ default: 1,
159
+ },
160
+ // 窗口背景色
161
+ bgColor: {
162
+ type: String,
163
+ default: '#000',
164
+ },
165
+ // 铃声
166
+ bellsUrl: {
167
+ type: String,
168
+ default: () => `${cdn.baseUrl}/files/audios/calling.wav`,
169
+ },
170
+ },
171
+ data() {
172
+ return {
173
+ start: 0,
174
+ zoom: false,
175
+ touched: null,
176
+ offset: {
177
+ top: 280,
178
+ left: 280,
179
+ },
180
+ enableMic: false,
181
+ enableCamera: this.callType == 2,
182
+ enableSpeaker: this.callType == 2,
183
+ frontCamera: true,
184
+ };
185
+ },
186
+ computed: {
187
+ systemInfo() {
188
+ return this.$store.state.system.info;
189
+ },
190
+ roomStyle({ systemInfo, zoom, offset }) {
191
+ const style = {
192
+ paddingTop: `${systemInfo.topStatusBarHeight}px`,
193
+ };
194
+ if (zoom) {
195
+ style.transform = `translateX(${offset.left}px) translateY(${offset.top}px)`;
196
+ }
197
+ return style;
198
+ },
199
+ trtcStyle({ systemInfo, bgColor }) {
200
+ return {
201
+ backgroundColor: bgColor,
202
+ paddingTop: `${systemInfo.topBarTitleHeight}px`,
203
+ };
204
+ },
205
+ headerStyle({ systemInfo }) {
206
+ return {
207
+ height: `${systemInfo.titleHeight}px`,
208
+ };
209
+ },
210
+ titleStyle() {
211
+ return {
212
+ transform: 'translateY(10vh)',
213
+ };
214
+ },
215
+ buttons({ enableCamera, enableSpeaker, enableMic, frontCamera, callType, start }) {
216
+ const buttons = [];
217
+ if (start) {
218
+ buttons.push({
219
+ icon: `${enableMic ? '' : 'disable-'}microphone`,
220
+ key: 'microphone',
221
+ text: `麦克风${enableMic ? '开启' : '关闭'}`,
222
+ light: enableMic,
223
+ });
224
+ } else if (callType == 2) {
225
+ buttons.push({
226
+ icon: 'switch-camera',
227
+ key: 'switch-camera',
228
+ text: `前置摄像头${frontCamera ? '开启' : '关闭'}`,
229
+ light: frontCamera,
230
+ });
231
+ }
232
+ if (start || callType == 2) {
233
+ buttons.push({
234
+ icon: `${enableSpeaker ? '' : 'disable-'}speaker`,
235
+ key: 'speaker',
236
+ text: `扬声器${enableSpeaker ? '开启' : '关闭'}`,
237
+ light: enableSpeaker,
238
+ });
239
+ }
240
+ if (callType == 2) {
241
+ buttons.push({
242
+ icon: `${enableCamera ? '' : 'disable-'}camera`,
243
+ key: 'camera',
244
+ text: `摄像头${enableCamera ? '开启' : '关闭'}`,
245
+ light: enableCamera,
246
+ });
247
+ }
248
+ return buttons;
249
+ },
250
+ tips() {
251
+ return `邀请你进行通话...`;
252
+ },
253
+ },
254
+ watch: {
255
+ zoom(e) {
256
+ this.$emit('zoom', e);
257
+ },
258
+ },
259
+ methods: {
260
+ leave(players) {
261
+ if (!players.length) {
262
+ this.handler('leave');
263
+ }
264
+ },
265
+ join(players) {
266
+ if (players.length === 1) {
267
+ this.$refs.trtc.frontUserId = players[0].userID;
268
+ }
269
+ },
270
+ handler(type) {
271
+ uni.$uv.throttle(() => {
272
+ switch (type) {
273
+ case 'zoom':
274
+ if (this.zoom) {
275
+ this.zoom = false;
276
+ }
277
+ break;
278
+ case 'accept':
279
+ this.start = Date.now();
280
+ this.audioContext?.stop();
281
+ this.enableMic = true;
282
+ this.$refs.trtc.start();
283
+ this.$emit(type);
284
+ break;
285
+ case 'leave':
286
+ this.$emit(type);
287
+ break;
288
+ case 'hangup':
289
+ this.audioContext?.stop();
290
+ this.$emit(type);
291
+ break;
292
+ case 'switch-camera':
293
+ this.frontCamera = !this.frontCamera;
294
+ break;
295
+ case 'microphone':
296
+ this.enableMic = !this.enableMic;
297
+ break;
298
+ case 'speaker':
299
+ this.enableSpeaker = !this.enableSpeaker;
300
+ break;
301
+ case 'camera':
302
+ this.enableCamera = !this.enableCamera;
303
+ break;
304
+ }
305
+ });
306
+ },
307
+ timerChange(e) {
308
+ this.duration = e;
309
+ },
310
+ touchStart(e) {
311
+ if (this.zoom) {
312
+ this.touched = Object.assign({}, e.touches[0], this.offset);
313
+ }
314
+ },
315
+ touchMove(e) {
316
+ if (this.touched) {
317
+ const { pageX, pageY, top, left } = this.touched;
318
+ this.offset = {
319
+ top: top + (e.touches[0].pageY - pageY),
320
+ left: left + (e.touches[0].pageX - pageX),
321
+ };
322
+ }
323
+ },
324
+ touchEnd() {
325
+ this.touched = null;
326
+ },
327
+ createBells() {
328
+ if (!this.audioContext) {
329
+ const audioContext = uni.createInnerAudioContext();
330
+ audioContext.autoplay = true;
331
+ audioContext.loop = true;
332
+ audioContext.src = this.bellsUrl;
333
+ this.audioContext = audioContext;
334
+ uni.setKeepScreenOn({ keepScreenOn: true });
335
+ }
336
+ },
337
+ destroyBells() {
338
+ if (this.audioContext) {
339
+ this.audioContext.stop();
340
+ this.audioContext.destroy();
341
+ this.audioContext = null;
342
+ uni.setKeepScreenOn({ keepScreenOn: false });
343
+ }
344
+ },
345
+ },
346
+ mounted() {
347
+ this.createBells();
348
+ },
349
+ beforeUnmount() {
350
+ this.destroyBells();
351
+ },
352
+ };
353
+ </script>
354
+
355
+ <style lang="scss">
356
+ @import './iconfont.scss';
357
+ </style>
358
+
359
+ <style lang="scss" scoped>
360
+ .trtc-room {
361
+ position: fixed;
362
+ top: 0;
363
+ left: 0;
364
+ right: 0;
365
+ bottom: 0;
366
+ width: 100vw;
367
+ height: 100vh;
368
+ color: rgba(255, 255, 255, 1);
369
+ padding: 32rpx;
370
+ & > view {
371
+ position: relative;
372
+ z-index: 1;
373
+ }
374
+ &-zoom {
375
+ width: 160rpx;
376
+ height: auto;
377
+ border: 1px solid $uv-border-color;
378
+ border-radius: 16rpx;
379
+ background-color: #fff;
380
+ color: $uv-success;
381
+ top: auto;
382
+ right: auto;
383
+ bottom: auto;
384
+ left: auto;
385
+ padding: 32rpx 24rpx 24rpx !important;
386
+ text-align: center;
387
+ overflow: hidden;
388
+ .trtc-room-header,
389
+ .trtc-room-handler > view {
390
+ display: none;
391
+ }
392
+ .trtc-room-handler {
393
+ position: static !important;
394
+ & > view:first-child {
395
+ margin-top: 0;
396
+ display: flex;
397
+ flex-direction: column;
398
+ & > view:last-child {
399
+ margin-top: 20rpx;
400
+ }
401
+ }
402
+ }
403
+ ::v-deep .trtc {
404
+ display: none;
405
+ }
406
+ &-video {
407
+ width: 160rpx;
408
+ height: 250rpx;
409
+ border: none;
410
+ background-color: #000;
411
+ padding: 0 !important;
412
+ ::v-deep .trtc {
413
+ display: block;
414
+ padding: 10rpx !important;
415
+ &:before {
416
+ content: '';
417
+ background-color: transparent;
418
+ position: absolute;
419
+ top: 0;
420
+ right: 0;
421
+ bottom: 0;
422
+ left: 0;
423
+ z-index: 2;
424
+ }
425
+ &-stream {
426
+ width: 31rpx !important;
427
+ height: 47rpx !important;
428
+ margin: 0 !important;
429
+ &.front {
430
+ width: 100% !important;
431
+ height: 100% !important;
432
+ }
433
+ }
434
+ }
435
+ }
436
+ }
437
+ &-header {
438
+ & > view {
439
+ &:nth-child(2) {
440
+ flex: 1;
441
+ text-align: center;
442
+ height: 100%;
443
+ display: flex;
444
+ align-items: center;
445
+ justify-content: center;
446
+ }
447
+ &:first-child {
448
+ position: absolute;
449
+ left: 0;
450
+ top: 50%;
451
+ transform: translateY(-50%);
452
+ }
453
+ }
454
+ }
455
+ &-handler {
456
+ position: absolute !important;
457
+ bottom: 120rpx;
458
+ left: 32rpx;
459
+ right: 32rpx;
460
+ font-size: 28rpx;
461
+ & > view {
462
+ margin-top: 80rpx;
463
+ display: flex;
464
+ & > view {
465
+ flex: 1;
466
+ display: flex;
467
+ justify-content: center;
468
+ align-items: center;
469
+ }
470
+ }
471
+ }
472
+ &-button {
473
+ display: flex;
474
+ flex-direction: column;
475
+ align-items: center;
476
+ justify-content: flex-start;
477
+ & > view {
478
+ display: flex;
479
+ justify-content: center;
480
+ align-items: center;
481
+ width: 120rpx;
482
+ height: 120rpx;
483
+ border-radius: 120rpx;
484
+ background-color: #161413;
485
+ }
486
+ & > text {
487
+ margin-top: 16rpx;
488
+ }
489
+ &.error {
490
+ & > view {
491
+ background-color: $uv-error;
492
+ color: #fff;
493
+ }
494
+ }
495
+ &.success {
496
+ & > view {
497
+ background-color: $uv-success;
498
+ color: #fff;
499
+ }
500
+ }
501
+ &.light {
502
+ & > view {
503
+ background-color: rgba(255, 255, 255, 1);
504
+ color: #161413;
505
+ }
506
+ }
507
+ }
508
+ ::v-deep .trtc {
509
+ padding: 32rpx;
510
+ &-streams {
511
+ display: flex;
512
+ flex-direction: column;
513
+ align-items: flex-end;
514
+ }
515
+ &-stream {
516
+ width: 194rpx;
517
+ height: 258rpx;
518
+ border-radius: 8rpx;
519
+ margin: 32rpx 0 0 32rpx;
520
+ border: 4rpx solid rgba(255, 255, 255, 1);
521
+ }
522
+ }
523
+ }
524
+ </style>
@@ -0,0 +1,59 @@
1
+ @font-face {
2
+ font-family: "icon-rtc"; /* Project id 4732578 */
3
+ src:
4
+ url("//at.alicdn.com/t/c/font_4732578_jkzp60fo53h.woff2?t=1730615518353") format("woff2"),
5
+ url("//at.alicdn.com/t/c/font_4732578_jkzp60fo53h.woff?t=1730615518353") format("woff"),
6
+ url("//at.alicdn.com/t/c/font_4732578_jkzp60fo53h.ttf?t=1730615518353") format("truetype");
7
+ }
8
+
9
+ .icon-rtc {
10
+ font-family: "icon-rtc" !important;
11
+ font-size: 16px;
12
+ font-style: normal;
13
+ -webkit-font-smoothing: antialiased;
14
+ -moz-osx-font-smoothing: grayscale;
15
+ }
16
+
17
+ .icon-rtc-call:before {
18
+ content: "\e655";
19
+ }
20
+
21
+ .icon-rtc-zoom:before {
22
+ content: "\e607";
23
+ }
24
+
25
+ .icon-rtc-microphone:before {
26
+ content: "\e600";
27
+ }
28
+
29
+ .icon-rtc-disable-microphone:before {
30
+ content: "\e601";
31
+ }
32
+
33
+ .icon-rtc-calling:before {
34
+ content: "\e602";
35
+ }
36
+
37
+ .icon-rtc-disable-speaker:before {
38
+ content: "\e603";
39
+ }
40
+
41
+ .icon-rtc-speaker:before {
42
+ content: "\e604";
43
+ }
44
+
45
+ .icon-rtc-disable-camera:before {
46
+ content: "\e605";
47
+ }
48
+
49
+ .icon-rtc-camera:before {
50
+ content: "\e606";
51
+ }
52
+
53
+ .icon-rtc-hangup:before {
54
+ content: "\e7f6";
55
+ }
56
+
57
+ .icon-rtc-switch-camera:before {
58
+ content: "\e65d";
59
+ }