2023-07-13 00:44:51 +00:00
|
|
|
<template>
|
2023-07-21 11:22:50 +00:00
|
|
|
<div>
|
2023-08-08 13:15:15 +00:00
|
|
|
<x-avatar v-if="item.columntype=='avatar' || item.component=='avatar'" :name="item.name" :options="item.options" :data="row"></x-avatar>
|
2023-07-21 11:22:50 +00:00
|
|
|
<el-badge v-else-if="item.columntype=='badge' || item.columntype=='imagegroup'" :value="getType(row[item.name])" :type="item.options.type || 'warning'"></el-badge>
|
|
|
|
<el-image v-else-if="item.columntype=='image'" :preview-src-list="[getImg(row[item.name])]" :preview-teleported="true" hide-on-click-modal="true" lazy="true" style="max-width: 60px; height: 26px; border-radius: 2px;" fit="cover" :src="getImg(row[item.name])">
|
2023-07-17 10:22:43 +00:00
|
|
|
<template #error>
|
|
|
|
<div class="image-slot">
|
|
|
|
无图
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
</el-image>
|
2023-07-21 11:22:50 +00:00
|
|
|
|
|
|
|
<input v-else-if="item.columntype=='input'" @click="handleClick(row, item)" style="cursor: pointer; " class="el-input__inner" type="text" readonly :value="row[item.name]">
|
|
|
|
|
2023-07-17 10:22:43 +00:00
|
|
|
<p v-else-if="item.columntype=='status'">
|
2023-08-21 11:00:12 +00:00
|
|
|
|
|
|
|
<template v-for="{ value, type = 'success', label } in item.options.items">
|
|
|
|
<x-status-indicator
|
|
|
|
:key="value"
|
|
|
|
pulse
|
|
|
|
:type="type"
|
|
|
|
:label="label"
|
|
|
|
@click="handleClick(row, item)"
|
|
|
|
v-if="value === row[item.name]"
|
|
|
|
></x-status-indicator>
|
|
|
|
</template>
|
2023-07-13 00:44:51 +00:00
|
|
|
</p>
|
2023-07-21 11:22:50 +00:00
|
|
|
|
2023-07-21 09:13:44 +00:00
|
|
|
<p v-else-if="item.columntype=='button' && item.options.items && item.options.items.length>0">
|
2023-08-21 11:00:12 +00:00
|
|
|
<template v-for="{ value, type = 'warning', size = 'small', label, icon, link } in item.options.items">
|
|
|
|
<el-button
|
|
|
|
@click="handleClick(row, item)"
|
|
|
|
:key="value"
|
|
|
|
:type="type"
|
|
|
|
style="margin: 0;"
|
|
|
|
:size="size"
|
|
|
|
:link="link"
|
|
|
|
:icon="icon"
|
|
|
|
v-if="value === row[item.name]"
|
|
|
|
>
|
|
|
|
{{ label }}
|
|
|
|
</el-button>
|
|
|
|
</template>
|
2023-07-21 09:13:44 +00:00
|
|
|
</p>
|
2023-07-21 11:22:50 +00:00
|
|
|
|
2023-07-21 09:13:44 +00:00
|
|
|
<p v-else-if="item.columntype=='button'">
|
2023-07-21 11:22:50 +00:00
|
|
|
<el-button @click="handleClick(row, item)" :type="item.options.type || 'warning'" :size="item.options.size || 'small'" :icon="item.options.icon">
|
2023-07-21 09:13:44 +00:00
|
|
|
{{ row[item.name] }}
|
|
|
|
</el-button>
|
|
|
|
</p>
|
2023-07-21 11:22:50 +00:00
|
|
|
|
|
|
|
<p v-else-if="item.columntype=='tag'" @click="handleClick(row, item)" v-time.tip="row[item.name]"></p>
|
|
|
|
|
2023-07-17 10:22:43 +00:00
|
|
|
<slot v-else :name="item.name" v-bind="scope">
|
2023-07-21 11:22:50 +00:00
|
|
|
{{ item.columntype=='select' && item.options && item.options.items ? getNameByValue( row[item.name], item.options.items ) : row[item.name] }}
|
2023-07-17 10:22:43 +00:00
|
|
|
</slot>
|
|
|
|
</div>
|
2023-07-13 00:44:51 +00:00
|
|
|
</template>
|
|
|
|
<script>
|
|
|
|
|
|
|
|
export default {
|
2023-08-08 07:40:11 +00:00
|
|
|
name: 'XTableColumnItem',
|
2023-07-13 00:44:51 +00:00
|
|
|
props: {
|
|
|
|
item: { type: Object, default: () => {} },
|
2023-08-08 07:40:11 +00:00
|
|
|
row: { type: Object, default: () => {} },
|
2023-07-13 00:44:51 +00:00
|
|
|
},
|
|
|
|
methods: {
|
2023-07-21 11:22:50 +00:00
|
|
|
handleClick(row, item){
|
2023-08-21 11:00:12 +00:00
|
|
|
|
2023-07-23 14:33:20 +00:00
|
|
|
// 打开编辑层
|
|
|
|
if (item.update && (item.update.url || item.update.name)) {
|
2023-07-21 11:22:50 +00:00
|
|
|
this.$emit('xtableupdate', row, {
|
2023-07-23 14:33:20 +00:00
|
|
|
name:item.update.name || item.name,
|
2023-08-21 11:00:12 +00:00
|
|
|
remoteurl: item.update.url || 'table/getUpdate?name='+item.update.name
|
|
|
|
}, item.update.type || 'dialog', 'update');
|
2023-07-23 14:33:20 +00:00
|
|
|
return ;
|
|
|
|
}
|
|
|
|
|
|
|
|
// 打开表格
|
2023-08-21 11:00:12 +00:00
|
|
|
if (item.table && (item.table.url || item.table.name)) {
|
|
|
|
this.$emit('xtableupdate', row, {
|
|
|
|
name:item.table.name || item.name,
|
|
|
|
remoteurl: item.table.url || 'table/get?name='+item.table.name
|
|
|
|
}, item.table.type || 'dialog', 'table');
|
2023-07-23 14:33:20 +00:00
|
|
|
return ;
|
2023-07-17 10:22:43 +00:00
|
|
|
}
|
|
|
|
},
|
2023-07-21 11:22:50 +00:00
|
|
|
getType(value) {
|
|
|
|
if (Array.isArray(value)) {
|
|
|
|
return value.length;
|
|
|
|
}
|
|
|
|
return value;
|
|
|
|
},
|
2023-07-13 00:44:51 +00:00
|
|
|
getNameByValue (value, degrees) {
|
|
|
|
const degree = degrees.find(degree => degree.value === value);
|
|
|
|
return degree ? (degree.name?degree.name:degree.label) : value;
|
|
|
|
},
|
|
|
|
getImg(o){
|
|
|
|
if (!o) {
|
|
|
|
return ;
|
|
|
|
}
|
|
|
|
return typeof o === 'string'? o : o.url;
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|