Подсистема "Конструктор правил заполнения объектов" на основе СКД (для обычного или управляемого приложения).

Публикация № 563741 29.03.17

Приемы и методы разработки - Инструментарий разработчика

Подсистема документ справочник объект форма заполнение конструктор условия значения СКД порядок правило настройка

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

Описание проблемы 

Одним из  классов задач, с которыми часто приходится сталкиваться разработчику, является заполнение значений объектов по умолчанию. Например, пользователь при создании нового документа желает видеть поле "Организация" заполненым значением "Наша организация". Для выполнения этого требования  можно использовать следующие типовые команды платформы  "Добавить копированием" или "Ввести на основании". А так же при наличии необходимой подсистемы из БСП назначить некоторые настройки в соответствующем регистре и/или константах.

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

заполнить статью движения денежных средств и подразделение исходя из текста поля "Назначение платежа" в документе "Списание с расчетного счета" при загрузке из клиент-банка.
Если Найти(НазначениеПлатежа, "Расчеты через ТУ") <>0 
     И Справочники.Организации.НайтиПоКоду("0000000005") Тогда
     СтатьяЗатрат = Справочники.СтатьиЗатрат.НайтиПоКоду("0000000023");
     Подразделение = Справочники.Подразделения.НайтиПоНаименованию("Торговый отдел");
Иначе
//Выполнять другое
КонецЕсли;
если пользователь указанный в поле "Ответственный" попадает в некоторый список, тогда ставится некоторая отметка в создаваемым им документе.  
ЯвляетсяРуководителем = СамописныйМодуль.ПользовательИзСпискаРуководителей(Ответственный);
ТребуетсяСогласование = НЕ ЯвляетсяРуководителем;
если сумма документа  основания меньше 100 000 руб., то заполнить вводимый на основании документ"Заявка на расходование средств"  определенным банковским счетом
Если НЕ ЗначениеЗаполнено(ДокументОснование) Тогда
     Возврат;
КонецЕсли;
Если ТипЗнч(ДокументОснование.Ссылка) = Тип("ДокументОснование.БюджетнаяОперация") Тогда
     Если ДокументОснование.Сумма < 100 000 и ДокументОснование.ВалютаДокумента = ВалютаРегламенитрованногоУчета Тогда
          Организация = Константа.ОрганизацияДляМелкихРасчетов .Получить();
          ДоговорКонтрагента = СамописныйМодуль.ПолучитьПоследнийДоговор(Организация , Контрагент);
     Иначе
     //Используем типовой код
     КонецЕсли;
КонецЕсли;
в табличной части "Товары" указать такую номенклатуру поставщика, которая соответствует некоторой номенклатуре заказчика
Для Каждого ТекСтрока Из Товары Цикл
    Если ТекСтрока.Номенклатура = Справочники.Номенклатура.НайтиПоКоду("0000052956") Тогда
         ТекСтрока.НоменклатураПоставщика = = Справочники.НоменклатураПокупателя.НайтиПоКоду("0000000174")
    КонецЕсли;
КонецЦикла;

Подобных примеров можно привести не мало и для каждой компании они будут по своему специфичны. Такие задачи можно характеризовать как требующие доработки конфигурации.

Добавим следующее условие - если читатель публикации:

- программист, тогда у него нет желания добавлять еще один кусок кода, новые объекты, учитывать изменения при обновлении, да и вообще куча более интересных задач.

- пользователь, то  он имеет желание сократить затраты на реализацию собственных хотелок.

Т.е. нужно гибкое, универсальное и достаточно простое решение класса задач подобных описанным мной выше.  

 

Исходя из этого была разработана подсистема "Конструктор правил заполнения объектов".  

С технической точки зрения - это связь подписок на события + возможности СКД. Таким образом, пользователь может самостоятельно настроить условия заполнения и указать события при которых оно будет выполняться. На текущий момент реализовано заполнение объектов при возникновении следующих событий :

- Обработка заполнения - вызывается интерактивно командами "Ввести на основании" или "Создать".  

- При копировании - командой "Добавить копированием".

- Перед записью  - командами "Записать" или "Провести".

Весь интерфейс подсистемы выполнен на управляемых формах. Исходный код, на данный момент, открыт.

 

Возможности

1. Выбор в качестве объекта заполнения любого документа конфигурации.

2. Автоматизация заполнения за счет связи с 3-мя возможными событиями.

3. Использование в качестве условий любые реквизиты и табличные части документов, а так же их вложенные элементы.

4. Условия и значения заполнения могут применены к отдельной табличной части построчно.

5. Правила можно назначить отдельным пользовавтелям.

5. Предварительная проверка выполнения заполнения на уже существующем документе в качестве примера.

6. Значения заполнения могут быть применены к любым реквизитам соответсвующего типа.

7. Учет и изменение последовательности событий заполнения.

8. Вывод некоторой информации в виде диаграмм, а так же виде сводной таблицы для дальнейшего редактирования.

 

Примеры

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

Тестовые примеры проводил на 1С:Предприятие 8.3 (8.3.9.1818);

- Бухгалтерия предприятия, редакция 3.0 (3.0.44.204); 

- Управление производственным предприятием, редакция 1.3 (1.3.85.2);

- Управление торговлей, редакция 11 (11.3.2.218)

   

   

Требования

1) Если конфигурация запускается в режиме обычного приложения, то для корректной работы подсистемы необходимо наличие установленного флага в свойстве "Использовать управляемые формы в обычном приложении".

2) Для назначения правил отдельным пользователям необходимо наличие подсистемы "Пользователи" из БСП.

 

Примечания

1) Событие "Обработка заполнения" не будет выполнено, если объект создается программно. Вариантом решения можно указать событие "Перед записью" и свойство "Это новый" со значением "Да".

2)  Для заполнения, связанного с событием "Перед записью" желательно определять свойство "Это новый", чтобы не получилось ситуации, когда значение реквизита, осозннано указанное пользователем, отличное от значения из правила, заменялось при каждой записи.

3) Событие "Обработка заполнения" не выполняется для ряда документов, например "Бюджетная операция" в УПП. При чем, если создать новую, такую же форму списка документа и на ней нажать кнопку "Создать", то подписка сработает. Без изменения эту проблему можно обойти решением из пункта 1, т.е. указать событие "Перед записью" и свойство "Это новый" со значением "Да".

4) Максимальное возможное на данный момент количество табличных частей - 20.

 

Интеграция

Подсистема может быть "бесшовно" встроена в любую конфигурацию на платформе 1С Предпрития версии 8.3.

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

 

Планы развития

Добавить в подсистему следующие функции:

1) заполнение объектов справочников;

2) возможность использовать в качестве правого значения условия и значения заполнения поля из группы "2. Доступные поля";

3) экспорт/импорт схем правил в файлы XML;

4) добавить несколько красивых отчетов;

5) в качестве значения заполнения использовать расчетные формулы (например Цена*Количество);

6) возможность учета успешных/не успешных заполнений;

7) обработка исключительных ситуаций, когда на момент попытки заполнения искомый реквизит был удален или переименован.

 

Тех. поддержка и обновление

Первые 30 дней после покупки техническая поддержка и обновления бесплатны.


Вопросы возврата

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


Заказать подбор решения


Специальные предложения

Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. Brawler 513 29.03.17 22:25 Сейчас в теме
Да, вещь вроде бы нужная, но крайне вреднючая.
Юзеры и так без мозгов, а когда программа за них все заполняет, они вообще думать перестают, после чего с таким контингентом в разу труднее работать...
Плюсану так или иначе, работа дельная.
2. Техподдержка 30.03.17 00:14
(1) Сомневаюсь, что исключение из ежедневной деятельности пользователей некоторых рутинных операций, связанных с вводом значений, повлияет как то негативно на их мышление. Считаю, что в рамках учетной системы есть возможность и необходимость заняться чем-то более сложным и важным, что не позволит расслабиться. Тем более вне учетной системы. Для программистов - аналогично.
По своему опыту отметил следующее - есть пользователи, которые самостоятельно настроили программу под себя. Они же обычно умеют редактировать структуры отчетов, делиться их вариантами друг с другом, знают о регистрах, читают описания обновлений конфигураций и тп. И есть остальные.
На данный момент, после внедрения этого решения, качественных изменений мышления своих пользователей не заметил.
3. Brawler 513 30.03.17 08:14 Сейчас в теме
(2) Приведу пример.
Каждое утро, в одной организации должны были отрабатывать регламентные операции, финалом которых были созданные документы реализации.
Как итог, начальник службы, тот кто и должен был создавать эти документы (максимум 6 штук в день), так как подчиненные несколько иные роли выполняют, так вот этот начальник тупо не знает как эти документы создавать и у него каждый раз ступор, когда по каким либо причинам регламент не отрабатывает.
При этом, если создать документ реализации вручную, то нужно указать всего лишь контрагента и склад, потом нажать кнопку заполнить товары по реализациям таким-та...
4. Техподдержка 30.03.17 11:49
(3)
тупо не знает

Не знает и не знал или знал, но забыл?
В обоих случаях решением может быть обращение к инструкциям, регламентам и тп.
5. Brawler 513 30.03.17 12:17 Сейчас в теме
(4) Банально все:
1. Компьютерная неграмотность
2. Низкая квалификация пользователя учетной системы

Причина - отсутствие жестких требования к выше обозначенным пунктам.

Поэтому, если что-то за юзера само делается, то ему это на руку, а что-то не дай бог сдвинется влево или вправо и все, трагедия))

Инструкции да хорошее дело, но и желтые книжки никто не отменял!

Был недавно в книжном магазине.
Да книг вообще завались, покупай, учись...

Ладно, думаю можно не продолжать флудить на эту тему.
fd13; Dimz_z; +2 Ответить
6. Cyberhawk 130 14.03.18 18:42 Сейчас в теме
Если пользователь заполнил реквизит объекта до записи, а в правиле для события "Перед записью" переопределено заполнение этого же реквизита, то как ведет себя подсистема?
Проще говоря, можно ли в правилах учитывать, заполнен ли реквизит, и тем самым указывать в правиле, что заполнять реквизит надо только если он не заполнен (или явным образом указывать, что заполнять надо всегда независимо от его заполнения).
7. Техподдержка 15.03.18 11:51
(6)
Добрый день.

Да, можно.
В первом файле пример безусловного(постоянного) заполнения реквизита "Организация".
Во втором и третьем примеры условий проверки заполненности.
Прикрепленные файлы:
Cyberhawk; +1 Ответить
8. vvv_vit 13 26.07.18 11:01 Сейчас в теме
Добрый день.
Подскажите, а элементы справочников заполняет?
9. Техподдержка 26.07.18 18:18
(8)
Добрый день.

Пока нет, т.к. до сих пор не было на то необходимости.
Однако, не считаю, что для меня составит много труда адаптировать подсистему под заполнение справочников.
13. user1145156 16.04.21 13:29 Сейчас в теме
(9) Да, меня тоже интересует заполнение справочников
10. klaus38 29.01.21 12:48 Сейчас в теме
Доброго дня. Куплю с удовольствием 8.3.18 УТ 11.4.10. Актуализируете?
11. Техподдержка 29.01.21 15:39
(10) Здравствуйте!
Последний раз актуализировали на платформе 8.3.14 примерно 23.11.2020. Сомневаюсь, что на 8.3.18 синтаксис поменялся с тех пор как то значительно для "Конструктора правил заполнения") Версия конфигурации, в общем случае, не влияет на работоспособность подсистемы, поскольку все необходимые функции уже в себе содержит. Не влияет и версия БСП основной конфы. Так что - дерзайте)
12. user1145156 16.04.21 13:20 Сейчас в теме
Здравствуйте
На 8.3.6 работать будет?
14. Техподдержка 16.04.21 14:39
(12) Здравствуйте!
С 8.3.6 будет работать.
15. user1145156 16.04.21 16:43 Сейчас в теме
(14) Как с Вами можно связаться по поводу доработки?
16. user1145156 19.04.21 11:41 Сейчас в теме
Оставьте свое сообщение

См. также

Infostart Toolkit Промо

Инструментарий разработчика v8 v8::УФ v8::Запросы v8::СКД 1cv8.cf Платные (руб)

Простые и удобные инструменты: Консоль запросов, СКД, Редактор объекта, Поиск ссылок и другие. Редактор запросов и кода с раскраской и контекстной подсказкой. Улучшенный конструктор тонкого клиента и др.

9000 руб.

02.09.2020    56910    246    322    

Подсистема хранения картинок во внешних файлах для УТ 10.3

Инструментарий разработчика v8 УТ10 УУ Платные (руб)

Решение позволит вам хранить файлы и картинки вне базы данных, для более лучшей компактности вашей базы данных

21600 руб.

11.08.2021    2844    1    6    

Печать договоров по шаблонам word c выводом товаров

Инструментарий разработчика v8 ERP2 УТ11 КА2 Россия УУ Платные (руб)

Из заказа печатает договор по шаблону. Есть возможность вывести и строки заказа внизу (как приложение). Не увидел ни у кого данной возможности. Есть аналогичная для БП. Ее не выкладываю, пока, ввиду наличия в БП стандартного функционала.

2400 руб.

21.05.2021    4211    4    1    

Автоматизация труда программиста. Библиотека прикладных функций

Инструментарий разработчика Универсальные функции v8 Платформа 1C v8.2 Платформа 1С v8.1 1cv8.cf Платные (руб)

Программист - это человек, непрерывно принимающий решения. Написание кода не является процессом принятия решения - это всего лишь трансляция ваших желаний. Если вас периодически тяготит написание сотен строк кода ради решения задач, то прошу обратить внимание. Данный продукт позволит существенно сократить время на рутинные операции при разработке. За счет библиотечной реализации сокращается объём кода, а его читаемость повышается. К библиотеке прилагается документация API и шаблоны кода для наиболее популярных методов.

4200 руб.

16.04.2021    6305    0    2    

SALE! 30%

PowerTools Промо

Инструментарий разработчика v8 v8::УФ 1cv8.cf Россия Платные (руб)

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

2400 1680 руб.

14.01.2013    150403    864    0    

Универсальная печатная форма договора в Word/Writer (с использованием БСП). УТ 11

Инструментарий разработчика v8 УТ11 Россия Платные (руб)

Универсальная печатная форма по шаблону Word/Writer для печати из договора контрагента для конфигурации "Управление торговлей 11.4". Пользователь имеет возможность вставлять в текст договора любое количество произвольных параметров, а также любой параметр из дополнительных сведений договора.

5000 руб.

25.03.2021    4164    0    0    

Выполнение произвольного кода или запроса с параметрами через Web-сервис (замена COM-подключений)

Инструментарий разработчика v8 Платные (руб)

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

1500 руб.

24.09.2019    14597    8    11    

Автоматическое подтверждение легальности обновления базы или как обновить 100 типовых баз 1С за 5 часов

Инструментарий разработчика v8 1cv8.cf Платные (руб)

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

1200 руб.

08.05.2019    15675    42    24    

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

Инструментарий разработчика v8 v8::УФ 1cv8.cf Платные (руб)

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

5000 руб.

16.01.2015    52811    35    49    

Версионирование регистров сведений (необъектных данных) - история изменений по версиям записей регистров сведений - ВНОД

Инструментарий разработчика v8 v8::УФ 1cv8.cf Платные (руб)

ВНОД – отдельная (дополнительная) подсистема, которая построена на основе типовой подсистемы «Версионирование объектов». Предназначена для сохранения и анализа изменений независимых (периодических и непериодических) регистров сведений, с точностью до состава измерений, ресурсов и реквизитов записей.

2800 руб.

11.02.2019    20196    54    22    

Многопоточность. Универсальный «Менеджер потоков» 2.1

Инструментарий разработчика v8 1cv8.cf Россия Платные (руб)

Восстановление партий или взаиморасчетов, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализации многопоточности? * о запуске и остановке потоков? * о поддержании потоков в рабочем состоянии? * о передаче данных в потоки и как получить ответ из потока? * об организации последовательности? Тогда ЭТО - то что надо!!!

5000 руб.

07.02.2018    87067    212    82    

1С HTML Шаблоны / HTML Templates

Инструментарий разработчика v8 1cv8.cf Платные (руб)

Быстрая и удобная обработка для работы с шаблонами HTML. Позволяет легко и быстро формировать код HTML.

1000 руб.

27.12.2017    22437    2    10    

Заполнение документа "Корректировка регистров" произвольными данными Промо

Закрытие периода Инструментарий разработчика v8 v8::СКД УНФ ERP2 УТ11 УУ Платные (руб)

Внешняя обработка, позволяющая произвольным образом заполнять документ "Корректировка регистров" Предназначена для использования в конфигурациях "Управление торговлей 11", "Управление небольшой фирмой", "ERP Управление предприятием", а также в других конфигурациях, в состав которых входит библиотека стандартных подсистем (БСП) версии 2.2+ и указанный выше документ.

1000 руб.

13.07.2015    40024    147    16    

DataReducer — R-консоль для «1С:Предприятия»

Инструментарий разработчика v8 v8::DataMining Платные (руб)

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

1000 руб.

10.07.2017    26773    6    13    

Сжатие таблиц SQL (УФ)

Инструментарий разработчика v8::УФ 1cv8.cf Платные (руб)

Обработка позволяет уменьшить размер базы данных SQL путем сжатия её таблиц. Разработана для работы в управляемых формах.

1000 руб.

14.04.2017    25854    10    4    

Версионирование объектов для Альфа-авто, ред 4 и 5.

Оптовая торговля Розничная торговля Инструментарий разработчика v8 1cv8.cf Автомобили, автосервисы УУ Платные (руб)

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

4000 руб.

03.09.2016    36326    26    24    

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

Инструментарий разработчика v8 v8::УФ 1cv8.cf Платные (руб)

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

5000 руб.

14.01.2016    47459    13    21    

Система хранения присоединенных файлов в томах на диске

Инструментарий разработчика v8 КА1 УПП1 Платные (руб)

Конфигурация Комплексная автоматизация 1.1 (и УПП 1.3 тоже) хранит файлы и изображения в справочнике Хранилище дополнительной информации в реквизите Хранилище типа ХранилищеЗначений. Та же история с ВложениямиЭлектроннойПочты. Но при этом присоединенные файлы в Электронном документообороте хранит в томах на диске. Эта доработка позволяет использовать стандартный механизм хранения файлов, изображений и вложений электронных писем в томах на диске. При этом можно разделить тома хранения по объектам конфигурации.

4200 руб.

10.11.2015    53950    77    51    

Снегопат - расширение Конфигуратора 8.2/8.3 от orefkov

Инструментарий разработчика v8 1cv8.cf Россия Платные (руб)

Работать в Конфигураторе становится еще удобнее и производительнее. Усилий меньше - результат больше! Будь программистом, а не кодером.

16.12.2011    194712    0    orefkov    1096