af-mobile-client-vue3 1.4.63 → 1.4.65
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/package.json +1 -1
- package/src/components/common/otherCharge/ChargePrintSelectorAndRemarks.vue +137 -137
- package/src/components/common/otherCharge/CodePayment.vue +357 -357
- package/src/components/common/otherCharge/FileUploader.vue +602 -602
- package/src/components/common/otherCharge/GridFileUploader.vue +846 -846
- package/src/components/common/otherCharge/PaymentMethodSelector.vue +202 -202
- package/src/components/common/otherCharge/PaymentMethodSelectorCard.vue +45 -45
- package/src/components/common/otherCharge/ReceiptModal.vue +273 -273
- package/src/components/common/otherCharge/index.ts +43 -43
- package/src/components/core/ImageUploader/index.vue +4 -4
- package/src/components/data/OtherCharge/OtherChargeItemModal.vue +547 -547
- package/src/components/data/XForm/index.vue +45 -0
- package/src/components/data/XFormGroup/doc/DeviceForm.vue +1 -1
- package/src/components/data/XFormGroup/doc/UserForm.vue +1 -1
- package/src/components/data/XFormItem/index.vue +32 -3
- package/src/components/data/XReportGrid/XReportDemo.vue +33 -33
- package/src/components/data/XReportGrid/print.js +184 -184
- package/src/utils/queryFormDefaultRangePicker.ts +57 -57
- package/src/utils/timeUtil.ts +27 -27
- package/src/views/component/XCellListView/index.vue +107 -138
- package/src/views/component/XFormGroupView/index.vue +78 -82
- package/src/views/component/XFormView/index.vue +41 -46
package/package.json
CHANGED
|
@@ -1,137 +1,137 @@
|
|
|
1
|
-
<script setup lang="ts">
|
|
2
|
-
import CardContainer from '@af-mobile-client-vue3/components/data/CardContainer/CardContainer.vue'
|
|
3
|
-
import CardHeader from '@af-mobile-client-vue3/components/data/CardContainer/CardHeader.vue'
|
|
4
|
-
import {
|
|
5
|
-
Field as VanField,
|
|
6
|
-
Picker as VanPicker,
|
|
7
|
-
Popup as VanPopup,
|
|
8
|
-
} from 'vant'
|
|
9
|
-
import { ref, watch } from 'vue'
|
|
10
|
-
|
|
11
|
-
const props = defineProps<{
|
|
12
|
-
modelValue: string
|
|
13
|
-
remarks: string
|
|
14
|
-
}>()
|
|
15
|
-
|
|
16
|
-
const emit = defineEmits<{
|
|
17
|
-
(e: 'update:modelValue', value: string): void
|
|
18
|
-
(e: 'update:remarks', value: string): void
|
|
19
|
-
}>()
|
|
20
|
-
|
|
21
|
-
const printOptions = [
|
|
22
|
-
{ text: '电子发票', value: '电子发票' },
|
|
23
|
-
{ text: '普通收据', value: '普通收据' },
|
|
24
|
-
{ text: '两者都需要', value: 'both' },
|
|
25
|
-
]
|
|
26
|
-
|
|
27
|
-
const selectedOption = ref(getOptionText(props.modelValue))
|
|
28
|
-
const remarks = ref(props.remarks)
|
|
29
|
-
const showPicker = ref(false)
|
|
30
|
-
|
|
31
|
-
function getOptionText(value: string): string {
|
|
32
|
-
const option = printOptions.find(opt => opt.value === value)
|
|
33
|
-
return option ? option.text : ''
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
function onConfirm({ selectedValues }: { selectedValues: string[] }) {
|
|
37
|
-
selectedOption.value = selectedValues[0]
|
|
38
|
-
emit('update:modelValue', selectedValues[0])
|
|
39
|
-
showPicker.value = false
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
watch(() => remarks.value, (newValue) => {
|
|
43
|
-
emit('update:remarks', newValue)
|
|
44
|
-
})
|
|
45
|
-
|
|
46
|
-
// 当从外部更新值时更新内部状态
|
|
47
|
-
watch(() => props.modelValue, (newValue) => {
|
|
48
|
-
selectedOption.value = getOptionText(newValue)
|
|
49
|
-
})
|
|
50
|
-
|
|
51
|
-
watch(() => props.remarks, (newValue) => {
|
|
52
|
-
remarks.value = newValue
|
|
53
|
-
})
|
|
54
|
-
</script>
|
|
55
|
-
|
|
56
|
-
<template>
|
|
57
|
-
<CardContainer class="charge-print-and-remarks">
|
|
58
|
-
<CardHeader title="打印及备注" />
|
|
59
|
-
<div class="charge-print-options">
|
|
60
|
-
<div class="charge-print-options__section">
|
|
61
|
-
<label class="charge-print-options__label">收据打印选项</label>
|
|
62
|
-
<div class="charge-print-options__selector">
|
|
63
|
-
<VanField
|
|
64
|
-
v-model="selectedOption"
|
|
65
|
-
is-link
|
|
66
|
-
readonly
|
|
67
|
-
placeholder="请选择打印方式"
|
|
68
|
-
@click="showPicker = true"
|
|
69
|
-
/>
|
|
70
|
-
</div>
|
|
71
|
-
</div>
|
|
72
|
-
|
|
73
|
-
<div class="charge-print-options__section">
|
|
74
|
-
<label class="charge-print-options__label">备注</label>
|
|
75
|
-
<div class="charge-print-options__selector">
|
|
76
|
-
<VanField
|
|
77
|
-
v-model="remarks"
|
|
78
|
-
type="textarea"
|
|
79
|
-
placeholder="可选填写备注信息"
|
|
80
|
-
rows="2"
|
|
81
|
-
autosize
|
|
82
|
-
maxlength="200"
|
|
83
|
-
show-word-limit
|
|
84
|
-
/>
|
|
85
|
-
</div>
|
|
86
|
-
</div>
|
|
87
|
-
|
|
88
|
-
<VanPopup v-model:show="showPicker" position="bottom" round teleport="body">
|
|
89
|
-
<VanPicker
|
|
90
|
-
:columns="printOptions"
|
|
91
|
-
show-toolbar
|
|
92
|
-
title="选择打印方式"
|
|
93
|
-
@confirm="onConfirm"
|
|
94
|
-
@cancel="showPicker = false"
|
|
95
|
-
/>
|
|
96
|
-
</VanPopup>
|
|
97
|
-
</div>
|
|
98
|
-
</CardContainer>
|
|
99
|
-
</template>
|
|
100
|
-
|
|
101
|
-
<style scoped lang="less">
|
|
102
|
-
.charge-print-and-remarks {
|
|
103
|
-
margin-bottom: 16px;
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
.charge-print-options {
|
|
107
|
-
&__section {
|
|
108
|
-
margin-bottom: 16px;
|
|
109
|
-
|
|
110
|
-
&:last-child {
|
|
111
|
-
margin-bottom: 0;
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
&__label {
|
|
116
|
-
display: block;
|
|
117
|
-
font-size: 12px;
|
|
118
|
-
font-weight: 500;
|
|
119
|
-
color: #6b7280;
|
|
120
|
-
margin-bottom: 4px;
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
&__selector {
|
|
124
|
-
position: relative;
|
|
125
|
-
|
|
126
|
-
:deep(.van-field) {
|
|
127
|
-
background-color: #f9fafb;
|
|
128
|
-
border-radius: 6px;
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
:deep(.van-field__control) {
|
|
133
|
-
background-color: #f9fafb;
|
|
134
|
-
border-radius: 6px;
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
</style>
|
|
1
|
+
<script setup lang="ts">
|
|
2
|
+
import CardContainer from '@af-mobile-client-vue3/components/data/CardContainer/CardContainer.vue'
|
|
3
|
+
import CardHeader from '@af-mobile-client-vue3/components/data/CardContainer/CardHeader.vue'
|
|
4
|
+
import {
|
|
5
|
+
Field as VanField,
|
|
6
|
+
Picker as VanPicker,
|
|
7
|
+
Popup as VanPopup,
|
|
8
|
+
} from 'vant'
|
|
9
|
+
import { ref, watch } from 'vue'
|
|
10
|
+
|
|
11
|
+
const props = defineProps<{
|
|
12
|
+
modelValue: string
|
|
13
|
+
remarks: string
|
|
14
|
+
}>()
|
|
15
|
+
|
|
16
|
+
const emit = defineEmits<{
|
|
17
|
+
(e: 'update:modelValue', value: string): void
|
|
18
|
+
(e: 'update:remarks', value: string): void
|
|
19
|
+
}>()
|
|
20
|
+
|
|
21
|
+
const printOptions = [
|
|
22
|
+
{ text: '电子发票', value: '电子发票' },
|
|
23
|
+
{ text: '普通收据', value: '普通收据' },
|
|
24
|
+
{ text: '两者都需要', value: 'both' },
|
|
25
|
+
]
|
|
26
|
+
|
|
27
|
+
const selectedOption = ref(getOptionText(props.modelValue))
|
|
28
|
+
const remarks = ref(props.remarks)
|
|
29
|
+
const showPicker = ref(false)
|
|
30
|
+
|
|
31
|
+
function getOptionText(value: string): string {
|
|
32
|
+
const option = printOptions.find(opt => opt.value === value)
|
|
33
|
+
return option ? option.text : ''
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
function onConfirm({ selectedValues }: { selectedValues: string[] }) {
|
|
37
|
+
selectedOption.value = selectedValues[0]
|
|
38
|
+
emit('update:modelValue', selectedValues[0])
|
|
39
|
+
showPicker.value = false
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
watch(() => remarks.value, (newValue) => {
|
|
43
|
+
emit('update:remarks', newValue)
|
|
44
|
+
})
|
|
45
|
+
|
|
46
|
+
// 当从外部更新值时更新内部状态
|
|
47
|
+
watch(() => props.modelValue, (newValue) => {
|
|
48
|
+
selectedOption.value = getOptionText(newValue)
|
|
49
|
+
})
|
|
50
|
+
|
|
51
|
+
watch(() => props.remarks, (newValue) => {
|
|
52
|
+
remarks.value = newValue
|
|
53
|
+
})
|
|
54
|
+
</script>
|
|
55
|
+
|
|
56
|
+
<template>
|
|
57
|
+
<CardContainer class="charge-print-and-remarks">
|
|
58
|
+
<CardHeader title="打印及备注" />
|
|
59
|
+
<div class="charge-print-options">
|
|
60
|
+
<div class="charge-print-options__section">
|
|
61
|
+
<label class="charge-print-options__label">收据打印选项</label>
|
|
62
|
+
<div class="charge-print-options__selector">
|
|
63
|
+
<VanField
|
|
64
|
+
v-model="selectedOption"
|
|
65
|
+
is-link
|
|
66
|
+
readonly
|
|
67
|
+
placeholder="请选择打印方式"
|
|
68
|
+
@click="showPicker = true"
|
|
69
|
+
/>
|
|
70
|
+
</div>
|
|
71
|
+
</div>
|
|
72
|
+
|
|
73
|
+
<div class="charge-print-options__section">
|
|
74
|
+
<label class="charge-print-options__label">备注</label>
|
|
75
|
+
<div class="charge-print-options__selector">
|
|
76
|
+
<VanField
|
|
77
|
+
v-model="remarks"
|
|
78
|
+
type="textarea"
|
|
79
|
+
placeholder="可选填写备注信息"
|
|
80
|
+
rows="2"
|
|
81
|
+
autosize
|
|
82
|
+
maxlength="200"
|
|
83
|
+
show-word-limit
|
|
84
|
+
/>
|
|
85
|
+
</div>
|
|
86
|
+
</div>
|
|
87
|
+
|
|
88
|
+
<VanPopup v-model:show="showPicker" position="bottom" round teleport="body">
|
|
89
|
+
<VanPicker
|
|
90
|
+
:columns="printOptions"
|
|
91
|
+
show-toolbar
|
|
92
|
+
title="选择打印方式"
|
|
93
|
+
@confirm="onConfirm"
|
|
94
|
+
@cancel="showPicker = false"
|
|
95
|
+
/>
|
|
96
|
+
</VanPopup>
|
|
97
|
+
</div>
|
|
98
|
+
</CardContainer>
|
|
99
|
+
</template>
|
|
100
|
+
|
|
101
|
+
<style scoped lang="less">
|
|
102
|
+
.charge-print-and-remarks {
|
|
103
|
+
margin-bottom: 16px;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
.charge-print-options {
|
|
107
|
+
&__section {
|
|
108
|
+
margin-bottom: 16px;
|
|
109
|
+
|
|
110
|
+
&:last-child {
|
|
111
|
+
margin-bottom: 0;
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
&__label {
|
|
116
|
+
display: block;
|
|
117
|
+
font-size: 12px;
|
|
118
|
+
font-weight: 500;
|
|
119
|
+
color: #6b7280;
|
|
120
|
+
margin-bottom: 4px;
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
&__selector {
|
|
124
|
+
position: relative;
|
|
125
|
+
|
|
126
|
+
:deep(.van-field) {
|
|
127
|
+
background-color: #f9fafb;
|
|
128
|
+
border-radius: 6px;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
:deep(.van-field__control) {
|
|
133
|
+
background-color: #f9fafb;
|
|
134
|
+
border-radius: 6px;
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
</style>
|