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

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

<
От версии < 46.1 >
отредактировано Михаил Галич
на 20.12.2023, 12:06
К версии < 77.1 >
отредактировано Байн Огультинова
на 28.08.2025, 14:37
>
Изменить комментарий: К данной версии нет комментариев

Комментарий

Подробности

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