Commit 71e682f728086c7492c44f6897521b8044bdabff

Authored by Anchit Jindal
Exists in master

Merge branch 'master' of http://git.viithiisys.com/viithiisys/acufuel

app/css/custom.css
... ... @@ -390,8 +390,207 @@ font-size: 10px !important;
390 390 float: left;
391 391 }
392 392 .appliesTableBody > div.lastDiv textarea{
393   - width: 100%;
  393 + width: 40%;
394 394 height: 60px;
395 395 margin: 15px 0;
396 396 resize: none;
  397 + float: left;
  398 +}
  399 +.reportedByTag{
  400 + width: 60%;
  401 + height: 80px;
  402 + border-top: 10px solid #393;
  403 + border-left: 10px solid #6c6;
  404 + border-radius: 5px 0 0 5px;
  405 + background-color: #d7d7d7;
  406 + float: right;
  407 + position: relative;
  408 + right: -13px;
  409 + margin-top: 5px;
  410 + font-size: 11px;
  411 +}
  412 +.confirmedTag{
  413 + background-color: #393;
  414 + color: #fff;
  415 + -webkit-transform: rotate(-90deg);
  416 + -moz-transform: rotate(-90deg);
  417 + -o-transform: rotate(-90deg);
  418 + -ms-transform: rotate(-90deg);
  419 + transform: rotate(-90deg);
  420 + position: absolute;
  421 + bottom: 25px;
  422 + left: -24px;
  423 + width: 71px;
  424 + text-align: center;
  425 + font-size: 11px;
  426 +}
  427 +.reportedByTag table{
  428 + margin-left: 27px;
  429 + width: calc(100% - 27px);
  430 +}
  431 +.reportedByTag table td{
  432 + font-size: 11px;
  433 + text-align: center;
  434 + font-weight: bold;
  435 +}
  436 +.reportedByTag table tr:last-child td{
  437 + text-align: left;
  438 + font-weight: normal;
  439 + font-size: 10px;
  440 +}
  441 +.feeManagerRight{
  442 + min-height: 70px;
  443 + position: relative;
  444 +}
  445 +.feeManagerRight div{
  446 + position: absolute;
  447 + bottom: 0;
  448 + width: 100%;
  449 +}
  450 +.new-tab-body-td{
  451 + padding: 5px 0;
  452 +}
  453 +
  454 +/* new checkbox slide css */
  455 +
  456 +.onoffswitch {
  457 + position: relative; width: 80px;
  458 + -webkit-user-select:none;
  459 + -moz-user-select:none;
  460 + -ms-user-select: none;
  461 + margin: auto;
  462 +}
  463 +.onoffswitch-checkbox {
  464 + display: none;
  465 +}
  466 +.onoffswitch-label {
  467 + display: block;
  468 + overflow: hidden;
  469 + cursor: pointer;
  470 + border: 2px solid #999999;
  471 + border-radius: 0px;
  472 +}
  473 +.onoffswitch-inner {
  474 + display: block;
  475 + width: 200%;
  476 + margin-left: -100%;
  477 + transition: margin 0.3s ease-in 0s;
  478 +}
  479 +.onoffswitch-inner:before, .onoffswitch-inner:after {
  480 + display: block;
  481 + float: left;
  482 + width: 50%;
  483 + height: 18px;
  484 + padding: 0;
  485 + line-height: 18px;
  486 + font-size: 10px;
  487 + color: white;
  488 + font-family: Trebuchet, Arial, sans-serif;
  489 + font-weight: bold;
  490 + box-sizing: border-box;
  491 +}
  492 +.onoffswitch-inner:before {
  493 + content: "Include";
  494 + padding-left: 5px;
  495 + background-color: #016ADB; color: #FFFFFF;
  496 + text-align: left;
  497 +}
  498 +.onoffswitch-inner:after {
  499 + content: "Exclude";
  500 + padding-right: 5px;
  501 + background-color: ; color: #333333;
  502 + text-align: right;
  503 +}
  504 +.onoffswitch-switch {
  505 + display: block;
  506 + width: 25px;
  507 + margin: -3.5px;
  508 + background: #FFFFFF;
  509 + position: absolute;
  510 + top: 0;
  511 + bottom: 0;
  512 + right: 58px;
  513 + border: 2px solid #999999;
  514 + border-radius: 0px;
  515 + transition: all 0.3s ease-in 0s;
  516 +}
  517 +.onoffswitch-switch i{
  518 + line-height: 25px;
  519 +}
  520 +.onoffswitch-checkbox:checked + .onoffswitch-label .onoffswitch-inner {
  521 + margin-left: 0;
  522 +}
  523 +.onoffswitch-checkbox:checked + .onoffswitch-label .onoffswitch-switch {
  524 + right: 0px;
  525 +}
  526 +.onoffswitch-checkbox fa-check{
  527 + color: #00ff00;
  528 +}
  529 +.onoffswitch-checkbox fa-times{
  530 + color: #ff0000;
  531 +}
  532 +
  533 +.newButtons{
  534 + background-color: #fff;
  535 + border-radius: 10px;
  536 + color: #333;
  537 + border: 1px solid #eee;
  538 + box-shadow: 5px 5px 6px rgba(0,0,0,0.3);
  539 + padding: 6px 15px;
  540 + margin-right: 10px;
  541 +}
  542 +.newButtons:disabled{
  543 + background-color: #eee;
  544 +}
  545 +*{
  546 + outline: none;
  547 +}
  548 +
  549 +
  550 +/* my custom modal */
  551 +
  552 +.customBackdrop{
  553 + position: fixed;
  554 + background-color: rgba(0, 0, 0, 0.15);
  555 + top: 0;
  556 + left: 0;
  557 + width: 100%;
  558 + height: 100%;
  559 + z-index: 999;
  560 +}
  561 +.customModalInner{
  562 + width: 100%;
  563 + max-width: 500px;
  564 + height: 200px;
  565 + top: 15%;
  566 + position: relative;
  567 + margin: auto;
  568 +}
  569 +.customModelHead, .customModelFooter{
  570 + width: 100%;
  571 + background-color: #fafafa;
  572 + border-bottom: 1px solid #ccc;
  573 + color: #333;
  574 + padding: 10px;
  575 +}
  576 +.customModelFooter{
  577 + border-top: 1px solid #ccc;
  578 +}
  579 +.customModelBody{
  580 + width: 100%;
  581 + height: auto;
  582 + background-color: #fff;
  583 + color: #333;
  584 + padding: 10px;
  585 +}
  586 +.customModelHead p{
  587 + margin-bottom: 0;
  588 + font-size: 14px;
  589 +}
  590 +.customModelFooter button{
  591 + border: 1px solid #ccc;
  592 +}
  593 +.customModelFooter input[type="submit"]{
  594 + background-color: #6ad46a;
  595 + border: 1px solid #ccc;
397 596 }
398 597 \ No newline at end of file
... ...
app/css/datepicker3.css
... ... @@ -0,0 +1,789 @@
  1 +/*!
  2 + * Datepicker for Bootstrap
  3 + *
  4 + * Copyright 2012 Stefan Petre
  5 + * Improvements by Andrew Rowls
  6 + * Licensed under the Apache License v2.0
  7 + * http://www.apache.org/licenses/LICENSE-2.0
  8 + *
  9 + */
  10 +.datepicker {
  11 + padding: 4px;
  12 + border-radius: 4px;
  13 + direction: ltr;
  14 + /*.dow {
  15 + border-top: 1px solid #ddd !important;
  16 + }*/
  17 +}
  18 +.datepicker-inline {
  19 + width: 220px;
  20 +}
  21 +.datepicker.datepicker-rtl {
  22 + direction: rtl;
  23 +}
  24 +.datepicker.datepicker-rtl table tr td span {
  25 + float: right;
  26 +}
  27 +.datepicker-dropdown {
  28 + top: 0;
  29 + left: 0;
  30 +}
  31 +.datepicker-dropdown:before {
  32 + content: '';
  33 + display: inline-block;
  34 + border-left: 7px solid transparent;
  35 + border-right: 7px solid transparent;
  36 + border-bottom: 7px solid #ccc;
  37 + border-top: 0;
  38 + border-bottom-color: rgba(0, 0, 0, 0.2);
  39 + position: absolute;
  40 +}
  41 +.datepicker-dropdown:after {
  42 + content: '';
  43 + display: inline-block;
  44 + border-left: 6px solid transparent;
  45 + border-right: 6px solid transparent;
  46 + border-bottom: 6px solid #fff;
  47 + border-top: 0;
  48 + position: absolute;
  49 +}
  50 +.datepicker-dropdown.datepicker-orient-left:before {
  51 + left: 6px;
  52 +}
  53 +.datepicker-dropdown.datepicker-orient-left:after {
  54 + left: 7px;
  55 +}
  56 +.datepicker-dropdown.datepicker-orient-right:before {
  57 + right: 6px;
  58 +}
  59 +.datepicker-dropdown.datepicker-orient-right:after {
  60 + right: 7px;
  61 +}
  62 +.datepicker-dropdown.datepicker-orient-top:before {
  63 + top: -7px;
  64 +}
  65 +.datepicker-dropdown.datepicker-orient-top:after {
  66 + top: -6px;
  67 +}
  68 +.datepicker-dropdown.datepicker-orient-bottom:before {
  69 + bottom: -7px;
  70 + border-bottom: 0;
  71 + border-top: 7px solid #999;
  72 +}
  73 +.datepicker-dropdown.datepicker-orient-bottom:after {
  74 + bottom: -6px;
  75 + border-bottom: 0;
  76 + border-top: 6px solid #fff;
  77 +}
  78 +.datepicker > div {
  79 + display: none;
  80 +}
  81 +.datepicker.days div.datepicker-days {
  82 + display: block;
  83 +}
  84 +.datepicker.months div.datepicker-months {
  85 + display: block;
  86 +}
  87 +.datepicker.years div.datepicker-years {
  88 + display: block;
  89 +}
  90 +.datepicker table {
  91 + margin: 0;
  92 + -webkit-touch-callout: none;
  93 + -webkit-user-select: none;
  94 + -khtml-user-select: none;
  95 + -moz-user-select: none;
  96 + -ms-user-select: none;
  97 + user-select: none;
  98 +}
  99 +.datepicker table tr td,
  100 +.datepicker table tr th {
  101 + text-align: center;
  102 + width: 30px;
  103 + height: 30px;
  104 + border-radius: 4px;
  105 + border: none;
  106 +}
  107 +.table-striped .datepicker table tr td,
  108 +.table-striped .datepicker table tr th {
  109 + background-color: transparent;
  110 +}
  111 +.datepicker table tr td.day:hover,
  112 +.datepicker table tr td.day.focused {
  113 + background: #eeeeee;
  114 + cursor: pointer;
  115 +}
  116 +.datepicker table tr td.old,
  117 +.datepicker table tr td.new {
  118 + color: #999999;
  119 +}
  120 +.datepicker table tr td.disabled,
  121 +.datepicker table tr td.disabled:hover {
  122 + background: none;
  123 + color: #999999;
  124 + cursor: default;
  125 +}
  126 +.datepicker table tr td.today,
  127 +.datepicker table tr td.today:hover,
  128 +.datepicker table tr td.today.disabled,
  129 +.datepicker table tr td.today.disabled:hover {
  130 + color: #000000;
  131 + background-color: #ffdb99;
  132 + border-color: #ffb733;
  133 +}
  134 +.datepicker table tr td.today:hover,
  135 +.datepicker table tr td.today:hover:hover,
  136 +.datepicker table tr td.today.disabled:hover,
  137 +.datepicker table tr td.today.disabled:hover:hover,
  138 +.datepicker table tr td.today:focus,
  139 +.datepicker table tr td.today:hover:focus,
  140 +.datepicker table tr td.today.disabled:focus,
  141 +.datepicker table tr td.today.disabled:hover:focus,
  142 +.datepicker table tr td.today:active,
  143 +.datepicker table tr td.today:hover:active,
  144 +.datepicker table tr td.today.disabled:active,
  145 +.datepicker table tr td.today.disabled:hover:active,
  146 +.datepicker table tr td.today.active,
  147 +.datepicker table tr td.today:hover.active,
  148 +.datepicker table tr td.today.disabled.active,
  149 +.datepicker table tr td.today.disabled:hover.active,
  150 +.open .dropdown-toggle.datepicker table tr td.today,
  151 +.open .dropdown-toggle.datepicker table tr td.today:hover,
  152 +.open .dropdown-toggle.datepicker table tr td.today.disabled,
  153 +.open .dropdown-toggle.datepicker table tr td.today.disabled:hover {
  154 + color: #000000;
  155 + background-color: #ffcd70;
  156 + border-color: #f59e00;
  157 +}
  158 +.datepicker table tr td.today:active,
  159 +.datepicker table tr td.today:hover:active,
  160 +.datepicker table tr td.today.disabled:active,
  161 +.datepicker table tr td.today.disabled:hover:active,
  162 +.datepicker table tr td.today.active,
  163 +.datepicker table tr td.today:hover.active,
  164 +.datepicker table tr td.today.disabled.active,
  165 +.datepicker table tr td.today.disabled:hover.active,
  166 +.open .dropdown-toggle.datepicker table tr td.today,
  167 +.open .dropdown-toggle.datepicker table tr td.today:hover,
  168 +.open .dropdown-toggle.datepicker table tr td.today.disabled,
  169 +.open .dropdown-toggle.datepicker table tr td.today.disabled:hover {
  170 + background-image: none;
  171 +}
  172 +.datepicker table tr td.today.disabled,
  173 +.datepicker table tr td.today:hover.disabled,
  174 +.datepicker table tr td.today.disabled.disabled,
  175 +.datepicker table tr td.today.disabled:hover.disabled,
  176 +.datepicker table tr td.today[disabled],
  177 +.datepicker table tr td.today:hover[disabled],
  178 +.datepicker table tr td.today.disabled[disabled],
  179 +.datepicker table tr td.today.disabled:hover[disabled],
  180 +fieldset[disabled] .datepicker table tr td.today,
  181 +fieldset[disabled] .datepicker table tr td.today:hover,
  182 +fieldset[disabled] .datepicker table tr td.today.disabled,
  183 +fieldset[disabled] .datepicker table tr td.today.disabled:hover,
  184 +.datepicker table tr td.today.disabled:hover,
  185 +.datepicker table tr td.today:hover.disabled:hover,
  186 +.datepicker table tr td.today.disabled.disabled:hover,
  187 +.datepicker table tr td.today.disabled:hover.disabled:hover,
  188 +.datepicker table tr td.today[disabled]:hover,
  189 +.datepicker table tr td.today:hover[disabled]:hover,
  190 +.datepicker table tr td.today.disabled[disabled]:hover,
  191 +.datepicker table tr td.today.disabled:hover[disabled]:hover,
  192 +fieldset[disabled] .datepicker table tr td.today:hover,
  193 +fieldset[disabled] .datepicker table tr td.today:hover:hover,
  194 +fieldset[disabled] .datepicker table tr td.today.disabled:hover,
  195 +fieldset[disabled] .datepicker table tr td.today.disabled:hover:hover,
  196 +.datepicker table tr td.today.disabled:focus,
  197 +.datepicker table tr td.today:hover.disabled:focus,
  198 +.datepicker table tr td.today.disabled.disabled:focus,
  199 +.datepicker table tr td.today.disabled:hover.disabled:focus,
  200 +.datepicker table tr td.today[disabled]:focus,
  201 +.datepicker table tr td.today:hover[disabled]:focus,
  202 +.datepicker table tr td.today.disabled[disabled]:focus,
  203 +.datepicker table tr td.today.disabled:hover[disabled]:focus,
  204 +fieldset[disabled] .datepicker table tr td.today:focus,
  205 +fieldset[disabled] .datepicker table tr td.today:hover:focus,
  206 +fieldset[disabled] .datepicker table tr td.today.disabled:focus,
  207 +fieldset[disabled] .datepicker table tr td.today.disabled:hover:focus,
  208 +.datepicker table tr td.today.disabled:active,
  209 +.datepicker table tr td.today:hover.disabled:active,
  210 +.datepicker table tr td.today.disabled.disabled:active,
  211 +.datepicker table tr td.today.disabled:hover.disabled:active,
  212 +.datepicker table tr td.today[disabled]:active,
  213 +.datepicker table tr td.today:hover[disabled]:active,
  214 +.datepicker table tr td.today.disabled[disabled]:active,
  215 +.datepicker table tr td.today.disabled:hover[disabled]:active,
  216 +fieldset[disabled] .datepicker table tr td.today:active,
  217 +fieldset[disabled] .datepicker table tr td.today:hover:active,
  218 +fieldset[disabled] .datepicker table tr td.today.disabled:active,
  219 +fieldset[disabled] .datepicker table tr td.today.disabled:hover:active,
  220 +.datepicker table tr td.today.disabled.active,
  221 +.datepicker table tr td.today:hover.disabled.active,
  222 +.datepicker table tr td.today.disabled.disabled.active,
  223 +.datepicker table tr td.today.disabled:hover.disabled.active,
  224 +.datepicker table tr td.today[disabled].active,
  225 +.datepicker table tr td.today:hover[disabled].active,
  226 +.datepicker table tr td.today.disabled[disabled].active,
  227 +.datepicker table tr td.today.disabled:hover[disabled].active,
  228 +fieldset[disabled] .datepicker table tr td.today.active,
  229 +fieldset[disabled] .datepicker table tr td.today:hover.active,
  230 +fieldset[disabled] .datepicker table tr td.today.disabled.active,
  231 +fieldset[disabled] .datepicker table tr td.today.disabled:hover.active {
  232 + background-color: #ffdb99;
  233 + border-color: #ffb733;
  234 +}
  235 +.datepicker table tr td.today:hover:hover {
  236 + color: #000;
  237 +}
  238 +.datepicker table tr td.today.active:hover {
  239 + color: #fff;
  240 +}
  241 +.datepicker table tr td.range,
  242 +.datepicker table tr td.range:hover,
  243 +.datepicker table tr td.range.disabled,
  244 +.datepicker table tr td.range.disabled:hover {
  245 + background: #eeeeee;
  246 + border-radius: 0;
  247 +}
  248 +.datepicker table tr td.range.today,
  249 +.datepicker table tr td.range.today:hover,
  250 +.datepicker table tr td.range.today.disabled,
  251 +.datepicker table tr td.range.today.disabled:hover {
  252 + color: #000000;
  253 + background-color: #f7ca77;
  254 + border-color: #f1a417;
  255 + border-radius: 0;
  256 +}
  257 +.datepicker table tr td.range.today:hover,
  258 +.datepicker table tr td.range.today:hover:hover,
  259 +.datepicker table tr td.range.today.disabled:hover,
  260 +.datepicker table tr td.range.today.disabled:hover:hover,
  261 +.datepicker table tr td.range.today:focus,
  262 +.datepicker table tr td.range.today:hover:focus,
  263 +.datepicker table tr td.range.today.disabled:focus,
  264 +.datepicker table tr td.range.today.disabled:hover:focus,
  265 +.datepicker table tr td.range.today:active,
  266 +.datepicker table tr td.range.today:hover:active,
  267 +.datepicker table tr td.range.today.disabled:active,
  268 +.datepicker table tr td.range.today.disabled:hover:active,
  269 +.datepicker table tr td.range.today.active,
  270 +.datepicker table tr td.range.today:hover.active,
  271 +.datepicker table tr td.range.today.disabled.active,
  272 +.datepicker table tr td.range.today.disabled:hover.active,
  273 +.open .dropdown-toggle.datepicker table tr td.range.today,
  274 +.open .dropdown-toggle.datepicker table tr td.range.today:hover,
  275 +.open .dropdown-toggle.datepicker table tr td.range.today.disabled,
  276 +.open .dropdown-toggle.datepicker table tr td.range.today.disabled:hover {
  277 + color: #000000;
  278 + background-color: #f4bb51;
  279 + border-color: #bf800c;
  280 +}
  281 +.datepicker table tr td.range.today:active,
  282 +.datepicker table tr td.range.today:hover:active,
  283 +.datepicker table tr td.range.today.disabled:active,
  284 +.datepicker table tr td.range.today.disabled:hover:active,
  285 +.datepicker table tr td.range.today.active,
  286 +.datepicker table tr td.range.today:hover.active,
  287 +.datepicker table tr td.range.today.disabled.active,
  288 +.datepicker table tr td.range.today.disabled:hover.active,
  289 +.open .dropdown-toggle.datepicker table tr td.range.today,
  290 +.open .dropdown-toggle.datepicker table tr td.range.today:hover,
  291 +.open .dropdown-toggle.datepicker table tr td.range.today.disabled,
  292 +.open .dropdown-toggle.datepicker table tr td.range.today.disabled:hover {
  293 + background-image: none;
  294 +}
  295 +.datepicker table tr td.range.today.disabled,
  296 +.datepicker table tr td.range.today:hover.disabled,
  297 +.datepicker table tr td.range.today.disabled.disabled,
  298 +.datepicker table tr td.range.today.disabled:hover.disabled,
  299 +.datepicker table tr td.range.today[disabled],
  300 +.datepicker table tr td.range.today:hover[disabled],
  301 +.datepicker table tr td.range.today.disabled[disabled],
  302 +.datepicker table tr td.range.today.disabled:hover[disabled],
  303 +fieldset[disabled] .datepicker table tr td.range.today,
  304 +fieldset[disabled] .datepicker table tr td.range.today:hover,
  305 +fieldset[disabled] .datepicker table tr td.range.today.disabled,
  306 +fieldset[disabled] .datepicker table tr td.range.today.disabled:hover,
  307 +.datepicker table tr td.range.today.disabled:hover,
  308 +.datepicker table tr td.range.today:hover.disabled:hover,
  309 +.datepicker table tr td.range.today.disabled.disabled:hover,
  310 +.datepicker table tr td.range.today.disabled:hover.disabled:hover,
  311 +.datepicker table tr td.range.today[disabled]:hover,
  312 +.datepicker table tr td.range.today:hover[disabled]:hover,
  313 +.datepicker table tr td.range.today.disabled[disabled]:hover,
  314 +.datepicker table tr td.range.today.disabled:hover[disabled]:hover,
  315 +fieldset[disabled] .datepicker table tr td.range.today:hover,
  316 +fieldset[disabled] .datepicker table tr td.range.today:hover:hover,
  317 +fieldset[disabled] .datepicker table tr td.range.today.disabled:hover,
  318 +fieldset[disabled] .datepicker table tr td.range.today.disabled:hover:hover,
  319 +.datepicker table tr td.range.today.disabled:focus,
  320 +.datepicker table tr td.range.today:hover.disabled:focus,
  321 +.datepicker table tr td.range.today.disabled.disabled:focus,
  322 +.datepicker table tr td.range.today.disabled:hover.disabled:focus,
  323 +.datepicker table tr td.range.today[disabled]:focus,
  324 +.datepicker table tr td.range.today:hover[disabled]:focus,
  325 +.datepicker table tr td.range.today.disabled[disabled]:focus,
  326 +.datepicker table tr td.range.today.disabled:hover[disabled]:focus,
  327 +fieldset[disabled] .datepicker table tr td.range.today:focus,
  328 +fieldset[disabled] .datepicker table tr td.range.today:hover:focus,
  329 +fieldset[disabled] .datepicker table tr td.range.today.disabled:focus,
  330 +fieldset[disabled] .datepicker table tr td.range.today.disabled:hover:focus,
  331 +.datepicker table tr td.range.today.disabled:active,
  332 +.datepicker table tr td.range.today:hover.disabled:active,
  333 +.datepicker table tr td.range.today.disabled.disabled:active,
  334 +.datepicker table tr td.range.today.disabled:hover.disabled:active,
  335 +.datepicker table tr td.range.today[disabled]:active,
  336 +.datepicker table tr td.range.today:hover[disabled]:active,
  337 +.datepicker table tr td.range.today.disabled[disabled]:active,
  338 +.datepicker table tr td.range.today.disabled:hover[disabled]:active,
  339 +fieldset[disabled] .datepicker table tr td.range.today:active,
  340 +fieldset[disabled] .datepicker table tr td.range.today:hover:active,
  341 +fieldset[disabled] .datepicker table tr td.range.today.disabled:active,
  342 +fieldset[disabled] .datepicker table tr td.range.today.disabled:hover:active,
  343 +.datepicker table tr td.range.today.disabled.active,
  344 +.datepicker table tr td.range.today:hover.disabled.active,
  345 +.datepicker table tr td.range.today.disabled.disabled.active,
  346 +.datepicker table tr td.range.today.disabled:hover.disabled.active,
  347 +.datepicker table tr td.range.today[disabled].active,
  348 +.datepicker table tr td.range.today:hover[disabled].active,
  349 +.datepicker table tr td.range.today.disabled[disabled].active,
  350 +.datepicker table tr td.range.today.disabled:hover[disabled].active,
  351 +fieldset[disabled] .datepicker table tr td.range.today.active,
  352 +fieldset[disabled] .datepicker table tr td.range.today:hover.active,
  353 +fieldset[disabled] .datepicker table tr td.range.today.disabled.active,
  354 +fieldset[disabled] .datepicker table tr td.range.today.disabled:hover.active {
  355 + background-color: #f7ca77;
  356 + border-color: #f1a417;
  357 +}
  358 +.datepicker table tr td.selected,
  359 +.datepicker table tr td.selected:hover,
  360 +.datepicker table tr td.selected.disabled,
  361 +.datepicker table tr td.selected.disabled:hover {
  362 + color: #ffffff;
  363 + background-color: #999999;
  364 + border-color: #555555;
  365 + text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
  366 +}
  367 +.datepicker table tr td.selected:hover,
  368 +.datepicker table tr td.selected:hover:hover,
  369 +.datepicker table tr td.selected.disabled:hover,
  370 +.datepicker table tr td.selected.disabled:hover:hover,
  371 +.datepicker table tr td.selected:focus,
  372 +.datepicker table tr td.selected:hover:focus,
  373 +.datepicker table tr td.selected.disabled:focus,
  374 +.datepicker table tr td.selected.disabled:hover:focus,
  375 +.datepicker table tr td.selected:active,
  376 +.datepicker table tr td.selected:hover:active,
  377 +.datepicker table tr td.selected.disabled:active,
  378 +.datepicker table tr td.selected.disabled:hover:active,
  379 +.datepicker table tr td.selected.active,
  380 +.datepicker table tr td.selected:hover.active,
  381 +.datepicker table tr td.selected.disabled.active,
  382 +.datepicker table tr td.selected.disabled:hover.active,
  383 +.open .dropdown-toggle.datepicker table tr td.selected,
  384 +.open .dropdown-toggle.datepicker table tr td.selected:hover,
  385 +.open .dropdown-toggle.datepicker table tr td.selected.disabled,
  386 +.open .dropdown-toggle.datepicker table tr td.selected.disabled:hover {
  387 + color: #ffffff;
  388 + background-color: #858585;
  389 + border-color: #373737;
  390 +}
  391 +.datepicker table tr td.selected:active,
  392 +.datepicker table tr td.selected:hover:active,
  393 +.datepicker table tr td.selected.disabled:active,
  394 +.datepicker table tr td.selected.disabled:hover:active,
  395 +.datepicker table tr td.selected.active,
  396 +.datepicker table tr td.selected:hover.active,
  397 +.datepicker table tr td.selected.disabled.active,
  398 +.datepicker table tr td.selected.disabled:hover.active,
  399 +.open .dropdown-toggle.datepicker table tr td.selected,
  400 +.open .dropdown-toggle.datepicker table tr td.selected:hover,
  401 +.open .dropdown-toggle.datepicker table tr td.selected.disabled,
  402 +.open .dropdown-toggle.datepicker table tr td.selected.disabled:hover {
  403 + background-image: none;
  404 +}
  405 +.datepicker table tr td.selected.disabled,
  406 +.datepicker table tr td.selected:hover.disabled,
  407 +.datepicker table tr td.selected.disabled.disabled,
  408 +.datepicker table tr td.selected.disabled:hover.disabled,
  409 +.datepicker table tr td.selected[disabled],
  410 +.datepicker table tr td.selected:hover[disabled],
  411 +.datepicker table tr td.selected.disabled[disabled],
  412 +.datepicker table tr td.selected.disabled:hover[disabled],
  413 +fieldset[disabled] .datepicker table tr td.selected,
  414 +fieldset[disabled] .datepicker table tr td.selected:hover,
  415 +fieldset[disabled] .datepicker table tr td.selected.disabled,
  416 +fieldset[disabled] .datepicker table tr td.selected.disabled:hover,
  417 +.datepicker table tr td.selected.disabled:hover,
  418 +.datepicker table tr td.selected:hover.disabled:hover,
  419 +.datepicker table tr td.selected.disabled.disabled:hover,
  420 +.datepicker table tr td.selected.disabled:hover.disabled:hover,
  421 +.datepicker table tr td.selected[disabled]:hover,
  422 +.datepicker table tr td.selected:hover[disabled]:hover,
  423 +.datepicker table tr td.selected.disabled[disabled]:hover,
  424 +.datepicker table tr td.selected.disabled:hover[disabled]:hover,
  425 +fieldset[disabled] .datepicker table tr td.selected:hover,
  426 +fieldset[disabled] .datepicker table tr td.selected:hover:hover,
  427 +fieldset[disabled] .datepicker table tr td.selected.disabled:hover,
  428 +fieldset[disabled] .datepicker table tr td.selected.disabled:hover:hover,
  429 +.datepicker table tr td.selected.disabled:focus,
  430 +.datepicker table tr td.selected:hover.disabled:focus,
  431 +.datepicker table tr td.selected.disabled.disabled:focus,
  432 +.datepicker table tr td.selected.disabled:hover.disabled:focus,
  433 +.datepicker table tr td.selected[disabled]:focus,
  434 +.datepicker table tr td.selected:hover[disabled]:focus,
  435 +.datepicker table tr td.selected.disabled[disabled]:focus,
  436 +.datepicker table tr td.selected.disabled:hover[disabled]:focus,
  437 +fieldset[disabled] .datepicker table tr td.selected:focus,
  438 +fieldset[disabled] .datepicker table tr td.selected:hover:focus,
  439 +fieldset[disabled] .datepicker table tr td.selected.disabled:focus,
  440 +fieldset[disabled] .datepicker table tr td.selected.disabled:hover:focus,
  441 +.datepicker table tr td.selected.disabled:active,
  442 +.datepicker table tr td.selected:hover.disabled:active,
  443 +.datepicker table tr td.selected.disabled.disabled:active,
  444 +.datepicker table tr td.selected.disabled:hover.disabled:active,
  445 +.datepicker table tr td.selected[disabled]:active,
  446 +.datepicker table tr td.selected:hover[disabled]:active,
  447 +.datepicker table tr td.selected.disabled[disabled]:active,
  448 +.datepicker table tr td.selected.disabled:hover[disabled]:active,
  449 +fieldset[disabled] .datepicker table tr td.selected:active,
  450 +fieldset[disabled] .datepicker table tr td.selected:hover:active,
  451 +fieldset[disabled] .datepicker table tr td.selected.disabled:active,
  452 +fieldset[disabled] .datepicker table tr td.selected.disabled:hover:active,
  453 +.datepicker table tr td.selected.disabled.active,
  454 +.datepicker table tr td.selected:hover.disabled.active,
  455 +.datepicker table tr td.selected.disabled.disabled.active,
  456 +.datepicker table tr td.selected.disabled:hover.disabled.active,
  457 +.datepicker table tr td.selected[disabled].active,
  458 +.datepicker table tr td.selected:hover[disabled].active,
  459 +.datepicker table tr td.selected.disabled[disabled].active,
  460 +.datepicker table tr td.selected.disabled:hover[disabled].active,
  461 +fieldset[disabled] .datepicker table tr td.selected.active,
  462 +fieldset[disabled] .datepicker table tr td.selected:hover.active,
  463 +fieldset[disabled] .datepicker table tr td.selected.disabled.active,
  464 +fieldset[disabled] .datepicker table tr td.selected.disabled:hover.active {
  465 + background-color: #999999;
  466 + border-color: #555555;
  467 +}
  468 +.datepicker table tr td.active,
  469 +.datepicker table tr td.active:hover,
  470 +.datepicker table tr td.active.disabled,
  471 +.datepicker table tr td.active.disabled:hover {
  472 + color: #ffffff;
  473 + background-color: #428bca;
  474 + border-color: #357ebd;
  475 + text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
  476 +}
  477 +.datepicker table tr td.active:hover,
  478 +.datepicker table tr td.active:hover:hover,
  479 +.datepicker table tr td.active.disabled:hover,
  480 +.datepicker table tr td.active.disabled:hover:hover,
  481 +.datepicker table tr td.active:focus,
  482 +.datepicker table tr td.active:hover:focus,
  483 +.datepicker table tr td.active.disabled:focus,
  484 +.datepicker table tr td.active.disabled:hover:focus,
  485 +.datepicker table tr td.active:active,
  486 +.datepicker table tr td.active:hover:active,
  487 +.datepicker table tr td.active.disabled:active,
  488 +.datepicker table tr td.active.disabled:hover:active,
  489 +.datepicker table tr td.active.active,
  490 +.datepicker table tr td.active:hover.active,
  491 +.datepicker table tr td.active.disabled.active,
  492 +.datepicker table tr td.active.disabled:hover.active,
  493 +.open .dropdown-toggle.datepicker table tr td.active,
  494 +.open .dropdown-toggle.datepicker table tr td.active:hover,
  495 +.open .dropdown-toggle.datepicker table tr td.active.disabled,
  496 +.open .dropdown-toggle.datepicker table tr td.active.disabled:hover {
  497 + color: #ffffff;
  498 + background-color: #3276b1;
  499 + border-color: #285e8e;
  500 +}
  501 +.datepicker table tr td.active:active,
  502 +.datepicker table tr td.active:hover:active,
  503 +.datepicker table tr td.active.disabled:active,
  504 +.datepicker table tr td.active.disabled:hover:active,
  505 +.datepicker table tr td.active.active,
  506 +.datepicker table tr td.active:hover.active,
  507 +.datepicker table tr td.active.disabled.active,
  508 +.datepicker table tr td.active.disabled:hover.active,
  509 +.open .dropdown-toggle.datepicker table tr td.active,
  510 +.open .dropdown-toggle.datepicker table tr td.active:hover,
  511 +.open .dropdown-toggle.datepicker table tr td.active.disabled,
  512 +.open .dropdown-toggle.datepicker table tr td.active.disabled:hover {
  513 + background-image: none;
  514 +}
  515 +.datepicker table tr td.active.disabled,
  516 +.datepicker table tr td.active:hover.disabled,
  517 +.datepicker table tr td.active.disabled.disabled,
  518 +.datepicker table tr td.active.disabled:hover.disabled,
  519 +.datepicker table tr td.active[disabled],
  520 +.datepicker table tr td.active:hover[disabled],
  521 +.datepicker table tr td.active.disabled[disabled],
  522 +.datepicker table tr td.active.disabled:hover[disabled],
  523 +fieldset[disabled] .datepicker table tr td.active,
  524 +fieldset[disabled] .datepicker table tr td.active:hover,
  525 +fieldset[disabled] .datepicker table tr td.active.disabled,
  526 +fieldset[disabled] .datepicker table tr td.active.disabled:hover,
  527 +.datepicker table tr td.active.disabled:hover,
  528 +.datepicker table tr td.active:hover.disabled:hover,
  529 +.datepicker table tr td.active.disabled.disabled:hover,
  530 +.datepicker table tr td.active.disabled:hover.disabled:hover,
  531 +.datepicker table tr td.active[disabled]:hover,
  532 +.datepicker table tr td.active:hover[disabled]:hover,
  533 +.datepicker table tr td.active.disabled[disabled]:hover,
  534 +.datepicker table tr td.active.disabled:hover[disabled]:hover,
  535 +fieldset[disabled] .datepicker table tr td.active:hover,
  536 +fieldset[disabled] .datepicker table tr td.active:hover:hover,
  537 +fieldset[disabled] .datepicker table tr td.active.disabled:hover,
  538 +fieldset[disabled] .datepicker table tr td.active.disabled:hover:hover,
  539 +.datepicker table tr td.active.disabled:focus,
  540 +.datepicker table tr td.active:hover.disabled:focus,
  541 +.datepicker table tr td.active.disabled.disabled:focus,
  542 +.datepicker table tr td.active.disabled:hover.disabled:focus,
  543 +.datepicker table tr td.active[disabled]:focus,
  544 +.datepicker table tr td.active:hover[disabled]:focus,
  545 +.datepicker table tr td.active.disabled[disabled]:focus,
  546 +.datepicker table tr td.active.disabled:hover[disabled]:focus,
  547 +fieldset[disabled] .datepicker table tr td.active:focus,
  548 +fieldset[disabled] .datepicker table tr td.active:hover:focus,
  549 +fieldset[disabled] .datepicker table tr td.active.disabled:focus,
  550 +fieldset[disabled] .datepicker table tr td.active.disabled:hover:focus,
  551 +.datepicker table tr td.active.disabled:active,
  552 +.datepicker table tr td.active:hover.disabled:active,
  553 +.datepicker table tr td.active.disabled.disabled:active,
  554 +.datepicker table tr td.active.disabled:hover.disabled:active,
  555 +.datepicker table tr td.active[disabled]:active,
  556 +.datepicker table tr td.active:hover[disabled]:active,
  557 +.datepicker table tr td.active.disabled[disabled]:active,
  558 +.datepicker table tr td.active.disabled:hover[disabled]:active,
  559 +fieldset[disabled] .datepicker table tr td.active:active,
  560 +fieldset[disabled] .datepicker table tr td.active:hover:active,
  561 +fieldset[disabled] .datepicker table tr td.active.disabled:active,
  562 +fieldset[disabled] .datepicker table tr td.active.disabled:hover:active,
  563 +.datepicker table tr td.active.disabled.active,
  564 +.datepicker table tr td.active:hover.disabled.active,
  565 +.datepicker table tr td.active.disabled.disabled.active,
  566 +.datepicker table tr td.active.disabled:hover.disabled.active,
  567 +.datepicker table tr td.active[disabled].active,
  568 +.datepicker table tr td.active:hover[disabled].active,
  569 +.datepicker table tr td.active.disabled[disabled].active,
  570 +.datepicker table tr td.active.disabled:hover[disabled].active,
  571 +fieldset[disabled] .datepicker table tr td.active.active,
  572 +fieldset[disabled] .datepicker table tr td.active:hover.active,
  573 +fieldset[disabled] .datepicker table tr td.active.disabled.active,
  574 +fieldset[disabled] .datepicker table tr td.active.disabled:hover.active {
  575 + background-color: #428bca;
  576 + border-color: #357ebd;
  577 +}
  578 +.datepicker table tr td span {
  579 + display: block;
  580 + width: 23%;
  581 + height: 54px;
  582 + line-height: 54px;
  583 + float: left;
  584 + margin: 1%;
  585 + cursor: pointer;
  586 + border-radius: 4px;
  587 +}
  588 +.datepicker table tr td span:hover {
  589 + background: #eeeeee;
  590 +}
  591 +.datepicker table tr td span.disabled,
  592 +.datepicker table tr td span.disabled:hover {
  593 + background: none;
  594 + color: #999999;
  595 + cursor: default;
  596 +}
  597 +.datepicker table tr td span.active,
  598 +.datepicker table tr td span.active:hover,
  599 +.datepicker table tr td span.active.disabled,
  600 +.datepicker table tr td span.active.disabled:hover {
  601 + color: #ffffff;
  602 + background-color: #428bca;
  603 + border-color: #357ebd;
  604 + text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
  605 +}
  606 +.datepicker table tr td span.active:hover,
  607 +.datepicker table tr td span.active:hover:hover,
  608 +.datepicker table tr td span.active.disabled:hover,
  609 +.datepicker table tr td span.active.disabled:hover:hover,
  610 +.datepicker table tr td span.active:focus,
  611 +.datepicker table tr td span.active:hover:focus,
  612 +.datepicker table tr td span.active.disabled:focus,
  613 +.datepicker table tr td span.active.disabled:hover:focus,
  614 +.datepicker table tr td span.active:active,
  615 +.datepicker table tr td span.active:hover:active,
  616 +.datepicker table tr td span.active.disabled:active,
  617 +.datepicker table tr td span.active.disabled:hover:active,
  618 +.datepicker table tr td span.active.active,
  619 +.datepicker table tr td span.active:hover.active,
  620 +.datepicker table tr td span.active.disabled.active,
  621 +.datepicker table tr td span.active.disabled:hover.active,
  622 +.open .dropdown-toggle.datepicker table tr td span.active,
  623 +.open .dropdown-toggle.datepicker table tr td span.active:hover,
  624 +.open .dropdown-toggle.datepicker table tr td span.active.disabled,
  625 +.open .dropdown-toggle.datepicker table tr td span.active.disabled:hover {
  626 + color: #ffffff;
  627 + background-color: #3276b1;
  628 + border-color: #285e8e;
  629 +}
  630 +.datepicker table tr td span.active:active,
  631 +.datepicker table tr td span.active:hover:active,
  632 +.datepicker table tr td span.active.disabled:active,
  633 +.datepicker table tr td span.active.disabled:hover:active,
  634 +.datepicker table tr td span.active.active,
  635 +.datepicker table tr td span.active:hover.active,
  636 +.datepicker table tr td span.active.disabled.active,
  637 +.datepicker table tr td span.active.disabled:hover.active,
  638 +.open .dropdown-toggle.datepicker table tr td span.active,
  639 +.open .dropdown-toggle.datepicker table tr td span.active:hover,
  640 +.open .dropdown-toggle.datepicker table tr td span.active.disabled,
  641 +.open .dropdown-toggle.datepicker table tr td span.active.disabled:hover {
  642 + background-image: none;
  643 +}
  644 +.datepicker table tr td span.active.disabled,
  645 +.datepicker table tr td span.active:hover.disabled,
  646 +.datepicker table tr td span.active.disabled.disabled,
  647 +.datepicker table tr td span.active.disabled:hover.disabled,
  648 +.datepicker table tr td span.active[disabled],
  649 +.datepicker table tr td span.active:hover[disabled],
  650 +.datepicker table tr td span.active.disabled[disabled],
  651 +.datepicker table tr td span.active.disabled:hover[disabled],
  652 +fieldset[disabled] .datepicker table tr td span.active,
  653 +fieldset[disabled] .datepicker table tr td span.active:hover,
  654 +fieldset[disabled] .datepicker table tr td span.active.disabled,
  655 +fieldset[disabled] .datepicker table tr td span.active.disabled:hover,
  656 +.datepicker table tr td span.active.disabled:hover,
  657 +.datepicker table tr td span.active:hover.disabled:hover,
  658 +.datepicker table tr td span.active.disabled.disabled:hover,
  659 +.datepicker table tr td span.active.disabled:hover.disabled:hover,
  660 +.datepicker table tr td span.active[disabled]:hover,
  661 +.datepicker table tr td span.active:hover[disabled]:hover,
  662 +.datepicker table tr td span.active.disabled[disabled]:hover,
  663 +.datepicker table tr td span.active.disabled:hover[disabled]:hover,
  664 +fieldset[disabled] .datepicker table tr td span.active:hover,
  665 +fieldset[disabled] .datepicker table tr td span.active:hover:hover,
  666 +fieldset[disabled] .datepicker table tr td span.active.disabled:hover,
  667 +fieldset[disabled] .datepicker table tr td span.active.disabled:hover:hover,
  668 +.datepicker table tr td span.active.disabled:focus,
  669 +.datepicker table tr td span.active:hover.disabled:focus,
  670 +.datepicker table tr td span.active.disabled.disabled:focus,
  671 +.datepicker table tr td span.active.disabled:hover.disabled:focus,
  672 +.datepicker table tr td span.active[disabled]:focus,
  673 +.datepicker table tr td span.active:hover[disabled]:focus,
  674 +.datepicker table tr td span.active.disabled[disabled]:focus,
  675 +.datepicker table tr td span.active.disabled:hover[disabled]:focus,
  676 +fieldset[disabled] .datepicker table tr td span.active:focus,
  677 +fieldset[disabled] .datepicker table tr td span.active:hover:focus,
  678 +fieldset[disabled] .datepicker table tr td span.active.disabled:focus,
  679 +fieldset[disabled] .datepicker table tr td span.active.disabled:hover:focus,
  680 +.datepicker table tr td span.active.disabled:active,
  681 +.datepicker table tr td span.active:hover.disabled:active,
  682 +.datepicker table tr td span.active.disabled.disabled:active,
  683 +.datepicker table tr td span.active.disabled:hover.disabled:active,
  684 +.datepicker table tr td span.active[disabled]:active,
  685 +.datepicker table tr td span.active:hover[disabled]:active,
  686 +.datepicker table tr td span.active.disabled[disabled]:active,
  687 +.datepicker table tr td span.active.disabled:hover[disabled]:active,
  688 +fieldset[disabled] .datepicker table tr td span.active:active,
  689 +fieldset[disabled] .datepicker table tr td span.active:hover:active,
  690 +fieldset[disabled] .datepicker table tr td span.active.disabled:active,
  691 +fieldset[disabled] .datepicker table tr td span.active.disabled:hover:active,
  692 +.datepicker table tr td span.active.disabled.active,
  693 +.datepicker table tr td span.active:hover.disabled.active,
  694 +.datepicker table tr td span.active.disabled.disabled.active,
  695 +.datepicker table tr td span.active.disabled:hover.disabled.active,
  696 +.datepicker table tr td span.active[disabled].active,
  697 +.datepicker table tr td span.active:hover[disabled].active,
  698 +.datepicker table tr td span.active.disabled[disabled].active,
  699 +.datepicker table tr td span.active.disabled:hover[disabled].active,
  700 +fieldset[disabled] .datepicker table tr td span.active.active,
  701 +fieldset[disabled] .datepicker table tr td span.active:hover.active,
  702 +fieldset[disabled] .datepicker table tr td span.active.disabled.active,
  703 +fieldset[disabled] .datepicker table tr td span.active.disabled:hover.active {
  704 + background-color: #428bca;
  705 + border-color: #357ebd;
  706 +}
  707 +.datepicker table tr td span.old,
  708 +.datepicker table tr td span.new {
  709 + color: #999999;
  710 +}
  711 +.datepicker th.datepicker-switch {
  712 + width: 145px;
  713 +}
  714 +.datepicker thead tr:first-child th,
  715 +.datepicker tfoot tr th {
  716 + cursor: pointer;
  717 +}
  718 +.datepicker thead tr:first-child th:hover,
  719 +.datepicker tfoot tr th:hover {
  720 + background: #eeeeee;
  721 +}
  722 +.datepicker .cw {
  723 + font-size: 10px;
  724 + width: 12px;
  725 + padding: 0 2px 0 5px;
  726 + vertical-align: middle;
  727 +}
  728 +.datepicker thead tr:first-child th.cw {
  729 + cursor: default;
  730 + background-color: transparent;
  731 +}
  732 +.input-group.date .input-group-addon i {
  733 + cursor: pointer;
  734 + width: 16px;
  735 + height: 16px;
  736 +}
  737 +.input-daterange input {
  738 + text-align: center;
  739 +}
  740 +.input-daterange input:first-child {
  741 + border-radius: 3px 0 0 3px;
  742 +}
  743 +.input-daterange input:last-child {
  744 + border-radius: 0 3px 3px 0;
  745 +}
  746 +.input-daterange .input-group-addon {
  747 + width: auto;
  748 + min-width: 16px;
  749 + padding: 4px 5px;
  750 + font-weight: normal;
  751 + line-height: 1.428571429;
  752 + text-align: center;
  753 + text-shadow: 0 1px 0 #fff;
  754 + vertical-align: middle;
  755 + background-color: #eeeeee;
  756 + border-width: 1px 0;
  757 + margin-left: -5px;
  758 + margin-right: -5px;
  759 +}
  760 +.datepicker.dropdown-menu {
  761 + position: absolute;
  762 + top: 100%;
  763 + left: 0;
  764 + z-index: 1000;
  765 + float: left;
  766 + display: none;
  767 + min-width: 160px;
  768 + list-style: none;
  769 + background-color: #ffffff;
  770 + border: 1px solid #ccc;
  771 + border: 1px solid rgba(0, 0, 0, 0.2);
  772 + border-radius: 5px;
  773 + -webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
  774 + -moz-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
  775 + box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
  776 + -webkit-background-clip: padding-box;
  777 + -moz-background-clip: padding;
  778 + background-clip: padding-box;
  779 + *border-right-width: 2px;
  780 + *border-bottom-width: 2px;
  781 + color: #333333;
  782 + font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  783 + font-size: 13px;
  784 + line-height: 1.428571429;
  785 +}
  786 +.datepicker.dropdown-menu th,
  787 +.datepicker.dropdown-menu td {
  788 + padding: 4px 5px;
  789 +}
... ...
... ... @@ -36,6 +36,7 @@
36 36 <link href="js/plugins/msgbox/jquery.msgbox.css" rel="stylesheet">
37 37 <link href="css/pages/pricing.css" rel="stylesheet">
38 38 <link href="css/pages/reports.css" rel="stylesheet">
  39 + <link rel="stylesheet" type="text/css" href="css/datepicker3.css">
39 40  
40 41  
41 42  
... ... @@ -124,6 +125,7 @@
124 125 <script src="partials/delselected/delselected.controller.js"></script>
125 126 <script src="partials/pricingcontact/pricingcontact.controller.js"></script>
126 127 <script src="partials/viewcontact/viewcontact.controller.js"></script>
  128 + <script src="partials/viewFuelVendor/viewFuelVendor.controller.js"></script>
127 129  
128 130 <script src="partials/main/main.controller.js"></script>
129 131 <div ui-view></div>
... ... @@ -157,6 +159,7 @@
157 159 <script src="partials/delselected/delselected.service.js"></script>
158 160 <script src="partials/pricingcontact/pricingcontact.service.js"></script>
159 161 <script src="partials/viewcontact/viewcontact.service.js"></script>
  162 + <script src="partials/viewFuelVendor/viewFuelVendor.service.js"></script>
160 163  
161 164 <script src="partials/main/main.service.js"></script>
162 165 </body>
... ...
app/js/app.constant.js
... ... @@ -4,8 +4,10 @@
4 4 angular.module('acufuel')
5 5  
6 6 .constant('BASE_URL', {
7   - //url: 'http://54.149.169.33:8080/ws'
8   - url: 'http://192.168.1.226:8080/ws'
  7 + url: 'http://54.149.169.33:8080/ws'
  8 + //url: 'http://192.168.1.175:8080/ws'
  9 + //url: 'http://192.168.1.8:8080/ws'
  10 +
9 11 })
10 12  
11 13 .constant('AUTH_EVENTS', {
... ...
... ... @@ -180,12 +180,18 @@
180 180 // }
181 181 })
182 182  
183   - .state("app.viewCompany", {
  183 + .state("app.viewCompany", {
184 184 url: "/viewCompany/:id",
185 185 templateUrl: "partials/viewCompany/viewCompany.html",
186 186 controller: "viewCompanyController"
187 187 })
188 188  
  189 + .state("app.viewFuelVendor", {
  190 + url: "/viewFuelVendor/:id",
  191 + templateUrl: "partials/viewFuelVendor/viewFuelVendor.html",
  192 + controller: "ViewFuelVendorController"
  193 + })
  194 +
189 195 .state("app.fuelOrders", {
190 196 url: "/fuelOrders",
191 197 templateUrl: "partials/fuelOrders/fuelOrders.html",
... ...
app/js/jquery-3.1.1.min.js
... ... @@ -0,0 +1,4 @@
  1 +/*! jQuery v3.1.1 | (c) jQuery Foundation | jquery.org/license */
  2 +!function(a,b){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=a.document?b(a,!0):function(a){if(!a.document)throw new Error("jQuery requires a window with a document");return b(a)}:b(a)}("undefined"!=typeof window?window:this,function(a,b){"use strict";var c=[],d=a.document,e=Object.getPrototypeOf,f=c.slice,g=c.concat,h=c.push,i=c.indexOf,j={},k=j.toString,l=j.hasOwnProperty,m=l.toString,n=m.call(Object),o={};function p(a,b){b=b||d;var c=b.createElement("script");c.text=a,b.head.appendChild(c).parentNode.removeChild(c)}var q="3.1.1",r=function(a,b){return new r.fn.init(a,b)},s=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,t=/^-ms-/,u=/-([a-z])/g,v=function(a,b){return b.toUpperCase()};r.fn=r.prototype={jquery:q,constructor:r,length:0,toArray:function(){return f.call(this)},get:function(a){return null==a?f.call(this):a<0?this[a+this.length]:this[a]},pushStack:function(a){var b=r.merge(this.constructor(),a);return b.prevObject=this,b},each:function(a){return r.each(this,a)},map:function(a){return this.pushStack(r.map(this,function(b,c){return a.call(b,c,b)}))},slice:function(){return this.pushStack(f.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(a){var b=this.length,c=+a+(a<0?b:0);return this.pushStack(c>=0&&c<b?[this[c]]:[])},end:function(){return this.prevObject||this.constructor()},push:h,sort:c.sort,splice:c.splice},r.extend=r.fn.extend=function(){var a,b,c,d,e,f,g=arguments[0]||{},h=1,i=arguments.length,j=!1;for("boolean"==typeof g&&(j=g,g=arguments[h]||{},h++),"object"==typeof g||r.isFunction(g)||(g={}),h===i&&(g=this,h--);h<i;h++)if(null!=(a=arguments[h]))for(b in a)c=g[b],d=a[b],g!==d&&(j&&d&&(r.isPlainObject(d)||(e=r.isArray(d)))?(e?(e=!1,f=c&&r.isArray(c)?c:[]):f=c&&r.isPlainObject(c)?c:{},g[b]=r.extend(j,f,d)):void 0!==d&&(g[b]=d));return g},r.extend({expando:"jQuery"+(q+Math.random()).replace(/\D/g,""),isReady:!0,error:function(a){throw new Error(a)},noop:function(){},isFunction:function(a){return"function"===r.type(a)},isArray:Array.isArray,isWindow:function(a){return null!=a&&a===a.window},isNumeric:function(a){var b=r.type(a);return("number"===b||"string"===b)&&!isNaN(a-parseFloat(a))},isPlainObject:function(a){var b,c;return!(!a||"[object Object]"!==k.call(a))&&(!(b=e(a))||(c=l.call(b,"constructor")&&b.constructor,"function"==typeof c&&m.call(c)===n))},isEmptyObject:function(a){var b;for(b in a)return!1;return!0},type:function(a){return null==a?a+"":"object"==typeof a||"function"==typeof a?j[k.call(a)]||"object":typeof a},globalEval:function(a){p(a)},camelCase:function(a){return a.replace(t,"ms-").replace(u,v)},nodeName:function(a,b){return a.nodeName&&a.nodeName.toLowerCase()===b.toLowerCase()},each:function(a,b){var c,d=0;if(w(a)){for(c=a.length;d<c;d++)if(b.call(a[d],d,a[d])===!1)break}else for(d in a)if(b.call(a[d],d,a[d])===!1)break;return a},trim:function(a){return null==a?"":(a+"").replace(s,"")},makeArray:function(a,b){var c=b||[];return null!=a&&(w(Object(a))?r.merge(c,"string"==typeof a?[a]:a):h.call(c,a)),c},inArray:function(a,b,c){return null==b?-1:i.call(b,a,c)},merge:function(a,b){for(var c=+b.length,d=0,e=a.length;d<c;d++)a[e++]=b[d];return a.length=e,a},grep:function(a,b,c){for(var d,e=[],f=0,g=a.length,h=!c;f<g;f++)d=!b(a[f],f),d!==h&&e.push(a[f]);return e},map:function(a,b,c){var d,e,f=0,h=[];if(w(a))for(d=a.length;f<d;f++)e=b(a[f],f,c),null!=e&&h.push(e);else for(f in a)e=b(a[f],f,c),null!=e&&h.push(e);return g.apply([],h)},guid:1,proxy:function(a,b){var c,d,e;if("string"==typeof b&&(c=a[b],b=a,a=c),r.isFunction(a))return d=f.call(arguments,2),e=function(){return a.apply(b||this,d.concat(f.call(arguments)))},e.guid=a.guid=a.guid||r.guid++,e},now:Date.now,support:o}),"function"==typeof Symbol&&(r.fn[Symbol.iterator]=c[Symbol.iterator]),r.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "),function(a,b){j["[object "+b+"]"]=b.toLowerCase()});function w(a){var b=!!a&&"length"in a&&a.length,c=r.type(a);return"function"!==c&&!r.isWindow(a)&&("array"===c||0===b||"number"==typeof b&&b>0&&b-1 in a)}var x=function(a){var b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u="sizzle"+1*new Date,v=a.document,w=0,x=0,y=ha(),z=ha(),A=ha(),B=function(a,b){return a===b&&(l=!0),0},C={}.hasOwnProperty,D=[],E=D.pop,F=D.push,G=D.push,H=D.slice,I=function(a,b){for(var c=0,d=a.length;c<d;c++)if(a[c]===b)return c;return-1},J="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",K="[\\x20\\t\\r\\n\\f]",L="(?:\\\\.|[\\w-]|[^\0-\\xa0])+",M="\\["+K+"*("+L+")(?:"+K+"*([*^$|!~]?=)"+K+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+L+"))|)"+K+"*\\]",N=":("+L+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+M+")*)|.*)\\)|)",O=new RegExp(K+"+","g"),P=new RegExp("^"+K+"+|((?:^|[^\\\\])(?:\\\\.)*)"+K+"+$","g"),Q=new RegExp("^"+K+"*,"+K+"*"),R=new RegExp("^"+K+"*([>+~]|"+K+")"+K+"*"),S=new RegExp("="+K+"*([^\\]'\"]*?)"+K+"*\\]","g"),T=new RegExp(N),U=new RegExp("^"+L+"$"),V={ID:new RegExp("^#("+L+")"),CLASS:new RegExp("^\\.("+L+")"),TAG:new RegExp("^("+L+"|[*])"),ATTR:new RegExp("^"+M),PSEUDO:new RegExp("^"+N),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+K+"*(even|odd|(([+-]|)(\\d*)n|)"+K+"*(?:([+-]|)"+K+"*(\\d+)|))"+K+"*\\)|)","i"),bool:new RegExp("^(?:"+J+")$","i"),needsContext:new RegExp("^"+K+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+K+"*((?:-\\d)?\\d*)"+K+"*\\)|)(?=[^-]|$)","i")},W=/^(?:input|select|textarea|button)$/i,X=/^h\d$/i,Y=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,$=/[+~]/,_=new RegExp("\\\\([\\da-f]{1,6}"+K+"?|("+K+")|.)","ig"),aa=function(a,b,c){var d="0x"+b-65536;return d!==d||c?b:d<0?String.fromCharCode(d+65536):String.fromCharCode(d>>10|55296,1023&d|56320)},ba=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ca=function(a,b){return b?"\0"===a?"\ufffd":a.slice(0,-1)+"\\"+a.charCodeAt(a.length-1).toString(16)+" ":"\\"+a},da=function(){m()},ea=ta(function(a){return a.disabled===!0&&("form"in a||"label"in a)},{dir:"parentNode",next:"legend"});try{G.apply(D=H.call(v.childNodes),v.childNodes),D[v.childNodes.length].nodeType}catch(fa){G={apply:D.length?function(a,b){F.apply(a,H.call(b))}:function(a,b){var c=a.length,d=0;while(a[c++]=b[d++]);a.length=c-1}}}function ga(a,b,d,e){var f,h,j,k,l,o,r,s=b&&b.ownerDocument,w=b?b.nodeType:9;if(d=d||[],"string"!=typeof a||!a||1!==w&&9!==w&&11!==w)return d;if(!e&&((b?b.ownerDocument||b:v)!==n&&m(b),b=b||n,p)){if(11!==w&&(l=Z.exec(a)))if(f=l[1]){if(9===w){if(!(j=b.getElementById(f)))return d;if(j.id===f)return d.push(j),d}else if(s&&(j=s.getElementById(f))&&t(b,j)&&j.id===f)return d.push(j),d}else{if(l[2])return G.apply(d,b.getElementsByTagName(a)),d;if((f=l[3])&&c.getElementsByClassName&&b.getElementsByClassName)return G.apply(d,b.getElementsByClassName(f)),d}if(c.qsa&&!A[a+" "]&&(!q||!q.test(a))){if(1!==w)s=b,r=a;else if("object"!==b.nodeName.toLowerCase()){(k=b.getAttribute("id"))?k=k.replace(ba,ca):b.setAttribute("id",k=u),o=g(a),h=o.length;while(h--)o[h]="#"+k+" "+sa(o[h]);r=o.join(","),s=$.test(a)&&qa(b.parentNode)||b}if(r)try{return G.apply(d,s.querySelectorAll(r)),d}catch(x){}finally{k===u&&b.removeAttribute("id")}}}return i(a.replace(P,"$1"),b,d,e)}function ha(){var a=[];function b(c,e){return a.push(c+" ")>d.cacheLength&&delete b[a.shift()],b[c+" "]=e}return b}function ia(a){return a[u]=!0,a}function ja(a){var b=n.createElement("fieldset");try{return!!a(b)}catch(c){return!1}finally{b.parentNode&&b.parentNode.removeChild(b),b=null}}function ka(a,b){var c=a.split("|"),e=c.length;while(e--)d.attrHandle[c[e]]=b}function la(a,b){var c=b&&a,d=c&&1===a.nodeType&&1===b.nodeType&&a.sourceIndex-b.sourceIndex;if(d)return d;if(c)while(c=c.nextSibling)if(c===b)return-1;return a?1:-1}function ma(a){return function(b){var c=b.nodeName.toLowerCase();return"input"===c&&b.type===a}}function na(a){return function(b){var c=b.nodeName.toLowerCase();return("input"===c||"button"===c)&&b.type===a}}function oa(a){return function(b){return"form"in b?b.parentNode&&b.disabled===!1?"label"in b?"label"in b.parentNode?b.parentNode.disabled===a:b.disabled===a:b.isDisabled===a||b.isDisabled!==!a&&ea(b)===a:b.disabled===a:"label"in b&&b.disabled===a}}function pa(a){return ia(function(b){return b=+b,ia(function(c,d){var e,f=a([],c.length,b),g=f.length;while(g--)c[e=f[g]]&&(c[e]=!(d[e]=c[e]))})})}function qa(a){return a&&"undefined"!=typeof a.getElementsByTagName&&a}c=ga.support={},f=ga.isXML=function(a){var b=a&&(a.ownerDocument||a).documentElement;return!!b&&"HTML"!==b.nodeName},m=ga.setDocument=function(a){var b,e,g=a?a.ownerDocument||a:v;return g!==n&&9===g.nodeType&&g.documentElement?(n=g,o=n.documentElement,p=!f(n),v!==n&&(e=n.defaultView)&&e.top!==e&&(e.addEventListener?e.addEventListener("unload",da,!1):e.attachEvent&&e.attachEvent("onunload",da)),c.attributes=ja(function(a){return a.className="i",!a.getAttribute("className")}),c.getElementsByTagName=ja(function(a){return a.appendChild(n.createComment("")),!a.getElementsByTagName("*").length}),c.getElementsByClassName=Y.test(n.getElementsByClassName),c.getById=ja(function(a){return o.appendChild(a).id=u,!n.getElementsByName||!n.getElementsByName(u).length}),c.getById?(d.filter.ID=function(a){var b=a.replace(_,aa);return function(a){return a.getAttribute("id")===b}},d.find.ID=function(a,b){if("undefined"!=typeof b.getElementById&&p){var c=b.getElementById(a);return c?[c]:[]}}):(d.filter.ID=function(a){var b=a.replace(_,aa);return function(a){var c="undefined"!=typeof a.getAttributeNode&&a.getAttributeNode("id");return c&&c.value===b}},d.find.ID=function(a,b){if("undefined"!=typeof b.getElementById&&p){var c,d,e,f=b.getElementById(a);if(f){if(c=f.getAttributeNode("id"),c&&c.value===a)return[f];e=b.getElementsByName(a),d=0;while(f=e[d++])if(c=f.getAttributeNode("id"),c&&c.value===a)return[f]}return[]}}),d.find.TAG=c.getElementsByTagName?function(a,b){return"undefined"!=typeof b.getElementsByTagName?b.getElementsByTagName(a):c.qsa?b.querySelectorAll(a):void 0}:function(a,b){var c,d=[],e=0,f=b.getElementsByTagName(a);if("*"===a){while(c=f[e++])1===c.nodeType&&d.push(c);return d}return f},d.find.CLASS=c.getElementsByClassName&&function(a,b){if("undefined"!=typeof b.getElementsByClassName&&p)return b.getElementsByClassName(a)},r=[],q=[],(c.qsa=Y.test(n.querySelectorAll))&&(ja(function(a){o.appendChild(a).innerHTML="<a id='"+u+"'></a><select id='"+u+"-\r\\' msallowcapture=''><option selected=''></option></select>",a.querySelectorAll("[msallowcapture^='']").length&&q.push("[*^$]="+K+"*(?:''|\"\")"),a.querySelectorAll("[selected]").length||q.push("\\["+K+"*(?:value|"+J+")"),a.querySelectorAll("[id~="+u+"-]").length||q.push("~="),a.querySelectorAll(":checked").length||q.push(":checked"),a.querySelectorAll("a#"+u+"+*").length||q.push(".#.+[+~]")}),ja(function(a){a.innerHTML="<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";var b=n.createElement("input");b.setAttribute("type","hidden"),a.appendChild(b).setAttribute("name","D"),a.querySelectorAll("[name=d]").length&&q.push("name"+K+"*[*^$|!~]?="),2!==a.querySelectorAll(":enabled").length&&q.push(":enabled",":disabled"),o.appendChild(a).disabled=!0,2!==a.querySelectorAll(":disabled").length&&q.push(":enabled",":disabled"),a.querySelectorAll("*,:x"),q.push(",.*:")})),(c.matchesSelector=Y.test(s=o.matches||o.webkitMatchesSelector||o.mozMatchesSelector||o.oMatchesSelector||o.msMatchesSelector))&&ja(function(a){c.disconnectedMatch=s.call(a,"*"),s.call(a,"[s!='']:x"),r.push("!=",N)}),q=q.length&&new RegExp(q.join("|")),r=r.length&&new RegExp(r.join("|")),b=Y.test(o.compareDocumentPosition),t=b||Y.test(o.contains)?function(a,b){var c=9===a.nodeType?a.documentElement:a,d=b&&b.parentNode;return a===d||!(!d||1!==d.nodeType||!(c.contains?c.contains(d):a.compareDocumentPosition&&16&a.compareDocumentPosition(d)))}:function(a,b){if(b)while(b=b.parentNode)if(b===a)return!0;return!1},B=b?function(a,b){if(a===b)return l=!0,0;var d=!a.compareDocumentPosition-!b.compareDocumentPosition;return d?d:(d=(a.ownerDocument||a)===(b.ownerDocument||b)?a.compareDocumentPosition(b):1,1&d||!c.sortDetached&&b.compareDocumentPosition(a)===d?a===n||a.ownerDocument===v&&t(v,a)?-1:b===n||b.ownerDocument===v&&t(v,b)?1:k?I(k,a)-I(k,b):0:4&d?-1:1)}:function(a,b){if(a===b)return l=!0,0;var c,d=0,e=a.parentNode,f=b.parentNode,g=[a],h=[b];if(!e||!f)return a===n?-1:b===n?1:e?-1:f?1:k?I(k,a)-I(k,b):0;if(e===f)return la(a,b);c=a;while(c=c.parentNode)g.unshift(c);c=b;while(c=c.parentNode)h.unshift(c);while(g[d]===h[d])d++;return d?la(g[d],h[d]):g[d]===v?-1:h[d]===v?1:0},n):n},ga.matches=function(a,b){return ga(a,null,null,b)},ga.matchesSelector=function(a,b){if((a.ownerDocument||a)!==n&&m(a),b=b.replace(S,"='$1']"),c.matchesSelector&&p&&!A[b+" "]&&(!r||!r.test(b))&&(!q||!q.test(b)))try{var d=s.call(a,b);if(d||c.disconnectedMatch||a.document&&11!==a.document.nodeType)return d}catch(e){}return ga(b,n,null,[a]).length>0},ga.contains=function(a,b){return(a.ownerDocument||a)!==n&&m(a),t(a,b)},ga.attr=function(a,b){(a.ownerDocument||a)!==n&&m(a);var e=d.attrHandle[b.toLowerCase()],f=e&&C.call(d.attrHandle,b.toLowerCase())?e(a,b,!p):void 0;return void 0!==f?f:c.attributes||!p?a.getAttribute(b):(f=a.getAttributeNode(b))&&f.specified?f.value:null},ga.escape=function(a){return(a+"").replace(ba,ca)},ga.error=function(a){throw new Error("Syntax error, unrecognized expression: "+a)},ga.uniqueSort=function(a){var b,d=[],e=0,f=0;if(l=!c.detectDuplicates,k=!c.sortStable&&a.slice(0),a.sort(B),l){while(b=a[f++])b===a[f]&&(e=d.push(f));while(e--)a.splice(d[e],1)}return k=null,a},e=ga.getText=function(a){var b,c="",d=0,f=a.nodeType;if(f){if(1===f||9===f||11===f){if("string"==typeof a.textContent)return a.textContent;for(a=a.firstChild;a;a=a.nextSibling)c+=e(a)}else if(3===f||4===f)return a.nodeValue}else while(b=a[d++])c+=e(b);return c},d=ga.selectors={cacheLength:50,createPseudo:ia,match:V,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(a){return a[1]=a[1].replace(_,aa),a[3]=(a[3]||a[4]||a[5]||"").replace(_,aa),"~="===a[2]&&(a[3]=" "+a[3]+" "),a.slice(0,4)},CHILD:function(a){return a[1]=a[1].toLowerCase(),"nth"===a[1].slice(0,3)?(a[3]||ga.error(a[0]),a[4]=+(a[4]?a[5]+(a[6]||1):2*("even"===a[3]||"odd"===a[3])),a[5]=+(a[7]+a[8]||"odd"===a[3])):a[3]&&ga.error(a[0]),a},PSEUDO:function(a){var b,c=!a[6]&&a[2];return V.CHILD.test(a[0])?null:(a[3]?a[2]=a[4]||a[5]||"":c&&T.test(c)&&(b=g(c,!0))&&(b=c.indexOf(")",c.length-b)-c.length)&&(a[0]=a[0].slice(0,b),a[2]=c.slice(0,b)),a.slice(0,3))}},filter:{TAG:function(a){var b=a.replace(_,aa).toLowerCase();return"*"===a?function(){return!0}:function(a){return a.nodeName&&a.nodeName.toLowerCase()===b}},CLASS:function(a){var b=y[a+" "];return b||(b=new RegExp("(^|"+K+")"+a+"("+K+"|$)"))&&y(a,function(a){return b.test("string"==typeof a.className&&a.className||"undefined"!=typeof a.getAttribute&&a.getAttribute("class")||"")})},ATTR:function(a,b,c){return function(d){var e=ga.attr(d,a);return null==e?"!="===b:!b||(e+="","="===b?e===c:"!="===b?e!==c:"^="===b?c&&0===e.indexOf(c):"*="===b?c&&e.indexOf(c)>-1:"$="===b?c&&e.slice(-c.length)===c:"~="===b?(" "+e.replace(O," ")+" ").indexOf(c)>-1:"|="===b&&(e===c||e.slice(0,c.length+1)===c+"-"))}},CHILD:function(a,b,c,d,e){var f="nth"!==a.slice(0,3),g="last"!==a.slice(-4),h="of-type"===b;return 1===d&&0===e?function(a){return!!a.parentNode}:function(b,c,i){var j,k,l,m,n,o,p=f!==g?"nextSibling":"previousSibling",q=b.parentNode,r=h&&b.nodeName.toLowerCase(),s=!i&&!h,t=!1;if(q){if(f){while(p){m=b;while(m=m[p])if(h?m.nodeName.toLowerCase()===r:1===m.nodeType)return!1;o=p="only"===a&&!o&&"nextSibling"}return!0}if(o=[g?q.firstChild:q.lastChild],g&&s){m=q,l=m[u]||(m[u]={}),k=l[m.uniqueID]||(l[m.uniqueID]={}),j=k[a]||[],n=j[0]===w&&j[1],t=n&&j[2],m=n&&q.childNodes[n];while(m=++n&&m&&m[p]||(t=n=0)||o.pop())if(1===m.nodeType&&++t&&m===b){k[a]=[w,n,t];break}}else if(s&&(m=b,l=m[u]||(m[u]={}),k=l[m.uniqueID]||(l[m.uniqueID]={}),j=k[a]||[],n=j[0]===w&&j[1],t=n),t===!1)while(m=++n&&m&&m[p]||(t=n=0)||o.pop())if((h?m.nodeName.toLowerCase()===r:1===m.nodeType)&&++t&&(s&&(l=m[u]||(m[u]={}),k=l[m.uniqueID]||(l[m.uniqueID]={}),k[a]=[w,t]),m===b))break;return t-=e,t===d||t%d===0&&t/d>=0}}},PSEUDO:function(a,b){var c,e=d.pseudos[a]||d.setFilters[a.toLowerCase()]||ga.error("unsupported pseudo: "+a);return e[u]?e(b):e.length>1?(c=[a,a,"",b],d.setFilters.hasOwnProperty(a.toLowerCase())?ia(function(a,c){var d,f=e(a,b),g=f.length;while(g--)d=I(a,f[g]),a[d]=!(c[d]=f[g])}):function(a){return e(a,0,c)}):e}},pseudos:{not:ia(function(a){var b=[],c=[],d=h(a.replace(P,"$1"));return d[u]?ia(function(a,b,c,e){var f,g=d(a,null,e,[]),h=a.length;while(h--)(f=g[h])&&(a[h]=!(b[h]=f))}):function(a,e,f){return b[0]=a,d(b,null,f,c),b[0]=null,!c.pop()}}),has:ia(function(a){return function(b){return ga(a,b).length>0}}),contains:ia(function(a){return a=a.replace(_,aa),function(b){return(b.textContent||b.innerText||e(b)).indexOf(a)>-1}}),lang:ia(function(a){return U.test(a||"")||ga.error("unsupported lang: "+a),a=a.replace(_,aa).toLowerCase(),function(b){var c;do if(c=p?b.lang:b.getAttribute("xml:lang")||b.getAttribute("lang"))return c=c.toLowerCase(),c===a||0===c.indexOf(a+"-");while((b=b.parentNode)&&1===b.nodeType);return!1}}),target:function(b){var c=a.location&&a.location.hash;return c&&c.slice(1)===b.id},root:function(a){return a===o},focus:function(a){return a===n.activeElement&&(!n.hasFocus||n.hasFocus())&&!!(a.type||a.href||~a.tabIndex)},enabled:oa(!1),disabled:oa(!0),checked:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&!!a.checked||"option"===b&&!!a.selected},selected:function(a){return a.parentNode&&a.parentNode.selectedIndex,a.selected===!0},empty:function(a){for(a=a.firstChild;a;a=a.nextSibling)if(a.nodeType<6)return!1;return!0},parent:function(a){return!d.pseudos.empty(a)},header:function(a){return X.test(a.nodeName)},input:function(a){return W.test(a.nodeName)},button:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&"button"===a.type||"button"===b},text:function(a){var b;return"input"===a.nodeName.toLowerCase()&&"text"===a.type&&(null==(b=a.getAttribute("type"))||"text"===b.toLowerCase())},first:pa(function(){return[0]}),last:pa(function(a,b){return[b-1]}),eq:pa(function(a,b,c){return[c<0?c+b:c]}),even:pa(function(a,b){for(var c=0;c<b;c+=2)a.push(c);return a}),odd:pa(function(a,b){for(var c=1;c<b;c+=2)a.push(c);return a}),lt:pa(function(a,b,c){for(var d=c<0?c+b:c;--d>=0;)a.push(d);return a}),gt:pa(function(a,b,c){for(var d=c<0?c+b:c;++d<b;)a.push(d);return a})}},d.pseudos.nth=d.pseudos.eq;for(b in{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})d.pseudos[b]=ma(b);for(b in{submit:!0,reset:!0})d.pseudos[b]=na(b);function ra(){}ra.prototype=d.filters=d.pseudos,d.setFilters=new ra,g=ga.tokenize=function(a,b){var c,e,f,g,h,i,j,k=z[a+" "];if(k)return b?0:k.slice(0);h=a,i=[],j=d.preFilter;while(h){c&&!(e=Q.exec(h))||(e&&(h=h.slice(e[0].length)||h),i.push(f=[])),c=!1,(e=R.exec(h))&&(c=e.shift(),f.push({value:c,type:e[0].replace(P," ")}),h=h.slice(c.length));for(g in d.filter)!(e=V[g].exec(h))||j[g]&&!(e=j[g](e))||(c=e.shift(),f.push({value:c,type:g,matches:e}),h=h.slice(c.length));if(!c)break}return b?h.length:h?ga.error(a):z(a,i).slice(0)};function sa(a){for(var b=0,c=a.length,d="";b<c;b++)d+=a[b].value;return d}function ta(a,b,c){var d=b.dir,e=b.next,f=e||d,g=c&&"parentNode"===f,h=x++;return b.first?function(b,c,e){while(b=b[d])if(1===b.nodeType||g)return a(b,c,e);return!1}:function(b,c,i){var j,k,l,m=[w,h];if(i){while(b=b[d])if((1===b.nodeType||g)&&a(b,c,i))return!0}else while(b=b[d])if(1===b.nodeType||g)if(l=b[u]||(b[u]={}),k=l[b.uniqueID]||(l[b.uniqueID]={}),e&&e===b.nodeName.toLowerCase())b=b[d]||b;else{if((j=k[f])&&j[0]===w&&j[1]===h)return m[2]=j[2];if(k[f]=m,m[2]=a(b,c,i))return!0}return!1}}function ua(a){return a.length>1?function(b,c,d){var e=a.length;while(e--)if(!a[e](b,c,d))return!1;return!0}:a[0]}function va(a,b,c){for(var d=0,e=b.length;d<e;d++)ga(a,b[d],c);return c}function wa(a,b,c,d,e){for(var f,g=[],h=0,i=a.length,j=null!=b;h<i;h++)(f=a[h])&&(c&&!c(f,d,e)||(g.push(f),j&&b.push(h)));return g}function xa(a,b,c,d,e,f){return d&&!d[u]&&(d=xa(d)),e&&!e[u]&&(e=xa(e,f)),ia(function(f,g,h,i){var j,k,l,m=[],n=[],o=g.length,p=f||va(b||"*",h.nodeType?[h]:h,[]),q=!a||!f&&b?p:wa(p,m,a,h,i),r=c?e||(f?a:o||d)?[]:g:q;if(c&&c(q,r,h,i),d){j=wa(r,n),d(j,[],h,i),k=j.length;while(k--)(l=j[k])&&(r[n[k]]=!(q[n[k]]=l))}if(f){if(e||a){if(e){j=[],k=r.length;while(k--)(l=r[k])&&j.push(q[k]=l);e(null,r=[],j,i)}k=r.length;while(k--)(l=r[k])&&(j=e?I(f,l):m[k])>-1&&(f[j]=!(g[j]=l))}}else r=wa(r===g?r.splice(o,r.length):r),e?e(null,g,r,i):G.apply(g,r)})}function ya(a){for(var b,c,e,f=a.length,g=d.relative[a[0].type],h=g||d.relative[" "],i=g?1:0,k=ta(function(a){return a===b},h,!0),l=ta(function(a){return I(b,a)>-1},h,!0),m=[function(a,c,d){var e=!g&&(d||c!==j)||((b=c).nodeType?k(a,c,d):l(a,c,d));return b=null,e}];i<f;i++)if(c=d.relative[a[i].type])m=[ta(ua(m),c)];else{if(c=d.filter[a[i].type].apply(null,a[i].matches),c[u]){for(e=++i;e<f;e++)if(d.relative[a[e].type])break;return xa(i>1&&ua(m),i>1&&sa(a.slice(0,i-1).concat({value:" "===a[i-2].type?"*":""})).replace(P,"$1"),c,i<e&&ya(a.slice(i,e)),e<f&&ya(a=a.slice(e)),e<f&&sa(a))}m.push(c)}return ua(m)}function za(a,b){var c=b.length>0,e=a.length>0,f=function(f,g,h,i,k){var l,o,q,r=0,s="0",t=f&&[],u=[],v=j,x=f||e&&d.find.TAG("*",k),y=w+=null==v?1:Math.random()||.1,z=x.length;for(k&&(j=g===n||g||k);s!==z&&null!=(l=x[s]);s++){if(e&&l){o=0,g||l.ownerDocument===n||(m(l),h=!p);while(q=a[o++])if(q(l,g||n,h)){i.push(l);break}k&&(w=y)}c&&((l=!q&&l)&&r--,f&&t.push(l))}if(r+=s,c&&s!==r){o=0;while(q=b[o++])q(t,u,g,h);if(f){if(r>0)while(s--)t[s]||u[s]||(u[s]=E.call(i));u=wa(u)}G.apply(i,u),k&&!f&&u.length>0&&r+b.length>1&&ga.uniqueSort(i)}return k&&(w=y,j=v),t};return c?ia(f):f}return h=ga.compile=function(a,b){var c,d=[],e=[],f=A[a+" "];if(!f){b||(b=g(a)),c=b.length;while(c--)f=ya(b[c]),f[u]?d.push(f):e.push(f);f=A(a,za(e,d)),f.selector=a}return f},i=ga.select=function(a,b,c,e){var f,i,j,k,l,m="function"==typeof a&&a,n=!e&&g(a=m.selector||a);if(c=c||[],1===n.length){if(i=n[0]=n[0].slice(0),i.length>2&&"ID"===(j=i[0]).type&&9===b.nodeType&&p&&d.relative[i[1].type]){if(b=(d.find.ID(j.matches[0].replace(_,aa),b)||[])[0],!b)return c;m&&(b=b.parentNode),a=a.slice(i.shift().value.length)}f=V.needsContext.test(a)?0:i.length;while(f--){if(j=i[f],d.relative[k=j.type])break;if((l=d.find[k])&&(e=l(j.matches[0].replace(_,aa),$.test(i[0].type)&&qa(b.parentNode)||b))){if(i.splice(f,1),a=e.length&&sa(i),!a)return G.apply(c,e),c;break}}}return(m||h(a,n))(e,b,!p,c,!b||$.test(a)&&qa(b.parentNode)||b),c},c.sortStable=u.split("").sort(B).join("")===u,c.detectDuplicates=!!l,m(),c.sortDetached=ja(function(a){return 1&a.compareDocumentPosition(n.createElement("fieldset"))}),ja(function(a){return a.innerHTML="<a href='#'></a>","#"===a.firstChild.getAttribute("href")})||ka("type|href|height|width",function(a,b,c){if(!c)return a.getAttribute(b,"type"===b.toLowerCase()?1:2)}),c.attributes&&ja(function(a){return a.innerHTML="<input/>",a.firstChild.setAttribute("value",""),""===a.firstChild.getAttribute("value")})||ka("value",function(a,b,c){if(!c&&"input"===a.nodeName.toLowerCase())return a.defaultValue}),ja(function(a){return null==a.getAttribute("disabled")})||ka(J,function(a,b,c){var d;if(!c)return a[b]===!0?b.toLowerCase():(d=a.getAttributeNode(b))&&d.specified?d.value:null}),ga}(a);r.find=x,r.expr=x.selectors,r.expr[":"]=r.expr.pseudos,r.uniqueSort=r.unique=x.uniqueSort,r.text=x.getText,r.isXMLDoc=x.isXML,r.contains=x.contains,r.escapeSelector=x.escape;var y=function(a,b,c){var d=[],e=void 0!==c;while((a=a[b])&&9!==a.nodeType)if(1===a.nodeType){if(e&&r(a).is(c))break;d.push(a)}return d},z=function(a,b){for(var c=[];a;a=a.nextSibling)1===a.nodeType&&a!==b&&c.push(a);return c},A=r.expr.match.needsContext,B=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i,C=/^.[^:#\[\.,]*$/;function D(a,b,c){return r.isFunction(b)?r.grep(a,function(a,d){return!!b.call(a,d,a)!==c}):b.nodeType?r.grep(a,function(a){return a===b!==c}):"string"!=typeof b?r.grep(a,function(a){return i.call(b,a)>-1!==c}):C.test(b)?r.filter(b,a,c):(b=r.filter(b,a),r.grep(a,function(a){return i.call(b,a)>-1!==c&&1===a.nodeType}))}r.filter=function(a,b,c){var d=b[0];return c&&(a=":not("+a+")"),1===b.length&&1===d.nodeType?r.find.matchesSelector(d,a)?[d]:[]:r.find.matches(a,r.grep(b,function(a){return 1===a.nodeType}))},r.fn.extend({find:function(a){var b,c,d=this.length,e=this;if("string"!=typeof a)return this.pushStack(r(a).filter(function(){for(b=0;b<d;b++)if(r.contains(e[b],this))return!0}));for(c=this.pushStack([]),b=0;b<d;b++)r.find(a,e[b],c);return d>1?r.uniqueSort(c):c},filter:function(a){return this.pushStack(D(this,a||[],!1))},not:function(a){return this.pushStack(D(this,a||[],!0))},is:function(a){return!!D(this,"string"==typeof a&&A.test(a)?r(a):a||[],!1).length}});var E,F=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/,G=r.fn.init=function(a,b,c){var e,f;if(!a)return this;if(c=c||E,"string"==typeof a){if(e="<"===a[0]&&">"===a[a.length-1]&&a.length>=3?[null,a,null]:F.exec(a),!e||!e[1]&&b)return!b||b.jquery?(b||c).find(a):this.constructor(b).find(a);if(e[1]){if(b=b instanceof r?b[0]:b,r.merge(this,r.parseHTML(e[1],b&&b.nodeType?b.ownerDocument||b:d,!0)),B.test(e[1])&&r.isPlainObject(b))for(e in b)r.isFunction(this[e])?this[e](b[e]):this.attr(e,b[e]);return this}return f=d.getElementById(e[2]),f&&(this[0]=f,this.length=1),this}return a.nodeType?(this[0]=a,this.length=1,this):r.isFunction(a)?void 0!==c.ready?c.ready(a):a(r):r.makeArray(a,this)};G.prototype=r.fn,E=r(d);var H=/^(?:parents|prev(?:Until|All))/,I={children:!0,contents:!0,next:!0,prev:!0};r.fn.extend({has:function(a){var b=r(a,this),c=b.length;return this.filter(function(){for(var a=0;a<c;a++)if(r.contains(this,b[a]))return!0})},closest:function(a,b){var c,d=0,e=this.length,f=[],g="string"!=typeof a&&r(a);if(!A.test(a))for(;d<e;d++)for(c=this[d];c&&c!==b;c=c.parentNode)if(c.nodeType<11&&(g?g.index(c)>-1:1===c.nodeType&&r.find.matchesSelector(c,a))){f.push(c);break}return this.pushStack(f.length>1?r.uniqueSort(f):f)},index:function(a){return a?"string"==typeof a?i.call(r(a),this[0]):i.call(this,a.jquery?a[0]:a):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(a,b){return this.pushStack(r.uniqueSort(r.merge(this.get(),r(a,b))))},addBack:function(a){return this.add(null==a?this.prevObject:this.prevObject.filter(a))}});function J(a,b){while((a=a[b])&&1!==a.nodeType);return a}r.each({parent:function(a){var b=a.parentNode;return b&&11!==b.nodeType?b:null},parents:function(a){return y(a,"parentNode")},parentsUntil:function(a,b,c){return y(a,"parentNode",c)},next:function(a){return J(a,"nextSibling")},prev:function(a){return J(a,"previousSibling")},nextAll:function(a){return y(a,"nextSibling")},prevAll:function(a){return y(a,"previousSibling")},nextUntil:function(a,b,c){return y(a,"nextSibling",c)},prevUntil:function(a,b,c){return y(a,"previousSibling",c)},siblings:function(a){return z((a.parentNode||{}).firstChild,a)},children:function(a){return z(a.firstChild)},contents:function(a){return a.contentDocument||r.merge([],a.childNodes)}},function(a,b){r.fn[a]=function(c,d){var e=r.map(this,b,c);return"Until"!==a.slice(-5)&&(d=c),d&&"string"==typeof d&&(e=r.filter(d,e)),this.length>1&&(I[a]||r.uniqueSort(e),H.test(a)&&e.reverse()),this.pushStack(e)}});var K=/[^\x20\t\r\n\f]+/g;function L(a){var b={};return r.each(a.match(K)||[],function(a,c){b[c]=!0}),b}r.Callbacks=function(a){a="string"==typeof a?L(a):r.extend({},a);var b,c,d,e,f=[],g=[],h=-1,i=function(){for(e=a.once,d=b=!0;g.length;h=-1){c=g.shift();while(++h<f.length)f[h].apply(c[0],c[1])===!1&&a.stopOnFalse&&(h=f.length,c=!1)}a.memory||(c=!1),b=!1,e&&(f=c?[]:"")},j={add:function(){return f&&(c&&!b&&(h=f.length-1,g.push(c)),function d(b){r.each(b,function(b,c){r.isFunction(c)?a.unique&&j.has(c)||f.push(c):c&&c.length&&"string"!==r.type(c)&&d(c)})}(arguments),c&&!b&&i()),this},remove:function(){return r.each(arguments,function(a,b){var c;while((c=r.inArray(b,f,c))>-1)f.splice(c,1),c<=h&&h--}),this},has:function(a){return a?r.inArray(a,f)>-1:f.length>0},empty:function(){return f&&(f=[]),this},disable:function(){return e=g=[],f=c="",this},disabled:function(){return!f},lock:function(){return e=g=[],c||b||(f=c=""),this},locked:function(){return!!e},fireWith:function(a,c){return e||(c=c||[],c=[a,c.slice?c.slice():c],g.push(c),b||i()),this},fire:function(){return j.fireWith(this,arguments),this},fired:function(){return!!d}};return j};function M(a){return a}function N(a){throw a}function O(a,b,c){var d;try{a&&r.isFunction(d=a.promise)?d.call(a).done(b).fail(c):a&&r.isFunction(d=a.then)?d.call(a,b,c):b.call(void 0,a)}catch(a){c.call(void 0,a)}}r.extend({Deferred:function(b){var c=[["notify","progress",r.Callbacks("memory"),r.Callbacks("memory"),2],["resolve","done",r.Callbacks("once memory"),r.Callbacks("once memory"),0,"resolved"],["reject","fail",r.Callbacks("once memory"),r.Callbacks("once memory"),1,"rejected"]],d="pending",e={state:function(){return d},always:function(){return f.done(arguments).fail(arguments),this},"catch":function(a){return e.then(null,a)},pipe:function(){var a=arguments;return r.Deferred(function(b){r.each(c,function(c,d){var e=r.isFunction(a[d[4]])&&a[d[4]];f[d[1]](function(){var a=e&&e.apply(this,arguments);a&&r.isFunction(a.promise)?a.promise().progress(b.notify).done(b.resolve).fail(b.reject):b[d[0]+"With"](this,e?[a]:arguments)})}),a=null}).promise()},then:function(b,d,e){var f=0;function g(b,c,d,e){return function(){var h=this,i=arguments,j=function(){var a,j;if(!(b<f)){if(a=d.apply(h,i),a===c.promise())throw new TypeError("Thenable self-resolution");j=a&&("object"==typeof a||"function"==typeof a)&&a.then,r.isFunction(j)?e?j.call(a,g(f,c,M,e),g(f,c,N,e)):(f++,j.call(a,g(f,c,M,e),g(f,c,N,e),g(f,c,M,c.notifyWith))):(d!==M&&(h=void 0,i=[a]),(e||c.resolveWith)(h,i))}},k=e?j:function(){try{j()}catch(a){r.Deferred.exceptionHook&&r.Deferred.exceptionHook(a,k.stackTrace),b+1>=f&&(d!==N&&(h=void 0,i=[a]),c.rejectWith(h,i))}};b?k():(r.Deferred.getStackHook&&(k.stackTrace=r.Deferred.getStackHook()),a.setTimeout(k))}}return r.Deferred(function(a){c[0][3].add(g(0,a,r.isFunction(e)?e:M,a.notifyWith)),c[1][3].add(g(0,a,r.isFunction(b)?b:M)),c[2][3].add(g(0,a,r.isFunction(d)?d:N))}).promise()},promise:function(a){return null!=a?r.extend(a,e):e}},f={};return r.each(c,function(a,b){var g=b[2],h=b[5];e[b[1]]=g.add,h&&g.add(function(){d=h},c[3-a][2].disable,c[0][2].lock),g.add(b[3].fire),f[b[0]]=function(){return f[b[0]+"With"](this===f?void 0:this,arguments),this},f[b[0]+"With"]=g.fireWith}),e.promise(f),b&&b.call(f,f),f},when:function(a){var b=arguments.length,c=b,d=Array(c),e=f.call(arguments),g=r.Deferred(),h=function(a){return function(c){d[a]=this,e[a]=arguments.length>1?f.call(arguments):c,--b||g.resolveWith(d,e)}};if(b<=1&&(O(a,g.done(h(c)).resolve,g.reject),"pending"===g.state()||r.isFunction(e[c]&&e[c].then)))return g.then();while(c--)O(e[c],h(c),g.reject);return g.promise()}});var P=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;r.Deferred.exceptionHook=function(b,c){a.console&&a.console.warn&&b&&P.test(b.name)&&a.console.warn("jQuery.Deferred exception: "+b.message,b.stack,c)},r.readyException=function(b){a.setTimeout(function(){throw b})};var Q=r.Deferred();r.fn.ready=function(a){return Q.then(a)["catch"](function(a){r.readyException(a)}),this},r.extend({isReady:!1,readyWait:1,holdReady:function(a){a?r.readyWait++:r.ready(!0)},ready:function(a){(a===!0?--r.readyWait:r.isReady)||(r.isReady=!0,a!==!0&&--r.readyWait>0||Q.resolveWith(d,[r]))}}),r.ready.then=Q.then;function R(){d.removeEventListener("DOMContentLoaded",R),
  3 +a.removeEventListener("load",R),r.ready()}"complete"===d.readyState||"loading"!==d.readyState&&!d.documentElement.doScroll?a.setTimeout(r.ready):(d.addEventListener("DOMContentLoaded",R),a.addEventListener("load",R));var S=function(a,b,c,d,e,f,g){var h=0,i=a.length,j=null==c;if("object"===r.type(c)){e=!0;for(h in c)S(a,b,h,c[h],!0,f,g)}else if(void 0!==d&&(e=!0,r.isFunction(d)||(g=!0),j&&(g?(b.call(a,d),b=null):(j=b,b=function(a,b,c){return j.call(r(a),c)})),b))for(;h<i;h++)b(a[h],c,g?d:d.call(a[h],h,b(a[h],c)));return e?a:j?b.call(a):i?b(a[0],c):f},T=function(a){return 1===a.nodeType||9===a.nodeType||!+a.nodeType};function U(){this.expando=r.expando+U.uid++}U.uid=1,U.prototype={cache:function(a){var b=a[this.expando];return b||(b={},T(a)&&(a.nodeType?a[this.expando]=b:Object.defineProperty(a,this.expando,{value:b,configurable:!0}))),b},set:function(a,b,c){var d,e=this.cache(a);if("string"==typeof b)e[r.camelCase(b)]=c;else for(d in b)e[r.camelCase(d)]=b[d];return e},get:function(a,b){return void 0===b?this.cache(a):a[this.expando]&&a[this.expando][r.camelCase(b)]},access:function(a,b,c){return void 0===b||b&&"string"==typeof b&&void 0===c?this.get(a,b):(this.set(a,b,c),void 0!==c?c:b)},remove:function(a,b){var c,d=a[this.expando];if(void 0!==d){if(void 0!==b){r.isArray(b)?b=b.map(r.camelCase):(b=r.camelCase(b),b=b in d?[b]:b.match(K)||[]),c=b.length;while(c--)delete d[b[c]]}(void 0===b||r.isEmptyObject(d))&&(a.nodeType?a[this.expando]=void 0:delete a[this.expando])}},hasData:function(a){var b=a[this.expando];return void 0!==b&&!r.isEmptyObject(b)}};var V=new U,W=new U,X=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,Y=/[A-Z]/g;function Z(a){return"true"===a||"false"!==a&&("null"===a?null:a===+a+""?+a:X.test(a)?JSON.parse(a):a)}function $(a,b,c){var d;if(void 0===c&&1===a.nodeType)if(d="data-"+b.replace(Y,"-$&").toLowerCase(),c=a.getAttribute(d),"string"==typeof c){try{c=Z(c)}catch(e){}W.set(a,b,c)}else c=void 0;return c}r.extend({hasData:function(a){return W.hasData(a)||V.hasData(a)},data:function(a,b,c){return W.access(a,b,c)},removeData:function(a,b){W.remove(a,b)},_data:function(a,b,c){return V.access(a,b,c)},_removeData:function(a,b){V.remove(a,b)}}),r.fn.extend({data:function(a,b){var c,d,e,f=this[0],g=f&&f.attributes;if(void 0===a){if(this.length&&(e=W.get(f),1===f.nodeType&&!V.get(f,"hasDataAttrs"))){c=g.length;while(c--)g[c]&&(d=g[c].name,0===d.indexOf("data-")&&(d=r.camelCase(d.slice(5)),$(f,d,e[d])));V.set(f,"hasDataAttrs",!0)}return e}return"object"==typeof a?this.each(function(){W.set(this,a)}):S(this,function(b){var c;if(f&&void 0===b){if(c=W.get(f,a),void 0!==c)return c;if(c=$(f,a),void 0!==c)return c}else this.each(function(){W.set(this,a,b)})},null,b,arguments.length>1,null,!0)},removeData:function(a){return this.each(function(){W.remove(this,a)})}}),r.extend({queue:function(a,b,c){var d;if(a)return b=(b||"fx")+"queue",d=V.get(a,b),c&&(!d||r.isArray(c)?d=V.access(a,b,r.makeArray(c)):d.push(c)),d||[]},dequeue:function(a,b){b=b||"fx";var c=r.queue(a,b),d=c.length,e=c.shift(),f=r._queueHooks(a,b),g=function(){r.dequeue(a,b)};"inprogress"===e&&(e=c.shift(),d--),e&&("fx"===b&&c.unshift("inprogress"),delete f.stop,e.call(a,g,f)),!d&&f&&f.empty.fire()},_queueHooks:function(a,b){var c=b+"queueHooks";return V.get(a,c)||V.access(a,c,{empty:r.Callbacks("once memory").add(function(){V.remove(a,[b+"queue",c])})})}}),r.fn.extend({queue:function(a,b){var c=2;return"string"!=typeof a&&(b=a,a="fx",c--),arguments.length<c?r.queue(this[0],a):void 0===b?this:this.each(function(){var c=r.queue(this,a,b);r._queueHooks(this,a),"fx"===a&&"inprogress"!==c[0]&&r.dequeue(this,a)})},dequeue:function(a){return this.each(function(){r.dequeue(this,a)})},clearQueue:function(a){return this.queue(a||"fx",[])},promise:function(a,b){var c,d=1,e=r.Deferred(),f=this,g=this.length,h=function(){--d||e.resolveWith(f,[f])};"string"!=typeof a&&(b=a,a=void 0),a=a||"fx";while(g--)c=V.get(f[g],a+"queueHooks"),c&&c.empty&&(d++,c.empty.add(h));return h(),e.promise(b)}});var _=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,aa=new RegExp("^(?:([+-])=|)("+_+")([a-z%]*)$","i"),ba=["Top","Right","Bottom","Left"],ca=function(a,b){return a=b||a,"none"===a.style.display||""===a.style.display&&r.contains(a.ownerDocument,a)&&"none"===r.css(a,"display")},da=function(a,b,c,d){var e,f,g={};for(f in b)g[f]=a.style[f],a.style[f]=b[f];e=c.apply(a,d||[]);for(f in b)a.style[f]=g[f];return e};function ea(a,b,c,d){var e,f=1,g=20,h=d?function(){return d.cur()}:function(){return r.css(a,b,"")},i=h(),j=c&&c[3]||(r.cssNumber[b]?"":"px"),k=(r.cssNumber[b]||"px"!==j&&+i)&&aa.exec(r.css(a,b));if(k&&k[3]!==j){j=j||k[3],c=c||[],k=+i||1;do f=f||".5",k/=f,r.style(a,b,k+j);while(f!==(f=h()/i)&&1!==f&&--g)}return c&&(k=+k||+i||0,e=c[1]?k+(c[1]+1)*c[2]:+c[2],d&&(d.unit=j,d.start=k,d.end=e)),e}var fa={};function ga(a){var b,c=a.ownerDocument,d=a.nodeName,e=fa[d];return e?e:(b=c.body.appendChild(c.createElement(d)),e=r.css(b,"display"),b.parentNode.removeChild(b),"none"===e&&(e="block"),fa[d]=e,e)}function ha(a,b){for(var c,d,e=[],f=0,g=a.length;f<g;f++)d=a[f],d.style&&(c=d.style.display,b?("none"===c&&(e[f]=V.get(d,"display")||null,e[f]||(d.style.display="")),""===d.style.display&&ca(d)&&(e[f]=ga(d))):"none"!==c&&(e[f]="none",V.set(d,"display",c)));for(f=0;f<g;f++)null!=e[f]&&(a[f].style.display=e[f]);return a}r.fn.extend({show:function(){return ha(this,!0)},hide:function(){return ha(this)},toggle:function(a){return"boolean"==typeof a?a?this.show():this.hide():this.each(function(){ca(this)?r(this).show():r(this).hide()})}});var ia=/^(?:checkbox|radio)$/i,ja=/<([a-z][^\/\0>\x20\t\r\n\f]+)/i,ka=/^$|\/(?:java|ecma)script/i,la={option:[1,"<select multiple='multiple'>","</select>"],thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};la.optgroup=la.option,la.tbody=la.tfoot=la.colgroup=la.caption=la.thead,la.th=la.td;function ma(a,b){var c;return c="undefined"!=typeof a.getElementsByTagName?a.getElementsByTagName(b||"*"):"undefined"!=typeof a.querySelectorAll?a.querySelectorAll(b||"*"):[],void 0===b||b&&r.nodeName(a,b)?r.merge([a],c):c}function na(a,b){for(var c=0,d=a.length;c<d;c++)V.set(a[c],"globalEval",!b||V.get(b[c],"globalEval"))}var oa=/<|&#?\w+;/;function pa(a,b,c,d,e){for(var f,g,h,i,j,k,l=b.createDocumentFragment(),m=[],n=0,o=a.length;n<o;n++)if(f=a[n],f||0===f)if("object"===r.type(f))r.merge(m,f.nodeType?[f]:f);else if(oa.test(f)){g=g||l.appendChild(b.createElement("div")),h=(ja.exec(f)||["",""])[1].toLowerCase(),i=la[h]||la._default,g.innerHTML=i[1]+r.htmlPrefilter(f)+i[2],k=i[0];while(k--)g=g.lastChild;r.merge(m,g.childNodes),g=l.firstChild,g.textContent=""}else m.push(b.createTextNode(f));l.textContent="",n=0;while(f=m[n++])if(d&&r.inArray(f,d)>-1)e&&e.push(f);else if(j=r.contains(f.ownerDocument,f),g=ma(l.appendChild(f),"script"),j&&na(g),c){k=0;while(f=g[k++])ka.test(f.type||"")&&c.push(f)}return l}!function(){var a=d.createDocumentFragment(),b=a.appendChild(d.createElement("div")),c=d.createElement("input");c.setAttribute("type","radio"),c.setAttribute("checked","checked"),c.setAttribute("name","t"),b.appendChild(c),o.checkClone=b.cloneNode(!0).cloneNode(!0).lastChild.checked,b.innerHTML="<textarea>x</textarea>",o.noCloneChecked=!!b.cloneNode(!0).lastChild.defaultValue}();var qa=d.documentElement,ra=/^key/,sa=/^(?:mouse|pointer|contextmenu|drag|drop)|click/,ta=/^([^.]*)(?:\.(.+)|)/;function ua(){return!0}function va(){return!1}function wa(){try{return d.activeElement}catch(a){}}function xa(a,b,c,d,e,f){var g,h;if("object"==typeof b){"string"!=typeof c&&(d=d||c,c=void 0);for(h in b)xa(a,h,c,d,b[h],f);return a}if(null==d&&null==e?(e=c,d=c=void 0):null==e&&("string"==typeof c?(e=d,d=void 0):(e=d,d=c,c=void 0)),e===!1)e=va;else if(!e)return a;return 1===f&&(g=e,e=function(a){return r().off(a),g.apply(this,arguments)},e.guid=g.guid||(g.guid=r.guid++)),a.each(function(){r.event.add(this,b,e,d,c)})}r.event={global:{},add:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,n,o,p,q=V.get(a);if(q){c.handler&&(f=c,c=f.handler,e=f.selector),e&&r.find.matchesSelector(qa,e),c.guid||(c.guid=r.guid++),(i=q.events)||(i=q.events={}),(g=q.handle)||(g=q.handle=function(b){return"undefined"!=typeof r&&r.event.triggered!==b.type?r.event.dispatch.apply(a,arguments):void 0}),b=(b||"").match(K)||[""],j=b.length;while(j--)h=ta.exec(b[j])||[],n=p=h[1],o=(h[2]||"").split(".").sort(),n&&(l=r.event.special[n]||{},n=(e?l.delegateType:l.bindType)||n,l=r.event.special[n]||{},k=r.extend({type:n,origType:p,data:d,handler:c,guid:c.guid,selector:e,needsContext:e&&r.expr.match.needsContext.test(e),namespace:o.join(".")},f),(m=i[n])||(m=i[n]=[],m.delegateCount=0,l.setup&&l.setup.call(a,d,o,g)!==!1||a.addEventListener&&a.addEventListener(n,g)),l.add&&(l.add.call(a,k),k.handler.guid||(k.handler.guid=c.guid)),e?m.splice(m.delegateCount++,0,k):m.push(k),r.event.global[n]=!0)}},remove:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,n,o,p,q=V.hasData(a)&&V.get(a);if(q&&(i=q.events)){b=(b||"").match(K)||[""],j=b.length;while(j--)if(h=ta.exec(b[j])||[],n=p=h[1],o=(h[2]||"").split(".").sort(),n){l=r.event.special[n]||{},n=(d?l.delegateType:l.bindType)||n,m=i[n]||[],h=h[2]&&new RegExp("(^|\\.)"+o.join("\\.(?:.*\\.|)")+"(\\.|$)"),g=f=m.length;while(f--)k=m[f],!e&&p!==k.origType||c&&c.guid!==k.guid||h&&!h.test(k.namespace)||d&&d!==k.selector&&("**"!==d||!k.selector)||(m.splice(f,1),k.selector&&m.delegateCount--,l.remove&&l.remove.call(a,k));g&&!m.length&&(l.teardown&&l.teardown.call(a,o,q.handle)!==!1||r.removeEvent(a,n,q.handle),delete i[n])}else for(n in i)r.event.remove(a,n+b[j],c,d,!0);r.isEmptyObject(i)&&V.remove(a,"handle events")}},dispatch:function(a){var b=r.event.fix(a),c,d,e,f,g,h,i=new Array(arguments.length),j=(V.get(this,"events")||{})[b.type]||[],k=r.event.special[b.type]||{};for(i[0]=b,c=1;c<arguments.length;c++)i[c]=arguments[c];if(b.delegateTarget=this,!k.preDispatch||k.preDispatch.call(this,b)!==!1){h=r.event.handlers.call(this,b,j),c=0;while((f=h[c++])&&!b.isPropagationStopped()){b.currentTarget=f.elem,d=0;while((g=f.handlers[d++])&&!b.isImmediatePropagationStopped())b.rnamespace&&!b.rnamespace.test(g.namespace)||(b.handleObj=g,b.data=g.data,e=((r.event.special[g.origType]||{}).handle||g.handler).apply(f.elem,i),void 0!==e&&(b.result=e)===!1&&(b.preventDefault(),b.stopPropagation()))}return k.postDispatch&&k.postDispatch.call(this,b),b.result}},handlers:function(a,b){var c,d,e,f,g,h=[],i=b.delegateCount,j=a.target;if(i&&j.nodeType&&!("click"===a.type&&a.button>=1))for(;j!==this;j=j.parentNode||this)if(1===j.nodeType&&("click"!==a.type||j.disabled!==!0)){for(f=[],g={},c=0;c<i;c++)d=b[c],e=d.selector+" ",void 0===g[e]&&(g[e]=d.needsContext?r(e,this).index(j)>-1:r.find(e,this,null,[j]).length),g[e]&&f.push(d);f.length&&h.push({elem:j,handlers:f})}return j=this,i<b.length&&h.push({elem:j,handlers:b.slice(i)}),h},addProp:function(a,b){Object.defineProperty(r.Event.prototype,a,{enumerable:!0,configurable:!0,get:r.isFunction(b)?function(){if(this.originalEvent)return b(this.originalEvent)}:function(){if(this.originalEvent)return this.originalEvent[a]},set:function(b){Object.defineProperty(this,a,{enumerable:!0,configurable:!0,writable:!0,value:b})}})},fix:function(a){return a[r.expando]?a:new r.Event(a)},special:{load:{noBubble:!0},focus:{trigger:function(){if(this!==wa()&&this.focus)return this.focus(),!1},delegateType:"focusin"},blur:{trigger:function(){if(this===wa()&&this.blur)return this.blur(),!1},delegateType:"focusout"},click:{trigger:function(){if("checkbox"===this.type&&this.click&&r.nodeName(this,"input"))return this.click(),!1},_default:function(a){return r.nodeName(a.target,"a")}},beforeunload:{postDispatch:function(a){void 0!==a.result&&a.originalEvent&&(a.originalEvent.returnValue=a.result)}}}},r.removeEvent=function(a,b,c){a.removeEventListener&&a.removeEventListener(b,c)},r.Event=function(a,b){return this instanceof r.Event?(a&&a.type?(this.originalEvent=a,this.type=a.type,this.isDefaultPrevented=a.defaultPrevented||void 0===a.defaultPrevented&&a.returnValue===!1?ua:va,this.target=a.target&&3===a.target.nodeType?a.target.parentNode:a.target,this.currentTarget=a.currentTarget,this.relatedTarget=a.relatedTarget):this.type=a,b&&r.extend(this,b),this.timeStamp=a&&a.timeStamp||r.now(),void(this[r.expando]=!0)):new r.Event(a,b)},r.Event.prototype={constructor:r.Event,isDefaultPrevented:va,isPropagationStopped:va,isImmediatePropagationStopped:va,isSimulated:!1,preventDefault:function(){var a=this.originalEvent;this.isDefaultPrevented=ua,a&&!this.isSimulated&&a.preventDefault()},stopPropagation:function(){var a=this.originalEvent;this.isPropagationStopped=ua,a&&!this.isSimulated&&a.stopPropagation()},stopImmediatePropagation:function(){var a=this.originalEvent;this.isImmediatePropagationStopped=ua,a&&!this.isSimulated&&a.stopImmediatePropagation(),this.stopPropagation()}},r.each({altKey:!0,bubbles:!0,cancelable:!0,changedTouches:!0,ctrlKey:!0,detail:!0,eventPhase:!0,metaKey:!0,pageX:!0,pageY:!0,shiftKey:!0,view:!0,"char":!0,charCode:!0,key:!0,keyCode:!0,button:!0,buttons:!0,clientX:!0,clientY:!0,offsetX:!0,offsetY:!0,pointerId:!0,pointerType:!0,screenX:!0,screenY:!0,targetTouches:!0,toElement:!0,touches:!0,which:function(a){var b=a.button;return null==a.which&&ra.test(a.type)?null!=a.charCode?a.charCode:a.keyCode:!a.which&&void 0!==b&&sa.test(a.type)?1&b?1:2&b?3:4&b?2:0:a.which}},r.event.addProp),r.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(a,b){r.event.special[a]={delegateType:b,bindType:b,handle:function(a){var c,d=this,e=a.relatedTarget,f=a.handleObj;return e&&(e===d||r.contains(d,e))||(a.type=f.origType,c=f.handler.apply(this,arguments),a.type=b),c}}}),r.fn.extend({on:function(a,b,c,d){return xa(this,a,b,c,d)},one:function(a,b,c,d){return xa(this,a,b,c,d,1)},off:function(a,b,c){var d,e;if(a&&a.preventDefault&&a.handleObj)return d=a.handleObj,r(a.delegateTarget).off(d.namespace?d.origType+"."+d.namespace:d.origType,d.selector,d.handler),this;if("object"==typeof a){for(e in a)this.off(e,b,a[e]);return this}return b!==!1&&"function"!=typeof b||(c=b,b=void 0),c===!1&&(c=va),this.each(function(){r.event.remove(this,a,c,b)})}});var ya=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([a-z][^\/\0>\x20\t\r\n\f]*)[^>]*)\/>/gi,za=/<script|<style|<link/i,Aa=/checked\s*(?:[^=]|=\s*.checked.)/i,Ba=/^true\/(.*)/,Ca=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;function Da(a,b){return r.nodeName(a,"table")&&r.nodeName(11!==b.nodeType?b:b.firstChild,"tr")?a.getElementsByTagName("tbody")[0]||a:a}function Ea(a){return a.type=(null!==a.getAttribute("type"))+"/"+a.type,a}function Fa(a){var b=Ba.exec(a.type);return b?a.type=b[1]:a.removeAttribute("type"),a}function Ga(a,b){var c,d,e,f,g,h,i,j;if(1===b.nodeType){if(V.hasData(a)&&(f=V.access(a),g=V.set(b,f),j=f.events)){delete g.handle,g.events={};for(e in j)for(c=0,d=j[e].length;c<d;c++)r.event.add(b,e,j[e][c])}W.hasData(a)&&(h=W.access(a),i=r.extend({},h),W.set(b,i))}}function Ha(a,b){var c=b.nodeName.toLowerCase();"input"===c&&ia.test(a.type)?b.checked=a.checked:"input"!==c&&"textarea"!==c||(b.defaultValue=a.defaultValue)}function Ia(a,b,c,d){b=g.apply([],b);var e,f,h,i,j,k,l=0,m=a.length,n=m-1,q=b[0],s=r.isFunction(q);if(s||m>1&&"string"==typeof q&&!o.checkClone&&Aa.test(q))return a.each(function(e){var f=a.eq(e);s&&(b[0]=q.call(this,e,f.html())),Ia(f,b,c,d)});if(m&&(e=pa(b,a[0].ownerDocument,!1,a,d),f=e.firstChild,1===e.childNodes.length&&(e=f),f||d)){for(h=r.map(ma(e,"script"),Ea),i=h.length;l<m;l++)j=e,l!==n&&(j=r.clone(j,!0,!0),i&&r.merge(h,ma(j,"script"))),c.call(a[l],j,l);if(i)for(k=h[h.length-1].ownerDocument,r.map(h,Fa),l=0;l<i;l++)j=h[l],ka.test(j.type||"")&&!V.access(j,"globalEval")&&r.contains(k,j)&&(j.src?r._evalUrl&&r._evalUrl(j.src):p(j.textContent.replace(Ca,""),k))}return a}function Ja(a,b,c){for(var d,e=b?r.filter(b,a):a,f=0;null!=(d=e[f]);f++)c||1!==d.nodeType||r.cleanData(ma(d)),d.parentNode&&(c&&r.contains(d.ownerDocument,d)&&na(ma(d,"script")),d.parentNode.removeChild(d));return a}r.extend({htmlPrefilter:function(a){return a.replace(ya,"<$1></$2>")},clone:function(a,b,c){var d,e,f,g,h=a.cloneNode(!0),i=r.contains(a.ownerDocument,a);if(!(o.noCloneChecked||1!==a.nodeType&&11!==a.nodeType||r.isXMLDoc(a)))for(g=ma(h),f=ma(a),d=0,e=f.length;d<e;d++)Ha(f[d],g[d]);if(b)if(c)for(f=f||ma(a),g=g||ma(h),d=0,e=f.length;d<e;d++)Ga(f[d],g[d]);else Ga(a,h);return g=ma(h,"script"),g.length>0&&na(g,!i&&ma(a,"script")),h},cleanData:function(a){for(var b,c,d,e=r.event.special,f=0;void 0!==(c=a[f]);f++)if(T(c)){if(b=c[V.expando]){if(b.events)for(d in b.events)e[d]?r.event.remove(c,d):r.removeEvent(c,d,b.handle);c[V.expando]=void 0}c[W.expando]&&(c[W.expando]=void 0)}}}),r.fn.extend({detach:function(a){return Ja(this,a,!0)},remove:function(a){return Ja(this,a)},text:function(a){return S(this,function(a){return void 0===a?r.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=a)})},null,a,arguments.length)},append:function(){return Ia(this,arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=Da(this,a);b.appendChild(a)}})},prepend:function(){return Ia(this,arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=Da(this,a);b.insertBefore(a,b.firstChild)}})},before:function(){return Ia(this,arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this)})},after:function(){return Ia(this,arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this.nextSibling)})},empty:function(){for(var a,b=0;null!=(a=this[b]);b++)1===a.nodeType&&(r.cleanData(ma(a,!1)),a.textContent="");return this},clone:function(a,b){return a=null!=a&&a,b=null==b?a:b,this.map(function(){return r.clone(this,a,b)})},html:function(a){return S(this,function(a){var b=this[0]||{},c=0,d=this.length;if(void 0===a&&1===b.nodeType)return b.innerHTML;if("string"==typeof a&&!za.test(a)&&!la[(ja.exec(a)||["",""])[1].toLowerCase()]){a=r.htmlPrefilter(a);try{for(;c<d;c++)b=this[c]||{},1===b.nodeType&&(r.cleanData(ma(b,!1)),b.innerHTML=a);b=0}catch(e){}}b&&this.empty().append(a)},null,a,arguments.length)},replaceWith:function(){var a=[];return Ia(this,arguments,function(b){var c=this.parentNode;r.inArray(this,a)<0&&(r.cleanData(ma(this)),c&&c.replaceChild(b,this))},a)}}),r.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){r.fn[a]=function(a){for(var c,d=[],e=r(a),f=e.length-1,g=0;g<=f;g++)c=g===f?this:this.clone(!0),r(e[g])[b](c),h.apply(d,c.get());return this.pushStack(d)}});var Ka=/^margin/,La=new RegExp("^("+_+")(?!px)[a-z%]+$","i"),Ma=function(b){var c=b.ownerDocument.defaultView;return c&&c.opener||(c=a),c.getComputedStyle(b)};!function(){function b(){if(i){i.style.cssText="box-sizing:border-box;position:relative;display:block;margin:auto;border:1px;padding:1px;top:1%;width:50%",i.innerHTML="",qa.appendChild(h);var b=a.getComputedStyle(i);c="1%"!==b.top,g="2px"===b.marginLeft,e="4px"===b.width,i.style.marginRight="50%",f="4px"===b.marginRight,qa.removeChild(h),i=null}}var c,e,f,g,h=d.createElement("div"),i=d.createElement("div");i.style&&(i.style.backgroundClip="content-box",i.cloneNode(!0).style.backgroundClip="",o.clearCloneStyle="content-box"===i.style.backgroundClip,h.style.cssText="border:0;width:8px;height:0;top:0;left:-9999px;padding:0;margin-top:1px;position:absolute",h.appendChild(i),r.extend(o,{pixelPosition:function(){return b(),c},boxSizingReliable:function(){return b(),e},pixelMarginRight:function(){return b(),f},reliableMarginLeft:function(){return b(),g}}))}();function Na(a,b,c){var d,e,f,g,h=a.style;return c=c||Ma(a),c&&(g=c.getPropertyValue(b)||c[b],""!==g||r.contains(a.ownerDocument,a)||(g=r.style(a,b)),!o.pixelMarginRight()&&La.test(g)&&Ka.test(b)&&(d=h.width,e=h.minWidth,f=h.maxWidth,h.minWidth=h.maxWidth=h.width=g,g=c.width,h.width=d,h.minWidth=e,h.maxWidth=f)),void 0!==g?g+"":g}function Oa(a,b){return{get:function(){return a()?void delete this.get:(this.get=b).apply(this,arguments)}}}var Pa=/^(none|table(?!-c[ea]).+)/,Qa={position:"absolute",visibility:"hidden",display:"block"},Ra={letterSpacing:"0",fontWeight:"400"},Sa=["Webkit","Moz","ms"],Ta=d.createElement("div").style;function Ua(a){if(a in Ta)return a;var b=a[0].toUpperCase()+a.slice(1),c=Sa.length;while(c--)if(a=Sa[c]+b,a in Ta)return a}function Va(a,b,c){var d=aa.exec(b);return d?Math.max(0,d[2]-(c||0))+(d[3]||"px"):b}function Wa(a,b,c,d,e){var f,g=0;for(f=c===(d?"border":"content")?4:"width"===b?1:0;f<4;f+=2)"margin"===c&&(g+=r.css(a,c+ba[f],!0,e)),d?("content"===c&&(g-=r.css(a,"padding"+ba[f],!0,e)),"margin"!==c&&(g-=r.css(a,"border"+ba[f]+"Width",!0,e))):(g+=r.css(a,"padding"+ba[f],!0,e),"padding"!==c&&(g+=r.css(a,"border"+ba[f]+"Width",!0,e)));return g}function Xa(a,b,c){var d,e=!0,f=Ma(a),g="border-box"===r.css(a,"boxSizing",!1,f);if(a.getClientRects().length&&(d=a.getBoundingClientRect()[b]),d<=0||null==d){if(d=Na(a,b,f),(d<0||null==d)&&(d=a.style[b]),La.test(d))return d;e=g&&(o.boxSizingReliable()||d===a.style[b]),d=parseFloat(d)||0}return d+Wa(a,b,c||(g?"border":"content"),e,f)+"px"}r.extend({cssHooks:{opacity:{get:function(a,b){if(b){var c=Na(a,"opacity");return""===c?"1":c}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{"float":"cssFloat"},style:function(a,b,c,d){if(a&&3!==a.nodeType&&8!==a.nodeType&&a.style){var e,f,g,h=r.camelCase(b),i=a.style;return b=r.cssProps[h]||(r.cssProps[h]=Ua(h)||h),g=r.cssHooks[b]||r.cssHooks[h],void 0===c?g&&"get"in g&&void 0!==(e=g.get(a,!1,d))?e:i[b]:(f=typeof c,"string"===f&&(e=aa.exec(c))&&e[1]&&(c=ea(a,b,e),f="number"),null!=c&&c===c&&("number"===f&&(c+=e&&e[3]||(r.cssNumber[h]?"":"px")),o.clearCloneStyle||""!==c||0!==b.indexOf("background")||(i[b]="inherit"),g&&"set"in g&&void 0===(c=g.set(a,c,d))||(i[b]=c)),void 0)}},css:function(a,b,c,d){var e,f,g,h=r.camelCase(b);return b=r.cssProps[h]||(r.cssProps[h]=Ua(h)||h),g=r.cssHooks[b]||r.cssHooks[h],g&&"get"in g&&(e=g.get(a,!0,c)),void 0===e&&(e=Na(a,b,d)),"normal"===e&&b in Ra&&(e=Ra[b]),""===c||c?(f=parseFloat(e),c===!0||isFinite(f)?f||0:e):e}}),r.each(["height","width"],function(a,b){r.cssHooks[b]={get:function(a,c,d){if(c)return!Pa.test(r.css(a,"display"))||a.getClientRects().length&&a.getBoundingClientRect().width?Xa(a,b,d):da(a,Qa,function(){return Xa(a,b,d)})},set:function(a,c,d){var e,f=d&&Ma(a),g=d&&Wa(a,b,d,"border-box"===r.css(a,"boxSizing",!1,f),f);return g&&(e=aa.exec(c))&&"px"!==(e[3]||"px")&&(a.style[b]=c,c=r.css(a,b)),Va(a,c,g)}}}),r.cssHooks.marginLeft=Oa(o.reliableMarginLeft,function(a,b){if(b)return(parseFloat(Na(a,"marginLeft"))||a.getBoundingClientRect().left-da(a,{marginLeft:0},function(){return a.getBoundingClientRect().left}))+"px"}),r.each({margin:"",padding:"",border:"Width"},function(a,b){r.cssHooks[a+b]={expand:function(c){for(var d=0,e={},f="string"==typeof c?c.split(" "):[c];d<4;d++)e[a+ba[d]+b]=f[d]||f[d-2]||f[0];return e}},Ka.test(a)||(r.cssHooks[a+b].set=Va)}),r.fn.extend({css:function(a,b){return S(this,function(a,b,c){var d,e,f={},g=0;if(r.isArray(b)){for(d=Ma(a),e=b.length;g<e;g++)f[b[g]]=r.css(a,b[g],!1,d);return f}return void 0!==c?r.style(a,b,c):r.css(a,b)},a,b,arguments.length>1)}});function Ya(a,b,c,d,e){return new Ya.prototype.init(a,b,c,d,e)}r.Tween=Ya,Ya.prototype={constructor:Ya,init:function(a,b,c,d,e,f){this.elem=a,this.prop=c,this.easing=e||r.easing._default,this.options=b,this.start=this.now=this.cur(),this.end=d,this.unit=f||(r.cssNumber[c]?"":"px")},cur:function(){var a=Ya.propHooks[this.prop];return a&&a.get?a.get(this):Ya.propHooks._default.get(this)},run:function(a){var b,c=Ya.propHooks[this.prop];return this.options.duration?this.pos=b=r.easing[this.easing](a,this.options.duration*a,0,1,this.options.duration):this.pos=b=a,this.now=(this.end-this.start)*b+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),c&&c.set?c.set(this):Ya.propHooks._default.set(this),this}},Ya.prototype.init.prototype=Ya.prototype,Ya.propHooks={_default:{get:function(a){var b;return 1!==a.elem.nodeType||null!=a.elem[a.prop]&&null==a.elem.style[a.prop]?a.elem[a.prop]:(b=r.css(a.elem,a.prop,""),b&&"auto"!==b?b:0)},set:function(a){r.fx.step[a.prop]?r.fx.step[a.prop](a):1!==a.elem.nodeType||null==a.elem.style[r.cssProps[a.prop]]&&!r.cssHooks[a.prop]?a.elem[a.prop]=a.now:r.style(a.elem,a.prop,a.now+a.unit)}}},Ya.propHooks.scrollTop=Ya.propHooks.scrollLeft={set:function(a){a.elem.nodeType&&a.elem.parentNode&&(a.elem[a.prop]=a.now)}},r.easing={linear:function(a){return a},swing:function(a){return.5-Math.cos(a*Math.PI)/2},_default:"swing"},r.fx=Ya.prototype.init,r.fx.step={};var Za,$a,_a=/^(?:toggle|show|hide)$/,ab=/queueHooks$/;function bb(){$a&&(a.requestAnimationFrame(bb),r.fx.tick())}function cb(){return a.setTimeout(function(){Za=void 0}),Za=r.now()}function db(a,b){var c,d=0,e={height:a};for(b=b?1:0;d<4;d+=2-b)c=ba[d],e["margin"+c]=e["padding"+c]=a;return b&&(e.opacity=e.width=a),e}function eb(a,b,c){for(var d,e=(hb.tweeners[b]||[]).concat(hb.tweeners["*"]),f=0,g=e.length;f<g;f++)if(d=e[f].call(c,b,a))return d}function fb(a,b,c){var d,e,f,g,h,i,j,k,l="width"in b||"height"in b,m=this,n={},o=a.style,p=a.nodeType&&ca(a),q=V.get(a,"fxshow");c.queue||(g=r._queueHooks(a,"fx"),null==g.unqueued&&(g.unqueued=0,h=g.empty.fire,g.empty.fire=function(){g.unqueued||h()}),g.unqueued++,m.always(function(){m.always(function(){g.unqueued--,r.queue(a,"fx").length||g.empty.fire()})}));for(d in b)if(e=b[d],_a.test(e)){if(delete b[d],f=f||"toggle"===e,e===(p?"hide":"show")){if("show"!==e||!q||void 0===q[d])continue;p=!0}n[d]=q&&q[d]||r.style(a,d)}if(i=!r.isEmptyObject(b),i||!r.isEmptyObject(n)){l&&1===a.nodeType&&(c.overflow=[o.overflow,o.overflowX,o.overflowY],j=q&&q.display,null==j&&(j=V.get(a,"display")),k=r.css(a,"display"),"none"===k&&(j?k=j:(ha([a],!0),j=a.style.display||j,k=r.css(a,"display"),ha([a]))),("inline"===k||"inline-block"===k&&null!=j)&&"none"===r.css(a,"float")&&(i||(m.done(function(){o.display=j}),null==j&&(k=o.display,j="none"===k?"":k)),o.display="inline-block")),c.overflow&&(o.overflow="hidden",m.always(function(){o.overflow=c.overflow[0],o.overflowX=c.overflow[1],o.overflowY=c.overflow[2]})),i=!1;for(d in n)i||(q?"hidden"in q&&(p=q.hidden):q=V.access(a,"fxshow",{display:j}),f&&(q.hidden=!p),p&&ha([a],!0),m.done(function(){p||ha([a]),V.remove(a,"fxshow");for(d in n)r.style(a,d,n[d])})),i=eb(p?q[d]:0,d,m),d in q||(q[d]=i.start,p&&(i.end=i.start,i.start=0))}}function gb(a,b){var c,d,e,f,g;for(c in a)if(d=r.camelCase(c),e=b[d],f=a[c],r.isArray(f)&&(e=f[1],f=a[c]=f[0]),c!==d&&(a[d]=f,delete a[c]),g=r.cssHooks[d],g&&"expand"in g){f=g.expand(f),delete a[d];for(c in f)c in a||(a[c]=f[c],b[c]=e)}else b[d]=e}function hb(a,b,c){var d,e,f=0,g=hb.prefilters.length,h=r.Deferred().always(function(){delete i.elem}),i=function(){if(e)return!1;for(var b=Za||cb(),c=Math.max(0,j.startTime+j.duration-b),d=c/j.duration||0,f=1-d,g=0,i=j.tweens.length;g<i;g++)j.tweens[g].run(f);return h.notifyWith(a,[j,f,c]),f<1&&i?c:(h.resolveWith(a,[j]),!1)},j=h.promise({elem:a,props:r.extend({},b),opts:r.extend(!0,{specialEasing:{},easing:r.easing._default},c),originalProperties:b,originalOptions:c,startTime:Za||cb(),duration:c.duration,tweens:[],createTween:function(b,c){var d=r.Tween(a,j.opts,b,c,j.opts.specialEasing[b]||j.opts.easing);return j.tweens.push(d),d},stop:function(b){var c=0,d=b?j.tweens.length:0;if(e)return this;for(e=!0;c<d;c++)j.tweens[c].run(1);return b?(h.notifyWith(a,[j,1,0]),h.resolveWith(a,[j,b])):h.rejectWith(a,[j,b]),this}}),k=j.props;for(gb(k,j.opts.specialEasing);f<g;f++)if(d=hb.prefilters[f].call(j,a,k,j.opts))return r.isFunction(d.stop)&&(r._queueHooks(j.elem,j.opts.queue).stop=r.proxy(d.stop,d)),d;return r.map(k,eb,j),r.isFunction(j.opts.start)&&j.opts.start.call(a,j),r.fx.timer(r.extend(i,{elem:a,anim:j,queue:j.opts.queue})),j.progress(j.opts.progress).done(j.opts.done,j.opts.complete).fail(j.opts.fail).always(j.opts.always)}r.Animation=r.extend(hb,{tweeners:{"*":[function(a,b){var c=this.createTween(a,b);return ea(c.elem,a,aa.exec(b),c),c}]},tweener:function(a,b){r.isFunction(a)?(b=a,a=["*"]):a=a.match(K);for(var c,d=0,e=a.length;d<e;d++)c=a[d],hb.tweeners[c]=hb.tweeners[c]||[],hb.tweeners[c].unshift(b)},prefilters:[fb],prefilter:function(a,b){b?hb.prefilters.unshift(a):hb.prefilters.push(a)}}),r.speed=function(a,b,c){var e=a&&"object"==typeof a?r.extend({},a):{complete:c||!c&&b||r.isFunction(a)&&a,duration:a,easing:c&&b||b&&!r.isFunction(b)&&b};return r.fx.off||d.hidden?e.duration=0:"number"!=typeof e.duration&&(e.duration in r.fx.speeds?e.duration=r.fx.speeds[e.duration]:e.duration=r.fx.speeds._default),null!=e.queue&&e.queue!==!0||(e.queue="fx"),e.old=e.complete,e.complete=function(){r.isFunction(e.old)&&e.old.call(this),e.queue&&r.dequeue(this,e.queue)},e},r.fn.extend({fadeTo:function(a,b,c,d){return this.filter(ca).css("opacity",0).show().end().animate({opacity:b},a,c,d)},animate:function(a,b,c,d){var e=r.isEmptyObject(a),f=r.speed(b,c,d),g=function(){var b=hb(this,r.extend({},a),f);(e||V.get(this,"finish"))&&b.stop(!0)};return g.finish=g,e||f.queue===!1?this.each(g):this.queue(f.queue,g)},stop:function(a,b,c){var d=function(a){var b=a.stop;delete a.stop,b(c)};return"string"!=typeof a&&(c=b,b=a,a=void 0),b&&a!==!1&&this.queue(a||"fx",[]),this.each(function(){var b=!0,e=null!=a&&a+"queueHooks",f=r.timers,g=V.get(this);if(e)g[e]&&g[e].stop&&d(g[e]);else for(e in g)g[e]&&g[e].stop&&ab.test(e)&&d(g[e]);for(e=f.length;e--;)f[e].elem!==this||null!=a&&f[e].queue!==a||(f[e].anim.stop(c),b=!1,f.splice(e,1));!b&&c||r.dequeue(this,a)})},finish:function(a){return a!==!1&&(a=a||"fx"),this.each(function(){var b,c=V.get(this),d=c[a+"queue"],e=c[a+"queueHooks"],f=r.timers,g=d?d.length:0;for(c.finish=!0,r.queue(this,a,[]),e&&e.stop&&e.stop.call(this,!0),b=f.length;b--;)f[b].elem===this&&f[b].queue===a&&(f[b].anim.stop(!0),f.splice(b,1));for(b=0;b<g;b++)d[b]&&d[b].finish&&d[b].finish.call(this);delete c.finish})}}),r.each(["toggle","show","hide"],function(a,b){var c=r.fn[b];r.fn[b]=function(a,d,e){return null==a||"boolean"==typeof a?c.apply(this,arguments):this.animate(db(b,!0),a,d,e)}}),r.each({slideDown:db("show"),slideUp:db("hide"),slideToggle:db("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(a,b){r.fn[a]=function(a,c,d){return this.animate(b,a,c,d)}}),r.timers=[],r.fx.tick=function(){var a,b=0,c=r.timers;for(Za=r.now();b<c.length;b++)a=c[b],a()||c[b]!==a||c.splice(b--,1);c.length||r.fx.stop(),Za=void 0},r.fx.timer=function(a){r.timers.push(a),a()?r.fx.start():r.timers.pop()},r.fx.interval=13,r.fx.start=function(){$a||($a=a.requestAnimationFrame?a.requestAnimationFrame(bb):a.setInterval(r.fx.tick,r.fx.interval))},r.fx.stop=function(){a.cancelAnimationFrame?a.cancelAnimationFrame($a):a.clearInterval($a),$a=null},r.fx.speeds={slow:600,fast:200,_default:400},r.fn.delay=function(b,c){return b=r.fx?r.fx.speeds[b]||b:b,c=c||"fx",this.queue(c,function(c,d){var e=a.setTimeout(c,b);d.stop=function(){a.clearTimeout(e)}})},function(){var a=d.createElement("input"),b=d.createElement("select"),c=b.appendChild(d.createElement("option"));a.type="checkbox",o.checkOn=""!==a.value,o.optSelected=c.selected,a=d.createElement("input"),a.value="t",a.type="radio",o.radioValue="t"===a.value}();var ib,jb=r.expr.attrHandle;r.fn.extend({attr:function(a,b){return S(this,r.attr,a,b,arguments.length>1)},removeAttr:function(a){return this.each(function(){r.removeAttr(this,a)})}}),r.extend({attr:function(a,b,c){var d,e,f=a.nodeType;if(3!==f&&8!==f&&2!==f)return"undefined"==typeof a.getAttribute?r.prop(a,b,c):(1===f&&r.isXMLDoc(a)||(e=r.attrHooks[b.toLowerCase()]||(r.expr.match.bool.test(b)?ib:void 0)),
  4 +void 0!==c?null===c?void r.removeAttr(a,b):e&&"set"in e&&void 0!==(d=e.set(a,c,b))?d:(a.setAttribute(b,c+""),c):e&&"get"in e&&null!==(d=e.get(a,b))?d:(d=r.find.attr(a,b),null==d?void 0:d))},attrHooks:{type:{set:function(a,b){if(!o.radioValue&&"radio"===b&&r.nodeName(a,"input")){var c=a.value;return a.setAttribute("type",b),c&&(a.value=c),b}}}},removeAttr:function(a,b){var c,d=0,e=b&&b.match(K);if(e&&1===a.nodeType)while(c=e[d++])a.removeAttribute(c)}}),ib={set:function(a,b,c){return b===!1?r.removeAttr(a,c):a.setAttribute(c,c),c}},r.each(r.expr.match.bool.source.match(/\w+/g),function(a,b){var c=jb[b]||r.find.attr;jb[b]=function(a,b,d){var e,f,g=b.toLowerCase();return d||(f=jb[g],jb[g]=e,e=null!=c(a,b,d)?g:null,jb[g]=f),e}});var kb=/^(?:input|select|textarea|button)$/i,lb=/^(?:a|area)$/i;r.fn.extend({prop:function(a,b){return S(this,r.prop,a,b,arguments.length>1)},removeProp:function(a){return this.each(function(){delete this[r.propFix[a]||a]})}}),r.extend({prop:function(a,b,c){var d,e,f=a.nodeType;if(3!==f&&8!==f&&2!==f)return 1===f&&r.isXMLDoc(a)||(b=r.propFix[b]||b,e=r.propHooks[b]),void 0!==c?e&&"set"in e&&void 0!==(d=e.set(a,c,b))?d:a[b]=c:e&&"get"in e&&null!==(d=e.get(a,b))?d:a[b]},propHooks:{tabIndex:{get:function(a){var b=r.find.attr(a,"tabindex");return b?parseInt(b,10):kb.test(a.nodeName)||lb.test(a.nodeName)&&a.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),o.optSelected||(r.propHooks.selected={get:function(a){var b=a.parentNode;return b&&b.parentNode&&b.parentNode.selectedIndex,null},set:function(a){var b=a.parentNode;b&&(b.selectedIndex,b.parentNode&&b.parentNode.selectedIndex)}}),r.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){r.propFix[this.toLowerCase()]=this});function mb(a){var b=a.match(K)||[];return b.join(" ")}function nb(a){return a.getAttribute&&a.getAttribute("class")||""}r.fn.extend({addClass:function(a){var b,c,d,e,f,g,h,i=0;if(r.isFunction(a))return this.each(function(b){r(this).addClass(a.call(this,b,nb(this)))});if("string"==typeof a&&a){b=a.match(K)||[];while(c=this[i++])if(e=nb(c),d=1===c.nodeType&&" "+mb(e)+" "){g=0;while(f=b[g++])d.indexOf(" "+f+" ")<0&&(d+=f+" ");h=mb(d),e!==h&&c.setAttribute("class",h)}}return this},removeClass:function(a){var b,c,d,e,f,g,h,i=0;if(r.isFunction(a))return this.each(function(b){r(this).removeClass(a.call(this,b,nb(this)))});if(!arguments.length)return this.attr("class","");if("string"==typeof a&&a){b=a.match(K)||[];while(c=this[i++])if(e=nb(c),d=1===c.nodeType&&" "+mb(e)+" "){g=0;while(f=b[g++])while(d.indexOf(" "+f+" ")>-1)d=d.replace(" "+f+" "," ");h=mb(d),e!==h&&c.setAttribute("class",h)}}return this},toggleClass:function(a,b){var c=typeof a;return"boolean"==typeof b&&"string"===c?b?this.addClass(a):this.removeClass(a):r.isFunction(a)?this.each(function(c){r(this).toggleClass(a.call(this,c,nb(this),b),b)}):this.each(function(){var b,d,e,f;if("string"===c){d=0,e=r(this),f=a.match(K)||[];while(b=f[d++])e.hasClass(b)?e.removeClass(b):e.addClass(b)}else void 0!==a&&"boolean"!==c||(b=nb(this),b&&V.set(this,"__className__",b),this.setAttribute&&this.setAttribute("class",b||a===!1?"":V.get(this,"__className__")||""))})},hasClass:function(a){var b,c,d=0;b=" "+a+" ";while(c=this[d++])if(1===c.nodeType&&(" "+mb(nb(c))+" ").indexOf(b)>-1)return!0;return!1}});var ob=/\r/g;r.fn.extend({val:function(a){var b,c,d,e=this[0];{if(arguments.length)return d=r.isFunction(a),this.each(function(c){var e;1===this.nodeType&&(e=d?a.call(this,c,r(this).val()):a,null==e?e="":"number"==typeof e?e+="":r.isArray(e)&&(e=r.map(e,function(a){return null==a?"":a+""})),b=r.valHooks[this.type]||r.valHooks[this.nodeName.toLowerCase()],b&&"set"in b&&void 0!==b.set(this,e,"value")||(this.value=e))});if(e)return b=r.valHooks[e.type]||r.valHooks[e.nodeName.toLowerCase()],b&&"get"in b&&void 0!==(c=b.get(e,"value"))?c:(c=e.value,"string"==typeof c?c.replace(ob,""):null==c?"":c)}}}),r.extend({valHooks:{option:{get:function(a){var b=r.find.attr(a,"value");return null!=b?b:mb(r.text(a))}},select:{get:function(a){var b,c,d,e=a.options,f=a.selectedIndex,g="select-one"===a.type,h=g?null:[],i=g?f+1:e.length;for(d=f<0?i:g?f:0;d<i;d++)if(c=e[d],(c.selected||d===f)&&!c.disabled&&(!c.parentNode.disabled||!r.nodeName(c.parentNode,"optgroup"))){if(b=r(c).val(),g)return b;h.push(b)}return h},set:function(a,b){var c,d,e=a.options,f=r.makeArray(b),g=e.length;while(g--)d=e[g],(d.selected=r.inArray(r.valHooks.option.get(d),f)>-1)&&(c=!0);return c||(a.selectedIndex=-1),f}}}}),r.each(["radio","checkbox"],function(){r.valHooks[this]={set:function(a,b){if(r.isArray(b))return a.checked=r.inArray(r(a).val(),b)>-1}},o.checkOn||(r.valHooks[this].get=function(a){return null===a.getAttribute("value")?"on":a.value})});var pb=/^(?:focusinfocus|focusoutblur)$/;r.extend(r.event,{trigger:function(b,c,e,f){var g,h,i,j,k,m,n,o=[e||d],p=l.call(b,"type")?b.type:b,q=l.call(b,"namespace")?b.namespace.split("."):[];if(h=i=e=e||d,3!==e.nodeType&&8!==e.nodeType&&!pb.test(p+r.event.triggered)&&(p.indexOf(".")>-1&&(q=p.split("."),p=q.shift(),q.sort()),k=p.indexOf(":")<0&&"on"+p,b=b[r.expando]?b:new r.Event(p,"object"==typeof b&&b),b.isTrigger=f?2:3,b.namespace=q.join("."),b.rnamespace=b.namespace?new RegExp("(^|\\.)"+q.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,b.result=void 0,b.target||(b.target=e),c=null==c?[b]:r.makeArray(c,[b]),n=r.event.special[p]||{},f||!n.trigger||n.trigger.apply(e,c)!==!1)){if(!f&&!n.noBubble&&!r.isWindow(e)){for(j=n.delegateType||p,pb.test(j+p)||(h=h.parentNode);h;h=h.parentNode)o.push(h),i=h;i===(e.ownerDocument||d)&&o.push(i.defaultView||i.parentWindow||a)}g=0;while((h=o[g++])&&!b.isPropagationStopped())b.type=g>1?j:n.bindType||p,m=(V.get(h,"events")||{})[b.type]&&V.get(h,"handle"),m&&m.apply(h,c),m=k&&h[k],m&&m.apply&&T(h)&&(b.result=m.apply(h,c),b.result===!1&&b.preventDefault());return b.type=p,f||b.isDefaultPrevented()||n._default&&n._default.apply(o.pop(),c)!==!1||!T(e)||k&&r.isFunction(e[p])&&!r.isWindow(e)&&(i=e[k],i&&(e[k]=null),r.event.triggered=p,e[p](),r.event.triggered=void 0,i&&(e[k]=i)),b.result}},simulate:function(a,b,c){var d=r.extend(new r.Event,c,{type:a,isSimulated:!0});r.event.trigger(d,null,b)}}),r.fn.extend({trigger:function(a,b){return this.each(function(){r.event.trigger(a,b,this)})},triggerHandler:function(a,b){var c=this[0];if(c)return r.event.trigger(a,b,c,!0)}}),r.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(a,b){r.fn[b]=function(a,c){return arguments.length>0?this.on(b,null,a,c):this.trigger(b)}}),r.fn.extend({hover:function(a,b){return this.mouseenter(a).mouseleave(b||a)}}),o.focusin="onfocusin"in a,o.focusin||r.each({focus:"focusin",blur:"focusout"},function(a,b){var c=function(a){r.event.simulate(b,a.target,r.event.fix(a))};r.event.special[b]={setup:function(){var d=this.ownerDocument||this,e=V.access(d,b);e||d.addEventListener(a,c,!0),V.access(d,b,(e||0)+1)},teardown:function(){var d=this.ownerDocument||this,e=V.access(d,b)-1;e?V.access(d,b,e):(d.removeEventListener(a,c,!0),V.remove(d,b))}}});var qb=a.location,rb=r.now(),sb=/\?/;r.parseXML=function(b){var c;if(!b||"string"!=typeof b)return null;try{c=(new a.DOMParser).parseFromString(b,"text/xml")}catch(d){c=void 0}return c&&!c.getElementsByTagName("parsererror").length||r.error("Invalid XML: "+b),c};var tb=/\[\]$/,ub=/\r?\n/g,vb=/^(?:submit|button|image|reset|file)$/i,wb=/^(?:input|select|textarea|keygen)/i;function xb(a,b,c,d){var e;if(r.isArray(b))r.each(b,function(b,e){c||tb.test(a)?d(a,e):xb(a+"["+("object"==typeof e&&null!=e?b:"")+"]",e,c,d)});else if(c||"object"!==r.type(b))d(a,b);else for(e in b)xb(a+"["+e+"]",b[e],c,d)}r.param=function(a,b){var c,d=[],e=function(a,b){var c=r.isFunction(b)?b():b;d[d.length]=encodeURIComponent(a)+"="+encodeURIComponent(null==c?"":c)};if(r.isArray(a)||a.jquery&&!r.isPlainObject(a))r.each(a,function(){e(this.name,this.value)});else for(c in a)xb(c,a[c],b,e);return d.join("&")},r.fn.extend({serialize:function(){return r.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var a=r.prop(this,"elements");return a?r.makeArray(a):this}).filter(function(){var a=this.type;return this.name&&!r(this).is(":disabled")&&wb.test(this.nodeName)&&!vb.test(a)&&(this.checked||!ia.test(a))}).map(function(a,b){var c=r(this).val();return null==c?null:r.isArray(c)?r.map(c,function(a){return{name:b.name,value:a.replace(ub,"\r\n")}}):{name:b.name,value:c.replace(ub,"\r\n")}}).get()}});var yb=/%20/g,zb=/#.*$/,Ab=/([?&])_=[^&]*/,Bb=/^(.*?):[ \t]*([^\r\n]*)$/gm,Cb=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,Db=/^(?:GET|HEAD)$/,Eb=/^\/\//,Fb={},Gb={},Hb="*/".concat("*"),Ib=d.createElement("a");Ib.href=qb.href;function Jb(a){return function(b,c){"string"!=typeof b&&(c=b,b="*");var d,e=0,f=b.toLowerCase().match(K)||[];if(r.isFunction(c))while(d=f[e++])"+"===d[0]?(d=d.slice(1)||"*",(a[d]=a[d]||[]).unshift(c)):(a[d]=a[d]||[]).push(c)}}function Kb(a,b,c,d){var e={},f=a===Gb;function g(h){var i;return e[h]=!0,r.each(a[h]||[],function(a,h){var j=h(b,c,d);return"string"!=typeof j||f||e[j]?f?!(i=j):void 0:(b.dataTypes.unshift(j),g(j),!1)}),i}return g(b.dataTypes[0])||!e["*"]&&g("*")}function Lb(a,b){var c,d,e=r.ajaxSettings.flatOptions||{};for(c in b)void 0!==b[c]&&((e[c]?a:d||(d={}))[c]=b[c]);return d&&r.extend(!0,a,d),a}function Mb(a,b,c){var d,e,f,g,h=a.contents,i=a.dataTypes;while("*"===i[0])i.shift(),void 0===d&&(d=a.mimeType||b.getResponseHeader("Content-Type"));if(d)for(e in h)if(h[e]&&h[e].test(d)){i.unshift(e);break}if(i[0]in c)f=i[0];else{for(e in c){if(!i[0]||a.converters[e+" "+i[0]]){f=e;break}g||(g=e)}f=f||g}if(f)return f!==i[0]&&i.unshift(f),c[f]}function Nb(a,b,c,d){var e,f,g,h,i,j={},k=a.dataTypes.slice();if(k[1])for(g in a.converters)j[g.toLowerCase()]=a.converters[g];f=k.shift();while(f)if(a.responseFields[f]&&(c[a.responseFields[f]]=b),!i&&d&&a.dataFilter&&(b=a.dataFilter(b,a.dataType)),i=f,f=k.shift())if("*"===f)f=i;else if("*"!==i&&i!==f){if(g=j[i+" "+f]||j["* "+f],!g)for(e in j)if(h=e.split(" "),h[1]===f&&(g=j[i+" "+h[0]]||j["* "+h[0]])){g===!0?g=j[e]:j[e]!==!0&&(f=h[0],k.unshift(h[1]));break}if(g!==!0)if(g&&a["throws"])b=g(b);else try{b=g(b)}catch(l){return{state:"parsererror",error:g?l:"No conversion from "+i+" to "+f}}}return{state:"success",data:b}}r.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:qb.href,type:"GET",isLocal:Cb.test(qb.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Hb,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":r.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(a,b){return b?Lb(Lb(a,r.ajaxSettings),b):Lb(r.ajaxSettings,a)},ajaxPrefilter:Jb(Fb),ajaxTransport:Jb(Gb),ajax:function(b,c){"object"==typeof b&&(c=b,b=void 0),c=c||{};var e,f,g,h,i,j,k,l,m,n,o=r.ajaxSetup({},c),p=o.context||o,q=o.context&&(p.nodeType||p.jquery)?r(p):r.event,s=r.Deferred(),t=r.Callbacks("once memory"),u=o.statusCode||{},v={},w={},x="canceled",y={readyState:0,getResponseHeader:function(a){var b;if(k){if(!h){h={};while(b=Bb.exec(g))h[b[1].toLowerCase()]=b[2]}b=h[a.toLowerCase()]}return null==b?null:b},getAllResponseHeaders:function(){return k?g:null},setRequestHeader:function(a,b){return null==k&&(a=w[a.toLowerCase()]=w[a.toLowerCase()]||a,v[a]=b),this},overrideMimeType:function(a){return null==k&&(o.mimeType=a),this},statusCode:function(a){var b;if(a)if(k)y.always(a[y.status]);else for(b in a)u[b]=[u[b],a[b]];return this},abort:function(a){var b=a||x;return e&&e.abort(b),A(0,b),this}};if(s.promise(y),o.url=((b||o.url||qb.href)+"").replace(Eb,qb.protocol+"//"),o.type=c.method||c.type||o.method||o.type,o.dataTypes=(o.dataType||"*").toLowerCase().match(K)||[""],null==o.crossDomain){j=d.createElement("a");try{j.href=o.url,j.href=j.href,o.crossDomain=Ib.protocol+"//"+Ib.host!=j.protocol+"//"+j.host}catch(z){o.crossDomain=!0}}if(o.data&&o.processData&&"string"!=typeof o.data&&(o.data=r.param(o.data,o.traditional)),Kb(Fb,o,c,y),k)return y;l=r.event&&o.global,l&&0===r.active++&&r.event.trigger("ajaxStart"),o.type=o.type.toUpperCase(),o.hasContent=!Db.test(o.type),f=o.url.replace(zb,""),o.hasContent?o.data&&o.processData&&0===(o.contentType||"").indexOf("application/x-www-form-urlencoded")&&(o.data=o.data.replace(yb,"+")):(n=o.url.slice(f.length),o.data&&(f+=(sb.test(f)?"&":"?")+o.data,delete o.data),o.cache===!1&&(f=f.replace(Ab,"$1"),n=(sb.test(f)?"&":"?")+"_="+rb++ +n),o.url=f+n),o.ifModified&&(r.lastModified[f]&&y.setRequestHeader("If-Modified-Since",r.lastModified[f]),r.etag[f]&&y.setRequestHeader("If-None-Match",r.etag[f])),(o.data&&o.hasContent&&o.contentType!==!1||c.contentType)&&y.setRequestHeader("Content-Type",o.contentType),y.setRequestHeader("Accept",o.dataTypes[0]&&o.accepts[o.dataTypes[0]]?o.accepts[o.dataTypes[0]]+("*"!==o.dataTypes[0]?", "+Hb+"; q=0.01":""):o.accepts["*"]);for(m in o.headers)y.setRequestHeader(m,o.headers[m]);if(o.beforeSend&&(o.beforeSend.call(p,y,o)===!1||k))return y.abort();if(x="abort",t.add(o.complete),y.done(o.success),y.fail(o.error),e=Kb(Gb,o,c,y)){if(y.readyState=1,l&&q.trigger("ajaxSend",[y,o]),k)return y;o.async&&o.timeout>0&&(i=a.setTimeout(function(){y.abort("timeout")},o.timeout));try{k=!1,e.send(v,A)}catch(z){if(k)throw z;A(-1,z)}}else A(-1,"No Transport");function A(b,c,d,h){var j,m,n,v,w,x=c;k||(k=!0,i&&a.clearTimeout(i),e=void 0,g=h||"",y.readyState=b>0?4:0,j=b>=200&&b<300||304===b,d&&(v=Mb(o,y,d)),v=Nb(o,v,y,j),j?(o.ifModified&&(w=y.getResponseHeader("Last-Modified"),w&&(r.lastModified[f]=w),w=y.getResponseHeader("etag"),w&&(r.etag[f]=w)),204===b||"HEAD"===o.type?x="nocontent":304===b?x="notmodified":(x=v.state,m=v.data,n=v.error,j=!n)):(n=x,!b&&x||(x="error",b<0&&(b=0))),y.status=b,y.statusText=(c||x)+"",j?s.resolveWith(p,[m,x,y]):s.rejectWith(p,[y,x,n]),y.statusCode(u),u=void 0,l&&q.trigger(j?"ajaxSuccess":"ajaxError",[y,o,j?m:n]),t.fireWith(p,[y,x]),l&&(q.trigger("ajaxComplete",[y,o]),--r.active||r.event.trigger("ajaxStop")))}return y},getJSON:function(a,b,c){return r.get(a,b,c,"json")},getScript:function(a,b){return r.get(a,void 0,b,"script")}}),r.each(["get","post"],function(a,b){r[b]=function(a,c,d,e){return r.isFunction(c)&&(e=e||d,d=c,c=void 0),r.ajax(r.extend({url:a,type:b,dataType:e,data:c,success:d},r.isPlainObject(a)&&a))}}),r._evalUrl=function(a){return r.ajax({url:a,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,"throws":!0})},r.fn.extend({wrapAll:function(a){var b;return this[0]&&(r.isFunction(a)&&(a=a.call(this[0])),b=r(a,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&b.insertBefore(this[0]),b.map(function(){var a=this;while(a.firstElementChild)a=a.firstElementChild;return a}).append(this)),this},wrapInner:function(a){return r.isFunction(a)?this.each(function(b){r(this).wrapInner(a.call(this,b))}):this.each(function(){var b=r(this),c=b.contents();c.length?c.wrapAll(a):b.append(a)})},wrap:function(a){var b=r.isFunction(a);return this.each(function(c){r(this).wrapAll(b?a.call(this,c):a)})},unwrap:function(a){return this.parent(a).not("body").each(function(){r(this).replaceWith(this.childNodes)}),this}}),r.expr.pseudos.hidden=function(a){return!r.expr.pseudos.visible(a)},r.expr.pseudos.visible=function(a){return!!(a.offsetWidth||a.offsetHeight||a.getClientRects().length)},r.ajaxSettings.xhr=function(){try{return new a.XMLHttpRequest}catch(b){}};var Ob={0:200,1223:204},Pb=r.ajaxSettings.xhr();o.cors=!!Pb&&"withCredentials"in Pb,o.ajax=Pb=!!Pb,r.ajaxTransport(function(b){var c,d;if(o.cors||Pb&&!b.crossDomain)return{send:function(e,f){var g,h=b.xhr();if(h.open(b.type,b.url,b.async,b.username,b.password),b.xhrFields)for(g in b.xhrFields)h[g]=b.xhrFields[g];b.mimeType&&h.overrideMimeType&&h.overrideMimeType(b.mimeType),b.crossDomain||e["X-Requested-With"]||(e["X-Requested-With"]="XMLHttpRequest");for(g in e)h.setRequestHeader(g,e[g]);c=function(a){return function(){c&&(c=d=h.onload=h.onerror=h.onabort=h.onreadystatechange=null,"abort"===a?h.abort():"error"===a?"number"!=typeof h.status?f(0,"error"):f(h.status,h.statusText):f(Ob[h.status]||h.status,h.statusText,"text"!==(h.responseType||"text")||"string"!=typeof h.responseText?{binary:h.response}:{text:h.responseText},h.getAllResponseHeaders()))}},h.onload=c(),d=h.onerror=c("error"),void 0!==h.onabort?h.onabort=d:h.onreadystatechange=function(){4===h.readyState&&a.setTimeout(function(){c&&d()})},c=c("abort");try{h.send(b.hasContent&&b.data||null)}catch(i){if(c)throw i}},abort:function(){c&&c()}}}),r.ajaxPrefilter(function(a){a.crossDomain&&(a.contents.script=!1)}),r.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(a){return r.globalEval(a),a}}}),r.ajaxPrefilter("script",function(a){void 0===a.cache&&(a.cache=!1),a.crossDomain&&(a.type="GET")}),r.ajaxTransport("script",function(a){if(a.crossDomain){var b,c;return{send:function(e,f){b=r("<script>").prop({charset:a.scriptCharset,src:a.url}).on("load error",c=function(a){b.remove(),c=null,a&&f("error"===a.type?404:200,a.type)}),d.head.appendChild(b[0])},abort:function(){c&&c()}}}});var Qb=[],Rb=/(=)\?(?=&|$)|\?\?/;r.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var a=Qb.pop()||r.expando+"_"+rb++;return this[a]=!0,a}}),r.ajaxPrefilter("json jsonp",function(b,c,d){var e,f,g,h=b.jsonp!==!1&&(Rb.test(b.url)?"url":"string"==typeof b.data&&0===(b.contentType||"").indexOf("application/x-www-form-urlencoded")&&Rb.test(b.data)&&"data");if(h||"jsonp"===b.dataTypes[0])return e=b.jsonpCallback=r.isFunction(b.jsonpCallback)?b.jsonpCallback():b.jsonpCallback,h?b[h]=b[h].replace(Rb,"$1"+e):b.jsonp!==!1&&(b.url+=(sb.test(b.url)?"&":"?")+b.jsonp+"="+e),b.converters["script json"]=function(){return g||r.error(e+" was not called"),g[0]},b.dataTypes[0]="json",f=a[e],a[e]=function(){g=arguments},d.always(function(){void 0===f?r(a).removeProp(e):a[e]=f,b[e]&&(b.jsonpCallback=c.jsonpCallback,Qb.push(e)),g&&r.isFunction(f)&&f(g[0]),g=f=void 0}),"script"}),o.createHTMLDocument=function(){var a=d.implementation.createHTMLDocument("").body;return a.innerHTML="<form></form><form></form>",2===a.childNodes.length}(),r.parseHTML=function(a,b,c){if("string"!=typeof a)return[];"boolean"==typeof b&&(c=b,b=!1);var e,f,g;return b||(o.createHTMLDocument?(b=d.implementation.createHTMLDocument(""),e=b.createElement("base"),e.href=d.location.href,b.head.appendChild(e)):b=d),f=B.exec(a),g=!c&&[],f?[b.createElement(f[1])]:(f=pa([a],b,g),g&&g.length&&r(g).remove(),r.merge([],f.childNodes))},r.fn.load=function(a,b,c){var d,e,f,g=this,h=a.indexOf(" ");return h>-1&&(d=mb(a.slice(h)),a=a.slice(0,h)),r.isFunction(b)?(c=b,b=void 0):b&&"object"==typeof b&&(e="POST"),g.length>0&&r.ajax({url:a,type:e||"GET",dataType:"html",data:b}).done(function(a){f=arguments,g.html(d?r("<div>").append(r.parseHTML(a)).find(d):a)}).always(c&&function(a,b){g.each(function(){c.apply(this,f||[a.responseText,b,a])})}),this},r.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(a,b){r.fn[b]=function(a){return this.on(b,a)}}),r.expr.pseudos.animated=function(a){return r.grep(r.timers,function(b){return a===b.elem}).length};function Sb(a){return r.isWindow(a)?a:9===a.nodeType&&a.defaultView}r.offset={setOffset:function(a,b,c){var d,e,f,g,h,i,j,k=r.css(a,"position"),l=r(a),m={};"static"===k&&(a.style.position="relative"),h=l.offset(),f=r.css(a,"top"),i=r.css(a,"left"),j=("absolute"===k||"fixed"===k)&&(f+i).indexOf("auto")>-1,j?(d=l.position(),g=d.top,e=d.left):(g=parseFloat(f)||0,e=parseFloat(i)||0),r.isFunction(b)&&(b=b.call(a,c,r.extend({},h))),null!=b.top&&(m.top=b.top-h.top+g),null!=b.left&&(m.left=b.left-h.left+e),"using"in b?b.using.call(a,m):l.css(m)}},r.fn.extend({offset:function(a){if(arguments.length)return void 0===a?this:this.each(function(b){r.offset.setOffset(this,a,b)});var b,c,d,e,f=this[0];if(f)return f.getClientRects().length?(d=f.getBoundingClientRect(),d.width||d.height?(e=f.ownerDocument,c=Sb(e),b=e.documentElement,{top:d.top+c.pageYOffset-b.clientTop,left:d.left+c.pageXOffset-b.clientLeft}):d):{top:0,left:0}},position:function(){if(this[0]){var a,b,c=this[0],d={top:0,left:0};return"fixed"===r.css(c,"position")?b=c.getBoundingClientRect():(a=this.offsetParent(),b=this.offset(),r.nodeName(a[0],"html")||(d=a.offset()),d={top:d.top+r.css(a[0],"borderTopWidth",!0),left:d.left+r.css(a[0],"borderLeftWidth",!0)}),{top:b.top-d.top-r.css(c,"marginTop",!0),left:b.left-d.left-r.css(c,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var a=this.offsetParent;while(a&&"static"===r.css(a,"position"))a=a.offsetParent;return a||qa})}}),r.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(a,b){var c="pageYOffset"===b;r.fn[a]=function(d){return S(this,function(a,d,e){var f=Sb(a);return void 0===e?f?f[b]:a[d]:void(f?f.scrollTo(c?f.pageXOffset:e,c?e:f.pageYOffset):a[d]=e)},a,d,arguments.length)}}),r.each(["top","left"],function(a,b){r.cssHooks[b]=Oa(o.pixelPosition,function(a,c){if(c)return c=Na(a,b),La.test(c)?r(a).position()[b]+"px":c})}),r.each({Height:"height",Width:"width"},function(a,b){r.each({padding:"inner"+a,content:b,"":"outer"+a},function(c,d){r.fn[d]=function(e,f){var g=arguments.length&&(c||"boolean"!=typeof e),h=c||(e===!0||f===!0?"margin":"border");return S(this,function(b,c,e){var f;return r.isWindow(b)?0===d.indexOf("outer")?b["inner"+a]:b.document.documentElement["client"+a]:9===b.nodeType?(f=b.documentElement,Math.max(b.body["scroll"+a],f["scroll"+a],b.body["offset"+a],f["offset"+a],f["client"+a])):void 0===e?r.css(b,c,h):r.style(b,c,e,h)},b,g?e:void 0,g)}})}),r.fn.extend({bind:function(a,b,c){return this.on(a,null,b,c)},unbind:function(a,b){return this.off(a,null,b)},delegate:function(a,b,c,d){return this.on(b,a,c,d)},undelegate:function(a,b,c){return 1===arguments.length?this.off(a,"**"):this.off(b,a||"**",c)}}),r.parseJSON=JSON.parse,"function"==typeof define&&define.amd&&define("jquery",[],function(){return r});var Tb=a.jQuery,Ub=a.$;return r.noConflict=function(b){return a.$===r&&(a.$=Ub),b&&a.jQuery===r&&(a.jQuery=Tb),r},b||(a.jQuery=a.$=r),r});
... ...
app/js/plugins/bootstrap-datepicker.js
... ... @@ -0,0 +1,1671 @@
  1 +/* =========================================================
  2 + * bootstrap-datepicker.js
  3 + * Repo: https://github.com/eternicode/bootstrap-datepicker/
  4 + * Demo: http://eternicode.github.io/bootstrap-datepicker/
  5 + * Docs: http://bootstrap-datepicker.readthedocs.org/
  6 + * Forked from http://www.eyecon.ro/bootstrap-datepicker
  7 + * =========================================================
  8 + * Started by Stefan Petre; improvements by Andrew Rowls + contributors
  9 + *
  10 + * Licensed under the Apache License, Version 2.0 (the "License");
  11 + * you may not use this file except in compliance with the License.
  12 + * You may obtain a copy of the License at
  13 + *
  14 + * http://www.apache.org/licenses/LICENSE-2.0
  15 + *
  16 + * Unless required by applicable law or agreed to in writing, software
  17 + * distributed under the License is distributed on an "AS IS" BASIS,
  18 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  19 + * See the License for the specific language governing permissions and
  20 + * limitations under the License.
  21 + * ========================================================= */
  22 +
  23 +(function($, undefined){
  24 +
  25 + var $window = $(window);
  26 +
  27 + function UTCDate(){
  28 + return new Date(Date.UTC.apply(Date, arguments));
  29 + }
  30 + function UTCToday(){
  31 + var today = new Date();
  32 + return UTCDate(today.getFullYear(), today.getMonth(), today.getDate());
  33 + }
  34 + function alias(method){
  35 + return function(){
  36 + return this[method].apply(this, arguments);
  37 + };
  38 + }
  39 +
  40 + var DateArray = (function(){
  41 + var extras = {
  42 + get: function(i){
  43 + return this.slice(i)[0];
  44 + },
  45 + contains: function(d){
  46 + // Array.indexOf is not cross-browser;
  47 + // $.inArray doesn't work with Dates
  48 + var val = d && d.valueOf();
  49 + for (var i=0, l=this.length; i < l; i++)
  50 + if (this[i].valueOf() === val)
  51 + return i;
  52 + return -1;
  53 + },
  54 + remove: function(i){
  55 + this.splice(i,1);
  56 + },
  57 + replace: function(new_array){
  58 + if (!new_array)
  59 + return;
  60 + if (!$.isArray(new_array))
  61 + new_array = [new_array];
  62 + this.clear();
  63 + this.push.apply(this, new_array);
  64 + },
  65 + clear: function(){
  66 + this.splice(0);
  67 + },
  68 + copy: function(){
  69 + var a = new DateArray();
  70 + a.replace(this);
  71 + return a;
  72 + }
  73 + };
  74 +
  75 + return function(){
  76 + var a = [];
  77 + a.push.apply(a, arguments);
  78 + $.extend(a, extras);
  79 + return a;
  80 + };
  81 + })();
  82 +
  83 +
  84 + // Picker object
  85 +
  86 + var Datepicker = function(element, options){
  87 + this.dates = new DateArray();
  88 + this.viewDate = UTCToday();
  89 + this.focusDate = null;
  90 +
  91 + this._process_options(options);
  92 +
  93 + this.element = $(element);
  94 + this.isInline = false;
  95 + this.isInput = this.element.is('input');
  96 + this.component = this.element.is('.date') ? this.element.find('.add-on, .input-group-addon, .btn') : false;
  97 + this.hasInput = this.component && this.element.find('input').length;
  98 + if (this.component && this.component.length === 0)
  99 + this.component = false;
  100 +
  101 + this.picker = $(DPGlobal.template);
  102 + this._buildEvents();
  103 + this._attachEvents();
  104 +
  105 + if (this.isInline){
  106 + this.picker.addClass('datepicker-inline').appendTo(this.element);
  107 + }
  108 + else {
  109 + this.picker.addClass('datepicker-dropdown dropdown-menu');
  110 + }
  111 +
  112 + if (this.o.rtl){
  113 + this.picker.addClass('datepicker-rtl');
  114 + }
  115 +
  116 + this.viewMode = this.o.startView;
  117 +
  118 + if (this.o.calendarWeeks)
  119 + this.picker.find('tfoot th.today')
  120 + .attr('colspan', function(i, val){
  121 + return parseInt(val) + 1;
  122 + });
  123 +
  124 + this._allow_update = false;
  125 +
  126 + this.setStartDate(this._o.startDate);
  127 + this.setEndDate(this._o.endDate);
  128 + this.setDaysOfWeekDisabled(this.o.daysOfWeekDisabled);
  129 +
  130 + this.fillDow();
  131 + this.fillMonths();
  132 +
  133 + this._allow_update = true;
  134 +
  135 + this.update();
  136 + this.showMode();
  137 +
  138 + if (this.isInline){
  139 + this.show();
  140 + }
  141 + };
  142 +
  143 + Datepicker.prototype = {
  144 + constructor: Datepicker,
  145 +
  146 + _process_options: function(opts){
  147 + // Store raw options for reference
  148 + this._o = $.extend({}, this._o, opts);
  149 + // Processed options
  150 + var o = this.o = $.extend({}, this._o);
  151 +
  152 + // Check if "de-DE" style date is available, if not language should
  153 + // fallback to 2 letter code eg "de"
  154 + var lang = o.language;
  155 + if (!dates[lang]){
  156 + lang = lang.split('-')[0];
  157 + if (!dates[lang])
  158 + lang = defaults.language;
  159 + }
  160 + o.language = lang;
  161 +
  162 + switch (o.startView){
  163 + case 2:
  164 + case 'decade':
  165 + o.startView = 2;
  166 + break;
  167 + case 1:
  168 + case 'year':
  169 + o.startView = 1;
  170 + break;
  171 + default:
  172 + o.startView = 0;
  173 + }
  174 +
  175 + switch (o.minViewMode){
  176 + case 1:
  177 + case 'months':
  178 + o.minViewMode = 1;
  179 + break;
  180 + case 2:
  181 + case 'years':
  182 + o.minViewMode = 2;
  183 + break;
  184 + default:
  185 + o.minViewMode = 0;
  186 + }
  187 +
  188 + o.startView = Math.max(o.startView, o.minViewMode);
  189 +
  190 + // true, false, or Number > 0
  191 + if (o.multidate !== true){
  192 + o.multidate = Number(o.multidate) || false;
  193 + if (o.multidate !== false)
  194 + o.multidate = Math.max(0, o.multidate);
  195 + else
  196 + o.multidate = 1;
  197 + }
  198 + o.multidateSeparator = String(o.multidateSeparator);
  199 +
  200 + o.weekStart %= 7;
  201 + o.weekEnd = ((o.weekStart + 6) % 7);
  202 +
  203 + var format = DPGlobal.parseFormat(o.format);
  204 + if (o.startDate !== -Infinity){
  205 + if (!!o.startDate){
  206 + if (o.startDate instanceof Date)
  207 + o.startDate = this._local_to_utc(this._zero_time(o.startDate));
  208 + else
  209 + o.startDate = DPGlobal.parseDate(o.startDate, format, o.language);
  210 + }
  211 + else {
  212 + o.startDate = -Infinity;
  213 + }
  214 + }
  215 + if (o.endDate !== Infinity){
  216 + if (!!o.endDate){
  217 + if (o.endDate instanceof Date)
  218 + o.endDate = this._local_to_utc(this._zero_time(o.endDate));
  219 + else
  220 + o.endDate = DPGlobal.parseDate(o.endDate, format, o.language);
  221 + }
  222 + else {
  223 + o.endDate = Infinity;
  224 + }
  225 + }
  226 +
  227 + o.daysOfWeekDisabled = o.daysOfWeekDisabled||[];
  228 + if (!$.isArray(o.daysOfWeekDisabled))
  229 + o.daysOfWeekDisabled = o.daysOfWeekDisabled.split(/[,\s]*/);
  230 + o.daysOfWeekDisabled = $.map(o.daysOfWeekDisabled, function(d){
  231 + return parseInt(d, 10);
  232 + });
  233 +
  234 + var plc = String(o.orientation).toLowerCase().split(/\s+/g),
  235 + _plc = o.orientation.toLowerCase();
  236 + plc = $.grep(plc, function(word){
  237 + return (/^auto|left|right|top|bottom$/).test(word);
  238 + });
  239 + o.orientation = {x: 'auto', y: 'auto'};
  240 + if (!_plc || _plc === 'auto')
  241 + ; // no action
  242 + else if (plc.length === 1){
  243 + switch (plc[0]){
  244 + case 'top':
  245 + case 'bottom':
  246 + o.orientation.y = plc[0];
  247 + break;
  248 + case 'left':
  249 + case 'right':
  250 + o.orientation.x = plc[0];
  251 + break;
  252 + }
  253 + }
  254 + else {
  255 + _plc = $.grep(plc, function(word){
  256 + return (/^left|right$/).test(word);
  257 + });
  258 + o.orientation.x = _plc[0] || 'auto';
  259 +
  260 + _plc = $.grep(plc, function(word){
  261 + return (/^top|bottom$/).test(word);
  262 + });
  263 + o.orientation.y = _plc[0] || 'auto';
  264 + }
  265 + },
  266 + _events: [],
  267 + _secondaryEvents: [],
  268 + _applyEvents: function(evs){
  269 + for (var i=0, el, ch, ev; i < evs.length; i++){
  270 + el = evs[i][0];
  271 + if (evs[i].length === 2){
  272 + ch = undefined;
  273 + ev = evs[i][1];
  274 + }
  275 + else if (evs[i].length === 3){
  276 + ch = evs[i][1];
  277 + ev = evs[i][2];
  278 + }
  279 + el.on(ev, ch);
  280 + }
  281 + },
  282 + _unapplyEvents: function(evs){
  283 + for (var i=0, el, ev, ch; i < evs.length; i++){
  284 + el = evs[i][0];
  285 + if (evs[i].length === 2){
  286 + ch = undefined;
  287 + ev = evs[i][1];
  288 + }
  289 + else if (evs[i].length === 3){
  290 + ch = evs[i][1];
  291 + ev = evs[i][2];
  292 + }
  293 + el.off(ev, ch);
  294 + }
  295 + },
  296 + _buildEvents: function(){
  297 + if (this.isInput){ // single input
  298 + this._events = [
  299 + [this.element, {
  300 + focus: $.proxy(this.show, this),
  301 + keyup: $.proxy(function(e){
  302 + if ($.inArray(e.keyCode, [27,37,39,38,40,32,13,9]) === -1)
  303 + this.update();
  304 + }, this),
  305 + keydown: $.proxy(this.keydown, this)
  306 + }]
  307 + ];
  308 + }
  309 + else if (this.component && this.hasInput){ // component: input + button
  310 + this._events = [
  311 + // For components that are not readonly, allow keyboard nav
  312 + [this.element.find('input'), {
  313 + focus: $.proxy(this.show, this),
  314 + keyup: $.proxy(function(e){
  315 + if ($.inArray(e.keyCode, [27,37,39,38,40,32,13,9]) === -1)
  316 + this.update();
  317 + }, this),
  318 + keydown: $.proxy(this.keydown, this)
  319 + }],
  320 + [this.component, {
  321 + click: $.proxy(this.show, this)
  322 + }]
  323 + ];
  324 + }
  325 + else if (this.element.is('div')){ // inline datepicker
  326 + this.isInline = true;
  327 + }
  328 + else {
  329 + this._events = [
  330 + [this.element, {
  331 + click: $.proxy(this.show, this)
  332 + }]
  333 + ];
  334 + }
  335 + this._events.push(
  336 + // Component: listen for blur on element descendants
  337 + [this.element, '*', {
  338 + blur: $.proxy(function(e){
  339 + this._focused_from = e.target;
  340 + }, this)
  341 + }],
  342 + // Input: listen for blur on element
  343 + [this.element, {
  344 + blur: $.proxy(function(e){
  345 + this._focused_from = e.target;
  346 + }, this)
  347 + }]
  348 + );
  349 +
  350 + this._secondaryEvents = [
  351 + [this.picker, {
  352 + click: $.proxy(this.click, this)
  353 + }],
  354 + [$(window), {
  355 + resize: $.proxy(this.place, this)
  356 + }],
  357 + [$(document), {
  358 + 'mousedown touchstart': $.proxy(function(e){
  359 + // Clicked outside the datepicker, hide it
  360 + if (!(
  361 + this.element.is(e.target) ||
  362 + this.element.find(e.target).length ||
  363 + this.picker.is(e.target) ||
  364 + this.picker.find(e.target).length
  365 + )){
  366 + this.hide();
  367 + }
  368 + }, this)
  369 + }]
  370 + ];
  371 + },
  372 + _attachEvents: function(){
  373 + this._detachEvents();
  374 + this._applyEvents(this._events);
  375 + },
  376 + _detachEvents: function(){
  377 + this._unapplyEvents(this._events);
  378 + },
  379 + _attachSecondaryEvents: function(){
  380 + this._detachSecondaryEvents();
  381 + this._applyEvents(this._secondaryEvents);
  382 + },
  383 + _detachSecondaryEvents: function(){
  384 + this._unapplyEvents(this._secondaryEvents);
  385 + },
  386 + _trigger: function(event, altdate){
  387 + var date = altdate || this.dates.get(-1),
  388 + local_date = this._utc_to_local(date);
  389 +
  390 + this.element.trigger({
  391 + type: event,
  392 + date: local_date,
  393 + dates: $.map(this.dates, this._utc_to_local),
  394 + format: $.proxy(function(ix, format){
  395 + if (arguments.length === 0){
  396 + ix = this.dates.length - 1;
  397 + format = this.o.format;
  398 + }
  399 + else if (typeof ix === 'string'){
  400 + format = ix;
  401 + ix = this.dates.length - 1;
  402 + }
  403 + format = format || this.o.format;
  404 + var date = this.dates.get(ix);
  405 + return DPGlobal.formatDate(date, format, this.o.language);
  406 + }, this)
  407 + });
  408 + },
  409 +
  410 + show: function(){
  411 + if (!this.isInline)
  412 + this.picker.appendTo('body');
  413 + this.picker.show();
  414 + this.place();
  415 + this._attachSecondaryEvents();
  416 + this._trigger('show');
  417 + },
  418 +
  419 + hide: function(){
  420 + if (this.isInline)
  421 + return;
  422 + if (!this.picker.is(':visible'))
  423 + return;
  424 + this.focusDate = null;
  425 + this.picker.hide().detach();
  426 + this._detachSecondaryEvents();
  427 + this.viewMode = this.o.startView;
  428 + this.showMode();
  429 +
  430 + if (
  431 + this.o.forceParse &&
  432 + (
  433 + this.isInput && this.element.val() ||
  434 + this.hasInput && this.element.find('input').val()
  435 + )
  436 + )
  437 + this.setValue();
  438 + this._trigger('hide');
  439 + },
  440 +
  441 + remove: function(){
  442 + this.hide();
  443 + this._detachEvents();
  444 + this._detachSecondaryEvents();
  445 + this.picker.remove();
  446 + delete this.element.data().datepicker;
  447 + if (!this.isInput){
  448 + delete this.element.data().date;
  449 + }
  450 + },
  451 +
  452 + _utc_to_local: function(utc){
  453 + return utc && new Date(utc.getTime() + (utc.getTimezoneOffset()*60000));
  454 + },
  455 + _local_to_utc: function(local){
  456 + return local && new Date(local.getTime() - (local.getTimezoneOffset()*60000));
  457 + },
  458 + _zero_time: function(local){
  459 + return local && new Date(local.getFullYear(), local.getMonth(), local.getDate());
  460 + },
  461 + _zero_utc_time: function(utc){
  462 + return utc && new Date(Date.UTC(utc.getUTCFullYear(), utc.getUTCMonth(), utc.getUTCDate()));
  463 + },
  464 +
  465 + getDates: function(){
  466 + return $.map(this.dates, this._utc_to_local);
  467 + },
  468 +
  469 + getUTCDates: function(){
  470 + return $.map(this.dates, function(d){
  471 + return new Date(d);
  472 + });
  473 + },
  474 +
  475 + getDate: function(){
  476 + return this._utc_to_local(this.getUTCDate());
  477 + },
  478 +
  479 + getUTCDate: function(){
  480 + return new Date(this.dates.get(-1));
  481 + },
  482 +
  483 + setDates: function(){
  484 + var args = $.isArray(arguments[0]) ? arguments[0] : arguments;
  485 + this.update.apply(this, args);
  486 + this._trigger('changeDate');
  487 + this.setValue();
  488 + },
  489 +
  490 + setUTCDates: function(){
  491 + var args = $.isArray(arguments[0]) ? arguments[0] : arguments;
  492 + this.update.apply(this, $.map(args, this._utc_to_local));
  493 + this._trigger('changeDate');
  494 + this.setValue();
  495 + },
  496 +
  497 + setDate: alias('setDates'),
  498 + setUTCDate: alias('setUTCDates'),
  499 +
  500 + setValue: function(){
  501 + var formatted = this.getFormattedDate();
  502 + if (!this.isInput){
  503 + if (this.component){
  504 + this.element.find('input').val(formatted).change();
  505 + }
  506 + }
  507 + else {
  508 + this.element.val(formatted).change();
  509 + }
  510 + },
  511 +
  512 + getFormattedDate: function(format){
  513 + if (format === undefined)
  514 + format = this.o.format;
  515 +
  516 + var lang = this.o.language;
  517 + return $.map(this.dates, function(d){
  518 + return DPGlobal.formatDate(d, format, lang);
  519 + }).join(this.o.multidateSeparator);
  520 + },
  521 +
  522 + setStartDate: function(startDate){
  523 + this._process_options({startDate: startDate});
  524 + this.update();
  525 + this.updateNavArrows();
  526 + },
  527 +
  528 + setEndDate: function(endDate){
  529 + this._process_options({endDate: endDate});
  530 + this.update();
  531 + this.updateNavArrows();
  532 + },
  533 +
  534 + setDaysOfWeekDisabled: function(daysOfWeekDisabled){
  535 + this._process_options({daysOfWeekDisabled: daysOfWeekDisabled});
  536 + this.update();
  537 + this.updateNavArrows();
  538 + },
  539 +
  540 + place: function(){
  541 + if (this.isInline)
  542 + return;
  543 + var calendarWidth = this.picker.outerWidth(),
  544 + calendarHeight = this.picker.outerHeight(),
  545 + visualPadding = 10,
  546 + windowWidth = $window.width(),
  547 + windowHeight = $window.height(),
  548 + scrollTop = $window.scrollTop();
  549 +
  550 + var zIndex = parseInt(this.element.parents().filter(function(){
  551 + return $(this).css('z-index') !== 'auto';
  552 + }).first().css('z-index'))+10;
  553 + var offset = this.component ? this.component.parent().offset() : this.element.offset();
  554 + var height = this.component ? this.component.outerHeight(true) : this.element.outerHeight(false);
  555 + var width = this.component ? this.component.outerWidth(true) : this.element.outerWidth(false);
  556 + var left = offset.left,
  557 + top = offset.top;
  558 +
  559 + this.picker.removeClass(
  560 + 'datepicker-orient-top datepicker-orient-bottom '+
  561 + 'datepicker-orient-right datepicker-orient-left'
  562 + );
  563 +
  564 + if (this.o.orientation.x !== 'auto'){
  565 + this.picker.addClass('datepicker-orient-' + this.o.orientation.x);
  566 + if (this.o.orientation.x === 'right')
  567 + left -= calendarWidth - width;
  568 + }
  569 + // auto x orientation is best-placement: if it crosses a window
  570 + // edge, fudge it sideways
  571 + else {
  572 + // Default to left
  573 + this.picker.addClass('datepicker-orient-left');
  574 + if (offset.left < 0)
  575 + left -= offset.left - visualPadding;
  576 + else if (offset.left + calendarWidth > windowWidth)
  577 + left = windowWidth - calendarWidth - visualPadding;
  578 + }
  579 +
  580 + // auto y orientation is best-situation: top or bottom, no fudging,
  581 + // decision based on which shows more of the calendar
  582 + var yorient = this.o.orientation.y,
  583 + top_overflow, bottom_overflow;
  584 + if (yorient === 'auto'){
  585 + top_overflow = -scrollTop + offset.top - calendarHeight;
  586 + bottom_overflow = scrollTop + windowHeight - (offset.top + height + calendarHeight);
  587 + if (Math.max(top_overflow, bottom_overflow) === bottom_overflow)
  588 + yorient = 'top';
  589 + else
  590 + yorient = 'bottom';
  591 + }
  592 + this.picker.addClass('datepicker-orient-' + yorient);
  593 + if (yorient === 'top')
  594 + top += height;
  595 + else
  596 + top -= calendarHeight + parseInt(this.picker.css('padding-top'));
  597 +
  598 + this.picker.css({
  599 + top: top,
  600 + left: left,
  601 + zIndex: zIndex
  602 + });
  603 + },
  604 +
  605 + _allow_update: true,
  606 + update: function(){
  607 + if (!this._allow_update)
  608 + return;
  609 +
  610 + var oldDates = this.dates.copy(),
  611 + dates = [],
  612 + fromArgs = false;
  613 + if (arguments.length){
  614 + $.each(arguments, $.proxy(function(i, date){
  615 + if (date instanceof Date)
  616 + date = this._local_to_utc(date);
  617 + dates.push(date);
  618 + }, this));
  619 + fromArgs = true;
  620 + }
  621 + else {
  622 + dates = this.isInput
  623 + ? this.element.val()
  624 + : this.element.data('date') || this.element.find('input').val();
  625 + if (dates && this.o.multidate)
  626 + dates = dates.split(this.o.multidateSeparator);
  627 + else
  628 + dates = [dates];
  629 + delete this.element.data().date;
  630 + }
  631 +
  632 + dates = $.map(dates, $.proxy(function(date){
  633 + return DPGlobal.parseDate(date, this.o.format, this.o.language);
  634 + }, this));
  635 + dates = $.grep(dates, $.proxy(function(date){
  636 + return (
  637 + date < this.o.startDate ||
  638 + date > this.o.endDate ||
  639 + !date
  640 + );
  641 + }, this), true);
  642 + this.dates.replace(dates);
  643 +
  644 + if (this.dates.length)
  645 + this.viewDate = new Date(this.dates.get(-1));
  646 + else if (this.viewDate < this.o.startDate)
  647 + this.viewDate = new Date(this.o.startDate);
  648 + else if (this.viewDate > this.o.endDate)
  649 + this.viewDate = new Date(this.o.endDate);
  650 +
  651 + if (fromArgs){
  652 + // setting date by clicking
  653 + this.setValue();
  654 + }
  655 + else if (dates.length){
  656 + // setting date by typing
  657 + if (String(oldDates) !== String(this.dates))
  658 + this._trigger('changeDate');
  659 + }
  660 + if (!this.dates.length && oldDates.length)
  661 + this._trigger('clearDate');
  662 +
  663 + this.fill();
  664 + },
  665 +
  666 + fillDow: function(){
  667 + var dowCnt = this.o.weekStart,
  668 + html = '<tr>';
  669 + if (this.o.calendarWeeks){
  670 + var cell = '<th class="cw">&nbsp;</th>';
  671 + html += cell;
  672 + this.picker.find('.datepicker-days thead tr:first-child').prepend(cell);
  673 + }
  674 + while (dowCnt < this.o.weekStart + 7){
  675 + html += '<th class="dow">'+dates[this.o.language].daysMin[(dowCnt++)%7]+'</th>';
  676 + }
  677 + html += '</tr>';
  678 + this.picker.find('.datepicker-days thead').append(html);
  679 + },
  680 +
  681 + fillMonths: function(){
  682 + var html = '',
  683 + i = 0;
  684 + while (i < 12){
  685 + html += '<span class="month">'+dates[this.o.language].monthsShort[i++]+'</span>';
  686 + }
  687 + this.picker.find('.datepicker-months td').html(html);
  688 + },
  689 +
  690 + setRange: function(range){
  691 + if (!range || !range.length)
  692 + delete this.range;
  693 + else
  694 + this.range = $.map(range, function(d){
  695 + return d.valueOf();
  696 + });
  697 + this.fill();
  698 + },
  699 +
  700 + getClassNames: function(date){
  701 + var cls = [],
  702 + year = this.viewDate.getUTCFullYear(),
  703 + month = this.viewDate.getUTCMonth(),
  704 + today = new Date();
  705 + if (date.getUTCFullYear() < year || (date.getUTCFullYear() === year && date.getUTCMonth() < month)){
  706 + cls.push('old');
  707 + }
  708 + else if (date.getUTCFullYear() > year || (date.getUTCFullYear() === year && date.getUTCMonth() > month)){
  709 + cls.push('new');
  710 + }
  711 + if (this.focusDate && date.valueOf() === this.focusDate.valueOf())
  712 + cls.push('focused');
  713 + // Compare internal UTC date with local today, not UTC today
  714 + if (this.o.todayHighlight &&
  715 + date.getUTCFullYear() === today.getFullYear() &&
  716 + date.getUTCMonth() === today.getMonth() &&
  717 + date.getUTCDate() === today.getDate()){
  718 + cls.push('today');
  719 + }
  720 + if (this.dates.contains(date) !== -1)
  721 + cls.push('active');
  722 + if (date.valueOf() < this.o.startDate || date.valueOf() > this.o.endDate ||
  723 + $.inArray(date.getUTCDay(), this.o.daysOfWeekDisabled) !== -1){
  724 + cls.push('disabled');
  725 + }
  726 + if (this.range){
  727 + if (date > this.range[0] && date < this.range[this.range.length-1]){
  728 + cls.push('range');
  729 + }
  730 + if ($.inArray(date.valueOf(), this.range) !== -1){
  731 + cls.push('selected');
  732 + }
  733 + }
  734 + return cls;
  735 + },
  736 +
  737 + fill: function(){
  738 + var d = new Date(this.viewDate),
  739 + year = d.getUTCFullYear(),
  740 + month = d.getUTCMonth(),
  741 + startYear = this.o.startDate !== -Infinity ? this.o.startDate.getUTCFullYear() : -Infinity,
  742 + startMonth = this.o.startDate !== -Infinity ? this.o.startDate.getUTCMonth() : -Infinity,
  743 + endYear = this.o.endDate !== Infinity ? this.o.endDate.getUTCFullYear() : Infinity,
  744 + endMonth = this.o.endDate !== Infinity ? this.o.endDate.getUTCMonth() : Infinity,
  745 + todaytxt = dates[this.o.language].today || dates['en'].today || '',
  746 + cleartxt = dates[this.o.language].clear || dates['en'].clear || '',
  747 + tooltip;
  748 + this.picker.find('.datepicker-days thead th.datepicker-switch')
  749 + .text(dates[this.o.language].months[month]+' '+year);
  750 + this.picker.find('tfoot th.today')
  751 + .text(todaytxt)
  752 + .toggle(this.o.todayBtn !== false);
  753 + this.picker.find('tfoot th.clear')
  754 + .text(cleartxt)
  755 + .toggle(this.o.clearBtn !== false);
  756 + this.updateNavArrows();
  757 + this.fillMonths();
  758 + var prevMonth = UTCDate(year, month-1, 28),
  759 + day = DPGlobal.getDaysInMonth(prevMonth.getUTCFullYear(), prevMonth.getUTCMonth());
  760 + prevMonth.setUTCDate(day);
  761 + prevMonth.setUTCDate(day - (prevMonth.getUTCDay() - this.o.weekStart + 7)%7);
  762 + var nextMonth = new Date(prevMonth);
  763 + nextMonth.setUTCDate(nextMonth.getUTCDate() + 42);
  764 + nextMonth = nextMonth.valueOf();
  765 + var html = [];
  766 + var clsName;
  767 + while (prevMonth.valueOf() < nextMonth){
  768 + if (prevMonth.getUTCDay() === this.o.weekStart){
  769 + html.push('<tr>');
  770 + if (this.o.calendarWeeks){
  771 + // ISO 8601: First week contains first thursday.
  772 + // ISO also states week starts on Monday, but we can be more abstract here.
  773 + var
  774 + // Start of current week: based on weekstart/current date
  775 + ws = new Date(+prevMonth + (this.o.weekStart - prevMonth.getUTCDay() - 7) % 7 * 864e5),
  776 + // Thursday of this week
  777 + th = new Date(Number(ws) + (7 + 4 - ws.getUTCDay()) % 7 * 864e5),
  778 + // First Thursday of year, year from thursday
  779 + yth = new Date(Number(yth = UTCDate(th.getUTCFullYear(), 0, 1)) + (7 + 4 - yth.getUTCDay())%7*864e5),
  780 + // Calendar week: ms between thursdays, div ms per day, div 7 days
  781 + calWeek = (th - yth) / 864e5 / 7 + 1;
  782 + html.push('<td class="cw">'+ calWeek +'</td>');
  783 +
  784 + }
  785 + }
  786 + clsName = this.getClassNames(prevMonth);
  787 + clsName.push('day');
  788 +
  789 + if (this.o.beforeShowDay !== $.noop){
  790 + var before = this.o.beforeShowDay(this._utc_to_local(prevMonth));
  791 + if (before === undefined)
  792 + before = {};
  793 + else if (typeof(before) === 'boolean')
  794 + before = {enabled: before};
  795 + else if (typeof(before) === 'string')
  796 + before = {classes: before};
  797 + if (before.enabled === false)
  798 + clsName.push('disabled');
  799 + if (before.classes)
  800 + clsName = clsName.concat(before.classes.split(/\s+/));
  801 + if (before.tooltip)
  802 + tooltip = before.tooltip;
  803 + }
  804 +
  805 + clsName = $.unique(clsName);
  806 + html.push('<td class="'+clsName.join(' ')+'"' + (tooltip ? ' title="'+tooltip+'"' : '') + '>'+prevMonth.getUTCDate() + '</td>');
  807 + if (prevMonth.getUTCDay() === this.o.weekEnd){
  808 + html.push('</tr>');
  809 + }
  810 + prevMonth.setUTCDate(prevMonth.getUTCDate()+1);
  811 + }
  812 + this.picker.find('.datepicker-days tbody').empty().append(html.join(''));
  813 +
  814 + var months = this.picker.find('.datepicker-months')
  815 + .find('th:eq(1)')
  816 + .text(year)
  817 + .end()
  818 + .find('span').removeClass('active');
  819 +
  820 + $.each(this.dates, function(i, d){
  821 + if (d.getUTCFullYear() === year)
  822 + months.eq(d.getUTCMonth()).addClass('active');
  823 + });
  824 +
  825 + if (year < startYear || year > endYear){
  826 + months.addClass('disabled');
  827 + }
  828 + if (year === startYear){
  829 + months.slice(0, startMonth).addClass('disabled');
  830 + }
  831 + if (year === endYear){
  832 + months.slice(endMonth+1).addClass('disabled');
  833 + }
  834 +
  835 + html = '';
  836 + year = parseInt(year/10, 10) * 10;
  837 + var yearCont = this.picker.find('.datepicker-years')
  838 + .find('th:eq(1)')
  839 + .text(year + '-' + (year + 9))
  840 + .end()
  841 + .find('td');
  842 + year -= 1;
  843 + var years = $.map(this.dates, function(d){
  844 + return d.getUTCFullYear();
  845 + }),
  846 + classes;
  847 + for (var i = -1; i < 11; i++){
  848 + classes = ['year'];
  849 + if (i === -1)
  850 + classes.push('old');
  851 + else if (i === 10)
  852 + classes.push('new');
  853 + if ($.inArray(year, years) !== -1)
  854 + classes.push('active');
  855 + if (year < startYear || year > endYear)
  856 + classes.push('disabled');
  857 + html += '<span class="' + classes.join(' ') + '">'+year+'</span>';
  858 + year += 1;
  859 + }
  860 + yearCont.html(html);
  861 + },
  862 +
  863 + updateNavArrows: function(){
  864 + if (!this._allow_update)
  865 + return;
  866 +
  867 + var d = new Date(this.viewDate),
  868 + year = d.getUTCFullYear(),
  869 + month = d.getUTCMonth();
  870 + switch (this.viewMode){
  871 + case 0:
  872 + if (this.o.startDate !== -Infinity && year <= this.o.startDate.getUTCFullYear() && month <= this.o.startDate.getUTCMonth()){
  873 + this.picker.find('.prev').css({visibility: 'hidden'});
  874 + }
  875 + else {
  876 + this.picker.find('.prev').css({visibility: 'visible'});
  877 + }
  878 + if (this.o.endDate !== Infinity && year >= this.o.endDate.getUTCFullYear() && month >= this.o.endDate.getUTCMonth()){
  879 + this.picker.find('.next').css({visibility: 'hidden'});
  880 + }
  881 + else {
  882 + this.picker.find('.next').css({visibility: 'visible'});
  883 + }
  884 + break;
  885 + case 1:
  886 + case 2:
  887 + if (this.o.startDate !== -Infinity && year <= this.o.startDate.getUTCFullYear()){
  888 + this.picker.find('.prev').css({visibility: 'hidden'});
  889 + }
  890 + else {
  891 + this.picker.find('.prev').css({visibility: 'visible'});
  892 + }
  893 + if (this.o.endDate !== Infinity && year >= this.o.endDate.getUTCFullYear()){
  894 + this.picker.find('.next').css({visibility: 'hidden'});
  895 + }
  896 + else {
  897 + this.picker.find('.next').css({visibility: 'visible'});
  898 + }
  899 + break;
  900 + }
  901 + },
  902 +
  903 + click: function(e){
  904 + e.preventDefault();
  905 + var target = $(e.target).closest('span, td, th'),
  906 + year, month, day;
  907 + if (target.length === 1){
  908 + switch (target[0].nodeName.toLowerCase()){
  909 + case 'th':
  910 + switch (target[0].className){
  911 + case 'datepicker-switch':
  912 + this.showMode(1);
  913 + break;
  914 + case 'prev':
  915 + case 'next':
  916 + var dir = DPGlobal.modes[this.viewMode].navStep * (target[0].className === 'prev' ? -1 : 1);
  917 + switch (this.viewMode){
  918 + case 0:
  919 + this.viewDate = this.moveMonth(this.viewDate, dir);
  920 + this._trigger('changeMonth', this.viewDate);
  921 + break;
  922 + case 1:
  923 + case 2:
  924 + this.viewDate = this.moveYear(this.viewDate, dir);
  925 + if (this.viewMode === 1)
  926 + this._trigger('changeYear', this.viewDate);
  927 + break;
  928 + }
  929 + this.fill();
  930 + break;
  931 + case 'today':
  932 + var date = new Date();
  933 + date = UTCDate(date.getFullYear(), date.getMonth(), date.getDate(), 0, 0, 0);
  934 +
  935 + this.showMode(-2);
  936 + var which = this.o.todayBtn === 'linked' ? null : 'view';
  937 + this._setDate(date, which);
  938 + break;
  939 + case 'clear':
  940 + var element;
  941 + if (this.isInput)
  942 + element = this.element;
  943 + else if (this.component)
  944 + element = this.element.find('input');
  945 + if (element)
  946 + element.val("").change();
  947 + this.update();
  948 + this._trigger('changeDate');
  949 + if (this.o.autoclose)
  950 + this.hide();
  951 + break;
  952 + }
  953 + break;
  954 + case 'span':
  955 + if (!target.is('.disabled')){
  956 + this.viewDate.setUTCDate(1);
  957 + if (target.is('.month')){
  958 + day = 1;
  959 + month = target.parent().find('span').index(target);
  960 + year = this.viewDate.getUTCFullYear();
  961 + this.viewDate.setUTCMonth(month);
  962 + this._trigger('changeMonth', this.viewDate);
  963 + if (this.o.minViewMode === 1){
  964 + this._setDate(UTCDate(year, month, day));
  965 + }
  966 + }
  967 + else {
  968 + day = 1;
  969 + month = 0;
  970 + year = parseInt(target.text(), 10)||0;
  971 + this.viewDate.setUTCFullYear(year);
  972 + this._trigger('changeYear', this.viewDate);
  973 + if (this.o.minViewMode === 2){
  974 + this._setDate(UTCDate(year, month, day));
  975 + }
  976 + }
  977 + this.showMode(-1);
  978 + this.fill();
  979 + }
  980 + break;
  981 + case 'td':
  982 + if (target.is('.day') && !target.is('.disabled')){
  983 + day = parseInt(target.text(), 10)||1;
  984 + year = this.viewDate.getUTCFullYear();
  985 + month = this.viewDate.getUTCMonth();
  986 + if (target.is('.old')){
  987 + if (month === 0){
  988 + month = 11;
  989 + year -= 1;
  990 + }
  991 + else {
  992 + month -= 1;
  993 + }
  994 + }
  995 + else if (target.is('.new')){
  996 + if (month === 11){
  997 + month = 0;
  998 + year += 1;
  999 + }
  1000 + else {
  1001 + month += 1;
  1002 + }
  1003 + }
  1004 + this._setDate(UTCDate(year, month, day));
  1005 + }
  1006 + break;
  1007 + }
  1008 + }
  1009 + if (this.picker.is(':visible') && this._focused_from){
  1010 + $(this._focused_from).focus();
  1011 + }
  1012 + delete this._focused_from;
  1013 + },
  1014 +
  1015 + _toggle_multidate: function(date){
  1016 + var ix = this.dates.contains(date);
  1017 + if (!date){
  1018 + this.dates.clear();
  1019 + }
  1020 + else if (ix !== -1){
  1021 + this.dates.remove(ix);
  1022 + }
  1023 + else {
  1024 + this.dates.push(date);
  1025 + }
  1026 + if (typeof this.o.multidate === 'number')
  1027 + while (this.dates.length > this.o.multidate)
  1028 + this.dates.remove(0);
  1029 + },
  1030 +
  1031 + _setDate: function(date, which){
  1032 + if (!which || which === 'date')
  1033 + this._toggle_multidate(date && new Date(date));
  1034 + if (!which || which === 'view')
  1035 + this.viewDate = date && new Date(date);
  1036 +
  1037 + this.fill();
  1038 + this.setValue();
  1039 + this._trigger('changeDate');
  1040 + var element;
  1041 + if (this.isInput){
  1042 + element = this.element;
  1043 + }
  1044 + else if (this.component){
  1045 + element = this.element.find('input');
  1046 + }
  1047 + if (element){
  1048 + element.change();
  1049 + }
  1050 + if (this.o.autoclose && (!which || which === 'date')){
  1051 + this.hide();
  1052 + }
  1053 + },
  1054 +
  1055 + moveMonth: function(date, dir){
  1056 + if (!date)
  1057 + return undefined;
  1058 + if (!dir)
  1059 + return date;
  1060 + var new_date = new Date(date.valueOf()),
  1061 + day = new_date.getUTCDate(),
  1062 + month = new_date.getUTCMonth(),
  1063 + mag = Math.abs(dir),
  1064 + new_month, test;
  1065 + dir = dir > 0 ? 1 : -1;
  1066 + if (mag === 1){
  1067 + test = dir === -1
  1068 + // If going back one month, make sure month is not current month
  1069 + // (eg, Mar 31 -> Feb 31 == Feb 28, not Mar 02)
  1070 + ? function(){
  1071 + return new_date.getUTCMonth() === month;
  1072 + }
  1073 + // If going forward one month, make sure month is as expected
  1074 + // (eg, Jan 31 -> Feb 31 == Feb 28, not Mar 02)
  1075 + : function(){
  1076 + return new_date.getUTCMonth() !== new_month;
  1077 + };
  1078 + new_month = month + dir;
  1079 + new_date.setUTCMonth(new_month);
  1080 + // Dec -> Jan (12) or Jan -> Dec (-1) -- limit expected date to 0-11
  1081 + if (new_month < 0 || new_month > 11)
  1082 + new_month = (new_month + 12) % 12;
  1083 + }
  1084 + else {
  1085 + // For magnitudes >1, move one month at a time...
  1086 + for (var i=0; i < mag; i++)
  1087 + // ...which might decrease the day (eg, Jan 31 to Feb 28, etc)...
  1088 + new_date = this.moveMonth(new_date, dir);
  1089 + // ...then reset the day, keeping it in the new month
  1090 + new_month = new_date.getUTCMonth();
  1091 + new_date.setUTCDate(day);
  1092 + test = function(){
  1093 + return new_month !== new_date.getUTCMonth();
  1094 + };
  1095 + }
  1096 + // Common date-resetting loop -- if date is beyond end of month, make it
  1097 + // end of month
  1098 + while (test()){
  1099 + new_date.setUTCDate(--day);
  1100 + new_date.setUTCMonth(new_month);
  1101 + }
  1102 + return new_date;
  1103 + },
  1104 +
  1105 + moveYear: function(date, dir){
  1106 + return this.moveMonth(date, dir*12);
  1107 + },
  1108 +
  1109 + dateWithinRange: function(date){
  1110 + return date >= this.o.startDate && date <= this.o.endDate;
  1111 + },
  1112 +
  1113 + keydown: function(e){
  1114 + if (this.picker.is(':not(:visible)')){
  1115 + if (e.keyCode === 27) // allow escape to hide and re-show picker
  1116 + this.show();
  1117 + return;
  1118 + }
  1119 + var dateChanged = false,
  1120 + dir, newDate, newViewDate,
  1121 + focusDate = this.focusDate || this.viewDate;
  1122 + switch (e.keyCode){
  1123 + case 27: // escape
  1124 + if (this.focusDate){
  1125 + this.focusDate = null;
  1126 + this.viewDate = this.dates.get(-1) || this.viewDate;
  1127 + this.fill();
  1128 + }
  1129 + else
  1130 + this.hide();
  1131 + e.preventDefault();
  1132 + break;
  1133 + case 37: // left
  1134 + case 39: // right
  1135 + if (!this.o.keyboardNavigation)
  1136 + break;
  1137 + dir = e.keyCode === 37 ? -1 : 1;
  1138 + if (e.ctrlKey){
  1139 + newDate = this.moveYear(this.dates.get(-1) || UTCToday(), dir);
  1140 + newViewDate = this.moveYear(focusDate, dir);
  1141 + this._trigger('changeYear', this.viewDate);
  1142 + }
  1143 + else if (e.shiftKey){
  1144 + newDate = this.moveMonth(this.dates.get(-1) || UTCToday(), dir);
  1145 + newViewDate = this.moveMonth(focusDate, dir);
  1146 + this._trigger('changeMonth', this.viewDate);
  1147 + }
  1148 + else {
  1149 + newDate = new Date(this.dates.get(-1) || UTCToday());
  1150 + newDate.setUTCDate(newDate.getUTCDate() + dir);
  1151 + newViewDate = new Date(focusDate);
  1152 + newViewDate.setUTCDate(focusDate.getUTCDate() + dir);
  1153 + }
  1154 + if (this.dateWithinRange(newDate)){
  1155 + this.focusDate = this.viewDate = newViewDate;
  1156 + this.setValue();
  1157 + this.fill();
  1158 + e.preventDefault();
  1159 + }
  1160 + break;
  1161 + case 38: // up
  1162 + case 40: // down
  1163 + if (!this.o.keyboardNavigation)
  1164 + break;
  1165 + dir = e.keyCode === 38 ? -1 : 1;
  1166 + if (e.ctrlKey){
  1167 + newDate = this.moveYear(this.dates.get(-1) || UTCToday(), dir);
  1168 + newViewDate = this.moveYear(focusDate, dir);
  1169 + this._trigger('changeYear', this.viewDate);
  1170 + }
  1171 + else if (e.shiftKey){
  1172 + newDate = this.moveMonth(this.dates.get(-1) || UTCToday(), dir);
  1173 + newViewDate = this.moveMonth(focusDate, dir);
  1174 + this._trigger('changeMonth', this.viewDate);
  1175 + }
  1176 + else {
  1177 + newDate = new Date(this.dates.get(-1) || UTCToday());
  1178 + newDate.setUTCDate(newDate.getUTCDate() + dir * 7);
  1179 + newViewDate = new Date(focusDate);
  1180 + newViewDate.setUTCDate(focusDate.getUTCDate() + dir * 7);
  1181 + }
  1182 + if (this.dateWithinRange(newDate)){
  1183 + this.focusDate = this.viewDate = newViewDate;
  1184 + this.setValue();
  1185 + this.fill();
  1186 + e.preventDefault();
  1187 + }
  1188 + break;
  1189 + case 32: // spacebar
  1190 + // Spacebar is used in manually typing dates in some formats.
  1191 + // As such, its behavior should not be hijacked.
  1192 + break;
  1193 + case 13: // enter
  1194 + focusDate = this.focusDate || this.dates.get(-1) || this.viewDate;
  1195 + this._toggle_multidate(focusDate);
  1196 + dateChanged = true;
  1197 + this.focusDate = null;
  1198 + this.viewDate = this.dates.get(-1) || this.viewDate;
  1199 + this.setValue();
  1200 + this.fill();
  1201 + if (this.picker.is(':visible')){
  1202 + e.preventDefault();
  1203 + if (this.o.autoclose)
  1204 + this.hide();
  1205 + }
  1206 + break;
  1207 + case 9: // tab
  1208 + this.focusDate = null;
  1209 + this.viewDate = this.dates.get(-1) || this.viewDate;
  1210 + this.fill();
  1211 + this.hide();
  1212 + break;
  1213 + }
  1214 + if (dateChanged){
  1215 + if (this.dates.length)
  1216 + this._trigger('changeDate');
  1217 + else
  1218 + this._trigger('clearDate');
  1219 + var element;
  1220 + if (this.isInput){
  1221 + element = this.element;
  1222 + }
  1223 + else if (this.component){
  1224 + element = this.element.find('input');
  1225 + }
  1226 + if (element){
  1227 + element.change();
  1228 + }
  1229 + }
  1230 + },
  1231 +
  1232 + showMode: function(dir){
  1233 + if (dir){
  1234 + this.viewMode = Math.max(this.o.minViewMode, Math.min(2, this.viewMode + dir));
  1235 + }
  1236 + this.picker
  1237 + .find('>div')
  1238 + .hide()
  1239 + .filter('.datepicker-'+DPGlobal.modes[this.viewMode].clsName)
  1240 + .css('display', 'block');
  1241 + this.updateNavArrows();
  1242 + }
  1243 + };
  1244 +
  1245 + var DateRangePicker = function(element, options){
  1246 + this.element = $(element);
  1247 + this.inputs = $.map(options.inputs, function(i){
  1248 + return i.jquery ? i[0] : i;
  1249 + });
  1250 + delete options.inputs;
  1251 +
  1252 + $(this.inputs)
  1253 + .datepicker(options)
  1254 + .bind('changeDate', $.proxy(this.dateUpdated, this));
  1255 +
  1256 + this.pickers = $.map(this.inputs, function(i){
  1257 + return $(i).data('datepicker');
  1258 + });
  1259 + this.updateDates();
  1260 + };
  1261 + DateRangePicker.prototype = {
  1262 + updateDates: function(){
  1263 + this.dates = $.map(this.pickers, function(i){
  1264 + return i.getUTCDate();
  1265 + });
  1266 + this.updateRanges();
  1267 + },
  1268 + updateRanges: function(){
  1269 + var range = $.map(this.dates, function(d){
  1270 + return d.valueOf();
  1271 + });
  1272 + $.each(this.pickers, function(i, p){
  1273 + p.setRange(range);
  1274 + });
  1275 + },
  1276 + dateUpdated: function(e){
  1277 + // `this.updating` is a workaround for preventing infinite recursion
  1278 + // between `changeDate` triggering and `setUTCDate` calling. Until
  1279 + // there is a better mechanism.
  1280 + if (this.updating)
  1281 + return;
  1282 + this.updating = true;
  1283 +
  1284 + var dp = $(e.target).data('datepicker'),
  1285 + new_date = dp.getUTCDate(),
  1286 + i = $.inArray(e.target, this.inputs),
  1287 + l = this.inputs.length;
  1288 + if (i === -1)
  1289 + return;
  1290 +
  1291 + $.each(this.pickers, function(i, p){
  1292 + if (!p.getUTCDate())
  1293 + p.setUTCDate(new_date);
  1294 + });
  1295 +
  1296 + if (new_date < this.dates[i]){
  1297 + // Date being moved earlier/left
  1298 + while (i >= 0 && new_date < this.dates[i]){
  1299 + this.pickers[i--].setUTCDate(new_date);
  1300 + }
  1301 + }
  1302 + else if (new_date > this.dates[i]){
  1303 + // Date being moved later/right
  1304 + while (i < l && new_date > this.dates[i]){
  1305 + this.pickers[i++].setUTCDate(new_date);
  1306 + }
  1307 + }
  1308 + this.updateDates();
  1309 +
  1310 + delete this.updating;
  1311 + },
  1312 + remove: function(){
  1313 + $.map(this.pickers, function(p){ p.remove(); });
  1314 + delete this.element.data().datepicker;
  1315 + }
  1316 + };
  1317 +
  1318 + function opts_from_el(el, prefix){
  1319 + // Derive options from element data-attrs
  1320 + var data = $(el).data(),
  1321 + out = {}, inkey,
  1322 + replace = new RegExp('^' + prefix.toLowerCase() + '([A-Z])');
  1323 + prefix = new RegExp('^' + prefix.toLowerCase());
  1324 + function re_lower(_,a){
  1325 + return a.toLowerCase();
  1326 + }
  1327 + for (var key in data)
  1328 + if (prefix.test(key)){
  1329 + inkey = key.replace(replace, re_lower);
  1330 + out[inkey] = data[key];
  1331 + }
  1332 + return out;
  1333 + }
  1334 +
  1335 + function opts_from_locale(lang){
  1336 + // Derive options from locale plugins
  1337 + var out = {};
  1338 + // Check if "de-DE" style date is available, if not language should
  1339 + // fallback to 2 letter code eg "de"
  1340 + if (!dates[lang]){
  1341 + lang = lang.split('-')[0];
  1342 + if (!dates[lang])
  1343 + return;
  1344 + }
  1345 + var d = dates[lang];
  1346 + $.each(locale_opts, function(i,k){
  1347 + if (k in d)
  1348 + out[k] = d[k];
  1349 + });
  1350 + return out;
  1351 + }
  1352 +
  1353 + var old = $.fn.datepicker;
  1354 + $.fn.datepicker = function(option){
  1355 + var args = Array.apply(null, arguments);
  1356 + args.shift();
  1357 + var internal_return;
  1358 + this.each(function(){
  1359 + var $this = $(this),
  1360 + data = $this.data('datepicker'),
  1361 + options = typeof option === 'object' && option;
  1362 + if (!data){
  1363 + var elopts = opts_from_el(this, 'date'),
  1364 + // Preliminary otions
  1365 + xopts = $.extend({}, defaults, elopts, options),
  1366 + locopts = opts_from_locale(xopts.language),
  1367 + // Options priority: js args, data-attrs, locales, defaults
  1368 + opts = $.extend({}, defaults, locopts, elopts, options);
  1369 + if ($this.is('.input-daterange') || opts.inputs){
  1370 + var ropts = {
  1371 + inputs: opts.inputs || $this.find('input').toArray()
  1372 + };
  1373 + $this.data('datepicker', (data = new DateRangePicker(this, $.extend(opts, ropts))));
  1374 + }
  1375 + else {
  1376 + $this.data('datepicker', (data = new Datepicker(this, opts)));
  1377 + }
  1378 + }
  1379 + if (typeof option === 'string' && typeof data[option] === 'function'){
  1380 + internal_return = data[option].apply(data, args);
  1381 + if (internal_return !== undefined)
  1382 + return false;
  1383 + }
  1384 + });
  1385 + if (internal_return !== undefined)
  1386 + return internal_return;
  1387 + else
  1388 + return this;
  1389 + };
  1390 +
  1391 + var defaults = $.fn.datepicker.defaults = {
  1392 + autoclose: false,
  1393 + beforeShowDay: $.noop,
  1394 + calendarWeeks: false,
  1395 + clearBtn: false,
  1396 + daysOfWeekDisabled: [],
  1397 + endDate: Infinity,
  1398 + forceParse: true,
  1399 + format: 'mm/dd/yyyy',
  1400 + keyboardNavigation: true,
  1401 + language: 'en',
  1402 + minViewMode: 0,
  1403 + multidate: false,
  1404 + multidateSeparator: ',',
  1405 + orientation: "auto",
  1406 + rtl: false,
  1407 + startDate: -Infinity,
  1408 + startView: 0,
  1409 + todayBtn: false,
  1410 + todayHighlight: false,
  1411 + weekStart: 0
  1412 + };
  1413 + var locale_opts = $.fn.datepicker.locale_opts = [
  1414 + 'format',
  1415 + 'rtl',
  1416 + 'weekStart'
  1417 + ];
  1418 + $.fn.datepicker.Constructor = Datepicker;
  1419 + var dates = $.fn.datepicker.dates = {
  1420 + en: {
  1421 + days: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday", "Sunday"],
  1422 + daysShort: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat", "Sun"],
  1423 + daysMin: ["Su", "Mo", "Tu", "We", "Th", "Fr", "Sa", "Su"],
  1424 + months: ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"],
  1425 + monthsShort: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"],
  1426 + today: "Today",
  1427 + clear: "Clear"
  1428 + }
  1429 + };
  1430 +
  1431 + var DPGlobal = {
  1432 + modes: [
  1433 + {
  1434 + clsName: 'days',
  1435 + navFnc: 'Month',
  1436 + navStep: 1
  1437 + },
  1438 + {
  1439 + clsName: 'months',
  1440 + navFnc: 'FullYear',
  1441 + navStep: 1
  1442 + },
  1443 + {
  1444 + clsName: 'years',
  1445 + navFnc: 'FullYear',
  1446 + navStep: 10
  1447 + }],
  1448 + isLeapYear: function(year){
  1449 + return (((year % 4 === 0) && (year % 100 !== 0)) || (year % 400 === 0));
  1450 + },
  1451 + getDaysInMonth: function(year, month){
  1452 + return [31, (DPGlobal.isLeapYear(year) ? 29 : 28), 31, 30, 31, 30, 31, 31, 30, 31, 30, 31][month];
  1453 + },
  1454 + validParts: /dd?|DD?|mm?|MM?|yy(?:yy)?/g,
  1455 + nonpunctuation: /[^ -\/:-@\[\u3400-\u9fff-`{-~\t\n\r]+/g,
  1456 + parseFormat: function(format){
  1457 + // IE treats \0 as a string end in inputs (truncating the value),
  1458 + // so it's a bad format delimiter, anyway
  1459 + var separators = format.replace(this.validParts, '\0').split('\0'),
  1460 + parts = format.match(this.validParts);
  1461 + if (!separators || !separators.length || !parts || parts.length === 0){
  1462 + throw new Error("Invalid date format.");
  1463 + }
  1464 + return {separators: separators, parts: parts};
  1465 + },
  1466 + parseDate: function(date, format, language){
  1467 + if (!date)
  1468 + return undefined;
  1469 + if (date instanceof Date)
  1470 + return date;
  1471 + if (typeof format === 'string')
  1472 + format = DPGlobal.parseFormat(format);
  1473 + var part_re = /([\-+]\d+)([dmwy])/,
  1474 + parts = date.match(/([\-+]\d+)([dmwy])/g),
  1475 + part, dir, i;
  1476 + if (/^[\-+]\d+[dmwy]([\s,]+[\-+]\d+[dmwy])*$/.test(date)){
  1477 + date = new Date();
  1478 + for (i=0; i < parts.length; i++){
  1479 + part = part_re.exec(parts[i]);
  1480 + dir = parseInt(part[1]);
  1481 + switch (part[2]){
  1482 + case 'd':
  1483 + date.setUTCDate(date.getUTCDate() + dir);
  1484 + break;
  1485 + case 'm':
  1486 + date = Datepicker.prototype.moveMonth.call(Datepicker.prototype, date, dir);
  1487 + break;
  1488 + case 'w':
  1489 + date.setUTCDate(date.getUTCDate() + dir * 7);
  1490 + break;
  1491 + case 'y':
  1492 + date = Datepicker.prototype.moveYear.call(Datepicker.prototype, date, dir);
  1493 + break;
  1494 + }
  1495 + }
  1496 + return UTCDate(date.getUTCFullYear(), date.getUTCMonth(), date.getUTCDate(), 0, 0, 0);
  1497 + }
  1498 + parts = date && date.match(this.nonpunctuation) || [];
  1499 + date = new Date();
  1500 + var parsed = {},
  1501 + setters_order = ['yyyy', 'yy', 'M', 'MM', 'm', 'mm', 'd', 'dd'],
  1502 + setters_map = {
  1503 + yyyy: function(d,v){
  1504 + return d.setUTCFullYear(v);
  1505 + },
  1506 + yy: function(d,v){
  1507 + return d.setUTCFullYear(2000+v);
  1508 + },
  1509 + m: function(d,v){
  1510 + if (isNaN(d))
  1511 + return d;
  1512 + v -= 1;
  1513 + while (v < 0) v += 12;
  1514 + v %= 12;
  1515 + d.setUTCMonth(v);
  1516 + while (d.getUTCMonth() !== v)
  1517 + d.setUTCDate(d.getUTCDate()-1);
  1518 + return d;
  1519 + },
  1520 + d: function(d,v){
  1521 + return d.setUTCDate(v);
  1522 + }
  1523 + },
  1524 + val, filtered;
  1525 + setters_map['M'] = setters_map['MM'] = setters_map['mm'] = setters_map['m'];
  1526 + setters_map['dd'] = setters_map['d'];
  1527 + date = UTCDate(date.getFullYear(), date.getMonth(), date.getDate(), 0, 0, 0);
  1528 + var fparts = format.parts.slice();
  1529 + // Remove noop parts
  1530 + if (parts.length !== fparts.length){
  1531 + fparts = $(fparts).filter(function(i,p){
  1532 + return $.inArray(p, setters_order) !== -1;
  1533 + }).toArray();
  1534 + }
  1535 + // Process remainder
  1536 + function match_part(){
  1537 + var m = this.slice(0, parts[i].length),
  1538 + p = parts[i].slice(0, m.length);
  1539 + return m === p;
  1540 + }
  1541 + if (parts.length === fparts.length){
  1542 + var cnt;
  1543 + for (i=0, cnt = fparts.length; i < cnt; i++){
  1544 + val = parseInt(parts[i], 10);
  1545 + part = fparts[i];
  1546 + if (isNaN(val)){
  1547 + switch (part){
  1548 + case 'MM':
  1549 + filtered = $(dates[language].months).filter(match_part);
  1550 + val = $.inArray(filtered[0], dates[language].months) + 1;
  1551 + break;
  1552 + case 'M':
  1553 + filtered = $(dates[language].monthsShort).filter(match_part);
  1554 + val = $.inArray(filtered[0], dates[language].monthsShort) + 1;
  1555 + break;
  1556 + }
  1557 + }
  1558 + parsed[part] = val;
  1559 + }
  1560 + var _date, s;
  1561 + for (i=0; i < setters_order.length; i++){
  1562 + s = setters_order[i];
  1563 + if (s in parsed && !isNaN(parsed[s])){
  1564 + _date = new Date(date);
  1565 + setters_map[s](_date, parsed[s]);
  1566 + if (!isNaN(_date))
  1567 + date = _date;
  1568 + }
  1569 + }
  1570 + }
  1571 + return date;
  1572 + },
  1573 + formatDate: function(date, format, language){
  1574 + if (!date)
  1575 + return '';
  1576 + if (typeof format === 'string')
  1577 + format = DPGlobal.parseFormat(format);
  1578 + var val = {
  1579 + d: date.getUTCDate(),
  1580 + D: dates[language].daysShort[date.getUTCDay()],
  1581 + DD: dates[language].days[date.getUTCDay()],
  1582 + m: date.getUTCMonth() + 1,
  1583 + M: dates[language].monthsShort[date.getUTCMonth()],
  1584 + MM: dates[language].months[date.getUTCMonth()],
  1585 + yy: date.getUTCFullYear().toString().substring(2),
  1586 + yyyy: date.getUTCFullYear()
  1587 + };
  1588 + val.dd = (val.d < 10 ? '0' : '') + val.d;
  1589 + val.mm = (val.m < 10 ? '0' : '') + val.m;
  1590 + date = [];
  1591 + var seps = $.extend([], format.separators);
  1592 + for (var i=0, cnt = format.parts.length; i <= cnt; i++){
  1593 + if (seps.length)
  1594 + date.push(seps.shift());
  1595 + date.push(val[format.parts[i]]);
  1596 + }
  1597 + return date.join('');
  1598 + },
  1599 + headTemplate: '<thead>'+
  1600 + '<tr>'+
  1601 + '<th class="prev">&laquo;</th>'+
  1602 + '<th colspan="5" class="datepicker-switch"></th>'+
  1603 + '<th class="next">&raquo;</th>'+
  1604 + '</tr>'+
  1605 + '</thead>',
  1606 + contTemplate: '<tbody><tr><td colspan="7"></td></tr></tbody>',
  1607 + footTemplate: '<tfoot>'+
  1608 + '<tr>'+
  1609 + '<th colspan="7" class="today"></th>'+
  1610 + '</tr>'+
  1611 + '<tr>'+
  1612 + '<th colspan="7" class="clear"></th>'+
  1613 + '</tr>'+
  1614 + '</tfoot>'
  1615 + };
  1616 + DPGlobal.template = '<div class="datepicker">'+
  1617 + '<div class="datepicker-days">'+
  1618 + '<table class=" table-condensed">'+
  1619 + DPGlobal.headTemplate+
  1620 + '<tbody></tbody>'+
  1621 + DPGlobal.footTemplate+
  1622 + '</table>'+
  1623 + '</div>'+
  1624 + '<div class="datepicker-months">'+
  1625 + '<table class="table-condensed">'+
  1626 + DPGlobal.headTemplate+
  1627 + DPGlobal.contTemplate+
  1628 + DPGlobal.footTemplate+
  1629 + '</table>'+
  1630 + '</div>'+
  1631 + '<div class="datepicker-years">'+
  1632 + '<table class="table-condensed">'+
  1633 + DPGlobal.headTemplate+
  1634 + DPGlobal.contTemplate+
  1635 + DPGlobal.footTemplate+
  1636 + '</table>'+
  1637 + '</div>'+
  1638 + '</div>';
  1639 +
  1640 + $.fn.datepicker.DPGlobal = DPGlobal;
  1641 +
  1642 +
  1643 + /* DATEPICKER NO CONFLICT
  1644 + * =================== */
  1645 +
  1646 + $.fn.datepicker.noConflict = function(){
  1647 + $.fn.datepicker = old;
  1648 + return this;
  1649 + };
  1650 +
  1651 +
  1652 + /* DATEPICKER DATA-API
  1653 + * ================== */
  1654 +
  1655 + $(document).on(
  1656 + 'focus.datepicker.data-api click.datepicker.data-api',
  1657 + '[data-provide="datepicker"]',
  1658 + function(e){
  1659 + var $this = $(this);
  1660 + if ($this.data('datepicker'))
  1661 + return;
  1662 + e.preventDefault();
  1663 + // component click requires us to explicitly show it
  1664 + $this.datepicker('show');
  1665 + }
  1666 + );
  1667 + $(function(){
  1668 + $('[data-provide="datepicker-inline"]').datepicker();
  1669 + });
  1670 +
  1671 +}(window.jQuery));
... ...
app/partials/FuelVendors/FuelVendors.controller.js
... ... @@ -3,38 +3,124 @@
3 3 //Load controller
4 4 angular.module('acufuel')
5 5  
6   - .controller('FuelVendorsController', ['$scope',function($scope) {
7   -
8   - $scope.vendorList = [{
9   - "companyName": "Name and inc",
10   - "phone":"1010101010",
11   - "contact":"jimmy",
12   - "status":'Active',
13   - "source": "tenant",
14   - "allIn" : "$123"
15   - },{
16   - "companyName": "Name and inc",
17   - "phone":"1010101010",
18   - "contact":"jimmy",
19   - "status":'Active',
20   - "source": "tenant",
21   - "allIn" : "$123"
22   - },{
23   - "companyName": "Name and inc",
24   - "Fleet": 3,
25   - "phone":"1010101010",
26   - "contact":"jimmy",
27   - "Base":"Kiad",
28   - "status":'Inactive',
29   - "source": "tenant",
30   - "allIn" : "$123"
31   - },{
32   - "companyName": "Name and inc",
33   - "phone":"1010101010",
34   - "contact":"jimmy",
35   - "status":'Active',
36   - "source": "tenant",
37   - "allIn" : "$123"
38   - }]
39   -
40   - }]);
41 6 \ No newline at end of file
  7 + .controller('FuelVendorsController', ['$scope', '$rootScope', '$uibModal', '$filter', '$http', 'FuelVendorsService', 'CustomersService', FuelVendorsController]);
  8 +
  9 + function FuelVendorsController($scope, $rootScope, $uibModal, $filter, $http, FuelVendorsService, CustomersService) {
  10 +
  11 + $(document).ready(function() {
  12 + $('#example').DataTable();
  13 + });
  14 + $scope.data = {};
  15 + $scope.aircraft = {};
  16 + $scope.data.activate = true;
  17 +
  18 + getAllVendor();
  19 +
  20 + function getAllVendor(){
  21 + FuelVendorsService.getAllVendor().then(function(result) {
  22 + console.log(result)
  23 + $scope.vendorList = result;
  24 + })
  25 + }
  26 +
  27 +
  28 + $(function() {
  29 + $('#vendor-toggle-one2').bootstrapToggle();
  30 + $('#vendor-toggle-one2').change(function() {
  31 + $('#console-event').html('Toggle: ' + $(this).prop('checked'));
  32 + $scope.data.activate = $(this).prop('checked');
  33 + })
  34 + })
  35 +
  36 + getData();
  37 + function getData(){
  38 + CustomersService.getAircraftMake().then(function(result) {
  39 + $scope.aircraftMakeList = result;
  40 + })
  41 + }
  42 +
  43 + $scope.addFirstData = function(sel, step){
  44 + // console.log($scope.data)
  45 +
  46 + var vendorData = "vendorName=" + $scope.data.vendorName + "&masterMargin=" + $scope.data.masterMargin
  47 + + "&addressOne=" + $scope.data.addressOne + "&addressTwo=" + $scope.data.addressTwo + "&city=" + $scope.data.city + "&state="
  48 + + $scope.data.state + "&country=" + $scope.data.country + "&zipcode=" + $scope.data.zipcode + "&internalNote="
  49 + + $scope.data.internalNote + "&certificateType=" + $scope.data.certificateType + "&baseTenant=" + $scope.data.baseTenant
  50 + + "&fuelerlinxCustomer=" + $scope.data.fuelerlinxCustomer + "&contractFuelVendor=" + $scope.data.contractFuelVendor
  51 + + "&activate=" + $scope.data.activate + "&baseIcao=" + $scope.data.baseIcao;
  52 +
  53 + FuelVendorsService.addVendor(vendorData).then(function(result) {
  54 + console.log("result",result)
  55 + $scope.accountId = result;
  56 + $scope.aircraft.accountId = $scope.accountId;
  57 + })
  58 + $(sel).trigger('next.m.' + step);
  59 + getData();
  60 + }
  61 +
  62 + $scope.aircraftDetails = [{
  63 + 'tail':'',
  64 + 'make': '',
  65 + 'model': '',
  66 + 'sizeId' : ''
  67 + }];
  68 +
  69 + $scope.addNew = function(){
  70 + $scope.aircraftDetails.push({
  71 + 'tail':'',
  72 + 'make': '',
  73 + 'model': '',
  74 + 'sizeId' : ''
  75 + });
  76 + console.log($scope.aircraftDetails)
  77 + };
  78 +
  79 + $scope.getModal = function(makeId, index){
  80 + $scope.aircraft.make = makeId;
  81 + //var makeId = makeId;
  82 + CustomersService.getModal($scope.aircraft.make).then(function(result) {
  83 + $scope.aircraftDetails[index].aircraftModalList = result;
  84 + //$scope.aircraftDetails[index].model = $scope.aircraftModalList[0];
  85 + })
  86 + }
  87 +
  88 + $scope.getSize = function(model, index){
  89 + CustomersService.getAircraftSize($scope.aircraft.make, model).then(function(result) {
  90 + console.log("result",result)
  91 + $scope.aircraftDetails[index].aircraftSizeList = result;
  92 + //$scope.aircraftDetails[index].size = $scope.aircraftSizeList[0];
  93 + console.log($scope.aircraftDetails[index].size)
  94 + })
  95 + }
  96 +
  97 + $scope.aircraftListData = {};
  98 + $scope.addData = [];
  99 + $scope.saveVendorData = function(){
  100 + for(var i=0; i<$scope.aircraftDetails.length;i++){
  101 + $scope.addData.push({
  102 + 'tail': $scope.aircraftDetails[i].tail,
  103 + 'make': $scope.aircraftDetails[i].make,
  104 + 'model': $scope.aircraftDetails[i].model,
  105 + 'sizeId' : $scope.aircraftDetails[i].sizeId
  106 + });
  107 + }
  108 + $scope.aircraftListData.aircraftList = $scope.addData;
  109 + $scope.aircraftListData.accountId = $scope.aircraft.accountId;
  110 +
  111 + FuelVendorsService.addVendorAicraft($scope.aircraftListData).then(function(result) {
  112 + console.log(result)
  113 +
  114 + if(result != null && result.success){
  115 + toastr.success(''+result.success+'', {
  116 + closeButton: true
  117 + })
  118 + $('#vendor-modal-3').modal('hide');
  119 + getAllVendor();
  120 + }else{
  121 + toastr.error(''+result.statusText+'', {
  122 + closeButton: true
  123 + })
  124 + }
  125 + });
  126 + }
  127 + }
42 128 \ No newline at end of file
... ...
app/partials/FuelVendors/FuelVendors.html
1 1 <style>
2 2 .subnavbar .mainnav > li:nth-child(3) > a{
3   - color: #ff9900;
  3 + color: #ff9900;
4 4 }
  5 +
  6 + .button1 {
  7 + display: inline-block;
  8 + height: 35px;
  9 + line-height: 35px;
  10 + padding-right: 15px;
  11 + padding-left: 50px;
  12 + position: relative;
  13 + background-color:rgb(41,127,184);
  14 + color:rgb(255,255,255);
  15 + text-decoration: none;
  16 + text-transform: uppercase;
  17 + letter-spacing: 1px;
  18 + margin-bottom: 15px;
  19 + border: 0;
  20 +
  21 +
  22 + border-radius: 5px;
  23 + -moz-border-radius: 5px;
  24 + -webkit-border-radius: 5px;
  25 + text-shadow:0px 1px 0px rgba(0,0,0,0.5);
  26 + -ms-filter:"progid:DXImageTransform.Microsoft.dropshadow(OffX=0,OffY=1,Color=#ff123852,Positive=true)";zoom:1;
  27 + filter:progid:DXImageTransform.Microsoft.dropshadow(OffX=0,OffY=1,Color=#ff123852,Positive=true);
  28 +
  29 + -moz-box-shadow:0px 2px 2px rgba(0,0,0,0.2);
  30 + -webkit-box-shadow:0px 2px 2px rgba(0,0,0,0.2);
  31 + box-shadow:0px 2px 2px rgba(0,0,0,0.2);
  32 + -ms-filter:"progid:DXImageTransform.Microsoft.dropshadow(OffX=0,OffY=2,Color=#33000000,Positive=true)";
  33 + filter:progid:DXImageTransform.Microsoft.dropshadow(OffX=0,OffY=2,Color=#33000000,Positive=true);
  34 + }
  35 +
  36 + .button1 span {
  37 + position: absolute;
  38 + left: 0;
  39 + top: 0;
  40 + width: 35px;
  41 + background-color:rgba(0,0,0,0.5);
  42 +
  43 + -webkit-border-top-left-radius: 5px;
  44 + -webkit-border-bottom-left-radius: 5px;
  45 + -moz-border-radius-topleft: 5px;
  46 + -moz-border-radius-bottomleft: 5px;
  47 + border-top-left-radius: 5px;
  48 + border-bottom-left-radius: 5px;
  49 + border-right: 1px solid rgba(0,0,0,0.15);
  50 + }
  51 +
  52 + .button1:hover span, .button1.active span {
  53 + background-color:rgb(0,102,26);
  54 + border-right: 1px solid rgba(0,0,0,0.3);
  55 + }
  56 +
  57 + .button1:active {
  58 + margin-top: 2px;
  59 + margin-bottom: 13px;
  60 +
  61 + -moz-box-shadow:0px 1px 0px rgba(255,255,255,0.5);
  62 + -webkit-box-shadow:0px 1px 0px rgba(255,255,255,0.5);
  63 + box-shadow:0px 1px 0px rgba(255,255,255,0.5);
  64 + -ms-filter:"progid:DXImageTransform.Microsoft.dropshadow(OffX=0,OffY=1,Color=#ccffffff,Positive=true)";
  65 + filter:progid:DXImageTransform.Microsoft.dropshadow(OffX=0,OffY=1,Color=#ccffffff,Positive=true);
  66 + }
  67 +
  68 + .button1.turquoise {
  69 + background: #449d44;
  70 + }
  71 +
5 72 </style>
6 73 <div class="main">
7 74 <div class="container">
... ... @@ -28,7 +95,7 @@
28 95 </li>
29 96 <li style="margin: 0px 10px 4px 40px;"><input type="text" style="height:31px;"class="form-control" name="name" id="name" placeholder="Search In Table"></li>
30 97 <li><button type="button" class="btn btn-default btn-sm">Clear Search And Filters</button></li>
31   - <li style="float:right"><button type="submit" class="btn btn-success btn-sm"><i class="fa fa-plus" aria-hidden="true"></i> Add Company</button></li>
  98 + <li style="float:right"><button type="submit" data-toggle="modal" data-target="#vendor-modal-3" class="btn btn-success btn-sm"><i class="fa fa-plus" aria-hidden="true"></i> Add Vendor</button></li>
32 99 </ul>
33 100 <br>
34 101 <div class="tab-content customer-table" style="margin:0px">
... ... @@ -38,7 +105,7 @@
38 105 <tr>
39 106 <th>
40 107 <input type="text" class="form-control" style="height:31px;" name="name" id="name">
41   - <label class="font-company">Company Name <i class="fa fa-sort" aria-hidden="true"></i></label>
  108 + <label class="font-company">Vendor Name <i class="fa fa-sort" aria-hidden="true"></i></label>
42 109 </th>
43 110  
44 111 <th>
... ... @@ -69,12 +136,14 @@
69 136 </thead>
70 137 <tbody>
71 138 <tr ng-repeat="vendor in vendorList">
72   - <td class="font-company">{{vendor.companyName}}</td>
  139 + <td class="font-company">
  140 + <a style="color: #333; text-decoration: none;" href="#!/viewFuelVendor/{{vendor.id}}">{{vendor.vendorName}}</a>
  141 + </td>
73 142 <td class="font-company">{{vendor.phone}}</td>
74 143 <td class="font-company">{{vendor.contact}}</td>
75 144 <td class="font-company">
76   - <button type="button" ng-if="vendor.status == 'Active'" class="btn btn-success btn-xs">{{vendor.status}}</button>
77   - <button type="button" ng-if="vendor.status == 'Inactive'" class="btn btn-warning btn-xs">{{vendor.status}}</button>
  145 + <button type="button" ng-if="vendor.activate == true" class="btn btn-success btn-xs">Active</button>
  146 + <button type="button" ng-if="vendor.activate == false" class="btn btn-warning btn-xs">InActive</button>
78 147 </td>
79 148 <td class="font-company">{{vendor.source}}</td>
80 149 <td class="font-company">
... ... @@ -219,4 +288,330 @@
219 288 </div>
220 289 <!-- /container -->
221 290 </div>
222   -<!-- /main -->
223 291 \ No newline at end of file
  292 +<!-- /main -->
  293 +
  294 +<form class="modal multi-step" id="vendor-modal-3" name="vendorForm">
  295 + <div class="modal-dialog modal-lg">
  296 + <div class="modal-content">
  297 + <div class="modal-body step-1" data-step="1" style="padding: 0;">
  298 + <div>
  299 + <div class="row" style="margin: 0;">
  300 + <div>
  301 + <div class="widget" style="margin-bottom: 0;">
  302 + <div class="widget-header">
  303 + <i class="icon-pencil"></i>
  304 + <i class="fa fa-tasks" aria-hidden="true"></i>
  305 + <h3>Add a New Vendor</h3>
  306 + <div class="pull-right my-toggle-switch" style="margin-right: 30px;">
  307 + <div style="color: #ff9a01;">Activate &nbsp &nbsp
  308 + <input id="vendor-toggle-one2" checked type="checkbox" data-size="mini" data-width="55" data-toggle="toggle" data-on="On" data-off="Off">
  309 + </div>
  310 + </div>
  311 + <div class="clearfix"></div>
  312 + </div>
  313 + <div class="widget-content" style="padding-left: 0; padding-right: 0; border-bottom: 0;">
  314 + <div class="col-xs-12">
  315 + <div class="col-md-8">
  316 + <div class="pull-left">
  317 + <label class="new-input-label"><b>Vendor Name</b></label>
  318 + </div>
  319 + <div class="pull-left" style="margin-left: 15px;">
  320 + <input type="text" ng-model="data.vendorName" class="form-control" id="Address" placeholder="">
  321 + </div>
  322 + <div class="clearfix"></div>
  323 + </div>
  324 + <div class="col-md-4">
  325 +
  326 + <div class="pull-right">
  327 + <input type="text" ng-model="data.baseIcao" style="width: 100px;" class="form-control" id="Address" placeholder="">
  328 + </div>
  329 + <div class="pull-right">
  330 + <label style="margin-right: 15px;" class="new-input-label"><b>Base ICAO</b></label>
  331 + </div>
  332 + <div class="clearfix"></div>
  333 + </div>
  334 + </div>
  335 + <div class="clearfix"></div><br>
  336 + <div class="col-xs-12">
  337 + <div class="col-md-8">
  338 + <div class="pull-left">
  339 + <label class="new-input-label"><b>Relationship&nbsp;</b></label>
  340 + </div>
  341 + <div class="pull-left" style="margin-left: 32px;">
  342 + <input type="checkbox" ng-model="data.baseTenant" name="vehicle" value="Bike"> Check here if this is a Base Tenant<br>
  343 + <input type="checkbox" ng-model="data.fuelerlinxCustomer" name="vehicle" value="Car" checked> Check here if this is a FuelerLinx Customer<br>
  344 + <input type="checkbox" ng-model="data.contractFuelVendor" name="vehicle" value="Car" checked> Check here if this is a Contract Fuel Vendor
  345 + </div>
  346 + <div class="clearfix"></div>
  347 + </div>
  348 + </div>
  349 + <div class="clearfix"></div>
  350 + <br/>
  351 + <div class="col-xs-12">
  352 + <div class="col-md-6">
  353 + <div class="pull-left" style="width: 110px;">
  354 + <b>Master Margin</b>
  355 + </div>
  356 + <div class="pull-left">
  357 + <select required class="form-control" style="max-width: 250px;" ng-model="data.masterMargin">
  358 + <option value="" disabled selected hidden>Select </option>
  359 + <option value="margin1">Margin1</option>
  360 + <option value="margin2">Margin2</option>
  361 + <option value="vendorsonly">Vendors Only</option>
  362 + <option value="margintenants">Margin Tenants</option>
  363 + </select>
  364 + </div>
  365 + <div class="clearfix"></div>
  366 + </div>
  367 +
  368 + <div class="col-md-3 Airport" style="text-align: right;">
  369 + <b>Certificate Type</b>
  370 + </div>
  371 + <div class="col-md-3 Airport">
  372 + <select required class="form-control" ng-model="data.certificateType">
  373 + <option value="" disabled selected hidden>Select </option>
  374 + <option value="corporate">Part 91 (Corporate)</option>
  375 + <option value="charter">Part 135 (Charter)</option>
  376 + <option value="scheduled">Part 121 (Scheduled)</option>
  377 + <option value="military">Military</option>
  378 + <option value="government">Government</option>
  379 + </select>
  380 + </div>
  381 + </div>
  382 + <div class="clearfix"></div>
  383 + <br/>
  384 + <div class="col-xs-12">
  385 + <div class="col-md-12">
  386 + <div class="pull-left" style="width: 110px;">
  387 + <label class="new-input-label"><b>Address</b></label>
  388 + </div>
  389 + <div class="pull-left" style="width: calc(100% - 110px);">
  390 + <input type="text" class="form-control" ng-model="data.addressOne" id="Address" placeholder="">
  391 + </div>
  392 + <div class="clearfix"></div>
  393 + </div>
  394 + </div>
  395 + <div class="clearfix"></div>
  396 + <br/>
  397 + <div class="col-xs-12">
  398 + <div class="col-md-12">
  399 + <div class="pull-left" style="width: 110px;">
  400 + <label class="new-input-label"><b>Address2</b></label>
  401 + </div>
  402 + <div class="pull-left" style="width: calc(100% - 110px);">
  403 + <input type="text" ng-model="data.addressTwo" class="form-control" id="Address" placeholder="">
  404 + </div>
  405 + <div class="clearfix"></div>
  406 + </div>
  407 + </div>
  408 + <div class="clearfix"></div>
  409 + <br/>
  410 + <div class="col-xs-12">
  411 +
  412 + <div class="col-md-6">
  413 + <div class="pull-left" style="width: 110px;">
  414 + <label class="new-input-label"><b>City</b></label>
  415 + </div>
  416 + <div class="pull-left" style="width: calc(100% - 110px);">
  417 + <input type="text" ng-model="data.city" class="form-control" id="Address" placeholder="">
  418 + </div>
  419 + <div class="clearfix"></div>
  420 + </div>
  421 + <div class="col-md-3">
  422 + <div class="pull-left" style="width: 40px;">
  423 + <label class="new-input-label"><b>State</b></label>
  424 + </div>
  425 + <div class="pull-left" style="width: calc(100% - 110px);">
  426 + <input type="text" ng-model="data.state" class="form-control" id="Address" placeholder="">
  427 + </div>
  428 + <div class="clearfix"></div>
  429 + </div>
  430 + <div class="col-md-3">
  431 + <div class="pull-left">
  432 + <label class="new-input-label"><b>Zip Code</b></label>
  433 + </div>
  434 + <div class="pull-right" style="width: calc(100% - 60px);">
  435 + <input type="tel" ng-model="data.zipcode" class="form-control" id="Address" placeholder="">
  436 + </div>
  437 + <div class="clearfix"></div>
  438 + </div>
  439 + </div>
  440 + <div class="clearfix"></div>
  441 + <br/>
  442 + <div class="col-xs-12">
  443 +
  444 + <div class="col-md-6">
  445 + <div class="pull-left" style="width: 110px;">
  446 + <label class="new-input-label"><b>Country</b></label>
  447 + </div>
  448 + <div class="pull-left" style="width: calc(100% - 110px);">
  449 + <input type="text" ng-model="data.country" class="form-control" id="Address" placeholder="">
  450 + </div>
  451 + <div class="clearfix"></div>
  452 + </div>
  453 + <div class="col-md-6">
  454 + <div class="pull-left" style="width: 110px;">
  455 + <label class="new-input-label"><b>Internal Note</b></label>
  456 + </div>
  457 + <div class="pull-left" style="width: calc(100% - 110px);">
  458 + <textarea name="message" ng-model="data.internalNote" rows="4" cols="34"></textarea>
  459 + </div>
  460 + <div class="clearfix"></div>
  461 + </div>
  462 + </div>
  463 + <div class="clearfix"></div>
  464 + <!-- <br/>
  465 + <div class="col-xs-12">
  466 + <div class="col-md-2 Airport"></div>
  467 + <div class="col-md-10 Airport">
  468 + <div class="pull-right">
  469 + <button type="button" class="btn btn-default" ng-click="cancel()">Cancel</button>
  470 + <button type="button" class="btn btn-warning" ng-click="addAircraft()">Next: Add Aircraft</button>
  471 + </div>
  472 + </div>
  473 + </div> -->
  474 + </div>
  475 + </div>
  476 + <div class="clearfix"></div>
  477 + </div>
  478 + </div>
  479 + </div>
  480 + </div>
  481 + <div class="modal-body step-2" data-step="2" style="padding: 0;">
  482 + <div>
  483 + <div class="row" style="margin: 0;">
  484 + <div>
  485 + <div class="widget" style="margin-bottom: 0;">
  486 + <div class="widget-header">
  487 + <i class="icon-pencil"></i>
  488 + <i class="fa fa-tasks" aria-hidden="true"></i>
  489 + <h3>Add a New Vendor</h3>
  490 + <div class="clearfix"></div>
  491 + </div>
  492 + <div class="widget-content" style="padding-left: 0; padding-right: 0; border-bottom: 0;">
  493 + <div class="col-xs-12">
  494 + <div class="widget-header">
  495 + <i class="fa fa-list"></i>
  496 + <h3>Aircraft List</h3>
  497 + </div>
  498 + <div class="widget-content" style="padding:0px;border: 0px; ">
  499 + <div class="table-responsive">
  500 + <!-- <table class="table table-bordered table-hover table-striped addRow" style="margin-bottom: 0px;">
  501 + <thead>
  502 + <tr>
  503 + <th>Tail</th>
  504 + <th>Make</th>
  505 + <th>Model</th>
  506 + <th>Size</th>
  507 + <th>Margin</th>
  508 + </tr>
  509 + </thead>
  510 + <tbody>
  511 + <tr>
  512 + <td>
  513 + <input type="text" style="width:100px;" ng-model="aircraft.tail" class="form-control">
  514 + </td>
  515 + <td style="width: 25%;">
  516 + <select class="form-control" ng-model="aircraft.make" ng-change="getModal()">
  517 + <option ng-repeat="make in aircraftMakeList">{{make}}</option>
  518 + </select>
  519 + </td>
  520 + <td style="width: 20%;">
  521 + <select class="form-control" ng-model="aircraft.model" ng-change="getSize()">
  522 + <option ng-repeat="model in aircraftModalList">{{model}}</option>
  523 + </select>
  524 + </td>
  525 + <td style="width: 25%;">
  526 + <select class="form-control" ng-model="aircraft.size">
  527 + <option ng-repeat="size in aircraftSizeList">{{size}}</option>
  528 + </select>
  529 + </td>
  530 + <td>
  531 + <select class="form-control">
  532 + <option>Margin1</option>
  533 + <option>Margin2</option>
  534 + </select>
  535 + </td>
  536 + </tr>
  537 + </tbody>
  538 +
  539 + </table> -->
  540 + <table class="table table-striped table-bordered">
  541 + <thead>
  542 + <tr>
  543 + <!-- <th><input type="checkbox" ng-model="selectedAll" ng-click="checkAll()" /></th> -->
  544 + <th>Tail</th>
  545 + <th>Make</th>
  546 + <th>Model</th>
  547 + <th>Size</th>
  548 + </tr>
  549 + </thead>
  550 + <tbody>
  551 + <tr ng-repeat="aircraftData in aircraftDetails track by $index">
  552 + <!-- <td>
  553 + <input type="checkbox" ng-model="aircraftData.selected"/>
  554 + </td> -->
  555 + <td style="width: 20%">
  556 + <input type="text" class="form-control" ng-model="aircraftData.tail" required/>
  557 + </td>
  558 + <td style="width: 20%">
  559 + <select class="form-control" ng-model="aircraftData.make" ng-change="getModal(aircraftData.make, $index)">
  560 + <option ng-repeat="make in aircraftMakeList">{{make}}</option>
  561 + </select>
  562 + </td>
  563 + <td style="width: 20%">
  564 + <select class="form-control" ng-model="aircraftData.model" ng-change="getSize(aircraftData.model, $index)">
  565 + <option ng-repeat="model in aircraftData.aircraftModalList">{{model}}</option>
  566 + </select>
  567 + </td>
  568 + <td style="width: 20%">
  569 + <select class="form-control" ng-model="aircraftData.sizeId" ng-options="size.aircraftSize.id as size.aircraftSize.size for size in aircraftData.aircraftSizeList"></select>
  570 + <!-- <select class="form-control" ng-model="aircraftData.size">
  571 + <option ng-repeat="size in aircraftData.aircraftSizeList">{{size}}</option>
  572 + </select> -->
  573 + </td>
  574 + </tr>
  575 + </tbody>
  576 + </table>
  577 + </div>
  578 + <div class="clearfix"></div>
  579 + </div>
  580 + </div>
  581 + <div class="clearfix"></div>
  582 + <div class="col-xs-12" style="margin-bottom: 50px;margin-top: 10px;">
  583 + <button ng-click="addNew()" class="button1 turquoise pull-right"><span>+</span>Add Aircraft</button>
  584 + </div>
  585 + <!-- <div class="col-xs-12" style="margin-bottom: 20px;">
  586 + <div class="pull-right">
  587 + <button type="button" class="btn btn-default" ng-click="cancelCraft()">Cancel</button>
  588 + <button type="button" class="btn btn-warning" ng-click="goBack()">Go Back</button>
  589 + <button type="button" class="btn btn-success" ng-click="goBack()">Save</button>
  590 + </div>
  591 + </div> -->
  592 + </div>
  593 + </div>
  594 + <div class="clearfix"></div>
  595 + </div>
  596 + </div>
  597 + </div>
  598 + </div>
  599 + <!-- <div class="modal-body step-3" data-step="3">
  600 + This is the final step.
  601 + </div> -->
  602 + <div class="modal-footer" style="border-top: 0;">
  603 + <button type="button" class="btn btn-default" data-dismiss="modal">Cancel</button>
  604 + <button type="button" class="btn btn-primary step step-1" data-step="1" ng-click="addFirstData('#vendor-modal-3', 2)">Next: Add Aircraft</button>
  605 + <button type="button" class="btn btn-primary step step-2" data-step="2" onclick="sendEvent('#vendor-modal-3', 1)">Go Back</button>
  606 + <!-- <button type="button" class="btn btn-primary step step-2" data-step="2" onclick="sendEvent('#vendor-modal-3', 3)">Continue</button> -->
  607 + <button type="button" class="btn btn-success step step-2" data-step="2" ng-click="saveVendorData()">Save</button>
  608 + </div>
  609 + </div>
  610 + </div>
  611 +</form>
  612 +
  613 +<script src="js/multi-step-modal.js"></script>
  614 +<script>
  615 +sendEvent = function(sel, step) {
  616 + $(sel).trigger('next.m.' + step);
  617 +}
  618 +</script>
224 619 \ No newline at end of file
... ...
app/partials/FuelVendors/FuelVendors.service.js
1 1 (function(){
2 2 'use strict';
3 3 angular.module('acufuel')
4   - .service('FuelVendorsService', ['$q', '$http', 'BE', FuelVendorsService]);
  4 + .service('FuelVendorsService', ['$q', '$http','BASE_URL', FuelVendorsService]);
5 5  
6   - function FuelVendorsService($q, $http, BE) {
7   - var temp = {};
  6 + function FuelVendorsService($q, $http, BASE_URL) {
  7 +
  8 + this.getAllVendor = function() {
  9 +
  10 + var deferred = $q.defer();
  11 + $http({
  12 + method : 'GET',
  13 + url : BASE_URL.url +'/user/allVendors',
  14 + headers : {'Content-Type': 'application/json'},
  15 + })
  16 + .then(function (result){
  17 + deferred.resolve(result.data);
  18 + },function (result){
  19 + deferred.resolve(result.data);
  20 + })
  21 + return deferred.promise;
  22 + }
  23 +
  24 + this.addVendor = function(data) {
  25 + console.log("data",data);
  26 +
  27 + var deferred = $q.defer();
  28 + $http({
  29 + method : 'POST',
  30 + url : BASE_URL.url +'/vendor',
  31 + headers : {'Content-Type': 'application/json'},
  32 + data: data
  33 + })
  34 + .then(function (result){
  35 + deferred.resolve(result.data);
  36 + },function (result){
  37 + deferred.resolve(result.data);
  38 + })
  39 + return deferred.promise;
  40 + }
  41 +
  42 + this.addVendorAicraft = function(data) {
  43 + console.log("data",data);
  44 +
  45 + var deferred = $q.defer();
  46 + $http({
  47 + method : 'POST',
  48 + url : BASE_URL.url +'/vendor/add/aircrafts',
  49 + headers : {'Content-Type': 'application/json'},
  50 + data: data
  51 + })
  52 + .then(function (result){
  53 + deferred.resolve(result.data);
  54 + },function (result){
  55 + deferred.resolve(result.data);
  56 + })
  57 + return deferred.promise;
  58 + }
  59 + }
8 60  
9   -
10   -
11   - }
12   -
13 61 })();
14 62 \ No newline at end of file
... ...
app/partials/customers/customers.controller.js
... ... @@ -12,10 +12,14 @@
12 12 $scope.aircraft = {};
13 13 $scope.data.activate = true;
14 14  
15   - CustomersService.getAllCompanies().then(function(result) {
16   - console.log(result)
17   - $scope.companyList = result;
18   - })
  15 + getAllCompanies();
  16 +
  17 + function getAllCompanies(){
  18 + CustomersService.getAllCompanies().then(function(result) {
  19 + console.log(result)
  20 + $scope.companyList = result;
  21 + })
  22 + }
19 23  
20 24 $(function() {
21 25 $('#toggle-one2').bootstrapToggle();
... ... @@ -57,7 +61,7 @@
57 61 'tail':'',
58 62 'make': '',
59 63 'model': '',
60   - 'size' : ''
  64 + 'sizeId' : ''
61 65 }];
62 66  
63 67 $scope.addNew = function(){
... ... @@ -65,7 +69,7 @@
65 69 'tail':'',
66 70 'make': '',
67 71 'model': '',
68   - 'size' : ''
  72 + 'sizeId' : ''
69 73 });
70 74 console.log($scope.aircraftDetails)
71 75 };
... ... @@ -95,7 +99,7 @@
95 99 'tail': $scope.aircraftDetails[i].tail,
96 100 'make': $scope.aircraftDetails[i].make,
97 101 'model': $scope.aircraftDetails[i].model,
98   - 'size' : $scope.aircraftDetails[i].size
  102 + 'sizeId' : $scope.aircraftDetails[i].sizeId
99 103 });
100 104 }
101 105 $scope.aircraftListData.aircraftList = $scope.addData;
... ... @@ -103,11 +107,13 @@
103 107  
104 108 CustomersService.addAircraft($scope.aircraftListData).then(function(result) {
105 109 console.log(result)
  110 +
106 111 if(result != null && result.success){
107 112 toastr.success(''+result.success+'', {
108 113 closeButton: true
109 114 })
110 115 $('#demo-modal-3').modal('hide');
  116 + getAllCompanies();
111 117 }else{
112 118 toastr.error(''+result.statusText+'', {
113 119 closeButton: true
... ...
app/partials/customers/customers.html
... ... @@ -154,7 +154,6 @@
154 154 <button type="button" ng-if="customer.activate == true" class="btn btn-success btn-xs">Active</button>
155 155 <button type="button" ng-if="customer.activate == false" class="btn btn-warning btn-xs">InActive</button>
156 156 </td>
157   - </td>
158 157 <td class="font-company">
159 158 <select class="form-control" style="height:31px;">
160 159 <option>Margin1</option>
... ... @@ -577,9 +576,10 @@
577 576 </select>
578 577 </td>
579 578 <td style="width: 20%">
580   - <select class="form-control" ng-model="aircraftData.size">
  579 + <select class="form-control" ng-model="aircraftData.sizeId" ng-options="size.aircraftSize.id as size.aircraftSize.size for size in aircraftData.aircraftSizeList"></select>
  580 + <!-- <select class="form-control" ng-model="aircraftData.size">
581 581 <option ng-repeat="size in aircraftData.aircraftSizeList">{{size}}</option>
582   - </select>
  582 + </select> -->
583 583 </td>
584 584 </tr>
585 585 </tbody>
... ...
app/partials/fuelManager/fuelManager.controller.js
... ... @@ -12,7 +12,6 @@
12 12 $scope.currentUserData = JSON.parse(localStorage.getItem('userProfileId'));
13 13  
14 14 fuelManagerService.getFullList().then(function(result) {
15   - console.log('result', result)
16 15 $scope.fullJetList = result;
17 16 })
18 17  
... ... @@ -45,9 +44,11 @@
45 44 }
46 45 $scope.avoidanceList.rampFeesAndAvoidanceList = $scope.addData;
47 46 $scope.avoidanceList.fboUserId = $scope.currentUserData;
48   - console.log('data', $scope.avoidanceList);
49 47  
50 48 fuelManagerService.updateFullList($scope.avoidanceList).then(function(result) {
  49 + toastr.success(''+result.success+'', {
  50 + closeButton: true
  51 + })
51 52 fuelManagerService.getFullList().then(function(result) {
52 53 $scope.fullJetList = result;
53 54 })
... ... @@ -56,6 +57,144 @@
56 57 }
57 58  
58 59 }
  60 +
  61 + $scope.dropOptions = {};
  62 +
  63 + fuelManagerService.getOptions().then(function(result) {
  64 + $scope.dropOptions = result;
  65 + })
  66 +
  67 + fuelManagerService.getAircrafts().then(function(result) {
  68 + $scope.aircrafts = result;
  69 + })
  70 +
  71 + $scope.openRampFeeModal = false;
  72 + $scope.customRampData = {};
  73 + $scope.customRampData.rampFeesAndAvoidanceList = {};
  74 + $scope.customRampData.rampFeesAndAvoidanceList.aircraftType = null;
  75 +
  76 + $scope.customRampData.rampFeesAndAvoidanceList.aircraftMake = '';
  77 + $scope.customRampData.rampFeesAndAvoidanceList.aircraftSizeId = '';
  78 + $scope.customRampData.rampFeesAndAvoidanceList.tailNumber = '';
  79 + $scope.customRampData.rampFeesAndAvoidanceList.wingspanMin = '';
  80 + $scope.customRampData.rampFeesAndAvoidanceList.wingspanMax = '';
  81 + $scope.customRampData.rampFeesAndAvoidanceList.weightRangeMin = '';
  82 + $scope.customRampData.rampFeesAndAvoidanceList.weightRangeMax = '';
  83 + $scope.customRampData.rampFeesAndAvoidanceList.weightRangeMax = '';
  84 + $scope.customRampData.rampFeesAndAvoidanceList.rampFees = '';
  85 + $scope.customRampData.rampFeesAndAvoidanceList.avoidance = '';
  86 + //$scope.customRampData.fboUserId = '';
  87 +
  88 + //$scope.rampFeeType = '';
  89 +
  90 + $scope.openRampModal = function(){
  91 + //console.log('$scope.dropOptions', $scope.dropOptions)
  92 +
  93 +
  94 + if ($scope.customRampData.rampFeesAndAvoidanceList.aircraftType === 'WEIGHT') {
  95 + $scope.openRampFeeModal = true;
  96 + $scope.showWeight = true;
  97 + $scope.showWingspan = false;
  98 + $scope.showTail = false;
  99 + $scope.showAircraft = false;
  100 + $scope.customRampData.rampFeesAndAvoidanceList.aircraftMake = '';
  101 + $scope.customRampData.rampFeesAndAvoidanceList.tailNumber = '';
  102 + $scope.customRampData.rampFeesAndAvoidanceList.wingspanMin = '';
  103 + $scope.customRampData.rampFeesAndAvoidanceList.wingspanMax = '';
  104 + $scope.customRampData.rampFeesAndAvoidanceList.rampFees = '';
  105 + $scope.customRampData.rampFeesAndAvoidanceList.avoidance = '';
  106 + }else if ($scope.customRampData.rampFeesAndAvoidanceList.aircraftType === 'MAKE_AND_MODEL') {
  107 + $scope.openRampFeeModal = true;
  108 + $scope.showWeight = false;
  109 + $scope.showWingspan = false;
  110 + $scope.showTail = false;
  111 + $scope.showAircraft = true;
  112 + $scope.customRampData.rampFeesAndAvoidanceList.tailNumber = '';
  113 + $scope.customRampData.rampFeesAndAvoidanceList.wingspanMin = '';
  114 + $scope.customRampData.rampFeesAndAvoidanceList.wingspanMax = '';
  115 + $scope.customRampData.rampFeesAndAvoidanceList.weightRangeMin = '';
  116 + $scope.customRampData.rampFeesAndAvoidanceList.weightRangeMax = '';
  117 + $scope.customRampData.rampFeesAndAvoidanceList.rampFees = '';
  118 + $scope.customRampData.rampFeesAndAvoidanceList.avoidance = '';
  119 + }else if ($scope.customRampData.rampFeesAndAvoidanceList.aircraftType === 'WINGSPAN') {
  120 + $scope.openRampFeeModal = true;
  121 + $scope.showWeight = false;
  122 + $scope.showWingspan = true;
  123 + $scope.showTail = false;
  124 + $scope.showAircraft = false;
  125 + $scope.customRampData.rampFeesAndAvoidanceList.aircraftMake = '';
  126 + $scope.customRampData.rampFeesAndAvoidanceList.tailNumber = '';
  127 + $scope.customRampData.rampFeesAndAvoidanceList.weightRangeMin = '';
  128 + $scope.customRampData.rampFeesAndAvoidanceList.weightRangeMax = '';
  129 + $scope.customRampData.rampFeesAndAvoidanceList.rampFees = '';
  130 + $scope.customRampData.rampFeesAndAvoidanceList.avoidance = '';
  131 + }else if ($scope.customRampData.rampFeesAndAvoidanceList.aircraftType === 'TAIL') {
  132 + $scope.openRampFeeModal = true;
  133 + $scope.showWeight = false;
  134 + $scope.showWingspan = false;
  135 + $scope.showTail = true;
  136 + $scope.showAircraft = false;
  137 + $scope.customRampData.rampFeesAndAvoidanceList.aircraftMake = '';
  138 + $scope.customRampData.rampFeesAndAvoidanceList.wingspanMin = '';
  139 + $scope.customRampData.rampFeesAndAvoidanceList.wingspanMax = '';
  140 + $scope.customRampData.rampFeesAndAvoidanceList.weightRangeMin = '';
  141 + $scope.customRampData.rampFeesAndAvoidanceList.weightRangeMax = '';
  142 + $scope.customRampData.rampFeesAndAvoidanceList.rampFees = '';
  143 + $scope.customRampData.rampFeesAndAvoidanceList.avoidance = '';
  144 + }else if ($scope.customRampData.rampFeesAndAvoidanceList.aircraftType = null){
  145 + $scope.openRampFeeModal = false;
  146 + $scope.showWeight = false;
  147 + $scope.showWingspan = false;
  148 + $scope.showTail = false;
  149 + $scope.showAircraft = false;
  150 + }else{
  151 + $scope.openRampFeeModal = false;
  152 + $scope.showWeight = false;
  153 + $scope.showWingspan = false;
  154 + $scope.showTail = false;
  155 + $scope.showAircraft = false;
  156 + }
  157 + for (var i = 0; $scope.dropOptions.length; i++) {
  158 + if ($scope.customRampData.rampFeesAndAvoidanceList.aircraftType === $scope.dropOptions[i].size) {
  159 + $scope.customRampData.rampFeesAndAvoidanceList.aircraftSizeId = $scope.dropOptions[i].id;
  160 + }
  161 + }
  162 + }
  163 +
  164 +
  165 +
  166 + $scope.addCustomRamp = function(){
  167 +
  168 + $scope.newData = {};
  169 + $scope.newData.rampFeesAndAvoidanceList = [];
  170 + $scope.newData.rampFeesAndAvoidanceList.push($scope.customRampData.rampFeesAndAvoidanceList);
  171 + $scope.newData.fboUserId = $scope.currentUserData;
  172 + console.log('$scope.customRampData', $scope.newData)
  173 + fuelManagerService.updateFullList($scope.newData).then(function(result) {
  174 + toastr.success(''+result.success+'', {
  175 + closeButton: true
  176 + });
  177 + $scope.openRampFeeModal = false;
  178 + $scope.customRampData.rampFeesAndAvoidanceList = {};
  179 + $scope.customRampData.rampFeesAndAvoidanceList.aircraftType = null;
  180 + $scope.newData = {};
  181 + $scope.newData.rampFeesAndAvoidanceList = [];
  182 + fuelManagerService.getFullList().then(function(result) {
  183 + $scope.fullJetList = result;
  184 + })
  185 + })
  186 + }
  187 +
  188 + $scope.closeRampFeeModel = function(){
  189 + $scope.openRampFeeModal = false;
  190 + $scope.showWeight = false;
  191 + $scope.showWingspan = false;
  192 + $scope.showTail = false;
  193 + $scope.showAircraft = false;
  194 + $scope.customRampData.rampFeesAndAvoidanceList = {};
  195 + $scope.customRampData.rampFeesAndAvoidanceList.aircraftType = null;
  196 + }
  197 +
59 198 $scope.parentOpen = function(index){
60 199 $('#parentOpen'+index).css('display', 'none');
61 200 $('#parentClose'+index).css('display', 'initial');
... ... @@ -79,6 +218,12 @@
79 218 }
80 219  
81 220 $(document).ready(function(){
  221 +
  222 + setInterval(function(){
  223 + var newHeight = $('.feeManagerLeft').height();
  224 + $('.feeManagerRight').css('height', newHeight);
  225 + }, 3);
  226 +
82 227 $('#customTabToggle1').click(function(){
83 228 console.log('tab 1');
84 229 $('#customTabsBody1').slideDown();
... ...
app/partials/fuelManager/fuelManager.html
... ... @@ -317,11 +317,9 @@
317 317 <div class="widget-header">
318 318 <i class="fa fa-pencil"></i>
319 319 <h3>Ramp Fee Manager</h3>
320   - <select style="float: right; margin: 8px 10px;">
321   - <option>Ramp Fee By Category</option>
322   - <option>Make And Model</option>
323   - <option>Weight</option>
324   - <option>Wingspan</option>
  320 + <select style="float: right; margin: 8px 10px;" ng-model="customRampData.rampFeesAndAvoidanceList.aircraftType" ng-change="openRampModal()">
  321 + <option disabled selected value="">Ramp Fee By Category</option>
  322 + <option ng-repeat="modals in dropOptions" value="{{modals.size}}">{{modals.size}}</option>
325 323 </select>
326 324 </div>
327 325 <!-- /widget-header -->
... ... @@ -329,7 +327,7 @@
329 327 <section id="accordions1">
330 328 <div class="newCustomAccordian">
331 329  
332   - <div class="col-md-9" style="padding: 0;">
  330 + <div class="col-md-9 feeManagerLeft" style="padding: 0;">
333 331  
334 332 <div ng-repeat="list in fullJetList">
335 333 <div class="new-tab-heading">
... ... @@ -363,16 +361,32 @@
363 361 <span style="margin-left: 5px;">{{jets.size}}</span>
364 362 </div>
365 363 <div class="col-md-2">
366   - <input type="text" ng-model="jets.rampFeesAndAvoidance.rampFees" name="">
  364 + <input type="text" ng-disabled="jets.rampFeesAndAvoidance.applicable == false || jets.rampFeesAndAvoidance.applicable == null" ng-model="jets.rampFeesAndAvoidance.rampFees" name="">
367 365 </div>
368 366 <div class="col-md-2">
369   - <input type="text" ng-model="jets.rampFeesAndAvoidance.avoidance" name="">
  367 + <input type="text" ng-disabled="jets.rampFeesAndAvoidance.applicable == false || jets.rampFeesAndAvoidance.applicable == null" ng-model="jets.rampFeesAndAvoidance.avoidance" name="">
370 368 </div>
371 369 <div class="col-md-2">
372   - <input type="date" ng-model="jets.rampFeesAndAvoidance.expirationDate" name="">
  370 + <input type="date" ng-disabled="jets.rampFeesAndAvoidance.applicable == false || jets.rampFeesAndAvoidance.applicable == null" name="" ng-model="jets.rampFeesAndAvoidance.expirationDate">
  371 + <!-- <div class="form-group" id="data_1">
  372 + <div class="input-group date">
  373 + <span class="input-group-addon"><i class="fa fa-calendar"></i></span>
  374 + <input type="text" style="height: 34px;" class="form-control" >
  375 + </div>
  376 + </div> -->
373 377 </div>
374 378 <div class="col-md-2">
375   - <input type="checkbox" ng-model="jets.rampFeesAndAvoidance.applicable">
  379 + <!-- <input type="checkbox" ng-model="jets.rampFeesAndAvoidance.applicable"> -->
  380 + <div class="onoffswitch">
  381 + <input type="checkbox" name="onoffswitch" class="onoffswitch-checkbox" id="{{jets.id}}{{$index}}" ng-model="jets.rampFeesAndAvoidance.applicable">
  382 + <label class="onoffswitch-label" for="{{jets.id}}{{$index}}">
  383 + <span class="onoffswitch-inner"></span>
  384 + <span class="onoffswitch-switch">
  385 + <i class="fa fa-check" ng-show="jets.rampFeesAndAvoidance.applicable" aria-hidden="true"></i>
  386 + <i class="fa fa-times" ng-hide="jets.rampFeesAndAvoidance.applicable" aria-hidden="true"></i>
  387 + </span>
  388 + </label>
  389 + </div>
376 390 </div>
377 391 <div class="clearfix"></div>
378 392 </div>
... ... @@ -386,6 +400,32 @@
386 400 </div>
387 401 <div class="lastDiv">
388 402 <textarea ng-model="jets.rampFeesAndAvoidance.notes"></textarea>
  403 + <div class="reportedByTag">
  404 + <div class="confirmedTag">Confirmed</div>
  405 + <table>
  406 + <tr>
  407 + <td width="50%">
  408 + Reported By:
  409 + </td>
  410 + <td width="50%">
  411 + {{jets.rampFeesAndAvoidance.reportedBy}}
  412 + </td>
  413 + </tr>
  414 + <tr>
  415 + <td width="50%">
  416 + Reported On:
  417 + </td>
  418 + <td width="50%">
  419 + {{jets.rampFeesAndAvoidance.reportedOn}}
  420 + </td>
  421 + </tr>
  422 + <tr>
  423 + <td colspan="2">
  424 + <i>Click the Save Form button to Re-Confirm</i>
  425 + </td>
  426 + </tr>
  427 + </table>
  428 + </div>
389 429 </div>
390 430 <div class="clearfix"></div>
391 431 </div>
... ... @@ -398,9 +438,11 @@
398 438 </div>
399 439 </div>
400 440 </div>
401   - <div class="col-md-3 text-center" style="padding: 0;">
402   - <button type="submit" ng-click="updateList(fullJetList)" class="btn btn-success"><i class="icon-ok"></i> Save Form</button>&nbsp;&nbsp;
403   - <button type="reset" class="btn btn-default">Cancel</button>
  441 + <div class="col-md-3 text-center feeManagerRight" style="padding: 0;">
  442 + <div class="text-center">
  443 + <button type="submit" ng-click="updateList(fullJetList)" class="btn btn-success"><i class="icon-ok"></i> Save Form</button>&nbsp;&nbsp;
  444 + <button type="reset" class="btn btn-default">Cancel</button>
  445 + </div>
404 446 </div>
405 447 <div class="clearfix"></div>
406 448 <br/>
... ... @@ -414,4 +456,152 @@
414 456 <!-- /span6 -->
415 457 </div>
416 458 <!-- /span12 -->
417   -</div> <!-- /container 2 -->
418 459 \ No newline at end of file
  460 +</div> <!-- /container 2 -->
  461 +
  462 +<div ng-show="openRampFeeModal">
  463 + <div class="customBackdrop">
  464 + <div class="customModalInner">
  465 + <div class="customModelHead">
  466 + <p class="pull-left">
  467 + <i class="fa fa-list-alt" aria-hidden="true"></i>
  468 + Add Ramp Fee
  469 + </p>
  470 + <p class="pull-right">
  471 + <i class="fa fa-times" aria-hidden="true" style="cursor: pointer;" ng-click="closeRampFeeModel()"></i>
  472 + </p>
  473 + <div class="clearfix"></div>
  474 + </div>
  475 + <div class="customModelBody">
  476 +
  477 + <div class="col-xs-12 col-sm-4">
  478 + Type:
  479 + </div>
  480 + <div class="col-xs-12 col-sm-4" style="padding-right: 0;">
  481 + <select class="form-control" style="border-radius: 0; height: 26px; padding: 0;" ng-model="customRampData.rampFeesAndAvoidanceList.aircraftType" ng-change="openRampModal()">
  482 + <option ng-repeat="modalsNew in dropOptions" value="{{modalsNew.size}}">{{modalsNew.size}}</option>
  483 + </select>
  484 + </div>
  485 + <div class="clearfix"></div>
  486 + <br/>
  487 +
  488 + <div ng-show="showAircraft">
  489 + <div class="col-xs-12 col-sm-4">
  490 + Aircraft Make:
  491 + </div>
  492 + <div class="col-xs-12 col-sm-4" style="padding-right: 0;">
  493 + <select class="form-control" style="border-radius: 0; height: 26px; padding: 0;" ng-model="customRampData.rampFeesAndAvoidanceList.aircraftMake">
  494 + <option ng-repeat="crafts in aircrafts" value="{{crafts}}">{{crafts}}</option>
  495 + </select>
  496 + </div>
  497 + <div class="clearfix"></div>
  498 + <br/>
  499 + </div>
  500 +
  501 + <div ng-show="showTail">
  502 + <div class="col-xs-12 col-sm-4">
  503 + Tail Numbers:
  504 + </div>
  505 + <div class="col-xs-12 col-sm-4" style="padding-right: 0;">
  506 + <select class="form-control" style="border-radius: 0; height: 26px; padding: 0;" ng-model="customRampData.rampFeesAndAvoidanceList.tailNumber">
  507 + <!-- <option ng-repeat="crafts in aircrafts" value="{{crafts}}">{{crafts}}</option> -->
  508 + </select>
  509 + </div>
  510 + <div class="clearfix"></div>
  511 + <br/>
  512 + </div>
  513 +
  514 + <div ng-show="showWingspan">
  515 + <div class="col-xs-12 col-sm-4">
  516 + Wingspan Min:
  517 + </div>
  518 + <div class="col-xs-12 col-sm-4" style="padding-right: 0;">
  519 + <input type="number" value="0.00" ng-model="customRampData.rampFeesAndAvoidanceList.wingspanMin" class="form-control" style="border-radius: 0; height: 26px; padding: 0 5px;" >
  520 + </div>
  521 + <div class="col-xs-12 col-sm-4" style="padding-left: 5px;">
  522 + ft.
  523 + </div>
  524 + <div class="clearfix"></div>
  525 + <br/>
  526 + <div class="col-xs-12 col-sm-4">
  527 + Wingspan Max:
  528 + </div>
  529 + <div class="col-xs-12 col-sm-4" style="padding-right: 0;">
  530 + <input type="number" value="0.00" ng-model="customRampData.rampFeesAndAvoidanceList.wingspanMax" class="form-control" style="border-radius: 0; height: 26px; padding: 0 5px;" >
  531 + </div>
  532 + <div class="col-xs-12 col-sm-4" style="padding-left: 5px;">
  533 + ft.
  534 + </div>
  535 + <div class="clearfix"></div>
  536 + <br/>
  537 + </div>
  538 +
  539 + <div ng-show="showWeight">
  540 + <div class="col-xs-12 col-sm-4">
  541 + Weight Range Min:
  542 + </div>
  543 + <div class="col-xs-12 col-sm-4" style="padding-right: 0;">
  544 + <input type="number" value="0.00" ng-model="customRampData.rampFeesAndAvoidanceList.weightRangeMin" class="form-control" style="border-radius: 0; height: 26px; padding: 0 5px;" >
  545 + </div>
  546 + <div class="col-xs-12 col-sm-4" style="padding-left: 5px;">
  547 + lbs.
  548 + </div>
  549 + <div class="clearfix"></div>
  550 + <br/>
  551 + <div class="col-xs-12 col-sm-4">
  552 + Weight Range Max:
  553 + </div>
  554 + <div class="col-xs-12 col-sm-4" style="padding-right: 0;">
  555 + <input type="number" value="0.00" ng-model="customRampData.rampFeesAndAvoidanceList.weightRangeMax" class="form-control" style="border-radius: 0; height: 26px; padding: 0 5px;" >
  556 + </div>
  557 + <div class="col-xs-12 col-sm-4" style="padding-left: 5px;">
  558 + lbs.
  559 + </div>
  560 + <div class="clearfix"></div>
  561 + <br/>
  562 + </div>
  563 +
  564 + <div>
  565 + <div class="col-xs-12 col-sm-4">
  566 + Ramp/Facil. Fee($):
  567 + </div>
  568 + <div class="col-xs-12 col-sm-4" style="padding-right: 0;">
  569 + <input type="number" value="0" ng-model="customRampData.rampFeesAndAvoidanceList.rampFees" class="form-control" style="border-radius: 0; height: 26px; padding: 0 5px;" >
  570 + </div>
  571 + <div class="clearfix"></div>
  572 + <br/>
  573 + </div>
  574 + <div>
  575 + <div class="col-xs-12 col-sm-4">
  576 + Avoidance:
  577 + </div>
  578 + <div class="col-xs-12 col-sm-4" style="padding-right: 0;">
  579 + <input type="number" value="0" ng-model="customRampData.rampFeesAndAvoidanceList.avoidance" class="form-control" style="border-radius: 0; height: 26px; padding: 0 5px;" >
  580 + </div>
  581 + <div class="col-xs-12 col-sm-4" style="padding-left: 5px;">
  582 + gal.
  583 + </div>
  584 + <div class="clearfix"></div>
  585 + </div>
  586 +
  587 + </div>
  588 + <div class="customModelFooter text-center">
  589 + <input type="submit" value="Save" class="btn" ng-click="addCustomRamp(customRampData)">
  590 + <button class="btn" ng-click="closeRampFeeModel()">Cancel</button>
  591 + </div>
  592 + </div>
  593 + </div>
  594 +</div>
  595 +
  596 +<script src="js/jquery-3.1.1.min.js"></script>
  597 +<script src="js/plugins/bootstrap-datepicker.js"></script>
  598 +<script type="text/javascript">
  599 + $(document).ready(function(){
  600 + $('#data_1 .input-group.date').datepicker({
  601 + todayBtn: "linked",
  602 + keyboardNavigation: false,
  603 + forceParse: false,
  604 + calendarWeeks: true,
  605 + autoclose: true
  606 + });
  607 + })
  608 +</script>
419 609 \ No newline at end of file
... ...
app/partials/fuelManager/fuelManager.service.js
... ... @@ -4,7 +4,39 @@
4 4 .service('fuelManagerService', ['$q', '$http', 'BASE_URL', fuelManagerService]);
5 5  
6 6 function fuelManagerService($q, $http, BASE_URL) {
  7 +
  8 + this.getOptions = function() {
  9 +
  10 + var deferred = $q.defer();
  11 + $http({
  12 + method : 'GET',
  13 + url : BASE_URL.url +'/rampFeesAndAvoidance/getCustomCategorySize',
  14 + headers : {'Content-Type': 'application/json'},
  15 + })
  16 + .then(function (result){
  17 + deferred.resolve(result.data);
  18 + },function (result){
  19 + deferred.resolve(result.data);
  20 + })
  21 + return deferred.promise;
  22 + }
7 23  
  24 + this.getAircrafts = function() {
  25 +
  26 + var deferred = $q.defer();
  27 + $http({
  28 + method : 'GET',
  29 + url : BASE_URL.url +'/fuelerlinx/acufuel/getAircraftMake',
  30 + headers : {'Content-Type': 'application/json'},
  31 + })
  32 + .then(function (result){
  33 + deferred.resolve(result.data);
  34 + },function (result){
  35 + deferred.resolve(result.data);
  36 + })
  37 + return deferred.promise;
  38 + }
  39 +
8 40 this.getFullList = function() {
9 41  
10 42 var deferred = $q.defer();
... ... @@ -21,9 +53,8 @@
21 53 return deferred.promise;
22 54 }
23 55  
24   - //this.addCompany = function(data) {
25 56 this.updateFullList = function(data){
26   -
  57 + console.log('service data', data);
27 58 var deferred = $q.defer();
28 59 $http({
29 60 method : 'POST',
... ...
app/partials/viewCompany/viewCompany.controller.js
... ... @@ -103,7 +103,7 @@
103 103 'tail':'',
104 104 'make': '',
105 105 'model': '',
106   - 'size' : ''
  106 + 'sizeId' : ''
107 107 }];
108 108  
109 109 $scope.addNew = function(){
... ... @@ -111,8 +111,9 @@
111 111 'tail':'',
112 112 'make': '',
113 113 'model': '',
114   - 'size' : ''
  114 + 'sizeId' : ''
115 115 });
  116 + console.log($scope.aircraftDetails)
116 117 };
117 118  
118 119 $scope.getModal = function(makeId, index){
... ... @@ -139,9 +140,10 @@
139 140 'tail': $scope.aircraftDetails[i].tail,
140 141 'make': $scope.aircraftDetails[i].make,
141 142 'model': $scope.aircraftDetails[i].model,
142   - 'size' : $scope.aircraftDetails[i].size
  143 + 'sizeId' : $scope.aircraftDetails[i].sizeId
143 144 });
144 145 }
  146 + console.log($scope.addData)
145 147 $scope.aircraftListData.aircraftList = $scope.addData;
146 148 $scope.aircraftListData.accountId = companyId;
147 149  
... ...
app/partials/viewCompany/viewCompany.html
... ... @@ -589,9 +589,10 @@
589 589 </select>
590 590 </td>
591 591 <td style="width: 20%">
592   - <select class="form-control" ng-model="aircraftData.size">
  592 + <select class="form-control" ng-model="aircraftData.sizeId" ng-options="size.aircraftSize.id as size.aircraftSize.size for size in aircraftData.aircraftSizeList"></select>
  593 + <!-- <select class="form-control" ng-model="aircraftData.size">
593 594 <option ng-repeat="size in aircraftData.aircraftSizeList">{{size}}</option>
594   - </select>
  595 + </select> -->
595 596 </td>
596 597 </tr>
597 598 </tbody>
... ...
app/partials/viewFuelVendor/viewFuelVendor.controller.js
... ... @@ -0,0 +1,225 @@
  1 +
  2 +'use strict';
  3 +
  4 + //Load controller
  5 + angular.module('acufuel')
  6 +
  7 + .controller('ViewFuelVendorController', ['$scope','$uibModal', '$stateParams', 'ViewFuelVendorService', 'CustomersService', function($scope , $uibModal, $stateParams, ViewFuelVendorService, CustomersService) {
  8 + $scope.data = {};
  9 + $scope.data.priceEmail = true;
  10 + $scope.aircraft = {};
  11 +
  12 + $(function() {
  13 + $('#company-one2').bootstrapToggle();
  14 + })
  15 +
  16 + $(function() {
  17 + $('#toggle-one1').bootstrapToggle();
  18 + })
  19 + $(function() {
  20 + $('#toggle-two').bootstrapToggle();
  21 + })
  22 + $(function() {
  23 + $('#toggle-three').bootstrapToggle();
  24 + })
  25 + $(function() {
  26 + $('#toggle-four').bootstrapToggle();
  27 + })
  28 +
  29 + $(function() {
  30 + $('#price-one2').bootstrapToggle();
  31 + $('#price-one2').change(function() {
  32 + $('#console-event').html('Toggle: ' + $(this).prop('checked'));
  33 + $scope.data.priceEmail = $(this).prop('checked');
  34 + })
  35 + })
  36 +
  37 + var value = "";
  38 + var vendorId = $stateParams.id;
  39 + ViewFuelVendorService.getFuelOrder(vendorId).then(function(result) {
  40 + $scope.vendorData = result;
  41 + if($scope.vendorData.activate == true){
  42 + value = 'on';
  43 + }else{
  44 + value = 'off'
  45 + }
  46 + $('#company-one2').bootstrapToggle(value)
  47 + })
  48 +
  49 + getContactList();
  50 + function getContactList(){
  51 + ViewFuelVendorService.getContact(vendorId).then(function(result) {
  52 + $scope.vendorContactList = result;
  53 + for(var i=0;i<$scope.vendorContactList.length; i++){
  54 + if($scope.vendorContactList[i].priceEmail == true){
  55 + $scope.vendorContactList[i].value1 = 'on';
  56 + console.log('aya')
  57 + }else{
  58 + $scope.vendorContactList[i].value1 = 'off';
  59 +
  60 + }
  61 + console.log($scope.vendorContactList[i])
  62 + $('#'+$scope.vendorContactList[i].id).bootstrapToggle($scope.vendorContactList[i].value1)
  63 + }
  64 + })
  65 + }
  66 +
  67 + getAircraftList();
  68 + function getAircraftList(){
  69 + ViewFuelVendorService.getAircraft(vendorId).then(function(result) {
  70 + $scope.contactAircraftList = result;
  71 + })
  72 + }
  73 +
  74 +
  75 + $scope.contactData = {};
  76 + $scope.contactData.contactList = [];
  77 + $scope.addContact = function(){
  78 + $scope.data.vendorId = vendorId;
  79 + $scope.contactData.contactList.push($scope.data);
  80 + ViewFuelVendorService.addContact($scope.contactData).then(function(result) {
  81 + if(result.success){
  82 + toastr.success(''+result.success+'', {
  83 + closeButton: true
  84 + })
  85 + $('#contact-modal-3').modal('hide');
  86 + getContactList();
  87 + }else{
  88 + toastr.error(''+result.statusText+'', {
  89 + closeButton: true
  90 + })
  91 + }
  92 + })
  93 + }
  94 +
  95 + getData();
  96 + function getData(){
  97 + CustomersService.getAircraftMake().then(function(result) {
  98 + $scope.aircraftMakeList = result;
  99 + })
  100 + }
  101 +
  102 + $scope.aircraftDetails = [{
  103 + 'tail':'',
  104 + 'make': '',
  105 + 'model': '',
  106 + 'sizeId' : ''
  107 + }];
  108 +
  109 + $scope.addNew = function(){
  110 + $scope.aircraftDetails.push({
  111 + 'tail':'',
  112 + 'make': '',
  113 + 'model': '',
  114 + 'sizeId' : ''
  115 + });
  116 + console.log($scope.aircraftDetails)
  117 + };
  118 +
  119 + $scope.getModal = function(makeId, index){
  120 + $scope.aircraft.make = makeId;
  121 + //var makeId = makeId;
  122 + CustomersService.getModal($scope.aircraft.make).then(function(result) {
  123 + $scope.aircraftDetails[index].aircraftModalList = result;
  124 + //$scope.aircraftDetails[index].model = $scope.aircraftModalList[0];
  125 + })
  126 + }
  127 +
  128 + $scope.getSize = function(model, index){
  129 + CustomersService.getAircraftSize($scope.aircraft.make, model).then(function(result) {
  130 + $scope.aircraftDetails[index].aircraftSizeList = result;
  131 + //$scope.aircraftDetails[index].size = $scope.aircraftSizeList[0];
  132 + })
  133 + }
  134 +
  135 + $scope.aircraftListData = {};
  136 + $scope.addData = [];
  137 + $scope.saveVendorData = function(){
  138 + for(var i=0; i<$scope.aircraftDetails.length;i++){
  139 + $scope.addData.push({
  140 + 'tail': $scope.aircraftDetails[i].tail,
  141 + 'make': $scope.aircraftDetails[i].make,
  142 + 'model': $scope.aircraftDetails[i].model,
  143 + 'sizeId' : $scope.aircraftDetails[i].sizeId
  144 + });
  145 + }
  146 + console.log($scope.addData)
  147 + $scope.aircraftListData.aircraftList = $scope.addData;
  148 + $scope.aircraftListData.accountId = vendorId;
  149 +
  150 + CustomersService.addAircraft($scope.aircraftListData).then(function(result) {
  151 + if(result != null && result.success){
  152 + toastr.success(''+result.success+'', {
  153 + closeButton: true
  154 + })
  155 + $('#aircraft-modal-3').modal('hide');
  156 + getAircraftList();
  157 + }else{
  158 + toastr.error(''+result.statusText+'', {
  159 + closeButton: true
  160 + })
  161 + }
  162 + });
  163 +
  164 + }
  165 + $scope.showNoteData = true;
  166 + $scope.showCompanyName = true;
  167 + $scope.showAddress = true;
  168 + $scope.showNote = function(){
  169 + $scope.showNoteData = false;
  170 + }
  171 +
  172 + $scope.company = function(){
  173 + $scope.showCompanyName = false;
  174 + }
  175 +
  176 + $scope.addressChange = function(){
  177 + $scope.showAddress = false;
  178 + }
  179 +
  180 + $scope.editData = function(inputName) {
  181 + console.log($scope.vendorData)
  182 + if(inputName == 'showNoteData'){
  183 + $scope.showNoteData = true;
  184 + }else if(inputName == 'showCompanyName'){
  185 + $scope.showCompanyName = true;
  186 + }else if(inputName == 'showAddress'){
  187 + $scope.showAddress = true;
  188 + }
  189 +
  190 + var vendorData = "companyName=" + $scope.vendorData.companyName + "&masterMargin=" + $scope.vendorData.masterMargin
  191 + + "&addressOne=" + $scope.vendorData.addressOne + "&addressTwo=" + $scope.vendorData.addressTwo + "&city=" + $scope.vendorData.city + "&state="
  192 + + $scope.vendorData.state + "&country=" + $scope.vendorData.country + "&zipcode=" + $scope.vendorData.zipcode + "&internalNote="
  193 + + $scope.vendorData.internalNote + "&certificateType=" + $scope.vendorData.certificateType + "&baseTenant=" + $scope.vendorData.baseTenant
  194 + + "&fuelerlinxCustomer=" + $scope.vendorData.fuelerlinxCustomer + "&contractFuelVendor=" + $scope.vendorData.contractFuelVendor
  195 + + "&activate=" + $scope.vendorData.activate + "&baseIcao=" + $scope.vendorData.baseIcao + "&vendorId=" + vendorId;
  196 +
  197 + ViewFuelVendorService.updateContact(vendorData).then(function(result) {
  198 + if(result != null && result.success){
  199 + toastr.success(''+result.success+'', {
  200 + closeButton: true
  201 + })
  202 + }else{
  203 + toastr.error(''+result.statusText+'', {
  204 + closeButton: true
  205 + })
  206 + }
  207 + })
  208 +
  209 + }
  210 +
  211 + $scope.sendMail = function(){
  212 + ViewFuelVendorService.sendMail(vendorId).then(function(result) {
  213 + if(result != null && result.success){
  214 + toastr.success(''+result.success+'', {
  215 + closeButton: true
  216 + })
  217 + }else{
  218 + toastr.error(''+result.statusText+'', {
  219 + closeButton: true
  220 + })
  221 + }
  222 + })
  223 + }
  224 +
  225 + }]);
0 226 \ No newline at end of file
... ...
app/partials/viewFuelVendor/viewFuelVendor.html
... ... @@ -0,0 +1,648 @@
  1 +<style>
  2 + .subnavbar .mainnav > li:nth-child(3) > a{
  3 + color: #ff9900;
  4 + }
  5 + .widget-content{
  6 + padding: 10px !important;
  7 + }
  8 + .widget-content input[type="text"], .widget-content select{
  9 + height: 31px;
  10 + padding: 0;
  11 + }
  12 + .new-label span{
  13 + float: left;
  14 + line-height: 31px;
  15 + }
  16 + .new-label span:first-child{
  17 + margin-right: 5px;
  18 + font-weight: bold;
  19 + }
  20 + .new-label span:last-child{
  21 + margin-left: 5px;
  22 + }
  23 + .new-label select{
  24 + display: -webkit-inline-box;
  25 + display: inline-box;
  26 + float: left;
  27 + }
  28 + .new-address p{
  29 + margin-bottom: 0;
  30 + }
  31 + .new-add-select{
  32 + padding-left: 15px;
  33 + margin: 10px 0;
  34 + }
  35 + .new-add-select select{
  36 + width: 100px;
  37 + }
  38 + .widget{
  39 + -moz-box-shadow: 0px 3px 8px rgba(100,100,100, 0.7);
  40 + -webkit-box-shadow: 0px 3px 8px rgba(100,100,100, 0.7);
  41 + box-shadow: 0px 3px 8px rgba(100,100,100, 0.7);
  42 + }
  43 + .optionclass {
  44 + background: #fff;
  45 + }
  46 + .timess {
  47 + float: right !important;
  48 + margin-top: 10px !important;
  49 + margin-right: 10px !important;
  50 + color: #999 !important;
  51 + cursor: pointer !important;
  52 + }
  53 +
  54 + .button1 {
  55 + display: inline-block;
  56 + height: 35px;
  57 + line-height: 35px;
  58 + padding-right: 15px;
  59 + padding-left: 50px;
  60 + position: relative;
  61 + background-color:rgb(41,127,184);
  62 + color:rgb(255,255,255);
  63 + text-decoration: none;
  64 + text-transform: uppercase;
  65 + letter-spacing: 1px;
  66 + margin-bottom: 15px;
  67 + border: 0;
  68 +
  69 +
  70 + border-radius: 5px;
  71 + -moz-border-radius: 5px;
  72 + -webkit-border-radius: 5px;
  73 + text-shadow:0px 1px 0px rgba(0,0,0,0.5);
  74 + -ms-filter:"progid:DXImageTransform.Microsoft.dropshadow(OffX=0,OffY=1,Color=#ff123852,Positive=true)";zoom:1;
  75 + filter:progid:DXImageTransform.Microsoft.dropshadow(OffX=0,OffY=1,Color=#ff123852,Positive=true);
  76 +
  77 + -moz-box-shadow:0px 2px 2px rgba(0,0,0,0.2);
  78 + -webkit-box-shadow:0px 2px 2px rgba(0,0,0,0.2);
  79 + box-shadow:0px 2px 2px rgba(0,0,0,0.2);
  80 + -ms-filter:"progid:DXImageTransform.Microsoft.dropshadow(OffX=0,OffY=2,Color=#33000000,Positive=true)";
  81 + filter:progid:DXImageTransform.Microsoft.dropshadow(OffX=0,OffY=2,Color=#33000000,Positive=true);
  82 + }
  83 +
  84 + .button1 span {
  85 + position: absolute;
  86 + left: 0;
  87 + top: 0;
  88 + width: 35px;
  89 + background-color:rgba(0,0,0,0.5);
  90 +
  91 + -webkit-border-top-left-radius: 5px;
  92 + -webkit-border-bottom-left-radius: 5px;
  93 + -moz-border-radius-topleft: 5px;
  94 + -moz-border-radius-bottomleft: 5px;
  95 + border-top-left-radius: 5px;
  96 + border-bottom-left-radius: 5px;
  97 + border-right: 1px solid rgba(0,0,0,0.15);
  98 + }
  99 +
  100 + .button1:hover span, .button1.active span {
  101 + background-color:rgb(0,102,26);
  102 + border-right: 1px solid rgba(0,0,0,0.3);
  103 + }
  104 +
  105 + .button1:active {
  106 + margin-top: 2px;
  107 + margin-bottom: 13px;
  108 +
  109 + -moz-box-shadow:0px 1px 0px rgba(255,255,255,0.5);
  110 + -webkit-box-shadow:0px 1px 0px rgba(255,255,255,0.5);
  111 + box-shadow:0px 1px 0px rgba(255,255,255,0.5);
  112 + -ms-filter:"progid:DXImageTransform.Microsoft.dropshadow(OffX=0,OffY=1,Color=#ccffffff,Positive=true)";
  113 + filter:progid:DXImageTransform.Microsoft.dropshadow(OffX=0,OffY=1,Color=#ccffffff,Positive=true);
  114 + }
  115 +
  116 + .button1.turquoise {
  117 + background: #449d44;
  118 + }
  119 +
  120 +</style>
  121 +<div class="col-xs-12 col-md-11">
  122 + <div class="row" style="margin-left:0px">
  123 + <div class="col-md-12">
  124 + <div class="widget">
  125 + <div class="widget-header">
  126 + <i class="fa fa-building-o" aria-hidden="true"></i>
  127 + <h3>Antioch Flight Department</h3>
  128 + <i class="fa fa-times timess" ui-sref="app.customers" aria-hidden="true"></i>
  129 + </div>
  130 + <!-- /widget-header -->
  131 + <div class="widget-content">
  132 + <div class="row" style="margin-left:0px">
  133 + <div class="col-md-6">
  134 + <div class="widget">
  135 + <div class="widget-header">
  136 + <i class="fa fa-building-o" aria-hidden="true"></i>
  137 + <h3>Company Details</h3>
  138 + <label>BASE ICAO</label>
  139 + <input type="tel" ng-model="vendorData.baseIcao" style="line-height: 18px;width: 50px;padding: 0px 9px;" ng-blur="editData()"/>
  140 + <div class="pull-right my-toggle-switch" style="margin-top: 10px; margin-right: 10px;">
  141 + <div><input id="company-one2" checked type="checkbox" data-size="mini" data-width="55" data-toggle="toggle" data-on="Active" data-off="Dactive">
  142 + </div>
  143 + </div>
  144 + </div>
  145 + <div class="widget-content">
  146 + <div class="row" style="margin-left:0px;">
  147 + <div class="col-md-7" style="padding-left: 0;">
  148 + <h4 ng-show="showCompanyName">
  149 + <b style="color:#F90;">{{vendorData.vendorName}}</b> &nbsp;<i class="fa fa-pencil-square-o" ng-click="company()" style="font-size: 14px;" aria-hidden="true"></i>
  150 + </h4>
  151 + <input type="tel" ng-hide="showCompanyName" ng-model="vendorData.vendorName" class="form-control" ng-blur="editData('showCompanyName')"/>
  152 + </div>
  153 + <div class="col-md-5">
  154 + <select class="form-control" style="padding: 4px 8px;background: #ebebeb;" ng-model="vendorData.certificateType" ng-click="editData()">
  155 + <option class="optionclass" disabled selected>Certificate Type</option>
  156 + <option class="optionclass" value="corporate">Part 91 (Corporate)</option>
  157 + <option class="optionclass" value="charter">Part 135 (Charter)</option>
  158 + <option class="optionclass" value="scheduled">Part 121 (Scheduled)</option>
  159 + <option class="optionclass" value="military">Military</option>
  160 + <option class="optionclass" value="government">Government</option>
  161 + </select>
  162 + </div>
  163 + </div>
  164 + <div>
  165 + <p class="new-label">
  166 + <span>Master Margin Setting </span>
  167 + <select class="form-control" style="width: 135px;padding: 4px 8px;" ng-model="vendorData.masterMargin" ng-click="editData()">
  168 + <option value="margin1">Margin1</option>
  169 + <option value="margin2">Margin2</option>
  170 + <option value="vendorsonly">Vendors Only</option>
  171 + <option value="margintenants">Margin Tenants</option>
  172 + </select>
  173 + <span>&nbsp;See Aircrart List</span>
  174 + <div class="clearfix"></div>
  175 + </p>
  176 + </div>
  177 + <div class="row" style="margin-left:0px;">
  178 + <div class="col-md-5" style="padding-left: 0;">
  179 + <input type="checkbox" name="" ng-click="editData()" ng-model="vendorData.baseTenant"> Tenant/Base Customer
  180 + </div>
  181 + <div class="col-md-5" style="padding-left: 0;">
  182 + <input type="checkbox" name="" ng-click="editData()" ng-model="vendorData.fuelerlinxCustomer"> FuelerLinx Customer
  183 + </div>
  184 + </div>
  185 + <div>
  186 + <input type="checkbox" name="" ng-click="editData()" ng-model="vendorData.contractFuelVendor"> CAA Member
  187 + </div>
  188 + </br>
  189 + <div class="new-address">
  190 + <p ng-show="showAddress"><i class="fa fa-map-marker"></i> {{vendorData.addressOne}} {{vendorData.addressTwo}} &nbsp;<i class="fa fa-pencil-square-o" ng-click="addressChange()" aria-hidden="true"></i> </p>
  191 +
  192 + <div ng-hide="showAddress">
  193 + <label>Address1</label>
  194 + <input type="tel" ng-hide="showAddress" ng-model="vendorData.addressOne" class="form-control" ng-blur="editData('showAddress')"/>
  195 + <label>Address2</label>
  196 + <input type="tel" ng-hide="showAddress" ng-model="vendorData.addressTwo" class="form-control" ng-blur="editData('showAddress')"/>
  197 + </div>
  198 +
  199 + <p><i class="fa fa-phone"></i> (310) 2342-3433 &nbsp;<i class="fa fa-pencil-square-o" aria-hidden="true"></i></p>
  200 + <p><i class="fa fa-envelope"></i> freed@gmail.com &nbsp;<i class="fa fa-pencil-square-o" aria-hidden="true"></i></p>
  201 + </div>
  202 + <div class="new-add-select">
  203 + <select class="form-control" style="background: #ebebeb;padding: 4px 8px;width: 115px;">
  204 + <option disabled selected>Add Field</option>
  205 + <option class="optionclass">Add Phone</option>
  206 + <option class="optionclass">Add Email</option>
  207 + </select>
  208 + </div>
  209 + <div>
  210 + <p style="margin-bottom: 0;"><b>Company Notes</b> &nbsp;<i class="fa fa-pencil-square-o" ng-click="showNote()" aria-hidden="true"></i></p>
  211 + <p ng-show="showNoteData">{{vendorData.internalNote}}</p>
  212 + <textarea name="message" ng-hide="showNoteData" style="margin-bottom: 6px;" class="form-control" ng-model="vendorData.internalNote" ng-blur="editData('showNoteData')" rows="4" cols="34"></textarea>
  213 + </div>
  214 + <div class="dis">
  215 + <button type="button" data-toggle="modal" data-target="#distribute-modal-3" class="btn btn-primary">Distribute Price to Company Contacts</button>
  216 + </div>
  217 + <div><button type="button" class="btn btn-info">Setup Fuel</button></div>
  218 + </div>
  219 + </div>
  220 + </div>
  221 + <div class="col-md-6">
  222 + <div class="widget">
  223 + <div class="widget-header">
  224 + <i class="fa fa-plane"></i>
  225 + <h3>Aircraft List</h3>
  226 + <div class="pull-right">
  227 + <button type="submit" class="btn btn-success btn-sm" data-toggle="modal" data-target="#aircraft-modal-3" style="margin-top: 4px; margin-right: 9px;"><i class="fa fa-plus" aria-hidden="true"></i>&nbsp; Add Aircraft</button>
  228 + </div>
  229 + </div>
  230 + <div class="widget-content" style="padding:0px">
  231 + <div class="table-responsive">
  232 + <table class="table table-bordered table-hover table-striped">
  233 + <thead>
  234 + <tr>
  235 + <th>Tail #</th>
  236 + <th>Make</th>
  237 + <th>Model</th>
  238 + <th>JET-A</th>
  239 + <th>All in</th>
  240 + <th>AVGAS</th>
  241 + <th>All in</th>
  242 + <th></th>
  243 + </tr>
  244 + </thead>
  245 + <tbody>
  246 + <tr ng-repeat="aircraft in contactAircraftList">
  247 + <td>{{aircraft.tail}}</td>
  248 + <td>{{aircraft.make}}</td>
  249 + <td>{{aircraft.model}}</td>
  250 + <td>
  251 + <select class="form-control" style="height:31px;">
  252 + <option>Margin1</option>
  253 + <option>Margin2</option>
  254 + </select>
  255 + </td>
  256 + <td style="color:#55AF8B;">$3659</td>
  257 + <td>
  258 + <select class="form-control" style="height:31px;">
  259 + <option>Margin1</option>
  260 + <option>Margin2</option>
  261 + </select>
  262 + </td>
  263 + <td style="color:#55AF8B;">$3659</td>
  264 + <td></td>
  265 + </tr>
  266 + </tbody>
  267 + </table>
  268 + </div>
  269 + </div>
  270 + </div>
  271 + </div>
  272 + </div>
  273 + <div class="row" style="margin-left:0px">
  274 + <div class="col-md-6">
  275 + <div class="widget">
  276 + <div class="widget-header">
  277 + <i class="fa fa-user"></i>
  278 + <h3>Contact List</h3>
  279 + <div class="pull-right">
  280 + <button type="submit" data-toggle="modal" data-target="#contact-modal-3" class="btn btn-success btn-sm" style="margin-top: 4px; margin-right: 9px;"><i class="fa fa-plus" aria-hidden="true"></i>&nbsp; Add Contact</button>
  281 + </div>
  282 + </div>
  283 + <div class="widget-content" style="padding:0px">
  284 + <div class="table-responsive">
  285 + <table class="table table-bordered table-hover table-striped">
  286 + <thead>
  287 + <tr>
  288 + <th>Price Email</th>
  289 + <th>First Name</th>
  290 + <th>Last Name</th>
  291 + <th>Title</th>
  292 + </tr>
  293 + </thead>
  294 + <tbody>
  295 + <tr ng-repeat="contact in vendorContactList">
  296 + <td class="my-toggle-switch"><input id="{{contact.id}}" checked type="checkbox" data-size="mini" data-toggle="toggle"></td>
  297 + <td>
  298 + <a href="#!/viewContact/{{contact.id}}">
  299 + {{contact.firstName}}
  300 + </a>
  301 + </td>
  302 + <td>{{contact.lastName}}</td>
  303 + <td>{{contact.title}}</td>
  304 + </tr>
  305 + </tbody>
  306 + </table>
  307 + </div>
  308 + </div>
  309 + </div>
  310 + </div>
  311 + <div class="col-md-6">
  312 + <div class="widget">
  313 + <div class="widget-header">
  314 + <i class="fa fa-pencil"></i>
  315 + <h3>Price Manager Reference</h3>
  316 + </div>
  317 + <div class="widget-content">
  318 + <div class="table-responsive">
  319 + <table class="table table-hover table-striped">
  320 + <thead>
  321 + <tr>
  322 + <th>Omit</th>
  323 + <th>Product</th>
  324 + <th>Cost</th>
  325 + <th>PAP (Margin)</th>
  326 + <th>PAP (Total)</th>
  327 + <th style="color:#F90">Expires</th>
  328 + </tr>
  329 + </thead>
  330 + <tbody>
  331 + <tr>
  332 + <td><input type="checkbox"></td>
  333 + <td>Jet-A Full Service</td>
  334 + <td>$2.123</td>
  335 + <td>$23000</td>
  336 + <td style="color:#55AF8B;">$3659</td>
  337 + <td style="color:#F90">3/15/2017</td>
  338 + </tr>
  339 + <tr>
  340 + <td><input type="checkbox"></td>
  341 + <td>Jet-A Full Service</td>
  342 + <td>$2.123</td>
  343 + <td>$23000</td>
  344 + <td style="color:#55AF8B;">$3659</td>
  345 + <td style="color:#F90">3/15/2017</td>
  346 + </tr>
  347 + <tr>
  348 + <tr>
  349 + <td><input type="checkbox"></td>
  350 + <td>Jet-A Full Service</td>
  351 + <td>$2.123</td>
  352 + <td>$23000</td>
  353 + <td style="color:#55AF8B;">$3659</td>
  354 + <td style="color:#F90">3/15/2017</td>
  355 + </tr>
  356 + <tr>
  357 + <td><input type="checkbox"></td>
  358 + <td>Jet-A Full Service</td>
  359 + <td>$2.123</td>
  360 + <td>$23000</td>
  361 + <td style="color:#55AF8B;">$3659</td>
  362 + <td style="color:#F90">3/15/2017</td>
  363 + </tr>
  364 + </tbody>
  365 + </table>
  366 + </div>
  367 + </div>
  368 + </div>
  369 + </div>
  370 + </div>
  371 + </div>
  372 + <!-- /widget-content -->
  373 + </div>
  374 + <!-- /widget -->
  375 + </div>
  376 + <!-- /span6 -->
  377 + </div>
  378 + <!-- /widget -->
  379 +</div>
  380 +<!-- /container -->
  381 +<form class="modal multi-step" id="contact-modal-3" name="companyForm">
  382 + <div class="modal-dialog modal-lg">
  383 + <div class="modal-content">
  384 + <div class="modal-body step-1" data-step="1" style="padding: 0;">
  385 + <div>
  386 + <div class="row" style="margin: 0;">
  387 + <div>
  388 + <div class="widget" style="margin-bottom: 0; box-shadow: none;">
  389 + <div class="widget-header">
  390 + <i class="icon-pencil"></i>
  391 + <i class="fa fa-tasks" aria-hidden="true"></i>
  392 + <h3>Add a New Contact</h3>
  393 + <div class="clearfix"></div>
  394 + </div>
  395 + <div class="widget-content" style="padding-left: 0; padding-right: 0; border-bottom: 0;">
  396 + <div class="col-xs-12">
  397 + <div class="col-md-6">
  398 + <div class="pull-left" style="width: 110px;">
  399 + <label class="new-input-label"><b>First Name</b></label>
  400 + </div>
  401 + <div class="pull-left" style="margin-left: 15px;">
  402 + <input type="tel" ng-model="data.firstName" class="form-control" placeholder="">
  403 + </div>
  404 + <div class="clearfix"></div>
  405 + </div>
  406 + <div class="col-md-6">
  407 +
  408 + <div class="pull-left" style="width: 110px;">
  409 + <label class="new-input-label"><b>Last Name</b></label>
  410 + </div>
  411 + <div class="pull-left" style="margin-left: 15px;">
  412 + <input type="tel" ng-model="data.lastName" class="form-control" id="Address" placeholder="">
  413 + </div>
  414 + <div class="clearfix"></div>
  415 + </div>
  416 + </div>
  417 + <div class="clearfix"></div><br>
  418 + <div class="col-xs-12">
  419 + <div class="col-md-6">
  420 + <div class="pull-left" style="width: 110px;">
  421 + <label class="new-input-label"><b>Title</b></label>
  422 + </div>
  423 + <div class="pull-left" style="margin-left: 15px;">
  424 + <input type="tel" ng-model="data.title" class="form-control" id="Address" placeholder="">
  425 + </div>
  426 + <div class="clearfix"></div>
  427 + </div>
  428 + <div class="col-md-6">
  429 +
  430 + <div class="pull-left" style="width: 110px;">
  431 + <label class="new-input-label"><b>Email</b></label>
  432 + </div>
  433 + <div class="pull-left" style="margin-left: 15px;">
  434 + <input type="email" ng-model="data.email" class="form-control" id="Address" placeholder="">
  435 + </div>
  436 + <div class="clearfix"></div>
  437 + </div>
  438 + </div>
  439 + <div class="clearfix"></div><br>
  440 + <div class="col-xs-12">
  441 + <div class="col-md-6">
  442 + <div class="pull-left" style="width: 110px;">
  443 + <label class="new-input-label"><b>Username</b></label>
  444 + </div>
  445 + <div class="pull-left" style="margin-left: 15px;">
  446 + <input type="tel" ng-model="data.userName" class="form-control" id="Address" placeholder="">
  447 + </div>
  448 + <div class="clearfix"></div>
  449 + </div>
  450 + <div class="col-md-6">
  451 +
  452 + <div class="pull-left" style="width: 110px;">
  453 + <label class="new-input-label"><b>Password</b></label>
  454 + </div>
  455 + <div class="pull-left" style="margin-left: 15px;">
  456 + <input type="password" ng-model="data.password" class="form-control" id="Address" placeholder="">
  457 + </div>
  458 + <div class="clearfix"></div>
  459 + </div>
  460 + </div>
  461 + <div class="clearfix"></div><br>
  462 + <div class="col-xs-12">
  463 + <div class="col-md-6">
  464 + <div class="pull-left" style="width: 110px;">
  465 + <label class="new-input-label"><b>Work Phone</b></label>
  466 + </div>
  467 + <div class="pull-left" style="margin-left: 15px;">
  468 + <input type="tel" ng-model="data.workPhone" class="form-control" id="Address" placeholder="">
  469 + </div>
  470 + <div class="clearfix"></div>
  471 + </div>
  472 + <div class="col-md-6">
  473 +
  474 + <div class="pull-left" style="width: 110px;">
  475 + <label class="new-input-label"><b>Mobile Phone</b></label>
  476 + </div>
  477 + <div class="pull-left" style="margin-left: 15px;">
  478 + <input type="tel" ng-model="data.mobilePhone" class="form-control" id="Address" placeholder="">
  479 + </div>
  480 + <div class="clearfix"></div>
  481 + </div>
  482 + </div>
  483 + <div class="clearfix"></div><br>
  484 + <div class="col-xs-12">
  485 + <div class="col-md-12">
  486 + <div class="pull-left" style="width: 110px;">
  487 + <label class="new-input-label"><b>Address</b></label>
  488 + </div>
  489 + <div class="pull-right" style="width: calc(100% - 123px);">
  490 + <input type="tel" class="form-control" ng-model="data.address" id="Address" placeholder="">
  491 + </div>
  492 + <div class="clearfix"></div>
  493 + </div>
  494 + </div>
  495 + <div class="clearfix"></div>
  496 + <br/>
  497 + <div class="col-xs-12">
  498 + <div class="col-md-3">
  499 + <div class="pull-left my-toggle-switch">
  500 + <div style="color: #ff9a01;">Price Email &nbsp &nbsp
  501 + <input id="price-one2" checked type="checkbox" data-size="mini" data-width="55" data-toggle="toggle" data-on="On" data-off="Off">
  502 + </div>
  503 + </div>
  504 + <div class="clearfix"></div>
  505 + </div>
  506 + <div class="col-md-3">
  507 + <div class="pull-left my-toggle-switch">
  508 + <div style="color: #ff9a01;">Primary Contact &nbsp &nbsp
  509 + <input type="checkbox" ng-model="data.primaryContact">
  510 + </div>
  511 + </div>
  512 + <div class="clearfix"></div>
  513 + </div>
  514 + <div class="col-md-6">
  515 + <div class="pull-left" style="width: 110px;">
  516 + <label class="new-input-label"><b>Internal Note</b></label>
  517 + </div>
  518 + <div class="pull-left" style="width: calc(100% - 110px);">
  519 + <textarea name="message" ng-model="data.note" rows="4" cols="34"></textarea>
  520 + </div>
  521 + </div>
  522 + <div class="clearfix"></div>
  523 + </div>
  524 + <div class="clearfix"></div><br>
  525 + </div>
  526 + </div>
  527 + <div class="clearfix"></div>
  528 + </div>
  529 + </div>
  530 + </div>
  531 + </div>
  532 + <div class="modal-footer" style="border-top: 0;">
  533 + <button type="button" class="btn btn-default" data-dismiss="modal">Cancel</button>
  534 + <button type="button" class="btn btn-primary step step-1" data-step="1" ng-click="addContact()">Save</button>
  535 + </div>
  536 + </div>
  537 + </div>
  538 +</form>
  539 +<div class="clearfix"></div>
  540 +
  541 +<form class="modal multi-step" id="aircraft-modal-3" name="aircraftForm">
  542 + <div class="modal-dialog modal-lg">
  543 + <div class="modal-content">
  544 + <div class="modal-body step-2" data-step="2" style="padding: 0;">
  545 + <div>
  546 + <div class="row" style="margin: 0;">
  547 + <div>
  548 + <div class="widget" style="margin-bottom: 0;box-shadow: none;">
  549 + <div class="widget-header">
  550 + <i class="icon-pencil"></i>
  551 + <i class="fa fa-tasks" aria-hidden="true"></i>
  552 + <h3>Add a New Aircraft</h3>
  553 + <div class="clearfix"></div>
  554 + </div>
  555 + <div class="widget-content" style="padding-left: 0; padding-right: 0; border-bottom: 0;">
  556 + <div class="col-xs-12">
  557 + <div class="widget-header">
  558 + <i class="fa fa-list"></i>
  559 + <h3>Aircraft List</h3>
  560 + </div>
  561 + <div class="widget-content" style="padding:0px;border: 0px; padding: 0px !important;">
  562 + <div class="table-responsive">
  563 + <table class="table table-striped table-bordered">
  564 + <thead>
  565 + <tr>
  566 + <!-- <th><input type="checkbox" ng-model="selectedAll" ng-click="checkAll()" /></th> -->
  567 + <th>Tail</th>
  568 + <th>Make</th>
  569 + <th>Model</th>
  570 + <th>Size</th>
  571 + </tr>
  572 + </thead>
  573 + <tbody>
  574 + <tr ng-repeat="aircraftData in aircraftDetails track by $index">
  575 + <!-- <td>
  576 + <input type="checkbox" ng-model="aircraftData.selected"/>
  577 + </td> -->
  578 + <td style="width: 20%">
  579 + <input type="tel" class="form-control" ng-model="aircraftData.tail" required/>
  580 + </td>
  581 + <td style="width: 20%">
  582 + <select class="form-control" ng-model="aircraftData.make" ng-change="getModal(aircraftData.make, $index)">
  583 + <option ng-repeat="make in aircraftMakeList">{{make}}</option>
  584 + </select>
  585 + </td>
  586 + <td style="width: 20%">
  587 + <select class="form-control" ng-model="aircraftData.model" ng-change="getSize(aircraftData.model, $index)">
  588 + <option ng-repeat="model in aircraftData.aircraftModalList">{{model}}</option>
  589 + </select>
  590 + </td>
  591 + <td style="width: 20%">
  592 + <select class="form-control" ng-model="aircraftData.sizeId" ng-options="size.aircraftSize.id as size.aircraftSize.size for size in aircraftData.aircraftSizeList"></select>
  593 + <!-- <select class="form-control" ng-model="aircraftData.size">
  594 + <option ng-repeat="size in aircraftData.aircraftSizeList">{{size}}</option>
  595 + </select> -->
  596 + </td>
  597 + </tr>
  598 + </tbody>
  599 + </table>
  600 + </div>
  601 + <div class="clearfix"></div>
  602 + </div>
  603 + </div>
  604 + <div class="clearfix"></div>
  605 + <div class="col-xs-12" style="margin-bottom: 50px;margin-top: 10px;">
  606 + <button ng-click="addNew()" class="button1 turquoise pull-right"><span>+</span>Add Aircraft</button>
  607 + </div>
  608 + </div>
  609 + </div>
  610 + <div class="clearfix"></div>
  611 + </div>
  612 + </div>
  613 + </div>
  614 + </div>
  615 + <div class="modal-footer" style="border-top: 0;">
  616 + <button type="button" class="btn btn-default" data-dismiss="modal">Cancel</button>
  617 + <button type="button" class="btn btn-primary step step-1" data-step="1" ng-click="saveVendorData()">Save</button>
  618 + </div>
  619 + </div>
  620 + </div>
  621 +</form>
  622 +
  623 +<form class="modal multi-step" id="distribute-modal-3" name="aircraftForm">
  624 + <div class="modal-dialog">
  625 + <div class="modal-content">
  626 + <div class="modal-body step-2" data-step="2" style="padding: 0;">
  627 + <div>
  628 + <div class="row" style="margin: 0;">
  629 + <p>Are you sure that you want to email pricing to everyone in your contact list</p>
  630 + </div>
  631 + </div>
  632 + </div>
  633 + <div class="modal-footer" style="border-top: 0;">
  634 + <button type="button" class="btn btn-default" data-dismiss="modal">Cancel</button>
  635 + <button type="button" class="btn btn-primary step step-1" data-step="1" ng-click="sendMail()">Save</button>
  636 + </div>
  637 + </div>
  638 + </div>
  639 +</form>
  640 +<!-- Le javascript
  641 + ================================================== -->
  642 +<!-- Placed at the end of the document so the pages load faster -->
  643 +<!-- <script
  644 + CKEDITOR.replace( 'editor2', {
  645 + height: 250,
  646 + extraPlugins: 'divarea'
  647 + } );
  648 + </script> -->
... ...
app/partials/viewFuelVendor/viewFuelVendor.service.js
... ... @@ -0,0 +1,108 @@
  1 +(function(){
  2 + 'use strict';
  3 + angular.module('acufuel')
  4 + .service('ViewFuelVendorService', ['$q', '$http', 'BASE_URL', ViewFuelVendorService]);
  5 +
  6 + function ViewFuelVendorService($q, $http, BASE_URL) {
  7 +
  8 + this.getFuelOrder = function(id) {
  9 +
  10 + var deferred = $q.defer();
  11 + $http({
  12 + method : 'GET',
  13 + url : BASE_URL.url +'/vendor/'+id,
  14 + headers : {'Content-Type': 'application/json'},
  15 + })
  16 + .then(function (result){
  17 + deferred.resolve(result.data);
  18 + },function (result){
  19 + deferred.resolve(result.data);
  20 + })
  21 + return deferred.promise;
  22 + }
  23 +
  24 + this.getContact = function(id) {
  25 +
  26 + var deferred = $q.defer();
  27 + $http({
  28 + method : 'GET',
  29 + url : BASE_URL.url +'/vendor/contacts/'+id,
  30 + headers : {'Content-Type': 'application/json'},
  31 + })
  32 + .then(function (result){
  33 + deferred.resolve(result.data);
  34 + },function (result){
  35 + deferred.resolve(result.data);
  36 + })
  37 + return deferred.promise;
  38 + }
  39 +
  40 + this.addContact = function(data) {
  41 +
  42 + var deferred = $q.defer();
  43 + $http({
  44 + method : 'POST',
  45 + url : BASE_URL.url +'/vendor/add/contact',
  46 + data : data,
  47 + headers : {'Content-Type': 'application/json'},
  48 + })
  49 + .then(function (result){
  50 + deferred.resolve(result.data);
  51 + },function (result){
  52 + deferred.resolve(result.data);
  53 + })
  54 + return deferred.promise;
  55 + }
  56 +
  57 + this.sendMail = function(id) {
  58 +
  59 + var deferred = $q.defer();
  60 + $http({
  61 + method : 'POST',
  62 + url : BASE_URL.url +'/mailPriceToContacts/'+id,
  63 + headers : {'Content-Type': 'application/json'},
  64 + })
  65 + .then(function (result){
  66 + deferred.resolve(result.data);
  67 + },function (result){
  68 + deferred.resolve(result.data);
  69 + })
  70 + return deferred.promise;
  71 + }
  72 +
  73 + this.updateContact = function(data) {
  74 +
  75 + var deferred = $q.defer();
  76 + $http({
  77 + method : 'PUT',
  78 + url : BASE_URL.url +'/vendor',
  79 + data : data,
  80 + headers : {'Content-Type': 'application/json'},
  81 + })
  82 + .then(function (result){
  83 + deferred.resolve(result.data);
  84 + },function (result){
  85 + deferred.resolve(result.data);
  86 + })
  87 + return deferred.promise;
  88 + }
  89 +
  90 + this.getAircraft = function(id) {
  91 +
  92 + var deferred = $q.defer();
  93 + $http({
  94 + method : 'GET',
  95 + url : BASE_URL.url +'/vendor/aircrafts/'+id,
  96 + headers : {'Content-Type': 'application/json'},
  97 + })
  98 + .then(function (result){
  99 + deferred.resolve(result.data);
  100 + },function (result){
  101 + deferred.resolve(result.data);
  102 + })
  103 + return deferred.promise;
  104 + }
  105 +
  106 + }
  107 +
  108 +})();
0 109 \ No newline at end of file
... ...
app/partials/viewcontact/viewcontact.controller.js
... ... @@ -10,8 +10,119 @@
10 10 })
11 11  
12 12 var contactId = $stateParams.id;
  13 + $scope.contactDetail = {};
13 14 ViewcontactService.getContact(contactId).then(function(result) {
14 15 $scope.contactDetail = result;
15 16 })
  17 +
  18 + $scope.contactIdList = {};
  19 + var index;
  20 + var one = 1;
  21 + var selectedId;
  22 +
  23 + ViewcontactService.getContactsList(contactId).then(function(list){
  24 + $scope.contactIdList = list;
  25 + index = $scope.contactIdList.indexOf(contactId);
  26 + selectedId = $scope.contactIdList[index]
  27 + })
  28 +
  29 + $scope.nextContact = function(){
  30 + index = index + one;
  31 + selectedId = $scope.contactIdList[index];
  32 + ViewcontactService.getContact(selectedId).then(function(result) {
  33 + $scope.contactDetail = result;
  34 + })
  35 + }
  36 +
  37 + $scope.prevContact = function(){
  38 + index = index - one;
  39 + selectedId = $scope.contactIdList[index];
  40 + ViewcontactService.getContact(selectedId).then(function(result) {
  41 + $scope.contactDetail = result;
  42 + })
  43 + }
  44 +
  45 + setInterval(function(){
  46 + var checkMaxLength = $scope.contactIdList.length - one;
  47 + if (index === checkMaxLength) {
  48 + $scope.disableNext = true;
  49 + }else{
  50 + $scope.disableNext = false;
  51 + }
  52 + if (index === 0) {
  53 + $scope.disablePrev = true;
  54 + }else{
  55 + $scope.disablePrev = false;
  56 + }
  57 + }, 3);
  58 +
  59 + $scope.editName = true;
  60 + $scope.editCompany = true;
  61 + $scope.editAddress = true;
  62 + $scope.editPhone = true;
  63 + $scope.editMobile = true;
  64 + $scope.editEmail = true;
  65 + $scope.editContactNotes = true;
  66 +
  67 + $scope.nameEdit = function(){
  68 + $scope.editName = false;
  69 + }
  70 + $scope.addressEdit = function(){
  71 + $scope.editAddress = false;
  72 + }
  73 + $scope.phoneEdit = function(){
  74 + $scope.editPhone = false;
  75 + }
  76 + $scope.mobileEdit = function(){
  77 + $scope.editMobile = false;
  78 + }
  79 + $scope.emailEdit = function(){
  80 + $scope.editEmail = false;
  81 + }
  82 + $scope.notesEdit = function(){
  83 + $scope.editContactNotes = false;
  84 + }
  85 +
  86 + $scope.conData = {};
  87 + $scope.contactData = {};
  88 + $scope.contactData.contactList = [];
  89 + $scope.updateContact = function(data){
  90 + $scope.editName = true;
  91 + $scope.editCompany = true;
  92 + $scope.editAddress = true;
  93 + $scope.editPhone = true;
  94 + $scope.editMobile = true;
  95 + $scope.editEmail = true;
  96 + $scope.editContactNotes = true;
  97 +
  98 + $scope.conData.address = data.address;
  99 + $scope.conData.email = data.email;
  100 + $scope.conData.firstName = data.firstName;
  101 + $scope.conData.id = data.id;
  102 + $scope.conData.lastName = data.lastName;
  103 + $scope.conData.mobilePhone = data.mobilePhone;
  104 + $scope.conData.note = data.note;
  105 + $scope.conData.password = data.password;
  106 + $scope.conData.priceEmail = data.priceEmail;
  107 + $scope.conData.primaryContact = data.primaryContact;
  108 + $scope.conData.title = data.title;
  109 + $scope.conData.userName = data.userName;
  110 + $scope.conData.workPhone = data.workPhone;
  111 + $scope.conData.companyId = data.owner.id;
  112 +
  113 + $scope.contactData.contactList.push($scope.conData);
  114 + $scope.contactData.contactList.push();
  115 + ViewcontactService.updateContact($scope.contactData).then(function(result) {
  116 + if(result.success){
  117 + toastr.success(''+result.success+'', {
  118 + closeButton: true
  119 + })
  120 + }else{
  121 + toastr.error(''+result.statusText+'', {
  122 + closeButton: true
  123 + })
  124 + }
  125 + })
  126 + }
16 127  
17 128 }]);
... ...
app/partials/viewcontact/viewcontact.html
... ... @@ -9,6 +9,16 @@
9 9 </div>
10 10 <div class="widget-content" style="padding-left: 0; padding-right: 0; ">
11 11 <div class="container">
  12 + <div style="margin-bottom: 25px;">
  13 + <button ng-disabled="disablePrev" class="newButtons" ng-click="prevContact()">
  14 + <i class="fa fa-long-arrow-left" aria-hidden="true"></i>
  15 + Previous Contact
  16 + </button>
  17 + <button ng-disabled="disableNext" class="newButtons" ng-click="nextContact()">
  18 + Next Contact
  19 + <i class="fa fa-long-arrow-right" aria-hidden="true"></i>
  20 + </button>
  21 + </div>
12 22 <div class="row">
13 23 <div class="col-md-6" style="margin-left: 20px;">
14 24 <div class="widget stacked">
... ... @@ -24,15 +34,17 @@
24 34 <div class="row" style="margin-left:0px">
25 35 <div class="col-md-6" style="padding-left: 0px;">
26 36 <h3>
27   - <b style="color:#F90;">{{contactDetail.firstName}} {{contactDetail.lastName}}</b>
28   - &nbsp;<i class="fa fa-pencil-square-o" ng-click="company()" style="font-size: 11px;" aria-hidden="true"></i>
  37 + <b ng-show="editName" style="color:#F90;">{{contactDetail.firstName}} {{contactDetail.lastName}}</b>
  38 + <input type="text" ng-hide="editName" class="form-control" ng-blur="updateContact(contactDetail)" style="width: 49%; float: left;" ng-model="contactDetail.firstName">
  39 + <input type="text" ng-hide="editName" class="form-control" ng-blur="updateContact(contactDetail)" style="width: 49%;" ng-model="contactDetail.lastName">
  40 + &nbsp;<i class="fa fa-pencil-square-o" ng-show="editName" ng-click="nameEdit()" style="font-size: 11px;" aria-hidden="true"></i>
29 41 </h3>
30 42 {{contactDetail.owner.companyName}}
31 43 </div>
32 44 <div class="col-md-6">
33 45 <div style="margin-bottom: 10px" class="input-group email-password">
34 46 <span class="input-group-addon email-password"><i class="glyphicon glyphicon-user email-password-icon"></i></span>
35   - <input id="login-username" type="text" ng-model="contatctDetail.userName" class="form-control email-password" name="username" value="" placeholder="username or email">
  47 + <input id="login-username" type="text" ng-blur="updateContact(contactDetail)" ng-model="contactDetail.userName" class="form-control email-password" placeholder="username or email">
36 48 </div>
37 49  
38 50 <!-- <div class="input-group email-password">
... ... @@ -42,14 +54,38 @@
42 54 </div>
43 55 </div>
44 56 <div>
45   - <p><i class="fa fa-map-marker"></i> {{contactDetail.address}} &nbsp;<i class="fa fa-pencil-square-o" ng-click="company()" style="font-size: 11px;" aria-hidden="true"></i></p>
46   - <p><i class="fa fa-phone"></i> (310) 2342-3433 &nbsp;<i class="fa fa-pencil-square-o" ng-click="company()" style="font-size: 11px;" aria-hidden="true"></i></p>
47   - <p><i class="fa fa-envelope"></i> {{contactDetail.email}} &nbsp;<i class="fa fa-pencil-square-o" ng-click="company()" style="font-size: 11px;" aria-hidden="true"></i></p>
  57 + <p>
  58 + <span ng-show="editAddress">
  59 + <i class="fa fa-map-marker"></i> {{contactDetail.address}} &nbsp;
  60 + <i class="fa fa-pencil-square-o" ng-click="addressEdit()" style="font-size: 11px;" aria-hidden="true"></i>
  61 + </span>
  62 +
  63 + <input type="text" ng-hide="editAddress" class="form-control" ng-model="contactDetail.address" ng-blur="updateContact(contactDetail)">
  64 + </p>
  65 +
  66 + <p ng-show="editPhone"><i class="fa fa-phone"></i> {{contactDetail.mobilePhone}} &nbsp;<i class="fa fa-pencil-square-o" ng-click="phoneEdit()" style="font-size: 11px;" aria-hidden="true"></i></p>
  67 + <p ng-hide="editPhone">
  68 + <input type="text" ng-model="contactDetail.mobilePhone" ng-blur="updateContact(contactDetail)" class="form-control">
  69 + </p>
  70 +
  71 + <p ng-show="editMobile"><i class="fa fa-mobile"></i> {{contactDetail.workPhone}} &nbsp;<i class="fa fa-pencil-square-o" ng-click="mobileEdit()" style="font-size: 11px;" aria-hidden="true"></i></p>
  72 + <p ng-hide="editMobile">
  73 + <input type="text" ng-model="contactDetail.workPhone" ng-blur="updateContact(contactDetail)" class="form-control">
  74 + </p>
  75 +
  76 + <p ng-show="editEmail"><i class="fa fa-envelope"></i> {{contactDetail.email}} &nbsp;<i class="fa fa-pencil-square-o" ng-click="emailEdit()" style="font-size: 11px;" aria-hidden="true"></i></p>
  77 + <p ng-hide="editEmail">
  78 + <input type="email" ng-model="contactDetail.email" ng-blur="updateContact(contactDetail)" class="form-control">
  79 + </p>
48 80 </div>
49 81 </br>
50 82 <div>
51   - <p><b>Contact Notes</b> &nbsp;<i class="fa fa-pencil-square-o" ng-click="company()" style="font-size: 11px;" aria-hidden="true"></i>
52   - <p>{{contactDetail.note}}</p>
  83 + <p><b>Contact Notes</b> &nbsp;<i ng-show="editContactNotes" class="fa fa-pencil-square-o" ng-click="notesEdit()" style="font-size: 11px;" aria-hidden="true"></i>
  84 + <p ng-show="editContactNotes">{{contactDetail.note}}</p>
  85 + <p ng-hide="editContactNotes">
  86 + <input type="text" ng-model="contactDetail.note" ng-blur="updateContact(contactDetail)" class="form-control">
  87 + </p>
  88 +
53 89 <button type="button" class="btn btn-primary">Send Price to This Contacts</button>
54 90 </div>
55 91 <!-- <div class="col-md-6">
... ...
app/partials/viewcontact/viewcontact.service.js
... ... @@ -20,6 +20,38 @@
20 20 })
21 21 return deferred.promise;
22 22 }
  23 +
  24 + this.getContactsList = function(id) {
  25 +
  26 + var deferred = $q.defer();
  27 + $http({
  28 + method : 'GET',
  29 + url : BASE_URL.url +'/company/contact/idList/'+id,
  30 + headers : {'Content-Type': 'application/json'},
  31 + })
  32 + .then(function (result){
  33 + deferred.resolve(result.data);
  34 + },function (result){
  35 + deferred.resolve(result.data);
  36 + })
  37 + return deferred.promise;
  38 + }
  39 +
  40 + this.updateContact = function(data) {
  41 + var deferred = $q.defer();
  42 + $http({
  43 + method : 'PUT',
  44 + url : BASE_URL.url +'/company/contact',
  45 + data : data,
  46 + headers : {'Content-Type': 'application/json'},
  47 + })
  48 + .then(function (result){
  49 + deferred.resolve(result.data);
  50 + },function (result){
  51 + deferred.resolve(result.data);
  52 + })
  53 + return deferred.promise;
  54 + }
23 55  
24 56 }
25 57  
... ...