2023-07-13 00:44:51 +00:00
|
|
|
<template>
|
2023-07-17 10:22:43 +00:00
|
|
|
<div @click="handleClick(row, item.options)" style="cursor: pointer; ">
|
|
|
|
<x-avatar v-if="item.columntype=='avatar' || item.component=='avatar'" :name="item.name" :options="item.options" v-model="row"></x-avatar>
|
|
|
|
<el-badge v-else-if="item.columntype=='badge'" :value="row[item.name]" :type="item.options.type || 'warning'"></el-badge>
|
2023-07-19 15:42:11 +00:00
|
|
|
<span style="border: none; background: none;" v-else-if="item.columntype=='tag'" v-time.tip="row[item.name]"></span>
|
2023-07-17 10:22:43 +00:00
|
|
|
<el-badge v-else-if="item.columntype=='imagegroup'" :value="row[item.name].length" :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="width: 30px; height: 30px" fit="cover" :src="getImg(row[item.name])">
|
|
|
|
<template #error>
|
|
|
|
<div class="image-slot">
|
|
|
|
无图
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
</el-image>
|
|
|
|
<p v-else-if="item.columntype=='status'">
|
|
|
|
<x-status-indicator v-for="op in item.options.items" :key="op.value" pulse :type="op.type || 'success'" :label="op.label" v-show="op.value==row[item.name]">
|
|
|
|
</x-status-indicator>
|
2023-07-13 00:44:51 +00:00
|
|
|
</p>
|
2023-07-17 10:22:43 +00:00
|
|
|
<p v-else-if="item.columntype=='input'">
|
|
|
|
<input class="el-input__inner" type="text" readonly :value="row[item.name]">
|
|
|
|
</p>
|
|
|
|
<slot v-else-if="item.columntype=='select'" :name="item.name" v-bind="scope">
|
|
|
|
<p style="overflow:hidden; white-space: nowrap; text-overflow: ellipsis; -o-text-overflow:ellipsis;" :title="row[item.name]">
|
|
|
|
{{ getNameByValue( row[item.name], item.options.items) }}
|
|
|
|
</p>
|
|
|
|
</slot>
|
|
|
|
<slot v-else :name="item.name" v-bind="scope">
|
|
|
|
{{row[item.name]}}
|
|
|
|
</slot>
|
|
|
|
</div>
|
2023-07-13 00:44:51 +00:00
|
|
|
</template>
|
|
|
|
<script>
|
|
|
|
|
|
|
|
export default {
|
|
|
|
name: 'xTablecolumnitem',
|
|
|
|
props: {
|
|
|
|
item: { type: Object, default: () => {} },
|
|
|
|
modelValue: { type: Array, default: () => [] },
|
|
|
|
},
|
|
|
|
watch: {
|
|
|
|
|
|
|
|
},
|
|
|
|
computed: {
|
|
|
|
},
|
|
|
|
data() {
|
|
|
|
return {
|
2023-07-17 10:22:43 +00:00
|
|
|
row : this.modelValue,
|
2023-07-13 00:44:51 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
mounted() {
|
|
|
|
|
|
|
|
},
|
|
|
|
methods: {
|
2023-07-17 10:22:43 +00:00
|
|
|
handleClick(row, options){
|
|
|
|
if (options && options.updataname) {
|
|
|
|
this.$emit('xtableupdate', row, {name:options.updataname, remoteurl:'system/table/getUpdate?name='+options.updataname});
|
|
|
|
}
|
|
|
|
},
|
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>
|