Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 1 | <template>
|
| 2 | <div class="upload-page">
|
Xing Jinwen | ebbccad | 2025-06-07 21:24:44 +0800 | [diff] [blame^] | 3 | <Navbar />
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 4 | <div class="upload-container">
|
| 5 | <h2>上传种子</h2>
|
| 6 |
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 7 | <el-form
|
| 8 | ref="uploadFormRef"
|
| 9 | :model="uploadForm"
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 10 | :rules="uploadRules"
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 11 | label-width="120px"
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 12 | class="upload-form"
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 13 | >
|
| 14 | <!-- 种子文件上传 -->
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 15 | <el-form-item label="种子文件" prop="file">
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 16 | <el-upload
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 17 | ref="uploadRef"
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 18 | :auto-upload="false"
|
| 19 | :limit="1"
|
| 20 | accept=".torrent"
|
| 21 | :on-change="handleTorrentChange"
|
| 22 | :on-remove="handleTorrentRemove"
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 23 | :file-list="fileList"
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 24 | >
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 25 | <template #trigger>
|
| 26 | <el-button type="primary">选择文件</el-button>
|
| 27 | </template>
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 28 | <template #tip>
|
| 29 | <div class="el-upload__tip">
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 30 | 只能上传 .torrent 文件
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 31 | </div>
|
| 32 | </template>
|
| 33 | </el-upload>
|
| 34 | </el-form-item>
|
| 35 |
|
| 36 | <!-- 基本信息 -->
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 37 | <el-form-item label="标题" prop="title">
|
| 38 | <el-input v-model="uploadForm.title" placeholder="请输入种子标题" />
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 39 | </el-form-item>
|
| 40 |
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 41 | <el-form-item label="副标题" prop="subtitle">
|
| 42 | <el-input v-model="uploadForm.subtitle" placeholder="请输入副标题(可选)" />
|
| 43 | </el-form-item>
|
| 44 |
|
| 45 | <el-form-item label="分类" prop="category">
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 46 | <el-select v-model="uploadForm.category" placeholder="请选择分类">
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 47 | <el-option
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 48 | v-for="category in categories"
|
| 49 | :key="category.id"
|
| 50 | :label="category.name"
|
| 51 | :value="category.slug"
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 52 | />
|
| 53 | </el-select>
|
| 54 | </el-form-item>
|
| 55 |
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 56 | <!-- 标签 -->
|
| 57 | <el-form-item label="标签" prop="tag">
|
| 58 | <el-select
|
| 59 | v-model="uploadForm.tag"
|
| 60 | multiple
|
| 61 | filterable
|
| 62 | allow-create
|
| 63 | placeholder="请选择或输入标签"
|
| 64 | >
|
| 65 | <el-option
|
| 66 | v-for="tag in availableTags"
|
| 67 | :key="tag.id"
|
| 68 | :label="tag.name"
|
| 69 | :value="tag.name"
|
| 70 | />
|
| 71 | </el-select>
|
| 72 | </el-form-item>
|
| 73 |
|
| 74 | <!-- 描述信息 -->
|
| 75 | <el-form-item label="描述" prop="description">
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 76 | <el-input
|
| 77 | v-model="uploadForm.description"
|
| 78 | type="textarea"
|
| 79 | :rows="6"
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 80 | placeholder="请输入种子描述,支持 Markdown 格式"
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 81 | />
|
| 82 | </el-form-item>
|
| 83 |
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 84 | <!-- 匿名发布 -->
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 85 | <el-form-item>
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 86 | <el-checkbox v-model="uploadForm.anonymous">匿名发布</el-checkbox>
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 87 | </el-form-item>
|
| 88 |
|
| 89 | <!-- 提交按钮 -->
|
| 90 | <el-form-item>
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 91 | <el-button type="primary" @click="submitUpload" :loading="uploading">
|
| 92 | 上传种子
|
| 93 | </el-button>
|
| 94 | <el-button @click="resetForm">重置表单</el-button>
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 95 | </el-form-item>
|
| 96 | </el-form>
|
| 97 | </div>
|
| 98 | </div>
|
| 99 | </template>
|
| 100 |
|
| 101 | <script>
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 102 | import { ref, reactive, onMounted } from 'vue'
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 103 | import { useRouter } from 'vue-router'
|
| 104 | import { ElMessage } from 'element-plus'
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 105 | import { uploadTorrent, getCategories, getTags } from '@/api/torrent'
|
Xing Jinwen | ebbccad | 2025-06-07 21:24:44 +0800 | [diff] [blame^] | 106 | import Navbar from '@/components/Navbar.vue'
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 107 | export default {
|
| 108 | name: 'UploadView',
|
Xing Jinwen | ebbccad | 2025-06-07 21:24:44 +0800 | [diff] [blame^] | 109 | components: {
|
| 110 | Navbar
|
| 111 | },
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 112 | setup() {
|
| 113 | const router = useRouter()
|
| 114 | const uploadFormRef = ref(null)
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 115 | const uploadRef = ref(null)
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 116 | const uploading = ref(false)
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 117 | const fileList = ref([])
|
| 118 |
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 119 | const uploadForm = reactive({
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 120 | title: '',
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 121 | subtitle: '',
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 122 | category: '',
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 123 | tag: [],
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 124 | description: '',
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 125 | anonymous: false,
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 126 | file: null
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 127 | })
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 128 |
|
| 129 | const uploadRules = {
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 130 | title: [
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 131 | { required: true, message: '请输入种子标题', trigger: 'blur' },
|
| 132 | { min: 3, max: 100, message: '标题长度应在 3 到 100 个字符之间', trigger: 'blur' }
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 133 | ],
|
| 134 | category: [
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 135 | { required: true, message: '请选择分类', trigger: 'change' }
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 136 | ],
|
| 137 | description: [
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 138 | { required: true, message: '请输入种子描述', trigger: 'blur' },
|
| 139 | { min: 10, message: '描述至少需要 10 个字符', trigger: 'blur' }
|
| 140 | ],
|
| 141 | file: [
|
| 142 | { required: true, message: '请上传种子文件', trigger: 'change' }
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 143 | ]
|
| 144 | }
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 145 |
|
| 146 | const categories = ref([])
|
| 147 | const availableTags = ref([])
|
| 148 |
|
| 149 | // 获取分类列表
|
| 150 | const loadCategories = async () => {
|
| 151 | try {
|
| 152 | console.log('开始加载分类列表...')
|
vulgar5201 | c4a15b1 | 2025-06-06 13:55:09 +0800 | [diff] [blame] | 153 | console.log('当前token(分类列表):', localStorage.getItem('token'))
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 154 | const response = await getCategories()
|
| 155 | console.log('分类列表响应:', response)
|
| 156 |
|
vulgar5201 | c4a15b1 | 2025-06-06 13:55:09 +0800 | [diff] [blame] | 157 | const list = Array.isArray(response) ? response : response.data
|
| 158 |
|
| 159 | if (list && list.length > 0) {
|
| 160 | categories.value = list
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 161 | console.log('分类列表加载成功:', categories.value)
|
| 162 | } else {
|
| 163 | console.warn('分类列表数据为空')
|
| 164 | categories.value = []
|
| 165 | }
|
| 166 | } catch (error) {
|
| 167 | console.error('Failed to load categories:', error)
|
| 168 | console.error('错误详情:', {
|
| 169 | message: error.message,
|
| 170 | response: error.response?.data,
|
| 171 | status: error.response?.status,
|
| 172 | config: error.config
|
| 173 | })
|
| 174 |
|
| 175 | // 根据错误类型显示不同的提示
|
| 176 | if (error.response?.status === 401) {
|
| 177 | ElMessage.error('请先登录')
|
| 178 | router.push('/login')
|
| 179 | } else if (error.response?.status === 403) {
|
| 180 | ElMessage.error('没有权限访问分类列表')
|
| 181 | } else if (error.code === 'ERR_NETWORK') {
|
| 182 | ElMessage.error('无法连接到服务器,请检查后端服务是否启动')
|
| 183 | } else {
|
| 184 | ElMessage.error(`获取分类列表失败: ${error.message}`)
|
| 185 | }
|
| 186 | }
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 187 | }
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 188 |
|
| 189 | // 获取标签列表
|
| 190 | const loadTags = async () => {
|
| 191 | try {
|
| 192 | console.log('开始加载标签列表...')
|
| 193 | const response = await getTags()
|
| 194 | console.log('标签列表响应:', response)
|
| 195 |
|
| 196 | if (response && response.data) {
|
| 197 | availableTags.value = response.data
|
| 198 | console.log('标签列表加载成功:', availableTags.value)
|
| 199 | } else {
|
| 200 | console.warn('标签列表数据为空')
|
| 201 | availableTags.value = []
|
| 202 | }
|
| 203 | } catch (error) {
|
| 204 | console.error('Failed to load tags:', error)
|
| 205 | console.error('错误详情:', {
|
| 206 | message: error.message,
|
| 207 | response: error.response?.data,
|
| 208 | status: error.response?.status
|
| 209 | })
|
| 210 |
|
| 211 | // 如果是网络错误,提供更详细的提示
|
| 212 | if (error.code === 'ERR_NETWORK') {
|
| 213 | ElMessage.error('无法连接到服务器,请检查后端服务是否启动')
|
| 214 | } else {
|
| 215 | ElMessage.error(`获取标签列表失败: ${error.message}`)
|
| 216 | }
|
| 217 | }
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 218 | }
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 219 |
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 220 | const handleTorrentChange = (file) => {
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 221 | if (file) {
|
| 222 | uploadForm.file = file.raw
|
| 223 | fileList.value = [file]
|
| 224 |
|
| 225 | // 自动校验文件字段
|
| 226 | uploadFormRef.value?.validateField('file')
|
| 227 | }
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 228 | }
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 229 |
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 230 | const handleTorrentRemove = () => {
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 231 | uploadForm.file = null
|
| 232 | fileList.value = []
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 233 | }
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 234 |
|
| 235 | const submitUpload = async () => {
|
| 236 | if (!uploadForm.file) {
|
| 237 | ElMessage.warning('请先选择种子文件')
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 238 | return
|
| 239 | }
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 240 |
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 241 | try {
|
| 242 | await uploadFormRef.value?.validate()
|
| 243 |
|
| 244 | uploading.value = true
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 245 | const formData = new FormData()
|
| 246 | formData.append('file', uploadForm.file)
|
| 247 | formData.append('title', uploadForm.title)
|
| 248 | formData.append('subtitle', uploadForm.subtitle || '')
|
| 249 | formData.append('category', uploadForm.category)
|
| 250 | formData.append('description', uploadForm.description)
|
| 251 | formData.append('anonymous', uploadForm.anonymous)
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 252 |
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 253 | // 处理标签数组
|
| 254 | if (uploadForm.tag && uploadForm.tag.length > 0) {
|
| 255 | uploadForm.tag.forEach(tag => {
|
| 256 | formData.append('tag', tag)
|
| 257 | })
|
| 258 | }
|
| 259 |
|
| 260 | const response = await uploadTorrent(formData)
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 261 |
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 262 | ElMessage.success('种子上传成功')
|
| 263 | // 根据后端返回的数据跳转到种子详情页
|
| 264 | if (response.data && response.data.infoHash) {
|
| 265 | router.push(`/torrent/${response.data.infoHash}`)
|
| 266 | } else {
|
| 267 | router.push('/torrents') // 或者跳转到种子列表页
|
| 268 | }
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 269 | } catch (error) {
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 270 | console.error('Failed to upload torrent:', error)
|
| 271 |
|
| 272 | // 根据后端返回的错误信息显示不同的提示
|
| 273 | let errorMessage = '种子上传失败'
|
| 274 | if (error.response?.data?.message) {
|
| 275 | errorMessage = error.response.data.message
|
| 276 | } else if (error.response?.data?.error) {
|
| 277 | errorMessage = error.response.data.error
|
| 278 | }
|
| 279 |
|
| 280 | ElMessage.error(errorMessage)
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 281 | } finally {
|
| 282 | uploading.value = false
|
| 283 | }
|
| 284 | }
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 285 |
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 286 | const resetForm = () => {
|
| 287 | uploadFormRef.value?.resetFields()
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 288 | uploadRef.value?.clearFiles()
|
| 289 | uploadForm.file = null
|
| 290 | fileList.value = []
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 291 | }
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 292 |
|
| 293 | // 组件挂载时加载数据
|
| 294 | onMounted(() => {
|
| 295 | loadCategories()
|
| 296 | loadTags()
|
| 297 | })
|
| 298 |
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 299 | return {
|
| 300 | uploadFormRef,
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 301 | uploadRef,
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 302 | uploading,
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 303 | uploadForm,
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 304 | uploadRules,
|
| 305 | categories,
|
| 306 | availableTags,
|
| 307 | fileList,
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 308 | handleTorrentChange,
|
| 309 | handleTorrentRemove,
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 310 | submitUpload,
|
| 311 | resetForm
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 312 | }
|
| 313 | }
|
| 314 | }
|
| 315 | </script>
|
| 316 |
|
| 317 | <style lang="scss" scoped>
|
| 318 | .upload-page {
|
| 319 | max-width: 800px;
|
| 320 | margin: 0 auto;
|
| 321 | padding: 24px;
|
| 322 | }
|
| 323 |
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 324 | .upload-container {
|
| 325 | background: #fff;
|
| 326 | border-radius: 8px;
|
| 327 | padding: 24px;
|
| 328 | box-shadow: 0 2px 12px rgba(0, 0, 0, 0.1);
|
| 329 |
|
| 330 | h2 {
|
| 331 | margin: 0 0 24px;
|
| 332 | padding-bottom: 16px;
|
| 333 | border-bottom: 1px solid #eee;
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 334 | color: #2c3e50;
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 335 | }
|
| 336 | }
|
| 337 |
|
| 338 | .upload-form {
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 339 | .el-upload {
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 340 | width: 100%;
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 341 | }
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 342 |
|
| 343 | .el-upload__tip {
|
| 344 | line-height: 1.2;
|
| 345 | padding: 8px 0;
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 346 | color: #909399;
|
| 347 | }
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 348 | }
|
| 349 |
|
| 350 | @media (max-width: 768px) {
|
| 351 | .upload-page {
|
| 352 | padding: 16px;
|
| 353 | }
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 354 |
|
| 355 | .upload-container {
|
| 356 | padding: 16px;
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 357 | }
|
vulgar5201 | 055346a | 2025-06-05 14:15:55 +0800 | [diff] [blame] | 358 |
|
| 359 | :deep(.el-form-item__label) {
|
| 360 | float: none;
|
| 361 | display: block;
|
| 362 | text-align: left;
|
| 363 | padding: 0 0 8px;
|
| 364 | }
|
| 365 |
|
| 366 | :deep(.el-form-item__content) {
|
| 367 | margin-left: 0 !important;
|
Xing Jinwen | ff16b1e | 2025-06-05 00:29:26 +0800 | [diff] [blame] | 368 | }
|
| 369 | }
|
xingjinwen | d652cc6 | 2025-06-04 19:52:19 +0800 | [diff] [blame] | 370 | </style> |