|
@ -233,7 +233,10 @@ async function strucWithPomsProject (ctx) { |
|
|
t_structure.id AS strucId, |
|
|
t_structure.id AS strucId, |
|
|
t_structure.name AS strucName, |
|
|
t_structure.name AS strucName, |
|
|
t_factor.id AS factorId, |
|
|
t_factor.id AS factorId, |
|
|
t_factor.name AS factorName |
|
|
t_factor.name AS factorName, |
|
|
|
|
|
t_factor.proto AS factorProto, |
|
|
|
|
|
t_factor_proto_item.name AS factorItemName, |
|
|
|
|
|
t_factor_proto_item.id AS factorItemId |
|
|
FROM |
|
|
FROM |
|
|
t_project |
|
|
t_project |
|
|
LEFT JOIN |
|
|
LEFT JOIN |
|
@ -260,6 +263,8 @@ async function strucWithPomsProject (ctx) { |
|
|
ON t_structure_factor.structure = t_structure.id |
|
|
ON t_structure_factor.structure = t_structure.id |
|
|
LEFT JOIN t_factor |
|
|
LEFT JOIN t_factor |
|
|
ON t_structure_factor.factor = t_factor.id |
|
|
ON t_structure_factor.factor = t_factor.id |
|
|
|
|
|
LEFT JOIN t_factor_proto_item |
|
|
|
|
|
ON t_factor_proto_item.proto = t_factor.proto |
|
|
WHERE |
|
|
WHERE |
|
|
project_state != -1 |
|
|
project_state != -1 |
|
|
AND |
|
|
AND |
|
@ -273,9 +278,18 @@ async function strucWithPomsProject (ctx) { |
|
|
if (!corStrut) { |
|
|
if (!corStrut) { |
|
|
let nextFacor = [] |
|
|
let nextFacor = [] |
|
|
if (s.factorId) { |
|
|
if (s.factorId) { |
|
|
|
|
|
let nextFactorItem = [] |
|
|
|
|
|
if (s.factorItemId) { |
|
|
|
|
|
nextFactorItem.push({ |
|
|
|
|
|
id: s.factorItemId, |
|
|
|
|
|
name: s.factorItemName, |
|
|
|
|
|
}) |
|
|
|
|
|
} |
|
|
nextFacor.push({ |
|
|
nextFacor.push({ |
|
|
id: s.factorId, |
|
|
id: s.factorId, |
|
|
name: s.factorName |
|
|
name: s.factorName, |
|
|
|
|
|
proto: s.factorProto, |
|
|
|
|
|
item: nextFactorItem, |
|
|
}) |
|
|
}) |
|
|
} |
|
|
} |
|
|
undelStruc.push({ |
|
|
undelStruc.push({ |
|
@ -284,15 +298,34 @@ async function strucWithPomsProject (ctx) { |
|
|
factor: nextFacor |
|
|
factor: nextFacor |
|
|
}) |
|
|
}) |
|
|
} else { |
|
|
} else { |
|
|
if (s.factorId && !corStrut.factor.some(v => v.id == s.factorId)) { |
|
|
if (s.factorId) { |
|
|
|
|
|
let corFactor = corStrut.factor.find(v => v.id == s.factorId) |
|
|
|
|
|
let nextFactorItem = null |
|
|
|
|
|
if (s.factorItemId) { |
|
|
|
|
|
nextFactorItem = { |
|
|
|
|
|
id: s.factorItemId, |
|
|
|
|
|
name: s.factorItemName, |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
if (corFactor) { |
|
|
|
|
|
if (!corFactor.item.some(fi => fi.id == s.factorItemId) && nextFactorItem) { |
|
|
|
|
|
corFactor.item.push(nextFactorItem) |
|
|
|
|
|
} |
|
|
|
|
|
} else { |
|
|
corStrut.factor.push({ |
|
|
corStrut.factor.push({ |
|
|
id: s.factorId, |
|
|
id: s.factorId, |
|
|
name: s.factorName |
|
|
name: s.factorName, |
|
|
|
|
|
proto: s.factorProto, |
|
|
|
|
|
item: nextFactorItem ? [{ |
|
|
|
|
|
id: s.factorItemId, |
|
|
|
|
|
name: s.factorItemName, |
|
|
|
|
|
}] : [], |
|
|
}) |
|
|
}) |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
ctx.status = 200; |
|
|
ctx.status = 200; |
|
|
ctx.body = undelStruc |
|
|
ctx.body = undelStruc |
|
|