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

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

<
От версии < 50.1 >
отредактировано Михаил Галич
на 20.12.2023, 15:45
К версии < 5.2 >
отредактировано Михаил Галич
на 11.12.2023, 13:56
>
Изменить комментарий: К данной версии нет комментариев

Комментарий

Подробности

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