Некоторые особенности БП 3.0

18.09.14

Разработка - Механизмы типовых конфигураций

В этой статье рассматриваются особенности, выявляемые по мере совершения тестового перевода нетиповой конфигурации (релиз БП 2.0.50.3) на релиз 3.0.24.9. Оговорюсь, что сама нетиповая конфигурация не описывается, так как это было бы и долго и не вполне этично по отношению к владельцу оной. Разумеется, БП 3.0 работает под управляемым приложением, которое кардинально отличается от обычного. Однако, в данной статье особенности программирования под управляемом приложении не рассматривается и предполагается, что читатель знает о чем идет речь

Как осуществляется переход на БП 3.0

Перевод с БП 2.0 на БП 3.0, как гласит официальная информация 1С, не требует ввода остатков и осуществляется почти стандартным образом. Что значит «почти»? Это значит, что даже, если конфигурация находится на поддержке, то уж совсем просто - через поиск доступных конфигураций ничего не получится. То есть, если пройти по цепочке «Конфигурация -> Поддержка - Обновить конфигурацию - Поиск доступных обновлений», то обновление на БП 3.0 найдено не будет.

 И что же делать? Допустим, вы хотите обновиться на релиз 3.0.24.9 .Заходите на сайт http://users.v8.1c.ru/ и скачиваете полный дистрибутив БП 3.0.24.9. Устанавливаете его.

Важно понимать, с какого релиза БП 2.0 можно уйти на данный релиз. Это написано в файле Readme релиза 3.0.24.9 и можно почитать на сайте http://users.v8.1c.ru/ (конечно, если есть пароль) Для нашего примера написано следующее : «Для перехода на версию 3.0.24 необходимо использовать версию конфигурации "Бухгалтерия предприятия" не ниже 2.0.51» Другими словами, тот тестовый переход, который я затеял не вполне корректен. Ведь у меня исходная версия БП - 2.0.50.3. Ну да ладно. Речь пойдет не об ошибках перевода конфигурации… И да, он прошел! Причем, практически без ошибок.

 Вывод первый –внимательно сопоставлять конфигурации при переходе!

 Теперь заходим в конфигуратор 2.0.51 и «Конфигурация -> Поддержка -> Обновить конфигурацию -> Выбор файла обновления». Выбираем cf-файл релиза3.0.24.9

 После этого, в общем-то, механизм стандартный. У меня уже после обновления при первом запуске обновленной конфигурации вылетела ошибка, связанная с изменением в БП 3.0 механизма свойств по сравнению с оным в БП 2.0 и пришлось немного похимичить, но это, как говорится, частный случай…

 На 16.09.2014 ситуация немного изменилась, причем в лучшую сторону. Сегодня уже выпущен релиз Бухгалтерия предприятия, редакция 3.0, версия 3.0.35.28 и в составе дистрибутива есть «Дистрибутив обновления для перехода с редакции 2.0». Если использовать именно этот дистрибутив, то обновлять можно через автоматический поиск обновлений, что немного упрощает организацию процесса.

Что с внешними отчетами, внешними обработками и внешними печатными формами?

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

Где подключать внешние обработки, отчеты, формы и прочее в БП 3.0 в 1С-Предприятии?

 Внешнее в БП 3.0 бывает разного вида.

 Чтобы подключить оное добро необходимо в разделе «Администрирование» на панели навигации воспользоваться пунктом меню (или как его назвать в терминах управляемого приложения?) “Дополнительные отчеты и обработки”. Дальше – всё довольно прозрачно…

А можно ли подключить обработку или отчет к новому разделу, который я создал сам?

Конечно можно, но для этого необходимо внести изменения в конфигурацию. В типовой БП 3.0 оное добро накрепко связано с разделами, которые жестко прописаны в коде. Да-да, подсистемы верхнего уровня, к которым можно приделать внешний отчет или обработку прописаны в коде. Чтобы подключить отчет или обработку к новому разделу, необходимо внести изменения в следующие процедуры:

  •  ДополнительныеОтчетыИОбработкиПереопределяемый.ОпределитьРазделыСДополнительнымиОтчетами()
  •  ДополнительныеОтчетыИОбработкиПереопределяемый.ОпределитьРазделыСДополнительнымиОбработками()
 Процедура ОпределитьРазделыСДополнительнымиОтчетами(Разделы) Экспорт

                //Здесь добавляются стандартные подсистемы в типовой конфигурации

…

                Разделы.Добавить(Метаданные.Подсистемы.Администрирование);

                 //Вызываем самописанную процедуру, которая добавляет новые разделы

                ДобавитьРазделыБН(Разделы)                         

КонецПроцедуры

//

Процедура ДобавитьРазделыБН(Разделы)

                Разделы.Добавить(Метаданные.Подсистемы.БН);

КонецПроцедуры

 

//Разделы - массив

Ниже приводится стек вызовов, который приводит к вызову процедуры ОпределитьРазделыСДополнительнымиОтчетами(Разделы)

В результате вышеописанного колдунства, появится возможность разместить отчет или обработку в этом новом разделе. В нашем случае, появилась возможность разместить «Простой внешний отчет» в разделе «Менеджеру». «Менеджеру» - синоним подсистемы с именем БН, которая и добавляется в процедуре.

Можно ли подключить отчет так, чтобы он был доступен из каждого раздела, в том числе и такого, которого нет в форме списка разделов командного интерфеса?

 Мне не удалось, хотя и не исключаю такую возможность. Если у кого-то получилось, надеюсь на поделиться.

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

А где обещанный бонус по внешним отчетам, обработкам и печатным формам?

 Бонус от 1С, на мой взгляд, выглядит так. Теперь перенести базовый алгоритм печати из встроенной печатной формы во внешнюю стало ну очень просто и, главное быстро (просто было и раньше в БП 2.0). С чем это связано? Как ни удивительно, с тем, что теперь мы не должны привязывать алгоритм к реквизиту СсылкаНаОбъект, ибо реквизитов у печатных форм теперь нет. То, что нет реквизитов приводит к усложнению кода в части регистрации печатной формы в конфигурации, но зато, появляется бонус. Такая вот диалектика.

 В БП 3.0 алгоритм печати попросту копируется из встроенной печатной формы и потом допиливается по эскизу заказчика.

 Почему это реальный бонус. Да потому, что присабачивать алгоритм к реквизиту СсылкаНаОбъект  было муторно и противно. Кто делал это для в БП 2.0, например, для Счетов-Фактур, тот знает… Пока оно там переделаешь… Теперь же нужно просто владеть копипастом.

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

Как создать дополнительную (внешнюю) печатную форму

 Распишу механизм на примере внешней печатной формы “Счет на оплату покупателям” для документа СчетНаОплатуПокупателю.

 Обозначу главные ключевые моменты.

  1. Старые печатные формы под БП 2.0, которые работали в обычном приложении не подойдут, все интерфейсные вещи гарантированно придется переписывать. Алгоритмы можно переносить, но, скорее всего их так же придется адаптировать.
  2. В печатных формах для БП 3.0 (релиз 3.0.24.9) отсутствует реквизит СсылкаНаОбъект, по которому БП 2.0 опрееляла, к какому объекту относится внешняя печатная форма. Регистрация печатной формы через механизм макетов, как в БП 2.0 (в макете задавалось полное имя объекта, для которого производилась регистрация) так же отсутствует.
  3. Чтобы зарегистрировать  дополнительную печатную форму  необходимо в модуле обработки прописать две стандартных функции и одну процедуру:
    • Функция СведенияОВнешнейОбработке() Экспорт
    • Функция ПолучитьТаблицуКоманд()
    • Процедура ДобавитьКоманду

Разберу эти функции и процедуры подробно.

 

Функция СведенияОВнешнейОбработке() Экспорт

 

// Структура, в которой сохраняются параметры регистрации внешней печатной формы

    ПараметрыРегистрации = Новый Структура;   

// МассивНазначений определяет, к какому объекту (например, к какому документу) относится печатная форма

 

    МассивНазначений  = Новый Массив;     

    // Первый параметр, который мы должны указать - это какой вид обработки системе должна зарегистрировать.

 // Допустимые типы:

//ДополнительнаяОбработка,

//ДополнительныйОтчет,

//ЗаполнениеОбъекта,

//Отчет,

//ПечатнаяФорма,

//СозданиеСвязанныхОбъектов

 

    ПараметрыРегистрации.Вставить("Вид", "ПечатнаяФорма");

 

 // Как мы помним, у нас нет реквизита СсылкаНаобъект.

// Вместо него используется массив МассивНазначений

// Можно задать имя в таком виде: Документ.* - в этом случае обработка будет подключена ко всем //документам в системе, которые поддерживают механизм ВПФ

 

    МассивНазначений .Добавить("Документ.СчетНаОплатуПокупателю");

    ПараметрыРегистрации.Вставить("Назначение", МассивНазначений );

// Теперь зададим имя, под которым ВПФ будет зарегистрирована в справочнике внешних обработок

//Речь идет именно о справочнике обработок. Пользователь, нажав на кнопку «Печать» в документе увидит иное…

   ПараметрыРегистрации.Вставить("Наименование", "Счет на оплату покупателю");                                                                                                                                                                                                                                                                                      

 // Зададим использование безопасного режима, чтобы было всё безопасно и никто ничего не боялся.

// (см. метод УстановитьБезопасныйРежим)

    ПараметрыРегистрации.Вставить("БезопасныйРежим", Истина);

 

// Следующие два параметра  -  прописывают информацию к обработке

 

  ПараметрыРегистрации.Вставить("Версия", "1.0");   

    ПараметрыРегистрации.Вставить("Информация", "Дополнительная печатная форма ""Счет на оплату покупателю"" к документу СчетНаОплатуПокупателю");

  

     // Создадим таблицу команд

    ТаблицаКоманд = ПолучитьТаблицуКоманд();

   

    // Добавим команду в таблицу команд

    ДобавитьКоманду(ТаблицаКоманд, "Счет на оплату(внеш)", "СчетЗаказВнеш1", "ВызовСерверногоМетода", Истина, "ПечатьMXL");

//формат вызова:ТаблицаКоманд, Представление       , Идентификатор, Использование, //ПоказыватьОповещение = Ложь, Модификатор = ""

//Для нашего примера:

//Представление      =  "Счет на оплату(внеш)"

//Нажав на кнопку «Печать» пользователь как раз и увидит "Счет на оплату(внеш)"

//Обратите внимание на идентификатор.

//В нашем примере, Идентификатор = “СчетЗаказВнеш1”

//На него будет еще ссылка в другой процедуре и это очень важно. Если указать не тот идентификатор в этой второй процедуре, то всё перекосит. Кроме того, этот идентификатор можно будет использовать для того, чтобы переопределить стандартную, вшитую в конфигурацию БП 3.0 печатную форму. Но об этом колдунстве попозже.

  // Таблица команд сохраняется в параметры регистрации обработки

    ПараметрыРегистрации.Вставить("Команды", ТаблицаКоманд);

   

    // Теперь вернем системе наши параметры

    Возврат ПараметрыРегистрации;

 

КонецФункции

 

Функция ПолучитьТаблицуКоманд()

 

   // Создание новой ТЗ

   Команды = Новый ТаблицаЗначений;

 

   // Представление – поле, которое говорит, что увидит пользователь, нажав на кнопку «Печать»

   Команды.Колонки.Добавить("Представление", Новый ОписаниеТипов("Строка"));

 

   // Имя нашего макета, что бы могли отличить вызванную команду в обработке печати

   Команды.Колонки.Добавить("Идентификатор", Новый ОписаниеТипов("Строка"));

 

   // Определяем способ вызова команды обработки

   // Возможные варианты:

   // - ОткрытиеФормы - в этом случае в колонке “Идентификатор” должно быть указано имя формы, которое должна будет открыть система

   // - ВызовКлиентскогоМетода - вызвать клиентскую экспортную процедуру из модуля формы обработки

   // - ВызовСерверногоМетода - вызвать серверную экспортную процедуру из модуля объекта обработки

   Команды.Колонки.Добавить("Использование", Новый ОписаниеТипов("Строка"));

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

   Команды.Колонки.Добавить("ПоказыватьОповещение", Новый ОписаниеТипов("Булево"));

   // Для печатной формы должен содержать строку ПечатьMXL

   Команды.Колонки.Добавить("Модификатор", Новый ОписаниеТипов("Строка"));

   Возврат Команды;

КонецФункции

 

Процедура ДобавитьКоманду(ТаблицаКоманд, Представление, Идентификатор, Использование, ПоказыватьОповещение = Ложь, Модификатор = "")

  // Добавляем команду в таблицу команд по переданному описанию.

  НоваяКоманда = ТаблицаКоманд.Добавить();

  НоваяКоманда.Представление = Представление;

  НоваяКоманда.Идентификатор = Идентификатор;

  НоваяКоманда.Использование = Использование;

  НоваяКоманда.ПоказыватьОповещение = ПоказыватьОповещение;

  НоваяКоманда.Модификатор = Модификатор;

 

КонецПроцедуры

 

//А вот теперь, тот самый бонус….

//Просто копируем алгоритм печати из модуля менеджера документа СчетНаОплатуПочупателю. Единственное отличие состоит в том, что вместо общего макета, использую макет из данной печатной формы.

 

//---------------------------------------------------------------------------------------------

//Фактическая часть, отвечающая за подбор данных для печати и их выводе на печать

//Ниже-просто скопированные процедуры из менеджера документа

//Макет берем из ВПФ

// //Макет = УправлениеПечатью.ПолучитьМакет("ОбщийМакет.ПФ_MXL_М11");

// Макет = ПолучитьМакет("ПФ_MXL_М11");

 

Процедура Печать(МассивОбъектов, КоллекцияПечатныхФорм, ОбъектыПечати, ПараметрыВывода) Экспорт

 

                // Устанавливаем признак доступности печати покомплектно.

                ПараметрыВывода.ДоступнаПечатьПоКомплектно = Истина;

 

                // Проверяем, нужно ли для макета ПКО формировать табличный документ.

                // Формируем табличный документ и добавляем его в коллекцию печатных форм.

                //УправлениеПечатью.ВывестиТабличныйДокументВКоллекцию(КоллекцияПечатныхФорм,"М11","М11 (Требовние-накладная)",ПечатьМ11(МассивОбъектов, ОбъектыПечати));

                УправлениеПечатью.ВывестиТабличныйДокументВКоллекцию(КоллекцияПечатныхФорм, "СчетЗаказВнеш1", "Счет на оплату",               ПечатьДокумента(МассивОбъектов, ОбъектыПечати));

               

//Обратите внимание, что используется именно тот идентификатор, который мы задали в функции СведенияОВнешнейОбработке

 

КонецПроцедуры

 

Что сделать, чтобы внешнюю печатную форму можно было использовать в режиме групповой печати

 

Во-первых, о чем идет речь? В БП 3.0 нет сервисной обработки  «Групповая печать справочников и документов». Зато в полный рост работает механизм множественного выделения объектов.

 

Пусть у нас открыт список документов «Счет на оплату покупателю». Тогда, чтобы выделить все те документы, которые имеются в этом списке, можно нажать Ctrl A (в частности, можно отобрать документы в заданном диапазоне и нажать Ctrl A и будут выделены только они, а те, что вне диапазона останутся без выделения). Можно, удерживая Ctrl, щелкать мышкой по строкам, а можно, удерживая Shift, нажимать «Стрелку вниз».

В результате, получится примерно такая картина:

Если нажать на кнопку «Печать» и выбрать, скажем, «Счет на оплату(внеш)», то хотелось бы получить счета по всем выделенным объектам.

Для достижения такого результата необходимо в алгоритме печати учесть это множественное выделение. Для этого нужно понимать, что ссылки на выделенные объекты передаются в процедуру Печать() в массиве МассивОбъектов.

 

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

В типовых встроенных печатных формах (которые я смотрел) этот вопрос решен. Их можно взять за образец при разработке своей дополнительной печатной формы.

Как устроен механизм печати встроенных печатных форм

В качестве объекта исследований возьмем документ СчетНаОплатуПокупателю. О чем речь? В форме списка документа и в форме документа отображается такая кнопка со стрелочкой «Печать», нажав на которую, получаем список печатных форм документа.

 

 Попытаемся ответить на несколько вопросов:

 

Печать из карточки документа и из списка документов позволяет вывести один и тот же перечень видов печатных форм или нет?

 

Да, это один и тот же перечень.

 

 Где программно задается перечень видов печатных форм и как?

 

В модуле менеджера документа есть процедура ДобавитьКомандыПечати(КомандыПечати). Именно в ней и формируется данный перечень печатных форм.

 

 

Обратите внимание на идентификатор. Помните, я обещал рассказать, как подменить стандартную печатную форму. Так вот, если идентификатор внешней печатной формы совпадет с идентификатором встроенной печатной формы, то будет печататься внешняя вместо встроенной. Колдунство тестировалось на релизе БП 3.0.24.9. и как будет после или было до сказать не могу. Возможно, что и так же…

 

  • То окно, в которое выводится подготовленная печатная форма это что за объект конфигурации и каковы его особенности?

 

 Объект, который позволяет лицезреть печатную форму это: ОбщаяФорма.ПечатьДокументов

 

Справа снизу расположено больо-шо-ое поле табличного документа с именем ПечатнаяФормаОбразец. И при беглом осмотре внешней печатной формы можно подумать, что именно в него и выводится печатная форма. Но это не так, всё на много интереснее.

 Реквизиты, куда выводится печатная форма создаются динамически в процедуре Форма.ПечатьДокументов.МодульФормы. СоздатьРеквизитыИЭлементыФормыДляПечатныхФорм(КоллекцияПечатныхФорм). Эти реквизиты добавляются в таблицу значений «НастройкиПечатныхФорм», которая выведена в форму в конфигураторе, но сокрыта от пользовательских глаз. Именно эту таблицу значений мы и видим слева в окне формы в конфигураторе.

 Если, например, посмотреть в отладчике, какой будет создан реквизит для внешней печатной формы документа СчетНаОблатуПокупателю (файл печатной формы прилагается к данной статье), то обнаружим, что имя реквизита, который добавляется в НастройкиПечатныхФорм будет  «ПечатнаяФорма1». Реквизит будет размещен на форме динамически на странице с именем «СтраницаПечатнаяФорма1». Кому интересно в деталях, может покопаться с отладчиком в процедуре СоздатьРеквизитыИЭлементыФормыДляПечатныхФорм

Обратиться к полю табличного документа можно так:

 ИмяРеквизита = ‘ПечатнаяФорма1’;

 …ЭтаФорма[ИмяРеквизита]…

  Разумеется, это обращение должно происходить уже после того, как реквизит будет создан. Упомяну, что процедура СоздатьРеквизитыИЭлементыФормыДляПечатныхФорм вызывается из процедуры  ПриСозданииНаСервере.

 Зачем сие знание может понадобится? Ну, допустим, если вы захотите сделать какую-то свою рассылку документов по e-mail, не влезая и не меняя типовые механизмы, а просто по отдельной кнопочке… Или вам вдруг понадобилось сделать что-либо протевоестественное, скажем, с шапкой сформированной печатной формы ну, допустим, заменить слово «Номенклатура» на «Наш товар», а макет менять не хотите, ибо заказчик может потом и передумать J … В общем, может пригодиться.

 Что знает печатная форма о данных объекта-владельца и как она это знает?

  В модуле формы ОбщаяФорма.ПечатьДокументов доступны параметры формы, что не удивительно.В процедуре ПриСозданииНаСервере() доступно, в частности: Параметры.ПараметрыИсточника.ОбъектыНазначения

  Это массив строк. Параметры.ПараметрыИсточника.ОбъектыНазначения[0].Ссылка – даст ссылку на первый из объектов, для которого производится печать. Из этой ссылкми можно, в частности, взять контрагента, а из контрагента, скажем, адрес для отправки e-mail.

 Как подменить стандартную печатную форму внешней

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

 

Механизм прав и ролей в БП 3.0.24.9

В БП 3.0.24.9 механизм прав и ролей на уровне приложения выглядит следующим образом. Основной правообразующей единицей для пользователя является профиль групп доступа. Пользователю добавляют профили. А профиль, в свою очередь состоит из ролей, определенных на уровне конфигурации. Профиль как бы «собирается» из различных ролей, а каждая из ролей определяется в конфигураторе.

 

В БП 3.0.24.9 имеются предопределенные профили.

 

 

Но можно создать и собственный профиль. В моем случае это профиль «менеджер».

В моем профиле только одна роль.  Эта роль полностью определяет возможность работы менеджера. Это новая не типовая роль, созданная мной. Почему только одна и почему новая, а не использована суперпозиция стандартных ролей. Например, можно было бы создать роль с каким-то специфическим доступом к тем или иным объектам конфигурации, включить ее в профиль «Менеджер», а пользовател. Назначить два профиля – «Менеджер» и «Только просмотр».

 

В моем случае камнем преткновения стала панель разделов. Мне нужно оставить в ней только «Рабочий стол» и новый раздел «Менеджеру», а всё остальное убрать. Назначение стандартных ролей через какой-либо профиль гарантированно добавляет в панель разделов «стандарнтые» разделы, которые мне не нужны.

 

Что бы было понятно, какую картинку должен получить мой менеджер, приведу скриншот, ради которого я и создал роль. Я бы убрал еще и «Рабочий стол», но, увы рабочий стол убрать нельзя.

Добавление профиля группы доступа осуществляется через Администрирование --> Профили групп доступа.

Пользователю назначается профиль так: Администрирование --> Пользователи -->[Выбрать пользователя] --> Права доступа

 

Не могу добавить новую роль в профиль, что делать?

 

Была такая беда. Создал я новую роль и хотел добавить ее в профиль группы доступа, но БП 3.0.24.9 обругала меня вот так, когда я в окне профиля группы доступа нажал на кнопку «Записать и закрыть».

 


 

 

Оказывается, в БП 3.0.24.9 есть справочник «Идентификатор объектов метаданных», в котором присутствует описание метаданных конфигрурации. В ряде ситуаций конфигурация требует, чтобы новые объекты присутствовали в этом справочнике. Зачем? Вопрос опять же риторический. А потому что!

 

Справочник «Идентификатор объектов метаданных» выглядит примерно так.

 

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

А называется она «ИнструментыРазработчикаОбновлениеВспомогательныхДанных.epf» (не верьте окну-ругательству), а берется она из Библиотеки Стандартных Подсистем. Ставите БСП, сохраняете обработку, как внешнюю и запускаете. В результате увидите такое вот прекрасное окно:

 

Я выбрал «Обновлять всё» и нажал на «Обновить». После этого стало возможно добавить мою новую роль в профиль доступа.

Где взять БСП.

Скачать последнюю версию с http://users.v8.1c.ru. Я устанавливал БСП 2.1.6.5, хотя уже есть и свежее.

 

 

Где взять описание БСП

 

 http://its.1c.ru/db/bspdoc#browse:13:-1:50001

 

 

THE END

Бухгалтерия предприятия 3.0

См. также

СКД Механизмы типовых конфигураций Запросы Программист Платформа 1С v8.3 1С:Зарплата и кадры государственного учреждения 3 1С:Зарплата и Управление Персоналом 3.x Россия Бесплатно (free)

Работая с типовыми отчетами в конфигурациях «Зарплата и управление персоналом, редакция 3», «Зарплата и кадры государственного учреждения, редакция 3» и подобных, в схемах компоновки данных можно встретить конструкции запросов, которые обращаются к некоторым виртуальным таблицам.

20.08.2024    1016    PROSTO-1C    0    

15

Механизмы типовых конфигураций Программист Платформа 1С v8.3 1С:Комплексная автоматизация 2.х Россия Бесплатно (free)

Эта ошибка была обнаружена мной в типовой конфигурации 1С:Комплексная автоматизация 2 (2.5.16.115), БСП версия 3.1.9.302. Возникает она после того, как вы добавляете в расширение бизнес-процесс или задачу, выполняете обновление идентификаторов метаданных расширений, но ошибка при записи любого элемента справочника "Профили групп доступа" всё равно остаётся.

01.07.2024    1212    Vidz    0    

8

Механизмы типовых конфигураций Программист Платформа 1С v8.3 Конфигурации 1cv8 Россия Бесплатно (free)

Очень часто в написании кода требуется обращаться к предопределённым значениям. Если идёт обращение к типовым предопределённым значениям, то проблем не возникает.

24.06.2024    919    olja-ljaaa    0    

3

Механизмы типовых конфигураций Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Статистическая выборка сценариев и точек изменения отчетов на общей форме ФормаОтчета в типовых конфигурациях. Примеры кода.

03.06.2024    3879    Serg2000mr    32    

104

Механизмы типовых конфигураций Ценообразование, анализ цен Программист Пользователь Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Россия Абонемент ($m)

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

1 стартмани

11.04.2024    900    tango    5    

3

Механизмы типовых конфигураций Программист Платформа 1С v8.3 1С:Управление торговлей 11 Россия Абонемент ($m)

Какому-либо элементу списка сопоставляется числовое значение, зависящее от других значений, причем эта зависимость изменяется от элемента к элементу. Так, в справочнике "Валюты" курс какой-либо валюты может быть задан формулой (или даже запросом) от значения другой валюты. А в справочнике "Виды цен" формула определяет расчет цены для товарной позиции, т.е. элементов справочника "Номенклатура", у которых в карточке указан этот вид цены. А в 1С:ERP, например, этот механизм используется в ресурсной спецификации.

10 стартмани

11.04.2024    779    tango    5    

4

Механизмы типовых конфигураций Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Россия Бесплатно (free)

В первом сезоне мы рассмотрели (с точки зрения программиста) внутренний механизм, помещающий цены в регистр "Цены". Из этого регистра цена попадает в исходящие УПД (в продажи). Но эта цена (в прайс-листе) дифференцирована (ценообразована) в разрезах свойств самой номенклатуры. Но стратегия ценообразования, ценовая власть - это в первую очередь о работе с ценами для клиента. И тут вступает в дело второй акт марлезонского, Скидки (наценки) и кешбек.

08.04.2024    1065    tango    0    

2
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. krein 63 18.09.14 21:38 Сейчас в теме
Вместо использования обработки из БСП еще как вариант можно просто в конфигураторе в "Сервис - Параметры"
на закладке "Запуск 1с:Предприятия" "Параметр запуска" установить = ЗапуститьОбновлениеИнформационнойБазы
и запустить отладку
Или сделать ярлык либо в командной строке запустить 1с с праметром /с ЗапуститьОбновлениеИнформационнойБазы
(тут надо обратить внимание, что в "/c" с- это английская буква, т.к. если скопировать из описания 1с - она почему-то оказывается русской и не очень очевидно в чем проблема при запуске)

Способы не новые и все их можно найти в интернете,
т.к. проблема частая и проявляется в том числе при добавлении многих объектов метаданных - например нового документа...
CratosX; TerveRus; +2 Ответить
2. scape 282 24.09.14 11:36 Сейчас в теме
С начала этого года пытались с клиентом перейти на 3.0, обновив 2.0. Исходная конфигурация содержит много доработок. При помощи бубна удалось обновить конфигурацию. Но, что характерно, 1с обошла несовместимость алгоритмов проведения, просто установив флажок ручной корректировки проводок в некоторых документах. Эксперимент показал, что если снять флажок и перепровести документ, получим не тот результат который был до проведения. Клиента такой вариант не устроил, со следующего года переходит на 3.0 через остатки. Другие клиенты высказали такое же мнение.
3. Трофимов_Николай 25.09.14 20:28 Сейчас в теме
В начале года пытались также перейти С БП 2.0 на БП 3.0. через обновление конфигурации.Столкнулись с низкой производительностью конфигурации+несовместимость некоторых алгоритмов по ЗП.Решено с 2015 переходить с перенесением остатков в чистую конфигурацию.
4. Puk2 190 06.10.14 10:03 Сейчас в теме
Обновили 3 базы, одна из них была с "криводоработками", к которым бухи привыкли. Обновились с 2.0 до 3.0 среди года. 2 конфы почти типовые, их бухгалтеры вроде как вообще довольны. Встречаются документы с ручной корректировкой, но проанализировав не увидел ничего страшного, перепроведение, как правило, даёт тот же результат после переноса кода из старой версии. Да и так бухгалтерскую операцию и корректировку проводок часто используют, за что руки готов побить тому, кто их к этому приучил, поэтому сравнил ОСВ в двух базах и вперёд, т.к. расхождений не было.
5. Puk2 190 06.10.14 10:05 Сейчас в теме
кстати, теперь финансисты подключаются к базам филиалам напрямую, без всяких РИБов, которые меня задолбали совсем не радовали. Скорость отличная через тонкого клиента!
6. Puk2 190 06.10.14 10:20 Сейчас в теме
Ставите БСП, сохраняете обработку, как внешнюю и запускаете.


Не знаю как раньше, но выпуски этого года хранят внешние обработки в папках шаблонов конфигураций по адресу %AppData%\1C\1cv8\tmplts\1c\SSL\2_2_3_41\ExtFiles\Инструмент­ы разработчика
7. hazd 12.10.14 00:54 Сейчас в теме
тоже предстоит перевод с БП 2.0 на БП 3.0((, возьму на заметку
8. Stim213 415 07.11.14 10:29 Сейчас в теме
мда.. описание в целом полезное, но часть информации из серии "не знаю зачем, но нажимайте эту желтую кнопку"

"Оказывается, в БП 3.0.24.9 есть справочник «Идентификатор объектов метаданных», в котором присутствует описание метаданных конфигрурации. В ряде ситуаций конфигурация требует, чтобы новые объекты присутствовали в этом справочнике. Зачем? Вопрос опять же риторический. А потому что!"
Справочник нужен для того, чтобы его можно было использоваться в профилях групп пользователей.
В профиле должны указываться роли(в табличной части элемента). Но так как сами роли как метаданные не представлены в пользовательском режиме и вообще недоступны как ссылки на объекты - сделали такой справочник, в котором хранят идентификаторы объектов МД. Справочник чисто служебный, недоступный для ручного изменения.
Обновление или спец обработку запускать не обязательно, достаточно выполнить экспортную функцию:
Справочники.ИдентификаторыОбъектовМетаданных.ОбновитьДанныеСправочника(ИСТИНА,ЛОЖЬ,ЛОЖЬ);//ЕстьИзменения, ЕстьУдаленные, ТолькоПроверка

Если вы добавили новую роль, то помимо обновления вышеуказанного справочника необходимо еще и обновить значение константы ПараметрыРаботыПользователей. Константа содержит в себе структуру связей ролей и профилей. Через неё работает обратная связь, когда вы в реж Предприятия назначаете пользователю профиль групп пользователя, а пользователю ИБ назначаются роли этого профиля.
Обновить значения константы можно так:
Константы.ПараметрыРаботыПользователей.СоздатьМенеджерЗначения().ОбновитьОбщиеПараметры();


И когда назначаете профили пользователям - создаются элементы спр ГруппыДоступа, в которых и хранятся связки пользователь-профиль

про программную работу с доступом и правами можно почитать в http://infostart.ru/public/300363/
Оформление потом допилю)
9. Душечка 70 30.01.15 23:27 Сейчас в теме
Огромное спасибо за статью. Очень приятно, когда люди делятся своим опытом. Я не программист, поэтому рада любой помощи, любому совету. Моя розовая мечта, создать с нуля внешнюю печатную форму, а не качать с инфостарта. Буду пытаться с Вашей помощью осуществить свою мечту.
AlexandrIII; +1 Ответить
10. kosmonavtka 16 22.06.15 19:21 Сейчас в теме
Огромное спасибо за статью! Очень актуально сейчас.
11. prestige 15.10.15 17:40 Сейчас в теме
Оставьте свое сообщение