feat: refs #7363 item_getBalance saleTracking no mostrar duplicados
gitea/salix/pipeline/pr-dev There was a failure building this commit Details

This commit is contained in:
Robert Ferrús 2024-05-10 11:51:54 +02:00
parent 6207d79244
commit cb9cacc1ea
1 changed files with 149 additions and 110 deletions

View File

@ -41,113 +41,152 @@ BEGIN
); );
INSERT INTO tItemDiary INSERT INTO tItemDiary
SELECT tr.landed shipped, WITH entries AS (
b.quantity `in`, SELECT tr.landed shipped,
NULL `out`, b.quantity `in`,
st.alertLevel , NULL `out`,
st.name stateName, st.alertLevel ,
s.name `name`, st.name stateName,
e.invoiceNumber reference, s.name `name`,
e.id origin, e.invoiceNumber reference,
s.id clientFk, e.id origin,
IF(st.`code` = 'DELIVERED', TRUE, FALSE) isPicked, s.id clientFk,
FALSE isTicket, IF(st.`code` = 'DELIVERED', TRUE, FALSE) isPicked,
b.id lineFk, FALSE isTicket,
NULL `order`, b.id lineFk,
NULL clientType, NULL `order`,
NULL claimFk, NULL clientType,
ec.inventorySupplierFk NULL claimFk,
FROM buy b ec.inventorySupplierFk
JOIN entry e ON e.id = b.entryFk FROM buy b
JOIN travel tr ON tr.id = e.travelFk JOIN entry e ON e.id = b.entryFk
JOIN supplier s ON s.id = e.supplierFk JOIN travel tr ON tr.id = e.travelFk
JOIN state st ON st.`code` = IF( tr.landed < util.VN_CURDATE() JOIN supplier s ON s.id = e.supplierFk
OR (util.VN_CURDATE() AND tr.isReceived), JOIN state st ON st.`code` = IF( tr.landed < util.VN_CURDATE()
'DELIVERED', OR (util.VN_CURDATE() AND tr.isReceived),
'FREE') 'DELIVERED',
JOIN entryConfig ec 'FREE')
WHERE tr.landed >= vDateInventory JOIN entryConfig ec
AND vWarehouseFk = tr.warehouseInFk WHERE tr.landed >= vDateInventory
AND (s.id <> ec.inventorySupplierFk OR vDate IS NULL) AND vWarehouseFk = tr.warehouseInFk
AND b.itemFk = vItemFk AND (s.id <> ec.inventorySupplierFk OR vDate IS NULL)
AND e.isExcludedFromAvailable = FALSE AND b.itemFk = vItemFk
AND e.isRaid = FALSE AND NOT e.isExcludedFromAvailable
UNION ALL AND NOT e.isRaid
SELECT tr.shipped, ),
NULL, deliveried AS (
b.quantity, SELECT tr.shipped,
st.alertLevel, NULL,
st.name, b.quantity,
s.name, st.alertLevel,
e.invoiceNumber, st.name stateName,
e.id, s.name ,
s.id, e.invoiceNumber,
IF(st.`code` = 'DELIVERED' , TRUE, FALSE), e.id entryFk,
FALSE, s.id supplierFk,
b.id, IF(st.`code` = 'DELIVERED' , TRUE, FALSE),
NULL, FALSE isTicket,
NULL, b.id,
NULL, NULL `order`,
ec.inventorySupplierFk NULL clientType,
FROM buy b NULL claimFk,
JOIN entry e ON e.id = b.entryFk ec.inventorySupplierFk
JOIN travel tr ON tr.id = e.travelFk FROM buy b
JOIN warehouse w ON w.id = tr.warehouseOutFk JOIN entry e ON e.id = b.entryFk
JOIN supplier s ON s.id = e.supplierFk JOIN travel tr ON tr.id = e.travelFk
JOIN state st ON st.`code` = IF(tr.shipped < util.VN_CURDATE() JOIN warehouse w ON w.id = tr.warehouseOutFk
OR (tr.shipped = util.VN_CURDATE() AND tr.isReceived), JOIN supplier s ON s.id = e.supplierFk
'DELIVERED', JOIN state st ON st.`code` = IF(tr.shipped < util.VN_CURDATE()
'FREE') OR (tr.shipped = util.VN_CURDATE() AND tr.isReceived),
JOIN entryConfig ec 'DELIVERED',
WHERE tr.shipped >= vDateInventory 'FREE')
AND vWarehouseFk = tr.warehouseOutFk JOIN entryConfig ec
AND (s.id <> ec.inventorySupplierFk OR vDate IS NULL) WHERE tr.shipped >= vDateInventory
AND b.itemFk = vItemFk AND vWarehouseFk = tr.warehouseOutFk
AND e.isExcludedFromAvailable = FALSE AND (s.id <> ec.inventorySupplierFk OR vDate IS NULL)
AND w.isFeedStock = FALSE AND b.itemFk = vItemFk
AND e.isRaid = FALSE AND NOT e.isExcludedFromAvailable
UNION ALL AND NOT w.isFeedStock
SELECT DATE(t.shipped), AND NOT e.isRaid
NULL, ),
s.quantity, sales AS (
st2.alertLevel, SELECT DATE(t.shipped) shipped,
st2.name, s.quantity,
t.nickname, st2.alertLevel,
t.refFk, st2.name,
t.id, t.nickname,
t.clientFk, t.refFk,
stk.id, t.id ticketFk,
TRUE, t.clientFk,
s.id, s.id saleFk,
st.`order`, st.`order`,
c.typeFk, c.typeFk,
cb.claimFk, cb.claimFk
NULL FROM sale s
FROM sale s JOIN ticket t ON t.id = s.ticketFk
JOIN ticket t ON t.id = s.ticketFk LEFT JOIN ticketState ts ON ts.ticketFk = t.id
LEFT JOIN ticketState ts ON ts.ticketFk = t.id LEFT JOIN state st ON st.`code` = ts.`code`
LEFT JOIN state st ON st.`code` = ts.`code` JOIN client c ON c.id = t.clientFk
JOIN client c ON c.id = t.clientFk JOIN state st2 ON st2.`code` = IF(t.shipped < util.VN_CURDATE(),
JOIN state st2 ON st2.`code` = IF(t.shipped < util.VN_CURDATE(), 'DELIVERED',
'DELIVERED', IF (t.shipped > util.dayEnd(util.VN_CURDATE()),
IF (t.shipped > util.dayEnd(util.VN_CURDATE()), 'FREE',
'FREE', IFNULL(ts.code, 'FREE')))
IFNULL(ts.code, 'FREE'))) LEFT JOIN claimBeginning cb ON s.id = cb.saleFk
LEFT JOIN state stPrep ON stPrep.`code` = 'PREPARED' WHERE t.shipped >= vDateInventory
LEFT JOIN saleTracking stk ON stk.saleFk = s.id AND s.itemFk = vItemFk
AND stk.stateFk = stPrep.id AND vWarehouseFk = t.warehouseFk
LEFT JOIN claimBeginning cb ON s.id = cb.saleFk ),sale AS (
WHERE t.shipped >= vDateInventory SELECT s.shipped,
AND s.itemFk = vItemFk NULL `in`,
AND vWarehouseFk =t.warehouseFk s.quantity,
ORDER BY shipped, s.alertLevel,
(inventorySupplierFk = clientFk) DESC, s.name,
alertLevel DESC, s.nickname,
isTicket, s.refFk,
`order` DESC, s.ticketFk,
isPicked DESC, s.clientFk,
`in` DESC, IF(stk.saleFk, TRUE, NULL),
`out` DESC; TRUE,
s.saleFk,
s.`order`,
s.typeFk,
s.claimFk,
NULL
FROM sales s
LEFT JOIN state stPrep ON stPrep.`code` = 'PREPARED'
LEFT JOIN saleTracking stk ON stk.saleFk = s.saleFk
AND stk.stateFk = stPrep.id
GROUP BY s.saleFk
) SELECT shipped,
`in`,
`out`,
alertLevel,
stateName,
`name`,
reference,
origin,
clientFk,
isPicked,
isTicket,
lineFk,
`order`,
clientType,
claimFk,
inventorySupplierFk
FROM entries
UNION ALL
SELECT * FROM deliveried
UNION ALL
SELECT * FROM sale
ORDER BY shipped,
(inventorySupplierFk = clientFk) DESC,
alertLevel DESC,
isTicket,
`order` DESC,
isPicked DESC,
`in` DESC,
`out` DESC;
IF vDate IS NULL THEN IF vDate IS NULL THEN