Изменения документа Для_разработчиков

Редактировал(а) Михаил Галич 19.09.2025, 10:16

<
От версии < 39.2 >
отредактировано Михаил Галич
на 15.12.2023, 14:12
К версии < 79.1 >
отредактировано Юлия Кирюшина
на 01.09.2025, 12:30
>
Изменить комментарий: К данной версии нет комментариев

Комментарий

Подробности

Свойства страницы
Название
... ... @@ -1,1 +1,1 @@
1 -Для разработчиков
1 +Для_разработчиков
Автор документа
... ... @@ -1,1 +1,1 @@
1 -XWiki.galich
1 +XWiki.kirushina
Содержимое
... ... @@ -9,6 +9,7 @@
9 9  2. Вставьте в необходимом месте на своём сайте код:
10 10  
11 11  {{code language="html"}}
12 +
12 12  <script type="text/javascript">
13 13  // инициализируем виджет с параметрами
14 14  WPInit({
... ... @@ -31,6 +31,7 @@
31 31   }
32 32  }
33 33  </script>
35 +
34 34  {{/code}}
35 35  
36 36  = Функции =
... ... @@ -57,10 +57,10 @@
57 57  
58 58  {{code language="javascript"}}
59 59  WPInit({
60 - id: 1,
61 - width: 400,
62 - height: 600,
63 - type: 'modal'
62 +id: 1,
63 +width: 400,
64 +height: 600,
65 +type: 'modal'
64 64  })
65 65  {{/code}}
66 66  
... ... @@ -76,7 +76,7 @@
76 76  {{code language="javascript"}}
77 77  // показ виджета с группой id 5
78 78  WPOpen({
79 - groupid: [5]
81 +groupid: [5]
80 80  })
81 81  {{/code}}
82 82  
... ... @@ -93,7 +93,7 @@
93 93  // показ виджета на нажатие кнопки с id "OpenButton"
94 94  var OpenButton = document.getElementById('OpenButton');
95 95  OpenButton.onclick = function () {
96 - WPOpenModal({ tariffsid: [27, 28] });
98 +WPOpenModal({ tariffsid: [27, 28] });
97 97  };
98 98  {{/code}}
99 99  
... ... @@ -108,10 +108,10 @@
108 108  
109 109  ===== Примеры передаваемых данных: =====
110 110  
111 -* ##{ status:'starting' }## — виджет в процессе запуска, в этот момент определяется, что он должен в данный момент отображать
112 -* ##{ status:'started' }## — виджет на начальном экране, где показывается список услуг для покупки
113 -* ##{ status:'reserved', data: { order_id: 2 } }## — виджет находится на стадии забронированного заказ, в data передаётся id
114 -* ##{ status:'completed', data: { order_id: 2 } }## — виджет находится на стадии оплаченного заказ, в data передаётся id заказа
113 +- ##{ status:'starting' }## — виджет в процессе запуска, в этот момент определяется, что он должен в данный момент отображать
114 +- ##{ status:'started' }## — виджет на начальном экране, где показывается список услуг для покупки
115 +- ##{ status:'reserved', data: { order_id: 2 } }## — виджет находится на стадии забронированного заказ, в data передаётся id
116 +- ##{ status:'completed', data: { order_id: 2 } }## — виджет находится на стадии оплаченного заказ, в data передаётся id заказа
115 115  
116 116  ===== Пример работы с данными: =====
117 117  
... ... @@ -149,28 +149,24 @@
149 149  
150 150  ==== height ====
151 151  
152 -Тип данных:## //number //##//|## boolean##//
154 +Тип данных:## //number//##
153 153  
154 -По умолчанию:##// false//##
155 -
156 156  (% class="box infomessage" %)
157 157  (((
158 158  Высота виджета в пикселях, по умолчанию:
159 - • 480px, если виджет запущен как type: 'modal'
160 - • 100%, если виджет запущен как type: 'instant'
159 +• 480px, если виджет запущен как type: 'modal'
160 +• 100%, если виджет запущен как type: 'instant'
161 161  )))
162 162  
163 163  ==== width ====
164 164  
165 -Тип данных:## //number //##//|## boolean##//
165 +Тип данных:## //number//##
166 166  
167 -По умолчанию:##// false//##
168 -
169 169  (% class="box infomessage" %)
170 170  (((
171 171  Ширина виджета в пикселях, по умолчанию:
172 - • 640px, если виджет запущен как type: 'modal'
173 - • 100%, если виджет запущен как type: 'instant'
170 +• 640px, если виджет запущен как type: 'modal'
171 +• 100%, если виджет запущен как type: 'instant'
174 174  )))
175 175  
176 176  ==== type ====
... ... @@ -182,16 +182,14 @@
182 182  (% class="box infomessage" %)
183 183  (((
184 184  Способ открытия виджета
185 - • 'instant' Открытие виджета на месте, где был вызов виджета (на месте тэга script), либо в блоке place, если он указан в параметрах виджета при инициализации
186 - • 'modal' Открытие виджета в модальном окне
183 +• 'instant' Открытие виджета на месте, где был вызов виджета (на месте тэга script), либо в блоке place, если он указан в параметрах виджета при инициализации
184 +• 'modal' Открытие виджета в модальном окне
187 187  )))
188 188  
189 189  ==== place ====
190 190  
191 -Тип данных:## //string //##//|## boolean##//
189 +Тип данных:## //string//##
192 192  
193 -По умолчанию:##// false//##
194 -
195 195  (% class="box infomessage" %)
196 196  (((
197 197  Идентификатор элемента DOM, в который необходимо поместить виджет, например: **###widget##**. Используется совместно с **##type: 'instant'##**
... ... @@ -206,9 +206,9 @@
206 206  
207 207  == Возможные параметры WPOpen и WPOpenModal ==
208 208  
209 -=== Календарь и даты ===
205 +=== Инструкторские занятия ===
210 210  
211 -==== disableddates ====
207 +==== categories ====
212 212  
213 213  Тип данных:##// Array<string>//##
214 214  
... ... @@ -216,239 +216,335 @@
216 216  
217 217  (% class="box infomessage" %)
218 218  (((
219 -Параметр отключения дат в календаре (и в //покупке// и в //пополнении//). Делает невозможным выбор определённых дней в массиве дат.
215 +Фильтр категорий инструкторских занятий. Скрывает категории в выпадающем списке, **##id##** которых не совпадают заданными в массиве.
220 220  )))
221 221  
218 +[[image:1703065952567-753.png]]
219 +
220 +==== coachid ====
221 +
222 +Тип данных:##// number//##
223 +
224 +По умолчанию:##// undefined//##
225 +
226 +(% class="box infomessage" %)
227 +(((
228 +Идентификатор тренера, позволяет сепарировать список занятий по тренеру
229 +)))
230 +
231 +==== grouplessonsskillstariffs ====
232 +
233 +Тип данных:##// object//##
234 +
235 +По умолчанию:##// {}//##
236 +
237 +(% class="box infomessage" %)
238 +(((
239 +Ограничивает список тарифов (в фильтре) при выборе конкретной дисциплины групповых занятий.
240 +Принимает объект, внутри которого указываются пары ключ/значение по выражению: {skillid}: [{tariffid},...]
241 +)))
242 +
222 222  Пример:
223 223  
224 224  {{code language="javascript"}}
225 -disableddates: ['23.02.2018', '08.03.2018'] // уберёт даты 23.02.2018 и 08.03.2018 из возможных для выбора дат в календаре.
246 +grouplessonsskillstariffs: {
247 + "1": [ 15, 23] // При выборе дисциплины с id 1 - отображать тарифы с id 15 и 23
248 +}
226 226  {{/code}}
227 227  
228 -==== forcedate ====
251 +==== grouplessonstariffsid ====
229 229  
230 -Тип данных:##// string//##
253 +Тип данных:##// Array<number>//##
231 231  
232 -По умолчанию:##// undefined//##
255 +По умолчанию:##// []//##
233 233  
234 234  (% class="box infomessage" %)
235 235  (((
236 -Параметр для открывания виджета с указанной сразу датой (и в //покупке// и в //пополнении//).
237 -**##forcedate: '20.05.2018'##** покажет услуги к продаже на дату 20.05.2018.
259 +Фильтр программ обучения для групповых занятий
238 238  )))
239 239  
240 -==== maxdate ====
262 +[[image:1703065356750-663.png]]
241 241  
242 -Тип данных:##// string//##
264 +Пример:
243 243  
266 +{{code language="javascript"}}
267 +grouplessonstariffsid: [1823, 1900] // скрыть групповые программы обучения, кроме 1823 и 1900
268 +{{/code}}
269 +
270 +==== lessonslocation ====
271 +
272 +Тип данных:##// number//##
273 +
244 244  По умолчанию:##// undefined//##
245 245  
246 246  (% class="box infomessage" %)
247 247  (((
248 -Параметр максимальной отображаемой даты в календаре (и в //покупке// и в //пополнении//).
249 -**##maxdate: '20.05.2018'##** покажет 20.05.2018 как самую последнюю дату, доступную к выбору в календаре.
278 +Отображение места занятия для индивидуальных, групповых и многодневных занятий
250 250  )))
251 251  
252 -==== mindate ====
281 +[[image:1702560957244-690.png]]
253 253  
254 -Тип данных:##// string//##
283 +==== lessonstariffsid ====
255 255  
256 -По умолчанию:##// undefined//##
285 +Тип данных:##// Array<number>//##
257 257  
287 +По умолчанию:##// []//##
288 +
258 258  (% class="box infomessage" %)
259 259  (((
260 -Параметр минимальной отображаемой даты в календаре (и в //покупке// и в //пополнении//). mindate: '20.05.2018' покажет 20.05.2018 как самую первую дату, доступную к выбору в календаре, если она находится после текущего дня.
291 +Ограничить видимость доступных тарифов в выпадающем списке программ обучения по массиву с их идентификаторами
261 261  )))
262 262  
263 -==== nocalendar ====
294 +[[image:1702641274330-465.png]]
264 264  
265 -Тип данных:## //boolean//##
296 +==== multidayslessonsskillstariffs ====
266 266  
298 +Тип данных:##// Array<number> //##//|## object##//
299 +
300 +По умолчанию:##// []//##
301 +
302 +(% class="box infomessage" %)
303 +(((
304 +Производит фильтрацию тарифов для многодневных занятий. Принимает массив идентификаторов.
305 +Параметр дополняет фильтрацию по параметру **##grouplessonsskillstariffs##**.
306 +)))
307 +
308 +==== nocategories ====
309 +
310 +Тип данных:##// boolean//##
311 +
267 267  По умолчанию:##// false//##
268 268  
269 269  (% class="box infomessage" %)
270 270  (((
271 -Убирает календарь внутри виджета (и в //покупке// и в //пополнении//), в случаях, когда дата, на которую покупается/пополняется билет, не важна.
316 +Если **##true##** скрывает фильтр по категории инструкторских занятий
272 272  )))
273 273  
274 -----
319 +[[image:1702638427440-675.png]]
275 275  
276 -=== Услуги, пакеты услуг, группы услуг ===
321 +==== nocoach ====
277 277  
278 -==== tariffsid ====
323 +Тип данных:##// boolean//##
279 279  
280 -Тип данных:##// Array<number> //##//|## boolean##//
325 +По умолчанию:##// false//##
281 281  
282 -По умолчанию:##// []//##
327 +(% class="box infomessage" %)
328 +(((
329 +Если **##true##** скрывает выпадающее меню выбора инструктора
330 +)))
283 283  
332 +[[image:1702638265778-588.png]]
333 +
334 +==== nolocation ====
335 +
336 +Тип данных:##// boolean//##
337 +
338 +По умолчанию:##// false//##
339 +
284 284  (% class="box infomessage" %)
285 285  (((
286 -Тарифы, которые следует показать на вкладке «Покупка услуг». По умолчанию массив пуст и не показывает отдельно никакие из услуг. Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать услуги, доступные только для него.
342 +Если **##true##** скрывает фильтр по месту проведения инструкторских занятий
287 287  )))
288 288  
289 -Пример:
345 +[[image:1702638034420-756.png]]
290 290  
291 -{{code language="javascript"}}
292 -tariffsid: [29, 30] // покажет тарифы с id 29 и 30 во вкладке «Покупка услуг».
293 -tariffsid: false // уберёт все тарифы с первой страницы
294 -{{/code}}
347 +==== noskills ====
295 295  
296 -==== rtariffsid ====
349 +Тип данных:##// boolean//##
297 297  
298 -Тип данных:##// Array<number> //##//|## boolean##//
351 +По умолчанию:##// false//##
299 299  
300 -По умолчанию:##// []//##
353 +(% class="box infomessage" %)
354 +(((
355 +Если **##true##** скрывает фильтр по дисциплине инструкторских занятий
356 +)))
301 301  
358 +[[image:1702638705750-678.png]]
359 +
360 +==== notagfilter ====
361 +
362 +Тип данных:##// boolean//##
363 +
364 +По умолчанию:##// false//##
365 +
302 302  (% class="box infomessage" %)
303 303  (((
304 -Тарифы, которые следует показать после ввода карты во вкладке «Пополнение услуг». По умолчанию массив пуст и не показывает отдельно никакие из услуг. Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать услуги, доступные только для него.
368 +Если **##true##** скрывает фильтр по тэгам
305 305  )))
306 306  
307 -Пример:
371 +[[image:1732612477973-413.png]]
308 308  
309 -{{code language="javascript"}}
310 -rtariffsid: [56, 57] // покажет тарифы с id 56 и 57 после ввода карты во вкладке «Пополнение услуг»
311 -rtariffsid: false // уберёт все тарифы во вкладке «Пополнение услуг»
312 -{{/code}}
313 313  
314 -==== bundlesid ====
374 +==== notariffs ====
315 315  
316 -Тип данных:##// Array<number> //##//|## boolean##//
376 +Тип данных:##// boolean//##
317 317  
318 -По умолчанию:##// []//##
378 +По умолчанию:##// false//##
319 319  
320 320  (% class="box infomessage" %)
321 321  (((
322 -Пакеты услуг, которые следует показать на первой странице. По умолчанию массив пуст и не показывает отдельно никакие из пакетов услуг. Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать пакеты услуг, доступные только для него.
382 +Если **##true##** скрывает фильтр по программе обучения инструкторских занятий
323 323  )))
324 324  
385 +[[image:1703063138160-208.png]]
386 +
387 +==== personallessonsskillstariffs ====
388 +
389 +Тип данных:##// object//##
390 +
391 +По умолчанию:##// {}//##
392 +
393 +(% class="box infomessage" %)
394 +(((
395 +Ограничивает список тарифов (в фильтре) при выборе конкретной дисциплины.
396 +Принимает объект, внутри которого указываются пары ключ/значение по выражению: {skillid}: [{tariffid},...]
397 +)))
398 +
325 325  Пример:
326 326  
327 327  {{code language="javascript"}}
328 -bundlesid: [4, 5] // покажет пакеты услуг с id 4 и 5 в момент открытия виджета.
329 -bundlesid: false // уберёт все пакеты услуг с первой страницы
402 +personallessonsskillstariffs: {
403 + "1": [ 15, 23] // При выборе дисциплины с id 1 - отображать тарифы с id 15 и 23
404 +}
330 330  {{/code}}
331 331  
332 -==== bundleslessonstariffsid ====
407 +==== placeid ====
333 333  
334 -Тип данных:##// Array<number>//##
409 +Тип данных:##// number//##
335 335  
336 -По умолчанию:##// []//##
411 +По умолчанию:##// undefined//##
337 337  
338 -(% class="box warningmessage" %)
413 +(% class="box infomessage" %)
339 339  (((
340 -Описание отсутствует
415 +Идентификатор места, использующийся для получения списка инструкторов.
341 341  )))
342 342  
343 -==== groupid ====
418 +==== singleguest ====
344 344  
345 -Тип данных:##// number//##
420 +Тип данных:##// Boolean//##
346 346  
347 -По умолчанию:##// undefined//##
422 +По умолчанию:##// false//##
348 348  
349 349  (% class="box infomessage" %)
350 350  (((
351 -Параметр, который форсирует показ определённой группы услуг ппс. groupid: 5 покажет только одну группу с id 5 в виджете.
426 +Если **##true##**, то при выборе занятия препятствует выбору 2 гостей.
352 352  )))
353 353  
354 -----
429 +[[image:1710854841918-858.png]]
355 355  
356 -=== Предзаказ ===
431 +==== skills ====
357 357  
358 -==== preorder ====
433 +Тип данных:##// Array<number>//##
359 359  
360 -Тип данных:##// Array<object>//##
435 +По умолчанию:##// []//##
361 361  
362 -По умолчанию:##// undefined//##
437 +(% class="box infomessage" %)
438 +(((
439 +Ограничить видимость доступных к выбору дисциплин по идентификатору
440 +)))
363 363  
442 +[[image:1702639385677-964.png]]
443 +
444 +=== Календарь и даты ===
445 +
446 +==== disableddates * ====
447 +
448 +Тип данных:##// Array<string>//##
449 +
450 +По умолчанию:##// []//##
451 +
364 364  (% class="box infomessage" %)
365 365  (((
366 -Параметр, позволяющий купить сразу несколько услуг и перейти к подтверждению покупки.
367 - • id — id услуги к покупке
368 - • date — дата, на которую покупается услуга
369 - • count — количество покупаемых услуг
454 +Параметр отключения дат в календаре (и в //покупке// и в //пополнении//). Делает невозможным выбор определённых дней в массиве дат.
370 370  )))
371 371  
372 -===== Пример передаваемых данных: =====
457 +Пример:
373 373  
374 374  {{code language="javascript"}}
375 -// либо WPOpenModal({})
376 -WPOpen({
377 - preorder: [
378 - {
379 - id: 57,
380 - date: '06.06.2019',
381 - count: 1
382 - }, {
383 - id: 58,
384 - date: '07.06.2019',
385 - count: 2
386 - }
387 - ]
388 -})
460 +disableddates: ['23.02.2018', '08.03.2018'] // уберёт даты 23.02.2018 и 08.03.2018 из возможных для выбора дат в календаре.
389 389  {{/code}}
390 390  
391 -----
463 +==== disableddays **##*##** ====
392 392  
393 -=== Отображение ===
465 +Тип данных:##// Array<number>//##
394 394  
395 -==== cartmaxitems ====
467 +По умолчанию:##// []//##
396 396  
397 -Тип данных:##// number//##
469 +(% class="box infomessage" %)
470 +(((
471 +Параметры открлючения дней недели в календаре (и в покупке и в пополнении), где 0 - воскресенье, 1 - понедельник и так далее.
472 +)))
398 398  
399 -По умолчанию:##// 6//##
474 +==== forcedate * ====
400 400  
476 +Тип данных:##// string//##
477 +
478 +По умолчанию:##// undefined//##
479 +
401 401  (% class="box infomessage" %)
402 402  (((
403 -Ограничивает максимальное кол-во товаров в корзине. ##Минимальное значение 1, но не меньше **cartminitems**. Максимальное значение 60.##
482 +Параметр для открывания виджета с указанной сразу датой (и в //покупке// и в //пополнении//).
483 +**##forcedate: '20.05.2018'##** покажет услуги к продаже на дату 20.05.2018.
404 404  )))
405 405  
406 -==== cartminitems ====
486 +==== maxdate * ====
407 407  
408 -Тип данных:##// number//##
488 +Тип данных:##// string//##
409 409  
410 -По умолчанию:##// 1//##
490 +По умолчанию:##// undefined//##
411 411  
412 412  (% class="box infomessage" %)
413 413  (((
414 -Ограничивает минимальное кол-во товаров в корзине. ##Минимальное значение 1. Максимальное значение 60, но не больше **cartmaxitems**.##
494 +Параметр максимальной отображаемой даты в календаре (и в //покупке// и в //пополнении//).
495 +**##maxdate: '20.05.2018'##** покажет 20.05.2018 как самую последнюю дату, доступную к выбору в календаре.
415 415  )))
416 416  
417 -==== categories ====
498 +==== mindate * ====
418 418  
419 -Тип данных:##// Array<string>//##
500 +Тип данных:##// string//##
420 420  
421 -По умолчанию:##// []//##
502 +По умолчанию:##// undefined//##
422 422  
423 -(% class="box warningmessage" %)
504 +(% class="box infomessage" %)
424 424  (((
425 -Описание отсутствует
506 +Параметр минимальной отображаемой даты в календаре (и в //покупке// и в //пополнении//).
507 +**##mindate: '20.05.2018'##** покажет 20.05.2018 как самую первую дату, доступную к выбору в календаре, если она находится после текущего дня.
426 426  )))
427 427  
428 -==== clubsiteid ====
510 +==== nocalendar * ====
429 429  
430 -Тип данных:##// number//##
512 +Тип данных:## //boolean//##
431 431  
432 -По умолчанию:##// 0//##
514 +По умолчанию:##// false//##
433 433  
434 -(% class="box warningmessage" %)
516 +(% class="box infomessage" %)
435 435  (((
436 -Описание отсутствует
518 +Убирает календарь внутри виджета (и в //покупке// и в //пополнении//), в случаях, когда дата, на которую покупается/пополняется билет, не важна.
437 437  )))
438 438  
439 -==== coachid ====
521 +==== servicecalendar * ====
440 440  
441 -Тип данных:##// number//##
523 +Тип данных~:// "block" | "page"//
442 442  
443 -По умолчанию:##// undefined//##
525 +По умолчанию без указания идентификатора не учитывается.
444 444  
445 -(% class="box warningmessage" %)
527 +(% class="box infomessage" %)
446 446  (((
447 -Описание отсутствует
529 +Изменяет отображение календаря в виджете.
530 +
531 +**servicecalendar: "block"  **обычно используется в комбинации с параметром **busycalendar:true, **чтобы скрыть кнопки Отменить, Очистить и Ок.
532 +
533 +При** servicecalendar: "page" **календарь не имеет привычных кнопок календаря Отменить, Очистить и Ок, вместо них доступна только кнопка Выбрать, потому в комбинации с параметром **busycalendar:true **не нуждается.
448 448  )))
449 449  
450 -==== disablemultipleseances ====
536 +{{code language="javascript"}}
537 +servicecalendar: "block" // закрепит календарь в виджете в открытом виде.
451 451  
539 +servicecalendar: "page" // автоматически откроет календарь в виджете при инициализации.
540 +{{/code}}
541 +
542 +==== busycalendar * ====
543 +
452 452  Тип данных:##// boolean//##
453 453  
454 454  По умолчанию:##// false//##
... ... @@ -455,152 +455,167 @@
455 455  
456 456  (% class="box infomessage" %)
457 457  (((
458 -Параметр предотвращает добавление в корзину тарифов с различными сеансами.
459 -Таким образом как только в корзине появится хоть один товар с сеансом "10:00 - 11:30", товары, у которых есть сеанс например "13:00 - 14:30" будет невозможно добавить в корзину.
460 -Товары без сеансов __не будут затронуты__.
550 +Изменяет отображение календаря в виджете.
551 +
552 +Работает, если **servicecalendar: "block".**
553 +
554 +Используется, чтобы скрыть кнопки Отменить, Очистить и Ок у закрепленного календаря.
461 461  )))
462 462  
463 -==== forcemedia ====
557 +==== saledepth **##*##** ====
464 464  
465 -Тип данных:##// string//##
559 +Тип данных:## //number//##
466 466  
467 -По умолчанию:##// ''//##
561 +По умолчанию:##// undefined//##
468 468  
469 469  (% class="box infomessage" %)
470 470  (((
471 -Параметр, который вставяет строчку с носителем в поле носителя во вкладке «Пополнение услуг». Используется, например, для QR-кода нанесённого на носитель, чтобы быстро его пополнить.
565 +Ограничивает глубину продаж начиная с сегодняшнего дня. Таким образом если ##saledepth: 1##, то доступные даты в календаре выбора тарифа будут __**сегодня **__и __**завтра**__.
566 +⚠ Имеет больший приоритет, чем ##maxdate##
472 472  )))
473 473  
474 -Пример:
569 +----
475 475  
476 -{{code language="javascript"}}
477 -forcemedia: 'E0012345678900'
478 -{{/code}}
571 +=== Отображение ===
479 479  
480 -==== forceseanceid ====
573 +==== cartmaxitems ====
481 481  
482 482  Тип данных:##// number//##
483 483  
484 -По умолчанию без указания идентификатора не учитывается.
577 +По умолчанию:##// 6//##
485 485  
486 486  (% class="box infomessage" %)
487 487  (((
488 -Заставит виджет выбрать мероприятие арены по идентификатору платформы и не позволять вернуться к этапу выбора других мероприятий.
581 +Ограничивает максимальное кол-во товаров в корзине. ##Минимальное значение 1, но не меньше **cartminitems**. Максимальное значение 60.##
489 489  )))
490 490  
491 -==== forcesectorid ====
584 +==== cartminitems ====
492 492  
493 493  Тип данных:##// number//##
494 494  
495 -По умолчанию без указания идентификатора не учитывается.
588 +По умолчанию:##// 1//##
496 496  
497 497  (% class="box infomessage" %)
498 498  (((
499 -Заставит виджет выбрать сектор мероприятия по **##id##** и не позволять вернуться к этапу выбора других секторов.
592 +Ограничивает минимальное кол-во товаров в корзине. ##Минимальное значение 1. Максимальное значение 60, но не больше **cartmaxitems**.##
500 500  )))
501 501  
502 -==== forcetab ====
595 +==== clubsiteid ====
503 503  
504 -Тип данных:##// string//##
597 +Тип данных:##// number//##
505 505  
506 -По умолчанию:##// ''//##
599 +По умолчанию:##// 0//##
507 507  
508 508  (% class="box infomessage" %)
509 509  (((
510 -Переключение на необходимую вкладку виджета («**покупка услуг**» или «**пополнение услуг**») при загрузке.
511 -По умолчанию открывается вкладка «**покупка услуг**».
512 -**##forcetab: 'rewrite'##** принудительно откроет «**пополнение услуг**».
513 -Обычно используется в комбинации с параметром **##onlytab##**
603 +Вызов сайта для оформления клубного контракта
514 514  )))
515 515  
516 -==== grouplessonsskillstariffs ====
606 +==== customseancetitles ====
517 517  
518 -Тип данных:##// Array<number> //##//|## object##//
608 +Типа данных: ##//Array<object>//##
519 519  
520 -По умолчанию:##// {}//##
521 -
522 -(% class="box warningmessage" %)
610 +(% class="box infomessage" %)
523 523  (((
524 -Описание отсутствует
612 +Выводит цветную текст-метку над сеансом.
613 +Описание параметров объекта текста-метки:
614 +\\##**seanceId**## - идентификатор сеанса, у которого нужно отобразить текст-метку
615 +##**days**## - массив с днями недели, в которые нужно отобразить текст-метку. **ВАЖНО**: 0 - воскресенье, 1 - понедельник ... 6 - суббота
616 +##**dates**## - массив с датами, в которые нужно отобразить текст-метку независимо от массива дней.
617 +##**color**## - любой валидный CSS цвет текста-метки
618 +##**text**## - текст, который нужно отобразить
619 +\\Работает если **##tariffsseancesfilter: true##**
525 525  )))
526 526  
527 -==== grouplessonstariffsid ====
622 +Пример:
528 528  
529 -Тип данных:##// Array<number>//##
624 +{{code language="javascript"}}
625 +customseancetitles: [
626 + {
627 + seanceId: 1,
628 + text: "Тематический сеанс",
629 + color: "#f00",
630 + days: [0,1],
631 + dates: ["25.12.2023","17.04.2025"]
632 + }
633 +]
634 +{{/code}}
530 530  
531 -По умолчанию:##// []//##
636 +==== disablemultipleseances ====
532 532  
533 -(% class="box warningmessage" %)
534 -(((
535 -Описание отсутствует
536 -)))
537 -
538 -==== ismobile ====
539 -
540 540  Тип данных:##// boolean//##
541 541  
542 542  По умолчанию:##// false//##
543 543  
544 -(% class="box warningmessage" %)
642 +(% class="box infomessage" %)
545 545  (((
546 -Описание отсутствует
644 +Параметр предотвращает добавление в корзину тарифов с различными сеансами.
645 +Таким образом как только в корзине появится хоть один товар с сеансом "10:00 - 11:30", товары, у которых есть сеанс например "13:00 - 14:30" будет невозможно добавить в корзину.
646 +Товары без сеансов **не будут затронуты**.
547 547  )))
548 548  
549 -==== lessonslocation ====
649 +==== forcemedia * ====
550 550  
551 -Тип данных:##// number//##
651 +Тип данных:##// string//##
552 552  
553 -По умолчанию:##// undefined//##
653 +По умолчанию:##// ''//##
554 554  
555 555  (% class="box infomessage" %)
556 556  (((
557 -Отображение места занятия для индивидуальных, групповых и многодневных занятий
657 +Параметр, который вставяет строчку с носителем в поле носителя во вкладке «Пополнение услуг». Используется, например, для QR-кода нанесённого на носитель, чтобы быстро его пополнить.
558 558  )))
559 559  
560 -[[image:1702560957244-690.png]]
660 +Пример:
561 561  
562 -==== lessonstariffsid ====
662 +{{code language="javascript"}}
663 +forcemedia: 'E0012345678900'
664 +{{/code}}
563 563  
564 -Тип данных:##// Array<number>//##
666 +==== forceseanceid ====
565 565  
566 -По умолчанию:##// []//##
668 +Тип данных:##// number//##
567 567  
568 -(% class="box warningmessage" %)
670 +По умолчанию без указания идентификатора не учитывается.
671 +
672 +(% class="box infomessage" %)
569 569  (((
570 -Описание отсутствует
674 +Заставит виджет выбрать мероприятие арены по идентификатору платформы и не позволять вернуться к этапу выбора других мероприятий.
571 571  )))
572 572  
573 -==== locale ====
677 +==== forcesectorid ====
574 574  
575 -Тип данных:##// string//##
679 +Тип данных:##// number//##
576 576  
577 -По умолчанию:##// ''//##
681 +По умолчанию без указания идентификатора не учитывается.
578 578  
579 579  (% class="box infomessage" %)
580 580  (((
581 -Параметр локализации. Позволяет переключать между языками виджета, например 'ru' - русский язык, 'en' - английский язык.
685 +Заставит виджет выбрать сектор мероприятия по **##id##** и не позволять вернуться к этапу выбора других секторов.
582 582  )))
583 583  
584 -==== marketbillid ====
688 +==== forcetab **##*##** ====
585 585  
586 -Тип данных:##// number//##
690 +Тип данных:##// string//##
587 587  
588 -По умолчанию:##// undefined//##
692 +По умолчанию:##// ''//##
589 589  
590 -(% class="box warningmessage" %)
694 +(% class="box infomessage" %)
591 591  (((
592 -Описание отсутствует
696 +Переключение на необходимую вкладку виджета («**покупка услуг**» или «**пополнение услуг**») при загрузке.
697 +По умолчанию открывается вкладка «**покупка услуг**».
698 +**##forcetab: 'rewrite'##** принудительно откроет «**пополнение услуг**».
699 +Обычно используется в комбинации с параметром **##onlytab##**
593 593  )))
594 594  
595 -==== marketemployeeid ====
702 +==== locale * ====
596 596  
597 -Тип данных:##// number//##
704 +Тип данных:##// string//##
598 598  
599 -По умолчанию:##// undefined//##
706 +По умолчанию:##// ''//##
600 600  
601 -(% class="box warningmessage" %)
708 +(% class="box infomessage" %)
602 602  (((
603 -Описание отсутствует
710 +Параметр локализации. Позволяет переключать между языками виджета, например 'ru' - русский язык, 'en' - английский язык.
604 604  )))
605 605  
606 606  ==== minimap ====
... ... @@ -625,20 +625,8 @@
625 625  Размер миникарты относительной полного размера карты, а не контейнера, в которой она находится.
626 626  )))
627 627  
628 -==== multidayslessonsskillstarif(% style="display:none" %) (%%)fs ====
735 +==== nopromo * ====
629 629  
630 -Тип данных:##// Array<number> //##//|## object##//
631 -
632 -По умолчанию:##// []//##
633 -
634 -(% class="box infomessage" %)
635 -(((
636 -Производит фильтрацию тарифов для многодневных занятий. Принимает массив идентификаторов.
637 -Параметр дополняет фильтрацию по параметру **##grouplessonsskillstariffs##**.
638 -)))
639 -
640 -==== nocategories ====
641 -
642 642  Тип данных:##// boolean//##
643 643  
644 644  По умолчанию:##// false//##
... ... @@ -645,13 +645,11 @@
645 645  
646 646  (% class="box infomessage" %)
647 647  (((
648 -Если **##true##** скрывает фильтр по категории инструкторских занятий
743 +Убирает вывод промокода на странице подтверждения заказа.
649 649  )))
650 650  
651 -[[image:1702638427440-675.png]]
746 +==== noscroll ====
652 652  
653 -==== nocoach ====
654 -
655 655  Тип данных:##// boolean//##
656 656  
657 657  По умолчанию:##// false//##
... ... @@ -658,36 +658,43 @@
658 658  
659 659  (% class="box infomessage" %)
660 660  (((
661 -Если **##true##** скрывает выпадающее меню выбора инструктора
754 +Скрывает кнопку прокручивания страницы виджета продаж вверх
662 662  )))
663 663  
664 -[[image:1702638265778-588.png]]
757 +==== onlytab **##*##** ====
665 665  
666 -==== nolocation ====
759 +Тип данных:##// string //##//|## Array<string>##//
667 667  
668 -Тип данных:##// boolean//##
761 +По умолчанию:##// []//##
669 669  
670 -По умолчанию:##// false//##
671 -
672 672  (% class="box infomessage" %)
673 673  (((
674 -Если **##true##** скрывает фильтр по месту проведения инструкторских занятий
765 +Скрытие других вкладок виджета («покупка услуг» или «пополнение услуг») при загрузке. Обычно используется в комбинации с параметром **##forcetab
766 +Важно: ##**##если для отображения выбрана только одна вкладка, то вся навигационная панель скрывается.##
675 675  )))
676 676  
677 -==== [[image:1702638034420-756.png]] ====
769 +{{code language="javascript"}}
770 +onlytab: "service" // покажет только вкладку «покупка услуг».
771 +onlytab: "rewrite" // покажет только вкладку «пополнение услуг».
772 +onlytab: "personal_lessons" // покажет только вкладку «индивидуальные занятия».
773 +onlytab: "group_lessons" // покажет только вкладку «групповые занятия».
774 +onlytab: "bundles_lessons" // покажет только вкладку «многодневные занятия».
775 +onlytab: ["service", "rewrite"] // покажет только вкладки «покупка услуг» и «пополнение услуг»;
776 +onlytab: "service, rewrite" // покажет только вкладки «покупка услуг» и «пополнение услуг»;
777 +{{/code}}
678 678  
679 -==== nopromo ====
779 +==== ordercomment ====
680 680  
681 -Тип данных:##// boolean//##
781 +Тип данных:##// string//##
682 682  
683 -По умолчанию:##// false//##
783 +По умолчанию:##// ''//##
684 684  
685 685  (% class="box infomessage" %)
686 686  (((
687 -Убирает вывод промокода на странице подтверждения заказа.
787 +Опциональный комментарий к заказу. Максимальная длинна комментария 50 символов.
688 688  )))
689 689  
690 -==== noskills ====
790 +==== requiredloyalty ====
691 691  
692 692  Тип данных:##// boolean//##
693 693  
... ... @@ -695,74 +695,78 @@
695 695  
696 696  (% class="box infomessage" %)
697 697  (((
698 -Если **##true##** скрывает фильтр по дисциплине инструкторских занятий
798 +Включает обязательную регистрацию клиента в программе настроенной на объекте.
699 699  )))
700 700  
701 -[[image:1702638705750-678.png]]
801 +==== resetcart ====
702 702  
703 -==== notariffs ====
704 -
705 705  Тип данных:##// boolean//##
706 706  
707 707  По умолчанию:##// false//##
708 708  
709 -(% class="box warningmessage" %)
807 +(% class="box infomessage" %)
710 710  (((
711 -Описание отсутствует
809 +Автоматически очищать содержимое корзины.
712 712  )))
713 713  
714 -==== onlytab ====
812 +==== saletermstype ====
715 715  
716 -Тип данных:##// string //##//|## Array<string>##//
814 +Тип данных:##// string//##
717 717  
718 -По умолчанию:##// []//##
816 +По умолчанию:##// '//default//'//##
719 719  
720 720  (% class="box infomessage" %)
721 721  (((
722 -Скрытие других вкладок виджета покупка услуг» или «пополнение услуг») при загрузке. Обычно используется в комбинации с параметром **##forcetab##**
820 +Перед оплатой просит пользователя согласиться с правилами в форме галочки или всплывающего окна
723 723  )))
724 724  
725 725  {{code language="javascript"}}
726 -onlytab: 'service' // покажет только вкладку «покупка услуг».
727 -onlytab: 'rewrite' // покажет только вкладку «пополнение услуг».
728 -onlytab: ['service', 'rewrite'] // покажет только вкладки «покупка услуг» и «пополнение услуг»;
824 +saletermstype: 'checkbox' // потребует установку галочки для согласия.
825 +saletermstype: 'dialog' // покажет всплывающее окно с правилами, которые нужно принять.
826 +saletermstype: 'default' // принятие правил не требуется.
729 729  {{/code}}
730 730  
731 -==== ordercomment ====
829 +==== shownoticketsseances ====
732 732  
733 -Тип данных:##// string//##
831 +Тип данных:##// boolean//##
734 734  
735 -По умолчанию:##// ''//##
833 +По умолчанию:##// false//##
736 736  
737 737  (% class="box infomessage" %)
738 738  (((
739 -Опциональный комментарий к заказу. Максимальная длинна комментария 50 символов.
837 +Не скрывать сеансы, на которые закончились билеты. Работает если **##tariffsseancesfilter: true##**
740 740  )))
741 741  
742 -==== personallessonsskillstariffs ====
840 +==== showoverseances ====
743 743  
744 -Тип данных:##// Array<number> //##//|## object##//
842 +Тип данных:##// boolean//##
745 745  
746 -По умолчанию:##// []//##
844 +По умолчанию:##// false//##
747 747  
748 748  (% class="box infomessage" %)
749 749  (((
750 -Производит фильтрацию тарифов для индивидуальных занятий. Принимает массив идентификаторов.
848 +Отвечает за отображение прошедших сеансов в списке для фильтрации по времени. При значении **##true##** прошедшие сеансы будут отображаться, но недоступны для выбора пользователем. Работает если **##tariffsseancesfilter: true##**
751 751  )))
752 752  
753 -==== placeid ====
851 +[[image:1702554598837-627.png]]
754 754  
755 -Тип данных:##// number//##
853 +==== tariffsseancesfilter ====
756 756  
757 -По умолчанию:##// undefined//##
855 +Тип данных:##// boolean//##
758 758  
759 -(% class="box warningmessage" %)
857 +По умолчанию:##// false//##
858 +
859 +(% class="box infomessage" %)
760 760  (((
761 -Описание отсутствует
861 +Включить отображение фильтра тарифов по сеансам.
762 762  )))
763 763  
764 -==== requiredloyalty ====
864 +[[image:https://info.moipass.ru/images/tariffsseancesfilter.png||alt="Example"]]
765 765  
866 +==== ====
867 +
868 +==== hidenext * ====
869 +
766 766  Тип данных:##// boolean//##
767 767  
768 768  По умолчанию:##// false//##
... ... @@ -769,92 +769,141 @@
769 769  
770 770  (% class="box infomessage" %)
771 771  (((
772 -Включает обязательную регистрацию клиента в программе настроенной на объектке.
876 +Убирает кнопку Далее, которая отображается после добавления тарифа в корзину до резервирования.
773 773  )))
774 774  
775 -==== resetcart ====
879 +=== Предзаказ ===
776 776  
777 -Тип данных:##// boolean//##
881 +==== preorder ====
778 778  
779 -По умолчанию:##// false//##
883 +Тип данных:##// Array<object>//##
780 780  
885 +По умолчанию:##// undefined//##
886 +
781 781  (% class="box infomessage" %)
782 782  (((
783 -Автоматически очищать содержимое корзины.
889 +Параметр, позволяющий купить сразу несколько услуг и перейти к подтверждению покупки.
890 +• ##id## — id услуги к покупке
891 +• ##date## — дата, на которую покупается услуга
892 +• ##count## — количество покупаемых услуг
784 784  )))
785 785  
786 -==== rewritetariffsid ====
895 +===== Пример передаваемых данных: =====
787 787  
788 -Тип данных:##// Array<number>//##
897 +{{code language="javascript"}}
898 +// либо WPOpenModal({})
899 +WPOpen({
900 + preorder: [
901 + {
902 + id: 57,
903 + date: '06.06.2019',
904 + count: 1
905 + }, {
906 + id: 58,
907 + date: '07.06.2019',
908 + count: 2
909 + }
910 + ]
911 +})
912 +{{/code}}
789 789  
914 +----
915 +
916 +=== Услуги, пакеты услуг, группы услуг ===
917 +
918 +==== tariffsid * ====
919 +
920 +Тип данных:##// Array<number> //##//|## boolean##//
921 +
790 790  По умолчанию:##// []//##
791 791  
792 -(% class="box warningmessage" %)
924 +(% class="box infomessage" %)
793 793  (((
794 -Описание отсутствует
926 +Тарифы, которые следует показать на вкладке «Покупка услуг».
927 +По умолчанию массив пуст и не показывает отдельно никакие из услуг.
928 +Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать услуги, доступные только для него.
795 795  )))
796 796  
797 -==== saletermstype ====
931 +Пример:
798 798  
799 -Тип данных:##// string//##
933 +{{code language="javascript"}}
934 +tariffsid: [29, 30] // покажет тарифы с id 29 и 30 во вкладке «Покупка услуг».
935 +tariffsid: "15, 16" // покажет тарифы с id 15 и 16 во вкладке «Покупка услуг».
936 +tariffsid: false // уберёт все тарифы с первой страницы
937 +{{/code}}
800 800  
801 -По умолчанию:##// '//default//'//##
939 +==== rewritetariffsid * ====
802 802  
941 +Тип данных:##// Array<number> //##//|## boolean##//
942 +
943 +По умолчанию:##// []//##
944 +
803 803  (% class="box infomessage" %)
804 804  (((
805 -Перед оплатой просит пользователя согласиться с правилами в форме галочки или всплывающего окна
947 +Тарифы, которые следует показать после ввода карты во вкладке «Пополнение услуг».
948 +По умолчанию массив пуст и не показывает отдельно никакие из услуг.
949 +Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать услуги, доступные только для него.
806 806  )))
807 807  
952 +Пример:
953 +
808 808  {{code language="javascript"}}
809 -saletermstype: 'checkbox' // потребует установку галочки для согласия.
810 -saletermstype: 'dialog' // покажет всплывающее окно с правилами, которые нужно принять.
811 -saletermstype: 'default' // принятие правил не требуется.
955 +rtariffsid: [56, 57] // покажет тарифы с id 56 и 57 после ввода карты во вкладке «Пополнение услуг»
956 +rtariffsid: false // уберёт все тарифы во вкладке «Пополнение услуг»
812 812  {{/code}}
813 813  
814 -==== shownoticketsseances ====
959 +==== rtariffsid ====
815 815  
816 -Тип данных:##// boolean//##
817 -
818 -По умолчанию:##// false//##
819 -
820 -(% class="box warningmessage" %)
961 +(% class="box infomessage" %)
821 821  (((
822 -Описание отсутствует
963 +См. **##rewritetariffsid##**. Доступен и в старой версии виджета
823 823  )))
824 824  
825 -==== showoverseances ====
966 +==== bundlesid ====
826 826  
827 -Тип данных:##// boolean//##
968 +Тип данных:##// Array<number> //##//|## boolean##//
828 828  
829 -По умолчанию:##// false//##
970 +По умолчанию:##// []//##
830 830  
831 831  (% class="box infomessage" %)
832 832  (((
833 -Отвечает за отображение прошедших сеансов в списке для фильтрации по времени. При значении **##true##** прошедшие сеансы будут отображаться, но недоступны для выбора пользователем. Работает если **##tariffsseancesfilter: true##**
974 +Пакеты услуг, которые следует показать на первой странице.
975 +По умолчанию массив пуст и не показывает отдельно никакие из пакетов услуг.
976 +Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать пакеты услуг, доступные только для него.
834 834  )))
835 835  
836 -[[image:1702554598837-627.png]]
979 +Пример:
837 837  
838 -==== skills ====
981 +{{code language="javascript"}}
982 +bundlesid: [4, 5] // покажет пакеты услуг с id 4 и 5 в момент открытия виджета.
983 +bundlesid: false // уберёт все пакеты услуг с первой страницы
984 +{{/code}}
839 839  
986 +==== bundleslessonstariffsid ====
987 +
840 840  Тип данных:##// Array<number>//##
841 841  
842 842  По умолчанию:##// []//##
843 843  
844 -(% class="box warningmessage" %)
992 +(% class="box infomessage" %)
845 845  (((
846 -Описание отсутствует
994 +Фильтр списка доступных связок занятий по массиву идентификаторов
847 847  )))
848 848  
849 -==== tariffsseancesfilter ====
997 +==== groupid ====
850 850  
851 -Тип данных:##// boolean//##
999 +Тип данных:##// number//##
852 852  
853 -По умолчанию:##// false//##
1001 +По умолчанию:##// undefined//##
854 854  
855 855  (% class="box infomessage" %)
856 856  (((
857 -Включить отображение фильтра тарифов по сеансам.
1005 +Параметр, который форсирует показ определённой группы услуг ппс. **##groupid: 5##** покажет только одну группу с **##id##** 5 в виджете.
858 858  )))
859 859  
860 -[[image:https://info.moipass.ru/images/tariffsseancesfilter.png||alt="Example"]]
1008 +----
1009 +
1010 +(% class="box warningmessage" %)
1011 +(((
1012 +**##* ##**- доступно в новой версии виджета
1013 +)))
1702639385677-964.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.galich
Размер
... ... @@ -1,0 +1,1 @@
1 +2.6 KB
Содержимое
1702641274330-465.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.galich
Размер
... ... @@ -1,0 +1,1 @@
1 +3.7 KB
Содержимое
1703061675290-102.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.galich
Размер
... ... @@ -1,0 +1,1 @@
1 +35.6 KB
Содержимое
1703063138160-208.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.galich
Размер
... ... @@ -1,0 +1,1 @@
1 +3.7 KB
Содержимое
1703065328290-657.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.galich
Размер
... ... @@ -1,0 +1,1 @@
1 +37.2 KB
Содержимое
1703065338350-331.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.galich
Размер
... ... @@ -1,0 +1,1 @@
1 +37.1 KB
Содержимое
1703065356750-663.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.galich
Размер
... ... @@ -1,0 +1,1 @@
1 +36.7 KB
Содержимое
1703065952567-753.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.galich
Размер
... ... @@ -1,0 +1,1 @@
1 +2.9 KB
Содержимое
1710854841918-858.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.galich
Размер
... ... @@ -1,0 +1,1 @@
1 +14.6 KB
Содержимое
1732612477973-413.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.galich
Размер
... ... @@ -1,0 +1,1 @@
1 +24.9 KB
Содержимое
1753179056434-450.png
Author
... ... @@ -1,0 +1,1 @@
1 +XWiki.ogultinova
Размер
... ... @@ -1,0 +1,1 @@
1 +24.1 KB
Содержимое
XWiki.XWikiRights[2]
allow
... ... @@ -1,0 +1,1 @@
1 +Разрешить
groups
... ... @@ -1,0 +1,1 @@
1 +XWiki.XWikiAllGroup
levels
... ... @@ -1,0 +1,1 @@
1 +view