Создание приходных актов библиотеки#
Создает приходные акты и позиции документов для библиотечного модуля на основе заданного набора данных.
Место применения: Сервис > Инструменты > Выполнить JEXL-скрипт
Внимание
Скрипт привязан к объектам конкретного модуля и требует проверки на целевой базе. Перед запуском проверьте идентификаторы, SQL-запросы, API-классы и условия обработки.
Тип: JEXL-скрипт
var idvDepOwner = Bs_DepOwnerApi.findByMnemoCode("0000");
var idvPerson1 = Bs_PersonApi.findByMnemoCode("0200");
var idvPerson2 = Bs_PersonApi.findByMnemoCode("0201");
sql(`
select regexp_replace(ssystemname, 'lbr', '') as "sNum"
from btk_module bm
where ssystemname like 'lbr__'
`).foreach(function(r){
var list = [["1", 567.000000000000000000B, [["1", "978-5-04-121401-2", 3.000000000000000000B, 189.000000000000000000B, 567.000000000000000000B]]], ["2", null, [["1", "978-5-389-10222-4", 5.000000000000000000B, 450.000000000000000000B, 2250.000000000000000000B], ["2", "978-5-04-121401-2", 5.000000000000000000B, 358.000000000000000000B, 1790.000000000000000000B], ["3", "978-5-04-121401-3", 10.000000000000000000B, 635.000000000000000000B, 6350.000000000000000000B]]], ["3", null, [[null, null, null]]], ["5", 1000000.000000000000000000B, [["2", "978-5-04-119061-3", 100.000000000000000000B, 100.000000000000000000B, 10000.000000000000000000B], ["3", "978-5-389-06256-6", 100.000000000000000000B, 100.000000000000000000B, 10000.000000000000000000B], ["4", "978-5-04-121401-2", 100.000000000000000000B, 100.000000000000000000B, 10000.000000000000000000B], ["1", "978-5-04-121401-3", 100.000000000000000000B, 100.000000000000000000B, 10000.000000000000000000B], ["5", "978-5-17-063868-0", 100.000000000000000000B, 100.000000000000000000B, 10000.000000000000000000B]]]];
var apiDoc = Btk_ClassApi.getApiBySimpleClassName("Lbr" + r.sNum + "_InAct");
var apiDet = Btk_ClassApi.getApiBySimpleClassName("Lbr" + r.sNum + "_InActDet");
var apiBook = Btk_ClassApi.getApiBySimpleClassName("Lbr" + r.sNum + "_Book");
for (t : list){
var svCode = t.0;
var idv = apiDoc.findByMnemoCode(svCode);
if(idv == null){
var rop = apiDoc.insert();
apiDoc.setsNumDoc(rop, svCode);
apiDoc.setsNumDocBMs_dz(rop, 1B);
apiDoc.setnSum(rop, t.1);
apiDoc.setidLibrarian(rop, idvPerson1);
apiDoc.setidDepOwner(rop, idvDepOwner);
for (det : t.2) {
var sDetCode = det.0;
if(sDetCode != null){
var ropDet = apiDet.insertByParent(rop);
apiDet.setsNumber(ropDet, sDetCode);
apiDet.setsNumberBMs_dz(ropDet, 1B);
var idvBook = apiBook.findByMnemoCode(det.1);
if(idvBook != null){
apiDet.setidBook(ropDet, idvBook);
}
apiDet.setnQty(ropDet, det.2);
apiDet.setnPrice(ropDet, det.3);
apiDet.setnSum(ropDet, det.4);
}
}
}
}
commit();
}) ;