system-phone 3.1.1 → 3.1.4

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 (106) hide show
  1. package/.gradle/buildOutputCleanup/cache.properties +2 -2
  2. package/SystemPhone.iml +8 -8
  3. package/build/dev-server.js +141 -141
  4. package/build/webpack.base.conf.js +82 -82
  5. package/build.gradle +27 -27
  6. package/gradle/wrapper/gradle-wrapper.properties +5 -5
  7. package/gradlew +183 -183
  8. package/gradlew.bat +100 -100
  9. package/index.html +21 -21
  10. package/package.json +1 -1
  11. package/src/App.vue +25 -25
  12. package/src/Util.js +415 -415
  13. package/src/assets//346/215/242/350/241/250/347/273/264/344/277/256.png +0 -0
  14. package/src/assets//351/200/232/347/224/250/350/203/214/346/231/257/345/233/276.png +0 -0
  15. package/src/components/AloneLoadParams.vue +26 -26
  16. package/src/components/AlreadyService.vue +193 -193
  17. package/src/components/AttendManage.vue +534 -534
  18. package/src/components/LoadAppdata.vue +38 -38
  19. package/src/components/LoginApp.vue +732 -732
  20. package/src/components/LoginAppNew.vue +587 -587
  21. package/src/components/LoginAppV4.vue +716 -716
  22. package/src/components/ModifyPassWord.vue +216 -216
  23. package/src/components/NavBottom.vue +117 -117
  24. package/src/components/NavBottomV.vue +141 -141
  25. package/src/components/NavBottomVVV.vue +185 -185
  26. package/src/components/OnlineManage.vue +256 -256
  27. package/src/components/PhoneAllInfo.vue +68 -68
  28. package/src/components/PhoneChangemeterInfo.vue +116 -116
  29. package/src/components/PhoneImageInfo.vue +102 -102
  30. package/src/components/PhoneInfoTable.vue +39 -39
  31. package/src/components/PhoneMeterInfo.vue +132 -132
  32. package/src/components/PhoneRepairInfo.vue +146 -146
  33. package/src/components/PhoneSafeInfo.vue +101 -101
  34. package/src/components/PhoneSellInfo.vue +148 -148
  35. package/src/components/PhoneSellInfoLite.vue +112 -112
  36. package/src/components/PhoneUser.vue +202 -202
  37. package/src/components/PhoneUserDetil.vue +70 -70
  38. package/src/components/PhoneUserFind.vue +138 -138
  39. package/src/components/RightTree.vue +217 -217
  40. package/src/components/SystemSetUp.vue +332 -332
  41. package/src/components/TabBarPhone.vue +81 -81
  42. package/src/components/Test.vue +14 -14
  43. package/src/components/ToolsPage.vue +199 -199
  44. package/src/components/UploadManage.vue +194 -194
  45. package/src/components/gaomi/NavBottomV.vue +223 -223
  46. package/src/components/gaomi/NavBottomVVVV.vue +210 -210
  47. package/src/components/gaomi/Scroller.vue +63 -63
  48. package/src/components/gaomi/SystemSetUp.vue +186 -186
  49. package/src/components/gaomi/ToolsPage.vue +168 -168
  50. package/src/components/idea/feedBack.vue +150 -150
  51. package/src/components/idea/feedbackAdd.vue +366 -366
  52. package/src/components/info/ConfigInfo.vue +122 -122
  53. package/src/components/info/FindUserInfo.vue +157 -157
  54. package/src/components/info/InfoTable.vue +37 -37
  55. package/src/components/iot/InstructMessage.vue +313 -313
  56. package/src/components/iot/IotBaseInfo.vue +97 -97
  57. package/src/components/iot/IotMeterInfo.vue +77 -77
  58. package/src/components/iot/iotMonitoringMain.vue +501 -501
  59. package/src/components/online/ApplyOnline.vue +581 -581
  60. package/src/components/online/BJZhongRan/ApplyOnline.vue +600 -600
  61. package/src/components/screen/ChargeContentPage.vue +656 -656
  62. package/src/components/screen/ContentPage.vue +611 -611
  63. package/src/components/screen/GongdanContentPage.vue +149 -149
  64. package/src/components/screen/ListCountItem.vue +93 -93
  65. package/src/components/screen/ModuleTitle.vue +48 -48
  66. package/src/components/screen/SafeOrderContentPage.vue +440 -440
  67. package/src/components/screen/SecurityCheckItem.vue +50 -50
  68. package/src/components/screen/TotalItem.vue +76 -76
  69. package/src/components/screen/TotalUserNumber.vue +77 -77
  70. package/src/components/screen/WorkOrderItem.vue +51 -51
  71. package/src/components/screen/WorkOrderRightDownItem.vue +103 -103
  72. package/src/components/screen/WorkOrderRightItem.vue +115 -115
  73. package/src/components/userinfo/paymentQuery.vue +189 -189
  74. package/src/components/userinfo/queryFile.vue +190 -190
  75. package/src/components/wasm.vue +18 -18
  76. package/src/expandcssAndroid.less +521 -521
  77. package/src/filiale/liaoyuan/NavBottomVVV.vue +186 -0
  78. package/src/filiale/liaoyuan/ToolsPage.vue +199 -0
  79. package/src/filiale/liaoyuan/systemphonegrid.js +5 -0
  80. package/src/filiale/yulinyuchuan/AlreadyService.vue +194 -194
  81. package/src/filiale/yulinyuchuan/AttendManage.vue +537 -537
  82. package/src/filiale/yulinyuchuan/LoginApp.vue +741 -741
  83. package/src/filiale/yulinyuchuan/OnlineManage.vue +256 -256
  84. package/src/filiale/yulinyuchuan/SystemSetUp.vue +332 -332
  85. package/src/filiale/yulinyuchuan/UploadManage.vue +195 -195
  86. package/src/filiale/yulinyuchuan/systemphonegrid.js +9 -9
  87. package/src/filiale/yulinyuchuanTY/AlreadyService.vue +194 -0
  88. package/src/filiale/yulinyuchuanTY/AttendManage.vue +537 -0
  89. package/src/filiale/yulinyuchuanTY/LoginApp.vue +741 -0
  90. package/src/filiale/yulinyuchuanTY/OnlineManage.vue +256 -0
  91. package/src/filiale/yulinyuchuanTY/SystemSetUp.vue +332 -0
  92. package/src/filiale/yulinyuchuanTY/UploadManage.vue +195 -0
  93. package/src/filiale/yulinyuchuanTY/systemphonegrid.js +9 -0
  94. package/src/index.js +9 -9
  95. package/src/main.js +38 -38
  96. package/src/plugins/const.js +404 -404
  97. package/src/plugins/vue-py.js +37 -37
  98. package/src/stores/AppData.js +79 -79
  99. package/src/systemphone-gaomi.js +105 -105
  100. package/src/systemphone.js +60 -60
  101. package/src/systemphonegrid.js +185 -185
  102. package/src/util/LdapHelper.js +75 -75
  103. package/static/const.js +404 -404
  104. package/static/layui/font/iconfont.svg +554 -554
  105. package/static/vue-py.js +37 -37
  106. package/static/wasm_exec.js +465 -465
@@ -0,0 +1,256 @@
1
+ <template>
2
+ <div class="nav-bgcolor">
3
+ <img src="../../assets/通用背景图.png" style="height: 20vh; width: 96vw; margin: 8px 0 0 8px; border-radius: 10px">
4
+ <div class="auto">
5
+ <div class="row nav-bgcolor">
6
+ <div class="col-xs-6 manbiankuang" v-for="tab in tabs" @click="gotopage(tab.link,tab.name,tab.navigate)">
7
+ <div class="badge" v-show="tab.name == '维修派发' && isShowRedNum && isShowRedNum == 'true'">
8
+ <div class="badge-content">{{ pointNum ? pointNum : 0 }}</div>
9
+ </div>
10
+ <div class="badge" v-show="tab.name == '抄表待办' && isShowRedNum && isShowRedNum == 'true'">
11
+ <div class="badge-content">{{ meterNum ? meterNum : 0 }}</div>
12
+ </div>
13
+ <div class="badge" v-show="tab.name == '信息公告' && isShowRedNum && isShowRedNum == 'true'">
14
+ <div class="badge-content">{{ infoNum ? infoNum : 0 }}</div>
15
+ </div>
16
+ <img class="imgs" :src="imgback(tab.name)" alt="">
17
+ <p></p>
18
+ <p class="pagesfoot">{{ tab.name }}</p>
19
+ <!--<p class="pagesfoot">{{tab.name}}&nbsp;{{tab.icon}}</p>-->
20
+ <p></p>
21
+ </div>
22
+ </div>
23
+ <!--<div class="row" style="overflow:auto;">-->
24
+ <!--<repair-first v-show="componentName == 'repair-first'" worktype="报修单" :sourcet="sourcet" tabname="维修待办" v-on:changesum="changesum"></repair-first>-->
25
+ <!--<zhihuan-first v-show="componentName == 'zhihuan-first'" worktype="置换通气单" :sourcet="sourcet" tabname="置换待办" v-on:changesum="changesum"></zhihuan-first>-->
26
+ <!--</div>-->
27
+ </div>
28
+ </div>
29
+ </template>
30
+
31
+ <script scoped>
32
+ import Vue from 'vue'
33
+ import {HttpResetClass} from "vue-client";
34
+
35
+ export default {
36
+ title: '在线业务导航',
37
+ data() {
38
+ return {
39
+ titleName: '在线业务',
40
+ isMenu: true,
41
+ tabs: this.getTabs(),
42
+ text: '导航组件this',
43
+ isShowRedNum:this.$appdata.getSingleValue('手机端获取任务条数'),
44
+ beforeName: '在线业务',
45
+ sourcet: '竖屏',
46
+ pointNum: null,
47
+ infoNum: null,
48
+ meterNum: null
49
+ }
50
+ },
51
+ ready() {
52
+ this.getRepairNum()
53
+ this.getInfoNum()
54
+ this.getmeterNum()
55
+ },
56
+ methods: {
57
+ changesum(titdata) {
58
+ for (var i = 0; i < this.tabs.length; i++) {
59
+ if (this.tabs[i].name == titdata.title) {
60
+ this.tabs[i].icon = titdata.sum + '单'
61
+ console.log(JSON.stringify(this.tabs[i].icon))
62
+ return
63
+ }
64
+ }
65
+ },
66
+ getTabs() {
67
+ for (let funs in Vue.functions) {
68
+ if (Vue.functions[funs].link == 'online-manage') {
69
+ return Vue.functions[funs].children
70
+ }
71
+ }
72
+ this.getRepairNum()
73
+ this.getInfoNum()
74
+ this.getmeterNum()
75
+ },
76
+ getmeterNum() {
77
+ if (!this.isShowRedNum || this.isShowRedNum != 'true') {
78
+ return
79
+ }
80
+ this.timeOutGetmeterNum()
81
+ },
82
+ getInfoNum() {
83
+ if (!this.isShowRedNum || this.isShowRedNum != 'true') {
84
+ return
85
+ }
86
+ this.timeOutGetInfoNum()
87
+ },
88
+ getRepairNum() {
89
+ if (!this.isShowRedNum || this.isShowRedNum != 'true') {
90
+ return
91
+ }
92
+ this.timeOutGetRepairNum()
93
+ },
94
+ timeOutGetRepairNum() {
95
+ let condition = `1 = 1 and f_workorder_type = '报修单' and f_state = null `
96
+ let val = {
97
+ condition: {
98
+ condition: condition,
99
+ sign: '1 = 1'
100
+ },
101
+ userid: Vue.user.name
102
+ }
103
+ let http = new HttpResetClass()
104
+ http.load('POST', `${this.$androidUtil.getProxyUrl()}/rs/path/operatorServiceAndroid`, {data: val}, {
105
+ resolveMsg: null,
106
+ rejectMsg: null
107
+ }).then((res) => {
108
+ this.pointNum = res.data.length
109
+ })
110
+ },
111
+ timeOutGetInfoNum() {
112
+ let condition = " 1 = 1 and (f_enddate >= '" + Util.toStandardTimeString() + "' or f_state = '公告中') "
113
+ let val = {
114
+ items: "count(*) as count_num",
115
+ tablename: "T_STOPGAS",
116
+ orderitem: "1",
117
+ condition: condition,
118
+ f_orgstr: `'${Vue.user.orgid}'`
119
+ }
120
+ let http = new HttpResetClass()
121
+ http.load('POST', `${this.$androidUtil.getProxyUrl()}/rs/sql/tel_singleTable_OrderBy`, {data: val}, {
122
+ resolveMsg: null,
123
+ rejectMsg: null
124
+ }).then((res) => {
125
+ this.infoNum = res.data[0].count_num
126
+ })
127
+ },
128
+ timeOutGetmeterNum() {
129
+ let val = {
130
+ items: "count(*) as count_num",
131
+ tablename: "t_handplan",
132
+ orderitem: "1",
133
+ condition: `1=1 and f_inputtor = '${Vue.user.name}' and f_hand_state = '有效' and f_meter_state = '未抄表'`,
134
+ f_orgid: `'${Vue.user.orgid}'`
135
+ }
136
+ let http = new HttpResetClass()
137
+ http.load('POST', `${this.$androidUtil.getProxyUrl()}/rs/sql/tel_singleTable_OrderBy`, {data: val}, {
138
+ resolveMsg: null,
139
+ rejectMsg: null
140
+ }).then((res) => {
141
+ this.meterNum = res.data[0].count_num
142
+ })
143
+ },
144
+ imgback(val) {
145
+ return require('../../assets/' + val + '.png')
146
+ },
147
+ // 返回主界面
148
+ back() {
149
+ this.titleName = '主界面'
150
+ this.isMenu = true
151
+
152
+ },
153
+ gotopage(param, title, navigate) {
154
+ console.log('进入子组件')
155
+ var prpdata = {
156
+ _this: this,
157
+ title: title,
158
+ safe: false
159
+ }
160
+ this.$dispatch('gotoson', prpdata)
161
+ if (navigate) {
162
+ this.$goto('embbed-page', {domainName: navigate, title: title, compName: param, login: Vue.user})
163
+ } else {
164
+ this.$goto(param, {sourcet: '竖屏', tabname: title},'self',this.getTabs)
165
+ }
166
+ },
167
+ mute() {
168
+ HostApp.mute()
169
+ }
170
+ },
171
+ }
172
+ </script>
173
+ <style lang="less">
174
+ .badge-content {
175
+ color: #fff;
176
+ box-sizing: border-box;
177
+ min-width: 8px;
178
+ font-size: 9px;
179
+ line-height: 12px;
180
+ white-space: nowrap;
181
+ font-weight: 400;
182
+ text-align: center;
183
+ }
184
+
185
+ .badge {
186
+ top: 6px;
187
+ position: absolute;
188
+ max-height: 13px;
189
+ min-height: 8px;
190
+ right: 0;
191
+ display: inline-flex;
192
+ vertical-align: middle;
193
+ box-sizing: content-box;
194
+ border-radius: 100px;
195
+ background-color: red;
196
+ }
197
+
198
+ .tab-befor-img {
199
+ content: '';
200
+ background-size: 30px;
201
+ display: inline-block;
202
+ margin-right: 8px;
203
+ height: 30px;
204
+ width: 30px;
205
+ vertical-align: -35%;
206
+ }
207
+
208
+ .pageskuang {
209
+ vertical-align: middle;
210
+ display: table-cell;
211
+ width: 32%;
212
+ top: -50%;
213
+ margin-top: 1%;
214
+ margin-left: 1%;
215
+ border: 1px solid #e3e3e3;
216
+ text-align: center;
217
+ background-color: #ffffff;
218
+ }
219
+
220
+ .pgesfoot {
221
+ font-size: 14px;
222
+ color: #666666;
223
+ }
224
+
225
+ .imgs {
226
+ width: 35px;
227
+ height: 39px;
228
+ margin-top: 15px;
229
+ }
230
+
231
+ .pages-bgcolor {
232
+ text-align: center;
233
+ background-color: #f0f0ef;
234
+ }
235
+
236
+ img[src=""], img:not([src]) {
237
+ opacity: 0;
238
+ border: none;
239
+ visibility: hidden;
240
+ max-width: none;
241
+ }
242
+
243
+ .manbiankuang {
244
+ width: 44%;
245
+ margin-top: 15px;
246
+ margin-left: 4%;
247
+ border: 1px solid #e3e3e3;
248
+ border-radius: 10px 10px 10px 10px;
249
+ text-align: center;
250
+ background-color: #ffffff;
251
+ }
252
+
253
+ .nav-bgcolor {
254
+ background-color: #ffffff;
255
+ }
256
+ </style>
@@ -0,0 +1,332 @@
1
+ <template>
2
+ <div class="nav-bgcolor">
3
+ <img src="../../assets/通用背景图.png" style="height: 20vh; width: 96vw; margin: 8px 0 0 8px; border-radius: 10px">
4
+ <div class="auto">
5
+ <div class="row nav-bgcolor">
6
+ <div class="col-xs-6 manbiankuang" v-for="tab in tabs" @click="gotopage(tab.link,tab.name)">
7
+ <img class="imgs" :src="imgback(tab.name)">
8
+ <p></p>
9
+ <p class="pagesfoot">{{ tab.name }}</p>
10
+ <p></p>
11
+ </div>
12
+ </div>
13
+ </div>
14
+ <modal :show.sync="show" v-ref:modal backdrop="false">
15
+ <header slot="modal-header" class="modal-header text-center">
16
+ <h4 class="modal-title">清除项选择</h4>
17
+ <input type="checkbox" class="" id="f_operator" v-model="all">
18
+ <label for="f_operator" class="font-size">全选</label>
19
+ </header>
20
+ <article slot="modal-body" v-if="show">
21
+ <div class="auto col-sm-11 col-xs-11 col-xs-offset-1 col-md-offset-1" style="margin-top: 10px;">
22
+ <div class="col-sm-4 col-xs-4" v-for="f in fields">
23
+ <input type="checkbox" class="" :id="'export-col-'+$index" v-model="modelval" :value="$key">
24
+ <label :for="'export-col-'+$index" class="font-size">{{ f }}</label>
25
+ </div>
26
+ </div>
27
+ </article>
28
+ <footer slot="modal-footer" class="modal-footer">
29
+ <center>
30
+ <button v-show="show" type="button" class="btn btn-default" @click='close()'>取消</button>
31
+ <button v-show="show" type="button" class="btn btn-success" @click='clear()'>确定</button>
32
+ </center>
33
+ </footer>
34
+ </modal>
35
+ </div>
36
+ </template>
37
+
38
+ <script>
39
+ import Vue from 'vue'
40
+
41
+ export default {
42
+ title: '系统设置',
43
+ data() {
44
+ return {
45
+ version: '1.0',
46
+ titleName: '系统设置',
47
+ all: false,
48
+ flag: true,
49
+ show: false,
50
+ fields: {},
51
+ dataclear: [],
52
+ tabs: this.getTabs(),
53
+ //tabs:[{name:"清空数据"}],
54
+ modelval: [],
55
+ text: '导航组件this',
56
+ beforeName: '系统设置',
57
+ }
58
+ },
59
+ ready() {
60
+ this.version = HostApp.getAppVersion().data
61
+ // if(Vue.config.safecheck.clearPhone){
62
+ // let cleartable=Vue.config.safecheck.clearPhone.cleardata
63
+ // for (let i = 0; i < cleartable.length; i++) {
64
+ // this.fields[cleartable[i].module]=cleartable[i].module
65
+ // }
66
+ // }
67
+ },
68
+ methods: {
69
+ versionShow() {
70
+ this.$showMessage('系统版本:' + this.version)
71
+ },
72
+ // clear(){
73
+ // let cleartable=Vue.config.safecheck.clearPhone.cleardata
74
+ // console.log(this.modelval)
75
+ // for (let i = 0; i < cleartable.length; i++) {
76
+ // for (let j = 0; j < this.modelval.length; j++) {
77
+ // if (cleartable[i].module==this.modelval[i]){
78
+ // this.dataclear=Object.assign([],this.dataclear,cleartable[i].tables)
79
+ // }
80
+ // }
81
+ // }
82
+ // console.log(this.dataclear)
83
+ // this.cleandata()
84
+ // },
85
+ close() {
86
+ this.show = false
87
+ this.all = false
88
+ this.flag = true
89
+ this.modelval = []
90
+ },
91
+ sortModelval() {
92
+ let sortModel = []
93
+ Object.keys(this.fields).forEach((key) => {
94
+ if (this.modelval.includes(key)) {
95
+ sortModel.push(key)
96
+ }
97
+ })
98
+ console.log('看看选择的顺序。。。', sortModel)
99
+ console.log('看看选择的顺序。。。', this.modelval)
100
+ if (sortModel.length == this.modelval.length - 1) {
101
+ this.flag = false
102
+ console.log("66666666666666")
103
+ this.all = false
104
+ }
105
+ console.log(Object.keys(this.fields).length)
106
+ if (sortModel.length == Object.keys(this.fields).length) {
107
+ this.all = true
108
+ }
109
+ this.modelval = sortModel
110
+ },
111
+ imgback(val) {
112
+ return require('../../assets/' + val + '.png')
113
+ },
114
+ getTabs() {
115
+ for (let funs in Vue.user.functions) {
116
+ if (Vue.user.functions[funs].link == 'system-setup') {
117
+ return Vue.user.functions[funs].children
118
+ }
119
+ }
120
+ },
121
+ gotopage(link, name) {
122
+ if (name == '清空数据') {
123
+ this.cleanalldata()
124
+ return
125
+ }
126
+ if (name == '系统版本') {
127
+ this.versionShow()
128
+ return
129
+ }
130
+ // else if (name == '清除数据'){
131
+ // this.openclear()
132
+ // }
133
+ else if (name == '声音开关') {
134
+ this.voiceSwitch()
135
+ } else if (name == '导出数据') {
136
+ this.outdata()
137
+ } else if (name == '退出系统') {
138
+ HostApp.back_home()
139
+ } else if (name == '删除照片') {
140
+ const result = HostApp.deletePic()
141
+ if (result){
142
+ this.$showMessage('删除成功!共删除照片'+result.delete_pic_ok+'张!')
143
+ }
144
+ } else if (name == '返回桌面') {
145
+ HostApp.back_home()
146
+ } else if (name == '退出登录') {
147
+ this.$showMessage('即将返回登陆界面!', ['confirm', 'cancel']).then((res) => {
148
+ if (res === 'confirm') {
149
+ this.$androidUtil.setPreference('f_repairman_id', 'x')
150
+ this.$androidUtil.setPreference('f_repairman_name', 'x')
151
+ this.$dispatch('gologin')
152
+ }
153
+ })
154
+ } else {
155
+ console.log('进入子组件')
156
+ let safe = true
157
+ if (name == '打卡'){
158
+ safe = false
159
+ }
160
+ var prpdata = {
161
+ _this:this,
162
+ title:name,
163
+ safe
164
+ }
165
+ this.$dispatch('gotoson',prpdata)
166
+ this.$goto(link)
167
+ }
168
+ },
169
+ cleanalldata() {
170
+ this.$showMessage('此操作为清理数据,无法恢复!', ['confirm', 'cancel']).then((res) => {
171
+ if (res === 'confirm') {
172
+ let result = this.$androidUtil.bzLogic('clearPhoneData', {flag: 0})
173
+ console.log((result.result))
174
+ if (result.result == '成功') {
175
+ this.$showMessage('清除数据完成!')
176
+ } else {
177
+ this.$showMessage('清除数据失败!')
178
+ }
179
+ }
180
+ })
181
+ },
182
+ // 清空数据
183
+ cleandata() {
184
+ console.log("88888888888")
185
+ this.$showMessage('此操作为清理数据,无法恢复!', ['confirm', 'cancel']).then((res) => {
186
+ if (res === 'confirm') {
187
+ let result = this.$androidUtil.bzLogic('clearPhoneDataNew', {tables: this.dataclear})
188
+ console.log((result.result))
189
+ if (result.result == '成功') {
190
+ this.$showMessage('清除数据完成!')
191
+ } else {
192
+ this.$showMessage('清除数据失败!')
193
+ }
194
+ this.close()
195
+ }
196
+ })
197
+ },
198
+ // 导出数据
199
+ openclear() {
200
+ this.show = true
201
+ },
202
+ voiceSwitch() {
203
+ console.log("进入声音开关")
204
+ let voicedata = this.$androidUtil.getPreference('f_voiceSwitch')
205
+ console.log(voicedata)
206
+ let voicechange = '开启'
207
+ if (voicedata == "true") {
208
+ console.log("进入判断")
209
+ voicechange = '关闭'
210
+ }
211
+ this.$showMessage('此操作为' + voicechange + '提示音,请再次确认!', ['confirm', 'cancel']).then((res) => {
212
+ if (res == 'confirm') {
213
+ if (voicechange == '关闭') {
214
+ this.$androidUtil.setPreference('f_voiceSwitch', "false")
215
+ this.$showMessage('提示音关闭成功!')
216
+ } else {
217
+ this.$androidUtil.setPreference('f_voiceSwitch', "true")
218
+ this.$showMessage('提示音开启成功!')
219
+ }
220
+ }
221
+ })
222
+ },
223
+ outdata() {
224
+ HostApp.backupDatabase()
225
+ this.$showMessage('数据导出成功!')
226
+ },
227
+ //取消自动登录
228
+ cancelAutoLogin() {
229
+ let auto = this.$androidUtil.getPreference('autoLogin')
230
+ if (auto) {
231
+ this.$androidUtil.setPreference('autoLogin', false)
232
+ this.$showMessage('已取消自动登录!')
233
+ } else {
234
+ this.$showMessage('当前已处于非自动登录!')
235
+ }
236
+ }
237
+ },
238
+ watch: {
239
+ 'all'(val) {
240
+ if (val) {
241
+ this.modelval = Object.keys(this.fields)
242
+ } else {
243
+ console.log(this.flag)
244
+ if (this.flag) {
245
+ this.modelval = []
246
+ }
247
+ }
248
+ this.flag = true
249
+ },
250
+ 'modelval.length'() {
251
+ this.sortModelval()
252
+ }
253
+ }
254
+ }
255
+
256
+ </script>
257
+ <style scoped>
258
+ .flex-between {
259
+ display: flex;
260
+ justify-content: space-between;
261
+ align-items: center;
262
+ }
263
+
264
+ .flex-between span {
265
+ padding-right: 10px;
266
+ }
267
+
268
+ .flex-full {
269
+ flex: 1;
270
+ }
271
+
272
+ .name {
273
+ font: 15px PingFang-SC-Medium;
274
+ color: #666666;
275
+ }
276
+
277
+ .imgs {
278
+ width: 35px;
279
+ margin-top: 15px;
280
+ height: 39px;
281
+ }
282
+
283
+ .plan {
284
+ border-bottom: 0.5px solid #EAEAEA;
285
+ border-right: 0.5px solid #EAEAEA;
286
+ height: 120px;
287
+ }
288
+
289
+ .manbiankuang {
290
+ width: 44%;
291
+ margin-top: 15px;
292
+ margin-left: 4%;
293
+ border: 1px solid #e3e3e3;
294
+ border-radius: 10px 10px 10px 10px;
295
+ text-align: center;
296
+ background-color: #ffffff;
297
+ }
298
+
299
+ .user {
300
+ border-bottom: 0.5px solid #EAEAEA;
301
+ border-right: 0.5px solid #EAEAEA;
302
+ border-left: 0.5px solid #EAEAEA;
303
+ height: 120px;
304
+ }
305
+
306
+ .safecheck {
307
+ border-bottom: 0.5px solid #EAEAEA;
308
+ border-left: 0.5px solid #EAEAEA;
309
+ height: 120px;
310
+ }
311
+
312
+ .appointment {
313
+ border-top: 0.5px solid #EAEAEA;
314
+ border-right: 0.5px solid #EAEAEA;
315
+ height: 120px;
316
+ }
317
+
318
+ .search {
319
+ border-top: 0.5px solid #EAEAEA;
320
+ border-right: 0.5px solid #EAEAEA;
321
+ border-left: 0.5px solid #EAEAEA;
322
+ height: 120px;
323
+ }
324
+
325
+ .upload {
326
+ border-top: 0.5px solid #EAEAEA;
327
+ border-left: 0.5px solid #EAEAEA;
328
+ height: 120px;
329
+ }
330
+
331
+
332
+ </style>