Как программно свернуть/развернуть дерево значений на управляемой форме? Желательно &НаКлиенте.
Код 1C v 8.2 УП КоллекцияЭлементовДерева= ДеревоНоменклатуры. ПолучитьЭлементы( ) ;
Для Каждого Строка Из КоллекцияЭлементовДерева Цикл
ИдентификаторСтроки= Строка. ПолучитьИдентификатор( ) ;
Элементы. ДеревоНоменклатуры. Свернуть( ИдентификаторСтроки) ;
КонецЦикла ;
Для Каждого Строка Из КоллекцияЭлементовДерева Цикл
ИдентификаторСтроки= Строка. ПолучитьИдентификатор( ) ;
Элементы. ДеревоНоменклатуры. Развернуть( ИдентификаторСтроки) ;
КонецЦикла ;
Для выделенной, текущей строки:
Код 1C v 8.х
Строка = ЭлементыФормы. ТабличноеПоле. ТекущаяСтрока;
ЭлементыФормы. ТабличноеПоле. Развернуть( Строка, Истина ) ;
УзелРазвернут = ЭлементыФормы. ТабличноеПоле. Развернут( Строка) ;
Если УзелРазвернут Тогда
ЭлементыФормы. ТабличноеПоле. Свернуть( Строка) ;
КонецЕсли ;
Код 1C v 8.х
Для каждого Строка Из ЭлеменетыФормы. ТабличноеПоле1 . ВыделенныеСтроки Цикл
ЭлементыФормы. ТабличноеПоле. Свернуть( Строка) ;
КонецЦикла ;
Хотя конечно есть
Ctrl+Shift+"+" и
Ctrl+Shift+"-".
P.S. Для Табличного поля с галочкой Дерево(отображающего справочник), перебрать строки НЕВОЗМОЖНО!!!
Примеры вида:
Код 1C v 8.х Для каждого Строка Из ЭлементыФормы. тпОбъекты. Строки Цикл
Для каждого Строка Из ЭлементыФормы. тпОбъекты. ТекущаяСтрока. Строки Цикл
ЭлементыФормы. тпОбъекты. Свернуть( Строка) ;
КонецЦикла ;
- НЕ РАБОТАЮТ!!!
Для СправочникСписок (ДокументСписок) итератора нет. Это не коллекция значений, перебрать не сможете. Дерево здесь ни при чем.
Можно работать со строками либо через ПриПолученииДанных (предпочтительнее по скорости), либо ПриВыводеСтроки. В продолжении
Как для Выбора Элемента Справочника Открыть Форму Выбора с нужной Открытой Группой? опишу как настроить Подбор, на примере Типовой Бухгалтерии:
1. Откроем документ Реализации и зайдем в Свойства Кнопки
Подбор
2. И так попорядку:
Кнопка вызывает процедуру:
Код 1C v 8.х Процедура КоманднаяПанельТоварыДействиеПодбор(Кнопка)
ДействиеПодбор( Товары) ;
КонецПроцедуры
Далее вызывается процедура
ДействиеПодбор
Код 1C v 8.х Процедура ДействиеПодбор(ТабличнаяЧасть)
Перем Команда, Валюта;
ЕстьЦена = Истина ;
Если ТабличнаяЧасть = Товары Тогда
Команда = "ПодборВТабличнуюЧастьТовары" ;
Валюта = ВалютаДокумента;
СпособЗаполненияЦен = Перечисления. СпособыЗаполненияЦен. ПоЦенамНоменклатуры;
ИмяТабличнойЧасти = "Товары" ;
ИначеЕсли ТабличнаяЧасть = ВозвратнаяТара Тогда
КонецЕсли ;
СписокВидовПодбора = СформироватьСписокЗапросовДляПодбора( ТабличнаяЧасть) ;
ПредставлениеДок = Метаданные( ) . Представление( ) ;
СтруктураПараметровПодбора = Новый Структура( ) ;
СтруктураПараметровПодбора. Вставить( "Команда" , Команда) ;
СтруктураПараметровПодбора. Вставить( "СписокВидовПодбора" , СписокВидовПодбора) ;
ВременнаяДатаРасчетов = ? ( НачалоДня( Дата) = НачалоДня( ТекущаяДата( ) ) , Неопределено , Дата) ;
СтруктураПараметровПодбора. Вставить( "ДатаРасчетов" , ВременнаяДатаРасчетов) ;
СтруктураПараметровПодбора. Вставить( "Склад" , Склад) ;
СтруктураПараметровПодбора. Вставить( "ТипЦен" , ТипЦен) ;
СтруктураПараметровПодбора. Вставить( "ДоговорКонтрагента" , ДоговорКонтрагента) ;
СтруктураПараметровПодбора. Вставить( "Контрагент" , Контрагент) ;
СтруктураПараметровПодбора. Вставить( "Организация" , Организация) ;
СтруктураПараметровПодбора. Вставить( "СпособЗаполненияЦен" , СпособЗаполненияЦен) ;
СтруктураПараметровПодбора. Вставить( "ЕстьЦена" , ЕстьЦена) ;
СтруктураПараметровПодбора. Вставить( "ВалютаДокумента" , Валюта) ;
СтруктураПараметровПодбора. Вставить( "Заголовок" , "Подбор номенклатуры в документ " + ПредставлениеДок + " № " + Номер + " (" + ИмяТабличнойЧасти + ")" ) ;
РаботаСДиалогами. ОткрытьПодборНоменклатуры( ЭтаФорма, СтруктураПараметровПодбора, мФормаПодбораНоменклатуры) ;
КонецПроцедуры
Из нее для открытия Подбора вызывается
ОткрытьПодборНоменклатуры из общего Модуля
РаботаСДиалогами :
Сюда и добавляем Наши изменения
Код 1C v 8.х Процедура ОткрытьПодборНоменклатуры(ФормаДокумента, СтруктураПараметров, ФормаПодбора = Неопределено) Экспорт
МетаданныеДокумента = ФормаДокумента. ДокументОбъект. Метаданные( ) ;
Для Каждого ЭлементСтруктурыПараметров Из СтруктураПараметров Цикл
Если ОбщегоНазначения. ЕстьРеквизитДокумента( ЭлементСтруктурыПараметров. Ключ, МетаданныеДокумента) Тогда
ФормаДокумента. ПодключитьОбработчикИзмененияДанных( ЭлементСтруктурыПараметров. Ключ, "ОбновитьФормуПодбора" , Ложь ) ;
КонецЕсли ;
КонецЦикла ;
ФормаПодбора = Обработки. ПодборНоменклатуры. ПолучитьФорму( "ОсновнаяФорма" , ФормаДокумента, ФормаДокумента) ;
ФормаПодбора. ОбработкаОбъект. СтруктураИсходныхПараметров = СтруктураПараметров;
ФормаПодбора. ЭлементыФормы. ДеревоНоменклатуры. ТекущаяСтрока = Справочники. Номенклатура. НайтиПоКоду( "00000013608" ) ;
ФормаПодбора. Открыть( ) ;
КонецПроцедуры
Все, перезапускаем и пользуемся