fix: product_category tree root node query + parent_id normalization - get_product_category: accept NULL/empty/'0' as root (parent_id IS NULL OR '' OR '0') - new_product_category: normalize empty/0 parent_id to NULL
This commit is contained in:
parent
24605f88e8
commit
f13651e830
@ -2,15 +2,15 @@
|
||||
ns = params_kw.copy()
|
||||
sql = '''select * from product_category where 1 = 1'''
|
||||
id = ns.get('id')
|
||||
if id:
|
||||
if id and id != '0' and id != 'null' and id != 'undefined':
|
||||
sql += " and parent_id = ${id}$"
|
||||
else:
|
||||
sql += " and parent_id is null"
|
||||
sql += " and (parent_id is null or parent_id = '' or parent_id = '0')"
|
||||
|
||||
sql += " order by name "
|
||||
sql += " order by sort_order, name "
|
||||
db = DBPools()
|
||||
dbname = get_module_dbname('product_management')
|
||||
async with db.sqlorContext(dbname) as sor:
|
||||
r = await sor.sqlExe(sql, ns)
|
||||
return r
|
||||
return []
|
||||
return []
|
||||
|
||||
@ -1,15 +1,19 @@
|
||||
|
||||
ns = params_kw.copy()
|
||||
for k,v in ns.items():
|
||||
if v == 'NaN' or v == 'null':
|
||||
if v == 'NaN' or v == 'null' or v == 'undefined' or v == '':
|
||||
ns[k] = None
|
||||
id = params_kw.id
|
||||
if not id or len(id) > 32:
|
||||
|
||||
# Normalize parent_id: empty/0/None all mean root node (NULL)
|
||||
pid = ns.get('parent_id')
|
||||
if not pid or pid == '0':
|
||||
ns['parent_id'] = None
|
||||
|
||||
id = params_kw.get('id')
|
||||
if not id or len(str(id)) > 32:
|
||||
id = uuid()
|
||||
ns['id'] = id
|
||||
|
||||
|
||||
|
||||
userorgid = await get_userorgid()
|
||||
if not userorgid:
|
||||
return {
|
||||
@ -54,4 +58,4 @@ return {
|
||||
"timeout":3,
|
||||
"message":"failed"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user