sh-view 2.8.0 → 2.8.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.
- package/.eslintrc.js +25 -20
- package/other.js +8 -8
- package/package.json +9 -6
- package/packages/components/index.js +91 -91
- package/packages/components/sh-alert/alert.ts +30 -0
- package/packages/components/sh-alert/index.vue +143 -168
- package/packages/components/sh-badge/index.vue +242 -242
- package/packages/components/sh-calendar/index.vue +650 -650
- package/packages/components/sh-card/index.vue +148 -148
- package/packages/components/sh-code-editor/index.vue +19 -19
- package/packages/components/sh-col/index.vue +92 -92
- package/packages/components/sh-corner/index.vue +230 -230
- package/packages/components/sh-count-to/index.vue +131 -131
- package/packages/components/sh-date/index.vue +301 -301
- package/packages/components/sh-drawer/index.vue +579 -579
- package/packages/components/sh-drawer/scrollbar.js +78 -78
- package/packages/components/sh-empty/index.vue +42 -42
- package/packages/components/sh-form/js/props.js +76 -76
- package/packages/components/sh-form/js/useForm.js +229 -229
- package/packages/components/sh-header/index.vue +261 -260
- package/packages/components/sh-icon/css/default/ionicons.svg +869 -869
- package/packages/components/sh-icon/css/font/iconfont.json +247 -247
- package/packages/components/sh-icon/index.vue +41 -41
- package/packages/components/sh-image/index.vue +133 -133
- package/packages/components/sh-list/index.vue +146 -146
- package/packages/components/sh-loading/index.vue +53 -53
- package/packages/components/sh-modal/index.vue +188 -188
- package/packages/components/sh-noticebar/index.vue +215 -215
- package/packages/components/sh-poptip/index.vue +597 -597
- package/packages/components/sh-progress/index.vue +276 -276
- package/packages/components/sh-pull-refresh/index.vue +289 -289
- package/packages/components/sh-result/index.vue +114 -114
- package/packages/components/sh-row/index.vue +66 -66
- package/packages/components/sh-split/components/trigger.vue +33 -33
- package/packages/components/sh-split/index.vue +342 -342
- package/packages/components/sh-table/components/importModal.vue +363 -363
- package/packages/components/sh-table/components/sh-column.vue +68 -68
- package/packages/components/sh-table/js/excel_to_json.js +313 -313
- package/packages/components/sh-table/js/props.js +305 -305
- package/packages/components/sh-table/js/tableMethods.js +167 -167
- package/packages/components/sh-table/js/useTable.js +636 -636
- package/packages/components/sh-table/table.vue +217 -217
- package/packages/components/sh-tabs/index.vue +426 -426
- package/packages/components/sh-tag/index.vue +168 -168
- package/packages/components/sh-toolbar/index.vue +182 -182
- package/packages/components/sh-tree/components/table-tree.vue +289 -289
- package/packages/components/sh-tree/mixin/treeProps.js +122 -122
- package/packages/components/sh-upload/index.vue +535 -535
- package/packages/components/sh-water-fall/index.vue +80 -80
- package/packages/components/sh-water-mark/index.vue +96 -96
- package/packages/css/index.js +4 -4
- package/packages/directive/index.js +19 -19
- package/packages/directive/module/click-out.js +14 -14
- package/packages/directive/module/draggable.js +42 -42
- package/packages/directive/module/line-clamp.js +22 -22
- package/packages/directive/module/prevent-click.js +18 -18
- package/packages/directive/module/resize.js +14 -14
- package/packages/directive/module/ripple.js +166 -166
- package/packages/index.js +39 -39
- package/packages/mixin/index.js +86 -86
- package/packages/other/sh-cron-modal/components/cron-content.vue +294 -294
- package/packages/other/sh-cron-modal/index.vue +81 -81
- package/packages/other/sh-cron-modal/mixin/cron-emits.js +1 -1
- package/packages/other/sh-cron-modal/mixin/cron-props.js +9 -9
- package/packages/other/sh-cron-modal/tabs/cron-week-box.vue +126 -126
- package/packages/other/sh-menu/index.vue +326 -326
- package/packages/other/sh-menu/menu-group-content.vue +136 -136
- package/packages/other/sh-menu/menu-item-content.vue +71 -71
- package/packages/other/sh-menu-card/index.vue +250 -250
- package/packages/other/sh-menu-card/menu-box.vue +87 -87
- package/packages/other/sh-preview/components/sh-excel.vue +163 -163
- package/packages/other/sh-preview/js/data-hook.js +41 -41
- package/packages/other/sh-preview/js/data-props.js +15 -15
- package/packages/other/sh-system-tip/index.vue +115 -115
- package/packages/utils/resize.js +69 -70
- package/packages/utils/transfer-queue.js +12 -12
- package/packages/vxeTable/index.js +193 -184
- package/packages/vxeTable/plugins/export.js +450 -450
- package/packages/vxeTable/render/cell/vxe-render-img.vue +27 -27
- package/packages/vxeTable/render/cell/vxe-render-table.vue +51 -51
- package/packages/vxeTable/render/cell/vxe-render-time.vue +44 -44
- package/packages/vxeTable/render/cell/vxe-render-tree.vue +70 -70
- package/packages/vxeTable/render/filters/vxe-filter-input.vue +26 -26
- package/packages/vxeTable/render/filters/vxe-filter-time.vue +26 -26
- package/packages/vxeTable/render/globalRenders.jsx +514 -514
- package/packages/vxeTable/render/mixin/cell-hooks.js +198 -198
- package/packages/vxeTable/render/mixin/cell-props.js +23 -23
- package/packages/vxeTable/render/mixin/filter-hooks.js +46 -46
- package/tsconfig.json +25 -0
- package/types/component.d.ts +1 -0
- package/types/index.ts +0 -0
|
@@ -1,27 +1,27 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<span class="vxe-render--inner">
|
|
3
|
-
<sh-image class="vxe-render--inner-img" :src="imgSrc" v-bind="rprops" :height="imgHeight"></sh-image>
|
|
4
|
-
</span>
|
|
5
|
-
</template>
|
|
6
|
-
|
|
7
|
-
<script>
|
|
8
|
-
import { computed, defineComponent, getCurrentInstance } from 'vue'
|
|
9
|
-
import cellProps from '../mixin/cell-props'
|
|
10
|
-
export default defineComponent({
|
|
11
|
-
name: 'VxeRenderImg',
|
|
12
|
-
props: cellProps,
|
|
13
|
-
setup(props, context) {
|
|
14
|
-
const { proxy } = getCurrentInstance()
|
|
15
|
-
const { $vUtils } = proxy
|
|
16
|
-
const imgSrc = computed(() => $vUtils.get(props.rdata, props.rkey))
|
|
17
|
-
const imgHeight = computed(() => {
|
|
18
|
-
return props.rprops.square ? props.rprops.width : props.rprops.height
|
|
19
|
-
})
|
|
20
|
-
|
|
21
|
-
return {
|
|
22
|
-
imgSrc,
|
|
23
|
-
imgHeight
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
})
|
|
27
|
-
</script>
|
|
1
|
+
<template>
|
|
2
|
+
<span class="vxe-render--inner">
|
|
3
|
+
<sh-image class="vxe-render--inner-img" :src="imgSrc" v-bind="rprops" :height="imgHeight"></sh-image>
|
|
4
|
+
</span>
|
|
5
|
+
</template>
|
|
6
|
+
|
|
7
|
+
<script>
|
|
8
|
+
import { computed, defineComponent, getCurrentInstance } from 'vue'
|
|
9
|
+
import cellProps from '../mixin/cell-props'
|
|
10
|
+
export default defineComponent({
|
|
11
|
+
name: 'VxeRenderImg',
|
|
12
|
+
props: cellProps,
|
|
13
|
+
setup(props, context) {
|
|
14
|
+
const { proxy } = getCurrentInstance()
|
|
15
|
+
const { $vUtils } = proxy
|
|
16
|
+
const imgSrc = computed(() => $vUtils.get(props.rdata, props.rkey))
|
|
17
|
+
const imgHeight = computed(() => {
|
|
18
|
+
return props.rprops.square ? props.rprops.width : props.rprops.height
|
|
19
|
+
})
|
|
20
|
+
|
|
21
|
+
return {
|
|
22
|
+
imgSrc,
|
|
23
|
+
imgHeight
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
})
|
|
27
|
+
</script>
|
|
@@ -1,51 +1,51 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<span class="vxe-render--inner" style="display: inline-grid; width: 100%">
|
|
3
|
-
<sh-table
|
|
4
|
-
ref="shTableRef"
|
|
5
|
-
:disabled="!redit && !isEditAll"
|
|
6
|
-
v-bind="rprops"
|
|
7
|
-
:size="rsize"
|
|
8
|
-
:data-sourse="renderValue"
|
|
9
|
-
@edit-closed="vxeInputCallback"
|
|
10
|
-
@toolbaroption="onToolbaroption"></sh-table>
|
|
11
|
-
</span>
|
|
12
|
-
</template>
|
|
13
|
-
|
|
14
|
-
<script>
|
|
15
|
-
import { defineComponent, getCurrentInstance, ref } from 'vue'
|
|
16
|
-
import cellProps from '../mixin/cell-props'
|
|
17
|
-
import cellHooks from '../mixin/cell-hooks'
|
|
18
|
-
export default defineComponent({
|
|
19
|
-
name: 'VxeRenderTable',
|
|
20
|
-
props: cellProps,
|
|
21
|
-
setup(props, context) {
|
|
22
|
-
const { proxy } = getCurrentInstance()
|
|
23
|
-
const useCell = cellHooks(props, context, proxy)
|
|
24
|
-
const shTableRef = ref()
|
|
25
|
-
|
|
26
|
-
const fullData = () => {
|
|
27
|
-
return shTableRef.value.getFullData({ deleteXid: true })
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
// 输入框回调
|
|
31
|
-
const vxeInputCallback = ({ $table, row }) => {
|
|
32
|
-
driveBackData()
|
|
33
|
-
}
|
|
34
|
-
// 新增、删除行回调
|
|
35
|
-
const onToolbaroption = (code, data, $table) => {
|
|
36
|
-
driveBackData()
|
|
37
|
-
}
|
|
38
|
-
// 回填数据
|
|
39
|
-
const driveBackData = value => {
|
|
40
|
-
useCell.setRenderValue(fullData(), true)
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
return {
|
|
44
|
-
...useCell,
|
|
45
|
-
shTableRef,
|
|
46
|
-
vxeInputCallback,
|
|
47
|
-
onToolbaroption
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
})
|
|
51
|
-
</script>
|
|
1
|
+
<template>
|
|
2
|
+
<span class="vxe-render--inner" style="display: inline-grid; width: 100%">
|
|
3
|
+
<sh-table
|
|
4
|
+
ref="shTableRef"
|
|
5
|
+
:disabled="!redit && !isEditAll"
|
|
6
|
+
v-bind="rprops"
|
|
7
|
+
:size="rsize"
|
|
8
|
+
:data-sourse="renderValue"
|
|
9
|
+
@edit-closed="vxeInputCallback"
|
|
10
|
+
@toolbaroption="onToolbaroption"></sh-table>
|
|
11
|
+
</span>
|
|
12
|
+
</template>
|
|
13
|
+
|
|
14
|
+
<script>
|
|
15
|
+
import { defineComponent, getCurrentInstance, ref } from 'vue'
|
|
16
|
+
import cellProps from '../mixin/cell-props'
|
|
17
|
+
import cellHooks from '../mixin/cell-hooks'
|
|
18
|
+
export default defineComponent({
|
|
19
|
+
name: 'VxeRenderTable',
|
|
20
|
+
props: cellProps,
|
|
21
|
+
setup(props, context) {
|
|
22
|
+
const { proxy } = getCurrentInstance()
|
|
23
|
+
const useCell = cellHooks(props, context, proxy)
|
|
24
|
+
const shTableRef = ref()
|
|
25
|
+
|
|
26
|
+
const fullData = () => {
|
|
27
|
+
return shTableRef.value.getFullData({ deleteXid: true })
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
// 输入框回调
|
|
31
|
+
const vxeInputCallback = ({ $table, row }) => {
|
|
32
|
+
driveBackData()
|
|
33
|
+
}
|
|
34
|
+
// 新增、删除行回调
|
|
35
|
+
const onToolbaroption = (code, data, $table) => {
|
|
36
|
+
driveBackData()
|
|
37
|
+
}
|
|
38
|
+
// 回填数据
|
|
39
|
+
const driveBackData = value => {
|
|
40
|
+
useCell.setRenderValue(fullData(), true)
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
return {
|
|
44
|
+
...useCell,
|
|
45
|
+
shTableRef,
|
|
46
|
+
vxeInputCallback,
|
|
47
|
+
onToolbaroption
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
})
|
|
51
|
+
</script>
|
|
@@ -1,44 +1,44 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<span class="vxe-render--inner" :class="{ 'form-render': rform, 'td-render': !rform }">
|
|
3
|
-
<template v-if="redit || isEditAll">
|
|
4
|
-
<sh-date v-model="renderValue" v-bind="rprops" :size="rsize" :disabled-method="vxeDisabledMethod" @change="vxeChangeCallBack"></sh-date>
|
|
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
|
+
<template>
|
|
2
|
+
<span class="vxe-render--inner" :class="{ 'form-render': rform, 'td-render': !rform }">
|
|
3
|
+
<template v-if="redit || isEditAll">
|
|
4
|
+
<sh-date v-model="renderValue" v-bind="rprops" :size="rsize" :disabled-method="vxeDisabledMethod" @change="vxeChangeCallBack"></sh-date>
|
|
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,70 +1,70 @@
|
|
|
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
|
-
let rvalue = selectedKeys
|
|
36
|
-
if (!multiple) {
|
|
37
|
-
rvalue = selectedKeys[0] || ''
|
|
38
|
-
}
|
|
39
|
-
if (valueKeys && selectedRows && selectedRows.length > 0) {
|
|
40
|
-
let prefixKey = props.rkey
|
|
41
|
-
let endStrs = ['Id', '_id']
|
|
42
|
-
endStrs.forEach(end => {
|
|
43
|
-
if (props.rkey.endsWith(end)) {
|
|
44
|
-
prefixKey = props.rkey.replace(end, '')
|
|
45
|
-
}
|
|
46
|
-
})
|
|
47
|
-
let valueks = Array.isArray(valueKeys) ? valueKeys : valueKeys.split(',')
|
|
48
|
-
valueks.forEach(key => {
|
|
49
|
-
let keySplits = key.split('=')
|
|
50
|
-
let fromDefaultKey = String(keySplits[0]).replace(/@/gi, '').toLowerCase()
|
|
51
|
-
let fromKey = keySplits[1] || String(keySplits[0]).replace(/@/gi, prefixKey)
|
|
52
|
-
let fromvalue = null
|
|
53
|
-
if (multiple) {
|
|
54
|
-
fromvalue = selectedRows.map(item => $vUtils.get(item, fromKey) || $vUtils.get(item, fromDefaultKey))
|
|
55
|
-
} else {
|
|
56
|
-
fromvalue = $vUtils.get(selectedRows[0], fromKey) || $vUtils.get(selectedRows[0], fromDefaultKey)
|
|
57
|
-
}
|
|
58
|
-
$vUtils.set(props.rdata, fromKey, fromvalue)
|
|
59
|
-
})
|
|
60
|
-
}
|
|
61
|
-
useCell.setRenderValue(rvalue, true)
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
return {
|
|
65
|
-
...useCell,
|
|
66
|
-
vxeTreeCallback
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
})
|
|
70
|
-
</script>
|
|
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
|
+
let rvalue = selectedKeys
|
|
36
|
+
if (!multiple) {
|
|
37
|
+
rvalue = selectedKeys[0] || ''
|
|
38
|
+
}
|
|
39
|
+
if (valueKeys && selectedRows && selectedRows.length > 0) {
|
|
40
|
+
let prefixKey = props.rkey
|
|
41
|
+
let endStrs = ['Id', '_id']
|
|
42
|
+
endStrs.forEach(end => {
|
|
43
|
+
if (props.rkey.endsWith(end)) {
|
|
44
|
+
prefixKey = props.rkey.replace(end, '')
|
|
45
|
+
}
|
|
46
|
+
})
|
|
47
|
+
let valueks = Array.isArray(valueKeys) ? valueKeys : valueKeys.split(',')
|
|
48
|
+
valueks.forEach(key => {
|
|
49
|
+
let keySplits = key.split('=')
|
|
50
|
+
let fromDefaultKey = String(keySplits[0]).replace(/@/gi, '').toLowerCase()
|
|
51
|
+
let fromKey = keySplits[1] || String(keySplits[0]).replace(/@/gi, prefixKey)
|
|
52
|
+
let fromvalue = null
|
|
53
|
+
if (multiple) {
|
|
54
|
+
fromvalue = selectedRows.map(item => $vUtils.get(item, fromKey) || $vUtils.get(item, fromDefaultKey))
|
|
55
|
+
} else {
|
|
56
|
+
fromvalue = $vUtils.get(selectedRows[0], fromKey) || $vUtils.get(selectedRows[0], fromDefaultKey)
|
|
57
|
+
}
|
|
58
|
+
$vUtils.set(props.rdata, fromKey, fromvalue)
|
|
59
|
+
})
|
|
60
|
+
}
|
|
61
|
+
useCell.setRenderValue(rvalue, true)
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
return {
|
|
65
|
+
...useCell,
|
|
66
|
+
vxeTreeCallback
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
})
|
|
70
|
+
</script>
|
|
@@ -1,26 +1,26 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<div class="vxe-filter--wrap">
|
|
3
|
-
<span class="vxe-filter--inner">
|
|
4
|
-
<vxe-input v-model="renderOption.data" v-bind="rprops" :disabled="false" @input="vxeFilterChange" />
|
|
5
|
-
</span>
|
|
6
|
-
</div>
|
|
7
|
-
</template>
|
|
8
|
-
|
|
9
|
-
<script>
|
|
10
|
-
import { defineComponent, getCurrentInstance, ref, watch } 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
|
-
|
|
19
|
-
const useFilter = filterHooks(props, context, proxy)
|
|
20
|
-
|
|
21
|
-
return {
|
|
22
|
-
...useFilter
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
})
|
|
26
|
-
</script>
|
|
1
|
+
<template>
|
|
2
|
+
<div class="vxe-filter--wrap">
|
|
3
|
+
<span class="vxe-filter--inner">
|
|
4
|
+
<vxe-input v-model="renderOption.data" v-bind="rprops" :disabled="false" @input="vxeFilterChange" />
|
|
5
|
+
</span>
|
|
6
|
+
</div>
|
|
7
|
+
</template>
|
|
8
|
+
|
|
9
|
+
<script>
|
|
10
|
+
import { defineComponent, getCurrentInstance, ref, watch } 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
|
+
|
|
19
|
+
const useFilter = filterHooks(props, context, proxy)
|
|
20
|
+
|
|
21
|
+
return {
|
|
22
|
+
...useFilter
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
})
|
|
26
|
+
</script>
|
|
@@ -1,26 +1,26 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<div class="vxe-filter--wrap">
|
|
3
|
-
<span class="vxe-filter--inner">
|
|
4
|
-
<sh-date v-model="renderOption.data" v-bind="rprops" :disabled="false" @change="vxeFilterChange" />
|
|
5
|
-
</span>
|
|
6
|
-
</div>
|
|
7
|
-
</template>
|
|
8
|
-
|
|
9
|
-
<script>
|
|
10
|
-
import { defineComponent, getCurrentInstance, reactive, ref } from 'vue'
|
|
11
|
-
import cellProps from '../mixin/cell-props'
|
|
12
|
-
import filterHooks from '../mixin/filter-hooks'
|
|
13
|
-
export default defineComponent({
|
|
14
|
-
name: 'VxeFilterTime',
|
|
15
|
-
props: cellProps,
|
|
16
|
-
setup(props, context) {
|
|
17
|
-
const { proxy } = getCurrentInstance()
|
|
18
|
-
|
|
19
|
-
const useFilter = filterHooks(props, context, proxy)
|
|
20
|
-
|
|
21
|
-
return {
|
|
22
|
-
...useFilter
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
})
|
|
26
|
-
</script>
|
|
1
|
+
<template>
|
|
2
|
+
<div class="vxe-filter--wrap">
|
|
3
|
+
<span class="vxe-filter--inner">
|
|
4
|
+
<sh-date v-model="renderOption.data" v-bind="rprops" :disabled="false" @change="vxeFilterChange" />
|
|
5
|
+
</span>
|
|
6
|
+
</div>
|
|
7
|
+
</template>
|
|
8
|
+
|
|
9
|
+
<script>
|
|
10
|
+
import { defineComponent, getCurrentInstance, reactive, ref } from 'vue'
|
|
11
|
+
import cellProps from '../mixin/cell-props'
|
|
12
|
+
import filterHooks from '../mixin/filter-hooks'
|
|
13
|
+
export default defineComponent({
|
|
14
|
+
name: 'VxeFilterTime',
|
|
15
|
+
props: cellProps,
|
|
16
|
+
setup(props, context) {
|
|
17
|
+
const { proxy } = getCurrentInstance()
|
|
18
|
+
|
|
19
|
+
const useFilter = filterHooks(props, context, proxy)
|
|
20
|
+
|
|
21
|
+
return {
|
|
22
|
+
...useFilter
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
})
|
|
26
|
+
</script>
|