93 lines
2.2 KiB
Vue
Raw Normal View History

2022-01-14 22:07:02 +08:00
<template>
2022-01-19 09:19:17 +08:00
<div class="go-content-charts-item-box">
<!-- 每一项组件的渲染 -->
<div
class="item-box"
v-for="(item, index) in menuOptions"
:key="index"
draggable
@dragstart="handleDragStart($event, item)"
>
<div class="list-header">
<AppleControlBtn :mini="true" :disabled="true"></AppleControlBtn>
<n-text class="list-header-text" depth="3">{{ item.title }}</n-text>
</div>
<div class="list-center go-flex-center">
<n-image
class="list-img"
object-fit="contain"
preview-disabled
:src="item.image"
:fallback-src="requireFallbackImg()"
/>
</div>
2022-01-14 22:07:02 +08:00
</div>
</div>
</template>
<script setup lang="ts">
import { AppleControlBtn } from '@/components/AppleControlBtn/index'
2022-01-15 12:50:00 +08:00
import { requireFallbackImg } from '@/utils'
2022-01-14 22:07:02 +08:00
defineProps({
menuOptions: {
type: Array,
default: () => []
}
})
2022-01-19 09:19:17 +08:00
// 拖拽处理
const handleDragStart = (e: DragEvent, item: any) => {
if (e.dataTransfer instanceof Object && e.target instanceof Object) {
e.dataTransfer.setData('chartName', item.key)
e.dataTransfer.setData('chartNode', item.node)
}
}
2022-01-14 22:07:02 +08:00
</script>
<style lang="scss" scoped>
/* 列表项宽度 */
$itemWidth: 86%;
/* 内容高度 */
2022-01-15 22:35:32 +08:00
$centerHeight: 100px;
2022-01-19 09:19:17 +08:00
@include go('content-charts-item-box') {
.item-box {
margin: 0 7%;
margin-bottom: 15px;
width: $itemWidth;
overflow: hidden;
border-radius: 6px;
cursor: pointer;
border: 1px solid rgba(0, 0, 0, 0);
@include filter-bg-color('background-color2');
@extend .go-transition;
&:hover {
@include hover-border-color('background-color4');
.list-img {
transform: scale(1.1);
}
2022-01-15 21:05:11 +08:00
}
2022-01-19 09:19:17 +08:00
.list-header {
display: flex;
align-items: center;
justify-content: space-between;
padding: 2px 15px;
@include filter-bg-color('background-color3');
&-text {
font-size: 12px;
margin-left: 8px;
}
2022-01-14 22:07:02 +08:00
}
2022-01-19 09:19:17 +08:00
.list-center {
padding: 6px 0;
height: $centerHeight;
overflow: hidden;
.list-img {
height: 100%;
border-radius: 6px;
@extend .go-transition;
}
2022-01-14 22:07:02 +08:00
}
}
}
</style>