129 lines
3.9 KiB
Vue
129 lines
3.9 KiB
Vue
<template>
|
|
<div class="demo detection-roll-list" style="height: 90%">
|
|
<div class="list-item-header item-warp" :style="{ flex: listKeys.length }">
|
|
<template v-for="(h, indexh) in listKeys" :key="indexh">
|
|
<div class="item-td" :style="{ width: 'calc(100% / ' + listKeys.length + ')' }">{{ listKeysHeader[h] }}</div>
|
|
</template>
|
|
</div>
|
|
<vue3ScrollSeamless class="scroll-wrap" :class-options="classOptions" :data-list="list">
|
|
<div v-for="(item, index) in list" :key="index" class="list-item">
|
|
<div class="list-item-content">
|
|
<div class="list-item-boday item-warp" :style="{ flex: listKeys.length }">
|
|
<template v-for="(b, indexb) in listKeys" :key="indexb">
|
|
<div class="item-td" :class="{ 'zebra-b': (index + 1) % 2 == 0 }" :style="{ width: 'calc(100% / ' + listKeys.length + ')' }">
|
|
<span v-if="b != 'status'">
|
|
{{ item[b] }}
|
|
</span>
|
|
<span v-else :class="item[b] == 0 ? 'status-no' : 'status-y'">
|
|
{{ item[b] == 0 ? '不合格' : '合格' }}
|
|
</span>
|
|
</div>
|
|
</template>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</vue3ScrollSeamless>
|
|
</div>
|
|
<!-- </div> -->
|
|
</template>
|
|
|
|
<script setup>
|
|
import { ref, onMounted, onUnmounted, computed, reactive } from 'vue';
|
|
import { vue3ScrollSeamless } from 'vue3-scroll-seamless';
|
|
const props = defineProps({
|
|
// items: {
|
|
// type: Array,
|
|
// default: () => [],
|
|
// },
|
|
});
|
|
|
|
let list = reactive([
|
|
{ title: '红星农业合作社', agency: '耿马农残检测中心', time: '2025.01.02', status: 1, info: '经销商资质不合格' },
|
|
{ title: '成大食品加工厂', agency: '耿马农残检测中心', time: '2025.01.01', status: 1, info: '农药成分不合格' },
|
|
{ title: '大大食品加工厂', agency: '耿马食品检测中心', time: '2025.01.02', status: 0, info: '经销商资质不合格' },
|
|
{ title: '佳成农业合作社', agency: '耿马农残检测中心', time: '2025.01.01', status: 1, info: '成分不合格' },
|
|
{ title: '嘉庆食品加工厂', agency: '耿马食品检测中心', time: '2025.01.02', status: 1, info: '经销商资质不合格' },
|
|
{ title: '汇星农业合作社', agency: '耿马农残检测中心', time: '2025.01.01', status: 1, info: '经销商资质不完全' },
|
|
{ title: '瑞达农业合作社', agency: '耿马农残检测中心', time: '2025.01.02', status: 1, info: '种源质量不好' },
|
|
]);
|
|
|
|
const listKeys = reactive(['title', 'agency', 'status']);
|
|
const listKeysHeader = reactive({
|
|
title: '送检单位',
|
|
agency: '检测单位',
|
|
status: '检测结果',
|
|
});
|
|
|
|
const classOptions = {
|
|
singleHeight: 48,
|
|
};
|
|
</script>
|
|
|
|
<style scoped lang="scss">
|
|
.detection-roll-list {
|
|
margin-top: 8px;
|
|
.scroll-wrap {
|
|
height: 80%;
|
|
width: 100%;
|
|
margin: 4px auto;
|
|
overflow: hidden;
|
|
}
|
|
.list-item-header {
|
|
background: #144482;
|
|
font-size: 10px;
|
|
width: 100%;
|
|
.item-td {
|
|
padding: 8px 6px;
|
|
}
|
|
}
|
|
.list-item-boday {
|
|
background: transparent;
|
|
width: 100%;
|
|
.item-td {
|
|
padding: 6px 6px;
|
|
&.td-title {
|
|
color: #6beff9 !important;
|
|
}
|
|
&.zebra-b {
|
|
background: #051225 !important;
|
|
}
|
|
}
|
|
}
|
|
.item-warp {
|
|
display: inline-flex;
|
|
justify-content: space-around;
|
|
.item-td {
|
|
display: inline-block;
|
|
vertical-align: middle;
|
|
|
|
text-align: center;
|
|
color: #fff;
|
|
|
|
.status-no {
|
|
color: red;
|
|
}
|
|
.status-y {
|
|
color: #6beff9;
|
|
}
|
|
}
|
|
}
|
|
.list-item {
|
|
// border-bottom: 1px dashed rgba(255, 255, 255, 0.2);
|
|
line-height: 18px;
|
|
|
|
.list-item-content {
|
|
display: inline-flex;
|
|
width: 100%;
|
|
justify-content: space-around;
|
|
position: relative;
|
|
}
|
|
}
|
|
}
|
|
.demo {
|
|
// display: flex;
|
|
// align-items: center;
|
|
// justify-content: center;
|
|
// margin-top: 10px;
|
|
}
|
|
</style>
|