mirror of
https://github.com/tormozit/RDT1C.git
synced 2025-12-17 05:04:11 +00:00
*Исправлена некорректная работа команд "Найти в динамическом списке" и "Найти в основной форме списка"
*В управляемой форме исправлена свежая ошибка переключения типа таблицы со ссылочной на регистр в некоторых случаях
+При записи движений документа теперь тоже устанавливаются дополнительные свойства
*Исправлено восстановление списка последних добавленных дополнительных свойств
Общее
*Исправлено получение представлений стандартных реквизитов
Динамический список
*В управляемой форме исправлено применение пользовательских настроек списка при редактировании их в собственной форме
+В управляемой форме в настройках списка добавлена закладка "Исполняемые"
+В управляемой форме при передаче отбора во все команды теперь учитывается состояние просмотра
98 lines
4.6 KiB
Plaintext
98 lines
4.6 KiB
Plaintext
Перем _Тип Экспорт;
|
||
|
||
Процедура Конструктор(Объект) Экспорт
|
||
|
||
ЭтотОбъект.ДополнительныеСвойства = Объект.ДополнительныеСвойства;
|
||
ЭтотОбъект.ОбменДанными = ирОбщий.СтруктураОбменаДаннымиОбъектаЛкс(Объект);
|
||
ЭтотОбъект._Тип = ТипЗнч(Объект);
|
||
ОбъектМД = Объект.Метаданные();
|
||
ПоляТаблицыБД = ирОбщий.ПолучитьПоляТаблицыМДЛкс(ОбъектМД,,,, Ложь);
|
||
Данные = Новый Структура;
|
||
ПоляШапки = Новый Массив;
|
||
Для Каждого СтрокаПоля Из ПоляТаблицыБД Цикл
|
||
Данные.Вставить(СтрокаПоля.Имя);
|
||
КонецЦикла;
|
||
ЗаполнитьЗначенияСвойств(Данные, Объект);
|
||
ЭтотОбъект.Данные = Данные;
|
||
|
||
КонецПроцедуры
|
||
|
||
Функция Снимок() Экспорт
|
||
|
||
СтруктураОбъекта = Новый Структура;
|
||
СтруктураОбъекта.Вставить("ОбменДанными", ОбменДанными);
|
||
СтруктураОбъекта.Вставить("ДополнительныеСвойства", ДополнительныеСвойства);
|
||
СтруктураОбъекта.Вставить("Данные", Данные);
|
||
СтруктураОбъекта.Вставить("_Тип", _Тип);
|
||
ЗаписьJSON = Новый ЗаписьJSON;
|
||
ЗаписьJSON.УстановитьСтроку();
|
||
СериализаторXDTO.ЗаписатьJSON(ЗаписьJSON, СтруктураОбъекта, НазначениеТипаXML.Явное);
|
||
Результат = ЗаписьJSON.Закрыть();
|
||
Возврат Результат;
|
||
|
||
КонецФункции
|
||
|
||
Процедура ЗагрузитьСнимок(Снимок) Экспорт
|
||
|
||
ЧтениеJSON = Новый ЧтениеJSON;
|
||
ЧтениеJSON.УстановитьСтроку(Снимок);
|
||
СтруктураОбъекта = СериализаторXDTO.ПрочитатьJSON(ЧтениеJSON);
|
||
ЧтениеJSON.Закрыть();
|
||
ЗаполнитьЗначенияСвойств(ЭтотОбъект, СтруктураОбъекта);
|
||
|
||
КонецПроцедуры
|
||
|
||
Функция КлючОбъекта()
|
||
|
||
Результат = Неопределено;
|
||
Возврат Результат;
|
||
|
||
КонецФункции
|
||
|
||
Функция ОбъектБД() Экспорт
|
||
|
||
КлючОбъекта = КлючОбъекта();
|
||
Результат = ирОбщий.ОбъектБДПоКлючуЛкс(Метаданные.НайтиПоТипу(_Тип).ПолноеИмя(), КлючОбъекта,, Ложь).Данные;
|
||
ирОбщий.СкопироватьУниверсальнуюКоллекциюЛкс(ДополнительныеСвойства, Результат.ДополнительныеСвойства);
|
||
ирОбщий.ВосстановитьСтруктуруОбменаДаннымиОбъектаЛкс(Результат, ОбменДанными);
|
||
ЗаполнитьЗначенияСвойств(Результат, Данные);
|
||
Возврат Результат;
|
||
|
||
КонецФункции
|
||
|
||
Процедура Прочитать(НаСервере = Истина) Экспорт
|
||
|
||
Если НаСервере Тогда
|
||
Снимок = Снимок();
|
||
ирСервер.ПрочитатьОбъектЧерезИмитаторЛкс(Снимок, ТипЗнч(ЭтотОбъект));
|
||
ЗагрузитьСнимок(Снимок);
|
||
Иначе
|
||
ОбъектБД = ОбъектБД();
|
||
ОбъектБД.Прочитать();
|
||
Конструктор(ОбъектБД);
|
||
КонецЕсли;
|
||
|
||
КонецПроцедуры
|
||
|
||
Функция Записать() Экспорт
|
||
|
||
#Если Не Сервер Тогда
|
||
Снимок = Снимок();
|
||
ирСервер.ЗаписатьОбъектXMLЛкс(Снимок,,,,,, ТипЗнч(ЭтотОбъект));
|
||
ЗагрузитьСнимок(Снимок);
|
||
#Иначе
|
||
ОбъектБД = ОбъектБД();
|
||
ОбъектБД.Записать();
|
||
Конструктор(ОбъектБД);
|
||
#КонецЕсли
|
||
|
||
КонецФункции
|
||
|
||
Процедура ОбработкаПроверкиЗаполнения(Отказ, ПроверяемыеРеквизиты)
|
||
|
||
ОбъектБД = ОбъектБД();
|
||
Отказ = Не ОбъектБД.ПроверитьЗаполнение();
|
||
Конструктор(ОбъектБД);
|
||
|
||
КонецПроцедуры
|