李红攀:V2.0.001小程序的采摘管理

This commit is contained in:
2026-04-17 19:40:30 +08:00
parent 9ee0c6c597
commit 45eb9232d7
16 changed files with 2463 additions and 0 deletions

View File

@@ -0,0 +1,104 @@
<template>
<!-- 搜索框入口 -->
<view @click="visible = true">
<wd-search :placeholder="placeholder" hide-cancel disabled />
</view>
<!-- 搜索弹窗 -->
<wd-popup v-model="visible" position="top" @close="visible = false">
<view class="yd-search-form-container" :style="{ paddingTop: `${getNavbarHeight()}px` }">
<view class="yd-search-form-item">
<view class="yd-search-form-label">
采购单编号
</view>
<wd-input
v-model="formData.no"
placeholder="请输入采购单编号"
clearable
/>
</view>
<view class="yd-search-form-item">
<view class="yd-search-form-label">
采购状态
</view>
<wd-radio-group v-model="formData.status" shape="button">
<wd-radio :value="-1">
全部
</wd-radio>
<wd-radio :value="10">
未审批
</wd-radio>
<wd-radio :value="20">
已审批
</wd-radio>
<wd-radio :value="30">
已驳回
</wd-radio>
</wd-radio-group>
</view>
<view class="yd-search-form-actions">
<wd-button class="flex-1" plain @click="handleReset">
重置
</wd-button>
<wd-button class="flex-1" type="primary" @click="handleSearch">
搜索
</wd-button>
</view>
</view>
</wd-popup>
</template>
<script lang="ts" setup>
import { computed, reactive, ref } from 'vue'
import { getNavbarHeight } from '@/utils'
const emit = defineEmits<{
search: [data: Record<string, any>]
reset: []
}>()
const visible = ref(false)
const formData = reactive({
no: undefined as string | undefined,
status: -1,
})
const statusMap: Record<number, string> = {
10: '未审批',
20: '已审批',
30: '已驳回',
}
/** 搜索条件 placeholder 拼接 */
const placeholder = computed(() => {
const conditions: string[] = []
if (formData.no) {
conditions.push(`编号:${formData.no}`)
}
if (formData.status !== -1) {
conditions.push(`状态:${statusMap[formData.status] || formData.status}`)
}
return conditions.length > 0 ? conditions.join(' | ') : '搜索采购订单'
})
/** 搜索 */
function handleSearch() {
visible.value = false
const params: Record<string, any> = {}
if (formData.no) {
params.no = formData.no
}
if (formData.status !== -1) {
params.status = formData.status
}
emit('search', params)
}
/** 重置 */
function handleReset() {
formData.no = undefined
formData.status = -1
visible.value = false
emit('reset')
}
</script>