npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

bsl-js

v1.0.1

Published

Унифицированная интеграция HTML-страниц со средой исполнения 1С

Downloads

3

Readme

Интеграционный интиерфейс 1С <-> HTML

Назначение

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

Часто разработчику приходится искать пример интеграции либо в уже готовом решении, либо в интернетах, а затем "допиливать" решение под себя.

Данная библиотека призвана унифицировать и формализовать подход к реализации таких элементов интерфейса.

Совместимость

Библиотека совместима с платформой 1С-Предприятие версии 8.3.14.1565 и выше. Если вы используете версию ниже, то перестаньте.

Установка и плдключение

Установка выполняется из реестра npm в виде ES модуля:

npm i bsl-js

Подключение на странице:

import {...} from 'bsl-js'

Концепция библиотеки

После подключения библиотеки, в глобальной области видимости(window.*) становится доступен объект integration_ctx. Прямое использование объекта не требуется, он нужен только для 1С-ной обвязки.

Со стороны 1С, реализован специальная библиотека, работающая в паре с JS.

Концепция системы основывается на паттерне Observer, который реализован с обеих сторон интеграции системы(1С и JS). Каждая сторона интеграции подписывается на определенные события противоположной стороны. Аналогично, каждая сторона генерирует события для другой стороны.

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

Далее, для удобства, входящими событиями будем называть события отправленные из 1С в JS, а исходящими - события отправленные из JS в 1С.

Интеграция в страницу

Основные методы библиотеки позволяют "слушать" входящие события и отправлять "исходящие"

import {sendTo1C, listenFrom1C} from 'bsl-js'

// Слушать входящее событие из 1С
listenFrom1C("some_event", data => {...})

// Отправить исходящее событие в 1С
sendTo1C("some_event", {...})

Интеграция в 1С

На стороне среды исполнения 1С интеграция аналогична.

&НаКлиенте
Процедура БраузерПриНажатии(Элемент, ДанныеСобытия, СтандартнаяОбработка)
	
    // Общий обработичик событий, просто фильтрует "наши" события и стандартные события поля-HTML
	Если ИнтеграцияHTMLКлиент.ОбработатьСобытиеJS(ЭтотОбъект, Элемент, ДанныеСобытия) Тогда
		СтандартнаяОбработка = Ложь;
	КонецЕсли;
	
КонецПроцедуры

&НаКлиенте
Процедура БраузерДокументСформирован(Элемент)
	
    // Подписка на конкретное событие "ПриГенерацииМодуляФормы"
    // с привязкой ОписанияОповешения
	ИнтеграцияHTMLКлиент.ПодписатьсяНаСобытиеJS(
		ЭтотОбъект,
		"ПриГенерацииМодуляФормы",
		"Подключаемый_ПриГенерацииМодуляФормы",
		Элемент
	);
		
КонецПроцедуры

&НаКлиенте
Процедура Подключаемый_ПриГенерацииМодуляФормы(Данные, ДопПараметры = Неопределено) Экспорт

	// В параметре Данные будет десереализованный объект JS в виде структуры
	// Данные.content - для события "ПриГенерацииМодуляФормы" тут будет шаблон текста модуля формы
    Сообщить(Данные.content);
	
КонецПроцедуры

&НаКлиенте
Процедура КомандаСгенерироватьТекстМодуляФормы(Данные, ДопПараметры = Неопределено) Экспорт
    // Отправка события в JS
	ИнтеграцияHTMLКлиент.ОтправитьСобытиеJS(Элементы.Браузер, "СгенерироватьМодульФормы");
	
КонецПроцедуры

Генерация кода 1С

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

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

import {registerEvents} from 'bsl-js'

// На входе объект описывающий входящие и исходящие события
registerEvents({eventsDescription})

Пример объекта описывающего события:

export default {
    // Входящие события
    exports: [
        ...
        {   
            // Идентификатор входящего события
            id: "УстановитьСодержимое",
            // Описание события
            desc: "Устанавливает переданный текст в виде содержимое текущего документа",
            // Описание данных события
            data: {
                content: {
                    required: true,
                    desc: "Текст"
                },
                mode: {
                    desc: "Режим подсветки синтаксиса. Если не передан будет установлен режим 'text'",
                    enum: ['text', 'xml', 'json']
                }
            }
        },
        ...
    ],
    // Исходящие события
    events: [
        ...
        {
            // Идентификатор входящего события
            id: "ПриПолученииСодержимого",
            // Описание опущено
            // Описание данных события
            data: {
                content: {
                    desc: "Текст документа"
                }
            }
        }
        ....
    ]

}

Описание встроенных событий

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

TODO: Реализовать генерацию md с описанием протокола.

Исходящие события

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

  • ПриГенерацииМодуляФормы

    Получение сгенерированного текста формы

      {
          content: string
      }

    | Поле | Назначение | | - | - | | content | Текст модуля формы 1С для работы со страницей, его возвращающей |

Входящие события

Здесь указываются все события генерируемые 1С

  • СгенерироватьМодульФормы

    Парное исходящее событие ПриГенерацииМодуляФормы