sql数据流,amdin业务逻辑接入

This commit is contained in:
comlibmb
2026-02-15 16:37:37 +08:00
parent ec636dc703
commit e648ff0c22
43 changed files with 5412 additions and 1024 deletions

View File

@@ -197,3 +197,165 @@ export async function getPromoterList(params?: PromoterListParams): Promise<Prom
}
return (data ?? []) as Promoter[]
}
/**
* 事业部模型
*/
export type DistributionDivision = {
id?: string
merchant_id?: string
uid: string
name: string
invite_code: string
ratio: number
agent_count: number
end_time: string | null
status: boolean
created_at?: string
updated_at?: string
// 关联字段
nickname?: string
avatar_url?: string
}
/**
* 代理商模型
*/
export type DistributionAgent = {
id?: string
merchant_id?: string
uid: string
division_id: string
name: string
status: boolean
created_at?: string
updated_at?: string
// 关联字段
nickname?: string
avatar_url?: string
division_name?: string
}
/**
* 获取事业部列表
*/
export async function fetchDivisions(query?: { search?: string, page?: number, pageSize?: number }): Promise<{ total: number, items: DistributionDivision[] }> {
let q = supa.from('ak_distribution_divisions').select('*, ak_users!uid(username, avatar_url)', { count: 'exact' })
if (query?.search != null && query.search !== '') {
q = q.or(`name.ilike.%${query.search}%,ak_users.username.ilike.%${query.search}%`)
}
const p = query?.page ?? 1
const ps = query?.pageSize ?? 20
const from = (p - 1) * ps
const to = from + ps - 1
const { data, error, count } = await q
.order('created_at', { ascending: false })
.range(from, to)
.execute()
if (error != null) {
console.error('获取事业部列表失败:', error)
return { total: 0, items: [] as DistributionDivision[] }
}
const items = (data ?? []).map((item: any): DistributionDivision => {
return {
...item,
nickname: item.ak_users?.username,
avatar_url: item.ak_users?.avatar_url
} as DistributionDivision
})
return { total: count ?? 0, items }
}
/**
* 保存事业部(新增/更新)
*/
export async function saveDivision(division: DistributionDivision): Promise<boolean> {
const session = supa.getSession()
const mid = session?.user?.getString('id')
if (mid == null) return false
const { error } = await supa
.from('ak_distribution_divisions')
.upsert({
...division,
merchant_id: mid,
updated_at: new Date().toISOString()
})
.execute()
return error == null
}
/**
* 删除事业部
*/
export async function deleteDivision(id: string): Promise<boolean> {
const { error } = await supa.from('ak_distribution_divisions').delete().eq('id', id).execute()
return error == null
}
/**
* 获取代理商列表
*/
export async function fetchAgents(query?: { search?: string, divisionId?: string, page?: number, pageSize?: number }): Promise<{ total: number, items: DistributionAgent[] }> {
let q = supa.from('ak_distribution_agents').select('*, ak_users!uid(username, avatar_url), ak_distribution_divisions!division_id(name)', { count: 'exact' })
if (query?.search != null && query.search !== '') {
q = q.or(`name.ilike.%${query.search}%,ak_users.username.ilike.%${query.search}%`)
}
if (query?.divisionId != null) {
q = q.eq('division_id', query.divisionId)
}
const p = query?.page ?? 1
const ps = query?.pageSize ?? 20
const from = (p - 1) * ps
const to = from + ps - 1
const { data, error, count } = await q
.order('created_at', { ascending: false })
.range(from, to)
.execute()
if (error != null) {
console.error('获取代理商列表失败:', error)
return { total: 0, items: [] as DistributionAgent[] }
}
const items = (data ?? []).map((item: any): DistributionAgent => {
return {
...item,
nickname: item.ak_users?.username,
avatar_url: item.ak_users?.avatar_url,
division_name: item.ak_distribution_divisions?.name
} as DistributionAgent
})
return { total: count ?? 0, items }
}
/**
* 保存代理商
*/
export async function saveAgent(agent: DistributionAgent): Promise<boolean> {
const session = supa.getSession()
const mid = session?.user?.getString('id')
if (mid == null) return false
const { error } = await supa
.from('ak_distribution_agents')
.upsert({
...agent,
merchant_id: mid,
updated_at: new Date().toISOString()
})
.execute()
return error == null
}