Photo Gallery by WD – Responsive Photo Gallery - Version 1.5.81

Version Description

  • Improved: DB queries on opening lightbox.
  • Improved: Updated external js libraries.
  • Improved: Escaped all data printed in gallery views.
  • Fixed: Disable "Add selected images to gallery" button after adding images.
  • Fixed: Missing "Back" button in Gallery groups with disabled dynamic URLs for galleries and gallery groups.
  • Fixed: Masonry distance issue with video items.
  • Fixed: Restrict Gallery download from URL.
  • Fixed: Bulk actions after search by alt/desc.
Download this release

Release Info

Developer 10web
Plugin Icon 128x128 Photo Gallery by WD – Responsive Photo Gallery
Version 1.5.81
Comparing to
See all releases

Code changes from version 1.5.80 to 1.5.81

Files changed (49) hide show
  1. admin/controllers/Options.php +1 -0
  2. admin/models/Galleries.php +60 -20
  3. admin/views/Options.php +2 -2
  4. admin/views/Shortcode.php +1 -1
  5. admin/views/Themes.php +140 -136
  6. admin/views/WidgetTags.php +3 -3
  7. css/bwg_frontend.css +7 -0
  8. css/bwg_tables.css +4 -1
  9. css/jquery.mCustomScrollbar.css +1265 -462
  10. css/jquery.mCustomScrollbar.min.css +1 -1
  11. css/styles.min.css +1 -1
  12. css/sumoselect.css +337 -84
  13. css/sumoselect.min.css +1 -1
  14. filemanager/UploadHandler.php +11 -16
  15. filemanager/js/default.js +3 -0
  16. filemanager/js/jq_uploader/jquery.fileupload.js +156 -161
  17. filemanager/js/jq_uploader/jquery.iframe-transport.js +36 -30
  18. filemanager/model.php +96 -79
  19. filemanager/view.php +3 -3
  20. framework/WDWLibrary.php +30 -30
  21. frontend/controllers/BWGControllerDownload_gallery.php +6 -0
  22. frontend/controllers/BWGControllerGalleryBox.php +18 -13
  23. frontend/models/BWGModelGalleryBox.php +8 -5
  24. frontend/models/model.php +9 -0
  25. frontend/views/BWGViewAlbum_compact_preview.php +22 -22
  26. frontend/views/BWGViewAlbum_extended_preview.php +37 -37
  27. frontend/views/BWGViewGalleryBox.php +88 -86
  28. frontend/views/BWGViewImage_browser.php +31 -31
  29. frontend/views/BWGViewSlideshow.php +66 -65
  30. frontend/views/BWGViewThumbnails.php +21 -20
  31. frontend/views/view.php +68 -66
  32. js/bwg.js +26 -3
  33. js/bwg_frontend.js +4 -4
  34. js/bwg_gallery_box.js +260 -252
  35. js/fontselect/fonts/Action Man.woff +0 -0
  36. js/fontselect/fonts/Bauer.woff +0 -0
  37. js/fontselect/fonts/Bubble.woff +0 -0
  38. js/fontselect/fontselect.css +89 -0
  39. js/fontselect/fontselect.js +1314 -0
  40. js/fontselect/fontselect.min.css +1 -0
  41. js/fontselect/fontselect.min.js +13 -0
  42. js/jquery.fullscreen.js +296 -0
  43. js/jquery.fullscreen.min.js +28 -0
  44. js/jquery.jscolor.js +3524 -0
  45. js/jquery.mCustomScrollbar.concat.min.js +5 -4
  46. js/jquery.mCustomScrollbar.js +2454 -0
  47. js/jquery.mobile.min.js +1 -1
  48. js/jquery.sumoselect.js +913 -0
  49. js/jquery.sumoselect.min.js +79 -759
admin/controllers/Options.php CHANGED
@@ -245,6 +245,7 @@ class OptionsController_bwg {
245
  }
246
 
247
  $error = false;
 
248
  if ( ini_get('allow_url_fopen') == 0 ) {
249
  $error = true;
250
  $message = WDWLibrary::message_id(0, __('http:// wrapper is disabled in the server configuration by allow_url_fopen=0.', $this->prefix), 'error');
245
  }
246
 
247
  $error = false;
248
+
249
  if ( ini_get('allow_url_fopen') == 0 ) {
250
  $error = true;
251
  $message = WDWLibrary::message_id(0, __('http:// wrapper is disabled in the server configuration by allow_url_fopen=0.', $this->prefix), 'error');
admin/models/Galleries.php CHANGED
@@ -903,8 +903,12 @@ class GalleriesModel_bwg {
903
  }
904
  $search = WDWLibrary::get('s');
905
  if ( $search ) {
906
- $where .= ' AND `filename` LIKE %s';
907
- $prepareArgs[] = "%" . $search . "%";
 
 
 
 
908
  }
909
  $updated = $wpdb->query($wpdb->prepare('UPDATE `' . $wpdb->prefix . 'bwg_image` SET published=1' . $where, $prepareArgs));
910
  $message = 2;
@@ -938,8 +942,12 @@ class GalleriesModel_bwg {
938
  }
939
  $search = WDWLibrary::get('s');
940
  if ( $search ) {
941
- $where .= ' AND `filename` LIKE %s';
942
- $prepareArgs[] = "%" . $search . "%";
 
 
 
 
943
  }
944
  $updated = $wpdb->query($wpdb->prepare('UPDATE `' . $wpdb->prefix . 'bwg_image` SET published=0' . $where, $prepareArgs));
945
  $message = 2;
@@ -1068,8 +1076,12 @@ class GalleriesModel_bwg {
1068
  //$where = ( ($gallery_id) ? ' `gallery_id` = ' . $gallery_id . ($image_id ? ' AND `id` = ' . $image_id : '' ) : 1 );
1069
  $search = WDWLibrary::get('s');
1070
  if ( $search ) {
1071
- $where .= ' AND `filename` LIKE %s';
1072
- $prepareArgs[] = "%" . $search . "%";
 
 
 
 
1073
  }
1074
  if ( !empty($prepareArgs) ) {
1075
  $images_data = $wpdb->get_results($wpdb->prepare('SELECT id, image_url, thumb_url, resolution_thumb FROM `' . $wpdb->prefix . 'bwg_image` WHERE ' . $where, $prepareArgs));
@@ -1182,8 +1194,12 @@ class GalleriesModel_bwg {
1182
  }
1183
  $search = WDWLibrary::get('s');
1184
  if ( $search ) {
1185
- $where .= ' AND `filename` LIKE %s';
1186
- $prepareArgs[] = "%" . $search . "%";
 
 
 
 
1187
  }
1188
  foreach ( $img_ids as $img_id ) {
1189
  $file_path = str_replace("thumb", ".original", htmlspecialchars_decode(BWG()->upload_dir . $img_id->thumb_url, ENT_COMPAT | ENT_QUOTES));
@@ -1226,8 +1242,12 @@ class GalleriesModel_bwg {
1226
  }
1227
  $search = WDWLibrary::get('s');
1228
  if ( $search ) {
1229
- $where .= ' AND `filename` LIKE %s';
1230
- $prepareArgs[] = "%" . $search . "%";
 
 
 
 
1231
  }
1232
  $images = $wpdb->get_results($wpdb->prepare('SELECT * FROM `' . $wpdb->prefix . 'bwg_image` WHERE ' . $where, $prepareArgs));
1233
  if ( !empty($images) ) {
@@ -1271,8 +1291,12 @@ class GalleriesModel_bwg {
1271
  }
1272
  $search = WDWLibrary::get('s');
1273
  if ( $search ) {
1274
- $where .= ' AND `filename` LIKE %s';
1275
- $prepareArgs[] = "%" . $search . "%";
 
 
 
 
1276
  }
1277
  global $wpdb;
1278
  $updated = $wpdb->query($wpdb->prepare('UPDATE `' . $wpdb->prefix . 'bwg_image` SET `alt`="%s", `description`="%s", `redirect_url`="%s"' . $where, $prepareArgs));
@@ -1306,8 +1330,12 @@ class GalleriesModel_bwg {
1306
  }
1307
  $search = WDWLibrary::get('s');
1308
  if ( $search ) {
1309
- $where .= ' AND `filename` LIKE %s';
1310
- $prepareArgs[] = "%" . $search . "%";
 
 
 
 
1311
  }
1312
  global $wpdb;
1313
  $updated = $wpdb->query($wpdb->prepare('UPDATE `' . $wpdb->prefix . 'bwg_image` SET `alt`="%s"' . $where, $prepareArgs));
@@ -1341,8 +1369,12 @@ class GalleriesModel_bwg {
1341
  }
1342
  $search = WDWLibrary::get('s');
1343
  if ( $search ) {
1344
- $where .= ' AND `filename` LIKE %s';
1345
- $prepareArgs[] = "%" . $search . "%";
 
 
 
 
1346
  }
1347
  global $wpdb;
1348
  $updated = $wpdb->query($wpdb->prepare('UPDATE `' . $wpdb->prefix . 'bwg_image` SET `description`="%s"' . $where, $prepareArgs));
@@ -1376,8 +1408,12 @@ class GalleriesModel_bwg {
1376
  }
1377
  $search = WDWLibrary::get('s');
1378
  if ( $search ) {
1379
- $where .= ' AND `filename` LIKE %s';
1380
- $prepareArgs[] = "%" . $search . "%";
 
 
 
 
1381
  }
1382
  global $wpdb;
1383
  $updated = $wpdb->query($wpdb->prepare('UPDATE `' . $wpdb->prefix . 'bwg_image` SET `redirect_url`="%s"' . $where, $prepareArgs));
@@ -1505,8 +1541,12 @@ class GalleriesModel_bwg {
1505
  }
1506
  $search = WDWLibrary::get('s');
1507
  if ( $search ) {
1508
- $where .= ' AND `filename` LIKE %s';
1509
- $prepareArgs[] = "%" . $search . "%";
 
 
 
 
1510
  }
1511
  $wpdb->query($wpdb->prepare('UPDATE `' . $wpdb->prefix . 'bwg_image` SET pricelist_id=0' . $where, $prepareArgs));
1512
  }
903
  }
904
  $search = WDWLibrary::get('s');
905
  if ( $search ) {
906
+ $where .= ' AND (`alt` LIKE %s';
907
+ $where .= ' OR `filename` LIKE %s';
908
+ $where .= ' OR `description` LIKE %s)';
909
+ $prepareArgs[] = "%" . trim($search) . "%";
910
+ $prepareArgs[] = "%" . trim($search) . "%";
911
+ $prepareArgs[] = "%" . trim($search) . "%";
912
  }
913
  $updated = $wpdb->query($wpdb->prepare('UPDATE `' . $wpdb->prefix . 'bwg_image` SET published=1' . $where, $prepareArgs));
914
  $message = 2;
942
  }
943
  $search = WDWLibrary::get('s');
944
  if ( $search ) {
945
+ $where .= ' AND (`alt` LIKE %s';
946
+ $where .= ' OR `filename` LIKE %s';
947
+ $where .= ' OR `description` LIKE %s)';
948
+ $prepareArgs[] = "%" . trim($search) . "%";
949
+ $prepareArgs[] = "%" . trim($search) . "%";
950
+ $prepareArgs[] = "%" . trim($search) . "%";
951
  }
952
  $updated = $wpdb->query($wpdb->prepare('UPDATE `' . $wpdb->prefix . 'bwg_image` SET published=0' . $where, $prepareArgs));
953
  $message = 2;
1076
  //$where = ( ($gallery_id) ? ' `gallery_id` = ' . $gallery_id . ($image_id ? ' AND `id` = ' . $image_id : '' ) : 1 );
1077
  $search = WDWLibrary::get('s');
1078
  if ( $search ) {
1079
+ $where .= ' AND (`alt` LIKE %s';
1080
+ $where .= ' OR `filename` LIKE %s';
1081
+ $where .= ' OR `description` LIKE %s)';
1082
+ $prepareArgs[] = "%" . trim($search) . "%";
1083
+ $prepareArgs[] = "%" . trim($search) . "%";
1084
+ $prepareArgs[] = "%" . trim($search) . "%";
1085
  }
1086
  if ( !empty($prepareArgs) ) {
1087
  $images_data = $wpdb->get_results($wpdb->prepare('SELECT id, image_url, thumb_url, resolution_thumb FROM `' . $wpdb->prefix . 'bwg_image` WHERE ' . $where, $prepareArgs));
1194
  }
1195
  $search = WDWLibrary::get('s');
1196
  if ( $search ) {
1197
+ $where .= ' AND (`alt` LIKE %s';
1198
+ $where .= ' OR `filename` LIKE %s';
1199
+ $where .= ' OR `description` LIKE %s)';
1200
+ $prepareArgs[] = "%" . trim($search) . "%";
1201
+ $prepareArgs[] = "%" . trim($search) . "%";
1202
+ $prepareArgs[] = "%" . trim($search) . "%";
1203
  }
1204
  foreach ( $img_ids as $img_id ) {
1205
  $file_path = str_replace("thumb", ".original", htmlspecialchars_decode(BWG()->upload_dir . $img_id->thumb_url, ENT_COMPAT | ENT_QUOTES));
1242
  }
1243
  $search = WDWLibrary::get('s');
1244
  if ( $search ) {
1245
+ $where .= ' AND (`alt` LIKE %s';
1246
+ $where .= ' OR `filename` LIKE %s';
1247
+ $where .= ' OR `description` LIKE %s)';
1248
+ $prepareArgs[] = "%" . trim($search) . "%";
1249
+ $prepareArgs[] = "%" . trim($search) . "%";
1250
+ $prepareArgs[] = "%" . trim($search) . "%";
1251
  }
1252
  $images = $wpdb->get_results($wpdb->prepare('SELECT * FROM `' . $wpdb->prefix . 'bwg_image` WHERE ' . $where, $prepareArgs));
1253
  if ( !empty($images) ) {
1291
  }
1292
  $search = WDWLibrary::get('s');
1293
  if ( $search ) {
1294
+ $where .= ' AND (`alt` LIKE %s';
1295
+ $where .= ' OR `filename` LIKE %s';
1296
+ $where .= ' OR `description` LIKE %s)';
1297
+ $prepareArgs[] = "%" . trim($search) . "%";
1298
+ $prepareArgs[] = "%" . trim($search) . "%";
1299
+ $prepareArgs[] = "%" . trim($search) . "%";
1300
  }
1301
  global $wpdb;
1302
  $updated = $wpdb->query($wpdb->prepare('UPDATE `' . $wpdb->prefix . 'bwg_image` SET `alt`="%s", `description`="%s", `redirect_url`="%s"' . $where, $prepareArgs));
1330
  }
1331
  $search = WDWLibrary::get('s');
1332
  if ( $search ) {
1333
+ $where .= ' AND (`alt` LIKE %s';
1334
+ $where .= ' OR `filename` LIKE %s';
1335
+ $where .= ' OR `description` LIKE %s)';
1336
+ $prepareArgs[] = "%" . trim($search) . "%";
1337
+ $prepareArgs[] = "%" . trim($search) . "%";
1338
+ $prepareArgs[] = "%" . trim($search) . "%";
1339
  }
1340
  global $wpdb;
1341
  $updated = $wpdb->query($wpdb->prepare('UPDATE `' . $wpdb->prefix . 'bwg_image` SET `alt`="%s"' . $where, $prepareArgs));
1369
  }
1370
  $search = WDWLibrary::get('s');
1371
  if ( $search ) {
1372
+ $where .= ' AND (`alt` LIKE %s';
1373
+ $where .= ' OR `filename` LIKE %s';
1374
+ $where .= ' OR `description` LIKE %s)';
1375
+ $prepareArgs[] = "%" . trim($search) . "%";
1376
+ $prepareArgs[] = "%" . trim($search) . "%";
1377
+ $prepareArgs[] = "%" . trim($search) . "%";
1378
  }
1379
  global $wpdb;
1380
  $updated = $wpdb->query($wpdb->prepare('UPDATE `' . $wpdb->prefix . 'bwg_image` SET `description`="%s"' . $where, $prepareArgs));
1408
  }
1409
  $search = WDWLibrary::get('s');
1410
  if ( $search ) {
1411
+ $where .= ' AND (`alt` LIKE %s';
1412
+ $where .= ' OR `filename` LIKE %s';
1413
+ $where .= ' OR `description` LIKE %s)';
1414
+ $prepareArgs[] = "%" . trim($search) . "%";
1415
+ $prepareArgs[] = "%" . trim($search) . "%";
1416
+ $prepareArgs[] = "%" . trim($search) . "%";
1417
  }
1418
  global $wpdb;
1419
  $updated = $wpdb->query($wpdb->prepare('UPDATE `' . $wpdb->prefix . 'bwg_image` SET `redirect_url`="%s"' . $where, $prepareArgs));
1541
  }
1542
  $search = WDWLibrary::get('s');
1543
  if ( $search ) {
1544
+ $where .= ' AND (`alt` LIKE %s';
1545
+ $where .= ' OR `filename` LIKE %s';
1546
+ $where .= ' OR `description` LIKE %s)';
1547
+ $prepareArgs[] = "%" . trim($search) . "%";
1548
+ $prepareArgs[] = "%" . trim($search) . "%";
1549
+ $prepareArgs[] = "%" . trim($search) . "%";
1550
  }
1551
  $wpdb->query($wpdb->prepare('UPDATE `' . $wpdb->prefix . 'bwg_image` SET pricelist_id=0' . $where, $prepareArgs));
1552
  }
admin/views/Options.php CHANGED
@@ -954,7 +954,7 @@ class OptionsView_bwg extends AdminView_bwg {
954
  <div class="wd-group">
955
  <label class="wd-label" for="watermark_color"><?php _e('Advertisement color', BWG()->prefix); ?></label>
956
  <div class="bwg-flex">
957
- <input type="text" name="watermark_color" id="watermark_color" value="<?php echo $row->watermark_color; ?>" class="color" onchange="preview_watermark()" />
958
  </div>
959
  <p class="description"><?php _e('Choose the color for the advertisement text on images.', BWG()->prefix) ?></p>
960
  </div>
@@ -1102,7 +1102,7 @@ class OptionsView_bwg extends AdminView_bwg {
1102
  <div class="wd-group">
1103
  <label class="wd-label" for="built_in_watermark_color"><?php _e('Watermark color', BWG()->prefix); ?></label>
1104
  <div class="bwg-flex">
1105
- <input type="text" name="built_in_watermark_color" id="built_in_watermark_color" value="<?php echo $row->built_in_watermark_color; ?>" class="color" onchange="preview_built_in_watermark()" />
1106
  </div>
1107
  <p class="description"><?php _e('Choose the color for the watermark text on images.', BWG()->prefix) ?></p>
1108
  </div>
954
  <div class="wd-group">
955
  <label class="wd-label" for="watermark_color"><?php _e('Advertisement color', BWG()->prefix); ?></label>
956
  <div class="bwg-flex">
957
+ <input type="text" name="watermark_color" id="watermark_color" value="<?php echo $row->watermark_color; ?>" class="jscolor" onchange="preview_watermark()" />
958
  </div>
959
  <p class="description"><?php _e('Choose the color for the advertisement text on images.', BWG()->prefix) ?></p>
960
  </div>
1102
  <div class="wd-group">
1103
  <label class="wd-label" for="built_in_watermark_color"><?php _e('Watermark color', BWG()->prefix); ?></label>
1104
  <div class="bwg-flex">
1105
+ <input type="text" name="built_in_watermark_color" id="built_in_watermark_color" value="<?php echo $row->built_in_watermark_color; ?>" class="jscolor" onchange="preview_built_in_watermark()" />
1106
  </div>
1107
  <p class="description"><?php _e('Choose the color for the watermark text on images.', BWG()->prefix) ?></p>
1108
  </div>
admin/views/Shortcode.php CHANGED
@@ -456,7 +456,7 @@ class ShortcodeView_bwg extends AdminView_bwg {
456
  <div class="wd-box-content wd-width-100" id="tr_watermark_color">
457
  <div class="wd-group">
458
  <label class="wd-label" for="watermark_color"><?php _e('Advertisement color', BWG()->prefix); ?></label>
459
- <input type="text" name="watermark_color" id="watermark_color" value="<?php echo BWG()->options->watermark_color; ?>" class="color" />
460
  <p class="description"><?php _e("Choose the color for the advertisement text on images.", BWG()->prefix); ?></p>
461
  </div>
462
  </div>
456
  <div class="wd-box-content wd-width-100" id="tr_watermark_color">
457
  <div class="wd-group">
458
  <label class="wd-label" for="watermark_color"><?php _e('Advertisement color', BWG()->prefix); ?></label>
459
+ <input type="text" name="watermark_color" id="watermark_color" value="<?php echo BWG()->options->watermark_color; ?>" class="jscolor" />
460
  <p class="description"><?php _e("Choose the color for the advertisement text on images.", BWG()->prefix); ?></p>
461
  </div>
462
  </div>
admin/views/Themes.php CHANGED
@@ -260,8 +260,12 @@ class ThemesView_bwg extends AdminView_bwg {
260
  }
261
 
262
  /**
263
- *
264
  * Generate row for font styles google fonts
 
 
 
 
 
265
  */
266
  public function font_style_row( $saved_style, $font_style, $label_text, $radio_name) {
267
  $google_fonts = WDWLibrary::get_google_fonts();
@@ -414,7 +418,7 @@ class ThemesView_bwg extends AdminView_bwg {
414
  <tr>
415
  <td class="spider_label"><label for="thumb_border_color"><?php echo __('Border color:', BWG()->prefix); ?></label></td>
416
  <td>
417
- <input type="text" name="thumb_border_color" id="thumb_border_color" value="<?php echo $row->thumb_border_color; ?>" class="color"/>
418
  </td>
419
  </tr>
420
  <tr>
@@ -473,10 +477,10 @@ class ThemesView_bwg extends AdminView_bwg {
473
  <tbody>
474
  <tr>
475
  <td class="spider_label">
476
- <label for="thumb_bg_color"><?php echo __('Thumbnail background color:', BWG()->prefix); ?> </label>
477
  </td>
478
  <td>
479
- <input type="text" name="thumb_bg_color" id="thumb_bg_color" value="<?php echo $row->thumb_bg_color; ?>" class="color"/>
480
  </td>
481
  </tr>
482
  <tr>
@@ -496,7 +500,7 @@ class ThemesView_bwg extends AdminView_bwg {
496
  <tr>
497
  <td class="spider_label"><label for="thumbs_bg_color"><?php echo __('Full background color:', BWG()->prefix); ?> </label></td>
498
  <td>
499
- <input type="text" name="thumbs_bg_color" id="thumbs_bg_color" value="<?php echo $row->thumbs_bg_color; ?>" class="color"/>
500
  </td>
501
  </tr>
502
  <tr>
@@ -548,13 +552,13 @@ class ThemesView_bwg extends AdminView_bwg {
548
  <tr>
549
  <td class="spider_label"><label for="thumb_title_font_color"><?php echo __('Title font color:', BWG()->prefix); ?> </label></td>
550
  <td>
551
- <input type="text" name="thumb_title_font_color" id="thumb_title_font_color" value="<?php echo $row->thumb_title_font_color; ?>" class="color" />
552
  </td>
553
  </tr>
554
  <tr>
555
  <td class="spider_label"><label for="thumb_title_font_color_hover"><?php echo __('Title font color (Show on hover):', BWG()->prefix); ?> </label></td>
556
  <td>
557
- <input type="text" name="thumb_title_font_color_hover" id="thumb_title_font_color_hover" value="<?php echo $row->thumb_title_font_color_hover; ?>" class="color" />
558
  </td>
559
  </tr>
560
  <tr>
@@ -599,7 +603,7 @@ class ThemesView_bwg extends AdminView_bwg {
599
  <tr>
600
  <td class="spider_label"><label for="thumb_description_font_color"><?php echo __('Thumb description font color:', BWG()->prefix); ?> </label></td>
601
  <td>
602
- <input type="text" name="thumb_description_font_color" id="thumb_description_font_color" value="<?php echo $row->thumb_description_font_color; ?>" class="color" />
603
  </td>
604
  </tr>
605
  <tr>
@@ -616,7 +620,7 @@ class ThemesView_bwg extends AdminView_bwg {
616
  <tr>
617
  <td class="spider_label"><label for="thumb_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
618
  <td>
619
- <input type="text" name="thumb_gal_title_font_color" id="thumb_gal_title_font_color" value="<?php echo $row->thumb_gal_title_font_color; ?>" class="color" />
620
  </td>
621
  </tr>
622
  <tr>
@@ -718,7 +722,7 @@ class ThemesView_bwg extends AdminView_bwg {
718
  <tr>
719
  <td class="spider_label"><label for="masonry_thumb_border_color"><?php echo __('Border color:', BWG()->prefix); ?> </label></td>
720
  <td>
721
- <input type="text" name="masonry_thumb_border_color" id="masonry_thumb_border_color" value="<?php echo $row->masonry_thumb_border_color; ?>" class="color" />
722
  </td>
723
  </tr>
724
  <tr>
@@ -773,7 +777,7 @@ class ThemesView_bwg extends AdminView_bwg {
773
  <label for="masonry_thumb_bg_color"><?php echo __('Thumbnail background color:', BWG()->prefix); ?> </label>
774
  </td>
775
  <td>
776
- <input type="text" name="masonry_thumb_bg_color" id="masonry_thumb_bg_color" value="<?php echo $row->masonry_thumb_bg_color; ?>" class="color" />
777
  </td>
778
  </tr>
779
  <tr>
@@ -793,7 +797,7 @@ class ThemesView_bwg extends AdminView_bwg {
793
  <tr>
794
  <td class="spider_label"><label for="masonry_thumbs_bg_color"><?php echo __('Full Background color:', BWG()->prefix); ?> </label></td>
795
  <td>
796
- <input type="text" name="masonry_thumbs_bg_color" id="masonry_thumbs_bg_color" value="<?php echo $row->masonry_thumbs_bg_color; ?>" class="color" />
797
  </td>
798
  </tr>
799
  <tr>
@@ -832,13 +836,13 @@ class ThemesView_bwg extends AdminView_bwg {
832
  <tr>
833
  <td class="spider_label"><label for="masonry_thumb_title_font_color"><?php echo __('Title font color:', BWG()->prefix); ?> </label></td>
834
  <td>
835
- <input type="text" name="masonry_thumb_title_font_color" id="masonry_thumb_title_font_color" value="<?php echo $row->masonry_thumb_title_font_color; ?>" class="color" />
836
  </td>
837
  </tr>
838
  <tr>
839
  <td class="spider_label"><label for="masonry_thumb_title_font_color_hover"><?php echo __('Title font color (Show on hover):', BWG()->prefix); ?> </label></td>
840
  <td>
841
- <input type="text" name="masonry_thumb_title_font_color_hover" id="masonry_thumb_title_font_color_hover" value="<?php echo $row->masonry_thumb_title_font_color_hover; ?>" class="color" />
842
  </td>
843
  </tr>
844
  <tr>
@@ -875,7 +879,7 @@ class ThemesView_bwg extends AdminView_bwg {
875
  <tr>
876
  <td class="spider_label"><label for="masonry_description_color"><?php echo __('Description font color:', BWG()->prefix); ?> </label></td>
877
  <td>
878
- <input type="text" name="masonry_description_color" id="masonry_description_color" value="<?php echo $row->masonry_description_color; ?>" class="color" />
879
  </td>
880
  </tr>
881
  <tr>
@@ -891,7 +895,7 @@ class ThemesView_bwg extends AdminView_bwg {
891
  <tr>
892
  <td class="spider_label"><label for="masonry_thumb_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
893
  <td>
894
- <input type="text" name="masonry_thumb_gal_title_font_color" id="masonry_thumb_gal_title_font_color" value="<?php echo $row->masonry_thumb_gal_title_font_color; ?>" class="color" />
895
  </td>
896
  </tr>
897
  <tr>
@@ -993,7 +997,7 @@ class ThemesView_bwg extends AdminView_bwg {
993
  <tr>
994
  <td class="spider_label"><label for="mosaic_thumb_border_color"><?php echo __('Border color:', BWG()->prefix); ?> </label></td>
995
  <td>
996
- <input type="text" name="mosaic_thumb_border_color" id="mosaic_thumb_border_color" value="<?php echo $row->mosaic_thumb_border_color; ?>" class="color" />
997
  </td>
998
  </tr>
999
  <tr>
@@ -1046,7 +1050,7 @@ class ThemesView_bwg extends AdminView_bwg {
1046
  <tr>
1047
  <td class="spider_label"><label for="mosaic_thumb_bg_color"><?php echo __('Thumbnail background color:', BWG()->prefix); ?> </label></td>
1048
  <td>
1049
- <input type="text" name="mosaic_thumb_bg_color" id="mosaic_thumb_bg_color" value="<?php echo $row->mosaic_thumb_bg_color; ?>" class="color" />
1050
  </td>
1051
  </tr>
1052
  <tr>
@@ -1066,7 +1070,7 @@ class ThemesView_bwg extends AdminView_bwg {
1066
  <tr>
1067
  <td class="spider_label"><label for="mosaic_thumbs_bg_color"><?php echo __('Full Background color:', BWG()->prefix); ?> </label></td>
1068
  <td>
1069
- <input type="text" name="mosaic_thumbs_bg_color" id="mosaic_thumbs_bg_color" value="<?php echo $row->mosaic_thumbs_bg_color; ?>" class="color" />
1070
  </td>
1071
  </tr>
1072
  <tr>
@@ -1109,13 +1113,13 @@ class ThemesView_bwg extends AdminView_bwg {
1109
  <tr>
1110
  <td class="spider_label"><label for="mosaic_thumb_title_font_color"><?php echo __('Title font color:', BWG()->prefix); ?> </label></td>
1111
  <td>
1112
- <input type="text" name="mosaic_thumb_title_font_color" id="mosaic_thumb_title_font_color" value="<?php echo $row->mosaic_thumb_title_font_color; ?>" class="color" />
1113
  </td>
1114
  </tr>
1115
  <tr>
1116
  <td class="spider_label"><label for="mosaic_thumb_title_font_color_hover"><?php echo __('Title font color (Show on hover):', BWG()->prefix); ?> </label></td>
1117
  <td>
1118
- <input type="text" name="mosaic_thumb_title_font_color_hover" id="mosaic_thumb_title_font_color_hover" value="<?php echo $row->mosaic_thumb_title_font_color_hover; ?>" class="color" />
1119
  </td>
1120
  </tr>
1121
  <tr>
@@ -1159,7 +1163,7 @@ class ThemesView_bwg extends AdminView_bwg {
1159
  <tr>
1160
  <td class="spider_label"><label for="mosaic_thumb_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
1161
  <td>
1162
- <input type="text" name="mosaic_thumb_gal_title_font_color" id="mosaic_thumb_gal_title_font_color" value="<?php echo $row->mosaic_thumb_gal_title_font_color; ?>" class="color" />
1163
  </td>
1164
  </tr>
1165
  <tr>
@@ -1225,7 +1229,7 @@ class ThemesView_bwg extends AdminView_bwg {
1225
  <tr>
1226
  <td class="spider_label"><label for="slideshow_cont_bg_color"><?php echo __('Background color:', BWG()->prefix); ?> </label></td>
1227
  <td>
1228
- <input type="text" name="slideshow_cont_bg_color" id="slideshow_cont_bg_color" value="<?php echo $row->slideshow_cont_bg_color; ?>" class="color"/>
1229
  </td>
1230
  </tr>
1231
  <tr>
@@ -1243,7 +1247,7 @@ class ThemesView_bwg extends AdminView_bwg {
1243
  <tr>
1244
  <td class="spider_label"><label for="slideshow_rl_btn_color"><?php echo __('Buttons color:', BWG()->prefix); ?> </label></td>
1245
  <td>
1246
- <input type="text" name="slideshow_rl_btn_color" id="slideshow_rl_btn_color" value="<?php echo $row->slideshow_rl_btn_color; ?>" class="color"/>
1247
  </td>
1248
  </tr>
1249
  <tr>
@@ -1256,7 +1260,7 @@ class ThemesView_bwg extends AdminView_bwg {
1256
  <tr>
1257
  <td class="spider_label"><label for="slideshow_close_rl_btn_hover_color"><?php echo __('Buttons hover color:', BWG()->prefix); ?> </label></td>
1258
  <td>
1259
- <input type="text" name="slideshow_close_rl_btn_hover_color" id="slideshow_close_rl_btn_hover_color" value="<?php echo $row->slideshow_close_rl_btn_hover_color; ?>" class="color"/>
1260
  </td>
1261
  </tr>
1262
  <tr>
@@ -1274,7 +1278,7 @@ class ThemesView_bwg extends AdminView_bwg {
1274
  <tr>
1275
  <td class="spider_label"><label for="slideshow_rl_btn_bg_color"><?php echo __('Right, left buttons background color:', BWG()->prefix); ?> </label></td>
1276
  <td>
1277
- <input type="text" name="slideshow_rl_btn_bg_color" id="slideshow_rl_btn_bg_color" value="<?php echo $row->slideshow_rl_btn_bg_color; ?>" class="color"/>
1278
  </td>
1279
  </tr>
1280
  <tr>
@@ -1300,7 +1304,7 @@ class ThemesView_bwg extends AdminView_bwg {
1300
  <tr>
1301
  <td class="spider_label"><label for="slideshow_rl_btn_border_color"><?php echo __('Right, left buttons border color:', BWG()->prefix); ?> </label></td>
1302
  <td>
1303
- <input type="text" name="slideshow_rl_btn_border_color" id="slideshow_rl_btn_border_color" value="<?php echo $row->slideshow_rl_btn_border_color; ?>" class="color"/>
1304
  </td>
1305
  </tr>
1306
  <tr>
@@ -1383,7 +1387,7 @@ class ThemesView_bwg extends AdminView_bwg {
1383
  <tr>
1384
  <td class="spider_label"><label for="slideshow_filmstrip_thumb_border_color"><?php echo __('Filmstrip border color:', BWG()->prefix); ?> </label></td>
1385
  <td>
1386
- <input type="text" name="slideshow_filmstrip_thumb_border_color" id="slideshow_filmstrip_thumb_border_color" value="<?php echo $row->slideshow_filmstrip_thumb_border_color; ?>" class="color"/>
1387
  </td>
1388
  </tr>
1389
  <tr>
@@ -1402,7 +1406,7 @@ class ThemesView_bwg extends AdminView_bwg {
1402
  <tr>
1403
  <td class="spider_label"><label for="slideshow_filmstrip_thumb_active_border_color"><?php echo __('Filmstrip active border color:', BWG()->prefix); ?> </label></td>
1404
  <td>
1405
- <input type="text" name="slideshow_filmstrip_thumb_active_border_color" id="slideshow_filmstrip_thumb_active_border_color" value="<?php echo $row->slideshow_filmstrip_thumb_active_border_color; ?>" class="color"/>
1406
  </td>
1407
  </tr>
1408
  <tr id="tr_appWidth">
@@ -1415,13 +1419,13 @@ class ThemesView_bwg extends AdminView_bwg {
1415
  <tr>
1416
  <td class="spider_label"><label for="slideshow_filmstrip_rl_bg_color"><?php echo __('Filmstrip right, left buttons background color: ', BWG()->prefix); ?></label></td>
1417
  <td>
1418
- <input type="text" name="slideshow_filmstrip_rl_bg_color" id="slideshow_filmstrip_rl_bg_color" value="<?php echo $row->slideshow_filmstrip_rl_bg_color; ?>" class="color"/>
1419
  </td>
1420
  </tr>
1421
  <tr>
1422
  <td class="spider_label"><label for="slideshow_filmstrip_rl_btn_color"><?php echo __('Filmstrip right, left buttons color:', BWG()->prefix); ?> </label></td>
1423
  <td>
1424
- <input type="text" name="slideshow_filmstrip_rl_btn_color" id="slideshow_filmstrip_rl_btn_color" value="<?php echo $row->slideshow_filmstrip_rl_btn_color; ?>" class="color"/>
1425
  </td>
1426
  </tr>
1427
  <tr>
@@ -1452,7 +1456,7 @@ class ThemesView_bwg extends AdminView_bwg {
1452
  <tr>
1453
  <td class="spider_label"><label for="slideshow_dots_background_color"><?php echo __('Slider bullet background color:', BWG()->prefix); ?> </label></td>
1454
  <td>
1455
- <input type="text" name="slideshow_dots_background_color" id="slideshow_dots_background_color" value="<?php echo $row->slideshow_dots_background_color; ?>" class="color"/>
1456
  </td>
1457
  </tr>
1458
  <tr>
@@ -1464,7 +1468,7 @@ class ThemesView_bwg extends AdminView_bwg {
1464
  <tr>
1465
  <td class="spider_label"><label for="slideshow_dots_active_background_color"><?php echo __('Slider bullet active background color: ', BWG()->prefix); ?></label></td>
1466
  <td>
1467
- <input type="text" name="slideshow_dots_active_background_color" id="slideshow_dots_active_background_color" value="<?php echo $row->slideshow_dots_active_background_color; ?>" class="color"/>
1468
  </td>
1469
  </tr>
1470
  <tr>
@@ -1476,7 +1480,7 @@ class ThemesView_bwg extends AdminView_bwg {
1476
  <tr>
1477
  <td class="spider_label"><label for="slideshow_dots_active_border_color"><?php echo __('Slider bullet active border color: ', BWG()->prefix); ?></label></td>
1478
  <td>
1479
- <input type="text" name="slideshow_dots_active_border_color" id="slideshow_dots_active_border_color" value="<?php echo $row->slideshow_dots_active_border_color; ?>" class="color"/>
1480
  </td>
1481
  </tr>
1482
  </tbody>
@@ -1492,7 +1496,7 @@ class ThemesView_bwg extends AdminView_bwg {
1492
  <tr>
1493
  <td class="spider_label"><label for="slideshow_title_background_color"><?php echo __('Title background color: ', BWG()->prefix); ?></label></td>
1494
  <td>
1495
- <input type="text" name="slideshow_title_background_color" id="slideshow_title_background_color" value="<?php echo $row->slideshow_title_background_color; ?>" class="color"/>
1496
  </td>
1497
  </tr>
1498
  <tr>
@@ -1525,7 +1529,7 @@ class ThemesView_bwg extends AdminView_bwg {
1525
  <tr>
1526
  <td class="spider_label"><label for="slideshow_title_color"><?php echo __('Title color: ', BWG()->prefix); ?></label></td>
1527
  <td>
1528
- <input type="text" name="slideshow_title_color" id="slideshow_title_color" value="<?php echo $row->slideshow_title_color; ?>" class="color"/>
1529
  </td>
1530
  </tr>
1531
  <tr>
@@ -1535,7 +1539,7 @@ class ThemesView_bwg extends AdminView_bwg {
1535
  <tr>
1536
  <td class="spider_label"><label for="slideshow_description_background_color"><?php echo __('Description background color:', BWG()->prefix); ?> </label></td>
1537
  <td>
1538
- <input type="text" name="slideshow_description_background_color" id="slideshow_description_background_color" value="<?php echo $row->slideshow_description_background_color; ?>" class="color"/>
1539
  </td>
1540
  </tr>
1541
  <tr>
@@ -1568,7 +1572,7 @@ class ThemesView_bwg extends AdminView_bwg {
1568
  <tr>
1569
  <td class="spider_label"><label for="slideshow_description_color"><?php echo __('Description color:', BWG()->prefix); ?> </label></td>
1570
  <td>
1571
- <input type="text" name="slideshow_description_color" id="slideshow_description_color" value="<?php echo $row->slideshow_description_color; ?>" class="color"/>
1572
  </td>
1573
  </tr>
1574
  <tr>
@@ -1599,7 +1603,7 @@ class ThemesView_bwg extends AdminView_bwg {
1599
  <tr>
1600
  <td class="spider_label"><label for="image_browser_full_bg_color"><?php echo __('Full background color:', BWG()->prefix); ?> </label></td>
1601
  <td>
1602
- <input type="text" name="image_browser_full_bg_color" id="image_browser_full_bg_color" value="<?php echo $row->image_browser_full_bg_color; ?>" class="color" />
1603
  </td>
1604
  </tr>
1605
  <tr>
@@ -1639,7 +1643,7 @@ class ThemesView_bwg extends AdminView_bwg {
1639
  <tr>
1640
  <td class="spider_label"><label for="image_browser_full_border_color"><?php echo __('Full border color:', BWG()->prefix); ?> </label></td>
1641
  <td>
1642
- <input type="text" name="image_browser_full_border_color" id="image_browser_full_border_color" value="<?php echo $row->image_browser_full_border_color; ?>" class="color" />
1643
  </td>
1644
  </tr>
1645
  </tbody>
@@ -1703,7 +1707,7 @@ class ThemesView_bwg extends AdminView_bwg {
1703
  <tr>
1704
  <td class="spider_label"><label for="image_browser_border_color"><?php echo __('Border color:', BWG()->prefix); ?> </label></td>
1705
  <td>
1706
- <input type="text" name="image_browser_border_color" id="image_browser_border_color" value="<?php echo $row->image_browser_border_color; ?>" class="color" />
1707
  </td>
1708
  </tr>
1709
  <tr>
@@ -1716,7 +1720,7 @@ class ThemesView_bwg extends AdminView_bwg {
1716
  <tr>
1717
  <td class="spider_label"><label for="image_browser_bg_color"><?php echo __('Background color:', BWG()->prefix); ?> </label></td>
1718
  <td>
1719
- <input type="text" name="image_browser_bg_color" id="image_browser_bg_color" value="<?php echo $row->image_browser_bg_color; ?>" class="color" />
1720
  </td>
1721
  </tr>
1722
  <tr>
@@ -1775,7 +1779,7 @@ class ThemesView_bwg extends AdminView_bwg {
1775
  <tr>
1776
  <td class="spider_label"><label for="image_browser_img_font_color"><?php echo __('Font color:', BWG()->prefix); ?> </label></td>
1777
  <td>
1778
- <input type="text" name="image_browser_img_font_color" id="image_browser_img_font_color" value="<?php echo $row->image_browser_img_font_color; ?>" class="color" />
1779
  </td>
1780
  </tr>
1781
  <tr>
@@ -1819,7 +1823,7 @@ class ThemesView_bwg extends AdminView_bwg {
1819
  <tr>
1820
  <td class="spider_label"><label for="image_browser_image_description_border_color"><?php echo __('Description border color:', BWG()->prefix); ?> </label></td>
1821
  <td>
1822
- <input type="text" name="image_browser_image_description_border_color" id="image_browser_image_description_border_color" value="<?php echo $row->image_browser_image_description_border_color; ?>" class="color" />
1823
  </td>
1824
  </tr>
1825
  <tr>
@@ -1832,7 +1836,7 @@ class ThemesView_bwg extends AdminView_bwg {
1832
  <tr>
1833
  <td class="spider_label"><label for="image_browser_image_description_bg_color"><?php echo __('Description background color:', BWG()->prefix); ?> </label></td>
1834
  <td>
1835
- <input type="text" name="image_browser_image_description_bg_color" id="image_browser_image_description_bg_color" value="<?php echo $row->image_browser_image_description_bg_color; ?>" class="color" />
1836
  </td>
1837
  </tr>
1838
  <tr>
@@ -1845,7 +1849,7 @@ class ThemesView_bwg extends AdminView_bwg {
1845
  <tr>
1846
  <td class="spider_label"><label for="image_browser_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
1847
  <td>
1848
- <input type="text" name="image_browser_gal_title_font_color" id="image_browser_gal_title_font_color" value="<?php echo $row->image_browser_gal_title_font_color; ?>" class="color" />
1849
  </td>
1850
  </tr>
1851
  <tr>
@@ -1954,7 +1958,7 @@ class ThemesView_bwg extends AdminView_bwg {
1954
  <tr>
1955
  <td class="spider_label"><label for="album_compact_thumb_border_color"><?php echo __('Border color:', BWG()->prefix); ?> </label></td>
1956
  <td>
1957
- <input type="text" name="album_compact_thumb_border_color" id="album_compact_thumb_border_color" value="<?php echo $row->album_compact_thumb_border_color; ?>" class="color" />
1958
  </td>
1959
  </tr>
1960
  <tr>
@@ -2014,7 +2018,7 @@ class ThemesView_bwg extends AdminView_bwg {
2014
  <tr>
2015
  <td class="spider_label"><label for="album_compact_thumb_bg_color"><?php echo __('Thumbnail background color:', BWG()->prefix); ?> </label></td>
2016
  <td>
2017
- <input type="text" name="album_compact_thumb_bg_color" id="album_compact_thumb_bg_color" value="<?php echo $row->album_compact_thumb_bg_color; ?>" class="color" />
2018
  </td>
2019
  </tr>
2020
  <tr>
@@ -2034,7 +2038,7 @@ class ThemesView_bwg extends AdminView_bwg {
2034
  <tr>
2035
  <td class="spider_label"><label for="album_compact_thumbs_bg_color"><?php echo __('Full background color:', BWG()->prefix); ?> </label></td>
2036
  <td>
2037
- <input type="text" name="album_compact_thumbs_bg_color" id="album_compact_thumbs_bg_color" value="<?php echo $row->album_compact_thumbs_bg_color; ?>" class="color" />
2038
  </td>
2039
  </tr>
2040
  <tr>
@@ -2086,13 +2090,13 @@ class ThemesView_bwg extends AdminView_bwg {
2086
  <tr>
2087
  <td class="spider_label"><label for="album_compact_title_font_color"><?php echo __('Title font color:', BWG()->prefix); ?> </label></td>
2088
  <td>
2089
- <input type="text" name="album_compact_title_font_color" id="album_compact_title_font_color" value="<?php echo $row->album_compact_title_font_color; ?>" class="color" />
2090
  </td>
2091
  </tr>
2092
  <tr>
2093
  <td class="spider_label"><label for="album_compact_title_font_color_hover"><?php echo __('Title font color (Show on hover):', BWG()->prefix); ?> </label></td>
2094
  <td>
2095
- <input type="text" name="album_compact_title_font_color_hover" id="album_compact_title_font_color_hover" value="<?php echo $row->album_compact_title_font_color_hover; ?>" class="color" />
2096
  </td>
2097
  </tr>
2098
  <tr>
@@ -2136,7 +2140,7 @@ class ThemesView_bwg extends AdminView_bwg {
2136
  <tr>
2137
  <td class="spider_label"><label for="album_compact_back_font_color"><?php echo __('Back Font color:', BWG()->prefix); ?> </label></td>
2138
  <td>
2139
- <input type="text" name="album_compact_back_font_color" id="album_compact_back_font_color" value="<?php echo $row->album_compact_back_font_color; ?>" class="color" />
2140
  </td>
2141
  </tr>
2142
  <tr>
@@ -2173,7 +2177,7 @@ class ThemesView_bwg extends AdminView_bwg {
2173
  <tr>
2174
  <td class="spider_label"><label for="album_compact_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
2175
  <td>
2176
- <input type="text" name="album_compact_gal_title_font_color" id="album_compact_gal_title_font_color" value="<?php echo $row->album_compact_gal_title_font_color; ?>" class="color" />
2177
  </td>
2178
  </tr>
2179
  <tr>
@@ -2271,7 +2275,7 @@ class ThemesView_bwg extends AdminView_bwg {
2271
  <tr>
2272
  <td class="spider_label"><label for="album_extended_thumb_border_color"><?php echo __('Thumbnail border color:', BWG()->prefix); ?> </label></td>
2273
  <td>
2274
- <input type="text" name="album_extended_thumb_border_color" id="album_extended_thumb_border_color" value="<?php echo $row->album_extended_thumb_border_color; ?>" class="color"/>
2275
  </td>
2276
  </tr>
2277
  <tr>
@@ -2342,13 +2346,13 @@ class ThemesView_bwg extends AdminView_bwg {
2342
  <tr>
2343
  <td class="spider_label"><label for="album_extended_thumb_bg_color"><?php echo __('Thumbnail background color:', BWG()->prefix); ?> </label></td>
2344
  <td>
2345
- <input type="text" name="album_extended_thumb_bg_color" id="album_extended_thumb_bg_color" value="<?php echo $row->album_extended_thumb_bg_color; ?>" class="color"/>
2346
  </td>
2347
  </tr>
2348
  <tr>
2349
  <td class="spider_label"><label for="album_extended_thumbs_bg_color"><?php echo __('Thumbnails background color:', BWG()->prefix); ?> </label></td>
2350
  <td>
2351
- <input type="text" name="album_extended_thumbs_bg_color" id="album_extended_thumbs_bg_color" value="<?php echo $row->album_extended_thumbs_bg_color; ?>" class="color"/>
2352
  </td>
2353
  </tr>
2354
  <tr>
@@ -2379,7 +2383,7 @@ class ThemesView_bwg extends AdminView_bwg {
2379
  <tr>
2380
  <td class="spider_label"><label for="album_extended_thumb_div_bg_color"><?php echo __('Thumbnail div background color:', BWG()->prefix); ?> </label></td>
2381
  <td>
2382
- <input type="text" name="album_extended_thumb_div_bg_color" id="album_extended_thumb_div_bg_color" value="<?php echo $row->album_extended_thumb_div_bg_color; ?>" class="color"/>
2383
  </td>
2384
  </tr>
2385
  <tr>
@@ -2406,7 +2410,7 @@ class ThemesView_bwg extends AdminView_bwg {
2406
  <tr>
2407
  <td class="spider_label"><label for="album_extended_thumb_div_border_color"><?php echo __('Thumbnail div border color:', BWG()->prefix); ?> </label></td>
2408
  <td>
2409
- <input type="text" name="album_extended_thumb_div_border_color" id="album_extended_thumb_div_border_color" value="<?php echo $row->album_extended_thumb_div_border_color; ?>" class="color"/>
2410
  </td>
2411
  </tr>
2412
  <tr>
@@ -2432,7 +2436,7 @@ class ThemesView_bwg extends AdminView_bwg {
2432
  <tr>
2433
  <td class="spider_label"><label for="album_extended_div_bg_color"><?php echo __('Background color:', BWG()->prefix); ?> </label></td>
2434
  <td>
2435
- <input type="text" name="album_extended_div_bg_color" id="album_extended_div_bg_color" value="<?php echo $row->album_extended_div_bg_color; ?>" class="color"/>
2436
  </td>
2437
  </tr>
2438
  <tr>
@@ -2472,7 +2476,7 @@ class ThemesView_bwg extends AdminView_bwg {
2472
  <tr>
2473
  <td class="spider_label"><label for="album_extended_div_separator_color"><?php echo __('Separator color:', BWG()->prefix); ?> </label></td>
2474
  <td>
2475
- <input type="text" name="album_extended_div_separator_color" id="album_extended_div_separator_color" value="<?php echo $row->album_extended_div_separator_color; ?>" class="color"/>
2476
  </td>
2477
  </tr>
2478
  <tr>
@@ -2491,7 +2495,7 @@ class ThemesView_bwg extends AdminView_bwg {
2491
  <tr>
2492
  <td class="spider_label"><label for="album_extended_back_font_color"><?php echo __('Back font color:', BWG()->prefix); ?> </label></td>
2493
  <td>
2494
- <input type="text" name="album_extended_back_font_color" id="album_extended_back_font_color" value="<?php echo $row->album_extended_back_font_color; ?>" class="color"/>
2495
  </td>
2496
  </tr>
2497
  <tr>
@@ -2566,7 +2570,7 @@ class ThemesView_bwg extends AdminView_bwg {
2566
  <tr>
2567
  <td class="spider_label"><label for="album_extended_text_div_border_color"><?php echo __('Text border color:', BWG()->prefix); ?> </label></td>
2568
  <td>
2569
- <input type="text" name="album_extended_text_div_border_color" id="album_extended_text_div_border_color" value="<?php echo $row->album_extended_text_div_border_color; ?>" class="color"/>
2570
  </td>
2571
  </tr>
2572
  <tr>
@@ -2579,7 +2583,7 @@ class ThemesView_bwg extends AdminView_bwg {
2579
  <tr>
2580
  <td class="spider_label"><label for="album_extended_text_div_bg_color"><?php echo __('Text background color:', BWG()->prefix); ?> </label></td>
2581
  <td>
2582
- <input type="text" name="album_extended_text_div_bg_color" id="album_extended_text_div_bg_color" value="<?php echo $row->album_extended_text_div_bg_color; ?>" class="color"/>
2583
  </td>
2584
  </tr>
2585
  <tr>
@@ -2618,7 +2622,7 @@ class ThemesView_bwg extends AdminView_bwg {
2618
  <tr>
2619
  <td class="spider_label"><label for="album_extended_title_span_border_color"><?php echo __('Title border color:', BWG()->prefix); ?> </label></td>
2620
  <td>
2621
- <input type="text" name="album_extended_title_span_border_color" id="album_extended_title_span_border_color" value="<?php echo $row->album_extended_title_span_border_color; ?>" class="color"/>
2622
  </td>
2623
  </tr>
2624
  <tr>
@@ -2630,7 +2634,7 @@ class ThemesView_bwg extends AdminView_bwg {
2630
  <tr>
2631
  <td class="spider_label"><label for="album_extended_title_font_color"><?php echo __('Title font color:', BWG()->prefix); ?> </label></td>
2632
  <td>
2633
- <input type="text" name="album_extended_title_font_color" id="album_extended_title_font_color" value="<?php echo $row->album_extended_title_font_color; ?>" class="color"/>
2634
  </td>
2635
  </tr>
2636
  <tr>
@@ -2681,7 +2685,7 @@ class ThemesView_bwg extends AdminView_bwg {
2681
  <tr>
2682
  <td class="spider_label"><label for="album_extended_desc_span_border_color"><?php echo __('Description border color:', BWG()->prefix); ?> </label></td>
2683
  <td>
2684
- <input type="text" name="album_extended_desc_span_border_color" id="album_extended_desc_span_border_color" value="<?php echo $row->album_extended_desc_span_border_color; ?>" class="color"/>
2685
  </td>
2686
  </tr>
2687
  <tr>
@@ -2693,7 +2697,7 @@ class ThemesView_bwg extends AdminView_bwg {
2693
  <tr>
2694
  <td class="spider_label"><label for="album_extended_desc_font_color"><?php echo __('Description font color:', BWG()->prefix); ?> </label></td>
2695
  <td>
2696
- <input type="text" name="album_extended_desc_font_color" id="album_extended_desc_font_color" value="<?php echo $row->album_extended_desc_font_color; ?>" class="color"/>
2697
  </td>
2698
  </tr>
2699
  <tr>
@@ -2723,7 +2727,7 @@ class ThemesView_bwg extends AdminView_bwg {
2723
  <tr>
2724
  <td class="spider_label"><label for="album_extended_desc_more_color"><?php echo __('Description more color:', BWG()->prefix); ?> </label></td>
2725
  <td>
2726
- <input type="text" name="album_extended_desc_more_color" id="album_extended_desc_more_color" value="<?php echo $row->album_extended_desc_more_color; ?>" class="color"/>
2727
  </td>
2728
  </tr>
2729
  <tr>
@@ -2735,7 +2739,7 @@ class ThemesView_bwg extends AdminView_bwg {
2735
  <tr>
2736
  <td class="spider_label"><label for="album_extended_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
2737
  <td>
2738
- <input type="text" name="album_extended_gal_title_font_color" id="album_extended_gal_title_font_color" value="<?php echo $row->album_extended_gal_title_font_color; ?>" class="color" />
2739
  </td>
2740
  </tr>
2741
  <tr>
@@ -2838,7 +2842,7 @@ class ThemesView_bwg extends AdminView_bwg {
2838
  <tr>
2839
  <td class="spider_label"><label for="album_masonry_thumb_border_color"><?php echo __('Border color:', BWG()->prefix); ?> </label></td>
2840
  <td>
2841
- <input type="text" name="album_masonry_thumb_border_color" id="album_masonry_thumb_border_color" value="<?php echo $row->album_masonry_thumb_border_color; ?>" class="color" />
2842
  </td>
2843
  </tr>
2844
  <tr>
@@ -2893,7 +2897,7 @@ class ThemesView_bwg extends AdminView_bwg {
2893
  <label for="album_masonry_thumb_bg_color"><?php echo __('Thumbnail background color:', BWG()->prefix); ?> </label>
2894
  </td>
2895
  <td>
2896
- <input type="text" name="album_masonry_thumb_bg_color" id="album_masonry_thumb_bg_color" value="<?php echo $row->album_masonry_thumb_bg_color; ?>" class="color" />
2897
  </td>
2898
  </tr>
2899
  <tr>
@@ -2906,7 +2910,7 @@ class ThemesView_bwg extends AdminView_bwg {
2906
  <tr>
2907
  <td class="spider_label"><label for="album_masonry_thumbs_bg_color"><?php echo __('Full background color:', BWG()->prefix); ?> </label></td>
2908
  <td>
2909
- <input type="text" name="album_masonry_thumbs_bg_color" id="album_masonry_thumbs_bg_color" value="<?php echo $row->album_masonry_thumbs_bg_color; ?>" class="color" />
2910
  </td>
2911
  </tr>
2912
  <tr>
@@ -2949,13 +2953,13 @@ class ThemesView_bwg extends AdminView_bwg {
2949
  <tr>
2950
  <td class="spider_label"><label for="album_masonry_title_font_color"><?php echo __('Title font color:', BWG()->prefix); ?> </label></td>
2951
  <td>
2952
- <input type="text" name="album_masonry_title_font_color" id="album_masonry_title_font_color" value="<?php echo $row->album_masonry_title_font_color; ?>" class="color" />
2953
  </td>
2954
  </tr>
2955
  <tr>
2956
  <td class="spider_label"><label for="album_masonry_thumb_title_font_color_hover"><?php echo __('Title font color (Show on hover):', BWG()->prefix); ?> </label></td>
2957
  <td>
2958
- <input type="text" name="album_masonry_thumb_title_font_color_hover" id="album_masonry_thumb_title_font_color_hover" value="<?php echo $row->album_masonry_thumb_title_font_color_hover; ?>" class="color" />
2959
  </td>
2960
  </tr>
2961
  <tr>
@@ -2992,7 +2996,7 @@ class ThemesView_bwg extends AdminView_bwg {
2992
  <tr>
2993
  <td class="spider_label"><label for="album_masonry_back_font_color"><?php echo __('Back Font color:', BWG()->prefix); ?> </label></td>
2994
  <td>
2995
- <input type="text" name="album_masonry_back_font_color" id="album_masonry_back_font_color" value="<?php echo $row->album_masonry_back_font_color; ?>" class="color" />
2996
  </td>
2997
  </tr>
2998
  <tr>
@@ -3029,7 +3033,7 @@ class ThemesView_bwg extends AdminView_bwg {
3029
  <tr>
3030
  <td class="spider_label"><label for="album_masonry_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
3031
  <td>
3032
- <input type="text" name="album_masonry_gal_title_font_color" id="album_masonry_gal_title_font_color" value="<?php echo $row->album_masonry_gal_title_font_color; ?>" class="color" />
3033
  </td>
3034
  </tr>
3035
  <tr>
@@ -3095,7 +3099,7 @@ class ThemesView_bwg extends AdminView_bwg {
3095
  <tr>
3096
  <td class="spider_label"><label for="blog_style_bg_color"><?php echo __('Background color:', BWG()->prefix); ?> </label></td>
3097
  <td>
3098
- <input type="text" name="blog_style_bg_color" id="blog_style_bg_color" value="<?php echo $row->blog_style_bg_color; ?>" class="color"/>
3099
  </td>
3100
  </tr>
3101
  <tr>
@@ -3163,7 +3167,7 @@ class ThemesView_bwg extends AdminView_bwg {
3163
  <tr>
3164
  <td class="spider_label"><label for="blog_style_img_font_color"><?php echo __('Font color:', BWG()->prefix); ?> </label></td>
3165
  <td>
3166
- <input type="text" name="blog_style_img_font_color" id="blog_style_img_font_color" value="<?php echo $row->blog_style_img_font_color; ?>" class="color"/>
3167
  </td>
3168
  </tr>
3169
  <tr>
@@ -3189,7 +3193,7 @@ class ThemesView_bwg extends AdminView_bwg {
3189
  <tr>
3190
  <td class="spider_label"><label for="blog_style_border_color"><?php echo __('Border color:', BWG()->prefix); ?> </label></td>
3191
  <td>
3192
- <input type="text" name="blog_style_border_color" id="blog_style_border_color" value="<?php echo $row->blog_style_border_color; ?>" class="color" />
3193
  </td>
3194
  </tr>
3195
  <tr>
@@ -3225,7 +3229,7 @@ class ThemesView_bwg extends AdminView_bwg {
3225
  <tr>
3226
  <td class="spider_label"><label for="blog_style_share_buttons_color"><?php echo __('Buttons color:', BWG()->prefix); ?> </label></td>
3227
  <td>
3228
- <input type="text" name="blog_style_share_buttons_color" id="blog_style_share_buttons_color" value="<?php echo $row->blog_style_share_buttons_color; ?>" class="color"/>
3229
  </td>
3230
  </tr>
3231
  <tr>
@@ -3251,7 +3255,7 @@ class ThemesView_bwg extends AdminView_bwg {
3251
  <tr>
3252
  <td class="spider_label"><label for="blog_style_share_buttons_border_color"><?php echo __('Buttons and title border color:', BWG()->prefix); ?> </label></td>
3253
  <td>
3254
- <input type="text" name="blog_style_share_buttons_border_color" id="blog_style_share_buttons_border_color" value="<?php echo $row->blog_style_share_buttons_border_color; ?>" class="color"/>
3255
  </td>
3256
  </tr>
3257
  <tr>
@@ -3264,7 +3268,7 @@ class ThemesView_bwg extends AdminView_bwg {
3264
  <tr>
3265
  <td class="spider_label"><label for="blog_style_share_buttons_bg_color"><?php echo __('Buttons and title background color:', BWG()->prefix); ?> </label></td>
3266
  <td>
3267
- <input type="text" name="blog_style_share_buttons_bg_color" id="blog_style_share_buttons_bg_color" value="<?php echo $row->blog_style_share_buttons_bg_color; ?>" class="color"/>
3268
  </td>
3269
  </tr>
3270
  <tr>
@@ -3298,7 +3302,7 @@ class ThemesView_bwg extends AdminView_bwg {
3298
  <tr>
3299
  <td class="spider_label"><label for="blog_style_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
3300
  <td>
3301
- <input type="text" name="blog_style_gal_title_font_color" id="blog_style_gal_title_font_color" value="<?php echo $row->blog_style_gal_title_font_color; ?>" class="color" />
3302
  </td>
3303
  </tr>
3304
  <tr>
@@ -3364,7 +3368,7 @@ class ThemesView_bwg extends AdminView_bwg {
3364
  <tr id="lightbox_overlay_bg">
3365
  <td class="spider_label"><label for="lightbox_overlay_bg_color"><?php echo __('Overlay background color:', BWG()->prefix); ?> </label></td>
3366
  <td>
3367
- <input type="text" name="lightbox_overlay_bg_color" id="lightbox_overlay_bg_color" value="<?php echo $row->lightbox_overlay_bg_color; ?>" class="color"/>
3368
  </td>
3369
  </tr>
3370
  <tr id="lightbox_overlay">
@@ -3377,7 +3381,7 @@ class ThemesView_bwg extends AdminView_bwg {
3377
  <tr id="lightbox_bg">
3378
  <td class="spider_label"><label for="lightbox_bg_color"><?php echo __('Lightbox background color:', BWG()->prefix); ?> </label></td>
3379
  <td>
3380
- <input type="text" name="lightbox_bg_color" id="lightbox_bg_color" value="<?php echo $row->lightbox_bg_color; ?>" class="color"/>
3381
  </td>
3382
  </tr>
3383
  <tr id="lightbox_transparency">
@@ -3417,7 +3421,7 @@ class ThemesView_bwg extends AdminView_bwg {
3417
  <tr id="lightbox_cntrl8">
3418
  <td class="spider_label"><label for="lightbox_ctrl_cont_bg_color"><?php echo __('Control buttons background color:', BWG()->prefix); ?> </label></td>
3419
  <td>
3420
- <input type="text" name="lightbox_ctrl_cont_bg_color" id="lightbox_ctrl_cont_bg_color" value="<?php echo $row->lightbox_ctrl_cont_bg_color; ?>" class="color"/>
3421
  </td>
3422
  </tr>
3423
  <tr id="lightbox_cntrl5">
@@ -3451,7 +3455,7 @@ class ThemesView_bwg extends AdminView_bwg {
3451
  <tr id="lightbox_cntrl7">
3452
  <td class="spider_label"><label for="lightbox_ctrl_btn_color"><?php echo __('Control buttons color:', BWG()->prefix); ?> </label></td>
3453
  <td>
3454
- <input type="text" name="lightbox_ctrl_btn_color" id="lightbox_ctrl_btn_color" value="<?php echo $row->lightbox_ctrl_btn_color; ?>" class="color"/>
3455
  </td>
3456
  </tr>
3457
  <tr id="lightbox_cntrl4">
@@ -3504,7 +3508,7 @@ class ThemesView_bwg extends AdminView_bwg {
3504
  <tr id="lightbox_close13">
3505
  <td class="spider_label"><label for="lightbox_close_btn_border_color"><?php echo __('Close button border color:', BWG()->prefix); ?> </label></td>
3506
  <td>
3507
- <input type="text" name="lightbox_close_btn_border_color" id="lightbox_close_btn_border_color" value="<?php echo $row->lightbox_close_btn_border_color; ?>" class="color"/>
3508
  </td>
3509
  </tr>
3510
  <tr id="lightbox_close3">
@@ -3517,7 +3521,7 @@ class ThemesView_bwg extends AdminView_bwg {
3517
  <tr id="lightbox_close11">
3518
  <td class="spider_label"><label for="lightbox_close_btn_bg_color"><?php echo __('Close button background color:', BWG()->prefix); ?> </label></td>
3519
  <td>
3520
- <input type="text" name="lightbox_close_btn_bg_color" id="lightbox_close_btn_bg_color" value="<?php echo $row->lightbox_close_btn_bg_color; ?>" class="color"/>
3521
  <div class="spider_description"><?php echo __('The option does not apply to Full-width lightbox.', BWG()->prefix); ?></div>
3522
  </td>
3523
  </tr>
@@ -3564,19 +3568,19 @@ class ThemesView_bwg extends AdminView_bwg {
3564
  <tr id="lightbox_close14">
3565
  <td class="spider_label"><label for="lightbox_close_btn_color"><?php echo __('Close button color:', BWG()->prefix); ?> </label></td>
3566
  <td>
3567
- <input type="text" name="lightbox_close_btn_color" id="lightbox_close_btn_color" value="<?php echo $row->lightbox_close_btn_color; ?>" class="color"/>
3568
  </td>
3569
  </tr>
3570
  <tr id="lightbox_close10">
3571
  <td class="spider_label"><label for="lightbox_close_btn_full_color"><?php echo __('Fullscreen close button color:', BWG()->prefix); ?> </label></td>
3572
  <td>
3573
- <input type="text" name="lightbox_close_btn_full_color" id="lightbox_close_btn_full_color" value="<?php echo $row->lightbox_close_btn_full_color; ?>" class="color"/>
3574
  </td>
3575
  </tr>
3576
  <tr id="lightbox_comment24">
3577
  <td class="spider_label"><label for="lightbox_comment_share_button_color"><?php echo __('Share buttons color:', BWG()->prefix); ?> </label></td>
3578
  <td>
3579
- <input type="text" name="lightbox_comment_share_button_color" id="lightbox_comment_share_button_color" value="<?php echo $row->lightbox_comment_share_button_color; ?>" class="color" />
3580
  </td>
3581
  </tr>
3582
  </tbody>
@@ -3606,7 +3610,7 @@ class ThemesView_bwg extends AdminView_bwg {
3606
  <tr id="lightbox_right_left7">
3607
  <td class="spider_label"><label for="lightbox_rl_btn_bg_color"><?php echo __('Right, left buttons background color:', BWG()->prefix); ?> </label></td>
3608
  <td>
3609
- <input type="text" name="lightbox_rl_btn_bg_color" id="lightbox_rl_btn_bg_color" value="<?php echo $row->lightbox_rl_btn_bg_color; ?>" class="color"/>
3610
  </td>
3611
  </tr>
3612
  <tr>
@@ -3643,13 +3647,13 @@ class ThemesView_bwg extends AdminView_bwg {
3643
  <tr id="lightbox_close15">
3644
  <td class="spider_label"><label for="lightbox_close_rl_btn_hover_color"><?php echo __('Right, left, close buttons hover color:', BWG()->prefix); ?> </label></td>
3645
  <td>
3646
- <input type="text" name="lightbox_close_rl_btn_hover_color" id="lightbox_close_rl_btn_hover_color" value="<?php echo $row->lightbox_close_rl_btn_hover_color; ?>" class="color" />
3647
  </td>
3648
  </tr>
3649
  <tr id="lightbox_right_left10">
3650
  <td class="spider_label"><label for="lightbox_rl_btn_color"><?php echo __('Right, left buttons color:', BWG()->prefix); ?> </label></td>
3651
  <td>
3652
- <input type="text" name="lightbox_rl_btn_color" id="lightbox_rl_btn_color" value="<?php echo $row->lightbox_rl_btn_color; ?>" class="color"/>
3653
  </td>
3654
  </tr>
3655
  <tr id="lightbox_right_left1">
@@ -3682,7 +3686,7 @@ class ThemesView_bwg extends AdminView_bwg {
3682
  <tr id="lightbox_right_left9">
3683
  <td class="spider_label"><label for="lightbox_rl_btn_border_color"><?php echo __('Right, left buttons border color:', BWG()->prefix); ?> </label></td>
3684
  <td>
3685
- <input type="text" name="lightbox_rl_btn_border_color" id="lightbox_rl_btn_border_color" value="<?php echo $row->lightbox_rl_btn_border_color; ?>" class="color"/>
3686
  </td>
3687
  </tr>
3688
  <tr id="lightbox_filmstrip12">
@@ -3726,7 +3730,7 @@ class ThemesView_bwg extends AdminView_bwg {
3726
  <tr id="lightbox_filmstrip10">
3727
  <td class="spider_label"><label for="lightbox_filmstrip_thumb_border_color"><?php echo __('Filmstrip thumbnail border color:', BWG()->prefix); ?> </label></td>
3728
  <td>
3729
- <input type="text" name="lightbox_filmstrip_thumb_border_color" id="lightbox_filmstrip_thumb_border_color" value="<?php echo $row->lightbox_filmstrip_thumb_border_color; ?>" class="color" />
3730
  </td>
3731
  </tr>
3732
  <tr id="lightbox_filmstrip4">
@@ -3745,7 +3749,7 @@ class ThemesView_bwg extends AdminView_bwg {
3745
  <tr id="lightbox_filmstrip11">
3746
  <td class="spider_label"> <label for="lightbox_filmstrip_thumb_active_border_color"><?php echo __('Filmstrip thumbnail active border color:', BWG()->prefix); ?></label></td>
3747
  <td>
3748
- <input type="text" name="lightbox_filmstrip_thumb_active_border_color" id="lightbox_filmstrip_thumb_active_border_color" value="<?php echo $row->lightbox_filmstrip_thumb_active_border_color; ?>" class="color"/>
3749
  </td>
3750
  </tr>
3751
  <tr id="lightbox_filmstrip5">
@@ -3764,13 +3768,13 @@ class ThemesView_bwg extends AdminView_bwg {
3764
  <tr id="lightbox_filmstrip7">
3765
  <td class="spider_label"><label for="lightbox_filmstrip_rl_btn_color"><?php echo __('Filmstrip right, left buttons color:', BWG()->prefix); ?> </label></td>
3766
  <td>
3767
- <input type="text" name="lightbox_filmstrip_rl_btn_color" id="lightbox_filmstrip_rl_btn_color" value="<?php echo $row->lightbox_filmstrip_rl_btn_color; ?>" class="color"/>
3768
  </td>
3769
  </tr>
3770
  <tr id="lightbox_filmstrip8">
3771
  <td class="spider_label"><label for="lightbox_filmstrip_rl_bg_color"><?php echo __('Filmstrip right, left button background color:', BWG()->prefix); ?></label></td>
3772
  <td>
3773
- <input type="text" name="lightbox_filmstrip_rl_bg_color" id="lightbox_filmstrip_rl_bg_color" value="<?php echo $row->lightbox_filmstrip_rl_bg_color; ?>" class="color"/>
3774
  </td>
3775
  </tr>
3776
  <tr>
@@ -3813,13 +3817,13 @@ class ThemesView_bwg extends AdminView_bwg {
3813
  <tr>
3814
  <td class="spider_label"><label for="lightbox_rate_color"><?php echo __('Rating color:', BWG()->prefix); ?> </label></td>
3815
  <td>
3816
- <input type="text" name="lightbox_rate_color" id="lightbox_rate_color" value="<?php echo $row->lightbox_rate_color; ?>" class="color"/>
3817
  </td>
3818
  </tr>
3819
  <tr>
3820
  <td class="spider_label"><label for="lightbox_rate_hover_color"><?php echo __('Rating hover color:', BWG()->prefix); ?> </label></td>
3821
  <td>
3822
- <input type="text" name="lightbox_rate_hover_color" id="lightbox_rate_hover_color" value="<?php echo $row->lightbox_rate_hover_color; ?>" class="color"/>
3823
  </td>
3824
  </tr>
3825
  <tr>
@@ -3867,7 +3871,7 @@ class ThemesView_bwg extends AdminView_bwg {
3867
  <tr>
3868
  <td class="spider_label"><label for="lightbox_hit_bg_color"><?php echo __('Hit counter background color:', BWG()->prefix); ?> </label></td>
3869
  <td>
3870
- <input type="text" name="lightbox_hit_bg_color" id="lightbox_hit_bg_color" value="<?php echo $row->lightbox_hit_bg_color; ?>" class="color"/>
3871
  </td>
3872
  </tr>
3873
  <tr>
@@ -3900,7 +3904,7 @@ class ThemesView_bwg extends AdminView_bwg {
3900
  <tr>
3901
  <td class="spider_label"><label for="lightbox_hit_border_color"><?php echo __('Hit counter border color:', BWG()->prefix); ?> </label></td>
3902
  <td>
3903
- <input type="text" name="lightbox_hit_border_color" id="lightbox_hit_border_color" value="<?php echo $row->lightbox_hit_border_color; ?>" class="color"/>
3904
  </td>
3905
  </tr>
3906
  <tr>
@@ -3927,7 +3931,7 @@ class ThemesView_bwg extends AdminView_bwg {
3927
  <tr>
3928
  <td class="spider_label"><label for="lightbox_hit_color"><?php echo __('Hit counter font color:', BWG()->prefix); ?> </label></td>
3929
  <td>
3930
- <input type="text" name="lightbox_hit_color" id="lightbox_hit_color" value="<?php echo $row->lightbox_hit_color; ?>" class="color"/>
3931
  </td>
3932
  </tr>
3933
  <tr>
@@ -3991,7 +3995,7 @@ class ThemesView_bwg extends AdminView_bwg {
3991
  <tr>
3992
  <td class="spider_label"><label for="lightbox_info_bg_color"><?php echo __('Info background color:', BWG()->prefix); ?> </label></td>
3993
  <td>
3994
- <input type="text" name="lightbox_info_bg_color" id="lightbox_info_bg_color" value="<?php echo $row->lightbox_info_bg_color; ?>" class="color"/>
3995
  </td>
3996
  </tr>
3997
  <tr>
@@ -4024,7 +4028,7 @@ class ThemesView_bwg extends AdminView_bwg {
4024
  <tr>
4025
  <td class="spider_label"><label for="lightbox_info_border_color"><?php echo __('Info border color:', BWG()->prefix); ?> </label></td>
4026
  <td>
4027
- <input type="text" name="lightbox_info_border_color" id="lightbox_info_border_color" value="<?php echo $row->lightbox_info_border_color; ?>" class="color"/>
4028
  </td>
4029
  </tr>
4030
  <tr>
@@ -4051,7 +4055,7 @@ class ThemesView_bwg extends AdminView_bwg {
4051
  <tr>
4052
  <td class="spider_label"><label for="lightbox_title_color"><?php echo __('Title font color:', BWG()->prefix); ?> </label></td>
4053
  <td>
4054
- <input type="text" name="lightbox_title_color" id="lightbox_title_color" value="<?php echo $row->lightbox_title_color; ?>" class="color"/>
4055
  </td>
4056
  </tr>
4057
  <tr>
@@ -4082,7 +4086,7 @@ class ThemesView_bwg extends AdminView_bwg {
4082
  <tr>
4083
  <td class="spider_label"><label for="lightbox_description_color"><?php echo __('Description font color:', BWG()->prefix); ?> </label></td>
4084
  <td>
4085
- <input type="text" name="lightbox_description_color" id="lightbox_description_color" value="<?php echo $row->lightbox_description_color; ?>" class="color"/>
4086
  </td>
4087
  </tr>
4088
  <tr>
@@ -4128,7 +4132,7 @@ class ThemesView_bwg extends AdminView_bwg {
4128
  <tr id="lightbox_comment13">
4129
  <td class="spider_label"><label for="lightbox_comment_bg_color"><?php echo __('Comments background color:', BWG()->prefix); ?> </label></td>
4130
  <td>
4131
- <input type="text" name="lightbox_comment_bg_color" id="lightbox_comment_bg_color" value="<?php echo $row->lightbox_comment_bg_color; ?>" class="color"/>
4132
  </td>
4133
  </tr>
4134
  <tr id="lightbox_comment2">
@@ -4140,7 +4144,7 @@ class ThemesView_bwg extends AdminView_bwg {
4140
  <tr id="lightbox_comment14">
4141
  <td class="spider_label"><label for="lightbox_comment_font_color"><?php echo __('Comments font color:', BWG()->prefix); ?></label></td>
4142
  <td>
4143
- <input type="text" name="lightbox_comment_font_color" id="lightbox_comment_font_color" value="<?php echo $row->lightbox_comment_font_color; ?>" class="color"/>
4144
  </td>
4145
  </tr>
4146
  <tr id="lightbox_comment15">
@@ -4189,7 +4193,7 @@ class ThemesView_bwg extends AdminView_bwg {
4189
  <tr id="lightbox_comment20">
4190
  <td class="spider_label"><label for="lightbox_comment_input_border_color"><?php echo __('Comment input border color:', BWG()->prefix); ?> </label></td>
4191
  <td>
4192
- <input type="text" name="lightbox_comment_input_border_color" id="lightbox_comment_input_border_color" value="<?php echo $row->lightbox_comment_input_border_color; ?>" class="color"/>
4193
  </td>
4194
  </tr>
4195
  <tr id="lightbox_comment7">
@@ -4208,13 +4212,13 @@ class ThemesView_bwg extends AdminView_bwg {
4208
  <tr id="lightbox_comment19">
4209
  <td class="spider_label"><label for="lightbox_comment_input_bg_color"><?php echo __('Comment input background color:', BWG()->prefix); ?> </label></td>
4210
  <td>
4211
- <input type="text" name="lightbox_comment_input_bg_color" id="lightbox_comment_input_bg_color" value="<?php echo $row->lightbox_comment_input_bg_color; ?>" class="color"/>
4212
  </td>
4213
  </tr>
4214
  <tr id="lightbox_comment16">
4215
  <td class="spider_label"><label for="lightbox_comment_button_bg_color"><?php echo __('Comment button background color:', BWG()->prefix); ?> </label></td>
4216
  <td>
4217
- <input type="text" name="lightbox_comment_button_bg_color" id="lightbox_comment_button_bg_color" value="<?php echo $row->lightbox_comment_button_bg_color; ?>" class="color"/>
4218
  </td>
4219
  </tr>
4220
  <tr id="lightbox_comment5">
@@ -4247,7 +4251,7 @@ class ThemesView_bwg extends AdminView_bwg {
4247
  <tr id="lightbox_comment17">
4248
  <td class="spider_label"><label for="lightbox_comment_button_border_color"><?php echo __('Comment button border color:', BWG()->prefix); ?> </label></td>
4249
  <td>
4250
- <input type="text" name="lightbox_comment_button_border_color" id="lightbox_comment_button_border_color" value="<?php echo $row->lightbox_comment_button_border_color; ?>" class="color"/>
4251
  </td>
4252
  </tr>
4253
  <tr id="lightbox_comment4">
@@ -4280,7 +4284,7 @@ class ThemesView_bwg extends AdminView_bwg {
4280
  <tr id="lightbox_comment23">
4281
  <td class="spider_label"><label for="lightbox_comment_separator_color"><?php echo __('Comment separator color:', BWG()->prefix); ?> </label></td>
4282
  <td>
4283
- <input type="text" name="lightbox_comment_separator_color" id="lightbox_comment_separator_color" value="<?php echo $row->lightbox_comment_separator_color; ?>" class="color"/>
4284
  </td>
4285
  </tr>
4286
  </tbody>
@@ -4306,7 +4310,7 @@ class ThemesView_bwg extends AdminView_bwg {
4306
  <tr>
4307
  <td class="spider_label"><label for="page_nav_font_color"><?php echo __('Font color:', BWG()->prefix); ?> </label></td>
4308
  <td>
4309
- <input type="text" name="page_nav_font_color" id="page_nav_font_color" value="<?php echo $row->page_nav_font_color; ?>" class="color"/>
4310
  </td>
4311
  </tr>
4312
  <tr>
@@ -4350,7 +4354,7 @@ class ThemesView_bwg extends AdminView_bwg {
4350
  <tr>
4351
  <td class="spider_label"><label for="page_nav_border_color"><?php echo __('Border color:', BWG()->prefix); ?></label></td>
4352
  <td>
4353
- <input type="text" name="page_nav_border_color" id="page_nav_border_color" value="<?php echo $row->page_nav_border_color; ?>" class="color"/>
4354
  </td>
4355
  </tr>
4356
  <tr>
@@ -4387,7 +4391,7 @@ class ThemesView_bwg extends AdminView_bwg {
4387
  <tr>
4388
  <td class="spider_label"><label for="page_nav_button_bg_color"><?php echo __('Button background color:', BWG()->prefix); ?> </label></td>
4389
  <td>
4390
- <input type="text" name="page_nav_button_bg_color" id="page_nav_button_bg_color" value="<?php echo $row->page_nav_button_bg_color; ?>" class="color" />
4391
  </td>
4392
  </tr>
4393
  <tr>
@@ -4482,7 +4486,7 @@ class ThemesView_bwg extends AdminView_bwg {
4482
  <tr>
4483
  <td class="spider_label"><label for="carousel_cont_bg_color"><?php echo __('Background color:', BWG()->prefix); ?> </label></td>
4484
  <td>
4485
- <input type="text" name="carousel_cont_bg_color" id="carousel_cont_bg_color" value="<?php echo $row->carousel_cont_bg_color; ?>" class="color"/>
4486
  </td>
4487
  </tr>
4488
  <tr>
@@ -4507,7 +4511,7 @@ class ThemesView_bwg extends AdminView_bwg {
4507
  <tr>
4508
  <td class="spider_label"><label for="carousel_rl_btn_color"><?php echo __('Buttons color:', BWG()->prefix); ?> </label></td>
4509
  <td>
4510
- <input type="text" name="carousel_rl_btn_color" id="carousel_rl_btn_color" value="<?php echo $row->carousel_rl_btn_color; ?>" class="color"/>
4511
  </td>
4512
  </tr>
4513
  <tr>
@@ -4520,7 +4524,7 @@ class ThemesView_bwg extends AdminView_bwg {
4520
  <tr>
4521
  <td class="spider_label"><label for="carousel_close_rl_btn_hover_color"><?php echo __('Buttons hover color:', BWG()->prefix); ?> </label></td>
4522
  <td>
4523
- <input type="text" name="carousel_close_rl_btn_hover_color" id="carousel_close_rl_btn_hover_color" value="<?php echo $row->carousel_close_rl_btn_hover_color; ?>" class="color"/>
4524
  </td>
4525
  </tr>
4526
  <tr>
@@ -4538,7 +4542,7 @@ class ThemesView_bwg extends AdminView_bwg {
4538
  <tr>
4539
  <td class="spider_label"><label for="carousel_rl_btn_bg_color"><?php echo __('Right, left buttons background color:', BWG()->prefix); ?> </label></td>
4540
  <td>
4541
- <input type="text" name="carousel_rl_btn_bg_color" id="carousel_rl_btn_bg_color" value="<?php echo $row->carousel_rl_btn_bg_color; ?>" class="color"/>
4542
  </td>
4543
  </tr>
4544
  <tr>
@@ -4564,7 +4568,7 @@ class ThemesView_bwg extends AdminView_bwg {
4564
  <tr>
4565
  <td class="spider_label"><label for="carousel_rl_btn_border_color"><?php echo __('Right, left buttons border color:', BWG()->prefix); ?> </label></td>
4566
  <td>
4567
- <input type="text" name="carousel_rl_btn_border_color" id="slideshow_rl_btn_border_color" value="<?php echo $row->carousel_rl_btn_border_color; ?>" class="color"/>
4568
  </td>
4569
  </tr>
4570
  <tr>
@@ -4629,7 +4633,7 @@ class ThemesView_bwg extends AdminView_bwg {
4629
  <tr>
4630
  <td class="spider_label"><label for="carousel_feature_border_color"><?php echo __('Image border color:', BWG()->prefix); ?> </label></td>
4631
  <td>
4632
- <input type="text" name="carousel_feature_border_color" id="carousel_feature_border_color" value="<?php echo $row->carousel_feature_border_color; ?>" class="color"/>
4633
  </td>
4634
  </tr>
4635
  </tbody>
@@ -4645,7 +4649,7 @@ class ThemesView_bwg extends AdminView_bwg {
4645
  <tr>
4646
  <td class="spider_label"><label for="carousel_caption_background_color"><?php echo __('Title background color:', BWG()->prefix); ?> </label></td>
4647
  <td>
4648
- <input type="text" name="carousel_caption_background_color" id="carousel_caption_background_color" value="<?php echo $row->carousel_caption_background_color; ?>" class="color"/>
4649
  </td>
4650
  </tr>
4651
 
@@ -4688,7 +4692,7 @@ class ThemesView_bwg extends AdminView_bwg {
4688
  <tr>
4689
  <td class="spider_label"><label for="carousel_caption_p_color"><?php echo __('Title color:', BWG()->prefix); ?> </label></td>
4690
  <td>
4691
- <input type="text" name="carousel_caption_p_color" id="carousel_caption_p_color" value="<?php echo $row->carousel_caption_p_color; ?>" class="color"/>
4692
  </td>
4693
  </tr>
4694
  <tr>
@@ -4715,7 +4719,7 @@ class ThemesView_bwg extends AdminView_bwg {
4715
  <tr>
4716
  <td class="spider_label"><label for="carousel_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
4717
  <td>
4718
- <input type="text" name="carousel_gal_title_font_color" id="carousel_gal_title_font_color" value="<?php echo $row->carousel_gal_title_font_color; ?>" class="color" />
4719
  </td>
4720
  </tr>
4721
  <tr>
@@ -4805,7 +4809,7 @@ class ThemesView_bwg extends AdminView_bwg {
4805
  </tr>
4806
  <tr>
4807
  <td class="spider_label"><label for="tags_but_font_color"><?php echo __('Font color:', BWG()->prefix); ?> </label></td>
4808
- <td><input type="text" name="tags_but_font_color" id="tags_but_font_color" value="<?php echo $row->tags_but_font_color; ?>" class="color"/></td>
4809
  </tr>
4810
  <tr>
4811
  <!--generate font style with google fonts -->
@@ -4853,7 +4857,7 @@ class ThemesView_bwg extends AdminView_bwg {
4853
  </tr>
4854
  <tr>
4855
  <td class="spider_label"><label for="tags_but_border_color"><?php echo __('Border color:', BWG()->prefix); ?></label></td>
4856
- <td><input type="text" name="tags_but_border_color" id="tags_but_border_color" value="<?php echo $row->tags_but_border_color; ?>" class="color"/></td>
4857
  </tr>
4858
  <tr>
4859
  <td class="spider_label"><label for="tags_but_border_radius"><?php echo __('Border radius:', BWG()->prefix); ?> </label></td>
@@ -4864,15 +4868,15 @@ class ThemesView_bwg extends AdminView_bwg {
4864
  </tr>
4865
  <tr>
4866
  <td class="spider_label"><label for="tags_but_bg_color"><?php echo __('Button background color:', BWG()->prefix); ?> </label></td>
4867
- <td><input type="text" name="tags_but_bg_color" id="tags_but_bg_color" value="<?php echo $row->tags_but_bg_color; ?>" class="color" /></td>
4868
  </tr>
4869
  <tr>
4870
  <td class="spider_label"><label for="tags_but_active_bg_color"><?php echo __('Active Button background color:', BWG()->prefix); ?> </label></td>
4871
- <td><input type="text" name="tags_but_active_bg_color" id="tags_but_active_bg_color" value="<?php echo $row->tags_but_active_bg_color; ?>" class="color" /></td>
4872
  </tr>
4873
  <tr>
4874
  <td class="spider_label"><label for="tags_but_active_color"><?php echo __('Active Button font color:', BWG()->prefix); ?> </label></td>
4875
- <td><input type="text" name="tags_but_active_color" id="tags_but_active_color" value="<?php echo $row->tags_but_active_color; ?>" class="color" /></td>
4876
  </tr>
4877
  <tr>
4878
  <td class="spider_label"><label for="tags_but_see_all_size"><?php echo __('See All Button Font size:', BWG()->prefix); ?> </label></td>
@@ -4882,11 +4886,11 @@ class ThemesView_bwg extends AdminView_bwg {
4882
  </tr>
4883
  <tr>
4884
  <td class="spider_label"><label for="tags_but_see_all_color"><?php echo __('See All Button Font color:', BWG()->prefix); ?> </label></td>
4885
- <td><input type="text" name="tags_but_see_all_color" id="tags_but_see_all_color" value="<?php echo $row->tags_but_see_all_color; ?>" class="color"/></td>
4886
  </tr>
4887
  <tr>
4888
  <td class="spider_label"><label for="tags_but_see_all_back_color"><?php echo __('See All Button background color:', BWG()->prefix); ?> </label></td>
4889
- <td><input type="text" name="tags_but_see_all_back_color" id="tags_but_see_all_back_color" value="<?php echo $row->tags_but_see_all_back_color; ?>" class="color" /></td>
4890
  </tr>
4891
  <tr>
4892
  <td class="spider_label"><label for="tags_but_see_all_border_w"><?php echo __('See All Button Border width:', BWG()->prefix); ?> </label></td>
@@ -4906,7 +4910,7 @@ class ThemesView_bwg extends AdminView_bwg {
4906
  </tr>
4907
  <tr>
4908
  <td class="spider_label"><label for="tags_but_see_all_border_c"><?php echo __('See All Button Border color:', BWG()->prefix); ?></label></td>
4909
- <td><input type="text" name="tags_but_see_all_border_c" id="tags_but_see_all_border_c" value="<?php echo $row->tags_but_see_all_border_c; ?>" class="color"/></td>
4910
  </tr>
4911
  <tr>
4912
  <td class="spider_label"><label for="tags_but_see_all_border_r"><?php echo __('See All Button Border radius:', BWG()->prefix); ?> </label></td>
260
  }
261
 
262
  /**
 
263
  * Generate row for font styles google fonts
264
+ *
265
+ * @param $saved_style
266
+ * @param $font_style
267
+ * @param $label_text
268
+ * @param $radio_name
269
  */
270
  public function font_style_row( $saved_style, $font_style, $label_text, $radio_name) {
271
  $google_fonts = WDWLibrary::get_google_fonts();
418
  <tr>
419
  <td class="spider_label"><label for="thumb_border_color"><?php echo __('Border color:', BWG()->prefix); ?></label></td>
420
  <td>
421
+ <input type="text" name="thumb_border_color" id="thumb_border_color" value="<?php echo $row->thumb_border_color; ?>" class="jscolor"/>
422
  </td>
423
  </tr>
424
  <tr>
477
  <tbody>
478
  <tr>
479
  <td class="spider_label">
480
+ <label for="thumb_bg_color"><?php echo __('Thumbnail background color:', BWG()->prefix); ?> </label>
481
  </td>
482
  <td>
483
+ <input type="text" name="thumb_bg_color" id="thumb_bg_color" value="<?php echo $row->thumb_bg_color; ?>" class="jscolor" />
484
  </td>
485
  </tr>
486
  <tr>
500
  <tr>
501
  <td class="spider_label"><label for="thumbs_bg_color"><?php echo __('Full background color:', BWG()->prefix); ?> </label></td>
502
  <td>
503
+ <input type="text" name="thumbs_bg_color" id="thumbs_bg_color" value="<?php echo $row->thumbs_bg_color; ?>" class="jscolor"/>
504
  </td>
505
  </tr>
506
  <tr>
552
  <tr>
553
  <td class="spider_label"><label for="thumb_title_font_color"><?php echo __('Title font color:', BWG()->prefix); ?> </label></td>
554
  <td>
555
+ <input type="text" name="thumb_title_font_color" id="thumb_title_font_color" value="<?php echo $row->thumb_title_font_color; ?>" class="jscolor" />
556
  </td>
557
  </tr>
558
  <tr>
559
  <td class="spider_label"><label for="thumb_title_font_color_hover"><?php echo __('Title font color (Show on hover):', BWG()->prefix); ?> </label></td>
560
  <td>
561
+ <input type="text" name="thumb_title_font_color_hover" id="thumb_title_font_color_hover" value="<?php echo $row->thumb_title_font_color_hover; ?>" class="jscolor" />
562
  </td>
563
  </tr>
564
  <tr>
603
  <tr>
604
  <td class="spider_label"><label for="thumb_description_font_color"><?php echo __('Thumb description font color:', BWG()->prefix); ?> </label></td>
605
  <td>
606
+ <input type="text" name="thumb_description_font_color" id="thumb_description_font_color" value="<?php echo $row->thumb_description_font_color; ?>" class="jscolor" />
607
  </td>
608
  </tr>
609
  <tr>
620
  <tr>
621
  <td class="spider_label"><label for="thumb_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
622
  <td>
623
+ <input type="text" name="thumb_gal_title_font_color" id="thumb_gal_title_font_color" value="<?php echo $row->thumb_gal_title_font_color; ?>" class="jscolor" />
624
  </td>
625
  </tr>
626
  <tr>
722
  <tr>
723
  <td class="spider_label"><label for="masonry_thumb_border_color"><?php echo __('Border color:', BWG()->prefix); ?> </label></td>
724
  <td>
725
+ <input type="text" name="masonry_thumb_border_color" id="masonry_thumb_border_color" value="<?php echo $row->masonry_thumb_border_color; ?>" class="jscolor" />
726
  </td>
727
  </tr>
728
  <tr>
777
  <label for="masonry_thumb_bg_color"><?php echo __('Thumbnail background color:', BWG()->prefix); ?> </label>
778
  </td>
779
  <td>
780
+ <input type="text" name="masonry_thumb_bg_color" id="masonry_thumb_bg_color" value="<?php echo $row->masonry_thumb_bg_color; ?>" class="jscolor" />
781
  </td>
782
  </tr>
783
  <tr>
797
  <tr>
798
  <td class="spider_label"><label for="masonry_thumbs_bg_color"><?php echo __('Full Background color:', BWG()->prefix); ?> </label></td>
799
  <td>
800
+ <input type="text" name="masonry_thumbs_bg_color" id="masonry_thumbs_bg_color" value="<?php echo $row->masonry_thumbs_bg_color; ?>" class="jscolor" />
801
  </td>
802
  </tr>
803
  <tr>
836
  <tr>
837
  <td class="spider_label"><label for="masonry_thumb_title_font_color"><?php echo __('Title font color:', BWG()->prefix); ?> </label></td>
838
  <td>
839
+ <input type="text" name="masonry_thumb_title_font_color" id="masonry_thumb_title_font_color" value="<?php echo $row->masonry_thumb_title_font_color; ?>" class="jscolor" />
840
  </td>
841
  </tr>
842
  <tr>
843
  <td class="spider_label"><label for="masonry_thumb_title_font_color_hover"><?php echo __('Title font color (Show on hover):', BWG()->prefix); ?> </label></td>
844
  <td>
845
+ <input type="text" name="masonry_thumb_title_font_color_hover" id="masonry_thumb_title_font_color_hover" value="<?php echo $row->masonry_thumb_title_font_color_hover; ?>" class="jscolor" />
846
  </td>
847
  </tr>
848
  <tr>
879
  <tr>
880
  <td class="spider_label"><label for="masonry_description_color"><?php echo __('Description font color:', BWG()->prefix); ?> </label></td>
881
  <td>
882
+ <input type="text" name="masonry_description_color" id="masonry_description_color" value="<?php echo $row->masonry_description_color; ?>" class="jscolor" />
883
  </td>
884
  </tr>
885
  <tr>
895
  <tr>
896
  <td class="spider_label"><label for="masonry_thumb_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
897
  <td>
898
+ <input type="text" name="masonry_thumb_gal_title_font_color" id="masonry_thumb_gal_title_font_color" value="<?php echo $row->masonry_thumb_gal_title_font_color; ?>" class="jscolor" />
899
  </td>
900
  </tr>
901
  <tr>
997
  <tr>
998
  <td class="spider_label"><label for="mosaic_thumb_border_color"><?php echo __('Border color:', BWG()->prefix); ?> </label></td>
999
  <td>
1000
+ <input type="text" name="mosaic_thumb_border_color" id="mosaic_thumb_border_color" value="<?php echo $row->mosaic_thumb_border_color; ?>" class="jscolor" />
1001
  </td>
1002
  </tr>
1003
  <tr>
1050
  <tr>
1051
  <td class="spider_label"><label for="mosaic_thumb_bg_color"><?php echo __('Thumbnail background color:', BWG()->prefix); ?> </label></td>
1052
  <td>
1053
+ <input type="text" name="mosaic_thumb_bg_color" id="mosaic_thumb_bg_color" value="<?php echo $row->mosaic_thumb_bg_color; ?>" class="jscolor" />
1054
  </td>
1055
  </tr>
1056
  <tr>
1070
  <tr>
1071
  <td class="spider_label"><label for="mosaic_thumbs_bg_color"><?php echo __('Full Background color:', BWG()->prefix); ?> </label></td>
1072
  <td>
1073
+ <input type="text" name="mosaic_thumbs_bg_color" id="mosaic_thumbs_bg_color" value="<?php echo $row->mosaic_thumbs_bg_color; ?>" class="jscolor" />
1074
  </td>
1075
  </tr>
1076
  <tr>
1113
  <tr>
1114
  <td class="spider_label"><label for="mosaic_thumb_title_font_color"><?php echo __('Title font color:', BWG()->prefix); ?> </label></td>
1115
  <td>
1116
+ <input type="text" name="mosaic_thumb_title_font_color" id="mosaic_thumb_title_font_color" value="<?php echo $row->mosaic_thumb_title_font_color; ?>" class="jscolor" />
1117
  </td>
1118
  </tr>
1119
  <tr>
1120
  <td class="spider_label"><label for="mosaic_thumb_title_font_color_hover"><?php echo __('Title font color (Show on hover):', BWG()->prefix); ?> </label></td>
1121
  <td>
1122
+ <input type="text" name="mosaic_thumb_title_font_color_hover" id="mosaic_thumb_title_font_color_hover" value="<?php echo $row->mosaic_thumb_title_font_color_hover; ?>" class="jscolor" />
1123
  </td>
1124
  </tr>
1125
  <tr>
1163
  <tr>
1164
  <td class="spider_label"><label for="mosaic_thumb_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
1165
  <td>
1166
+ <input type="text" name="mosaic_thumb_gal_title_font_color" id="mosaic_thumb_gal_title_font_color" value="<?php echo $row->mosaic_thumb_gal_title_font_color; ?>" class="jscolor" />
1167
  </td>
1168
  </tr>
1169
  <tr>
1229
  <tr>
1230
  <td class="spider_label"><label for="slideshow_cont_bg_color"><?php echo __('Background color:', BWG()->prefix); ?> </label></td>
1231
  <td>
1232
+ <input type="text" name="slideshow_cont_bg_color" id="slideshow_cont_bg_color" value="<?php echo $row->slideshow_cont_bg_color; ?>" class="jscolor"/>
1233
  </td>
1234
  </tr>
1235
  <tr>
1247
  <tr>
1248
  <td class="spider_label"><label for="slideshow_rl_btn_color"><?php echo __('Buttons color:', BWG()->prefix); ?> </label></td>
1249
  <td>
1250
+ <input type="text" name="slideshow_rl_btn_color" id="slideshow_rl_btn_color" value="<?php echo $row->slideshow_rl_btn_color; ?>" class="jscolor"/>
1251
  </td>
1252
  </tr>
1253
  <tr>
1260
  <tr>
1261
  <td class="spider_label"><label for="slideshow_close_rl_btn_hover_color"><?php echo __('Buttons hover color:', BWG()->prefix); ?> </label></td>
1262
  <td>
1263
+ <input type="text" name="slideshow_close_rl_btn_hover_color" id="slideshow_close_rl_btn_hover_color" value="<?php echo $row->slideshow_close_rl_btn_hover_color; ?>" class="jscolor"/>
1264
  </td>
1265
  </tr>
1266
  <tr>
1278
  <tr>
1279
  <td class="spider_label"><label for="slideshow_rl_btn_bg_color"><?php echo __('Right, left buttons background color:', BWG()->prefix); ?> </label></td>
1280
  <td>
1281
+ <input type="text" name="slideshow_rl_btn_bg_color" id="slideshow_rl_btn_bg_color" value="<?php echo $row->slideshow_rl_btn_bg_color; ?>" class="jscolor"/>
1282
  </td>
1283
  </tr>
1284
  <tr>
1304
  <tr>
1305
  <td class="spider_label"><label for="slideshow_rl_btn_border_color"><?php echo __('Right, left buttons border color:', BWG()->prefix); ?> </label></td>
1306
  <td>
1307
+ <input type="text" name="slideshow_rl_btn_border_color" id="slideshow_rl_btn_border_color" value="<?php echo $row->slideshow_rl_btn_border_color; ?>" class="jscolor"/>
1308
  </td>
1309
  </tr>
1310
  <tr>
1387
  <tr>
1388
  <td class="spider_label"><label for="slideshow_filmstrip_thumb_border_color"><?php echo __('Filmstrip border color:', BWG()->prefix); ?> </label></td>
1389
  <td>
1390
+ <input type="text" name="slideshow_filmstrip_thumb_border_color" id="slideshow_filmstrip_thumb_border_color" value="<?php echo $row->slideshow_filmstrip_thumb_border_color; ?>" class="jscolor"/>
1391
  </td>
1392
  </tr>
1393
  <tr>
1406
  <tr>
1407
  <td class="spider_label"><label for="slideshow_filmstrip_thumb_active_border_color"><?php echo __('Filmstrip active border color:', BWG()->prefix); ?> </label></td>
1408
  <td>
1409
+ <input type="text" name="slideshow_filmstrip_thumb_active_border_color" id="slideshow_filmstrip_thumb_active_border_color" value="<?php echo $row->slideshow_filmstrip_thumb_active_border_color; ?>" class="jscolor"/>
1410
  </td>
1411
  </tr>
1412
  <tr id="tr_appWidth">
1419
  <tr>
1420
  <td class="spider_label"><label for="slideshow_filmstrip_rl_bg_color"><?php echo __('Filmstrip right, left buttons background color: ', BWG()->prefix); ?></label></td>
1421
  <td>
1422
+ <input type="text" name="slideshow_filmstrip_rl_bg_color" id="slideshow_filmstrip_rl_bg_color" value="<?php echo $row->slideshow_filmstrip_rl_bg_color; ?>" class="jscolor"/>
1423
  </td>
1424
  </tr>
1425
  <tr>
1426
  <td class="spider_label"><label for="slideshow_filmstrip_rl_btn_color"><?php echo __('Filmstrip right, left buttons color:', BWG()->prefix); ?> </label></td>
1427
  <td>
1428
+ <input type="text" name="slideshow_filmstrip_rl_btn_color" id="slideshow_filmstrip_rl_btn_color" value="<?php echo $row->slideshow_filmstrip_rl_btn_color; ?>" class="jscolor"/>
1429
  </td>
1430
  </tr>
1431
  <tr>
1456
  <tr>
1457
  <td class="spider_label"><label for="slideshow_dots_background_color"><?php echo __('Slider bullet background color:', BWG()->prefix); ?> </label></td>
1458
  <td>
1459
+ <input type="text" name="slideshow_dots_background_color" id="slideshow_dots_background_color" value="<?php echo $row->slideshow_dots_background_color; ?>" class="jscolor"/>
1460
  </td>
1461
  </tr>
1462
  <tr>
1468
  <tr>
1469
  <td class="spider_label"><label for="slideshow_dots_active_background_color"><?php echo __('Slider bullet active background color: ', BWG()->prefix); ?></label></td>
1470
  <td>
1471
+ <input type="text" name="slideshow_dots_active_background_color" id="slideshow_dots_active_background_color" value="<?php echo $row->slideshow_dots_active_background_color; ?>" class="jscolor"/>
1472
  </td>
1473
  </tr>
1474
  <tr>
1480
  <tr>
1481
  <td class="spider_label"><label for="slideshow_dots_active_border_color"><?php echo __('Slider bullet active border color: ', BWG()->prefix); ?></label></td>
1482
  <td>
1483
+ <input type="text" name="slideshow_dots_active_border_color" id="slideshow_dots_active_border_color" value="<?php echo $row->slideshow_dots_active_border_color; ?>" class="jscolor"/>
1484
  </td>
1485
  </tr>
1486
  </tbody>
1496
  <tr>
1497
  <td class="spider_label"><label for="slideshow_title_background_color"><?php echo __('Title background color: ', BWG()->prefix); ?></label></td>
1498
  <td>
1499
+ <input type="text" name="slideshow_title_background_color" id="slideshow_title_background_color" value="<?php echo $row->slideshow_title_background_color; ?>" class="jscolor"/>
1500
  </td>
1501
  </tr>
1502
  <tr>
1529
  <tr>
1530
  <td class="spider_label"><label for="slideshow_title_color"><?php echo __('Title color: ', BWG()->prefix); ?></label></td>
1531
  <td>
1532
+ <input type="text" name="slideshow_title_color" id="slideshow_title_color" value="<?php echo $row->slideshow_title_color; ?>" class="jscolor"/>
1533
  </td>
1534
  </tr>
1535
  <tr>
1539
  <tr>
1540
  <td class="spider_label"><label for="slideshow_description_background_color"><?php echo __('Description background color:', BWG()->prefix); ?> </label></td>
1541
  <td>
1542
+ <input type="text" name="slideshow_description_background_color" id="slideshow_description_background_color" value="<?php echo $row->slideshow_description_background_color; ?>" class="jscolor"/>
1543
  </td>
1544
  </tr>
1545
  <tr>
1572
  <tr>
1573
  <td class="spider_label"><label for="slideshow_description_color"><?php echo __('Description color:', BWG()->prefix); ?> </label></td>
1574
  <td>
1575
+ <input type="text" name="slideshow_description_color" id="slideshow_description_color" value="<?php echo $row->slideshow_description_color; ?>" class="jscolor"/>
1576
  </td>
1577
  </tr>
1578
  <tr>
1603
  <tr>
1604
  <td class="spider_label"><label for="image_browser_full_bg_color"><?php echo __('Full background color:', BWG()->prefix); ?> </label></td>
1605
  <td>
1606
+ <input type="text" name="image_browser_full_bg_color" id="image_browser_full_bg_color" value="<?php echo $row->image_browser_full_bg_color; ?>" class="jscolor" />
1607
  </td>
1608
  </tr>
1609
  <tr>
1643
  <tr>
1644
  <td class="spider_label"><label for="image_browser_full_border_color"><?php echo __('Full border color:', BWG()->prefix); ?> </label></td>
1645
  <td>
1646
+ <input type="text" name="image_browser_full_border_color" id="image_browser_full_border_color" value="<?php echo $row->image_browser_full_border_color; ?>" class="jscolor" />
1647
  </td>
1648
  </tr>
1649
  </tbody>
1707
  <tr>
1708
  <td class="spider_label"><label for="image_browser_border_color"><?php echo __('Border color:', BWG()->prefix); ?> </label></td>
1709
  <td>
1710
+ <input type="text" name="image_browser_border_color" id="image_browser_border_color" value="<?php echo $row->image_browser_border_color; ?>" class="jscolor" />
1711
  </td>
1712
  </tr>
1713
  <tr>
1720
  <tr>
1721
  <td class="spider_label"><label for="image_browser_bg_color"><?php echo __('Background color:', BWG()->prefix); ?> </label></td>
1722
  <td>
1723
+ <input type="text" name="image_browser_bg_color" id="image_browser_bg_color" value="<?php echo $row->image_browser_bg_color; ?>" class="jscolor" />
1724
  </td>
1725
  </tr>
1726
  <tr>
1779
  <tr>
1780
  <td class="spider_label"><label for="image_browser_img_font_color"><?php echo __('Font color:', BWG()->prefix); ?> </label></td>
1781
  <td>
1782
+ <input type="text" name="image_browser_img_font_color" id="image_browser_img_font_color" value="<?php echo $row->image_browser_img_font_color; ?>" class="jscolor" />
1783
  </td>
1784
  </tr>
1785
  <tr>
1823
  <tr>
1824
  <td class="spider_label"><label for="image_browser_image_description_border_color"><?php echo __('Description border color:', BWG()->prefix); ?> </label></td>
1825
  <td>
1826
+ <input type="text" name="image_browser_image_description_border_color" id="image_browser_image_description_border_color" value="<?php echo $row->image_browser_image_description_border_color; ?>" class="jscolor" />
1827
  </td>
1828
  </tr>
1829
  <tr>
1836
  <tr>
1837
  <td class="spider_label"><label for="image_browser_image_description_bg_color"><?php echo __('Description background color:', BWG()->prefix); ?> </label></td>
1838
  <td>
1839
+ <input type="text" name="image_browser_image_description_bg_color" id="image_browser_image_description_bg_color" value="<?php echo $row->image_browser_image_description_bg_color; ?>" class="jscolor" />
1840
  </td>
1841
  </tr>
1842
  <tr>
1849
  <tr>
1850
  <td class="spider_label"><label for="image_browser_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
1851
  <td>
1852
+ <input type="text" name="image_browser_gal_title_font_color" id="image_browser_gal_title_font_color" value="<?php echo $row->image_browser_gal_title_font_color; ?>" class="jscolor" />
1853
  </td>
1854
  </tr>
1855
  <tr>
1958
  <tr>
1959
  <td class="spider_label"><label for="album_compact_thumb_border_color"><?php echo __('Border color:', BWG()->prefix); ?> </label></td>
1960
  <td>
1961
+ <input type="text" name="album_compact_thumb_border_color" id="album_compact_thumb_border_color" value="<?php echo $row->album_compact_thumb_border_color; ?>" class="jscolor" />
1962
  </td>
1963
  </tr>
1964
  <tr>
2018
  <tr>
2019
  <td class="spider_label"><label for="album_compact_thumb_bg_color"><?php echo __('Thumbnail background color:', BWG()->prefix); ?> </label></td>
2020
  <td>
2021
+ <input type="text" name="album_compact_thumb_bg_color" id="album_compact_thumb_bg_color" value="<?php echo $row->album_compact_thumb_bg_color; ?>" class="jscolor" />
2022
  </td>
2023
  </tr>
2024
  <tr>
2038
  <tr>
2039
  <td class="spider_label"><label for="album_compact_thumbs_bg_color"><?php echo __('Full background color:', BWG()->prefix); ?> </label></td>
2040
  <td>
2041
+ <input type="text" name="album_compact_thumbs_bg_color" id="album_compact_thumbs_bg_color" value="<?php echo $row->album_compact_thumbs_bg_color; ?>" class="jscolor" />
2042
  </td>
2043
  </tr>
2044
  <tr>
2090
  <tr>
2091
  <td class="spider_label"><label for="album_compact_title_font_color"><?php echo __('Title font color:', BWG()->prefix); ?> </label></td>
2092
  <td>
2093
+ <input type="text" name="album_compact_title_font_color" id="album_compact_title_font_color" value="<?php echo $row->album_compact_title_font_color; ?>" class="jscolor" />
2094
  </td>
2095
  </tr>
2096
  <tr>
2097
  <td class="spider_label"><label for="album_compact_title_font_color_hover"><?php echo __('Title font color (Show on hover):', BWG()->prefix); ?> </label></td>
2098
  <td>
2099
+ <input type="text" name="album_compact_title_font_color_hover" id="album_compact_title_font_color_hover" value="<?php echo $row->album_compact_title_font_color_hover; ?>" class="jscolor" />
2100
  </td>
2101
  </tr>
2102
  <tr>
2140
  <tr>
2141
  <td class="spider_label"><label for="album_compact_back_font_color"><?php echo __('Back Font color:', BWG()->prefix); ?> </label></td>
2142
  <td>
2143
+ <input type="text" name="album_compact_back_font_color" id="album_compact_back_font_color" value="<?php echo $row->album_compact_back_font_color; ?>" class="jscolor" />
2144
  </td>
2145
  </tr>
2146
  <tr>
2177
  <tr>
2178
  <td class="spider_label"><label for="album_compact_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
2179
  <td>
2180
+ <input type="text" name="album_compact_gal_title_font_color" id="album_compact_gal_title_font_color" value="<?php echo $row->album_compact_gal_title_font_color; ?>" class="jscolor" />
2181
  </td>
2182
  </tr>
2183
  <tr>
2275
  <tr>
2276
  <td class="spider_label"><label for="album_extended_thumb_border_color"><?php echo __('Thumbnail border color:', BWG()->prefix); ?> </label></td>
2277
  <td>
2278
+ <input type="text" name="album_extended_thumb_border_color" id="album_extended_thumb_border_color" value="<?php echo $row->album_extended_thumb_border_color; ?>" class="jscolor"/>
2279
  </td>
2280
  </tr>
2281
  <tr>
2346
  <tr>
2347
  <td class="spider_label"><label for="album_extended_thumb_bg_color"><?php echo __('Thumbnail background color:', BWG()->prefix); ?> </label></td>
2348
  <td>
2349
+ <input type="text" name="album_extended_thumb_bg_color" id="album_extended_thumb_bg_color" value="<?php echo $row->album_extended_thumb_bg_color; ?>" class="jscolor"/>
2350
  </td>
2351
  </tr>
2352
  <tr>
2353
  <td class="spider_label"><label for="album_extended_thumbs_bg_color"><?php echo __('Thumbnails background color:', BWG()->prefix); ?> </label></td>
2354
  <td>
2355
+ <input type="text" name="album_extended_thumbs_bg_color" id="album_extended_thumbs_bg_color" value="<?php echo $row->album_extended_thumbs_bg_color; ?>" class="jscolor"/>
2356
  </td>
2357
  </tr>
2358
  <tr>
2383
  <tr>
2384
  <td class="spider_label"><label for="album_extended_thumb_div_bg_color"><?php echo __('Thumbnail div background color:', BWG()->prefix); ?> </label></td>
2385
  <td>
2386
+ <input type="text" name="album_extended_thumb_div_bg_color" id="album_extended_thumb_div_bg_color" value="<?php echo $row->album_extended_thumb_div_bg_color; ?>" class="jscolor"/>
2387
  </td>
2388
  </tr>
2389
  <tr>
2410
  <tr>
2411
  <td class="spider_label"><label for="album_extended_thumb_div_border_color"><?php echo __('Thumbnail div border color:', BWG()->prefix); ?> </label></td>
2412
  <td>
2413
+ <input type="text" name="album_extended_thumb_div_border_color" id="album_extended_thumb_div_border_color" value="<?php echo $row->album_extended_thumb_div_border_color; ?>" class="jscolor"/>
2414
  </td>
2415
  </tr>
2416
  <tr>
2436
  <tr>
2437
  <td class="spider_label"><label for="album_extended_div_bg_color"><?php echo __('Background color:', BWG()->prefix); ?> </label></td>
2438
  <td>
2439
+ <input type="text" name="album_extended_div_bg_color" id="album_extended_div_bg_color" value="<?php echo $row->album_extended_div_bg_color; ?>" class="jscolor"/>
2440
  </td>
2441
  </tr>
2442
  <tr>
2476
  <tr>
2477
  <td class="spider_label"><label for="album_extended_div_separator_color"><?php echo __('Separator color:', BWG()->prefix); ?> </label></td>
2478
  <td>
2479
+ <input type="text" name="album_extended_div_separator_color" id="album_extended_div_separator_color" value="<?php echo $row->album_extended_div_separator_color; ?>" class="jscolor"/>
2480
  </td>
2481
  </tr>
2482
  <tr>
2495
  <tr>
2496
  <td class="spider_label"><label for="album_extended_back_font_color"><?php echo __('Back font color:', BWG()->prefix); ?> </label></td>
2497
  <td>
2498
+ <input type="text" name="album_extended_back_font_color" id="album_extended_back_font_color" value="<?php echo $row->album_extended_back_font_color; ?>" class="jscolor"/>
2499
  </td>
2500
  </tr>
2501
  <tr>
2570
  <tr>
2571
  <td class="spider_label"><label for="album_extended_text_div_border_color"><?php echo __('Text border color:', BWG()->prefix); ?> </label></td>
2572
  <td>
2573
+ <input type="text" name="album_extended_text_div_border_color" id="album_extended_text_div_border_color" value="<?php echo $row->album_extended_text_div_border_color; ?>" class="jscolor"/>
2574
  </td>
2575
  </tr>
2576
  <tr>
2583
  <tr>
2584
  <td class="spider_label"><label for="album_extended_text_div_bg_color"><?php echo __('Text background color:', BWG()->prefix); ?> </label></td>
2585
  <td>
2586
+ <input type="text" name="album_extended_text_div_bg_color" id="album_extended_text_div_bg_color" value="<?php echo $row->album_extended_text_div_bg_color; ?>" class="jscolor"/>
2587
  </td>
2588
  </tr>
2589
  <tr>
2622
  <tr>
2623
  <td class="spider_label"><label for="album_extended_title_span_border_color"><?php echo __('Title border color:', BWG()->prefix); ?> </label></td>
2624
  <td>
2625
+ <input type="text" name="album_extended_title_span_border_color" id="album_extended_title_span_border_color" value="<?php echo $row->album_extended_title_span_border_color; ?>" class="jscolor"/>
2626
  </td>
2627
  </tr>
2628
  <tr>
2634
  <tr>
2635
  <td class="spider_label"><label for="album_extended_title_font_color"><?php echo __('Title font color:', BWG()->prefix); ?> </label></td>
2636
  <td>
2637
+ <input type="text" name="album_extended_title_font_color" id="album_extended_title_font_color" value="<?php echo $row->album_extended_title_font_color; ?>" class="jscolor"/>
2638
  </td>
2639
  </tr>
2640
  <tr>
2685
  <tr>
2686
  <td class="spider_label"><label for="album_extended_desc_span_border_color"><?php echo __('Description border color:', BWG()->prefix); ?> </label></td>
2687
  <td>
2688
+ <input type="text" name="album_extended_desc_span_border_color" id="album_extended_desc_span_border_color" value="<?php echo $row->album_extended_desc_span_border_color; ?>" class="jscolor"/>
2689
  </td>
2690
  </tr>
2691
  <tr>
2697
  <tr>
2698
  <td class="spider_label"><label for="album_extended_desc_font_color"><?php echo __('Description font color:', BWG()->prefix); ?> </label></td>
2699
  <td>
2700
+ <input type="text" name="album_extended_desc_font_color" id="album_extended_desc_font_color" value="<?php echo $row->album_extended_desc_font_color; ?>" class="jscolor"/>
2701
  </td>
2702
  </tr>
2703
  <tr>
2727
  <tr>
2728
  <td class="spider_label"><label for="album_extended_desc_more_color"><?php echo __('Description more color:', BWG()->prefix); ?> </label></td>
2729
  <td>
2730
+ <input type="text" name="album_extended_desc_more_color" id="album_extended_desc_more_color" value="<?php echo $row->album_extended_desc_more_color; ?>" class="jscolor"/>
2731
  </td>
2732
  </tr>
2733
  <tr>
2739
  <tr>
2740
  <td class="spider_label"><label for="album_extended_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
2741
  <td>
2742
+ <input type="text" name="album_extended_gal_title_font_color" id="album_extended_gal_title_font_color" value="<?php echo $row->album_extended_gal_title_font_color; ?>" class="jscolor" />
2743
  </td>
2744
  </tr>
2745
  <tr>
2842
  <tr>
2843
  <td class="spider_label"><label for="album_masonry_thumb_border_color"><?php echo __('Border color:', BWG()->prefix); ?> </label></td>
2844
  <td>
2845
+ <input type="text" name="album_masonry_thumb_border_color" id="album_masonry_thumb_border_color" value="<?php echo $row->album_masonry_thumb_border_color; ?>" class="jscolor" />
2846
  </td>
2847
  </tr>
2848
  <tr>
2897
  <label for="album_masonry_thumb_bg_color"><?php echo __('Thumbnail background color:', BWG()->prefix); ?> </label>
2898
  </td>
2899
  <td>
2900
+ <input type="text" name="album_masonry_thumb_bg_color" id="album_masonry_thumb_bg_color" value="<?php echo $row->album_masonry_thumb_bg_color; ?>" class="jscolor" />
2901
  </td>
2902
  </tr>
2903
  <tr>
2910
  <tr>
2911
  <td class="spider_label"><label for="album_masonry_thumbs_bg_color"><?php echo __('Full background color:', BWG()->prefix); ?> </label></td>
2912
  <td>
2913
+ <input type="text" name="album_masonry_thumbs_bg_color" id="album_masonry_thumbs_bg_color" value="<?php echo $row->album_masonry_thumbs_bg_color; ?>" class="jscolor" />
2914
  </td>
2915
  </tr>
2916
  <tr>
2953
  <tr>
2954
  <td class="spider_label"><label for="album_masonry_title_font_color"><?php echo __('Title font color:', BWG()->prefix); ?> </label></td>
2955
  <td>
2956
+ <input type="text" name="album_masonry_title_font_color" id="album_masonry_title_font_color" value="<?php echo $row->album_masonry_title_font_color; ?>" class="jscolor" />
2957
  </td>
2958
  </tr>
2959
  <tr>
2960
  <td class="spider_label"><label for="album_masonry_thumb_title_font_color_hover"><?php echo __('Title font color (Show on hover):', BWG()->prefix); ?> </label></td>
2961
  <td>
2962
+ <input type="text" name="album_masonry_thumb_title_font_color_hover" id="album_masonry_thumb_title_font_color_hover" value="<?php echo $row->album_masonry_thumb_title_font_color_hover; ?>" class="jscolor" />
2963
  </td>
2964
  </tr>
2965
  <tr>
2996
  <tr>
2997
  <td class="spider_label"><label for="album_masonry_back_font_color"><?php echo __('Back Font color:', BWG()->prefix); ?> </label></td>
2998
  <td>
2999
+ <input type="text" name="album_masonry_back_font_color" id="album_masonry_back_font_color" value="<?php echo $row->album_masonry_back_font_color; ?>" class="jscolor" />
3000
  </td>
3001
  </tr>
3002
  <tr>
3033
  <tr>
3034
  <td class="spider_label"><label for="album_masonry_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
3035
  <td>
3036
+ <input type="text" name="album_masonry_gal_title_font_color" id="album_masonry_gal_title_font_color" value="<?php echo $row->album_masonry_gal_title_font_color; ?>" class="jscolor" />
3037
  </td>
3038
  </tr>
3039
  <tr>
3099
  <tr>
3100
  <td class="spider_label"><label for="blog_style_bg_color"><?php echo __('Background color:', BWG()->prefix); ?> </label></td>
3101
  <td>
3102
+ <input type="text" name="blog_style_bg_color" id="blog_style_bg_color" value="<?php echo $row->blog_style_bg_color; ?>" class="jscolor"/>
3103
  </td>
3104
  </tr>
3105
  <tr>
3167
  <tr>
3168
  <td class="spider_label"><label for="blog_style_img_font_color"><?php echo __('Font color:', BWG()->prefix); ?> </label></td>
3169
  <td>
3170
+ <input type="text" name="blog_style_img_font_color" id="blog_style_img_font_color" value="<?php echo $row->blog_style_img_font_color; ?>" class="jscolor"/>
3171
  </td>
3172
  </tr>
3173
  <tr>
3193
  <tr>
3194
  <td class="spider_label"><label for="blog_style_border_color"><?php echo __('Border color:', BWG()->prefix); ?> </label></td>
3195
  <td>
3196
+ <input type="text" name="blog_style_border_color" id="blog_style_border_color" value="<?php echo $row->blog_style_border_color; ?>" class="jscolor" />
3197
  </td>
3198
  </tr>
3199
  <tr>
3229
  <tr>
3230
  <td class="spider_label"><label for="blog_style_share_buttons_color"><?php echo __('Buttons color:', BWG()->prefix); ?> </label></td>
3231
  <td>
3232
+ <input type="text" name="blog_style_share_buttons_color" id="blog_style_share_buttons_color" value="<?php echo $row->blog_style_share_buttons_color; ?>" class="jscolor"/>
3233
  </td>
3234
  </tr>
3235
  <tr>
3255
  <tr>
3256
  <td class="spider_label"><label for="blog_style_share_buttons_border_color"><?php echo __('Buttons and title border color:', BWG()->prefix); ?> </label></td>
3257
  <td>
3258
+ <input type="text" name="blog_style_share_buttons_border_color" id="blog_style_share_buttons_border_color" value="<?php echo $row->blog_style_share_buttons_border_color; ?>" class="jscolor"/>
3259
  </td>
3260
  </tr>
3261
  <tr>
3268
  <tr>
3269
  <td class="spider_label"><label for="blog_style_share_buttons_bg_color"><?php echo __('Buttons and title background color:', BWG()->prefix); ?> </label></td>
3270
  <td>
3271
+ <input type="text" name="blog_style_share_buttons_bg_color" id="blog_style_share_buttons_bg_color" value="<?php echo $row->blog_style_share_buttons_bg_color; ?>" class="jscolor"/>
3272
  </td>
3273
  </tr>
3274
  <tr>
3302
  <tr>
3303
  <td class="spider_label"><label for="blog_style_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
3304
  <td>
3305
+ <input type="text" name="blog_style_gal_title_font_color" id="blog_style_gal_title_font_color" value="<?php echo $row->blog_style_gal_title_font_color; ?>" class="jscolor" />
3306
  </td>
3307
  </tr>
3308
  <tr>
3368
  <tr id="lightbox_overlay_bg">
3369
  <td class="spider_label"><label for="lightbox_overlay_bg_color"><?php echo __('Overlay background color:', BWG()->prefix); ?> </label></td>
3370
  <td>
3371
+ <input type="text" name="lightbox_overlay_bg_color" id="lightbox_overlay_bg_color" value="<?php echo $row->lightbox_overlay_bg_color; ?>" class="jscolor"/>
3372
  </td>
3373
  </tr>
3374
  <tr id="lightbox_overlay">
3381
  <tr id="lightbox_bg">
3382
  <td class="spider_label"><label for="lightbox_bg_color"><?php echo __('Lightbox background color:', BWG()->prefix); ?> </label></td>
3383
  <td>
3384
+ <input type="text" name="lightbox_bg_color" id="lightbox_bg_color" value="<?php echo $row->lightbox_bg_color; ?>" class="jscolor"/>
3385
  </td>
3386
  </tr>
3387
  <tr id="lightbox_transparency">
3421
  <tr id="lightbox_cntrl8">
3422
  <td class="spider_label"><label for="lightbox_ctrl_cont_bg_color"><?php echo __('Control buttons background color:', BWG()->prefix); ?> </label></td>
3423
  <td>
3424
+ <input type="text" name="lightbox_ctrl_cont_bg_color" id="lightbox_ctrl_cont_bg_color" value="<?php echo $row->lightbox_ctrl_cont_bg_color; ?>" class="jscolor"/>
3425
  </td>
3426
  </tr>
3427
  <tr id="lightbox_cntrl5">
3455
  <tr id="lightbox_cntrl7">
3456
  <td class="spider_label"><label for="lightbox_ctrl_btn_color"><?php echo __('Control buttons color:', BWG()->prefix); ?> </label></td>
3457
  <td>
3458
+ <input type="text" name="lightbox_ctrl_btn_color" id="lightbox_ctrl_btn_color" value="<?php echo $row->lightbox_ctrl_btn_color; ?>" class="jscolor"/>
3459
  </td>
3460
  </tr>
3461
  <tr id="lightbox_cntrl4">
3508
  <tr id="lightbox_close13">
3509
  <td class="spider_label"><label for="lightbox_close_btn_border_color"><?php echo __('Close button border color:', BWG()->prefix); ?> </label></td>
3510
  <td>
3511
+ <input type="text" name="lightbox_close_btn_border_color" id="lightbox_close_btn_border_color" value="<?php echo $row->lightbox_close_btn_border_color; ?>" class="jscolor"/>
3512
  </td>
3513
  </tr>
3514
  <tr id="lightbox_close3">
3521
  <tr id="lightbox_close11">
3522
  <td class="spider_label"><label for="lightbox_close_btn_bg_color"><?php echo __('Close button background color:', BWG()->prefix); ?> </label></td>
3523
  <td>
3524
+ <input type="text" name="lightbox_close_btn_bg_color" id="lightbox_close_btn_bg_color" value="<?php echo $row->lightbox_close_btn_bg_color; ?>" class="jscolor"/>
3525
  <div class="spider_description"><?php echo __('The option does not apply to Full-width lightbox.', BWG()->prefix); ?></div>
3526
  </td>
3527
  </tr>
3568
  <tr id="lightbox_close14">
3569
  <td class="spider_label"><label for="lightbox_close_btn_color"><?php echo __('Close button color:', BWG()->prefix); ?> </label></td>
3570
  <td>
3571
+ <input type="text" name="lightbox_close_btn_color" id="lightbox_close_btn_color" value="<?php echo $row->lightbox_close_btn_color; ?>" class="jscolor"/>
3572
  </td>
3573
  </tr>
3574
  <tr id="lightbox_close10">
3575
  <td class="spider_label"><label for="lightbox_close_btn_full_color"><?php echo __('Fullscreen close button color:', BWG()->prefix); ?> </label></td>
3576
  <td>
3577
+ <input type="text" name="lightbox_close_btn_full_color" id="lightbox_close_btn_full_color" value="<?php echo $row->lightbox_close_btn_full_color; ?>" class="jscolor"/>
3578
  </td>
3579
  </tr>
3580
  <tr id="lightbox_comment24">
3581
  <td class="spider_label"><label for="lightbox_comment_share_button_color"><?php echo __('Share buttons color:', BWG()->prefix); ?> </label></td>
3582
  <td>
3583
+ <input type="text" name="lightbox_comment_share_button_color" id="lightbox_comment_share_button_color" value="<?php echo $row->lightbox_comment_share_button_color; ?>" class="jscolor" />
3584
  </td>
3585
  </tr>
3586
  </tbody>
3610
  <tr id="lightbox_right_left7">
3611
  <td class="spider_label"><label for="lightbox_rl_btn_bg_color"><?php echo __('Right, left buttons background color:', BWG()->prefix); ?> </label></td>
3612
  <td>
3613
+ <input type="text" name="lightbox_rl_btn_bg_color" id="lightbox_rl_btn_bg_color" value="<?php echo $row->lightbox_rl_btn_bg_color; ?>" class="jscolor"/>
3614
  </td>
3615
  </tr>
3616
  <tr>
3647
  <tr id="lightbox_close15">
3648
  <td class="spider_label"><label for="lightbox_close_rl_btn_hover_color"><?php echo __('Right, left, close buttons hover color:', BWG()->prefix); ?> </label></td>
3649
  <td>
3650
+ <input type="text" name="lightbox_close_rl_btn_hover_color" id="lightbox_close_rl_btn_hover_color" value="<?php echo $row->lightbox_close_rl_btn_hover_color; ?>" class="jscolor" />
3651
  </td>
3652
  </tr>
3653
  <tr id="lightbox_right_left10">
3654
  <td class="spider_label"><label for="lightbox_rl_btn_color"><?php echo __('Right, left buttons color:', BWG()->prefix); ?> </label></td>
3655
  <td>
3656
+ <input type="text" name="lightbox_rl_btn_color" id="lightbox_rl_btn_color" value="<?php echo $row->lightbox_rl_btn_color; ?>" class="jscolor"/>
3657
  </td>
3658
  </tr>
3659
  <tr id="lightbox_right_left1">
3686
  <tr id="lightbox_right_left9">
3687
  <td class="spider_label"><label for="lightbox_rl_btn_border_color"><?php echo __('Right, left buttons border color:', BWG()->prefix); ?> </label></td>
3688
  <td>
3689
+ <input type="text" name="lightbox_rl_btn_border_color" id="lightbox_rl_btn_border_color" value="<?php echo $row->lightbox_rl_btn_border_color; ?>" class="jscolor"/>
3690
  </td>
3691
  </tr>
3692
  <tr id="lightbox_filmstrip12">
3730
  <tr id="lightbox_filmstrip10">
3731
  <td class="spider_label"><label for="lightbox_filmstrip_thumb_border_color"><?php echo __('Filmstrip thumbnail border color:', BWG()->prefix); ?> </label></td>
3732
  <td>
3733
+ <input type="text" name="lightbox_filmstrip_thumb_border_color" id="lightbox_filmstrip_thumb_border_color" value="<?php echo $row->lightbox_filmstrip_thumb_border_color; ?>" class="jscolor" />
3734
  </td>
3735
  </tr>
3736
  <tr id="lightbox_filmstrip4">
3749
  <tr id="lightbox_filmstrip11">
3750
  <td class="spider_label"> <label for="lightbox_filmstrip_thumb_active_border_color"><?php echo __('Filmstrip thumbnail active border color:', BWG()->prefix); ?></label></td>
3751
  <td>
3752
+ <input type="text" name="lightbox_filmstrip_thumb_active_border_color" id="lightbox_filmstrip_thumb_active_border_color" value="<?php echo $row->lightbox_filmstrip_thumb_active_border_color; ?>" class="jscolor"/>
3753
  </td>
3754
  </tr>
3755
  <tr id="lightbox_filmstrip5">
3768
  <tr id="lightbox_filmstrip7">
3769
  <td class="spider_label"><label for="lightbox_filmstrip_rl_btn_color"><?php echo __('Filmstrip right, left buttons color:', BWG()->prefix); ?> </label></td>
3770
  <td>
3771
+ <input type="text" name="lightbox_filmstrip_rl_btn_color" id="lightbox_filmstrip_rl_btn_color" value="<?php echo $row->lightbox_filmstrip_rl_btn_color; ?>" class="jscolor"/>
3772
  </td>
3773
  </tr>
3774
  <tr id="lightbox_filmstrip8">
3775
  <td class="spider_label"><label for="lightbox_filmstrip_rl_bg_color"><?php echo __('Filmstrip right, left button background color:', BWG()->prefix); ?></label></td>
3776
  <td>
3777
+ <input type="text" name="lightbox_filmstrip_rl_bg_color" id="lightbox_filmstrip_rl_bg_color" value="<?php echo $row->lightbox_filmstrip_rl_bg_color; ?>" class="jscolor"/>
3778
  </td>
3779
  </tr>
3780
  <tr>
3817
  <tr>
3818
  <td class="spider_label"><label for="lightbox_rate_color"><?php echo __('Rating color:', BWG()->prefix); ?> </label></td>
3819
  <td>
3820
+ <input type="text" name="lightbox_rate_color" id="lightbox_rate_color" value="<?php echo $row->lightbox_rate_color; ?>" class="jscolor"/>
3821
  </td>
3822
  </tr>
3823
  <tr>
3824
  <td class="spider_label"><label for="lightbox_rate_hover_color"><?php echo __('Rating hover color:', BWG()->prefix); ?> </label></td>
3825
  <td>
3826
+ <input type="text" name="lightbox_rate_hover_color" id="lightbox_rate_hover_color" value="<?php echo $row->lightbox_rate_hover_color; ?>" class="jscolor"/>
3827
  </td>
3828
  </tr>
3829
  <tr>
3871
  <tr>
3872
  <td class="spider_label"><label for="lightbox_hit_bg_color"><?php echo __('Hit counter background color:', BWG()->prefix); ?> </label></td>
3873
  <td>
3874
+ <input type="text" name="lightbox_hit_bg_color" id="lightbox_hit_bg_color" value="<?php echo $row->lightbox_hit_bg_color; ?>" class="jscolor"/>
3875
  </td>
3876
  </tr>
3877
  <tr>
3904
  <tr>
3905
  <td class="spider_label"><label for="lightbox_hit_border_color"><?php echo __('Hit counter border color:', BWG()->prefix); ?> </label></td>
3906
  <td>
3907
+ <input type="text" name="lightbox_hit_border_color" id="lightbox_hit_border_color" value="<?php echo $row->lightbox_hit_border_color; ?>" class="jscolor"/>
3908
  </td>
3909
  </tr>
3910
  <tr>
3931
  <tr>
3932
  <td class="spider_label"><label for="lightbox_hit_color"><?php echo __('Hit counter font color:', BWG()->prefix); ?> </label></td>
3933
  <td>
3934
+ <input type="text" name="lightbox_hit_color" id="lightbox_hit_color" value="<?php echo $row->lightbox_hit_color; ?>" class="jscolor"/>
3935
  </td>
3936
  </tr>
3937
  <tr>
3995
  <tr>
3996
  <td class="spider_label"><label for="lightbox_info_bg_color"><?php echo __('Info background color:', BWG()->prefix); ?> </label></td>
3997
  <td>
3998
+ <input type="text" name="lightbox_info_bg_color" id="lightbox_info_bg_color" value="<?php echo $row->lightbox_info_bg_color; ?>" class="jscolor"/>
3999
  </td>
4000
  </tr>
4001
  <tr>
4028
  <tr>
4029
  <td class="spider_label"><label for="lightbox_info_border_color"><?php echo __('Info border color:', BWG()->prefix); ?> </label></td>
4030
  <td>
4031
+ <input type="text" name="lightbox_info_border_color" id="lightbox_info_border_color" value="<?php echo $row->lightbox_info_border_color; ?>" class="jscolor"/>
4032
  </td>
4033
  </tr>
4034
  <tr>
4055
  <tr>
4056
  <td class="spider_label"><label for="lightbox_title_color"><?php echo __('Title font color:', BWG()->prefix); ?> </label></td>
4057
  <td>
4058
+ <input type="text" name="lightbox_title_color" id="lightbox_title_color" value="<?php echo $row->lightbox_title_color; ?>" class="jscolor"/>
4059
  </td>
4060
  </tr>
4061
  <tr>
4086
  <tr>
4087
  <td class="spider_label"><label for="lightbox_description_color"><?php echo __('Description font color:', BWG()->prefix); ?> </label></td>
4088
  <td>
4089
+ <input type="text" name="lightbox_description_color" id="lightbox_description_color" value="<?php echo $row->lightbox_description_color; ?>" class="jscolor"/>
4090
  </td>
4091
  </tr>
4092
  <tr>
4132
  <tr id="lightbox_comment13">
4133
  <td class="spider_label"><label for="lightbox_comment_bg_color"><?php echo __('Comments background color:', BWG()->prefix); ?> </label></td>
4134
  <td>
4135
+ <input type="text" name="lightbox_comment_bg_color" id="lightbox_comment_bg_color" value="<?php echo $row->lightbox_comment_bg_color; ?>" class="jscolor"/>
4136
  </td>
4137
  </tr>
4138
  <tr id="lightbox_comment2">
4144
  <tr id="lightbox_comment14">
4145
  <td class="spider_label"><label for="lightbox_comment_font_color"><?php echo __('Comments font color:', BWG()->prefix); ?></label></td>
4146
  <td>
4147
+ <input type="text" name="lightbox_comment_font_color" id="lightbox_comment_font_color" value="<?php echo $row->lightbox_comment_font_color; ?>" class="jscolor"/>
4148
  </td>
4149
  </tr>
4150
  <tr id="lightbox_comment15">
4193
  <tr id="lightbox_comment20">
4194
  <td class="spider_label"><label for="lightbox_comment_input_border_color"><?php echo __('Comment input border color:', BWG()->prefix); ?> </label></td>
4195
  <td>
4196
+ <input type="text" name="lightbox_comment_input_border_color" id="lightbox_comment_input_border_color" value="<?php echo $row->lightbox_comment_input_border_color; ?>" class="jscolor"/>
4197
  </td>
4198
  </tr>
4199
  <tr id="lightbox_comment7">
4212
  <tr id="lightbox_comment19">
4213
  <td class="spider_label"><label for="lightbox_comment_input_bg_color"><?php echo __('Comment input background color:', BWG()->prefix); ?> </label></td>
4214
  <td>
4215
+ <input type="text" name="lightbox_comment_input_bg_color" id="lightbox_comment_input_bg_color" value="<?php echo $row->lightbox_comment_input_bg_color; ?>" class="jscolor"/>
4216
  </td>
4217
  </tr>
4218
  <tr id="lightbox_comment16">
4219
  <td class="spider_label"><label for="lightbox_comment_button_bg_color"><?php echo __('Comment button background color:', BWG()->prefix); ?> </label></td>
4220
  <td>
4221
+ <input type="text" name="lightbox_comment_button_bg_color" id="lightbox_comment_button_bg_color" value="<?php echo $row->lightbox_comment_button_bg_color; ?>" class="jscolor"/>
4222
  </td>
4223
  </tr>
4224
  <tr id="lightbox_comment5">
4251
  <tr id="lightbox_comment17">
4252
  <td class="spider_label"><label for="lightbox_comment_button_border_color"><?php echo __('Comment button border color:', BWG()->prefix); ?> </label></td>
4253
  <td>
4254
+ <input type="text" name="lightbox_comment_button_border_color" id="lightbox_comment_button_border_color" value="<?php echo $row->lightbox_comment_button_border_color; ?>" class="jscolor"/>
4255
  </td>
4256
  </tr>
4257
  <tr id="lightbox_comment4">
4284
  <tr id="lightbox_comment23">
4285
  <td class="spider_label"><label for="lightbox_comment_separator_color"><?php echo __('Comment separator color:', BWG()->prefix); ?> </label></td>
4286
  <td>
4287
+ <input type="text" name="lightbox_comment_separator_color" id="lightbox_comment_separator_color" value="<?php echo $row->lightbox_comment_separator_color; ?>" class="jscolor"/>
4288
  </td>
4289
  </tr>
4290
  </tbody>
4310
  <tr>
4311
  <td class="spider_label"><label for="page_nav_font_color"><?php echo __('Font color:', BWG()->prefix); ?> </label></td>
4312
  <td>
4313
+ <input type="text" name="page_nav_font_color" id="page_nav_font_color" value="<?php echo $row->page_nav_font_color; ?>" class="jscolor"/>
4314
  </td>
4315
  </tr>
4316
  <tr>
4354
  <tr>
4355
  <td class="spider_label"><label for="page_nav_border_color"><?php echo __('Border color:', BWG()->prefix); ?></label></td>
4356
  <td>
4357
+ <input type="text" name="page_nav_border_color" id="page_nav_border_color" value="<?php echo $row->page_nav_border_color; ?>" class="jscolor"/>
4358
  </td>
4359
  </tr>
4360
  <tr>
4391
  <tr>
4392
  <td class="spider_label"><label for="page_nav_button_bg_color"><?php echo __('Button background color:', BWG()->prefix); ?> </label></td>
4393
  <td>
4394
+ <input type="text" name="page_nav_button_bg_color" id="page_nav_button_bg_color" value="<?php echo $row->page_nav_button_bg_color; ?>" class="jscolor" />
4395
  </td>
4396
  </tr>
4397
  <tr>
4486
  <tr>
4487
  <td class="spider_label"><label for="carousel_cont_bg_color"><?php echo __('Background color:', BWG()->prefix); ?> </label></td>
4488
  <td>
4489
+ <input type="text" name="carousel_cont_bg_color" id="carousel_cont_bg_color" value="<?php echo $row->carousel_cont_bg_color; ?>" class="jscolor"/>
4490
  </td>
4491
  </tr>
4492
  <tr>
4511
  <tr>
4512
  <td class="spider_label"><label for="carousel_rl_btn_color"><?php echo __('Buttons color:', BWG()->prefix); ?> </label></td>
4513
  <td>
4514
+ <input type="text" name="carousel_rl_btn_color" id="carousel_rl_btn_color" value="<?php echo $row->carousel_rl_btn_color; ?>" class="jscolor"/>
4515
  </td>
4516
  </tr>
4517
  <tr>
4524
  <tr>
4525
  <td class="spider_label"><label for="carousel_close_rl_btn_hover_color"><?php echo __('Buttons hover color:', BWG()->prefix); ?> </label></td>
4526
  <td>
4527
+ <input type="text" name="carousel_close_rl_btn_hover_color" id="carousel_close_rl_btn_hover_color" value="<?php echo $row->carousel_close_rl_btn_hover_color; ?>" class="jscolor"/>
4528
  </td>
4529
  </tr>
4530
  <tr>
4542
  <tr>
4543
  <td class="spider_label"><label for="carousel_rl_btn_bg_color"><?php echo __('Right, left buttons background color:', BWG()->prefix); ?> </label></td>
4544
  <td>
4545
+ <input type="text" name="carousel_rl_btn_bg_color" id="carousel_rl_btn_bg_color" value="<?php echo $row->carousel_rl_btn_bg_color; ?>" class="jscolor"/>
4546
  </td>
4547
  </tr>
4548
  <tr>
4568
  <tr>
4569
  <td class="spider_label"><label for="carousel_rl_btn_border_color"><?php echo __('Right, left buttons border color:', BWG()->prefix); ?> </label></td>
4570
  <td>
4571
+ <input type="text" name="carousel_rl_btn_border_color" id="slideshow_rl_btn_border_color" value="<?php echo $row->carousel_rl_btn_border_color; ?>" class="jscolor"/>
4572
  </td>
4573
  </tr>
4574
  <tr>
4633
  <tr>
4634
  <td class="spider_label"><label for="carousel_feature_border_color"><?php echo __('Image border color:', BWG()->prefix); ?> </label></td>
4635
  <td>
4636
+ <input type="text" name="carousel_feature_border_color" id="carousel_feature_border_color" value="<?php echo $row->carousel_feature_border_color; ?>" class="jscolor"/>
4637
  </td>
4638
  </tr>
4639
  </tbody>
4649
  <tr>
4650
  <td class="spider_label"><label for="carousel_caption_background_color"><?php echo __('Title background color:', BWG()->prefix); ?> </label></td>
4651
  <td>
4652
+ <input type="text" name="carousel_caption_background_color" id="carousel_caption_background_color" value="<?php echo $row->carousel_caption_background_color; ?>" class="jscolor"/>
4653
  </td>
4654
  </tr>
4655
 
4692
  <tr>
4693
  <td class="spider_label"><label for="carousel_caption_p_color"><?php echo __('Title color:', BWG()->prefix); ?> </label></td>
4694
  <td>
4695
+ <input type="text" name="carousel_caption_p_color" id="carousel_caption_p_color" value="<?php echo $row->carousel_caption_p_color; ?>" class="jscolor"/>
4696
  </td>
4697
  </tr>
4698
  <tr>
4719
  <tr>
4720
  <td class="spider_label"><label for="carousel_gal_title_font_color"><?php echo __('Gallery title/description font color:', BWG()->prefix); ?> </label></td>
4721
  <td>
4722
+ <input type="text" name="carousel_gal_title_font_color" id="carousel_gal_title_font_color" value="<?php echo $row->carousel_gal_title_font_color; ?>" class="jscolor" />
4723
  </td>
4724
  </tr>
4725
  <tr>
4809
  </tr>
4810
  <tr>
4811
  <td class="spider_label"><label for="tags_but_font_color"><?php echo __('Font color:', BWG()->prefix); ?> </label></td>
4812
+ <td><input type="text" name="tags_but_font_color" id="tags_but_font_color" value="<?php echo $row->tags_but_font_color; ?>" class="jscolor"/></td>
4813
  </tr>
4814
  <tr>
4815
  <!--generate font style with google fonts -->
4857
  </tr>
4858
  <tr>
4859
  <td class="spider_label"><label for="tags_but_border_color"><?php echo __('Border color:', BWG()->prefix); ?></label></td>
4860
+ <td><input type="text" name="tags_but_border_color" id="tags_but_border_color" value="<?php echo $row->tags_but_border_color; ?>" class="jscolor"/></td>
4861
  </tr>
4862
  <tr>
4863
  <td class="spider_label"><label for="tags_but_border_radius"><?php echo __('Border radius:', BWG()->prefix); ?> </label></td>
4868
  </tr>
4869
  <tr>
4870
  <td class="spider_label"><label for="tags_but_bg_color"><?php echo __('Button background color:', BWG()->prefix); ?> </label></td>
4871
+ <td><input type="text" name="tags_but_bg_color" id="tags_but_bg_color" value="<?php echo $row->tags_but_bg_color; ?>" class="jscolor" /></td>
4872
  </tr>
4873
  <tr>
4874
  <td class="spider_label"><label for="tags_but_active_bg_color"><?php echo __('Active Button background color:', BWG()->prefix); ?> </label></td>
4875
+ <td><input type="text" name="tags_but_active_bg_color" id="tags_but_active_bg_color" value="<?php echo $row->tags_but_active_bg_color; ?>" class="jscolor" /></td>
4876
  </tr>
4877
  <tr>
4878
  <td class="spider_label"><label for="tags_but_active_color"><?php echo __('Active Button font color:', BWG()->prefix); ?> </label></td>
4879
+ <td><input type="text" name="tags_but_active_color" id="tags_but_active_color" value="<?php echo $row->tags_but_active_color; ?>" class="jscolor" /></td>
4880
  </tr>
4881
  <tr>
4882
  <td class="spider_label"><label for="tags_but_see_all_size"><?php echo __('See All Button Font size:', BWG()->prefix); ?> </label></td>
4886
  </tr>
4887
  <tr>
4888
  <td class="spider_label"><label for="tags_but_see_all_color"><?php echo __('See All Button Font color:', BWG()->prefix); ?> </label></td>
4889
+ <td><input type="text" name="tags_but_see_all_color" id="tags_but_see_all_color" value="<?php echo $row->tags_but_see_all_color; ?>" class="jscolor"/></td>
4890
  </tr>
4891
  <tr>
4892
  <td class="spider_label"><label for="tags_but_see_all_back_color"><?php echo __('See All Button background color:', BWG()->prefix); ?> </label></td>
4893
+ <td><input type="text" name="tags_but_see_all_back_color" id="tags_but_see_all_back_color" value="<?php echo $row->tags_but_see_all_back_color; ?>" class="jscolor" /></td>
4894
  </tr>
4895
  <tr>
4896
  <td class="spider_label"><label for="tags_but_see_all_border_w"><?php echo __('See All Button Border width:', BWG()->prefix); ?> </label></td>
4910
  </tr>
4911
  <tr>
4912
  <td class="spider_label"><label for="tags_but_see_all_border_c"><?php echo __('See All Button Border color:', BWG()->prefix); ?></label></td>
4913
+ <td><input type="text" name="tags_but_see_all_border_c" id="tags_but_see_all_border_c" value="<?php echo $row->tags_but_see_all_border_c; ?>" class="jscolor"/></td>
4914
  </tr>
4915
  <tr>
4916
  <td class="spider_label"><label for="tags_but_see_all_border_r"><?php echo __('See All Button Border radius:', BWG()->prefix); ?> </label></td>
admin/views/WidgetTags.php CHANGED
@@ -56,7 +56,7 @@ class WidgetTagsView_bwg {
56
  * @param $instance
57
  */
58
  function form($params, $instance) {
59
- wp_register_script(BWG()->prefix . '_jscolor', BWG()->plugin_url . '/js/jscolor/jscolor.js', array('jquery'), '1.3.9');
60
  wp_enqueue_script(BWG()->prefix . '_jscolor');
61
  extract($params);
62
  $defaults = array(
@@ -114,11 +114,11 @@ class WidgetTagsView_bwg {
114
  </p>
115
  <p id="p_bg_color" style="display:<?php echo (!$instance['background_transparent']) ? "" : "none" ?>;">
116
  <label for="<?php echo $id_background_color; ?>"><?php _e('Background Color:', BWG()->prefix); ?></label><br>
117
- <input class="color" style="width:25%;" id="<?php echo $id_background_color; ?>" name="<?php echo $name_background_color; ?>'" type="text" value="<?php echo $instance['background_color']; ?>"/>
118
  </p>
119
  <p>
120
  <label for="<?php echo $id_text_color; ?>"><?php _e('Text Color:', BWG()->prefix); ?></label><br>
121
- <input class="color" style="width:25%;" id="<?php echo $id_text_color; ?>" name="<?php echo $name_text_color; ?>'" type="text" value="<?php echo $instance['text_color']; ?>"/>
122
  </p>
123
  <p>
124
  <label for="<?php echo $id_theme_id; ?>"><?php _e('Themes:', BWG()->prefix); ?></label><br>
56
  * @param $instance
57
  */
58
  function form($params, $instance) {
59
+ wp_register_script(BWG()->prefix . '_jscolor', BWG()->plugin_url . '/js/jquery.jscolor.js', array('jquery'), '2.4.5');
60
  wp_enqueue_script(BWG()->prefix . '_jscolor');
61
  extract($params);
62
  $defaults = array(
114
  </p>
115
  <p id="p_bg_color" style="display:<?php echo (!$instance['background_transparent']) ? "" : "none" ?>;">
116
  <label for="<?php echo $id_background_color; ?>"><?php _e('Background Color:', BWG()->prefix); ?></label><br>
117
+ <input class="jscolor" style="width:25%;" id="<?php echo $id_background_color; ?>" name="<?php echo $name_background_color; ?>'" type="text" value="<?php echo $instance['background_color']; ?>"/>
118
  </p>
119
  <p>
120
  <label for="<?php echo $id_text_color; ?>"><?php _e('Text Color:', BWG()->prefix); ?></label><br>
121
+ <input class="jscolor" style="width:25%;" id="<?php echo $id_text_color; ?>" name="<?php echo $name_text_color; ?>'" type="text" value="<?php echo $instance['text_color']; ?>"/>
122
  </p>
123
  <p>
124
  <label for="<?php echo $id_theme_id; ?>"><?php _e('Themes:', BWG()->prefix); ?></label><br>
css/bwg_frontend.css CHANGED
@@ -312,6 +312,13 @@ div[id^="bwg_container"] div[id^="bwg_container"] .bwg_img_clear {
312
  .bwg_image_rate {
313
  z-index: 999 !important;
314
  }
 
 
 
 
 
 
 
315
 
316
  @media screen and (max-width: 465px) {
317
 
312
  .bwg_image_rate {
313
  z-index: 999 !important;
314
  }
315
+ .bwg_image_rate_disabled {
316
+ display: none;
317
+ position: absolute;
318
+ width: 100%;
319
+ height: 40px;
320
+ top: 0px;
321
+ }
322
 
323
  @media screen and (max-width: 465px) {
324
 
css/bwg_tables.css CHANGED
@@ -1866,7 +1866,10 @@ li.tabs {
1866
  #bwg_themes .wd-box-content select {
1867
  max-width: 90%;
1868
  }
1869
-
 
 
 
1870
  .bwg-section.bwg-no-top-border {
1871
  border-top: none;
1872
  }
1866
  #bwg_themes .wd-box-content select {
1867
  max-width: 90%;
1868
  }
1869
+ #bwg_themes .font-select {
1870
+ max-width: 85%;
1871
+ width: 100%;
1872
+ }
1873
  .bwg-section.bwg-no-top-border {
1874
  border-top: none;
1875
  }
css/jquery.mCustomScrollbar.css CHANGED
@@ -1,464 +1,1267 @@
1
- /* basic scrollbar styling */
2
- /* vertical scrollbar */
3
- .mCSB_container{
4
- width: auto;
5
- margin-right: 15px;
6
- overflow: hidden;
7
- }
8
- .mCSB_container.mCS_no_scrollbar{
9
- margin-right: 0;
10
- }
11
- .mCS_disabled>.mCustomScrollBox>.mCSB_container.mCS_no_scrollbar,
12
- .mCS_destroyed>.mCustomScrollBox>.mCSB_container.mCS_no_scrollbar{
13
- margin-right:15px;
14
- }
15
- .mCustomScrollBox>.mCSB_scrollTools{
16
- width:16px;
17
- height:100%;
18
- top:0;
19
- right:0;
20
- }
21
- .mCSB_scrollTools .mCSB_draggerContainer{
22
- position:absolute;
23
- top:0;
24
- left:0;
25
- bottom:0;
26
- right:0;
27
- height:auto;
28
- }
29
- .mCSB_scrollTools a+.mCSB_draggerContainer{
30
- margin:20px 0;
31
- }
32
- .mCSB_scrollTools .mCSB_draggerRail{
33
- width:2px;
34
- height:100%;
35
- margin:0 auto;
36
- -webkit-border-radius:10px;
37
- -moz-border-radius:10px;
38
- border-radius:10px;
39
- }
40
- .mCSB_scrollTools .mCSB_dragger{
41
- cursor:pointer;
42
- width:100%;
43
- height:30px;
44
- }
45
- .mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
46
- width:4px;
47
- height:100%;
48
- margin:0 auto;
49
- -webkit-border-radius:10px;
50
- -moz-border-radius:10px;
51
- border-radius:10px;
52
- text-align:center;
53
- }
54
- .mCSB_scrollTools .mCSB_buttonUp,
55
- .mCSB_scrollTools .mCSB_buttonDown{
56
- display:block;
57
- position:relative;
58
- height:20px;
59
- overflow:hidden;
60
- margin:0 auto;
61
- cursor:pointer;
62
- }
63
- .mCSB_scrollTools .mCSB_buttonDown{
64
- top:100%;
65
- margin-top:-40px;
66
- }
67
- /* horizontal scrollbar */
68
- .mCSB_horizontal>.mCSB_container{
69
- height:auto;
70
- margin-right:0;
71
- margin-bottom:30px;
72
- overflow:hidden;
73
- }
74
- .mCSB_horizontal>.mCSB_container.mCS_no_scrollbar{
75
- margin-bottom:0;
76
- }
77
- .mCS_disabled>.mCSB_horizontal>.mCSB_container.mCS_no_scrollbar,
78
- .mCS_destroyed>.mCSB_horizontal>.mCSB_container.mCS_no_scrollbar{
79
- margin-right:0;
80
- margin-bottom:30px;
81
- }
82
- .mCSB_horizontal.mCustomScrollBox>.mCSB_scrollTools{
83
- width:100%;
84
- height:16px;
85
- top:auto;
86
- right:auto;
87
- bottom:0;
88
- left:0;
89
- overflow:hidden;
90
- }
91
- .mCSB_horizontal>.mCSB_scrollTools a+.mCSB_draggerContainer{
92
- margin:0 20px;
93
- }
94
- .mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
95
- width:100%;
96
- height:2px;
97
- margin:7px 0;
98
- -webkit-border-radius:10px;
99
- -moz-border-radius:10px;
100
- border-radius:10px;
101
- }
102
- .mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger{
103
- width:30px;
104
- height:100%;
105
- }
106
- .mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
107
- width:100%;
108
- height:4px;
109
- margin:6px auto;
110
- -webkit-border-radius:10px;
111
- -moz-border-radius:10px;
112
- border-radius:10px;
113
- }
114
- .mCSB_horizontal>.mCSB_scrollTools .mCSB_buttonLeft,
115
- .mCSB_horizontal>.mCSB_scrollTools .mCSB_buttonRight{
116
- display:block;
117
- position:relative;
118
- width:20px;
119
- height:100%;
120
- overflow:hidden;
121
- margin:0 auto;
122
- cursor:pointer;
123
- float:left;
124
- }
125
- .mCSB_horizontal>.mCSB_scrollTools .mCSB_buttonRight{
126
- margin-left:-40px;
127
- float:right;
128
- }
129
- .mCustomScrollBox{
130
- -ms-touch-action:none; /*MSPointer events - direct all pointer events to js*/
131
- }
132
-
133
- /* default scrollbar colors and backgrounds (default theme) */
134
- .mCustomScrollBox>.mCSB_scrollTools{
135
- opacity:0.75;
136
- }
137
- .mCustomScrollBox:hover>.mCSB_scrollTools{
138
- opacity:1;
139
- }
140
- .mCSB_scrollTools .mCSB_draggerRail{
141
- background:#000; /* rgba fallback */
142
- background:rgba(0,0,0,0.4);
143
- }
144
- .mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
145
- background:#fff; /* rgba fallback */
146
- background:rgba(255,255,255,0.75);
147
- }
148
- .mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
149
- background:rgba(255,255,255,0.85);
150
- }
151
- .mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
152
- .mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
153
- background:rgba(255,255,255,0.9);
154
- }
155
- .mCSB_scrollTools .mCSB_buttonUp,
156
- .mCSB_scrollTools .mCSB_buttonDown,
157
- .mCSB_scrollTools .mCSB_buttonLeft,
158
- .mCSB_scrollTools .mCSB_buttonRight{
159
- background-repeat:no-repeat;
160
- opacity:0.4;
161
- }
162
- .mCSB_scrollTools .mCSB_buttonUp{
163
- background-position:0 0;
164
- /*
165
- sprites locations are 0 0/-16px 0/-32px 0/-48px 0 (light) and -80px 0/-96px 0/-112px 0/-128px 0 (dark)
166
- */
167
- }
168
- .mCSB_scrollTools .mCSB_buttonDown{
169
- background-position:0 -20px;
170
- /*
171
- sprites locations are 0 -20px/-16px -20px/-32px -20px/-48px -20px (light) and -80px -20px/-96px -20px/-112px -20px/-128px -20px (dark)
172
- */
173
- }
174
- .mCSB_scrollTools .mCSB_buttonLeft{
175
- background-position:0 -40px;
176
- /*
177
- sprites locations are 0 -40px/-20px -40px/-40px -40px/-60px -40px (light) and -80px -40px/-100px -40px/-120px -40px/-140px -40px (dark)
178
- */
179
- }
180
- .mCSB_scrollTools .mCSB_buttonRight{
181
- background-position:0 -56px;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
182
  /*
183
- sprites locations are 0 -56px/-20px -56px/-40px -56px/-60px -56px (light) and -80px -56px/-100px -56px/-120px -56px/-140px -56px (dark)
 
 
184
  */
185
- }
186
- .mCSB_scrollTools .mCSB_buttonUp:hover,
187
- .mCSB_scrollTools .mCSB_buttonDown:hover,
188
- .mCSB_scrollTools .mCSB_buttonLeft:hover,
189
- .mCSB_scrollTools .mCSB_buttonRight:hover{
190
- opacity:0.75;
191
- }
192
- .mCSB_scrollTools .mCSB_buttonUp:active,
193
- .mCSB_scrollTools .mCSB_buttonDown:active,
194
- .mCSB_scrollTools .mCSB_buttonLeft:active,
195
- .mCSB_scrollTools .mCSB_buttonRight:active{
196
- opacity:0.9;
197
- }
198
-
199
- /*scrollbar themes*/
200
- /*dark (dark colored scrollbar)*/
201
- .mCS-dark>.mCSB_scrollTools .mCSB_draggerRail{
202
- background:#000; /* rgba fallback */
203
- background:rgba(0,0,0,0.15);
204
- }
205
- .mCS-dark>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
206
- background:#000; /* rgba fallback */
207
- background:rgba(0,0,0,0.75);
208
- }
209
- .mCS-dark>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
210
- background:rgba(0,0,0,0.85);
211
- }
212
- .mCS-dark>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
213
- .mCS-dark>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
214
- background:rgba(0,0,0,0.9);
215
- }
216
- .mCS-dark>.mCSB_scrollTools .mCSB_buttonUp{
217
- background-position:-80px 0;
218
- }
219
- .mCS-dark>.mCSB_scrollTools .mCSB_buttonDown{
220
- background-position:-80px -20px;
221
- }
222
- .mCS-dark>.mCSB_scrollTools .mCSB_buttonLeft{
223
- background-position:-80px -40px;
224
- }
225
- .mCS-dark>.mCSB_scrollTools .mCSB_buttonRight{
226
- background-position:-80px -56px;
227
- }
228
- /*light-2*/
229
- .mCS-light-2>.mCSB_scrollTools .mCSB_draggerRail{
230
- width:4px;
231
- background:#fff; /* rgba fallback */
232
- background:rgba(255,255,255,0.1);
233
- -webkit-border-radius:1px;
234
- -moz-border-radius:1px;
235
- border-radius:1px;
236
- }
237
- .mCS-light-2>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
238
- width:4px;
239
- background:#fff; /* rgba fallback */
240
- background:rgba(255,255,255,0.75);
241
- -webkit-border-radius:1px;
242
- -moz-border-radius:1px;
243
- border-radius:1px;
244
- }
245
- .mCS-light-2.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
246
- width:100%;
247
- height:4px;
248
- margin:6px 0;
249
- }
250
- .mCS-light-2.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
251
- width:100%;
252
- height:4px;
253
- margin:6px auto;
254
- }
255
- .mCS-light-2>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
256
- background:rgba(255,255,255,0.85);
257
- }
258
- .mCS-light-2>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
259
- .mCS-light-2>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
260
- background:rgba(255,255,255,0.9);
261
- }
262
- .mCS-light-2>.mCSB_scrollTools .mCSB_buttonUp{
263
- background-position:-32px 0;
264
- }
265
- .mCS-light-2>.mCSB_scrollTools .mCSB_buttonDown{
266
- background-position:-32px -20px;
267
- }
268
- .mCS-light-2>.mCSB_scrollTools .mCSB_buttonLeft{
269
- background-position:-40px -40px;
270
- }
271
- .mCS-light-2>.mCSB_scrollTools .mCSB_buttonRight{
272
- background-position:-40px -56px;
273
- }
274
- /*dark-2*/
275
- .mCS-dark-2>.mCSB_scrollTools .mCSB_draggerRail{
276
- width:4px;
277
- background:#000; /* rgba fallback */
278
- background:rgba(0,0,0,0.1);
279
- -webkit-border-radius:1px;
280
- -moz-border-radius:1px;
281
- border-radius:1px;
282
- }
283
- .mCS-dark-2>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
284
- width:4px;
285
- background:#000; /* rgba fallback */
286
- background:rgba(0,0,0,0.75);
287
- -webkit-border-radius:1px;
288
- -moz-border-radius:1px;
289
- border-radius:1px;
290
- }
291
- .mCS-dark-2.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
292
- width:100%;
293
- height:4px;
294
- margin:6px 0;
295
- }
296
- .mCS-dark-2.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
297
- width:100%;
298
- height:4px;
299
- margin:6px auto;
300
- }
301
- .mCS-dark-2>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
302
- background:rgba(0,0,0,0.85);
303
- }
304
- .mCS-dark-2>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
305
- .mCS-dark-2>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
306
- background:rgba(0,0,0,0.9);
307
- }
308
- .mCS-dark-2>.mCSB_scrollTools .mCSB_buttonUp{
309
- background-position:-112px 0;
310
- }
311
- .mCS-dark-2>.mCSB_scrollTools .mCSB_buttonDown{
312
- background-position:-112px -20px;
313
- }
314
- .mCS-dark-2>.mCSB_scrollTools .mCSB_buttonLeft{
315
- background-position:-120px -40px;
316
- }
317
- .mCS-dark-2>.mCSB_scrollTools .mCSB_buttonRight{
318
- background-position:-120px -56px;
319
- }
320
- /*light-thick*/
321
- .mCS-light-thick>.mCSB_scrollTools .mCSB_draggerRail{
322
- width:4px;
323
- background:#fff; /* rgba fallback */
324
- background:rgba(255,255,255,0.1);
325
- -webkit-border-radius:2px;
326
- -moz-border-radius:2px;
327
- border-radius:2px;
328
- }
329
- .mCS-light-thick>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
330
- width:6px;
331
- background:#fff; /* rgba fallback */
332
- background:rgba(255,255,255,0.75);
333
- -webkit-border-radius:2px;
334
- -moz-border-radius:2px;
335
- border-radius:2px;
336
- }
337
- .mCS-light-thick.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
338
- width:100%;
339
- height:4px;
340
- margin:6px 0;
341
- }
342
- .mCS-light-thick.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
343
- width:100%;
344
- height:6px;
345
- margin:5px auto;
346
- }
347
- .mCS-light-thick>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
348
- background:rgba(255,255,255,0.85);
349
- }
350
- .mCS-light-thick>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
351
- .mCS-light-thick>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
352
- background:rgba(255,255,255,0.9);
353
- }
354
- .mCS-light-thick>.mCSB_scrollTools .mCSB_buttonUp{
355
- background-position:-16px 0;
356
- }
357
- .mCS-light-thick>.mCSB_scrollTools .mCSB_buttonDown{
358
- background-position:-16px -20px;
359
- }
360
- .mCS-light-thick>.mCSB_scrollTools .mCSB_buttonLeft{
361
- background-position:-20px -40px;
362
- }
363
- .mCS-light-thick>.mCSB_scrollTools .mCSB_buttonRight{
364
- background-position:-20px -56px;
365
- }
366
- /*dark-thick*/
367
- .mCS-dark-thick>.mCSB_scrollTools .mCSB_draggerRail{
368
- width:4px;
369
- background:#000; /* rgba fallback */
370
- background:rgba(0,0,0,0.1);
371
- -webkit-border-radius:2px;
372
- -moz-border-radius:2px;
373
- border-radius:2px;
374
- }
375
- .mCS-dark-thick>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
376
- width:6px;
377
- background:#000; /* rgba fallback */
378
- background:rgba(0,0,0,0.75);
379
- -webkit-border-radius:2px;
380
- -moz-border-radius:2px;
381
- border-radius:2px;
382
- }
383
- .mCS-dark-thick.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
384
- width:100%;
385
- height:4px;
386
- margin:6px 0;
387
- }
388
- .mCS-dark-thick.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
389
- width:100%;
390
- height:6px;
391
- margin:5px auto;
392
- }
393
- .mCS-dark-thick>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
394
- background:rgba(0,0,0,0.85);
395
- }
396
- .mCS-dark-thick>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
397
- .mCS-dark-thick>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
398
- background:rgba(0,0,0,0.9);
399
- }
400
- .mCS-dark-thick>.mCSB_scrollTools .mCSB_buttonUp{
401
- background-position:-96px 0;
402
- }
403
- .mCS-dark-thick>.mCSB_scrollTools .mCSB_buttonDown{
404
- background-position:-96px -20px;
405
- }
406
- .mCS-dark-thick>.mCSB_scrollTools .mCSB_buttonLeft{
407
- background-position:-100px -40px;
408
- }
409
- .mCS-dark-thick>.mCSB_scrollTools .mCSB_buttonRight{
410
- background-position:-100px -56px;
411
- }
412
- /*light-thin*/
413
- .mCS-light-thin>.mCSB_scrollTools .mCSB_draggerRail{
414
- background:#fff; /* rgba fallback */
415
- background:rgba(255,255,255,0.1);
416
- }
417
- .mCS-light-thin>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
418
- width:2px;
419
- }
420
- .mCS-light-thin.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
421
- width:100%;
422
- }
423
- .mCS-light-thin.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
424
- width:100%;
425
- height:2px;
426
- margin:7px auto;
427
- }
428
- /*dark-thin*/
429
- .mCS-dark-thin>.mCSB_scrollTools .mCSB_draggerRail{
430
- background:#000; /* rgba fallback */
431
- background:rgba(0,0,0,0.15);
432
- }
433
- .mCS-dark-thin>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
434
- width:2px;
435
- background:#000; /* rgba fallback */
436
- background:rgba(0,0,0,0.75);
437
- }
438
- .mCS-dark-thin.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{
439
- width:100%;
440
- }
441
- .mCS-dark-thin.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
442
- width:100%;
443
- height:2px;
444
- margin:7px auto;
445
- }
446
- .mCS-dark-thin>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
447
- background:rgba(0,0,0,0.85);
448
- }
449
- .mCS-dark-thin>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
450
- .mCS-dark-thin>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
451
- background:rgba(0,0,0,0.9);
452
- }
453
- .mCS-dark-thin>.mCSB_scrollTools .mCSB_buttonUp{
454
- background-position:-80px 0;
455
- }
456
- .mCS-dark-thin>.mCSB_scrollTools .mCSB_buttonDown{
457
- background-position:-80px -20px;
458
- }
459
- .mCS-dark-thin>.mCSB_scrollTools .mCSB_buttonLeft{
460
- background-position:-80px -40px;
461
- }
462
- .mCS-dark-thin>.mCSB_scrollTools .mCSB_buttonRight{
463
- background-position:-80px -56px;
464
- }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ /*
2
+ == malihu jquery custom scrollbar plugin ==
3
+ Plugin URI: http://manos.malihu.gr/jquery-custom-content-scroller
4
+ */
5
+
6
+
7
+
8
+ /*
9
+ CONTENTS:
10
+ 1. BASIC STYLE - Plugin's basic/essential CSS properties (normally, should not be edited).
11
+ 2. VERTICAL SCROLLBAR - Positioning and dimensions of vertical scrollbar.
12
+ 3. HORIZONTAL SCROLLBAR - Positioning and dimensions of horizontal scrollbar.
13
+ 4. VERTICAL AND HORIZONTAL SCROLLBARS - Positioning and dimensions of 2-axis scrollbars.
14
+ 5. TRANSITIONS - CSS3 transitions for hover events, auto-expanded and auto-hidden scrollbars.
15
+ 6. SCROLLBAR COLORS, OPACITY AND BACKGROUNDS
16
+ 6.1 THEMES - Scrollbar colors, opacity, dimensions, backgrounds etc. via ready-to-use themes.
17
+ */
18
+
19
+
20
+
21
+ /*
22
+ ------------------------------------------------------------------------------------------------------------------------
23
+ 1. BASIC STYLE
24
+ ------------------------------------------------------------------------------------------------------------------------
25
+ */
26
+
27
+ .mCustomScrollbar{ -ms-touch-action: pinch-zoom; touch-action: pinch-zoom; /* direct pointer events to js */ }
28
+ .mCustomScrollbar.mCS_no_scrollbar, .mCustomScrollbar.mCS_touch_action{ -ms-touch-action: auto; touch-action: auto; }
29
+
30
+ .mCustomScrollBox{ /* contains plugin's markup */
31
+ position: relative;
32
+ overflow: hidden;
33
+ height: 100%;
34
+ max-width: 100%;
35
+ outline: none;
36
+ direction: ltr;
37
+ }
38
+
39
+ .mCSB_container{ /* contains the original content */
40
+ overflow: hidden;
41
+ width: auto;
42
+ height: auto;
43
+ }
44
+
45
+
46
+
47
+ /*
48
+ ------------------------------------------------------------------------------------------------------------------------
49
+ 2. VERTICAL SCROLLBAR
50
+ y-axis
51
+ ------------------------------------------------------------------------------------------------------------------------
52
+ */
53
+
54
+ .mCSB_inside > .mCSB_container{ margin-right: 30px; }
55
+
56
+ .mCSB_container.mCS_no_scrollbar_y.mCS_y_hidden{ margin-right: 0; } /* non-visible scrollbar */
57
+
58
+ .mCS-dir-rtl > .mCSB_inside > .mCSB_container{ /* RTL direction/left-side scrollbar */
59
+ margin-right: 0;
60
+ margin-left: 30px;
61
+ }
62
+
63
+ .mCS-dir-rtl > .mCSB_inside > .mCSB_container.mCS_no_scrollbar_y.mCS_y_hidden{ margin-left: 0; } /* RTL direction/left-side scrollbar */
64
+
65
+ .mCSB_scrollTools{ /* contains scrollbar markup (draggable element, dragger rail, buttons etc.) */
66
+ position: absolute;
67
+ width: 16px;
68
+ height: auto;
69
+ left: auto;
70
+ top: 0;
71
+ right: 0;
72
+ bottom: 0;
73
+ }
74
+
75
+ .mCSB_outside + .mCSB_scrollTools{ right: -26px; } /* scrollbar position: outside */
76
+
77
+ .mCS-dir-rtl > .mCSB_inside > .mCSB_scrollTools,
78
+ .mCS-dir-rtl > .mCSB_outside + .mCSB_scrollTools{ /* RTL direction/left-side scrollbar */
79
+ right: auto;
80
+ left: 0;
81
+ }
82
+
83
+ .mCS-dir-rtl > .mCSB_outside + .mCSB_scrollTools{ left: -26px; } /* RTL direction/left-side scrollbar (scrollbar position: outside) */
84
+
85
+ .mCSB_scrollTools .mCSB_draggerContainer{ /* contains the draggable element and dragger rail markup */
86
+ position: absolute;
87
+ top: 0;
88
+ left: 0;
89
+ bottom: 0;
90
+ right: 0;
91
+ height: auto;
92
+ }
93
+
94
+ .mCSB_scrollTools a + .mCSB_draggerContainer{ margin: 20px 0; }
95
+
96
+ .mCSB_scrollTools .mCSB_draggerRail{
97
+ width: 2px;
98
+ height: 100%;
99
+ margin: 0 auto;
100
+ -webkit-border-radius: 16px; -moz-border-radius: 16px; border-radius: 16px;
101
+ }
102
+
103
+ .mCSB_scrollTools .mCSB_dragger{ /* the draggable element */
104
+ cursor: pointer;
105
+ width: 100%;
106
+ height: 30px; /* minimum dragger height */
107
+ z-index: 1;
108
+ }
109
+
110
+ .mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{ /* the dragger element */
111
+ position: relative;
112
+ width: 4px;
113
+ height: 100%;
114
+ margin: 0 auto;
115
+ -webkit-border-radius: 16px; -moz-border-radius: 16px; border-radius: 16px;
116
+ text-align: center;
117
+ }
118
+
119
+ .mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded .mCSB_dragger_bar,
120
+ .mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_dragger .mCSB_dragger_bar{ width: 12px; /* auto-expanded scrollbar */ }
121
+
122
+ .mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded + .mCSB_draggerRail,
123
+ .mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail{ width: 8px; /* auto-expanded scrollbar */ }
124
+
125
+ .mCSB_scrollTools .mCSB_buttonUp,
126
+ .mCSB_scrollTools .mCSB_buttonDown{
127
+ display: block;
128
+ position: absolute;
129
+ height: 20px;
130
+ width: 100%;
131
+ overflow: hidden;
132
+ margin: 0 auto;
133
+ cursor: pointer;
134
+ }
135
+
136
+ .mCSB_scrollTools .mCSB_buttonDown{ bottom: 0; }
137
+
138
+
139
+
140
+ /*
141
+ ------------------------------------------------------------------------------------------------------------------------
142
+ 3. HORIZONTAL SCROLLBAR
143
+ x-axis
144
+ ------------------------------------------------------------------------------------------------------------------------
145
+ */
146
+
147
+ .mCSB_horizontal.mCSB_inside > .mCSB_container{
148
+ margin-right: 0;
149
+ margin-bottom: 30px;
150
+ }
151
+
152
+ .mCSB_horizontal.mCSB_outside > .mCSB_container{ min-height: 100%; }
153
+
154
+ .mCSB_horizontal > .mCSB_container.mCS_no_scrollbar_x.mCS_x_hidden{ margin-bottom: 0; } /* non-visible scrollbar */
155
+
156
+ .mCSB_scrollTools.mCSB_scrollTools_horizontal{
157
+ width: auto;
158
+ height: 16px;
159
+ top: auto;
160
+ right: 0;
161
+ bottom: 0;
162
+ left: 0;
163
+ }
164
+
165
+ .mCustomScrollBox + .mCSB_scrollTools.mCSB_scrollTools_horizontal,
166
+ .mCustomScrollBox + .mCSB_scrollTools + .mCSB_scrollTools.mCSB_scrollTools_horizontal{ bottom: -26px; } /* scrollbar position: outside */
167
+
168
+ .mCSB_scrollTools.mCSB_scrollTools_horizontal a + .mCSB_draggerContainer{ margin: 0 20px; }
169
+
170
+ .mCSB_scrollTools.mCSB_scrollTools_horizontal .mCSB_draggerRail{
171
+ width: 100%;
172
+ height: 2px;
173
+ margin: 7px 0;
174
+ }
175
+
176
+ .mCSB_scrollTools.mCSB_scrollTools_horizontal .mCSB_dragger{
177
+ width: 30px; /* minimum dragger width */
178
+ height: 100%;
179
+ left: 0;
180
+ }
181
+
182
+ .mCSB_scrollTools.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{
183
+ width: 100%;
184
+ height: 4px;
185
+ margin: 6px auto;
186
+ }
187
+
188
+ .mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded .mCSB_dragger_bar,
189
+ .mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_dragger .mCSB_dragger_bar{
190
+ height: 12px; /* auto-expanded scrollbar */
191
+ margin: 2px auto;
192
+ }
193
+
194
+ .mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded + .mCSB_draggerRail,
195
+ .mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail{
196
+ height: 8px; /* auto-expanded scrollbar */
197
+ margin: 4px 0;
198
+ }
199
+
200
+ .mCSB_scrollTools.mCSB_scrollTools_horizontal .mCSB_buttonLeft,
201
+ .mCSB_scrollTools.mCSB_scrollTools_horizontal .mCSB_buttonRight{
202
+ display: block;
203
+ position: absolute;
204
+ width: 20px;
205
+ height: 100%;
206
+ overflow: hidden;
207
+ margin: 0 auto;
208
+ cursor: pointer;
209
+ }
210
+
211
+ .mCSB_scrollTools.mCSB_scrollTools_horizontal .mCSB_buttonLeft{ left: 0; }
212
+
213
+ .mCSB_scrollTools.mCSB_scrollTools_horizontal .mCSB_buttonRight{ right: 0; }
214
+
215
+
216
+
217
+ /*
218
+ ------------------------------------------------------------------------------------------------------------------------
219
+ 4. VERTICAL AND HORIZONTAL SCROLLBARS
220
+ yx-axis
221
+ ------------------------------------------------------------------------------------------------------------------------
222
+ */
223
+
224
+ .mCSB_container_wrapper{
225
+ position: absolute;
226
+ height: auto;
227
+ width: auto;
228
+ overflow: hidden;
229
+ top: 0;
230
+ left: 0;
231
+ right: 0;
232
+ bottom: 0;
233
+ margin-right: 30px;
234
+ margin-bottom: 30px;
235
+ }
236
+
237
+ .mCSB_container_wrapper > .mCSB_container{
238
+ padding-right: 30px;
239
+ padding-bottom: 30px;
240
+ -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box;
241
+ }
242
+
243
+ .mCSB_vertical_horizontal > .mCSB_scrollTools.mCSB_scrollTools_vertical{ bottom: 20px; }
244
+
245
+ .mCSB_vertical_horizontal > .mCSB_scrollTools.mCSB_scrollTools_horizontal{ right: 20px; }
246
+
247
+ /* non-visible horizontal scrollbar */
248
+ .mCSB_container_wrapper.mCS_no_scrollbar_x.mCS_x_hidden + .mCSB_scrollTools.mCSB_scrollTools_vertical{ bottom: 0; }
249
+
250
+ /* non-visible vertical scrollbar/RTL direction/left-side scrollbar */
251
+ .mCSB_container_wrapper.mCS_no_scrollbar_y.mCS_y_hidden + .mCSB_scrollTools ~ .mCSB_scrollTools.mCSB_scrollTools_horizontal,
252
+ .mCS-dir-rtl > .mCustomScrollBox.mCSB_vertical_horizontal.mCSB_inside > .mCSB_scrollTools.mCSB_scrollTools_horizontal{ right: 0; }
253
+
254
+ /* RTL direction/left-side scrollbar */
255
+ .mCS-dir-rtl > .mCustomScrollBox.mCSB_vertical_horizontal.mCSB_inside > .mCSB_scrollTools.mCSB_scrollTools_horizontal{ left: 20px; }
256
+
257
+ /* non-visible scrollbar/RTL direction/left-side scrollbar */
258
+ .mCS-dir-rtl > .mCustomScrollBox.mCSB_vertical_horizontal.mCSB_inside > .mCSB_container_wrapper.mCS_no_scrollbar_y.mCS_y_hidden + .mCSB_scrollTools ~ .mCSB_scrollTools.mCSB_scrollTools_horizontal{ left: 0; }
259
+
260
+ .mCS-dir-rtl > .mCSB_inside > .mCSB_container_wrapper{ /* RTL direction/left-side scrollbar */
261
+ margin-right: 0;
262
+ margin-left: 30px;
263
+ }
264
+
265
+ .mCSB_container_wrapper.mCS_no_scrollbar_y.mCS_y_hidden > .mCSB_container{ padding-right: 0; }
266
+
267
+ .mCSB_container_wrapper.mCS_no_scrollbar_x.mCS_x_hidden > .mCSB_container{ padding-bottom: 0; }
268
+
269
+ .mCustomScrollBox.mCSB_vertical_horizontal.mCSB_inside > .mCSB_container_wrapper.mCS_no_scrollbar_y.mCS_y_hidden{
270
+ margin-right: 0; /* non-visible scrollbar */
271
+ margin-left: 0;
272
+ }
273
+
274
+ /* non-visible horizontal scrollbar */
275
+ .mCustomScrollBox.mCSB_vertical_horizontal.mCSB_inside > .mCSB_container_wrapper.mCS_no_scrollbar_x.mCS_x_hidden{ margin-bottom: 0; }
276
+
277
+
278
+
279
+ /*
280
+ ------------------------------------------------------------------------------------------------------------------------
281
+ 5. TRANSITIONS
282
+ ------------------------------------------------------------------------------------------------------------------------
283
+ */
284
+
285
+ .mCSB_scrollTools,
286
+ .mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
287
+ .mCSB_scrollTools .mCSB_buttonUp,
288
+ .mCSB_scrollTools .mCSB_buttonDown,
289
+ .mCSB_scrollTools .mCSB_buttonLeft,
290
+ .mCSB_scrollTools .mCSB_buttonRight{
291
+ -webkit-transition: opacity .2s ease-in-out, background-color .2s ease-in-out;
292
+ -moz-transition: opacity .2s ease-in-out, background-color .2s ease-in-out;
293
+ -o-transition: opacity .2s ease-in-out, background-color .2s ease-in-out;
294
+ transition: opacity .2s ease-in-out, background-color .2s ease-in-out;
295
+ }
296
+
297
+ .mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger_bar, /* auto-expanded scrollbar */
298
+ .mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerRail,
299
+ .mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger_bar,
300
+ .mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerRail{
301
+ -webkit-transition: width .2s ease-out .2s, height .2s ease-out .2s,
302
+ margin-left .2s ease-out .2s, margin-right .2s ease-out .2s,
303
+ margin-top .2s ease-out .2s, margin-bottom .2s ease-out .2s,
304
+ opacity .2s ease-in-out, background-color .2s ease-in-out;
305
+ -moz-transition: width .2s ease-out .2s, height .2s ease-out .2s,
306
+ margin-left .2s ease-out .2s, margin-right .2s ease-out .2s,
307
+ margin-top .2s ease-out .2s, margin-bottom .2s ease-out .2s,
308
+ opacity .2s ease-in-out, background-color .2s ease-in-out;
309
+ -o-transition: width .2s ease-out .2s, height .2s ease-out .2s,
310
+ margin-left .2s ease-out .2s, margin-right .2s ease-out .2s,
311
+ margin-top .2s ease-out .2s, margin-bottom .2s ease-out .2s,
312
+ opacity .2s ease-in-out, background-color .2s ease-in-out;
313
+ transition: width .2s ease-out .2s, height .2s ease-out .2s,
314
+ margin-left .2s ease-out .2s, margin-right .2s ease-out .2s,
315
+ margin-top .2s ease-out .2s, margin-bottom .2s ease-out .2s,
316
+ opacity .2s ease-in-out, background-color .2s ease-in-out;
317
+ }
318
+
319
+
320
+
321
+ /*
322
+ ------------------------------------------------------------------------------------------------------------------------
323
+ 6. SCROLLBAR COLORS, OPACITY AND BACKGROUNDS
324
+ ------------------------------------------------------------------------------------------------------------------------
325
+ */
326
+
327
  /*
328
+ ----------------------------------------
329
+ 6.1 THEMES
330
+ ----------------------------------------
331
  */
332
+
333
+ /* default theme ("light") */
334
+
335
+ .mCSB_scrollTools{ opacity: 0.75; filter: "alpha(opacity=75)"; -ms-filter: "alpha(opacity=75)"; }
336
+
337
+ .mCS-autoHide > .mCustomScrollBox > .mCSB_scrollTools,
338
+ .mCS-autoHide > .mCustomScrollBox ~ .mCSB_scrollTools{ opacity: 0; filter: "alpha(opacity=0)"; -ms-filter: "alpha(opacity=0)"; }
339
+
340
+ .mCustomScrollbar > .mCustomScrollBox > .mCSB_scrollTools.mCSB_scrollTools_onDrag,
341
+ .mCustomScrollbar > .mCustomScrollBox ~ .mCSB_scrollTools.mCSB_scrollTools_onDrag,
342
+ .mCustomScrollBox:hover > .mCSB_scrollTools,
343
+ .mCustomScrollBox:hover ~ .mCSB_scrollTools,
344
+ .mCS-autoHide:hover > .mCustomScrollBox > .mCSB_scrollTools,
345
+ .mCS-autoHide:hover > .mCustomScrollBox ~ .mCSB_scrollTools{ opacity: 1; filter: "alpha(opacity=100)"; -ms-filter: "alpha(opacity=100)"; }
346
+
347
+ .mCSB_scrollTools .mCSB_draggerRail{
348
+ background-color: #000; background-color: rgba(0,0,0,0.4);
349
+ filter: "alpha(opacity=40)"; -ms-filter: "alpha(opacity=40)";
350
+ }
351
+
352
+ .mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
353
+ background-color: #fff; background-color: rgba(255,255,255,0.75);
354
+ filter: "alpha(opacity=75)"; -ms-filter: "alpha(opacity=75)";
355
+ }
356
+
357
+ .mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{
358
+ background-color: #fff; background-color: rgba(255,255,255,0.85);
359
+ filter: "alpha(opacity=85)"; -ms-filter: "alpha(opacity=85)";
360
+ }
361
+ .mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
362
+ .mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
363
+ background-color: #fff; background-color: rgba(255,255,255,0.9);
364
+ filter: "alpha(opacity=90)"; -ms-filter: "alpha(opacity=90)";
365
+ }
366
+
367
+ .mCSB_scrollTools .mCSB_buttonUp,
368
+ .mCSB_scrollTools .mCSB_buttonDown,
369
+ .mCSB_scrollTools .mCSB_buttonLeft,
370
+ .mCSB_scrollTools .mCSB_buttonRight{
371
+ background-image: url(mCSB_buttons.png); /* css sprites */
372
+ background-repeat: no-repeat;
373
+ opacity: 0.4; filter: "alpha(opacity=40)"; -ms-filter: "alpha(opacity=40)";
374
+ }
375
+
376
+ .mCSB_scrollTools .mCSB_buttonUp{
377
+ background-position: 0 0;
378
+ /*
379
+ sprites locations
380
+ light: 0 0, -16px 0, -32px 0, -48px 0, 0 -72px, -16px -72px, -32px -72px
381
+ dark: -80px 0, -96px 0, -112px 0, -128px 0, -80px -72px, -96px -72px, -112px -72px
382
+ */
383
+ }
384
+
385
+ .mCSB_scrollTools .mCSB_buttonDown{
386
+ background-position: 0 -20px;
387
+ /*
388
+ sprites locations
389
+ light: 0 -20px, -16px -20px, -32px -20px, -48px -20px, 0 -92px, -16px -92px, -32px -92px
390
+ dark: -80px -20px, -96px -20px, -112px -20px, -128px -20px, -80px -92px, -96px -92px, -112 -92px
391
+ */
392
+ }
393
+
394
+ .mCSB_scrollTools .mCSB_buttonLeft{
395
+ background-position: 0 -40px;
396
+ /*
397
+ sprites locations
398
+ light: 0 -40px, -20px -40px, -40px -40px, -60px -40px, 0 -112px, -20px -112px, -40px -112px
399
+ dark: -80px -40px, -100px -40px, -120px -40px, -140px -40px, -80px -112px, -100px -112px, -120px -112px
400
+ */
401
+ }
402
+
403
+ .mCSB_scrollTools .mCSB_buttonRight{
404
+ background-position: 0 -56px;
405
+ /*
406
+ sprites locations
407
+ light: 0 -56px, -20px -56px, -40px -56px, -60px -56px, 0 -128px, -20px -128px, -40px -128px
408
+ dark: -80px -56px, -100px -56px, -120px -56px, -140px -56px, -80px -128px, -100px -128px, -120px -128px
409
+ */
410
+ }
411
+
412
+ .mCSB_scrollTools .mCSB_buttonUp:hover,
413
+ .mCSB_scrollTools .mCSB_buttonDown:hover,
414
+ .mCSB_scrollTools .mCSB_buttonLeft:hover,
415
+ .mCSB_scrollTools .mCSB_buttonRight:hover{ opacity: 0.75; filter: "alpha(opacity=75)"; -ms-filter: "alpha(opacity=75)"; }
416
+
417
+ .mCSB_scrollTools .mCSB_buttonUp:active,
418
+ .mCSB_scrollTools .mCSB_buttonDown:active,
419
+ .mCSB_scrollTools .mCSB_buttonLeft:active,
420
+ .mCSB_scrollTools .mCSB_buttonRight:active{ opacity: 0.9; filter: "alpha(opacity=90)"; -ms-filter: "alpha(opacity=90)"; }
421
+
422
+
423
+ /* theme: "dark" */
424
+
425
+ .mCS-dark.mCSB_scrollTools .mCSB_draggerRail{ background-color: #000; background-color: rgba(0,0,0,0.15); }
426
+
427
+ .mCS-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.75); }
428
+
429
+ .mCS-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{ background-color: rgba(0,0,0,0.85); }
430
+
431
+ .mCS-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
432
+ .mCS-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{ background-color: rgba(0,0,0,0.9); }
433
+
434
+ .mCS-dark.mCSB_scrollTools .mCSB_buttonUp{ background-position: -80px 0; }
435
+
436
+ .mCS-dark.mCSB_scrollTools .mCSB_buttonDown{ background-position: -80px -20px; }
437
+
438
+ .mCS-dark.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -80px -40px; }
439
+
440
+ .mCS-dark.mCSB_scrollTools .mCSB_buttonRight{ background-position: -80px -56px; }
441
+
442
+ /* ---------------------------------------- */
443
+
444
+
445
+
446
+ /* theme: "light-2", "dark-2" */
447
+
448
+ .mCS-light-2.mCSB_scrollTools .mCSB_draggerRail,
449
+ .mCS-dark-2.mCSB_scrollTools .mCSB_draggerRail{
450
+ width: 4px;
451
+ background-color: #fff; background-color: rgba(255,255,255,0.1);
452
+ -webkit-border-radius: 1px; -moz-border-radius: 1px; border-radius: 1px;
453
+ }
454
+
455
+ .mCS-light-2.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
456
+ .mCS-dark-2.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
457
+ width: 4px;
458
+ background-color: #fff; background-color: rgba(255,255,255,0.75);
459
+ -webkit-border-radius: 1px; -moz-border-radius: 1px; border-radius: 1px;
460
+ }
461
+
462
+ .mCS-light-2.mCSB_scrollTools_horizontal .mCSB_draggerRail,
463
+ .mCS-dark-2.mCSB_scrollTools_horizontal .mCSB_draggerRail,
464
+ .mCS-light-2.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
465
+ .mCS-dark-2.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{
466
+ width: 100%;
467
+ height: 4px;
468
+ margin: 6px auto;
469
+ }
470
+
471
+ .mCS-light-2.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{ background-color: #fff; background-color: rgba(255,255,255,0.85); }
472
+
473
+ .mCS-light-2.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
474
+ .mCS-light-2.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{ background-color: #fff; background-color: rgba(255,255,255,0.9); }
475
+
476
+ .mCS-light-2.mCSB_scrollTools .mCSB_buttonUp{ background-position: -32px 0; }
477
+
478
+ .mCS-light-2.mCSB_scrollTools .mCSB_buttonDown{ background-position: -32px -20px; }
479
+
480
+ .mCS-light-2.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -40px -40px; }
481
+
482
+ .mCS-light-2.mCSB_scrollTools .mCSB_buttonRight{ background-position: -40px -56px; }
483
+
484
+
485
+ /* theme: "dark-2" */
486
+
487
+ .mCS-dark-2.mCSB_scrollTools .mCSB_draggerRail{
488
+ background-color: #000; background-color: rgba(0,0,0,0.1);
489
+ -webkit-border-radius: 1px; -moz-border-radius: 1px; border-radius: 1px;
490
+ }
491
+
492
+ .mCS-dark-2.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
493
+ background-color: #000; background-color: rgba(0,0,0,0.75);
494
+ -webkit-border-radius: 1px; -moz-border-radius: 1px; border-radius: 1px;
495
+ }
496
+
497
+ .mCS-dark-2.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.85); }
498
+
499
+ .mCS-dark-2.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
500
+ .mCS-dark-2.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.9); }
501
+
502
+ .mCS-dark-2.mCSB_scrollTools .mCSB_buttonUp{ background-position: -112px 0; }
503
+
504
+ .mCS-dark-2.mCSB_scrollTools .mCSB_buttonDown{ background-position: -112px -20px; }
505
+
506
+ .mCS-dark-2.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -120px -40px; }
507
+
508
+ .mCS-dark-2.mCSB_scrollTools .mCSB_buttonRight{ background-position: -120px -56px; }
509
+
510
+ /* ---------------------------------------- */
511
+
512
+
513
+
514
+ /* theme: "light-thick", "dark-thick" */
515
+
516
+ .mCS-light-thick.mCSB_scrollTools .mCSB_draggerRail,
517
+ .mCS-dark-thick.mCSB_scrollTools .mCSB_draggerRail{
518
+ width: 4px;
519
+ background-color: #fff; background-color: rgba(255,255,255,0.1);
520
+ -webkit-border-radius: 2px; -moz-border-radius: 2px; border-radius: 2px;
521
+ }
522
+
523
+ .mCS-light-thick.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
524
+ .mCS-dark-thick.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
525
+ width: 6px;
526
+ background-color: #fff; background-color: rgba(255,255,255,0.75);
527
+ -webkit-border-radius: 2px; -moz-border-radius: 2px; border-radius: 2px;
528
+ }
529
+
530
+ .mCS-light-thick.mCSB_scrollTools_horizontal .mCSB_draggerRail,
531
+ .mCS-dark-thick.mCSB_scrollTools_horizontal .mCSB_draggerRail{
532
+ width: 100%;
533
+ height: 4px;
534
+ margin: 6px 0;
535
+ }
536
+
537
+ .mCS-light-thick.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
538
+ .mCS-dark-thick.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{
539
+ width: 100%;
540
+ height: 6px;
541
+ margin: 5px auto;
542
+ }
543
+
544
+ .mCS-light-thick.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{ background-color: #fff; background-color: rgba(255,255,255,0.85); }
545
+
546
+ .mCS-light-thick.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
547
+ .mCS-light-thick.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{ background-color: #fff; background-color: rgba(255,255,255,0.9); }
548
+
549
+ .mCS-light-thick.mCSB_scrollTools .mCSB_buttonUp{ background-position: -16px 0; }
550
+
551
+ .mCS-light-thick.mCSB_scrollTools .mCSB_buttonDown{ background-position: -16px -20px; }
552
+
553
+ .mCS-light-thick.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -20px -40px; }
554
+
555
+ .mCS-light-thick.mCSB_scrollTools .mCSB_buttonRight{ background-position: -20px -56px; }
556
+
557
+
558
+ /* theme: "dark-thick" */
559
+
560
+ .mCS-dark-thick.mCSB_scrollTools .mCSB_draggerRail{
561
+ background-color: #000; background-color: rgba(0,0,0,0.1);
562
+ -webkit-border-radius: 2px; -moz-border-radius: 2px; border-radius: 2px;
563
+ }
564
+
565
+ .mCS-dark-thick.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
566
+ background-color: #000; background-color: rgba(0,0,0,0.75);
567
+ -webkit-border-radius: 2px; -moz-border-radius: 2px; border-radius: 2px;
568
+ }
569
+
570
+ .mCS-dark-thick.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.85); }
571
+
572
+ .mCS-dark-thick.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
573
+ .mCS-dark-thick.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.9); }
574
+
575
+ .mCS-dark-thick.mCSB_scrollTools .mCSB_buttonUp{ background-position: -96px 0; }
576
+
577
+ .mCS-dark-thick.mCSB_scrollTools .mCSB_buttonDown{ background-position: -96px -20px; }
578
+
579
+ .mCS-dark-thick.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -100px -40px; }
580
+
581
+ .mCS-dark-thick.mCSB_scrollTools .mCSB_buttonRight{ background-position: -100px -56px; }
582
+
583
+ /* ---------------------------------------- */
584
+
585
+
586
+
587
+ /* theme: "light-thin", "dark-thin" */
588
+
589
+ .mCS-light-thin.mCSB_scrollTools .mCSB_draggerRail{ background-color: #fff; background-color: rgba(255,255,255,0.1); }
590
+
591
+ .mCS-light-thin.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
592
+ .mCS-dark-thin.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{ width: 2px; }
593
+
594
+ .mCS-light-thin.mCSB_scrollTools_horizontal .mCSB_draggerRail,
595
+ .mCS-dark-thin.mCSB_scrollTools_horizontal .mCSB_draggerRail{ width: 100%; }
596
+
597
+ .mCS-light-thin.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
598
+ .mCS-dark-thin.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{
599
+ width: 100%;
600
+ height: 2px;
601
+ margin: 7px auto;
602
+ }
603
+
604
+
605
+ /* theme "dark-thin" */
606
+
607
+ .mCS-dark-thin.mCSB_scrollTools .mCSB_draggerRail{ background-color: #000; background-color: rgba(0,0,0,0.15); }
608
+
609
+ .mCS-dark-thin.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.75); }
610
+
611
+ .mCS-dark-thin.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.85); }
612
+
613
+ .mCS-dark-thin.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
614
+ .mCS-dark-thin.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.9); }
615
+
616
+ .mCS-dark-thin.mCSB_scrollTools .mCSB_buttonUp{ background-position: -80px 0; }
617
+
618
+ .mCS-dark-thin.mCSB_scrollTools .mCSB_buttonDown{ background-position: -80px -20px; }
619
+
620
+ .mCS-dark-thin.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -80px -40px; }
621
+
622
+ .mCS-dark-thin.mCSB_scrollTools .mCSB_buttonRight{ background-position: -80px -56px; }
623
+
624
+ /* ---------------------------------------- */
625
+
626
+
627
+
628
+ /* theme "rounded", "rounded-dark", "rounded-dots", "rounded-dots-dark" */
629
+
630
+ .mCS-rounded.mCSB_scrollTools .mCSB_draggerRail{ background-color: #fff; background-color: rgba(255,255,255,0.15); }
631
+
632
+ .mCS-rounded.mCSB_scrollTools .mCSB_dragger,
633
+ .mCS-rounded-dark.mCSB_scrollTools .mCSB_dragger,
634
+ .mCS-rounded-dots.mCSB_scrollTools .mCSB_dragger,
635
+ .mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_dragger{ height: 14px; }
636
+
637
+ .mCS-rounded.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
638
+ .mCS-rounded-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
639
+ .mCS-rounded-dots.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
640
+ .mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
641
+ width: 14px;
642
+ margin: 0 1px;
643
+ }
644
+
645
+ .mCS-rounded.mCSB_scrollTools_horizontal .mCSB_dragger,
646
+ .mCS-rounded-dark.mCSB_scrollTools_horizontal .mCSB_dragger,
647
+ .mCS-rounded-dots.mCSB_scrollTools_horizontal .mCSB_dragger,
648
+ .mCS-rounded-dots-dark.mCSB_scrollTools_horizontal .mCSB_dragger{ width: 14px; }
649
+
650
+ .mCS-rounded.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
651
+ .mCS-rounded-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
652
+ .mCS-rounded-dots.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
653
+ .mCS-rounded-dots-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{
654
+ height: 14px;
655
+ margin: 1px 0;
656
+ }
657
+
658
+ .mCS-rounded.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded .mCSB_dragger_bar,
659
+ .mCS-rounded.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_dragger .mCSB_dragger_bar,
660
+ .mCS-rounded-dark.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded .mCSB_dragger_bar,
661
+ .mCS-rounded-dark.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_dragger .mCSB_dragger_bar{
662
+ width: 16px; /* auto-expanded scrollbar */
663
+ height: 16px;
664
+ margin: -1px 0;
665
+ }
666
+
667
+ .mCS-rounded.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded + .mCSB_draggerRail,
668
+ .mCS-rounded.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail,
669
+ .mCS-rounded-dark.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded + .mCSB_draggerRail,
670
+ .mCS-rounded-dark.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail{ width: 4px; /* auto-expanded scrollbar */ }
671
+
672
+ .mCS-rounded.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded .mCSB_dragger_bar,
673
+ .mCS-rounded.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_dragger .mCSB_dragger_bar,
674
+ .mCS-rounded-dark.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded .mCSB_dragger_bar,
675
+ .mCS-rounded-dark.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_dragger .mCSB_dragger_bar{
676
+ height: 16px; /* auto-expanded scrollbar */
677
+ width: 16px;
678
+ margin: 0 -1px;
679
+ }
680
+
681
+ .mCS-rounded.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded + .mCSB_draggerRail,
682
+ .mCS-rounded.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail,
683
+ .mCS-rounded-dark.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded + .mCSB_draggerRail,
684
+ .mCS-rounded-dark.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail{
685
+ height: 4px; /* auto-expanded scrollbar */
686
+ margin: 6px 0;
687
+ }
688
+
689
+ .mCS-rounded.mCSB_scrollTools .mCSB_buttonUp{ background-position: 0 -72px; }
690
+
691
+ .mCS-rounded.mCSB_scrollTools .mCSB_buttonDown{ background-position: 0 -92px; }
692
+
693
+ .mCS-rounded.mCSB_scrollTools .mCSB_buttonLeft{ background-position: 0 -112px; }
694
+
695
+ .mCS-rounded.mCSB_scrollTools .mCSB_buttonRight{ background-position: 0 -128px; }
696
+
697
+
698
+ /* theme "rounded-dark", "rounded-dots-dark" */
699
+
700
+ .mCS-rounded-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
701
+ .mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.75); }
702
+
703
+ .mCS-rounded-dark.mCSB_scrollTools .mCSB_draggerRail{ background-color: #000; background-color: rgba(0,0,0,0.15); }
704
+
705
+ .mCS-rounded-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar,
706
+ .mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.85); }
707
+
708
+ .mCS-rounded-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
709
+ .mCS-rounded-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,
710
+ .mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
711
+ .mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.9); }
712
+
713
+ .mCS-rounded-dark.mCSB_scrollTools .mCSB_buttonUp{ background-position: -80px -72px; }
714
+
715
+ .mCS-rounded-dark.mCSB_scrollTools .mCSB_buttonDown{ background-position: -80px -92px; }
716
+
717
+ .mCS-rounded-dark.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -80px -112px; }
718
+
719
+ .mCS-rounded-dark.mCSB_scrollTools .mCSB_buttonRight{ background-position: -80px -128px; }
720
+
721
+
722
+ /* theme "rounded-dots", "rounded-dots-dark" */
723
+
724
+ .mCS-rounded-dots.mCSB_scrollTools_vertical .mCSB_draggerRail,
725
+ .mCS-rounded-dots-dark.mCSB_scrollTools_vertical .mCSB_draggerRail{ width: 4px; }
726
+
727
+ .mCS-rounded-dots.mCSB_scrollTools .mCSB_draggerRail,
728
+ .mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_draggerRail,
729
+ .mCS-rounded-dots.mCSB_scrollTools_horizontal .mCSB_draggerRail,
730
+ .mCS-rounded-dots-dark.mCSB_scrollTools_horizontal .mCSB_draggerRail{
731
+ background-color: transparent;
732
+ background-position: center;
733
+ }
734
+
735
+ .mCS-rounded-dots.mCSB_scrollTools .mCSB_draggerRail,
736
+ .mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_draggerRail{
737
+ background-image: url("");
738
+ background-repeat: repeat-y;
739
+ opacity: 0.3;
740
+ filter: "alpha(opacity=30)"; -ms-filter: "alpha(opacity=30)";
741
+ }
742
+
743
+ .mCS-rounded-dots.mCSB_scrollTools_horizontal .mCSB_draggerRail,
744
+ .mCS-rounded-dots-dark.mCSB_scrollTools_horizontal .mCSB_draggerRail{
745
+ height: 4px;
746
+ margin: 6px 0;
747
+ background-repeat: repeat-x;
748
+ }
749
+
750
+ .mCS-rounded-dots.mCSB_scrollTools .mCSB_buttonUp{ background-position: -16px -72px; }
751
+
752
+ .mCS-rounded-dots.mCSB_scrollTools .mCSB_buttonDown{ background-position: -16px -92px; }
753
+
754
+ .mCS-rounded-dots.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -20px -112px; }
755
+
756
+ .mCS-rounded-dots.mCSB_scrollTools .mCSB_buttonRight{ background-position: -20px -128px; }
757
+
758
+
759
+ /* theme "rounded-dots-dark" */
760
+
761
+ .mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_draggerRail{
762
+ background-image: url("");
763
+ }
764
+
765
+ .mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_buttonUp{ background-position: -96px -72px; }
766
+
767
+ .mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_buttonDown{ background-position: -96px -92px; }
768
+
769
+ .mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -100px -112px; }
770
+
771
+ .mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_buttonRight{ background-position: -100px -128px; }
772
+
773
+ /* ---------------------------------------- */
774
+
775
+
776
+
777
+ /* theme "3d", "3d-dark", "3d-thick", "3d-thick-dark" */
778
+
779
+ .mCS-3d.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
780
+ .mCS-3d-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
781
+ .mCS-3d-thick.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
782
+ .mCS-3d-thick-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
783
+ background-repeat: repeat-y;
784
+ background-image: -moz-linear-gradient(left, rgba(255,255,255,0.5) 0%, rgba(255,255,255,0) 100%);
785
+ background-image: -webkit-gradient(linear, left top, right top, color-stop(0%,rgba(255,255,255,0.5)), color-stop(100%,rgba(255,255,255,0)));
786
+ background-image: -webkit-linear-gradient(left, rgba(255,255,255,0.5) 0%,rgba(255,255,255,0) 100%);
787
+ background-image: -o-linear-gradient(left, rgba(255,255,255,0.5) 0%,rgba(255,255,255,0) 100%);
788
+ background-image: -ms-linear-gradient(left, rgba(255,255,255,0.5) 0%,rgba(255,255,255,0) 100%);
789
+ background-image: linear-gradient(to right, rgba(255,255,255,0.5) 0%,rgba(255,255,255,0) 100%);
790
+ }
791
+
792
+ .mCS-3d.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
793
+ .mCS-3d-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
794
+ .mCS-3d-thick.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
795
+ .mCS-3d-thick-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{
796
+ background-repeat: repeat-x;
797
+ background-image: -moz-linear-gradient(top, rgba(255,255,255,0.5) 0%, rgba(255,255,255,0) 100%);
798
+ background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(255,255,255,0.5)), color-stop(100%,rgba(255,255,255,0)));
799
+ background-image: -webkit-linear-gradient(top, rgba(255,255,255,0.5) 0%,rgba(255,255,255,0) 100%);
800
+ background-image: -o-linear-gradient(top, rgba(255,255,255,0.5) 0%,rgba(255,255,255,0) 100%);
801
+ background-image: -ms-linear-gradient(top, rgba(255,255,255,0.5) 0%,rgba(255,255,255,0) 100%);
802
+ background-image: linear-gradient(to bottom, rgba(255,255,255,0.5) 0%,rgba(255,255,255,0) 100%);
803
+ }
804
+
805
+
806
+ /* theme "3d", "3d-dark" */
807
+
808
+ .mCS-3d.mCSB_scrollTools_vertical .mCSB_dragger,
809
+ .mCS-3d-dark.mCSB_scrollTools_vertical .mCSB_dragger{ height: 70px; }
810
+
811
+ .mCS-3d.mCSB_scrollTools_horizontal .mCSB_dragger,
812
+ .mCS-3d-dark.mCSB_scrollTools_horizontal .mCSB_dragger{ width: 70px; }
813
+
814
+ .mCS-3d.mCSB_scrollTools,
815
+ .mCS-3d-dark.mCSB_scrollTools{
816
+ opacity: 1;
817
+ filter: "alpha(opacity=30)"; -ms-filter: "alpha(opacity=30)";
818
+ }
819
+
820
+ .mCS-3d.mCSB_scrollTools .mCSB_draggerRail,
821
+ .mCS-3d.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
822
+ .mCS-3d-dark.mCSB_scrollTools .mCSB_draggerRail,
823
+ .mCS-3d-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{ -webkit-border-radius: 16px; -moz-border-radius: 16px; border-radius: 16px; }
824
+
825
+ .mCS-3d.mCSB_scrollTools .mCSB_draggerRail,
826
+ .mCS-3d-dark.mCSB_scrollTools .mCSB_draggerRail{
827
+ width: 8px;
828
+ background-color: #000; background-color: rgba(0,0,0,0.2);
829
+ box-shadow: inset 1px 0 1px rgba(0,0,0,0.5), inset -1px 0 1px rgba(255,255,255,0.2);
830
+ }
831
+
832
+ .mCS-3d.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
833
+ .mCS-3d.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar,
834
+ .mCS-3d.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
835
+ .mCS-3d.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,
836
+ .mCS-3d-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
837
+ .mCS-3d-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar,
838
+ .mCS-3d-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
839
+ .mCS-3d-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{ background-color: #555; }
840
+
841
+ .mCS-3d.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
842
+ .mCS-3d-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{ width: 8px; }
843
+
844
+ .mCS-3d.mCSB_scrollTools_horizontal .mCSB_draggerRail,
845
+ .mCS-3d-dark.mCSB_scrollTools_horizontal .mCSB_draggerRail{
846
+ width: 100%;
847
+ height: 8px;
848
+ margin: 4px 0;
849
+ box-shadow: inset 0 1px 1px rgba(0,0,0,0.5), inset 0 -1px 1px rgba(255,255,255,0.2);
850
+ }
851
+
852
+ .mCS-3d.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
853
+ .mCS-3d-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{
854
+ width: 100%;
855
+ height: 8px;
856
+ margin: 4px auto;
857
+ }
858
+
859
+ .mCS-3d.mCSB_scrollTools .mCSB_buttonUp{ background-position: -32px -72px; }
860
+
861
+ .mCS-3d.mCSB_scrollTools .mCSB_buttonDown{ background-position: -32px -92px; }
862
+
863
+ .mCS-3d.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -40px -112px; }
864
+
865
+ .mCS-3d.mCSB_scrollTools .mCSB_buttonRight{ background-position: -40px -128px; }
866
+
867
+
868
+ /* theme "3d-dark" */
869
+
870
+ .mCS-3d-dark.mCSB_scrollTools .mCSB_draggerRail{
871
+ background-color: #000; background-color: rgba(0,0,0,0.1);
872
+ box-shadow: inset 1px 0 1px rgba(0,0,0,0.1);
873
+ }
874
+
875
+ .mCS-3d-dark.mCSB_scrollTools_horizontal .mCSB_draggerRail{ box-shadow: inset 0 1px 1px rgba(0,0,0,0.1); }
876
+
877
+ .mCS-3d-dark.mCSB_scrollTools .mCSB_buttonUp{ background-position: -112px -72px; }
878
+
879
+ .mCS-3d-dark.mCSB_scrollTools .mCSB_buttonDown{ background-position: -112px -92px; }
880
+
881
+ .mCS-3d-dark.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -120px -112px; }
882
+
883
+ .mCS-3d-dark.mCSB_scrollTools .mCSB_buttonRight{ background-position: -120px -128px; }
884
+
885
+ /* ---------------------------------------- */
886
+
887
+
888
+
889
+ /* theme: "3d-thick", "3d-thick-dark" */
890
+
891
+ .mCS-3d-thick.mCSB_scrollTools,
892
+ .mCS-3d-thick-dark.mCSB_scrollTools{
893
+ opacity: 1;
894
+ filter: "alpha(opacity=30)"; -ms-filter: "alpha(opacity=30)";
895
+ }
896
+
897
+ .mCS-3d-thick.mCSB_scrollTools,
898
+ .mCS-3d-thick-dark.mCSB_scrollTools,
899
+ .mCS-3d-thick.mCSB_scrollTools .mCSB_draggerContainer,
900
+ .mCS-3d-thick-dark.mCSB_scrollTools .mCSB_draggerContainer{ -webkit-border-radius: 7px; -moz-border-radius: 7px; border-radius: 7px; }
901
+
902
+ .mCS-3d-thick.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
903
+ .mCS-3d-thick-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{ -webkit-border-radius: 5px; -moz-border-radius: 5px; border-radius: 5px; }
904
+
905
+ .mCSB_inside + .mCS-3d-thick.mCSB_scrollTools_vertical,
906
+ .mCSB_inside + .mCS-3d-thick-dark.mCSB_scrollTools_vertical{ right: 1px; }
907
+
908
+ .mCS-3d-thick.mCSB_scrollTools_vertical,
909
+ .mCS-3d-thick-dark.mCSB_scrollTools_vertical{ box-shadow: inset 1px 0 1px rgba(0,0,0,0.1), inset 0 0 14px rgba(0,0,0,0.5); }
910
+
911
+ .mCS-3d-thick.mCSB_scrollTools_horizontal,
912
+ .mCS-3d-thick-dark.mCSB_scrollTools_horizontal{
913
+ bottom: 1px;
914
+ box-shadow: inset 0 1px 1px rgba(0,0,0,0.1), inset 0 0 14px rgba(0,0,0,0.5);
915
+ }
916
+
917
+ .mCS-3d-thick.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
918
+ .mCS-3d-thick-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
919
+ box-shadow: inset 1px 0 0 rgba(255,255,255,0.4);
920
+ width: 12px;
921
+ margin: 2px;
922
+ position: absolute;
923
+ height: auto;
924
+ top: 0;
925
+ bottom: 0;
926
+ left: 0;
927
+ right: 0;
928
+ }
929
+
930
+ .mCS-3d-thick.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
931
+ .mCS-3d-thick-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{ box-shadow: inset 0 1px 0 rgba(255,255,255,0.4); }
932
+
933
+ .mCS-3d-thick.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
934
+ .mCS-3d-thick.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar,
935
+ .mCS-3d-thick.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
936
+ .mCS-3d-thick.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{ background-color: #555; }
937
+
938
+ .mCS-3d-thick.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
939
+ .mCS-3d-thick-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{
940
+ height: 12px;
941
+ width: auto;
942
+ }
943
+
944
+ .mCS-3d-thick.mCSB_scrollTools .mCSB_draggerContainer{
945
+ background-color: #000; background-color: rgba(0,0,0,0.05);
946
+ box-shadow: inset 1px 1px 16px rgba(0,0,0,0.1);
947
+ }
948
+
949
+ .mCS-3d-thick.mCSB_scrollTools .mCSB_draggerRail{ background-color: transparent; }
950
+
951
+ .mCS-3d-thick.mCSB_scrollTools .mCSB_buttonUp{ background-position: -32px -72px; }
952
+
953
+ .mCS-3d-thick.mCSB_scrollTools .mCSB_buttonDown{ background-position: -32px -92px; }
954
+
955
+ .mCS-3d-thick.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -40px -112px; }
956
+
957
+ .mCS-3d-thick.mCSB_scrollTools .mCSB_buttonRight{ background-position: -40px -128px; }
958
+
959
+
960
+ /* theme: "3d-thick-dark" */
961
+
962
+ .mCS-3d-thick-dark.mCSB_scrollTools{ box-shadow: inset 0 0 14px rgba(0,0,0,0.2); }
963
+
964
+ .mCS-3d-thick-dark.mCSB_scrollTools_horizontal{ box-shadow: inset 0 1px 1px rgba(0,0,0,0.1), inset 0 0 14px rgba(0,0,0,0.2); }
965
+
966
+ .mCS-3d-thick-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{ box-shadow: inset 1px 0 0 rgba(255,255,255,0.4), inset -1px 0 0 rgba(0,0,0,0.2); }
967
+
968
+ .mCS-3d-thick-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{ box-shadow: inset 0 1px 0 rgba(255,255,255,0.4), inset 0 -1px 0 rgba(0,0,0,0.2); }
969
+
970
+ .mCS-3d-thick-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
971
+ .mCS-3d-thick-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar,
972
+ .mCS-3d-thick-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
973
+ .mCS-3d-thick-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{ background-color: #777; }
974
+
975
+ .mCS-3d-thick-dark.mCSB_scrollTools .mCSB_draggerContainer{
976
+ background-color: #fff; background-color: rgba(0,0,0,0.05);
977
+ box-shadow: inset 1px 1px 16px rgba(0,0,0,0.1);
978
+ }
979
+
980
+ .mCS-3d-thick-dark.mCSB_scrollTools .mCSB_draggerRail{ background-color: transparent; }
981
+
982
+ .mCS-3d-thick-dark.mCSB_scrollTools .mCSB_buttonUp{ background-position: -112px -72px; }
983
+
984
+ .mCS-3d-thick-dark.mCSB_scrollTools .mCSB_buttonDown{ background-position: -112px -92px; }
985
+
986
+ .mCS-3d-thick-dark.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -120px -112px; }
987
+
988
+ .mCS-3d-thick-dark.mCSB_scrollTools .mCSB_buttonRight{ background-position: -120px -128px; }
989
+
990
+ /* ---------------------------------------- */
991
+
992
+
993
+
994
+ /* theme: "minimal", "minimal-dark" */
995
+
996
+ .mCSB_outside + .mCS-minimal.mCSB_scrollTools_vertical,
997
+ .mCSB_outside + .mCS-minimal-dark.mCSB_scrollTools_vertical{
998
+ right: 0;
999
+ margin: 12px 0;
1000
+ }
1001
+
1002
+ .mCustomScrollBox.mCS-minimal + .mCSB_scrollTools.mCSB_scrollTools_horizontal,
1003
+ .mCustomScrollBox.mCS-minimal + .mCSB_scrollTools + .mCSB_scrollTools.mCSB_scrollTools_horizontal,
1004
+ .mCustomScrollBox.mCS-minimal-dark + .mCSB_scrollTools.mCSB_scrollTools_horizontal,
1005
+ .mCustomScrollBox.mCS-minimal-dark + .mCSB_scrollTools + .mCSB_scrollTools.mCSB_scrollTools_horizontal{
1006
+ bottom: 0;
1007
+ margin: 0 12px;
1008
+ }
1009
+
1010
+ /* RTL direction/left-side scrollbar */
1011
+ .mCS-dir-rtl > .mCSB_outside + .mCS-minimal.mCSB_scrollTools_vertical,
1012
+ .mCS-dir-rtl > .mCSB_outside + .mCS-minimal-dark.mCSB_scrollTools_vertical{
1013
+ left: 0;
1014
+ right: auto;
1015
+ }
1016
+
1017
+ .mCS-minimal.mCSB_scrollTools .mCSB_draggerRail,
1018
+ .mCS-minimal-dark.mCSB_scrollTools .mCSB_draggerRail{ background-color: transparent; }
1019
+
1020
+ .mCS-minimal.mCSB_scrollTools_vertical .mCSB_dragger,
1021
+ .mCS-minimal-dark.mCSB_scrollTools_vertical .mCSB_dragger{ height: 50px; }
1022
+
1023
+ .mCS-minimal.mCSB_scrollTools_horizontal .mCSB_dragger,
1024
+ .mCS-minimal-dark.mCSB_scrollTools_horizontal .mCSB_dragger{ width: 50px; }
1025
+
1026
+ .mCS-minimal.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
1027
+ background-color: #fff; background-color: rgba(255,255,255,0.2);
1028
+ filter: "alpha(opacity=20)"; -ms-filter: "alpha(opacity=20)";
1029
+ }
1030
+
1031
+ .mCS-minimal.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
1032
+ .mCS-minimal.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
1033
+ background-color: #fff; background-color: rgba(255,255,255,0.5);
1034
+ filter: "alpha(opacity=50)"; -ms-filter: "alpha(opacity=50)";
1035
+ }
1036
+
1037
+
1038
+ /* theme: "minimal-dark" */
1039
+
1040
+ .mCS-minimal-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
1041
+ background-color: #000; background-color: rgba(0,0,0,0.2);
1042
+ filter: "alpha(opacity=20)"; -ms-filter: "alpha(opacity=20)";
1043
+ }
1044
+
1045
+ .mCS-minimal-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
1046
+ .mCS-minimal-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{
1047
+ background-color: #000; background-color: rgba(0,0,0,0.5);
1048
+ filter: "alpha(opacity=50)"; -ms-filter: "alpha(opacity=50)";
1049
+ }
1050
+
1051
+ /* ---------------------------------------- */
1052
+
1053
+
1054
+
1055
+ /* theme "light-3", "dark-3" */
1056
+
1057
+ .mCS-light-3.mCSB_scrollTools .mCSB_draggerRail,
1058
+ .mCS-dark-3.mCSB_scrollTools .mCSB_draggerRail{
1059
+ width: 6px;
1060
+ background-color: #000; background-color: rgba(0,0,0,0.2);
1061
+ }
1062
+
1063
+ .mCS-light-3.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
1064
+ .mCS-dark-3.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{ width: 6px; }
1065
+
1066
+ .mCS-light-3.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
1067
+ .mCS-dark-3.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
1068
+ .mCS-light-3.mCSB_scrollTools_horizontal .mCSB_draggerRail,
1069
+ .mCS-dark-3.mCSB_scrollTools_horizontal .mCSB_draggerRail{
1070
+ width: 100%;
1071
+ height: 6px;
1072
+ margin: 5px 0;
1073
+ }
1074
+
1075
+ .mCS-light-3.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded + .mCSB_draggerRail,
1076
+ .mCS-light-3.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail,
1077
+ .mCS-dark-3.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded + .mCSB_draggerRail,
1078
+ .mCS-dark-3.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail{
1079
+ width: 12px;
1080
+ }
1081
+
1082
+ .mCS-light-3.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded + .mCSB_draggerRail,
1083
+ .mCS-light-3.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail,
1084
+ .mCS-dark-3.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded + .mCSB_draggerRail,
1085
+ .mCS-dark-3.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail{
1086
+ height: 12px;
1087
+ margin: 2px 0;
1088
+ }
1089
+
1090
+ .mCS-light-3.mCSB_scrollTools .mCSB_buttonUp{ background-position: -32px -72px; }
1091
+
1092
+ .mCS-light-3.mCSB_scrollTools .mCSB_buttonDown{ background-position: -32px -92px; }
1093
+
1094
+ .mCS-light-3.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -40px -112px; }
1095
+
1096
+ .mCS-light-3.mCSB_scrollTools .mCSB_buttonRight{ background-position: -40px -128px; }
1097
+
1098
+
1099
+ /* theme "dark-3" */
1100
+
1101
+ .mCS-dark-3.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.75); }
1102
+
1103
+ .mCS-dark-3.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.85); }
1104
+
1105
+ .mCS-dark-3.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
1106
+ .mCS-dark-3.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.9); }
1107
+
1108
+ .mCS-dark-3.mCSB_scrollTools .mCSB_draggerRail{ background-color: #000; background-color: rgba(0,0,0,0.1); }
1109
+
1110
+ .mCS-dark-3.mCSB_scrollTools .mCSB_buttonUp{ background-position: -112px -72px; }
1111
+
1112
+ .mCS-dark-3.mCSB_scrollTools .mCSB_buttonDown{ background-position: -112px -92px; }
1113
+
1114
+ .mCS-dark-3.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -120px -112px; }
1115
+
1116
+ .mCS-dark-3.mCSB_scrollTools .mCSB_buttonRight{ background-position: -120px -128px; }
1117
+
1118
+ /* ---------------------------------------- */
1119
+
1120
+
1121
+
1122
+ /* theme "inset", "inset-dark", "inset-2", "inset-2-dark", "inset-3", "inset-3-dark" */
1123
+
1124
+ .mCS-inset.mCSB_scrollTools .mCSB_draggerRail,
1125
+ .mCS-inset-dark.mCSB_scrollTools .mCSB_draggerRail,
1126
+ .mCS-inset-2.mCSB_scrollTools .mCSB_draggerRail,
1127
+ .mCS-inset-2-dark.mCSB_scrollTools .mCSB_draggerRail,
1128
+ .mCS-inset-3.mCSB_scrollTools .mCSB_draggerRail,
1129
+ .mCS-inset-3-dark.mCSB_scrollTools .mCSB_draggerRail{
1130
+ width: 12px;
1131
+ background-color: #000; background-color: rgba(0,0,0,0.2);
1132
+ }
1133
+
1134
+ .mCS-inset.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
1135
+ .mCS-inset-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
1136
+ .mCS-inset-2.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
1137
+ .mCS-inset-2-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
1138
+ .mCS-inset-3.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
1139
+ .mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
1140
+ width: 6px;
1141
+ margin: 3px 5px;
1142
+ position: absolute;
1143
+ height: auto;
1144
+ top: 0;
1145
+ bottom: 0;
1146
+ left: 0;
1147
+ right: 0;
1148
+ }
1149
+
1150
+ .mCS-inset.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
1151
+ .mCS-inset-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
1152
+ .mCS-inset-2.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
1153
+ .mCS-inset-2-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
1154
+ .mCS-inset-3.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,
1155
+ .mCS-inset-3-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{
1156
+ height: 6px;
1157
+ margin: 5px 3px;
1158
+ position: absolute;
1159
+ width: auto;
1160
+ top: 0;
1161
+ bottom: 0;
1162
+ left: 0;
1163
+ right: 0;
1164
+ }
1165
+
1166
+ .mCS-inset.mCSB_scrollTools_horizontal .mCSB_draggerRail,
1167
+ .mCS-inset-dark.mCSB_scrollTools_horizontal .mCSB_draggerRail,
1168
+ .mCS-inset-2.mCSB_scrollTools_horizontal .mCSB_draggerRail,
1169
+ .mCS-inset-2-dark.mCSB_scrollTools_horizontal .mCSB_draggerRail,
1170
+ .mCS-inset-3.mCSB_scrollTools_horizontal .mCSB_draggerRail,
1171
+ .mCS-inset-3-dark.mCSB_scrollTools_horizontal .mCSB_draggerRail{
1172
+ width: 100%;
1173
+ height: 12px;
1174
+ margin: 2px 0;
1175
+ }
1176
+
1177
+ .mCS-inset.mCSB_scrollTools .mCSB_buttonUp,
1178
+ .mCS-inset-2.mCSB_scrollTools .mCSB_buttonUp,
1179
+ .mCS-inset-3.mCSB_scrollTools .mCSB_buttonUp{ background-position: -32px -72px; }
1180
+
1181
+ .mCS-inset.mCSB_scrollTools .mCSB_buttonDown,
1182
+ .mCS-inset-2.mCSB_scrollTools .mCSB_buttonDown,
1183
+ .mCS-inset-3.mCSB_scrollTools .mCSB_buttonDown{ background-position: -32px -92px; }
1184
+
1185
+ .mCS-inset.mCSB_scrollTools .mCSB_buttonLeft,
1186
+ .mCS-inset-2.mCSB_scrollTools .mCSB_buttonLeft,
1187
+ .mCS-inset-3.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -40px -112px; }
1188
+
1189
+ .mCS-inset.mCSB_scrollTools .mCSB_buttonRight,
1190
+ .mCS-inset-2.mCSB_scrollTools .mCSB_buttonRight,
1191
+ .mCS-inset-3.mCSB_scrollTools .mCSB_buttonRight{ background-position: -40px -128px; }
1192
+
1193
+
1194
+ /* theme "inset-dark", "inset-2-dark", "inset-3-dark" */
1195
+
1196
+ .mCS-inset-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
1197
+ .mCS-inset-2-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,
1198
+ .mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.75); }
1199
+
1200
+ .mCS-inset-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar,
1201
+ .mCS-inset-2-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar,
1202
+ .mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.85); }
1203
+
1204
+ .mCS-inset-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
1205
+ .mCS-inset-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,
1206
+ .mCS-inset-2-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
1207
+ .mCS-inset-2-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,
1208
+ .mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
1209
+ .mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.9); }
1210
+
1211
+ .mCS-inset-dark.mCSB_scrollTools .mCSB_draggerRail,
1212
+ .mCS-inset-2-dark.mCSB_scrollTools .mCSB_draggerRail,
1213
+ .mCS-inset-3-dark.mCSB_scrollTools .mCSB_draggerRail{ background-color: #000; background-color: rgba(0,0,0,0.1); }
1214
+
1215
+ .mCS-inset-dark.mCSB_scrollTools .mCSB_buttonUp,
1216
+ .mCS-inset-2-dark.mCSB_scrollTools .mCSB_buttonUp,
1217
+ .mCS-inset-3-dark.mCSB_scrollTools .mCSB_buttonUp{ background-position: -112px -72px; }
1218
+
1219
+ .mCS-inset-dark.mCSB_scrollTools .mCSB_buttonDown,
1220
+ .mCS-inset-2-dark.mCSB_scrollTools .mCSB_buttonDown,
1221
+ .mCS-inset-3-dark.mCSB_scrollTools .mCSB_buttonDown{ background-position: -112px -92px; }
1222
+
1223
+ .mCS-inset-dark.mCSB_scrollTools .mCSB_buttonLeft,
1224
+ .mCS-inset-2-dark.mCSB_scrollTools .mCSB_buttonLeft,
1225
+ .mCS-inset-3-dark.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -120px -112px; }
1226
+
1227
+ .mCS-inset-dark.mCSB_scrollTools .mCSB_buttonRight,
1228
+ .mCS-inset-2-dark.mCSB_scrollTools .mCSB_buttonRight,
1229
+ .mCS-inset-3-dark.mCSB_scrollTools .mCSB_buttonRight{ background-position: -120px -128px; }
1230
+
1231
+
1232
+ /* theme "inset-2", "inset-2-dark" */
1233
+
1234
+ .mCS-inset-2.mCSB_scrollTools .mCSB_draggerRail,
1235
+ .mCS-inset-2-dark.mCSB_scrollTools .mCSB_draggerRail{
1236
+ background-color: transparent;
1237
+ border-width: 1px;
1238
+ border-style: solid;
1239
+ border-color: #fff;
1240
+ border-color: rgba(255,255,255,0.2);
1241
+ -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box;
1242
+ }
1243
+
1244
+ .mCS-inset-2-dark.mCSB_scrollTools .mCSB_draggerRail{ border-color: #000; border-color: rgba(0,0,0,0.2); }
1245
+
1246
+
1247
+ /* theme "inset-3", "inset-3-dark" */
1248
+
1249
+ .mCS-inset-3.mCSB_scrollTools .mCSB_draggerRail{ background-color: #fff; background-color: rgba(255,255,255,0.6); }
1250
+
1251
+ .mCS-inset-3-dark.mCSB_scrollTools .mCSB_draggerRail{ background-color: #000; background-color: rgba(0,0,0,0.6); }
1252
+
1253
+ .mCS-inset-3.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.75); }
1254
+
1255
+ .mCS-inset-3.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.85); }
1256
+
1257
+ .mCS-inset-3.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
1258
+ .mCS-inset-3.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{ background-color: #000; background-color: rgba(0,0,0,0.9); }
1259
+
1260
+ .mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{ background-color: #fff; background-color: rgba(255,255,255,0.75); }
1261
+
1262
+ .mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{ background-color: #fff; background-color: rgba(255,255,255,0.85); }
1263
+
1264
+ .mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
1265
+ .mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{ background-color: #fff; background-color: rgba(255,255,255,0.9); }
1266
+
1267
+ /* ---------------------------------------- */
css/jquery.mCustomScrollbar.min.css CHANGED
@@ -1 +1 @@
1
- .mCSB_container{width:auto;margin-right:15px;overflow:hidden}.mCSB_container.mCS_no_scrollbar{margin-right:0}.mCS_destroyed>.mCustomScrollBox>.mCSB_container.mCS_no_scrollbar,.mCS_disabled>.mCustomScrollBox>.mCSB_container.mCS_no_scrollbar{margin-right:15px}.mCustomScrollBox>.mCSB_scrollTools{width:16px;height:100%;top:0;right:0;opacity:.75}.mCSB_scrollTools .mCSB_draggerContainer{position:absolute;top:0;left:0;bottom:0;right:0;height:auto}.mCSB_scrollTools a+.mCSB_draggerContainer{margin:20px 0}.mCSB_scrollTools .mCSB_draggerRail{width:2px;height:100%;margin:0 auto;-webkit-border-radius:10px;-moz-border-radius:10px;border-radius:10px}.mCSB_scrollTools .mCSB_dragger{cursor:pointer;width:100%;height:30px}.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:4px;height:100%;margin:0 auto;-webkit-border-radius:10px;-moz-border-radius:10px;border-radius:10px;text-align:center}.mCSB_scrollTools .mCSB_buttonDown,.mCSB_scrollTools .mCSB_buttonUp{display:block;position:relative;height:20px;overflow:hidden;margin:0 auto;cursor:pointer}.mCSB_scrollTools .mCSB_buttonDown{top:100%;margin-top:-40px}.mCSB_horizontal>.mCSB_container{height:auto;margin-right:0;margin-bottom:30px;overflow:hidden}.mCSB_horizontal>.mCSB_container.mCS_no_scrollbar{margin-bottom:0}.mCS_destroyed>.mCSB_horizontal>.mCSB_container.mCS_no_scrollbar,.mCS_disabled>.mCSB_horizontal>.mCSB_container.mCS_no_scrollbar{margin-right:0;margin-bottom:30px}.mCSB_horizontal.mCustomScrollBox>.mCSB_scrollTools{width:100%;height:16px;top:auto;right:auto;bottom:0;left:0;overflow:hidden}.mCSB_horizontal>.mCSB_scrollTools a+.mCSB_draggerContainer{margin:0 20px}.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{width:100%;height:2px;margin:7px 0;-webkit-border-radius:10px;-moz-border-radius:10px;border-radius:10px}.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger{width:30px;height:100%}.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:100%;height:4px;margin:6px auto;-webkit-border-radius:10px;-moz-border-radius:10px;border-radius:10px}.mCSB_horizontal>.mCSB_scrollTools .mCSB_buttonLeft,.mCSB_horizontal>.mCSB_scrollTools .mCSB_buttonRight{display:block;position:relative;width:20px;height:100%;overflow:hidden;margin:0 auto;cursor:pointer;float:left}.mCSB_horizontal>.mCSB_scrollTools .mCSB_buttonRight{margin-left:-40px;float:right}.mCustomScrollBox{-ms-touch-action:none}.mCustomScrollBox:hover>.mCSB_scrollTools{opacity:1;}.mCSB_scrollTools .mCSB_draggerRail{background:#000;background:rgba(0,0,0,.4);}.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{background:#fff;background:rgba(255,255,255,.75);}.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background:rgba(255,255,255,.85);}.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background:rgba(255,255,255,.9);}.mCSB_scrollTools .mCSB_buttonDown,.mCSB_scrollTools .mCSB_buttonLeft,.mCSB_scrollTools .mCSB_buttonRight,.mCSB_scrollTools .mCSB_buttonUp{background-repeat:no-repeat;opacity:.4;}.mCSB_scrollTools .mCSB_buttonUp{background-position:0 0}.mCSB_scrollTools .mCSB_buttonDown{background-position:0 -20px}.mCSB_scrollTools .mCSB_buttonLeft{background-position:0 -40px}.mCSB_scrollTools .mCSB_buttonRight{background-position:0 -56px}.mCSB_scrollTools .mCSB_buttonDown:hover,.mCSB_scrollTools .mCSB_buttonLeft:hover,.mCSB_scrollTools .mCSB_buttonRight:hover,.mCSB_scrollTools .mCSB_buttonUp:hover{opacity:.75;}.mCSB_scrollTools .mCSB_buttonDown:active,.mCSB_scrollTools .mCSB_buttonLeft:active,.mCSB_scrollTools .mCSB_buttonRight:active,.mCSB_scrollTools .mCSB_buttonUp:active{opacity:.9;}.mCS-dark>.mCSB_scrollTools .mCSB_draggerRail{background:#000;background:rgba(0,0,0,.15)}.mCS-dark>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{background:#000;background:rgba(0,0,0,.75)}.mCS-dark>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background:rgba(0,0,0,.85)}.mCS-dark>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-dark>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background:rgba(0,0,0,.9)}.mCS-dark>.mCSB_scrollTools .mCSB_buttonUp{background-position:-80px 0}.mCS-dark>.mCSB_scrollTools .mCSB_buttonDown{background-position:-80px -20px}.mCS-dark>.mCSB_scrollTools .mCSB_buttonLeft{background-position:-80px -40px}.mCS-dark>.mCSB_scrollTools .mCSB_buttonRight{background-position:-80px -56px}.mCS-light-2>.mCSB_scrollTools .mCSB_draggerRail{width:4px;background:#fff;background:rgba(255,255,255,.1);-webkit-border-radius:1px;-moz-border-radius:1px;border-radius:1px}.mCS-light-2>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:4px;background:#fff;background:rgba(255,255,255,.75);-webkit-border-radius:1px;-moz-border-radius:1px;border-radius:1px}.mCS-light-2.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{width:100%;height:4px;margin:6px 0}.mCS-light-2.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:100%;height:4px;margin:6px auto}.mCS-light-2>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background:rgba(255,255,255,.85)}.mCS-light-2>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-light-2>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background:rgba(255,255,255,.9)}.mCS-light-2>.mCSB_scrollTools .mCSB_buttonUp{background-position:-32px 0}.mCS-light-2>.mCSB_scrollTools .mCSB_buttonDown{background-position:-32px -20px}.mCS-light-2>.mCSB_scrollTools .mCSB_buttonLeft{background-position:-40px -40px}.mCS-light-2>.mCSB_scrollTools .mCSB_buttonRight{background-position:-40px -56px}.mCS-dark-2>.mCSB_scrollTools .mCSB_draggerRail{width:4px;background:#000;background:rgba(0,0,0,.1);-webkit-border-radius:1px;-moz-border-radius:1px;border-radius:1px}.mCS-dark-2>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:4px;background:#000;background:rgba(0,0,0,.75);-webkit-border-radius:1px;-moz-border-radius:1px;border-radius:1px}.mCS-dark-2.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{width:100%;height:4px;margin:6px 0}.mCS-dark-2.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:100%;height:4px;margin:6px auto}.mCS-dark-2>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background:rgba(0,0,0,.85)}.mCS-dark-2>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-dark-2>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background:rgba(0,0,0,.9)}.mCS-dark-2>.mCSB_scrollTools .mCSB_buttonUp{background-position:-112px 0}.mCS-dark-2>.mCSB_scrollTools .mCSB_buttonDown{background-position:-112px -20px}.mCS-dark-2>.mCSB_scrollTools .mCSB_buttonLeft{background-position:-120px -40px}.mCS-dark-2>.mCSB_scrollTools .mCSB_buttonRight{background-position:-120px -56px}.mCS-light-thick>.mCSB_scrollTools .mCSB_draggerRail{width:4px;background:#fff;background:rgba(255,255,255,.1);-webkit-border-radius:2px;-moz-border-radius:2px;border-radius:2px}.mCS-light-thick>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:6px;background:#fff;background:rgba(255,255,255,.75);-webkit-border-radius:2px;-moz-border-radius:2px;border-radius:2px}.mCS-light-thick.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{width:100%;height:4px;margin:6px 0}.mCS-light-thick.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:100%;height:6px;margin:5px auto}.mCS-light-thick>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background:rgba(255,255,255,.85)}.mCS-light-thick>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-light-thick>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background:rgba(255,255,255,.9)}.mCS-light-thick>.mCSB_scrollTools .mCSB_buttonUp{background-position:-16px 0}.mCS-light-thick>.mCSB_scrollTools .mCSB_buttonDown{background-position:-16px -20px}.mCS-light-thick>.mCSB_scrollTools .mCSB_buttonLeft{background-position:-20px -40px}.mCS-light-thick>.mCSB_scrollTools .mCSB_buttonRight{background-position:-20px -56px}.mCS-dark-thick>.mCSB_scrollTools .mCSB_draggerRail{width:4px;background:#000;background:rgba(0,0,0,.1);-webkit-border-radius:2px;-moz-border-radius:2px;border-radius:2px}.mCS-dark-thick>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:6px;background:#000;background:rgba(0,0,0,.75);-webkit-border-radius:2px;-moz-border-radius:2px;border-radius:2px}.mCS-dark-thick.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{width:100%;height:4px;margin:6px 0}.mCS-dark-thick.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:100%;height:6px;margin:5px auto}.mCS-dark-thick>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background:rgba(0,0,0,.85)}.mCS-dark-thick>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-dark-thick>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background:rgba(0,0,0,.9)}.mCS-dark-thick>.mCSB_scrollTools .mCSB_buttonUp{background-position:-96px 0}.mCS-dark-thick>.mCSB_scrollTools .mCSB_buttonDown{background-position:-96px -20px}.mCS-dark-thick>.mCSB_scrollTools .mCSB_buttonLeft{background-position:-100px -40px}.mCS-dark-thick>.mCSB_scrollTools .mCSB_buttonRight{background-position:-100px -56px}.mCS-light-thin>.mCSB_scrollTools .mCSB_draggerRail{background:#fff;background:rgba(255,255,255,.1)}.mCS-light-thin>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:2px}.mCS-light-thin.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{width:100%}.mCS-light-thin.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:100%;height:2px;margin:7px auto}.mCS-dark-thin>.mCSB_scrollTools .mCSB_draggerRail{background:#000;background:rgba(0,0,0,.15)}.mCS-dark-thin>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:2px;background:#000;background:rgba(0,0,0,.75)}.mCS-dark-thin.mCSB_horizontal>.mCSB_scrollTools .mCSB_draggerRail{width:100%}.mCS-dark-thin.mCSB_horizontal>.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:100%;height:2px;margin:7px auto}.mCS-dark-thin>.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background:rgba(0,0,0,.85)}.mCS-dark-thin>.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-dark-thin>.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background:rgba(0,0,0,.9)}.mCS-dark-thin>.mCSB_scrollTools .mCSB_buttonUp{background-position:-80px 0}.mCS-dark-thin>.mCSB_scrollTools .mCSB_buttonDown{background-position:-80px -20px}.mCS-dark-thin>.mCSB_scrollTools .mCSB_buttonLeft{background-position:-80px -40px}.mCS-dark-thin>.mCSB_scrollTools .mCSB_buttonRight{background-position:-80px -56px}
1
+ .mCustomScrollbar{-ms-touch-action:pinch-zoom;touch-action:pinch-zoom}.mCustomScrollbar.mCS_no_scrollbar,.mCustomScrollbar.mCS_touch_action{-ms-touch-action:auto;touch-action:auto}.mCustomScrollBox{position:relative;overflow:hidden;height:100%;max-width:100%;outline:0;direction:ltr}.mCSB_container{overflow:hidden;width:auto;height:auto}.mCSB_inside>.mCSB_container{margin-right:30px}.mCSB_container.mCS_no_scrollbar_y.mCS_y_hidden{margin-right:0}.mCS-dir-rtl>.mCSB_inside>.mCSB_container{margin-right:0;margin-left:30px}.mCS-dir-rtl>.mCSB_inside>.mCSB_container.mCS_no_scrollbar_y.mCS_y_hidden{margin-left:0}.mCSB_scrollTools{position:absolute;width:16px;height:auto;left:auto;top:0;right:0;bottom:0;opacity:.75;filter:"alpha(opacity=75)";-ms-filter:"alpha(opacity=75)"}.mCSB_outside+.mCSB_scrollTools{right:-26px}.mCS-dir-rtl>.mCSB_inside>.mCSB_scrollTools,.mCS-dir-rtl>.mCSB_outside+.mCSB_scrollTools{right:auto;left:0}.mCS-dir-rtl>.mCSB_outside+.mCSB_scrollTools{left:-26px}.mCSB_scrollTools .mCSB_draggerContainer{position:absolute;top:0;left:0;bottom:0;right:0;height:auto}.mCSB_scrollTools a+.mCSB_draggerContainer{margin:20px 0}.mCSB_scrollTools .mCSB_draggerRail{width:2px;height:100%;margin:0 auto;-webkit-border-radius:16px;-moz-border-radius:16px;border-radius:16px}.mCSB_scrollTools .mCSB_dragger{cursor:pointer;width:100%;height:30px;z-index:1}.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{position:relative;width:4px;height:100%;margin:0 auto;-webkit-border-radius:16px;-moz-border-radius:16px;border-radius:16px;text-align:center}.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded .mCSB_dragger_bar,.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_dragger .mCSB_dragger_bar{width:12px}.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded+.mCSB_draggerRail,.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail{width:8px}.mCSB_scrollTools .mCSB_buttonDown,.mCSB_scrollTools .mCSB_buttonUp{display:block;position:absolute;height:20px;width:100%;overflow:hidden;margin:0 auto;cursor:pointer}.mCSB_scrollTools .mCSB_buttonDown{bottom:0}.mCSB_horizontal.mCSB_inside>.mCSB_container{margin-right:0;margin-bottom:30px}.mCSB_horizontal.mCSB_outside>.mCSB_container{min-height:100%}.mCSB_horizontal>.mCSB_container.mCS_no_scrollbar_x.mCS_x_hidden{margin-bottom:0}.mCSB_scrollTools.mCSB_scrollTools_horizontal{width:auto;height:16px;top:auto;right:0;bottom:0;left:0}.mCustomScrollBox+.mCSB_scrollTools+.mCSB_scrollTools.mCSB_scrollTools_horizontal,.mCustomScrollBox+.mCSB_scrollTools.mCSB_scrollTools_horizontal{bottom:-26px}.mCSB_scrollTools.mCSB_scrollTools_horizontal a+.mCSB_draggerContainer{margin:0 20px}.mCSB_scrollTools.mCSB_scrollTools_horizontal .mCSB_draggerRail{width:100%;height:2px;margin:7px 0}.mCSB_scrollTools.mCSB_scrollTools_horizontal .mCSB_dragger{width:30px;height:100%;left:0}.mCSB_scrollTools.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{width:100%;height:4px;margin:6px auto}.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded .mCSB_dragger_bar,.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_dragger .mCSB_dragger_bar{height:12px;margin:2px auto}.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded+.mCSB_draggerRail,.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail{height:8px;margin:4px 0}.mCSB_scrollTools.mCSB_scrollTools_horizontal .mCSB_buttonLeft,.mCSB_scrollTools.mCSB_scrollTools_horizontal .mCSB_buttonRight{display:block;position:absolute;width:20px;height:100%;overflow:hidden;margin:0 auto;cursor:pointer}.mCSB_scrollTools.mCSB_scrollTools_horizontal .mCSB_buttonLeft{left:0}.mCSB_scrollTools.mCSB_scrollTools_horizontal .mCSB_buttonRight{right:0}.mCSB_container_wrapper{position:absolute;height:auto;width:auto;overflow:hidden;top:0;left:0;right:0;bottom:0;margin-right:30px;margin-bottom:30px}.mCSB_container_wrapper>.mCSB_container{padding-right:30px;padding-bottom:30px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.mCSB_vertical_horizontal>.mCSB_scrollTools.mCSB_scrollTools_vertical{bottom:20px}.mCSB_vertical_horizontal>.mCSB_scrollTools.mCSB_scrollTools_horizontal{right:20px}.mCSB_container_wrapper.mCS_no_scrollbar_x.mCS_x_hidden+.mCSB_scrollTools.mCSB_scrollTools_vertical{bottom:0}.mCS-dir-rtl>.mCustomScrollBox.mCSB_vertical_horizontal.mCSB_inside>.mCSB_scrollTools.mCSB_scrollTools_horizontal,.mCSB_container_wrapper.mCS_no_scrollbar_y.mCS_y_hidden+.mCSB_scrollTools~.mCSB_scrollTools.mCSB_scrollTools_horizontal{right:0}.mCS-dir-rtl>.mCustomScrollBox.mCSB_vertical_horizontal.mCSB_inside>.mCSB_scrollTools.mCSB_scrollTools_horizontal{left:20px}.mCS-dir-rtl>.mCustomScrollBox.mCSB_vertical_horizontal.mCSB_inside>.mCSB_container_wrapper.mCS_no_scrollbar_y.mCS_y_hidden+.mCSB_scrollTools~.mCSB_scrollTools.mCSB_scrollTools_horizontal{left:0}.mCS-dir-rtl>.mCSB_inside>.mCSB_container_wrapper{margin-right:0;margin-left:30px}.mCSB_container_wrapper.mCS_no_scrollbar_y.mCS_y_hidden>.mCSB_container{padding-right:0}.mCSB_container_wrapper.mCS_no_scrollbar_x.mCS_x_hidden>.mCSB_container{padding-bottom:0}.mCustomScrollBox.mCSB_vertical_horizontal.mCSB_inside>.mCSB_container_wrapper.mCS_no_scrollbar_y.mCS_y_hidden{margin-right:0;margin-left:0}.mCustomScrollBox.mCSB_vertical_horizontal.mCSB_inside>.mCSB_container_wrapper.mCS_no_scrollbar_x.mCS_x_hidden{margin-bottom:0}.mCSB_scrollTools,.mCSB_scrollTools .mCSB_buttonDown,.mCSB_scrollTools .mCSB_buttonLeft,.mCSB_scrollTools .mCSB_buttonRight,.mCSB_scrollTools .mCSB_buttonUp,.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{-webkit-transition:opacity .2s ease-in-out,background-color .2s ease-in-out;-moz-transition:opacity .2s ease-in-out,background-color .2s ease-in-out;-o-transition:opacity .2s ease-in-out,background-color .2s ease-in-out;transition:opacity .2s ease-in-out,background-color .2s ease-in-out}.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerRail,.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger_bar,.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerRail,.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger_bar{-webkit-transition:width .2s ease-out .2s,height .2s ease-out .2s,margin-left .2s ease-out .2s,margin-right .2s ease-out .2s,margin-top .2s ease-out .2s,margin-bottom .2s ease-out .2s,opacity .2s ease-in-out,background-color .2s ease-in-out;-moz-transition:width .2s ease-out .2s,height .2s ease-out .2s,margin-left .2s ease-out .2s,margin-right .2s ease-out .2s,margin-top .2s ease-out .2s,margin-bottom .2s ease-out .2s,opacity .2s ease-in-out,background-color .2s ease-in-out;-o-transition:width .2s ease-out .2s,height .2s ease-out .2s,margin-left .2s ease-out .2s,margin-right .2s ease-out .2s,margin-top .2s ease-out .2s,margin-bottom .2s ease-out .2s,opacity .2s ease-in-out,background-color .2s ease-in-out;transition:width .2s ease-out .2s,height .2s ease-out .2s,margin-left .2s ease-out .2s,margin-right .2s ease-out .2s,margin-top .2s ease-out .2s,margin-bottom .2s ease-out .2s,opacity .2s ease-in-out,background-color .2s ease-in-out}.mCS-autoHide>.mCustomScrollBox>.mCSB_scrollTools,.mCS-autoHide>.mCustomScrollBox~.mCSB_scrollTools{opacity:0;filter:"alpha(opacity=0)";-ms-filter:"alpha(opacity=0)"}.mCS-autoHide:hover>.mCustomScrollBox>.mCSB_scrollTools,.mCS-autoHide:hover>.mCustomScrollBox~.mCSB_scrollTools,.mCustomScrollBox:hover>.mCSB_scrollTools,.mCustomScrollBox:hover~.mCSB_scrollTools,.mCustomScrollbar>.mCustomScrollBox>.mCSB_scrollTools.mCSB_scrollTools_onDrag,.mCustomScrollbar>.mCustomScrollBox~.mCSB_scrollTools.mCSB_scrollTools_onDrag{opacity:1;filter:"alpha(opacity=100)";-ms-filter:"alpha(opacity=100)"}.mCSB_scrollTools .mCSB_draggerRail{background-color:#000;background-color:rgba(0,0,0,.4);filter:"alpha(opacity=40)";-ms-filter:"alpha(opacity=40)"}.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{background-color:#fff;background-color:rgba(255,255,255,.75);filter:"alpha(opacity=75)";-ms-filter:"alpha(opacity=75)"}.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background-color:#fff;background-color:rgba(255,255,255,.85);filter:"alpha(opacity=85)";-ms-filter:"alpha(opacity=85)"}.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background-color:#fff;background-color:rgba(255,255,255,.9);filter:"alpha(opacity=90)";-ms-filter:"alpha(opacity=90)"}.mCSB_scrollTools .mCSB_buttonDown,.mCSB_scrollTools .mCSB_buttonLeft,.mCSB_scrollTools .mCSB_buttonRight,.mCSB_scrollTools .mCSB_buttonUp{background-image:url(mCSB_buttons.png);background-repeat:no-repeat;opacity:.4;filter:"alpha(opacity=40)";-ms-filter:"alpha(opacity=40)"}.mCSB_scrollTools .mCSB_buttonUp{background-position:0 0}.mCSB_scrollTools .mCSB_buttonDown{background-position:0 -20px}.mCSB_scrollTools .mCSB_buttonLeft{background-position:0 -40px}.mCSB_scrollTools .mCSB_buttonRight{background-position:0 -56px}.mCSB_scrollTools .mCSB_buttonDown:hover,.mCSB_scrollTools .mCSB_buttonLeft:hover,.mCSB_scrollTools .mCSB_buttonRight:hover,.mCSB_scrollTools .mCSB_buttonUp:hover{opacity:.75;filter:"alpha(opacity=75)";-ms-filter:"alpha(opacity=75)"}.mCSB_scrollTools .mCSB_buttonDown:active,.mCSB_scrollTools .mCSB_buttonLeft:active,.mCSB_scrollTools .mCSB_buttonRight:active,.mCSB_scrollTools .mCSB_buttonUp:active{opacity:.9;filter:"alpha(opacity=90)";-ms-filter:"alpha(opacity=90)"}.mCS-dark.mCSB_scrollTools .mCSB_draggerRail{background-color:#000;background-color:rgba(0,0,0,.15)}.mCS-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.75)}.mCS-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background-color:rgba(0,0,0,.85)}.mCS-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background-color:rgba(0,0,0,.9)}.mCS-dark.mCSB_scrollTools .mCSB_buttonUp{background-position:-80px 0}.mCS-dark.mCSB_scrollTools .mCSB_buttonDown{background-position:-80px -20px}.mCS-dark.mCSB_scrollTools .mCSB_buttonLeft{background-position:-80px -40px}.mCS-dark.mCSB_scrollTools .mCSB_buttonRight{background-position:-80px -56px}.mCS-dark-2.mCSB_scrollTools .mCSB_draggerRail,.mCS-light-2.mCSB_scrollTools .mCSB_draggerRail{width:4px;background-color:#fff;background-color:rgba(255,255,255,.1);-webkit-border-radius:1px;-moz-border-radius:1px;border-radius:1px}.mCS-dark-2.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-light-2.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:4px;background-color:#fff;background-color:rgba(255,255,255,.75);-webkit-border-radius:1px;-moz-border-radius:1px;border-radius:1px}.mCS-dark-2.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-dark-2.mCSB_scrollTools_horizontal .mCSB_draggerRail,.mCS-light-2.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-light-2.mCSB_scrollTools_horizontal .mCSB_draggerRail{width:100%;height:4px;margin:6px auto}.mCS-light-2.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background-color:#fff;background-color:rgba(255,255,255,.85)}.mCS-light-2.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-light-2.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background-color:#fff;background-color:rgba(255,255,255,.9)}.mCS-light-2.mCSB_scrollTools .mCSB_buttonUp{background-position:-32px 0}.mCS-light-2.mCSB_scrollTools .mCSB_buttonDown{background-position:-32px -20px}.mCS-light-2.mCSB_scrollTools .mCSB_buttonLeft{background-position:-40px -40px}.mCS-light-2.mCSB_scrollTools .mCSB_buttonRight{background-position:-40px -56px}.mCS-dark-2.mCSB_scrollTools .mCSB_draggerRail{background-color:#000;background-color:rgba(0,0,0,.1);-webkit-border-radius:1px;-moz-border-radius:1px;border-radius:1px}.mCS-dark-2.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.75);-webkit-border-radius:1px;-moz-border-radius:1px;border-radius:1px}.mCS-dark-2.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.85)}.mCS-dark-2.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-dark-2.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.9)}.mCS-dark-2.mCSB_scrollTools .mCSB_buttonUp{background-position:-112px 0}.mCS-dark-2.mCSB_scrollTools .mCSB_buttonDown{background-position:-112px -20px}.mCS-dark-2.mCSB_scrollTools .mCSB_buttonLeft{background-position:-120px -40px}.mCS-dark-2.mCSB_scrollTools .mCSB_buttonRight{background-position:-120px -56px}.mCS-dark-thick.mCSB_scrollTools .mCSB_draggerRail,.mCS-light-thick.mCSB_scrollTools .mCSB_draggerRail{width:4px;background-color:#fff;background-color:rgba(255,255,255,.1);-webkit-border-radius:2px;-moz-border-radius:2px;border-radius:2px}.mCS-dark-thick.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-light-thick.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:6px;background-color:#fff;background-color:rgba(255,255,255,.75);-webkit-border-radius:2px;-moz-border-radius:2px;border-radius:2px}.mCS-dark-thick.mCSB_scrollTools_horizontal .mCSB_draggerRail,.mCS-light-thick.mCSB_scrollTools_horizontal .mCSB_draggerRail{width:100%;height:4px;margin:6px 0}.mCS-dark-thick.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-light-thick.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{width:100%;height:6px;margin:5px auto}.mCS-light-thick.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background-color:#fff;background-color:rgba(255,255,255,.85)}.mCS-light-thick.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-light-thick.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background-color:#fff;background-color:rgba(255,255,255,.9)}.mCS-light-thick.mCSB_scrollTools .mCSB_buttonUp{background-position:-16px 0}.mCS-light-thick.mCSB_scrollTools .mCSB_buttonDown{background-position:-16px -20px}.mCS-light-thick.mCSB_scrollTools .mCSB_buttonLeft{background-position:-20px -40px}.mCS-light-thick.mCSB_scrollTools .mCSB_buttonRight{background-position:-20px -56px}.mCS-dark-thick.mCSB_scrollTools .mCSB_draggerRail{background-color:#000;background-color:rgba(0,0,0,.1);-webkit-border-radius:2px;-moz-border-radius:2px;border-radius:2px}.mCS-dark-thick.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.75);-webkit-border-radius:2px;-moz-border-radius:2px;border-radius:2px}.mCS-dark-thick.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.85)}.mCS-dark-thick.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-dark-thick.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.9)}.mCS-dark-thick.mCSB_scrollTools .mCSB_buttonUp{background-position:-96px 0}.mCS-dark-thick.mCSB_scrollTools .mCSB_buttonDown{background-position:-96px -20px}.mCS-dark-thick.mCSB_scrollTools .mCSB_buttonLeft{background-position:-100px -40px}.mCS-dark-thick.mCSB_scrollTools .mCSB_buttonRight{background-position:-100px -56px}.mCS-light-thin.mCSB_scrollTools .mCSB_draggerRail{background-color:#fff;background-color:rgba(255,255,255,.1)}.mCS-dark-thin.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-light-thin.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:2px}.mCS-dark-thin.mCSB_scrollTools_horizontal .mCSB_draggerRail,.mCS-light-thin.mCSB_scrollTools_horizontal .mCSB_draggerRail{width:100%}.mCS-dark-thin.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-light-thin.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{width:100%;height:2px;margin:7px auto}.mCS-dark-thin.mCSB_scrollTools .mCSB_draggerRail{background-color:#000;background-color:rgba(0,0,0,.15)}.mCS-dark-thin.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.75)}.mCS-dark-thin.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.85)}.mCS-dark-thin.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-dark-thin.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.9)}.mCS-dark-thin.mCSB_scrollTools .mCSB_buttonUp{background-position:-80px 0}.mCS-dark-thin.mCSB_scrollTools .mCSB_buttonDown{background-position:-80px -20px}.mCS-dark-thin.mCSB_scrollTools .mCSB_buttonLeft{background-position:-80px -40px}.mCS-dark-thin.mCSB_scrollTools .mCSB_buttonRight{background-position:-80px -56px}.mCS-rounded.mCSB_scrollTools .mCSB_draggerRail{background-color:#fff;background-color:rgba(255,255,255,.15)}.mCS-rounded-dark.mCSB_scrollTools .mCSB_dragger,.mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_dragger,.mCS-rounded-dots.mCSB_scrollTools .mCSB_dragger,.mCS-rounded.mCSB_scrollTools .mCSB_dragger{height:14px}.mCS-rounded-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-rounded-dots.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-rounded.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:14px;margin:0 1px}.mCS-rounded-dark.mCSB_scrollTools_horizontal .mCSB_dragger,.mCS-rounded-dots-dark.mCSB_scrollTools_horizontal .mCSB_dragger,.mCS-rounded-dots.mCSB_scrollTools_horizontal .mCSB_dragger,.mCS-rounded.mCSB_scrollTools_horizontal .mCSB_dragger{width:14px}.mCS-rounded-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-rounded-dots-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-rounded-dots.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-rounded.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{height:14px;margin:1px 0}.mCS-rounded-dark.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded .mCSB_dragger_bar,.mCS-rounded-dark.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_dragger .mCSB_dragger_bar,.mCS-rounded.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded .mCSB_dragger_bar,.mCS-rounded.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_dragger .mCSB_dragger_bar{width:16px;height:16px;margin:-1px 0}.mCS-rounded-dark.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded+.mCSB_draggerRail,.mCS-rounded-dark.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail,.mCS-rounded.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded+.mCSB_draggerRail,.mCS-rounded.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail{width:4px}.mCS-rounded-dark.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded .mCSB_dragger_bar,.mCS-rounded-dark.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_dragger .mCSB_dragger_bar,.mCS-rounded.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded .mCSB_dragger_bar,.mCS-rounded.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_dragger .mCSB_dragger_bar{height:16px;width:16px;margin:0 -1px}.mCS-rounded-dark.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded+.mCSB_draggerRail,.mCS-rounded-dark.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail,.mCS-rounded.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded+.mCSB_draggerRail,.mCS-rounded.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail{height:4px;margin:6px 0}.mCS-rounded.mCSB_scrollTools .mCSB_buttonUp{background-position:0 -72px}.mCS-rounded.mCSB_scrollTools .mCSB_buttonDown{background-position:0 -92px}.mCS-rounded.mCSB_scrollTools .mCSB_buttonLeft{background-position:0 -112px}.mCS-rounded.mCSB_scrollTools .mCSB_buttonRight{background-position:0 -128px}.mCS-rounded-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.75)}.mCS-rounded-dark.mCSB_scrollTools .mCSB_draggerRail{background-color:#000;background-color:rgba(0,0,0,.15)}.mCS-rounded-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar,.mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.85)}.mCS-rounded-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-rounded-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,.mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.9)}.mCS-rounded-dark.mCSB_scrollTools .mCSB_buttonUp{background-position:-80px -72px}.mCS-rounded-dark.mCSB_scrollTools .mCSB_buttonDown{background-position:-80px -92px}.mCS-rounded-dark.mCSB_scrollTools .mCSB_buttonLeft{background-position:-80px -112px}.mCS-rounded-dark.mCSB_scrollTools .mCSB_buttonRight{background-position:-80px -128px}.mCS-rounded-dots-dark.mCSB_scrollTools_vertical .mCSB_draggerRail,.mCS-rounded-dots.mCSB_scrollTools_vertical .mCSB_draggerRail{width:4px}.mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_draggerRail,.mCS-rounded-dots-dark.mCSB_scrollTools_horizontal .mCSB_draggerRail,.mCS-rounded-dots.mCSB_scrollTools .mCSB_draggerRail,.mCS-rounded-dots.mCSB_scrollTools_horizontal .mCSB_draggerRail{background-color:transparent;background-position:center}.mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_draggerRail,.mCS-rounded-dots.mCSB_scrollTools .mCSB_draggerRail{background-image:url();background-repeat:repeat-y;opacity:.3;filter:"alpha(opacity=30)";-ms-filter:"alpha(opacity=30)"}.mCS-rounded-dots-dark.mCSB_scrollTools_horizontal .mCSB_draggerRail,.mCS-rounded-dots.mCSB_scrollTools_horizontal .mCSB_draggerRail{height:4px;margin:6px 0;background-repeat:repeat-x}.mCS-rounded-dots.mCSB_scrollTools .mCSB_buttonUp{background-position:-16px -72px}.mCS-rounded-dots.mCSB_scrollTools .mCSB_buttonDown{background-position:-16px -92px}.mCS-rounded-dots.mCSB_scrollTools .mCSB_buttonLeft{background-position:-20px -112px}.mCS-rounded-dots.mCSB_scrollTools .mCSB_buttonRight{background-position:-20px -128px}.mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_draggerRail{background-image:url()}.mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_buttonUp{background-position:-96px -72px}.mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_buttonDown{background-position:-96px -92px}.mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_buttonLeft{background-position:-100px -112px}.mCS-rounded-dots-dark.mCSB_scrollTools .mCSB_buttonRight{background-position:-100px -128px}.mCS-3d-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-3d-thick-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-3d-thick.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-3d.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{background-repeat:repeat-y;background-image:-moz-linear-gradient(left,rgba(255,255,255,.5) 0,rgba(255,255,255,0) 100%);background-image:-webkit-gradient(linear,left top,right top,color-stop(0,rgba(255,255,255,.5)),color-stop(100%,rgba(255,255,255,0)));background-image:-webkit-linear-gradient(left,rgba(255,255,255,.5) 0,rgba(255,255,255,0) 100%);background-image:-o-linear-gradient(left,rgba(255,255,255,.5) 0,rgba(255,255,255,0) 100%);background-image:-ms-linear-gradient(left,rgba(255,255,255,.5) 0,rgba(255,255,255,0) 100%);background-image:linear-gradient(to right,rgba(255,255,255,.5) 0,rgba(255,255,255,0) 100%)}.mCS-3d-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-3d-thick-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-3d-thick.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-3d.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{background-repeat:repeat-x;background-image:-moz-linear-gradient(top,rgba(255,255,255,.5) 0,rgba(255,255,255,0) 100%);background-image:-webkit-gradient(linear,left top,left bottom,color-stop(0,rgba(255,255,255,.5)),color-stop(100%,rgba(255,255,255,0)));background-image:-webkit-linear-gradient(top,rgba(255,255,255,.5) 0,rgba(255,255,255,0) 100%);background-image:-o-linear-gradient(top,rgba(255,255,255,.5) 0,rgba(255,255,255,0) 100%);background-image:-ms-linear-gradient(top,rgba(255,255,255,.5) 0,rgba(255,255,255,0) 100%);background-image:linear-gradient(to bottom,rgba(255,255,255,.5) 0,rgba(255,255,255,0) 100%)}.mCS-3d-dark.mCSB_scrollTools_vertical .mCSB_dragger,.mCS-3d.mCSB_scrollTools_vertical .mCSB_dragger{height:70px}.mCS-3d-dark.mCSB_scrollTools_horizontal .mCSB_dragger,.mCS-3d.mCSB_scrollTools_horizontal .mCSB_dragger{width:70px}.mCS-3d-dark.mCSB_scrollTools,.mCS-3d.mCSB_scrollTools{opacity:1;filter:"alpha(opacity=30)";-ms-filter:"alpha(opacity=30)"}.mCS-3d-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-3d-dark.mCSB_scrollTools .mCSB_draggerRail,.mCS-3d.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-3d.mCSB_scrollTools .mCSB_draggerRail{-webkit-border-radius:16px;-moz-border-radius:16px;border-radius:16px}.mCS-3d-dark.mCSB_scrollTools .mCSB_draggerRail,.mCS-3d.mCSB_scrollTools .mCSB_draggerRail{width:8px;background-color:#000;background-color:rgba(0,0,0,.2);box-shadow:inset 1px 0 1px rgba(0,0,0,.5),inset -1px 0 1px rgba(255,255,255,.2)}.mCS-3d-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-3d-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-3d-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,.mCS-3d-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar,.mCS-3d.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-3d.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-3d.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,.mCS-3d.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background-color:#555}.mCS-3d-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-3d.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:8px}.mCS-3d-dark.mCSB_scrollTools_horizontal .mCSB_draggerRail,.mCS-3d.mCSB_scrollTools_horizontal .mCSB_draggerRail{width:100%;height:8px;margin:4px 0;box-shadow:inset 0 1px 1px rgba(0,0,0,.5),inset 0 -1px 1px rgba(255,255,255,.2)}.mCS-3d-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-3d.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{width:100%;height:8px;margin:4px auto}.mCS-3d.mCSB_scrollTools .mCSB_buttonUp{background-position:-32px -72px}.mCS-3d.mCSB_scrollTools .mCSB_buttonDown{background-position:-32px -92px}.mCS-3d.mCSB_scrollTools .mCSB_buttonLeft{background-position:-40px -112px}.mCS-3d.mCSB_scrollTools .mCSB_buttonRight{background-position:-40px -128px}.mCS-3d-dark.mCSB_scrollTools .mCSB_draggerRail{background-color:#000;background-color:rgba(0,0,0,.1);box-shadow:inset 1px 0 1px rgba(0,0,0,.1)}.mCS-3d-dark.mCSB_scrollTools_horizontal .mCSB_draggerRail{box-shadow:inset 0 1px 1px rgba(0,0,0,.1)}.mCS-3d-dark.mCSB_scrollTools .mCSB_buttonUp{background-position:-112px -72px}.mCS-3d-dark.mCSB_scrollTools .mCSB_buttonDown{background-position:-112px -92px}.mCS-3d-dark.mCSB_scrollTools .mCSB_buttonLeft{background-position:-120px -112px}.mCS-3d-dark.mCSB_scrollTools .mCSB_buttonRight{background-position:-120px -128px}.mCS-3d-thick-dark.mCSB_scrollTools,.mCS-3d-thick.mCSB_scrollTools{opacity:1;filter:"alpha(opacity=30)";-ms-filter:"alpha(opacity=30)"}.mCS-3d-thick-dark.mCSB_scrollTools,.mCS-3d-thick-dark.mCSB_scrollTools .mCSB_draggerContainer,.mCS-3d-thick.mCSB_scrollTools,.mCS-3d-thick.mCSB_scrollTools .mCSB_draggerContainer{-webkit-border-radius:7px;-moz-border-radius:7px;border-radius:7px}.mCSB_inside+.mCS-3d-thick-dark.mCSB_scrollTools_vertical,.mCSB_inside+.mCS-3d-thick.mCSB_scrollTools_vertical{right:1px}.mCS-3d-thick-dark.mCSB_scrollTools_vertical,.mCS-3d-thick.mCSB_scrollTools_vertical{box-shadow:inset 1px 0 1px rgba(0,0,0,.1),inset 0 0 14px rgba(0,0,0,.5)}.mCS-3d-thick-dark.mCSB_scrollTools_horizontal,.mCS-3d-thick.mCSB_scrollTools_horizontal{bottom:1px;box-shadow:inset 0 1px 1px rgba(0,0,0,.1),inset 0 0 14px rgba(0,0,0,.5)}.mCS-3d-thick-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-3d-thick.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{-webkit-border-radius:5px;-moz-border-radius:5px;border-radius:5px;box-shadow:inset 1px 0 0 rgba(255,255,255,.4);width:12px;margin:2px;position:absolute;height:auto;top:0;bottom:0;left:0;right:0}.mCS-3d-thick-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-3d-thick.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{box-shadow:inset 0 1px 0 rgba(255,255,255,.4);height:12px;width:auto}.mCS-3d-thick.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-3d-thick.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-3d-thick.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,.mCS-3d-thick.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background-color:#555}.mCS-3d-thick.mCSB_scrollTools .mCSB_draggerContainer{background-color:#000;background-color:rgba(0,0,0,.05);box-shadow:inset 1px 1px 16px rgba(0,0,0,.1)}.mCS-3d-thick.mCSB_scrollTools .mCSB_draggerRail{background-color:transparent}.mCS-3d-thick.mCSB_scrollTools .mCSB_buttonUp{background-position:-32px -72px}.mCS-3d-thick.mCSB_scrollTools .mCSB_buttonDown{background-position:-32px -92px}.mCS-3d-thick.mCSB_scrollTools .mCSB_buttonLeft{background-position:-40px -112px}.mCS-3d-thick.mCSB_scrollTools .mCSB_buttonRight{background-position:-40px -128px}.mCS-3d-thick-dark.mCSB_scrollTools{box-shadow:inset 0 0 14px rgba(0,0,0,.2)}.mCS-3d-thick-dark.mCSB_scrollTools_horizontal{box-shadow:inset 0 1px 1px rgba(0,0,0,.1),inset 0 0 14px rgba(0,0,0,.2)}.mCS-3d-thick-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{box-shadow:inset 1px 0 0 rgba(255,255,255,.4),inset -1px 0 0 rgba(0,0,0,.2)}.mCS-3d-thick-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{box-shadow:inset 0 1px 0 rgba(255,255,255,.4),inset 0 -1px 0 rgba(0,0,0,.2)}.mCS-3d-thick-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-3d-thick-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-3d-thick-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,.mCS-3d-thick-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background-color:#777}.mCS-3d-thick-dark.mCSB_scrollTools .mCSB_draggerContainer{background-color:#fff;background-color:rgba(0,0,0,.05);box-shadow:inset 1px 1px 16px rgba(0,0,0,.1)}.mCS-3d-thick-dark.mCSB_scrollTools .mCSB_draggerRail,.mCS-minimal-dark.mCSB_scrollTools .mCSB_draggerRail,.mCS-minimal.mCSB_scrollTools .mCSB_draggerRail{background-color:transparent}.mCS-3d-thick-dark.mCSB_scrollTools .mCSB_buttonUp{background-position:-112px -72px}.mCS-3d-thick-dark.mCSB_scrollTools .mCSB_buttonDown{background-position:-112px -92px}.mCS-3d-thick-dark.mCSB_scrollTools .mCSB_buttonLeft{background-position:-120px -112px}.mCS-3d-thick-dark.mCSB_scrollTools .mCSB_buttonRight{background-position:-120px -128px}.mCSB_outside+.mCS-minimal-dark.mCSB_scrollTools_vertical,.mCSB_outside+.mCS-minimal.mCSB_scrollTools_vertical{right:0;margin:12px 0}.mCustomScrollBox.mCS-minimal+.mCSB_scrollTools+.mCSB_scrollTools.mCSB_scrollTools_horizontal,.mCustomScrollBox.mCS-minimal+.mCSB_scrollTools.mCSB_scrollTools_horizontal,.mCustomScrollBox.mCS-minimal-dark+.mCSB_scrollTools+.mCSB_scrollTools.mCSB_scrollTools_horizontal,.mCustomScrollBox.mCS-minimal-dark+.mCSB_scrollTools.mCSB_scrollTools_horizontal{bottom:0;margin:0 12px}.mCS-dir-rtl>.mCSB_outside+.mCS-minimal-dark.mCSB_scrollTools_vertical,.mCS-dir-rtl>.mCSB_outside+.mCS-minimal.mCSB_scrollTools_vertical{left:0;right:auto}.mCS-minimal-dark.mCSB_scrollTools_vertical .mCSB_dragger,.mCS-minimal.mCSB_scrollTools_vertical .mCSB_dragger{height:50px}.mCS-minimal-dark.mCSB_scrollTools_horizontal .mCSB_dragger,.mCS-minimal.mCSB_scrollTools_horizontal .mCSB_dragger{width:50px}.mCS-minimal.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{background-color:#fff;background-color:rgba(255,255,255,.2);filter:"alpha(opacity=20)";-ms-filter:"alpha(opacity=20)"}.mCS-minimal.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-minimal.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background-color:#fff;background-color:rgba(255,255,255,.5);filter:"alpha(opacity=50)";-ms-filter:"alpha(opacity=50)"}.mCS-minimal-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.2);filter:"alpha(opacity=20)";-ms-filter:"alpha(opacity=20)"}.mCS-minimal-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-minimal-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.5);filter:"alpha(opacity=50)";-ms-filter:"alpha(opacity=50)"}.mCS-dark-3.mCSB_scrollTools .mCSB_draggerRail,.mCS-light-3.mCSB_scrollTools .mCSB_draggerRail{width:6px;background-color:#000;background-color:rgba(0,0,0,.2)}.mCS-dark-3.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-light-3.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:6px}.mCS-dark-3.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-dark-3.mCSB_scrollTools_horizontal .mCSB_draggerRail,.mCS-light-3.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-light-3.mCSB_scrollTools_horizontal .mCSB_draggerRail{width:100%;height:6px;margin:5px 0}.mCS-dark-3.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded+.mCSB_draggerRail,.mCS-dark-3.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail,.mCS-light-3.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded+.mCSB_draggerRail,.mCS-light-3.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail{width:12px}.mCS-dark-3.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded+.mCSB_draggerRail,.mCS-dark-3.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail,.mCS-light-3.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded+.mCSB_draggerRail,.mCS-light-3.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail{height:12px;margin:2px 0}.mCS-light-3.mCSB_scrollTools .mCSB_buttonUp{background-position:-32px -72px}.mCS-light-3.mCSB_scrollTools .mCSB_buttonDown{background-position:-32px -92px}.mCS-light-3.mCSB_scrollTools .mCSB_buttonLeft{background-position:-40px -112px}.mCS-light-3.mCSB_scrollTools .mCSB_buttonRight{background-position:-40px -128px}.mCS-dark-3.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.75)}.mCS-dark-3.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.85)}.mCS-dark-3.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-dark-3.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.9)}.mCS-dark-3.mCSB_scrollTools .mCSB_draggerRail{background-color:#000;background-color:rgba(0,0,0,.1)}.mCS-dark-3.mCSB_scrollTools .mCSB_buttonUp{background-position:-112px -72px}.mCS-dark-3.mCSB_scrollTools .mCSB_buttonDown{background-position:-112px -92px}.mCS-dark-3.mCSB_scrollTools .mCSB_buttonLeft{background-position:-120px -112px}.mCS-dark-3.mCSB_scrollTools .mCSB_buttonRight{background-position:-120px -128px}.mCS-inset-2-dark.mCSB_scrollTools .mCSB_draggerRail,.mCS-inset-2.mCSB_scrollTools .mCSB_draggerRail,.mCS-inset-3-dark.mCSB_scrollTools .mCSB_draggerRail,.mCS-inset-3.mCSB_scrollTools .mCSB_draggerRail,.mCS-inset-dark.mCSB_scrollTools .mCSB_draggerRail,.mCS-inset.mCSB_scrollTools .mCSB_draggerRail{width:12px;background-color:#000;background-color:rgba(0,0,0,.2)}.mCS-inset-2-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-inset-2.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-inset-3.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-inset-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-inset.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{width:6px;margin:3px 5px;position:absolute;height:auto;top:0;bottom:0;left:0;right:0}.mCS-inset-2-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-inset-2.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-inset-3-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-inset-3.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-inset-dark.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar,.mCS-inset.mCSB_scrollTools_horizontal .mCSB_dragger .mCSB_dragger_bar{height:6px;margin:5px 3px;position:absolute;width:auto;top:0;bottom:0;left:0;right:0}.mCS-inset-2-dark.mCSB_scrollTools_horizontal .mCSB_draggerRail,.mCS-inset-2.mCSB_scrollTools_horizontal .mCSB_draggerRail,.mCS-inset-3-dark.mCSB_scrollTools_horizontal .mCSB_draggerRail,.mCS-inset-3.mCSB_scrollTools_horizontal .mCSB_draggerRail,.mCS-inset-dark.mCSB_scrollTools_horizontal .mCSB_draggerRail,.mCS-inset.mCSB_scrollTools_horizontal .mCSB_draggerRail{width:100%;height:12px;margin:2px 0}.mCS-inset-2.mCSB_scrollTools .mCSB_buttonUp,.mCS-inset-3.mCSB_scrollTools .mCSB_buttonUp,.mCS-inset.mCSB_scrollTools .mCSB_buttonUp{background-position:-32px -72px}.mCS-inset-2.mCSB_scrollTools .mCSB_buttonDown,.mCS-inset-3.mCSB_scrollTools .mCSB_buttonDown,.mCS-inset.mCSB_scrollTools .mCSB_buttonDown{background-position:-32px -92px}.mCS-inset-2.mCSB_scrollTools .mCSB_buttonLeft,.mCS-inset-3.mCSB_scrollTools .mCSB_buttonLeft,.mCS-inset.mCSB_scrollTools .mCSB_buttonLeft{background-position:-40px -112px}.mCS-inset-2.mCSB_scrollTools .mCSB_buttonRight,.mCS-inset-3.mCSB_scrollTools .mCSB_buttonRight,.mCS-inset.mCSB_scrollTools .mCSB_buttonRight{background-position:-40px -128px}.mCS-inset-2-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar,.mCS-inset-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.75)}.mCS-inset-2-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar,.mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar,.mCS-inset-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.85)}.mCS-inset-2-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-inset-2-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,.mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,.mCS-inset-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-inset-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.9)}.mCS-inset-2-dark.mCSB_scrollTools .mCSB_draggerRail,.mCS-inset-3-dark.mCSB_scrollTools .mCSB_draggerRail,.mCS-inset-dark.mCSB_scrollTools .mCSB_draggerRail{background-color:#000;background-color:rgba(0,0,0,.1)}.mCS-inset-2-dark.mCSB_scrollTools .mCSB_buttonUp,.mCS-inset-3-dark.mCSB_scrollTools .mCSB_buttonUp,.mCS-inset-dark.mCSB_scrollTools .mCSB_buttonUp{background-position:-112px -72px}.mCS-inset-2-dark.mCSB_scrollTools .mCSB_buttonDown,.mCS-inset-3-dark.mCSB_scrollTools .mCSB_buttonDown,.mCS-inset-dark.mCSB_scrollTools .mCSB_buttonDown{background-position:-112px -92px}.mCS-inset-2-dark.mCSB_scrollTools .mCSB_buttonLeft,.mCS-inset-3-dark.mCSB_scrollTools .mCSB_buttonLeft,.mCS-inset-dark.mCSB_scrollTools .mCSB_buttonLeft{background-position:-120px -112px}.mCS-inset-2-dark.mCSB_scrollTools .mCSB_buttonRight,.mCS-inset-3-dark.mCSB_scrollTools .mCSB_buttonRight,.mCS-inset-dark.mCSB_scrollTools .mCSB_buttonRight{background-position:-120px -128px}.mCS-inset-2-dark.mCSB_scrollTools .mCSB_draggerRail,.mCS-inset-2.mCSB_scrollTools .mCSB_draggerRail{background-color:transparent;border-width:1px;border-style:solid;border-color:#fff;border-color:rgba(255,255,255,.2);-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.mCS-inset-2-dark.mCSB_scrollTools .mCSB_draggerRail{border-color:#000;border-color:rgba(0,0,0,.2)}.mCS-inset-3.mCSB_scrollTools .mCSB_draggerRail{background-color:#fff;background-color:rgba(255,255,255,.6)}.mCS-inset-3-dark.mCSB_scrollTools .mCSB_draggerRail{background-color:#000;background-color:rgba(0,0,0,.6)}.mCS-inset-3.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.75)}.mCS-inset-3.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.85)}.mCS-inset-3.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-inset-3.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background-color:#000;background-color:rgba(0,0,0,.9)}.mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{background-color:#fff;background-color:rgba(255,255,255,.75)}.mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{background-color:#fff;background-color:rgba(255,255,255,.85)}.mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar,.mCS-inset-3-dark.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar{background-color:#fff;background-color:rgba(255,255,255,.9)}
css/styles.min.css CHANGED
@@ -1 +1 @@
1
- .bwg_image_wrap figure{margin:0;padding:0}figure.zoom{background-position:50% 50%;background-size:200%;position:relative;width:auto;overflow:hidden;cursor:zoom-in}figure.zoom img:hover{opacity:0}figure.zoom img{transition:opacity .5s;display:block}div[id^=bwg_container] p{padding:0!important;margin:0!important}div[id^=bwg_container] img{box-shadow:none!important}div[id^=bwg_container] *{margin:0}div[id^=bwg_container] .SumoSelect.open>.CaptionCont,div[id^=bwg_container] .SumoSelect:focus>.CaptionCont,div[id^=bwg_container] .SumoSelect:hover>.CaptionCont,div[id^=bwg_container] .SumoSelect>.CaptionCont{border:none;box-shadow:none}#bwg_tag_wrap{background-color:#fff;width:100%;font-family:inherit;margin:0 -5px 20px 0;z-index:200;position:relative}.bwg_search_loupe_container,.bwg_search_reset_container{font-size:18px;color:#ccc;cursor:pointer;position:relative}#bwg_tag_container p{text-align:center}#bwg_tag_container{border:1px solid #ccc;box-shadow:0 0 3px 1px #ccc;border-radius:4px;width:256px;float:right}#spider_popup_wrap a{border:none;box-shadow:none}div[id^=bwg_container].bwg_container .bwg-a{border:none;box-shadow:none!important;outline:0;font-size:0;line-height:normal;cursor:pointer;text-decoration:none}div[id^=bwg_container].bwg_container .bwg-masonry-thumb-description,div[id^=bwg_container].bwg_container .bwg-thumb-description{cursor:auto}div[id^=bwg_container] div[id^=bwg_container] .bwg_img_clear{max-height:none!important;max-width:none!important;padding:0!important}.tag_cloud_link{font-size:inherit!important}@media print{#spider_popup_left,#spider_popup_right,.bwg_image_info,[class^=bwg_slideshow_title_text_],[id^=bwg_slideshow_play_pause_],[id^=spider_slideshow_left_],[id^=spider_slideshow_right_]{background:0 0}}.bwg_spider_popup_loading,.footer-list-block .bwp_gallery .bwg_spider_popup_loading,.footer-list-block .bwp_gallery_tags .bwg_spider_popup_loading{background-image:url(../images/ajax_loader.png);background-color:rgba(0,0,0,0);background-repeat:no-repeat;background-position:0 0;background-size:30px 30px;border:none!important;display:none;height:30px;left:50%;margin-left:-20px;margin-top:-20px;overflow:hidden;position:fixed;top:50%;width:30px;z-index:10102}.bwg_filmstrip_thumbnail_img{max-width:none!important}.dashicons-arrow-down-alt2:before{content:"\f347";height:100%;display:inline-block}.footer-list-block .bwp_gallery .spider_popup_overlay,.footer-list-block .bwp_gallery_tags .spider_popup_overlay,.spider_popup_overlay{cursor:pointer;display:none;height:100%;left:0;position:fixed;top:0;width:100%;z-index:10100}.bwp_gallery_tags div[id^=bwg_container] li{border:none}.spider_popup_close,.spider_popup_close_fullscreen{-moz-box-sizing:content-box!important;box-sizing:content-box!important;cursor:pointer;display:table;line-height:0;position:absolute;z-index:11100}.spider_popup_close_fullscreen{margin:10px 7px;right:7px}#spider_popup_left{left:0}#spider_popup_right{right:0}#spider_popup_left:hover,#spider_popup_right:hover{visibility:visible}#spider_popup_left:hover span{left:20px}#spider_popup_right:hover span{left:auto;right:20px}#spider_popup_left,#spider_popup_right{background:transparent url(../images/blank.gif) repeat scroll 0 0;bottom:35%;cursor:pointer;display:inline;height:30%;outline:medium none;position:absolute;width:35%;z-index:10130}#bwg_image_container #spider_popup_left,#bwg_image_container #spider_popup_right{width:25%}#spider_popup_left-ico,#spider_popup_right-ico{-moz-box-sizing:border-box;box-sizing:border-box;cursor:pointer;display:table;line-height:0;margin-top:-15px;position:absolute;top:50%;z-index:10135}.bwg_captcha_refresh{background-image:url(../images/captcha_refresh.png);background-position:center center;background-repeat:no-repeat;background-size:100% 100%;border-width:0;cursor:pointer;display:inline-block;height:20px;width:20px;margin:0;padding:0;vertical-align:middle}.bwg_captcha_input{vertical-align:middle;width:75px!important}.bwg_captcha_img{cursor:pointer;margin:0 5px 0 5px;vertical-align:middle}.bwg_comment_error{color:red;display:block}.bwg_comment_waiting_message{display:none}.bwg_image_hit_container1,.bwg_image_info_container1,.bwg_image_rate_container1{height:100%;margin:0 auto;position:absolute;width:100%}.bwg_image_rate_container1{display:none}.bwg_image_hit_container2,.bwg_image_info_container2,.bwg_image_rate_container2{display:table;height:100%;margin:0 auto;position:absolute;width:100%}.bwg_image_hit_spun,.bwg_image_info_spun,.bwg_image_rate_spun{display:table-cell;height:100%;left:0;top:0;width:100%;overflow:hidden;position:relative}.bwg_image_hit,.bwg_image_info,.bwg_image_rate{display:inline-block;position:relative;text-decoration:none;word-wrap:break-word;z-index:11}.bwg_image_rate{z-index:999!important}@media screen and (max-width:465px){.bwg_ctrl_btn_container{height:auto!important}}.bwg_search_container_1{display:inline-block;width:100%;text-align:right;margin:0 5px 20px 0;background-color:rgba(0,0,0,0)}.bwg_search_container_2{display:inline-block;position:relative;border-radius:4px;box-shadow:0 0 3px 1px #ccc;background-color:#fff;border:1px solid #ccc;max-width:100%}div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search_input_container{display:block;margin-right:45px}div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search_loupe_container{display:inline-block;margin-right:1px;vertical-align:middle;float:right}div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search_reset_container{margin-right:5px;vertical-align:middle;float:right}.bwg_thumbnail div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_reset,.bwg_thumbnail div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search{display:block;font-size:10px;color:#323a45;cursor:pointer;line-height:inherit!important}.bwg_thumbnail div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search{font-size:12px}div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search_input,div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search_input:focus{color:#070707;outline:0;border:none;box-shadow:none;background:0 0;padding:3px 5px;font-family:inherit;width:100%}.bwg_order_cont .SumoSelect{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 3px 1px #ccc;border-radius:4px;height:initial;max-width:100%;padding:0 10px}.SumoSelect>.optWrapper>.options li.opt{border:none;text-align:left}.bwg_order_cont .SumoSelect .CaptionCont{text-align:left}.bwg_order_cont{background-color:rgba(0,0,0,0);display:block;text-align:right;width:100%;margin:0 5px 20px 0}#bwg_tag_container .SumoSelect,.bwg_order_cont .SumoSelect{display:inline-table}#bwg_tag_container .SumoSelect ul.options,.bwg_order_cont .SumoSelect ul.options{margin:0;padding:0!important}#bwg_tag_container .SumoSelect li,.bwg_order_cont .SumoSelect li{list-style:none}#bwg_tag_container .SumoSelect.open .search-txt{padding:0 8px;height:100%}#bwg_tag_container .SumoSelect>.optWrapper>.options li label{margin:0}.bwg_order_label{border:none;box-shadow:none;color:#bbb;font-family:inherit;font-weight:700;outline:0}.bwg_order{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 3px 1px #ccc;border-radius:4px;height:initial;max-width:100%;text-align:left}.wd_error{color:#ccc;font-size:initial}div[id^=bwg_container] .bwg_download_gallery{text-align:right;margin-top:10px}div[id^=bwg_container] .bwg_download_gallery a{color:#4a4a4a;font-size:25px;text-decoration:none}div[id^=bwg_container] .bwg_download_gallery a:hover{color:#7d7d7d}div[id^=bwg_container] .bwg-border-box *{-moz-box-sizing:border-box;box-sizing:border-box}.bwg-flex{display:flex}.bwg-width-100{width:100%;max-width:100%}.bwg-flex-column{flex-direction:column}.bwg-flex-row{flex-direction:row;flex-wrap:wrap}.bwg-container{font-size:0;width:100%;max-width:100%;display:flex;flex-direction:row;flex-wrap:wrap}.bwg-item{display:flex;flex-direction:column;cursor:pointer}.bwg-item0{overflow:hidden;z-index:100}.bwg-item0:hover{background:0 0!important;backface-visibility:hidden;-webkit-backface-visibility:hidden;-moz-backface-visibility:hidden;-ms-backface-visibility:hidden;opacity:1;z-index:102;position:relative}.bwg-item1{overflow:hidden;width:100%;position:relative}.bwg-item2{top:0;left:0;bottom:0;right:0;width:100%;height:100%}.bwg-item2{position:absolute}.bwg-ecommerce1,.bwg-title1{opacity:1;text-align:center;width:100%}.bwg-ecommerce1{text-align:right}.bwg-title2{width:100%;word-wrap:break-word}.bwg-item0:hover .bwg-ecommerce1,.bwg-item0:hover .bwg-title1{left:0!important;opacity:1!important}.bwg-play-icon1{display:flex;height:100%;opacity:1;position:absolute;top:0;width:100%;z-index:100;justify-content:center;align-content:center;flex-direction:column;text-align:center}.bwg_loading_div_1{position:absolute;width:100%;height:100%;z-index:115;text-align:center;vertical-align:middle;top:0}.bwg_load_more_ajax_loading{width:100%;z-index:115;text-align:center;vertical-align:middle;position:relative;height:30px}.bwg_loading_div_2{display:table;vertical-align:middle;width:100%;height:100%;background-color:#fff;opacity:.95}.bwg_loading_div_3{display:table-cell;text-align:center;position:relative;vertical-align:middle}.bwg_spider_ajax_loading{border:none!important;display:inline-block;text-align:center;position:relative;vertical-align:middle;background-image:url(../images/ajax_loader.png);float:none;width:30px;height:30px;background-size:30px 30px}.bwg-hidden{visibility:hidden}.bwg_container{position:relative;margin:20px auto}.bwg_inst_play_btn_cont,.bwg_inst_play_btn_cont .bwg_inst_play{display:block}.hidden{display:none}.bwg-loading{width:100%;height:100%;opacity:.95;position:absolute;background-image:url(../images/ajax_loader.png);background-position:center;background-repeat:no-repeat;background-size:50px;z-index:100100;top:0;left:0}#bwg_download{display:inline-block}#bwg_download.hidden{display:none}.bwg_thumbnail.bwg_container .search_line.bwg_tag_select_view{min-height:50px;-webkit-box-shadow:0 5px 7px -5px rgba(0,0,0,.16);-moz-box-shadow:0 5px 7px -5px rgba(0,0,0,.16);box-shadow:0 5px 7px -5px rgba(0,0,0,.16);margin-bottom:10px;display:inline-block;width:100%}.bwg_thumbnail.bwg_container .search_line #bwg_tag_wrap,.bwg_thumbnail.bwg_container .search_line .bwg_order_cont,.bwg_thumbnail.bwg_container .search_line .bwg_search_container_1{float:left;display:table-cell;text-align:left;vertical-align:middle}.bwg_thumbnail.bwg_container .search_line #bwg_tag_wrap #bwg_tag_container,.bwg_thumbnail.bwg_container .search_line .bwg_order_cont select{border:.5px solid rgba(0,0,0,.15);box-shadow:none;border-radius:15px}.bwg_thumbnail.bwg_container .search_line .bwg_order_cont,.bwg_thumbnail.bwg_container .search_line .search_tags_container{width:25%;min-width:120px;max-width:180px;margin-right:20px;border:.5px solid rgba(0,0,0,.15);box-shadow:none;border-radius:15px;float:left;height:30px;padding:0;cursor:pointer;background:#fff}.bwg_thumbnail.bwg_container .search_line .bwg_order_cont select,.bwg_thumbnail.bwg_container .search_line .placeholder,.bwg_thumbnail.bwg_container .search_line .search-txt,.bwg_thumbnail.bwg_container .search_line .select-all,.bwg_thumbnail.bwg_container .search_line.SumoSelect .opt label{color:#323a45;font-size:12px;text-transform:uppercase;font-weight:400;font-family:Ubuntu;margin:0;border:none}.bwg_thumbnail.bwg_container .search_line .select-all label{margin-bottom:0;line-height:13px}.bwg_thumbnail.bwg_container .search_line .SumoSelect ul.options:not(:empty){padding:15px 0 0 10px!important}.bwg_thumbnail.bwg_container .search_line .SumoSelect{padding:0 10px;width:initial;height:inherit;cursor:pointer;display:block;border:none;box-shadow:none;border-radius:0;max-width:100%;background-color:transparent;line-height:inherit;vertical-align:bottom}.bwg_thumbnail.bwg_container .search_line .bwg_search_input_container{height:30px;text-align:center;font-size:12px;font-family:Ubuntu;border-radius:15px;text-align:left;width:calc(100%);margin:0;overflow:hidden}.bwg_thumbnail div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search_input,.bwg_thumbnail div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search_input:focus{height:30px;padding:0 10px;text-align:center;font-size:12px;font-family:Ubuntu;border-radius:15px;text-align:left;width:calc(100% - 64px);display:inline-table}.bwg_thumbnail.bwg_container .search_line .CaptionCont span{display:block!important;vertical-align:middle;color:#323a45!important;font-size:12px;text-transform:uppercase;font-family:Ubuntu;cursor:pointer;line-height:29px;max-width:calc(100% - 20px)}.bwg_thumbnail .search_tags{cursor:pointer}.bwg_thumbnail.bwg_container .search_line .SumoSelect .select-all>span,.bwg_thumbnail.bwg_container .search_line .SumoSelect>.optWrapper.multiple>.options li.opt span{margin-left:-35px}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.optWrapper.multiple>.options li.opt{padding-left:25px}.bwg_thumbnail .bwg_search_input::-webkit-input-placeholder{color:#ccc;font-size:12px;text-transform:uppercase;font-family:Ubuntu}.bwg_thumbnail .bwg_search_input::-moz-placeholder{color:#ccc;font-size:12px;text-transform:uppercase;text-align:left;font-family:Ubuntu;line-height:30px}.bwg_thumbnail .bwg_search_input:-ms-input-placeholder{color:#ccc;font-size:12px;text-transform:uppercase;text-align:left;font-family:Ubuntu}.bwg_thumbnail .bwg_search_input:-moz-placeholder{color:#ccc;font-size:12px;text-transform:uppercase;text-align:left;font-family:Ubuntu}.bwg_thumbnail .search-txt::-webkit-input-placeholder{text-align:left;color:#323a45;opacity:.5;font-size:12px!important}.bwg_thumbnail .search-txt::-moz-placeholder{text-align:left;color:#323a45;opacity:.5;font-size:12px!important}.bwg_thumbnail .search-txt::-ms-input-placeholder{text-align:left;color:#323a45;opacity:.5;font-size:12px}.bwg_thumbnail .search-txt:-ms-input-placeholder{text-align:left;color:#323a45;opacity:.5;font-size:12px}.bwg_thumbnail .search-txt:-moz-placeholder{text-align:left;color:#323a45;opacity:.5;font-size:12px}.bwg_thumbnail .bwg_search_input_container .search_placeholder_title{width:calc(100% - 20px);height:29px;text-align:center;display:inline-block;background:#fff;position:absolute;top:.5px;left:10px;white-space:nowrap;border-radius:15px;color:#4e4e4e;text-transform:uppercase;overflow:hidden}.bwg_thumbnail .bwg_search_input_container .search_placeholder_title span{line-height:28px}.bwg_thumbnail.bwg_container .search_line .bwg_search_loupe_container{line-height:29px;display:inline-block;top:0;margin-right:10px;vertical-align:middle;float:none;padding-top:0;font-size:12px;font-family:Ubuntug}.bwg_thumbnail.bwg_container .search_line .bwg_search_loupe_container1{margin-left:0;float:left;top:0;line-height:30px;width:auto;height:30px;margin-left:10px}.bwg_thumbnail.bwg_container .search_line .bwg_search_reset_container{right:0;top:0;line-height:30px;width:11px;height:30px;margin-right:10px}.bwg_thumbnail.bwg_container .search_line .bwg_search_container_1{float:right;width:30%;min-width:120px}.bwg_thumbnail.bwg_container .search_line .bwg_search_container_1 .bwg_search_container_2{width:100%!important;float:right}.bwg_thumbnail.bwg_container .search_line .SumoSelect .select-all{padding:0 0 3px 35px!important;height:13px;line-height:13px;margin-bottom:15px!important}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.optWrapper>.options li.opt{margin-bottom:15px;padding:0;list-style:none;color:#323a45;font-size:12px;text-transform:uppercase;font-family:Ubuntu;line-height:12px}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.optWrapper.multiple>.MultiControls>p.btnCancel,.bwg_thumbnail.bwg_container .search_line .SumoSelect>.optWrapper.multiple>.MultiControls>p.btnOk{font-family:Ubuntu;font-size:12px;line-height:12px}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.optWrapper.multiple>.MultiControls>p:hover{background:0 0}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.optWrapper>.options li.opt label{color:#323a45;font-size:12px;text-transform:uppercase;font-family:Ubuntu;font-weight:400;margin-bottom:0}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.CaptionCont{height:inherit;border:transparent;background:inherit;width:100%;cursor:pointer;max-height:calc(100% - 2px)}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.CaptionCont>label{margin:0;line-height:100%;cursor:pointer;width:20px}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.CaptionCont>label>i{line-height:100%;height:100%}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.CaptionCont>label>i.closed:before,.bwg_thumbnail.bwg_container .search_line .SumoSelect>.CaptionCont>label>i.opened:before{color:#323a45;font-size:10px;line-height:30px}.bwg_thumbnail.bwg_container .search_line .bwg_reset{position:absolute}.bwg_thumbnail.bwg_container .search_line .no-match{font-family:Ubuntu;font-size:12px;color:#323a45;padding:5px 25px!important;text-align:center}.bwg_thumbnail.bwg_container .search_line .search-txt{border:transparent;background:0 0;padding:4px 0!important;height:100%}.bwg_thumbnail.bwg_container .search_line .search-txt:focus{box-shadow:none}.bwg_thumbnail.bwg_container .search_line .bwg_order.SumoUnder{display:none}.bwg_slideshow_image_container{position:absolute}.bwg_slideshow_image_container>div>div{display:table;margin:0 auto}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slide_container_] img[id^=bwg_slideshow_image_]{display:inline-block}.bwg_thumbnail #bwg_tag_container p{text-align:left}.bwg_thumbnail .bwg_search_container_2{display:inline-block;position:relative;border-radius:4px;background-color:#fff;max-width:100%;box-shadow:none;border:.5px solid rgba(0,0,0,.15);border-radius:15px}.bwg_thumbnail .bwg_order_cont{background-color:rgba(0,0,0,0);display:block;text-align:right;width:100%}.bwg_thumbnail div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search_input_container{display:block;text-align:center}.bwg_thumbnail .SumoSelect>.optWrapper>.options li.opt:hover{background-color:transparent}.bwg-zoom-effect .bwg-zoom-effect-overlay{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;opacity:0;-webkit-transition:all .45s ease-in-out;transition:all .45s ease-in-out}.bwg-zoom-effect-overlay{display:flex;align-items:center;justify-content:center}.bwg-zoom-effect:hover .bwg-zoom-effect-overlay{opacity:1}.bwg-zoom-effect .bwg-title1{-webkit-transition:all .3s ease-in-out;transition:all .3s ease-in-out}@media (min-width:480px){.bwg-zoom-effect img{-webkit-transition:all .3s;transition:all .3s}}.bwg_container div[id^=bwg_container2_] img{height:initial}.bwg-masonry-vertical{flex-direction:column}.bwg_thumbnails_masonry .bwg-masonry-thumbnails{overflow:hidden}.bwg_thumbnails_masonry .bwg-masonry-thumbnails .bwg-item{box-sizing:border-box}.bwg-masonry-horizontal{flex-direction:row}.bwg-masonry-horizontal-parent{overflow-x:scroll;overflow-y:hidden}.bwg-masonry-horizontal-container{width:fit-content}.bwg-item.bwg-empty-item{border:0!important;padding:0!important}.bwg-background{background-color:rgba(0,0,0,0);position:relative;width:100%}.bwg-background .wd_error{color:#323a45;font-weight:700}div[id^=bwg_container] .bwg-carousel{margin:0 auto}.bwg_carousel_preload{background-image:url(../images/ajax_loader.png);background-size:50px!important;background-repeat:no-repeat;background-color:#fff;background-position:center}.bwg_container.bwg_carousel *{-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.bwg_container.bwg_carousel [id^=bwg_container2_] *{-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_watermark_]{position:relative;z-index:15}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_image_container_]{display:inline-block;position:absolute;text-align:center;vertical-align:middle}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_watermark_container_]{display:table-cell;margin:0 auto;position:relative;vertical-align:middle}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_watermark_container_] div{display:table;margin:0 auto}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_watermark_spun_]{display:table-cell;overflow:hidden;position:relative}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_watermark_image_]{padding:0!important;display:inline-block;float:none!important;margin:4px!important;position:relative;z-index:15}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_watermark_text_],.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_watermark_text_]:hover{text-decoration:none;margin:4px;display:block;position:relative;z-index:17}.bwg_container.bwg_carousel [id^=bwg_container2_] .bwg_carousel-cont-child{max-width:100%;position:relative;overflow:hidden;height:100%;width:100%}.bwg_container.bwg_carousel [id^=bwg_container2_] .bwg-carousel-image{border:0;position:absolute;display:block;max-width:none;padding:0!important;margin:0!important;float:none!important;vertical-align:middle;height:100%;width:100%;background-position:center center;background-repeat:no-repeat;background-size:cover;vertical-align:middle}.bwg_container.bwg_carousel [id^=bwg_container2_] .bwg-carousel{position:relative;max-width:100%;width:100%}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel-feature]{position:absolute;display:block;overflow:hidden;cursor:pointer}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel-feature] [class^=bwg_carousel-caption] [class^=bwg_carousel_title_text_]{text-decoration:none;position:absolute;z-index:15;display:inline-block;width:75%;top:0;text-align:center;word-wrap:break-word;word-break:break-word}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=bwg_carousel-left],.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=bwg_carousel-right]{bottom:38%;cursor:pointer;display:inline;height:30%;outline:medium none;position:absolute;width:0%;z-index:13;visibility:visible}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=bwg_carousel-right]{right:0;left:auto;z-index:999}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=bwg_carousel-left]{left:20px;z-index:999}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_video_hide]{width:100%;height:100%;position:absolute;z-index:22}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=spider_carousel_left-ico_] span,.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=spider_carousel_right-ico_] span{display:table-cell;text-align:center;vertical-align:middle;z-index:13}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=spider_carousel_left-ico_],.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=spider_carousel_right-ico_]{z-index:13;-moz-box-sizing:content-box;box-sizing:content-box;cursor:pointer;display:inline-table;line-height:0;margin-top:-15px;position:absolute;top:55%}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=spider_carousel_left-ico_]:hover,.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=spider_carousel_right-ico_]:hover{cursor:pointer}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=bwg_carousel_play_pause_]{bottom:0;cursor:pointer;display:flex;justify-content:center;align-items:center;outline:medium none;position:absolute;height:inherit;width:30%;left:35%;z-index:13}.bwg_container.bwg_carousel .bwg_carousel_play_pause:hover .bwg_carousel_play_pause-ico{display:inline-block!important}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=bwg_carousel_play_pause_]:hover span{position:relative;z-index:13}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=bwg_carousel_play_pause_] span{display:flex;justify-content:center;align-items:center}.bwg_container.bwg_carousel [id^=bwg_container2_] .bwg_carousel_play_pause-ico{display:none!important;cursor:pointer;position:relative;z-index:13}.bwg_container.bwg_carousel [id^=bwg_container2_] .bwg_carousel_play_pause-ico:hover{display:inline-block;position:relative;z-index:13}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_embed_]{padding:0!important;float:none!important;width:100%;height:100%;vertical-align:middle;position:relative;display:table;background-color:#000;text-align:center}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_embed_video_]{padding:0!important;margin:0!important;float:none!important;vertical-align:middle;position:relative;display:table-cell;background-color:#000;text-align:center}.bwg_thumbnail.bwg_container{padding:0 1px}.bwg_thumbnail.bwg_container .search_line.bwg-search-line-responsive{display:inline-block}body .bwg_thumbnail.bwg_container .search_line.bwg-search-line-responsive .bwg_order_cont,body .bwg_thumbnail.bwg_container .search_line.bwg-search-line-responsive .bwg_search_container_1,body .bwg_thumbnail.bwg_container .search_line.bwg-search-line-responsive .search_tags_container{width:100%;margin:0 0 10px 0;text-align:center;max-width:100%}.search_line .SumoSelect>.optWrapper.multiple.isFloating{padding-bottom:26px}.bwg_container.bwg_blog_style .fluid-width-video-wrapper,.bwg_container.bwg_carousel .fluid-width-video-wrapper,.bwg_container.bwg_image_browser .fluid-width-video-wrapper{width:100%;position:unset!important;padding:0!important}.bwg_inst_play_btn_cont{width:100%;height:100%;position:absolute;z-index:1;cursor:pointer;top:0}.bwg_inst_play{position:absolute;width:50px;height:50px;background-position:center center;background-repeat:no-repeat;background-size:cover;transition:background-image .2s ease-out;-ms-transition:background-image .2s ease-out;-moz-transition:background-image .2s ease-out;-webkit-transition:background-image .2s ease-out;top:0;left:0;right:0;bottom:0;margin:auto}.bwg_inst_play:hover{background-position:center center;background-repeat:no-repeat;background-size:cover}.spider_popup_wrap *{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}.spider_popup_wrap{display:inline-block;left:50%;outline:medium none;position:fixed;text-align:center;top:50%;z-index:100000}.bwg_popup_image{width:auto;vertical-align:middle;display:inline-block}.bwg_slider img{display:inline-block}.bwg_popup_embed{width:100%;height:100%;vertical-align:middle;text-align:center;display:table}.bwg_btn_container{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0}.bwg_toggle_btn{margin:0;padding:0}.bwg_ctrl_btn_container{position:absolute;width:100%;z-index:10150}.bwg_btn_container.bwg_no_ctrl_btn .bwg_ctrl_btn_container{background:0 0}.bwg_toggle_container{cursor:pointer;left:50%;line-height:0;position:absolute;text-align:center;z-index:10150}#spider_popup_left-ico span,#spider_popup_right-ico span,.spider_popup_close span{display:table-cell;text-align:center;vertical-align:middle}.bwg_image_wrap{height:inherit;display:table;position:absolute;text-align:center;width:inherit}.bwg_image_wrap *{-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.bwg_comment_wrap,.bwg_ecommerce_wrap{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0;z-index:-1}.bwg_comment_container,.bwg_ecommerce_container{-moz-box-sizing:border-box;height:100%;overflow:hidden;position:absolute;top:0;z-index:10103}#bwg_ecommerce{padding:10px}.bwg_ecommerce_body{background:0 0!important;border:none!important}.pge_tabs{list-style-type:none;margin:0;padding:0;background:0 0!important}.pge_tabs li a,.pge_tabs li a:hover,.pge_tabs li.pge_active a{text-decoration:none;display:block;width:100%;outline:0!important;padding:8px 5px!important;font-weight:700;font-size:13px}.pge_add_to_cart a{padding:5px 10px;text-decoration:none!important;display:block}.pge_add_to_cart{margin:5px 0 15px}.pge_add_to_cart_title{font-size:17px;padding:5px}.pge_add_to_cart div:first-child{float:left}.pge_add_to_cart div:last-child{float:right;margin-top:4px}.pge_add_to_cart:after,.pge_tabs:after{clear:both;content:"";display:table}#downloads table tr td,#downloads table tr th{padding:6px 10px!important;text-transform:none!important}.bwg_comments input[type=submit],.bwg_ecommerce_panel input[type=button]{cursor:pointer;font-size:15px;width:100%;margin-bottom:5px}.bwg_comments,.bwg_ecommerce_panel{bottom:0;height:100%;left:0;overflow-x:hidden;overflow-y:auto;position:absolute;top:0;width:100%;z-index:10101}.bwg_comments{height:100%}.bwg_comment_body_p,.bwg_comments p{margin:5px!important;text-align:left;word-wrap:break-word;word-break:break-all}.bwg_ecommerce_panel p{padding:5px!important;text-align:left;word-wrap:break-word;word-break:break-all;margin:0!important}.bwg_comments .bwg-submit-disabled{opacity:.5}.bwg_comments textarea{height:120px;resize:vertical}.bwg_comment_delete_btn{color:#7a7a7a;cursor:pointer;float:right;font-size:14px;margin:2px}.bwg_comments_close,.bwg_ecommerce_close{cursor:pointer;line-height:0;position:relative;font-size:13px;margin:5px;z-index:10150}.bwg_ecommerce_panel a:hover{text-decoration:underline}.bwg_comment_textarea::-webkit-scrollbar{width:4px}.bwg_comment_textarea::-webkit-scrollbar-thumb{background-color:rgba(255,255,255,.55);border-radius:2px}.bwg_comment_textarea::-webkit-scrollbar-thumb:hover{background-color:#d9d9d9}.bwg_ctrl_btn_container a,.bwg_ctrl_btn_container a:hover{text-decoration:none}.bwg_facebook:hover{color:#3b5998}.bwg_twitter:hover{color:#4099fb}.bwg_pinterest:hover{color:#cb2027}.bwg_tumblr:hover{color:#2f5070}.bwg_image_container{display:table;position:absolute;text-align:center;vertical-align:middle;width:100%}.bwg_filmstrip_container{position:absolute;z-index:10150}.bwg_filmstrip{overflow:hidden;position:absolute;z-index:10106}.bwg_filmstrip_thumbnails{margin:0 auto;overflow:hidden;position:relative}.bwg_filmstrip_thumbnail{position:relative;background:0 0;float:left;cursor:pointer;overflow:hidden}.bwg_filmstrip_thumbnail .bwg_filmstrip_thumbnail_img_wrap{overflow:hidden}.bwg_thumb_active{opacity:1}.bwg_filmstrip_thumbnail_img{display:block;opacity:1}.bwg_filmstrip_left{cursor:pointer;vertical-align:middle;z-index:10106;line-height:0}.bwg_filmstrip_right{cursor:pointer;vertical-align:middle;z-index:10106;line-height:0}.bwg_none_selectable{-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.bwg_watermark_container{display:table-cell;margin:0 auto;position:relative;vertical-align:middle}.bwg_watermark_container>div{display:table;margin:0 auto}.bwg_watermark_spun{display:table-cell;overflow:hidden;position:relative}.bwg_watermark_image{margin:4px;position:relative;z-index:10141}.bwg_watermark_text,.bwg_watermark_text:hover{text-decoration:none;margin:4px;position:relative;z-index:10141}.bwg_slide_container{display:table-cell;position:absolute;vertical-align:middle;width:100%;height:100%}.bwg_slide_bg{margin:0 auto;width:inherit;height:inherit}.bwg_slider{height:inherit;width:inherit}.bwg_popup_image_spun{height:inherit;display:table-cell;opacity:1;position:absolute;vertical-align:middle;width:inherit;z-index:2}.bwg_popup_image_second_spun{width:inherit;height:inherit;display:table-cell;opacity:0;position:absolute;vertical-align:middle;z-index:1}.bwg_grid{display:none;height:100%;overflow:hidden;position:absolute;width:100%}.bwg_gridlet{opacity:1;position:absolute}.bwg_image_info::-webkit-scrollbar{width:4px}.bwg_image_info::-webkit-scrollbar-thumb{background-color:rgba(255,255,255,.55);border-radius:2px}.bwg_image_info::-webkit-scrollbar-thumb:hover{background-color:#d9d9d9}#bwg_rate_form .bwg_hint{margin:0 5px;display:none}.bwg_star{display:inline-block;width:unset!important}.bwg_image_count_container{left:0;line-height:1;position:absolute;vertical-align:middle}#bwg_comment_form label{display:block;font-weight:700;margin-top:17px;text-transform:uppercase}#bwg_comment_form .bwg-privacy-policy-box label{text-transform:unset;word-break:break-word}.bwg_popup_image_spun .bwg_popup_image_spun1{width:inherit;height:inherit}.bwg_popup_image_spun1 .bwg_popup_image_spun2{vertical-align:middle;text-align:center;height:100%}#embed_conteiner{table-layout:fixed;height:100%}#opacity_div{background-color:rgba(255,255,255,.2);position:absolute;z-index:10150}#loading_div{text-align:center;position:relative;vertical-align:middle;z-index:10170;float:none;width:30px;height:30px;background-size:30px 30px;background-repeat:no-repeat;background-position:50% 50%}#ecommerce_ajax_loading{position:absolute}#ecommerce_opacity_div{display:none;background-color:rgba(255,255,255,.2);position:absolute;z-index:10150}#ecommerce_loading_div{display:none;text-align:center;position:relative;vertical-align:middle;z-index:10170;float:none;width:30px;height:30px;background-size:30px 30px;background-repeat:no-repeat;background-position:50% 50%}.bwg_ecommerce_panel.bwg_popup_sidebar_panel.bwg_popup_sidebar{text-align:left}#ajax_loading{position:absolute}@media (max-width:480px){.bwg_image_count_container{display:none}.bwg_image_title,.bwg_image_title *{font-size:12px}.bwg_image_description,.bwg_image_description *{font-size:10px}}@media (pointer:none),(pointer:coarse){#bwg_container1_0 #bwg_container2_0 .bwg-container-0.bwg-masonry-thumbnails .bwg-title1,#bwg_container1_0 #bwg_container2_0 .bwg-container-0.bwg-standard-thumbnails .bwg-title1,.bwg-mosaic-thumbnails{opacity:1!important}.bwg-zoom-effect .bwg-zoom-effect-overlay,.bwg-zoom-effect-overlay>span{opacity:1!important;background-color:unset!important}}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_image_wrap_] *{box-sizing:border-box;-moz-box-sizing:border-box;-webkit-box-sizing:border-box}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_image_wrap_]{border-collapse:collapse;display:table;position:relative;text-align:center;margin:auto}div[id^=bwg_container1_] div[id^=bwg_container2_] img[class^=bwg_slideshow_image_]{display:inline-block;padding:0!important;margin:0!important;float:none!important;vertical-align:middle}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_embed_]{padding:0!important;margin:0!important;float:none!important;vertical-align:middle;display:inline-block;text-align:center}div[id^=bwg_container1_] div[id^=bwg_container2_] img[class^=bwg_slideshow_watermark_]{position:relative;z-index:15}div[id^=bwg_container1_] div[id^=bwg_container2_] span.bwg_slideshow_play_pause{bottom:0;cursor:pointer;display:table;height:inherit;outline:medium none;position:absolute;width:30%;left:35%;z-index:13}div[id^=bwg_container1_] div[id^=bwg_container2_] span.bwg_slideshow_play_pause:hover span[id^=bwg_slideshow_play_pause-ico_]{display:inline-block!important}div[id^=bwg_container1_] div[id^=bwg_container2_] span.bwg_slideshow_play_pause:hover span{position:relative;z-index:13}div[id^=bwg_container1_] div[id^=bwg_container2_] span.bwg_slideshow_play_pause span{display:table-cell;text-align:center;vertical-align:middle;z-index:13}div[id^=bwg_container1_] div[id^=bwg_container2_] span[id^=bwg_slideshow_play_pause-ico_]{display:none!important;cursor:pointer;position:relative;z-index:13}div[id^=bwg_container1_] div[id^=bwg_container2_] span[id^=bwg_slideshow_play_pause-ico_]:hover{display:inline-block;position:relative;z-index:13}div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_left_],div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_right_]{bottom:35%;cursor:pointer;display:inline;height:30%;outline:medium none;position:absolute;width:35%;z-index:13}div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_left_]{left:0}div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_right_]{right:0}div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_left_]:hover,div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_right_]:hover{visibility:visible}div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_left_]:hover,div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_right_]:hover{visibility:visible}div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_right_]:hover span{left:auto!important;right:20px!important}div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_left_]:hover span{left:20px!important}div[id^=bwg_container1_] div[id^=bwg_container2_] span[id^=spider_slideshow_left-ico_] span,div[id^=bwg_container1_] div[id^=bwg_container2_] span[id^=spider_slideshow_right-ico_] span{display:table-cell;text-align:center;vertical-align:middle;z-index:13}div[id^=bwg_container1_] div[id^=bwg_container2_] span[id^=spider_slideshow_left-ico_],div[id^=bwg_container1_] div[id^=bwg_container2_] span[id^=spider_slideshow_right-ico_]{z-index:13;-moz-box-sizing:content-box;box-sizing:content-box;cursor:pointer;display:table;line-height:0;margin-top:-15px;position:absolute;top:50%}div[id^=bwg_container1_] div[id^=bwg_container2_] span[id^=spider_slideshow_left-ico_]:hover,div[id^=bwg_container1_] div[id^=bwg_container2_] span[id^=spider_slideshow_right-ico_]:hover{cursor:pointer}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_image_container_]{display:table;position:absolute;text-align:center;vertical-align:middle}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_filmstrip_container_]{position:absolute}div[id^=bwg_container1_] div[id^=bwg_container2_] .bwg_slideshow_filmstrip{overflow:hidden;position:absolute}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_filmstrip_thumbnails_]{margin:0 auto;overflow:hidden;position:relative}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_filmstrip_thumbnail_]{position:relative;background:0 0;cursor:pointer;float:left;overflow:hidden}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_thumb_active_]{opacity:1}div[id^=bwg_container1_] div[id^=bwg_container2_] img[class^=bwg_slideshow_filmstrip_thumbnail_img_]{display:block;opacity:1;padding:0!important}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_filmstrip_left_]{cursor:pointer;vertical-align:middle}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_filmstrip_right_]{cursor:pointer;vertical-align:middle}div[id^=bwg_container1_] div[id^=bwg_container2_] a[class^=bwg_none_selectable_]{-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_watermark_container_]{display:table-cell;margin:0 auto;position:relative;vertical-align:middle}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_watermark_spun_]{display:table-cell;overflow:hidden;position:relative}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_title_spun_]{display:table-cell;overflow:hidden;position:relative}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_description_spun_]{display:table-cell;overflow:hidden;position:relative}div[id^=bwg_container1_] div[id^=bwg_container2_] img[class^=bwg_slideshow_watermark_image_]{padding:0!important;float:none!important;margin:4px!important;position:relative;z-index:15}div[id^=bwg_container1_] div[id^=bwg_container2_] a[class^=bwg_slideshow_watermark_text_],div[id^=bwg_container1_] div[id^=bwg_container2_] a[class^=bwg_slideshow_watermark_text_]:hover{text-decoration:none;margin:4px;position:relative;z-index:15}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_title_text_]{text-decoration:none;position:relative;z-index:11;display:inline-block;word-wrap:break-word;word-break:break-word}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_description_text_]{text-decoration:none;position:relative;z-index:15;margin:5px;display:inline-block;word-wrap:break-word;word-break:break-word}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slide_container_]{display:table-cell;margin:0 auto;position:absolute;vertical-align:middle;width:100%;height:100%}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slide_bg_]{margin:0 auto;width:inherit;height:inherit}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slider_]{height:inherit;width:inherit}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_image_spun_]{width:inherit;height:inherit;display:table-cell;opacity:1;position:absolute;vertical-align:middle;z-index:2}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_image_second_spun_]{width:inherit;height:inherit;display:table-cell;opacity:0;position:absolute;vertical-align:middle;z-index:1}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_grid_]{display:none;height:100%;overflow:hidden;position:absolute;width:100%}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_gridlet_]{opacity:1;position:absolute}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_dots_]{display:inline-block;position:relative;cursor:pointer;overflow:hidden;z-index:17}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_dots_container_]{display:block;overflow:hidden;position:absolute;z-index:17}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_dots_thumbnails_]{left:0;font-size:0;margin:0 auto;overflow:hidden;position:relative}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_dots_active_]{opacity:1}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_image_spun1_]{display:table;width:inherit;height:inherit}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_image_spun2_]{display:table-cell;vertical-align:middle;text-align:center}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_mosaic_play_icon_spun_]{display:flex;height:100%;opacity:1;position:absolute;top:0;width:100%;z-index:100;justify-content:center;align-content:center;flex-direction:column;text-align:center;left:0}.lazy_loader{background-image:url(../images/ajax_loader.png);background-size:30px 30px;background-repeat:no-repeat;background-position:50% 50%}.bwg-container-temp0{visibility:hidden!important;position:absolute!important}.bwg_image_browser .pagination-links{display:flex;padding:0}.bwg_image_browser .pagination-links_col1{flex-grow:3;text-align:left}.bwg_image_browser .pagination-links_col2{flex-grow:4;text-align:center}.bwg_image_browser .pagination-links_col3{flex-grow:3;text-align:right}.bwg_current_page[type=number]{width:35px;display:inline-block;-moz-appearance:textfield;line-height:normal!important}.bwg_current_page::-webkit-inner-spin-button,.bwg_current_page::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.bwg_container .bwg_tag_button_view_container{display:flex;justify-content:flex-start;align-content:flex-start;align-items:flex-start;margin-bottom:45px;position:relative;padding-top:3px;flex-wrap:wrap;overflow:hidden;clear:both}.bwg_container .bwg_tag_button_view_container button{cursor:pointer}.bwg_container .bwg_tag_button_view_container button.active{cursor:default}.bwg_container .bwg_tag_button_view_container .verLine{min-height:26px;margin:0 15px}.bwg_container .bwg_tag_button_see_all{margin-bottom:70px;position:relative;display:none}.bwg_container .bwg_tag_button_see_all .see_all_tags{text-transform:uppercase;position:absolute;padding:10px 25px;font-weight:600;cursor:pointer;left:47%;top:-23px}.bwg_container .bwg_tag_button_see_all .see_all_tags span{display:inline-block;line-height:normal;text-align:center;border-radius:50%;margin-right:10px;font-weight:500;color:#fff;height:18px;width:18px}.bwg_addThis{position:absolute;left:10px;top:10px;z-index:9999}
1
+ .bwg_image_wrap figure{margin:0;padding:0}figure.zoom{background-position:50% 50%;background-size:200%;position:relative;width:auto;overflow:hidden;cursor:zoom-in}figure.zoom img:hover{opacity:0}figure.zoom img{transition:opacity .5s;display:block}div[id^=bwg_container] p{padding:0!important;margin:0!important}div[id^=bwg_container] img{box-shadow:none!important}div[id^=bwg_container] *{margin:0}div[id^=bwg_container] .SumoSelect.open>.CaptionCont,div[id^=bwg_container] .SumoSelect:focus>.CaptionCont,div[id^=bwg_container] .SumoSelect:hover>.CaptionCont,div[id^=bwg_container] .SumoSelect>.CaptionCont{border:none;box-shadow:none}#bwg_tag_wrap{background-color:#fff;width:100%;font-family:inherit;margin:0 -5px 20px 0;z-index:200;position:relative}.bwg_search_loupe_container,.bwg_search_reset_container{font-size:18px;color:#ccc;cursor:pointer;position:relative}#bwg_tag_container p{text-align:center}#bwg_tag_container{border:1px solid #ccc;box-shadow:0 0 3px 1px #ccc;border-radius:4px;width:256px;float:right}#spider_popup_wrap a{border:none;box-shadow:none}div[id^=bwg_container].bwg_container .bwg-a{border:none;box-shadow:none!important;outline:0;font-size:0;line-height:normal;cursor:pointer;text-decoration:none}div[id^=bwg_container].bwg_container .bwg-masonry-thumb-description,div[id^=bwg_container].bwg_container .bwg-thumb-description{cursor:auto}div[id^=bwg_container] div[id^=bwg_container] .bwg_img_clear{max-height:none!important;max-width:none!important;padding:0!important}.tag_cloud_link{font-size:inherit!important}@media print{#spider_popup_left,#spider_popup_right,.bwg_image_info,[class^=bwg_slideshow_title_text_],[id^=bwg_slideshow_play_pause_],[id^=spider_slideshow_left_],[id^=spider_slideshow_right_]{background:0 0}}.bwg_spider_popup_loading,.footer-list-block .bwp_gallery .bwg_spider_popup_loading,.footer-list-block .bwp_gallery_tags .bwg_spider_popup_loading{background-image:url(../images/ajax_loader.png);background-color:rgba(0,0,0,0);background-repeat:no-repeat;background-position:0 0;background-size:30px 30px;border:none!important;display:none;height:30px;left:50%;margin-left:-20px;margin-top:-20px;overflow:hidden;position:fixed;top:50%;width:30px;z-index:10102}.bwg_filmstrip_thumbnail_img{max-width:none!important}.dashicons-arrow-down-alt2:before{content:"\f347";height:100%;display:inline-block}.footer-list-block .bwp_gallery .spider_popup_overlay,.footer-list-block .bwp_gallery_tags .spider_popup_overlay,.spider_popup_overlay{cursor:pointer;display:none;height:100%;left:0;position:fixed;top:0;width:100%;z-index:10100}.bwp_gallery_tags div[id^=bwg_container] li{border:none}.spider_popup_close,.spider_popup_close_fullscreen{-moz-box-sizing:content-box!important;box-sizing:content-box!important;cursor:pointer;display:table;line-height:0;position:absolute;z-index:11100}.spider_popup_close_fullscreen{margin:10px 7px;right:7px}#spider_popup_left{left:0}#spider_popup_right{right:0}#spider_popup_left:hover,#spider_popup_right:hover{visibility:visible}#spider_popup_left:hover span{left:20px}#spider_popup_right:hover span{left:auto;right:20px}#spider_popup_left,#spider_popup_right{background:transparent url(../images/blank.gif) repeat scroll 0 0;bottom:35%;cursor:pointer;display:inline;height:30%;outline:medium none;position:absolute;width:35%;z-index:10130}#bwg_image_container #spider_popup_left,#bwg_image_container #spider_popup_right{width:25%}#spider_popup_left-ico,#spider_popup_right-ico{-moz-box-sizing:border-box;box-sizing:border-box;cursor:pointer;display:table;line-height:0;margin-top:-15px;position:absolute;top:50%;z-index:10135}.bwg_captcha_refresh{background-image:url(../images/captcha_refresh.png);background-position:center center;background-repeat:no-repeat;background-size:100% 100%;border-width:0;cursor:pointer;display:inline-block;height:20px;width:20px;margin:0;padding:0;vertical-align:middle}.bwg_captcha_input{vertical-align:middle;width:75px!important}.bwg_captcha_img{cursor:pointer;margin:0 5px 0 5px;vertical-align:middle}.bwg_comment_error{color:red;display:block}.bwg_comment_waiting_message{display:none}.bwg_image_hit_container1,.bwg_image_info_container1,.bwg_image_rate_container1{height:100%;margin:0 auto;position:absolute;width:100%}.bwg_image_rate_container1{display:none}.bwg_image_hit_container2,.bwg_image_info_container2,.bwg_image_rate_container2{display:table;height:100%;margin:0 auto;position:absolute;width:100%}.bwg_image_hit_spun,.bwg_image_info_spun,.bwg_image_rate_spun{display:table-cell;height:100%;left:0;top:0;width:100%;overflow:hidden;position:relative}.bwg_image_hit,.bwg_image_info,.bwg_image_rate{display:inline-block;position:relative;text-decoration:none;word-wrap:break-word;z-index:11}.bwg_image_rate{z-index:999!important}.bwg_image_rate_disabled{display:none;position:absolute;width:100%;height:40px;top:0}@media screen and (max-width:465px){.bwg_ctrl_btn_container{height:auto!important}}.bwg_search_container_1{display:inline-block;width:100%;text-align:right;margin:0 5px 20px 0;background-color:rgba(0,0,0,0)}.bwg_search_container_2{display:inline-block;position:relative;border-radius:4px;box-shadow:0 0 3px 1px #ccc;background-color:#fff;border:1px solid #ccc;max-width:100%}div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search_input_container{display:block;margin-right:45px}div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search_loupe_container{display:inline-block;margin-right:1px;vertical-align:middle;float:right}div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search_reset_container{margin-right:5px;vertical-align:middle;float:right}.bwg_thumbnail div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_reset,.bwg_thumbnail div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search{display:block;font-size:10px;color:#323a45;cursor:pointer;line-height:inherit!important}.bwg_thumbnail div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search{font-size:12px}div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search_input,div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search_input:focus{color:#070707;outline:0;border:none;box-shadow:none;background:0 0;padding:3px 5px;font-family:inherit;width:100%}.bwg_order_cont .SumoSelect{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 3px 1px #ccc;border-radius:4px;height:initial;max-width:100%;padding:0 10px}.SumoSelect>.optWrapper>.options li.opt{border:none;text-align:left}.bwg_order_cont .SumoSelect .CaptionCont{text-align:left}.bwg_order_cont{background-color:rgba(0,0,0,0);display:block;text-align:right;width:100%;margin:0 5px 20px 0}#bwg_tag_container .SumoSelect,.bwg_order_cont .SumoSelect{display:inline-table}#bwg_tag_container .SumoSelect ul.options,.bwg_order_cont .SumoSelect ul.options{margin:0;padding:0!important}#bwg_tag_container .SumoSelect li,.bwg_order_cont .SumoSelect li{list-style:none}#bwg_tag_container .SumoSelect.open .search-txt{padding:0 8px;height:100%}#bwg_tag_container .SumoSelect>.optWrapper>.options li label{margin:0}.bwg_order_label{border:none;box-shadow:none;color:#bbb;font-family:inherit;font-weight:700;outline:0}.bwg_order{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 3px 1px #ccc;border-radius:4px;height:initial;max-width:100%;text-align:left}.wd_error{color:#ccc;font-size:initial}div[id^=bwg_container] .bwg_download_gallery{text-align:right;margin-top:10px}div[id^=bwg_container] .bwg_download_gallery a{color:#4a4a4a;font-size:25px;text-decoration:none}div[id^=bwg_container] .bwg_download_gallery a:hover{color:#7d7d7d}div[id^=bwg_container] .bwg-border-box *{-moz-box-sizing:border-box;box-sizing:border-box}.bwg-flex{display:flex}.bwg-width-100{width:100%;max-width:100%}.bwg-flex-column{flex-direction:column}.bwg-flex-row{flex-direction:row;flex-wrap:wrap}.bwg-container{font-size:0;width:100%;max-width:100%;display:flex;flex-direction:row;flex-wrap:wrap}.bwg-item{display:flex;flex-direction:column;cursor:pointer}.bwg-item0{overflow:hidden;z-index:100}.bwg-item0:hover{background:0 0!important;backface-visibility:hidden;-webkit-backface-visibility:hidden;-moz-backface-visibility:hidden;-ms-backface-visibility:hidden;opacity:1;z-index:102;position:relative}.bwg-item1{overflow:hidden;width:100%;position:relative}.bwg-item2{top:0;left:0;bottom:0;right:0;width:100%;height:100%}.bwg-item2{position:absolute}.bwg-ecommerce1,.bwg-title1{opacity:1;text-align:center;width:100%}.bwg-ecommerce1{text-align:right}.bwg-title2{width:100%;word-wrap:break-word}.bwg-item0:hover .bwg-ecommerce1,.bwg-item0:hover .bwg-title1{left:0!important;opacity:1!important}.bwg-play-icon1{display:flex;height:100%;opacity:1;position:absolute;top:0;width:100%;z-index:100;justify-content:center;align-content:center;flex-direction:column;text-align:center}.bwg_loading_div_1{position:absolute;width:100%;height:100%;z-index:115;text-align:center;vertical-align:middle;top:0}.bwg_load_more_ajax_loading{width:100%;z-index:115;text-align:center;vertical-align:middle;position:relative;height:30px}.bwg_loading_div_2{display:table;vertical-align:middle;width:100%;height:100%;background-color:#fff;opacity:.95}.bwg_loading_div_3{display:table-cell;text-align:center;position:relative;vertical-align:middle}.bwg_spider_ajax_loading{border:none!important;display:inline-block;text-align:center;position:relative;vertical-align:middle;background-image:url(../images/ajax_loader.png);float:none;width:30px;height:30px;background-size:30px 30px}.bwg-hidden{visibility:hidden}.bwg_container{position:relative;margin:20px auto}.bwg_inst_play_btn_cont,.bwg_inst_play_btn_cont .bwg_inst_play{display:block}.hidden{display:none}.bwg-loading{width:100%;height:100%;opacity:.95;position:absolute;background-image:url(../images/ajax_loader.png);background-position:center;background-repeat:no-repeat;background-size:50px;z-index:100100;top:0;left:0}#bwg_download{display:inline-block}#bwg_download.hidden{display:none}.bwg_thumbnail.bwg_container .search_line.bwg_tag_select_view{min-height:50px;-webkit-box-shadow:0 5px 7px -5px rgba(0,0,0,.16);-moz-box-shadow:0 5px 7px -5px rgba(0,0,0,.16);box-shadow:0 5px 7px -5px rgba(0,0,0,.16);margin-bottom:10px;display:inline-block;width:100%}.bwg_thumbnail.bwg_container .search_line #bwg_tag_wrap,.bwg_thumbnail.bwg_container .search_line .bwg_order_cont,.bwg_thumbnail.bwg_container .search_line .bwg_search_container_1{float:left;display:table-cell;text-align:left;vertical-align:middle}.bwg_thumbnail.bwg_container .search_line #bwg_tag_wrap #bwg_tag_container,.bwg_thumbnail.bwg_container .search_line .bwg_order_cont select{border:.5px solid rgba(0,0,0,.15);box-shadow:none;border-radius:15px}.bwg_thumbnail.bwg_container .search_line .bwg_order_cont,.bwg_thumbnail.bwg_container .search_line .search_tags_container{width:25%;min-width:120px;max-width:180px;margin-right:20px;border:.5px solid rgba(0,0,0,.15);box-shadow:none;border-radius:15px;float:left;height:30px;padding:0;cursor:pointer;background:#fff}.bwg_thumbnail.bwg_container .search_line .bwg_order_cont select,.bwg_thumbnail.bwg_container .search_line .placeholder,.bwg_thumbnail.bwg_container .search_line .search-txt,.bwg_thumbnail.bwg_container .search_line .select-all,.bwg_thumbnail.bwg_container .search_line.SumoSelect .opt label{color:#323a45;font-size:12px;text-transform:uppercase;font-weight:400;font-family:Ubuntu;margin:0;border:none}.bwg_thumbnail.bwg_container .search_line .select-all label{margin-bottom:0;line-height:13px}.bwg_thumbnail.bwg_container .search_line .SumoSelect ul.options:not(:empty){padding:15px 0 0 10px!important}.bwg_thumbnail.bwg_container .search_line .SumoSelect{padding:0 10px;width:initial;height:inherit;cursor:pointer;display:block;border:none;box-shadow:none;border-radius:0;max-width:100%;background-color:transparent;line-height:inherit;vertical-align:bottom}.bwg_thumbnail.bwg_container .search_line .bwg_search_input_container{height:30px;text-align:center;font-size:12px;font-family:Ubuntu;border-radius:15px;text-align:left;width:calc(100%);margin:0;overflow:hidden}.bwg_thumbnail div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search_input,.bwg_thumbnail div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search_input:focus{height:30px;padding:0 10px;text-align:center;font-size:12px;font-family:Ubuntu;border-radius:15px;text-align:left;width:calc(100% - 64px);display:inline-table}.bwg_thumbnail.bwg_container .search_line .CaptionCont span{display:block!important;vertical-align:middle;color:#323a45!important;font-size:12px;text-transform:uppercase;font-family:Ubuntu;cursor:pointer;line-height:29px;max-width:calc(100% - 20px)}.bwg_thumbnail .search_tags{cursor:pointer}.bwg_thumbnail.bwg_container .search_line .SumoSelect .select-all>span,.bwg_thumbnail.bwg_container .search_line .SumoSelect>.optWrapper.multiple>.options li.opt span{margin-left:-35px}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.optWrapper.multiple>.options li.opt{padding-left:25px}.bwg_thumbnail .bwg_search_input::-webkit-input-placeholder{color:#ccc;font-size:12px;text-transform:uppercase;font-family:Ubuntu}.bwg_thumbnail .bwg_search_input::-moz-placeholder{color:#ccc;font-size:12px;text-transform:uppercase;text-align:left;font-family:Ubuntu;line-height:30px}.bwg_thumbnail .bwg_search_input:-ms-input-placeholder{color:#ccc;font-size:12px;text-transform:uppercase;text-align:left;font-family:Ubuntu}.bwg_thumbnail .bwg_search_input:-moz-placeholder{color:#ccc;font-size:12px;text-transform:uppercase;text-align:left;font-family:Ubuntu}.bwg_thumbnail .search-txt::-webkit-input-placeholder{text-align:left;color:#323a45;opacity:.5;font-size:12px!important}.bwg_thumbnail .search-txt::-moz-placeholder{text-align:left;color:#323a45;opacity:.5;font-size:12px!important}.bwg_thumbnail .search-txt::-ms-input-placeholder{text-align:left;color:#323a45;opacity:.5;font-size:12px}.bwg_thumbnail .search-txt:-ms-input-placeholder{text-align:left;color:#323a45;opacity:.5;font-size:12px}.bwg_thumbnail .search-txt:-moz-placeholder{text-align:left;color:#323a45;opacity:.5;font-size:12px}.bwg_thumbnail .bwg_search_input_container .search_placeholder_title{width:calc(100% - 20px);height:29px;text-align:center;display:inline-block;background:#fff;position:absolute;top:.5px;left:10px;white-space:nowrap;border-radius:15px;color:#4e4e4e;text-transform:uppercase;overflow:hidden}.bwg_thumbnail .bwg_search_input_container .search_placeholder_title span{line-height:28px}.bwg_thumbnail.bwg_container .search_line .bwg_search_loupe_container{line-height:29px;display:inline-block;top:0;margin-right:10px;vertical-align:middle;float:none;padding-top:0;font-size:12px;font-family:Ubuntug}.bwg_thumbnail.bwg_container .search_line .bwg_search_loupe_container1{margin-left:0;float:left;top:0;line-height:30px;width:auto;height:30px;margin-left:10px}.bwg_thumbnail.bwg_container .search_line .bwg_search_reset_container{right:0;top:0;line-height:30px;width:11px;height:30px;margin-right:10px}.bwg_thumbnail.bwg_container .search_line .bwg_search_container_1{float:right;width:30%;min-width:120px}.bwg_thumbnail.bwg_container .search_line .bwg_search_container_1 .bwg_search_container_2{width:100%!important;float:right}.bwg_thumbnail.bwg_container .search_line .SumoSelect .select-all{padding:0 0 3px 35px!important;height:13px;line-height:13px;margin-bottom:15px!important}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.optWrapper>.options li.opt{margin-bottom:15px;padding:0;list-style:none;color:#323a45;font-size:12px;text-transform:uppercase;font-family:Ubuntu;line-height:12px}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.optWrapper.multiple>.MultiControls>p.btnCancel,.bwg_thumbnail.bwg_container .search_line .SumoSelect>.optWrapper.multiple>.MultiControls>p.btnOk{font-family:Ubuntu;font-size:12px;line-height:12px}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.optWrapper.multiple>.MultiControls>p:hover{background:0 0}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.optWrapper>.options li.opt label{color:#323a45;font-size:12px;text-transform:uppercase;font-family:Ubuntu;font-weight:400;margin-bottom:0}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.CaptionCont{height:inherit;border:transparent;background:inherit;width:100%;cursor:pointer;max-height:calc(100% - 2px)}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.CaptionCont>label{margin:0;line-height:100%;cursor:pointer;width:20px}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.CaptionCont>label>i{line-height:100%;height:100%}.bwg_thumbnail.bwg_container .search_line .SumoSelect>.CaptionCont>label>i.closed:before,.bwg_thumbnail.bwg_container .search_line .SumoSelect>.CaptionCont>label>i.opened:before{color:#323a45;font-size:10px;line-height:30px}.bwg_thumbnail.bwg_container .search_line .bwg_reset{position:absolute}.bwg_thumbnail.bwg_container .search_line .no-match{font-family:Ubuntu;font-size:12px;color:#323a45;padding:5px 25px!important;text-align:center}.bwg_thumbnail.bwg_container .search_line .search-txt{border:transparent;background:0 0;padding:4px 0!important;height:100%}.bwg_thumbnail.bwg_container .search_line .search-txt:focus{box-shadow:none}.bwg_thumbnail.bwg_container .search_line .bwg_order.SumoUnder{display:none}.bwg_slideshow_image_container{position:absolute}.bwg_slideshow_image_container>div>div{display:table;margin:0 auto}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slide_container_] img[id^=bwg_slideshow_image_]{display:inline-block}.bwg_thumbnail #bwg_tag_container p{text-align:left}.bwg_thumbnail .bwg_search_container_2{display:inline-block;position:relative;border-radius:4px;background-color:#fff;max-width:100%;box-shadow:none;border:.5px solid rgba(0,0,0,.15);border-radius:15px}.bwg_thumbnail .bwg_order_cont{background-color:rgba(0,0,0,0);display:block;text-align:right;width:100%}.bwg_thumbnail div[id^=bwg_search_container_1_] div[id^=bwg_search_container_2_] .bwg_search_input_container{display:block;text-align:center}.bwg_thumbnail .SumoSelect>.optWrapper>.options li.opt:hover{background-color:transparent}.bwg-zoom-effect .bwg-zoom-effect-overlay{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;opacity:0;-webkit-transition:all .45s ease-in-out;transition:all .45s ease-in-out}.bwg-zoom-effect-overlay{display:flex;align-items:center;justify-content:center}.bwg-zoom-effect:hover .bwg-zoom-effect-overlay{opacity:1}.bwg-zoom-effect .bwg-title1{-webkit-transition:all .3s ease-in-out;transition:all .3s ease-in-out}@media (min-width:480px){.bwg-zoom-effect img{-webkit-transition:all .3s;transition:all .3s}}.bwg_container div[id^=bwg_container2_] img{height:initial}.bwg-masonry-vertical{flex-direction:column}.bwg_thumbnails_masonry .bwg-masonry-thumbnails{overflow:hidden}.bwg_thumbnails_masonry .bwg-masonry-thumbnails .bwg-item{box-sizing:border-box}.bwg-masonry-horizontal{flex-direction:row}.bwg-masonry-horizontal-parent{overflow-x:scroll;overflow-y:hidden}.bwg-masonry-horizontal-container{width:fit-content}.bwg-item.bwg-empty-item{border:0!important;padding:0!important}.bwg-background{background-color:rgba(0,0,0,0);position:relative;width:100%}.bwg-background .wd_error{color:#323a45;font-weight:700}div[id^=bwg_container] .bwg-carousel{margin:0 auto}.bwg_carousel_preload{background-image:url(../images/ajax_loader.png);background-size:50px!important;background-repeat:no-repeat;background-color:#fff;background-position:center}.bwg_container.bwg_carousel *{-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.bwg_container.bwg_carousel [id^=bwg_container2_] *{-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_watermark_]{position:relative;z-index:15}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_image_container_]{display:inline-block;position:absolute;text-align:center;vertical-align:middle}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_watermark_container_]{display:table-cell;margin:0 auto;position:relative;vertical-align:middle}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_watermark_container_] div{display:table;margin:0 auto}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_watermark_spun_]{display:table-cell;overflow:hidden;position:relative}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_watermark_image_]{padding:0!important;display:inline-block;float:none!important;margin:4px!important;position:relative;z-index:15}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_watermark_text_],.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_watermark_text_]:hover{text-decoration:none;margin:4px;display:block;position:relative;z-index:17}.bwg_container.bwg_carousel [id^=bwg_container2_] .bwg_carousel-cont-child{max-width:100%;position:relative;overflow:hidden;height:100%;width:100%}.bwg_container.bwg_carousel [id^=bwg_container2_] .bwg-carousel-image{border:0;position:absolute;display:block;max-width:none;padding:0!important;margin:0!important;float:none!important;vertical-align:middle;height:100%;width:100%;background-position:center center;background-repeat:no-repeat;background-size:cover;vertical-align:middle}.bwg_container.bwg_carousel [id^=bwg_container2_] .bwg-carousel{position:relative;max-width:100%;width:100%}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel-feature]{position:absolute;display:block;overflow:hidden;cursor:pointer}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel-feature] [class^=bwg_carousel-caption] [class^=bwg_carousel_title_text_]{text-decoration:none;position:absolute;z-index:15;display:inline-block;width:75%;top:0;text-align:center;word-wrap:break-word;word-break:break-word}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=bwg_carousel-left],.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=bwg_carousel-right]{bottom:38%;cursor:pointer;display:inline;height:30%;outline:medium none;position:absolute;width:0%;z-index:13;visibility:visible}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=bwg_carousel-right]{right:0;left:auto;z-index:999}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=bwg_carousel-left]{left:20px;z-index:999}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_video_hide]{width:100%;height:100%;position:absolute;z-index:22}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=spider_carousel_left-ico_] span,.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=spider_carousel_right-ico_] span{display:table-cell;text-align:center;vertical-align:middle;z-index:13}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=spider_carousel_left-ico_],.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=spider_carousel_right-ico_]{z-index:13;-moz-box-sizing:content-box;box-sizing:content-box;cursor:pointer;display:inline-table;line-height:0;margin-top:-15px;position:absolute;top:55%}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=spider_carousel_left-ico_]:hover,.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=spider_carousel_right-ico_]:hover{cursor:pointer}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=bwg_carousel_play_pause_]{bottom:0;cursor:pointer;display:flex;justify-content:center;align-items:center;outline:medium none;position:absolute;height:inherit;width:30%;left:35%;z-index:13}.bwg_container.bwg_carousel .bwg_carousel_play_pause:hover .bwg_carousel_play_pause-ico{display:inline-block!important}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=bwg_carousel_play_pause_]:hover span{position:relative;z-index:13}.bwg_container.bwg_carousel [id^=bwg_container2_] [id^=bwg_carousel_play_pause_] span{display:flex;justify-content:center;align-items:center}.bwg_container.bwg_carousel [id^=bwg_container2_] .bwg_carousel_play_pause-ico{display:none!important;cursor:pointer;position:relative;z-index:13}.bwg_container.bwg_carousel [id^=bwg_container2_] .bwg_carousel_play_pause-ico:hover{display:inline-block;position:relative;z-index:13}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_embed_]{padding:0!important;float:none!important;width:100%;height:100%;vertical-align:middle;position:relative;display:table;background-color:#000;text-align:center}.bwg_container.bwg_carousel [id^=bwg_container2_] [class^=bwg_carousel_embed_video_]{padding:0!important;margin:0!important;float:none!important;vertical-align:middle;position:relative;display:table-cell;background-color:#000;text-align:center}.bwg_thumbnail.bwg_container{padding:0 1px}.bwg_thumbnail.bwg_container .search_line.bwg-search-line-responsive{display:inline-block}body .bwg_thumbnail.bwg_container .search_line.bwg-search-line-responsive .bwg_order_cont,body .bwg_thumbnail.bwg_container .search_line.bwg-search-line-responsive .bwg_search_container_1,body .bwg_thumbnail.bwg_container .search_line.bwg-search-line-responsive .search_tags_container{width:100%;margin:0 0 10px 0;text-align:center;max-width:100%}.search_line .SumoSelect>.optWrapper.multiple.isFloating{padding-bottom:26px}.bwg_container.bwg_blog_style .fluid-width-video-wrapper,.bwg_container.bwg_carousel .fluid-width-video-wrapper,.bwg_container.bwg_image_browser .fluid-width-video-wrapper{width:100%;position:unset!important;padding:0!important}.bwg_inst_play_btn_cont{width:100%;height:100%;position:absolute;z-index:1;cursor:pointer;top:0}.bwg_inst_play{position:absolute;width:50px;height:50px;background-position:center center;background-repeat:no-repeat;background-size:cover;transition:background-image .2s ease-out;-ms-transition:background-image .2s ease-out;-moz-transition:background-image .2s ease-out;-webkit-transition:background-image .2s ease-out;top:0;left:0;right:0;bottom:0;margin:auto}.bwg_inst_play:hover{background-position:center center;background-repeat:no-repeat;background-size:cover}.spider_popup_wrap *{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}.spider_popup_wrap{display:inline-block;left:50%;outline:medium none;position:fixed;text-align:center;top:50%;z-index:100000}.bwg_popup_image{width:auto;vertical-align:middle;display:inline-block}.bwg_slider img{display:inline-block}.bwg_popup_embed{width:100%;height:100%;vertical-align:middle;text-align:center;display:table}.bwg_btn_container{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0}.bwg_toggle_btn{margin:0;padding:0}.bwg_ctrl_btn_container{position:absolute;width:100%;z-index:10150}.bwg_btn_container.bwg_no_ctrl_btn .bwg_ctrl_btn_container{background:0 0}.bwg_toggle_container{cursor:pointer;left:50%;line-height:0;position:absolute;text-align:center;z-index:10150}#spider_popup_left-ico span,#spider_popup_right-ico span,.spider_popup_close span{display:table-cell;text-align:center;vertical-align:middle}.bwg_image_wrap{height:inherit;display:table;position:absolute;text-align:center;width:inherit}.bwg_image_wrap *{-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none}.bwg_comment_wrap,.bwg_ecommerce_wrap{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0;z-index:-1}.bwg_comment_container,.bwg_ecommerce_container{-moz-box-sizing:border-box;height:100%;overflow:hidden;position:absolute;top:0;z-index:10103}#bwg_ecommerce{padding:10px}.bwg_ecommerce_body{background:0 0!important;border:none!important}.pge_tabs{list-style-type:none;margin:0;padding:0;background:0 0!important}.pge_tabs li a,.pge_tabs li a:hover,.pge_tabs li.pge_active a{text-decoration:none;display:block;width:100%;outline:0!important;padding:8px 5px!important;font-weight:700;font-size:13px}.pge_add_to_cart a{padding:5px 10px;text-decoration:none!important;display:block}.pge_add_to_cart{margin:5px 0 15px}.pge_add_to_cart_title{font-size:17px;padding:5px}.pge_add_to_cart div:first-child{float:left}.pge_add_to_cart div:last-child{float:right;margin-top:4px}.pge_add_to_cart:after,.pge_tabs:after{clear:both;content:"";display:table}#downloads table tr td,#downloads table tr th{padding:6px 10px!important;text-transform:none!important}.bwg_comments input[type=submit],.bwg_ecommerce_panel input[type=button]{cursor:pointer;font-size:15px;width:100%;margin-bottom:5px}.bwg_comments,.bwg_ecommerce_panel{bottom:0;height:100%;left:0;overflow-x:hidden;overflow-y:auto;position:absolute;top:0;width:100%;z-index:10101}.bwg_comments{height:100%}.bwg_comment_body_p,.bwg_comments p{margin:5px!important;text-align:left;word-wrap:break-word;word-break:break-all}.bwg_ecommerce_panel p{padding:5px!important;text-align:left;word-wrap:break-word;word-break:break-all;margin:0!important}.bwg_comments .bwg-submit-disabled{opacity:.5}.bwg_comments textarea{height:120px;resize:vertical}.bwg_comment_delete_btn{color:#7a7a7a;cursor:pointer;float:right;font-size:14px;margin:2px}.bwg_comments_close,.bwg_ecommerce_close{cursor:pointer;line-height:0;position:relative;font-size:13px;margin:5px;z-index:10150}.bwg_ecommerce_panel a:hover{text-decoration:underline}.bwg_comment_textarea::-webkit-scrollbar{width:4px}.bwg_comment_textarea::-webkit-scrollbar-thumb{background-color:rgba(255,255,255,.55);border-radius:2px}.bwg_comment_textarea::-webkit-scrollbar-thumb:hover{background-color:#d9d9d9}.bwg_ctrl_btn_container a,.bwg_ctrl_btn_container a:hover{text-decoration:none}.bwg_facebook:hover{color:#3b5998}.bwg_twitter:hover{color:#4099fb}.bwg_pinterest:hover{color:#cb2027}.bwg_tumblr:hover{color:#2f5070}.bwg_image_container{display:table;position:absolute;text-align:center;vertical-align:middle;width:100%}.bwg_filmstrip_container{position:absolute;z-index:10150}.bwg_filmstrip{overflow:hidden;position:absolute;z-index:10106}.bwg_filmstrip_thumbnails{margin:0 auto;overflow:hidden;position:relative}.bwg_filmstrip_thumbnail{position:relative;background:0 0;float:left;cursor:pointer;overflow:hidden}.bwg_filmstrip_thumbnail .bwg_filmstrip_thumbnail_img_wrap{overflow:hidden}.bwg_thumb_active{opacity:1}.bwg_filmstrip_thumbnail_img{display:block;opacity:1}.bwg_filmstrip_left{cursor:pointer;vertical-align:middle;z-index:10106;line-height:0}.bwg_filmstrip_right{cursor:pointer;vertical-align:middle;z-index:10106;line-height:0}.bwg_none_selectable{-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.bwg_watermark_container{display:table-cell;margin:0 auto;position:relative;vertical-align:middle}.bwg_watermark_container>div{display:table;margin:0 auto}.bwg_watermark_spun{display:table-cell;overflow:hidden;position:relative}.bwg_watermark_image{margin:4px;position:relative;z-index:10141}.bwg_watermark_text,.bwg_watermark_text:hover{text-decoration:none;margin:4px;position:relative;z-index:10141}.bwg_slide_container{display:table-cell;position:absolute;vertical-align:middle;width:100%;height:100%}.bwg_slide_bg{margin:0 auto;width:inherit;height:inherit}.bwg_slider{height:inherit;width:inherit}.bwg_popup_image_spun{height:inherit;display:table-cell;opacity:1;position:absolute;vertical-align:middle;width:inherit;z-index:2}.bwg_popup_image_second_spun{width:inherit;height:inherit;display:table-cell;opacity:0;position:absolute;vertical-align:middle;z-index:1}.bwg_grid{display:none;height:100%;overflow:hidden;position:absolute;width:100%}.bwg_gridlet{opacity:1;position:absolute}.bwg_image_info::-webkit-scrollbar{width:4px}.bwg_image_info::-webkit-scrollbar-thumb{background-color:rgba(255,255,255,.55);border-radius:2px}.bwg_image_info::-webkit-scrollbar-thumb:hover{background-color:#d9d9d9}#bwg_rate_form .bwg_hint{margin:0 5px;display:none}.bwg_star{display:inline-block;width:unset!important}.bwg_image_count_container{left:0;line-height:1;position:absolute;vertical-align:middle}#bwg_comment_form label{display:block;font-weight:700;margin-top:17px;text-transform:uppercase}#bwg_comment_form .bwg-privacy-policy-box label{text-transform:unset;word-break:break-word}.bwg_popup_image_spun .bwg_popup_image_spun1{width:inherit;height:inherit}.bwg_popup_image_spun1 .bwg_popup_image_spun2{vertical-align:middle;text-align:center;height:100%}#embed_conteiner{table-layout:fixed;height:100%}#opacity_div{background-color:rgba(255,255,255,.2);position:absolute;z-index:10150}#loading_div{text-align:center;position:relative;vertical-align:middle;z-index:10170;float:none;width:30px;height:30px;background-size:30px 30px;background-repeat:no-repeat;background-position:50% 50%}#ecommerce_ajax_loading{position:absolute}#ecommerce_opacity_div{display:none;background-color:rgba(255,255,255,.2);position:absolute;z-index:10150}#ecommerce_loading_div{display:none;text-align:center;position:relative;vertical-align:middle;z-index:10170;float:none;width:30px;height:30px;background-size:30px 30px;background-repeat:no-repeat;background-position:50% 50%}.bwg_ecommerce_panel.bwg_popup_sidebar_panel.bwg_popup_sidebar{text-align:left}#ajax_loading{position:absolute}@media (max-width:480px){.bwg_image_count_container{display:none}.bwg_image_title,.bwg_image_title *{font-size:12px}.bwg_image_description,.bwg_image_description *{font-size:10px}}@media (pointer:none),(pointer:coarse){#bwg_container1_0 #bwg_container2_0 .bwg-container-0.bwg-masonry-thumbnails .bwg-title1,#bwg_container1_0 #bwg_container2_0 .bwg-container-0.bwg-standard-thumbnails .bwg-title1,.bwg-mosaic-thumbnails{opacity:1!important}.bwg-zoom-effect .bwg-zoom-effect-overlay,.bwg-zoom-effect-overlay>span{opacity:1!important;background-color:unset!important}}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_image_wrap_] *{box-sizing:border-box;-moz-box-sizing:border-box;-webkit-box-sizing:border-box}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_image_wrap_]{border-collapse:collapse;display:table;position:relative;text-align:center;margin:auto}div[id^=bwg_container1_] div[id^=bwg_container2_] img[class^=bwg_slideshow_image_]{display:inline-block;padding:0!important;margin:0!important;float:none!important;vertical-align:middle}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_embed_]{padding:0!important;margin:0!important;float:none!important;vertical-align:middle;display:inline-block;text-align:center}div[id^=bwg_container1_] div[id^=bwg_container2_] img[class^=bwg_slideshow_watermark_]{position:relative;z-index:15}div[id^=bwg_container1_] div[id^=bwg_container2_] span.bwg_slideshow_play_pause{bottom:0;cursor:pointer;display:table;height:inherit;outline:medium none;position:absolute;width:30%;left:35%;z-index:13}div[id^=bwg_container1_] div[id^=bwg_container2_] span.bwg_slideshow_play_pause:hover span[id^=bwg_slideshow_play_pause-ico_]{display:inline-block!important}div[id^=bwg_container1_] div[id^=bwg_container2_] span.bwg_slideshow_play_pause:hover span{position:relative;z-index:13}div[id^=bwg_container1_] div[id^=bwg_container2_] span.bwg_slideshow_play_pause span{display:table-cell;text-align:center;vertical-align:middle;z-index:13}div[id^=bwg_container1_] div[id^=bwg_container2_] span[id^=bwg_slideshow_play_pause-ico_]{display:none!important;cursor:pointer;position:relative;z-index:13}div[id^=bwg_container1_] div[id^=bwg_container2_] span[id^=bwg_slideshow_play_pause-ico_]:hover{display:inline-block;position:relative;z-index:13}div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_left_],div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_right_]{bottom:35%;cursor:pointer;display:inline;height:30%;outline:medium none;position:absolute;width:35%;z-index:13}div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_left_]{left:0}div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_right_]{right:0}div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_left_]:hover,div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_right_]:hover{visibility:visible}div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_left_]:hover,div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_right_]:hover{visibility:visible}div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_right_]:hover span{left:auto!important;right:20px!important}div[id^=bwg_container1_] div[id^=bwg_container2_] a[id^=spider_slideshow_left_]:hover span{left:20px!important}div[id^=bwg_container1_] div[id^=bwg_container2_] span[id^=spider_slideshow_left-ico_] span,div[id^=bwg_container1_] div[id^=bwg_container2_] span[id^=spider_slideshow_right-ico_] span{display:table-cell;text-align:center;vertical-align:middle;z-index:13}div[id^=bwg_container1_] div[id^=bwg_container2_] span[id^=spider_slideshow_left-ico_],div[id^=bwg_container1_] div[id^=bwg_container2_] span[id^=spider_slideshow_right-ico_]{z-index:13;-moz-box-sizing:content-box;box-sizing:content-box;cursor:pointer;display:table;line-height:0;margin-top:-15px;position:absolute;top:50%}div[id^=bwg_container1_] div[id^=bwg_container2_] span[id^=spider_slideshow_left-ico_]:hover,div[id^=bwg_container1_] div[id^=bwg_container2_] span[id^=spider_slideshow_right-ico_]:hover{cursor:pointer}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_image_container_]{display:table;position:absolute;text-align:center;vertical-align:middle}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_filmstrip_container_]{position:absolute}div[id^=bwg_container1_] div[id^=bwg_container2_] .bwg_slideshow_filmstrip{overflow:hidden;position:absolute}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_filmstrip_thumbnails_]{margin:0 auto;overflow:hidden;position:relative}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_filmstrip_thumbnail_]{position:relative;background:0 0;cursor:pointer;float:left;overflow:hidden}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_thumb_active_]{opacity:1}div[id^=bwg_container1_] div[id^=bwg_container2_] img[class^=bwg_slideshow_filmstrip_thumbnail_img_]{display:block;opacity:1;padding:0!important}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_filmstrip_left_]{cursor:pointer;vertical-align:middle}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_filmstrip_right_]{cursor:pointer;vertical-align:middle}div[id^=bwg_container1_] div[id^=bwg_container2_] a[class^=bwg_none_selectable_]{-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_watermark_container_]{display:table-cell;margin:0 auto;position:relative;vertical-align:middle}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_watermark_spun_]{display:table-cell;overflow:hidden;position:relative}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_title_spun_]{display:table-cell;overflow:hidden;position:relative}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_description_spun_]{display:table-cell;overflow:hidden;position:relative}div[id^=bwg_container1_] div[id^=bwg_container2_] img[class^=bwg_slideshow_watermark_image_]{padding:0!important;float:none!important;margin:4px!important;position:relative;z-index:15}div[id^=bwg_container1_] div[id^=bwg_container2_] a[class^=bwg_slideshow_watermark_text_],div[id^=bwg_container1_] div[id^=bwg_container2_] a[class^=bwg_slideshow_watermark_text_]:hover{text-decoration:none;margin:4px;position:relative;z-index:15}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_title_text_]{text-decoration:none;position:relative;z-index:11;display:inline-block;word-wrap:break-word;word-break:break-word}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_description_text_]{text-decoration:none;position:relative;z-index:15;margin:5px;display:inline-block;word-wrap:break-word;word-break:break-word}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slide_container_]{display:table-cell;margin:0 auto;position:absolute;vertical-align:middle;width:100%;height:100%}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slide_bg_]{margin:0 auto;width:inherit;height:inherit}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slider_]{height:inherit;width:inherit}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_image_spun_]{width:inherit;height:inherit;display:table-cell;opacity:1;position:absolute;vertical-align:middle;z-index:2}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_image_second_spun_]{width:inherit;height:inherit;display:table-cell;opacity:0;position:absolute;vertical-align:middle;z-index:1}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_grid_]{display:none;height:100%;overflow:hidden;position:absolute;width:100%}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_gridlet_]{opacity:1;position:absolute}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_dots_]{display:inline-block;position:relative;cursor:pointer;overflow:hidden;z-index:17}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_dots_container_]{display:block;overflow:hidden;position:absolute;z-index:17}div[id^=bwg_container1_] div[id^=bwg_container2_] div[class^=bwg_slideshow_dots_thumbnails_]{left:0;font-size:0;margin:0 auto;overflow:hidden;position:relative}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_dots_active_]{opacity:1}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_image_spun1_]{display:table;width:inherit;height:inherit}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_slideshow_image_spun2_]{display:table-cell;vertical-align:middle;text-align:center}div[id^=bwg_container1_] div[id^=bwg_container2_] span[class^=bwg_mosaic_play_icon_spun_]{display:flex;height:100%;opacity:1;position:absolute;top:0;width:100%;z-index:100;justify-content:center;align-content:center;flex-direction:column;text-align:center;left:0}.lazy_loader{background-image:url(../images/ajax_loader.png);background-size:30px 30px;background-repeat:no-repeat;background-position:50% 50%}.bwg-container-temp0{visibility:hidden!important;position:absolute!important}.bwg_image_browser .pagination-links{display:flex;padding:0}.bwg_image_browser .pagination-links_col1{flex-grow:3;text-align:left}.bwg_image_browser .pagination-links_col2{flex-grow:4;text-align:center}.bwg_image_browser .pagination-links_col3{flex-grow:3;text-align:right}.bwg_current_page[type=number]{width:35px;display:inline-block;-moz-appearance:textfield;line-height:normal!important}.bwg_current_page::-webkit-inner-spin-button,.bwg_current_page::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.bwg_container .bwg_tag_button_view_container{display:flex;justify-content:flex-start;align-content:flex-start;align-items:flex-start;margin-bottom:45px;position:relative;padding-top:3px;flex-wrap:wrap;overflow:hidden;clear:both}.bwg_container .bwg_tag_button_view_container button{cursor:pointer}.bwg_container .bwg_tag_button_view_container button.active{cursor:default}.bwg_container .bwg_tag_button_view_container .verLine{min-height:26px;margin:0 15px}.bwg_container .bwg_tag_button_see_all{margin-bottom:70px;position:relative;display:none}.bwg_container .bwg_tag_button_see_all .see_all_tags{text-transform:uppercase;position:absolute;padding:10px 25px;font-weight:600;cursor:pointer;left:47%;top:-23px}.bwg_container .bwg_tag_button_see_all .see_all_tags span{display:inline-block;line-height:normal;text-align:center;border-radius:50%;margin-right:10px;font-weight:500;color:#fff;height:18px;width:18px}.bwg_addThis{position:absolute;left:10px;top:10px;z-index:9999}
css/sumoselect.css CHANGED
@@ -1,51 +1,126 @@
1
- .SumoSelect p {margin: 0;}
2
- .SumoSelect{width: 200px;}
 
 
 
 
3
 
4
- .SelectBox {padding: 5px 8px;}
 
 
5
 
6
- .sumoStopScroll{overflow:hidden;}
 
 
7
 
8
  /* Filtering style */
9
- .SumoSelect .hidden { display:none; }
10
- .SumoSelect .search-txt{display:none;outline:none;}
11
- .SumoSelect .no-match{display:none;padding: 6px;}
12
- .SumoSelect.open .search-txt{display: inline-block;position: absolute;top: 0;left: 0;width: 100%;margin: 0;padding: 4px 8px;border: none;-webkit-box-sizing: border-box;-moz-box-sizing: border-box;box-sizing: border-box;border-radius: 5px;}
13
- .SumoSelect.open>.search>span, .SumoSelect.open>.search>label{visibility:hidden;}
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
14
 
15
  /*this is applied on that hidden select. DO NOT USE display:none; or visiblity:hidden; and Do not override any of these properties. */
16
- .bwg_thumbnail .SelectClass,.bwg_thumbnail .SumoUnder { position: absolute; top: 0; left: 0; right: 0; height: 100%; width: 100%; border: none; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; -moz-opacity: 0; -khtml-opacity: 0; opacity: 0; }
17
- .SelectClass, .SumoUnder {
18
- display: inline-block;
19
  position: absolute;
20
  top: 0;
21
  left: 0;
22
  right: 0;
23
  height: 100%;
24
- width: 102%;
25
  border: none;
26
  -webkit-box-sizing: border-box;
27
  -moz-box-sizing: border-box;
28
  box-sizing: border-box;
 
 
29
  -moz-opacity: 0;
30
  -khtml-opacity: 0;
31
  opacity: 0;
32
  }
33
- .SelectClass{z-index: 1;}
 
 
34
 
35
- .SumoSelect > .optWrapper > .options li.opt label, .SumoSelect > .CaptionCont,.SumoSelect .select-all > label { user-select: none; -o-user-select: none; -moz-user-select: none; -khtml-user-select: none; -webkit-user-select: none; }
 
 
 
 
 
 
 
 
36
 
37
- .SumoSelect { display: inline-block; position: relative;outline:none;}
38
- .SumoSelect:focus > .CaptionCont,.SumoSelect:hover > .CaptionCont, .SumoSelect.open > .CaptionCont {box-shadow: 0 0 2px #7799D0;border-color: #7799D0;}
39
- .SumoSelect > .CaptionCont { position: relative; border: 1px solid #A4A4A4; min-height: 14px; background-color: #fff;border-radius:2px;margin:0; }
40
- .SumoSelect > .CaptionCont > span { display: block; padding-right: 0px; text-overflow: ellipsis; white-space: nowrap; overflow: hidden;cursor:default;}
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
41
  /*placeholder style*/
42
- .SumoSelect > .CaptionCont > span.placeholder { color: #000000; }
43
-
44
- .SumoSelect > .CaptionCont > label { position: absolute; top: 0; right: 0; bottom: 0; width: 30px;}
45
-
46
- .SumoSelect > .CaptionCont > label { position: absolute; top: 0; right: 0; bottom: 0; width: 30px;}
47
- .bwg_thumbnail .SumoSelect > .CaptionCont > label > i {
48
- background-image: none;
 
 
 
 
 
 
 
 
 
49
  background-position: center center;
50
  width: 16px;
51
  height: 16px;
@@ -59,86 +134,264 @@
59
  background-repeat: no-repeat;
60
  opacity: 0.8;
61
  }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
62
 
63
-
64
- .bwg_thumbnail .SumoSelect > .CaptionCont > label > i {
65
- background-position: center center; width: 16px; height: 16px; display: block; position: absolute; top: 0; left: 0; right: 0; margin: auto;background-repeat: no-repeat;opacity: 0.8;}
66
-
67
- .SumoSelect > .optWrapper {display:none; z-index: 1000; top: 30px; width: 100%; position: absolute; left: 0; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; background: #fff; border: 1px solid #ddd; box-shadow: 2px 3px 3px rgba(0, 0, 0, 0.11); border-radius: 15px;overflow: hidden;}
68
- .SumoSelect.open > .optWrapper {top:35px; display:block;}
69
- .SumoSelect.open > .optWrapper.up {top: auto;bottom: 100%;margin-bottom: 5px;}
70
-
71
- .SumoSelect > .optWrapper ul {list-style: none; display: block; padding: 0; margin: 0; overflow: auto;}
72
- .SumoSelect > .optWrapper > .options { border-radius: 2px;position:relative;
73
  /*Set the height of pop up here (only for desktop mode)*/
74
  max-height: 250px;
75
- /*height*/ }
76
- .SumoSelect > .optWrapper > .options li.group.disabled > label{opacity:0.5;}
77
- .SumoSelect > .optWrapper > .options li ul li.opt{padding-left: 22px;}
78
- .SumoSelect > .optWrapper.multiple > .options li ul li.opt{padding-left: 50px;}
79
- .SumoSelect > .optWrapper.isFloating > .options {max-height: 100%;box-shadow: 0 0 100px #595959;}
80
- .SumoSelect > .optWrapper > .options li.opt { padding: 6px 6px; position: relative;}
81
- .SumoSelect > .optWrapper > .options > li.opt:first-child { border-radius: 2px 2px 0 0; }
82
- .SumoSelect > .optWrapper > .options > li.opt:last-child {border-radius: 0 0 2px 2px; border-bottom: none;}
83
- .bwg_thumbnail .SumoSelect > .optWrapper > .options li.opt > label:hover { color: #323A45; opacity: 0.7; }
84
- .SumoSelect > .optWrapper > .options li.opt:hover { background-color: #E4E4E4; }
85
- .SumoSelect > .optWrapper > .options li.opt.sel{background-color: #a1c0e4; border-bottom: 1px solid #a1c0e4;}
86
-
87
- .SumoSelect > .optWrapper > .options li label { text-overflow: ellipsis; white-space: nowrap; overflow: hidden; display: block;cursor: pointer;}
88
- .SumoSelect > .optWrapper > .options li span { display: none; }
89
- .SumoSelect > .optWrapper > .options li.group > label {cursor: default;padding: 8px 6px;font-weight: bold;}
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
90
 
91
  /*Floating styles*/
92
- .SumoSelect > .optWrapper.isFloating { position: fixed; top: 0; left: 0; right: 0; width: 90%; bottom: 0; margin: auto; max-height: 90%; }
 
 
 
 
 
 
 
 
 
93
 
94
  /*disabled state*/
95
- .SumoSelect > .optWrapper > .options li.opt.disabled { background-color: inherit;pointer-events: none;}
96
- .SumoSelect > .optWrapper > .options li.opt.disabled * { /* Netscape */ -moz-opacity: 0.5; /* Safari 1.x */ -khtml-opacity: 0.5; /* Good browsers */ opacity: 0.5; }
97
-
 
 
 
 
 
 
 
 
98
 
99
  /*styling for multiple select*/
100
- .SumoSelect > .optWrapper.multiple > .options li.opt { padding-left: 35px;cursor: pointer;}
 
 
 
101
  .SumoSelect > .optWrapper.multiple > .options li.opt span,
102
- .SumoSelect .select-all > span{position:absolute;display:block;width:30px;top:0;bottom:0;margin-left:-35px;}
 
 
 
 
 
 
 
103
  .SumoSelect > .optWrapper.multiple > .options li.opt span i,
104
- .SumoSelect .select-all > span i{position: absolute;margin: auto;left: 0;right: 0;top: 0;bottom: 0;width: 14px;height: 14px;border: 1px solid #AEAEAE;border-radius: 2px;box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.15);background-color: #fff;}
105
- .SumoSelect > .optWrapper > .MultiControls { display: none; border-top: 1px solid #ddd; background-color: #fff; box-shadow: 0 0 2px rgba(0, 0, 0, 0.13); border-radius: 0 0 3px 3px; }
106
- .SumoSelect > .optWrapper.multiple.isFloating > .MultiControls { display: block; margin-top: 5px; position: absolute; bottom: 0; width: 100%; }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
107
 
108
- .SumoSelect > .optWrapper.multiple.okCancelInMulti > .MultiControls { display: block; }
109
- .SumoSelect > .optWrapper.multiple.okCancelInMulti > .MultiControls > p { padding: 6px; }
 
 
 
 
 
 
 
 
 
 
110
 
111
- .SumoSelect > .optWrapper.multiple > .MultiControls > p { display: inline-block; cursor: pointer; padding: 12px; width: 50%; box-sizing: border-box; text-align: center; }
112
- .SumoSelect > .optWrapper.multiple > .MultiControls > p:hover { background-color: #f1f1f1; }
113
- .SumoSelect > .optWrapper.multiple > .MultiControls > p.btnOk { border-right: 1px solid #DBDBDB; border-radius: 0 0 0 3px; }
114
- .SumoSelect > .optWrapper.multiple > .MultiControls > p.btnCancel { border-radius: 0 0 3px 0; }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
115
  /*styling for select on popup mode*/
116
- .bwg_thumbnail .SumoSelect > .optWrapper.isFloating > .options li.opt { padding: 0px; }
117
- .SumoSelect > .optWrapper.isFloating > .options li.opt { padding: 12px 6px; }
 
118
 
119
  /*styling for only multiple select on popup mode*/
120
- .SumoSelect > .optWrapper.multiple.isFloating > .options li.opt { padding-left: 35px; }
121
- .SumoSelect > .optWrapper.multiple.isFloating { padding-bottom: 43px; }
 
 
 
 
122
 
123
  .SumoSelect > .optWrapper.multiple > .options li.opt.selected span i,
124
  .SumoSelect .select-all.selected > span i,
125
- .SumoSelect .select-all.partial > span i{background-color: rgb(17, 169, 17);box-shadow: none;
126
- /*
127
- background-image: url('');
128
- */
129
- background-image:url('');
130
  background-repeat: no-repeat;
131
- background-position: center center;}
 
132
  /*disabled state*/
133
- .SumoSelect.disabled { opacity: 0.7;cursor: not-allowed;}
134
- .SumoSelect.disabled > .CaptionCont{border-color:#ccc;box-shadow:none;}
 
 
 
 
 
 
135
 
136
  /**Select all button**/
137
- .SumoSelect .select-all{border-radius: 3px 3px 0 0;position: relative;border-bottom: 1px solid #ddd;background-color: #fff;padding: 8px 0 3px 35px;height: 20px;cursor: pointer;}
138
- .SumoSelect .select-all > label, .SumoSelect .select-all > span i{cursor: pointer;}
139
- .SumoSelect .select-all.partial > span i{background-color:#ccc;}
140
-
 
 
 
 
 
 
 
 
 
 
 
 
141
 
142
  /*styling for optgroups*/
143
- .SumoSelect > .optWrapper > .options li.optGroup { padding-left: 5px; text-decoration: underline; }
144
-
 
 
1
+ .SumoSelect p {
2
+ margin: 0;
3
+ }
4
+ .SumoSelect {
5
+ width: 200px;
6
+ }
7
 
8
+ .SelectBox {
9
+ padding: 5px 8px;
10
+ }
11
 
12
+ .sumoStopScroll {
13
+ overflow: hidden;
14
+ }
15
 
16
  /* Filtering style */
17
+ .SumoSelect .hidden {
18
+ display: none;
19
+ }
20
+ .SumoSelect .search-txt {
21
+ display: none;
22
+ outline: none;
23
+ }
24
+ .SumoSelect .no-match {
25
+ display: none;
26
+ padding: 6px;
27
+ }
28
+ .SumoSelect.open .search-txt {
29
+ display: inline-block;
30
+ position: absolute;
31
+ top: 0;
32
+ left: 0;
33
+ width: 100%;
34
+ margin: 0;
35
+ padding: 5px 8px;
36
+ border: none;
37
+ -webkit-box-sizing: border-box;
38
+ -moz-box-sizing: border-box;
39
+ box-sizing: border-box;
40
+ border-radius: 5px;
41
+ }
42
+ .SumoSelect.open > .search > span,
43
+ .SumoSelect.open > .search > label {
44
+ visibility: hidden;
45
+ }
46
 
47
  /*this is applied on that hidden select. DO NOT USE display:none; or visiblity:hidden; and Do not override any of these properties. */
48
+ .SelectClass,
49
+ .SumoUnder {
 
50
  position: absolute;
51
  top: 0;
52
  left: 0;
53
  right: 0;
54
  height: 100%;
55
+ width: 100%;
56
  border: none;
57
  -webkit-box-sizing: border-box;
58
  -moz-box-sizing: border-box;
59
  box-sizing: border-box;
60
+ -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
61
+ filter: alpha(opacity=0);
62
  -moz-opacity: 0;
63
  -khtml-opacity: 0;
64
  opacity: 0;
65
  }
66
+ .SelectClass {
67
+ z-index: 1;
68
+ }
69
 
70
+ .SumoSelect > .optWrapper > .options li.opt label,
71
+ .SumoSelect > .CaptionCont,
72
+ .SumoSelect .select-all > label {
73
+ user-select: none;
74
+ -o-user-select: none;
75
+ -moz-user-select: none;
76
+ -khtml-user-select: none;
77
+ -webkit-user-select: none;
78
+ }
79
 
80
+ .SumoSelect {
81
+ display: inline-block;
82
+ position: relative;
83
+ outline: none;
84
+ }
85
+ .SumoSelect:focus > .CaptionCont,
86
+ .SumoSelect:hover > .CaptionCont,
87
+ .SumoSelect.open > .CaptionCont {
88
+ box-shadow: 0 0 2px #7799d0;
89
+ border-color: #7799d0;
90
+ }
91
+ .SumoSelect > .CaptionCont {
92
+ position: relative;
93
+ border: 1px solid #a4a4a4;
94
+ min-height: 14px;
95
+ background-color: #fff;
96
+ border-radius: 2px;
97
+ margin: 0;
98
+ }
99
+ .SumoSelect > .CaptionCont > span {
100
+ display: block;
101
+ padding-right: 30px;
102
+ text-overflow: ellipsis;
103
+ white-space: nowrap;
104
+ overflow: hidden;
105
+ cursor: default;
106
+ }
107
  /*placeholder style*/
108
+ /* this part affects our style
109
+ .SumoSelect > .CaptionCont > span.placeholder {
110
+ color: #ccc;
111
+ font-style: italic;
112
+ }
113
+ */
114
+ .SumoSelect > .CaptionCont > label {
115
+ position: absolute;
116
+ top: 0;
117
+ right: 0;
118
+ bottom: 0;
119
+ width: 30px;
120
+ }
121
+ /* this part affects our style
122
+ .SumoSelect > .CaptionCont > label > i {
123
+ background-image: url("");
124
  background-position: center center;
125
  width: 16px;
126
  height: 16px;
134
  background-repeat: no-repeat;
135
  opacity: 0.8;
136
  }
137
+ */
138
+ .SumoSelect > .optWrapper {
139
+ display: none;
140
+ z-index: 1000;
141
+ top: 30px;
142
+ width: 100%;
143
+ position: absolute;
144
+ left: 0;
145
+ -webkit-box-sizing: border-box;
146
+ -moz-box-sizing: border-box;
147
+ box-sizing: border-box;
148
+ background: #fff;
149
+ border: 1px solid #ddd;
150
+ box-shadow: 2px 3px 3px rgba(0, 0, 0, 0.11);
151
+ border-radius: 3px;
152
+ overflow: hidden;
153
+ }
154
+ .SumoSelect.open > .optWrapper {
155
+ top: 35px;
156
+ display: block;
157
+ }
158
+ .SumoSelect.open > .optWrapper.up {
159
+ top: auto;
160
+ bottom: 100%;
161
+ margin-bottom: 5px;
162
+ }
163
 
164
+ .SumoSelect > .optWrapper ul {
165
+ list-style: none;
166
+ display: block;
167
+ padding: 0;
168
+ margin: 0;
169
+ overflow: auto;
170
+ }
171
+ .SumoSelect > .optWrapper > .options {
172
+ border-radius: 2px;
173
+ position: relative;
174
  /*Set the height of pop up here (only for desktop mode)*/
175
  max-height: 250px;
176
+ /*height*/
177
+ }
178
+ .SumoSelect > .optWrapper.okCancelInMulti > .options {
179
+ border-radius: 2px 2px 0 0;
180
+ }
181
+ .SumoSelect > .optWrapper.selall > .options {
182
+ border-radius: 0 0 2px 2px;
183
+ }
184
+ .SumoSelect > .optWrapper.selall.okCancelInMulti > .options {
185
+ border-radius: 0;
186
+ }
187
+ .SumoSelect > .optWrapper > .options li.group.disabled > label {
188
+ opacity: 0.5;
189
+ }
190
+ .SumoSelect > .optWrapper > .options li ul li.opt {
191
+ padding-left: 22px;
192
+ }
193
+ .SumoSelect > .optWrapper.multiple > .options li ul li.opt {
194
+ padding-left: 50px;
195
+ }
196
+ .SumoSelect > .optWrapper.isFloating > .options {
197
+ max-height: 100%;
198
+ box-shadow: 0 0 100px #595959;
199
+ }
200
+ .SumoSelect > .optWrapper > .options li.opt {
201
+ padding: 6px 6px;
202
+ position: relative;
203
+ border-bottom: 1px solid #f5f5f5;
204
+ }
205
+ .SumoSelect > .optWrapper > .options > li.opt:first-child {
206
+ border-radius: 2px 2px 0 0;
207
+ }
208
+ .SumoSelect > .optWrapper.selall > .options > li.opt:first-child {
209
+ border-radius: 0;
210
+ }
211
+ .SumoSelect > .optWrapper > .options > li.opt:last-child {
212
+ border-radius: 0 0 2px 2px;
213
+ border-bottom: none;
214
+ }
215
+ .SumoSelect > .optWrapper.okCancelInMulti > .options > li.opt:last-child {
216
+ border-radius: 0;
217
+ }
218
+ .SumoSelect > .optWrapper > .options li.opt:hover {
219
+ background-color: #e4e4e4;
220
+ }
221
+ .SumoSelect > .optWrapper > .options li.opt.sel,
222
+ .SumoSelect .select-all.sel {
223
+ background-color: #a1c0e4;
224
+ }
225
+
226
+ .SumoSelect > .optWrapper > .options li label {
227
+ text-overflow: ellipsis;
228
+ white-space: nowrap;
229
+ overflow: hidden;
230
+ display: block;
231
+ cursor: pointer;
232
+ }
233
+ .SumoSelect > .optWrapper > .options li span {
234
+ display: none;
235
+ }
236
+ .SumoSelect > .optWrapper > .options li.group > label {
237
+ cursor: default;
238
+ padding: 8px 6px;
239
+ font-weight: bold;
240
+ }
241
 
242
  /*Floating styles*/
243
+ .SumoSelect > .optWrapper.isFloating {
244
+ position: fixed;
245
+ top: 0;
246
+ left: 0;
247
+ right: 0;
248
+ width: 90%;
249
+ bottom: 0;
250
+ margin: auto;
251
+ max-height: 90%;
252
+ }
253
 
254
  /*disabled state*/
255
+ .SumoSelect > .optWrapper > .options li.opt.disabled {
256
+ background-color: inherit;
257
+ pointer-events: none;
258
+ }
259
+ .SumoSelect > .optWrapper > .options li.opt.disabled * {
260
+ -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)"; /* IE 5-7 */
261
+ filter: alpha(opacity=50); /* Netscape */
262
+ -moz-opacity: 0.5; /* Safari 1.x */
263
+ -khtml-opacity: 0.5; /* Good browsers */
264
+ opacity: 0.5;
265
+ }
266
 
267
  /*styling for multiple select*/
268
+ .SumoSelect > .optWrapper.multiple > .options li.opt {
269
+ padding-left: 35px;
270
+ cursor: pointer;
271
+ }
272
  .SumoSelect > .optWrapper.multiple > .options li.opt span,
273
+ .SumoSelect .select-all > span {
274
+ position: absolute;
275
+ display: block;
276
+ width: 30px;
277
+ top: 0;
278
+ bottom: 0;
279
+ margin-left: -35px;
280
+ }
281
  .SumoSelect > .optWrapper.multiple > .options li.opt span i,
282
+ .SumoSelect .select-all > span i {
283
+ position: absolute;
284
+ margin: auto;
285
+ left: 0;
286
+ right: 0;
287
+ top: 0;
288
+ bottom: 0;
289
+ width: 14px;
290
+ height: 14px;
291
+ border: 1px solid #aeaeae;
292
+ border-radius: 2px;
293
+ box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.15);
294
+ background-color: #fff;
295
+ }
296
+ .SumoSelect > .optWrapper > .MultiControls {
297
+ display: none;
298
+ border-top: 1px solid #ddd;
299
+ background-color: #fff;
300
+ box-shadow: 0 0 2px rgba(0, 0, 0, 0.13);
301
+ border-radius: 0 0 3px 3px;
302
+ }
303
+ .SumoSelect > .optWrapper.multiple.isFloating > .MultiControls {
304
+ display: block;
305
+ margin-top: 5px;
306
+ position: absolute;
307
+ bottom: 0;
308
+ width: 100%;
309
+ }
310
 
311
+ .SumoSelect > .optWrapper.multiple.okCancelInMulti > .MultiControls {
312
+ display: block;
313
+ }
314
+ .SumoSelect > .optWrapper.multiple.okCancelInMulti > .MultiControls > p {
315
+ padding: 6px;
316
+ }
317
+ .SumoSelect > .optWrapper.multiple.okCancelInMulti > .MultiControls > p:focus {
318
+ box-shadow: 0 0 2px #a1c0e4;
319
+ border-color: #a1c0e4;
320
+ outline: none;
321
+ background-color: #a1c0e4;
322
+ }
323
 
324
+ .SumoSelect > .optWrapper.multiple > .MultiControls > p {
325
+ display: inline-block;
326
+ cursor: pointer;
327
+ padding: 12px;
328
+ width: 50%;
329
+ box-sizing: border-box;
330
+ text-align: center;
331
+ }
332
+ .SumoSelect > .optWrapper.multiple > .MultiControls > p:hover {
333
+ background-color: #f1f1f1;
334
+ }
335
+ .SumoSelect > .optWrapper.multiple > .MultiControls > p.btnOk {
336
+ border-right: 1px solid #dbdbdb;
337
+ border-radius: 0 0 0 3px;
338
+ }
339
+ .SumoSelect > .optWrapper.multiple > .MultiControls > p.btnCancel {
340
+ border-radius: 0 0 3px 0;
341
+ }
342
  /*styling for select on popup mode*/
343
+ .SumoSelect > .optWrapper.isFloating > .options li.opt {
344
+ padding: 12px 6px;
345
+ }
346
 
347
  /*styling for only multiple select on popup mode*/
348
+ .SumoSelect > .optWrapper.multiple.isFloating > .options li.opt {
349
+ padding-left: 35px;
350
+ }
351
+ .SumoSelect > .optWrapper.multiple.isFloating {
352
+ padding-bottom: 43px;
353
+ }
354
 
355
  .SumoSelect > .optWrapper.multiple > .options li.opt.selected span i,
356
  .SumoSelect .select-all.selected > span i,
357
+ .SumoSelect .select-all.partial > span i {
358
+ background-color: rgb(17, 169, 17);
359
+ box-shadow: none;
360
+ border-color: transparent;
361
+ background-image: url("");
362
  background-repeat: no-repeat;
363
+ background-position: center center;
364
+ }
365
  /*disabled state*/
366
+ .SumoSelect.disabled {
367
+ opacity: 0.7;
368
+ cursor: not-allowed;
369
+ }
370
+ .SumoSelect.disabled > .CaptionCont {
371
+ border-color: #ccc;
372
+ box-shadow: none;
373
+ }
374
 
375
  /**Select all button**/
376
+ .SumoSelect .select-all {
377
+ border-radius: 3px 3px 0 0;
378
+ position: relative;
379
+ border-bottom: 1px solid #ddd;
380
+ background-color: #fff;
381
+ padding: 8px 0 3px 35px;
382
+ height: 20px;
383
+ cursor: pointer;
384
+ }
385
+ .SumoSelect .select-all > label,
386
+ .SumoSelect .select-all > span i {
387
+ cursor: pointer;
388
+ }
389
+ .SumoSelect .select-all.partial > span i {
390
+ background-color: #ccc;
391
+ }
392
 
393
  /*styling for optgroups*/
394
+ .SumoSelect > .optWrapper > .options li.optGroup {
395
+ padding-left: 5px;
396
+ text-decoration: underline;
397
+ }
css/sumoselect.min.css CHANGED
@@ -1 +1 @@
1
- .SumoSelect p{margin:0}.SumoSelect{width:200px}.SelectBox{padding:5px 8px}.sumoStopScroll{overflow:hidden}.SumoSelect .hidden{display:none}.SumoSelect .search-txt{display:none;outline:0}.SumoSelect .no-match{display:none;padding:6px}.SumoSelect.open .search-txt{display:inline-block;position:absolute;top:0;left:0;width:100%;margin:0;padding:4px 8px;border:none;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;border-radius:5px}.SelectClass,.SumoUnder,.bwg_thumbnail .SelectClass,.bwg_thumbnail .SumoUnder{position:absolute;height:100%;border:none;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-khtml-opacity:0;top:0;left:0;right:0}.SumoSelect.open>.search>label,.SumoSelect.open>.search>span{visibility:hidden}.bwg_thumbnail .SelectClass,.bwg_thumbnail .SumoUnder{width:100%;box-sizing:border-box;-moz-opacity:0;opacity:0}.SelectClass,.SumoUnder{display:inline-block;width:102%;box-sizing:border-box;-moz-opacity:0;opacity:0}.SelectClass{z-index:1}.SumoSelect .select-all>label,.SumoSelect>.CaptionCont,.SumoSelect>.optWrapper>.options li.opt label{user-select:none;-o-user-select:none;-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none}.SumoSelect{display:inline-block;position:relative;outline:0}.SumoSelect.open>.CaptionCont,.SumoSelect:focus>.CaptionCont,.SumoSelect:hover>.CaptionCont{box-shadow:0 0 2px #7799D0;border-color:#7799D0}.SumoSelect>.CaptionCont{position:relative;border:1px solid #A4A4A4;min-height:14px;background-color:#fff;border-radius:2px;margin:0}.SumoSelect>.CaptionCont>span{display:block;padding-right:0;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;cursor:default}.SumoSelect>.CaptionCont>span.placeholder{color:#000}.SumoSelect>.CaptionCont>label{position:absolute;top:0;right:0;bottom:0;width:30px}.bwg_thumbnail .SumoSelect>.CaptionCont>label>i{background-image:none;bottom:0;background-position:center center;width:16px;height:16px;display:block;position:absolute;top:0;left:0;right:0;margin:auto;background-repeat:no-repeat;opacity:.8}.SumoSelect>.optWrapper{display:none;z-index:1000;top:30px;width:100%;position:absolute;left:0;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;background:#fff;border:1px solid #ddd;box-shadow:2px 3px 3px rgba(0,0,0,.11);border-radius:15px;overflow:hidden}.SumoSelect.open>.optWrapper{top:35px;display:block}.SumoSelect.open>.optWrapper.up{top:auto;bottom:100%;margin-bottom:5px}.SumoSelect>.optWrapper ul{list-style:none;display:block;padding:0;margin:0;overflow:auto}.SumoSelect>.optWrapper>.options{border-radius:2px;position:relative;max-height:250px}.SumoSelect>.optWrapper>.options li.group.disabled>label{opacity:.5}.SumoSelect>.optWrapper>.options li ul li.opt{padding-left:22px}.SumoSelect>.optWrapper.multiple>.options li ul li.opt{padding-left:50px}.SumoSelect>.optWrapper.isFloating>.options{max-height:100%;box-shadow:0 0 100px #595959}.SumoSelect>.optWrapper>.options li.opt{padding:6px;position:relative}.SumoSelect>.optWrapper>.options>li.opt:first-child{border-radius:2px 2px 0 0}.SumoSelect>.optWrapper>.options>li.opt:last-child{border-radius:0 0 2px 2px;border-bottom:none}.bwg_thumbnail .SumoSelect>.optWrapper>.options li.opt>label:hover{color:#323A45;opacity:.7}.SumoSelect>.optWrapper>.options li.opt:hover{background-color:#E4E4E4}.SumoSelect>.optWrapper>.options li.opt.sel{background-color:#a1c0e4;border-bottom:1px solid #a1c0e4}.SumoSelect>.optWrapper>.options li label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;display:block;cursor:pointer}.SumoSelect>.optWrapper>.options li span{display:none}.SumoSelect>.optWrapper>.options li.group>label{cursor:default;padding:8px 6px;font-weight:700}.SumoSelect>.optWrapper.isFloating{position:fixed;top:0;left:0;right:0;width:90%;bottom:0;margin:auto;max-height:90%}.SumoSelect>.optWrapper>.options li.opt.disabled{background-color:inherit;pointer-events:none}.SumoSelect>.optWrapper>.options li.opt.disabled *{-moz-opacity:.5;-khtml-opacity:.5;opacity:.5}.SumoSelect>.optWrapper.multiple>.options li.opt{padding-left:35px;cursor:pointer}.SumoSelect .select-all>span,.SumoSelect>.optWrapper.multiple>.options li.opt span{position:absolute;display:block;width:30px;top:0;bottom:0;margin-left:-35px}.SumoSelect .select-all>span i,.SumoSelect>.optWrapper.multiple>.options li.opt span i{position:absolute;margin:auto;left:0;right:0;top:0;bottom:0;width:14px;height:14px;border:1px solid #AEAEAE;border-radius:2px;box-shadow:inset 0 1px 3px rgba(0,0,0,.15);background-color:#fff}.SumoSelect>.optWrapper>.MultiControls{display:none;border-top:1px solid #ddd;background-color:#fff;box-shadow:0 0 2px rgba(0,0,0,.13);border-radius:0 0 3px 3px}.SumoSelect>.optWrapper.multiple.isFloating>.MultiControls{display:block;margin-top:5px;position:absolute;bottom:0;width:100%}.SumoSelect>.optWrapper.multiple.okCancelInMulti>.MultiControls{display:block}.SumoSelect>.optWrapper.multiple.okCancelInMulti>.MultiControls>p{padding:6px}.SumoSelect>.optWrapper.multiple>.MultiControls>p{display:inline-block;cursor:pointer;padding:12px;width:50%;box-sizing:border-box;text-align:center}.SumoSelect>.optWrapper.multiple>.MultiControls>p:hover{background-color:#f1f1f1}.SumoSelect>.optWrapper.multiple>.MultiControls>p.btnOk{border-right:1px solid #DBDBDB;border-radius:0 0 0 3px}.SumoSelect>.optWrapper.multiple>.MultiControls>p.btnCancel{border-radius:0 0 3px}.bwg_thumbnail .SumoSelect>.optWrapper.isFloating>.options li.opt{padding:0}.SumoSelect>.optWrapper.isFloating>.options li.opt{padding:12px 6px}.SumoSelect>.optWrapper.multiple.isFloating>.options li.opt{padding-left:35px}.SumoSelect>.optWrapper.multiple.isFloating{padding-bottom:43px}.SumoSelect .select-all.partial>span i,.SumoSelect .select-all.selected>span i,.SumoSelect>.optWrapper.multiple>.options li.opt.selected span i{background-color:#11a911;box-shadow:none;background-image:url();background-repeat:no-repeat;background-position:center center}.SumoSelect.disabled{opacity:.7;cursor:not-allowed}.SumoSelect.disabled>.CaptionCont{border-color:#ccc;box-shadow:none}.SumoSelect .select-all{border-radius:3px 3px 0 0;position:relative;border-bottom:1px solid #ddd;background-color:#fff;padding:8px 0 3px 35px;height:20px;cursor:pointer}.SumoSelect .select-all>label,.SumoSelect .select-all>span i{cursor:pointer}.SumoSelect .select-all.partial>span i{background-color:#ccc}.SumoSelect>.optWrapper>.options li.optGroup{padding-left:5px;text-decoration:underline}
1
+ .SumoSelect p{margin:0}.SumoSelect{width:200px}.SelectBox{padding:5px 8px}.sumoStopScroll{overflow:hidden}.SumoSelect .hidden{display:none}.SumoSelect .search-txt{display:none;outline:0}.SumoSelect .no-match{display:none;padding:6px}.SumoSelect.open .search-txt{display:inline-block;position:absolute;top:0;left:0;width:100%;margin:0;padding:5px 8px;border:none;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;border-radius:5px}.SumoSelect.open>.search>label,.SumoSelect.open>.search>span{visibility:hidden}.SelectClass,.SumoUnder{position:absolute;top:0;left:0;right:0;height:100%;width:100%;border:none;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;-moz-opacity:0;-khtml-opacity:0;opacity:0}.SelectClass{z-index:1}.SumoSelect .select-all>label,.SumoSelect>.CaptionCont,.SumoSelect>.optWrapper>.options li.opt label{user-select:none;-o-user-select:none;-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none}.SumoSelect{display:inline-block;position:relative;outline:0}.SumoSelect.open>.CaptionCont,.SumoSelect:focus>.CaptionCont,.SumoSelect:hover>.CaptionCont{box-shadow:0 0 2px #7799d0;border-color:#7799d0}.SumoSelect>.CaptionCont{position:relative;border:1px solid #a4a4a4;min-height:14px;background-color:#fff;border-radius:2px;margin:0}.SumoSelect>.CaptionCont>span{display:block;padding-right:30px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;cursor:default}.SumoSelect>.CaptionCont>label{position:absolute;top:0;right:0;bottom:0;width:30px}.SumoSelect>.optWrapper{display:none;z-index:1000;top:30px;width:100%;position:absolute;left:0;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;background:#fff;border:1px solid #ddd;box-shadow:2px 3px 3px rgba(0,0,0,.11);border-radius:3px;overflow:hidden}.SumoSelect.open>.optWrapper{top:35px;display:block}.SumoSelect.open>.optWrapper.up{top:auto;bottom:100%;margin-bottom:5px}.SumoSelect>.optWrapper ul{list-style:none;display:block;padding:0;margin:0;overflow:auto}.SumoSelect>.optWrapper>.options{border-radius:2px;position:relative;max-height:250px}.SumoSelect>.optWrapper.okCancelInMulti>.options{border-radius:2px 2px 0 0}.SumoSelect>.optWrapper.selall>.options{border-radius:0 0 2px 2px}.SumoSelect>.optWrapper.selall.okCancelInMulti>.options{border-radius:0}.SumoSelect>.optWrapper>.options li.group.disabled>label{opacity:.5}.SumoSelect>.optWrapper>.options li ul li.opt{padding-left:22px}.SumoSelect>.optWrapper.multiple>.options li ul li.opt{padding-left:50px}.SumoSelect>.optWrapper.isFloating>.options{max-height:100%;box-shadow:0 0 100px #595959}.SumoSelect>.optWrapper>.options li.opt{padding:6px 6px;position:relative;border-bottom:1px solid #f5f5f5}.SumoSelect>.optWrapper>.options>li.opt:first-child{border-radius:2px 2px 0 0}.SumoSelect>.optWrapper.selall>.options>li.opt:first-child{border-radius:0}.SumoSelect>.optWrapper>.options>li.opt:last-child{border-radius:0 0 2px 2px;border-bottom:none}.SumoSelect>.optWrapper.okCancelInMulti>.options>li.opt:last-child{border-radius:0}.SumoSelect>.optWrapper>.options li.opt:hover{background-color:#e4e4e4}.SumoSelect .select-all.sel,.SumoSelect>.optWrapper>.options li.opt.sel{background-color:#a1c0e4}.SumoSelect>.optWrapper>.options li label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;display:block;cursor:pointer}.SumoSelect>.optWrapper>.options li span{display:none}.SumoSelect>.optWrapper>.options li.group>label{cursor:default;padding:8px 6px;font-weight:700}.SumoSelect>.optWrapper.isFloating{position:fixed;top:0;left:0;right:0;width:90%;bottom:0;margin:auto;max-height:90%}.SumoSelect>.optWrapper>.options li.opt.disabled{background-color:inherit;pointer-events:none}.SumoSelect>.optWrapper>.options li.opt.disabled *{-moz-opacity:0.5;-khtml-opacity:0.5;opacity:.5}.SumoSelect>.optWrapper.multiple>.options li.opt{padding-left:35px;cursor:pointer}.SumoSelect .select-all>span,.SumoSelect>.optWrapper.multiple>.options li.opt span{position:absolute;display:block;width:30px;top:0;bottom:0;margin-left:-35px}.SumoSelect .select-all>span i,.SumoSelect>.optWrapper.multiple>.options li.opt span i{position:absolute;margin:auto;left:0;right:0;top:0;bottom:0;width:14px;height:14px;border:1px solid #aeaeae;border-radius:2px;box-shadow:inset 0 1px 3px rgba(0,0,0,.15);background-color:#fff}.SumoSelect>.optWrapper>.MultiControls{display:none;border-top:1px solid #ddd;background-color:#fff;box-shadow:0 0 2px rgba(0,0,0,.13);border-radius:0 0 3px 3px}.SumoSelect>.optWrapper.multiple.isFloating>.MultiControls{display:block;margin-top:5px;position:absolute;bottom:0;width:100%}.SumoSelect>.optWrapper.multiple.okCancelInMulti>.MultiControls{display:block}.SumoSelect>.optWrapper.multiple.okCancelInMulti>.MultiControls>p{padding:6px}.SumoSelect>.optWrapper.multiple.okCancelInMulti>.MultiControls>p:focus{box-shadow:0 0 2px #a1c0e4;border-color:#a1c0e4;outline:0;background-color:#a1c0e4}.SumoSelect>.optWrapper.multiple>.MultiControls>p{display:inline-block;cursor:pointer;padding:12px;width:50%;box-sizing:border-box;text-align:center}.SumoSelect>.optWrapper.multiple>.MultiControls>p:hover{background-color:#f1f1f1}.SumoSelect>.optWrapper.multiple>.MultiControls>p.btnOk{border-right:1px solid #dbdbdb;border-radius:0 0 0 3px}.SumoSelect>.optWrapper.multiple>.MultiControls>p.btnCancel{border-radius:0 0 3px 0}.SumoSelect>.optWrapper.isFloating>.options li.opt{padding:12px 6px}.SumoSelect>.optWrapper.multiple.isFloating>.options li.opt{padding-left:35px}.SumoSelect>.optWrapper.multiple.isFloating{padding-bottom:43px}.SumoSelect .select-all.partial>span i,.SumoSelect .select-all.selected>span i,.SumoSelect>.optWrapper.multiple>.options li.opt.selected span i{background-color:#11a911;box-shadow:none;border-color:transparent;background-image:url('');background-repeat:no-repeat;background-position:center center}.SumoSelect.disabled{opacity:.7;cursor:not-allowed}.SumoSelect.disabled>.CaptionCont{border-color:#ccc;box-shadow:none}.SumoSelect .select-all{border-radius:3px 3px 0 0;position:relative;border-bottom:1px solid #ddd;background-color:#fff;padding:8px 0 3px 35px;height:20px;cursor:pointer}.SumoSelect .select-all>label,.SumoSelect .select-all>span i{cursor:pointer}.SumoSelect .select-all.partial>span i{background-color:#ccc}.SumoSelect>.optWrapper>.options li.optGroup{padding-left:5px;text-decoration:underline}
filemanager/UploadHandler.php CHANGED
@@ -540,7 +540,7 @@ class bwg_UploadHandler {
540
  // ini_set('allow_url_fopen',1);
541
  $image_info = @getimagesize(htmlspecialchars_decode($file->url, ENT_COMPAT | ENT_QUOTES));
542
  if ( $file->type == 'svg' ) {
543
- $size = $this->get_svg_size($file->dir . $file->name);
544
  if ( !empty($size) ) {
545
  $file->resolution = $size['width'] . " x " . $size['height'] . " px ";
546
  }
@@ -720,7 +720,7 @@ class bwg_UploadHandler {
720
  $image_info = @getimagesize(htmlspecialchars_decode($file_path, ENT_COMPAT | ENT_QUOTES));
721
 
722
  if ( $type == 'svg' ) {
723
- $size = $this->get_svg_size($file->dir.$file->name);
724
  if( !empty($size) ) {
725
  $file->resolution = $size['width'] . " x " . $size['height'] . " px ";
726
  $file->resolution_thumb = $size['width'] . "x" . $size['height'];
@@ -816,19 +816,6 @@ class bwg_UploadHandler {
816
  return $file;
817
  }
818
 
819
- public function get_svg_size( $image ) {
820
-
821
- $xml = simplexml_load_file($image);
822
- $attr = $xml->attributes();
823
-
824
- $size = array(
825
- 'width' => json_decode($attr->width),
826
- 'height'=> json_decode($attr->height),
827
- );
828
-
829
- return $size;
830
- }
831
-
832
  protected function readfile( $file_path ) {
833
  return readfile($file_path);
834
  }
@@ -1126,7 +1113,7 @@ class bwg_UploadHandler {
1126
  $data['author'] = get_current_user_id();
1127
 
1128
  if ( $data['type'] == 'svg') {
1129
- $size = $this->get_svg_size($info->dir.$data['name']);
1130
  if( !empty($size['width']) && !empty($size['height']) ) {
1131
  $data['resolution'] = $size['width'] . " x " . $size['height'] . " px ";
1132
  $data['resolution_thumb'] = $size['width'] . "x" . $size['height'];
@@ -1134,6 +1121,14 @@ class bwg_UploadHandler {
1134
  $data['resolution'] = WDWLibrary::get('upload_img_width') . " x " . WDWLibrary::get('upload_img_height') . " px ";
1135
  $data['resolution_thumb'] = WDWLibrary::get('upload_thumb_width') . "x" . WDWLibrary::get('upload_thumb_height');
1136
  }
 
 
 
 
 
 
 
 
1137
  } else {
1138
  $data['resolution'] = isset($info->resolution) ? $info->resolution : '';
1139
  $resolution_thumb = WDWLibrary::get_thumb_size("/" . $data['thumb']);
540
  // ini_set('allow_url_fopen',1);
541
  $image_info = @getimagesize(htmlspecialchars_decode($file->url, ENT_COMPAT | ENT_QUOTES));
542
  if ( $file->type == 'svg' ) {
543
+ $size = WDWLibrary::get_svg_size($file->url);
544
  if ( !empty($size) ) {
545
  $file->resolution = $size['width'] . " x " . $size['height'] . " px ";
546
  }
720
  $image_info = @getimagesize(htmlspecialchars_decode($file_path, ENT_COMPAT | ENT_QUOTES));
721
 
722
  if ( $type == 'svg' ) {
723
+ $size = WDWLibrary::get_svg_size($file->dir.$file->name);
724
  if( !empty($size) ) {
725
  $file->resolution = $size['width'] . " x " . $size['height'] . " px ";
726
  $file->resolution_thumb = $size['width'] . "x" . $size['height'];
816
  return $file;
817
  }
818
 
 
 
 
 
 
 
 
 
 
 
 
 
 
819
  protected function readfile( $file_path ) {
820
  return readfile($file_path);
821
  }
1113
  $data['author'] = get_current_user_id();
1114
 
1115
  if ( $data['type'] == 'svg') {
1116
+ $size = WDWLibrary::get_svg_size($info->dir.$data['name']);
1117
  if( !empty($size['width']) && !empty($size['height']) ) {
1118
  $data['resolution'] = $size['width'] . " x " . $size['height'] . " px ";
1119
  $data['resolution_thumb'] = $size['width'] . "x" . $size['height'];
1121
  $data['resolution'] = WDWLibrary::get('upload_img_width') . " x " . WDWLibrary::get('upload_img_height') . " px ";
1122
  $data['resolution_thumb'] = WDWLibrary::get('upload_thumb_width') . "x" . WDWLibrary::get('upload_thumb_height');
1123
  }
1124
+ $data['credit'] = '';
1125
+ $data['aperture'] = '';
1126
+ $data['camera'] = '';
1127
+ $data['caption'] = '';
1128
+ $data['iso'] = '';
1129
+ $data['orientation'] = '';
1130
+ $data['copyright'] = '';
1131
+ $data['tags'] = '';
1132
  } else {
1133
  $data['resolution'] = isset($info->resolution) ? $info->resolution : '';
1134
  $resolution_thumb = WDWLibrary::get_thumb_size("/" . $data['thumb']);
filemanager/js/default.js CHANGED
@@ -556,6 +556,9 @@ function onFileDrop(event, obj) {
556
  }
557
 
558
  function onBtnOpenClick(event, obj) {
 
 
 
559
  if (jQuery('.explorer_item[name="' + filesSelected[0] + '"]').attr("isDir") == true) {
560
  filesSelected.length = 1;
561
  submit("", null, null, null, dir + DS + filesSelected[0], null, null, null, null, null, null);
556
  }
557
 
558
  function onBtnOpenClick(event, obj) {
559
+ jQuery('#add_selectid_img').css('pointer-events', 'none');
560
+ jQuery('#cancel_add_img').css('pointer-events', 'none');
561
+ jQuery('#select_all_images').css('pointer-events', 'none');
562
  if (jQuery('.explorer_item[name="' + filesSelected[0] + '"]').attr("isDir") == true) {
563
  filesSelected.length = 1;
564
  submit("", null, null, null, dir + DS + filesSelected[0], null, null, null, null, null, null);
filemanager/js/jq_uploader/jquery.fileupload.js CHANGED
@@ -12,7 +12,7 @@
12
  /* global define, require */
13
  /* eslint-disable new-cap */
14
 
15
- (function(factory) {
16
  'use strict';
17
  if (typeof define === 'function' && define.amd) {
18
  // Register as an anonymous AMD module:
@@ -24,7 +24,7 @@
24
  // Browser globals:
25
  factory(window.jQuery);
26
  }
27
- })(function($) {
28
  'use strict';
29
 
30
  // Detect file input support, based on
@@ -64,7 +64,7 @@
64
  */
65
  function getDragHandler(type) {
66
  var isDragOver = type === 'dragover';
67
- return function(e) {
68
  e.dataTransfer = e.originalEvent && e.originalEvent.dataTransfer;
69
  var dataTransfer = e.dataTransfer;
70
  if (
@@ -185,11 +185,11 @@
185
 
186
  // Translation function, gets the message key to be translated
187
  // and an object with context specific data as arguments:
188
- i18n: function(message, context) {
189
  // eslint-disable-next-line no-param-reassign
190
  message = this.messages[message] || message.toString();
191
  if (context) {
192
- $.each(context, function(key, value) {
193
  // eslint-disable-next-line no-param-reassign
194
  message = message.replace('{' + key + '}', value);
195
  });
@@ -202,7 +202,7 @@
202
  // value properties, a function returning such an array, a FormData
203
  // object (for XHR file uploads), or a simple object.
204
  // The form of the first fileInput is given as parameter to the function:
205
- formData: function(form) {
206
  return form.serializeArray();
207
  },
208
 
@@ -217,12 +217,12 @@
217
  // and allows you to override plugin options as well as define ajax settings.
218
  //
219
  // Listeners for this callback can also be bound the following way:
220
- // .bind('fileuploadadd', func);
221
  //
222
  // data.submit() returns a Promise object and allows to attach additional
223
  // handlers using jQuery's Deferred callbacks:
224
  // data.submit().done(func).fail(func).always(func);
225
- add: function(e, data) {
226
  if (e.isDefaultPrevented()) {
227
  return false;
228
  }
@@ -231,7 +231,7 @@
231
  (data.autoUpload !== false &&
232
  $(this).fileupload('option', 'autoUpload'))
233
  ) {
234
- data.process().done(function() {
235
  data.submit();
236
  });
237
  }
@@ -240,58 +240,58 @@
240
  // Other callbacks:
241
 
242
  // Callback for the submit event of each file upload:
243
- // submit: function (e, data) {}, // .bind('fileuploadsubmit', func);
244
 
245
  // Callback for the start of each file upload request:
246
- // send: function (e, data) {}, // .bind('fileuploadsend', func);
247
 
248
  // Callback for successful uploads:
249
- // done: function (e, data) {}, // .bind('fileuploaddone', func);
250
 
251
  // Callback for failed (abort or error) uploads:
252
- // fail: function (e, data) {}, // .bind('fileuploadfail', func);
253
 
254
  // Callback for completed (success, abort or error) requests:
255
- // always: function (e, data) {}, // .bind('fileuploadalways', func);
256
 
257
  // Callback for upload progress events:
258
- // progress: function (e, data) {}, // .bind('fileuploadprogress', func);
259
 
260
  // Callback for global upload progress events:
261
- // progressall: function (e, data) {}, // .bind('fileuploadprogressall', func);
262
 
263
  // Callback for uploads start, equivalent to the global ajaxStart event:
264
- // start: function (e) {}, // .bind('fileuploadstart', func);
265
 
266
  // Callback for uploads stop, equivalent to the global ajaxStop event:
267
- // stop: function (e) {}, // .bind('fileuploadstop', func);
268
 
269
  // Callback for change events of the fileInput(s):
270
- // change: function (e, data) {}, // .bind('fileuploadchange', func);
271
 
272
  // Callback for paste events to the pasteZone(s):
273
- // paste: function (e, data) {}, // .bind('fileuploadpaste', func);
274
 
275
  // Callback for drop events of the dropZone(s):
276
- // drop: function (e, data) {}, // .bind('fileuploaddrop', func);
277
 
278
  // Callback for dragover events of the dropZone(s):
279
- // dragover: function (e) {}, // .bind('fileuploaddragover', func);
280
 
281
  // Callback before the start of each chunk upload request (before form data initialization):
282
- // chunkbeforesend: function (e, data) {}, // .bind('fileuploadchunkbeforesend', func);
283
 
284
  // Callback for the start of each chunk upload request:
285
- // chunksend: function (e, data) {}, // .bind('fileuploadchunksend', func);
286
 
287
  // Callback for successful chunk uploads:
288
- // chunkdone: function (e, data) {}, // .bind('fileuploadchunkdone', func);
289
 
290
  // Callback for failed (abort or error) chunk uploads:
291
- // chunkfail: function (e, data) {}, // .bind('fileuploadchunkfail', func);
292
 
293
  // Callback for completed (success, abort or error) chunk upload requests:
294
- // chunkalways: function (e, data) {}, // .bind('fileuploadchunkalways', func);
295
 
296
  // The plugin options are used as settings object for the ajax calls.
297
  // The following are jQuery ajax settings required for the file uploads:
@@ -301,6 +301,16 @@
301
  timeout: 0
302
  },
303
 
 
 
 
 
 
 
 
 
 
 
304
  // A list of options that require reinitializing event listeners and/or
305
  // special initialization code:
306
  _specialOptions: [
@@ -313,16 +323,16 @@
313
 
314
  _blobSlice:
315
  $.support.blobSlice &&
316
- function() {
317
  var slice = this.slice || this.webkitSlice || this.mozSlice;
318
  return slice.apply(this, arguments);
319
  },
320
 
321
- _BitrateTimer: function() {
322
  this.timestamp = Date.now ? Date.now() : new Date().getTime();
323
  this.loaded = 0;
324
  this.bitrate = 0;
325
- this.getBitrate = function(now, loaded, interval) {
326
  var timeDiff = now - this.timestamp;
327
  if (!this.bitrate || !interval || timeDiff > interval) {
328
  this.bitrate = (loaded - this.loaded) * (1000 / timeDiff) * 8;
@@ -333,7 +343,7 @@
333
  };
334
  },
335
 
336
- _isXHRUpload: function(options) {
337
  return (
338
  !options.forceIframeTransport &&
339
  ((!options.multipart && $.support.xhrFileUpload) ||
@@ -341,7 +351,7 @@
341
  );
342
  },
343
 
344
- _getFormData: function(options) {
345
  var formData;
346
  if ($.type(options.formData) === 'function') {
347
  return options.formData(options.form);
@@ -351,7 +361,7 @@
351
  }
352
  if ($.type(options.formData) === 'object') {
353
  formData = [];
354
- $.each(options.formData, function(name, value) {
355
  formData.push({ name: name, value: value });
356
  });
357
  return formData;
@@ -359,15 +369,15 @@
359
  return [];
360
  },
361
 
362
- _getTotal: function(files) {
363
  var total = 0;
364
- $.each(files, function(index, file) {
365
  total += file.size || 1;
366
  });
367
  return total;
368
  },
369
 
370
- _initProgressObject: function(obj) {
371
  var progress = {
372
  loaded: 0,
373
  total: 0,
@@ -380,7 +390,7 @@
380
  }
381
  },
382
 
383
- _initResponseObject: function(obj) {
384
  var prop;
385
  if (obj._response) {
386
  for (prop in obj._response) {
@@ -393,7 +403,7 @@
393
  }
394
  },
395
 
396
- _onProgress: function(e, data) {
397
  if (e.lengthComputable) {
398
  var now = Date.now ? Date.now() : new Date().getTime(),
399
  loaded;
@@ -442,13 +452,13 @@
442
  }
443
  },
444
 
445
- _initProgressListener: function(options) {
446
  var that = this,
447
  xhr = options.xhr ? options.xhr() : $.ajaxSettings.xhr();
448
  // Accesss to the native XHR object is required to add event listeners
449
  // for the upload progress event:
450
  if (xhr.upload) {
451
- $(xhr.upload).bind('progress', function(e) {
452
  var oe = e.originalEvent;
453
  // Make sure the progress event properties get copied over:
454
  e.lengthComputable = oe.lengthComputable;
@@ -456,30 +466,30 @@
456
  e.total = oe.total;
457
  that._onProgress(e, options);
458
  });
459
- options.xhr = function() {
460
  return xhr;
461
  };
462
  }
463
  },
464
 
465
- _deinitProgressListener: function(options) {
466
  var xhr = options.xhr ? options.xhr() : $.ajaxSettings.xhr();
467
  if (xhr.upload) {
468
- $(xhr.upload).unbind('progress');
469
  }
470
  },
471
 
472
- _isInstanceOf: function(type, obj) {
473
  // Cross-frame instanceof check
474
  return Object.prototype.toString.call(obj) === '[object ' + type + ']';
475
  },
476
 
477
- _getUniqueFilename: function(name, map) {
478
  // eslint-disable-next-line no-param-reassign
479
  name = String(name);
480
  if (map[name]) {
481
  // eslint-disable-next-line no-param-reassign
482
- name = name.replace(/(?: \(([\d]+)\))?(\.[^.]+)?$/, function(
483
  _,
484
  p1,
485
  p2
@@ -494,7 +504,7 @@
494
  return name;
495
  },
496
 
497
- _initXHRData: function(options) {
498
  var that = this,
499
  formData,
500
  file = options.files[0],
@@ -530,7 +540,7 @@
530
  value: options.blob
531
  });
532
  } else {
533
- $.each(options.files, function(index, file) {
534
  formData.push({
535
  name:
536
  ($.type(options.paramName) === 'array' &&
@@ -545,7 +555,7 @@
545
  formData = options.formData;
546
  } else {
547
  formData = new FormData();
548
- $.each(this._getFormData(options), function(index, field) {
549
  formData.append(field.name, field.value);
550
  });
551
  }
@@ -556,7 +566,7 @@
556
  file.uploadName || file.name
557
  );
558
  } else {
559
- $.each(options.files, function(index, file) {
560
  // This check allows the tests to run with
561
  // dummy objects:
562
  if (
@@ -587,10 +597,8 @@
587
  options.blob = null;
588
  },
589
 
590
- _initIframeSettings: function(options) {
591
- var targetHost = $('<a></a>')
592
- .prop('href', options.url)
593
- .prop('host');
594
  // Setting the dataType to iframe enables the iframe transport:
595
  options.dataType = 'iframe ' + (options.dataType || '');
596
  // The iframe transport accepts a serialized array as form data:
@@ -604,7 +612,7 @@
604
  }
605
  },
606
 
607
- _initDataSettings: function(options) {
608
  if (this._isXHRUpload(options)) {
609
  if (!this._chunkedUpload(options, true)) {
610
  if (!options.data) {
@@ -622,12 +630,12 @@
622
  }
623
  },
624
 
625
- _getParamName: function(options) {
626
  var fileInput = $(options.fileInput),
627
  paramName = options.paramName;
628
  if (!paramName) {
629
  paramName = [];
630
- fileInput.each(function() {
631
  var input = $(this),
632
  name = input.prop('name') || 'files[]',
633
  i = (input.prop('files') || [1]).length;
@@ -645,7 +653,7 @@
645
  return paramName;
646
  },
647
 
648
- _initFormSettings: function(options) {
649
  // Retrieve missing options from the input field and the
650
  // associated form, if available:
651
  if (!options.form || !options.form.length) {
@@ -679,7 +687,7 @@
679
  }
680
  },
681
 
682
- _getAJAXSettings: function(data) {
683
  var options = $.extend({}, this.options, data);
684
  this._initFormSettings(options);
685
  this._initDataSettings(options);
@@ -688,7 +696,7 @@
688
 
689
  // jQuery 1.6 doesn't provide .state(),
690
  // while jQuery 1.8+ removed .isRejected() and .isResolved():
691
- _getDeferredState: function(deferred) {
692
  if (deferred.state) {
693
  return deferred.state();
694
  }
@@ -703,7 +711,7 @@
703
 
704
  // Maps jqXHR callbacks to the equivalent
705
  // methods of the given Promise object:
706
- _enhancePromise: function(promise) {
707
  promise.success = promise.done;
708
  promise.error = promise.fail;
709
  promise.complete = promise.always;
@@ -712,7 +720,7 @@
712
 
713
  // Creates and returns a Promise object enhanced with
714
  // the jqXHR methods abort, success, error and complete:
715
- _getXHRPromise: function(resolveOrReject, context, args) {
716
  var dfd = $.Deferred(),
717
  promise = dfd.promise();
718
  // eslint-disable-next-line no-param-reassign
@@ -727,31 +735,26 @@
727
  },
728
 
729
  // Adds convenience methods to the data callback argument:
730
- _addConvenienceMethods: function(e, data) {
731
  var that = this,
732
- getPromise = function(args) {
733
- return $.Deferred()
734
- .resolveWith(that, args)
735
- .promise();
736
  };
737
- data.process = function(resolveFunc, rejectFunc) {
738
  if (resolveFunc || rejectFunc) {
739
- data._processQueue = this._processQueue = (
740
- this._processQueue || getPromise([this])
741
- )
742
- .then(function() {
743
  if (data.errorThrown) {
744
- return $.Deferred()
745
- .rejectWith(that, [data])
746
- .promise();
747
  }
748
  return getPromise(arguments);
749
  })
750
- .then(resolveFunc, rejectFunc);
751
  }
752
  return this._processQueue || getPromise([this]);
753
  };
754
- data.submit = function() {
755
  if (this.state() !== 'pending') {
756
  data.jqXHR = this.jqXHR =
757
  that._trigger(
@@ -762,7 +765,7 @@
762
  }
763
  return this.jqXHR || that._getXHRPromise();
764
  };
765
- data.abort = function() {
766
  if (this.jqXHR) {
767
  return this.jqXHR.abort();
768
  }
@@ -770,7 +773,7 @@
770
  that._trigger('fail', null, this);
771
  return that._getXHRPromise(false);
772
  };
773
- data.state = function() {
774
  if (this.jqXHR) {
775
  return that._getDeferredState(this.jqXHR);
776
  }
@@ -778,24 +781,24 @@
778
  return that._getDeferredState(this._processQueue);
779
  }
780
  };
781
- data.processing = function() {
782
  return (
783
  !this.jqXHR &&
784
  this._processQueue &&
785
  that._getDeferredState(this._processQueue) === 'pending'
786
  );
787
  };
788
- data.progress = function() {
789
  return this._progress;
790
  };
791
- data.response = function() {
792
  return this._response;
793
  };
794
  },
795
 
796
  // Parses the Range header from the server response
797
  // and returns the uploaded bytes:
798
- _getUploadedBytes: function(jqXHR) {
799
  var range = jqXHR.getResponseHeader('Range'),
800
  parts = range && range.split('-'),
801
  upperBytesPos = parts && parts.length > 1 && parseInt(parts[1], 10);
@@ -807,7 +810,7 @@
807
  // If the second parameter is true, only tests if the file
808
  // should be uploaded in chunks, but does not invoke any
809
  // upload requests:
810
- _chunkedUpload: function(options, testOnly) {
811
  options.uploadedBytes = options.uploadedBytes || 0;
812
  var that = this,
813
  file = options.files[0],
@@ -841,7 +844,7 @@
841
  ]);
842
  }
843
  // The chunk upload method:
844
- upload = function() {
845
  // Clone the options object for each chunk upload:
846
  var o = $.extend({}, options),
847
  currentLoaded = o._progress.loaded;
@@ -867,7 +870,7 @@
867
  (that._trigger('chunksend', null, o) !== false && $.ajax(o)) ||
868
  that._getXHRPromise(false, o.context)
869
  )
870
- .done(function(result, textStatus, jqXHR) {
871
  ub = that._getUploadedBytes(jqXHR) || ub + o.chunkSize;
872
  // Create a progress event if no final progress event
873
  // with loaded equaling total has been triggered
@@ -896,7 +899,7 @@
896
  dfd.resolveWith(o.context, [result, textStatus, jqXHR]);
897
  }
898
  })
899
- .fail(function(jqXHR, textStatus, errorThrown) {
900
  o.jqXHR = jqXHR;
901
  o.textStatus = textStatus;
902
  o.errorThrown = errorThrown;
@@ -904,19 +907,19 @@
904
  that._trigger('chunkalways', null, o);
905
  dfd.rejectWith(o.context, [jqXHR, textStatus, errorThrown]);
906
  })
907
- .always(function() {
908
  that._deinitProgressListener(o);
909
  });
910
  };
911
  this._enhancePromise(promise);
912
- promise.abort = function() {
913
  return jqXHR.abort();
914
  };
915
  upload();
916
  return promise;
917
  },
918
 
919
- _beforeSend: function(e, data) {
920
  if (this._active === 0) {
921
  // the start callback is triggered when an upload starts
922
  // and no other uploads are currently running,
@@ -942,7 +945,7 @@
942
  this._progress.total += data.total;
943
  },
944
 
945
- _onDone: function(result, textStatus, jqXHR, options) {
946
  var total = options._progress.total,
947
  response = options._response;
948
  if (options._progress.loaded < total) {
@@ -963,7 +966,7 @@
963
  this._trigger('done', null, options);
964
  },
965
 
966
- _onFail: function(jqXHR, textStatus, errorThrown, options) {
967
  var response = options._response;
968
  if (options.recalculateProgress) {
969
  // Remove the failed (error or abort) file upload from
@@ -977,13 +980,13 @@
977
  this._trigger('fail', null, options);
978
  },
979
 
980
- _onAlways: function(jqXHRorResult, textStatus, jqXHRorError, options) {
981
  // jqXHRorResult, textStatus and jqXHRorError are added to the
982
  // options object via done and fail callbacks
983
  this._trigger('always', null, options);
984
  },
985
 
986
- _onSend: function(e, data) {
987
  if (!data.submit) {
988
  this._addConvenienceMethods(e, data);
989
  }
@@ -993,7 +996,7 @@
993
  slot,
994
  pipe,
995
  options = that._getAJAXSettings(data),
996
- send = function() {
997
  that._sending += 1;
998
  // Set timer for bitrate progress calculation:
999
  options._bitrateTimer = new that._BitrateTimer();
@@ -1010,13 +1013,13 @@
1010
  that._chunkedUpload(options) ||
1011
  $.ajax(options)
1012
  )
1013
- .done(function(result, textStatus, jqXHR) {
1014
  that._onDone(result, textStatus, jqXHR, options);
1015
  })
1016
- .fail(function(jqXHR, textStatus, errorThrown) {
1017
  that._onFail(jqXHR, textStatus, errorThrown, options);
1018
  })
1019
- .always(function(jqXHRorResult, textStatus, jqXHRorError) {
1020
  that._deinitProgressListener(options);
1021
  that._onAlways(
1022
  jqXHRorResult,
@@ -1058,15 +1061,15 @@
1058
  if (this.options.limitConcurrentUploads > 1) {
1059
  slot = $.Deferred();
1060
  this._slots.push(slot);
1061
- pipe = slot.then(send);
1062
  } else {
1063
- this._sequence = this._sequence.then(send, send);
1064
  pipe = this._sequence;
1065
  }
1066
  // Return the piped Promise object, enhanced with an abort method,
1067
  // which is delegated to the jqXHR object of the current upload,
1068
  // and jqXHR callbacks mapped to the equivalent Promise methods:
1069
- pipe.abort = function() {
1070
  aborted = [undefined, 'abort', 'abort'];
1071
  if (!jqXHR) {
1072
  if (slot) {
@@ -1081,7 +1084,7 @@
1081
  return send();
1082
  },
1083
 
1084
- _onAdd: function(e, data) {
1085
  var that = this,
1086
  result = true,
1087
  options = $.extend({}, this.options, data),
@@ -1144,7 +1147,7 @@
1144
  paramNameSet = paramName;
1145
  }
1146
  data.originalFiles = files;
1147
- $.each(fileSet || files, function(index, element) {
1148
  var newData = $.extend({}, data);
1149
  newData.files = fileSet ? element : [element];
1150
  newData.paramName = paramNameSet[index];
@@ -1161,29 +1164,27 @@
1161
  return result;
1162
  },
1163
 
1164
- _replaceFileInput: function(data) {
1165
  var input = data.fileInput,
1166
  inputClone = input.clone(true),
1167
  restoreFocus = input.is(document.activeElement);
1168
  // Add a reference for the new cloned file input to the data argument:
1169
  data.fileInputClone = inputClone;
1170
- $('<form></form>')
1171
- .append(inputClone)[0]
1172
- .reset();
1173
  // Detaching allows to insert the fileInput on another form
1174
  // without loosing the file input value:
1175
  input.after(inputClone).detach();
1176
  // If the fileInput had focus before it was detached,
1177
  // restore focus to the inputClone.
1178
  if (restoreFocus) {
1179
- inputClone.focus();
1180
  }
1181
  // Avoid memory leaks with the detached file input:
1182
- $.cleanData(input.unbind('remove'));
1183
  // Replace the original file input element in the fileInput
1184
  // elements set with the clone, which has been copied including
1185
  // event handlers:
1186
- this.options.fileInput = this.options.fileInput.map(function(i, el) {
1187
  if (el === input[0]) {
1188
  return inputClone[0];
1189
  }
@@ -1196,12 +1197,12 @@
1196
  }
1197
  },
1198
 
1199
- _handleFileTreeEntry: function(entry, path) {
1200
  var that = this,
1201
  dfd = $.Deferred(),
1202
  entries = [],
1203
  dirReader,
1204
- errorHandler = function(e) {
1205
  if (e && !e.entry) {
1206
  e.entry = entry;
1207
  }
@@ -1211,16 +1212,16 @@
1211
  // to be returned together in one set:
1212
  dfd.resolve([e]);
1213
  },
1214
- successHandler = function(entries) {
1215
  that
1216
  ._handleFileTreeEntries(entries, path + entry.name + '/')
1217
- .done(function(files) {
1218
  dfd.resolve(files);
1219
  })
1220
  .fail(errorHandler);
1221
  },
1222
- readEntries = function() {
1223
- dirReader.readEntries(function(results) {
1224
  if (!results.length) {
1225
  successHandler(entries);
1226
  } else {
@@ -1237,7 +1238,7 @@
1237
  entry._file.relativePath = path;
1238
  dfd.resolve(entry._file);
1239
  } else {
1240
- entry.file(function(file) {
1241
  file.relativePath = path;
1242
  dfd.resolve(file);
1243
  }, errorHandler);
@@ -1253,21 +1254,21 @@
1253
  return dfd.promise();
1254
  },
1255
 
1256
- _handleFileTreeEntries: function(entries, path) {
1257
  var that = this;
1258
  return $.when
1259
  .apply(
1260
  $,
1261
- $.map(entries, function(entry) {
1262
  return that._handleFileTreeEntry(entry, path);
1263
  })
1264
  )
1265
- .then(function() {
1266
  return Array.prototype.concat.apply([], arguments);
1267
  });
1268
  },
1269
 
1270
- _getDroppedFiles: function(dataTransfer) {
1271
  // eslint-disable-next-line no-param-reassign
1272
  dataTransfer = dataTransfer || {};
1273
  var items = dataTransfer.items;
@@ -1277,7 +1278,7 @@
1277
  (items[0].webkitGetAsEntry || items[0].getAsEntry)
1278
  ) {
1279
  return this._handleFileTreeEntries(
1280
- $.map(items, function(item) {
1281
  var entry;
1282
  if (item.webkitGetAsEntry) {
1283
  entry = item.webkitGetAsEntry();
@@ -1291,12 +1292,10 @@
1291
  })
1292
  );
1293
  }
1294
- return $.Deferred()
1295
- .resolve($.makeArray(dataTransfer.files))
1296
- .promise();
1297
  },
1298
 
1299
- _getSingleFileInputFiles: function(fileInput) {
1300
  // eslint-disable-next-line no-param-reassign
1301
  fileInput = $(fileInput);
1302
  var entries =
@@ -1310,9 +1309,7 @@
1310
  if (!files.length) {
1311
  value = fileInput.prop('value');
1312
  if (!value) {
1313
- return $.Deferred()
1314
- .resolve([])
1315
- .promise();
1316
  }
1317
  // If the files property is not available, the browser does not
1318
  // support the File API and we add a pseudo File object with
@@ -1320,34 +1317,32 @@
1320
  files = [{ name: value.replace(/^.*\\/, '') }];
1321
  } else if (files[0].name === undefined && files[0].fileName) {
1322
  // File normalization for Safari 4 and Firefox 3:
1323
- $.each(files, function(index, file) {
1324
  file.name = file.fileName;
1325
  file.size = file.fileSize;
1326
  });
1327
  }
1328
- return $.Deferred()
1329
- .resolve(files)
1330
- .promise();
1331
  },
1332
 
1333
- _getFileInputFiles: function(fileInput) {
1334
  if (!(fileInput instanceof $) || fileInput.length === 1) {
1335
  return this._getSingleFileInputFiles(fileInput);
1336
  }
1337
  return $.when
1338
  .apply($, $.map(fileInput, this._getSingleFileInputFiles))
1339
- .then(function() {
1340
  return Array.prototype.concat.apply([], arguments);
1341
  });
1342
  },
1343
 
1344
- _onChange: function(e) {
1345
  var that = this,
1346
  data = {
1347
  fileInput: $(e.target),
1348
  form: $(e.target.form)
1349
  };
1350
- this._getFileInputFiles(data.fileInput).always(function(files) {
1351
  data.files = files;
1352
  if (that.options.replaceFileInput) {
1353
  that._replaceFileInput(data);
@@ -1364,14 +1359,14 @@
1364
  });
1365
  },
1366
 
1367
- _onPaste: function(e) {
1368
  var items =
1369
  e.originalEvent &&
1370
  e.originalEvent.clipboardData &&
1371
  e.originalEvent.clipboardData.items,
1372
  data = { files: [] };
1373
  if (items && items.length) {
1374
- $.each(items, function(index, item) {
1375
  var file = item.getAsFile && item.getAsFile();
1376
  if (file) {
1377
  data.files.push(file);
@@ -1389,14 +1384,14 @@
1389
  }
1390
  },
1391
 
1392
- _onDrop: function(e) {
1393
  e.dataTransfer = e.originalEvent && e.originalEvent.dataTransfer;
1394
  var that = this,
1395
  dataTransfer = e.dataTransfer,
1396
  data = {};
1397
  if (dataTransfer && dataTransfer.files && dataTransfer.files.length) {
1398
  e.preventDefault();
1399
- this._getDroppedFiles(dataTransfer).always(function(files) {
1400
  data.files = files;
1401
  if (
1402
  that._trigger(
@@ -1417,7 +1412,7 @@
1417
 
1418
  _onDragLeave: getDragHandler('dragleave'),
1419
 
1420
- _initEventHandlers: function() {
1421
  if (this._isXHRUpload(this.options)) {
1422
  this._on(this.options.dropZone, {
1423
  dragover: this._onDragOver,
@@ -1438,17 +1433,17 @@
1438
  }
1439
  },
1440
 
1441
- _destroyEventHandlers: function() {
1442
  this._off(this.options.dropZone, 'dragenter dragleave dragover drop');
1443
  this._off(this.options.pasteZone, 'paste');
1444
  this._off(this.options.fileInput, 'change');
1445
  },
1446
 
1447
- _destroy: function() {
1448
  this._destroyEventHandlers();
1449
  },
1450
 
1451
- _setOption: function(key, value) {
1452
  var reinit = $.inArray(key, this._specialOptions) !== -1;
1453
  if (reinit) {
1454
  this._destroyEventHandlers();
@@ -1460,7 +1455,7 @@
1460
  }
1461
  },
1462
 
1463
- _initSpecialOptions: function() {
1464
  var options = this.options;
1465
  if (options.fileInput === undefined) {
1466
  options.fileInput = this.element.is('input[type="file"]')
@@ -1477,14 +1472,14 @@
1477
  }
1478
  },
1479
 
1480
- _getRegExp: function(str) {
1481
  var parts = str.split('/'),
1482
  modifiers = parts.pop();
1483
  parts.shift();
1484
  return new RegExp(parts.join('/'), modifiers);
1485
  },
1486
 
1487
- _isRegExpOption: function(key, value) {
1488
  return (
1489
  key !== 'url' &&
1490
  $.type(value) === 'string' &&
@@ -1492,17 +1487,17 @@
1492
  );
1493
  },
1494
 
1495
- _initDataAttributes: function() {
1496
  var that = this,
1497
  options = this.options,
1498
  data = this.element.data();
1499
  // Initialize options set via HTML5 data-attributes:
1500
- $.each(this.element[0].attributes, function(index, attr) {
1501
  var key = attr.name.toLowerCase(),
1502
  value;
1503
  if (/^data-/.test(key)) {
1504
  // Convert hyphen-ated key to camelCase:
1505
- key = key.slice(5).replace(/-[a-z]/g, function(str) {
1506
  return str.charAt(1).toUpperCase();
1507
  });
1508
  value = data[key];
@@ -1514,7 +1509,7 @@
1514
  });
1515
  },
1516
 
1517
- _create: function() {
1518
  this._initDataAttributes();
1519
  this._initSpecialOptions();
1520
  this._slots = [];
@@ -1526,7 +1521,7 @@
1526
 
1527
  // This method is exposed to the widget API and allows to query
1528
  // the number of active uploads:
1529
- active: function() {
1530
  return this._active;
1531
  },
1532
 
@@ -1534,7 +1529,7 @@
1534
  // the widget upload progress.
1535
  // It returns an object with loaded, total and bitrate properties
1536
  // for the running uploads:
1537
- progress: function() {
1538
  return this._progress;
1539
  },
1540
 
@@ -1542,13 +1537,13 @@
1542
  // using the fileupload API. The data parameter accepts an object which
1543
  // must have a files property and can contain additional options:
1544
  // .fileupload('add', {files: filesList});
1545
- add: function(data) {
1546
  var that = this;
1547
  if (!data || this.options.disabled) {
1548
  return;
1549
  }
1550
  if (data.fileInput && !data.files) {
1551
- this._getFileInputFiles(data.fileInput).always(function(files) {
1552
  data.files = files;
1553
  that._onAdd(null, data);
1554
  });
@@ -1563,7 +1558,7 @@
1563
  // must have a files or fileInput property and can contain additional options:
1564
  // .fileupload('send', {files: filesList});
1565
  // The method returns a Promise object for the file upload call.
1566
- send: function(data) {
1567
  if (data && !this.options.disabled) {
1568
  if (data.fileInput && !data.files) {
1569
  var that = this,
@@ -1571,7 +1566,7 @@
1571
  promise = dfd.promise(),
1572
  jqXHR,
1573
  aborted;
1574
- promise.abort = function() {
1575
  aborted = true;
1576
  if (jqXHR) {
1577
  return jqXHR.abort();
@@ -1579,7 +1574,7 @@
1579
  dfd.reject(null, 'abort', 'abort');
1580
  return promise;
1581
  };
1582
- this._getFileInputFiles(data.fileInput).always(function(files) {
1583
  if (aborted) {
1584
  return;
1585
  }
@@ -1590,10 +1585,10 @@
1590
  data.files = files;
1591
  jqXHR = that._onSend(null, data);
1592
  jqXHR.then(
1593
- function(result, textStatus, jqXHR) {
1594
  dfd.resolve(result, textStatus, jqXHR);
1595
  },
1596
- function(jqXHR, textStatus, errorThrown) {
1597
  dfd.reject(jqXHR, textStatus, errorThrown);
1598
  }
1599
  );
12
  /* global define, require */
13
  /* eslint-disable new-cap */
14
 
15
+ (function (factory) {
16
  'use strict';
17
  if (typeof define === 'function' && define.amd) {
18
  // Register as an anonymous AMD module:
24
  // Browser globals:
25
  factory(window.jQuery);
26
  }
27
+ })(function ($) {
28
  'use strict';
29
 
30
  // Detect file input support, based on
64
  */
65
  function getDragHandler(type) {
66
  var isDragOver = type === 'dragover';
67
+ return function (e) {
68
  e.dataTransfer = e.originalEvent && e.originalEvent.dataTransfer;
69
  var dataTransfer = e.dataTransfer;
70
  if (
185
 
186
  // Translation function, gets the message key to be translated
187
  // and an object with context specific data as arguments:
188
+ i18n: function (message, context) {
189
  // eslint-disable-next-line no-param-reassign
190
  message = this.messages[message] || message.toString();
191
  if (context) {
192
+ $.each(context, function (key, value) {
193
  // eslint-disable-next-line no-param-reassign
194
  message = message.replace('{' + key + '}', value);
195
  });
202
  // value properties, a function returning such an array, a FormData
203
  // object (for XHR file uploads), or a simple object.
204
  // The form of the first fileInput is given as parameter to the function:
205
+ formData: function (form) {
206
  return form.serializeArray();
207
  },
208
 
217
  // and allows you to override plugin options as well as define ajax settings.
218
  //
219
  // Listeners for this callback can also be bound the following way:
220
+ // .on('fileuploadadd', func);
221
  //
222
  // data.submit() returns a Promise object and allows to attach additional
223
  // handlers using jQuery's Deferred callbacks:
224
  // data.submit().done(func).fail(func).always(func);
225
+ add: function (e, data) {
226
  if (e.isDefaultPrevented()) {
227
  return false;
228
  }
231
  (data.autoUpload !== false &&
232
  $(this).fileupload('option', 'autoUpload'))
233
  ) {
234
+ data.process().done(function () {
235
  data.submit();
236
  });
237
  }
240
  // Other callbacks:
241
 
242
  // Callback for the submit event of each file upload:
243
+ // submit: function (e, data) {}, // .on('fileuploadsubmit', func);
244
 
245
  // Callback for the start of each file upload request:
246
+ // send: function (e, data) {}, // .on('fileuploadsend', func);
247
 
248
  // Callback for successful uploads:
249
+ // done: function (e, data) {}, // .on('fileuploaddone', func);
250
 
251
  // Callback for failed (abort or error) uploads:
252
+ // fail: function (e, data) {}, // .on('fileuploadfail', func);
253
 
254
  // Callback for completed (success, abort or error) requests:
255
+ // always: function (e, data) {}, // .on('fileuploadalways', func);
256
 
257
  // Callback for upload progress events:
258
+ // progress: function (e, data) {}, // .on('fileuploadprogress', func);
259
 
260
  // Callback for global upload progress events:
261
+ // progressall: function (e, data) {}, // .on('fileuploadprogressall', func);
262
 
263
  // Callback for uploads start, equivalent to the global ajaxStart event:
264
+ // start: function (e) {}, // .on('fileuploadstart', func);
265
 
266
  // Callback for uploads stop, equivalent to the global ajaxStop event:
267
+ // stop: function (e) {}, // .on('fileuploadstop', func);
268
 
269
  // Callback for change events of the fileInput(s):
270
+ // change: function (e, data) {}, // .on('fileuploadchange', func);
271
 
272
  // Callback for paste events to the pasteZone(s):
273
+ // paste: function (e, data) {}, // .on('fileuploadpaste', func);
274
 
275
  // Callback for drop events of the dropZone(s):
276
+ // drop: function (e, data) {}, // .on('fileuploaddrop', func);
277
 
278
  // Callback for dragover events of the dropZone(s):
279
+ // dragover: function (e) {}, // .on('fileuploaddragover', func);
280
 
281
  // Callback before the start of each chunk upload request (before form data initialization):
282
+ // chunkbeforesend: function (e, data) {}, // .on('fileuploadchunkbeforesend', func);
283
 
284
  // Callback for the start of each chunk upload request:
285
+ // chunksend: function (e, data) {}, // .on('fileuploadchunksend', func);
286
 
287
  // Callback for successful chunk uploads:
288
+ // chunkdone: function (e, data) {}, // .on('fileuploadchunkdone', func);
289
 
290
  // Callback for failed (abort or error) chunk uploads:
291
+ // chunkfail: function (e, data) {}, // .on('fileuploadchunkfail', func);
292
 
293
  // Callback for completed (success, abort or error) chunk upload requests:
294
+ // chunkalways: function (e, data) {}, // .on('fileuploadchunkalways', func);
295
 
296
  // The plugin options are used as settings object for the ajax calls.
297
  // The following are jQuery ajax settings required for the file uploads:
301
  timeout: 0
302
  },
303
 
304
+ // jQuery versions before 1.8 require promise.pipe if the return value is
305
+ // used, as promise.then in older versions has a different behavior, see:
306
+ // https://blog.jquery.com/2012/08/09/jquery-1-8-released/
307
+ // https://bugs.jquery.com/ticket/11010
308
+ // https://github.com/blueimp/jQuery-File-Upload/pull/3435
309
+ _promisePipe: (function () {
310
+ var parts = $.fn.jquery.split('.');
311
+ return Number(parts[0]) > 1 || Number(parts[1]) > 7 ? 'then' : 'pipe';
312
+ })(),
313
+
314
  // A list of options that require reinitializing event listeners and/or
315
  // special initialization code:
316
  _specialOptions: [
323
 
324
  _blobSlice:
325
  $.support.blobSlice &&
326
+ function () {
327
  var slice = this.slice || this.webkitSlice || this.mozSlice;
328
  return slice.apply(this, arguments);
329
  },
330
 
331
+ _BitrateTimer: function () {
332
  this.timestamp = Date.now ? Date.now() : new Date().getTime();
333
  this.loaded = 0;
334
  this.bitrate = 0;
335
+ this.getBitrate = function (now, loaded, interval) {
336
  var timeDiff = now - this.timestamp;
337
  if (!this.bitrate || !interval || timeDiff > interval) {
338
  this.bitrate = (loaded - this.loaded) * (1000 / timeDiff) * 8;
343
  };
344
  },
345
 
346
+ _isXHRUpload: function (options) {
347
  return (
348
  !options.forceIframeTransport &&
349
  ((!options.multipart && $.support.xhrFileUpload) ||
351
  );
352
  },
353
 
354
+ _getFormData: function (options) {
355
  var formData;
356
  if ($.type(options.formData) === 'function') {
357
  return options.formData(options.form);
361
  }
362
  if ($.type(options.formData) === 'object') {
363
  formData = [];
364
+ $.each(options.formData, function (name, value) {
365
  formData.push({ name: name, value: value });
366
  });
367
  return formData;
369
  return [];
370
  },
371
 
372
+ _getTotal: function (files) {
373
  var total = 0;
374
+ $.each(files, function (index, file) {
375
  total += file.size || 1;
376
  });
377
  return total;
378
  },
379
 
380
+ _initProgressObject: function (obj) {
381
  var progress = {
382
  loaded: 0,
383
  total: 0,
390
  }
391
  },
392
 
393
+ _initResponseObject: function (obj) {
394
  var prop;
395
  if (obj._response) {
396
  for (prop in obj._response) {
403
  }
404
  },
405
 
406
+ _onProgress: function (e, data) {
407
  if (e.lengthComputable) {
408
  var now = Date.now ? Date.now() : new Date().getTime(),
409
  loaded;
452
  }
453
  },
454
 
455
+ _initProgressListener: function (options) {
456
  var that = this,
457
  xhr = options.xhr ? options.xhr() : $.ajaxSettings.xhr();
458
  // Accesss to the native XHR object is required to add event listeners
459
  // for the upload progress event:
460
  if (xhr.upload) {
461
+ $(xhr.upload).on('progress', function (e) {
462
  var oe = e.originalEvent;
463
  // Make sure the progress event properties get copied over:
464
  e.lengthComputable = oe.lengthComputable;
466
  e.total = oe.total;
467
  that._onProgress(e, options);
468
  });
469
+ options.xhr = function () {
470
  return xhr;
471
  };
472
  }
473
  },
474
 
475
+ _deinitProgressListener: function (options) {
476
  var xhr = options.xhr ? options.xhr() : $.ajaxSettings.xhr();
477
  if (xhr.upload) {
478
+ $(xhr.upload).off('progress');
479
  }
480
  },
481
 
482
+ _isInstanceOf: function (type, obj) {
483
  // Cross-frame instanceof check
484
  return Object.prototype.toString.call(obj) === '[object ' + type + ']';
485
  },
486
 
487
+ _getUniqueFilename: function (name, map) {
488
  // eslint-disable-next-line no-param-reassign
489
  name = String(name);
490
  if (map[name]) {
491
  // eslint-disable-next-line no-param-reassign
492
+ name = name.replace(/(?: \(([\d]+)\))?(\.[^.]+)?$/, function (
493
  _,
494
  p1,
495
  p2
504
  return name;
505
  },
506
 
507
+ _initXHRData: function (options) {
508
  var that = this,
509
  formData,
510
  file = options.files[0],
540
  value: options.blob
541
  });
542
  } else {
543
+ $.each(options.files, function (index, file) {
544
  formData.push({
545
  name:
546
  ($.type(options.paramName) === 'array' &&
555
  formData = options.formData;
556
  } else {
557
  formData = new FormData();
558
+ $.each(this._getFormData(options), function (index, field) {
559
  formData.append(field.name, field.value);
560
  });
561
  }
566
  file.uploadName || file.name
567
  );
568
  } else {
569
+ $.each(options.files, function (index, file) {
570
  // This check allows the tests to run with
571
  // dummy objects:
572
  if (
597
  options.blob = null;
598
  },
599
 
600
+ _initIframeSettings: function (options) {
601
+ var targetHost = $('<a></a>').prop('href', options.url).prop('host');
 
 
602
  // Setting the dataType to iframe enables the iframe transport:
603
  options.dataType = 'iframe ' + (options.dataType || '');
604
  // The iframe transport accepts a serialized array as form data:
612
  }
613
  },
614
 
615
+ _initDataSettings: function (options) {
616
  if (this._isXHRUpload(options)) {
617
  if (!this._chunkedUpload(options, true)) {
618
  if (!options.data) {
630
  }
631
  },
632
 
633
+ _getParamName: function (options) {
634
  var fileInput = $(options.fileInput),
635
  paramName = options.paramName;
636
  if (!paramName) {
637
  paramName = [];
638
+ fileInput.each(function () {
639
  var input = $(this),
640
  name = input.prop('name') || 'files[]',
641
  i = (input.prop('files') || [1]).length;
653
  return paramName;
654
  },
655
 
656
+ _initFormSettings: function (options) {
657
  // Retrieve missing options from the input field and the
658
  // associated form, if available:
659
  if (!options.form || !options.form.length) {
687
  }
688
  },
689
 
690
+ _getAJAXSettings: function (data) {
691
  var options = $.extend({}, this.options, data);
692
  this._initFormSettings(options);
693
  this._initDataSettings(options);
696
 
697
  // jQuery 1.6 doesn't provide .state(),
698
  // while jQuery 1.8+ removed .isRejected() and .isResolved():
699
+ _getDeferredState: function (deferred) {
700
  if (deferred.state) {
701
  return deferred.state();
702
  }
711
 
712
  // Maps jqXHR callbacks to the equivalent
713
  // methods of the given Promise object:
714
+ _enhancePromise: function (promise) {
715
  promise.success = promise.done;
716
  promise.error = promise.fail;
717
  promise.complete = promise.always;
720
 
721
  // Creates and returns a Promise object enhanced with
722
  // the jqXHR methods abort, success, error and complete:
723
+ _getXHRPromise: function (resolveOrReject, context, args) {
724
  var dfd = $.Deferred(),
725
  promise = dfd.promise();
726
  // eslint-disable-next-line no-param-reassign
735
  },
736
 
737
  // Adds convenience methods to the data callback argument:
738
+ _addConvenienceMethods: function (e, data) {
739
  var that = this,
740
+ getPromise = function (args) {
741
+ return $.Deferred().resolveWith(that, args).promise();
 
 
742
  };
743
+ data.process = function (resolveFunc, rejectFunc) {
744
  if (resolveFunc || rejectFunc) {
745
+ data._processQueue = this._processQueue = (this._processQueue ||
746
+ getPromise([this]))
747
+ [that._promisePipe](function () {
 
748
  if (data.errorThrown) {
749
+ return $.Deferred().rejectWith(that, [data]).promise();
 
 
750
  }
751
  return getPromise(arguments);
752
  })
753
+ [that._promisePipe](resolveFunc, rejectFunc);
754
  }
755
  return this._processQueue || getPromise([this]);
756
  };
757
+ data.submit = function () {
758
  if (this.state() !== 'pending') {
759
  data.jqXHR = this.jqXHR =
760
  that._trigger(
765
  }
766
  return this.jqXHR || that._getXHRPromise();
767
  };
768
+ data.abort = function () {
769
  if (this.jqXHR) {
770
  return this.jqXHR.abort();
771
  }
773
  that._trigger('fail', null, this);
774
  return that._getXHRPromise(false);
775
  };
776
+ data.state = function () {
777
  if (this.jqXHR) {
778
  return that._getDeferredState(this.jqXHR);
779
  }
781
  return that._getDeferredState(this._processQueue);
782
  }
783
  };
784
+ data.processing = function () {
785
  return (
786
  !this.jqXHR &&
787
  this._processQueue &&
788
  that._getDeferredState(this._processQueue) === 'pending'
789
  );
790
  };
791
+ data.progress = function () {
792
  return this._progress;
793
  };
794
+ data.response = function () {
795
  return this._response;
796
  };
797
  },
798
 
799
  // Parses the Range header from the server response
800
  // and returns the uploaded bytes:
801
+ _getUploadedBytes: function (jqXHR) {
802
  var range = jqXHR.getResponseHeader('Range'),
803
  parts = range && range.split('-'),
804
  upperBytesPos = parts && parts.length > 1 && parseInt(parts[1], 10);
810
  // If the second parameter is true, only tests if the file
811
  // should be uploaded in chunks, but does not invoke any
812
  // upload requests:
813
+ _chunkedUpload: function (options, testOnly) {
814
  options.uploadedBytes = options.uploadedBytes || 0;
815
  var that = this,
816
  file = options.files[0],
844
  ]);
845
  }
846
  // The chunk upload method:
847
+ upload = function () {
848
  // Clone the options object for each chunk upload:
849
  var o = $.extend({}, options),
850
  currentLoaded = o._progress.loaded;
870
  (that._trigger('chunksend', null, o) !== false && $.ajax(o)) ||
871
  that._getXHRPromise(false, o.context)
872
  )
873
+ .done(function (result, textStatus, jqXHR) {
874
  ub = that._getUploadedBytes(jqXHR) || ub + o.chunkSize;
875
  // Create a progress event if no final progress event
876
  // with loaded equaling total has been triggered
899
  dfd.resolveWith(o.context, [result, textStatus, jqXHR]);
900
  }
901
  })
902
+ .fail(function (jqXHR, textStatus, errorThrown) {
903
  o.jqXHR = jqXHR;
904
  o.textStatus = textStatus;
905
  o.errorThrown = errorThrown;
907
  that._trigger('chunkalways', null, o);
908
  dfd.rejectWith(o.context, [jqXHR, textStatus, errorThrown]);
909
  })
910
+ .always(function () {
911
  that._deinitProgressListener(o);
912
  });
913
  };
914
  this._enhancePromise(promise);
915
+ promise.abort = function () {
916
  return jqXHR.abort();
917
  };
918
  upload();
919
  return promise;
920
  },
921
 
922
+ _beforeSend: function (e, data) {
923
  if (this._active === 0) {
924
  // the start callback is triggered when an upload starts
925
  // and no other uploads are currently running,
945
  this._progress.total += data.total;
946
  },
947
 
948
+ _onDone: function (result, textStatus, jqXHR, options) {
949
  var total = options._progress.total,
950
  response = options._response;
951
  if (options._progress.loaded < total) {
966
  this._trigger('done', null, options);
967
  },
968
 
969
+ _onFail: function (jqXHR, textStatus, errorThrown, options) {
970
  var response = options._response;
971
  if (options.recalculateProgress) {
972
  // Remove the failed (error or abort) file upload from
980
  this._trigger('fail', null, options);
981
  },
982
 
983
+ _onAlways: function (jqXHRorResult, textStatus, jqXHRorError, options) {
984
  // jqXHRorResult, textStatus and jqXHRorError are added to the
985
  // options object via done and fail callbacks
986
  this._trigger('always', null, options);
987
  },
988
 
989
+ _onSend: function (e, data) {
990
  if (!data.submit) {
991
  this._addConvenienceMethods(e, data);
992
  }
996
  slot,
997
  pipe,
998
  options = that._getAJAXSettings(data),
999
+ send = function () {
1000
  that._sending += 1;
1001
  // Set timer for bitrate progress calculation:
1002
  options._bitrateTimer = new that._BitrateTimer();
1013
  that._chunkedUpload(options) ||
1014
  $.ajax(options)
1015
  )
1016
+ .done(function (result, textStatus, jqXHR) {
1017
  that._onDone(result, textStatus, jqXHR, options);
1018
  })
1019
+ .fail(function (jqXHR, textStatus, errorThrown) {
1020
  that._onFail(jqXHR, textStatus, errorThrown, options);
1021
  })
1022
+ .always(function (jqXHRorResult, textStatus, jqXHRorError) {
1023
  that._deinitProgressListener(options);
1024
  that._onAlways(
1025
  jqXHRorResult,
1061
  if (this.options.limitConcurrentUploads > 1) {
1062
  slot = $.Deferred();
1063
  this._slots.push(slot);
1064
+ pipe = slot[that._promisePipe](send);
1065
  } else {
1066
+ this._sequence = this._sequence[that._promisePipe](send, send);
1067
  pipe = this._sequence;
1068
  }
1069
  // Return the piped Promise object, enhanced with an abort method,
1070
  // which is delegated to the jqXHR object of the current upload,
1071
  // and jqXHR callbacks mapped to the equivalent Promise methods:
1072
+ pipe.abort = function () {
1073
  aborted = [undefined, 'abort', 'abort'];
1074
  if (!jqXHR) {
1075
  if (slot) {
1084
  return send();
1085
  },
1086
 
1087
+ _onAdd: function (e, data) {
1088
  var that = this,
1089
  result = true,
1090
  options = $.extend({}, this.options, data),
1147
  paramNameSet = paramName;
1148
  }
1149
  data.originalFiles = files;
1150
+ $.each(fileSet || files, function (index, element) {
1151
  var newData = $.extend({}, data);
1152
  newData.files = fileSet ? element : [element];
1153
  newData.paramName = paramNameSet[index];
1164
  return result;
1165
  },
1166
 
1167
+ _replaceFileInput: function (data) {
1168
  var input = data.fileInput,
1169
  inputClone = input.clone(true),
1170
  restoreFocus = input.is(document.activeElement);
1171
  // Add a reference for the new cloned file input to the data argument:
1172
  data.fileInputClone = inputClone;
1173
+ $('<form></form>').append(inputClone)[0].reset();
 
 
1174
  // Detaching allows to insert the fileInput on another form
1175
  // without loosing the file input value:
1176
  input.after(inputClone).detach();
1177
  // If the fileInput had focus before it was detached,
1178
  // restore focus to the inputClone.
1179
  if (restoreFocus) {
1180
+ inputClone.trigger('focus');
1181
  }
1182
  // Avoid memory leaks with the detached file input:
1183
+ $.cleanData(input.off('remove'));
1184
  // Replace the original file input element in the fileInput
1185
  // elements set with the clone, which has been copied including
1186
  // event handlers:
1187
+ this.options.fileInput = this.options.fileInput.map(function (i, el) {
1188
  if (el === input[0]) {
1189
  return inputClone[0];
1190
  }
1197
  }
1198
  },
1199
 
1200
+ _handleFileTreeEntry: function (entry, path) {
1201
  var that = this,
1202
  dfd = $.Deferred(),
1203
  entries = [],
1204
  dirReader,
1205
+ errorHandler = function (e) {
1206
  if (e && !e.entry) {
1207
  e.entry = entry;
1208
  }
1212
  // to be returned together in one set:
1213
  dfd.resolve([e]);
1214
  },
1215
+ successHandler = function (entries) {
1216
  that
1217
  ._handleFileTreeEntries(entries, path + entry.name + '/')
1218
+ .done(function (files) {
1219
  dfd.resolve(files);
1220
  })
1221
  .fail(errorHandler);
1222
  },
1223
+ readEntries = function () {
1224
+ dirReader.readEntries(function (results) {
1225
  if (!results.length) {
1226
  successHandler(entries);
1227
  } else {
1238
  entry._file.relativePath = path;
1239
  dfd.resolve(entry._file);
1240
  } else {
1241
+ entry.file(function (file) {
1242
  file.relativePath = path;
1243
  dfd.resolve(file);
1244
  }, errorHandler);
1254
  return dfd.promise();
1255
  },
1256
 
1257
+ _handleFileTreeEntries: function (entries, path) {
1258
  var that = this;
1259
  return $.when
1260
  .apply(
1261
  $,
1262
+ $.map(entries, function (entry) {
1263
  return that._handleFileTreeEntry(entry, path);
1264
  })
1265
  )
1266
+ [this._promisePipe](function () {
1267
  return Array.prototype.concat.apply([], arguments);
1268
  });
1269
  },
1270
 
1271
+ _getDroppedFiles: function (dataTransfer) {
1272
  // eslint-disable-next-line no-param-reassign
1273
  dataTransfer = dataTransfer || {};
1274
  var items = dataTransfer.items;
1278
  (items[0].webkitGetAsEntry || items[0].getAsEntry)
1279
  ) {
1280
  return this._handleFileTreeEntries(
1281
+ $.map(items, function (item) {
1282
  var entry;
1283
  if (item.webkitGetAsEntry) {
1284
  entry = item.webkitGetAsEntry();
1292
  })
1293
  );
1294
  }
1295
+ return $.Deferred().resolve($.makeArray(dataTransfer.files)).promise();
 
 
1296
  },
1297
 
1298
+ _getSingleFileInputFiles: function (fileInput) {
1299
  // eslint-disable-next-line no-param-reassign
1300
  fileInput = $(fileInput);
1301
  var entries =
1309
  if (!files.length) {
1310
  value = fileInput.prop('value');
1311
  if (!value) {
1312
+ return $.Deferred().resolve([]).promise();
 
 
1313
  }
1314
  // If the files property is not available, the browser does not
1315
  // support the File API and we add a pseudo File object with
1317
  files = [{ name: value.replace(/^.*\\/, '') }];
1318
  } else if (files[0].name === undefined && files[0].fileName) {
1319
  // File normalization for Safari 4 and Firefox 3:
1320
+ $.each(files, function (index, file) {
1321
  file.name = file.fileName;
1322
  file.size = file.fileSize;
1323
  });
1324
  }
1325
+ return $.Deferred().resolve(files).promise();
 
 
1326
  },
1327
 
1328
+ _getFileInputFiles: function (fileInput) {
1329
  if (!(fileInput instanceof $) || fileInput.length === 1) {
1330
  return this._getSingleFileInputFiles(fileInput);
1331
  }
1332
  return $.when
1333
  .apply($, $.map(fileInput, this._getSingleFileInputFiles))
1334
+ [this._promisePipe](function () {
1335
  return Array.prototype.concat.apply([], arguments);
1336
  });
1337
  },
1338
 
1339
+ _onChange: function (e) {
1340
  var that = this,
1341
  data = {
1342
  fileInput: $(e.target),
1343
  form: $(e.target.form)
1344
  };
1345
+ this._getFileInputFiles(data.fileInput).always(function (files) {
1346
  data.files = files;
1347
  if (that.options.replaceFileInput) {
1348
  that._replaceFileInput(data);
1359
  });
1360
  },
1361
 
1362
+ _onPaste: function (e) {
1363
  var items =
1364
  e.originalEvent &&
1365
  e.originalEvent.clipboardData &&
1366
  e.originalEvent.clipboardData.items,
1367
  data = { files: [] };
1368
  if (items && items.length) {
1369
+ $.each(items, function (index, item) {
1370
  var file = item.getAsFile && item.getAsFile();
1371
  if (file) {
1372
  data.files.push(file);
1384
  }
1385
  },
1386
 
1387
+ _onDrop: function (e) {
1388
  e.dataTransfer = e.originalEvent && e.originalEvent.dataTransfer;
1389
  var that = this,
1390
  dataTransfer = e.dataTransfer,
1391
  data = {};
1392
  if (dataTransfer && dataTransfer.files && dataTransfer.files.length) {
1393
  e.preventDefault();
1394
+ this._getDroppedFiles(dataTransfer).always(function (files) {
1395
  data.files = files;
1396
  if (
1397
  that._trigger(
1412
 
1413
  _onDragLeave: getDragHandler('dragleave'),
1414
 
1415
+ _initEventHandlers: function () {
1416
  if (this._isXHRUpload(this.options)) {
1417
  this._on(this.options.dropZone, {
1418
  dragover: this._onDragOver,
1433
  }
1434
  },
1435
 
1436
+ _destroyEventHandlers: function () {
1437
  this._off(this.options.dropZone, 'dragenter dragleave dragover drop');
1438
  this._off(this.options.pasteZone, 'paste');
1439
  this._off(this.options.fileInput, 'change');
1440
  },
1441
 
1442
+ _destroy: function () {
1443
  this._destroyEventHandlers();
1444
  },
1445
 
1446
+ _setOption: function (key, value) {
1447
  var reinit = $.inArray(key, this._specialOptions) !== -1;
1448
  if (reinit) {
1449
  this._destroyEventHandlers();
1455
  }
1456
  },
1457
 
1458
+ _initSpecialOptions: function () {
1459
  var options = this.options;
1460
  if (options.fileInput === undefined) {
1461
  options.fileInput = this.element.is('input[type="file"]')
1472
  }
1473
  },
1474
 
1475
+ _getRegExp: function (str) {
1476
  var parts = str.split('/'),
1477
  modifiers = parts.pop();
1478
  parts.shift();
1479
  return new RegExp(parts.join('/'), modifiers);
1480
  },
1481
 
1482
+ _isRegExpOption: function (key, value) {
1483
  return (
1484
  key !== 'url' &&
1485
  $.type(value) === 'string' &&
1487
  );
1488
  },
1489
 
1490
+ _initDataAttributes: function () {
1491
  var that = this,
1492
  options = this.options,
1493
  data = this.element.data();
1494
  // Initialize options set via HTML5 data-attributes:
1495
+ $.each(this.element[0].attributes, function (index, attr) {
1496
  var key = attr.name.toLowerCase(),
1497
  value;
1498
  if (/^data-/.test(key)) {
1499
  // Convert hyphen-ated key to camelCase:
1500
+ key = key.slice(5).replace(/-[a-z]/g, function (str) {
1501
  return str.charAt(1).toUpperCase();
1502
  });
1503
  value = data[key];
1509
  });
1510
  },
1511
 
1512
+ _create: function () {
1513
  this._initDataAttributes();
1514
  this._initSpecialOptions();
1515
  this._slots = [];
1521
 
1522
  // This method is exposed to the widget API and allows to query
1523
  // the number of active uploads:
1524
+ active: function () {
1525
  return this._active;
1526
  },
1527
 
1529
  // the widget upload progress.
1530
  // It returns an object with loaded, total and bitrate properties
1531
  // for the running uploads:
1532
+ progress: function () {
1533
  return this._progress;
1534
  },
1535
 
1537
  // using the fileupload API. The data parameter accepts an object which
1538
  // must have a files property and can contain additional options:
1539
  // .fileupload('add', {files: filesList});
1540
+ add: function (data) {
1541
  var that = this;
1542
  if (!data || this.options.disabled) {
1543
  return;
1544
  }
1545
  if (data.fileInput && !data.files) {
1546
+ this._getFileInputFiles(data.fileInput).always(function (files) {
1547
  data.files = files;
1548
  that._onAdd(null, data);
1549
  });
1558
  // must have a files or fileInput property and can contain additional options:
1559
  // .fileupload('send', {files: filesList});
1560
  // The method returns a Promise object for the file upload call.
1561
+ send: function (data) {
1562
  if (data && !this.options.disabled) {
1563
  if (data.fileInput && !data.files) {
1564
  var that = this,
1566
  promise = dfd.promise(),
1567
  jqXHR,
1568
  aborted;
1569
+ promise.abort = function () {
1570
  aborted = true;
1571
  if (jqXHR) {
1572
  return jqXHR.abort();
1574
  dfd.reject(null, 'abort', 'abort');
1575
  return promise;
1576
  };
1577
+ this._getFileInputFiles(data.fileInput).always(function (files) {
1578
  if (aborted) {
1579
  return;
1580
  }
1585
  data.files = files;
1586
  jqXHR = that._onSend(null, data);
1587
  jqXHR.then(
1588
+ function (result, textStatus, jqXHR) {
1589
  dfd.resolve(result, textStatus, jqXHR);
1590
  },
1591
+ function (jqXHR, textStatus, errorThrown) {
1592
  dfd.reject(jqXHR, textStatus, errorThrown);
1593
  }
1594
  );
filemanager/js/jq_uploader/jquery.iframe-transport.js CHANGED
@@ -11,7 +11,7 @@
11
 
12
  /* global define, require */
13
 
14
- (function(factory) {
15
  'use strict';
16
  if (typeof define === 'function' && define.amd) {
17
  // Register as an anonymous AMD module:
@@ -23,7 +23,7 @@
23
  // Browser globals:
24
  factory(window.jQuery);
25
  }
26
- })(function($) {
27
  'use strict';
28
 
29
  // Helper variable to create unique names for the transport iframes:
@@ -46,7 +46,7 @@
46
  // [{name: 'a', value: 1}, {name: 'b', value: 2}]
47
  // options.initialIframeSrc: the URL of the initial iframe src,
48
  // by default set to "javascript:false;"
49
- $.ajaxTransport('iframe', function(options) {
50
  if (options.async) {
51
  // javascript:false as initial iframe src
52
  // prevents warning popups on HTTPS in IE6:
@@ -56,7 +56,7 @@
56
  iframe,
57
  addParamChar;
58
  return {
59
- send: function(_, completeCallback) {
60
  form = $('<form style="display:none;"></form>');
61
  form.attr('accept-charset', options.formAcceptCharset);
62
  addParamChar = /\?/.test(options.url) ? '&' : '?';
@@ -81,12 +81,12 @@
81
  '" name="iframe-transport-' +
82
  counter +
83
  '"></iframe>'
84
- ).bind('load', function() {
85
  var fileInputClones,
86
  paramNames = $.isArray(options.paramName)
87
  ? options.paramName
88
  : [options.paramName];
89
- iframe.unbind('load').bind('load', function() {
90
  var response;
91
  // Wrap in a try/catch block to catch exceptions thrown
92
  // when trying to access cross-domain iframe contents:
@@ -109,7 +109,7 @@
109
  $('<iframe src="' + initialIframeSrc + '"></iframe>').appendTo(
110
  form
111
  );
112
- window.setTimeout(function() {
113
  // Removing the form in a setTimeout call
114
  // allows Chrome's developer tools to display
115
  // the response result
@@ -121,7 +121,7 @@
121
  .prop('action', options.url)
122
  .prop('method', options.type);
123
  if (options.formData) {
124
- $.each(options.formData, function(index, field) {
125
  $('<input type="hidden"/>')
126
  .prop('name', field.name)
127
  .val(field.value)
@@ -135,11 +135,11 @@
135
  ) {
136
  fileInputClones = options.fileInput.clone();
137
  // Insert a clone for each file input field:
138
- options.fileInput.after(function(index) {
139
  return fileInputClones[index];
140
  });
141
  if (options.paramName) {
142
- options.fileInput.each(function(index) {
143
  $(this).prop('name', paramNames[index] || options.paramName);
144
  });
145
  }
@@ -153,27 +153,33 @@
153
  // Remove the HTML5 form attribute from the input(s):
154
  options.fileInput.removeAttr('form');
155
  }
156
- form.submit();
157
- // Insert the file input fields at their original location
158
- // by replacing the clones with the originals:
159
- if (fileInputClones && fileInputClones.length) {
160
- options.fileInput.each(function(index, input) {
161
- var clone = $(fileInputClones[index]);
162
- // Restore the original name and form properties:
163
- $(input)
164
- .prop('name', clone.prop('name'))
165
- .attr('form', clone.attr('form'));
166
- clone.replaceWith(input);
167
- });
168
- }
 
 
 
 
 
 
169
  });
170
  form.append(iframe).appendTo(document.body);
171
  },
172
- abort: function() {
173
  if (iframe) {
174
  // javascript:false as iframe src aborts the request
175
  // and prevents warning popups on HTTPS in IE6.
176
- iframe.unbind('load').prop('src', initialIframeSrc);
177
  }
178
  if (form) {
179
  form.remove();
@@ -195,16 +201,16 @@
195
  // https://github.com/blueimp/jQuery-File-Upload/wiki/Setup#content-type-negotiation
196
  $.ajaxSetup({
197
  converters: {
198
- 'iframe text': function(iframe) {
199
  return iframe && $(iframe[0].body).text();
200
  },
201
- 'iframe json': function(iframe) {
202
  return iframe && jsonAPI[jsonParse]($(iframe[0].body).text());
203
  },
204
- 'iframe html': function(iframe) {
205
  return iframe && $(iframe[0].body).html();
206
  },
207
- 'iframe xml': function(iframe) {
208
  var xmlDoc = iframe && iframe[0];
209
  return xmlDoc && $.isXMLDoc(xmlDoc)
210
  ? xmlDoc
@@ -213,7 +219,7 @@
213
  $(xmlDoc.body).html()
214
  );
215
  },
216
- 'iframe script': function(iframe) {
217
  return iframe && $.globalEval($(iframe[0].body).text());
218
  }
219
  }
11
 
12
  /* global define, require */
13
 
14
+ (function (factory) {
15
  'use strict';
16
  if (typeof define === 'function' && define.amd) {
17
  // Register as an anonymous AMD module:
23
  // Browser globals:
24
  factory(window.jQuery);
25
  }
26
+ })(function ($) {
27
  'use strict';
28
 
29
  // Helper variable to create unique names for the transport iframes:
46
  // [{name: 'a', value: 1}, {name: 'b', value: 2}]
47
  // options.initialIframeSrc: the URL of the initial iframe src,
48
  // by default set to "javascript:false;"
49
+ $.ajaxTransport('iframe', function (options) {
50
  if (options.async) {
51
  // javascript:false as initial iframe src
52
  // prevents warning popups on HTTPS in IE6:
56
  iframe,
57
  addParamChar;
58
  return {
59
+ send: function (_, completeCallback) {
60
  form = $('<form style="display:none;"></form>');
61
  form.attr('accept-charset', options.formAcceptCharset);
62
  addParamChar = /\?/.test(options.url) ? '&' : '?';
81
  '" name="iframe-transport-' +
82
  counter +
83
  '"></iframe>'
84
+ ).on('load', function () {
85
  var fileInputClones,
86
  paramNames = $.isArray(options.paramName)
87
  ? options.paramName
88
  : [options.paramName];
89
+ iframe.off('load').on('load', function () {
90
  var response;
91
  // Wrap in a try/catch block to catch exceptions thrown
92
  // when trying to access cross-domain iframe contents:
109
  $('<iframe src="' + initialIframeSrc + '"></iframe>').appendTo(
110
  form
111
  );
112
+ window.setTimeout(function () {
113
  // Removing the form in a setTimeout call
114
  // allows Chrome's developer tools to display
115
  // the response result
121
  .prop('action', options.url)
122
  .prop('method', options.type);
123
  if (options.formData) {
124
+ $.each(options.formData, function (index, field) {
125
  $('<input type="hidden"/>')
126
  .prop('name', field.name)
127
  .val(field.value)
135
  ) {
136
  fileInputClones = options.fileInput.clone();
137
  // Insert a clone for each file input field:
138
+ options.fileInput.after(function (index) {
139
  return fileInputClones[index];
140
  });
141
  if (options.paramName) {
142
+ options.fileInput.each(function (index) {
143
  $(this).prop('name', paramNames[index] || options.paramName);
144
  });
145
  }
153
  // Remove the HTML5 form attribute from the input(s):
154
  options.fileInput.removeAttr('form');
155
  }
156
+ window.setTimeout(function () {
157
+ // Submitting the form in a setTimeout call fixes an issue with
158
+ // Safari 13 not triggering the iframe load event after resetting
159
+ // the load event handler, see also:
160
+ // https://github.com/blueimp/jQuery-File-Upload/issues/3633
161
+ form.submit();
162
+ // Insert the file input fields at their original location
163
+ // by replacing the clones with the originals:
164
+ if (fileInputClones && fileInputClones.length) {
165
+ options.fileInput.each(function (index, input) {
166
+ var clone = $(fileInputClones[index]);
167
+ // Restore the original name and form properties:
168
+ $(input)
169
+ .prop('name', clone.prop('name'))
170
+ .attr('form', clone.attr('form'));
171
+ clone.replaceWith(input);
172
+ });
173
+ }
174
+ }, 0);
175
  });
176
  form.append(iframe).appendTo(document.body);
177
  },
178
+ abort: function () {
179
  if (iframe) {
180
  // javascript:false as iframe src aborts the request
181
  // and prevents warning popups on HTTPS in IE6.
182
+ iframe.off('load').prop('src', initialIframeSrc);
183
  }
184
  if (form) {
185
  form.remove();
201
  // https://github.com/blueimp/jQuery-File-Upload/wiki/Setup#content-type-negotiation
202
  $.ajaxSetup({
203
  converters: {
204
+ 'iframe text': function (iframe) {
205
  return iframe && $(iframe[0].body).text();
206
  },
207
+ 'iframe json': function (iframe) {
208
  return iframe && jsonAPI[jsonParse]($(iframe[0].body).text());
209
  },
210
+ 'iframe html': function (iframe) {
211
  return iframe && $(iframe[0].body).html();
212
  },
213
+ 'iframe xml': function (iframe) {
214
  var xmlDoc = iframe && iframe[0];
215
  return xmlDoc && $.isXMLDoc(xmlDoc)
216
  ? xmlDoc
219
  $(xmlDoc.body).html()
220
  );
221
  },
222
+ 'iframe script': function (iframe) {
223
  return iframe && $.globalEval($(iframe[0].body).text());
224
  }
225
  }
filemanager/model.php CHANGED
@@ -209,101 +209,118 @@ class FilemanagerModel {
209
  *
210
  * @param array $params
211
  */
212
- function files_parsing_db( $params = array() ) {
213
- global $wpdb;
214
- $dir = $params['dir'];
215
- $path = $params['path'];
216
- $valid_types = $params['valid_types'];
217
- $truncate = !empty($params['truncate']) ? true : false;
218
-
219
- $dir = str_replace('/', DIRECTORY_SEPARATOR , $dir);
220
- $data = array();
221
- $dirs = array();
222
- $files = array();
223
- $items = $this->get_dir_contents($dir);
224
- if ( !empty($items) ) {
225
- foreach ( $items as $item ) {
226
- $value = str_replace($dir, '', $item);
227
- $value = explode(DIRECTORY_SEPARATOR, $value);
228
- $name = end($value);
229
- /*
230
- $paths = $value;
231
- array_pop($paths);
232
- $implode_path = implode('/', $paths);
233
- $path = !empty($implode_path) ? '/'. $implode_path . '/' : '/';
234
- */
235
- if ( is_dir($item) == TRUE ) {
236
- $file = array();
237
- $file['is_dir'] = 1;
238
- $file['path'] = $path;
239
- $file['name'] = $name;
240
- $file['filename'] = str_replace("_", " ", $name);
241
- $file['alt'] = str_replace("_", " ", $name);
242
- $file['thumb'] = '/filemanager/images/dir.png';
243
- $file['author'] = !empty($wpdb->get_var("SELECT `author` FROM `" . $wpdb->prefix . "bwg_file_paths` WHERE `name` = '$name'")) ? $wpdb->get_var("SELECT `author` FROM `" . $wpdb->prefix . "bwg_file_paths` WHERE `name` = '$name'") : 1;
244
- $dirs[] = $file;
245
- }
246
- else {
247
- $file = array();
248
- $file['is_dir'] = 0;
249
- $file['path'] = $path;
250
- $file['name'] = $name;
251
- $filename = substr($name, 0, strrpos($name, '.'));
252
- $file['filename'] = str_replace("_", " ", $filename);
253
- $file_extension = explode('.', $name);
254
- $file['type'] = strtolower(end($file_extension));
255
- $file['thumb'] = 'thumb/' . $name;
256
- if (($valid_types[0] != '*') && (in_array($file['type'], $valid_types) == FALSE)) {
257
- continue;
258
- }
259
- $file_size_kb = (int)(filesize($item) / 1024);
260
- $file['size'] = $file_size_kb . ' KB';
261
- $image_info = getimagesize(htmlspecialchars_decode($item, ENT_COMPAT | ENT_QUOTES));
262
- $file['resolution'] = $this->is_img($file['type']) ? $image_info[0] . ' x ' . $image_info[1] . ' px' : '';
263
- $file['resolution_thumb'] = WDWLibrary::get_thumb_size($file['thumb'] );
264
- $exif = WDWLibrary::read_image_metadata( $dir . '/.original/' . $name );
265
- $file['alt'] = BWG()->options->read_metadata && $exif['title'] ? $exif['title'] : str_replace("_", " ", $filename);
266
- $file['credit'] = !empty($exif['credit']) ? $exif['credit'] : '';
267
- $file['aperture'] = !empty($exif['aperture']) ? $exif['aperture'] : '';
268
- $file['camera'] = !empty($exif['camera']) ? $exif['camera'] : '';
269
- $file['caption'] = !empty($exif['caption']) ? $exif['caption'] : '';
270
- $file['iso'] = !empty($exif['iso']) ? $exif['iso'] : '';
271
- $file['orientation'] = !empty($exif['orientation']) ? $exif['orientation'] : '';
272
- $file['copyright'] = !empty($exif['copyright']) ? $exif['copyright']: '';
273
- $file['tags'] = !empty($exif['tags']) ? $exif['tags'] : '';
274
- $file['date_modified'] = date("Y-m-d H:i:s", filemtime($item));
275
- $file['author'] = !empty($wpdb->get_var("SELECT `author` FROM `" . $wpdb->prefix . "bwg_file_paths` WHERE `name` = '$name'")) ? $wpdb->get_var("SELECT `author` FROM `" . $wpdb->prefix . "bwg_file_paths` WHERE `name` = '$name'") : 1;
276
- $files[] = $file;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
277
  }
278
  }
279
- $data = array_merge($dirs,$files);
280
  $insert = 0;
281
  $tbl = $wpdb->prefix . 'bwg_file_paths';
282
  if ( !empty($params['refresh']) ) {
283
- $wpdb->delete($tbl, array( 'path' => $path ), array( '%s'));
284
  }
285
  foreach ( $data as $val ) {
286
  $insert = $wpdb->insert($tbl, $val);
287
  }
 
288
  return $insert;
289
  }
290
- }
291
 
292
  /**
293
- * Get from session.
 
294
  * @param $key
295
  * @param $default
296
  *
297
  * @return mixed
298
  */
299
- public function get_from_session( $key, $default ) {
300
- if (isset($_REQUEST[$key])) {
301
- $_REQUEST[$key] = stripslashes(WDWLibrary::get($key,'','sanitize_text_field','REQUEST'));
302
- }
303
- else {
304
- $_REQUEST[$key] = stripslashes($default);
305
- }
306
 
307
- return esc_html(stripslashes($_REQUEST[$key]));
308
- }
309
- }
 
 
 
 
209
  *
210
  * @param array $params
211
  */
212
+ function files_parsing_db( $params = array() ) {
213
+ global $wpdb;
214
+ $dir = $params['dir'];
215
+ $path = $params['path'];
216
+ $valid_types = $params['valid_types'];
217
+ $truncate = !empty($params['truncate']) ? TRUE : FALSE;
218
+ $dir = str_replace('/', DIRECTORY_SEPARATOR, $dir);
219
+ $data = array();
220
+ $dirs = array();
221
+ $files = array();
222
+ $items = $this->get_dir_contents($dir);
223
+ if ( !empty($items) ) {
224
+ foreach ( $items as $item ) {
225
+ $value = str_replace($dir, '', $item);
226
+ $value = explode(DIRECTORY_SEPARATOR, $value);
227
+ $name = end($value);
228
+ /*
229
+ $paths = $value;
230
+ array_pop($paths);
231
+ $implode_path = implode('/', $paths);
232
+ $path = !empty($implode_path) ? '/'. $implode_path . '/' : '/';
233
+ */
234
+ if ( is_dir($item) == TRUE ) {
235
+ $file = array();
236
+ $file['is_dir'] = 1;
237
+ $file['path'] = $path;
238
+ $file['name'] = $name;
239
+ $file['filename'] = str_replace("_", " ", $name);
240
+ $file['alt'] = str_replace("_", " ", $name);
241
+ $file['thumb'] = '/filemanager/images/dir.png';
242
+ $file['author'] = !empty($wpdb->get_var("SELECT `author` FROM `" . $wpdb->prefix . "bwg_file_paths` WHERE `name` = '$name'")) ? $wpdb->get_var("SELECT `author` FROM `" . $wpdb->prefix . "bwg_file_paths` WHERE `name` = '$name'") : 1;
243
+ $dirs[] = $file;
244
+ }
245
+ else {
246
+ $file = array();
247
+ $file['is_dir'] = 0;
248
+ $file['path'] = $path;
249
+ $file['name'] = $name;
250
+ $filename = substr($name, 0, strrpos($name, '.'));
251
+ $file['filename'] = str_replace("_", " ", $filename);
252
+ $file_extension = explode('.', $name);
253
+ $file['type'] = strtolower(end($file_extension));
254
+ $file['thumb'] = 'thumb/' . $name;
255
+ if ( ($valid_types[0] != '*') && (in_array($file['type'], $valid_types) == FALSE) ) {
256
+ continue;
257
+ }
258
+ $file_size_kb = (int) (filesize($item) / 1024);
259
+ $file['size'] = $file_size_kb . ' KB';
260
+ $image_info = getimagesize(htmlspecialchars_decode($item, ENT_COMPAT | ENT_QUOTES));
261
+ if ($this->is_img($file['type'])) {
262
+ if ($file['type'] === 'svg') {
263
+ $file_size_array = WDWLibrary::get_svg_size(BWG()->upload_url . $file['path'] . $file['name']);
264
+ if( !empty($file_size_array['width']) && !empty($file_size_array['height']) ) {
265
+ $file['resolution'] = $file_size_array['width'] . " x " . $file_size_array['height'] . " px ";
266
+ $file['resolution_thumb'] = $file_size_array['width'] . "x" . $file_size_array['height'];
267
+ } else {
268
+ $file['resolution'] = WDWLibrary::get('upload_img_width') . " x " . WDWLibrary::get('upload_img_height') . " px ";
269
+ $file['resolution_thumb'] = WDWLibrary::get('upload_thumb_width') . "x" . WDWLibrary::get('upload_thumb_height');
270
+ }
271
+ } else {
272
+ $file['resolution'] = $image_info[0] . ' x ' . $image_info[1] . ' px';
273
+ $file['resolution_thumb'] = WDWLibrary::get_thumb_size("/" . $file['thumb']);
274
+ }
275
+ } else {
276
+ $file['resolution'] = '';
277
+ $file['resolution_thumb'] = '';
278
+ }
279
+ $exif = WDWLibrary::read_image_metadata($dir . '/.original/' . $name);
280
+ $file['alt'] = BWG()->options->read_metadata && $exif['title'] ? $exif['title'] : str_replace("_", " ", $filename);
281
+ $file['credit'] = !empty($exif['credit']) ? $exif['credit'] : '';
282
+ $file['aperture'] = !empty($exif['aperture']) ? $exif['aperture'] : '';
283
+ $file['camera'] = !empty($exif['camera']) ? $exif['camera'] : '';
284
+ $file['caption'] = !empty($exif['caption']) ? $exif['caption'] : '';
285
+ $file['iso'] = !empty($exif['iso']) ? $exif['iso'] : '';
286
+ $file['orientation'] = !empty($exif['orientation']) ? $exif['orientation'] : '';
287
+ $file['copyright'] = !empty($exif['copyright']) ? $exif['copyright'] : '';
288
+ $file['tags'] = !empty($exif['tags']) ? $exif['tags'] : '';
289
+ $file['date_modified'] = date("Y-m-d H:i:s", filemtime($item));
290
+ $file['author'] = !empty($wpdb->get_var("SELECT `author` FROM `" . $wpdb->prefix . "bwg_file_paths` WHERE `name` = '$name'")) ? $wpdb->get_var("SELECT `author` FROM `" . $wpdb->prefix . "bwg_file_paths` WHERE `name` = '$name'") : 1;
291
+ $files[] = $file;
292
  }
293
  }
294
+ $data = array_merge($dirs, $files);
295
  $insert = 0;
296
  $tbl = $wpdb->prefix . 'bwg_file_paths';
297
  if ( !empty($params['refresh']) ) {
298
+ $wpdb->delete($tbl, array( 'path' => $path ), array( '%s' ));
299
  }
300
  foreach ( $data as $val ) {
301
  $insert = $wpdb->insert($tbl, $val);
302
  }
303
+
304
  return $insert;
305
  }
306
+ }
307
 
308
  /**
309
+ * Set the passed value to the REQUEST to make it possible to get from other page.
310
+ *
311
  * @param $key
312
  * @param $default
313
  *
314
  * @return mixed
315
  */
316
+ public function get_from_session( $key, $default ) {
317
+ // Sanitize the get value.
318
+ $value = WDWLibrary::get($key, $default, 'sanitize_text_field', 'REQUEST');
 
 
 
 
319
 
320
+ // Set the REQUEST value to make it possible to get from other page.
321
+ $_REQUEST[$key] = $value;
322
+
323
+ // Return the escaped value to use it in HTML.
324
+ return esc_html($value);
325
+ }
326
+ }
filemanager/view.php CHANGED
@@ -59,8 +59,8 @@ class FilemanagerView {
59
  wp_print_styles('wp-auth-check');
60
  wp_print_styles('wp-pointer');
61
  ?>
62
- <script src="<?php echo BWG()->plugin_url; ?>/filemanager/js/jq_uploader/jquery.iframe-transport.js?v=10.0.0"></script>
63
- <script src="<?php echo BWG()->plugin_url; ?>/filemanager/js/jq_uploader/jquery.fileupload.js?v=10.0.0"></script>
64
  <script>
65
  var DS = "<?php echo addslashes('/'); ?>";
66
  var demo_message = "<?php echo addslashes(__('This option is disabled in demo.', BWG()->prefix)); ?>";
@@ -218,7 +218,7 @@ class FilemanagerView {
218
  <a id="add_selectid_img" title="<?php echo $add_image_btn; ?>" class="button button-primary button-large" onclick="window.parent.bwg_create_loading_block(); onBtnOpenClick(event, this);">
219
  <div id="bwg_img_add"><?php echo $add_image_btn; ?></div>
220
  </a>
221
- <a class="button button-secondary button-large" title="<?php _e('Cancel', BWG()->prefix); ?>" onclick="onBtnCancelClick(event, this);">
222
  <div id="bwg_img_cancel"><?php _e('Cancel', BWG()->prefix); ?></div>
223
  </a>
224
  </div>
59
  wp_print_styles('wp-auth-check');
60
  wp_print_styles('wp-pointer');
61
  ?>
62
+ <script src="<?php echo BWG()->plugin_url; ?>/filemanager/js/jq_uploader/jquery.iframe-transport.js?v=10.31.0"></script>
63
+ <script src="<?php echo BWG()->plugin_url; ?>/filemanager/js/jq_uploader/jquery.fileupload.js?v=10.31.0"></script>
64
  <script>
65
  var DS = "<?php echo addslashes('/'); ?>";
66
  var demo_message = "<?php echo addslashes(__('This option is disabled in demo.', BWG()->prefix)); ?>";
218
  <a id="add_selectid_img" title="<?php echo $add_image_btn; ?>" class="button button-primary button-large" onclick="window.parent.bwg_create_loading_block(); onBtnOpenClick(event, this);">
219
  <div id="bwg_img_add"><?php echo $add_image_btn; ?></div>
220
  </a>
221
+ <a id="cancel_add_img" class="button button-secondary button-large" title="<?php _e('Cancel', BWG()->prefix); ?>" onclick="onBtnCancelClick(event, this);">
222
  <div id="bwg_img_cancel"><?php _e('Cancel', BWG()->prefix); ?></div>
223
  </a>
224
  </div>
framework/WDWLibrary.php CHANGED
@@ -251,9 +251,9 @@ class WDWLibrary {
251
  }
252
  if ($message) {
253
  ob_start();
254
- ?><div class="<?php echo $type; ?> inline">
255
  <p>
256
- <strong><?php echo $message; ?></strong>
257
  </p>
258
  </div><?php
259
  $message = ob_get_clean();
@@ -263,7 +263,7 @@ class WDWLibrary {
263
  }
264
 
265
  public static function message($message, $type) {
266
- return '<div style="width:100%"><div class="' . $type . '"><p><strong>' . $message . '</strong></p></div></div>';
267
  }
268
 
269
  /**
@@ -288,10 +288,10 @@ class WDWLibrary {
288
  $order = (($orderby == $id) && ($order == 'asc')) ? 'desc' : 'asc';
289
  ob_start();
290
  ?>
291
- <th id="order-<?php echo $id; ?>" class="<?php echo implode(' ', $class); ?>">
292
- <a href="<?php echo add_query_arg( array('orderby' => $id, 'order' => $order), $page_url ); ?>"
293
  title="<?php _e('Click to sort by this item', BWG()->prefix); ?>">
294
- <span><?php echo $text; ?></span><span class="sorting-indicator"></span>
295
  </a>
296
  </th>
297
  <?php
@@ -340,7 +340,7 @@ class WDWLibrary {
340
  $margin_right = 5;
341
  }
342
  ?>
343
- <div class="<?php echo $position_search; ?> actions" style="clear:both;">
344
  <script>
345
  function spider_search() {
346
  document.getElementById("page_number").value = "1";
@@ -365,8 +365,8 @@ class WDWLibrary {
365
  }
366
  </script>
367
  <div class="alignleft actions">
368
- <label for="search_value" style="font-size:14px; width:50px; display:inline-block;"><?php echo $search_by; ?>:</label>
369
- <input type="text" id="search_value" name="search_value" class="spider_search_value" onkeypress="return check_search_key(event, this);" value="<?php echo esc_html($search_value); ?>" style="width: 150px;margin-right:<?php echo $margin_right; ?>px; padding-top:10px; <?php echo (get_bloginfo('version') > '3.7') ? ' height: 33px;' : ''; ?>" />
370
  </div>
371
  <div class="alignleft actions">
372
  <input type="button" value="" title="<?php _e('Search',BWG()->prefix); ?>" onclick="spider_search()" class="wd-search-btn action">
@@ -470,18 +470,18 @@ class WDWLibrary {
470
  }
471
  ?>
472
  <span class="pagination-links">
473
- <a class="<?php echo $first_page; ?>" title="Go to the first page" href="javascript:spider_page(<?php echo $page_number; ?>,-2);">«</a>
474
- <a class="<?php echo $prev_page; ?>" title="Go to the previous page" href="javascript:spider_page(<?php echo $page_number; ?>,-1);">‹</a>
475
  <span class="paging-input">
476
  <span class="total-pages">
477
- <input class="current_page" id="current_page" name="current_page" value="<?php echo $page_number; ?>" onkeypress="return check_enter_key(event, this)" title="Go to the page" type="text" size="1" />
478
  </span> <?php echo __('of', BWG()->prefix); ?>
479
  <span class="total-pages">
480
- <?php echo $items_county; ?>
481
  </span>
482
  </span>
483
- <a class="<?php echo $next_page ?>" title="Go to the next page" href="javascript:spider_page(<?php echo $page_number; ?>,1);">›</a>
484
- <a class="<?php echo $last_page ?>" title="Go to the last page" href="javascript:spider_page(<?php echo $page_number; ?>,2);">»</a>
485
  <?php
486
  }
487
  ?>
@@ -517,8 +517,8 @@ class WDWLibrary {
517
  }
518
  </script>
519
  <div class="alignleft actions">
520
- <label for="search_value" style="font-size:14px; width:60px; display:inline-block;"><?php echo $search_by; ?>:</label>
521
- <input type="text" id="search_value" name="search_value" class="spider_search_value" onkeypress="return check_search_key(event, this);" value="<?php echo esc_html($search_value); ?>" style="width: 150px;margin-right:5px;<?php echo (get_bloginfo('version') > '3.7') ? ' height: 33px;' : ''; ?>" />
522
  </div>
523
  <div class="alignleft actions">
524
  <input type="button" value="" title="<?php echo __('Search',BWG()->prefix); ?>" onclick="spider_search()" class="wd-search-btn action">
@@ -617,8 +617,8 @@ class WDWLibrary {
617
  }
618
  ?>
619
  <span class="pagination-links">
620
- <a class="bwg-a <?php echo $first_page; ?>" title="Go to the first page" onclick="spider_page(<?php echo $page_number; ?>,-2)">«</a>
621
- <a class="bwg-a <?php echo $prev_page; ?>" title="Go to the previous page" onclick="spider_page(<?php echo $page_number; ?>,-1)">‹</a>
622
  <span class="paging-input">
623
  <span class="total-pages">
624
  <input class="current_page" id="current_page" name="current_page" value="<?php echo $page_number; ?>" onkeypress="return check_enter_key(event, this)" title="Go to the page" type="text" size="1" />
@@ -2301,7 +2301,7 @@ class WDWLibrary {
2301
  $title = ($title != '') ? strtolower($title) : 'items';
2302
  ob_start();
2303
  ?><tr class="no-items">
2304
- <td class="colspanchange" <?php echo $colspan_count ? 'colspan="' . $colspan_count . '"' : ''?>><?php echo sprintf(__('No %s found.', BWG()->prefix), $title); ?></td>
2305
  </tr><?php
2306
  return ob_get_clean();
2307
  }
@@ -2325,7 +2325,7 @@ class WDWLibrary {
2325
  $t_id = $tag->term_id; // Get the ID of the term you're editing
2326
  $term = get_term($t_id, 'bwg_tag');
2327
  ?>
2328
- <input type="hidden" name="old_tag" value="<?php echo isset($term->slug) ? $term->slug : ''; ?>" />
2329
  <?php
2330
  }
2331
 
@@ -2778,7 +2778,7 @@ class WDWLibrary {
2778
  <?php
2779
  if ( $show_guide_link ) {
2780
  ?>
2781
- <a href="<?php echo $user_guide_link; ?>" target="_blank" class="bwg-topbar_user_guid">
2782
  <div class="bwg-topbar-links-item">
2783
  <?php _e('User guide', BWG()->prefix); ?>
2784
  </div>
@@ -2792,9 +2792,9 @@ class WDWLibrary {
2792
  ?>
2793
  <div class="bwg-topbar bwg-topbar-links bwg-topbar_support_forum">
2794
  <div class="bwg-topbar-links-container">
2795
- <a href="<?php echo $support_forum_link; ?>" target="_blank" class="bwg-topbar_support_forum">
2796
  <div class="bwg-topbar-links-item">
2797
- <img src="<?php echo BWG()->plugin_url . '/css/images/help.svg'; ?>" class="help_icon" />
2798
  <?php _e('Ask a question', BWG()->prefix); ?>
2799
  </div>
2800
  </a>
@@ -2823,7 +2823,7 @@ class WDWLibrary {
2823
  ?>
2824
  <style>#wpbody-content>div:not(.wrap), .wrap .notice:not(#wd_bp_notice_cont) { display: none; }</style>
2825
  <div class="bwg-head">
2826
- <div><img src="<?php echo BWG()->plugin_url . '/images/FormMaker.png'; ?>"></div>
2827
  <ul class="bwg-breadcrumbs">
2828
  <?php
2829
  foreach ( $menus as $key => $item ) {
@@ -2832,7 +2832,7 @@ class WDWLibrary {
2832
  }
2833
  ?>
2834
  <li class="bwg-breadcrumb-item">
2835
- <a class="bwg-breadcrumb-item-link<?php echo ( $key == $page ) ? ' bwg-breadcrumb-item-link-active' : ''; ?>" href="<?php echo $item['href']; ?>"><?php echo $item['name']; ?></a>
2836
  </li>
2837
  <?php
2838
  }
@@ -2914,8 +2914,8 @@ class WDWLibrary {
2914
  ob_start();
2915
  if ( $show_guide_link ) {
2916
  ?>
2917
- <a href="<?php echo $user_guide_link; ?>" target="_blank" class="bwg-topbar_user_guid">
2918
- <img class="wd-question-mark" src="<?php echo BWG()->plugin_url . '/images/question_mark.svg';?>">
2919
  </a>
2920
  <?php
2921
  }?>
@@ -2940,7 +2940,7 @@ class WDWLibrary {
2940
  <p class="upgrade-text"><?php _e('features of the Premium Plugin', BWG()->prefix); ?></p>
2941
  <a class="upgrade-button" href="<?php echo $premium_link; ?>" target="_blank"><?php _e( 'Upgrade Now', BWG()->prefix ); ?></a>
2942
  </div>
2943
- <a class="wd-list-view-ask-question" href="<?php echo $support_forum_link; ?>" target="_blank"><?php _e('Ask a question', BWG()->prefix); ?></a>
2944
  <?php
2945
  echo ob_get_clean();
2946
  }
@@ -2954,7 +2954,7 @@ class WDWLibrary {
2954
  $support_forum_link = 'https://wordpress.org/support/plugin/photo-gallery/#new-post';
2955
  ob_start();
2956
  ?>
2957
- <a class="wd-list-view-ask-question" href="<?php echo $support_forum_link; ?>" target="_blank"><?php _e('Ask a question', BWG()->prefix); ?></a>
2958
  <?php
2959
  echo ob_get_clean();
2960
  }
251
  }
252
  if ($message) {
253
  ob_start();
254
+ ?><div class="<?php echo sanitize_html_class($type); ?> inline">
255
  <p>
256
+ <strong><?php echo esc_html($message); ?></strong>
257
  </p>
258
  </div><?php
259
  $message = ob_get_clean();
263
  }
264
 
265
  public static function message($message, $type) {
266
+ return '<div style="width:100%"><div class="' . sanitize_html_class($type) . '"><p><strong>' . esc_html($message) . '</strong></p></div></div>';
267
  }
268
 
269
  /**
288
  $order = (($orderby == $id) && ($order == 'asc')) ? 'desc' : 'asc';
289
  ob_start();
290
  ?>
291
+ <th id="order-<?php echo sanitize_html_class($id); ?>" class="<?php echo esc_html(implode(' ', $class)); ?>">
292
+ <a href="<?php echo esc_url(add_query_arg( array('orderby' => $id, 'order' => $order), $page_url )); ?>"
293
  title="<?php _e('Click to sort by this item', BWG()->prefix); ?>">
294
+ <span><?php echo esc_html($text); ?></span><span class="sorting-indicator"></span>
295
  </a>
296
  </th>
297
  <?php
340
  $margin_right = 5;
341
  }
342
  ?>
343
+ <div class="<?php echo sanitize_html_class($position_search); ?> actions" style="clear:both;">
344
  <script>
345
  function spider_search() {
346
  document.getElementById("page_number").value = "1";
365
  }
366
  </script>
367
  <div class="alignleft actions">
368
+ <label for="search_value" style="font-size:14px; width:50px; display:inline-block;"><?php echo esc_html($search_by); ?>:</label>
369
+ <input type="text" id="search_value" name="search_value" class="spider_search_value" onkeypress="return check_search_key(event, this);" value="<?php echo esc_attr($search_value); ?>" style="width: 150px;margin-right:<?php echo $margin_right; ?>px; padding-top:10px; <?php echo (get_bloginfo('version') > '3.7') ? ' height: 33px;' : ''; ?>" />
370
  </div>
371
  <div class="alignleft actions">
372
  <input type="button" value="" title="<?php _e('Search',BWG()->prefix); ?>" onclick="spider_search()" class="wd-search-btn action">
470
  }
471
  ?>
472
  <span class="pagination-links">
473
+ <a class="<?php echo esc_html($first_page); ?>" title="Go to the first page" href="javascript:spider_page(<?php echo $page_number; ?>,-2);">«</a>
474
+ <a class="<?php echo esc_html($prev_page); ?>" title="Go to the previous page" href="javascript:spider_page(<?php echo $page_number; ?>,-1);">‹</a>
475
  <span class="paging-input">
476
  <span class="total-pages">
477
+ <input class="current_page" id="current_page" name="current_page" value="<?php echo esc_attr($page_number); ?>" onkeypress="return check_enter_key(event, this)" title="Go to the page" type="text" size="1" />
478
  </span> <?php echo __('of', BWG()->prefix); ?>
479
  <span class="total-pages">
480
+ <?php echo esc_html($items_county); ?>
481
  </span>
482
  </span>
483
+ <a class="<?php echo esc_html($next_page) ?>" title="Go to the next page" href="javascript:spider_page(<?php echo $page_number; ?>,1);">›</a>
484
+ <a class="<?php echo esc_html($last_page) ?>" title="Go to the last page" href="javascript:spider_page(<?php echo $page_number; ?>,2);">»</a>
485
  <?php
486
  }
487
  ?>
517
  }
518
  </script>
519
  <div class="alignleft actions">
520
+ <label for="search_value" style="font-size:14px; width:60px; display:inline-block;"><?php echo esc_html($search_by); ?>:</label>
521
+ <input type="text" id="search_value" name="search_value" class="spider_search_value" onkeypress="return check_search_key(event, this);" value="<?php echo esc_attr($search_value); ?>" style="width: 150px;margin-right:5px;<?php echo (get_bloginfo('version') > '3.7') ? ' height: 33px;' : ''; ?>" />
522
  </div>
523
  <div class="alignleft actions">
524
  <input type="button" value="" title="<?php echo __('Search',BWG()->prefix); ?>" onclick="spider_search()" class="wd-search-btn action">
617
  }
618
  ?>
619
  <span class="pagination-links">
620
+ <a class="bwg-a <?php echo esc_html($first_page); ?>" title="Go to the first page" onclick="spider_page(<?php echo $page_number; ?>,-2)">«</a>
621
+ <a class="bwg-a <?php echo esc_html($prev_page); ?>" title="Go to the previous page" onclick="spider_page(<?php echo $page_number; ?>,-1)">‹</a>
622
  <span class="paging-input">
623
  <span class="total-pages">
624
  <input class="current_page" id="current_page" name="current_page" value="<?php echo $page_number; ?>" onkeypress="return check_enter_key(event, this)" title="Go to the page" type="text" size="1" />
2301
  $title = ($title != '') ? strtolower($title) : 'items';
2302
  ob_start();
2303
  ?><tr class="no-items">
2304
+ <td class="colspanchange" <?php echo $colspan_count ? 'colspan="' . esc_attr($colspan_count) . '"' : ''?>><?php echo sprintf(__('No %s found.', BWG()->prefix), $title); ?></td>
2305
  </tr><?php
2306
  return ob_get_clean();
2307
  }
2325
  $t_id = $tag->term_id; // Get the ID of the term you're editing
2326
  $term = get_term($t_id, 'bwg_tag');
2327
  ?>
2328
+ <input type="hidden" name="old_tag" value="<?php echo isset($term->slug) ? esc_attr($term->slug) : ''; ?>" />
2329
  <?php
2330
  }
2331
 
2778
  <?php
2779
  if ( $show_guide_link ) {
2780
  ?>
2781
+ <a href="<?php echo esc_url($user_guide_link); ?>" target="_blank" class="bwg-topbar_user_guid">
2782
  <div class="bwg-topbar-links-item">
2783
  <?php _e('User guide', BWG()->prefix); ?>
2784
  </div>
2792
  ?>
2793
  <div class="bwg-topbar bwg-topbar-links bwg-topbar_support_forum">
2794
  <div class="bwg-topbar-links-container">
2795
+ <a href="<?php echo esc_url($support_forum_link); ?>" target="_blank" class="bwg-topbar_support_forum">
2796
  <div class="bwg-topbar-links-item">
2797
+ <img src="<?php echo esc_url(BWG()->plugin_url . '/css/images/help.svg'); ?>" class="help_icon" />
2798
  <?php _e('Ask a question', BWG()->prefix); ?>
2799
  </div>
2800
  </a>
2823
  ?>
2824
  <style>#wpbody-content>div:not(.wrap), .wrap .notice:not(#wd_bp_notice_cont) { display: none; }</style>
2825
  <div class="bwg-head">
2826
+ <div><img src="<?php echo esc_url(BWG()->plugin_url . '/images/FormMaker.png'); ?>"></div>
2827
  <ul class="bwg-breadcrumbs">
2828
  <?php
2829
  foreach ( $menus as $key => $item ) {
2832
  }
2833
  ?>
2834
  <li class="bwg-breadcrumb-item">
2835
+ <a class="bwg-breadcrumb-item-link<?php echo ( $key == $page ) ? ' bwg-breadcrumb-item-link-active' : ''; ?>" href="<?php echo esc_url($item['href']); ?>"><?php echo esc_html($item['name']); ?></a>
2836
  </li>
2837
  <?php
2838
  }
2914
  ob_start();
2915
  if ( $show_guide_link ) {
2916
  ?>
2917
+ <a href="<?php echo esc_url($user_guide_link); ?>" target="_blank" class="bwg-topbar_user_guid">
2918
+ <img class="wd-question-mark" src="<?php echo esc_url(BWG()->plugin_url . '/images/question_mark.svg');?>">
2919
  </a>
2920
  <?php
2921
  }?>
2940
  <p class="upgrade-text"><?php _e('features of the Premium Plugin', BWG()->prefix); ?></p>
2941
  <a class="upgrade-button" href="<?php echo $premium_link; ?>" target="_blank"><?php _e( 'Upgrade Now', BWG()->prefix ); ?></a>
2942
  </div>
2943
+ <a class="wd-list-view-ask-question" href="<?php echo esc_url($support_forum_link); ?>" target="_blank"><?php _e('Ask a question', BWG()->prefix); ?></a>
2944
  <?php
2945
  echo ob_get_clean();
2946
  }
2954
  $support_forum_link = 'https://wordpress.org/support/plugin/photo-gallery/#new-post';
2955
  ob_start();
2956
  ?>
2957
+ <a class="wd-list-view-ask-question" href="<?php echo esc_url($support_forum_link); ?>" target="_blank"><?php _e('Ask a question', BWG()->prefix); ?></a>
2958
  <?php
2959
  echo ob_get_clean();
2960
  }
frontend/controllers/BWGControllerDownload_gallery.php CHANGED
@@ -6,6 +6,12 @@ class BWGControllerDownload_gallery {
6
  }
7
 
8
  public function display() {
 
 
 
 
 
 
9
  require_once BWG()->plugin_dir . "/frontend/views/BWGViewDownload_gallery.php";
10
  $view = new BWGViewDownload_gallery();
11
 
6
  }
7
 
8
  public function display() {
9
+ $nonce = WDWLibrary::get('_wpnonce', '', 'sanitize_text_field', 'GET');
10
+ if( !wp_verify_nonce( $nonce, "bwg-download-nonce" ) ){
11
+ echo "Permission denied";
12
+ die;
13
+ }
14
+
15
  require_once BWG()->plugin_dir . "/frontend/views/BWGViewDownload_gallery.php";
16
  $view = new BWGViewDownload_gallery();
17
 
frontend/controllers/BWGControllerGalleryBox.php CHANGED
@@ -22,7 +22,7 @@ class BWGControllerGalleryBox {
22
 
23
  public function save_rate() {
24
  global $wpdb;
25
- $image_id = WDWLibrary::get('image_id', 0, 'intval','POST');
26
  $rate = WDWLibrary::get('rate');
27
  $ip = BWG()->options->save_ip ? $_SERVER['REMOTE_ADDR'] : '';
28
  if ( !$ip || !$wpdb->get_var($wpdb->prepare('SELECT `image_id` FROM `' . $wpdb->prefix . 'bwg_image_rate` WHERE `ip`="%s" AND `image_id`="%d"', $ip, $image_id)) ) {
@@ -31,19 +31,24 @@ class BWGControllerGalleryBox {
31
  'rate' => $rate,
32
  'ip' => $ip,
33
  'date' => date('Y-m-d H:i:s'),
34
- ), array(
35
- '%d',
36
- '%f',
37
- '%s',
38
- '%s',
39
- ));
40
  }
41
  $rates = $wpdb->get_row($wpdb->prepare('SELECT AVG(`rate`) as `average`, COUNT(`rate`) as `rate_count` FROM ' . $wpdb->prefix . 'bwg_image_rate WHERE image_id="%d"', $image_id));
42
- $wpdb->update($wpdb->prefix . 'bwg_image', array(
43
- 'avg_rating' => $rates->average,
44
- 'rate_count' => $rates->rate_count
45
- ), array( 'id' => $image_id ),
46
- array('%f','%d'),array('%d'));
 
 
 
 
 
47
  $this->display();
48
  }
49
 
@@ -65,7 +70,7 @@ class BWGControllerGalleryBox {
65
  $image_id = WDWLibrary::get('comment_image_id', 0);
66
  $name = trim(WDWLibrary::get('comment_name', ''));
67
  $email = WDWLibrary::get('comment_email', '');
68
- $comment = trim(WDWLibrary::get('comment_text', ''));
69
  $moderation = trim(WDWLibrary::get('comment_moderation', 0));
70
  $privacy_policy = WDWLibrary::get('privacy_policy', '');
71
  $published = (current_user_can('manage_options') || !$moderation) ? 1 : 0;
22
 
23
  public function save_rate() {
24
  global $wpdb;
25
+ $image_id = WDWLibrary::get('image_id', 0, 'intval', 'POST');
26
  $rate = WDWLibrary::get('rate');
27
  $ip = BWG()->options->save_ip ? $_SERVER['REMOTE_ADDR'] : '';
28
  if ( !$ip || !$wpdb->get_var($wpdb->prepare('SELECT `image_id` FROM `' . $wpdb->prefix . 'bwg_image_rate` WHERE `ip`="%s" AND `image_id`="%d"', $ip, $image_id)) ) {
31
  'rate' => $rate,
32
  'ip' => $ip,
33
  'date' => date('Y-m-d H:i:s'),
34
+ ), array(
35
+ '%d',
36
+ '%f',
37
+ '%s',
38
+ '%s',
39
+ ));
40
  }
41
  $rates = $wpdb->get_row($wpdb->prepare('SELECT AVG(`rate`) as `average`, COUNT(`rate`) as `rate_count` FROM ' . $wpdb->prefix . 'bwg_image_rate WHERE image_id="%d"', $image_id));
42
+ $wpdb->update($wpdb->prefix . 'bwg_image',
43
+ array(
44
+ 'avg_rating' => $rates->average,
45
+ 'rate_count' => $rates->rate_count,
46
+ ),
47
+ array( 'id' => $image_id ),
48
+ array( '%f', '%d' ),
49
+ array( '%d' )
50
+ );
51
+
52
  $this->display();
53
  }
54
 
70
  $image_id = WDWLibrary::get('comment_image_id', 0);
71
  $name = trim(WDWLibrary::get('comment_name', ''));
72
  $email = WDWLibrary::get('comment_email', '');
73
+ $comment = trim(WDWLibrary::get('comment_text', '', 'htmlentities'));
74
  $moderation = trim(WDWLibrary::get('comment_moderation', 0));
75
  $privacy_policy = WDWLibrary::get('privacy_policy', '');
76
  $published = (current_user_can('manage_options') || !$moderation) ? 1 : 0;
frontend/models/BWGModelGalleryBox.php CHANGED
@@ -6,7 +6,7 @@ class BWGModelGalleryBox {
6
  return $row;
7
  }
8
 
9
- public function get_image_rows_data($gallery_id, $bwg, $sort_by, $order_by = 'asc', $tag = 0) {
10
  global $wpdb;
11
  $bwg_sort_by_temp = WDWLibrary::get('filtersortby', '');
12
  if ( $bwg_sort_by_temp == '' ) { /* for thumbnail view */
@@ -38,10 +38,10 @@ class BWGModelGalleryBox {
38
 
39
  $bwg_random_seed = WDWLibrary::get('bwg_random_seed','');
40
  $bwg_filter_tag_temp = WDWLibrary::get('filter_tag', 0);
41
- if ( $bwg_filter_tag_temp == 0 ) {
42
  $filter_tags = array();
43
  $bwg_filter_tag_temp = WDWLibrary::get('filter_tag_' . $bwg, 0);
44
- if ( $bwg_filter_tag_temp != 0 ) {
45
  $filter_tags = explode(",", $bwg_filter_tag_temp);
46
  }
47
  }
@@ -113,14 +113,17 @@ class BWGModelGalleryBox {
113
  $where .= ' AND CONCAT(",", tags.tags_combined, ",") REGEXP ",(' . implode($compare_sign, $filter_tags) . ')," ';
114
  }
115
 
116
- $query = 'SELECT image.*, rates.rate FROM ' . $wpdb->prefix . 'bwg_image as image LEFT JOIN (SELECT rate, image_id FROM ' . $wpdb->prefix . 'bwg_image_rate WHERE ip="' . $_SERVER['REMOTE_ADDR'] . '") as rates ON image.id=rates.image_id ' . $join . ' WHERE image.published=1 ' . $where;
 
 
 
 
117
  $query .= ' ORDER BY ' . str_replace('RAND()', 'RAND(' . $bwg_random_seed . ')', $sort_by) . ' ' . $order_by . ', image.id asc';
118
  if( !empty($prepareArgs) ) {
119
  $rows = $wpdb->get_results($wpdb->prepare($query, $prepareArgs));
120
  } else {
121
  $rows = $wpdb->get_results($query);
122
  }
123
-
124
  $images = array();
125
  if ( !empty($rows) ) {
126
  foreach ( $rows as $row ) {
6
  return $row;
7
  }
8
 
9
+ public function get_image_rows_data($gallery_id, $bwg, $sort_by, $order_by = 'asc', $tag = 0, $popup_enable_rate = 0 ) {
10
  global $wpdb;
11
  $bwg_sort_by_temp = WDWLibrary::get('filtersortby', '');
12
  if ( $bwg_sort_by_temp == '' ) { /* for thumbnail view */
38
 
39
  $bwg_random_seed = WDWLibrary::get('bwg_random_seed','');
40
  $bwg_filter_tag_temp = WDWLibrary::get('filter_tag', 0);
41
+ if ( empty($bwg_filter_tag_temp) ) {
42
  $filter_tags = array();
43
  $bwg_filter_tag_temp = WDWLibrary::get('filter_tag_' . $bwg, 0);
44
+ if ( !empty($bwg_filter_tag_temp) ) {
45
  $filter_tags = explode(",", $bwg_filter_tag_temp);
46
  }
47
  }
113
  $where .= ' AND CONCAT(",", tags.tags_combined, ",") REGEXP ",(' . implode($compare_sign, $filter_tags) . ')," ';
114
  }
115
 
116
+ $rate_join = '';
117
+ if( $popup_enable_rate ) {
118
+ $rate_join = ' LEFT JOIN (SELECT rate, image_id FROM ' . $wpdb->prefix . 'bwg_image_rate WHERE ip="' . $_SERVER['REMOTE_ADDR'] . '") as rates ON image.id=rates.image_id ';
119
+ }
120
+ $query = 'SELECT image.*' . ($popup_enable_rate ? ', rates.rate' : '') . ' FROM ' . $wpdb->prefix . 'bwg_image as image' . $rate_join . $join . ' WHERE image.published=1 ' . $where;
121
  $query .= ' ORDER BY ' . str_replace('RAND()', 'RAND(' . $bwg_random_seed . ')', $sort_by) . ' ' . $order_by . ', image.id asc';
122
  if( !empty($prepareArgs) ) {
123
  $rows = $wpdb->get_results($wpdb->prepare($query, $prepareArgs));
124
  } else {
125
  $rows = $wpdb->get_results($query);
126
  }
 
127
  $images = array();
128
  if ( !empty($rows) ) {
129
  foreach ( $rows as $row ) {
frontend/models/model.php CHANGED
@@ -7,6 +7,15 @@ class BWGModelSite {
7
  $id = $wpdb->get_var('SELECT id FROM ' . $wpdb->prefix . 'bwg_theme WHERE default_theme=1');
8
  }
9
  $row = new WD_BWG_Theme($id);
 
 
 
 
 
 
 
 
 
10
  return $row;
11
  }
12
 
7
  $id = $wpdb->get_var('SELECT id FROM ' . $wpdb->prefix . 'bwg_theme WHERE default_theme=1');
8
  }
9
  $row = new WD_BWG_Theme($id);
10
+ foreach ( $row as $key => $val ) {
11
+ // '#' is removed from the color (jscolor lib v2.4.5)
12
+ preg_match('/_color/', $key, $is_color_array);
13
+ if ( !empty($is_color_array) && !empty($is_color_array[0]) ) {
14
+ $val = str_replace('#', '', $val);
15
+ }
16
+ $row->$key = $val;
17
+ }
18
+
19
  return $row;
20
  }
21
 
frontend/views/BWGViewAlbum_compact_preview.php CHANGED
@@ -53,25 +53,25 @@ class BWGViewAlbum_compact_preview extends BWGViewSite {
53
  if ( !WDWLibrary::elementor_is_active() ) {
54
  if ( !$params['ajax'] ) {
55
  if ( BWG()->options->use_inline_stiles_and_scripts ) {
56
- wp_add_inline_style('bwg_frontend', $inline_style);
57
  }
58
  else {
59
- echo '<style id="bwg-style-' . $bwg . '">' . $inline_style . '</style>';
60
  }
61
  }
62
  }
63
  else {
64
- echo '<style id="bwg-style-' . $bwg . '">' . $inline_style . '</style>';
65
  }
66
  ob_start();
67
 
68
  if ( $params['album_view_type'] != 'gallery' ) {
69
  ?>
70
- <div data-max-count="<?php echo $params['items_col_num']; ?>"
71
- data-thumbnail-width="<?php echo $params['compuct_album_thumb_width']; ?>"
72
- data-bwg="<?php echo $bwg; ?>"
73
- id="<?php echo $params['container_id']; ?>"
74
- class="bwg-thumbnails bwg-container bwg-container-<?php echo $bwg; ?> bwg-album-thumbnails <?php echo $params['album_gallery_div_class']; ?>">
75
  <?php
76
  if ( !$params['album_gallery_rows']['page_nav']['total'] ) {
77
  echo WDWLibrary::message(__('No results found.', BWG()->prefix), 'wd_error');
@@ -96,25 +96,25 @@ class BWGViewAlbum_compact_preview extends BWGViewSite {
96
  $enable_dynamic_url = (int) BWG()->options->front_ajax;
97
  ?>
98
  <div class="bwg-item">
99
- <a class="bwg-a <?php echo $from !== "widget" ? 'bwg-album ' : ''; ?>bwg_album_<?php echo $bwg; ?>"
100
  <?php echo ( ($enable_seo || $enable_dynamic_url) && $from !== "widget" ? "href='" . esc_url($href) . "'" : ""); ?>
101
  <?php echo $from === "widget" ? 'href="' . $row->permalink . '"' : ''; ?>
102
- data-container_id="<?php echo $params['container_id']; ?>"
103
- data-def_type="<?php echo $row->def_type; ?>"
104
- data-album_gallery_id="<?php echo $params['album_gallery_id']; ?>"
105
- data-alb_gal_id="<?php echo (($params['album_gallery_id'] != 0) ? $row->alb_gal_id : $row->id); ?>"
106
- data-title="<?php echo htmlspecialchars(addslashes($row->name)); ?>"
107
- data-bwg="<?php echo $bwg; ?>">
108
- <?php if ( $params['compuct_album_title'] == 'show' && $theme_row->album_compact_thumb_title_pos == 'top' ) { echo $title; } ?>
109
  <div class="bwg-item0 <?php echo ($lazyload) ? 'lazy_loader': ''; ?>">
110
  <div class="bwg-item1 <?php echo $theme_row->album_compact_thumb_hover_effect == 'zoom' && $params['compuct_album_title'] == 'hover' ? 'bwg-zoom-effect' : ''; ?>">
111
  <div class="bwg-item2">
112
  <img class="skip-lazy <?php if( $lazyload ) { ?> bwg_lazyload <?php } ?>"
113
- data-width="<?php echo $image_thumb_width; ?>"
114
- data-height="<?php echo $image_thumb_height; ?>"
115
- data-original="<?php echo $row->preview_image; ?>"
116
- src="<?php if( !$lazyload ) { echo $row->preview_image; } else { echo BWG()->plugin_url."/images/lazy_placeholder.gif"; } ?>"
117
- alt="<?php echo $row->name; ?>" />
118
  </div>
119
  <div class="<?php echo $theme_row->album_compact_thumb_hover_effect == 'zoom' && $params['compuct_album_title'] == 'hover' ? 'bwg-zoom-effect-overlay' : ''; ?>">
120
  <?php if ( $params['compuct_album_title'] == 'hover' ) { echo $title; } ?>
@@ -137,7 +137,7 @@ class BWGViewAlbum_compact_preview extends BWGViewSite {
137
  }
138
  }
139
  ?>
140
- <input type="hidden" id="bwg_album_breadcrumb_<?php echo $bwg; ?>" name="bwg_album_breadcrumb_<?php echo $bwg; ?>" value='<?php echo esc_attr($breadcrumb); ?>' />
141
  <?php
142
  $content = ob_get_clean();
143
  if ( $ajax ) {/* Ajax response after ajax call for filters and pagination.*/
53
  if ( !WDWLibrary::elementor_is_active() ) {
54
  if ( !$params['ajax'] ) {
55
  if ( BWG()->options->use_inline_stiles_and_scripts ) {
56
+ wp_add_inline_style('bwg_frontend', $inline_style);
57
  }
58
  else {
59
+ echo '<style id="bwg-style-' . sanitize_html_class($bwg) . '">' . $inline_style . '</style>';
60
  }
61
  }
62
  }
63
  else {
64
+ echo '<style id="bwg-style-' . sanitize_html_class($bwg) . '">' . $inline_style . '</style>';
65
  }
66
  ob_start();
67
 
68
  if ( $params['album_view_type'] != 'gallery' ) {
69
  ?>
70
+ <div data-max-count="<?php echo esc_attr($params['items_col_num']); ?>"
71
+ data-thumbnail-width="<?php echo esc_attr($params['compuct_album_thumb_width']); ?>"
72
+ data-bwg="<?php echo esc_attr($bwg); ?>"
73
+ id="<?php echo esc_attr($params['container_id']); ?>"
74
+ class="bwg-thumbnails bwg-container bwg-container-<?php echo sanitize_html_class($bwg); ?> bwg-album-thumbnails <?php echo sanitize_html_class($params['album_gallery_div_class']); ?>">
75
  <?php
76
  if ( !$params['album_gallery_rows']['page_nav']['total'] ) {
77
  echo WDWLibrary::message(__('No results found.', BWG()->prefix), 'wd_error');
96
  $enable_dynamic_url = (int) BWG()->options->front_ajax;
97
  ?>
98
  <div class="bwg-item">
99
+ <a class="bwg-a <?php echo $from !== "widget" ? 'bwg-album ' : ''; ?>bwg_album_<?php echo sanitize_html_class($bwg); ?>"
100
  <?php echo ( ($enable_seo || $enable_dynamic_url) && $from !== "widget" ? "href='" . esc_url($href) . "'" : ""); ?>
101
  <?php echo $from === "widget" ? 'href="' . $row->permalink . '"' : ''; ?>
102
+ data-container_id="<?php echo esc_attr($params['container_id']); ?>"
103
+ data-def_type="<?php echo esc_attr($row->def_type); ?>"
104
+ data-album_gallery_id="<?php echo esc_attr($params['album_gallery_id']); ?>"
105
+ data-alb_gal_id="<?php echo (($params['album_gallery_id'] != 0) ? esc_attr($row->alb_gal_id) : esc_attr($row->id)); ?>"
106
+ data-title="<?php echo esc_attr($row->name); ?>"
107
+ data-bwg="<?php echo esc_attr($bwg); ?>">
108
+ <?php if ( $params['compuct_album_title'] == 'show' && $theme_row->album_compact_thumb_title_pos == 'top' ) { echo esc_html($title); } ?>
109
  <div class="bwg-item0 <?php echo ($lazyload) ? 'lazy_loader': ''; ?>">
110
  <div class="bwg-item1 <?php echo $theme_row->album_compact_thumb_hover_effect == 'zoom' && $params['compuct_album_title'] == 'hover' ? 'bwg-zoom-effect' : ''; ?>">
111
  <div class="bwg-item2">
112
  <img class="skip-lazy <?php if( $lazyload ) { ?> bwg_lazyload <?php } ?>"
113
+ data-width="<?php echo esc_attr($image_thumb_width); ?>"
114
+ data-height="<?php echo esc_attr($image_thumb_height); ?>"
115
+ data-original="<?php echo esc_attr($row->preview_image); ?>"
116
+ src="<?php if( !$lazyload ) { echo esc_url($row->preview_image); } else { echo esc_url(BWG()->plugin_url."/images/lazy_placeholder.gif"); } ?>"
117
+ alt="<?php echo esc_attr($row->name); ?>" />
118
  </div>
119
  <div class="<?php echo $theme_row->album_compact_thumb_hover_effect == 'zoom' && $params['compuct_album_title'] == 'hover' ? 'bwg-zoom-effect-overlay' : ''; ?>">
120
  <?php if ( $params['compuct_album_title'] == 'hover' ) { echo $title; } ?>
137
  }
138
  }
139
  ?>
140
+ <input type="hidden" id="bwg_album_breadcrumb_<?php echo sanitize_html_class($bwg); ?>" name="bwg_album_breadcrumb_<?php echo sanitize_html_class($bwg); ?>" value='<?php echo esc_attr($breadcrumb); ?>' />
141
  <?php
142
  $content = ob_get_clean();
143
  if ( $ajax ) {/* Ajax response after ajax call for filters and pagination.*/
frontend/views/BWGViewAlbum_extended_preview.php CHANGED
@@ -62,25 +62,25 @@ class BWGViewAlbum_extended_preview extends BWGViewSite {
62
  wp_add_inline_style('bwg_frontend', $inline_style);
63
  }
64
  else {
65
- echo '<style id="bwg-style-' . $bwg . '">' . $inline_style . '</style>';
66
  }
67
  }
68
  }
69
  else {
70
- echo '<style id="bwg-style-' . $bwg . '">' . $inline_style . '</style>';
71
  }
72
 
73
  ob_start();
74
 
75
  if ( $params['album_view_type'] != 'gallery' ) {
76
  ?>
77
- <div data-max-count="<?php echo $params['extended_album_column_number']; ?>"
78
- data-thumbnail-width="<?php echo $params['extended_album_thumb_width']; ?>"
79
- data-global-spacing="<?php echo $theme_row->album_extended_div_margin; ?>"
80
- data-spacing="<?php echo $theme_row->album_extended_div_padding; ?>"
81
- data-bwg="<?php echo $bwg; ?>"
82
- id="<?php echo $params['container_id']; ?>"
83
- class="bwg-album-extended bwg-border-box bwg-thumbnails bwg-container bwg-container-<?php echo $bwg; ?> bwg-album-thumbnails bwg_album_extended_thumbnails_<?php echo $bwg; ?>">
84
  <?php
85
  if ( !$params['album_gallery_rows']['page_nav']['total'] ) {
86
  echo WDWLibrary::message(__('No results found.', BWG()->prefix), 'wd_error');
@@ -105,23 +105,23 @@ class BWGViewAlbum_extended_preview extends BWGViewSite {
105
  ?>
106
  <div class="bwg-extended-item">
107
  <div class="bwg-extended-item0">
108
- <a class="bwg-a bwg-album bwg_album_<?php echo $bwg; ?>"
109
  <?php echo ( ($enable_seo || $enable_dynamic_url ) ? "href='" . esc_url($href) . "'" : ""); ?>
110
  style="font-size: 0;"
111
- data-bwg="<?php echo $bwg; ?>"
112
- data-container_id="<?php echo $params['container_id']; ?>"
113
- data-alb_gal_id="<?php echo (($params['album_gallery_id'] != 0) ? $row->alb_gal_id : $row->id); ?>"
114
- data-def_type="<?php echo $row->def_type; ?>"
115
  data-title="<?php echo htmlspecialchars(addslashes($row->name)); ?>">
116
- <div class="bwg-item0 bwg_album_thumb_<?php echo $bwg; ?> <?php echo ($lazyload) ? 'lazy_loader' : ''; ?>">
117
- <div class="bwg-item1 bwg_album_thumb_spun1_<?php echo $bwg; ?>">
118
  <div class="bwg-item2">
119
  <img class="skip-lazy <?php if( $lazyload ) { ?> bwg_lazyload <?php } ?>"
120
- data-width="<?php echo $image_thumb_width; ?>"
121
- data-height="<?php echo $image_thumb_height; ?>"
122
- data-original="<?php echo $row->preview_image; ?>"
123
- src="<?php if( !$lazyload ) { echo $row->preview_image; } else { echo BWG()->plugin_url."/images/lazy_placeholder.gif"; } ?>"
124
- alt="<?php echo $row->name; ?>" />
125
  </div>
126
  </div>
127
  </div>
@@ -131,14 +131,14 @@ class BWGViewAlbum_extended_preview extends BWGViewSite {
131
  <?php
132
  if ( $row->name ) {
133
  ?>
134
- <a class="bwg-album bwg_album_<?php echo $bwg; ?>"
135
  <?php echo ( ($enable_seo || $enable_dynamic_url) ? "href='" . esc_url($href) . "'" : "" ); ?>
136
- data-bwg="<?php echo $bwg; ?>"
137
- data-container_id="<?php echo $params['container_id']; ?>"
138
- data-alb_gal_id="<?php echo(($params['album_gallery_id'] != 0) ? $row->alb_gal_id : $row->id); ?>"
139
- data-def_type="<?php echo $row->def_type; ?>"
140
  data-title="<?php echo htmlspecialchars(addslashes($row->name)); ?>">
141
- <span class="bwg_title_spun_<?php echo $bwg; ?>"><?php echo $row->name; ?></span>
142
  </a>
143
  <?php
144
  }
@@ -148,18 +148,18 @@ class BWGViewAlbum_extended_preview extends BWGViewSite {
148
  $description_short = $description_array[0];
149
  $description_full = $description_array[1];
150
  ?>
151
- <span class="bwg_description_spun1_<?php echo $bwg; ?>">
152
- <span class="bwg_description_spun2_<?php echo $bwg; ?>">
153
- <span class="bwg_description_short_<?php echo $bwg; ?>">
154
- <?php echo $description_short; ?>
155
  </span>
156
  <span class="bwg_description_full">
157
- <?php echo $description_full; ?>
158
  </span>
159
  </span>
160
  <span data-more-msg="<?php _e('More', BWG()->prefix); ?>"
161
  data-hide-msg="<?php _e('Hide', BWG()->prefix); ?>"
162
- class="bwg_description_more bwg_description_more_<?php echo $bwg; ?> bwg_more">
163
  <?php _e('More', BWG()->prefix); ?>
164
  </span>
165
  </span>
@@ -167,9 +167,9 @@ class BWGViewAlbum_extended_preview extends BWGViewSite {
167
  }
168
  else {
169
  ?>
170
- <span class="bwg_description_spun1_<?php echo $bwg; ?>">
171
- <span class="bwg_description_short_<?php echo $bwg; ?>">
172
- <?php echo $row->description; ?>
173
  </span>
174
  </span>
175
  <?php
@@ -191,7 +191,7 @@ class BWGViewAlbum_extended_preview extends BWGViewSite {
191
  }
192
  }
193
  ?>
194
- <input type="hidden" id="bwg_album_breadcrumb_<?php echo $bwg; ?>" name="bwg_album_breadcrumb_<?php echo $bwg; ?>" value='<?php echo esc_attr($breadcrumb); ?>' />
195
  <?php
196
 
197
  $content = ob_get_clean();
62
  wp_add_inline_style('bwg_frontend', $inline_style);
63
  }
64
  else {
65
+ echo '<style id="bwg-style-' . sanitize_html_class($bwg) . '">' . $inline_style . '</style>';
66
  }
67
  }
68
  }
69
  else {
70
+ echo '<style id="bwg-style-' . sanitize_html_class($bwg) . '">' . $inline_style . '</style>';
71
  }
72
 
73
  ob_start();
74
 
75
  if ( $params['album_view_type'] != 'gallery' ) {
76
  ?>
77
+ <div data-max-count="<?php echo esc_attr($params['extended_album_column_number']); ?>"
78
+ data-thumbnail-width="<?php echo esc_attr($params['extended_album_thumb_width']); ?>"
79
+ data-global-spacing="<?php echo esc_attr($theme_row->album_extended_div_margin); ?>"
80
+ data-spacing="<?php echo esc_attr($theme_row->album_extended_div_padding); ?>"
81
+ data-bwg="<?php echo esc_attr($bwg); ?>"
82
+ id="<?php echo sanitize_html_class($params['container_id']); ?>"
83
+ class="bwg-album-extended bwg-border-box bwg-thumbnails bwg-container bwg-container-<?php echo sanitize_html_class($bwg); ?> bwg-album-thumbnails bwg_album_extended_thumbnails_<?php echo sanitize_html_class($bwg); ?>">
84
  <?php
85
  if ( !$params['album_gallery_rows']['page_nav']['total'] ) {
86
  echo WDWLibrary::message(__('No results found.', BWG()->prefix), 'wd_error');
105
  ?>
106
  <div class="bwg-extended-item">
107
  <div class="bwg-extended-item0">
108
+ <a class="bwg-a bwg-album bwg_album_<?php echo sanitize_html_class($bwg); ?>"
109
  <?php echo ( ($enable_seo || $enable_dynamic_url ) ? "href='" . esc_url($href) . "'" : ""); ?>
110
  style="font-size: 0;"
111
+ data-bwg="<?php echo esc_attr($bwg); ?>"
112
+ data-container_id="<?php echo esc_attr($params['container_id']); ?>"
113
+ data-alb_gal_id="<?php echo (($params['album_gallery_id'] != 0) ? esc_attr($row->alb_gal_id) : esc_attr($row->id)); ?>"
114
+ data-def_type="<?php echo esc_attr($row->def_type); ?>"
115
  data-title="<?php echo htmlspecialchars(addslashes($row->name)); ?>">
116
+ <div class="bwg-item0 bwg_album_thumb_<?php echo sanitize_html_class($bwg); ?> <?php echo ($lazyload) ? 'lazy_loader' : ''; ?>">
117
+ <div class="bwg-item1 bwg_album_thumb_spun1_<?php echo sanitize_html_class($bwg); ?>">
118
  <div class="bwg-item2">
119
  <img class="skip-lazy <?php if( $lazyload ) { ?> bwg_lazyload <?php } ?>"
120
+ data-width="<?php echo esc_attr($image_thumb_width); ?>"
121
+ data-height="<?php echo esc_attr($image_thumb_height); ?>"
122
+ data-original="<?php echo esc_url($row->preview_image); ?>"
123
+ src="<?php if( !$lazyload ) { echo esc_url($row->preview_image); } else { echo esc_url(BWG()->plugin_url."/images/lazy_placeholder.gif"); } ?>"
124
+ alt="<?php echo esc_attr($row->name); ?>" />
125
  </div>
126
  </div>
127
  </div>
131
  <?php
132
  if ( $row->name ) {
133
  ?>
134
+ <a class="bwg-album bwg_album_<?php echo sanitize_html_class($bwg); ?>"
135
  <?php echo ( ($enable_seo || $enable_dynamic_url) ? "href='" . esc_url($href) . "'" : "" ); ?>
136
+ data-bwg="<?php echo esc_attr($bwg); ?>"
137
+ data-container_id="<?php echo esc_attr($params['container_id']); ?>"
138
+ data-alb_gal_id="<?php echo(($params['album_gallery_id'] != 0) ? esc_attr($row->alb_gal_id) : esc_attr($row->id)); ?>"
139
+ data-def_type="<?php echo esc_attr($row->def_type); ?>"
140
  data-title="<?php echo htmlspecialchars(addslashes($row->name)); ?>">
141
+ <span class="bwg_title_spun_<?php echo sanitize_html_class($bwg); ?>"><?php echo esc_html($row->name); ?></span>
142
  </a>
143
  <?php
144
  }
148
  $description_short = $description_array[0];
149
  $description_full = $description_array[1];
150
  ?>
151
+ <span class="bwg_description_spun1_<?php echo sanitize_html_class($bwg); ?>">
152
+ <span class="bwg_description_spun2_<?php echo sanitize_html_class($bwg); ?>">
153
+ <span class="bwg_description_short_<?php echo sanitize_html_class($bwg); ?>">
154
+ <?php echo esc_html($description_short); ?>
155
  </span>
156
  <span class="bwg_description_full">
157
+ <?php echo esc_html($description_full); ?>
158
  </span>
159
  </span>
160
  <span data-more-msg="<?php _e('More', BWG()->prefix); ?>"
161
  data-hide-msg="<?php _e('Hide', BWG()->prefix); ?>"
162
+ class="bwg_description_more bwg_description_more_<?php echo sanitize_html_class($bwg); ?> bwg_more">
163
  <?php _e('More', BWG()->prefix); ?>
164
  </span>
165
  </span>
167
  }
168
  else {
169
  ?>
170
+ <span class="bwg_description_spun1_<?php echo sanitize_html_class($bwg); ?>">
171
+ <span class="bwg_description_short_<?php echo sanitize_html_class($bwg); ?>">
172
+ <?php echo esc_html($row->description); ?>
173
  </span>
174
  </span>
175
  <?php
191
  }
192
  }
193
  ?>
194
+ <input type="hidden" id="bwg_album_breadcrumb_<?php echo sanitize_html_class($bwg); ?>" name="bwg_album_breadcrumb_<?php echo esc_attr($bwg); ?>" value='<?php echo esc_attr($breadcrumb); ?>' />
195
  <?php
196
 
197
  $content = ob_get_clean();
frontend/views/BWGViewGalleryBox.php CHANGED
@@ -28,7 +28,6 @@ class BWGViewGalleryBox {
28
  $params['sort_by'] = WDWLibrary::esc_script('get', 'sort_by', 'RAND()');
29
  $params['order_by'] = WDWLibrary::esc_script('get', 'order_by', 'asc');
30
  $params['watermark_position'] = explode('-', $params['watermark_position']);
31
-
32
  if ( !BWG()->is_pro ) {
33
  $params['popup_enable_filmstrip'] = FALSE;
34
  $params['open_comment'] = FALSE;
@@ -70,7 +69,7 @@ class BWGViewGalleryBox {
70
  $image_filmstrip_height = round($thumb_ratio * $image_filmstrip_width);
71
  }
72
  }
73
- $image_rows = $this->model->get_image_rows_data($gallery_id, $bwg, $params['sort_by'], $params['order_by'], $tag);
74
  $image_id = WDWLibrary::get('image_id', $current_image_id, 'intval', 'POST');
75
  $pricelist_id = 0;
76
  if ( BWG()->is_pro && function_exists('BWGEC') && $params['popup_enable_ecommerce'] == 1 ) {
@@ -104,7 +103,6 @@ class BWGViewGalleryBox {
104
  }
105
 
106
  $popup_url = add_query_arg(array($params_array), admin_url('admin-ajax.php'));
107
-
108
  $filmstrip_thumb_margin = trim($theme_row->lightbox_filmstrip_thumb_margin);
109
 
110
  $margins_split = explode(" ", $filmstrip_thumb_margin);
@@ -574,7 +572,7 @@ class BWGViewGalleryBox {
574
  foreach ($image_rows as $key => $image_row) {
575
  if ($image_row->id == $image_id) {
576
  $current_avg_rating = $image_row->avg_rating;
577
- $current_rate = $image_row->rate;
578
  $current_rate_count = $image_row->rate_count;
579
  $current_image_key = $key;
580
  }
@@ -620,7 +618,7 @@ class BWGViewGalleryBox {
620
  $data[$key]["filetype"] = $image_row->filetype;
621
  $data[$key]["filename"] = $image_row->filename;
622
  $data[$key]["avg_rating"] = $image_row->avg_rating;
623
- $data[$key]["rate"] = $image_row->rate;
624
  $data[$key]["rate_count"] = $image_row->rate_count;
625
  $data[$key]["hit_count"] = $image_row->hit_count;
626
  if ( BWG()->is_pro && function_exists('BWGEC') ) {
@@ -640,10 +638,10 @@ class BWGViewGalleryBox {
640
  $current_pos = 0;
641
  if ( $params['popup_enable_filmstrip'] ) {
642
  ?>
643
- <div class="bwg_filmstrip_container" data-direction="<?php echo $filmstrip_direction; ?>">
644
  <div class="bwg_filmstrip_left"><i class="<?php echo ($filmstrip_direction == 'horizontal'? 'bwg-icon-angle-left-sm' : 'bwg-icon-angle-up-sm'); ?> "></i></div>
645
  <div class="bwg_filmstrip">
646
- <div class="bwg_filmstrip_thumbnails" data-all-images-right-left-space="<?php echo $all_images_right_left_space; ?>" data-all-images-top-bottom-space="<?php echo $all_images_top_bottom_space; ?>">
647
  <?php
648
  foreach ($image_rows as $key => $image_row) {
649
  if ($image_row->id == $current_image_id) {
@@ -702,16 +700,16 @@ class BWGViewGalleryBox {
702
  $thumb_left = ($_image_filmstrip_width - $image_thumb_width) / 2;
703
  $thumb_top = ($_image_filmstrip_height - $image_thumb_height) / 2;
704
  ?>
705
- <div id="bwg_filmstrip_thumbnail_<?php echo $key; ?>" class="bwg_filmstrip_thumbnail <?php echo (($image_row->id == $current_image_id) ? 'bwg_thumb_active' : 'bwg_thumb_deactive'); ?>">
706
  <div class="bwg_filmstrip_thumbnail_img_wrap">
707
  <img <?php if( $is_embed || $resolution_thumb ) { ?>
708
  style="width:<?php echo $image_thumb_width; ?>px; height:<?php echo $image_thumb_height; ?>px; margin-left: <?php echo $thumb_left; ?>px; margin-top: <?php echo $thumb_top; ?>px;" <?php } ?>
709
  class="bwg_filmstrip_thumbnail_img bwg-hidden"
710
- data-url="<?php echo ($is_embed ? "" : BWG()->upload_url) . urldecode($image_row->thumb_url); ?>"
711
  src=""
712
  onclick='bwg_change_image(parseInt(jQuery("#bwg_current_image_key").val()), "<?php echo $key; ?>")' ontouchend='bwg_change_image(parseInt(jQuery("#bwg_current_image_key").val()), "<?php echo $key; ?>")'
713
- image_id="<?php echo $image_row->id; ?>"
714
- image_key="<?php echo $key; ?>" alt="<?php echo $image_row->alt; ?>" />
715
  </div>
716
  </div>
717
  <?php
@@ -734,7 +732,7 @@ class BWGViewGalleryBox {
734
  if ($params['watermark_type'] == 'image') {
735
  ?>
736
  <a class="bwg-a" href="<?php echo esc_js($params['watermark_link']); ?>" target="_blank">
737
- <img class="bwg_watermark_image bwg_watermark" src="<?php echo $params['watermark_url']; ?>" />
738
  </a>
739
  <?php
740
  }
@@ -765,7 +763,7 @@ class BWGViewGalleryBox {
765
  if ($params['show_image_counts']) {
766
  ?>
767
  <span class="bwg_image_count_container bwg_ctrl_btn">
768
- <span class="bwg_image_count"><?php echo $current_image_key + 1; ?></span> /
769
  <span><?php echo count($image_rows); ?></span>
770
  </span>
771
  <?php
@@ -878,29 +876,33 @@ class BWGViewGalleryBox {
878
  </div>
879
  </div>
880
  <?php
881
- $data_rated = array(
882
- 'current_rate' => $current_rate,
883
- 'current_rate_count' => $current_rate_count,
884
- 'current_avg_rating' => $current_avg_rating,
885
- 'current_image_key' => $current_image_key,
886
- );
887
- $data_rated = json_encode($data_rated);
888
- ?>
889
- <div class="bwg_image_rate_container1">
890
- <div class="bwg_image_rate_container2">
891
- <span class="bwg_image_rate_spun">
892
- <span class="bwg_image_rate">
893
- <form id="bwg_rate_form" method="post" action="<?php echo $popup_url; ?>">
894
- <span id="bwg_star" class="bwg_star" data-score="<?php echo $current_avg_rating; ?>"></span>
895
- <span id="bwg_rated" data-params='<?php echo $data_rated; ?>' class="bwg_rated"><?php echo __('Rated.', BWG()->prefix); ?></span>
896
- <span id="bwg_hint" class="bwg_hint"></span>
897
- <input id="rate_ajax_task" name="ajax_task" type="hidden" value="" />
898
- <input id="rate_image_id" name="image_id" type="hidden" value="<?php echo $image_id; ?>" />
899
- </form>
 
 
 
900
  </span>
901
- </span>
902
  </div>
903
- </div>
 
904
  <div class="bwg_slide_container">
905
  <div class="bwg_slide_bg">
906
  <div class="bwg_slider">
@@ -914,7 +916,7 @@ class BWGViewGalleryBox {
914
  if ($image_row->id == $current_image_id) {
915
  $current_key = $key;
916
  ?>
917
- <span class="bwg_popup_image_spun" id="bwg_popup_image" image_id="<?php echo $image_row->id; ?>">
918
  <span class="bwg_popup_image_spun1" style="display: <?php echo ( !$is_embed ? 'table' : 'block' ); ?>;">
919
  <span class="bwg_popup_image_spun2" style="display: <?php echo ( !$is_embed ? 'table-cell' : 'block' ); ?>; ">
920
  <?php
@@ -926,8 +928,8 @@ class BWGViewGalleryBox {
926
  }
927
  ?>
928
  <img class="bwg_popup_image bwg_popup_watermark"
929
- src="<?php echo BWG()->upload_url . $image_row->image_url; ?>"
930
- alt="<?php echo $image_row->alt; ?>"/>
931
  <?php
932
  if ( $params['popup_enable_zoom'] ) {
933
  ?>
@@ -971,7 +973,7 @@ class BWGViewGalleryBox {
971
  </span>
972
  <span class="bwg_popup_image_second_spun">
973
  </span>
974
- <input type="hidden" id="bwg_current_image_key" value="<?php echo $key; ?>" />
975
  <?php
976
  break;
977
  }
@@ -980,8 +982,8 @@ class BWGViewGalleryBox {
980
  </div>
981
  </div>
982
  </div>
983
- <a id="spider_popup_left" <?php echo ($params['enable_loop'] == 0 && $current_key == 0) ? 'style="display: none;"' : ''; ?>><span id="spider_popup_left-ico"><span><i class="bwg_prev_btn <?php echo $theme_row->lightbox_rl_btn_style; ?>-left"></i></span></span></a>
984
- <a id="spider_popup_right" <?php echo ($params['enable_loop'] == 0 && $current_key == count($image_rows) - 1) ? 'style="display: none;"' : ''; ?>><span id="spider_popup_right-ico"><span><i class="bwg_next_btn <?php echo $theme_row->lightbox_rl_btn_style; ?>-right"></i></span></span></a>
985
  </div>
986
  </div>
987
  <?php if ( $params['popup_enable_comment'] ) {
@@ -997,18 +999,18 @@ class BWGViewGalleryBox {
997
  </div>
998
  <div class="bwg_comments bwg_popup_sidebar">
999
  <div title="<?php echo __('Hide Comments', BWG()->prefix); ?>" class="bwg_comments_close bwg_popup_sidebar_close">
1000
- <i class="bwg-icon-arrow-<?php echo $theme_row->lightbox_comment_pos; ?> bwg_comments_close_btn bwg_popup_sidebar_close_btn"></i>
1001
  </div>
1002
- <form id="bwg_comment_form" method="post" action="<?php echo $popup_url; ?>">
1003
  <p><label for="bwg_name"><?php echo __('Name', BWG()->prefix); ?> </label></p>
1004
  <p><input class="bwg-validate" type="text" name="bwg_name" id="bwg_name" <?php echo ((get_current_user_id() != 0) ? 'readonly="readonly"' : ''); ?>
1005
- value="<?php echo ((get_current_user_id() != 0) ? get_userdata(get_current_user_id())->display_name : $bwg_name); ?>" />
1006
  </p>
1007
  <p><span class="bwg_comment_error bwg_comment_name_error"></span></p>
1008
  <?php if ($params['popup_enable_email']) { ?>
1009
  <p><label for="bwg_email"><?php echo __('Email', BWG()->prefix); ?> </label></p>
1010
  <p><input class="bwg-validate" type="text" name="bwg_email" id="bwg_email"
1011
- value="<?php echo ((get_current_user_id() != 0) ? get_userdata(get_current_user_id())->user_email : $bwg_email); ?>" /></p>
1012
  <p><span class="bwg_comment_error bwg_comment_email_error"></span></p>
1013
  <?php } ?>
1014
  <p><label for="bwg_comment"><?php echo __('Comment', BWG()->prefix); ?> </label></p>
@@ -1054,10 +1056,10 @@ class BWGViewGalleryBox {
1054
  </p>
1055
  <p class="bwg_comment_waiting_message"><?php _e('Your comment is awaiting moderation', BWG()->prefix); ?></p>
1056
  <input id="ajax_task" name="ajax_task" type="hidden" value="" />
1057
- <input id="image_id"id="image_id" name="image_id" type="hidden" value="<?php echo $image_id; ?>" />
1058
  <input id="comment_id" name="comment_id" type="hidden" value="" />
1059
- <input type="hidden" value="<?php echo $params['comment_moderation'] ?>" id="bwg_comment_moderation">
1060
- <input type="hidden" value="<?php echo ($params['gdpr_compliance']) ? 0 : $params['popup_enable_captcha']; ?>" id="bwg_popup_enable_captcha">
1061
  </form>
1062
  <div id="bwg_added_comments">
1063
  <?php
@@ -1090,13 +1092,13 @@ class BWGViewGalleryBox {
1090
  <p title="<?php echo __('Hide Ecommerce', BWG()->prefix); ?>" class="bwg_ecommerce_close bwg_popup_sidebar_close" >
1091
  <i class="bwg-icon-arrow-<?php echo $theme_row->lightbox_comment_pos; ?> bwg_ecommerce_close_btn bwg_popup_sidebar_close_btn"></i>
1092
  </p>
1093
- <form id="bwg_ecommerce_form" method="post" action="<?php echo $popup_url; ?>">
1094
  <div class="pge_add_to_cart">
1095
  <div>
1096
  <span class="pge_add_to_cart_title"><?php echo (__('Add to cart', BWG()->prefix)); ?></span>
1097
  </div>
1098
  <div>
1099
- <a href="<?php echo get_permalink($options->checkout_page);?>"><?php echo "<span class='products_in_cart'>".$products_in_cart ."</span> ". __('items', BWG()->prefix); ?></a>
1100
  </div>
1101
  </div>
1102
  <div class="bwg_ecommerce_body">
@@ -1125,7 +1127,7 @@ class BWGViewGalleryBox {
1125
  <?php if ($pricelist->price) {
1126
  ?>
1127
  <p>
1128
- <span><?php echo __('Price', BWG()->prefix).': '.$options->currency_sign;?></span>
1129
  <span class="_product_manual_price"><?php echo number_format((float)$pricelist->price,2)?></span>
1130
  </p>
1131
  <?php
@@ -1137,7 +1139,7 @@ class BWGViewGalleryBox {
1137
  <div class="product_manual_desc_div">
1138
  <p>
1139
  <span><?php echo __('Description', BWG()->prefix);?>:</span>
1140
- <span class="product_manual_desc"><?php echo $pricelist->manual_description;?></span>
1141
  </p>
1142
  </div>
1143
  <?php
@@ -1158,43 +1160,43 @@ class BWGViewGalleryBox {
1158
  echo '<div class="parameter_row">';
1159
  switch($parameter["type"]){
1160
  case "1" :
1161
- echo '<div class="image_selected_parameter" data-parameter-id="'.$parameter_id.'" data-parameter-type = "'.$parameter["type"].'">';
1162
- echo $parameter["title"].": <span class='parameter_single'>". $parameter["values"][0]["parameter_value"]."</span>";
1163
  echo '</div>';
1164
  break;
1165
  case "2" :
1166
- echo '<div class="image_selected_parameter" data-parameter-id="'.$parameter_id.'" data-parameter-type = "'.$parameter["type"].'">';
1167
- echo '<label for="parameter_input">'.$parameter["title"].'</label>';
1168
- echo '<input type="text" name="parameter_input'.$parameter_id.'" id="parameter_input" value="'. $parameter["values"][0]["parameter_value"] .'">';
1169
  echo '</div>';
1170
  break;
1171
  case "3" :
1172
- echo '<div class="image_selected_parameter" data-parameter-id="'.$parameter_id.'" data-parameter-type = "'.$parameter["type"].'">';
1173
  echo '<label for="parameter_textarea">'.$parameter["title"].'</label>';
1174
- echo '<textarea name="parameter_textarea'.$parameter_id.'" id="parameter_textarea" >'. $parameter["values"][0]["parameter_value"] .'</textarea>';
1175
  echo '</div>';
1176
  break;
1177
  case "4" :
1178
- echo '<div class="image_selected_parameter" data-parameter-id="'.$parameter_id.'" data-parameter-type = "'.$parameter["type"].'">';
1179
- echo '<label for="parameter_select">'.$parameter["title"].'</label>';
1180
- echo '<select name="parameter_select'.$parameter_id.'" id="parameter_select" onchange="onSelectableParametersChange(this)">';
1181
  echo '<option value="+*0*">-Select-</option>';
1182
  foreach($parameter["values"] as $values){
1183
  $price_addon = $values["parameter_value_price"] == "0" ? "" : ' ('.$values["parameter_value_price_sign"].$options->currency_sign.number_format((float)$values["parameter_value_price"],2).')';
1184
- echo '<option value="'.$values["parameter_value_price_sign"].'*'.$values["parameter_value_price"].'*'.$values["parameter_value"].'">'.$values["parameter_value"].$price_addon.'</option>';
1185
  }
1186
  echo '</select>';
1187
  echo '<input type="hidden" class="already_selected_values">';
1188
  echo '</div>';
1189
  break;
1190
  case "5" :
1191
- echo '<div class="image_selected_parameter" data-parameter-id="'.$parameter_id.'" data-parameter-type = "'.$parameter["type"].'">';
1192
- echo '<label>'.$parameter["title"].'</label>';
1193
  foreach($parameter["values"] as $values){
1194
  $price_addon = $values["parameter_value_price"] == "0" ? "" : ' ('.$values["parameter_value_price_sign"].$options->currency_sign.number_format((float)$values["parameter_value_price"],2).')';
1195
  echo '<div>';
1196
- echo '<input type="radio" name="parameter_radio'.$parameter_id.'" id="parameter_radio'.$i.'" value="'.$values["parameter_value_price_sign"].'*'.$values["parameter_value_price"].'*'.$values["parameter_value"].'" onchange="onSelectableParametersChange(this)">';
1197
- echo '<label for="parameter_radio'.$i.'">'.$values["parameter_value"].$price_addon.'</label>';
1198
  echo '</div>';
1199
  $i++;
1200
  }
@@ -1202,13 +1204,13 @@ class BWGViewGalleryBox {
1202
  echo '</div>';
1203
  break;
1204
  case "6" :
1205
- echo '<div class="image_selected_parameter" data-parameter-id="'.$parameter_id.'" data-parameter-type = "'.$parameter["type"].'">';
1206
- echo '<label>'.$parameter["title"].'</label>';
1207
  foreach($parameter["values"] as $values){
1208
  $price_addon = $values["parameter_value_price"] == "0" ? "" : ' ('.$values["parameter_value_price_sign"].$options->currency_sign.number_format((float)$values["parameter_value_price"],2).')';
1209
  echo '<div>';
1210
- echo '<input type="checkbox" name="parameter_checkbox'.$parameter_id.'" id="parameter_checkbox'.$i.'" value="'.$values["parameter_value_price_sign"].'*'.$values["parameter_value_price"].'*'.$values["parameter_value"].'" onchange="onSelectableParametersChange(this)">';
1211
- echo '<label for="parameter_checkbox'.$i.'">'.$values["parameter_value"].$price_addon.'</label>';
1212
  echo '</div>';
1213
  $i++;
1214
  }
@@ -1225,8 +1227,8 @@ class BWGViewGalleryBox {
1225
  </div>
1226
  <?php } ?>
1227
  <p>
1228
- <span><b><?php echo __('Total', BWG()->prefix).': '.$options->currency_sign;?></b></span>
1229
- <b><span class="product_manual_price" data-price="<?php echo $pricelist->price; ?>" data-actual-price="<?php echo $pricelist->price; ?>"><?php echo number_format((float)$pricelist->price,2)?></span></b>
1230
  </p>
1231
  </div>
1232
  </div>
@@ -1246,13 +1248,13 @@ class BWGViewGalleryBox {
1246
  if(empty($download_items) === false){
1247
  foreach($download_items as $download_item){
1248
  ?>
1249
- <tr data-price="<?php echo $download_item->item_price; ?>" data-id="<?php echo $download_item->id; ?>">
1250
- <td><?php echo $download_item->item_name; ?></td>
1251
- <td><?php echo $download_item->item_longest_dimension.'px'; ?></td>
1252
- <td class="item_price"><?php echo $options->currency_sign. number_format((float)$download_item->item_price, 2); ?></td>
1253
  <?php if($options->show_digital_items_count == 0){
1254
  ?>
1255
- <td><input type="checkbox" name="selected_download_item" value="<?php echo $download_item->id; ?>" onchange="changeDownloadsTotal(this);"></td>
1256
  <?php
1257
  }
1258
  else{
@@ -1269,7 +1271,7 @@ class BWGViewGalleryBox {
1269
  </tbody>
1270
  </table>
1271
  <p>
1272
- <span><b><?php echo __('Total', BWG()->prefix).': '.$options->currency_sign;?></b></span>
1273
  <b><span class="product_downloads_price">0</span></b>
1274
  </p>
1275
  </div>
@@ -1282,11 +1284,11 @@ class BWGViewGalleryBox {
1282
  </div>
1283
  <input id="ajax_task" name="ajax_task" type="hidden" value="" />
1284
  <input id="ajax_url" type="hidden" value="<?php echo admin_url('admin-ajax.php'); ?>" />
1285
- <input id="type" name="type" type="hidden" value="<?php echo isset($pricelist_sections[0]) ? $pricelist_sections[0] : "" ?>" />
1286
- <input id="image_id" name="image_id" type="hidden" value="<?php echo $image_id; ?>" />
1287
  <div class="pge_options">
1288
- <input type="hidden" name="option_checkout_page" value="<?php echo get_permalink($options->checkout_page);?>">
1289
- <input type="hidden" name="option_show_digital_items_count" value="<?php echo $options->show_digital_items_count;?>">
1290
  </div>
1291
  </form>
1292
  </div>
@@ -1381,18 +1383,18 @@ class BWGViewGalleryBox {
1381
  public function html_comments_block( $row = array() ) {
1382
  ob_start();
1383
  ?>
1384
- <div id="bwg_comment_block_<?php echo $row->id; ?>" class="bwg_single_comment">
1385
  <p class="bwg_comment_header_p">
1386
- <span class="bwg_comment_header"><?php echo $row->name; ?></span>
1387
  <?php if ( current_user_can('manage_options') ) { ?>
1388
  <i onclick="bwg_remove_comment(<?php echo $row->id; ?>); return false;"
1389
  ontouchend="bwg_remove_comment(<?php echo $row->id; ?>); return false;"
1390
  title="<?php _e('Delete Comment', BWG()->prefix); ?>" class="bwg-icon-times bwg_comment_delete_btn"></i>
1391
  <?php } ?>
1392
- <span class="bwg_comment_date"><?php echo $row->date; ?></span>
1393
  </p>
1394
  <div class="bwg_comment_body_p">
1395
- <span class="bwg_comment_body"><?php echo wpautop($row->comment); ?></span>
1396
  </div>
1397
  </div>
1398
  <?php
28
  $params['sort_by'] = WDWLibrary::esc_script('get', 'sort_by', 'RAND()');
29
  $params['order_by'] = WDWLibrary::esc_script('get', 'order_by', 'asc');
30
  $params['watermark_position'] = explode('-', $params['watermark_position']);
 
31
  if ( !BWG()->is_pro ) {
32
  $params['popup_enable_filmstrip'] = FALSE;
33
  $params['open_comment'] = FALSE;
69
  $image_filmstrip_height = round($thumb_ratio * $image_filmstrip_width);
70
  }
71
  }
72
+ $image_rows = $this->model->get_image_rows_data($gallery_id, $bwg, $params['sort_by'], $params['order_by'], $tag, $params['popup_enable_rate']);
73
  $image_id = WDWLibrary::get('image_id', $current_image_id, 'intval', 'POST');
74
  $pricelist_id = 0;
75
  if ( BWG()->is_pro && function_exists('BWGEC') && $params['popup_enable_ecommerce'] == 1 ) {
103
  }
104
 
105
  $popup_url = add_query_arg(array($params_array), admin_url('admin-ajax.php'));
 
106
  $filmstrip_thumb_margin = trim($theme_row->lightbox_filmstrip_thumb_margin);
107
 
108
  $margins_split = explode(" ", $filmstrip_thumb_margin);
572
  foreach ($image_rows as $key => $image_row) {
573
  if ($image_row->id == $image_id) {
574
  $current_avg_rating = $image_row->avg_rating;
575
+ $current_rate = isset($image_row->rate) ? $image_row->rate : 0;
576
  $current_rate_count = $image_row->rate_count;
577
  $current_image_key = $key;
578
  }
618
  $data[$key]["filetype"] = $image_row->filetype;
619
  $data[$key]["filename"] = $image_row->filename;
620
  $data[$key]["avg_rating"] = $image_row->avg_rating;
621
+ $data[$key]["rate"] = isset($image_row->rate) ? $image_row->rate : 0;
622
  $data[$key]["rate_count"] = $image_row->rate_count;
623
  $data[$key]["hit_count"] = $image_row->hit_count;
624
  if ( BWG()->is_pro && function_exists('BWGEC') ) {
638
  $current_pos = 0;
639
  if ( $params['popup_enable_filmstrip'] ) {
640
  ?>
641
+ <div class="bwg_filmstrip_container" data-direction="<?php echo esc_attr($filmstrip_direction); ?>">
642
  <div class="bwg_filmstrip_left"><i class="<?php echo ($filmstrip_direction == 'horizontal'? 'bwg-icon-angle-left-sm' : 'bwg-icon-angle-up-sm'); ?> "></i></div>
643
  <div class="bwg_filmstrip">
644
+ <div class="bwg_filmstrip_thumbnails" data-all-images-right-left-space="<?php echo esc_attr($all_images_right_left_space); ?>" data-all-images-top-bottom-space="<?php echo esc_attr($all_images_top_bottom_space); ?>">
645
  <?php
646
  foreach ($image_rows as $key => $image_row) {
647
  if ($image_row->id == $current_image_id) {
700
  $thumb_left = ($_image_filmstrip_width - $image_thumb_width) / 2;
701
  $thumb_top = ($_image_filmstrip_height - $image_thumb_height) / 2;
702
  ?>
703
+ <div id="bwg_filmstrip_thumbnail_<?php echo sanitize_html_class($key); ?>" class="bwg_filmstrip_thumbnail <?php echo (($image_row->id == $current_image_id) ? 'bwg_thumb_active' : 'bwg_thumb_deactive'); ?>">
704
  <div class="bwg_filmstrip_thumbnail_img_wrap">
705
  <img <?php if( $is_embed || $resolution_thumb ) { ?>
706
  style="width:<?php echo $image_thumb_width; ?>px; height:<?php echo $image_thumb_height; ?>px; margin-left: <?php echo $thumb_left; ?>px; margin-top: <?php echo $thumb_top; ?>px;" <?php } ?>
707
  class="bwg_filmstrip_thumbnail_img bwg-hidden"
708
+ data-url="<?php echo ($is_embed ? "" : esc_url(BWG()->upload_url) . urldecode($image_row->thumb_url)); ?>"
709
  src=""
710
  onclick='bwg_change_image(parseInt(jQuery("#bwg_current_image_key").val()), "<?php echo $key; ?>")' ontouchend='bwg_change_image(parseInt(jQuery("#bwg_current_image_key").val()), "<?php echo $key; ?>")'
711
+ image_id="<?php echo esc_attr($image_row->id); ?>"
712
+ image_key="<?php echo esc_attr($key); ?>" alt="<?php echo esc_attr($image_row->alt); ?>" />
713
  </div>
714
  </div>
715
  <?php
732
  if ($params['watermark_type'] == 'image') {
733
  ?>
734
  <a class="bwg-a" href="<?php echo esc_js($params['watermark_link']); ?>" target="_blank">
735
+ <img class="bwg_watermark_image bwg_watermark" src="<?php echo esc_url($params['watermark_url']); ?>" />
736
  </a>
737
  <?php
738
  }
763
  if ($params['show_image_counts']) {
764
  ?>
765
  <span class="bwg_image_count_container bwg_ctrl_btn">
766
+ <span class="bwg_image_count"><?php echo intval($current_image_key) + 1; ?></span> /
767
  <span><?php echo count($image_rows); ?></span>
768
  </span>
769
  <?php
876
  </div>
877
  </div>
878
  <?php
879
+ if ( $params['popup_enable_rate'] ) {
880
+ $data_rated = array(
881
+ 'current_rate' => $current_rate,
882
+ 'current_rate_count' => $current_rate_count,
883
+ 'current_avg_rating' => $current_avg_rating,
884
+ 'current_image_key' => $current_image_key,
885
+ );
886
+ $data_rated = json_encode($data_rated);
887
+ ?>
888
+ <div class="bwg_image_rate_container1">
889
+ <div class="bwg_image_rate_container2">
890
+ <span class="bwg_image_rate_spun">
891
+ <span class="bwg_image_rate">
892
+ <span class="bwg_image_rate_disabled"></span>
893
+ <form id="bwg_rate_form" method="post" action="<?php echo $popup_url; ?>">
894
+ <span id="bwg_star" class="bwg_star" data-score="<?php echo $current_avg_rating; ?>"></span>
895
+ <span id="bwg_rated" data-params='<?php echo $data_rated; ?>' class="bwg_rated"><?php echo __('Rated.', BWG()->prefix); ?></span>
896
+ <span id="bwg_hint" class="bwg_hint"></span>
897
+ <input id="rate_ajax_task" name="ajax_task" type="hidden" value="" />
898
+ <input id="rate_image_id" name="image_id" type="hidden" value="<?php echo $image_id; ?>" />
899
+ </form>
900
+ </span>
901
  </span>
902
+ </div>
903
  </div>
904
+ <?php
905
+ } ?>
906
  <div class="bwg_slide_container">
907
  <div class="bwg_slide_bg">
908
  <div class="bwg_slider">
916
  if ($image_row->id == $current_image_id) {
917
  $current_key = $key;
918
  ?>
919
+ <span class="bwg_popup_image_spun" id="bwg_popup_image" image_id="<?php echo esc_attr($image_row->id); ?>">
920
  <span class="bwg_popup_image_spun1" style="display: <?php echo ( !$is_embed ? 'table' : 'block' ); ?>;">
921
  <span class="bwg_popup_image_spun2" style="display: <?php echo ( !$is_embed ? 'table-cell' : 'block' ); ?>; ">
922
  <?php
928
  }
929
  ?>
930
  <img class="bwg_popup_image bwg_popup_watermark"
931
+ src="<?php echo esc_url(BWG()->upload_url . $image_row->image_url); ?>"
932
+ alt="<?php echo esc_attr($image_row->alt); ?>"/>
933
  <?php
934
  if ( $params['popup_enable_zoom'] ) {
935
  ?>
973
  </span>
974
  <span class="bwg_popup_image_second_spun">
975
  </span>
976
+ <input type="hidden" id="bwg_current_image_key" value="<?php echo esc_attr($key); ?>" />
977
  <?php
978
  break;
979
  }
982
  </div>
983
  </div>
984
  </div>
985
+ <a id="spider_popup_left" <?php echo ($params['enable_loop'] == 0 && $current_key == 0) ? 'style="display: none;"' : ''; ?>><span id="spider_popup_left-ico"><span><i class="bwg_prev_btn <?php echo sanitize_html_class($theme_row->lightbox_rl_btn_style); ?>-left"></i></span></span></a>
986
+ <a id="spider_popup_right" <?php echo ($params['enable_loop'] == 0 && $current_key == count($image_rows) - 1) ? 'style="display: none;"' : ''; ?>><span id="spider_popup_right-ico"><span><i class="bwg_next_btn <?php echo sanitize_html_class($theme_row->lightbox_rl_btn_style); ?>-right"></i></span></span></a>
987
  </div>
988
  </div>
989
  <?php if ( $params['popup_enable_comment'] ) {
999
  </div>
1000
  <div class="bwg_comments bwg_popup_sidebar">
1001
  <div title="<?php echo __('Hide Comments', BWG()->prefix); ?>" class="bwg_comments_close bwg_popup_sidebar_close">
1002
+ <i class="bwg-icon-arrow-<?php echo sanitize_html_class($theme_row->lightbox_comment_pos); ?> bwg_comments_close_btn bwg_popup_sidebar_close_btn"></i>
1003
  </div>
1004
+ <form id="bwg_comment_form" method="post" action="<?php echo esc_url($popup_url); ?>">
1005
  <p><label for="bwg_name"><?php echo __('Name', BWG()->prefix); ?> </label></p>
1006
  <p><input class="bwg-validate" type="text" name="bwg_name" id="bwg_name" <?php echo ((get_current_user_id() != 0) ? 'readonly="readonly"' : ''); ?>
1007
+ value="<?php echo ((get_current_user_id() != 0) ? esc_attr(get_userdata(get_current_user_id())->display_name) : esc_attr($bwg_name)); ?>" />
1008
  </p>
1009
  <p><span class="bwg_comment_error bwg_comment_name_error"></span></p>
1010
  <?php if ($params['popup_enable_email']) { ?>
1011
  <p><label for="bwg_email"><?php echo __('Email', BWG()->prefix); ?> </label></p>
1012
  <p><input class="bwg-validate" type="text" name="bwg_email" id="bwg_email"
1013
+ value="<?php echo ((get_current_user_id() != 0) ? esc_attr(get_userdata(get_current_user_id())->user_email) : esc_attr($bwg_email)); ?>" /></p>
1014
  <p><span class="bwg_comment_error bwg_comment_email_error"></span></p>
1015
  <?php } ?>
1016
  <p><label for="bwg_comment"><?php echo __('Comment', BWG()->prefix); ?> </label></p>
1056
  </p>
1057
  <p class="bwg_comment_waiting_message"><?php _e('Your comment is awaiting moderation', BWG()->prefix); ?></p>
1058
  <input id="ajax_task" name="ajax_task" type="hidden" value="" />
1059
+ <input id="image_id"id="image_id" name="image_id" type="hidden" value="<?php echo esc_attr($image_id); ?>" />
1060
  <input id="comment_id" name="comment_id" type="hidden" value="" />
1061
+ <input type="hidden" value="<?php echo esc_attr($params['comment_moderation']) ?>" id="bwg_comment_moderation">
1062
+ <input type="hidden" value="<?php echo ($params['gdpr_compliance']) ? 0 : esc_attr($params['popup_enable_captcha']); ?>" id="bwg_popup_enable_captcha">
1063
  </form>
1064
  <div id="bwg_added_comments">
1065
  <?php
1092
  <p title="<?php echo __('Hide Ecommerce', BWG()->prefix); ?>" class="bwg_ecommerce_close bwg_popup_sidebar_close" >
1093
  <i class="bwg-icon-arrow-<?php echo $theme_row->lightbox_comment_pos; ?> bwg_ecommerce_close_btn bwg_popup_sidebar_close_btn"></i>
1094
  </p>
1095
+ <form id="bwg_ecommerce_form" method="post" action="<?php echo esc_url($popup_url); ?>">
1096
  <div class="pge_add_to_cart">
1097
  <div>
1098
  <span class="pge_add_to_cart_title"><?php echo (__('Add to cart', BWG()->prefix)); ?></span>
1099
  </div>
1100
  <div>
1101
+ <a href="<?php echo esc_url(get_permalink($options->checkout_page));?>"><?php echo "<span class='products_in_cart'>".esc_html($products_in_cart) ."</span> ". __('items', BWG()->prefix); ?></a>
1102
  </div>
1103
  </div>
1104
  <div class="bwg_ecommerce_body">
1127
  <?php if ($pricelist->price) {
1128
  ?>
1129
  <p>
1130
+ <span><?php echo __('Price', BWG()->prefix).': '.esc_html($options->currency_sign);?></span>
1131
  <span class="_product_manual_price"><?php echo number_format((float)$pricelist->price,2)?></span>
1132
  </p>
1133
  <?php
1139
  <div class="product_manual_desc_div">
1140
  <p>
1141
  <span><?php echo __('Description', BWG()->prefix);?>:</span>
1142
+ <span class="product_manual_desc"><?php echo esc_html($pricelist->manual_description);?></span>
1143
  </p>
1144
  </div>
1145
  <?php
1160
  echo '<div class="parameter_row">';
1161
  switch($parameter["type"]){
1162
  case "1" :
1163
+ echo '<div class="image_selected_parameter" data-parameter-id="'.esc_attr($parameter_id).'" data-parameter-type = "'.esc_attr($parameter["type"]).'">';
1164
+ echo $parameter["title"].": <span class='parameter_single'>". esc_html($parameter["values"][0]["parameter_value"])."</span>";
1165
  echo '</div>';
1166
  break;
1167
  case "2" :
1168
+ echo '<div class="image_selected_parameter" data-parameter-id="'.esc_attr($parameter_id).'" data-parameter-type = "'.esc_attr($parameter["type"]).'">';
1169
+ echo '<label for="parameter_input">'.esc_html($parameter["title"]).'</label>';
1170
+ echo '<input type="text" name="parameter_input'.esc_attr($parameter_id).'" id="parameter_input" value="'. esc_attr($parameter["values"][0]["parameter_value"]) .'">';
1171
  echo '</div>';
1172
  break;
1173
  case "3" :
1174
+ echo '<div class="image_selected_parameter" data-parameter-id="'.esc_attr($parameter_id).'" data-parameter-type = "'.esc_attr($parameter["type"]).'">';
1175
  echo '<label for="parameter_textarea">'.$parameter["title"].'</label>';
1176
+ echo '<textarea name="parameter_textarea'.esc_attr($parameter_id).'" id="parameter_textarea" >'. esc_html($parameter["values"][0]["parameter_value"]) .'</textarea>';
1177
  echo '</div>';
1178
  break;
1179
  case "4" :
1180
+ echo '<div class="image_selected_parameter" data-parameter-id="'.esc_attr($parameter_id).'" data-parameter-type = "'.esc_attr($parameter["type"]).'">';
1181
+ echo '<label for="parameter_select">'.esc_html($parameter["title"]).'</label>';
1182
+ echo '<select name="parameter_select'.esc_attr($parameter_id).'" id="parameter_select" onchange="onSelectableParametersChange(this)">';
1183
  echo '<option value="+*0*">-Select-</option>';
1184
  foreach($parameter["values"] as $values){
1185
  $price_addon = $values["parameter_value_price"] == "0" ? "" : ' ('.$values["parameter_value_price_sign"].$options->currency_sign.number_format((float)$values["parameter_value_price"],2).')';
1186
+ echo '<option value="'.esc_attr($values["parameter_value_price_sign"].'*'.$values["parameter_value_price"].'*'.$values["parameter_value"]).'">'.$values["parameter_value"].$price_addon.'</option>';
1187
  }
1188
  echo '</select>';
1189
  echo '<input type="hidden" class="already_selected_values">';
1190
  echo '</div>';
1191
  break;
1192
  case "5" :
1193
+ echo '<div class="image_selected_parameter" data-parameter-id="'.esc_attr($parameter_id).'" data-parameter-type = "'.esc_attr($parameter["type"]).'">';
1194
+ echo '<label>'.esc_html($parameter["title"]).'</label>';
1195
  foreach($parameter["values"] as $values){
1196
  $price_addon = $values["parameter_value_price"] == "0" ? "" : ' ('.$values["parameter_value_price_sign"].$options->currency_sign.number_format((float)$values["parameter_value_price"],2).')';
1197
  echo '<div>';
1198
+ echo '<input type="radio" name="parameter_radio'.esc_attr($parameter_id).'" id="parameter_radio'.$i.'" value="'.esc_attr($values["parameter_value_price_sign"].'*'.$values["parameter_value_price"].'*'.$values["parameter_value"]).'" onchange="onSelectableParametersChange(this)">';
1199
+ echo '<label for="parameter_radio'.$i.'">'.esc_html($values["parameter_value"].$price_addon).'</label>';
1200
  echo '</div>';
1201
  $i++;
1202
  }
1204
  echo '</div>';
1205
  break;
1206
  case "6" :
1207
+ echo '<div class="image_selected_parameter" data-parameter-id="'.esc_attr($parameter_id).'" data-parameter-type = "'.esc_attr($parameter["type"]).'">';
1208
+ echo '<label>'.esc_html($parameter["title"]).'</label>';
1209
  foreach($parameter["values"] as $values){
1210
  $price_addon = $values["parameter_value_price"] == "0" ? "" : ' ('.$values["parameter_value_price_sign"].$options->currency_sign.number_format((float)$values["parameter_value_price"],2).')';
1211
  echo '<div>';
1212
+ echo '<input type="checkbox" name="parameter_checkbox'.esc_attr($parameter_id).'" id="parameter_checkbox'.$i.'" value="'.esc_attr($values["parameter_value_price_sign"].'*'.$values["parameter_value_price"].'*'.$values["parameter_value"]).'" onchange="onSelectableParametersChange(this)">';
1213
+ echo '<label for="parameter_checkbox'.$i.'">'.esc_html($values["parameter_value"].$price_addon).'</label>';
1214
  echo '</div>';
1215
  $i++;
1216
  }
1227
  </div>
1228
  <?php } ?>
1229
  <p>
1230
+ <span><b><?php echo __('Total', BWG()->prefix).': '.esc_html($options->currency_sign);?></b></span>
1231
+ <b><span class="product_manual_price" data-price="<?php echo esc_attr($pricelist->price); ?>" data-actual-price="<?php echo esc_attr($pricelist->price); ?>"><?php echo number_format((float)$pricelist->price,2)?></span></b>
1232
  </p>
1233
  </div>
1234
  </div>
1248
  if(empty($download_items) === false){
1249
  foreach($download_items as $download_item){
1250
  ?>
1251
+ <tr data-price="<?php echo esc_attr($download_item->item_price); ?>" data-id="<?php echo esc_attr($download_item->id); ?>">
1252
+ <td><?php echo esc_html($download_item->item_name); ?></td>
1253
+ <td><?php echo esc_html($download_item->item_longest_dimension.'px'); ?></td>
1254
+ <td class="item_price"><?php echo esc_html($options->currency_sign. number_format((float)$download_item->item_price, 2)); ?></td>
1255
  <?php if($options->show_digital_items_count == 0){
1256
  ?>
1257
+ <td><input type="checkbox" name="selected_download_item" value="<?php echo esc_attr($download_item->id); ?>" onchange="changeDownloadsTotal(this);"></td>
1258
  <?php
1259
  }
1260
  else{
1271
  </tbody>
1272
  </table>
1273
  <p>
1274
+ <span><b><?php echo __('Total', BWG()->prefix).': '.esc_html($options->currency_sign);?></b></span>
1275
  <b><span class="product_downloads_price">0</span></b>
1276
  </p>
1277
  </div>
1284
  </div>
1285
  <input id="ajax_task" name="ajax_task" type="hidden" value="" />
1286
  <input id="ajax_url" type="hidden" value="<?php echo admin_url('admin-ajax.php'); ?>" />
1287
+ <input id="type" name="type" type="hidden" value="<?php echo isset($pricelist_sections[0]) ? esc_attr($pricelist_sections[0]) : "" ?>" />
1288
+ <input id="image_id" name="image_id" type="hidden" value="<?php echo esc_attr($image_id); ?>" />
1289
  <div class="pge_options">
1290
+ <input type="hidden" name="option_checkout_page" value="<?php echo esc_attr(get_permalink($options->checkout_page));?>">
1291
+ <input type="hidden" name="option_show_digital_items_count" value="<?php echo esc_attr($options->show_digital_items_count);?>">
1292
  </div>
1293
  </form>
1294
  </div>
1383
  public function html_comments_block( $row = array() ) {
1384
  ob_start();
1385
  ?>
1386
+ <div id="bwg_comment_block_<?php echo sanitize_html_class($row->id); ?>" class="bwg_single_comment">
1387
  <p class="bwg_comment_header_p">
1388
+ <span class="bwg_comment_header"><?php echo esc_html($row->name); ?></span>
1389
  <?php if ( current_user_can('manage_options') ) { ?>
1390
  <i onclick="bwg_remove_comment(<?php echo $row->id; ?>); return false;"
1391
  ontouchend="bwg_remove_comment(<?php echo $row->id; ?>); return false;"
1392
  title="<?php _e('Delete Comment', BWG()->prefix); ?>" class="bwg-icon-times bwg_comment_delete_btn"></i>
1393
  <?php } ?>
1394
+ <span class="bwg_comment_date"><?php echo esc_html($row->date); ?></span>
1395
  </p>
1396
  <div class="bwg_comment_body_p">
1397
+ <span class="bwg_comment_body"><?php echo html_entity_decode(wpautop($row->comment)); ?></span>
1398
  </div>
1399
  </div>
1400
  <?php
frontend/views/BWGViewImage_browser.php CHANGED
@@ -34,14 +34,14 @@ class BWGViewImage_browser extends BWGViewSite {
34
  $show_watermark = TRUE;
35
  $params['watermark_width'] = 0;
36
  $watermark_a = 'bwg_watermark_text_' . $bwg;
37
- $watermark_div = 'class="bwg_image_browser_watermark_text_' . $bwg . '"';
38
- $watermark_image_or_text = $params["watermark_text"];
39
  }
40
  elseif ( $params['watermark_type'] == 'image' ) {
41
  $show_watermark = TRUE;
42
- $watermark_image_or_text = '<img class="bwg_image_browser_watermark_img_' . $bwg . '" src="' . urldecode($params['watermark_url']) . '" />';
43
  $watermark_a = '';
44
- $watermark_div = 'class="bwg_image_browser_watermark_' . $bwg . '"';
45
  $params['watermark_font'] = '';
46
  $params['watermark_color'] = '';
47
  $params['watermark_font_size'] = '';
@@ -54,15 +54,15 @@ class BWGViewImage_browser extends BWGViewSite {
54
  wp_add_inline_style('bwg_frontend', $inline_style);
55
  }
56
  else {
57
- echo '<style id="bwg-style-' . $bwg . '">' . $inline_style . '</style>';
58
  }
59
  }
60
  else {
61
- echo '<style id="bwg-style-' . $bwg . '">' . $inline_style . '</style>';
62
  }
63
  }
64
  else {
65
- echo '<style id="bwg-style-' . $bwg . '">' . $inline_style . '</style>';
66
  }
67
  $bwg_param = array(
68
  'is_pro' => BWG()->is_pro,
@@ -72,11 +72,11 @@ class BWGViewImage_browser extends BWGViewSite {
72
  $bwg_params = json_encode($bwg_param);
73
  ob_start();
74
  ?>
75
- <div id="bwg_<?php echo $params['gallery_type'] . '_' . $bwg ?>" class="image_browser_images_conteiner_<?php echo $bwg; ?> bwg-image_browser-images-wrapper bwg-container"
76
- data-params='<?php echo $bwg_params ?>'
77
- data-bwg="<?php echo $bwg; ?>"
78
- data-lightbox-url="<?php echo addslashes(add_query_arg($params['params_array'], admin_url('admin-ajax.php'))); ?>">
79
- <div class="image_browser_images_<?php echo $bwg; ?>">
80
  <?php
81
  foreach ( $images as $image_row ) {
82
  $params['image_id'] = WDWLibrary::get('image_id', $image_row->id, 'intval');
@@ -84,28 +84,28 @@ class BWGViewImage_browser extends BWGViewSite {
84
  $is_embed_16x9 = ((preg_match('/EMBED/', $image_row->filetype) == 1 ? TRUE : FALSE) && (preg_match('/VIDEO/', $image_row->filetype) == 1 ? TRUE : FALSE) && !(preg_match('/INSTAGRAM/', $image_row->filetype) == 1 ? TRUE : FALSE));
85
  $is_embed_instagram_post = preg_match('/INSTAGRAM_POST/', $image_row->filetype) == 1 ? TRUE : FALSE;
86
  ?>
87
- <div class="image_browser_image_buttons_conteiner_<?php echo $bwg; ?>">
88
- <div class="image_browser_image_buttons_<?php echo $bwg; ?>">
89
  <?php
90
  if ( $image_title && ($image_browser_image_title_align == 'top') ) {
91
  ?>
92
- <div class="bwg_image_browser_image_alt_<?php echo $bwg; ?>">
93
- <div class="bwg_image_alt_<?php echo $bwg; ?>" id="alt<?php echo $image_row->id; ?>">
94
  <?php echo html_entity_decode($image_row->alt); ?>
95
  </div>
96
  </div>
97
  <?php
98
  }
99
  ?>
100
- <div class="bwg_image_browser_image_<?php echo $bwg; ?>">
101
  <?php
102
  if ( $show_watermark ) {
103
  ?>
104
- <div class="bwg_image_browser_image_contain_<?php echo $bwg; ?>" id="bwg_image_browser_image_contain_<?php echo $image_row->id ?>">
105
- <div class="bwg_image_browser_watermark_contain_<?php echo $bwg; ?>">
106
- <div class="bwg_image_browser_watermark_cont_<?php echo $bwg; ?>">
107
  <div <?php echo $watermark_div; ?> >
108
- <a class="bwg_none_selectable <?php echo $watermark_a; ?>" id="watermark_a<?php echo $image_row->id; ?>" href="<?php echo urldecode($params['watermark_link']); ?>" target="_blank">
109
  <?php echo $watermark_image_or_text; ?>
110
  </a>
111
  </div>
@@ -116,11 +116,11 @@ class BWGViewImage_browser extends BWGViewSite {
116
  }
117
  if ( !$is_embed ) {
118
  ?>
119
- <a style="position:relative;" <?php echo($params['thumb_click_action'] == 'open_lightbox' ? (' class="bwg-a bwg_lightbox" data-image-id="' . $image_row->id . '" data-elementor-open-lightbox="no"') : ('class="bwg-a" ' . ($params['thumb_click_action'] == 'redirect_to_url' && $image_row->redirect_url ? 'href="' . $image_row->redirect_url . '" target="' . ($params['thumb_link_target'] ? '_blank' : '') . '"' : ''))) ?>>
120
- <img class="skip-lazy bwg-item0 bwg_image_browser_img bwg_image_browser_img_<?php echo $bwg; ?> <?php if( $lazyload ) { ?> bwg_lazyload lazy_loader<?php } ?>"
121
- src="<?php if( !$lazyload ) { echo BWG()->upload_url . $image_row->image_url; } else { echo BWG()->plugin_url."/images/lazy_placeholder.gif"; } ?>"
122
- data-original="<?php echo BWG()->upload_url . $image_row->image_url; ?>"
123
- alt="<?php echo $image_row->alt; ?>" />
124
  </a>
125
  <?php
126
  }
@@ -156,7 +156,7 @@ class BWGViewImage_browser extends BWGViewSite {
156
  }
157
  else {/*for instagram image, video and flickr enable lightbox onclick*/
158
  ?>
159
- <a style="position:relative;" <?php echo($params['thumb_click_action'] == 'open_lightbox' ? (' class="bwg_lightbox bwg_lightbox_' . $bwg . '" data-image-id="' . $image_row->id . '"') : ($image_row->redirect_url ? 'href="' . $image_row->redirect_url . '" target="' . ($params['thumb_link_target'] ? '_blank' : '') . '"' : '')) ?>>
160
  <?php
161
  WDWLibraryEmbed::display_embed($image_row->filetype, $image_row->image_url, $image_row->filename, array(
162
  'id' => "bwg_embed_frame_" . $bwg,
@@ -178,8 +178,8 @@ class BWGViewImage_browser extends BWGViewSite {
178
  <?php
179
  if ( $image_title && ($image_browser_image_title_align == 'bottom') ) {
180
  ?>
181
- <div class="bwg_image_browser_image_alt_<?php echo $bwg; ?>">
182
- <div class="bwg_image_alt_<?php echo $bwg; ?>" id="alt<?php echo $image_row->id; ?>">
183
  <?php echo html_entity_decode($image_row->alt); ?>
184
  </div>
185
  </div>
@@ -187,8 +187,8 @@ class BWGViewImage_browser extends BWGViewSite {
187
  }
188
  if ( $enable_image_description && ($image_row->description != "") ) {
189
  ?>
190
- <div class="bwg_image_browser_image_desp_<?php echo $bwg; ?>">
191
- <div class="bwg_image_browser_image_description_<?php echo $bwg; ?>" id="alt<?php echo $image_row->id; ?>">
192
  <?php echo html_entity_decode($image_row->description); ?>
193
  </div>
194
  </div>
34
  $show_watermark = TRUE;
35
  $params['watermark_width'] = 0;
36
  $watermark_a = 'bwg_watermark_text_' . $bwg;
37
+ $watermark_div = 'class="bwg_image_browser_watermark_text_' . sanitize_html_class($bwg) . '"';
38
+ $watermark_image_or_text = esc_html($params["watermark_text"]);
39
  }
40
  elseif ( $params['watermark_type'] == 'image' ) {
41
  $show_watermark = TRUE;
42
+ $watermark_image_or_text = '<img class="bwg_image_browser_watermark_img_' . sanitize_html_class($bwg) . '" src="' . urldecode($params['watermark_url']) . '" />';
43
  $watermark_a = '';
44
+ $watermark_div = 'class="bwg_image_browser_watermark_' . sanitize_html_class($bwg) . '"';
45
  $params['watermark_font'] = '';
46
  $params['watermark_color'] = '';
47
  $params['watermark_font_size'] = '';
54
  wp_add_inline_style('bwg_frontend', $inline_style);
55
  }
56
  else {
57
+ echo '<style id="bwg-style-' . sanitize_html_class($bwg) . '">' . $inline_style . '</style>';
58
  }
59
  }
60
  else {
61
+ echo '<style id="bwg-style-' . sanitize_html_class($bwg) . '">' . $inline_style . '</style>';
62
  }
63
  }
64
  else {
65
+ echo '<style id="bwg-style-' . sanitize_html_class($bwg) . '">' . $inline_style . '</style>';
66
  }
67
  $bwg_param = array(
68
  'is_pro' => BWG()->is_pro,
72
  $bwg_params = json_encode($bwg_param);
73
  ob_start();
74
  ?>
75
+ <div id="bwg_<?php echo sanitize_html_class($params['gallery_type'] . '_' . $bwg) ?>" class="image_browser_images_conteiner_<?php echo sanitize_html_class($bwg); ?> bwg-image_browser-images-wrapper bwg-container"
76
+ data-params='<?php echo esc_attr($bwg_params) ?>'
77
+ data-bwg="<?php echo esc_attr($bwg); ?>"
78
+ data-lightbox-url="<?php echo esc_url(addslashes(add_query_arg($params['params_array'], admin_url('admin-ajax.php')))); ?>">
79
+ <div class="image_browser_images_<?php echo sanitize_html_class($bwg); ?>">
80
  <?php
81
  foreach ( $images as $image_row ) {
82
  $params['image_id'] = WDWLibrary::get('image_id', $image_row->id, 'intval');
84
  $is_embed_16x9 = ((preg_match('/EMBED/', $image_row->filetype) == 1 ? TRUE : FALSE) && (preg_match('/VIDEO/', $image_row->filetype) == 1 ? TRUE : FALSE) && !(preg_match('/INSTAGRAM/', $image_row->filetype) == 1 ? TRUE : FALSE));
85
  $is_embed_instagram_post = preg_match('/INSTAGRAM_POST/', $image_row->filetype) == 1 ? TRUE : FALSE;
86
  ?>
87
+ <div class="image_browser_image_buttons_conteiner_<?php echo sanitize_html_class($bwg); ?>">
88
+ <div class="image_browser_image_buttons_<?php echo sanitize_html_class($bwg); ?>">
89
  <?php
90
  if ( $image_title && ($image_browser_image_title_align == 'top') ) {
91
  ?>
92
+ <div class="bwg_image_browser_image_alt_<?php echo sanitize_html_class($bwg); ?>">
93
+ <div class="bwg_image_alt_<?php echo sanitize_html_class($bwg); ?>" id="alt<?php echo sanitize_html_class($image_row->id); ?>">
94
  <?php echo html_entity_decode($image_row->alt); ?>
95
  </div>
96
  </div>
97
  <?php
98
  }
99
  ?>
100
+ <div class="bwg_image_browser_image_<?php echo sanitize_html_class($bwg); ?>">
101
  <?php
102
  if ( $show_watermark ) {
103
  ?>
104
+ <div class="bwg_image_browser_image_contain_<?php echo sanitize_html_class($bwg); ?>" id="bwg_image_browser_image_contain_<?php echo sanitize_html_class($image_row->id) ?>">
105
+ <div class="bwg_image_browser_watermark_contain_<?php echo sanitize_html_class($bwg); ?>">
106
+ <div class="bwg_image_browser_watermark_cont_<?php echo sanitize_html_class($bwg); ?>">
107
  <div <?php echo $watermark_div; ?> >
108
+ <a class="bwg_none_selectable <?php echo sanitize_html_class($watermark_a); ?>" id="watermark_a<?php echo sanitize_html_class($image_row->id); ?>" href="<?php echo urldecode($params['watermark_link']); ?>" target="_blank">
109
  <?php echo $watermark_image_or_text; ?>
110
  </a>
111
  </div>
116
  }
117
  if ( !$is_embed ) {
118
  ?>
119
+ <a style="position:relative;" <?php echo($params['thumb_click_action'] == 'open_lightbox' ? (' class="bwg-a bwg_lightbox" data-image-id="' . esc_attr($image_row->id) . '" data-elementor-open-lightbox="no"') : ('class="bwg-a" ' . ($params['thumb_click_action'] == 'redirect_to_url' && $image_row->redirect_url ? 'href="' . esc_url($image_row->redirect_url) . '" target="' . ($params['thumb_link_target'] ? '_blank' : '') . '"' : ''))) ?>>
120
+ <img class="skip-lazy bwg-item0 bwg_image_browser_img bwg_image_browser_img_<?php echo sanitize_html_class($bwg); ?> <?php if( $lazyload ) { ?> bwg_lazyload lazy_loader<?php } ?>"
121
+ src="<?php if( !$lazyload ) { echo esc_url(BWG()->upload_url . $image_row->image_url); } else { echo esc_url(BWG()->plugin_url."/images/lazy_placeholder.gif"); } ?>"
122
+ data-original="<?php echo esc_url(BWG()->upload_url . $image_row->image_url); ?>"
123
+ alt="<?php echo esc_attr($image_row->alt); ?>" />
124
  </a>
125
  <?php
126
  }
156
  }
157
  else {/*for instagram image, video and flickr enable lightbox onclick*/
158
  ?>
159
+ <a style="position:relative;" <?php echo($params['thumb_click_action'] == 'open_lightbox' ? (' class="bwg_lightbox bwg_lightbox_' . sanitize_html_class($bwg) . '" data-image-id="' . esc_attr($image_row->id) . '"') : ($image_row->redirect_url ? 'href="' . esc_url($image_row->redirect_url) . '" target="' . ($params['thumb_link_target'] ? '_blank' : '') . '"' : '')) ?>>
160
  <?php
161
  WDWLibraryEmbed::display_embed($image_row->filetype, $image_row->image_url, $image_row->filename, array(
162
  'id' => "bwg_embed_frame_" . $bwg,
178
  <?php
179
  if ( $image_title && ($image_browser_image_title_align == 'bottom') ) {
180
  ?>
181
+ <div class="bwg_image_browser_image_alt_<?php echo sanitize_html_class($bwg); ?>">
182
+ <div class="bwg_image_alt_<?php echo sanitize_html_class($bwg); ?>" id="alt<?php echo esc_attr($image_row->id); ?>">
183
  <?php echo html_entity_decode($image_row->alt); ?>
184
  </div>
185
  </div>
187
  }
188
  if ( $enable_image_description && ($image_row->description != "") ) {
189
  ?>
190
+ <div class="bwg_image_browser_image_desp_<?php echo sanitize_html_class($bwg); ?>">
191
+ <div class="bwg_image_browser_image_description_<?php echo sanitize_html_class($bwg); ?>" id="alt<?php echo esc_attr($image_row->id); ?>">
192
  <?php echo html_entity_decode($image_row->description); ?>
193
  </div>
194
  </div>
frontend/views/BWGViewSlideshow.php CHANGED
@@ -104,11 +104,11 @@ public function display($params = array(), $bwg = 0, $ajax = FALSE) {
104
  }
105
  }
106
  else {
107
- echo '<style id="bwg-style-' . $bwg . '">' . $inline_style . '</style>';
108
  }
109
  }
110
  else {
111
- echo '<style id="bwg-style-' . $bwg . '">' . $inline_style . '</style>';
112
  }
113
 
114
  $data = array();
@@ -174,19 +174,19 @@ public function display($params = array(), $bwg = 0, $ajax = FALSE) {
174
  'enable_slideshow_music' => $enable_slideshow_music,
175
  );
176
  ?>
177
- <div class="bwg_slideshow_image_wrap_<?php echo $bwg; ?> bwg-slideshow-images-wrapper bwg-container"
178
- data-bwg="<?php echo $bwg; ?>"
179
- data-lightbox-url="<?php echo addslashes(add_query_arg($params['params_array'], admin_url('admin-ajax.php'))); ?>">
180
  <?php
181
  $current_pos = 0;
182
  if ( $enable_slideshow_filmstrip ) {
183
  ?>
184
- <div class="bwg_slideshow_filmstrip_container_<?php echo $bwg; ?>">
185
- <div class="bwg_slideshow_filmstrip_left_<?php echo $bwg; ?>">
186
  <i class="<?php echo($filmstrip_direction == 'horizontal' ? 'bwg-icon-angle-left' : 'bwg-icon-angle-up'); ?>"></i>
187
  </div>
188
- <div class="bwg_slideshow_filmstrip_<?php echo $bwg; ?> bwg_slideshow_filmstrip">
189
- <div class="bwg_slideshow_filmstrip_thumbnails_<?php echo $bwg; ?>">
190
  <?php
191
  foreach ( $image_rows as $key => $image_row ) {
192
  if ( $image_row->id == $current_image_id ) {
@@ -196,6 +196,7 @@ public function display($params = array(), $bwg = 0, $ajax = FALSE) {
196
  $is_embed = preg_match('/EMBED/', $image_row->filetype) == 1 ? TRUE : FALSE;
197
  $is_embed_video = ($is_embed && preg_match('/_VIDEO/', $image_row->filetype) == 1) ? TRUE : FALSE;
198
  $is_embed_instagram = preg_match('/EMBED_OEMBED_INSTAGRAM/', $image_row->filetype) == 1 ? TRUE : FALSE;
 
199
  if ( $play_pause_button_display === 'undefined' ) {
200
  if ( $is_embed_video ) {
201
  $play_pause_button_display = 'none';
@@ -249,22 +250,22 @@ public function display($params = array(), $bwg = 0, $ajax = FALSE) {
249
  $thumb_left = ($slideshow_filmstrip_width - $image_thumb_width) / 2;
250
  $thumb_top = ($slideshow_filmstrip_height - $image_thumb_height) / 2;
251
  ?>
252
- <div id="bwg_filmstrip_thumbnail_<?php echo $key; ?>_<?php echo $bwg; ?>" class="bwg_slideshow_filmstrip_thumbnail_<?php echo $bwg; ?> <?php echo(($image_row->id == $current_image_id) ? 'bwg_slideshow_thumb_active_' . $bwg : 'bwg_slideshow_thumb_deactive_' . $bwg); ?>">
253
  <img style="width:<?php echo $image_thumb_width; ?>px; height:<?php echo $image_thumb_height; ?>px; margin-left: <?php echo $thumb_left; ?>px; margin-top: <?php echo $thumb_top; ?>px;"
254
- class="skip-lazy bwg_filmstrip_thumbnail_img bwg_slideshow_filmstrip_thumbnail_img_<?php echo $bwg; ?> <?php if( $lazyload ) { ?> bwg_lazyload <?php } ?>"
255
- src="<?php if( !$lazyload ) { echo ($is_embed ? "" : BWG()->upload_url) . $image_row->thumb_url; } else { echo BWG()->plugin_url."/images/lazy_placeholder.gif"; } ?>"
256
- data-original="<?php echo ($is_embed ? "" : BWG()->upload_url) . $image_row->thumb_url; ?>"
257
  onclick="bwg_change_image(parseInt(jQuery('#bwg_current_image_key_<?php echo $bwg; ?>').val()), '<?php echo $key; ?>', '', '', '<?php echo $bwg; ?>')"
258
- image_id="<?php echo $image_row->id; ?>"
259
- image_key="<?php echo $key; ?>"
260
- alt="<?php echo $image_row->alt; ?>" />
261
  </div>
262
  <?php
263
  }
264
  ?>
265
  </div>
266
  </div>
267
- <div class="bwg_slideshow_filmstrip_right_<?php echo $bwg; ?>">
268
  <i class="<?php echo($filmstrip_direction == 'horizontal' ? 'bwg-icon-angle-right' : 'bwg-icon-angle-down'); ?>"></i>
269
  </div>
270
  </div>
@@ -272,8 +273,8 @@ public function display($params = array(), $bwg = 0, $ajax = FALSE) {
272
  }
273
  else {
274
  ?>
275
- <div class="bwg_slideshow_dots_container_<?php echo $bwg; ?>">
276
- <div class="bwg_slideshow_dots_thumbnails_<?php echo $bwg; ?>">
277
  <?php
278
  foreach ( $image_rows as $key => $image_row ) {
279
  if ( $image_row->id == $current_image_id ) {
@@ -281,7 +282,7 @@ public function display($params = array(), $bwg = 0, $ajax = FALSE) {
281
  $current_key = $key;
282
  }
283
  ?>
284
- <span id="bwg_dots_<?php echo $key; ?>_<?php echo $bwg; ?>" class="bwg_slideshow_dots_<?php echo $bwg; ?> <?php echo(($image_row->id == $current_image_id) ? 'bwg_slideshow_dots_active_' . $bwg : 'bwg_slideshow_dots_deactive_' . $bwg); ?>" onclick="bwg_change_image(parseInt(jQuery('#bwg_current_image_key_<?php echo $bwg; ?>').val()), '<?php echo $key; ?>', '', '', <?php echo $bwg; ?>)" image_id="<?php echo $image_row->id; ?>" image_key="<?php echo $key; ?>"></span>
285
  <?php
286
  }
287
  ?>
@@ -292,10 +293,10 @@ public function display($params = array(), $bwg = 0, $ajax = FALSE) {
292
  $bwg_param['bwg_current_filmstrip_pos'] = $current_pos;
293
  $bwg_params = json_encode($bwg_param);
294
  ?>
295
- <div id="bwg_slideshow_image_container_<?php echo $bwg; ?>" class="bwg_slideshow_image_container_<?php echo $bwg; ?>" data-params='<?php echo $bwg_params; ?>'>
296
- <div class="bwg_slide_container_<?php echo $bwg; ?>">
297
- <div class="bwg_slide_bg_<?php echo $bwg; ?>">
298
- <div class="bwg_slider_<?php echo $bwg; ?>">
299
  <?php
300
  foreach ( $image_rows as $key => $image_row ) {
301
  $is_embed = preg_match('/EMBED/', $image_row->filetype) == 1 ? TRUE : FALSE;
@@ -304,25 +305,25 @@ public function display($params = array(), $bwg = 0, $ajax = FALSE) {
304
  if ( $image_row->id == $current_image_id ) {
305
  $current_key = $key;
306
  ?>
307
- <span class="bwg_slideshow_image_spun_<?php echo $bwg; ?>" id="image_id_<?php echo $bwg; ?>_<?php echo $image_row->id; ?>">
308
- <span class="bwg_slideshow_image_spun1_<?php echo $bwg; ?>">
309
- <span class="bwg_slideshow_image_spun2_<?php echo $bwg; ?>">
310
  <?php
311
  if ( !$is_embed ) {
312
  ?>
313
- <a <?php echo($params['thumb_click_action'] == 'open_lightbox' ? (' class="bwg-a bwg_lightbox"' . (BWG()->options->enable_seo ? ' href="' . ($is_embed ? $image_row->thumb_url : BWG()->upload_url . $image_row->image_url) . '"' : '') . ' data-image-id="' . $image_row->id . '" data-elementor-open-lightbox="no"') : ('class="bwg-a" ' . ($params['thumb_click_action'] == 'redirect_to_url' && $image_row->redirect_url ? 'href="' . $image_row->redirect_url . '" target="' . ($params['thumb_link_target'] ? '_blank' : '') . '"' : ''))); ?>>
314
- <img id="bwg_slideshow_image_<?php echo $bwg; ?>"
315
- class="skip-lazy bwg_slide bwg_slideshow_image_<?php echo $bwg; ?> <?php if( $lazyload ) { ?> bwg_lazyload <?php } ?>"
316
- src="<?php if( !$lazyload ) { echo BWG()->upload_url . $image_row->image_url; } else { echo BWG()->plugin_url."/images/lazy_placeholder.gif"; } ?>"
317
- data-original="<?php echo BWG()->upload_url . $image_row->image_url; ?>"
318
- image_id="<?php echo $image_row->id; ?>"
319
- alt="<?php echo $image_row->alt; ?>" />
320
  </a>
321
  <?php
322
  }
323
  else { /*$is_embed*/
324
  ?>
325
- <span id="bwg_slideshow_image_<?php echo $bwg; ?>" class="bwg_slideshow_embed_<?php echo $bwg; ?>" image_id="<?php echo $image_row->id; ?>">
326
  <?php echo $is_embed_instagram_video ? '<span class="bwg_inst_play_btn_cont" onclick="bwg_play_instagram_video(this)" ><span class="bwg_inst_play"></span></span>' : '';
327
  if ( $is_embed_instagram_post ) {
328
  $post_width = $image_width - ($filmstrip_direction == 'vertical' ? $slideshow_filmstrip_width : 0);
@@ -365,32 +366,32 @@ public function display($params = array(), $bwg = 0, $ajax = FALSE) {
365
  </span>
366
  </span>
367
  </span>
368
- <span class="bwg_slideshow_image_second_spun_<?php echo $bwg; ?>">
369
  </span>
370
- <input type="hidden" id="bwg_current_image_key_<?php echo $bwg; ?>" value="<?php echo $key; ?>" />
371
  <?php
372
  break;
373
  }
374
  else {
375
  ?>
376
- <span class="bwg_slideshow_image_second_spun_<?php echo $bwg; ?>" id="image_id_<?php echo $bwg; ?>_<?php echo $image_row->id; ?>">
377
- <span class="bwg_slideshow_image_spun1_<?php echo $bwg; ?>">
378
- <span class="bwg_slideshow_image_spun2_<?php echo $bwg; ?>">
379
  <?php
380
  if ( !$is_embed ) {
381
  ?>
382
- <a <?php echo($params['thumb_click_action'] == 'open_lightbox' ? (' class="bwg-a bwg_lightbox_' . $bwg . '"' . (BWG()->options->enable_seo ? ' href="' . ($is_embed ? $image_row->thumb_url : BWG()->upload_url . $image_row->image_url) . '"' : '') . ' data-image-id="' . $image_row->id . '"') : ('class="bwg-a" ' . ($params['thumb_click_action'] == 'redirect_to_url' && $image_row->redirect_url ? 'href="' . $image_row->redirect_url . '" target="' . ($params['thumb_link_target'] ? '_blank' : '') . '"' : ''))) ?>>
383
- <img id="bwg_slideshow_image_<?php echo $bwg; ?>"
384
- class="skip-lazy bwg_slide bwg_slideshow_image_<?php echo $bwg; ?> <?php if( $lazyload ) { ?> bwg_lazyload lazy_loader <?php } ?>"
385
- src="<?php if( !$lazyload ) { echo BWG()->upload_url . $image_row->image_url; } else { echo BWG()->plugin_url."/images/lazy_placeholder.gif"; } ?>"
386
- data-original="<?php echo BWG()->upload_url . $image_row->image_url; ?>"
387
- image_id="<?php echo $image_row->id; ?>"
388
- alt="<?php echo $image_row->alt; ?>" />
389
  </a>
390
  <?php
391
  }
392
  else { /*$is_embed*/ ?>
393
- <span class="bwg_slideshow_embed_<?php echo $bwg; ?>">
394
  <?php
395
  if ( $is_embed_instagram_post ) {
396
  $post_width = $image_width - ($filmstrip_direction == 'vertical' ? $slideshow_filmstrip_width : 0);
@@ -443,9 +444,9 @@ public function display($params = array(), $bwg = 0, $ajax = FALSE) {
443
  <?php
444
  if ( $enable_slideshow_ctrl ) {
445
  ?>
446
- <a class="bwg-a" id="spider_slideshow_left_<?php echo $bwg; ?>" onclick="bwg_change_image(parseInt(jQuery('#bwg_current_image_key_<?php echo $bwg; ?>').val()), (parseInt(jQuery('#bwg_current_image_key_<?php echo $bwg; ?>').val()) + <?php echo count($data[$bwg]); ?> - bwg_iterator(<?php echo $bwg; ?>)) % <?php echo count($data[$bwg]); ?>, '', '', <?php echo $bwg; ?>); return false;"><span id="spider_slideshow_left-ico_<?php echo $bwg; ?>"><span><i class="<?php echo $theme_row->slideshow_rl_btn_style; ?>-left bwg_slideshow_prev_btn_<?php echo $bwg; ?>"></i></span></span></a>
447
- <span id="bwg_slideshow_play_pause_<?php echo $bwg; ?>" class="bwg_slideshow_play_pause" style="display: <?php echo $play_pause_button_display; ?>;"><span><span id="bwg_slideshow_play_pause-ico_<?php echo $bwg; ?>"><i class="bwg-icon-play bwg_ctrl_btn_<?php echo $bwg; ?> bwg_slideshow_play_pause_<?php echo $bwg; ?>"></i></span></span></span>
448
- <a class="bwg-a" id="spider_slideshow_right_<?php echo $bwg; ?>" onclick="bwg_change_image(parseInt(jQuery('#bwg_current_image_key_<?php echo $bwg; ?>').val()), (parseInt(jQuery('#bwg_current_image_key_<?php echo $bwg; ?>').val()) + bwg_iterator(<?php echo $bwg; ?>)) % <?php echo count($data[$bwg]); ?>, '', '', <?php echo $bwg; ?>); return false;"><span id="spider_slideshow_right-ico_<?php echo $bwg; ?>"><span><i class="<?php echo $theme_row->slideshow_rl_btn_style; ?>-right bwg_slideshow_next_btn_<?php echo $bwg; ?>"></i></span></span></a>
449
  <?php
450
  }
451
  ?>
@@ -453,21 +454,21 @@ public function display($params = array(), $bwg = 0, $ajax = FALSE) {
453
  <?php
454
  if ( $params['watermark_type'] != 'none' ) {
455
  ?>
456
- <div class="bwg_slideshow_image_container_<?php echo $bwg; ?> bwg_slideshow_image_container" data-params="<?php echo $bwg_params; ?>">
457
- <div class="bwg_slideshow_watermark_container_<?php echo $bwg; ?>">
458
  <div>
459
- <span class="bwg_slideshow_watermark_spun_<?php echo $bwg; ?>" id="bwg_slideshow_watermark_container_<?php echo $bwg; ?>">
460
  <?php
461
  if ( $params['watermark_type'] == 'image' ) {
462
  ?>
463
  <a class="bwg-a" href="<?php echo urldecode($watermark_link); ?>" target="_blank">
464
- <img class="bwg_slideshow_watermark_image_<?php echo $bwg; ?> bwg_slideshow_watermark_<?php echo $bwg; ?>" src="<?php echo urldecode($watermark_url); ?>" />
465
  </a>
466
  <?php
467
  }
468
  elseif ( $params['watermark_type'] == 'text' ) {
469
  ?>
470
- <a class="bwg_none_selectable_<?php echo $bwg; ?> bwg_slideshow_watermark_text_<?php echo $bwg; ?> bwg_slideshow_watermark_<?php echo $bwg; ?>" target="_blank" href="<?php echo urldecode($watermark_link); ?>"><?php echo $params['watermark_text']; ?></a>
471
  <?php
472
  }
473
  ?>
@@ -479,11 +480,11 @@ public function display($params = array(), $bwg = 0, $ajax = FALSE) {
479
  }
480
  if ( $enable_image_title ) {
481
  ?>
482
- <div class="bwg_slideshow_image_container_<?php echo $bwg; ?> bwg_slideshow_image_container" data-params="<?php echo $bwg_params; ?>">
483
- <div class="bwg_slideshow_watermark_container_<?php echo $bwg; ?>">
484
  <div>
485
- <span class="bwg_slideshow_title_spun_<?php echo $bwg; ?>">
486
- <div class="bwg_slideshow_title_text_<?php echo $bwg; ?> <?php if ( !$current_image_alt ) {
487
  echo 'bwg-hidden';
488
  } ?>">
489
  <?php echo html_entity_decode($current_image_alt); ?>
@@ -496,11 +497,11 @@ public function display($params = array(), $bwg = 0, $ajax = FALSE) {
496
  }
497
  if ( $enable_image_description && isset($current_image_description) ) {
498
  ?>
499
- <div class="bwg_slideshow_image_container_<?php echo $bwg; ?> bwg_slideshow_image_container" data-params="<?php echo $bwg_params; ?>">
500
- <div class="bwg_slideshow_watermark_container_<?php echo $bwg; ?>">
501
  <div>
502
- <span class="bwg_slideshow_description_spun_<?php echo $bwg; ?>">
503
- <div class="bwg_slideshow_description_text_<?php echo $bwg; ?> <?php if ( !$current_image_description ) {
504
  echo 'bwg-hidden';
505
  } ?>">
506
  <?php echo html_entity_decode(str_replace("\r\n", esc_html('<br />'), $current_image_description)); ?>
@@ -513,7 +514,7 @@ public function display($params = array(), $bwg = 0, $ajax = FALSE) {
513
  }
514
  if ( $enable_slideshow_music ) {
515
  ?>
516
- <audio id="bwg_audio_<?php echo $bwg; ?>" src="<?php echo $slideshow_music_url ?>" loop volume="1.0"></audio>
517
  <?php
518
  }
519
  ?>
104
  }
105
  }
106
  else {
107
+ echo '<style id="bwg-style-' . sanitize_html_class($bwg) . '">' . $inline_style . '</style>';
108
  }
109
  }
110
  else {
111
+ echo '<style id="bwg-style-' . sanitize_html_class($bwg) . '">' . $inline_style . '</style>';
112
  }
113
 
114
  $data = array();
174
  'enable_slideshow_music' => $enable_slideshow_music,
175
  );
176
  ?>
177
+ <div class="bwg_slideshow_image_wrap_<?php echo sanitize_html_class($bwg); ?> bwg-slideshow-images-wrapper bwg-container"
178
+ data-bwg="<?php echo esc_attr($bwg); ?>"
179
+ data-lightbox-url="<?php echo esc_url(addslashes(add_query_arg($params['params_array'], admin_url('admin-ajax.php')))); ?>">
180
  <?php
181
  $current_pos = 0;
182
  if ( $enable_slideshow_filmstrip ) {
183
  ?>
184
+ <div class="bwg_slideshow_filmstrip_container_<?php echo sanitize_html_class($bwg); ?>">
185
+ <div class="bwg_slideshow_filmstrip_left_<?php echo sanitize_html_class($bwg); ?>">
186
  <i class="<?php echo($filmstrip_direction == 'horizontal' ? 'bwg-icon-angle-left' : 'bwg-icon-angle-up'); ?>"></i>
187
  </div>
188
+ <div class="bwg_slideshow_filmstrip_<?php echo sanitize_html_class($bwg); ?> bwg_slideshow_filmstrip">
189
+ <div class="bwg_slideshow_filmstrip_thumbnails_<?php echo sanitize_html_class($bwg); ?>">
190
  <?php
191
  foreach ( $image_rows as $key => $image_row ) {
192
  if ( $image_row->id == $current_image_id ) {
196
  $is_embed = preg_match('/EMBED/', $image_row->filetype) == 1 ? TRUE : FALSE;
197
  $is_embed_video = ($is_embed && preg_match('/_VIDEO/', $image_row->filetype) == 1) ? TRUE : FALSE;
198
  $is_embed_instagram = preg_match('/EMBED_OEMBED_INSTAGRAM/', $image_row->filetype) == 1 ? TRUE : FALSE;
199
+ $bwg_thumb_url = esc_url($is_embed ? $image_row->thumb_url : BWG()->upload_url . $image_row->thumb_url);
200
  if ( $play_pause_button_display === 'undefined' ) {
201
  if ( $is_embed_video ) {
202
  $play_pause_button_display = 'none';
250
  $thumb_left = ($slideshow_filmstrip_width - $image_thumb_width) / 2;
251
  $thumb_top = ($slideshow_filmstrip_height - $image_thumb_height) / 2;
252
  ?>
253
+ <div id="bwg_filmstrip_thumbnail_<?php echo sanitize_html_class($key.'_'.$bwg); ?>" class="bwg_slideshow_filmstrip_thumbnail_<?php echo sanitize_html_class($bwg); ?> <?php echo(($image_row->id == $current_image_id) ? 'bwg_slideshow_thumb_active_' . sanitize_html_class($bwg) : 'bwg_slideshow_thumb_deactive_' . sanitize_html_class($bwg)); ?>">
254
  <img style="width:<?php echo $image_thumb_width; ?>px; height:<?php echo $image_thumb_height; ?>px; margin-left: <?php echo $thumb_left; ?>px; margin-top: <?php echo $thumb_top; ?>px;"
255
+ class="skip-lazy bwg_filmstrip_thumbnail_img bwg_slideshow_filmstrip_thumbnail_img_<?php echo sanitize_html_class($bwg); ?> <?php if( $lazyload ) { ?> bwg_lazyload <?php } ?>"
256
+ src="<?php if( !$lazyload ) { echo $bwg_thumb_url; } else { echo esc_url(BWG()->plugin_url."/images/lazy_placeholder.gif"); } ?>"
257
+ data-original="<?php echo $bwg_thumb_url; ?>"
258
  onclick="bwg_change_image(parseInt(jQuery('#bwg_current_image_key_<?php echo $bwg; ?>').val()), '<?php echo $key; ?>', '', '', '<?php echo $bwg; ?>')"
259
+ image_id="<?php echo esc_attr($image_row->id); ?>"
260
+ image_key="<?php echo esc_attr($key); ?>"
261
+ alt="<?php echo esc_attr($image_row->alt); ?>" />
262
  </div>
263
  <?php
264
  }
265
  ?>
266
  </div>
267
  </div>
268
+ <div class="bwg_slideshow_filmstrip_right_<?php echo sanitize_html_class($bwg); ?>">
269
  <i class="<?php echo($filmstrip_direction == 'horizontal' ? 'bwg-icon-angle-right' : 'bwg-icon-angle-down'); ?>"></i>
270
  </div>
271
  </div>
273
  }
274
  else {
275
  ?>
276
+ <div class="bwg_slideshow_dots_container_<?php echo sanitize_html_class($bwg); ?>">
277
+ <div class="bwg_slideshow_dots_thumbnails_<?php echo sanitize_html_class($bwg); ?>">
278
  <?php
279
  foreach ( $image_rows as $key => $image_row ) {
280
  if ( $image_row->id == $current_image_id ) {
282
  $current_key = $key;
283
  }
284
  ?>
285
+ <span id="bwg_dots_<?php echo sanitize_html_class($key.'_'.$bwg); ?>" class="bwg_slideshow_dots_<?php echo sanitize_html_class($bwg); ?> <?php echo(($image_row->id == $current_image_id) ? 'bwg_slideshow_dots_active_' . sanitize_html_class($bwg) : 'bwg_slideshow_dots_deactive_' . sanitize_html_class($bwg)); ?>" onclick="bwg_change_image(parseInt(jQuery('#bwg_current_image_key_<?php echo $bwg; ?>').val()), '<?php echo $key; ?>', '', '', <?php echo $bwg; ?>)" image_id="<?php echo esc_attr($image_row->id); ?>" image_key="<?php echo esc_attr($key); ?>"></span>
286
  <?php
287
  }
288
  ?>
293
  $bwg_param['bwg_current_filmstrip_pos'] = $current_pos;
294
  $bwg_params = json_encode($bwg_param);
295
  ?>
296
+ <div id="bwg_slideshow_image_container_<?php echo sanitize_html_class($bwg); ?>" class="bwg_slideshow_image_container_<?php echo sanitize_html_class($bwg); ?>" data-params='<?php echo esc_attr($bwg_params); ?>'>
297
+ <div class="bwg_slide_container_<?php echo sanitize_html_class($bwg); ?>">
298
+ <div class="bwg_slide_bg_<?php echo sanitize_html_class($bwg); ?>">
299
+ <div class="bwg_slider_<?php echo sanitize_html_class($bwg); ?>">
300
  <?php
301
  foreach ( $image_rows as $key => $image_row ) {
302
  $is_embed = preg_match('/EMBED/', $image_row->filetype) == 1 ? TRUE : FALSE;
305
  if ( $image_row->id == $current_image_id ) {
306
  $current_key = $key;
307
  ?>
308
+ <span class="bwg_slideshow_image_spun_<?php echo sanitize_html_class($bwg); ?>" id="image_id_<?php echo sanitize_html_class($bwg.'_'.$image_row->id); ?>">
309
+ <span class="bwg_slideshow_image_spun1_<?php echo sanitize_html_class($bwg); ?>">
310
+ <span class="bwg_slideshow_image_spun2_<?php echo sanitize_html_class($bwg); ?>">
311
  <?php
312
  if ( !$is_embed ) {
313
  ?>
314
+ <a <?php echo($params['thumb_click_action'] == 'open_lightbox' ? (' class="bwg-a bwg_lightbox"' . (BWG()->options->enable_seo ? ' href="' . esc_url($is_embed ? $image_row->thumb_url : BWG()->upload_url . $image_row->image_url) . '"' : '') . ' data-image-id="' . esc_attr($image_row->id) . '" data-elementor-open-lightbox="no"') : ('class="bwg-a" ' . ($params['thumb_click_action'] == 'redirect_to_url' && $image_row->redirect_url ? 'href="' . esc_url($image_row->redirect_url) . '" target="' . ($params['thumb_link_target'] ? '_blank' : '') . '"' : ''))); ?>>
315
+ <img id="bwg_slideshow_image_<?php echo sanitize_html_class($bwg); ?>"
316
+ class="skip-lazy bwg_slide bwg_slideshow_image_<?php echo sanitize_html_class($bwg); ?> <?php if( $lazyload ) { ?> bwg_lazyload <?php } ?>"
317
+ src="<?php if( !$lazyload ) { echo esc_url(BWG()->upload_url . $image_row->image_url); } else { echo esc_url(BWG()->plugin_url."/images/lazy_placeholder.gif"); } ?>"
318
+ data-original="<?php echo esc_url(BWG()->upload_url . $image_row->image_url); ?>"
319
+ image_id="<?php echo esc_attr($image_row->id); ?>"
320
+ alt="<?php echo esc_attr($image_row->alt); ?>" />
321
  </a>
322
  <?php
323
  }
324
  else { /*$is_embed*/
325
  ?>
326
+ <span id="bwg_slideshow_image_<?php echo sanitize_html_class($bwg); ?>" class="bwg_slideshow_embed_<?php echo sanitize_html_class($bwg); ?>" image_id="<?php echo esc_attr($image_row->id); ?>">
327
  <?php echo $is_embed_instagram_video ? '<span class="bwg_inst_play_btn_cont" onclick="bwg_play_instagram_video(this)" ><span class="bwg_inst_play"></span></span>' : '';
328
  if ( $is_embed_instagram_post ) {
329
  $post_width = $image_width - ($filmstrip_direction == 'vertical' ? $slideshow_filmstrip_width : 0);
366
  </span>
367
  </span>
368
  </span>
369
+ <span class="bwg_slideshow_image_second_spun_<?php echo sanitize_html_class($bwg); ?>">
370
  </span>
371
+ <input type="hidden" id="bwg_current_image_key_<?php echo sanitize_html_class($bwg); ?>" value="<?php echo esc_attr($key); ?>" />
372
  <?php
373
  break;
374
  }
375
  else {
376
  ?>
377
+ <span class="bwg_slideshow_image_second_spun_<?php echo sanitize_html_class($bwg); ?>" id="image_id_<?php echo sanitize_html_class($bwg.'_'.$image_row->id); ?>">
378
+ <span class="bwg_slideshow_image_spun1_<?php echo sanitize_html_class($bwg); ?>">
379
+ <span class="bwg_slideshow_image_spun2_<?php echo sanitize_html_class($bwg); ?>">
380
  <?php
381
  if ( !$is_embed ) {
382
  ?>
383
+ <a <?php echo($params['thumb_click_action'] == 'open_lightbox' ? (' class="bwg-a bwg_lightbox_' . sanitize_html_class($bwg) . '"' . (BWG()->options->enable_seo ? ' href="' . esc_url($is_embed ? $image_row->thumb_url : BWG()->upload_url . $image_row->image_url) . '"' : '') . ' data-image-id="' . esc_attr($image_row->id) . '"') : ('class="bwg-a" ' . ($params['thumb_click_action'] == 'redirect_to_url' && $image_row->redirect_url ? 'href="' . esc_url($image_row->redirect_url) . '" target="' . ($params['thumb_link_target'] ? '_blank' : '') . '"' : ''))) ?>>
384
+ <img id="bwg_slideshow_image_<?php echo sanitize_html_class($bwg); ?>"
385
+ class="skip-lazy bwg_slide bwg_slideshow_image_<?php echo sanitize_html_class($bwg); ?> <?php if( $lazyload ) { ?> bwg_lazyload lazy_loader <?php } ?>"
386
+ src="<?php if( !$lazyload ) { echo esc_url(BWG()->upload_url . $image_row->image_url); } else { echo esc_url(BWG()->plugin_url."/images/lazy_placeholder.gif"); } ?>"
387
+ data-original="<?php echo esc_url(BWG()->upload_url . $image_row->image_url); ?>"
388
+ image_id="<?php echo esc_attr($image_row->id); ?>"
389
+ alt="<?php echo esc_attr($image_row->alt); ?>" />
390
  </a>
391
  <?php
392
  }
393
  else { /*$is_embed*/ ?>
394
+ <span class="bwg_slideshow_embed_<?php echo sanitize_html_class($bwg); ?>">
395
  <?php
396
  if ( $is_embed_instagram_post ) {
397
  $post_width = $image_width - ($filmstrip_direction == 'vertical' ? $slideshow_filmstrip_width : 0);
444
  <?php
445
  if ( $enable_slideshow_ctrl ) {
446
  ?>
447
+ <a class="bwg-a" id="spider_slideshow_left_<?php echo sanitize_html_class($bwg); ?>" onclick="bwg_change_image(parseInt(jQuery('#bwg_current_image_key_<?php echo $bwg; ?>').val()), (parseInt(jQuery('#bwg_current_image_key_<?php echo $bwg; ?>').val()) + <?php echo count($data[$bwg]); ?> - bwg_iterator(<?php echo $bwg; ?>)) % <?php echo count($data[$bwg]); ?>, '', '', <?php echo $bwg; ?>); return false;"><span id="spider_slideshow_left-ico_<?php echo sanitize_html_class($bwg); ?>"><span><i class="<?php echo sanitize_html_class($theme_row->slideshow_rl_btn_style); ?>-left bwg_slideshow_prev_btn_<?php echo sanitize_html_class($bwg); ?>"></i></span></span></a>
448
+ <span id="bwg_slideshow_play_pause_<?php echo sanitize_html_class($bwg); ?>" class="bwg_slideshow_play_pause" style="display: <?php echo $play_pause_button_display; ?>;"><span><span id="bwg_slideshow_play_pause-ico_<?php echo sanitize_html_class($bwg); ?>"><i class="bwg-icon-play bwg_ctrl_btn_<?php echo sanitize_html_class($bwg); ?> bwg_slideshow_play_pause_<?php echo sanitize_html_class($bwg); ?>"></i></span></span></span>
449
+ <a class="bwg-a" id="spider_slideshow_right_<?php echo sanitize_html_class($bwg); ?>" onclick="bwg_change_image(parseInt(jQuery('#bwg_current_image_key_<?php echo $bwg; ?>').val()), (parseInt(jQuery('#bwg_current_image_key_<?php echo $bwg; ?>').val()) + bwg_iterator(<?php echo $bwg; ?>)) % <?php echo count($data[$bwg]); ?>, '', '', <?php echo $bwg; ?>); return false;"><span id="spider_slideshow_right-ico_<?php echo sanitize_html_class($bwg); ?>"><span><i class="<?php echo sanitize_html_class($theme_row->slideshow_rl_btn_style); ?>-right bwg_slideshow_next_btn_<?php echo sanitize_html_class($bwg); ?>"></i></span></span></a>
450
  <?php
451
  }
452
  ?>
454
  <?php
455
  if ( $params['watermark_type'] != 'none' ) {
456
  ?>
457
+ <div class="bwg_slideshow_image_container_<?php echo sanitize_html_class($bwg); ?> bwg_slideshow_image_container" data-params="<?php echo esc_attr($bwg_params); ?>">
458
+ <div class="bwg_slideshow_watermark_container_<?php echo sanitize_html_class($bwg); ?>">
459
  <div>
460
+ <span class="bwg_slideshow_watermark_spun_<?php echo sanitize_html_class($bwg); ?>" id="bwg_slideshow_watermark_container_<?php echo sanitize_html_class($bwg); ?>">
461
  <?php
462
  if ( $params['watermark_type'] == 'image' ) {
463
  ?>
464
  <a class="bwg-a" href="<?php echo urldecode($watermark_link); ?>" target="_blank">
465
+ <img class="bwg_slideshow_watermark_image_<?php echo sanitize_html_class($bwg); ?> bwg_slideshow_watermark_<?php echo sanitize_html_class($bwg); ?>" src="<?php echo urldecode($watermark_url); ?>" />
466
  </a>
467
  <?php
468
  }
469
  elseif ( $params['watermark_type'] == 'text' ) {
470
  ?>
471
+ <a class="bwg_none_selectable_<?php echo sanitize_html_class($bwg); ?> bwg_slideshow_watermark_text_<?php echo sanitize_html_class($bwg); ?> bwg_slideshow_watermark_<?php echo sanitize_html_class($bwg); ?>" target="_blank" href="<?php echo urldecode($watermark_link); ?>"><?php echo esc_html($params['watermark_text']); ?></a>
472
  <?php
473
  }
474
  ?>
480
  }
481
  if ( $enable_image_title ) {
482
  ?>
483
+ <div class="bwg_slideshow_image_container_<?php echo sanitize_html_class($bwg); ?> bwg_slideshow_image_container" data-params="<?php echo esc_attr($bwg_params); ?>">
484
+ <div class="bwg_slideshow_watermark_container_<?php echo sanitize_html_class($bwg); ?>">
485
  <div>
486
+ <span class="bwg_slideshow_title_spun_<?php echo sanitize_html_class($bwg); ?>">
487
+ <div class="bwg_slideshow_title_text_<?php echo sanitize_html_class($bwg); ?> <?php if ( !$current_image_alt ) {
488
  echo 'bwg-hidden';
489
  } ?>">
490
  <?php echo html_entity_decode($current_image_alt); ?>
497
  }
498
  if ( $enable_image_description && isset($current_image_description) ) {
499
  ?>
500
+ <div class="bwg_slideshow_image_container_<?php echo sanitize_html_class($bwg); ?> bwg_slideshow_image_container" data-params="<?php echo esc_attr($bwg_params); ?>">
501
+ <div class="bwg_slideshow_watermark_container_<?php echo sanitize_html_class($bwg); ?>">
502
  <div>
503
+ <span class="bwg_slideshow_description_spun_<?php echo sanitize_html_class($bwg); ?>">
504
+ <div class="bwg_slideshow_description_text_<?php echo sanitize_html_class($bwg); ?> <?php if ( !$current_image_description ) {
505
  echo 'bwg-hidden';
506
  } ?>">
507
  <?php echo html_entity_decode(str_replace("\r\n", esc_html('<br />'), $current_image_description)); ?>
514
  }
515
  if ( $enable_slideshow_music ) {
516
  ?>
517
+ <audio id="bwg_audio_<?php echo sanitize_html_class($bwg); ?>" src="<?php echo esc_url($slideshow_music_url) ?>" loop volume="1.0"></audio>
518
  <?php
519
  }
520
  ?>
frontend/views/BWGViewThumbnails.php CHANGED
@@ -13,26 +13,27 @@ class BWGViewThumbnails extends BWGViewSite {
13
  wp_add_inline_style('bwg_frontend', $inline_style);
14
  }
15
  else {
16
- echo '<style id="bwg-style-' . $bwg . '">' . $inline_style . '</style>';
17
  }
18
  }
19
  }
20
  else {
21
- echo '<style id="bwg-style-' . $bwg . '">' . $inline_style . '</style>';
22
  }
23
  ob_start();
24
  ?>
25
- <div data-max-count="<?php echo $params['image_column_number']; ?>"
26
- data-thumbnail-width="<?php echo $params['thumb_width']; ?>"
27
- data-bwg="<?php echo $bwg; ?>"
28
- data-gallery-id="<?php echo $params['gallery_id']; ?>"
29
- data-lightbox-url="<?php echo addslashes(add_query_arg($params['params_array'], admin_url('admin-ajax.php'))); ?>"
30
- id="bwg_<?php echo $params['gallery_type'].'_'.$bwg ?>"
31
- class="bwg-container-<?php echo $bwg; ?> bwg-thumbnails bwg-standard-thumbnails bwg-container bwg-border-box">
32
  <?php
33
  foreach ($image_rows as $image_row) {
34
  $is_embed = preg_match('/EMBED/',$image_row->filetype) == 1 ? true : false;
35
  $is_embed_video = preg_match('/VIDEO/',$image_row->filetype) == 1 ? true : false;
 
36
  $class = '';
37
  $data_image_id = '';
38
  $href = '';
@@ -50,13 +51,13 @@ class BWGViewThumbnails extends BWGViewSite {
50
  $ecommerce_icon .= '</div></div>';
51
  if ( $params['thumb_click_action'] == 'open_lightbox' ) {
52
  $class = ' bwg_lightbox';
53
- $data_image_id = ' data-image-id="' . $image_row->id . '"';
54
  if ( BWG()->options->enable_seo ) {
55
- $href = ' href="' . ($is_embed ? $image_row->thumb_url : BWG()->upload_url . $image_row->image_url) . '"';
56
  }
57
  }
58
  elseif ( $params['thumb_click_action'] == 'redirect_to_url' && $image_row->redirect_url ) {
59
- $href = ' href="' . $image_row->redirect_url . '" target="' . ($params['thumb_link_target'] ? '_blank' : '') . '"';
60
  }
61
 
62
  $resolution_thumb = $image_row->resolution_thumb;
@@ -70,18 +71,18 @@ class BWGViewThumbnails extends BWGViewSite {
70
  }
71
  ?>
72
  <div class="bwg-item">
73
- <a class="bwg-a<?php echo $class; ?>" <?php echo $data_image_id; ?><?php echo $href; ?> data-elementor-open-lightbox="no" >
74
  <?php if ( $params['image_title'] == 'show' && $theme_row->thumb_title_pos == 'top' ) { echo $title; } ?>
75
  <div class="bwg-item0 <?php if( $lazyload ) { ?> lazy_loader <?php } ?>">
76
  <div class="bwg-item1 <?php echo $theme_row->thumb_hover_effect == 'zoom' && $params['image_title'] == 'hover' ? 'bwg-zoom-effect' : ''; ?>">
77
  <div class="bwg-item2">
78
- <img class="skip-lazy bwg_standart_thumb_img_<?php echo $bwg; ?> <?php if( $lazyload ) { ?> bwg_lazyload <?php } ?>"
79
- data-id="<?php echo $image_row->id; ?>"
80
- data-width="<?php echo $image_thumb_width; ?>"
81
- data-height="<?php echo $image_thumb_height; ?>"
82
- data-original="<?php echo ($is_embed ? "" : BWG()->upload_url) . $image_row->thumb_url; ?>"
83
- src="<?php if( !$lazyload ) { echo ($is_embed ? "" : BWG()->upload_url) . $image_row->thumb_url; } else { echo BWG()->plugin_url."/images/lazy_placeholder.gif"; } ?>"
84
- alt="<?php echo $image_row->alt; ?>" />
85
  </div>
86
  <div class="<?php echo $theme_row->thumb_hover_effect == 'zoom' && $params['image_title'] == 'hover' ? 'bwg-zoom-effect-overlay' : ''; ?>">
87
  <?php if ( $params['image_title'] == 'hover' ) { echo $title; } ?>
13
  wp_add_inline_style('bwg_frontend', $inline_style);
14
  }
15
  else {
16
+ echo '<style id="bwg-style-' . sanitize_html_class($bwg) . '">' . $inline_style . '</style>';
17
  }
18
  }
19
  }
20
  else {
21
+ echo '<style id="bwg-style-' . sanitize_html_class($bwg) . '">' . $inline_style . '</style>';
22
  }
23
  ob_start();
24
  ?>
25
+ <div data-max-count="<?php echo esc_attr($params['image_column_number']); ?>"
26
+ data-thumbnail-width="<?php echo esc_attr($params['thumb_width']); ?>"
27
+ data-bwg="<?php echo esc_attr($bwg); ?>"
28
+ data-gallery-id="<?php echo esc_attr($params['gallery_id']); ?>"
29
+ data-lightbox-url="<?php echo esc_attr(addslashes(add_query_arg($params['params_array'], admin_url('admin-ajax.php')))); ?>"
30
+ id="bwg_<?php echo esc_attr($params['gallery_type'].'_'.$bwg) ?>"
31
+ class="bwg-container-<?php echo sanitize_html_class($bwg); ?> bwg-thumbnails bwg-standard-thumbnails bwg-container bwg-border-box">
32
  <?php
33
  foreach ($image_rows as $image_row) {
34
  $is_embed = preg_match('/EMBED/',$image_row->filetype) == 1 ? true : false;
35
  $is_embed_video = preg_match('/VIDEO/',$image_row->filetype) == 1 ? true : false;
36
+ $bwg_thumb_url = esc_url($is_embed ? $image_row->thumb_url : BWG()->upload_url . $image_row->thumb_url);
37
  $class = '';
38
  $data_image_id = '';
39
  $href = '';
51
  $ecommerce_icon .= '</div></div>';
52
  if ( $params['thumb_click_action'] == 'open_lightbox' ) {
53
  $class = ' bwg_lightbox';
54
+ $data_image_id = ' data-image-id="' . esc_attr($image_row->id) . '"';
55
  if ( BWG()->options->enable_seo ) {
56
+ $href = ' href="' . esc_url($is_embed ? $image_row->thumb_url : BWG()->upload_url . $image_row->image_url) . '"';
57
  }
58
  }
59
  elseif ( $params['thumb_click_action'] == 'redirect_to_url' && $image_row->redirect_url ) {
60
+ $href = ' href="' . esc_url($image_row->redirect_url) . '" target="' . (esc_attr($params['thumb_link_target']) ? '_blank' : '') . '"';
61
  }
62
 
63
  $resolution_thumb = $image_row->resolution_thumb;
71
  }
72
  ?>
73
  <div class="bwg-item">
74
+ <a class="bwg-a <?php echo sanitize_html_class($class); ?>" <?php echo $data_image_id; ?><?php echo $href; ?> data-elementor-open-lightbox="no" >
75
  <?php if ( $params['image_title'] == 'show' && $theme_row->thumb_title_pos == 'top' ) { echo $title; } ?>
76
  <div class="bwg-item0 <?php if( $lazyload ) { ?> lazy_loader <?php } ?>">
77
  <div class="bwg-item1 <?php echo $theme_row->thumb_hover_effect == 'zoom' && $params['image_title'] == 'hover' ? 'bwg-zoom-effect' : ''; ?>">
78
  <div class="bwg-item2">
79
+ <img class="skip-lazy bwg_standart_thumb_img_<?php echo sanitize_html_class($bwg); ?> <?php if( $lazyload ) { ?> bwg_lazyload <?php } ?>"
80
+ data-id="<?php echo esc_attr($image_row->id); ?>"
81
+ data-width="<?php echo esc_attr($image_thumb_width); ?>"
82
+ data-height="<?php echo esc_attr($image_thumb_height); ?>"
83
+ data-original="<?php echo $bwg_thumb_url; ?>"
84
+ src="<?php if( !$lazyload ) { echo $bwg_thumb_url; } else { echo esc_url(BWG()->plugin_url."/images/lazy_placeholder.gif"); } ?>"
85
+ alt="<?php echo esc_attr($image_row->alt); ?>" />
86
  </div>
87
  <div class="<?php echo $theme_row->thumb_hover_effect == 'zoom' && $params['image_title'] == 'hover' ? 'bwg-zoom-effect-overlay' : ''; ?>">
88
  <?php if ( $params['image_title'] == 'hover' ) { echo $title; } ?>
frontend/views/view.php CHANGED
@@ -58,33 +58,33 @@ class BWGViewSite {
58
  $params_array = $params['params_array'];
59
  $theme_row = $params['theme_row'];
60
  ?>
61
- <div id="bwg_container1_<?php echo $bwg; ?>"
62
- class="bwg_container bwg_thumbnail bwg_<?php echo $params['gallery_type']; ?>"
63
- data-right-click-protection="<?php echo BWG()->options->image_right_click; ?>"
64
- data-bwg="<?php echo $bwg; ?>"
65
- data-gallery-type="<?php echo $params['gallery_type']; ?>"
66
- data-current-url="<?php echo addslashes(urldecode($params_array['current_url'])); ?>"
67
- data-lightbox-url="<?php echo addslashes(add_query_arg($params_array, admin_url('admin-ajax.php'))); ?>"
68
- data-gallery-id="<?php echo $params_array['gallery_id']; ?>"
69
- data-popup-width="<?php echo $params["popup_width"]; ?>"
70
- data-popup-height="<?php echo $params["popup_height"]; ?>"
71
- data-is-album="<?php echo $params["view_type"]; ?>"
72
- data-buttons-position="<?php echo $theme_row->lightbox_ctrl_btn_pos; ?>">
73
- <div id="bwg_container2_<?php echo $bwg; ?>">
74
  <?php $this->loading($bwg, $params["image_enable_page"], $params['gallery_type'] ); ?>
75
- <form id="gal_front_form_<?php echo $bwg; ?>"
76
  class="bwg-hidden"
77
  method="post"
78
  action="#"
79
- data-current="<?php echo $bwg; ?>"
80
- data-shortcode-id="<?php echo isset($params['id']) ? $params['id'] : 0; ?>"
81
- data-gallery-type="<?php echo $params['gallery_type']; ?>"
82
- data-gallery-id="<?php echo $params['gallery_id']; ?>"
83
- data-tag="<?php echo $params['tag']; ?>"
84
- data-album-id="<?php echo $params['album_id']; ?>"
85
- data-theme-id="<?php echo $params['theme_id']; ?>"
86
- data-ajax-url="<?php echo add_query_arg(array('action' => 'bwg_frontend_data'), admin_url('admin-ajax.php')); ?>">
87
- <div id="bwg_container3_<?php echo $bwg; ?>" class="bwg-background bwg-background-<?php echo $bwg; ?>">
88
  <?php
89
  $get_album_gallery_id = WDWLibrary::get("album_gallery_id_" . $bwg, 0, 'intval');
90
  if ( BWG()->options->front_ajax == "1" && isset($get_album_gallery_id) && intval($get_album_gallery_id) > 0 ) {
@@ -158,9 +158,9 @@ class BWGViewSite {
158
  echo '<style>' . $inline_style . '</style>';
159
  }
160
  ?>
161
- <div id="bwg_spider_popup_loading_<?php echo $bwg; ?>" class="bwg_spider_popup_loading"></div>
162
- <div id="spider_popup_overlay_<?php echo $bwg; ?>" class="spider_popup_overlay" onclick="spider_destroypopup(1000)"></div>
163
- <input type="hidden" id="bwg_random_seed_<?php echo $bwg; ?>" value="<?php echo isset($GLOBALS['bwg_random_seed_' . $bwg]) ? $GLOBALS['bwg_random_seed_' . $bwg] : '' ?>">
164
  <?php
165
  }
166
  ?>
@@ -262,10 +262,10 @@ class BWGViewSite {
262
  $load_type_class = "bwg_load_more_ajax_loading";
263
  }
264
  ?>
265
- <div id="ajax_loading_<?php echo $bwg; ?>" class="<?php echo $load_type_class; ?>">
266
  <div class="bwg_loading_div_2">
267
  <div class="bwg_loading_div_3">
268
- <div id="loading_div_<?php echo $bwg; ?>" class="bwg_spider_ajax_loading">
269
  </div>
270
  </div>
271
  </div>
@@ -299,7 +299,7 @@ class BWGViewSite {
299
  echo '<style>' . $inline_style . '</style>';
300
  }
301
  ?>
302
- <div class="bwg_back bwg_back_<?php echo $bwg; ?>" onclick="bwg_ajax('gal_front_form_<?php echo $bwg; ?>', '<?php echo $bwg; ?>', '<?php echo $params['container_id']; ?>', 'back', '', 'album')"><i class="bwg-icon-arrow-left"></i> <?php _e('Back', BWG()->prefix); ?></div>
303
  <?php
304
  }
305
 
@@ -341,12 +341,12 @@ class BWGViewSite {
341
  }
342
  if ( $params['showthumbs_name'] && isset($row->name) && $row->name != '' ) {
343
  ?>
344
- <div class="bwg_gal_title_<?php echo $bwg; ?>"><?php echo WDWLibrary::strip_tags(stripslashes($row->name)); ?></div>
345
  <?php
346
  }
347
  if ( $params['show_gallery_description'] && isset($row->description) && $row->description != '' ) {
348
  ?>
349
- <div class="bwg_gal_title_<?php echo $bwg; ?> bwg_gal_description_<?php echo $bwg; ?>"><?php echo WDWLibrary::strip_tags(stripslashes($row->description)); ?></div>
350
  <?php
351
  }
352
  }
@@ -362,8 +362,10 @@ class BWGViewSite {
362
  && ($params['gallery_row']->id == 0 || ($params['gallery_row']->gallery_type != 'facebook' && $params['gallery_row']->gallery_type != 'instagram' && $params['gallery_row']->gallery_type != 'instagram_post')) ) {
363
  if ( count($params['image_rows']['images']) ) {
364
  $bwg_tags_input_value = WDWLibrary::get('bwg_tag_id_'.$params['container_id']);
 
365
  $query_url = addslashes(add_query_arg(array(
366
  "action" => "download_gallery",
 
367
  "gallery_id" => $params['gallery_id'],
368
  "bwg" => $bwg,
369
  "type" => 'gallery',
@@ -374,7 +376,7 @@ class BWGViewSite {
374
  ), admin_url('admin-ajax.php')));
375
  ?>
376
  <div class="bwg_download_gallery">
377
- <a href="<?php echo $query_url; ?>">
378
  <i title="<?php _e('Download gallery', BWG()->prefix); ?>" class="bwg-icon-download bwg_ctrl_btn"></i>
379
  </a>
380
  </div>
@@ -425,22 +427,22 @@ class BWGViewSite {
425
  $bwg_ajax_reset = "";
426
  }
427
  ?>
428
- <div class="bwg_search_container_1" id="bwg_search_container_1_<?php echo $current_view; ?>">
429
- <div class="bwg_search_container_2" id="bwg_search_container_2_<?php echo $current_view; ?>">
430
  <span class="bwg_search_input_container">
431
  <span class="bwg_search_loupe_container1 bwg-hidden">
432
  <i title="<?php echo __('SEARCH...', BWG()->prefix); ?>" class="bwg-icon-search bwg_search" onclick="bwg_ajax('<?php echo $form_id; ?>', '<?php echo $current_view; ?>', '<?php echo $cur_gal_id; ?>', <?php echo $album_gallery_id; ?>, '', '<?php echo $type; ?>', 1)"></i>
433
  </span>
434
- <input id="bwg_search_input_<?php echo $current_view; ?>" class="bwg_search_input" type="text" onkeypress="bwg_key_press(this); return bwg_check_search_input_enter(this, event);" name="bwg_search_<?php echo $current_view; ?>" value="<?php echo esc_attr($bwg_search); ?>" placeholder="<?php echo $placeholder; ?>" />
435
- <span class="bwg_search_reset_container <?echo $bwg_search_reset; ?>">
436
  <i title="<?php echo __('Reset', BWG()->prefix); ?>" class="bwg-icon-times bwg_reset" onclick="bwg_clear_search_input('<?php echo $current_view; ?>'); <?php echo $bwg_ajax_reset;?> "></i>
437
  </span>
438
- <input id="bwg_images_count_<?php echo $current_view; ?>" class="bwg_search_input" type="hidden" name="bwg_images_count_<?php echo $current_view; ?>" value="<?php echo $images_count; ?>">
439
  <span class="search_placeholder_title" onclick="bwg_search_focus(this)" <?php echo $bwg_search_focus; ?>>
440
  <span class="bwg_search_loupe_container">
441
  <i title="<?php echo __('SEARCH...', BWG()->prefix); ?>" class="bwg-icon-search bwg_search"></i>
442
  </span>
443
- <span style="font-size: 12px; font-family: Ubuntu;"><?php echo $placeholder; ?></span>
444
  </span>
445
  </span>
446
  </div>
@@ -474,7 +476,7 @@ class BWGViewSite {
474
  }
475
  ?>
476
  <div class="bwg_order_cont">
477
- <select id="bwg_order_<?php echo $current_view; ?>" class="bwg_order bwg_order_<?php echo $current_view; ?>" onchange="bwg_ajax('<?php echo $form_id; ?>', '<?php echo $current_view; ?>', '<?php echo $cur_gal_id; ?>', <?php echo $album_gallery_id; ?>, '', '<?php echo $type; ?>', 1, '', this.value)">
478
  <option <?php if ( $sort_by == 'default' ) {
479
  echo 'selected';
480
  } ?> value="default"><?php echo __('Order by Default', BWG()->prefix); ?></option>
@@ -574,13 +576,13 @@ class BWGViewSite {
574
  echo '<style>' . $inline_style . '</style>';
575
  }
576
  if ( $theme_row->tags_view == 1 ) { ?>
577
- <div class="bwg_tags_container_<?php echo $current_view; ?>" >
578
  <div class="search_tags_container">
579
- <select class="search_tags" id="bwg_tag_id_<?php echo $cur_gal_id; ?>" multiple="multiple">
580
  <?php
581
  foreach ( $tags_rows as $tags_row ) {
582
  $selected = ( !empty($bwg_search_tags) && in_array($tags_row->term_id ? $tags_row->term_id : '', $bwg_search_tags)) ? 'selected="selected"' : ''; ?>
583
- <option value="<?php echo $tags_row->term_id ?>" <?php echo $selected; ?>><?php echo $tags_row->name ?></option>
584
  <?php
585
  }
586
  ?>
@@ -589,14 +591,14 @@ class BWGViewSite {
589
  <?php
590
  }
591
  else { ?>
592
- <div class="bwg_tags_container_<?php echo $current_view; ?>">
593
  <div class="bwg_tag_button_view_container" >
594
  <button type="button" class="bwg_all_tags active" data-filter="All Tags"><?php echo __('All Tags', BWG()->prefix);?></button><div class="verLine"></div>
595
  <?php
596
  foreach ( $tags_rows as $tags_row ) {
597
  $active = ( !empty($bwg_search_tags) && in_array($tags_row->term_id ? $tags_row->term_id : '', $bwg_search_tags)) ? 'active' : '';
598
  ?>
599
- <button type="button" class="bwg_tags_filter_buttons <?php echo $active ?>" data-filter="<?php echo $tags_row->name ?>" value="<?php echo $tags_row->term_id; ?>" ><?php echo $tags_row->name ?></button>
600
  <?php
601
  }
602
  ?>
@@ -604,13 +606,13 @@ class BWGViewSite {
604
  <div class="bwg_tag_button_see_all"><div class="see_all_tags show"><span>&#43;</span><?php echo __('see all tags', BWG()->prefix);?></div></div>
605
  <?php
606
  } ?>
607
- <input type="hidden" id="bwg_tag_id_<?php echo $cur_gal_id; ?>" value="<?php echo $get_filter_teg ?>" />
608
- <input type="hidden" class="current_view" value="<?php echo $current_view; ?>" />
609
- <input type="hidden" class="form_id" value="<?php echo $form_id; ?>" />
610
- <input type="hidden" class="cur_gal_id" value="<?php echo $cur_gal_id; ?>" />
611
- <input type="hidden" class="album_gallery_id" value="<?php echo $album_gallery_id; ?>" />
612
- <input type="hidden" class="type" value="<?php echo $type; ?>" />
613
- <input type="hidden" class="show_bottom_tag" value="<?php echo $show_bottom_tag; ?>" />
614
  </div>
615
  <?php
616
  }
@@ -776,15 +778,15 @@ class BWGViewSite {
776
  $next_page = "next-page-" . $current_view;
777
  $last_page = "last-page-" . $current_view;
778
  ?>
779
- <span class="bwg_nav_cont_<?php echo $current_view; ?>">
780
  <?php
781
  if ( $pagination == 1 ) {
782
  ?>
783
- <div class="tablenav-pages_<?php echo $current_view; ?>">
784
  <?php
785
  if ( $theme_row->page_nav_number ) {
786
  ?>
787
- <span class="displaying-num_<?php echo $current_view; ?>"><?php echo $count_items . ' ' . __(' item(s)', BWG()->prefix); ?></span>
788
  <?php
789
  }
790
  if ( $count_items > $limit ) {
@@ -809,21 +811,21 @@ class BWGViewSite {
809
  $last_page = "last-page disabled";
810
  }
811
  ?>
812
- <span class="pagination-links_<?php echo $current_view; ?> pagination-links" data-pages-count="<?php echo $items_county; ?>">
813
  <span class="pagination-links_col1">
814
- <a class="bwg-a <?php echo $first_page; ?>" title="<?php echo __('Go to the first page', BWG()->prefix); ?>" <?php echo (($enable_dynamic_url || $enable_seo) && $page_number > 1) ? 'href="' . esc_url(add_query_arg(array( "page_number_" . $current_view => 1 ), $_SERVER['REQUEST_URI'])) . '"' : ""; ?>><?php echo $first_button; ?></a>
815
- <a class="bwg-a <?php echo $prev_page; ?>" title="<?php echo __('Go to the previous page', BWG()->prefix); ?>" <?php echo (($enable_dynamic_url || $enable_seo) && $page_number > 1) ? 'href="' . esc_url(add_query_arg(array( "page_number_" . $current_view => $page_number - 1 ), $_SERVER['REQUEST_URI'])) . '"' : ""; ?>><?php echo $previous_button; ?></a>
816
  </span>
817
  <span class="pagination-links_col2">
818
- <input type="number" class="bwg_current_page" name="bwg_current_page" value="<?php echo $page_number; ?>" data-url-info="page_number_<?php echo $current_view; ?>" onkeypress="return bwg_change_page_<?php echo $current_view; ?>(event, this)" min="1" oninput="validity.valid||(value='')" />
819
  <?php echo __('of', BWG()->prefix); ?>
820
- <span class="total-pages_<?php echo $current_view; ?>">
821
- <?php echo $items_county; ?>
822
  </span>
823
  </span>
824
  <span class="pagination-links_col3">
825
- <a class="bwg-a <?php echo $next_page ?>" title="<?php echo __('Go to the next page', BWG()->prefix); ?>" <?php echo (($enable_dynamic_url || $enable_seo) && $page_number + 1 <= $items_county) ? 'href="' . esc_url(add_query_arg(array( "page_number_" . $current_view => $page_number + 1 ), $_SERVER['REQUEST_URI'])) . '"' : ""; ?>><?php echo $next_button; ?></a>
826
- <a class="bwg-a <?php echo $last_page ?>" title="<?php echo __('Go to the last page', BWG()->prefix); ?>" <?php echo (($enable_dynamic_url || $enable_seo) && $page_number < $items_county) ? 'href="' . esc_url(add_query_arg(array( "page_number_" . $current_view => $items_county ), $_SERVER['REQUEST_URI'])) . '"' : ""; ?>><?php echo $last_button; ?></a>
827
  </span>
828
  </span>
829
  <?php
@@ -835,9 +837,9 @@ class BWGViewSite {
835
  elseif ($pagination == 2) {
836
  if ($count_items > ($limit * ($page_number - 1)) + $items_per_page['images_per_page']) {
837
  ?>
838
- <div id="bwg_load_<?php echo $current_view; ?>" class="tablenav-pages_<?php echo $current_view; ?>">
839
- <a class="bwg-a bwg_load_btn_<?php echo $current_view; ?> bwg_load_btn" href="javascript:void(0);"><?php echo __('Load More...', BWG()->prefix); ?></a>
840
- <input type="hidden" id="bwg_load_more_<?php echo $current_view; ?>" name="bwg_load_more_<?php echo $current_view; ?>" value="on" />
841
  </div>
842
  <?php
843
  } else {
@@ -871,7 +873,7 @@ class BWGViewSite {
871
  $page_number = WDWLibrary::get('page_number_' . $current_view, 1, 'intval');
872
  $scroll_to_top = $pagination == 1 ? 1 : 0;
873
  ?>
874
- <input type="hidden" id="page_number_<?php echo $current_view; ?>" name="page_number_<?php echo $current_view; ?>" value="<?php echo $page_number; ?>" />
875
  <script type="text/javascript">
876
  function spider_page_<?php echo $current_view; ?>(cur, x, y, load_more) {
877
  if (typeof load_more == "undefined") {
58
  $params_array = $params['params_array'];
59
  $theme_row = $params['theme_row'];
60
  ?>
61
+ <div id="bwg_container1_<?php echo sanitize_html_class($bwg); ?>"
62
+ class="bwg_container bwg_thumbnail bwg_<?php echo sanitize_html_class($params['gallery_type']); ?>"
63
+ data-right-click-protection="<?php echo esc_attr(BWG()->options->image_right_click); ?>"
64
+ data-bwg="<?php echo esc_attr($bwg); ?>"
65
+ data-gallery-type="<?php echo esc_attr($params['gallery_type']); ?>"
66
+ data-current-url="<?php echo esc_url(addslashes(urldecode($params_array['current_url']))); ?>"
67
+ data-lightbox-url="<?php echo esc_url(addslashes(add_query_arg($params_array, admin_url('admin-ajax.php')))); ?>"
68
+ data-gallery-id="<?php echo esc_attr($params_array['gallery_id']); ?>"
69
+ data-popup-width="<?php echo esc_attr($params["popup_width"]); ?>"
70
+ data-popup-height="<?php echo esc_attr($params["popup_height"]); ?>"
71
+ data-is-album="<?php echo esc_attr($params["view_type"]); ?>"
72
+ data-buttons-position="<?php echo esc_attr($theme_row->lightbox_ctrl_btn_pos); ?>">
73
+ <div id="bwg_container2_<?php echo sanitize_html_class($bwg); ?>">
74
  <?php $this->loading($bwg, $params["image_enable_page"], $params['gallery_type'] ); ?>
75
+ <form id="gal_front_form_<?php echo sanitize_html_class($bwg); ?>"
76
  class="bwg-hidden"
77
  method="post"
78
  action="#"
79
+ data-current="<?php echo esc_attr($bwg); ?>"
80
+ data-shortcode-id="<?php echo isset($params['id']) ? esc_attr($params['id']) : 0; ?>"
81
+ data-gallery-type="<?php echo esc_attr($params['gallery_type']); ?>"
82
+ data-gallery-id="<?php echo esc_attr($params['gallery_id']); ?>"
83
+ data-tag="<?php echo esc_attr($params['tag']); ?>"
84
+ data-album-id="<?php echo esc_attr($params['album_id']); ?>"
85
+ data-theme-id="<?php echo esc_attr($params['theme_id']); ?>"
86
+ data-ajax-url="<?php echo esc_url(add_query_arg(array('action' => 'bwg_frontend_data'), admin_url('admin-ajax.php'))); ?>">
87
+ <div id="bwg_container3_<?php echo sanitize_html_class($bwg); ?>" class="bwg-background bwg-background-<?php echo sanitize_html_class($bwg); ?>">
88
  <?php
89
  $get_album_gallery_id = WDWLibrary::get("album_gallery_id_" . $bwg, 0, 'intval');
90
  if ( BWG()->options->front_ajax == "1" && isset($get_album_gallery_id) && intval($get_album_gallery_id) > 0 ) {
158
  echo '<style>' . $inline_style . '</style>';
159
  }
160
  ?>
161
+ <div id="bwg_spider_popup_loading_<?php echo sanitize_html_class($bwg); ?>" class="bwg_spider_popup_loading"></div>
162
+ <div id="spider_popup_overlay_<?php echo sanitize_html_class($bwg); ?>" class="spider_popup_overlay" onclick="spider_destroypopup(1000)"></div>
163
+ <input type="hidden" id="bwg_random_seed_<?php echo sanitize_html_class($bwg); ?>" value="<?php echo isset($GLOBALS['bwg_random_seed_' . $bwg]) ? esc_attr($GLOBALS['bwg_random_seed_' . $bwg]) : '' ?>">
164
  <?php
165
  }
166
  ?>
262
  $load_type_class = "bwg_load_more_ajax_loading";
263
  }
264
  ?>
265
+ <div id="ajax_loading_<?php echo sanitize_html_class($bwg); ?>" class="<?php echo sanitize_html_class($load_type_class); ?>">
266
  <div class="bwg_loading_div_2">
267
  <div class="bwg_loading_div_3">
268
+ <div id="loading_div_<?php echo sanitize_html_class($bwg); ?>" class="bwg_spider_ajax_loading">
269
  </div>
270
  </div>
271
  </div>
299
  echo '<style>' . $inline_style . '</style>';
300
  }
301
  ?>
302
+ <div class="bwg_back bwg_back_<?php echo sanitize_html_class($bwg); ?>" onclick="bwg_ajax('gal_front_form_<?php echo $bwg; ?>', '<?php echo $bwg; ?>', '<?php echo $params['container_id']; ?>', 'back', '', 'album')"><i class="bwg-icon-arrow-left"></i> <?php _e('Back', BWG()->prefix); ?></div>
303
  <?php
304
  }
305
 
341
  }
342
  if ( $params['showthumbs_name'] && isset($row->name) && $row->name != '' ) {
343
  ?>
344
+ <div class="bwg_gal_title_<?php echo sanitize_html_class($bwg); ?>"><?php echo WDWLibrary::strip_tags(stripslashes($row->name)); ?></div>
345
  <?php
346
  }
347
  if ( $params['show_gallery_description'] && isset($row->description) && $row->description != '' ) {
348
  ?>
349
+ <div class="bwg_gal_title_<?php echo sanitize_html_class($bwg); ?> bwg_gal_description_<?php echo sanitize_html_class($bwg); ?>"><?php echo WDWLibrary::strip_tags(stripslashes($row->description)); ?></div>
350
  <?php
351
  }
352
  }
362
  && ($params['gallery_row']->id == 0 || ($params['gallery_row']->gallery_type != 'facebook' && $params['gallery_row']->gallery_type != 'instagram' && $params['gallery_row']->gallery_type != 'instagram_post')) ) {
363
  if ( count($params['image_rows']['images']) ) {
364
  $bwg_tags_input_value = WDWLibrary::get('bwg_tag_id_'.$params['container_id']);
365
+ $bwg_download_nonce = wp_create_nonce( 'bwg-download-nonce' );
366
  $query_url = addslashes(add_query_arg(array(
367
  "action" => "download_gallery",
368
+ "_wpnonce" => esc_attr( $bwg_download_nonce ),
369
  "gallery_id" => $params['gallery_id'],
370
  "bwg" => $bwg,
371
  "type" => 'gallery',
376
  ), admin_url('admin-ajax.php')));
377
  ?>
378
  <div class="bwg_download_gallery">
379
+ <a href="<?php echo esc_url($query_url); ?>">
380
  <i title="<?php _e('Download gallery', BWG()->prefix); ?>" class="bwg-icon-download bwg_ctrl_btn"></i>
381
  </a>
382
  </div>
427
  $bwg_ajax_reset = "";
428
  }
429
  ?>
430
+ <div class="bwg_search_container_1" id="bwg_search_container_1_<?php echo sanitize_html_class($current_view); ?>">
431
+ <div class="bwg_search_container_2" id="bwg_search_container_2_<?php echo sanitize_html_class($current_view); ?>">
432
  <span class="bwg_search_input_container">
433
  <span class="bwg_search_loupe_container1 bwg-hidden">
434
  <i title="<?php echo __('SEARCH...', BWG()->prefix); ?>" class="bwg-icon-search bwg_search" onclick="bwg_ajax('<?php echo $form_id; ?>', '<?php echo $current_view; ?>', '<?php echo $cur_gal_id; ?>', <?php echo $album_gallery_id; ?>, '', '<?php echo $type; ?>', 1)"></i>
435
  </span>
436
+ <input id="bwg_search_input_<?php echo sanitize_html_class($current_view); ?>" class="bwg_search_input" type="text" onkeypress="bwg_key_press(this); return bwg_check_search_input_enter(this, event);" name="bwg_search_<?php echo $current_view; ?>" value="<?php echo esc_attr($bwg_search); ?>" placeholder="<?php echo esc_attr($placeholder); ?>" />
437
+ <span class="bwg_search_reset_container <?echo sanitize_html_class($bwg_search_reset); ?>">
438
  <i title="<?php echo __('Reset', BWG()->prefix); ?>" class="bwg-icon-times bwg_reset" onclick="bwg_clear_search_input('<?php echo $current_view; ?>'); <?php echo $bwg_ajax_reset;?> "></i>
439
  </span>
440
+ <input id="bwg_images_count_<?php echo sanitize_html_class($current_view); ?>" class="bwg_search_input" type="hidden" name="bwg_images_count_<?php echo esc_attr($current_view); ?>" value="<?php echo esc_attr($images_count); ?>">
441
  <span class="search_placeholder_title" onclick="bwg_search_focus(this)" <?php echo $bwg_search_focus; ?>>
442
  <span class="bwg_search_loupe_container">
443
  <i title="<?php echo __('SEARCH...', BWG()->prefix); ?>" class="bwg-icon-search bwg_search"></i>
444
  </span>
445
+ <span style="font-size: 12px; font-family: Ubuntu;"><?php echo esc_html($placeholder); ?></span>
446
  </span>
447
  </span>
448
  </div>
476
  }
477
  ?>
478
  <div class="bwg_order_cont">
479
+ <select id="bwg_order_<?php echo sanitize_html_class($current_view); ?>" class="bwg_order bwg_order_<?php echo sanitize_html_class($current_view); ?>" onchange="bwg_ajax('<?php echo $form_id; ?>', '<?php echo $current_view; ?>', '<?php echo $cur_gal_id; ?>', <?php echo $album_gallery_id; ?>, '', '<?php echo $type; ?>', 1, '', this.value)">
480
  <option <?php if ( $sort_by == 'default' ) {
481
  echo 'selected';
482
  } ?> value="default"><?php echo __('Order by Default', BWG()->prefix); ?></option>
576
  echo '<style>' . $inline_style . '</style>';
577
  }
578
  if ( $theme_row->tags_view == 1 ) { ?>
579
+ <div class="bwg_tags_container_<?php echo sanitize_html_class($current_view); ?>" >
580
  <div class="search_tags_container">
581
+ <select class="search_tags" id="bwg_tag_id_<?php echo sanitize_html_class($cur_gal_id); ?>" multiple="multiple">
582
  <?php
583
  foreach ( $tags_rows as $tags_row ) {
584
  $selected = ( !empty($bwg_search_tags) && in_array($tags_row->term_id ? $tags_row->term_id : '', $bwg_search_tags)) ? 'selected="selected"' : ''; ?>
585
+ <option value="<?php echo esc_attr($tags_row->term_id) ?>" <?php echo $selected; ?>><?php echo esc_html($tags_row->name) ?></option>
586
  <?php
587
  }
588
  ?>
591
  <?php
592
  }
593
  else { ?>
594
+ <div class="bwg_tags_container_<?php echo sanitize_html_class($current_view); ?>">
595
  <div class="bwg_tag_button_view_container" >
596
  <button type="button" class="bwg_all_tags active" data-filter="All Tags"><?php echo __('All Tags', BWG()->prefix);?></button><div class="verLine"></div>
597
  <?php
598
  foreach ( $tags_rows as $tags_row ) {
599
  $active = ( !empty($bwg_search_tags) && in_array($tags_row->term_id ? $tags_row->term_id : '', $bwg_search_tags)) ? 'active' : '';
600
  ?>
601
+ <button type="button" class="bwg_tags_filter_buttons <?php echo sanitize_html_class($active) ?>" data-filter="<?php echo esc_attr($tags_row->name) ?>" value="<?php echo esc_attr($tags_row->term_id); ?>" ><?php echo esc_html($tags_row->name) ?></button>
602
  <?php
603
  }
604
  ?>
606
  <div class="bwg_tag_button_see_all"><div class="see_all_tags show"><span>&#43;</span><?php echo __('see all tags', BWG()->prefix);?></div></div>
607
  <?php
608
  } ?>
609
+ <input type="hidden" id="bwg_tag_id_<?php echo sanitize_html_class($cur_gal_id); ?>" value="<?php echo esc_attr($get_filter_teg) ?>" />
610
+ <input type="hidden" class="current_view" value="<?php echo esc_attr($current_view); ?>" />
611
+ <input type="hidden" class="form_id" value="<?php echo esc_attr($form_id); ?>" />
612
+ <input type="hidden" class="cur_gal_id" value="<?php echo esc_attr($cur_gal_id); ?>" />
613
+ <input type="hidden" class="album_gallery_id" value="<?php echo esc_attr($album_gallery_id); ?>" />
614
+ <input type="hidden" class="type" value="<?php echo esc_attr($type); ?>" />
615
+ <input type="hidden" class="show_bottom_tag" value="<?php echo esc_attr($show_bottom_tag); ?>" />
616
  </div>
617
  <?php
618
  }
778
  $next_page = "next-page-" . $current_view;
779
  $last_page = "last-page-" . $current_view;
780
  ?>
781
+ <span class="bwg_nav_cont_<?php echo sanitize_html_class($current_view); ?>">
782
  <?php
783
  if ( $pagination == 1 ) {
784
  ?>
785
+ <div class="tablenav-pages_<?php echo sanitize_html_class($current_view); ?>">
786
  <?php
787
  if ( $theme_row->page_nav_number ) {
788
  ?>
789
+ <span class="displaying-num_<?php echo sanitize_html_class($current_view); ?>"><?php echo esc_html($count_items) . ' ' . __(' item(s)', BWG()->prefix); ?></span>
790
  <?php
791
  }
792
  if ( $count_items > $limit ) {
811
  $last_page = "last-page disabled";
812
  }
813
  ?>
814
+ <span class="pagination-links_<?php echo sanitize_html_class($current_view); ?> pagination-links" data-pages-count="<?php echo esc_attr($items_county); ?>">
815
  <span class="pagination-links_col1">
816
+ <a class="bwg-a <?php echo esc_html($first_page); ?>" title="<?php echo __('Go to the first page', BWG()->prefix); ?>" <?php echo (($enable_dynamic_url || $enable_seo) && $page_number > 1) ? 'href="' . esc_url(add_query_arg(array( "page_number_" . $current_view => 1 ), $_SERVER['REQUEST_URI'])) . '"' : ""; ?>><?php echo esc_html($first_button); ?></a>
817
+ <a class="bwg-a <?php echo esc_html($prev_page); ?>" title="<?php echo __('Go to the previous page', BWG()->prefix); ?>" <?php echo (($enable_dynamic_url || $enable_seo) && $page_number > 1) ? 'href="' . esc_url(add_query_arg(array( "page_number_" . $current_view => $page_number - 1 ), $_SERVER['REQUEST_URI'])) . '"' : ""; ?>><?php echo esc_html($previous_button); ?></a>
818
  </span>
819
  <span class="pagination-links_col2">
820
+ <input type="number" class="bwg_current_page" name="bwg_current_page" value="<?php echo esc_attr($page_number); ?>" data-url-info="page_number_<?php echo esc_attr($current_view); ?>" onkeypress="return bwg_change_page_<?php echo $current_view; ?>(event, this)" min="1" oninput="validity.valid||(value='')" />
821
  <?php echo __('of', BWG()->prefix); ?>
822
+ <span class="total-pages_<?php echo sanitize_html_class($current_view); ?>">
823
+ <?php echo esc_html($items_county); ?>
824
  </span>
825
  </span>
826
  <span class="pagination-links_col3">
827
+ <a class="bwg-a <?php echo esc_html($next_page) ?>" title="<?php echo __('Go to the next page', BWG()->prefix); ?>" <?php echo (($enable_dynamic_url || $enable_seo) && $page_number + 1 <= $items_county) ? 'href="' . esc_url(add_query_arg(array( "page_number_" . $current_view => $page_number + 1 ), $_SERVER['REQUEST_URI'])) . '"' : ""; ?>><?php echo esc_html($next_button); ?></a>
828
+ <a class="bwg-a <?php echo esc_html($last_page) ?>" title="<?php echo __('Go to the last page', BWG()->prefix); ?>" <?php echo (($enable_dynamic_url || $enable_seo) && $page_number < $items_county) ? 'href="' . esc_url(add_query_arg(array( "page_number_" . $current_view => $items_county ), $_SERVER['REQUEST_URI'])) . '"' : ""; ?>><?php echo esc_html($last_button); ?></a>
829
  </span>
830
  </span>
831
  <?php
837
  elseif ($pagination == 2) {
838
  if ($count_items > ($limit * ($page_number - 1)) + $items_per_page['images_per_page']) {
839
  ?>
840
+ <div id="bwg_load_<?php echo sanitize_html_class($current_view); ?>" class="tablenav-pages_<?php echo sanitize_html_class($current_view); ?>">
841
+ <a class="bwg-a bwg_load_btn_<?php echo sanitize_html_class($current_view); ?> bwg_load_btn" href="javascript:void(0);"><?php echo __('Load More...', BWG()->prefix); ?></a>
842
+ <input type="hidden" id="bwg_load_more_<?php echo sanitize_html_class($current_view); ?>" name="bwg_load_more_<?php echo esc_attr($current_view); ?>" value="on" />
843
  </div>
844
  <?php
845
  } else {
873
  $page_number = WDWLibrary::get('page_number_' . $current_view, 1, 'intval');
874
  $scroll_to_top = $pagination == 1 ? 1 : 0;
875
  ?>
876
+ <input type="hidden" id="page_number_<?php echo sanitize_html_class($current_view); ?>" name="page_number_<?php echo esc_attr($current_view); ?>" value="<?php echo esc_attr($page_number); ?>" />
877
  <script type="text/javascript">
878
  function spider_page_<?php echo $current_view; ?>(cur, x, y, load_more) {
879
  if (typeof load_more == "undefined") {
js/bwg.js CHANGED
@@ -3,7 +3,12 @@ jQuery( function () {
3
  if ( jQuery( '.google_font' ).length ) {
4
  jQuery( '.google_font' ).each( function () {
5
  var bwg_google_font = jQuery( this );
6
- bwg_google_font.fontselect();
 
 
 
 
 
7
  input_name = jQuery( this ).closest( 'td' ).find( '.radio_google_fonts' ).children( 'input' ).attr( 'name' );
8
  data_view = input_name + '0';
9
  if ( jQuery( "#" + data_view ).is( ":checked" ) ) {
@@ -14,11 +19,11 @@ jQuery( function () {
14
  bwg_google_font.next( '.font-select' ).show();
15
  jQuery( '#' + input_name ).hide();
16
  }
17
- } )
18
  }
19
  jQuery( '.default-font' ).on( 'change', function () {
20
  jQuery( this ).css( { 'font-family': jQuery( this ).val() } );
21
- } );
22
 
23
  /* press ESC hide loading. */
24
  jQuery( document ).keyup( function ( e ) {
@@ -2905,3 +2910,21 @@ jQuery(document).mouseup(function(e){
2905
  }
2906
  }
2907
  });
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
3
  if ( jQuery( '.google_font' ).length ) {
4
  jQuery( '.google_font' ).each( function () {
5
  var bwg_google_font = jQuery( this );
6
+ bwg_google_font.fontselect({
7
+ searchable: true,
8
+ systemFonts: false,
9
+ }).on('change', function() {
10
+ applyGoogleFont(bwg_google_font, this.value);
11
+ });
12
  input_name = jQuery( this ).closest( 'td' ).find( '.radio_google_fonts' ).children( 'input' ).attr( 'name' );
13
  data_view = input_name + '0';
14
  if ( jQuery( "#" + data_view ).is( ":checked" ) ) {
19
  bwg_google_font.next( '.font-select' ).show();
20
  jQuery( '#' + input_name ).hide();
21
  }
22
+ });
23
  }
24
  jQuery( '.default-font' ).on( 'change', function () {
25
  jQuery( this ).css( { 'font-family': jQuery( this ).val() } );
26
+ });
27
 
28
  /* press ESC hide loading. */
29
  jQuery( document ).keyup( function ( e ) {
2910
  }
2911
  }
2912
  });
2913
+
2914
+
2915
+ function applyGoogleFont(that, font) {
2916
+ // Replace + signs with spaces for css
2917
+ font = font.replace(/\+/g, ' ');
2918
+ // Split font into family and weight/style
2919
+ font = font.split(':');
2920
+ var fontFamily = font[0];
2921
+ var fontSpecs = font[1] || null;
2922
+ var italic = false, fontWeight = 400;
2923
+
2924
+ if (/italic/.test(fontSpecs)) {
2925
+ italic = true;
2926
+ fontSpecs = fontSpecs.replace('italic','');
2927
+ }
2928
+ fontWeight = +fontSpecs;
2929
+ that.val(fontFamily);
2930
+ }
js/bwg_frontend.js CHANGED
@@ -1110,7 +1110,7 @@ function bwg_thumbnail_masonry(that) {
1110
  if ( jQuery("#bwg_album_masonry_" + bwg ).length) {
1111
  type = "#bwg_album_masonry_" + bwg;
1112
  }
1113
- if( jQuery(".bwg-container-temp" + bwg ).length === 0) {
1114
  jQuery(type).clone().appendTo("#bwg_container3_" + bwg).removeAttr("id").removeClass("bwg-container-" + bwg).addClass("bwg-container-temp" + bwg);
1115
  jQuery(".bwg-container-temp" + bwg).empty();
1116
  }
@@ -1174,11 +1174,11 @@ function bwg_thumbnail_masonry(that) {
1174
  var order = column_heights.indexOf( Math.min.apply( Math, column_heights ) );
1175
  jQuery( this ).css( { width: min_width + "%", order: order + 1 } );
1176
  if ( jQuery( this ).find("img").attr("data-width").length > 0 && jQuery( this ).find("img").attr("data-height").length > 0 ) {
1177
- scale = jQuery( this ).find("img").data("width") / jQuery( this ).find("img").data("height");
1178
- scaleHeight = (jQuery( this ).find("img").width() - (thumb_padding / column_count) ) / scale;
1179
  /* calculating height of image title and description */
1180
  /* finding title/description with 'a>' selector to avoid calculating heights for 'Show on hover' option. */
1181
- title_h = this.querySelector("a .bwg-zoom-effect-overlay .bwg-title2") || !this.querySelector("a .bwg-title2") ? 0 : this.querySelector("a .bwg-title2").getClientRects()[0].height;
1182
  desc_h = ( jQuery( this ).find('.bwg-masonry-thumb-description').length > 0 ) ? jQuery( this ).find('.bwg-masonry-thumb-description').height() : 0;
1183
  var k = title_h + desc_h;
1184
  jQuery(this).height( Math.floor(scaleHeight + k + (thumb_border * 2)));
1110
  if ( jQuery("#bwg_album_masonry_" + bwg ).length) {
1111
  type = "#bwg_album_masonry_" + bwg;
1112
  }
1113
+ if ( jQuery(".bwg-container-temp" + bwg ).length === 0 ) {
1114
  jQuery(type).clone().appendTo("#bwg_container3_" + bwg).removeAttr("id").removeClass("bwg-container-" + bwg).addClass("bwg-container-temp" + bwg);
1115
  jQuery(".bwg-container-temp" + bwg).empty();
1116
  }
1174
  var order = column_heights.indexOf( Math.min.apply( Math, column_heights ) );
1175
  jQuery( this ).css( { width: min_width + "%", order: order + 1 } );
1176
  if ( jQuery( this ).find("img").attr("data-width").length > 0 && jQuery( this ).find("img").attr("data-height").length > 0 ) {
1177
+ scale = parseInt(jQuery( this ).find("img").data("width")) / parseInt(jQuery( this ).find("img").data("height"));
1178
+ scaleHeight = ( jQuery( this ).find("img").width() - (thumb_padding / column_count) ) / scale;
1179
  /* calculating height of image title and description */
1180
  /* finding title/description with 'a>' selector to avoid calculating heights for 'Show on hover' option. */
1181
+ title_h = this.querySelector("a .bwg-zoom-effect-overlay .bwg-title2") || !this.querySelector("a .bwg-title1 .bwg-title2") ? 0 : this.querySelector("a .bwg-title1 .bwg-title2").getClientRects()[0].height;
1182
  desc_h = ( jQuery( this ).find('.bwg-masonry-thumb-description').length > 0 ) ? jQuery( this ).find('.bwg-masonry-thumb-description').height() : 0;
1183
  var k = title_h + desc_h;
1184
  jQuery(this).height( Math.floor(scaleHeight + k + (thumb_border * 2)));
js/bwg_gallery_box.js CHANGED
@@ -219,7 +219,7 @@ function gallery_box_ready() {
219
  }
220
  });
221
  }
222
- var mousewheelevt = (/Firefox/i.test(navigator.userAgent)) ? "DOMMouseScroll" : "mousewheel"; /*FF doesn't recognize mousewheel as of FF3.x*/
223
  jQuery('.bwg_filmstrip').on(mousewheelevt, function(e) {
224
  var evt = window.event || e; /* Equalize event object.*/
225
  evt = evt.originalEvent ? evt.originalEvent : evt; /* Convert to originalEvent if possible.*/
@@ -345,7 +345,7 @@ function gallery_box_ready() {
345
  jQuery( ".bwg_filmstrip_thumbnails" ).stop(true, false);
346
  if ((jQuery(".bwg_filmstrip_thumbnails").position().top) < 0) {
347
  jQuery(".bwg_filmstrip_right").css({opacity: 1});
348
- if (jQuery(".bwg_filmstrip_thumbnails").position().top > - (gallery_box_data['filmstrip_thumb_right_left_space'] + gallery_box_data['image_filmstrip_width'])) {
349
  jQuery(".bwg_filmstrip_thumbnails").animate({ top: 0 }, 500, 'linear');
350
  }
351
  else {
@@ -432,73 +432,73 @@ function gallery_box_ready() {
432
  jQuery(".bwg_ecommerce, .bwg_ecommerce_close_btn").on(bwg_click, function() { bwg_ecommerce() });
433
  /* Open/close control buttons.*/
434
  jQuery(".bwg_toggle_container").on(bwg_click, function () {
435
- var bwg_open_toggle_btn_class = (gallery_box_data['lightbox_ctrl_btn_pos'] == 'top') ? 'bwg-icon-caret-up' : 'bwg-icon-caret-down';
436
- var bwg_close_toggle_btn_class = (gallery_box_data['lightbox_ctrl_btn_pos'] == 'top') ? 'bwg-icon-caret-down' : 'bwg-icon-caret-up';
437
 
438
- if (jQuery(".bwg_toggle_container i").hasClass(bwg_open_toggle_btn_class)) {
439
- if ((!gallery_box_data['enable_image_filmstrip'] || gallery_box_data['lightbox_filmstrip_pos'] != 'bottom') && gallery_box_data['lightbox_ctrl_btn_pos'] == 'bottom' && gallery_box_data['lightbox_rate_pos'] == 'bottom') {
440
- jQuery(".bwg_image_rate").animate({bottom: 0}, 500);
441
- }
442
- else if ((!gallery_box_data['enable_image_filmstrip'] || gallery_box_data['lightbox_filmstrip_pos'] != 'top') && gallery_box_data['lightbox_ctrl_btn_pos'] == 'top' && gallery_box_data['lightbox_rate_pos'] == 'top') {
443
- jQuery(".bwg_image_rate").animate({top: 0}, 500);
444
- }
445
- if ((!gallery_box_data['enable_image_filmstrip'] || gallery_box_data['lightbox_filmstrip_pos'] != 'bottom') && gallery_box_data['lightbox_ctrl_btn_pos'] == 'bottom' && gallery_box_data['lightbox_hit_pos'] == 'bottom') {
446
- jQuery(".bwg_image_hit").animate({bottom: 0}, 500);
447
- }
448
- else if ((!gallery_box_data['enable_image_filmstrip'] || gallery_box_data['lightbox_filmstrip_pos'] != 'top') && gallery_box_data['lightbox_ctrl_btn_pos'] == 'top' && gallery_box_data['lightbox_hit_pos'] == 'top') {
449
- jQuery(".bwg_image_hit").animate({top: 0}, 500);
450
- }
451
- if ( gallery_box_data['lightbox_ctrl_btn_pos'] == 'bottom' ) {
452
- jQuery(".bwg_ctrl_btn_container").animate({ bottom : '-' + jQuery(".bwg_ctrl_btn_container").height()}, 500).addClass('closed');
453
- jQuery(".bwg_toggle_container").animate({
454
- bottom : 0
455
- }, {
456
- duration: 500,
457
- complete: function () { jQuery(".bwg_toggle_container i").attr("class", "bwg_toggle_btn " + bwg_close_toggle_btn_class) }
458
- });
459
- } else {
460
- jQuery(".bwg_ctrl_btn_container").animate({ top : '-' + jQuery(".bwg_ctrl_btn_container").height()}, 500).addClass('closed');
461
- jQuery(".bwg_toggle_container").animate({
462
- top : 0
463
- }, {
464
- duration: 500,
465
- complete: function () { jQuery(".bwg_toggle_container i").attr("class", "bwg_toggle_btn " + bwg_close_toggle_btn_class) }
466
- });
467
- }
 
 
 
 
 
 
 
 
 
 
 
 
 
468
  }
469
- else {
470
- if ((!gallery_box_data['enable_image_filmstrip'] || gallery_box_data['lightbox_filmstrip_pos'] != 'bottom') && gallery_box_data['lightbox_ctrl_btn_pos'] == 'bottom' && gallery_box_data['lightbox_rate_pos'] == 'bottom') {
471
- jQuery(".bwg_image_rate").animate({bottom: jQuery(".bwg_ctrl_btn_container").height()}, 500);
472
- }
473
- else if ((!gallery_box_data['enable_image_filmstrip'] || gallery_box_data['lightbox_filmstrip_pos'] != 'top') && gallery_box_data['lightbox_ctrl_btn_pos'] == 'top' && gallery_box_data['lightbox_rate_pos'] == 'top') {
474
- jQuery(".bwg_image_rate").animate({top: jQuery(".bwg_ctrl_btn_container").height()}, 500);
475
- }
476
- if ((!gallery_box_data['enable_image_filmstrip'] || gallery_box_data['lightbox_filmstrip_pos'] != 'bottom') && gallery_box_data['lightbox_ctrl_btn_pos'] == 'bottom' && gallery_box_data['lightbox_hit_pos'] == 'bottom') {
477
- jQuery(".bwg_image_hit").animate({bottom: jQuery(".bwg_ctrl_btn_container").height()}, 500);
478
- }
479
- else if ((!gallery_box_data['enable_image_filmstrip'] || gallery_box_data['lightbox_filmstrip_pos'] != 'top') && gallery_box_data['lightbox_ctrl_btn_pos'] == 'top' && gallery_box_data['lightbox_hit_pos'] == 'top') {
480
- jQuery(".bwg_image_hit").animate({top: jQuery(".bwg_ctrl_btn_container").height()}, 500);
481
- }
482
 
483
- if ( gallery_box_data['lightbox_ctrl_btn_pos'] == 'bottom' ) {
484
- jQuery(".bwg_ctrl_btn_container").animate({ bottom: 0 }, 500).removeClass('closed');
485
- jQuery(".bwg_toggle_container").animate({
486
- bottom : jQuery(".bwg_ctrl_btn_container").height()
487
- }, {
488
- duration: 500,
489
- complete: function () { jQuery(".bwg_toggle_container i").attr("class", "bwg_toggle_btn " + bwg_open_toggle_btn_class) }
490
- });
491
- } else {
492
- jQuery(".bwg_ctrl_btn_container").animate({ top: 0 }, 500).removeClass('closed');
493
- jQuery(".bwg_toggle_container").animate({
494
- top : jQuery(".bwg_ctrl_btn_container").height()
495
- }, {
496
- duration: 500,
497
- complete: function () { jQuery(".bwg_toggle_container i").attr("class", "bwg_toggle_btn " + bwg_open_toggle_btn_class) }
498
- });
499
- }
500
  }
501
- bwg_info_position( true );
 
502
  });
503
  /* Set window height not full screen */
504
  var bwg_windowheight = window.innerHeight;
@@ -782,10 +782,10 @@ function bwg_first_image_load(popup, lightbox_ctrl_btn_pos) {
782
 
783
  var bwg_ctrl_btn_container_height = jQuery(".bwg_ctrl_btn_container").height();
784
  if (lightbox_ctrl_btn_pos == 'bottom') {
785
- jQuery(".bwg_toggle_container").css("bottom", bwg_ctrl_btn_container_height + "px");
786
  }
787
  else if (lightbox_ctrl_btn_pos == 'top') {
788
- jQuery(".bwg_toggle_container").css("top", bwg_ctrl_btn_container_height + "px");
789
  }
790
  jQuery( ".bwg_spider_popup_loading" ).hide();
791
  if ( gallery_box_data['preload_images'] == 1 ) {
@@ -922,6 +922,7 @@ function spider_ajax_save(form_id) {
922
  url: jQuery('#' + form_id).attr('action'),
923
  data: post_data,
924
  success: function (data) {
 
925
  var str = jQuery(data).find('.bwg_comments').html();
926
  jQuery('.bwg_comments').html(str);
927
  },
@@ -947,10 +948,10 @@ function spider_ajax_save(form_id) {
947
  }
948
 
949
  /* Submit rating. */
950
- function spider_rate_ajax_save(form_id) {
951
  var post_data = {};
952
  post_data["image_id"] = jQuery("#" + form_id + " input[name='image_id']").val();
953
- post_data["rate"] = jQuery("#" + form_id + " input[name='score']").val();
954
  post_data["ajax_task"] = jQuery("#rate_ajax_task").val();
955
  return jQuery.ajax({
956
  type: "POST",
@@ -1001,13 +1002,13 @@ function spider_check_required(id, name) {
1001
 
1002
  /* Check if privacy polic field is checked. */
1003
  function comment_check_privacy_policy() {
1004
- var bwg_submit = jQuery('#bwg_submit');
1005
- bwg_submit.removeClass('bwg-submit-disabled');
1006
- bwg_submit.removeAttr("disabled");
1007
- if ( !jQuery('#bwg_comment_privacy_policy').is(':checked') ) {
1008
- bwg_submit.addClass('bwg-submit-disabled');
1009
- bwg_submit.attr('disabled', 'disabled');
1010
- }
1011
  }
1012
 
1013
  /* Check Email. */
@@ -1051,58 +1052,58 @@ function bwg_play_instagram_video(obj,bwg) {
1051
  * @returns {boolean}
1052
  */
1053
  function bwg_add_comment() {
1054
- var form = jQuery('#bwg_comment_form');
1055
- var url = form.attr('action');
1056
- var post_data = {};
1057
- post_data['ajax_task'] = 'add_comment';
1058
- post_data['comment_name'] = form.find('#bwg_name').val();
1059
  post_data['comment_email'] = form.find('#bwg_email').val();
1060
  post_data['comment_text'] = form.find('#bwg_comment').val();
1061
  post_data['comment_captcha'] = form.find('#bwg_captcha_input').val();
1062
  post_data['popup_enable_captcha'] = form.find('#bwg_popup_enable_captcha').val();
1063
  post_data['privacy_policy'] = ( form.find('#bwg_comment_privacy_policy').is(":checked") ) ? 1 : 0;
1064
- post_data['comment_image_id'] = jQuery('#bwg_popup_image').attr('image_id');
1065
  post_data['comment_moderation'] = form.find('#bwg_comment_moderation').val();
1066
- jQuery('.bwg_spider_ajax_loading').hide();
1067
- jQuery.ajax({
1068
- url: url,
1069
- type: "POST",
1070
- dataType: 'json',
1071
- data: post_data,
1072
- success: function ( res ) {
1073
- jQuery('.bwg_comment_error').text('');
1074
- if ( res.error == true ) {
1075
- jQuery.each(res.error_messages, function( index, value ) {
1076
- if ( value ) {
1077
- jQuery('.bwg_comment_'+ index +'_error').text(value);
1078
- }
1079
- });
1080
- }
1081
- else {
1082
  form.find('#bwg_comment').val('');
1083
- jQuery('.bwg_comment_waiting_message').hide();
1084
- if( res.published == 0 ) {
1085
- jQuery('.bwg_comment_waiting_message').show();
1086
- }
1087
- if ( res.html_comments_block != '' ) {
1088
- jQuery('#bwg_added_comments').html(res.html_comments_block).show();
1089
- }
1090
- }
1091
- },
1092
- beforeSend: function() {
1093
- jQuery('.bwg_spider_ajax_loading').show();
1094
- },
1095
- complete: function() {
1096
- if ( form.find('#bwg_comment_privacy_policy').length > 0 ) {
1097
- form.find('#bwg_comment_privacy_policy').prop('checked', false);
1098
- comment_check_privacy_policy();
1099
- }
1100
- bwg_captcha_refresh('bwg_captcha');
1101
- jQuery('.bwg_spider_ajax_loading').hide();
1102
- },
1103
- error:function() {}
1104
- });
1105
- return false;
1106
  }
1107
 
1108
  /**
@@ -1112,29 +1113,29 @@ function bwg_add_comment() {
1112
  * @returns {boolean}
1113
  */
1114
  function bwg_remove_comment( id_comment ) {
1115
- var form = jQuery('#bwg_comment_form');
1116
- var url = form.attr('action');
1117
- var post_data = {};
1118
- post_data['ajax_task'] = 'delete_comment';
1119
- post_data['id_image'] = jQuery('#bwg_popup_image').attr('image_id');
1120
- post_data['id_comment'] = id_comment;
1121
- jQuery.ajax({
1122
- url: url,
1123
- type: "POST",
1124
- dataType: 'json',
1125
- data: post_data,
1126
- success: function ( res ) {
1127
- if ( res.error == false) {
1128
- jQuery('#bwg_comment_block_' + id_comment ).fadeOut( "slow").remove();
1129
- }
1130
- },
1131
- beforeSend: function() {
1132
- },
1133
- complete:function() {
1134
- },
1135
- error:function() {}
1136
- });
1137
- return false;
1138
  }
1139
 
1140
  function bwg_gallery_box( image_id, bwg_container, openEcommerce, gallery_id ) {
@@ -1161,7 +1162,7 @@ function bwg_gallery_box( image_id, bwg_container, openEcommerce, gallery_id ) {
1161
  var ecommerce = openEcommerce == true ? "&open_ecommerce=1" : "";
1162
  var filtersearchname = jQuery("#bwg_search_input_" + bwg ).val();
1163
  var filtersortby = jQuery("#bwg_order_" + bwg).val() ? "&filtersortby=" + jQuery("#bwg_order_" + bwg).val() : '';
1164
- filtersearchname = filtersearchname ? filtersearchname : '';
1165
 
1166
  if ( typeof gallery_id != "undefined" ) {
1167
  /* Open lightbox with hash.*/
@@ -1170,7 +1171,7 @@ function bwg_gallery_box( image_id, bwg_container, openEcommerce, gallery_id ) {
1170
  var open_comment = '';
1171
  var open_comment_attr = jQuery('#bwg_blog_style_share_buttons_' + image_id).attr('data-open-comment');
1172
  if (typeof open_comment_attr !== typeof undefined && open_comment_attr !== false) {
1173
- open_comment = '&open_comment=1';
1174
  }
1175
  var bwg_random_seed = jQuery("#bwg_random_seed_"+bwg).val();
1176
  spider_createpopup(bwg_lightbox_url + '&bwg_random_seed='+bwg_random_seed+'&image_id=' + image_id + "&filter_tag=" + filterTags + ecommerce + open_comment + '&filter_search_name=' + filtersearchname + filtersortby, bwg, bwg_container.data('popup-width'), bwg_container.data('popup-height'), 1, 'testpopup', 5, bwg_container.data('buttons-position'));
@@ -1191,21 +1192,21 @@ function bwg_change_image_lightbox(current_key, key, data, from_effect) {
1191
  jQuery(".bwg_image_info").css("height","auto");
1192
  setTimeout(function(){
1193
  bwg_info_height_set();
1194
- if(jQuery('.bwg_image_description').height() > jQuery('.bwg_image_info').height() && jQuery('.mCSB_container').hasClass('mCS_no_scrollbar')){
1195
- jQuery(".bwg_image_info").mCustomScrollbar("destroy");
1196
- }
1197
- if (!jQuery('.bwg_image_info').hasClass('mCustomScrollbar')) {
1198
- if (typeof jQuery().mCustomScrollbar !== 'undefined' && jQuery.isFunction(jQuery().mCustomScrollbar)) {
1199
- jQuery(".bwg_image_info").mCustomScrollbar({
1200
- scrollInertia: 150,
1201
- theme: 'dark-thick',
1202
- advanced:{
1203
- updateOnContentResize: true
1204
- }
1205
- });
1206
- }
1207
- }
1208
- }, 200);
1209
  jQuery("#spider_popup_left").show();
1210
  jQuery("#spider_popup_right").show();
1211
  jQuery(".bwg_image_info").hide();
@@ -1301,18 +1302,20 @@ function bwg_change_image_lightbox(current_key, key, data, from_effect) {
1301
  history.replaceState(undefined, undefined, "#bwg" + gallery_box_data['gallery_id'] + "/" + data[key]["id"]);
1302
  }
1303
  jQuery("#bwg_rate_form input[name='image_id']").val(data[key]["id"]);
1304
- /* Change image id for rating.*/
1305
- if (gallery_box_data['popup_enable_rate']) {
 
 
 
 
1306
  jQuery("#bwg_star").attr("data-score", data[key]["avg_rating"]);
1307
  jQuery("#bwg_star").removeAttr("title");
1308
  data[key]['cur_key'] = key;
1309
  bwg_rating( data[key]["rate"], data[key]["rate_count"], data[key]["avg_rating"], key );
1310
  }
1311
- /* Increase image hit counter.*/
1312
- spider_set_input_value('rate_ajax_task', 'save_hit_count');
1313
 
1314
- spider_rate_ajax_save('bwg_rate_form');
1315
  jQuery(".bwg_image_hits span").html(++data[key]["hit_count"]);
 
1316
  /* Change image id.*/
1317
  jQuery("#bwg_popup_image").attr('image_id', data[key]["id"]);
1318
  /* Change image title, description.*/
@@ -1437,15 +1440,15 @@ function bwg_change_image_lightbox(current_key, key, data, from_effect) {
1437
  if (jQuery(".bwg_comment_container").hasClass("bwg_open")) {
1438
  jQuery(".bwg_comments .mCSB_container").css("top","0");
1439
  /* Todo: do not call comments if it's empty */
1440
- /* if (data[key]["comment_count"] == 0) {
1441
- jQuery("#bwg_added_comments").hide();
1442
- }
1443
- else {*/
1444
- jQuery("#bwg_added_comments").show();
1445
- spider_set_input_value('ajax_task', 'display');
1446
- spider_set_input_value('image_id', jQuery('#bwg_popup_image').attr('image_id'));
1447
- spider_ajax_save('bwg_comment_form');
1448
- /* }*/
1449
  }
1450
  if (jQuery(".bwg_ecommerce_container").hasClass("bwg_open")) {
1451
  /* Pricelist */
@@ -1490,7 +1493,7 @@ function bwg_change_image_lightbox(current_key, key, data, from_effect) {
1490
  bwg_afterload();
1491
  }
1492
  if ( typeof instgrm !== 'undefined' && typeof instgrm.Embeds !== 'undefined' ) {
1493
- instgrm.Embeds.process();
1494
  }
1495
  }
1496
  }
@@ -2070,49 +2073,54 @@ function bwg_rating( current_rate, rate_count, avg_rating, cur_key ) {
2070
  lightbox_rate_size = gallery_box_data['lightbox_rate_size'];
2071
  lightbox_rate_icon = gallery_box_data['lightbox_rate_icon'];
2072
  var avg_rating_message = "Not rated yet.";
2073
- if (avg_rating != 0) {
2074
- if (avg_rating != "") {
2075
  avg_rating_message = parseFloat(avg_rating).toFixed(1) + "\n Votes: " + rate_count;
2076
  }
2077
  }
2078
- if (typeof jQuery().raty !== 'undefined') {
2079
- if (jQuery.isFunction(jQuery().raty)) {
2080
- jQuery("#bwg_star").raty({
2081
- score: function() {
2082
- return jQuery(this).attr("data-score");
2083
- },
2084
  starType: 'i',
2085
- number : lightbox_rate_stars_count,
2086
- size : lightbox_rate_size,
2087
- readOnly : function() {
2088
- return (current_rate ? true : false);
2089
- },
2090
- noRatedMsg : "Not rated yet.",
2091
- click : function(score, evt) {
2092
- jQuery("#bwg_star").hide();
2093
- jQuery("#bwg_rated").show();
2094
- spider_set_input_value('rate_ajax_task', 'save_rate');
2095
- jQuery.when(spider_rate_ajax_save('bwg_rate_form')).then( function () {
2096
- gallery_box_data['data'][cur_key]["rate"] = score;
2097
- ++gallery_box_data['data'][cur_key]["rate_count"];
2098
- var curr_score = parseFloat(jQuery("#bwg_star").attr("data-score"));
2099
- gallery_box_data['data'][cur_key]["avg_rating"] = curr_score ? ((curr_score + score) / 2).toFixed(1) : score.toFixed(1);
2100
- bwg_rating(gallery_box_data['data'][cur_key]["rate"], gallery_box_data['data'][cur_key]["rate_count"], gallery_box_data['data'][cur_key]["avg_rating"], gallery_box_data['current_image_key']);
2101
- });
2102
- },
2103
- starHalf : 'bwg-icon-' + lightbox_rate_icon + ((lightbox_rate_icon == 'star') ? '-half' : '') + '-o',
2104
- starOff : 'bwg-icon-' + lightbox_rate_icon + '-o',
2105
- starOn : 'bwg-icon-' + lightbox_rate_icon,
2106
- cancelOff : 'bwg-icon-minus-square-o',
2107
- cancelOn : 'bwg-icon-minus-square-o',
2108
- cancel : false,
2109
- /*target : '#bwg_hint',
2110
- targetType : 'number',
2111
- targetKeep : true,*/
2112
- cancelHint : 'Cancel your rating.',
2113
- hints : [avg_rating_message, avg_rating_message, avg_rating_message, avg_rating_message, avg_rating_message],
2114
- alreadyRatedMsg : parseFloat(avg_rating).toFixed(1) + "\n" + "You have already rated.\nVotes: " + rate_count,
2115
- });
 
 
 
 
 
 
2116
  }
2117
  }
2118
  }
@@ -2371,55 +2379,55 @@ function bwg_filmstrip_thumb_view( image ) {
2371
 
2372
  /* Set image info height */
2373
  function bwg_info_height_set(){
2374
- bwg_info_position( false );
2375
- if ( jQuery(".mCustomScrollBox").length && jQuery(".bwg_image_info_container1").height() < jQuery(".mCustomScrollBox").height() + jQuery(".bwg_toggle_container").height() + bwg_image_info_pos + 2*( parseInt(gallery_box_data['lightbox_info_margin']))){
2376
- jQuery(".bwg_image_info").css({height:jQuery(".bwg_image_info_container1").height()- jQuery(".bwg_toggle_container").height()- bwg_image_info_pos - 2*(parseInt(gallery_box_data['lightbox_info_margin']))});
2377
- }
2378
  }
2379
 
2380
  /* Set image info position */
2381
  function bwg_info_position( toggle ) {
2382
- var number = 0;
2383
- var type = 'none';
 
 
 
 
 
 
 
 
 
 
 
2384
 
 
2385
  if (gallery_box_data['lightbox_ctrl_btn_pos'] == 'top') {
2386
- if (gallery_box_data['lightbox_info_pos'] == 'top') {
2387
- type = 'top';
2388
  }
2389
  }
2390
  else {
2391
- if (gallery_box_data['lightbox_info_pos'] == 'bottom') {
2392
- type = 'bottom';
2393
- }
2394
  }
 
2395
 
2396
- if ( !jQuery('.bwg_ctrl_btn_container').hasClass('closed') ) {
2397
- if (gallery_box_data['lightbox_ctrl_btn_pos'] == 'top') {
2398
- if (gallery_box_data['lightbox_info_pos'] == 'top') {
2399
- number = jQuery(".bwg_ctrl_btn_container").height();
2400
- }
2401
- }
2402
- else {
2403
- if (gallery_box_data['lightbox_info_pos'] == 'bottom') {
2404
- number = jQuery(".bwg_ctrl_btn_container").height();
2405
- }
2406
- }
2407
  }
2408
-
2409
- if (type == 'top') {
2410
- if (toggle == false) {
2411
- jQuery(".bwg_image_info").css('top', number);
2412
- }
2413
- else {
2414
- jQuery(".bwg_image_info").animate({top: number + "px"}, 500);
2415
- }
 
 
2416
  }
2417
- else if (type == 'bottom') {
2418
- if (toggle == false) {
2419
- jQuery(".bwg_image_info").css('bottom', number);
2420
- }
2421
- else {
2422
- jQuery(".bwg_image_info").animate({bottom: number + "px"}, 500);
2423
- }
2424
  }
2425
  }
219
  }
220
  });
221
  }
222
+ var mousewheelevt = (/Firefox/i.test(navigator.userAgent)) ? "DOMMouseScroll" : "mousewheel"; /*FF doesn't recognize mousewheel as of FF3.x*/
223
  jQuery('.bwg_filmstrip').on(mousewheelevt, function(e) {
224
  var evt = window.event || e; /* Equalize event object.*/
225
  evt = evt.originalEvent ? evt.originalEvent : evt; /* Convert to originalEvent if possible.*/
345
  jQuery( ".bwg_filmstrip_thumbnails" ).stop(true, false);
346
  if ((jQuery(".bwg_filmstrip_thumbnails").position().top) < 0) {
347
  jQuery(".bwg_filmstrip_right").css({opacity: 1});
348
+ if (jQuery(".bwg_filmstrip_thumbnails").position().top > - (gallery_box_data['filmstrip_thumb_right_left_space'] + gallery_box_data['image_filmstrip_width'])) {
349
  jQuery(".bwg_filmstrip_thumbnails").animate({ top: 0 }, 500, 'linear');
350
  }
351
  else {
432
  jQuery(".bwg_ecommerce, .bwg_ecommerce_close_btn").on(bwg_click, function() { bwg_ecommerce() });
433
  /* Open/close control buttons.*/
434
  jQuery(".bwg_toggle_container").on(bwg_click, function () {
435
+ var bwg_open_toggle_btn_class = (gallery_box_data['lightbox_ctrl_btn_pos'] == 'top') ? 'bwg-icon-caret-up' : 'bwg-icon-caret-down';
436
+ var bwg_close_toggle_btn_class = (gallery_box_data['lightbox_ctrl_btn_pos'] == 'top') ? 'bwg-icon-caret-down' : 'bwg-icon-caret-up';
437
 
438
+ if (jQuery(".bwg_toggle_container i").hasClass(bwg_open_toggle_btn_class)) {
439
+ if ((!gallery_box_data['enable_image_filmstrip'] || gallery_box_data['lightbox_filmstrip_pos'] != 'bottom') && gallery_box_data['lightbox_ctrl_btn_pos'] == 'bottom' && gallery_box_data['lightbox_rate_pos'] == 'bottom') {
440
+ jQuery(".bwg_image_rate").animate({bottom: 0}, 500);
441
+ }
442
+ else if ((!gallery_box_data['enable_image_filmstrip'] || gallery_box_data['lightbox_filmstrip_pos'] != 'top') && gallery_box_data['lightbox_ctrl_btn_pos'] == 'top' && gallery_box_data['lightbox_rate_pos'] == 'top') {
443
+ jQuery(".bwg_image_rate").animate({top: 0}, 500);
444
+ }
445
+ if ((!gallery_box_data['enable_image_filmstrip'] || gallery_box_data['lightbox_filmstrip_pos'] != 'bottom') && gallery_box_data['lightbox_ctrl_btn_pos'] == 'bottom' && gallery_box_data['lightbox_hit_pos'] == 'bottom') {
446
+ jQuery(".bwg_image_hit").animate({bottom: 0}, 500);
447
+ }
448
+ else if ((!gallery_box_data['enable_image_filmstrip'] || gallery_box_data['lightbox_filmstrip_pos'] != 'top') && gallery_box_data['lightbox_ctrl_btn_pos'] == 'top' && gallery_box_data['lightbox_hit_pos'] == 'top') {
449
+ jQuery(".bwg_image_hit").animate({top: 0}, 500);
450
+ }
451
+ if ( gallery_box_data['lightbox_ctrl_btn_pos'] == 'bottom' ) {
452
+ jQuery(".bwg_ctrl_btn_container").animate({ bottom : '-' + jQuery(".bwg_ctrl_btn_container").height()}, 500).addClass('closed');
453
+ jQuery(".bwg_toggle_container").animate({
454
+ bottom : 0
455
+ }, {
456
+ duration: 500,
457
+ complete: function () { jQuery(".bwg_toggle_container i").attr("class", "bwg_toggle_btn " + bwg_close_toggle_btn_class) }
458
+ });
459
+ } else {
460
+ jQuery(".bwg_ctrl_btn_container").animate({ top : '-' + jQuery(".bwg_ctrl_btn_container").height()}, 500).addClass('closed');
461
+ jQuery(".bwg_toggle_container").animate({
462
+ top : 0
463
+ }, {
464
+ duration: 500,
465
+ complete: function () { jQuery(".bwg_toggle_container i").attr("class", "bwg_toggle_btn " + bwg_close_toggle_btn_class) }
466
+ });
467
+ }
468
+ }
469
+ else {
470
+ if ((!gallery_box_data['enable_image_filmstrip'] || gallery_box_data['lightbox_filmstrip_pos'] != 'bottom') && gallery_box_data['lightbox_ctrl_btn_pos'] == 'bottom' && gallery_box_data['lightbox_rate_pos'] == 'bottom') {
471
+ jQuery(".bwg_image_rate").animate({bottom: jQuery(".bwg_ctrl_btn_container").height()}, 500);
472
+ }
473
+ else if ((!gallery_box_data['enable_image_filmstrip'] || gallery_box_data['lightbox_filmstrip_pos'] != 'top') && gallery_box_data['lightbox_ctrl_btn_pos'] == 'top' && gallery_box_data['lightbox_rate_pos'] == 'top') {
474
+ jQuery(".bwg_image_rate").animate({top: jQuery(".bwg_ctrl_btn_container").height()}, 500);
475
+ }
476
+ if ((!gallery_box_data['enable_image_filmstrip'] || gallery_box_data['lightbox_filmstrip_pos'] != 'bottom') && gallery_box_data['lightbox_ctrl_btn_pos'] == 'bottom' && gallery_box_data['lightbox_hit_pos'] == 'bottom') {
477
+ jQuery(".bwg_image_hit").animate({bottom: jQuery(".bwg_ctrl_btn_container").height()}, 500);
478
+ }
479
+ else if ((!gallery_box_data['enable_image_filmstrip'] || gallery_box_data['lightbox_filmstrip_pos'] != 'top') && gallery_box_data['lightbox_ctrl_btn_pos'] == 'top' && gallery_box_data['lightbox_hit_pos'] == 'top') {
480
+ jQuery(".bwg_image_hit").animate({top: jQuery(".bwg_ctrl_btn_container").height()}, 500);
481
  }
 
 
 
 
 
 
 
 
 
 
 
 
 
482
 
483
+ if ( gallery_box_data['lightbox_ctrl_btn_pos'] == 'bottom' ) {
484
+ jQuery(".bwg_ctrl_btn_container").animate({ bottom: 0 }, 500).removeClass('closed');
485
+ jQuery(".bwg_toggle_container").animate({
486
+ bottom : jQuery(".bwg_ctrl_btn_container").height()
487
+ }, {
488
+ duration: 500,
489
+ complete: function () { jQuery(".bwg_toggle_container i").attr("class", "bwg_toggle_btn " + bwg_open_toggle_btn_class) }
490
+ });
491
+ } else {
492
+ jQuery(".bwg_ctrl_btn_container").animate({ top: 0 }, 500).removeClass('closed');
493
+ jQuery(".bwg_toggle_container").animate({
494
+ top : jQuery(".bwg_ctrl_btn_container").height()
495
+ }, {
496
+ duration: 500,
497
+ complete: function () { jQuery(".bwg_toggle_container i").attr("class", "bwg_toggle_btn " + bwg_open_toggle_btn_class) }
498
+ });
 
499
  }
500
+ }
501
+ bwg_info_position( true );
502
  });
503
  /* Set window height not full screen */
504
  var bwg_windowheight = window.innerHeight;
782
 
783
  var bwg_ctrl_btn_container_height = jQuery(".bwg_ctrl_btn_container").height();
784
  if (lightbox_ctrl_btn_pos == 'bottom') {
785
+ jQuery(".bwg_toggle_container").css("bottom", bwg_ctrl_btn_container_height + "px");
786
  }
787
  else if (lightbox_ctrl_btn_pos == 'top') {
788
+ jQuery(".bwg_toggle_container").css("top", bwg_ctrl_btn_container_height + "px");
789
  }
790
  jQuery( ".bwg_spider_popup_loading" ).hide();
791
  if ( gallery_box_data['preload_images'] == 1 ) {
922
  url: jQuery('#' + form_id).attr('action'),
923
  data: post_data,
924
  success: function (data) {
925
+ jQuery('.bwg_comments').mCustomScrollbar('destroy');
926
  var str = jQuery(data).find('.bwg_comments').html();
927
  jQuery('.bwg_comments').html(str);
928
  },
948
  }
949
 
950
  /* Submit rating. */
951
+ function spider_rate_ajax_save(form_id, rate) {
952
  var post_data = {};
953
  post_data["image_id"] = jQuery("#" + form_id + " input[name='image_id']").val();
954
+ post_data["rate"] = (typeof rate != "undefined") ? rate : jQuery("#" + form_id + " input[name='score']").val();
955
  post_data["ajax_task"] = jQuery("#rate_ajax_task").val();
956
  return jQuery.ajax({
957
  type: "POST",
1002
 
1003
  /* Check if privacy polic field is checked. */
1004
  function comment_check_privacy_policy() {
1005
+ var bwg_submit = jQuery('#bwg_submit');
1006
+ bwg_submit.removeClass('bwg-submit-disabled');
1007
+ bwg_submit.removeAttr("disabled");
1008
+ if ( !jQuery('#bwg_comment_privacy_policy').is(':checked') ) {
1009
+ bwg_submit.addClass('bwg-submit-disabled');
1010
+ bwg_submit.attr('disabled', 'disabled');
1011
+ }
1012
  }
1013
 
1014
  /* Check Email. */
1052
  * @returns {boolean}
1053
  */
1054
  function bwg_add_comment() {
1055
+ var form = jQuery('#bwg_comment_form');
1056
+ var url = form.attr('action');
1057
+ var post_data = {};
1058
+ post_data['ajax_task'] = 'add_comment';
1059
+ post_data['comment_name'] = form.find('#bwg_name').val();
1060
  post_data['comment_email'] = form.find('#bwg_email').val();
1061
  post_data['comment_text'] = form.find('#bwg_comment').val();
1062
  post_data['comment_captcha'] = form.find('#bwg_captcha_input').val();
1063
  post_data['popup_enable_captcha'] = form.find('#bwg_popup_enable_captcha').val();
1064
  post_data['privacy_policy'] = ( form.find('#bwg_comment_privacy_policy').is(":checked") ) ? 1 : 0;
1065
+ post_data['comment_image_id'] = jQuery('#bwg_popup_image').attr('image_id');
1066
  post_data['comment_moderation'] = form.find('#bwg_comment_moderation').val();
1067
+ jQuery('.bwg_spider_ajax_loading').hide();
1068
+ jQuery.ajax({
1069
+ url: url,
1070
+ type: "POST",
1071
+ dataType: 'json',
1072
+ data: post_data,
1073
+ success: function ( res ) {
1074
+ jQuery('.bwg_comment_error').text('');
1075
+ if ( res.error == true ) {
1076
+ jQuery.each(res.error_messages, function( index, value ) {
1077
+ if ( value ) {
1078
+ jQuery('.bwg_comment_'+ index +'_error').text(value);
1079
+ }
1080
+ });
1081
+ }
1082
+ else {
1083
  form.find('#bwg_comment').val('');
1084
+ jQuery('.bwg_comment_waiting_message').hide();
1085
+ if( res.published == 0 ) {
1086
+ jQuery('.bwg_comment_waiting_message').show();
1087
+ }
1088
+ if ( res.html_comments_block != '' ) {
1089
+ jQuery('#bwg_added_comments').html(res.html_comments_block).show();
1090
+ }
1091
+ }
1092
+ },
1093
+ beforeSend: function() {
1094
+ jQuery('.bwg_spider_ajax_loading').show();
1095
+ },
1096
+ complete: function() {
1097
+ if ( form.find('#bwg_comment_privacy_policy').length > 0 ) {
1098
+ form.find('#bwg_comment_privacy_policy').prop('checked', false);
1099
+ comment_check_privacy_policy();
1100
+ }
1101
+ bwg_captcha_refresh('bwg_captcha');
1102
+ jQuery('.bwg_spider_ajax_loading').hide();
1103
+ },
1104
+ error:function() {}
1105
+ });
1106
+ return false;
1107
  }
1108
 
1109
  /**
1113
  * @returns {boolean}
1114
  */
1115
  function bwg_remove_comment( id_comment ) {
1116
+ var form = jQuery('#bwg_comment_form');
1117
+ var url = form.attr('action');
1118
+ var post_data = {};
1119
+ post_data['ajax_task'] = 'delete_comment';
1120
+ post_data['id_image'] = jQuery('#bwg_popup_image').attr('image_id');
1121
+ post_data['id_comment'] = id_comment;
1122
+ jQuery.ajax({
1123
+ url: url,
1124
+ type: "POST",
1125
+ dataType: 'json',
1126
+ data: post_data,
1127
+ success: function ( res ) {
1128
+ if ( res.error == false) {
1129
+ jQuery('#bwg_comment_block_' + id_comment ).fadeOut( "slow").remove();
1130
+ }
1131
+ },
1132
+ beforeSend: function() {
1133
+ },
1134
+ complete:function() {
1135
+ },
1136
+ error:function() {}
1137
+ });
1138
+ return false;
1139
  }
1140
 
1141
  function bwg_gallery_box( image_id, bwg_container, openEcommerce, gallery_id ) {
1162
  var ecommerce = openEcommerce == true ? "&open_ecommerce=1" : "";
1163
  var filtersearchname = jQuery("#bwg_search_input_" + bwg ).val();
1164
  var filtersortby = jQuery("#bwg_order_" + bwg).val() ? "&filtersortby=" + jQuery("#bwg_order_" + bwg).val() : '';
1165
+ filtersearchname = filtersearchname ? filtersearchname : '';
1166
 
1167
  if ( typeof gallery_id != "undefined" ) {
1168
  /* Open lightbox with hash.*/
1171
  var open_comment = '';
1172
  var open_comment_attr = jQuery('#bwg_blog_style_share_buttons_' + image_id).attr('data-open-comment');
1173
  if (typeof open_comment_attr !== typeof undefined && open_comment_attr !== false) {
1174
+ open_comment = '&open_comment=1';
1175
  }
1176
  var bwg_random_seed = jQuery("#bwg_random_seed_"+bwg).val();
1177
  spider_createpopup(bwg_lightbox_url + '&bwg_random_seed='+bwg_random_seed+'&image_id=' + image_id + "&filter_tag=" + filterTags + ecommerce + open_comment + '&filter_search_name=' + filtersearchname + filtersortby, bwg, bwg_container.data('popup-width'), bwg_container.data('popup-height'), 1, 'testpopup', 5, bwg_container.data('buttons-position'));
1192
  jQuery(".bwg_image_info").css("height","auto");
1193
  setTimeout(function(){
1194
  bwg_info_height_set();
1195
+ if(jQuery('.bwg_image_description').height() > jQuery('.bwg_image_info').height() && jQuery('.mCSB_container').hasClass('mCS_no_scrollbar')){
1196
+ jQuery(".bwg_image_info").mCustomScrollbar("destroy");
1197
+ }
1198
+ if (!jQuery('.bwg_image_info').hasClass('mCustomScrollbar')) {
1199
+ if (typeof jQuery().mCustomScrollbar !== 'undefined' && jQuery.isFunction(jQuery().mCustomScrollbar)) {
1200
+ jQuery(".bwg_image_info").mCustomScrollbar({
1201
+ scrollInertia: 150,
1202
+ theme: 'dark-thick',
1203
+ advanced:{
1204
+ updateOnContentResize: true
1205
+ }
1206
+ });
1207
+ }
1208
+ }
1209
+ }, 200);
1210
  jQuery("#spider_popup_left").show();
1211
  jQuery("#spider_popup_right").show();
1212
  jQuery(".bwg_image_info").hide();
1302
  history.replaceState(undefined, undefined, "#bwg" + gallery_box_data['gallery_id'] + "/" + data[key]["id"]);
1303
  }
1304
  jQuery("#bwg_rate_form input[name='image_id']").val(data[key]["id"]);
1305
+ /* Increase image hit counter.*/
1306
+ spider_set_input_value('rate_ajax_task', 'save_hit_count');
1307
+ spider_rate_ajax_save('bwg_rate_form');
1308
+
1309
+ /* Change image id for rating. */
1310
+ if ( gallery_box_data['popup_enable_rate'] ) {
1311
  jQuery("#bwg_star").attr("data-score", data[key]["avg_rating"]);
1312
  jQuery("#bwg_star").removeAttr("title");
1313
  data[key]['cur_key'] = key;
1314
  bwg_rating( data[key]["rate"], data[key]["rate_count"], data[key]["avg_rating"], key );
1315
  }
 
 
1316
 
 
1317
  jQuery(".bwg_image_hits span").html(++data[key]["hit_count"]);
1318
+
1319
  /* Change image id.*/
1320
  jQuery("#bwg_popup_image").attr('image_id', data[key]["id"]);
1321
  /* Change image title, description.*/
1440
  if (jQuery(".bwg_comment_container").hasClass("bwg_open")) {
1441
  jQuery(".bwg_comments .mCSB_container").css("top","0");
1442
  /* Todo: do not call comments if it's empty */
1443
+ /* if (data[key]["comment_count"] == 0) {
1444
+ jQuery("#bwg_added_comments").hide();
1445
+ }
1446
+ else {*/
1447
+ jQuery("#bwg_added_comments").show();
1448
+ spider_set_input_value('ajax_task', 'display');
1449
+ spider_set_input_value('image_id', jQuery('#bwg_popup_image').attr('image_id'));
1450
+ spider_ajax_save('bwg_comment_form');
1451
+ /* }*/
1452
  }
1453
  if (jQuery(".bwg_ecommerce_container").hasClass("bwg_open")) {
1454
  /* Pricelist */
1493
  bwg_afterload();
1494
  }
1495
  if ( typeof instgrm !== 'undefined' && typeof instgrm.Embeds !== 'undefined' ) {
1496
+ instgrm.Embeds.process();
1497
  }
1498
  }
1499
  }
2073
  lightbox_rate_size = gallery_box_data['lightbox_rate_size'];
2074
  lightbox_rate_icon = gallery_box_data['lightbox_rate_icon'];
2075
  var avg_rating_message = "Not rated yet.";
2076
+ if ( avg_rating != 0 ) {
2077
+ if ( avg_rating != "" ) {
2078
  avg_rating_message = parseFloat(avg_rating).toFixed(1) + "\n Votes: " + rate_count;
2079
  }
2080
  }
2081
+ if ( typeof jQuery().raty !== 'undefined' ) {
2082
+ if ( jQuery.isFunction(jQuery().raty) ) {
2083
+ var curr_score = parseFloat(jQuery("#bwg_star").attr("data-score"));
2084
+ jQuery("#bwg_star").removeAttr("data-score").html('');
2085
+ var rate_params = {
 
2086
  starType: 'i',
2087
+ number: lightbox_rate_stars_count,
2088
+ size: lightbox_rate_size,
2089
+ noRatedMsg: "Not rated yet.",
2090
+ readOnly: false,
2091
+ score: curr_score,
2092
+ starHalf: 'bwg-icon-' + lightbox_rate_icon + ((lightbox_rate_icon == 'star') ? '-half' : '') + '-o',
2093
+ starOff: 'bwg-icon-' + lightbox_rate_icon + '-o',
2094
+ starOn: 'bwg-icon-' + lightbox_rate_icon,
2095
+ cancelOff: 'bwg-icon-minus-square-o',
2096
+ cancelOn: 'bwg-icon-minus-square-o',
2097
+ cancel: false,
2098
+ // target : '#bwg_hint',
2099
+ // targetType : 'number',
2100
+ // targetKeep : true,
2101
+ cancelHint: 'Cancel your rating.',
2102
+ hints: [avg_rating_message, avg_rating_message, avg_rating_message, avg_rating_message, avg_rating_message],
2103
+ alreadyRatedMsg: parseFloat(avg_rating).toFixed(1) + "\n" + "You have already rated.\nVotes: " + rate_count,
2104
+ };
2105
+ if (!current_rate) {
2106
+ rate_params.click = function (score, evt) {
2107
+ jQuery("#bwg_star").hide();
2108
+ jQuery("#bwg_rated").show();
2109
+ spider_set_input_value('rate_ajax_task', 'save_rate');
2110
+ jQuery.when(spider_rate_ajax_save('bwg_rate_form', score)).then(function () {
2111
+ gallery_box_data['data'][cur_key]["rate"] = score;
2112
+ ++gallery_box_data['data'][cur_key]["rate_count"];
2113
+ gallery_box_data['data'][cur_key]["avg_rating"] = curr_score ? ((curr_score + score) / 2).toFixed(1) : score.toFixed(1);
2114
+ bwg_rating(gallery_box_data['data'][cur_key]["rate"], gallery_box_data['data'][cur_key]["rate_count"], gallery_box_data['data'][cur_key]["avg_rating"], gallery_box_data['current_image_key']);
2115
+ });
2116
+ };
2117
+ }
2118
+
2119
+ jQuery("#bwg_star").raty(rate_params);
2120
+ jQuery('.bwg_image_rate_disabled').hide();
2121
+ if ( current_rate ) {
2122
+ jQuery('.bwg_image_rate_disabled').show();
2123
+ }
2124
  }
2125
  }
2126
  }
2379
 
2380
  /* Set image info height */
2381
  function bwg_info_height_set(){
2382
+ bwg_info_position( false );
2383
+ if ( jQuery(".mCustomScrollBox").length && jQuery(".bwg_image_info_container1").height() < jQuery(".mCustomScrollBox").height() + jQuery(".bwg_toggle_container").height() + bwg_image_info_pos + 2*( parseInt(gallery_box_data['lightbox_info_margin']))){
2384
+ jQuery(".bwg_image_info").css({height:jQuery(".bwg_image_info_container1").height()- jQuery(".bwg_toggle_container").height()- bwg_image_info_pos - 2*(parseInt(gallery_box_data['lightbox_info_margin']))});
2385
+ }
2386
  }
2387
 
2388
  /* Set image info position */
2389
  function bwg_info_position( toggle ) {
2390
+ var number = 0;
2391
+ var type = 'none';
2392
+
2393
+ if (gallery_box_data['lightbox_ctrl_btn_pos'] == 'top') {
2394
+ if (gallery_box_data['lightbox_info_pos'] == 'top') {
2395
+ type = 'top';
2396
+ }
2397
+ }
2398
+ else {
2399
+ if (gallery_box_data['lightbox_info_pos'] == 'bottom') {
2400
+ type = 'bottom';
2401
+ }
2402
+ }
2403
 
2404
+ if ( !jQuery('.bwg_ctrl_btn_container').hasClass('closed') ) {
2405
  if (gallery_box_data['lightbox_ctrl_btn_pos'] == 'top') {
2406
+ if (gallery_box_data['lightbox_info_pos'] == 'top') {
2407
+ number = jQuery(".bwg_ctrl_btn_container").height();
2408
  }
2409
  }
2410
  else {
2411
+ if (gallery_box_data['lightbox_info_pos'] == 'bottom') {
2412
+ number = jQuery(".bwg_ctrl_btn_container").height();
2413
+ }
2414
  }
2415
+ }
2416
 
2417
+ if (type == 'top') {
2418
+ if (toggle == false) {
2419
+ jQuery(".bwg_image_info").css('top', number);
 
 
 
 
 
 
 
 
2420
  }
2421
+ else {
2422
+ jQuery(".bwg_image_info").animate({top: number + "px"}, 500);
2423
+ }
2424
+ }
2425
+ else if (type == 'bottom') {
2426
+ if (toggle == false) {
2427
+ jQuery(".bwg_image_info").css('bottom', number);
2428
+ }
2429
+ else {
2430
+ jQuery(".bwg_image_info").animate({bottom: number + "px"}, 500);
2431
  }
 
 
 
 
 
 
 
2432
  }
2433
  }
js/fontselect/fonts/Action Man.woff ADDED
Binary file
js/fontselect/fonts/Bauer.woff ADDED
Binary file
js/fontselect/fonts/Bubble.woff ADDED
Binary file
js/fontselect/fontselect.css ADDED
@@ -0,0 +1,89 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ .font-select * {
2
+ -webkit-box-sizing: border-box;
3
+ box-sizing: border-box;
4
+ }
5
+
6
+ .font-select {
7
+ font-size: 16px;
8
+ width: 240px;
9
+ position: relative;
10
+ display: inline-block;
11
+ }
12
+
13
+ .font-select .fs-drop {
14
+ position: absolute;
15
+ top: 38px;
16
+ left: 0;
17
+ z-index: 999;
18
+ background: #fff;
19
+ color: #000;
20
+ width: 100%;
21
+ border: 1px solid #aaa;
22
+ border-top: 0;
23
+ box-shadow: 0 4px 5px rgba(0,0,0,.15);
24
+ border-radius: 0 0 4px 4px;
25
+ }
26
+
27
+ .font-select > span {
28
+ outline: 0;
29
+ border-radius: 0.25rem;
30
+ border: 1px solid #ced4da;
31
+ display: block;
32
+ overflow: hidden;
33
+ white-space: nowrap;
34
+ text-overflow: ellipsis;
35
+ height: 38px;
36
+ line-height: 32px;
37
+ padding: 3px 8px 3px 8px;
38
+ color: #444;
39
+ background: #fff url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3e%3cpath fill='%23303030' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e") no-repeat right 0.75rem center/8px 10px;
40
+ -webkit-user-select: none;
41
+ -moz-user-select: none;
42
+ -ms-user-select: none;
43
+ user-select: none;
44
+ }
45
+
46
+ .font-select-active > span {
47
+ background-color: #eee;
48
+ border-bottom-left-radius : 0;
49
+ border-bottom-right-radius: 0;
50
+ }
51
+
52
+ .font-select .fs-results {
53
+ max-height: 190px;
54
+ overflow-x: hidden;
55
+ overflow-y: auto;
56
+ margin: 0;
57
+ padding: 0;
58
+ }
59
+
60
+ .font-select .fs-results li {
61
+ line-height: 80%;
62
+ padding: 8px;
63
+ margin: 0;
64
+ list-style: none;
65
+ font-size: 18px;
66
+ white-space: nowrap;
67
+ }
68
+
69
+ .font-select .fs-results li.active {
70
+ background-color: #3875d7;
71
+ color: #fff;
72
+ cursor: pointer;
73
+ }
74
+
75
+ .font-select .fs-search {
76
+ border-bottom: 1px solid #aaa;
77
+ padding: 4px;
78
+ }
79
+
80
+ .font-select .fs-search input {
81
+ padding: 7px;
82
+ width: 100%;
83
+ border: 1px solid #aaa;
84
+ font: 16px Helvetica, Sans-serif;
85
+ box-shadow: inset 0 1px 3px rgba(0,0,0,.06);
86
+ border-radius: .1875rem;
87
+ }
88
+
89
+
js/fontselect/fontselect.js ADDED
@@ -0,0 +1,1314 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ /*
2
+ * jQuery.fontselect - A font selector for system fonts, local fonts and Google Web Fonts
3
+ *
4
+ * Made by Arjan Haverkamp, https://www.webgear.nl
5
+ * Based on original by Tom Moor, http://tommoor.com
6
+ * Copyright (c) 2011 Tom Moor, 2019-2020 Arjan Haverkamp
7
+ * MIT Licensed
8
+ * @version 1.0 - 2020-02-26
9
+ * @url https://github.com/av01d/fontselect-jquery-plugin
10
+ */
11
+
12
+ (function($){
13
+
14
+ var fontsLoaded = {};
15
+
16
+ $.fn.fontselect = function(options) {
17
+ var __bind = function(fn, me) { return function(){ return fn.apply(me, arguments); }; };
18
+
19
+ var settings = {
20
+ style: 'font-select',
21
+ placeholder: 'Select a font',
22
+ placeholderSearch: 'Search...',
23
+ searchable: true,
24
+ lookahead: 2,
25
+ googleApi: 'https://fonts.googleapis.com/css?family=',
26
+ localFontsUrl: '/fonts/',
27
+ systemFonts: 'Arial|Helvetica+Neue|Courier+New|Times+New+Roman|Comic+Sans+MS|Verdana|Impact'.split('|'),
28
+
29
+ googleFonts: [
30
+ "ABeeZee:400,italic",
31
+ "Abel:400",
32
+ "Abhaya+Libre:400,500,600,700,800",
33
+ "Abril+Fatface:400",
34
+ "Aclonica:400",
35
+ "Acme:400",
36
+ "Actor:400",
37
+ "Adamina:400",
38
+ "Advent+Pro:100,200,300,400,500,600,700",
39
+ "Aguafina+Script:400",
40
+ "Akronim:400",
41
+ "Aladin:400",
42
+ "Alata:400",
43
+ "Alatsi:400",
44
+ "Aldrich:400",
45
+ "Alef:400,700",
46
+ "Alegreya:400,italic,500,500italic,700,700italic,800,800italic,900,900italic",
47
+ "Alegreya+SC:400,italic,500,500italic,700,700italic,800,800italic,900,900italic",
48
+ "Alegreya+Sans:100,100italic,300,300italic,400,italic,500,500italic,700,700italic,800,800italic,900,900italic",
49
+ "Alegreya+Sans+SC:100,100italic,300,300italic,400,italic,500,500italic,700,700italic,800,800italic,900,900italic",
50
+ "Aleo:300,300italic,400,italic,700,700italic",
51
+ "Alex+Brush:400",
52
+ "Alfa+Slab+One:400",
53
+ "Alice:400",
54
+ "Alike:400",
55
+ "Alike+Angular:400",
56
+ "Allan:400,700",
57
+ "Allerta:400",
58
+ "Allerta+Stencil:400",
59
+ "Allura:400",
60
+ "Almarai:300,400,700,800",
61
+ "Almendra:400,italic,700,700italic",
62
+ "Almendra+Display:400",
63
+ "Almendra+SC:400",
64
+ "Amarante:400",
65
+ "Amaranth:400,italic,700,700italic",
66
+ "Amatic+SC:400,700",
67
+ "Amethysta:400",
68
+ "Amiko:400,600,700",
69
+ "Amiri:400,italic,700,700italic",
70
+ "Amita:400,700",
71
+ "Anaheim:400",
72
+ "Andada:400",
73
+ "Andika:400",
74
+ "Angkor:400",
75
+ "Annie+Use+Your+Telescope:400",
76
+ "Anonymous+Pro:400,italic,700,700italic",
77
+ "Antic:400",
78
+ "Antic+Didone:400",
79
+ "Antic+Slab:400",
80
+ "Anton:400",
81
+ "Arapey:400,italic",
82
+ "Arbutus:400",
83
+ "Arbutus+Slab:400",
84
+ "Architects+Daughter:400",
85
+ "Archivo:400,italic,500,500italic,600,600italic,700,700italic",
86
+ "Archivo+Black:400",
87
+ "Archivo+Narrow:400,italic,500,500italic,600,600italic,700,700italic",
88
+ "Aref+Ruqaa:400,700",
89
+ "Arima+Madurai:100,200,300,400,500,700,800,900",
90
+ "Arimo:400,italic,700,700italic",
91
+ "Arizonia:400",
92
+ "Armata:400",
93
+ "Arsenal:400,italic,700,700italic",
94
+ "Artifika:400",
95
+ "Arvo:400,italic,700,700italic",
96
+ "Arya:400,700",
97
+ "Asap:400,italic,500,500italic,600,600italic,700,700italic",
98
+ "Asap+Condensed:400,italic,500,500italic,600,600italic,700,700italic",
99
+ "Asar:400",
100
+ "Asset:400",
101
+ "Assistant:200,300,400,600,700,800",
102
+ "Astloch:400,700",
103
+ "Asul:400,700",
104
+ "Athiti:200,300,400,500,600,700",
105
+ "Atma:300,400,500,600,700",
106
+ "Atomic+Age:400",
107
+ "Aubrey:400",
108
+ "Audiowide:400",
109
+ "Autour+One:400",
110
+ "Average:400",
111
+ "Average+Sans:400",
112
+ "Averia+Gruesa+Libre:400",
113
+ "Averia+Libre:300,300italic,400,italic,700,700italic",
114
+ "Averia+Sans+Libre:300,300italic,400,italic,700,700italic",
115
+ "Averia+Serif+Libre:300,300italic,400,italic,700,700italic",
116
+ "B612:400,italic,700,700italic",
117
+ "B612+Mono:400,italic,700,700italic",
118
+ "Bad+Script:400",
119
+ "Bahiana:400",
120
+ "Bahianita:400",
121
+ "Bai+Jamjuree:200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic",
122
+ "Baloo:400",
123
+ "Baloo+Bhai:400",
124
+ "Baloo+Bhaijaan:400",
125
+ "Baloo+Bhaina:400",
126
+ "Baloo+Chettan:400",
127
+ "Baloo+Da:400",
128
+ "Baloo+Paaji:400",
129
+ "Baloo+Tamma:400",
130
+ "Baloo+Tammudu:400",
131
+ "Baloo+Thambi:400",
132
+ "Balthazar:400",
133
+ "Bangers:400",
134
+ "Barlow:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
135
+ "Barlow+Condensed:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
136
+ "Barlow+Semi+Condensed:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
137
+ "Barriecito:400",
138
+ "Barrio:400",
139
+ "Basic:400",
140
+ "Baskervville:400,italic",
141
+ "Battambang:400,700",
142
+ "Baumans:400",
143
+ "Bayon:400",
144
+ "Be+Vietnam:100,100italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic",
145
+ "Bebas+Neue:400",
146
+ "Belgrano:400",
147
+ "Bellefair:400",
148
+ "Belleza:400",
149
+ "BenchNine:300,400,700",
150
+ "Bentham:400",
151
+ "Berkshire+Swash:400",
152
+ "Beth+Ellen:400",
153
+ "Bevan:400",
154
+ "Big+Shoulders+Display:100,300,400,500,600,700,800,900",
155
+ "Big+Shoulders+Text:100,300,400,500,600,700,800,900",
156
+ "Bigelow+Rules:400",
157
+ "Bigshot+One:400",
158
+ "Bilbo:400",
159
+ "Bilbo+Swash+Caps:400",
160
+ "BioRhyme:200,300,400,700,800",
161
+ "BioRhyme+Expanded:200,300,400,700,800",
162
+ "Biryani:200,300,400,600,700,800,900",
163
+ "Bitter:400,italic,700",
164
+ "Black+And+White+Picture:400",
165
+ "Black+Han+Sans:400",
166
+ "Black+Ops+One:400",
167
+ "Blinker:100,200,300,400,600,700,800,900",
168
+ "Bokor:400",
169
+ "Bonbon:400",
170
+ "Boogaloo:400",
171
+ "Bowlby+One:400",
172
+ "Bowlby+One+SC:400",
173
+ "Brawler:400",
174
+ "Bree+Serif:400",
175
+ "Bubblegum+Sans:400",
176
+ "Bubbler+One:400",
177
+ "Buda:300",
178
+ "Buenard:400,700",
179
+ "Bungee:400",
180
+ "Bungee+Hairline:400",
181
+ "Bungee+Inline:400",
182
+ "Bungee+Outline:400",
183
+ "Bungee+Shade:400",
184
+ "Butcherman:400",
185
+ "Butterfly+Kids:400",
186
+ "Cabin:400,italic,500,500italic,600,600italic,700,700italic",
187
+ "Cabin+Condensed:400,500,600,700",
188
+ "Cabin+Sketch:400,700",
189
+ "Caesar+Dressing:400",
190
+ "Cagliostro:400",
191
+ "Cairo:200,300,400,600,700,900",
192
+ "Calistoga:400",
193
+ "Calligraffitti:400",
194
+ "Cambay:400,italic,700,700italic",
195
+ "Cambo:400",
196
+ "Candal:400",
197
+ "Cantarell:400,italic,700,700italic",
198
+ "Cantata+One:400",
199
+ "Cantora+One:400",
200
+ "Capriola:400",
201
+ "Cardo:400,italic,700",
202
+ "Carme:400",
203
+ "Carrois+Gothic:400",
204
+ "Carrois+Gothic+SC:400",
205
+ "Carter+One:400",
206
+ "Catamaran:100,200,300,400,500,600,700,800,900",
207
+ "Caudex:400,italic,700,700italic",
208
+ "Caveat:400,700",
209
+ "Caveat+Brush:400",
210
+ "Cedarville+Cursive:400",
211
+ "Ceviche+One:400",
212
+ "Chakra+Petch:300,300italic,400,italic,500,500italic,600,600italic,700,700italic",
213
+ "Changa:200,300,400,500,600,700,800",
214
+ "Changa+One:400,italic",
215
+ "Chango:400",
216
+ "Charm:400,700",
217
+ "Charmonman:400,700",
218
+ "Chathura:100,300,400,700,800",
219
+ "Chau+Philomene+One:400,italic",
220
+ "Chela+One:400",
221
+ "Chelsea+Market:400",
222
+ "Chenla:400",
223
+ "Cherry+Cream+Soda:400",
224
+ "Cherry+Swash:400,700",
225
+ "Chewy:400",
226
+ "Chicle:400",
227
+ "Chilanka:400",
228
+ "Chivo:300,300italic,400,italic,700,700italic,900,900italic",
229
+ "Chonburi:400",
230
+ "Cinzel:400,700,900",
231
+ "Cinzel+Decorative:400,700,900",
232
+ "Clicker+Script:400",
233
+ "Coda:400,800",
234
+ "Coda+Caption:800",
235
+ "Codystar:300,400",
236
+ "Coiny:400",
237
+ "Combo:400",
238
+ "Comfortaa:300,400,500,600,700",
239
+ "Coming+Soon:400",
240
+ "Concert+One:400",
241
+ "Condiment:400",
242
+ "Content:400,700",
243
+ "Contrail+One:400",
244
+ "Convergence:400",
245
+ "Cookie:400",
246
+ "Copse:400",
247
+ "Corben:400,700",
248
+ "Cormorant:300,300italic,400,italic,500,500italic,600,600italic,700,700italic",
249
+ "Cormorant+Garamond:300,300italic,400,italic,500,500italic,600,600italic,700,700italic",
250
+ "Cormorant+Infant:300,300italic,400,italic,500,500italic,600,600italic,700,700italic",
251
+ "Cormorant+SC:300,400,500,600,700",
252
+ "Cormorant+Unicase:300,400,500,600,700",
253
+ "Cormorant+Upright:300,400,500,600,700",
254
+ "Courgette:400",
255
+ "Courier+Prime:400,italic,700,700italic",
256
+ "Cousine:400,italic,700,700italic",
257
+ "Coustard:400,900",
258
+ "Covered+By+Your+Grace:400",
259
+ "Crafty+Girls:400",
260
+ "Creepster:400",
261
+ "Crete+Round:400,italic",
262
+ "Crimson+Pro:200,300,400,500,600,700,800,900,200italic,300italic,italic,500italic,600italic,700italic,800italic,900italic",
263
+ "Crimson+Text:400,italic,600,600italic,700,700italic",
264
+ "Croissant+One:400",
265
+ "Crushed:400",
266
+ "Cuprum:400,italic,700,700italic",
267
+ "Cute+Font:400",
268
+ "Cutive:400",
269
+ "Cutive+Mono:400",
270
+ "DM+Sans:400,italic,500,500italic,700,700italic",
271
+ "DM+Serif+Display:400,italic",
272
+ "DM+Serif+Text:400,italic",
273
+ "Damion:400",
274
+ "Dancing+Script:400,500,600,700",
275
+ "Dangrek:400",
276
+ "Darker+Grotesque:300,400,500,600,700,800,900",
277
+ "David+Libre:400,500,700",
278
+ "Dawning+of+a+New+Day:400",
279
+ "Days+One:400",
280
+ "Dekko:400",
281
+ "Delius:400",
282
+ "Delius+Swash+Caps:400",
283
+ "Delius+Unicase:400,700",
284
+ "Della+Respira:400",
285
+ "Denk+One:400",
286
+ "Devonshire:400",
287
+ "Dhurjati:400",
288
+ "Didact+Gothic:400",
289
+ "Diplomata:400",
290
+ "Diplomata+SC:400",
291
+ "Do+Hyeon:400",
292
+ "Dokdo:400",
293
+ "Domine:400,700",
294
+ "Donegal+One:400",
295
+ "Doppio+One:400",
296
+ "Dorsa:400",
297
+ "Dosis:200,300,400,500,600,700,800",
298
+ "Dr+Sugiyama:400",
299
+ "Duru+Sans:400",
300
+ "Dynalight:400",
301
+ "EB+Garamond:400,500,600,700,800,italic,500italic,600italic,700italic,800italic",
302
+ "Eagle+Lake:400",
303
+ "East+Sea+Dokdo:400",
304
+ "Eater:400",
305
+ "Economica:400,italic,700,700italic",
306
+ "Eczar:400,500,600,700,800",
307
+ "El+Messiri:400,500,600,700",
308
+ "Electrolize:400",
309
+ "Elsie:400,900",
310
+ "Elsie+Swash+Caps:400,900",
311
+ "Emblema+One:400",
312
+ "Emilys+Candy:400",
313
+ "Encode+Sans:100,200,300,400,500,600,700,800,900",
314
+ "Encode+Sans+Condensed:100,200,300,400,500,600,700,800,900",
315
+ "Encode+Sans+Expanded:100,200,300,400,500,600,700,800,900",
316
+ "Encode+Sans+Semi+Condensed:100,200,300,400,500,600,700,800,900",
317
+ "Encode+Sans+Semi+Expanded:100,200,300,400,500,600,700,800,900",
318
+ "Engagement:400",
319
+ "Englebert:400",
320
+ "Enriqueta:400,500,600,700",
321
+ "Erica+One:400",
322
+ "Esteban:400",
323
+ "Euphoria+Script:400",
324
+ "Ewert:400",
325
+ "Exo:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
326
+ "Exo+2:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
327
+ "Expletus+Sans:400,italic,500,500italic,600,600italic,700,700italic",
328
+ "Fahkwang:200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic",
329
+ "Fanwood+Text:400,italic",
330
+ "Farro:300,400,500,700",
331
+ "Farsan:400",
332
+ "Fascinate:400",
333
+ "Fascinate+Inline:400",
334
+ "Faster+One:400",
335
+ "Fasthand:400",
336
+ "Fauna+One:400",
337
+ "Faustina:400,500,600,700,italic,500italic,600italic,700italic",
338
+ "Federant:400",
339
+ "Federo:400",
340
+ "Felipa:400",
341
+ "Fenix:400",
342
+ "Finger+Paint:400",
343
+ "Fira+Code:300,400,500,600,700",
344
+ "Fira+Mono:400,500,700",
345
+ "Fira+Sans:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
346
+ "Fira+Sans+Condensed:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
347
+ "Fira+Sans+Extra+Condensed:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
348
+ "Fjalla+One:400",
349
+ "Fjord+One:400",
350
+ "Flamenco:300,400",
351
+ "Flavors:400",
352
+ "Fondamento:400,italic",
353
+ "Fontdiner+Swanky:400",
354
+ "Forum:400",
355
+ "Francois+One:400",
356
+ "Frank+Ruhl+Libre:300,400,500,700,900",
357
+ "Freckle+Face:400",
358
+ "Fredericka+the+Great:400",
359
+ "Fredoka+One:400",
360
+ "Freehand:400",
361
+ "Fresca:400",
362
+ "Frijole:400",
363
+ "Fruktur:400",
364
+ "Fugaz+One:400",
365
+ "GFS+Didot:400",
366
+ "GFS+Neohellenic:400,italic,700,700italic",
367
+ "Gabriela:400",
368
+ "Gaegu:300,400,700",
369
+ "Gafata:400",
370
+ "Galada:400",
371
+ "Galdeano:400",
372
+ "Galindo:400",
373
+ "Gamja+Flower:400",
374
+ "Gayathri:100,400,700",
375
+ "Gelasio:400,italic,500,500italic,600,600italic,700,700italic",
376
+ "Gentium+Basic:400,italic,700,700italic",
377
+ "Gentium+Book+Basic:400,italic,700,700italic",
378
+ "Geo:400,italic",
379
+ "Geostar:400",
380
+ "Geostar+Fill:400",
381
+ "Germania+One:400",
382
+ "Gidugu:400",
383
+ "Gilda+Display:400",
384
+ "Girassol:400",
385
+ "Give+You+Glory:400",
386
+ "Glass+Antiqua:400",
387
+ "Glegoo:400,700",
388
+ "Gloria+Hallelujah:400",
389
+ "Goblin+One:400",
390
+ "Gochi+Hand:400",
391
+ "Gorditas:400,700",
392
+ "Gothic+A1:100,200,300,400,500,600,700,800,900",
393
+ "Goudy+Bookletter+1911:400",
394
+ "Graduate:400",
395
+ "Grand+Hotel:400",
396
+ "Gravitas+One:400",
397
+ "Great+Vibes:400",
398
+ "Grenze:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
399
+ "Griffy:400",
400
+ "Gruppo:400",
401
+ "Gudea:400,italic,700",
402
+ "Gugi:400",
403
+ "Gupter:400,500,700",
404
+ "Gurajada:400",
405
+ "Habibi:400",
406
+ "Halant:300,400,500,600,700",
407
+ "Hammersmith+One:400",
408
+ "Hanalei:400",
409
+ "Hanalei+Fill:400",
410
+ "Handlee:400",
411
+ "Hanuman:400,700",
412
+ "Happy+Monkey:400",
413
+ "Harmattan:400",
414
+ "Headland+One:400",
415
+ "Heebo:100,300,400,500,700,800,900",
416
+ "Henny+Penny:400",
417
+ "Hepta+Slab:100,200,300,400,500,600,700,800,900",
418
+ "Herr+Von+Muellerhoff:400",
419
+ "Hi+Melody:400",
420
+ "Hind:300,400,500,600,700",
421
+ "Hind+Guntur:300,400,500,600,700",
422
+ "Hind+Madurai:300,400,500,600,700",
423
+ "Hind+Siliguri:300,400,500,600,700",
424
+ "Hind+Vadodara:300,400,500,600,700",
425
+ "Holtwood+One+SC:400",
426
+ "Homemade+Apple:400",
427
+ "Homenaje:400",
428
+ "IBM+Plex+Mono:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic",
429
+ "IBM+Plex+Sans:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic",
430
+ "IBM+Plex+Sans+Condensed:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic",
431
+ "IBM+Plex+Serif:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic",
432
+ "IM+Fell+DW+Pica:400,italic",
433
+ "IM+Fell+DW+Pica+SC:400",
434
+ "IM+Fell+Double+Pica:400,italic",
435
+ "IM+Fell+Double+Pica+SC:400",
436
+ "IM+Fell+English:400,italic",
437
+ "IM+Fell+English+SC:400",
438
+ "IM+Fell+French+Canon:400,italic",
439
+ "IM+Fell+French+Canon+SC:400",
440
+ "IM+Fell+Great+Primer:400,italic",
441
+ "IM+Fell+Great+Primer+SC:400",
442
+ "Ibarra+Real+Nova:400,italic,600,600italic,700,700italic",
443
+ "Iceberg:400",
444
+ "Iceland:400",
445
+ "Imprima:400",
446
+ "Inconsolata:400,700",
447
+ "Inder:400",
448
+ "Indie+Flower:400",
449
+ "Inika:400,700",
450
+ "Inknut+Antiqua:300,400,500,600,700,800,900",
451
+ "Inria+Serif:300,300italic,400,italic,700,700italic",
452
+ "Irish+Grover:400",
453
+ "Istok+Web:400,italic,700,700italic",
454
+ "Italiana:400",
455
+ "Italianno:400",
456
+ "Itim:400",
457
+ "Jacques+Francois:400",
458
+ "Jacques+Francois+Shadow:400",
459
+ "Jaldi:400,700",
460
+ "Jim+Nightshade:400",
461
+ "Jockey+One:400",
462
+ "Jolly+Lodger:400",
463
+ "Jomhuria:400",
464
+ "Jomolhari:400",
465
+ "Josefin+Sans:100,100italic,300,300italic,400,italic,600,600italic,700,700italic",
466
+ "Josefin+Slab:100,100italic,300,300italic,400,italic,600,600italic,700,700italic",
467
+ "Joti+One:400",
468
+ "Jua:400",
469
+ "Judson:400,italic,700",
470
+ "Julee:400",
471
+ "Julius+Sans+One:400",
472
+ "Junge:400",
473
+ "Jura:300,400,500,600,700",
474
+ "Just+Another+Hand:400",
475
+ "Just+Me+Again+Down+Here:400",
476
+ "K2D:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic",
477
+ "Kadwa:400,700",
478
+ "Kalam:300,400,700",
479
+ "Kameron:400,700",
480
+ "Kanit:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
481
+ "Kantumruy:300,400,700",
482
+ "Karla:400,italic,700,700italic",
483
+ "Karma:300,400,500,600,700",
484
+ "Katibeh:400",
485
+ "Kaushan+Script:400",
486
+ "Kavivanar:400",
487
+ "Kavoon:400",
488
+ "Kdam+Thmor:400",
489
+ "Keania+One:400",
490
+ "Kelly+Slab:400",
491
+ "Kenia:400",
492
+ "Khand:300,400,500,600,700",
493
+ "Khmer:400",
494
+ "Khula:300,400,600,700,800",
495
+ "Kirang+Haerang:400",
496
+ "Kite+One:400",
497
+ "Knewave:400",
498
+ "KoHo:200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic",
499
+ "Kodchasan:200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic",
500
+ "Kosugi:400",
501
+ "Kosugi+Maru:400",
502
+ "Kotta+One:400",
503
+ "Koulen:400",
504
+ "Kranky:400",
505
+ "Kreon:300,400,500,600,700",
506
+ "Kristi:400",
507
+ "Krona+One:400",
508
+ "Krub:200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic",
509
+ "Kulim+Park:200,200italic,300,300italic,400,italic,600,600italic,700,700italic",
510
+ "Kumar+One:400",
511
+ "Kumar+One+Outline:400",
512
+ "Kurale:400",
513
+ "La+Belle+Aurore:400",
514
+ "Lacquer:400",
515
+ "Laila:300,400,500,600,700",
516
+ "Lakki+Reddy:400",
517
+ "Lalezar:400",
518
+ "Lancelot:400",
519
+ "Lateef:400",
520
+ "Lato:100,100italic,300,300italic,400,italic,700,700italic,900,900italic",
521
+ "League+Script:400",
522
+ "Leckerli+One:400",
523
+ "Ledger:400",
524
+ "Lekton:400,italic,700",
525
+ "Lemon:400",
526
+ "Lemonada:300,400,500,600,700",
527
+ "Lexend+Deca:400",
528
+ "Lexend+Exa:400",
529
+ "Lexend+Giga:400",
530
+ "Lexend+Mega:400",
531
+ "Lexend+Peta:400",
532
+ "Lexend+Tera:400",
533
+ "Lexend+Zetta:400",
534
+ "Libre+Barcode+128:400",
535
+ "Libre+Barcode+128+Text:400",
536
+ "Libre+Barcode+39:400",
537
+ "Libre+Barcode+39+Extended:400",
538
+ "Libre+Barcode+39+Extended+Text:400",
539
+ "Libre+Barcode+39+Text:400",
540
+ "Libre+Baskerville:400,italic,700",
541
+ "Libre+Caslon+Display:400",
542
+ "Libre+Caslon+Text:400,italic,700",
543
+ "Libre+Franklin:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
544
+ "Life+Savers:400,700,800",
545
+ "Lilita+One:400",
546
+ "Lily+Script+One:400",
547
+ "Limelight:400",
548
+ "Linden+Hill:400,italic",
549
+ "Literata:400,500,600,700,italic,500italic,600italic,700italic",
550
+ "Liu+Jian+Mao+Cao:400",
551
+ "Livvic:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,900,900italic",
552
+ "Lobster:400",
553
+ "Lobster+Two:400,italic,700,700italic",
554
+ "Londrina+Outline:400",
555
+ "Londrina+Shadow:400",
556
+ "Londrina+Sketch:400",
557
+ "Londrina+Solid:100,300,400,900",
558
+ "Long+Cang:400",
559
+ "Lora:400,italic,700,700italic",
560
+ "Love+Ya+Like+A+Sister:400",
561
+ "Loved+by+the+King:400",
562
+ "Lovers+Quarrel:400",
563
+ "Luckiest+Guy:400",
564
+ "Lusitana:400,700",
565
+ "Lustria:400",
566
+ "M+PLUS+1p:100,300,400,500,700,800,900",
567
+ "M+PLUS+Rounded+1c:100,300,400,500,700,800,900",
568
+ "Ma+Shan+Zheng:400",
569
+ "Macondo:400",
570
+ "Macondo+Swash+Caps:400",
571
+ "Mada:200,300,400,500,600,700,900",
572
+ "Magra:400,700",
573
+ "Maiden+Orange:400",
574
+ "Maitree:200,300,400,500,600,700",
575
+ "Major+Mono+Display:400",
576
+ "Mako:400",
577
+ "Mali:200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic",
578
+ "Mallanna:400",
579
+ "Mandali:400",
580
+ "Manjari:100,400,700",
581
+ "Mansalva:400",
582
+ "Manuale:400,500,600,700,italic,500italic,600italic,700italic",
583
+ "Marcellus:400",
584
+ "Marcellus+SC:400",
585
+ "Marck+Script:400",
586
+ "Margarine:400",
587
+ "Markazi+Text:400,500,600,700",
588
+ "Marko+One:400",
589
+ "Marmelad:400",
590
+ "Martel:200,300,400,600,700,800,900",
591
+ "Martel+Sans:200,300,400,600,700,800,900",
592
+ "Marvel:400,italic,700,700italic",
593
+ "Mate:400,italic",
594
+ "Mate+SC:400",
595
+ "Maven+Pro:400,500,600,700,800,900",
596
+ "McLaren:400",
597
+ "Meddon:400",
598
+ "MedievalSharp:400",
599
+ "Medula+One:400",
600
+ "Meera+Inimai:400",
601
+ "Megrim:400",
602
+ "Meie+Script:400",
603
+ "Merienda:400,700",
604
+ "Merienda+One:400",
605
+ "Merriweather:300,300italic,400,italic,700,700italic,900,900italic",
606
+ "Merriweather+Sans:300,300italic,400,italic,700,700italic,800,800italic",
607
+ "Metal:400",
608
+ "Metal+Mania:400",
609
+ "Metamorphous:400",
610
+ "Metrophobic:400",
611
+ "Michroma:400",
612
+ "Milonga:400",
613
+ "Miltonian:400",
614
+ "Miltonian+Tattoo:400",
615
+ "Mina:400,700",
616
+ "Miniver:400",
617
+ "Miriam+Libre:400,700",
618
+ "Mirza:400,500,600,700",
619
+ "Miss+Fajardose:400",
620
+ "Mitr:200,300,400,500,600,700",
621
+ "Modak:400",
622
+ "Modern+Antiqua:400",
623
+ "Mogra:400",
624
+ "Molengo:400",
625
+ "Molle:italic",
626
+ "Monda:400,700",
627
+ "Monofett:400",
628
+ "Monoton:400",
629
+ "Monsieur+La+Doulaise:400",
630
+ "Montaga:400",
631
+ "Montez:400",
632
+ "Montserrat:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
633
+ "Montserrat+Alternates:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
634
+ "Montserrat+Subrayada:400,700",
635
+ "Moul:400",
636
+ "Moulpali:400",
637
+ "Mountains+of+Christmas:400,700",
638
+ "Mouse+Memoirs:400",
639
+ "Mr+Bedfort:400",
640
+ "Mr+Dafoe:400",
641
+ "Mr+De+Haviland:400",
642
+ "Mrs+Saint+Delafield:400",
643
+ "Mrs+Sheppards:400",
644
+ "Mukta:200,300,400,500,600,700,800",
645
+ "Mukta+Mahee:200,300,400,500,600,700,800",
646
+ "Mukta+Malar:200,300,400,500,600,700,800",
647
+ "Mukta+Vaani:200,300,400,500,600,700,800",
648
+ "Muli:200,300,400,500,600,700,800,900,200italic,300italic,italic,500italic,600italic,700italic,800italic,900italic",
649
+ "Mystery+Quest:400",
650
+ "NTR:400",
651
+ "Nanum+Brush+Script:400",
652
+ "Nanum+Gothic:400,700,800",
653
+ "Nanum+Gothic+Coding:400,700",
654
+ "Nanum+Myeongjo:400,700,800",
655
+ "Nanum+Pen+Script:400",
656
+ "Neucha:400",
657
+ "Neuton:200,300,400,italic,700,800",
658
+ "New+Rocker:400",
659
+ "News+Cycle:400,700",
660
+ "Niconne:400",
661
+ "Niramit:200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic",
662
+ "Nixie+One:400",
663
+ "Nobile:400,italic,500,500italic,700,700italic",
664
+ "Nokora:400,700",
665
+ "Norican:400",
666
+ "Nosifer:400",
667
+ "Notable:400",
668
+ "Nothing+You+Could+Do:400",
669
+ "Noticia+Text:400,italic,700,700italic",
670
+ "Noto+Sans:400,italic,700,700italic",
671
+ "Noto+Sans+HK:100,300,400,500,700,900",
672
+ "Noto+Sans+JP:100,300,400,500,700,900",
673
+ "Noto+Sans+KR:100,300,400,500,700,900",
674
+ "Noto+Sans+SC:100,300,400,500,700,900",
675
+ "Noto+Sans+TC:100,300,400,500,700,900",
676
+ "Noto+Serif:400,italic,700,700italic",
677
+ "Noto+Serif+JP:200,300,400,500,600,700,900",
678
+ "Noto+Serif+KR:200,300,400,500,600,700,900",
679
+ "Noto+Serif+SC:200,300,400,500,600,700,900",
680
+ "Noto+Serif+TC:200,300,400,500,600,700,900",
681
+ "Nova+Cut:400",
682
+ "Nova+Flat:400",
683
+ "Nova+Mono:400",
684
+ "Nova+Oval:400",
685
+ "Nova+Round:400",
686
+ "Nova+Script:400",
687
+ "Nova+Slim:400",
688
+ "Nova+Square:400",
689
+ "Numans:400",
690
+ "Nunito:200,200italic,300,300italic,400,italic,600,600italic,700,700italic,800,800italic,900,900italic",
691
+ "Nunito+Sans:200,200italic,300,300italic,400,italic,600,600italic,700,700italic,800,800italic,900,900italic",
692
+ "Odibee+Sans:400",
693
+ "Odor+Mean+Chey:400",
694
+ "Offside:400",
695
+ "Old+Standard+TT:400,italic,700",
696
+ "Oldenburg:400",
697
+ "Oleo+Script:400,700",
698
+ "Oleo+Script+Swash+Caps:400,700",
699
+ "Open+Sans:300,300italic,400,italic,600,600italic,700,700italic,800,800italic",
700
+ "Open+Sans+Condensed:300,300italic,700",
701
+ "Oranienbaum:400",
702
+ "Orbitron:400,500,600,700,800,900",
703
+ "Oregano:400,italic",
704
+ "Orienta:400",
705
+ "Original+Surfer:400",
706
+ "Oswald:200,300,400,500,600,700",
707
+ "Over+the+Rainbow:400",
708
+ "Overlock:400,italic,700,700italic,900,900italic",
709
+ "Overlock+SC:400",
710
+ "Overpass:100,100italic,200,200italic,300,300italic,400,italic,600,600italic,700,700italic,800,800italic,900,900italic",
711
+ "Overpass+Mono:300,400,600,700",
712
+ "Ovo:400",
713
+ "Oxygen:300,400,700",
714
+ "Oxygen+Mono:400",
715
+ "PT+Mono:400",
716
+ "PT+Sans:400,italic,700,700italic",
717
+ "PT+Sans+Caption:400,700",
718
+ "PT+Sans+Narrow:400,700",
719
+ "PT+Serif:400,italic,700,700italic",
720
+ "PT+Serif+Caption:400,italic",
721
+ "Pacifico:400",
722
+ "Padauk:400,700",
723
+ "Palanquin:100,200,300,400,500,600,700",
724
+ "Palanquin+Dark:400,500,600,700",
725
+ "Pangolin:400",
726
+ "Paprika:400",
727
+ "Parisienne:400",
728
+ "Passero+One:400",
729
+ "Passion+One:400,700,900",
730
+ "Pathway+Gothic+One:400",
731
+ "Patrick+Hand:400",
732
+ "Patrick+Hand+SC:400",
733
+ "Pattaya:400",
734
+ "Patua+One:400",
735
+ "Pavanam:400",
736
+ "Paytone+One:400",
737
+ "Peddana:400",
738
+ "Peralta:400",
739
+ "Permanent+Marker:400",
740
+ "Petit+Formal+Script:400",
741
+ "Petrona:400",
742
+ "Philosopher:400,italic,700,700italic",
743
+ "Piedra:400",
744
+ "Pinyon+Script:400",
745
+ "Pirata+One:400",
746
+ "Plaster:400",
747
+ "Play:400,700",
748
+ "Playball:400",
749
+ "Playfair+Display:400,500,600,700,800,900,italic,500italic,600italic,700italic,800italic,900italic",
750
+ "Playfair+Display+SC:400,italic,700,700italic,900,900italic",
751
+ "Podkova:400,500,600,700,800",
752
+ "Poiret+One:400",
753
+ "Poller+One:400",
754
+ "Poly:400,italic",
755
+ "Pompiere:400",
756
+ "Pontano+Sans:400",
757
+ "Poor+Story:400",
758
+ "Poppins:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
759
+ "Port+Lligat+Sans:400",
760
+ "Port+Lligat+Slab:400",
761
+ "Pragati+Narrow:400,700",
762
+ "Prata:400",
763
+ "Preahvihear:400",
764
+ "Press+Start+2P:400",
765
+ "Pridi:200,300,400,500,600,700",
766
+ "Princess+Sofia:400",
767
+ "Prociono:400",
768
+ "Prompt:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
769
+ "Prosto+One:400",
770
+ "Proza+Libre:400,italic,500,500italic,600,600italic,700,700italic,800,800italic",
771
+ "Public+Sans:100,200,300,400,500,600,700,800,900,100italic,200italic,300italic,italic,500italic,600italic,700italic,800italic,900italic",
772
+ "Puritan:400,italic,700,700italic",
773
+ "Purple+Purse:400",
774
+ "Quando:400",
775
+ "Quantico:400,italic,700,700italic",
776
+ "Quattrocento:400,700",
777
+ "Quattrocento+Sans:400,italic,700,700italic",
778
+ "Questrial:400",
779
+ "Quicksand:300,400,500,600,700",
780
+ "Quintessential:400",
781
+ "Qwigley:400",
782
+ "Racing+Sans+One:400",
783
+ "Radley:400,italic",
784
+ "Rajdhani:300,400,500,600,700",
785
+ "Rakkas:400",
786
+ "Raleway:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
787
+ "Raleway+Dots:400",
788
+ "Ramabhadra:400",
789
+ "Ramaraja:400",
790
+ "Rambla:400,italic,700,700italic",
791
+ "Rammetto+One:400",
792
+ "Ranchers:400",
793
+ "Rancho:400",
794
+ "Ranga:400,700",
795
+ "Rasa:300,400,500,600,700",
796
+ "Rationale:400",
797
+ "Ravi+Prakash:400",
798
+ "Red+Hat+Display:400,italic,500,500italic,700,700italic,900,900italic",
799
+ "Red+Hat+Text:400,italic,500,500italic,700,700italic",
800
+ "Redressed:400",
801
+ "Reem+Kufi:400",
802
+ "Reenie+Beanie:400",
803
+ "Revalia:400",
804
+ "Rhodium+Libre:400",
805
+ "Ribeye:400",
806
+ "Ribeye+Marrow:400",
807
+ "Righteous:400",
808
+ "Risque:400",
809
+ "Roboto:100,100italic,300,300italic,400,italic,500,500italic,700,700italic,900,900italic",
810
+ "Roboto+Condensed:300,300italic,400,italic,700,700italic",
811
+ "Roboto+Mono:100,100italic,300,300italic,400,italic,500,500italic,700,700italic",
812
+ "Roboto+Slab:100,200,300,400,500,600,700,800,900",
813
+ "Rochester:400",
814
+ "Rock+Salt:400",
815
+ "Rokkitt:100,200,300,400,500,600,700,800,900",
816
+ "Romanesco:400",
817
+ "Ropa+Sans:400,italic",
818
+ "Rosario:300,400,500,600,700,300italic,italic,500italic,600italic,700italic",
819
+ "Rosarivo:400,italic",
820
+ "Rouge+Script:400",
821
+ "Rozha+One:400",
822
+ "Rubik:300,300italic,400,italic,500,500italic,700,700italic,900,900italic",
823
+ "Rubik+Mono+One:400",
824
+ "Ruda:400,700,900",
825
+ "Rufina:400,700",
826
+ "Ruge+Boogie:400",
827
+ "Ruluko:400",
828
+ "Rum+Raisin:400",
829
+ "Ruslan+Display:400",
830
+ "Russo+One:400",
831
+ "Ruthie:400",
832
+ "Rye:400",
833
+ "Sacramento:400",
834
+ "Sahitya:400,700",
835
+ "Sail:400",
836
+ "Saira:100,200,300,400,500,600,700,800,900",
837
+ "Saira+Condensed:100,200,300,400,500,600,700,800,900",
838
+ "Saira+Extra+Condensed:100,200,300,400,500,600,700,800,900",
839
+ "Saira+Semi+Condensed:100,200,300,400,500,600,700,800,900",
840
+ "Saira+Stencil+One:400",
841
+ "Salsa:400",
842
+ "Sanchez:400,italic",
843
+ "Sancreek:400",
844
+ "Sansita:400,italic,700,700italic,800,800italic,900,900italic",
845
+ "Sarabun:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic",
846
+ "Sarala:400,700",
847
+ "Sarina:400",
848
+ "Sarpanch:400,500,600,700,800,900",
849
+ "Satisfy:400",
850
+ "Sawarabi+Gothic:400",
851
+ "Sawarabi+Mincho:400",
852
+ "Scada:400,italic,700,700italic",
853
+ "Scheherazade:400,700",
854
+ "Schoolbell:400",
855
+ "Scope+One:400",
856
+ "Seaweed+Script:400",
857
+ "Secular+One:400",
858
+ "Sedgwick+Ave:400",
859
+ "Sedgwick+Ave+Display:400",
860
+ "Sevillana:400",
861
+ "Seymour+One:400",
862
+ "Shadows+Into+Light:400",
863
+ "Shadows+Into+Light+Two:400",
864
+ "Shanti:400",
865
+ "Share:400,italic,700,700italic",
866
+ "Share+Tech:400",
867
+ "Share+Tech+Mono:400",
868
+ "Shojumaru:400",
869
+ "Short+Stack:400",
870
+ "Shrikhand:400",
871
+ "Siemreap:400",
872
+ "Sigmar+One:400",
873
+ "Signika:300,400,600,700",
874
+ "Signika+Negative:300,400,600,700",
875
+ "Simonetta:400,italic,900,900italic",
876
+ "Single+Day:400",
877
+ "Sintony:400,700",
878
+ "Sirin+Stencil:400",
879
+ "Six+Caps:400",
880
+ "Skranji:400,700",
881
+ "Slabo+13px:400",
882
+ "Slabo+27px:400",
883
+ "Slackey:400",
884
+ "Smokum:400",
885
+ "Smythe:400",
886
+ "Sniglet:400,800",
887
+ "Snippet:400",
888
+ "Snowburst+One:400",
889
+ "Sofadi+One:400",
890
+ "Sofia:400",
891
+ "Solway:300,400,500,700,800",
892
+ "Song+Myung:400",
893
+ "Sonsie+One:400",
894
+ "Sorts+Mill+Goudy:400,italic",
895
+ "Source+Code+Pro:200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,900,900italic",
896
+ "Source+Sans+Pro:200,200italic,300,300italic,400,italic,600,600italic,700,700italic,900,900italic",
897
+ "Source+Serif+Pro:400,600,700",
898
+ "Space+Mono:400,italic,700,700italic",
899
+ "Special+Elite:400",
900
+ "Spectral:200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic",
901
+ "Spectral+SC:200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic",
902
+ "Spicy+Rice:400",
903
+ "Spinnaker:400",
904
+ "Spirax:400",
905
+ "Squada+One:400",
906
+ "Sree+Krushnadevaraya:400",
907
+ "Sriracha:400",
908
+ "Srisakdi:400,700",
909
+ "Staatliches:400",
910
+ "Stalemate:400",
911
+ "Stalinist+One:400",
912
+ "Stardos+Stencil:400,700",
913
+ "Stint+Ultra+Condensed:400",
914
+ "Stint+Ultra+Expanded:400",
915
+ "Stoke:300,400",
916
+ "Strait:400",
917
+ "Stylish:400",
918
+ "Sue+Ellen+Francisco:400",
919
+ "Suez+One:400",
920
+ "Sulphur+Point:300,400,700",
921
+ "Sumana:400,700",
922
+ "Sunflower:300,500,700",
923
+ "Sunshiney:400",
924
+ "Supermercado+One:400",
925
+ "Sura:400,700",
926
+ "Suranna:400",
927
+ "Suravaram:400",
928
+ "Suwannaphum:400",
929
+ "Swanky+and+Moo+Moo:400",
930
+ "Syncopate:400,700",
931
+ "Tajawal:200,300,400,500,700,800,900",
932
+ "Tangerine:400,700",
933
+ "Taprom:400",
934
+ "Tauri:400",
935
+ "Taviraj:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
936
+ "Teko:300,400,500,600,700",
937
+ "Telex:400",
938
+ "Tenali+Ramakrishna:400",
939
+ "Tenor+Sans:400",
940
+ "Text+Me+One:400",
941
+ "Thasadith:400,italic,700,700italic",
942
+ "The+Girl+Next+Door:400",
943
+ "Tienne:400,700,900",
944
+ "Tillana:400,500,600,700,800",
945
+ "Timmana:400",
946
+ "Tinos:400,italic,700,700italic",
947
+ "Titan+One:400",
948
+ "Titillium+Web:200,200italic,300,300italic,400,italic,600,600italic,700,700italic,900",
949
+ "Tomorrow:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
950
+ "Trade+Winds:400",
951
+ "Trirong:100,100italic,200,200italic,300,300italic,400,italic,500,500italic,600,600italic,700,700italic,800,800italic,900,900italic",
952
+ "Trocchi:400",
953
+ "Trochut:400,italic,700",
954
+ "Trykker:400",
955
+ "Tulpen+One:400",
956
+ "Turret+Road:200,300,400,500,700,800",
957
+ "Ubuntu:300,300italic,400,italic,500,500italic,700,700italic",
958
+ "Ubuntu+Condensed:400",
959
+ "Ubuntu+Mono:400,italic,700,700italic",
960
+ "Ultra:400",
961
+ "Uncial+Antiqua:400",
962
+ "Underdog:400",
963
+ "Unica+One:400",
964
+ "UnifrakturCook:700",
965
+ "UnifrakturMaguntia:400",
966
+ "Unkempt:400,700",
967
+ "Unlock:400",
968
+ "Unna:400,italic,700,700italic",
969
+ "VT323:400",
970
+ "Vampiro+One:400",
971
+ "Varela:400",
972
+ "Varela+Round:400",
973
+ "Vast+Shadow:400",
974
+ "Vesper+Libre:400,500,700,900",
975
+ "Vibes:400",
976
+ "Vibur:400",
977
+ "Vidaloka:400",
978
+ "Viga:400",
979
+ "Voces:400",
980
+ "Volkhov:400,italic,700,700italic",
981
+ "Vollkorn:400,italic,600,600italic,700,700italic,900,900italic",
982
+ "Vollkorn+SC:400,600,700,900",
983
+ "Voltaire:400",
984
+ "Waiting+for+the+Sunrise:400",
985
+ "Wallpoet:400",
986
+ "Walter+Turncoat:400",
987
+ "Warnes:400",
988
+ "Wellfleet:400",
989
+ "Wendy+One:400",
990
+ "Wire+One:400",
991
+ "Work+Sans:100,200,300,400,500,600,700,800,900",
992
+ "Yanone+Kaffeesatz:200,300,400,500,600,700",
993
+ "Yantramanav:100,300,400,500,700,900",
994
+ "Yatra+One:400",
995
+ "Yellowtail:400",
996
+ "Yeon+Sung:400",
997
+ "Yeseva+One:400",
998
+ "Yesteryear:400",
999
+ "Yrsa:300,400,500,600,700",
1000
+ "ZCOOL+KuaiLe:400",
1001
+ "ZCOOL+QingKe+HuangYou:400",
1002
+ "ZCOOL+XiaoWei:400",
1003
+ "Zeyada:400",
1004
+ "Zhi+Mang+Xing:400",
1005
+ "Zilla+Slab:300,300italic,400,italic,500,500italic,600,600italic,700,700italic",
1006
+ "Zilla+Slab+Highlight:400,700"
1007
+ ]
1008
+ };
1009
+
1010
+ var Fontselect = (function(){
1011
+
1012
+ function Fontselect(original, o) {
1013
+ if (!o.systemFonts) { o.systemFonts = []; }
1014
+ if (!o.localFonts) { o.localFonts = []; }
1015
+ if (!o.googleFonts) { o.googleFonts = []; }
1016
+
1017
+ var googleFonts = [];
1018
+ for (var i = 0; i < o.googleFonts.length; i++) {
1019
+ var item = o.googleFonts[i].split(':'); // Unna:regular,italic,700,700italic
1020
+ var fontName = item[0], fontVariants = item[1] ? item[1].split(',') : [];
1021
+ for (var v = 0; v < fontVariants.length; v++) {
1022
+ googleFonts.push(fontName + ':' + fontVariants[v]);
1023
+ }
1024
+ }
1025
+ o.googleFonts = googleFonts;
1026
+
1027
+ this.options = o;
1028
+ this.$original = $(original);
1029
+ this.setupHtml();
1030
+ this.getVisibleFonts();
1031
+ this.bindEvents();
1032
+ this.query = '';
1033
+ this.keyActive = false;
1034
+ this.searchBoxHeight = 0;
1035
+
1036
+ var font = this.$original.val();
1037
+ if (font) {
1038
+ this.updateSelected();
1039
+ this.addFontLink(font);
1040
+ }
1041
+ }
1042
+
1043
+ Fontselect.prototype = {
1044
+ keyDown: function(e) {
1045
+
1046
+ function stop(e) {
1047
+ e.preventDefault();
1048
+ e.stopPropagation();
1049
+ }
1050
+
1051
+ this.keyActive = true;
1052
+ if (e.keyCode == 27) {// Escape
1053
+ stop(e);
1054
+ this.toggleDropdown('hide');
1055
+ return;
1056
+ }
1057
+ if (e.keyCode == 38) {// Cursor up
1058
+ stop(e);
1059
+ var $li = $('li.active', this.$results), $pli = $li.prev('li');
1060
+ if ($pli.length > 0) {
1061
+ $li.removeClass('active');
1062
+ this.$results.scrollTop($pli.addClass('active')[0].offsetTop - this.searchBoxHeight);
1063
+ }
1064
+ return;
1065
+ }
1066
+ if (e.keyCode == 40) {// Cursor down
1067
+ stop(e);
1068
+ var $li = $('li.active', this.$results), $nli = $li.next('li');
1069
+ if ($nli.length > 0) {
1070
+ $li.removeClass('active');
1071
+ this.$results.scrollTop($nli.addClass('active')[0].offsetTop - this.searchBoxHeight);
1072
+ }
1073
+ return;
1074
+ }
1075
+ if (e.keyCode == 13) {// Enter
1076
+ stop(e);
1077
+ $('li.active', this.$results).trigger('click');
1078
+ return;
1079
+ }
1080
+ this.query += String.fromCharCode(e.keyCode).toLowerCase();
1081
+ var $found = $("li[data-query^='"+ this.query +"']").first();
1082
+ if ($found.length > 0) {
1083
+ $('li.active', this.$results).removeClass('active');
1084
+ this.$results.scrollTop($found.addClass('active')[0].offsetTop);
1085
+ }
1086
+ },
1087
+
1088
+ keyUp: function(e) {
1089
+ this.keyActive = false;
1090
+ },
1091
+
1092
+ bindEvents: function() {
1093
+ var self = this;
1094
+
1095
+ $('li', this.$results)
1096
+ .click(__bind(this.selectFont, this))
1097
+ .mouseover(__bind(this.activateFont, this));
1098
+
1099
+ this.$select.click(__bind(function() { self.toggleDropdown('show') }, this));
1100
+
1101
+ // Call like so: $("input[name='ffSelect']").trigger('setFont', [fontFamily, fontWeight]);
1102
+ this.$original.on('setFont', function(evt, fontFamily, fontWeight) {
1103
+ fontWeight = fontWeight || 400;
1104
+
1105
+ var fontSpec = fontFamily.replace(/ /g, '+') + ':' + fontWeight;
1106
+
1107
+ var $li = $("li[data-value='"+ fontSpec +"']", self.$results);
1108
+ if ($li.length == 0) {
1109
+ fontSpec = fontFamily.replace(/ /g, '+');
1110
+ }
1111
+ $li = $("li[data-value='"+ fontSpec +"']", self.$results);
1112
+ $('li.active', self.$results).removeClass('active');
1113
+ $li.addClass('active');
1114
+
1115
+ self.$original.val(fontSpec);
1116
+ self.updateSelected();
1117
+ self.addFontLink($li.data('value'));
1118
+ //$li.trigger('click'); // Removed 2019-10-16
1119
+ });
1120
+ this.$original.on('change', function() {
1121
+ self.updateSelected();
1122
+ self.addFontLink($('li.active', self.$results).data('value'));
1123
+ });
1124
+
1125
+ if (this.options.searchable) {
1126
+ this.$input.on('keyup', function() {
1127
+ var q = this.value.toLowerCase();
1128
+ // Hide options that don't match query:
1129
+ $('li', self.$results).each(function() {
1130
+ if ($(this).text().toLowerCase().indexOf(q) == -1) {
1131
+ $(this).hide();
1132
+ }
1133
+ else {
1134
+ $(this).show();
1135
+ }
1136
+ })
1137
+ })
1138
+ }
1139
+
1140
+ $(document).on('click', function(e) {
1141
+ if ($(e.target).closest('.'+self.options.style).length === 0) {
1142
+ self.toggleDropdown('hide');
1143
+ }
1144
+ });
1145
+ },
1146
+
1147
+ toggleDropdown: function(hideShow) {
1148
+ if (hideShow === 'hide') {
1149
+ // Make inactive
1150
+ this.$element.off('keydown keyup');
1151
+ this.query = '';
1152
+ this.keyActive = false;
1153
+ this.$element.removeClass('font-select-active');
1154
+ this.$drop.hide();
1155
+ clearInterval(this.visibleInterval);
1156
+ } else {
1157
+ // Make active
1158
+ this.$element.on('keydown', __bind(this.keyDown, this));
1159
+ this.$element.on('keyup', __bind(this.keyUp, this));
1160
+ this.$element.addClass('font-select-active');
1161
+ this.$drop.show();
1162
+
1163
+ this.visibleInterval = setInterval(__bind(this.getVisibleFonts, this), 500);
1164
+ this.searchBoxHeight = this.$search.outerHeight();
1165
+ this.moveToSelected();
1166
+
1167
+ /*
1168
+ if (this.options.searchable) {
1169
+ // Focus search box
1170
+ $this.$input.focus();
1171
+ }
1172
+ */
1173
+ }
1174
+ },
1175
+
1176
+ selectFont: function() {
1177
+ var font = $('li.active', this.$results).data('value');
1178
+ this.$original.val(font).change();
1179
+ this.updateSelected();
1180
+ this.toggleDropdown('hide'); // Hide dropdown
1181
+ },
1182
+
1183
+ moveToSelected: function() {
1184
+ var font = this.$original.val().replace(/ /g, '+');
1185
+ var $li = font ? $("li[data-value='"+ font +"']", this.$results) : $li = $('li', this.$results).first();
1186
+ this.$results.scrollTop($li.addClass('active')[0].offsetTop - this.searchBoxHeight);
1187
+ },
1188
+
1189
+ activateFont: function(e) {
1190
+ if (this.keyActive) { return; }
1191
+ $('li.active', this.$results).removeClass('active');
1192
+ $(e.target).addClass('active');
1193
+ },
1194
+
1195
+ updateSelected: function() {
1196
+ var font = this.$original.val();
1197
+ $('span', this.$element).text(this.toReadable(font)).css(this.toStyle(font));
1198
+ },
1199
+
1200
+ setupHtml: function() {
1201
+ this.$original.hide();
1202
+ this.$element = $('<div>', {'class': this.options.style});
1203
+ this.$select = $('<span tabindex="0">' + this.options.placeholder + '</span>');
1204
+ this.$search = $('<div>', {'class': 'fs-search'});
1205
+ this.$input = $('<input>', {type:'text'});
1206
+ if (this.options.placeholderSearch) {
1207
+ this.$input.attr('placeholder', this.options.placeholderSearch);
1208
+ }
1209
+ this.$search.append(this.$input);
1210
+ this.$drop = $('<div>', {'class': 'fs-drop'});
1211
+ this.$results = $('<ul>', {'class': 'fs-results'});
1212
+ this.$original.after(this.$element.append(this.$select, this.$drop));
1213
+ this.options.searchable && this.$drop.append(this.$search);
1214
+ this.$drop.append(this.$results.append(this.fontsAsHtml())).hide();
1215
+ },
1216
+
1217
+ fontsAsHtml: function() {
1218
+ var i, r, s, style, h = '';
1219
+ var systemFonts = this.options.systemFonts;
1220
+ var localFonts = this.options.localFonts;
1221
+ var googleFonts = this.options.googleFonts;
1222
+
1223
+ for (i = 0; i < systemFonts.length; i++){
1224
+ r = this.toReadable(systemFonts[i]);
1225
+ s = this.toStyle(systemFonts[i]);
1226
+ style = 'font-family:' + s['font-family'];
1227
+ if ((localFonts.length > 0 || googleFonts.length > 0) && i == systemFonts.length-1) {
1228
+ style += ';border-bottom:1px solid #444'; // Separator after last system font
1229
+ }
1230
+ h += '<li data-value="'+ systemFonts[i] +'" data-query="' + systemFonts[i].toLowerCase() + '" style="' + style + '">' + r + '</li>';
1231
+ }
1232
+
1233
+ for (i = 0; i < localFonts.length; i++){
1234
+ r = this.toReadable(localFonts[i]);
1235
+ s = this.toStyle(localFonts[i]);
1236
+ style = 'font-family:' + s['font-family'];
1237
+ if (googleFonts.length > 0 && i == localFonts.length-1) {
1238
+ style += ';border-bottom:1px solid #444'; // Separator after last local font
1239
+ }
1240
+ h += '<li data-value="'+ localFonts[i] +'" data-query="' + localFonts[i].toLowerCase() + '" style="' + style + '">' + r + '</li>';
1241
+ }
1242
+
1243
+ for (i = 0; i < googleFonts.length; i++){
1244
+ r = this.toReadable(googleFonts[i]);
1245
+ s = this.toStyle(googleFonts[i]);
1246
+ style = 'font-family:' + s['font-family'] + ';font-weight:' + s['font-weight'] + ';font-style:' + s['font-style'];
1247
+ h += '<li data-value="'+ googleFonts[i] +'" data-query="' + googleFonts[i].toLowerCase() + '" style="' + style + '">' + r + '</li>';
1248
+ }
1249
+
1250
+ return h;
1251
+ },
1252
+
1253
+ toReadable: function(font) {
1254
+ return font.replace(/[\+|:]/g, ' ').replace(/(\d+)italic/, '$1 italic');
1255
+ },
1256
+
1257
+ toStyle: function(font) {
1258
+ var t = font.split(':'), italic = false;
1259
+ if (t[1] && /italic/.test(t[1])) {
1260
+ italic = true;
1261
+ t[1] = t[1].replace('italic','');
1262
+ }
1263
+
1264
+ return {'font-family':"'"+this.toReadable(t[0])+"'", 'font-weight': (t[1] || 400), 'font-style': italic?'italic':'normal'};
1265
+ },
1266
+
1267
+ getVisibleFonts: function() {
1268
+ if(this.$results.is(':hidden')) { return; }
1269
+
1270
+ var fs = this;
1271
+ var top = this.$results.scrollTop();
1272
+ var bottom = top + this.$results.height();
1273
+
1274
+ if (this.options.lookahead){
1275
+ var li = $('li', this.$results).first().height();
1276
+ bottom += li * this.options.lookahead;
1277
+ }
1278
+
1279
+ $('li:visible', this.$results).each(function(){
1280
+ var ft = $(this).position().top+top;
1281
+ var fb = ft + $(this).height();
1282
+
1283
+ if ((fb >= top) && (ft <= bottom)){
1284
+ fs.addFontLink($(this).data('value'));
1285
+ }
1286
+ });
1287
+ },
1288
+
1289
+ addFontLink: function(font) {
1290
+ if (fontsLoaded[font]) { return; }
1291
+ fontsLoaded[font] = true;
1292
+
1293
+ if (this.options.googleFonts.indexOf(font) > -1) {
1294
+ $('link:last').after('<link href="' + this.options.googleApi + font + '" rel="stylesheet" type="text/css">');
1295
+ }
1296
+ else if (this.options.localFonts.indexOf(font) > -1) {
1297
+ font = this.toReadable(font);
1298
+ $('head').append("<style> @font-face { font-family:'" + font + "'; font-style:normal; font-weight:400; src:local('" + font + "'), url('" + this.options.localFontsUrl + font + ".woff') format('woff'); } </style>");
1299
+ }
1300
+ // System fonts need not be loaded!
1301
+ }
1302
+ }; // End prototype
1303
+
1304
+ return Fontselect;
1305
+ })();
1306
+
1307
+ return this.each(function() {
1308
+ // If options exist, merge them
1309
+ if (options) { $.extend(settings, options); }
1310
+
1311
+ return new Fontselect(this, settings);
1312
+ });
1313
+ };
1314
+ })(jQuery);
js/fontselect/fontselect.min.css ADDED
@@ -0,0 +1 @@
 
1
+ .font-select *{-webkit-box-sizing:border-box;box-sizing:border-box}.font-select{font-size:16px;width:240px;position:relative;display:inline-block}.font-select .fs-drop{position:absolute;top:38px;left:0;z-index:999;background:#fff;color:#000;width:100%;border:1px solid #aaa;border-top:0;box-shadow:0 4px 5px rgba(0,0,0,.15);border-radius:0 0 4px 4px}.font-select>span{outline:0;border-radius:.25rem;border:1px solid #ced4da;display:block;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;height:38px;line-height:32px;padding:3px 8px 3px 8px;color:#444;background:#fff url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 4 5'%3e%3cpath fill='%23303030' d='M2 0L0 2h4zm0 5L0 3h4z'/%3e%3c/svg%3e") no-repeat right .75rem center/8px 10px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.font-select-active>span{background-color:#eee;border-bottom-left-radius:0;border-bottom-right-radius:0}.font-select .fs-results{max-height:190px;overflow-x:hidden;overflow-y:auto;margin:0;padding:0}.font-select .fs-results li{line-height:80%;padding:8px;margin:0;list-style:none;font-size:18px;white-space:nowrap}.font-select .fs-results li.active{background-color:#3875d7;color:#fff;cursor:pointer}.font-select .fs-search{border-bottom:1px solid #aaa;padding:4px}.font-select .fs-search input{padding:7px;width:100%;border:1px solid #aaa;font:16px Helvetica,Sans-serif;box-shadow:inset 0 1px 3px rgba(0,0,0,.06);border-radius:.1875rem}
js/fontselect/fontselect.min.js ADDED
@@ -0,0 +1,13 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ (function(b){var l={};b.fn.fontselect=function(k){var g=function(b,a){return function(){return b.apply(a,arguments)}},m={style:"font-select",placeholder:"Select a font",placeholderSearch:"Search...",searchable:!0,lookahead:2,googleApi:"https://fonts.googleapis.com/css?family=",localFontsUrl:"/fonts/",systemFonts:"Arial Helvetica+Neue Courier+New Times+New+Roman Comic+Sans+MS Verdana Impact".split(" "),googleFonts:"ABeeZee Abel Abhaya+Libre Abril+Fatface Aclonica Acme Actor Adamina Advent+Pro Aguafina+Script Akronim Aladin Alata Alatsi Aldrich Alef Alegreya Alegreya+Sans Alegreya+Sans+SC Alegreya+SC Aleo Alex+Brush Alfa+Slab+One Alice Alike Alike+Angular Allan Allerta Allerta+Stencil Allura Almarai Almendra Almendra+Display Almendra+SC Amarante Amaranth Amatic+SC Amethysta Amiko Amiri Amita Anaheim Andada Andika Angkor Annie+Use+Your+Telescope Anonymous+Pro Antic Antic+Didone Antic+Slab Anton Arapey Arbutus Arbutus+Slab Architects+Daughter Archivo Archivo+Black Archivo+Narrow Aref+Ruqaa Arima+Madurai Arimo Arizonia Armata Arsenal Artifika Arvo Arya Asap Asap+Condensed Asar Asset Assistant Astloch Asul Athiti Atma Atomic+Age Aubrey Audiowide Autour+One Average Average+Sans Averia+Gruesa+Libre Averia+Libre Averia+Sans+Libre Averia+Serif+Libre B612 B612+Mono Bad+Script Bahiana Bahianita Bai+Jamjuree Baloo Baloo+Bhai Baloo+Bhaijaan Baloo+Bhaina Baloo+Chettan Baloo+Da Baloo+Paaji Baloo+Tamma Baloo+Tammudu Baloo+Thambi Balthazar Bangers Barlow Barlow+Condensed Barlow+Semi+Condensed Barriecito Barrio Basic Baskervville Battambang Baumans Bayon Be+Vietnam Bebas+Neue Belgrano Bellefair Belleza BenchNine Bentham Berkshire+Swash Beth+Ellen Bevan Big+Shoulders+Display Big+Shoulders+Text Bigelow+Rules Bigshot+One Bilbo Bilbo+Swash+Caps BioRhyme BioRhyme+Expanded Biryani Bitter Black+And+White+Picture Black+Han+Sans Black+Ops+One Blinker Bokor Bonbon Boogaloo Bowlby+One Bowlby+One+SC Brawler Bree+Serif Bubblegum+Sans Bubbler+One Buda Buenard Bungee Bungee+Hairline Bungee+Inline Bungee+Outline Bungee+Shade Butcherman Butterfly+Kids Cabin Cabin+Condensed Cabin+Sketch Caesar+Dressing Cagliostro Cairo Calistoga Calligraffitti Cambay Cambo Candal Cantarell Cantata+One Cantora+One Capriola Cardo Carme Carrois+Gothic Carrois+Gothic+SC Carter+One Catamaran Caudex Caveat Caveat+Brush Cedarville+Cursive Ceviche+One Chakra+Petch Changa Changa+One Chango Charm Charmonman Chathura Chau+Philomene+One Chela+One Chelsea+Market Chenla Cherry+Cream+Soda Cherry+Swash Chewy Chicle Chilanka Chivo Chonburi Cinzel Cinzel+Decorative Clicker+Script Coda Coda+Caption Codystar Coiny Combo Comfortaa Coming+Soon Concert+One Condiment Content Contrail+One Convergence Cookie Copse Corben Cormorant Cormorant+Garamond Cormorant+Infant Cormorant+SC Cormorant+Unicase Cormorant+Upright Courgette Courier+Prime Cousine Coustard Covered+By+Your+Grace Crafty+Girls Creepster Crete+Round Crimson+Pro Crimson+Text Croissant+One Crushed Cuprum Cute+Font Cutive Cutive+Mono Damion Dancing+Script Dangrek Darker+Grotesque David+Libre Dawning+of+a+New+Day Days+One Dekko Delius Delius+Swash+Caps Delius+Unicase Della+Respira Denk+One Devonshire Dhurjati Didact+Gothic Diplomata Diplomata+SC DM+Sans DM+Serif+Display DM+Serif+Text Do+Hyeon Dokdo Domine Donegal+One Doppio+One Dorsa Dosis Dr+Sugiyama Duru+Sans Dynalight Eagle+Lake East+Sea+Dokdo Eater EB+Garamond Economica Eczar El+Messiri Electrolize Elsie Elsie+Swash+Caps Emblema+One Emilys+Candy Encode+Sans Encode+Sans+Condensed Encode+Sans+Expanded Encode+Sans+Semi+Condensed Encode+Sans+Semi+Expanded Engagement Englebert Enriqueta Erica+One Esteban Euphoria+Script Ewert Exo Exo+2 Expletus+Sans Fahkwang Fanwood+Text Farro Farsan Fascinate Fascinate+Inline Faster+One Fasthand Fauna+One Faustina Federant Federo Felipa Fenix Finger+Paint Fira+Code Fira+Mono Fira+Sans Fira+Sans+Condensed Fira+Sans+Extra+Condensed Fjalla+One Fjord+One Flamenco Flavors Fondamento Fontdiner+Swanky Forum Francois+One Frank+Ruhl+Libre Freckle+Face Fredericka+the+Great Fredoka+One Freehand Fresca Frijole Fruktur Fugaz+One Gabriela Gaegu Gafata Galada Galdeano Galindo Gamja+Flower Gayathri Gelasio Gentium+Basic Gentium+Book+Basic Geo Geostar Geostar+Fill Germania+One GFS+Didot GFS+Neohellenic Gidugu Gilda+Display Girassol Give+You+Glory Glass+Antiqua Glegoo Gloria+Hallelujah Goblin+One Gochi+Hand Gorditas Gothic+A1 Goudy+Bookletter+1911 Graduate Grand+Hotel Gravitas+One Great+Vibes Grenze Griffy Gruppo Gudea Gugi Gupter Gurajada Habibi Halant Hammersmith+One Hanalei Hanalei+Fill Handlee Hanuman Happy+Monkey Harmattan Headland+One Heebo Henny+Penny Hepta+Slab Herr+Von+Muellerhoff Hi+Melody Hind Hind+Guntur Hind+Madurai Hind+Siliguri Hind+Vadodara Holtwood+One+SC Homemade+Apple Homenaje Ibarra+Real+Nova IBM+Plex+Mono IBM+Plex+Sans IBM+Plex+Sans+Condensed IBM+Plex+Serif Iceberg Iceland IM+Fell+Double+Pica IM+Fell+Double+Pica+SC IM+Fell+DW+Pica IM+Fell+DW+Pica+SC IM+Fell+English IM+Fell+English+SC IM+Fell+French+Canon IM+Fell+French+Canon+SC IM+Fell+Great+Primer IM+Fell+Great+Primer+SC Imprima Inconsolata Inder Indie+Flower Inika Inknut+Antiqua Inria+Serif Irish+Grover Istok+Web Italiana Italianno Itim Jacques+Francois Jacques+Francois+Shadow Jaldi Jim+Nightshade Jockey+One Jolly+Lodger Jomhuria Jomolhari Josefin+Sans Josefin+Slab Joti+One Jua Judson Julee Julius+Sans+One Junge Jura Just+Another+Hand Just+Me+Again+Down+Here K2D Kadwa Kalam Kameron Kanit Kantumruy Karla Karma Katibeh Kaushan+Script Kavivanar Kavoon Kdam+Thmor Keania+One Kelly+Slab Kenia Khand Khmer Khula Kirang+Haerang Kite+One Knewave Kodchasan KoHo Kosugi Kosugi+Maru Kotta+One Koulen Kranky Kreon Kristi Krona+One Krub Kulim+Park Kumar+One Kumar+One+Outline Kurale La+Belle+Aurore Lacquer Laila Lakki+Reddy Lalezar Lancelot Lateef Lato League+Script Leckerli+One Ledger Lekton Lemon Lemonada Lexend+Deca Lexend+Exa Lexend+Giga Lexend+Mega Lexend+Peta Lexend+Tera Lexend+Zetta Libre+Barcode+128 Libre+Barcode+128+Text Libre+Barcode+39 Libre+Barcode+39+Extended Libre+Barcode+39+Extended+Text Libre+Barcode+39+Text Libre+Baskerville Libre+Caslon+Display Libre+Caslon+Text Libre+Franklin Life+Savers Lilita+One Lily+Script+One Limelight Linden+Hill Literata Liu+Jian+Mao+Cao Livvic Lobster Lobster+Two Londrina+Outline Londrina+Shadow Londrina+Sketch Londrina+Solid Long+Cang Lora Love+Ya+Like+A+Sister Loved+by+the+King Lovers+Quarrel Luckiest+Guy Lusitana Lustria M+PLUS+1p M+PLUS+Rounded+1c Ma+Shan+Zheng Macondo Macondo+Swash+Caps Mada Magra Maiden+Orange Maitree Major+Mono+Display Mako Mali Mallanna Mandali Manjari Mansalva Manuale Marcellus Marcellus+SC Marck+Script Margarine Markazi+Text Marko+One Marmelad Martel Martel+Sans Marvel Mate Mate+SC Maven+Pro McLaren Meddon MedievalSharp Medula+One Meera+Inimai Megrim Meie+Script Merienda Merienda+One Merriweather Merriweather+Sans Metal Metal+Mania Metamorphous Metrophobic Michroma Milonga Miltonian Miltonian+Tattoo Mina Miniver Miriam+Libre Mirza Miss+Fajardose Mitr Modak Modern+Antiqua Mogra Molengo Molle Monda Monofett Monoton Monsieur+La+Doulaise Montaga Montez Montserrat Montserrat+Alternates Montserrat+Subrayada Moul Moulpali Mountains+of+Christmas Mouse+Memoirs Mr+Bedfort Mr+Dafoe Mr+De+Haviland Mrs+Saint+Delafield Mrs+Sheppards Mukta Mukta+Mahee Mukta+Malar Mukta+Vaani Muli Mystery+Quest Nanum+Brush+Script Nanum+Gothic Nanum+Gothic+Coding Nanum+Myeongjo Nanum+Pen+Script Neucha Neuton New+Rocker News+Cycle Niconne Niramit Nixie+One Nobile Nokora Norican Nosifer Notable Nothing+You+Could+Do Noticia+Text Noto+Sans Noto+Sans+HK Noto+Sans+JP Noto+Sans+KR Noto+Sans+SC Noto+Sans+TC Noto+Serif Noto+Serif+JP Noto+Serif+KR Noto+Serif+SC Noto+Serif+TC Nova+Cut Nova+Flat Nova+Mono Nova+Oval Nova+Round Nova+Script Nova+Slim Nova+Square NTR Numans Nunito Nunito+Sans Odibee+Sans Odor+Mean+Chey Offside Old+Standard+TT Oldenburg Oleo+Script Oleo+Script+Swash+Caps Open+Sans:300 Open+Sans Open+Sans:600 Open+Sans:800 Open+Sans+Condensed:300 Oranienbaum Orbitron Oregano Orienta Original+Surfer Oswald Over+the+Rainbow Overlock Overlock+SC Overpass Overpass+Mono Ovo Oxygen Oxygen+Mono Pacifico Padauk Palanquin Palanquin+Dark Pangolin Paprika Parisienne Passero+One Passion+One Pathway+Gothic+One Patrick+Hand Patrick+Hand+SC Pattaya Patua+One Pavanam Paytone+One Peddana Peralta Permanent+Marker Petit+Formal+Script Petrona Philosopher Piedra Pinyon+Script Pirata+One Plaster Play Playball Playfair+Display Playfair+Display+SC Podkova Poiret+One Poller+One Poly Pompiere Pontano+Sans Poor+Story Poppins Port+Lligat+Sans Port+Lligat+Slab Pragati+Narrow Prata Preahvihear Press+Start+2P Pridi Princess+Sofia Prociono Prompt Prosto+One Proza+Libre PT+Mono PT+Sans PT+Sans+Caption PT+Sans+Narrow PT+Serif PT+Serif+Caption Public+Sans Puritan Purple+Purse Quando Quantico Quattrocento Quattrocento+Sans Questrial Quicksand Quintessential Qwigley Racing+Sans+One Radley Rajdhani Rakkas Raleway Raleway+Dots Ramabhadra Ramaraja Rambla Rammetto+One Ranchers Rancho Ranga Rasa Rationale Ravi+Prakash Red+Hat+Display Red+Hat+Text Redressed Reem+Kufi Reenie+Beanie Revalia Rhodium+Libre Ribeye Ribeye+Marrow Righteous Risque Roboto Roboto+Condensed Roboto+Mono Roboto+Slab Rochester Rock+Salt Rokkitt Romanesco Ropa+Sans Rosario Rosarivo Rouge+Script Rozha+One Rubik Rubik+Mono+One Ruda Rufina Ruge+Boogie Ruluko Rum+Raisin Ruslan+Display Russo+One Ruthie Rye Sacramento Sahitya Sail Saira Saira+Condensed Saira+Extra+Condensed Saira+Semi+Condensed Saira+Stencil+One Salsa Sanchez Sancreek Sansita Sarabun Sarala Sarina Sarpanch Satisfy Sawarabi+Gothic Sawarabi+Mincho Scada Scheherazade Schoolbell Scope+One Seaweed+Script Secular+One Sedgwick+Ave Sedgwick+Ave+Display Sevillana Seymour+One Shadows+Into+Light Shadows+Into+Light+Two Shanti Share Share+Tech Share+Tech+Mono Shojumaru Short+Stack Shrikhand Siemreap Sigmar+One Signika Signika+Negative Simonetta Single+Day Sintony Sirin+Stencil Six+Caps Skranji Slabo+13px Slabo+27px Slackey Smokum Smythe Sniglet Snippet Snowburst+One Sofadi+One Sofia Solway Song+Myung Sonsie+One Sorts+Mill+Goudy Source+Code+Pro Source+Sans+Pro Source+Serif+Pro Space+Mono Special+Elite Spectral Spectral+SC Spicy+Rice Spinnaker Spirax Squada+One Sree+Krushnadevaraya Sriracha Srisakdi Staatliches Stalemate Stalinist+One Stardos+Stencil Stint+Ultra+Condensed Stint+Ultra+Expanded Stoke Strait Stylish Sue+Ellen+Francisco Suez+One Sulphur+Point Sumana Sunflower Sunshiney Supermercado+One Sura Suranna Suravaram Suwannaphum Swanky+and+Moo+Moo Syncopate Tajawal Tangerine Taprom Tauri Taviraj Teko Telex Tenali+Ramakrishna Tenor+Sans Text+Me+One Thasadith The+Girl+Next+Door Tienne Tillana Timmana Tinos Titan+One Titillium+Web Tomorrow Trade+Winds Trirong Trocchi Trochut Trykker Tulpen+One Turret+Road Ubuntu Ubuntu+Condensed Ubuntu+Mono Ultra Uncial+Antiqua Underdog Unica+One UnifrakturCook UnifrakturMaguntia Unkempt Unlock Unna Vampiro+One Varela Varela+Round Vast+Shadow Vesper+Libre Vibes Vibur Vidaloka Viga Voces Volkhov Vollkorn Vollkorn+SC Voltaire VT323 Waiting+for+the+Sunrise Wallpoet Walter+Turncoat Warnes Wellfleet Wendy+One Wire+One Work+Sans Yanone+Kaffeesatz Yantramanav Yatra+One Yellowtail Yeon+Sung Yeseva+One Yesteryear Yrsa ZCOOL+KuaiLe ZCOOL+QingKe+HuangYou ZCOOL+XiaoWei Zeyada Zhi+Mang+Xing Zilla+Slab Zilla+Slab+Highlight".split(" ")},
2
+ n=function(){function k(a,c){c.systemFonts||(c.systemFonts=[]);c.localFonts||(c.localFonts=[]);c.googleFonts||(c.googleFonts=[]);this.options=c;this.$original=b(a);this.setupHtml();this.getVisibleFonts();this.bindEvents();this.query="";this.keyActive=!1;this.searchBoxHeight=0;if(a=this.$original.val())this.updateSelected(),this.addFontLink(a)}k.prototype={keyDown:function(a){function c(a){a.preventDefault();a.stopPropagation()}this.keyActive=!0;if(27==a.keyCode)c(a),this.toggleDropdown("hide");else if(38==
3
+ a.keyCode){c(a);a=b("li.active",this.$results);var e=a.prev("li");0<e.length&&(a.removeClass("active"),this.$results.scrollTop(e.addClass("active")[0].offsetTop-this.searchBoxHeight))}else 40==a.keyCode?(c(a),a=b("li.active",this.$results),e=a.next("li"),0<e.length&&(a.removeClass("active"),this.$results.scrollTop(e.addClass("active")[0].offsetTop-this.searchBoxHeight))):13==a.keyCode?(c(a),b("li.active",this.$results).trigger("click")):(this.query+=String.fromCharCode(a.keyCode).toLowerCase(),a=
4
+ b("li[data-query^='"+this.query+"']").first(),0<a.length&&(b("li.active",this.$results).removeClass("active"),this.$results.scrollTop(a.addClass("active")[0].offsetTop)))},keyUp:function(a){this.keyActive=!1},bindEvents:function(){var a=this;b("li",this.$results).click(g(this.selectFont,this)).mouseover(g(this.activateFont,this));this.$select.click(g(function(){a.toggleDropdown("show")},this));this.$original.on("setFont",function(c,e,d){d=d||400;c=e.replace(/ /g,"+")+(400==d?"":":"+d);d=b("li[data-value='"+
5
+ c+"']",a.$results);0==d.length&&(c=e.replace(/ /g,"+"));d=b("li[data-value='"+c+"']",a.$results);b("li.active",a.$results).removeClass("active");d.addClass("active");a.$original.val(c);a.updateSelected();a.addFontLink(d.data("value"))});this.$original.on("change",function(){a.updateSelected();a.addFontLink(b("li.active",a.$results).data("value"))});if(this.options.searchable)this.$input.on("keyup",function(){var c=this.value.toLowerCase();b("li",a.$results).each(function(){-1==b(this).text().toLowerCase().indexOf(c)?
6
+ b(this).hide():b(this).show()})});b(document).on("click",function(c){0===b(c.target).closest("."+a.options.style).length&&a.toggleDropdown("hide")})},toggleDropdown:function(a){"hide"===a?(this.$element.off("keydown keyup"),this.query="",this.keyActive=!1,this.$element.removeClass("font-select-active"),this.$drop.hide(),clearInterval(this.visibleInterval)):(this.$element.on("keydown",g(this.keyDown,this)),this.$element.on("keyup",g(this.keyUp,this)),this.$element.addClass("font-select-active"),this.$drop.show(),
7
+ this.visibleInterval=setInterval(g(this.getVisibleFonts,this),500),this.searchBoxHeight=this.$search.outerHeight(),this.moveToSelected())},selectFont:function(){var a=b("li.active",this.$results).data("value");this.$original.val(a).change();this.updateSelected();this.toggleDropdown("hide")},moveToSelected:function(){var a=this.$original.val().replace(/ /g,"+");a=a?b("li[data-value='"+a+"']",this.$results):a=b("li",this.$results).first();this.$results.scrollTop(a.addClass("active")[0].offsetTop-this.searchBoxHeight)},
8
+ activateFont:function(a){this.keyActive||(b("li.active",this.$results).removeClass("active"),b(a.target).addClass("active"))},updateSelected:function(){var a=this.$original.val();b("span",this.$element).text(this.toReadable(a)).css(this.toStyle(a))},setupHtml:function(){this.$original.hide();this.$element=b("<div>",{"class":this.options.style});this.$select=b('<span tabindex="0">'+this.options.placeholder+"</span>");this.$search=b("<div>",{"class":"fs-search"});this.$input=b("<input>",{type:"text"});
9
+ this.options.placeholderSearch&&this.$input.attr("placeholder",this.options.placeholderSearch);this.$search.append(this.$input);this.$drop=b("<div>",{"class":"fs-drop"});this.$results=b("<ul>",{"class":"fs-results"});this.$original.after(this.$element.append(this.$select,this.$drop));this.options.searchable&&this.$drop.append(this.$search);this.$drop.append(this.$results.append(this.fontsAsHtml())).hide()},fontsAsHtml:function(){var a,b="",e=this.options.systemFonts,d=this.options.localFonts,h=this.options.googleFonts;
10
+ for(a=0;a<e.length;a++){var g=this.toReadable(e[a]);var f=this.toStyle(e[a]);f="font-family:"+f["font-family"];(0<d.length||0<h.length)&&a==e.length-1&&(f+=";border-bottom:1px solid #444");b+='<li data-value="'+e[a]+'" data-query="'+e[a].toLowerCase()+'" style="'+f+'">'+g+"</li>"}for(a=0;a<d.length;a++)g=this.toReadable(d[a]),f=this.toStyle(d[a]),f="font-family:"+f["font-family"],0<h.length&&a==d.length-1&&(f+=";border-bottom:1px solid #444"),b+='<li data-value="'+d[a]+'" data-query="'+d[a].toLowerCase()+
11
+ '" style="'+f+'">'+g+"</li>";for(a=0;a<h.length;a++)g=this.toReadable(h[a]),f=this.toStyle(h[a]),f="font-family:"+f["font-family"]+";font-weight:"+f["font-weight"],b+='<li data-value="'+h[a]+'" data-query="'+h[a].toLowerCase()+'" style="'+f+'">'+g+"</li>";return b},toReadable:function(a){return a.replace(/[\+|:]/g," ")},toStyle:function(a){a=a.split(":");return{"font-family":"'"+this.toReadable(a[0])+"'","font-weight":a[1]||400}},getVisibleFonts:function(){if(!this.$results.is(":hidden")){var a=this,
12
+ c=this.$results.scrollTop(),e=c+this.$results.height();if(this.options.lookahead){var d=b("li",this.$results).first().height();e+=d*this.options.lookahead}b("li:visible",this.$results).each(function(){var d=b(this).position().top+c;d+b(this).height()>=c&&d<=e&&a.addFontLink(b(this).data("value"))})}},addFontLink:function(a){l[a]||(l[a]=!0,-1<this.options.googleFonts.indexOf(a)?b("link:last").after('<link href="'+this.options.googleApi+a+'" rel="stylesheet" type="text/css">'):-1<this.options.localFonts.indexOf(a)&&
13
+ (a=this.toReadable(a),b("head").append("<style> @font-face { font-family:'"+a+"'; font-style:normal; font-weight:400; src:local('"+a+"'), url('"+this.options.localFontsUrl+a+".woff') format('woff'); } </style>")))}};return k}();return this.each(function(){k&&b.extend(m,k);return new n(this,m)})}})(jQuery);
js/jquery.fullscreen.js ADDED
@@ -0,0 +1,296 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ /*
2
+ * jquery.fullscreen v0.6.0
3
+ * https://github.com/private-face/jquery.fullscreen
4
+ *
5
+ * Copyright (c) 2012–2016 Vladimir Zhuravlev
6
+ * Released under the MIT license
7
+ * https://github.com/private-face/jquery.fullscreen/blob/master/LICENSE
8
+ *
9
+ * Date: 2016-08-25
10
+ **/
11
+ (function(global, factory) {
12
+ if (typeof define === 'function' && define.amd) {
13
+ // AMD
14
+ define(['jquery'], function (jQuery) {
15
+ return factory(jQuery);
16
+ });
17
+ } else if (typeof exports === 'object') {
18
+ // CommonJS/Browserify
19
+ factory(require('jquery'));
20
+ } else {
21
+ // Global
22
+ factory(global.jQuery);
23
+ }
24
+ }(this, function($) {
25
+ function defined(a) {
26
+ return typeof a !== "undefined";
27
+ }
28
+
29
+ function extend(child, parent, prototype) {
30
+ var F = function() {};
31
+ F.prototype = parent.prototype;
32
+ child.prototype = new F();
33
+ child.prototype.constructor = child;
34
+ parent.prototype.constructor = parent;
35
+ child._super = parent.prototype;
36
+ if (prototype) {
37
+ $.extend(child.prototype, prototype);
38
+ }
39
+ }
40
+
41
+ var SUBST = [ [ "", "" ], [ "exit", "cancel" ], [ "screen", "Screen" ] ];
42
+
43
+ var VENDOR_PREFIXES = [ "", "o", "ms", "moz", "webkit", "webkitCurrent" ];
44
+
45
+ function native(obj, name) {
46
+ var prefixed;
47
+ if (typeof obj === "string") {
48
+ name = obj;
49
+ obj = document;
50
+ }
51
+ for (var i = 0; i < SUBST.length; ++i) {
52
+ name = name.replace(SUBST[i][0], SUBST[i][1]);
53
+ for (var j = 0; j < VENDOR_PREFIXES.length; ++j) {
54
+ prefixed = VENDOR_PREFIXES[j];
55
+ prefixed += j === 0 ? name : name.charAt(0).toUpperCase() + name.substr(1);
56
+ if (defined(obj[prefixed])) {
57
+ return obj[prefixed];
58
+ }
59
+ }
60
+ }
61
+ return void 0;
62
+ }
63
+
64
+ var ua = navigator.userAgent;
65
+
66
+ var fsEnabled = native("fullscreenEnabled");
67
+
68
+ var parsedChromeUA = ua.match(/Android.*Chrome\/(\d+)\./);
69
+
70
+ var IS_ANDROID_CHROME = !!parsedChromeUA;
71
+
72
+ var CHROME_VERSION;
73
+
74
+ var ANDROID_CHROME_VERSION;
75
+
76
+ if (IS_ANDROID_CHROME) {
77
+ ANDROID_CHROME_VERSION = parseInt(parsedChromeUA[1]);
78
+ }
79
+
80
+ var IS_NATIVELY_SUPPORTED = (!IS_ANDROID_CHROME || ANDROID_CHROME_VERSION > 37) && defined(native("fullscreenElement")) && (!defined(fsEnabled) || fsEnabled === true);
81
+
82
+ var version = $.fn.jquery.split(".");
83
+
84
+ var JQ_LT_17 = parseInt(version[0]) < 2 && parseInt(version[1]) < 7;
85
+
86
+ var FullScreenAbstract = function() {
87
+ this.__options = null;
88
+ this._fullScreenElement = null;
89
+ this.__savedStyles = {};
90
+ };
91
+
92
+ FullScreenAbstract.prototype = {
93
+ native: native,
94
+ _DEFAULT_OPTIONS: {
95
+ styles: {
96
+ boxSizing: "border-box",
97
+ MozBoxSizing: "border-box",
98
+ WebkitBoxSizing: "border-box"
99
+ },
100
+ toggleClass: null
101
+ },
102
+ __documentOverflow: "",
103
+ __htmlOverflow: "",
104
+ _preventDocumentScroll: function() {
105
+ this.__documentOverflow = document.body.style.overflow;
106
+ this.__htmlOverflow = document.documentElement.style.overflow;
107
+ if (!$(this._fullScreenElement).is("body, html")) {
108
+ $("body, html").css("overflow", "hidden");
109
+ }
110
+ },
111
+ _allowDocumentScroll: function() {
112
+ document.body.style.overflow = this.__documentOverflow;
113
+ document.documentElement.style.overflow = this.__htmlOverflow;
114
+ },
115
+ _fullScreenChange: function() {
116
+ if (!this.__options) {
117
+ return;
118
+ }
119
+ if (!this.isFullScreen()) {
120
+ this._allowDocumentScroll();
121
+ this._revertStyles();
122
+ this._triggerEvents();
123
+ this._fullScreenElement = null;
124
+ } else {
125
+ this._preventDocumentScroll();
126
+ this._triggerEvents();
127
+ }
128
+ },
129
+ _fullScreenError: function(e) {
130
+ if (!this.__options) {
131
+ return;
132
+ }
133
+ this._revertStyles();
134
+ this._fullScreenElement = null;
135
+ if (e) {
136
+ $(document).trigger("fscreenerror", [ e ]);
137
+ }
138
+ },
139
+ _triggerEvents: function() {
140
+ $(this._fullScreenElement).trigger(this.isFullScreen() ? "fscreenopen" : "fscreenclose");
141
+ $(document).trigger("fscreenchange", [ this.isFullScreen(), this._fullScreenElement ]);
142
+ },
143
+ _saveAndApplyStyles: function() {
144
+ var $elem = $(this._fullScreenElement);
145
+ this.__savedStyles = {};
146
+ for (var property in this.__options.styles) {
147
+ this.__savedStyles[property] = this._fullScreenElement.style[property];
148
+ this._fullScreenElement.style[property] = this.__options.styles[property];
149
+ }
150
+ if ($elem.is("body")) {
151
+ document.documentElement.style.overflow = this.__options.styles.overflow;
152
+ }
153
+ if (this.__options.toggleClass) {
154
+ $elem.addClass(this.__options.toggleClass);
155
+ }
156
+ },
157
+ _revertStyles: function() {
158
+ var $elem = $(this._fullScreenElement);
159
+ for (var property in this.__options.styles) {
160
+ this._fullScreenElement.style[property] = this.__savedStyles[property];
161
+ }
162
+ if ($elem.is("body")) {
163
+ document.documentElement.style.overflow = this.__savedStyles.overflow;
164
+ }
165
+ if (this.__options.toggleClass) {
166
+ $elem.removeClass(this.__options.toggleClass);
167
+ }
168
+ },
169
+ open: function(elem, options) {
170
+ if (elem === this._fullScreenElement) {
171
+ return;
172
+ }
173
+ if (this.isFullScreen()) {
174
+ this.exit();
175
+ }
176
+ this._fullScreenElement = elem;
177
+ this.__options = $.extend(true, {}, this._DEFAULT_OPTIONS, options);
178
+ this._saveAndApplyStyles();
179
+ },
180
+ exit: null,
181
+ isFullScreen: null,
182
+ isNativelySupported: function() {
183
+ return IS_NATIVELY_SUPPORTED;
184
+ }
185
+ };
186
+
187
+ var FullScreenNative = function() {
188
+ FullScreenNative._super.constructor.apply(this, arguments);
189
+ this.exit = $.proxy(native("exitFullscreen"), document);
190
+ this._DEFAULT_OPTIONS = $.extend(true, {}, this._DEFAULT_OPTIONS, {
191
+ styles: {
192
+ width: "100%",
193
+ height: "100%"
194
+ }
195
+ });
196
+ $(document).bind(this._prefixedString("fullscreenchange") + " MSFullscreenChange", $.proxy(this._fullScreenChange, this)).bind(this._prefixedString("fullscreenerror") + " MSFullscreenError", $.proxy(this._fullScreenError, this));
197
+ };
198
+
199
+ extend(FullScreenNative, FullScreenAbstract, {
200
+ VENDOR_PREFIXES: [ "", "o", "moz", "webkit" ],
201
+ _prefixedString: function(str) {
202
+ return $.map(this.VENDOR_PREFIXES, function(s) {
203
+ return s + str;
204
+ }).join(" ");
205
+ },
206
+ open: function(elem, options) {
207
+ FullScreenNative._super.open.apply(this, arguments);
208
+ var requestFS = native(elem, "requestFullscreen");
209
+ requestFS.call(elem);
210
+ },
211
+ exit: $.noop,
212
+ isFullScreen: function() {
213
+ return native("fullscreenElement") !== null;
214
+ },
215
+ element: function() {
216
+ return native("fullscreenElement");
217
+ }
218
+ });
219
+
220
+ var FullScreenFallback = function() {
221
+ FullScreenFallback._super.constructor.apply(this, arguments);
222
+ this._DEFAULT_OPTIONS = $.extend({}, this._DEFAULT_OPTIONS, {
223
+ styles: {
224
+ position: "fixed",
225
+ zIndex: "2147483647",
226
+ left: 0,
227
+ top: 0,
228
+ bottom: 0,
229
+ right: 0
230
+ }
231
+ });
232
+ this.__delegateKeydownHandler();
233
+ };
234
+
235
+ extend(FullScreenFallback, FullScreenAbstract, {
236
+ __isFullScreen: false,
237
+ __delegateKeydownHandler: function() {
238
+ var $doc = $(document);
239
+ $doc.delegate("*", "keydown.fullscreen", $.proxy(this.__keydownHandler, this));
240
+ var data = JQ_LT_17 ? $doc.data("events") : $._data(document).events;
241
+ var events = data["keydown"];
242
+ if (!JQ_LT_17) {
243
+ events.splice(0, 0, events.splice(events.delegateCount - 1, 1)[0]);
244
+ } else {
245
+ data.live.unshift(data.live.pop());
246
+ }
247
+ },
248
+ __keydownHandler: function(e) {
249
+ if (this.isFullScreen() && e.which === 27) {
250
+ this.exit();
251
+ return false;
252
+ }
253
+ return true;
254
+ },
255
+ _revertStyles: function() {
256
+ FullScreenFallback._super._revertStyles.apply(this, arguments);
257
+ this._fullScreenElement.offsetHeight;
258
+ },
259
+ open: function(elem) {
260
+ FullScreenFallback._super.open.apply(this, arguments);
261
+ this.__isFullScreen = true;
262
+ this._fullScreenChange();
263
+ },
264
+ exit: function() {
265
+ if (!this.__isFullScreen) {
266
+ return;
267
+ }
268
+ this.__isFullScreen = false;
269
+ this._fullScreenChange();
270
+ },
271
+ isFullScreen: function() {
272
+ return this.__isFullScreen;
273
+ },
274
+ element: function() {
275
+ return this.__isFullScreen ? this._fullScreenElement : null;
276
+ }
277
+ });
278
+
279
+ $.fullscreen = IS_NATIVELY_SUPPORTED ? new FullScreenNative() : new FullScreenFallback();
280
+
281
+ $.fn.fullscreen = function(options) {
282
+ var elem = this[0];
283
+ options = $.extend({
284
+ toggleClass: null,
285
+ overflow: "hidden"
286
+ }, options);
287
+ options.styles = {
288
+ overflow: options.overflow
289
+ };
290
+ delete options.overflow;
291
+ if (elem) {
292
+ $.fullscreen.open(elem, options);
293
+ }
294
+ return this;
295
+ };return $.fullscreen;
296
+ }));
js/jquery.fullscreen.min.js ADDED
@@ -0,0 +1,28 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ /*
2
+ * jquery.fullscreen v0.6.0
3
+ * https://github.com/private-face/jquery.fullscreen
4
+ *
5
+ * Copyright (c) 2012–2016 Vladimir Zhuravlev
6
+ * Released under the MIT license
7
+ * https://github.com/private-face/jquery.fullscreen/blob/master/LICENSE
8
+ *
9
+ * Date: 2016-08-25
10
+ **/
11
+ (function(global, factory) {
12
+ if (typeof define === 'function' && define.amd) {
13
+ // AMD
14
+ define(['jquery'], function (jQuery) {
15
+ return factory(jQuery);
16
+ });
17
+ } else if (typeof exports === 'object') {
18
+ // CommonJS/Browserify
19
+ factory(require('jquery'));
20
+ } else {
21
+ // Global
22
+ factory(global.jQuery);
23
+ }
24
+ }(this, function($) {
25
+
26
+ function defined(a){return"undefined"!=typeof a}function extend(a,b,c){var d=function(){};d.prototype=b.prototype,a.prototype=new d,a.prototype.constructor=a,b.prototype.constructor=b,a._super=b.prototype,c&&$.extend(a.prototype,c)}function native(a,b){var c;"string"==typeof a&&(b=a,a=document);for(var d=0;d<SUBST.length;++d){b=b.replace(SUBST[d][0],SUBST[d][1]);for(var e=0;e<VENDOR_PREFIXES.length;++e)if(c=VENDOR_PREFIXES[e],c+=0===e?b:b.charAt(0).toUpperCase()+b.substr(1),defined(a[c]))return a[c]}}var SUBST=[["",""],["exit","cancel"],["screen","Screen"]],VENDOR_PREFIXES=["","o","ms","moz","webkit","webkitCurrent"],ua=navigator.userAgent,fsEnabled=native("fullscreenEnabled"),parsedChromeUA=ua.match(/Android.*Chrome\/(\d+)\./),IS_ANDROID_CHROME=!!parsedChromeUA,CHROME_VERSION,ANDROID_CHROME_VERSION;IS_ANDROID_CHROME&&(ANDROID_CHROME_VERSION=parseInt(parsedChromeUA[1]));var IS_NATIVELY_SUPPORTED=(!IS_ANDROID_CHROME||ANDROID_CHROME_VERSION>37)&&defined(native("fullscreenElement"))&&(!defined(fsEnabled)||fsEnabled===!0),version=$.fn.jquery.split("."),JQ_LT_17=parseInt(version[0])<2&&parseInt(version[1])<7,FullScreenAbstract=function(){this.__options=null,this._fullScreenElement=null,this.__savedStyles={}};FullScreenAbstract.prototype={native:native,_DEFAULT_OPTIONS:{styles:{boxSizing:"border-box",MozBoxSizing:"border-box",WebkitBoxSizing:"border-box"},toggleClass:null},__documentOverflow:"",__htmlOverflow:"",_preventDocumentScroll:function(){this.__documentOverflow=document.body.style.overflow,this.__htmlOverflow=document.documentElement.style.overflow,$(this._fullScreenElement).is("body, html")||$("body, html").css("overflow","hidden")},_allowDocumentScroll:function(){document.body.style.overflow=this.__documentOverflow,document.documentElement.style.overflow=this.__htmlOverflow},_fullScreenChange:function(){this.__options&&(this.isFullScreen()?(this._preventDocumentScroll(),this._triggerEvents()):(this._allowDocumentScroll(),this._revertStyles(),this._triggerEvents(),this._fullScreenElement=null))},_fullScreenError:function(a){this.__options&&(this._revertStyles(),this._fullScreenElement=null,a&&$(document).trigger("fscreenerror",[a]))},_triggerEvents:function(){$(this._fullScreenElement).trigger(this.isFullScreen()?"fscreenopen":"fscreenclose"),$(document).trigger("fscreenchange",[this.isFullScreen(),this._fullScreenElement])},_saveAndApplyStyles:function(){var a=$(this._fullScreenElement);this.__savedStyles={};for(var b in this.__options.styles)this.__savedStyles[b]=this._fullScreenElement.style[b],this._fullScreenElement.style[b]=this.__options.styles[b];a.is("body")&&(document.documentElement.style.overflow=this.__options.styles.overflow),this.__options.toggleClass&&a.addClass(this.__options.toggleClass)},_revertStyles:function(){var a=$(this._fullScreenElement);for(var b in this.__options.styles)this._fullScreenElement.style[b]=this.__savedStyles[b];a.is("body")&&(document.documentElement.style.overflow=this.__savedStyles.overflow),this.__options.toggleClass&&a.removeClass(this.__options.toggleClass)},open:function(a,b){a!==this._fullScreenElement&&(this.isFullScreen()&&this.exit(),this._fullScreenElement=a,this.__options=$.extend(!0,{},this._DEFAULT_OPTIONS,b),this._saveAndApplyStyles())},exit:null,isFullScreen:null,isNativelySupported:function(){return IS_NATIVELY_SUPPORTED}};var FullScreenNative=function(){FullScreenNative._super.constructor.apply(this,arguments),this.exit=$.proxy(native("exitFullscreen"),document),this._DEFAULT_OPTIONS=$.extend(!0,{},this._DEFAULT_OPTIONS,{styles:{width:"100%",height:"100%"}}),$(document).bind(this._prefixedString("fullscreenchange")+" MSFullscreenChange",$.proxy(this._fullScreenChange,this)).bind(this._prefixedString("fullscreenerror")+" MSFullscreenError",$.proxy(this._fullScreenError,this))};extend(FullScreenNative,FullScreenAbstract,{VENDOR_PREFIXES:["","o","moz","webkit"],_prefixedString:function(a){return $.map(this.VENDOR_PREFIXES,function(b){return b+a}).join(" ")},open:function(a,b){FullScreenNative._super.open.apply(this,arguments);var c=native(a,"requestFullscreen");c.call(a)},exit:$.noop,isFullScreen:function(){return null!==native("fullscreenElement")},element:function(){return native("fullscreenElement")}});var FullScreenFallback=function(){FullScreenFallback._super.constructor.apply(this,arguments),this._DEFAULT_OPTIONS=$.extend({},this._DEFAULT_OPTIONS,{styles:{position:"fixed",zIndex:"2147483647",left:0,top:0,bottom:0,right:0}}),this.__delegateKeydownHandler()};extend(FullScreenFallback,FullScreenAbstract,{__isFullScreen:!1,__delegateKeydownHandler:function(){var a=$(document);a.delegate("*","keydown.fullscreen",$.proxy(this.__keydownHandler,this));var b=JQ_LT_17?a.data("events"):$._data(document).events,c=b.keydown;JQ_LT_17?b.live.unshift(b.live.pop()):c.splice(0,0,c.splice(c.delegateCount-1,1)[0])},__keydownHandler:function(a){return!this.isFullScreen()||27!==a.which||(this.exit(),!1)},_revertStyles:function(){FullScreenFallback._super._revertStyles.apply(this,arguments),this._fullScreenElement.offsetHeight},open:function(a){FullScreenFallback._super.open.apply(this,arguments),this.__isFullScreen=!0,this._fullScreenChange()},exit:function(){this.__isFullScreen&&(this.__isFullScreen=!1,this._fullScreenChange())},isFullScreen:function(){return this.__isFullScreen},element:function(){return this.__isFullScreen?this._fullScreenElement:null}}),$.fullscreen=IS_NATIVELY_SUPPORTED?new FullScreenNative:new FullScreenFallback,$.fn.fullscreen=function(a){var b=this[0];return a=$.extend({toggleClass:null,overflow:"hidden"},a),a.styles={overflow:a.overflow},delete a.overflow,b&&$.fullscreen.open(b,a),this};
27
+ //# sourceMappingURL=jquery.fullscreen.min.js.mapreturn $.fullscreen;
28
+ }));
js/jquery.jscolor.js ADDED
@@ -0,0 +1,3524 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ /**
2
+ * jscolor - JavaScript Color Picker
3
+ *
4
+ * @link http://jscolor.com
5
+ * @license For open source use: GPLv3
6
+ * For commercial use: JSColor Commercial License
7
+ * @author Jan Odvarko - East Desire
8
+ * @version 2.4.5
9
+ *
10
+ * See usage examples at http://jscolor.com/examples/
11
+ */
12
+
13
+
14
+ (function (global, factory) {
15
+
16
+ 'use strict';
17
+
18
+ if (typeof module === 'object' && typeof module.exports === 'object') {
19
+ // Export jscolor as a module
20
+ module.exports = global.document ?
21
+ factory (global) :
22
+ function (win) {
23
+ if (!win.document) {
24
+ throw new Error('jscolor needs a window with document');
25
+ }
26
+ return factory(win);
27
+ }
28
+ return;
29
+ }
30
+
31
+ // Default use (no module export)
32
+ factory(global);
33
+
34
+ })(typeof window !== 'undefined' ? window : this, function (window) { // BEGIN factory
35
+
36
+ // BEGIN jscolor code
37
+
38
+
39
+ 'use strict';
40
+
41
+
42
+ var jscolor = (function () { // BEGIN jscolor
43
+
44
+ var jsc = {
45
+
46
+
47
+ initialized : false,
48
+
49
+ instances : [], // created instances of jscolor
50
+
51
+ readyQueue : [], // functions waiting to be called after init
52
+
53
+
54
+ register : function () {
55
+ if (typeof window !== 'undefined' && window.document) {
56
+ window.document.addEventListener('DOMContentLoaded', jsc.pub.init, false);
57
+ }
58
+ },
59
+
60
+
61
+ installBySelector : function (selector, rootNode) {
62
+ rootNode = rootNode ? jsc.node(rootNode) : window.document;
63
+ if (!rootNode) {
64
+ throw new Error('Missing root node');
65
+ }
66
+
67
+ var elms = rootNode.querySelectorAll(selector);
68
+
69
+ // for backward compatibility with DEPRECATED installation/configuration using className
70
+ var matchClass = new RegExp('(^|\\s)(' + jsc.pub.lookupClass + ')(\\s*(\\{[^}]*\\})|\\s|$)', 'i');
71
+
72
+ for (var i = 0; i < elms.length; i += 1) {
73
+
74
+ if (elms[i].jscolor && elms[i].jscolor instanceof jsc.pub) {
75
+ continue; // jscolor already installed on this element
76
+ }
77
+
78
+ if (elms[i].type !== undefined && elms[i].type.toLowerCase() == 'color' && jsc.isColorAttrSupported) {
79
+ continue; // skips inputs of type 'color' if supported by the browser
80
+ }
81
+
82
+ var dataOpts, m;
83
+
84
+ if (
85
+ (dataOpts = jsc.getDataAttr(elms[i], 'jscolor')) !== null ||
86
+ (elms[i].className && (m = elms[i].className.match(matchClass))) // installation using className (DEPRECATED)
87
+ ) {
88
+ var targetElm = elms[i];
89
+
90
+ var optsStr = '';
91
+ if (dataOpts !== null) {
92
+ optsStr = dataOpts;
93
+
94
+ } else if (m) { // installation using className (DEPRECATED)
95
+ console.warn('Installation using class name is DEPRECATED. Use data-jscolor="" attribute instead.' + jsc.docsRef);
96
+ if (m[4]) {
97
+ optsStr = m[4];
98
+ }
99
+ }
100
+
101
+ var opts = null;
102
+ if (optsStr.trim()) {
103
+ try {
104
+ opts = jsc.parseOptionsStr(optsStr);
105
+ } catch (e) {
106
+ console.warn(e + '\n' + optsStr);
107
+ }
108
+ }
109
+
110
+ try {
111
+ new jsc.pub(targetElm, opts);
112
+ } catch (e) {
113
+ console.warn(e);
114
+ }
115
+ }
116
+ }
117
+ },
118
+
119
+
120
+ parseOptionsStr : function (str) {
121
+ var opts = null;
122
+
123
+ try {
124
+ opts = JSON.parse(str);
125
+
126
+ } catch (eParse) {
127
+ if (!jsc.pub.looseJSON) {
128
+ throw new Error('Could not parse jscolor options as JSON: ' + eParse);
129
+ } else {
130
+ // loose JSON syntax is enabled -> try to evaluate the options string as JavaScript object
131
+ try {
132
+ opts = (new Function ('var opts = (' + str + '); return typeof opts === "object" ? opts : {};'))();
133
+ } catch (eEval) {
134
+ throw new Error('Could not evaluate jscolor options: ' + eEval);
135
+ }
136
+ }
137
+ }
138
+ return opts;
139
+ },
140
+
141
+
142
+ getInstances : function () {
143
+ var inst = [];
144
+ for (var i = 0; i < jsc.instances.length; i += 1) {
145
+ // if the targetElement still exists, the instance is considered "alive"
146
+ if (jsc.instances[i] && jsc.instances[i].targetElement) {
147
+ inst.push(jsc.instances[i]);
148
+ }
149
+ }
150
+ return inst;
151
+ },
152
+
153
+
154
+ createEl : function (tagName) {
155
+ var el = window.document.createElement(tagName);
156
+ jsc.setData(el, 'gui', true);
157
+ return el;
158
+ },
159
+
160
+
161
+ node : function (nodeOrSelector) {
162
+ if (!nodeOrSelector) {
163
+ return null;
164
+ }
165
+
166
+ if (typeof nodeOrSelector === 'string') {
167
+ // query selector
168
+ var sel = nodeOrSelector;
169
+ var el = null;
170
+ try {
171
+ el = window.document.querySelector(sel);
172
+ } catch (e) {
173
+ console.warn(e);
174
+ return null;
175
+ }
176
+ if (!el) {
177
+ console.warn('No element matches the selector: %s', sel);
178
+ }
179
+ return el;
180
+ }
181
+
182
+ if (jsc.isNode(nodeOrSelector)) {
183
+ // DOM node
184
+ return nodeOrSelector;
185
+ }
186
+
187
+ console.warn('Invalid node of type %s: %s', typeof nodeOrSelector, nodeOrSelector);
188
+ return null;
189
+ },
190
+
191
+
192
+ // See https://stackoverflow.com/questions/384286/
193
+ isNode : function (val) {
194
+ if (typeof Node === 'object') {
195
+ return val instanceof Node;
196
+ }
197
+ return val && typeof val === 'object' && typeof val.nodeType === 'number' && typeof val.nodeName === 'string';
198
+ },
199
+
200
+
201
+ nodeName : function (node) {
202
+ if (node && node.nodeName) {
203
+ return node.nodeName.toLowerCase();
204
+ }
205
+ return false;
206
+ },
207
+
208
+
209
+ removeChildren : function (node) {
210
+ while (node.firstChild) {
211
+ node.removeChild(node.firstChild);
212
+ }
213
+ },
214
+
215
+
216
+ isTextInput : function (el) {
217
+ return el && jsc.nodeName(el) === 'input' && el.type.toLowerCase() === 'text';
218
+ },
219
+
220
+
221
+ isButton : function (el) {
222
+ if (!el) {
223
+ return false;
224
+ }
225
+ var n = jsc.nodeName(el);
226
+ return (
227
+ (n === 'button') ||
228
+ (n === 'input' && ['button', 'submit', 'reset'].indexOf(el.type.toLowerCase()) > -1)
229
+ );
230
+ },
231
+
232
+
233
+ isButtonEmpty : function (el) {
234
+ switch (jsc.nodeName(el)) {
235
+ case 'input': return (!el.value || el.value.trim() === '');
236
+ case 'button': return (el.textContent.trim() === '');
237
+ }
238
+ return null; // could not determine element's text
239
+ },
240
+
241
+
242
+ // See https://github.com/WICG/EventListenerOptions/blob/gh-pages/explainer.md
243
+ isPassiveEventSupported : (function () {
244
+ var supported = false;
245
+
246
+ try {
247
+ var opts = Object.defineProperty({}, 'passive', {
248
+ get: function () { supported = true; }
249
+ });
250
+ window.addEventListener('testPassive', null, opts);
251
+ window.removeEventListener('testPassive', null, opts);
252
+ } catch (e) {}
253
+
254
+ return supported;
255
+ })(),
256
+
257
+
258
+ isColorAttrSupported : (function () {
259
+ var elm = window.document.createElement('input');
260
+ if (elm.setAttribute) {
261
+ elm.setAttribute('type', 'color');
262
+ if (elm.type.toLowerCase() == 'color') {
263
+ return true;
264
+ }
265
+ }
266
+ return false;
267
+ })(),
268
+
269
+
270
+ dataProp : '_data_jscolor',
271
+
272
+
273
+ // usage:
274
+ // setData(obj, prop, value)
275
+ // setData(obj, {prop:value, ...})
276
+ //
277
+ setData : function () {
278
+ var obj = arguments[0];
279
+
280
+ if (arguments.length === 3) {
281
+ // setting a single property
282
+ var data = obj.hasOwnProperty(jsc.dataProp) ? obj[jsc.dataProp] : (obj[jsc.dataProp] = {});
283
+ var prop = arguments[1];
284
+ var value = arguments[2];
285
+
286
+ data[prop] = value;
287
+ return true;
288
+
289
+ } else if (arguments.length === 2 && typeof arguments[1] === 'object') {
290
+ // setting multiple properties
291
+ var data = obj.hasOwnProperty(jsc.dataProp) ? obj[jsc.dataProp] : (obj[jsc.dataProp] = {});
292
+ var map = arguments[1];
293
+
294
+ for (var prop in map) {
295
+ if (map.hasOwnProperty(prop)) {
296
+ data[prop] = map[prop];
297
+ }
298
+ }
299
+ return true;
300
+ }
301
+
302
+ throw new Error('Invalid arguments');
303
+ },
304
+
305
+
306
+ // usage:
307
+ // removeData(obj, prop, [prop...])
308
+ //
309
+ removeData : function () {
310
+ var obj = arguments[0];
311
+ if (!obj.hasOwnProperty(jsc.dataProp)) {
312
+ return true; // data object does not exist
313
+ }
314
+ for (var i = 1; i < arguments.length; i += 1) {
315
+ var prop = arguments[i];
316
+ delete obj[jsc.dataProp][prop];
317
+ }
318
+ return true;
319
+ },
320
+
321
+
322
+ getData : function (obj, prop, setDefault) {
323
+ if (!obj.hasOwnProperty(jsc.dataProp)) {
324
+ // data object does not exist
325
+ if (setDefault !== undefined) {
326
+ obj[jsc.dataProp] = {}; // create data object
327
+ } else {
328
+ return undefined; // no value to return
329
+ }
330
+ }
331
+ var data = obj[jsc.dataProp];
332
+
333
+ if (!data.hasOwnProperty(prop) && setDefault !== undefined) {
334
+ data[prop] = setDefault;
335
+ }
336
+ return data[prop];
337
+ },
338
+
339
+
340
+ getDataAttr : function (el, name) {
341
+ var attrName = 'data-' + name;
342
+ var attrValue = el.getAttribute(attrName);
343
+ return attrValue;
344
+ },
345
+
346
+
347
+ setDataAttr : function (el, name, value) {
348
+ var attrName = 'data-' + name;
349
+ el.setAttribute(attrName, value);
350
+ },
351
+
352
+
353
+ _attachedGroupEvents : {},
354
+
355
+
356
+ attachGroupEvent : function (groupName, el, evnt, func) {
357
+ if (!jsc._attachedGroupEvents.hasOwnProperty(groupName)) {
358
+ jsc._attachedGroupEvents[groupName] = [];
359
+ }
360
+ jsc._attachedGroupEvents[groupName].push([el, evnt, func]);
361
+ el.addEventListener(evnt, func, false);
362
+ },
363
+
364
+
365
+ detachGroupEvents : function (groupName) {
366
+ if (jsc._attachedGroupEvents.hasOwnProperty(groupName)) {
367
+ for (var i = 0; i < jsc._attachedGroupEvents[groupName].length; i += 1) {
368
+ var evt = jsc._attachedGroupEvents[groupName][i];
369
+ evt[0].removeEventListener(evt[1], evt[2], false);
370
+ }
371
+ delete jsc._attachedGroupEvents[groupName];
372
+ }
373
+ },
374
+
375
+
376
+ preventDefault : function (e) {
377
+ if (e.preventDefault) { e.preventDefault(); }
378
+ e.returnValue = false;
379
+ },
380
+
381
+
382
+ captureTarget : function (target) {
383
+ // IE
384
+ if (target.setCapture) {
385
+ jsc._capturedTarget = target;
386
+ jsc._capturedTarget.setCapture();
387
+ }
388
+ },
389
+
390
+
391
+ releaseTarget : function () {
392
+ // IE
393
+ if (jsc._capturedTarget) {
394
+ jsc._capturedTarget.releaseCapture();
395
+ jsc._capturedTarget = null;
396
+ }
397
+ },
398
+
399
+
400
+ triggerEvent : function (el, eventName, bubbles, cancelable) {
401
+ if (!el) {
402
+ return;
403
+ }
404
+
405
+ var ev = null;
406
+
407
+ if (typeof Event === 'function') {
408
+ ev = new Event(eventName, {
409
+ bubbles: bubbles,
410
+ cancelable: cancelable
411
+ });
412
+ } else {
413
+ // IE
414
+ ev = window.document.createEvent('Event');
415
+ ev.initEvent(eventName, bubbles, cancelable);
416
+ }
417
+
418
+ if (!ev) {
419
+ return false;
420
+ }
421
+
422
+ // so that we know that the event was triggered internally
423
+ jsc.setData(ev, 'internal', true);
424
+
425
+ el.dispatchEvent(ev);
426
+ return true;
427
+ },
428
+
429
+
430
+ triggerInputEvent : function (el, eventName, bubbles, cancelable) {
431
+ if (!el) {
432
+ return;
433
+ }
434
+ if (jsc.isTextInput(el)) {
435
+ jsc.triggerEvent(el, eventName, bubbles, cancelable);
436
+ }
437
+ },
438
+
439
+
440
+ eventKey : function (ev) {
441
+ var keys = {
442
+ 9: 'Tab',
443
+ 13: 'Enter',
444
+ 27: 'Escape',
445
+ };
446
+ if (typeof ev.code === 'string') {
447
+ return ev.code;
448
+ } else if (ev.keyCode !== undefined && keys.hasOwnProperty(ev.keyCode)) {
449
+ return keys[ev.keyCode];
450
+ }
451
+ return null;
452
+ },
453
+
454
+
455
+ strList : function (str) {
456
+ if (!str) {
457
+ return [];
458
+ }
459
+ return str.replace(/^\s+|\s+$/g, '').split(/\s+/);
460
+ },
461
+
462
+
463
+ // The className parameter (str) can only contain a single class name
464
+ hasClass : function (elm, className) {
465
+ if (!className) {
466
+ return false;
467
+ }
468
+ if (elm.classList !== undefined) {
469
+ return elm.classList.contains(className);
470
+ }
471
+ // polyfill
472
+ return -1 != (' ' + elm.className.replace(/\s+/g, ' ') + ' ').indexOf(' ' + className + ' ');
473
+ },
474
+
475
+
476
+ // The className parameter (str) can contain multiple class names separated by whitespace
477
+ addClass : function (elm, className) {
478
+ var classNames = jsc.strList(className);
479
+
480
+ if (elm.classList !== undefined) {
481
+ for (var i = 0; i < classNames.length; i += 1) {
482
+ elm.classList.add(classNames[i]);
483
+ }
484
+ return;
485
+ }
486
+ // polyfill
487
+ for (var i = 0; i < classNames.length; i += 1) {
488
+ if (!jsc.hasClass(elm, classNames[i])) {
489
+ elm.className += (elm.className ? ' ' : '') + classNames[i];
490
+ }
491
+ }
492
+ },
493
+
494
+
495
+ // The className parameter (str) can contain multiple class names separated by whitespace
496
+ removeClass : function (elm, className) {
497
+ var classNames = jsc.strList(className);
498
+
499
+ if (elm.classList !== undefined) {
500
+ for (var i = 0; i < classNames.length; i += 1) {
501
+ elm.classList.remove(classNames[i]);
502
+ }
503
+ return;
504
+ }
505
+ // polyfill
506
+ for (var i = 0; i < classNames.length; i += 1) {
507
+ var repl = new RegExp(
508
+ '^\\s*' + classNames[i] + '\\s*|' +
509
+ '\\s*' + classNames[i] + '\\s*$|' +
510
+ '\\s+' + classNames[i] + '(\\s+)',
511
+ 'g'
512
+ );
513
+ elm.className = elm.className.replace(repl, '$1');
514
+ }
515
+ },
516
+
517
+
518
+ getCompStyle : function (elm) {
519
+ var compStyle = window.getComputedStyle ? window.getComputedStyle(elm) : elm.currentStyle;
520
+
521
+ // Note: In Firefox, getComputedStyle returns null in a hidden iframe,
522
+ // that's why we need to check if the returned value is non-empty
523
+ if (!compStyle) {
524
+ return {};
525
+ }
526
+ return compStyle;
527
+ },
528
+
529
+
530
+ // Note:
531
+ // Setting a property to NULL reverts it to the state before it was first set
532
+ // with the 'reversible' flag enabled
533
+ //
534
+ setStyle : function (elm, styles, important, reversible) {
535
+ // using '' for standard priority (IE10 apparently doesn't like value undefined)
536
+ var priority = important ? 'important' : '';
537
+ var origStyle = null;
538
+
539
+ for (var prop in styles) {
540
+ if (styles.hasOwnProperty(prop)) {
541
+ var setVal = null;
542
+
543
+ if (styles[prop] === null) {
544
+ // reverting a property value
545
+
546
+ if (!origStyle) {
547
+ // get the original style object, but dont't try to create it if it doesn't exist
548
+ origStyle = jsc.getData(elm, 'origStyle');
549
+ }
550
+ if (origStyle && origStyle.hasOwnProperty(prop)) {
551
+ // we have property's original value -> use it
552
+ setVal = origStyle[prop];
553
+ }
554
+
555
+ } else {
556
+ // setting a property value
557
+
558
+ if (reversible) {
559
+ if (!origStyle) {
560
+ // get the original style object and if it doesn't exist, create it
561
+ origStyle = jsc.getData(elm, 'origStyle', {});
562
+ }
563
+ if (!origStyle.hasOwnProperty(prop)) {
564
+ // original property value not yet stored -> store it
565
+ origStyle[prop] = elm.style[prop];
566
+ }
567
+ }
568
+ setVal = styles[prop];
569
+ }
570
+
571
+ if (setVal !== null) {
572
+ elm.style.setProperty(prop, setVal, priority);
573
+ }
574
+ }
575
+ }
576
+ },
577
+
578
+
579
+ hexColor : function (r, g, b) {
580
+ return '#' + (
581
+ ('0' + Math.round(r).toString(16)).substr(-2) +
582
+ ('0' + Math.round(g).toString(16)).substr(-2) +
583
+ ('0' + Math.round(b).toString(16)).substr(-2)
584
+ ).toUpperCase();
585
+ },
586
+
587
+
588
+ hexaColor : function (r, g, b, a) {
589
+ return '#' + (
590
+ ('0' + Math.round(r).toString(16)).substr(-2) +
591
+ ('0' + Math.round(g).toString(16)).substr(-2) +
592
+ ('0' + Math.round(b).toString(16)).substr(-2) +
593
+ ('0' + Math.round(a * 255).toString(16)).substr(-2)
594
+ ).toUpperCase();
595
+ },
596
+
597
+
598
+ rgbColor : function (r, g, b) {
599
+ return 'rgb(' +
600
+ Math.round(r) + ',' +
601
+ Math.round(g) + ',' +
602
+ Math.round(b) +
603
+ ')';
604
+ },
605
+
606
+
607
+ rgbaColor : function (r, g, b, a) {
608
+ return 'rgba(' +
609
+ Math.round(r) + ',' +
610
+ Math.round(g) + ',' +
611
+ Math.round(b) + ',' +
612
+ (Math.round((a===undefined || a===null ? 1 : a) * 100) / 100) +
613
+ ')';
614
+ },
615
+
616
+
617
+ linearGradient : (function () {
618
+
619
+ function getFuncName () {
620
+ var stdName = 'linear-gradient';
621
+ var prefixes = ['', '-webkit-', '-moz-', '-o-', '-ms-'];
622
+ var helper = window.document.createElement('div');
623
+
624
+ for (var i = 0; i < prefixes.length; i += 1) {
625
+ var tryFunc = prefixes[i] + stdName;
626
+ var tryVal = tryFunc + '(to right, rgba(0,0,0,0), rgba(0,0,0,0))';
627
+
628
+ helper.style.background = tryVal;
629
+ if (helper.style.background) { // CSS background successfully set -> function name is supported
630
+ return tryFunc;
631
+ }
632
+ }
633
+ return stdName; // fallback to standard 'linear-gradient' without vendor prefix
634
+ }
635
+
636
+ var funcName = getFuncName();
637
+
638
+ return function () {
639
+ return funcName + '(' + Array.prototype.join.call(arguments, ', ') + ')';
640
+ };
641
+
642
+ })(),
643
+
644
+
645
+ setBorderRadius : function (elm, value) {
646
+ jsc.setStyle(elm, {'border-radius' : value || '0'});
647
+ },
648
+
649
+
650
+ setBoxShadow : function (elm, value) {
651
+ jsc.setStyle(elm, {'box-shadow': value || 'none'});
652
+ },
653
+
654
+
655
+ getElementPos : function (e, relativeToViewport) {
656
+ var x=0, y=0;
657
+ var rect = e.getBoundingClientRect();
658
+ x = rect.left;
659
+ y = rect.top;
660
+ if (!relativeToViewport) {
661
+ var viewPos = jsc.getViewPos();
662
+ x += viewPos[0];
663
+ y += viewPos[1];
664
+ }
665
+ return [x, y];
666
+ },
667
+
668
+
669
+ getElementSize : function (e) {
670
+ return [e.offsetWidth, e.offsetHeight];
671
+ },
672
+
673
+
674
+ // get pointer's X/Y coordinates relative to viewport
675
+ getAbsPointerPos : function (e) {
676
+ var x = 0, y = 0;
677
+ if (typeof e.changedTouches !== 'undefined' && e.changedTouches.length) {
678
+ // touch devices
679
+ x = e.changedTouches[0].clientX;
680
+ y = e.changedTouches[0].clientY;
681
+ } else if (typeof e.clientX === 'number') {
682
+ x = e.clientX;
683
+ y = e.clientY;
684
+ }
685
+ return { x: x, y: y };
686
+ },
687
+
688
+
689
+ // get pointer's X/Y coordinates relative to target element
690
+ getRelPointerPos : function (e) {
691
+ var target = e.target || e.srcElement;
692
+ var targetRect = target.getBoundingClientRect();
693
+
694
+ var x = 0, y = 0;
695
+
696
+ var clientX = 0, clientY = 0;
697
+ if (typeof e.changedTouches !== 'undefined' && e.changedTouches.length) {
698
+ // touch devices
699
+ clientX = e.changedTouches[0].clientX;
700
+ clientY = e.changedTouches[0].clientY;
701
+ } else if (typeof e.clientX === 'number') {
702
+ clientX = e.clientX;
703
+ clientY = e.clientY;
704
+ }
705
+
706
+ x = clientX - targetRect.left;
707
+ y = clientY - targetRect.top;
708
+ return { x: x, y: y };
709
+ },
710
+
711
+
712
+ getViewPos : function () {
713
+ var doc = window.document.documentElement;
714
+ return [
715
+ (window.pageXOffset || doc.scrollLeft) - (doc.clientLeft || 0),
716
+ (window.pageYOffset || doc.scrollTop) - (doc.clientTop || 0)
717
+ ];
718
+ },
719
+
720
+
721
+ getViewSize : function () {
722
+ var doc = window.document.documentElement;
723
+ return [
724
+ (window.innerWidth || doc.clientWidth),
725
+ (window.innerHeight || doc.clientHeight),
726
+ ];
727
+ },
728
+
729
+
730
+ // r: 0-255
731
+ // g: 0-255
732
+ // b: 0-255
733
+ //
734
+ // returns: [ 0-360, 0-100, 0-100 ]
735
+ //
736
+ RGB_HSV : function (r, g, b) {
737
+ r /= 255;
738
+ g /= 255;
739
+ b /= 255;
740
+ var n = Math.min(Math.min(r,g),b);
741
+ var v = Math.max(Math.max(r,g),b);
742
+ var m = v - n;
743
+ if (m === 0) { return [ null, 0, 100 * v ]; }
744
+ var h = r===n ? 3+(b-g)/m : (g===n ? 5+(r-b)/m : 1+(g-r)/m);
745
+ return [
746
+ 60 * (h===6?0:h),
747
+ 100 * (m/v),
748
+ 100 * v
749
+ ];
750
+ },
751
+
752
+
753
+ // h: 0-360
754
+ // s: 0-100
755
+ // v: 0-100
756
+ //
757
+ // returns: [ 0-255, 0-255, 0-255 ]
758
+ //
759
+ HSV_RGB : function (h, s, v) {
760
+ var u = 255 * (v / 100);
761
+
762
+ if (h === null) {
763
+ return [ u, u, u ];
764
+ }
765
+
766
+ h /= 60;
767
+ s /= 100;
768
+
769
+ var i = Math.floor(h);
770
+ var f = i%2 ? h-i : 1-(h-i);
771
+ var m = u * (1 - s);
772
+ var n = u * (1 - s * f);
773
+ switch (i) {
774
+ case 6:
775
+ case 0: return [u,n,m];
776
+ case 1: return [n,u,m];
777
+ case 2: return [m,u,n];
778
+ case 3: return [m,n,u];
779
+ case 4: return [n,m,u];
780
+ case 5: return [u,m,n];
781
+ }
782
+ },
783
+
784
+
785
+ parseColorString : function (str) {
786
+ var ret = {
787
+ rgba: null,
788
+ format: null // 'hex' | 'hexa' | 'rgb' | 'rgba'
789
+ };
790
+
791
+ var m;
792
+
793
+ if (m = str.match(/^\W*([0-9A-F]{3,8})\W*$/i)) {
794
+ // HEX notation
795
+
796
+ if (m[1].length === 8) {
797
+ // 8-char notation (= with alpha)
798
+ ret.format = 'hexa';
799
+ ret.rgba = [
800
+ parseInt(m[1].substr(0,2),16),
801
+ parseInt(m[1].substr(2,2),16),
802
+ parseInt(m[1].substr(4,2),16),
803
+ parseInt(m[1].substr(6,2),16) / 255
804
+ ];
805
+
806
+ } else if (m[1].length === 6) {
807
+ // 6-char notation
808
+ ret.format = 'hex';
809
+ ret.rgba = [
810
+ parseInt(m[1].substr(0,2),16),
811
+ parseInt(m[1].substr(2,2),16),
812
+ parseInt(m[1].substr(4,2),16),
813
+ null
814
+ ];
815
+
816
+ } else if (m[1].length === 3) {
817
+ // 3-char notation
818
+ ret.format = 'hex';
819
+ ret.rgba = [
820
+ parseInt(m[1].charAt(0) + m[1].charAt(0),16),
821
+ parseInt(m[1].charAt(1) + m[1].charAt(1),16),
822
+ parseInt(m[1].charAt(2) + m[1].charAt(2),16),
823
+ null
824
+ ];
825
+
826
+ } else {
827
+ return false;
828
+ }
829
+
830
+ return ret;
831
+ }
832
+
833
+ if (m = str.match(/^\W*rgba?\(([^)]*)\)\W*$/i)) {
834
+ // rgb(...) or rgba(...) notation
835
+
836
+ var par = m[1].split(',');
837
+ var re = /^\s*(\d+|\d*\.\d+|\d+\.\d*)\s*$/;
838
+ var mR, mG, mB, mA;
839
+ if (
840
+ par.length >= 3 &&
841
+ (mR = par[0].match(re)) &&
842
+ (mG = par[1].match(re)) &&
843
+ (mB = par[2].match(re))
844
+ ) {
845
+ ret.format = 'rgb';
846
+ ret.rgba = [
847
+ parseFloat(mR[1]) || 0,
848
+ parseFloat(mG[1]) || 0,
849
+ parseFloat(mB[1]) || 0,
850
+ null
851
+ ];
852
+
853
+ if (
854
+ par.length >= 4 &&
855
+ (mA = par[3].match(re))
856
+ ) {
857
+ ret.format = 'rgba';
858
+ ret.rgba[3] = parseFloat(mA[1]) || 0;
859
+ }
860
+ return ret;
861
+ }
862
+ }
863
+
864
+ return false;
865
+ },
866
+
867
+
868
+ parsePaletteValue : function (mixed) {
869
+ var vals = [];
870
+
871
+ if (typeof mixed === 'string') { // input is a string of space separated color values
872
+ // rgb() and rgba() may contain spaces too, so let's find all color values by regex
873
+ mixed.replace(/#[0-9A-F]{3}([0-9A-F]{3})?|rgba?\(([^)]*)\)/ig, function (val) {
874
+ vals.push(val);
875
+ });
876
+ } else if (Array.isArray(mixed)) { // input is an array of color values
877
+ vals = mixed;
878
+ }
879
+
880
+ // convert all values into uniform color format
881
+
882
+ var colors = [];
883
+
884
+ for (var i = 0; i < vals.length; i++) {
885
+ var color = jsc.parseColorString(vals[i]);
886
+ if (color) {
887
+ colors.push(color);
888
+ }
889
+ }
890
+
891
+ return colors;
892
+ },
893
+
894
+
895
+ containsTranparentColor : function (colors) {
896
+ for (var i = 0; i < colors.length; i++) {
897
+ var a = colors[i].rgba[3];
898
+ if (a !== null && a < 1.0) {
899
+ return true;
900
+ }
901
+ }
902
+ return false;
903
+ },
904
+
905
+
906
+ isAlphaFormat : function (format) {
907
+ switch (format.toLowerCase()) {
908
+ case 'hexa':
909
+ case 'rgba':
910
+ return true;
911
+ }
912
+ return false;
913
+ },
914
+
915
+
916
+ // Canvas scaling for retina displays
917
+ //
918
+ // adapted from https://www.html5rocks.com/en/tutorials/canvas/hidpi/
919
+ //
920
+ scaleCanvasForHighDPR : function (canvas) {
921
+ var dpr = window.devicePixelRatio || 1;
922
+ canvas.width *= dpr;
923
+ canvas.height *= dpr;
924
+ var ctx = canvas.getContext('2d');
925
+ ctx.scale(dpr, dpr);
926
+ },
927
+
928
+
929
+ genColorPreviewCanvas : function (color, separatorPos, specWidth, scaleForHighDPR) {
930
+
931
+ var sepW = Math.round(jsc.pub.previewSeparator.length);
932
+ var sqSize = jsc.pub.chessboardSize;
933
+ var sqColor1 = jsc.pub.chessboardColor1;
934
+ var sqColor2 = jsc.pub.chessboardColor2;
935
+
936
+ var cWidth = specWidth ? specWidth : sqSize * 2;
937
+ var cHeight = sqSize * 2;
938
+
939
+ var canvas = jsc.createEl('canvas');
940
+ var ctx = canvas.getContext('2d');
941
+
942
+ canvas.width = cWidth;
943
+ canvas.height = cHeight;
944
+ if (scaleForHighDPR) {
945
+ jsc.scaleCanvasForHighDPR(canvas);
946
+ }
947
+
948
+ // transparency chessboard - background
949
+ ctx.fillStyle = sqColor1;
950
+ ctx.fillRect(0, 0, cWidth, cHeight);
951
+
952
+ // transparency chessboard - squares
953
+ ctx.fillStyle = sqColor2;
954
+ for (var x = 0; x < cWidth; x += sqSize * 2) {
955
+ ctx.fillRect(x, 0, sqSize, sqSize);
956
+ ctx.fillRect(x + sqSize, sqSize, sqSize, sqSize);
957
+ }
958
+
959
+ if (color) {
960
+ // actual color in foreground
961
+ ctx.fillStyle = color;
962
+ ctx.fillRect(0, 0, cWidth, cHeight);
963
+ }
964
+
965
+ var start = null;
966
+ switch (separatorPos) {
967
+ case 'left':
968
+ start = 0;
969
+ ctx.clearRect(0, 0, sepW/2, cHeight);
970
+ break;
971
+ case 'right':
972
+ start = cWidth - sepW;
973
+ ctx.clearRect(cWidth - (sepW/2), 0, sepW/2, cHeight);
974
+ break;
975
+ }
976
+ if (start !== null) {
977
+ ctx.lineWidth = 1;
978
+ for (var i = 0; i < jsc.pub.previewSeparator.length; i += 1) {
979
+ ctx.beginPath();
980
+ ctx.strokeStyle = jsc.pub.previewSeparator[i];
981
+ ctx.moveTo(0.5 + start + i, 0);
982
+ ctx.lineTo(0.5 + start + i, cHeight);
983
+ ctx.stroke();
984
+ }
985
+ }
986
+
987
+ return {
988
+ canvas: canvas,
989
+ width: cWidth,
990
+ height: cHeight,
991
+ };
992
+ },
993
+
994
+
995
+ // if position or width is not set => fill the entire element (0%-100%)
996
+ genColorPreviewGradient : function (color, position, width) {
997
+ var params = [];
998
+
999
+ if (position && width) {
1000
+ params = [
1001
+ 'to ' + {'left':'right', 'right':'left'}[position],
1002
+ color + ' 0%',
1003
+ color + ' ' + width + 'px',
1004
+ 'rgba(0,0,0,0) ' + (width + 1) + 'px',
1005
+ 'rgba(0,0,0,0) 100%',
1006
+ ];
1007
+ } else {
1008
+ params = [
1009
+ 'to right',
1010
+ color + ' 0%',
1011
+ color + ' 100%',
1012
+ ];
1013
+ }
1014
+
1015
+ return jsc.linearGradient.apply(this, params);
1016
+ },
1017
+
1018
+
1019
+ redrawPosition : function () {
1020
+
1021
+ if (!jsc.picker || !jsc.picker.owner) {
1022
+ return; // picker is not shown
1023
+ }
1024
+
1025
+ var thisObj = jsc.picker.owner;
1026
+
1027
+ var tp, vp;
1028
+
1029
+ if (thisObj.fixed) {
1030
+ // Fixed elements are positioned relative to viewport,
1031
+ // therefore we can ignore the scroll offset
1032
+ tp = jsc.getElementPos(thisObj.targetElement, true); // target pos
1033
+ vp = [0, 0]; // view pos
1034
+ } else {
1035
+ tp = jsc.getElementPos(thisObj.targetElement); // target pos
1036
+ vp = jsc.getViewPos(); // view pos
1037
+ }
1038
+
1039
+ var ts = jsc.getElementSize(thisObj.targetElement); // target size
1040
+ var vs = jsc.getViewSize(); // view size
1041
+ var pd = jsc.getPickerDims(thisObj);
1042
+ var ps = [pd.borderW, pd.borderH]; // picker outer size
1043
+ var a, b, c;
1044
+ switch (thisObj.position.toLowerCase()) {
1045
+ case 'left': a=1; b=0; c=-1; break;
1046
+ case 'right':a=1; b=0; c=1; break;
1047
+ case 'top': a=0; b=1; c=-1; break;
1048
+ default: a=0; b=1; c=1; break;
1049
+ }
1050
+ var l = (ts[b]+ps[b])/2;
1051
+
1052
+ // compute picker position
1053
+ if (!thisObj.smartPosition) {
1054
+ var pp = [
1055
+ tp[a],
1056
+ tp[b]+ts[b]-l+l*c
1057
+ ];
1058
+ } else {
1059
+ var pp = [
1060
+ -vp[a]+tp[a]+ps[a] > vs[a] ?
1061
+ (-vp[a]+tp[a]+ts[a]/2 > vs[a]/2 && tp[a]+ts[a]-ps[a] >= 0 ? tp[a]+ts[a]-ps[a] : tp[a]) :
1062
+ tp[a],
1063
+ -vp[b]+tp[b]+ts[b]+ps[b]-l+l*c > vs[b] ?
1064
+ (-vp[b]+tp[b]+ts[b]/2 > vs[b]/2 && tp[b]+ts[b]-l-l*c >= 0 ? tp[b]+ts[b]-l-l*c : tp[b]+ts[b]-l+l*c) :
1065
+ (tp[b]+ts[b]-l+l*c >= 0 ? tp[b]+ts[b]-l+l*c : tp[b]+ts[b]-l-l*c)
1066
+ ];
1067
+ }
1068
+
1069
+ var x = pp[a];
1070
+ var y = pp[b];
1071
+ var positionValue = thisObj.fixed ? 'fixed' : 'absolute';
1072
+ var contractShadow =
1073
+ (pp[0] + ps[0] > tp[0] || pp[0] < tp[0] + ts[0]) &&
1074
+ (pp[1] + ps[1] < tp[1] + ts[1]);
1075
+
1076
+ jsc._drawPosition(thisObj, x, y, positionValue, contractShadow);
1077
+ },
1078
+
1079
+
1080
+ _drawPosition : function (thisObj, x, y, positionValue, contractShadow) {
1081
+ var vShadow = contractShadow ? 0 : thisObj.shadowBlur; // px
1082
+
1083
+ jsc.picker.wrap.style.position = positionValue;
1084
+ jsc.picker.wrap.style.left = x + 'px';
1085
+ jsc.picker.wrap.style.top = y + 'px';
1086
+
1087
+ jsc.setBoxShadow(
1088
+ jsc.picker.boxS,
1089
+ thisObj.shadow ?
1090
+ new jsc.BoxShadow(0, vShadow, thisObj.shadowBlur, 0, thisObj.shadowColor) :
1091
+ null);
1092
+ },
1093
+
1094
+
1095
+ getPickerDims : function (thisObj) {
1096
+ var w = 2 * thisObj.controlBorderWidth + thisObj.width;
1097
+ var h = 2 * thisObj.controlBorderWidth + thisObj.height;
1098
+
1099
+ var sliderSpace = 2 * thisObj.controlBorderWidth + 2 * jsc.getControlPadding(thisObj) + thisObj.sliderSize;
1100
+
1101
+ if (jsc.getSliderChannel(thisObj)) {
1102
+ w += sliderSpace;
1103
+ }
1104
+ if (thisObj.hasAlphaChannel()) {
1105
+ w += sliderSpace;
1106
+ }
1107
+
1108
+ var pal = jsc.getPaletteDims(thisObj, w);
1109
+
1110
+ if (pal.height) {
1111
+ h += pal.height + thisObj.padding;
1112
+ }
1113
+ if (thisObj.closeButton) {
1114
+ h += 2 * thisObj.controlBorderWidth + thisObj.padding + thisObj.buttonHeight;
1115
+ }
1116
+
1117
+ var pW = w + (2 * thisObj.padding);
1118
+ var pH = h + (2 * thisObj.padding);
1119
+
1120
+ return {
1121
+ contentW: w,
1122
+ contentH: h,
1123
+ paddedW: pW,
1124
+ paddedH: pH,
1125
+ borderW: pW + (2 * thisObj.borderWidth),
1126
+ borderH: pH + (2 * thisObj.borderWidth),
1127
+ palette: pal,
1128
+ };
1129
+ },
1130
+
1131
+
1132
+ getPaletteDims : function (thisObj, width) {
1133
+ var cols = 0, rows = 0, cellW = 0, cellH = 0, height = 0;
1134
+ var sampleCount = thisObj._palette ? thisObj._palette.length : 0;
1135
+
1136
+ if (sampleCount) {
1137
+ cols = thisObj.paletteCols;
1138
+ rows = cols > 0 ? Math.ceil(sampleCount / cols) : 0;
1139
+
1140
+ // color sample's dimensions (includes border)
1141
+ cellW = Math.max(1, Math.floor((width - ((cols - 1) * thisObj.paletteSpacing)) / cols));
1142
+ cellH = thisObj.paletteHeight ? Math.min(thisObj.paletteHeight, cellW) : cellW;
1143
+ }
1144
+
1145
+ if (rows) {
1146
+ height =
1147
+ rows * cellH +
1148
+ (rows - 1) * thisObj.paletteSpacing;
1149
+ }
1150
+
1151
+ return {
1152
+ cols: cols,
1153
+ rows: rows,
1154
+ cellW: cellW,
1155
+ cellH: cellH,
1156
+ width: width,
1157
+ height: height,
1158
+ };
1159
+ },
1160
+
1161
+
1162
+ getControlPadding : function (thisObj) {
1163
+ return Math.max(
1164
+ thisObj.padding / 2,
1165
+ (2 * thisObj.pointerBorderWidth + thisObj.pointerThickness) - thisObj.controlBorderWidth
1166
+ );
1167
+ },
1168
+
1169
+
1170
+ getPadYChannel : function (thisObj) {
1171
+ switch (thisObj.mode.charAt(1).toLowerCase()) {
1172
+ case 'v': return 'v'; break;
1173
+ }
1174
+ return 's';
1175
+ },
1176
+
1177
+
1178
+ getSliderChannel : function (thisObj) {
1179
+ if (thisObj.mode.length > 2) {
1180
+ switch (thisObj.mode.charAt(2).toLowerCase()) {
1181
+ case 's': return 's'; break;
1182
+ case 'v': return 'v'; break;
1183
+ }
1184
+ }
1185
+ return null;
1186
+ },
1187
+
1188
+
1189
+ // calls function specified in picker's property
1190
+ triggerCallback : function (thisObj, prop) {
1191
+ if (!thisObj[prop]) {
1192
+ return; // callback func not specified
1193
+ }
1194
+ var callback = null;
1195
+
1196
+ if (typeof thisObj[prop] === 'string') {
1197
+ // string with code
1198
+ try {
1199
+ callback = new Function (thisObj[prop]);
1200
+ } catch (e) {
1201
+ console.error(e);
1202
+ }
1203
+ } else {
1204
+ // function
1205
+ callback = thisObj[prop];
1206
+ }
1207
+
1208
+ if (callback) {
1209
+ callback.call(thisObj);
1210
+ }
1211
+ },
1212
+
1213
+
1214
+ // Triggers a color change related event(s) on all picker instances.
1215
+ // It is possible to specify multiple events separated with a space.
1216
+ triggerGlobal : function (eventNames) {
1217
+ var inst = jsc.getInstances();
1218
+ for (var i = 0; i < inst.length; i += 1) {
1219
+ inst[i].trigger(eventNames);
1220
+ }
1221
+ },
1222
+
1223
+
1224
+ _pointerMoveEvent : {
1225
+ mouse: 'mousemove',
1226
+ touch: 'touchmove'
1227
+ },
1228
+ _pointerEndEvent : {
1229
+ mouse: 'mouseup',
1230
+ touch: 'touchend'
1231
+ },
1232
+
1233
+
1234
+ _pointerOrigin : null,
1235
+ _capturedTarget : null,
1236
+
1237
+
1238
+ onDocumentKeyUp : function (e) {
1239
+ if (['Tab', 'Escape'].indexOf(jsc.eventKey(e)) !== -1) {
1240
+ if (jsc.picker && jsc.picker.owner) {
1241
+ jsc.picker.owner.tryHide();
1242
+ }
1243
+ }
1244
+ },
1245
+
1246
+
1247
+ onWindowResize : function (e) {
1248
+ jsc.redrawPosition();
1249
+ },
1250
+
1251
+
1252
+ onWindowScroll : function (e) {
1253
+ jsc.redrawPosition();
1254
+ },
1255
+
1256
+
1257
+ onParentScroll : function (e) {
1258
+ // hide the picker when one of the parent elements is scrolled
1259
+ if (jsc.picker && jsc.picker.owner) {
1260
+ jsc.picker.owner.tryHide();
1261
+ }
1262
+ },
1263
+
1264
+
1265
+ onDocumentMouseDown : function (e) {
1266
+ var target = e.target || e.srcElement;
1267
+
1268
+ if (target.jscolor && target.jscolor instanceof jsc.pub) { // clicked targetElement -> show picker
1269
+ if (target.jscolor.showOnClick && !target.disabled) {
1270
+ target.jscolor.show();
1271
+ }
1272
+ } else if (jsc.getData(target, 'gui')) { // clicked jscolor's GUI element
1273
+ var control = jsc.getData(target, 'control');
1274
+ if (control) {
1275
+ // jscolor's control
1276
+ jsc.onControlPointerStart(e, target, jsc.getData(target, 'control'), 'mouse');
1277
+ }
1278
+ } else {
1279
+ // mouse is outside the picker's controls -> hide the color picker!
1280
+ if (jsc.picker && jsc.picker.owner) {
1281
+ jsc.picker.owner.tryHide();
1282
+ }
1283
+ }
1284
+ },
1285
+
1286
+
1287
+ onPickerTouchStart : function (e) {
1288
+ var target = e.target || e.srcElement;
1289
+
1290
+ if (jsc.getData(target, 'control')) {
1291
+ jsc.onControlPointerStart(e, target, jsc.getData(target, 'control'), 'touch');
1292
+ }
1293
+ },
1294
+
1295
+
1296
+ onControlPointerStart : function (e, target, controlName, pointerType) {
1297
+ var thisObj = jsc.getData(target, 'instance');
1298
+
1299
+ jsc.preventDefault(e);
1300
+ jsc.captureTarget(target);
1301
+
1302
+ var registerDragEvents = function (doc, offset) {
1303
+ jsc.attachGroupEvent('drag', doc, jsc._pointerMoveEvent[pointerType],
1304
+ jsc.onDocumentPointerMove(e, target, controlName, pointerType, offset));
1305
+ jsc.attachGroupEvent('drag', doc, jsc._pointerEndEvent[pointerType],
1306
+ jsc.onDocumentPointerEnd(e, target, controlName, pointerType));
1307
+ };
1308
+
1309
+ registerDragEvents(window.document, [0, 0]);
1310
+
1311
+ if (window.parent && window.frameElement) {
1312
+ var rect = window.frameElement.getBoundingClientRect();
1313
+ var ofs = [-rect.left, -rect.top];
1314
+ registerDragEvents(window.parent.window.document, ofs);
1315
+ }
1316
+
1317
+ var abs = jsc.getAbsPointerPos(e);
1318
+ var rel = jsc.getRelPointerPos(e);
1319
+ jsc._pointerOrigin = {
1320
+ x: abs.x - rel.x,
1321
+ y: abs.y - rel.y
1322
+ };
1323
+
1324
+ switch (controlName) {
1325
+ case 'pad':
1326
+ // if the value slider is at the bottom, move it up
1327
+ if (jsc.getSliderChannel(thisObj) === 'v' && thisObj.channels.v === 0) {
1328
+ thisObj.fromHSVA(null, null, 100, null);
1329
+ }
1330
+ jsc.setPad(thisObj, e, 0, 0);
1331
+ break;
1332
+
1333
+ case 'sld':
1334
+ jsc.setSld(thisObj, e, 0);
1335
+ break;
1336
+
1337
+ case 'asld':
1338
+ jsc.setASld(thisObj, e, 0);
1339
+ break;
1340
+ }
1341
+ thisObj.trigger('input');
1342
+ },
1343
+
1344
+
1345
+ onDocumentPointerMove : function (e, target, controlName, pointerType, offset) {
1346
+ return function (e) {
1347
+ var thisObj = jsc.getData(target, 'instance');
1348
+ switch (controlName) {
1349
+ case 'pad':
1350
+ jsc.setPad(thisObj, e, offset[0], offset[1]);
1351
+ break;
1352
+
1353
+ case 'sld':
1354
+ jsc.setSld(thisObj, e, offset[1]);
1355
+ break;
1356
+
1357
+ case 'asld':
1358
+ jsc.setASld(thisObj, e, offset[1]);
1359
+ break;
1360
+ }
1361
+ thisObj.trigger('input');
1362
+ }
1363
+ },
1364
+
1365
+
1366
+ onDocumentPointerEnd : function (e, target, controlName, pointerType) {
1367
+ return function (e) {
1368
+ var thisObj = jsc.getData(target, 'instance');
1369
+ jsc.detachGroupEvents('drag');
1370
+ jsc.releaseTarget();
1371
+
1372
+ // Always trigger changes AFTER detaching outstanding mouse handlers,
1373
+ // in case some color change that occured in user-defined onChange/onInput handler
1374
+ // intruded into current mouse events
1375
+ thisObj.trigger('input');
1376
+ thisObj.trigger('change');
1377
+ };
1378
+ },
1379
+
1380
+
1381
+ onPaletteSampleClick : function (e) {
1382
+ var target = e.currentTarget;
1383
+ var thisObj = jsc.getData(target, 'instance');
1384
+ var color = jsc.getData(target, 'color');
1385
+
1386
+ // when format is flexible, use the original format of this color sample
1387
+ if (thisObj.format.toLowerCase() === 'any') {
1388
+ thisObj._setFormat(color.format); // adapt format
1389
+ if (!jsc.isAlphaFormat(thisObj.getFormat())) {
1390
+ color.rgba[3] = 1.0; // when switching to a format that doesn't support alpha, set full opacity
1391
+ }
1392
+ }
1393
+
1394
+ // if this color doesn't specify alpha, use alpha of 1.0 (if applicable)
1395
+ if (color.rgba[3] === null) {
1396
+ if (thisObj.paletteSetsAlpha === true || (thisObj.paletteSetsAlpha === 'auto' && thisObj._paletteHasTransparency)) {
1397
+ color.rgba[3] = 1.0;
1398
+ }
1399
+ }
1400
+
1401
+ thisObj.fromRGBA.apply(thisObj, color.rgba);
1402
+
1403
+ thisObj.trigger('input');
1404
+ thisObj.trigger('change');
1405
+
1406
+ if (thisObj.hideOnPaletteClick) {
1407
+ thisObj.hide();
1408
+ }
1409
+ },
1410
+
1411
+
1412
+ setPad : function (thisObj, e, ofsX, ofsY) {
1413
+ var pointerAbs = jsc.getAbsPointerPos(e);
1414
+ var x = ofsX + pointerAbs.x - jsc._pointerOrigin.x - thisObj.padding - thisObj.controlBorderWidth;
1415
+ var y = ofsY + pointerAbs.y - jsc._pointerOrigin.y - thisObj.padding - thisObj.controlBorderWidth;
1416
+
1417
+ var xVal = x * (360 / (thisObj.width - 1));
1418
+ var yVal = 100 - (y * (100 / (thisObj.height - 1)));
1419
+
1420
+ switch (jsc.getPadYChannel(thisObj)) {
1421
+ case 's': thisObj.fromHSVA(xVal, yVal, null, null); break;
1422
+ case 'v': thisObj.fromHSVA(xVal, null, yVal, null); break;
1423
+ }
1424
+ },
1425
+
1426
+
1427
+ setSld : function (thisObj, e, ofsY) {
1428
+ var pointerAbs = jsc.getAbsPointerPos(e);
1429
+ var y = ofsY + pointerAbs.y - jsc._pointerOrigin.y - thisObj.padding - thisObj.controlBorderWidth;
1430
+ var yVal = 100 - (y * (100 / (thisObj.height - 1)));
1431
+
1432
+ switch (jsc.getSliderChannel(thisObj)) {
1433
+ case 's': thisObj.fromHSVA(null, yVal, null, null); break;
1434
+ case 'v': thisObj.fromHSVA(null, null, yVal, null); break;
1435
+ }
1436
+ },
1437
+
1438
+
1439
+ setASld : function (thisObj, e, ofsY) {
1440
+ var pointerAbs = jsc.getAbsPointerPos(e);
1441
+ var y = ofsY + pointerAbs.y - jsc._pointerOrigin.y - thisObj.padding - thisObj.controlBorderWidth;
1442
+ var yVal = 1.0 - (y * (1.0 / (thisObj.height - 1)));
1443
+
1444
+ if (yVal < 1.0) {
1445
+ // if format is flexible and the current format doesn't support alpha, switch to a suitable one
1446
+ var fmt = thisObj.getFormat();
1447
+ if (thisObj.format.toLowerCase() === 'any' && !jsc.isAlphaFormat(fmt)) {
1448
+ thisObj._setFormat(fmt === 'hex' ? 'hexa' : 'rgba');
1449
+ }
1450
+ }
1451
+
1452
+ thisObj.fromHSVA(null, null, null, yVal);
1453
+ },
1454
+
1455
+
1456
+ createPadCanvas : function () {
1457
+
1458
+ var ret = {
1459
+ elm: null,
1460
+ draw: null
1461
+ };
1462
+
1463
+ var canvas = jsc.createEl('canvas');
1464
+ var ctx = canvas.getContext('2d');
1465
+
1466
+ var drawFunc = function (width, height, type) {
1467
+ canvas.width = width;
1468
+ canvas.height = height;
1469
+
1470
+ ctx.clearRect(0, 0, canvas.width, canvas.height);
1471
+
1472
+ var hGrad = ctx.createLinearGradient(0, 0, canvas.width, 0);
1473
+ hGrad.addColorStop(0 / 6, '#F00');
1474
+ hGrad.addColorStop(1 / 6, '#FF0');
1475
+ hGrad.addColorStop(2 / 6, '#0F0');
1476
+ hGrad.addColorStop(3 / 6, '#0FF');
1477
+ hGrad.addColorStop(4 / 6, '#00F');
1478
+ hGrad.addColorStop(5 / 6, '#F0F');
1479
+ hGrad.addColorStop(6 / 6, '#F00');
1480
+
1481
+ ctx.fillStyle = hGrad;
1482
+ ctx.fillRect(0, 0, canvas.width, canvas.height);
1483
+
1484
+ var vGrad = ctx.createLinearGradient(0, 0, 0, canvas.height);
1485
+ switch (type.toLowerCase()) {
1486
+ case 's':
1487
+ vGrad.addColorStop(0, 'rgba(255,255,255,0)');
1488
+ vGrad.addColorStop(1, 'rgba(255,255,255,1)');
1489
+ break;
1490
+ case 'v':
1491
+ vGrad.addColorStop(0, 'rgba(0,0,0,0)');
1492
+ vGrad.addColorStop(1, 'rgba(0,0,0,1)');
1493
+ break;
1494
+ }
1495
+ ctx.fillStyle = vGrad;
1496
+ ctx.fillRect(0, 0, canvas.width, canvas.height);
1497
+ };
1498
+
1499
+ ret.elm = canvas;
1500
+ ret.draw = drawFunc;
1501
+
1502
+ return ret;
1503
+ },
1504
+
1505
+
1506
+ createSliderGradient : function () {
1507
+
1508
+ var ret = {
1509
+ elm: null,
1510
+ draw: null
1511
+ };
1512
+
1513
+ var canvas = jsc.createEl('canvas');
1514
+ var ctx = canvas.getContext('2d');
1515
+
1516
+ var drawFunc = function (width, height, color1, color2) {
1517
+ canvas.width = width;
1518
+ canvas.height = height;
1519
+
1520
+ ctx.clearRect(0, 0, canvas.width, canvas.height);
1521
+
1522
+ var grad = ctx.createLinearGradient(0, 0, 0, canvas.height);
1523
+ grad.addColorStop(0, color1);
1524
+ grad.addColorStop(1, color2);
1525
+
1526
+ ctx.fillStyle = grad;
1527
+ ctx.fillRect(0, 0, canvas.width, canvas.height);
1528
+ };
1529
+
1530
+ ret.elm = canvas;
1531
+ ret.draw = drawFunc;
1532
+
1533
+ return ret;
1534
+ },
1535
+
1536
+
1537
+ createASliderGradient : function () {
1538
+
1539
+ var ret = {
1540
+ elm: null,
1541
+ draw: null
1542
+ };
1543
+
1544
+ var canvas = jsc.createEl('canvas');
1545
+ var ctx = canvas.getContext('2d');
1546
+
1547
+ var drawFunc = function (width, height, color) {
1548
+ canvas.width = width;
1549
+ canvas.height = height;
1550
+
1551
+ ctx.clearRect(0, 0, canvas.width, canvas.height);
1552
+
1553
+ var sqSize = canvas.width / 2;
1554
+ var sqColor1 = jsc.pub.chessboardColor1;
1555
+ var sqColor2 = jsc.pub.chessboardColor2;
1556
+
1557
+ // dark gray background
1558
+ ctx.fillStyle = sqColor1;
1559
+ ctx.fillRect(0, 0, canvas.width, canvas.height);
1560
+
1561
+ if (sqSize > 0) { // to avoid infinite loop
1562
+ for (var y = 0; y < canvas.height; y += sqSize * 2) {
1563
+ // light gray squares
1564
+ ctx.fillStyle = sqColor2;
1565
+ ctx.fillRect(0, y, sqSize, sqSize);
1566
+ ctx.fillRect(sqSize, y + sqSize, sqSize, sqSize);
1567
+ }
1568
+ }
1569
+
1570
+ var grad = ctx.createLinearGradient(0, 0, 0, canvas.height);
1571
+ grad.addColorStop(0, color);
1572
+ grad.addColorStop(1, 'rgba(0,0,0,0)');
1573
+
1574
+ ctx.fillStyle = grad;
1575
+ ctx.fillRect(0, 0, canvas.width, canvas.height);
1576
+ };
1577
+
1578
+ ret.elm = canvas;
1579
+ ret.draw = drawFunc;
1580
+
1581
+ return ret;
1582
+ },
1583
+
1584
+
1585
+ BoxShadow : (function () {
1586
+ var BoxShadow = function (hShadow, vShadow, blur, spread, color, inset) {
1587
+ this.hShadow = hShadow;
1588
+ this.vShadow = vShadow;
1589
+ this.blur = blur;
1590
+ this.spread = spread;
1591
+ this.color = color;
1592
+ this.inset = !!inset;
1593
+ };
1594
+
1595
+ BoxShadow.prototype.toString = function () {
1596
+ var vals = [
1597
+ Math.round(this.hShadow) + 'px',
1598
+ Math.round(this.vShadow) + 'px',
1599
+ Math.round(this.blur) + 'px',
1600
+ Math.round(this.spread) + 'px',
1601
+ this.color
1602
+ ];
1603
+ if (this.inset) {
1604
+ vals.push('inset');
1605
+ }
1606
+ return vals.join(' ');
1607
+ };
1608
+
1609
+ return BoxShadow;
1610
+ })(),
1611
+
1612
+
1613
+ flags : {
1614
+ leaveValue : 1 << 0,
1615
+ leaveAlpha : 1 << 1,
1616
+ leavePreview : 1 << 2,
1617
+ },
1618
+
1619
+
1620
+ enumOpts : {
1621
+ format: ['auto', 'any', 'hex', 'hexa', 'rgb', 'rgba'],
1622
+ previewPosition: ['left', 'right'],
1623
+ mode: ['hsv', 'hvs', 'hs', 'hv'],
1624
+ position: ['left', 'right', 'top', 'bottom'],
1625
+ alphaChannel: ['auto', true, false],
1626
+ paletteSetsAlpha: ['auto', true, false],
1627
+ },
1628
+
1629
+
1630
+ deprecatedOpts : {
1631
+ // <old_option>: <new_option> (<new_option> can be null)
1632
+ 'styleElement': 'previewElement',
1633
+ 'onFineChange': 'onInput',
1634
+ 'overwriteImportant': 'forceStyle',
1635
+ 'closable': 'closeButton',
1636
+ 'insetWidth': 'controlBorderWidth',
1637
+ 'insetColor': 'controlBorderColor',
1638
+ 'refine': null,
1639
+ },
1640
+
1641
+
1642
+ docsRef : ' ' + 'See https://jscolor.com/docs/',
1643
+
1644
+
1645
+ //
1646
+ // Usage:
1647
+ // var myPicker = new JSColor(<targetElement> [, <options>])
1648
+ //
1649
+ // (constructor is accessible via both 'jscolor' and 'JSColor' name)
1650
+ //
1651
+
1652
+ pub : function (targetElement, opts) {
1653
+
1654
+ var THIS = this;
1655
+
1656
+ if (!opts) {
1657
+ opts = {};
1658
+ }
1659
+
1660
+ this.channels = {
1661
+ r: 255, // red [0-255]
1662
+ g: 255, // green [0-255]
1663
+ b: 255, // blue [0-255]
1664
+ h: 0, // hue [0-360]
1665
+ s: 0, // saturation [0-100]
1666
+ v: 100, // value (brightness) [0-100]
1667
+ a: 1.0, // alpha (opacity) [0.0 - 1.0]
1668
+ };
1669
+
1670
+ // General options
1671
+ //
1672
+ this.format = 'auto'; // 'auto' | 'any' | 'hex' | 'hexa' | 'rgb' | 'rgba' - Format of the input/output value
1673
+ this.value = undefined; // INITIAL color value in any supported format. To change it later, use method fromString(), fromHSVA(), fromRGBA() or channel()
1674
+ this.alpha = undefined; // INITIAL alpha value. To change it later, call method channel('A', <value>)
1675
+ this.onChange = undefined; // called when color changes. Value can be either a function or a string with JS code.
1676
+ this.onInput = undefined; // called repeatedly as the color is being changed, e.g. while dragging a slider. Value can be either a function or a string with JS code.
1677
+ this.valueElement = undefined; // element that will be used to display and input the color value
1678
+ this.alphaElement = undefined; // element that will be used to display and input the alpha (opacity) value
1679
+ this.previewElement = undefined; // element that will preview the picked color using CSS background
1680
+ this.previewPosition = 'left'; // 'left' | 'right' - position of the color preview in previewElement
1681
+ this.previewSize = 32; // (px) width of the color preview displayed in previewElement
1682
+ this.previewPadding = 8; // (px) space between color preview and content of the previewElement
1683
+ this.required = true; // whether the associated text input must always contain a color value. If false, the input can be left empty.
1684
+ this.hash = true; // whether to prefix the HEX color code with # symbol (only applicable for HEX format)
1685
+ this.uppercase = true; // whether to show the HEX color code in upper case (only applicable for HEX format)
1686
+ this.forceStyle = true; // whether to overwrite CSS style of the previewElement using !important flag
1687
+
1688
+ // Color Picker options
1689
+ //
1690
+ this.width = 181; // width of the color spectrum (in px)
1691
+ this.height = 101; // height of the color spectrum (in px)
1692
+ this.mode = 'HSV'; // 'HSV' | 'HVS' | 'HS' | 'HV' - layout of the color picker controls
1693
+ this.alphaChannel = 'auto'; // 'auto' | true | false - if alpha channel is enabled, the alpha slider will be visible. If 'auto', it will be determined according to color format
1694
+ this.position = 'bottom'; // 'left' | 'right' | 'top' | 'bottom' - position relative to the target element
1695
+ this.smartPosition = true; // automatically change picker position when there is not enough space for it
1696
+ this.showOnClick = true; // whether to show the picker when user clicks its target element
1697
+ this.hideOnLeave = true; // whether to automatically hide the picker when user leaves its target element (e.g. upon clicking the document)
1698
+ this.palette = []; // colors to be displayed in the palette, specified as an array or a string of space separated color values (in any supported format)
1699
+ this.paletteCols = 10; // number of columns in the palette
1700
+ this.paletteSetsAlpha = 'auto'; // 'auto' | true | false - if true, palette colors that don't specify alpha will set alpha to 1.0
1701
+ this.paletteHeight = 16; // maximum height (px) of a row in the palette
1702
+ this.paletteSpacing = 4; // distance (px) between color samples in the palette
1703
+ this.hideOnPaletteClick = false; // when set to true, clicking the palette will also hide the color picker
1704
+ this.sliderSize = 16; // px
1705
+ this.crossSize = 8; // px
1706
+ this.closeButton = false; // whether to display the Close button
1707
+ this.closeText = 'Close';
1708
+ this.buttonColor = 'rgba(0,0,0,1)'; // CSS color
1709
+ this.buttonHeight = 18; // px
1710
+ this.padding = 12; // px
1711
+ this.backgroundColor = 'rgba(255,255,255,1)'; // CSS color
1712
+ this.borderWidth = 1; // px
1713
+ this.borderColor = 'rgba(187,187,187,1)'; // CSS color
1714
+ this.borderRadius = 8; // px
1715
+ this.controlBorderWidth = 1; // px
1716
+ this.controlBorderColor = 'rgba(187,187,187,1)'; // CSS color
1717
+ this.shadow = true; // whether to display a shadow
1718
+ this.shadowBlur = 15; // px
1719
+ this.shadowColor = 'rgba(0,0,0,0.2)'; // CSS color
1720
+ this.pointerColor = 'rgba(76,76,76,1)'; // CSS color
1721
+ this.pointerBorderWidth = 1; // px
1722
+ this.pointerBorderColor = 'rgba(255,255,255,1)'; // CSS color
1723
+ this.pointerThickness = 2; // px
1724
+ this.zIndex = 5000;
1725
+ this.container = undefined; // where to append the color picker (BODY element by default)
1726
+
1727
+ // Experimental
1728
+ //
1729
+ this.minS = 0; // min allowed saturation (0 - 100)
1730
+ this.maxS = 100; // max allowed saturation (0 - 100)
1731
+ this.minV = 0; // min allowed value (brightness) (0 - 100)
1732
+ this.maxV = 100; // max allowed value (brightness) (0 - 100)
1733
+ this.minA = 0.0; // min allowed alpha (opacity) (0.0 - 1.0)
1734
+ this.maxA = 1.0; // max allowed alpha (opacity) (0.0 - 1.0)
1735
+
1736
+
1737
+ // Getter: option(name)
1738
+ // Setter: option(name, value)
1739
+ // option({name:value, ...})
1740
+ //
1741
+ this.option = function () {
1742
+ if (!arguments.length) {
1743
+ throw new Error('No option specified');
1744
+ }
1745
+
1746
+ if (arguments.length === 1 && typeof arguments[0] === 'string') {
1747
+ // getting a single option
1748
+ try {
1749
+ return getOption(arguments[0]);
1750
+ } catch (e) {
1751
+ console.warn(e);
1752
+ }
1753
+ return false;
1754
+
1755
+ } else if (arguments.length >= 2 && typeof arguments[0] === 'string') {
1756
+ // setting a single option
1757
+ try {
1758
+ if (!setOption(arguments[0], arguments[1])) {
1759
+ return false;
1760
+ }
1761
+ } catch (e) {
1762
+ console.warn(e);
1763
+ return false;
1764
+ }
1765
+ this.redraw(); // immediately redraws the picker, if it's displayed
1766
+ this.exposeColor(); // in case some preview-related or format-related option was changed
1767
+ return true;
1768
+
1769
+ } else if (arguments.length === 1 && typeof arguments[0] === 'object') {
1770
+ // setting multiple options
1771
+ var opts = arguments[0];
1772
+ var success = true;
1773
+ for (var opt in opts) {
1774
+ if (opts.hasOwnProperty(opt)) {
1775
+ try {
1776
+ if (!setOption(opt, opts[opt])) {
1777
+ success = false;
1778
+ }
1779
+ } catch (e) {
1780
+ console.warn(e);
1781
+ success = false;
1782
+ }
1783
+ }
1784
+ }
1785
+ this.redraw(); // immediately redraws the picker, if it's displayed
1786
+ this.exposeColor(); // in case some preview-related or format-related option was changed
1787
+ return success;
1788
+ }
1789
+
1790
+ throw new Error('Invalid arguments');
1791
+ }
1792
+
1793
+
1794
+ // Getter: channel(name)
1795
+ // Setter: channel(name, value)
1796
+ //
1797
+ this.channel = function (name, value) {
1798
+ if (typeof name !== 'string') {
1799
+ throw new Error('Invalid value for channel name: ' + name);
1800
+ }
1801
+
1802
+ if (value === undefined) {
1803
+ // getting channel value
1804
+ if (!this.channels.hasOwnProperty(name.toLowerCase())) {
1805
+ console.warn('Getting unknown channel: ' + name);
1806
+ return false;
1807
+ }
1808
+ return this.channels[name.toLowerCase()];
1809
+
1810
+ } else {
1811
+ // setting channel value
1812
+ var res = false;
1813
+ switch (name.toLowerCase()) {
1814
+ case 'r': res = this.fromRGBA(value, null, null, null); break;
1815
+ case 'g': res = this.fromRGBA(null, value, null, null); break;
1816
+ case 'b': res = this.fromRGBA(null, null, value, null); break;
1817
+ case 'h': res = this.fromHSVA(value, null, null, null); break;
1818
+ case 's': res = this.fromHSVA(null, value, null, null); break;
1819
+ case 'v': res = this.fromHSVA(null, null, value, null); break;
1820
+ case 'a': res = this.fromHSVA(null, null, null, value); break;
1821
+ default:
1822
+ console.warn('Setting unknown channel: ' + name);
1823
+ return false;
1824
+ }
1825
+ if (res) {
1826
+ this.redraw(); // immediately redraws the picker, if it's displayed
1827
+ return true;
1828
+ }
1829
+ }
1830
+
1831
+ return false;
1832
+ }
1833
+
1834
+
1835
+ // Triggers given input event(s) by:
1836
+ // - executing on<Event> callback specified as picker's option
1837
+ // - triggering standard DOM event listeners attached to the value element
1838
+ //
1839
+ // It is possible to specify multiple events separated with a space.
1840
+ //
1841
+ this.trigger = function (eventNames) {
1842
+ var evs = jsc.strList(eventNames);
1843
+ for (var i = 0; i < evs.length; i += 1) {
1844
+ var ev = evs[i].toLowerCase();
1845
+
1846
+ // trigger a callback
1847
+ var callbackProp = null;
1848
+ switch (ev) {
1849
+ case 'input': callbackProp = 'onInput'; break;
1850
+ case 'change': callbackProp = 'onChange'; break;
1851
+ }
1852
+ if (callbackProp) {
1853
+ jsc.triggerCallback(this, callbackProp);
1854
+ }
1855
+
1856
+ // trigger standard DOM event listeners on the value element
1857
+ jsc.triggerInputEvent(this.valueElement, ev, true, true);
1858
+ }
1859
+ };
1860
+
1861
+
1862
+ // h: 0-360
1863
+ // s: 0-100
1864
+ // v: 0-100
1865
+ // a: 0.0-1.0
1866
+ //
1867
+ this.fromHSVA = function (h, s, v, a, flags) { // null = don't change
1868
+ if (h === undefined) { h = null; }
1869
+ if (s === undefined) { s = null; }
1870
+ if (v === undefined) { v = null; }
1871
+ if (a === undefined) { a = null; }
1872
+
1873
+ if (h !== null) {
1874
+ if (isNaN(h)) { return false; }
1875
+ this.channels.h = Math.max(0, Math.min(360, h));
1876
+ }
1877
+ if (s !== null) {
1878
+ if (isNaN(s)) { return false; }
1879
+ this.channels.s = Math.max(0, Math.min(100, this.maxS, s), this.minS);
1880
+ }
1881
+ if (v !== null) {
1882
+ if (isNaN(v)) { return false; }
1883
+ this.channels.v = Math.max(0, Math.min(100, this.maxV, v), this.minV);
1884
+ }
1885
+ if (a !== null) {
1886
+ if (isNaN(a)) { return false; }
1887
+ this.channels.a = this.hasAlphaChannel() ?
1888
+ Math.max(0, Math.min(1, this.maxA, a), this.minA) :
1889
+ 1.0; // if alpha channel is disabled, the color should stay 100% opaque
1890
+ }
1891
+
1892
+ var rgb = jsc.HSV_RGB(
1893
+ this.channels.h,
1894
+ this.channels.s,
1895
+ this.channels.v
1896
+ );
1897
+ this.channels.r = rgb[0];
1898
+ this.channels.g = rgb[1];
1899
+ this.channels.b = rgb[2];
1900
+
1901
+ this.exposeColor(flags);
1902
+ return true;
1903
+ };
1904
+
1905
+
1906
+ // r: 0-255
1907
+ // g: 0-255
1908
+ // b: 0-255
1909
+ // a: 0.0-1.0
1910
+ //
1911
+ this.fromRGBA = function (r, g, b, a, flags) { // null = don't change
1912
+ if (r === undefined) { r = null; }
1913
+ if (g === undefined) { g = null; }
1914
+ if (b === undefined) { b = null; }
1915
+ if (a === undefined) { a = null; }
1916
+
1917
+ if (r !== null) {
1918
+ if (isNaN(r)) { return false; }
1919
+ r = Math.max(0, Math.min(255, r));
1920
+ }
1921
+ if (g !== null) {
1922
+ if (isNaN(g)) { return false; }
1923
+ g = Math.max(0, Math.min(255, g));
1924
+ }
1925
+ if (b !== null) {
1926
+ if (isNaN(b)) { return false; }
1927
+ b = Math.max(0, Math.min(255, b));
1928
+ }
1929
+ if (a !== null) {
1930
+ if (isNaN(a)) { return false; }
1931
+ this.channels.a = this.hasAlphaChannel() ?
1932
+ Math.max(0, Math.min(1, this.maxA, a), this.minA) :
1933
+ 1.0; // if alpha channel is disabled, the color should stay 100% opaque
1934
+ }
1935
+
1936
+ var hsv = jsc.RGB_HSV(
1937
+ r===null ? this.channels.r : r,
1938
+ g===null ? this.channels.g : g,
1939
+ b===null ? this.channels.b : b
1940
+ );
1941
+ if (hsv[0] !== null) {
1942
+ this.channels.h = Math.max(0, Math.min(360, hsv[0]));
1943
+ }
1944
+ if (hsv[2] !== 0) { // fully black color stays black through entire saturation range, so let's not change saturation
1945
+ this.channels.s = Math.max(0, this.minS, Math.min(100, this.maxS, hsv[1]));
1946
+ }
1947
+ this.channels.v = Math.max(0, this.minV, Math.min(100, this.maxV, hsv[2]));
1948
+
1949
+ // update RGB according to final HSV, as some values might be trimmed
1950
+ var rgb = jsc.HSV_RGB(this.channels.h, this.channels.s, this.channels.v);
1951
+ this.channels.r = rgb[0];
1952
+ this.channels.g = rgb[1];
1953
+ this.channels.b = rgb[2];
1954
+
1955
+ this.exposeColor(flags);
1956
+ return true;
1957
+ };
1958
+
1959
+
1960
+ // DEPRECATED. Use .fromHSVA() instead
1961
+ //
1962
+ this.fromHSV = function (h, s, v, flags) {
1963
+ console.warn('fromHSV() method is DEPRECATED. Using fromHSVA() instead.' + jsc.docsRef);
1964
+ return this.fromHSVA(h, s, v, null, flags);
1965
+ };
1966
+
1967
+
1968
+ // DEPRECATED. Use .fromRGBA() instead
1969
+ //
1970
+ this.fromRGB = function (r, g, b, flags) {
1971
+ console.warn('fromRGB() method is DEPRECATED. Using fromRGBA() instead.' + jsc.docsRef);
1972
+ return this.fromRGBA(r, g, b, null, flags);
1973
+ };
1974
+
1975
+
1976
+ this.fromString = function (str, flags) {
1977
+ if (!this.required && str.trim() === '') {
1978
+ // setting empty string to an optional color input
1979
+ this.setPreviewElementBg(null);
1980
+ this.setValueElementValue('');
1981
+ return true;
1982
+ }
1983
+
1984
+ var color = jsc.parseColorString(str);
1985
+ if (!color) {
1986
+ return false; // could not parse
1987
+ }
1988
+ if (this.format.toLowerCase() === 'any') {
1989
+ this._setFormat(color.format); // adapt format
1990
+ if (!jsc.isAlphaFormat(this.getFormat())) {
1991
+ color.rgba[3] = 1.0; // when switching to a format that doesn't support alpha, set full opacity
1992
+ }
1993
+ }
1994
+ this.fromRGBA(
1995
+ color.rgba[0],
1996
+ color.rgba[1],
1997
+ color.rgba[2],
1998
+ color.rgba[3],
1999
+ flags
2000
+ );
2001
+ return true;
2002
+ };
2003
+
2004
+
2005
+ this.toString = function (format) {
2006
+ if (format === undefined) {
2007
+ format = this.getFormat(); // format not specified -> use the current format
2008
+ }
2009
+ switch (format.toLowerCase()) {
2010
+ case 'hex': return this.toHEXString(); break;
2011
+ case 'hexa': return this.toHEXAString(); break;
2012
+ case 'rgb': return this.toRGBString(); break;
2013
+ case 'rgba': return this.toRGBAString(); break;
2014
+ }
2015
+ return false;
2016
+ };
2017
+
2018
+
2019
+ this.toHEXString = function () {
2020
+ return jsc.hexColor(
2021
+ this.channels.r,
2022
+ this.channels.g,
2023
+ this.channels.b
2024
+ );
2025
+ };
2026
+
2027
+
2028
+ this.toHEXAString = function () {
2029
+ return jsc.hexaColor(
2030
+ this.channels.r,
2031
+ this.channels.g,
2032
+ this.channels.b,
2033
+ this.channels.a
2034
+ );
2035
+ };
2036
+
2037
+
2038
+ this.toRGBString = function () {
2039
+ return jsc.rgbColor(
2040
+ this.channels.r,
2041
+ this.channels.g,
2042
+ this.channels.b
2043
+ );
2044
+ };
2045
+
2046
+
2047
+ this.toRGBAString = function () {
2048
+ return jsc.rgbaColor(
2049
+ this.channels.r,
2050
+ this.channels.g,
2051
+ this.channels.b,
2052
+ this.channels.a
2053
+ );
2054
+ };
2055
+
2056
+
2057
+ this.toGrayscale = function () {
2058
+ return (
2059
+ 0.213 * this.channels.r +
2060
+ 0.715 * this.channels.g +
2061
+ 0.072 * this.channels.b
2062
+ );
2063
+ };
2064
+
2065
+
2066
+ this.toCanvas = function () {
2067
+ return jsc.genColorPreviewCanvas(this.toRGBAString()).canvas;
2068
+ };
2069
+
2070
+
2071
+ this.toDataURL = function () {
2072
+ return this.toCanvas().toDataURL();
2073
+ };
2074
+
2075
+
2076
+ this.toBackground = function () {
2077
+ return jsc.pub.background(this.toRGBAString());
2078
+ };
2079
+
2080
+
2081
+ this.isLight = function () {
2082
+ return this.toGrayscale() > 255 / 2;
2083
+ };
2084
+
2085
+
2086
+ this.hide = function () {
2087
+ if (isPickerOwner()) {
2088
+ detachPicker();
2089
+ }
2090
+ };
2091
+
2092
+
2093
+ this.show = function () {
2094
+ drawPicker();
2095
+ };
2096
+
2097
+
2098
+ this.redraw = function () {
2099
+ if (isPickerOwner()) {
2100
+ drawPicker();
2101
+ }
2102
+ };
2103
+
2104
+
2105
+ this.getFormat = function () {
2106
+ return this._currentFormat;
2107
+ };
2108
+
2109
+
2110
+ this._setFormat = function (format) {
2111
+ this._currentFormat = format.toLowerCase();
2112
+ };
2113
+
2114
+
2115
+ this.hasAlphaChannel = function () {
2116
+ if (this.alphaChannel === 'auto') {
2117
+ return (
2118
+ this.format.toLowerCase() === 'any' || // format can change on the fly (e.g. from hex to rgba), so let's consider the alpha channel enabled
2119
+ jsc.isAlphaFormat(this.getFormat()) || // the current format supports alpha channel
2120
+ this.alpha !== undefined || // initial alpha value is set, so we're working with alpha channel
2121
+ this.alphaElement !== undefined // the alpha value is redirected, so we're working with alpha channel
2122
+ );
2123
+ }
2124
+
2125
+ return this.alphaChannel; // the alpha channel is explicitly set
2126
+ };
2127
+
2128
+
2129
+ this.processValueInput = function (str) {
2130
+ if (!this.fromString(str)) {
2131
+ // could not parse the color value - let's just expose the current color
2132
+ this.exposeColor();
2133
+ }
2134
+ };
2135
+
2136
+
2137
+ this.processAlphaInput = function (str) {
2138
+ if (!this.fromHSVA(null, null, null, parseFloat(str))) {
2139
+ // could not parse the alpha value - let's just expose the current color
2140
+ this.exposeColor();
2141
+ }
2142
+ };
2143
+
2144
+
2145
+ this.exposeColor = function (flags) {
2146
+ var colorStr = this.toString();
2147
+ var fmt = this.getFormat();
2148
+
2149
+ // reflect current color in data- attribute
2150
+ jsc.setDataAttr(this.targetElement, 'current-color', colorStr);
2151
+
2152
+ if (!(flags & jsc.flags.leaveValue) && this.valueElement) {
2153
+ if (fmt === 'hex' || fmt === 'hexa') {
2154
+ if (!this.uppercase) { colorStr = colorStr.toLowerCase(); }
2155
+ if (!this.hash) { colorStr = colorStr.replace(/^#/, ''); }
2156
+ }
2157
+ this.setValueElementValue(colorStr);
2158
+ }
2159
+
2160
+ if (!(flags & jsc.flags.leaveAlpha) && this.alphaElement) {
2161
+ var alphaVal = Math.round(this.channels.a * 100) / 100;
2162
+ this.setAlphaElementValue(alphaVal);
2163
+ }
2164
+
2165
+ if (!(flags & jsc.flags.leavePreview) && this.previewElement) {
2166
+ var previewPos = null; // 'left' | 'right' (null -> fill the entire element)
2167
+
2168
+ if (
2169
+ jsc.isTextInput(this.previewElement) || // text input
2170
+ (jsc.isButton(this.previewElement) && !jsc.isButtonEmpty(this.previewElement)) // button with text
2171
+ ) {
2172
+ previewPos = this.previewPosition;
2173
+ }
2174
+
2175
+ this.setPreviewElementBg(this.toRGBAString());
2176
+ }
2177
+
2178
+ if (isPickerOwner()) {
2179
+ redrawPad();
2180
+ redrawSld();
2181
+ redrawASld();
2182
+ }
2183
+ };
2184
+
2185
+
2186
+ this.setPreviewElementBg = function (color) {
2187
+ if (!this.previewElement) {
2188
+ return;
2189
+ }
2190
+
2191
+ var position = null; // color preview position: null | 'left' | 'right'
2192
+ var width = null; // color preview width: px | null = fill the entire element
2193
+ if (
2194
+ jsc.isTextInput(this.previewElement) || // text input
2195
+ (jsc.isButton(this.previewElement) && !jsc.isButtonEmpty(this.previewElement)) // button with text
2196
+ ) {
2197
+ position = this.previewPosition;
2198
+ width = this.previewSize;
2199
+ }
2200
+
2201
+ var backgrounds = [];
2202
+
2203
+ if (!color) {
2204
+ // there is no color preview to display -> let's remove any previous background image
2205
+ backgrounds.push({
2206
+ image: 'none',
2207
+ position: 'left top',
2208
+ size: 'auto',
2209
+ repeat: 'no-repeat',
2210
+ origin: 'padding-box',
2211
+ });
2212
+ } else {
2213
+ // CSS gradient for background color preview
2214
+ backgrounds.push({
2215
+ image: jsc.genColorPreviewGradient(
2216
+ color,
2217
+ position,
2218
+ width ? width - jsc.pub.previewSeparator.length : null
2219
+ ),
2220
+ position: 'left top',
2221
+ size: 'auto',
2222
+ repeat: position ? 'repeat-y' : 'repeat',
2223
+ origin: 'padding-box',
2224
+ });
2225
+
2226
+ // data URL of generated PNG image with a gray transparency chessboard
2227
+ var preview = jsc.genColorPreviewCanvas(
2228
+ 'rgba(0,0,0,0)',
2229
+ position ? {'left':'right', 'right':'left'}[position] : null,
2230
+ width,
2231
+ true
2232
+ );
2233
+ backgrounds.push({
2234
+ image: 'url(\'' + preview.canvas.toDataURL() + '\')',
2235
+ position: (position || 'left') + ' top',
2236
+ size: preview.width + 'px ' + preview.height + 'px',
2237
+ repeat: position ? 'repeat-y' : 'repeat',
2238
+ origin: 'padding-box',
2239
+ });
2240
+ }
2241
+
2242
+ var bg = {
2243
+ image: [],
2244
+ position: [],
2245
+ size: [],
2246
+ repeat: [],
2247
+ origin: [],
2248
+ };
2249
+ for (var i = 0; i < backgrounds.length; i += 1) {
2250
+ bg.image.push(backgrounds[i].image);
2251
+ bg.position.push(backgrounds[i].position);
2252
+ bg.size.push(backgrounds[i].size);
2253
+ bg.repeat.push(backgrounds[i].repeat);
2254
+ bg.origin.push(backgrounds[i].origin);
2255
+ }
2256
+
2257
+ // set previewElement's background-images
2258
+ var sty = {
2259
+ 'background-image': bg.image.join(', '),
2260
+ 'background-position': bg.position.join(', '),
2261
+ 'background-size': bg.size.join(', '),
2262
+ 'background-repeat': bg.repeat.join(', '),
2263
+ 'background-origin': bg.origin.join(', '),
2264
+ };
2265
+ jsc.setStyle(this.previewElement, sty, this.forceStyle);
2266
+
2267
+
2268
+ // set/restore previewElement's padding
2269
+ var padding = {
2270
+ left: null,
2271
+ right: null,
2272
+ };
2273
+ if (position) {
2274
+ padding[position] = (this.previewSize + this.previewPadding) + 'px';
2275
+ }
2276
+
2277
+ var sty = {
2278
+ 'padding-left': padding.left,
2279
+ 'padding-right': padding.right,
2280
+ };
2281
+ jsc.setStyle(this.previewElement, sty, this.forceStyle, true);
2282
+ };
2283
+
2284
+
2285
+ this.setValueElementValue = function (str) {
2286
+ if (this.valueElement) {
2287
+ if (jsc.nodeName(this.valueElement) === 'input') {
2288
+ this.valueElement.value = str;
2289
+ } else {
2290
+ this.valueElement.innerHTML = str;
2291
+ }
2292
+ }
2293
+ };
2294
+
2295
+
2296
+ this.setAlphaElementValue = function (str) {
2297
+ if (this.alphaElement) {
2298
+ if (jsc.nodeName(this.alphaElement) === 'input') {
2299
+ this.alphaElement.value = str;
2300
+ } else {
2301
+ this.alphaElement.innerHTML = str;
2302
+ }
2303
+ }
2304
+ };
2305
+
2306
+
2307
+ this._processParentElementsInDOM = function () {
2308
+ if (this._parentElementsProcessed) { return; }
2309
+ this._parentElementsProcessed = true;
2310
+
2311
+ var elm = this.targetElement;
2312
+ do {
2313
+ // If the target element or one of its parent nodes has fixed position,
2314
+ // then use fixed positioning instead
2315
+ var compStyle = jsc.getCompStyle(elm);
2316
+ if (compStyle.position && compStyle.position.toLowerCase() === 'fixed') {
2317
+ this.fixed = true;
2318
+ }
2319
+
2320
+ if (elm !== this.targetElement) {
2321
+ // Ensure to attach onParentScroll only once to each parent element
2322
+ // (multiple targetElements can share the same parent nodes)
2323
+ //
2324
+ // Note: It's not just offsetParents that can be scrollable,
2325
+ // that's why we loop through all parent nodes
2326
+ if (!jsc.getData(elm, 'hasScrollListener')) {
2327
+ elm.addEventListener('scroll', jsc.onParentScroll, false);
2328
+ jsc.setData(elm, 'hasScrollListener', true);
2329
+ }
2330
+ }
2331
+ } while ((elm = elm.parentNode) && jsc.nodeName(elm) !== 'body');
2332
+ };
2333
+
2334
+
2335
+ this.tryHide = function () {
2336
+ if (this.hideOnLeave) {
2337
+ this.hide();
2338
+ }
2339
+ };
2340
+
2341
+
2342
+ this.set__palette = function (val) {
2343
+ this.palette = val;
2344
+ this._palette = jsc.parsePaletteValue(val);
2345
+ this._paletteHasTransparency = jsc.containsTranparentColor(this._palette);
2346
+ };
2347
+
2348
+
2349
+ function setOption (option, value) {
2350
+ if (typeof option !== 'string') {
2351
+ throw new Error('Invalid value for option name: ' + option);
2352
+ }
2353
+
2354
+ // enum option
2355
+ if (jsc.enumOpts.hasOwnProperty(option)) {
2356
+ if (typeof value === 'string') { // enum string values are case insensitive
2357
+ value = value.toLowerCase();
2358
+ }
2359
+ if (jsc.enumOpts[option].indexOf(value) === -1) {
2360
+ throw new Error('Option \'' + option + '\' has invalid value: ' + value);
2361
+ }
2362
+ }
2363
+
2364
+ // deprecated option
2365
+ if (jsc.deprecatedOpts.hasOwnProperty(option)) {
2366
+ var oldOpt = option;
2367
+ var newOpt = jsc.deprecatedOpts[option];
2368
+ if (newOpt) {
2369
+ // if we have a new name for this option, let's log a warning and use the new name
2370
+ console.warn('Option \'%s\' is DEPRECATED, using \'%s\' instead.' + jsc.docsRef, oldOpt, newOpt);
2371
+ option = newOpt;
2372
+ } else {
2373
+ // new name not available for the option
2374
+ throw new Error('Option \'' + option + '\' is DEPRECATED');
2375
+ }
2376
+ }
2377
+
2378
+ var setter = 'set__' + option;
2379
+
2380
+ if (typeof THIS[setter] === 'function') { // a setter exists for this option
2381
+ THIS[setter](value);
2382
+ return true;
2383
+
2384
+ } else if (option in THIS) { // option exists as a property
2385
+ THIS[option] = value;
2386
+ return true;
2387
+ }
2388
+
2389
+ throw new Error('Unrecognized configuration option: ' + option);
2390
+ }
2391
+
2392
+
2393
+ function getOption (option) {
2394
+ if (typeof option !== 'string') {
2395
+ throw new Error('Invalid value for option name: ' + option);
2396
+ }
2397
+
2398
+ // deprecated option
2399
+ if (jsc.deprecatedOpts.hasOwnProperty(option)) {
2400
+ var oldOpt = option;
2401
+ var newOpt = jsc.deprecatedOpts[option];
2402
+ if (newOpt) {
2403
+ // if we have a new name for this option, let's log a warning and use the new name
2404
+ console.warn('Option \'%s\' is DEPRECATED, using \'%s\' instead.' + jsc.docsRef, oldOpt, newOpt);
2405
+ option = newOpt;
2406
+ } else {
2407
+ // new name not available for the option
2408
+ throw new Error('Option \'' + option + '\' is DEPRECATED');
2409
+ }
2410
+ }
2411
+
2412
+ var getter = 'get__' + option;
2413
+
2414
+ if (typeof THIS[getter] === 'function') { // a getter exists for this option
2415
+ return THIS[getter](value);
2416
+
2417
+ } else if (option in THIS) { // option exists as a property
2418
+ return THIS[option];
2419
+ }
2420
+
2421
+ throw new Error('Unrecognized configuration option: ' + option);
2422
+ }
2423
+
2424
+
2425
+ function detachPicker () {
2426
+ jsc.removeClass(THIS.targetElement, jsc.pub.activeClassName);
2427
+ jsc.picker.wrap.parentNode.removeChild(jsc.picker.wrap);
2428
+ delete jsc.picker.owner;
2429
+ }
2430
+
2431
+
2432
+ function drawPicker () {
2433
+
2434
+ // At this point, when drawing the picker, we know what the parent elements are
2435
+ // and we can do all related DOM operations, such as registering events on them
2436
+ // or checking their positioning
2437
+ THIS._processParentElementsInDOM();
2438
+
2439
+ if (!jsc.picker) {
2440
+ jsc.picker = {
2441
+ owner: null, // owner picker instance
2442
+ wrap : jsc.createEl('div'),
2443
+ box : jsc.createEl('div'),
2444
+ boxS : jsc.createEl('div'), // shadow area
2445
+ boxB : jsc.createEl('div'), // border
2446
+ pad : jsc.createEl('div'),
2447
+ padB : jsc.createEl('div'), // border
2448
+ padM : jsc.createEl('div'), // mouse/touch area
2449
+ padCanvas : jsc.createPadCanvas(),
2450
+ cross : jsc.createEl('div'),
2451
+ crossBY : jsc.createEl('div'), // border Y
2452
+ crossBX : jsc.createEl('div'), // border X
2453
+ crossLY : jsc.createEl('div'), // line Y
2454
+ crossLX : jsc.createEl('div'), // line X
2455
+ sld : jsc.createEl('div'), // slider
2456
+ sldB : jsc.createEl('div'), // border
2457
+ sldM : jsc.createEl('div'), // mouse/touch area
2458
+ sldGrad : jsc.createSliderGradient(),
2459
+ sldPtrS : jsc.createEl('div'), // slider pointer spacer
2460
+ sldPtrIB : jsc.createEl('div'), // slider pointer inner border
2461
+ sldPtrMB : jsc.createEl('div'), // slider pointer middle border
2462
+ sldPtrOB : jsc.createEl('div'), // slider pointer outer border
2463
+ asld : jsc.createEl('div'), // alpha slider
2464
+ asldB : jsc.createEl('div'), // border
2465
+ asldM : jsc.createEl('div'), // mouse/touch area
2466
+ asldGrad : jsc.createASliderGradient(),
2467
+ asldPtrS : jsc.createEl('div'), // slider pointer spacer
2468
+ asldPtrIB : jsc.createEl('div'), // slider pointer inner border
2469
+ asldPtrMB : jsc.createEl('div'), // slider pointer middle border
2470
+ asldPtrOB : jsc.createEl('div'), // slider pointer outer border
2471
+ pal : jsc.createEl('div'), // palette
2472
+ btn : jsc.createEl('div'),
2473
+ btnT : jsc.createEl('span'), // text
2474
+ };
2475
+
2476
+ jsc.picker.pad.appendChild(jsc.picker.padCanvas.elm);
2477
+ jsc.picker.padB.appendChild(jsc.picker.pad);
2478
+ jsc.picker.cross.appendChild(jsc.picker.crossBY);
2479
+ jsc.picker.cross.appendChild(jsc.picker.crossBX);
2480
+ jsc.picker.cross.appendChild(jsc.picker.crossLY);
2481
+ jsc.picker.cross.appendChild(jsc.picker.crossLX);
2482
+ jsc.picker.padB.appendChild(jsc.picker.cross);
2483
+ jsc.picker.box.appendChild(jsc.picker.padB);
2484
+ jsc.picker.box.appendChild(jsc.picker.padM);
2485
+
2486
+ jsc.picker.sld.appendChild(jsc.picker.sldGrad.elm);
2487
+ jsc.picker.sldB.appendChild(jsc.picker.sld);
2488
+ jsc.picker.sldB.appendChild(jsc.picker.sldPtrOB);
2489
+ jsc.picker.sldPtrOB.appendChild(jsc.picker.sldPtrMB);
2490
+ jsc.picker.sldPtrMB.appendChild(jsc.picker.sldPtrIB);
2491
+ jsc.picker.sldPtrIB.appendChild(jsc.picker.sldPtrS);
2492
+ jsc.picker.box.appendChild(jsc.picker.sldB);
2493
+ jsc.picker.box.appendChild(jsc.picker.sldM);
2494
+
2495
+ jsc.picker.asld.appendChild(jsc.picker.asldGrad.elm);
2496
+ jsc.picker.asldB.appendChild(jsc.picker.asld);
2497
+ jsc.picker.asldB.appendChild(jsc.picker.asldPtrOB);
2498
+ jsc.picker.asldPtrOB.appendChild(jsc.picker.asldPtrMB);
2499
+ jsc.picker.asldPtrMB.appendChild(jsc.picker.asldPtrIB);
2500
+ jsc.picker.asldPtrIB.appendChild(jsc.picker.asldPtrS);
2501
+ jsc.picker.box.appendChild(jsc.picker.asldB);
2502
+ jsc.picker.box.appendChild(jsc.picker.asldM);
2503
+
2504
+ jsc.picker.box.appendChild(jsc.picker.pal);
2505
+
2506
+ jsc.picker.btn.appendChild(jsc.picker.btnT);
2507
+ jsc.picker.box.appendChild(jsc.picker.btn);
2508
+
2509
+ jsc.picker.boxB.appendChild(jsc.picker.box);
2510
+ jsc.picker.wrap.appendChild(jsc.picker.boxS);
2511
+ jsc.picker.wrap.appendChild(jsc.picker.boxB);
2512
+
2513
+ jsc.picker.wrap.addEventListener('touchstart', jsc.onPickerTouchStart,
2514
+ jsc.isPassiveEventSupported ? {passive: false} : false);
2515
+ }
2516
+
2517
+ var p = jsc.picker;
2518
+
2519
+ var displaySlider = !!jsc.getSliderChannel(THIS);
2520
+ var displayAlphaSlider = THIS.hasAlphaChannel();
2521
+ var pickerDims = jsc.getPickerDims(THIS);
2522
+ var crossOuterSize = (2 * THIS.pointerBorderWidth + THIS.pointerThickness + 2 * THIS.crossSize);
2523
+ var controlPadding = jsc.getControlPadding(THIS);
2524
+ var borderRadius = Math.min(
2525
+ THIS.borderRadius,
2526
+ Math.round(THIS.padding * Math.PI)); // px
2527
+ var padCursor = 'crosshair';
2528
+
2529
+ // wrap
2530
+ p.wrap.className = 'jscolor-picker-wrap';
2531
+ p.wrap.style.clear = 'both';
2532
+ p.wrap.style.width = pickerDims.borderW + 'px';
2533
+ p.wrap.style.height = pickerDims.borderH + 'px';
2534
+ p.wrap.style.zIndex = THIS.zIndex;
2535
+
2536
+ // picker
2537
+ p.box.className = 'jscolor-picker';
2538
+ p.box.style.width = pickerDims.paddedW + 'px';
2539
+ p.box.style.height = pickerDims.paddedH + 'px';
2540
+ p.box.style.position = 'relative';
2541
+
2542
+ // picker shadow
2543
+ p.boxS.className = 'jscolor-picker-shadow';
2544
+ p.boxS.style.position = 'absolute';
2545
+ p.boxS.style.left = '0';
2546
+ p.boxS.style.top = '0';
2547
+ p.boxS.style.width = '100%';
2548
+ p.boxS.style.height = '100%';
2549
+ jsc.setBorderRadius(p.boxS, borderRadius + 'px');
2550
+
2551
+ // picker border
2552
+ p.boxB.className = 'jscolor-picker-border';
2553
+ p.boxB.style.position = 'relative';
2554
+ p.boxB.style.border = THIS.borderWidth + 'px solid';
2555
+ p.boxB.style.borderColor = THIS.borderColor;
2556
+ p.boxB.style.background = THIS.backgroundColor;
2557
+ jsc.setBorderRadius(p.boxB, borderRadius + 'px');
2558
+
2559
+ // IE hack:
2560
+ // If the element is transparent, IE will trigger the event on the elements under it,
2561
+ // e.g. on Canvas or on elements with border
2562
+ p.padM.style.background = 'rgba(255,0,0,.2)';
2563
+ p.sldM.style.background = 'rgba(0,255,0,.2)';
2564
+ p.asldM.style.background = 'rgba(0,0,255,.2)';
2565
+
2566
+ p.padM.style.opacity =
2567
+ p.sldM.style.opacity =
2568
+ p.asldM.style.opacity =
2569
+ '0';
2570
+
2571
+ // pad
2572
+ p.pad.style.position = 'relative';
2573
+ p.pad.style.width = THIS.width + 'px';
2574
+ p.pad.style.height = THIS.height + 'px';
2575
+
2576
+ // pad - color spectrum (HSV and HVS)
2577
+ p.padCanvas.draw(THIS.width, THIS.height, jsc.getPadYChannel(THIS));
2578
+
2579
+ // pad border
2580
+ p.padB.style.position = 'absolute';
2581
+ p.padB.style.left = THIS.padding + 'px';
2582
+ p.padB.style.top = THIS.padding + 'px';
2583
+ p.padB.style.border = THIS.controlBorderWidth + 'px solid';
2584
+ p.padB.style.borderColor = THIS.controlBorderColor;
2585
+
2586
+ // pad mouse area
2587
+ p.padM.style.position = 'absolute';
2588
+ p.padM.style.left = 0 + 'px';
2589
+ p.padM.style.top = 0 + 'px';
2590
+ p.padM.style.width = (THIS.padding + 2 * THIS.controlBorderWidth + THIS.width + controlPadding) + 'px';
2591
+ p.padM.style.height = (2 * THIS.controlBorderWidth + 2 * THIS.padding + THIS.height) + 'px';
2592
+ p.padM.style.cursor = padCursor;
2593
+ jsc.setData(p.padM, {
2594
+ instance: THIS,
2595
+ control: 'pad',
2596
+ })
2597
+
2598
+ // pad cross
2599
+ p.cross.style.position = 'absolute';
2600
+ p.cross.style.left =
2601
+ p.cross.style.top =
2602
+ '0';
2603
+ p.cross.style.width =
2604
+ p.cross.style.height =
2605
+ crossOuterSize + 'px';
2606
+
2607
+ // pad cross border Y and X
2608
+ p.crossBY.style.position =
2609
+ p.crossBX.style.position =
2610
+ 'absolute';
2611
+ p.crossBY.style.background =
2612
+ p.crossBX.style.background =
2613
+ THIS.pointerBorderColor;
2614
+ p.crossBY.style.width =
2615
+ p.crossBX.style.height =
2616
+ (2 * THIS.pointerBorderWidth + THIS.pointerThickness) + 'px';
2617
+ p.crossBY.style.height =
2618
+ p.crossBX.style.width =
2619
+ crossOuterSize + 'px';
2620
+ p.crossBY.style.left =
2621
+ p.crossBX.style.top =
2622
+ (Math.floor(crossOuterSize / 2) - Math.floor(THIS.pointerThickness / 2) - THIS.pointerBorderWidth) + 'px';
2623
+ p.crossBY.style.top =
2624
+ p.crossBX.style.left =
2625
+ '0';
2626
+
2627
+ // pad cross line Y and X
2628
+ p.crossLY.style.position =
2629
+ p.crossLX.style.position =
2630
+ 'absolute';
2631
+ p.crossLY.style.background =
2632
+ p.crossLX.style.background =
2633
+ THIS.pointerColor;
2634
+ p.crossLY.style.height =
2635
+ p.crossLX.style.width =
2636
+ (crossOuterSize - 2 * THIS.pointerBorderWidth) + 'px';
2637
+ p.crossLY.style.width =
2638
+ p.crossLX.style.height =
2639
+ THIS.pointerThickness + 'px';
2640
+ p.crossLY.style.left =
2641
+ p.crossLX.style.top =
2642
+ (Math.floor(crossOuterSize / 2) - Math.floor(THIS.pointerThickness / 2)) + 'px';
2643
+ p.crossLY.style.top =
2644
+ p.crossLX.style.left =
2645
+ THIS.pointerBorderWidth + 'px';
2646
+
2647
+
2648
+ // slider
2649
+ p.sld.style.overflow = 'hidden';
2650
+ p.sld.style.width = THIS.sliderSize + 'px';
2651
+ p.sld.style.height = THIS.height + 'px';
2652
+
2653
+ // slider gradient
2654
+ p.sldGrad.draw(THIS.sliderSize, THIS.height, '#000', '#000');
2655
+
2656
+ // slider border
2657
+ p.sldB.style.display = displaySlider ? 'block' : 'none';
2658
+ p.sldB.style.position = 'absolute';
2659
+ p.sldB.style.left = (THIS.padding + THIS.width + 2 * THIS.controlBorderWidth + 2 * controlPadding) + 'px';
2660
+ p.sldB.style.top = THIS.padding + 'px';
2661
+ p.sldB.style.border = THIS.controlBorderWidth + 'px solid';
2662
+ p.sldB.style.borderColor = THIS.controlBorderColor;
2663
+
2664
+ // slider mouse area
2665
+ p.sldM.style.display = displaySlider ? 'block' : 'none';
2666
+ p.sldM.style.position = 'absolute';
2667
+ p.sldM.style.left = (THIS.padding + THIS.width + 2 * THIS.controlBorderWidth + controlPadding) + 'px';
2668
+ p.sldM.style.top = 0 + 'px';
2669
+ p.sldM.style.width = (
2670
+ (THIS.sliderSize + 2 * controlPadding + 2 * THIS.controlBorderWidth) +
2671
+ (displayAlphaSlider ? 0 : Math.max(0, THIS.padding - controlPadding)) // remaining padding to the right edge
2672
+ ) + 'px';
2673
+ p.sldM.style.height = (2 * THIS.controlBorderWidth + 2 * THIS.padding + THIS.height) + 'px';
2674
+ p.sldM.style.cursor = 'default';
2675
+ jsc.setData(p.sldM, {
2676
+ instance: THIS,
2677
+ control: 'sld',
2678
+ });
2679
+
2680
+ // slider pointer inner and outer border
2681
+ p.sldPtrIB.style.border =
2682
+ p.sldPtrOB.style.border =
2683
+ THIS.pointerBorderWidth + 'px solid ' + THIS.pointerBorderColor;
2684
+
2685
+ // slider pointer outer border
2686
+ p.sldPtrOB.style.position = 'absolute';
2687
+ p.sldPtrOB.style.left = -(2 * THIS.pointerBorderWidth + THIS.pointerThickness) + 'px';
2688
+ p.sldPtrOB.style.top = '0';
2689
+
2690
+ // slider pointer middle border
2691
+ p.sldPtrMB.style.border = THIS.pointerThickness + 'px solid ' + THIS.pointerColor;
2692
+
2693
+ // slider pointer spacer
2694
+ p.sldPtrS.style.width = THIS.sliderSize + 'px';
2695
+ p.sldPtrS.style.height = jsc.pub.sliderInnerSpace + 'px';
2696
+
2697
+
2698
+ // alpha slider
2699
+ p.asld.style.overflow = 'hidden';
2700
+ p.asld.style.width = THIS.sliderSize + 'px';
2701
+ p.asld.style.height = THIS.height + 'px';
2702
+
2703
+ // alpha slider gradient
2704
+ p.asldGrad.draw(THIS.sliderSize, THIS.height, '#000');
2705
+
2706
+ // alpha slider border
2707
+ p.asldB.style.display = displayAlphaSlider ? 'block' : 'none';
2708
+ p.asldB.style.position = 'absolute';
2709
+ p.asldB.style.left = (
2710
+ (THIS.padding + THIS.width + 2 * THIS.controlBorderWidth + controlPadding) +
2711
+ (displaySlider ? (THIS.sliderSize + 3 * controlPadding + 2 * THIS.controlBorderWidth) : 0)
2712
+ ) + 'px';
2713
+ p.asldB.style.top = THIS.padding + 'px';
2714
+ p.asldB.style.border = THIS.controlBorderWidth + 'px solid';
2715
+ p.asldB.style.borderColor = THIS.controlBorderColor;
2716
+
2717
+ // alpha slider mouse area
2718
+ p.asldM.style.display = displayAlphaSlider ? 'block' : 'none';
2719
+ p.asldM.style.position = 'absolute';
2720
+ p.asldM.style.left = (
2721
+ (THIS.padding + THIS.width + 2 * THIS.controlBorderWidth + controlPadding) +
2722
+ (displaySlider ? (THIS.sliderSize + 2 * controlPadding + 2 * THIS.controlBorderWidth) : 0)
2723
+ ) + 'px';
2724
+ p.asldM.style.top = 0 + 'px';
2725
+ p.asldM.style.width = (
2726
+ (THIS.sliderSize + 2 * controlPadding + 2 * THIS.controlBorderWidth) +
2727
+ Math.max(0, THIS.padding - controlPadding) // remaining padding to the right edge
2728
+ ) + 'px';
2729
+ p.asldM.style.height = (2 * THIS.controlBorderWidth + 2 * THIS.padding + THIS.height) + 'px';
2730
+ p.asldM.style.cursor = 'default';
2731
+ jsc.setData(p.asldM, {
2732
+ instance: THIS,
2733
+ control: 'asld',
2734
+ })
2735
+
2736
+ // alpha slider pointer inner and outer border
2737
+ p.asldPtrIB.style.border =
2738
+ p.asldPtrOB.style.border =
2739
+ THIS.pointerBorderWidth + 'px solid ' + THIS.pointerBorderColor;
2740
+
2741
+ // alpha slider pointer outer border
2742
+ p.asldPtrOB.style.position = 'absolute';
2743
+ p.asldPtrOB.style.left = -(2 * THIS.pointerBorderWidth + THIS.pointerThickness) + 'px';
2744
+ p.asldPtrOB.style.top = '0';
2745
+
2746
+ // alpha slider pointer middle border
2747
+ p.asldPtrMB.style.border = THIS.pointerThickness + 'px solid ' + THIS.pointerColor;
2748
+
2749
+ // alpha slider pointer spacer
2750
+ p.asldPtrS.style.width = THIS.sliderSize + 'px';
2751
+ p.asldPtrS.style.height = jsc.pub.sliderInnerSpace + 'px';
2752
+
2753
+
2754
+ // palette
2755
+ p.pal.className = 'jscolor-palette';
2756
+ p.pal.style.display = pickerDims.palette.rows ? 'block' : 'none';
2757
+ p.pal.style.position = 'absolute';
2758
+ p.pal.style.left = THIS.padding + 'px';
2759
+ p.pal.style.top = (2 * THIS.controlBorderWidth + 2 * THIS.padding + THIS.height) + 'px';
2760
+
2761
+ // palette's color samples
2762
+
2763
+ p.pal.innerHTML = '';
2764
+
2765
+ var chessboard = jsc.genColorPreviewCanvas('rgba(0,0,0,0)');
2766
+
2767
+ var si = 0; // color sample's index
2768
+ for (var r = 0; r < pickerDims.palette.rows; r++) {
2769
+ for (var c = 0; c < pickerDims.palette.cols && si < THIS._palette.length; c++, si++) {
2770
+ var sampleColor = THIS._palette[si];
2771
+ var sampleCssColor = jsc.rgbaColor.apply(null, sampleColor.rgba);
2772
+
2773
+ var sc = jsc.createEl('div'); // color sample's color
2774
+ sc.style.width = (pickerDims.palette.cellW - 2 * THIS.controlBorderWidth) + 'px';
2775
+ sc.style.height = (pickerDims.palette.cellH - 2 * THIS.controlBorderWidth) + 'px';
2776
+ sc.style.backgroundColor = sampleCssColor;
2777
+
2778
+ var sw = jsc.createEl('div'); // color sample's wrap
2779
+ sw.className = 'jscolor-palette-sample';
2780
+ sw.style.display = 'block';
2781
+ sw.style.position = 'absolute';
2782
+ sw.style.left = (
2783
+ pickerDims.palette.cols <= 1 ? 0 :
2784
+ Math.round(10 * (c * ((pickerDims.contentW - pickerDims.palette.cellW) / (pickerDims.palette.cols - 1)))) / 10
2785
+ ) + 'px';
2786
+ sw.style.top = (r * (pickerDims.palette.cellH + THIS.paletteSpacing)) + 'px';
2787
+ sw.style.border = THIS.controlBorderWidth + 'px solid';
2788
+ sw.style.borderColor = THIS.controlBorderColor;
2789
+ sw.style.cursor = 'pointer';
2790
+ if (sampleColor.rgba[3] !== null && sampleColor.rgba[3] < 1.0) { // only create chessboard background if the sample has transparency
2791
+ sw.style.backgroundImage = 'url(\'' + chessboard.canvas.toDataURL() + '\')';
2792
+ sw.style.backgroundRepeat = 'repeat';
2793
+ sw.style.backgroundPosition = 'center center';
2794
+ }
2795
+ jsc.setData(sw, {
2796
+ instance: THIS,
2797
+ control: 'palette-sample',
2798
+ color: sampleColor,
2799
+ })
2800
+ sw.addEventListener('click', jsc.onPaletteSampleClick, false);
2801
+ sw.appendChild(sc);
2802
+ p.pal.appendChild(sw);
2803
+ }
2804
+ }
2805
+
2806
+
2807
+ // the Close button
2808
+ function setBtnBorder () {
2809
+ var insetColors = THIS.controlBorderColor.split(/\s+/);
2810
+ var outsetColor = insetColors.length < 2 ? insetColors[0] : insetColors[1] + ' ' + insetColors[0] + ' ' + insetColors[0] + ' ' + insetColors[1];
2811
+ p.btn.style.borderColor = outsetColor;
2812
+ }
2813
+ var btnPadding = 15; // px
2814
+ p.btn.className = 'jscolor-btn-close';
2815
+ p.btn.style.display = THIS.closeButton ? 'block' : 'none';
2816
+ p.btn.style.position = 'absolute';
2817
+ p.btn.style.left = THIS.padding + 'px';
2818
+ p.btn.style.bottom = THIS.padding + 'px';
2819
+ p.btn.style.padding = '0 ' + btnPadding + 'px';
2820
+ p.btn.style.maxWidth = (pickerDims.contentW - 2 * THIS.controlBorderWidth - 2 * btnPadding) + 'px';
2821
+ p.btn.style.overflow = 'hidden';
2822
+ p.btn.style.height = THIS.buttonHeight + 'px';
2823
+ p.btn.style.whiteSpace = 'nowrap';
2824
+ p.btn.style.border = THIS.controlBorderWidth + 'px solid';
2825
+ setBtnBorder();
2826
+ p.btn.style.color = THIS.buttonColor;
2827
+ p.btn.style.font = '12px sans-serif';
2828
+ p.btn.style.textAlign = 'center';
2829
+ p.btn.style.cursor = 'pointer';
2830
+ p.btn.onmousedown = function () {
2831
+ THIS.hide();
2832
+ };
2833
+ p.btnT.style.lineHeight = THIS.buttonHeight + 'px';
2834
+ p.btnT.innerHTML = '';
2835
+ p.btnT.appendChild(window.document.createTextNode(THIS.closeText));
2836
+
2837
+ // reposition the pointers
2838
+ redrawPad();
2839
+ redrawSld();
2840
+ redrawASld();
2841
+
2842
+ // If we are changing the owner without first closing the picker,
2843
+ // make sure to first deal with the old owner
2844
+ if (jsc.picker.owner && jsc.picker.owner !== THIS) {
2845
+ jsc.removeClass(jsc.picker.owner.targetElement, jsc.pub.activeClassName);
2846
+ }
2847
+
2848
+ // Set a new picker owner
2849
+ jsc.picker.owner = THIS;
2850
+
2851
+ // The redrawPosition() method needs picker.owner to be set, that's why we call it here,
2852
+ // after setting the owner
2853
+ if (THIS.container === window.document.body) {
2854
+ jsc.redrawPosition();
2855
+ } else {
2856
+ jsc._drawPosition(THIS, 0, 0, 'relative', false);
2857
+ }
2858
+
2859
+ if (p.wrap.parentNode !== THIS.container) {
2860
+ THIS.container.appendChild(p.wrap);
2861
+ }
2862
+
2863
+ jsc.addClass(THIS.targetElement, jsc.pub.activeClassName);
2864
+ }
2865
+
2866
+
2867
+ function redrawPad () {
2868
+ // redraw the pad pointer
2869
+ var yChannel = jsc.getPadYChannel(THIS);
2870
+ var x = Math.round((THIS.channels.h / 360) * (THIS.width - 1));
2871
+ var y = Math.round((1 - THIS.channels[yChannel] / 100) * (THIS.height - 1));
2872
+ var crossOuterSize = (2 * THIS.pointerBorderWidth + THIS.pointerThickness + 2 * THIS.crossSize);
2873
+ var ofs = -Math.floor(crossOuterSize / 2);
2874
+ jsc.picker.cross.style.left = (x + ofs) + 'px';
2875
+ jsc.picker.cross.style.top = (y + ofs) + 'px';
2876
+
2877
+ // redraw the slider
2878
+ switch (jsc.getSliderChannel(THIS)) {
2879
+ case 's':
2880
+ var rgb1 = jsc.HSV_RGB(THIS.channels.h, 100, THIS.channels.v);
2881
+ var rgb2 = jsc.HSV_RGB(THIS.channels.h, 0, THIS.channels.v);
2882
+ var color1 = 'rgb(' +
2883
+ Math.round(rgb1[0]) + ',' +
2884
+ Math.round(rgb1[1]) + ',' +
2885
+ Math.round(rgb1[2]) + ')';
2886
+ var color2 = 'rgb(' +
2887
+ Math.round(rgb2[0]) + ',' +
2888
+ Math.round(rgb2[1]) + ',' +
2889
+ Math.round(rgb2[2]) + ')';
2890
+ jsc.picker.sldGrad.draw(THIS.sliderSize, THIS.height, color1, color2);
2891
+ break;
2892
+ case 'v':
2893
+ var rgb = jsc.HSV_RGB(THIS.channels.h, THIS.channels.s, 100);
2894
+ var color1 = 'rgb(' +
2895
+ Math.round(rgb[0]) + ',' +
2896
+ Math.round(rgb[1]) + ',' +
2897
+ Math.round(rgb[2]) + ')';
2898
+ var color2 = '#000';
2899
+ jsc.picker.sldGrad.draw(THIS.sliderSize, THIS.height, color1, color2);
2900
+ break;
2901
+ }
2902
+
2903
+ // redraw the alpha slider
2904
+ jsc.picker.asldGrad.draw(THIS.sliderSize, THIS.height, THIS.toHEXString());
2905
+ }
2906
+
2907
+
2908
+ function redrawSld () {
2909
+ var sldChannel = jsc.getSliderChannel(THIS);
2910
+ if (sldChannel) {
2911
+ // redraw the slider pointer
2912
+ var y = Math.round((1 - THIS.channels[sldChannel] / 100) * (THIS.height - 1));
2913
+ jsc.picker.sldPtrOB.style.top = (y - (2 * THIS.pointerBorderWidth + THIS.pointerThickness) - Math.floor(jsc.pub.sliderInnerSpace / 2)) + 'px';
2914
+ }
2915
+
2916
+ // redraw the alpha slider
2917
+ jsc.picker.asldGrad.draw(THIS.sliderSize, THIS.height, THIS.toHEXString());
2918
+ }
2919
+
2920
+
2921
+ function redrawASld () {
2922
+ var y = Math.round((1 - THIS.channels.a) * (THIS.height - 1));
2923
+ jsc.picker.asldPtrOB.style.top = (y - (2 * THIS.pointerBorderWidth + THIS.pointerThickness) - Math.floor(jsc.pub.sliderInnerSpace / 2)) + 'px';
2924
+ }
2925
+
2926
+
2927
+ function isPickerOwner () {
2928
+ return jsc.picker && jsc.picker.owner === THIS;
2929
+ }
2930
+
2931
+
2932
+ function onValueKeyDown (ev) {
2933
+ if (jsc.eventKey(ev) === 'Enter') {
2934
+ if (THIS.valueElement) {
2935
+ THIS.processValueInput(THIS.valueElement.value);
2936
+ }
2937
+ THIS.tryHide();
2938
+ }
2939
+ }
2940
+
2941
+
2942
+ function onAlphaKeyDown (ev) {
2943
+ if (jsc.eventKey(ev) === 'Enter') {
2944
+ if (THIS.alphaElement) {
2945
+ THIS.processAlphaInput(THIS.alphaElement.value);
2946
+ }
2947
+ THIS.tryHide();
2948
+ }
2949
+ }
2950
+
2951
+
2952
+ function onValueChange (ev) {
2953
+ if (jsc.getData(ev, 'internal')) {
2954
+ return; // skip if the event was internally triggered by jscolor
2955
+ }
2956
+
2957
+ var oldVal = THIS.valueElement.value;
2958
+
2959
+ THIS.processValueInput(THIS.valueElement.value); // this might change the value
2960
+
2961
+ jsc.triggerCallback(THIS, 'onChange');
2962
+
2963
+ if (THIS.valueElement.value !== oldVal) {
2964
+ // value was additionally changed -> let's trigger the change event again, even though it was natively dispatched
2965
+ jsc.triggerInputEvent(THIS.valueElement, 'change', true, true);
2966
+ }
2967
+ }
2968
+
2969
+
2970
+ function onAlphaChange (ev) {
2971
+ if (jsc.getData(ev, 'internal')) {
2972
+ return; // skip if the event was internally triggered by jscolor
2973
+ }
2974
+
2975
+ var oldVal = THIS.alphaElement.value;
2976
+
2977
+ THIS.processAlphaInput(THIS.alphaElement.value); // this might change the value
2978
+
2979
+ jsc.triggerCallback(THIS, 'onChange');
2980
+
2981
+ // triggering valueElement's onChange (because changing alpha changes the entire color, e.g. with rgba format)
2982
+ jsc.triggerInputEvent(THIS.valueElement, 'change', true, true);
2983
+
2984
+ if (THIS.alphaElement.value !== oldVal) {
2985
+ // value was additionally changed -> let's trigger the change event again, even though it was natively dispatched
2986
+ jsc.triggerInputEvent(THIS.alphaElement, 'change', true, true);
2987
+ }
2988
+ }
2989
+
2990
+
2991
+ function onValueInput (ev) {
2992
+ if (jsc.getData(ev, 'internal')) {
2993
+ return; // skip if the event was internally triggered by jscolor
2994
+ }
2995
+
2996
+ if (THIS.valueElement) {
2997
+ THIS.fromString(THIS.valueElement.value, jsc.flags.leaveValue);
2998
+ }
2999
+
3000
+ jsc.triggerCallback(THIS, 'onInput');
3001
+
3002
+ // triggering valueElement's onInput
3003
+ // (not needed, it was dispatched normally by the browser)
3004
+ }
3005
+
3006
+
3007
+ function onAlphaInput (ev) {
3008
+ if (jsc.getData(ev, 'internal')) {
3009
+ return; // skip if the event was internally triggered by jscolor
3010
+ }
3011
+
3012
+ if (THIS.alphaElement) {
3013
+ THIS.fromHSVA(null, null, null, parseFloat(THIS.alphaElement.value), jsc.flags.leaveAlpha);
3014
+ }
3015
+
3016
+ jsc.triggerCallback(THIS, 'onInput');
3017
+
3018
+ // triggering valueElement's onInput (because changing alpha changes the entire color, e.g. with rgba format)
3019
+ jsc.triggerInputEvent(THIS.valueElement, 'input', true, true);
3020
+ }
3021
+
3022
+
3023
+ // let's process the DEPRECATED 'options' property (this will be later removed)
3024
+ if (jsc.pub.options) {
3025
+ // let's set custom default options, if specified
3026
+ for (var opt in jsc.pub.options) {
3027
+ if (jsc.pub.options.hasOwnProperty(opt)) {
3028
+ try {
3029
+ setOption(opt, jsc.pub.options[opt]);
3030
+ } catch (e) {
3031
+ console.warn(e);
3032
+ }
3033
+ }
3034
+ }
3035
+ }
3036
+
3037
+
3038
+ // let's apply configuration presets
3039
+ //
3040
+ var presetsArr = [];
3041
+
3042
+ if (opts.preset) {
3043
+ if (typeof opts.preset === 'string') {
3044
+ presetsArr = opts.preset.split(/\s+/);
3045
+ } else if (Array.isArray(opts.preset)) {
3046
+ presetsArr = opts.preset.slice(); // slice() to clone
3047
+ } else {
3048
+ console.warn('Unrecognized preset value');
3049
+ }
3050
+ }
3051
+
3052
+ // always use the 'default' preset. If it's not listed, append it to the end.
3053
+ if (presetsArr.indexOf('default') === -1) {
3054
+ presetsArr.push('default');
3055
+ }
3056
+
3057
+ // let's apply the presets in reverse order, so that should there be any overlapping options,
3058
+ // the formerly listed preset will override the latter
3059
+ for (var i = presetsArr.length - 1; i >= 0; i -= 1) {
3060
+ var pres = presetsArr[i];
3061
+ if (!pres) {
3062
+ continue; // preset is empty string
3063
+ }
3064
+ if (!jsc.pub.presets.hasOwnProperty(pres)) {
3065
+ console.warn('Unknown preset: %s', pres);
3066
+ continue;
3067
+ }
3068
+ for (var opt in jsc.pub.presets[pres]) {
3069
+ if (jsc.pub.presets[pres].hasOwnProperty(opt)) {
3070
+ try {
3071
+ setOption(opt, jsc.pub.presets[pres][opt]);
3072
+ } catch (e) {
3073
+ console.warn(e);
3074
+ }
3075
+ }
3076
+ }
3077
+ }
3078
+
3079
+
3080
+ // let's set specific options for this color picker
3081
+ var nonProperties = [
3082
+ // these options won't be set as instance properties
3083
+ 'preset',
3084
+ ];
3085
+ for (var opt in opts) {
3086
+ if (opts.hasOwnProperty(opt)) {
3087
+ if (nonProperties.indexOf(opt) === -1) {
3088
+ try {
3089
+ setOption(opt, opts[opt]);
3090
+ } catch (e) {
3091
+ console.warn(e);
3092
+ }
3093
+ }
3094
+ }
3095
+ }
3096
+
3097
+
3098
+ //
3099
+ // Install the color picker on chosen element(s)
3100
+ //
3101
+
3102
+
3103
+ // Determine picker's container element
3104
+ if (this.container === undefined) {
3105
+ this.container = window.document.body; // default container is BODY element
3106
+
3107
+ } else { // explicitly set to custom element
3108
+ this.container = jsc.node(this.container);
3109
+ }
3110
+
3111
+ if (!this.container) {
3112
+ throw new Error('Cannot instantiate color picker without a container element');
3113
+ }
3114
+
3115
+
3116
+ // Fetch the target element
3117
+ this.targetElement = jsc.node(targetElement);
3118
+
3119
+ if (!this.targetElement) {
3120
+ // temporarily customized error message to help with migrating from versions prior to 2.2
3121
+ if (typeof targetElement === 'string' && /^[a-zA-Z][\w:.-]*$/.test(targetElement)) {
3122
+ // targetElement looks like valid ID
3123
+ var possiblyId = targetElement;
3124
+ throw new Error('If \'' + possiblyId + '\' is supposed to be an ID, please use \'#' + possiblyId + '\' or any valid CSS selector.');
3125
+ }
3126
+
3127
+ throw new Error('Cannot instantiate color picker without a target element');
3128
+ }
3129
+
3130
+ if (this.targetElement.jscolor && this.targetElement.jscolor instanceof jsc.pub) {
3131
+ throw new Error('Color picker already installed on this element');
3132
+ }
3133
+
3134
+
3135
+ // link this instance with the target element
3136
+ this.targetElement.jscolor = this;
3137
+ jsc.addClass(this.targetElement, jsc.pub.className);
3138
+
3139
+ // register this instance
3140
+ jsc.instances.push(this);
3141
+
3142
+
3143
+ // if target is BUTTON
3144
+ if (jsc.isButton(this.targetElement)) {
3145
+
3146
+ if (this.targetElement.type.toLowerCase() !== 'button') {
3147
+ // on buttons, always force type to be 'button', e.g. in situations the target <button> has no type
3148
+ // and thus defaults to 'submit' and would submit the form when clicked
3149
+ this.targetElement.type = 'button';
3150
+ }
3151
+
3152
+ if (jsc.isButtonEmpty(this.targetElement)) { // empty button
3153
+ // it is important to clear element's contents first.
3154
+ // if we're re-instantiating color pickers on DOM that has been modified by changing page's innerHTML,
3155
+ // we would keep adding more non-breaking spaces to element's content (because element's contents survive
3156
+ // innerHTML changes, but picker instances don't)
3157
+ jsc.removeChildren(this.targetElement);
3158
+
3159
+ // let's insert a non-breaking space
3160
+ this.targetElement.appendChild(window.document.createTextNode('\xa0'));
3161
+
3162
+ // set min-width = previewSize, if not already greater
3163
+ var compStyle = jsc.getCompStyle(this.targetElement);
3164
+ var currMinWidth = parseFloat(compStyle['min-width']) || 0;
3165
+ if (currMinWidth < this.previewSize) {
3166
+ jsc.setStyle(this.targetElement, {
3167
+ 'min-width': this.previewSize + 'px',
3168
+ }, this.forceStyle);
3169
+ }
3170
+ }
3171
+ }
3172
+
3173
+ // Determine the value element
3174
+ if (this.valueElement === undefined) {
3175
+ if (jsc.isTextInput(this.targetElement)) {
3176
+ // for text inputs, default valueElement is targetElement
3177
+ this.valueElement = this.targetElement;
3178
+ } else {
3179
+ // leave it undefined
3180
+ }
3181
+
3182
+ } else if (this.valueElement === null) { // explicitly set to null
3183
+ // leave it null
3184
+
3185
+ } else { // explicitly set to custom element
3186
+ this.valueElement = jsc.node(this.valueElement);
3187
+ }
3188
+
3189
+ // Determine the alpha element
3190
+ if (this.alphaElement) {
3191
+ this.alphaElement = jsc.node(this.alphaElement);
3192
+ }
3193
+
3194
+ // Determine the preview element
3195
+ if (this.previewElement === undefined) {
3196
+ this.previewElement = this.targetElement; // default previewElement is targetElement
3197
+
3198
+ } else if (this.previewElement === null) { // explicitly set to null
3199
+ // leave it null
3200
+
3201
+ } else { // explicitly set to custom element
3202
+ this.previewElement = jsc.node(this.previewElement);
3203
+ }
3204
+
3205
+ // valueElement
3206
+ if (this.valueElement && jsc.isTextInput(this.valueElement)) {
3207
+
3208
+ // If the value element has onInput event already set, we need to detach it and attach AFTER our listener.
3209
+ // otherwise the picker instance would still contain the old color when accessed from the onInput handler.
3210
+ var valueElementOrigEvents = {
3211
+ onInput: this.valueElement.oninput
3212
+ };
3213
+ this.valueElement.oninput = null;
3214
+
3215
+ this.valueElement.addEventListener('keydown', onValueKeyDown, false);
3216
+ this.valueElement.addEventListener('change', onValueChange, false);
3217
+ this.valueElement.addEventListener('input', onValueInput, false);
3218
+ // the original event listener must be attached AFTER our handler (to let it first set picker's color)
3219
+ if (valueElementOrigEvents.onInput) {
3220
+ this.valueElement.addEventListener('input', valueElementOrigEvents.onInput, false);
3221
+ }
3222
+
3223
+ this.valueElement.setAttribute('autocomplete', 'off');
3224
+ this.valueElement.setAttribute('autocorrect', 'off');
3225
+ this.valueElement.setAttribute('autocapitalize', 'off');
3226
+ this.valueElement.setAttribute('spellcheck', false);
3227
+ }
3228
+
3229
+ // alphaElement
3230
+ if (this.alphaElement && jsc.isTextInput(this.alphaElement)) {
3231
+ this.alphaElement.addEventListener('keydown', onAlphaKeyDown, false);
3232
+ this.alphaElement.addEventListener('change', onAlphaChange, false);
3233
+ this.alphaElement.addEventListener('input', onAlphaInput, false);
3234
+
3235
+ this.alphaElement.setAttribute('autocomplete', 'off');
3236
+ this.alphaElement.setAttribute('autocorrect', 'off');
3237
+ this.alphaElement.setAttribute('autocapitalize', 'off');
3238
+ this.alphaElement.setAttribute('spellcheck', false);
3239
+ }
3240
+
3241
+ // determine initial color value
3242
+ //
3243
+ var initValue = 'FFFFFF';
3244
+
3245
+ if (this.value !== undefined) {
3246
+ initValue = this.value; // get initial color from the 'value' property
3247
+ } else if (this.valueElement && this.valueElement.value !== undefined) {
3248
+ initValue = this.valueElement.value; // get initial color from valueElement's value
3249
+ }
3250
+
3251
+ // determine initial alpha value
3252
+ //
3253
+ var initAlpha = undefined;
3254
+
3255
+ if (this.alpha !== undefined) {
3256
+ initAlpha = (''+this.alpha); // get initial alpha value from the 'alpha' property
3257
+ } else if (this.alphaElement && this.alphaElement.value !== undefined) {
3258
+ initAlpha = this.alphaElement.value; // get initial color from alphaElement's value
3259
+ }
3260
+
3261
+ // determine current format based on the initial color value
3262
+ //
3263
+ this._currentFormat = null;
3264
+
3265
+ if (['auto', 'any'].indexOf(this.format.toLowerCase()) > -1) {
3266
+ // format is 'auto' or 'any' -> let's auto-detect current format
3267
+ var color = jsc.parseColorString(initValue);
3268
+ this._currentFormat = color ? color.format : 'hex';
3269
+ } else {
3270
+ // format is specified
3271
+ this._currentFormat = this.format.toLowerCase();
3272
+ }
3273
+
3274
+
3275
+ // let's parse the initial color value and expose color's preview
3276
+ this.processValueInput(initValue);
3277
+
3278
+ // let's also parse and expose the initial alpha value, if any
3279
+ //
3280
+ // Note: If the initial color value contains alpha value in it (e.g. in rgba format),
3281
+ // this will overwrite it. So we should only process alpha input if there was any initial
3282
+ // alpha explicitly set, otherwise we could needlessly lose initial value's alpha
3283
+ if (initAlpha !== undefined) {
3284
+ this.processAlphaInput(initAlpha);
3285
+ }
3286
+
3287
+ }
3288
+
3289
+ };
3290
+
3291
+
3292
+ //================================
3293
+ // Public properties and methods
3294
+ //================================
3295
+
3296
+ //
3297
+ // These will be publicly available via jscolor.<name> and JSColor.<name>
3298
+ //
3299
+
3300
+
3301
+ // class that will be set to elements having jscolor installed on them
3302
+ jsc.pub.className = 'jscolor';
3303
+
3304
+
3305
+ // class that will be set to elements having jscolor active on them
3306
+ jsc.pub.activeClassName = 'jscolor-active';
3307
+
3308
+
3309
+ // whether to try to parse the options string by evaluating it using 'new Function()'
3310
+ // in case it could not be parsed with JSON.parse()
3311
+ jsc.pub.looseJSON = true;
3312
+
3313
+
3314
+ // presets
3315
+ jsc.pub.presets = {};
3316
+
3317
+ // built-in presets
3318
+ jsc.pub.presets['default'] = {}; // baseline for customization
3319
+
3320
+ jsc.pub.presets['light'] = { // default color scheme
3321
+ backgroundColor: 'rgba(255,255,255,1)',
3322
+ controlBorderColor: 'rgba(187,187,187,1)',
3323
+ buttonColor: 'rgba(0,0,0,1)',
3324
+ };
3325
+ jsc.pub.presets['dark'] = {
3326
+ backgroundColor: 'rgba(51,51,51,1)',
3327
+ controlBorderColor: 'rgba(153,153,153,1)',
3328
+ buttonColor: 'rgba(240,240,240,1)',
3329
+ };
3330
+
3331
+ jsc.pub.presets['small'] = { width:101, height:101, padding:10, sliderSize:14, paletteCols:8 };
3332
+ jsc.pub.presets['medium'] = { width:181, height:101, padding:12, sliderSize:16, paletteCols:10 }; // default size
3333
+ jsc.pub.presets['large'] = { width:271, height:151, padding:12, sliderSize:24, paletteCols:15 };
3334
+
3335
+ jsc.pub.presets['thin'] = { borderWidth:1, controlBorderWidth:1, pointerBorderWidth:1 }; // default thickness
3336
+ jsc.pub.presets['thick'] = { borderWidth:2, controlBorderWidth:2, pointerBorderWidth:2 };
3337
+
3338
+
3339
+ // size of space in the sliders
3340
+ jsc.pub.sliderInnerSpace = 3; // px
3341
+
3342
+ // transparency chessboard
3343
+ jsc.pub.chessboardSize = 8; // px
3344
+ jsc.pub.chessboardColor1 = '#666666';
3345
+ jsc.pub.chessboardColor2 = '#999999';
3346
+
3347
+ // preview separator
3348
+ jsc.pub.previewSeparator = ['rgba(255,255,255,.65)', 'rgba(128,128,128,.65)'];
3349
+
3350
+
3351
+ // Initializes jscolor
3352
+ jsc.pub.init = function () {
3353
+ if (jsc.initialized) {
3354
+ return;
3355
+ }
3356
+
3357
+ // attach some necessary handlers
3358
+ window.document.addEventListener('mousedown', jsc.onDocumentMouseDown, false);
3359
+ window.document.addEventListener('keyup', jsc.onDocumentKeyUp, false);
3360
+ window.addEventListener('resize', jsc.onWindowResize, false);
3361
+ window.addEventListener('scroll', jsc.onWindowScroll, false);
3362
+
3363
+ // install jscolor on current DOM
3364
+ jsc.pub.install();
3365
+
3366
+ jsc.initialized = true;
3367
+
3368
+ // call functions waiting in the queue
3369
+ while (jsc.readyQueue.length) {
3370
+ var func = jsc.readyQueue.shift();
3371
+ func();
3372
+ }
3373
+ };
3374
+
3375
+
3376
+ // Installs jscolor on current DOM tree
3377
+ jsc.pub.install = function (rootNode) {
3378
+ var success = true;
3379
+
3380
+ try {
3381
+ jsc.installBySelector('[data-jscolor]', rootNode);
3382
+ } catch (e) {
3383
+ success = false;
3384
+ console.warn(e);
3385
+ }
3386
+
3387
+ // for backward compatibility with DEPRECATED installation using class name
3388
+ if (jsc.pub.lookupClass) {
3389
+ try {
3390
+ jsc.installBySelector(
3391
+ (
3392
+ 'input.' + jsc.pub.lookupClass + ', ' +
3393
+ 'button.' + jsc.pub.lookupClass
3394
+ ),
3395
+ rootNode
3396
+ );
3397
+ } catch (e) {}
3398
+ }
3399
+
3400
+ return success;
3401
+ };
3402
+
3403
+
3404
+ // Registers function to be called as soon as jscolor is initialized (or immediately, if it already is).
3405
+ //
3406
+ jsc.pub.ready = function (func) {
3407
+ if (typeof func !== 'function') {
3408
+ console.warn('Passed value is not a function');
3409
+ return false;
3410
+ }
3411
+
3412
+ if (jsc.initialized) {
3413
+ func();
3414
+ } else {
3415
+ jsc.readyQueue.push(func);
3416
+ }
3417
+ return true;
3418
+ };
3419
+
3420
+
3421
+ // Triggers given input event(s) (e.g. 'input' or 'change') on all color pickers.
3422
+ //
3423
+ // It is possible to specify multiple events separated with a space.
3424
+ // If called before jscolor is initialized, then the events will be triggered after initialization.
3425
+ //
3426
+ jsc.pub.trigger = function (eventNames) {
3427
+ var triggerNow = function () {
3428
+ jsc.triggerGlobal(eventNames);
3429
+ };
3430
+
3431
+ if (jsc.initialized) {
3432
+ triggerNow();
3433
+ } else {
3434
+ jsc.pub.ready(triggerNow);
3435
+ }
3436
+ };
3437
+
3438
+
3439
+ // Hides current color picker box
3440
+ jsc.pub.hide = function () {
3441
+ if (jsc.picker && jsc.picker.owner) {
3442
+ jsc.picker.owner.hide();
3443
+ }
3444
+ };
3445
+
3446
+
3447
+ // Returns a data URL of a gray chessboard image that indicates transparency
3448
+ jsc.pub.chessboard = function (color) {
3449
+ if (!color) {
3450
+ color = 'rgba(0,0,0,0)';
3451
+ }
3452
+ var preview = jsc.genColorPreviewCanvas(color);
3453
+ return preview.canvas.toDataURL();
3454
+ };
3455
+
3456
+
3457
+ // Returns a data URL of a gray chessboard image that indicates transparency
3458
+ jsc.pub.background = function (color) {
3459
+ var backgrounds = [];
3460
+
3461
+ // CSS gradient for background color preview
3462
+ backgrounds.push(jsc.genColorPreviewGradient(color));
3463
+
3464
+ // data URL of generated PNG image with a gray transparency chessboard
3465
+ var preview = jsc.genColorPreviewCanvas();
3466
+ backgrounds.push([
3467
+ 'url(\'' + preview.canvas.toDataURL() + '\')',
3468
+ 'left top',
3469
+ 'repeat',
3470
+ ].join(' '));
3471
+
3472
+ return backgrounds.join(', ');
3473
+ };
3474
+
3475
+
3476
+ //
3477
+ // DEPRECATED properties and methods
3478
+ //
3479
+
3480
+
3481
+ // DEPRECATED. Use jscolor.presets.default instead.
3482
+ //
3483
+ // Custom default options for all color pickers, e.g. { hash: true, width: 300 }
3484
+ jsc.pub.options = {};
3485
+
3486
+
3487
+ // DEPRECATED. Use data-jscolor attribute instead, which installs jscolor on given element.
3488
+ //
3489
+ // By default, we'll search for all elements with class="jscolor" and install a color picker on them.
3490
+ //
3491
+ // You can change what class name will be looked for by setting the property jscolor.lookupClass
3492
+ // anywhere in your HTML document. To completely disable the automatic lookup, set it to null.
3493
+ //
3494
+ jsc.pub.lookupClass = 'jscolor';
3495
+
3496
+
3497
+ // DEPRECATED. Use data-jscolor attribute instead, which installs jscolor on given element.
3498
+ //
3499
+ // Install jscolor on all elements that have the specified class name
3500
+ jsc.pub.installByClassName = function () {
3501
+ console.error('jscolor.installByClassName() is DEPRECATED. Use data-jscolor="" attribute instead of a class name.' + jsc.docsRef);
3502
+ return false;
3503
+ };
3504
+
3505
+
3506
+ jsc.register();
3507
+
3508
+
3509
+ return jsc.pub;
3510
+
3511
+
3512
+ })(); // END jscolor
3513
+
3514
+
3515
+ if (typeof window.jscolor === 'undefined') {
3516
+ window.jscolor = window.JSColor = jscolor;
3517
+ }
3518
+
3519
+
3520
+ // END jscolor code
3521
+
3522
+ return jscolor;
3523
+
3524
+ }); // END factory
js/jquery.mCustomScrollbar.concat.min.js CHANGED
@@ -1,4 +1,5 @@
1
- /*mousewheel*/
2
- (function(a){function d(b){var c=b||window.event,d=[].slice.call(arguments,1),e=0,f=!0,g=0,h=0;return b=a.event.fix(c),b.type="mousewheel",c.wheelDelta&&(e=c.wheelDelta/120),c.detail&&(e=-c.detail/3),h=e,c.axis!==undefined&&c.axis===c.HORIZONTAL_AXIS&&(h=0,g=-1*e),c.wheelDeltaY!==undefined&&(h=c.wheelDeltaY/120),c.wheelDeltaX!==undefined&&(g=-1*c.wheelDeltaX/120),d.unshift(b,e,g,h),(a.event.dispatch||a.event.handle).apply(this,d)}var b=["DOMMouseScroll","mousewheel"];if(a.event.fixHooks)for(var c=b.length;c;)a.event.fixHooks[b[--c]]=a.event.mouseHooks;a.event.special.mousewheel={setup:function(){if(this.addEventListener)for(var a=b.length;a;)this.addEventListener(b[--a],d,!1);else this.onmousewheel=d},teardown:function(){if(this.removeEventListener)for(var a=b.length;a;)this.removeEventListener(b[--a],d,!1);else this.onmousewheel=null}},a.fn.extend({mousewheel:function(a){return a?this.bind("mousewheel",a):this.trigger("mousewheel")},unmousewheel:function(a){return this.unbind("mousewheel",a)}})})(jQuery);
3
- /*custom scrollbar*/
4
- (function(c){var b={init:function(e){var f={set_width:false,set_height:false,horizontalScroll:false,scrollInertia:950,mouseWheel:true,mouseWheelPixels:"auto",autoDraggerLength:true,autoHideScrollbar:false,snapAmount:null,snapOffset:0,scrollButtons:{enable:false,scrollType:"continuous",scrollSpeed:"auto",scrollAmount:40},advanced:{updateOnBrowserResize:true,updateOnContentResize:false,autoExpandHorizontalScroll:false,autoScrollOnFocus:true,normalizeMouseWheelDelta:false},contentTouchScroll:true,callbacks:{onScrollStart:function(){},onScroll:function(){},onTotalScroll:function(){},onTotalScrollBack:function(){},onTotalScrollOffset:0,onTotalScrollBackOffset:0,whileScrolling:function(){}},theme:"light"},e=c.extend(true,f,e);return this.each(function(){var m=c(this);if(e.set_width){m.css("width",e.set_width)}if(e.set_height){m.css("height",e.set_height)}if(!c(document).data("mCustomScrollbar-index")){c(document).data("mCustomScrollbar-index","1")}else{var t=parseInt(c(document).data("mCustomScrollbar-index"));c(document).data("mCustomScrollbar-index",t+1)}m.wrapInner("<div class='mCustomScrollBox mCS-"+e.theme+"' id='mCSB_"+c(document).data("mCustomScrollbar-index")+"' style='position:relative; height:100%; overflow:hidden; max-width:100%;' />").addClass("mCustomScrollbar _mCS_"+c(document).data("mCustomScrollbar-index"));var g=m.children(".mCustomScrollBox");if(e.horizontalScroll){g.addClass("mCSB_horizontal").wrapInner("<div class='mCSB_h_wrapper' style='position:relative; left:0; width:999999px;' />");var k=g.children(".mCSB_h_wrapper");k.wrapInner("<div class='mCSB_container' style='position:absolute; left:0;' />").children(".mCSB_container").css({width:k.children().outerWidth(),position:"relative"}).unwrap()}else{g.wrapInner("<div class='mCSB_container' style='position:relative; top:0;' />")}var o=g.children(".mCSB_container");if(c.support.touch){o.addClass("mCS_touch")}o.after("<div class='mCSB_scrollTools' style='position:absolute;'><div class='mCSB_draggerContainer'><div class='mCSB_dragger' style='position:absolute;' oncontextmenu='return false;'><div class='mCSB_dragger_bar' style='position:relative;'></div></div><div class='mCSB_draggerRail'></div></div></div>");var l=g.children(".mCSB_scrollTools"),h=l.children(".mCSB_draggerContainer"),q=h.children(".mCSB_dragger");if(e.horizontalScroll){q.data("minDraggerWidth",q.width())}else{q.data("minDraggerHeight",q.height())}if(e.scrollButtons.enable){if(e.horizontalScroll){l.prepend("<a class='mCSB_buttonLeft' oncontextmenu='return false;'></a>").append("<a class='mCSB_buttonRight' oncontextmenu='return false;'></a>")}else{l.prepend("<a class='mCSB_buttonUp' oncontextmenu='return false;'></a>").append("<a class='mCSB_buttonDown' oncontextmenu='return false;'></a>")}}g.bind("scroll",function(){if(!m.is(".mCS_disabled")){g.scrollTop(0).scrollLeft(0)}});m.data({mCS_Init:true,mCustomScrollbarIndex:c(document).data("mCustomScrollbar-index"),horizontalScroll:e.horizontalScroll,scrollInertia:e.scrollInertia,scrollEasing:"mcsEaseOut",mouseWheel:e.mouseWheel,mouseWheelPixels:e.mouseWheelPixels,autoDraggerLength:e.autoDraggerLength,autoHideScrollbar:e.autoHideScrollbar,snapAmount:e.snapAmount,snapOffset:e.snapOffset,scrollButtons_enable:e.scrollButtons.enable,scrollButtons_scrollType:e.scrollButtons.scrollType,scrollButtons_scrollSpeed:e.scrollButtons.scrollSpeed,scrollButtons_scrollAmount:e.scrollButtons.scrollAmount,autoExpandHorizontalScroll:e.advanced.autoExpandHorizontalScroll,autoScrollOnFocus:e.advanced.autoScrollOnFocus,normalizeMouseWheelDelta:e.advanced.normalizeMouseWheelDelta,contentTouchScroll:e.contentTouchScroll,onScrollStart_Callback:e.callbacks.onScrollStart,onScroll_Callback:e.callbacks.onScroll,onTotalScroll_Callback:e.callbacks.onTotalScroll,onTotalScrollBack_Callback:e.callbacks.onTotalScrollBack,onTotalScroll_Offset:e.callbacks.onTotalScrollOffset,onTotalScrollBack_Offset:e.callbacks.onTotalScrollBackOffset,whileScrolling_Callback:e.callbacks.whileScrolling,bindEvent_scrollbar_drag:false,bindEvent_content_touch:false,bindEvent_scrollbar_click:false,bindEvent_mousewheel:false,bindEvent_buttonsContinuous_y:false,bindEvent_buttonsContinuous_x:false,bindEvent_buttonsPixels_y:false,bindEvent_buttonsPixels_x:false,bindEvent_focusin:false,bindEvent_autoHideScrollbar:false,mCSB_buttonScrollRight:false,mCSB_buttonScrollLeft:false,mCSB_buttonScrollDown:false,mCSB_buttonScrollUp:false});if(e.horizontalScroll){if(m.css("max-width")!=="none"){if(!e.advanced.updateOnContentResize){e.advanced.updateOnContentResize=true}}}else{if(m.css("max-height")!=="none"){var s=false,r=parseInt(m.css("max-height"));if(m.css("max-height").indexOf("%")>=0){s=r,r=m.parent().height()*s/100}m.css("overflow","hidden");g.css("max-height",r)}}m.mCustomScrollbar("update");if(e.advanced.updateOnBrowserResize){var i,j=c(window).width(),u=c(window).height();c(window).bind("resize."+m.data("mCustomScrollbarIndex"),function(){if(i){clearTimeout(i)}i=setTimeout(function(){if(!m.is(".mCS_disabled")&&!m.is(".mCS_destroyed")){var w=c(window).width(),v=c(window).height();if(j!==w||u!==v){if(m.css("max-height")!=="none"&&s){g.css("max-height",m.parent().height()*s/100)}m.mCustomScrollbar("update");j=w;u=v}}},150)})}if(e.advanced.updateOnContentResize){var p;if(e.horizontalScroll){var n=o.outerWidth()}else{var n=o.outerHeight()}p=setInterval(function(){if(e.horizontalScroll){if(e.advanced.autoExpandHorizontalScroll){o.css({position:"absolute",width:"auto"}).wrap("<div class='mCSB_h_wrapper' style='position:relative; left:0; width:999999px;' />").css({width:o.outerWidth(),position:"relative"}).unwrap()}var v=o.outerWidth()}else{var v=o.outerHeight()}if(v!=n){m.mCustomScrollbar("update");n=v}},300)}})},update:function(){var n=c(this),k=n.children(".mCustomScrollBox"),q=k.children(".mCSB_container");q.removeClass("mCS_no_scrollbar");n.removeClass("mCS_disabled mCS_destroyed");k.scrollTop(0).scrollLeft(0);var y=k.children(".mCSB_scrollTools"),o=y.children(".mCSB_draggerContainer"),m=o.children(".mCSB_dragger");if(n.data("horizontalScroll")){var A=y.children(".mCSB_buttonLeft"),t=y.children(".mCSB_buttonRight"),f=k.width();if(n.data("autoExpandHorizontalScroll")){q.css({position:"absolute",width:"auto"}).wrap("<div class='mCSB_h_wrapper' style='position:relative; left:0; width:999999px;' />").css({width:q.outerWidth(),position:"relative"}).unwrap()}var z=q.outerWidth()}else{var w=y.children(".mCSB_buttonUp"),g=y.children(".mCSB_buttonDown"),r=k.height(),i=q.outerHeight()}if(i>r&&!n.data("horizontalScroll")){y.css("display","block");var s=o.height();if(n.data("autoDraggerLength")){var u=Math.round(r/i*s),l=m.data("minDraggerHeight");if(u<=l){m.css({height:l})}else{if(u>=s-10){var p=s-10;m.css({height:p})}else{m.css({height:u})}}m.children(".mCSB_dragger_bar").css({"line-height":m.height()+"px"})}var B=m.height(),x=(i-r)/(s-B);n.data("scrollAmount",x).mCustomScrollbar("scrolling",k,q,o,m,w,g,A,t);var D=Math.abs(q.position().top);n.mCustomScrollbar("scrollTo",D,{scrollInertia:0,trigger:"internal"})}else{if(z>f&&n.data("horizontalScroll")){y.css("display","block");var h=o.width();if(n.data("autoDraggerLength")){var j=Math.round(f/z*h),C=m.data("minDraggerWidth");if(j<=C){m.css({width:C})}else{if(j>=h-10){var e=h-10;m.css({width:e})}else{m.css({width:j})}}}var v=m.width(),x=(z-f)/(h-v);n.data("scrollAmount",x).mCustomScrollbar("scrolling",k,q,o,m,w,g,A,t);var D=Math.abs(q.position().left);n.mCustomScrollbar("scrollTo",D,{scrollInertia:0,trigger:"internal"})}else{k.unbind("mousewheel focusin");if(n.data("horizontalScroll")){m.add(q).css("left",0)}else{m.add(q).css("top",0)}y.css("display","none");q.addClass("mCS_no_scrollbar");n.data({bindEvent_mousewheel:false,bindEvent_focusin:false})}}},scrolling:function(h,p,m,j,w,e,A,v){var k=c(this);if(!k.data("bindEvent_scrollbar_drag")){var n,o;if(c.support.msPointer){j.bind("MSPointerDown",function(H){H.preventDefault();k.data({on_drag:true});j.addClass("mCSB_dragger_onDrag");var G=c(this),J=G.offset(),F=H.originalEvent.pageX-J.left,I=H.originalEvent.pageY-J.top;if(F<G.width()&&F>0&&I<G.height()&&I>0){n=I;o=F}});c(document).bind("MSPointerMove."+k.data("mCustomScrollbarIndex"),function(H){H.preventDefault();if(k.data("on_drag")){var G=j,J=G.offset(),F=H.originalEvent.pageX-J.left,I=H.originalEvent.pageY-J.top;D(n,o,I,F)}}).bind("MSPointerUp."+k.data("mCustomScrollbarIndex"),function(x){k.data({on_drag:false});j.removeClass("mCSB_dragger_onDrag")})}else{j.bind("mousedown touchstart",function(H){H.preventDefault();H.stopImmediatePropagation();var G=c(this),K=G.offset(),F,J;if(H.type==="touchstart"){var I=H.originalEvent.touches[0]||H.originalEvent.changedTouches[0];F=I.pageX-K.left;J=I.pageY-K.top}else{k.data({on_drag:true});j.addClass("mCSB_dragger_onDrag");F=H.pageX-K.left;J=H.pageY-K.top}if(F<G.width()&&F>0&&J<G.height()&&J>0){n=J;o=F}}).bind("touchmove",function(H){H.preventDefault();H.stopImmediatePropagation();var K=H.originalEvent.touches[0]||H.originalEvent.changedTouches[0],G=c(this),J=G.offset(),F=K.pageX-J.left,I=K.pageY-J.top;D(n,o,I,F)});c(document).bind("mousemove."+k.data("mCustomScrollbarIndex"),function(H){if(k.data("on_drag")){var G=j,J=G.offset(),F=H.pageX-J.left,I=H.pageY-J.top;D(n,o,I,F)}}).bind("mouseup."+k.data("mCustomScrollbarIndex"),function(x){k.data({on_drag:false});j.removeClass("mCSB_dragger_onDrag")})}k.data({bindEvent_scrollbar_drag:true})}function D(G,H,I,F){if(k.data("horizontalScroll")){k.mCustomScrollbar("scrollTo",(j.position().left-(H))+F,{moveDragger:true,trigger:"internal"})}else{k.mCustomScrollbar("scrollTo",(j.position().top-(G))+I,{moveDragger:true,trigger:"internal"})}}if(c.support.touch&&k.data("contentTouchScroll")){if(!k.data("bindEvent_content_touch")){var l,B,r,s,u,C,E;p.bind("touchstart",function(x){x.stopImmediatePropagation();l=x.originalEvent.touches[0]||x.originalEvent.changedTouches[0];B=c(this);r=B.offset();u=l.pageX-r.left;s=l.pageY-r.top;C=s;E=u});p.bind("touchmove",function(x){x.preventDefault();x.stopImmediatePropagation();l=x.originalEvent.touches[0]||x.originalEvent.changedTouches[0];B=c(this).parent();r=B.offset();u=l.pageX-r.left;s=l.pageY-r.top;if(k.data("horizontalScroll")){k.mCustomScrollbar("scrollTo",E-u,{trigger:"internal"})}else{k.mCustomScrollbar("scrollTo",C-s,{trigger:"internal"})}})}}if(!k.data("bindEvent_scrollbar_click")){m.bind("click",function(F){var x=(F.pageY-m.offset().top)*k.data("scrollAmount"),y=c(F.target);if(k.data("horizontalScroll")){x=(F.pageX-m.offset().left)*k.data("scrollAmount")}if(y.hasClass("mCSB_draggerContainer")||y.hasClass("mCSB_draggerRail")){k.mCustomScrollbar("scrollTo",x,{trigger:"internal",scrollEasing:"draggerRailEase"})}});k.data({bindEvent_scrollbar_click:true})}if(k.data("mouseWheel")){if(!k.data("bindEvent_mousewheel")){h.bind("mousewheel",function(H,J){var G,F=k.data("mouseWheelPixels"),x=Math.abs(p.position().top),I=j.position().top,y=m.height()-j.height();if(k.data("normalizeMouseWheelDelta")){if(J<0){J=-1}else{J=1}}if(F==="auto"){F=100+Math.round(k.data("scrollAmount")/2)}if(k.data("horizontalScroll")){I=j.position().left;y=m.width()-j.width();x=Math.abs(p.position().left)}if((J>0&&I!==0)||(J<0&&I!==y)){H.preventDefault();H.stopImmediatePropagation()}G=x-(J*F);k.mCustomScrollbar("scrollTo",G,{trigger:"internal"})});k.data({bindEvent_mousewheel:true})}}if(k.data("scrollButtons_enable")){if(k.data("scrollButtons_scrollType")==="pixels"){if(k.data("horizontalScroll")){v.add(A).unbind("mousedown touchstart MSPointerDown mouseup MSPointerUp mouseout MSPointerOut touchend",i,g);k.data({bindEvent_buttonsContinuous_x:false});if(!k.data("bindEvent_buttonsPixels_x")){v.bind("click",function(x){x.preventDefault();q(Math.abs(p.position().left)+k.data("scrollButtons_scrollAmount"))});A.bind("click",function(x){x.preventDefault();q(Math.abs(p.position().left)-k.data("scrollButtons_scrollAmount"))});k.data({bindEvent_buttonsPixels_x:true})}}else{e.add(w).unbind("mousedown touchstart MSPointerDown mouseup MSPointerUp mouseout MSPointerOut touchend",i,g);k.data({bindEvent_buttonsContinuous_y:false});if(!k.data("bindEvent_buttonsPixels_y")){e.bind("click",function(x){x.preventDefault();q(Math.abs(p.position().top)+k.data("scrollButtons_scrollAmount"))});w.bind("click",function(x){x.preventDefault();q(Math.abs(p.position().top)-k.data("scrollButtons_scrollAmount"))});k.data({bindEvent_buttonsPixels_y:true})}}function q(x){if(!j.data("preventAction")){j.data("preventAction",true);k.mCustomScrollbar("scrollTo",x,{trigger:"internal"})}}}else{if(k.data("horizontalScroll")){v.add(A).unbind("click");k.data({bindEvent_buttonsPixels_x:false});if(!k.data("bindEvent_buttonsContinuous_x")){v.bind("mousedown touchstart MSPointerDown",function(y){y.preventDefault();var x=z();k.data({mCSB_buttonScrollRight:setInterval(function(){k.mCustomScrollbar("scrollTo",Math.abs(p.position().left)+x,{trigger:"internal",scrollEasing:"easeOutCirc"})},17)})});var i=function(x){x.preventDefault();clearInterval(k.data("mCSB_buttonScrollRight"))};v.bind("mouseup touchend MSPointerUp mouseout MSPointerOut",i);A.bind("mousedown touchstart MSPointerDown",function(y){y.preventDefault();var x=z();k.data({mCSB_buttonScrollLeft:setInterval(function(){k.mCustomScrollbar("scrollTo",Math.abs(p.position().left)-x,{trigger:"internal",scrollEasing:"easeOutCirc"})},17)})});var g=function(x){x.preventDefault();clearInterval(k.data("mCSB_buttonScrollLeft"))};A.bind("mouseup touchend MSPointerUp mouseout MSPointerOut",g);k.data({bindEvent_buttonsContinuous_x:true})}}else{e.add(w).unbind("click");k.data({bindEvent_buttonsPixels_y:false});if(!k.data("bindEvent_buttonsContinuous_y")){e.bind("mousedown touchstart MSPointerDown",function(y){y.preventDefault();var x=z();k.data({mCSB_buttonScrollDown:setInterval(function(){k.mCustomScrollbar("scrollTo",Math.abs(p.position().top)+x,{trigger:"internal",scrollEasing:"easeOutCirc"})},17)})});var t=function(x){x.preventDefault();clearInterval(k.data("mCSB_buttonScrollDown"))};e.bind("mouseup touchend MSPointerUp mouseout MSPointerOut",t);w.bind("mousedown touchstart MSPointerDown",function(y){y.preventDefault();var x=z();k.data({mCSB_buttonScrollUp:setInterval(function(){k.mCustomScrollbar("scrollTo",Math.abs(p.position().top)-x,{trigger:"internal",scrollEasing:"easeOutCirc"})},17)})});var f=function(x){x.preventDefault();clearInterval(k.data("mCSB_buttonScrollUp"))};w.bind("mouseup touchend MSPointerUp mouseout MSPointerOut",f);k.data({bindEvent_buttonsContinuous_y:true})}}function z(){var x=k.data("scrollButtons_scrollSpeed");if(k.data("scrollButtons_scrollSpeed")==="auto"){x=Math.round((k.data("scrollInertia")+100)/40)}return x}}}if(k.data("autoScrollOnFocus")){if(!k.data("bindEvent_focusin")){h.bind("focusin",function(){h.scrollTop(0).scrollLeft(0);var x=c(document.activeElement);if(x.is("input,textarea,select,button,a[tabindex],area,object")){var G=p.position().top,y=x.position().top,F=h.height()-x.outerHeight();if(k.data("horizontalScroll")){G=p.position().left;y=x.position().left;F=h.width()-x.outerWidth()}if(G+y<0||G+y>F){k.mCustomScrollbar("scrollTo",y,{trigger:"internal"})}}});k.data({bindEvent_focusin:true})}}if(k.data("autoHideScrollbar")){if(!k.data("bindEvent_autoHideScrollbar")){h.bind("mouseenter",function(x){h.addClass("mCS-mouse-over");d.showScrollbar.call(h.children(".mCSB_scrollTools"))}).bind("mouseleave touchend",function(x){h.removeClass("mCS-mouse-over");if(x.type==="mouseleave"){d.hideScrollbar.call(h.children(".mCSB_scrollTools"))}});k.data({bindEvent_autoHideScrollbar:true})}}},scrollTo:function(e,f){var i=c(this),o={moveDragger:false,trigger:"external",callbacks:true,scrollInertia:i.data("scrollInertia"),scrollEasing:i.data("scrollEasing")},f=c.extend(o,f),p,g=i.children(".mCustomScrollBox"),k=g.children(".mCSB_container"),r=g.children(".mCSB_scrollTools"),j=r.children(".mCSB_draggerContainer"),h=j.children(".mCSB_dragger"),t=draggerSpeed=f.scrollInertia,q,s,m,l;if(!k.hasClass("mCS_no_scrollbar")){i.data({mCS_trigger:f.trigger});if(i.data("mCS_Init")){f.callbacks=false}if(e||e===0){if(typeof(e)==="number"){if(f.moveDragger){p=e;if(i.data("horizontalScroll")){e=h.position().left*i.data("scrollAmount")}else{e=h.position().top*i.data("scrollAmount")}draggerSpeed=0}else{p=e/i.data("scrollAmount")}}else{if(typeof(e)==="string"){var v;if(e==="top"){v=0}else{if(e==="bottom"&&!i.data("horizontalScroll")){v=k.outerHeight()-g.height()}else{if(e==="left"){v=0}else{if(e==="right"&&i.data("horizontalScroll")){v=k.outerWidth()-g.width()}else{if(e==="first"){v=i.find(".mCSB_container").find(":first")}else{if(e==="last"){v=i.find(".mCSB_container").find(":last")}else{v=i.find(e)}}}}}}if(v.length===1){if(i.data("horizontalScroll")){e=v.position().left}else{e=v.position().top}p=e/i.data("scrollAmount")}else{p=e=v}}}if(i.data("horizontalScroll")){if(i.data("onTotalScrollBack_Offset")){s=-i.data("onTotalScrollBack_Offset")}if(i.data("onTotalScroll_Offset")){l=g.width()-k.outerWidth()+i.data("onTotalScroll_Offset")}if(p<0){p=e=0;clearInterval(i.data("mCSB_buttonScrollLeft"));if(!s){q=true}}else{if(p>=j.width()-h.width()){p=j.width()-h.width();e=g.width()-k.outerWidth();clearInterval(i.data("mCSB_buttonScrollRight"));if(!l){m=true}}else{e=-e}}var n=i.data("snapAmount");if(n){e=Math.round(e/n)*n-i.data("snapOffset")}d.mTweenAxis.call(this,h[0],"left",Math.round(p),draggerSpeed,f.scrollEasing);d.mTweenAxis.call(this,k[0],"left",Math.round(e),t,f.scrollEasing,{onStart:function(){if(f.callbacks&&!i.data("mCS_tweenRunning")){u("onScrollStart")}if(i.data("autoHideScrollbar")){d.showScrollbar.call(r)}},onUpdate:function(){if(f.callbacks){u("whileScrolling")}},onComplete:function(){if(f.callbacks){u("onScroll");if(q||(s&&k.position().left>=s)){u("onTotalScrollBack")}if(m||(l&&k.position().left<=l)){u("onTotalScroll")}}h.data("preventAction",false);i.data("mCS_tweenRunning",false);if(i.data("autoHideScrollbar")){if(!g.hasClass("mCS-mouse-over")){d.hideScrollbar.call(r)}}}})}else{if(i.data("onTotalScrollBack_Offset")){s=-i.data("onTotalScrollBack_Offset")}if(i.data("onTotalScroll_Offset")){l=g.height()-k.outerHeight()+i.data("onTotalScroll_Offset")}if(p<0){p=e=0;clearInterval(i.data("mCSB_buttonScrollUp"));if(!s){q=true}}else{if(p>=j.height()-h.height()){p=j.height()-h.height();e=g.height()-k.outerHeight();clearInterval(i.data("mCSB_buttonScrollDown"));if(!l){m=true}}else{e=-e}}var n=i.data("snapAmount");if(n){e=Math.round(e/n)*n-i.data("snapOffset")}d.mTweenAxis.call(this,h[0],"top",Math.round(p),draggerSpeed,f.scrollEasing);d.mTweenAxis.call(this,k[0],"top",Math.round(e),t,f.scrollEasing,{onStart:function(){if(f.callbacks&&!i.data("mCS_tweenRunning")){u("onScrollStart")}if(i.data("autoHideScrollbar")){d.showScrollbar.call(r)}},onUpdate:function(){if(f.callbacks){u("whileScrolling")}},onComplete:function(){if(f.callbacks){u("onScroll");if(q||(s&&k.position().top>=s)){u("onTotalScrollBack")}if(m||(l&&k.position().top<=l)){u("onTotalScroll")}}h.data("preventAction",false);i.data("mCS_tweenRunning",false);if(i.data("autoHideScrollbar")){if(!g.hasClass("mCS-mouse-over")){d.hideScrollbar.call(r)}}}})}if(i.data("mCS_Init")){i.data({mCS_Init:false})}}}function u(w){this.mcs={top:k.position().top,left:k.position().left,draggerTop:h.position().top,draggerLeft:h.position().left,topPct:Math.round((100*Math.abs(k.position().top))/Math.abs(k.outerHeight()-g.height())),leftPct:Math.round((100*Math.abs(k.position().left))/Math.abs(k.outerWidth()-g.width()))};switch(w){case"onScrollStart":i.data("mCS_tweenRunning",true).data("onScrollStart_Callback").call(i,this.mcs);break;case"whileScrolling":i.data("whileScrolling_Callback").call(i,this.mcs);break;case"onScroll":i.data("onScroll_Callback").call(i,this.mcs);break;case"onTotalScrollBack":i.data("onTotalScrollBack_Callback").call(i,this.mcs);break;case"onTotalScroll":i.data("onTotalScroll_Callback").call(i,this.mcs);break}}},stop:function(){var g=c(this),e=g.children().children(".mCSB_container"),f=g.children().children().children().children(".mCSB_dragger");d.mTweenAxisStop.call(this,e[0]);d.mTweenAxisStop.call(this,f[0])},disable:function(e){var j=c(this),f=j.children(".mCustomScrollBox"),h=f.children(".mCSB_container"),g=f.children(".mCSB_scrollTools"),i=g.children().children(".mCSB_dragger");f.unbind("mousewheel focusin mouseenter mouseleave touchend");h.unbind("touchstart touchmove");if(e){if(j.data("horizontalScroll")){i.add(h).css("left",0)}else{i.add(h).css("top",0)}}g.css("display","none");h.addClass("mCS_no_scrollbar");j.data({bindEvent_mousewheel:false,bindEvent_focusin:false,bindEvent_content_touch:false,bindEvent_autoHideScrollbar:false}).addClass("mCS_disabled")},destroy:function(){var e=c(this);e.removeClass("mCustomScrollbar _mCS_"+e.data("mCustomScrollbarIndex")).addClass("mCS_destroyed").children().children(".mCSB_container").unwrap().children().unwrap().siblings(".mCSB_scrollTools").remove();c(document).unbind("mousemove."+e.data("mCustomScrollbarIndex")+" mouseup."+e.data("mCustomScrollbarIndex")+" MSPointerMove."+e.data("mCustomScrollbarIndex")+" MSPointerUp."+e.data("mCustomScrollbarIndex"));c(window).unbind("resize."+e.data("mCustomScrollbarIndex"))}},d={showScrollbar:function(){this.stop().animate({opacity:1},"fast")},hideScrollbar:function(){this.stop().animate({opacity:0},"fast")},mTweenAxis:function(g,i,h,f,o,y){var y=y||{},v=y.onStart||function(){},p=y.onUpdate||function(){},w=y.onComplete||function(){};var n=t(),l,j=0,r=g.offsetTop,s=g.style;if(i==="left"){r=g.offsetLeft}var m=h-r;q();e();function t(){if(window.performance&&window.performance.now){return window.performance.now()}else{if(window.performance&&window.performance.webkitNow){return window.performance.webkitNow()}else{if(Date.now){return Date.now()}else{return new Date().getTime()}}}}function x(){if(!j){v.call()}j=t()-n;u();if(j>=g._time){g._time=(j>g._time)?j+l-(j-g._time):j+l-1;if(g._time<j+1){g._time=j+1}}if(g._time<f){g._id=_request(x)}else{w.call()}}function u(){if(f>0){g.currVal=k(g._time,r,m,f,o);s[i]=Math.round(g.currVal)+"px"}else{s[i]=h+"px"}p.call()}function e(){l=1000/60;g._time=j+l;_request=(!window.requestAnimationFrame)?function(z){u();return setTimeout(z,0.01)}:window.requestAnimationFrame;g._id=_request(x)}function q(){if(g._id==null){return}if(!window.requestAnimationFrame){clearTimeout(g._id)}else{window.cancelAnimationFrame(g._id)}g._id=null}function k(B,A,F,E,C){switch(C){case"linear":return F*B/E+A;break;case"easeOutQuad":B/=E;return -F*B*(B-2)+A;break;case"easeInOutQuad":B/=E/2;if(B<1){return F/2*B*B+A}B--;return -F/2*(B*(B-2)-1)+A;break;case"easeOutCubic":B/=E;B--;return F*(B*B*B+1)+A;break;case"easeOutQuart":B/=E;B--;return -F*(B*B*B*B-1)+A;break;case"easeOutQuint":B/=E;B--;return F*(B*B*B*B*B+1)+A;break;case"easeOutCirc":B/=E;B--;return F*Math.sqrt(1-B*B)+A;break;case"easeOutSine":return F*Math.sin(B/E*(Math.PI/2))+A;break;case"easeOutExpo":return F*(-Math.pow(2,-10*B/E)+1)+A;break;case"mcsEaseOut":var D=(B/=E)*B,z=D*B;return A+F*(0.499999999999997*z*D+-2.5*D*D+5.5*z+-6.5*D+4*B);break;case"draggerRailEase":B/=E/2;if(B<1){return F/2*B*B*B+A}B-=2;return F/2*(B*B*B+2)+A;break}}},mTweenAxisStop:function(e){if(e._id==null){return}if(!window.requestAnimationFrame){clearTimeout(e._id)}else{window.cancelAnimationFrame(e._id)}e._id=null},rafPolyfill:function(){var f=["ms","moz","webkit","o"],e=f.length;while(--e>-1&&!window.requestAnimationFrame){window.requestAnimationFrame=window[f[e]+"RequestAnimationFrame"];window.cancelAnimationFrame=window[f[e]+"CancelAnimationFrame"]||window[f[e]+"CancelRequestAnimationFrame"]}}};d.rafPolyfill.call();c.support.touch=!!("ontouchstart" in window);c.support.msPointer=window.navigator.msPointerEnabled;var a=("https:"==document.location.protocol)?"https:":"http:";c.event.special.mousewheel||document.write('<script src="'+a+'//cdnjs.cloudflare.com/ajax/libs/jquery-mousewheel/3.0.6/jquery.mousewheel.min.js"><\/script>');c.fn.mCustomScrollbar=function(e){if(b[e]){return b[e].apply(this,Array.prototype.slice.call(arguments,1))}else{if(typeof e==="object"||!e){return b.init.apply(this,arguments)}else{c.error("Method "+e+" does not exist")}}}})(jQuery);
 
1
+ /* == jquery mousewheel plugin == Version: 3.1.15, License: MIT License (MIT) */
2
+ !function(a){"function"==typeof define&&define.amd?define(["jquery"],a):"object"==typeof exports?module.exports=a:a(jQuery)}(function(a){function b(b){var g=b||window.event,h=i.call(arguments,1),j=0,l=0,m=0,n=0,o=0,p=0;if(b=a.event.fix(g),b.type="mousewheel","detail"in g&&(m=-1*g.detail),"wheelDelta"in g&&(m=g.wheelDelta),"wheelDeltaY"in g&&(m=g.wheelDeltaY),"wheelDeltaX"in g&&(l=-1*g.wheelDeltaX),"axis"in g&&g.axis===g.HORIZONTAL_AXIS&&(l=-1*m,m=0),j=0===m?l:m,"deltaY"in g&&(m=-1*g.deltaY,j=m),"deltaX"in g&&(l=g.deltaX,0===m&&(j=-1*l)),0!==m||0!==l){if(1===g.deltaMode){var q=a.data(this,"mousewheel-line-height");j*=q,m*=q,l*=q}else if(2===g.deltaMode){var r=a.data(this,"mousewheel-page-height");j*=r,m*=r,l*=r}if(n=Math.max(Math.abs(m),Math.abs(l)),(!f||f>n)&&(f=n,d(g,n)&&(f/=40)),d(g,n)&&(j/=40,l/=40,m/=40),j=Math[j>=1?"floor":"ceil"](j/f),l=Math[l>=1?"floor":"ceil"](l/f),m=Math[m>=1?"floor":"ceil"](m/f),k.settings.normalizeOffset&&this.getBoundingClientRect){var s=this.getBoundingClientRect();o=b.clientX-s.left,p=b.clientY-s.top}return b.deltaX=l,b.deltaY=m,b.deltaFactor=f,b.offsetX=o,b.offsetY=p,b.deltaMode=0,h.unshift(b,j,l,m),e&&clearTimeout(e),e=setTimeout(c,200),(a.event.dispatch||a.event.handle).apply(this,h)}}function c(){f=null}function d(a,b){return k.settings.adjustOldDeltas&&"mousewheel"===a.type&&b%120===0}var e,f,g=["wheel","mousewheel","DOMMouseScroll","MozMousePixelScroll"],h="onwheel"in document||document.documentMode>=9?["wheel"]:["mousewheel","DomMouseScroll","MozMousePixelScroll"],i=Array.prototype.slice;if(a.event.fixHooks)for(var j=g.length;j;)a.event.fixHooks[g[--j]]=a.event.mouseHooks;var k=a.event.special.mousewheel={version:"3.1.12",setup:function(){if(this.addEventListener)for(var c=h.length;c;)this.addEventListener(h[--c],b,!1);else this.onmousewheel=b;a.data(this,"mousewheel-line-height",k.getLineHeight(this)),a.data(this,"mousewheel-page-height",k.getPageHeight(this))},teardown:function(){if(this.removeEventListener)for(var c=h.length;c;)this.removeEventListener(h[--c],b,!1);else this.onmousewheel=null;a.removeData(this,"mousewheel-line-height"),a.removeData(this,"mousewheel-page-height")},getLineHeight:function(b){var c=a(b),d=c["offsetParent"in a.fn?"offsetParent":"parent"]();return d.length||(d=a("body")),parseInt(d.css("fontSize"),10)||parseInt(c.css("fontSize"),10)||16},getPageHeight:function(b){return a(b).height()},settings:{adjustOldDeltas:!0,normalizeOffset:!0}};a.fn.extend({mousewheel:function(a){return a?this.bind("mousewheel",a):this.trigger("mousewheel")},unmousewheel:function(a){return this.unbind("mousewheel",a)}})});!function(a){"function"==typeof define&&define.amd?define(["jquery"],a):"object"==typeof exports?module.exports=a:a(jQuery)}(function(a){function b(b){var g=b||window.event,h=i.call(arguments,1),j=0,l=0,m=0,n=0,o=0,p=0;if(b=a.event.fix(g),b.type="mousewheel","detail"in g&&(m=-1*g.detail),"wheelDelta"in g&&(m=g.wheelDelta),"wheelDeltaY"in g&&(m=g.wheelDeltaY),"wheelDeltaX"in g&&(l=-1*g.wheelDeltaX),"axis"in g&&g.axis===g.HORIZONTAL_AXIS&&(l=-1*m,m=0),j=0===m?l:m,"deltaY"in g&&(m=-1*g.deltaY,j=m),"deltaX"in g&&(l=g.deltaX,0===m&&(j=-1*l)),0!==m||0!==l){if(1===g.deltaMode){var q=a.data(this,"mousewheel-line-height");j*=q,m*=q,l*=q}else if(2===g.deltaMode){var r=a.data(this,"mousewheel-page-height");j*=r,m*=r,l*=r}if(n=Math.max(Math.abs(m),Math.abs(l)),(!f||f>n)&&(f=n,d(g,n)&&(f/=40)),d(g,n)&&(j/=40,l/=40,m/=40),j=Math[j>=1?"floor":"ceil"](j/f),l=Math[l>=1?"floor":"ceil"](l/f),m=Math[m>=1?"floor":"ceil"](m/f),k.settings.normalizeOffset&&this.getBoundingClientRect){var s=this.getBoundingClientRect();o=b.clientX-s.left,p=b.clientY-s.top}return b.deltaX=l,b.deltaY=m,b.deltaFactor=f,b.offsetX=o,b.offsetY=p,b.deltaMode=0,h.unshift(b,j,l,m),e&&clearTimeout(e),e=setTimeout(c,200),(a.event.dispatch||a.event.handle).apply(this,h)}}function c(){f=null}function d(a,b){return k.settings.adjustOldDeltas&&"mousewheel"===a.type&&b%120===0}var e,f,g=["wheel","mousewheel","DOMMouseScroll","MozMousePixelScroll"],h="onwheel"in document||document.documentMode>=9?["wheel"]:["mousewheel","DomMouseScroll","MozMousePixelScroll"],i=Array.prototype.slice;if(a.event.fixHooks)for(var j=g.length;j;)a.event.fixHooks[g[--j]]=a.event.mouseHooks;var k=a.event.special.mousewheel={version:"3.1.12",setup:function(){if(this.addEventListener)for(var c=h.length;c;)this.addEventListener(h[--c],b,!1);else this.onmousewheel=b;a.data(this,"mousewheel-line-height",k.getLineHeight(this)),a.data(this,"mousewheel-page-height",k.getPageHeight(this))},teardown:function(){if(this.removeEventListener)for(var c=h.length;c;)this.removeEventListener(h[--c],b,!1);else this.onmousewheel=null;a.removeData(this,"mousewheel-line-height"),a.removeData(this,"mousewheel-page-height")},getLineHeight:function(b){var c=a(b),d=c["offsetParent"in a.fn?"offsetParent":"parent"]();return d.length||(d=a("body")),parseInt(d.css("fontSize"),10)||parseInt(c.css("fontSize"),10)||16},getPageHeight:function(b){return a(b).height()},settings:{adjustOldDeltas:!0,normalizeOffset:!0}};a.fn.extend({mousewheel:function(a){return a?this.bind("mousewheel",a):this.trigger("mousewheel")},unmousewheel:function(a){return this.unbind("mousewheel",a)}})});
3
+ /* == malihu jquery custom scrollbar plugin == Version: 3.1.5, License: MIT License (MIT) */
4
+ !function(e){"function"==typeof define&&define.amd?define(["jquery"],e):"undefined"!=typeof module&&module.exports?module.exports=e:e(jQuery,window,document)}(function(e){!function(t){var o="function"==typeof define&&define.amd,a="undefined"!=typeof module&&module.exports,n="https:"==document.location.protocol?"https:":"http:",i="cdnjs.cloudflare.com/ajax/libs/jquery-mousewheel/3.1.13/jquery.mousewheel.min.js";o||(a?require("jquery-mousewheel")(e):e.event.special.mousewheel||e("head").append(decodeURI("%3Cscript src="+n+"//"+i+"%3E%3C/script%3E"))),t()}(function(){var t,o="mCustomScrollbar",a="mCS",n=".mCustomScrollbar",i={setTop:0,setLeft:0,axis:"y",scrollbarPosition:"inside",scrollInertia:950,autoDraggerLength:!0,alwaysShowScrollbar:0,snapOffset:0,mouseWheel:{enable:!0,scrollAmount:"auto",axis:"y",deltaFactor:"auto",disableOver:["select","option","keygen","datalist","textarea"]},scrollButtons:{scrollType:"stepless",scrollAmount:"auto"},keyboard:{enable:!0,scrollType:"stepless",scrollAmount:"auto"},contentTouchScroll:25,documentTouchScroll:!0,advanced:{autoScrollOnFocus:"input,textarea,select,button,datalist,keygen,a[tabindex],area,object,[contenteditable='true']",updateOnContentResize:!0,updateOnImageLoad:"auto",autoUpdateTimeout:60},theme:"light",callbacks:{onTotalScrollOffset:0,onTotalScrollBackOffset:0,alwaysTriggerOffsets:!0}},r=0,l={},s=window.attachEvent&&!window.addEventListener?1:0,c=!1,d=["mCSB_dragger_onDrag","mCSB_scrollTools_onDrag","mCS_img_loaded","mCS_disabled","mCS_destroyed","mCS_no_scrollbar","mCS-autoHide","mCS-dir-rtl","mCS_no_scrollbar_y","mCS_no_scrollbar_x","mCS_y_hidden","mCS_x_hidden","mCSB_draggerContainer","mCSB_buttonUp","mCSB_buttonDown","mCSB_buttonLeft","mCSB_buttonRight"],u={init:function(t){var t=e.extend(!0,{},i,t),o=f.call(this);if(t.live){var s=t.liveSelector||this.selector||n,c=e(s);if("off"===t.live)return void m(s);l[s]=setTimeout(function(){c.mCustomScrollbar(t),"once"===t.live&&c.length&&m(s)},500)}else m(s);return t.setWidth=t.set_width?t.set_width:t.setWidth,t.setHeight=t.set_height?t.set_height:t.setHeight,t.axis=t.horizontalScroll?"x":p(t.axis),t.scrollInertia=t.scrollInertia>0&&t.scrollInertia<17?17:t.scrollInertia,"object"!=typeof t.mouseWheel&&1==t.mouseWheel&&(t.mouseWheel={enable:!0,scrollAmount:"auto",axis:"y",preventDefault:!1,deltaFactor:"auto",normalizeDelta:!1,invert:!1}),t.mouseWheel.scrollAmount=t.mouseWheelPixels?t.mouseWheelPixels:t.mouseWheel.scrollAmount,t.mouseWheel.normalizeDelta=t.advanced.normalizeMouseWheelDelta?t.advanced.normalizeMouseWheelDelta:t.mouseWheel.normalizeDelta,t.scrollButtons.scrollType=g(t.scrollButtons.scrollType),h(t),e(o).each(function(){var o=e(this);if(!o.data(a)){o.data(a,{idx:++r,opt:t,scrollRatio:{y:null,x:null},overflowed:null,contentReset:{y:null,x:null},bindEvents:!1,tweenRunning:!1,sequential:{},langDir:o.css("direction"),cbOffsets:null,trigger:null,poll:{size:{o:0,n:0},img:{o:0,n:0},change:{o:0,n:0}}});var n=o.data(a),i=n.opt,l=o.data("mcs-axis"),s=o.data("mcs-scrollbar-position"),c=o.data("mcs-theme");l&&(i.axis=l),s&&(i.scrollbarPosition=s),c&&(i.theme=c,h(i)),v.call(this),n&&i.callbacks.onCreate&&"function"==typeof i.callbacks.onCreate&&i.callbacks.onCreate.call(this),e("#mCSB_"+n.idx+"_container img:not(."+d[2]+")").addClass(d[2]),u.update.call(null,o)}})},update:function(t,o){var n=t||f.call(this);return e(n).each(function(){var t=e(this);if(t.data(a)){var n=t.data(a),i=n.opt,r=e("#mCSB_"+n.idx+"_container"),l=e("#mCSB_"+n.idx),s=[e("#mCSB_"+n.idx+"_dragger_vertical"),e("#mCSB_"+n.idx+"_dragger_horizontal")];if(!r.length)return;n.tweenRunning&&Q(t),o&&n&&i.callbacks.onBeforeUpdate&&"function"==typeof i.callbacks.onBeforeUpdate&&i.callbacks.onBeforeUpdate.call(this),t.hasClass(d[3])&&t.removeClass(d[3]),t.hasClass(d[4])&&t.removeClass(d[4]),l.css("max-height","none"),l.height()!==t.height()&&l.css("max-height",t.height()),_.call(this),"y"===i.axis||i.advanced.autoExpandHorizontalScroll||r.css("width",x(r)),n.overflowed=y.call(this),M.call(this),i.autoDraggerLength&&S.call(this),b.call(this),T.call(this);var c=[Math.abs(r[0].offsetTop),Math.abs(r[0].offsetLeft)];"x"!==i.axis&&(n.overflowed[0]?s[0].height()>s[0].parent().height()?B.call(this):(G(t,c[0].toString(),{dir:"y",dur:0,overwrite:"none"}),n.contentReset.y=null):(B.call(this),"y"===i.axis?k.call(this):"yx"===i.axis&&n.overflowed[1]&&G(t,c[1].toString(),{dir:"x",dur:0,overwrite:"none"}))),"y"!==i.axis&&(n.overflowed[1]?s[1].width()>s[1].parent().width()?B.call(this):(G(t,c[1].toString(),{dir:"x",dur:0,overwrite:"none"}),n.contentReset.x=null):(B.call(this),"x"===i.axis?k.call(this):"yx"===i.axis&&n.overflowed[0]&&G(t,c[0].toString(),{dir:"y",dur:0,overwrite:"none"}))),o&&n&&(2===o&&i.callbacks.onImageLoad&&"function"==typeof i.callbacks.onImageLoad?i.callbacks.onImageLoad.call(this):3===o&&i.callbacks.onSelectorChange&&"function"==typeof i.callbacks.onSelectorChange?i.callbacks.onSelectorChange.call(this):i.callbacks.onUpdate&&"function"==typeof i.callbacks.onUpdate&&i.callbacks.onUpdate.call(this)),N.call(this)}})},scrollTo:function(t,o){if("undefined"!=typeof t&&null!=t){var n=f.call(this);return e(n).each(function(){var n=e(this);if(n.data(a)){var i=n.data(a),r=i.opt,l={trigger:"external",scrollInertia:r.scrollInertia,scrollEasing:"mcsEaseInOut",moveDragger:!1,timeout:60,callbacks:!0,onStart:!0,onUpdate:!0,onComplete:!0},s=e.extend(!0,{},l,o),c=Y.call(this,t),d=s.scrollInertia>0&&s.scrollInertia<17?17:s.scrollInertia;c[0]=X.call(this,c[0],"y"),c[1]=X.call(this,c[1],"x"),s.moveDragger&&(c[0]*=i.scrollRatio.y,c[1]*=i.scrollRatio.x),s.dur=ne()?0:d,setTimeout(function(){null!==c[0]&&"undefined"!=typeof c[0]&&"x"!==r.axis&&i.overflowed[0]&&(s.dir="y",s.overwrite="all",G(n,c[0].toString(),s)),null!==c[1]&&"undefined"!=typeof c[1]&&"y"!==r.axis&&i.overflowed[1]&&(s.dir="x",s.overwrite="none",G(n,c[1].toString(),s))},s.timeout)}})}},stop:function(){var t=f.call(this);return e(t).each(function(){var t=e(this);t.data(a)&&Q(t)})},disable:function(t){var o=f.call(this);return e(o).each(function(){var o=e(this);if(o.data(a)){o.data(a);N.call(this,"remove"),k.call(this),t&&B.call(this),M.call(this,!0),o.addClass(d[3])}})},destroy:function(){var t=f.call(this);return e(t).each(function(){var n=e(this);if(n.data(a)){var i=n.data(a),r=i.opt,l=e("#mCSB_"+i.idx),s=e("#mCSB_"+i.idx+"_container"),c=e(".mCSB_"+i.idx+"_scrollbar");r.live&&m(r.liveSelector||e(t).selector),N.call(this,"remove"),k.call(this),B.call(this),n.removeData(a),$(this,"mcs"),c.remove(),s.find("img."+d[2]).removeClass(d[2]),l.replaceWith(s.contents()),n.removeClass(o+" _"+a+"_"+i.idx+" "+d[6]+" "+d[7]+" "+d[5]+" "+d[3]).addClass(d[4])}})}},f=function(){return"object"!=typeof e(this)||e(this).length<1?n:this},h=function(t){var o=["rounded","rounded-dark","rounded-dots","rounded-dots-dark"],a=["rounded-dots","rounded-dots-dark","3d","3d-dark","3d-thick","3d-thick-dark","inset","inset-dark","inset-2","inset-2-dark","inset-3","inset-3-dark"],n=["minimal","minimal-dark"],i=["minimal","minimal-dark"],r=["minimal","minimal-dark"];t.autoDraggerLength=e.inArray(t.theme,o)>-1?!1:t.autoDraggerLength,t.autoExpandScrollbar=e.inArray(t.theme,a)>-1?!1:t.autoExpandScrollbar,t.scrollButtons.enable=e.inArray(t.theme,n)>-1?!1:t.scrollButtons.enable,t.autoHideScrollbar=e.inArray(t.theme,i)>-1?!0:t.autoHideScrollbar,t.scrollbarPosition=e.inArray(t.theme,r)>-1?"outside":t.scrollbarPosition},m=function(e){l[e]&&(clearTimeout(l[e]),$(l,e))},p=function(e){return"yx"===e||"xy"===e||"auto"===e?"yx":"x"===e||"horizontal"===e?"x":"y"},g=function(e){return"stepped"===e||"pixels"===e||"step"===e||"click"===e?"stepped":"stepless"},v=function(){var t=e(this),n=t.data(a),i=n.opt,r=i.autoExpandScrollbar?" "+d[1]+"_expand":"",l=["<div id='mCSB_"+n.idx+"_scrollbar_vertical' class='mCSB_scrollTools mCSB_"+n.idx+"_scrollbar mCS-"+i.theme+" mCSB_scrollTools_vertical"+r+"'><div class='"+d[12]+"'><div id='mCSB_"+n.idx+"_dragger_vertical' class='mCSB_dragger' style='position:absolute;'><div class='mCSB_dragger_bar' /></div><div class='mCSB_draggerRail' /></div></div>","<div id='mCSB_"+n.idx+"_scrollbar_horizontal' class='mCSB_scrollTools mCSB_"+n.idx+"_scrollbar mCS-"+i.theme+" mCSB_scrollTools_horizontal"+r+"'><div class='"+d[12]+"'><div id='mCSB_"+n.idx+"_dragger_horizontal' class='mCSB_dragger' style='position:absolute;'><div class='mCSB_dragger_bar' /></div><div class='mCSB_draggerRail' /></div></div>"],s="yx"===i.axis?"mCSB_vertical_horizontal":"x"===i.axis?"mCSB_horizontal":"mCSB_vertical",c="yx"===i.axis?l[0]+l[1]:"x"===i.axis?l[1]:l[0],u="yx"===i.axis?"<div id='mCSB_"+n.idx+"_container_wrapper' class='mCSB_container_wrapper' />":"",f=i.autoHideScrollbar?" "+d[6]:"",h="x"!==i.axis&&"rtl"===n.langDir?" "+d[7]:"";i.setWidth&&t.css("width",i.setWidth),i.setHeight&&t.css("height",i.setHeight),i.setLeft="y"!==i.axis&&"rtl"===n.langDir?"989999px":i.setLeft,t.addClass(o+" _"+a+"_"+n.idx+f+h).wrapInner("<div id='mCSB_"+n.idx+"' class='mCustomScrollBox mCS-"+i.theme+" "+s+"'><div id='mCSB_"+n.idx+"_container' class='mCSB_container' style='position:relative; top:"+i.setTop+"; left:"+i.setLeft+";' dir='"+n.langDir+"' /></div>");var m=e("#mCSB_"+n.idx),p=e("#mCSB_"+n.idx+"_container");"y"===i.axis||i.advanced.autoExpandHorizontalScroll||p.css("width",x(p)),"outside"===i.scrollbarPosition?("static"===t.css("position")&&t.css("position","relative"),t.css("overflow","visible"),m.addClass("mCSB_outside").after(c)):(m.addClass("mCSB_inside").append(c),p.wrap(u)),w.call(this);var g=[e("#mCSB_"+n.idx+"_dragger_vertical"),e("#mCSB_"+n.idx+"_dragger_horizontal")];g[0].css("min-height",g[0].height()),g[1].css("min-width",g[1].width())},x=function(t){var o=[t[0].scrollWidth,Math.max.apply(Math,t.children().map(function(){return e(this).outerWidth(!0)}).get())],a=t.parent().width();return o[0]>a?o[0]:o[1]>a?o[1]:"100%"},_=function(){var t=e(this),o=t.data(a),n=o.opt,i=e("#mCSB_"+o.idx+"_container");if(n.advanced.autoExpandHorizontalScroll&&"y"!==n.axis){i.css({width:"auto","min-width":0,"overflow-x":"scroll"});var r=Math.ceil(i[0].scrollWidth);3===n.advanced.autoExpandHorizontalScroll||2!==n.advanced.autoExpandHorizontalScroll&&r>i.parent().width()?i.css({width:r,"min-width":"100%","overflow-x":"inherit"}):i.css({"overflow-x":"inherit",position:"absolute"}).wrap("<div class='mCSB_h_wrapper' style='position:relative; left:0; width:999999px;' />").css({width:Math.ceil(i[0].getBoundingClientRect().right+.4)-Math.floor(i[0].getBoundingClientRect().left),"min-width":"100%",position:"relative"}).unwrap()}},w=function(){var t=e(this),o=t.data(a),n=o.opt,i=e(".mCSB_"+o.idx+"_scrollbar:first"),r=oe(n.scrollButtons.tabindex)?"tabindex='"+n.scrollButtons.tabindex+"'":"",l=["<a href='#' class='"+d[13]+"' "+r+" />","<a href='#' class='"+d[14]+"' "+r+" />","<a href='#' class='"+d[15]+"' "+r+" />","<a href='#' class='"+d[16]+"' "+r+" />"],s=["x"===n.axis?l[2]:l[0],"x"===n.axis?l[3]:l[1],l[2],l[3]];n.scrollButtons.enable&&i.prepend(s[0]).append(s[1]).next(".mCSB_scrollTools").prepend(s[2]).append(s[3])},S=function(){var t=e(this),o=t.data(a),n=e("#mCSB_"+o.idx),i=e("#mCSB_"+o.idx+"_container"),r=[e("#mCSB_"+o.idx+"_dragger_vertical"),e("#mCSB_"+o.idx+"_dragger_horizontal")],l=[n.height()/i.outerHeight(!1),n.width()/i.outerWidth(!1)],c=[parseInt(r[0].css("min-height")),Math.round(l[0]*r[0].parent().height()),parseInt(r[1].css("min-width")),Math.round(l[1]*r[1].parent().width())],d=s&&c[1]<c[0]?c[0]:c[1],u=s&&c[3]<c[2]?c[2]:c[3];r[0].css({height:d,"max-height":r[0].parent().height()-10}).find(".mCSB_dragger_bar").css({"line-height":c[0]+"px"}),r[1].css({width:u,"max-width":r[1].parent().width()-10})},b=function(){var t=e(this),o=t.data(a),n=e("#mCSB_"+o.idx),i=e("#mCSB_"+o.idx+"_container"),r=[e("#mCSB_"+o.idx+"_dragger_vertical"),e("#mCSB_"+o.idx+"_dragger_horizontal")],l=[i.outerHeight(!1)-n.height(),i.outerWidth(!1)-n.width()],s=[l[0]/(r[0].parent().height()-r[0].height()),l[1]/(r[1].parent().width()-r[1].width())];o.scrollRatio={y:s[0],x:s[1]}},C=function(e,t,o){var a=o?d[0]+"_expanded":"",n=e.closest(".mCSB_scrollTools");"active"===t?(e.toggleClass(d[0]+" "+a),n.toggleClass(d[1]),e[0]._draggable=e[0]._draggable?0:1):e[0]._draggable||("hide"===t?(e.removeClass(d[0]),n.removeClass(d[1])):(e.addClass(d[0]),n.addClass(d[1])))},y=function(){var t=e(this),o=t.data(a),n=e("#mCSB_"+o.idx),i=e("#mCSB_"+o.idx+"_container"),r=null==o.overflowed?i.height():i.outerHeight(!1),l=null==o.overflowed?i.width():i.outerWidth(!1),s=i[0].scrollHeight,c=i[0].scrollWidth;return s>r&&(r=s),c>l&&(l=c),[r>n.height(),l>n.width()]},B=function(){var t=e(this),o=t.data(a),n=o.opt,i=e("#mCSB_"+o.idx),r=e("#mCSB_"+o.idx+"_container"),l=[e("#mCSB_"+o.idx+"_dragger_vertical"),e("#mCSB_"+o.idx+"_dragger_horizontal")];if(Q(t),("x"!==n.axis&&!o.overflowed[0]||"y"===n.axis&&o.overflowed[0])&&(l[0].add(r).css("top",0),G(t,"_resetY")),"y"!==n.axis&&!o.overflowed[1]||"x"===n.axis&&o.overflowed[1]){var s=dx=0;"rtl"===o.langDir&&(s=i.width()-r.outerWidth(!1),dx=Math.abs(s/o.scrollRatio.x)),r.css("left",s),l[1].css("left",dx),G(t,"_resetX")}},T=function(){function t(){r=setTimeout(function(){e.event.special.mousewheel?(clearTimeout(r),W.call(o[0])):t()},100)}var o=e(this),n=o.data(a),i=n.opt;if(!n.bindEvents){if(I.call(this),i.contentTouchScroll&&D.call(this),E.call(this),i.mouseWheel.enable){var r;t()}P.call(this),U.call(this),i.advanced.autoScrollOnFocus&&H.call(this),i.scrollButtons.enable&&F.call(this),i.keyboard.enable&&q.call(this),n.bindEvents=!0}},k=function(){var t=e(this),o=t.data(a),n=o.opt,i=a+"_"+o.idx,r=".mCSB_"+o.idx+"_scrollbar",l=e("#mCSB_"+o.idx+",#mCSB_"+o.idx+"_container,#mCSB_"+o.idx+"_container_wrapper,"+r+" ."+d[12]+",#mCSB_"+o.idx+"_dragger_vertical,#mCSB_"+o.idx+"_dragger_horizontal,"+r+">a"),s=e("#mCSB_"+o.idx+"_container");n.advanced.releaseDraggableSelectors&&l.add(e(n.advanced.releaseDraggableSelectors)),n.advanced.extraDraggableSelectors&&l.add(e(n.advanced.extraDraggableSelectors)),o.bindEvents&&(e(document).add(e(!A()||top.document)).unbind("."+i),l.each(function(){e(this).unbind("."+i)}),clearTimeout(t[0]._focusTimeout),$(t[0],"_focusTimeout"),clearTimeout(o.sequential.step),$(o.sequential,"step"),clearTimeout(s[0].onCompleteTimeout),$(s[0],"onCompleteTimeout"),o.bindEvents=!1)},M=function(t){var o=e(this),n=o.data(a),i=n.opt,r=e("#mCSB_"+n.idx+"_container_wrapper"),l=r.length?r:e("#mCSB_"+n.idx+"_container"),s=[e("#mCSB_"+n.idx+"_scrollbar_vertical"),e("#mCSB_"+n.idx+"_scrollbar_horizontal")],c=[s[0].find(".mCSB_dragger"),s[1].find(".mCSB_dragger")];"x"!==i.axis&&(n.overflowed[0]&&!t?(s[0].add(c[0]).add(s[0].children("a")).css("display","block"),l.removeClass(d[8]+" "+d[10])):(i.alwaysShowScrollbar?(2!==i.alwaysShowScrollbar&&c[0].css("display","none"),l.removeClass(d[10])):(s[0].css("display","none"),l.addClass(d[10])),l.addClass(d[8]))),"y"!==i.axis&&(n.overflowed[1]&&!t?(s[1].add(c[1]).add(s[1].children("a")).css("display","block"),l.removeClass(d[9]+" "+d[11])):(i.alwaysShowScrollbar?(2!==i.alwaysShowScrollbar&&c[1].css("display","none"),l.removeClass(d[11])):(s[1].css("display","none"),l.addClass(d[11])),l.addClass(d[9]))),n.overflowed[0]||n.overflowed[1]?o.removeClass(d[5]):o.addClass(d[5])},O=function(t){var o=t.type,a=t.target.ownerDocument!==document&&null!==frameElement?[e(frameElement).offset().top,e(frameElement).offset().left]:null,n=A()&&t.target.ownerDocument!==top.document&&null!==frameElement?[e(t.view.frameElement).offset().top,e(t.view.frameElement).offset().left]:[0,0];switch(o){case"pointerdown":case"MSPointerDown":case"pointermove":case"MSPointerMove":case"pointerup":case"MSPointerUp":return a?[t.originalEvent.pageY-a[0]+n[0],t.originalEvent.pageX-a[1]+n[1],!1]:[t.originalEvent.pageY,t.originalEvent.pageX,!1];case"touchstart":case"touchmove":case"touchend":var i=t.originalEvent.touches[0]||t.originalEvent.changedTouches[0],r=t.originalEvent.touches.length||t.originalEvent.changedTouches.length;return t.target.ownerDocument!==document?[i.screenY,i.screenX,r>1]:[i.pageY,i.pageX,r>1];default:return a?[t.pageY-a[0]+n[0],t.pageX-a[1]+n[1],!1]:[t.pageY,t.pageX,!1]}},I=function(){function t(e,t,a,n){if(h[0].idleTimer=d.scrollInertia<233?250:0,o.attr("id")===f[1])var i="x",s=(o[0].offsetLeft-t+n)*l.scrollRatio.x;else var i="y",s=(o[0].offsetTop-e+a)*l.scrollRatio.y;G(r,s.toString(),{dir:i,drag:!0})}var o,n,i,r=e(this),l=r.data(a),d=l.opt,u=a+"_"+l.idx,f=["mCSB_"+l.idx+"_dragger_vertical","mCSB_"+l.idx+"_dragger_horizontal"],h=e("#mCSB_"+l.idx+"_container"),m=e("#"+f[0]+",#"+f[1]),p=d.advanced.releaseDraggableSelectors?m.add(e(d.advanced.releaseDraggableSelectors)):m,g=d.advanced.extraDraggableSelectors?e(!A()||top.document).add(e(d.advanced.extraDraggableSelectors)):e(!A()||top.document);m.bind("contextmenu."+u,function(e){e.preventDefault()}).bind("mousedown."+u+" touchstart."+u+" pointerdown."+u+" MSPointerDown."+u,function(t){if(t.stopImmediatePropagation(),t.preventDefault(),ee(t)){c=!0,s&&(document.onselectstart=function(){return!1}),L.call(h,!1),Q(r),o=e(this);var a=o.offset(),l=O(t)[0]-a.top,u=O(t)[1]-a.left,f=o.height()+a.top,m=o.width()+a.left;f>l&&l>0&&m>u&&u>0&&(n=l,i=u),C(o,"active",d.autoExpandScrollbar)}}).bind("touchmove."+u,function(e){e.stopImmediatePropagation(),e.preventDefault();var a=o.offset(),r=O(e)[0]-a.top,l=O(e)[1]-a.left;t(n,i,r,l)}),e(document).add(g).bind("mousemove."+u+" pointermove."+u+" MSPointerMove."+u,function(e){if(o){var a=o.offset(),r=O(e)[0]-a.top,l=O(e)[1]-a.left;if(n===r&&i===l)return;t(n,i,r,l)}}).add(p).bind("mouseup."+u+" touchend."+u+" pointerup."+u+" MSPointerUp."+u,function(){o&&(C(o,"active",d.autoExpandScrollbar),o=null),c=!1,s&&(document.onselectstart=null),L.call(h,!0)})},D=function(){function o(e){if(!te(e)||c||O(e)[2])return void(t=0);t=1,b=0,C=0,d=1,y.removeClass("mCS_touch_action");var o=I.offset();u=O(e)[0]-o.top,f=O(e)[1]-o.left,z=[O(e)[0],O(e)[1]]}function n(e){if(te(e)&&!c&&!O(e)[2]&&(T.documentTouchScroll||e.preventDefault(),e.stopImmediatePropagation(),(!C||b)&&d)){g=K();var t=M.offset(),o=O(e)[0]-t.top,a=O(e)[1]-t.left,n="mcsLinearOut";if(E.push(o),W.push(a),z[2]=Math.abs(O(e)[0]-z[0]),z[3]=Math.abs(O(e)[1]-z[1]),B.overflowed[0])var i=D[0].parent().height()-D[0].height(),r=u-o>0&&o-u>-(i*B.scrollRatio.y)&&(2*z[3]<z[2]||"yx"===T.axis);if(B.overflowed[1])var l=D[1].parent().width()-D[1].width(),h=f-a>0&&a-f>-(l*B.scrollRatio.x)&&(2*z[2]<z[3]||"yx"===T.axis);r||h?(U||e.preventDefault(),b=1):(C=1,y.addClass("mCS_touch_action")),U&&e.preventDefault(),w="yx"===T.axis?[u-o,f-a]:"x"===T.axis?[null,f-a]:[u-o,null],I[0].idleTimer=250,B.overflowed[0]&&s(w[0],R,n,"y","all",!0),B.overflowed[1]&&s(w[1],R,n,"x",L,!0)}}function i(e){if(!te(e)||c||O(e)[2])return void(t=0);t=1,e.stopImmediatePropagation(),Q(y),p=K();var o=M.offset();h=O(e)[0]-o.top,m=O(e)[1]-o.left,E=[],W=[]}function r(e){if(te(e)&&!c&&!O(e)[2]){d=0,e.stopImmediatePropagation(),b=0,C=0,v=K();var t=M.offset(),o=O(e)[0]-t.top,a=O(e)[1]-t.left;if(!(v-g>30)){_=1e3/(v-p);var n="mcsEaseOut",i=2.5>_,r=i?[E[E.length-2],W[W.length-2]]:[0,0];x=i?[o-r[0],a-r[1]]:[o-h,a-m];var u=[Math.abs(x[0]),Math.abs(x[1])];_=i?[Math.abs(x[0]/4),Math.abs(x[1]/4)]:[_,_];var f=[Math.abs(I[0].offsetTop)-x[0]*l(u[0]/_[0],_[0]),Math.abs(I[0].offsetLeft)-x[1]*l(u[1]/_[1],_[1])];w="yx"===T.axis?[f[0],f[1]]:"x"===T.axis?[null,f[1]]:[f[0],null],S=[4*u[0]+T.scrollInertia,4*u[1]+T.scrollInertia];var y=parseInt(T.contentTouchScroll)||0;w[0]=u[0]>y?w[0]:0,w[1]=u[1]>y?w[1]:0,B.overflowed[0]&&s(w[0],S[0],n,"y",L,!1),B.overflowed[1]&&s(w[1],S[1],n,"x",L,!1)}}}function l(e,t){var o=[1.5*t,2*t,t/1.5,t/2];return e>90?t>4?o[0]:o[3]:e>60?t>3?o[3]:o[2]:e>30?t>8?o[1]:t>6?o[0]:t>4?t:o[2]:t>8?t:o[3]}function s(e,t,o,a,n,i){e&&G(y,e.toString(),{dur:t,scrollEasing:o,dir:a,overwrite:n,drag:i})}var d,u,f,h,m,p,g,v,x,_,w,S,b,C,y=e(this),B=y.data(a),T=B.opt,k=a+"_"+B.idx,M=e("#mCSB_"+B.idx),I=e("#mCSB_"+B.idx+"_container"),D=[e("#mCSB_"+B.idx+"_dragger_vertical"),e("#mCSB_"+B.idx+"_dragger_horizontal")],E=[],W=[],R=0,L="yx"===T.axis?"none":"all",z=[],P=I.find("iframe"),H=["touchstart."+k+" pointerdown."+k+" MSPointerDown."+k,"touchmove."+k+" pointermove."+k+" MSPointerMove."+k,"touchend."+k+" pointerup."+k+" MSPointerUp."+k],U=void 0!==document.body.style.touchAction&&""!==document.body.style.touchAction;I.bind(H[0],function(e){o(e)}).bind(H[1],function(e){n(e)}),M.bind(H[0],function(e){i(e)}).bind(H[2],function(e){r(e)}),P.length&&P.each(function(){e(this).bind("load",function(){A(this)&&e(this.contentDocument||this.contentWindow.document).bind(H[0],function(e){o(e),i(e)}).bind(H[1],function(e){n(e)}).bind(H[2],function(e){r(e)})})})},E=function(){function o(){return window.getSelection?window.getSelection().toString():document.selection&&"Control"!=document.selection.type?document.selection.createRange().text:0}function n(e,t,o){d.type=o&&i?"stepped":"stepless",d.scrollAmount=10,j(r,e,t,"mcsLinearOut",o?60:null)}var i,r=e(this),l=r.data(a),s=l.opt,d=l.sequential,u=a+"_"+l.idx,f=e("#mCSB_"+l.idx+"_container"),h=f.parent();f.bind("mousedown."+u,function(){t||i||(i=1,c=!0)}).add(document).bind("mousemove."+u,function(e){if(!t&&i&&o()){var a=f.offset(),r=O(e)[0]-a.top+f[0].offsetTop,c=O(e)[1]-a.left+f[0].offsetLeft;r>0&&r<h.height()&&c>0&&c<h.width()?d.step&&n("off",null,"stepped"):("x"!==s.axis&&l.overflowed[0]&&(0>r?n("on",38):r>h.height()&&n("on",40)),"y"!==s.axis&&l.overflowed[1]&&(0>c?n("on",37):c>h.width()&&n("on",39)))}}).bind("mouseup."+u+" dragend."+u,function(){t||(i&&(i=0,n("off",null)),c=!1)})},W=function(){function t(t,a){if(Q(o),!z(o,t.target)){var r="auto"!==i.mouseWheel.deltaFactor?parseInt(i.mouseWheel.deltaFactor):s&&t.deltaFactor<100?100:t.deltaFactor||100,d=i.scrollInertia;if("x"===i.axis||"x"===i.mouseWheel.axis)var u="x",f=[Math.round(r*n.scrollRatio.x),parseInt(i.mouseWheel.scrollAmount)],h="auto"!==i.mouseWheel.scrollAmount?f[1]:f[0]>=l.width()?.9*l.width():f[0],m=Math.abs(e("#mCSB_"+n.idx+"_container")[0].offsetLeft),p=c[1][0].offsetLeft,g=c[1].parent().width()-c[1].width(),v="y"===i.mouseWheel.axis?t.deltaY||a:t.deltaX;else var u="y",f=[Math.round(r*n.scrollRatio.y),parseInt(i.mouseWheel.scrollAmount)],h="auto"!==i.mouseWheel.scrollAmount?f[1]:f[0]>=l.height()?.9*l.height():f[0],m=Math.abs(e("#mCSB_"+n.idx+"_container")[0].offsetTop),p=c[0][0].offsetTop,g=c[0].parent().height()-c[0].height(),v=t.deltaY||a;"y"===u&&!n.overflowed[0]||"x"===u&&!n.overflowed[1]||((i.mouseWheel.invert||t.webkitDirectionInvertedFromDevice)&&(v=-v),i.mouseWheel.normalizeDelta&&(v=0>v?-1:1),(v>0&&0!==p||0>v&&p!==g||i.mouseWheel.preventDefault)&&(t.stopImmediatePropagation(),t.preventDefault()),t.deltaFactor<5&&!i.mouseWheel.normalizeDelta&&(h=t.deltaFactor,d=17),G(o,(m-v*h).toString(),{dir:u,dur:d}))}}if(e(this).data(a)){var o=e(this),n=o.data(a),i=n.opt,r=a+"_"+n.idx,l=e("#mCSB_"+n.idx),c=[e("#mCSB_"+n.idx+"_dragger_vertical"),e("#mCSB_"+n.idx+"_dragger_horizontal")],d=e("#mCSB_"+n.idx+"_container").find("iframe");d.length&&d.each(function(){e(this).bind("load",function(){A(this)&&e(this.contentDocument||this.contentWindow.document).bind("mousewheel."+r,function(e,o){t(e,o)})})}),l.bind("mousewheel."+r,function(e,o){t(e,o)})}},R=new Object,A=function(t){var o=!1,a=!1,n=null;if(void 0===t?a="#empty":void 0!==e(t).attr("id")&&(a=e(t).attr("id")),a!==!1&&void 0!==R[a])return R[a];if(t){try{var i=t.contentDocument||t.contentWindow.document;n=i.body.innerHTML}catch(r){}o=null!==n}else{try{var i=top.document;n=i.body.innerHTML}catch(r){}o=null!==n}return a!==!1&&(R[a]=o),o},L=function(e){var t=this.find("iframe");if(t.length){var o=e?"auto":"none";t.css("pointer-events",o)}},z=function(t,o){var n=o.nodeName.toLowerCase(),i=t.data(a).opt.mouseWheel.disableOver,r=["select","textarea"];return e.inArray(n,i)>-1&&!(e.inArray(n,r)>-1&&!e(o).is(":focus"))},P=function(){var t,o=e(this),n=o.data(a),i=a+"_"+n.idx,r=e("#mCSB_"+n.idx+"_container"),l=r.parent(),s=e(".mCSB_"+n.idx+"_scrollbar ."+d[12]);s.bind("mousedown."+i+" touchstart."+i+" pointerdown."+i+" MSPointerDown."+i,function(o){c=!0,e(o.target).hasClass("mCSB_dragger")||(t=1)}).bind("touchend."+i+" pointerup."+i+" MSPointerUp."+i,function(){c=!1}).bind("click."+i,function(a){if(t&&(t=0,e(a.target).hasClass(d[12])||e(a.target).hasClass("mCSB_draggerRail"))){Q(o);var i=e(this),s=i.find(".mCSB_dragger");if(i.parent(".mCSB_scrollTools_horizontal").length>0){if(!n.overflowed[1])return;var c="x",u=a.pageX>s.offset().left?-1:1,f=Math.abs(r[0].offsetLeft)-u*(.9*l.width())}else{if(!n.overflowed[0])return;var c="y",u=a.pageY>s.offset().top?-1:1,f=Math.abs(r[0].offsetTop)-u*(.9*l.height())}G(o,f.toString(),{dir:c,scrollEasing:"mcsEaseInOut"})}})},H=function(){var t=e(this),o=t.data(a),n=o.opt,i=a+"_"+o.idx,r=e("#mCSB_"+o.idx+"_container"),l=r.parent();r.bind("focusin."+i,function(){var o=e(document.activeElement),a=r.find(".mCustomScrollBox").length,i=0;o.is(n.advanced.autoScrollOnFocus)&&(Q(t),clearTimeout(t[0]._focusTimeout),t[0]._focusTimer=a?(i+17)*a:0,t[0]._focusTimeout=setTimeout(function(){var e=[ae(o)[0],ae(o)[1]],a=[r[0].offsetTop,r[0].offsetLeft],s=[a[0]+e[0]>=0&&a[0]+e[0]<l.height()-o.outerHeight(!1),a[1]+e[1]>=0&&a[0]+e[1]<l.width()-o.outerWidth(!1)],c="yx"!==n.axis||s[0]||s[1]?"all":"none";"x"===n.axis||s[0]||G(t,e[0].toString(),{dir:"y",scrollEasing:"mcsEaseInOut",overwrite:c,dur:i}),"y"===n.axis||s[1]||G(t,e[1].toString(),{dir:"x",scrollEasing:"mcsEaseInOut",overwrite:c,dur:i})},t[0]._focusTimer))})},U=function(){var t=e(this),o=t.data(a),n=a+"_"+o.idx,i=e("#mCSB_"+o.idx+"_container").parent();i.bind("scroll."+n,function(){0===i.scrollTop()&&0===i.scrollLeft()||e(".mCSB_"+o.idx+"_scrollbar").css("visibility","hidden")})},F=function(){var t=e(this),o=t.data(a),n=o.opt,i=o.sequential,r=a+"_"+o.idx,l=".mCSB_"+o.idx+"_scrollbar",s=e(l+">a");s.bind("contextmenu."+r,function(e){e.preventDefault()}).bind("mousedown."+r+" touchstart."+r+" pointerdown."+r+" MSPointerDown."+r+" mouseup."+r+" touchend."+r+" pointerup."+r+" MSPointerUp."+r+" mouseout."+r+" pointerout."+r+" MSPointerOut."+r+" click."+r,function(a){function r(e,o){i.scrollAmount=n.scrollButtons.scrollAmount,j(t,e,o)}if(a.preventDefault(),ee(a)){var l=e(this).attr("class");switch(i.type=n.scrollButtons.scrollType,a.type){case"mousedown":case"touchstart":case"pointerdown":case"MSPointerDown":if("stepped"===i.type)return;c=!0,o.tweenRunning=!1,r("on",l);break;case"mouseup":case"touchend":case"pointerup":case"MSPointerUp":case"mouseout":case"pointerout":case"MSPointerOut":if("stepped"===i.type)return;c=!1,i.dir&&r("off",l);break;case"click":if("stepped"!==i.type||o.tweenRunning)return;r("on",l)}}})},q=function(){function t(t){function a(e,t){r.type=i.keyboard.scrollType,r.scrollAmount=i.keyboard.scrollAmount,"stepped"===r.type&&n.tweenRunning||j(o,e,t)}switch(t.type){case"blur":n.tweenRunning&&r.dir&&a("off",null);break;case"keydown":case"keyup":var l=t.keyCode?t.keyCode:t.which,s="on";if("x"!==i.axis&&(38===l||40===l)||"y"!==i.axis&&(37===l||39===l)){if((38===l||40===l)&&!n.overflowed[0]||(37===l||39===l)&&!n.overflowed[1])return;"keyup"===t.type&&(s="off"),e(document.activeElement).is(u)||(t.preventDefault(),t.stopImmediatePropagation(),a(s,l))}else if(33===l||34===l){if((n.overflowed[0]||n.overflowed[1])&&(t.preventDefault(),t.stopImmediatePropagation()),"keyup"===t.type){Q(o);var f=34===l?-1:1;if("x"===i.axis||"yx"===i.axis&&n.overflowed[1]&&!n.overflowed[0])var h="x",m=Math.abs(c[0].offsetLeft)-f*(.9*d.width());else var h="y",m=Math.abs(c[0].offsetTop)-f*(.9*d.height());G(o,m.toString(),{dir:h,scrollEasing:"mcsEaseInOut"})}}else if((35===l||36===l)&&!e(document.activeElement).is(u)&&((n.overflowed[0]||n.overflowed[1])&&(t.preventDefault(),t.stopImmediatePropagation()),"keyup"===t.type)){if("x"===i.axis||"yx"===i.axis&&n.overflowed[1]&&!n.overflowed[0])var h="x",m=35===l?Math.abs(d.width()-c.outerWidth(!1)):0;else var h="y",m=35===l?Math.abs(d.height()-c.outerHeight(!1)):0;G(o,m.toString(),{dir:h,scrollEasing:"mcsEaseInOut"})}}}var o=e(this),n=o.data(a),i=n.opt,r=n.sequential,l=a+"_"+n.idx,s=e("#mCSB_"+n.idx),c=e("#mCSB_"+n.idx+"_container"),d=c.parent(),u="input,textarea,select,datalist,keygen,[contenteditable='true']",f=c.find("iframe"),h=["blur."+l+" keydown."+l+" keyup."+l];f.length&&f.each(function(){e(this).bind("load",function(){A(this)&&e(this.contentDocument||this.contentWindow.document).bind(h[0],function(e){t(e)})})}),s.attr("tabindex","0").bind(h[0],function(e){t(e)})},j=function(t,o,n,i,r){function l(e){u.snapAmount&&(f.scrollAmount=u.snapAmount instanceof Array?"x"===f.dir[0]?u.snapAmount[1]:u.snapAmount[0]:u.snapAmount);var o="stepped"!==f.type,a=r?r:e?o?p/1.5:g:1e3/60,n=e?o?7.5:40:2.5,s=[Math.abs(h[0].offsetTop),Math.abs(h[0].offsetLeft)],d=[c.scrollRatio.y>10?10:c.scrollRatio.y,c.scrollRatio.x>10?10:c.scrollRatio.x],m="x"===f.dir[0]?s[1]+f.dir[1]*(d[1]*n):s[0]+f.dir[1]*(d[0]*n),v="x"===f.dir[0]?s[1]+f.dir[1]*parseInt(f.scrollAmount):s[0]+f.dir[1]*parseInt(f.scrollAmount),x="auto"!==f.scrollAmount?v:m,_=i?i:e?o?"mcsLinearOut":"mcsEaseInOut":"mcsLinear",w=!!e;return e&&17>a&&(x="x"===f.dir[0]?s[1]:s[0]),G(t,x.toString(),{dir:f.dir[0],scrollEasing:_,dur:a,onComplete:w}),e?void(f.dir=!1):(clearTimeout(f.step),void(f.step=setTimeout(function(){l()},a)))}function s(){clearTimeout(f.step),$(f,"step"),Q(t)}var c=t.data(a),u=c.opt,f=c.sequential,h=e("#mCSB_"+c.idx+"_container"),m="stepped"===f.type,p=u.scrollInertia<26?26:u.scrollInertia,g=u.scrollInertia<1?17:u.scrollInertia;switch(o){case"on":if(f.dir=[n===d[16]||n===d[15]||39===n||37===n?"x":"y",n===d[13]||n===d[15]||38===n||37===n?-1:1],Q(t),oe(n)&&"stepped"===f.type)return;l(m);break;case"off":s(),(m||c.tweenRunning&&f.dir)&&l(!0)}},Y=function(t){var o=e(this).data(a).opt,n=[];return"function"==typeof t&&(t=t()),t instanceof Array?n=t.length>1?[t[0],t[1]]:"x"===o.axis?[null,t[0]]:[t[0],null]:(n[0]=t.y?t.y:t.x||"x"===o.axis?null:t,n[1]=t.x?t.x:t.y||"y"===o.axis?null:t),"function"==typeof n[0]&&(n[0]=n[0]()),"function"==typeof n[1]&&(n[1]=n[1]()),n},X=function(t,o){if(null!=t&&"undefined"!=typeof t){var n=e(this),i=n.data(a),r=i.opt,l=e("#mCSB_"+i.idx+"_container"),s=l.parent(),c=typeof t;o||(o="x"===r.axis?"x":"y");var d="x"===o?l.outerWidth(!1)-s.width():l.outerHeight(!1)-s.height(),f="x"===o?l[0].offsetLeft:l[0].offsetTop,h="x"===o?"left":"top";switch(c){case"function":return t();case"object":var m=t.jquery?t:e(t);if(!m.length)return;return"x"===o?ae(m)[1]:ae(m)[0];case"string":case"number":if(oe(t))return Math.abs(t);if(-1!==t.indexOf("%"))return Math.abs(d*parseInt(t)/100);if(-1!==t.indexOf("-="))return Math.abs(f-parseInt(t.split("-=")[1]));if(-1!==t.indexOf("+=")){var p=f+parseInt(t.split("+=")[1]);return p>=0?0:Math.abs(p)}if(-1!==t.indexOf("px")&&oe(t.split("px")[0]))return Math.abs(t.split("px")[0]);if("top"===t||"left"===t)return 0;if("bottom"===t)return Math.abs(s.height()-l.outerHeight(!1));if("right"===t)return Math.abs(s.width()-l.outerWidth(!1));if("first"===t||"last"===t){var m=l.find(":"+t);return"x"===o?ae(m)[1]:ae(m)[0]}return e(t).length?"x"===o?ae(e(t))[1]:ae(e(t))[0]:(l.css(h,t),void u.update.call(null,n[0]))}}},N=function(t){function o(){return clearTimeout(f[0].autoUpdate),0===l.parents("html").length?void(l=null):void(f[0].autoUpdate=setTimeout(function(){return c.advanced.updateOnSelectorChange&&(s.poll.change.n=i(),s.poll.change.n!==s.poll.change.o)?(s.poll.change.o=s.poll.change.n,void r(3)):c.advanced.updateOnContentResize&&(s.poll.size.n=l[0].scrollHeight+l[0].scrollWidth+f[0].offsetHeight+l[0].offsetHeight+l[0].offsetWidth,s.poll.size.n!==s.poll.size.o)?(s.poll.size.o=s.poll.size.n,void r(1)):!c.advanced.updateOnImageLoad||"auto"===c.advanced.updateOnImageLoad&&"y"===c.axis||(s.poll.img.n=f.find("img").length,s.poll.img.n===s.poll.img.o)?void((c.advanced.updateOnSelectorChange||c.advanced.updateOnContentResize||c.advanced.updateOnImageLoad)&&o()):(s.poll.img.o=s.poll.img.n,void f.find("img").each(function(){n(this)}))},c.advanced.autoUpdateTimeout))}function n(t){function o(e,t){return function(){
5
+ return t.apply(e,arguments)}}function a(){this.onload=null,e(t).addClass(d[2]),r(2)}if(e(t).hasClass(d[2]))return void r();var n=new Image;n.onload=o(n,a),n.src=t.src}function i(){c.advanced.updateOnSelectorChange===!0&&(c.advanced.updateOnSelectorChange="*");var e=0,t=f.find(c.advanced.updateOnSelectorChange);return c.advanced.updateOnSelectorChange&&t.length>0&&t.each(function(){e+=this.offsetHeight+this.offsetWidth}),e}function r(e){clearTimeout(f[0].autoUpdate),u.update.call(null,l[0],e)}var l=e(this),s=l.data(a),c=s.opt,f=e("#mCSB_"+s.idx+"_container");return t?(clearTimeout(f[0].autoUpdate),void $(f[0],"autoUpdate")):void o()},V=function(e,t,o){return Math.round(e/t)*t-o},Q=function(t){var o=t.data(a),n=e("#mCSB_"+o.idx+"_container,#mCSB_"+o.idx+"_container_wrapper,#mCSB_"+o.idx+"_dragger_vertical,#mCSB_"+o.idx+"_dragger_horizontal");n.each(function(){Z.call(this)})},G=function(t,o,n){function i(e){return s&&c.callbacks[e]&&"function"==typeof c.callbacks[e]}function r(){return[c.callbacks.alwaysTriggerOffsets||w>=S[0]+y,c.callbacks.alwaysTriggerOffsets||-B>=w]}function l(){var e=[h[0].offsetTop,h[0].offsetLeft],o=[x[0].offsetTop,x[0].offsetLeft],a=[h.outerHeight(!1),h.outerWidth(!1)],i=[f.height(),f.width()];t[0].mcs={content:h,top:e[0],left:e[1],draggerTop:o[0],draggerLeft:o[1],topPct:Math.round(100*Math.abs(e[0])/(Math.abs(a[0])-i[0])),leftPct:Math.round(100*Math.abs(e[1])/(Math.abs(a[1])-i[1])),direction:n.dir}}var s=t.data(a),c=s.opt,d={trigger:"internal",dir:"y",scrollEasing:"mcsEaseOut",drag:!1,dur:c.scrollInertia,overwrite:"all",callbacks:!0,onStart:!0,onUpdate:!0,onComplete:!0},n=e.extend(d,n),u=[n.dur,n.drag?0:n.dur],f=e("#mCSB_"+s.idx),h=e("#mCSB_"+s.idx+"_container"),m=h.parent(),p=c.callbacks.onTotalScrollOffset?Y.call(t,c.callbacks.onTotalScrollOffset):[0,0],g=c.callbacks.onTotalScrollBackOffset?Y.call(t,c.callbacks.onTotalScrollBackOffset):[0,0];if(s.trigger=n.trigger,0===m.scrollTop()&&0===m.scrollLeft()||(e(".mCSB_"+s.idx+"_scrollbar").css("visibility","visible"),m.scrollTop(0).scrollLeft(0)),"_resetY"!==o||s.contentReset.y||(i("onOverflowYNone")&&c.callbacks.onOverflowYNone.call(t[0]),s.contentReset.y=1),"_resetX"!==o||s.contentReset.x||(i("onOverflowXNone")&&c.callbacks.onOverflowXNone.call(t[0]),s.contentReset.x=1),"_resetY"!==o&&"_resetX"!==o){if(!s.contentReset.y&&t[0].mcs||!s.overflowed[0]||(i("onOverflowY")&&c.callbacks.onOverflowY.call(t[0]),s.contentReset.x=null),!s.contentReset.x&&t[0].mcs||!s.overflowed[1]||(i("onOverflowX")&&c.callbacks.onOverflowX.call(t[0]),s.contentReset.x=null),c.snapAmount){var v=c.snapAmount instanceof Array?"x"===n.dir?c.snapAmount[1]:c.snapAmount[0]:c.snapAmount;o=V(o,v,c.snapOffset)}switch(n.dir){case"x":var x=e("#mCSB_"+s.idx+"_dragger_horizontal"),_="left",w=h[0].offsetLeft,S=[f.width()-h.outerWidth(!1),x.parent().width()-x.width()],b=[o,0===o?0:o/s.scrollRatio.x],y=p[1],B=g[1],T=y>0?y/s.scrollRatio.x:0,k=B>0?B/s.scrollRatio.x:0;break;case"y":var x=e("#mCSB_"+s.idx+"_dragger_vertical"),_="top",w=h[0].offsetTop,S=[f.height()-h.outerHeight(!1),x.parent().height()-x.height()],b=[o,0===o?0:o/s.scrollRatio.y],y=p[0],B=g[0],T=y>0?y/s.scrollRatio.y:0,k=B>0?B/s.scrollRatio.y:0}b[1]<0||0===b[0]&&0===b[1]?b=[0,0]:b[1]>=S[1]?b=[S[0],S[1]]:b[0]=-b[0],t[0].mcs||(l(),i("onInit")&&c.callbacks.onInit.call(t[0])),clearTimeout(h[0].onCompleteTimeout),J(x[0],_,Math.round(b[1]),u[1],n.scrollEasing),!s.tweenRunning&&(0===w&&b[0]>=0||w===S[0]&&b[0]<=S[0])||J(h[0],_,Math.round(b[0]),u[0],n.scrollEasing,n.overwrite,{onStart:function(){n.callbacks&&n.onStart&&!s.tweenRunning&&(i("onScrollStart")&&(l(),c.callbacks.onScrollStart.call(t[0])),s.tweenRunning=!0,C(x),s.cbOffsets=r())},onUpdate:function(){n.callbacks&&n.onUpdate&&i("whileScrolling")&&(l(),c.callbacks.whileScrolling.call(t[0]))},onComplete:function(){if(n.callbacks&&n.onComplete){"yx"===c.axis&&clearTimeout(h[0].onCompleteTimeout);var e=h[0].idleTimer||0;h[0].onCompleteTimeout=setTimeout(function(){i("onScroll")&&(l(),c.callbacks.onScroll.call(t[0])),i("onTotalScroll")&&b[1]>=S[1]-T&&s.cbOffsets[0]&&(l(),c.callbacks.onTotalScroll.call(t[0])),i("onTotalScrollBack")&&b[1]<=k&&s.cbOffsets[1]&&(l(),c.callbacks.onTotalScrollBack.call(t[0])),s.tweenRunning=!1,h[0].idleTimer=0,C(x,"hide")},e)}}})}},J=function(e,t,o,a,n,i,r){function l(){S.stop||(x||m.call(),x=K()-v,s(),x>=S.time&&(S.time=x>S.time?x+f-(x-S.time):x+f-1,S.time<x+1&&(S.time=x+1)),S.time<a?S.id=h(l):g.call())}function s(){a>0?(S.currVal=u(S.time,_,b,a,n),w[t]=Math.round(S.currVal)+"px"):w[t]=o+"px",p.call()}function c(){f=1e3/60,S.time=x+f,h=window.requestAnimationFrame?window.requestAnimationFrame:function(e){return s(),setTimeout(e,.01)},S.id=h(l)}function d(){null!=S.id&&(window.requestAnimationFrame?window.cancelAnimationFrame(S.id):clearTimeout(S.id),S.id=null)}function u(e,t,o,a,n){switch(n){case"linear":case"mcsLinear":return o*e/a+t;case"mcsLinearOut":return e/=a,e--,o*Math.sqrt(1-e*e)+t;case"easeInOutSmooth":return e/=a/2,1>e?o/2*e*e+t:(e--,-o/2*(e*(e-2)-1)+t);case"easeInOutStrong":return e/=a/2,1>e?o/2*Math.pow(2,10*(e-1))+t:(e--,o/2*(-Math.pow(2,-10*e)+2)+t);case"easeInOut":case"mcsEaseInOut":return e/=a/2,1>e?o/2*e*e*e+t:(e-=2,o/2*(e*e*e+2)+t);case"easeOutSmooth":return e/=a,e--,-o*(e*e*e*e-1)+t;case"easeOutStrong":return o*(-Math.pow(2,-10*e/a)+1)+t;case"easeOut":case"mcsEaseOut":default:var i=(e/=a)*e,r=i*e;return t+o*(.499999999999997*r*i+-2.5*i*i+5.5*r+-6.5*i+4*e)}}e._mTween||(e._mTween={top:{},left:{}});var f,h,r=r||{},m=r.onStart||function(){},p=r.onUpdate||function(){},g=r.onComplete||function(){},v=K(),x=0,_=e.offsetTop,w=e.style,S=e._mTween[t];"left"===t&&(_=e.offsetLeft);var b=o-_;S.stop=0,"none"!==i&&d(),c()},K=function(){return window.performance&&window.performance.now?window.performance.now():window.performance&&window.performance.webkitNow?window.performance.webkitNow():Date.now?Date.now():(new Date).getTime()},Z=function(){var e=this;e._mTween||(e._mTween={top:{},left:{}});for(var t=["top","left"],o=0;o<t.length;o++){var a=t[o];e._mTween[a].id&&(window.requestAnimationFrame?window.cancelAnimationFrame(e._mTween[a].id):clearTimeout(e._mTween[a].id),e._mTween[a].id=null,e._mTween[a].stop=1)}},$=function(e,t){try{delete e[t]}catch(o){e[t]=null}},ee=function(e){return!(e.which&&1!==e.which)},te=function(e){var t=e.originalEvent.pointerType;return!(t&&"touch"!==t&&2!==t)},oe=function(e){return!isNaN(parseFloat(e))&&isFinite(e)},ae=function(e){var t=e.parents(".mCSB_container");return[e.offset().top-t.offset().top,e.offset().left-t.offset().left]},ne=function(){function e(){var e=["webkit","moz","ms","o"];if("hidden"in document)return"hidden";for(var t=0;t<e.length;t++)if(e[t]+"Hidden"in document)return e[t]+"Hidden";return null}var t=e();return t?document[t]:!1};e.fn[o]=function(t){return u[t]?u[t].apply(this,Array.prototype.slice.call(arguments,1)):"object"!=typeof t&&t?void e.error("Method "+t+" does not exist"):u.init.apply(this,arguments)},e[o]=function(t){return u[t]?u[t].apply(this,Array.prototype.slice.call(arguments,1)):"object"!=typeof t&&t?void e.error("Method "+t+" does not exist"):u.init.apply(this,arguments)},e[o].defaults=i,window[o]=!0,e(window).bind("load",function(){e(n)[o](),e.extend(e.expr[":"],{mcsInView:e.expr[":"].mcsInView||function(t){var o,a,n=e(t),i=n.parents(".mCSB_container");if(i.length)return o=i.parent(),a=[i[0].offsetTop,i[0].offsetLeft],a[0]+ae(n)[0]>=0&&a[0]+ae(n)[0]<o.height()-n.outerHeight(!1)&&a[1]+ae(n)[1]>=0&&a[1]+ae(n)[1]<o.width()-n.outerWidth(!1)},mcsInSight:e.expr[":"].mcsInSight||function(t,o,a){var n,i,r,l,s=e(t),c=s.parents(".mCSB_container"),d="exact"===a[3]?[[1,0],[1,0]]:[[.9,.1],[.6,.4]];if(c.length)return n=[s.outerHeight(!1),s.outerWidth(!1)],r=[c[0].offsetTop+ae(s)[0],c[0].offsetLeft+ae(s)[1]],i=[c.parent()[0].offsetHeight,c.parent()[0].offsetWidth],l=[n[0]<i[0]?d[0]:d[1],n[1]<i[1]?d[0]:d[1]],r[0]-i[0]*l[0][0]<0&&r[0]+n[0]-i[0]*l[0][1]>=0&&r[1]-i[1]*l[1][0]<0&&r[1]+n[1]-i[1]*l[1][1]>=0},mcsOverflow:e.expr[":"].mcsOverflow||function(t){var o=e(t).data(a);if(o)return o.overflowed[0]||o.overflowed[1]}})})})});
js/jquery.mCustomScrollbar.js ADDED
@@ -0,0 +1,2454 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ /*
2
+ == malihu jquery custom scrollbar plugin ==
3
+ Version: 3.1.5
4
+ Plugin URI: http://manos.malihu.gr/jquery-custom-content-scroller
5
+ Author: malihu
6
+ Author URI: http://manos.malihu.gr
7
+ License: MIT License (MIT)
8
+ */
9
+
10
+ /*
11
+ Copyright Manos Malihutsakis (email: manos@malihu.gr)
12
+
13
+ Permission is hereby granted, free of charge, to any person obtaining a copy
14
+ of this software and associated documentation files (the "Software"), to deal
15
+ in the Software without restriction, including without limitation the rights
16
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
17
+ copies of the Software, and to permit persons to whom the Software is
18
+ furnished to do so, subject to the following conditions:
19
+
20
+ The above copyright notice and this permission notice shall be included in
21
+ all copies or substantial portions of the Software.
22
+
23
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
24
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
25
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
26
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
27
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
28
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
29
+ THE SOFTWARE.
30
+ */
31
+
32
+ /*
33
+ The code below is fairly long, fully commented and should be normally used in development.
34
+ For production, use either the minified jquery.mCustomScrollbar.min.js script or
35
+ the production-ready jquery.mCustomScrollbar.concat.min.js which contains the plugin
36
+ and dependencies (minified).
37
+ */
38
+
39
+ (function(factory){
40
+ if(typeof define==="function" && define.amd){
41
+ define(["jquery"],factory);
42
+ }else if(typeof module!=="undefined" && module.exports){
43
+ module.exports=factory;
44
+ }else{
45
+ factory(jQuery,window,document);
46
+ }
47
+ }(function($){
48
+ (function(init){
49
+ var _rjs=typeof define==="function" && define.amd, /* RequireJS */
50
+ _njs=typeof module !== "undefined" && module.exports, /* NodeJS */
51
+ _dlp=("https:"==document.location.protocol) ? "https:" : "http:", /* location protocol */
52
+ _url="cdnjs.cloudflare.com/ajax/libs/jquery-mousewheel/3.1.13/jquery.mousewheel.min.js";
53
+ if(!_rjs){
54
+ if(_njs){
55
+ require("jquery-mousewheel")($);
56
+ }else{
57
+ /* load jquery-mousewheel plugin (via CDN) if it's not present or not loaded via RequireJS
58
+ (works when mCustomScrollbar fn is called on window load) */
59
+ $.event.special.mousewheel || $("head").append(decodeURI("%3Cscript src="+_dlp+"//"+_url+"%3E%3C/script%3E"));
60
+ }
61
+ }
62
+ init();
63
+ }(function(){
64
+
65
+ /*
66
+ ----------------------------------------
67
+ PLUGIN NAMESPACE, PREFIX, DEFAULT SELECTOR(S)
68
+ ----------------------------------------
69
+ */
70
+
71
+ var pluginNS="mCustomScrollbar",
72
+ pluginPfx="mCS",
73
+ defaultSelector=".mCustomScrollbar",
74
+
75
+
76
+
77
+
78
+
79
+ /*
80
+ ----------------------------------------
81
+ DEFAULT OPTIONS
82
+ ----------------------------------------
83
+ */
84
+
85
+ defaults={
86
+ /*
87
+ set element/content width/height programmatically
88
+ values: boolean, pixels, percentage
89
+ option default
90
+ -------------------------------------
91
+ setWidth false
92
+ setHeight false
93
+ */
94
+ /*
95
+ set the initial css top property of content
96
+ values: string (e.g. "-100px", "10%" etc.)
97
+ */
98
+ setTop:0,
99
+ /*
100
+ set the initial css left property of content
101
+ values: string (e.g. "-100px", "10%" etc.)
102
+ */
103
+ setLeft:0,
104
+ /*
105
+ scrollbar axis (vertical and/or horizontal scrollbars)
106
+ values (string): "y", "x", "yx"
107
+ */
108
+ axis:"y",
109
+ /*
110
+ position of scrollbar relative to content
111
+ values (string): "inside", "outside" ("outside" requires elements with position:relative)
112
+ */
113
+ scrollbarPosition:"inside",
114
+ /*
115
+ scrolling inertia
116
+ values: integer (milliseconds)
117
+ */
118
+ scrollInertia:950,
119
+ /*
120
+ auto-adjust scrollbar dragger length
121
+ values: boolean
122
+ */
123
+ autoDraggerLength:true,
124
+ /*
125
+ auto-hide scrollbar when idle
126
+ values: boolean
127
+ option default
128
+ -------------------------------------
129
+ autoHideScrollbar false
130
+ */
131
+ /*
132
+ auto-expands scrollbar on mouse-over and dragging
133
+ values: boolean
134
+ option default
135
+ -------------------------------------
136
+ autoExpandScrollbar false
137
+ */
138
+ /*
139
+ always show scrollbar, even when there's nothing to scroll
140
+ values: integer (0=disable, 1=always show dragger rail and buttons, 2=always show dragger rail, dragger and buttons), boolean
141
+ */
142
+ alwaysShowScrollbar:0,
143
+ /*
144
+ scrolling always snaps to a multiple of this number in pixels
145
+ values: integer, array ([y,x])
146
+ option default
147
+ -------------------------------------
148
+ snapAmount null
149
+ */
150
+ /*
151
+ when snapping, snap with this number in pixels as an offset
152
+ values: integer
153
+ */
154
+ snapOffset:0,
155
+ /*
156
+ mouse-wheel scrolling
157
+ */
158
+ mouseWheel:{
159
+ /*
160
+ enable mouse-wheel scrolling
161
+ values: boolean
162
+ */
163
+ enable:true,
164
+ /*
165
+ scrolling amount in pixels
166
+ values: "auto", integer
167
+ */
168
+ scrollAmount:"auto",
169
+ /*
170
+ mouse-wheel scrolling axis
171
+ the default scrolling direction when both vertical and horizontal scrollbars are present
172
+ values (string): "y", "x"
173
+ */
174
+ axis:"y",
175
+ /*
176
+ prevent the default behaviour which automatically scrolls the parent element(s) when end of scrolling is reached
177
+ values: boolean
178
+ option default
179
+ -------------------------------------
180
+ preventDefault null
181
+ */
182
+ /*
183
+ the reported mouse-wheel delta value. The number of lines (translated to pixels) one wheel notch scrolls.
184
+ values: "auto", integer
185
+ "auto" uses the default OS/browser value
186
+ */
187
+ deltaFactor:"auto",
188
+ /*
189
+ normalize mouse-wheel delta to -1 or 1 (disables mouse-wheel acceleration)
190
+ values: boolean
191
+ option default
192
+ -------------------------------------
193
+ normalizeDelta null
194
+ */
195
+ /*
196
+ invert mouse-wheel scrolling direction
197
+ values: boolean
198
+ option default
199
+ -------------------------------------
200
+ invert null
201
+ */
202
+ /*
203
+ the tags that disable mouse-wheel when cursor is over them
204
+ */
205
+ disableOver:["select","option","keygen","datalist","textarea"]
206
+ },
207
+ /*
208
+ scrollbar buttons
209
+ */
210
+ scrollButtons:{
211
+ /*
212
+ enable scrollbar buttons
213
+ values: boolean
214
+ option default
215
+ -------------------------------------
216
+ enable null
217
+ */
218
+ /*
219
+ scrollbar buttons scrolling type
220
+ values (string): "stepless", "stepped"
221
+ */
222
+ scrollType:"stepless",
223
+ /*
224
+ scrolling amount in pixels
225
+ values: "auto", integer
226
+ */
227
+ scrollAmount:"auto"
228
+ /*
229
+ tabindex of the scrollbar buttons
230
+ values: false, integer
231
+ option default
232
+ -------------------------------------
233
+ tabindex null
234
+ */
235
+ },
236
+ /*
237
+ keyboard scrolling
238
+ */
239
+ keyboard:{
240
+ /*
241
+ enable scrolling via keyboard
242
+ values: boolean
243
+ */
244
+ enable:true,
245
+ /*
246
+ keyboard scrolling type
247
+ values (string): "stepless", "stepped"
248
+ */
249
+ scrollType:"stepless",
250
+ /*
251
+ scrolling amount in pixels
252
+ values: "auto", integer
253
+ */
254
+ scrollAmount:"auto"
255
+ },
256
+ /*
257
+ enable content touch-swipe scrolling
258
+ values: boolean, integer, string (number)
259
+ integer values define the axis-specific minimum amount required for scrolling momentum
260
+ */
261
+ contentTouchScroll:25,
262
+ /*
263
+ enable/disable document (default) touch-swipe scrolling
264
+ */
265
+ documentTouchScroll:true,
266
+ /*
267
+ advanced option parameters
268
+ */
269
+ advanced:{
270
+ /*
271
+ auto-expand content horizontally (for "x" or "yx" axis)
272
+ values: boolean, integer (the value 2 forces the non scrollHeight/scrollWidth method, the value 3 forces the scrollHeight/scrollWidth method)
273
+ option default
274
+ -------------------------------------
275
+ autoExpandHorizontalScroll null
276
+ */
277
+ /*
278
+ auto-scroll to elements with focus
279
+ */
280
+ autoScrollOnFocus:"input,textarea,select,button,datalist,keygen,a[tabindex],area,object,[contenteditable='true']",
281
+ /*
282
+ auto-update scrollbars on content, element or viewport resize
283
+ should be true for fluid layouts/elements, adding/removing content dynamically, hiding/showing elements, content with images etc.
284
+ values: boolean
285
+ */
286
+ updateOnContentResize:true,
287
+ /*
288
+ auto-update scrollbars each time each image inside the element is fully loaded
289
+ values: "auto", boolean
290
+ */
291
+ updateOnImageLoad:"auto",
292
+ /*
293
+ auto-update scrollbars based on the amount and size changes of specific selectors
294
+ useful when you need to update the scrollbar(s) automatically, each time a type of element is added, removed or changes its size
295
+ values: boolean, string (e.g. "ul li" will auto-update scrollbars each time list-items inside the element are changed)
296
+ a value of true (boolean) will auto-update scrollbars each time any element is changed
297
+ option default
298
+ -------------------------------------
299
+ updateOnSelectorChange null
300
+ */
301
+ /*
302
+ extra selectors that'll allow scrollbar dragging upon mousemove/up, pointermove/up, touchend etc. (e.g. "selector-1, selector-2")
303
+ option default
304
+ -------------------------------------
305
+ extraDraggableSelectors null
306
+ */
307
+ /*
308
+ extra selectors that'll release scrollbar dragging upon mouseup, pointerup, touchend etc. (e.g. "selector-1, selector-2")
309
+ option default
310
+ -------------------------------------
311
+ releaseDraggableSelectors null
312
+ */
313
+ /*
314
+ auto-update timeout
315
+ values: integer (milliseconds)
316
+ */
317
+ autoUpdateTimeout:60
318
+ },
319
+ /*
320
+ scrollbar theme
321
+ values: string (see CSS/plugin URI for a list of ready-to-use themes)
322
+ */
323
+ theme:"light",
324
+ /*
325
+ user defined callback functions
326
+ */
327
+ callbacks:{
328
+ /*
329
+ Available callbacks:
330
+ callback default
331
+ -------------------------------------
332
+ onCreate null
333
+ onInit null
334
+ onScrollStart null
335
+ onScroll null
336
+ onTotalScroll null
337
+ onTotalScrollBack null
338
+ whileScrolling null
339
+ onOverflowY null
340
+ onOverflowX null
341
+ onOverflowYNone null
342
+ onOverflowXNone null
343
+ onImageLoad null
344
+ onSelectorChange null
345
+ onBeforeUpdate null
346
+ onUpdate null
347
+ */
348
+ onTotalScrollOffset:0,
349
+ onTotalScrollBackOffset:0,
350
+ alwaysTriggerOffsets:true
351
+ }
352
+ /*
353
+ add scrollbar(s) on all elements matching the current selector, now and in the future
354
+ values: boolean, string
355
+ string values: "on" (enable), "once" (disable after first invocation), "off" (disable)
356
+ liveSelector values: string (selector)
357
+ option default
358
+ -------------------------------------
359
+ live false
360
+ liveSelector null
361
+ */
362
+ },
363
+
364
+
365
+
366
+
367
+
368
+ /*
369
+ ----------------------------------------
370
+ VARS, CONSTANTS
371
+ ----------------------------------------
372
+ */
373
+
374
+ totalInstances=0, /* plugin instances amount */
375
+ liveTimers={}, /* live option timers */
376
+ oldIE=(window.attachEvent && !window.addEventListener) ? 1 : 0, /* detect IE < 9 */
377
+ touchActive=false,touchable, /* global touch vars (for touch and pointer events) */
378
+ /* general plugin classes */
379
+ classes=[
380
+ "mCSB_dragger_onDrag","mCSB_scrollTools_onDrag","mCS_img_loaded","mCS_disabled","mCS_destroyed","mCS_no_scrollbar",
381
+ "mCS-autoHide","mCS-dir-rtl","mCS_no_scrollbar_y","mCS_no_scrollbar_x","mCS_y_hidden","mCS_x_hidden","mCSB_draggerContainer",
382
+ "mCSB_buttonUp","mCSB_buttonDown","mCSB_buttonLeft","mCSB_buttonRight"
383
+ ],
384
+
385
+
386
+
387
+
388
+
389
+ /*
390
+ ----------------------------------------
391
+ METHODS
392
+ ----------------------------------------
393
+ */
394
+
395
+ methods={
396
+
397
+ /*
398
+ plugin initialization method
399
+ creates the scrollbar(s), plugin data object and options
400
+ ----------------------------------------
401
+ */
402
+
403
+ init:function(options){
404
+
405
+ var options=$.extend(true,{},defaults,options),
406
+ selector=_selector.call(this); /* validate selector */
407
+
408
+ /*
409
+ if live option is enabled, monitor for elements matching the current selector and
410
+ apply scrollbar(s) when found (now and in the future)
411
+ */
412
+ if(options.live){
413
+ var liveSelector=options.liveSelector || this.selector || defaultSelector, /* live selector(s) */
414
+ $liveSelector=$(liveSelector); /* live selector(s) as jquery object */
415
+ if(options.live==="off"){
416
+ /*
417
+ disable live if requested
418
+ usage: $(selector).mCustomScrollbar({live:"off"});
419
+ */
420
+ removeLiveTimers(liveSelector);
421
+ return;
422
+ }
423
+ liveTimers[liveSelector]=setTimeout(function(){
424
+ /* call mCustomScrollbar fn on live selector(s) every half-second */
425
+ $liveSelector.mCustomScrollbar(options);
426
+ if(options.live==="once" && $liveSelector.length){
427
+ /* disable live after first invocation */
428
+ removeLiveTimers(liveSelector);
429
+ }
430
+ },500);
431
+ }else{
432
+ removeLiveTimers(liveSelector);
433
+ }
434
+
435
+ /* options backward compatibility (for versions < 3.0.0) and normalization */
436
+ options.setWidth=(options.set_width) ? options.set_width : options.setWidth;
437
+ options.setHeight=(options.set_height) ? options.set_height : options.setHeight;
438
+ options.axis=(options.horizontalScroll) ? "x" : _findAxis(options.axis);
439
+ options.scrollInertia=options.scrollInertia>0 && options.scrollInertia<17 ? 17 : options.scrollInertia;
440
+ if(typeof options.mouseWheel!=="object" && options.mouseWheel==true){ /* old school mouseWheel option (non-object) */
441
+ options.mouseWheel={enable:true,scrollAmount:"auto",axis:"y",preventDefault:false,deltaFactor:"auto",normalizeDelta:false,invert:false}
442
+ }
443
+ options.mouseWheel.scrollAmount=!options.mouseWheelPixels ? options.mouseWheel.scrollAmount : options.mouseWheelPixels;
444
+ options.mouseWheel.normalizeDelta=!options.advanced.normalizeMouseWheelDelta ? options.mouseWheel.normalizeDelta : options.advanced.normalizeMouseWheelDelta;
445
+ options.scrollButtons.scrollType=_findScrollButtonsType(options.scrollButtons.scrollType);
446
+
447
+ _theme(options); /* theme-specific options */
448
+
449
+ /* plugin constructor */
450
+ return $(selector).each(function(){
451
+
452
+ var $this=$(this);
453
+
454
+ if(!$this.data(pluginPfx)){ /* prevent multiple instantiations */
455
+
456
+ /* store options and create objects in jquery data */
457
+ $this.data(pluginPfx,{
458
+ idx:++totalInstances, /* instance index */
459
+ opt:options, /* options */
460
+ scrollRatio:{y:null,x:null}, /* scrollbar to content ratio */
461
+ overflowed:null, /* overflowed axis */
462
+ contentReset:{y:null,x:null}, /* object to check when content resets */
463
+ bindEvents:false, /* object to check if events are bound */
464
+ tweenRunning:false, /* object to check if tween is running */
465
+ sequential:{}, /* sequential scrolling object */
466
+ langDir:$this.css("direction"), /* detect/store direction (ltr or rtl) */
467
+ cbOffsets:null, /* object to check whether callback offsets always trigger */
468
+ /*
469
+ object to check how scrolling events where last triggered
470
+ "internal" (default - triggered by this script), "external" (triggered by other scripts, e.g. via scrollTo method)
471
+ usage: object.data("mCS").trigger
472
+ */
473
+ trigger:null,
474
+ /*
475
+ object to check for changes in elements in order to call the update method automatically
476
+ */
477
+ poll:{size:{o:0,n:0},img:{o:0,n:0},change:{o:0,n:0}}
478
+ });
479
+
480
+ var d=$this.data(pluginPfx),o=d.opt,
481
+ /* HTML data attributes */
482
+ htmlDataAxis=$this.data("mcs-axis"),htmlDataSbPos=$this.data("mcs-scrollbar-position"),htmlDataTheme=$this.data("mcs-theme");
483
+
484
+ if(htmlDataAxis){o.axis=htmlDataAxis;} /* usage example: data-mcs-axis="y" */
485
+ if(htmlDataSbPos){o.scrollbarPosition=htmlDataSbPos;} /* usage example: data-mcs-scrollbar-position="outside" */
486
+ if(htmlDataTheme){ /* usage example: data-mcs-theme="minimal" */
487
+ o.theme=htmlDataTheme;
488
+ _theme(o); /* theme-specific options */
489
+ }
490
+
491
+ _pluginMarkup.call(this); /* add plugin markup */
492
+
493
+ if(d && o.callbacks.onCreate && typeof o.callbacks.onCreate==="function"){o.callbacks.onCreate.call(this);} /* callbacks: onCreate */
494
+
495
+ $("#mCSB_"+d.idx+"_container img:not(."+classes[2]+")").addClass(classes[2]); /* flag loaded images */
496
+
497
+ methods.update.call(null,$this); /* call the update method */
498
+
499
+ }
500
+
501
+ });
502
+
503
+ },
504
+ /* ---------------------------------------- */
505
+
506
+
507
+
508
+ /*
509
+ plugin update method
510
+ updates content and scrollbar(s) values, events and status
511
+ ----------------------------------------
512
+ usage: $(selector).mCustomScrollbar("update");
513
+ */
514
+
515
+ update:function(el,cb){
516
+
517
+ var selector=el || _selector.call(this); /* validate selector */
518
+
519
+ return $(selector).each(function(){
520
+
521
+ var $this=$(this);
522
+
523
+ if($this.data(pluginPfx)){ /* check if plugin has initialized */
524
+
525
+ var d=$this.data(pluginPfx),o=d.opt,
526
+ mCSB_container=$("#mCSB_"+d.idx+"_container"),
527
+ mCustomScrollBox=$("#mCSB_"+d.idx),
528
+ mCSB_dragger=[$("#mCSB_"+d.idx+"_dragger_vertical"),$("#mCSB_"+d.idx+"_dragger_horizontal")];
529
+
530
+ if(!mCSB_container.length){return;}
531
+
532
+ if(d.tweenRunning){_stop($this);} /* stop any running tweens while updating */
533
+
534
+ if(cb && d && o.callbacks.onBeforeUpdate && typeof o.callbacks.onBeforeUpdate==="function"){o.callbacks.onBeforeUpdate.call(this);} /* callbacks: onBeforeUpdate */
535
+
536
+ /* if element was disabled or destroyed, remove class(es) */
537
+ if($this.hasClass(classes[3])){$this.removeClass(classes[3]);}
538
+ if($this.hasClass(classes[4])){$this.removeClass(classes[4]);}
539
+
540
+ /* css flexbox fix, detect/set max-height */
541
+ mCustomScrollBox.css("max-height","none");
542
+ if(mCustomScrollBox.height()!==$this.height()){mCustomScrollBox.css("max-height",$this.height());}
543
+
544
+ _expandContentHorizontally.call(this); /* expand content horizontally */
545
+
546
+ if(o.axis!=="y" && !o.advanced.autoExpandHorizontalScroll){
547
+ mCSB_container.css("width",_contentWidth(mCSB_container));
548
+ }
549
+
550
+ d.overflowed=_overflowed.call(this); /* determine if scrolling is required */
551
+
552
+ _scrollbarVisibility.call(this); /* show/hide scrollbar(s) */
553
+
554
+ /* auto-adjust scrollbar dragger length analogous to content */
555
+ if(o.autoDraggerLength){_setDraggerLength.call(this);}
556
+
557
+ _scrollRatio.call(this); /* calculate and store scrollbar to content ratio */
558
+
559
+ _bindEvents.call(this); /* bind scrollbar events */
560
+
561
+ /* reset scrolling position and/or events */
562
+ var to=[Math.abs(mCSB_container[0].offsetTop),Math.abs(mCSB_container[0].offsetLeft)];
563
+ if(o.axis!=="x"){ /* y/yx axis */
564
+ if(!d.overflowed[0]){ /* y scrolling is not required */
565
+ _resetContentPosition.call(this); /* reset content position */
566
+ if(o.axis==="y"){
567
+ _unbindEvents.call(this);
568
+ }else if(o.axis==="yx" && d.overflowed[1]){
569
+ _scrollTo($this,to[1].toString(),{dir:"x",dur:0,overwrite:"none"});
570
+ }
571
+ }else if(mCSB_dragger[0].height()>mCSB_dragger[0].parent().height()){
572
+ _resetContentPosition.call(this); /* reset content position */
573
+ }else{ /* y scrolling is required */
574
+ _scrollTo($this,to[0].toString(),{dir:"y",dur:0,overwrite:"none"});
575
+ d.contentReset.y=null;
576
+ }
577
+ }
578
+ if(o.axis!=="y"){ /* x/yx axis */
579
+ if(!d.overflowed[1]){ /* x scrolling is not required */
580
+ _resetContentPosition.call(this); /* reset content position */
581
+ if(o.axis==="x"){
582
+ _unbindEvents.call(this);
583
+ }else if(o.axis==="yx" && d.overflowed[0]){
584
+ _scrollTo($this,to[0].toString(),{dir:"y",dur:0,overwrite:"none"});
585
+ }
586
+ }else if(mCSB_dragger[1].width()>mCSB_dragger[1].parent().width()){
587
+ _resetContentPosition.call(this); /* reset content position */
588
+ }else{ /* x scrolling is required */
589
+ _scrollTo($this,to[1].toString(),{dir:"x",dur:0,overwrite:"none"});
590
+ d.contentReset.x=null;
591
+ }
592
+ }
593
+
594
+ /* callbacks: onImageLoad, onSelectorChange, onUpdate */
595
+ if(cb && d){
596
+ if(cb===2 && o.callbacks.onImageLoad && typeof o.callbacks.onImageLoad==="function"){
597
+ o.callbacks.onImageLoad.call(this);
598
+ }else if(cb===3 && o.callbacks.onSelectorChange && typeof o.callbacks.onSelectorChange==="function"){
599
+ o.callbacks.onSelectorChange.call(this);
600
+ }else if(o.callbacks.onUpdate && typeof o.callbacks.onUpdate==="function"){
601
+ o.callbacks.onUpdate.call(this);
602
+ }
603
+ }
604
+
605
+ _autoUpdate.call(this); /* initialize automatic updating (for dynamic content, fluid layouts etc.) */
606
+
607
+ }
608
+
609
+ });
610
+
611
+ },
612
+ /* ---------------------------------------- */
613
+
614
+
615
+
616
+ /*
617
+ plugin scrollTo method
618
+ triggers a scrolling event to a specific value
619
+ ----------------------------------------
620
+ usage: $(selector).mCustomScrollbar("scrollTo",value,options);
621
+ */
622
+
623
+ scrollTo:function(val,options){
624
+
625
+ /* prevent silly things like $(selector).mCustomScrollbar("scrollTo",undefined); */
626
+ if(typeof val=="undefined" || val==null){return;}
627
+
628
+ var selector=_selector.call(this); /* validate selector */
629
+
630
+ return $(selector).each(function(){
631
+
632
+ var $this=$(this);
633
+
634
+ if($this.data(pluginPfx)){ /* check if plugin has initialized */
635
+
636
+ var d=$this.data(pluginPfx),o=d.opt,
637
+ /* method default options */
638
+ methodDefaults={
639
+ trigger:"external", /* method is by default triggered externally (e.g. from other scripts) */
640
+ scrollInertia:o.scrollInertia, /* scrolling inertia (animation duration) */
641
+ scrollEasing:"mcsEaseInOut", /* animation easing */
642
+ moveDragger:false, /* move dragger instead of content */
643
+ timeout:60, /* scroll-to delay */
644
+ callbacks:true, /* enable/disable callbacks */
645
+ onStart:true,
646
+ onUpdate:true,
647
+ onComplete:true
648
+ },
649
+ methodOptions=$.extend(true,{},methodDefaults,options),
650
+ to=_arr.call(this,val),dur=methodOptions.scrollInertia>0 && methodOptions.scrollInertia<17 ? 17 : methodOptions.scrollInertia;
651
+
652
+ /* translate yx values to actual scroll-to positions */
653
+ to[0]=_to.call(this,to[0],"y");
654
+ to[1]=_to.call(this,to[1],"x");
655
+
656
+ /*
657
+ check if scroll-to value moves the dragger instead of content.
658
+ Only pixel values apply on dragger (e.g. 100, "100px", "-=100" etc.)
659
+ */
660
+ if(methodOptions.moveDragger){
661
+ to[0]*=d.scrollRatio.y;
662
+ to[1]*=d.scrollRatio.x;
663
+ }
664
+
665
+ methodOptions.dur=_isTabHidden() ? 0 : dur; //skip animations if browser tab is hidden
666
+
667
+ setTimeout(function(){
668
+ /* do the scrolling */
669
+ if(to[0]!==null && typeof to[0]!=="undefined" && o.axis!=="x" && d.overflowed[0]){ /* scroll y */
670
+ methodOptions.dir="y";
671
+ methodOptions.overwrite="all";
672
+ _scrollTo($this,to[0].toString(),methodOptions);
673
+ }
674
+ if(to[1]!==null && typeof to[1]!=="undefined" && o.axis!=="y" && d.overflowed[1]){ /* scroll x */
675
+ methodOptions.dir="x";
676
+ methodOptions.overwrite="none";
677
+ _scrollTo($this,to[1].toString(),methodOptions);
678
+ }
679
+ },methodOptions.timeout);
680
+
681
+ }
682
+
683
+ });
684
+
685
+ },
686
+ /* ---------------------------------------- */
687
+
688
+
689
+
690
+ /*
691
+ plugin stop method
692
+ stops scrolling animation
693
+ ----------------------------------------
694
+ usage: $(selector).mCustomScrollbar("stop");
695
+ */
696
+ stop:function(){
697
+
698
+ var selector=_selector.call(this); /* validate selector */
699
+
700
+ return $(selector).each(function(){
701
+
702
+ var $this=$(this);
703
+
704
+ if($this.data(pluginPfx)){ /* check if plugin has initialized */
705
+
706
+ _stop($this);
707
+
708
+ }
709
+
710
+ });
711
+
712
+ },
713
+ /* ---------------------------------------- */
714
+
715
+
716
+
717
+ /*
718
+ plugin disable method
719
+ temporarily disables the scrollbar(s)
720
+ ----------------------------------------
721
+ usage: $(selector).mCustomScrollbar("disable",reset);
722
+ reset (boolean): resets content position to 0
723
+ */
724
+ disable:function(r){
725
+
726
+ var selector=_selector.call(this); /* validate selector */
727
+
728
+ return $(selector).each(function(){
729
+
730
+ var $this=$(this);
731
+
732
+ if($this.data(pluginPfx)){ /* check if plugin has initialized */
733
+
734
+ var d=$this.data(pluginPfx);
735
+
736
+ _autoUpdate.call(this,"remove"); /* remove automatic updating */
737
+
738
+ _unbindEvents.call(this); /* unbind events */
739
+
740
+ if(r){_resetContentPosition.call(this);} /* reset content position */
741
+
742
+ _scrollbarVisibility.call(this,true); /* show/hide scrollbar(s) */
743
+
744
+ $this.addClass(classes[3]); /* add disable class */
745
+
746
+ }
747
+
748
+ });
749
+
750
+ },
751
+ /* ---------------------------------------- */
752
+
753
+
754
+
755
+ /*
756
+ plugin destroy method
757
+ completely removes the scrollbar(s) and returns the element to its original state
758
+ ----------------------------------------
759
+ usage: $(selector).mCustomScrollbar("destroy");
760
+ */
761
+ destroy:function(){
762
+
763
+ var selector=_selector.call(this); /* validate selector */
764
+
765
+ return $(selector).each(function(){
766
+
767
+ var $this=$(this);
768
+
769
+ if($this.data(pluginPfx)){ /* check if plugin has initialized */
770
+
771
+ var d=$this.data(pluginPfx),o=d.opt,
772
+ mCustomScrollBox=$("#mCSB_"+d.idx),
773
+ mCSB_container=$("#mCSB_"+d.idx+"_container"),
774
+ scrollbar=$(".mCSB_"+d.idx+"_scrollbar");
775
+
776
+ if(o.live){removeLiveTimers(o.liveSelector || $(selector).selector);} /* remove live timers */
777
+
778
+ _autoUpdate.call(this,"remove"); /* remove automatic updating */
779
+
780
+ _unbindEvents.call(this); /* unbind events */
781
+
782
+ _resetContentPosition.call(this); /* reset content position */
783
+
784
+ $this.removeData(pluginPfx); /* remove plugin data object */
785
+
786
+ _delete(this,"mcs"); /* delete callbacks object */
787
+
788
+ /* remove plugin markup */
789
+ scrollbar.remove(); /* remove scrollbar(s) first (those can be either inside or outside plugin's inner wrapper) */
790
+ mCSB_container.find("img."+classes[2]).removeClass(classes[2]); /* remove loaded images flag */
791
+ mCustomScrollBox.replaceWith(mCSB_container.contents()); /* replace plugin's inner wrapper with the original content */
792
+ /* remove plugin classes from the element and add destroy class */
793
+ $this.removeClass(pluginNS+" _"+pluginPfx+"_"+d.idx+" "+classes[6]+" "+classes[7]+" "+classes[5]+" "+classes[3]).addClass(classes[4]);
794
+
795
+ }
796
+
797
+ });
798
+
799
+ }
800
+ /* ---------------------------------------- */
801
+
802
+ },
803
+
804
+
805
+
806
+
807
+
808
+ /*
809
+ ----------------------------------------
810
+ FUNCTIONS
811
+ ----------------------------------------
812
+ */
813
+
814
+ /* validates selector (if selector is invalid or undefined uses the default one) */
815
+ _selector=function(){
816
+ return (typeof $(this)!=="object" || $(this).length<1) ? defaultSelector : this;
817
+ },
818
+ /* -------------------- */
819
+
820
+
821
+ /* changes options according to theme */
822
+ _theme=function(obj){
823
+ var fixedSizeScrollbarThemes=["rounded","rounded-dark","rounded-dots","rounded-dots-dark"],
824
+ nonExpandedScrollbarThemes=["rounded-dots","rounded-dots-dark","3d","3d-dark","3d-thick","3d-thick-dark","inset","inset-dark","inset-2","inset-2-dark","inset-3","inset-3-dark"],
825
+ disabledScrollButtonsThemes=["minimal","minimal-dark"],
826
+ enabledAutoHideScrollbarThemes=["minimal","minimal-dark"],
827
+ scrollbarPositionOutsideThemes=["minimal","minimal-dark"];
828
+ obj.autoDraggerLength=$.inArray(obj.theme,fixedSizeScrollbarThemes) > -1 ? false : obj.autoDraggerLength;
829
+ obj.autoExpandScrollbar=$.inArray(obj.theme,nonExpandedScrollbarThemes) > -1 ? false : obj.autoExpandScrollbar;
830
+ obj.scrollButtons.enable=$.inArray(obj.theme,disabledScrollButtonsThemes) > -1 ? false : obj.scrollButtons.enable;
831
+ obj.autoHideScrollbar=$.inArray(obj.theme,enabledAutoHideScrollbarThemes) > -1 ? true : obj.autoHideScrollbar;
832
+ obj.scrollbarPosition=$.inArray(obj.theme,scrollbarPositionOutsideThemes) > -1 ? "outside" : obj.scrollbarPosition;
833
+ },
834
+ /* -------------------- */
835
+
836
+
837
+ /* live option timers removal */
838
+ removeLiveTimers=function(selector){
839
+ if(liveTimers[selector]){
840
+ clearTimeout(liveTimers[selector]);
841
+ _delete(liveTimers,selector);
842
+ }
843
+ },
844
+ /* -------------------- */
845
+
846
+
847
+ /* normalizes axis option to valid values: "y", "x", "yx" */
848
+ _findAxis=function(val){
849
+ return (val==="yx" || val==="xy" || val==="auto") ? "yx" : (val==="x" || val==="horizontal") ? "x" : "y";
850
+ },
851
+ /* -------------------- */
852
+
853
+
854
+ /* normalizes scrollButtons.scrollType option to valid values: "stepless", "stepped" */
855
+ _findScrollButtonsType=function(val){
856
+ return (val==="stepped" || val==="pixels" || val==="step" || val==="click") ? "stepped" : "stepless";
857
+ },
858
+ /* -------------------- */
859
+
860
+
861
+ /* generates plugin markup */
862
+ _pluginMarkup=function(){
863
+ var $this=$(this),d=$this.data(pluginPfx),o=d.opt,
864
+ expandClass=o.autoExpandScrollbar ? " "+classes[1]+"_expand" : "",
865
+ scrollbar=["<div id='mCSB_"+d.idx+"_scrollbar_vertical' class='mCSB_scrollTools mCSB_"+d.idx+"_scrollbar mCS-"+o.theme+" mCSB_scrollTools_vertical"+expandClass+"'><div class='"+classes[12]+"'><div id='mCSB_"+d.idx+"_dragger_vertical' class='mCSB_dragger' style='position:absolute;'><div class='mCSB_dragger_bar' /></div><div class='mCSB_draggerRail' /></div></div>","<div id='mCSB_"+d.idx+"_scrollbar_horizontal' class='mCSB_scrollTools mCSB_"+d.idx+"_scrollbar mCS-"+o.theme+" mCSB_scrollTools_horizontal"+expandClass+"'><div class='"+classes[12]+"'><div id='mCSB_"+d.idx+"_dragger_horizontal' class='mCSB_dragger' style='position:absolute;'><div class='mCSB_dragger_bar' /></div><div class='mCSB_draggerRail' /></div></div>"],
866
+ wrapperClass=o.axis==="yx" ? "mCSB_vertical_horizontal" : o.axis==="x" ? "mCSB_horizontal" : "mCSB_vertical",
867
+ scrollbars=o.axis==="yx" ? scrollbar[0]+scrollbar[1] : o.axis==="x" ? scrollbar[1] : scrollbar[0],
868
+ contentWrapper=o.axis==="yx" ? "<div id='mCSB_"+d.idx+"_container_wrapper' class='mCSB_container_wrapper' />" : "",
869
+ autoHideClass=o.autoHideScrollbar ? " "+classes[6] : "",
870
+ scrollbarDirClass=(o.axis!=="x" && d.langDir==="rtl") ? " "+classes[7] : "";
871
+ if(o.setWidth){$this.css("width",o.setWidth);} /* set element width */
872
+ if(o.setHeight){$this.css("height",o.setHeight);} /* set element height */
873
+ o.setLeft=(o.axis!=="y" && d.langDir==="rtl") ? "989999px" : o.setLeft; /* adjust left position for rtl direction */
874
+ $this.addClass(pluginNS+" _"+pluginPfx+"_"+d.idx+autoHideClass+scrollbarDirClass).wrapInner("<div id='mCSB_"+d.idx+"' class='mCustomScrollBox mCS-"+o.theme+" "+wrapperClass+"'><div id='mCSB_"+d.idx+"_container' class='mCSB_container' style='position:relative; top:"+o.setTop+"; left:"+o.setLeft+";' dir='"+d.langDir+"' /></div>");
875
+ var mCustomScrollBox=$("#mCSB_"+d.idx),
876
+ mCSB_container=$("#mCSB_"+d.idx+"_container");
877
+ if(o.axis!=="y" && !o.advanced.autoExpandHorizontalScroll){
878
+ mCSB_container.css("width",_contentWidth(mCSB_container));
879
+ }
880
+ if(o.scrollbarPosition==="outside"){
881
+ if($this.css("position")==="static"){ /* requires elements with non-static position */
882
+ $this.css("position","relative");
883
+ }
884
+ $this.css("overflow","visible");
885
+ mCustomScrollBox.addClass("mCSB_outside").after(scrollbars);
886
+ }else{
887
+ mCustomScrollBox.addClass("mCSB_inside").append(scrollbars);
888
+ mCSB_container.wrap(contentWrapper);
889
+ }
890
+ _scrollButtons.call(this); /* add scrollbar buttons */
891
+ /* minimum dragger length */
892
+ var mCSB_dragger=[$("#mCSB_"+d.idx+"_dragger_vertical"),$("#mCSB_"+d.idx+"_dragger_horizontal")];
893
+ mCSB_dragger[0].css("min-height",mCSB_dragger[0].height());
894
+ mCSB_dragger[1].css("min-width",mCSB_dragger[1].width());
895
+ },
896
+ /* -------------------- */
897
+
898
+
899
+ /* calculates content width */
900
+ _contentWidth=function(el){
901
+ var val=[el[0].scrollWidth,Math.max.apply(Math,el.children().map(function(){return $(this).outerWidth(true);}).get())],w=el.parent().width();
902
+ return val[0]>w ? val[0] : val[1]>w ? val[1] : "100%";
903
+ },
904
+ /* -------------------- */
905
+
906
+
907
+ /* expands content horizontally */
908
+ _expandContentHorizontally=function(){
909
+ var $this=$(this),d=$this.data(pluginPfx),o=d.opt,
910
+ mCSB_container=$("#mCSB_"+d.idx+"_container");
911
+ if(o.advanced.autoExpandHorizontalScroll && o.axis!=="y"){
912
+ /* calculate scrollWidth */
913
+ mCSB_container.css({"width":"auto","min-width":0,"overflow-x":"scroll"});
914
+ var w=Math.ceil(mCSB_container[0].scrollWidth);
915
+ if(o.advanced.autoExpandHorizontalScroll===3 || (o.advanced.autoExpandHorizontalScroll!==2 && w>mCSB_container.parent().width())){
916
+ mCSB_container.css({"width":w,"min-width":"100%","overflow-x":"inherit"});
917
+ }else{
918
+ /*
919
+ wrap content with an infinite width div and set its position to absolute and width to auto.
920
+ Setting width to auto before calculating the actual width is important!
921
+ We must let the browser set the width as browser zoom values are impossible to calculate.
922
+ */
923
+ mCSB_container.css({"overflow-x":"inherit","position":"absolute"})
924
+ .wrap("<div class='mCSB_h_wrapper' style='position:relative; left:0; width:999999px;' />")
925
+ .css({ /* set actual width, original position and un-wrap */
926
+ /*
927
+ get the exact width (with decimals) and then round-up.
928
+ Using jquery outerWidth() will round the width value which will mess up with inner elements that have non-integer width
929
+ */
930
+ "width":(Math.ceil(mCSB_container[0].getBoundingClientRect().right+0.4)-Math.floor(mCSB_container[0].getBoundingClientRect().left)),
931
+ "min-width":"100%",
932
+ "position":"relative"
933
+ }).unwrap();
934
+ }
935
+ }
936
+ },
937
+ /* -------------------- */
938
+
939
+
940
+ /* adds scrollbar buttons */
941
+ _scrollButtons=function(){
942
+ var $this=$(this),d=$this.data(pluginPfx),o=d.opt,
943
+ mCSB_scrollTools=$(".mCSB_"+d.idx+"_scrollbar:first"),
944
+ tabindex=!_isNumeric(o.scrollButtons.tabindex) ? "" : "tabindex='"+o.scrollButtons.tabindex+"'",
945
+ btnHTML=[
946
+ "<a href='#' class='"+classes[13]+"' "+tabindex+" />",
947
+ "<a href='#' class='"+classes[14]+"' "+tabindex+" />",
948
+ "<a href='#' class='"+classes[15]+"' "+tabindex+" />",
949
+ "<a href='#' class='"+classes[16]+"' "+tabindex+" />"
950
+ ],
951
+ btn=[(o.axis==="x" ? btnHTML[2] : btnHTML[0]),(o.axis==="x" ? btnHTML[3] : btnHTML[1]),btnHTML[2],btnHTML[3]];
952
+ if(o.scrollButtons.enable){
953
+ mCSB_scrollTools.prepend(btn[0]).append(btn[1]).next(".mCSB_scrollTools").prepend(btn[2]).append(btn[3]);
954
+ }
955
+ },
956
+ /* -------------------- */
957
+
958
+
959
+ /* auto-adjusts scrollbar dragger length */
960
+ _setDraggerLength=function(){
961
+ var $this=$(this),d=$this.data(pluginPfx),
962
+ mCustomScrollBox=$("#mCSB_"+d.idx),
963
+ mCSB_container=$("#mCSB_"+d.idx+"_container"),
964
+ mCSB_dragger=[$("#mCSB_"+d.idx+"_dragger_vertical"),$("#mCSB_"+d.idx+"_dragger_horizontal")],
965
+ ratio=[mCustomScrollBox.height()/mCSB_container.outerHeight(false),mCustomScrollBox.width()/mCSB_container.outerWidth(false)],
966
+ l=[
967
+ parseInt(mCSB_dragger[0].css("min-height")),Math.round(ratio[0]*mCSB_dragger[0].parent().height()),
968
+ parseInt(mCSB_dragger[1].css("min-width")),Math.round(ratio[1]*mCSB_dragger[1].parent().width())
969
+ ],
970
+ h=oldIE && (l[1]<l[0]) ? l[0] : l[1],w=oldIE && (l[3]<l[2]) ? l[2] : l[3];
971
+ mCSB_dragger[0].css({
972
+ "height":h,"max-height":(mCSB_dragger[0].parent().height()-10)
973
+ }).find(".mCSB_dragger_bar").css({"line-height":l[0]+"px"});
974
+ mCSB_dragger[1].css({
975
+ "width":w,"max-width":(mCSB_dragger[1].parent().width()-10)
976
+ });
977
+ },
978
+ /* -------------------- */
979
+
980
+
981
+ /* calculates scrollbar to content ratio */
982
+ _scrollRatio=function(){
983
+ var $this=$(this),d=$this.data(pluginPfx),
984
+ mCustomScrollBox=$("#mCSB_"+d.idx),
985
+ mCSB_container=$("#mCSB_"+d.idx+"_container"),
986
+ mCSB_dragger=[$("#mCSB_"+d.idx+"_dragger_vertical"),$("#mCSB_"+d.idx+"_dragger_horizontal")],
987
+ scrollAmount=[mCSB_container.outerHeight(false)-mCustomScrollBox.height(),mCSB_container.outerWidth(false)-mCustomScrollBox.width()],
988
+ ratio=[
989
+ scrollAmount[0]/(mCSB_dragger[0].parent().height()-mCSB_dragger[0].height()),
990
+ scrollAmount[1]/(mCSB_dragger[1].parent().width()-mCSB_dragger[1].width())
991
+ ];
992
+ d.scrollRatio={y:ratio[0],x:ratio[1]};
993
+ },
994
+ /* -------------------- */
995
+
996
+
997
+ /* toggles scrolling classes */
998
+ _onDragClasses=function(el,action,xpnd){
999
+ var expandClass=xpnd ? classes[0]+"_expanded" : "",
1000
+ scrollbar=el.closest(".mCSB_scrollTools");
1001
+ if(action==="active"){
1002
+ el.toggleClass(classes[0]+" "+expandClass); scrollbar.toggleClass(classes[1]);
1003
+ el[0]._draggable=el[0]._draggable ? 0 : 1;
1004
+ }else{
1005
+ if(!el[0]._draggable){
1006
+ if(action==="hide"){
1007
+ el.removeClass(classes[0]); scrollbar.removeClass(classes[1]);
1008
+ }else{
1009
+ el.addClass(classes[0]); scrollbar.addClass(classes[1]);
1010
+ }
1011
+ }
1012
+ }
1013
+ },
1014
+ /* -------------------- */
1015
+
1016
+
1017
+ /* checks if content overflows its container to determine if scrolling is required */
1018
+ _overflowed=function(){
1019
+ var $this=$(this),d=$this.data(pluginPfx),
1020
+ mCustomScrollBox=$("#mCSB_"+d.idx),
1021
+ mCSB_container=$("#mCSB_"+d.idx+"_container"),
1022
+ contentHeight=d.overflowed==null ? mCSB_container.height() : mCSB_container.outerHeight(false),
1023
+ contentWidth=d.overflowed==null ? mCSB_container.width() : mCSB_container.outerWidth(false),
1024
+ h=mCSB_container[0].scrollHeight,w=mCSB_container[0].scrollWidth;
1025
+ if(h>contentHeight){contentHeight=h;}
1026
+ if(w>contentWidth){contentWidth=w;}
1027
+ return [contentHeight>mCustomScrollBox.height(),contentWidth>mCustomScrollBox.width()];
1028
+ },
1029
+ /* -------------------- */
1030
+
1031
+
1032
+ /* resets content position to 0 */
1033
+ _resetContentPosition=function(){
1034
+ var $this=$(this),d=$this.data(pluginPfx),o=d.opt,
1035
+ mCustomScrollBox=$("#mCSB_"+d.idx),
1036
+ mCSB_container=$("#mCSB_"+d.idx+"_container"),
1037
+ mCSB_dragger=[$("#mCSB_"+d.idx+"_dragger_vertical"),$("#mCSB_"+d.idx+"_dragger_horizontal")];
1038
+ _stop($this); /* stop any current scrolling before resetting */
1039
+ if((o.axis!=="x" && !d.overflowed[0]) || (o.axis==="y" && d.overflowed[0])){ /* reset y */
1040
+ mCSB_dragger[0].add(mCSB_container).css("top",0);
1041
+ _scrollTo($this,"_resetY");
1042
+ }
1043
+ if((o.axis!=="y" && !d.overflowed[1]) || (o.axis==="x" && d.overflowed[1])){ /* reset x */
1044
+ var cx=dx=0;
1045
+ if(d.langDir==="rtl"){ /* adjust left position for rtl direction */
1046
+ cx=mCustomScrollBox.width()-mCSB_container.outerWidth(false);
1047
+ dx=Math.abs(cx/d.scrollRatio.x);
1048
+ }
1049
+ mCSB_container.css("left",cx);
1050
+ mCSB_dragger[1].css("left",dx);
1051
+ _scrollTo($this,"_resetX");
1052
+ }
1053
+ },
1054
+ /* -------------------- */
1055
+
1056
+
1057
+ /* binds scrollbar events */
1058
+ _bindEvents=function(){
1059
+ var $this=$(this),d=$this.data(pluginPfx),o=d.opt;
1060
+ if(!d.bindEvents){ /* check if events are already bound */
1061
+ _draggable.call(this);
1062
+ if(o.contentTouchScroll){_contentDraggable.call(this);}
1063
+ _selectable.call(this);
1064
+ if(o.mouseWheel.enable){ /* bind mousewheel fn when plugin is available */
1065
+ function _mwt(){
1066
+ mousewheelTimeout=setTimeout(function(){
1067
+ if(!$.event.special.mousewheel){
1068
+ _mwt();
1069
+ }else{
1070
+ clearTimeout(mousewheelTimeout);
1071
+ _mousewheel.call($this[0]);
1072
+ }
1073
+ },100);
1074
+ }
1075
+ var mousewheelTimeout;
1076
+ _mwt();
1077
+ }
1078
+ _draggerRail.call(this);
1079
+ _wrapperScroll.call(this);
1080
+ if(o.advanced.autoScrollOnFocus){_focus.call(this);}
1081
+ if(o.scrollButtons.enable){_buttons.call(this);}
1082
+ if(o.keyboard.enable){_keyboard.call(this);}
1083
+ d.bindEvents=true;
1084
+ }
1085
+ },
1086
+ /* -------------------- */
1087
+
1088
+
1089
+ /* unbinds scrollbar events */
1090
+ _unbindEvents=function(){
1091
+ var $this=$(this),d=$this.data(pluginPfx),o=d.opt,
1092
+ namespace=pluginPfx+"_"+d.idx,
1093
+ sb=".mCSB_"+d.idx+"_scrollbar",
1094
+ sel=$("#mCSB_"+d.idx+",#mCSB_"+d.idx+"_container,#mCSB_"+d.idx+"_container_wrapper,"+sb+" ."+classes[12]+",#mCSB_"+d.idx+"_dragger_vertical,#mCSB_"+d.idx+"_dragger_horizontal,"+sb+">a"),
1095
+ mCSB_container=$("#mCSB_"+d.idx+"_container");
1096
+ if(o.advanced.releaseDraggableSelectors){sel.add($(o.advanced.releaseDraggableSelectors));}
1097
+ if(o.advanced.extraDraggableSelectors){sel.add($(o.advanced.extraDraggableSelectors));}
1098
+ if(d.bindEvents){ /* check if events are bound */
1099
+ /* unbind namespaced events from document/selectors */
1100
+ $(document).add($(!_canAccessIFrame() || top.document)).unbind("."+namespace);
1101
+ sel.each(function(){
1102
+ $(this).unbind("."+namespace);
1103
+ });
1104
+ /* clear and delete timeouts/objects */
1105
+ clearTimeout($this[0]._focusTimeout); _delete($this[0],"_focusTimeout");
1106
+ clearTimeout(d.sequential.step); _delete(d.sequential,"step");
1107
+ clearTimeout(mCSB_container[0].onCompleteTimeout); _delete(mCSB_container[0],"onCompleteTimeout");
1108
+ d.bindEvents=false;
1109
+ }
1110
+ },
1111
+ /* -------------------- */
1112
+
1113
+
1114
+ /* toggles scrollbar visibility */
1115
+ _scrollbarVisibility=function(disabled){
1116
+ var $this=$(this),d=$this.data(pluginPfx),o=d.opt,
1117
+ contentWrapper=$("#mCSB_"+d.idx+"_container_wrapper"),
1118
+ content=contentWrapper.length ? contentWrapper : $("#mCSB_"+d.idx+"_container"),
1119
+ scrollbar=[$("#mCSB_"+d.idx+"_scrollbar_vertical"),$("#mCSB_"+d.idx+"_scrollbar_horizontal")],
1120
+ mCSB_dragger=[scrollbar[0].find(".mCSB_dragger"),scrollbar[1].find(".mCSB_dragger")];
1121
+ if(o.axis!=="x"){
1122
+ if(d.overflowed[0] && !disabled){
1123
+ scrollbar[0].add(mCSB_dragger[0]).add(scrollbar[0].children("a")).css("display","block");
1124
+ content.removeClass(classes[8]+" "+classes[10]);
1125
+ }else{
1126
+ if(o.alwaysShowScrollbar){
1127
+ if(o.alwaysShowScrollbar!==2){mCSB_dragger[0].css("display","none");}
1128
+ content.removeClass(classes[10]);
1129
+ }else{
1130
+ scrollbar[0].css("display","none");
1131
+ content.addClass(classes[10]);
1132
+ }
1133
+ content.addClass(classes[8]);
1134
+ }
1135
+ }
1136
+ if(o.axis!=="y"){
1137
+ if(d.overflowed[1] && !disabled){
1138
+ scrollbar[1].add(mCSB_dragger[1]).add(scrollbar[1].children("a")).css("display","block");
1139
+ content.removeClass(classes[9]+" "+classes[11]);
1140
+ }else{
1141
+ if(o.alwaysShowScrollbar){
1142
+ if(o.alwaysShowScrollbar!==2){mCSB_dragger[1].css("display","none");}
1143
+ content.removeClass(classes[11]);
1144
+ }else{
1145
+ scrollbar[1].css("display","none");
1146
+ content.addClass(classes[11]);
1147
+ }
1148
+ content.addClass(classes[9]);
1149
+ }
1150
+ }
1151
+ if(!d.overflowed[0] && !d.overflowed[1]){
1152
+ $this.addClass(classes[5]);
1153
+ }else{
1154
+ $this.removeClass(classes[5]);
1155
+ }
1156
+ },
1157
+ /* -------------------- */
1158
+
1159
+
1160
+ /* returns input coordinates of pointer, touch and mouse events (relative to document) */
1161
+ _coordinates=function(e){
1162
+ var t=e.type,o=e.target.ownerDocument!==document && frameElement!==null ? [$(frameElement).offset().top,$(frameElement).offset().left] : null,
1163
+ io=_canAccessIFrame() && e.target.ownerDocument!==top.document && frameElement!==null ? [$(e.view.frameElement).offset().top,$(e.view.frameElement).offset().left] : [0,0];
1164
+ switch(t){
1165
+ case "pointerdown": case "MSPointerDown": case "pointermove": case "MSPointerMove": case "pointerup": case "MSPointerUp":
1166
+ return o ? [e.originalEvent.pageY-o[0]+io[0],e.originalEvent.pageX-o[1]+io[1],false] : [e.originalEvent.pageY,e.originalEvent.pageX,false];
1167
+ break;
1168
+ case "touchstart": case "touchmove": case "touchend":
1169
+ var touch=e.originalEvent.touches[0] || e.originalEvent.changedTouches[0],
1170
+ touches=e.originalEvent.touches.length || e.originalEvent.changedTouches.length;
1171
+ return e.target.ownerDocument!==document ? [touch.screenY,touch.screenX,touches>1] : [touch.pageY,touch.pageX,touches>1];
1172
+ break;
1173
+ default:
1174
+ return o ? [e.pageY-o[0]+io[0],e.pageX-o[1]+io[1],false] : [e.pageY,e.pageX,false];
1175
+ }
1176
+ },
1177
+ /* -------------------- */
1178
+
1179
+
1180
+ /*
1181
+ SCROLLBAR DRAG EVENTS
1182
+ scrolls content via scrollbar dragging
1183
+ */
1184
+ _draggable=function(){
1185
+ var $this=$(this),d=$this.data(pluginPfx),o=d.opt,
1186
+ namespace=pluginPfx+"_"+d.idx,
1187
+ draggerId=["mCSB_"+d.idx+"_dragger_vertical","mCSB_"+d.idx+"_dragger_horizontal"],
1188
+ mCSB_container=$("#mCSB_"+d.idx+"_container"),
1189
+ mCSB_dragger=$("#"+draggerId[0]+",#"+draggerId[1]),
1190
+ draggable,dragY,dragX,
1191
+ rds=o.advanced.releaseDraggableSelectors ? mCSB_dragger.add($(o.advanced.releaseDraggableSelectors)) : mCSB_dragger,
1192
+ eds=o.advanced.extraDraggableSelectors ? $(!_canAccessIFrame() || top.document).add($(o.advanced.extraDraggableSelectors)) : $(!_canAccessIFrame() || top.document);
1193
+ mCSB_dragger.bind("contextmenu."+namespace,function(e){
1194
+ e.preventDefault(); //prevent right click
1195
+ }).bind("mousedown."+namespace+" touchstart."+namespace+" pointerdown."+namespace+" MSPointerDown."+namespace,function(e){
1196
+ e.stopImmediatePropagation();
1197
+ e.preventDefault();
1198
+ if(!_mouseBtnLeft(e)){return;} /* left mouse button only */
1199
+ touchActive=true;
1200
+ if(oldIE){document.onselectstart=function(){return false;}} /* disable text selection for IE < 9 */
1201
+ _iframe.call(mCSB_container,false); /* enable scrollbar dragging over iframes by disabling their events */
1202
+ _stop($this);
1203
+ draggable=$(this);
1204
+ var offset=draggable.offset(),y=_coordinates(e)[0]-offset.top,x=_coordinates(e)[1]-offset.left,
1205
+ h=draggable.height()+offset.top,w=draggable.width()+offset.left;
1206
+ if(y<h && y>0 && x<w && x>0){
1207
+ dragY=y;
1208
+ dragX=x;
1209
+ }
1210
+ _onDragClasses(draggable,"active",o.autoExpandScrollbar);
1211
+ }).bind("touchmove."+namespace,function(e){
1212
+ e.stopImmediatePropagation();
1213
+ e.preventDefault();
1214
+ var offset=draggable.offset(),y=_coordinates(e)[0]-offset.top,x=_coordinates(e)[1]-offset.left;
1215
+ _drag(dragY,dragX,y,x);
1216
+ });
1217
+ $(document).add(eds).bind("mousemove."+namespace+" pointermove."+namespace+" MSPointerMove."+namespace,function(e){
1218
+ if(draggable){
1219
+ var offset=draggable.offset(),y=_coordinates(e)[0]-offset.top,x=_coordinates(e)[1]-offset.left;
1220
+ if(dragY===y && dragX===x){return;} /* has it really moved? */
1221
+ _drag(dragY,dragX,y,x);
1222
+ }
1223
+ }).add(rds).bind("mouseup."+namespace+" touchend."+namespace+" pointerup."+namespace+" MSPointerUp."+namespace,function(e){
1224
+ if(draggable){
1225
+ _onDragClasses(draggable,"active",o.autoExpandScrollbar);
1226
+ draggable=null;
1227
+ }
1228
+ touchActive=false;
1229
+ if(oldIE){document.onselectstart=null;} /* enable text selection for IE < 9 */
1230
+ _iframe.call(mCSB_container,true); /* enable iframes events */
1231
+ });
1232
+ function _drag(dragY,dragX,y,x){
1233
+ mCSB_container[0].idleTimer=o.scrollInertia<233 ? 250 : 0;
1234
+ if(draggable.attr("id")===draggerId[1]){
1235
+ var dir="x",to=((draggable[0].offsetLeft-dragX)+x)*d.scrollRatio.x;
1236
+ }else{
1237
+ var dir="y",to=((draggable[0].offsetTop-dragY)+y)*d.scrollRatio.y;
1238
+ }
1239
+ _scrollTo($this,to.toString(),{dir:dir,drag:true});
1240
+ }
1241
+ },
1242
+ /* -------------------- */
1243
+
1244
+
1245
+ /*
1246
+ TOUCH SWIPE EVENTS
1247
+ scrolls content via touch swipe
1248
+ Emulates the native touch-swipe scrolling with momentum found in iOS, Android and WP devices
1249
+ */
1250
+ _contentDraggable=function(){
1251
+ var $this=$(this),d=$this.data(pluginPfx),o=d.opt,
1252
+ namespace=pluginPfx+"_"+d.idx,
1253
+ mCustomScrollBox=$("#mCSB_"+d.idx),
1254
+ mCSB_container=$("#mCSB_"+d.idx+"_container"),
1255
+ mCSB_dragger=[$("#mCSB_"+d.idx+"_dragger_vertical"),$("#mCSB_"+d.idx+"_dragger_horizontal")],
1256
+ draggable,dragY,dragX,touchStartY,touchStartX,touchMoveY=[],touchMoveX=[],startTime,runningTime,endTime,distance,speed,amount,
1257
+ durA=0,durB,overwrite=o.axis==="yx" ? "none" : "all",touchIntent=[],touchDrag,docDrag,
1258
+ iframe=mCSB_container.find("iframe"),
1259
+ events=[
1260
+ "touchstart."+namespace+" pointerdown."+namespace+" MSPointerDown."+namespace, //start
1261
+ "touchmove."+namespace+" pointermove."+namespace+" MSPointerMove."+namespace, //move
1262
+ "touchend."+namespace+" pointerup."+namespace+" MSPointerUp."+namespace //end
1263
+ ],
1264
+ touchAction=document.body.style.touchAction!==undefined && document.body.style.touchAction!=="";
1265
+ mCSB_container.bind(events[0],function(e){
1266
+ _onTouchstart(e);
1267
+ }).bind(events[1],function(e){
1268
+ _onTouchmove(e);
1269
+ });
1270
+ mCustomScrollBox.bind(events[0],function(e){
1271
+ _onTouchstart2(e);
1272
+ }).bind(events[2],function(e){
1273
+ _onTouchend(e);
1274
+ });
1275
+ if(iframe.length){
1276
+ iframe.each(function(){
1277
+ $(this).bind("load",function(){
1278
+ /* bind events on accessible iframes */
1279
+ if(_canAccessIFrame(this)){
1280
+ $(this.contentDocument || this.contentWindow.document).bind(events[0],function(e){
1281
+ _onTouchstart(e);
1282
+ _onTouchstart2(e);
1283
+ }).bind(events[1],function(e){
1284
+ _onTouchmove(e);
1285
+ }).bind(events[2],function(e){
1286
+ _onTouchend(e);
1287
+ });
1288
+ }
1289
+ });
1290
+ });
1291
+ }
1292
+ function _onTouchstart(e){
1293
+ if(!_pointerTouch(e) || touchActive || _coordinates(e)[2]){touchable=0; return;}
1294
+ touchable=1; touchDrag=0; docDrag=0; draggable=1;
1295
+ $this.removeClass("mCS_touch_action");
1296
+ var offset=mCSB_container.offset();
1297
+ dragY=_coordinates(e)[0]-offset.top;
1298
+ dragX=_coordinates(e)[1]-offset.left;
1299
+ touchIntent=[_coordinates(e)[0],_coordinates(e)[1]];
1300
+ }
1301
+ function _onTouchmove(e){
1302
+ if(!_pointerTouch(e) || touchActive || _coordinates(e)[2]){return;}
1303
+ if(!o.documentTouchScroll){e.preventDefault();}
1304
+ e.stopImmediatePropagation();
1305
+ if(docDrag && !touchDrag){return;}
1306
+ if(draggable){
1307
+ runningTime=_getTime();
1308
+ var offset=mCustomScrollBox.offset(),y=_coordinates(e)[0]-offset.top,x=_coordinates(e)[1]-offset.left,
1309
+ easing="mcsLinearOut";
1310
+ touchMoveY.push(y);
1311
+ touchMoveX.push(x);
1312
+ touchIntent[2]=Math.abs(_coordinates(e)[0]-touchIntent[0]); touchIntent[3]=Math.abs(_coordinates(e)[1]-touchIntent[1]);
1313
+ if(d.overflowed[0]){
1314
+ var limit=mCSB_dragger[0].parent().height()-mCSB_dragger[0].height(),
1315
+ prevent=((dragY-y)>0 && (y-dragY)>-(limit*d.scrollRatio.y) && (touchIntent[3]*2<touchIntent[2] || o.axis==="yx"));
1316
+ }
1317
+ if(d.overflowed[1]){
1318
+ var limitX=mCSB_dragger[1].parent().width()-mCSB_dragger[1].width(),
1319
+ preventX=((dragX-x)>0 && (x-dragX)>-(limitX*d.scrollRatio.x) && (touchIntent[2]*2<touchIntent[3] || o.axis==="yx"));
1320
+ }
1321
+ if(prevent || preventX){ /* prevent native document scrolling */
1322
+ if(!touchAction){e.preventDefault();}
1323
+ touchDrag=1;
1324
+ }else{
1325
+ docDrag=1;
1326
+ $this.addClass("mCS_touch_action");
1327
+ }
1328
+ if(touchAction){e.preventDefault();}
1329
+ amount=o.axis==="yx" ? [(dragY-y),(dragX-x)] : o.axis==="x" ? [null,(dragX-x)] : [(dragY-y),null];
1330
+ mCSB_container[0].idleTimer=250;
1331
+ if(d.overflowed[0]){_drag(amount[0],durA,easing,"y","all",true);}
1332
+ if(d.overflowed[1]){_drag(amount[1],durA,easing,"x",overwrite,true);}
1333
+ }
1334
+ }
1335
+ function _onTouchstart2(e){
1336
+ if(!_pointerTouch(e) || touchActive || _coordinates(e)[2]){touchable=0; return;}
1337
+ touchable=1;
1338
+ e.stopImmediatePropagation();
1339
+ _stop($this);
1340
+ startTime=_getTime();
1341
+ var offset=mCustomScrollBox.offset();
1342
+ touchStartY=_coordinates(e)[0]-offset.top;
1343
+ touchStartX=_coordinates(e)[1]-offset.left;
1344
+ touchMoveY=[]; touchMoveX=[];
1345
+ }
1346
+ function _onTouchend(e){
1347
+ if(!_pointerTouch(e) || touchActive || _coordinates(e)[2]){return;}
1348
+ draggable=0;
1349
+ e.stopImmediatePropagation();
1350
+ touchDrag=0; docDrag=0;
1351
+ endTime=_getTime();
1352
+ var offset=mCustomScrollBox.offset(),y=_coordinates(e)[0]-offset.top,x=_coordinates(e)[1]-offset.left;
1353
+ if((endTime-runningTime)>30){return;}
1354
+ speed=1000/(endTime-startTime);
1355
+ var easing="mcsEaseOut",slow=speed<2.5,
1356
+ diff=slow ? [touchMoveY[touchMoveY.length-2],touchMoveX[touchMoveX.length-2]] : [0,0];
1357
+ distance=slow ? [(y-diff[0]),(x-diff[1])] : [y-touchStartY,x-touchStartX];
1358
+ var absDistance=[Math.abs(distance[0]),Math.abs(distance[1])];
1359
+ speed=slow ? [Math.abs(distance[0]/4),Math.abs(distance[1]/4)] : [speed,speed];
1360
+ var a=[
1361
+ Math.abs(mCSB_container[0].offsetTop)-(distance[0]*_m((absDistance[0]/speed[0]),speed[0])),
1362
+ Math.abs(mCSB_container[0].offsetLeft)-(distance[1]*_m((absDistance[1]/speed[1]),speed[1]))
1363
+ ];
1364
+ amount=o.axis==="yx" ? [a[0],a[1]] : o.axis==="x" ? [null,a[1]] : [a[0],null];
1365
+ durB=[(absDistance[0]*4)+o.scrollInertia,(absDistance[1]*4)+o.scrollInertia];
1366
+ var md=parseInt(o.contentTouchScroll) || 0; /* absolute minimum distance required */
1367
+ amount[0]=absDistance[0]>md ? amount[0] : 0;
1368
+ amount[1]=absDistance[1]>md ? amount[1] : 0;
1369
+ if(d.overflowed[0]){_drag(amount[0],durB[0],easing,"y",overwrite,false);}
1370
+ if(d.overflowed[1]){_drag(amount[1],durB[1],easing,"x",overwrite,false);}
1371
+ }
1372
+ function _m(ds,s){
1373
+ var r=[s*1.5,s*2,s/1.5,s/2];
1374
+ if(ds>90){
1375
+ return s>4 ? r[0] : r[3];
1376
+ }else if(ds>60){
1377
+ return s>3 ? r[3] : r[2];
1378
+ }else if(ds>30){
1379
+ return s>8 ? r[1] : s>6 ? r[0] : s>4 ? s : r[2];
1380
+ }else{
1381
+ return s>8 ? s : r[3];
1382
+ }
1383
+ }
1384
+ function _drag(amount,dur,easing,dir,overwrite,drag){
1385
+ if(!amount){return;}
1386
+ _scrollTo($this,amount.toString(),{dur:dur,scrollEasing:easing,dir:dir,overwrite:overwrite,drag:drag});
1387
+ }
1388
+ },
1389
+ /* -------------------- */
1390
+
1391
+
1392
+ /*
1393
+ SELECT TEXT EVENTS
1394
+ scrolls content when text is selected
1395
+ */
1396
+ _selectable=function(){
1397
+ var $this=$(this),d=$this.data(pluginPfx),o=d.opt,seq=d.sequential,
1398
+ namespace=pluginPfx+"_"+d.idx,
1399
+ mCSB_container=$("#mCSB_"+d.idx+"_container"),
1400
+ wrapper=mCSB_container.parent(),
1401
+ action;
1402
+ mCSB_container.bind("mousedown."+namespace,function(e){
1403
+ if(touchable){return;}
1404
+ if(!action){action=1; touchActive=true;}
1405
+ }).add(document).bind("mousemove."+namespace,function(e){
1406
+ if(!touchable && action && _sel()){
1407
+ var offset=mCSB_container.offset(),
1408
+ y=_coordinates(e)[0]-offset.top+mCSB_container[0].offsetTop,x=_coordinates(e)[1]-offset.left+mCSB_container[0].offsetLeft;
1409
+ if(y>0 && y<wrapper.height() && x>0 && x<wrapper.width()){
1410
+ if(seq.step){_seq("off",null,"stepped");}
1411
+ }else{
1412
+ if(o.axis!=="x" && d.overflowed[0]){
1413
+ if(y<0){
1414
+ _seq("on",38);
1415
+ }else if(y>wrapper.height()){
1416
+ _seq("on",40);
1417
+ }
1418
+ }
1419
+ if(o.axis!=="y" && d.overflowed[1]){
1420
+ if(x<0){
1421
+ _seq("on",37);
1422
+ }else if(x>wrapper.width()){
1423
+ _seq("on",39);
1424
+ }
1425
+ }
1426
+ }
1427
+ }
1428
+ }).bind("mouseup."+namespace+" dragend."+namespace,function(e){
1429
+ if(touchable){return;}
1430
+ if(action){action=0; _seq("off",null);}
1431
+ touchActive=false;
1432
+ });
1433
+ function _sel(){
1434
+ return window.getSelection ? window.getSelection().toString() :
1435
+ document.selection && document.selection.type!="Control" ? document.selection.createRange().text : 0;
1436
+ }
1437
+ function _seq(a,c,s){
1438
+ seq.type=s && action ? "stepped" : "stepless";
1439
+ seq.scrollAmount=10;
1440
+ _sequentialScroll($this,a,c,"mcsLinearOut",s ? 60 : null);
1441
+ }
1442
+ },
1443
+ /* -------------------- */
1444
+
1445
+
1446
+ /*
1447
+ MOUSE WHEEL EVENT
1448
+ scrolls content via mouse-wheel
1449
+ via mouse-wheel plugin (https://github.com/brandonaaron/jquery-mousewheel)
1450
+ */
1451
+ _mousewheel=function(){
1452
+ if(!$(this).data(pluginPfx)){return;} /* Check if the scrollbar is ready to use mousewheel events (issue: #185) */
1453
+ var $this=$(this),d=$this.data(pluginPfx),o=d.opt,
1454
+ namespace=pluginPfx+"_"+d.idx,
1455
+ mCustomScrollBox=$("#mCSB_"+d.idx),
1456
+ mCSB_dragger=[$("#mCSB_"+d.idx+"_dragger_vertical"),$("#mCSB_"+d.idx+"_dragger_horizontal")],
1457
+ iframe=$("#mCSB_"+d.idx+"_container").find("iframe");
1458
+ if(iframe.length){
1459
+ iframe.each(function(){
1460
+ $(this).bind("load",function(){
1461
+ /* bind events on accessible iframes */
1462
+ if(_canAccessIFrame(this)){
1463
+ $(this.contentDocument || this.contentWindow.document).bind("mousewheel."+namespace,function(e,delta){
1464
+ _onMousewheel(e,delta);
1465
+ });
1466
+ }
1467
+ });
1468
+ });
1469
+ }
1470
+ mCustomScrollBox.bind("mousewheel."+namespace,function(e,delta){
1471
+ _onMousewheel(e,delta);
1472
+ });
1473
+ function _onMousewheel(e,delta){
1474
+ _stop($this);
1475
+ if(_disableMousewheel($this,e.target)){return;} /* disables mouse-wheel when hovering specific elements */
1476
+ var deltaFactor=o.mouseWheel.deltaFactor!=="auto" ? parseInt(o.mouseWheel.deltaFactor) : (oldIE && e.deltaFactor<100) ? 100 : e.deltaFactor || 100,
1477
+ dur=o.scrollInertia;
1478
+ if(o.axis==="x" || o.mouseWheel.axis==="x"){
1479
+ var dir="x",
1480
+ px=[Math.round(deltaFactor*d.scrollRatio.x),parseInt(o.mouseWheel.scrollAmount)],
1481
+ amount=o.mouseWheel.scrollAmount!=="auto" ? px[1] : px[0]>=mCustomScrollBox.width() ? mCustomScrollBox.width()*0.9 : px[0],
1482
+ contentPos=Math.abs($("#mCSB_"+d.idx+"_container")[0].offsetLeft),
1483
+ draggerPos=mCSB_dragger[1][0].offsetLeft,
1484
+ limit=mCSB_dragger[1].parent().width()-mCSB_dragger[1].width(),
1485
+ dlt=o.mouseWheel.axis==="y" ? (e.deltaY || delta) : e.deltaX;
1486
+ }else{
1487
+ var dir="y",
1488
+ px=[Math.round(deltaFactor*d.scrollRatio.y),parseInt(o.mouseWheel.scrollAmount)],
1489
+ amount=o.mouseWheel.scrollAmount!=="auto" ? px[1] : px[0]>=mCustomScrollBox.height() ? mCustomScrollBox.height()*0.9 : px[0],
1490
+ contentPos=Math.abs($("#mCSB_"+d.idx+"_container")[0].offsetTop),
1491
+ draggerPos=mCSB_dragger[0][0].offsetTop,
1492
+ limit=mCSB_dragger[0].parent().height()-mCSB_dragger[0].height(),
1493
+ dlt=e.deltaY || delta;
1494
+ }
1495
+ if((dir==="y" && !d.overflowed[0]) || (dir==="x" && !d.overflowed[1])){return;}
1496
+ if(o.mouseWheel.invert || e.webkitDirectionInvertedFromDevice){dlt=-dlt;}
1497
+ if(o.mouseWheel.normalizeDelta){dlt=dlt<0 ? -1 : 1;}
1498
+ if((dlt>0 && draggerPos!==0) || (dlt<0 && draggerPos!==limit) || o.mouseWheel.preventDefault){
1499
+ e.stopImmediatePropagation();
1500
+ e.preventDefault();
1501
+ }
1502
+ if(e.deltaFactor<5 && !o.mouseWheel.normalizeDelta){
1503
+ //very low deltaFactor values mean some kind of delta acceleration (e.g. osx trackpad), so adjusting scrolling accordingly
1504
+ amount=e.deltaFactor; dur=17;
1505
+ }
1506
+ _scrollTo($this,(contentPos-(dlt*amount)).toString(),{dir:dir,dur:dur});
1507
+ }
1508
+ },
1509
+ /* -------------------- */
1510
+
1511
+
1512
+ /* checks if iframe can be accessed */
1513
+ _canAccessIFrameCache=new Object(),
1514
+ _canAccessIFrame=function(iframe){
1515
+ var result=false,cacheKey=false,html=null;
1516
+ if(iframe===undefined){
1517
+ cacheKey="#empty";
1518
+ }else if($(iframe).attr("id")!==undefined){
1519
+ cacheKey=$(iframe).attr("id");
1520
+ }
1521
+ if(cacheKey!==false && _canAccessIFrameCache[cacheKey]!==undefined){
1522
+ return _canAccessIFrameCache[cacheKey];
1523
+ }
1524
+ if(!iframe){
1525
+ try{
1526
+ var doc=top.document;
1527
+ html=doc.body.innerHTML;
1528
+ }catch(err){/* do nothing */}
1529
+ result=(html!==null);
1530
+ }else{
1531
+ try{
1532
+ var doc=iframe.contentDocument || iframe.contentWindow.document;
1533
+ html=doc.body.innerHTML;
1534
+ }catch(err){/* do nothing */}
1535
+ result=(html!==null);
1536
+ }
1537
+ if(cacheKey!==false){_canAccessIFrameCache[cacheKey]=result;}
1538
+ return result;
1539
+ },
1540
+ /* -------------------- */
1541
+
1542
+
1543
+ /* switches iframe's pointer-events property (drag, mousewheel etc. over cross-domain iframes) */
1544
+ _iframe=function(evt){
1545
+ var el=this.find("iframe");
1546
+ if(!el.length){return;} /* check if content contains iframes */
1547
+ var val=!evt ? "none" : "auto";
1548
+ el.css("pointer-events",val); /* for IE11, iframe's display property should not be "block" */
1549
+ },
1550
+ /* -------------------- */
1551
+
1552
+
1553
+ /* disables mouse-wheel when hovering specific elements like select, datalist etc. */
1554
+ _disableMousewheel=function(el,target){
1555
+ var tag=target.nodeName.toLowerCase(),
1556
+ tags=el.data(pluginPfx).opt.mouseWheel.disableOver,
1557
+ /* elements that require focus */
1558
+ focusTags=["select","textarea"];
1559
+ return $.inArray(tag,tags) > -1 && !($.inArray(tag,focusTags) > -1 && !$(target).is(":focus"));
1560
+ },
1561
+ /* -------------------- */
1562
+
1563
+
1564
+ /*
1565
+ DRAGGER RAIL CLICK EVENT
1566
+ scrolls content via dragger rail
1567
+ */
1568
+ _draggerRail=function(){
1569
+ var $this=$(this),d=$this.data(pluginPfx),
1570
+ namespace=pluginPfx+"_"+d.idx,
1571
+ mCSB_container=$("#mCSB_"+d.idx+"_container"),
1572
+ wrapper=mCSB_container.parent(),
1573
+ mCSB_draggerContainer=$(".mCSB_"+d.idx+"_scrollbar ."+classes[12]),
1574
+ clickable;
1575
+ mCSB_draggerContainer.bind("mousedown."+namespace+" touchstart."+namespace+" pointerdown."+namespace+" MSPointerDown."+namespace,function(e){
1576
+ touchActive=true;
1577
+ if(!$(e.target).hasClass("mCSB_dragger")){clickable=1;}
1578
+ }).bind("touchend."+namespace+" pointerup."+namespace+" MSPointerUp."+namespace,function(e){
1579
+ touchActive=false;
1580
+ }).bind("click."+namespace,function(e){
1581
+ if(!clickable){return;}
1582
+ clickable=0;
1583
+ if($(e.target).hasClass(classes[12]) || $(e.target).hasClass("mCSB_draggerRail")){
1584
+ _stop($this);
1585
+ var el=$(this),mCSB_dragger=el.find(".mCSB_dragger");
1586
+ if(el.parent(".mCSB_scrollTools_horizontal").length>0){
1587
+ if(!d.overflowed[1]){return;}
1588
+ var dir="x",
1589
+ clickDir=e.pageX>mCSB_dragger.offset().left ? -1 : 1,
1590
+ to=Math.abs(mCSB_container[0].offsetLeft)-(clickDir*(wrapper.width()*0.9));
1591
+ }else{
1592
+ if(!d.overflowed[0]){return;}
1593
+ var dir="y",
1594
+ clickDir=e.pageY>mCSB_dragger.offset().top ? -1 : 1,
1595
+ to=Math.abs(mCSB_container[0].offsetTop)-(clickDir*(wrapper.height()*0.9));
1596
+ }
1597
+ _scrollTo($this,to.toString(),{dir:dir,scrollEasing:"mcsEaseInOut"});
1598
+ }
1599
+ });
1600
+ },
1601
+ /* -------------------- */
1602
+
1603
+
1604
+ /*
1605
+ FOCUS EVENT
1606
+ scrolls content via element focus (e.g. clicking an input, pressing TAB key etc.)
1607
+ */
1608
+ _focus=function(){
1609
+ var $this=$(this),d=$this.data(pluginPfx),o=d.opt,
1610
+ namespace=pluginPfx+"_"+d.idx,
1611
+ mCSB_container=$("#mCSB_"+d.idx+"_container"),
1612
+ wrapper=mCSB_container.parent();
1613
+ mCSB_container.bind("focusin."+namespace,function(e){
1614
+ var el=$(document.activeElement),
1615
+ nested=mCSB_container.find(".mCustomScrollBox").length,
1616
+ dur=0;
1617
+ if(!el.is(o.advanced.autoScrollOnFocus)){return;}
1618
+ _stop($this);
1619
+ clearTimeout($this[0]._focusTimeout);
1620
+ $this[0]._focusTimer=nested ? (dur+17)*nested : 0;
1621
+ $this[0]._focusTimeout=setTimeout(function(){
1622
+ var to=[_childPos(el)[0],_childPos(el)[1]],
1623
+ contentPos=[mCSB_container[0].offsetTop,mCSB_container[0].offsetLeft],
1624
+ isVisible=[
1625
+ (contentPos[0]+to[0]>=0 && contentPos[0]+to[0]<wrapper.height()-el.outerHeight(false)),
1626
+ (contentPos[1]+to[1]>=0 && contentPos[0]+to[1]<wrapper.width()-el.outerWidth(false))
1627
+ ],
1628
+ overwrite=(o.axis==="yx" && !isVisible[0] && !isVisible[1]) ? "none" : "all";
1629
+ if(o.axis!=="x" && !isVisible[0]){
1630
+ _scrollTo($this,to[0].toString(),{dir:"y",scrollEasing:"mcsEaseInOut",overwrite:overwrite,dur:dur});
1631
+ }
1632
+ if(o.axis!=="y" && !isVisible[1]){
1633
+ _scrollTo($this,to[1].toString(),{dir:"x",scrollEasing:"mcsEaseInOut",overwrite:overwrite,dur:dur});
1634
+ }
1635
+ },$this[0]._focusTimer);
1636
+ });
1637
+ },
1638
+ /* -------------------- */
1639
+
1640
+
1641
+ /* sets content wrapper scrollTop/scrollLeft always to 0 */
1642
+ _wrapperScroll=function(){
1643
+ var $this=$(this),d=$this.data(pluginPfx),
1644
+ namespace=pluginPfx+"_"+d.idx,
1645
+ wrapper=$("#mCSB_"+d.idx+"_container").parent();
1646
+ wrapper.bind("scroll."+namespace,function(e){
1647
+ if(wrapper.scrollTop()!==0 || wrapper.scrollLeft()!==0){
1648
+ $(".mCSB_"+d.idx+"_scrollbar").css("visibility","hidden"); /* hide scrollbar(s) */
1649
+ }
1650
+ });
1651
+ },
1652
+ /* -------------------- */
1653
+
1654
+
1655
+ /*
1656
+ BUTTONS EVENTS
1657
+ scrolls content via up, down, left and right buttons
1658
+ */
1659
+ _buttons=function(){
1660
+ var $this=$(this),d=$this.data(pluginPfx),o=d.opt,seq=d.sequential,
1661
+ namespace=pluginPfx+"_"+d.idx,
1662
+ sel=".mCSB_"+d.idx+"_scrollbar",
1663
+ btn=$(sel+">a");
1664
+ btn.bind("contextmenu."+namespace,function(e){
1665
+ e.preventDefault(); //prevent right click
1666
+ }).bind("mousedown."+namespace+" touchstart."+namespace+" pointerdown."+namespace+" MSPointerDown."+namespace+" mouseup."+namespace+" touchend."+namespace+" pointerup."+namespace+" MSPointerUp."+namespace+" mouseout."+namespace+" pointerout."+namespace+" MSPointerOut."+namespace+" click."+namespace,function(e){
1667
+ e.preventDefault();
1668
+ if(!_mouseBtnLeft(e)){return;} /* left mouse button only */
1669
+ var btnClass=$(this).attr("class");
1670
+ seq.type=o.scrollButtons.scrollType;
1671
+ switch(e.type){
1672
+ case "mousedown": case "touchstart": case "pointerdown": case "MSPointerDown":
1673
+ if(seq.type==="stepped"){return;}
1674
+ touchActive=true;
1675
+ d.tweenRunning=false;
1676
+ _seq("on",btnClass);
1677
+ break;
1678
+ case "mouseup": case "touchend": case "pointerup": case "MSPointerUp":
1679
+ case "mouseout": case "pointerout": case "MSPointerOut":
1680
+ if(seq.type==="stepped"){return;}
1681
+ touchActive=false;
1682
+ if(seq.dir){_seq("off",btnClass);}
1683
+ break;
1684
+ case "click":
1685
+ if(seq.type!=="stepped" || d.tweenRunning){return;}
1686
+ _seq("on",btnClass);
1687
+ break;
1688
+ }
1689
+ function _seq(a,c){
1690
+ seq.scrollAmount=o.scrollButtons.scrollAmount;
1691
+ _sequentialScroll($this,a,c);
1692
+ }
1693
+ });
1694
+ },
1695
+ /* -------------------- */
1696
+
1697
+
1698
+ /*
1699
+ KEYBOARD EVENTS
1700
+ scrolls content via keyboard
1701
+ Keys: up arrow, down arrow, left arrow, right arrow, PgUp, PgDn, Home, End
1702
+ */
1703
+ _keyboard=function(){
1704
+ var $this=$(this),d=$this.data(pluginPfx),o=d.opt,seq=d.sequential,
1705
+ namespace=pluginPfx+"_"+d.idx,
1706
+ mCustomScrollBox=$("#mCSB_"+d.idx),
1707
+ mCSB_container=$("#mCSB_"+d.idx+"_container"),
1708
+ wrapper=mCSB_container.parent(),
1709
+ editables="input,textarea,select,datalist,keygen,[contenteditable='true']",
1710
+ iframe=mCSB_container.find("iframe"),
1711
+ events=["blur."+namespace+" keydown."+namespace+" keyup."+namespace];
1712
+ if(iframe.length){
1713
+ iframe.each(function(){
1714
+ $(this).bind("load",function(){
1715
+ /* bind events on accessible iframes */
1716
+ if(_canAccessIFrame(this)){
1717
+ $(this.contentDocument || this.contentWindow.document).bind(events[0],function(e){
1718
+ _onKeyboard(e);
1719
+ });
1720
+ }
1721
+ });
1722
+ });
1723
+ }
1724
+ mCustomScrollBox.attr("tabindex","0").bind(events[0],function(e){
1725
+ _onKeyboard(e);
1726
+ });
1727
+ function _onKeyboard(e){
1728
+ switch(e.type){
1729
+ case "blur":
1730
+ if(d.tweenRunning && seq.dir){_seq("off",null);}
1731
+ break;
1732
+ case "keydown": case "keyup":
1733
+ var code=e.keyCode ? e.keyCode : e.which,action="on";
1734
+ if((o.axis!=="x" && (code===38 || code===40)) || (o.axis!=="y" && (code===37 || code===39))){
1735
+ /* up (38), down (40), left (37), right (39) arrows */
1736
+ if(((code===38 || code===40) && !d.overflowed[0]) || ((code===37 || code===39) && !d.overflowed[1])){return;}
1737
+ if(e.type==="keyup"){action="off";}
1738
+ if(!$(document.activeElement).is(editables)){
1739
+ e.preventDefault();
1740
+ e.stopImmediatePropagation();
1741
+ _seq(action,code);
1742
+ }
1743
+ }else if(code===33 || code===34){
1744
+ /* PgUp (33), PgDn (34) */
1745
+ if(d.overflowed[0] || d.overflowed[1]){
1746
+ e.preventDefault();
1747
+ e.stopImmediatePropagation();
1748
+ }
1749
+ if(e.type==="keyup"){
1750
+ _stop($this);
1751
+ var keyboardDir=code===34 ? -1 : 1;
1752
+ if(o.axis==="x" || (o.axis==="yx" && d.overflowed[1] && !d.overflowed[0])){
1753
+ var dir="x",to=Math.abs(mCSB_container[0].offsetLeft)-(keyboardDir*(wrapper.width()*0.9));
1754
+ }else{
1755
+ var dir="y",to=Math.abs(mCSB_container[0].offsetTop)-(keyboardDir*(wrapper.height()*0.9));
1756
+ }
1757
+ _scrollTo($this,to.toString(),{dir:dir,scrollEasing:"mcsEaseInOut"});
1758
+ }
1759
+ }else if(code===35 || code===36){
1760
+ /* End (35), Home (36) */
1761
+ if(!$(document.activeElement).is(editables)){
1762
+ if(d.overflowed[0] || d.overflowed[1]){
1763
+ e.preventDefault();
1764
+ e.stopImmediatePropagation();
1765
+ }
1766
+ if(e.type==="keyup"){
1767
+ if(o.axis==="x" || (o.axis==="yx" && d.overflowed[1] && !d.overflowed[0])){
1768
+ var dir="x",to=code===35 ? Math.abs(wrapper.width()-mCSB_container.outerWidth(false)) : 0;
1769
+ }else{
1770
+ var dir="y",to=code===35 ? Math.abs(wrapper.height()-mCSB_container.outerHeight(false)) : 0;
1771
+ }
1772
+ _scrollTo($this,to.toString(),{dir:dir,scrollEasing:"mcsEaseInOut"});
1773
+ }
1774
+ }
1775
+ }
1776
+ break;
1777
+ }
1778
+ function _seq(a,c){
1779
+ seq.type=o.keyboard.scrollType;
1780
+ seq.scrollAmount=o.keyboard.scrollAmount;
1781
+ if(seq.type==="stepped" && d.tweenRunning){return;}
1782
+ _sequentialScroll($this,a,c);
1783
+ }
1784
+ }
1785
+ },
1786
+ /* -------------------- */
1787
+
1788
+
1789
+ /* scrolls content sequentially (used when scrolling via buttons, keyboard arrows etc.) */
1790
+ _sequentialScroll=function(el,action,trigger,e,s){
1791
+ var d=el.data(pluginPfx),o=d.opt,seq=d.sequential,
1792
+ mCSB_container=$("#mCSB_"+d.idx+"_container"),
1793
+ once=seq.type==="stepped" ? true : false,
1794
+ steplessSpeed=o.scrollInertia < 26 ? 26 : o.scrollInertia, /* 26/1.5=17 */
1795
+ steppedSpeed=o.scrollInertia < 1 ? 17 : o.scrollInertia;
1796
+ switch(action){
1797
+ case "on":
1798
+ seq.dir=[
1799
+ (trigger===classes[16] || trigger===classes[15] || trigger===39 || trigger===37 ? "x" : "y"),
1800
+ (trigger===classes[13] || trigger===classes[15] || trigger===38 || trigger===37 ? -1 : 1)
1801
+ ];
1802
+ _stop(el);
1803
+ if(_isNumeric(trigger) && seq.type==="stepped"){return;}
1804
+ _on(once);
1805
+ break;
1806
+ case "off":
1807
+ _off();
1808
+ if(once || (d.tweenRunning && seq.dir)){
1809
+ _on(true);
1810
+ }
1811
+ break;
1812
+ }
1813
+
1814
+ /* starts sequence */
1815
+ function _on(once){
1816
+ if(o.snapAmount){seq.scrollAmount=!(o.snapAmount instanceof Array) ? o.snapAmount : seq.dir[0]==="x" ? o.snapAmount[1] : o.snapAmount[0];} /* scrolling snapping */
1817
+ var c=seq.type!=="stepped", /* continuous scrolling */
1818
+ t=s ? s : !once ? 1000/60 : c ? steplessSpeed/1.5 : steppedSpeed, /* timer */
1819
+ m=!once ? 2.5 : c ? 7.5 : 40, /* multiplier */
1820
+ contentPos=[Math.abs(mCSB_container[0].offsetTop),Math.abs(mCSB_container[0].offsetLeft)],
1821
+ ratio=[d.scrollRatio.y>10 ? 10 : d.scrollRatio.y,d.scrollRatio.x>10 ? 10 : d.scrollRatio.x],
1822
+ amount=seq.dir[0]==="x" ? contentPos[1]+(seq.dir[1]*(ratio[1]*m)) : contentPos[0]+(seq.dir[1]*(ratio[0]*m)),
1823
+ px=seq.dir[0]==="x" ? contentPos[1]+(seq.dir[1]*parseInt(seq.scrollAmount)) : contentPos[0]+(seq.dir[1]*parseInt(seq.scrollAmount)),
1824
+ to=seq.scrollAmount!=="auto" ? px : amount,
1825
+ easing=e ? e : !once ? "mcsLinear" : c ? "mcsLinearOut" : "mcsEaseInOut",
1826
+ onComplete=!once ? false : true;
1827
+ if(once && t<17){
1828
+ to=seq.dir[0]==="x" ? contentPos[1] : contentPos[0];
1829
+ }
1830
+ _scrollTo(el,to.toString(),{dir:seq.dir[0],scrollEasing:easing,dur:t,onComplete:onComplete});
1831
+ if(once){
1832
+ seq.dir=false;
1833
+ return;
1834
+ }
1835
+ clearTimeout(seq.step);
1836
+ seq.step=setTimeout(function(){
1837
+ _on();
1838
+ },t);
1839
+ }
1840
+ /* stops sequence */
1841
+ function _off(){
1842
+ clearTimeout(seq.step);
1843
+ _delete(seq,"step");
1844
+ _stop(el);
1845
+ }
1846
+ },
1847
+ /* -------------------- */
1848
+
1849
+
1850
+ /* returns a yx array from value */
1851
+ _arr=function(val){
1852
+ var o=$(this).data(pluginPfx).opt,vals=[];
1853
+ if(typeof val==="function"){val=val();} /* check if the value is a single anonymous function */
1854
+ /* check if value is object or array, its length and create an array with yx values */
1855
+ if(!(val instanceof Array)){ /* object value (e.g. {y:"100",x:"100"}, 100 etc.) */
1856
+ vals[0]=val.y ? val.y : val.x || o.axis==="x" ? null : val;
1857
+ vals[1]=val.x ? val.x : val.y || o.axis==="y" ? null : val;
1858
+ }else{ /* array value (e.g. [100,100]) */
1859
+ vals=val.length>1 ? [val[0],val[1]] : o.axis==="x" ? [null,val[0]] : [val[0],null];
1860
+ }
1861
+ /* check if array values are anonymous functions */
1862
+ if(typeof vals[0]==="function"){vals[0]=vals[0]();}
1863
+ if(typeof vals[1]==="function"){vals[1]=vals[1]();}
1864
+ return vals;
1865
+ },
1866
+ /* -------------------- */
1867
+
1868
+
1869
+ /* translates values (e.g. "top", 100, "100px", "#id") to actual scroll-to positions */
1870
+ _to=function(val,dir){
1871
+ if(val==null || typeof val=="undefined"){return;}
1872
+ var $this=$(this),d=$this.data(pluginPfx),o=d.opt,
1873
+ mCSB_container=$("#mCSB_"+d.idx+"_container"),
1874
+ wrapper=mCSB_container.parent(),
1875
+ t=typeof val;
1876
+ if(!dir){dir=o.axis==="x" ? "x" : "y";}
1877
+ var contentLength=dir==="x" ? mCSB_container.outerWidth(false)-wrapper.width() : mCSB_container.outerHeight(false)-wrapper.height(),
1878
+ contentPos=dir==="x" ? mCSB_container[0].offsetLeft : mCSB_container[0].offsetTop,
1879
+ cssProp=dir==="x" ? "left" : "top";
1880
+ switch(t){
1881
+ case "function": /* this currently is not used. Consider removing it */
1882
+ return val();
1883
+ break;
1884
+ case "object": /* js/jquery object */
1885
+ var obj=val.jquery ? val : $(val);
1886
+ if(!obj.length){return;}
1887
+ return dir==="x" ? _childPos(obj)[1] : _childPos(obj)[0];
1888
+ break;
1889
+ case "string": case "number":
1890
+ if(_isNumeric(val)){ /* numeric value */
1891
+ return Math.abs(val);
1892
+ }else if(val.indexOf("%")!==-1){ /* percentage value */
1893
+ return Math.abs(contentLength*parseInt(val)/100);
1894
+ }else if(val.indexOf("-=")!==-1){ /* decrease value */
1895
+ return Math.abs(contentPos-parseInt(val.split("-=")[1]));
1896
+ }else if(val.indexOf("+=")!==-1){ /* inrease value */
1897
+ var p=(contentPos+parseInt(val.split("+=")[1]));
1898
+ return p>=0 ? 0 : Math.abs(p);
1899
+ }else if(val.indexOf("px")!==-1 && _isNumeric(val.split("px")[0])){ /* pixels string value (e.g. "100px") */
1900
+ return Math.abs(val.split("px")[0]);
1901
+ }else{
1902
+ if(val==="top" || val==="left"){ /* special strings */
1903
+ return 0;
1904
+ }else if(val==="bottom"){
1905
+ return Math.abs(wrapper.height()-mCSB_container.outerHeight(false));
1906
+ }else if(val==="right"){
1907
+ return Math.abs(wrapper.width()-mCSB_container.outerWidth(false));
1908
+ }else if(val==="first" || val==="last"){
1909
+ var obj=mCSB_container.find(":"+val);
1910
+ return dir==="x" ? _childPos(obj)[1] : _childPos(obj)[0];
1911
+ }else{
1912
+ if($(val).length){ /* jquery selector */
1913
+ return dir==="x" ? _childPos($(val))[1] : _childPos($(val))[0];
1914
+ }else{ /* other values (e.g. "100em") */
1915
+ mCSB_container.css(cssProp,val);
1916
+ methods.update.call(null,$this[0]);
1917
+ return;
1918
+ }
1919
+ }
1920
+ }
1921
+ break;
1922
+ }
1923
+ },
1924
+ /* -------------------- */
1925
+
1926
+
1927
+ /* calls the update method automatically */
1928
+ _autoUpdate=function(rem){
1929
+ var $this=$(this),d=$this.data(pluginPfx),o=d.opt,
1930
+ mCSB_container=$("#mCSB_"+d.idx+"_container");
1931
+ if(rem){
1932
+ /*
1933
+ removes autoUpdate timer
1934
+ usage: _autoUpdate.call(this,"remove");
1935
+ */
1936
+ clearTimeout(mCSB_container[0].autoUpdate);
1937
+ _delete(mCSB_container[0],"autoUpdate");
1938
+ return;
1939
+ }
1940
+ upd();
1941
+ function upd(){
1942
+ clearTimeout(mCSB_container[0].autoUpdate);
1943
+ if($this.parents("html").length===0){
1944
+ /* check element in dom tree */
1945
+ $this=null;
1946
+ return;
1947
+ }
1948
+ mCSB_container[0].autoUpdate=setTimeout(function(){
1949
+ /* update on specific selector(s) length and size change */
1950
+ if(o.advanced.updateOnSelectorChange){
1951
+ d.poll.change.n=sizesSum();
1952
+ if(d.poll.change.n!==d.poll.change.o){
1953
+ d.poll.change.o=d.poll.change.n;
1954
+ doUpd(3);
1955
+ return;
1956
+ }
1957
+ }
1958
+ /* update on main element and scrollbar size changes */
1959
+ if(o.advanced.updateOnContentResize){
1960
+ d.poll.size.n=$this[0].scrollHeight+$this[0].scrollWidth+mCSB_container[0].offsetHeight+$this[0].offsetHeight+$this[0].offsetWidth;
1961
+ if(d.poll.size.n!==d.poll.size.o){
1962
+ d.poll.size.o=d.poll.size.n;
1963
+ doUpd(1);
1964
+ return;
1965
+ }
1966
+ }
1967
+ /* update on image load */
1968
+ if(o.advanced.updateOnImageLoad){
1969
+ if(!(o.advanced.updateOnImageLoad==="auto" && o.axis==="y")){ //by default, it doesn't run on vertical content
1970
+ d.poll.img.n=mCSB_container.find("img").length;
1971
+ if(d.poll.img.n!==d.poll.img.o){
1972
+ d.poll.img.o=d.poll.img.n;
1973
+ mCSB_container.find("img").each(function(){
1974
+ imgLoader(this);
1975
+ });
1976
+ return;
1977
+ }
1978
+ }
1979
+ }
1980
+ if(o.advanced.updateOnSelectorChange || o.advanced.updateOnContentResize || o.advanced.updateOnImageLoad){upd();}
1981
+ },o.advanced.autoUpdateTimeout);
1982
+ }
1983
+ /* a tiny image loader */
1984
+ function imgLoader(el){
1985
+ if($(el).hasClass(classes[2])){doUpd(); return;}
1986
+ var img=new Image();
1987
+ function createDelegate(contextObject,delegateMethod){
1988
+ return function(){return delegateMethod.apply(contextObject,arguments);}
1989
+ }
1990
+ function imgOnLoad(){
1991
+ this.onload=null;
1992
+ $(el).addClass(classes[2]);
1993
+ doUpd(2);
1994
+ }
1995
+ img.onload=createDelegate(img,imgOnLoad);
1996
+ img.src=el.src;
1997
+ }
1998
+ /* returns the total height and width sum of all elements matching the selector */
1999
+ function sizesSum(){
2000
+ if(o.advanced.updateOnSelectorChange===true){o.advanced.updateOnSelectorChange="*";}
2001
+ var total=0,sel=mCSB_container.find(o.advanced.updateOnSelectorChange);
2002
+ if(o.advanced.updateOnSelectorChange && sel.length>0){sel.each(function(){total+=this.offsetHeight+this.offsetWidth;});}
2003
+ return total;
2004
+ }
2005
+ /* calls the update method */
2006
+ function doUpd(cb){
2007
+ clearTimeout(mCSB_container[0].autoUpdate);
2008
+ methods.update.call(null,$this[0],cb);
2009
+ }
2010
+ },
2011
+ /* -------------------- */
2012
+
2013
+
2014
+ /* snaps scrolling to a multiple of a pixels number */
2015
+ _snapAmount=function(to,amount,offset){
2016
+ return (Math.round(to/amount)*amount-offset);
2017
+ },
2018
+ /* -------------------- */
2019
+
2020
+
2021
+ /* stops content and scrollbar animations */
2022
+ _stop=function(el){
2023
+ var d=el.data(pluginPfx),
2024
+ sel=$("#mCSB_"+d.idx+"_container,#mCSB_"+d.idx+"_container_wrapper,#mCSB_"+d.idx+"_dragger_vertical,#mCSB_"+d.idx+"_dragger_horizontal");
2025
+ sel.each(function(){
2026
+ _stopTween.call(this);
2027
+ });
2028
+ },
2029
+ /* -------------------- */
2030
+
2031
+
2032
+ /*
2033
+ ANIMATES CONTENT
2034
+ This is where the actual scrolling happens
2035
+ */
2036
+ _scrollTo=function(el,to,options){
2037
+ var d=el.data(pluginPfx),o=d.opt,
2038
+ defaults={
2039
+ trigger:"internal",
2040
+ dir:"y",
2041
+ scrollEasing:"mcsEaseOut",
2042
+ drag:false,
2043
+ dur:o.scrollInertia,
2044
+ overwrite:"all",
2045
+ callbacks:true,
2046
+ onStart:true,
2047
+ onUpdate:true,
2048
+ onComplete:true
2049
+ },
2050
+ options=$.extend(defaults,options),
2051
+ dur=[options.dur,(options.drag ? 0 : options.dur)],
2052
+ mCustomScrollBox=$("#mCSB_"+d.idx),
2053
+ mCSB_container=$("#mCSB_"+d.idx+"_container"),
2054
+ wrapper=mCSB_container.parent(),
2055
+ totalScrollOffsets=o.callbacks.onTotalScrollOffset ? _arr.call(el,o.callbacks.onTotalScrollOffset) : [0,0],
2056
+ totalScrollBackOffsets=o.callbacks.onTotalScrollBackOffset ? _arr.call(el,o.callbacks.onTotalScrollBackOffset) : [0,0];
2057
+ d.trigger=options.trigger;
2058
+ if(wrapper.scrollTop()!==0 || wrapper.scrollLeft()!==0){ /* always reset scrollTop/Left */
2059
+ $(".mCSB_"+d.idx+"_scrollbar").css("visibility","visible");
2060
+ wrapper.scrollTop(0).scrollLeft(0);
2061
+ }
2062
+ if(to==="_resetY" && !d.contentReset.y){
2063
+ /* callbacks: onOverflowYNone */
2064
+ if(_cb("onOverflowYNone")){o.callbacks.onOverflowYNone.call(el[0]);}
2065
+ d.contentReset.y=1;
2066
+ }
2067
+ if(to==="_resetX" && !d.contentReset.x){
2068
+ /* callbacks: onOverflowXNone */
2069
+ if(_cb("onOverflowXNone")){o.callbacks.onOverflowXNone.call(el[0]);}
2070
+ d.contentReset.x=1;
2071
+ }
2072
+ if(to==="_resetY" || to==="_resetX"){return;}
2073
+ if((d.contentReset.y || !el[0].mcs) && d.overflowed[0]){
2074
+ /* callbacks: onOverflowY */
2075
+ if(_cb("onOverflowY")){o.callbacks.onOverflowY.call(el[0]);}
2076
+ d.contentReset.x=null;
2077
+ }
2078
+ if((d.contentReset.x || !el[0].mcs) && d.overflowed[1]){
2079
+ /* callbacks: onOverflowX */
2080
+ if(_cb("onOverflowX")){o.callbacks.onOverflowX.call(el[0]);}
2081
+ d.contentReset.x=null;
2082
+ }
2083
+ if(o.snapAmount){ /* scrolling snapping */
2084
+ var snapAmount=!(o.snapAmount instanceof Array) ? o.snapAmount : options.dir==="x" ? o.snapAmount[1] : o.snapAmount[0];
2085
+ to=_snapAmount(to,snapAmount,o.snapOffset);
2086
+ }
2087
+ switch(options.dir){
2088
+ case "x":
2089
+ var mCSB_dragger=$("#mCSB_"+d.idx+"_dragger_horizontal"),
2090
+ property="left",
2091
+ contentPos=mCSB_container[0].offsetLeft,
2092
+ limit=[
2093
+ mCustomScrollBox.width()-mCSB_container.outerWidth(false),
2094
+ mCSB_dragger.parent().width()-mCSB_dragger.width()
2095
+ ],
2096
+ scrollTo=[to,to===0 ? 0 : (to/d.scrollRatio.x)],
2097
+ tso=totalScrollOffsets[1],
2098
+ tsbo=totalScrollBackOffsets[1],
2099
+ totalScrollOffset=tso>0 ? tso/d.scrollRatio.x : 0,
2100
+ totalScrollBackOffset=tsbo>0 ? tsbo/d.scrollRatio.x : 0;
2101
+ break;
2102
+ case "y":
2103
+ var mCSB_dragger=$("#mCSB_"+d.idx+"_dragger_vertical"),
2104
+ property="top",
2105
+ contentPos=mCSB_container[0].offsetTop,
2106
+ limit=[
2107
+ mCustomScrollBox.height()-mCSB_container.outerHeight(false),
2108
+ mCSB_dragger.parent().height()-mCSB_dragger.height()
2109
+ ],
2110
+ scrollTo=[to,to===0 ? 0 : (to/d.scrollRatio.y)],
2111
+ tso=totalScrollOffsets[0],
2112
+ tsbo=totalScrollBackOffsets[0],
2113
+ totalScrollOffset=tso>0 ? tso/d.scrollRatio.y : 0,
2114
+ totalScrollBackOffset=tsbo>0 ? tsbo/d.scrollRatio.y : 0;
2115
+ break;
2116
+ }
2117
+ if(scrollTo[1]<0 || (scrollTo[0]===0 && scrollTo[1]===0)){
2118
+ scrollTo=[0,0];
2119
+ }else if(scrollTo[1]>=limit[1]){
2120
+ scrollTo=[limit[0],limit[1]];
2121
+ }else{
2122
+ scrollTo[0]=-scrollTo[0];
2123
+ }
2124
+ if(!el[0].mcs){
2125
+ _mcs(); /* init mcs object (once) to make it available before callbacks */
2126
+ if(_cb("onInit")){o.callbacks.onInit.call(el[0]);} /* callbacks: onInit */
2127
+ }
2128
+ clearTimeout(mCSB_container[0].onCompleteTimeout);
2129
+ _tweenTo(mCSB_dragger[0],property,Math.round(scrollTo[1]),dur[1],options.scrollEasing);
2130
+ if(!d.tweenRunning && ((contentPos===0 && scrollTo[0]>=0) || (contentPos===limit[0] && scrollTo[0]<=limit[0]))){return;}
2131
+ _tweenTo(mCSB_container[0],property,Math.round(scrollTo[0]),dur[0],options.scrollEasing,options.overwrite,{
2132
+ onStart:function(){
2133
+ if(options.callbacks && options.onStart && !d.tweenRunning){
2134
+ /* callbacks: onScrollStart */
2135
+ if(_cb("onScrollStart")){_mcs(); o.callbacks.onScrollStart.call(el[0]);}
2136
+ d.tweenRunning=true;
2137
+ _onDragClasses(mCSB_dragger);
2138
+ d.cbOffsets=_cbOffsets();
2139
+ }
2140
+ },onUpdate:function(){
2141
+ if(options.callbacks && options.onUpdate){
2142
+ /* callbacks: whileScrolling */
2143
+ if(_cb("whileScrolling")){_mcs(); o.callbacks.whileScrolling.call(el[0]);}
2144
+ }
2145
+ },onComplete:function(){
2146
+ if(options.callbacks && options.onComplete){
2147
+ if(o.axis==="yx"){clearTimeout(mCSB_container[0].onCompleteTimeout);}
2148
+ var t=mCSB_container[0].idleTimer || 0;
2149
+ mCSB_container[0].onCompleteTimeout=setTimeout(function(){
2150
+ /* callbacks: onScroll, onTotalScroll, onTotalScrollBack */
2151
+ if(_cb("onScroll")){_mcs(); o.callbacks.onScroll.call(el[0]);}
2152
+ if(_cb("onTotalScroll") && scrollTo[1]>=limit[1]-totalScrollOffset && d.cbOffsets[0]){_mcs(); o.callbacks.onTotalScroll.call(el[0]);}
2153
+ if(_cb("onTotalScrollBack") && scrollTo[1]<=totalScrollBackOffset && d.cbOffsets[1]){_mcs(); o.callbacks.onTotalScrollBack.call(el[0]);}
2154
+ d.tweenRunning=false;
2155
+ mCSB_container[0].idleTimer=0;
2156
+ _onDragClasses(mCSB_dragger,"hide");
2157
+ },t);
2158
+ }
2159
+ }
2160
+ });
2161
+ /* checks if callback function exists */
2162
+ function _cb(cb){
2163
+ return d && o.callbacks[cb] && typeof o.callbacks[cb]==="function";
2164
+ }
2165
+ /* checks whether callback offsets always trigger */
2166
+ function _cbOffsets(){
2167
+ return [o.callbacks.alwaysTriggerOffsets || contentPos>=limit[0]+tso,o.callbacks.alwaysTriggerOffsets || contentPos<=-tsbo];
2168
+ }
2169
+ /*
2170
+ populates object with useful values for the user
2171
+ values:
2172
+ content: this.mcs.content
2173
+ content top position: this.mcs.top
2174
+ content left position: this.mcs.left
2175
+ dragger top position: this.mcs.draggerTop
2176
+ dragger left position: this.mcs.draggerLeft
2177
+ scrolling y percentage: this.mcs.topPct
2178
+ scrolling x percentage: this.mcs.leftPct
2179
+ scrolling direction: this.mcs.direction
2180
+ */
2181
+ function _mcs(){
2182
+ var cp=[mCSB_container[0].offsetTop,mCSB_container[0].offsetLeft], /* content position */
2183
+ dp=[mCSB_dragger[0].offsetTop,mCSB_dragger[0].offsetLeft], /* dragger position */
2184
+ cl=[mCSB_container.outerHeight(false),mCSB_container.outerWidth(false)], /* content length */
2185
+ pl=[mCustomScrollBox.height(),mCustomScrollBox.width()]; /* content parent length */
2186
+ el[0].mcs={
2187
+ content:mCSB_container, /* original content wrapper as jquery object */
2188
+ top:cp[0],left:cp[1],draggerTop:dp[0],draggerLeft:dp[1],
2189
+ topPct:Math.round((100*Math.abs(cp[0]))/(Math.abs(cl[0])-pl[0])),leftPct:Math.round((100*Math.abs(cp[1]))/(Math.abs(cl[1])-pl[1])),
2190
+ direction:options.dir
2191
+ };
2192
+ /*
2193
+ this refers to the original element containing the scrollbar(s)
2194
+ usage: this.mcs.top, this.mcs.leftPct etc.
2195
+ */
2196
+ }
2197
+ },
2198
+ /* -------------------- */
2199
+
2200
+
2201
+ /*
2202
+ CUSTOM JAVASCRIPT ANIMATION TWEEN
2203
+ Lighter and faster than jquery animate() and css transitions
2204
+ Animates top/left properties and includes easings
2205
+ */
2206
+ _tweenTo=function(el,prop,to,duration,easing,overwrite,callbacks){
2207
+ if(!el._mTween){el._mTween={top:{},left:{}};}
2208
+ var callbacks=callbacks || {},
2209
+ onStart=callbacks.onStart || function(){},onUpdate=callbacks.onUpdate || function(){},onComplete=callbacks.onComplete || function(){},
2210
+ startTime=_getTime(),_delay,progress=0,from=el.offsetTop,elStyle=el.style,_request,tobj=el._mTween[prop];
2211
+ if(prop==="left"){from=el.offsetLeft;}
2212
+ var diff=to-from;
2213
+ tobj.stop=0;
2214
+ if(overwrite!=="none"){_cancelTween();}
2215
+ _startTween();
2216
+ function _step(){
2217
+ if(tobj.stop){return;}
2218
+ if(!progress){onStart.call();}
2219
+ progress=_getTime()-startTime;
2220
+ _tween();
2221
+ if(progress>=tobj.time){
2222
+ tobj.time=(progress>tobj.time) ? progress+_delay-(progress-tobj.time) : progress+_delay-1;
2223
+ if(tobj.time<progress+1){tobj.time=progress+1;}
2224
+ }
2225
+ if(tobj.time<duration){tobj.id=_request(_step);}else{onComplete.call();}
2226
+ }
2227
+ function _tween(){
2228
+ if(duration>0){
2229
+ tobj.currVal=_ease(tobj.time,from,diff,duration,easing);
2230
+ elStyle[prop]=Math.round(tobj.currVal)+"px";
2231
+ }else{
2232
+ elStyle[prop]=to+"px";
2233
+ }
2234
+ onUpdate.call();
2235
+ }
2236
+ function _startTween(){
2237
+ _delay=1000/60;
2238
+ tobj.time=progress+_delay;
2239
+ _request=(!window.requestAnimationFrame) ? function(f){_tween(); return setTimeout(f,0.01);} : window.requestAnimationFrame;
2240
+ tobj.id=_request(_step);
2241
+ }
2242
+ function _cancelTween(){
2243
+ if(tobj.id==null){return;}
2244
+ if(!window.requestAnimationFrame){clearTimeout(tobj.id);
2245
+ }else{window.cancelAnimationFrame(tobj.id);}
2246
+ tobj.id=null;
2247
+ }
2248
+ function _ease(t,b,c,d,type){
2249
+ switch(type){
2250
+ case "linear": case "mcsLinear":
2251
+ return c*t/d + b;
2252
+ break;
2253
+ case "mcsLinearOut":
2254
+ t/=d; t--; return c * Math.sqrt(1 - t*t) + b;
2255
+ break;
2256
+ case "easeInOutSmooth":
2257
+ t/=d/2;
2258
+ if(t<1) return c/2*t*t + b;
2259
+ t--;
2260
+ return -c/2 * (t*(t-2) - 1) + b;
2261
+ break;
2262
+ case "easeInOutStrong":
2263
+ t/=d/2;
2264
+ if(t<1) return c/2 * Math.pow( 2, 10 * (t - 1) ) + b;
2265
+ t--;
2266
+ return c/2 * ( -Math.pow( 2, -10 * t) + 2 ) + b;
2267
+ break;
2268
+ case "easeInOut": case "mcsEaseInOut":
2269
+ t/=d/2;
2270
+ if(t<1) return c/2*t*t*t + b;
2271
+ t-=2;
2272
+ return c/2*(t*t*t + 2) + b;
2273
+ break;
2274
+ case "easeOutSmooth":
2275
+ t/=d; t--;
2276
+ return -c * (t*t*t*t - 1) + b;
2277
+ break;
2278
+ case "easeOutStrong":
2279
+ return c * ( -Math.pow( 2, -10 * t/d ) + 1 ) + b;
2280
+ break;
2281
+ case "easeOut": case "mcsEaseOut": default:
2282
+ var ts=(t/=d)*t,tc=ts*t;
2283
+ return b+c*(0.499999999999997*tc*ts + -2.5*ts*ts + 5.5*tc + -6.5*ts + 4*t);
2284
+ }
2285
+ }
2286
+ },
2287
+ /* -------------------- */
2288
+
2289
+
2290
+ /* returns current time */
2291
+ _getTime=function(){
2292
+ if(window.performance && window.performance.now){
2293
+ return window.performance.now();
2294
+ }else{
2295
+ if(window.performance && window.performance.webkitNow){
2296
+ return window.performance.webkitNow();
2297
+ }else{
2298
+ if(Date.now){return Date.now();}else{return new Date().getTime();}
2299
+ }
2300
+ }
2301
+ },
2302
+ /* -------------------- */
2303
+
2304
+
2305
+ /* stops a tween */
2306
+ _stopTween=function(){
2307
+ var el=this;
2308
+ if(!el._mTween){el._mTween={top:{},left:{}};}
2309
+ var props=["top","left"];
2310
+ for(var i=0; i<props.length; i++){
2311
+ var prop=props[i];
2312
+ if(el._mTween[prop].id){
2313
+ if(!window.requestAnimationFrame){clearTimeout(el._mTween[prop].id);
2314
+ }else{window.cancelAnimationFrame(el._mTween[prop].id);}
2315
+ el._mTween[prop].id=null;
2316
+ el._mTween[prop].stop=1;
2317
+ }
2318
+ }
2319
+ },
2320
+ /* -------------------- */
2321
+
2322
+
2323
+ /* deletes a property (avoiding the exception thrown by IE) */
2324
+ _delete=function(c,m){
2325
+ try{delete c[m];}catch(e){c[m]=null;}
2326
+ },
2327
+ /* -------------------- */
2328
+
2329
+
2330
+ /* detects left mouse button */
2331
+ _mouseBtnLeft=function(e){
2332
+ return !(e.which && e.which!==1);
2333
+ },
2334
+ /* -------------------- */
2335
+
2336
+
2337
+ /* detects if pointer type event is touch */
2338
+ _pointerTouch=function(e){
2339
+ var t=e.originalEvent.pointerType;
2340
+ return !(t && t!=="touch" && t!==2);
2341
+ },
2342
+ /* -------------------- */
2343
+
2344
+
2345
+ /* checks if value is numeric */
2346
+ _isNumeric=function(val){
2347
+ return !isNaN(parseFloat(val)) && isFinite(val);
2348
+ },
2349
+ /* -------------------- */
2350
+
2351
+
2352
+ /* returns element position according to content */
2353
+ _childPos=function(el){
2354
+ var p=el.parents(".mCSB_container");
2355
+ return [el.offset().top-p.offset().top,el.offset().left-p.offset().left];
2356
+ },
2357
+ /* -------------------- */
2358
+
2359
+
2360
+ /* checks if browser tab is hidden/inactive via Page Visibility API */
2361
+ _isTabHidden=function(){
2362
+ var prop=_getHiddenProp();
2363
+ if(!prop) return false;
2364
+ return document[prop];
2365
+ function _getHiddenProp(){
2366
+ var pfx=["webkit","moz","ms","o"];
2367
+ if("hidden" in document) return "hidden"; //natively supported
2368
+ for(var i=0; i<pfx.length; i++){ //prefixed
2369
+ if((pfx[i]+"Hidden") in document)
2370
+ return pfx[i]+"Hidden";
2371
+ }
2372
+ return null; //not supported
2373
+ }
2374
+ };
2375
+ /* -------------------- */
2376
+
2377
+ /*
2378
+ ----------------------------------------
2379
+ PLUGIN SETUP
2380
+ ----------------------------------------
2381
+ */
2382
+
2383
+ /* plugin constructor functions */
2384
+ $.fn[pluginNS]=function(method){ /* usage: $(selector).mCustomScrollbar(); */
2385
+ if(methods[method]){
2386
+ return methods[method].apply(this,Array.prototype.slice.call(arguments,1));
2387
+ }else if(typeof method==="object" || !method){
2388
+ return methods.init.apply(this,arguments);
2389
+ }else{
2390
+ $.error("Method "+method+" does not exist");
2391
+ }
2392
+ };
2393
+ $[pluginNS]=function(method){ /* usage: $.mCustomScrollbar(); */
2394
+ if(methods[method]){
2395
+ return methods[method].apply(this,Array.prototype.slice.call(arguments,1));
2396
+ }else if(typeof method==="object" || !method){
2397
+ return methods.init.apply(this,arguments);
2398
+ }else{
2399
+ $.error("Method "+method+" does not exist");
2400
+ }
2401
+ };
2402
+
2403
+ /*
2404
+ allow setting plugin default options.
2405
+ usage: $.mCustomScrollbar.defaults.scrollInertia=500;
2406
+ to apply any changed default options on default selectors (below), use inside document ready fn
2407
+ e.g.: $(document).ready(function(){ $.mCustomScrollbar.defaults.scrollInertia=500; });
2408
+ */
2409
+ $[pluginNS].defaults=defaults;
2410
+
2411
+ /*
2412
+ add window object (window.mCustomScrollbar)
2413
+ usage: if(window.mCustomScrollbar){console.log("custom scrollbar plugin loaded");}
2414
+ */
2415
+ window[pluginNS]=true;
2416
+
2417
+ $(window).bind("load",function(){
2418
+
2419
+ $(defaultSelector)[pluginNS](); /* add scrollbars automatically on default selector */
2420
+
2421
+ /* extend jQuery expressions */
2422
+ $.extend($.expr[":"],{
2423
+ /* checks if element is within scrollable viewport */
2424
+ mcsInView:$.expr[":"].mcsInView || function(el){
2425
+ var $el=$(el),content=$el.parents(".mCSB_container"),wrapper,cPos;
2426
+ if(!content.length){return;}
2427
+ wrapper=content.parent();
2428
+ cPos=[content[0].offsetTop,content[0].offsetLeft];
2429
+ return cPos[0]+_childPos($el)[0]>=0 && cPos[0]+_childPos($el)[0]<wrapper.height()-$el.outerHeight(false) &&
2430
+ cPos[1]+_childPos($el)[1]>=0 && cPos[1]+_childPos($el)[1]<wrapper.width()-$el.outerWidth(false);
2431
+ },
2432
+ /* checks if element or part of element is in view of scrollable viewport */
2433
+ mcsInSight:$.expr[":"].mcsInSight || function(el,i,m){
2434
+ var $el=$(el),elD,content=$el.parents(".mCSB_container"),wrapperView,pos,wrapperViewPct,
2435
+ pctVals=m[3]==="exact" ? [[1,0],[1,0]] : [[0.9,0.1],[0.6,0.4]];
2436
+ if(!content.length){return;}
2437
+ elD=[$el.outerHeight(false),$el.outerWidth(false)];
2438
+ pos=[content[0].offsetTop+_childPos($el)[0],content[0].offsetLeft+_childPos($el)[1]];
2439
+ wrapperView=[content.parent()[0].offsetHeight,content.parent()[0].offsetWidth];
2440
+ wrapperViewPct=[elD[0]<wrapperView[0] ? pctVals[0] : pctVals[1],elD[1]<wrapperView[1] ? pctVals[0] : pctVals[1]];
2441
+ return pos[0]-(wrapperView[0]*wrapperViewPct[0][0])<0 && pos[0]+elD[0]-(wrapperView[0]*wrapperViewPct[0][1])>=0 &&
2442
+ pos[1]-(wrapperView[1]*wrapperViewPct[1][0])<0 && pos[1]+elD[1]-(wrapperView[1]*wrapperViewPct[1][1])>=0;
2443
+ },
2444
+ /* checks if element is overflowed having visible scrollbar(s) */
2445
+ mcsOverflow:$.expr[":"].mcsOverflow || function(el){
2446
+ var d=$(el).data(pluginPfx);
2447
+ if(!d){return;}
2448
+ return d.overflowed[0] || d.overflowed[1];
2449
+ }
2450
+ });
2451
+
2452
+ });
2453
+
2454
+ }))}));
js/jquery.mobile.min.js CHANGED
@@ -1,3 +1,3 @@
1
  /*! jQuery Mobile v1.4.5 | Copyright 2010, 2014 jQuery Foundation, Inc. | jquery.org/license */
2
 
3
- !function(e,t,n){"function"==typeof define&&define.amd?define(["jquery"],function(i){return n(i,e,t),i.mobile}):n(e.jQuery,e,t)}(this,document,function(e,t,n,i){!function(e,t,i){function o(e){return"#"+(e=e||location.href).replace(/^[^#]*#?(.*)$/,"$1")}var a,r="hashchange",s=n,l=e.event.special,c=s.documentMode,u="on"+r in t&&(void 0===c||c>7);e.fn[r]=function(e){return e?this.bind(r,e):this.trigger(r)},e.fn[r].delay=50,l[r]=e.extend(l[r],{setup:function(){if(u)return!1;e(a.start)},teardown:function(){if(u)return!1;e(a.stop)}}),a=function(){function n(){var a=o(),s=h(l);a!==l?(d(l=a,s),e(t).trigger(r)):s!==l&&(location.href=location.href.replace(/#.*/,"")+s),i=setTimeout(n,e.fn[r].delay)}var i,a={},l=o(),c=function(e){return e},d=c,h=c;return a.start=function(){i||n()},a.stop=function(){i&&clearTimeout(i),i=void 0},t.attachEvent&&!t.addEventListener&&!u&&function(){var t,i;a.start=function(){t||(i=(i=e.fn[r].src)&&i+o(),t=e('<iframe tabindex="-1" title="empty"/>').hide().one("load",function(){i||d(o()),n()}).attr("src",i||"javascript:0").insertAfter("body")[0].contentWindow,s.onpropertychange=function(){try{"title"===event.propertyName&&(t.document.title=s.title)}catch(e){}})},a.stop=c,h=function(){return o(t.location.href)},d=function(n,i){var o=t.document,a=e.fn[r].domain;n!==i&&(o.title=s.title,o.open(),a&&o.write('<script>document.domain="'+a+'"<\/script>'),o.close(),t.location.hash=n)}}(),a}()}(e,this),function(e){e.mobile={}}(e),function(e,t,n){e.extend(e.mobile,{version:"1.4.5",subPageUrlKey:"ui-page",hideUrlBar:!0,keepNative:":jqmData(role='none'), :jqmData(role='nojs')",activePageClass:"ui-page-active",activeBtnClass:"ui-btn-active",focusClass:"ui-focus",ajaxEnabled:!0,hashListeningEnabled:!0,linkBindingEnabled:!0,defaultPageTransition:"fade",maxTransitionWidth:!1,minScrollBack:0,defaultDialogTransition:"pop",pageLoadErrorMessage:"Error Loading Page",pageLoadErrorMessageTheme:"a",phonegapNavigationEnabled:!1,autoInitializePage:!0,pushStateEnabled:!0,ignoreContentEnabled:!1,buttonMarkup:{hoverDelay:200},dynamicBaseEnabled:!0,pageContainer:e(),allowCrossDomainPages:!1,dialogHashKey:"&ui-state=dialog"})}(e),function(e,t,n){var i={},o=e.find,a=/(?:\{[\s\S]*\}|\[[\s\S]*\])$/,r=/:jqmData\(([^)]*)\)/g;e.extend(e.mobile,{ns:"",getAttribute:function(t,n){var i;(t=t.jquery?t[0]:t)&&t.getAttribute&&(i=t.getAttribute("data-"+e.mobile.ns+n));try{i="true"===i||"false"!==i&&("null"===i?null:+i+""===i?+i:a.test(i)?JSON.parse(i):i)}catch(e){}return i},nsNormalizeDict:i,nsNormalize:function(t){return i[t]||(i[t]=e.camelCase(e.mobile.ns+t))},closestPageData:function(e){return e.closest(":jqmData(role='page'), :jqmData(role='dialog')").data("mobile-page")}}),e.fn.jqmData=function(t,n){var i;return void 0!==t&&(t&&(t=e.mobile.nsNormalize(t)),i=arguments.length<2||void 0===n?this.data(t):this.data(t,n)),i},e.jqmData=function(t,n,i){var o;return void 0!==n&&(o=e.data(t,n?e.mobile.nsNormalize(n):n,i)),o},e.fn.jqmRemoveData=function(t){return this.removeData(e.mobile.nsNormalize(t))},e.jqmRemoveData=function(t,n){return e.removeData(t,e.mobile.nsNormalize(n))},e.find=function(t,n,i,a){return t.indexOf(":jqmData")>-1&&(t=t.replace(r,"[data-"+(e.mobile.ns||"")+"$1]")),o.call(this,t,n,i,a)},e.extend(e.find,o)}(e),function(e,t){function i(t,n){var i,a,r,s=t.nodeName.toLowerCase();return"area"===s?(a=(i=t.parentNode).name,!(!t.href||!a||"map"!==i.nodeName.toLowerCase())&&!!(r=e("img[usemap=#"+a+"]")[0])&&o(r)):(/input|select|textarea|button|object/.test(s)?!t.disabled:"a"===s&&t.href||n)&&o(t)}function o(t){return e.expr.filters.visible(t)&&!e(t).parents().addBack().filter(function(){return"hidden"===e.css(this,"visibility")}).length}var a=0,r=/^ui-id-\d+$/;e.ui=e.ui||{},e.extend(e.ui,{version:"c0ab71056b936627e8a7821f03c044aec6280a40",keyCode:{BACKSPACE:8,COMMA:188,DELETE:46,DOWN:40,END:35,ENTER:13,ESCAPE:27,HOME:36,LEFT:37,PAGE_DOWN:34,PAGE_UP:33,PERIOD:190,RIGHT:39,SPACE:32,TAB:9,UP:38}}),e.fn.extend({focus:function(t){return function(n,i){return"number"==typeof n?this.each(function(){var t=this;setTimeout(function(){e(t).focus(),i&&i.call(t)},n)}):t.apply(this,arguments)}}(e.fn.focus),scrollParent:function(){var t;return t=e.ui.ie&&/(static|relative)/.test(this.css("position"))||/absolute/.test(this.css("position"))?this.parents().filter(function(){return/(relative|absolute|fixed)/.test(e.css(this,"position"))&&/(auto|scroll)/.test(e.css(this,"overflow")+e.css(this,"overflow-y")+e.css(this,"overflow-x"))}).eq(0):this.parents().filter(function(){return/(auto|scroll)/.test(e.css(this,"overflow")+e.css(this,"overflow-y")+e.css(this,"overflow-x"))}).eq(0),/fixed/.test(this.css("position"))||!t.length?e(this[0].ownerDocument||n):t},uniqueId:function(){return this.each(function(){this.id||(this.id="ui-id-"+ ++a)})},removeUniqueId:function(){return this.each(function(){r.test(this.id)&&e(this).removeAttr("id")})}}),e.extend(e.expr[":"],{data:e.expr.createPseudo?e.expr.createPseudo(function(t){return function(n){return!!e.data(n,t)}}):function(t,n,i){return!!e.data(t,i[3])},focusable:function(t){return i(t,!isNaN(e.attr(t,"tabindex")))},tabbable:function(t){var n=e.attr(t,"tabindex"),o=isNaN(n);return(o||n>=0)&&i(t,!o)}}),e("<a>").outerWidth(1).jquery||e.each(["Width","Height"],function(t,n){function i(t,n,i,a){return e.each(o,function(){n-=parseFloat(e.css(t,"padding"+this))||0,i&&(n-=parseFloat(e.css(t,"border"+this+"Width"))||0),a&&(n-=parseFloat(e.css(t,"margin"+this))||0)}),n}var o="Width"===n?["Left","Right"]:["Top","Bottom"],a=n.toLowerCase(),r={innerWidth:e.fn.innerWidth,innerHeight:e.fn.innerHeight,outerWidth:e.fn.outerWidth,outerHeight:e.fn.outerHeight};e.fn["inner"+n]=function(t){return void 0===t?r["inner"+n].call(this):this.each(function(){e(this).css(a,i(this,t)+"px")})},e.fn["outer"+n]=function(t,o){return"number"!=typeof t?r["outer"+n].call(this,t):this.each(function(){e(this).css(a,i(this,t,!0,o)+"px")})}}),e.fn.addBack||(e.fn.addBack=function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}),e("<a>").data("a-b","a").removeData("a-b").data("a-b")&&(e.fn.removeData=function(t){return function(n){return arguments.length?t.call(this,e.camelCase(n)):t.call(this)}}(e.fn.removeData)),e.ui.ie=!!/msie [\w.]+/.exec(navigator.userAgent.toLowerCase()),e.support.selectstart="onselectstart"in n.createElement("div"),e.fn.extend({disableSelection:function(){return this.bind((e.support.selectstart?"selectstart":"mousedown")+".ui-disableSelection",function(e){e.preventDefault()})},enableSelection:function(){return this.unbind(".ui-disableSelection")},zIndex:function(t){if(void 0!==t)return this.css("zIndex",t);if(this.length)for(var i,o,a=e(this[0]);a.length&&a[0]!==n;){if(("absolute"===(i=a.css("position"))||"relative"===i||"fixed"===i)&&(o=parseInt(a.css("zIndex"),10),!isNaN(o)&&0!==o))return o;a=a.parent()}return 0}}),e.ui.plugin={add:function(t,n,i){var o,a=e.ui[t].prototype;for(o in i)a.plugins[o]=a.plugins[o]||[],a.plugins[o].push([n,i[o]])},call:function(e,t,n,i){var o,a=e.plugins[t];if(a&&(i||e.element[0].parentNode&&11!==e.element[0].parentNode.nodeType))for(o=0;o<a.length;o++)e.options[a[o][0]]&&a[o][1].apply(e.element,n)}}}(e),function(e,t,i){e.extend(e.mobile,{window:e(t),document:e(n),keyCode:e.ui.keyCode,behaviors:{},silentScroll:function(n){"number"!==e.type(n)&&(n=e.mobile.defaultHomeScroll),e.event.special.scrollstart.enabled=!1,setTimeout(function(){t.scrollTo(0,n),e.mobile.document.trigger("silentscroll",{x:0,y:n})},20),setTimeout(function(){e.event.special.scrollstart.enabled=!0},150)},getClosestBaseUrl:function(t){var n=e(t).closest(".ui-page").jqmData("url"),i=e.mobile.path.documentBase.hrefNoHash;return e.mobile.dynamicBaseEnabled&&n&&e.mobile.path.isPath(n)||(n=i),e.mobile.path.makeUrlAbsolute(n,i)},removeActiveLinkClass:function(t){!e.mobile.activeClickedLink||e.mobile.activeClickedLink.closest("."+e.mobile.activePageClass).length&&!t||e.mobile.activeClickedLink.removeClass(e.mobile.activeBtnClass),e.mobile.activeClickedLink=null},getInheritedTheme:function(e,t){for(var n,i,o=e[0],a="",r=/ui-(bar|body|overlay)-([a-z])\b/;o&&!((n=o.className||"")&&(i=r.exec(n))&&(a=i[2]));)o=o.parentNode;return a||t||"a"},enhanceable:function(e){return this.haveParents(e,"enhance")},hijackable:function(e){return this.haveParents(e,"ajax")},haveParents:function(t,n){if(!e.mobile.ignoreContentEnabled)return t;var i,o,a,r,s=t.length,l=e();for(r=0;r<s;r++){for(o=t.eq(r),a=!1,i=t[r];i;){if("false"===(i.getAttribute?i.getAttribute("data-"+e.mobile.ns+n):"")){a=!0;break}i=i.parentNode}a||(l=l.add(o))}return l},getScreenHeight:function(){return t.innerHeight||e.mobile.window.height()},resetActivePageHeight:function(t){var n=e("."+e.mobile.activePageClass),i=n.height(),o=n.outerHeight(!0);t=function(t,n){var i=t.parent(),o=[],a=function(){var t=e(this),n=e.mobile.toolbar&&t.data("mobile-toolbar")?t.toolbar("option"):{position:t.attr("data-"+e.mobile.ns+"position"),updatePagePadding:!1!==t.attr("data-"+e.mobile.ns+"update-page-padding")};return!("fixed"===n.position&&!0===n.updatePagePadding)},r=i.children(":jqmData(role='header')").filter(a),s=t.children(":jqmData(role='header')"),l=i.children(":jqmData(role='footer')").filter(a),c=t.children(":jqmData(role='footer')");return 0===s.length&&r.length>0&&(o=o.concat(r.toArray())),0===c.length&&l.length>0&&(o=o.concat(l.toArray())),e.each(o,function(t,i){n-=e(i).outerHeight()}),Math.max(0,n)}(n,"number"==typeof t?t:e.mobile.getScreenHeight()),n.css("min-height",""),n.height()<t&&n.css("min-height",t-(o-i))},loading:function(){var t=this.loading._widget||e(e.mobile.loader.prototype.defaultHtml).loader(),n=t.loader.apply(t,arguments);return this.loading._widget=t,n}}),e.addDependents=function(t,n){var i=e(t),o=i.jqmData("dependents")||e();i.jqmData("dependents",e(o).add(n))},e.fn.extend({removeWithDependents:function(){e.removeWithDependents(this)},enhanceWithin:function(){var t,n={},i=e.mobile.page.prototype.keepNativeSelector(),o=this;for(t in e.mobile.nojs&&e.mobile.nojs(this),e.mobile.links&&e.mobile.links(this),e.mobile.degradeInputsWithin&&e.mobile.degradeInputsWithin(this),e.fn.buttonMarkup&&this.find(e.fn.buttonMarkup.initSelector).not(i).jqmEnhanceable().buttonMarkup(),e.fn.fieldcontain&&this.find(":jqmData(role='fieldcontain')").not(i).jqmEnhanceable().fieldcontain(),e.each(e.mobile.widgets,function(t,a){if(a.initSelector){var r=e.mobile.enhanceable(o.find(a.initSelector));r.length>0&&(r=r.not(i)),r.length>0&&(n[a.prototype.widgetName]=r)}}),n)n[t][t]();return this},addDependents:function(t){e.addDependents(this,t)},getEncodedText:function(){return e("<a>").text(this.text()).html()},jqmEnhanceable:function(){return e.mobile.enhanceable(this)},jqmHijackable:function(){return e.mobile.hijackable(this)}}),e.removeWithDependents=function(t){var n=e(t);(n.jqmData("dependents")||e()).remove(),n.remove()},e.addDependents=function(t,n){var i=e(t),o=i.jqmData("dependents")||e();i.jqmData("dependents",e(o).add(n))},e.find.matches=function(t,n){return e.find(t,null,null,n)},e.find.matchesSelector=function(t,n){return e.find(n,null,null,[t]).length>0}}(e,this),function(e,i){t.matchMedia=t.matchMedia||function(e,t){var n,i=e.documentElement,o=i.firstElementChild||i.firstChild,a=e.createElement("body"),r=e.createElement("div");return r.id="mq-test-1",r.style.cssText="position:absolute;top:-100em",a.style.background="none",a.appendChild(r),function(e){return r.innerHTML='&shy;<style media="'+e+'"> #mq-test-1 { width: 42px; }</style>',i.insertBefore(a,o),n=42===r.offsetWidth,i.removeChild(a),{matches:n,media:e}}}(n),e.mobile.media=function(e){return t.matchMedia(e).matches}}(e),function(e,t){var i={touch:"ontouchend"in n};e.mobile.support=e.mobile.support||{},e.extend(e.support,i),e.extend(e.mobile.support,i)}(e),function(e,n){e.extend(e.support,{orientation:"orientation"in t&&"onorientationchange"in t})}(e),function(e,i){function o(e){var t,n=e.charAt(0).toUpperCase()+e.substr(1),o=(e+" "+l.join(n+" ")+n).split(" ");for(t in o)if(s[o[t]]!==i)return!0}var a,r=e("<body>").prependTo("html"),s=r[0].style,l=["Webkit","Moz","O"],c="palmGetResource"in t,u=t.operamini&&"[object OperaMini]"==={}.toString.call(t.operamini),d=t.blackberry&&!o("-webkit-transform");e.extend(e.mobile,{browser:{}}),e.mobile.browser.oldIE=function(){var e=3,t=n.createElement("div"),i=t.all||[];do{t.innerHTML="\x3c!--[if gt IE "+ ++e+"]><br><![endif]--\x3e"}while(i[0]);return e>4?e:!e}(),e.extend(e.support,{pushState:"pushState"in history&&"replaceState"in history&&!(t.navigator.userAgent.indexOf("Firefox")>=0&&t.top!==t)&&-1===t.navigator.userAgent.search(/CriOS/),mediaquery:e.mobile.media("only all"),cssPseudoElement:!!o("content"),touchOverflow:!!o("overflowScrolling"),cssTransform3d:function(){var o,a,s,c="transform-3d",u=e.mobile.media("(-"+l.join("-"+c+"),(-")+"-"+c+"),("+c+")");if(u)return!!u;for(s in o=n.createElement("div"),a={MozTransform:"-moz-transform",transform:"transform"},r.append(o),a)o.style[s]!==i&&(o.style[s]="translate3d( 100px, 1px, 1px )",u=t.getComputedStyle(o).getPropertyValue(a[s]));return!!u&&"none"!==u}(),boxShadow:!!o("boxShadow")&&!d,fixedPosition:function(){var e=t,n=navigator.userAgent,i=navigator.platform,o=n.match(/AppleWebKit\/([0-9]+)/),a=!!o&&o[1],r=n.match(/Fennec\/([0-9]+)/),s=!!r&&r[1],l=n.match(/Opera Mobi\/([0-9]+)/),c=!!l&&l[1];return!((i.indexOf("iPhone")>-1||i.indexOf("iPad")>-1||i.indexOf("iPod")>-1)&&a&&a<534||e.operamini&&"[object OperaMini]"==={}.toString.call(e.operamini)||l&&c<7458||n.indexOf("Android")>-1&&a&&a<533||s&&s<6||"palmGetResource"in t&&a&&a<534||n.indexOf("MeeGo")>-1&&n.indexOf("NokiaBrowser/8.5.0")>-1)}(),scrollTop:("pageXOffset"in t||"scrollTop"in n.documentElement||"scrollTop"in r[0])&&!c&&!u,dynamicBaseTag:function(){var t,n=location.protocol+"//"+location.host+location.pathname+"ui-dir/",i=e("head base"),o=null,a="";return i.length?a=i.attr("href"):i=o=e("<base>",{href:n}).appendTo("head"),t=e("<a href='testurl' />").prependTo(r)[0].href,i[0].href=a||location.pathname,o&&o.remove(),0===t.indexOf(n)}(),cssPointerEvents:function(){var e,i=n.createElement("x"),o=n.documentElement,a=t.getComputedStyle;return"pointerEvents"in i.style&&(i.style.pointerEvents="auto",i.style.pointerEvents="x",o.appendChild(i),e=a&&"auto"===a(i,"").pointerEvents,o.removeChild(i),!!e)}(),boundingRect:void 0!==n.createElement("div").getBoundingClientRect,inlineSVG:function(){var n=t,i=!(!n.document.createElementNS||!n.document.createElementNS("http://www.w3.org/2000/svg","svg").createSVGRect||n.opera&&-1===navigator.userAgent.indexOf("Chrome")),o=function(t){t&&i||e("html").addClass("ui-nosvg")},a=new n.Image;a.onerror=function(){o(!1)},a.onload=function(){o(1===a.width&&1===a.height)},a.src=""}}),r.remove(),a=function(){var e=t.navigator.userAgent;return e.indexOf("Nokia")>-1&&(e.indexOf("Symbian/3")>-1||e.indexOf("Series60/5")>-1)&&e.indexOf("AppleWebKit")>-1&&e.match(/(BrowserNG|NokiaBrowser)\/7\.[0-3]/)}(),e.mobile.gradeA=function(){return(e.support.mediaquery&&e.support.cssPseudoElement||e.mobile.browser.oldIE&&e.mobile.browser.oldIE>=8)&&(e.support.boundingRect||null!==e.fn.jquery.match(/1\.[0-7+]\.[0-9+]?/))},e.mobile.ajaxBlacklist=t.blackberry&&!t.WebKitPoint||u||a,a&&e(function(){e("head link[rel='stylesheet']").attr("rel","alternate stylesheet").attr("rel","stylesheet")}),e.support.boxShadow||e("html").addClass("ui-noboxshadow")}(e),function(e,t){var n,i=e.mobile.window,o=function(){};e.event.special.beforenavigate={setup:function(){i.on("navigate",o)},teardown:function(){i.off("navigate",o)}},e.event.special.navigate=n={bound:!1,pushStateEnabled:!0,originalEventName:void 0,isPushStateEnabled:function(){return e.support.pushState&&!0===e.mobile.pushStateEnabled&&this.isHashChangeEnabled()},isHashChangeEnabled:function(){return!0===e.mobile.hashListeningEnabled},popstate:function(t){var n=new e.Event("navigate"),o=new e.Event("beforenavigate"),a=t.originalEvent.state||{};o.originalEvent=t,i.trigger(o),o.isDefaultPrevented()||(t.historyState&&e.extend(a,t.historyState),n.originalEvent=t,setTimeout(function(){i.trigger(n,{state:a})},0))},hashchange:function(t){var n=new e.Event("navigate"),o=new e.Event("beforenavigate");o.originalEvent=t,i.trigger(o),o.isDefaultPrevented()||(n.originalEvent=t,i.trigger(n,{state:t.hashchangeState||{}}))},setup:function(){n.bound||(n.bound=!0,n.isPushStateEnabled()?(n.originalEventName="popstate",i.bind("popstate.navigate",n.popstate)):n.isHashChangeEnabled()&&(n.originalEventName="hashchange",i.bind("hashchange.navigate",n.hashchange)))}}}(e),function(e){e.event.special.throttledresize={setup:function(){e(this).bind("resize",o)},teardown:function(){e(this).unbind("resize",o)}};var t,n,i,o=function(){n=(new Date).getTime(),(i=n-a)>=250?(a=n,e(this).trigger("throttledresize")):(t&&clearTimeout(t),t=setTimeout(o,250-i))},a=0}(e),function(e,t){function i(){var e=o();e!==a&&(a=e,u.trigger(d))}var o,a,r,s,l,c,u=e(t),d="orientationchange",h={0:!0,180:!0};e.support.orientation&&(50,r=(l=t.innerWidth||u.width())>(c=t.innerHeight||u.height())&&l-c>50,s=h[t.orientation],(r&&s||!r&&!s)&&(h={"-90":!0,90:!0})),e.event.special.orientationchange=e.extend({},e.event.special.orientationchange,{setup:function(){if(e.support.orientation&&!e.event.special.orientationchange.disabled)return!1;a=o(),u.bind("throttledresize",i)},teardown:function(){if(e.support.orientation&&!e.event.special.orientationchange.disabled)return!1;u.unbind("throttledresize",i)},add:function(e){var t=e.handler;e.handler=function(e){return e.orientation=o(),t.apply(this,arguments)}}}),e.event.special.orientationchange.orientation=o=function(){var i=n.documentElement;return(e.support.orientation?h[t.orientation]:i&&i.clientWidth/i.clientHeight<1.1)?"portrait":"landscape"},e.fn[d]=function(e){return e?this.bind(d,e):this.trigger(d)}}(e,this),function(e,t,n,i){function o(e){for(;e&&void 0!==e.originalEvent;)e=e.originalEvent;return e}function a(t,n){var a,r,s,l,c,u,d,h,f,p=t.type;if((t=e.Event(t)).type=n,a=t.originalEvent,r=e.event.props,p.search(/^(mouse|click)/)>-1&&(r=A),a)for(d=r.length;d;)t[l=r[--d]]=a[l];if(p.search(/mouse(down|up)|click/)>-1&&!t.which&&(t.which=1),-1!==p.search(/^touch/)&&(p=(s=o(a)).touches,c=s.changedTouches,u=p&&p.length?p[0]:c&&c.length?c[0]:i))for(h=0,f=T.length;h<f;h++)t[l=T[h]]=u[l];return t}function r(t){for(var n,i,o={};t;){for(i in n=e.data(t,y))n[i]&&(o[i]=o.hasVirtualBinding=!0);t=t.parentNode}return o}function s(){M=!0}function l(){M=!1}function c(){u(),k=setTimeout(function(){k=0,L=0,q.length=0,O=!1,s()},e.vmouse.resetTimerDuration)}function u(){k&&(clearTimeout(k),k=0)}function d(t,n,i){var o;return(i&&i[t]||!i&&function(t,n){for(var i;t;){if((i=e.data(t,y))&&(!n||i[n]))return t;t=t.parentNode}return null}(n.target,t))&&(o=a(n,t),e(n.target).trigger(o)),o}function h(t){var n,i=e.data(t.target,x);O||L&&L===i||(n=d("v"+t.type,t))&&(n.isDefaultPrevented()&&t.preventDefault(),n.isPropagationStopped()&&t.stopPropagation(),n.isImmediatePropagationStopped()&&t.stopImmediatePropagation())}function f(t){var n,i,a,s=o(t).touches;s&&1===s.length&&((i=r(n=t.target)).hasVirtualBinding&&(L=H++,e.data(n,x,L),u(),l(),N=!1,a=o(t).touches[0],C=a.pageX,j=a.pageY,d("vmouseover",t,i),d("vmousedown",t,i)))}function p(e){M||(N||d("vmousecancel",e,r(e.target)),N=!0,c())}function m(t){if(!M){var n=o(t).touches[0],i=N,a=e.vmouse.moveDistanceThreshold,s=r(t.target);(N=N||Math.abs(n.pageX-C)>a||Math.abs(n.pageY-j)>a)&&!i&&d("vmousecancel",t,s),d("vmousemove",t,s),c()}}function v(e){if(!M){s();var t,n,i=r(e.target);d("vmouseup",e,i),N||(t=d("vclick",e,i))&&t.isDefaultPrevented()&&(n=o(e).changedTouches[0],q.push({touchID:L,x:n.clientX,y:n.clientY}),O=!0),d("vmouseout",e,i),N=!1,c()}}function g(t){var n,i=e.data(t,y);if(i)for(n in i)if(i[n])return!0;return!1}function b(){}var w,E,y="virtualMouseBindings",x="virtualTouchID",D="vmouseover vmousedown vmousemove vmouseup vclick vmouseout vmousecancel".split(" "),T="clientX clientY pageX pageY screenX screenY".split(" "),P=e.event.mouseHooks?e.event.mouseHooks.props:[],A=e.event.props.concat(P),S={},k=0,C=0,j=0,N=!1,q=[],O=!1,M=!1,I="addEventListener"in n,B=e(n),H=1,L=0;for(e.vmouse={moveDistanceThreshold:10,clickDistanceThreshold:10,resetTimerDuration:1500},E=0;E<D.length;E++)e.event.special[D[E]]=function(t){var n=t.substr(1);return{setup:function(){g(this)||e.data(this,y,{}),e.data(this,y)[t]=!0,S[t]=(S[t]||0)+1,1===S[t]&&B.bind(n,h),e(this).bind(n,b),I&&(S.touchstart=(S.touchstart||0)+1,1===S.touchstart&&B.bind("touchstart",f).bind("touchend",v).bind("touchmove",m).bind("scroll",p))},teardown:function(){--S[t],S[t]||B.unbind(n,h),I&&(--S.touchstart||B.unbind("touchstart",f).unbind("touchmove",m).unbind("touchend",v).unbind("scroll",p));var i=e(this),o=e.data(this,y);o&&(o[t]=!1),i.unbind(n,b),g(this)||i.removeData(y)}}}(D[E]);I&&n.addEventListener("click",function(t){var n,i,o,a,r,s=q.length,l=t.target;if(s)for(n=t.clientX,i=t.clientY,w=e.vmouse.clickDistanceThreshold,o=l;o;){for(a=0;a<s;a++)if(r=q[a],o===l&&Math.abs(r.x-n)<w&&Math.abs(r.y-i)<w||e.data(o,x)===r.touchID)return t.preventDefault(),void t.stopPropagation();o=o.parentNode}},!0)}(e,0,n),function(e,t,i){function o(t,n,o,a){var r=o.type;o.type=n,a?e.event.trigger(o,i,t):e.event.dispatch.call(t,o),o.type=r}var a=e(n),r=e.mobile.support.touch,s=r?"touchstart":"mousedown",l=r?"touchend":"mouseup",c=r?"touchmove":"mousemove";e.each("touchstart touchmove touchend tap taphold swipe swipeleft swiperight scrollstart scrollstop".split(" "),function(t,n){e.fn[n]=function(e){return e?this.bind(n,e):this.trigger(n)}}),e.event.special.scrollstart={enabled:!0,setup:function(){function t(e,t){o(a,(n=t)?"scrollstart":"scrollstop",e)}var n,i,a=this;e(a).bind("touchmove scroll",function(o){e.event.special.scrollstart.enabled&&(n||t(o,!0),clearTimeout(i),i=setTimeout(function(){t(o,!1)},50))})},teardown:function(){e(this).unbind("touchmove scroll")}},e.event.special.tap={tapholdThreshold:750,emitTapOnTaphold:!0,setup:function(){var t=this,n=e(t),i=!1;n.bind("vmousedown",function(r){function s(){clearTimeout(u)}function l(){s(),n.unbind("vclick",c).unbind("vmouseup",s),a.unbind("vmousecancel",l)}function c(e){l(),i||d!==e.target?i&&e.preventDefault():o(t,"tap",e)}if(i=!1,r.which&&1!==r.which)return!1;var u,d=r.target;n.bind("vmouseup",s).bind("vclick",c),a.bind("vmousecancel",l),u=setTimeout(function(){e.event.special.tap.emitTapOnTaphold||(i=!0),o(t,"taphold",e.Event("taphold",{target:d}))},e.event.special.tap.tapholdThreshold)})},teardown:function(){e(this).unbind("vmousedown").unbind("vclick").unbind("vmouseup"),a.unbind("vmousecancel")}},e.event.special.swipe={scrollSupressionThreshold:30,durationThreshold:1e3,horizontalDistanceThreshold:30,verticalDistanceThreshold:30,getLocation:function(e){var n=t.pageXOffset,i=t.pageYOffset,o=e.clientX,a=e.clientY;return 0===e.pageY&&Math.floor(a)>Math.floor(e.pageY)||0===e.pageX&&Math.floor(o)>Math.floor(e.pageX)?(o-=n,a-=i):(a<e.pageY-i||o<e.pageX-n)&&(o=e.pageX-n,a=e.pageY-i),{x:o,y:a}},start:function(t){var n=t.originalEvent.touches?t.originalEvent.touches[0]:t,i=e.event.special.swipe.getLocation(n);return{time:(new Date).getTime(),coords:[i.x,i.y],origin:e(t.target)}},stop:function(t){var n=t.originalEvent.touches?t.originalEvent.touches[0]:t,i=e.event.special.swipe.getLocation(n);return{time:(new Date).getTime(),coords:[i.x,i.y]}},handleSwipe:function(t,n,i,a){if(n.time-t.time<e.event.special.swipe.durationThreshold&&Math.abs(t.coords[0]-n.coords[0])>e.event.special.swipe.horizontalDistanceThreshold&&Math.abs(t.coords[1]-n.coords[1])<e.event.special.swipe.verticalDistanceThreshold){var r=t.coords[0]>n.coords[0]?"swipeleft":"swiperight";return o(i,"swipe",e.Event("swipe",{target:a,swipestart:t,swipestop:n}),!0),o(i,r,e.Event(r,{target:a,swipestart:t,swipestop:n}),!0),!0}return!1},eventInProgress:!1,setup:function(){var t,n=this,i=e(n),o={};(t=e.data(this,"mobile-events"))||(t={length:0},e.data(this,"mobile-events",t)),t.length++,t.swipe=o,o.start=function(t){if(!e.event.special.swipe.eventInProgress){e.event.special.swipe.eventInProgress=!0;var i,r=e.event.special.swipe.start(t),s=t.target,u=!1;o.move=function(t){r&&!t.isDefaultPrevented()&&(i=e.event.special.swipe.stop(t),u||(u=e.event.special.swipe.handleSwipe(r,i,n,s))&&(e.event.special.swipe.eventInProgress=!1),Math.abs(r.coords[0]-i.coords[0])>e.event.special.swipe.scrollSupressionThreshold&&t.preventDefault())},o.stop=function(){u=!0,e.event.special.swipe.eventInProgress=!1,a.off(c,o.move),o.move=null},a.on(c,o.move).one(l,o.stop)}},i.on(s,o.start)},teardown:function(){var t,n;(t=e.data(this,"mobile-events"))&&(n=t.swipe,delete t.swipe,0==--t.length&&e.removeData(this,"mobile-events")),n&&(n.start&&e(this).off(s,n.start),n.move&&a.off(c,n.move),n.stop&&a.off(l,n.stop))}},e.each({scrollstop:"scrollstart",taphold:"tap",swipeleft:"swipe.left",swiperight:"swipe.right"},function(t,n){e.event.special[t]={setup:function(){e(this).bind(n,e.noop)},teardown:function(){e(this).unbind(n)}}})}(e,this)});
1
  /*! jQuery Mobile v1.4.5 | Copyright 2010, 2014 jQuery Foundation, Inc. | jquery.org/license */
2
 
3
+ !function(e,t,n){"function"==typeof define&&define.amd?define(["jquery"],function(i){return n(i,e,t),i.mobile}):n(e.jQuery,e,t)}(this,document,function(e,t,n,i){!function(e,t,i){function o(e){return"#"+(e=e||location.href).replace(/^[^#]*#?(.*)$/,"$1")}var a,r="hashchange",s=n,l=e.event.special,c=s.documentMode,u="on"+r in t&&(void 0===c||c>7);e.fn[r]=function(e){return e?this.bind(r,e):this.trigger(r)},e.fn[r].delay=50,l[r]=e.extend(l[r],{setup:function(){if(u)return!1;e(a.start)},teardown:function(){if(u)return!1;e(a.stop)}}),a=function(){function n(){var a=o(),s=h(l);a!==l?(d(l=a,s),e(t).trigger(r)):s!==l&&(location.href=location.href.replace(/#.*/,"")+s),i=setTimeout(n,e.fn[r].delay)}var i,a={},l=o(),c=function(e){return e},d=c,h=c;return a.start=function(){i||n()},a.stop=function(){i&&clearTimeout(i),i=void 0},t.attachEvent&&!t.addEventListener&&!u&&function(){var t,i;a.start=function(){t||(i=(i=e.fn[r].src)&&i+o(),t=e('<iframe tabindex="-1" title="empty"/>').hide().one("load",function(){i||d(o()),n()}).attr("src",i||"javascript:0").insertAfter("body")[0].contentWindow,s.onpropertychange=function(){try{"title"===event.propertyName&&(t.document.title=s.title)}catch(e){}})},a.stop=c,h=function(){return o(t.location.href)},d=function(n,i){var o=t.document,a=e.fn[r].domain;n!==i&&(o.title=s.title,o.open(),a&&o.write('<script>document.domain="'+a+'"<\/script>'),o.close(),t.location.hash=n)}}(),a}()}(e,this),function(e){e.mobile={}}(e),function(e,t,n){e.extend(e.mobile,{version:"1.4.5",subPageUrlKey:"ui-page",hideUrlBar:!0,keepNative:":jqmData(role='none'), :jqmData(role='nojs')",activePageClass:"ui-page-active",activeBtnClass:"ui-btn-active",focusClass:"ui-focus",ajaxEnabled:!0,hashListeningEnabled:!0,linkBindingEnabled:!0,defaultPageTransition:"fade",maxTransitionWidth:!1,minScrollBack:0,defaultDialogTransition:"pop",pageLoadErrorMessage:"Error Loading Page",pageLoadErrorMessageTheme:"a",phonegapNavigationEnabled:!1,autoInitializePage:!0,pushStateEnabled:!0,ignoreContentEnabled:!1,buttonMarkup:{hoverDelay:200},dynamicBaseEnabled:!0,pageContainer:e(),allowCrossDomainPages:!1,dialogHashKey:"&ui-state=dialog"})}(e),function(e,t,n){var i={},o=e.find,a=/(?:\{[\s\S]*\}|\[[\s\S]*\])$/,r=/:jqmData\(([^)]*)\)/g;e.extend(e.mobile,{ns:"",getAttribute:function(t,n){var i;(t=t.jquery?t[0]:t)&&t.getAttribute&&(i=t.getAttribute("data-"+e.mobile.ns+n));try{i="true"===i||"false"!==i&&("null"===i?null:+i+""===i?+i:a.test(i)?JSON.parse(i):i)}catch(e){}return i},nsNormalizeDict:i,nsNormalize:function(t){return i[t]||(i[t]=e.camelCase(e.mobile.ns+t))},closestPageData:function(e){return e.closest(":jqmData(role='page'), :jqmData(role='dialog')").data("mobile-page")}}),e.fn.jqmData=function(t,n){var i;return void 0!==t&&(t&&(t=e.mobile.nsNormalize(t)),i=arguments.length<2||void 0===n?this.data(t):this.data(t,n)),i},e.jqmData=function(t,n,i){var o;return void 0!==n&&(o=e.data(t,n?e.mobile.nsNormalize(n):n,i)),o},e.fn.jqmRemoveData=function(t){return this.removeData(e.mobile.nsNormalize(t))},e.jqmRemoveData=function(t,n){return e.removeData(t,e.mobile.nsNormalize(n))},e.find=function(t,n,i,a){return t.indexOf(":jqmData")>-1&&(t=t.replace(r,"[data-"+(e.mobile.ns||"")+"$1]")),o.call(this,t,n,i,a)},e.extend(e.find,o)}(e),function(e,t){function i(t,n){var i,a,r,s=t.nodeName.toLowerCase();return"area"===s?(a=(i=t.parentNode).name,!(!t.href||!a||"map"!==i.nodeName.toLowerCase())&&!!(r=e("img[usemap=#"+a+"]")[0])&&o(r)):(/input|select|textarea|button|object/.test(s)?!t.disabled:"a"===s&&t.href||n)&&o(t)}function o(t){return e.expr.filters.visible(t)&&!e(t).parents().addBack().filter(function(){return"hidden"===e.css(this,"visibility")}).length}var a=0,r=/^ui-id-\d+$/;e.ui=e.ui||{},e.extend(e.ui,{version:"c0ab71056b936627e8a7821f03c044aec6280a40",keyCode:{BACKSPACE:8,COMMA:188,DELETE:46,DOWN:40,END:35,ENTER:13,ESCAPE:27,HOME:36,LEFT:37,PAGE_DOWN:34,PAGE_UP:33,PERIOD:190,RIGHT:39,SPACE:32,TAB:9,UP:38}}),e.fn.extend({focus:function(t){return function(n,i){return"number"==typeof n?this.each(function(){var t=this;setTimeout(function(){e(t).focus(),i&&i.call(t)},n)}):t.apply(this,arguments)}}(e.fn.focus),scrollParent:function(){var t;return t=e.ui.ie&&/(static|relative)/.test(this.css("position"))||/absolute/.test(this.css("position"))?this.parents().filter(function(){return/(relative|absolute|fixed)/.test(e.css(this,"position"))&&/(auto|scroll)/.test(e.css(this,"overflow")+e.css(this,"overflow-y")+e.css(this,"overflow-x"))}).eq(0):this.parents().filter(function(){return/(auto|scroll)/.test(e.css(this,"overflow")+e.css(this,"overflow-y")+e.css(this,"overflow-x"))}).eq(0),/fixed/.test(this.css("position"))||!t.length?e(this[0].ownerDocument||n):t},uniqueId:function(){return this.each(function(){this.id||(this.id="ui-id-"+ ++a)})},removeUniqueId:function(){return this.each(function(){r.test(this.id)&&e(this).removeAttr("id")})}}),e.extend(e.expr[":"],{data:e.expr.createPseudo?e.expr.createPseudo(function(t){return function(n){return!!e.data(n,t)}}):function(t,n,i){return!!e.data(t,i[3])},focusable:function(t){return i(t,!isNaN(e.attr(t,"tabindex")))},tabbable:function(t){var n=e.attr(t,"tabindex"),o=isNaN(n);return(o||n>=0)&&i(t,!o)}}),e("<a>").outerWidth(1).jquery||e.each(["Width","Height"],function(t,n){function i(t,n,i,a){return e.each(o,function(){n-=parseFloat(e.css(t,"padding"+this))||0,i&&(n-=parseFloat(e.css(t,"border"+this+"Width"))||0),a&&(n-=parseFloat(e.css(t,"margin"+this))||0)}),n}var o="Width"===n?["Left","Right"]:["Top","Bottom"],a=n.toLowerCase(),r={innerWidth:e.fn.innerWidth,innerHeight:e.fn.innerHeight,outerWidth:e.fn.outerWidth,outerHeight:e.fn.outerHeight};e.fn["inner"+n]=function(t){return void 0===t?r["inner"+n].call(this):this.each(function(){e(this).css(a,i(this,t)+"px")})},e.fn["outer"+n]=function(t,o){return"number"!=typeof t?r["outer"+n].call(this,t):this.each(function(){e(this).css(a,i(this,t,!0,o)+"px")})}}),e.fn.addBack||(e.fn.addBack=function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}),e("<a>").data("a-b","a").removeData("a-b").data("a-b")&&(e.fn.removeData=function(t){return function(n){return arguments.length?t.call(this,e.camelCase(n)):t.call(this)}}(e.fn.removeData)),e.ui.ie=!!/msie [\w.]+/.exec(navigator.userAgent.toLowerCase()),e.support.selectstart="onselectstart"in n.createElement("div"),e.fn.extend({disableSelection:function(){return this.bind((e.support.selectstart?"selectstart":"mousedown")+".ui-disableSelection",function(e){e.preventDefault()})},enableSelection:function(){return this.unbind(".ui-disableSelection")},zIndex:function(t){if(void 0!==t)return this.css("zIndex",t);if(this.length)for(var i,o,a=e(this[0]);a.length&&a[0]!==n;){if(("absolute"===(i=a.css("position"))||"relative"===i||"fixed"===i)&&(o=parseInt(a.css("zIndex"),10),!isNaN(o)&&0!==o))return o;a=a.parent()}return 0}}),e.ui.plugin={add:function(t,n,i){var o,a=e.ui[t].prototype;for(o in i)a.plugins[o]=a.plugins[o]||[],a.plugins[o].push([n,i[o]])},call:function(e,t,n,i){var o,a=e.plugins[t];if(a&&(i||e.element[0].parentNode&&11!==e.element[0].parentNode.nodeType))for(o=0;o<a.length;o++)e.options[a[o][0]]&&a[o][1].apply(e.element,n)}}}(e),function(e,t,i){e.extend(e.mobile,{window:e(t),document:e(n),keyCode:e.ui.keyCode,behaviors:{},silentScroll:function(n){"number"!==e.type(n)&&(n=e.mobile.defaultHomeScroll),e.event.special.scrollstart.enabled=!1,setTimeout(function(){t.scrollTo(0,n),e.mobile.document.trigger("silentscroll",{x:0,y:n})},20),setTimeout(function(){e.event.special.scrollstart.enabled=!0},150)},getClosestBaseUrl:function(t){var n=e(t).closest(".ui-page").jqmData("url"),i=e.mobile.path.documentBase.hrefNoHash;return e.mobile.dynamicBaseEnabled&&n&&e.mobile.path.isPath(n)||(n=i),e.mobile.path.makeUrlAbsolute(n,i)},removeActiveLinkClass:function(t){!e.mobile.activeClickedLink||e.mobile.activeClickedLink.closest("."+e.mobile.activePageClass).length&&!t||e.mobile.activeClickedLink.removeClass(e.mobile.activeBtnClass),e.mobile.activeClickedLink=null},getInheritedTheme:function(e,t){for(var n,i,o=e[0],a="",r=/ui-(bar|body|overlay)-([a-z])\b/;o&&!((n=o.className||"")&&(i=r.exec(n))&&(a=i[2]));)o=o.parentNode;return a||t||"a"},enhanceable:function(e){return this.haveParents(e,"enhance")},hijackable:function(e){return this.haveParents(e,"ajax")},haveParents:function(t,n){if(!e.mobile.ignoreContentEnabled)return t;var i,o,a,r,s=t.length,l=e();for(r=0;r<s;r++){for(o=t.eq(r),a=!1,i=t[r];i;){if("false"===(i.getAttribute?i.getAttribute("data-"+e.mobile.ns+n):"")){a=!0;break}i=i.parentNode}a||(l=l.add(o))}return l},getScreenHeight:function(){return t.innerHeight||e.mobile.window.height()},resetActivePageHeight:function(t){var n=e("."+e.mobile.activePageClass),i=n.height(),o=n.outerHeight(!0);t=function(t,n){var i=t.parent(),o=[],a=function(){var t=e(this),n=e.mobile.toolbar&&t.data("mobile-toolbar")?t.toolbar("option"):{position:t.attr("data-"+e.mobile.ns+"position"),updatePagePadding:!1!==t.attr("data-"+e.mobile.ns+"update-page-padding")};return!("fixed"===n.position&&!0===n.updatePagePadding)},r=i.children(":jqmData(role='header')").filter(a),s=t.children(":jqmData(role='header')"),l=i.children(":jqmData(role='footer')").filter(a),c=t.children(":jqmData(role='footer')");return 0===s.length&&r.length>0&&(o=o.concat(r.toArray())),0===c.length&&l.length>0&&(o=o.concat(l.toArray())),e.each(o,function(t,i){n-=e(i).outerHeight()}),Math.max(0,n)}(n,"number"==typeof t?t:e.mobile.getScreenHeight()),n.css("min-height",""),n.height()<t&&n.css("min-height",t-(o-i))},loading:function(){var t=this.loading._widget||e(e.mobile.loader.prototype.defaultHtml).loader(),n=t.loader.apply(t,arguments);return this.loading._widget=t,n}}),e.addDependents=function(t,n){var i=e(t),o=i.jqmData("dependents")||e();i.jqmData("dependents",e(o).add(n))},e.fn.extend({removeWithDependents:function(){e.removeWithDependents(this)},enhanceWithin:function(){var t,n={},i=e.mobile.page.prototype.keepNativeSelector(),o=this;for(t in e.mobile.nojs&&e.mobile.nojs(this),e.mobile.links&&e.mobile.links(this),e.mobile.degradeInputsWithin&&e.mobile.degradeInputsWithin(this),e.fn.buttonMarkup&&this.find(e.fn.buttonMarkup.initSelector).not(i).jqmEnhanceable().buttonMarkup(),e.fn.fieldcontain&&this.find(":jqmData(role='fieldcontain')").not(i).jqmEnhanceable().fieldcontain(),e.each(e.mobile.widgets,function(t,a){if(a.initSelector){var r=e.mobile.enhanceable(o.find(a.initSelector));r.length>0&&(r=r.not(i)),r.length>0&&(n[a.prototype.widgetName]=r)}}),n)n[t][t]();return this},addDependents:function(t){e.addDependents(this,t)},getEncodedText:function(){return e("<a>").text(this.text()).html()},jqmEnhanceable:function(){return e.mobile.enhanceable(this)},jqmHijackable:function(){return e.mobile.hijackable(this)}}),e.removeWithDependents=function(t){var n=e(t);(n.jqmData("dependents")||e()).remove(),n.remove()},e.addDependents=function(t,n){var i=e(t),o=i.jqmData("dependents")||e();i.jqmData("dependents",e(o).add(n))},e.find.matches=function(t,n){return e.find(t,null,null,n)},e.find.matchesSelector=function(t,n){return e.find(n,null,null,[t]).length>0}}(e,this),function(e,i){t.matchMedia=t.matchMedia||function(e,t){var n,i=e.documentElement,o=i.firstElementChild||i.firstChild,a=e.createElement("body"),r=e.createElement("div");return r.id="mq-test-1",r.style.cssText="position:absolute;top:-100em",a.style.background="none",a.appendChild(r),function(e){return r.innerHTML='&shy;<style media="'+e+'"> #mq-test-1 { width: 42px; }</style>',i.insertBefore(a,o),n=42===r.offsetWidth,i.removeChild(a),{matches:n,media:e}}}(n),e.mobile.media=function(e){return t.matchMedia(e).matches}}(e),function(e,t){var i={touch:"ontouchend"in n};e.mobile.support=e.mobile.support||{},e.extend(e.support,i),e.extend(e.mobile.support,i)}(e),function(e,n){e.extend(e.support,{orientation:"orientation"in t&&"onorientationchange"in t})}(e),function(e,i){function o(e){var t,n=e.charAt(0).toUpperCase()+e.substr(1),o=(e+" "+l.join(n+" ")+n).split(" ");for(t in o)if(s[o[t]]!==i)return!0}var a,r=e("<body>").prependTo("html"),s=r[0].style,l=["Webkit","Moz","O"],c="palmGetResource"in t,u=t.operamini&&"[object OperaMini]"==={}.toString.call(t.operamini),d=t.blackberry&&!o("-webkit-transform");e.extend(e.mobile,{browser:{}}),e.mobile.browser.oldIE=function(){var e=3,t=n.createElement("div"),i=t.all||[];do{t.innerHTML="\x3c!--[if gt IE "+ ++e+"]><br><![endif]--\x3e"}while(i[0]);return e>4?e:!e}(),e.extend(e.support,{pushState:"pushState"in history&&"replaceState"in history&&!(t.navigator.userAgent.indexOf("Firefox")>=0&&t.top!==t)&&-1===t.navigator.userAgent.search(/CriOS/),mediaquery:e.mobile.media("only all"),cssPseudoElement:!!o("content"),touchOverflow:!!o("overflowScrolling"),cssTransform3d:function(){var o,a,s,c="transform-3d",u=e.mobile.media("(-"+l.join("-"+c+"),(-")+"-"+c+"),("+c+")");if(u)return!!u;for(s in o=n.createElement("div"),a={MozTransform:"-moz-transform",transform:"transform"},r.append(o),a)o.style[s]!==i&&(o.style[s]="translate3d( 100px, 1px, 1px )",u=t.getComputedStyle(o).getPropertyValue(a[s]));return!!u&&"none"!==u}(),boxShadow:!!o("boxShadow")&&!d,fixedPosition:function(){var e=t,n=navigator.userAgent,i=navigator.platform,o=n.match(/AppleWebKit\/([0-9]+)/),a=!!o&&o[1],r=n.match(/Fennec\/([0-9]+)/),s=!!r&&r[1],l=n.match(/Opera Mobi\/([0-9]+)/),c=!!l&&l[1];return!((i.indexOf("iPhone")>-1||i.indexOf("iPad")>-1||i.indexOf("iPod")>-1)&&a&&a<534||e.operamini&&"[object OperaMini]"==={}.toString.call(e.operamini)||l&&c<7458||n.indexOf("Android")>-1&&a&&a<533||s&&s<6||"palmGetResource"in t&&a&&a<534||n.indexOf("MeeGo")>-1&&n.indexOf("NokiaBrowser/8.5.0")>-1)}(),scrollTop:("pageXOffset"in t||"scrollTop"in n.documentElement||"scrollTop"in r[0])&&!c&&!u,dynamicBaseTag:function(){var t,n=location.protocol+"//"+location.host+location.pathname+"ui-dir/",i=e("head base"),o=null,a="";return i.length?a=i.attr("href"):i=o=e("<base>",{href:n}).appendTo("head"),t=e("<a href='testurl' />").prependTo(r)[0].href,i[0].href=a||location.pathname,o&&o.remove(),0===t.indexOf(n)}(),cssPointerEvents:function(){var e,i=n.createElement("x"),o=n.documentElement,a=t.getComputedStyle;return"pointerEvents"in i.style&&(i.style.pointerEvents="auto",i.style.pointerEvents="x",o.appendChild(i),e=a&&"auto"===a(i,"").pointerEvents,o.removeChild(i),!!e)}(),boundingRect:void 0!==n.createElement("div").getBoundingClientRect,inlineSVG:function(){var n=t,i=!(!n.document.createElementNS||!n.document.createElementNS("http://www.w3.org/2000/svg","svg").createSVGRect||n.opera&&-1===navigator.userAgent.indexOf("Chrome")),o=function(t){t&&i||e("html").addClass("ui-nosvg")},a=new n.Image;a.onerror=function(){o(!1)},a.onload=function(){o(1===a.width&&1===a.height)},a.src=""}}),r.remove(),a=function(){var e=t.navigator.userAgent;return e.indexOf("Nokia")>-1&&(e.indexOf("Symbian/3")>-1||e.indexOf("Series60/5")>-1)&&e.indexOf("AppleWebKit")>-1&&e.match(/(BrowserNG|NokiaBrowser)\/7\.[0-3]/)}(),e.mobile.gradeA=function(){return(e.support.mediaquery&&e.support.cssPseudoElement||e.mobile.browser.oldIE&&e.mobile.browser.oldIE>=8)&&(e.support.boundingRect||null!==e.fn.jquery.match(/1\.[0-7+]\.[0-9+]?/))},e.mobile.ajaxBlacklist=t.blackberry&&!t.WebKitPoint||u||a,a&&e(function(){e("head link[rel='stylesheet']").attr("rel","alternate stylesheet").attr("rel","stylesheet")}),e.support.boxShadow||e("html").addClass("ui-noboxshadow")}(e),function(e,t){var n,i=e.mobile.window,o=function(){};e.event.special.beforenavigate={setup:function(){i.on("navigate",o)},teardown:function(){i.off("navigate",o)}},e.event.special.navigate=n={bound:!1,pushStateEnabled:!0,originalEventName:void 0,isPushStateEnabled:function(){return e.support.pushState&&!0===e.mobile.pushStateEnabled&&this.isHashChangeEnabled()},isHashChangeEnabled:function(){return!0===e.mobile.hashListeningEnabled},popstate:function(t){var n=new e.Event("navigate"),o=new e.Event("beforenavigate"),a=t.originalEvent.state||{};o.originalEvent=t,i.trigger(o),o.isDefaultPrevented()||(t.historyState&&e.extend(a,t.historyState),n.originalEvent=t,setTimeout(function(){i.trigger(n,{state:a})},0))},hashchange:function(t){var n=new e.Event("navigate"),o=new e.Event("beforenavigate");o.originalEvent=t,i.trigger(o),o.isDefaultPrevented()||(n.originalEvent=t,i.trigger(n,{state:t.hashchangeState||{}}))},setup:function(){n.bound||(n.bound=!0,n.isPushStateEnabled()?(n.originalEventName="popstate",i.bind("popstate.navigate",n.popstate)):n.isHashChangeEnabled()&&(n.originalEventName="hashchange",i.bind("hashchange.navigate",n.hashchange)))}}}(e),function(e){e.event.special.throttledresize={setup:function(){e(this).bind("resize",o)},teardown:function(){e(this).unbind("resize",o)}};var t,n,i,o=function(){n=(new Date).getTime(),(i=n-a)>=250?(a=n,e(this).trigger("throttledresize")):(t&&clearTimeout(t),t=setTimeout(o,250-i))},a=0}(e),function(e,t){function i(){var e=o();e!==a&&(a=e,u.trigger(d))}var o,a,r,s,l,c,u=e(t),d="orientationchange",h={0:!0,180:!0};e.support.orientation&&(50,r=(l=t.innerWidth||u.width())>(c=t.innerHeight||u.height())&&l-c>50,s=h[t.orientation],(r&&s||!r&&!s)&&(h={"-90":!0,90:!0})),e.event.special.orientationchange=e.extend({},e.event.special.orientationchange,{setup:function(){if(e.support.orientation&&!e.event.special.orientationchange.disabled)return!1;a=o(),u.bind("throttledresize",i)},teardown:function(){if(e.support.orientation&&!e.event.special.orientationchange.disabled)return!1;u.unbind("throttledresize",i)},add:function(e){var t=e.handler;e.handler=function(e){return e.orientation=o(),t.apply(this,arguments)}}}),e.event.special.orientationchange.orientation=o=function(){var i=n.documentElement;return(e.support.orientation?h[t.orientation]:i&&i.clientWidth/i.clientHeight<1.1)?"portrait":"landscape"},e.fn[d]=function(e){return e?this.bind(d,e):this.trigger(d)}}(e,this),function(e,t,n,i){function o(e){for(;e&&void 0!==e.originalEvent;)e=e.originalEvent;return e}function a(t,n){var a,r,s,l,c,u,d,h,f,p=t.type;if((t=e.Event(t)).type=n,a=t.originalEvent,r=e.event.props,p.search(/^(mouse|click)/)>-1&&(r=A),a)for(d=r.length;d;)t[l=r[--d]]=a[l];if(p.search(/mouse(down|up)|click/)>-1&&!t.which&&(t.which=1),-1!==p.search(/^touch/)&&(p=(s=o(a)).touches,c=s.changedTouches,u=p&&p.length?p[0]:c&&c.length?c[0]:i))for(h=0,f=T.length;h<f;h++)t[l=T[h]]=u[l];return t}function r(t){for(var n,i,o={};t;){for(i in n=e.data(t,y))n[i]&&(o[i]=o.hasVirtualBinding=!0);t=t.parentNode}return o}function s(){M=!0}function l(){M=!1}function c(){u(),k=setTimeout(function(){k=0,L=0,q.length=0,O=!1,s()},e.vmouse.resetTimerDuration)}function u(){k&&(clearTimeout(k),k=0)}function d(t,n,i){var o;return(i&&i[t]||!i&&function(t,n){for(var i;t;){if((i=e.data(t,y))&&(!n||i[n]))return t;t=t.parentNode}return null}(n.target,t))&&(o=a(n,t),e(n.target).trigger(o)),o}function h(t){var n,i=e.data(t.target,x);O||L&&L===i||(n=d("v"+t.type,t))&&(n.isDefaultPrevented()&&t.preventDefault(),n.isPropagationStopped()&&t.stopPropagation(),n.isImmediatePropagationStopped()&&t.stopImmediatePropagation())}function f(t){var n,i,a,s=o(t).touches;s&&1===s.length&&((i=r(n=t.target)).hasVirtualBinding&&(L=H++,e.data(n,x,L),u(),l(),N=!1,a=o(t).touches[0],C=a.pageX,j=a.pageY,d("vmouseover",t,i),d("vmousedown",t,i)))}function p(e){M||(N||d("vmousecancel",e,r(e.target)),N=!0,c())}function m(t){if(!M){var n=o(t).touches[0],i=N,a=e.vmouse.moveDistanceThreshold,s=r(t.target);(N=N||Math.abs(n.pageX-C)>a||Math.abs(n.pageY-j)>a)&&!i&&d("vmousecancel",t,s),d("vmousemove",t,s),c()}}function v(e){if(!M){s();var t,n,i=r(e.target);d("vmouseup",e,i),N||(t=d("vclick",e,i))&&t.isDefaultPrevented()&&(n=o(e).changedTouches[0],q.push({touchID:L,x:n.clientX,y:n.clientY}),O=!0),d("vmouseout",e,i),N=!1,c()}}function g(t){var n,i=e.data(t,y);if(i)for(n in i)if(i[n])return!0;return!1}function b(){}var w,E,y="virtualMouseBindings",x="virtualTouchID",D="vmouseover vmousedown vmousemove vmouseup vclick vmouseout vmousecancel".split(" "),T="clientX clientY pageX pageY screenX screenY".split(" "),P=e.event.mouseHooks?e.event.mouseHooks.props:[],A=e.event.props.concat(P),S={},k=0,C=0,j=0,N=!1,q=[],O=!1,M=!1,I="addEventListener"in n,B=e(n),H=1,L=0;for(e.vmouse={moveDistanceThreshold:10,clickDistanceThreshold:10,resetTimerDuration:1500},E=0;E<D.length;E++)e.event.special[D[E]]=function(t){var n=t.substr(1);return{setup:function(){g(this)||e.data(this,y,{}),e.data(this,y)[t]=!0,S[t]=(S[t]||0)+1,1===S[t]&&B.bind(n,h),e(this).bind(n,b),I&&(S.touchstart=(S.touchstart||0)+1,1===S.touchstart&&B.bind("touchstart",f).bind("touchend",v).bind("touchmove",m).bind("scroll",p))},teardown:function(){--S[t],S[t]||B.unbind(n,h),I&&(--S.touchstart||B.unbind("touchstart",f).unbind("touchmove",m).unbind("touchend",v).unbind("scroll",p));var i=e(this),o=e.data(this,y);o&&(o[t]=!1),i.unbind(n,b),g(this)||i.removeData(y)}}}(D[E]);I&&n.addEventListener("click",function(t){var n,i,o,a,r,s=q.length,l=t.target;if(s)for(n=t.clientX,i=t.clientY,w=e.vmouse.clickDistanceThreshold,o=l;o;){for(a=0;a<s;a++)if(r=q[a],o===l&&Math.abs(r.x-n)<w&&Math.abs(r.y-i)<w||e.data(o,x)===r.touchID)return t.preventDefault(),void t.stopPropagation();o=o.parentNode}},!0)}(e,0,n),function(e,t,i){function o(t,n,o,a){var r=o.type;o.type=n,a?e.event.trigger(o,i,t):e.event.dispatch.call(t,o),o.type=r}var a=e(n),r=e.mobile.support.touch,s=r?"touchstart":"mousedown",l=r?"touchend":"mouseup",c=r?"touchmove":"mousemove";e.each("touchstart touchmove touchend tap taphold swipe swipeleft swiperight scrollstart scrollstop".split(" "),function(t,n){e.fn[n]=function(e){return e?this.bind(n,e):this.trigger(n)}}),e.event.special.scrollstart={enabled:!0,setup:function(){function t(e,t){o(a,(n=t)?"scrollstart":"scrollstop",e)}var n,i,a=this;e(a).bind("touchmove scroll",function(o){e.event.special.scrollstart.enabled&&(n||t(o,!0),clearTimeout(i),i=setTimeout(function(){t(o,!1)},50))})},teardown:function(){e(this).unbind("touchmove scroll")}},e.event.special.tap={tapholdThreshold:750,emitTapOnTaphold:!0,setup:function(){var t=this,n=e(t),i=!1;n.bind("vmousedown",function(r){function s(){clearTimeout(u)}function l(){s(),n.unbind("vclick",c).unbind("vmouseup",s),a.unbind("vmousecancel",l)}function c(e){l(),i||d!==e.target?i&&e.preventDefault():o(t,"tap",e)}if(i=!1,r.which&&1!==r.which)return!1;var u,d=r.target;n.bind("vmouseup",s).bind("vclick",c),a.bind("vmousecancel",l),u=setTimeout(function(){e.event.special.tap.emitTapOnTaphold||(i=!0),o(t,"taphold",e.Event("taphold",{target:d}))},e.event.special.tap.tapholdThreshold)})},teardown:function(){e(this).unbind("vmousedown").unbind("vclick").unbind("vmouseup"),a.unbind("vmousecancel")}},e.event.special.swipe={scrollSupressionThreshold:30,durationThreshold:1e3,horizontalDistanceThreshold:30,verticalDistanceThreshold:30,getLocation:function(e){var n=t.pageXOffset,i=t.pageYOffset,o=e.clientX,a=e.clientY;return 0===e.pageY&&Math.floor(a)>Math.floor(e.pageY)||0===e.pageX&&Math.floor(o)>Math.floor(e.pageX)?(o-=n,a-=i):(a<e.pageY-i||o<e.pageX-n)&&(o=e.pageX-n,a=e.pageY-i),{x:o,y:a}},start:function(t){var n=t.originalEvent.touches?t.originalEvent.touches[0]:t,i=e.event.special.swipe.getLocation(n);return{time:(new Date).getTime(),coords:[i.x,i.y],origin:e(t.target)}},stop:function(t){var n=t.originalEvent.touches?t.originalEvent.touches[0]:t,i=e.event.special.swipe.getLocation(n);return{time:(new Date).getTime(),coords:[i.x,i.y]}},handleSwipe:function(t,n,i,a){if(n.time-t.time<e.event.special.swipe.durationThreshold&&Math.abs(t.coords[0]-n.coords[0])>e.event.special.swipe.horizontalDistanceThreshold&&Math.abs(t.coords[1]-n.coords[1])<e.event.special.swipe.verticalDistanceThreshold){var r=t.coords[0]>n.coords[0]?"swipeleft":"swiperight";return o(i,"swipe",e.Event("swipe",{target:a,swipestart:t,swipestop:n}),!0),o(i,r,e.Event(r,{target:a,swipestart:t,swipestop:n}),!0),!0}return!1},eventInProgress:!1,setup:function(){var t,n=this,i=e(n),o={};(t=e.data(this,"mobile-events"))||(t={length:0},e.data(this,"mobile-events",t)),t.length++,t.swipe=o,o.start=function(t){if(!e.event.special.swipe.eventInProgress){e.event.special.swipe.eventInProgress=!0;var i,r=e.event.special.swipe.start(t),s=t.target,u=!1;o.move=function(t){r&&!t.isDefaultPrevented()&&(i=e.event.special.swipe.stop(t),u||(u=e.event.special.swipe.handleSwipe(r,i,n,s))&&(e.event.special.swipe.eventInProgress=!1),Math.abs(r.coords[0]-i.coords[0])>e.event.special.swipe.scrollSupressionThreshold&&t.preventDefault())},o.stop=function(){u=!0,e.event.special.swipe.eventInProgress=!1,a.off(c,o.move),o.move=null},a.on(c,o.move).one(l,o.stop)}},i.on(s,o.start)},teardown:function(){var t,n;(t=e.data(this,"mobile-events"))&&(n=t.swipe,delete t.swipe,0==--t.length&&e.removeData(this,"mobile-events")),n&&(n.start&&e(this).off(s,n.start),n.move&&a.off(c,n.move),n.stop&&a.off(l,n.stop))}},e.each({scrollstop:"scrollstart",taphold:"tap",swipeleft:"swipe.left",swiperight:"swipe.right"},function(t,n){e.event.special[t]={setup:function(){e(this).bind(n,e.noop)},teardown:function(){e(this).unbind(n)}}})}(e,this)});
js/jquery.sumoselect.js ADDED
@@ -0,0 +1,913 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ /*global jQuery, define, module, require*/
2
+ /*!
3
+ * jquery.sumoselect v3.3.24
4
+ * http://hemantnegi.github.io/jquery.sumoselect
5
+ * 2016-12-12
6
+ *
7
+ * Copyright 2015 Hemant Negi
8
+ * Email : hemant.frnz@gmail.com
9
+ * Compressor http://refresh-sf.com/
10
+ */
11
+
12
+ (function (factory) {
13
+ 'use strict';
14
+ if (typeof define === 'function' && define.amd) {
15
+ define(['jquery'], factory);
16
+ } else if (typeof exports !== 'undefined') {
17
+ module.exports = factory(require('jquery'));
18
+ } else {
19
+ factory(jQuery);
20
+ }
21
+
22
+ })(($) => {
23
+
24
+ 'namespace sumo';
25
+ $.fn.SumoSelect = function (options) {
26
+
27
+ // This is the easiest way to have default options.
28
+ const defaultOptions = {
29
+ placeholder: 'Select Here', // Dont change it here.
30
+ csvDispCount: 3, // display no. of items in multiselect. 0 to display all.
31
+ captionFormat: '{0} Selected', // format of caption text. you can set your locale.
32
+ captionFormatAllSelected: '{0} all selected!', // format of caption text when all elements are selected. set null to use captionFormat. It will not work if there are disabled elements in select.
33
+ floatWidth: 400, // Screen width of device at which the list is rendered in floating popup fashion.
34
+ forceCustomRendering: false, // force the custom modal on all devices below floatWidth resolution.
35
+ nativeOnDevice: ['Android', 'BlackBerry', 'iPhone', 'iPad', 'iPod', 'Opera Mini', 'IEMobile', 'Silk'], //
36
+ outputAsCSV: false, // true to POST data as csv ( false for Html control array ie. default select )
37
+ csvSepChar: ',', // separation char in csv mode
38
+ okCancelInMulti: false, // display ok cancel buttons in desktop mode multiselect also.
39
+ isClickAwayOk: false, // for okCancelInMulti=true. sets whether click outside will trigger Ok or Cancel (default is cancel).
40
+ triggerChangeCombined: true, // im multi select mode whether to trigger change event on individual selection or combined selection.
41
+ selectAll: false, // to display select all button in multiselect mode.|| also select all will not be available on mobile devices.
42
+
43
+ search: false, // to display input for filtering content. selectAlltext will be input text placeholder
44
+ searchText: 'Search...', // placeholder for search input
45
+ searchFn (haystack, needle) { // search function
46
+ return haystack.toLowerCase().indexOf(needle.toLowerCase()) < 0;
47
+ },
48
+ noMatch: 'No matches for "{0}"',
49
+ prefix: '', // some prefix usually the field name. eg. '<b>Hello</b>'
50
+ locale: ['OK', 'Cancel', 'Select All'], // all text that is used. don't change the index.
51
+ up: false, // set true to open upside.
52
+ showTitle: true, // set to false to prevent title (tooltip) from appearing
53
+ max: null, // Maximum number of options selected (when multiple)
54
+ // eslint-disable-next-line no-unused-vars
55
+ renderLi: (li, _originalOption) => li // Custom <li> item renderer
56
+ };
57
+
58
+ const ret = this.each(function () {
59
+ const selObj = this; // the original select object.
60
+ if (this.sumo || !$(this).is('select')) return; //already initialized
61
+
62
+ const settings = $.extend({}, defaultOptions, options, $(this).data());
63
+
64
+ this.sumo = {
65
+ E: $(selObj), //the jquery object of original select element.
66
+ is_multi: $(selObj).attr('multiple'), //if its a multiple select
67
+ select: '',
68
+ caption: '',
69
+ placeholder: '',
70
+ optDiv: '',
71
+ CaptionCont: '',
72
+ ul: '',
73
+ is_floating: false,
74
+ is_opened: false,
75
+ //backdrop: '',
76
+ mob: false, // if to open device default select
77
+ Pstate: [],
78
+ lastUnselected: null,
79
+ selectedCount: 0,
80
+
81
+ createElems () {
82
+ const O = this;
83
+ const {0: {selectedOptions}} = O.E;
84
+ O.E.wrap('<div class="SumoSelect" tabindex="0" role="button" aria-expanded="false">');
85
+ [...selectedOptions].forEach((selectedOption) => { // Fix for IE resetting index to 0 when -1
86
+ selectedOption.selected = true;
87
+ });
88
+ O.select = O.E.parent();
89
+ O.caption = $('<span>');
90
+ O.CaptionCont = $(`<p class="CaptionCont SelectBox ${O.E.attr('class')}" ><label><i></i></label></p>`)
91
+ .attr('style', O.E.attr('style'))
92
+ .prepend(O.caption);
93
+ O.select.append(O.CaptionCont);
94
+
95
+ // default turn off if no multiselect
96
+ if (!O.is_multi) settings.okCancelInMulti = false;
97
+
98
+ if (O.E.attr('disabled'))
99
+ O.select.addClass('disabled').removeAttr('tabindex');
100
+
101
+ //if output as csv and is a multiselect.
102
+ if (settings.outputAsCSV && O.is_multi && O.E.attr('name')) {
103
+ //create a hidden field to store csv value.
104
+ O.select.append($('<input class="HEMANT123" type="hidden" />').attr('name', O.E.attr('name')).val(O.getSelStr()));
105
+
106
+ // so it can not post the original select.
107
+ O.E.removeAttr('name');
108
+ }
109
+
110
+ //break for mobile rendring.. if forceCustomRendering is false
111
+ if (O.isMobile() && !settings.forceCustomRendering) {
112
+ O.setNativeMobile();
113
+ return;
114
+ }
115
+
116
+ // if there is a name attr in select add a class to container div
117
+ if (O.E.attr('name')) O.select.addClass(`sumo_${O.E.attr('name').replace(/\[\]/, '')}`);
118
+
119
+ //hide original select
120
+ O.E.addClass('SumoUnder').attr('tabindex', '-1');
121
+
122
+ //## Creating the list...
123
+ O.optDiv = $(`<div class="optWrapper ${settings.up ? 'up' : ''}">`);
124
+
125
+ //branch for floating list in low res devices.
126
+ O.floatingList();
127
+
128
+ //Creating the markup for the available options
129
+ O.ul = $('<ul class="options">');
130
+ O.optDiv.append(O.ul);
131
+
132
+ // Select all functionality
133
+ if (settings.selectAll && O.is_multi && !settings.max) O.SelAll();
134
+
135
+ // search functionality
136
+ if (settings.search) O.Search();
137
+
138
+ O.ul.append(O.prepItems(O.E.children()));
139
+
140
+ //if multiple then add the class multiple and add OK / CANCEL button
141
+ if (O.is_multi) O.multiSelelect();
142
+
143
+ O.select.append(O.optDiv);
144
+ O._handleMax();
145
+ O.basicEvents();
146
+ O.selAllState();
147
+ },
148
+
149
+ prepItems (opts, d) {
150
+ const lis = [], O = this;
151
+ $(opts).each((i, opt) => { // parsing options to li
152
+ const $opt = $(opt);
153
+ lis.push($opt.is('optgroup') ?
154
+ $(`<li class="group ${opt.disabled ? 'disabled' : ''}"><label></label><ul></ul></li>`)
155
+ .find('label')
156
+ .text($opt.attr('label'))
157
+ .end()
158
+ .find('ul')
159
+ .append(O.prepItems($opt.children(), opt.disabled))
160
+ .end()
161
+ :
162
+ O.createLi($opt, d)
163
+ );
164
+ });
165
+ return lis;
166
+ },
167
+
168
+ //## Creates a LI element from a given option and binds events to it
169
+ //## returns the jquery instance of li (not inserted in dom)
170
+ createLi (opt, d) {
171
+ const O = this;
172
+
173
+ if (!opt.attr('value')) opt.attr('value', opt.val());
174
+ const li = $(`<li class="opt"><label>${opt.html()}</label></li>`);
175
+
176
+ li.data('opt', opt); // store a direct reference to option.
177
+ opt.data('li', li); // store a direct reference to list item.
178
+ if (O.is_multi) li.prepend('<span><i></i></span>');
179
+
180
+ if (opt[0].disabled || d)
181
+ li.addClass('disabled');
182
+
183
+ O.onOptClick(li);
184
+
185
+ if (opt[0].selected) {
186
+ li.addClass('selected');
187
+ O.selectedCount++;
188
+ }
189
+
190
+ if (opt.attr('class'))
191
+ li.addClass(opt.attr('class'));
192
+
193
+ if (opt.attr('title'))
194
+ li.attr('title', opt.attr('title'));
195
+
196
+ return settings.renderLi(li, opt);
197
+ },
198
+
199
+ //## Returns the selected items as string in a Multiselect.
200
+ getSelStr () {
201
+ // get the pre selected items.
202
+ const sopt = [];
203
+ this.E.find('option:checked').each(function () { sopt.push($(this).val()); });
204
+ return sopt.join(settings.csvSepChar);
205
+ },
206
+
207
+ //## THOSE OK/CANCEL BUTTONS ON MULTIPLE SELECT.
208
+ multiSelelect () {
209
+ const O = this;
210
+ O.optDiv.addClass('multiple');
211
+ O.okbtn = $('<p tabindex="0" class="btnOk"></p>').click(() => {
212
+ //if combined change event is set.
213
+ O._okbtn();
214
+ O.hideOpts();
215
+ });
216
+ [O.okbtn[0].innerText] = settings.locale;
217
+
218
+ O.cancelBtn = $('<p tabindex="0" class="btnCancel"></p>').click(() => {
219
+ O._cnbtn();
220
+ O.hideOpts();
221
+ });
222
+ [, O.cancelBtn[0].innerText] = settings.locale;
223
+
224
+ const btns = O.okbtn.add(O.cancelBtn);
225
+ O.optDiv.append($('<div class="MultiControls">').append(btns));
226
+
227
+ // handling keyboard navigation on ok cancel buttons.
228
+ btns.on('keydown.sumo', function (e) {
229
+ const el = $(this);
230
+ switch (e.which) {
231
+ case 32: // space
232
+ case 13: // enter
233
+ el.trigger('click');
234
+ break;
235
+
236
+ case 9: //tab
237
+ if (el.hasClass('btnOk')) return;
238
+ break;
239
+ case 27: // esc
240
+ O._cnbtn();
241
+ O.hideOpts();
242
+ return;
243
+ default:
244
+ break;
245
+ }
246
+ e.stopPropagation();
247
+ e.preventDefault();
248
+ });
249
+ },
250
+
251
+ _okbtn () {
252
+ const O = this;
253
+ let cg = 0;
254
+ //if combined change event is set.
255
+ if (settings.triggerChangeCombined) {
256
+ //check for a change in the selection.
257
+ if (O.E.find('option:checked').length !== O.Pstate.length) {
258
+ cg = 1;
259
+ }
260
+ else {
261
+ O.E.find('option').each((i, e) => {
262
+ if (e.selected && O.Pstate.indexOf(i) < 0) cg = 1;
263
+ });
264
+ }
265
+
266
+ if (cg) {
267
+ O.callChange();
268
+ O.setText();
269
+ }
270
+ }
271
+ },
272
+ _cnbtn () {
273
+ const O = this;
274
+ //remove all selections
275
+ O.E.find('option:checked').each(function () { this.selected = false; });
276
+ O.optDiv.find('li.selected').removeClass('selected');
277
+
278
+ //restore selections from saved state.
279
+ for (let i = 0; i < O.Pstate.length; i++) {
280
+ O.E.find('option')[O.Pstate[i]].selected = true;
281
+ O.ul.find('li.opt').eq(O.Pstate[i]).addClass('selected');
282
+ }
283
+ O.selAllState();
284
+ },
285
+
286
+ _handleMax () {
287
+ // Disable options if max reached
288
+ if (settings.max) {
289
+ if (this.selectedCount >= +settings.max) {
290
+ this.optDiv.find('li.opt').not('.hidden').each((ix, e) => {
291
+ if (!$(e).hasClass('selected')) {
292
+ $(e).addClass('temporary-disabled disabled');
293
+ }
294
+ });
295
+ } else {
296
+ // Enable options back
297
+ this.optDiv.find('li.opt').not('.hidden').each((ix, e) => {
298
+ if ($(e).hasClass('temporary-disabled')) {
299
+ $(e).removeClass('temporary-disabled disabled');
300
+ }
301
+ });
302
+ }
303
+ }
304
+ },
305
+
306
+ SelAll () {
307
+ const O = this;
308
+ if (!O.is_multi) return;
309
+ O.selAll = $('<p class="select-all"><span><i></i></span><label></label></p>');
310
+ [, , O.selAll.find('label')[0].innerText] = settings.locale;
311
+ O.optDiv.addClass('selall');
312
+ O.selAll.on('click', () => {
313
+ O.selAll.toggleClass('selected');
314
+ O.toggSelAll(O.selAll.hasClass('selected'), 1);
315
+ //O.selAllState();
316
+ });
317
+
318
+ O.optDiv.prepend(O.selAll);
319
+ },
320
+
321
+ // search module (can be removed if not required.)
322
+ Search () {
323
+ const O = this,
324
+ cc = O.CaptionCont.addClass('search'),
325
+ P = $('<p class="no-match">'),
326
+ fn = (options.searchFn && typeof options.searchFn === 'function') ? options.searchFn : settings.searchFn;
327
+
328
+ O.ftxt = $('<input type="text" class="search-txt" value="" autocomplete="off">')
329
+ .on('click', (e) => {
330
+ e.stopPropagation();
331
+ });
332
+ O.ftxt.placeholder = settings.searchText;
333
+ cc.append(O.ftxt);
334
+ O.optDiv.children('ul').after(P);
335
+
336
+ O.ftxt.on('keyup.sumo', () => {
337
+ const hid = O.optDiv.find('ul.options li.opt').each((ix, e) => {
338
+ const el = $(e),
339
+ {0: opt} = el.data('opt');
340
+ opt.hidden = fn(el.text(), O.ftxt.val());
341
+ el.toggleClass('hidden', opt.hidden);
342
+ }).not('.hidden');
343
+
344
+ // Hide opt-groups with no options matched
345
+ O.optDiv[0].querySelectorAll('li.group').forEach(optGroup => {
346
+ if (optGroup.querySelector('li:not(.hidden)')) {
347
+ optGroup.classList.remove('hidden');
348
+ } else {
349
+ optGroup.classList.add('hidden');
350
+ }
351
+ });
352
+
353
+ P.html(settings.noMatch.replace(/\{0\}/g, '<em></em>')).toggle(!hid.length);
354
+ P.find('em').text(O.ftxt.val());
355
+ O.selAllState();
356
+ });
357
+ },
358
+
359
+ selAllState () {
360
+ const O = this;
361
+ if (settings.selectAll && O.is_multi) {
362
+ let sc = 0, vc = 0;
363
+ O.optDiv.find('li.opt').not('.hidden .disabled').each((ix, e) => {
364
+ if ($(e).hasClass('selected')) sc++;
365
+ vc++;
366
+ });
367
+ //select all checkbox state change.
368
+ if (sc === vc) O.selAll.removeClass('partial').addClass('selected');
369
+ else if (sc === 0) O.selAll.removeClass('selected partial');
370
+ else O.selAll.addClass('partial');//.removeClass('selected');
371
+ }
372
+ },
373
+
374
+ showOpts () {
375
+ const O = this;
376
+ if (O.E.attr('disabled')) return; // if select is disabled then retrun
377
+ O.E.trigger('sumo:opening', O);
378
+ O.is_opened = true;
379
+ O.select.addClass('open').attr('aria-expanded', 'true');
380
+ O.E.trigger('sumo:opened', O);
381
+
382
+ if (O.ftxt) O.ftxt.focus();
383
+ else O.select.focus();
384
+
385
+ // hide options on click outside.
386
+ $(document).on('click.sumo', (e) => {
387
+ if (!O.select.is(e.target) // if the target of the click isn't the container...
388
+ && O.select.has(e.target).length === 0) { // ... nor a descendant of the container
389
+ if (!O.is_opened) return;
390
+ O.hideOpts();
391
+ if (settings.okCancelInMulti) {
392
+ if (settings.isClickAwayOk)
393
+ O._okbtn();
394
+ else
395
+ O._cnbtn();
396
+ }
397
+ }
398
+ });
399
+
400
+ if (O.is_floating) {
401
+ let H = O.optDiv.children('ul').outerHeight() + 2; // +2 is clear fix
402
+ if (O.is_multi) H = H + +O.optDiv.css('padding-bottom');
403
+ O.optDiv.css('height', H);
404
+ $('body').addClass('sumoStopScroll');
405
+ }
406
+
407
+ O.setPstate();
408
+ },
409
+
410
+ //maintain state when ok/cancel buttons are available storing the indexes.
411
+ setPstate () {
412
+ const O = this;
413
+ if (O.is_multi && (O.is_floating || settings.okCancelInMulti)) {
414
+ O.Pstate = [];
415
+ // assuming that find returns elements in tree order
416
+ O.E.find('option').each((i, e) => { if (e.selected) O.Pstate.push(i); });
417
+ }
418
+ },
419
+
420
+ callChange () {
421
+ this.E.get().forEach(e => {
422
+ e.dispatchEvent(new Event('change'));
423
+ e.dispatchEvent(new Event('click'));
424
+ });
425
+ },
426
+
427
+ hideOpts () {
428
+ const O = this;
429
+ if (O.is_opened) {
430
+ O.E.trigger('sumo:closing', O);
431
+ O.is_opened = false;
432
+ O.select.removeClass('open').attr('aria-expanded', 'false').find('ul li.sel').removeClass('sel');
433
+ O.E.trigger('sumo:closed', O);
434
+ $(document).off('click.sumo');
435
+ $('body').removeClass('sumoStopScroll');
436
+
437
+ // clear the search
438
+ if (settings.search) {
439
+ O.ftxt.val('');
440
+ O.ftxt.trigger('keyup.sumo');
441
+ }
442
+ }
443
+ },
444
+ setOnOpen () {
445
+ const O = this;
446
+ let li = O.optDiv.find('li.opt:not(.hidden)').eq(settings.search ? 0 : O.E[0].selectedIndex);
447
+ if (li.hasClass('disabled')) {
448
+ li = li.next(':not(disabled)');
449
+ if (!li.length) return;
450
+ }
451
+ O.optDiv.find('li.sel').removeClass('sel');
452
+ li.addClass('sel');
453
+ O.showOpts();
454
+ },
455
+ nav (up) {
456
+ const O = this;
457
+ let c = null, sel = O.ul.find('li.opt.sel:not(.hidden)');
458
+ const
459
+ s = O.ul.find('li.opt:not(.disabled):not(.hidden)'),
460
+ idx = s.index(sel);
461
+ if (O.is_opened && sel.length) {
462
+ if (up && idx > 0)
463
+ c = s.eq(idx - 1);
464
+ else if (!up && idx < s.length - 1 && idx > -1)
465
+ c = s.eq(idx + 1);
466
+ else return; // if no items before or after
467
+
468
+ sel.removeClass('sel');
469
+ sel = c.addClass('sel');
470
+
471
+ // setting sel item to visible view.
472
+ const { ul } = O,
473
+ st = ul.scrollTop(),
474
+ t = sel.position().top + st;
475
+ if (t >= st + ul.height() - sel.outerHeight())
476
+ ul.scrollTop(t - ul.height() + sel.outerHeight());
477
+ if (t < st)
478
+ ul.scrollTop(t);
479
+
480
+ }
481
+ else
482
+ O.setOnOpen();
483
+ },
484
+
485
+ basicEvents () {
486
+ const O = this;
487
+ O.CaptionCont.click((evt) => {
488
+ O.E.trigger('click');
489
+ if (O.is_opened) O.hideOpts(); else O.showOpts();
490
+ evt.stopPropagation();
491
+ });
492
+
493
+ O.select.on('keydown.sumo', (e) => {
494
+ switch (e.which) {
495
+ case 38: // up
496
+ O.nav(true);
497
+ break;
498
+
499
+ case 40: // down
500
+ O.nav(false);
501
+ break;
502
+
503
+ case 65: // shortcut ctrl + a to select all and ctrl + shift + a to unselect all.
504
+ if (O.is_multi && !settings.max && e.ctrlKey) {
505
+ O.toggSelAll(!e.shiftKey, 1);
506
+ break;
507
+ }
508
+ else
509
+ return;
510
+
511
+ case 32: // space
512
+ if (settings.search && O.ftxt.is(e.target)) return;
513
+ break;
514
+ case 13: // enter
515
+ if (O.is_opened)
516
+ O.optDiv.find('ul li.sel').trigger('click');
517
+ else
518
+ O.setOnOpen();
519
+ break;
520
+ case 9: //tab
521
+ if (!settings.okCancelInMulti)
522
+ O.hideOpts();
523
+ return;
524
+ case 27: // esc
525
+ if (settings.okCancelInMulti) O._cnbtn();
526
+ O.hideOpts();
527
+ return;
528
+
529
+ default:
530
+ return; // exit this handler for other keys
531
+ }
532
+ e.preventDefault(); // prevent the default action (scroll / move caret)
533
+ });
534
+
535
+ $(window).on('resize.sumo', () => {
536
+ O.floatingList();
537
+ });
538
+ },
539
+
540
+ onOptClick (li) {
541
+ const O = this;
542
+ li.click(function () {
543
+ const $li = $(this);
544
+ if ($li.hasClass('disabled')) return;
545
+ if (O.is_multi) {
546
+ $li.toggleClass('selected');
547
+ $li.data('opt')[0].selected = $li.hasClass('selected');
548
+ if ($li.data('opt')[0].selected === false) {
549
+ O.lastUnselected = $li.data('opt')[0].textContent;
550
+ O.selectedCount--;
551
+ } else {
552
+ O.selectedCount++;
553
+ }
554
+
555
+ if (settings.max) {
556
+ O._handleMax();
557
+ }
558
+
559
+ O.selAllState();
560
+ }
561
+ else {
562
+ $li.parent().find('li.selected').removeClass('selected'); //if not multiselect then remove all selections from this list
563
+ $li.toggleClass('selected');
564
+ $li.data('opt')[0].selected = true;
565
+ O.selectedCount = 1;
566
+ }
567
+
568
+ //branch for combined change event.
569
+ if (!(O.is_multi && settings.triggerChangeCombined && (O.is_floating || settings.okCancelInMulti))) {
570
+ O.setText();
571
+ O.callChange();
572
+ }
573
+
574
+ if (!O.is_multi) O.hideOpts(); //if its not a multiselect then hide on single select.
575
+ });
576
+ },
577
+
578
+ // fixed some variables that were not explicitly typed (michc)
579
+ setText () {
580
+ const O = this;
581
+ O.placeholder = "";
582
+ if (O.is_multi) {
583
+ const sels = O.E.find(':checked').not(':disabled'); //selected options.
584
+
585
+ if (settings.csvDispCount && sels.length > settings.csvDispCount) {
586
+ if (sels.length === O.E.find('option').length && settings.captionFormatAllSelected) {
587
+ O.placeholder = settings.captionFormatAllSelected.replace(/\{0\}/g, sels.length);
588
+ }
589
+ else {
590
+ O.placeholder = settings.captionFormat.replace(/\{0\}/g, sels.length);
591
+ }
592
+ }
593
+ else {
594
+ O.placeholder = sels.toArray().map(selected => selected.innerText).join(', ');
595
+ }
596
+ }
597
+ else {
598
+ O.placeholder = O.E.find(':checked').not(':disabled').text();
599
+ }
600
+
601
+ let is_placeholder = false;
602
+
603
+ if (!O.placeholder) {
604
+
605
+ is_placeholder = true;
606
+
607
+ O.placeholder = O.E.attr('placeholder');
608
+ if (!O.placeholder) //if placeholder is there then set it
609
+ O.placeholder = O.E.find('option:disabled:checked').text();
610
+ }
611
+
612
+ O.placeholder = O.placeholder ? (`${settings.prefix} ${O.placeholder}`) : settings.placeholder;
613
+
614
+ //set display text
615
+ O.caption.text(O.placeholder);
616
+ if (settings.showTitle) O.CaptionCont.attr('title', O.placeholder);
617
+
618
+ //set the hidden field if post as csv is true.
619
+ const csvField = O.select.find('input.HEMANT123');
620
+ if (csvField.length) csvField.val(O.getSelStr());
621
+
622
+ //add class placeholder if its a placeholder text.
623
+ if (is_placeholder) O.caption.addClass('placeholder'); else O.caption.removeClass('placeholder');
624
+ return O.placeholder;
625
+ },
626
+
627
+ isMobile () {
628
+
629
+ // Adapted from http://www.detectmobilebrowsers.com
630
+ const ua = navigator.userAgent || navigator.vendor || window.opera;
631
+
632
+ // Checks for iOs, Android, Blackberry, Opera Mini, and Windows mobile devices
633
+ for (let i = 0; i < settings.nativeOnDevice.length; i++) if (ua.toString().toLowerCase().indexOf(settings.nativeOnDevice[i].toLowerCase()) > 0) return settings.nativeOnDevice[i];
634
+ return false;
635
+ },
636
+
637
+ setNativeMobile () {
638
+ const O = this;
639
+ O.E.addClass('SelectClass');//.css('height', O.select.outerHeight());
640
+ O.mob = true;
641
+ O.E.change(() => {
642
+ O.setText();
643
+ });
644
+ },
645
+
646
+ floatingList () {
647
+ const O = this;
648
+ //called on init and also on resize.
649
+ //O.is_floating = true if window width is < specified float width
650
+ O.is_floating = $(window).width() <= settings.floatWidth;
651
+
652
+ //set class isFloating
653
+ O.optDiv.toggleClass('isFloating', O.is_floating);
654
+
655
+ //remove height if not floating
656
+ if (!O.is_floating) O.optDiv.css('height', '');
657
+
658
+ //toggle class according to okCancelInMulti flag only when it is not floating
659
+ O.optDiv.toggleClass('okCancelInMulti', settings.okCancelInMulti && !O.is_floating);
660
+ },
661
+
662
+ //HELPERS FOR OUTSIDERS
663
+ // validates range of given item operations
664
+ vRange (i) {
665
+ const O = this;
666
+ const opts = O.E.find('option');
667
+ if (opts.length <= i || i < 0) throw new Error("index out of bounds");
668
+ return O;
669
+ },
670
+
671
+ //toggles selection on c as boolean.
672
+ toggSel (c, i) {
673
+ const O = this;
674
+ let opt = null;
675
+ if (typeof (i) === "number") {
676
+ O.vRange(i);
677
+ opt = O.E.find('option')[i];
678
+ }
679
+ else {
680
+ opt = O.E.find(`option[value="${i}"]`)[0] || 0;
681
+ }
682
+ if (!opt || opt.disabled)
683
+ return;
684
+
685
+ if (opt.selected !== c) {
686
+ if ((settings.max && !opt.selected && O.selectedCount < settings.max) || opt.selected || (!settings.max && !opt.selected)) {
687
+ opt.selected = c;
688
+ if (!O.mob) $(opt).data('li').toggleClass('selected', c);
689
+
690
+ O.callChange();
691
+ O.setPstate();
692
+ O.setText();
693
+ O.selAllState();
694
+ }
695
+ }
696
+ },
697
+
698
+ //toggles disabled on c as boolean.
699
+ toggDis (c, i) {
700
+ const O = this.vRange(i);
701
+ O.E.find('option')[i].disabled = c;
702
+ if (c) O.E.find('option')[i].selected = false;
703
+ if (!O.mob) O.optDiv.find('ul.options li.opt').eq(i).toggleClass('disabled', c).removeClass('selected');
704
+ O.setText();
705
+ },
706
+
707
+ // toggle disable/enable on complete select control
708
+ toggSumo (val) {
709
+ const O = this;
710
+ O.enabled = val;
711
+ O.select.toggleClass('disabled', val);
712
+
713
+ if (val) {
714
+ O.E.attr('disabled', 'disabled');
715
+ O.select.removeAttr('tabindex');
716
+ }
717
+ else {
718
+ O.E.removeAttr('disabled');
719
+ O.select.attr('tabindex', '0');
720
+ }
721
+
722
+ return O;
723
+ },
724
+
725
+ // toggles all option on c as boolean.
726
+ // set direct=false/0 bypasses okCancelInMulti behaviour.
727
+ toggSelAll (c, direct) {
728
+ const O = this;
729
+ const cloneOriginalEvents = $.extend(true, {}, $._data(O.E.get(0), "events")); // clone original select elements events
730
+ O.E.off(); // unbind original select elements events because we do not want the following clicks to trigger change on it
731
+
732
+ if (O.is_multi) {
733
+ // Select all
734
+ if (c) {
735
+ O.E.find('option:not(:checked):not(:disabled):not(:hidden)').toArray().forEach(option => {
736
+ if (!$(option).data('li').hasClass('hidden')) {
737
+ option.selected = true;
738
+ $(option).data('li').toggleClass('selected', true);
739
+ }
740
+ });
741
+ } else {
742
+ // Unselect all
743
+ O.E.find('option:checked:not(:disabled):not(:hidden)').toArray().forEach(option => {
744
+ if (!$(option).data('li').hasClass('hidden')) {
745
+ option.selected = false;
746
+ $(option).data('li').toggleClass('selected', false);
747
+ }
748
+ });
749
+ }
750
+ } else {
751
+ if (!c) O.E[0].selectedIndex = -1;
752
+ else console.warn('You called `SelectAll` on a non-multiple select');
753
+ }
754
+
755
+ // rebind original select elements events
756
+ $.each(cloneOriginalEvents, (_, e) => {
757
+ $.each(e, (__, ev) => {
758
+ O.E.on(ev.type, ev.handler);
759
+ });
760
+ });
761
+
762
+ O.callChange(); // call change on original select element
763
+
764
+ if (!direct) {
765
+ if (!O.mob && O.selAll) O.selAll.removeClass('partial').toggleClass('selected', !!c);
766
+ O.setText();
767
+ O.setPstate();
768
+ }
769
+ },
770
+
771
+ /* outside accessibility options
772
+ which can be accessed from the element instance.
773
+ */
774
+ reload () {
775
+ const elm = this.unload();
776
+ return $(elm).SumoSelect(settings);
777
+ },
778
+
779
+ unload () {
780
+ const O = this;
781
+ O.select.before(O.E);
782
+ O.E.show();
783
+ O.E[0].classList.remove('SumoUnder');
784
+
785
+ if (settings.outputAsCSV && O.is_multi && O.select.find('input.HEMANT123').length) {
786
+ O.E.attr('name', O.select.find('input.HEMANT123').attr('name')); // restore the name;
787
+ }
788
+ O.select.remove();
789
+ delete selObj.sumo;
790
+ O.E.trigger('sumo:unloaded', O);
791
+ return selObj;
792
+ },
793
+
794
+ //## add a new option to select at a given index.
795
+ add (val, txt, i, attr) {
796
+ if (typeof val === "undefined") throw new Error("No value to add");
797
+
798
+ const O = this;
799
+ const opts = O.E.find('option');
800
+ let
801
+ value = val,
802
+ text = txt,
803
+ index = i;
804
+ if (typeof txt === "number") { // .add('xxx', 2) shorthand
805
+ index = txt;
806
+ text = val;
807
+ } else if (typeof txt === "undefined") { // .add('xxx') shorthand
808
+ text = val;
809
+ }
810
+
811
+ const opt = $("<option></option>").val(value).html(text);
812
+
813
+ if (attr && typeof attr === "object") {
814
+ $.each(attr, (j, v) => {
815
+ opt.attr(j, v);
816
+ });
817
+ }
818
+
819
+ if (opts.length < index) throw new Error("index out of bounds");
820
+
821
+ if (typeof index === "undefined" || opts.length === index) { // add it to the last if given index is last no or no index provides.
822
+ O.E.append(opt);
823
+ if (!O.mob) O.ul.append(O.createLi(opt));
824
+ }
825
+ else {
826
+ opts.eq(index).before(opt);
827
+ if (!O.mob) O.ul.find('li.opt').eq(index).before(O.createLi(opt));
828
+ }
829
+
830
+ return selObj;
831
+ },
832
+
833
+ //## removes an item at a given index.
834
+ remove (i) {
835
+ const O = this.vRange(i);
836
+ O.E.find('option').eq(i).remove();
837
+ if (!O.mob) O.optDiv.find('ul.options li.opt').eq(i).remove();
838
+ O.setText();
839
+ },
840
+
841
+ // removes all but the selected one
842
+ removeAll () {
843
+ const O = this;
844
+ const optionList = O.E.find('option');
845
+
846
+ for (let x = (optionList.length - 1); x >= 0; x--) {
847
+ if (optionList[x].selected !== true) {
848
+ O.remove(x);
849
+ }
850
+ }
851
+
852
+ },
853
+
854
+
855
+ find (val) {
856
+ const O = this;
857
+ const optionList = O.E.find('option');
858
+ for (let x in optionList) {
859
+ if (optionList[x].value === val) {
860
+ return +x;
861
+ }
862
+ }
863
+
864
+ return -1;
865
+
866
+ },
867
+
868
+ //## Select an item at a given index.
869
+ selectItem (i) { this.toggSel(true, i); },
870
+
871
+ //## UnSelect an iten at a given index.
872
+ unSelectItem (i) { this.toggSel(false, i); },
873
+
874
+ //## Select all items of the select.
875
+ selectAll () { this.toggSelAll(true); },
876
+
877
+ //## UnSelect all items of the select.
878
+ unSelectAll () { this.toggSelAll(false); },
879
+
880
+ //## Disable an iten at a given index.
881
+ disableItem (i) { this.toggDis(true, i); },
882
+
883
+ //## Removes disabled an iten at a given index.
884
+ enableItem (i) { this.toggDis(false, i); },
885
+
886
+ //## New simple methods as getter and setter are not working fine in ie8-
887
+ //## variable to check state of control if enabled or disabled.
888
+ enabled: true,
889
+ //## Enables the control
890
+ enable () { return this.toggSumo(false); },
891
+
892
+ //## Disables the control
893
+ disable () { return this.toggSumo(true); },
894
+
895
+
896
+ init () {
897
+ const O = this;
898
+ O.createElems();
899
+ O.setText();
900
+ O.E.trigger('sumo:initialized', O);
901
+ return O;
902
+ }
903
+
904
+ };
905
+
906
+ selObj.sumo.init();
907
+ });
908
+
909
+ return ret.length === 1 ? ret[0] : ret;
910
+ };
911
+
912
+
913
+ });
js/jquery.sumoselect.min.js CHANGED
@@ -1,765 +1,97 @@
1
- /*
2
- * jquery.sumoselect - v3.0.3
3
  * http://hemantnegi.github.io/jquery.sumoselect
4
  * 2016-12-12
5
  *
6
  * Copyright 2015 Hemant Negi
7
  * Email : hemant.frnz@gmail.com
8
  * Compressor http://refresh-sf.com/
9
- */
10
-
11
- (function(factory) {
12
- 'use strict';
13
- if (typeof define === 'function' && define.amd) {
14
- define(['jquery'], factory);
15
- } else if (typeof exports !== 'undefined') {
16
- module.exports = factory(require('jquery'));
17
- } else {
18
- factory(jQuery);
19
- }
20
-
21
- })(function ($) {
22
-
23
- 'namespace sumo';
24
- $.fn.SumoSelect = function (options) {
25
-
26
- /* This is the easiest way to have default options.*/
27
- var settings = $.extend({
28
- placeholder: 'Select Here', /* Dont change it here.*/
29
- csvDispCount: 3, /* display no. of items in multiselect. 0 to display all.*/
30
- captionFormat:'{0} Selected', /* format of caption text. you can set your locale.*/
31
- captionFormatAllSelected:'{0} all selected!', /* format of caption text when all elements are selected. set null to use captionFormat. It will not work if there are disabled elements in select.*/
32
- floatWidth: 400, /* Screen width of device at which the list is rendered in floating popup fashion.*/
33
- forceCustomRendering: false, /* force the custom modal on all devices below floatWidth resolution.*/
34
- nativeOnDevice: ['Android', 'BlackBerry', 'iPhone', 'iPad', 'iPod', 'Opera Mini', 'IEMobile', 'Silk'],
35
- outputAsCSV: false, /* true to POST data as csv ( false for Html control array ie. default select )*/
36
- csvSepChar: ',', /* separation char in csv mode*/
37
- okCancelInMulti: false, /* display ok cancel buttons in desktop mode multiselect also.*/
38
- isClickAwayOk: false, /* for okCancelInMulti=true. sets whether click outside will trigger Ok or Cancel (default is cancel).*/
39
- triggerChangeCombined: true, /* im multi select mode whether to trigger change event on individual selection or combined selection.*/
40
- selectAll: false, /* to display select all button in multiselect mode.|| also select all will not be available on mobile devices.*/
41
- search: false, /* to display input for filtering content. selectAlltext will be input text placeholder*/
42
- searchText: 'Search...', /* placeholder for search input*/
43
- noMatch: 'No matches for "{0}"',
44
- prefix: '', /* some prefix usually the field name. eg. '<b>Hello</b>'*/
45
- locale: ['OK', 'Cancel', 'Select All'], /* all text that is used. don't change the index.*/
46
- up: false, /* set true to open upside.*/
47
- showTitle: true /* set to false to prevent title (tooltip) from appearing*/
48
- }, options);
49
-
50
- var ret = this.each(function () {
51
- var selObj = this; /* the original select object.*/
52
- if (this.sumo || !$(this).is('select')) return; /* already initialized*/
53
-
54
- this.sumo = {
55
- E: $(selObj), /* the jquery object of original select element.*/
56
- is_multi: $(selObj).attr('multiple'), /* if its a multiple select*/
57
- select: '',
58
- caption: '',
59
- placeholder: '',
60
- optDiv: '',
61
- CaptionCont: '',
62
- ul:'',
63
- is_floating: false,
64
- is_opened: false,
65
- /* backdrop: '', */
66
- mob:false, /* if to open device default select */
67
- Pstate: [],
68
-
69
- createElems: function () {
70
- var O = this;
71
- O.E.wrap('<div class="SumoSelect" tabindex="0" role="button" aria-expanded="false">');
72
- O.select = O.E.parent();
73
- O.caption = $('<span>');
74
- O.CaptionCont = $('<p class="CaptionCont SelectBox" ><label><i></i></label></p>')
75
- .attr('style', O.E.attr('style'))
76
- .prepend(O.caption);
77
- O.select.append(O.CaptionCont);
78
-
79
- /* default turn off if no multiselect */
80
- if(!O.is_multi)settings.okCancelInMulti = false
81
-
82
- if(O.E.attr('disabled'))
83
- O.select.addClass('disabled').removeAttr('tabindex');
84
-
85
- /* if output as csv and is a multiselect.*/
86
- if (settings.outputAsCSV && O.is_multi && O.E.attr('name')) {
87
- /* create a hidden field to store csv value.*/
88
- O.select.append($('<input class="HEMANT123" type="hidden" />').attr('name', O.E.attr('name')).val(O.getSelStr()));
89
-
90
- /* so it can not post the original select.*/
91
- O.E.removeAttr('name');
92
- }
93
-
94
- /* break for mobile rendring.. if forceCustomRendering is false*/
95
- if (O.isMobile() && !settings.forceCustomRendering) {
96
- O.setNativeMobile();
97
- return;
98
- }
99
-
100
- /* if there is a name attr in select add a class to container div*/
101
- if(O.E.attr('name')) O.select.addClass('sumo_'+O.E.attr('name').replace(/\[\]/, ''))
102
-
103
- /* hide original select */
104
- O.E.addClass('SumoUnder').attr('tabindex','-1');
105
-
106
- /* Creating the list... */
107
- O.optDiv = $('<div class="optWrapper '+ (settings.up?'up':'') +'">');
108
-
109
- /* branch for floating list in low res devices.*/
110
- O.floatingList();
111
-
112
- /* Creating the markup for the available options*/
113
- O.ul = $('<ul class="options">');
114
- O.optDiv.append(O.ul);
115
-
116
- /* Select all functionality*/
117
- if(settings.selectAll && O.is_multi) O.SelAll();
118
-
119
- /* search functionality*/
120
- if(settings.search) O.Search();
121
-
122
- O.ul.append(O.prepItems(O.E.children()));
123
-
124
- /* if multiple then add the class multiple and add OK / CANCEL button */
125
- if (O.is_multi) O.multiSelelect();
126
-
127
- O.select.append(O.optDiv);
128
- O.basicEvents();
129
- O.selAllState();
130
- },
131
-
132
- prepItems: function(opts, d){
133
- var lis = [], O=this;
134
- $(opts).each(function (i, opt) { /* parsing options to li */
135
- opt = $(opt);
136
- lis.push(opt.is('optgroup')?
137
- $('<li class="group '+ (opt[0].disabled?'disabled':'') +'"><label>' + opt.attr('label') +'</label><ul></ul></li>')
138
- .find('ul')
139
- .append(O.prepItems(opt.children(), opt[0].disabled))
140
- .end()
141
- :
142
- O.createLi(opt, d)
143
- );
144
- });
145
- return lis;
146
- },
147
-
148
- /* Creates a LI element from a given option and binds events to it*/
149
- /*returns the jquery instance of li (not inserted in dom)*/
150
- createLi: function (opt, d) {
151
- var O = this;
152
-
153
- if(!opt.attr('value'))opt.attr('value',opt.val());
154
- var li = $('<li class="opt"><label>' + opt.text() + '</label></li>');
155
-
156
- li.data('opt', opt); /* store a direct reference to option.*/
157
- opt.data('li', li); /* store a direct reference to list item.*/
158
- if (O.is_multi) li.prepend('<span><i></i></span>');
159
-
160
- if (opt[0].disabled || d)
161
- li = li.addClass('disabled');
162
-
163
- O.onOptClick(li);
164
-
165
- if (opt[0].selected)
166
- li.addClass('selected');
167
-
168
- if (opt.attr('class'))
169
- li.addClass(opt.attr('class'));
170
-
171
- if (opt.attr('title'))
172
- li.attr('title', opt.attr('title'));
173
-
174
- return li;
175
- },
176
-
177
- /* Returns the selected items as string in a Multiselect.*/
178
- getSelStr: function () {
179
- /* get the pre selected items.*/
180
- sopt = [];
181
- this.E.find('option:selected').each(function () { sopt.push($(this).val()); });
182
- return sopt.join(settings.csvSepChar);
183
- },
184
-
185
- /* THOSE OK/CANCEL BUTTONS ON MULTIPLE SELECT.*/
186
- multiSelelect: function () {
187
- var O = this;
188
- O.optDiv.addClass('multiple');
189
- O.okbtn = $('<p tabindex="0" class="btnOk">'+settings.locale[0]+'</p>').click(function () {
190
- /* if combined change event is set.*/
191
- O._okbtn();
192
- O.hideOpts();
193
- });
194
- O.cancelBtn = $('<p tabindex="0" class="btnCancel">'+settings.locale[1]+'</p>').click(function () {
195
- O._cnbtn();
196
- O.hideOpts();
197
- });
198
- var btns = O.okbtn.add(O.cancelBtn);
199
- O.optDiv.append($('<div class="MultiControls">').append(btns));
200
-
201
- /* handling keyboard navigation on ok cancel buttons. */
202
- btns.on('keydown.sumo', function (e) {
203
- var el = $(this);
204
- switch (e.which) {
205
- case 32: /* space */
206
- case 13: /* enter */
207
- el.trigger('click');
208
- break;
209
-
210
- case 9: /* tab */
211
- if(el.hasClass('btnOk'))return;
212
- case 27: /* esc */
213
- O._cnbtn();
214
- O.hideOpts();
215
- return;
216
- }
217
- e.stopPropagation();
218
- e.preventDefault();
219
- });
220
- },
221
-
222
- _okbtn:function(){
223
- var O = this, cg = 0;
224
- /* if combined change event is set. */
225
- if (settings.triggerChangeCombined) {
226
- /* check for a change in the selection. */
227
- if (O.E.find('option:selected').length != O.Pstate.length) {
228
- cg = 1;
229
- }
230
- else {
231
- O.E.find('option').each(function (i,e) {
232
- if(e.selected && O.Pstate.indexOf(i) < 0) cg = 1;
233
- });
234
- }
235
-
236
- if (cg) {
237
- O.callChange();
238
- O.setText();
239
- }
240
- }
241
- },
242
- _cnbtn:function(){
243
- var O = this;
244
- /* remove all selections */
245
- O.E.find('option:selected').each(function () { this.selected = false; });
246
- O.optDiv.find('li.selected').removeClass('selected')
247
-
248
- /* restore selections from saved state. */
249
- for(var i = 0; i < O.Pstate.length; i++) {
250
- O.E.find('option')[O.Pstate[i]].selected = true;
251
- O.ul.find('li.opt').eq(O.Pstate[i]).addClass('selected');
252
- }
253
- O.selAllState();
254
- },
255
-
256
- SelAll:function(){
257
- var O = this;
258
- if(!O.is_multi)return;
259
- O.selAll = $('<p class="select-all"><span><i></i></span><label>' + settings.locale[2] + '</label></p>');
260
- O.optDiv.addClass('selall');
261
- O.selAll.on('click',function(){
262
- O.selAll.toggleClass('selected');
263
- O.toggSelAll(O.selAll.hasClass('selected'), 1);
264
- //O.selAllState();
265
- });
266
-
267
- O.optDiv.prepend(O.selAll);
268
- },
269
-
270
- /* search module (can be removed if not required.) */
271
- Search: function(){
272
- var O = this,
273
- cc = O.CaptionCont.addClass('search'),
274
- P = $('<p class="no-match">');
275
-
276
- O.ftxt = $('<input type="text" class="search-txt" value="" placeholder="' + settings.searchText + '">')
277
- .on('click', function(e){
278
- e.stopPropagation();
279
- });
280
- cc.append(O.ftxt);
281
- O.optDiv.children('ul').after(P);
282
-
283
- O.ftxt.on('keyup.sumo',function(){
284
- var hid = O.optDiv.find('ul.options li.opt').each(function(ix,e){
285
- var e = $(e),
286
- opt = e.data('opt')[0];
287
- opt.hidden = e.text().toLowerCase().indexOf(O.ftxt.val().toLowerCase()) < 0;
288
- e.toggleClass('hidden', opt.hidden);
289
- }).not('.hidden');
290
-
291
- P.html(settings.noMatch.replace(/\{0\}/g, '<em></em>')).toggle(!hid.length);
292
- P.find('em').text(O.ftxt.val());
293
- O.selAllState();
294
- });
295
- },
296
-
297
- selAllState: function () {
298
- var O = this;
299
- if (settings.selectAll && O.is_multi) {
300
- var sc = 0, vc = 0;
301
- O.optDiv.find('li.opt').not('.hidden').each(function (ix, e) {
302
- if ($(e).hasClass('selected')) sc++;
303
- if (!$(e).hasClass('disabled')) vc++;
304
- });
305
- /* select all checkbox state change. */
306
- if (sc == vc) O.selAll.removeClass('partial').addClass('selected');
307
- else if (sc == 0) O.selAll.removeClass('selected partial');
308
- else O.selAll.addClass('partial') /* .removeClass('selected'); */
309
- }
310
- },
311
-
312
- showOpts: function () {
313
- var O = this;
314
- if (O.E.attr('disabled')) return; /* if select is disabled then retrun */
315
- O.E.trigger('sumo:opening', O);
316
- O.is_opened = true;
317
- O.select.addClass('open').attr('aria-expanded', 'true');
318
- O.E.trigger('sumo:opened', O);
319
-
320
- if(O.ftxt)O.ftxt.focus();
321
- else O.select.focus();
322
-
323
- /* hide options on click outside.*/
324
- $(document).on('click.sumo', function (e) {
325
- if (!O.select.is(e.target) /* if the target of the click isn't the container... */
326
- && O.select.has(e.target).length === 0){ /* ... nor a descendant of the container */
327
- if(!O.is_opened)return;
328
- O.hideOpts();
329
- if (settings.okCancelInMulti){
330
- if(settings.isClickAwayOk)
331
- O._okbtn();
332
- else
333
- O._cnbtn();
334
- }
335
- }
336
- });
337
-
338
- if (O.is_floating) {
339
- H = O.optDiv.children('ul').outerHeight() + 2; /* +2 is clear fix*/
340
- if (O.is_multi) H = H + parseInt(O.optDiv.css('padding-bottom'));
341
- O.optDiv.css('height', H);
342
- $('body').addClass('sumoStopScroll');
343
- }
344
-
345
- O.setPstate();
346
- },
347
-
348
- /* maintain state when ok/cancel buttons are available storing the indexes. */
349
- setPstate: function(){
350
- var O = this;
351
- if (O.is_multi && (O.is_floating || settings.okCancelInMulti)){
352
- O.Pstate = [];
353
- /* assuming that find returns elements in tree order */
354
- O.E.find('option').each(function (i, e){if(e.selected) O.Pstate.push(i);});
355
- }
356
- },
357
-
358
- callChange:function(){
359
- this.E.trigger('change').trigger('click');
360
- },
361
-
362
- hideOpts: function () {
363
- var O = this;
364
- if(O.is_opened){
365
- O.E.trigger('sumo:closing', O);
366
- O.is_opened = false;
367
- O.select.removeClass('open').attr('aria-expanded', 'true').find('ul li.sel').removeClass('sel');
368
- O.E.trigger('sumo:closed', O);
369
- $(document).off('click.sumo');
370
- O.select.focus();
371
- $('body').removeClass('sumoStopScroll');
372
-
373
- /* clear the search */
374
- if(settings.search){
375
- O.ftxt.val('');
376
- O.ftxt.trigger('keyup.sumo');
377
- }
378
- }
379
- },
380
- setOnOpen: function () {
381
- var O = this,
382
- li = O.optDiv.find('li.opt:not(.hidden)').eq(settings.search?0:O.E[0].selectedIndex);
383
- if(li.hasClass('disabled')){
384
- li = li.next(':not(disabled)')
385
- if(!li.length) return;
386
- }
387
- O.optDiv.find('li.sel').removeClass('sel');
388
- li.addClass('sel');
389
- O.showOpts();
390
- },
391
- nav: function (up) {
392
- var O = this, c,
393
- s=O.ul.find('li.opt:not(.disabled, .hidden)'),
394
- sel = O.ul.find('li.opt.sel:not(.hidden)'),
395
- idx = s.index(sel);
396
- if (O.is_opened && sel.length) {
397
-
398
- if (up && idx > 0)
399
- c = s.eq(idx-1);
400
- else if(!up && idx < s.length-1 && idx > -1)
401
- c = s.eq(idx+1);
402
- else return; /* if no items before or after*/
403
-
404
- sel.removeClass('sel');
405
- sel = c.addClass('sel');
406
-
407
- /* setting sel item to visible view. */
408
- var ul = O.ul,
409
- st = ul.scrollTop(),
410
- t = sel.position().top + st;
411
- if(t >= st + ul.height()-sel.outerHeight())
412
- ul.scrollTop(t - ul.height() + sel.outerHeight());
413
- if(t<st)
414
- ul.scrollTop(t);
415
-
416
- }
417
- else
418
- O.setOnOpen();
419
- },
420
-
421
- basicEvents: function () {
422
- var O = this;
423
- O.CaptionCont.click(function (evt) {
424
- O.E.trigger('click');
425
- if (O.is_opened) O.hideOpts(); else O.showOpts();
426
- evt.stopPropagation();
427
- });
428
-
429
- O.select.on('keydown.sumo', function (e) {
430
- switch (e.which) {
431
- case 38: /* up */
432
- O.nav(true);
433
- break;
434
-
435
- case 40: /* down */
436
- O.nav(false);
437
- break;
438
-
439
- case 65: /* shortcut ctrl + a to select all and ctrl + shift + a to unselect all.*/
440
- if (O.is_multi && e.ctrlKey){
441
- O.toggSelAll(!e.shiftKey, 1);
442
- break;
443
- }
444
- else
445
- return;
446
-
447
- case 32: /* space*/
448
- if(settings.search && O.ftxt.is(e.target))return;
449
- case 13: /* enter*/
450
- if (O.is_opened)
451
- O.optDiv.find('ul li.sel').trigger('click');
452
- else
453
- O.setOnOpen();
454
- break;
455
- case 9: /* tab*/
456
- if(!settings.okCancelInMulti)
457
- O.hideOpts();
458
- return;
459
- case 27: /* esc*/
460
- if(settings.okCancelInMulti)O._cnbtn();
461
- O.hideOpts();
462
- return;
463
-
464
- default:
465
- return; /* exit this handler for other keys */
466
- }
467
- e.preventDefault(); /* prevent the default action (scroll / move caret) */
468
- });
469
-
470
- $(window).on('resize.sumo', function () {
471
- O.floatingList();
472
- });
473
- },
474
-
475
- onOptClick: function (li) {
476
- var O = this;
477
- li.click(function () {
478
- var li = $(this);
479
- if(li.hasClass('disabled'))return;
480
- var txt = "";
481
- if (O.is_multi) {
482
- li.toggleClass('selected');
483
- li.data('opt')[0].selected = li.hasClass('selected');
484
- O.selAllState();
485
- }
486
- else {
487
- li.parent().find('li.selected').removeClass('selected'); //if not multiselect then remove all selections from this list
488
- li.toggleClass('selected');
489
- li.data('opt')[0].selected = true;
490
- }
491
-
492
- //branch for combined change event.
493
- if (!(O.is_multi && settings.triggerChangeCombined && (O.is_floating || settings.okCancelInMulti))) {
494
- O.setText();
495
- O.callChange();
496
- }
497
-
498
- if (!O.is_multi) O.hideOpts(); //if its not a multiselect then hide on single select.
499
- });
500
- },
501
-
502
- setText: function () {
503
- var O = this;
504
- O.placeholder = "";
505
- if (O.is_multi) {
506
- sels = O.E.find(':selected').not(':disabled'); //selected options.
507
-
508
- for (i = 0; i < sels.length; i++) {
509
- if (i + 1 >= settings.csvDispCount && settings.csvDispCount) {
510
- if (sels.length == O.E.find('option').length && settings.captionFormatAllSelected) {
511
- O.placeholder = settings.captionFormatAllSelected.replace(/\{0\}/g, sels.length)+',';
512
- } else {
513
- O.placeholder = settings.captionFormat.replace(/\{0\}/g, sels.length)+',';
514
- }
515
-
516
- break;
517
- }
518
- else O.placeholder += $(sels[i]).text() + ", ";
519
- }
520
- O.placeholder = O.placeholder.replace(/,([^,]*)$/, '$1'); //remove unexpected "," from last.
521
- }
522
- else {
523
- O.placeholder = O.E.find(':selected').not(':disabled').text();
524
- }
525
-
526
- var is_placeholder = false;
527
-
528
- if (!O.placeholder) {
529
-
530
- is_placeholder = true;
531
-
532
- O.placeholder = O.E.attr('placeholder');
533
- if (!O.placeholder) //if placeholder is there then set it
534
- O.placeholder = O.E.find('option:disabled:selected').text();
535
- }
536
-
537
- O.placeholder = O.placeholder ? (settings.prefix + ' ' + O.placeholder) : settings.placeholder
538
-
539
- //set display text
540
- O.caption.html(O.placeholder);
541
- if (settings.showTitle) O.CaptionCont.attr('title', O.placeholder);
542
-
543
- //set the hidden field if post as csv is true.
544
- var csvField = O.select.find('input.HEMANT123');
545
- if (csvField.length) csvField.val(O.getSelStr());
546
-
547
- //add class placeholder if its a placeholder text.
548
- if (is_placeholder) O.caption.addClass('placeholder'); else O.caption.removeClass('placeholder');
549
- return O.placeholder;
550
- },
551
-
552
- isMobile: function () {
553
-
554
- /* Adapted from http://www.detectmobilebrowsers.com */
555
- var ua = navigator.userAgent || navigator.vendor || window.opera;
556
-
557
- /* Checks for iOs, Android, Blackberry, Opera Mini, and Windows mobile devices */
558
- for (var i = 0; i < settings.nativeOnDevice.length; i++) if (ua.toString().toLowerCase().indexOf(settings.nativeOnDevice[i].toLowerCase()) > 0) return settings.nativeOnDevice[i];
559
- return false;
560
- },
561
-
562
- setNativeMobile: function () {
563
- var O = this;
564
- O.E.addClass('SelectClass'); /* .css('height', O.select.outerHeight()); */
565
- O.mob = true;
566
- O.E.change(function () {
567
- O.setText();
568
- });
569
- },
570
-
571
- floatingList: function () {
572
- var O = this;
573
- /*called on init and also on resize.*/
574
- /*O.is_floating = true if window width is < specified float width*/
575
- O.is_floating = $(window).width() <= settings.floatWidth;
576
-
577
- /*set class isFloating*/
578
- O.optDiv.toggleClass('isFloating', O.is_floating);
579
-
580
- /*remove height if not floating*/
581
- if (!O.is_floating) O.optDiv.css('height', '');
582
-
583
- /*toggle class according to okCancelInMulti flag only when it is not floating*/
584
- O.optDiv.toggleClass('okCancelInMulti', settings.okCancelInMulti && !O.is_floating);
585
- },
586
-
587
- /* HELPERS FOR OUTSIDERS*/
588
- /* validates range of given item operations*/
589
- vRange: function (i) {
590
- var O = this;
591
- var opts = O.E.find('option');
592
- if (opts.length <= i || i < 0) throw "index out of bounds"
593
- return O;
594
- },
595
-
596
- /*toggles selection on c as boolean.*/
597
- toggSel: function (c, i) {
598
- var O = this;
599
- var opt;
600
- if (typeof(i) === "number"){
601
- O.vRange(i);
602
- opt = O.E.find('option')[i];
603
- }
604
- else{
605
- opt = O.E.find('option[value="'+i+'"]')[0]||0;
606
- }
607
- if (!opt || opt.disabled)
608
- return;
609
-
610
- if(opt.selected != c){
611
- opt.selected = c;
612
- if(!O.mob) $(opt).data('li').toggleClass('selected',c);
613
-
614
- O.callChange();
615
- O.setPstate();
616
- O.setText();
617
- O.selAllState();
618
- }
619
- },
620
-
621
- /*toggles disabled on c as boolean.*/
622
- toggDis: function (c, i) {
623
- var O = this.vRange(i);
624
- O.E.find('option')[i].disabled = c;
625
- if(c)O.E.find('option')[i].selected = false;
626
- if(!O.mob)O.optDiv.find('ul.options li').eq(i).toggleClass('disabled', c).removeClass('selected');
627
- O.setText();
628
- },
629
-
630
- /* toggle disable/enable on complete select control*/
631
- toggSumo: function(val) {
632
- var O = this;
633
- O.enabled = val;
634
- O.select.toggleClass('disabled', val);
635
-
636
- if (val) {
637
- O.E.attr('disabled', 'disabled');
638
- O.select.removeAttr('tabindex');
639
- }
640
- else{
641
- O.E.removeAttr('disabled');
642
- O.select.attr('tabindex','0');
643
- }
644
-
645
- return O;
646
- },
647
-
648
- /* toggles all option on c as boolean.*/
649
- /* set direct=false/0 bypasses okCancelInMulti behaviour.*/
650
- toggSelAll: function (c, direct) {
651
- var O = this;
652
- O.E.find('option:not(:disabled,:hidden)')
653
- .each(function(ix,e){
654
- var is_selected=e.selected,
655
- e = $(e).data('li');
656
- if(e.hasClass('hidden'))return;
657
- if(!!c){
658
- if(!is_selected)e.trigger('click');
659
- }
660
- else{
661
- if(is_selected)e.trigger('click');
662
- }
663
- });
664
-
665
- if(!direct){
666
- if(!O.mob && O.selAll)O.selAll.removeClass('partial').toggleClass('selected',!!c);
667
- O.callChange();
668
- O.setText();
669
- O.setPstate();
670
- }
671
- },
672
-
673
- /* outside accessibility options
674
- which can be accessed from the element instance.
675
- */
676
- reload:function(){
677
- var elm = this.unload();
678
- return $(elm).SumoSelect(settings);
679
- },
680
-
681
- unload: function () {
682
- var O = this;
683
- O.select.before(O.E);
684
- O.E.show();
685
-
686
- if (settings.outputAsCSV && O.is_multi && O.select.find('input.HEMANT123').length) {
687
- O.E.attr('name', O.select.find('input.HEMANT123').attr('name')); /* restore the name; */
688
- }
689
- O.select.remove();
690
- delete selObj.sumo;
691
- return selObj;
692
- },
693
-
694
- /* add a new option to select at a given index.*/
695
- add: function (val, txt, i) {
696
- if (typeof val == "undefined") throw "No value to add"
697
-
698
- var O = this;
699
- opts=O.E.find('option')
700
- if (typeof txt == "number") { i = txt; txt = val; }
701
- if (typeof txt == "undefined") { txt = val; }
702
-
703
- opt = $("<option></option>").val(val).html(txt);
704
-
705
- if (opts.length < i) throw "index out of bounds"
706
-
707
- if (typeof i == "undefined" || opts.length == i) { /* add it to the last if given index is last no or no index provides.*/
708
- O.E.append(opt);
709
- if(!O.mob)O.ul.append(O.createLi(opt));
710
- }
711
- else {
712
- opts.eq(i).before(opt);
713
- if(!O.mob)O.ul.find('li.opt').eq(i).before(O.createLi(opt));
714
- }
715
-
716
- return selObj;
717
- },
718
-
719
- /* removes an item at a given index. */
720
- remove: function (i) {
721
- var O = this.vRange(i);
722
- O.E.find('option').eq(i).remove();
723
- if(!O.mob)O.optDiv.find('ul.options li').eq(i).remove();
724
- O.setText();
725
- },
726
-
727
- /* Select an item at a given index.*/
728
- selectItem: function (i) { this.toggSel(true, i); },
729
-
730
- /* UnSelect an iten at a given index.*/
731
- unSelectItem: function (i) { this.toggSel(false, i); },
732
-
733
- /* Select all items of the select.*/
734
- selectAll: function () { this.toggSelAll(true); },
735
-
736
- /* UnSelect all items of the select.*/
737
- unSelectAll: function () { this.toggSelAll(false); },
738
-
739
- /* Disable an iten at a given index.*/
740
- disableItem: function (i) { this.toggDis(true, i) },
741
-
742
- /* Removes disabled an iten at a given index.*/
743
- enableItem: function (i) { this.toggDis(false, i) },
744
-
745
- /* New simple methods as getter and setter are not working fine in ie8-*/
746
- /* variable to check state of control if enabled or disabled.*/
747
- enabled : true,
748
- /* Enables the control*/
749
- enable: function(){return this.toggSumo(false)},
750
-
751
- /* Disables the control*/
752
- disable: function(){return this.toggSumo(true)},
753
- init: function () {
754
- var O = this;
755
- O.createElems();
756
- O.setText();
757
- return O
758
- }
759
- };
760
- selObj.sumo.init();
761
- });
762
-
763
- return ret.length == 1 ? ret[0] : ret;
764
- };
765
- });
1
+ "use strict";function _typeof(a){"@babel/helpers - typeof";return _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a},_typeof(a)}function _slicedToArray(a,b){return _arrayWithHoles(a)||_iterableToArrayLimit(a,b)||_unsupportedIterableToArray(a,b)||_nonIterableRest()}function _nonIterableRest(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _iterableToArrayLimit(a,b){var c=null==a?null:"undefined"!=typeof Symbol&&a[Symbol.iterator]||a["@@iterator"];if(null!=c){var d,e,f=[],g=!0,h=!1;try{for(c=c.call(a);!(g=(d=c.next()).done)&&(f.push(d.value),!(b&&f.length===b));g=!0);}catch(a){h=!0,e=a}finally{try{g||null==c["return"]||c["return"]()}finally{if(h)throw e}}return f}}function _arrayWithHoles(a){if(Array.isArray(a))return a}function _toConsumableArray(a){return _arrayWithoutHoles(a)||_iterableToArray(a)||_unsupportedIterableToArray(a)||_nonIterableSpread()}function _nonIterableSpread(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _unsupportedIterableToArray(a,b){if(a){if("string"==typeof a)return _arrayLikeToArray(a,b);var c=Object.prototype.toString.call(a).slice(8,-1);return"Object"===c&&a.constructor&&(c=a.constructor.name),"Map"===c||"Set"===c?Array.from(a):"Arguments"===c||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(c)?_arrayLikeToArray(a,b):void 0}}function _iterableToArray(a){if("undefined"!=typeof Symbol&&null!=a[Symbol.iterator]||null!=a["@@iterator"])return Array.from(a)}function _arrayWithoutHoles(a){if(Array.isArray(a))return _arrayLikeToArray(a)}function _arrayLikeToArray(a,b){(null==b||b>a.length)&&(b=a.length);for(var c=0,d=Array(b);c<b;c++)d[c]=a[c];return d}/*global jQuery, define, module, require*/ /*!
2
+ * jquery.sumoselect
3
  * http://hemantnegi.github.io/jquery.sumoselect
4
  * 2016-12-12
5
  *
6
  * Copyright 2015 Hemant Negi
7
  * Email : hemant.frnz@gmail.com
8
  * Compressor http://refresh-sf.com/
9
+ */(function(a){'use strict';"function"==typeof define&&define.amd?define(["jquery"],a):"undefined"==typeof exports?a(jQuery):module.exports=a(require("jquery"))})(function(a){'namespace sumo';a.fn.SumoSelect=function(b){// This is the easiest way to have default options.
10
+ var c={placeholder:"Select Here",// Dont change it here.
11
+ csvDispCount:3,// display no. of items in multiselect. 0 to display all.
12
+ captionFormat:"{0} Selected",// format of caption text. you can set your locale.
13
+ captionFormatAllSelected:"{0} all selected!",// format of caption text when all elements are selected. set null to use captionFormat. It will not work if there are disabled elements in select.
14
+ floatWidth:400,// Screen width of device at which the list is rendered in floating popup fashion.
15
+ forceCustomRendering:!1,// force the custom modal on all devices below floatWidth resolution.
16
+ nativeOnDevice:["Android","BlackBerry","iPhone","iPad","iPod","Opera Mini","IEMobile","Silk"],//
17
+ outputAsCSV:!1,// true to POST data as csv ( false for Html control array ie. default select )
18
+ csvSepChar:",",// separation char in csv mode
19
+ okCancelInMulti:!1,// display ok cancel buttons in desktop mode multiselect also.
20
+ isClickAwayOk:!1,// for okCancelInMulti=true. sets whether click outside will trigger Ok or Cancel (default is cancel).
21
+ triggerChangeCombined:!0,// im multi select mode whether to trigger change event on individual selection or combined selection.
22
+ selectAll:!1,// to display select all button in multiselect mode.|| also select all will not be available on mobile devices.
23
+ search:!1,// to display input for filtering content. selectAlltext will be input text placeholder
24
+ searchText:"Search...",// placeholder for search input
25
+ searchFn:function searchFn(a,b){// search function
26
+ return 0>a.toLowerCase().indexOf(b.toLowerCase())},noMatch:"No matches for \"{0}\"",prefix:"",// some prefix usually the field name. eg. '<b>Hello</b>'
27
+ locale:["OK","Cancel","Select All"],// all text that is used. don't change the index.
28
+ up:!1,// set true to open upside.
29
+ showTitle:!0,// set to false to prevent title (tooltip) from appearing
30
+ max:null,// Maximum number of options selected (when multiple)
31
+ // eslint-disable-next-line no-unused-vars
32
+ renderLi:function renderLi(a){return a}// Custom <li> item renderer
33
+ },d=this.each(function(){var d=this;// the original select object.
34
+ if(!this.sumo&&a(this).is("select")){//already initialized
35
+ var f=a.extend({},c,b,a(this).data());this.sumo={E:a(d),//the jquery object of original select element.
36
+ is_multi:a(d).attr("multiple"),//if its a multiple select
37
+ select:"",caption:"",placeholder:"",optDiv:"",CaptionCont:"",ul:"",is_floating:!1,is_opened:!1,//backdrop: '',
38
+ mob:!1,// if to open device default select
39
+ Pstate:[],lastUnselected:null,selectedCount:0,createElems:function createElems(){var b=this,c=b.E[0].selectedOptions;//break for mobile rendring.. if forceCustomRendering is false
40
+ return b.E.wrap("<div class=\"SumoSelect\" tabindex=\"0\" role=\"button\" aria-expanded=\"false\">"),_toConsumableArray(c).forEach(function(a){a.selected=!0}),b.select=b.E.parent(),b.caption=a("<span>"),b.CaptionCont=a("<p class=\"CaptionCont SelectBox ".concat(b.E.attr("class"),"\" ><label><i></i></label></p>")).attr("style",b.E.attr("style")).prepend(b.caption),b.select.append(b.CaptionCont),b.is_multi||(f.okCancelInMulti=!1),b.E.attr("disabled")&&b.select.addClass("disabled").removeAttr("tabindex"),f.outputAsCSV&&b.is_multi&&b.E.attr("name")&&(b.select.append(a("<input class=\"HEMANT123\" type=\"hidden\" />").attr("name",b.E.attr("name")).val(b.getSelStr())),b.E.removeAttr("name")),b.isMobile()&&!f.forceCustomRendering?void b.setNativeMobile():void(//hide original select
41
+ //## Creating the list...
42
+ //branch for floating list in low res devices.
43
+ //Creating the markup for the available options
44
+ b.E.attr("name")&&b.select.addClass("sumo_".concat(b.E.attr("name").replace(/\[\]/,""))),b.E.addClass("SumoUnder").attr("tabindex","-1"),b.optDiv=a("<div class=\"optWrapper ".concat(f.up?"up":"","\">")),b.floatingList(),b.ul=a("<ul class=\"options\">"),b.optDiv.append(b.ul),f.selectAll&&b.is_multi&&!f.max&&b.SelAll(),f.search&&b.Search(),b.ul.append(b.prepItems(b.E.children())),b.is_multi&&b.multiSelelect(),b.select.append(b.optDiv),b._handleMax(),b.basicEvents(),b.selAllState());// if there is a name attr in select add a class to container div
45
+ },prepItems:function prepItems(b,c){var d=[],e=this;return a(b).each(function(b,f){// parsing options to li
46
+ var g=a(f);d.push(g.is("optgroup")?a("<li class=\"group ".concat(f.disabled?"disabled":"","\"><label></label><ul></ul></li>")).find("label").text(g.attr("label")).end().find("ul").append(e.prepItems(g.children(),f.disabled)).end():e.createLi(g,c))}),d},//## Creates a LI element from a given option and binds events to it
47
+ //## returns the jquery instance of li (not inserted in dom)
48
+ createLi:function createLi(b,c){var d=this;b.attr("value")||b.attr("value",b.val());var e=a("<li class=\"opt\"><label>".concat(b.html(),"</label></li>"));return e.data("opt",b),b.data("li",e),d.is_multi&&e.prepend("<span><i></i></span>"),(b[0].disabled||c)&&e.addClass("disabled"),d.onOptClick(e),b[0].selected&&(e.addClass("selected"),d.selectedCount++),b.attr("class")&&e.addClass(b.attr("class")),b.attr("title")&&e.attr("title",b.attr("title")),f.renderLi(e,b)},//## Returns the selected items as string in a Multiselect.
49
+ getSelStr:function getSelStr(){// get the pre selected items.
50
+ var b=[];return this.E.find("option:checked").each(function(){b.push(a(this).val())}),b.join(f.csvSepChar)},//## THOSE OK/CANCEL BUTTONS ON MULTIPLE SELECT.
51
+ multiSelelect:function multiSelelect(){var b=this;b.optDiv.addClass("multiple"),b.okbtn=a("<p tabindex=\"0\" class=\"btnOk\"></p>").click(function(){b._okbtn(),b.hideOpts()});var c=_slicedToArray(f.locale,1);b.okbtn[0].innerText=c[0],b.cancelBtn=a("<p tabindex=\"0\" class=\"btnCancel\"></p>").click(function(){b._cnbtn(),b.hideOpts()});var d=_slicedToArray(f.locale,2);b.cancelBtn[0].innerText=d[1];var e=b.okbtn.add(b.cancelBtn);b.optDiv.append(a("<div class=\"MultiControls\">").append(e)),e.on("keydown.sumo",function(c){var d=a(this);switch(c.which){case 32:// space
52
+ case 13:d.trigger("click");break;case 9://tab
53
+ if(d.hasClass("btnOk"))return;break;case 27:return b._cnbtn(),void b.hideOpts();default:}c.stopPropagation(),c.preventDefault()})},_okbtn:function _okbtn(){var a=this,b=0;f.triggerChangeCombined&&(a.E.find("option:checked").length===a.Pstate.length?a.E.find("option").each(function(c,d){d.selected&&0>a.Pstate.indexOf(c)&&(b=1)}):b=1,b&&(a.callChange(),a.setText()))},_cnbtn:function _cnbtn(){var a=this;//remove all selections
54
+ a.E.find("option:checked").each(function(){this.selected=!1}),a.optDiv.find("li.selected").removeClass("selected");//restore selections from saved state.
55
+ for(var b=0;b<a.Pstate.length;b++)a.E.find("option")[a.Pstate[b]].selected=!0,a.ul.find("li.opt").eq(a.Pstate[b]).addClass("selected");a.selAllState()},_handleMax:function _handleMax(){f.max&&(this.selectedCount>=+f.max?this.optDiv.find("li.opt").not(".hidden").each(function(b,c){a(c).hasClass("selected")||a(c).addClass("temporary-disabled disabled")}):this.optDiv.find("li.opt").not(".hidden").each(function(b,c){a(c).hasClass("temporary-disabled")&&a(c).removeClass("temporary-disabled disabled")}))},SelAll:function SelAll(){var b=this;if(b.is_multi){b.selAll=a("<p class=\"select-all\"><span><i></i></span><label></label></p>");var c=_slicedToArray(f.locale,3);b.selAll.find("label")[0].innerText=c[2],b.optDiv.addClass("selall"),b.selAll.on("click",function(){b.selAll.toggleClass("selected"),b.toggSelAll(b.selAll.hasClass("selected"),1)}),b.optDiv.prepend(b.selAll)}},// search module (can be removed if not required.)
56
+ Search:function Search(){var c=this,d=c.CaptionCont.addClass("search"),e=a("<p class=\"no-match\">"),g=b.searchFn&&"function"==typeof b.searchFn?b.searchFn:f.searchFn;c.ftxt=a("<input type=\"text\" class=\"search-txt\" value=\"\" autocomplete=\"off\">").on("click",function(a){a.stopPropagation()}),c.ftxt.placeholder=f.searchText,d.append(c.ftxt),c.optDiv.children("ul").after(e),c.ftxt.on("keyup.sumo",function(){var b=c.optDiv.find("ul.options li.opt").each(function(b,d){var e=a(d),f=e.data("opt"),h=f[0];h.hidden=g(e.text(),c.ftxt.val()),e.toggleClass("hidden",h.hidden)}).not(".hidden");// Hide opt-groups with no options matched
57
+ c.optDiv[0].querySelectorAll("li.group").forEach(function(a){a.querySelector("li:not(.hidden)")?a.classList.remove("hidden"):a.classList.add("hidden")}),e.html(f.noMatch.replace(/\{0\}/g,"<em></em>")).toggle(!b.length),e.find("em").text(c.ftxt.val()),c.selAllState()})},selAllState:function selAllState(){var b=this;if(f.selectAll&&b.is_multi){var c=0,d=0;b.optDiv.find("li.opt").not(".hidden .disabled").each(function(b,f){a(f).hasClass("selected")&&c++,d++}),c==d?b.selAll.removeClass("partial").addClass("selected"):0===c?b.selAll.removeClass("selected partial"):b.selAll.addClass("partial")}},showOpts:function showOpts(){var b=this;if(!b.E.attr("disabled")){if(b.E.trigger("sumo:opening",b),b.is_opened=!0,b.select.addClass("open").attr("aria-expanded","true"),b.E.trigger("sumo:opened",b),b.ftxt?b.ftxt.focus():b.select.focus(),a(document).on("click.sumo",function(a){if(!b.select.is(a.target)// if the target of the click isn't the container...
58
+ &&0===b.select.has(a.target).length){// ... nor a descendant of the container
59
+ if(!b.is_opened)return;b.hideOpts(),f.okCancelInMulti&&(f.isClickAwayOk?b._okbtn():b._cnbtn())}}),b.is_floating){var c=b.optDiv.children("ul").outerHeight()+2;// +2 is clear fix
60
+ b.is_multi&&(c+=+b.optDiv.css("padding-bottom")),b.optDiv.css("height",c),a("body").addClass("sumoStopScroll")}b.setPstate()}// if select is disabled then retrun
61
+ },//maintain state when ok/cancel buttons are available storing the indexes.
62
+ setPstate:function setPstate(){var a=this;a.is_multi&&(a.is_floating||f.okCancelInMulti)&&(a.Pstate=[],a.E.find("option").each(function(b,c){c.selected&&a.Pstate.push(b)}))},callChange:function callChange(){this.E.get().forEach(function(a){a.dispatchEvent(new Event("change")),a.dispatchEvent(new Event("click"))})},hideOpts:function hideOpts(){var b=this;b.is_opened&&(b.E.trigger("sumo:closing",b),b.is_opened=!1,b.select.removeClass("open").attr("aria-expanded","false").find("ul li.sel").removeClass("sel"),b.E.trigger("sumo:closed",b),a(document).off("click.sumo"),a("body").removeClass("sumoStopScroll"),f.search&&(b.ftxt.val(""),b.ftxt.trigger("keyup.sumo")))},setOnOpen:function setOnOpen(){var a=this,b=a.optDiv.find("li.opt:not(.hidden)").eq(f.search?0:a.E[0].selectedIndex);b.hasClass("disabled")&&(b=b.next(":not(disabled)"),!b.length)||(a.optDiv.find("li.sel").removeClass("sel"),b.addClass("sel"),a.showOpts())},nav:function nav(a){var b=this,d=null,e=b.ul.find("li.opt.sel:not(.hidden)"),f=b.ul.find("li.opt:not(.disabled):not(.hidden)"),g=f.index(e);if(b.is_opened&&e.length){if(a&&0<g)d=f.eq(g-1);else if(!a&&g<f.length-1&&-1<g)d=f.eq(g+1);else return;// if no items before or after
63
+ e.removeClass("sel"),e=d.addClass("sel");// setting sel item to visible view.
64
+ var h=b.ul,i=h.scrollTop(),j=e.position().top+i;j>=i+h.height()-e.outerHeight()&&h.scrollTop(j-h.height()+e.outerHeight()),j<i&&h.scrollTop(j)}else b.setOnOpen()},basicEvents:function basicEvents(){var b=this;b.CaptionCont.click(function(a){b.E.trigger("click"),b.is_opened?b.hideOpts():b.showOpts(),a.stopPropagation()}),b.select.on("keydown.sumo",function(a){switch(a.which){case 38:b.nav(!0);break;case 40:b.nav(!1);break;case 65:// shortcut ctrl + a to select all and ctrl + shift + a to unselect all.
65
+ if(b.is_multi&&!f.max&&a.ctrlKey){b.toggSelAll(!a.shiftKey,1);break}else return;case 32:// space
66
+ if(f.search&&b.ftxt.is(a.target))return;break;case 13:b.is_opened?b.optDiv.find("ul li.sel").trigger("click"):b.setOnOpen();break;case 9:return void(f.okCancelInMulti||b.hideOpts());case 27:return f.okCancelInMulti&&b._cnbtn(),void b.hideOpts();default:return;// exit this handler for other keys
67
+ }a.preventDefault()}),a(window).on("resize.sumo",function(){b.floatingList()})},onOptClick:function onOptClick(b){var c=this;b.click(function(){var b=a(this);b.hasClass("disabled")||(c.is_multi?(b.toggleClass("selected"),b.data("opt")[0].selected=b.hasClass("selected"),!1===b.data("opt")[0].selected?(c.lastUnselected=b.data("opt")[0].textContent,c.selectedCount--):c.selectedCount++,f.max&&c._handleMax(),c.selAllState()):(b.parent().find("li.selected").removeClass("selected"),b.toggleClass("selected"),b.data("opt")[0].selected=!0,c.selectedCount=1),!(c.is_multi&&f.triggerChangeCombined&&(c.is_floating||f.okCancelInMulti))&&(c.setText(),c.callChange()),!c.is_multi&&c.hideOpts())})},// fixed some variables that were not explicitly typed (michc)
68
+ setText:function setText(){var a=this;if(a.placeholder="",a.is_multi){var d=a.E.find(":checked").not(":disabled");//selected options.
69
+ a.placeholder=f.csvDispCount&&d.length>f.csvDispCount?d.length===a.E.find("option").length&&f.captionFormatAllSelected?f.captionFormatAllSelected.replace(/\{0\}/g,d.length):f.captionFormat.replace(/\{0\}/g,d.length):d.toArray().map(function(a){return a.innerText}).join(", ")}else a.placeholder=a.E.find(":checked").not(":disabled").text();var b=!1;a.placeholder||(b=!0,a.placeholder=a.E.attr("placeholder"),!a.placeholder&&(//if placeholder is there then set it
70
+ a.placeholder=a.E.find("option:disabled:checked").text())),a.placeholder=a.placeholder?"".concat(f.prefix," ").concat(a.placeholder):f.placeholder,a.caption.text(a.placeholder),f.showTitle&&a.CaptionCont.attr("title",a.placeholder);//set the hidden field if post as csv is true.
71
+ var c=a.select.find("input.HEMANT123");return c.length&&c.val(a.getSelStr()),b?a.caption.addClass("placeholder"):a.caption.removeClass("placeholder"),a.placeholder},isMobile:function isMobile(){// Adapted from http://www.detectmobilebrowsers.com
72
+ // Checks for iOs, Android, Blackberry, Opera Mini, and Windows mobile devices
73
+ for(var a=navigator.userAgent||navigator.vendor||window.opera,b=0;b<f.nativeOnDevice.length;b++)if(0<a.toString().toLowerCase().indexOf(f.nativeOnDevice[b].toLowerCase()))return f.nativeOnDevice[b];return!1},setNativeMobile:function setNativeMobile(){var a=this;a.E.addClass("SelectClass"),a.mob=!0,a.E.change(function(){a.setText()})},floatingList:function floatingList(){var b=this;//called on init and also on resize.
74
+ //O.is_floating = true if window width is < specified float width
75
+ b.is_floating=a(window).width()<=f.floatWidth,b.optDiv.toggleClass("isFloating",b.is_floating),b.is_floating||b.optDiv.css("height",""),b.optDiv.toggleClass("okCancelInMulti",f.okCancelInMulti&&!b.is_floating)},//HELPERS FOR OUTSIDERS
76
+ // validates range of given item operations
77
+ vRange:function vRange(a){var b=this,c=b.E.find("option");if(c.length<=a||0>a)throw new Error("index out of bounds");return b},//toggles selection on c as boolean.
78
+ toggSel:function toggSel(b,c){var d=this,e=null;"number"==typeof c?(d.vRange(c),e=d.E.find("option")[c]):e=d.E.find("option[value=\"".concat(c,"\"]"))[0]||0,!e||e.disabled||e.selected!==b&&(f.max&&!e.selected&&d.selectedCount<f.max||e.selected||!f.max&&!e.selected)&&(e.selected=b,!d.mob&&a(e).data("li").toggleClass("selected",b),d.callChange(),d.setPstate(),d.setText(),d.selAllState())},//toggles disabled on c as boolean.
79
+ toggDis:function toggDis(a,b){var c=this.vRange(b);c.E.find("option")[b].disabled=a,a&&(c.E.find("option")[b].selected=!1),c.mob||c.optDiv.find("ul.options li.opt").eq(b).toggleClass("disabled",a).removeClass("selected"),c.setText()},// toggle disable/enable on complete select control
80
+ toggSumo:function toggSumo(a){var b=this;return b.enabled=a,b.select.toggleClass("disabled",a),a?(b.E.attr("disabled","disabled"),b.select.removeAttr("tabindex")):(b.E.removeAttr("disabled"),b.select.attr("tabindex","0")),b},// toggles all option on c as boolean.
81
+ // set direct=false/0 bypasses okCancelInMulti behaviour.
82
+ toggSelAll:function toggSelAll(b,c){var d=this,e=a.extend(!0,{},a._data(d.E.get(0),"events"));d.E.off(),d.is_multi?b?d.E.find("option:not(:checked):not(:disabled):not(:hidden)").toArray().forEach(function(b){a(b).data("li").hasClass("hidden")||(b.selected=!0,a(b).data("li").toggleClass("selected",!0))}):d.E.find("option:checked:not(:disabled):not(:hidden)").toArray().forEach(function(b){a(b).data("li").hasClass("hidden")||(b.selected=!1,a(b).data("li").toggleClass("selected",!1))}):b?console.warn("You called `SelectAll` on a non-multiple select"):d.E[0].selectedIndex=-1,a.each(e,function(b,c){a.each(c,function(a,b){d.E.on(b.type,b.handler)})}),d.callChange(),c||(!d.mob&&d.selAll&&d.selAll.removeClass("partial").toggleClass("selected",!!b),d.setText(),d.setPstate())},/* outside accessibility options
83
+ which can be accessed from the element instance.
84
+ */reload:function reload(){var b=this.unload();return a(b).SumoSelect(f)},unload:function unload(){var a=this;return a.select.before(a.E),a.E.show(),a.E[0].classList.remove("SumoUnder"),f.outputAsCSV&&a.is_multi&&a.select.find("input.HEMANT123").length&&a.E.attr("name",a.select.find("input.HEMANT123").attr("name")),a.select.remove(),delete d.sumo,a.E.trigger("sumo:unloaded",a),d},//## add a new option to select at a given index.
85
+ add:function add(b,c,e,f){if("undefined"==typeof b)throw new Error("No value to add");var g=this,h=g.E.find("option"),i=c,j=e;"number"==typ