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,80 @@
1
+ // #ifdef APP-PLUS
2
+ const animation = weex.requireModule('animation')
3
+ // #endif
4
+ export default {
5
+ methods: {
6
+ /**
7
+ * 显示面板
8
+ */
9
+ panelShow() {
10
+ let that = this
11
+
12
+ let sys = uni.getSystemInfoSync()
13
+
14
+ animation.transition(that.$refs.mask, {
15
+ styles: {
16
+ opacity: 1,
17
+ height: sys.windowHeight + 'px'
18
+ },
19
+ duration: 200, //ms
20
+ timingFunction: 'linear',
21
+ delay: 0 //ms
22
+ })
23
+
24
+ let height = Math.ceil(sys.windowHeight * 0.8)
25
+
26
+ animation.transition(
27
+ that.$refs.panel,
28
+ {
29
+ styles: {
30
+ opacity: 1,
31
+ transform: `transform: translate(0px,${height}px)`
32
+ },
33
+ duration: 1, //ms
34
+ timingFunction: 'linear',
35
+ delay: 0 //ms
36
+ },
37
+ (res) => {
38
+ animation.transition(that.$refs.panel, {
39
+ styles: {
40
+ transform: 'transform: translate(0px,0px)'
41
+ },
42
+ duration: 200, //ms
43
+ timingFunction: 'linear',
44
+ delay: 0 //ms
45
+ })
46
+ }
47
+ )
48
+ },
49
+ /**
50
+ * 关闭面板
51
+ */
52
+ panelHide() {
53
+ let that = this
54
+
55
+ animation.transition(that.$refs.mask, {
56
+ styles: {
57
+ opacity: 0
58
+ },
59
+ duration: 200, //ms
60
+ timingFunction: 'linear',
61
+ delay: 0 //ms
62
+ })
63
+ let height = uni.upx2px(1000)
64
+ animation.transition(
65
+ that.$refs.panel,
66
+ {
67
+ styles: {
68
+ transform: `transform: translate(0px,${height}px)`
69
+ },
70
+ duration: 200, //ms
71
+ timingFunction: 'linear',
72
+ delay: 0 //ms
73
+ },
74
+ () => {
75
+ uni.$emit('devTools_panelHideSuccess')
76
+ }
77
+ )
78
+ }
79
+ }
80
+ }
@@ -0,0 +1,76 @@
1
+ export default {
2
+ data() {
3
+ return {
4
+ windowInfo: getWindowInfo()
5
+ }
6
+ },
7
+ computed: {
8
+ /**
9
+ * 小程序和H5的标题
10
+ */
11
+ navbarStyle() {
12
+ let windowInfo = getWindowInfo()
13
+ return {
14
+ statusBarHeightPx: windowInfo.system.statusBarHeight + 'px',
15
+ navbarHeightPx: windowInfo.navbar.bodyHeightPx + 'px'
16
+ }
17
+ }
18
+ },
19
+ methods: {
20
+ back() {
21
+ uni.$dev.hide()
22
+ }
23
+ }
24
+ }
25
+
26
+ /**
27
+ * 获取当前窗口数据
28
+ *
29
+ */
30
+ function getWindowInfo() {
31
+ let systemInfo = uni.getSystemInfoSync()
32
+ systemInfo.pixelRatio = Math.round(systemInfo.pixelRatio * 100) / 100
33
+
34
+ let windowInfo = {
35
+ system: systemInfo,
36
+ capsule: {
37
+ bottom: 78,
38
+ height: 30,
39
+ left: 283,
40
+ right: 363,
41
+ top: 48,
42
+ width: 0
43
+ },
44
+ navbar: {
45
+ heightPx: uni.upx2px(100) + systemInfo.statusBarHeight,
46
+ bodyHeightPx: uni.upx2px(100),
47
+ bodyWidthPx: systemInfo.windowWidth,
48
+ capsuleWidthPx: 0,
49
+ capsuleRightPx: 0
50
+ },
51
+
52
+ height: systemInfo.windowHeight * (750 / systemInfo.windowWidth),
53
+ width: 750,
54
+ statusBarHeight: systemInfo.statusBarHeight * (750 / systemInfo.windowWidth),
55
+ safeBottom: systemInfo.windowHeight - systemInfo.safeArea.bottom,
56
+ safeBottomRpx: (systemInfo.windowHeight - systemInfo.safeArea.bottom) * (750 / systemInfo.windowWidth),
57
+ /**
58
+ * 原生端 底部导航栏高度
59
+ */
60
+ footNavbarHeight: uni.upx2px(100) + (systemInfo.windowHeight - systemInfo.safeArea.bottom)
61
+ }
62
+
63
+ // #ifdef MP-QQ || MP-WEIXIN
64
+ let capsuleInfo = uni.getMenuButtonBoundingClientRect()
65
+ windowInfo.capsule = capsuleInfo
66
+ let capsuleToStatusBarPx = capsuleInfo.top - systemInfo.statusBarHeight //胶囊和状态栏之间的高度
67
+ windowInfo.navbar.bodyHeightPx = capsuleInfo.height + capsuleToStatusBarPx * 2
68
+ windowInfo.navbar.heightPx = windowInfo.navbar.bodyHeightPx + systemInfo.statusBarHeight
69
+ let capsuleWidthPx = (systemInfo.windowWidth - capsuleInfo.right) * 2 + capsuleInfo.width
70
+ windowInfo.navbar.bodyWidthPx = systemInfo.windowWidth - capsuleWidthPx
71
+ windowInfo.navbar.capsuleWidthPx = capsuleWidthPx
72
+ windowInfo.navbar.capsuleRightPx = capsuleWidthPx - (systemInfo.windowWidth - capsuleInfo.right)
73
+ // #endif
74
+
75
+ return windowInfo
76
+ }
@@ -0,0 +1,77 @@
1
+ <template>
2
+ <view class="btnTabs" v-if="list.length > 0">
3
+ <block v-for="(item, index) in list" :key="item.title">
4
+ <view class="btnTabsItem" :class="{ active: index == value }" @click="$emit('indexChange', index)">
5
+ <text class="tabsText" :class="{ active: index == value }">
6
+ {{ item.title }}
7
+ </text>
8
+ </view>
9
+ <view v-if="index != list.length - 1" class="splitLine"></view>
10
+ </block>
11
+ </view>
12
+ </template>
13
+ <script>
14
+ export default {
15
+ props: {
16
+ /**
17
+ * 按钮列表
18
+ */
19
+ list: {
20
+ type: Array,
21
+ default: () => []
22
+ },
23
+ /**
24
+ * 当前选中的按钮索引
25
+ */
26
+ value: {
27
+ type: Number,
28
+ default: 0
29
+ }
30
+ }
31
+ }
32
+ </script>
33
+ <style lang="scss" scoped>
34
+ .btnTabs {
35
+ display: flex;
36
+ flex-direction: row;
37
+ align-items: center;
38
+ border-radius: 14rpx;
39
+ overflow: hidden;
40
+ transform: translateZ(0);
41
+ height: 54rpx;
42
+ border: 1px solid rgba(15, 23, 42, 0.12);
43
+ background: #eef2f7;
44
+ box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
45
+ .btnTabsItem {
46
+ display: flex;
47
+ align-items: center;
48
+ justify-content: center;
49
+ flex-shrink: 0;
50
+ position: relative;
51
+ height: 54rpx;
52
+ padding: 0 16rpx;
53
+ background-color: transparent;
54
+ &.active {
55
+ background-color: #fff;
56
+ }
57
+ &:active {
58
+ opacity: 0.92;
59
+ }
60
+ .tabsText {
61
+ font-size: 24rpx;
62
+ line-height: 54rpx;
63
+ height: 54rpx;
64
+ white-space: nowrap;
65
+ color: #64748b;
66
+ &.active {
67
+ color: #2563eb;
68
+ }
69
+ }
70
+ }
71
+ .splitLine {
72
+ width: 1px;
73
+ height: 30rpx;
74
+ background-color: rgba(15, 23, 42, 0.12);
75
+ }
76
+ }
77
+ </style>
@@ -0,0 +1,161 @@
1
+ <template>
2
+ <view
3
+ class="codeHisPicker"
4
+ v-if="isShow"
5
+ @click="close"
6
+ :style="{
7
+ height: height + 'px'
8
+ }"
9
+ >
10
+ <view class="codeList" @click.stop>
11
+ <view class="head">
12
+ <view class="title">
13
+ <text class="titleText">历史运行代码:</text>
14
+ </view>
15
+ <view class="subTitle">
16
+ <text class="subTitleText">(保留100条运行记录)</text>
17
+ </view>
18
+ </view>
19
+ <scroll-view scroll-y class="codeScroll">
20
+ <view class="hisItem" v-for="(item, index) in list" :key="index" @click="selectedRow(item)">
21
+ <text class="hisItemCode">
22
+ {{ item }}
23
+ </text>
24
+ </view>
25
+ <view style="height: 100rpx"></view>
26
+ </scroll-view>
27
+ </view>
28
+ </view>
29
+ </template>
30
+ <script>
31
+ export default {
32
+ data() {
33
+ return {
34
+ /**
35
+ * 是否展示
36
+ */
37
+ isShow: false,
38
+ /**
39
+ * 筛选的列表
40
+ */
41
+ list: [],
42
+ /**
43
+ * 默认选中的索引
44
+ */
45
+ index: 0,
46
+ /**
47
+ * 选中的回调事件
48
+ */
49
+ callback: null,
50
+ /**
51
+ * 屏幕高度
52
+ */
53
+ height: uni.getSystemInfoSync().screenHeight
54
+ }
55
+ },
56
+ methods: {
57
+ /**
58
+ * 展示弹窗
59
+ */
60
+ show(list = []) {
61
+ let that = this
62
+ that.index = 0
63
+ that.list = list
64
+ that.isShow = true
65
+ return new Promise((yes) => {
66
+ that.callback = yes
67
+ })
68
+ },
69
+ /**
70
+ * 选择改变事件
71
+ */
72
+ pickerChange(e) {
73
+ that.callback = ''
74
+ console.log('e', e)
75
+ },
76
+ /**
77
+ * 关闭弹窗
78
+ */
79
+ close() {
80
+ this.isShow = false
81
+ },
82
+ /**
83
+ * 选择单行代码
84
+ */
85
+ selectedRow(row) {
86
+ this.callback(row)
87
+ this.close()
88
+ }
89
+ }
90
+ }
91
+ </script>
92
+ <style lang="scss" scoped>
93
+ .codeHisPicker {
94
+ position: fixed;
95
+ bottom: 0;
96
+ left: 0;
97
+ width: 750rpx;
98
+ background-color: rgba(0, 0, 0, 0.3);
99
+ /* #ifndef APP-PLUS */
100
+ backdrop-filter: blur(1px);
101
+ /* #endif */
102
+ display: flex;
103
+ flex-direction: column-reverse;
104
+ z-index: 999;
105
+ .codeList {
106
+ width: 750rpx;
107
+ border-radius: 20rpx 20rpx 0 0;
108
+ background-color: #fff;
109
+ .head {
110
+ padding: 20rpx;
111
+ border-bottom: 1px solid rgba(0, 0, 0, 0.2);
112
+ display: flex;
113
+ flex-direction: row;
114
+ align-items: center;
115
+ justify-content: space-between;
116
+ .title {
117
+ .titleText {
118
+ font-size: 24rpx;
119
+ line-height: 28rpx;
120
+ color: #333;
121
+ }
122
+ }
123
+ .subTitle {
124
+ display: flex;
125
+ flex-direction: row;
126
+ align-items: center;
127
+ .subTitleText {
128
+ font-size: 20rpx;
129
+ line-height: 28rpx;
130
+ color: #777;
131
+ }
132
+ }
133
+ }
134
+ .codeScroll {
135
+ height: 750rpx;
136
+ width: 750rpx;
137
+ .hisItem {
138
+ width: 750rpx;
139
+ padding: 10rpx 20rpx;
140
+ border-bottom: 1px solid rgba(0, 0, 0, 0.1);
141
+ .hisItemCode {
142
+ font-size: 20rpx;
143
+ color: #333;
144
+ line-height: 26rpx;
145
+ overflow: hidden;
146
+ text-overflow: ellipsis;
147
+ /* #ifdef H5 */
148
+ display: -webkit-box;
149
+ -webkit-line-clamp: 3;
150
+ -webkit-box-orient: vertical;
151
+ /* #endif */
152
+ lines: 3;
153
+ }
154
+ }
155
+ .hisItem:active {
156
+ background-color: rgba(0, 0, 0, 0.03);
157
+ }
158
+ }
159
+ }
160
+ }
161
+ </style>
@@ -0,0 +1,13 @@
1
+ <template>
2
+ <view><slot></slot></view>
3
+ </template>
4
+ <script>
5
+ export default {}
6
+ </script>
7
+ <style scoped>
8
+ view {
9
+ width: 100%;
10
+ display: block;
11
+ box-sizing: border-box;
12
+ }
13
+ </style>
@@ -0,0 +1,87 @@
1
+ <template>
2
+ <view>
3
+ <view class="menuBtn" v-if="list.length > 0" @click="showMenu">
4
+ <text class="menuText">{{ title }}</text>
5
+ <text class="menuText">{{ list[value] ? list[value].title : '' }}</text>
6
+ <image src="../../static/menu.png" class="menuIcon" />
7
+ </view>
8
+ </view>
9
+ </template>
10
+ <script>
11
+ import devUi from '../../../core/libs/devUi.js'
12
+
13
+ export default {
14
+ props: {
15
+ /**
16
+ * 按钮列表
17
+ */
18
+ list: {
19
+ type: Array,
20
+ default: () => []
21
+ },
22
+ /**
23
+ * 当前选中的按钮索引
24
+ */
25
+ value: {
26
+ type: Number,
27
+ default: 0
28
+ },
29
+ /**
30
+ * 标题
31
+ */
32
+ title: {
33
+ type: String,
34
+ default: ''
35
+ }
36
+ },
37
+ methods: {
38
+ /**
39
+ * 展示菜单
40
+ */
41
+ async showMenu() {
42
+ const list = this.list.map((item) => ({
43
+ title: String(item.title || ''),
44
+ msg: item.msg ? String(item.msg) : ''
45
+ }))
46
+
47
+ const res = await devUi.showActionSheet({
48
+ itemList: list,
49
+ itemColor: '#334155',
50
+ selectedIndex: this.value,
51
+ selectedColor: '#2563eb'
52
+ })
53
+
54
+ if (res && typeof res.tapIndex === 'number' && res.tapIndex > -1) {
55
+ this.$emit('indexChange', res.tapIndex)
56
+ }
57
+ }
58
+ }
59
+ }
60
+ </script>
61
+ <style lang="scss" scoped>
62
+ .menuBtn {
63
+ display: flex;
64
+ flex-direction: row;
65
+ align-items: center;
66
+ justify-content: center;
67
+ border-radius: 14rpx;
68
+ height: 54rpx;
69
+ border: 1px solid rgba(15, 23, 42, 0.12);
70
+ padding: 0 14rpx;
71
+ background-color: #fff;
72
+ box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
73
+ &:active {
74
+ background-color: rgba(59, 130, 246, 0.1);
75
+ }
76
+ .menuText {
77
+ font-size: 24rpx;
78
+ line-height: 54rpx;
79
+ color: #475569;
80
+ }
81
+ .menuIcon {
82
+ margin-left: 10rpx;
83
+ width: 30rpx;
84
+ height: 30rpx;
85
+ }
86
+ }
87
+ </style>
@@ -0,0 +1,71 @@
1
+ <template>
2
+ <view class="mobileSwiperScroll">
3
+ <scroll-view
4
+ class="mobileSwiperScrollView"
5
+ scroll-y
6
+ :style="{
7
+ height: scrollHeight + 'px'
8
+ }"
9
+ :scroll-top="scrollTop"
10
+ >
11
+ <slot :item="tabList[tabIndex]" :index="tabIndex"></slot>
12
+ </scroll-view>
13
+ </view>
14
+ </template>
15
+ <script>
16
+ export default {
17
+ props: {
18
+ /**
19
+ * 分类索引
20
+ */
21
+ tabIndex: {
22
+ type: Number,
23
+ default: 0
24
+ },
25
+ /**
26
+ * tab列表
27
+ */
28
+ tabList: {
29
+ type: Array,
30
+ default: () => []
31
+ },
32
+ /**
33
+ * 滚动高度
34
+ */
35
+ scrollHeight: {
36
+ type: Number,
37
+ default: 1000
38
+ }
39
+ },
40
+ data() {
41
+ return {
42
+ /**
43
+ * 滚动位置
44
+ */
45
+ scrollTop: 0
46
+ }
47
+ },
48
+ methods: {
49
+ /**
50
+ * 滚动到列表底部
51
+ */
52
+ scrollToBottom() {
53
+ this.scrollTop = 999999999 + Math.random()
54
+ }
55
+ }
56
+ }
57
+ </script>
58
+ <style lang="scss" scoped>
59
+ .mobileSwiperScroll {
60
+ width: 100%;
61
+ overflow-x: hidden;
62
+ }
63
+
64
+ .mobileSwiperScrollView {
65
+ width: 100%;
66
+ }
67
+
68
+ .mobileSwiperScrollView ::v-deep .uni-scroll-view-content {
69
+ width: 100%;
70
+ }
71
+ </style>
@@ -0,0 +1,47 @@
1
+ <template>
2
+ <view>
3
+ <MenuBtn :list="typeList" :value="index" @indexChange="change" title="网速:" />
4
+ </view>
5
+ </template>
6
+ <script>
7
+ import MenuBtn from './menuBtn.vue'
8
+ export default {
9
+ components: {
10
+ MenuBtn
11
+ },
12
+ data() {
13
+ return {
14
+ /**
15
+ * 弱网模拟状态
16
+ */
17
+ typeList: [
18
+ { title: '不限', type: '', msg: '正常响应请求' },
19
+ { title: '2G龟速', type: '2g', msg: '随机延迟30~60秒后响应' },
20
+ { title: '3G慢速', type: '3g-', msg: '随机延迟10~30秒后响应' },
21
+ { title: '3G略快', type: '3g', msg: '随机延迟3~10秒后响应' },
22
+ { title: '4G弱网', type: '4g', msg: '随机延迟0.5~3秒后响应' }
23
+ ],
24
+ /**
25
+ * 当前选中的索引
26
+ */
27
+ index: 0
28
+ }
29
+ },
30
+ mounted() {
31
+ let cache = uni.getStorageSync('devtools_uniResLimitType')
32
+ let index = this.typeList.findIndex((x) => x.type == cache)
33
+ if (index == -1) index = 0
34
+ this.index = index
35
+ },
36
+ methods: {
37
+ /**
38
+ * 选项发生改变事件
39
+ */
40
+ change(index) {
41
+ uni.setStorageSync('devtools_uniResLimitType', this.typeList[index].type)
42
+ this.index = index
43
+ }
44
+ }
45
+ }
46
+ </script>
47
+ <style lang="scss"></style>
@@ -0,0 +1,50 @@
1
+ <template>
2
+ <view>
3
+ <MenuBtn :list="typeList" :value="index" @indexChange="change" title="超时:" />
4
+ </view>
5
+ </template>
6
+ <script>
7
+ import MenuBtn from './menuBtn.vue'
8
+ export default {
9
+ components: {
10
+ MenuBtn
11
+ },
12
+ data() {
13
+ return {
14
+ /**
15
+ * 随机响应超时
16
+ */
17
+ typeList: [
18
+ { title: '无', type: '', msg: '正常响应请求' },
19
+ { title: '5%', type: '5', msg: '随机5%的概率请求响应超时或报错' },
20
+ { title: '10%', type: '10', msg: '随机10%的概率请求响应超时或报错' },
21
+ { title: '30%', type: '30', msg: '随机30%的概率请求响应超时或报错' },
22
+ { title: '50%', type: '50', msg: '随机50%的概率请求响应超时或报错' },
23
+ { title: '70%', type: '70', msg: '随机70%的概率请求响应超时或报错' },
24
+ { title: '90%', type: '90', msg: '随机90%的概率请求响应超时或报错' },
25
+ { title: '100%', type: '100', msg: '所有请求均响应超时或报错' }
26
+ ],
27
+ /**
28
+ * 当前选中的索引
29
+ */
30
+ index: 0
31
+ }
32
+ },
33
+ mounted() {
34
+ let cache = uni.getStorageSync('devtools_uniResTimeout')
35
+ let index = this.typeList.findIndex((x) => x.type == cache)
36
+ if (index == -1) index = 0
37
+ this.index = index
38
+ },
39
+ methods: {
40
+ /**
41
+ * 选项发生改变事件
42
+ */
43
+ change(index) {
44
+ uni.setStorageSync('devtools_uniResTimeout', this.typeList[index].type)
45
+ this.index = index
46
+ }
47
+ }
48
+ }
49
+ </script>
50
+ <style lang="scss"></style>