pagetype列表页Select字段类型自动增加badge背景

This commit is contained in:
jingrow 2025-11-01 17:18:07 +08:00
parent f8a1c82394
commit a2e4a0e074

View File

@ -149,6 +149,14 @@
<span v-if="row[f.key] === 1 || row[f.key] === true" class="boolean-true"></span>
<span v-else class="boolean-false"></span>
</template>
<template v-else-if="isSelectField(f.key) && row[f.key]">
<span
class="select-badge"
:style="{ backgroundColor: getSelectBadgeColor(f.key, row[f.key]) }"
>
{{ formatDisplayValue(row[f.key], f.key) }}
</span>
</template>
<template v-else>{{ formatDisplayValue(row[f.key], f.key) }}</template>
</span>
</div>
@ -235,6 +243,14 @@
<span v-if="row[col.key] === 1 || row[col.key] === true" class="boolean-true"></span>
<span v-else class="boolean-false"></span>
</template>
<template v-else-if="isSelectField(col.key) && row[col.key]">
<span
class="select-badge"
:style="{ backgroundColor: getSelectBadgeColor(col.key, row[col.key]) }"
>
{{ formatDisplayValue(row[col.key], col.key) }}
</span>
</template>
<template v-else>{{ formatDisplayValue(row[col.key], col.key) }}</template>
</div>
<div class="col-actions">
@ -988,6 +1004,68 @@ function isBooleanField(fieldName: string) {
return false
}
// Select
function isSelectField(fieldName: string) {
const fieldMeta = metaFields.value.find(f => f.fieldname === fieldName)
return fieldMeta?.fieldtype === 'Select'
}
// Select
// { fieldName: { value: color } } { 'global': { value: color } } Select
// 'blue', 'green', 'red' '#3b82f6'
const selectFieldColors = ref<Record<string, Record<string, string>>>({
// Select
'global': {
//
}
})
// Select
function getSelectBadgeColor(fieldName: string, value: any): string {
if (!value || value === '') return ''
const valueStr = String(value)
// 1.
if (selectFieldColors.value[fieldName] && selectFieldColors.value[fieldName][valueStr]) {
return selectFieldColors.value[fieldName][valueStr]
}
// 2.
if (selectFieldColors.value['global'] && selectFieldColors.value['global'][valueStr]) {
return selectFieldColors.value['global'][valueStr]
}
// 3. 使
return getDefaultColorForValue(valueStr)
}
// 使
function getDefaultColorForValue(value: string): string {
//
const colors = [
'#3b82f6', // blue
'#10b981', // green
'#f59e0b', // amber
'#ef4444', // red
'#8b5cf6', // violet
'#ec4899', // pink
'#06b6d4', // cyan
'#84cc16', // lime
'#f97316', // orange
'#6366f1', // indigo
]
//
let hash = 0
for (let i = 0; i < value.length; i++) {
hash = ((hash << 5) - hash) + value.charCodeAt(i)
hash = hash & hash // 32
}
return colors[Math.abs(hash) % colors.length]
}
function formatDisplayValue(value: any, fieldName: string) {
let result: any = value
@ -1198,6 +1276,23 @@ function formatDisplayValue(value: any, fieldName: string) {
min-width: 0;
}
/* Select字段Badge样式 */
.select-badge {
display: inline-block;
padding: 4px 10px;
border-radius: 12px;
font-size: 12px;
font-weight: 500;
color: white;
white-space: nowrap;
line-height: 1.4;
transition: opacity 0.2s ease;
}
.select-badge:hover {
opacity: 0.9;
}
.card-actions {
display: flex;
align-items: center;