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