sh-view 2.6.2 → 2.6.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.
- package/package.json +1 -1
- package/packages/components/global-components/sh-form/form.vue +110 -108
- package/packages/components/global-components/sh-form/js/useForm.js +3 -0
- package/packages/components/global-components/sh-form/query.vue +70 -68
- package/packages/components/global-components/sh-table/components/sh-column.vue +69 -69
- package/packages/components/global-components/sh-table/grid.vue +160 -159
- package/packages/components/global-components/sh-table/js/useTable.js +12 -6
- package/packages/components/global-components/sh-table/table.vue +218 -217
- package/packages/components/other-components/sh-cron-modal/mixin/cron-hooks.js +179 -177
- package/packages/components/other-components/sh-cron-modal/tabs/cron-day-box.vue +101 -99
- package/packages/components/other-components/sh-cron-modal/tabs/cron-hour-box.vue +68 -66
- package/packages/components/other-components/sh-cron-modal/tabs/cron-minute-box.vue +68 -66
- package/packages/components/other-components/sh-cron-modal/tabs/cron-month-box.vue +68 -66
- package/packages/components/other-components/sh-cron-modal/tabs/cron-second-box.vue +68 -66
- package/packages/components/other-components/sh-cron-modal/tabs/cron-week-box.vue +126 -125
- package/packages/components/other-components/sh-cron-modal/tabs/cron-year-box.vue +59 -57
- package/packages/components/other-components/sh-preview/components/sh-excel.vue +929 -927
- package/packages/components/other-components/sh-preview/components/sh-word.vue +78 -76
- package/packages/vxeTable/render/cell/vxe-render-checkbox.vue +28 -26
- package/packages/vxeTable/render/cell/vxe-render-checkgroup.vue +43 -42
- package/packages/vxeTable/render/cell/vxe-render-code.vue +36 -34
- package/packages/vxeTable/render/cell/vxe-render-goption.vue +104 -103
- package/packages/vxeTable/render/cell/vxe-render-href.vue +21 -19
- package/packages/vxeTable/render/cell/vxe-render-input.vue +53 -52
- package/packages/vxeTable/render/cell/vxe-render-money.vue +33 -31
- package/packages/vxeTable/render/cell/vxe-render-progress.vue +28 -26
- package/packages/vxeTable/render/cell/vxe-render-radio.vue +28 -26
- package/packages/vxeTable/render/cell/vxe-render-radiogroup.vue +43 -42
- package/packages/vxeTable/render/cell/vxe-render-select.vue +52 -51
- package/packages/vxeTable/render/cell/vxe-render-switch.vue +28 -26
- package/packages/vxeTable/render/cell/vxe-render-table.vue +51 -50
- package/packages/vxeTable/render/cell/vxe-render-textarea.vue +28 -26
- package/packages/vxeTable/render/cell/vxe-render-time.vue +44 -41
- package/packages/vxeTable/render/cell/vxe-render-tree.vue +63 -60
- package/packages/vxeTable/render/cell/vxe-render-upload.vue +28 -26
- package/packages/vxeTable/render/filters/vxe-filter-input.vue +25 -23
- package/packages/vxeTable/render/footer/vxe-footer-input.vue +23 -21
- package/packages/vxeTable/render/footer/vxe-footer-money.vue +30 -28
- package/packages/vxeTable/render/header/vxe-header-money.vue +31 -29
- package/packages/vxeTable/render/mixin/cell-hooks.js +4 -1
|
@@ -1,26 +1,28 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<span class="vxe-render--inner" :class="{ 'form-render': rform, 'td-render': !rform }">
|
|
3
|
-
<template v-if="redit || isEditAll">
|
|
4
|
-
<vxe-textarea v-model="renderValue" v-bind="rprops" :size="rsize" @change="vxeInputChange" @blur="vxeBlurCallback" @clear="vxeBlurCallback" />
|
|
5
|
-
</template>
|
|
6
|
-
<template v-else>
|
|
7
|
-
<span>{{ renderText }}</span>
|
|
8
|
-
</template>
|
|
9
|
-
</span>
|
|
10
|
-
</template>
|
|
11
|
-
|
|
12
|
-
<script>
|
|
13
|
-
import { defineComponent, getCurrentInstance } from 'vue'
|
|
14
|
-
import cellProps from '../mixin/cell-props'
|
|
15
|
-
import cellHooks from '../mixin/cell-hooks'
|
|
16
|
-
export default defineComponent({
|
|
17
|
-
name: 'VxeRenderTextarea',
|
|
18
|
-
props: cellProps,
|
|
19
|
-
setup(props, context) {
|
|
20
|
-
const { proxy } = getCurrentInstance()
|
|
21
|
-
const useCell = cellHooks(props, context, proxy)
|
|
22
|
-
|
|
23
|
-
return
|
|
24
|
-
|
|
25
|
-
}
|
|
26
|
-
|
|
1
|
+
<template>
|
|
2
|
+
<span class="vxe-render--inner" :class="{ 'form-render': rform, 'td-render': !rform }">
|
|
3
|
+
<template v-if="redit || isEditAll">
|
|
4
|
+
<vxe-textarea v-model="renderValue" v-bind="rprops" :size="rsize" @change="vxeInputChange" @blur="vxeBlurCallback" @clear="vxeBlurCallback" />
|
|
5
|
+
</template>
|
|
6
|
+
<template v-else>
|
|
7
|
+
<span>{{ renderText }}</span>
|
|
8
|
+
</template>
|
|
9
|
+
</span>
|
|
10
|
+
</template>
|
|
11
|
+
|
|
12
|
+
<script>
|
|
13
|
+
import { defineComponent, getCurrentInstance } from 'vue'
|
|
14
|
+
import cellProps from '../mixin/cell-props'
|
|
15
|
+
import cellHooks from '../mixin/cell-hooks'
|
|
16
|
+
export default defineComponent({
|
|
17
|
+
name: 'VxeRenderTextarea',
|
|
18
|
+
props: cellProps,
|
|
19
|
+
setup(props, context) {
|
|
20
|
+
const { proxy } = getCurrentInstance()
|
|
21
|
+
const useCell = cellHooks(props, context, proxy)
|
|
22
|
+
|
|
23
|
+
return {
|
|
24
|
+
...useCell
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
})
|
|
28
|
+
</script>
|
|
@@ -1,41 +1,44 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<span class="vxe-render--inner" :class="{ 'form-render': rform, 'td-render': !rform }">
|
|
3
|
-
<template v-if="redit || isEditAll">
|
|
4
|
-
<vxe-input v-model="renderValue" v-bind="rprops" :size="rsize" :disabled-method="vxeDisabledMethod" @change="vxeChangeCallBack"></vxe-input>
|
|
5
|
-
</template>
|
|
6
|
-
<template v-else>
|
|
7
|
-
<span v-html="renderText"></span>
|
|
8
|
-
</template>
|
|
9
|
-
</span>
|
|
10
|
-
</template>
|
|
11
|
-
|
|
12
|
-
<script>
|
|
13
|
-
import { defineComponent, getCurrentInstance } from 'vue'
|
|
14
|
-
import cellProps from '../mixin/cell-props'
|
|
15
|
-
import cellHooks from '../mixin/cell-hooks'
|
|
16
|
-
export default defineComponent({
|
|
17
|
-
name: 'VxeRenderTime',
|
|
18
|
-
props: cellProps,
|
|
19
|
-
setup(props, context) {
|
|
20
|
-
const { proxy } = getCurrentInstance()
|
|
21
|
-
const { $vUtils } = proxy
|
|
22
|
-
const useCell = cellHooks(props, context, proxy)
|
|
23
|
-
|
|
24
|
-
// 禁用事件
|
|
25
|
-
const vxeDisabledMethod = ({ date, viewType }) => {
|
|
26
|
-
let { startTime, endTime } = props.rprops
|
|
27
|
-
if (startTime) {
|
|
28
|
-
startTime = $vUtils.format(startTime, props.rdata)
|
|
29
|
-
let { done, time } = $vUtils.getDateDiff(startTime, date)
|
|
30
|
-
return startTime ? !done : false
|
|
31
|
-
} else if (endTime) {
|
|
32
|
-
endTime = $vUtils.format(endTime, props.rdata)
|
|
33
|
-
let { done, time } = $vUtils.getDateDiff(endTime, date)
|
|
34
|
-
return done
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
return
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
1
|
+
<template>
|
|
2
|
+
<span class="vxe-render--inner" :class="{ 'form-render': rform, 'td-render': !rform }">
|
|
3
|
+
<template v-if="redit || isEditAll">
|
|
4
|
+
<vxe-input v-model="renderValue" v-bind="rprops" :size="rsize" :disabled-method="vxeDisabledMethod" @change="vxeChangeCallBack"></vxe-input>
|
|
5
|
+
</template>
|
|
6
|
+
<template v-else>
|
|
7
|
+
<span v-html="renderText"></span>
|
|
8
|
+
</template>
|
|
9
|
+
</span>
|
|
10
|
+
</template>
|
|
11
|
+
|
|
12
|
+
<script>
|
|
13
|
+
import { defineComponent, getCurrentInstance } from 'vue'
|
|
14
|
+
import cellProps from '../mixin/cell-props'
|
|
15
|
+
import cellHooks from '../mixin/cell-hooks'
|
|
16
|
+
export default defineComponent({
|
|
17
|
+
name: 'VxeRenderTime',
|
|
18
|
+
props: cellProps,
|
|
19
|
+
setup(props, context) {
|
|
20
|
+
const { proxy } = getCurrentInstance()
|
|
21
|
+
const { $vUtils } = proxy
|
|
22
|
+
const useCell = cellHooks(props, context, proxy)
|
|
23
|
+
|
|
24
|
+
// 禁用事件
|
|
25
|
+
const vxeDisabledMethod = ({ date, viewType }) => {
|
|
26
|
+
let { startTime, endTime } = props.rprops
|
|
27
|
+
if (startTime) {
|
|
28
|
+
startTime = $vUtils.format(startTime, props.rdata)
|
|
29
|
+
let { done, time } = $vUtils.getDateDiff(startTime, date)
|
|
30
|
+
return startTime ? !done : false
|
|
31
|
+
} else if (endTime) {
|
|
32
|
+
endTime = $vUtils.format(endTime, props.rdata)
|
|
33
|
+
let { done, time } = $vUtils.getDateDiff(endTime, date)
|
|
34
|
+
return done
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
return {
|
|
39
|
+
...useCell,
|
|
40
|
+
vxeDisabledMethod
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
})
|
|
44
|
+
</script>
|
|
@@ -1,60 +1,63 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<span class="vxe-render--inner" :class="{ 'form-render': rform, 'td-render': !rform }">
|
|
3
|
-
<template v-if="redit || isEditAll">
|
|
4
|
-
<span v-if="rprops.prefixText && rform" class="prefix">
|
|
5
|
-
<vxe-button v-if="prefixButton" v-bind="psButtonConfig" @click="vxeInputPrefixClick">{{ rprops.prefixText }}</vxe-button>
|
|
6
|
-
<span v-else @click="vxeInputPrefixClick">{{ rprops.prefixText }}</span>
|
|
7
|
-
</span>
|
|
8
|
-
<sh-tree v-model="renderValue" v-bind="rprops" :field="rkey" :value-data="rdata" :size="rsize" is-select @change="vxeTreeCallback"></sh-tree>
|
|
9
|
-
<span v-if="rprops.suffixText && rform" class="suffix">
|
|
10
|
-
<vxe-button v-if="suffixButton" v-bind="psButtonConfig" @click="vxeInputSuffixClick">{{ rprops.suffixText }}</vxe-button>
|
|
11
|
-
<span v-else @click="vxeInputSuffixClick">{{ rprops.suffixText }}</span>
|
|
12
|
-
</span>
|
|
13
|
-
</template>
|
|
14
|
-
<template v-else>
|
|
15
|
-
<span v-html="renderText"></span>
|
|
16
|
-
</template>
|
|
17
|
-
</span>
|
|
18
|
-
</template>
|
|
19
|
-
|
|
20
|
-
<script>
|
|
21
|
-
import { defineComponent, getCurrentInstance } from 'vue'
|
|
22
|
-
import cellProps from '../mixin/cell-props'
|
|
23
|
-
import cellHooks from '../mixin/cell-hooks'
|
|
24
|
-
export default defineComponent({
|
|
25
|
-
name: 'VxeRenderTree',
|
|
26
|
-
props: cellProps,
|
|
27
|
-
setup(props, context) {
|
|
28
|
-
const { proxy } = getCurrentInstance()
|
|
29
|
-
const { $vUtils } = proxy
|
|
30
|
-
const useCell = cellHooks(props, context, proxy)
|
|
31
|
-
|
|
32
|
-
// 输入框回调
|
|
33
|
-
const vxeTreeCallback = (selectedKeys, selectedRows) => {
|
|
34
|
-
let { valueKeys, multiple } = props.rprops
|
|
35
|
-
if (!multiple) {
|
|
36
|
-
selectedKeys = selectedKeys[0] || ''
|
|
37
|
-
}
|
|
38
|
-
if (valueKeys && selectedRows && selectedRows.length > 0) {
|
|
39
|
-
let prefixKey = props.rkey.endsWith('Id') ? String(props.rkey).replace('Id', '') : props.rkey
|
|
40
|
-
let valueks = Array.isArray(valueKeys) ? valueKeys : valueKeys.split(',')
|
|
41
|
-
valueks.forEach(key => {
|
|
42
|
-
let keySplits = key.split('=')
|
|
43
|
-
let fromDefaultKey = String(keySplits[0]).replace(/@/gi, '').toLowerCase()
|
|
44
|
-
let fromKey = keySplits[1] || String(keySplits[0]).replace(/@/gi, prefixKey)
|
|
45
|
-
let fromvalue = null
|
|
46
|
-
if (multiple) {
|
|
47
|
-
fromvalue = selectedRows.map(item => $vUtils.get(item, fromKey) || $vUtils.get(item, fromDefaultKey))
|
|
48
|
-
} else {
|
|
49
|
-
fromvalue = $vUtils.get(selectedRows[0], fromKey) || $vUtils.get(selectedRows[0], fromDefaultKey)
|
|
50
|
-
}
|
|
51
|
-
$vUtils.set(props.rdata, fromKey, fromvalue)
|
|
52
|
-
})
|
|
53
|
-
}
|
|
54
|
-
useCell.setRenderValue(selectedKeys, true)
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
return
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
1
|
+
<template>
|
|
2
|
+
<span class="vxe-render--inner" :class="{ 'form-render': rform, 'td-render': !rform }">
|
|
3
|
+
<template v-if="redit || isEditAll">
|
|
4
|
+
<span v-if="rprops.prefixText && rform" class="prefix">
|
|
5
|
+
<vxe-button v-if="prefixButton" v-bind="psButtonConfig" @click="vxeInputPrefixClick">{{ rprops.prefixText }}</vxe-button>
|
|
6
|
+
<span v-else @click="vxeInputPrefixClick">{{ rprops.prefixText }}</span>
|
|
7
|
+
</span>
|
|
8
|
+
<sh-tree v-model="renderValue" v-bind="rprops" :field="rkey" :value-data="rdata" :size="rsize" is-select @change="vxeTreeCallback"></sh-tree>
|
|
9
|
+
<span v-if="rprops.suffixText && rform" class="suffix">
|
|
10
|
+
<vxe-button v-if="suffixButton" v-bind="psButtonConfig" @click="vxeInputSuffixClick">{{ rprops.suffixText }}</vxe-button>
|
|
11
|
+
<span v-else @click="vxeInputSuffixClick">{{ rprops.suffixText }}</span>
|
|
12
|
+
</span>
|
|
13
|
+
</template>
|
|
14
|
+
<template v-else>
|
|
15
|
+
<span v-html="renderText"></span>
|
|
16
|
+
</template>
|
|
17
|
+
</span>
|
|
18
|
+
</template>
|
|
19
|
+
|
|
20
|
+
<script>
|
|
21
|
+
import { defineComponent, getCurrentInstance } from 'vue'
|
|
22
|
+
import cellProps from '../mixin/cell-props'
|
|
23
|
+
import cellHooks from '../mixin/cell-hooks'
|
|
24
|
+
export default defineComponent({
|
|
25
|
+
name: 'VxeRenderTree',
|
|
26
|
+
props: cellProps,
|
|
27
|
+
setup(props, context) {
|
|
28
|
+
const { proxy } = getCurrentInstance()
|
|
29
|
+
const { $vUtils } = proxy
|
|
30
|
+
const useCell = cellHooks(props, context, proxy)
|
|
31
|
+
|
|
32
|
+
// 输入框回调
|
|
33
|
+
const vxeTreeCallback = (selectedKeys, selectedRows) => {
|
|
34
|
+
let { valueKeys, multiple } = props.rprops
|
|
35
|
+
if (!multiple) {
|
|
36
|
+
selectedKeys = selectedKeys[0] || ''
|
|
37
|
+
}
|
|
38
|
+
if (valueKeys && selectedRows && selectedRows.length > 0) {
|
|
39
|
+
let prefixKey = props.rkey.endsWith('Id') ? String(props.rkey).replace('Id', '') : props.rkey
|
|
40
|
+
let valueks = Array.isArray(valueKeys) ? valueKeys : valueKeys.split(',')
|
|
41
|
+
valueks.forEach(key => {
|
|
42
|
+
let keySplits = key.split('=')
|
|
43
|
+
let fromDefaultKey = String(keySplits[0]).replace(/@/gi, '').toLowerCase()
|
|
44
|
+
let fromKey = keySplits[1] || String(keySplits[0]).replace(/@/gi, prefixKey)
|
|
45
|
+
let fromvalue = null
|
|
46
|
+
if (multiple) {
|
|
47
|
+
fromvalue = selectedRows.map(item => $vUtils.get(item, fromKey) || $vUtils.get(item, fromDefaultKey))
|
|
48
|
+
} else {
|
|
49
|
+
fromvalue = $vUtils.get(selectedRows[0], fromKey) || $vUtils.get(selectedRows[0], fromDefaultKey)
|
|
50
|
+
}
|
|
51
|
+
$vUtils.set(props.rdata, fromKey, fromvalue)
|
|
52
|
+
})
|
|
53
|
+
}
|
|
54
|
+
useCell.setRenderValue(selectedKeys, true)
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
return {
|
|
58
|
+
...useCell,
|
|
59
|
+
vxeTreeCallback
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
})
|
|
63
|
+
</script>
|
|
@@ -1,26 +1,28 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<span class="vxe-render--inner" :class="{ 'form-render': rform, 'td-render': !rform }">
|
|
3
|
-
<template v-if="redit || isEditAll">
|
|
4
|
-
<sh-upload v-model="renderValue" v-bind="rprops" :size="rsize" @input="vxeChangeCallBack({ value: $event })"></sh-upload>
|
|
5
|
-
</template>
|
|
6
|
-
<template v-else>
|
|
7
|
-
<sh-upload :model-value="renderText" v-bind="rprops" :disabled="true" :size="rsize"></sh-upload>
|
|
8
|
-
</template>
|
|
9
|
-
</span>
|
|
10
|
-
</template>
|
|
11
|
-
|
|
12
|
-
<script>
|
|
13
|
-
import { defineComponent, getCurrentInstance } from 'vue'
|
|
14
|
-
import cellProps from '../mixin/cell-props'
|
|
15
|
-
import cellHooks from '../mixin/cell-hooks'
|
|
16
|
-
export default defineComponent({
|
|
17
|
-
name: 'VxeRenderUpload',
|
|
18
|
-
props: cellProps,
|
|
19
|
-
setup(props, context) {
|
|
20
|
-
const { proxy } = getCurrentInstance()
|
|
21
|
-
const useCell = cellHooks(props, context, proxy)
|
|
22
|
-
|
|
23
|
-
return
|
|
24
|
-
|
|
25
|
-
}
|
|
26
|
-
|
|
1
|
+
<template>
|
|
2
|
+
<span class="vxe-render--inner" :class="{ 'form-render': rform, 'td-render': !rform }">
|
|
3
|
+
<template v-if="redit || isEditAll">
|
|
4
|
+
<sh-upload v-model="renderValue" v-bind="rprops" :size="rsize" @input="vxeChangeCallBack({ value: $event })"></sh-upload>
|
|
5
|
+
</template>
|
|
6
|
+
<template v-else>
|
|
7
|
+
<sh-upload :model-value="renderText" v-bind="rprops" :disabled="true" :size="rsize"></sh-upload>
|
|
8
|
+
</template>
|
|
9
|
+
</span>
|
|
10
|
+
</template>
|
|
11
|
+
|
|
12
|
+
<script>
|
|
13
|
+
import { defineComponent, getCurrentInstance } from 'vue'
|
|
14
|
+
import cellProps from '../mixin/cell-props'
|
|
15
|
+
import cellHooks from '../mixin/cell-hooks'
|
|
16
|
+
export default defineComponent({
|
|
17
|
+
name: 'VxeRenderUpload',
|
|
18
|
+
props: cellProps,
|
|
19
|
+
setup(props, context) {
|
|
20
|
+
const { proxy } = getCurrentInstance()
|
|
21
|
+
const useCell = cellHooks(props, context, proxy)
|
|
22
|
+
|
|
23
|
+
return {
|
|
24
|
+
...useCell
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
})
|
|
28
|
+
</script>
|
|
@@ -1,23 +1,25 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<div class="vxe-filter--wrap">
|
|
3
|
-
<span class="vxe-filter--inner">
|
|
4
|
-
<vxe-input v-model="renderValue.data" v-bind="rprops" :disabled="false" @input="vxeFilterCallback" />
|
|
5
|
-
</span>
|
|
6
|
-
</div>
|
|
7
|
-
</template>
|
|
8
|
-
|
|
9
|
-
<script>
|
|
10
|
-
import { defineComponent, getCurrentInstance } from 'vue'
|
|
11
|
-
import cellProps from '../mixin/cell-props'
|
|
12
|
-
import filterHooks from '../mixin/filter-hooks'
|
|
13
|
-
export default defineComponent({
|
|
14
|
-
name: 'VxeFilterInput',
|
|
15
|
-
props: cellProps,
|
|
16
|
-
setup(props, context) {
|
|
17
|
-
const { proxy } = getCurrentInstance()
|
|
18
|
-
const useFilter = filterHooks(props, context, proxy)
|
|
19
|
-
|
|
20
|
-
return
|
|
21
|
-
|
|
22
|
-
}
|
|
23
|
-
|
|
1
|
+
<template>
|
|
2
|
+
<div class="vxe-filter--wrap">
|
|
3
|
+
<span class="vxe-filter--inner">
|
|
4
|
+
<vxe-input v-model="renderValue.data" v-bind="rprops" :disabled="false" @input="vxeFilterCallback" />
|
|
5
|
+
</span>
|
|
6
|
+
</div>
|
|
7
|
+
</template>
|
|
8
|
+
|
|
9
|
+
<script>
|
|
10
|
+
import { defineComponent, getCurrentInstance } from 'vue'
|
|
11
|
+
import cellProps from '../mixin/cell-props'
|
|
12
|
+
import filterHooks from '../mixin/filter-hooks'
|
|
13
|
+
export default defineComponent({
|
|
14
|
+
name: 'VxeFilterInput',
|
|
15
|
+
props: cellProps,
|
|
16
|
+
setup(props, context) {
|
|
17
|
+
const { proxy } = getCurrentInstance()
|
|
18
|
+
const useFilter = filterHooks(props, context, proxy)
|
|
19
|
+
|
|
20
|
+
return {
|
|
21
|
+
...useFilter
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
})
|
|
25
|
+
</script>
|
|
@@ -1,21 +1,23 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<span>{{ getFooterData() }}</span>
|
|
3
|
-
</template>
|
|
4
|
-
|
|
5
|
-
<script>
|
|
6
|
-
import { defineComponent, getCurrentInstance } from 'vue'
|
|
7
|
-
import cellProps from '../mixin/cell-props'
|
|
8
|
-
import cellHooks from '../mixin/cell-hooks'
|
|
9
|
-
export default defineComponent({
|
|
10
|
-
name: 'VxeFooterInput',
|
|
11
|
-
props: cellProps,
|
|
12
|
-
setup(props, context) {
|
|
13
|
-
const { proxy } = getCurrentInstance()
|
|
14
|
-
const useCell = cellHooks(props, context, proxy)
|
|
15
|
-
|
|
16
|
-
return
|
|
17
|
-
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
1
|
+
<template>
|
|
2
|
+
<span>{{ getFooterData() }}</span>
|
|
3
|
+
</template>
|
|
4
|
+
|
|
5
|
+
<script>
|
|
6
|
+
import { defineComponent, getCurrentInstance } from 'vue'
|
|
7
|
+
import cellProps from '../mixin/cell-props'
|
|
8
|
+
import cellHooks from '../mixin/cell-hooks'
|
|
9
|
+
export default defineComponent({
|
|
10
|
+
name: 'VxeFooterInput',
|
|
11
|
+
props: cellProps,
|
|
12
|
+
setup(props, context) {
|
|
13
|
+
const { proxy } = getCurrentInstance()
|
|
14
|
+
const useCell = cellHooks(props, context, proxy)
|
|
15
|
+
|
|
16
|
+
return {
|
|
17
|
+
...useCell
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
})
|
|
21
|
+
</script>
|
|
22
|
+
|
|
23
|
+
<style scoped></style>
|
|
@@ -1,28 +1,30 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<div v-if="rprops.bill" class="header-bill-box">
|
|
3
|
-
<template v-for="(bil, bilindex) in billGroups" :key="bilindex">
|
|
4
|
-
<span class="cell-bill-number" :class="getBillClass(bil)">{{ getBillValue(bilindex, true) }}</span>
|
|
5
|
-
</template>
|
|
6
|
-
</div>
|
|
7
|
-
<template v-else>
|
|
8
|
-
<span class="blue">{{ getFooterData() }}</span>
|
|
9
|
-
</template>
|
|
10
|
-
</template>
|
|
11
|
-
|
|
12
|
-
<script>
|
|
13
|
-
import { defineComponent, getCurrentInstance } from 'vue'
|
|
14
|
-
import cellProps from '../mixin/cell-props'
|
|
15
|
-
import cellHooks from '../mixin/cell-hooks'
|
|
16
|
-
export default defineComponent({
|
|
17
|
-
name: 'VxeFooterMoney',
|
|
18
|
-
props: cellProps,
|
|
19
|
-
setup(props, context) {
|
|
20
|
-
const { proxy } = getCurrentInstance()
|
|
21
|
-
const useCell = cellHooks(props, context, proxy)
|
|
22
|
-
|
|
23
|
-
return
|
|
24
|
-
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
1
|
+
<template>
|
|
2
|
+
<div v-if="rprops.bill" class="header-bill-box">
|
|
3
|
+
<template v-for="(bil, bilindex) in billGroups" :key="bilindex">
|
|
4
|
+
<span class="cell-bill-number" :class="getBillClass(bil)">{{ getBillValue(bilindex, true) }}</span>
|
|
5
|
+
</template>
|
|
6
|
+
</div>
|
|
7
|
+
<template v-else>
|
|
8
|
+
<span class="blue">{{ getFooterData() }}</span>
|
|
9
|
+
</template>
|
|
10
|
+
</template>
|
|
11
|
+
|
|
12
|
+
<script>
|
|
13
|
+
import { defineComponent, getCurrentInstance } from 'vue'
|
|
14
|
+
import cellProps from '../mixin/cell-props'
|
|
15
|
+
import cellHooks from '../mixin/cell-hooks'
|
|
16
|
+
export default defineComponent({
|
|
17
|
+
name: 'VxeFooterMoney',
|
|
18
|
+
props: cellProps,
|
|
19
|
+
setup(props, context) {
|
|
20
|
+
const { proxy } = getCurrentInstance()
|
|
21
|
+
const useCell = cellHooks(props, context, proxy)
|
|
22
|
+
|
|
23
|
+
return {
|
|
24
|
+
...useCell
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
})
|
|
28
|
+
</script>
|
|
29
|
+
|
|
30
|
+
<style scoped></style>
|
|
@@ -1,29 +1,31 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<span>
|
|
3
|
-
{{ rparams.column.title }}
|
|
4
|
-
<span v-if="moneyUnitText" class="header-money-unit-text">({{ moneyUnitText }})</span>
|
|
5
|
-
</span>
|
|
6
|
-
<div v-if="rprops.bill" class="header-bill-box">
|
|
7
|
-
<template v-for="(bil, bilindex) in billGroups" :key="bilindex">
|
|
8
|
-
<span class="cell-bill-number" :class="getBillClass(bil)">{{ bil.shortText }}</span>
|
|
9
|
-
</template>
|
|
10
|
-
</div>
|
|
11
|
-
</template>
|
|
12
|
-
|
|
13
|
-
<script>
|
|
14
|
-
import { defineComponent, getCurrentInstance } from 'vue'
|
|
15
|
-
import cellProps from '../mixin/cell-props'
|
|
16
|
-
import cellHooks from '../mixin/cell-hooks'
|
|
17
|
-
export default defineComponent({
|
|
18
|
-
name: 'VxeHeaderMoney',
|
|
19
|
-
props: cellProps,
|
|
20
|
-
setup(props, context) {
|
|
21
|
-
const { proxy } = getCurrentInstance()
|
|
22
|
-
const useCell = cellHooks(props, context, proxy)
|
|
23
|
-
|
|
24
|
-
return
|
|
25
|
-
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
1
|
+
<template>
|
|
2
|
+
<span>
|
|
3
|
+
{{ rparams.column.title }}
|
|
4
|
+
<span v-if="moneyUnitText" class="header-money-unit-text">({{ moneyUnitText }})</span>
|
|
5
|
+
</span>
|
|
6
|
+
<div v-if="rprops.bill" class="header-bill-box">
|
|
7
|
+
<template v-for="(bil, bilindex) in billGroups" :key="bilindex">
|
|
8
|
+
<span class="cell-bill-number" :class="getBillClass(bil)">{{ bil.shortText }}</span>
|
|
9
|
+
</template>
|
|
10
|
+
</div>
|
|
11
|
+
</template>
|
|
12
|
+
|
|
13
|
+
<script>
|
|
14
|
+
import { defineComponent, getCurrentInstance } from 'vue'
|
|
15
|
+
import cellProps from '../mixin/cell-props'
|
|
16
|
+
import cellHooks from '../mixin/cell-hooks'
|
|
17
|
+
export default defineComponent({
|
|
18
|
+
name: 'VxeHeaderMoney',
|
|
19
|
+
props: cellProps,
|
|
20
|
+
setup(props, context) {
|
|
21
|
+
const { proxy } = getCurrentInstance()
|
|
22
|
+
const useCell = cellHooks(props, context, proxy)
|
|
23
|
+
|
|
24
|
+
return {
|
|
25
|
+
...useCell
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
})
|
|
29
|
+
</script>
|
|
30
|
+
|
|
31
|
+
<style scoped></style>
|
|
@@ -102,7 +102,10 @@ export default function (props, context, proxy) {
|
|
|
102
102
|
const setRenderValue = (value, isCall) => {
|
|
103
103
|
let cellValue = value || renderValue.value
|
|
104
104
|
if (!isCall) {
|
|
105
|
-
if (['$vMoney'].includes(props.rname) && !$vUtils.isNone(cellValue))
|
|
105
|
+
if (['$vMoney'].includes(props.rname) && !$vUtils.isNone(cellValue)) {
|
|
106
|
+
if (props.rprops.commafy) cellValue = String(cellValue).replace(',', '')
|
|
107
|
+
cellValue = $vUtils.multiply(cellValue, props.rprops.moneyUnit || 1)
|
|
108
|
+
}
|
|
106
109
|
let { rvalue, rtext } = formatValueFun(cellValue, true)
|
|
107
110
|
cellValue = rvalue
|
|
108
111
|
}
|