x-php-Admin/src/components/xTable/columnItem.vue

124 lines
4.4 KiB
Vue
Raw Normal View History

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-09-04 09:30:49 +00:00
<el-badge v-else-if="item.columntype=='badge' || item.columntype=='imagegroup'" :value="getType(row[item.name])" @click="handleClick(row, item)" :type="item.options.type || 'warning'"></el-badge>
2023-07-21 11:22:50 +00:00
<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)"
2023-09-04 09:30:49 +00:00
v-if="value === row[item.name]"></x-status-indicator>
2023-08-21 11:00:12 +00:00
</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-09-05 07:23:52 +00:00
<template v-for="op in item.options.items">
2023-08-21 11:00:12 +00:00
<el-button
2023-09-05 07:23:52 +00:00
@click="handleClick(row, op.options || item)"
:key="op.value"
:type="op.type || 'warning'"
:size="op.size || 'small'"
:link="op.link"
:icon="op.icon"
:circle="op.circle || false"
2023-09-04 09:30:49 +00:00
v-if="value === row[item.name]">
2023-09-05 07:23:52 +00:00
{{ op.label }}
2023-08-21 11:00:12 +00:00
</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-09-04 09:30:49 +00:00
<el-button
@click="handleClick(row, item)"
:type="item.options.type || 'warning'"
:size="item.options.size || 'small'"
:circle="item.options.circle || false"
:icon="item.options.icon"> {{ row[item.name] }} </el-button>
2023-07-21 09:13:44 +00:00
</p>
2023-07-21 11:22:50 +00:00
2023-09-04 14:47:11 +00:00
<p v-else-if="item.columntype=='tag' || item.columntype=='time'" @click="handleClick(row, item)" v-time.tip="row[item.name]"></p>
2023-07-21 11:22:50 +00:00
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-09-05 07:23:52 +00:00
2023-08-31 08:52:44 +00:00
// 打开新窗口链接
if (item.open && item.open.name && row[item.open.name]?.trim()) {
window.open(row[item.open.name], "_blank");
return ;
}
2023-07-23 14:33:20 +00:00
// 打开编辑层
2023-08-31 08:52:44 +00:00
else 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-31 08:52:44 +00:00
else if (item.table && (item.table.url || item.table.name)) {
2023-08-21 11:00:12 +00:00
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-09-05 07:23:52 +00:00
}else if(item.http && item.http.url && item.http.key && String(row[item.http.key])?.trim()){
this.$confirm( item.http.title || '确定要执行?', '提示', { type: item.http.type || 'warning' }).then(() => {
const loading = this.$loading();
this.$http.post(item.http.url, {[item.http.key]: row[item.http.key]}).then((res) => {
loading.close();
if (res.code == 200 ) {
this.$message.success(res.message || '操作成功')
return;
}
this.$alert(res.message || '操作失败', "提示", {type: 'error'});
});
}).catch(() => {
})
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>