Изменения

Перейти к навигации Перейти к поиску

Интеграция

10 912 байт убрано, 13:14, 7 ноября 2017
Нет описания правки
[[Category:Функции]]{{Deprecated ru}}[[Category:Интеграция]]<!-- -->Для интеграции Nemo {{NameSystemLink}} с другими системами имеются инструменты обмена данными.
== Легкая форма на сайт ==
[[Файл:Лёгкая_форма.png|400px|thumb|right|«Лёгкая форма»]]
Если вы желаете разместить поисковую форму авиабилетов на другом домене, то это можно сделать с помощью '''«Легкой Формы»'''. Других доменов может быть несколько, но после заполнения поисковых критериев [[пользователь]] будет перебрасываться на ваш сайт для просмотра результатов и бронирования.
[[Файл:IMG_13092012_112041.png]]
Для этого необходимо=== Настройка легкой формы ===В архиве собраны все необходимые файлы для установки легкой формы на вашем сайте. '''Архив легкой формы:''' [[Файл:Light-form.zip]]. 1. Подключить у себя на странице внутри тега <head> нужные файлы:
<pre><link rel="stylesheet" href="css/ui.datepicker.css" type="text/css" media="screen"><link rel="stylesheet" href="css/style.css" type="text/css" media="screen"><script type="text/javascript" src="js/jquery-1.3.1. Разместить у себя на странице в месте, где должна располагаться форма следующий html-код:min.js"></script><script type="text/javascript" src="js/nano_loader.js"></script></pre>
<pre><link relspan style="stylesheetbackground-color:#fff0f5;" href><span style="httpfont-size://DOMAIN/templates/nano/css/ui.datepicker.css" type="text/css" media="screenlarge;" ><script typespan style="text/javascript" src=color:#ff0000;">Если ранее вы использовали http://DOMAIN/static/js/jquery-1.3.1.min.js"></script><script type="text/javascript" src="http://DOMAIN/static/js/nano_loader— обратите внимание на изменение пути.js"></scriptspan></prespan>
<span style="background-color:#fff0f5;"><span style="font-size:large;"><span style="color:#ff0000;">!</span></span> {{Attention|Здесь и делее далее замените в адресах ссылок DOMAIN на имя вашего домена!}}
2. Разместить Также необходимо разместить скрипт инициализации формы:
<pre><script>
</script></pre>
Здесь : * '''typeSearch''' может принимать значения OW или RT (в один конец или туда и обратно).<br> ; * '''arrDate''' - через сколько дней вылет.<br> ;* '''depDate''' - через сколько дней обратный вылет;* '''outSearch''' — текст запроса в автокомплит для предзаполнения поля "Вылет";* '''inSearch''' — текст запроса в автокомплит для предзаполнения поля "Прилет";Дефолтным пунктом вылета/прилета в полях формы установится первый пункт, который подгружается в автокомплит по вводу этого текста.
3. Разместить на html-странице в желаемом месте код формы: <div class="toccolours mw-collapsible mw-collapsed">Код формы<prediv class="mw-collapsible-content"><syntaxhighlight lang="html4strict" line enclose="div" style="font-size:9pt; padding: 10px 5px; margin: 10px 0;"><div id="nano_flght_form" style="display:none;"> <div id="test"></div> <div id="wrapper"> <div id="main"> <div class="title"> <h1>Поиск авиабилетов</h1> </div> <form name="search-form" id="search-form" method="POST" action="http://lightform/index.php?go=search/index"> <fieldset> <div class="box"> <div class="bg-t"> <div class="form-track"> <h2>Маршрут</h2> <div class="mtext"></div> <div class="row"> <input type="hidden" value="1" name="real_gogo"> <input type="radio" id="trip_type" name="trip_type" value="OW" checked>В одну сторону <input type="radio" id="trip_type" name="trip_type" value="RT">Туда и обратно </div> <div id="normal-selection"> <!-- Строка вылета --> <div class="row row-departure"> <!-- Вылет из --> <div class="col-airport"> <label>Вылет</label><span style="display: none; margin-left: 100px;" class="required error" id="out_search-error"></span> <div class="location_select"> <span class="hint"> <div id="span_out_search"></div> <input type="text" style="width: 100%; display: none;" class="loc ac_input" value="" id="out_search" name="out_search" check="" autocomplete="off"> </span> <div id="control_out_iata"> <input type="hidden" rel="{group:['OW', 'RT'], visitor:'prev_iata', id: 'out_search-error', required_error:'Обязательное поле'}" class="v-visitor v-required" value="" name="out_iata"> </div> </div>
</div>
<div id="normal-selection"> <!-- Строка вылета --> <div class="row row-departure"> <!-- Вылет из --> <div class="col-airport"> <label>Вылет</label><span style="display: none; margin-left: 100px;" class="required error" id="out_search-error"></span> <div class="location_select"> <span class="hint"> <div id="span_out_search"></div> <input type="text" style="width: 100%; display: none;" class="loc ac_input" value id="out_search" name="out_search" check autocomplete="off"> </span> <div id="control_out_iata"> <input type="hidden" rel="{group:['OW', 'RT'], visitor:'prev_iata', id: 'out_search-error', required_error:'Обязательное поле'}" class="v-visitor v-required" value name="out_iata"> </div> </div> </div> <!-- Дата вылета --> <div class="col-date"> <label>Дата вылета</label> <div class="inp-hold"> <input type="text" rel="{group:['OW', 'RT'], pattern:/^[\d]{2}\.(0[1-9]|1[0-2])\.(19|20)[\d]{2}$/, date:{use_datepicker_limits: 1}, visitor: 'rt_prev_date', required_error:'Обязательное поле'}" maxlength="10" size="10" value="" id="departure_date" class="text v-date v-required v-visitor" name="departure_date"><span class="smbl_req"> * </span><span normal_error="" field="departure_date" id="departure_date-error" class="required error" style="display:none;"></span> </div> </div> <!-- Время вылета --> <!-- <div class="col-time"> <label>Время вылета</label> <span class="hint"> <select rel="{group:['RT'], visitor: 'rt_daytime'}" class="v-prefered v-required v-visitor" id="prefered_departure_type" name="prefered_departure_type"> <option selected="" value="not_important">в любое время </option> <option value="morning">утром </option> <option value="afternoon">днем </option> <option value="evening">вечером </option> <option value="night">ночью </option> </select> </span> <span normal_error="" field="prefered_departure_type" id="prefered_departure_type-error" class="error"></span> </div> --> </div> <div class="arrows arrow_ow" id="arrows"></div> <!-- Строка прилета (обратного вылета) --> <div class="row row-arrival"> <!-- Пункт прилета --> <div class="col-airport"> <label>Прилет </label><span style="display: none; margin-left: 100px;" class="required error" id="in_search-error"></span> <div class="location_select"> <span class="hint"> <div id="span_in_search"></div> <input type="text" style="display: none;" class="loc ac_input" size="40" rel="{group:['OW','RT'], visitor:'prev_iata'}" value="" id="in_search" name="in_search" check="" autocomplete="off"> </span> <div id="control_in_iata"> <input type="text" rel="{group:['OW','RT'], visitor:'prev_iata', id: 'in_search-error', required_error:'Обязательное поле'}" style="display: none;" class="v-visitor v-required" valuename="in_iata"> </div> </div> </div> <!-- Дата обратного вылета --> <div style="display: none;" id="control_back_departure_date" class="col-date"> <label>Обратный вылет</label> <div class="inp-hold"> <input type="text" rel="{group:['RT'], pattern:/^[\d]{2}\.(0[1-9]|1[0-2])\.(19|20)[\d]{2}$/, date:{use_datepicker_limits: 1}, visitor: 'rt_prev_date', required_error:'Обязательное поле'}" maxlength="10" size="10" value id="back_departure_date" class="text datepick v-date v-required v-visitor" name="in_iataback_departure_date"><span class="smbl_req"> * </span><span normal_error field="back_departure_date" id="back_departure_date-error" class="required error"></span> </div> </div> <!-- Время обратного вылета --> <!-- <div style="display: none;" id="prefered_back_departure_type" class="col-time"> <label>Время вылета обратно</label> <select rel="{group:['RT'], visitor: 'rt_daytime'}" class=" v-prefered v-visitor" name="prefered_back_departure_type"> <option value="not_important">в любое время </option> <option value="morning">утром </option> <option value="afternoon">днем </option> <option value="evening">вечером </option> <option value="night">ночью </option> </select> </div> --> </div> <!-- Доп. параметры в осн. блоке --> <div class="row row4"> <!-- Поиск только прямых рейсов --> <div class="che-hold"> <input type="checkbox" id="direct" name="direct" value="true"> </div> <label for="direct">Без пересадок</label> <!-- Поиск только LOWCost --> </div>
</div>
</div>
<!-- Дата обратного вылета -->
<div style="display: none;" id="control_back_departure_date" class="col-date">
<label>Обратный вылет</label>
<div class="inp-hold">
<input type="text" rel="{group:['RT'], pattern:/^[\d]{2}\.(0[1-9]|1[0-2])\.(19|20)[\d]{2}$/, date:{use_datepicker_limits: 1}, visitor: 'rt_prev_date', required_error:'Обязательное поле'}" maxlength="10" size="10" value="" id="back_departure_date" class="text datepick v-date v-required v-visitor" name="back_departure_date"><span class="smbl_req"> * </span><span normal_error="" field="back_departure_date" id="back_departure_date-error" class="required error"></span>
</div>
</div>
<!-- Время обратного вылета --> <div style="display: none;" id="prefered_back_departure_type" class="col-time"> <label>Время вылета обратно</label> <select rel="{group:['RT'], visitor: 'rt_daytime'}" class=" v-prefered v-visitor" name="prefered_back_departure_type"> <option value="not_important">в любое время </option> <option value="morning">утром </option> <option value="afternoon">днем </option> <option value="evening">вечером </option> <option value="night">ночью </option> </select> </div> </div> <!-- Доп. параметры в осн. блоке --> <div class="row row4"> <!-- Поиск только прямых рейсов --> <div class="che-hold"> <input type="checkbox" id="direct" name="direct" value="true"> </div> <label for="direct">Без пересадок</label> <!-- Поиск только LOWCost --> </div> </div> </div> </div> </div> <div class="box-bottom"> </div> <div class="box box2"> <div class="bg-t"> <div class="bg-b"> <div class="form-track"> <h2>Пассажиры</h2> <div class="row row2"> <div class="passenger"> <label class="lab1 ts_adults_label">взрослых <span class="psngr_age"><br> 12 лет</span></label> <select rel="{group:['OW', 'RT', 'CR'], visitor:'people', id:'people_error'}" class="v-visitor select3" name="adults"> <option selected="" value="1">1</option> <option value="2">2</option> <option value="3">3</option> <option value="4">4</option> <option value="5">5</option> </select> </div> <div class="passenger"> <label class="ts_chd_label">детей <span class="psngr_age"><br>от 2 до 12 лет</span></label> <select rel="{group:['OW', 'RT', 'CR'], visitor:'people', id:'people_error'}" class="v-visitor select3" name="children"> <option selected="" value="0">0</option>
<option value="1">1</option>
<option value="2">2</option>
<option value="4">4</option>
<option value="5">5</option>
</select> </div> <div class="passenger"> <label class="ts_inf_label">младенцев <span class="psngr_age"><br>до 2 лет</span></label> <select rel="{group:['OW', 'RT', 'CR'], visitor:'people', id:'people_error'}" class="v-visitor select3" name="infants"> <option selected="" value="0">0</option>
<option value="1">1</option>
</select> </div> <div class="passenger"> <label class="ts_infseat_label">младенцев с местом <span class="psngr_age"><br>до 2 лет</span></label> <select rel="{group:['OW', 'RT', 'CR'], visitor:'people', id:'people_error'}" class="v-visitor select3" name="infants_seat"> <option selected="" value="0">0</option> <option value="1">1</option> <option value="2">2</option> <option value="3">3</option> </select> </div> <span normal_error="" field="adults" id="people_error" class="required error"></span> </div> </div> </div> </div> </div> <div class="buttons holder"> <input type="submit" class="linkbutton btn-search" value="Поиск" name="gogo" id="submit_click"> <input type="button" value="очистить" class="btn btn-clear search_btn_clear linkbutton" name="clear" id="clear_button"> <span class="search-form-err" id="search-form-static-error"></span><br> <span class="search-form-err" id="search-form-error" style="display: none;"></span> <div class="clear"></div> </div> <input type="hidden" value id="input_vendors" name="input_vendors"> <input type="hidden" value="1" id="advanced_count" name="advanced_count"> <div class="clear"></div> <div style="display: none;" id="ChildrenWarn"> <span>Путешествие детей без взрослых может быть запрещено <br> <a id="read-children-warn" href="javascript:void(null);">Я принимаю условия</a> </span> </div> </fieldset> </form>
</div>
</div> <div class="buttons holder"> <input type="submit" class="linkbutton btn-search" value="Поиск" name="gogo" id="submit_click"> <input type="button" class="linkbutton btn-search" value="Расширенный поиск" name="advanced" href="" id="advanced_link" style="float: right;"> <input type="button" value="очистить" class="btn btn-clear search_btn_clear linkbutton" name="clear" id="clear_button"> <span class="search-form-err" id="search-form-static-error"></span><br> <span class="search-form-err" id="search-form-error" style="display: none;"></span> <div class="clear"></div> </div> <input type="hidden" value="" id="input_vendors" name="input_vendors"> <input type="hidden" value="1" id="advanced_count" name="advanced_count"> <div class="clear"></div> <div style="display: none;" id="ChildrenWarn"> <span>Путешествие детей без взрослых может быть запрещено <br> <a id="read-children-warn" href="javascript:void(null);">Я принимаю условия</a> </span> </div> </fieldset> </formsyntaxhighlight> </div> </div></div></pre>
И код <div class="toccolours mw-collapsible mw-collapsed">Код стилей (их можно изменять по своему желанию). <prediv class="mw-collapsible-content"><syntaxhighlight lang="css" line enclose="div" style="font-size:9pt; padding: 10px 5px; margin: 10px 0;">body{color:#4a4a4a;font:12px Arial, 'Trebuchet MS', sans-serif;/*background:url(../images/bg.jpg) no-repeat 50% 0;*/margin:0;}
img{border-style:none;}
a{color:#009}
.header-hold{width:100%;clear:both;}
.logo{width:114px;height:55px;overflow:hidden;float:left;display:inline;margin:4px 0 0 63px;}
.header-hold .logo a{display:block;background:url(../images/logo.png);text-indent:-9999px;overflow:hidden;width:114px;height:55px;}
#header .login-box{float:left;display:inline;margin:10px 0 0 0;}
#lang{float:right;display:none;margin:12px 20px 0 0;}
#header .top-menu li{float:left;margin:0 0 0 5px;}
#header .top-menu a{float:left;padding:0 0 0 7px;}
#header .top-menu a.lnk-avt{background:url(../images/ico-topnav.gif) no-repeat 0 0;}#header .top-menu a.lnk-reg{background:url(../images/ico-topnav.gif) no-repeat 0 -18px;padding:0 0 0 14px;}/*#header .top-menu a.lnk-tools{background:url(../images/ico-topnav.gif) no-repeat 0 -36px;padding:0 0 0 18px;}*/
.navigation{list-style:none;font-size:22px;line-height:36px;width:1048px;overflow:hidden;margin:0 -48px 0 0;padding:14px 0 0 1px;}
.navigation li{float:left;margin:0 48px 0 0;}
.navigation a{float:left;color:#4a4a4a;background:url(../images/bg-nav-ico.png) no-repeat;}
.navigation .lnk-ticket{background-position:0 0;padding:0 0 0 63px;}
.navigation .lnk-otel{background-position:0 -36px;padding:0 0 0 37px;}
#main .title{overflow:hidden;padding:0 0 12px;}
#main .title h1{color:#333;font-size:24px;font-weight:400;margin:0;}
.box{width:100%;background:url(../images/bg-box.gif);}
.box .bg-t{border-top:1px solid #e3e3e3;border-bottom:1px solid #a3a3a3;border-right:1px solid #a3a3a3}
.form-track{padding:8px 15px 0;}
.form-track label.active{font-weight:700;color:#48a200;}
ul.che-list li {clear:both;}
.arrows{background:url(../images/arrows.png) no-repeat left top;margin-left: 151px;height:35px;width:61px;cursor:pointer;display:none}
.arrow_rt{background-position:left -35px;}
.col-airport, .col-city{float:left;width:390px;position:relative}
#assignment-error .tooltip-red{top:-80px !important;left:190px !important;position:relative !important;}
.tooltip .l{float:left;overflow:hidden;width:30px;height:51px;}
.tooltip-blue .l{background:url(../images/bg-tt-blue-l.png);}.tooltip-red .l{background:url(images/bg-tt-red-l.png);}.tooltip-red ./l{background:url(images/bg-tt-red-l.png);}
.tooltip .txt{float:left;height:33px;padding:0 8px 0 0;}
.tooltip-blue .txt{background:url(../images/bg-tt-blue-c.png);}.tooltip-red .txt{background:url(../images/bg-tt-red-c.png);}
.tooltip .txt span{float:left;position:relative;margin:0 0 0 -13px;}
.tooltip .r{float:left;overflow:hidden;width:11px;height:33px;}
.tooltip-blue .r{background:url(../images/bg-tt-blue-r.png);}.tooltip-red .r{background:url(../images/bg-tt-red-r.png);}
.col-airport select{width:365px;font:17px/20px 'Trebuchet MS', Arial, sans-serif;color:#6c6c6c;}
.form-track .col-date{float:left;position:relative}
/*.form-track .col-time{float:left;overflow:hidden;}*/
.row-departure{width:100%;clear:both;padding:0 0 4px;}
.box-bottom{width:100%;overflow:hidden;background:url(../images/bg-box-b.gif);margin:0 0 20px;}.box-bottom .bg-t{width:100%;overflow:hidden;background:url(../images/bg-box-b-t.gif) no-repeat;display:none}
.box-bottom .bg-b{height:1%;overflow:hidden;padding:14px 10px 10px 10px;border:1px solid #ececec}
.box-bottom .title-b{padding:0 0 24px;}
.box-bottom h3{font-size:18px;font-weight:400;background:url(../images/dashed.gif) repeat-x 0 100%;float:left;margin:0;padding:0 0 3px;}.box-bottom h3 a{text-decoration:none;background:url(../images/arrow-top.gif) no-repeat 100% 50%;color:#4a4a4a;padding:0 18px 0 0;}.box-bottom h3 a.close-box{background:url(../images/arrow-bottom.gif) no-repeat 100% 50%;}
.row{clear:both;padding:0 0 24px;}
.row label span{padding:0 5px;}
.toll-che{padding-top:20px;}
.add,.delete{float:left;color:#4a4a4a;font-size:14px;line-height:27px;text-decoration:none;padding:0 0 0 32px;}
.delete{float:right;background:url(../images/ico-error.gif) no-repeat 0 -41px;margin:0 116px 0 0;}.add span,.delete span{background:url(../images/dashed.gif) repeat-x 0 100%;}.add{background:url(../images/ico-error.gif) no-repeat 0 0;font-size:18px;line-height:36px;padding:0 0 0 44px;}
.form-track .row1 label{line-height:30px;}
.buttons{padding:10px 0 15px;}
.error1{color:#ec1612;font-size:14px;background:url(../images/ico-error.gif) no-repeat 0 -75px;line-height:30px;margin:5px 0 0 42px;padding:0 0 0 52px}
.search_noresults{width:960px !important;margin-left:-265px}
.btn{border:none;background:none;}
.search-form-err{color:#F00; line-height:30px;font-size:16px; margin:10px 0 0 42px;padding:10px 0 0;}
.warning{color:#af0307;font-size:14px;font-weight:700;background:url(../images/warning.png) no-repeat;line-height:48px;margin:5px 0 10px 12px;padding:0 0 0 52px;}
.buttons .btn-search, .btn-big-w{background: #57bb10;float:left;height:25px;line-height:25px;font-size:18px;color:#fff;text-decoration:none;margin:0 0 0 0;border-top:1px solid #add595;border-left:1px solid #add595;border-right:1px solid #3e8514;border-bottom:1px solid #3e8514;
border-radius: 3px;-moz-border-radius: 3px;-webkit-border-bottom-left-radius: 3px;-webkit-border-top-right-radius: 3px;
-webkit-border-bottom-right-radius: 3px;-webkit-border-top-left-radius: 3px}
.buttons .btn-search span, .btn-big-w span{float:left;background:url(../images/btn-search.gif) no-repeat 100% -41px;cursor:pointer;padding:0 45px;}.btn-big-g{background:url(../images/btn-big-g.gif);float:left;height:41px;line-height:41px;font-size:24px;color:#fff;text-decoration:none;margin:0 0 0 31px;}.btn-big-g span{float:left;background:url(../images/btn-big-g.gif) no-repeat 100% -41px;cursor:pointer;padding:0 45px;}.btn-big-g-a{background:url(../images/btn-big-g.gif);float:left;height:41px;line-height:41px;font-size:24px;color:#fff;text-decoration:none;}.btn-big-g-a span{float:left;background:url(../images/btn-big-g.gif) no-repeat 100% -41px;cursor:pointer;padding:0 45px;}.pay-btn-big-g{background:url(../images/btn-big-g.gif);float:left;height:41px;line-height:41px;font-size:24px;color:#fff;text-decoration:none;margin:0 0 0 31px;}.pay-btn-big-g span{float:left;background:url(../images/btn-big-g.gif) no-repeat 100% -41px;cursor:pointer;padding:0 45px;}
.btn-clear, .btn-small{float:right;border-bottom:1px solid #a3a3a3;border-right:1px solid #a3a3a3;border-left:1px solid #f4f4f4;border-top:1px solid #f4f4f4;height:24px;line-height:24px;color:#4a4a4a;text-decoration:none;margin:9px 20px 0 0;background:#d9d9d9}
.btn-small-g{float:right;background:#FF8C00;border-right:1px solid #a4a4a4;border-bottom:1px solid #a4a4a4;border-left:1px solid #f4f4f4;border-top:1px solid #f4f4f4;height:24px;line-height:24px;color:#fff;text-decoration:none;border-radius: 3px;-moz-border-radius: 3px;-webkit-border-bottom-left-radius: 3px;-webkit-border-top-right-radius: 3px;
.btn-small-g span{float:left;cursor:pointer;white-space:nowrap;padding:0 12px;}
button{cursor:pointer;}
.btn-clear span,.btn-small span{float:left;cursor:pointer;background:url(../images/btn-clear.gif) no-repeat 100% -24px;white-space:nowrap;padding:0 12px;}
.search_btn_clear{float:right;display:none}
.select2{width:53px;}
.che-hold{float:left;overflow:visible;margin:4px 0 0;}
.row-arrows1 select{width:364px;font:17px/20px 'Trebuchet MS', Arial, sans-serif;color:#6c6c6c;}
.row-arrows1 .arrow{float:left;overflow:hidden;background:url(../images/arrow-right.gif);width:35px;height:28px;margin:0 27px 0 33px;}
#table{
border-collapse: collapse;
}
#table th, #table td{
border: 1px solid #E2E2E2; vertical-align: top; padding:4px;
}
#air_fare_info h2{margin-top:20px;}
#table th{
background-image: url(../images/hdr.gif); background-repeat: repeat-x; background-position: top; background-color: #4888eb; color: #FFF; font-size: 10px;
}
.stub_extra_block{ padding: 14px 0 0; }
#footer{width:420px;overflow:hidden;background:url(../images/sep-footer.gif) no-repeat 50% 0;margin:20px auto 0;padding:10px 0 20px;display:none !important}
#footer p{text-align:center;margin:0;}
#footer p a{padding:0 10px;}
.canvas{padding:10px 20px 0;}
#fader{position:absolute;top:0;left:0;display:none;z-index:999;background:#000;}
.popup .title{background:url(../images/bg-popup-top.png);width:512px;height:43px;overflow:hidden;}.popup .title .close{float:right;text-indent:-9999px;overflow:hidden;background:url(../images/btn-close.gif);width:15px;height:16px;margin:13px 16px 0 0;}.popup .m{background:url(../images/bg-popup.png);overflow:hidden;width:474px;padding:10px 16px 22px 22px;}.popup .b{display:block;overflow:hidden;width:100%;background:url(../images/bg-popup-b.png);height:8px;}.popup .inp-hold3{background:url(../images/bg-inp3.gif);overflow:hidden;width:339px;height:14px;margin:0 0 15px;padding:8px 13px;}
.popup .inp-hold3 input{border:0;width:339px;height:14px;padding:0;}
.popup .wrap{overflow:hidden;height:334px;width:475px;position:relative;}
.popup .check-list li{width:100%;overflow:hidden;padding:0 0 16px;}
.popup .check-list label{float:left;line-height:22px;margin:0 0 0 6px;}
.popup .btn-save{float:left;overflow:hidden;background:url(../images/btn-save.gif);height:32px;color:#fff;line-height:32px;text-decoration:none;font-size:18px;margin:16px 0 0;}.popup .btn-save span{float:left;cursor:pointer;background:url(../images/btn-save.gif) no-repeat 100% -32px;padding:0 27px;}
.scrollable{height:334px;overflow:hidden;}
.scroll-content{top:0!important;height:334px!important;width:475px!important;left:0!important;}
.vscroll-bar{position:absolute;width:12px!important;height:334px!important;top:0!important;margin:0;padding:0;}
.vscroll-line{width:11px!important;overflow:hidden;background:url(../images/scroll-line.gif);}.vscroll-slider{background:url(../images/slider.gif)!important;width:12px!important;cursor:pointer;height:12px!important;overflow:hidden;}
.box-hide .box{margin-top:-230px;position:relative;}
.box-hide .active-box{margin-top:0;}
.ac_results li{display:block;font:menu;font-size:11px;line-height:16px;overflow:hidden;color:#FFF;border-top:1px solid #1fa2e7;border-bottom:1px solid #0088d0;white-space:nowrap;cursor:pointer;margin:0;padding:4px 5px;}
.ac_results .grey, .aj_inf{color:#9ff8ff;}
.ac_loading{background:url(../images/indicator.gif) right no-repeat!important;background-color:#FFF;}
.ac_over{background-color:#5ec1f7;color:#FFF;}
input[type=text],input[type=password],input[type=input],select, .location_select{position:relative;line-height:20px;height:20px;border:1 solid #CCC;background:#FFF /*url(../images/inp-shadow.gif) repeat-x*/;border-right:1px solid #b7b7b7;border-left:1px solid #b7b7b7;border-top:1px solid #AAA;border-bottom:1px solid #E9E9E9;padding:0; overflow:hidden;}
.loc{width:100%;border-style:none !important;background-image:none!important;padding:0!important;margin:0!important;height:18px!important;}
.location_select{cursor:pointer;}
.location_select span div, .location_select input{width:99%; cursor:pointer;}
.location_select .grey, .location_select .aj_inf{color:#DDD;float:right !important;}
input.hasDatepicker{background:url(../images/cal-bg.png) top right no-repeat;padding-right:20px;}
.inp-hold1{float:left;}
#tooltip{background:url(../images/bg-tooltip.png);background-color:none;opacity:0.85;position:absolute;z-index:3000;padding:17px 6px 6px 17px;}
#tooltip h3,#tooltip div{font-size:.9em;color:#FFF;margin:0;}
.settings{margin-bottom:20px;clear:both; position:relative;}
#TB_secondLine{font:10px Arial, Helvetica, sans-serif;color:#666;}
#TB_overlay{position:fixed;z-index:100;top:0;left:0;height:100%;width:100%;}
.TB_overlayMacFFBGHack{background:url(images/macFFBgHack.png) repeat;}
.TB_overlayBG{background-color:#000;filter:alpha(opacity=75);-moz-opacity:0.75;opacity:0.75;}
#TB_window img#TB_Image{display:block;border-right:1px solid #ccc;border-bottom:1px solid #ccc;border-top:1px solid #666;border-left:1px solid #666;margin:15px 0 0 15px;}
#TB_closeWindow{height:25px;float:right;padding:11px 25px 10px 0;}
#TB_closeAjaxWindow{margin-bottom:1px;text-align:right;float:right;padding:12px 10px 5px 0;}
#TB_closeWindowButton{background:url(../images/btn-close.gif) no-repeat right;width:15px;height:16px;color:#FFF;margin:33px 5px 0 0;padding:12px 22px 13px;}
#TB_closeWindowButton a:link,#TB_closeWindowButton a:visited{color:#FFF;}
#TB_title{background-color:#0097e7;height:43px;}
* html #TB_overlay,* html #TB_HideSelect{
position:absolute; height:expression(document.body.scrollHeight>document.body.offsetHeight?document.body.scrollHeight:document.body.offsetHeight+'px');
}
* html #TB_window,* html #TB_load{
position:absolute; margin-top:expression(0-parseInt(this.offsetHeight/2)); margin-right:0px; margin-bottom:expression(TBWindowMargin=document.documentElement&&document.documentElement.scrollTop||document.body.scrollTop); margin-left:0px;
}
/* FIX ME*/
.price_val{font-size:18px;text-align:center;}
.price_val_hotel{color:#48a200;
font-size:24px; font-weight:normal;}.delim{background-image:url(../images/delim.jpg);background-repeat:no-repeat;background-position:center top;height:30px;}
.price_detail_link a{color:#999;}
.var_num{font-size:24px;color:#38647d;width:30px;}
.map_var{background-color:#4F86A4;color:#FFF;font-weight:700;font-size:8px;padding:0 2px;}
.vendor_wl{background-color:#F5FFF5;}
.selected_flight .var_num{background:#f9b500 url(../images/sr_bg.jpg) -90px top;color:#000;}
#tools{top:0;left:30%;z-index:10;background:#ff8c00;border:2px solid #CCC;text-align:center;font-weight:700;width:auto;position:fixed;opacity:0.95;padding:10px;}
#tools a{color:#FFF;font-size:16px;padding:10px;}
.timetable_search{float:right;width:20%;text-align:right;padding-top:20px;}
.details div{display:inline;}
.bookmark{background:url(../images/star_off.png) no-repeat;width:16px;height:16px;float:right;cursor:pointer;display:none}.selected_flight .bookmark{background:url(../images/star.png);}
.dep,.arr{font-family:verdana;font-weight:700;font-size:11px;}
#sr-search-params{padding:10px;}
#matrix{margin:auto;background-color:#e6e7ec;}
#matrix td,th{border:1px solid #cecece;font-size:12px;padding:7px;}
#matrix td{background:url(../images/sr_fl_bg.png) no-repeat left -40px;}
.active_cell{background-position:left bottom!important;}
#matrix th,#matrix th .active_cell{background-image:url(../images/th_bg.jpg) ;}
.price_num{font-weight:700;}
.nav_links{float:right;width:200px;}
#back_to_search{float:right;}
/*#form_hotel_search .label{margin-top:15px;} */
.hotel{background:#d9dde2 url(../images/sr_htl_bg.png) no-repeat;font-family:Arial, Helvetica, sans-serif;font-size:11px;width:100%;}
.hotel td{vertical-align:top;}
.res_hotel_location{float:right; white-space:nowrap;padding:5px;}
.info_link{margin-left:10px;}
.hname{font-size:14px;font-weight:700;font-family:Verdana;color:#333;}
.star5,.star4,.star3,.star2,.star1{background:url(../images/stars.png);font-size:1px;width:54px;height:10px;float:left;}
.star4{background-position:left -15px;}
.star3{background-position:left -30px;}
#sr-search-params,#sr_toolbar{padding:10px;}
.search_params label{margin:0;}
.cr_out_loc{background:url(../images/arrow-right.gif) 96% 20px no-repeat;padding-right:70px!important;}
.cr_segment{padding-bottom:30px; padding-top:20px;margin-bottom:20px;}
.cr_options .col{width:300px; float:left;}
/*Seatmapping*/
.seatmap div.row_left { background: url(../images/row_left.png) no-repeat right top !important; width:154px!important;color:#FFF; text-align:right;font-size:18px;padding-right:20px;}.seatmap div.row_right { background: url(../images/row_right.png) no-repeat left top !important; width:154px!important;}.seatmap div, .seatmap_legend td { background: url(../images/seatmap.png) no-repeat top left;}
.pass_settings{margin-left: 220px; clear:both;}
.aisle, .row_left, .row_right { background-position: 0 0!important; width: 33px; height: 47px; }
.sel {background-position: -84px -47px!important; cursor:pointer;}
.seatmap div.row_left.wing {background: url(../images/row_left_wing.png) no-repeat right top !important; }.seatmap div.row_right.wing {background: url(../images/row_right_wing.png) no-repeat left top !important; }
#map_segments td.segment, #map_segments td.segment a{font-size:15px;color:#48a200;font-weight:700;}
#map_segments td.inactive_segment, #map_segments td.inactive_segment a{font-size:17px;color:#DDD;font-weight:700;}
.room_lab{font-weight:700;}
.room_lab .room_number{font-size:150%}
.delete_icon{ background: url(../images/cross_small.png) no-repeat; padding-left:20px; margin-right:20px;}.add_icon{ background: url(../images/plus_small.png) no-repeat;padding-left:20px; margin-right:20px;}
.category_table{width: 100%;}
.cmstoolbar_page:hover{height:100px;width:300px;z-index:1005}
.search_form .form-tools .row{padding:0;}
/*SMALL WIDTH
body{background:none;}
.search_form #wrapper{width:520px;}
.search_form #header{height:50px;background:none;margin:0;background-color:#f6f6f6;}
.search_form .navigation{display:none;}
.search_form .logo{display:none;}
.search_form #header .login-box{margin-left:10px}
.search_form .logged_in{display:none;}
.search_form div.box, .search_form .box-bottom{width:520px;}
.search_form .box{width:100%;background:url(../images/520/bg-box.gif);}
.search_form .box .bg-t{width:100%;background:url(../images/520/bg-box-t.gif) no-repeat;}
.search_form .box-bottom{width:100%;overflow:hidden;background:url(../images/520/bg-box-b.gif);margin:0 0 20px;}
.search_form .box-bottom .bg-t{width:100%;overflow:hidden;background:url(../images/520/bg-box-b-t.gif) no-repeat;}
.search_form .box-bottom .bg-b{height:1%;overflow:hidden;background:url(../images/520/bg-box-b-b.gif) no-repeat 0 100%;padding:24px 10px 0 32px;}
.search_form .box .bg-b1,.search_form .box .bg-b{width:100%;background:url(../images/520/bg-box-b1.gif) no-repeat 0 100%;}
.search_form .form-track{width:510px;padding:10px 15px 0;}
.search_form .col-airport, .search_form .city_lookup{width:230px;}
.search_form .location_select .grey, .search_form .location_select .aj_inf{color:#DDD;float:none;}
.search_form .col-airport, .col-city, .search_form .form-track .col-date {padding-right:15px; margin-right:0;}
.search_form .arrows{margin-left:80px}
.search_form .form-track .col-time select, .search_form .select1{width:125px;}
.search_form .cr_out_loc{background:none;padding-right:10px!important;}
.search_form .form-track .row2 label {margin-left:15px;}
.search_form .passenger{white-space:nowrap;position:relative; width:100px;float:left;}
.search_form .form-track .row2 label {margin-left:0;}
.search_form .col2{margin-top:10px;}
.search_form .form-tools .row{padding:0;}
*/
span.img_currency_USD {overflow: hidden; background:url("../images/usd.png") no-repeat 0 5px; margin-left: 3px; vertical-align: middle; letter-spacing: 10px;}span.img_currency_EUR {overflow: hidden; background:url("../images/eur.png") no-repeat 0 5px; margin-left: 3px; vertical-align: middle; letter-spacing: 10px;}span.img_currency_RUB {overflow: hidden; background:url("../images/rub.png") no-repeat 0 5px; margin-left: 3px; vertical-align: middle; letter-spacing: 10px;}
#kkdateTime {
text-align: right; font-weight:bold;
}
.logic_record{margin:4px;}
.ac_loading {
background:url(/templates/pro/images/ajax-loader.gif) no-repeat 100% 0 !important;
}
.login_buttons_div{padding-left:170px}
.big_green_text{color:#48a200;
font-size:24px; font-weight:normal; margin:0 20px 20px 0;}
#div_reg .btn-small-g{
margin-right: 25px;
}
/*
.po_actions{margin-left:10px;padding-left:20px;width:1px;overflow:hidden;margin-top:-15px;background:url(/templates/pro/images/arrow-bottom.gif) no-repeat;height:15px;padding-top:15px overflow:hidden; border:0;}
.po_actions:hover{width:150px!important;min-height:15px;overflow:normal;height:auto; z-index:900; position:absolute; background-color:#ffff80;}
*/
/*.po_date_range{width:370px;}*/
.comment{
color:silver;
}
.row_trip input{vertical-align: top;}
#dropoff_city_from #citiesAndCountry, #dropoff_city_from #list_ref{
margin: 0 0 0 219px;
}
.flag.flag-zm{background-position:-216px -168px;}
.flag.flag-zw{background-position:-234px -168px;}
</stylesyntaxhighlight></prediv></div>
В настройках агентства системы (если доступно) перечислите домены, на которых будет размещена легкая форма.
<span style="background-color:#fff0f5;"><span style="font-size:large;"><span style="color:#ff0000;">!</span></span> {{Attention|Легкая форма работает на сайтах с кодировкой UTF-8.}}
== Сайты-спутники ==
== СайтыАльтернативой функционалу [[Интеграция#Легкая форма на сайт|«Легкая форма поиска»]] является функционал «Сайты-спутники ==спутники».
Альтернативой "Легкой формы"В этом случае, являются "Сайтыесли мини-спутники".Т.е. когда вы хотите разместить мини форму форма поиска размещается на другом домене, с условием, что то пользователь при переходе к результатам поиска, будет оставаться остается на том же домене. Это позволит позволяет видеть статистику поисковых запросов и созданных бронировании бронирований именно с партнерского домена.
[[Файл:IMG_13092012_112049.png]]
Для этого настройки функционала необходимо: 1. Создать компанию-партнер в разделе '''Администрирование''' - '''Пользователи и группы'''. 2. В настройки этой компании-партнера в разделе '''Администрирование''' - '''Настройки агентства''' указать '''Доменное имя сайта для загрузки настроек''' - доменное имя сайта компании-партнера. Это может быть домен второго уровня. А на домене первого уровня - на основном сайте компании-партнера можно разместить "Легкую форму" поиска.
3# Создать компанию-партнер в разделе '''Аккаунт менеджмент → Агенты и пользователи → Управление'''.# В настройки этой компании-партнера в разделе '''Управление сайтом → Домены и протоколы''' указать {{Setting|Доменное имя сайта для загрузки настроек}} — доменное имя сайта компании-партнера. Здесь может быть домен второго уровня. А на домене первого уровня — на основном сайте компании-партнера можно разместить «Легкую форму» поиска. # Также необходимо выполнить [[Привязка к доменному имени агентства|привязку сайта к доменному имени агентства [http://support]].mute-lab.com/ru/%D0%92%D0%B5%D0%B1-%D1%81%D0%B0%D0%B9%D1%82#.D0.9F.D1.80.D0.B8.D0.B2.D1.8F.D0.B7.D0.BA.D0.B0_.D1.81.D0.B0.D0.B9.D1.82.D0.B0_.D0.B2_Nemo_.D0.BA_.D0.B4.D0.BE.D0.BC.D0.B5.D0.BD.D0.BD.D0.BE.D0.BC.D1.83_.D0.B8.D0.BC.D0.B5.D0.BD.D0.B8_.D0.B0.D0.B3.D0.B5.D0.BD.D1.82.D1.81.D1.82.D0.B2.D0.B0] 4. Стили основного сайта на сайт компании-партнера не распространяются. Их можно прописать отдельно в разделе '''Администрирование''' - '''Управление сайтом → Настройки внешнего вида'''.
== Фиксация оплаты внешним запросом ==
Сервис предназначен для приема информации о получении оплаты и простановки статуса '''«Оплачено»''' для определенного заказа.
Сервис вызывается следующим образом: [http://hostnameCLIENT_DOMAIN/index.php?go=payment/bill http://hostname/index.php?go=payment/bill]
'''Допустимые Get-параметры:''' === Подпись запроса ===
Подпись sig сверяется c <table bordersyntaxhighlight lang="text" enclose="1none"> <tr bgcolorstyle="font-size: 1.2em; padding: 0 3px; background: #ccccccF0F0F0; border: 1px dashed #2F6FAB;"> <th>Параметр</th><th>значение</th> md5($booking_id.$secret)</trsyntaxhighlight>, где: <tr> <td>locator</td><td>номер * $booking_id — Id заказа в системе поставщика</td>{{NameSystem}}; </tr>* $secret — значение настройки {{Setting|Ключ безопасности для сервиса выставления оплаты и получения XML выгрузки}} в разделе '''Управление сайтом → Домены и протоколы'''.
<tr> <td>type</td><td>тип оплачиваемой услуги</td> </tr> <tr> <td>billing_id</td><td>номер платежной транзакции</td> </tr> <tr>=== Пример ===
<td>booking_id</td><td>номер заказа (бронирования) в системе Nemo</td> </trpre> <tr> <td>user_id</td><td>ID пользователя</td> </tr> <tr> <td>sig</td><td>подпись запроса</td>Если
</tr></table> '''Type''' может принимать следующие значения:  <table border="1"> <tr bgcolor="#cccccc"> <th class="col0">Значение</th><th class="col1">Описание</th> </tr>  <tr class="row1"> <td class="col0">FLIGHTS</td><td class="col1">авиабилет</td> </tr> <tr class="row2"> <td class="col0">HOTELS</td><td class="col1">отель </td> </tr> <tr class="row3">  <td class="col0">APARTMENTS</td><td class="col1">апартаменты</td> </tr> <tr class="row4"> <td class="col0">TRANSFERS</td><td class="col1"> трансфер</td> </tr> <tr class="row5">  <td class="col0">TOURS</td><td class="col1"> экскурсия</td> </tr> <tr class="row6"> <td class="col0">TOURPACK</td><td class="col1"> пакетный тур</td> </tr> <tr class="row7">  <td class="col0">DYNAPACK</td><td class="col1"> динамический пакет</td> </tr> <tr class="row8"> <td class="col0">INSURANCE</td><td class="col1"> страховка</td> </tr> <tr class="row9">  <td class="col0">TRAINS</td><td class="col1"> ж/д билет</td> </tr></table> '''Подпись запроса''' Подпись sig сверяется c md5($locator.$type.$booking_id.$billing_id.$user_id.$secret) Если какие-то из альтернативных параметров не заданы, то они не влияют на подпись. $secret - значение настройки в разделе '''Администрирование → Настройки агентства → Ключ безопасности для сервиса выставления оплаты и получения XML выгрузки''' '''Внешний шлюз''' Данный способ оплаты предназначен для создания объектов биллинга.  Для создания billing_id необходимо: 1. На странице с информацией о заказе нажать кнопку '''«Оплатить»'''.<br>2. Выбрать в качестве способа оплаты '''«Внешний шлюз»'''.  Созданный параметр можно использовать для фиксации оплаты при помощи внешнего запроса, принцип работы которого описан выше. Использовать «Внешний шлюз» как самостоятельный способ оплаты невозможно. Чтобы сделать фиксацию без выбора способа оплаты надо в ссылке на фиксацию оплаты вместо billing_id указать параметр ext_id с кодом оплаты во внешней системе. В подпись этот параметр вставляется перед $secret: <pre>md5($locator.$type.$booking_id.$user_id.$ext_id.$secret)</pre> == Получение информации о бронировании == Сторонний скрипт может запросить информацию в формате XML по совершенному в системе Nemo бронировании. Сервис вызывается по следующему URL: [http://hostname/index.php?go=booking/pnr_export_xml http://hostname/index.php?go=booking/pnr_export_xml] '''Возможные GET-параметры:'''  <table border="1">  <tr bgcolor="#cccccc"> <th>переменная</th><th>значение</th> </tr> <tr> <td>booking_id</td><td>номер бронирования в системе Nemo</td> </tr> <tr>  <td>locator</td><td>номер бронирования в системе поставщика</td> </tr> <tr> <td>type</td><td>тип услуги</td> </tr> <tr> <td>user_id</td><td> идентификатор менеджера агентства </td>  </tr> <tr> <td>sig </td><td>подпись запроса</td> </tr></table> '''Type''' может принимать следующие значения:263330 <table border="1"> <tr bgcolor="#cccccc"> <th>Значение</th><th>Описание</th> </tr> <tr> <td>FLIGHTS</td><td>авиабилет</td> </tr>  <tr> <td>HOTELS</td><td>отель </td> </tr> <tr> <td>APARTMENTS</td><td>апартаменты</td> </tr> <tr>  <td>TRANSFERS</td><td> трансфер</td> </tr> <tr> <td>TOURS</td><td> экскурсия</td> </tr> <tr>  <td>TOURPACK</td><td> пакетный тур</td> </tr> <tr> <td>DYNAPACK</td><td> динамический пакет</td> </tr> <tr>  <td>INSURANCE</td><td> страховка</td> </tr> <tr> <td>TRAINS</td><td> ж/д билет</td> </tr></table> В запросе должны обязательно присутствовать или '''booking_id''', '''user_id''' и '''sig''' или '''locator''', '''type''', '''user_id''' и '''sig'''. '''Подпись запроса''' Подпись sig сверяется c md5($locator.$type.$booking_id.$user_id.$secret) где KEY - значение настройки в разделе '''Администрирование → Настройки агентства → Ключ безопасности для сервиса выставления оплаты и получения XML выгрузки'''. '''Пример:''' <pre>Если Ключ ключ безопасности: 33333333UserID: 7536Locator: J89RWT12345
То
sig=md5(J89RWTFLIGHTS75363333333326333012345) = 81bff1e4257435466a3245bf1040ed8ea439a4492131f4b866ed1a17d018d3a6</pre>
Для получения данных о брони фиксации оплаты получается такая ссылка:
[<pre>http://hostnameCLIENT_DOMAIN/index.php?go=bookingpayment/pnr_export_xmlbill&locatorbooking_id=J89RWT&type=FLIGHTS&user_id=7536263330&sig=81bff1e4257435466a3245bf1040ed8e http://hostname/index.php?go=bookinga439a4492131f4b866ed1a17d018d3a6</pnr_export_xml&locator=J89RWT&type=FLIGHTS&user_id=7536&sig=81bff1e4257435466a3245bf1040ed8e]pre>
'''Пример выдачи:'''== FastSearch — передача параметров в форму ==
<pre>-<PNR> -<Common> <id>31394</id> <Type>FLIGHTS</Type> <Service>GALILEO</Service> <Locator>TTJF5Q</Locator> <BeginDateTime>2012.01.27-17:55</BeginDateTime> <EndDateTime>2012.01.27-20:30</EndDateTime> -<TotalPrice> <Amount>5604</Amount> <CurrencyCode>RUB</CurrencyCode> </TotalPrice> <UserId>31875</UserId> <EEUserId>23131</EEUserId> <UserLogin>makasy</UserLogin> <GroupId>31874</GroupId> <UserStatus>Менеджер</UserStatus> <DateCreate>2011.11.29-14:32</DateCreate> </Common> -<Payment> <Title>Инвойс</Title> <Method>Gateline</Method> <BillingId>6688</BillingId> <CreateDate>2011-11-30 13:59:23</CreateDate> <Status>booked</Status> <PenaltyDate></PenaltyDate> <Timelimit>2011-12-01 14:40:02</Timelimit> -<Charge> <Amount>100</Amount> <CurrencyCode>RUB</CurrencyCode> </Charge> -<Book> <Amount>183.9712</Amount> <CurrencyCode>USD</CurrencyCode> -</Book> -<Penalty> <Amount>0</Amount> <CurrencyCode>RUB</CurrencyCode> </Penalty> -<Total> <Amount>5604</Amount> <CurrencyCode>RUB</CurrencyCode> </Total> -<Commission> <Amount>0</Amount> <CurrencyCode>RUB</CurrencyCode> </Commission> </Payment> -<Client> <LastName>RTVCVBVCB</LastName> <Name>TTVCBVCVB</Name> <MiddleName>отчество</MiddleName> <SerialNumber>1234</SerialNumber> <Number>567891</Number> <Birth></Birth> <Email>makasy15@gmail.com</Email> <Phone>+79878262130</Phone> </Client> <PassengersCount>1</PassengersCount> -<Passengers> -<Passenger> <nationality>RU</nationality> <passenger_type>ADT</passenger_type> <lastname>RTVCVBVCB</lastname> <name>TTVCBVCVB</name> <passport_series></passport_series> <passport_number>1234567891</passport_number> <date_of_birth>26.11.1981</date_of_birth> <currency_of_passport>17.05.2012</currency_of_passport> -<phone> <country></country> <city></city> <number>+79878262130</number> <expansion></expansion> </phone> <doc_type>P</doc_type> <middlename></middlename> <passenger_id></passenger_id> <gender>M</gender> <meal>NONE</meal> </Passenger> </Passengers> <FlightType>Международный</FlightType> -<OrderInfo> -<Info> <Company>Эйр Берлин</Company> <CompanyCode>AB</CompanyCode> <StartDate>2012.01.27</StartDate> <StartTime>17:55</StartTime> <StartDayOfWeek>Friday</StartDayOfWeek> <FlightNumber>8353 (AB8353)</FlightNumber> <StartAirportCode>DME</StartAirportCode> <StartAirportName>Домодедово (Москва)</StartAirportName> <StartCountry>Россия</StartCountry> <StartCountryCode>RU</StartCountryCode> <EndAirportCode>TXL</EndAirportCode> <EndAirportName>Тегэль (Берлин)</EndAirportName> <EndCountry>Германия</EndCountry> <EndCountryCode>DE</EndCountryCode> <Time>2:55</Time> -<Equip> <Name>Эрбас 320</Name> <Type>320</Type> </Equip> <ClassType>economy</ClassType> <ClassTypeCode>P</ClassTypeCode> <Meal>S</Meal> </Info> -<Info> <Company>Эйр Берлин</Company> <CompanyCode>AB</CompanyCode> <StartDate>2012.01.27</StartDate> <StartTime>18:45</StartTime> <StartDayOfWeek>Friday</StartDayOfWeek> <FlightNumber>8156 (AB8156)</FlightNumber> <StartAirportCode>TXL</StartAirportCode> <StartAirportName>Тегэль (Берлин)</StartAirportName> <StartCountry>Германия</StartCountry> <StartCountryCode>DE</StartCountryCode> <EndAirportCode>ORY</EndAirportCode> <EndAirportName>Париж, Орли</EndAirportName> <EndCountry>Франция</EndCountry> <EndCountryCode>FR</EndCountryCode> <Time>1:45</Time> -<Equip> <Name>Эрбас 320</Name> <Type>320</Type> </Equip> <ClassType>economy</ClassType> <ClassTypeCode>Q</ClassTypeCode> <Meal>S</Meal> </Info> </OrderInfo> </PNR></pre> == FastSearch - передача параметров в форму == В системе Nemo {{NameSystem}} имеется возможность перенаправлять пользователей на страницу с уже заполненными параметрами поиска или сразу напрямую на результаты поиска.
Эта технология может использоваться, к примеру, для формирования ссылок с баннеров, при клике на которые [[пользователь]] попадает на форму, в которой уже могут быть заполнены пункты назначения, даты, количество пассажиров и прочие параметры.
Также при указании всех необходимых параметров пользователя можно перебрасывать сразу на процесс поиска авиабилетов с указанными критериями.
Для использования заполнения формы из URL следует включить опцию: '''Администрирование → Настройки агентства → '''{{Setting|Включить FastSearch (передачу параметров поиска)}} в разделе '''Управление сайтом → Домены и протоколы'''.
После этого можно использовать ссылки на форму поиска вида:
<pre>http://DOMAIN/?trip_type=OW&out_iata=MOW&in_iata=BER&departure_date=21.10.2009&adults=1&children=0&input_vendors=SU,PS&param_by_get=on</pre>
'''Имена полей''' - такие же как имена инпутов на поисковой форме.
Если вы указываете все необходимые для поиска параметры, то для того чтобы отправить пользователя сразу на результаты поиска нужно указать непустой параметр fast_search. Например, &fast_search=true.
<span style="background-color:#fff0f5;"><span style="color:#ff0000;"><span style="font-size:large;">!</span></span> Данный функционал доступен только Подробная информация о данном функционале для компонента "Авиа".</span>отелей находится по ссылке [[Fast Search для отелей]]
== Интеграция со Сторонней системой - Авторизация==
В Немо {{NameSystem}} существует возможность авторизоваться в системе менеджерам агентства и субагентам, прежде не работавшим в системе, при помощи интеграции со Сторонней системой (СС).
Настраивается данный функционал в разделе: «Администрирование» - «Реквизиты подключения»'''Для техподдержки → Устаревшие настройки → Реквизиты подключения''', где логин и пароль используется для доступа к системе.
[[Файл:Shema avtopizacii.png]]
== Пример: Интеграция с Eagle Eye - авторизация ==
'''Процесс авторизации:'''
# Пользователь на странице авторизации в системе {{NameSystem}} вводит Логин и Пароль, которые отправляются в СС для авторизации.
'''Процесс Сценарий успешной авторизации:'''# Если авторизация пользователя в СС прошла успешно, то идёт проверка, есть ли в базе данных пользователей {{NameSystem}} пользователь с таким ID.# Если такой пользователь существует в базе {{NameSystem}}, то данные о пользователе и агентстве обновляются, исходя из информации, содержащейся в ответе на авторизацию.Обновляется логин и пароль.# Логин пользователя {{NameSystem}} может быть обновлен на актуальный.# Если в {{NameSystem}} отсутствует пользователь с данным ID — то происходит добавление пользователя.
1'''Сценарий неуспешной авторизации:'''# Если авторизация в СС прошла не успешно, то система {{NameSystem}} проверяет, существует ли в СС ID для пользователя с запрашиваемым логином. Пользователь на странице # Если в СС пользователь с ID был сохранен, значит данный пользователь выключен в системе СС, пользователю будет отказано в авторизации .# Если в СС пользователь с данным ID отсутствует, то данного пользователя нет в системе Немо вводит Логин СС и Пароль, которые отправляются если шаг 1 был успешным, то он авторизуется в СС для {{NameSystem}} как при обычной авторизации{{NameSystem}}.
'''Сценарий успешной авторизации''' 1. Если авторизация пользователя в СС прошла успешно, то идёт проверка, есть ли в базе данных пользователей Немо пользователь с таким ID. 2. Если такой пользователь существует в базе Немо, то данные о пользователе и агентстве обновляются, исходя из информации, содержащейся в ответе на авторизацию.Обновляется логин и пароль. 3. Идёт проверка в Немо, изменился ли логин для пользователя с данным ID. 4. Если в Немо отсутствует пользователь с данным ID - то происходит добавление пользователя. '''Сценарий неуспешной авторизации''' 1. Если авторизация в СС прошла не успешно, то система Немо проверяет, существует ли в СС ID для пользователя с запрашиваемым логином. 2. Если в СС пользователь с ID был сохранен, значит данный пользователь выключен в системе СС, пользователю будет отказано в авторизации. 3. Если в СС пользователь с данным ID отсутствует, то данного пользователя нет в системе СС и, если шаг 1 был успешным, то он авторизуется в Немо как при обычной авторизации Немо. <span style="background-color:#fff0f5;"><span style="font-size:large;"><span style="color:#ff0000;">!</span></span> {{Attention|Если в системе пытается авторизоваться субагент агентства, которое ещё не создано в системе, то в регистрации ему будет отказано, т.к. родительское агентство отсутствует. <span style="background-color:#fff0f5;"><span style="color:#ff0000;"><span style="font-size:large;">!</span></span> Когда логины пользователей совпадают, то в этом случае к логину добавляется id агентства. Например: test2431</span>}}
== Синхронизация данных о пользователях и компаниях ==
Назначение данного модуля — обеспечение взаимодействия между сторонней программой (например, «САМО-тур») и системой Nemo {{NameSystem}} в части синхронизации списка B2B-пользователей.
Модуль является компонентом, включаемым/отключаемым из административной части.
'''=== Авторизация'''===
Все B2B-пользователи, загруженные через модуль взаимодействия со сторонней программой, будут иметь случайным образом сгенерированный криптостойкий пароль. Механизм авторизации работает следующим образом:
 1. # Система пытается авторизовать пользователя через собственную службу авторизации.<br>2. # В случае неудачи, но присутствия в системе введенного логина, она должна попытаться авторизовать пользователя во внешней службе авторизации («САМО-тур»), при включенном компоненте взаимодействия с «САМО-тур».<br>3. # В случае неудачного опознавания пользователя выводится соответствующее сообщение и процедура может быть повторена путем повторного ввода логина и пароля.
Регистрация неудачных попыток входа производится только в двух случаях:
*Компонент взаимодействия выключен.*Компонент взаимодействия включен и провалены обе попытки авторизации (внутренней и внешней).
Для сторонней авторизации пользователей в системе Nemo {{NameSystem}} сторонняя программа должна иметь веб-службу, основанную на WSDL определенного формата. Ссылка на веб-службу прописывается в настройках системы Nemo {{NameSystem}} на странице конфигурации интеграции с внешней системой.
Для импортированных пользователей в Nemo {{NameSystem}} имеется поле '''«Идентификатор внешней системы»''', который отвечает за сопоставление с ID пользователя в сторонней системе. Для менеджеров агентств оно равно номеру партнера (агента) во внешней системе, для пользователей — номеру пользователя в «САМО-туре».
Для пользователей, имеющих какое-либо значение в поле '''«Идентификатор во внешней системе»''', запрещен функционал смены пароля или его восстановления по электронной почте.
'''=== Пример запросов и ответов на авторизацию:'''===
<pre><?xml version="1.0" encoding="utf-8"?>
Сервис реализует функцию «getAuthorization», на вход которой передается конструкция «getAuthorizationRequest»:
*login (строка) - введенный пользователем логин*pass (строка) - введенный пользователем пароль
Функция должна отдавать системе конструкцию getAuthorizationResponse:
*session_id (строка) - пустое значение*user_id (строка) - идентификатор менеджера в системе «САМО-тур»*login (строка) - логин пользователя (для контроля)*status (строка) - может иметь значения:** oadm - администратор** omgr - менеджер** ousr - пользователь (возвращается всегда это значение)
'''=== Импорт\синхронизация учетных записей'''===
Со стороны внешней системы должно быть приложение, отправляющее в формате XML данные по учетным записям B2B-клиентов (агентств и пользователей). Со стороны Nemo {{NameSystem}} имеется скрипт, который принимает XML в формате, приведенном в описании документов, передаваемых в Nemo {{NameSystem}} с ключом авторизации, определенным в Nemo {{NameSystem}} в административной части модуля.
Передаваемые элементы с описанием учетных записей и партнеров имеют аккаунт (Account ID) во внешней системе и атрибут action, который может быть в состоянии update или delete, т.е. обновления/добавления и удаления соответственно.
В административной части модуля в Nemo {{NameSystem}} задается ключ авторизации для защиты от несанкционированного доступа. Значение не должно быть пустым.
Скрипт получает данные об обновлении, добавлении (проходят как одно и то же действие) или удалении информации по аккаунту. XML-данные могут содержать несколько элементов, например:
<item id=9 partnerId=30 action="delete" />
</accounts>
<partners> - список изменений по партнерам
<item id=140 action="update">
<name>Название агентства</name>
При импорте информации об '''Агентствах''' будут возвращаться следующие значения:
<table {| collspadding="10" border="1"> <tr bgcolorclass="#ccccccwikitable"> <th>! Поле во внешней системе </th><th> !! Путь к элементу xml </th><th> !! Тип данных </th><th> !! Сопоставляемое поле в Nemo </th><th> {{NameSystem}} !! Примечание </th>|- </tr> <tr> <td>| Идентификатор партнера</td><td>| /changes/partners/item[@id]</td><td>| Целое число </td><td>| Идентификатор во внешней системе для менеджера / администратора </td><td></td> </tr>| <tr>|- <td>| Название юридического лица</td><td>| /changes/partners/item/ofname</td><td>| Строка</td><td>| Полное официальное название юридического лица </td><td>| Необходимо для выписки счетов юридическими лицами</td>|- </tr> <tr> <td>| Сокращенное название</td><td>| /changes/partners/item/name</td><td>| Строка</td><td>| Имя агентства </td><td></td> </tr>| <tr>|- <td>| Код агентства</td><td>| /changes/partners/item/code</td><td>| Строка</td><td>| Используется при создании логина администратора</td><td></td>| </tr> <tr>|- <td>| Номер группы в самотуре</td><td>| /changes/partners/item/group</td><td>| Целое число, либо пусто</td><td>| На основании таблицы сопоставлений (см. ниже) определяется, к какой группе агентство принадлежит в Nemo </td><td></td>{{NameSystem}} </tr>| <tr class="row6">|- <td>| Форма налогообложения</td><td class="col1">| /changes/partners/item/tax</td><td>| Целое число, равное идентификатору во внешней системе</td><td class="col3"></td><td></td>| </tr>| </table> Для каждого возвращенного агентства Nemo проверяет наличие его в своей базе. Если [[агентство]] не найдено, то создается новое. Для него создается менеджер (админ) с логином ABCD-1234, где ABCD – буквенный идентификатор партнера во внешней системе, 1234 — id партнера во внешней системе. Пароль — генерируется случайный и криптостойкий. Если агентство найдено, то в случае необходимости производится обновление всех полей на основании данных из внешней системы. Если изменился код агентства (буквенный), то Nemo переименовывает менеджера в соответствии с новым кодом. При импорте информации о пользователях агентств в Nemo будут посылаться следующие поля: |}
Для каждого возвращенного агентства {{NameSystem}} проверяет наличие его в своей базе. Если [[агентство]] не найдено, то создается новое. Для него создается менеджер (админ) с логином <table bordersyntaxhighlight lang="text" enclose="none" style="font-size: 1.2em; padding: 0 3px; background: #F0F0F0; border: 1px dashed #2F6FAB;"> ABCD-1234<tr bgcolor/syntaxhighlight>, где <syntaxhighlight lang="text" enclose="none" style="font-size: 1.2em; padding: 0 3px; background: #F0F0F0; border: 1px dashed #cccccc2F6FAB;"> ABCD<th/syntaxhighlight>Поле – буквенный идентификатор партнера во внешней системе, </thsyntaxhighlight lang="text" enclose="none" style="font-size: 1.2em; padding: 0 3px; background: #F0F0F0; border: 1px dashed #2F6FAB;"><th>Путь к элементу xml1234</th><th>Тип данных</th><th>Сопоставляемое поле в Nemo</th><th>Примечание</thsyntaxhighlight>— id партнера во внешней системе. Пароль — генерируется случайный и криптостойкий.
</tr> <tr> <td>Идентификатор пользователя</td><td>/changes/accounts/item[@id]</td><td>Целое число</td><td>Идентификатор внешней системы</td><td>Храним как дополнительное поле </td> </tr> <tr> <td>Идентификатор партнера</td><td class="col1">/changes/accounts/item[@partnerId]</td><td>Целое число</td><td>Идентификатор Если агентство найдено, то в случае необходимости производится обновление всех полей на основании данных из внешней системы . Если изменился код агентства (буквенный), то {{NameSystem}} переименовывает менеджера агентства</td><td></td>в соответствии с новым кодом. При импорте информации о пользователях агентств в {{NameSystem}} будут посылаться следующие поля:
<{| collspadding="10" border="1" class="wikitable"! Поле во внешней системе !! Путь к элементу xml !! Тип данных !! Сопоставляемое поле в {{NameSystem}} !! Примечание|-| Идентификатор партнера| /changes/tr>partners/item[@id] <tr>| Целое число <td>| Идентификатор внешней системы| Храним как дополнительное поле|-| Идентификатор партнера| /changes/accounts/item[@partnerId]| Целое число| Идентификатор внешней системы менеджера агентства| |-| Логин</td><td>| /changes/accounts/item/login</td><td>| Строка</td><td>| Логин пользователя</td><td class="col4"></td> </tr>| <tr>|- <td>| Администратор</td><td>| /changes/accounts/item[@admin]</td><td>| 0 - нет, 1 - да</td><td>| Эксперт по бронированию </td><td></td>| |}
</tr></table>Для каждого возвращенного пользователя {{NameSystem}} проверяет наличие его в своей базе. Если пользователь не найден, то создается новый. Пароль генерируется случайный и криптостойкий.
Для каждого возвращенного пользователя Nemo проверяет наличие его в своей базе. Если пользователь не найден, то создается новый. Пароль генерируется случайный и криптостойкий.  Если пользователь найден, то в случае необходимости производится обновление всех полей на основании данных из внешней системы. При запросе на удаление пользователя, в Nemo {{NameSystem}} указанный логин удаляться не будет в целях сохранения целостности старых данных, а просто помечается как удаленный, и логин переименовывается и становится вида <syntaxhighlight lang="text" enclose="none" style="font-size: 1.2em; padding: 0 3px; background: #F0F0F0; border: 1px dashed #2F6FAB;">[логин_пользователя]_X_[числовой идентификатор_пользователя в Само]</syntaxhighlight>.
<pre><item id=[идентификатор] action="delete" /></pre>
'''=== Таблица сопоставлений групп'''===
В административной части Nemo {{NameSystem}} надо создать отдельную страницу, на которой можно сопоставить имеющиеся группы в Nemo {{NameSystem}} номерам групп в САМО-тур (поле group в XML). Выводится список существующих групп для текущего (корневого) агентства.
== См. также ==
*[[Пользователь]]<br>*[[Авторизованный пользователь]]<br>*[[Авторизация пользователей из внешних систем]]<br>*[[Пароль]]<br>*[[Агентство]]<br>*[[Веб-сайт]]<br>*[[ПНРPassenger Name Record (PNR)]]<br>*[[Бронирование]]<br>*[[Войдирование]] [[Category:Функции]]<br/>[[Category:Интеграция]]

Навигация

'