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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 03.02.2012, 09:36   #1  
DesertBrowser is offline
DesertBrowser
Участник
 
55 / 10 (1) +
Регистрация: 04.08.2010
Angry Фиксация изменённых данных вызывающей формы до её обновления
Добрый день!

Ситуация:
есть основная форма - т.н. форма "шапки" документа, и форма строк, вызываемая из неё. При изменениях в строках происходит переформирование текстового поля с комментарием в таблице шапки. Сразу после изменения этого поля форма шапки (вызывающая) обновляется. Но при этом возникает проблема: иногда пользователь, не закрывая формы строк, переключается из неё в форму шапки и производит в ней изменения. А после правки данных в форме строк шапка обновляется, и последние изменения теряются. Каким образом можно перед обновлением шапки зафиксировать её изменения?
X++:
void updateTableForm(bom _bom)
{
    args            args;
    FormObjectSet   fos;
    BOMTable        bt;
    ;
    if (_bom.dataSource())
    {
        if (_bom.dataSource().formRun().args())
        {
            args = _bom.dataSource().formRun().args();
            fos = args.record().dataSource();
            bt = args.record();//здесь неизменённые значения, как и в fos.cursor()

            bt.reread();
            fos.refresh();
        }
    }
}
MS Ax 3.0 SP 3 MS SQL Server 2000
Старый 03.02.2012, 10:00   #2  
ice is offline
ice
Участник
Аватар для ice
Лучший по профессии 2014
 
1,763 / 404 (17) +++++++
Регистрация: 23.03.2006
Зачем изменять шапку до сохранения изменений на строках?
Старый 03.02.2012, 10:07   #3  
DesertBrowser is offline
DesertBrowser
Участник
 
55 / 10 (1) +
Регистрация: 04.08.2010
Шапку изменяют, если забыли заполнить/неправильно заполнили какое-либо поле.
Старый 03.02.2012, 10:49   #4  
ice is offline
ice
Участник
Аватар для ice
Лучший по профессии 2014
 
1,763 / 404 (17) +++++++
Регистрация: 23.03.2006
при открытой формы строк блокируйте изменения в шапке как в складских журналах
Старый 03.02.2012, 10:52   #5  
S.Kuskov is offline
S.Kuskov
Участник
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
 
3,440 / 1775 (66) ++++++++
Регистрация: 28.04.2007
Адрес: Калуга
По идее при потере гридом фокуса ввода изменённые данные должны сохранится в БД. В случае ошибки сохранения фокус ввода должен остатся на несохранённых данных.
Каким образом у вас пользователь после редактирования шапки документа переходит на форму строк без сохранения изменённых данных?
Старый 03.02.2012, 10:58   #6  
DesertBrowser is offline
DesertBrowser
Участник
 
55 / 10 (1) +
Регистрация: 04.08.2010
Пользователь не открывает форму строк - она уже открыта. Он переключается из одной открытой формы (строк) вначале в форму шапки, не закрывая строки. Потом обратно, из шапки в форму строк. Запись при этом не сохраняется - никаких попыток сохранения не происходит, соответственно и ошибок тоже нет. Фокус в форме шапки остаётся там, где он был до переключения в строки.
Старый 03.02.2012, 11:03   #7  
Владимир Максимов is offline
Владимир Максимов
Участник
КОРУС Консалтинг
 
1,701 / 1195 (43) ++++++++
Регистрация: 13.01.2004
Записей в блоге: 3
Как мне кажется, ответ очевиден. Сначала выполнить сохранение в родительской форме, и только потом обновление. Примерно так

X++:
fos.write();   // Вот это добавить
fos.reread();
fos.refresh();
Собственно, я бы сделал на родительской форме отдельный метод, котрый все это будет делать и вызывал бы его из подчиненной по мере необходимости.

X++:
Object callerForm;

callerForm = args.caller();
if (formHasMethod(callerForm,"MyMethod"))
{
    callerForm.MyMethod();
}
Можно передавать в этом метод в качестве параметра новое значение комментария (или ту часть, которую надо добавить). Тогда все изменения в родительской форме будут выполняться непосредственно самой формой.
__________________
- Может, я как-то неправильно живу?!
- Отчего же? Правильно. Только зря...
За это сообщение автора поблагодарили: S.Kuskov (1).
Старый 03.02.2012, 11:19   #8  
DesertBrowser is offline
DesertBrowser
Участник
 
55 / 10 (1) +
Регистрация: 04.08.2010
Это было первое, что я попробовала, до того как открыла эту ветку на форуме. Эффекта ни write на DS, ни update на record не имеют. Т.к. новые - т.е. изменённые пользователем данные - в них не попадают.

Последний раз редактировалось DesertBrowser; 03.02.2012 в 11:25.
Старый 03.02.2012, 13:28   #9  
CDR is offline
CDR
MCTS
MCBMSS
 
236 / 175 (6) ++++++
Регистрация: 27.11.2003
В вызываемой дочерней форме строк объявите табличную переменную parentTable того же типа, что и главная таблица из родительской формы. При открытии дочерней формы в inite свяжите ее с курсором родительской формы (parentTable = element.args().record() ).

Обязательно проверьте, чтобы в дочерней форме эта переменная больше нигде не переприсваивалась и не перевыбиралась из БД, это важно!

При сохранении текущей записи (именно при сохранении, а не при изменении поля !!!) в дочерней форме формируйте нужный комментарий, просто записывайте его в поле табличной переменной (parentTable.comment = 'comment'), а затем

parentTable.dataSource().write().
parentTable.dataSource().refresh().

Естественно, запись в оба датасоурса должна быть в одной транзакции.
Если сделаете все правильно, то все должно работать.
__________________
Dynamics AX Experience
Теги
datasource, form, formrun, update, write, как правильно

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
разная скорость отработки display методов на источнике данных формы wojzeh DAX: Программирование 10 05.05.2008 23:53
Изменение свойства Table источника данных формы vasiliy DAX: Программирование 6 26.04.2005 12:16
Обновление данных формы из другой формы DiZ DAX: Программирование 4 14.10.2004 11:39
Метод findValue у источника данных формы demID DAX: Программирование 3 01.10.2004 10:19
Русская локализация Axapta 3 ? SlavaK DAX: Администрирование 59 01.07.2003 22:38

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

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

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