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