@uxda/appkit 4.1.16 → 4.1.22

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.
package/dist/appkit.css CHANGED
@@ -623,14 +623,14 @@ page {
623
623
  top: 11px;
624
624
  background-image: url("");
625
625
  }
626
- .consumption-date-filter {
626
+ .appkit-date-filter {
627
627
  height: 100%;
628
628
  display: flex;
629
629
  flex-direction: column;
630
630
  width: 100%;
631
631
  position: relative;
632
632
  }
633
- .consumption-date-filter .date-filter-header {
633
+ .appkit-date-filter .date-filter-header {
634
634
  text-align: center;
635
635
  height: 44px;
636
636
  line-height: 44px;
@@ -638,42 +638,42 @@ page {
638
638
  font-size: 17px;
639
639
  background-color: #f5f5f5;
640
640
  }
641
- .consumption-date-filter .content {
641
+ .appkit-date-filter .content {
642
642
  flex: 1;
643
643
  margin: 15px;
644
644
  overflow-y: scroll;
645
645
  color: #353535;
646
646
  font-size: 13px;
647
647
  }
648
- .consumption-date-filter .content .title {
648
+ .appkit-date-filter .content .title {
649
649
  opacity: 0.6;
650
650
  line-height: 18px;
651
651
  }
652
- .consumption-date-filter .content .info {
652
+ .appkit-date-filter .content .info {
653
653
  display: grid;
654
654
  grid-template-columns: 1fr 1fr 1fr;
655
655
  grid-gap: 10px;
656
656
  margin: 10px 0;
657
657
  }
658
- .consumption-date-filter .content .info .item {
658
+ .appkit-date-filter .content .info .item {
659
659
  height: 30px;
660
660
  line-height: 30px;
661
661
  border: 1px solid #ccc;
662
662
  border-radius: 6px;
663
663
  text-align: center;
664
664
  }
665
- .consumption-date-filter .content .info .current {
665
+ .appkit-date-filter .content .info .current {
666
666
  border: 1px solid;
667
667
  border-image-source: linear-gradient(180deg, rgba(239, 208, 130, 0.8) 0%, rgba(255, 185, 120, 0.8) 100%);
668
668
  background: linear-gradient(180deg, rgba(239, 208, 130, 0.8) 0%, rgba(255, 185, 120, 0.8) 100%), linear-gradient(180deg, #fff7e3 0%, #fefde6 100%);
669
669
  }
670
- .consumption-date-filter .buttons {
671
- margin: 0 15px;
670
+ .appkit-date-filter .buttons {
671
+ margin: 32px 15px 0 15px;
672
672
  display: flex;
673
673
  justify-content: space-between;
674
674
  align-items: center;
675
675
  }
676
- .consumption-date-filter .buttons .btn {
676
+ .appkit-date-filter .buttons .btn {
677
677
  flex: 1;
678
678
  height: 40px;
679
679
  line-height: 40px;
@@ -684,22 +684,22 @@ page {
684
684
  font-size: 16px;
685
685
  border-radius: 6px;
686
686
  }
687
- .consumption-date-filter .buttons .confirm {
687
+ .appkit-date-filter .buttons .confirm {
688
688
  margin-left: 11px;
689
689
  color: #000;
690
690
  border: none;
691
691
  background: linear-gradient(90deg, #ffebc1 0%, #ffd7a7 52.29%, #ffb875 100%);
692
692
  }
693
- .consumption-date-filter .time {
693
+ .appkit-date-filter .time {
694
694
  display: flex;
695
695
  justify-content: flex-start;
696
696
  align-items: center;
697
697
  margin: 10px 0 30px 0;
698
698
  }
699
- .consumption-date-filter .time .line {
699
+ .appkit-date-filter .time .line {
700
700
  margin: 0 8px;
701
701
  }
702
- .consumption-date-filter .time .item {
702
+ .appkit-date-filter .time .item {
703
703
  height: 30px;
704
704
  line-height: 30px;
705
705
  padding: 0 15px;
@@ -710,13 +710,16 @@ page {
710
710
  background: rgba(245, 245, 245, 0.8);
711
711
  border-radius: 6px;
712
712
  }
713
- .consumption-date-filter .time .current {
713
+ .appkit-date-filter .time .current {
714
714
  border: 1px solid #353535;
715
715
  }
716
- .consumption-date-filter .bottom {
716
+ .appkit-date-filter .bottom {
717
717
  height: 32px;
718
718
  background: #fff;
719
719
  }
720
+ .nut-overlay.date-filter-picker-overlay {
721
+ height: 100vh;
722
+ }
720
723
  .consumption-rules .title {
721
724
  line-height: 16px;
722
725
  font-weight: 500;
@@ -1462,7 +1465,7 @@ page {
1462
1465
  padding-left: 6px;
1463
1466
  }
1464
1467
  .notice-entry {
1465
- position: fixed;
1468
+ position: absolute;
1466
1469
  right: 0;
1467
1470
  top: 120px;
1468
1471
  min-width: 66px;
package/dist/index.js CHANGED
@@ -7,7 +7,7 @@ import '@nutui/nutui-taro/dist/packages/griditem/style/css';
7
7
  import Taro, { useDidShow, useRouter } from '@tarojs/taro';
8
8
  import '@nutui/nutui-taro/dist/packages/popup/style/css';
9
9
  import { isIdentityCard, isMobilePhone } from 'validator';
10
- import { NsForm, NsInput, NsButton, NsIcon, useNutshell } from '@uxda/nutshell/taro';
10
+ import { NsForm, NsInput, NsButton, NsIcon, usePopup, useNutshell } from '@uxda/nutshell/taro';
11
11
  import debounce from 'lodash/debounce';
12
12
  import '@nutui/nutui-taro/dist/packages/dialog/style/css';
13
13
  import '@nutui/nutui-taro/dist/packages/datepicker/style/css';
@@ -951,7 +951,7 @@ var script$C = /* @__PURE__ */ defineComponent({
951
951
  onClick: onIconClick
952
952
  },
953
953
  [
954
- createVNode(unref(NsIcon), { name: "https://simple.shensi.tech/icons/ocr.svg" })
954
+ createVNode(unref(NsIcon), { name: "https://cdn.ddjf.com/static/images/beidouxing/ocr-icon.png" })
955
955
  ],
956
956
  2
957
957
  /* CLASS */
@@ -1061,7 +1061,7 @@ var script$B = /* @__PURE__ */ defineComponent({
1061
1061
  onClick: onIconClick
1062
1062
  },
1063
1063
  [
1064
- createVNode(unref(NsIcon), { name: "https://simple.shensi.tech/icons/ocr.svg" })
1064
+ createVNode(unref(NsIcon), { name: "https://cdn.ddjf.com/static/images/beidouxing/ocr-icon.png" })
1065
1065
  ],
1066
1066
  2
1067
1067
  /* CLASS */
@@ -2217,7 +2217,7 @@ var script$u = /* @__PURE__ */ defineComponent({
2217
2217
 
2218
2218
  script$u.__file = "src/balance/components/ConsumptionFilter.vue";
2219
2219
 
2220
- const _hoisted_1$p = { class: "consumption-date-filter" };
2220
+ const _hoisted_1$p = { class: "appkit-date-filter" };
2221
2221
  const _hoisted_2$g = { class: "content" };
2222
2222
  const _hoisted_3$b = { class: "time" };
2223
2223
  var script$t = /* @__PURE__ */ defineComponent({
@@ -2229,7 +2229,7 @@ var script$t = /* @__PURE__ */ defineComponent({
2229
2229
  emits: ["complete", "reset"],
2230
2230
  setup(__props, { emit: __emit }) {
2231
2231
  const props = __props;
2232
- const emit = __emit;
2232
+ const emit = __emit, state = usePopup();
2233
2233
  watch(
2234
2234
  () => `${props.from}${props.to}`,
2235
2235
  () => {
@@ -2243,6 +2243,10 @@ var script$t = /* @__PURE__ */ defineComponent({
2243
2243
  const minDate = ref();
2244
2244
  const maxDate = ref(/* @__PURE__ */ new Date());
2245
2245
  const datePickerOpen = ref(false);
2246
+ state.beforeClose = () => {
2247
+ datePickerOpen.value = false;
2248
+ return true;
2249
+ };
2246
2250
  function reset() {
2247
2251
  emit("reset");
2248
2252
  }
@@ -2261,6 +2265,11 @@ var script$t = /* @__PURE__ */ defineComponent({
2261
2265
  result.to = time;
2262
2266
  }
2263
2267
  datePickerOpen.value = false;
2268
+ state.couldClose = true;
2269
+ }
2270
+ function onDatePickerCancel() {
2271
+ datePickerOpen.value = false;
2272
+ state.couldClose = true;
2264
2273
  }
2265
2274
  function switchDateInput(shift) {
2266
2275
  if (shift === "from") {
@@ -2273,12 +2282,13 @@ var script$t = /* @__PURE__ */ defineComponent({
2273
2282
  focusedDate.value = new Date(result[shift]);
2274
2283
  focused.value = shift;
2275
2284
  datePickerOpen.value = true;
2285
+ state.couldClose = false;
2276
2286
  }
2277
2287
  return (_ctx, _cache) => {
2278
2288
  const _component_nut_date_picker = DatePicker;
2279
2289
  const _component_nut_popup = Popup;
2280
2290
  return openBlock(), createElementBlock("div", _hoisted_1$p, [
2281
- _cache[7] || (_cache[7] = createElementVNode(
2291
+ _cache[6] || (_cache[6] = createElementVNode(
2282
2292
  "div",
2283
2293
  { class: "date-filter-header" },
2284
2294
  "\u65E5\u671F\u9009\u62E9",
@@ -2286,7 +2296,7 @@ var script$t = /* @__PURE__ */ defineComponent({
2286
2296
  /* HOISTED */
2287
2297
  )),
2288
2298
  createElementVNode("div", _hoisted_2$g, [
2289
- _cache[6] || (_cache[6] = createElementVNode(
2299
+ _cache[5] || (_cache[5] = createElementVNode(
2290
2300
  "div",
2291
2301
  { class: "title" },
2292
2302
  "\u81EA\u5B9A\u4E49",
@@ -2304,7 +2314,7 @@ var script$t = /* @__PURE__ */ defineComponent({
2304
2314
  3
2305
2315
  /* TEXT, CLASS */
2306
2316
  ),
2307
- _cache[5] || (_cache[5] = createElementVNode(
2317
+ _cache[4] || (_cache[4] = createElementVNode(
2308
2318
  "div",
2309
2319
  { class: "line" },
2310
2320
  "-",
@@ -2333,7 +2343,7 @@ var script$t = /* @__PURE__ */ defineComponent({
2333
2343
  onClick: onOkClick
2334
2344
  }, "\u786E\u5B9A")
2335
2345
  ]),
2336
- _cache[8] || (_cache[8] = createElementVNode(
2346
+ _cache[7] || (_cache[7] = createElementVNode(
2337
2347
  "div",
2338
2348
  { class: "bottom" },
2339
2349
  null,
@@ -2342,8 +2352,10 @@ var script$t = /* @__PURE__ */ defineComponent({
2342
2352
  )),
2343
2353
  createVNode(_component_nut_popup, {
2344
2354
  visible: datePickerOpen.value,
2345
- "onUpdate:visible": _cache[4] || (_cache[4] = ($event) => datePickerOpen.value = $event),
2346
- position: "bottom"
2355
+ "onUpdate:visible": _cache[3] || (_cache[3] = ($event) => datePickerOpen.value = $event),
2356
+ class: "appkit-date-filter-picker-popup",
2357
+ position: "bottom",
2358
+ "overlay-class": "appkit-date-filter-picker-overlay"
2347
2359
  }, {
2348
2360
  default: withCtx(() => [
2349
2361
  createVNode(_component_nut_date_picker, {
@@ -2353,7 +2365,7 @@ var script$t = /* @__PURE__ */ defineComponent({
2353
2365
  "max-date": maxDate.value,
2354
2366
  "is-show-chinese": false,
2355
2367
  "three-dimensional": false,
2356
- onCancel: _cache[3] || (_cache[3] = ($event) => datePickerOpen.value = false),
2368
+ onCancel: onDatePickerCancel,
2357
2369
  onConfirm: onDatePickerComplete
2358
2370
  }, null, 8, ["modelValue", "min-date", "max-date"])
2359
2371
  ]),
@@ -3198,14 +3210,18 @@ var script$n = /* @__PURE__ */ defineComponent({
3198
3210
  const $n = useNutshell();
3199
3211
  const model = useModel(__props, "modelValue");
3200
3212
  const openDateRangePicker = () => {
3213
+ const child = ref();
3201
3214
  $n.sheet({
3202
3215
  component: script$t,
3216
+ ref: child,
3203
3217
  props: {
3204
3218
  from: model.value.from,
3205
3219
  to: model.value.to
3206
3220
  },
3221
+ modal: true,
3222
+ // 不允许点击 overlay 关闭弹窗
3223
+ mask: true,
3207
3224
  onComplete(result) {
3208
- console.log("===openDateFilter complete", result);
3209
3225
  model.value = {
3210
3226
  from: result.from,
3211
3227
  to: result.to
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@uxda/appkit",
3
- "version": "4.1.16",
3
+ "version": "4.1.22",
4
4
  "description": "小程序应用开发包",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/index.ts",
@@ -20,7 +20,7 @@
20
20
  ],
21
21
  "author": "",
22
22
  "dependencies": {
23
- "@babel/runtime": "^7.7.7",
23
+ "@babel/runtime": "^7.25.6",
24
24
  "@nutui/auto-import-resolver": "^1.0.0",
25
25
  "@nutui/icons-vue-taro": "^0.0.9",
26
26
  "@nutui/nutui-taro": "^4.3.11",
@@ -34,7 +34,6 @@
34
34
  "@tarojs/shared": "^4.0.0",
35
35
  "@tarojs/taro": "^4.0.0",
36
36
  "@types/wechat-miniprogram": "^3.4.7",
37
- "@uxda/nutshell": "^1.0.0",
38
37
  "dayjs": "^1.11.10",
39
38
  "validator": "^13.12.0",
40
39
  "vue": "^3.5.0"
@@ -71,5 +70,8 @@
71
70
  "unplugin-auto-import": "^0.18.2",
72
71
  "unplugin-vue-components": "^0.27.3",
73
72
  "webpack": "^5.78.0"
73
+ },
74
+ "peerDependencies": {
75
+ "@uxda/nutshell": "^1.0.0"
74
76
  }
75
77
  }
@@ -1,5 +1,5 @@
1
1
  <template>
2
- <div class="consumption-date-filter">
2
+ <div class="appkit-date-filter">
3
3
  <div class="date-filter-header">日期选择</div>
4
4
  <div class="content">
5
5
  <div class="title">自定义</div>
@@ -22,22 +22,25 @@
22
22
  <div class="btn confirm" @click="onOkClick">确定</div>
23
23
  </div>
24
24
  <div class="bottom"></div>
25
- <nut-popup v-model:visible="datePickerOpen" position="bottom">
25
+ <nut-popup v-model:visible="datePickerOpen"
26
+ class="appkit-date-filter-picker-popup"
27
+ position="bottom"
28
+ overlay-class="appkit-date-filter-picker-overlay">
26
29
  <nut-date-picker
27
30
  v-model="focusedDate"
28
31
  :min-date="minDate"
29
32
  :max-date="maxDate"
30
33
  :is-show-chinese="false"
31
34
  :three-dimensional="false"
32
- @cancel="datePickerOpen = false"
33
- @confirm="onDatePickerComplete"
34
- ></nut-date-picker>
35
+ @cancel="onDatePickerCancel"
36
+ @confirm="onDatePickerComplete" />
35
37
  </nut-popup>
36
38
  </div>
37
39
  </template>
38
40
 
39
41
  <script lang="ts" setup>
40
42
  import { reactive, ref, watch } from 'vue'
43
+ import { usePopup } from '@uxda/nutshell/taro'
41
44
 
42
45
  type DateFilterProps = {
43
46
  from: string
@@ -46,7 +49,8 @@ type DateFilterProps = {
46
49
 
47
50
  const props = defineProps<DateFilterProps>()
48
51
 
49
- const emit = defineEmits(['complete', 'reset'])
52
+ const emit = defineEmits(['complete', 'reset']),
53
+ state = usePopup()
50
54
 
51
55
  watch(
52
56
  () => `${props.from}${props.to}`,
@@ -71,6 +75,11 @@ const minDate = ref<any>()
71
75
  const maxDate = ref<Date>(new Date())
72
76
  const datePickerOpen = ref<boolean>(false)
73
77
 
78
+ state.beforeClose = () => {
79
+ datePickerOpen.value = false
80
+ return true
81
+ }
82
+
74
83
  /**
75
84
  * 日期重置
76
85
  */
@@ -99,6 +108,12 @@ function onDatePickerComplete({ selectedValue, selectedOptions }) {
99
108
  result.to = time
100
109
  }
101
110
  datePickerOpen.value = false
111
+ state.couldClose = true
112
+ }
113
+
114
+ function onDatePickerCancel () {
115
+ datePickerOpen.value = false
116
+ state.couldClose = true
102
117
  }
103
118
 
104
119
  /**
@@ -106,7 +121,7 @@ function onDatePickerComplete({ selectedValue, selectedOptions }) {
106
121
  * 当选择开始时间大于结束时间,结束时间改为开始时间
107
122
  * 时间选择器都要小于当前时间,结束时间的时间选择器要以开始时间为最小值,
108
123
  */
109
- function switchDateInput(shift: string) {
124
+ function switchDateInput (shift: string) {
110
125
  // 要设置一下结束时间的起始值 开始时间往前倒5年
111
126
  if (shift === 'from') {
112
127
  let time = result.from.split('-').map(Number)
@@ -118,10 +133,12 @@ function switchDateInput(shift: string) {
118
133
  focusedDate.value = new Date(result[shift])
119
134
  focused.value = shift
120
135
  datePickerOpen.value = true
136
+ // 不允许浮窗关闭
137
+ state.couldClose = false
121
138
  }
122
139
  </script>
123
140
  <style lang="scss">
124
- .consumption-date-filter {
141
+ .appkit-date-filter {
125
142
  height: 100%;
126
143
  display: flex;
127
144
  flex-direction: column;
@@ -174,7 +191,7 @@ function switchDateInput(shift: string) {
174
191
  }
175
192
  }
176
193
  .buttons {
177
- margin: 0 15px;
194
+ margin: 32px 15px 0 15px;
178
195
  display: flex;
179
196
  justify-content: space-between;
180
197
  align-items: center;
@@ -224,4 +241,9 @@ function switchDateInput(shift: string) {
224
241
  background: #fff;
225
242
  }
226
243
  }
244
+ .nut-overlay {
245
+ &.date-filter-picker-overlay {
246
+ height: 100vh;
247
+ }
248
+ }
227
249
  </style>
@@ -10,7 +10,7 @@
10
10
  </template>
11
11
 
12
12
  <script lang="ts" setup>
13
- import { computed, PropType, reactive } from 'vue'
13
+ import { computed, PropType, ref } from 'vue'
14
14
  import { useNutshell } from '@uxda/nutshell/taro'
15
15
  import DateFilter from './DateFilter.vue'
16
16
  import dayjs from 'dayjs'
@@ -32,14 +32,17 @@ const model = defineModel({
32
32
  })
33
33
 
34
34
  const openDateRangePicker = () => {
35
+ const child = ref()
35
36
  $n.sheet({
36
37
  component: DateFilter,
38
+ ref: child,
37
39
  props: {
38
40
  from: model.value.from,
39
41
  to: model.value.to,
40
42
  },
43
+ modal: true, // 不允许点击 overlay 关闭弹窗
44
+ mask: true,
41
45
  onComplete (result: any) {
42
- console.log('===openDateFilter complete', result)
43
46
  model.value = {
44
47
  from: result.from,
45
48
  to: result.to
@@ -66,7 +66,7 @@ async function getNotice() {
66
66
 
67
67
  <style lang="scss">
68
68
  .notice-entry {
69
- position: fixed;
69
+ position: absolute;
70
70
  right: 0;
71
71
  top: 120px;
72
72
  min-width: 66px;
@@ -1,30 +1,33 @@
1
1
  <template>
2
- <div :class="['ocr-business-license', disabled ? 'disabled' : '']" class="ocr-icon" @click="onIconClick">
3
- <ns-icon name="https://simple.shensi.tech/icons/ocr.svg" />
2
+ <div
3
+ :class="['ocr-business-license', disabled ? 'disabled' : '']"
4
+ class="ocr-icon"
5
+ @click="onIconClick"
6
+ >
7
+ <ns-icon name="https://cdn.ddjf.com/static/images/beidouxing/ocr-icon.png" />
4
8
  </div>
5
9
  </template>
6
10
 
7
11
  <script lang="ts" setup>
8
- import Taro from '@tarojs/taro'
9
- import { NsIcon } from '@uxda/nutshell/taro'
10
- import { useAppKitOptions } from '../../Appkit'
12
+ import Taro from '@tarojs/taro';
13
+ import { NsIcon } from '@uxda/nutshell/taro';
14
+ import { useAppKitOptions } from '../../Appkit';
11
15
 
12
- const appKitOptions = useAppKitOptions()
13
-
14
- const emits = defineEmits(['complete'])
16
+ const appKitOptions = useAppKitOptions();
15
17
 
18
+ const emits = defineEmits(['complete']);
16
19
 
17
20
  type OcrBusinessLicenseProps = {
18
- disabled: boolean
19
- }
21
+ disabled: boolean;
22
+ };
20
23
 
21
- const props = defineProps<OcrBusinessLicenseProps>()
24
+ const props = defineProps<OcrBusinessLicenseProps>();
22
25
 
23
26
  export type OcrResult = {
24
- companyName: string
25
- idCardNo: string
26
- legalPersonName: string
27
- }
27
+ companyName: string;
28
+ idCardNo: string;
29
+ legalPersonName: string;
30
+ };
28
31
 
29
32
  async function taroImgCompress(src: string, quality = 80) {
30
33
  return new Promise((resolve, reject) => {
@@ -32,45 +35,45 @@ async function taroImgCompress(src: string, quality = 80) {
32
35
  src: src,
33
36
  quality: quality,
34
37
  success: (res) => {
35
- resolve(res)
38
+ resolve(res);
36
39
  },
37
40
  fail: (res) => {
38
- reject(res)
41
+ reject(res);
39
42
  },
40
- })
41
- })
43
+ });
44
+ });
42
45
  }
43
46
 
44
47
  function getCompressQuality(size: number) {
45
- let quality = 100
46
- const curSize = size / (1024 * 1024)
48
+ let quality = 100;
49
+ const curSize = size / (1024 * 1024);
47
50
  if (curSize > 6) {
48
- quality = quality - ((curSize - 6) / curSize) * 100
51
+ quality = quality - ((curSize - 6) / curSize) * 100;
49
52
  }
50
- return quality
53
+ return quality;
51
54
  }
52
55
 
53
56
  function allTrim(str: string) {
54
- return str.replace(/\s+/g, '')
57
+ return str.replace(/\s+/g, '');
55
58
  }
56
59
 
57
60
  async function onIconClick() {
58
61
  if (props.disabled) {
59
- return
62
+ return;
60
63
  }
61
- console.log('===onIconClick')
62
- let result: OcrResult | null = null
64
+ console.log('===onIconClick');
65
+ let result: OcrResult | null = null;
63
66
  try {
64
67
  const csRes = await Taro.chooseImage({
65
68
  count: 1,
66
- })
67
- let { path, size } = csRes.tempFiles[0]
69
+ });
70
+ let { path, size } = csRes.tempFiles[0];
68
71
  const compressImg: any =
69
- (await taroImgCompress(path, getCompressQuality(size))) || {}
70
- const filePath = compressImg.tempFilePath || path
71
- Taro.showLoading({ title: '营业执照识别中..' })
72
- const session = appKitOptions.token()
73
- const baseUrl = appKitOptions.baseUrl()
72
+ (await taroImgCompress(path, getCompressQuality(size))) || {};
73
+ const filePath = compressImg.tempFilePath || path;
74
+ Taro.showLoading({ title: '营业执照识别中..' });
75
+ const session = appKitOptions.token();
76
+ const baseUrl = appKitOptions.baseUrl();
74
77
  const upRes: any = await Taro.uploadFile({
75
78
  url: baseUrl + '/promoact/common/parseBusinessLicense',
76
79
  filePath,
@@ -82,11 +85,11 @@ async function onIconClick() {
82
85
  sessionKey: session || '',
83
86
  token: session || '',
84
87
  },
85
- })
86
- Taro.hideLoading()
87
- const res = JSON.parse(upRes.data)
88
+ });
89
+ Taro.hideLoading();
90
+ const res = JSON.parse(upRes.data);
88
91
  if (res.code === '200') {
89
- const faceInfo = res.result || {}
92
+ const faceInfo = res.result || {};
90
93
  result = {
91
94
  companyName: allTrim(faceInfo.companyName || ''),
92
95
  idCardNo: allTrim(faceInfo.idCardNo || ''),
@@ -94,22 +97,22 @@ async function onIconClick() {
94
97
  fileId: faceInfo.fileId,
95
98
  originalUrl: faceInfo.originalUrl,
96
99
  downloadUrl: faceInfo.downloadUrl,
97
- }
98
- console.log('===识别', result)
100
+ };
101
+ console.log('===识别', result);
99
102
  if (!result.companyName && !result.idCardNo) {
100
- Taro.showToast({ title: '识别失败,请重试', icon: 'none' })
103
+ Taro.showToast({ title: '识别失败,请重试', icon: 'none' });
101
104
  }
102
105
  } else {
103
106
  Taro.showToast({
104
107
  title: res.msg,
105
108
  icon: 'error',
106
- })
109
+ });
107
110
  }
108
111
  } catch (err) {
109
- Taro.hideLoading()
110
- console.log(err)
112
+ Taro.hideLoading();
113
+ console.log(err);
111
114
  }
112
- emits('complete', result)
115
+ emits('complete', result);
113
116
  }
114
117
  </script>
115
118
 
@@ -1,29 +1,29 @@
1
1
  <template>
2
2
  <div :class="['ocr-icon', disabled ? 'disabled' : '']" @click="onIconClick">
3
- <ns-icon name="https://simple.shensi.tech/icons/ocr.svg" />
3
+ <ns-icon name="https://cdn.ddjf.com/static/images/beidouxing/ocr-icon.png" />
4
4
  </div>
5
5
  </template>
6
6
 
7
7
  <script lang="ts" setup>
8
- import Taro from '@tarojs/taro'
9
- import { NsIcon } from '@uxda/nutshell/taro'
10
- import { useAppKitOptions } from '../../Appkit'
8
+ import Taro from '@tarojs/taro';
9
+ import { NsIcon } from '@uxda/nutshell/taro';
10
+ import { useAppKitOptions } from '../../Appkit';
11
11
 
12
- const appKitOptions = useAppKitOptions()
12
+ const appKitOptions = useAppKitOptions();
13
13
 
14
- const emits = defineEmits(['complete'])
14
+ const emits = defineEmits(['complete']);
15
15
 
16
16
  type OcrIconProps = {
17
- disabled: boolean
18
- }
17
+ disabled: boolean;
18
+ };
19
19
 
20
- const props = defineProps<OcrIconProps>()
20
+ const props = defineProps<OcrIconProps>();
21
21
 
22
22
  export type OcrResult = {
23
- name: string
24
- number: string
25
- address: string
26
- }
23
+ name: string;
24
+ number: string;
25
+ address: string;
26
+ };
27
27
 
28
28
  async function taroImgCompress(src: string, quality = 80) {
29
29
  return new Promise((resolve, reject) => {
@@ -31,43 +31,44 @@ async function taroImgCompress(src: string, quality = 80) {
31
31
  src: src,
32
32
  quality: quality,
33
33
  success: (res) => {
34
- resolve(res)
34
+ resolve(res);
35
35
  },
36
36
  fail: (res) => {
37
- reject(res)
37
+ reject(res);
38
38
  },
39
- })
40
- })
39
+ });
40
+ });
41
41
  }
42
42
 
43
43
  function getCompressQuality(size: number) {
44
- let quality = 100
45
- const curSize = size / (1024 * 1024)
44
+ let quality = 100;
45
+ const curSize = size / (1024 * 1024);
46
46
  if (curSize > 6) {
47
- quality = quality - ((curSize - 6) / curSize) * 100
47
+ quality = quality - ((curSize - 6) / curSize) * 100;
48
48
  }
49
- return quality
49
+ return quality;
50
50
  }
51
51
 
52
52
  function allTrim(str: string) {
53
- return str.replace(/\s+/g, '')
53
+ return str.replace(/\s+/g, '');
54
54
  }
55
55
 
56
56
  async function onIconClick() {
57
57
  if (props.disabled) {
58
- return
58
+ return;
59
59
  }
60
- let result: OcrResult | null = null
60
+ let result: OcrResult | null = null;
61
61
  try {
62
62
  const csRes = await Taro.chooseImage({
63
63
  count: 1,
64
- })
65
- let { path, size } = csRes.tempFiles[0]
66
- const compressImg: any = (await taroImgCompress(path, getCompressQuality(size))) || {}
67
- const filePath = compressImg.tempFilePath || path
68
- Taro.showLoading({ title: '身份证识别中..' })
69
- const session = appKitOptions.token()
70
- const baseUrl = appKitOptions.baseUrl()
64
+ });
65
+ let { path, size } = csRes.tempFiles[0];
66
+ const compressImg: any =
67
+ (await taroImgCompress(path, getCompressQuality(size))) || {};
68
+ const filePath = compressImg.tempFilePath || path;
69
+ Taro.showLoading({ title: '身份证识别中..' });
70
+ const session = appKitOptions.token();
71
+ const baseUrl = appKitOptions.baseUrl();
71
72
  const upRes: any = await Taro.uploadFile({
72
73
  url: baseUrl + '/hkapprove/ocr/idcard',
73
74
  filePath,
@@ -80,12 +81,12 @@ async function onIconClick() {
80
81
  sessionKey: session || '',
81
82
  token: session || '',
82
83
  },
83
- })
84
- Taro.hideLoading()
85
- const res = JSON.parse(upRes.data)
84
+ });
85
+ Taro.hideLoading();
86
+ const res = JSON.parse(upRes.data);
86
87
  if (res.code === '200') {
87
88
  const faceInfo = res.result.faceInfo || {},
88
- file = res.result.fileUploadVO
89
+ file = res.result.fileUploadVO;
89
90
  result = {
90
91
  name: allTrim(faceInfo.name || ''),
91
92
  number: allTrim(faceInfo.num || ''),
@@ -96,22 +97,22 @@ async function onIconClick() {
96
97
  // object: file.objectNo,
97
98
  // thumb: file.thumbnailUrl
98
99
  // }
99
- }
100
- console.log('===识别', result)
100
+ };
101
+ console.log('===识别', result);
101
102
  if (!result.name && !result.number) {
102
- Taro.showToast({ title: '识别失败,请重试', icon: 'none' })
103
+ Taro.showToast({ title: '识别失败,请重试', icon: 'none' });
103
104
  }
104
105
  } else {
105
106
  Taro.showToast({
106
107
  title: res.msg,
107
108
  icon: 'error',
108
- })
109
+ });
109
110
  }
110
111
  } catch (err) {
111
- Taro.hideLoading()
112
- console.log(err)
112
+ Taro.hideLoading();
113
+ console.log(err);
113
114
  }
114
- emits('complete', result)
115
+ emits('complete', result);
115
116
  }
116
117
  </script>
117
118
 
@@ -129,4 +130,4 @@ async function onIconClick() {
129
130
  }
130
131
  }
131
132
  }
132
- </style>
133
+ </style>