添加cl-draggable组件

This commit is contained in:
icssoa
2025-07-27 22:27:53 +08:00
parent 0c4fc52b9a
commit 9a49963a91
10 changed files with 885 additions and 2 deletions

View File

@@ -0,0 +1,178 @@
<template>
<cl-page>
<view class="p-3 overflow-visible">
<demo-item label="纵向排列">
<cl-draggable v-model="list">
<template #item="{ item, index }">
<view
class="flex flex-row items-center p-3 bg-surface-100 rounded-lg mb-2"
:class="{
'!bg-surface-300': (item as UTSJSONObject).disabled
}"
>
<cl-text>{{ (item as UTSJSONObject).label }}</cl-text>
</view>
</template>
</cl-draggable>
</demo-item>
<demo-item label="结合列表使用">
<cl-list border>
<cl-draggable v-model="list2">
<template #item="{ item, index, dragging, dragIndex }">
<cl-list-item
icon="chat-thread-line"
:label="(item as UTSJSONObject).label"
arrow
:pt="{
inner: {
className:
dragging && dragIndex == index ? '!bg-surface-100' : ''
}
}"
></cl-list-item>
</template>
</cl-draggable>
</cl-list>
</demo-item>
<demo-item label="横向排列">
<cl-draggable v-model="list3" :columns="4">
<template #item="{ item, index }">
<view
class="flex flex-row items-center justify-center p-3 bg-surface-100 rounded-lg m-1"
:class="{
'!bg-surface-300': (item as UTSJSONObject).disabled
}"
>
<cl-text>{{ (item as UTSJSONObject).label }}</cl-text>
</view>
</template>
</cl-draggable>
</demo-item>
<demo-item label="结合图片使用">
<cl-draggable v-model="list4" :columns="4">
<template #item="{ item, index }">
<view class="p-[2px]">
<cl-image
:src="(item as UTSJSONObject).url"
mode="widthFix"
:pt="{
className: '!w-full'
}"
preview
></cl-image>
</view>
</template>
</cl-draggable>
</demo-item>
</view>
</cl-page>
</template>
<script lang="ts" setup>
import DemoItem from "../components/item.uvue";
import { ref } from "vue";
const list = ref<UTSJSONObject[]>([
{
label: "明月几时有,把酒问青天"
},
{
label: "不知天上宫阙,今夕是何年",
disabled: true
},
{
label: "我欲乘风归去,又恐琼楼玉宇"
},
{
label: "高处不胜寒,起舞弄清影"
},
{
label: "何似在人间"
}
]);
const list2 = ref<UTSJSONObject[]>([
{
label: "明月几时有,把酒问青天"
},
{
label: "不知天上宫阙,今夕是何年"
},
{
label: "我欲乘风归去,又恐琼楼玉宇"
},
{
label: "高处不胜寒,起舞弄清影"
},
{
label: "何似在人间"
}
]);
const list3 = ref<UTSJSONObject[]>([
{
label: "项目1"
},
{
label: "项目2"
},
{
label: "项目3"
},
{
label: "项目4"
},
{
label: "项目5"
},
{
label: "项目6"
},
{
label: "项目7"
},
{
label: "项目8",
disabled: true
},
{
label: "项目9"
},
{
label: "项目10"
},
{
label: "项目11"
},
{
label: "项目12"
}
]);
const list4 = ref<UTSJSONObject[]>([
{
url: "https://unix.cool-js.com/images/demo/1.jpg"
},
{
url: "https://unix.cool-js.com/images/demo/2.jpg"
},
{
url: "https://unix.cool-js.com/images/demo/3.jpg"
},
{
url: "https://unix.cool-js.com/images/demo/4.jpg"
},
{
url: "https://unix.cool-js.com/images/demo/5.jpg"
},
{
url: "https://unix.cool-js.com/images/demo/6.jpg"
},
{
url: "https://unix.cool-js.com/images/demo/7.jpg"
}
]);
</script>

View File

@@ -271,6 +271,11 @@ const data = computed<Item[]>(() => {
label: t("时间轴"),
icon: "timeline-view",
path: "/pages/demo/data/timeline"
},
{
label: t("拖拽"),
icon: "drag-move-line",
path: "/pages/demo/data/draggable"
}
]
},