oxy-uni-ui 2.1.1 → 2.1.2

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 (183) hide show
  1. package/attributes.json +1 -1
  2. package/components/common/abstracts/variable.scss +13 -2
  3. package/components/oxy-checkbox/index.scss +37 -2
  4. package/components/oxy-sort-button/index.scss +3 -4
  5. package/components/oxy-tag/index.scss +157 -17
  6. package/components/oxy-tag/oxy-tag.vue +14 -2
  7. package/components/oxy-tag/types.ts +9 -0
  8. package/dev-tools.ts +2 -0
  9. package/devTools/components/DevToolsOverlay.vue +56 -0
  10. package/devTools/components/DevToolsUiHost.vue +589 -0
  11. package/devTools/config.js +55 -0
  12. package/devTools/core/components/mpDevBubble.vue +174 -0
  13. package/devTools/core/libs/createH5Bubble.js +156 -0
  14. package/devTools/core/libs/devCache.js +151 -0
  15. package/devTools/core/libs/devOptions.js +163 -0
  16. package/devTools/core/libs/devUi.js +219 -0
  17. package/devTools/core/libs/drawView.js +140 -0
  18. package/devTools/core/libs/errorReport.js +64 -0
  19. package/devTools/core/libs/jsonCompress.js +334 -0
  20. package/devTools/core/libs/logReport.js +59 -0
  21. package/devTools/core/libs/pageLinkList.js +125 -0
  22. package/devTools/core/libs/timeFormat.js +94 -0
  23. package/devTools/core/proxy/console.js +430 -0
  24. package/devTools/core/proxy/index.js +36 -0
  25. package/devTools/core/proxy/request.js +495 -0
  26. package/devTools/core/proxy/storage.js +113 -0
  27. package/devTools/core/proxy/uniBus.js +153 -0
  28. package/devTools/core/proxy/uniListen.js +192 -0
  29. package/devTools/core/proxy/vueMixin.js +120 -0
  30. package/devTools/index.js +168 -0
  31. package/devTools/page/components/bottomTools.vue +1046 -0
  32. package/devTools/page/components/dialog/addStorage.vue +204 -0
  33. package/devTools/page/components/dialog/createDir.vue +366 -0
  34. package/devTools/page/components/dialog/editDialog.vue +192 -0
  35. package/devTools/page/components/dialog/routeDialog.vue +184 -0
  36. package/devTools/page/components/dialog/sendRequest.vue +603 -0
  37. package/devTools/page/components/dialog/textFileEditDialog.vue +391 -0
  38. package/devTools/page/components/libs/appDelDir.js +86 -0
  39. package/devTools/page/components/libs/dirReader.js +248 -0
  40. package/devTools/page/components/libs/fileSize.js +15 -0
  41. package/devTools/page/components/libs/getRuntimeInfo.js +134 -0
  42. package/devTools/page/components/listItem/consoleItem.vue +314 -0
  43. package/devTools/page/components/listItem/errorItem.vue +292 -0
  44. package/devTools/page/components/listItem/fileSysItem.vue +533 -0
  45. package/devTools/page/components/listItem/infoList.vue +100 -0
  46. package/devTools/page/components/listItem/jsRunnerItem.vue +255 -0
  47. package/devTools/page/components/listItem/logItem.vue +193 -0
  48. package/devTools/page/components/listItem/networkItem.vue +398 -0
  49. package/devTools/page/components/listItem/objectAnalysis.vue +651 -0
  50. package/devTools/page/components/listItem/pages.vue +319 -0
  51. package/devTools/page/components/listItem/routeItem.vue +153 -0
  52. package/devTools/page/components/listItem/setting.vue +734 -0
  53. package/devTools/page/components/listItem/storageList.vue +681 -0
  54. package/devTools/page/components/listItem/tools.vue +315 -0
  55. package/devTools/page/components/listItem/vuexList.vue +599 -0
  56. package/devTools/page/components/main.vue +1867 -0
  57. package/devTools/page/components/mixins/animationControl.js +91 -0
  58. package/devTools/page/components/mixins/mp.js +83 -0
  59. package/devTools/page/components/ui/btnTabs.vue +90 -0
  60. package/devTools/page/components/ui/codeHisPicker.vue +172 -0
  61. package/devTools/page/components/ui/h5Cell.vue +13 -0
  62. package/devTools/page/components/ui/menuBtn.vue +94 -0
  63. package/devTools/page/components/ui/mobileSwiperScroll.vue +74 -0
  64. package/devTools/page/components/ui/requestSpeedLimit.vue +52 -0
  65. package/devTools/page/components/ui/requestTimeoutMock.vue +55 -0
  66. package/devTools/page/components/ui/subTitleBar.vue +101 -0
  67. package/devTools/page/static/copy.png +0 -0
  68. package/devTools/page/static/delete.png +0 -0
  69. package/devTools/page/static/fileSys/AI.png +0 -0
  70. package/devTools/page/static/fileSys/DWG.png +0 -0
  71. package/devTools/page/static/fileSys/EXE.png +0 -0
  72. package/devTools/page/static/fileSys/GIF.png +0 -0
  73. package/devTools/page/static/fileSys/HTML.png +0 -0
  74. package/devTools/page/static/fileSys/PSD.png +0 -0
  75. package/devTools/page/static/fileSys/RVT.png +0 -0
  76. package/devTools/page/static/fileSys/SKP.png +0 -0
  77. package/devTools/page/static/fileSys/SVG.png +0 -0
  78. package/devTools/page/static/fileSys/excel.png +0 -0
  79. package/devTools/page/static/fileSys/pdf.png +0 -0
  80. package/devTools/page/static/fileSys/pptl.png +0 -0
  81. package/devTools/page/static/fileSys/shipin.png +0 -0
  82. package/devTools/page/static/fileSys/tupian.png +0 -0
  83. package/devTools/page/static/fileSys/txt.png +0 -0
  84. package/devTools/page/static/fileSys/weizhiwenjian.png +0 -0
  85. package/devTools/page/static/fileSys/wenjianjia.png +0 -0
  86. package/devTools/page/static/fileSys/word.png +0 -0
  87. package/devTools/page/static/fileSys/yasuo.png +0 -0
  88. package/devTools/page/static/fileSys/yinpin.png +0 -0
  89. package/devTools/page/static/fold.png +0 -0
  90. package/devTools/page/static/menu.png +0 -0
  91. package/devTools/page/static/refresh.png +0 -0
  92. package/devTools/page/static/unfold.png +0 -0
  93. package/devTools/tools.vue +25 -0
  94. package/devTools/type/devTools.d.ts +406 -0
  95. package/oxy-dev-tools/components/DevToolsUiHost.vue +555 -0
  96. package/oxy-dev-tools/config.js +61 -0
  97. package/oxy-dev-tools/core/components/mpDevBubble.vue +176 -0
  98. package/oxy-dev-tools/core/libs/createH5Bubble.js +156 -0
  99. package/oxy-dev-tools/core/libs/devCache.js +149 -0
  100. package/oxy-dev-tools/core/libs/devOptions.js +160 -0
  101. package/oxy-dev-tools/core/libs/devUi.js +219 -0
  102. package/oxy-dev-tools/core/libs/drawView.js +144 -0
  103. package/oxy-dev-tools/core/libs/errorReport.js +60 -0
  104. package/oxy-dev-tools/core/libs/jsonCompress.js +328 -0
  105. package/oxy-dev-tools/core/libs/logReport.js +55 -0
  106. package/oxy-dev-tools/core/libs/pageLinkList.js +121 -0
  107. package/oxy-dev-tools/core/libs/timeFormat.js +93 -0
  108. package/oxy-dev-tools/core/proxy/console.js +398 -0
  109. package/oxy-dev-tools/core/proxy/index.js +33 -0
  110. package/oxy-dev-tools/core/proxy/request.js +473 -0
  111. package/oxy-dev-tools/core/proxy/storage.js +96 -0
  112. package/oxy-dev-tools/core/proxy/uniBus.js +148 -0
  113. package/oxy-dev-tools/core/proxy/uniListen.js +190 -0
  114. package/oxy-dev-tools/core/proxy/vueMixin.js +115 -0
  115. package/oxy-dev-tools/index.ts +183 -0
  116. package/oxy-dev-tools/oxy-dev-tools.vue +62 -0
  117. package/oxy-dev-tools/page/components/bottomTools.vue +933 -0
  118. package/oxy-dev-tools/page/components/dialog/addStorage.vue +184 -0
  119. package/oxy-dev-tools/page/components/dialog/createDir.vue +352 -0
  120. package/oxy-dev-tools/page/components/dialog/editDialog.vue +178 -0
  121. package/oxy-dev-tools/page/components/dialog/routeDialog.vue +170 -0
  122. package/oxy-dev-tools/page/components/dialog/sendRequest.vue +530 -0
  123. package/oxy-dev-tools/page/components/dialog/textFileEditDialog.vue +379 -0
  124. package/oxy-dev-tools/page/components/libs/appDelDir.js +77 -0
  125. package/oxy-dev-tools/page/components/libs/dirReader.js +239 -0
  126. package/oxy-dev-tools/page/components/libs/fileSize.js +15 -0
  127. package/oxy-dev-tools/page/components/libs/getRuntimeInfo.js +132 -0
  128. package/oxy-dev-tools/page/components/listItem/consoleItem.vue +292 -0
  129. package/oxy-dev-tools/page/components/listItem/errorItem.vue +268 -0
  130. package/oxy-dev-tools/page/components/listItem/fileSysItem.vue +511 -0
  131. package/oxy-dev-tools/page/components/listItem/infoList.vue +89 -0
  132. package/oxy-dev-tools/page/components/listItem/jsRunnerItem.vue +236 -0
  133. package/oxy-dev-tools/page/components/listItem/logItem.vue +185 -0
  134. package/oxy-dev-tools/page/components/listItem/networkItem.vue +362 -0
  135. package/oxy-dev-tools/page/components/listItem/objectAnalysis.vue +642 -0
  136. package/oxy-dev-tools/page/components/listItem/pages.vue +285 -0
  137. package/oxy-dev-tools/page/components/listItem/routeItem.vue +140 -0
  138. package/oxy-dev-tools/page/components/listItem/setting.vue +687 -0
  139. package/oxy-dev-tools/page/components/listItem/storageList.vue +623 -0
  140. package/oxy-dev-tools/page/components/listItem/tools.vue +273 -0
  141. package/oxy-dev-tools/page/components/listItem/vuexList.vue +559 -0
  142. package/oxy-dev-tools/page/components/main.vue +1824 -0
  143. package/oxy-dev-tools/page/components/mixins/animationControl.js +80 -0
  144. package/oxy-dev-tools/page/components/mixins/mp.js +76 -0
  145. package/oxy-dev-tools/page/components/ui/btnTabs.vue +77 -0
  146. package/oxy-dev-tools/page/components/ui/codeHisPicker.vue +161 -0
  147. package/oxy-dev-tools/page/components/ui/h5Cell.vue +13 -0
  148. package/oxy-dev-tools/page/components/ui/menuBtn.vue +87 -0
  149. package/oxy-dev-tools/page/components/ui/mobileSwiperScroll.vue +71 -0
  150. package/oxy-dev-tools/page/components/ui/requestSpeedLimit.vue +47 -0
  151. package/oxy-dev-tools/page/components/ui/requestTimeoutMock.vue +50 -0
  152. package/oxy-dev-tools/page/components/ui/subTitleBar.vue +87 -0
  153. package/oxy-dev-tools/page/static/copy.png +0 -0
  154. package/oxy-dev-tools/page/static/delete.png +0 -0
  155. package/oxy-dev-tools/page/static/fileSys/AI.png +0 -0
  156. package/oxy-dev-tools/page/static/fileSys/DWG.png +0 -0
  157. package/oxy-dev-tools/page/static/fileSys/EXE.png +0 -0
  158. package/oxy-dev-tools/page/static/fileSys/GIF.png +0 -0
  159. package/oxy-dev-tools/page/static/fileSys/HTML.png +0 -0
  160. package/oxy-dev-tools/page/static/fileSys/PSD.png +0 -0
  161. package/oxy-dev-tools/page/static/fileSys/RVT.png +0 -0
  162. package/oxy-dev-tools/page/static/fileSys/SKP.png +0 -0
  163. package/oxy-dev-tools/page/static/fileSys/SVG.png +0 -0
  164. package/oxy-dev-tools/page/static/fileSys/excel.png +0 -0
  165. package/oxy-dev-tools/page/static/fileSys/pdf.png +0 -0
  166. package/oxy-dev-tools/page/static/fileSys/pptl.png +0 -0
  167. package/oxy-dev-tools/page/static/fileSys/shipin.png +0 -0
  168. package/oxy-dev-tools/page/static/fileSys/tupian.png +0 -0
  169. package/oxy-dev-tools/page/static/fileSys/txt.png +0 -0
  170. package/oxy-dev-tools/page/static/fileSys/weizhiwenjian.png +0 -0
  171. package/oxy-dev-tools/page/static/fileSys/wenjianjia.png +0 -0
  172. package/oxy-dev-tools/page/static/fileSys/word.png +0 -0
  173. package/oxy-dev-tools/page/static/fileSys/yasuo.png +0 -0
  174. package/oxy-dev-tools/page/static/fileSys/yinpin.png +0 -0
  175. package/oxy-dev-tools/page/static/fold.png +0 -0
  176. package/oxy-dev-tools/page/static/menu.png +0 -0
  177. package/oxy-dev-tools/page/static/refresh.png +0 -0
  178. package/oxy-dev-tools/page/static/unfold.png +0 -0
  179. package/oxy-dev-tools/tools.vue +22 -0
  180. package/oxy-dev-tools/type/devTools.d.ts +406 -0
  181. package/package.json +1 -1
  182. package/tags.json +1 -1
  183. package/web-types.json +1 -1
@@ -0,0 +1,681 @@
1
+ <template>
2
+ <view class="storageList">
3
+ <view
4
+ v-if="!isLoaded"
5
+ class="dataLoading"
6
+ >
7
+ <text class="status">加载中</text>
8
+ </view>
9
+
10
+ <view
11
+ v-else-if="isEmpty"
12
+ class="dataLoading"
13
+ >
14
+ <text class="status">无缓存数据</text>
15
+ </view>
16
+
17
+ <template v-else>
18
+ <view
19
+ v-for="(item, index) in storageList"
20
+ :key="`${item.key}_${index}`"
21
+ class="storageRow"
22
+ @click="openValueViewer(item)"
23
+ >
24
+ <view class="section keySection">
25
+ <text class="sectionLabel">KEY</text>
26
+ <view class="keyContentRow">
27
+ <text class="keyText">{{ item.key }}</text>
28
+ <view
29
+ class="detailBtn"
30
+ @click.stop="openValueViewer(item)"
31
+ >
32
+ <text class="detailBtnText">查看详情</text>
33
+ </view>
34
+ </view>
35
+ </view>
36
+
37
+ <view class="sectionDivider" />
38
+
39
+ <view class="section valueSection">
40
+ <text class="sectionLabel">VALUE</text>
41
+ <text class="sectionText valueText">{{ item.preview }}</text>
42
+ </view>
43
+ </view>
44
+ </template>
45
+
46
+ <view
47
+ v-if="valueViewer.show"
48
+ class="valueViewerMask"
49
+ @click="closeValueViewer"
50
+ >
51
+ <view
52
+ class="valueViewerCard"
53
+ @click.stop
54
+ >
55
+ <view class="viewerHead">
56
+ <text class="viewerTitle">键值详情</text>
57
+ <text
58
+ class="viewerClose"
59
+ @click.stop="closeValueViewer"
60
+ >
61
+ ×
62
+ </text>
63
+ </view>
64
+
65
+ <view class="viewerSection">
66
+ <view class="viewerKeyRow">
67
+ <text class="sectionLabel">KEY</text>
68
+ <text class="viewerKey">{{ valueViewer.key }}</text>
69
+ </view>
70
+ </view>
71
+
72
+ <view class="viewerSection">
73
+ <text class="sectionLabel">VALUE</text>
74
+ <scroll-view
75
+ scroll-y
76
+ class="viewerBody"
77
+ >
78
+ <text class="viewerText">{{ valueViewer.fullText }}</text>
79
+ </scroll-view>
80
+ </view>
81
+
82
+ <view class="viewerActions">
83
+ <view
84
+ class="viewerBtn"
85
+ @click.stop="copyViewerValue"
86
+ >
87
+ <text class="viewerBtnText">复制</text>
88
+ </view>
89
+
90
+ <view
91
+ class="viewerBtn"
92
+ @click.stop="editViewerValue"
93
+ >
94
+ <text class="viewerBtnText">编辑</text>
95
+ </view>
96
+
97
+ <view
98
+ class="viewerBtn danger"
99
+ @click.stop="deleteViewerValue"
100
+ >
101
+ <text class="viewerBtnText">删除</text>
102
+ </view>
103
+ </view>
104
+ </view>
105
+ </view>
106
+ </view>
107
+ </template>
108
+
109
+ <script>
110
+ // #ifdef MP
111
+ import devCache from '../../../core/libs/devCache'
112
+ // #endif
113
+ import devUi from '../../../core/libs/devUi.js'
114
+
115
+ export default {
116
+ data() {
117
+ return {
118
+ isLoaded: false,
119
+ isEmpty: false,
120
+ storageType: 'localStorage',
121
+ storageList: [],
122
+ maxPreviewLength: 120,
123
+ loadToken: 0,
124
+ valueViewer: {
125
+ show: false,
126
+ key: '',
127
+ fullText: '',
128
+ },
129
+ }
130
+ },
131
+ beforeUnmount() {
132
+ this.loadToken += 1
133
+ uni.$emit('devTools_valueViewer_hide')
134
+ },
135
+ beforeDestroy() {
136
+ this.loadToken += 1
137
+ uni.$emit('devTools_valueViewer_hide')
138
+ },
139
+ methods: {
140
+ async getData(storageType) {
141
+ const currentToken = ++this.loadToken
142
+ this.isLoaded = false
143
+ this.storageType = storageType || this.storageType || 'localStorage'
144
+ const activeStorageType = this.storageType
145
+ const data = {}
146
+
147
+ // #ifdef APP-PLUS
148
+ const keys = plus.storage.getAllKeys()
149
+ for (let i = 0; i < keys.length; i++) {
150
+ const key = keys[i]
151
+ if (key.indexOf('devTools_') === 0) {
152
+ continue
153
+ }
154
+ data[key] = uni.getStorageSync(key)
155
+ }
156
+ // #endif
157
+
158
+ // #ifdef H5
159
+ if (activeStorageType === 'localStorage') {
160
+ for (let i = 0; i < localStorage.length; i++) {
161
+ const key = localStorage.key(i)
162
+ if (!key || key.indexOf('devTools_') === 0) {
163
+ continue
164
+ }
165
+ data[key] = localStorage.getItem(key)
166
+ }
167
+ }
168
+ else if (activeStorageType === 'sessionStorage') {
169
+ for (let i = 0; i < sessionStorage.length; i++) {
170
+ const key = sessionStorage.key(i)
171
+ if (!key || key.indexOf('devTools_') === 0) {
172
+ continue
173
+ }
174
+ data[key] = sessionStorage.getItem(key)
175
+ }
176
+ }
177
+ else if (activeStorageType === 'cookie') {
178
+ document.cookie.split(';').forEach((cookieStr) => {
179
+ if (!cookieStr || cookieStr.trim() === '') {
180
+ return
181
+ }
182
+ const [name, value] = cookieStr.trim().split('=')
183
+ if (!name) {
184
+ return
185
+ }
186
+ let parsedKey = name
187
+ let parsedValue = value || ''
188
+ try {
189
+ parsedKey = decodeURIComponent(name)
190
+ parsedValue = decodeURIComponent(value || '')
191
+ }
192
+ catch (error) {}
193
+ data[parsedKey] = parsedValue
194
+ })
195
+ }
196
+ // #endif
197
+
198
+ // #ifdef MP
199
+ let keyList = devCache.get('storage')
200
+ if (!keyList) {
201
+ keyList = []
202
+ }
203
+ for (let i = 0; i < keyList.length; i++) {
204
+ const key = keyList[i]
205
+ if (key.indexOf('devTools_') === 0) {
206
+ continue
207
+ }
208
+ data[key] = uni.getStorageSync(key)
209
+ }
210
+ // #endif
211
+
212
+ if (currentToken !== this.loadToken) {
213
+ return
214
+ }
215
+
216
+ this.storageList = this.buildStorageList(data)
217
+ this.isEmpty = this.storageList.length === 0
218
+ this.isLoaded = true
219
+ this.closeValueViewer()
220
+ },
221
+
222
+ buildStorageList(data) {
223
+ const keys = Object.keys(data || {})
224
+ return keys.map((key) => {
225
+ const fullText = this.formatStorageValue(data[key])
226
+ return {
227
+ key,
228
+ fullText,
229
+ preview: this.getPreviewText(fullText),
230
+ }
231
+ })
232
+ },
233
+
234
+ formatStorageValue(value) {
235
+ if (typeof value === 'string') {
236
+ return value
237
+ }
238
+ if (value === undefined) {
239
+ return 'undefined'
240
+ }
241
+ if (value === null) {
242
+ return 'null'
243
+ }
244
+ if (typeof value === 'boolean') {
245
+ return value ? 'true' : 'false'
246
+ }
247
+ if (typeof value === 'object') {
248
+ try {
249
+ return JSON.stringify(value, null, 2)
250
+ }
251
+ catch (error) {
252
+ return String(value)
253
+ }
254
+ }
255
+ return String(value)
256
+ },
257
+
258
+ getPreviewText(fullText) {
259
+ const singleLine = fullText.replace(/\s+/g, ' ').trim()
260
+ if (singleLine.length <= this.maxPreviewLength) {
261
+ return singleLine
262
+ }
263
+ return `${singleLine.slice(0, this.maxPreviewLength)}...`
264
+ },
265
+
266
+ openValueViewer(item) {
267
+ uni.$emit('devTools_valueViewer_show')
268
+ this.valueViewer = {
269
+ show: true,
270
+ key: item.key,
271
+ fullText: item.fullText,
272
+ }
273
+ },
274
+
275
+ closeValueViewer() {
276
+ if (this.valueViewer.show) {
277
+ uni.$emit('devTools_valueViewer_hide')
278
+ }
279
+ this.valueViewer = {
280
+ ...this.valueViewer,
281
+ show: false,
282
+ }
283
+ },
284
+
285
+ copyViewerValue() {
286
+ if (!this.valueViewer.show) {
287
+ return
288
+ }
289
+ this.copyToClipboard(this.buildCopyText(this.valueViewer.key, this.valueViewer.fullText))
290
+ },
291
+ copyToClipboard(data) {
292
+ uni.setClipboardData({
293
+ data,
294
+ success: () => {
295
+ devUi.showToast({
296
+ icon: 'success',
297
+ title: '复制成功',
298
+ })
299
+ },
300
+ })
301
+ },
302
+ buildCopyText(key, valueText) {
303
+ return `KEY: ${key}\nVALUE:\n${valueText}`
304
+ },
305
+
306
+ editViewerValue() {
307
+ const row = this.storageList.find(x => x.key === this.valueViewer.key)
308
+ if (!row) {
309
+ this.closeValueViewer()
310
+ return
311
+ }
312
+ this.closeValueViewer()
313
+ this.editItemValue(row)
314
+ },
315
+
316
+ deleteViewerValue() {
317
+ const row = this.storageList.find(x => x.key === this.valueViewer.key)
318
+ if (!row) {
319
+ this.closeValueViewer()
320
+ return
321
+ }
322
+ this.closeValueViewer()
323
+ this.deleteItem(row)
324
+ },
325
+
326
+ deleteItem(item) {
327
+ const key = item.key
328
+
329
+ // #ifdef H5
330
+ if (this.storageType === 'localStorage') {
331
+ localStorage.removeItem(key)
332
+ }
333
+ else if (this.storageType === 'sessionStorage') {
334
+ sessionStorage.removeItem(key)
335
+ }
336
+ else if (this.storageType === 'cookie') {
337
+ document.cookie = `${encodeURIComponent(key)}=;expires=${new Date(Date.now() - 1000).toUTCString()};path=/`
338
+ }
339
+ // #endif
340
+
341
+ // #ifndef H5
342
+ uni.removeStorageSync(key)
343
+ // #endif
344
+
345
+ devUi.showToast({
346
+ title: '删除成功!',
347
+ icon: 'success',
348
+ })
349
+
350
+ if (this.storageType === 'cookie') {
351
+ setTimeout(() => {
352
+ this.getData()
353
+ }, 1200)
354
+ }
355
+ else {
356
+ this.getData()
357
+ }
358
+ },
359
+
360
+ editItemValue(item) {
361
+ const key = item.key
362
+ let value = this.getItemRawValue(key)
363
+
364
+ if (typeof value === 'object' && value !== null) {
365
+ value = JSON.stringify(value)
366
+ }
367
+ else if (value === false) {
368
+ value = 'false'
369
+ }
370
+ else if (value === true) {
371
+ value = 'true'
372
+ }
373
+ else if (value === undefined || value === null) {
374
+ value = ''
375
+ }
376
+ else {
377
+ value = String(value)
378
+ }
379
+
380
+ uni.$emit('devTools_showEditDialog', {
381
+ title: `key:${key}`,
382
+ value,
383
+ })
384
+
385
+ uni.$on('devTools_editDialogClose', () => {
386
+ uni.$off('devTools_editDialogSaveSuccess')
387
+ uni.$off('devTools_editDialogClose')
388
+ })
389
+
390
+ uni.$on('devTools_editDialogSaveSuccess', (val) => {
391
+ uni.$off('devTools_editDialogSaveSuccess')
392
+ uni.$off('devTools_editDialogClose')
393
+
394
+ const oldValue = this.getItemRawValue(key)
395
+ if (oldValue === false || oldValue === true) {
396
+ if (val === 'true' || val === 'false') {
397
+ val = val === 'true'
398
+ }
399
+ }
400
+
401
+ // #ifdef H5
402
+ if (this.storageType === 'localStorage') {
403
+ localStorage.setItem(key, val)
404
+ }
405
+ else if (this.storageType === 'sessionStorage') {
406
+ sessionStorage.setItem(key, val)
407
+ }
408
+ else if (this.storageType === 'cookie') {
409
+ const cookieKey = encodeURIComponent(key)
410
+ const cookieVal = encodeURIComponent(val)
411
+ const cookie = `${cookieKey}=${cookieVal}; path=/; expires=${new Date(
412
+ new Date().getTime() + 86400 * 1000 * 365,
413
+ ).toGMTString()}`
414
+ document.cookie = cookie
415
+ }
416
+ // #endif
417
+
418
+ // #ifndef H5
419
+ uni.setStorageSync(key, val)
420
+ // #endif
421
+
422
+ devUi.showToast({
423
+ icon: 'success',
424
+ title: '保存成功',
425
+ })
426
+
427
+ setTimeout(() => {
428
+ this.getData()
429
+ }, 300)
430
+ })
431
+ },
432
+
433
+ getItemRawValue(key) {
434
+ // #ifdef H5
435
+ if (this.storageType === 'localStorage') {
436
+ return localStorage.getItem(key)
437
+ }
438
+ if (this.storageType === 'sessionStorage') {
439
+ return sessionStorage.getItem(key)
440
+ }
441
+ if (this.storageType === 'cookie') {
442
+ let cookieValue = ''
443
+ document.cookie.split(';').forEach((cookieStr) => {
444
+ const [name, value] = cookieStr.trim().split('=')
445
+ if (!name) {
446
+ return
447
+ }
448
+ let parsedName = name
449
+ let parsedValue = value || ''
450
+ try {
451
+ parsedName = decodeURIComponent(name)
452
+ parsedValue = decodeURIComponent(value || '')
453
+ }
454
+ catch (error) {}
455
+ if (parsedName === key) {
456
+ cookieValue = parsedValue
457
+ }
458
+ })
459
+ return cookieValue
460
+ }
461
+ // #endif
462
+
463
+ return uni.getStorageSync(key)
464
+ },
465
+ },
466
+ }
467
+ </script>
468
+
469
+ <style lang="scss" scoped>
470
+ .storageList {
471
+ padding: 16rpx 20rpx;
472
+ width: 100%;
473
+ box-sizing: border-box;
474
+ }
475
+
476
+ .dataLoading {
477
+ width: 100%;
478
+ box-sizing: border-box;
479
+ height: 220rpx;
480
+ margin: 10rpx 0;
481
+ border-radius: 16rpx;
482
+ border: 1px solid rgba(148, 163, 184, 0.2);
483
+ background: #f8fafc;
484
+ display: flex;
485
+ flex-direction: row;
486
+ align-items: center;
487
+ justify-content: center;
488
+
489
+ .status {
490
+ font-size: 24rpx;
491
+ color: #64748b;
492
+ line-height: 34rpx;
493
+ }
494
+ }
495
+
496
+ .storageRow {
497
+ width: 100%;
498
+ box-sizing: border-box;
499
+ border-radius: 16rpx;
500
+ border: 1px solid rgba(148, 163, 184, 0.18);
501
+ background: #fff;
502
+ margin: 0 0 12rpx;
503
+ padding: 14rpx 16rpx;
504
+ box-shadow: 0 4rpx 12rpx rgba(15, 23, 42, 0.04);
505
+ }
506
+
507
+ .section {
508
+ display: flex;
509
+ flex-direction: column;
510
+ }
511
+
512
+ .sectionLabel {
513
+ font-size: 18rpx;
514
+ line-height: 24rpx;
515
+ color: #94a3b8;
516
+ letter-spacing: 1rpx;
517
+ text-transform: uppercase;
518
+ }
519
+
520
+ .sectionText {
521
+ margin-top: 6rpx;
522
+ word-break: break-all;
523
+ }
524
+
525
+ .keyText {
526
+ flex: 1;
527
+ font-size: 24rpx;
528
+ line-height: 32rpx;
529
+ color: #0f172a;
530
+ font-weight: 500;
531
+ word-break: break-all;
532
+ padding-right: 12rpx;
533
+ }
534
+
535
+ .keyContentRow {
536
+ margin-top: 6rpx;
537
+ display: flex;
538
+ flex-direction: row;
539
+ align-items: center;
540
+ }
541
+
542
+ .detailBtn {
543
+ height: 44rpx;
544
+ padding: 0 14rpx;
545
+ border-radius: 22rpx;
546
+ border: 1px solid rgba(59, 130, 246, 0.26);
547
+ background: #eff6ff;
548
+ display: flex;
549
+ flex-direction: row;
550
+ align-items: center;
551
+ justify-content: center;
552
+ flex-shrink: 0;
553
+ }
554
+
555
+ .detailBtnText {
556
+ font-size: 20rpx;
557
+ line-height: 28rpx;
558
+ color: #2563eb;
559
+ }
560
+
561
+ .sectionDivider {
562
+ margin: 10rpx 0;
563
+ height: 1px;
564
+ background: rgba(148, 163, 184, 0.22);
565
+ }
566
+
567
+ .valueText {
568
+ font-size: 22rpx;
569
+ line-height: 30rpx;
570
+ color: #334155;
571
+ }
572
+
573
+ .valueViewerMask {
574
+ position: fixed;
575
+ left: 0;
576
+ right: 0;
577
+ top: var(--devtools-panel-top, 40vh);
578
+ bottom: 0;
579
+ background: rgba(15, 23, 42, 0.45);
580
+ z-index: 20;
581
+ display: flex;
582
+ align-items: center;
583
+ justify-content: center;
584
+ }
585
+
586
+ .valueViewerCard {
587
+ width: 700rpx;
588
+ max-height: calc(var(--devtools-panel-height, 60vh) - 40rpx);
589
+ border-radius: 16rpx;
590
+ background: #fff;
591
+ border: 1px solid rgba(148, 163, 184, 0.25);
592
+ padding: 14rpx;
593
+ display: flex;
594
+ flex-direction: column;
595
+ }
596
+
597
+ .viewerHead {
598
+ display: flex;
599
+ align-items: center;
600
+ justify-content: space-between;
601
+ gap: 14rpx;
602
+ }
603
+
604
+ .viewerTitle {
605
+ flex: 1;
606
+ font-size: 24rpx;
607
+ line-height: 32rpx;
608
+ color: #0f172a;
609
+ font-weight: 500;
610
+ }
611
+
612
+ .viewerClose {
613
+ font-size: 42rpx;
614
+ line-height: 32rpx;
615
+ color: #64748b;
616
+ }
617
+
618
+ .viewerSection {
619
+ margin-top: 12rpx;
620
+ }
621
+
622
+ .viewerKey {
623
+ margin-left: 10rpx;
624
+ font-size: 22rpx;
625
+ line-height: 32rpx;
626
+ color: #0f172a;
627
+ word-break: break-all;
628
+ }
629
+
630
+ .viewerKeyRow {
631
+ margin-top: 6rpx;
632
+ display: flex;
633
+ flex-direction: row;
634
+ align-items: center;
635
+ }
636
+
637
+ .viewerBody {
638
+ margin-top: 8rpx;
639
+ height: 560rpx;
640
+ padding: 10rpx;
641
+ background: #f8fafc;
642
+ border-radius: 10rpx;
643
+ border: 1px solid rgba(148, 163, 184, 0.16);
644
+ }
645
+
646
+ .viewerText {
647
+ font-size: 22rpx;
648
+ line-height: 32rpx;
649
+ color: #334155;
650
+ word-break: break-all;
651
+ white-space: pre-wrap;
652
+ }
653
+
654
+ .viewerActions {
655
+ margin-top: 12rpx;
656
+ display: flex;
657
+ justify-content: flex-end;
658
+ gap: 8rpx;
659
+ }
660
+
661
+ .viewerBtn {
662
+ min-width: 108rpx;
663
+ height: 56rpx;
664
+ border-radius: 10rpx;
665
+ background: #f1f5f9;
666
+ border: 1px solid rgba(148, 163, 184, 0.25);
667
+ display: flex;
668
+ align-items: center;
669
+ justify-content: center;
670
+
671
+ &.danger {
672
+ background: #fef2f2;
673
+ border-color: rgba(220, 38, 38, 0.25);
674
+ }
675
+ }
676
+
677
+ .viewerBtnText {
678
+ font-size: 22rpx;
679
+ color: #334155;
680
+ }
681
+ </style>