2024-01-15 11:31:03 +00:00
|
|
|
DELIMITER $$
|
2024-08-20 08:06:10 +00:00
|
|
|
CREATE OR REPLACE DEFINER=`vn`@`localhost` TRIGGER `vn`.`sale_afterInsert`
|
2024-01-15 11:31:03 +00:00
|
|
|
AFTER INSERT ON `sale`
|
|
|
|
FOR EACH ROW
|
|
|
|
BEGIN
|
|
|
|
IF (SELECT COUNT(*) from item i WHERE id = NEW.itemFk AND family = 'SER') THEN
|
|
|
|
CALL util.throw('Cannot insert a service item into a ticket');
|
|
|
|
END IF;
|
|
|
|
|
|
|
|
IF NEW.quantity > 0 THEN
|
|
|
|
UPDATE vn.collection c
|
|
|
|
JOIN vn.ticketCollection tc ON tc.collectionFk = c.id
|
|
|
|
AND tc.ticketFk = NEW.ticketFk
|
|
|
|
JOIN vn.item i ON i.id = NEW.itemFk
|
|
|
|
AND (c.itemPackingTypeFk = i.itemPackingTypeFk
|
|
|
|
OR c.itemPackingTypeFk IS NULL)
|
|
|
|
SET c.saleTotalCount = c.saleTotalCount + 1;
|
|
|
|
|
|
|
|
INSERT IGNORE INTO `vn`.`routeRecalc` (`routeFk`)
|
|
|
|
SELECT r.id
|
|
|
|
FROM vn.sale s
|
|
|
|
JOIN vn.ticket t ON t.id = s.ticketFk
|
|
|
|
JOIN vn.route r ON r.id = t.routeFk
|
|
|
|
WHERE r.isOk = FALSE
|
|
|
|
AND s.id = NEW.id
|
|
|
|
AND r.created >= util.VN_CURDATE()
|
|
|
|
GROUP BY r.id;
|
|
|
|
END IF;
|
|
|
|
END$$
|
|
|
|
DELIMITER ;
|