Исходный код вики Для разработчиков

Версия 55.1 от Михаил Галич на 20.12.2023, 16:48

Последние авторы
1 {{toc depth="4"/}}
2
3 = Инструкция для подключения =
4
5 Назначение данного раздела — описать способы взаимодействия с виджетом Веб-платформы по задуманному вами сценарию. Типичный процесс подключения, открытия и отслеживания виджета выглядит так:
6
7 ~1. Подключите скрипт ##external.script.js## к вашему сайту. Его адрес будет доступен **после добавления сайта** в процессе настройки в **администраторской панели Веб-Платформы**, так же как и параметр ##id## для подключения
8
9 2. Вставьте в необходимом месте на своём сайте код:
10
11 {{code language="html"}}
12
13 <script type="text/javascript">
14 // инициализируем виджет с параметрами
15 WPInit({
16 id: 1,
17 width: 400,
18 type: 'modal'
19 })
20
21 // сразу откроем его для пользователя
22 WPOpenModal(); // вариант для модального окна
23 // WPOpen(); // вариант для открытия в теле страницы. Используется при инициализации виджета с type: 'instant'
24
25 // будем следить за состоянием виджета
26 WPChange = function(response) {
27 if (response.status == 'reserved') {
28 // если заказ зарезирвирован, занесём данные из response.data.order_id себе на сайт
29 }
30 if (response.status == 'completed') {
31 // если заказ оплачен, занесём данные из response.data.order_id себе на сайт
32 }
33 }
34 </script>
35
36 {{/code}}
37
38 = Функции =
39
40 == WPInit ==
41
42 (% class="box infomessage" %)
43 (((
44 Функция загрузки виджета с параметризацией, при создании необходимо передать**## id ##**виджета, который можно найти в Административной панели
45 )))
46
47 ===== Минимальный способ инициализации: =====
48
49 {{code language="javascript"}}
50 WPInit({ id: 1 })
51 {{/code}}
52
53 ===== Пример передаваемых данных: =====
54
55 (% class="box infomessage" %)
56 (((
57 Виджет можно инициализировать с различными параметрами, все из них опциональные, кроме **##id##**.
58 )))
59
60 {{code language="javascript"}}
61 WPInit({
62 id: 1,
63 width: 400,
64 height: 600,
65 type: 'modal'
66 })
67 {{/code}}
68
69 == WPOpen ==
70
71 (% class="box infomessage" %)
72 (((
73 Функция открытия виджета в каком-либо блоке, используется при инициализации виджета с## **type: 'instant'**##
74 )))
75
76 ===== Пример передаваемых данных: =====
77
78 {{code language="javascript"}}
79 // показ виджета с группой id 5
80 WPOpen({
81 groupid: [5]
82 })
83 {{/code}}
84
85 == WPOpenModal ==
86
87 (% class="box infomessage" %)
88 (((
89 Функция открытия виджета в модальном окне, используется при инициализации виджета с## **type: 'modal'**##
90 )))
91
92 ===== Пример передаваемых данных: =====
93
94 {{code language="javascript"}}
95 // показ виджета на нажатие кнопки с id "OpenButton"
96 var OpenButton = document.getElementById('OpenButton');
97 OpenButton.onclick = function () {
98 WPOpenModal({ tariffsid: [27, 28] });
99 };
100 {{/code}}
101
102 == WPChange ==
103
104 (% class="box infomessage" %)
105 (((
106 Функция, которая вызывается каждый раз при изменении состояния виджета.
107 Каждый раз передаёт в переменной response состояние в **##status##** и опционально данные в **##data##**.
108 При переопределении этой функции у себя на странице, администратор может следить за состоянием виджета и статусом заказа из javascript
109 )))
110
111 ===== Примеры передаваемых данных: =====
112
113 - ##{ status:'starting' }## — виджет в процессе запуска, в этот момент определяется, что он должен в данный момент отображать
114 - ##{ status:'started' }## — виджет на начальном экране, где показывается список услуг для покупки
115 - ##{ status:'reserved', data: { order_id: 2 } }## — виджет находится на стадии забронированного заказ, в data передаётся id
116 - ##{ status:'completed', data: { order_id: 2 } }## — виджет находится на стадии оплаченного заказ, в data передаётся id заказа
117
118 ===== Пример работы с данными: =====
119
120 {{code language="javascript"}}
121 WPChange = function(response) {
122 if (response.status == 'starting') {
123 // действие на внешней странице
124 }
125 if (response.status == 'started') {
126 // действие на внешней странице
127 }
128 if (response.status == 'reserved') {
129 // id зарезервированного заказа: response.data.order_id
130 }
131 if (response.status == 'completed') {
132 // id оплаченного заказа: response.data.order_id
133 }
134 }
135 {{/code}}
136
137 = Параметры =
138
139 == Обязательные параметры WPInit ==
140
141 ==== id ====
142
143 Тип данных:## //number//##
144
145 (% class="box infomessage" %)
146 (((
147 id виджета, который можно узнать в Административной панели.
148 )))
149
150 == Возможные параметры WPInit ==
151
152 ==== height ====
153
154 Тип данных:## //number//##
155
156 (% class="box infomessage" %)
157 (((
158 Высота виджета в пикселях, по умолчанию:
159 • 480px, если виджет запущен как type: 'modal'
160 • 100%, если виджет запущен как type: 'instant'
161 )))
162
163 ==== width ====
164
165 Тип данных:## //number//##
166
167 (% class="box infomessage" %)
168 (((
169 Ширина виджета в пикселях, по умолчанию:
170 • 640px, если виджет запущен как type: 'modal'
171 • 100%, если виджет запущен как type: 'instant'
172 )))
173
174 ==== type ====
175
176 Тип данных:## //string//##
177
178 По умолчанию:##// 'instant'//##
179
180 (% class="box infomessage" %)
181 (((
182 Способ открытия виджета
183 • 'instant' Открытие виджета на месте, где был вызов виджета (на месте тэга script), либо в блоке place, если он указан в параметрах виджета при инициализации
184 • 'modal' Открытие виджета в модальном окне
185 )))
186
187 ==== place ====
188
189 Тип данных:## //string//##
190
191 (% class="box infomessage" %)
192 (((
193 Идентификатор элемента DOM, в который необходимо поместить виджет, например: **###widget##**. Используется совместно с **##type: 'instant'##**
194 )))
195
196 (% class="box warningmessage" %)
197 (((
198 **Важно:** элемент DOM для place должен быть либо на странице до вставки инициализации виджета (WPInit), либо инициализация виджета должна быть исполнена после загрузки DOM (например, обёрнута в событие $(document).ready(function(){}) в jQuery)
199 )))
200
201 ----
202
203 == Возможные параметры WPOpen и WPOpenModal ==
204
205 === Инструкторские занятия ===
206
207 ==== categories ====
208
209 Тип данных:##// Array<string>//##
210
211 По умолчанию:##// []//##
212
213 (% class="box infomessage" %)
214 (((
215 Фильтр категорий инструкторских занятий. Скрывает категории в выпадающем списке, **##id##** которых не совпадают заданными в массиве.
216 )))
217
218 [[image:1703065952567-753.png]]
219
220 ==== coachid ====
221
222 Тип данных:##// number//##
223
224 По умолчанию:##// undefined//##
225
226 (% class="box infomessage" %)
227 (((
228 Идентификатор тренера, позволяет сепарировать список занятий по тренеру
229 )))
230
231 ==== grouplessonstariffsid ====
232
233 Тип данных:##// Array<number>//##
234
235 По умолчанию:##// []//##
236
237 (% class="box infomessage" %)
238 (((
239 Фильтр программ обучения для групповых занятий
240 )))
241
242 [[image:1703065356750-663.png]]
243
244 Пример:
245
246 {{code language="javascript"}}
247 grouplessonstariffsid: [1823, 1900] // скрыть все программы обучения, кроме 1823 и 1900
248 {{/code}}
249
250 ==== lessonslocation **##*##** ====
251
252 Тип данных:##// number//##
253
254 По умолчанию:##// undefined//##
255
256 (% class="box infomessage" %)
257 (((
258 Отображение места занятия для индивидуальных, групповых и многодневных занятий
259 )))
260
261 [[image:1702560957244-690.png]]
262
263 ==== lessonstariffsid ====
264
265 Тип данных:##// Array<number>//##
266
267 По умолчанию:##// []//##
268
269 (% class="box infomessage" %)
270 (((
271 Ограничить видимость доступных тарифов в выпадающем списке программ обучения по массиву с их идентификаторами
272 )))
273
274 [[image:1702641274330-465.png]]
275
276 ==== multidayslessonsskillstariffs **##*##** ====
277
278 Тип данных:##// Array<number> //##//|## object##//
279
280 По умолчанию:##// []//##
281
282 (% class="box infomessage" %)
283 (((
284 Производит фильтрацию тарифов для многодневных занятий. Принимает массив идентификаторов.
285 Параметр дополняет фильтрацию по параметру **##grouplessonsskillstariffs##**.
286 )))
287
288 ==== nocategories **##*##** ====
289
290 Тип данных:##// boolean//##
291
292 По умолчанию:##// false//##
293
294 (% class="box infomessage" %)
295 (((
296 Если **##true##** скрывает фильтр по категории инструкторских занятий
297 )))
298
299 [[image:1702638427440-675.png]]
300
301 ==== nocoach **##*##** ====
302
303 Тип данных:##// boolean//##
304
305 По умолчанию:##// false//##
306
307 (% class="box infomessage" %)
308 (((
309 Если **##true##** скрывает выпадающее меню выбора инструктора
310 )))
311
312 [[image:1702638265778-588.png]]
313
314 ==== nolocation **##*##** ====
315
316 Тип данных:##// boolean//##
317
318 По умолчанию:##// false//##
319
320 (% class="box infomessage" %)
321 (((
322 Если **##true##** скрывает фильтр по месту проведения инструкторских занятий
323 )))
324
325 [[image:1702638034420-756.png]]
326
327 ==== noskills **##*##** ====
328
329 Тип данных:##// boolean//##
330
331 По умолчанию:##// false//##
332
333 (% class="box infomessage" %)
334 (((
335 Если **##true##** скрывает фильтр по дисциплине инструкторских занятий
336 )))
337
338 [[image:1702638705750-678.png]]
339
340 ==== notariffs ====
341
342 Тип данных:##// boolean//##
343
344 По умолчанию:##// false//##
345
346 (% class="box infomessage" %)
347 (((
348 Если **##true##** скрывает фильтр по программе обучения инструкторских занятий
349 )))
350
351 [[image:1703063138160-208.png]]
352
353 ==== personallessonsskillstariffs **##*##** ====
354
355 Тип данных:##// object//##
356
357 По умолчанию:##// {}//##
358
359 (% class="box infomessage" %)
360 (((
361 Ограничивает список тарифов (в фильтре) при выборе конкретной дисциплины.
362 Принимает объект, внутри которого указываются пары ключ/значение по выражению: {skillid}: [{tariffid},...]
363 )))
364
365 Пример:
366
367 {{code language="javascript"}}
368 personallessonsskillstariffs: {
369 "1": [ 15, 23] // При выборе дисциплины с id 1 - отображать тарифы с id 15 и 23
370 }
371 {{/code}}
372
373 ==== placeid **##*##** ====
374
375 Тип данных:##// number//##
376
377 По умолчанию:##// undefined//##
378
379 (% class="box infomessage" %)
380 (((
381 идентификатор места, использующийся для получения списка инструкторов.
382 )))
383
384 ==== skills **##*##** ====
385
386 Тип данных:##// Array<number>//##
387
388 По умолчанию:##// []//##
389
390 (% class="box infomessage" %)
391 (((
392 Ограничить видимость доступных к выбору дисциплин по идентификатору
393 )))
394
395 [[image:1702639385677-964.png]]
396
397 === Календарь и даты ===
398
399 ==== disableddates ====
400
401 Тип данных:##// Array<string>//##
402
403 По умолчанию:##// []//##
404
405 (% class="box infomessage" %)
406 (((
407 Параметр отключения дат в календаре (и в //покупке// и в //пополнении//). Делает невозможным выбор определённых дней в массиве дат.
408 )))
409
410 Пример:
411
412 {{code language="javascript"}}
413 disableddates: ['23.02.2018', '08.03.2018'] // уберёт даты 23.02.2018 и 08.03.2018 из возможных для выбора дат в календаре.
414 {{/code}}
415
416 ==== forcedate ====
417
418 Тип данных:##// string//##
419
420 По умолчанию:##// undefined//##
421
422 (% class="box infomessage" %)
423 (((
424 Параметр для открывания виджета с указанной сразу датой (и в //покупке// и в //пополнении//).
425 **##forcedate: '20.05.2018'##** покажет услуги к продаже на дату 20.05.2018.
426 )))
427
428 ==== maxdate ====
429
430 Тип данных:##// string//##
431
432 По умолчанию:##// undefined//##
433
434 (% class="box infomessage" %)
435 (((
436 Параметр максимальной отображаемой даты в календаре (и в //покупке// и в //пополнении//).
437 **##maxdate: '20.05.2018'##** покажет 20.05.2018 как самую последнюю дату, доступную к выбору в календаре.
438 )))
439
440 ==== mindate ====
441
442 Тип данных:##// string//##
443
444 По умолчанию:##// undefined//##
445
446 (% class="box infomessage" %)
447 (((
448 Параметр минимальной отображаемой даты в календаре (и в //покупке// и в //пополнении//).
449 **##mindate: '20.05.2018'##** покажет 20.05.2018 как самую первую дату, доступную к выбору в календаре, если она находится после текущего дня.
450 )))
451
452 ==== nocalendar ====
453
454 Тип данных:## //boolean//##
455
456 По умолчанию:##// false//##
457
458 (% class="box infomessage" %)
459 (((
460 Убирает календарь внутри виджета (и в //покупке// и в //пополнении//), в случаях, когда дата, на которую покупается/пополняется билет, не важна.
461 )))
462
463 ----
464
465 === Отображение ===
466
467 ==== cartmaxitems **##*##** ====
468
469 Тип данных:##// number//##
470
471 По умолчанию:##// 6//##
472
473 (% class="box infomessage" %)
474 (((
475 Ограничивает максимальное кол-во товаров в корзине. ##Минимальное значение 1, но не меньше **cartminitems**. Максимальное значение 60.##
476 )))
477
478 ==== cartminitems **##*##** ====
479
480 Тип данных:##// number//##
481
482 По умолчанию:##// 1//##
483
484 (% class="box infomessage" %)
485 (((
486 Ограничивает минимальное кол-во товаров в корзине. ##Минимальное значение 1. Максимальное значение 60, но не больше **cartmaxitems**.##
487 )))
488
489 ==== clubsiteid ====
490
491 Тип данных:##// number//##
492
493 По умолчанию:##// 0//##
494
495 (% class="box warningmessage" %)
496 (((
497 Описание отсутствует
498 )))
499
500 ==== disablemultipleseances **##*##** ====
501
502 Тип данных:##// boolean//##
503
504 По умолчанию:##// false//##
505
506 (% class="box infomessage" %)
507 (((
508 Параметр предотвращает добавление в корзину тарифов с различными сеансами.
509 Таким образом как только в корзине появится хоть один товар с сеансом "10:00 - 11:30", товары, у которых есть сеанс например "13:00 - 14:30" будет невозможно добавить в корзину.
510 Товары без сеансов **не будут затронуты**.
511 )))
512
513 ==== forcemedia ====
514
515 Тип данных:##// string//##
516
517 По умолчанию:##// ''//##
518
519 (% class="box infomessage" %)
520 (((
521 Параметр, который вставяет строчку с носителем в поле носителя во вкладке «Пополнение услуг». Используется, например, для QR-кода нанесённого на носитель, чтобы быстро его пополнить.
522 )))
523
524 Пример:
525
526 {{code language="javascript"}}
527 forcemedia: 'E0012345678900'
528 {{/code}}
529
530 ==== forceseanceid **##*##** ====
531
532 Тип данных:##// number//##
533
534 По умолчанию без указания идентификатора не учитывается.
535
536 (% class="box infomessage" %)
537 (((
538 Заставит виджет выбрать мероприятие арены по идентификатору платформы и не позволять вернуться к этапу выбора других мероприятий.
539 )))
540
541 ==== forcesectorid **##*##** ====
542
543 Тип данных:##// number//##
544
545 По умолчанию без указания идентификатора не учитывается.
546
547 (% class="box infomessage" %)
548 (((
549 Заставит виджет выбрать сектор мероприятия по **##id##** и не позволять вернуться к этапу выбора других секторов.
550 )))
551
552 ==== forcetab **##*##** ====
553
554 Тип данных:##// string//##
555
556 По умолчанию:##// ''//##
557
558 (% class="box infomessage" %)
559 (((
560 Переключение на необходимую вкладку виджета («**покупка услуг**» или «**пополнение услуг**») при загрузке.
561 По умолчанию открывается вкладка «**покупка услуг**».
562 **##forcetab: 'rewrite'##** принудительно откроет «**пополнение услуг**».
563 Обычно используется в комбинации с параметром **##onlytab##**
564 )))
565
566 ==== grouplessonsskillstariffs ====
567
568 Тип данных:##// Array<number> //##//|## object##//
569
570 По умолчанию:##// {}//##
571
572 (% class="box warningmessage" %)
573 (((
574 Описание отсутствует
575 )))
576
577 ==== locale **##*##** ====
578
579 Тип данных:##// string//##
580
581 По умолчанию:##// ''//##
582
583 (% class="box infomessage" %)
584 (((
585 Параметр локализации. Позволяет переключать между языками виджета, например 'ru' - русский язык, 'en' - английский язык.
586 )))
587
588 ==== marketbillid ====
589
590 Тип данных:##// number//##
591
592 По умолчанию:##// undefined//##
593
594 (% class="box warningmessage" %)
595 (((
596 Описание отсутствует
597 )))
598
599 ==== marketemployeeid ====
600
601 Тип данных:##// number//##
602
603 По умолчанию:##// undefined//##
604
605 (% class="box warningmessage" %)
606 (((
607 Описание отсутствует
608 )))
609
610 ==== minimap **##*##** ====
611
612 Тип данных:##// boolean//##
613
614 По умолчанию:##// true//##
615
616 (% class="box infomessage" %)
617 (((
618 Отображать миникарту.
619 )))
620
621 ==== minimapaspect **##*##** ====
622
623 Тип данных:##// number//##
624
625 По умолчанию:##// 0.2//##
626
627 (% class="box infomessage" %)
628 (((
629 Размер миникарты относительной полного размера карты, а не контейнера, в которой она находится.
630 )))
631
632 ==== nopromo **##*##** ====
633
634 Тип данных:##// boolean//##
635
636 По умолчанию:##// false//##
637
638 (% class="box infomessage" %)
639 (((
640 Убирает вывод промокода на странице подтверждения заказа.
641 )))
642
643 ==== onlytab **##*##** ====
644
645 Тип данных:##// string //##//|## Array<string>##//
646
647 По умолчанию:##// []//##
648
649 (% class="box infomessage" %)
650 (((
651 Скрытие других вкладок виджета («покупка услуг» или «пополнение услуг») при загрузке. Обычно используется в комбинации с параметром **##forcetab##**
652 )))
653
654 {{code language="javascript"}}
655 onlytab: 'service' // покажет только вкладку «покупка услуг».
656 onlytab: 'rewrite' // покажет только вкладку «пополнение услуг».
657 onlytab: ['service', 'rewrite'] // покажет только вкладки «покупка услуг» и «пополнение услуг»;
658 {{/code}}
659
660 ==== ordercomment **##*##** ====
661
662 Тип данных:##// string//##
663
664 По умолчанию:##// ''//##
665
666 (% class="box infomessage" %)
667 (((
668 Опциональный комментарий к заказу. Максимальная длинна комментария 50 символов.
669 )))
670
671 ==== requiredloyalty **##*##** ====
672
673 Тип данных:##// boolean//##
674
675 По умолчанию:##// false//##
676
677 (% class="box infomessage" %)
678 (((
679 Включает обязательную регистрацию клиента в программе настроенной на объектке.
680 )))
681
682 ==== resetcart **##*##** ====
683
684 Тип данных:##// boolean//##
685
686 По умолчанию:##// false//##
687
688 (% class="box infomessage" %)
689 (((
690 Автоматически очищать содержимое корзины.
691 )))
692
693 ==== saletermstype **##*##** ====
694
695 Тип данных:##// string//##
696
697 По умолчанию:##// '//default//'//##
698
699 (% class="box infomessage" %)
700 (((
701 Перед оплатой просит пользователя согласиться с правилами в форме галочки или всплывающего окна
702 )))
703
704 {{code language="javascript"}}
705 saletermstype: 'checkbox' // потребует установку галочки для согласия.
706 saletermstype: 'dialog' // покажет всплывающее окно с правилами, которые нужно принять.
707 saletermstype: 'default' // принятие правил не требуется.
708 {{/code}}
709
710 ==== shownoticketsseances **##*##** ====
711
712 Тип данных:##// boolean//##
713
714 По умолчанию:##// false//##
715
716 (% class="box infomessage" %)
717 (((
718 Не скрывать сеансы, на которые закончились билеты. Работает если **##tariffsseancesfilter: true##**
719 )))
720
721 ==== showoverseances **##*##** ====
722
723 Тип данных:##// boolean//##
724
725 По умолчанию:##// false//##
726
727 (% class="box infomessage" %)
728 (((
729 Отвечает за отображение прошедших сеансов в списке для фильтрации по времени. При значении **##true##** прошедшие сеансы будут отображаться, но недоступны для выбора пользователем. Работает если **##tariffsseancesfilter: true##**
730 )))
731
732 [[image:1702554598837-627.png]]
733
734 ==== tariffsseancesfilter **##*##** ====
735
736 Тип данных:##// boolean//##
737
738 По умолчанию:##// false//##
739
740 (% class="box infomessage" %)
741 (((
742 Включить отображение фильтра тарифов по сеансам.
743 )))
744
745 [[image:https://info.moipass.ru/images/tariffsseancesfilter.png||alt="Example"]]
746
747 ----
748
749 === Предзаказ ===
750
751 ==== preorder ====
752
753 Тип данных:##// Array<object>//##
754
755 По умолчанию:##// undefined//##
756
757 (% class="box infomessage" %)
758 (((
759 Параметр, позволяющий купить сразу несколько услуг и перейти к подтверждению покупки.
760 • ##id## — id услуги к покупке
761 • ##date## — дата, на которую покупается услуга
762 • ##count## — количество покупаемых услуг
763 )))
764
765 ===== Пример передаваемых данных: =====
766
767 {{code language="javascript"}}
768 // либо WPOpenModal({})
769 WPOpen({
770 preorder: [
771 {
772 id: 57,
773 date: '06.06.2019',
774 count: 1
775 }, {
776 id: 58,
777 date: '07.06.2019',
778 count: 2
779 }
780 ]
781 })
782 {{/code}}
783
784 ----
785
786 === Услуги, пакеты услуг, группы услуг ===
787
788 ==== tariffsid ====
789
790 Тип данных:##// Array<number> //##//|## boolean##//
791
792 По умолчанию:##// []//##
793
794 (% class="box infomessage" %)
795 (((
796 Тарифы, которые следует показать на вкладке «Покупка услуг».
797 По умолчанию массив пуст и не показывает отдельно никакие из услуг.
798 Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать услуги, доступные только для него.
799 )))
800
801 Пример:
802
803 {{code language="javascript"}}
804 tariffsid: [29, 30] // покажет тарифы с id 29 и 30 во вкладке «Покупка услуг».
805 tariffsid: false // уберёт все тарифы с первой страницы
806 {{/code}}
807
808 ==== rewritetariffsid **##*##** ====
809
810 Тип данных:##// Array<number> //##//|## boolean##//
811
812 По умолчанию:##// []//##
813
814 (% class="box infomessage" %)
815 (((
816 Тарифы, которые следует показать после ввода карты во вкладке «Пополнение услуг».
817 По умолчанию массив пуст и не показывает отдельно никакие из услуг.
818 Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать услуги, доступные только для него.
819 )))
820
821 Пример:
822
823 {{code language="javascript"}}
824 rtariffsid: [56, 57] // покажет тарифы с id 56 и 57 после ввода карты во вкладке «Пополнение услуг»
825 rtariffsid: false // уберёт все тарифы во вкладке «Пополнение услуг»
826 {{/code}}
827
828 ==== rtariffsid ====
829
830 (% class="box infomessage" %)
831 (((
832 См. **##rewritetariffsid##**. Доступен и в старой версии виджета
833 )))
834
835 ==== bundlesid ====
836
837 Тип данных:##// Array<number> //##//|## boolean##//
838
839 По умолчанию:##// []//##
840
841 (% class="box infomessage" %)
842 (((
843 Пакеты услуг, которые следует показать на первой странице.
844 По умолчанию массив пуст и не показывает отдельно никакие из пакетов услуг.
845 Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать пакеты услуг, доступные только для него.
846 )))
847
848 Пример:
849
850 {{code language="javascript"}}
851 bundlesid: [4, 5] // покажет пакеты услуг с id 4 и 5 в момент открытия виджета.
852 bundlesid: false // уберёт все пакеты услуг с первой страницы
853 {{/code}}
854
855 ==== bundleslessonstariffsid ====
856
857 Тип данных:##// Array<number>//##
858
859 По умолчанию:##// []//##
860
861 (% class="box warningmessage" %)
862 (((
863 Описание отсутствует
864 )))
865
866 ==== groupid ====
867
868 Тип данных:##// number//##
869
870 По умолчанию:##// undefined//##
871
872 (% class="box infomessage" %)
873 (((
874 Параметр, который форсирует показ определённой группы услуг ппс. **##groupid: 5##** покажет только одну группу с **##id##** 5 в виджете.
875 )))
876
877 ----
878
879 (% class="box warningmessage" %)
880 (((
881 **##* ##**- доступно в новой версии виджета
882 )))