Когда интерфейсам 1С нужны веб-технологии

15.10.21

Разработка - Работа с интерфейсом

Есть несколько способов сделать интерфейс в 1С богаче и оптимальнее с помощью веб-технологий. О том, какие практические приемы помогут в этой задаче, на митапе «Интерфейс в 1С» рассказали руководители разработки в компании «Арбис» Матвей Серегин и Анна Гнатюк.

Расскажу о примерах использования веба внутри интерфейса 1С. Все примеры, которые буду показывать – это наши реальные разработки. Какие-то уже внедрены, какие еще находятся на стадии проектирования.

 

Предпосылки

 

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

 

 

  • В первую очередь – интерфейс 1С хоть и гибок, но только в рамках своих основных задач. Исторически это именно учетные задачи.

 

 

  • Несмотря на это, в приложениях 1С все больше и больше внимания уделяется бизнес-задачам – автоматизации процессов, общению, документообороту.

 

 

  • На фоне других аналогов подобных программ пользователи уже очень сильно привыкли к хорошему, и не готовы мириться с «суровым Enterprise» даже для решения каких-то сложных задач.

 

 

  • И последний момент – сейчас веб-верстка отчасти становится новым стандартом интерфейсов.

На экране вы видите примеры десктопных приложений, которые для вывода своего интерфейса используют такой движок, как Electron – он позволяет использовать для вывода интерфейса связку HTML+JS+CSS. Все эти приложения плюс Skype, плюс Spotify и т.д. для вывода своих функций в интерфейс используют именно веб-технологии.

 

Несколько примеров в сравнении с 1С-интерфейсами

Маркетинговая информация. Лендинги, отображение видео и аудио

 

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

Стандартно в 1С сейчас маркетинговая информация выглядит как на слайде – это информация, но спорно судить, насколько она привлекательна.

Даже если это баннеры – здесь спорный вопрос.

В то же время с помощью веба вы можете произвольным образом скомпоновать эту информацию, выделить более важные элементы.

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

Вы можете вовлечь пользователей, показав им какую-то статистику в красивом виде. Также вы можете добавить видео, аудио и все это – прямо в вашем приложении.

 

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

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

В этом случае мы можем применить веб и сделать гибкую и настраиваемую визуализацию данных:

  • подсветить те элементы, которые нужны;

  • показать ховером какую-то дополнительную информацию;

  • вставить любые графики и любые диаграммы, сделать их интерактивными – например, по клику на какой-то сегмент у нас будет обновляться правая часть интерфейса;

  • сделать вкладки, написать на вкладках не только одно слово и циферку в скобках, но и вывести какую-то дополнительную информацию.

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

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

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

 

CRM и канбан-доски. Обработка нестандартных событий: перехват движения мыши, перетаскивания, ховеры

Пример CRM. УНФ – прекрасное решение. Согласна, что ребята действительно с душой относятся к тому продукту, который они делают. Они много поработали над CRM, они действительно создали аналог поведения сервисов – таких, как AmoCRM, Битрикс24 и других популярных сейчас продуктов на рынке CRM.

Но что, если хочется сделать это еще лучше и еще ближе к конкурентам – где-то даже лучше по опыту использования?

В этом случае вы можете применить веб.

Благодаря обработке кастомных событий, таких как перетаскивание, нажатие на клавиши клавиатуры, скролл, ховер – вы дадите своим пользователям еще более классный опыт использования продукта. И при этом пользователь до сих пор останется в вашем приложении 1С и по клику на карточку сможет, например, открыть контрагента. И его банковский счет, все элементы бухгалтерского учета, которые у него будут тут же под рукой. Не теряя при этом удобства использования такой бизнес-функции, как CRM.

 

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

И то, чего в 1С практически нет, но бизнес-задачи все больше требуют – это мессенджеры. Ближайший аналог – это обсуждения в 1С, но они достаточно закрытые и сами в себе находятся. Мы же с помощью веба реализовали в том числе вот такую ленту, куда сыпятся сообщения из нашего личного кабинета клиента и из разных мессенджеров плюс почта, IP-телефония и т.д.

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

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

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

Точно так же у вас. У вашего клиента будет мобильное приложение, где гораздо проще (если это нативное приложение, или приложение на веб-технологиях), реализовать удобный дизайн чата, ваш пользователь 1С-приложения сможет поддержать диалог из вашей программы.

 

Списки файлов

Еще один кейс – это списки файлов. Стандартно в форме «Архив файлов» у нас есть иконка для расширения плюс название файла.

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

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

 

Пошаговые мастеры

И еще один небольшой пример – это пошаговые мастеры, которые вовлекают пользователя в ваши интерфейсы и в ваши функции простыми средствами. Это значительно снижает порог вхождения и порог использования вашего приложения. Эти мастеры можно сопроводить красивыми иллюстрациями.

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

 

Способы внедрения

 

Я продемонстрирую несколько приемов, которые позволяют нам отображать такие интерфейсы и расскажу, каким образом вы можете это сделать в своих решениях.

Мы рассмотрим три варианта:

  • Самый простой – когда мы полностью формируем HTML внутри 1С-приложения и отдаем ее на форму.

  • Второй вариант – когда мы взаимодействуем с динамическим списком и справа от него показываем предпросмотр документа.

  • И третье – полнофункциональное приложение, полнофункциональный компонент, который самостоятельно взаимодействует с базой.

 

Частичное внедрение веб-технологий – в зависимости от параметров собираем HTML и отдаем на форму

 

Чтобы реализовать на форме 1С веб-интерфейс, нам нужен некий шаблон, который подготовит веб-разработчик (фронтэнд-разработчик или верстальщик).

В первом примере у нас есть простой шаблон, который выводит одну картинку. Наша задача – предсобрать на основе этого шаблона страницу так, чтобы картинка могла выводиться несколько раз динамически.

 

 

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

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

 

Техническая реализация

 

 

Для генерации такой страницы применяем классическую работу со строками.

  • при изменении реквизита «КоличествоСтрок» заполняем поле HTML – берем элемент шаблона с id=“gallery__row” (его мы будем заменять на наш набор баннеров);

  • далее с помощью функции Изображение(URLКартинки) объединяем баннеры (соответствующие шаблоны) в массив;

  • далее этот массив строк просто соединяем и вставляем в нужное место HTML – переопределяем содержимое элемента с id=“gallery__row”.

 

 

В макете HTML у нас находится простой шаблон, в котором задан CSS и непосредственно само тело HTML, где есть div с id=”gallery__row”, содержимое которого у нас переопределяется в коде.

Минусы такого подхода:

  • нет интерактивности;

  • когда пользователь меняет какие-то параметры отображения, нам приходится пересобирать всю HTML – если она сложная, если скрипты на отрисовку данных сложные, плюс если нам нужно поменять всего один элемент, то мы выполняем избыточно много кода, создаем много нагрузки на клиентскую машину.

Это – самый простой вариант работы с веб в 1С.

 

Частичное внедрение веб-технологий – взаимодействуем с динамическим списком и справа показываем предпросмотр

 

 

Я сделал небольшой пример, как мог бы выглядеть предпросмотр в списке документов на 1С. Допустим, задача следующая – у нас есть список документов, и нам нужно обеспечить предпросмотр. При этом, если в документе всего одна строка табличной части, то реквизиты выводятся как отдельные элементы управления.

 

 

Если несколько строк – то это выводится как таблица.

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

Такую задачу можно решить целиком на 1С. Единственный минус – иногда управление свойством видимости отдельных элементов управления влечет контекстный вызов.

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

  • изменение заголовка декорации – с помощью нее мы можем выводить форматированную строку;

  • изменение флага видимости у определенных элементов формы;

  • ряд других моментов.

Контекстный серверный вызов приводит к тому, что при перемещении по строкам такой динамический список автоматически прокручивается, «прыгает» – из-за таких перерисовок списка пользователь может пропустить какие-то элементы.

 

 

Альтернативное решение – то же самое, сделанное с помощью веб-технологий.

Список оформлен в самом простом варианте – просто чтобы мы просто могли посмотреть, как это выглядит. Однако здесь оно работает чуть шустрее, потому что у нас нет контекстных серверных вызовов, мы не работаем с элементами управления, мы просто меняем строку в шаблоне. Плюс – динамический список не «прыгает». Это в дополнение к тому, что здесь можно сделать любое оформление, запихать сюда какие-то графики, диаграммы, которые могут динамически меняться – все, что угодно.

Функциональность по смене комментария здесь тоже поддерживается – комментарий у документа в базе данных сразу же поменялся. Соответственно, мы можем перехватывать события у элементов управления.

 

 

Также сохранена возможность перехода по ссылкам. Если мы нажимаем на клиента, у нас открывается соответствующая форма, если мы нажимаем на товар, у нас тоже открывается соответствующая форма номенклатуры.

 

Техническая реализация

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

 

 

Во-первых, у нас есть форма, на которую добавлен реквизит «Строка» и выведен в качестве поля HTML-документа.

 

 

Также у нас подготовлен шаблон HTML, на основе которого мы выводим. Этот шаблон можно открыть в браузере – веб-разработчик на старте обычно работает с ним. Он выглядит вот таким образом.

 

 

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

 

 

И далее – есть инициализирующий скрипт, где мы объявляем переменную app, которая отвечает за отрисовку. И инициализируем ее с помощью вызова специальной функции, передавая в качестве параметра простой текст в формате JSON.

 

 

Этот HTML-шаблон у нас хранится в макете документа.

  • В целом, хранение в макете – один из вариантов.

  • Можно также помещать это во временное хранилище – платформа может оттуда доставать.

  • Либо в качестве альтернативы, можно хранить на каком-то веб-сервере в качестве статики.

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

 

 

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

 

 

И далее, при активизации строки, если у нас документ сформирован (все начальные скрипты отработали), мы добавляем новые скрипты по отрисовке.

 

Проверка, что документ сформирован

 

 

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

Есть особенность, что событие «ДокументСформирован» для поля HTML-документа в Windows вызывается 2-3-4 и более раз. При этом не всегда понятно, когда он действительно сформирован.

Соответственно, мы проверяем:

  • есть ли вообще тело документа;

  • есть ли длина у вложенных элементов;

  • если они определены, то уже проверяем готовность.

Если готовность – “complete”, значит, все скрипты уже отработали, и мы можем добавлять свои кастомные скрипты для отрисовки интерфейса, для вывода информации.

 

Добавление скрипта для отрисовки интерфейса

 

 

Как мы добавляем скрипт?

 

 

Во-первых, мы получаем с сервера информацию о документе – это простой запрос с отбором «по ссылке».

 

 

Далее мы собираем структуру, в которую в том числе помещаем структуру из массива строк «Товары» – комбинация из структур, массивов и примитивных типов наиболее хорошо преобразуется в JSON.

 

 

И затем простой функцией преобразовываем данные документа в JSON-строку.

Сам исполняющий код выделен. Все остальное – обертка для универсальности.

 

 

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

 

 

Далее – мы формируем скрипт. Здесь к тексту скрипта добавляется метод app.Init(), который задан фронтэнд-разработчиком – мы его вызываем и передаем туда JSON.

В результате, на форме уже полностью через JavaScript отрисовывается необходимая информация.

 

Перехват комментариев

Как нам перехватить комментарии – как в принципе получить обратную связь от элемента управления поля HTML-документа.

 

 

Определенные события, которые существуют в JavaScript, можно перехватывать с помощью соответствующих обработчиков, которые можно добавлять с помощью типовой платформенной функции ДобавитьОбработчик.

  • Указываем событие определенного элемента управления внутри поля HTML-документа – ПолеКомментарий.onblur

  • И далее указываем, какую процедуру мы будем подвешивать на этот обработчик – ОбработчикHTMLКомментарийПриИзменении.

В процедуре ОбработчикHTMLКомментарийПриИзменении мы из события, которое нам передано в качестве параметра, достаем значение поля Комментарий. И просто неконтекстным вызовом передаем это значение на сервер с параметрами Ссылка и строка комментария, где документ перезаписывается.

Далее обновляется список, и мы в нем видим новые данные.

 

Переход по ссылке

И еще один момент интерактивного взаимодействия – это переход по ссылке.

 

 

В демо-примере показано два способа обработать нажатие в поле HTML.

Во-первых, мы можем просто с помощью тега href повесить на элемент управления ссылку – тогда при нажатии на этот элемент у нас сработает переход по ссылке.

Внутри 1С можно использовать протокол e1c – для любого объекта мы можем сформировать внутреннюю навигационную ссылку и далее с помощью простого метода БСП перейти по этой ссылке. Также здесь могут быть любые поддерживаемые операционной системой ссылки.

Кроме этого, с помощью гиперссылок мы можем создавать какие-то свои кастомные события. Например, если мы повесили сюда ссылку, которая начинается на «demo», то передавая туда какие-то строки в качестве параметров, дальше мы смогли бы подвесить на такие ссылки абсолютно любой свой алгоритм – можно открыть отчет, можно открыть поверх форму, можно закрыть форму. Абсолютно любой алгоритм, который имеет смысл выполнять в контексте клиента с точки зрения 1С.

 

 

Еще один способ взаимодействия – это прокси-кнопки.

При формировании шаблона мы можем создать скрытую кнопку и далее в любой момент – здесь уже нет привязки к типовым событиям JavaScript – нажать эту кнопку программно (вызвать ее срабатывание). В этом случае туда также можно передать любые данные.

Это нам позволяет делать какие-то таймеры внутри JavaScript или другие процедуры, которые должны выполняться при определенных обстоятельствах, но без реакции пользователя.

Например, он опрашивает какой-то внешний веб-сервис прямо из поля HTML-документа. Если что-то произошло – изменилась погода, поступил телефонный звонок, позвонили в дверь и т.д. – то он открывает форму в 1С или выполняет другое действие.

 

Отладка макетов HTML внутри 1С

Немного о том, каким образом фронтэнд-разработчику обеспечить работоспособность этого решения внутри 1С.

Несмотря на то, что, начиная с 14-й версии платформы у нас в качестве движка для поля HTML-документа используется встроенный браузер, являющийся форком WebKit (у фирмы «1С» есть отдельная статья на хабре о том, как они совершенствовали поле HTML-документа), поведение этого браузера отличается от того же Chrome. Это просто еще один браузер, под который хоть и привычными способами, но тем не менее, нужно адаптировать верстку.

 

 

Для отладки HTML-макетов есть достаточно простая обработка.

Внутри этой обработки выведено два элемента управления:

  • одно – это строка для того, чтобы можно было выбирать конкретные файлы;

  • второе – это поле HTML-документа, где у нас будут отображаться данные шаблона.

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

 

 

Более того, во встроенный браузер встроены инструменты разработчика – их можно открыть с помощью комбинации клавиш Ctrl+Alt+Shift+F12.

Снизу у нас появляются инструменты разработчика, здесь мы можем привычным способом, как в инструментах разработчика в Chrome, смотреть, отлаживать весь фронтенд – использовать консоль, вызывать дополнительные скрипты и т.д.

Например, мы хотим проверить, как работает тот или иной скрипт. Мы можем взять шаблон, скопировать из него сюда скрипт для заполнения – например, поменяем здесь комментарий на «Привет IS». Выполняем скрипт – у нас поменялся отображенный.

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

 

Полноэкранное внедрение веб-технологий – полнофункциональный компонент, который самостоятельно взаимодействует с базой

 

Еще один вариант применения веб-технологий – это непосредственное взаимодействие веб-компонента с сервером 1С.

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

Однако если от поля HTML-документа требуется более сложная функциональность, тонкий клиент будет только увеличивать время отклика – в этом случае мы можем реализовать схему прямого взаимодействия. Единственный нюанс, что она не работает в тонком клиенте с файловой базой, поэтому я продемонстрирую работу в браузере.

 

 

Здесь у нас выводится список справочника контрагентов, куда для демонстрации добавлено 10 тысяч элементов.

Есть регистр сведений, в котором просто хранится число – количество заявок

И у нас есть функциональность «Добавить заявку» и «Обработать заявки»

По умолчанию в список загружается 20 элементов. Когда мы прокручиваем до нужной позиции, динамически подгружаются следующие элементы.

 

 

И еще работает поиск – он работает сравнимо с полнотекстовым поиском в динамических списках.

 

 

Также мы перехватываем открытие.

 

 

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

 

Техническая реализация

 

 

С технической стороны это реализовано следующим образом.

Есть очень простая обработка. При ее вызове мы получаем параметры сервера.

 

 

В параметры сервера включается адрес сервера и настройка cookie.

Здесь применяется один интересный хак, как получить идентификатор текущего сеанса. Мы получаем идентификатор текущего сеанса из адреса временного хранилища – с недавней версии платформы в адрес временного хранилища включен параметр seanceId, который используется для взаимодействия между клиентом и сервером, для отправки запросов. Соответственно, мы можем поместить что-то в хранилище, получить его адрес, выдернуть оттуда seanceId и дальше использовать для своих запросов.

Этот seanceId мы передаем в шаблон в качестве Cookie и у нас получается структура параметров с полями «url» и «cookie».

 

 

Больше со стороны тонкого клиента мы никакие команды в поле HTML-документа не отправляем – только перехватываем его нажатие, если необходимо перейти по ссылке.

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

 

 

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

 

 

Внутри методов обработки заявок и добавления заявки простейший код, который вызывает функции общего модуля.

 

 

В функции ОбработатьТекущиеЗаявки мы просто пишем набор записей с отбором, в функции СоздатьНовуюЗаявку – увеличиваем количество заявок в регистре.

 

 

Чуть более сложный код по получению данных клиентов.

Здесь передаются определенные параметры – начиная с какого элемента какое количество получить, реализуется логика пагинации.

 

 

Дальше формируется простой запрос.

Параметры, которые нам переданы, через схему запросов подставляются в сам запрос.

 

 

Формируется текст запроса – он выполняется, и результат заворачивается в JSON так же, как это было в варианте с отображением документа.

JSON возвращается HTTP-сервису в качестве ответа, и далее JavaScript стандартным образом эти данные у себя отображает.

 

Три варианта технической реализации, проверенные практикой

 

Итого, мы рассмотрели три варианта использования веб-технологий для формирования интерфейса в 1С:

  • 1С получает данные, формирует HTML на сервере. JS реагирует на события.

  • 1С получает данные, вызывает методы JS. JS формирует HTML.

  • JS получает данные от 1С через HTTP-сервис и формирует HTML.

 

Выводы, плюсы и минусы использования веб-технологий для 1С

 

Аналогичный подход позволяет реализовать интерфейс, аналогичный по внешнему виду и функциональности современным веб-решениям. Это могут быть карты, это может быть видео, это может быть сложная графика, это могут быть сложные диаграммы – что угодно, что вы видите у себя в браузере, можно сделать здесь.

Но существуют и определенные минусы.

  • Во-первых, такой подход требует достаточно много ресурсов – требуется отдельный дизайнер, фронтенд-разработчик, бэкенд-разработчик (или разработчик 1С, который знает бэкенд). Если мы используем последний вариант, который я демонстрировал, то HTTP-сервисы должны быть написаны в соответствии с принципами бэкенд-разработки. Потому что фронтенд будет строиться на каких-то типовых библиотеках – это может быть Vue, React. Это может быть все, что угодно, а в самих этих библиотеках уже какие-то подходы заложены. Соответственно, это кратно увеличивает стоимость разработки – на 3-4 и более раз.

  • Обязательно нужно согласовывать модель данных между 1С-разработчиком и фронтенд-разработчиком, потому что 1С в данном случае выступает уже не просто как приложение, а бэкенд, который делает API. Это несколько другие правила игры, несколько другие профессиональные требования.

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

 

Вопросы

 

Нет диссонанса видеть форму предпросмотра в веб, а при открытии – обычную форму документа?

Диссонанс есть, поэтому сейчас мы стараемся либо полностью разрабатывать форму на веб, либо на 1С. Когда это соседствует, тоже сложно. Есть вариант полностью имитировать элементы 1С-интерфейс с помощью веб-технологий, но у нас в приоритете все-таки оказалось более качественное решение отдельных задач и предоставление пользователю современных интерфейсов хотя в части приложений.

Обычно на веб-технологиях решаются какие-то сложные дашборды, которые не реализовать внутри 1С. Например, стартовая форма в 1С:Документооборот или 1С:Бухгалтерия предприятия – она тоже отличается от остальных, но, в целом, не вызывает диссонанса.

При реализации через HTTP-сервисы как реализуете аутентификацию?

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

Если такой метод по каким-то причинам не подходит, то просто инициализируется сеанс, получается токен, токен сохраняется в регистре. И клиент тогда будет дергать анонимный HTTP-сервис и при вызове будет проверяться токен. Единственное, это будет работать медленнее.

Можно ли посмотреть демобазу?

Мы обсудим с коллегами возможность публикации. Если нам позволят обстоятельства, выложим.

Почему не использовали React, Vue.js? Или использовали?

У нас разработка в продуктиве крутится сегодня большей частью на Vue. Сейчас для демонстрации не использовали, потому что такие простые вещи быстрее накидать на стандартном js.

 

*************

Данная статья написана по итогам доклада (видео), прочитанного на онлайн-митапе "Интерфейс в 1С".

См. также

Работа с интерфейсом Системный администратор Программист Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Платные (руб)

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

5000 руб.

14.01.2016    55306    17    23    

43

Работа с интерфейсом Рабочее место Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Платные (руб)

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

6000 руб.

16.01.2015    63700    44    59    

82

Работа с интерфейсом Программист Платформа 1С v8.3 Конфигурации 1cv8 1С:ERP Управление предприятием 2 Платные (руб)

Обработка предназначена для создания и управления дашбордами.

2400 руб.

29.06.2020    19550    27    6    

42

Работа с интерфейсом Программист Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Россия Платные (руб)

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

1500 руб.

06.10.2020    10768    7    7    

11

Работа с интерфейсом Программист Стажер Платформа 1С v8.3 Бесплатно (free)

Это инструкция по дизайну форм в среде 1С. Гайд охватывает рекомендации и стандарты для оптимизации пользовательского интерфейса. В гайде содержатся указания по использованию элементов интерфейса, включая как основные, так и продвинутые аспекты. Предоставляются также примеры и антипримеры для наглядного понимания принципов дизайна

20.08.2024    20833    mrXoxot    44    

128

Работа с интерфейсом Программист Платформа 1С v8.3 Бесплатно (free)

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

27.05.2024    10317    smielka    37    

105

Работа с интерфейсом Платформа 1С v8.3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 Бесплатно (free)

Добавьте новогоднего настроения! Расширение создает декорацию в виде гирлянды на некоторых формах объектов.

27.12.2023    17745    1223    elcoan    53    

125
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. VVi3ard 52 15.10.21 14:00 Сейчас в теме
Интересно было бы именно в части использования react/vue посмотреть.
Я пытался сам сделать но возникают проблемы с расположением файлов, приходится всё паковать в один файл.
2. Akcium 359 15.10.21 17:48 Сейчас в теме
(1) в этом случае мы распологаем веб-содержимое отдельно на веб-сервере и в соответствующем полю HTML документа реквизите формы прописываем ссылку на html страницу. В этом случае платформа сама подтягивает нужные дополнительные файлы и при возможности кэширует их.
3. VVi3ard 52 16.10.21 13:07 Сейчас в теме
Да но тогда не понятно как все это поставлять (продавать) заказчикам и потом поддерживать, ведь многие даже клиент сервер не используют а мы к ним приходим и говорим что поставьте веб сервер, сделайте публикацию. Потом же это обновлять ещё как то надо при установке обновления. Такое вообще пройдет сертификацию 1С?
4. Akcium 359 17.10.21 21:24 Сейчас в теме
(3) если решение продается как коробочное и при этом на рабочих местах нет доступа к интернету, то такая схема действительно будет сложной для развертывания на внедрениях, где используется файловая база.

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

В части требований к 1С:Совместимо решение не анализировал, но на первый взгляд проблем при сертификации не должно возникнуть.
5. VVi3ard 52 17.10.21 23:07 Сейчас в теме
(4)
- если на рабочих местах есть доступ в интернет, то можно разместить необходимые файлы на облачном сервере и загружать веб-содержимое из интернета;

Это требует дополнительной инфраструктуры на стороне разработчика, при этом становится единой точкой выхода из строя, затрудняет работу с релизами, под каждый релиз нужен свой сервис (т.к. не все сразу обновятся, а многие вообще не будут обновляться по году) соответственно нужно для каждого релиза поддерживать соответствующий сервис. Плюс интернет то может и есть но не в таком количестве что бы формы хорошо работали.
Как вообще в таком варианте всё кешируется? Т.е. вот например у хром я понимаю как кэш работает и где лежит, а у тонкого клиента для поля html документа как работает кеширование? Не получится ли что ваша коробка которая стучится к вам на сервер, проданная под 2000-3000 установок положит его?


(4)
- если интернета может не быть, но внедрение относительно крупное (клиент-серверный режим), то можно подготовить инструкцию для размещения веб-содержимого на веб-сервере или использовать http-сервисы конфигурации, чтобы выдавать нужные файлы (это будет работать медленнее публикации на веб-сервере при первом получении).

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

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


Да в этом случае уже понятно что есть админы которые все развернут настроят и тут вопрос отпадает.
6. Akcium 359 17.10.21 23:12 Сейчас в теме
(5) В части затруднения работы с релизами - особо нет. Просто веб-контент версионируется и хранится в папках с указанием номера версии. Это не очень большие объемы и довольно низкая сложность.

В части стандартного инсталятора. Завернуть можно, просто это будет сложнее. Плюс сейчас практически норма публиковать ИБ на веб-сервере (автоматическое обновление клиента, 1С:Аналитика, интеграции через http или soap сервисы и т.д.), поэтому докинуть туда еще и веб-содержимое для работы конфигурации сильно сложной задачей не выглядит.
7. rpgshnik 3815 18.10.21 12:28 Сейчас в теме
Чат красивый, вот бы до такого доросло Обсуждение) у вас будет отдельно продажа чата? Какие есть решения уже на продажу?
8. Akcium 359 20.10.21 22:49 Сейчас в теме
(7) В докладе был пример реализации для одного из наших клиентов. Универсальных решений на продажу нет, но можем реализовать решение на этих технологиях по вашим требованиям или требованиям ваших клиентов.
9. AlexeyPapanov 466 29.10.21 11:35 Сейчас в теме
Хочу сказать спасибо за статью и за видео, которое очень "по делу" и без воды.
И спасибо, Матвей, за помощь!
10. MAlexey81 16.11.21 10:26 Сейчас в теме
Похоже на проект полета человека на Луну. Сложно, дорого, ресурсоемко. Для реализации личных кабинетов и закрытия части бизнес-задач такие методы могут помочь, но делать из 1С подобие веб-приложения будет сопоставимо по затратам с программой освоения космоса.
Спасибо за статью.
Планирую в одном проекте попробовать вариант - "JS получает данные от 1С через HTTP-сервис и формирует HTML" как наиболее реализуемый в рамках соотношения затраты/результат.
11. Pawlick 10 07.10.22 12:18 Сейчас в теме
Это очень, очень интересная тема, которая делает из 1С практически платформу с безграничными возможностями. Сам имею огромный опыт подобных решений. НО!

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

Что касается комментариев про "затраты сопоставимые с программой освоения космоса", то могу сказать следующее. Очень легко разводить болтологию на темы "как в 21 веке существует тысячи платформ для создания чего угодно". На практике все существующие решения предоставляющие web интерфейс для доступа к базам данных по сравнению с 1С - бледные тени. Тот же хваленый Битрикс-управление сайтом, или 24 при ближайшем рассмотрении имеют такую массу ограничений на доработку и изменения, что проект по созданию личного кабинета B2B легко переваливает за 500к на первом месяце разработки. Я уже не говорю, про проблему поиска нормального исполнителя, сложностей проверки качества его php кода, и самое главное - пост обслуживания этих "поделок", когда не понятно кто, что и зачем создал в базе данных, созданы ли индексы таблиц, по какми полям и насколько они эффективны, и т.д. Про механизмы вроде RLS я уже вообще молчу. За то как это реализовано у персонажей типа "разработка сайтов 500р/час" - нужно к стенке ставить.

С этой точки зрения приложение написанное на vue + 1С лицензия на 500 пользователей для http интерфейса серверной части - вполне конкурентное решение по сравнению с доброй половиной современных "сурьезных" web платформ.
Оставьте свое сообщение