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