AXForum  
Вернуться   AXForum > Microsoft Dynamics NAV > NAV: Программирование
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 14.11.2005, 17:48   #21  
Kirvisniemi is offline
Kirvisniemi
Moderator
 
342 / 13 (1) ++
Регистрация: 21.12.2004
Если кому интересно, расскажу как все удалось реализовать.

Т.к. в ходе экспериментов выяснилось, что не все кодюниты постят данные в G/L Entry через кодюнит 12, пришлось пойти единственным верным путем - повесится на триггер OnInsert таблицы G/L Entry.

Шаг 1. Поскольку во всех стандартных модулях, работающих с таблицей G/L в коде написан просто INSERT, наш код в триггере OnInsert вызываться не будет. Следовательно везде нужно поменять INSERT на INSERT(TRUE).
Я сделал просто - выгрузил все кодюниты в txt-файл и поиском нашел все переменные, ссылающиеся на G/L (это просто - достаточно поискать строку ":record 17;"). Переменных оказалось не много, а уж кодюнитов, осуществляющих непосредственную работу с G/L и вовсе всего три:
12 (Gen. Jnl.-Post Line),
413 (AnalysisViewEntryToGLEntries) и
432 (Consolidate).
Во всех них я подправил INSERT на INSERT(TRUE)

Шаг 2. Поскольку для отката транзакции нужно было выбрать место до которого уже сформировались все проводки, кодюнит 12 для этих не подошел. Пришлось вставлять тривиальный ERROR('') в четыре кодюнита:
80 (Sales-Post),
90 (Purch.-Post),
5704 (TransferOrder-Post Shipment) и
5705 (TransferOrder-Post Receipt)
Последние два нужны только для учета перемещений.
Имейте ввиду, что 80 и 90 кодюниты напичканы COMMIT'ами и перед каждым нужно поставить проверку флага "Режим будущих проводок". В режиме будущих проводок ничего коммитится не должно.

Шаг 3. Т.к для хранения будущих транзакций нельзя было использовать таблицу (потому что при откате транзакции все записи сразу были бы стерты), пришлось выбирать из двух вариантов - либо использовать кодюнит с SingleInstance=Yes, либо писать проводки в файл. И тот и другой способы имеют свои достоинства и недостатки. Я решил остановиться на кодюните и сохранять данные в массиве. Этот же кодюнит по совместительству выполняет функцию хранению флага "Режим будущих проводок" для текущего юзера.

Шаг 4. Во все нужные документы я добавил новый пункт меню "Просмотр будущих проводок". Код остался точно такое же как и при учете. До него добавил выставление флага "Режим будущих проводок"

Шаг 5. На этом шаге получился полнофункциональный механизм отслеживания будущих проводок, за исключением вывода результатов пользователю. Для вывода я решил использовать REPORT. Репорту пришлось передавать временную таблицу с будущими проводками, а т.к. репорт с врем.таблицами в принципе не работает, таблицу пришлось передавать через функцию, а репорт организовывать через Integer.

Что имеем в результате:
работающий механизм просмотра будущих проводок, не блокирующий работу и даже имеющий поддержку будущего функционала (если будут писать INSERT(TRUE)
 


Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 05:00.