Найти нужную часть кода (процедуру/функцию) которая отвечает за то или иное действие в 1С достаточно сложно, особенно если в этом деле нет опыта. Такие трудности в основном возникают у начинающих 1С программистом. Так же все зависит и от самой конфигурации, в типовых все более менее понятно, хоть там и кода очень много, так как они пишутся по стандартам, а вот если взять самописную, которую разработал человек с нестандартным складом ума, который могу затолкать скажем процедуру печати в общий модуль и туда же положить сам макет а еще и по извращаться с названия, можно как говориться голову сломать. Стандартным вариантом поиска кода является Отладка. Я же сегодня хочу поделиться еще одним, которым в свое время пользовался достаточно часто, особенно если не знал где расположенная нужная часть кода или целая процедуру/функцию.
Как в конфигураторе быстро найти код для нужно мне объекта
Поиск будем проводить в типовой конфигурации «Бухгалтерия государственного учреждения, редакция 2.0». Допустим нам нужно найти процедуру которая отвечает за формирование печатной формы документа «Счет на оплату» а именно то условие где вбирается макет «Счет на оплату» и «Счет на оплату с QR кодом».
Для того чтобы посмотреть какие процедуры и функции а так же какая часть кода выполняется в момент выбора той или иной печатной формы нужно сделать следующие. Запускаем конфигуратор и 1С в пользовательском режиме, открываем интересующий нас документ «Счет на оплату», после чего переходим в конфигуратор и выбираем «Отладка» и нажимаем «Замер производительности».
После этого возвращаемся в пользовательский режим и жмем печать «Счет на оплату».
После того как печатная форма откроется, снова возвращаемся в конфигуратор и отжимаем пункт «Замер производительности».
Когда Вы это сделается откроется окно в котором будут отображены все модули и конкретные строчки кода которые использовались для формирования печатная формы. Для удобства поиска произведем сортировку по полю «Номер строки». Видим что началось все с модуля менеджера и условия «Если Управление печатью …». Для того чтобы открыть данный модуль просто кликаем два раза мышкой.
В итоге откроется процедура «Печать» и то самое условие, тут достаточно наглядно можно понять какая часть кода выполнялась во время формирования печатной формы документа.
В правой части данного условия можно увидеть название используемого макета. Если повторить все тоже самое но выбрать печать «Счет на оплату с QR кодом» то вы увидите что будет использоваться другое условие с другим макетом.
Кстати подобным образом можно найти макет который используется во время печати, так как не всегда они хранятся в самом документе как в нашем случае. Очень части макеты сохраняют в общих макетах.
Так же данный поиск может пригодиться когда на форму программно добавляются различные элементы. Этот вариант хоть и не стандартный но имеет место быть и им обязательно стоит пользоваться. Но лучше хорошенько изучить Отладку.
Задание:
Нужно доработать типовой отчет 1С “Динамика продаж”.
Проблема в том что в конфигураторе 1С нет отчета с названием или синонимом “Димика продаж” .
Таких отчетов много и сейчас мы узнаем как нам найти их в конфигураторе.
Решение:
Ищем этот отчет в режиме 1с предприятие:
либо так:
В конфигураторе по названию мы этот отчет не найдем:
Запустим отчет “динамика продаж” и кликнем на “получить ссылку”:
Получаем ссылку на справочник – варианты отчетов.
Найдем справочник варианты отчетов :
Вот нужный справочник, найдем в нем отчет(вариант отчета) “Динамика продаж”:
Открываем элемент “Динамика продаж” , на реквизите отчет нажимаем открыть:
Вот наш отчет:
открываем его и открываем скд:
Наш искомый отчет “Динамика продаж” всего лишь один из его вариантов:
Уважаемые коллеги, прошу помочь.
В пользовательском режиме есть произвольная форма, как эту конкретную форму найти в конфигураторе?
- Вопрос задан более года назад
- 561 просмотр
Попробуйте следующий метод:
1. Запускаете клиент в режиме отладки.
2. В режиме 1С Предприяте находите команду, действие, событие, либо что там у вас, после выполнения которого открывается ваша форма.
3. В режиме 1С Конфигуратор указываете следующее Отладка — > Остановить
4. В режиме предприятия выполняете действие открывающее вашу форму.
После проделанного отладчик останавливается на событие, далее идете по строчкам и ищите следующий код, что то вроде ОткрытьФорму(“Форма.ВашаФорма”);
Либо, если форма уже открыта, то выполняете тоже самое, но непосредственно из формы (выполняете любую команду, событие прямо из вашей искомой формы в пользовательском режиме) и отладчик вас остановит в модуле вашей формы
В большинстве своем делаю именно так. Гораздо быстрее, чем использовать глобальный поиск.
В этой статье мы научимся создавать внешнюю печатную форму для управляемого приложения 1С 8.3, которое написано на БСП («1С: Бухгалтерия предприятия 3.0», «1С: Управление торговлей 11»). Причем создавать с нуля, не используя так называемые шаблоны. Вы сами научитесь создавать шаблоны внешних печатных форм.
Все это делается довольно просто))
И так, создадим новую обработку.
Мы будем создавать внешний счет на оплату покупателю, поэтому обработку так и назовем: «СчетНаОплатуВнешний».
Сохраним ее на жесткий диск.
Регистрация внешней обработки или отчета в базе 1С осуществляется на основании сведений, которые поставляет сама обработка. Поэтому эти сведения должны быть описаны в обработке. Осуществляется это с помощью структуры, которая имеет определенный набор полей, и которая возвращается экспортной функций СведенияОВнешнейОбработке.
Зайдем в модуль обработки, и создадим экспортную функцию СведенияОВнешнейОбработке.
Внутри этой функции создадим структуру ПараметрыРегистрации, которая будет содержать определенный список полей. Каждое поле мы разберем в отдельности.
Создадим первый элемент структуры, он будет иметь ключ с название «Вид».
Значением данной связки КлючИЗначение идет одна из строк:
- «ДополнительнаяОбработка»
- «ДополнительныйОтчет»
- «ЗаполнениеОбъекта»
- «Отчет»
- «ПечатнаяФорма»
- «СозданиеСвязанныхОбъектов»
В нашем случае должна быть строка «ПечатнаяФорма».
Следующий элемент структуры должен иметь ключ с названием Назначение.
В качестве значения данного элемента должен выступать массив, где перечислены будут все документы или справочники, в которых будет выходить данная печатная форма.
Они должны иметь тип строка, и быть в следующем формате:
Документ.»НазваниеДокумента»
Справочник.»НазваниеСправочника»
У нас этот массив будет возвращать отдельная функция ПолучитьНазначениеОбработки.
Допишем созданный последним элемент структуры.
Создадим новый элемент структуры, ключ которого будет называться «Наименование», а в значении будет содержаться наименование обработки, которое будет отображаться в справочнике «Дополнительные внешние печатные формы».
Следующий элемент структуры будет иметь название «Версия», значением данного элемента будет версия обработки. Задается программистом на его усмотрение.
Следующий элемент имеет название «Информация», который содержит краткую информацию по обработке.
Следующий элемент имеет название «БезопасныйРежим», его необходим устанавливать в значение истина или ложь, в зависимости от того необходимо устанавливать или отключать безопасный режим во время выполнения обработки. Мы установим значение Истина.
И в последнем параметре необходимо добавить команды, которые будут поставляться обработкой. Для этого нам необходимо создать и заполнить таблицу команд. Разработаем функцию, которая создает и возвращает таблицу с определенным набором полей. Делать это будем в функции ПолучитьТаблицуКоманд.
Создадим функцию и таблицу значений внутри нее.
Теперь создадим пять колонок этой таблицы.
И первая колонка – Представление (тип строка).
Эта колонка – представление команды в пользовательском интерфейсе, т.е. то, что пользователь увидит при нажатии меню»Печать» в документе или справочнике.
Вторая колонка – Идентификатор.
Это может быть любая текстовая строка, уникальная в пределах данной обработки.
Третья колонка – Использование.
Параметр данной колонки типа строка, должен принимать одно из четырех значений –
- ОткрытиеФормы – Открывает форму обработки.
- ВызовКлиентскогоМетода – будет вызвана клиентская процедура из модуля формы обработки.
- ВызовСерверногоМетода — будет вызвана серверная процедура из модуля обработки.
- СценарийВБезопасномРежиме – тоже будет вызвана серверная процедура из модуля обработки в безопасном режиме.
Конкретно мы будем использовать вызов серверного метода.
Следующая колонка – показывать оповещение. Принимает значение истина или ложь, в зависимости от того надо показывать оповещение или нет.
И последняя колонка – модификатор. Это дополнительный модификатор команды. В нашем случае будет иметь название ПечатьXML.
Теперь создадим процедуру, которая будет заполнять данную таблицу значений.
В данном коде все понятно.
В функции СведенияОВнешнейОбработке создадим команду и заполним ее.
Создаем таблицу значений:
Теперь заполним ее.
Еще раз пройдемся по параметрам.
- Первый параметр, непосредственно таблица команд вновь созданная.
- Второй параметр, как будет отображаться команда пользователю на форме (документа, справочника).
- Третий – уникальный идентификатор команды, запомните его, он нам еще пригодится!
- Четвертый параметр – использование, что вызовет Ваша команда.
- Пятый параметр – показывать оповещение, мы не будем это делать.
- Шестой параметр – модификатор, в нашем случае он всегда один ПечатьXML.
Теперь передадим вновь созданную таблицу команд в структуру ПараметрыРегистрации.
И пусть наша функция СведенияОВнешнейОбработке возвращает данную структуру.
Все теперь наша обработка будет передавать нужные параметры регистрации, которые будут необходимы при создании элемента справочника дополнительные печатные формы и обработки. Обращаю ваше внимание, что название всех полей в структуре Параметры регистрации, а также название и типы всех колонок в таблице команд, должны быть те которые приведены в примере, иначе Ваша обработка не зарегистрируется.
Теперь в модуле объекта создадим процедуру Печать. Это процедура с четырьмя параметрами: МассивОбъектов, КоллекцияПечатныхФорм, ОбъектыПечати, ПараметрыВывода.
И вот начинается самое интересное, теперь вам необходимо войти в аналогичную процедуру в менеджере объекта счет на оплату покупателю, или в обработке, которая, по сути, является менеджером печати.
Как узнать, где находится нужная нам функция?
Откроем модуль менеджера документа Счет на оплату покупателю.
И найдем процедуру ДобавитьКомандыПечати, которая заполняет список команд .
В этой процедуре найдем код, где добавляется команда для нужной нам печатной формы (список команд добавляется в таблицу значений КомандыПечати). И обратим внимание на свойство МенеджерПечати. Если этому свойству присваивается какое-нибудь значение — это путь к объекту метаданных, как правило к обработке, то значит при выводе нужной печатной формы будет отработан код в процедуре Печать, которая находится в модуле менеджере этого объекта (в обработке). А если это свойство в принципе не фигурирует при заполнении команды печати, то значит будет отработан код в процедуре Печать, которая находится в модуле менеджера нашего основного объекта (в нашем случае это документ СчетНаОплатуПокупателю)
Посмотрим на процедуру ДобавитьКомандыПечати в модуле менеджера документа «Счет на оплату покупателя».
оскольку мы делаем внешнюю печатную форму счета на оплату, то нас интересует первое добавление в таблицу значений (см. свойство Представление), и мы видим, что в этом случае заполнено свойство МенеджерПечати, где указан объект Обработка.ПечатьСчетаНаОплату. Это значит, что нам нужно найти процедуру Печать в модуле менеджера обработки ПечатьСчетаНаОплату.
А если бы мы решили сделать внешнюю печатную форму договора счета на оплату (второе добавление в таблицу значений КомандыПечати), то нам нужно было бы найти процедуру Печать в модуле менеджера документа СчетНаОплатуПокупателя.
Откроем модуль менеджера обработки ПечатьСчетаНаОплату.
И раскроем процедуру Печать.
Нас интересует второе условие (где фигурирует строка «СчетЗаказ», см. идентификатор нужной команды в процедуре ДобавитьКомандыПечати модуля менеджера документа), скопируем это условие в процедуру Печать нашей внешней обработки.
Внимание! Копировать напрямую процедуру Печать из модуля менеджера (без разницы обработка это, документ или справочник) не следует. Поскольку у них отличается количество параметров, в последствие это приводит к ошибкам при работе.
Так же из модуля менеджера обработки скопируем процедуру СформироватьПечатнуюФорм
В этом коде есть строка, где заполняется таблица сведений счета на оплату.
Эта таблица получается при помощи процедуры модуля менеджера объекта (в нашем случае это документ СчетНаОплатуПокупателю). Найдем эту процедуру в модуле менеджера документа СчетНаОплатуПокупателю.
И скопируем её в модель нашей внешней обработки.
А сам код процедуры СформироватьПечатнуюФорму в модуле внешней обработки исправим, убрав все не нужное от туда.
Если мы сейчас сделаем проверку модуля внешней обработки, то выйдет две ошибки. Первая, что не определена переменная ПараметрыПечати в процедуре Печать, и, что не найдена функция ПолучитьТекстЗапросаДляФормированияТаблицыСведенийСчетаНаОплату в функции ПолучитьТаблицуСведенийСчетаНаОплату.
Создадим переменную ПараметрыПечати в процедуре Печать. Это будет простая структура.
А потом найдем функцию ПолучитьТекстЗапросаДляФормированияТаблицыСведенийСчетаНаОплату в модуле менеджера документа СчетНаОплатуПокупателю и скопируем её в модуль внешней обработки.
Должен получится следующий состав процедур и функций модуля внешней обработки (для удобства я разделил их на две области).
Еще раз делаем проверку модуля. Ошибок не обнаружено.
Продолжаем, теперь нам необходимо, что бы брался наш макет, и печатался по нашей команде.
Нас интересует процедура СформироватьПечатнуюФорму, а в ней мы уделим внимание методу ПечатьСчетаНаОплату общего модуля ПечатьТорговыхДокументов.
Очевидно, она непосредственно формирует табличный документ. Перейдем в этот общий модуль, и скопируем функцию ПечатьСчетаНаОплату в модуль нашей внешней обработки.
Делаем проверку модуля внешней обработки. Ругается на несуществующие методы ВывестиЗаголовокПредупреждение и НомерСчетаНаОплату.
Переходим в общий модуль, от куда мы взяли функцию ПечатьСчетаНаОплату, находим процедуру ВывестиЗаголовокПредупреждение , и копируем ее в модуль внешней обработки.
А функция НомерСчетаНаОплату в общем модуле ПечатьТорговыхДокументов экспортная, поэтому мы просто исправим код в процедуре ПечатьСчетаНаОплату, где используется проблемная функция, сделав вызов этой функции из вышеупомянутого общего модуля.
Проверяем еще раз ошибки. Все нормально.
Не забудем в процедуре СформироватьПечатнуюФорму убрать вызов метода ПечатьСчетаНаОплату из общего модуля.
Теперь зайдем в скопированную функцию ПечатьСчетаНаОплату, и посмотрим, где в ней подтягивается макет.
Находим данный макет в общих макетах и копируем его в макеты нашей обработки.
Исправляем выделенный код, где подтягивается макет, следующий образом.
Теперь зайдем в наш скопированный макет, и сделаем какое-нибудь изменение, чтобы вы видели, что команда подтянула именно макет из внешней обработки.
Вернемся обратно в процедуру Печать нашей внешней обработки.
И теперь осталась одна небольшая хитрость, без которой ваш внешний отчет не будет работать. Необходимо текст «СчетЗаказ» (это идентификатор типовой печатной формы).
Заменить на название идентификатора команды («СчетНаОплатуВнешний»).
Все, сохраняем данную обработку. И запускаем «1С: Предприятие» из конфигуратора 1С.
Идем в администрирование. В дополнительные отчеты и обработки.
Нажимаем на кнопку «Добавить из файла» и выбираем нашу созданную обработку.
Записываем. И смотрим, как выходит наша печатная форма.
Ссылка на дубль статьи на Инфостарте. В конце этой статьи приведены примеры внешних печатных форм счета на оплату, ТОРГ 12, ПКО , М11 и Требование накладная в одной обработке (документ Требование накладная). Все внешние печатные формы сделаны для конфигурации «1С: Бухгалтерия предприятия» (релиз 3.0.67.67).
Изучайте программирование в 1С в месте с моей книги «Программировать в 1С за 11 шагов»
- Книга написана понятным и простым языком — для новичка.
- Книга посылается на электронную почту в формате PDF. Можно открыть на любом устройстве!
- Научитесь понимать архитектуру 1С;
- Станете писать код на языке 1С;
- Освоите основные приемы программирования;
- Закрепите полученные знания при помощи задачника;
Отличное пособие по разработке в управляемом приложении 1С, как для начинающих разработчиков, так и для опытных программистов.
- Очень доступный и понятный язык изложения
- Книга посылается на электронную почту в формате PDF. Можно открыть на любом устройстве!
- Поймете идеологию управляемого приложения 1С
- Узнаете, как разрабатывать управляемое приложение;
- Научитесь разрабатывать управляемые формы 1С;
- Сможете работать с основными и нужными элементами управляемых форм
- Программирование под управляемым приложением станет понятным
Промо-код на скидку в 15% — 48PVXHeYu
Если Вам помог этот урок решить какую-нибудь проблему, понравился или оказался полезен, то Вы можете поддержать мой проект, перечислив любую сумму:
можно оплатить вручную:
Яндекс.Деньги — 410012882996301
Web Money — R955262494655
Искал в:
1. Конфигураторе — общие таблицы
2. Документы — Форма документа(там никаких таблиц нету. есть кнопка выбора печатной формы. но в модуле непонятно (для меня) как и где программа эту форму ищет и выбирает.
3. Вручную переоткрывал (в конфигураторе) почти все файлы — *.ert, *.mxl и т.д. и т.п. — там тоже нужной формы (таблицы) не нашел.
И куда ж ее вообще могли запрятать?
Ищу форму Накладной документа “Реализация” в конфигурации 1С: Предприниматель . Конфигурация стандартная — никто в ней ничего не менял.
Где и как ее теперь еще искать, кто может что-подсказать, посоветовать, помочь?
———————
Необходимые дополнения: в самой конфигурации я менять ничего не собираюсь. мне нужно только в саму форму Ф.И.О. в одном месте проставить — то что бухгалтеры каждый раз делают вручную. Вобщем, анекдот про сына программиста мне ХОРОШО знаком ))))
А кому незнаком или кто подзабыл — напоминаю )))
===========
Подходит сын программиста к отцу, который сидит уставившись компьютер и щелкает увлеченно по клавиатуре:
— Папа, а почему солнце всегда встает на восходе, а садится на западе?
Отец, не отрываясь от компа:
— Сынок, ты это проверял?
— Проверял!
— Это всегда так работает?
— Всегда..
— Сбоев ни разу не было?
— Ни разу.
— РАДИ БОГА, Сынок. Ничего не меня! Ничего не трогай!
))))))))))))))))))))))))
Как найти в конфигураторе |
Я |
06.02.23 – 13:17
День добрый!
В пользовательском режиме есть РС “Учет основного заработка физлиц организации”.
Как его найти в конфигураторе?
Спасибо.
1 – 06.02.23 – 13:19
поиск разве не находит?
а так в пользовательском режиме там есть кнопка получить ссылку
2 – 06.02.23 – 13:19
ну или еще -> Информация для технического специалиста
3 – 06.02.23 – 13:21
4 – 06.02.23 – 13:21
(2) в какой то платформе ~16 +- добавили ещё из режима отладки переход – “открыть в конфигуратуре”
5 – 06.02.23 – 13:21
(1) У нас УПП от 2004 года.
Поиск не находит.
6 – 06.02.23 – 13:22
(3) Ага, оно, в 17
7 – 06.02.23 – 13:25
(0) поиск по синонимам?
8 – 06.02.23 – 13:28
9 – 06.02.23 – 13:28
(0) очень просто это делается. Открываете в предприятии этот регистр. А потом щелк сюда https://disk.yandex.ru/i/3_uPPMbHugvpJg
10 – 06.02.23 – 13:29
(0) А сколько РС-то по количеству? Давно бы уж открыла свойства и перещелкала все по очереди.
11 – 06.02.23 – 13:30
12 – 06.02.23 – 13:30
(5) Ну платформа же 8.3? В строке поиска дерева конфигурации ищите “Учет основного заработка”.
Находится 3 регистра, смотрим у них формы списка, интересующий заголок у РС УчетОсновногоЗаработкаРаботниковОрганизацииВРегламентированномУчете.
13 – 06.02.23 – 13:30
(10) Это не наш метод))
14 – 06.02.23 – 13:30
(0)
Для каждого строка из Метаданные.РегистрыСведений Цикл
стр = строка.ПолноеИмя() + ” — ” + строка.Представление();
Сообщить(стр);
КонецЦикла;
Затем делаем там CTRL+F
15 – 06.02.23 – 13:30
(13) вполне себе официальный метод который рекомендует 1С
16 – 06.02.23 – 13:31
(13) иногда китайским поиском быстрее, если разовая задача.
17 – 06.02.23 – 13:31
18 – 06.02.23 – 13:31
(9) Так ведь УПП..
19 – 06.02.23 – 13:32
(18) бяда, ну что поделать, переходите на ЕРП))
20 – 06.02.23 – 13:32
(13) И кстати, заголовок на форме может и отличаться от синонома регистра, так что я бы через поиск по свойствам поискал еще дополнительно.
21 – 06.02.23 – 13:32
(19) Ага, все там будем. )
22 – 06.02.23 – 13:32
(17) пора ставить ИР, там точно есть возможносьт узнать
23 – 06.02.23 – 13:33
Глобальный поиск, имею ввиду.
24 – 06.02.23 – 13:36
(20) Да, так и оказалось, ответ в (12).
25 – 06.02.23 – 13:39
26 – 06.02.23 – 13:40
Я, конечно, блондинка, но…
Глазками смотрела, поиском искала… Результат – 0.
Поэтому и обратилась к гуру…
27 – 06.02.23 – 13:40
(25) А форма списка у этого регистра?
28 – 06.02.23 – 13:41
(25) что значит нет? Ты форму списка открой
29 – 06.02.23 – 13:41
(26) еще и не читатель
30 – 06.02.23 – 13:49
(27) (28) Извиняйте…
До такого блондинка додуматься не шмогла…
31 – 06.02.23 – 13:49
Есть еще один способ найти, то что открываешь в предприятии – замер производительности. Запустил, открыл, что интересует и закрыл. В стеке вызовов будет, что открывалось.
32 – 06.02.23 – 13:50
(30) Блондинка.
Отладка – Замер производительности.
33 – 06.02.23 – 13:51
(31) Эээ не мог или попозже или пораньше?
34 – 06.02.23 – 13:51
(33) хе хе
35 – 06.02.23 – 13:54
Так и запишем, что все мы оказались немного блондины.
36 – 06.02.23 – 14:08
Я бы ещё полез в какую-нибудь БСПшную клиентскую процедуру куда форма передаётся типа
МенеджерОборудованияКлиент.НачатьПодключениеОборудованиеПриОткрытииФормы()
и посмотрел бы что там за имя формы)
Но да, замер производительности – годное решение) Я с полгода назад товарища журил что он про него забывает, а сейчас даже и не подумал)
37 – 06.02.23 – 14:19
Про замер производимости уже писали?
Тут такое иногда вытворяють, НомераГТД как “источники данных” в меню выведено и источники данных есть, но открываю но не такая форма, включил замер, а это млять НомераГТД
38 – 06.02.23 – 14:30
Периодически, работая с 1С, я думаю о Сталине…
39 – 06.02.23 – 14:33
(38) этого мало, портреты подари отделу разработки на фоне тайги – стильно, модно, практично)
40 – 06.02.23 – 15:25
Ctrl + Alt + M
41 – 06.02.23 – 15:35
Serg_1960
42 – 06.02.23 – 15:39
05.11.2013
Работать с объектами конфигурации стало удобнее
Реализовано в версии 8.3.5.1068.
Функциональность прикладных решений постоянно увеличивается. Это объективный процесс, пользователи хотят, чтобы программа умела “всё”, и к тому же делала эта “сама” и “быстро”. Соответствующим образом увеличиваются размеры конфигураций, растёт количество объектов конфигурации, используемых в конкретных прикладных решениях.
Пока конфигурация невелика, ориентироваться среди имеющихся объектов не составляет труда. Структура дерева, привязка объектов к подсистемам и поиск по вхождению подстроки позволяют без труда найти нужный объект.
Однако когда конфигурация содержит, скажем, 150 справочников, 100 документов и не меньшее количество регистров, поиск нужного объекта становится непростой задачей и начинает занимать значительное количество времени.
Мы проанализировали типичные проблемы, которые возникают при поиске в больших конфигурациях, и реализовали в конфигураторе новый механизм поиска, более простой и удобный. Его основные отличия – это поиск по нескольким словам, ввод условия поиска и отображение найденного прямо в том окне, в котором происходит работа, а не в отдельном. Изменения коснулись разных областей конфигуратора, поэтому имеет смысл рассказать о них по-отдельности.
Поиск в дереве конфигурации
Над деревом конфигурации появилось поле, в которое можно ввести фрагменты слов для поиска, разделённые пробелом. Поиск будет выполнен автоматически. При этом фрагменты слов будут искаться в имени, синониме и комментарии объектов конфигурации. Результаты поиска будут показаны тут же, в дереве конфигурации, причём найденные фрагменты слов в них будут подсвечены.
Подсветка “умная”, и работает следующим образом:
- если искомое найдено в объекте конфигурации, то имя этого объекта отображается чёрным цветом;
- при этом, если искомое найдено в имени (а не в синониме или комментарии), то оно подсвечивается прямо в имени красным цветом;
- если искомое найдено в подчинённом объекте конфигурации, а в родительском нет, то имя родительского объекта отображается серым цветом.
Поиск в палитре свойств
В верхней части палитры свойств также появилось окно поиска. Оно работает аналогично. Отличие заключается в том, что найденные свойства и элементы конфигурации отображаются списком, без разбивки по категориям. Поиск выполняется в именах, или в представлениях. В зависимости от того, что включено в палитре свойств.
Поиск в диалоге выбора типа
При выборе типа тоже часто приходится искать нужный объект конфигурации, так как многие из них образуют собственные типы. Поэтому в окне редактирования типа данных мы реализовали такой же поиск, как и в дереве объектов конфигурации.
Поиск в диалоге выбора объекта конфигурации
Есть ситуации, когда нужно выбрать один из имеющихся объектов конфигурации. Например, в свойствах конфигурации Основная форма …, или при формировании рабочей области начальной страницы. В этих случаях используется диалог выбора объекта конфигурации, в который мы тоже добавили поиск.
Быстрый отбор по подсистеме
В дереве конфигурации есть возможность отобрать только те объекты, который входят в нужные подсистемы. Для этого используется фильтр по подсистемам, который, кажется, существовал в конфигураторе всегда. Он удобен, когда нужно отобрать объекты из нескольких подсистем.
Но гораздо чаще нужно отобрать объекты единственной подсистемы. Специально для такой задачи в контекстном меню подсистемы мы сделали команду Объекты подсистемы, которая сразу же фильтрует дерево объектов конфигурации по этой подсистеме. Убрать этот отбор можно с помощью “старого” диалога По подсистемам.
Быстрый отбор захваченных
Объекты, захваченные в хранилище, теперь тоже можно отобрать очень быстро. Для этого в командной панели дерева конфигурации мы реализовали команду Захваченные объекты. Её можно использовать как самостоятельно, так и вместе с фильтром по подсистемам и поиском.
Теги:
разработка
8.3.5