Создание приходных актов библиотеки

Создание приходных актов библиотеки#

Создает приходные акты и позиции документов для библиотечного модуля на основе заданного набора данных.

Место применения: Сервис > Инструменты > Выполнить 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();
}) ;