Исходный код вики Для_разработчиков
Версия 63.3 от Михаил Галич на 27.05.2024, 13:14
Скрыть последних авторов
author | version | line-number | content |
---|---|---|---|
![]() |
17.1 | 1 | {{toc depth="4"/}} |
![]() |
13.1 | 2 | |
![]() |
15.1 | 3 | = Инструкция для подключения = |
![]() |
13.1 | 4 | |
![]() |
21.1 | 5 | Назначение данного раздела — описать способы взаимодействия с виджетом Веб-платформы по задуманному вами сценарию. Типичный процесс подключения, открытия и отслеживания виджета выглядит так: |
![]() |
1.1 | 6 | |
![]() |
13.1 | 7 | ~1. Подключите скрипт ##external.script.js## к вашему сайту. Его адрес будет доступен **после добавления сайта** в процессе настройки в **администраторской панели Веб-Платформы**, так же как и параметр ##id## для подключения |
![]() |
1.1 | 8 | |
9 | 2. Вставьте в необходимом месте на своём сайте код: | ||
10 | |||
![]() |
8.1 | 11 | {{code language="html"}} |
![]() |
51.1 | 12 | |
![]() |
8.1 | 13 | <script type="text/javascript"> |
![]() |
5.1 | 14 | // инициализируем виджет с параметрами |
15 | WPInit({ | ||
16 | id: 1, | ||
17 | width: 400, | ||
18 | type: 'modal' | ||
19 | }) | ||
![]() |
1.1 | 20 | |
![]() |
5.1 | 21 | // сразу откроем его для пользователя |
22 | WPOpenModal(); // вариант для модального окна | ||
23 | // WPOpen(); // вариант для открытия в теле страницы. Используется при инициализации виджета с type: 'instant' | ||
![]() |
1.1 | 24 | |
![]() |
5.1 | 25 | // будем следить за состоянием виджета |
26 | WPChange = function(response) { | ||
27 | if (response.status == 'reserved') { | ||
28 | // если заказ зарезирвирован, занесём данные из response.data.order_id себе на сайт | ||
29 | } | ||
30 | if (response.status == 'completed') { | ||
31 | // если заказ оплачен, занесём данные из response.data.order_id себе на сайт | ||
32 | } | ||
33 | } | ||
![]() |
8.1 | 34 | </script> |
![]() |
51.1 | 35 | |
![]() |
8.1 | 36 | {{/code}} |
![]() |
5.1 | 37 | |
![]() |
15.1 | 38 | = Функции = |
![]() |
1.1 | 39 | |
![]() |
36.1 | 40 | == WPInit == |
![]() |
1.2 | 41 | |
![]() |
34.1 | 42 | (% class="box infomessage" %) |
43 | ((( | ||
![]() |
35.1 | 44 | Функция загрузки виджета с параметризацией, при создании необходимо передать**## id ##**виджета, который можно найти в Административной панели |
![]() |
34.1 | 45 | ))) |
![]() |
1.2 | 46 | |
47 | ===== Минимальный способ инициализации: ===== | ||
48 | |||
![]() |
25.1 | 49 | {{code language="javascript"}} |
50 | WPInit({ id: 1 }) | ||
51 | {{/code}} | ||
![]() |
1.2 | 52 | |
53 | ===== Пример передаваемых данных: ===== | ||
54 | |||
![]() |
34.1 | 55 | (% class="box infomessage" %) |
56 | ((( | ||
57 | Виджет можно инициализировать с различными параметрами, все из них опциональные, кроме **##id##**. | ||
58 | ))) | ||
![]() |
1.2 | 59 | |
![]() |
10.1 | 60 | {{code language="javascript"}} |
61 | WPInit({ | ||
![]() |
51.1 | 62 | id: 1, |
63 | width: 400, | ||
64 | height: 600, | ||
65 | type: 'modal' | ||
![]() |
10.1 | 66 | }) |
67 | {{/code}} | ||
![]() |
1.2 | 68 | |
![]() |
36.1 | 69 | == WPOpen == |
![]() |
1.2 | 70 | |
![]() |
34.1 | 71 | (% class="box infomessage" %) |
72 | ((( | ||
73 | Функция открытия виджета в каком-либо блоке, используется при инициализации виджета с## **type: 'instant'**## | ||
74 | ))) | ||
![]() |
1.2 | 75 | |
76 | ===== Пример передаваемых данных: ===== | ||
77 | |||
![]() |
9.1 | 78 | {{code language="javascript"}} |
![]() |
10.1 | 79 | // показ виджета с группой id 5 |
80 | WPOpen({ | ||
![]() |
51.1 | 81 | groupid: [5] |
![]() |
9.1 | 82 | }) |
83 | {{/code}} | ||
![]() |
1.2 | 84 | |
![]() |
36.1 | 85 | == WPOpenModal == |
![]() |
1.2 | 86 | |
![]() |
34.1 | 87 | (% class="box infomessage" %) |
88 | ((( | ||
89 | Функция открытия виджета в модальном окне, используется при инициализации виджета с## **type: 'modal'**## | ||
90 | ))) | ||
![]() |
1.2 | 91 | |
92 | ===== Пример передаваемых данных: ===== | ||
93 | |||
![]() |
22.1 | 94 | {{code language="javascript"}} |
95 | // показ виджета на нажатие кнопки с id "OpenButton" | ||
96 | var OpenButton = document.getElementById('OpenButton'); | ||
97 | OpenButton.onclick = function () { | ||
![]() |
51.1 | 98 | WPOpenModal({ tariffsid: [27, 28] }); |
![]() |
22.1 | 99 | }; |
100 | {{/code}} | ||
![]() |
1.2 | 101 | |
![]() |
36.1 | 102 | == WPChange == |
![]() |
1.2 | 103 | |
![]() |
34.1 | 104 | (% class="box infomessage" %) |
105 | ((( | ||
![]() |
36.1 | 106 | Функция, которая вызывается каждый раз при изменении состояния виджета. |
107 | Каждый раз передаёт в переменной response состояние в **##status##** и опционально данные в **##data##**. | ||
108 | При переопределении этой функции у себя на странице, администратор может следить за состоянием виджета и статусом заказа из javascript | ||
![]() |
34.1 | 109 | ))) |
![]() |
1.2 | 110 | |
111 | ===== Примеры передаваемых данных: ===== | ||
112 | |||
![]() |
51.1 | 113 | - ##{ status:'starting' }## — виджет в процессе запуска, в этот момент определяется, что он должен в данный момент отображать |
114 | - ##{ status:'started' }## — виджет на начальном экране, где показывается список услуг для покупки | ||
115 | - ##{ status:'reserved', data: { order_id: 2 } }## — виджет находится на стадии забронированного заказ, в data передаётся id | ||
116 | - ##{ status:'completed', data: { order_id: 2 } }## — виджет находится на стадии оплаченного заказ, в data передаётся id заказа | ||
![]() |
1.2 | 117 | |
118 | ===== Пример работы с данными: ===== | ||
119 | |||
![]() |
16.1 | 120 | {{code language="javascript"}} |
121 | WPChange = function(response) { | ||
![]() |
53.1 | 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 | } | ||
![]() |
16.1 | 134 | } |
135 | {{/code}} | ||
![]() |
1.2 | 136 | |
![]() |
15.1 | 137 | = Параметры = |
![]() |
1.2 | 138 | |
![]() |
16.1 | 139 | == Обязательные параметры WPInit == |
![]() |
1.2 | 140 | |
![]() |
22.1 | 141 | ==== id ==== |
![]() |
1.2 | 142 | |
![]() |
22.1 | 143 | Тип данных:## //number//## |
144 | |||
![]() |
34.1 | 145 | (% class="box infomessage" %) |
146 | ((( | ||
147 | id виджета, который можно узнать в Административной панели. | ||
148 | ))) | ||
![]() |
1.2 | 149 | |
![]() |
16.1 | 150 | == Возможные параметры WPInit == |
![]() |
1.2 | 151 | |
![]() |
22.1 | 152 | ==== height ==== |
![]() |
1.2 | 153 | |
![]() |
49.2 | 154 | Тип данных:## //number//## |
![]() |
22.1 | 155 | |
![]() |
34.1 | 156 | (% class="box infomessage" %) |
157 | ((( | ||
![]() |
1.2 | 158 | Высота виджета в пикселях, по умолчанию: |
![]() |
51.1 | 159 | • 480px, если виджет запущен как type: 'modal' |
160 | • 100%, если виджет запущен как type: 'instant' | ||
![]() |
34.1 | 161 | ))) |
![]() |
1.2 | 162 | |
![]() |
22.1 | 163 | ==== width ==== |
![]() |
1.2 | 164 | |
![]() |
49.2 | 165 | Тип данных:## //number//## |
![]() |
22.1 | 166 | |
![]() |
34.1 | 167 | (% class="box infomessage" %) |
168 | ((( | ||
![]() |
1.2 | 169 | Ширина виджета в пикселях, по умолчанию: |
![]() |
51.1 | 170 | • 640px, если виджет запущен как type: 'modal' |
171 | • 100%, если виджет запущен как type: 'instant' | ||
![]() |
34.1 | 172 | ))) |
![]() |
1.2 | 173 | |
![]() |
22.1 | 174 | ==== type ==== |
![]() |
5.2 | 175 | |
![]() |
22.1 | 176 | Тип данных:## //string//## |
![]() |
5.2 | 177 | |
![]() |
22.1 | 178 | По умолчанию:##// 'instant'//## |
179 | |||
![]() |
34.1 | 180 | (% class="box infomessage" %) |
181 | ((( | ||
![]() |
22.1 | 182 | Способ открытия виджета |
![]() |
51.1 | 183 | • 'instant' Открытие виджета на месте, где был вызов виджета (на месте тэга script), либо в блоке place, если он указан в параметрах виджета при инициализации |
184 | • 'modal' Открытие виджета в модальном окне | ||
![]() |
34.1 | 185 | ))) |
![]() |
22.1 | 186 | |
187 | ==== place ==== | ||
![]() |
5.2 | 188 | |
![]() |
49.2 | 189 | Тип данных:## //string//## |
![]() |
22.1 | 190 | |
![]() |
34.1 | 191 | (% class="box infomessage" %) |
192 | ((( | ||
193 | Идентификатор элемента DOM, в который необходимо поместить виджет, например: **###widget##**. Используется совместно с **##type: 'instant'##** | ||
194 | ))) | ||
![]() |
5.2 | 195 | |
196 | (% class="box warningmessage" %) | ||
197 | ((( | ||
198 | **Важно:** элемент DOM для place должен быть либо на странице до вставки инициализации виджета (WPInit), либо инициализация виджета должна быть исполнена после загрузки DOM (например, обёрнута в событие $(document).ready(function(){}) в jQuery) | ||
199 | ))) | ||
200 | |||
![]() |
53.1 | 201 | ---- |
![]() |
6.1 | 202 | |
![]() |
16.1 | 203 | == Возможные параметры WPOpen и WPOpenModal == |
![]() |
5.2 | 204 | |
![]() |
51.1 | 205 | === Инструкторские занятия === |
206 | |||
207 | ==== categories ==== | ||
208 | |||
209 | Тип данных:##// Array<string>//## | ||
210 | |||
211 | По умолчанию:##// []//## | ||
212 | |||
213 | (% class="box infomessage" %) | ||
214 | ((( | ||
215 | Фильтр категорий инструкторских занятий. Скрывает категории в выпадающем списке, **##id##** которых не совпадают заданными в массиве. | ||
216 | ))) | ||
217 | |||
218 | [[image:1703065952567-753.png]] | ||
219 | |||
220 | ==== coachid ==== | ||
221 | |||
222 | Тип данных:##// number//## | ||
223 | |||
224 | По умолчанию:##// undefined//## | ||
225 | |||
![]() |
55.1 | 226 | (% class="box infomessage" %) |
![]() |
51.1 | 227 | ((( |
![]() |
55.1 | 228 | Идентификатор тренера, позволяет сепарировать список занятий по тренеру |
![]() |
51.1 | 229 | ))) |
230 | |||
![]() |
56.1 | 231 | ==== grouplessonsskillstariffs **##*##** ==== |
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 | |||
![]() |
51.1 | 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"}} | ||
![]() |
55.2 | 267 | grouplessonstariffsid: [1823, 1900] // скрыть групповые программы обучения, кроме 1823 и 1900 |
![]() |
51.1 | 268 | {{/code}} |
269 | |||
![]() |
52.1 | 270 | ==== lessonslocation **##*##** ==== |
![]() |
51.1 | 271 | |
272 | Тип данных:##// number//## | ||
273 | |||
274 | По умолчанию:##// undefined//## | ||
275 | |||
276 | (% class="box infomessage" %) | ||
277 | ((( | ||
278 | Отображение места занятия для индивидуальных, групповых и многодневных занятий | ||
279 | ))) | ||
280 | |||
281 | [[image:1702560957244-690.png]] | ||
282 | |||
![]() |
54.1 | 283 | ==== lessonstariffsid ==== |
284 | |||
285 | Тип данных:##// Array<number>//## | ||
286 | |||
287 | По умолчанию:##// []//## | ||
288 | |||
289 | (% class="box infomessage" %) | ||
290 | ((( | ||
291 | Ограничить видимость доступных тарифов в выпадающем списке программ обучения по массиву с их идентификаторами | ||
292 | ))) | ||
293 | |||
294 | [[image:1702641274330-465.png]] | ||
295 | |||
![]() |
54.2 | 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 | |||
![]() |
54.3 | 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 | ((( | ||
![]() |
62.1 | 401 | Идентификатор места, использующийся для получения списка инструкторов. |
![]() |
54.3 | 402 | ))) |
403 | |||
![]() |
62.1 | 404 | ==== singleguest **##*##** ==== |
![]() |
63.3 | 405 | |
![]() |
62.1 | 406 | Тип данных:##// Boolean//## |
![]() |
63.3 | 407 | |
![]() |
62.1 | 408 | По умолчанию:##// false//## |
![]() |
63.3 | 409 | |
![]() |
62.1 | 410 | (% class="box infomessage" %) |
411 | ((( | ||
412 | Если **##true##**, то при выборе занятия препятствует выбору 2 гостей. | ||
413 | ))) | ||
![]() |
63.3 | 414 | |
![]() |
62.1 | 415 | ==== [[image:1710854841918-858.png]] ==== |
![]() |
63.3 | 416 | |
![]() |
54.4 | 417 | ==== skills **##*##** ==== |
418 | |||
419 | Тип данных:##// Array<number>//## | ||
420 | |||
421 | По умолчанию:##// []//## | ||
422 | |||
423 | (% class="box infomessage" %) | ||
424 | ((( | ||
425 | Ограничить видимость доступных к выбору дисциплин по идентификатору | ||
426 | ))) | ||
427 | |||
428 | [[image:1702639385677-964.png]] | ||
429 | |||
![]() |
50.1 | 430 | === Календарь и даты === |
![]() |
5.2 | 431 | |
![]() |
50.1 | 432 | ==== disableddates ==== |
![]() |
5.2 | 433 | |
![]() |
50.1 | 434 | Тип данных:##// Array<string>//## |
![]() |
25.1 | 435 | |
![]() |
50.1 | 436 | По умолчанию:##// []//## |
![]() |
25.1 | 437 | |
![]() |
34.1 | 438 | (% class="box infomessage" %) |
439 | ((( | ||
![]() |
50.1 | 440 | Параметр отключения дат в календаре (и в //покупке// и в //пополнении//). Делает невозможным выбор определённых дней в массиве дат. |
![]() |
34.1 | 441 | ))) |
![]() |
5.2 | 442 | |
![]() |
50.1 | 443 | Пример: |
![]() |
5.2 | 444 | |
![]() |
11.1 | 445 | {{code language="javascript"}} |
![]() |
50.1 | 446 | disableddates: ['23.02.2018', '08.03.2018'] // уберёт даты 23.02.2018 и 08.03.2018 из возможных для выбора дат в календаре. |
![]() |
11.1 | 447 | {{/code}} |
![]() |
5.2 | 448 | |
![]() |
60.1 | 449 | ==== disableddays **##*##** ==== |
450 | |||
451 | Тип данных:##// Array<number>//## | ||
452 | |||
453 | По умолчанию:##// []//## | ||
454 | |||
455 | (% class="box infomessage" %) | ||
456 | ((( | ||
457 | Параметры открлючения дней недели в календаре (и в покупке и в пополнении), где 0 - воскресенье, 1 - понедельник и так далее. | ||
458 | ))) | ||
459 | |||
![]() |
50.1 | 460 | ==== forcedate ==== |
461 | |||
462 | Тип данных:##// string//## | ||
463 | |||
464 | По умолчанию:##// undefined//## | ||
465 | |||
466 | (% class="box infomessage" %) | ||
467 | ((( | ||
468 | Параметр для открывания виджета с указанной сразу датой (и в //покупке// и в //пополнении//). | ||
469 | **##forcedate: '20.05.2018'##** покажет услуги к продаже на дату 20.05.2018. | ||
470 | ))) | ||
471 | |||
472 | ==== maxdate ==== | ||
473 | |||
474 | Тип данных:##// string//## | ||
475 | |||
476 | По умолчанию:##// undefined//## | ||
477 | |||
478 | (% class="box infomessage" %) | ||
479 | ((( | ||
480 | Параметр максимальной отображаемой даты в календаре (и в //покупке// и в //пополнении//). | ||
481 | **##maxdate: '20.05.2018'##** покажет 20.05.2018 как самую последнюю дату, доступную к выбору в календаре. | ||
482 | ))) | ||
483 | |||
484 | ==== mindate ==== | ||
485 | |||
486 | Тип данных:##// string//## | ||
487 | |||
488 | По умолчанию:##// undefined//## | ||
489 | |||
490 | (% class="box infomessage" %) | ||
491 | ((( | ||
492 | Параметр минимальной отображаемой даты в календаре (и в //покупке// и в //пополнении//). | ||
493 | **##mindate: '20.05.2018'##** покажет 20.05.2018 как самую первую дату, доступную к выбору в календаре, если она находится после текущего дня. | ||
494 | ))) | ||
495 | |||
496 | ==== nocalendar ==== | ||
497 | |||
498 | Тип данных:## //boolean//## | ||
499 | |||
500 | По умолчанию:##// false//## | ||
501 | |||
502 | (% class="box infomessage" %) | ||
503 | ((( | ||
504 | Убирает календарь внутри виджета (и в //покупке// и в //пополнении//), в случаях, когда дата, на которую покупается/пополняется билет, не важна. | ||
505 | ))) | ||
506 | |||
![]() |
61.3 | 507 | ==== saledepth **##*##** ==== |
![]() |
61.1 | 508 | |
509 | Тип данных:## //number//## | ||
510 | |||
511 | По умолчанию:##// undefined//## | ||
512 | |||
513 | (% class="box infomessage" %) | ||
514 | ((( | ||
515 | Ограничивает глубину продаж начиная с сегодняшнего дня. Таким образом если ##saledepth: 1##, то доступные даты в календаре выбора тарифа будут __**сегодня **__и __**завтра**__. | ||
![]() |
61.2 | 516 | ⚠ Имеет больший приоритет, чем ##maxdate## |
![]() |
61.1 | 517 | ))) |
518 | |||
![]() |
53.1 | 519 | ---- |
![]() |
28.1 | 520 | |
![]() |
16.1 | 521 | === Отображение === |
![]() |
5.2 | 522 | |
![]() |
52.1 | 523 | ==== cartmaxitems **##*##** ==== |
![]() |
5.2 | 524 | |
![]() |
28.1 | 525 | Тип данных:##// number//## |
![]() |
25.1 | 526 | |
![]() |
28.1 | 527 | По умолчанию:##// 6//## |
![]() |
25.1 | 528 | |
![]() |
34.1 | 529 | (% class="box infomessage" %) |
530 | ((( | ||
531 | Ограничивает максимальное кол-во товаров в корзине. ##Минимальное значение 1, но не меньше **cartminitems**. Максимальное значение 60.## | ||
532 | ))) | ||
![]() |
6.2 | 533 | |
![]() |
52.1 | 534 | ==== cartminitems **##*##** ==== |
![]() |
6.2 | 535 | |
![]() |
28.1 | 536 | Тип данных:##// number//## |
![]() |
25.1 | 537 | |
![]() |
28.1 | 538 | По умолчанию:##// 1//## |
![]() |
25.1 | 539 | |
![]() |
34.1 | 540 | (% class="box infomessage" %) |
541 | ((( | ||
542 | Ограничивает минимальное кол-во товаров в корзине. ##Минимальное значение 1. Максимальное значение 60, но не больше **cartmaxitems**.## | ||
543 | ))) | ||
![]() |
6.2 | 544 | |
![]() |
29.1 | 545 | ==== clubsiteid ==== |
546 | |||
547 | Тип данных:##// number//## | ||
548 | |||
549 | По умолчанию:##// 0//## | ||
550 | |||
![]() |
56.1 | 551 | (% class="box infomessage" %) |
![]() |
29.1 | 552 | ((( |
![]() |
56.1 | 553 | Вызов сайта для оформления клубного контракта |
![]() |
29.1 | 554 | ))) |
555 | |||
![]() |
59.1 | 556 | ==== customseancetitles ==== |
557 | |||
558 | Типа данных: ##//Array<object>//## | ||
559 | |||
560 | (% class="box infomessage" %) | ||
561 | ((( | ||
562 | Выводит цветную текст-метку над сеансом. | ||
563 | Описание параметров объекта текста-метки: | ||
564 | \\##**seanceId**## - идентификатор сеанса, у которого нужно отобразить текст-метку | ||
565 | ##**days**## - массив с днями недели, в которые нужно отобразить текст-метку. **ВАЖНО**: 0 - воскресенье, 1 - понедельник ... 6 - суббота | ||
566 | ##**dates**## - массив с датами, в которые нужно отобразить текст-метку независимо от массива дней. | ||
567 | ##**color**## - любой валидный CSS цвет текста-метки | ||
568 | ##**text**## - текст, который нужно отобразить | ||
569 | \\Работает если **##tariffsseancesfilter: true##** | ||
570 | ))) | ||
571 | |||
572 | Пример: | ||
573 | |||
574 | {{code language="javascript"}} | ||
575 | customseancetitles: [ | ||
576 | { | ||
577 | seanceId: 1, | ||
578 | text: "Тематический сеанс", | ||
579 | color: "#f00", | ||
580 | days: [0,1], | ||
581 | dates: ["25.12.2023","17.04.2025"] | ||
582 | } | ||
583 | ] | ||
584 | {{/code}} | ||
585 | |||
![]() |
52.1 | 586 | ==== disablemultipleseances **##*##** ==== |
![]() |
29.1 | 587 | |
![]() |
28.1 | 588 | Тип данных:##// boolean//## |
589 | |||
590 | По умолчанию:##// false//## | ||
591 | |||
![]() |
34.1 | 592 | (% class="box infomessage" %) |
593 | ((( | ||
![]() |
28.1 | 594 | Параметр предотвращает добавление в корзину тарифов с различными сеансами. |
![]() |
34.1 | 595 | Таким образом как только в корзине появится хоть один товар с сеансом "10:00 - 11:30", товары, у которых есть сеанс например "13:00 - 14:30" будет невозможно добавить в корзину. |
![]() |
51.1 | 596 | Товары без сеансов **не будут затронуты**. |
![]() |
34.1 | 597 | ))) |
![]() |
28.1 | 598 | |
![]() |
25.1 | 599 | ==== forcemedia ==== |
![]() |
6.2 | 600 | |
![]() |
25.1 | 601 | Тип данных:##// string//## |
602 | |||
603 | По умолчанию:##// ''//## | ||
604 | |||
![]() |
34.1 | 605 | (% class="box infomessage" %) |
606 | ((( | ||
![]() |
6.2 | 607 | Параметр, который вставяет строчку с носителем в поле носителя во вкладке «Пополнение услуг». Используется, например, для QR-кода нанесённого на носитель, чтобы быстро его пополнить. |
![]() |
34.1 | 608 | ))) |
![]() |
6.2 | 609 | |
![]() |
25.1 | 610 | Пример: |
![]() |
6.2 | 611 | |
![]() |
25.1 | 612 | {{code language="javascript"}} |
613 | forcemedia: 'E0012345678900' | ||
614 | {{/code}} | ||
615 | |||
![]() |
52.1 | 616 | ==== forceseanceid **##*##** ==== |
![]() |
25.1 | 617 | |
![]() |
28.1 | 618 | Тип данных:##// number//## |
![]() |
6.2 | 619 | |
![]() |
28.1 | 620 | По умолчанию без указания идентификатора не учитывается. |
![]() |
6.2 | 621 | |
![]() |
34.1 | 622 | (% class="box infomessage" %) |
623 | ((( | ||
![]() |
28.1 | 624 | Заставит виджет выбрать мероприятие арены по идентификатору платформы и не позволять вернуться к этапу выбора других мероприятий. |
![]() |
34.1 | 625 | ))) |
![]() |
21.1 | 626 | |
![]() |
52.1 | 627 | ==== forcesectorid **##*##** ==== |
![]() |
25.1 | 628 | |
![]() |
26.1 | 629 | Тип данных:##// number//## |
![]() |
6.2 | 630 | |
![]() |
28.1 | 631 | По умолчанию без указания идентификатора не учитывается. |
![]() |
26.1 | 632 | |
![]() |
34.1 | 633 | (% class="box infomessage" %) |
634 | ((( | ||
635 | Заставит виджет выбрать сектор мероприятия по **##id##** и не позволять вернуться к этапу выбора других секторов. | ||
636 | ))) | ||
![]() |
6.2 | 637 | |
![]() |
52.1 | 638 | ==== forcetab **##*##** ==== |
![]() |
6.2 | 639 | |
![]() |
28.1 | 640 | Тип данных:##// string//## |
![]() |
6.2 | 641 | |
![]() |
28.1 | 642 | По умолчанию:##// ''//## |
![]() |
21.1 | 643 | |
![]() |
34.1 | 644 | (% class="box infomessage" %) |
645 | ((( | ||
646 | Переключение на необходимую вкладку виджета («**покупка услуг**» или «**пополнение услуг**») при загрузке. | ||
647 | По умолчанию открывается вкладка «**покупка услуг**». | ||
648 | **##forcetab: 'rewrite'##** принудительно откроет «**пополнение услуг**». | ||
649 | Обычно используется в комбинации с параметром **##onlytab##** | ||
650 | ))) | ||
![]() |
21.1 | 651 | |
![]() |
52.1 | 652 | ==== locale **##*##** ==== |
![]() |
26.1 | 653 | |
654 | Тип данных:##// string//## | ||
655 | |||
656 | По умолчанию:##// ''//## | ||
657 | |||
![]() |
34.1 | 658 | (% class="box infomessage" %) |
659 | ((( | ||
![]() |
6.2 | 660 | Параметр локализации. Позволяет переключать между языками виджета, например 'ru' - русский язык, 'en' - английский язык. |
![]() |
34.1 | 661 | ))) |
![]() |
6.2 | 662 | |
![]() |
52.1 | 663 | ==== minimap **##*##** ==== |
![]() |
6.2 | 664 | |
![]() |
28.1 | 665 | Тип данных:##// boolean//## |
![]() |
26.1 | 666 | |
![]() |
28.1 | 667 | По умолчанию:##// true//## |
![]() |
26.1 | 668 | |
![]() |
34.1 | 669 | (% class="box infomessage" %) |
670 | ((( | ||
![]() |
28.1 | 671 | Отображать миникарту. |
![]() |
34.1 | 672 | ))) |
![]() |
6.2 | 673 | |
![]() |
52.1 | 674 | ==== minimapaspect **##*##** ==== |
![]() |
6.2 | 675 | |
![]() |
28.1 | 676 | Тип данных:##// number//## |
![]() |
26.1 | 677 | |
![]() |
28.1 | 678 | По умолчанию:##// 0.2//## |
![]() |
26.1 | 679 | |
![]() |
34.1 | 680 | (% class="box infomessage" %) |
681 | ((( | ||
![]() |
28.1 | 682 | Размер миникарты относительной полного размера карты, а не контейнера, в которой она находится. |
![]() |
34.1 | 683 | ))) |
![]() |
6.2 | 684 | |
![]() |
52.1 | 685 | ==== nopromo **##*##** ==== |
![]() |
6.2 | 686 | |
![]() |
26.1 | 687 | Тип данных:##// boolean//## |
![]() |
6.2 | 688 | |
![]() |
26.1 | 689 | По умолчанию:##// false//## |
690 | |||
![]() |
33.1 | 691 | (% class="box infomessage" %) |
692 | ((( | ||
![]() |
28.1 | 693 | Убирает вывод промокода на странице подтверждения заказа. |
![]() |
33.1 | 694 | ))) |
![]() |
6.2 | 695 | |
![]() |
52.1 | 696 | ==== onlytab **##*##** ==== |
![]() |
6.2 | 697 | |
![]() |
28.1 | 698 | Тип данных:##// string //##//|## Array<string>##// |
![]() |
6.2 | 699 | |
![]() |
28.1 | 700 | По умолчанию:##// []//## |
![]() |
26.1 | 701 | |
![]() |
33.1 | 702 | (% class="box infomessage" %) |
703 | ((( | ||
704 | Скрытие других вкладок виджета («покупка услуг» или «пополнение услуг») при загрузке. Обычно используется в комбинации с параметром **##forcetab##** | ||
705 | ))) | ||
![]() |
6.2 | 706 | |
![]() |
28.1 | 707 | {{code language="javascript"}} |
708 | onlytab: 'service' // покажет только вкладку «покупка услуг». | ||
709 | onlytab: 'rewrite' // покажет только вкладку «пополнение услуг». | ||
![]() |
63.1 | 710 | onlytab: 'personal_lessons' // покажет только вкладку «индивидуальные занятия». |
711 | onlytab: 'group_lessons' // покажет только вкладку «групповые занятия». | ||
712 | onlytab: 'bundles_lessons' // покажет только вкладку «многодневные занятия». | ||
![]() |
28.1 | 713 | onlytab: ['service', 'rewrite'] // покажет только вкладки «покупка услуг» и «пополнение услуг»; |
714 | {{/code}} | ||
![]() |
6.2 | 715 | |
![]() |
52.1 | 716 | ==== ordercomment **##*##** ==== |
![]() |
6.2 | 717 | |
![]() |
28.1 | 718 | Тип данных:##// string//## |
![]() |
26.1 | 719 | |
![]() |
28.1 | 720 | По умолчанию:##// ''//## |
![]() |
6.2 | 721 | |
![]() |
33.1 | 722 | (% class="box infomessage" %) |
723 | ((( | ||
![]() |
28.1 | 724 | Опциональный комментарий к заказу. Максимальная длинна комментария 50 символов. |
![]() |
33.1 | 725 | ))) |
![]() |
6.2 | 726 | |
![]() |
52.1 | 727 | ==== requiredloyalty **##*##** ==== |
![]() |
6.2 | 728 | |
![]() |
26.1 | 729 | Тип данных:##// boolean//## |
730 | |||
731 | По умолчанию:##// false//## | ||
732 | |||
![]() |
32.2 | 733 | (% class="box infomessage" %) |
734 | ((( | ||
735 | Включает обязательную регистрацию клиента в программе настроенной на объектке. | ||
736 | ))) | ||
![]() |
21.1 | 737 | |
![]() |
52.1 | 738 | ==== resetcart **##*##** ==== |
![]() |
29.1 | 739 | |
740 | Тип данных:##// boolean//## | ||
741 | |||
742 | По умолчанию:##// false//## | ||
743 | |||
![]() |
32.2 | 744 | (% class="box infomessage" %) |
745 | ((( | ||
![]() |
29.1 | 746 | Автоматически очищать содержимое корзины. |
![]() |
32.2 | 747 | ))) |
![]() |
29.1 | 748 | |
![]() |
52.1 | 749 | ==== saletermstype **##*##** ==== |
![]() |
21.1 | 750 | |
![]() |
26.1 | 751 | Тип данных:##// string//## |
752 | |||
753 | По умолчанию:##// '//default//'//## | ||
754 | |||
![]() |
32.2 | 755 | (% class="box infomessage" %) |
756 | ((( | ||
![]() |
6.2 | 757 | Перед оплатой просит пользователя согласиться с правилами в форме галочки или всплывающего окна |
![]() |
32.2 | 758 | ))) |
![]() |
6.2 | 759 | |
![]() |
26.1 | 760 | {{code language="javascript"}} |
761 | saletermstype: 'checkbox' // потребует установку галочки для согласия. | ||
762 | saletermstype: 'dialog' // покажет всплывающее окно с правилами, которые нужно принять. | ||
763 | saletermstype: 'default' // принятие правил не требуется. | ||
764 | {{/code}} | ||
![]() |
28.1 | 765 | |
![]() |
52.1 | 766 | ==== shownoticketsseances **##*##** ==== |
![]() |
29.1 | 767 | |
768 | Тип данных:##// boolean//## | ||
769 | |||
770 | По умолчанию:##// false//## | ||
771 | |||
![]() |
39.3 | 772 | (% class="box infomessage" %) |
![]() |
29.1 | 773 | ((( |
![]() |
39.3 | 774 | Не скрывать сеансы, на которые закончились билеты. Работает если **##tariffsseancesfilter: true##** |
![]() |
29.1 | 775 | ))) |
776 | |||
![]() |
52.1 | 777 | ==== showoverseances **##*##** ==== |
![]() |
29.1 | 778 | |
779 | Тип данных:##// boolean//## | ||
780 | |||
781 | По умолчанию:##// false//## | ||
782 | |||
![]() |
31.1 | 783 | (% class="box infomessage" %) |
![]() |
29.1 | 784 | ((( |
![]() |
32.1 | 785 | Отвечает за отображение прошедших сеансов в списке для фильтрации по времени. При значении **##true##** прошедшие сеансы будут отображаться, но недоступны для выбора пользователем. Работает если **##tariffsseancesfilter: true##** |
![]() |
29.1 | 786 | ))) |
787 | |||
![]() |
35.1 | 788 | [[image:1702554598837-627.png]] |
![]() |
33.1 | 789 | |
![]() |
52.1 | 790 | ==== tariffsseancesfilter **##*##** ==== |
![]() |
28.1 | 791 | |
792 | Тип данных:##// boolean//## | ||
793 | |||
794 | По умолчанию:##// false//## | ||
795 | |||
![]() |
32.1 | 796 | (% class="box infomessage" %) |
797 | ((( | ||
798 | Включить отображение фильтра тарифов по сеансам. | ||
799 | ))) | ||
800 | |||
![]() |
28.1 | 801 | [[image:https://info.moipass.ru/images/tariffsseancesfilter.png||alt="Example"]] |
![]() |
43.1 | 802 | |
![]() |
52.1 | 803 | ---- |
![]() |
43.1 | 804 | |
![]() |
50.1 | 805 | === Предзаказ === |
806 | |||
807 | ==== preorder ==== | ||
808 | |||
809 | Тип данных:##// Array<object>//## | ||
810 | |||
811 | По умолчанию:##// undefined//## | ||
812 | |||
813 | (% class="box infomessage" %) | ||
814 | ((( | ||
815 | Параметр, позволяющий купить сразу несколько услуг и перейти к подтверждению покупки. | ||
![]() |
52.1 | 816 | • ##id## — id услуги к покупке |
817 | • ##date## — дата, на которую покупается услуга | ||
818 | • ##count## — количество покупаемых услуг | ||
![]() |
50.1 | 819 | ))) |
820 | |||
821 | ===== Пример передаваемых данных: ===== | ||
822 | |||
823 | {{code language="javascript"}} | ||
824 | // либо WPOpenModal({}) | ||
825 | WPOpen({ | ||
![]() |
53.1 | 826 | preorder: [ |
827 | { | ||
828 | id: 57, | ||
829 | date: '06.06.2019', | ||
830 | count: 1 | ||
831 | }, { | ||
832 | id: 58, | ||
833 | date: '07.06.2019', | ||
834 | count: 2 | ||
835 | } | ||
836 | ] | ||
![]() |
50.1 | 837 | }) |
838 | {{/code}} | ||
839 | |||
![]() |
52.1 | 840 | ---- |
![]() |
50.1 | 841 | |
![]() |
50.2 | 842 | === Услуги, пакеты услуг, группы услуг === |
843 | |||
844 | ==== tariffsid ==== | ||
845 | |||
846 | Тип данных:##// Array<number> //##//|## boolean##// | ||
847 | |||
848 | По умолчанию:##// []//## | ||
849 | |||
850 | (% class="box infomessage" %) | ||
851 | ((( | ||
![]() |
52.1 | 852 | Тарифы, которые следует показать на вкладке «Покупка услуг». |
853 | По умолчанию массив пуст и не показывает отдельно никакие из услуг. | ||
854 | Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать услуги, доступные только для него. | ||
![]() |
50.2 | 855 | ))) |
856 | |||
857 | Пример: | ||
858 | |||
859 | {{code language="javascript"}} | ||
860 | tariffsid: [29, 30] // покажет тарифы с id 29 и 30 во вкладке «Покупка услуг». | ||
861 | tariffsid: false // уберёт все тарифы с первой страницы | ||
862 | {{/code}} | ||
863 | |||
![]() |
52.1 | 864 | ==== rewritetariffsid **##*##** ==== |
![]() |
50.2 | 865 | |
866 | Тип данных:##// Array<number> //##//|## boolean##// | ||
867 | |||
868 | По умолчанию:##// []//## | ||
869 | |||
870 | (% class="box infomessage" %) | ||
871 | ((( | ||
![]() |
52.1 | 872 | Тарифы, которые следует показать после ввода карты во вкладке «Пополнение услуг». |
873 | По умолчанию массив пуст и не показывает отдельно никакие из услуг. | ||
874 | Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать услуги, доступные только для него. | ||
![]() |
50.2 | 875 | ))) |
876 | |||
877 | Пример: | ||
878 | |||
879 | {{code language="javascript"}} | ||
880 | rtariffsid: [56, 57] // покажет тарифы с id 56 и 57 после ввода карты во вкладке «Пополнение услуг» | ||
881 | rtariffsid: false // уберёт все тарифы во вкладке «Пополнение услуг» | ||
882 | {{/code}} | ||
883 | |||
884 | ==== rtariffsid ==== | ||
885 | |||
886 | (% class="box infomessage" %) | ||
887 | ((( | ||
![]() |
52.1 | 888 | См. **##rewritetariffsid##**. Доступен и в старой версии виджета |
![]() |
50.2 | 889 | ))) |
890 | |||
891 | ==== bundlesid ==== | ||
892 | |||
893 | Тип данных:##// Array<number> //##//|## boolean##// | ||
894 | |||
895 | По умолчанию:##// []//## | ||
896 | |||
897 | (% class="box infomessage" %) | ||
898 | ((( | ||
![]() |
52.1 | 899 | Пакеты услуг, которые следует показать на первой странице. |
900 | По умолчанию массив пуст и не показывает отдельно никакие из пакетов услуг. | ||
901 | Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать пакеты услуг, доступные только для него. | ||
![]() |
50.2 | 902 | ))) |
903 | |||
904 | Пример: | ||
905 | |||
906 | {{code language="javascript"}} | ||
907 | bundlesid: [4, 5] // покажет пакеты услуг с id 4 и 5 в момент открытия виджета. | ||
908 | bundlesid: false // уберёт все пакеты услуг с первой страницы | ||
909 | {{/code}} | ||
910 | |||
911 | ==== bundleslessonstariffsid ==== | ||
912 | |||
913 | Тип данных:##// Array<number>//## | ||
914 | |||
915 | По умолчанию:##// []//## | ||
916 | |||
![]() |
56.1 | 917 | (% class="box infomessage" %) |
![]() |
43.1 | 918 | ((( |
![]() |
56.1 | 919 | Фильтр списка доступных связок занятий по массиву идентификаторов |
![]() |
50.2 | 920 | ))) |
921 | |||
922 | ==== groupid ==== | ||
923 | |||
924 | Тип данных:##// number//## | ||
925 | |||
926 | По умолчанию:##// undefined//## | ||
927 | |||
928 | (% class="box infomessage" %) | ||
929 | ((( | ||
![]() |
52.1 | 930 | Параметр, который форсирует показ определённой группы услуг ппс. **##groupid: 5##** покажет только одну группу с **##id##** 5 в виджете. |
![]() |
50.2 | 931 | ))) |
932 | |||
![]() |
52.1 | 933 | ---- |
![]() |
50.2 | 934 | |
935 | (% class="box warningmessage" %) | ||
936 | ((( | ||
![]() |
52.1 | 937 | **##* ##**- доступно в новой версии виджета |
![]() |
43.1 | 938 | ))) |