К основному контенту

СписокВыбора и Представление выбранного значения

Для элемента формы "всё просто" представление используется из СпискаВыбора элемента, если установлено свойство РежимВыбораИзСписка. Для элементов формы -  полей ТаблицыФормы необходимо программно задать УсловноеОформление  формы (не забываем, что для формы УсловноеОформление доступно только на сервере), иначе представление значений после выбора из списка будет "по-умолчанию". (проверено вплоть до 8.3.12.1616)



&НаСервере
Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка)
 
 УстановитьСписокВыбораВалют(Элементы.Валюта);
 УстановитьСписокВыбораВалют(Элементы.ТаблицаВалютВалюта);
 УстановитьУсловноеОформлениеДляСпискаВыбора(Элементы.ТаблицаВалютВалюта);
 
КонецПроцедуры

Процедура УстановитьСписокВыбораВалют(Элемент)
 
 Перем СписокВыборка;
 
 Запрос = Новый Запрос("ВЫБРАТЬ Валюты.Ссылка КАК Валюты ИЗ Справочник.Валюты КАК Валюты");
 
 СписокВыбора = Элемент.СписокВыбора;
 СписокВыбора.ЗагрузитьЗначения(Запрос.Выполнить().Выгрузить().ВыгрузитьКолонку(0));
 Для НомерПозиции = 1 По СписокВыбора.Количество() Цикл
  ЭлементСпискаВыбора = СписокВыбора.Получить(НомерПозиции-1);
  ЭлементСпискаВыбора.Представление = СтрШаблон("Представление %1 (%2)", НомерПозиции, ЭлементСпискаВыбора.Значение);
 КонецЦикла;
 Элемент.РежимВыбораИзСписка = СписокВыбора.Количество();
 
КонецПроцедуры

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

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

Комментарии

Популярные сообщения из этого блога

СписокВыбора. Показать Представление вместо Значения

Вводная Если на форме есть элемент управления со списком выбора, в моем конкретном примере это Колонка Значение (Число (3,0)) с настроенным списком выбора. По умолчанию платформа отображает именно строковое значения, а не текст представления  из списка выбора (когда как при выборе значения из списка показываются именно представления). Решение Для Управляемых форм необходимо настроить правила условного оформления, для обычных форм - оформление ячеек при выводе данных.

Табличный Документ. Разная ширина колонки в строках

Когда нужно в макете (табличном документе) изменить ширину колонки  для конкретных строк: 1. Выделить всю строку (строки). Именно всю, фокус для выделенной области не работает. 2. Нажимаем и не отпускает Ctrl 3. С помощью мыши изменяют ширину любой из колонок - будет задан вопрос об создании нового формата строк - соглашаемся. Как же прекрасен мир, где для модификаций не достаточно просто использовать контекстное меню и диалог редактора свойств, где нужно знать заветные слова и таинства танца. 90ые, моё почтение. UPD Программно, тоже самое, можно сделать через ТабДок = Новый ТабличныйДокумент(); ТабДок.Область(1,,1,).СоздатьФорматСтрок(); ТабДок.Область(1,1).ШиринаКолонок = 70; ТабДок.Область(1,2).ШиринаКолонок = 30; ТабДок.Область(2,,2,).СоздатьФорматСтрок(); ТабДок.Область(2,1).ШиринаКолонок = 30; ТабДок.Область(2,2).ШиринаКолонок = 70; ТабДок.Показать();

Расширение конфигурации + Связанные документы (Режим совместимости 8.3.12)

Вводная: реализовать ввод Заказа поставщику на основании Заказа на Ремонт. решить через расширения конфигурации. Хочу обратить ваше внимание, не нужно добавлять в расширение критерий отбора, для 8.3.12 нам не доступно добавление\изменение состава критерия. Более того может зависать конфигуратор (столкнулся с последней версией 8.3.14 + ERP) Разработку рекомендую вести с применением хранилища и для расширения. Иначе устанете потом выгребать чего лишнего включили в расширение при добавлении таких или схожих обектов с составными типами и подобное. Все текущие типовые решения сейчас идут в режиме совместимости 8.3.12, в прочем и для 8.3.14 (и даже 8.3.15 ничего не поменялось). Что нам нужно было бы сделать при отказе от поддержки: 1) добавить наш документ в Критерий отбора (состав, реквизиты); 2) в раздел Ввод на основании целевого документа. И что с целью сохранения поддержки. Как сделать это же для расширения: 1) Добавить реквизит расширения Документы.ЗаказПоставщику._За