Форма универсального отбора и сортировки для таблицы значений (обычные формы)

26.03.16

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

Обычная форма, с помощью которой можно произвести отбор и сортировку в таблице значений.

Скачать исходный код

Наименование Файл Версия Размер
Форма универсально отбора и сортировки
.epf 10,99Kb
44
.epf 10,99Kb 44 Скачать

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

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

	ИменаПолейОтбора = "Колонка1;Колонка2;Колонка3;Колонка4;Колонка5;Колонка6;Колонка7;Колонка8;Колонка9;Колонка10;Колонка11;Колонка12";
	
	НастройкиОтбора = Новый Структура;
	НастройкиОтбора.Вставить("ИменаПолейОтбора", ИменаПолейОтбора);
	НастройкиОтбора.Вставить("ИменаПолейСортировки", ИменаПолейОтбора);
	НастройкиОтбора.Вставить("ТабДанные", ТабЗнач);
	НастройкиОтбора.Вставить("ЗаголовокФормы", "Настройте отбор таблицы значений");
	
	ФормаУО = Обработки.ФормаУниверсальногоОтбора.ПолучитьФорму("ФормаУниверсальногоОтбора");
	ФормаУО.НастройкиОтбора = НастройкиОтбора;
	ТабДанные = ФормаУО.ОткрытьМодально();
	Если ТабДанные <> Неопределено Тогда
		ТабЗнач.Очистить();
		Для каждого ТекСтр Из ТабДанные Цикл
			НовСтр = ТабЗнач.Добавить();
			ЗаполнитьЗначенияСвойств(НовСтр, ТекСтр);
		КонецЦикла; 
	КонецЕсли;

Набор элементов для каждого поля отбора создается программно.

ПанельДляЭлементов = ЭлементыФормы.Панель1;
	ВертИнтервал = 3;
	
	//флажок
	НовыйФлажок = ЭлементыФормы.Добавить(Тип("Флажок"), "фл" + ИмяКолонки, Истина, ПанельДляЭлементов);
	НовыйФлажок.Лево = 8;
	НовыйФлажок.Ширина = 131;
	НовыйФлажок.Высота = 19;
	НовыйФлажок.Верх = 6 + (19 + ВертИнтервал) * НомерЭлемента;
	НовыйФлажок.Заголовок = Заголовок;
	
	//вид сравнения заполняем в зависимости от типа данных 
	СписокВидовСравнения = СформироватьСписокВидовСравнения(ТипЗначения);
	НовыйВидСравнения = ЭлементыФормы.Добавить(Тип("ПолеВвода"), "ВидСравнения" + ИмяКолонки, Истина, ПанельДляЭлементов);
	НовыйВидСравнения.ТипЗначения = Новый ОписаниеТипов("ВидСравнения");
	НовыйВидСравнения.РежимВыбораИзСписка = Истина;
	НовыйВидСравнения.СписокВыбора = СписокВидовСравнения;
	НовыйВидСравнения.КнопкаВыбора = Ложь;
	НовыйВидСравнения.Лево = 144;
	НовыйВидСравнения.Ширина = 111;
	НовыйВидСравнения.Высота = 19;
	НовыйВидСравнения.Верх = 6 + (19 + ВертИнтервал) * НомерЭлемента;
    НовыйВидСравнения.УстановитьДействие("ПриИзменении", Новый Действие("ПриИзмененииПоляВидаСравнения"));
	
	//поле значения
	//для типов дата и число, создаем изначально два поля, но одно из них делаем невидимым
	Если ЕстьТипЧислоДата(ТипЗначения) Тогда
		НовоеПолеЗначения = ЭлементыФормы.Добавить(Тип("ПолеВвода"), "ПолеЗначения" + ИмяКолонки, Истина, ПанельДляЭлементов);
		НовоеПолеЗначения.ТипЗначения = ТипЗначения;
		НовоеПолеЗначения.Лево = 260;
		НовоеПолеЗначения.Ширина = 120;
		НовоеПолеЗначения.Высота = 19;
		НовоеПолеЗначения.Верх = 6 + (19 + ВертИнтервал) * НомерЭлемента;
		Если ЭтоСоставнойТип(ТипЗначения) Тогда
			НовоеПолеЗначения.ВыбиратьТип = Истина;
			НовоеПолеЗначения.КнопкаВыбора = Истина;
			НовоеПолеЗначения.КнопкаОчистки = Истина;
		КонецЕсли; 
		НовоеПолеЗначения.УстановитьДействие("ПриИзменении", Новый Действие("ПриИзмененииПоляПолеЗначения"));
		
		НовоеПолеЗначения = ЭлементыФормы.Добавить(Тип("ПолеВвода"), "ПолеЗначения2" + ИмяКолонки, Ложь, ПанельДляЭлементов);
		НовоеПолеЗначения.ТипЗначения = ТипЗначения;
		НовоеПолеЗначения.Лево = 385;
		НовоеПолеЗначения.Ширина = 120;
		НовоеПолеЗначения.Высота = 19;
		НовоеПолеЗначения.Верх = 6 + (19 + ВертИнтервал) * НомерЭлемента;
		Если ЭтоСоставнойТип(ТипЗначения) Тогда
			НовоеПолеЗначения.ВыбиратьТип = Истина;
			НовоеПолеЗначения.КнопкаВыбора = Истина;
			НовоеПолеЗначения.КнопкаОчистки = Истина;
		КонецЕсли; 
		НовоеПолеЗначения.УстановитьДействие("ПриИзменении", Новый Действие("ПриИзмененииПоляПолеЗначения"));
	Иначе	
		НовоеПолеЗначения = ЭлементыФормы.Добавить(Тип("ПолеВвода"), "ПолеЗначения" + ИмяКолонки, Истина, ПанельДляЭлементов);
		НовоеПолеЗначения.ТипЗначения = ТипЗначения;
		НовоеПолеЗначения.Лево = 260;
		НовоеПолеЗначения.Ширина = 245;
		НовоеПолеЗначения.Высота = 19;
		НовоеПолеЗначения.Верх = 6 + (19 + ВертИнтервал) * НомерЭлемента;
		Если ЭтоСоставнойТип(ТипЗначения) Тогда
			НовоеПолеЗначения.ВыбиратьТип = Истина;
			НовоеПолеЗначения.КнопкаВыбора = Истина;
			НовоеПолеЗначения.КнопкаОчистки = Истина;
		КонецЕсли; 
		НовоеПолеЗначения.УстановитьДействие("ПриИзменении", Новый Действие("ПриИзмененииПоляПолеЗначения"));
	КонецЕсли;

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

Процедура ДобавитьВидыСравненияПоТипу(СписокВидовСравнения, ТипЗначения)
	Если ТипЗначения = Тип("Строка") Тогда
		СписокВидовСравнения.Добавить(ВидСравнения.Содержит);
		СписокВидовСравнения.Добавить(ВидСравнения.НеСодержит);
	ИначеЕсли ТипЗначения = Тип("Дата") 
		ИЛИ ТипЗначения = Тип("Число") Тогда 	
		СписокВидовСравнения.Добавить(ВидСравнения.Больше);
		СписокВидовСравнения.Добавить(ВидСравнения.БольшеИлиРавно);
		СписокВидовСравнения.Добавить(ВидСравнения.Меньше);
		СписокВидовСравнения.Добавить(ВидСравнения.МеньшеИлиРавно);
		
		СписокВидовСравнения.Добавить(ВидСравнения.Интервал);
		СписокВидовСравнения.Добавить(ВидСравнения.ИнтервалВключаяГраницы);
		СписокВидовСравнения.Добавить(ВидСравнения.ИнтервалВключаяНачало);
		СписокВидовСравнения.Добавить(ВидСравнения.ИнтервалВключаяОкончание);
	Иначе
		МетаданныеТипа = Метаданные.НайтиПоТипу(ТипЗначения);
		//если тип - иерархический справочник
		Если МетаданныеТипа <> Неопределено Тогда 
        	МассивФрагментов = ЛксПолучитьМассивИзСтрокиСРазделителем(МетаданныеТипа.ПолноеИмя());
			Если МассивФрагментов.Количество() И МассивФрагментов[0] = "Справочник" 
				И МетаданныеТипа.Иерархический Тогда 
				СписокВидовСравнения.Добавить(ВидСравнения.ВИерархии);
				СписокВидовСравнения.Добавить(ВидСравнения.НеВИерархии);				
			КонецЕсли;
		КонецЕсли;	
	КонецЕсли; 	
КонецПроцедуры

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

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

Процедура ОсновныеДействияФормыкнУстановитьОтбор(Кнопка)
	Запрос = Новый Запрос;
	
	//формируем условие отбора
	СтрУсловийОтбора = "";
	Для каждого ТекПоле Из ПереченьПолейОтбора Цикл
		//проверим что установлен флаг, отбирать по данному полю
		Если ЭлементыФормы["фл" + ТекПоле].Значение Тогда
			СтрУсловийОтбора = СтрУсловийОтбора + ?(ЗначениеЗаполнено(СтрУсловийОтбора), " И ", "")
				+ ПолучитьУсловиеЗапроса(ТекПоле);
			Если ЭлементыФормы["ВидСравнения" + ТекПоле].Значение = ВидСравнения.Содержит 
				ИЛИ	ЭлементыФормы["ВидСравнения" + ТекПоле].Значение = ВидСравнения.НеСодержит Тогда
				Запрос.УстановитьПараметр(ТекПоле, "%" + ЭлементыФормы["ПолеЗначения" + ТекПоле].Значение + "%");	
				Если ЭлементыФормы.Найти("ПолеЗначения2" + ТекПоле) <> Неопределено Тогда
					Запрос.УстановитьПараметр("" + ТекПоле + "2", "%" + ЭлементыФормы["ПолеЗначения2" + ТекПоле].Значение + "%");
				КонецЕсли;
			Иначе	
				Запрос.УстановитьПараметр(ТекПоле, ЭлементыФормы["ПолеЗначения" + ТекПоле].Значение);	
				Если ЭлементыФормы.Найти("ПолеЗначения2" + ТекПоле) <> Неопределено Тогда
					Запрос.УстановитьПараметр("" + ТекПоле + "2", ЭлементыФормы["ПолеЗначения2" + ТекПоле].Значение);
				КонецЕсли;
			КонецЕсли; 	
		КонецЕсли; 
	КонецЦикла; 
	
	//формируем условие сортировки
	СтрУсловийСортировки = "";
	Если СписокВыбранныеПоля.Количество() Тогда
		Для каждого ТекКолонка Из СписокВыбранныеПоля Цикл
			СтрУсловийСортировки = СтрУсловийСортировки + ?(ЗначениеЗаполнено(СтрУсловийСортировки), ", ", "")
				+ ТекКолонка.Значение;
		КонецЦикла; 
	КонецЕсли; 
	
	//ничего делать не нужно
	Если НЕ(ЗначениеЗаполнено(СтрУсловийОтбора) 
		ИЛИ ЗначениеЗаполнено(СтрУсловийСортировки)) Тогда
		
		ЭтаФорма.Закрыть(Неопределено);
	КонецЕсли; 
	
	СтрПоляТаблицы = "";
	Для каждого ТекКолонка Из ТабДанные.Колонки Цикл
		СтрПоляТаблицы = СтрПоляТаблицы + "ТабДанные." + ТекКолонка.Имя + " КАК " + ТекКолонка.Имя + ", "
	КонецЦикла; 
	СтрПоляТаблицы = Лев(СтрПоляТаблицы, СтрДлина(СтрПоляТаблицы) - 2); 
		
	ТекстЗапроса = "ВЫБРАТЬ " 
		+ СтрПоляТаблицы 
		+ " ПОМЕСТИТЬ втТабДанные 
		|ИЗ &ТабДанные КАК ТабДанные
		|;
		|ВЫБРАТЬ "
		+ СтрПоляТаблицы 
		+ " ИЗ втТабДанные КАК ТабДанные "
		+ ?(ЗначениеЗаполнено(СтрУсловийОтбора), " ГДЕ " + СтрУсловийОтбора, "")
		+ ?(ЗначениеЗаполнено(СтрУсловийСортировки), " УПОРЯДОЧИТЬ ПО " + СтрУсловийСортировки, "")
		;  
			
	Запрос.Текст = ТекстЗапроса;	
	Запрос.УстановитьПараметр("ТабДанные", ТабДанные);
	ТабДанные = Запрос.Выполнить().Выгрузить();
	
	ЭтаФорма.Закрыть(ТабДанные);
КонецПроцедуры

Возможно, эта обработка кому и поможет. 

UPD (26/03/2016): Для дат при выборе вида сравнения интервал, добавил кнопку выбора периода.


отбор сортировка обычные формы

См. также

Богатый редактор картинок, хранимых в базе, с возможностью РИСОВАНИЯ. Редактор внешних файлов картинок. Объект, расширяющий возможности работы с картинками из встроенного языка (Три в одном) + Обработка «Стандартизация картинок»

Работа с интерфейсом Рабочее место Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Платные (руб)

Обработка предназначена для редактирования картинок в режиме «Предприятие», с возможностью РИСОВАТЬ на них. Поддерживается работа как в обычных формах (толстый клиент) так и на управляемых формах (тонкий клиент). Обработка позволяет редактировать как картинки, хранимые в базе, так и графические файлы с диска на файловой системе. Помимо базовых функций (изменение размеров, преобразование формата, обрезание картинки, повороты и т.п.) – редактор имеет богатый набор инструментов для рисования. Доступна функция вставки изображения из буфера обмена. Также обработка может быть использована из встроенного языка как объект для редактирования картинок. Объект может быть использован: на стороне клиента, на стороне сервера, из внешнего соединения. Данная обработка будет особенно полезна тем, кто вносит картинки в базу (изображения номенклатуры, фотографии физических лиц и т.п.). Функционал реализуется с использованием JavaScript и бесплатного ПО ImageMagick (без использования внешних компонент).

6000 руб.

16.01.2015    61971    43    59    

81

[Расширения] Динамическое управление видимостью и доступностью элементов форм (УФ) (8.3.6+)

Работа с интерфейсом Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Платные (руб)

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

5000 руб.

14.01.2016    54599    16    21    

42

Управление дашбордами

Работа с интерфейсом Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

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

2400 руб.

29.06.2020    16849    21    4    

35

Новогоднее оформление для 1С

Работа с интерфейсом Платформа 1С v8.3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 Бесплатно (free)

Добавьте новогоднего настроения! Расширение создает декорацию в виде гирлянды на некоторых формах объектов.

27.12.2023    11036    757    elcoan    45    

106

Конструктор HTML, CSS и javascript

Инструментарий разработчика Работа с интерфейсом Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

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

2 стартмани

10.04.2023    9809    153    acces969    31    

119

Модель состояния для MVC

Работа с интерфейсом Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

"MVC плохо применима в 1С" - познакомьтесь с моделью состояния и, возможно, ваше мнение поменяется! Представленное решение является эволюционным развитием идеи реализации MVC для 1С. В новой версии добавлены DSL для описания модели состояния, а также параметризация свойств параметров и элементов формы.

1 стартмани

05.07.2022    3867    kalyaka    4    

29

Табло очереди заказов на экран телевизора

WEB-интеграция Работа с интерфейсом Платформа 1С v8.3 1С:Розница 2 Платные (руб)

Связка из веб-приложения и расширения для 1С: Розница 2.3.

3600 руб.

29.04.2022    12228    1    5    

10
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. tormozit 7140 05.10.15 21:22 Сейчас в теме
Посмотри в инструментах разработчика на менеджер табличного поля. Думаю тебе понравится.
+
2. vinni_pooh 17 05.10.15 23:33 Сейчас в теме
Согласен, по табличной части вопросов то нет и изначально их небыло. А вот по таблице значений, в которой колонки могут быть программно добавлены, сей инструмент не справляется. Но каждому свое.
+
3. tormozit 7140 06.10.15 00:48 Сейчас в теме
(2) В чем выражается "не справляется"? Вероятно ты открывал таблицу значений в режиме ТолькоПросмотр и поэтому не видел доступных настроек сортировки.
+
4. vinni_pooh 17 06.10.15 00:57 Сейчас в теме
(3) tormozit,
И отбор ? И сортировка по нескольким полям? Признаю, возможно я чего то не знаю и в таблице значений, размещенной на форме можно отфильтровать строки каким то штатным механизмом. Если вы подскажет каким, то буду очень признателен.
+
5. tormozit 7140 06.10.15 01:26 Сейчас в теме
(4) Отбор для табличного поля таблицы значений в менеджере табличного поля в ИР не реализован, ты прав. Универсально его сделать будет непросто. Твой вариант подразумевает хранение оригинала таблицы значений оторванно от табличного поля кодом самой формы, что потребует адаптации формы для использования такой формы настройки. Конечно же и такой способ полезен, но широко его применять будет не очень удобно.
+
6. echo77 1881 06.10.15 07:31 Сейчас в теме
А не лучше ли построить запрос и добавить в него отбор и сортировку построителе запроса?
+
7. vinni_pooh 17 06.10.15 10:47 Сейчас в теме
(6) echo77,
Не совсем уловил суть предлагаемого вами решения. Если можно поподробнее, как дать пользователю возможность самому отобрать нужные ему данные из тз используя построитель запроса?
Можно кусок кода?
+
8. echo77 1881 06.10.15 16:55 Сейчас в теме
(7) Я про код в процедуре вашего решения
Процедура ОсновныеДействияФормыкнУстановитьОтбор(Кнопка)
+
Оставьте свое сообщение