| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- <template>
- <app-remote-select v-model="selectedValue" :options="dataList"
- :option-props="{ label: 'goodsName', value: 'goodsId' }" :remote-method="remoteMethod" @change="onChange"
- @reset="onReset">
- <template #default="{ option }">
- <div style="display: flex;justify-content: space-between;">
- <span>{{ option.goodsCode }}</span>
- <span>{{ option.goodsName }}</span>
- </div>
- </template>
- </app-remote-select>
- </template>
- <script lang="ts" setup>
- import { computed, toRaw } from 'vue'
- import { useRequest } from '@/hooks/request'
- import { queryGoodsSelect } from '@/services/api/common'
- import AppRemoteSelect from '@pc/components/base/remote-select/index.vue'
- const props = defineProps({
- modelValue: [Number, String],
- marketId: Number,
- status: String
- })
- const emit = defineEmits(['update:modelValue', 'change'])
- const selectedValue = computed({
- get: () => props.modelValue,
- set: (val) => emit('update:modelValue', val)
- })
- const { dataList, loading, run } = useRequest(queryGoodsSelect, {
- params: {
- goodsStatusIds: props.status
- }
- })
- const onReset = () => {
- if (!loading.value) {
- selectedValue.value = undefined
- run({
- marketId: props.marketId
- })
- }
- }
- const remoteMethod = (query: string) => {
- if (!loading.value) {
- if (query) {
- run({
- marketId: props.marketId,
- searchCode: query
- })
- } else if (!dataList.value.length) {
- onReset()
- }
- }
- }
- const onChange = (value?: number) => {
- const item = dataList.value.find((e) => e.goodsId === value)
- emit('change', toRaw(item))
- }
- </script>
|