Сохранение настроек колонок

10.07.20

Разработка - Работа с интерфейсом

Сохранение настроек колонок табличных полей. Получение имени формы из модуля формы. Для обычных форм.

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
Сохранение настроек колонок:
.cf 82,81Kb
3 1 850 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Недавно ко мне обратились с жалобой на то, что установленная пользователем ширина колонки в табличном поле не сохраняется. С удивлением обнаружил, что да, так случается. В том случае, когда пользователь изменяет ширину не двигая границу мышкой, а через настройку списка при повторном открытии формы ширина колонок сбрасывается в дефолтную. Не каждый раз, что-то похоже еще влияет, но часто.

Кроме того, я достаточно часто использую колонки, добавляемые программно. Сохранение их позиции и размера я прописывал для каждого конкретного случая. А оказалось, что сохранять нужно всё и везде. В всяком случае во всех формах, на которые жалуются клиенты.

Возникла необходимость написания универсальной процедуры сохранения-восстановления. Далее предлагаю очередной велосипед. Особенность предлагаемых процедур в том, что достаточно просто вставить вызов в процедуры обработки событий открытия и закрытия формы. То есть не писать имен табличных частей, не перечислять колонки, не придумывать название для сохраняемых настроек, просто вызвать процедуру с параметром ЭтаФорма.

Для этого понадобилось выяснить имя открытой формы. Как оказалось, платформа такой функции не предлагает. Получилось следуещее:

Функция ПолучитьИмяНастроек(Форма)
	Результат = "НастройкиКолонок."+Форма.Метаданные().ПолноеИмя();
	Для Каждого Элемент Из Форма.Метаданные().Формы Цикл
		Если Форма.ЭтотОбъект.ПолучитьФорму(Элемент.Имя)=Форма Тогда
			Результат = Результат+"."+Элемент.Имя;
			Прервать;
		КонецЕсли;	
	КонецЦикла;	
	Возврат Результат;
КонецФункции

Перебираем формы в метаданных объекта, получаем каждую и проверяем, не совпала ли она с нашей открытой формой.

Далее мой вариант сохранения и восстановления настроек. Сохраняются настройки всех табличных полей. Если вдруг зачем-то какие-то поля запоминать не нужно, можно передать в процедуру массив имен табличных полей. Не знаю, зачем это может пригодится, но пусть будет. 

Процедура Сохранить(Форма,ИменаТабличныхПолей = Неопределено) Экспорт
	Настройки = Новый Структура;
	Для Каждого Элемент Из Форма.ЭлементыФормы Цикл
		Если Тип(Элемент)=Тип("ТабличноеПоле") Тогда
			Если Тип(ИменаТабличныхПолей)=Тип("Массив") Тогда
				Если ИменаТабличныхПолей.Найти(Элемент.Имя)=Неопределено Тогда
					Продолжить;
				КонецЕсли;	
			КонецЕсли;	
			ТабКолонок = Новый ТаблицаЗначений;
			ТабКолонок.Колонки.Добавить("Имя");
			ТабКолонок.Колонки.Добавить("Позиция");
			ТабКолонок.Колонки.Добавить("Видимость");
			ТабКолонок.Колонки.Добавить("Ширина");		
			Для Каждого Колонка Из Элемент.Колонки Цикл
				Стр = ТабКолонок.Добавить();
				Стр.Имя = Колонка.Имя;
				Стр.Позиция = Элемент.Колонки.Индекс(Колонка);
				Стр.Видимость = Колонка.Видимость;
				Стр.Ширина = Колонка.Ширина;
			КонецЦикла;	
			ТабКолонок.Сортировать("Позиция");
			Настройки.Вставить(Элемент.Имя,ТабКолонок);
		КонецЕсли;	
	КонецЦикла;	
	Если Настройки.Количество()>0 Тогда
		СохранитьЗначение(ПолучитьИмяНастроек(Форма),Настройки);
	КонецЕсли;
КонецПроцедуры	

Процедура Восстановить(Форма) Экспорт
	Настройки = ВосстановитьЗначение(ПолучитьИмяНастроек(Форма));
	Если Настройки=Неопределено Тогда
		Возврат;
	КонецЕсли;	
	Попытка 
		Для Каждого Элемент Из Форма.ЭлементыФормы Цикл
			Если Тип(Элемент)=Тип("ТабличноеПоле") Тогда
				ТабКолонок = Неопределено;
				Если Настройки.Свойство(Элемент.Имя,ТабКолонок) Тогда
					Для Каждого Стр Из ТабКолонок Цикл
						Колонка = Элемент.Колонки.Найти(Стр.Имя);
						Если Колонка <> Неопределено Тогда
							ТекущаяПозиция = Элемент.Колонки.Индекс(Колонка);
							Элемент.Колонки.Сдвинуть(ТекущаяПозиция,Стр.Позиция-ТекущаяПозиция);
							Колонка.Видимость = Стр.Видимость;
							Колонка.Ширина = Стр.Ширина;	
						КонецЕсли;
					КонецЦикла;	
				КонецЕсли;		
			КонецЕсли;		
		КонецЦикла;	
	Исключение  // Отрабатываем в том случае, если в настройках хранится что-то не то
		Сохранить(Форма);
	КонецПопытки;
КонецПроцедуры	

Всё это помещается в общий модуль и остаётся только добавить вызовы в модуль формы:

Процедура ПередОткрытием(Отказ, СтандартнаяОбработка)

	НастройкиКолонок.Восстановить(ЭтаФорма);

КонецПроцедуры

Процедура ПередЗакрытием(Отказ, СтандартнаяОбработка)

	НастройкиКолонок.Сохранить(ЭтаФорма);

КонецПроцедуры

И всё. Единственное, на что следует обратить внимание, вызов процедуры сохранения нужно делать по событию ПередЗакрытием. Если вызвать из ПриЗакрытии, форма уже будет закрыта, узнать имя формы не получится и наименование для настроек сгенерируется неправильно.

В демонстрационной конфигурации есть модуль НастройкиКолонок и тестовая обработка в которой он используется. Можно попробовать поменять настройки колонок через настройки списка и увидеть, что сохраняются они не всегда. Впрочем всё, что нужно изложено выше и скачивать конфигурацию необязательно )

Протестировано на релизе платформы 1С:Предприятие 8.3 (8.3.16.1063).

Вступайте в нашу телеграмм-группу Инфостарт

См. также

Работа с интерфейсом Анализ учета Мониторинг 1С:Предприятие 8 1С 8.3 1C:Бухгалтерия 1С:Бухгалтерия 3.0 1С:Библиотека стандартных подсистем 1С:ERP Управление предприятием 2 1С:Управление холдингом 1С:Зарплата и Управление Персоналом 3.x 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Управление торговлей 11 Платные (руб)

Создайте свой функциональный интерфейс в любой конфигурации 1С с помощью расширения Infostart Dashboard. Настраивайте панели виджетов с метриками, индикаторами и показателями на начальном экране. Узнайте возможность внедрения подсистемы у себя в конфигурации с помощью бесплатной обработки "Анализ внедрения подсистемы 1С Infostart Dashboard"!

28800 руб.

27.03.2025    56402    31    25    

45

Разработка Инструментарий разработчика Работа с интерфейсом Адаптация типовых решений Нейросети 1C:Бухгалтерия 1C:ERP 1С:ЗУП 1С:КА 1С:УНФ 1С:УТ 1С:Розница 1С:ДО 1С:ERP Управление предприятием 2 Платные (руб)

Разработка "Дизайнер форм 1С" реализована в виде расширения 1С и является универсальным инструментом для разработки прототипа форм с целью демонстраций, технических заданий и т.д. Без участия разработчика с возможностью экспорта в файл внешней обработки и генерации формы используя искусственный интеллект.

36000 руб.

28.08.2025    2702    1    2    

4

Работа с интерфейсом Системный администратор Программист 1С:Предприятие 8 1C:Бухгалтерия Платные (руб)

Расширение «Динамическое управление доступом к элементам форм объектов 1С8» предназначен для обеспечения возможности оперативного управления видимостью и доступностью элементов форм документов и справочников продуктов фирмы «1С» «1С:Предприятие 8». Решение универсальное, встраивается в любую конфигурацию с минимальными доработками, что позволяет без проблем обновлять типовые решения.

6000 руб.

14.01.2016    58241    20    25    

46

Работа с интерфейсом Программист 1С:Предприятие 8 1C:Бухгалтерия 1С:ERP Управление предприятием 2 Платные (руб)

Обработка предназначена для создания и управления дашбордами (виджетами) в 1С.

5160 руб.

29.06.2020    22865    32    6    

51

Работа с интерфейсом Программист 1С:Предприятие 8 1C:Бухгалтерия Россия Платные (руб)

Редактор графов в 1С - внешний отчет, который формирует графы на основе таблицы значений, используя рисунки табличного документа. Есть возможность добавления, редактирования объектов графа и выгрузки результата в таблицу значений.

5040 руб.

06.10.2020    12852    8    8    

14

Универсальные функции Программист 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

Благодаря этим пяти строчкам можно больше не заморачиваться с загрузкой из внешних файлов. Пользуюсь везде, всегда и постоянно.

21.05.2024    46517    dimanich70    83    

165

WEB-интеграция Универсальные функции Механизмы платформы 1С Программист 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

При работе с интеграциями рано или поздно придется столкнуться с получением JSON файлов. И, конечно же, жизнь заставит проверять файлы перед тем, как записывать данные в БД.

28.08.2023    22846    YA_418728146    8    

174
Для отправки сообщения требуется регистрация/авторизация