2025-11-13 01:06:28 +08:00
|
|
|
|
<script setup>
|
2026-02-25 21:30:24 +08:00
|
|
|
|
import { ref, onMounted } from 'vue'
|
2025-11-14 02:15:14 +08:00
|
|
|
|
import GradientButton from '@/components/GradientButton.vue'
|
2026-03-16 01:52:38 +08:00
|
|
|
|
import { Button } from '@/components/ui/button'
|
|
|
|
|
|
import { Input } from '@/components/ui/input'
|
|
|
|
|
|
import { RadioGroup, RadioGroupItem } from '@/components/ui/radio-group'
|
|
|
|
|
|
import { Label } from '@/components/ui/label'
|
2026-03-16 01:57:16 +08:00
|
|
|
|
import { Card, CardContent } from '@/components/ui/card'
|
2026-02-25 21:30:24 +08:00
|
|
|
|
import { usePointsConfigStore } from '@/stores/pointsConfig'
|
|
|
|
|
|
|
|
|
|
|
|
const pointsConfigStore = usePointsConfigStore()
|
|
|
|
|
|
|
|
|
|
|
|
// 加载积分配置
|
|
|
|
|
|
onMounted(() => {
|
|
|
|
|
|
pointsConfigStore.loadConfig()
|
|
|
|
|
|
})
|
2025-11-13 01:06:28 +08:00
|
|
|
|
|
|
|
|
|
|
const props = defineProps({
|
|
|
|
|
|
modelValue: {
|
|
|
|
|
|
type: Object,
|
|
|
|
|
|
required: true,
|
|
|
|
|
|
},
|
|
|
|
|
|
loading: {
|
|
|
|
|
|
type: Boolean,
|
|
|
|
|
|
default: false,
|
|
|
|
|
|
},
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
const emit = defineEmits(['update:modelValue', 'analyze', 'reset'])
|
|
|
|
|
|
|
|
|
|
|
|
const form = ref({ ...props.modelValue })
|
|
|
|
|
|
|
|
|
|
|
|
function handleAnalyze() {
|
|
|
|
|
|
emit('update:modelValue', { ...form.value })
|
|
|
|
|
|
emit('analyze')
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function handleReset() {
|
|
|
|
|
|
form.value = { platform: '抖音', url: '', count: 20, sort_type: 0 }
|
|
|
|
|
|
emit('update:modelValue', { ...form.value })
|
|
|
|
|
|
emit('reset')
|
|
|
|
|
|
}
|
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
|
|
<template>
|
2026-03-16 01:57:16 +08:00
|
|
|
|
<Card class="border-0 shadow-sm bg-white/80 backdrop-blur-sm">
|
|
|
|
|
|
<CardContent class="p-5 space-y-5">
|
2026-03-16 01:52:38 +08:00
|
|
|
|
<!-- 平台选择 -->
|
2026-03-16 01:57:16 +08:00
|
|
|
|
<div class="space-y-2">
|
|
|
|
|
|
<Label class="text-sm font-medium text-gray-700">平台</Label>
|
|
|
|
|
|
<RadioGroup v-model="form.platform" class="flex gap-2">
|
|
|
|
|
|
<div class="inline-flex items-center justify-center px-4 h-9 text-sm font-medium text-white bg-primary-500 border border-primary-500 rounded-md cursor-pointer">
|
2026-03-16 01:52:38 +08:00
|
|
|
|
<RadioGroupItem value="抖音" id="douyin" class="hidden" />
|
2026-03-16 01:57:16 +08:00
|
|
|
|
<label for="douyin" class="cursor-pointer">抖音</label>
|
2026-03-16 01:52:38 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</RadioGroup>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- 链接输入 -->
|
2026-03-16 01:57:16 +08:00
|
|
|
|
<div class="space-y-2">
|
|
|
|
|
|
<Label class="text-sm font-medium text-gray-700">主页/视频链接</Label>
|
2026-03-16 01:52:38 +08:00
|
|
|
|
<Input
|
|
|
|
|
|
v-model="form.url"
|
2026-01-27 00:39:12 +08:00
|
|
|
|
placeholder="粘贴抖音主页或视频链接"
|
2026-03-16 01:57:16 +08:00
|
|
|
|
class="h-11 bg-gray-50 border-gray-300"
|
2025-11-13 01:06:28 +08:00
|
|
|
|
/>
|
2026-03-16 01:52:38 +08:00
|
|
|
|
</div>
|
2026-01-27 00:39:12 +08:00
|
|
|
|
|
2026-03-17 23:41:49 +08:00
|
|
|
|
<!-- 排序方式 -->
|
|
|
|
|
|
<div class="space-y-2">
|
|
|
|
|
|
<Label class="text-sm font-medium text-gray-700">排序方式</Label>
|
|
|
|
|
|
<RadioGroup v-model="form.sort_type" class="flex gap-2">
|
|
|
|
|
|
<div class="inline-flex items-center justify-center px-4 h-9 text-sm font-medium rounded-lg cursor-pointer transition-all"
|
|
|
|
|
|
:class="form.sort_type === 0 ? 'bg-primary text-primary-foreground' : 'bg-muted text-muted-foreground hover:bg-muted/80'">
|
|
|
|
|
|
<RadioGroupItem :value="0" id="sort-default" class="hidden" />
|
|
|
|
|
|
<label for="sort-default" class="cursor-pointer">综合排序</label>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="inline-flex items-center justify-center px-4 h-9 text-sm font-medium rounded-lg cursor-pointer transition-all"
|
|
|
|
|
|
:class="form.sort_type === 1 ? 'bg-primary text-primary-foreground' : 'bg-muted text-muted-foreground hover:bg-muted/80'">
|
|
|
|
|
|
<RadioGroupItem :value="1" id="sort-likes" class="hidden" />
|
|
|
|
|
|
<label for="sort-likes" class="cursor-pointer">最多点赞</label>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="inline-flex items-center justify-center px-4 h-9 text-sm font-medium rounded-lg cursor-pointer transition-all"
|
|
|
|
|
|
:class="form.sort_type === 2 ? 'bg-primary text-primary-foreground' : 'bg-muted text-muted-foreground hover:bg-muted/80'">
|
|
|
|
|
|
<RadioGroupItem :value="2" id="sort-latest" class="hidden" />
|
|
|
|
|
|
<label for="sort-latest" class="cursor-pointer">最新发布</label>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</RadioGroup>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
2026-03-16 01:52:38 +08:00
|
|
|
|
<!-- 分析数量 -->
|
2026-03-16 01:57:16 +08:00
|
|
|
|
<div class="space-y-2">
|
|
|
|
|
|
<Label class="text-sm font-medium text-gray-700">分析数量</Label>
|
|
|
|
|
|
<div class="flex items-center gap-3">
|
|
|
|
|
|
<span class="min-w-[32px] text-sm font-semibold text-primary-500 text-center">{{ form.count }}</span>
|
2026-02-25 21:57:05 +08:00
|
|
|
|
<input
|
|
|
|
|
|
type="range"
|
|
|
|
|
|
v-model.number="form.count"
|
|
|
|
|
|
min="1"
|
|
|
|
|
|
max="40"
|
2026-03-16 01:57:16 +08:00
|
|
|
|
class="flex-1 h-1 bg-gray-200 rounded-full appearance-none cursor-pointer
|
|
|
|
|
|
[&::-webkit-slider-thumb]:appearance-none [&::-webkit-slider-thumb]:w-4 [&::-webkit-slider-thumb]:h-4
|
|
|
|
|
|
[&::-webkit-slider-thumb]:bg-primary-500 [&::-webkit-slider-thumb]:rounded-full
|
|
|
|
|
|
[&::-webkit-slider-thumb]:cursor-pointer [&::-webkit-slider-thumb]:transition-transform
|
|
|
|
|
|
[&::-webkit-slider-thumb]:hover:scale-110 [&::-webkit-slider-thumb]:hover:shadow-[0_0_0_4px_rgba(59,130,246,0.15)]
|
|
|
|
|
|
[&::-moz-range-thumb]:w-4 [&::-moz-range-thumb]:h-4 [&::-moz-range-thumb]:bg-primary-500
|
|
|
|
|
|
[&::-moz-range-thumb]:rounded-full [&::-moz-range-thumb]:border-none [&::-moz-range-thumb]:cursor-pointer"
|
2026-02-25 21:57:05 +08:00
|
|
|
|
/>
|
2025-11-13 01:06:28 +08:00
|
|
|
|
</div>
|
2026-03-16 01:57:16 +08:00
|
|
|
|
<p class="text-sm text-gray-500 mt-1">建议 20-30 个内容</p>
|
2026-03-16 01:52:38 +08:00
|
|
|
|
</div>
|
2026-01-27 00:39:12 +08:00
|
|
|
|
|
2026-03-16 01:52:38 +08:00
|
|
|
|
<!-- 操作按钮 -->
|
2026-03-16 01:57:16 +08:00
|
|
|
|
<div class="flex gap-3">
|
2025-11-14 02:15:14 +08:00
|
|
|
|
<GradientButton
|
|
|
|
|
|
text="开始分析"
|
|
|
|
|
|
:loading="loading"
|
|
|
|
|
|
loading-text="分析中…"
|
|
|
|
|
|
size="middle"
|
|
|
|
|
|
@click="handleAnalyze"
|
|
|
|
|
|
/>
|
2026-03-16 01:52:38 +08:00
|
|
|
|
<Button variant="outline" @click="handleReset">重置</Button>
|
|
|
|
|
|
</div>
|
2026-03-16 01:57:16 +08:00
|
|
|
|
<p class="text-xs text-gray-500 text-center">每次分析将消耗积分,消耗量与分析数量相关</p>
|
|
|
|
|
|
</CardContent>
|
|
|
|
|
|
</Card>
|
2025-11-13 01:06:28 +08:00
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<style scoped>
|
|
|
|
|
|
</style>
|