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

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

<
От версии < 56.1 >
отредактировано Михаил Галич
на 21.12.2023, 11:26
К версии < 8.1 >
отредактировано Михаил Галич
на 12.12.2023, 10:53
>
Изменить комментарий: К данной версии нет комментариев

Комментарий

Подробности

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