Диалог выбора даты на JS без зависимостей. Отображалки от kuzkov.info

10.04.23

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

Диалог выбора даты на чистом js для встройки в обозреватели. Методы и свойства отображалки сделаны в 1Сном стиле и будут понятны почти любому 1Снику. Выбор данных в любом формате из возможных: Дата, Время, ДатаВремя. Аналог 1Сной отображалки "Календарь".

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование SM По подписке [?] Купить один файл
Диалог выбора даты на JS без зависимостей. Отображалки от kuzkov.info:
.zip 22,82Kb
1
1
10 SM
Скачать Купить за 4 550 руб.

Приветствую уважаемое сообщество!

В этой статье будем рассматривать случай отображалки диалога выбора даты на js в обозревателе.

 
Отступление 1 

 

 

Данная статья является кратким конспектом ролика на ютубе.
Если есть сложности со встроенным игрателем, то прямая ссылка для плюсануть, написать комментарий и подписаться: https://www.youtube.com/watch?v=FWKsMxJ_EPU
 



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

Особенности

  • Выбор данных в любом формате из возможных: Дата, Время, ДатаВремя;
  • Внутренний код js написан на русском языке с комментариями;
  • Методы и свойства на русском языке;
  • Написано на родном чистом js без зависимостей;


Методы и свойства

Открыть()
Закрыть()

Открыто
ПолеДанных
ВыбраннаяДата
ВыборДня
ВыборВремени
СобытиеПриВыборе


Метод Открыть()

Диалог должен открываться при вызове метода Открыть().
Диалог должен открываться под dom элементом ПолеДанных.

Если указана ВыбраннаяДата, то эта дата должна быть выделена стилем.
Текущий отображаемый месяц должен быть месяцем выбранной даты.

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


Метод  Закрыть()

Метод должен закрыть диалог выбора даты.


Свойства

Открыто
Тип: Булево
Истина = окно отображалки открыто
Ложь = окно отбражалки закрыто


ПолеДанных

Тип: dom элемент
Отображалка должна показываться под этим dom элементом.
При открытии данные должны браться из этого поля ввода


ВыбраннаяДата

Тип: Дата
Только чтение.
Объект js даты с датой и временем.
Если из поля была прочитана дата ДатаВремя, то возвращаться после выбора должна новая дата со старым временем.


ВыборДня

Тип: Булево
Если Истина, тогда должна отображаться часть отображалки для выбора дня.


ВыборВремени

Тип: Булево
Если Истина, тогда должна отображаться часть отображалки для выбора времени.


СобытиеПриВыборе

Тип: Строка
Полное имя функции, которая должна быть вызвана при нажатии кнопки выбора.


Сценарии применения

Создание и открытие диалога.
 

// Эта функция вызывается при нажатии кнопки выбора даты.
function ВыбратьДеньВремя(){
    // Определение элемента формы как якоря для выбиралки даты и времени
    эфПолеДатыНачала = document.getElementById('ПолеПоказаВыбраннойДатыВремени');
    // Если выбиралка даты создается первый раз
    if (эфПолеДатыНачала.ДиалогВыбораДаты == undefined) {
        var двДата              = new ДиалогВыбораДаты;
        двДата.СобытиеПриВыборе = ОбработкаВыбораДня;
        двДата.ПолеДанных       = эфПолеДатыНачала;
        двДата.ВыбраннаяДата    = new Date(2023, 1, 2, 11, 22, 33);
        двДата.ВыборДня         = true;
        двДата.ВыборВремени     = true;
        двДата.Открыть();
    } else if (эфПолеДатыНачала.ДиалогВыбораДаты.Открыто ) {
        // Если диалог открыт, то при нажатии кнопки закроем выбор даты
        эфПолеДатыНачала.ДиалогВыбораДаты.Закрыть();
    }
};

function ОбработкаВыбораДня(ДиалогВыбораДаты){
    // Берем выбранную дату из объекта диалога выбора даты
    // Может нужно будет форматировать для приведения к строке для показа в поле данных
    console.log(ДиалогВыбораДаты.ВыбраннаяДата); 
    // Установка выбранной даты и времени
    эфПолеДатыНачала.value = "" + ДиалогВыбораДаты.ВыбраннаяДата.getFullYear() + "-" + (ДиалогВыбораДаты.ВыбраннаяДата.getMonth() + 1) + "-" + ДиалогВыбораДаты.ВыбраннаяДата.getDate();
    // Закроем выбор даты
    ДиалогВыбораДаты.ПолеДанных.ДиалогВыбораДаты.Закрыть();
};



Покажем на примерах

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



[Экроснимок 1. Открытие диалога]

Текущая дата отображается в красной рамке.

При нужности выбора даты и времени, включаем свойство "двДата.ВыборВремени = true" и включается блок выбора времени.



[Экроснимок 2. Выбора даты со временем]

Если нужно выбрать только время, то через "двДата.ВыборДня = false" отключаем выбор даты.


[Экроснимок 3. Выбор времени]



Приложенный пример

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

Версия 1С, с которой работаю при разработке: разработку веду на 1С 8.3.10.

Вопросы, пожелания и замечания прошу писать в личку учетки.

На этом пока все :)

Вопросы, пожелания и замечания прошу писать в личку учетки.

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

Всем лучи добра !

Кузьков.инфо kuzkov.info json js верстка веб-формы веб-морды веб формы http веб 1с веб отображалки выбор даты диалог

См. также

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

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

2400 руб.

29.06.2020    18080    25    6    

39

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

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

20.08.2024    10989    mrXoxot    43    

107

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

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

27.05.2024    5956    smielka    37    

97

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

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

27.12.2023    13283    809    elcoan    47    

113

Инструментарий разработчика Работа с интерфейсом Программист Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

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

2 стартмани

10.04.2023    11092    160    acces969    31    

121

Работа с интерфейсом Программист Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

"MVC плохо применима в 1С" - познакомьтесь с моделью состояния и, возможно, ваше мнение поменяется! Представленное решение является эволюционным развитием идеи реализации MVC для 1С. В новой версии добавлены DSL для описания модели состояния, а также параметризация свойств параметров и элементов формы.

1 стартмани

05.07.2022    4958    kalyaka    6    

33

Работа с интерфейсом Платформа 1С v8.3 Платные (руб)

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

6000 руб.

18.01.2022    9659    1    2    

6