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

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

<
От версии < 50.1 >
отредактировано Михаил Галич
на 20.12.2023, 15:45
К версии < 12.1 >
отредактировано Михаил Галич
на 12.12.2023, 10:59
>
Изменить комментарий: К данной версии нет комментариев

Комментарий

Подробности

Свойства страницы
Содержимое
... ... @@ -1,11 +1,9 @@
1 -{{toc depth="4"/}}
1 +== Для разработчиков ==
2 2  
3 -= Инструкция для подключения =
3 +Назначение данного раздела — описать способы взаимодействия с виджетом Веб-платформы по задуманому вами сценарию. Типичный процесс подключения, открытия и отслеживания виджета выглядит так:
4 4  
5 -Назначение данного раздела описать способы взаимодействия с виджетом Веб-платформы по задуманному вами сценарию. Типичный процесс подключения, открытия и отслеживания виджета выглядит так:
5 +~1. Подключите скрипт ##external.script.js## к вашему сайту. Его адрес будет доступен **после добавления сайта** в процессе настройки в **администраторской панели Веб-Платформы**, так же как и параметр id для подключения
6 6  
7 -~1. Подключите скрипт ##external.script.js## к вашему сайту. Его адрес будет доступен **после добавления сайта** в процессе настройки в **администраторской панели Веб-Платформы**, так же как и параметр ##id## для подключения
8 -
9 9  2. Вставьте в необходимом месте на своём сайте код:
10 10  
11 11  {{code language="html"}}
... ... @@ -33,27 +33,19 @@
33 33  </script>
34 34  {{/code}}
35 35  
36 -= Функции =
34 +== Функции ==
37 37  
38 -== WPInit ==
36 +=== WPInit({params}) ===
39 39  
40 -(% class="box infomessage" %)
41 -(((
42 -Функция загрузки виджета с параметризацией, при создании необходимо передать**## id ##**виджета, который можно найти в Административной панели
43 -)))
38 +Функция загрузки виджета с параметризацией, при создании необходимо передать id виджета, который можно найти в Административной панели
44 44  
45 45  ===== Минимальный способ инициализации: =====
46 46  
47 -{{code language="javascript"}}
48 -WPInit({ id: 1 })
49 -{{/code}}
42 +* WPInit({ id: 1 })
50 50  
51 51  ===== Пример передаваемых данных: =====
52 52  
53 -(% class="box infomessage" %)
54 -(((
55 -Виджет можно инициализировать с различными параметрами, все из них опциональные, кроме **##id##**.
56 -)))
46 +Виджет можно инициализировать с различными параметрами, все из них опциональные, кроме id.
57 57  
58 58  {{code language="javascript"}}
59 59  WPInit({
... ... @@ -64,12 +64,9 @@
64 64  })
65 65  {{/code}}
66 66  
67 -== WPOpen ==
57 +=== WPOpen({params}) ===
68 68  
69 -(% class="box infomessage" %)
70 -(((
71 -Функция открытия виджета в каком-либо блоке, используется при инициализации виджета с## **type: 'instant'**##
72 -)))
59 +Функция открытия виджета в каком-либо блоке, используется при инициализации виджета с type: 'instant'
73 73  
74 74  ===== Пример передаваемых данных: =====
75 75  
... ... @@ -80,793 +80,306 @@
80 80  })
81 81  {{/code}}
82 82  
83 -== WPOpenModal ==
70 +=== WPOpenModal({params}) ===
84 84  
85 -(% class="box infomessage" %)
86 -(((
87 -Функция открытия виджета в модальном окне, используется при инициализации виджета с## **type: 'modal'**##
88 -)))
72 +Функция открытия виджета в модальном окне, используется при инициализации виджета с 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}}
76 +{{{// показ виджета на нажатие кнопки с id "OpenButton" var OpenButton = document.getElementById('OpenButton'); OpenButton.onclick = function() { WPOpenModal({ tariffsid: [27, 28] }) }}}}
99 99  
100 -== WPChange ==
78 +=== WPChange({status, data}) ===
101 101  
102 -(% class="box infomessage" %)
103 -(((
104 -Функция, которая вызывается каждый раз при изменении состояния виджета.
105 -Каждый раз передаёт в переменной response состояние в **##status##** и опционально данные в **##data##**.
106 -При переопределении этой функции у себя на странице, администратор может следить за состоянием виджета и статусом заказа из javascript
107 -)))
80 +Функция, которая вызывается каждый раз при изменении состояния виджета. Каждый раз передаёт в переменной 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 заказа
84 +* { status:'starting' } — виджет в процессе запуска, в этот момент определяется, что он должен в данный момент отображать
85 +* { status:'started' } — виджет на начальном экране, где показывается список услуг для покупки
86 +* { status:'reserved', data: { order_id: 2 } } — виджет находится на стадии забронированного заказ, в data передаётся id
87 +* { 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}}
91 +{{{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 -= Параметры =
93 +== Параметры ==
136 136  
137 -== Обязательные параметры WPInit ==
95 +==== Обязательные параметры WPInit ====
138 138  
139 -==== id ====
97 +==== id: 1 ====
140 140  
141 -Тип данных:## //number//##
99 +id виджета, который можно узнать в Административной панели
142 142  
143 -(% class="box infomessage" %)
144 -(((
145 -id виджета, который можно узнать в Административной панели.
146 -)))
101 +==== Возможные параметры WPInit ====
147 147  
148 -== Возможные параметры WPInit ==
103 +==== 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 ====
107 +* 480px, если виджет запущен как type: 'modal'
108 +* 100%, если виджет запущен как type: 'instant'
162 162  
163 -Тип данных:## //number//##
110 +==== width: 640 ====
164 164  
165 -(% class="box infomessage" %)
166 -(((
167 167  Ширина виджета в пикселях, по умолчанию:
168 - • 640px, если виджет запущен как type: 'modal'
169 - • 100%, если виджет запущен как type: 'instant'
170 -)))
171 171  
172 -==== type ====
114 +* 640px, если виджет запущен как type: 'modal'
115 +* 100%, если виджет запущен как type: 'instant'
173 173  
174 -Тип данных:## //string//##
117 +==== type: 'modal' ====
175 175  
176 -По умолчанию:##// 'instant'//##
119 +Способ открытия виджета, по умолчанию 'instant':
177 177  
178 -(% class="box infomessage" %)
179 -(((
180 -Способ открытия виджета
181 - • 'instant' Открытие виджета на месте, где был вызов виджета (на месте тэга script), либо в блоке place, если он указан в параметрах виджета при инициализации
182 - • 'modal' Открытие виджета в модальном окне
183 -)))
121 +* 'instant' Открытие виджета на месте, где был вызов виджета (на месте тэга script), либо в блоке place, если он указан в параметрах виджета при инициализации
122 +* 'modal' Открытие виджета в модальном окне
184 184  
185 -==== place ====
124 +==== place: '#place' ====
186 186  
187 -Тип данных:## //string//##
126 +Идентификатор элемента 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 -----
133 +==== ~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-- ====
200 200  
201 -== Возможные параметры WPOpen и WPOpenModal ==
135 +==== Возможные параметры WPOpen и WPOpenModal ====
202 202  
203 -=== Услуги, пакеты услуг, группы услуг ===
137 +===== Календарь и даты =====
204 204  
205 -==== tariffsid ====
139 +==== nocalendar: false ====
206 206  
207 -Тип данных:##// Array<number> //##//|## boolean##//
141 +Убирает календарь внутри виджета (и в //покупке// и в //пополнении//), в случаях, когда дата, на которую покупается/пополняется билет, не важна. По умолчанию false
208 208  
209 -По умолчанию:##// []//##
143 +==== mindate: '01.01.2019' ====
210 210  
211 -(% class="box infomessage" %)
212 -(((
213 -Тарифы, которые следует показать на вкладке «Покупка услуг». По умолчанию массив пуст и не показывает отдельно никакие из услуг. Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать услуги, доступные только для него.
214 -)))
145 +Параметр минимальной отображаемой даты в календаре (и в //покупке// и в //пополнении//). mindate: '20.05.2018' покажет 20.05.2018 как самую первую дату, доступную к выбору в календаре, если она находится после текущего дня
215 215  
216 -Пример:
147 +==== maxdate: '01.01.2020' ====
217 217  
218 -{{code language="javascript"}}
219 -tariffsid: [29, 30] // покажет тарифы с id 29 и 30 во вкладке «Покупка услуг».
220 -tariffsid: false // уберёт все тарифы с первой страницы
221 -{{/code}}
149 +Параметр максимальной отображаемой даты в календаре (и в //покупке// и в //пополнении//). maxdate: '20.05.2018' покажет 20.05.2018 как самую последнюю дату, доступную к выбору в календаре.
222 222  
223 -==== rewritetariffsid **##*##** ====
151 +==== forcedate: '12.06.2019' ====
224 224  
225 -Тип данных:##// Array<number> //##//|## boolean##//
153 +Параметр для открывания виджета с указанной сразу датой (и в //покупке// и в //пополнении//). forcedate: '20.05.2018' покажет услуги к продаже на дату 20.05.2018.
226 226  
227 -По умолчанию:##// []//##
155 +==== disableddates: ['23.02.2019' ====
228 228  
229 -(% class="box infomessage" %)
230 -(((
231 -Тарифы, которые следует показать после ввода карты во вкладке «Пополнение услуг». По умолчанию массив пуст и не показывает отдельно никакие из услуг. Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать услуги, доступные только для него.
232 -)))
157 +==== , … ] ====
233 233  
234 -Пример:
159 +Параметр отключения дат в календаре (и в //покупке// и в //пополнении//). Делает невозможным выбор определённых дней в массиве дат.
160 +Пример использования: disableddates: ['23.02.2018', '08.03.2018'] уберёт даты 23.02.2018 и 08.03.2018 из возможных для выбора дат в календаре.
235 235  
236 -{{code language="javascript"}}
237 -rtariffsid: [56, 57] // покажет тарифы с id 56 и 57 после ввода карты во вкладке «Пополнение услуг»
238 -rtariffsid: false // уберёт все тарифы во вкладке «Пополнение услуг»
239 -{{/code}}
162 +~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~--
240 240  
241 -==== rtariffsid ====
164 +===== Услуги, пакеты услуг, группы услуг =====
242 242  
243 -(% class="box infomessage" %)
244 -(((
245 -См. rewritetariffsid. Доступен и в старой версии виджета
246 -)))
166 +==== tariffsid: [29 ====
247 247  
248 -==== bundlesid ====
168 +==== , 30 ====
249 249  
250 -Тип данных:##// Array<number> //##//|## boolean##//
170 +==== , … ] ====
251 251  
252 -По умолчанию:##// []//##
172 +Тарифы, которые следует показать на вкладке «Покупка услуг». По умолчанию массив пуст и не показывает отдельно никакие из услуг. Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать услуги, доступные только для него.
173 +Пример использования:
174 +tariffsid: [29, 30] покажет тарифы с id 29 и 30 во вкладке «Покупка услуг».
175 +tariffsid: false уберёт все тарифы с первой страницы
253 253  
254 -(% class="box infomessage" %)
255 -(((
256 -Пакеты услуг, которые следует показать на первой странице. По умолчанию массив пуст и не показывает отдельно никакие из пакетов услуг. Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать пакеты услуг, доступные только для него.
257 -)))
177 +==== rtariffsid: [56 ====
258 258  
259 -Пример:
179 +==== , 57 ====
260 260  
261 -{{code language="javascript"}}
262 -bundlesid: [4, 5] // покажет пакеты услуг с id 4 и 5 в момент открытия виджета.
263 -bundlesid: false // уберёт все пакеты услуг с первой страницы
264 -{{/code}}
181 +==== , … ] ====
265 265  
266 -==== bundleslessonstariffsid ====
183 +Тарифы, которые следует показать после ввода карты во вкладке «Пополнение услуг». По умолчанию массив пуст и не показывает отдельно никакие из услуг. Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать услуги, доступные только для него.
184 +Пример использования:
185 +rtariffsid: [56, 57] покажет тарифы с id 56 и 57 после ввода карты во вкладке «Пополнение услуг»
186 +tariffsid: false уберёт все тарифы с первой страницы
267 267  
268 -Тип данных:##// Array<number>//##
188 +==== bundlesid: [4 ====
269 269  
270 -По умолчанию:##// []//##
190 +==== , 5 ====
271 271  
272 -(% class="box warningmessage" %)
273 -(((
274 -Описание отсутствует
275 -)))
192 +==== , … ] ====
276 276  
277 -==== groupid ====
194 +Пакеты услуг, которые следует показать на первой странице. По умолчанию массив пуст и не показывает отдельно никакие из пакетов услуг. Используется для принудительной фильтрации в том случае, когда определённому пользователю необходимо показывать пакеты услуг, доступные только для него.
195 +Пример использования:
196 +bundlesid: [4, 5] покажет пакеты услуг с id 4 и 5 в момент открытия виджета.
197 +bundlesid: false уберёт все пакеты услуг с первой страницы
278 278  
279 -Тип данных:##// number//##
199 +==== groupid: 12 ====
280 280  
281 -По умолчанию:##// undefined//##
282 -
283 -(% class="box infomessage" %)
284 -(((
285 285  Параметр, который форсирует показ определённой группы услуг ппс. groupid: 5 покажет только одну группу с id 5 в виджете.
286 -)))
287 287  
288 -----
203 +~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~-~--
289 289  
290 -=== Календарь и даты ===
205 +===== Предзаказ =====
291 291  
292 -==== disableddates ====
207 +==== preorder: [{id: 57 ====
293 293  
294 -Тип данных:##// Array<string>//##
209 +==== , date: '06.06.2019' ====
295 295  
296 -По умолчанию:##// []//##
211 +==== , count: 1 ====
297 297  
298 -(% class="box infomessage" %)
299 -(((
300 -Параметр отключения дат в календаре (и в //покупке// и в //пополнении//). Делает невозможным выбор определённых дней в массиве дат.
301 -)))
213 +==== }, … ] ====
302 302  
303 -Пример:
215 араметр, позволяющий купить сразу несколько услуг и перейти к подтверждению покупки.
304 304  
305 -{{code language="javascript"}}
306 -disableddates: ['23.02.2018', '08.03.2018'] // уберёт даты 23.02.2018 и 08.03.2018 из возможных для выбора дат в календаре.
307 -{{/code}}
217 +* id id услуги к покупке
218 +* date дата, на которую покупается услуга
219 +* count — количество покупаемых услуг
308 308  
309 -==== forcedate ====
221 +===== Пример передаваемых данных: =====
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 443  {{code language="javascript"}}
444 -forcemedia: 'E0012345678900'
224 +// либо WPOpenModal({})
225 +WPOpen({
226 + preorder: [
227 + {
228 + id: 57,
229 + date: '06.06.2019',
230 + count: 1
231 + }, {
232 + id: 58,
233 + date: '07.06.2019',
234 + count: 2
235 + }
236 + ]
237 +})
445 445  {{/code}}
446 446  
447 -==== forceseanceid **##*##** ====
240 +===== Отображение =====
448 448  
449 -Тип данных:##// number//##
242 +==== forcetab: 'rewrite' ====
450 450  
451 о умолчанию без указания идентификатора не учитывается.
244 ереключение на необходимую вкладку виджета («покупка услуг» или «пополнение услуг») при загрузке. По умолчанию открывается вкладка «покупка услуг». forcetab: 'rewrite' принудительно откроет «пополнение услуг». Обычно используется в комбинации с параметром onlytab
452 452  
453 -(% class="box infomessage" %)
454 -(((
455 -Заставит виджет выбрать мероприятие арены по идентификатору платформы и не позволять вернуться к этапу выбора других мероприятий.
456 -)))
246 +==== onlytab: 'rewrite' ====
457 457  
458 -==== forcesectorid **##*##** ====
248 +Скрытие других вкладок виджета («покупка услуг» или «пополнение услуг») при загрузке. Обычно используется в комбинации с параметром forcetab
459 459  
460 -Тип данных:##// number//##
250 +* onlytab: 'service' покажет только вкладку «покупка услуг».
251 +* onlytab: 'rewrite' покажет только вкладку «пополнение услуг».
461 461  
462 -По умолчанию без указания идентификатора не учитывается.
253 +==== forcemedia: 'E0012345678900' ====
463 463  
464 -(% class="box infomessage" %)
465 -(((
466 -Заставит виджет выбрать сектор мероприятия по **##id##** и не позволять вернуться к этапу выбора других секторов.
467 -)))
255 +Параметр, который вставяет строчку с носителем в поле носителя во вкладке «Пополнение услуг». Используется, например, для QR-кода нанесённого на носитель, чтобы быстро его пополнить.
468 468  
469 -==== forcetab **##*##** ====
257 +==== nopromo: false ====
470 470  
471 -Тип данных:##// string//##
259 +Убирает вывод промокода на странице подтверждения заказа. По умолчанию false
472 472  
473 -По умолчанию:##// ''//##
261 +==== terminal: true ====
474 474  
475 -(% class="box infomessage" %)
476 -(((
477 -Переключение на необходимую вкладку виджета («**покупка услуг**» или «**пополнение услуг**») при загрузке.
478 -По умолчанию открывается вкладка «**покупка услуг**».
479 -**##forcetab: 'rewrite'##** принудительно откроет «**пополнение услуг**».
480 -Обычно используется в комбинации с параметром **##onlytab##**
481 -)))
263 +Включение режима «терминал» для работы виджета. При этом режиме убирается возможность отослать заказ на SMS, а сам заказ распечатывается на принтере.
482 482  
483 -==== grouplessonsskillstariffs ====
265 +==== cartmaxitems: 5 ====
484 484  
485 -Тип данных:##// Array<number> //##//|## object##//
267 +==== ====
486 486  
487 -По умолчанию:##// {}//##
269 +Ограничивает максимальное кол-во товаров в корзине. Минимальное значение 1. Максимальное значение 60. По умолчанию 6
488 488  
489 -(% class="box warningmessage" %)
490 -(((
491 -Описание отсутствует
492 -)))
271 +==== cartminitems: 2 ====
493 493  
494 -==== grouplessonstariffsid ====
273 +==== ====
495 495  
496 -Тип данных:##// Array<number>//##
275 +Ограничивает минимальное кол-во товаров в корзине. Минимальное значение 1. Максимальное значение 60. По умолчанию 1
497 497  
498 -По умолчанию:##// []//##
277 +==== locale: 'ru' ====
499 499  
500 -(% class="box infomessage" %)
501 -(((
502 -Фильтр программ обучения для групповых занятий
503 -)))
279 +==== ====
504 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 547  Параметр локализации. Позволяет переключать между языками виджета, например 'ru' - русский язык, 'en' - английский язык.
548 -)))
549 549  
550 -==== marketbillid ====
283 +==== ordercomment: 'Комментарий к заказу' ====
551 551  
552 -Тип данных:##// number//##
285 +==== ====
553 553  
554 -По умолчанию:##// undefined//##
287 +Опциональный комментарий к заказу. Максимальная длинна комментария 50 символов.
555 555  
556 -(% class="box warningmessage" %)
557 -(((
558 -Описание отсутствует
559 -)))
289 +==== disablemultipleseances: true ====
560 560  
561 -==== marketemployeeid ====
291 +==== ====
562 562  
563 -Тип данных:##// number//##
293 +Параметр предотвращает добавление в корзину тарифов с различными сеансами.
294 +Таким образом как только в корзине появится хоть один товар с сеансом "10:00 - 11:30", товары, у которых есть сеанс например "13:00 - 14:30" будет невозможно добавить в корзину. Товары без сеансов не будут затронуты.
295 +По умолчанию false
564 564  
565 -По умолчанию:##// undefined//##
566 566  
567 -(% class="box warningmessage" %)
568 -(((
569 -Описание отсутствует
570 -)))
298 +==== tariffsseancesfilter: true ====
571 571  
572 -==== minimap **##*##** ====
300 +==== ====
573 573  
574 -Тип данных:##// boolean//##
302 +[[image:https://info.moipass.ru/images/tariffsseancesfilter.png||alt="Example"]]
575 575  
576 -По умолчанию:##// true//##
304 +Включить отображение фильтра тарифов по сеансам. По умолчанию false
577 577  
578 -(% class="box infomessage" %)
579 -(((
580 -Отображать миникарту.
581 -)))
306 +==== resetcart: true ====
582 582  
583 -==== minimapaspect **##*##** ====
308 +==== ====
584 584  
585 -Тип данных:##// number//##
310 +Автоматически очищать содержимое корзины. По умолчанию false
586 586  
587 -По умолчанию:##// 0.2//##
312 +==== minimap: false ====
588 588  
589 -(% class="box infomessage" %)
590 -(((
591 -Размер миникарты относительной полного размера карты, а не контейнера, в которой она находится.
592 -)))
314 +==== ====
593 593  
594 -==== multidayslessonsskillstariffs **##*##** ====
316 +Отображать миникарту. По умолчанию true
595 595  
596 -Тип данных:##// Array<number> //##//|## object##//
318 +==== minimapaspect: 0.5 ====
597 597  
598 -По умолчанию:##// []//##
320 +==== ====
599 599  
600 -(% class="box infomessage" %)
601 -(((
602 -Производит фильтрацию тарифов для многодневных занятий. Принимает массив идентификаторов.
603 -Параметр дополняет фильтрацию по параметру **##grouplessonsskillstariffs##**.
604 -)))
322 +Размер миникарты относительной полного размера карты, а не контейнера, в которой она находится. По умолчанию 0.2
605 605  
606 -==== nocategories **##*##** ====
324 +==== forceseanceid: 42 ====
607 607  
608 -Тип данных:##// boolean//##
326 +==== ====
609 609  
610 -По умолчанию:##// false//##
328 +Заставит виджет выбрать мероприятие арены по идентификатору платформы и не позволять вернуться к этапу выбора других мероприятий. Без указания идентификатора не учитывается.
611 611  
612 -(% class="box infomessage" %)
613 -(((
614 -Если **##true##** скрывает фильтр по категории инструкторских занятий
615 -)))
330 +==== forcesectorid: 42 ====
616 616  
617 -[[image:1702638427440-675.png]]
332 +==== ====
618 618  
619 -==== nocoach **##*##** ====
334 +Заставит виджет выбрать сектор мероприятия по id и не позволять вернуться к этапу выбора других секторов. Без указания идентификатора не учитывается.
620 620  
621 -Тип данных:##// boolean//##
336 +==== requiredloyalty: true ====
622 622  
623 -По умолчанию:##// false//##
338 +==== ====
624 624  
625 -(% class="box infomessage" %)
626 -(((
627 -Если **##true##** скрывает выпадающее меню выбора инструктора
628 -)))
340 +Включает обязательную регистриацию клиента в программе настроенной на объектке. По умолчанию false
629 629  
630 -[[image:1702638265778-588.png]]
342 +==== personallessonsskillstariffs: [56 ====
631 631  
632 -==== nolocation **##*##** ====
344 +==== , 57 ====
633 633  
634 -Тип данных:##// boolean//##
346 +==== , … ] ====
635 635  
636 -По умолчанию:##// false//##
348 +==== ====
637 637  
638 -(% class="box infomessage" %)
639 -(((
640 -Если **##true##** скрывает фильтр по месту проведения инструкторских занятий
641 -)))
350 +Производит фильтрацию тарифов для индивидуальных занятий. Принимает массив идентификаторов. По умолчанию []
642 642  
643 -[[image:1702638034420-756.png]]
352 +==== multidayslessonsskillstariffs: [56 ====
644 644  
645 -==== nopromo **##*##** ====
354 +==== , 57 ====
646 646  
647 -Тип данных:##// boolean//##
356 +==== , … ] ====
648 648  
649 -По умолчанию:##// false//##
358 +==== ====
650 650  
651 -(% class="box infomessage" %)
652 -(((
653 -Убирает вывод промокода на странице подтверждения заказа.
654 -)))
360 +Производит фильтрацию тарифов для многодневных занятий. Принимает массив идентификаторов. Параметр дополняет фильтрацию по параметру grouplessonsskillstariffs. По умолчанию []
655 655  
656 -==== noskills **##*##** ====
362 +==== saletermstype: 'checkbox' ====
657 657  
658 -Тип данных:##// boolean//##
364 +==== ====
659 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 771  Перед оплатой просит пользователя согласиться с правилами в форме галочки или всплывающего окна
772 -)))
773 773  
774 -{{code language="javascript"}}
775 -saletermstype: 'checkbox' // потребует установку галочки для согласия.
776 -saletermstype: 'dialog' // покажет всплывающее окно с правилами, которые нужно принять.
777 -saletermstype: 'default' // принятие правил не требуется.
778 -{{/code}}
368 +* saletermstype: 'checkbox' потребует установку галочки для согласия.
369 +* saletermstype: 'dialog' покажет всплывающее окно с правилами, которые нужно принять.
370 +* saletermstype: 'default' принятие правил не требуется.
779 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 -===== Пример передаваемых данных: =====
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 -
869 -(% class="box warningmessage" %)
870 -(((
871 -**##* ##**- доступно в новой версии виджета
872 -)))
372 +По умолчанию 'default'
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