- Add installation position handler, service, and schema - Update list configuration and entry form components - Enhance pagination component with configurable controls - Implement installation position list view with search and pagination
42 lines
1.0 KiB
TypeScript
42 lines
1.0 KiB
TypeScript
// Base
|
|
import * as base from './_crud-base'
|
|
|
|
// Types
|
|
import type { Installation } from '~/models/installation'
|
|
|
|
const path = '/api/v1/installation-position'
|
|
const name = 'installation'
|
|
|
|
export function create(data: any) {
|
|
return base.create(path, data, name)
|
|
}
|
|
|
|
export function getList(params: any = null) {
|
|
return base.getList(path, params, name)
|
|
}
|
|
|
|
export function getDetail(id: number | string) {
|
|
return base.getDetail(path, id, name)
|
|
}
|
|
|
|
export function update(id: number | string, data: any) {
|
|
return base.update(path, id, data, name)
|
|
}
|
|
|
|
export function remove(id: number | string) {
|
|
return base.remove(path, id, name)
|
|
}
|
|
|
|
export async function getValueLabelList(params: any = null): Promise<{ value: string; label: string }[]> {
|
|
let data: { value: string; label: string }[] = []
|
|
const result = await getList(params)
|
|
if (result.success) {
|
|
const resultData = result.body?.data || []
|
|
data = resultData.map((item: Installation) => ({
|
|
value: item.id ? Number(item.id) : item.code,
|
|
label: item.name,
|
|
}))
|
|
}
|
|
return data
|
|
}
|