Version Description
Download this release
Release Info
Developer | webdorado |
Plugin | WD Google Analytics |
Version | 1.2.8 |
Comparing to | |
See all releases |
Code changes from version 1.2.4 to 1.2.8
- admin/pages/browser.php +10 -10
- admin/pages/dashboard.php +2 -2
- admin/pages/dashboard_menu.php +4 -4
- admin/pages/licensing.php +0 -8
- admin/pages/real_time.php +16 -16
- admin/pages/settings.php +2 -2
- admin/pages/uninstall.php +2 -2
- admin/pages/visitors.php +10 -10
- config.php +1 -1
- gawd_class.php +33 -30
- google-analytics-wd.php +10 -11
- inc/css/bootstrap-chosen.css +330 -330
- inc/css/bootstrap-select.css +281 -281
- inc/css/daterangepicker.css +233 -233
- inc/css/font_awesome.css +3 -3
- inc/css/gawd_front.css +4 -4
- inc/css/jquery-ui.css +565 -565
- inc/css/jquery.datetimepicker.css +418 -418
- inc/js/StackBlur.js +654 -654
- inc/js/bootstrap-select.js +1709 -1709
- inc/js/bootstrap.min.js +7 -0
- inc/js/bootstrap_js.js +0 -7
- inc/js/canvg.js +3095 -3095
- inc/js/chosen.jquery.js +1284 -1284
- inc/js/images/lens.svg +6 -6
- inc/js/jquery.cookie.js +117 -117
- inc/js/js_highlight.js +1 -1
- inc/js/loader.js +146 -146
- inc/js/moment.min.js +6 -6
- inc/js/rgbcolor.js +303 -303
- include/gawd_csv_file.php +3 -3
- include/gawd_file.php +6 -6
- include/gawd_pdf_file.php +1 -1
- library/gawd-custom-ajax-class.php +5 -5
- library/gawd-email-class.php +14 -10
- library/gawd-helper-class.php +40 -1
- readme.txt +7 -339
admin/pages/browser.php
CHANGED
@@ -1,10 +1,10 @@
|
|
1 |
-
|
2 |
-
|
3 |
-
<div class="">
|
4 |
-
<div class="opacity_div_compact">
|
5 |
-
<div class="loading_div_compact">
|
6 |
-
<img src="<?php echo GAWD_URL . '/assets/ajax_loader.gif'; ?>" style="margin-top: 200px; width:50px;">
|
7 |
-
</div>
|
8 |
-
</div>
|
9 |
-
<div id="gawd_browser_meta"></div>
|
10 |
-
</div>
|
1 |
+
|
2 |
+
|
3 |
+
<div class="">
|
4 |
+
<div class="opacity_div_compact">
|
5 |
+
<div class="loading_div_compact">
|
6 |
+
<img src="<?php echo GAWD_URL . '/assets/ajax_loader.gif'; ?>" style="margin-top: 200px; width:50px;">
|
7 |
+
</div>
|
8 |
+
</div>
|
9 |
+
<div id="gawd_browser_meta"></div>
|
10 |
+
</div>
|
admin/pages/dashboard.php
CHANGED
@@ -80,10 +80,10 @@ if(in_array($_GET['tab'], $line_column)) {
|
|
80 |
<div class="clear"></div>
|
81 |
<input type="hidden" name='web_property_name' id='web_property_name'/>
|
82 |
</div>
|
83 |
-
<div id="gawd_body" data-gawd-tab="<?php echo $_GET['tab']; ?>">
|
84 |
<?php
|
85 |
include_once('dashboard_menu.php');
|
86 |
-
$page = isset($_GET['tab']) ? $_GET['tab'] : 'overview';
|
87 |
if(strpos($page,'custom_report')!==false){
|
88 |
$tab = $page;
|
89 |
}
|
80 |
<div class="clear"></div>
|
81 |
<input type="hidden" name='web_property_name' id='web_property_name'/>
|
82 |
</div>
|
83 |
+
<div id="gawd_body" data-gawd-tab="<?php echo esc_attr(stripslashes($_GET['tab'])); ?>">
|
84 |
<?php
|
85 |
include_once('dashboard_menu.php');
|
86 |
+
$page = isset($_GET['tab']) ? sanitize_text_field($_GET['tab']) : 'overview';
|
87 |
if(strpos($page,'custom_report')!==false){
|
88 |
$tab = $page;
|
89 |
}
|
admin/pages/dashboard_menu.php
CHANGED
@@ -8,7 +8,7 @@ function gawd_write_menu($tabs, $title = true){
|
|
8 |
$sub_arrow = '';
|
9 |
}
|
10 |
if($tab_data["childs"] == array()) {
|
11 |
-
$active_tab = $_GET['tab'] == $tab_key ? 'gawd_active_li' : '';
|
12 |
/** FREE **/
|
13 |
if($tab_key === "Pro"){
|
14 |
echo ' <li class="gawd_inactive_pro gawd_menu_li '.$active_tab.' " id="gawd_'.$tab_key.'">
|
@@ -57,7 +57,7 @@ function gawd_write_menu($tabs, $title = true){
|
|
57 |
if(!$title) {
|
58 |
$child_title = "";
|
59 |
}
|
60 |
-
$active_tab = $_GET['tab'] == $child_key ? 'gawd_active_li' : '';
|
61 |
if(!in_array($tab_key, $free_tabs)){
|
62 |
echo ' <li class=" gawd_menu_ul_li '.$active_tab.'">
|
63 |
<span class="gawd_menu_item " >'.$child_title.'</span>
|
@@ -84,7 +84,7 @@ function gawd_write_menu_collapse($tabs, $title = true){
|
|
84 |
$sub_arrow = '';
|
85 |
}
|
86 |
if($tab_data["childs"] == array()) {
|
87 |
-
$active_tab = $_GET['tab'] == $tab_key ? 'gawd_active_li' : '';
|
88 |
if($tab_key == 'customReport') {
|
89 |
echo '<a id="gawd_' . $tab_key . '" class="' . $active_tab . ' gawd_menu_item " href="' . admin_url() . 'admin.php?page=gawd_custom_reports">' . $tab_data["title"] . '</a>';
|
90 |
} else {
|
@@ -99,7 +99,7 @@ function gawd_write_menu_collapse($tabs, $title = true){
|
|
99 |
<div class="collapse_ul" id="gawd_' . $tab_key . '_ul">';
|
100 |
}
|
101 |
foreach($tab_data["childs"] as $child_key => $child_title) {
|
102 |
-
$active_tab = $_GET['tab'] == $child_key ? 'gawd_active_li_text' : '';
|
103 |
echo '<a class="' . $active_tab . ' gawd_menu_item " href="' . admin_url() . 'admin.php?page=gawd_reports&tab=' . $child_key . '">' . $child_title . '</a>';
|
104 |
}
|
105 |
echo '</div></span>';
|
8 |
$sub_arrow = '';
|
9 |
}
|
10 |
if($tab_data["childs"] == array()) {
|
11 |
+
$active_tab = sanitize_text_field($_GET['tab']) == $tab_key ? 'gawd_active_li' : '';
|
12 |
/** FREE **/
|
13 |
if($tab_key === "Pro"){
|
14 |
echo ' <li class="gawd_inactive_pro gawd_menu_li '.$active_tab.' " id="gawd_'.$tab_key.'">
|
57 |
if(!$title) {
|
58 |
$child_title = "";
|
59 |
}
|
60 |
+
$active_tab = sanitize_text_field($_GET['tab']) == $child_key ? 'gawd_active_li' : '';
|
61 |
if(!in_array($tab_key, $free_tabs)){
|
62 |
echo ' <li class=" gawd_menu_ul_li '.$active_tab.'">
|
63 |
<span class="gawd_menu_item " >'.$child_title.'</span>
|
84 |
$sub_arrow = '';
|
85 |
}
|
86 |
if($tab_data["childs"] == array()) {
|
87 |
+
$active_tab = sanitize_text_field($_GET['tab']) == $tab_key ? 'gawd_active_li' : '';
|
88 |
if($tab_key == 'customReport') {
|
89 |
echo '<a id="gawd_' . $tab_key . '" class="' . $active_tab . ' gawd_menu_item " href="' . admin_url() . 'admin.php?page=gawd_custom_reports">' . $tab_data["title"] . '</a>';
|
90 |
} else {
|
99 |
<div class="collapse_ul" id="gawd_' . $tab_key . '_ul">';
|
100 |
}
|
101 |
foreach($tab_data["childs"] as $child_key => $child_title) {
|
102 |
+
$active_tab = sanitize_text_field($_GET['tab']) == $child_key ? 'gawd_active_li_text' : '';
|
103 |
echo '<a class="' . $active_tab . ' gawd_menu_item " href="' . admin_url() . 'admin.php?page=gawd_reports&tab=' . $child_key . '">' . $child_title . '</a>';
|
104 |
}
|
105 |
echo '</div></span>';
|
admin/pages/licensing.php
CHANGED
@@ -76,12 +76,4 @@
|
|
76 |
<span class="yes"></span>
|
77 |
<span class="yes"></span>
|
78 |
</div>
|
79 |
-
</div>
|
80 |
-
<div style="float: left; clear: both;">
|
81 |
-
<p><?php _e("After purchasing the commercial version follow these steps:", 'gawd'); ?></p>
|
82 |
-
<ol>
|
83 |
-
<li><?php _e("Deactivate Google Analytics by 10Web plugin.", 'gawd'); ?></li>
|
84 |
-
<li><?php _e("Delete Google Analytics by 10Web plugin.", 'gawd'); ?></li>
|
85 |
-
<li><?php _e("Install the downloaded commercial version of the plugin.", 'gawd'); ?></li>
|
86 |
-
</ol>
|
87 |
</div>
|
76 |
<span class="yes"></span>
|
77 |
<span class="yes"></span>
|
78 |
</div>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
79 |
</div>
|
admin/pages/real_time.php
CHANGED
@@ -1,17 +1,17 @@
|
|
1 |
-
|
2 |
-
|
3 |
-
<div class="">
|
4 |
-
<div class="opacity_div_compact">
|
5 |
-
<div class="loading_div_compact">
|
6 |
-
<img src="<?php echo GAWD_URL . '/assets/ajax_loader.gif'; ?>" style="margin-top: 30px; width:50px;">
|
7 |
-
</div>
|
8 |
-
</div>
|
9 |
-
|
10 |
-
<div id="gawd_real_time_meta"></div>
|
11 |
-
</div>
|
12 |
-
<script>
|
13 |
-
jQuery(document).ready(function(){
|
14 |
-
gawd_widget_real_time('#gawd_real_time_meta');
|
15 |
-
|
16 |
-
})
|
17 |
</script>
|
1 |
+
|
2 |
+
|
3 |
+
<div class="">
|
4 |
+
<div class="opacity_div_compact">
|
5 |
+
<div class="loading_div_compact">
|
6 |
+
<img src="<?php echo GAWD_URL . '/assets/ajax_loader.gif'; ?>" style="margin-top: 30px; width:50px;">
|
7 |
+
</div>
|
8 |
+
</div>
|
9 |
+
|
10 |
+
<div id="gawd_real_time_meta"></div>
|
11 |
+
</div>
|
12 |
+
<script>
|
13 |
+
jQuery(document).ready(function(){
|
14 |
+
gawd_widget_real_time('#gawd_real_time_meta');
|
15 |
+
|
16 |
+
})
|
17 |
</script>
|
admin/pages/settings.php
CHANGED
@@ -618,7 +618,7 @@ if(is_array($gawd_emails)) {
|
|
618 |
</label>
|
619 |
</div>
|
620 |
<div class="gawd_info"
|
621 |
-
title="Click to enable/disable help text for
|
622 |
<div class="onoffswitch_text">
|
623 |
Enable reports tooltips
|
624 |
</div>
|
@@ -637,7 +637,7 @@ if(is_array($gawd_emails)) {
|
|
637 |
title="Turn this option on to get AdSense tracking reports. Make sure to link your Google AdSense to Google Analytics first (find out more in User Guide)"></div>
|
638 |
<div class="onoffswitch_text">
|
639 |
Enable AdSense link tracking
|
640 |
-
<a target="_blank" href="https://10web.io/plugins/wordpress-google-analytics/?utm_source=10web_analytics&utm_medium=free_plugin" class="gawd_pro"> ( This feature is available in
|
641 |
</div>
|
642 |
<div class="clear"></div>
|
643 |
</div>
|
618 |
</label>
|
619 |
</div>
|
620 |
<div class="gawd_info"
|
621 |
+
title="Click to enable/disable help text for 10Web Analytics reports."></div>
|
622 |
<div class="onoffswitch_text">
|
623 |
Enable reports tooltips
|
624 |
</div>
|
637 |
title="Turn this option on to get AdSense tracking reports. Make sure to link your Google AdSense to Google Analytics first (find out more in User Guide)"></div>
|
638 |
<div class="onoffswitch_text">
|
639 |
Enable AdSense link tracking
|
640 |
+
<a target="_blank" href="https://10web.io/plugins/wordpress-google-analytics/?utm_source=10web_analytics&utm_medium=free_plugin" class="gawd_pro"> ( This feature is available in 10Web Analytics Premium. )</a>
|
641 |
</div>
|
642 |
<div class="clear"></div>
|
643 |
</div>
|
admin/pages/uninstall.php
CHANGED
@@ -8,7 +8,7 @@ class GAWDUninstall{
|
|
8 |
<div class="gawd">
|
9 |
<h2>
|
10 |
<img src="<?php echo GAWD_URL . '/assets/uninstall-icon.png';?>" width="30" style="vertical-align:middle;">
|
11 |
-
<span><?php _e("Uninstall
|
12 |
</h2>
|
13 |
<div class="goodbye-text">
|
14 |
<?php
|
@@ -62,7 +62,7 @@ class GAWDUninstall{
|
|
62 |
</p>
|
63 |
<p style="text-align: center;">
|
64 |
<input type="button" id="gawd_uninstall" value="<?php _e("UNINSTALL","gawd"); ?>" onclick="if (check_yes.checked) {
|
65 |
-
if (confirm('You are About to Uninstall
|
66 |
jQuery('#adminForm').submit();;
|
67 |
} else {
|
68 |
return false;
|
8 |
<div class="gawd">
|
9 |
<h2>
|
10 |
<img src="<?php echo GAWD_URL . '/assets/uninstall-icon.png';?>" width="30" style="vertical-align:middle;">
|
11 |
+
<span><?php _e("Uninstall 10Web Analytics","gawd"); ?></span>
|
12 |
</h2>
|
13 |
<div class="goodbye-text">
|
14 |
<?php
|
62 |
</p>
|
63 |
<p style="text-align: center;">
|
64 |
<input type="button" id="gawd_uninstall" value="<?php _e("UNINSTALL","gawd"); ?>" onclick="if (check_yes.checked) {
|
65 |
+
if (confirm('You are About to Uninstall 10Web Analytics from WordPress.\nThis Action Is Not Reversible.')) {
|
66 |
jQuery('#adminForm').submit();;
|
67 |
} else {
|
68 |
return false;
|
admin/pages/visitors.php
CHANGED
@@ -1,10 +1,10 @@
|
|
1 |
-
|
2 |
-
|
3 |
-
<div class="">
|
4 |
-
<div class="opacity_div_compact">
|
5 |
-
<div class="loading_div_compact">
|
6 |
-
<img src="<?php echo GAWD_URL . '/assets/ajax_loader.gif'; ?>" style="margin-top: 200px; width:50px;">
|
7 |
-
</div>
|
8 |
-
</div>
|
9 |
-
<div id="gawd_visitors_meta"></div>
|
10 |
-
</div>
|
1 |
+
|
2 |
+
|
3 |
+
<div class="">
|
4 |
+
<div class="opacity_div_compact">
|
5 |
+
<div class="loading_div_compact">
|
6 |
+
<img src="<?php echo GAWD_URL . '/assets/ajax_loader.gif'; ?>" style="margin-top: 200px; width:50px;">
|
7 |
+
</div>
|
8 |
+
</div>
|
9 |
+
<div id="gawd_visitors_meta"></div>
|
10 |
+
</div>
|
config.php
CHANGED
@@ -13,7 +13,7 @@ if(!defined('GAWD_DIR')) {
|
|
13 |
define('GWD_NAME', plugin_basename(dirname(__FILE__)));
|
14 |
define('GAWD_URL', plugins_url(plugin_basename(dirname(__FILE__))));
|
15 |
define('GAWD_INC', GAWD_URL . '/inc');
|
16 |
-
define('GAWD_VERSION', '1.2.
|
17 |
|
18 |
$upload_dir = wp_upload_dir();
|
19 |
define('GAWD_UPLOAD_DIR', $upload_dir['basedir'] . '/' . plugin_basename(dirname(__FILE__)));
|
13 |
define('GWD_NAME', plugin_basename(dirname(__FILE__)));
|
14 |
define('GAWD_URL', plugins_url(plugin_basename(dirname(__FILE__))));
|
15 |
define('GAWD_INC', GAWD_URL . '/inc');
|
16 |
+
define('GAWD_VERSION', '1.2.8');
|
17 |
|
18 |
$upload_dir = wp_upload_dir();
|
19 |
define('GAWD_UPLOAD_DIR', $upload_dir['basedir'] . '/' . plugin_basename(dirname(__FILE__)));
|
gawd_class.php
CHANGED
@@ -16,7 +16,6 @@ class GAWD {
|
|
16 |
* Singleton via the `new` operator from outside of this class.
|
17 |
*/
|
18 |
protected function __construct(){
|
19 |
-
|
20 |
if(get_site_transient('gawd_uninstall') === '1'){
|
21 |
return;
|
22 |
}
|
@@ -100,7 +99,7 @@ class GAWD {
|
|
100 |
$gawd_props = GAWD_helper::get_current_site_properties();
|
101 |
|
102 |
if(count($gawd_props) === 0 && empty($web_property_id) && strpos($screen->base, 'gawd') !== false && !empty($accounts)) {
|
103 |
-
$msg = "
|
104 |
$this->gawd_admin_notice($msg, "error", 'gawd_tracking_notice_link');
|
105 |
}
|
106 |
}
|
@@ -203,8 +202,8 @@ class GAWD {
|
|
203 |
foreach($profile as $item) {
|
204 |
|
205 |
if($item["id"] === $_POST['gawd_id']) {
|
206 |
-
$gawd_profile_data['profile_id'] = isset($_POST['gawd_id']) ? $_POST['gawd_id'] : '';
|
207 |
-
$gawd_profile_data['web_property_name'] = isset($_POST['web_property_name']) ? $_POST['web_property_name'] : '';
|
208 |
$gawd_profile_data['web_property_id'] = isset($item["webPropertyId"]) ? $item["webPropertyId"] : '';
|
209 |
$gawd_profile_data['account_id'] = isset($item["accountId"]) ? $item["accountId"] : '';
|
210 |
update_option('gawd_last_viewed_profile', $gawd_profile_data);
|
@@ -262,7 +261,7 @@ class GAWD {
|
|
262 |
|
263 |
public function create_pdf_file($ajax = true, $data = null, $dimension = null, $start_date = null, $end_date = null, $metric_compare_recc = null, $metric_recc = null){
|
264 |
$first_data = isset($_REQUEST["first_data"]) ? sanitize_text_field($_REQUEST["first_data"]) : '';
|
265 |
-
$_data_compare = isset($_REQUEST["_data_compare"]) ? ($_REQUEST["_data_compare"]) : '';
|
266 |
if($ajax == true) {
|
267 |
$export_type = isset($_REQUEST["export_type"]) ? sanitize_text_field($_REQUEST["export_type"]) : '';
|
268 |
if($export_type != 'pdf') {
|
@@ -430,11 +429,11 @@ class GAWD {
|
|
430 |
$menu_name = $data['menu_name'];
|
431 |
$info = $data['info'];
|
432 |
} else {
|
433 |
-
$gawd_request_last_args =
|
434 |
-
$compare_by = $_POST['compare_by'];
|
435 |
-
$gawd_compare_request_last_args = (!empty($_POST['gawd_compare_request_last_args'])) ? $_POST['gawd_compare_request_last_args'] : null;
|
436 |
-
$info =
|
437 |
-
$menu_name = $_POST['menu_name'];
|
438 |
}//else set defaults
|
439 |
|
440 |
if(is_array($ajax_response) && !empty($ajax_response)) {
|
@@ -595,8 +594,8 @@ class GAWD {
|
|
595 |
}
|
596 |
} else {
|
597 |
$metric = isset($_REQUEST["gawd_metric"]) ? sanitize_text_field($_REQUEST["gawd_metric"]) : '';
|
598 |
-
$_data_compare = isset($_REQUEST["_data_compare"]) ? ($_REQUEST["_data_compare"]) : '';
|
599 |
-
$first_data = isset($_REQUEST["first_data"]) ? ($_REQUEST["first_data"]) : '';
|
600 |
$view_id = isset($_REQUEST["view_id"]) ? sanitize_text_field($_REQUEST["view_id"]) : '';
|
601 |
$metric_compare = isset($_REQUEST["gawd_metric_compare"]) ? sanitize_text_field($_REQUEST["gawd_metric_compare"]) : '';
|
602 |
$dimension = isset($_REQUEST["gawd_dimension"]) ? sanitize_text_field($_REQUEST["gawd_dimension"]) : '';
|
@@ -864,7 +863,7 @@ class GAWD {
|
|
864 |
wp_enqueue_script('gawd_datatables_ui_js', GAWD_URL . '/inc/js/dataTables.jqueryui.min.js', array('jquery','gawd_charts'), GAWD_VERSION);
|
865 |
|
866 |
if(strpos($screen->post_type, 'page') === false && strpos($screen->post_type, 'post') === false && strpos($screen->base, 'edit') === false) {
|
867 |
-
wp_enqueue_script('bootstrap_js', GAWD_URL . '/inc/js/
|
868 |
wp_enqueue_script('bootstrap-select', GAWD_URL . '/inc/js/bootstrap-select.js', array('jquery'), GAWD_VERSION);
|
869 |
}
|
870 |
wp_enqueue_script('highlight_js', GAWD_URL . '/inc/js/js_highlight.js', array('jquery'), GAWD_VERSION);
|
@@ -1177,7 +1176,7 @@ class GAWD {
|
|
1177 |
|
1178 |
$selected_account_data = $gawd_user_data;
|
1179 |
if(!empty($_POST['web_property_name']) && !empty($_POST['gawd_profile_id'])) {
|
1180 |
-
$selected_account_data['profile_id'] = $_POST['gawd_profile_id'];
|
1181 |
}
|
1182 |
|
1183 |
if(isset($_POST['web_property_name']) && $_POST['web_property_name'] != '') {
|
@@ -1210,7 +1209,7 @@ class GAWD {
|
|
1210 |
if(isset($_POST['gawd_email_remove'])){
|
1211 |
if(isset($_POST['gawd_save_form_fild']) && wp_verify_nonce($_POST['gawd_save_form_fild'], 'gawd_save_form')){
|
1212 |
include_once 'library/gawd-email-class.php';
|
1213 |
-
GAWD_email::delete_email($_POST['gawd_email_remove']);
|
1214 |
}
|
1215 |
}
|
1216 |
|
@@ -1233,16 +1232,20 @@ class GAWD {
|
|
1233 |
}
|
1234 |
|
1235 |
public function gawd_pushover_api($user_key, $metric, $condition, $value){
|
1236 |
-
$
|
1237 |
-
|
1238 |
-
|
1239 |
-
|
1240 |
-
|
1241 |
-
|
1242 |
-
|
1243 |
-
|
1244 |
-
|
1245 |
-
|
|
|
|
|
|
|
|
|
1246 |
}
|
1247 |
|
1248 |
public function gawd_pushover_daily(){
|
@@ -1327,7 +1330,7 @@ class GAWD {
|
|
1327 |
$headers = array();
|
1328 |
$headers[] = 'From: <' . $email_from . '>';
|
1329 |
$headers[] = 'Content-Type: text/html';
|
1330 |
-
$content = '<div style="font-family: sans-serif;width:100%;height:50px;background-color:#FB8583;font-size:20px;color:#fff;margin-bottom:20px;text-align:center;line-height:50px">
|
1331 |
wp_mail($alert['emails'], 'Analytics Alert', $content, $headers);
|
1332 |
}
|
1333 |
}
|
@@ -1353,7 +1356,7 @@ class GAWD {
|
|
1353 |
$headers = array();
|
1354 |
$headers[] = 'From: <' . $email_from . '>';
|
1355 |
$headers[] = 'Content-Type: text/html';
|
1356 |
-
$content = '<div style="font-family: sans-serif;width:100%;height:50px;background-color:#FB8583;font-size:20px;color:#fff;margin-bottom:20px;text-align:center;line-height:50px">
|
1357 |
wp_mail($alert['emails'], 'Analytics Alert', $content, $headers);
|
1358 |
}
|
1359 |
}
|
@@ -1378,7 +1381,7 @@ class GAWD {
|
|
1378 |
$headers = array();
|
1379 |
$headers[] = 'From: <' . $email_from . '>';
|
1380 |
$headers[] = 'Content-Type: text/html';
|
1381 |
-
$content = '<div style="font-family: sans-serif;width:100%;height:50px;background-color:#FB8583;font-size:20px;color:#fff;margin-bottom:20px;text-align:center;line-height:50px">
|
1382 |
wp_mail($alert['emails'], 'Analytics Alert', $content, $headers);
|
1383 |
}
|
1384 |
}
|
@@ -1402,7 +1405,7 @@ class GAWD {
|
|
1402 |
GAWD_helper::check_permission($gawd_backend_roles)
|
1403 |
) {
|
1404 |
|
1405 |
-
wp_add_dashboard_widget('wd_dashboard_widget', '
|
1406 |
$this,
|
1407 |
'wd_dashboard_widget'
|
1408 |
));
|
@@ -1569,7 +1572,7 @@ class GAWD {
|
|
1569 |
|
1570 |
public function nossl_message(){
|
1571 |
$this->gawd_admin_notice(
|
1572 |
-
__('ERROR:
|
1573 |
'error'
|
1574 |
);
|
1575 |
}
|
16 |
* Singleton via the `new` operator from outside of this class.
|
17 |
*/
|
18 |
protected function __construct(){
|
|
|
19 |
if(get_site_transient('gawd_uninstall') === '1'){
|
20 |
return;
|
21 |
}
|
99 |
$gawd_props = GAWD_helper::get_current_site_properties();
|
100 |
|
101 |
if(count($gawd_props) === 0 && empty($web_property_id) && strpos($screen->base, 'gawd') !== false && !empty($accounts)) {
|
102 |
+
$msg = "10Web Analytics: You haven't created a web-property with current site URL, or it has been deleted. Please <a href='" . admin_url() . "admin.php?page=gawd_settings#gawd_tracking_tab'>create </a> one.";
|
103 |
$this->gawd_admin_notice($msg, "error", 'gawd_tracking_notice_link');
|
104 |
}
|
105 |
}
|
202 |
foreach($profile as $item) {
|
203 |
|
204 |
if($item["id"] === $_POST['gawd_id']) {
|
205 |
+
$gawd_profile_data['profile_id'] = isset($_POST['gawd_id']) ? sanitize_text_field($_POST['gawd_id']) : '';
|
206 |
+
$gawd_profile_data['web_property_name'] = isset($_POST['web_property_name']) ? sanitize_text_field($_POST['web_property_name']) : '';
|
207 |
$gawd_profile_data['web_property_id'] = isset($item["webPropertyId"]) ? $item["webPropertyId"] : '';
|
208 |
$gawd_profile_data['account_id'] = isset($item["accountId"]) ? $item["accountId"] : '';
|
209 |
update_option('gawd_last_viewed_profile', $gawd_profile_data);
|
261 |
|
262 |
public function create_pdf_file($ajax = true, $data = null, $dimension = null, $start_date = null, $end_date = null, $metric_compare_recc = null, $metric_recc = null){
|
263 |
$first_data = isset($_REQUEST["first_data"]) ? sanitize_text_field($_REQUEST["first_data"]) : '';
|
264 |
+
$_data_compare = isset($_REQUEST["_data_compare"]) ? sanitize_text_field($_REQUEST["_data_compare"]) : '';
|
265 |
if($ajax == true) {
|
266 |
$export_type = isset($_REQUEST["export_type"]) ? sanitize_text_field($_REQUEST["export_type"]) : '';
|
267 |
if($export_type != 'pdf') {
|
429 |
$menu_name = $data['menu_name'];
|
430 |
$info = $data['info'];
|
431 |
} else {
|
432 |
+
$gawd_request_last_args = GAWD_helper::validate_string('gawd_request_last_args', array());
|
433 |
+
$compare_by = sanitize_text_field($_POST['compare_by']);
|
434 |
+
$gawd_compare_request_last_args = (!empty($_POST['gawd_compare_request_last_args'])) ? sanitize_text_field($_POST['gawd_compare_request_last_args']) : null;
|
435 |
+
$info = GAWD_helper::validate_string("info", array());
|
436 |
+
$menu_name = sanitize_text_field($_POST['menu_name']);
|
437 |
}//else set defaults
|
438 |
|
439 |
if(is_array($ajax_response) && !empty($ajax_response)) {
|
594 |
}
|
595 |
} else {
|
596 |
$metric = isset($_REQUEST["gawd_metric"]) ? sanitize_text_field($_REQUEST["gawd_metric"]) : '';
|
597 |
+
$_data_compare = isset($_REQUEST["_data_compare"]) ? sanitize_text_field($_REQUEST["_data_compare"]) : '';
|
598 |
+
$first_data = isset($_REQUEST["first_data"]) ? sanitize_text_field($_REQUEST["first_data"]) : '';
|
599 |
$view_id = isset($_REQUEST["view_id"]) ? sanitize_text_field($_REQUEST["view_id"]) : '';
|
600 |
$metric_compare = isset($_REQUEST["gawd_metric_compare"]) ? sanitize_text_field($_REQUEST["gawd_metric_compare"]) : '';
|
601 |
$dimension = isset($_REQUEST["gawd_dimension"]) ? sanitize_text_field($_REQUEST["gawd_dimension"]) : '';
|
863 |
wp_enqueue_script('gawd_datatables_ui_js', GAWD_URL . '/inc/js/dataTables.jqueryui.min.js', array('jquery','gawd_charts'), GAWD_VERSION);
|
864 |
|
865 |
if(strpos($screen->post_type, 'page') === false && strpos($screen->post_type, 'post') === false && strpos($screen->base, 'edit') === false) {
|
866 |
+
wp_enqueue_script('bootstrap_js', GAWD_URL . '/inc/js/bootstrap.min.js', array('jquery'), '4.3.1');
|
867 |
wp_enqueue_script('bootstrap-select', GAWD_URL . '/inc/js/bootstrap-select.js', array('jquery'), GAWD_VERSION);
|
868 |
}
|
869 |
wp_enqueue_script('highlight_js', GAWD_URL . '/inc/js/js_highlight.js', array('jquery'), GAWD_VERSION);
|
1176 |
|
1177 |
$selected_account_data = $gawd_user_data;
|
1178 |
if(!empty($_POST['web_property_name']) && !empty($_POST['gawd_profile_id'])) {
|
1179 |
+
$selected_account_data['profile_id'] = sanitize_text_field($_POST['gawd_profile_id']);
|
1180 |
}
|
1181 |
|
1182 |
if(isset($_POST['web_property_name']) && $_POST['web_property_name'] != '') {
|
1209 |
if(isset($_POST['gawd_email_remove'])){
|
1210 |
if(isset($_POST['gawd_save_form_fild']) && wp_verify_nonce($_POST['gawd_save_form_fild'], 'gawd_save_form')){
|
1211 |
include_once 'library/gawd-email-class.php';
|
1212 |
+
GAWD_email::delete_email(sanitize_text_field($_POST['gawd_email_remove']));
|
1213 |
}
|
1214 |
}
|
1215 |
|
1232 |
}
|
1233 |
|
1234 |
public function gawd_pushover_api($user_key, $metric, $condition, $value){
|
1235 |
+
$url = 'https://api.pushover.net/1/messages.json';
|
1236 |
+
$args = array(
|
1237 |
+
'timeout' => 45,
|
1238 |
+
'redirection' => 5,
|
1239 |
+
'blocking' => true,
|
1240 |
+
'headers' => array(),
|
1241 |
+
'body' => array(
|
1242 |
+
"token" => "aJBDhTfhR87EaTzs7wpx1MMKwboBjB",
|
1243 |
+
"user" => $user_key,
|
1244 |
+
"message" => 'The ' . $metric . ' less ' . $value
|
1245 |
+
),
|
1246 |
+
'cookies' => array()
|
1247 |
+
);
|
1248 |
+
wp_remote_post( $url, $args );
|
1249 |
}
|
1250 |
|
1251 |
public function gawd_pushover_daily(){
|
1330 |
$headers = array();
|
1331 |
$headers[] = 'From: <' . $email_from . '>';
|
1332 |
$headers[] = 'Content-Type: text/html';
|
1333 |
+
$content = '<div style="font-family: sans-serif;width:100%;height:50px;background-color:#FB8583;font-size:20px;color:#fff;margin-bottom:20px;text-align:center;line-height:50px">10Web Analytics Alert!</div><p style="color:#808080;text-align: center;font-size: 26px;font-family: sans-serif;">' . preg_replace('!\s+!', ' ', trim(ucfirst(preg_replace('/([A-Z])/', ' $1', $alert['metric'])))) . ' in <a style="text-decoration:none;color:rgba(124,181,216,1);font-family: sans-serif;" href="' . $alert["alert_view_name"] . '" target="_blank">' . $alert["alert_view_name"] . '</a> are <span style="color:' . $color_condition . '">' . $cond . '</span></p><p style="color:rgba(124,181,216,1);font-size: 26px;font-family: sans-serif; text-align: center;">' . $alert['value'] . '</p>';
|
1334 |
wp_mail($alert['emails'], 'Analytics Alert', $content, $headers);
|
1335 |
}
|
1336 |
}
|
1356 |
$headers = array();
|
1357 |
$headers[] = 'From: <' . $email_from . '>';
|
1358 |
$headers[] = 'Content-Type: text/html';
|
1359 |
+
$content = '<div style="font-family: sans-serif;width:100%;height:50px;background-color:#FB8583;font-size:20px;color:#fff;margin-bottom:20px;text-align:center;line-height:50px">10Web Analytics Alert!</div><p style="color:#808080;text-align: center;font-size: 26px;font-family: sans-serif;">' . preg_replace('!\s+!', ' ', trim(ucfirst(preg_replace('/([A-Z])/', ' $1', $alert['metric'])))) . ' in <a style="text-decoration:none;color:rgba(124,181,216,1);font-family: sans-serif;" href="' . $alert["alert_view_name"] . '" target="_blank">' . $alert["alert_view_name"] . '</a> are <span style="color:' . $color_condition . '">' . $cond . '</span></p><p style="color:rgba(124,181,216,1);font-size: 26px;font-family: sans-serif; text-align: center;">' . $alert['value'] . '</p>';
|
1360 |
wp_mail($alert['emails'], 'Analytics Alert', $content, $headers);
|
1361 |
}
|
1362 |
}
|
1381 |
$headers = array();
|
1382 |
$headers[] = 'From: <' . $email_from . '>';
|
1383 |
$headers[] = 'Content-Type: text/html';
|
1384 |
+
$content = '<div style="font-family: sans-serif;width:100%;height:50px;background-color:#FB8583;font-size:20px;color:#fff;margin-bottom:20px;text-align:center;line-height:50px">10Web Analytics Alert!</div><p style="color:#808080;text-align: center;font-size: 26px;font-family: sans-serif;">' . preg_replace('!\s+!', ' ', trim(ucfirst(preg_replace('/([A-Z])/', ' $1', $alert['metric'])))) . ' in <a style="text-decoration:none;color:rgba(124,181,216,1);font-family: sans-serif;" href="' . $alert["alert_view_name"] . '" target="_blank">' . $alert["alert_view_name"] . '</a> are <span style="color:' . $color_condition . '">' . $cond . '</span></p><p style="color:rgba(124,181,216,1);font-size: 26px;font-family: sans-serif; text-align: center;">' . $alert['value'] . '</p>';
|
1385 |
wp_mail($alert['emails'], 'Analytics Alert', $content, $headers);
|
1386 |
}
|
1387 |
}
|
1405 |
GAWD_helper::check_permission($gawd_backend_roles)
|
1406 |
) {
|
1407 |
|
1408 |
+
wp_add_dashboard_widget('wd_dashboard_widget', '10Web Analytics', array(
|
1409 |
$this,
|
1410 |
'wd_dashboard_widget'
|
1411 |
));
|
1572 |
|
1573 |
public function nossl_message(){
|
1574 |
$this->gawd_admin_notice(
|
1575 |
+
__('ERROR: 10Web Analytics cannot make insecure requests to Google API. Please enable PHP OpenSSL extension', 'gawd'),
|
1576 |
'error'
|
1577 |
);
|
1578 |
}
|
google-analytics-wd.php
CHANGED
@@ -1,9 +1,8 @@
|
|
1 |
<?php
|
2 |
/**
|
3 |
-
* Plugin Name:
|
4 |
* Plugin URI: https://10web.io/plugins/wordpress-google-analytics/
|
5 |
-
*
|
6 |
-
* Version: 1.2.4
|
7 |
* Author: 10Web
|
8 |
* Author URI: https://10web.io/plugins/
|
9 |
* License: GNU/GPLv3 http://www.gnu.org/licenses/gpl-3.0.html
|
@@ -42,10 +41,10 @@ if(version_compare(PHP_VERSION, '5.4.0') >= 0) {
|
|
42 |
function gawd_php_version_admin_notice(){
|
43 |
?>
|
44 |
<div class="notice notice-error">
|
45 |
-
<h3>
|
46 |
<p><?php _e('This version of the plugin uses the latest Google library requiring PHP 5.4.0 or higher.', 'gawd'); ?></p>
|
47 |
<p><?php _e('We recommend you to update PHP or ask your hosting provider to do that. ', 'gawd');
|
48 |
-
printf(__('If it is not possible and you previously had
|
49 |
'<a href="https://help.10web.io/hc/en-us/requests/new" target="_blank">' . __('Contact us', 'gawd') . '</a>'
|
50 |
); ?></p>
|
51 |
|
@@ -67,12 +66,12 @@ function gawd_web_init() {
|
|
67 |
"prefix" => "gawd",
|
68 |
"wd_plugin_id" => 158,
|
69 |
"plugin_id" => 45,
|
70 |
-
"plugin_title" => "
|
71 |
"plugin_wordpress_slug" => "wd-google-analytics",
|
72 |
"plugin_dir" => GAWD_DIR,
|
73 |
"plugin_main_file" => __FILE__,
|
74 |
"description" => __('Analytics by 10Web WordPress plugin - a certified member of Google Analytics Technology Partners Program.
|
75 |
-
With a large number of detailed and user-friendly reports,
|
76 |
"addons" => NULL,
|
77 |
"plugin_features" => array(
|
78 |
0 => array(
|
@@ -81,7 +80,7 @@ With a large number of detailed and user-friendly reports, Google Analytics by 1
|
|
81 |
),
|
82 |
1 => array(
|
83 |
"title" => __("All Analytics Reports", "gawd"),
|
84 |
-
"description" => __("
|
85 |
),
|
86 |
2 => array(
|
87 |
"title" => __("Page and Post Reports", "gawd"),
|
@@ -98,7 +97,7 @@ With a large number of detailed and user-friendly reports, Google Analytics by 1
|
|
98 |
),
|
99 |
"user_guide" => array(
|
100 |
0 => array(
|
101 |
-
"main_title" => __("Installing
|
102 |
"url" => "https://help.10web.io/hc/en-us/articles/360017502592-Introducing-WordPress-Google-Analytics",
|
103 |
"titles" => array(),
|
104 |
),
|
@@ -220,7 +219,7 @@ With a large number of detailed and user-friendly reports, Google Analytics by 1
|
|
220 |
|
221 |
add_filter('wp_get_default_privacy_policy_content', 'gawd_privacy_policy');
|
222 |
function gawd_privacy_policy($content){
|
223 |
-
$title = __('
|
224 |
|
225 |
$pp_link = '<a target="_blank" href="https://policies.google.com/privacy">' . __('Privacy Policy', "gawd") . '</a>';
|
226 |
$text = sprintf(__('If you enable tracking code, explain that your site uses Google Analytics. Whether it will send any personal data to Google, depends on how you set up your website. For example, do not expose emails or other personally identifiable information to Google via URLs. Do not send form submissions via analytics to Google. By default, all the IPs of visitors are anonymized. If you change that setting, you must inform your website visitors on that. Personal data processing by Google is explained in their %s.', "gawd"), $pp_link);
|
@@ -295,7 +294,7 @@ if(!function_exists('gawd_wd_bp_install_notice')) {
|
|
295 |
<div class="notice notice-info" id="wd_bp_notice_cont">
|
296 |
<p>
|
297 |
<img id="wd_bp_logo_notice" src="<?php echo $wd_bp_plugin_url . '/assets/seo_logo.png'; ?>">
|
298 |
-
<?php _e("
|
299 |
<a href="https://wordpress.org/plugins/seo-by-10web/" title="<?php _e("More details", $prefix) ?>"
|
300 |
target="_blank"><?php _e("FREE SEO", $prefix) ?></a>
|
301 |
<?php _e("plugin.", $prefix) ?>
|
1 |
<?php
|
2 |
/**
|
3 |
+
* Plugin Name: 10WebAnalytics
|
4 |
* Plugin URI: https://10web.io/plugins/wordpress-google-analytics/
|
5 |
+
* Version: 1.2.8
|
|
|
6 |
* Author: 10Web
|
7 |
* Author URI: https://10web.io/plugins/
|
8 |
* License: GNU/GPLv3 http://www.gnu.org/licenses/gpl-3.0.html
|
41 |
function gawd_php_version_admin_notice(){
|
42 |
?>
|
43 |
<div class="notice notice-error">
|
44 |
+
<h3>10Web Analytics</h3>
|
45 |
<p><?php _e('This version of the plugin uses the latest Google library requiring PHP 5.4.0 or higher.', 'gawd'); ?></p>
|
46 |
<p><?php _e('We recommend you to update PHP or ask your hosting provider to do that. ', 'gawd');
|
47 |
+
printf(__('If it is not possible and you previously had 10Web Analytics Premium version installed, please ask 10Web to send you an older version of the plugin supporting PHP 5.3 %s', 'gawd'),
|
48 |
'<a href="https://help.10web.io/hc/en-us/requests/new" target="_blank">' . __('Contact us', 'gawd') . '</a>'
|
49 |
); ?></p>
|
50 |
|
66 |
"prefix" => "gawd",
|
67 |
"wd_plugin_id" => 158,
|
68 |
"plugin_id" => 45,
|
69 |
+
"plugin_title" => "10Web Analytics",
|
70 |
"plugin_wordpress_slug" => "wd-google-analytics",
|
71 |
"plugin_dir" => GAWD_DIR,
|
72 |
"plugin_main_file" => __FILE__,
|
73 |
"description" => __('Analytics by 10Web WordPress plugin - a certified member of Google Analytics Technology Partners Program.
|
74 |
+
With a large number of detailed and user-friendly reports, 10Web Analytics plugin is just the right choice for you!', 'gawd'),
|
75 |
"addons" => NULL,
|
76 |
"plugin_features" => array(
|
77 |
0 => array(
|
80 |
),
|
81 |
1 => array(
|
82 |
"title" => __("All Analytics Reports", "gawd"),
|
83 |
+
"description" => __("10Web Analytics provides various reports, including Age, Gender, Demographics and Interests, Behavior and Technology, as well as Ecommerce tracking, Custom Dimensions and Custom Reports. Just as in Google Analytics, you can compare tracking reports of two metrics with elegantly designed Line, Pie and Column charts.", "gawd"),
|
84 |
),
|
85 |
2 => array(
|
86 |
"title" => __("Page and Post Reports", "gawd"),
|
97 |
),
|
98 |
"user_guide" => array(
|
99 |
0 => array(
|
100 |
+
"main_title" => __("Installing 10Web Analytics", "gawd"),
|
101 |
"url" => "https://help.10web.io/hc/en-us/articles/360017502592-Introducing-WordPress-Google-Analytics",
|
102 |
"titles" => array(),
|
103 |
),
|
219 |
|
220 |
add_filter('wp_get_default_privacy_policy_content', 'gawd_privacy_policy');
|
221 |
function gawd_privacy_policy($content){
|
222 |
+
$title = __('10Web Analytics', "gawd");
|
223 |
|
224 |
$pp_link = '<a target="_blank" href="https://policies.google.com/privacy">' . __('Privacy Policy', "gawd") . '</a>';
|
225 |
$text = sprintf(__('If you enable tracking code, explain that your site uses Google Analytics. Whether it will send any personal data to Google, depends on how you set up your website. For example, do not expose emails or other personally identifiable information to Google via URLs. Do not send form submissions via analytics to Google. By default, all the IPs of visitors are anonymized. If you change that setting, you must inform your website visitors on that. Personal data processing by Google is explained in their %s.', "gawd"), $pp_link);
|
294 |
<div class="notice notice-info" id="wd_bp_notice_cont">
|
295 |
<p>
|
296 |
<img id="wd_bp_logo_notice" src="<?php echo $wd_bp_plugin_url . '/assets/seo_logo.png'; ?>">
|
297 |
+
<?php _e("10Web Analytics advises: Optimize your web pages for search engines with the", $prefix) ?>
|
298 |
<a href="https://wordpress.org/plugins/seo-by-10web/" title="<?php _e("More details", $prefix) ?>"
|
299 |
target="_blank"><?php _e("FREE SEO", $prefix) ?></a>
|
300 |
<?php _e("plugin.", $prefix) ?>
|
inc/css/bootstrap-chosen.css
CHANGED
@@ -1,330 +1,330 @@
|
|
1 |
-
.chosen-select {
|
2 |
-
width: 100%; }
|
3 |
-
|
4 |
-
.chosen-select-deselect {
|
5 |
-
width: 100%; }
|
6 |
-
|
7 |
-
.chosen-container {
|
8 |
-
display: inline-block;
|
9 |
-
font-size: 14px;
|
10 |
-
position: relative;
|
11 |
-
vertical-align: middle; }
|
12 |
-
.chosen-container .chosen-drop {
|
13 |
-
background: #fff;
|
14 |
-
border: 1px solid #ccc;
|
15 |
-
|
16 |
-
-webkit-box-shadow: 0 8px 8px rgba(0, 0, 0, 0.25);
|
17 |
-
box-shadow: 0 8px 8px rgba(0, 0, 0, 0.25);
|
18 |
-
margin-top: -1px;
|
19 |
-
position: absolute;
|
20 |
-
top: 100%;
|
21 |
-
left: -9000px;
|
22 |
-
z-index: 1060; }
|
23 |
-
.chosen-container.chosen-with-drop .chosen-drop {
|
24 |
-
left: 0;
|
25 |
-
right: 0; }
|
26 |
-
.chosen-container .chosen-results {
|
27 |
-
color: #555555;
|
28 |
-
margin: 0 4px 4px 0;
|
29 |
-
max-height: 240px;
|
30 |
-
padding: 0 0 0 4px;
|
31 |
-
position: relative;
|
32 |
-
overflow-x: hidden;
|
33 |
-
overflow-y: auto;
|
34 |
-
-webkit-overflow-scrolling: touch; }
|
35 |
-
.chosen-container .chosen-results li {
|
36 |
-
display: none;
|
37 |
-
line-height: 1.42857;
|
38 |
-
list-style: none;
|
39 |
-
margin: 0;
|
40 |
-
padding: 5px 6px; }
|
41 |
-
.chosen-container .chosen-results li em {
|
42 |
-
background: #feffde;
|
43 |
-
font-style: normal; }
|
44 |
-
.chosen-container .chosen-results li.group-result {
|
45 |
-
display: list-item;
|
46 |
-
cursor: default;
|
47 |
-
color: #999;
|
48 |
-
font-weight: bold; }
|
49 |
-
.chosen-container .chosen-results li.group-option {
|
50 |
-
padding-left: 15px; }
|
51 |
-
.chosen-container .chosen-results li.active-result {
|
52 |
-
cursor: pointer;
|
53 |
-
display: list-item; }
|
54 |
-
.chosen-container .chosen-results li.highlighted {
|
55 |
-
background-color: #337ab7;
|
56 |
-
background-image: none;
|
57 |
-
color: white; }
|
58 |
-
.chosen-container .chosen-results li.highlighted em {
|
59 |
-
background: transparent; }
|
60 |
-
.chosen-container .chosen-results li.disabled-result {
|
61 |
-
display: list-item;
|
62 |
-
color: #777777; }
|
63 |
-
.chosen-container .chosen-results .no-results {
|
64 |
-
background: #eeeeee;
|
65 |
-
display: list-item; }
|
66 |
-
.chosen-container .chosen-results-scroll {
|
67 |
-
background: white;
|
68 |
-
margin: 0 4px;
|
69 |
-
position: absolute;
|
70 |
-
text-align: center;
|
71 |
-
width: 321px;
|
72 |
-
z-index: 1; }
|
73 |
-
.chosen-container .chosen-results-scroll span {
|
74 |
-
display: inline-block;
|
75 |
-
height: 1.42857;
|
76 |
-
text-indent: -5000px;
|
77 |
-
width: 9px; }
|
78 |
-
.chosen-container .chosen-results-scroll-down {
|
79 |
-
bottom: 0; }
|
80 |
-
.chosen-container .chosen-results-scroll-down span {
|
81 |
-
background: url("chosen-sprite.png") no-repeat -4px -3px; }
|
82 |
-
.chosen-container .chosen-results-scroll-up span {
|
83 |
-
background: url("chosen-sprite.png") no-repeat -22px -3px; }
|
84 |
-
|
85 |
-
.chosen-container-single .chosen-single {
|
86 |
-
background-color: #fff;
|
87 |
-
-webkit-background-clip: padding-box;
|
88 |
-
-moz-background-clip: padding;
|
89 |
-
background-clip: padding-box;
|
90 |
-
border: 1px solid #ccc;
|
91 |
-
|
92 |
-
-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
93 |
-
box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
94 |
-
color: #555555;
|
95 |
-
display: block;
|
96 |
-
height: 34px;
|
97 |
-
overflow: hidden;
|
98 |
-
line-height: 34px;
|
99 |
-
padding: 0 0 0 8px;
|
100 |
-
position: relative;
|
101 |
-
text-decoration: none;
|
102 |
-
white-space: nowrap; }
|
103 |
-
.chosen-container-single .chosen-single span {
|
104 |
-
display: block;
|
105 |
-
margin-right: 26px;
|
106 |
-
overflow: hidden;
|
107 |
-
text-overflow: ellipsis;
|
108 |
-
white-space: nowrap; }
|
109 |
-
.chosen-container-single .chosen-single abbr {
|
110 |
-
background: url("chosen-sprite.png") right top no-repeat;
|
111 |
-
display: block;
|
112 |
-
font-size: 1px;
|
113 |
-
height: 10px;
|
114 |
-
position: absolute;
|
115 |
-
right: 26px;
|
116 |
-
top: 12px;
|
117 |
-
width: 12px; }
|
118 |
-
.chosen-container-single .chosen-single abbr:hover {
|
119 |
-
background-position: right -11px; }
|
120 |
-
.chosen-container-single .chosen-single.chosen-disabled .chosen-single abbr:hover {
|
121 |
-
background-position: right 2px; }
|
122 |
-
.chosen-container-single .chosen-single div {
|
123 |
-
display: block;
|
124 |
-
height: 100%;
|
125 |
-
position: absolute;
|
126 |
-
top: 0;
|
127 |
-
right: 0;
|
128 |
-
width: 18px; }
|
129 |
-
.chosen-container-single .chosen-single div b {
|
130 |
-
background: url("chosen-sprite.png") no-repeat 0 7px;
|
131 |
-
display: block;
|
132 |
-
height: 100%;
|
133 |
-
width: 100%; }
|
134 |
-
.chosen-container-single .chosen-default {
|
135 |
-
color: #777777; }
|
136 |
-
.chosen-container-single .chosen-search {
|
137 |
-
margin: 0;
|
138 |
-
padding: 3px 4px;
|
139 |
-
position: relative;
|
140 |
-
white-space: nowrap;
|
141 |
-
z-index: 1000; }
|
142 |
-
.chosen-container-single .chosen-search input[type="text"] {
|
143 |
-
background: url("chosen-sprite.png") no-repeat 100% -20px, #fff;
|
144 |
-
border: 1px solid #ccc;
|
145 |
-
|
146 |
-
-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
147 |
-
box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
148 |
-
margin: 1px 0;
|
149 |
-
padding: 4px 20px 4px 4px;
|
150 |
-
width: 100%; }
|
151 |
-
.chosen-container-single .chosen-drop {
|
152 |
-
margin-top: -1px;
|
153 |
-
|
154 |
-
-webkit-background-clip: padding-box;
|
155 |
-
-moz-background-clip: padding;
|
156 |
-
background-clip: padding-box; }
|
157 |
-
|
158 |
-
.chosen-container-single-nosearch .chosen-search input[type="text"] {
|
159 |
-
position: absolute;
|
160 |
-
left: -9000px; }
|
161 |
-
|
162 |
-
.chosen-container-multi .chosen-choices {
|
163 |
-
background-color: #fff;
|
164 |
-
border: 1px solid #ccc;
|
165 |
-
height:auto;
|
166 |
-
-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
167 |
-
box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
168 |
-
cursor: text;
|
169 |
-
/* //height: auto !important;
|
170 |
-
//height: 1%; */
|
171 |
-
margin: 0;
|
172 |
-
overflow: hidden;
|
173 |
-
padding: 0;
|
174 |
-
position: relative; }
|
175 |
-
.chosen-container-multi .chosen-choices li {
|
176 |
-
float: left;
|
177 |
-
list-style: none; }
|
178 |
-
.chosen-container-multi .chosen-choices .search-field {
|
179 |
-
margin: 0;
|
180 |
-
padding: 0;
|
181 |
-
white-space: nowrap; }
|
182 |
-
.chosen-container-multi .chosen-choices .search-field input[type="text"] {
|
183 |
-
background: transparent !important;
|
184 |
-
border: 0 !important;
|
185 |
-
-webkit-box-shadow: none;
|
186 |
-
box-shadow: none;
|
187 |
-
color: #555555;
|
188 |
-
height: 28px;
|
189 |
-
margin: 0;
|
190 |
-
padding: 4px;
|
191 |
-
outline: 0; }
|
192 |
-
.chosen-container-multi .chosen-choices .search-field .default {
|
193 |
-
color: #999; }
|
194 |
-
.chosen-container-multi .chosen-choices .search-choice {
|
195 |
-
-webkit-background-clip: padding-box;
|
196 |
-
-moz-background-clip: padding;
|
197 |
-
background-clip: padding-box;
|
198 |
-
background-color: #eeeeee;
|
199 |
-
border: 1px solid #ccc;
|
200 |
-
|
201 |
-
background-image: -webkit-linear-gradient(top, white 0%, #eeeeee 100%);
|
202 |
-
background-image: -o-linear-gradient(top, white 0%, #eeeeee 100%);
|
203 |
-
background-image: linear-gradient(to bottom, white 0%, #eeeeee 100%);
|
204 |
-
background-repeat: repeat-x;
|
205 |
-
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#FFFFFFFF', endColorstr='#FFEEEEEE', GradientType=0);
|
206 |
-
-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
207 |
-
box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
208 |
-
color: #333333;
|
209 |
-
cursor: default;
|
210 |
-
line-height: 13px;
|
211 |
-
margin: 4px 0 3px 5px;
|
212 |
-
padding: 3px 20px 3px 5px;
|
213 |
-
position: relative; }
|
214 |
-
.chosen-container-multi .chosen-choices .search-choice .search-choice-close {
|
215 |
-
background: url("chosen-sprite.png") right top no-repeat;
|
216 |
-
display: block;
|
217 |
-
font-size: 1px;
|
218 |
-
height: 10px;
|
219 |
-
position: absolute;
|
220 |
-
right: 4px;
|
221 |
-
top: 5px;
|
222 |
-
width: 12px;
|
223 |
-
cursor: pointer; }
|
224 |
-
|
225 |
-
.chosen-container-multi .chosen-choices .search-choice-focus {
|
226 |
-
background: #d4d4d4; }
|
227 |
-
.chosen-container-multi .chosen-choices .search-choice-focus .search-choice-close {
|
228 |
-
background-position: right -11px; }
|
229 |
-
.chosen-container-multi .chosen-results {
|
230 |
-
margin: 0 0 0 0;
|
231 |
-
padding: 0; }
|
232 |
-
.chosen-container-multi .chosen-drop .result-selected {
|
233 |
-
display: none; }
|
234 |
-
|
235 |
-
.chosen-container-active .chosen-single {
|
236 |
-
border: 1px solid #66afe9;
|
237 |
-
/* -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset, 0 0 8px #66afe9;
|
238 |
-
box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset, 0 0 8px #66afe9;
|
239 |
-
-webkit-transition: border linear 0.2s, box-shadow linear 0.2s;
|
240 |
-
-o-transition: border linear 0.2s, box-shadow linear 0.2s;
|
241 |
-
transition: border linear 0.2s, box-shadow linear 0.2s;*/ }
|
242 |
-
.chosen-container-active.chosen-with-drop .chosen-single {
|
243 |
-
background-color: #fff;
|
244 |
-
border: 1px solid #66afe9;
|
245 |
-
|
246 |
-
/* -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset, 0 0 8px #66afe9;
|
247 |
-
box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset, 0 0 8px #66afe9;
|
248 |
-
-webkit-transition: border linear 0.2s, box-shadow linear 0.2s;
|
249 |
-
-o-transition: border linear 0.2s, box-shadow linear 0.2s;
|
250 |
-
transition: border linear 0.2s, box-shadow linear 0.2s; */ }
|
251 |
-
.chosen-container-active.chosen-with-drop .chosen-single div {
|
252 |
-
background: transparent;
|
253 |
-
border-left: none; }
|
254 |
-
.chosen-container-active.chosen-with-drop .chosen-single div b {
|
255 |
-
background-position: -18px 7px; }
|
256 |
-
.chosen-container-active .chosen-choices {
|
257 |
-
border: 1px solid #66afe9;
|
258 |
-
border-bottom-right-radius: 0;
|
259 |
-
border-bottom-left-radius: 0;
|
260 |
-
/* -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset, 0 0 8px #66afe9;
|
261 |
-
box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset, 0 0 8px #66afe9;
|
262 |
-
-webkit-transition: border linear 0.2s, box-shadow linear 0.2s;
|
263 |
-
-o-transition: border linear 0.2s, box-shadow linear 0.2s;
|
264 |
-
transition: border linear 0.2s, box-shadow linear 0.2s; */ }
|
265 |
-
.chosen-container-active .chosen-choices .search-field input[type="text"] {
|
266 |
-
color: #111 !important; }
|
267 |
-
.chosen-container-active.chosen-with-drop .chosen-choices {
|
268 |
-
border-bottom-right-radius: 0;
|
269 |
-
border-bottom-left-radius: 0; }
|
270 |
-
|
271 |
-
.chosen-disabled {
|
272 |
-
cursor: default;
|
273 |
-
opacity: 0.5 !important; }
|
274 |
-
.chosen-disabled .chosen-single {
|
275 |
-
cursor: default; }
|
276 |
-
.chosen-disabled .chosen-choices .search-choice .search-choice-close {
|
277 |
-
cursor: default; }
|
278 |
-
|
279 |
-
.chosen-rtl {
|
280 |
-
text-align: right; }
|
281 |
-
.chosen-rtl .chosen-single {
|
282 |
-
padding: 0 8px 0 0;
|
283 |
-
overflow: visible; }
|
284 |
-
.chosen-rtl .chosen-single span {
|
285 |
-
margin-left: 26px;
|
286 |
-
margin-right: 0;
|
287 |
-
direction: rtl; }
|
288 |
-
.chosen-rtl .chosen-single div {
|
289 |
-
left: 7px;
|
290 |
-
right: auto; }
|
291 |
-
.chosen-rtl .chosen-single abbr {
|
292 |
-
left: 26px;
|
293 |
-
right: auto; }
|
294 |
-
.chosen-rtl .chosen-choices .search-field input[type="text"] {
|
295 |
-
direction: rtl; }
|
296 |
-
.chosen-rtl .chosen-choices li {
|
297 |
-
float: right; }
|
298 |
-
.chosen-rtl .chosen-choices .search-choice {
|
299 |
-
margin: 6px 5px 3px 0;
|
300 |
-
padding: 3px 5px 3px 19px; }
|
301 |
-
.chosen-rtl .chosen-choices .search-choice .search-choice-close {
|
302 |
-
background-position: right top;
|
303 |
-
left: 4px;
|
304 |
-
right: auto; }
|
305 |
-
.chosen-rtl.chosen-container-single .chosen-results {
|
306 |
-
margin: 0 0 4px 4px;
|
307 |
-
padding: 0 4px 0 0; }
|
308 |
-
.chosen-rtl .chosen-results .group-option {
|
309 |
-
padding-left: 0;
|
310 |
-
padding-right: 15px; }
|
311 |
-
.chosen-rtl.chosen-container-active.chosen-with-drop .chosen-single div {
|
312 |
-
border-right: none; }
|
313 |
-
.chosen-rtl .chosen-search input[type="text"] {
|
314 |
-
background: url("chosen-sprite.png") no-repeat -28px -20px, #fff;
|
315 |
-
direction: rtl;
|
316 |
-
padding: 4px 5px 4px 20px; }
|
317 |
-
|
318 |
-
@media only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min-resolution: 2dppx) {
|
319 |
-
.chosen-rtl .chosen-search input[type="text"],
|
320 |
-
.chosen-container-single .chosen-single abbr,
|
321 |
-
.chosen-container-single .chosen-single div b,
|
322 |
-
.chosen-container-single .chosen-search input[type="text"],
|
323 |
-
.chosen-container-multi .chosen-choices .search-choice .search-choice-close,
|
324 |
-
.chosen-container .chosen-results-scroll-down span,
|
325 |
-
.chosen-container .chosen-results-scroll-up span {
|
326 |
-
background-image: url("chosen-sprite@2x.png") !important;
|
327 |
-
background-size: 52px 37px !important;
|
328 |
-
background-repeat: no-repeat !important; } }
|
329 |
-
|
330 |
-
/*# sourceMappingURL=bootstrap-chosen.css.map */
|
1 |
+
.chosen-select {
|
2 |
+
width: 100%; }
|
3 |
+
|
4 |
+
.chosen-select-deselect {
|
5 |
+
width: 100%; }
|
6 |
+
|
7 |
+
.chosen-container {
|
8 |
+
display: inline-block;
|
9 |
+
font-size: 14px;
|
10 |
+
position: relative;
|
11 |
+
vertical-align: middle; }
|
12 |
+
.chosen-container .chosen-drop {
|
13 |
+
background: #fff;
|
14 |
+
border: 1px solid #ccc;
|
15 |
+
|
16 |
+
-webkit-box-shadow: 0 8px 8px rgba(0, 0, 0, 0.25);
|
17 |
+
box-shadow: 0 8px 8px rgba(0, 0, 0, 0.25);
|
18 |
+
margin-top: -1px;
|
19 |
+
position: absolute;
|
20 |
+
top: 100%;
|
21 |
+
left: -9000px;
|
22 |
+
z-index: 1060; }
|
23 |
+
.chosen-container.chosen-with-drop .chosen-drop {
|
24 |
+
left: 0;
|
25 |
+
right: 0; }
|
26 |
+
.chosen-container .chosen-results {
|
27 |
+
color: #555555;
|
28 |
+
margin: 0 4px 4px 0;
|
29 |
+
max-height: 240px;
|
30 |
+
padding: 0 0 0 4px;
|
31 |
+
position: relative;
|
32 |
+
overflow-x: hidden;
|
33 |
+
overflow-y: auto;
|
34 |
+
-webkit-overflow-scrolling: touch; }
|
35 |
+
.chosen-container .chosen-results li {
|
36 |
+
display: none;
|
37 |
+
line-height: 1.42857;
|
38 |
+
list-style: none;
|
39 |
+
margin: 0;
|
40 |
+
padding: 5px 6px; }
|
41 |
+
.chosen-container .chosen-results li em {
|
42 |
+
background: #feffde;
|
43 |
+
font-style: normal; }
|
44 |
+
.chosen-container .chosen-results li.group-result {
|
45 |
+
display: list-item;
|
46 |
+
cursor: default;
|
47 |
+
color: #999;
|
48 |
+
font-weight: bold; }
|
49 |
+
.chosen-container .chosen-results li.group-option {
|
50 |
+
padding-left: 15px; }
|
51 |
+
.chosen-container .chosen-results li.active-result {
|
52 |
+
cursor: pointer;
|
53 |
+
display: list-item; }
|
54 |
+
.chosen-container .chosen-results li.highlighted {
|
55 |
+
background-color: #337ab7;
|
56 |
+
background-image: none;
|
57 |
+
color: white; }
|
58 |
+
.chosen-container .chosen-results li.highlighted em {
|
59 |
+
background: transparent; }
|
60 |
+
.chosen-container .chosen-results li.disabled-result {
|
61 |
+
display: list-item;
|
62 |
+
color: #777777; }
|
63 |
+
.chosen-container .chosen-results .no-results {
|
64 |
+
background: #eeeeee;
|
65 |
+
display: list-item; }
|
66 |
+
.chosen-container .chosen-results-scroll {
|
67 |
+
background: white;
|
68 |
+
margin: 0 4px;
|
69 |
+
position: absolute;
|
70 |
+
text-align: center;
|
71 |
+
width: 321px;
|
72 |
+
z-index: 1; }
|
73 |
+
.chosen-container .chosen-results-scroll span {
|
74 |
+
display: inline-block;
|
75 |
+
height: 1.42857;
|
76 |
+
text-indent: -5000px;
|
77 |
+
width: 9px; }
|
78 |
+
.chosen-container .chosen-results-scroll-down {
|
79 |
+
bottom: 0; }
|
80 |
+
.chosen-container .chosen-results-scroll-down span {
|
81 |
+
background: url("chosen-sprite.png") no-repeat -4px -3px; }
|
82 |
+
.chosen-container .chosen-results-scroll-up span {
|
83 |
+
background: url("chosen-sprite.png") no-repeat -22px -3px; }
|
84 |
+
|
85 |
+
.chosen-container-single .chosen-single {
|
86 |
+
background-color: #fff;
|
87 |
+
-webkit-background-clip: padding-box;
|
88 |
+
-moz-background-clip: padding;
|
89 |
+
background-clip: padding-box;
|
90 |
+
border: 1px solid #ccc;
|
91 |
+
|
92 |
+
-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
93 |
+
box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
94 |
+
color: #555555;
|
95 |
+
display: block;
|
96 |
+
height: 34px;
|
97 |
+
overflow: hidden;
|
98 |
+
line-height: 34px;
|
99 |
+
padding: 0 0 0 8px;
|
100 |
+
position: relative;
|
101 |
+
text-decoration: none;
|
102 |
+
white-space: nowrap; }
|
103 |
+
.chosen-container-single .chosen-single span {
|
104 |
+
display: block;
|
105 |
+
margin-right: 26px;
|
106 |
+
overflow: hidden;
|
107 |
+
text-overflow: ellipsis;
|
108 |
+
white-space: nowrap; }
|
109 |
+
.chosen-container-single .chosen-single abbr {
|
110 |
+
background: url("chosen-sprite.png") right top no-repeat;
|
111 |
+
display: block;
|
112 |
+
font-size: 1px;
|
113 |
+
height: 10px;
|
114 |
+
position: absolute;
|
115 |
+
right: 26px;
|
116 |
+
top: 12px;
|
117 |
+
width: 12px; }
|
118 |
+
.chosen-container-single .chosen-single abbr:hover {
|
119 |
+
background-position: right -11px; }
|
120 |
+
.chosen-container-single .chosen-single.chosen-disabled .chosen-single abbr:hover {
|
121 |
+
background-position: right 2px; }
|
122 |
+
.chosen-container-single .chosen-single div {
|
123 |
+
display: block;
|
124 |
+
height: 100%;
|
125 |
+
position: absolute;
|
126 |
+
top: 0;
|
127 |
+
right: 0;
|
128 |
+
width: 18px; }
|
129 |
+
.chosen-container-single .chosen-single div b {
|
130 |
+
background: url("chosen-sprite.png") no-repeat 0 7px;
|
131 |
+
display: block;
|
132 |
+
height: 100%;
|
133 |
+
width: 100%; }
|
134 |
+
.chosen-container-single .chosen-default {
|
135 |
+
color: #777777; }
|
136 |
+
.chosen-container-single .chosen-search {
|
137 |
+
margin: 0;
|
138 |
+
padding: 3px 4px;
|
139 |
+
position: relative;
|
140 |
+
white-space: nowrap;
|
141 |
+
z-index: 1000; }
|
142 |
+
.chosen-container-single .chosen-search input[type="text"] {
|
143 |
+
background: url("chosen-sprite.png") no-repeat 100% -20px, #fff;
|
144 |
+
border: 1px solid #ccc;
|
145 |
+
|
146 |
+
-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
147 |
+
box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
148 |
+
margin: 1px 0;
|
149 |
+
padding: 4px 20px 4px 4px;
|
150 |
+
width: 100%; }
|
151 |
+
.chosen-container-single .chosen-drop {
|
152 |
+
margin-top: -1px;
|
153 |
+
|
154 |
+
-webkit-background-clip: padding-box;
|
155 |
+
-moz-background-clip: padding;
|
156 |
+
background-clip: padding-box; }
|
157 |
+
|
158 |
+
.chosen-container-single-nosearch .chosen-search input[type="text"] {
|
159 |
+
position: absolute;
|
160 |
+
left: -9000px; }
|
161 |
+
|
162 |
+
.chosen-container-multi .chosen-choices {
|
163 |
+
background-color: #fff;
|
164 |
+
border: 1px solid #ccc;
|
165 |
+
height:auto;
|
166 |
+
-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
167 |
+
box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
168 |
+
cursor: text;
|
169 |
+
/* //height: auto !important;
|
170 |
+
//height: 1%; */
|
171 |
+
margin: 0;
|
172 |
+
overflow: hidden;
|
173 |
+
padding: 0;
|
174 |
+
position: relative; }
|
175 |
+
.chosen-container-multi .chosen-choices li {
|
176 |
+
float: left;
|
177 |
+
list-style: none; }
|
178 |
+
.chosen-container-multi .chosen-choices .search-field {
|
179 |
+
margin: 0;
|
180 |
+
padding: 0;
|
181 |
+
white-space: nowrap; }
|
182 |
+
.chosen-container-multi .chosen-choices .search-field input[type="text"] {
|
183 |
+
background: transparent !important;
|
184 |
+
border: 0 !important;
|
185 |
+
-webkit-box-shadow: none;
|
186 |
+
box-shadow: none;
|
187 |
+
color: #555555;
|
188 |
+
height: 28px;
|
189 |
+
margin: 0;
|
190 |
+
padding: 4px;
|
191 |
+
outline: 0; }
|
192 |
+
.chosen-container-multi .chosen-choices .search-field .default {
|
193 |
+
color: #999; }
|
194 |
+
.chosen-container-multi .chosen-choices .search-choice {
|
195 |
+
-webkit-background-clip: padding-box;
|
196 |
+
-moz-background-clip: padding;
|
197 |
+
background-clip: padding-box;
|
198 |
+
background-color: #eeeeee;
|
199 |
+
border: 1px solid #ccc;
|
200 |
+
|
201 |
+
background-image: -webkit-linear-gradient(top, white 0%, #eeeeee 100%);
|
202 |
+
background-image: -o-linear-gradient(top, white 0%, #eeeeee 100%);
|
203 |
+
background-image: linear-gradient(to bottom, white 0%, #eeeeee 100%);
|
204 |
+
background-repeat: repeat-x;
|
205 |
+
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#FFFFFFFF', endColorstr='#FFEEEEEE', GradientType=0);
|
206 |
+
-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
207 |
+
box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
208 |
+
color: #333333;
|
209 |
+
cursor: default;
|
210 |
+
line-height: 13px;
|
211 |
+
margin: 4px 0 3px 5px;
|
212 |
+
padding: 3px 20px 3px 5px;
|
213 |
+
position: relative; }
|
214 |
+
.chosen-container-multi .chosen-choices .search-choice .search-choice-close {
|
215 |
+
background: url("chosen-sprite.png") right top no-repeat;
|
216 |
+
display: block;
|
217 |
+
font-size: 1px;
|
218 |
+
height: 10px;
|
219 |
+
position: absolute;
|
220 |
+
right: 4px;
|
221 |
+
top: 5px;
|
222 |
+
width: 12px;
|
223 |
+
cursor: pointer; }
|
224 |
+
|
225 |
+
.chosen-container-multi .chosen-choices .search-choice-focus {
|
226 |
+
background: #d4d4d4; }
|
227 |
+
.chosen-container-multi .chosen-choices .search-choice-focus .search-choice-close {
|
228 |
+
background-position: right -11px; }
|
229 |
+
.chosen-container-multi .chosen-results {
|
230 |
+
margin: 0 0 0 0;
|
231 |
+
padding: 0; }
|
232 |
+
.chosen-container-multi .chosen-drop .result-selected {
|
233 |
+
display: none; }
|
234 |
+
|
235 |
+
.chosen-container-active .chosen-single {
|
236 |
+
border: 1px solid #66afe9;
|
237 |
+
/* -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset, 0 0 8px #66afe9;
|
238 |
+
box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset, 0 0 8px #66afe9;
|
239 |
+
-webkit-transition: border linear 0.2s, box-shadow linear 0.2s;
|
240 |
+
-o-transition: border linear 0.2s, box-shadow linear 0.2s;
|
241 |
+
transition: border linear 0.2s, box-shadow linear 0.2s;*/ }
|
242 |
+
.chosen-container-active.chosen-with-drop .chosen-single {
|
243 |
+
background-color: #fff;
|
244 |
+
border: 1px solid #66afe9;
|
245 |
+
|
246 |
+
/* -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset, 0 0 8px #66afe9;
|
247 |
+
box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset, 0 0 8px #66afe9;
|
248 |
+
-webkit-transition: border linear 0.2s, box-shadow linear 0.2s;
|
249 |
+
-o-transition: border linear 0.2s, box-shadow linear 0.2s;
|
250 |
+
transition: border linear 0.2s, box-shadow linear 0.2s; */ }
|
251 |
+
.chosen-container-active.chosen-with-drop .chosen-single div {
|
252 |
+
background: transparent;
|
253 |
+
border-left: none; }
|
254 |
+
.chosen-container-active.chosen-with-drop .chosen-single div b {
|
255 |
+
background-position: -18px 7px; }
|
256 |
+
.chosen-container-active .chosen-choices {
|
257 |
+
border: 1px solid #66afe9;
|
258 |
+
border-bottom-right-radius: 0;
|
259 |
+
border-bottom-left-radius: 0;
|
260 |
+
/* -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset, 0 0 8px #66afe9;
|
261 |
+
box-shadow: 0 1px 1px rgba(0, 0, 0, 0.075) inset, 0 0 8px #66afe9;
|
262 |
+
-webkit-transition: border linear 0.2s, box-shadow linear 0.2s;
|
263 |
+
-o-transition: border linear 0.2s, box-shadow linear 0.2s;
|
264 |
+
transition: border linear 0.2s, box-shadow linear 0.2s; */ }
|
265 |
+
.chosen-container-active .chosen-choices .search-field input[type="text"] {
|
266 |
+
color: #111 !important; }
|
267 |
+
.chosen-container-active.chosen-with-drop .chosen-choices {
|
268 |
+
border-bottom-right-radius: 0;
|
269 |
+
border-bottom-left-radius: 0; }
|
270 |
+
|
271 |
+
.chosen-disabled {
|
272 |
+
cursor: default;
|
273 |
+
opacity: 0.5 !important; }
|
274 |
+
.chosen-disabled .chosen-single {
|
275 |
+
cursor: default; }
|
276 |
+
.chosen-disabled .chosen-choices .search-choice .search-choice-close {
|
277 |
+
cursor: default; }
|
278 |
+
|
279 |
+
.chosen-rtl {
|
280 |
+
text-align: right; }
|
281 |
+
.chosen-rtl .chosen-single {
|
282 |
+
padding: 0 8px 0 0;
|
283 |
+
overflow: visible; }
|
284 |
+
.chosen-rtl .chosen-single span {
|
285 |
+
margin-left: 26px;
|
286 |
+
margin-right: 0;
|
287 |
+
direction: rtl; }
|
288 |
+
.chosen-rtl .chosen-single div {
|
289 |
+
left: 7px;
|
290 |
+
right: auto; }
|
291 |
+
.chosen-rtl .chosen-single abbr {
|
292 |
+
left: 26px;
|
293 |
+
right: auto; }
|
294 |
+
.chosen-rtl .chosen-choices .search-field input[type="text"] {
|
295 |
+
direction: rtl; }
|
296 |
+
.chosen-rtl .chosen-choices li {
|
297 |
+
float: right; }
|
298 |
+
.chosen-rtl .chosen-choices .search-choice {
|
299 |
+
margin: 6px 5px 3px 0;
|
300 |
+
padding: 3px 5px 3px 19px; }
|
301 |
+
.chosen-rtl .chosen-choices .search-choice .search-choice-close {
|
302 |
+
background-position: right top;
|
303 |
+
left: 4px;
|
304 |
+
right: auto; }
|
305 |
+
.chosen-rtl.chosen-container-single .chosen-results {
|
306 |
+
margin: 0 0 4px 4px;
|
307 |
+
padding: 0 4px 0 0; }
|
308 |
+
.chosen-rtl .chosen-results .group-option {
|
309 |
+
padding-left: 0;
|
310 |
+
padding-right: 15px; }
|
311 |
+
.chosen-rtl.chosen-container-active.chosen-with-drop .chosen-single div {
|
312 |
+
border-right: none; }
|
313 |
+
.chosen-rtl .chosen-search input[type="text"] {
|
314 |
+
background: url("chosen-sprite.png") no-repeat -28px -20px, #fff;
|
315 |
+
direction: rtl;
|
316 |
+
padding: 4px 5px 4px 20px; }
|
317 |
+
|
318 |
+
@media only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min-resolution: 2dppx) {
|
319 |
+
.chosen-rtl .chosen-search input[type="text"],
|
320 |
+
.chosen-container-single .chosen-single abbr,
|
321 |
+
.chosen-container-single .chosen-single div b,
|
322 |
+
.chosen-container-single .chosen-search input[type="text"],
|
323 |
+
.chosen-container-multi .chosen-choices .search-choice .search-choice-close,
|
324 |
+
.chosen-container .chosen-results-scroll-down span,
|
325 |
+
.chosen-container .chosen-results-scroll-up span {
|
326 |
+
background-image: url("chosen-sprite@2x.png") !important;
|
327 |
+
background-size: 52px 37px !important;
|
328 |
+
background-repeat: no-repeat !important; } }
|
329 |
+
|
330 |
+
/*# sourceMappingURL=bootstrap-chosen.css.map */
|
inc/css/bootstrap-select.css
CHANGED
@@ -1,282 +1,282 @@
|
|
1 |
-
/*!
|
2 |
-
* Bootstrap-select v1.10.0 (http://silviomoreto.github.io/bootstrap-select)
|
3 |
-
*
|
4 |
-
* Copyright 2013-2016 bootstrap-select
|
5 |
-
* Licensed under MIT (https://github.com/silviomoreto/bootstrap-select/blob/master/LICENSE)
|
6 |
-
*/
|
7 |
-
|
8 |
-
select.bs-select-hidden,
|
9 |
-
select.selectpicker {
|
10 |
-
display: none !important;
|
11 |
-
}
|
12 |
-
.bootstrap-select {
|
13 |
-
width: 220px \0;
|
14 |
-
/*IE9 and below*/
|
15 |
-
}
|
16 |
-
.bootstrap-select > .dropdown-toggle {
|
17 |
-
width: 100%;
|
18 |
-
padding-right: 25px;
|
19 |
-
z-index: 1;
|
20 |
-
}
|
21 |
-
.bootstrap-select > select {
|
22 |
-
position: absolute !important;
|
23 |
-
bottom: 0;
|
24 |
-
left: 50%;
|
25 |
-
display: block !important;
|
26 |
-
width: 0.5px !important;
|
27 |
-
height: 100% !important;
|
28 |
-
padding: 0 !important;
|
29 |
-
opacity: 0 !important;
|
30 |
-
border: none;
|
31 |
-
}
|
32 |
-
.bootstrap-select > select.mobile-device {
|
33 |
-
top: 0;
|
34 |
-
left: 0;
|
35 |
-
display: block !important;
|
36 |
-
width: 100% !important;
|
37 |
-
z-index: 2;
|
38 |
-
}
|
39 |
-
.has-error .bootstrap-select .dropdown-toggle,
|
40 |
-
.error .bootstrap-select .dropdown-toggle {
|
41 |
-
border-color: #b94a48;
|
42 |
-
}
|
43 |
-
.bootstrap-select.fit-width {
|
44 |
-
width: auto !important;
|
45 |
-
}
|
46 |
-
.bootstrap-select:not([class*="col-"]):not([class*="form-control"]):not(.input-group-btn) {
|
47 |
-
width: 96%;
|
48 |
-
}
|
49 |
-
.bootstrap-select .dropdown-toggle:focus {
|
50 |
-
outline: thin dotted #333333 !important;
|
51 |
-
outline: 5px auto -webkit-focus-ring-color !important;
|
52 |
-
outline-offset: -2px;
|
53 |
-
}
|
54 |
-
.bootstrap-select.form-control {
|
55 |
-
margin-bottom: 0;
|
56 |
-
padding: 0;
|
57 |
-
border: none;
|
58 |
-
}
|
59 |
-
.bootstrap-select.form-control:not([class*="col-"]) {
|
60 |
-
width: 100%;
|
61 |
-
}
|
62 |
-
.bootstrap-select.form-control.input-group-btn {
|
63 |
-
z-index: auto;
|
64 |
-
}
|
65 |
-
.bootstrap-select.btn-group:not(.input-group-btn),
|
66 |
-
.bootstrap-select.btn-group[class*="col-"] {
|
67 |
-
float: none;
|
68 |
-
display: inline-block;
|
69 |
-
margin-left: 0;
|
70 |
-
}
|
71 |
-
.bootstrap-select.btn-group.dropdown-menu-right,
|
72 |
-
.bootstrap-select.btn-group[class*="col-"].dropdown-menu-right,
|
73 |
-
.row .bootstrap-select.btn-group[class*="col-"].dropdown-menu-right {
|
74 |
-
float: right;
|
75 |
-
}
|
76 |
-
.form-inline .bootstrap-select.btn-group,
|
77 |
-
.form-horizontal .bootstrap-select.btn-group,
|
78 |
-
.form-group .bootstrap-select.btn-group {
|
79 |
-
margin-bottom: 0;
|
80 |
-
}
|
81 |
-
.form-group-lg .bootstrap-select.btn-group.form-control,
|
82 |
-
.form-group-sm .bootstrap-select.btn-group.form-control {
|
83 |
-
padding: 0;
|
84 |
-
}
|
85 |
-
.form-inline .bootstrap-select.btn-group .form-control {
|
86 |
-
width: 100%;
|
87 |
-
}
|
88 |
-
.bootstrap-select.btn-group.disabled,
|
89 |
-
.bootstrap-select.btn-group > .disabled {
|
90 |
-
cursor: not-allowed;
|
91 |
-
}
|
92 |
-
.bootstrap-select.btn-group.disabled:focus,
|
93 |
-
.bootstrap-select.btn-group > .disabled:focus {
|
94 |
-
outline: none !important;
|
95 |
-
}
|
96 |
-
.bootstrap-select.btn-group.bs-container {
|
97 |
-
position: absolute;
|
98 |
-
}
|
99 |
-
.bootstrap-select.btn-group.bs-container .dropdown-menu {
|
100 |
-
z-index: 1060;
|
101 |
-
}
|
102 |
-
.bootstrap-select.btn-group .dropdown-toggle .filter-option {
|
103 |
-
display: inline-block;
|
104 |
-
overflow: hidden;
|
105 |
-
width: 100%;
|
106 |
-
text-align: left;
|
107 |
-
}
|
108 |
-
.bootstrap-select.btn-group .dropdown-toggle .caret {
|
109 |
-
position: absolute;
|
110 |
-
top: 50%;
|
111 |
-
right: 12px;
|
112 |
-
margin-top: -2px;
|
113 |
-
vertical-align: middle;
|
114 |
-
}
|
115 |
-
.bootstrap-select.btn-group[class*="col-"] .dropdown-toggle {
|
116 |
-
width: 100%;
|
117 |
-
}
|
118 |
-
.bootstrap-select.btn-group .dropdown-menu {
|
119 |
-
min-width: 100%;
|
120 |
-
-webkit-box-sizing: border-box;
|
121 |
-
-moz-box-sizing: border-box;
|
122 |
-
box-sizing: border-box;
|
123 |
-
}
|
124 |
-
.bootstrap-select.btn-group .dropdown-menu.inner {
|
125 |
-
position: static;
|
126 |
-
float: none;
|
127 |
-
border: 0;
|
128 |
-
padding: 0;
|
129 |
-
margin: 0;
|
130 |
-
border-radius: 0;
|
131 |
-
-webkit-box-shadow: none;
|
132 |
-
box-shadow: none;
|
133 |
-
}
|
134 |
-
.bootstrap-select.btn-group .dropdown-menu li {
|
135 |
-
position: relative;
|
136 |
-
}
|
137 |
-
.bootstrap-select.btn-group .dropdown-menu li.active small {
|
138 |
-
color: #fff;
|
139 |
-
}
|
140 |
-
.bootstrap-select.btn-group .dropdown-menu li.disabled a {
|
141 |
-
cursor: not-allowed;
|
142 |
-
}
|
143 |
-
.bootstrap-select.btn-group .dropdown-menu li a {
|
144 |
-
cursor: pointer;
|
145 |
-
-webkit-user-select: none;
|
146 |
-
-moz-user-select: none;
|
147 |
-
-ms-user-select: none;
|
148 |
-
user-select: none;
|
149 |
-
}
|
150 |
-
.bootstrap-select.btn-group .dropdown-menu li a.opt {
|
151 |
-
position: relative;
|
152 |
-
padding-left: 2.25em;
|
153 |
-
}
|
154 |
-
.bootstrap-select.btn-group .dropdown-menu li a span.check-mark {
|
155 |
-
display: none;
|
156 |
-
}
|
157 |
-
.bootstrap-select.btn-group .dropdown-menu li a span.text {
|
158 |
-
display: inline-block;
|
159 |
-
}
|
160 |
-
.bootstrap-select.btn-group .dropdown-menu li small {
|
161 |
-
padding-left: 0.5em;
|
162 |
-
}
|
163 |
-
.bootstrap-select.btn-group .dropdown-menu .notify {
|
164 |
-
position: absolute;
|
165 |
-
bottom: 5px;
|
166 |
-
width: 96%;
|
167 |
-
margin: 0 2%;
|
168 |
-
min-height: 26px;
|
169 |
-
padding: 3px 5px;
|
170 |
-
background: #f5f5f5;
|
171 |
-
border: 1px solid #e3e3e3;
|
172 |
-
-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);
|
173 |
-
box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);
|
174 |
-
pointer-events: none;
|
175 |
-
opacity: 0.9;
|
176 |
-
-webkit-box-sizing: border-box;
|
177 |
-
-moz-box-sizing: border-box;
|
178 |
-
box-sizing: border-box;
|
179 |
-
}
|
180 |
-
.bootstrap-select.btn-group .no-results {
|
181 |
-
padding: 3px;
|
182 |
-
background: #f5f5f5;
|
183 |
-
margin: 0 5px;
|
184 |
-
white-space: nowrap;
|
185 |
-
}
|
186 |
-
.bootstrap-select.btn-group.fit-width .dropdown-toggle .filter-option {
|
187 |
-
position: static;
|
188 |
-
}
|
189 |
-
.bootstrap-select.btn-group.fit-width .dropdown-toggle .caret {
|
190 |
-
position: static;
|
191 |
-
top: auto;
|
192 |
-
margin-top: -1px;
|
193 |
-
}
|
194 |
-
.bootstrap-select.btn-group.show-tick .dropdown-menu li.selected a span.check-mark {
|
195 |
-
position: absolute;
|
196 |
-
display: inline-block;
|
197 |
-
right: 15px;
|
198 |
-
margin-top: 5px;
|
199 |
-
}
|
200 |
-
.bootstrap-select.btn-group.show-tick .dropdown-menu li a span.text {
|
201 |
-
margin-right: 34px;
|
202 |
-
}
|
203 |
-
.bootstrap-select.show-menu-arrow.open > .dropdown-toggle {
|
204 |
-
z-index: 1061;
|
205 |
-
}
|
206 |
-
.bootstrap-select.show-menu-arrow .dropdown-toggle:before {
|
207 |
-
content: '';
|
208 |
-
border-left: 7px solid transparent;
|
209 |
-
border-right: 7px solid transparent;
|
210 |
-
border-bottom: 7px solid rgba(204, 204, 204, 0.2);
|
211 |
-
position: absolute;
|
212 |
-
bottom: -4px;
|
213 |
-
left: 9px;
|
214 |
-
display: none;
|
215 |
-
}
|
216 |
-
.bootstrap-select.show-menu-arrow .dropdown-toggle:after {
|
217 |
-
content: '';
|
218 |
-
border-left: 6px solid transparent;
|
219 |
-
border-right: 6px solid transparent;
|
220 |
-
border-bottom: 6px solid white;
|
221 |
-
position: absolute;
|
222 |
-
bottom: -4px;
|
223 |
-
left: 10px;
|
224 |
-
display: none;
|
225 |
-
}
|
226 |
-
.bootstrap-select.show-menu-arrow.dropup .dropdown-toggle:before {
|
227 |
-
bottom: auto;
|
228 |
-
top: -3px;
|
229 |
-
border-top: 7px solid rgba(204, 204, 204, 0.2);
|
230 |
-
border-bottom: 0;
|
231 |
-
}
|
232 |
-
.bootstrap-select.show-menu-arrow.dropup .dropdown-toggle:after {
|
233 |
-
bottom: auto;
|
234 |
-
top: -3px;
|
235 |
-
border-top: 6px solid white;
|
236 |
-
border-bottom: 0;
|
237 |
-
}
|
238 |
-
.bootstrap-select.show-menu-arrow.pull-right .dropdown-toggle:before {
|
239 |
-
right: 12px;
|
240 |
-
left: auto;
|
241 |
-
}
|
242 |
-
.bootstrap-select.show-menu-arrow.pull-right .dropdown-toggle:after {
|
243 |
-
right: 13px;
|
244 |
-
left: auto;
|
245 |
-
}
|
246 |
-
.bootstrap-select.show-menu-arrow.open > .dropdown-toggle:before,
|
247 |
-
.bootstrap-select.show-menu-arrow.open > .dropdown-toggle:after {
|
248 |
-
display: block;
|
249 |
-
}
|
250 |
-
.bs-searchbox,
|
251 |
-
.bs-actionsbox,
|
252 |
-
.bs-donebutton {
|
253 |
-
padding: 4px 8px;
|
254 |
-
}
|
255 |
-
.bs-actionsbox {
|
256 |
-
width: 100%;
|
257 |
-
-webkit-box-sizing: border-box;
|
258 |
-
-moz-box-sizing: border-box;
|
259 |
-
box-sizing: border-box;
|
260 |
-
}
|
261 |
-
.bs-actionsbox .btn-group button {
|
262 |
-
width: 50%;
|
263 |
-
}
|
264 |
-
.bs-donebutton {
|
265 |
-
float: left;
|
266 |
-
width: 100%;
|
267 |
-
-webkit-box-sizing: border-box;
|
268 |
-
-moz-box-sizing: border-box;
|
269 |
-
box-sizing: border-box;
|
270 |
-
}
|
271 |
-
.bs-donebutton .btn-group button {
|
272 |
-
width: 100%;
|
273 |
-
}
|
274 |
-
.bs-searchbox + .bs-actionsbox {
|
275 |
-
padding: 0 8px 4px;
|
276 |
-
}
|
277 |
-
.bs-searchbox .form-control {
|
278 |
-
margin-bottom: 0;
|
279 |
-
width: 100%;
|
280 |
-
float: none;
|
281 |
-
}
|
282 |
/*# sourceMappingURL=bootstrap-select.css.map */
|
1 |
+
/*!
|
2 |
+
* Bootstrap-select v1.10.0 (http://silviomoreto.github.io/bootstrap-select)
|
3 |
+
*
|
4 |
+
* Copyright 2013-2016 bootstrap-select
|
5 |
+
* Licensed under MIT (https://github.com/silviomoreto/bootstrap-select/blob/master/LICENSE)
|
6 |
+
*/
|
7 |
+
|
8 |
+
select.bs-select-hidden,
|
9 |
+
select.selectpicker {
|
10 |
+
display: none !important;
|
11 |
+
}
|
12 |
+
.bootstrap-select {
|
13 |
+
width: 220px \0;
|
14 |
+
/*IE9 and below*/
|
15 |
+
}
|
16 |
+
.bootstrap-select > .dropdown-toggle {
|
17 |
+
width: 100%;
|
18 |
+
padding-right: 25px;
|
19 |
+
z-index: 1;
|
20 |
+
}
|
21 |
+
.bootstrap-select > select {
|
22 |
+
position: absolute !important;
|
23 |
+
bottom: 0;
|
24 |
+
left: 50%;
|
25 |
+
display: block !important;
|
26 |
+
width: 0.5px !important;
|
27 |
+
height: 100% !important;
|
28 |
+
padding: 0 !important;
|
29 |
+
opacity: 0 !important;
|
30 |
+
border: none;
|
31 |
+
}
|
32 |
+
.bootstrap-select > select.mobile-device {
|
33 |
+
top: 0;
|
34 |
+
left: 0;
|
35 |
+
display: block !important;
|
36 |
+
width: 100% !important;
|
37 |
+
z-index: 2;
|
38 |
+
}
|
39 |
+
.has-error .bootstrap-select .dropdown-toggle,
|
40 |
+
.error .bootstrap-select .dropdown-toggle {
|
41 |
+
border-color: #b94a48;
|
42 |
+
}
|
43 |
+
.bootstrap-select.fit-width {
|
44 |
+
width: auto !important;
|
45 |
+
}
|
46 |
+
.bootstrap-select:not([class*="col-"]):not([class*="form-control"]):not(.input-group-btn) {
|
47 |
+
width: 96%;
|
48 |
+
}
|
49 |
+
.bootstrap-select .dropdown-toggle:focus {
|
50 |
+
outline: thin dotted #333333 !important;
|
51 |
+
outline: 5px auto -webkit-focus-ring-color !important;
|
52 |
+
outline-offset: -2px;
|
53 |
+
}
|
54 |
+
.bootstrap-select.form-control {
|
55 |
+
margin-bottom: 0;
|
56 |
+
padding: 0;
|
57 |
+
border: none;
|
58 |
+
}
|
59 |
+
.bootstrap-select.form-control:not([class*="col-"]) {
|
60 |
+
width: 100%;
|
61 |
+
}
|
62 |
+
.bootstrap-select.form-control.input-group-btn {
|
63 |
+
z-index: auto;
|
64 |
+
}
|
65 |
+
.bootstrap-select.btn-group:not(.input-group-btn),
|
66 |
+
.bootstrap-select.btn-group[class*="col-"] {
|
67 |
+
float: none;
|
68 |
+
display: inline-block;
|
69 |
+
margin-left: 0;
|
70 |
+
}
|
71 |
+
.bootstrap-select.btn-group.dropdown-menu-right,
|
72 |
+
.bootstrap-select.btn-group[class*="col-"].dropdown-menu-right,
|
73 |
+
.row .bootstrap-select.btn-group[class*="col-"].dropdown-menu-right {
|
74 |
+
float: right;
|
75 |
+
}
|
76 |
+
.form-inline .bootstrap-select.btn-group,
|
77 |
+
.form-horizontal .bootstrap-select.btn-group,
|
78 |
+
.form-group .bootstrap-select.btn-group {
|
79 |
+
margin-bottom: 0;
|
80 |
+
}
|
81 |
+
.form-group-lg .bootstrap-select.btn-group.form-control,
|
82 |
+
.form-group-sm .bootstrap-select.btn-group.form-control {
|
83 |
+
padding: 0;
|
84 |
+
}
|
85 |
+
.form-inline .bootstrap-select.btn-group .form-control {
|
86 |
+
width: 100%;
|
87 |
+
}
|
88 |
+
.bootstrap-select.btn-group.disabled,
|
89 |
+
.bootstrap-select.btn-group > .disabled {
|
90 |
+
cursor: not-allowed;
|
91 |
+
}
|
92 |
+
.bootstrap-select.btn-group.disabled:focus,
|
93 |
+
.bootstrap-select.btn-group > .disabled:focus {
|
94 |
+
outline: none !important;
|
95 |
+
}
|
96 |
+
.bootstrap-select.btn-group.bs-container {
|
97 |
+
position: absolute;
|
98 |
+
}
|
99 |
+
.bootstrap-select.btn-group.bs-container .dropdown-menu {
|
100 |
+
z-index: 1060;
|
101 |
+
}
|
102 |
+
.bootstrap-select.btn-group .dropdown-toggle .filter-option {
|
103 |
+
display: inline-block;
|
104 |
+
overflow: hidden;
|
105 |
+
width: 100%;
|
106 |
+
text-align: left;
|
107 |
+
}
|
108 |
+
.bootstrap-select.btn-group .dropdown-toggle .caret {
|
109 |
+
position: absolute;
|
110 |
+
top: 50%;
|
111 |
+
right: 12px;
|
112 |
+
margin-top: -2px;
|
113 |
+
vertical-align: middle;
|
114 |
+
}
|
115 |
+
.bootstrap-select.btn-group[class*="col-"] .dropdown-toggle {
|
116 |
+
width: 100%;
|
117 |
+
}
|
118 |
+
.bootstrap-select.btn-group .dropdown-menu {
|
119 |
+
min-width: 100%;
|
120 |
+
-webkit-box-sizing: border-box;
|
121 |
+
-moz-box-sizing: border-box;
|
122 |
+
box-sizing: border-box;
|
123 |
+
}
|
124 |
+
.bootstrap-select.btn-group .dropdown-menu.inner {
|
125 |
+
position: static;
|
126 |
+
float: none;
|
127 |
+
border: 0;
|
128 |
+
padding: 0;
|
129 |
+
margin: 0;
|
130 |
+
border-radius: 0;
|
131 |
+
-webkit-box-shadow: none;
|
132 |
+
box-shadow: none;
|
133 |
+
}
|
134 |
+
.bootstrap-select.btn-group .dropdown-menu li {
|
135 |
+
position: relative;
|
136 |
+
}
|
137 |
+
.bootstrap-select.btn-group .dropdown-menu li.active small {
|
138 |
+
color: #fff;
|
139 |
+
}
|
140 |
+
.bootstrap-select.btn-group .dropdown-menu li.disabled a {
|
141 |
+
cursor: not-allowed;
|
142 |
+
}
|
143 |
+
.bootstrap-select.btn-group .dropdown-menu li a {
|
144 |
+
cursor: pointer;
|
145 |
+
-webkit-user-select: none;
|
146 |
+
-moz-user-select: none;
|
147 |
+
-ms-user-select: none;
|
148 |
+
user-select: none;
|
149 |
+
}
|
150 |
+
.bootstrap-select.btn-group .dropdown-menu li a.opt {
|
151 |
+
position: relative;
|
152 |
+
padding-left: 2.25em;
|
153 |
+
}
|
154 |
+
.bootstrap-select.btn-group .dropdown-menu li a span.check-mark {
|
155 |
+
display: none;
|
156 |
+
}
|
157 |
+
.bootstrap-select.btn-group .dropdown-menu li a span.text {
|
158 |
+
display: inline-block;
|
159 |
+
}
|
160 |
+
.bootstrap-select.btn-group .dropdown-menu li small {
|
161 |
+
padding-left: 0.5em;
|
162 |
+
}
|
163 |
+
.bootstrap-select.btn-group .dropdown-menu .notify {
|
164 |
+
position: absolute;
|
165 |
+
bottom: 5px;
|
166 |
+
width: 96%;
|
167 |
+
margin: 0 2%;
|
168 |
+
min-height: 26px;
|
169 |
+
padding: 3px 5px;
|
170 |
+
background: #f5f5f5;
|
171 |
+
border: 1px solid #e3e3e3;
|
172 |
+
-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);
|
173 |
+
box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);
|
174 |
+
pointer-events: none;
|
175 |
+
opacity: 0.9;
|
176 |
+
-webkit-box-sizing: border-box;
|
177 |
+
-moz-box-sizing: border-box;
|
178 |
+
box-sizing: border-box;
|
179 |
+
}
|
180 |
+
.bootstrap-select.btn-group .no-results {
|
181 |
+
padding: 3px;
|
182 |
+
background: #f5f5f5;
|
183 |
+
margin: 0 5px;
|
184 |
+
white-space: nowrap;
|
185 |
+
}
|
186 |
+
.bootstrap-select.btn-group.fit-width .dropdown-toggle .filter-option {
|
187 |
+
position: static;
|
188 |
+
}
|
189 |
+
.bootstrap-select.btn-group.fit-width .dropdown-toggle .caret {
|
190 |
+
position: static;
|
191 |
+
top: auto;
|
192 |
+
margin-top: -1px;
|
193 |
+
}
|
194 |
+
.bootstrap-select.btn-group.show-tick .dropdown-menu li.selected a span.check-mark {
|
195 |
+
position: absolute;
|
196 |
+
display: inline-block;
|
197 |
+
right: 15px;
|
198 |
+
margin-top: 5px;
|
199 |
+
}
|
200 |
+
.bootstrap-select.btn-group.show-tick .dropdown-menu li a span.text {
|
201 |
+
margin-right: 34px;
|
202 |
+
}
|
203 |
+
.bootstrap-select.show-menu-arrow.open > .dropdown-toggle {
|
204 |
+
z-index: 1061;
|
205 |
+
}
|
206 |
+
.bootstrap-select.show-menu-arrow .dropdown-toggle:before {
|
207 |
+
content: '';
|
208 |
+
border-left: 7px solid transparent;
|
209 |
+
border-right: 7px solid transparent;
|
210 |
+
border-bottom: 7px solid rgba(204, 204, 204, 0.2);
|
211 |
+
position: absolute;
|
212 |
+
bottom: -4px;
|
213 |
+
left: 9px;
|
214 |
+
display: none;
|
215 |
+
}
|
216 |
+
.bootstrap-select.show-menu-arrow .dropdown-toggle:after {
|
217 |
+
content: '';
|
218 |
+
border-left: 6px solid transparent;
|
219 |
+
border-right: 6px solid transparent;
|
220 |
+
border-bottom: 6px solid white;
|
221 |
+
position: absolute;
|
222 |
+
bottom: -4px;
|
223 |
+
left: 10px;
|
224 |
+
display: none;
|
225 |
+
}
|
226 |
+
.bootstrap-select.show-menu-arrow.dropup .dropdown-toggle:before {
|
227 |
+
bottom: auto;
|
228 |
+
top: -3px;
|
229 |
+
border-top: 7px solid rgba(204, 204, 204, 0.2);
|
230 |
+
border-bottom: 0;
|
231 |
+
}
|
232 |
+
.bootstrap-select.show-menu-arrow.dropup .dropdown-toggle:after {
|
233 |
+
bottom: auto;
|
234 |
+
top: -3px;
|
235 |
+
border-top: 6px solid white;
|
236 |
+
border-bottom: 0;
|
237 |
+
}
|
238 |
+
.bootstrap-select.show-menu-arrow.pull-right .dropdown-toggle:before {
|
239 |
+
right: 12px;
|
240 |
+
left: auto;
|
241 |
+
}
|
242 |
+
.bootstrap-select.show-menu-arrow.pull-right .dropdown-toggle:after {
|
243 |
+
right: 13px;
|
244 |
+
left: auto;
|
245 |
+
}
|
246 |
+
.bootstrap-select.show-menu-arrow.open > .dropdown-toggle:before,
|
247 |
+
.bootstrap-select.show-menu-arrow.open > .dropdown-toggle:after {
|
248 |
+
display: block;
|
249 |
+
}
|
250 |
+
.bs-searchbox,
|
251 |
+
.bs-actionsbox,
|
252 |
+
.bs-donebutton {
|
253 |
+
padding: 4px 8px;
|
254 |
+
}
|
255 |
+
.bs-actionsbox {
|
256 |
+
width: 100%;
|
257 |
+
-webkit-box-sizing: border-box;
|
258 |
+
-moz-box-sizing: border-box;
|
259 |
+
box-sizing: border-box;
|
260 |
+
}
|
261 |
+
.bs-actionsbox .btn-group button {
|
262 |
+
width: 50%;
|
263 |
+
}
|
264 |
+
.bs-donebutton {
|
265 |
+
float: left;
|
266 |
+
width: 100%;
|
267 |
+
-webkit-box-sizing: border-box;
|
268 |
+
-moz-box-sizing: border-box;
|
269 |
+
box-sizing: border-box;
|
270 |
+
}
|
271 |
+
.bs-donebutton .btn-group button {
|
272 |
+
width: 100%;
|
273 |
+
}
|
274 |
+
.bs-searchbox + .bs-actionsbox {
|
275 |
+
padding: 0 8px 4px;
|
276 |
+
}
|
277 |
+
.bs-searchbox .form-control {
|
278 |
+
margin-bottom: 0;
|
279 |
+
width: 100%;
|
280 |
+
float: none;
|
281 |
+
}
|
282 |
/*# sourceMappingURL=bootstrap-select.css.map */
|
inc/css/daterangepicker.css
CHANGED
@@ -1,233 +1,233 @@
|
|
1 |
-
.daterangepicker {
|
2 |
-
position: absolute;
|
3 |
-
color: inherit;
|
4 |
-
background: #fff;
|
5 |
-
border-radius: 4px;
|
6 |
-
width: 278px;
|
7 |
-
padding: 4px;
|
8 |
-
margin-top: 1px;
|
9 |
-
top: 100px;
|
10 |
-
left: 20px;
|
11 |
-
/* Calendars */ }
|
12 |
-
.daterangepicker:before, .daterangepicker:after {
|
13 |
-
position: absolute;
|
14 |
-
display: inline-block;
|
15 |
-
border-bottom-color: rgba(0, 0, 0, 0.2);
|
16 |
-
content: ''; }
|
17 |
-
.daterangepicker:before {
|
18 |
-
top: -7px;
|
19 |
-
border-right: 7px solid transparent;
|
20 |
-
border-left: 7px solid transparent;
|
21 |
-
border-bottom: 7px solid #ccc; }
|
22 |
-
.daterangepicker:after {
|
23 |
-
top: -6px;
|
24 |
-
border-right: 6px solid transparent;
|
25 |
-
border-bottom: 6px solid #fff;
|
26 |
-
border-left: 6px solid transparent; }
|
27 |
-
.daterangepicker.opensleft:before {
|
28 |
-
right: 9px; }
|
29 |
-
.daterangepicker.opensleft:after {
|
30 |
-
right: 10px; }
|
31 |
-
.daterangepicker.openscenter:before {
|
32 |
-
left: 0;
|
33 |
-
right: 0;
|
34 |
-
width: 0;
|
35 |
-
margin-left: auto;
|
36 |
-
margin-right: auto; }
|
37 |
-
.daterangepicker.openscenter:after {
|
38 |
-
left: 0;
|
39 |
-
right: 0;
|
40 |
-
width: 0;
|
41 |
-
margin-left: auto;
|
42 |
-
margin-right: auto; }
|
43 |
-
.daterangepicker.opensright:before {
|
44 |
-
left: 9px; }
|
45 |
-
.daterangepicker.opensright:after {
|
46 |
-
left: 10px; }
|
47 |
-
.daterangepicker.dropup {
|
48 |
-
margin-top: -5px; }
|
49 |
-
.daterangepicker.dropup:before {
|
50 |
-
top: initial;
|
51 |
-
bottom: -7px;
|
52 |
-
border-bottom: initial;
|
53 |
-
border-top: 7px solid #ccc; }
|
54 |
-
.daterangepicker.dropup:after {
|
55 |
-
top: initial;
|
56 |
-
bottom: -6px;
|
57 |
-
border-bottom: initial;
|
58 |
-
border-top: 6px solid #fff; }
|
59 |
-
.daterangepicker.dropdown-menu {
|
60 |
-
max-width: none;
|
61 |
-
z-index: 3001; }
|
62 |
-
.daterangepicker.single .ranges, .daterangepicker.single .calendar {
|
63 |
-
float: none; }
|
64 |
-
.daterangepicker.show-calendar .calendar {
|
65 |
-
display: block; }
|
66 |
-
.daterangepicker .calendar {
|
67 |
-
display: none;
|
68 |
-
max-width: 270px;
|
69 |
-
margin: 4px; }
|
70 |
-
.daterangepicker .calendar.single .calendar-table {
|
71 |
-
border: none; }
|
72 |
-
.daterangepicker .calendar th, .daterangepicker .calendar td {
|
73 |
-
white-space: nowrap;
|
74 |
-
text-align: center;
|
75 |
-
min-width: 32px; }
|
76 |
-
.daterangepicker .calendar-table {
|
77 |
-
border: 1px solid #fff;
|
78 |
-
padding: 4px;
|
79 |
-
border-radius: 4px;
|
80 |
-
background: #fff; }
|
81 |
-
.daterangepicker table {
|
82 |
-
width: 100%;
|
83 |
-
margin: 0; }
|
84 |
-
.daterangepicker td, .daterangepicker th {
|
85 |
-
text-align: center;
|
86 |
-
width: 20px;
|
87 |
-
height: 20px;
|
88 |
-
//border-radius: 4px;
|
89 |
-
border: 1px solid transparent;
|
90 |
-
white-space: nowrap;
|
91 |
-
cursor: pointer; }
|
92 |
-
.daterangepicker td.available:hover, .daterangepicker th.available:hover {
|
93 |
-
background: #eee; }
|
94 |
-
.daterangepicker td.week, .daterangepicker th.week {
|
95 |
-
font-size: 80%;
|
96 |
-
color: #ccc; }
|
97 |
-
.daterangepicker td.off, .daterangepicker td.off.in-range, .daterangepicker td.off.start-date, .daterangepicker td.off.end-date {
|
98 |
-
background-color: #fff;
|
99 |
-
border-color: transparent;
|
100 |
-
color: #999; }
|
101 |
-
.daterangepicker td.in-range {
|
102 |
-
background-color: #b7d9e8;
|
103 |
-
border-color: transparent;
|
104 |
-
color: #000;
|
105 |
-
border-radius: 0; }
|
106 |
-
.daterangepicker td.start-date {
|
107 |
-
border-radius: 4px 0 0 4px; }
|
108 |
-
.daterangepicker td.end-date {
|
109 |
-
border-radius: 0 4px 4px 0; }
|
110 |
-
.daterangepicker td.start-date.end-date {
|
111 |
-
border-radius: 4px; }
|
112 |
-
.daterangepicker td.active, .daterangepicker td.active:hover {
|
113 |
-
background-color: #357ebd;
|
114 |
-
border-color: transparent;
|
115 |
-
color: #fff; }
|
116 |
-
.daterangepicker th.month {
|
117 |
-
width: auto; }
|
118 |
-
.daterangepicker td.disabled, .daterangepicker option.disabled {
|
119 |
-
color: #999;
|
120 |
-
cursor: not-allowed;
|
121 |
-
/*text-decoration: line-through;*/ }
|
122 |
-
.daterangepicker select.monthselect, .daterangepicker select.yearselect {
|
123 |
-
font-size: 12px;
|
124 |
-
padding: 1px;
|
125 |
-
height: auto;
|
126 |
-
margin: 0;
|
127 |
-
cursor: default; }
|
128 |
-
.daterangepicker select.monthselect {
|
129 |
-
margin-right: 2%;
|
130 |
-
width: 56%; }
|
131 |
-
.daterangepicker select.yearselect {
|
132 |
-
width: 40%; }
|
133 |
-
.daterangepicker select.hourselect, .daterangepicker select.minuteselect, .daterangepicker select.secondselect, .daterangepicker select.ampmselect {
|
134 |
-
width: 50px;
|
135 |
-
margin-bottom: 0; }
|
136 |
-
.daterangepicker .input-mini {
|
137 |
-
border: 1px solid #ccc;
|
138 |
-
border-radius: 4px;
|
139 |
-
color: #555;
|
140 |
-
height: 30px;
|
141 |
-
line-height: 30px;
|
142 |
-
display: block;
|
143 |
-
vertical-align: middle;
|
144 |
-
margin: 0 0 5px 0;
|
145 |
-
padding: 0 6px 0 28px;
|
146 |
-
width:100% }
|
147 |
-
.daterangepicker .input-mini.active {
|
148 |
-
border: 1px solid #08c;
|
149 |
-
border-radius: 4px; }
|
150 |
-
.daterangepicker .daterangepicker_input {
|
151 |
-
position: relative;
|
152 |
-
background-color:#fff
|
153 |
-
}
|
154 |
-
.daterangepicker .daterangepicker_input i {
|
155 |
-
position: absolute;
|
156 |
-
left: 8px;
|
157 |
-
top: 8px; }
|
158 |
-
.daterangepicker .calendar-time {
|
159 |
-
text-align: center;
|
160 |
-
margin: 5px auto;
|
161 |
-
line-height: 30px;
|
162 |
-
position: relative;
|
163 |
-
padding-left: 28px; }
|
164 |
-
.daterangepicker .calendar-time select.disabled {
|
165 |
-
color: #ccc;
|
166 |
-
cursor: not-allowed; }
|
167 |
-
|
168 |
-
.ranges {
|
169 |
-
font-size: 11px;
|
170 |
-
float: none;
|
171 |
-
margin: 4px;
|
172 |
-
text-align: left; }
|
173 |
-
.ranges ul {
|
174 |
-
list-style: none;
|
175 |
-
margin: 0 auto;
|
176 |
-
padding: 0;
|
177 |
-
width: 100%; }
|
178 |
-
.ranges li {
|
179 |
-
font-size: 13px;
|
180 |
-
background: #f5f5f5;
|
181 |
-
border: 1px solid #f5f5f5;
|
182 |
-
border-radius: 4px;
|
183 |
-
color: #08c;
|
184 |
-
padding: 3px 12px;
|
185 |
-
margin-bottom: 8px;
|
186 |
-
cursor: pointer; }
|
187 |
-
.ranges li:hover {
|
188 |
-
background: #08c;
|
189 |
-
border: 1px solid #08c;
|
190 |
-
color: #fff; }
|
191 |
-
.ranges li.active {
|
192 |
-
background: #08c;
|
193 |
-
border: 1px solid #08c;
|
194 |
-
color: #fff; }
|
195 |
-
|
196 |
-
/* Larger Screen Styling */
|
197 |
-
@media (min-width: 564px) {
|
198 |
-
.daterangepicker {
|
199 |
-
width: auto; }
|
200 |
-
.daterangepicker .ranges ul {
|
201 |
-
width: 160px; }
|
202 |
-
.daterangepicker.single .ranges ul {
|
203 |
-
width: 100%; }
|
204 |
-
.daterangepicker.single .calendar.left {
|
205 |
-
clear: none; }
|
206 |
-
.daterangepicker.single .ranges, .daterangepicker.single .calendar {
|
207 |
-
float: left; }
|
208 |
-
.daterangepicker .calendar.left {
|
209 |
-
clear: left;
|
210 |
-
margin-right: 0; }
|
211 |
-
.daterangepicker .calendar.left .calendar-table {
|
212 |
-
border-right: none;
|
213 |
-
border-top-right-radius: 0;
|
214 |
-
border-bottom-right-radius: 0; }
|
215 |
-
.daterangepicker .calendar.right {
|
216 |
-
margin-left: 0; }
|
217 |
-
.daterangepicker .calendar.right .calendar-table {
|
218 |
-
border-left: none;
|
219 |
-
border-top-left-radius: 0;
|
220 |
-
border-bottom-left-radius: 0; }
|
221 |
-
.daterangepicker .left .daterangepicker_input {
|
222 |
-
padding-right: 12px; }
|
223 |
-
.daterangepicker .calendar.left .calendar-table {
|
224 |
-
padding-right: 12px; }
|
225 |
-
.daterangepicker .ranges, .daterangepicker .calendar {
|
226 |
-
float: left; } }
|
227 |
-
|
228 |
-
@media (min-width: 730px) {
|
229 |
-
.daterangepicker .ranges {
|
230 |
-
width: auto;
|
231 |
-
float: left; }
|
232 |
-
.daterangepicker .calendar.left {
|
233 |
-
clear: none; } }
|
1 |
+
.daterangepicker {
|
2 |
+
position: absolute;
|
3 |
+
color: inherit;
|
4 |
+
background: #fff;
|
5 |
+
border-radius: 4px;
|
6 |
+
width: 278px;
|
7 |
+
padding: 4px;
|
8 |
+
margin-top: 1px;
|
9 |
+
top: 100px;
|
10 |
+
left: 20px;
|
11 |
+
/* Calendars */ }
|
12 |
+
.daterangepicker:before, .daterangepicker:after {
|
13 |
+
position: absolute;
|
14 |
+
display: inline-block;
|
15 |
+
border-bottom-color: rgba(0, 0, 0, 0.2);
|
16 |
+
content: ''; }
|
17 |
+
.daterangepicker:before {
|
18 |
+
top: -7px;
|
19 |
+
border-right: 7px solid transparent;
|
20 |
+
border-left: 7px solid transparent;
|
21 |
+
border-bottom: 7px solid #ccc; }
|
22 |
+
.daterangepicker:after {
|
23 |
+
top: -6px;
|
24 |
+
border-right: 6px solid transparent;
|
25 |
+
border-bottom: 6px solid #fff;
|
26 |
+
border-left: 6px solid transparent; }
|
27 |
+
.daterangepicker.opensleft:before {
|
28 |
+
right: 9px; }
|
29 |
+
.daterangepicker.opensleft:after {
|
30 |
+
right: 10px; }
|
31 |
+
.daterangepicker.openscenter:before {
|
32 |
+
left: 0;
|
33 |
+
right: 0;
|
34 |
+
width: 0;
|
35 |
+
margin-left: auto;
|
36 |
+
margin-right: auto; }
|
37 |
+
.daterangepicker.openscenter:after {
|
38 |
+
left: 0;
|
39 |
+
right: 0;
|
40 |
+
width: 0;
|
41 |
+
margin-left: auto;
|
42 |
+
margin-right: auto; }
|
43 |
+
.daterangepicker.opensright:before {
|
44 |
+
left: 9px; }
|
45 |
+
.daterangepicker.opensright:after {
|
46 |
+
left: 10px; }
|
47 |
+
.daterangepicker.dropup {
|
48 |
+
margin-top: -5px; }
|
49 |
+
.daterangepicker.dropup:before {
|
50 |
+
top: initial;
|
51 |
+
bottom: -7px;
|
52 |
+
border-bottom: initial;
|
53 |
+
border-top: 7px solid #ccc; }
|
54 |
+
.daterangepicker.dropup:after {
|
55 |
+
top: initial;
|
56 |
+
bottom: -6px;
|
57 |
+
border-bottom: initial;
|
58 |
+
border-top: 6px solid #fff; }
|
59 |
+
.daterangepicker.dropdown-menu {
|
60 |
+
max-width: none;
|
61 |
+
z-index: 3001; }
|
62 |
+
.daterangepicker.single .ranges, .daterangepicker.single .calendar {
|
63 |
+
float: none; }
|
64 |
+
.daterangepicker.show-calendar .calendar {
|
65 |
+
display: block; }
|
66 |
+
.daterangepicker .calendar {
|
67 |
+
display: none;
|
68 |
+
max-width: 270px;
|
69 |
+
margin: 4px; }
|
70 |
+
.daterangepicker .calendar.single .calendar-table {
|
71 |
+
border: none; }
|
72 |
+
.daterangepicker .calendar th, .daterangepicker .calendar td {
|
73 |
+
white-space: nowrap;
|
74 |
+
text-align: center;
|
75 |
+
min-width: 32px; }
|
76 |
+
.daterangepicker .calendar-table {
|
77 |
+
border: 1px solid #fff;
|
78 |
+
padding: 4px;
|
79 |
+
border-radius: 4px;
|
80 |
+
background: #fff; }
|
81 |
+
.daterangepicker table {
|
82 |
+
width: 100%;
|
83 |
+
margin: 0; }
|
84 |
+
.daterangepicker td, .daterangepicker th {
|
85 |
+
text-align: center;
|
86 |
+
width: 20px;
|
87 |
+
height: 20px;
|
88 |
+
//border-radius: 4px;
|
89 |
+
border: 1px solid transparent;
|
90 |
+
white-space: nowrap;
|
91 |
+
cursor: pointer; }
|
92 |
+
.daterangepicker td.available:hover, .daterangepicker th.available:hover {
|
93 |
+
background: #eee; }
|
94 |
+
.daterangepicker td.week, .daterangepicker th.week {
|
95 |
+
font-size: 80%;
|
96 |
+
color: #ccc; }
|
97 |
+
.daterangepicker td.off, .daterangepicker td.off.in-range, .daterangepicker td.off.start-date, .daterangepicker td.off.end-date {
|
98 |
+
background-color: #fff;
|
99 |
+
border-color: transparent;
|
100 |
+
color: #999; }
|
101 |
+
.daterangepicker td.in-range {
|
102 |
+
background-color: #b7d9e8;
|
103 |
+
border-color: transparent;
|
104 |
+
color: #000;
|
105 |
+
border-radius: 0; }
|
106 |
+
.daterangepicker td.start-date {
|
107 |
+
border-radius: 4px 0 0 4px; }
|
108 |
+
.daterangepicker td.end-date {
|
109 |
+
border-radius: 0 4px 4px 0; }
|
110 |
+
.daterangepicker td.start-date.end-date {
|
111 |
+
border-radius: 4px; }
|
112 |
+
.daterangepicker td.active, .daterangepicker td.active:hover {
|
113 |
+
background-color: #357ebd;
|
114 |
+
border-color: transparent;
|
115 |
+
color: #fff; }
|
116 |
+
.daterangepicker th.month {
|
117 |
+
width: auto; }
|
118 |
+
.daterangepicker td.disabled, .daterangepicker option.disabled {
|
119 |
+
color: #999;
|
120 |
+
cursor: not-allowed;
|
121 |
+
/*text-decoration: line-through;*/ }
|
122 |
+
.daterangepicker select.monthselect, .daterangepicker select.yearselect {
|
123 |
+
font-size: 12px;
|
124 |
+
padding: 1px;
|
125 |
+
height: auto;
|
126 |
+
margin: 0;
|
127 |
+
cursor: default; }
|
128 |
+
.daterangepicker select.monthselect {
|
129 |
+
margin-right: 2%;
|
130 |
+
width: 56%; }
|
131 |
+
.daterangepicker select.yearselect {
|
132 |
+
width: 40%; }
|
133 |
+
.daterangepicker select.hourselect, .daterangepicker select.minuteselect, .daterangepicker select.secondselect, .daterangepicker select.ampmselect {
|
134 |
+
width: 50px;
|
135 |
+
margin-bottom: 0; }
|
136 |
+
.daterangepicker .input-mini {
|
137 |
+
border: 1px solid #ccc;
|
138 |
+
border-radius: 4px;
|
139 |
+
color: #555;
|
140 |
+
height: 30px;
|
141 |
+
line-height: 30px;
|
142 |
+
display: block;
|
143 |
+
vertical-align: middle;
|
144 |
+
margin: 0 0 5px 0;
|
145 |
+
padding: 0 6px 0 28px;
|
146 |
+
width:100% }
|
147 |
+
.daterangepicker .input-mini.active {
|
148 |
+
border: 1px solid #08c;
|
149 |
+
border-radius: 4px; }
|
150 |
+
.daterangepicker .daterangepicker_input {
|
151 |
+
position: relative;
|
152 |
+
background-color:#fff
|
153 |
+
}
|
154 |
+
.daterangepicker .daterangepicker_input i {
|
155 |
+
position: absolute;
|
156 |
+
left: 8px;
|
157 |
+
top: 8px; }
|
158 |
+
.daterangepicker .calendar-time {
|
159 |
+
text-align: center;
|
160 |
+
margin: 5px auto;
|
161 |
+
line-height: 30px;
|
162 |
+
position: relative;
|
163 |
+
padding-left: 28px; }
|
164 |
+
.daterangepicker .calendar-time select.disabled {
|
165 |
+
color: #ccc;
|
166 |
+
cursor: not-allowed; }
|
167 |
+
|
168 |
+
.ranges {
|
169 |
+
font-size: 11px;
|
170 |
+
float: none;
|
171 |
+
margin: 4px;
|
172 |
+
text-align: left; }
|
173 |
+
.ranges ul {
|
174 |
+
list-style: none;
|
175 |
+
margin: 0 auto;
|
176 |
+
padding: 0;
|
177 |
+
width: 100%; }
|
178 |
+
.ranges li {
|
179 |
+
font-size: 13px;
|
180 |
+
background: #f5f5f5;
|
181 |
+
border: 1px solid #f5f5f5;
|
182 |
+
border-radius: 4px;
|
183 |
+
color: #08c;
|
184 |
+
padding: 3px 12px;
|
185 |
+
margin-bottom: 8px;
|
186 |
+
cursor: pointer; }
|
187 |
+
.ranges li:hover {
|
188 |
+
background: #08c;
|
189 |
+
border: 1px solid #08c;
|
190 |
+
color: #fff; }
|
191 |
+
.ranges li.active {
|
192 |
+
background: #08c;
|
193 |
+
border: 1px solid #08c;
|
194 |
+
color: #fff; }
|
195 |
+
|
196 |
+
/* Larger Screen Styling */
|
197 |
+
@media (min-width: 564px) {
|
198 |
+
.daterangepicker {
|
199 |
+
width: auto; }
|
200 |
+
.daterangepicker .ranges ul {
|
201 |
+
width: 160px; }
|
202 |
+
.daterangepicker.single .ranges ul {
|
203 |
+
width: 100%; }
|
204 |
+
.daterangepicker.single .calendar.left {
|
205 |
+
clear: none; }
|
206 |
+
.daterangepicker.single .ranges, .daterangepicker.single .calendar {
|
207 |
+
float: left; }
|
208 |
+
.daterangepicker .calendar.left {
|
209 |
+
clear: left;
|
210 |
+
margin-right: 0; }
|
211 |
+
.daterangepicker .calendar.left .calendar-table {
|
212 |
+
border-right: none;
|
213 |
+
border-top-right-radius: 0;
|
214 |
+
border-bottom-right-radius: 0; }
|
215 |
+
.daterangepicker .calendar.right {
|
216 |
+
margin-left: 0; }
|
217 |
+
.daterangepicker .calendar.right .calendar-table {
|
218 |
+
border-left: none;
|
219 |
+
border-top-left-radius: 0;
|
220 |
+
border-bottom-left-radius: 0; }
|
221 |
+
.daterangepicker .left .daterangepicker_input {
|
222 |
+
padding-right: 12px; }
|
223 |
+
.daterangepicker .calendar.left .calendar-table {
|
224 |
+
padding-right: 12px; }
|
225 |
+
.daterangepicker .ranges, .daterangepicker .calendar {
|
226 |
+
float: left; } }
|
227 |
+
|
228 |
+
@media (min-width: 730px) {
|
229 |
+
.daterangepicker .ranges {
|
230 |
+
width: auto;
|
231 |
+
float: left; }
|
232 |
+
.daterangepicker .calendar.left {
|
233 |
+
clear: none; } }
|
inc/css/font_awesome.css
CHANGED
@@ -1,4 +1,4 @@
|
|
1 |
-
/*!
|
2 |
-
* Font Awesome 4.3.0 by @davegandy - http://fontawesome.io - @fontawesome
|
3 |
-
* License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License)
|
4 |
*/@font-face{font-family:'FontAwesome';src:url('../fonts/fontawesome-webfont.eot?v=4.3.0');src:url('../fonts/fontawesome-webfont.eot?#iefix&v=4.3.0') format('embedded-opentype'),url('../fonts/fontawesome-webfont.woff2?v=4.3.0') format('woff2'),url('../fonts/fontawesome-webfont.woff?v=4.3.0') format('woff'),url('../fonts/fontawesome-webfont.ttf?v=4.3.0') format('truetype'),url('../fonts/fontawesome-webfont.svg?v=4.3.0#fontawesomeregular') format('svg');font-weight:normal;font-style:normal}.fa{display:inline-block;font:normal normal normal 14px/1 FontAwesome;font-size:inherit;text-rendering:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transform:translate(0, 0)}.fa-lg{font-size:1.33333333em;line-height:.75em;vertical-align:-15%}.fa-2x{font-size:2em}.fa-3x{font-size:3em}.fa-4x{font-size:4em}.fa-5x{font-size:5em}.fa-fw{width:1.28571429em;text-align:center}.fa-ul{padding-left:0;margin-left:2.14285714em;list-style-type:none}.fa-ul>li{position:relative}.fa-li{position:absolute;left:-2.14285714em;width:2.14285714em;top:.14285714em;text-align:center}.fa-li.fa-lg{left:-1.85714286em}.fa-border{padding:.2em .25em .15em;border:solid .08em #eee;border-radius:.1em}.pull-right{float:right}.pull-left{float:left}.fa.pull-left{margin-right:.3em}.fa.pull-right{margin-left:.3em}.fa-spin{-webkit-animation:fa-spin 2s infinite linear;animation:fa-spin 2s infinite linear}.fa-pulse{-webkit-animation:fa-spin 1s infinite steps(8);animation:fa-spin 1s infinite steps(8)}@-webkit-keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}@keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.fa-rotate-90{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=1);-webkit-transform:rotate(90deg);-ms-transform:rotate(90deg);transform:rotate(90deg)}.fa-rotate-180{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=2);-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg)}.fa-rotate-270{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=3);-webkit-transform:rotate(270deg);-ms-transform:rotate(270deg);transform:rotate(270deg)}.fa-flip-horizontal{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1);-webkit-transform:scale(-1, 1);-ms-transform:scale(-1, 1);transform:scale(-1, 1)}.fa-flip-vertical{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1);-webkit-transform:scale(1, -1);-ms-transform:scale(1, -1);transform:scale(1, -1)}:root .fa-rotate-90,:root .fa-rotate-180,:root .fa-rotate-270,:root .fa-flip-horizontal,:root .fa-flip-vertical{filter:none}.fa-stack{position:relative;display:inline-block;width:2em;height:2em;line-height:2em;vertical-align:middle}.fa-stack-1x,.fa-stack-2x{position:absolute;left:0;width:100%;text-align:center}.fa-stack-1x{line-height:inherit}.fa-stack-2x{font-size:2em}.fa-inverse{color:#fff}.fa-glass:before{content:"\f000"}.fa-music:before{content:"\f001"}.fa-search:before{content:"\f002"}.fa-envelope-o:before{content:"\f003"}.fa-heart:before{content:"\f004"}.fa-star:before{content:"\f005"}.fa-star-o:before{content:"\f006"}.fa-user:before{content:"\f007"}.fa-film:before{content:"\f008"}.fa-th-large:before{content:"\f009"}.fa-th:before{content:"\f00a"}.fa-th-list:before{content:"\f00b"}.fa-check:before{content:"\f00c"}.fa-remove:before,.fa-close:before,.fa-times:before{content:"\f00d"}.fa-search-plus:before{content:"\f00e"}.fa-search-minus:before{content:"\f010"}.fa-power-off:before{content:"\f011"}.fa-signal:before{content:"\f012"}.fa-gear:before,.fa-cog:before{content:"\f013"}.fa-trash-o:before{content:"\f014"}.fa-home:before{content:"\f015"}.fa-file-o:before{content:"\f016"}.fa-clock-o:before{content:"\f017"}.fa-road:before{content:"\f018"}.fa-download:before{content:"\f019"}.fa-arrow-circle-o-down:before{content:"\f01a"}.fa-arrow-circle-o-up:before{content:"\f01b"}.fa-inbox:before{content:"\f01c"}.fa-play-circle-o:before{content:"\f01d"}.fa-rotate-right:before,.fa-repeat:before{content:"\f01e"}.fa-refresh:before{content:"\f021"}.fa-list-alt:before{content:"\f022"}.fa-lock:before{content:"\f023"}.fa-flag:before{content:"\f024"}.fa-headphones:before{content:"\f025"}.fa-volume-off:before{content:"\f026"}.fa-volume-down:before{content:"\f027"}.fa-volume-up:before{content:"\f028"}.fa-qrcode:before{content:"\f029"}.fa-barcode:before{content:"\f02a"}.fa-tag:before{content:"\f02b"}.fa-tags:before{content:"\f02c"}.fa-book:before{content:"\f02d"}.fa-bookmark:before{content:"\f02e"}.fa-print:before{content:"\f02f"}.fa-camera:before{content:"\f030"}.fa-font:before{content:"\f031"}.fa-bold:before{content:"\f032"}.fa-italic:before{content:"\f033"}.fa-text-height:before{content:"\f034"}.fa-text-width:before{content:"\f035"}.fa-align-left:before{content:"\f036"}.fa-align-center:before{content:"\f037"}.fa-align-right:before{content:"\f038"}.fa-align-justify:before{content:"\f039"}.fa-list:before{content:"\f03a"}.fa-dedent:before,.fa-outdent:before{content:"\f03b"}.fa-indent:before{content:"\f03c"}.fa-video-camera:before{content:"\f03d"}.fa-photo:before,.fa-image:before,.fa-picture-o:before{content:"\f03e"}.fa-pencil:before{content:"\f040"}.fa-map-marker:before{content:"\f041"}.fa-adjust:before{content:"\f042"}.fa-tint:before{content:"\f043"}.fa-edit:before,.fa-pencil-square-o:before{content:"\f044"}.fa-share-square-o:before{content:"\f045"}.fa-check-square-o:before{content:"\f046"}.fa-arrows:before{content:"\f047"}.fa-step-backward:before{content:"\f048"}.fa-fast-backward:before{content:"\f049"}.fa-backward:before{content:"\f04a"}.fa-play:before{content:"\f04b"}.fa-pause:before{content:"\f04c"}.fa-stop:before{content:"\f04d"}.fa-forward:before{content:"\f04e"}.fa-fast-forward:before{content:"\f050"}.fa-step-forward:before{content:"\f051"}.fa-eject:before{content:"\f052"}.fa-chevron-left:before{content:"\f053"}.fa-chevron-right:before{content:"\f054"}.fa-plus-circle:before{content:"\f055"}.fa-minus-circle:before{content:"\f056"}.fa-times-circle:before{content:"\f057"}.fa-check-circle:before{content:"\f058"}.fa-question-circle:before{content:"\f059"}.fa-info-circle:before{content:"\f05a"}.fa-crosshairs:before{content:"\f05b"}.fa-times-circle-o:before{content:"\f05c"}.fa-check-circle-o:before{content:"\f05d"}.fa-ban:before{content:"\f05e"}.fa-arrow-left:before{content:"\f060"}.fa-arrow-right:before{content:"\f061"}.fa-arrow-up:before{content:"\f062"}.fa-arrow-down:before{content:"\f063"}.fa-mail-forward:before,.fa-share:before{content:"\f064"}.fa-expand:before{content:"\f065"}.fa-compress:before{content:"\f066"}.fa-plus:before{content:"\f067"}.fa-minus:before{content:"\f068"}.fa-asterisk:before{content:"\f069"}.fa-exclamation-circle:before{content:"\f06a"}.fa-gift:before{content:"\f06b"}.fa-leaf:before{content:"\f06c"}.fa-fire:before{content:"\f06d"}.fa-eye:before{content:"\f06e"}.fa-eye-slash:before{content:"\f070"}.fa-warning:before,.fa-exclamation-triangle:before{content:"\f071"}.fa-plane:before{content:"\f072"}.fa-calendar:before{content:"\f073"}.fa-random:before{content:"\f074"}.fa-comment:before{content:"\f075"}.fa-magnet:before{content:"\f076"}.fa-chevron-up:before{content:"\f077"}.fa-chevron-down:before{content:"\f078"}.fa-retweet:before{content:"\f079"}.fa-shopping-cart:before{content:"\f07a"}.fa-folder:before{content:"\f07b"}.fa-folder-open:before{content:"\f07c"}.fa-arrows-v:before{content:"\f07d"}.fa-arrows-h:before{content:"\f07e"}.fa-bar-chart-o:before,.fa-bar-chart:before{content:"\f080"}.fa-twitter-square:before{content:"\f081"}.fa-facebook-square:before{content:"\f082"}.fa-camera-retro:before{content:"\f083"}.fa-key:before{content:"\f084"}.fa-gears:before,.fa-cogs:before{content:"\f085"}.fa-comments:before{content:"\f086"}.fa-thumbs-o-up:before{content:"\f087"}.fa-thumbs-o-down:before{content:"\f088"}.fa-star-half:before{content:"\f089"}.fa-heart-o:before{content:"\f08a"}.fa-sign-out:before{content:"\f08b"}.fa-linkedin-square:before{content:"\f08c"}.fa-thumb-tack:before{content:"\f08d"}.fa-external-link:before{content:"\f08e"}.fa-sign-in:before{content:"\f090"}.fa-trophy:before{content:"\f091"}.fa-github-square:before{content:"\f092"}.fa-upload:before{content:"\f093"}.fa-lemon-o:before{content:"\f094"}.fa-phone:before{content:"\f095"}.fa-square-o:before{content:"\f096"}.fa-bookmark-o:before{content:"\f097"}.fa-phone-square:before{content:"\f098"}.fa-twitter:before{content:"\f099"}.fa-facebook-f:before,.fa-facebook:before{content:"\f09a"}.fa-github:before{content:"\f09b"}.fa-unlock:before{content:"\f09c"}.fa-credit-card:before{content:"\f09d"}.fa-rss:before{content:"\f09e"}.fa-hdd-o:before{content:"\f0a0"}.fa-bullhorn:before{content:"\f0a1"}.fa-bell:before{content:"\f0f3"}.fa-certificate:before{content:"\f0a3"}.fa-hand-o-right:before{content:"\f0a4"}.fa-hand-o-left:before{content:"\f0a5"}.fa-hand-o-up:before{content:"\f0a6"}.fa-hand-o-down:before{content:"\f0a7"}.fa-arrow-circle-left:before{content:"\f0a8"}.fa-arrow-circle-right:before{content:"\f0a9"}.fa-arrow-circle-up:before{content:"\f0aa"}.fa-arrow-circle-down:before{content:"\f0ab"}.fa-globe:before{content:"\f0ac"}.fa-wrench:before{content:"\f0ad"}.fa-tasks:before{content:"\f0ae"}.fa-filter:before{content:"\f0b0"}.fa-briefcase:before{content:"\f0b1"}.fa-arrows-alt:before{content:"\f0b2"}.fa-group:before,.fa-users:before{content:"\f0c0"}.fa-chain:before,.fa-link:before{content:"\f0c1"}.fa-cloud:before{content:"\f0c2"}.fa-flask:before{content:"\f0c3"}.fa-cut:before,.fa-scissors:before{content:"\f0c4"}.fa-copy:before,.fa-files-o:before{content:"\f0c5"}.fa-paperclip:before{content:"\f0c6"}.fa-save:before,.fa-floppy-o:before{content:"\f0c7"}.fa-square:before{content:"\f0c8"}.fa-navicon:before,.fa-reorder:before,.fa-bars:before{content:"\f0c9"}.fa-list-ul:before{content:"\f0ca"}.fa-list-ol:before{content:"\f0cb"}.fa-strikethrough:before{content:"\f0cc"}.fa-underline:before{content:"\f0cd"}.fa-table:before{content:"\f0ce"}.fa-magic:before{content:"\f0d0"}.fa-truck:before{content:"\f0d1"}.fa-pinterest:before{content:"\f0d2"}.fa-pinterest-square:before{content:"\f0d3"}.fa-google-plus-square:before{content:"\f0d4"}.fa-google-plus:before{content:"\f0d5"}.fa-money:before{content:"\f0d6"}.fa-caret-down:before{content:"\f0d7"}.fa-caret-up:before{content:"\f0d8"}.fa-caret-left:before{content:"\f0d9"}.fa-caret-right:before{content:"\f0da"}.fa-columns:before{content:"\f0db"}.fa-unsorted:before,.fa-sort:before{content:"\f0dc"}.fa-sort-down:before,.fa-sort-desc:before{content:"\f0dd"}.fa-sort-up:before,.fa-sort-asc:before{content:"\f0de"}.fa-envelope:before{content:"\f0e0"}.fa-linkedin:before{content:"\f0e1"}.fa-rotate-left:before,.fa-undo:before{content:"\f0e2"}.fa-legal:before,.fa-gavel:before{content:"\f0e3"}.fa-dashboard:before,.fa-tachometer:before{content:"\f0e4"}.fa-comment-o:before{content:"\f0e5"}.fa-comments-o:before{content:"\f0e6"}.fa-flash:before,.fa-bolt:before{content:"\f0e7"}.fa-sitemap:before{content:"\f0e8"}.fa-umbrella:before{content:"\f0e9"}.fa-paste:before,.fa-clipboard:before{content:"\f0ea"}.fa-lightbulb-o:before{content:"\f0eb"}.fa-exchange:before{content:"\f0ec"}.fa-cloud-download:before{content:"\f0ed"}.fa-cloud-upload:before{content:"\f0ee"}.fa-user-md:before{content:"\f0f0"}.fa-stethoscope:before{content:"\f0f1"}.fa-suitcase:before{content:"\f0f2"}.fa-bell-o:before{content:"\f0a2"}.fa-coffee:before{content:"\f0f4"}.fa-cutlery:before{content:"\f0f5"}.fa-file-text-o:before{content:"\f0f6"}.fa-building-o:before{content:"\f0f7"}.fa-hospital-o:before{content:"\f0f8"}.fa-ambulance:before{content:"\f0f9"}.fa-medkit:before{content:"\f0fa"}.fa-fighter-jet:before{content:"\f0fb"}.fa-beer:before{content:"\f0fc"}.fa-h-square:before{content:"\f0fd"}.fa-plus-square:before{content:"\f0fe"}.fa-angle-double-left:before{content:"\f100"}.fa-angle-double-right:before{content:"\f101"}.fa-angle-double-up:before{content:"\f102"}.fa-angle-double-down:before{content:"\f103"}.fa-angle-left:before{content:"\f104"}.fa-angle-right:before{content:"\f105"}.fa-angle-up:before{content:"\f106"}.fa-angle-down:before{content:"\f107"}.fa-desktop:before{content:"\f108"}.fa-laptop:before{content:"\f109"}.fa-tablet:before{content:"\f10a"}.fa-mobile-phone:before,.fa-mobile:before{content:"\f10b"}.fa-circle-o:before{content:"\f10c"}.fa-quote-left:before{content:"\f10d"}.fa-quote-right:before{content:"\f10e"}.fa-spinner:before{content:"\f110"}.fa-circle:before{content:"\f111"}.fa-mail-reply:before,.fa-reply:before{content:"\f112"}.fa-github-alt:before{content:"\f113"}.fa-folder-o:before{content:"\f114"}.fa-folder-open-o:before{content:"\f115"}.fa-smile-o:before{content:"\f118"}.fa-frown-o:before{content:"\f119"}.fa-meh-o:before{content:"\f11a"}.fa-gamepad:before{content:"\f11b"}.fa-keyboard-o:before{content:"\f11c"}.fa-flag-o:before{content:"\f11d"}.fa-flag-checkered:before{content:"\f11e"}.fa-terminal:before{content:"\f120"}.fa-code:before{content:"\f121"}.fa-mail-reply-all:before,.fa-reply-all:before{content:"\f122"}.fa-star-half-empty:before,.fa-star-half-full:before,.fa-star-half-o:before{content:"\f123"}.fa-location-arrow:before{content:"\f124"}.fa-crop:before{content:"\f125"}.fa-code-fork:before{content:"\f126"}.fa-unlink:before,.fa-chain-broken:before{content:"\f127"}.fa-question:before{content:"\f128"}.fa-info:before{content:"\f129"}.fa-exclamation:before{content:"\f12a"}.fa-superscript:before{content:"\f12b"}.fa-subscript:before{content:"\f12c"}.fa-eraser:before{content:"\f12d"}.fa-puzzle-piece:before{content:"\f12e"}.fa-microphone:before{content:"\f130"}.fa-microphone-slash:before{content:"\f131"}.fa-shield:before{content:"\f132"}.fa-calendar-o:before{content:"\f133"}.fa-fire-extinguisher:before{content:"\f134"}.fa-rocket:before{content:"\f135"}.fa-maxcdn:before{content:"\f136"}.fa-chevron-circle-left:before{content:"\f137"}.fa-chevron-circle-right:before{content:"\f138"}.fa-chevron-circle-up:before{content:"\f139"}.fa-chevron-circle-down:before{content:"\f13a"}.fa-html5:before{content:"\f13b"}.fa-css3:before{content:"\f13c"}.fa-anchor:before{content:"\f13d"}.fa-unlock-alt:before{content:"\f13e"}.fa-bullseye:before{content:"\f140"}.fa-ellipsis-h:before{content:"\f141"}.fa-ellipsis-v:before{content:"\f142"}.fa-rss-square:before{content:"\f143"}.fa-play-circle:before{content:"\f144"}.fa-ticket:before{content:"\f145"}.fa-minus-square:before{content:"\f146"}.fa-minus-square-o:before{content:"\f147"}.fa-level-up:before{content:"\f148"}.fa-level-down:before{content:"\f149"}.fa-check-square:before{content:"\f14a"}.fa-pencil-square:before{content:"\f14b"}.fa-external-link-square:before{content:"\f14c"}.fa-share-square:before{content:"\f14d"}.fa-compass:before{content:"\f14e"}.fa-toggle-down:before,.fa-caret-square-o-down:before{content:"\f150"}.fa-toggle-up:before,.fa-caret-square-o-up:before{content:"\f151"}.fa-toggle-right:before,.fa-caret-square-o-right:before{content:"\f152"}.fa-euro:before,.fa-eur:before{content:"\f153"}.fa-gbp:before{content:"\f154"}.fa-dollar:before,.fa-usd:before{content:"\f155"}.fa-rupee:before,.fa-inr:before{content:"\f156"}.fa-cny:before,.fa-rmb:before,.fa-yen:before,.fa-jpy:before{content:"\f157"}.fa-ruble:before,.fa-rouble:before,.fa-rub:before{content:"\f158"}.fa-won:before,.fa-krw:before{content:"\f159"}.fa-bitcoin:before,.fa-btc:before{content:"\f15a"}.fa-file:before{content:"\f15b"}.fa-file-text:before{content:"\f15c"}.fa-sort-alpha-asc:before{content:"\f15d"}.fa-sort-alpha-desc:before{content:"\f15e"}.fa-sort-amount-asc:before{content:"\f160"}.fa-sort-amount-desc:before{content:"\f161"}.fa-sort-numeric-asc:before{content:"\f162"}.fa-sort-numeric-desc:before{content:"\f163"}.fa-thumbs-up:before{content:"\f164"}.fa-thumbs-down:before{content:"\f165"}.fa-youtube-square:before{content:"\f166"}.fa-youtube:before{content:"\f167"}.fa-xing:before{content:"\f168"}.fa-xing-square:before{content:"\f169"}.fa-youtube-play:before{content:"\f16a"}.fa-dropbox:before{content:"\f16b"}.fa-stack-overflow:before{content:"\f16c"}.fa-instagram:before{content:"\f16d"}.fa-flickr:before{content:"\f16e"}.fa-adn:before{content:"\f170"}.fa-bitbucket:before{content:"\f171"}.fa-bitbucket-square:before{content:"\f172"}.fa-tumblr:before{content:"\f173"}.fa-tumblr-square:before{content:"\f174"}.fa-long-arrow-down:before{content:"\f175"}.fa-long-arrow-up:before{content:"\f176"}.fa-long-arrow-left:before{content:"\f177"}.fa-long-arrow-right:before{content:"\f178"}.fa-apple:before{content:"\f179"}.fa-windows:before{content:"\f17a"}.fa-android:before{content:"\f17b"}.fa-linux:before{content:"\f17c"}.fa-dribbble:before{content:"\f17d"}.fa-skype:before{content:"\f17e"}.fa-foursquare:before{content:"\f180"}.fa-trello:before{content:"\f181"}.fa-female:before{content:"\f182"}.fa-male:before{content:"\f183"}.fa-gittip:before,.fa-gratipay:before{content:"\f184"}.fa-sun-o:before{content:"\f185"}.fa-moon-o:before{content:"\f186"}.fa-archive:before{content:"\f187"}.fa-bug:before{content:"\f188"}.fa-vk:before{content:"\f189"}.fa-weibo:before{content:"\f18a"}.fa-renren:before{content:"\f18b"}.fa-pagelines:before{content:"\f18c"}.fa-stack-exchange:before{content:"\f18d"}.fa-arrow-circle-o-right:before{content:"\f18e"}.fa-arrow-circle-o-left:before{content:"\f190"}.fa-toggle-left:before,.fa-caret-square-o-left:before{content:"\f191"}.fa-dot-circle-o:before{content:"\f192"}.fa-wheelchair:before{content:"\f193"}.fa-vimeo-square:before{content:"\f194"}.fa-turkish-lira:before,.fa-try:before{content:"\f195"}.fa-plus-square-o:before{content:"\f196"}.fa-space-shuttle:before{content:"\f197"}.fa-slack:before{content:"\f198"}.fa-envelope-square:before{content:"\f199"}.fa-wordpress:before{content:"\f19a"}.fa-openid:before{content:"\f19b"}.fa-institution:before,.fa-bank:before,.fa-university:before{content:"\f19c"}.fa-mortar-board:before,.fa-graduation-cap:before{content:"\f19d"}.fa-yahoo:before{content:"\f19e"}.fa-google:before{content:"\f1a0"}.fa-reddit:before{content:"\f1a1"}.fa-reddit-square:before{content:"\f1a2"}.fa-stumbleupon-circle:before{content:"\f1a3"}.fa-stumbleupon:before{content:"\f1a4"}.fa-delicious:before{content:"\f1a5"}.fa-digg:before{content:"\f1a6"}.fa-pied-piper:before{content:"\f1a7"}.fa-pied-piper-alt:before{content:"\f1a8"}.fa-drupal:before{content:"\f1a9"}.fa-joomla:before{content:"\f1aa"}.fa-language:before{content:"\f1ab"}.fa-fax:before{content:"\f1ac"}.fa-building:before{content:"\f1ad"}.fa-child:before{content:"\f1ae"}.fa-paw:before{content:"\f1b0"}.fa-spoon:before{content:"\f1b1"}.fa-cube:before{content:"\f1b2"}.fa-cubes:before{content:"\f1b3"}.fa-behance:before{content:"\f1b4"}.fa-behance-square:before{content:"\f1b5"}.fa-steam:before{content:"\f1b6"}.fa-steam-square:before{content:"\f1b7"}.fa-recycle:before{content:"\f1b8"}.fa-automobile:before,.fa-car:before{content:"\f1b9"}.fa-cab:before,.fa-taxi:before{content:"\f1ba"}.fa-tree:before{content:"\f1bb"}.fa-spotify:before{content:"\f1bc"}.fa-deviantart:before{content:"\f1bd"}.fa-soundcloud:before{content:"\f1be"}.fa-database:before{content:"\f1c0"}.fa-file-pdf-o:before{content:"\f1c1"}.fa-file-word-o:before{content:"\f1c2"}.fa-file-excel-o:before{content:"\f1c3"}.fa-file-powerpoint-o:before{content:"\f1c4"}.fa-file-photo-o:before,.fa-file-picture-o:before,.fa-file-image-o:before{content:"\f1c5"}.fa-file-zip-o:before,.fa-file-archive-o:before{content:"\f1c6"}.fa-file-sound-o:before,.fa-file-audio-o:before{content:"\f1c7"}.fa-file-movie-o:before,.fa-file-video-o:before{content:"\f1c8"}.fa-file-code-o:before{content:"\f1c9"}.fa-vine:before{content:"\f1ca"}.fa-codepen:before{content:"\f1cb"}.fa-jsfiddle:before{content:"\f1cc"}.fa-life-bouy:before,.fa-life-buoy:before,.fa-life-saver:before,.fa-support:before,.fa-life-ring:before{content:"\f1cd"}.fa-circle-o-notch:before{content:"\f1ce"}.fa-ra:before,.fa-rebel:before{content:"\f1d0"}.fa-ge:before,.fa-empire:before{content:"\f1d1"}.fa-git-square:before{content:"\f1d2"}.fa-git:before{content:"\f1d3"}.fa-hacker-news:before{content:"\f1d4"}.fa-tencent-weibo:before{content:"\f1d5"}.fa-qq:before{content:"\f1d6"}.fa-wechat:before,.fa-weixin:before{content:"\f1d7"}.fa-send:before,.fa-paper-plane:before{content:"\f1d8"}.fa-send-o:before,.fa-paper-plane-o:before{content:"\f1d9"}.fa-history:before{content:"\f1da"}.fa-genderless:before,.fa-circle-thin:before{content:"\f1db"}.fa-header:before{content:"\f1dc"}.fa-paragraph:before{content:"\f1dd"}.fa-sliders:before{content:"\f1de"}.fa-share-alt:before{content:"\f1e0"}.fa-share-alt-square:before{content:"\f1e1"}.fa-bomb:before{content:"\f1e2"}.fa-soccer-ball-o:before,.fa-futbol-o:before{content:"\f1e3"}.fa-tty:before{content:"\f1e4"}.fa-binoculars:before{content:"\f1e5"}.fa-plug:before{content:"\f1e6"}.fa-slideshare:before{content:"\f1e7"}.fa-twitch:before{content:"\f1e8"}.fa-yelp:before{content:"\f1e9"}.fa-newspaper-o:before{content:"\f1ea"}.fa-wifi:before{content:"\f1eb"}.fa-calculator:before{content:"\f1ec"}.fa-paypal:before{content:"\f1ed"}.fa-google-wallet:before{content:"\f1ee"}.fa-cc-visa:before{content:"\f1f0"}.fa-cc-mastercard:before{content:"\f1f1"}.fa-cc-discover:before{content:"\f1f2"}.fa-cc-amex:before{content:"\f1f3"}.fa-cc-paypal:before{content:"\f1f4"}.fa-cc-stripe:before{content:"\f1f5"}.fa-bell-slash:before{content:"\f1f6"}.fa-bell-slash-o:before{content:"\f1f7"}.fa-trash:before{content:"\f1f8"}.fa-copyright:before{content:"\f1f9"}.fa-at:before{content:"\f1fa"}.fa-eyedropper:before{content:"\f1fb"}.fa-paint-brush:before{content:"\f1fc"}.fa-birthday-cake:before{content:"\f1fd"}.fa-area-chart:before{content:"\f1fe"}.fa-pie-chart:before{content:"\f200"}.fa-line-chart:before{content:"\f201"}.fa-lastfm:before{content:"\f202"}.fa-lastfm-square:before{content:"\f203"}.fa-toggle-off:before{content:"\f204"}.fa-toggle-on:before{content:"\f205"}.fa-bicycle:before{content:"\f206"}.fa-bus:before{content:"\f207"}.fa-ioxhost:before{content:"\f208"}.fa-angellist:before{content:"\f209"}.fa-cc:before{content:"\f20a"}.fa-shekel:before,.fa-sheqel:before,.fa-ils:before{content:"\f20b"}.fa-meanpath:before{content:"\f20c"}.fa-buysellads:before{content:"\f20d"}.fa-connectdevelop:before{content:"\f20e"}.fa-dashcube:before{content:"\f210"}.fa-forumbee:before{content:"\f211"}.fa-leanpub:before{content:"\f212"}.fa-sellsy:before{content:"\f213"}.fa-shirtsinbulk:before{content:"\f214"}.fa-simplybuilt:before{content:"\f215"}.fa-skyatlas:before{content:"\f216"}.fa-cart-plus:before{content:"\f217"}.fa-cart-arrow-down:before{content:"\f218"}.fa-diamond:before{content:"\f219"}.fa-ship:before{content:"\f21a"}.fa-user-secret:before{content:"\f21b"}.fa-motorcycle:before{content:"\f21c"}.fa-street-view:before{content:"\f21d"}.fa-heartbeat:before{content:"\f21e"}.fa-venus:before{content:"\f221"}.fa-mars:before{content:"\f222"}.fa-mercury:before{content:"\f223"}.fa-transgender:before{content:"\f224"}.fa-transgender-alt:before{content:"\f225"}.fa-venus-double:before{content:"\f226"}.fa-mars-double:before{content:"\f227"}.fa-venus-mars:before{content:"\f228"}.fa-mars-stroke:before{content:"\f229"}.fa-mars-stroke-v:before{content:"\f22a"}.fa-mars-stroke-h:before{content:"\f22b"}.fa-neuter:before{content:"\f22c"}.fa-facebook-official:before{content:"\f230"}.fa-pinterest-p:before{content:"\f231"}.fa-whatsapp:before{content:"\f232"}.fa-server:before{content:"\f233"}.fa-user-plus:before{content:"\f234"}.fa-user-times:before{content:"\f235"}.fa-hotel:before,.fa-bed:before{content:"\f236"}.fa-viacoin:before{content:"\f237"}.fa-train:before{content:"\f238"}.fa-subway:before{content:"\f239"}.fa-medium:before{content:"\f23a"}
|
1 |
+
/*!
|
2 |
+
* Font Awesome 4.3.0 by @davegandy - http://fontawesome.io - @fontawesome
|
3 |
+
* License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License)
|
4 |
*/@font-face{font-family:'FontAwesome';src:url('../fonts/fontawesome-webfont.eot?v=4.3.0');src:url('../fonts/fontawesome-webfont.eot?#iefix&v=4.3.0') format('embedded-opentype'),url('../fonts/fontawesome-webfont.woff2?v=4.3.0') format('woff2'),url('../fonts/fontawesome-webfont.woff?v=4.3.0') format('woff'),url('../fonts/fontawesome-webfont.ttf?v=4.3.0') format('truetype'),url('../fonts/fontawesome-webfont.svg?v=4.3.0#fontawesomeregular') format('svg');font-weight:normal;font-style:normal}.fa{display:inline-block;font:normal normal normal 14px/1 FontAwesome;font-size:inherit;text-rendering:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transform:translate(0, 0)}.fa-lg{font-size:1.33333333em;line-height:.75em;vertical-align:-15%}.fa-2x{font-size:2em}.fa-3x{font-size:3em}.fa-4x{font-size:4em}.fa-5x{font-size:5em}.fa-fw{width:1.28571429em;text-align:center}.fa-ul{padding-left:0;margin-left:2.14285714em;list-style-type:none}.fa-ul>li{position:relative}.fa-li{position:absolute;left:-2.14285714em;width:2.14285714em;top:.14285714em;text-align:center}.fa-li.fa-lg{left:-1.85714286em}.fa-border{padding:.2em .25em .15em;border:solid .08em #eee;border-radius:.1em}.pull-right{float:right}.pull-left{float:left}.fa.pull-left{margin-right:.3em}.fa.pull-right{margin-left:.3em}.fa-spin{-webkit-animation:fa-spin 2s infinite linear;animation:fa-spin 2s infinite linear}.fa-pulse{-webkit-animation:fa-spin 1s infinite steps(8);animation:fa-spin 1s infinite steps(8)}@-webkit-keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}@keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.fa-rotate-90{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=1);-webkit-transform:rotate(90deg);-ms-transform:rotate(90deg);transform:rotate(90deg)}.fa-rotate-180{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=2);-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg)}.fa-rotate-270{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=3);-webkit-transform:rotate(270deg);-ms-transform:rotate(270deg);transform:rotate(270deg)}.fa-flip-horizontal{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1);-webkit-transform:scale(-1, 1);-ms-transform:scale(-1, 1);transform:scale(-1, 1)}.fa-flip-vertical{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1);-webkit-transform:scale(1, -1);-ms-transform:scale(1, -1);transform:scale(1, -1)}:root .fa-rotate-90,:root .fa-rotate-180,:root .fa-rotate-270,:root .fa-flip-horizontal,:root .fa-flip-vertical{filter:none}.fa-stack{position:relative;display:inline-block;width:2em;height:2em;line-height:2em;vertical-align:middle}.fa-stack-1x,.fa-stack-2x{position:absolute;left:0;width:100%;text-align:center}.fa-stack-1x{line-height:inherit}.fa-stack-2x{font-size:2em}.fa-inverse{color:#fff}.fa-glass:before{content:"\f000"}.fa-music:before{content:"\f001"}.fa-search:before{content:"\f002"}.fa-envelope-o:before{content:"\f003"}.fa-heart:before{content:"\f004"}.fa-star:before{content:"\f005"}.fa-star-o:before{content:"\f006"}.fa-user:before{content:"\f007"}.fa-film:before{content:"\f008"}.fa-th-large:before{content:"\f009"}.fa-th:before{content:"\f00a"}.fa-th-list:before{content:"\f00b"}.fa-check:before{content:"\f00c"}.fa-remove:before,.fa-close:before,.fa-times:before{content:"\f00d"}.fa-search-plus:before{content:"\f00e"}.fa-search-minus:before{content:"\f010"}.fa-power-off:before{content:"\f011"}.fa-signal:before{content:"\f012"}.fa-gear:before,.fa-cog:before{content:"\f013"}.fa-trash-o:before{content:"\f014"}.fa-home:before{content:"\f015"}.fa-file-o:before{content:"\f016"}.fa-clock-o:before{content:"\f017"}.fa-road:before{content:"\f018"}.fa-download:before{content:"\f019"}.fa-arrow-circle-o-down:before{content:"\f01a"}.fa-arrow-circle-o-up:before{content:"\f01b"}.fa-inbox:before{content:"\f01c"}.fa-play-circle-o:before{content:"\f01d"}.fa-rotate-right:before,.fa-repeat:before{content:"\f01e"}.fa-refresh:before{content:"\f021"}.fa-list-alt:before{content:"\f022"}.fa-lock:before{content:"\f023"}.fa-flag:before{content:"\f024"}.fa-headphones:before{content:"\f025"}.fa-volume-off:before{content:"\f026"}.fa-volume-down:before{content:"\f027"}.fa-volume-up:before{content:"\f028"}.fa-qrcode:before{content:"\f029"}.fa-barcode:before{content:"\f02a"}.fa-tag:before{content:"\f02b"}.fa-tags:before{content:"\f02c"}.fa-book:before{content:"\f02d"}.fa-bookmark:before{content:"\f02e"}.fa-print:before{content:"\f02f"}.fa-camera:before{content:"\f030"}.fa-font:before{content:"\f031"}.fa-bold:before{content:"\f032"}.fa-italic:before{content:"\f033"}.fa-text-height:before{content:"\f034"}.fa-text-width:before{content:"\f035"}.fa-align-left:before{content:"\f036"}.fa-align-center:before{content:"\f037"}.fa-align-right:before{content:"\f038"}.fa-align-justify:before{content:"\f039"}.fa-list:before{content:"\f03a"}.fa-dedent:before,.fa-outdent:before{content:"\f03b"}.fa-indent:before{content:"\f03c"}.fa-video-camera:before{content:"\f03d"}.fa-photo:before,.fa-image:before,.fa-picture-o:before{content:"\f03e"}.fa-pencil:before{content:"\f040"}.fa-map-marker:before{content:"\f041"}.fa-adjust:before{content:"\f042"}.fa-tint:before{content:"\f043"}.fa-edit:before,.fa-pencil-square-o:before{content:"\f044"}.fa-share-square-o:before{content:"\f045"}.fa-check-square-o:before{content:"\f046"}.fa-arrows:before{content:"\f047"}.fa-step-backward:before{content:"\f048"}.fa-fast-backward:before{content:"\f049"}.fa-backward:before{content:"\f04a"}.fa-play:before{content:"\f04b"}.fa-pause:before{content:"\f04c"}.fa-stop:before{content:"\f04d"}.fa-forward:before{content:"\f04e"}.fa-fast-forward:before{content:"\f050"}.fa-step-forward:before{content:"\f051"}.fa-eject:before{content:"\f052"}.fa-chevron-left:before{content:"\f053"}.fa-chevron-right:before{content:"\f054"}.fa-plus-circle:before{content:"\f055"}.fa-minus-circle:before{content:"\f056"}.fa-times-circle:before{content:"\f057"}.fa-check-circle:before{content:"\f058"}.fa-question-circle:before{content:"\f059"}.fa-info-circle:before{content:"\f05a"}.fa-crosshairs:before{content:"\f05b"}.fa-times-circle-o:before{content:"\f05c"}.fa-check-circle-o:before{content:"\f05d"}.fa-ban:before{content:"\f05e"}.fa-arrow-left:before{content:"\f060"}.fa-arrow-right:before{content:"\f061"}.fa-arrow-up:before{content:"\f062"}.fa-arrow-down:before{content:"\f063"}.fa-mail-forward:before,.fa-share:before{content:"\f064"}.fa-expand:before{content:"\f065"}.fa-compress:before{content:"\f066"}.fa-plus:before{content:"\f067"}.fa-minus:before{content:"\f068"}.fa-asterisk:before{content:"\f069"}.fa-exclamation-circle:before{content:"\f06a"}.fa-gift:before{content:"\f06b"}.fa-leaf:before{content:"\f06c"}.fa-fire:before{content:"\f06d"}.fa-eye:before{content:"\f06e"}.fa-eye-slash:before{content:"\f070"}.fa-warning:before,.fa-exclamation-triangle:before{content:"\f071"}.fa-plane:before{content:"\f072"}.fa-calendar:before{content:"\f073"}.fa-random:before{content:"\f074"}.fa-comment:before{content:"\f075"}.fa-magnet:before{content:"\f076"}.fa-chevron-up:before{content:"\f077"}.fa-chevron-down:before{content:"\f078"}.fa-retweet:before{content:"\f079"}.fa-shopping-cart:before{content:"\f07a"}.fa-folder:before{content:"\f07b"}.fa-folder-open:before{content:"\f07c"}.fa-arrows-v:before{content:"\f07d"}.fa-arrows-h:before{content:"\f07e"}.fa-bar-chart-o:before,.fa-bar-chart:before{content:"\f080"}.fa-twitter-square:before{content:"\f081"}.fa-facebook-square:before{content:"\f082"}.fa-camera-retro:before{content:"\f083"}.fa-key:before{content:"\f084"}.fa-gears:before,.fa-cogs:before{content:"\f085"}.fa-comments:before{content:"\f086"}.fa-thumbs-o-up:before{content:"\f087"}.fa-thumbs-o-down:before{content:"\f088"}.fa-star-half:before{content:"\f089"}.fa-heart-o:before{content:"\f08a"}.fa-sign-out:before{content:"\f08b"}.fa-linkedin-square:before{content:"\f08c"}.fa-thumb-tack:before{content:"\f08d"}.fa-external-link:before{content:"\f08e"}.fa-sign-in:before{content:"\f090"}.fa-trophy:before{content:"\f091"}.fa-github-square:before{content:"\f092"}.fa-upload:before{content:"\f093"}.fa-lemon-o:before{content:"\f094"}.fa-phone:before{content:"\f095"}.fa-square-o:before{content:"\f096"}.fa-bookmark-o:before{content:"\f097"}.fa-phone-square:before{content:"\f098"}.fa-twitter:before{content:"\f099"}.fa-facebook-f:before,.fa-facebook:before{content:"\f09a"}.fa-github:before{content:"\f09b"}.fa-unlock:before{content:"\f09c"}.fa-credit-card:before{content:"\f09d"}.fa-rss:before{content:"\f09e"}.fa-hdd-o:before{content:"\f0a0"}.fa-bullhorn:before{content:"\f0a1"}.fa-bell:before{content:"\f0f3"}.fa-certificate:before{content:"\f0a3"}.fa-hand-o-right:before{content:"\f0a4"}.fa-hand-o-left:before{content:"\f0a5"}.fa-hand-o-up:before{content:"\f0a6"}.fa-hand-o-down:before{content:"\f0a7"}.fa-arrow-circle-left:before{content:"\f0a8"}.fa-arrow-circle-right:before{content:"\f0a9"}.fa-arrow-circle-up:before{content:"\f0aa"}.fa-arrow-circle-down:before{content:"\f0ab"}.fa-globe:before{content:"\f0ac"}.fa-wrench:before{content:"\f0ad"}.fa-tasks:before{content:"\f0ae"}.fa-filter:before{content:"\f0b0"}.fa-briefcase:before{content:"\f0b1"}.fa-arrows-alt:before{content:"\f0b2"}.fa-group:before,.fa-users:before{content:"\f0c0"}.fa-chain:before,.fa-link:before{content:"\f0c1"}.fa-cloud:before{content:"\f0c2"}.fa-flask:before{content:"\f0c3"}.fa-cut:before,.fa-scissors:before{content:"\f0c4"}.fa-copy:before,.fa-files-o:before{content:"\f0c5"}.fa-paperclip:before{content:"\f0c6"}.fa-save:before,.fa-floppy-o:before{content:"\f0c7"}.fa-square:before{content:"\f0c8"}.fa-navicon:before,.fa-reorder:before,.fa-bars:before{content:"\f0c9"}.fa-list-ul:before{content:"\f0ca"}.fa-list-ol:before{content:"\f0cb"}.fa-strikethrough:before{content:"\f0cc"}.fa-underline:before{content:"\f0cd"}.fa-table:before{content:"\f0ce"}.fa-magic:before{content:"\f0d0"}.fa-truck:before{content:"\f0d1"}.fa-pinterest:before{content:"\f0d2"}.fa-pinterest-square:before{content:"\f0d3"}.fa-google-plus-square:before{content:"\f0d4"}.fa-google-plus:before{content:"\f0d5"}.fa-money:before{content:"\f0d6"}.fa-caret-down:before{content:"\f0d7"}.fa-caret-up:before{content:"\f0d8"}.fa-caret-left:before{content:"\f0d9"}.fa-caret-right:before{content:"\f0da"}.fa-columns:before{content:"\f0db"}.fa-unsorted:before,.fa-sort:before{content:"\f0dc"}.fa-sort-down:before,.fa-sort-desc:before{content:"\f0dd"}.fa-sort-up:before,.fa-sort-asc:before{content:"\f0de"}.fa-envelope:before{content:"\f0e0"}.fa-linkedin:before{content:"\f0e1"}.fa-rotate-left:before,.fa-undo:before{content:"\f0e2"}.fa-legal:before,.fa-gavel:before{content:"\f0e3"}.fa-dashboard:before,.fa-tachometer:before{content:"\f0e4"}.fa-comment-o:before{content:"\f0e5"}.fa-comments-o:before{content:"\f0e6"}.fa-flash:before,.fa-bolt:before{content:"\f0e7"}.fa-sitemap:before{content:"\f0e8"}.fa-umbrella:before{content:"\f0e9"}.fa-paste:before,.fa-clipboard:before{content:"\f0ea"}.fa-lightbulb-o:before{content:"\f0eb"}.fa-exchange:before{content:"\f0ec"}.fa-cloud-download:before{content:"\f0ed"}.fa-cloud-upload:before{content:"\f0ee"}.fa-user-md:before{content:"\f0f0"}.fa-stethoscope:before{content:"\f0f1"}.fa-suitcase:before{content:"\f0f2"}.fa-bell-o:before{content:"\f0a2"}.fa-coffee:before{content:"\f0f4"}.fa-cutlery:before{content:"\f0f5"}.fa-file-text-o:before{content:"\f0f6"}.fa-building-o:before{content:"\f0f7"}.fa-hospital-o:before{content:"\f0f8"}.fa-ambulance:before{content:"\f0f9"}.fa-medkit:before{content:"\f0fa"}.fa-fighter-jet:before{content:"\f0fb"}.fa-beer:before{content:"\f0fc"}.fa-h-square:before{content:"\f0fd"}.fa-plus-square:before{content:"\f0fe"}.fa-angle-double-left:before{content:"\f100"}.fa-angle-double-right:before{content:"\f101"}.fa-angle-double-up:before{content:"\f102"}.fa-angle-double-down:before{content:"\f103"}.fa-angle-left:before{content:"\f104"}.fa-angle-right:before{content:"\f105"}.fa-angle-up:before{content:"\f106"}.fa-angle-down:before{content:"\f107"}.fa-desktop:before{content:"\f108"}.fa-laptop:before{content:"\f109"}.fa-tablet:before{content:"\f10a"}.fa-mobile-phone:before,.fa-mobile:before{content:"\f10b"}.fa-circle-o:before{content:"\f10c"}.fa-quote-left:before{content:"\f10d"}.fa-quote-right:before{content:"\f10e"}.fa-spinner:before{content:"\f110"}.fa-circle:before{content:"\f111"}.fa-mail-reply:before,.fa-reply:before{content:"\f112"}.fa-github-alt:before{content:"\f113"}.fa-folder-o:before{content:"\f114"}.fa-folder-open-o:before{content:"\f115"}.fa-smile-o:before{content:"\f118"}.fa-frown-o:before{content:"\f119"}.fa-meh-o:before{content:"\f11a"}.fa-gamepad:before{content:"\f11b"}.fa-keyboard-o:before{content:"\f11c"}.fa-flag-o:before{content:"\f11d"}.fa-flag-checkered:before{content:"\f11e"}.fa-terminal:before{content:"\f120"}.fa-code:before{content:"\f121"}.fa-mail-reply-all:before,.fa-reply-all:before{content:"\f122"}.fa-star-half-empty:before,.fa-star-half-full:before,.fa-star-half-o:before{content:"\f123"}.fa-location-arrow:before{content:"\f124"}.fa-crop:before{content:"\f125"}.fa-code-fork:before{content:"\f126"}.fa-unlink:before,.fa-chain-broken:before{content:"\f127"}.fa-question:before{content:"\f128"}.fa-info:before{content:"\f129"}.fa-exclamation:before{content:"\f12a"}.fa-superscript:before{content:"\f12b"}.fa-subscript:before{content:"\f12c"}.fa-eraser:before{content:"\f12d"}.fa-puzzle-piece:before{content:"\f12e"}.fa-microphone:before{content:"\f130"}.fa-microphone-slash:before{content:"\f131"}.fa-shield:before{content:"\f132"}.fa-calendar-o:before{content:"\f133"}.fa-fire-extinguisher:before{content:"\f134"}.fa-rocket:before{content:"\f135"}.fa-maxcdn:before{content:"\f136"}.fa-chevron-circle-left:before{content:"\f137"}.fa-chevron-circle-right:before{content:"\f138"}.fa-chevron-circle-up:before{content:"\f139"}.fa-chevron-circle-down:before{content:"\f13a"}.fa-html5:before{content:"\f13b"}.fa-css3:before{content:"\f13c"}.fa-anchor:before{content:"\f13d"}.fa-unlock-alt:before{content:"\f13e"}.fa-bullseye:before{content:"\f140"}.fa-ellipsis-h:before{content:"\f141"}.fa-ellipsis-v:before{content:"\f142"}.fa-rss-square:before{content:"\f143"}.fa-play-circle:before{content:"\f144"}.fa-ticket:before{content:"\f145"}.fa-minus-square:before{content:"\f146"}.fa-minus-square-o:before{content:"\f147"}.fa-level-up:before{content:"\f148"}.fa-level-down:before{content:"\f149"}.fa-check-square:before{content:"\f14a"}.fa-pencil-square:before{content:"\f14b"}.fa-external-link-square:before{content:"\f14c"}.fa-share-square:before{content:"\f14d"}.fa-compass:before{content:"\f14e"}.fa-toggle-down:before,.fa-caret-square-o-down:before{content:"\f150"}.fa-toggle-up:before,.fa-caret-square-o-up:before{content:"\f151"}.fa-toggle-right:before,.fa-caret-square-o-right:before{content:"\f152"}.fa-euro:before,.fa-eur:before{content:"\f153"}.fa-gbp:before{content:"\f154"}.fa-dollar:before,.fa-usd:before{content:"\f155"}.fa-rupee:before,.fa-inr:before{content:"\f156"}.fa-cny:before,.fa-rmb:before,.fa-yen:before,.fa-jpy:before{content:"\f157"}.fa-ruble:before,.fa-rouble:before,.fa-rub:before{content:"\f158"}.fa-won:before,.fa-krw:before{content:"\f159"}.fa-bitcoin:before,.fa-btc:before{content:"\f15a"}.fa-file:before{content:"\f15b"}.fa-file-text:before{content:"\f15c"}.fa-sort-alpha-asc:before{content:"\f15d"}.fa-sort-alpha-desc:before{content:"\f15e"}.fa-sort-amount-asc:before{content:"\f160"}.fa-sort-amount-desc:before{content:"\f161"}.fa-sort-numeric-asc:before{content:"\f162"}.fa-sort-numeric-desc:before{content:"\f163"}.fa-thumbs-up:before{content:"\f164"}.fa-thumbs-down:before{content:"\f165"}.fa-youtube-square:before{content:"\f166"}.fa-youtube:before{content:"\f167"}.fa-xing:before{content:"\f168"}.fa-xing-square:before{content:"\f169"}.fa-youtube-play:before{content:"\f16a"}.fa-dropbox:before{content:"\f16b"}.fa-stack-overflow:before{content:"\f16c"}.fa-instagram:before{content:"\f16d"}.fa-flickr:before{content:"\f16e"}.fa-adn:before{content:"\f170"}.fa-bitbucket:before{content:"\f171"}.fa-bitbucket-square:before{content:"\f172"}.fa-tumblr:before{content:"\f173"}.fa-tumblr-square:before{content:"\f174"}.fa-long-arrow-down:before{content:"\f175"}.fa-long-arrow-up:before{content:"\f176"}.fa-long-arrow-left:before{content:"\f177"}.fa-long-arrow-right:before{content:"\f178"}.fa-apple:before{content:"\f179"}.fa-windows:before{content:"\f17a"}.fa-android:before{content:"\f17b"}.fa-linux:before{content:"\f17c"}.fa-dribbble:before{content:"\f17d"}.fa-skype:before{content:"\f17e"}.fa-foursquare:before{content:"\f180"}.fa-trello:before{content:"\f181"}.fa-female:before{content:"\f182"}.fa-male:before{content:"\f183"}.fa-gittip:before,.fa-gratipay:before{content:"\f184"}.fa-sun-o:before{content:"\f185"}.fa-moon-o:before{content:"\f186"}.fa-archive:before{content:"\f187"}.fa-bug:before{content:"\f188"}.fa-vk:before{content:"\f189"}.fa-weibo:before{content:"\f18a"}.fa-renren:before{content:"\f18b"}.fa-pagelines:before{content:"\f18c"}.fa-stack-exchange:before{content:"\f18d"}.fa-arrow-circle-o-right:before{content:"\f18e"}.fa-arrow-circle-o-left:before{content:"\f190"}.fa-toggle-left:before,.fa-caret-square-o-left:before{content:"\f191"}.fa-dot-circle-o:before{content:"\f192"}.fa-wheelchair:before{content:"\f193"}.fa-vimeo-square:before{content:"\f194"}.fa-turkish-lira:before,.fa-try:before{content:"\f195"}.fa-plus-square-o:before{content:"\f196"}.fa-space-shuttle:before{content:"\f197"}.fa-slack:before{content:"\f198"}.fa-envelope-square:before{content:"\f199"}.fa-wordpress:before{content:"\f19a"}.fa-openid:before{content:"\f19b"}.fa-institution:before,.fa-bank:before,.fa-university:before{content:"\f19c"}.fa-mortar-board:before,.fa-graduation-cap:before{content:"\f19d"}.fa-yahoo:before{content:"\f19e"}.fa-google:before{content:"\f1a0"}.fa-reddit:before{content:"\f1a1"}.fa-reddit-square:before{content:"\f1a2"}.fa-stumbleupon-circle:before{content:"\f1a3"}.fa-stumbleupon:before{content:"\f1a4"}.fa-delicious:before{content:"\f1a5"}.fa-digg:before{content:"\f1a6"}.fa-pied-piper:before{content:"\f1a7"}.fa-pied-piper-alt:before{content:"\f1a8"}.fa-drupal:before{content:"\f1a9"}.fa-joomla:before{content:"\f1aa"}.fa-language:before{content:"\f1ab"}.fa-fax:before{content:"\f1ac"}.fa-building:before{content:"\f1ad"}.fa-child:before{content:"\f1ae"}.fa-paw:before{content:"\f1b0"}.fa-spoon:before{content:"\f1b1"}.fa-cube:before{content:"\f1b2"}.fa-cubes:before{content:"\f1b3"}.fa-behance:before{content:"\f1b4"}.fa-behance-square:before{content:"\f1b5"}.fa-steam:before{content:"\f1b6"}.fa-steam-square:before{content:"\f1b7"}.fa-recycle:before{content:"\f1b8"}.fa-automobile:before,.fa-car:before{content:"\f1b9"}.fa-cab:before,.fa-taxi:before{content:"\f1ba"}.fa-tree:before{content:"\f1bb"}.fa-spotify:before{content:"\f1bc"}.fa-deviantart:before{content:"\f1bd"}.fa-soundcloud:before{content:"\f1be"}.fa-database:before{content:"\f1c0"}.fa-file-pdf-o:before{content:"\f1c1"}.fa-file-word-o:before{content:"\f1c2"}.fa-file-excel-o:before{content:"\f1c3"}.fa-file-powerpoint-o:before{content:"\f1c4"}.fa-file-photo-o:before,.fa-file-picture-o:before,.fa-file-image-o:before{content:"\f1c5"}.fa-file-zip-o:before,.fa-file-archive-o:before{content:"\f1c6"}.fa-file-sound-o:before,.fa-file-audio-o:before{content:"\f1c7"}.fa-file-movie-o:before,.fa-file-video-o:before{content:"\f1c8"}.fa-file-code-o:before{content:"\f1c9"}.fa-vine:before{content:"\f1ca"}.fa-codepen:before{content:"\f1cb"}.fa-jsfiddle:before{content:"\f1cc"}.fa-life-bouy:before,.fa-life-buoy:before,.fa-life-saver:before,.fa-support:before,.fa-life-ring:before{content:"\f1cd"}.fa-circle-o-notch:before{content:"\f1ce"}.fa-ra:before,.fa-rebel:before{content:"\f1d0"}.fa-ge:before,.fa-empire:before{content:"\f1d1"}.fa-git-square:before{content:"\f1d2"}.fa-git:before{content:"\f1d3"}.fa-hacker-news:before{content:"\f1d4"}.fa-tencent-weibo:before{content:"\f1d5"}.fa-qq:before{content:"\f1d6"}.fa-wechat:before,.fa-weixin:before{content:"\f1d7"}.fa-send:before,.fa-paper-plane:before{content:"\f1d8"}.fa-send-o:before,.fa-paper-plane-o:before{content:"\f1d9"}.fa-history:before{content:"\f1da"}.fa-genderless:before,.fa-circle-thin:before{content:"\f1db"}.fa-header:before{content:"\f1dc"}.fa-paragraph:before{content:"\f1dd"}.fa-sliders:before{content:"\f1de"}.fa-share-alt:before{content:"\f1e0"}.fa-share-alt-square:before{content:"\f1e1"}.fa-bomb:before{content:"\f1e2"}.fa-soccer-ball-o:before,.fa-futbol-o:before{content:"\f1e3"}.fa-tty:before{content:"\f1e4"}.fa-binoculars:before{content:"\f1e5"}.fa-plug:before{content:"\f1e6"}.fa-slideshare:before{content:"\f1e7"}.fa-twitch:before{content:"\f1e8"}.fa-yelp:before{content:"\f1e9"}.fa-newspaper-o:before{content:"\f1ea"}.fa-wifi:before{content:"\f1eb"}.fa-calculator:before{content:"\f1ec"}.fa-paypal:before{content:"\f1ed"}.fa-google-wallet:before{content:"\f1ee"}.fa-cc-visa:before{content:"\f1f0"}.fa-cc-mastercard:before{content:"\f1f1"}.fa-cc-discover:before{content:"\f1f2"}.fa-cc-amex:before{content:"\f1f3"}.fa-cc-paypal:before{content:"\f1f4"}.fa-cc-stripe:before{content:"\f1f5"}.fa-bell-slash:before{content:"\f1f6"}.fa-bell-slash-o:before{content:"\f1f7"}.fa-trash:before{content:"\f1f8"}.fa-copyright:before{content:"\f1f9"}.fa-at:before{content:"\f1fa"}.fa-eyedropper:before{content:"\f1fb"}.fa-paint-brush:before{content:"\f1fc"}.fa-birthday-cake:before{content:"\f1fd"}.fa-area-chart:before{content:"\f1fe"}.fa-pie-chart:before{content:"\f200"}.fa-line-chart:before{content:"\f201"}.fa-lastfm:before{content:"\f202"}.fa-lastfm-square:before{content:"\f203"}.fa-toggle-off:before{content:"\f204"}.fa-toggle-on:before{content:"\f205"}.fa-bicycle:before{content:"\f206"}.fa-bus:before{content:"\f207"}.fa-ioxhost:before{content:"\f208"}.fa-angellist:before{content:"\f209"}.fa-cc:before{content:"\f20a"}.fa-shekel:before,.fa-sheqel:before,.fa-ils:before{content:"\f20b"}.fa-meanpath:before{content:"\f20c"}.fa-buysellads:before{content:"\f20d"}.fa-connectdevelop:before{content:"\f20e"}.fa-dashcube:before{content:"\f210"}.fa-forumbee:before{content:"\f211"}.fa-leanpub:before{content:"\f212"}.fa-sellsy:before{content:"\f213"}.fa-shirtsinbulk:before{content:"\f214"}.fa-simplybuilt:before{content:"\f215"}.fa-skyatlas:before{content:"\f216"}.fa-cart-plus:before{content:"\f217"}.fa-cart-arrow-down:before{content:"\f218"}.fa-diamond:before{content:"\f219"}.fa-ship:before{content:"\f21a"}.fa-user-secret:before{content:"\f21b"}.fa-motorcycle:before{content:"\f21c"}.fa-street-view:before{content:"\f21d"}.fa-heartbeat:before{content:"\f21e"}.fa-venus:before{content:"\f221"}.fa-mars:before{content:"\f222"}.fa-mercury:before{content:"\f223"}.fa-transgender:before{content:"\f224"}.fa-transgender-alt:before{content:"\f225"}.fa-venus-double:before{content:"\f226"}.fa-mars-double:before{content:"\f227"}.fa-venus-mars:before{content:"\f228"}.fa-mars-stroke:before{content:"\f229"}.fa-mars-stroke-v:before{content:"\f22a"}.fa-mars-stroke-h:before{content:"\f22b"}.fa-neuter:before{content:"\f22c"}.fa-facebook-official:before{content:"\f230"}.fa-pinterest-p:before{content:"\f231"}.fa-whatsapp:before{content:"\f232"}.fa-server:before{content:"\f233"}.fa-user-plus:before{content:"\f234"}.fa-user-times:before{content:"\f235"}.fa-hotel:before,.fa-bed:before{content:"\f236"}.fa-viacoin:before{content:"\f237"}.fa-train:before{content:"\f238"}.fa-subway:before{content:"\f239"}.fa-medium:before{content:"\f23a"}
|
inc/css/gawd_front.css
CHANGED
@@ -1,5 +1,5 @@
|
|
1 |
-
.gawd_draw_analytics_front{
|
2 |
-
padding: 2px;
|
3 |
-
line-height: 28px;
|
4 |
-
height: 28px;
|
5 |
}
|
1 |
+
.gawd_draw_analytics_front{
|
2 |
+
padding: 2px;
|
3 |
+
line-height: 28px;
|
4 |
+
height: 28px;
|
5 |
}
|
inc/css/jquery-ui.css
CHANGED
@@ -1,566 +1,566 @@
|
|
1 |
-
/*
|
2 |
-
* jQuery UI CSS Framework 1.8.14
|
3 |
-
*
|
4 |
-
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
5 |
-
* Dual licensed under the MIT or GPL Version 2 licenses.
|
6 |
-
* http://jquery.org/license
|
7 |
-
*
|
8 |
-
* http://docs.jquery.com/UI/Theming/API
|
9 |
-
*/
|
10 |
-
|
11 |
-
/* Layout helpers
|
12 |
-
----------------------------------*/
|
13 |
-
.ui-helper-hidden { display: none; }
|
14 |
-
.ui-helper-hidden-accessible { position: absolute !important; clip: rect(1px 1px 1px 1px); clip: rect(1px,1px,1px,1px); }
|
15 |
-
.ui-helper-reset { margin: 0; padding: 0; border: 0; outline: 0; line-height: 1.3; text-decoration: none; font-size: 100%; list-style: none; }
|
16 |
-
.ui-helper-clearfix:after { content: "."; display: block; height: 0; clear: both; visibility: hidden; }
|
17 |
-
.ui-helper-clearfix { display: inline-block; }
|
18 |
-
/* required comment for clearfix to work in Opera \*/
|
19 |
-
* html .ui-helper-clearfix { height:1%; }
|
20 |
-
.ui-helper-clearfix { display:block; }
|
21 |
-
/* end clearfix */
|
22 |
-
.ui-helper-zfix { width: 100%; height: 100%; top: 0; left: 0; position: absolute; opacity: 0; filter:Alpha(Opacity=0); }
|
23 |
-
|
24 |
-
|
25 |
-
/* Interaction Cues
|
26 |
-
----------------------------------*/
|
27 |
-
.ui-state-disabled { cursor: default !important; }
|
28 |
-
|
29 |
-
|
30 |
-
/* Icons
|
31 |
-
----------------------------------*/
|
32 |
-
|
33 |
-
/* states and images */
|
34 |
-
.ui-icon { display: block; text-indent: -99999px; overflow: hidden; background-repeat: no-repeat; }
|
35 |
-
|
36 |
-
|
37 |
-
/* Misc visuals
|
38 |
-
----------------------------------*/
|
39 |
-
|
40 |
-
/* Overlays */
|
41 |
-
.ui-widget-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
|
42 |
-
/*
|
43 |
-
* jQuery UI Accordion 1.8.14
|
44 |
-
*
|
45 |
-
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
46 |
-
* Dual licensed under the MIT or GPL Version 2 licenses.
|
47 |
-
* http://jquery.org/license
|
48 |
-
*
|
49 |
-
* http://docs.jquery.com/UI/Accordion#theming
|
50 |
-
*/
|
51 |
-
/* IE/Win - Fix animation bug - #4615 */
|
52 |
-
.ui-accordion { width: 100%; }
|
53 |
-
.ui-accordion .ui-accordion-header { cursor: pointer; position: relative; margin-top: 1px; zoom: 1; }
|
54 |
-
.ui-accordion .ui-accordion-li-fix { display: inline; }
|
55 |
-
.ui-accordion .ui-accordion-header-active { border-bottom: 0 !important; }
|
56 |
-
.ui-accordion .ui-accordion-header a { display: block; font-size: 1em; padding: .5em .5em .5em .7em; }
|
57 |
-
.ui-accordion-icons .ui-accordion-header a { padding-left: 2.2em; }
|
58 |
-
.ui-accordion .ui-accordion-header .ui-icon { position: absolute; left: .5em; top: 50%; margin-top: -8px; }
|
59 |
-
.ui-accordion .ui-accordion-content { padding: 1em 2.2em; border-top: 0; margin-top: -2px; position: relative; top: 1px; margin-bottom: 2px; overflow: auto; display: none; zoom: 1; }
|
60 |
-
.ui-accordion .ui-accordion-content-active { display: block; }
|
61 |
-
/*
|
62 |
-
* jQuery UI Autocomplete 1.8.14
|
63 |
-
*
|
64 |
-
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
65 |
-
* Dual licensed under the MIT or GPL Version 2 licenses.
|
66 |
-
* http://jquery.org/license
|
67 |
-
*
|
68 |
-
* http://docs.jquery.com/UI/Autocomplete#theming
|
69 |
-
*/
|
70 |
-
.ui-autocomplete { position: absolute; cursor: default; }
|
71 |
-
|
72 |
-
/* workarounds */
|
73 |
-
* html .ui-autocomplete { width:1px; } /* without this, the menu expands to 100% in IE6 */
|
74 |
-
|
75 |
-
/*
|
76 |
-
* jQuery UI Menu 1.8.14
|
77 |
-
*
|
78 |
-
* Copyright 2010, AUTHORS.txt (http://jqueryui.com/about)
|
79 |
-
* Dual licensed under the MIT or GPL Version 2 licenses.
|
80 |
-
* http://jquery.org/license
|
81 |
-
*
|
82 |
-
* http://docs.jquery.com/UI/Menu#theming
|
83 |
-
*/
|
84 |
-
.ui-menu {
|
85 |
-
list-style:none;
|
86 |
-
padding: 2px;
|
87 |
-
margin: 0;
|
88 |
-
display:block;
|
89 |
-
float: left;
|
90 |
-
}
|
91 |
-
.ui-menu .ui-menu {
|
92 |
-
margin-top: -3px;
|
93 |
-
}
|
94 |
-
.ui-menu .ui-menu-item {
|
95 |
-
margin:0;
|
96 |
-
padding: 0;
|
97 |
-
zoom: 1;
|
98 |
-
float: left;
|
99 |
-
clear: left;
|
100 |
-
width: 100%;
|
101 |
-
}
|
102 |
-
.ui-menu .ui-menu-item a {
|
103 |
-
text-decoration:none;
|
104 |
-
display:block;
|
105 |
-
padding:.2em .4em;
|
106 |
-
line-height:1.5;
|
107 |
-
zoom:1;
|
108 |
-
}
|
109 |
-
.ui-menu .ui-menu-item a.ui-state-hover,
|
110 |
-
.ui-menu .ui-menu-item a.ui-state-active {
|
111 |
-
font-weight: normal;
|
112 |
-
margin: -1px;
|
113 |
-
}
|
114 |
-
/*
|
115 |
-
* jQuery UI Button 1.8.14
|
116 |
-
*
|
117 |
-
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
118 |
-
* Dual licensed under the MIT or GPL Version 2 licenses.
|
119 |
-
* http://jquery.org/license
|
120 |
-
*
|
121 |
-
* http://docs.jquery.com/UI/Button#theming
|
122 |
-
*/
|
123 |
-
.ui-button { display: inline-block; position: relative; padding: 0; margin-right: .1em; text-decoration: none !important; cursor: pointer; text-align: center; zoom: 1; overflow: visible; } /* the overflow property removes extra width in IE */
|
124 |
-
.ui-button-icon-only { width: 2.2em; } /* to make room for the icon, a width needs to be set here */
|
125 |
-
button.ui-button-icon-only { width: 2.4em; } /* button elements seem to need a little more width */
|
126 |
-
.ui-button-icons-only { width: 3.4em; }
|
127 |
-
button.ui-button-icons-only { width: 3.7em; }
|
128 |
-
|
129 |
-
/*button text element */
|
130 |
-
.ui-button .ui-button-text { display: block; line-height: 1.4; }
|
131 |
-
.ui-button-text-only .ui-button-text { padding: .4em 1em; }
|
132 |
-
.ui-button-icon-only .ui-button-text, .ui-button-icons-only .ui-button-text { padding: .4em; text-indent: -9999999px; }
|
133 |
-
.ui-button-text-icon-primary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 1em .4em 2.1em; }
|
134 |
-
.ui-button-text-icon-secondary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 2.1em .4em 1em; }
|
135 |
-
.ui-button-text-icons .ui-button-text { padding-left: 2.1em; padding-right: 2.1em; }
|
136 |
-
/* no icon support for input elements, provide padding by default */
|
137 |
-
input.ui-button { padding: .4em 1em; }
|
138 |
-
|
139 |
-
/*button icon element(s) */
|
140 |
-
.ui-button-icon-only .ui-icon, .ui-button-text-icon-primary .ui-icon, .ui-button-text-icon-secondary .ui-icon, .ui-button-text-icons .ui-icon, .ui-button-icons-only .ui-icon { position: absolute; top: 50%; margin-top: -8px; }
|
141 |
-
.ui-button-icon-only .ui-icon { left: 50%; margin-left: -8px; }
|
142 |
-
.ui-button-text-icon-primary .ui-button-icon-primary, .ui-button-text-icons .ui-button-icon-primary, .ui-button-icons-only .ui-button-icon-primary { left: .5em; }
|
143 |
-
.ui-button-text-icon-secondary .ui-button-icon-secondary, .ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; }
|
144 |
-
.ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; }
|
145 |
-
|
146 |
-
/*button sets*/
|
147 |
-
.ui-buttonset { margin-right: 7px; }
|
148 |
-
.ui-buttonset .ui-button { margin-left: 0; margin-right: -.3em; }
|
149 |
-
|
150 |
-
/* workarounds */
|
151 |
-
button.ui-button::-moz-focus-inner { border: 0; padding: 0; } /* reset extra padding in Firefox */
|
152 |
-
/*
|
153 |
-
* jQuery UI Datepicker 1.8.14
|
154 |
-
*
|
155 |
-
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
156 |
-
* Dual licensed under the MIT or GPL Version 2 licenses.
|
157 |
-
* http://jquery.org/license
|
158 |
-
*
|
159 |
-
* http://docs.jquery.com/UI/Datepicker#theming
|
160 |
-
*/
|
161 |
-
.ui-datepicker { width: 17em; padding: .2em .2em 0; display: none; }
|
162 |
-
.ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0; }
|
163 |
-
.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; }
|
164 |
-
.ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { top: 1px; }
|
165 |
-
.ui-datepicker .ui-datepicker-prev { left:2px; }
|
166 |
-
.ui-datepicker .ui-datepicker-next { right:2px; }
|
167 |
-
.ui-datepicker .ui-datepicker-prev-hover { left:1px; }
|
168 |
-
.ui-datepicker .ui-datepicker-next-hover { right:1px; }
|
169 |
-
.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px; }
|
170 |
-
.ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; }
|
171 |
-
.ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; }
|
172 |
-
.ui-datepicker select.ui-datepicker-month-year {width: 100%;}
|
173 |
-
.ui-datepicker select.ui-datepicker-month,
|
174 |
-
.ui-datepicker select.ui-datepicker-year { width: 49%;}
|
175 |
-
.ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; }
|
176 |
-
.ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0; }
|
177 |
-
.ui-datepicker td { border: 0; padding: 1px; }
|
178 |
-
.ui-datepicker td span, .ui-datepicker td a { display: block; padding: .2em; text-align: right; text-decoration: none; }
|
179 |
-
.ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .7em 0 0 0; padding:0 .2em; border-left: 0; border-right: 0; border-bottom: 0; }
|
180 |
-
.ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; }
|
181 |
-
.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; }
|
182 |
-
|
183 |
-
/* with multiple calendars */
|
184 |
-
.ui-datepicker.ui-datepicker-multi { width:auto; }
|
185 |
-
.ui-datepicker-multi .ui-datepicker-group { float:left; }
|
186 |
-
.ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; }
|
187 |
-
.ui-datepicker-multi-2 .ui-datepicker-group { width:50%; }
|
188 |
-
.ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; }
|
189 |
-
.ui-datepicker-multi-4 .ui-datepicker-group { width:25%; }
|
190 |
-
.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; }
|
191 |
-
.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; }
|
192 |
-
.ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; }
|
193 |
-
.ui-datepicker-row-break { clear:both; width:100%; font-size:0em; }
|
194 |
-
|
195 |
-
/* RTL support */
|
196 |
-
.ui-datepicker-rtl { direction: rtl; }
|
197 |
-
.ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; }
|
198 |
-
.ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; }
|
199 |
-
.ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; }
|
200 |
-
.ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; }
|
201 |
-
.ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; }
|
202 |
-
.ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; }
|
203 |
-
.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; }
|
204 |
-
.ui-datepicker-rtl .ui-datepicker-group { float:right; }
|
205 |
-
.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; }
|
206 |
-
.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; }
|
207 |
-
|
208 |
-
/* IE6 IFRAME FIX (taken from datepicker 1.5.3 */
|
209 |
-
.ui-datepicker-cover {
|
210 |
-
display: none; /*sorry for IE5*/
|
211 |
-
display/**/: block; /*sorry for IE5*/
|
212 |
-
position: absolute; /*must have*/
|
213 |
-
z-index: -1; /*must have*/
|
214 |
-
filter: mask(); /*must have*/
|
215 |
-
top: -4px; /*must have*/
|
216 |
-
left: -4px; /*must have*/
|
217 |
-
width: 200px; /*must have*/
|
218 |
-
height: 200px; /*must have*/
|
219 |
-
}/*
|
220 |
-
* jQuery UI Dialog 1.8.14
|
221 |
-
*
|
222 |
-
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
223 |
-
* Dual licensed under the MIT or GPL Version 2 licenses.
|
224 |
-
* http://jquery.org/license
|
225 |
-
*
|
226 |
-
* http://docs.jquery.com/UI/Dialog#theming
|
227 |
-
*/
|
228 |
-
.ui-dialog { position: absolute; padding: .2em; width: 300px; overflow: hidden; }
|
229 |
-
.ui-dialog .ui-dialog-titlebar { padding: .4em 1em; position: relative; }
|
230 |
-
.ui-dialog .ui-dialog-title { float: left; margin: .1em 16px .1em 0; }
|
231 |
-
.ui-dialog .ui-dialog-titlebar-close { position: absolute; right: .3em; top: 50%; width: 19px; margin: -10px 0 0 0; padding: 1px; height: 18px; }
|
232 |
-
.ui-dialog .ui-dialog-titlebar-close span { display: block; margin: 1px; }
|
233 |
-
.ui-dialog .ui-dialog-titlebar-close:hover, .ui-dialog .ui-dialog-titlebar-close:focus { padding: 0; }
|
234 |
-
.ui-dialog .ui-dialog-content { position: relative; border: 0; padding: .5em 1em; background: none; overflow: auto; zoom: 1; }
|
235 |
-
.ui-dialog .ui-dialog-buttonpane { text-align: left; border-width: 1px 0 0 0; background-image: none; margin: .5em 0 0 0; padding: .3em 1em .5em .4em; }
|
236 |
-
.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset { float: right; }
|
237 |
-
.ui-dialog .ui-dialog-buttonpane button { margin: .5em .4em .5em 0; cursor: pointer; }
|
238 |
-
.ui-dialog .ui-resizable-se { width: 14px; height: 14px; right: 3px; bottom: 3px; }
|
239 |
-
.ui-draggable .ui-dialog-titlebar { cursor: move; }
|
240 |
-
/*
|
241 |
-
* jQuery UI Progressbar 1.8.14
|
242 |
-
*
|
243 |
-
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
244 |
-
* Dual licensed under the MIT or GPL Version 2 licenses.
|
245 |
-
* http://jquery.org/license
|
246 |
-
*
|
247 |
-
* http://docs.jquery.com/UI/Progressbar#theming
|
248 |
-
*/
|
249 |
-
.ui-progressbar { height:2em; text-align: left; }
|
250 |
-
.ui-progressbar .ui-progressbar-value {margin: -1px; height:100%; }/*
|
251 |
-
* jQuery UI Resizable 1.8.14
|
252 |
-
*
|
253 |
-
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
254 |
-
* Dual licensed under the MIT or GPL Version 2 licenses.
|
255 |
-
* http://jquery.org/license
|
256 |
-
*
|
257 |
-
* http://docs.jquery.com/UI/Resizable#theming
|
258 |
-
*/
|
259 |
-
.ui-resizable { position: relative;}
|
260 |
-
.ui-resizable-handle { position: absolute;font-size: 0.1px;z-index: 99999; display: block; }
|
261 |
-
.ui-resizable-disabled .ui-resizable-handle, .ui-resizable-autohide .ui-resizable-handle { display: none; }
|
262 |
-
.ui-resizable-n { cursor: n-resize; height: 7px; width: 100%; top: -5px; left: 0; }
|
263 |
-
.ui-resizable-s { cursor: s-resize; height: 7px; width: 100%; bottom: -5px; left: 0; }
|
264 |
-
.ui-resizable-e { cursor: e-resize; width: 7px; right: -5px; top: 0; height: 100%; }
|
265 |
-
.ui-resizable-w { cursor: w-resize; width: 7px; left: -5px; top: 0; height: 100%; }
|
266 |
-
.ui-resizable-se { cursor: se-resize; width: 12px; height: 12px; right: 1px; bottom: 1px; }
|
267 |
-
.ui-resizable-sw { cursor: sw-resize; width: 9px; height: 9px; left: -5px; bottom: -5px; }
|
268 |
-
.ui-resizable-nw { cursor: nw-resize; width: 9px; height: 9px; left: -5px; top: -5px; }
|
269 |
-
.ui-resizable-ne { cursor: ne-resize; width: 9px; height: 9px; right: -5px; top: -5px;}/*
|
270 |
-
* jQuery UI Selectable 1.8.14
|
271 |
-
*
|
272 |
-
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
273 |
-
* Dual licensed under the MIT or GPL Version 2 licenses.
|
274 |
-
* http://jquery.org/license
|
275 |
-
*
|
276 |
-
* http://docs.jquery.com/UI/Selectable#theming
|
277 |
-
*/
|
278 |
-
.ui-selectable-helper { position: absolute; z-index: 100; border:1px dotted black; }
|
279 |
-
/*
|
280 |
-
* jQuery UI Slider 1.8.14
|
281 |
-
*
|
282 |
-
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
283 |
-
* Dual licensed under the MIT or GPL Version 2 licenses.
|
284 |
-
* http://jquery.org/license
|
285 |
-
*
|
286 |
-
* http://docs.jquery.com/UI/Slider#theming
|
287 |
-
*/
|
288 |
-
.ui-slider { position: relative; text-align: left; }
|
289 |
-
.ui-slider .ui-slider-handle { position: absolute; z-index: 2; width: 1.2em; height: 1.2em; cursor: default; }
|
290 |
-
.ui-slider .ui-slider-range { position: absolute; z-index: 1; font-size: .7em; display: block; border: 0; background-position: 0 0; }
|
291 |
-
|
292 |
-
.ui-slider-horizontal { height: .8em; }
|
293 |
-
.ui-slider-horizontal .ui-slider-handle { top: -.3em; margin-left: -.6em; }
|
294 |
-
.ui-slider-horizontal .ui-slider-range { top: 0; height: 100%; }
|
295 |
-
.ui-slider-horizontal .ui-slider-range-min { left: 0; }
|
296 |
-
.ui-slider-horizontal .ui-slider-range-max { right: 0; }
|
297 |
-
|
298 |
-
.ui-slider-vertical { width: .8em; height: 100px; }
|
299 |
-
.ui-slider-vertical .ui-slider-handle { left: -.3em; margin-left: 0; margin-bottom: -.6em; }
|
300 |
-
.ui-slider-vertical .ui-slider-range { left: 0; width: 100%; }
|
301 |
-
.ui-slider-vertical .ui-slider-range-min { bottom: 0; }
|
302 |
-
.ui-slider-vertical .ui-slider-range-max { top: 0; }/*
|
303 |
-
* jQuery UI Tabs 1.8.14
|
304 |
-
*
|
305 |
-
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
306 |
-
* Dual licensed under the MIT or GPL Version 2 licenses.
|
307 |
-
* http://jquery.org/license
|
308 |
-
*
|
309 |
-
* http://docs.jquery.com/UI/Tabs#theming
|
310 |
-
*/
|
311 |
-
.ui-tabs { position: relative; padding: .2em; zoom: 1; } /* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */
|
312 |
-
.ui-tabs .ui-tabs-nav { margin: 0; padding: .2em .2em 0; }
|
313 |
-
.ui-tabs .ui-tabs-nav li { list-style: none; float: left; position: relative; top: 1px; margin: 0 .2em 1px 0; border-bottom: 0 !important; padding: 0; white-space: nowrap; }
|
314 |
-
.ui-tabs .ui-tabs-nav li a { float: left; padding: .5em 1em; text-decoration: none; }
|
315 |
-
.ui-tabs .ui-tabs-nav li.ui-tabs-selected { margin-bottom: 0; padding-bottom: 1px; }
|
316 |
-
.ui-tabs .ui-tabs-nav li.ui-tabs-selected a, .ui-tabs .ui-tabs-nav li.ui-state-disabled a, .ui-tabs .ui-tabs-nav li.ui-state-processing a { cursor: text; }
|
317 |
-
.ui-tabs .ui-tabs-nav li a, .ui-tabs.ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-selected a { cursor: pointer; } /* first selector in group seems obsolete, but required to overcome bug in Opera applying cursor: text overall if defined elsewhere... */
|
318 |
-
.ui-tabs .ui-tabs-panel { display: block; border-width: 0; padding: 1em 1.4em; background: none; }
|
319 |
-
.ui-tabs .ui-tabs-hide { display: none !important; }
|
320 |
-
/*
|
321 |
-
* jQuery UI CSS Framework 1.8.14
|
322 |
-
*
|
323 |
-
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
324 |
-
* Dual licensed under the MIT or GPL Version 2 licenses.
|
325 |
-
* http://jquery.org/license
|
326 |
-
*
|
327 |
-
* http://docs.jquery.com/UI/Theming/API
|
328 |
-
*
|
329 |
-
* To view and modify this theme, visit http://jqueryui.com/themeroller/
|
330 |
-
*/
|
331 |
-
|
332 |
-
|
333 |
-
/* Component containers
|
334 |
-
----------------------------------*/
|
335 |
-
.ui-widget { font-family: Verdana,Arial,sans-serif/*{ffDefault}*/; font-size: 1.1em/*{fsDefault}*/; }
|
336 |
-
.ui-widget .ui-widget { font-size: 1em; }
|
337 |
-
.ui-widget input, .ui-widget select, .ui-widget textarea, .ui-widget button { font-family: Verdana,Arial,sans-serif/*{ffDefault}*/; font-size: 1em; }
|
338 |
-
.ui-widget-content { border: 1px solid #aaaaaa/*{borderColorContent}*/; background: #ffffff/*{bgColorContent}*/ url(images/ui-bg_flat_75_ffffff_40x100.png)/*{bgImgUrlContent}*/ 50%/*{bgContentXPos}*/ 50%/*{bgContentYPos}*/ repeat-x/*{bgContentRepeat}*/; color: #949494/*{fcContent}*/; }
|
339 |
-
.ui-widget-content a { color: #949494/*{fcContent}*/; }
|
340 |
-
.ui-widget-header { border: 1px solid #aaaaaa/*{borderColorHeader}*/; background: #cccccc/*{bgColorHeader}*/ url(images/ui-bg_highlight-soft_75_cccccc_1x100.png)/*{bgImgUrlHeader}*/ 50%/*{bgHeaderXPos}*/ 50%/*{bgHeaderYPos}*/ repeat-x/*{bgHeaderRepeat}*/; color: #949494/*{fcHeader}*/; font-weight: bold; }
|
341 |
-
.ui-widget-header a { color: #222222/*{fcHeader}*/; }
|
342 |
-
|
343 |
-
/* Interaction states
|
344 |
-
----------------------------------*/
|
345 |
-
.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { border: 1px solid #d3d3d3/*{borderColorDefault}*/; background: #7DB5D8/*{bgColorDefault}*/ /*{bgImgUrlDefault}*/ 50%/*{bgDefaultXPos}*/ 50%/*{bgDefaultYPos}*/ repeat-x/*{bgDefaultRepeat}*/; font-weight: normal/*{fwDefault}*/; color: #fff/*{fcDefault}*/; }
|
346 |
-
.ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #555555/*{fcDefault}*/; text-decoration: none; }
|
347 |
-
.ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { border: 1px solid #999999/*{borderColorHover}*/; background: #7DB5D8/*{bgColorHover}*/ /*{bgImgUrlHover}*/ 50%/*{bgHoverXPos}*/ 50%/*{bgHoverYPos}*/ repeat-x/*{bgHoverRepeat}*/; font-weight: normal/*{fwDefault}*/; color: #fff/*{fcHover}*/; }
|
348 |
-
.ui-state-hover a, .ui-state-hover a:hover { color: #212121/*{fcHover}*/; text-decoration: none; }
|
349 |
-
.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { border: 1px solid #aaaaaa/*{borderColorActive}*/; background: #ffffff/*{bgColorActive}*/ url(images/ui-bg_glass_65_ffffff_1x400.png)/*{bgImgUrlActive}*/ 50%/*{bgActiveXPos}*/ 50%/*{bgActiveYPos}*/ repeat-x/*{bgActiveRepeat}*/; font-weight: normal/*{fwDefault}*/; color: #212121/*{fcActive}*/; }
|
350 |
-
.ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #212121/*{fcActive}*/; text-decoration: none; }
|
351 |
-
.ui-widget :active { outline: none; }
|
352 |
-
|
353 |
-
/* Interaction Cues
|
354 |
-
----------------------------------*/
|
355 |
-
.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight {border: 1px solid #fcefa1/*{borderColorHighlight}*/; background: #fbf9ee/*{bgColorHighlight}*/ url(images/ui-bg_glass_55_fbf9ee_1x400.png)/*{bgImgUrlHighlight}*/ 50%/*{bgHighlightXPos}*/ 50%/*{bgHighlightYPos}*/ repeat-x/*{bgHighlightRepeat}*/; color: #363636/*{fcHighlight}*/; }
|
356 |
-
.ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #363636/*{fcHighlight}*/; }
|
357 |
-
.ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error {border: 1px solid #cd0a0a/*{borderColorError}*/; background: #fef1ec/*{bgColorError}*/ url(images/ui-bg_glass_95_fef1ec_1x400.png)/*{bgImgUrlError}*/ 50%/*{bgErrorXPos}*/ 50%/*{bgErrorYPos}*/ repeat-x/*{bgErrorRepeat}*/; color: #cd0a0a/*{fcError}*/; }
|
358 |
-
.ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #cd0a0a/*{fcError}*/; }
|
359 |
-
.ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #cd0a0a/*{fcError}*/; }
|
360 |
-
.ui-priority-primary, .ui-widget-content .ui-priority-primary, .ui-widget-header .ui-priority-primary { font-weight: bold; }
|
361 |
-
.ui-priority-secondary, .ui-widget-content .ui-priority-secondary, .ui-widget-header .ui-priority-secondary { opacity: .7; filter:Alpha(Opacity=70); font-weight: normal; }
|
362 |
-
.ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled { opacity: .35; filter:Alpha(Opacity=35); background-image: none; }
|
363 |
-
|
364 |
-
/* Icons
|
365 |
-
----------------------------------*/
|
366 |
-
|
367 |
-
/* states and images */
|
368 |
-
.ui-icon { width: 16px; height: 16px; background-image: url(images/ui-icons_222222_256x240.png)/*{iconsContent}*/; }
|
369 |
-
.ui-widget-content .ui-icon {background-image: url(images/ui-icons_222222_256x240.png)/*{iconsContent}*/; }
|
370 |
-
.ui-widget-header .ui-icon {background-image: url(images/ui-icons_222222_256x240.png)/*{iconsHeader}*/; }
|
371 |
-
.ui-state-default .ui-icon { background-image: url(images/ui-icons_888888_256x240.png)/*{iconsDefault}*/; }
|
372 |
-
.ui-state-hover .ui-icon, .ui-state-focus .ui-icon {background-image: url(images/ui-icons_454545_256x240.png)/*{iconsHover}*/; }
|
373 |
-
.ui-state-active .ui-icon {background-image: url(images/ui-icons_454545_256x240.png)/*{iconsActive}*/; }
|
374 |
-
.ui-state-highlight .ui-icon {background-image: url(images/ui-icons_2e83ff_256x240.png)/*{iconsHighlight}*/; }
|
375 |
-
.ui-state-error .ui-icon, .ui-state-error-text .ui-icon {background-image: url(images/ui-icons_cd0a0a_256x240.png)/*{iconsError}*/; }
|
376 |
-
|
377 |
-
/* positioning */
|
378 |
-
.ui-icon-carat-1-n { background-position: 0 0; }
|
379 |
-
.ui-icon-carat-1-ne { background-position: -16px 0; }
|
380 |
-
.ui-icon-carat-1-e { background-position: -32px 0; }
|
381 |
-
.ui-icon-carat-1-se { background-position: -48px 0; }
|
382 |
-
.ui-icon-carat-1-s { background-position: -64px 0; }
|
383 |
-
.ui-icon-carat-1-sw { background-position: -80px 0; }
|
384 |
-
.ui-icon-carat-1-w { background-position: -96px 0; }
|
385 |
-
.ui-icon-carat-1-nw { background-position: -112px 0; }
|
386 |
-
.ui-icon-carat-2-n-s { background-position: -128px 0; }
|
387 |
-
.ui-icon-carat-2-e-w { background-position: -144px 0; }
|
388 |
-
.ui-icon-triangle-1-n { background-position: 0 -16px; }
|
389 |
-
.ui-icon-triangle-1-ne { background-position: -16px -16px; }
|
390 |
-
.ui-icon-triangle-1-e { background-position: -32px -16px; }
|
391 |
-
.ui-icon-triangle-1-se { background-position: -48px -16px; }
|
392 |
-
.ui-icon-triangle-1-s { background-position: -64px -16px; }
|
393 |
-
.ui-icon-triangle-1-sw { background-position: -80px -16px; }
|
394 |
-
.ui-icon-triangle-1-w { background-position: -96px -16px; }
|
395 |
-
.ui-icon-triangle-1-nw { background-position: -112px -16px; }
|
396 |
-
.ui-icon-triangle-2-n-s { background-position: -128px -16px; }
|
397 |
-
.ui-icon-triangle-2-e-w { background-position: -144px -16px; }
|
398 |
-
.ui-icon-arrow-1-n { background-position: 0 -32px; }
|
399 |
-
.ui-icon-arrow-1-ne { background-position: -16px -32px; }
|
400 |
-
.ui-icon-arrow-1-e { background-position: -32px -32px; }
|
401 |
-
.ui-icon-arrow-1-se { background-position: -48px -32px; }
|
402 |
-
.ui-icon-arrow-1-s { background-position: -64px -32px; }
|
403 |
-
.ui-icon-arrow-1-sw { background-position: -80px -32px; }
|
404 |
-
.ui-icon-arrow-1-w { background-position: -96px -32px; }
|
405 |
-
.ui-icon-arrow-1-nw { background-position: -112px -32px; }
|
406 |
-
.ui-icon-arrow-2-n-s { background-position: -128px -32px; }
|
407 |
-
.ui-icon-arrow-2-ne-sw { background-position: -144px -32px; }
|
408 |
-
.ui-icon-arrow-2-e-w { background-position: -160px -32px; }
|
409 |
-
.ui-icon-arrow-2-se-nw { background-position: -176px -32px; }
|
410 |
-
.ui-icon-arrowstop-1-n { background-position: -192px -32px; }
|
411 |
-
.ui-icon-arrowstop-1-e { background-position: -208px -32px; }
|
412 |
-
.ui-icon-arrowstop-1-s { background-position: -224px -32px; }
|
413 |
-
.ui-icon-arrowstop-1-w { background-position: -240px -32px; }
|
414 |
-
.ui-icon-arrowthick-1-n { background-position: 0 -48px; }
|
415 |
-
.ui-icon-arrowthick-1-ne { background-position: -16px -48px; }
|
416 |
-
.ui-icon-arrowthick-1-e { background-position: -32px -48px; }
|
417 |
-
.ui-icon-arrowthick-1-se { background-position: -48px -48px; }
|
418 |
-
.ui-icon-arrowthick-1-s { background-position: -64px -48px; }
|
419 |
-
.ui-icon-arrowthick-1-sw { background-position: -80px -48px; }
|
420 |
-
.ui-icon-arrowthick-1-w { background-position: -96px -48px; }
|
421 |
-
.ui-icon-arrowthick-1-nw { background-position: -112px -48px; }
|
422 |
-
.ui-icon-arrowthick-2-n-s { background-position: -128px -48px; }
|
423 |
-
.ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; }
|
424 |
-
.ui-icon-arrowthick-2-e-w { background-position: -160px -48px; }
|
425 |
-
.ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; }
|
426 |
-
.ui-icon-arrowthickstop-1-n { background-position: -192px -48px; }
|
427 |
-
.ui-icon-arrowthickstop-1-e { background-position: -208px -48px; }
|
428 |
-
.ui-icon-arrowthickstop-1-s { background-position: -224px -48px; }
|
429 |
-
.ui-icon-arrowthickstop-1-w { background-position: -240px -48px; }
|
430 |
-
.ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; }
|
431 |
-
.ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; }
|
432 |
-
.ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; }
|
433 |
-
.ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; }
|
434 |
-
.ui-icon-arrowreturn-1-w { background-position: -64px -64px; }
|
435 |
-
.ui-icon-arrowreturn-1-n { background-position: -80px -64px; }
|
436 |
-
.ui-icon-arrowreturn-1-e { background-position: -96px -64px; }
|
437 |
-
.ui-icon-arrowreturn-1-s { background-position: -112px -64px; }
|
438 |
-
.ui-icon-arrowrefresh-1-w { background-position: -128px -64px; }
|
439 |
-
.ui-icon-arrowrefresh-1-n { background-position: -144px -64px; }
|
440 |
-
.ui-icon-arrowrefresh-1-e { background-position: -160px -64px; }
|
441 |
-
.ui-icon-arrowrefresh-1-s { background-position: -176px -64px; }
|
442 |
-
.ui-icon-arrow-4 { background-position: 0 -80px; }
|
443 |
-
.ui-icon-arrow-4-diag { background-position: -16px -80px; }
|
444 |
-
.ui-icon-extlink { background-position: -32px -80px; }
|
445 |
-
.ui-icon-newwin { background-position: -48px -80px; }
|
446 |
-
.ui-icon-refresh { background-position: -64px -80px; }
|
447 |
-
.ui-icon-shuffle { background-position: -80px -80px; }
|
448 |
-
.ui-icon-transfer-e-w { background-position: -96px -80px; }
|
449 |
-
.ui-icon-transferthick-e-w { background-position: -112px -80px; }
|
450 |
-
.ui-icon-folder-collapsed { background-position: 0 -96px; }
|
451 |
-
.ui-icon-folder-open { background-position: -16px -96px; }
|
452 |
-
.ui-icon-document { background-position: -32px -96px; }
|
453 |
-
.ui-icon-document-b { background-position: -48px -96px; }
|
454 |
-
.ui-icon-note { background-position: -64px -96px; }
|
455 |
-
.ui-icon-mail-closed { background-position: -80px -96px; }
|
456 |
-
.ui-icon-mail-open { background-position: -96px -96px; }
|
457 |
-
.ui-icon-suitcase { background-position: -112px -96px; }
|
458 |
-
.ui-icon-comment { background-position: -128px -96px; }
|
459 |
-
.ui-icon-person { background-position: -144px -96px; }
|
460 |
-
.ui-icon-print { background-position: -160px -96px; }
|
461 |
-
.ui-icon-trash { background-position: -176px -96px; }
|
462 |
-
.ui-icon-locked { background-position: -192px -96px; }
|
463 |
-
.ui-icon-unlocked { background-position: -208px -96px; }
|
464 |
-
.ui-icon-bookmark { background-position: -224px -96px; }
|
465 |
-
.ui-icon-tag { background-position: -240px -96px; }
|
466 |
-
.ui-icon-home { background-position: 0 -112px; }
|
467 |
-
.ui-icon-flag { background-position: -16px -112px; }
|
468 |
-
.ui-icon-calendar { background-position: -32px -112px; }
|
469 |
-
.ui-icon-cart { background-position: -48px -112px; }
|
470 |
-
.ui-icon-pencil { background-position: -64px -112px; }
|
471 |
-
.ui-icon-clock { background-position: -80px -112px; }
|
472 |
-
.ui-icon-disk { background-position: -96px -112px; }
|
473 |
-
.ui-icon-calculator { background-position: -112px -112px; }
|
474 |
-
.ui-icon-zoomin { background-position: -128px -112px; }
|
475 |
-
.ui-icon-zoomout { background-position: -144px -112px; }
|
476 |
-
.ui-icon-search { background-position: -160px -112px; }
|
477 |
-
.ui-icon-wrench { background-position: -176px -112px; }
|
478 |
-
.ui-icon-gear { background-position: -192px -112px; }
|
479 |
-
.ui-icon-heart { background-position: -208px -112px; }
|
480 |
-
.ui-icon-star { background-position: -224px -112px; }
|
481 |
-
.ui-icon-link { background-position: -240px -112px; }
|
482 |
-
.ui-icon-cancel { background-position: 0 -128px; }
|
483 |
-
.ui-icon-plus { background-position: -16px -128px; }
|
484 |
-
.ui-icon-plusthick { background-position: -32px -128px; }
|
485 |
-
.ui-icon-minus { background-position: -48px -128px; }
|
486 |
-
.ui-icon-minusthick { background-position: -64px -128px; }
|
487 |
-
.ui-icon-close { background-position: -80px -128px; }
|
488 |
-
.ui-icon-closethick { background-position: -96px -128px; }
|
489 |
-
.ui-icon-key { background-position: -112px -128px; }
|
490 |
-
.ui-icon-lightbulb { background-position: -128px -128px; }
|
491 |
-
.ui-icon-scissors { background-position: -144px -128px; }
|
492 |
-
.ui-icon-clipboard { background-position: -160px -128px; }
|
493 |
-
.ui-icon-copy { background-position: -176px -128px; }
|
494 |
-
.ui-icon-contact { background-position: -192px -128px; }
|
495 |
-
.ui-icon-image { background-position: -208px -128px; }
|
496 |
-
.ui-icon-video { background-position: -224px -128px; }
|
497 |
-
.ui-icon-script { background-position: -240px -128px; }
|
498 |
-
.ui-icon-alert { background-position: 0 -144px; }
|
499 |
-
.ui-icon-info { background-position: -16px -144px; }
|
500 |
-
.ui-icon-notice { background-position: -32px -144px; }
|
501 |
-
.ui-icon-help { background-position: -48px -144px; }
|
502 |
-
.ui-icon-check { background-position: -64px -144px; }
|
503 |
-
.ui-icon-bullet { background-position: -80px -144px; }
|
504 |
-
.ui-icon-radio-off { background-position: -96px -144px; }
|
505 |
-
.ui-icon-radio-on { background-position: -112px -144px; }
|
506 |
-
.ui-icon-pin-w { background-position: -128px -144px; }
|
507 |
-
.ui-icon-pin-s { background-position: -144px -144px; }
|
508 |
-
.ui-icon-play { background-position: 0 -160px; }
|
509 |
-
.ui-icon-pause { background-position: -16px -160px; }
|
510 |
-
.ui-icon-seek-next { background-position: -32px -160px; }
|
511 |
-
.ui-icon-seek-prev { background-position: -48px -160px; }
|
512 |
-
.ui-icon-seek-end { background-position: -64px -160px; }
|
513 |
-
.ui-icon-seek-start { background-position: -80px -160px; }
|
514 |
-
/* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */
|
515 |
-
.ui-icon-seek-first { background-position: -80px -160px; }
|
516 |
-
.ui-icon-stop { background-position: -96px -160px; }
|
517 |
-
.ui-icon-eject { background-position: -112px -160px; }
|
518 |
-
.ui-icon-volume-off { background-position: -128px -160px; }
|
519 |
-
.ui-icon-volume-on { background-position: -144px -160px; }
|
520 |
-
.ui-icon-power { background-position: 0 -176px; }
|
521 |
-
.ui-icon-signal-diag { background-position: -16px -176px; }
|
522 |
-
.ui-icon-signal { background-position: -32px -176px; }
|
523 |
-
.ui-icon-battery-0 { background-position: -48px -176px; }
|
524 |
-
.ui-icon-battery-1 { background-position: -64px -176px; }
|
525 |
-
.ui-icon-battery-2 { background-position: -80px -176px; }
|
526 |
-
.ui-icon-battery-3 { background-position: -96px -176px; }
|
527 |
-
.ui-icon-circle-plus { background-position: 0 -192px; }
|
528 |
-
.ui-icon-circle-minus { background-position: -16px -192px; }
|
529 |
-
.ui-icon-circle-close { background-position: -32px -192px; }
|
530 |
-
.ui-icon-circle-triangle-e { background-position: -48px -192px; }
|
531 |
-
.ui-icon-circle-triangle-s { background-position: -64px -192px; }
|
532 |
-
.ui-icon-circle-triangle-w { background-position: -80px -192px; }
|
533 |
-
.ui-icon-circle-triangle-n { background-position: -96px -192px; }
|
534 |
-
.ui-icon-circle-arrow-e { background-position: -112px -192px; }
|
535 |
-
.ui-icon-circle-arrow-s { background-position: -128px -192px; }
|
536 |
-
.ui-icon-circle-arrow-w { background-position: -144px -192px; }
|
537 |
-
.ui-icon-circle-arrow-n { background-position: -160px -192px; }
|
538 |
-
.ui-icon-circle-zoomin { background-position: -176px -192px; }
|
539 |
-
.ui-icon-circle-zoomout { background-position: -192px -192px; }
|
540 |
-
.ui-icon-circle-check { background-position: -208px -192px; }
|
541 |
-
.ui-icon-circlesmall-plus { background-position: 0 -208px; }
|
542 |
-
.ui-icon-circlesmall-minus { background-position: -16px -208px; }
|
543 |
-
.ui-icon-circlesmall-close { background-position: -32px -208px; }
|
544 |
-
.ui-icon-squaresmall-plus { background-position: -48px -208px; }
|
545 |
-
.ui-icon-squaresmall-minus { background-position: -64px -208px; }
|
546 |
-
.ui-icon-squaresmall-close { background-position: -80px -208px; }
|
547 |
-
.ui-icon-grip-dotted-vertical { background-position: 0 -224px; }
|
548 |
-
.ui-icon-grip-dotted-horizontal { background-position: -16px -224px; }
|
549 |
-
.ui-icon-grip-solid-vertical { background-position: -32px -224px; }
|
550 |
-
.ui-icon-grip-solid-horizontal { background-position: -48px -224px; }
|
551 |
-
.ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; }
|
552 |
-
.ui-icon-grip-diagonal-se { background-position: -80px -224px; }
|
553 |
-
|
554 |
-
|
555 |
-
/* Misc visuals
|
556 |
-
----------------------------------*/
|
557 |
-
|
558 |
-
/* Corner radius */
|
559 |
-
.ui-corner-all, .ui-corner-top, .ui-corner-left, .ui-corner-tl { -moz-border-radius-topleft: 4px/*{cornerRadius}*/; -webkit-border-top-left-radius: 4px/*{cornerRadius}*/; -khtml-border-top-left-radius: 4px/*{cornerRadius}*/; border-top-left-radius: 4px/*{cornerRadius}*/; }
|
560 |
-
.ui-corner-all, .ui-corner-top, .ui-corner-right, .ui-corner-tr { -moz-border-radius-topright: 4px/*{cornerRadius}*/; -webkit-border-top-right-radius: 4px/*{cornerRadius}*/; -khtml-border-top-right-radius: 4px/*{cornerRadius}*/; border-top-right-radius: 4px/*{cornerRadius}*/; }
|
561 |
-
.ui-corner-all, .ui-corner-bottom, .ui-corner-left, .ui-corner-bl { -moz-border-radius-bottomleft: 4px/*{cornerRadius}*/; -webkit-border-bottom-left-radius: 4px/*{cornerRadius}*/; -khtml-border-bottom-left-radius: 4px/*{cornerRadius}*/; border-bottom-left-radius: 4px/*{cornerRadius}*/; }
|
562 |
-
.ui-corner-all, .ui-corner-bottom, .ui-corner-right, .ui-corner-br { -moz-border-radius-bottomright: 4px/*{cornerRadius}*/; -webkit-border-bottom-right-radius: 4px/*{cornerRadius}*/; -khtml-border-bottom-right-radius: 4px/*{cornerRadius}*/; border-bottom-right-radius: 4px/*{cornerRadius}*/; }
|
563 |
-
|
564 |
-
/* Overlays */
|
565 |
-
.ui-widget-overlay { background: #aaaaaa/*{bgColorOverlay}*/ url(images/ui-bg_flat_0_aaaaaa_40x100.png)/*{bgImgUrlOverlay}*/ 50%/*{bgOverlayXPos}*/ 50%/*{bgOverlayYPos}*/ repeat-x/*{bgOverlayRepeat}*/; opacity: .3;filter:Alpha(Opacity=30)/*{opacityOverlay}*/; }
|
566 |
.ui-widget-shadow { margin: -8px/*{offsetTopShadow}*/ 0 0 -8px/*{offsetLeftShadow}*/; padding: 8px/*{thicknessShadow}*/; background: #aaaaaa/*{bgColorShadow}*/ url(images/ui-bg_flat_0_aaaaaa_40x100.png)/*{bgImgUrlShadow}*/ 50%/*{bgShadowXPos}*/ 50%/*{bgShadowYPos}*/ repeat-x/*{bgShadowRepeat}*/; opacity: .3;filter:Alpha(Opacity=30)/*{opacityShadow}*/; -moz-border-radius: 8px/*{cornerRadiusShadow}*/; -khtml-border-radius: 8px/*{cornerRadiusShadow}*/; -webkit-border-radius: 8px/*{cornerRadiusShadow}*/; border-radius: 8px/*{cornerRadiusShadow}*/; }
|
1 |
+
/*
|
2 |
+
* jQuery UI CSS Framework 1.8.14
|
3 |
+
*
|
4 |
+
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
5 |
+
* Dual licensed under the MIT or GPL Version 2 licenses.
|
6 |
+
* http://jquery.org/license
|
7 |
+
*
|
8 |
+
* http://docs.jquery.com/UI/Theming/API
|
9 |
+
*/
|
10 |
+
|
11 |
+
/* Layout helpers
|
12 |
+
----------------------------------*/
|
13 |
+
.ui-helper-hidden { display: none; }
|
14 |
+
.ui-helper-hidden-accessible { position: absolute !important; clip: rect(1px 1px 1px 1px); clip: rect(1px,1px,1px,1px); }
|
15 |
+
.ui-helper-reset { margin: 0; padding: 0; border: 0; outline: 0; line-height: 1.3; text-decoration: none; font-size: 100%; list-style: none; }
|
16 |
+
.ui-helper-clearfix:after { content: "."; display: block; height: 0; clear: both; visibility: hidden; }
|
17 |
+
.ui-helper-clearfix { display: inline-block; }
|
18 |
+
/* required comment for clearfix to work in Opera \*/
|
19 |
+
* html .ui-helper-clearfix { height:1%; }
|
20 |
+
.ui-helper-clearfix { display:block; }
|
21 |
+
/* end clearfix */
|
22 |
+
.ui-helper-zfix { width: 100%; height: 100%; top: 0; left: 0; position: absolute; opacity: 0; filter:Alpha(Opacity=0); }
|
23 |
+
|
24 |
+
|
25 |
+
/* Interaction Cues
|
26 |
+
----------------------------------*/
|
27 |
+
.ui-state-disabled { cursor: default !important; }
|
28 |
+
|
29 |
+
|
30 |
+
/* Icons
|
31 |
+
----------------------------------*/
|
32 |
+
|
33 |
+
/* states and images */
|
34 |
+
.ui-icon { display: block; text-indent: -99999px; overflow: hidden; background-repeat: no-repeat; }
|
35 |
+
|
36 |
+
|
37 |
+
/* Misc visuals
|
38 |
+
----------------------------------*/
|
39 |
+
|
40 |
+
/* Overlays */
|
41 |
+
.ui-widget-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
|
42 |
+
/*
|
43 |
+
* jQuery UI Accordion 1.8.14
|
44 |
+
*
|
45 |
+
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
46 |
+
* Dual licensed under the MIT or GPL Version 2 licenses.
|
47 |
+
* http://jquery.org/license
|
48 |
+
*
|
49 |
+
* http://docs.jquery.com/UI/Accordion#theming
|
50 |
+
*/
|
51 |
+
/* IE/Win - Fix animation bug - #4615 */
|
52 |
+
.ui-accordion { width: 100%; }
|
53 |
+
.ui-accordion .ui-accordion-header { cursor: pointer; position: relative; margin-top: 1px; zoom: 1; }
|
54 |
+
.ui-accordion .ui-accordion-li-fix { display: inline; }
|
55 |
+
.ui-accordion .ui-accordion-header-active { border-bottom: 0 !important; }
|
56 |
+
.ui-accordion .ui-accordion-header a { display: block; font-size: 1em; padding: .5em .5em .5em .7em; }
|
57 |
+
.ui-accordion-icons .ui-accordion-header a { padding-left: 2.2em; }
|
58 |
+
.ui-accordion .ui-accordion-header .ui-icon { position: absolute; left: .5em; top: 50%; margin-top: -8px; }
|
59 |
+
.ui-accordion .ui-accordion-content { padding: 1em 2.2em; border-top: 0; margin-top: -2px; position: relative; top: 1px; margin-bottom: 2px; overflow: auto; display: none; zoom: 1; }
|
60 |
+
.ui-accordion .ui-accordion-content-active { display: block; }
|
61 |
+
/*
|
62 |
+
* jQuery UI Autocomplete 1.8.14
|
63 |
+
*
|
64 |
+
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
65 |
+
* Dual licensed under the MIT or GPL Version 2 licenses.
|
66 |
+
* http://jquery.org/license
|
67 |
+
*
|
68 |
+
* http://docs.jquery.com/UI/Autocomplete#theming
|
69 |
+
*/
|
70 |
+
.ui-autocomplete { position: absolute; cursor: default; }
|
71 |
+
|
72 |
+
/* workarounds */
|
73 |
+
* html .ui-autocomplete { width:1px; } /* without this, the menu expands to 100% in IE6 */
|
74 |
+
|
75 |
+
/*
|
76 |
+
* jQuery UI Menu 1.8.14
|
77 |
+
*
|
78 |
+
* Copyright 2010, AUTHORS.txt (http://jqueryui.com/about)
|
79 |
+
* Dual licensed under the MIT or GPL Version 2 licenses.
|
80 |
+
* http://jquery.org/license
|
81 |
+
*
|
82 |
+
* http://docs.jquery.com/UI/Menu#theming
|
83 |
+
*/
|
84 |
+
.ui-menu {
|
85 |
+
list-style:none;
|
86 |
+
padding: 2px;
|
87 |
+
margin: 0;
|
88 |
+
display:block;
|
89 |
+
float: left;
|
90 |
+
}
|
91 |
+
.ui-menu .ui-menu {
|
92 |
+
margin-top: -3px;
|
93 |
+
}
|
94 |
+
.ui-menu .ui-menu-item {
|
95 |
+
margin:0;
|
96 |
+
padding: 0;
|
97 |
+
zoom: 1;
|
98 |
+
float: left;
|
99 |
+
clear: left;
|
100 |
+
width: 100%;
|
101 |
+
}
|
102 |
+
.ui-menu .ui-menu-item a {
|
103 |
+
text-decoration:none;
|
104 |
+
display:block;
|
105 |
+
padding:.2em .4em;
|
106 |
+
line-height:1.5;
|
107 |
+
zoom:1;
|
108 |
+
}
|
109 |
+
.ui-menu .ui-menu-item a.ui-state-hover,
|
110 |
+
.ui-menu .ui-menu-item a.ui-state-active {
|
111 |
+
font-weight: normal;
|
112 |
+
margin: -1px;
|
113 |
+
}
|
114 |
+
/*
|
115 |
+
* jQuery UI Button 1.8.14
|
116 |
+
*
|
117 |
+
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
118 |
+
* Dual licensed under the MIT or GPL Version 2 licenses.
|
119 |
+
* http://jquery.org/license
|
120 |
+
*
|
121 |
+
* http://docs.jquery.com/UI/Button#theming
|
122 |
+
*/
|
123 |
+
.ui-button { display: inline-block; position: relative; padding: 0; margin-right: .1em; text-decoration: none !important; cursor: pointer; text-align: center; zoom: 1; overflow: visible; } /* the overflow property removes extra width in IE */
|
124 |
+
.ui-button-icon-only { width: 2.2em; } /* to make room for the icon, a width needs to be set here */
|
125 |
+
button.ui-button-icon-only { width: 2.4em; } /* button elements seem to need a little more width */
|
126 |
+
.ui-button-icons-only { width: 3.4em; }
|
127 |
+
button.ui-button-icons-only { width: 3.7em; }
|
128 |
+
|
129 |
+
/*button text element */
|
130 |
+
.ui-button .ui-button-text { display: block; line-height: 1.4; }
|
131 |
+
.ui-button-text-only .ui-button-text { padding: .4em 1em; }
|
132 |
+
.ui-button-icon-only .ui-button-text, .ui-button-icons-only .ui-button-text { padding: .4em; text-indent: -9999999px; }
|
133 |
+
.ui-button-text-icon-primary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 1em .4em 2.1em; }
|
134 |
+
.ui-button-text-icon-secondary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 2.1em .4em 1em; }
|
135 |
+
.ui-button-text-icons .ui-button-text { padding-left: 2.1em; padding-right: 2.1em; }
|
136 |
+
/* no icon support for input elements, provide padding by default */
|
137 |
+
input.ui-button { padding: .4em 1em; }
|
138 |
+
|
139 |
+
/*button icon element(s) */
|
140 |
+
.ui-button-icon-only .ui-icon, .ui-button-text-icon-primary .ui-icon, .ui-button-text-icon-secondary .ui-icon, .ui-button-text-icons .ui-icon, .ui-button-icons-only .ui-icon { position: absolute; top: 50%; margin-top: -8px; }
|
141 |
+
.ui-button-icon-only .ui-icon { left: 50%; margin-left: -8px; }
|
142 |
+
.ui-button-text-icon-primary .ui-button-icon-primary, .ui-button-text-icons .ui-button-icon-primary, .ui-button-icons-only .ui-button-icon-primary { left: .5em; }
|
143 |
+
.ui-button-text-icon-secondary .ui-button-icon-secondary, .ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; }
|
144 |
+
.ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; }
|
145 |
+
|
146 |
+
/*button sets*/
|
147 |
+
.ui-buttonset { margin-right: 7px; }
|
148 |
+
.ui-buttonset .ui-button { margin-left: 0; margin-right: -.3em; }
|
149 |
+
|
150 |
+
/* workarounds */
|
151 |
+
button.ui-button::-moz-focus-inner { border: 0; padding: 0; } /* reset extra padding in Firefox */
|
152 |
+
/*
|
153 |
+
* jQuery UI Datepicker 1.8.14
|
154 |
+
*
|
155 |
+
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
156 |
+
* Dual licensed under the MIT or GPL Version 2 licenses.
|
157 |
+
* http://jquery.org/license
|
158 |
+
*
|
159 |
+
* http://docs.jquery.com/UI/Datepicker#theming
|
160 |
+
*/
|
161 |
+
.ui-datepicker { width: 17em; padding: .2em .2em 0; display: none; }
|
162 |
+
.ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0; }
|
163 |
+
.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; }
|
164 |
+
.ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { top: 1px; }
|
165 |
+
.ui-datepicker .ui-datepicker-prev { left:2px; }
|
166 |
+
.ui-datepicker .ui-datepicker-next { right:2px; }
|
167 |
+
.ui-datepicker .ui-datepicker-prev-hover { left:1px; }
|
168 |
+
.ui-datepicker .ui-datepicker-next-hover { right:1px; }
|
169 |
+
.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px; }
|
170 |
+
.ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; }
|
171 |
+
.ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; }
|
172 |
+
.ui-datepicker select.ui-datepicker-month-year {width: 100%;}
|
173 |
+
.ui-datepicker select.ui-datepicker-month,
|
174 |
+
.ui-datepicker select.ui-datepicker-year { width: 49%;}
|
175 |
+
.ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; }
|
176 |
+
.ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0; }
|
177 |
+
.ui-datepicker td { border: 0; padding: 1px; }
|
178 |
+
.ui-datepicker td span, .ui-datepicker td a { display: block; padding: .2em; text-align: right; text-decoration: none; }
|
179 |
+
.ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .7em 0 0 0; padding:0 .2em; border-left: 0; border-right: 0; border-bottom: 0; }
|
180 |
+
.ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; }
|
181 |
+
.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; }
|
182 |
+
|
183 |
+
/* with multiple calendars */
|
184 |
+
.ui-datepicker.ui-datepicker-multi { width:auto; }
|
185 |
+
.ui-datepicker-multi .ui-datepicker-group { float:left; }
|
186 |
+
.ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; }
|
187 |
+
.ui-datepicker-multi-2 .ui-datepicker-group { width:50%; }
|
188 |
+
.ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; }
|
189 |
+
.ui-datepicker-multi-4 .ui-datepicker-group { width:25%; }
|
190 |
+
.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; }
|
191 |
+
.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; }
|
192 |
+
.ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; }
|
193 |
+
.ui-datepicker-row-break { clear:both; width:100%; font-size:0em; }
|
194 |
+
|
195 |
+
/* RTL support */
|
196 |
+
.ui-datepicker-rtl { direction: rtl; }
|
197 |
+
.ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; }
|
198 |
+
.ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; }
|
199 |
+
.ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; }
|
200 |
+
.ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; }
|
201 |
+
.ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; }
|
202 |
+
.ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; }
|
203 |
+
.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; }
|
204 |
+
.ui-datepicker-rtl .ui-datepicker-group { float:right; }
|
205 |
+
.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; }
|
206 |
+
.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; }
|
207 |
+
|
208 |
+
/* IE6 IFRAME FIX (taken from datepicker 1.5.3 */
|
209 |
+
.ui-datepicker-cover {
|
210 |
+
display: none; /*sorry for IE5*/
|
211 |
+
display/**/: block; /*sorry for IE5*/
|
212 |
+
position: absolute; /*must have*/
|
213 |
+
z-index: -1; /*must have*/
|
214 |
+
filter: mask(); /*must have*/
|
215 |
+
top: -4px; /*must have*/
|
216 |
+
left: -4px; /*must have*/
|
217 |
+
width: 200px; /*must have*/
|
218 |
+
height: 200px; /*must have*/
|
219 |
+
}/*
|
220 |
+
* jQuery UI Dialog 1.8.14
|
221 |
+
*
|
222 |
+
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
223 |
+
* Dual licensed under the MIT or GPL Version 2 licenses.
|
224 |
+
* http://jquery.org/license
|
225 |
+
*
|
226 |
+
* http://docs.jquery.com/UI/Dialog#theming
|
227 |
+
*/
|
228 |
+
.ui-dialog { position: absolute; padding: .2em; width: 300px; overflow: hidden; }
|
229 |
+
.ui-dialog .ui-dialog-titlebar { padding: .4em 1em; position: relative; }
|
230 |
+
.ui-dialog .ui-dialog-title { float: left; margin: .1em 16px .1em 0; }
|
231 |
+
.ui-dialog .ui-dialog-titlebar-close { position: absolute; right: .3em; top: 50%; width: 19px; margin: -10px 0 0 0; padding: 1px; height: 18px; }
|
232 |
+
.ui-dialog .ui-dialog-titlebar-close span { display: block; margin: 1px; }
|
233 |
+
.ui-dialog .ui-dialog-titlebar-close:hover, .ui-dialog .ui-dialog-titlebar-close:focus { padding: 0; }
|
234 |
+
.ui-dialog .ui-dialog-content { position: relative; border: 0; padding: .5em 1em; background: none; overflow: auto; zoom: 1; }
|
235 |
+
.ui-dialog .ui-dialog-buttonpane { text-align: left; border-width: 1px 0 0 0; background-image: none; margin: .5em 0 0 0; padding: .3em 1em .5em .4em; }
|
236 |
+
.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset { float: right; }
|
237 |
+
.ui-dialog .ui-dialog-buttonpane button { margin: .5em .4em .5em 0; cursor: pointer; }
|
238 |
+
.ui-dialog .ui-resizable-se { width: 14px; height: 14px; right: 3px; bottom: 3px; }
|
239 |
+
.ui-draggable .ui-dialog-titlebar { cursor: move; }
|
240 |
+
/*
|
241 |
+
* jQuery UI Progressbar 1.8.14
|
242 |
+
*
|
243 |
+
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
244 |
+
* Dual licensed under the MIT or GPL Version 2 licenses.
|
245 |
+
* http://jquery.org/license
|
246 |
+
*
|
247 |
+
* http://docs.jquery.com/UI/Progressbar#theming
|
248 |
+
*/
|
249 |
+
.ui-progressbar { height:2em; text-align: left; }
|
250 |
+
.ui-progressbar .ui-progressbar-value {margin: -1px; height:100%; }/*
|
251 |
+
* jQuery UI Resizable 1.8.14
|
252 |
+
*
|
253 |
+
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
254 |
+
* Dual licensed under the MIT or GPL Version 2 licenses.
|
255 |
+
* http://jquery.org/license
|
256 |
+
*
|
257 |
+
* http://docs.jquery.com/UI/Resizable#theming
|
258 |
+
*/
|
259 |
+
.ui-resizable { position: relative;}
|
260 |
+
.ui-resizable-handle { position: absolute;font-size: 0.1px;z-index: 99999; display: block; }
|
261 |
+
.ui-resizable-disabled .ui-resizable-handle, .ui-resizable-autohide .ui-resizable-handle { display: none; }
|
262 |
+
.ui-resizable-n { cursor: n-resize; height: 7px; width: 100%; top: -5px; left: 0; }
|
263 |
+
.ui-resizable-s { cursor: s-resize; height: 7px; width: 100%; bottom: -5px; left: 0; }
|
264 |
+
.ui-resizable-e { cursor: e-resize; width: 7px; right: -5px; top: 0; height: 100%; }
|
265 |
+
.ui-resizable-w { cursor: w-resize; width: 7px; left: -5px; top: 0; height: 100%; }
|
266 |
+
.ui-resizable-se { cursor: se-resize; width: 12px; height: 12px; right: 1px; bottom: 1px; }
|
267 |
+
.ui-resizable-sw { cursor: sw-resize; width: 9px; height: 9px; left: -5px; bottom: -5px; }
|
268 |
+
.ui-resizable-nw { cursor: nw-resize; width: 9px; height: 9px; left: -5px; top: -5px; }
|
269 |
+
.ui-resizable-ne { cursor: ne-resize; width: 9px; height: 9px; right: -5px; top: -5px;}/*
|
270 |
+
* jQuery UI Selectable 1.8.14
|
271 |
+
*
|
272 |
+
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
273 |
+
* Dual licensed under the MIT or GPL Version 2 licenses.
|
274 |
+
* http://jquery.org/license
|
275 |
+
*
|
276 |
+
* http://docs.jquery.com/UI/Selectable#theming
|
277 |
+
*/
|
278 |
+
.ui-selectable-helper { position: absolute; z-index: 100; border:1px dotted black; }
|
279 |
+
/*
|
280 |
+
* jQuery UI Slider 1.8.14
|
281 |
+
*
|
282 |
+
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
283 |
+
* Dual licensed under the MIT or GPL Version 2 licenses.
|
284 |
+
* http://jquery.org/license
|
285 |
+
*
|
286 |
+
* http://docs.jquery.com/UI/Slider#theming
|
287 |
+
*/
|
288 |
+
.ui-slider { position: relative; text-align: left; }
|
289 |
+
.ui-slider .ui-slider-handle { position: absolute; z-index: 2; width: 1.2em; height: 1.2em; cursor: default; }
|
290 |
+
.ui-slider .ui-slider-range { position: absolute; z-index: 1; font-size: .7em; display: block; border: 0; background-position: 0 0; }
|
291 |
+
|
292 |
+
.ui-slider-horizontal { height: .8em; }
|
293 |
+
.ui-slider-horizontal .ui-slider-handle { top: -.3em; margin-left: -.6em; }
|
294 |
+
.ui-slider-horizontal .ui-slider-range { top: 0; height: 100%; }
|
295 |
+
.ui-slider-horizontal .ui-slider-range-min { left: 0; }
|
296 |
+
.ui-slider-horizontal .ui-slider-range-max { right: 0; }
|
297 |
+
|
298 |
+
.ui-slider-vertical { width: .8em; height: 100px; }
|
299 |
+
.ui-slider-vertical .ui-slider-handle { left: -.3em; margin-left: 0; margin-bottom: -.6em; }
|
300 |
+
.ui-slider-vertical .ui-slider-range { left: 0; width: 100%; }
|
301 |
+
.ui-slider-vertical .ui-slider-range-min { bottom: 0; }
|
302 |
+
.ui-slider-vertical .ui-slider-range-max { top: 0; }/*
|
303 |
+
* jQuery UI Tabs 1.8.14
|
304 |
+
*
|
305 |
+
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
306 |
+
* Dual licensed under the MIT or GPL Version 2 licenses.
|
307 |
+
* http://jquery.org/license
|
308 |
+
*
|
309 |
+
* http://docs.jquery.com/UI/Tabs#theming
|
310 |
+
*/
|
311 |
+
.ui-tabs { position: relative; padding: .2em; zoom: 1; } /* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */
|
312 |
+
.ui-tabs .ui-tabs-nav { margin: 0; padding: .2em .2em 0; }
|
313 |
+
.ui-tabs .ui-tabs-nav li { list-style: none; float: left; position: relative; top: 1px; margin: 0 .2em 1px 0; border-bottom: 0 !important; padding: 0; white-space: nowrap; }
|
314 |
+
.ui-tabs .ui-tabs-nav li a { float: left; padding: .5em 1em; text-decoration: none; }
|
315 |
+
.ui-tabs .ui-tabs-nav li.ui-tabs-selected { margin-bottom: 0; padding-bottom: 1px; }
|
316 |
+
.ui-tabs .ui-tabs-nav li.ui-tabs-selected a, .ui-tabs .ui-tabs-nav li.ui-state-disabled a, .ui-tabs .ui-tabs-nav li.ui-state-processing a { cursor: text; }
|
317 |
+
.ui-tabs .ui-tabs-nav li a, .ui-tabs.ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-selected a { cursor: pointer; } /* first selector in group seems obsolete, but required to overcome bug in Opera applying cursor: text overall if defined elsewhere... */
|
318 |
+
.ui-tabs .ui-tabs-panel { display: block; border-width: 0; padding: 1em 1.4em; background: none; }
|
319 |
+
.ui-tabs .ui-tabs-hide { display: none !important; }
|
320 |
+
/*
|
321 |
+
* jQuery UI CSS Framework 1.8.14
|
322 |
+
*
|
323 |
+
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
324 |
+
* Dual licensed under the MIT or GPL Version 2 licenses.
|
325 |
+
* http://jquery.org/license
|
326 |
+
*
|
327 |
+
* http://docs.jquery.com/UI/Theming/API
|
328 |
+
*
|
329 |
+
* To view and modify this theme, visit http://jqueryui.com/themeroller/
|
330 |
+
*/
|
331 |
+
|
332 |
+
|
333 |
+
/* Component containers
|
334 |
+
----------------------------------*/
|
335 |
+
.ui-widget { font-family: Verdana,Arial,sans-serif/*{ffDefault}*/; font-size: 1.1em/*{fsDefault}*/; }
|
336 |
+
.ui-widget .ui-widget { font-size: 1em; }
|
337 |
+
.ui-widget input, .ui-widget select, .ui-widget textarea, .ui-widget button { font-family: Verdana,Arial,sans-serif/*{ffDefault}*/; font-size: 1em; }
|
338 |
+
.ui-widget-content { border: 1px solid #aaaaaa/*{borderColorContent}*/; background: #ffffff/*{bgColorContent}*/ url(images/ui-bg_flat_75_ffffff_40x100.png)/*{bgImgUrlContent}*/ 50%/*{bgContentXPos}*/ 50%/*{bgContentYPos}*/ repeat-x/*{bgContentRepeat}*/; color: #949494/*{fcContent}*/; }
|
339 |
+
.ui-widget-content a { color: #949494/*{fcContent}*/; }
|
340 |
+
.ui-widget-header { border: 1px solid #aaaaaa/*{borderColorHeader}*/; background: #cccccc/*{bgColorHeader}*/ url(images/ui-bg_highlight-soft_75_cccccc_1x100.png)/*{bgImgUrlHeader}*/ 50%/*{bgHeaderXPos}*/ 50%/*{bgHeaderYPos}*/ repeat-x/*{bgHeaderRepeat}*/; color: #949494/*{fcHeader}*/; font-weight: bold; }
|
341 |
+
.ui-widget-header a { color: #222222/*{fcHeader}*/; }
|
342 |
+
|
343 |
+
/* Interaction states
|
344 |
+
----------------------------------*/
|
345 |
+
.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { border: 1px solid #d3d3d3/*{borderColorDefault}*/; background: #7DB5D8/*{bgColorDefault}*/ /*{bgImgUrlDefault}*/ 50%/*{bgDefaultXPos}*/ 50%/*{bgDefaultYPos}*/ repeat-x/*{bgDefaultRepeat}*/; font-weight: normal/*{fwDefault}*/; color: #fff/*{fcDefault}*/; }
|
346 |
+
.ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #555555/*{fcDefault}*/; text-decoration: none; }
|
347 |
+
.ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { border: 1px solid #999999/*{borderColorHover}*/; background: #7DB5D8/*{bgColorHover}*/ /*{bgImgUrlHover}*/ 50%/*{bgHoverXPos}*/ 50%/*{bgHoverYPos}*/ repeat-x/*{bgHoverRepeat}*/; font-weight: normal/*{fwDefault}*/; color: #fff/*{fcHover}*/; }
|
348 |
+
.ui-state-hover a, .ui-state-hover a:hover { color: #212121/*{fcHover}*/; text-decoration: none; }
|
349 |
+
.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { border: 1px solid #aaaaaa/*{borderColorActive}*/; background: #ffffff/*{bgColorActive}*/ url(images/ui-bg_glass_65_ffffff_1x400.png)/*{bgImgUrlActive}*/ 50%/*{bgActiveXPos}*/ 50%/*{bgActiveYPos}*/ repeat-x/*{bgActiveRepeat}*/; font-weight: normal/*{fwDefault}*/; color: #212121/*{fcActive}*/; }
|
350 |
+
.ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #212121/*{fcActive}*/; text-decoration: none; }
|
351 |
+
.ui-widget :active { outline: none; }
|
352 |
+
|
353 |
+
/* Interaction Cues
|
354 |
+
----------------------------------*/
|
355 |
+
.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight {border: 1px solid #fcefa1/*{borderColorHighlight}*/; background: #fbf9ee/*{bgColorHighlight}*/ url(images/ui-bg_glass_55_fbf9ee_1x400.png)/*{bgImgUrlHighlight}*/ 50%/*{bgHighlightXPos}*/ 50%/*{bgHighlightYPos}*/ repeat-x/*{bgHighlightRepeat}*/; color: #363636/*{fcHighlight}*/; }
|
356 |
+
.ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #363636/*{fcHighlight}*/; }
|
357 |
+
.ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error {border: 1px solid #cd0a0a/*{borderColorError}*/; background: #fef1ec/*{bgColorError}*/ url(images/ui-bg_glass_95_fef1ec_1x400.png)/*{bgImgUrlError}*/ 50%/*{bgErrorXPos}*/ 50%/*{bgErrorYPos}*/ repeat-x/*{bgErrorRepeat}*/; color: #cd0a0a/*{fcError}*/; }
|
358 |
+
.ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #cd0a0a/*{fcError}*/; }
|
359 |
+
.ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #cd0a0a/*{fcError}*/; }
|
360 |
+
.ui-priority-primary, .ui-widget-content .ui-priority-primary, .ui-widget-header .ui-priority-primary { font-weight: bold; }
|
361 |
+
.ui-priority-secondary, .ui-widget-content .ui-priority-secondary, .ui-widget-header .ui-priority-secondary { opacity: .7; filter:Alpha(Opacity=70); font-weight: normal; }
|
362 |
+
.ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled { opacity: .35; filter:Alpha(Opacity=35); background-image: none; }
|
363 |
+
|
364 |
+
/* Icons
|
365 |
+
----------------------------------*/
|
366 |
+
|
367 |
+
/* states and images */
|
368 |
+
.ui-icon { width: 16px; height: 16px; background-image: url(images/ui-icons_222222_256x240.png)/*{iconsContent}*/; }
|
369 |
+
.ui-widget-content .ui-icon {background-image: url(images/ui-icons_222222_256x240.png)/*{iconsContent}*/; }
|
370 |
+
.ui-widget-header .ui-icon {background-image: url(images/ui-icons_222222_256x240.png)/*{iconsHeader}*/; }
|
371 |
+
.ui-state-default .ui-icon { background-image: url(images/ui-icons_888888_256x240.png)/*{iconsDefault}*/; }
|
372 |
+
.ui-state-hover .ui-icon, .ui-state-focus .ui-icon {background-image: url(images/ui-icons_454545_256x240.png)/*{iconsHover}*/; }
|
373 |
+
.ui-state-active .ui-icon {background-image: url(images/ui-icons_454545_256x240.png)/*{iconsActive}*/; }
|
374 |
+
.ui-state-highlight .ui-icon {background-image: url(images/ui-icons_2e83ff_256x240.png)/*{iconsHighlight}*/; }
|
375 |
+
.ui-state-error .ui-icon, .ui-state-error-text .ui-icon {background-image: url(images/ui-icons_cd0a0a_256x240.png)/*{iconsError}*/; }
|
376 |
+
|
377 |
+
/* positioning */
|
378 |
+
.ui-icon-carat-1-n { background-position: 0 0; }
|
379 |
+
.ui-icon-carat-1-ne { background-position: -16px 0; }
|
380 |
+
.ui-icon-carat-1-e { background-position: -32px 0; }
|
381 |
+
.ui-icon-carat-1-se { background-position: -48px 0; }
|
382 |
+
.ui-icon-carat-1-s { background-position: -64px 0; }
|
383 |
+
.ui-icon-carat-1-sw { background-position: -80px 0; }
|
384 |
+
.ui-icon-carat-1-w { background-position: -96px 0; }
|
385 |
+
.ui-icon-carat-1-nw { background-position: -112px 0; }
|
386 |
+
.ui-icon-carat-2-n-s { background-position: -128px 0; }
|
387 |
+
.ui-icon-carat-2-e-w { background-position: -144px 0; }
|
388 |
+
.ui-icon-triangle-1-n { background-position: 0 -16px; }
|
389 |
+
.ui-icon-triangle-1-ne { background-position: -16px -16px; }
|
390 |
+
.ui-icon-triangle-1-e { background-position: -32px -16px; }
|
391 |
+
.ui-icon-triangle-1-se { background-position: -48px -16px; }
|
392 |
+
.ui-icon-triangle-1-s { background-position: -64px -16px; }
|
393 |
+
.ui-icon-triangle-1-sw { background-position: -80px -16px; }
|
394 |
+
.ui-icon-triangle-1-w { background-position: -96px -16px; }
|
395 |
+
.ui-icon-triangle-1-nw { background-position: -112px -16px; }
|
396 |
+
.ui-icon-triangle-2-n-s { background-position: -128px -16px; }
|
397 |
+
.ui-icon-triangle-2-e-w { background-position: -144px -16px; }
|
398 |
+
.ui-icon-arrow-1-n { background-position: 0 -32px; }
|
399 |
+
.ui-icon-arrow-1-ne { background-position: -16px -32px; }
|
400 |
+
.ui-icon-arrow-1-e { background-position: -32px -32px; }
|
401 |
+
.ui-icon-arrow-1-se { background-position: -48px -32px; }
|
402 |
+
.ui-icon-arrow-1-s { background-position: -64px -32px; }
|
403 |
+
.ui-icon-arrow-1-sw { background-position: -80px -32px; }
|
404 |
+
.ui-icon-arrow-1-w { background-position: -96px -32px; }
|
405 |
+
.ui-icon-arrow-1-nw { background-position: -112px -32px; }
|
406 |
+
.ui-icon-arrow-2-n-s { background-position: -128px -32px; }
|
407 |
+
.ui-icon-arrow-2-ne-sw { background-position: -144px -32px; }
|
408 |
+
.ui-icon-arrow-2-e-w { background-position: -160px -32px; }
|
409 |
+
.ui-icon-arrow-2-se-nw { background-position: -176px -32px; }
|
410 |
+
.ui-icon-arrowstop-1-n { background-position: -192px -32px; }
|
411 |
+
.ui-icon-arrowstop-1-e { background-position: -208px -32px; }
|
412 |
+
.ui-icon-arrowstop-1-s { background-position: -224px -32px; }
|
413 |
+
.ui-icon-arrowstop-1-w { background-position: -240px -32px; }
|
414 |
+
.ui-icon-arrowthick-1-n { background-position: 0 -48px; }
|
415 |
+
.ui-icon-arrowthick-1-ne { background-position: -16px -48px; }
|
416 |
+
.ui-icon-arrowthick-1-e { background-position: -32px -48px; }
|
417 |
+
.ui-icon-arrowthick-1-se { background-position: -48px -48px; }
|
418 |
+
.ui-icon-arrowthick-1-s { background-position: -64px -48px; }
|
419 |
+
.ui-icon-arrowthick-1-sw { background-position: -80px -48px; }
|
420 |
+
.ui-icon-arrowthick-1-w { background-position: -96px -48px; }
|
421 |
+
.ui-icon-arrowthick-1-nw { background-position: -112px -48px; }
|
422 |
+
.ui-icon-arrowthick-2-n-s { background-position: -128px -48px; }
|
423 |
+
.ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; }
|
424 |
+
.ui-icon-arrowthick-2-e-w { background-position: -160px -48px; }
|
425 |
+
.ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; }
|
426 |
+
.ui-icon-arrowthickstop-1-n { background-position: -192px -48px; }
|
427 |
+
.ui-icon-arrowthickstop-1-e { background-position: -208px -48px; }
|
428 |
+
.ui-icon-arrowthickstop-1-s { background-position: -224px -48px; }
|
429 |
+
.ui-icon-arrowthickstop-1-w { background-position: -240px -48px; }
|
430 |
+
.ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; }
|
431 |
+
.ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; }
|
432 |
+
.ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; }
|
433 |
+
.ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; }
|
434 |
+
.ui-icon-arrowreturn-1-w { background-position: -64px -64px; }
|
435 |
+
.ui-icon-arrowreturn-1-n { background-position: -80px -64px; }
|
436 |
+
.ui-icon-arrowreturn-1-e { background-position: -96px -64px; }
|
437 |
+
.ui-icon-arrowreturn-1-s { background-position: -112px -64px; }
|
438 |
+
.ui-icon-arrowrefresh-1-w { background-position: -128px -64px; }
|
439 |
+
.ui-icon-arrowrefresh-1-n { background-position: -144px -64px; }
|
440 |
+
.ui-icon-arrowrefresh-1-e { background-position: -160px -64px; }
|
441 |
+
.ui-icon-arrowrefresh-1-s { background-position: -176px -64px; }
|
442 |
+
.ui-icon-arrow-4 { background-position: 0 -80px; }
|
443 |
+
.ui-icon-arrow-4-diag { background-position: -16px -80px; }
|
444 |
+
.ui-icon-extlink { background-position: -32px -80px; }
|
445 |
+
.ui-icon-newwin { background-position: -48px -80px; }
|
446 |
+
.ui-icon-refresh { background-position: -64px -80px; }
|
447 |
+
.ui-icon-shuffle { background-position: -80px -80px; }
|
448 |
+
.ui-icon-transfer-e-w { background-position: -96px -80px; }
|
449 |
+
.ui-icon-transferthick-e-w { background-position: -112px -80px; }
|
450 |
+
.ui-icon-folder-collapsed { background-position: 0 -96px; }
|
451 |
+
.ui-icon-folder-open { background-position: -16px -96px; }
|
452 |
+
.ui-icon-document { background-position: -32px -96px; }
|
453 |
+
.ui-icon-document-b { background-position: -48px -96px; }
|
454 |
+
.ui-icon-note { background-position: -64px -96px; }
|
455 |
+
.ui-icon-mail-closed { background-position: -80px -96px; }
|
456 |
+
.ui-icon-mail-open { background-position: -96px -96px; }
|
457 |
+
.ui-icon-suitcase { background-position: -112px -96px; }
|
458 |
+
.ui-icon-comment { background-position: -128px -96px; }
|
459 |
+
.ui-icon-person { background-position: -144px -96px; }
|
460 |
+
.ui-icon-print { background-position: -160px -96px; }
|
461 |
+
.ui-icon-trash { background-position: -176px -96px; }
|
462 |
+
.ui-icon-locked { background-position: -192px -96px; }
|
463 |
+
.ui-icon-unlocked { background-position: -208px -96px; }
|
464 |
+
.ui-icon-bookmark { background-position: -224px -96px; }
|
465 |
+
.ui-icon-tag { background-position: -240px -96px; }
|
466 |
+
.ui-icon-home { background-position: 0 -112px; }
|
467 |
+
.ui-icon-flag { background-position: -16px -112px; }
|
468 |
+
.ui-icon-calendar { background-position: -32px -112px; }
|
469 |
+
.ui-icon-cart { background-position: -48px -112px; }
|
470 |
+
.ui-icon-pencil { background-position: -64px -112px; }
|
471 |
+
.ui-icon-clock { background-position: -80px -112px; }
|
472 |
+
.ui-icon-disk { background-position: -96px -112px; }
|
473 |
+
.ui-icon-calculator { background-position: -112px -112px; }
|
474 |
+
.ui-icon-zoomin { background-position: -128px -112px; }
|
475 |
+
.ui-icon-zoomout { background-position: -144px -112px; }
|
476 |
+
.ui-icon-search { background-position: -160px -112px; }
|
477 |
+
.ui-icon-wrench { background-position: -176px -112px; }
|
478 |
+
.ui-icon-gear { background-position: -192px -112px; }
|
479 |
+
.ui-icon-heart { background-position: -208px -112px; }
|
480 |
+
.ui-icon-star { background-position: -224px -112px; }
|
481 |
+
.ui-icon-link { background-position: -240px -112px; }
|
482 |
+
.ui-icon-cancel { background-position: 0 -128px; }
|
483 |
+
.ui-icon-plus { background-position: -16px -128px; }
|
484 |
+
.ui-icon-plusthick { background-position: -32px -128px; }
|
485 |
+
.ui-icon-minus { background-position: -48px -128px; }
|
486 |
+
.ui-icon-minusthick { background-position: -64px -128px; }
|
487 |
+
.ui-icon-close { background-position: -80px -128px; }
|
488 |
+
.ui-icon-closethick { background-position: -96px -128px; }
|
489 |
+
.ui-icon-key { background-position: -112px -128px; }
|
490 |
+
.ui-icon-lightbulb { background-position: -128px -128px; }
|
491 |
+
.ui-icon-scissors { background-position: -144px -128px; }
|
492 |
+
.ui-icon-clipboard { background-position: -160px -128px; }
|
493 |
+
.ui-icon-copy { background-position: -176px -128px; }
|
494 |
+
.ui-icon-contact { background-position: -192px -128px; }
|
495 |
+
.ui-icon-image { background-position: -208px -128px; }
|
496 |
+
.ui-icon-video { background-position: -224px -128px; }
|
497 |
+
.ui-icon-script { background-position: -240px -128px; }
|
498 |
+
.ui-icon-alert { background-position: 0 -144px; }
|
499 |
+
.ui-icon-info { background-position: -16px -144px; }
|
500 |
+
.ui-icon-notice { background-position: -32px -144px; }
|
501 |
+
.ui-icon-help { background-position: -48px -144px; }
|
502 |
+
.ui-icon-check { background-position: -64px -144px; }
|
503 |
+
.ui-icon-bullet { background-position: -80px -144px; }
|
504 |
+
.ui-icon-radio-off { background-position: -96px -144px; }
|
505 |
+
.ui-icon-radio-on { background-position: -112px -144px; }
|
506 |
+
.ui-icon-pin-w { background-position: -128px -144px; }
|
507 |
+
.ui-icon-pin-s { background-position: -144px -144px; }
|
508 |
+
.ui-icon-play { background-position: 0 -160px; }
|
509 |
+
.ui-icon-pause { background-position: -16px -160px; }
|
510 |
+
.ui-icon-seek-next { background-position: -32px -160px; }
|
511 |
+
.ui-icon-seek-prev { background-position: -48px -160px; }
|
512 |
+
.ui-icon-seek-end { background-position: -64px -160px; }
|
513 |
+
.ui-icon-seek-start { background-position: -80px -160px; }
|
514 |
+
/* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */
|
515 |
+
.ui-icon-seek-first { background-position: -80px -160px; }
|
516 |
+
.ui-icon-stop { background-position: -96px -160px; }
|
517 |
+
.ui-icon-eject { background-position: -112px -160px; }
|
518 |
+
.ui-icon-volume-off { background-position: -128px -160px; }
|
519 |
+
.ui-icon-volume-on { background-position: -144px -160px; }
|
520 |
+
.ui-icon-power { background-position: 0 -176px; }
|
521 |
+
.ui-icon-signal-diag { background-position: -16px -176px; }
|
522 |
+
.ui-icon-signal { background-position: -32px -176px; }
|
523 |
+
.ui-icon-battery-0 { background-position: -48px -176px; }
|
524 |
+
.ui-icon-battery-1 { background-position: -64px -176px; }
|
525 |
+
.ui-icon-battery-2 { background-position: -80px -176px; }
|
526 |
+
.ui-icon-battery-3 { background-position: -96px -176px; }
|
527 |
+
.ui-icon-circle-plus { background-position: 0 -192px; }
|
528 |
+
.ui-icon-circle-minus { background-position: -16px -192px; }
|
529 |
+
.ui-icon-circle-close { background-position: -32px -192px; }
|
530 |
+
.ui-icon-circle-triangle-e { background-position: -48px -192px; }
|
531 |
+
.ui-icon-circle-triangle-s { background-position: -64px -192px; }
|
532 |
+
.ui-icon-circle-triangle-w { background-position: -80px -192px; }
|
533 |
+
.ui-icon-circle-triangle-n { background-position: -96px -192px; }
|
534 |
+
.ui-icon-circle-arrow-e { background-position: -112px -192px; }
|
535 |
+
.ui-icon-circle-arrow-s { background-position: -128px -192px; }
|
536 |
+
.ui-icon-circle-arrow-w { background-position: -144px -192px; }
|
537 |
+
.ui-icon-circle-arrow-n { background-position: -160px -192px; }
|
538 |
+
.ui-icon-circle-zoomin { background-position: -176px -192px; }
|
539 |
+
.ui-icon-circle-zoomout { background-position: -192px -192px; }
|
540 |
+
.ui-icon-circle-check { background-position: -208px -192px; }
|
541 |
+
.ui-icon-circlesmall-plus { background-position: 0 -208px; }
|
542 |
+
.ui-icon-circlesmall-minus { background-position: -16px -208px; }
|
543 |
+
.ui-icon-circlesmall-close { background-position: -32px -208px; }
|
544 |
+
.ui-icon-squaresmall-plus { background-position: -48px -208px; }
|
545 |
+
.ui-icon-squaresmall-minus { background-position: -64px -208px; }
|
546 |
+
.ui-icon-squaresmall-close { background-position: -80px -208px; }
|
547 |
+
.ui-icon-grip-dotted-vertical { background-position: 0 -224px; }
|
548 |
+
.ui-icon-grip-dotted-horizontal { background-position: -16px -224px; }
|
549 |
+
.ui-icon-grip-solid-vertical { background-position: -32px -224px; }
|
550 |
+
.ui-icon-grip-solid-horizontal { background-position: -48px -224px; }
|
551 |
+
.ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; }
|
552 |
+
.ui-icon-grip-diagonal-se { background-position: -80px -224px; }
|
553 |
+
|
554 |
+
|
555 |
+
/* Misc visuals
|
556 |
+
----------------------------------*/
|
557 |
+
|
558 |
+
/* Corner radius */
|
559 |
+
.ui-corner-all, .ui-corner-top, .ui-corner-left, .ui-corner-tl { -moz-border-radius-topleft: 4px/*{cornerRadius}*/; -webkit-border-top-left-radius: 4px/*{cornerRadius}*/; -khtml-border-top-left-radius: 4px/*{cornerRadius}*/; border-top-left-radius: 4px/*{cornerRadius}*/; }
|
560 |
+
.ui-corner-all, .ui-corner-top, .ui-corner-right, .ui-corner-tr { -moz-border-radius-topright: 4px/*{cornerRadius}*/; -webkit-border-top-right-radius: 4px/*{cornerRadius}*/; -khtml-border-top-right-radius: 4px/*{cornerRadius}*/; border-top-right-radius: 4px/*{cornerRadius}*/; }
|
561 |
+
.ui-corner-all, .ui-corner-bottom, .ui-corner-left, .ui-corner-bl { -moz-border-radius-bottomleft: 4px/*{cornerRadius}*/; -webkit-border-bottom-left-radius: 4px/*{cornerRadius}*/; -khtml-border-bottom-left-radius: 4px/*{cornerRadius}*/; border-bottom-left-radius: 4px/*{cornerRadius}*/; }
|
562 |
+
.ui-corner-all, .ui-corner-bottom, .ui-corner-right, .ui-corner-br { -moz-border-radius-bottomright: 4px/*{cornerRadius}*/; -webkit-border-bottom-right-radius: 4px/*{cornerRadius}*/; -khtml-border-bottom-right-radius: 4px/*{cornerRadius}*/; border-bottom-right-radius: 4px/*{cornerRadius}*/; }
|
563 |
+
|
564 |
+
/* Overlays */
|
565 |
+
.ui-widget-overlay { background: #aaaaaa/*{bgColorOverlay}*/ url(images/ui-bg_flat_0_aaaaaa_40x100.png)/*{bgImgUrlOverlay}*/ 50%/*{bgOverlayXPos}*/ 50%/*{bgOverlayYPos}*/ repeat-x/*{bgOverlayRepeat}*/; opacity: .3;filter:Alpha(Opacity=30)/*{opacityOverlay}*/; }
|
566 |
.ui-widget-shadow { margin: -8px/*{offsetTopShadow}*/ 0 0 -8px/*{offsetLeftShadow}*/; padding: 8px/*{thicknessShadow}*/; background: #aaaaaa/*{bgColorShadow}*/ url(images/ui-bg_flat_0_aaaaaa_40x100.png)/*{bgImgUrlShadow}*/ 50%/*{bgShadowXPos}*/ 50%/*{bgShadowYPos}*/ repeat-x/*{bgShadowRepeat}*/; opacity: .3;filter:Alpha(Opacity=30)/*{opacityShadow}*/; -moz-border-radius: 8px/*{cornerRadiusShadow}*/; -khtml-border-radius: 8px/*{cornerRadiusShadow}*/; -webkit-border-radius: 8px/*{cornerRadiusShadow}*/; border-radius: 8px/*{cornerRadiusShadow}*/; }
|
inc/css/jquery.datetimepicker.css
CHANGED
@@ -1,418 +1,418 @@
|
|
1 |
-
.xdsoft_datetimepicker{
|
2 |
-
box-shadow: 0 5px 15px -5px rgba(0, 0, 0, 0.506);
|
3 |
-
background: #FFFFFF;
|
4 |
-
border-bottom: 1px solid #BBBBBB;
|
5 |
-
border-left: 1px solid #CCCCCC;
|
6 |
-
border-right: 1px solid #CCCCCC;
|
7 |
-
border-top: 1px solid #CCCCCC;
|
8 |
-
color: #333333;
|
9 |
-
font-family: "Helvetica Neue", "Helvetica", "Arial", sans-serif;
|
10 |
-
padding: 8px;
|
11 |
-
padding-left: 0;
|
12 |
-
padding-top: 2px;
|
13 |
-
position: absolute;
|
14 |
-
z-index: 9999;
|
15 |
-
-moz-box-sizing: border-box;
|
16 |
-
box-sizing: border-box;
|
17 |
-
display:none;
|
18 |
-
}
|
19 |
-
|
20 |
-
.xdsoft_datetimepicker iframe {
|
21 |
-
position: absolute;
|
22 |
-
left: 0;
|
23 |
-
top: 0;
|
24 |
-
width: 75px;
|
25 |
-
height: 210px;
|
26 |
-
background: transparent;
|
27 |
-
border:none;
|
28 |
-
}
|
29 |
-
/*For IE8 or lower*/
|
30 |
-
.xdsoft_datetimepicker button {
|
31 |
-
border:none !important;
|
32 |
-
}
|
33 |
-
|
34 |
-
.xdsoft_noselect{
|
35 |
-
-webkit-touch-callout: none;
|
36 |
-
-webkit-user-select: none;
|
37 |
-
-khtml-user-select: none;
|
38 |
-
-moz-user-select: none;
|
39 |
-
-ms-user-select: none;
|
40 |
-
-o-user-select: none;
|
41 |
-
user-select: none;
|
42 |
-
}
|
43 |
-
.xdsoft_noselect::selection { background: transparent; }
|
44 |
-
.xdsoft_noselect::-moz-selection { background: transparent; }
|
45 |
-
.xdsoft_datetimepicker.xdsoft_inline{
|
46 |
-
display: inline-block;
|
47 |
-
position: static;
|
48 |
-
box-shadow: none;
|
49 |
-
}
|
50 |
-
.xdsoft_datetimepicker *{
|
51 |
-
-moz-box-sizing: border-box;
|
52 |
-
box-sizing: border-box;
|
53 |
-
padding: 0;
|
54 |
-
margin: 0;
|
55 |
-
}
|
56 |
-
.xdsoft_datetimepicker .xdsoft_datepicker, .xdsoft_datetimepicker .xdsoft_timepicker{
|
57 |
-
display:none;
|
58 |
-
}
|
59 |
-
.xdsoft_datetimepicker .xdsoft_datepicker.active, .xdsoft_datetimepicker .xdsoft_timepicker.active{
|
60 |
-
display:block;
|
61 |
-
}
|
62 |
-
.xdsoft_datetimepicker .xdsoft_datepicker{
|
63 |
-
width: 224px;
|
64 |
-
float:left;
|
65 |
-
margin-left:8px;
|
66 |
-
}
|
67 |
-
.xdsoft_datetimepicker.xdsoft_showweeks .xdsoft_datepicker{
|
68 |
-
width: 256px;
|
69 |
-
}
|
70 |
-
.xdsoft_datetimepicker .xdsoft_timepicker{
|
71 |
-
width: 58px;
|
72 |
-
float:left;
|
73 |
-
text-align:center;
|
74 |
-
margin-left:8px;
|
75 |
-
margin-top: 0;
|
76 |
-
}
|
77 |
-
.xdsoft_datetimepicker .xdsoft_datepicker.active+.xdsoft_timepicker{
|
78 |
-
margin-top:8px;
|
79 |
-
margin-bottom:3px
|
80 |
-
}
|
81 |
-
.xdsoft_datetimepicker .xdsoft_mounthpicker{
|
82 |
-
position: relative;
|
83 |
-
text-align: center;
|
84 |
-
}
|
85 |
-
|
86 |
-
.xdsoft_datetimepicker .xdsoft_label i,
|
87 |
-
.xdsoft_datetimepicker .xdsoft_prev,
|
88 |
-
.xdsoft_datetimepicker .xdsoft_next,
|
89 |
-
.xdsoft_datetimepicker .xdsoft_today_button{
|
90 |
-
background-image: url();
|
91 |
-
}
|
92 |
-
|
93 |
-
.xdsoft_datetimepicker .xdsoft_label i{
|
94 |
-
opacity:0.5;
|
95 |
-
background-position:-92px -19px;
|
96 |
-
display: inline-block;
|
97 |
-
width: 9px;
|
98 |
-
height: 20px;
|
99 |
-
vertical-align: middle;
|
100 |
-
}
|
101 |
-
|
102 |
-
.xdsoft_datetimepicker .xdsoft_prev{
|
103 |
-
float: left;
|
104 |
-
background-position:-20px 0;
|
105 |
-
}
|
106 |
-
.xdsoft_datetimepicker .xdsoft_today_button{
|
107 |
-
float: left;
|
108 |
-
background-position:-70px 0;
|
109 |
-
margin-left:5px;
|
110 |
-
}
|
111 |
-
|
112 |
-
.xdsoft_datetimepicker .xdsoft_next{
|
113 |
-
float: right;
|
114 |
-
background-position: 0 0;
|
115 |
-
}
|
116 |
-
|
117 |
-
.xdsoft_datetimepicker .xdsoft_next,
|
118 |
-
.xdsoft_datetimepicker .xdsoft_prev ,
|
119 |
-
.xdsoft_datetimepicker .xdsoft_today_button{
|
120 |
-
background-color: transparent;
|
121 |
-
background-repeat: no-repeat;
|
122 |
-
border: 0 none currentColor;
|
123 |
-
cursor: pointer;
|
124 |
-
display: block;
|
125 |
-
height: 30px;
|
126 |
-
opacity: 0.5;
|
127 |
-
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
|
128 |
-
outline: medium none currentColor;
|
129 |
-
overflow: hidden;
|
130 |
-
padding: 0;
|
131 |
-
position: relative;
|
132 |
-
text-indent: 100%;
|
133 |
-
white-space: nowrap;
|
134 |
-
width: 20px;
|
135 |
-
}
|
136 |
-
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_prev,
|
137 |
-
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_next{
|
138 |
-
float:none;
|
139 |
-
background-position:-40px -15px;
|
140 |
-
height: 15px;
|
141 |
-
width: 30px;
|
142 |
-
display: block;
|
143 |
-
margin-left:14px;
|
144 |
-
margin-top:7px;
|
145 |
-
}
|
146 |
-
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_prev{
|
147 |
-
background-position:-40px 0;
|
148 |
-
margin-bottom:7px;
|
149 |
-
margin-top: 0;
|
150 |
-
}
|
151 |
-
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box{
|
152 |
-
height:151px;
|
153 |
-
overflow:hidden;
|
154 |
-
border-bottom:1px solid #DDDDDD;
|
155 |
-
}
|
156 |
-
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div{
|
157 |
-
background: #F5F5F5;
|
158 |
-
border-top:1px solid #DDDDDD;
|
159 |
-
color: #666666;
|
160 |
-
font-size: 12px;
|
161 |
-
text-align: center;
|
162 |
-
border-collapse:collapse;
|
163 |
-
cursor:pointer;
|
164 |
-
border-bottom-width: 0;
|
165 |
-
height:25px;
|
166 |
-
line-height:25px;
|
167 |
-
}
|
168 |
-
|
169 |
-
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div > div:first-child{
|
170 |
-
border-top-width: 0;
|
171 |
-
}
|
172 |
-
.xdsoft_datetimepicker .xdsoft_today_button:hover,
|
173 |
-
.xdsoft_datetimepicker .xdsoft_next:hover,
|
174 |
-
.xdsoft_datetimepicker .xdsoft_prev:hover {
|
175 |
-
opacity: 1;
|
176 |
-
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
|
177 |
-
}
|
178 |
-
.xdsoft_datetimepicker .xdsoft_label{
|
179 |
-
display: inline;
|
180 |
-
position: relative;
|
181 |
-
z-index: 9999;
|
182 |
-
margin: 0;
|
183 |
-
padding: 5px 3px;
|
184 |
-
font-size: 14px;
|
185 |
-
line-height: 20px;
|
186 |
-
font-weight: bold;
|
187 |
-
background-color: #fff;
|
188 |
-
float:left;
|
189 |
-
width:182px;
|
190 |
-
text-align:center;
|
191 |
-
cursor:pointer;
|
192 |
-
}
|
193 |
-
.xdsoft_datetimepicker .xdsoft_label:hover>span{
|
194 |
-
text-decoration:underline;
|
195 |
-
}
|
196 |
-
.xdsoft_datetimepicker .xdsoft_label:hover i{
|
197 |
-
opacity:1.0;
|
198 |
-
}
|
199 |
-
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select{
|
200 |
-
border:1px solid #ccc;
|
201 |
-
position:absolute;
|
202 |
-
right: 0;
|
203 |
-
top:30px;
|
204 |
-
z-index:101;
|
205 |
-
display:none;
|
206 |
-
background:#fff;
|
207 |
-
max-height:160px;
|
208 |
-
overflow-y:hidden;
|
209 |
-
}
|
210 |
-
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select.xdsoft_monthselect{right:-7px;}
|
211 |
-
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select.xdsoft_yearselect{right:2px;}
|
212 |
-
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select > div > .xdsoft_option:hover{
|
213 |
-
color: #fff;
|
214 |
-
background: #ff8000;
|
215 |
-
}
|
216 |
-
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select > div > .xdsoft_option{
|
217 |
-
padding:2px 10px 2px 5px;
|
218 |
-
text-decoration:none !important;
|
219 |
-
}
|
220 |
-
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select > div > .xdsoft_option.xdsoft_current{
|
221 |
-
background: #33AAFF;
|
222 |
-
box-shadow: #178FE5 0 1px 3px 0 inset;
|
223 |
-
color:#fff;
|
224 |
-
font-weight: 700;
|
225 |
-
}
|
226 |
-
.xdsoft_datetimepicker .xdsoft_month{
|
227 |
-
width:100px;
|
228 |
-
text-align:right;
|
229 |
-
}
|
230 |
-
.xdsoft_datetimepicker .xdsoft_calendar{
|
231 |
-
clear:both;
|
232 |
-
}
|
233 |
-
.xdsoft_datetimepicker .xdsoft_year{
|
234 |
-
width: 48px;
|
235 |
-
margin-left: 5px;
|
236 |
-
}
|
237 |
-
.xdsoft_datetimepicker .xdsoft_calendar table{
|
238 |
-
border-collapse:collapse;
|
239 |
-
width:100%;
|
240 |
-
|
241 |
-
}
|
242 |
-
.xdsoft_datetimepicker .xdsoft_calendar td > div{
|
243 |
-
padding-right:5px;
|
244 |
-
}
|
245 |
-
.xdsoft_datetimepicker .xdsoft_calendar th{
|
246 |
-
height: 25px;
|
247 |
-
}
|
248 |
-
.xdsoft_datetimepicker .xdsoft_calendar td,.xdsoft_datetimepicker .xdsoft_calendar th{
|
249 |
-
width:14.2857142%;
|
250 |
-
background: #F5F5F5;
|
251 |
-
border:1px solid #DDDDDD;
|
252 |
-
color: #666666;
|
253 |
-
font-size: 12px;
|
254 |
-
text-align: right;
|
255 |
-
vertical-align: middle;
|
256 |
-
padding: 0;
|
257 |
-
border-collapse:collapse;
|
258 |
-
cursor:pointer;
|
259 |
-
height: 25px;
|
260 |
-
}
|
261 |
-
.xdsoft_datetimepicker.xdsoft_showweeks .xdsoft_calendar td,.xdsoft_datetimepicker.xdsoft_showweeks .xdsoft_calendar th{
|
262 |
-
width:12.5%;
|
263 |
-
}
|
264 |
-
.xdsoft_datetimepicker .xdsoft_calendar th{
|
265 |
-
background: #F1F1F1;
|
266 |
-
}
|
267 |
-
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_today{
|
268 |
-
color:#33AAFF;
|
269 |
-
}
|
270 |
-
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_default,
|
271 |
-
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_current,
|
272 |
-
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div.xdsoft_current{
|
273 |
-
background: #33AAFF;
|
274 |
-
box-shadow: #178FE5 0 1px 3px 0 inset;
|
275 |
-
color:#fff;
|
276 |
-
font-weight: 700;
|
277 |
-
}
|
278 |
-
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_other_month,
|
279 |
-
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_disabled,
|
280 |
-
.xdsoft_datetimepicker .xdsoft_time_box >div >div.xdsoft_disabled{
|
281 |
-
opacity:0.5;
|
282 |
-
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
|
283 |
-
}
|
284 |
-
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_other_month.xdsoft_disabled{
|
285 |
-
opacity:0.2;
|
286 |
-
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=20)";
|
287 |
-
}
|
288 |
-
.xdsoft_datetimepicker .xdsoft_calendar td:hover,
|
289 |
-
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div:hover{
|
290 |
-
color: #fff !important;
|
291 |
-
background: #ff8000 !important;
|
292 |
-
box-shadow: none !important;
|
293 |
-
}
|
294 |
-
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_disabled:hover,
|
295 |
-
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div.xdsoft_disabled:hover{
|
296 |
-
color: inherit !important;
|
297 |
-
background: inherit !important;
|
298 |
-
box-shadow: inherit !important;
|
299 |
-
}
|
300 |
-
.xdsoft_datetimepicker .xdsoft_calendar th{
|
301 |
-
font-weight: 700;
|
302 |
-
text-align: center;
|
303 |
-
color: #999;
|
304 |
-
cursor:default;
|
305 |
-
}
|
306 |
-
.xdsoft_datetimepicker .xdsoft_copyright{ color:#ccc !important; font-size:10px;clear:both;float:none;margin-left:8px;}
|
307 |
-
.xdsoft_datetimepicker .xdsoft_copyright a{ color:#eee !important;}
|
308 |
-
.xdsoft_datetimepicker .xdsoft_copyright a:hover{ color:#aaa !important;}
|
309 |
-
|
310 |
-
|
311 |
-
.xdsoft_time_box{
|
312 |
-
position:relative;
|
313 |
-
border:1px solid #ccc;
|
314 |
-
}
|
315 |
-
.xdsoft_scrollbar >.xdsoft_scroller{
|
316 |
-
background:#ccc !important;
|
317 |
-
height:20px;
|
318 |
-
border-radius:3px;
|
319 |
-
}
|
320 |
-
.xdsoft_scrollbar{
|
321 |
-
position:absolute;
|
322 |
-
width:7px;
|
323 |
-
right: 0;
|
324 |
-
top: 0;
|
325 |
-
bottom: 0;
|
326 |
-
cursor:pointer;
|
327 |
-
}
|
328 |
-
.xdsoft_scroller_box{
|
329 |
-
position:relative;
|
330 |
-
}
|
331 |
-
|
332 |
-
|
333 |
-
.xdsoft_datetimepicker.xdsoft_dark{
|
334 |
-
box-shadow: 0 5px 15px -5px rgba(255, 255, 255, 0.506);
|
335 |
-
background: #000000;
|
336 |
-
border-bottom: 1px solid #444444;
|
337 |
-
border-left: 1px solid #333333;
|
338 |
-
border-right: 1px solid #333333;
|
339 |
-
border-top: 1px solid #333333;
|
340 |
-
color: #cccccc;
|
341 |
-
}
|
342 |
-
|
343 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_timepicker .xdsoft_time_box{
|
344 |
-
border-bottom:1px solid #222222;
|
345 |
-
}
|
346 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_timepicker .xdsoft_time_box >div >div{
|
347 |
-
background: #0a0a0a;
|
348 |
-
border-top:1px solid #222222;
|
349 |
-
color: #999999;
|
350 |
-
}
|
351 |
-
|
352 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label{
|
353 |
-
background-color: #000;
|
354 |
-
}
|
355 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label > .xdsoft_select{
|
356 |
-
border:1px solid #333;
|
357 |
-
background:#000;
|
358 |
-
}
|
359 |
-
|
360 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label > .xdsoft_select > div > .xdsoft_option:hover{
|
361 |
-
color: #000;
|
362 |
-
background: #007fff;
|
363 |
-
}
|
364 |
-
|
365 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label > .xdsoft_select > div > .xdsoft_option.xdsoft_current{
|
366 |
-
background: #cc5500;
|
367 |
-
box-shadow: #b03e00 0 1px 3px 0 inset;
|
368 |
-
color:#000;
|
369 |
-
}
|
370 |
-
|
371 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label i,
|
372 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_prev,
|
373 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_next,
|
374 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_today_button{
|
375 |
-
background-image: url();
|
376 |
-
}
|
377 |
-
|
378 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td,
|
379 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar th{
|
380 |
-
background: #0a0a0a;
|
381 |
-
border:1px solid #222222;
|
382 |
-
color: #999999;
|
383 |
-
}
|
384 |
-
|
385 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar th{
|
386 |
-
background: #0e0e0e;
|
387 |
-
}
|
388 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td.xdsoft_today{
|
389 |
-
color:#cc5500;
|
390 |
-
}
|
391 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td.xdsoft_default,
|
392 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td.xdsoft_current,
|
393 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_timepicker .xdsoft_time_box >div >div.xdsoft_current{
|
394 |
-
background: #cc5500;
|
395 |
-
box-shadow: #b03e00 0 1px 3px 0 inset;
|
396 |
-
color:#000;
|
397 |
-
}
|
398 |
-
|
399 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td:hover,
|
400 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_timepicker .xdsoft_time_box >div >div:hover{
|
401 |
-
color: #000 !important;
|
402 |
-
background: #007fff !important;
|
403 |
-
}
|
404 |
-
|
405 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar th{
|
406 |
-
color: #666;
|
407 |
-
}
|
408 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_copyright{ color:#333 !important;}
|
409 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_copyright a{ color:#111 !important;}
|
410 |
-
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_copyright a:hover{ color:#555 !important;}
|
411 |
-
|
412 |
-
|
413 |
-
.xdsoft_dark .xdsoft_time_box{
|
414 |
-
border:1px solid #333;
|
415 |
-
}
|
416 |
-
.xdsoft_dark .xdsoft_scrollbar >.xdsoft_scroller{
|
417 |
-
background:#333 !important;
|
418 |
-
}
|
1 |
+
.xdsoft_datetimepicker{
|
2 |
+
box-shadow: 0 5px 15px -5px rgba(0, 0, 0, 0.506);
|
3 |
+
background: #FFFFFF;
|
4 |
+
border-bottom: 1px solid #BBBBBB;
|
5 |
+
border-left: 1px solid #CCCCCC;
|
6 |
+
border-right: 1px solid #CCCCCC;
|
7 |
+
border-top: 1px solid #CCCCCC;
|
8 |
+
color: #333333;
|
9 |
+
font-family: "Helvetica Neue", "Helvetica", "Arial", sans-serif;
|
10 |
+
padding: 8px;
|
11 |
+
padding-left: 0;
|
12 |
+
padding-top: 2px;
|
13 |
+
position: absolute;
|
14 |
+
z-index: 9999;
|
15 |
+
-moz-box-sizing: border-box;
|
16 |
+
box-sizing: border-box;
|
17 |
+
display:none;
|
18 |
+
}
|
19 |
+
|
20 |
+
.xdsoft_datetimepicker iframe {
|
21 |
+
position: absolute;
|
22 |
+
left: 0;
|
23 |
+
top: 0;
|
24 |
+
width: 75px;
|
25 |
+
height: 210px;
|
26 |
+
background: transparent;
|
27 |
+
border:none;
|
28 |
+
}
|
29 |
+
/*For IE8 or lower*/
|
30 |
+
.xdsoft_datetimepicker button {
|
31 |
+
border:none !important;
|
32 |
+
}
|
33 |
+
|
34 |
+
.xdsoft_noselect{
|
35 |
+
-webkit-touch-callout: none;
|
36 |
+
-webkit-user-select: none;
|
37 |
+
-khtml-user-select: none;
|
38 |
+
-moz-user-select: none;
|
39 |
+
-ms-user-select: none;
|
40 |
+
-o-user-select: none;
|
41 |
+
user-select: none;
|
42 |
+
}
|
43 |
+
.xdsoft_noselect::selection { background: transparent; }
|
44 |
+
.xdsoft_noselect::-moz-selection { background: transparent; }
|
45 |
+
.xdsoft_datetimepicker.xdsoft_inline{
|
46 |
+
display: inline-block;
|
47 |
+
position: static;
|
48 |
+
box-shadow: none;
|
49 |
+
}
|
50 |
+
.xdsoft_datetimepicker *{
|
51 |
+
-moz-box-sizing: border-box;
|
52 |
+
box-sizing: border-box;
|
53 |
+
padding: 0;
|
54 |
+
margin: 0;
|
55 |
+
}
|
56 |
+
.xdsoft_datetimepicker .xdsoft_datepicker, .xdsoft_datetimepicker .xdsoft_timepicker{
|
57 |
+
display:none;
|
58 |
+
}
|
59 |
+
.xdsoft_datetimepicker .xdsoft_datepicker.active, .xdsoft_datetimepicker .xdsoft_timepicker.active{
|
60 |
+
display:block;
|
61 |
+
}
|
62 |
+
.xdsoft_datetimepicker .xdsoft_datepicker{
|
63 |
+
width: 224px;
|
64 |
+
float:left;
|
65 |
+
margin-left:8px;
|
66 |
+
}
|
67 |
+
.xdsoft_datetimepicker.xdsoft_showweeks .xdsoft_datepicker{
|
68 |
+
width: 256px;
|
69 |
+
}
|
70 |
+
.xdsoft_datetimepicker .xdsoft_timepicker{
|
71 |
+
width: 58px;
|
72 |
+
float:left;
|
73 |
+
text-align:center;
|
74 |
+
margin-left:8px;
|
75 |
+
margin-top: 0;
|
76 |
+
}
|
77 |
+
.xdsoft_datetimepicker .xdsoft_datepicker.active+.xdsoft_timepicker{
|
78 |
+
margin-top:8px;
|
79 |
+
margin-bottom:3px
|
80 |
+
}
|
81 |
+
.xdsoft_datetimepicker .xdsoft_mounthpicker{
|
82 |
+
position: relative;
|
83 |
+
text-align: center;
|
84 |
+
}
|
85 |
+
|
86 |
+
.xdsoft_datetimepicker .xdsoft_label i,
|
87 |
+
.xdsoft_datetimepicker .xdsoft_prev,
|
88 |
+
.xdsoft_datetimepicker .xdsoft_next,
|
89 |
+
.xdsoft_datetimepicker .xdsoft_today_button{
|
90 |
+
background-image: url();
|
91 |
+
}
|
92 |
+
|
93 |
+
.xdsoft_datetimepicker .xdsoft_label i{
|
94 |
+
opacity:0.5;
|
95 |
+
background-position:-92px -19px;
|
96 |
+
display: inline-block;
|
97 |
+
width: 9px;
|
98 |
+
height: 20px;
|
99 |
+
vertical-align: middle;
|
100 |
+
}
|
101 |
+
|
102 |
+
.xdsoft_datetimepicker .xdsoft_prev{
|
103 |
+
float: left;
|
104 |
+
background-position:-20px 0;
|
105 |
+
}
|
106 |
+
.xdsoft_datetimepicker .xdsoft_today_button{
|
107 |
+
float: left;
|
108 |
+
background-position:-70px 0;
|
109 |
+
margin-left:5px;
|
110 |
+
}
|
111 |
+
|
112 |
+
.xdsoft_datetimepicker .xdsoft_next{
|
113 |
+
float: right;
|
114 |
+
background-position: 0 0;
|
115 |
+
}
|
116 |
+
|
117 |
+
.xdsoft_datetimepicker .xdsoft_next,
|
118 |
+
.xdsoft_datetimepicker .xdsoft_prev ,
|
119 |
+
.xdsoft_datetimepicker .xdsoft_today_button{
|
120 |
+
background-color: transparent;
|
121 |
+
background-repeat: no-repeat;
|
122 |
+
border: 0 none currentColor;
|
123 |
+
cursor: pointer;
|
124 |
+
display: block;
|
125 |
+
height: 30px;
|
126 |
+
opacity: 0.5;
|
127 |
+
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
|
128 |
+
outline: medium none currentColor;
|
129 |
+
overflow: hidden;
|
130 |
+
padding: 0;
|
131 |
+
position: relative;
|
132 |
+
text-indent: 100%;
|
133 |
+
white-space: nowrap;
|
134 |
+
width: 20px;
|
135 |
+
}
|
136 |
+
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_prev,
|
137 |
+
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_next{
|
138 |
+
float:none;
|
139 |
+
background-position:-40px -15px;
|
140 |
+
height: 15px;
|
141 |
+
width: 30px;
|
142 |
+
display: block;
|
143 |
+
margin-left:14px;
|
144 |
+
margin-top:7px;
|
145 |
+
}
|
146 |
+
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_prev{
|
147 |
+
background-position:-40px 0;
|
148 |
+
margin-bottom:7px;
|
149 |
+
margin-top: 0;
|
150 |
+
}
|
151 |
+
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box{
|
152 |
+
height:151px;
|
153 |
+
overflow:hidden;
|
154 |
+
border-bottom:1px solid #DDDDDD;
|
155 |
+
}
|
156 |
+
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div{
|
157 |
+
background: #F5F5F5;
|
158 |
+
border-top:1px solid #DDDDDD;
|
159 |
+
color: #666666;
|
160 |
+
font-size: 12px;
|
161 |
+
text-align: center;
|
162 |
+
border-collapse:collapse;
|
163 |
+
cursor:pointer;
|
164 |
+
border-bottom-width: 0;
|
165 |
+
height:25px;
|
166 |
+
line-height:25px;
|
167 |
+
}
|
168 |
+
|
169 |
+
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div > div:first-child{
|
170 |
+
border-top-width: 0;
|
171 |
+
}
|
172 |
+
.xdsoft_datetimepicker .xdsoft_today_button:hover,
|
173 |
+
.xdsoft_datetimepicker .xdsoft_next:hover,
|
174 |
+
.xdsoft_datetimepicker .xdsoft_prev:hover {
|
175 |
+
opacity: 1;
|
176 |
+
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
|
177 |
+
}
|
178 |
+
.xdsoft_datetimepicker .xdsoft_label{
|
179 |
+
display: inline;
|
180 |
+
position: relative;
|
181 |
+
z-index: 9999;
|
182 |
+
margin: 0;
|
183 |
+
padding: 5px 3px;
|
184 |
+
font-size: 14px;
|
185 |
+
line-height: 20px;
|
186 |
+
font-weight: bold;
|
187 |
+
background-color: #fff;
|
188 |
+
float:left;
|
189 |
+
width:182px;
|
190 |
+
text-align:center;
|
191 |
+
cursor:pointer;
|
192 |
+
}
|
193 |
+
.xdsoft_datetimepicker .xdsoft_label:hover>span{
|
194 |
+
text-decoration:underline;
|
195 |
+
}
|
196 |
+
.xdsoft_datetimepicker .xdsoft_label:hover i{
|
197 |
+
opacity:1.0;
|
198 |
+
}
|
199 |
+
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select{
|
200 |
+
border:1px solid #ccc;
|
201 |
+
position:absolute;
|
202 |
+
right: 0;
|
203 |
+
top:30px;
|
204 |
+
z-index:101;
|
205 |
+
display:none;
|
206 |
+
background:#fff;
|
207 |
+
max-height:160px;
|
208 |
+
overflow-y:hidden;
|
209 |
+
}
|
210 |
+
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select.xdsoft_monthselect{right:-7px;}
|
211 |
+
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select.xdsoft_yearselect{right:2px;}
|
212 |
+
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select > div > .xdsoft_option:hover{
|
213 |
+
color: #fff;
|
214 |
+
background: #ff8000;
|
215 |
+
}
|
216 |
+
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select > div > .xdsoft_option{
|
217 |
+
padding:2px 10px 2px 5px;
|
218 |
+
text-decoration:none !important;
|
219 |
+
}
|
220 |
+
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select > div > .xdsoft_option.xdsoft_current{
|
221 |
+
background: #33AAFF;
|
222 |
+
box-shadow: #178FE5 0 1px 3px 0 inset;
|
223 |
+
color:#fff;
|
224 |
+
font-weight: 700;
|
225 |
+
}
|
226 |
+
.xdsoft_datetimepicker .xdsoft_month{
|
227 |
+
width:100px;
|
228 |
+
text-align:right;
|
229 |
+
}
|
230 |
+
.xdsoft_datetimepicker .xdsoft_calendar{
|
231 |
+
clear:both;
|
232 |
+
}
|
233 |
+
.xdsoft_datetimepicker .xdsoft_year{
|
234 |
+
width: 48px;
|
235 |
+
margin-left: 5px;
|
236 |
+
}
|
237 |
+
.xdsoft_datetimepicker .xdsoft_calendar table{
|
238 |
+
border-collapse:collapse;
|
239 |
+
width:100%;
|
240 |
+
|
241 |
+
}
|
242 |
+
.xdsoft_datetimepicker .xdsoft_calendar td > div{
|
243 |
+
padding-right:5px;
|
244 |
+
}
|
245 |
+
.xdsoft_datetimepicker .xdsoft_calendar th{
|
246 |
+
height: 25px;
|
247 |
+
}
|
248 |
+
.xdsoft_datetimepicker .xdsoft_calendar td,.xdsoft_datetimepicker .xdsoft_calendar th{
|
249 |
+
width:14.2857142%;
|
250 |
+
background: #F5F5F5;
|
251 |
+
border:1px solid #DDDDDD;
|
252 |
+
color: #666666;
|
253 |
+
font-size: 12px;
|
254 |
+
text-align: right;
|
255 |
+
vertical-align: middle;
|
256 |
+
padding: 0;
|
257 |
+
border-collapse:collapse;
|
258 |
+
cursor:pointer;
|
259 |
+
height: 25px;
|
260 |
+
}
|
261 |
+
.xdsoft_datetimepicker.xdsoft_showweeks .xdsoft_calendar td,.xdsoft_datetimepicker.xdsoft_showweeks .xdsoft_calendar th{
|
262 |
+
width:12.5%;
|
263 |
+
}
|
264 |
+
.xdsoft_datetimepicker .xdsoft_calendar th{
|
265 |
+
background: #F1F1F1;
|
266 |
+
}
|
267 |
+
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_today{
|
268 |
+
color:#33AAFF;
|
269 |
+
}
|
270 |
+
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_default,
|
271 |
+
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_current,
|
272 |
+
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div.xdsoft_current{
|
273 |
+
background: #33AAFF;
|
274 |
+
box-shadow: #178FE5 0 1px 3px 0 inset;
|
275 |
+
color:#fff;
|
276 |
+
font-weight: 700;
|
277 |
+
}
|
278 |
+
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_other_month,
|
279 |
+
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_disabled,
|
280 |
+
.xdsoft_datetimepicker .xdsoft_time_box >div >div.xdsoft_disabled{
|
281 |
+
opacity:0.5;
|
282 |
+
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
|
283 |
+
}
|
284 |
+
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_other_month.xdsoft_disabled{
|
285 |
+
opacity:0.2;
|
286 |
+
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=20)";
|
287 |
+
}
|
288 |
+
.xdsoft_datetimepicker .xdsoft_calendar td:hover,
|
289 |
+
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div:hover{
|
290 |
+
color: #fff !important;
|
291 |
+
background: #ff8000 !important;
|
292 |
+
box-shadow: none !important;
|
293 |
+
}
|
294 |
+
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_disabled:hover,
|
295 |
+
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div.xdsoft_disabled:hover{
|
296 |
+
color: inherit !important;
|
297 |
+
background: inherit !important;
|
298 |
+
box-shadow: inherit !important;
|
299 |
+
}
|
300 |
+
.xdsoft_datetimepicker .xdsoft_calendar th{
|
301 |
+
font-weight: 700;
|
302 |
+
text-align: center;
|
303 |
+
color: #999;
|
304 |
+
cursor:default;
|
305 |
+
}
|
306 |
+
.xdsoft_datetimepicker .xdsoft_copyright{ color:#ccc !important; font-size:10px;clear:both;float:none;margin-left:8px;}
|
307 |
+
.xdsoft_datetimepicker .xdsoft_copyright a{ color:#eee !important;}
|
308 |
+
.xdsoft_datetimepicker .xdsoft_copyright a:hover{ color:#aaa !important;}
|
309 |
+
|
310 |
+
|
311 |
+
.xdsoft_time_box{
|
312 |
+
position:relative;
|
313 |
+
border:1px solid #ccc;
|
314 |
+
}
|
315 |
+
.xdsoft_scrollbar >.xdsoft_scroller{
|
316 |
+
background:#ccc !important;
|
317 |
+
height:20px;
|
318 |
+
border-radius:3px;
|
319 |
+
}
|
320 |
+
.xdsoft_scrollbar{
|
321 |
+
position:absolute;
|
322 |
+
width:7px;
|
323 |
+
right: 0;
|
324 |
+
top: 0;
|
325 |
+
bottom: 0;
|
326 |
+
cursor:pointer;
|
327 |
+
}
|
328 |
+
.xdsoft_scroller_box{
|
329 |
+
position:relative;
|
330 |
+
}
|
331 |
+
|
332 |
+
|
333 |
+
.xdsoft_datetimepicker.xdsoft_dark{
|
334 |
+
box-shadow: 0 5px 15px -5px rgba(255, 255, 255, 0.506);
|
335 |
+
background: #000000;
|
336 |
+
border-bottom: 1px solid #444444;
|
337 |
+
border-left: 1px solid #333333;
|
338 |
+
border-right: 1px solid #333333;
|
339 |
+
border-top: 1px solid #333333;
|
340 |
+
color: #cccccc;
|
341 |
+
}
|
342 |
+
|
343 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_timepicker .xdsoft_time_box{
|
344 |
+
border-bottom:1px solid #222222;
|
345 |
+
}
|
346 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_timepicker .xdsoft_time_box >div >div{
|
347 |
+
background: #0a0a0a;
|
348 |
+
border-top:1px solid #222222;
|
349 |
+
color: #999999;
|
350 |
+
}
|
351 |
+
|
352 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label{
|
353 |
+
background-color: #000;
|
354 |
+
}
|
355 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label > .xdsoft_select{
|
356 |
+
border:1px solid #333;
|
357 |
+
background:#000;
|
358 |
+
}
|
359 |
+
|
360 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label > .xdsoft_select > div > .xdsoft_option:hover{
|
361 |
+
color: #000;
|
362 |
+
background: #007fff;
|
363 |
+
}
|
364 |
+
|
365 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label > .xdsoft_select > div > .xdsoft_option.xdsoft_current{
|
366 |
+
background: #cc5500;
|
367 |
+
box-shadow: #b03e00 0 1px 3px 0 inset;
|
368 |
+
color:#000;
|
369 |
+
}
|
370 |
+
|
371 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label i,
|
372 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_prev,
|
373 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_next,
|
374 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_today_button{
|
375 |
+
background-image: url();
|
376 |
+
}
|
377 |
+
|
378 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td,
|
379 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar th{
|
380 |
+
background: #0a0a0a;
|
381 |
+
border:1px solid #222222;
|
382 |
+
color: #999999;
|
383 |
+
}
|
384 |
+
|
385 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar th{
|
386 |
+
background: #0e0e0e;
|
387 |
+
}
|
388 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td.xdsoft_today{
|
389 |
+
color:#cc5500;
|
390 |
+
}
|
391 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td.xdsoft_default,
|
392 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td.xdsoft_current,
|
393 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_timepicker .xdsoft_time_box >div >div.xdsoft_current{
|
394 |
+
background: #cc5500;
|
395 |
+
box-shadow: #b03e00 0 1px 3px 0 inset;
|
396 |
+
color:#000;
|
397 |
+
}
|
398 |
+
|
399 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td:hover,
|
400 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_timepicker .xdsoft_time_box >div >div:hover{
|
401 |
+
color: #000 !important;
|
402 |
+
background: #007fff !important;
|
403 |
+
}
|
404 |
+
|
405 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar th{
|
406 |
+
color: #666;
|
407 |
+
}
|
408 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_copyright{ color:#333 !important;}
|
409 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_copyright a{ color:#111 !important;}
|
410 |
+
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_copyright a:hover{ color:#555 !important;}
|
411 |
+
|
412 |
+
|
413 |
+
.xdsoft_dark .xdsoft_time_box{
|
414 |
+
border:1px solid #333;
|
415 |
+
}
|
416 |
+
.xdsoft_dark .xdsoft_scrollbar >.xdsoft_scroller{
|
417 |
+
background:#333 !important;
|
418 |
+
}
|
inc/js/StackBlur.js
CHANGED
@@ -1,655 +1,655 @@
|
|
1 |
-
/*
|
2 |
-
|
3 |
-
StackBlur - a fast almost Gaussian Blur For Canvas
|
4 |
-
|
5 |
-
Version: 0.5
|
6 |
-
Author: Mario Klingemann
|
7 |
-
Contact: mario@quasimondo.com
|
8 |
-
Website: http://www.quasimondo.com/StackBlurForCanvas
|
9 |
-
Twitter: @quasimondo
|
10 |
-
|
11 |
-
In case you find this class useful - especially in commercial projects -
|
12 |
-
I am not totally unhappy for a small donation to my PayPal account
|
13 |
-
mario@quasimondo.de
|
14 |
-
|
15 |
-
Or support me on flattr:
|
16 |
-
https://flattr.com/thing/72791/StackBlur-a-fast-almost-Gaussian-Blur-Effect-for-CanvasJavascript
|
17 |
-
|
18 |
-
Copyright (c) 2010 Mario Klingemann
|
19 |
-
|
20 |
-
Permission is hereby granted, free of charge, to any person
|
21 |
-
obtaining a copy of this software and associated documentation
|
22 |
-
files (the "Software"), to deal in the Software without
|
23 |
-
restriction, including without limitation the rights to use,
|
24 |
-
copy, modify, merge, publish, distribute, sublicense, and/or sell
|
25 |
-
copies of the Software, and to permit persons to whom the
|
26 |
-
Software is furnished to do so, subject to the following
|
27 |
-
conditions:
|
28 |
-
|
29 |
-
The above copyright notice and this permission notice shall be
|
30 |
-
included in all copies or substantial portions of the Software.
|
31 |
-
|
32 |
-
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
33 |
-
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
34 |
-
OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
35 |
-
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
36 |
-
HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
37 |
-
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
38 |
-
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
39 |
-
OTHER DEALINGS IN THE SOFTWARE.
|
40 |
-
*/
|
41 |
-
|
42 |
-
(function ( global ) {
|
43 |
-
|
44 |
-
var mul_table = [
|
45 |
-
512,512,456,512,328,456,335,512,405,328,271,456,388,335,292,512,
|
46 |
-
454,405,364,328,298,271,496,456,420,388,360,335,312,292,273,512,
|
47 |
-
482,454,428,405,383,364,345,328,312,298,284,271,259,496,475,456,
|
48 |
-
437,420,404,388,374,360,347,335,323,312,302,292,282,273,265,512,
|
49 |
-
497,482,468,454,441,428,417,405,394,383,373,364,354,345,337,328,
|
50 |
-
320,312,305,298,291,284,278,271,265,259,507,496,485,475,465,456,
|
51 |
-
446,437,428,420,412,404,396,388,381,374,367,360,354,347,341,335,
|
52 |
-
329,323,318,312,307,302,297,292,287,282,278,273,269,265,261,512,
|
53 |
-
505,497,489,482,475,468,461,454,447,441,435,428,422,417,411,405,
|
54 |
-
399,394,389,383,378,373,368,364,359,354,350,345,341,337,332,328,
|
55 |
-
324,320,316,312,309,305,301,298,294,291,287,284,281,278,274,271,
|
56 |
-
268,265,262,259,257,507,501,496,491,485,480,475,470,465,460,456,
|
57 |
-
451,446,442,437,433,428,424,420,416,412,408,404,400,396,392,388,
|
58 |
-
385,381,377,374,370,367,363,360,357,354,350,347,344,341,338,335,
|
59 |
-
332,329,326,323,320,318,315,312,310,307,304,302,299,297,294,292,
|
60 |
-
289,287,285,282,280,278,275,273,271,269,267,265,263,261,259];
|
61 |
-
|
62 |
-
|
63 |
-
var shg_table = [
|
64 |
-
9, 11, 12, 13, 13, 14, 14, 15, 15, 15, 15, 16, 16, 16, 16, 17,
|
65 |
-
17, 17, 17, 17, 17, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18, 19,
|
66 |
-
19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 20, 20, 20,
|
67 |
-
20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 21,
|
68 |
-
21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,
|
69 |
-
21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 22, 22, 22, 22, 22, 22,
|
70 |
-
22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22,
|
71 |
-
22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 23,
|
72 |
-
23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,
|
73 |
-
23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,
|
74 |
-
23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,
|
75 |
-
23, 23, 23, 23, 23, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,
|
76 |
-
24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,
|
77 |
-
24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,
|
78 |
-
24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,
|
79 |
-
24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24 ];
|
80 |
-
|
81 |
-
function premultiplyAlpha(imageData)
|
82 |
-
{
|
83 |
-
var pixels = imageData.data;
|
84 |
-
var size = imageData.width * imageData.height * 4;
|
85 |
-
|
86 |
-
for (var i=0; i<size; i+=4)
|
87 |
-
{
|
88 |
-
var a = pixels[i+3] / 255;
|
89 |
-
pixels[i ] *= a;
|
90 |
-
pixels[i+1] *= a;
|
91 |
-
pixels[i+2] *= a;
|
92 |
-
}
|
93 |
-
}
|
94 |
-
|
95 |
-
function unpremultiplyAlpha(imageData)
|
96 |
-
{
|
97 |
-
var pixels = imageData.data;
|
98 |
-
var size = imageData.width * imageData.height * 4;
|
99 |
-
|
100 |
-
for (var i=0; i<size; i+=4)
|
101 |
-
{
|
102 |
-
var a = pixels[i+3];
|
103 |
-
if (a != 0)
|
104 |
-
{
|
105 |
-
a = 255 / a;
|
106 |
-
pixels[i ] *= a;
|
107 |
-
pixels[i+1] *= a;
|
108 |
-
pixels[i+2] *= a;
|
109 |
-
}
|
110 |
-
}
|
111 |
-
}
|
112 |
-
|
113 |
-
function stackBlurImage( imageID, canvasID, radius, blurAlphaChannel )
|
114 |
-
{
|
115 |
-
|
116 |
-
var img = document.getElementById( imageID );
|
117 |
-
var w = img.naturalWidth;
|
118 |
-
var h = img.naturalHeight;
|
119 |
-
|
120 |
-
var canvas = document.getElementById( canvasID );
|
121 |
-
|
122 |
-
canvas.style.width = w + "px";
|
123 |
-
canvas.style.height = h + "px";
|
124 |
-
canvas.width = w;
|
125 |
-
canvas.height = h;
|
126 |
-
|
127 |
-
var context = canvas.getContext("2d");
|
128 |
-
context.clearRect( 0, 0, w, h );
|
129 |
-
context.drawImage( img, 0, 0 );
|
130 |
-
|
131 |
-
if ( isNaN(radius) || radius < 1 ) return;
|
132 |
-
|
133 |
-
if ( blurAlphaChannel )
|
134 |
-
stackBlurCanvasRGBA( canvasID, 0, 0, w, h, radius );
|
135 |
-
else
|
136 |
-
stackBlurCanvasRGB( canvasID, 0, 0, w, h, radius );
|
137 |
-
}
|
138 |
-
|
139 |
-
|
140 |
-
function stackBlurCanvasRGBA( id, top_x, top_y, width, height, radius )
|
141 |
-
{
|
142 |
-
if ( isNaN(radius) || radius < 1 ) return;
|
143 |
-
radius |= 0;
|
144 |
-
|
145 |
-
var canvas = document.getElementById( id );
|
146 |
-
var context = canvas.getContext("2d");
|
147 |
-
var imageData;
|
148 |
-
|
149 |
-
try {
|
150 |
-
try {
|
151 |
-
imageData = context.getImageData( top_x, top_y, width, height );
|
152 |
-
} catch(e) {
|
153 |
-
|
154 |
-
// NOTE: this part is supposedly only needed if you want to work with local files
|
155 |
-
// so it might be okay to remove the whole try/catch block and just use
|
156 |
-
// imageData = context.getImageData( top_x, top_y, width, height );
|
157 |
-
try {
|
158 |
-
netscape.security.PrivilegeManager.enablePrivilege("UniversalBrowserRead");
|
159 |
-
imageData = context.getImageData( top_x, top_y, width, height );
|
160 |
-
} catch(e) {
|
161 |
-
alert("Cannot access local image");
|
162 |
-
throw new Error("unable to access local image data: " + e);
|
163 |
-
return;
|
164 |
-
}
|
165 |
-
}
|
166 |
-
} catch(e) {
|
167 |
-
alert("Cannot access image");
|
168 |
-
throw new Error("unable to access image data: " + e);
|
169 |
-
}
|
170 |
-
|
171 |
-
premultiplyAlpha(imageData);
|
172 |
-
|
173 |
-
var pixels = imageData.data;
|
174 |
-
|
175 |
-
var x, y, i, p, yp, yi, yw, r_sum, g_sum, b_sum, a_sum,
|
176 |
-
r_out_sum, g_out_sum, b_out_sum, a_out_sum,
|
177 |
-
r_in_sum, g_in_sum, b_in_sum, a_in_sum,
|
178 |
-
pr, pg, pb, pa, rbs;
|
179 |
-
|
180 |
-
var div = radius + radius + 1;
|
181 |
-
var w4 = width << 2;
|
182 |
-
var widthMinus1 = width - 1;
|
183 |
-
var heightMinus1 = height - 1;
|
184 |
-
var radiusPlus1 = radius + 1;
|
185 |
-
var sumFactor = radiusPlus1 * ( radiusPlus1 + 1 ) / 2;
|
186 |
-
|
187 |
-
var stackStart = new BlurStack();
|
188 |
-
var stack = stackStart;
|
189 |
-
for ( i = 1; i < div; i++ )
|
190 |
-
{
|
191 |
-
stack = stack.next = new BlurStack();
|
192 |
-
if ( i == radiusPlus1 ) var stackEnd = stack;
|
193 |
-
}
|
194 |
-
stack.next = stackStart;
|
195 |
-
var stackIn = null;
|
196 |
-
var stackOut = null;
|
197 |
-
|
198 |
-
yw = yi = 0;
|
199 |
-
|
200 |
-
var mul_sum = mul_table[radius];
|
201 |
-
var shg_sum = shg_table[radius];
|
202 |
-
|
203 |
-
for ( y = 0; y < height; y++ )
|
204 |
-
{
|
205 |
-
r_in_sum = g_in_sum = b_in_sum = a_in_sum = r_sum = g_sum = b_sum = a_sum = 0;
|
206 |
-
|
207 |
-
r_out_sum = radiusPlus1 * ( pr = pixels[yi] );
|
208 |
-
g_out_sum = radiusPlus1 * ( pg = pixels[yi+1] );
|
209 |
-
b_out_sum = radiusPlus1 * ( pb = pixels[yi+2] );
|
210 |
-
a_out_sum = radiusPlus1 * ( pa = pixels[yi+3] );
|
211 |
-
|
212 |
-
r_sum += sumFactor * pr;
|
213 |
-
g_sum += sumFactor * pg;
|
214 |
-
b_sum += sumFactor * pb;
|
215 |
-
a_sum += sumFactor * pa;
|
216 |
-
|
217 |
-
stack = stackStart;
|
218 |
-
|
219 |
-
for( i = 0; i < radiusPlus1; i++ )
|
220 |
-
{
|
221 |
-
stack.r = pr;
|
222 |
-
stack.g = pg;
|
223 |
-
stack.b = pb;
|
224 |
-
stack.a = pa;
|
225 |
-
stack = stack.next;
|
226 |
-
}
|
227 |
-
|
228 |
-
for( i = 1; i < radiusPlus1; i++ )
|
229 |
-
{
|
230 |
-
p = yi + (( widthMinus1 < i ? widthMinus1 : i ) << 2 );
|
231 |
-
r_sum += ( stack.r = ( pr = pixels[p])) * ( rbs = radiusPlus1 - i );
|
232 |
-
g_sum += ( stack.g = ( pg = pixels[p+1])) * rbs;
|
233 |
-
b_sum += ( stack.b = ( pb = pixels[p+2])) * rbs;
|
234 |
-
a_sum += ( stack.a = ( pa = pixels[p+3])) * rbs;
|
235 |
-
|
236 |
-
r_in_sum += pr;
|
237 |
-
g_in_sum += pg;
|
238 |
-
b_in_sum += pb;
|
239 |
-
a_in_sum += pa;
|
240 |
-
|
241 |
-
stack = stack.next;
|
242 |
-
}
|
243 |
-
|
244 |
-
stackIn = stackStart;
|
245 |
-
stackOut = stackEnd;
|
246 |
-
for ( x = 0; x < width; x++ )
|
247 |
-
{
|
248 |
-
pixels[yi] = (r_sum * mul_sum) >> shg_sum;
|
249 |
-
pixels[yi+1] = (g_sum * mul_sum) >> shg_sum;
|
250 |
-
pixels[yi+2] = (b_sum * mul_sum) >> shg_sum;
|
251 |
-
pixels[yi+3] = (a_sum * mul_sum) >> shg_sum;
|
252 |
-
|
253 |
-
r_sum -= r_out_sum;
|
254 |
-
g_sum -= g_out_sum;
|
255 |
-
b_sum -= b_out_sum;
|
256 |
-
a_sum -= a_out_sum;
|
257 |
-
|
258 |
-
r_out_sum -= stackIn.r;
|
259 |
-
g_out_sum -= stackIn.g;
|
260 |
-
b_out_sum -= stackIn.b;
|
261 |
-
a_out_sum -= stackIn.a;
|
262 |
-
|
263 |
-
p = ( yw + ( ( p = x + radius + 1 ) < widthMinus1 ? p : widthMinus1 ) ) << 2;
|
264 |
-
|
265 |
-
r_in_sum += ( stackIn.r = pixels[p]);
|
266 |
-
g_in_sum += ( stackIn.g = pixels[p+1]);
|
267 |
-
b_in_sum += ( stackIn.b = pixels[p+2]);
|
268 |
-
a_in_sum += ( stackIn.a = pixels[p+3]);
|
269 |
-
|
270 |
-
r_sum += r_in_sum;
|
271 |
-
g_sum += g_in_sum;
|
272 |
-
b_sum += b_in_sum;
|
273 |
-
a_sum += a_in_sum;
|
274 |
-
|
275 |
-
stackIn = stackIn.next;
|
276 |
-
|
277 |
-
r_out_sum += ( pr = stackOut.r );
|
278 |
-
g_out_sum += ( pg = stackOut.g );
|
279 |
-
b_out_sum += ( pb = stackOut.b );
|
280 |
-
a_out_sum += ( pa = stackOut.a );
|
281 |
-
|
282 |
-
r_in_sum -= pr;
|
283 |
-
g_in_sum -= pg;
|
284 |
-
b_in_sum -= pb;
|
285 |
-
a_in_sum -= pa;
|
286 |
-
|
287 |
-
stackOut = stackOut.next;
|
288 |
-
|
289 |
-
yi += 4;
|
290 |
-
}
|
291 |
-
yw += width;
|
292 |
-
}
|
293 |
-
|
294 |
-
|
295 |
-
for ( x = 0; x < width; x++ )
|
296 |
-
{
|
297 |
-
g_in_sum = b_in_sum = a_in_sum = r_in_sum = g_sum = b_sum = a_sum = r_sum = 0;
|
298 |
-
|
299 |
-
yi = x << 2;
|
300 |
-
r_out_sum = radiusPlus1 * ( pr = pixels[yi]);
|
301 |
-
g_out_sum = radiusPlus1 * ( pg = pixels[yi+1]);
|
302 |
-
b_out_sum = radiusPlus1 * ( pb = pixels[yi+2]);
|
303 |
-
a_out_sum = radiusPlus1 * ( pa = pixels[yi+3]);
|
304 |
-
|
305 |
-
r_sum += sumFactor * pr;
|
306 |
-
g_sum += sumFactor * pg;
|
307 |
-
b_sum += sumFactor * pb;
|
308 |
-
a_sum += sumFactor * pa;
|
309 |
-
|
310 |
-
stack = stackStart;
|
311 |
-
|
312 |
-
for( i = 0; i < radiusPlus1; i++ )
|
313 |
-
{
|
314 |
-
stack.r = pr;
|
315 |
-
stack.g = pg;
|
316 |
-
stack.b = pb;
|
317 |
-
stack.a = pa;
|
318 |
-
stack = stack.next;
|
319 |
-
}
|
320 |
-
|
321 |
-
yp = width;
|
322 |
-
|
323 |
-
for( i = 1; i <= radius; i++ )
|
324 |
-
{
|
325 |
-
yi = ( yp + x ) << 2;
|
326 |
-
|
327 |
-
r_sum += ( stack.r = ( pr = pixels[yi])) * ( rbs = radiusPlus1 - i );
|
328 |
-
g_sum += ( stack.g = ( pg = pixels[yi+1])) * rbs;
|
329 |
-
b_sum += ( stack.b = ( pb = pixels[yi+2])) * rbs;
|
330 |
-
a_sum += ( stack.a = ( pa = pixels[yi+3])) * rbs;
|
331 |
-
|
332 |
-
r_in_sum += pr;
|
333 |
-
g_in_sum += pg;
|
334 |
-
b_in_sum += pb;
|
335 |
-
a_in_sum += pa;
|
336 |
-
|
337 |
-
stack = stack.next;
|
338 |
-
|
339 |
-
if( i < heightMinus1 )
|
340 |
-
{
|
341 |
-
yp += width;
|
342 |
-
}
|
343 |
-
}
|
344 |
-
|
345 |
-
yi = x;
|
346 |
-
stackIn = stackStart;
|
347 |
-
stackOut = stackEnd;
|
348 |
-
for ( y = 0; y < height; y++ )
|
349 |
-
{
|
350 |
-
p = yi << 2;
|
351 |
-
pixels[p] = (r_sum * mul_sum) >> shg_sum;
|
352 |
-
pixels[p+1] = (g_sum * mul_sum) >> shg_sum;
|
353 |
-
pixels[p+2] = (b_sum * mul_sum) >> shg_sum;
|
354 |
-
pixels[p+3] = (a_sum * mul_sum) >> shg_sum;
|
355 |
-
|
356 |
-
r_sum -= r_out_sum;
|
357 |
-
g_sum -= g_out_sum;
|
358 |
-
b_sum -= b_out_sum;
|
359 |
-
a_sum -= a_out_sum;
|
360 |
-
|
361 |
-
r_out_sum -= stackIn.r;
|
362 |
-
g_out_sum -= stackIn.g;
|
363 |
-
b_out_sum -= stackIn.b;
|
364 |
-
a_out_sum -= stackIn.a;
|
365 |
-
|
366 |
-
p = ( x + (( ( p = y + radiusPlus1) < heightMinus1 ? p : heightMinus1 ) * width )) << 2;
|
367 |
-
|
368 |
-
r_sum += ( r_in_sum += ( stackIn.r = pixels[p]));
|
369 |
-
g_sum += ( g_in_sum += ( stackIn.g = pixels[p+1]));
|
370 |
-
b_sum += ( b_in_sum += ( stackIn.b = pixels[p+2]));
|
371 |
-
a_sum += ( a_in_sum += ( stackIn.a = pixels[p+3]));
|
372 |
-
|
373 |
-
stackIn = stackIn.next;
|
374 |
-
|
375 |
-
r_out_sum += ( pr = stackOut.r );
|
376 |
-
g_out_sum += ( pg = stackOut.g );
|
377 |
-
b_out_sum += ( pb = stackOut.b );
|
378 |
-
a_out_sum += ( pa = stackOut.a );
|
379 |
-
|
380 |
-
r_in_sum -= pr;
|
381 |
-
g_in_sum -= pg;
|
382 |
-
b_in_sum -= pb;
|
383 |
-
a_in_sum -= pa;
|
384 |
-
|
385 |
-
stackOut = stackOut.next;
|
386 |
-
|
387 |
-
yi += width;
|
388 |
-
}
|
389 |
-
}
|
390 |
-
|
391 |
-
unpremultiplyAlpha(imageData);
|
392 |
-
|
393 |
-
context.putImageData( imageData, top_x, top_y );
|
394 |
-
}
|
395 |
-
|
396 |
-
|
397 |
-
function stackBlurCanvasRGB( id, top_x, top_y, width, height, radius )
|
398 |
-
{
|
399 |
-
if ( isNaN(radius) || radius < 1 ) return;
|
400 |
-
radius |= 0;
|
401 |
-
|
402 |
-
var canvas = document.getElementById( id );
|
403 |
-
var context = canvas.getContext("2d");
|
404 |
-
var imageData;
|
405 |
-
|
406 |
-
try {
|
407 |
-
try {
|
408 |
-
imageData = context.getImageData( top_x, top_y, width, height );
|
409 |
-
} catch(e) {
|
410 |
-
|
411 |
-
// NOTE: this part is supposedly only needed if you want to work with local files
|
412 |
-
// so it might be okay to remove the whole try/catch block and just use
|
413 |
-
// imageData = context.getImageData( top_x, top_y, width, height );
|
414 |
-
try {
|
415 |
-
netscape.security.PrivilegeManager.enablePrivilege("UniversalBrowserRead");
|
416 |
-
imageData = context.getImageData( top_x, top_y, width, height );
|
417 |
-
} catch(e) {
|
418 |
-
alert("Cannot access local image");
|
419 |
-
throw new Error("unable to access local image data: " + e);
|
420 |
-
return;
|
421 |
-
}
|
422 |
-
}
|
423 |
-
} catch(e) {
|
424 |
-
alert("Cannot access image");
|
425 |
-
throw new Error("unable to access image data: " + e);
|
426 |
-
}
|
427 |
-
|
428 |
-
var pixels = imageData.data;
|
429 |
-
|
430 |
-
var x, y, i, p, yp, yi, yw, r_sum, g_sum, b_sum,
|
431 |
-
r_out_sum, g_out_sum, b_out_sum,
|
432 |
-
r_in_sum, g_in_sum, b_in_sum,
|
433 |
-
pr, pg, pb, rbs;
|
434 |
-
|
435 |
-
var div = radius + radius + 1;
|
436 |
-
var w4 = width << 2;
|
437 |
-
var widthMinus1 = width - 1;
|
438 |
-
var heightMinus1 = height - 1;
|
439 |
-
var radiusPlus1 = radius + 1;
|
440 |
-
var sumFactor = radiusPlus1 * ( radiusPlus1 + 1 ) / 2;
|
441 |
-
|
442 |
-
var stackStart = new BlurStack();
|
443 |
-
var stack = stackStart;
|
444 |
-
for ( i = 1; i < div; i++ )
|
445 |
-
{
|
446 |
-
stack = stack.next = new BlurStack();
|
447 |
-
if ( i == radiusPlus1 ) var stackEnd = stack;
|
448 |
-
}
|
449 |
-
stack.next = stackStart;
|
450 |
-
var stackIn = null;
|
451 |
-
var stackOut = null;
|
452 |
-
|
453 |
-
yw = yi = 0;
|
454 |
-
|
455 |
-
var mul_sum = mul_table[radius];
|
456 |
-
var shg_sum = shg_table[radius];
|
457 |
-
|
458 |
-
for ( y = 0; y < height; y++ )
|
459 |
-
{
|
460 |
-
r_in_sum = g_in_sum = b_in_sum = r_sum = g_sum = b_sum = 0;
|
461 |
-
|
462 |
-
r_out_sum = radiusPlus1 * ( pr = pixels[yi] );
|
463 |
-
g_out_sum = radiusPlus1 * ( pg = pixels[yi+1] );
|
464 |
-
b_out_sum = radiusPlus1 * ( pb = pixels[yi+2] );
|
465 |
-
|
466 |
-
r_sum += sumFactor * pr;
|
467 |
-
g_sum += sumFactor * pg;
|
468 |
-
b_sum += sumFactor * pb;
|
469 |
-
|
470 |
-
stack = stackStart;
|
471 |
-
|
472 |
-
for( i = 0; i < radiusPlus1; i++ )
|
473 |
-
{
|
474 |
-
stack.r = pr;
|
475 |
-
stack.g = pg;
|
476 |
-
stack.b = pb;
|
477 |
-
stack = stack.next;
|
478 |
-
}
|
479 |
-
|
480 |
-
for( i = 1; i < radiusPlus1; i++ )
|
481 |
-
{
|
482 |
-
p = yi + (( widthMinus1 < i ? widthMinus1 : i ) << 2 );
|
483 |
-
r_sum += ( stack.r = ( pr = pixels[p])) * ( rbs = radiusPlus1 - i );
|
484 |
-
g_sum += ( stack.g = ( pg = pixels[p+1])) * rbs;
|
485 |
-
b_sum += ( stack.b = ( pb = pixels[p+2])) * rbs;
|
486 |
-
|
487 |
-
r_in_sum += pr;
|
488 |
-
g_in_sum += pg;
|
489 |
-
b_in_sum += pb;
|
490 |
-
|
491 |
-
stack = stack.next;
|
492 |
-
}
|
493 |
-
|
494 |
-
|
495 |
-
stackIn = stackStart;
|
496 |
-
stackOut = stackEnd;
|
497 |
-
for ( x = 0; x < width; x++ )
|
498 |
-
{
|
499 |
-
pixels[yi] = (r_sum * mul_sum) >> shg_sum;
|
500 |
-
pixels[yi+1] = (g_sum * mul_sum) >> shg_sum;
|
501 |
-
pixels[yi+2] = (b_sum * mul_sum) >> shg_sum;
|
502 |
-
|
503 |
-
r_sum -= r_out_sum;
|
504 |
-
g_sum -= g_out_sum;
|
505 |
-
b_sum -= b_out_sum;
|
506 |
-
|
507 |
-
r_out_sum -= stackIn.r;
|
508 |
-
g_out_sum -= stackIn.g;
|
509 |
-
b_out_sum -= stackIn.b;
|
510 |
-
|
511 |
-
p = ( yw + ( ( p = x + radius + 1 ) < widthMinus1 ? p : widthMinus1 ) ) << 2;
|
512 |
-
|
513 |
-
r_in_sum += ( stackIn.r = pixels[p]);
|
514 |
-
g_in_sum += ( stackIn.g = pixels[p+1]);
|
515 |
-
b_in_sum += ( stackIn.b = pixels[p+2]);
|
516 |
-
|
517 |
-
r_sum += r_in_sum;
|
518 |
-
g_sum += g_in_sum;
|
519 |
-
b_sum += b_in_sum;
|
520 |
-
|
521 |
-
stackIn = stackIn.next;
|
522 |
-
|
523 |
-
r_out_sum += ( pr = stackOut.r );
|
524 |
-
g_out_sum += ( pg = stackOut.g );
|
525 |
-
b_out_sum += ( pb = stackOut.b );
|
526 |
-
|
527 |
-
r_in_sum -= pr;
|
528 |
-
g_in_sum -= pg;
|
529 |
-
b_in_sum -= pb;
|
530 |
-
|
531 |
-
stackOut = stackOut.next;
|
532 |
-
|
533 |
-
yi += 4;
|
534 |
-
}
|
535 |
-
yw += width;
|
536 |
-
}
|
537 |
-
|
538 |
-
|
539 |
-
for ( x = 0; x < width; x++ )
|
540 |
-
{
|
541 |
-
g_in_sum = b_in_sum = r_in_sum = g_sum = b_sum = r_sum = 0;
|
542 |
-
|
543 |
-
yi = x << 2;
|
544 |
-
r_out_sum = radiusPlus1 * ( pr = pixels[yi]);
|
545 |
-
g_out_sum = radiusPlus1 * ( pg = pixels[yi+1]);
|
546 |
-
b_out_sum = radiusPlus1 * ( pb = pixels[yi+2]);
|
547 |
-
|
548 |
-
r_sum += sumFactor * pr;
|
549 |
-
g_sum += sumFactor * pg;
|
550 |
-
b_sum += sumFactor * pb;
|
551 |
-
|
552 |
-
stack = stackStart;
|
553 |
-
|
554 |
-
for( i = 0; i < radiusPlus1; i++ )
|
555 |
-
{
|
556 |
-
stack.r = pr;
|
557 |
-
stack.g = pg;
|
558 |
-
stack.b = pb;
|
559 |
-
stack = stack.next;
|
560 |
-
}
|
561 |
-
|
562 |
-
yp = width;
|
563 |
-
|
564 |
-
for( i = 1; i <= radius; i++ )
|
565 |
-
{
|
566 |
-
yi = ( yp + x ) << 2;
|
567 |
-
|
568 |
-
r_sum += ( stack.r = ( pr = pixels[yi])) * ( rbs = radiusPlus1 - i );
|
569 |
-
g_sum += ( stack.g = ( pg = pixels[yi+1])) * rbs;
|
570 |
-
b_sum += ( stack.b = ( pb = pixels[yi+2])) * rbs;
|
571 |
-
|
572 |
-
r_in_sum += pr;
|
573 |
-
g_in_sum += pg;
|
574 |
-
b_in_sum += pb;
|
575 |
-
|
576 |
-
stack = stack.next;
|
577 |
-
|
578 |
-
if( i < heightMinus1 )
|
579 |
-
{
|
580 |
-
yp += width;
|
581 |
-
}
|
582 |
-
}
|
583 |
-
|
584 |
-
yi = x;
|
585 |
-
stackIn = stackStart;
|
586 |
-
stackOut = stackEnd;
|
587 |
-
for ( y = 0; y < height; y++ )
|
588 |
-
{
|
589 |
-
p = yi << 2;
|
590 |
-
pixels[p] = (r_sum * mul_sum) >> shg_sum;
|
591 |
-
pixels[p+1] = (g_sum * mul_sum) >> shg_sum;
|
592 |
-
pixels[p+2] = (b_sum * mul_sum) >> shg_sum;
|
593 |
-
|
594 |
-
r_sum -= r_out_sum;
|
595 |
-
g_sum -= g_out_sum;
|
596 |
-
b_sum -= b_out_sum;
|
597 |
-
|
598 |
-
r_out_sum -= stackIn.r;
|
599 |
-
g_out_sum -= stackIn.g;
|
600 |
-
b_out_sum -= stackIn.b;
|
601 |
-
|
602 |
-
p = ( x + (( ( p = y + radiusPlus1) < heightMinus1 ? p : heightMinus1 ) * width )) << 2;
|
603 |
-
|
604 |
-
r_sum += ( r_in_sum += ( stackIn.r = pixels[p]));
|
605 |
-
g_sum += ( g_in_sum += ( stackIn.g = pixels[p+1]));
|
606 |
-
b_sum += ( b_in_sum += ( stackIn.b = pixels[p+2]));
|
607 |
-
|
608 |
-
stackIn = stackIn.next;
|
609 |
-
|
610 |
-
r_out_sum += ( pr = stackOut.r );
|
611 |
-
g_out_sum += ( pg = stackOut.g );
|
612 |
-
b_out_sum += ( pb = stackOut.b );
|
613 |
-
|
614 |
-
r_in_sum -= pr;
|
615 |
-
g_in_sum -= pg;
|
616 |
-
b_in_sum -= pb;
|
617 |
-
|
618 |
-
stackOut = stackOut.next;
|
619 |
-
|
620 |
-
yi += width;
|
621 |
-
}
|
622 |
-
}
|
623 |
-
|
624 |
-
context.putImageData( imageData, top_x, top_y );
|
625 |
-
|
626 |
-
}
|
627 |
-
|
628 |
-
function BlurStack()
|
629 |
-
{
|
630 |
-
this.r = 0;
|
631 |
-
this.g = 0;
|
632 |
-
this.b = 0;
|
633 |
-
this.a = 0;
|
634 |
-
this.next = null;
|
635 |
-
}
|
636 |
-
|
637 |
-
var stackBlur = {
|
638 |
-
image: stackBlurImage,
|
639 |
-
canvasRGBA: stackBlurCanvasRGBA,
|
640 |
-
canvasRGB: stackBlurCanvasRGB
|
641 |
-
};
|
642 |
-
|
643 |
-
// export as AMD...
|
644 |
-
if ( typeof define !== 'undefined' && define.amd ) {
|
645 |
-
define( function () { return stackBlur; });
|
646 |
-
}
|
647 |
-
|
648 |
-
// ...or as browserify
|
649 |
-
else if ( typeof module !== 'undefined' && module.exports ) {
|
650 |
-
module.exports = stackBlur;
|
651 |
-
}
|
652 |
-
|
653 |
-
global.stackBlur = stackBlur;
|
654 |
-
|
655 |
}( typeof window !== 'undefined' ? window : this ));
|
1 |
+
/*
|
2 |
+
|
3 |
+
StackBlur - a fast almost Gaussian Blur For Canvas
|
4 |
+
|
5 |
+
Version: 0.5
|
6 |
+
Author: Mario Klingemann
|
7 |
+
Contact: mario@quasimondo.com
|
8 |
+
Website: http://www.quasimondo.com/StackBlurForCanvas
|
9 |
+
Twitter: @quasimondo
|
10 |
+
|
11 |
+
In case you find this class useful - especially in commercial projects -
|
12 |
+
I am not totally unhappy for a small donation to my PayPal account
|
13 |
+
mario@quasimondo.de
|
14 |
+
|
15 |
+
Or support me on flattr:
|
16 |
+
https://flattr.com/thing/72791/StackBlur-a-fast-almost-Gaussian-Blur-Effect-for-CanvasJavascript
|
17 |
+
|
18 |
+
Copyright (c) 2010 Mario Klingemann
|
19 |
+
|
20 |
+
Permission is hereby granted, free of charge, to any person
|
21 |
+
obtaining a copy of this software and associated documentation
|
22 |
+
files (the "Software"), to deal in the Software without
|
23 |
+
restriction, including without limitation the rights to use,
|
24 |
+
copy, modify, merge, publish, distribute, sublicense, and/or sell
|
25 |
+
copies of the Software, and to permit persons to whom the
|
26 |
+
Software is furnished to do so, subject to the following
|
27 |
+
conditions:
|
28 |
+
|
29 |
+
The above copyright notice and this permission notice shall be
|
30 |
+
included in all copies or substantial portions of the Software.
|
31 |
+
|
32 |
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
33 |
+
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
34 |
+
OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
35 |
+
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
36 |
+
HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
37 |
+
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
38 |
+
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
39 |
+
OTHER DEALINGS IN THE SOFTWARE.
|
40 |
+
*/
|
41 |
+
|
42 |
+
(function ( global ) {
|
43 |
+
|
44 |
+
var mul_table = [
|
45 |
+
512,512,456,512,328,456,335,512,405,328,271,456,388,335,292,512,
|
46 |
+
454,405,364,328,298,271,496,456,420,388,360,335,312,292,273,512,
|
47 |
+
482,454,428,405,383,364,345,328,312,298,284,271,259,496,475,456,
|
48 |
+
437,420,404,388,374,360,347,335,323,312,302,292,282,273,265,512,
|
49 |
+
497,482,468,454,441,428,417,405,394,383,373,364,354,345,337,328,
|
50 |
+
320,312,305,298,291,284,278,271,265,259,507,496,485,475,465,456,
|
51 |
+
446,437,428,420,412,404,396,388,381,374,367,360,354,347,341,335,
|
52 |
+
329,323,318,312,307,302,297,292,287,282,278,273,269,265,261,512,
|
53 |
+
505,497,489,482,475,468,461,454,447,441,435,428,422,417,411,405,
|
54 |
+
399,394,389,383,378,373,368,364,359,354,350,345,341,337,332,328,
|
55 |
+
324,320,316,312,309,305,301,298,294,291,287,284,281,278,274,271,
|
56 |
+
268,265,262,259,257,507,501,496,491,485,480,475,470,465,460,456,
|
57 |
+
451,446,442,437,433,428,424,420,416,412,408,404,400,396,392,388,
|
58 |
+
385,381,377,374,370,367,363,360,357,354,350,347,344,341,338,335,
|
59 |
+
332,329,326,323,320,318,315,312,310,307,304,302,299,297,294,292,
|
60 |
+
289,287,285,282,280,278,275,273,271,269,267,265,263,261,259];
|
61 |
+
|
62 |
+
|
63 |
+
var shg_table = [
|
64 |
+
9, 11, 12, 13, 13, 14, 14, 15, 15, 15, 15, 16, 16, 16, 16, 17,
|
65 |
+
17, 17, 17, 17, 17, 17, 18, 18, 18, 18, 18, 18, 18, 18, 18, 19,
|
66 |
+
19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 20, 20, 20,
|
67 |
+
20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 21,
|
68 |
+
21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21,
|
69 |
+
21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 22, 22, 22, 22, 22, 22,
|
70 |
+
22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22,
|
71 |
+
22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 23,
|
72 |
+
23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,
|
73 |
+
23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,
|
74 |
+
23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23,
|
75 |
+
23, 23, 23, 23, 23, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,
|
76 |
+
24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,
|
77 |
+
24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,
|
78 |
+
24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24,
|
79 |
+
24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24 ];
|
80 |
+
|
81 |
+
function premultiplyAlpha(imageData)
|
82 |
+
{
|
83 |
+
var pixels = imageData.data;
|
84 |
+
var size = imageData.width * imageData.height * 4;
|
85 |
+
|
86 |
+
for (var i=0; i<size; i+=4)
|
87 |
+
{
|
88 |
+
var a = pixels[i+3] / 255;
|
89 |
+
pixels[i ] *= a;
|
90 |
+
pixels[i+1] *= a;
|
91 |
+
pixels[i+2] *= a;
|
92 |
+
}
|
93 |
+
}
|
94 |
+
|
95 |
+
function unpremultiplyAlpha(imageData)
|
96 |
+
{
|
97 |
+
var pixels = imageData.data;
|
98 |
+
var size = imageData.width * imageData.height * 4;
|
99 |
+
|
100 |
+
for (var i=0; i<size; i+=4)
|
101 |
+
{
|
102 |
+
var a = pixels[i+3];
|
103 |
+
if (a != 0)
|
104 |
+
{
|
105 |
+
a = 255 / a;
|
106 |
+
pixels[i ] *= a;
|
107 |
+
pixels[i+1] *= a;
|
108 |
+
pixels[i+2] *= a;
|
109 |
+
}
|
110 |
+
}
|
111 |
+
}
|
112 |
+
|
113 |
+
function stackBlurImage( imageID, canvasID, radius, blurAlphaChannel )
|
114 |
+
{
|
115 |
+
|
116 |
+
var img = document.getElementById( imageID );
|
117 |
+
var w = img.naturalWidth;
|
118 |
+
var h = img.naturalHeight;
|
119 |
+
|
120 |
+
var canvas = document.getElementById( canvasID );
|
121 |
+
|
122 |
+
canvas.style.width = w + "px";
|
123 |
+
canvas.style.height = h + "px";
|
124 |
+
canvas.width = w;
|
125 |
+
canvas.height = h;
|
126 |
+
|
127 |
+
var context = canvas.getContext("2d");
|
128 |
+
context.clearRect( 0, 0, w, h );
|
129 |
+
context.drawImage( img, 0, 0 );
|
130 |
+
|
131 |
+
if ( isNaN(radius) || radius < 1 ) return;
|
132 |
+
|
133 |
+
if ( blurAlphaChannel )
|
134 |
+
stackBlurCanvasRGBA( canvasID, 0, 0, w, h, radius );
|
135 |
+
else
|
136 |
+
stackBlurCanvasRGB( canvasID, 0, 0, w, h, radius );
|
137 |
+
}
|
138 |
+
|
139 |
+
|
140 |
+
function stackBlurCanvasRGBA( id, top_x, top_y, width, height, radius )
|
141 |
+
{
|
142 |
+
if ( isNaN(radius) || radius < 1 ) return;
|
143 |
+
radius |= 0;
|
144 |
+
|
145 |
+
var canvas = document.getElementById( id );
|
146 |
+
var context = canvas.getContext("2d");
|
147 |
+
var imageData;
|
148 |
+
|
149 |
+
try {
|
150 |
+
try {
|
151 |
+
imageData = context.getImageData( top_x, top_y, width, height );
|
152 |
+
} catch(e) {
|
153 |
+
|
154 |
+
// NOTE: this part is supposedly only needed if you want to work with local files
|
155 |
+
// so it might be okay to remove the whole try/catch block and just use
|
156 |
+
// imageData = context.getImageData( top_x, top_y, width, height );
|
157 |
+
try {
|
158 |
+
netscape.security.PrivilegeManager.enablePrivilege("UniversalBrowserRead");
|
159 |
+
imageData = context.getImageData( top_x, top_y, width, height );
|
160 |
+
} catch(e) {
|
161 |
+
alert("Cannot access local image");
|
162 |
+
throw new Error("unable to access local image data: " + e);
|
163 |
+
return;
|
164 |
+
}
|
165 |
+
}
|
166 |
+
} catch(e) {
|
167 |
+
alert("Cannot access image");
|
168 |
+
throw new Error("unable to access image data: " + e);
|
169 |
+
}
|
170 |
+
|
171 |
+
premultiplyAlpha(imageData);
|
172 |
+
|
173 |
+
var pixels = imageData.data;
|
174 |
+
|
175 |
+
var x, y, i, p, yp, yi, yw, r_sum, g_sum, b_sum, a_sum,
|
176 |
+
r_out_sum, g_out_sum, b_out_sum, a_out_sum,
|
177 |
+
r_in_sum, g_in_sum, b_in_sum, a_in_sum,
|
178 |
+
pr, pg, pb, pa, rbs;
|
179 |
+
|
180 |
+
var div = radius + radius + 1;
|
181 |
+
var w4 = width << 2;
|
182 |
+
var widthMinus1 = width - 1;
|
183 |
+
var heightMinus1 = height - 1;
|
184 |
+
var radiusPlus1 = radius + 1;
|
185 |
+
var sumFactor = radiusPlus1 * ( radiusPlus1 + 1 ) / 2;
|
186 |
+
|
187 |
+
var stackStart = new BlurStack();
|
188 |
+
var stack = stackStart;
|
189 |
+
for ( i = 1; i < div; i++ )
|
190 |
+
{
|
191 |
+
stack = stack.next = new BlurStack();
|
192 |
+
if ( i == radiusPlus1 ) var stackEnd = stack;
|
193 |
+
}
|
194 |
+
stack.next = stackStart;
|
195 |
+
var stackIn = null;
|
196 |
+
var stackOut = null;
|
197 |
+
|
198 |
+
yw = yi = 0;
|
199 |
+
|
200 |
+
var mul_sum = mul_table[radius];
|
201 |
+
var shg_sum = shg_table[radius];
|
202 |
+
|
203 |
+
for ( y = 0; y < height; y++ )
|
204 |
+
{
|
205 |
+
r_in_sum = g_in_sum = b_in_sum = a_in_sum = r_sum = g_sum = b_sum = a_sum = 0;
|
206 |
+
|
207 |
+
r_out_sum = radiusPlus1 * ( pr = pixels[yi] );
|
208 |
+
g_out_sum = radiusPlus1 * ( pg = pixels[yi+1] );
|
209 |
+
b_out_sum = radiusPlus1 * ( pb = pixels[yi+2] );
|
210 |
+
a_out_sum = radiusPlus1 * ( pa = pixels[yi+3] );
|
211 |
+
|
212 |
+
r_sum += sumFactor * pr;
|
213 |
+
g_sum += sumFactor * pg;
|
214 |
+
b_sum += sumFactor * pb;
|
215 |
+
a_sum += sumFactor * pa;
|
216 |
+
|
217 |
+
stack = stackStart;
|
218 |
+
|
219 |
+
for( i = 0; i < radiusPlus1; i++ )
|
220 |
+
{
|
221 |
+
stack.r = pr;
|
222 |
+
stack.g = pg;
|
223 |
+
stack.b = pb;
|
224 |
+
stack.a = pa;
|
225 |
+
stack = stack.next;
|
226 |
+
}
|
227 |
+
|
228 |
+
for( i = 1; i < radiusPlus1; i++ )
|
229 |
+
{
|
230 |
+
p = yi + (( widthMinus1 < i ? widthMinus1 : i ) << 2 );
|
231 |
+
r_sum += ( stack.r = ( pr = pixels[p])) * ( rbs = radiusPlus1 - i );
|
232 |
+
g_sum += ( stack.g = ( pg = pixels[p+1])) * rbs;
|
233 |
+
b_sum += ( stack.b = ( pb = pixels[p+2])) * rbs;
|
234 |
+
a_sum += ( stack.a = ( pa = pixels[p+3])) * rbs;
|
235 |
+
|
236 |
+
r_in_sum += pr;
|
237 |
+
g_in_sum += pg;
|
238 |
+
b_in_sum += pb;
|
239 |
+
a_in_sum += pa;
|
240 |
+
|
241 |
+
stack = stack.next;
|
242 |
+
}
|
243 |
+
|
244 |
+
stackIn = stackStart;
|
245 |
+
stackOut = stackEnd;
|
246 |
+
for ( x = 0; x < width; x++ )
|
247 |
+
{
|
248 |
+
pixels[yi] = (r_sum * mul_sum) >> shg_sum;
|
249 |
+
pixels[yi+1] = (g_sum * mul_sum) >> shg_sum;
|
250 |
+
pixels[yi+2] = (b_sum * mul_sum) >> shg_sum;
|
251 |
+
pixels[yi+3] = (a_sum * mul_sum) >> shg_sum;
|
252 |
+
|
253 |
+
r_sum -= r_out_sum;
|
254 |
+
g_sum -= g_out_sum;
|
255 |
+
b_sum -= b_out_sum;
|
256 |
+
a_sum -= a_out_sum;
|
257 |
+
|
258 |
+
r_out_sum -= stackIn.r;
|
259 |
+
g_out_sum -= stackIn.g;
|
260 |
+
b_out_sum -= stackIn.b;
|
261 |
+
a_out_sum -= stackIn.a;
|
262 |
+
|
263 |
+
p = ( yw + ( ( p = x + radius + 1 ) < widthMinus1 ? p : widthMinus1 ) ) << 2;
|
264 |
+
|
265 |
+
r_in_sum += ( stackIn.r = pixels[p]);
|
266 |
+
g_in_sum += ( stackIn.g = pixels[p+1]);
|
267 |
+
b_in_sum += ( stackIn.b = pixels[p+2]);
|
268 |
+
a_in_sum += ( stackIn.a = pixels[p+3]);
|
269 |
+
|
270 |
+
r_sum += r_in_sum;
|
271 |
+
g_sum += g_in_sum;
|
272 |
+
b_sum += b_in_sum;
|
273 |
+
a_sum += a_in_sum;
|
274 |
+
|
275 |
+
stackIn = stackIn.next;
|
276 |
+
|
277 |
+
r_out_sum += ( pr = stackOut.r );
|
278 |
+
g_out_sum += ( pg = stackOut.g );
|
279 |
+
b_out_sum += ( pb = stackOut.b );
|
280 |
+
a_out_sum += ( pa = stackOut.a );
|
281 |
+
|
282 |
+
r_in_sum -= pr;
|
283 |
+
g_in_sum -= pg;
|
284 |
+
b_in_sum -= pb;
|
285 |
+
a_in_sum -= pa;
|
286 |
+
|
287 |
+
stackOut = stackOut.next;
|
288 |
+
|
289 |
+
yi += 4;
|
290 |
+
}
|
291 |
+
yw += width;
|
292 |
+
}
|
293 |
+
|
294 |
+
|
295 |
+
for ( x = 0; x < width; x++ )
|
296 |
+
{
|
297 |
+
g_in_sum = b_in_sum = a_in_sum = r_in_sum = g_sum = b_sum = a_sum = r_sum = 0;
|
298 |
+
|
299 |
+
yi = x << 2;
|
300 |
+
r_out_sum = radiusPlus1 * ( pr = pixels[yi]);
|
301 |
+
g_out_sum = radiusPlus1 * ( pg = pixels[yi+1]);
|
302 |
+
b_out_sum = radiusPlus1 * ( pb = pixels[yi+2]);
|
303 |
+
a_out_sum = radiusPlus1 * ( pa = pixels[yi+3]);
|
304 |
+
|
305 |
+
r_sum += sumFactor * pr;
|
306 |
+
g_sum += sumFactor * pg;
|
307 |
+
b_sum += sumFactor * pb;
|
308 |
+
a_sum += sumFactor * pa;
|
309 |
+
|
310 |
+
stack = stackStart;
|
311 |
+
|
312 |
+
for( i = 0; i < radiusPlus1; i++ )
|
313 |
+
{
|
314 |
+
stack.r = pr;
|
315 |
+
stack.g = pg;
|
316 |
+
stack.b = pb;
|
317 |
+
stack.a = pa;
|
318 |
+
stack = stack.next;
|
319 |
+
}
|
320 |
+
|
321 |
+
yp = width;
|
322 |
+
|
323 |
+
for( i = 1; i <= radius; i++ )
|
324 |
+
{
|
325 |
+
yi = ( yp + x ) << 2;
|
326 |
+
|
327 |
+
r_sum += ( stack.r = ( pr = pixels[yi])) * ( rbs = radiusPlus1 - i );
|
328 |
+
g_sum += ( stack.g = ( pg = pixels[yi+1])) * rbs;
|
329 |
+
b_sum += ( stack.b = ( pb = pixels[yi+2])) * rbs;
|
330 |
+
a_sum += ( stack.a = ( pa = pixels[yi+3])) * rbs;
|
331 |
+
|
332 |
+
r_in_sum += pr;
|
333 |
+
g_in_sum += pg;
|
334 |
+
b_in_sum += pb;
|
335 |
+
a_in_sum += pa;
|
336 |
+
|
337 |
+
stack = stack.next;
|
338 |
+
|
339 |
+
if( i < heightMinus1 )
|
340 |
+
{
|
341 |
+
yp += width;
|
342 |
+
}
|
343 |
+
}
|
344 |
+
|
345 |
+
yi = x;
|
346 |
+
stackIn = stackStart;
|
347 |
+
stackOut = stackEnd;
|
348 |
+
for ( y = 0; y < height; y++ )
|
349 |
+
{
|
350 |
+
p = yi << 2;
|
351 |
+
pixels[p] = (r_sum * mul_sum) >> shg_sum;
|
352 |
+
pixels[p+1] = (g_sum * mul_sum) >> shg_sum;
|
353 |
+
pixels[p+2] = (b_sum * mul_sum) >> shg_sum;
|
354 |
+
pixels[p+3] = (a_sum * mul_sum) >> shg_sum;
|
355 |
+
|
356 |
+
r_sum -= r_out_sum;
|
357 |
+
g_sum -= g_out_sum;
|
358 |
+
b_sum -= b_out_sum;
|
359 |
+
a_sum -= a_out_sum;
|
360 |
+
|
361 |
+
r_out_sum -= stackIn.r;
|
362 |
+
g_out_sum -= stackIn.g;
|
363 |
+
b_out_sum -= stackIn.b;
|
364 |
+
a_out_sum -= stackIn.a;
|
365 |
+
|
366 |
+
p = ( x + (( ( p = y + radiusPlus1) < heightMinus1 ? p : heightMinus1 ) * width )) << 2;
|
367 |
+
|
368 |
+
r_sum += ( r_in_sum += ( stackIn.r = pixels[p]));
|
369 |
+
g_sum += ( g_in_sum += ( stackIn.g = pixels[p+1]));
|
370 |
+
b_sum += ( b_in_sum += ( stackIn.b = pixels[p+2]));
|
371 |
+
a_sum += ( a_in_sum += ( stackIn.a = pixels[p+3]));
|
372 |
+
|
373 |
+
stackIn = stackIn.next;
|
374 |
+
|
375 |
+
r_out_sum += ( pr = stackOut.r );
|
376 |
+
g_out_sum += ( pg = stackOut.g );
|
377 |
+
b_out_sum += ( pb = stackOut.b );
|
378 |
+
a_out_sum += ( pa = stackOut.a );
|
379 |
+
|
380 |
+
r_in_sum -= pr;
|
381 |
+
g_in_sum -= pg;
|
382 |
+
b_in_sum -= pb;
|
383 |
+
a_in_sum -= pa;
|
384 |
+
|
385 |
+
stackOut = stackOut.next;
|
386 |
+
|
387 |
+
yi += width;
|
388 |
+
}
|
389 |
+
}
|
390 |
+
|
391 |
+
unpremultiplyAlpha(imageData);
|
392 |
+
|
393 |
+
context.putImageData( imageData, top_x, top_y );
|
394 |
+
}
|
395 |
+
|
396 |
+
|
397 |
+
function stackBlurCanvasRGB( id, top_x, top_y, width, height, radius )
|
398 |
+
{
|
399 |
+
if ( isNaN(radius) || radius < 1 ) return;
|
400 |
+
radius |= 0;
|
401 |
+
|
402 |
+
var canvas = document.getElementById( id );
|
403 |
+
var context = canvas.getContext("2d");
|
404 |
+
var imageData;
|
405 |
+
|
406 |
+
try {
|
407 |
+
try {
|
408 |
+
imageData = context.getImageData( top_x, top_y, width, height );
|
409 |
+
} catch(e) {
|
410 |
+
|
411 |
+
// NOTE: this part is supposedly only needed if you want to work with local files
|
412 |
+
// so it might be okay to remove the whole try/catch block and just use
|
413 |
+
// imageData = context.getImageData( top_x, top_y, width, height );
|
414 |
+
try {
|
415 |
+
netscape.security.PrivilegeManager.enablePrivilege("UniversalBrowserRead");
|
416 |
+
imageData = context.getImageData( top_x, top_y, width, height );
|
417 |
+
} catch(e) {
|
418 |
+
alert("Cannot access local image");
|
419 |
+
throw new Error("unable to access local image data: " + e);
|
420 |
+
return;
|
421 |
+
}
|
422 |
+
}
|
423 |
+
} catch(e) {
|
424 |
+
alert("Cannot access image");
|
425 |
+
throw new Error("unable to access image data: " + e);
|
426 |
+
}
|
427 |
+
|
428 |
+
var pixels = imageData.data;
|
429 |
+
|
430 |
+
var x, y, i, p, yp, yi, yw, r_sum, g_sum, b_sum,
|
431 |
+
r_out_sum, g_out_sum, b_out_sum,
|
432 |
+
r_in_sum, g_in_sum, b_in_sum,
|
433 |
+
pr, pg, pb, rbs;
|
434 |
+
|
435 |
+
var div = radius + radius + 1;
|
436 |
+
var w4 = width << 2;
|
437 |
+
var widthMinus1 = width - 1;
|
438 |
+
var heightMinus1 = height - 1;
|
439 |
+
var radiusPlus1 = radius + 1;
|
440 |
+
var sumFactor = radiusPlus1 * ( radiusPlus1 + 1 ) / 2;
|
441 |
+
|
442 |
+
var stackStart = new BlurStack();
|
443 |
+
var stack = stackStart;
|
444 |
+
for ( i = 1; i < div; i++ )
|
445 |
+
{
|
446 |
+
stack = stack.next = new BlurStack();
|
447 |
+
if ( i == radiusPlus1 ) var stackEnd = stack;
|
448 |
+
}
|
449 |
+
stack.next = stackStart;
|
450 |
+
var stackIn = null;
|
451 |
+
var stackOut = null;
|
452 |
+
|
453 |
+
yw = yi = 0;
|
454 |
+
|
455 |
+
var mul_sum = mul_table[radius];
|
456 |
+
var shg_sum = shg_table[radius];
|
457 |
+
|
458 |
+
for ( y = 0; y < height; y++ )
|
459 |
+
{
|
460 |
+
r_in_sum = g_in_sum = b_in_sum = r_sum = g_sum = b_sum = 0;
|
461 |
+
|
462 |
+
r_out_sum = radiusPlus1 * ( pr = pixels[yi] );
|
463 |
+
g_out_sum = radiusPlus1 * ( pg = pixels[yi+1] );
|
464 |
+
b_out_sum = radiusPlus1 * ( pb = pixels[yi+2] );
|
465 |
+
|
466 |
+
r_sum += sumFactor * pr;
|
467 |
+
g_sum += sumFactor * pg;
|
468 |
+
b_sum += sumFactor * pb;
|
469 |
+
|
470 |
+
stack = stackStart;
|
471 |
+
|
472 |
+
for( i = 0; i < radiusPlus1; i++ )
|
473 |
+
{
|
474 |
+
stack.r = pr;
|
475 |
+
stack.g = pg;
|
476 |
+
stack.b = pb;
|
477 |
+
stack = stack.next;
|
478 |
+
}
|
479 |
+
|
480 |
+
for( i = 1; i < radiusPlus1; i++ )
|
481 |
+
{
|
482 |
+
p = yi + (( widthMinus1 < i ? widthMinus1 : i ) << 2 );
|
483 |
+
r_sum += ( stack.r = ( pr = pixels[p])) * ( rbs = radiusPlus1 - i );
|
484 |
+
g_sum += ( stack.g = ( pg = pixels[p+1])) * rbs;
|
485 |
+
b_sum += ( stack.b = ( pb = pixels[p+2])) * rbs;
|
486 |
+
|
487 |
+
r_in_sum += pr;
|
488 |
+
g_in_sum += pg;
|
489 |
+
b_in_sum += pb;
|
490 |
+
|
491 |
+
stack = stack.next;
|
492 |
+
}
|
493 |
+
|
494 |
+
|
495 |
+
stackIn = stackStart;
|
496 |
+
stackOut = stackEnd;
|
497 |
+
for ( x = 0; x < width; x++ )
|
498 |
+
{
|
499 |
+
pixels[yi] = (r_sum * mul_sum) >> shg_sum;
|
500 |
+
pixels[yi+1] = (g_sum * mul_sum) >> shg_sum;
|
501 |
+
pixels[yi+2] = (b_sum * mul_sum) >> shg_sum;
|
502 |
+
|
503 |
+
r_sum -= r_out_sum;
|
504 |
+
g_sum -= g_out_sum;
|
505 |
+
b_sum -= b_out_sum;
|
506 |
+
|
507 |
+
r_out_sum -= stackIn.r;
|
508 |
+
g_out_sum -= stackIn.g;
|
509 |
+
b_out_sum -= stackIn.b;
|
510 |
+
|
511 |
+
p = ( yw + ( ( p = x + radius + 1 ) < widthMinus1 ? p : widthMinus1 ) ) << 2;
|
512 |
+
|
513 |
+
r_in_sum += ( stackIn.r = pixels[p]);
|
514 |
+
g_in_sum += ( stackIn.g = pixels[p+1]);
|
515 |
+
b_in_sum += ( stackIn.b = pixels[p+2]);
|
516 |
+
|
517 |
+
r_sum += r_in_sum;
|
518 |
+
g_sum += g_in_sum;
|
519 |
+
b_sum += b_in_sum;
|
520 |
+
|
521 |
+
stackIn = stackIn.next;
|
522 |
+
|
523 |
+
r_out_sum += ( pr = stackOut.r );
|
524 |
+
g_out_sum += ( pg = stackOut.g );
|
525 |
+
b_out_sum += ( pb = stackOut.b );
|
526 |
+
|
527 |
+
r_in_sum -= pr;
|
528 |
+
g_in_sum -= pg;
|
529 |
+
b_in_sum -= pb;
|
530 |
+
|
531 |
+
stackOut = stackOut.next;
|
532 |
+
|
533 |
+
yi += 4;
|
534 |
+
}
|
535 |
+
yw += width;
|
536 |
+
}
|
537 |
+
|
538 |
+
|
539 |
+
for ( x = 0; x < width; x++ )
|
540 |
+
{
|
541 |
+
g_in_sum = b_in_sum = r_in_sum = g_sum = b_sum = r_sum = 0;
|
542 |
+
|
543 |
+
yi = x << 2;
|
544 |
+
r_out_sum = radiusPlus1 * ( pr = pixels[yi]);
|
545 |
+
g_out_sum = radiusPlus1 * ( pg = pixels[yi+1]);
|
546 |
+
b_out_sum = radiusPlus1 * ( pb = pixels[yi+2]);
|
547 |
+
|
548 |
+
r_sum += sumFactor * pr;
|
549 |
+
g_sum += sumFactor * pg;
|
550 |
+
b_sum += sumFactor * pb;
|
551 |
+
|
552 |
+
stack = stackStart;
|
553 |
+
|
554 |
+
for( i = 0; i < radiusPlus1; i++ )
|
555 |
+
{
|
556 |
+
stack.r = pr;
|
557 |
+
stack.g = pg;
|
558 |
+
stack.b = pb;
|
559 |
+
stack = stack.next;
|
560 |
+
}
|
561 |
+
|
562 |
+
yp = width;
|
563 |
+
|
564 |
+
for( i = 1; i <= radius; i++ )
|
565 |
+
{
|
566 |
+
yi = ( yp + x ) << 2;
|
567 |
+
|
568 |
+
r_sum += ( stack.r = ( pr = pixels[yi])) * ( rbs = radiusPlus1 - i );
|
569 |
+
g_sum += ( stack.g = ( pg = pixels[yi+1])) * rbs;
|
570 |
+
b_sum += ( stack.b = ( pb = pixels[yi+2])) * rbs;
|
571 |
+
|
572 |
+
r_in_sum += pr;
|
573 |
+
g_in_sum += pg;
|
574 |
+
b_in_sum += pb;
|
575 |
+
|
576 |
+
stack = stack.next;
|
577 |
+
|
578 |
+
if( i < heightMinus1 )
|
579 |
+
{
|
580 |
+
yp += width;
|
581 |
+
}
|
582 |
+
}
|
583 |
+
|
584 |
+
yi = x;
|
585 |
+
stackIn = stackStart;
|
586 |
+
stackOut = stackEnd;
|
587 |
+
for ( y = 0; y < height; y++ )
|
588 |
+
{
|
589 |
+
p = yi << 2;
|
590 |
+
pixels[p] = (r_sum * mul_sum) >> shg_sum;
|
591 |
+
pixels[p+1] = (g_sum * mul_sum) >> shg_sum;
|
592 |
+
pixels[p+2] = (b_sum * mul_sum) >> shg_sum;
|
593 |
+
|
594 |
+
r_sum -= r_out_sum;
|
595 |
+
g_sum -= g_out_sum;
|
596 |
+
b_sum -= b_out_sum;
|
597 |
+
|
598 |
+
r_out_sum -= stackIn.r;
|
599 |
+
g_out_sum -= stackIn.g;
|
600 |
+
b_out_sum -= stackIn.b;
|
601 |
+
|
602 |
+
p = ( x + (( ( p = y + radiusPlus1) < heightMinus1 ? p : heightMinus1 ) * width )) << 2;
|
603 |
+
|
604 |
+
r_sum += ( r_in_sum += ( stackIn.r = pixels[p]));
|
605 |
+
g_sum += ( g_in_sum += ( stackIn.g = pixels[p+1]));
|
606 |
+
b_sum += ( b_in_sum += ( stackIn.b = pixels[p+2]));
|
607 |
+
|
608 |
+
stackIn = stackIn.next;
|
609 |
+
|
610 |
+
r_out_sum += ( pr = stackOut.r );
|
611 |
+
g_out_sum += ( pg = stackOut.g );
|
612 |
+
b_out_sum += ( pb = stackOut.b );
|
613 |
+
|
614 |
+
r_in_sum -= pr;
|
615 |
+
g_in_sum -= pg;
|
616 |
+
b_in_sum -= pb;
|
617 |
+
|
618 |
+
stackOut = stackOut.next;
|
619 |
+
|
620 |
+
yi += width;
|
621 |
+
}
|
622 |
+
}
|
623 |
+
|
624 |
+
context.putImageData( imageData, top_x, top_y );
|
625 |
+
|
626 |
+
}
|
627 |
+
|
628 |
+
function BlurStack()
|
629 |
+
{
|
630 |
+
this.r = 0;
|
631 |
+
this.g = 0;
|
632 |
+
this.b = 0;
|
633 |
+
this.a = 0;
|
634 |
+
this.next = null;
|
635 |
+
}
|
636 |
+
|
637 |
+
var stackBlur = {
|
638 |
+
image: stackBlurImage,
|
639 |
+
canvasRGBA: stackBlurCanvasRGBA,
|
640 |
+
canvasRGB: stackBlurCanvasRGB
|
641 |
+
};
|
642 |
+
|
643 |
+
// export as AMD...
|
644 |
+
if ( typeof define !== 'undefined' && define.amd ) {
|
645 |
+
define( function () { return stackBlur; });
|
646 |
+
}
|
647 |
+
|
648 |
+
// ...or as browserify
|
649 |
+
else if ( typeof module !== 'undefined' && module.exports ) {
|
650 |
+
module.exports = stackBlur;
|
651 |
+
}
|
652 |
+
|
653 |
+
global.stackBlur = stackBlur;
|
654 |
+
|
655 |
}( typeof window !== 'undefined' ? window : this ));
|
inc/js/bootstrap-select.js
CHANGED
@@ -1,1709 +1,1709 @@
|
|
1 |
-
(function ($) {
|
2 |
-
'use strict';
|
3 |
-
|
4 |
-
//<editor-fold desc="Shims">
|
5 |
-
if (!String.prototype.includes) {
|
6 |
-
(function () {
|
7 |
-
'use strict'; // needed to support `apply`/`call` with `undefined`/`null`
|
8 |
-
var toString = {}.toString;
|
9 |
-
var defineProperty = (function () {
|
10 |
-
// IE 8 only supports `Object.defineProperty` on DOM elements
|
11 |
-
try {
|
12 |
-
var object = {};
|
13 |
-
var $defineProperty = Object.defineProperty;
|
14 |
-
var result = $defineProperty(object, object, object) && $defineProperty;
|
15 |
-
} catch (error) {
|
16 |
-
}
|
17 |
-
return result;
|
18 |
-
}());
|
19 |
-
var indexOf = ''.indexOf;
|
20 |
-
var includes = function (search) {
|
21 |
-
if (this == null) {
|
22 |
-
throw new TypeError();
|
23 |
-
}
|
24 |
-
var string = String(this);
|
25 |
-
if (search && toString.call(search) == '[object RegExp]') {
|
26 |
-
throw new TypeError();
|
27 |
-
}
|
28 |
-
var stringLength = string.length;
|
29 |
-
var searchString = String(search);
|
30 |
-
var searchLength = searchString.length;
|
31 |
-
var position = arguments.length > 1 ? arguments[1] : undefined;
|
32 |
-
// `ToInteger`
|
33 |
-
var pos = position ? Number(position) : 0;
|
34 |
-
if (pos != pos) { // better `isNaN`
|
35 |
-
pos = 0;
|
36 |
-
}
|
37 |
-
var start = Math.min(Math.max(pos, 0), stringLength);
|
38 |
-
// Avoid the `indexOf` call if no match is possible
|
39 |
-
if (searchLength + start > stringLength) {
|
40 |
-
return false;
|
41 |
-
}
|
42 |
-
return indexOf.call(string, searchString, pos) != -1;
|
43 |
-
};
|
44 |
-
if (defineProperty) {
|
45 |
-
defineProperty(String.prototype, 'includes', {
|
46 |
-
'value': includes,
|
47 |
-
'configurable': true,
|
48 |
-
'writable': true
|
49 |
-
});
|
50 |
-
} else {
|
51 |
-
String.prototype.includes = includes;
|
52 |
-
}
|
53 |
-
}());
|
54 |
-
}
|
55 |
-
|
56 |
-
if (!String.prototype.startsWith) {
|
57 |
-
(function () {
|
58 |
-
'use strict'; // needed to support `apply`/`call` with `undefined`/`null`
|
59 |
-
var defineProperty = (function () {
|
60 |
-
// IE 8 only supports `Object.defineProperty` on DOM elements
|
61 |
-
try {
|
62 |
-
var object = {};
|
63 |
-
var $defineProperty = Object.defineProperty;
|
64 |
-
var result = $defineProperty(object, object, object) && $defineProperty;
|
65 |
-
} catch (error) {
|
66 |
-
}
|
67 |
-
return result;
|
68 |
-
}());
|
69 |
-
var toString = {}.toString;
|
70 |
-
var startsWith = function (search) {
|
71 |
-
if (this == null) {
|
72 |
-
throw new TypeError();
|
73 |
-
}
|
74 |
-
var string = String(this);
|
75 |
-
if (search && toString.call(search) == '[object RegExp]') {
|
76 |
-
throw new TypeError();
|
77 |
-
}
|
78 |
-
var stringLength = string.length;
|
79 |
-
var searchString = String(search);
|
80 |
-
var searchLength = searchString.length;
|
81 |
-
var position = arguments.length > 1 ? arguments[1] : undefined;
|
82 |
-
// `ToInteger`
|
83 |
-
var pos = position ? Number(position) : 0;
|
84 |
-
if (pos != pos) { // better `isNaN`
|
85 |
-
pos = 0;
|
86 |
-
}
|
87 |
-
var start = Math.min(Math.max(pos, 0), stringLength);
|
88 |
-
// Avoid the `indexOf` call if no match is possible
|
89 |
-
if (searchLength + start > stringLength) {
|
90 |
-
return false;
|
91 |
-
}
|
92 |
-
var index = -1;
|
93 |
-
while (++index < searchLength) {
|
94 |
-
if (string.charCodeAt(start + index) != searchString.charCodeAt(index)) {
|
95 |
-
return false;
|
96 |
-
}
|
97 |
-
}
|
98 |
-
return true;
|
99 |
-
};
|
100 |
-
if (defineProperty) {
|
101 |
-
defineProperty(String.prototype, 'startsWith', {
|
102 |
-
'value': startsWith,
|
103 |
-
'configurable': true,
|
104 |
-
'writable': true
|
105 |
-
});
|
106 |
-
} else {
|
107 |
-
String.prototype.startsWith = startsWith;
|
108 |
-
}
|
109 |
-
}());
|
110 |
-
}
|
111 |
-
|
112 |
-
if (!Object.keys) {
|
113 |
-
Object.keys = function (
|
114 |
-
o, // object
|
115 |
-
k, // key
|
116 |
-
r // result array
|
117 |
-
){
|
118 |
-
// initialize object and result
|
119 |
-
r=[];
|
120 |
-
// iterate over object keys
|
121 |
-
for (k in o)
|
122 |
-
// fill result array with non-prototypical keys
|
123 |
-
r.hasOwnProperty.call(o, k) && r.push(k);
|
124 |
-
// return result
|
125 |
-
return r;
|
126 |
-
};
|
127 |
-
}
|
128 |
-
|
129 |
-
$.fn.triggerNative = function (eventName) {
|
130 |
-
var el = this[0],
|
131 |
-
event;
|
132 |
-
|
133 |
-
if (el.dispatchEvent) {
|
134 |
-
if (typeof Event === 'function') {
|
135 |
-
// For modern browsers
|
136 |
-
event = new Event(eventName, {
|
137 |
-
bubbles: true
|
138 |
-
});
|
139 |
-
} else {
|
140 |
-
// For IE since it doesn't support Event constructor
|
141 |
-
event = document.createEvent('Event');
|
142 |
-
event.initEvent(eventName, true, false);
|
143 |
-
}
|
144 |
-
|
145 |
-
el.dispatchEvent(event);
|
146 |
-
} else {
|
147 |
-
if (el.fireEvent) {
|
148 |
-
event = document.createEventObject();
|
149 |
-
event.eventType = eventName;
|
150 |
-
el.fireEvent('on' + eventName, event);
|
151 |
-
}
|
152 |
-
|
153 |
-
this.trigger(eventName);
|
154 |
-
}
|
155 |
-
};
|
156 |
-
//</editor-fold>
|
157 |
-
|
158 |
-
// Case insensitive contains search
|
159 |
-
$.expr[':'].icontains = function (obj, index, meta) {
|
160 |
-
var $obj = $(obj);
|
161 |
-
var haystack = ($obj.data('tokens') || $obj.text()).toUpperCase();
|
162 |
-
return haystack.includes(meta[3].toUpperCase());
|
163 |
-
};
|
164 |
-
|
165 |
-
// Case insensitive begins search
|
166 |
-
$.expr[':'].ibegins = function (obj, index, meta) {
|
167 |
-
var $obj = $(obj);
|
168 |
-
var haystack = ($obj.data('tokens') || $obj.text()).toUpperCase();
|
169 |
-
return haystack.startsWith(meta[3].toUpperCase());
|
170 |
-
};
|
171 |
-
|
172 |
-
// Case and accent insensitive contains search
|
173 |
-
$.expr[':'].aicontains = function (obj, index, meta) {
|
174 |
-
var $obj = $(obj);
|
175 |
-
var haystack = ($obj.data('tokens') || $obj.data('normalizedText') || $obj.text()).toUpperCase();
|
176 |
-
return haystack.includes(meta[3].toUpperCase());
|
177 |
-
};
|
178 |
-
|
179 |
-
// Case and accent insensitive begins search
|
180 |
-
$.expr[':'].aibegins = function (obj, index, meta) {
|
181 |
-
var $obj = $(obj);
|
182 |
-
var haystack = ($obj.data('tokens') || $obj.data('normalizedText') || $obj.text()).toUpperCase();
|
183 |
-
return haystack.startsWith(meta[3].toUpperCase());
|
184 |
-
};
|
185 |
-
|
186 |
-
/**
|
187 |
-
* Remove all diatrics from the given text.
|
188 |
-
* @access private
|
189 |
-
* @param {String} text
|
190 |
-
* @returns {String}
|
191 |
-
*/
|
192 |
-
function normalizeToBase(text) {
|
193 |
-
var rExps = [
|
194 |
-
{re: /[\xC0-\xC6]/g, ch: "A"},
|
195 |
-
{re: /[\xE0-\xE6]/g, ch: "a"},
|
196 |
-
{re: /[\xC8-\xCB]/g, ch: "E"},
|
197 |
-
{re: /[\xE8-\xEB]/g, ch: "e"},
|
198 |
-
{re: /[\xCC-\xCF]/g, ch: "I"},
|
199 |
-
{re: /[\xEC-\xEF]/g, ch: "i"},
|
200 |
-
{re: /[\xD2-\xD6]/g, ch: "O"},
|
201 |
-
{re: /[\xF2-\xF6]/g, ch: "o"},
|
202 |
-
{re: /[\xD9-\xDC]/g, ch: "U"},
|
203 |
-
{re: /[\xF9-\xFC]/g, ch: "u"},
|
204 |
-
{re: /[\xC7-\xE7]/g, ch: "c"},
|
205 |
-
{re: /[\xD1]/g, ch: "N"},
|
206 |
-
{re: /[\xF1]/g, ch: "n"}
|
207 |
-
];
|
208 |
-
$.each(rExps, function () {
|
209 |
-
text = text.replace(this.re, this.ch);
|
210 |
-
});
|
211 |
-
return text;
|
212 |
-
}
|
213 |
-
|
214 |
-
|
215 |
-
function htmlEscape(html) {
|
216 |
-
var escapeMap = {
|
217 |
-
'&': '&',
|
218 |
-
'<': '<',
|
219 |
-
'>': '>',
|
220 |
-
'"': '"',
|
221 |
-
"'": ''',
|
222 |
-
'`': '`'
|
223 |
-
};
|
224 |
-
var source = '(?:' + Object.keys(escapeMap).join('|') + ')',
|
225 |
-
testRegexp = new RegExp(source),
|
226 |
-
replaceRegexp = new RegExp(source, 'g'),
|
227 |
-
string = html == null ? '' : '' + html;
|
228 |
-
return testRegexp.test(string) ? string.replace(replaceRegexp, function (match) {
|
229 |
-
return escapeMap[match];
|
230 |
-
}) : string;
|
231 |
-
}
|
232 |
-
|
233 |
-
var Selectpicker = function (element, options, e) {
|
234 |
-
if (e) {
|
235 |
-
e.stopPropagation();
|
236 |
-
e.preventDefault();
|
237 |
-
}
|
238 |
-
|
239 |
-
this.$element = $(element);
|
240 |
-
this.$newElement = null;
|
241 |
-
this.$button = null;
|
242 |
-
this.$menu = null;
|
243 |
-
this.$lis = null;
|
244 |
-
this.options = options;
|
245 |
-
|
246 |
-
// If we have no title yet, try to pull it from the html title attribute (jQuery doesnt' pick it up as it's not a
|
247 |
-
// data-attribute)
|
248 |
-
if (this.options.title === null) {
|
249 |
-
this.options.title = this.$element.attr('title');
|
250 |
-
}
|
251 |
-
|
252 |
-
//Expose public methods
|
253 |
-
this.val = Selectpicker.prototype.val;
|
254 |
-
this.render = Selectpicker.prototype.render;
|
255 |
-
this.refresh = Selectpicker.prototype.refresh;
|
256 |
-
this.setStyle = Selectpicker.prototype.setStyle;
|
257 |
-
this.selectAll = Selectpicker.prototype.selectAll;
|
258 |
-
this.deselectAll = Selectpicker.prototype.deselectAll;
|
259 |
-
this.destroy = Selectpicker.prototype.destroy;
|
260 |
-
this.remove = Selectpicker.prototype.remove;
|
261 |
-
this.show = Selectpicker.prototype.show;
|
262 |
-
this.hide = Selectpicker.prototype.hide;
|
263 |
-
|
264 |
-
this.init();
|
265 |
-
};
|
266 |
-
|
267 |
-
Selectpicker.VERSION = '1.10.0';
|
268 |
-
|
269 |
-
// part of this is duplicated in i18n/defaults-en_US.js. Make sure to update both.
|
270 |
-
Selectpicker.DEFAULTS = {
|
271 |
-
noneSelectedText: 'Nothing selected',
|
272 |
-
noneResultsText: 'No results matched {0}',
|
273 |
-
countSelectedText: function (numSelected, numTotal) {
|
274 |
-
return (numSelected == 1) ? "{0} item selected" : "{0} items selected";
|
275 |
-
},
|
276 |
-
maxOptionsText: function (numAll, numGroup) {
|
277 |
-
return [
|
278 |
-
(numAll == 1) ? 'Limit reached ({n} item max)' : 'Limit reached ({n} items max)',
|
279 |
-
(numGroup == 1) ? 'Group limit reached ({n} item max)' : 'Group limit reached ({n} items max)'
|
280 |
-
];
|
281 |
-
},
|
282 |
-
selectAllText: 'Select All',
|
283 |
-
deselectAllText: 'Deselect All',
|
284 |
-
doneButton: false,
|
285 |
-
doneButtonText: 'Close',
|
286 |
-
multipleSeparator: ', ',
|
287 |
-
styleBase: 'btn',
|
288 |
-
style: 'btn-default',
|
289 |
-
size: 'auto',
|
290 |
-
title: null,
|
291 |
-
selectedTextFormat: 'values',
|
292 |
-
width: false,
|
293 |
-
container: false,
|
294 |
-
hideDisabled: false,
|
295 |
-
showSubtext: false,
|
296 |
-
showIcon: true,
|
297 |
-
showContent: true,
|
298 |
-
dropupAuto: true,
|
299 |
-
header: false,
|
300 |
-
liveSearch: false,
|
301 |
-
liveSearchPlaceholder: null,
|
302 |
-
liveSearchNormalize: false,
|
303 |
-
liveSearchStyle: 'contains',
|
304 |
-
actionsBox: false,
|
305 |
-
iconBase: 'glyphicon',
|
306 |
-
tickIcon: 'glyphicon-ok',
|
307 |
-
showTick: false,
|
308 |
-
template: {
|
309 |
-
caret: '<span class="caret"></span>'
|
310 |
-
},
|
311 |
-
maxOptions: false,
|
312 |
-
mobile: false,
|
313 |
-
selectOnTab: false,
|
314 |
-
dropdownAlignRight: false
|
315 |
-
};
|
316 |
-
|
317 |
-
Selectpicker.prototype = {
|
318 |
-
|
319 |
-
constructor: Selectpicker,
|
320 |
-
|
321 |
-
init: function () {
|
322 |
-
var that = this,
|
323 |
-
id = this.$element.attr('id');
|
324 |
-
|
325 |
-
this.$element.addClass('bs-select-hidden');
|
326 |
-
|
327 |
-
// store originalIndex (key) and newIndex (value) in this.liObj for fast accessibility
|
328 |
-
// allows us to do this.$lis.eq(that.liObj[index]) instead of this.$lis.filter('[data-original-index="' + index + '"]')
|
329 |
-
this.liObj = {};
|
330 |
-
this.multiple = this.$element.prop('multiple');
|
331 |
-
this.autofocus = this.$element.prop('autofocus');
|
332 |
-
this.$newElement = this.createView();
|
333 |
-
this.$element
|
334 |
-
.after(this.$newElement)
|
335 |
-
.appendTo(this.$newElement);
|
336 |
-
this.$button = this.$newElement.children('button');
|
337 |
-
this.$menu = this.$newElement.children('.dropdown-menu');
|
338 |
-
this.$menuInner = this.$menu.children('.inner');
|
339 |
-
this.$searchbox = this.$menu.find('input');
|
340 |
-
|
341 |
-
this.$element.removeClass('bs-select-hidden');
|
342 |
-
|
343 |
-
if (this.options.dropdownAlignRight)
|
344 |
-
this.$menu.addClass('dropdown-menu-right');
|
345 |
-
|
346 |
-
if (typeof id !== 'undefined') {
|
347 |
-
this.$button.attr('data-id', id);
|
348 |
-
$('label[for="' + id + '"]').click(function (e) {
|
349 |
-
e.preventDefault();
|
350 |
-
that.$button.focus();
|
351 |
-
});
|
352 |
-
}
|
353 |
-
|
354 |
-
this.checkDisabled();
|
355 |
-
this.clickListener();
|
356 |
-
if (this.options.liveSearch) this.liveSearchListener();
|
357 |
-
this.render();
|
358 |
-
this.setStyle();
|
359 |
-
this.setWidth();
|
360 |
-
if (this.options.container) this.selectPosition();
|
361 |
-
this.$menu.data('this', this);
|
362 |
-
this.$newElement.data('this', this);
|
363 |
-
if (this.options.mobile) this.mobile();
|
364 |
-
|
365 |
-
this.$newElement.on({
|
366 |
-
'hide.bs.dropdown': function (e) {
|
367 |
-
that.$element.trigger('hide.bs.select', e);
|
368 |
-
},
|
369 |
-
'hidden.bs.dropdown': function (e) {
|
370 |
-
that.$element.trigger('hidden.bs.select', e);
|
371 |
-
},
|
372 |
-
'show.bs.dropdown': function (e) {
|
373 |
-
that.$element.trigger('show.bs.select', e);
|
374 |
-
},
|
375 |
-
'shown.bs.dropdown': function (e) {
|
376 |
-
that.$element.trigger('shown.bs.select', e);
|
377 |
-
}
|
378 |
-
});
|
379 |
-
|
380 |
-
if (that.$element[0].hasAttribute('required')) {
|
381 |
-
this.$element.on('invalid', function () {
|
382 |
-
that.$button
|
383 |
-
.addClass('bs-invalid')
|
384 |
-
.focus();
|
385 |
-
|
386 |
-
that.$element.on({
|
387 |
-
'focus.bs.select': function () {
|
388 |
-
that.$button.focus();
|
389 |
-
that.$element.off('focus.bs.select');
|
390 |
-
},
|
391 |
-
'shown.bs.select': function () {
|
392 |
-
that.$element
|
393 |
-
.val(that.$element.val()) // set the value to hide the validation message in Chrome when menu is opened
|
394 |
-
.off('shown.bs.select');
|
395 |
-
},
|
396 |
-
'rendered.bs.select': function () {
|
397 |
-
// if select is no longer invalid, remove the bs-invalid class
|
398 |
-
if (this.validity.valid) that.$button.removeClass('bs-invalid');
|
399 |
-
that.$element.off('rendered.bs.select');
|
400 |
-
}
|
401 |
-
});
|
402 |
-
|
403 |
-
});
|
404 |
-
}
|
405 |
-
|
406 |
-
setTimeout(function () {
|
407 |
-
that.$element.trigger('loaded.bs.select');
|
408 |
-
});
|
409 |
-
},
|
410 |
-
|
411 |
-
createDropdown: function () {
|
412 |
-
// Options
|
413 |
-
// If we are multiple or showTick option is set, then add the show-tick class
|
414 |
-
var showTick = (this.multiple || this.options.showTick) ? ' show-tick' : '',
|
415 |
-
inputGroup = this.$element.parent().hasClass('input-group') ? ' input-group-btn' : '',
|
416 |
-
autofocus = this.autofocus ? ' autofocus' : '';
|
417 |
-
// Elements
|
418 |
-
var header = this.options.header ? '<div class="popover-title"><button type="button" class="close" aria-hidden="true">×</button>' + this.options.header + '</div>' : '';
|
419 |
-
var searchbox = this.options.liveSearch ?
|
420 |
-
'<div class="bs-searchbox">' +
|
421 |
-
'<input type="text" class="form-control" autocomplete="off"' +
|
422 |
-
(null === this.options.liveSearchPlaceholder ? '' : ' placeholder="' + htmlEscape(this.options.liveSearchPlaceholder) + '"') + '>' +
|
423 |
-
'</div>'
|
424 |
-
: '';
|
425 |
-
var actionsbox = this.multiple && this.options.actionsBox ?
|
426 |
-
'<div class="bs-actionsbox">' +
|
427 |
-
'<div class="btn-group btn-group-sm btn-block">' +
|
428 |
-
'<button type="button" class="actions-btn bs-select-all btn btn-default">' +
|
429 |
-
this.options.selectAllText +
|
430 |
-
'</button>' +
|
431 |
-
'<button type="button" class="actions-btn bs-deselect-all btn btn-default">' +
|
432 |
-
this.options.deselectAllText +
|
433 |
-
'</button>' +
|
434 |
-
'</div>' +
|
435 |
-
'</div>'
|
436 |
-
: '';
|
437 |
-
var donebutton = this.multiple && this.options.doneButton ?
|
438 |
-
'<div class="bs-donebutton">' +
|
439 |
-
'<div class="btn-group btn-block">' +
|
440 |
-
'<button type="button" class="btn btn-sm btn-default">' +
|
441 |
-
this.options.doneButtonText +
|
442 |
-
'</button>' +
|
443 |
-
'</div>' +
|
444 |
-
'</div>'
|
445 |
-
: '';
|
446 |
-
var drop =
|
447 |
-
'<div class="btn-group bootstrap-select' + showTick + inputGroup + '">' +
|
448 |
-
'<button type="button" class="' + this.options.styleBase + ' dropdown-toggle" data-toggle="dropdown"' + autofocus + '>' +
|
449 |
-
'<span class="filter-option pull-left"></span> ' +
|
450 |
-
'<span class="bs-caret">' +
|
451 |
-
this.options.template.caret +
|
452 |
-
'</span>' +
|
453 |
-
'</button>' +
|
454 |
-
'<div class="dropdown-menu open">' +
|
455 |
-
header +
|
456 |
-
searchbox +
|
457 |
-
actionsbox +
|
458 |
-
'<ul class="dropdown-menu inner" role="menu">' +
|
459 |
-
'</ul>' +
|
460 |
-
donebutton +
|
461 |
-
'</div>' +
|
462 |
-
'</div>';
|
463 |
-
|
464 |
-
return $(drop);
|
465 |
-
},
|
466 |
-
|
467 |
-
createView: function () {
|
468 |
-
var $drop = this.createDropdown(),
|
469 |
-
li = this.createLi();
|
470 |
-
|
471 |
-
$drop.find('ul')[0].innerHTML = li;
|
472 |
-
return $drop;
|
473 |
-
},
|
474 |
-
|
475 |
-
reloadLi: function () {
|
476 |
-
//Remove all children.
|
477 |
-
this.destroyLi();
|
478 |
-
//Re build
|
479 |
-
var li = this.createLi();
|
480 |
-
this.$menuInner[0].innerHTML = li;
|
481 |
-
},
|
482 |
-
|
483 |
-
destroyLi: function () {
|
484 |
-
this.$menu.find('li').remove();
|
485 |
-
},
|
486 |
-
|
487 |
-
createLi: function () {
|
488 |
-
var that = this,
|
489 |
-
_li = [],
|
490 |
-
optID = 0,
|
491 |
-
titleOption = document.createElement('option'),
|
492 |
-
liIndex = -1; // increment liIndex whenever a new <li> element is created to ensure liObj is correct
|
493 |
-
|
494 |
-
// Helper functions
|
495 |
-
/**
|
496 |
-
* @param content
|
497 |
-
* @param [index]
|
498 |
-
* @param [classes]
|
499 |
-
* @param [optgroup]
|
500 |
-
* @returns {string}
|
501 |
-
*/
|
502 |
-
var generateLI = function (content, index, classes, optgroup) {
|
503 |
-
return '<li' +
|
504 |
-
((typeof classes !== 'undefined' & '' !== classes) ? ' class="' + classes + '"' : '') +
|
505 |
-
((typeof index !== 'undefined' & null !== index) ? ' data-original-index="' + index + '"' : '') +
|
506 |
-
((typeof optgroup !== 'undefined' & null !== optgroup) ? 'data-optgroup="' + optgroup + '"' : '') +
|
507 |
-
'>' + content + '</li>';
|
508 |
-
};
|
509 |
-
|
510 |
-
/**
|
511 |
-
* @param text
|
512 |
-
* @param [classes]
|
513 |
-
* @param [inline]
|
514 |
-
* @param [tokens]
|
515 |
-
* @returns {string}
|
516 |
-
*/
|
517 |
-
var generateA = function (text, classes, inline, tokens) {
|
518 |
-
return '<a tabindex="0"' +
|
519 |
-
(typeof classes !== 'undefined' ? ' class="' + classes + '"' : '') +
|
520 |
-
(typeof inline !== 'undefined' ? ' style="' + inline + '"' : '') +
|
521 |
-
(that.options.liveSearchNormalize ? ' data-normalized-text="' + normalizeToBase(htmlEscape(text)) + '"' : '') +
|
522 |
-
(typeof tokens !== 'undefined' || tokens !== null ? ' data-tokens="' + tokens + '"' : '') +
|
523 |
-
'>' + text +
|
524 |
-
'<span class="' + that.options.iconBase + ' ' + that.options.tickIcon + ' check-mark"></span>' +
|
525 |
-
'</a>';
|
526 |
-
};
|
527 |
-
|
528 |
-
if (this.options.title && !this.multiple) {
|
529 |
-
// this option doesn't create a new <li> element, but does add a new option, so liIndex is decreased
|
530 |
-
// since liObj is recalculated on every refresh, liIndex needs to be decreased even if the titleOption is already appended
|
531 |
-
liIndex--;
|
532 |
-
|
533 |
-
if (!this.$element.find('.bs-title-option').length) {
|
534 |
-
// Use native JS to prepend option (faster)
|
535 |
-
var element = this.$element[0];
|
536 |
-
titleOption.className = 'bs-title-option';
|
537 |
-
titleOption.appendChild(document.createTextNode(this.options.title));
|
538 |
-
titleOption.value = '';
|
539 |
-
element.insertBefore(titleOption, element.firstChild);
|
540 |
-
// Check if selected attribute is already set on an option. If not, select the titleOption option.
|
541 |
-
if ($(element.options[element.selectedIndex]).attr('selected') === undefined) titleOption.selected = true;
|
542 |
-
}
|
543 |
-
}
|
544 |
-
|
545 |
-
this.$element.find('option').each(function (index) {
|
546 |
-
var $this = $(this);
|
547 |
-
|
548 |
-
liIndex++;
|
549 |
-
|
550 |
-
if ($this.hasClass('bs-title-option')) return;
|
551 |
-
|
552 |
-
// Get the class and text for the option
|
553 |
-
var optionClass = this.className || '',
|
554 |
-
inline = this.style.cssText,
|
555 |
-
text = $this.data('content') ? $this.data('content') : $this.html(),
|
556 |
-
tokens = $this.data('tokens') ? $this.data('tokens') : null,
|
557 |
-
subtext = typeof $this.data('subtext') !== 'undefined' ? '<small class="text-muted">' + $this.data('subtext') + '</small>' : '',
|
558 |
-
icon = typeof $this.data('icon') !== 'undefined' ? '<span class="' + that.options.iconBase + ' ' + $this.data('icon') + '"></span> ' : '',
|
559 |
-
isOptgroup = this.parentNode.tagName === 'OPTGROUP',
|
560 |
-
isDisabled = this.disabled || (isOptgroup && this.parentNode.disabled);
|
561 |
-
|
562 |
-
if (icon !== '' && isDisabled) {
|
563 |
-
icon = '<span>' + icon + '</span>';
|
564 |
-
}
|
565 |
-
|
566 |
-
if (that.options.hideDisabled && isDisabled && !isOptgroup) {
|
567 |
-
liIndex--;
|
568 |
-
return;
|
569 |
-
}
|
570 |
-
|
571 |
-
if (!$this.data('content')) {
|
572 |
-
// Prepend any icon and append any subtext to the main text.
|
573 |
-
text = icon + '<span class="text">' + text + subtext + '</span>';
|
574 |
-
}
|
575 |
-
|
576 |
-
if (isOptgroup && $this.data('divider') !== true) {
|
577 |
-
var optGroupClass = ' ' + this.parentNode.className || '';
|
578 |
-
|
579 |
-
if ($this.index() === 0) { // Is it the first option of the optgroup?
|
580 |
-
optID += 1;
|
581 |
-
|
582 |
-
// Get the opt group label
|
583 |
-
var label = this.parentNode.label,
|
584 |
-
labelSubtext = typeof $this.parent().data('subtext') !== 'undefined' ? '<small class="text-muted">' + $this.parent().data('subtext') + '</small>' : '',
|
585 |
-
labelIcon = $this.parent().data('icon') ? '<span class="' + that.options.iconBase + ' ' + $this.parent().data('icon') + '"></span> ' : '';
|
586 |
-
|
587 |
-
label = labelIcon + '<span class="text">' + label + labelSubtext + '</span>';
|
588 |
-
|
589 |
-
if (index !== 0 && _li.length > 0) { // Is it NOT the first option of the select && are there elements in the dropdown?
|
590 |
-
liIndex++;
|
591 |
-
_li.push(generateLI('', null, 'divider', optID + 'div'));
|
592 |
-
}
|
593 |
-
liIndex++;
|
594 |
-
_li.push(generateLI(label, null, 'dropdown-header' + optGroupClass, optID));
|
595 |
-
}
|
596 |
-
|
597 |
-
if (that.options.hideDisabled && isDisabled) {
|
598 |
-
liIndex--;
|
599 |
-
return;
|
600 |
-
}
|
601 |
-
|
602 |
-
_li.push(generateLI(generateA(text, 'opt ' + optionClass + optGroupClass, inline, tokens), index, '', optID));
|
603 |
-
} else if ($this.data('divider') === true) {
|
604 |
-
_li.push(generateLI('', index, 'divider'));
|
605 |
-
} else if ($this.data('hidden') === true) {
|
606 |
-
_li.push(generateLI(generateA(text, optionClass, inline, tokens), index, 'hidden is-hidden'));
|
607 |
-
} else {
|
608 |
-
if (this.previousElementSibling && this.previousElementSibling.tagName === 'OPTGROUP') {
|
609 |
-
liIndex++;
|
610 |
-
_li.push(generateLI('', null, 'divider', optID + 'div'));
|
611 |
-
}
|
612 |
-
_li.push(generateLI(generateA(text, optionClass, inline, tokens), index));
|
613 |
-
}
|
614 |
-
|
615 |
-
that.liObj[index] = liIndex;
|
616 |
-
});
|
617 |
-
|
618 |
-
//If we are not multiple, we don't have a selected item, and we don't have a title, select the first element so something is set in the button
|
619 |
-
if (!this.multiple && this.$element.find('option:selected').length === 0 && !this.options.title) {
|
620 |
-
this.$element.find('option').eq(0).prop('selected', true).attr('selected', 'selected');
|
621 |
-
}
|
622 |
-
|
623 |
-
return _li.join('');
|
624 |
-
},
|
625 |
-
|
626 |
-
findLis: function () {
|
627 |
-
if (this.$lis == null) this.$lis = this.$menu.find('li');
|
628 |
-
return this.$lis;
|
629 |
-
},
|
630 |
-
|
631 |
-
/**
|
632 |
-
* @param [updateLi] defaults to true
|
633 |
-
*/
|
634 |
-
render: function (updateLi) {
|
635 |
-
var that = this,
|
636 |
-
notDisabled;
|
637 |
-
|
638 |
-
//Update the LI to match the SELECT
|
639 |
-
if (updateLi !== false) {
|
640 |
-
this.$element.find('option').each(function (index) {
|
641 |
-
var $lis = that.findLis().eq(that.liObj[index]);
|
642 |
-
|
643 |
-
that.setDisabled(index, this.disabled || this.parentNode.tagName === 'OPTGROUP' && this.parentNode.disabled, $lis);
|
644 |
-
that.setSelected(index, this.selected, $lis);
|
645 |
-
});
|
646 |
-
}
|
647 |
-
|
648 |
-
this.tabIndex();
|
649 |
-
|
650 |
-
var selectedItems = this.$element.find('option').map(function () {
|
651 |
-
if (this.selected) {
|
652 |
-
if (that.options.hideDisabled && (this.disabled || this.parentNode.tagName === 'OPTGROUP' && this.parentNode.disabled)) return;
|
653 |
-
|
654 |
-
var $this = $(this),
|
655 |
-
icon = $this.data('icon') && that.options.showIcon ? '<i class="' + that.options.iconBase + ' ' + $this.data('icon') + '"></i> ' : '',
|
656 |
-
subtext;
|
657 |
-
|
658 |
-
if (that.options.showSubtext && $this.data('subtext') && !that.multiple) {
|
659 |
-
subtext = ' <small class="text-muted">' + $this.data('subtext') + '</small>';
|
660 |
-
} else {
|
661 |
-
subtext = '';
|
662 |
-
}
|
663 |
-
if (typeof $this.attr('title') !== 'undefined') {
|
664 |
-
return $this.attr('title');
|
665 |
-
} else if ($this.data('content') && that.options.showContent) {
|
666 |
-
return $this.data('content');
|
667 |
-
} else {
|
668 |
-
return icon + $this.html() + subtext;
|
669 |
-
}
|
670 |
-
}
|
671 |
-
}).toArray();
|
672 |
-
|
673 |
-
//Fixes issue in IE10 occurring when no default option is selected and at least one option is disabled
|
674 |
-
//Convert all the values into a comma delimited string
|
675 |
-
var title = !this.multiple ? selectedItems[0] : selectedItems.join(this.options.multipleSeparator);
|
676 |
-
|
677 |
-
//If this is multi select, and the selectText type is count, the show 1 of 2 selected etc..
|
678 |
-
if (this.multiple && this.options.selectedTextFormat.indexOf('count') > -1) {
|
679 |
-
var max = this.options.selectedTextFormat.split('>');
|
680 |
-
if ((max.length > 1 && selectedItems.length > max[1]) || (max.length == 1 && selectedItems.length >= 2)) {
|
681 |
-
notDisabled = this.options.hideDisabled ? ', [disabled]' : '';
|
682 |
-
var totalCount = this.$element.find('option').not('[data-divider="true"], [data-hidden="true"]' + notDisabled).length,
|
683 |
-
tr8nText = (typeof this.options.countSelectedText === 'function') ? this.options.countSelectedText(selectedItems.length, totalCount) : this.options.countSelectedText;
|
684 |
-
title = tr8nText.replace('{0}', selectedItems.length.toString()).replace('{1}', totalCount.toString());
|
685 |
-
}
|
686 |
-
}
|
687 |
-
|
688 |
-
if (this.options.title == undefined) {
|
689 |
-
this.options.title = this.$element.attr('title');
|
690 |
-
}
|
691 |
-
|
692 |
-
if (this.options.selectedTextFormat == 'static') {
|
693 |
-
title = this.options.title;
|
694 |
-
}
|
695 |
-
|
696 |
-
//If we dont have a title, then use the default, or if nothing is set at all, use the not selected text
|
697 |
-
if (!title) {
|
698 |
-
title = typeof this.options.title !== 'undefined' ? this.options.title : this.options.noneSelectedText;
|
699 |
-
}
|
700 |
-
|
701 |
-
//strip all html-tags and trim the result
|
702 |
-
// this.$button.attr('title', $.trim(title.replace(/<[^>]*>?/g, '')));
|
703 |
-
this.$button.children('.filter-option').html(title);
|
704 |
-
|
705 |
-
this.$element.trigger('rendered.bs.select');
|
706 |
-
},
|
707 |
-
|
708 |
-
/**
|
709 |
-
* @param [style]
|
710 |
-
* @param [status]
|
711 |
-
*/
|
712 |
-
setStyle: function (style, status) {
|
713 |
-
if (this.$element.attr('class')) {
|
714 |
-
this.$newElement.addClass(this.$element.attr('class').replace(/selectpicker|mobile-device|bs-select-hidden|validate\[.*\]/gi, ''));
|
715 |
-
}
|
716 |
-
|
717 |
-
var buttonClass = style ? style : this.options.style;
|
718 |
-
|
719 |
-
if (status == 'add') {
|
720 |
-
this.$button.addClass(buttonClass);
|
721 |
-
} else if (status == 'remove') {
|
722 |
-
this.$button.removeClass(buttonClass);
|
723 |
-
} else {
|
724 |
-
this.$button.removeClass(this.options.style);
|
725 |
-
this.$button.addClass(buttonClass);
|
726 |
-
}
|
727 |
-
},
|
728 |
-
|
729 |
-
liHeight: function (refresh) {
|
730 |
-
if (!refresh && (this.options.size === false || this.sizeInfo)) return;
|
731 |
-
|
732 |
-
var newElement = document.createElement('div'),
|
733 |
-
menu = document.createElement('div'),
|
734 |
-
menuInner = document.createElement('ul'),
|
735 |
-
divider = document.createElement('li'),
|
736 |
-
li = document.createElement('li'),
|
737 |
-
a = document.createElement('a'),
|
738 |
-
text = document.createElement('span'),
|
739 |
-
header = this.options.header && this.$menu.find('.popover-title').length > 0 ? this.$menu.find('.popover-title')[0].cloneNode(true) : null,
|
740 |
-
search = this.options.liveSearch ? document.createElement('div') : null,
|
741 |
-
actions = this.options.actionsBox && this.multiple && this.$menu.find('.bs-actionsbox').length > 0 ? this.$menu.find('.bs-actionsbox')[0].cloneNode(true) : null,
|
742 |
-
doneButton = this.options.doneButton && this.multiple && this.$menu.find('.bs-donebutton').length > 0 ? this.$menu.find('.bs-donebutton')[0].cloneNode(true) : null;
|
743 |
-
|
744 |
-
text.className = 'text';
|
745 |
-
newElement.className = this.$menu[0].parentNode.className + ' open';
|
746 |
-
menu.className = 'dropdown-menu open';
|
747 |
-
menuInner.className = 'dropdown-menu inner';
|
748 |
-
divider.className = 'divider';
|
749 |
-
|
750 |
-
text.appendChild(document.createTextNode('Inner text'));
|
751 |
-
a.appendChild(text);
|
752 |
-
li.appendChild(a);
|
753 |
-
menuInner.appendChild(li);
|
754 |
-
menuInner.appendChild(divider);
|
755 |
-
if (header) menu.appendChild(header);
|
756 |
-
if (search) {
|
757 |
-
// create a span instead of input as creating an input element is slower
|
758 |
-
var input = document.createElement('span');
|
759 |
-
search.className = 'bs-searchbox';
|
760 |
-
input.className = 'form-control';
|
761 |
-
search.appendChild(input);
|
762 |
-
menu.appendChild(search);
|
763 |
-
}
|
764 |
-
if (actions) menu.appendChild(actions);
|
765 |
-
menu.appendChild(menuInner);
|
766 |
-
if (doneButton) menu.appendChild(doneButton);
|
767 |
-
newElement.appendChild(menu);
|
768 |
-
|
769 |
-
document.body.appendChild(newElement);
|
770 |
-
|
771 |
-
var liHeight = a.offsetHeight,
|
772 |
-
headerHeight = header ? header.offsetHeight : 0,
|
773 |
-
searchHeight = search ? search.offsetHeight : 0,
|
774 |
-
actionsHeight = actions ? actions.offsetHeight : 0,
|
775 |
-
doneButtonHeight = doneButton ? doneButton.offsetHeight : 0,
|
776 |
-
dividerHeight = $(divider).outerHeight(true),
|
777 |
-
// fall back to jQuery if getComputedStyle is not supported
|
778 |
-
menuStyle = typeof getComputedStyle === 'function' ? getComputedStyle(menu) : false,
|
779 |
-
$menu = menuStyle ? null : $(menu),
|
780 |
-
menuPadding = parseInt(menuStyle ? menuStyle.paddingTop : $menu.css('paddingTop')) +
|
781 |
-
parseInt(menuStyle ? menuStyle.paddingBottom : $menu.css('paddingBottom')) +
|
782 |
-
parseInt(menuStyle ? menuStyle.borderTopWidth : $menu.css('borderTopWidth')) +
|
783 |
-
parseInt(menuStyle ? menuStyle.borderBottomWidth : $menu.css('borderBottomWidth')),
|
784 |
-
menuExtras = menuPadding +
|
785 |
-
parseInt(menuStyle ? menuStyle.marginTop : $menu.css('marginTop')) +
|
786 |
-
parseInt(menuStyle ? menuStyle.marginBottom : $menu.css('marginBottom')) + 2;
|
787 |
-
|
788 |
-
document.body.removeChild(newElement);
|
789 |
-
|
790 |
-
this.sizeInfo = {
|
791 |
-
liHeight: liHeight,
|
792 |
-
headerHeight: headerHeight,
|
793 |
-
searchHeight: searchHeight,
|
794 |
-
actionsHeight: actionsHeight,
|
795 |
-
doneButtonHeight: doneButtonHeight,
|
796 |
-
dividerHeight: dividerHeight,
|
797 |
-
menuPadding: menuPadding,
|
798 |
-
menuExtras: menuExtras
|
799 |
-
};
|
800 |
-
},
|
801 |
-
|
802 |
-
setSize: function () {
|
803 |
-
this.findLis();
|
804 |
-
this.liHeight();
|
805 |
-
|
806 |
-
if (this.options.header) this.$menu.css('padding-top', 0);
|
807 |
-
if (this.options.size === false) return;
|
808 |
-
|
809 |
-
var that = this,
|
810 |
-
$menu = this.$menu,
|
811 |
-
$menuInner = this.$menuInner,
|
812 |
-
$window = $(window),
|
813 |
-
selectHeight = this.$newElement[0].offsetHeight,
|
814 |
-
liHeight = this.sizeInfo['liHeight'],
|
815 |
-
headerHeight = this.sizeInfo['headerHeight'],
|
816 |
-
searchHeight = this.sizeInfo['searchHeight'],
|
817 |
-
actionsHeight = this.sizeInfo['actionsHeight'],
|
818 |
-
doneButtonHeight = this.sizeInfo['doneButtonHeight'],
|
819 |
-
divHeight = this.sizeInfo['dividerHeight'],
|
820 |
-
menuPadding = this.sizeInfo['menuPadding'],
|
821 |
-
menuExtras = this.sizeInfo['menuExtras'],
|
822 |
-
notDisabled = this.options.hideDisabled ? '.disabled' : '',
|
823 |
-
menuHeight,
|
824 |
-
getHeight,
|
825 |
-
selectOffsetTop,
|
826 |
-
selectOffsetBot,
|
827 |
-
posVert = function () {
|
828 |
-
selectOffsetTop = that.$newElement.offset().top - $window.scrollTop();
|
829 |
-
selectOffsetBot = $window.height() - selectOffsetTop - selectHeight;
|
830 |
-
};
|
831 |
-
|
832 |
-
posVert();
|
833 |
-
|
834 |
-
if (this.options.size === 'auto') {
|
835 |
-
var getSize = function () {
|
836 |
-
var minHeight,
|
837 |
-
hasClass = function (className, include) {
|
838 |
-
return function (element) {
|
839 |
-
if (include) {
|
840 |
-
return (element.classList ? element.classList.contains(className) : $(element).hasClass(className));
|
841 |
-
} else {
|
842 |
-
return !(element.classList ? element.classList.contains(className) : $(element).hasClass(className));
|
843 |
-
}
|
844 |
-
};
|
845 |
-
},
|
846 |
-
lis = that.$menuInner[0].getElementsByTagName('li'),
|
847 |
-
lisVisible = Array.prototype.filter ? Array.prototype.filter.call(lis, hasClass('hidden', false)) : that.$lis.not('.hidden'),
|
848 |
-
optGroup = Array.prototype.filter ? Array.prototype.filter.call(lisVisible, hasClass('dropdown-header', true)) : lisVisible.filter('.dropdown-header');
|
849 |
-
|
850 |
-
posVert();
|
851 |
-
menuHeight = selectOffsetBot - menuExtras;
|
852 |
-
|
853 |
-
if (that.options.container) {
|
854 |
-
if (!$menu.data('height')) $menu.data('height', $menu.height());
|
855 |
-
getHeight = $menu.data('height');
|
856 |
-
} else {
|
857 |
-
getHeight = $menu.height();
|
858 |
-
}
|
859 |
-
|
860 |
-
if (that.options.dropupAuto) {
|
861 |
-
that.$newElement.toggleClass('dropup', selectOffsetTop > selectOffsetBot && (menuHeight - menuExtras) < getHeight);
|
862 |
-
}
|
863 |
-
if (that.$newElement.hasClass('dropup')) {
|
864 |
-
menuHeight = selectOffsetTop - menuExtras;
|
865 |
-
}
|
866 |
-
|
867 |
-
if ((lisVisible.length + optGroup.length) > 3) {
|
868 |
-
minHeight = liHeight * 3 + menuExtras - 2;
|
869 |
-
} else {
|
870 |
-
minHeight = 0;
|
871 |
-
}
|
872 |
-
|
873 |
-
$menu.css({
|
874 |
-
'max-height': menuHeight + 'px',
|
875 |
-
'overflow': 'hidden',
|
876 |
-
'min-height': minHeight + headerHeight + searchHeight + actionsHeight + doneButtonHeight + 'px'
|
877 |
-
});
|
878 |
-
$menuInner.css({
|
879 |
-
'max-height': menuHeight - headerHeight - searchHeight - actionsHeight - doneButtonHeight - menuPadding + 'px',
|
880 |
-
'overflow-y': 'auto',
|
881 |
-
'min-height': Math.max(minHeight - menuPadding, 0) + 'px'
|
882 |
-
});
|
883 |
-
};
|
884 |
-
getSize();
|
885 |
-
this.$searchbox.off('input.getSize propertychange.getSize').on('input.getSize propertychange.getSize', getSize);
|
886 |
-
$window.off('resize.getSize scroll.getSize').on('resize.getSize scroll.getSize', getSize);
|
887 |
-
} else if (this.options.size && this.options.size != 'auto' && this.$lis.not(notDisabled).length > this.options.size) {
|
888 |
-
var optIndex = this.$lis.not('.divider').not(notDisabled).children().slice(0, this.options.size).last().parent().index(),
|
889 |
-
divLength = this.$lis.slice(0, optIndex + 1).filter('.divider').length;
|
890 |
-
menuHeight = liHeight * this.options.size + divLength * divHeight + menuPadding;
|
891 |
-
|
892 |
-
if (that.options.container) {
|
893 |
-
if (!$menu.data('height')) $menu.data('height', $menu.height());
|
894 |
-
getHeight = $menu.data('height');
|
895 |
-
} else {
|
896 |
-
getHeight = $menu.height();
|
897 |
-
}
|
898 |
-
|
899 |
-
if (that.options.dropupAuto) {
|
900 |
-
//noinspection JSUnusedAssignment
|
901 |
-
this.$newElement.toggleClass('dropup', selectOffsetTop > selectOffsetBot && (menuHeight - menuExtras) < getHeight);
|
902 |
-
}
|
903 |
-
$menu.css({
|
904 |
-
'max-height': menuHeight + headerHeight + searchHeight + actionsHeight + doneButtonHeight + 'px',
|
905 |
-
'overflow': 'hidden',
|
906 |
-
'min-height': ''
|
907 |
-
});
|
908 |
-
$menuInner.css({
|
909 |
-
'max-height': menuHeight - menuPadding + 'px',
|
910 |
-
'overflow-y': 'auto',
|
911 |
-
'min-height': ''
|
912 |
-
});
|
913 |
-
}
|
914 |
-
},
|
915 |
-
|
916 |
-
setWidth: function () {
|
917 |
-
if (this.options.width === 'auto') {
|
918 |
-
this.$menu.css('min-width', '0');
|
919 |
-
|
920 |
-
// Get correct width if element is hidden
|
921 |
-
var $selectClone = this.$menu.parent().clone().appendTo('body'),
|
922 |
-
$selectClone2 = this.options.container ? this.$newElement.clone().appendTo('body') : $selectClone,
|
923 |
-
ulWidth = $selectClone.children('.dropdown-menu').outerWidth(),
|
924 |
-
btnWidth = $selectClone2.css('width', 'auto').children('button').outerWidth();
|
925 |
-
|
926 |
-
$selectClone.remove();
|
927 |
-
$selectClone2.remove();
|
928 |
-
|
929 |
-
// Set width to whatever's larger, button title or longest option
|
930 |
-
this.$newElement.css('width', Math.max(ulWidth, btnWidth) + 'px');
|
931 |
-
} else if (this.options.width === 'fit') {
|
932 |
-
// Remove inline min-width so width can be changed from 'auto'
|
933 |
-
this.$menu.css('min-width', '');
|
934 |
-
this.$newElement.css('width', '').addClass('fit-width');
|
935 |
-
} else if (this.options.width) {
|
936 |
-
// Remove inline min-width so width can be changed from 'auto'
|
937 |
-
this.$menu.css('min-width', '');
|
938 |
-
this.$newElement.css('width', this.options.width);
|
939 |
-
} else {
|
940 |
-
// Remove inline min-width/width so width can be changed
|
941 |
-
this.$menu.css('min-width', '');
|
942 |
-
this.$newElement.css('width', '');
|
943 |
-
}
|
944 |
-
// Remove fit-width class if width is changed programmatically
|
945 |
-
if (this.$newElement.hasClass('fit-width') && this.options.width !== 'fit') {
|
946 |
-
this.$newElement.removeClass('fit-width');
|
947 |
-
}
|
948 |
-
},
|
949 |
-
|
950 |
-
selectPosition: function () {
|
951 |
-
this.$bsContainer = $('<div class="bs-container" />');
|
952 |
-
|
953 |
-
var that = this,
|
954 |
-
pos,
|
955 |
-
actualHeight,
|
956 |
-
getPlacement = function ($element) {
|
957 |
-
that.$bsContainer.addClass($element.attr('class').replace(/form-control|fit-width/gi, '')).toggleClass('dropup', $element.hasClass('dropup'));
|
958 |
-
pos = $element.offset();
|
959 |
-
actualHeight = $element.hasClass('dropup') ? 0 : $element[0].offsetHeight;
|
960 |
-
that.$bsContainer.css({
|
961 |
-
'top': pos.top + actualHeight,
|
962 |
-
'left': pos.left,
|
963 |
-
'width': $element[0].offsetWidth
|
964 |
-
});
|
965 |
-
};
|
966 |
-
|
967 |
-
this.$button.on('click', function () {
|
968 |
-
var $this = $(this);
|
969 |
-
|
970 |
-
if (that.isDisabled()) {
|
971 |
-
return;
|
972 |
-
}
|
973 |
-
|
974 |
-
getPlacement(that.$newElement);
|
975 |
-
|
976 |
-
that.$bsContainer
|
977 |
-
.appendTo(that.options.container)
|
978 |
-
.toggleClass('open', !$this.hasClass('open'))
|
979 |
-
.append(that.$menu);
|
980 |
-
});
|
981 |
-
|
982 |
-
$(window).on('resize scroll', function () {
|
983 |
-
getPlacement(that.$newElement);
|
984 |
-
});
|
985 |
-
|
986 |
-
this.$element.on('hide.bs.select', function () {
|
987 |
-
that.$menu.data('height', that.$menu.height());
|
988 |
-
that.$bsContainer.detach();
|
989 |
-
});
|
990 |
-
},
|
991 |
-
|
992 |
-
setSelected: function (index, selected, $lis) {
|
993 |
-
if (!$lis) {
|
994 |
-
$lis = this.findLis().eq(this.liObj[index]);
|
995 |
-
}
|
996 |
-
|
997 |
-
$lis.toggleClass('selected', selected);
|
998 |
-
},
|
999 |
-
|
1000 |
-
setDisabled: function (index, disabled, $lis) {
|
1001 |
-
if (!$lis) {
|
1002 |
-
$lis = this.findLis().eq(this.liObj[index]);
|
1003 |
-
}
|
1004 |
-
|
1005 |
-
if (disabled) {
|
1006 |
-
$lis.addClass('disabled').children('a').attr('href', '#').attr('tabindex', -1);
|
1007 |
-
} else {
|
1008 |
-
$lis.removeClass('disabled').children('a').removeAttr('href').attr('tabindex', 0);
|
1009 |
-
}
|
1010 |
-
},
|
1011 |
-
|
1012 |
-
isDisabled: function () {
|
1013 |
-
return this.$element[0].disabled;
|
1014 |
-
},
|
1015 |
-
|
1016 |
-
checkDisabled: function () {
|
1017 |
-
var that = this;
|
1018 |
-
|
1019 |
-
if (this.isDisabled()) {
|
1020 |
-
this.$newElement.addClass('disabled');
|
1021 |
-
this.$button.addClass('disabled').attr('tabindex', -1);
|
1022 |
-
} else {
|
1023 |
-
if (this.$button.hasClass('disabled')) {
|
1024 |
-
this.$newElement.removeClass('disabled');
|
1025 |
-
this.$button.removeClass('disabled');
|
1026 |
-
}
|
1027 |
-
|
1028 |
-
if (this.$button.attr('tabindex') == -1 && !this.$element.data('tabindex')) {
|
1029 |
-
this.$button.removeAttr('tabindex');
|
1030 |
-
}
|
1031 |
-
}
|
1032 |
-
|
1033 |
-
this.$button.click(function () {
|
1034 |
-
return !that.isDisabled();
|
1035 |
-
});
|
1036 |
-
},
|
1037 |
-
|
1038 |
-
tabIndex: function () {
|
1039 |
-
if (this.$element.data('tabindex') !== this.$element.attr('tabindex') &&
|
1040 |
-
(this.$element.attr('tabindex') !== -98 && this.$element.attr('tabindex') !== '-98')) {
|
1041 |
-
this.$element.data('tabindex', this.$element.attr('tabindex'));
|
1042 |
-
this.$button.attr('tabindex', this.$element.data('tabindex'));
|
1043 |
-
}
|
1044 |
-
|
1045 |
-
this.$element.attr('tabindex', -98);
|
1046 |
-
},
|
1047 |
-
|
1048 |
-
clickListener: function () {
|
1049 |
-
var that = this,
|
1050 |
-
$document = $(document);
|
1051 |
-
|
1052 |
-
this.$newElement.on('touchstart.dropdown', '.dropdown-menu', function (e) {
|
1053 |
-
e.stopPropagation();
|
1054 |
-
});
|
1055 |
-
|
1056 |
-
$document.data('spaceSelect', false);
|
1057 |
-
|
1058 |
-
this.$button.on('keyup', function (e) {
|
1059 |
-
if (/(32)/.test(e.keyCode.toString(10)) && $document.data('spaceSelect')) {
|
1060 |
-
e.preventDefault();
|
1061 |
-
$document.data('spaceSelect', false);
|
1062 |
-
}
|
1063 |
-
});
|
1064 |
-
|
1065 |
-
this.$button.on('click', function () {
|
1066 |
-
that.setSize();
|
1067 |
-
});
|
1068 |
-
|
1069 |
-
this.$element.on('shown.bs.select', function () {
|
1070 |
-
if (!that.options.liveSearch && !that.multiple) {
|
1071 |
-
that.$menuInner.find('.selected a').focus();
|
1072 |
-
} else if (!that.multiple) {
|
1073 |
-
var selectedIndex = that.liObj[that.$element[0].selectedIndex];
|
1074 |
-
|
1075 |
-
if (typeof selectedIndex !== 'number' || that.options.size === false) return;
|
1076 |
-
|
1077 |
-
// scroll to selected option
|
1078 |
-
var offset = that.$lis.eq(selectedIndex)[0].offsetTop - that.$menuInner[0].offsetTop;
|
1079 |
-
offset = offset - that.$menuInner[0].offsetHeight/2 + that.sizeInfo.liHeight/2;
|
1080 |
-
that.$menuInner[0].scrollTop = offset;
|
1081 |
-
}
|
1082 |
-
});
|
1083 |
-
|
1084 |
-
this.$menuInner.on('click', 'li a', function (e) {
|
1085 |
-
var $this = $(this),
|
1086 |
-
clickedIndex = $this.parent().data('originalIndex'),
|
1087 |
-
prevValue = that.$element.val(),
|
1088 |
-
prevIndex = that.$element.prop('selectedIndex');
|
1089 |
-
|
1090 |
-
// Don't close on multi choice menu
|
1091 |
-
if (that.multiple) {
|
1092 |
-
e.stopPropagation();
|
1093 |
-
}
|
1094 |
-
|
1095 |
-
e.preventDefault();
|
1096 |
-
|
1097 |
-
//Don't run if we have been disabled
|
1098 |
-
if (!that.isDisabled() && !$this.parent().hasClass('disabled')) {
|
1099 |
-
var $options = that.$element.find('option'),
|
1100 |
-
$option = $options.eq(clickedIndex),
|
1101 |
-
state = $option.prop('selected'),
|
1102 |
-
$optgroup = $option.parent('optgroup'),
|
1103 |
-
maxOptions = that.options.maxOptions,
|
1104 |
-
maxOptionsGrp = $optgroup.data('maxOptions') || false;
|
1105 |
-
|
1106 |
-
if (!that.multiple) { // Deselect all others if not multi select box
|
1107 |
-
$options.prop('selected', false);
|
1108 |
-
$option.prop('selected', true);
|
1109 |
-
that.$menuInner.find('.selected').removeClass('selected');
|
1110 |
-
that.setSelected(clickedIndex, true);
|
1111 |
-
} else { // Toggle the one we have chosen if we are multi select.
|
1112 |
-
$option.prop('selected', !state);
|
1113 |
-
that.setSelected(clickedIndex, !state);
|
1114 |
-
$this.blur();
|
1115 |
-
|
1116 |
-
if (maxOptions !== false || maxOptionsGrp !== false) {
|
1117 |
-
var maxReached = maxOptions < $options.filter(':selected').length,
|
1118 |
-
maxReachedGrp = maxOptionsGrp < $optgroup.find('option:selected').length;
|
1119 |
-
|
1120 |
-
if ((maxOptions && maxReached) || (maxOptionsGrp && maxReachedGrp)) {
|
1121 |
-
if (maxOptions && maxOptions == 1) {
|
1122 |
-
$options.prop('selected', false);
|
1123 |
-
$option.prop('selected', true);
|
1124 |
-
that.$menuInner.find('.selected').removeClass('selected');
|
1125 |
-
that.setSelected(clickedIndex, true);
|
1126 |
-
} else if (maxOptionsGrp && maxOptionsGrp == 1) {
|
1127 |
-
$optgroup.find('option:selected').prop('selected', false);
|
1128 |
-
$option.prop('selected', true);
|
1129 |
-
var optgroupID = $this.parent().data('optgroup');
|
1130 |
-
that.$menuInner.find('[data-optgroup="' + optgroupID + '"]').removeClass('selected');
|
1131 |
-
that.setSelected(clickedIndex, true);
|
1132 |
-
} else {
|
1133 |
-
var maxOptionsArr = (typeof that.options.maxOptionsText === 'function') ?
|
1134 |
-
that.options.maxOptionsText(maxOptions, maxOptionsGrp) : that.options.maxOptionsText,
|
1135 |
-
maxTxt = maxOptionsArr[0].replace('{n}', maxOptions),
|
1136 |
-
maxTxtGrp = maxOptionsArr[1].replace('{n}', maxOptionsGrp),
|
1137 |
-
$notify = $('<div class="notify"></div>');
|
1138 |
-
// If {var} is set in array, replace it
|
1139 |
-
/** @deprecated */
|
1140 |
-
if (maxOptionsArr[2]) {
|
1141 |
-
maxTxt = maxTxt.replace('{var}', maxOptionsArr[2][maxOptions > 1 ? 0 : 1]);
|
1142 |
-
maxTxtGrp = maxTxtGrp.replace('{var}', maxOptionsArr[2][maxOptionsGrp > 1 ? 0 : 1]);
|
1143 |
-
}
|
1144 |
-
|
1145 |
-
$option.prop('selected', false);
|
1146 |
-
|
1147 |
-
that.$menu.append($notify);
|
1148 |
-
|
1149 |
-
if (maxOptions && maxReached) {
|
1150 |
-
$notify.append($('<div>' + maxTxt + '</div>'));
|
1151 |
-
that.$element.trigger('maxReached.bs.select');
|
1152 |
-
}
|
1153 |
-
|
1154 |
-
if (maxOptionsGrp && maxReachedGrp) {
|
1155 |
-
$notify.append($('<div>' + maxTxtGrp + '</div>'));
|
1156 |
-
that.$element.trigger('maxReachedGrp.bs.select');
|
1157 |
-
}
|
1158 |
-
|
1159 |
-
setTimeout(function () {
|
1160 |
-
that.setSelected(clickedIndex, false);
|
1161 |
-
}, 10);
|
1162 |
-
|
1163 |
-
$notify.delay(750).fadeOut(300, function () {
|
1164 |
-
$(this).remove();
|
1165 |
-
});
|
1166 |
-
}
|
1167 |
-
}
|
1168 |
-
}
|
1169 |
-
}
|
1170 |
-
|
1171 |
-
if (!that.multiple) {
|
1172 |
-
that.$button.focus();
|
1173 |
-
} else if (that.options.liveSearch) {
|
1174 |
-
that.$searchbox.focus();
|
1175 |
-
}
|
1176 |
-
|
1177 |
-
// Trigger select 'change'
|
1178 |
-
if ((prevValue != that.$element.val() && that.multiple) || (prevIndex != that.$element.prop('selectedIndex') && !that.multiple)) {
|
1179 |
-
// $option.prop('selected') is current option state (selected/unselected). state is previous option state.
|
1180 |
-
that.$element
|
1181 |
-
.trigger('changed.bs.select', [clickedIndex, $option.prop('selected'), state])
|
1182 |
-
.triggerNative('change');
|
1183 |
-
}
|
1184 |
-
}
|
1185 |
-
});
|
1186 |
-
|
1187 |
-
this.$menu.on('click', 'li.disabled a, .popover-title, .popover-title :not(.close)', function (e) {
|
1188 |
-
if (e.currentTarget == this) {
|
1189 |
-
e.preventDefault();
|
1190 |
-
e.stopPropagation();
|
1191 |
-
if (that.options.liveSearch && !$(e.target).hasClass('close')) {
|
1192 |
-
that.$searchbox.focus();
|
1193 |
-
} else {
|
1194 |
-
that.$button.focus();
|
1195 |
-
}
|
1196 |
-
}
|
1197 |
-
});
|
1198 |
-
|
1199 |
-
this.$menuInner.on('click', '.divider, .dropdown-header', function (e) {
|
1200 |
-
e.preventDefault();
|
1201 |
-
e.stopPropagation();
|
1202 |
-
if (that.options.liveSearch) {
|
1203 |
-
that.$searchbox.focus();
|
1204 |
-
} else {
|
1205 |
-
that.$button.focus();
|
1206 |
-
}
|
1207 |
-
});
|
1208 |
-
|
1209 |
-
this.$menu.on('click', '.popover-title .close', function () {
|
1210 |
-
that.$button.click();
|
1211 |
-
});
|
1212 |
-
|
1213 |
-
this.$searchbox.on('click', function (e) {
|
1214 |
-
e.stopPropagation();
|
1215 |
-
});
|
1216 |
-
|
1217 |
-
this.$menu.on('click', '.actions-btn', function (e) {
|
1218 |
-
if (that.options.liveSearch) {
|
1219 |
-
that.$searchbox.focus();
|
1220 |
-
} else {
|
1221 |
-
that.$button.focus();
|
1222 |
-
}
|
1223 |
-
|
1224 |
-
e.preventDefault();
|
1225 |
-
e.stopPropagation();
|
1226 |
-
|
1227 |
-
if ($(this).hasClass('bs-select-all')) {
|
1228 |
-
that.selectAll();
|
1229 |
-
} else {
|
1230 |
-
that.deselectAll();
|
1231 |
-
}
|
1232 |
-
});
|
1233 |
-
|
1234 |
-
this.$element.change(function () {
|
1235 |
-
that.render(false);
|
1236 |
-
});
|
1237 |
-
},
|
1238 |
-
|
1239 |
-
liveSearchListener: function () {
|
1240 |
-
var that = this,
|
1241 |
-
$no_results = $('<li class="no-results"></li>');
|
1242 |
-
|
1243 |
-
this.$button.on('click.dropdown.data-api touchstart.dropdown.data-api', function () {
|
1244 |
-
that.$menuInner.find('.active').removeClass('active');
|
1245 |
-
if (!!that.$searchbox.val()) {
|
1246 |
-
that.$searchbox.val('');
|
1247 |
-
that.$lis.not('.is-hidden').removeClass('hidden');
|
1248 |
-
if (!!$no_results.parent().length) $no_results.remove();
|
1249 |
-
}
|
1250 |
-
if (!that.multiple) that.$menuInner.find('.selected').addClass('active');
|
1251 |
-
setTimeout(function () {
|
1252 |
-
that.$searchbox.focus();
|
1253 |
-
}, 10);
|
1254 |
-
});
|
1255 |
-
|
1256 |
-
this.$searchbox.on('click.dropdown.data-api focus.dropdown.data-api touchend.dropdown.data-api', function (e) {
|
1257 |
-
e.stopPropagation();
|
1258 |
-
});
|
1259 |
-
|
1260 |
-
this.$searchbox.on('input propertychange', function () {
|
1261 |
-
if (that.$searchbox.val()) {
|
1262 |
-
var $searchBase = that.$lis.not('.is-hidden').removeClass('hidden').children('a');
|
1263 |
-
if (that.options.liveSearchNormalize) {
|
1264 |
-
$searchBase = $searchBase.not(':a' + that._searchStyle() + '("' + normalizeToBase(that.$searchbox.val()) + '")');
|
1265 |
-
} else {
|
1266 |
-
$searchBase = $searchBase.not(':' + that._searchStyle() + '("' + that.$searchbox.val() + '")');
|
1267 |
-
}
|
1268 |
-
$searchBase.parent().addClass('hidden');
|
1269 |
-
|
1270 |
-
that.$lis.filter('.dropdown-header').each(function () {
|
1271 |
-
var $this = $(this),
|
1272 |
-
optgroup = $this.data('optgroup');
|
1273 |
-
|
1274 |
-
if (that.$lis.filter('[data-optgroup=' + optgroup + ']').not($this).not('.hidden').length === 0) {
|
1275 |
-
$this.addClass('hidden');
|
1276 |
-
that.$lis.filter('[data-optgroup=' + optgroup + 'div]').addClass('hidden');
|
1277 |
-
}
|
1278 |
-
});
|
1279 |
-
|
1280 |
-
var $lisVisible = that.$lis.not('.hidden');
|
1281 |
-
|
1282 |
-
// hide divider if first or last visible, or if followed by another divider
|
1283 |
-
$lisVisible.each(function (index) {
|
1284 |
-
var $this = $(this);
|
1285 |
-
|
1286 |
-
if ($this.hasClass('divider') && (
|
1287 |
-
$this.index() === $lisVisible.first().index() ||
|
1288 |
-
$this.index() === $lisVisible.last().index() ||
|
1289 |
-
$lisVisible.eq(index + 1).hasClass('divider'))) {
|
1290 |
-
$this.addClass('hidden');
|
1291 |
-
}
|
1292 |
-
});
|
1293 |
-
|
1294 |
-
if (!that.$lis.not('.hidden, .no-results').length) {
|
1295 |
-
if (!!$no_results.parent().length) {
|
1296 |
-
$no_results.remove();
|
1297 |
-
}
|
1298 |
-
$no_results.html(that.options.noneResultsText.replace('{0}', '"' + htmlEscape(that.$searchbox.val()) + '"')).show();
|
1299 |
-
that.$menuInner.append($no_results);
|
1300 |
-
} else if (!!$no_results.parent().length) {
|
1301 |
-
$no_results.remove();
|
1302 |
-
}
|
1303 |
-
} else {
|
1304 |
-
that.$lis.not('.is-hidden').removeClass('hidden');
|
1305 |
-
if (!!$no_results.parent().length) {
|
1306 |
-
$no_results.remove();
|
1307 |
-
}
|
1308 |
-
}
|
1309 |
-
|
1310 |
-
that.$lis.filter('.active').removeClass('active');
|
1311 |
-
if (that.$searchbox.val()) that.$lis.not('.hidden, .divider, .dropdown-header').eq(0).addClass('active').children('a').focus();
|
1312 |
-
$(this).focus();
|
1313 |
-
});
|
1314 |
-
},
|
1315 |
-
|
1316 |
-
_searchStyle: function () {
|
1317 |
-
var styles = {
|
1318 |
-
begins: 'ibegins',
|
1319 |
-
startsWith: 'ibegins'
|
1320 |
-
};
|
1321 |
-
|
1322 |
-
return styles[this.options.liveSearchStyle] || 'icontains';
|
1323 |
-
},
|
1324 |
-
|
1325 |
-
val: function (value) {
|
1326 |
-
if (typeof value !== 'undefined') {
|
1327 |
-
this.$element.val(value);
|
1328 |
-
this.render();
|
1329 |
-
|
1330 |
-
return this.$element;
|
1331 |
-
} else {
|
1332 |
-
return this.$element.val();
|
1333 |
-
}
|
1334 |
-
},
|
1335 |
-
|
1336 |
-
changeAll: function (status) {
|
1337 |
-
if (typeof status === 'undefined') status = true;
|
1338 |
-
|
1339 |
-
this.findLis();
|
1340 |
-
|
1341 |
-
var $options = this.$element.find('option'),
|
1342 |
-
$lisVisible = this.$lis.not('.divider, .dropdown-header, .disabled, .hidden').toggleClass('selected', status),
|
1343 |
-
lisVisLen = $lisVisible.length,
|
1344 |
-
selectedOptions = [];
|
1345 |
-
|
1346 |
-
for (var i = 0; i < lisVisLen; i++) {
|
1347 |
-
var origIndex = $lisVisible[i].getAttribute('data-original-index');
|
1348 |
-
selectedOptions[selectedOptions.length] = $options.eq(origIndex)[0];
|
1349 |
-
}
|
1350 |
-
|
1351 |
-
$(selectedOptions).prop('selected', status);
|
1352 |
-
|
1353 |
-
this.render(false);
|
1354 |
-
|
1355 |
-
this.$element
|
1356 |
-
.trigger('changed.bs.select')
|
1357 |
-
.triggerNative('change');
|
1358 |
-
},
|
1359 |
-
|
1360 |
-
selectAll: function () {
|
1361 |
-
return this.changeAll(true);
|
1362 |
-
},
|
1363 |
-
|
1364 |
-
deselectAll: function () {
|
1365 |
-
return this.changeAll(false);
|
1366 |
-
},
|
1367 |
-
|
1368 |
-
toggle: function (e) {
|
1369 |
-
e = e || window.event;
|
1370 |
-
|
1371 |
-
if (e) e.stopPropagation();
|
1372 |
-
|
1373 |
-
this.$button.trigger('click');
|
1374 |
-
},
|
1375 |
-
|
1376 |
-
keydown: function (e) {
|
1377 |
-
var $this = $(this),
|
1378 |
-
$parent = $this.is('input') ? $this.parent().parent() : $this.parent(),
|
1379 |
-
$items,
|
1380 |
-
that = $parent.data('this'),
|
1381 |
-
index,
|
1382 |
-
next,
|
1383 |
-
first,
|
1384 |
-
last,
|
1385 |
-
prev,
|
1386 |
-
nextPrev,
|
1387 |
-
prevIndex,
|
1388 |
-
isActive,
|
1389 |
-
selector = ':not(.disabled, .hidden, .dropdown-header, .divider)',
|
1390 |
-
keyCodeMap = {
|
1391 |
-
32: ' ',
|
1392 |
-
48: '0',
|
1393 |
-
49: '1',
|
1394 |
-
50: '2',
|
1395 |
-
51: '3',
|
1396 |
-
52: '4',
|
1397 |
-
53: '5',
|
1398 |
-
54: '6',
|
1399 |
-
55: '7',
|
1400 |
-
56: '8',
|
1401 |
-
57: '9',
|
1402 |
-
59: ';',
|
1403 |
-
65: 'a',
|
1404 |
-
66: 'b',
|
1405 |
-
67: 'c',
|
1406 |
-
68: 'd',
|
1407 |
-
69: 'e',
|
1408 |
-
70: 'f',
|
1409 |
-
71: 'g',
|
1410 |
-
72: 'h',
|
1411 |
-
73: 'i',
|
1412 |
-
74: 'j',
|
1413 |
-
75: 'k',
|
1414 |
-
76: 'l',
|
1415 |
-
77: 'm',
|
1416 |
-
78: 'n',
|
1417 |
-
79: 'o',
|
1418 |
-
80: 'p',
|
1419 |
-
81: 'q',
|
1420 |
-
82: 'r',
|
1421 |
-
83: 's',
|
1422 |
-
84: 't',
|
1423 |
-
85: 'u',
|
1424 |
-
86: 'v',
|
1425 |
-
87: 'w',
|
1426 |
-
88: 'x',
|
1427 |
-
89: 'y',
|
1428 |
-
90: 'z',
|
1429 |
-
96: '0',
|
1430 |
-
97: '1',
|
1431 |
-
98: '2',
|
1432 |
-
99: '3',
|
1433 |
-
100: '4',
|
1434 |
-
101: '5',
|
1435 |
-
102: '6',
|
1436 |
-
103: '7',
|
1437 |
-
104: '8',
|
1438 |
-
105: '9'
|
1439 |
-
};
|
1440 |
-
|
1441 |
-
if (that.options.liveSearch) $parent = $this.parent().parent();
|
1442 |
-
|
1443 |
-
if (that.options.container) $parent = that.$menu;
|
1444 |
-
|
1445 |
-
$items = $('[role=menu] li', $parent);
|
1446 |
-
|
1447 |
-
isActive = that.$newElement.hasClass('open');
|
1448 |
-
|
1449 |
-
if (!isActive && (e.keyCode >= 48 && e.keyCode <= 57 || e.keyCode >= 96 && e.keyCode <= 105 || e.keyCode >= 65 && e.keyCode <= 90)) {
|
1450 |
-
if (!that.options.container) {
|
1451 |
-
that.setSize();
|
1452 |
-
that.$menu.parent().addClass('open');
|
1453 |
-
isActive = true;
|
1454 |
-
} else {
|
1455 |
-
that.$button.trigger('click');
|
1456 |
-
}
|
1457 |
-
that.$searchbox.focus();
|
1458 |
-
}
|
1459 |
-
|
1460 |
-
if (that.options.liveSearch) {
|
1461 |
-
if (/(^9$|27)/.test(e.keyCode.toString(10)) && isActive && that.$menu.find('.active').length === 0) {
|
1462 |
-
e.preventDefault();
|
1463 |
-
that.$menu.parent().removeClass('open');
|
1464 |
-
if (that.options.container) that.$newElement.removeClass('open');
|
1465 |
-
that.$button.focus();
|
1466 |
-
}
|
1467 |
-
// $items contains li elements when liveSearch is enabled
|
1468 |
-
$items = $('[role=menu] li' + selector, $parent);
|
1469 |
-
if (!$this.val() && !/(38|40)/.test(e.keyCode.toString(10))) {
|
1470 |
-
if ($items.filter('.active').length === 0) {
|
1471 |
-
$items = that.$menuInner.find('li');
|
1472 |
-
if (that.options.liveSearchNormalize) {
|
1473 |
-
$items = $items.filter(':a' + that._searchStyle() + '(' + normalizeToBase(keyCodeMap[e.keyCode]) + ')');
|
1474 |
-
} else {
|
1475 |
-
$items = $items.filter(':' + that._searchStyle() + '(' + keyCodeMap[e.keyCode] + ')');
|
1476 |
-
}
|
1477 |
-
}
|
1478 |
-
}
|
1479 |
-
}
|
1480 |
-
|
1481 |
-
if (!$items.length) return;
|
1482 |
-
|
1483 |
-
if (/(38|40)/.test(e.keyCode.toString(10))) {
|
1484 |
-
index = $items.index($items.find('a').filter(':focus').parent());
|
1485 |
-
first = $items.filter(selector).first().index();
|
1486 |
-
last = $items.filter(selector).last().index();
|
1487 |
-
next = $items.eq(index).nextAll(selector).eq(0).index();
|
1488 |
-
prev = $items.eq(index).prevAll(selector).eq(0).index();
|
1489 |
-
nextPrev = $items.eq(next).prevAll(selector).eq(0).index();
|
1490 |
-
|
1491 |
-
if (that.options.liveSearch) {
|
1492 |
-
$items.each(function (i) {
|
1493 |
-
if (!$(this).hasClass('disabled')) {
|
1494 |
-
$(this).data('index', i);
|
1495 |
-
}
|
1496 |
-
});
|
1497 |
-
index = $items.index($items.filter('.active'));
|
1498 |
-
first = $items.first().data('index');
|
1499 |
-
last = $items.last().data('index');
|
1500 |
-
next = $items.eq(index).nextAll().eq(0).data('index');
|
1501 |
-
prev = $items.eq(index).prevAll().eq(0).data('index');
|
1502 |
-
nextPrev = $items.eq(next).prevAll().eq(0).data('index');
|
1503 |
-
}
|
1504 |
-
|
1505 |
-
prevIndex = $this.data('prevIndex');
|
1506 |
-
|
1507 |
-
if (e.keyCode == 38) {
|
1508 |
-
if (that.options.liveSearch) index--;
|
1509 |
-
if (index != nextPrev && index > prev) index = prev;
|
1510 |
-
if (index < first) index = first;
|
1511 |
-
if (index == prevIndex) index = last;
|
1512 |
-
} else if (e.keyCode == 40) {
|
1513 |
-
if (that.options.liveSearch) index++;
|
1514 |
-
if (index == -1) index = 0;
|
1515 |
-
if (index != nextPrev && index < next) index = next;
|
1516 |
-
if (index > last) index = last;
|
1517 |
-
if (index == prevIndex) index = first;
|
1518 |
-
}
|
1519 |
-
|
1520 |
-
$this.data('prevIndex', index);
|
1521 |
-
|
1522 |
-
if (!that.options.liveSearch) {
|
1523 |
-
$items.eq(index).children('a').focus();
|
1524 |
-
} else {
|
1525 |
-
e.preventDefault();
|
1526 |
-
if (!$this.hasClass('dropdown-toggle')) {
|
1527 |
-
$items.removeClass('active').eq(index).addClass('active').children('a').focus();
|
1528 |
-
$this.focus();
|
1529 |
-
}
|
1530 |
-
}
|
1531 |
-
|
1532 |
-
} else if (!$this.is('input')) {
|
1533 |
-
var keyIndex = [],
|
1534 |
-
count,
|
1535 |
-
prevKey;
|
1536 |
-
|
1537 |
-
$items.each(function () {
|
1538 |
-
if (!$(this).hasClass('disabled')) {
|
1539 |
-
if ($.trim($(this).children('a').text().toLowerCase()).substring(0, 1) == keyCodeMap[e.keyCode]) {
|
1540 |
-
keyIndex.push($(this).index());
|
1541 |
-
}
|
1542 |
-
}
|
1543 |
-
});
|
1544 |
-
|
1545 |
-
count = $(document).data('keycount');
|
1546 |
-
count++;
|
1547 |
-
$(document).data('keycount', count);
|
1548 |
-
|
1549 |
-
prevKey = $.trim($(':focus').text().toLowerCase()).substring(0, 1);
|
1550 |
-
|
1551 |
-
if (prevKey != keyCodeMap[e.keyCode]) {
|
1552 |
-
count = 1;
|
1553 |
-
$(document).data('keycount', count);
|
1554 |
-
} else if (count >= keyIndex.length) {
|
1555 |
-
$(document).data('keycount', 0);
|
1556 |
-
if (count > keyIndex.length) count = 1;
|
1557 |
-
}
|
1558 |
-
|
1559 |
-
$items.eq(keyIndex[count - 1]).children('a').focus();
|
1560 |
-
}
|
1561 |
-
|
1562 |
-
// Select focused option if "Enter", "Spacebar" or "Tab" (when selectOnTab is true) are pressed inside the menu.
|
1563 |
-
if ((/(13|32)/.test(e.keyCode.toString(10)) || (/(^9$)/.test(e.keyCode.toString(10)) && that.options.selectOnTab)) && isActive) {
|
1564 |
-
if (!/(32)/.test(e.keyCode.toString(10))) e.preventDefault();
|
1565 |
-
if (!that.options.liveSearch) {
|
1566 |
-
var elem = $(':focus');
|
1567 |
-
elem.click();
|
1568 |
-
// Bring back focus for multiselects
|
1569 |
-
elem.focus();
|
1570 |
-
// Prevent screen from scrolling if the user hit the spacebar
|
1571 |
-
e.preventDefault();
|
1572 |
-
// Fixes spacebar selection of dropdown items in FF & IE
|
1573 |
-
$(document).data('spaceSelect', true);
|
1574 |
-
} else if (!/(32)/.test(e.keyCode.toString(10))) {
|
1575 |
-
that.$menuInner.find('.active a').click();
|
1576 |
-
$this.focus();
|
1577 |
-
}
|
1578 |
-
$(document).data('keycount', 0);
|
1579 |
-
}
|
1580 |
-
|
1581 |
-
if ((/(^9$|27)/.test(e.keyCode.toString(10)) && isActive && (that.multiple || that.options.liveSearch)) || (/(27)/.test(e.keyCode.toString(10)) && !isActive)) {
|
1582 |
-
that.$menu.parent().removeClass('open');
|
1583 |
-
if (that.options.container) that.$newElement.removeClass('open');
|
1584 |
-
that.$button.focus();
|
1585 |
-
}
|
1586 |
-
},
|
1587 |
-
|
1588 |
-
mobile: function () {
|
1589 |
-
this.$element.addClass('mobile-device');
|
1590 |
-
},
|
1591 |
-
|
1592 |
-
refresh: function () {
|
1593 |
-
this.$lis = null;
|
1594 |
-
this.liObj = {};
|
1595 |
-
this.reloadLi();
|
1596 |
-
this.render();
|
1597 |
-
this.checkDisabled();
|
1598 |
-
this.liHeight(true);
|
1599 |
-
this.setStyle();
|
1600 |
-
this.setWidth();
|
1601 |
-
if (this.$lis) this.$searchbox.trigger('propertychange');
|
1602 |
-
|
1603 |
-
this.$element.trigger('refreshed.bs.select');
|
1604 |
-
},
|
1605 |
-
|
1606 |
-
hide: function () {
|
1607 |
-
this.$newElement.hide();
|
1608 |
-
},
|
1609 |
-
|
1610 |
-
show: function () {
|
1611 |
-
this.$newElement.show();
|
1612 |
-
},
|
1613 |
-
|
1614 |
-
remove: function () {
|
1615 |
-
this.$newElement.remove();
|
1616 |
-
this.$element.remove();
|
1617 |
-
},
|
1618 |
-
|
1619 |
-
destroy: function () {
|
1620 |
-
this.$newElement.before(this.$element).remove();
|
1621 |
-
|
1622 |
-
if (this.$bsContainer) {
|
1623 |
-
this.$bsContainer.remove();
|
1624 |
-
} else {
|
1625 |
-
this.$menu.remove();
|
1626 |
-
}
|
1627 |
-
|
1628 |
-
this.$element
|
1629 |
-
.off('.bs.select')
|
1630 |
-
.removeData('selectpicker')
|
1631 |
-
.removeClass('bs-select-hidden selectpicker');
|
1632 |
-
}
|
1633 |
-
};
|
1634 |
-
|
1635 |
-
// SELECTPICKER PLUGIN DEFINITION
|
1636 |
-
// ==============================
|
1637 |
-
function Plugin(option, event) {
|
1638 |
-
// get the args of the outer function..
|
1639 |
-
var args = arguments;
|
1640 |
-
// The arguments of the function are explicitly re-defined from the argument list, because the shift causes them
|
1641 |
-
// to get lost/corrupted in android 2.3 and IE9 #715 #775
|
1642 |
-
var _option = option,
|
1643 |
-
_event = event;
|
1644 |
-
[].shift.apply(args);
|
1645 |
-
|
1646 |
-
var value;
|
1647 |
-
var chain = this.each(function () {
|
1648 |
-
var $this = $(this);
|
1649 |
-
if ($this.is('select')) {
|
1650 |
-
var data = $this.data('selectpicker'),
|
1651 |
-
options = typeof _option == 'object' && _option;
|
1652 |
-
|
1653 |
-
if (!data) {
|
1654 |
-
var config = $.extend({}, Selectpicker.DEFAULTS, $.fn.selectpicker.defaults || {}, $this.data(), options);
|
1655 |
-
config.template = $.extend({}, Selectpicker.DEFAULTS.template, ($.fn.selectpicker.defaults ? $.fn.selectpicker.defaults.template : {}), $this.data().template, options.template);
|
1656 |
-
$this.data('selectpicker', (data = new Selectpicker(this, config, _event)));
|
1657 |
-
} else if (options) {
|
1658 |
-
for (var i in options) {
|
1659 |
-
if (options.hasOwnProperty(i)) {
|
1660 |
-
data.options[i] = options[i];
|
1661 |
-
}
|
1662 |
-
}
|
1663 |
-
}
|
1664 |
-
|
1665 |
-
if (typeof _option == 'string') {
|
1666 |
-
if (data[_option] instanceof Function) {
|
1667 |
-
value = data[_option].apply(data, args);
|
1668 |
-
} else {
|
1669 |
-
value = data.options[_option];
|
1670 |
-
}
|
1671 |
-
}
|
1672 |
-
}
|
1673 |
-
});
|
1674 |
-
|
1675 |
-
if (typeof value !== 'undefined') {
|
1676 |
-
//noinspection JSUnusedAssignment
|
1677 |
-
return value;
|
1678 |
-
} else {
|
1679 |
-
return chain;
|
1680 |
-
}
|
1681 |
-
}
|
1682 |
-
|
1683 |
-
var old = $.fn.selectpicker;
|
1684 |
-
$.fn.selectpicker = Plugin;
|
1685 |
-
$.fn.selectpicker.Constructor = Selectpicker;
|
1686 |
-
|
1687 |
-
// SELECTPICKER NO CONFLICT
|
1688 |
-
// ========================
|
1689 |
-
$.fn.selectpicker.noConflict = function () {
|
1690 |
-
$.fn.selectpicker = old;
|
1691 |
-
return this;
|
1692 |
-
};
|
1693 |
-
|
1694 |
-
$(document)
|
1695 |
-
.data('keycount', 0)
|
1696 |
-
.on('keydown.bs.select', '.bootstrap-select [data-toggle=dropdown], .bootstrap-select [role="menu"], .bs-searchbox input', Selectpicker.prototype.keydown)
|
1697 |
-
.on('focusin.modal', '.bootstrap-select [data-toggle=dropdown], .bootstrap-select [role="menu"], .bs-searchbox input', function (e) {
|
1698 |
-
e.stopPropagation();
|
1699 |
-
});
|
1700 |
-
|
1701 |
-
// SELECTPICKER DATA-API
|
1702 |
-
// =====================
|
1703 |
-
$(window).on('load.bs.select.data-api', function () {
|
1704 |
-
$('.selectpicker').each(function () {
|
1705 |
-
var $selectpicker = $(this);
|
1706 |
-
Plugin.call($selectpicker, $selectpicker.data());
|
1707 |
-
})
|
1708 |
-
});
|
1709 |
-
})(jQuery);
|
1 |
+
(function ($) {
|
2 |
+
'use strict';
|
3 |
+
|
4 |
+
//<editor-fold desc="Shims">
|
5 |
+
if (!String.prototype.includes) {
|
6 |
+
(function () {
|
7 |
+
'use strict'; // needed to support `apply`/`call` with `undefined`/`null`
|
8 |
+
var toString = {}.toString;
|
9 |
+
var defineProperty = (function () {
|
10 |
+
// IE 8 only supports `Object.defineProperty` on DOM elements
|
11 |
+
try {
|
12 |
+
var object = {};
|
13 |
+
var $defineProperty = Object.defineProperty;
|
14 |
+
var result = $defineProperty(object, object, object) && $defineProperty;
|
15 |
+
} catch (error) {
|
16 |
+
}
|
17 |
+
return result;
|
18 |
+
}());
|
19 |
+
var indexOf = ''.indexOf;
|
20 |
+
var includes = function (search) {
|
21 |
+
if (this == null) {
|
22 |
+
throw new TypeError();
|
23 |
+
}
|
24 |
+
var string = String(this);
|
25 |
+
if (search && toString.call(search) == '[object RegExp]') {
|
26 |
+
throw new TypeError();
|
27 |
+
}
|
28 |
+
var stringLength = string.length;
|
29 |
+
var searchString = String(search);
|
30 |
+
var searchLength = searchString.length;
|
31 |
+
var position = arguments.length > 1 ? arguments[1] : undefined;
|
32 |
+
// `ToInteger`
|
33 |
+
var pos = position ? Number(position) : 0;
|
34 |
+
if (pos != pos) { // better `isNaN`
|
35 |
+
pos = 0;
|
36 |
+
}
|
37 |
+
var start = Math.min(Math.max(pos, 0), stringLength);
|
38 |
+
// Avoid the `indexOf` call if no match is possible
|
39 |
+
if (searchLength + start > stringLength) {
|
40 |
+
return false;
|
41 |
+
}
|
42 |
+
return indexOf.call(string, searchString, pos) != -1;
|
43 |
+
};
|
44 |
+
if (defineProperty) {
|
45 |
+
defineProperty(String.prototype, 'includes', {
|
46 |
+
'value': includes,
|
47 |
+
'configurable': true,
|
48 |
+
'writable': true
|
49 |
+
});
|
50 |
+
} else {
|
51 |
+
String.prototype.includes = includes;
|
52 |
+
}
|
53 |
+
}());
|
54 |
+
}
|
55 |
+
|
56 |
+
if (!String.prototype.startsWith) {
|
57 |
+
(function () {
|
58 |
+
'use strict'; // needed to support `apply`/`call` with `undefined`/`null`
|
59 |
+
var defineProperty = (function () {
|
60 |
+
// IE 8 only supports `Object.defineProperty` on DOM elements
|
61 |
+
try {
|
62 |
+
var object = {};
|
63 |
+
var $defineProperty = Object.defineProperty;
|
64 |
+
var result = $defineProperty(object, object, object) && $defineProperty;
|
65 |
+
} catch (error) {
|
66 |
+
}
|
67 |
+
return result;
|
68 |
+
}());
|
69 |
+
var toString = {}.toString;
|
70 |
+
var startsWith = function (search) {
|
71 |
+
if (this == null) {
|
72 |
+
throw new TypeError();
|
73 |
+
}
|
74 |
+
var string = String(this);
|
75 |
+
if (search && toString.call(search) == '[object RegExp]') {
|
76 |
+
throw new TypeError();
|
77 |
+
}
|
78 |
+
var stringLength = string.length;
|
79 |
+
var searchString = String(search);
|
80 |
+
var searchLength = searchString.length;
|
81 |
+
var position = arguments.length > 1 ? arguments[1] : undefined;
|
82 |
+
// `ToInteger`
|
83 |
+
var pos = position ? Number(position) : 0;
|
84 |
+
if (pos != pos) { // better `isNaN`
|
85 |
+
pos = 0;
|
86 |
+
}
|
87 |
+
var start = Math.min(Math.max(pos, 0), stringLength);
|
88 |
+
// Avoid the `indexOf` call if no match is possible
|
89 |
+
if (searchLength + start > stringLength) {
|
90 |
+
return false;
|
91 |
+
}
|
92 |
+
var index = -1;
|
93 |
+
while (++index < searchLength) {
|
94 |
+
if (string.charCodeAt(start + index) != searchString.charCodeAt(index)) {
|
95 |
+
return false;
|
96 |
+
}
|
97 |
+
}
|
98 |
+
return true;
|
99 |
+
};
|
100 |
+
if (defineProperty) {
|
101 |
+
defineProperty(String.prototype, 'startsWith', {
|
102 |
+
'value': startsWith,
|
103 |
+
'configurable': true,
|
104 |
+
'writable': true
|
105 |
+
});
|
106 |
+
} else {
|
107 |
+
String.prototype.startsWith = startsWith;
|
108 |
+
}
|
109 |
+
}());
|
110 |
+
}
|
111 |
+
|
112 |
+
if (!Object.keys) {
|
113 |
+
Object.keys = function (
|
114 |
+
o, // object
|
115 |
+
k, // key
|
116 |
+
r // result array
|
117 |
+
){
|
118 |
+
// initialize object and result
|
119 |
+
r=[];
|
120 |
+
// iterate over object keys
|
121 |
+
for (k in o)
|
122 |
+
// fill result array with non-prototypical keys
|
123 |
+
r.hasOwnProperty.call(o, k) && r.push(k);
|
124 |
+
// return result
|
125 |
+
return r;
|
126 |
+
};
|
127 |
+
}
|
128 |
+
|
129 |
+
$.fn.triggerNative = function (eventName) {
|
130 |
+
var el = this[0],
|
131 |
+
event;
|
132 |
+
|
133 |
+
if (el.dispatchEvent) {
|
134 |
+
if (typeof Event === 'function') {
|
135 |
+
// For modern browsers
|
136 |
+
event = new Event(eventName, {
|
137 |
+
bubbles: true
|
138 |
+
});
|
139 |
+
} else {
|
140 |
+
// For IE since it doesn't support Event constructor
|
141 |
+
event = document.createEvent('Event');
|
142 |
+
event.initEvent(eventName, true, false);
|
143 |
+
}
|
144 |
+
|
145 |
+
el.dispatchEvent(event);
|
146 |
+
} else {
|
147 |
+
if (el.fireEvent) {
|
148 |
+
event = document.createEventObject();
|
149 |
+
event.eventType = eventName;
|
150 |
+
el.fireEvent('on' + eventName, event);
|
151 |
+
}
|
152 |
+
|
153 |
+
this.trigger(eventName);
|
154 |
+
}
|
155 |
+
};
|
156 |
+
//</editor-fold>
|
157 |
+
|
158 |
+
// Case insensitive contains search
|
159 |
+
$.expr[':'].icontains = function (obj, index, meta) {
|
160 |
+
var $obj = $(obj);
|
161 |
+
var haystack = ($obj.data('tokens') || $obj.text()).toUpperCase();
|
162 |
+
return haystack.includes(meta[3].toUpperCase());
|
163 |
+
};
|
164 |
+
|
165 |
+
// Case insensitive begins search
|
166 |
+
$.expr[':'].ibegins = function (obj, index, meta) {
|
167 |
+
var $obj = $(obj);
|
168 |
+
var haystack = ($obj.data('tokens') || $obj.text()).toUpperCase();
|
169 |
+
return haystack.startsWith(meta[3].toUpperCase());
|
170 |
+
};
|
171 |
+
|
172 |
+
// Case and accent insensitive contains search
|
173 |
+
$.expr[':'].aicontains = function (obj, index, meta) {
|
174 |
+
var $obj = $(obj);
|
175 |
+
var haystack = ($obj.data('tokens') || $obj.data('normalizedText') || $obj.text()).toUpperCase();
|
176 |
+
return haystack.includes(meta[3].toUpperCase());
|
177 |
+
};
|
178 |
+
|
179 |
+
// Case and accent insensitive begins search
|
180 |
+
$.expr[':'].aibegins = function (obj, index, meta) {
|
181 |
+
var $obj = $(obj);
|
182 |
+
var haystack = ($obj.data('tokens') || $obj.data('normalizedText') || $obj.text()).toUpperCase();
|
183 |
+
return haystack.startsWith(meta[3].toUpperCase());
|
184 |
+
};
|
185 |
+
|
186 |
+
/**
|
187 |
+
* Remove all diatrics from the given text.
|
188 |
+
* @access private
|
189 |
+
* @param {String} text
|
190 |
+
* @returns {String}
|
191 |
+
*/
|
192 |
+
function normalizeToBase(text) {
|
193 |
+
var rExps = [
|
194 |
+
{re: /[\xC0-\xC6]/g, ch: "A"},
|
195 |
+
{re: /[\xE0-\xE6]/g, ch: "a"},
|
196 |
+
{re: /[\xC8-\xCB]/g, ch: "E"},
|
197 |
+
{re: /[\xE8-\xEB]/g, ch: "e"},
|
198 |
+
{re: /[\xCC-\xCF]/g, ch: "I"},
|
199 |
+
{re: /[\xEC-\xEF]/g, ch: "i"},
|
200 |
+
{re: /[\xD2-\xD6]/g, ch: "O"},
|
201 |
+
{re: /[\xF2-\xF6]/g, ch: "o"},
|
202 |
+
{re: /[\xD9-\xDC]/g, ch: "U"},
|
203 |
+
{re: /[\xF9-\xFC]/g, ch: "u"},
|
204 |
+
{re: /[\xC7-\xE7]/g, ch: "c"},
|
205 |
+
{re: /[\xD1]/g, ch: "N"},
|
206 |
+
{re: /[\xF1]/g, ch: "n"}
|
207 |
+
];
|
208 |
+
$.each(rExps, function () {
|
209 |
+
text = text.replace(this.re, this.ch);
|
210 |
+
});
|
211 |
+
return text;
|
212 |
+
}
|
213 |
+
|
214 |
+
|
215 |
+
function htmlEscape(html) {
|
216 |
+
var escapeMap = {
|
217 |
+
'&': '&',
|
218 |
+
'<': '<',
|
219 |
+
'>': '>',
|
220 |
+
'"': '"',
|
221 |
+
"'": ''',
|
222 |
+
'`': '`'
|
223 |
+
};
|
224 |
+
var source = '(?:' + Object.keys(escapeMap).join('|') + ')',
|
225 |
+
testRegexp = new RegExp(source),
|
226 |
+
replaceRegexp = new RegExp(source, 'g'),
|
227 |
+
string = html == null ? '' : '' + html;
|
228 |
+
return testRegexp.test(string) ? string.replace(replaceRegexp, function (match) {
|
229 |
+
return escapeMap[match];
|
230 |
+
}) : string;
|
231 |
+
}
|
232 |
+
|
233 |
+
var Selectpicker = function (element, options, e) {
|
234 |
+
if (e) {
|
235 |
+
e.stopPropagation();
|
236 |
+
e.preventDefault();
|
237 |
+
}
|
238 |
+
|
239 |
+
this.$element = $(element);
|
240 |
+
this.$newElement = null;
|
241 |
+
this.$button = null;
|
242 |
+
this.$menu = null;
|
243 |
+
this.$lis = null;
|
244 |
+
this.options = options;
|
245 |
+
|
246 |
+
// If we have no title yet, try to pull it from the html title attribute (jQuery doesnt' pick it up as it's not a
|
247 |
+
// data-attribute)
|
248 |
+
if (this.options.title === null) {
|
249 |
+
this.options.title = this.$element.attr('title');
|
250 |
+
}
|
251 |
+
|
252 |
+
//Expose public methods
|
253 |
+
this.val = Selectpicker.prototype.val;
|
254 |
+
this.render = Selectpicker.prototype.render;
|
255 |
+
this.refresh = Selectpicker.prototype.refresh;
|
256 |
+
this.setStyle = Selectpicker.prototype.setStyle;
|
257 |
+
this.selectAll = Selectpicker.prototype.selectAll;
|
258 |
+
this.deselectAll = Selectpicker.prototype.deselectAll;
|
259 |
+
this.destroy = Selectpicker.prototype.destroy;
|
260 |
+
this.remove = Selectpicker.prototype.remove;
|
261 |
+
this.show = Selectpicker.prototype.show;
|
262 |
+
this.hide = Selectpicker.prototype.hide;
|
263 |
+
|
264 |
+
this.init();
|
265 |
+
};
|
266 |
+
|
267 |
+
Selectpicker.VERSION = '1.10.0';
|
268 |
+
|
269 |
+
// part of this is duplicated in i18n/defaults-en_US.js. Make sure to update both.
|
270 |
+
Selectpicker.DEFAULTS = {
|
271 |
+
noneSelectedText: 'Nothing selected',
|
272 |
+
noneResultsText: 'No results matched {0}',
|
273 |
+
countSelectedText: function (numSelected, numTotal) {
|
274 |
+
return (numSelected == 1) ? "{0} item selected" : "{0} items selected";
|
275 |
+
},
|
276 |
+
maxOptionsText: function (numAll, numGroup) {
|
277 |
+
return [
|
278 |
+
(numAll == 1) ? 'Limit reached ({n} item max)' : 'Limit reached ({n} items max)',
|
279 |
+
(numGroup == 1) ? 'Group limit reached ({n} item max)' : 'Group limit reached ({n} items max)'
|
280 |
+
];
|
281 |
+
},
|
282 |
+
selectAllText: 'Select All',
|
283 |
+
deselectAllText: 'Deselect All',
|
284 |
+
doneButton: false,
|
285 |
+
doneButtonText: 'Close',
|
286 |
+
multipleSeparator: ', ',
|
287 |
+
styleBase: 'btn',
|
288 |
+
style: 'btn-default',
|
289 |
+
size: 'auto',
|
290 |
+
title: null,
|
291 |
+
selectedTextFormat: 'values',
|
292 |
+
width: false,
|
293 |
+
container: false,
|
294 |
+
hideDisabled: false,
|
295 |
+
showSubtext: false,
|
296 |
+
showIcon: true,
|
297 |
+
showContent: true,
|
298 |
+
dropupAuto: true,
|
299 |
+
header: false,
|
300 |
+
liveSearch: false,
|
301 |
+
liveSearchPlaceholder: null,
|
302 |
+
liveSearchNormalize: false,
|
303 |
+
liveSearchStyle: 'contains',
|
304 |
+
actionsBox: false,
|
305 |
+
iconBase: 'glyphicon',
|
306 |
+
tickIcon: 'glyphicon-ok',
|
307 |
+
showTick: false,
|
308 |
+
template: {
|
309 |
+
caret: '<span class="caret"></span>'
|
310 |
+
},
|
311 |
+
maxOptions: false,
|
312 |
+
mobile: false,
|
313 |
+
selectOnTab: false,
|
314 |
+
dropdownAlignRight: false
|
315 |
+
};
|
316 |
+
|
317 |
+
Selectpicker.prototype = {
|
318 |
+
|
319 |
+
constructor: Selectpicker,
|
320 |
+
|
321 |
+
init: function () {
|
322 |
+
var that = this,
|
323 |
+
id = this.$element.attr('id');
|
324 |
+
|
325 |
+
this.$element.addClass('bs-select-hidden');
|
326 |
+
|
327 |
+
// store originalIndex (key) and newIndex (value) in this.liObj for fast accessibility
|
328 |
+
// allows us to do this.$lis.eq(that.liObj[index]) instead of this.$lis.filter('[data-original-index="' + index + '"]')
|
329 |
+
this.liObj = {};
|
330 |
+
this.multiple = this.$element.prop('multiple');
|
331 |
+
this.autofocus = this.$element.prop('autofocus');
|
332 |
+
this.$newElement = this.createView();
|
333 |
+
this.$element
|
334 |
+
.after(this.$newElement)
|
335 |
+
.appendTo(this.$newElement);
|
336 |
+
this.$button = this.$newElement.children('button');
|
337 |
+
this.$menu = this.$newElement.children('.dropdown-menu');
|
338 |
+
this.$menuInner = this.$menu.children('.inner');
|
339 |
+
this.$searchbox = this.$menu.find('input');
|
340 |
+
|
341 |
+
this.$element.removeClass('bs-select-hidden');
|
342 |
+
|
343 |
+
if (this.options.dropdownAlignRight)
|
344 |
+
this.$menu.addClass('dropdown-menu-right');
|
345 |
+
|
346 |
+
if (typeof id !== 'undefined') {
|
347 |
+
this.$button.attr('data-id', id);
|
348 |
+
$('label[for="' + id + '"]').click(function (e) {
|
349 |
+
e.preventDefault();
|
350 |
+
that.$button.focus();
|
351 |
+
});
|
352 |
+
}
|
353 |
+
|
354 |
+
this.checkDisabled();
|
355 |
+
this.clickListener();
|
356 |
+
if (this.options.liveSearch) this.liveSearchListener();
|
357 |
+
this.render();
|
358 |
+
this.setStyle();
|
359 |
+
this.setWidth();
|
360 |
+
if (this.options.container) this.selectPosition();
|
361 |
+
this.$menu.data('this', this);
|
362 |
+
this.$newElement.data('this', this);
|
363 |
+
if (this.options.mobile) this.mobile();
|
364 |
+
|
365 |
+
this.$newElement.on({
|
366 |
+
'hide.bs.dropdown': function (e) {
|
367 |
+
that.$element.trigger('hide.bs.select', e);
|
368 |
+
},
|
369 |
+
'hidden.bs.dropdown': function (e) {
|
370 |
+
that.$element.trigger('hidden.bs.select', e);
|
371 |
+
},
|
372 |
+
'show.bs.dropdown': function (e) {
|
373 |
+
that.$element.trigger('show.bs.select', e);
|
374 |
+
},
|
375 |
+
'shown.bs.dropdown': function (e) {
|
376 |
+
that.$element.trigger('shown.bs.select', e);
|
377 |
+
}
|
378 |
+
});
|
379 |
+
|
380 |
+
if (that.$element[0].hasAttribute('required')) {
|
381 |
+
this.$element.on('invalid', function () {
|
382 |
+
that.$button
|
383 |
+
.addClass('bs-invalid')
|
384 |
+
.focus();
|
385 |
+
|
386 |
+
that.$element.on({
|
387 |
+
'focus.bs.select': function () {
|
388 |
+
that.$button.focus();
|
389 |
+
that.$element.off('focus.bs.select');
|
390 |
+
},
|
391 |
+
'shown.bs.select': function () {
|
392 |
+
that.$element
|
393 |
+
.val(that.$element.val()) // set the value to hide the validation message in Chrome when menu is opened
|
394 |
+
.off('shown.bs.select');
|
395 |
+
},
|
396 |
+
'rendered.bs.select': function () {
|
397 |
+
// if select is no longer invalid, remove the bs-invalid class
|
398 |
+
if (this.validity.valid) that.$button.removeClass('bs-invalid');
|
399 |
+
that.$element.off('rendered.bs.select');
|
400 |
+
}
|
401 |
+
});
|
402 |
+
|
403 |
+
});
|
404 |
+
}
|
405 |
+
|
406 |
+
setTimeout(function () {
|
407 |
+
that.$element.trigger('loaded.bs.select');
|
408 |
+
});
|
409 |
+
},
|
410 |
+
|
411 |
+
createDropdown: function () {
|
412 |
+
// Options
|
413 |
+
// If we are multiple or showTick option is set, then add the show-tick class
|
414 |
+
var showTick = (this.multiple || this.options.showTick) ? ' show-tick' : '',
|
415 |
+
inputGroup = this.$element.parent().hasClass('input-group') ? ' input-group-btn' : '',
|
416 |
+
autofocus = this.autofocus ? ' autofocus' : '';
|
417 |
+
// Elements
|
418 |
+
var header = this.options.header ? '<div class="popover-title"><button type="button" class="close" aria-hidden="true">×</button>' + this.options.header + '</div>' : '';
|
419 |
+
var searchbox = this.options.liveSearch ?
|
420 |
+
'<div class="bs-searchbox">' +
|
421 |
+
'<input type="text" class="form-control" autocomplete="off"' +
|
422 |
+
(null === this.options.liveSearchPlaceholder ? '' : ' placeholder="' + htmlEscape(this.options.liveSearchPlaceholder) + '"') + '>' +
|
423 |
+
'</div>'
|
424 |
+
: '';
|
425 |
+
var actionsbox = this.multiple && this.options.actionsBox ?
|
426 |
+
'<div class="bs-actionsbox">' +
|
427 |
+
'<div class="btn-group btn-group-sm btn-block">' +
|
428 |
+
'<button type="button" class="actions-btn bs-select-all btn btn-default">' +
|
429 |
+
this.options.selectAllText +
|
430 |
+
'</button>' +
|
431 |
+
'<button type="button" class="actions-btn bs-deselect-all btn btn-default">' +
|
432 |
+
this.options.deselectAllText +
|
433 |
+
'</button>' +
|
434 |
+
'</div>' +
|
435 |
+
'</div>'
|
436 |
+
: '';
|
437 |
+
var donebutton = this.multiple && this.options.doneButton ?
|
438 |
+
'<div class="bs-donebutton">' +
|
439 |
+
'<div class="btn-group btn-block">' +
|
440 |
+
'<button type="button" class="btn btn-sm btn-default">' +
|
441 |
+
this.options.doneButtonText +
|
442 |
+
'</button>' +
|
443 |
+
'</div>' +
|
444 |
+
'</div>'
|
445 |
+
: '';
|
446 |
+
var drop =
|
447 |
+
'<div class="btn-group bootstrap-select' + showTick + inputGroup + '">' +
|
448 |
+
'<button type="button" class="' + this.options.styleBase + ' dropdown-toggle" data-toggle="dropdown"' + autofocus + '>' +
|
449 |
+
'<span class="filter-option pull-left"></span> ' +
|
450 |
+
'<span class="bs-caret">' +
|
451 |
+
this.options.template.caret +
|
452 |
+
'</span>' +
|
453 |
+
'</button>' +
|
454 |
+
'<div class="dropdown-menu open">' +
|
455 |
+
header +
|
456 |
+
searchbox +
|
457 |
+
actionsbox +
|
458 |
+
'<ul class="dropdown-menu inner" role="menu">' +
|
459 |
+
'</ul>' +
|
460 |
+
donebutton +
|
461 |
+
'</div>' +
|
462 |
+
'</div>';
|
463 |
+
|
464 |
+
return $(drop);
|
465 |
+
},
|
466 |
+
|
467 |
+
createView: function () {
|
468 |
+
var $drop = this.createDropdown(),
|
469 |
+
li = this.createLi();
|
470 |
+
|
471 |
+
$drop.find('ul')[0].innerHTML = li;
|
472 |
+
return $drop;
|
473 |
+
},
|
474 |
+
|
475 |
+
reloadLi: function () {
|
476 |
+
//Remove all children.
|
477 |
+
this.destroyLi();
|
478 |
+
//Re build
|
479 |
+
var li = this.createLi();
|
480 |
+
this.$menuInner[0].innerHTML = li;
|
481 |
+
},
|
482 |
+
|
483 |
+
destroyLi: function () {
|
484 |
+
this.$menu.find('li').remove();
|
485 |
+
},
|
486 |
+
|
487 |
+
createLi: function () {
|
488 |
+
var that = this,
|
489 |
+
_li = [],
|
490 |
+
optID = 0,
|
491 |
+
titleOption = document.createElement('option'),
|
492 |
+
liIndex = -1; // increment liIndex whenever a new <li> element is created to ensure liObj is correct
|
493 |
+
|
494 |
+
// Helper functions
|
495 |
+
/**
|
496 |
+
* @param content
|
497 |
+
* @param [index]
|
498 |
+
* @param [classes]
|
499 |
+
* @param [optgroup]
|
500 |
+
* @returns {string}
|
501 |
+
*/
|
502 |
+
var generateLI = function (content, index, classes, optgroup) {
|
503 |
+
return '<li' +
|
504 |
+
((typeof classes !== 'undefined' & '' !== classes) ? ' class="' + classes + '"' : '') +
|
505 |
+
((typeof index !== 'undefined' & null !== index) ? ' data-original-index="' + index + '"' : '') +
|
506 |
+
((typeof optgroup !== 'undefined' & null !== optgroup) ? 'data-optgroup="' + optgroup + '"' : '') +
|
507 |
+
'>' + content + '</li>';
|
508 |
+
};
|
509 |
+
|
510 |
+
/**
|
511 |
+
* @param text
|
512 |
+
* @param [classes]
|
513 |
+
* @param [inline]
|
514 |
+
* @param [tokens]
|
515 |
+
* @returns {string}
|
516 |
+
*/
|
517 |
+
var generateA = function (text, classes, inline, tokens) {
|
518 |
+
return '<a tabindex="0"' +
|
519 |
+
(typeof classes !== 'undefined' ? ' class="' + classes + '"' : '') +
|
520 |
+
(typeof inline !== 'undefined' ? ' style="' + inline + '"' : '') +
|
521 |
+
(that.options.liveSearchNormalize ? ' data-normalized-text="' + normalizeToBase(htmlEscape(text)) + '"' : '') +
|
522 |
+
(typeof tokens !== 'undefined' || tokens !== null ? ' data-tokens="' + tokens + '"' : '') +
|
523 |
+
'>' + text +
|
524 |
+
'<span class="' + that.options.iconBase + ' ' + that.options.tickIcon + ' check-mark"></span>' +
|
525 |
+
'</a>';
|
526 |
+
};
|
527 |
+
|
528 |
+
if (this.options.title && !this.multiple) {
|
529 |
+
// this option doesn't create a new <li> element, but does add a new option, so liIndex is decreased
|
530 |
+
// since liObj is recalculated on every refresh, liIndex needs to be decreased even if the titleOption is already appended
|
531 |
+
liIndex--;
|
532 |
+
|
533 |
+
if (!this.$element.find('.bs-title-option').length) {
|
534 |
+
// Use native JS to prepend option (faster)
|
535 |
+
var element = this.$element[0];
|
536 |
+
titleOption.className = 'bs-title-option';
|
537 |
+
titleOption.appendChild(document.createTextNode(this.options.title));
|
538 |
+
titleOption.value = '';
|
539 |
+
element.insertBefore(titleOption, element.firstChild);
|
540 |
+
// Check if selected attribute is already set on an option. If not, select the titleOption option.
|
541 |
+
if ($(element.options[element.selectedIndex]).attr('selected') === undefined) titleOption.selected = true;
|
542 |
+
}
|
543 |
+
}
|
544 |
+
|
545 |
+
this.$element.find('option').each(function (index) {
|
546 |
+
var $this = $(this);
|
547 |
+
|
548 |
+
liIndex++;
|
549 |
+
|
550 |
+
if ($this.hasClass('bs-title-option')) return;
|
551 |
+
|
552 |
+
// Get the class and text for the option
|
553 |
+
var optionClass = this.className || '',
|
554 |
+
inline = this.style.cssText,
|
555 |
+
text = $this.data('content') ? $this.data('content') : $this.html(),
|
556 |
+
tokens = $this.data('tokens') ? $this.data('tokens') : null,
|
557 |
+
subtext = typeof $this.data('subtext') !== 'undefined' ? '<small class="text-muted">' + $this.data('subtext') + '</small>' : '',
|
558 |
+
icon = typeof $this.data('icon') !== 'undefined' ? '<span class="' + that.options.iconBase + ' ' + $this.data('icon') + '"></span> ' : '',
|
559 |
+
isOptgroup = this.parentNode.tagName === 'OPTGROUP',
|
560 |
+
isDisabled = this.disabled || (isOptgroup && this.parentNode.disabled);
|
561 |
+
|
562 |
+
if (icon !== '' && isDisabled) {
|
563 |
+
icon = '<span>' + icon + '</span>';
|
564 |
+
}
|
565 |
+
|
566 |
+
if (that.options.hideDisabled && isDisabled && !isOptgroup) {
|
567 |
+
liIndex--;
|
568 |
+
return;
|
569 |
+
}
|
570 |
+
|
571 |
+
if (!$this.data('content')) {
|
572 |
+
// Prepend any icon and append any subtext to the main text.
|
573 |
+
text = icon + '<span class="text">' + text + subtext + '</span>';
|
574 |
+
}
|
575 |
+
|
576 |
+
if (isOptgroup && $this.data('divider') !== true) {
|
577 |
+
var optGroupClass = ' ' + this.parentNode.className || '';
|
578 |
+
|
579 |
+
if ($this.index() === 0) { // Is it the first option of the optgroup?
|
580 |
+
optID += 1;
|
581 |
+
|
582 |
+
// Get the opt group label
|
583 |
+
var label = this.parentNode.label,
|
584 |
+
labelSubtext = typeof $this.parent().data('subtext') !== 'undefined' ? '<small class="text-muted">' + $this.parent().data('subtext') + '</small>' : '',
|
585 |
+
labelIcon = $this.parent().data('icon') ? '<span class="' + that.options.iconBase + ' ' + $this.parent().data('icon') + '"></span> ' : '';
|
586 |
+
|
587 |
+
label = labelIcon + '<span class="text">' + label + labelSubtext + '</span>';
|
588 |
+
|
589 |
+
if (index !== 0 && _li.length > 0) { // Is it NOT the first option of the select && are there elements in the dropdown?
|
590 |
+
liIndex++;
|
591 |
+
_li.push(generateLI('', null, 'divider', optID + 'div'));
|
592 |
+
}
|
593 |
+
liIndex++;
|
594 |
+
_li.push(generateLI(label, null, 'dropdown-header' + optGroupClass, optID));
|
595 |
+
}
|
596 |
+
|
597 |
+
if (that.options.hideDisabled && isDisabled) {
|
598 |
+
liIndex--;
|
599 |
+
return;
|
600 |
+
}
|
601 |
+
|
602 |
+
_li.push(generateLI(generateA(text, 'opt ' + optionClass + optGroupClass, inline, tokens), index, '', optID));
|
603 |
+
} else if ($this.data('divider') === true) {
|
604 |
+
_li.push(generateLI('', index, 'divider'));
|
605 |
+
} else if ($this.data('hidden') === true) {
|
606 |
+
_li.push(generateLI(generateA(text, optionClass, inline, tokens), index, 'hidden is-hidden'));
|
607 |
+
} else {
|
608 |
+
if (this.previousElementSibling && this.previousElementSibling.tagName === 'OPTGROUP') {
|
609 |
+
liIndex++;
|
610 |
+
_li.push(generateLI('', null, 'divider', optID + 'div'));
|
611 |
+
}
|
612 |
+
_li.push(generateLI(generateA(text, optionClass, inline, tokens), index));
|
613 |
+
}
|
614 |
+
|
615 |
+
that.liObj[index] = liIndex;
|
616 |
+
});
|
617 |
+
|
618 |
+
//If we are not multiple, we don't have a selected item, and we don't have a title, select the first element so something is set in the button
|
619 |
+
if (!this.multiple && this.$element.find('option:selected').length === 0 && !this.options.title) {
|
620 |
+
this.$element.find('option').eq(0).prop('selected', true).attr('selected', 'selected');
|
621 |
+
}
|
622 |
+
|
623 |
+
return _li.join('');
|
624 |
+
},
|
625 |
+
|
626 |
+
findLis: function () {
|
627 |
+
if (this.$lis == null) this.$lis = this.$menu.find('li');
|
628 |
+
return this.$lis;
|
629 |
+
},
|
630 |
+
|
631 |
+
/**
|
632 |
+
* @param [updateLi] defaults to true
|
633 |
+
*/
|
634 |
+
render: function (updateLi) {
|
635 |
+
var that = this,
|
636 |
+
notDisabled;
|
637 |
+
|
638 |
+
//Update the LI to match the SELECT
|
639 |
+
if (updateLi !== false) {
|
640 |
+
this.$element.find('option').each(function (index) {
|
641 |
+
var $lis = that.findLis().eq(that.liObj[index]);
|
642 |
+
|
643 |
+
that.setDisabled(index, this.disabled || this.parentNode.tagName === 'OPTGROUP' && this.parentNode.disabled, $lis);
|
644 |
+
that.setSelected(index, this.selected, $lis);
|
645 |
+
});
|
646 |
+
}
|
647 |
+
|
648 |
+
this.tabIndex();
|
649 |
+
|
650 |
+
var selectedItems = this.$element.find('option').map(function () {
|
651 |
+
if (this.selected) {
|
652 |
+
if (that.options.hideDisabled && (this.disabled || this.parentNode.tagName === 'OPTGROUP' && this.parentNode.disabled)) return;
|
653 |
+
|
654 |
+
var $this = $(this),
|
655 |
+
icon = $this.data('icon') && that.options.showIcon ? '<i class="' + that.options.iconBase + ' ' + $this.data('icon') + '"></i> ' : '',
|
656 |
+
subtext;
|
657 |
+
|
658 |
+
if (that.options.showSubtext && $this.data('subtext') && !that.multiple) {
|
659 |
+
subtext = ' <small class="text-muted">' + $this.data('subtext') + '</small>';
|
660 |
+
} else {
|
661 |
+
subtext = '';
|
662 |
+
}
|
663 |
+
if (typeof $this.attr('title') !== 'undefined') {
|
664 |
+
return $this.attr('title');
|
665 |
+
} else if ($this.data('content') && that.options.showContent) {
|
666 |
+
return $this.data('content');
|
667 |
+
} else {
|
668 |
+
return icon + $this.html() + subtext;
|
669 |
+
}
|
670 |
+
}
|
671 |
+
}).toArray();
|
672 |
+
|
673 |
+
//Fixes issue in IE10 occurring when no default option is selected and at least one option is disabled
|
674 |
+
//Convert all the values into a comma delimited string
|
675 |
+
var title = !this.multiple ? selectedItems[0] : selectedItems.join(this.options.multipleSeparator);
|
676 |
+
|
677 |
+
//If this is multi select, and the selectText type is count, the show 1 of 2 selected etc..
|
678 |
+
if (this.multiple && this.options.selectedTextFormat.indexOf('count') > -1) {
|
679 |
+
var max = this.options.selectedTextFormat.split('>');
|
680 |
+
if ((max.length > 1 && selectedItems.length > max[1]) || (max.length == 1 && selectedItems.length >= 2)) {
|
681 |
+
notDisabled = this.options.hideDisabled ? ', [disabled]' : '';
|
682 |
+
var totalCount = this.$element.find('option').not('[data-divider="true"], [data-hidden="true"]' + notDisabled).length,
|
683 |
+
tr8nText = (typeof this.options.countSelectedText === 'function') ? this.options.countSelectedText(selectedItems.length, totalCount) : this.options.countSelectedText;
|
684 |
+
title = tr8nText.replace('{0}', selectedItems.length.toString()).replace('{1}', totalCount.toString());
|
685 |
+
}
|
686 |
+
}
|
687 |
+
|
688 |
+
if (this.options.title == undefined) {
|
689 |
+
this.options.title = this.$element.attr('title');
|
690 |
+
}
|
691 |
+
|
692 |
+
if (this.options.selectedTextFormat == 'static') {
|
693 |
+
title = this.options.title;
|
694 |
+
}
|
695 |
+
|
696 |
+
//If we dont have a title, then use the default, or if nothing is set at all, use the not selected text
|
697 |
+
if (!title) {
|
698 |
+
title = typeof this.options.title !== 'undefined' ? this.options.title : this.options.noneSelectedText;
|
699 |
+
}
|
700 |
+
|
701 |
+
//strip all html-tags and trim the result
|
702 |
+
// this.$button.attr('title', $.trim(title.replace(/<[^>]*>?/g, '')));
|
703 |
+
this.$button.children('.filter-option').html(title);
|
704 |
+
|
705 |
+
this.$element.trigger('rendered.bs.select');
|
706 |
+
},
|
707 |
+
|
708 |
+
/**
|
709 |
+
* @param [style]
|
710 |
+
* @param [status]
|
711 |
+
*/
|
712 |
+
setStyle: function (style, status) {
|
713 |
+
if (this.$element.attr('class')) {
|
714 |
+
this.$newElement.addClass(this.$element.attr('class').replace(/selectpicker|mobile-device|bs-select-hidden|validate\[.*\]/gi, ''));
|
715 |
+
}
|
716 |
+
|
717 |
+
var buttonClass = style ? style : this.options.style;
|
718 |
+
|
719 |
+
if (status == 'add') {
|
720 |
+
this.$button.addClass(buttonClass);
|
721 |
+
} else if (status == 'remove') {
|
722 |
+
this.$button.removeClass(buttonClass);
|
723 |
+
} else {
|
724 |
+
this.$button.removeClass(this.options.style);
|
725 |
+
this.$button.addClass(buttonClass);
|
726 |
+
}
|
727 |
+
},
|
728 |
+
|
729 |
+
liHeight: function (refresh) {
|
730 |
+
if (!refresh && (this.options.size === false || this.sizeInfo)) return;
|
731 |
+
|
732 |
+
var newElement = document.createElement('div'),
|
733 |
+
menu = document.createElement('div'),
|
734 |
+
menuInner = document.createElement('ul'),
|
735 |
+
divider = document.createElement('li'),
|
736 |
+
li = document.createElement('li'),
|
737 |
+
a = document.createElement('a'),
|
738 |
+
text = document.createElement('span'),
|
739 |
+
header = this.options.header && this.$menu.find('.popover-title').length > 0 ? this.$menu.find('.popover-title')[0].cloneNode(true) : null,
|
740 |
+
search = this.options.liveSearch ? document.createElement('div') : null,
|
741 |
+
actions = this.options.actionsBox && this.multiple && this.$menu.find('.bs-actionsbox').length > 0 ? this.$menu.find('.bs-actionsbox')[0].cloneNode(true) : null,
|
742 |
+
doneButton = this.options.doneButton && this.multiple && this.$menu.find('.bs-donebutton').length > 0 ? this.$menu.find('.bs-donebutton')[0].cloneNode(true) : null;
|
743 |
+
|
744 |
+
text.className = 'text';
|
745 |
+
newElement.className = this.$menu[0].parentNode.className + ' open';
|
746 |
+
menu.className = 'dropdown-menu open';
|
747 |
+
menuInner.className = 'dropdown-menu inner';
|
748 |
+
divider.className = 'divider';
|
749 |
+
|
750 |
+
text.appendChild(document.createTextNode('Inner text'));
|
751 |
+
a.appendChild(text);
|
752 |
+
li.appendChild(a);
|
753 |
+
menuInner.appendChild(li);
|
754 |
+
menuInner.appendChild(divider);
|
755 |
+
if (header) menu.appendChild(header);
|
756 |
+
if (search) {
|
757 |
+
// create a span instead of input as creating an input element is slower
|
758 |
+
var input = document.createElement('span');
|
759 |
+
search.className = 'bs-searchbox';
|
760 |
+
input.className = 'form-control';
|
761 |
+
search.appendChild(input);
|
762 |
+
menu.appendChild(search);
|
763 |
+
}
|
764 |
+
if (actions) menu.appendChild(actions);
|
765 |
+
menu.appendChild(menuInner);
|
766 |
+
if (doneButton) menu.appendChild(doneButton);
|
767 |
+
newElement.appendChild(menu);
|
768 |
+
|
769 |
+
document.body.appendChild(newElement);
|
770 |
+
|
771 |
+
var liHeight = a.offsetHeight,
|
772 |
+
headerHeight = header ? header.offsetHeight : 0,
|
773 |
+
searchHeight = search ? search.offsetHeight : 0,
|
774 |
+
actionsHeight = actions ? actions.offsetHeight : 0,
|
775 |
+
doneButtonHeight = doneButton ? doneButton.offsetHeight : 0,
|
776 |
+
dividerHeight = $(divider).outerHeight(true),
|
777 |
+
// fall back to jQuery if getComputedStyle is not supported
|
778 |
+
menuStyle = typeof getComputedStyle === 'function' ? getComputedStyle(menu) : false,
|
779 |
+
$menu = menuStyle ? null : $(menu),
|
780 |
+
menuPadding = parseInt(menuStyle ? menuStyle.paddingTop : $menu.css('paddingTop')) +
|
781 |
+
parseInt(menuStyle ? menuStyle.paddingBottom : $menu.css('paddingBottom')) +
|
782 |
+
parseInt(menuStyle ? menuStyle.borderTopWidth : $menu.css('borderTopWidth')) +
|
783 |
+
parseInt(menuStyle ? menuStyle.borderBottomWidth : $menu.css('borderBottomWidth')),
|
784 |
+
menuExtras = menuPadding +
|
785 |
+
parseInt(menuStyle ? menuStyle.marginTop : $menu.css('marginTop')) +
|
786 |
+
parseInt(menuStyle ? menuStyle.marginBottom : $menu.css('marginBottom')) + 2;
|
787 |
+
|
788 |
+
document.body.removeChild(newElement);
|
789 |
+
|
790 |
+
this.sizeInfo = {
|
791 |
+
liHeight: liHeight,
|
792 |
+
headerHeight: headerHeight,
|
793 |
+
searchHeight: searchHeight,
|
794 |
+
actionsHeight: actionsHeight,
|
795 |
+
doneButtonHeight: doneButtonHeight,
|
796 |
+
dividerHeight: dividerHeight,
|
797 |
+
menuPadding: menuPadding,
|
798 |
+
menuExtras: menuExtras
|
799 |
+
};
|
800 |
+
},
|
801 |
+
|
802 |
+
setSize: function () {
|
803 |
+
this.findLis();
|
804 |
+
this.liHeight();
|
805 |
+
|
806 |
+
if (this.options.header) this.$menu.css('padding-top', 0);
|
807 |
+
if (this.options.size === false) return;
|
808 |
+
|
809 |
+
var that = this,
|
810 |
+
$menu = this.$menu,
|
811 |
+
$menuInner = this.$menuInner,
|
812 |
+
$window = $(window),
|
813 |
+
selectHeight = this.$newElement[0].offsetHeight,
|
814 |
+
liHeight = this.sizeInfo['liHeight'],
|
815 |
+
headerHeight = this.sizeInfo['headerHeight'],
|
816 |
+
searchHeight = this.sizeInfo['searchHeight'],
|
817 |
+
actionsHeight = this.sizeInfo['actionsHeight'],
|
818 |
+
doneButtonHeight = this.sizeInfo['doneButtonHeight'],
|
819 |
+
divHeight = this.sizeInfo['dividerHeight'],
|
820 |
+
menuPadding = this.sizeInfo['menuPadding'],
|
821 |
+
menuExtras = this.sizeInfo['menuExtras'],
|
822 |
+
notDisabled = this.options.hideDisabled ? '.disabled' : '',
|
823 |
+
menuHeight,
|
824 |
+
getHeight,
|
825 |
+
selectOffsetTop,
|
826 |
+
selectOffsetBot,
|
827 |
+
posVert = function () {
|
828 |
+
selectOffsetTop = that.$newElement.offset().top - $window.scrollTop();
|
829 |
+
selectOffsetBot = $window.height() - selectOffsetTop - selectHeight;
|
830 |
+
};
|
831 |
+
|
832 |
+
posVert();
|
833 |
+
|
834 |
+
if (this.options.size === 'auto') {
|
835 |
+
var getSize = function () {
|
836 |
+
var minHeight,
|
837 |
+
hasClass = function (className, include) {
|
838 |
+
return function (element) {
|
839 |
+
if (include) {
|
840 |
+
return (element.classList ? element.classList.contains(className) : $(element).hasClass(className));
|
841 |
+
} else {
|
842 |
+
return !(element.classList ? element.classList.contains(className) : $(element).hasClass(className));
|
843 |
+
}
|
844 |
+
};
|
845 |
+
},
|
846 |
+
lis = that.$menuInner[0].getElementsByTagName('li'),
|
847 |
+
lisVisible = Array.prototype.filter ? Array.prototype.filter.call(lis, hasClass('hidden', false)) : that.$lis.not('.hidden'),
|
848 |
+
optGroup = Array.prototype.filter ? Array.prototype.filter.call(lisVisible, hasClass('dropdown-header', true)) : lisVisible.filter('.dropdown-header');
|
849 |
+
|
850 |
+
posVert();
|
851 |
+
menuHeight = selectOffsetBot - menuExtras;
|
852 |
+
|
853 |
+
if (that.options.container) {
|
854 |
+
if (!$menu.data('height')) $menu.data('height', $menu.height());
|
855 |
+
getHeight = $menu.data('height');
|
856 |
+
} else {
|
857 |
+
getHeight = $menu.height();
|
858 |
+
}
|
859 |
+
|
860 |
+
if (that.options.dropupAuto) {
|
861 |
+
that.$newElement.toggleClass('dropup', selectOffsetTop > selectOffsetBot && (menuHeight - menuExtras) < getHeight);
|
862 |
+
}
|
863 |
+
if (that.$newElement.hasClass('dropup')) {
|
864 |
+
menuHeight = selectOffsetTop - menuExtras;
|
865 |
+
}
|
866 |
+
|
867 |
+
if ((lisVisible.length + optGroup.length) > 3) {
|
868 |
+
minHeight = liHeight * 3 + menuExtras - 2;
|
869 |
+
} else {
|
870 |
+
minHeight = 0;
|
871 |
+
}
|
872 |
+
|
873 |
+
$menu.css({
|
874 |
+
'max-height': menuHeight + 'px',
|
875 |
+
'overflow': 'hidden',
|
876 |
+
'min-height': minHeight + headerHeight + searchHeight + actionsHeight + doneButtonHeight + 'px'
|
877 |
+
});
|
878 |
+
$menuInner.css({
|
879 |
+
'max-height': menuHeight - headerHeight - searchHeight - actionsHeight - doneButtonHeight - menuPadding + 'px',
|
880 |
+
'overflow-y': 'auto',
|
881 |
+
'min-height': Math.max(minHeight - menuPadding, 0) + 'px'
|
882 |
+
});
|
883 |
+
};
|
884 |
+
getSize();
|
885 |
+
this.$searchbox.off('input.getSize propertychange.getSize').on('input.getSize propertychange.getSize', getSize);
|
886 |
+
$window.off('resize.getSize scroll.getSize').on('resize.getSize scroll.getSize', getSize);
|
887 |
+
} else if (this.options.size && this.options.size != 'auto' && this.$lis.not(notDisabled).length > this.options.size) {
|
888 |
+
var optIndex = this.$lis.not('.divider').not(notDisabled).children().slice(0, this.options.size).last().parent().index(),
|
889 |
+
divLength = this.$lis.slice(0, optIndex + 1).filter('.divider').length;
|
890 |
+
menuHeight = liHeight * this.options.size + divLength * divHeight + menuPadding;
|
891 |
+
|
892 |
+
if (that.options.container) {
|
893 |
+
if (!$menu.data('height')) $menu.data('height', $menu.height());
|
894 |
+
getHeight = $menu.data('height');
|
895 |
+
} else {
|
896 |
+
getHeight = $menu.height();
|
897 |
+
}
|
898 |
+
|
899 |
+
if (that.options.dropupAuto) {
|
900 |
+
//noinspection JSUnusedAssignment
|
901 |
+
this.$newElement.toggleClass('dropup', selectOffsetTop > selectOffsetBot && (menuHeight - menuExtras) < getHeight);
|
902 |
+
}
|
903 |
+
$menu.css({
|
904 |
+
'max-height': menuHeight + headerHeight + searchHeight + actionsHeight + doneButtonHeight + 'px',
|
905 |
+
'overflow': 'hidden',
|
906 |
+
'min-height': ''
|
907 |
+
});
|
908 |
+
$menuInner.css({
|
909 |
+
'max-height': menuHeight - menuPadding + 'px',
|
910 |
+
'overflow-y': 'auto',
|
911 |
+
'min-height': ''
|
912 |
+
});
|
913 |
+
}
|
914 |
+
},
|
915 |
+
|
916 |
+
setWidth: function () {
|
917 |
+
if (this.options.width === 'auto') {
|
918 |
+
this.$menu.css('min-width', '0');
|
919 |
+
|
920 |
+
// Get correct width if element is hidden
|
921 |
+
var $selectClone = this.$menu.parent().clone().appendTo('body'),
|
922 |
+
$selectClone2 = this.options.container ? this.$newElement.clone().appendTo('body') : $selectClone,
|
923 |
+
ulWidth = $selectClone.children('.dropdown-menu').outerWidth(),
|
924 |
+
btnWidth = $selectClone2.css('width', 'auto').children('button').outerWidth();
|
925 |
+
|
926 |
+
$selectClone.remove();
|
927 |
+
$selectClone2.remove();
|
928 |
+
|
929 |
+
// Set width to whatever's larger, button title or longest option
|
930 |
+
this.$newElement.css('width', Math.max(ulWidth, btnWidth) + 'px');
|
931 |
+
} else if (this.options.width === 'fit') {
|
932 |
+
// Remove inline min-width so width can be changed from 'auto'
|
933 |
+
this.$menu.css('min-width', '');
|
934 |
+
this.$newElement.css('width', '').addClass('fit-width');
|
935 |
+
} else if (this.options.width) {
|
936 |
+
// Remove inline min-width so width can be changed from 'auto'
|
937 |
+
this.$menu.css('min-width', '');
|
938 |
+
this.$newElement.css('width', this.options.width);
|
939 |
+
} else {
|
940 |
+
// Remove inline min-width/width so width can be changed
|
941 |
+
this.$menu.css('min-width', '');
|
942 |
+
this.$newElement.css('width', '');
|
943 |
+
}
|
944 |
+
// Remove fit-width class if width is changed programmatically
|
945 |
+
if (this.$newElement.hasClass('fit-width') && this.options.width !== 'fit') {
|
946 |
+
this.$newElement.removeClass('fit-width');
|
947 |
+
}
|
948 |
+
},
|
949 |
+
|
950 |
+
selectPosition: function () {
|
951 |
+
this.$bsContainer = $('<div class="bs-container" />');
|
952 |
+
|
953 |
+
var that = this,
|
954 |
+
pos,
|
955 |
+
actualHeight,
|
956 |
+
getPlacement = function ($element) {
|
957 |
+
that.$bsContainer.addClass($element.attr('class').replace(/form-control|fit-width/gi, '')).toggleClass('dropup', $element.hasClass('dropup'));
|
958 |
+
pos = $element.offset();
|
959 |
+
actualHeight = $element.hasClass('dropup') ? 0 : $element[0].offsetHeight;
|
960 |
+
that.$bsContainer.css({
|
961 |
+
'top': pos.top + actualHeight,
|
962 |
+
'left': pos.left,
|
963 |
+
'width': $element[0].offsetWidth
|
964 |
+
});
|
965 |
+
};
|
966 |
+
|
967 |
+
this.$button.on('click', function () {
|
968 |
+
var $this = $(this);
|
969 |
+
|
970 |
+
if (that.isDisabled()) {
|
971 |
+
return;
|
972 |
+
}
|
973 |
+
|
974 |
+
getPlacement(that.$newElement);
|
975 |
+
|
976 |
+
that.$bsContainer
|
977 |
+
.appendTo(that.options.container)
|
978 |
+
.toggleClass('open', !$this.hasClass('open'))
|
979 |
+
.append(that.$menu);
|
980 |
+
});
|
981 |
+
|
982 |
+
$(window).on('resize scroll', function () {
|
983 |
+
getPlacement(that.$newElement);
|
984 |
+
});
|
985 |
+
|
986 |
+
this.$element.on('hide.bs.select', function () {
|
987 |
+
that.$menu.data('height', that.$menu.height());
|
988 |
+
that.$bsContainer.detach();
|
989 |
+
});
|
990 |
+
},
|
991 |
+
|
992 |
+
setSelected: function (index, selected, $lis) {
|
993 |
+
if (!$lis) {
|
994 |
+
$lis = this.findLis().eq(this.liObj[index]);
|
995 |
+
}
|
996 |
+
|
997 |
+
$lis.toggleClass('selected', selected);
|
998 |
+
},
|
999 |
+
|
1000 |
+
setDisabled: function (index, disabled, $lis) {
|
1001 |
+
if (!$lis) {
|
1002 |
+
$lis = this.findLis().eq(this.liObj[index]);
|
1003 |
+
}
|
1004 |
+
|
1005 |
+
if (disabled) {
|
1006 |
+
$lis.addClass('disabled').children('a').attr('href', '#').attr('tabindex', -1);
|
1007 |
+
} else {
|
1008 |
+
$lis.removeClass('disabled').children('a').removeAttr('href').attr('tabindex', 0);
|
1009 |
+
}
|
1010 |
+
},
|
1011 |
+
|
1012 |
+
isDisabled: function () {
|
1013 |
+
return this.$element[0].disabled;
|
1014 |
+
},
|
1015 |
+
|
1016 |
+
checkDisabled: function () {
|
1017 |
+
var that = this;
|
1018 |
+
|
1019 |
+
if (this.isDisabled()) {
|
1020 |
+
this.$newElement.addClass('disabled');
|
1021 |
+
this.$button.addClass('disabled').attr('tabindex', -1);
|
1022 |
+
} else {
|
1023 |
+
if (this.$button.hasClass('disabled')) {
|
1024 |
+
this.$newElement.removeClass('disabled');
|
1025 |
+
this.$button.removeClass('disabled');
|
1026 |
+
}
|
1027 |
+
|
1028 |
+
if (this.$button.attr('tabindex') == -1 && !this.$element.data('tabindex')) {
|
1029 |
+
this.$button.removeAttr('tabindex');
|
1030 |
+
}
|
1031 |
+
}
|
1032 |
+
|
1033 |
+
this.$button.click(function () {
|
1034 |
+
return !that.isDisabled();
|
1035 |
+
});
|
1036 |
+
},
|
1037 |
+
|
1038 |
+
tabIndex: function () {
|
1039 |
+
if (this.$element.data('tabindex') !== this.$element.attr('tabindex') &&
|
1040 |
+
(this.$element.attr('tabindex') !== -98 && this.$element.attr('tabindex') !== '-98')) {
|
1041 |
+
this.$element.data('tabindex', this.$element.attr('tabindex'));
|
1042 |
+
this.$button.attr('tabindex', this.$element.data('tabindex'));
|
1043 |
+
}
|
1044 |
+
|
1045 |
+
this.$element.attr('tabindex', -98);
|
1046 |
+
},
|
1047 |
+
|
1048 |
+
clickListener: function () {
|
1049 |
+
var that = this,
|
1050 |
+
$document = $(document);
|
1051 |
+
|
1052 |
+
this.$newElement.on('touchstart.dropdown', '.dropdown-menu', function (e) {
|
1053 |
+
e.stopPropagation();
|
1054 |
+
});
|
1055 |
+
|
1056 |
+
$document.data('spaceSelect', false);
|
1057 |
+
|
1058 |
+
this.$button.on('keyup', function (e) {
|
1059 |
+
if (/(32)/.test(e.keyCode.toString(10)) && $document.data('spaceSelect')) {
|
1060 |
+
e.preventDefault();
|
1061 |
+
$document.data('spaceSelect', false);
|
1062 |
+
}
|
1063 |
+
});
|
1064 |
+
|
1065 |
+
this.$button.on('click', function () {
|
1066 |
+
that.setSize();
|
1067 |
+
});
|
1068 |
+
|
1069 |
+
this.$element.on('shown.bs.select', function () {
|
1070 |
+
if (!that.options.liveSearch && !that.multiple) {
|
1071 |
+
that.$menuInner.find('.selected a').focus();
|
1072 |
+
} else if (!that.multiple) {
|
1073 |
+
var selectedIndex = that.liObj[that.$element[0].selectedIndex];
|
1074 |
+
|
1075 |
+
if (typeof selectedIndex !== 'number' || that.options.size === false) return;
|
1076 |
+
|
1077 |
+
// scroll to selected option
|
1078 |
+
var offset = that.$lis.eq(selectedIndex)[0].offsetTop - that.$menuInner[0].offsetTop;
|
1079 |
+
offset = offset - that.$menuInner[0].offsetHeight/2 + that.sizeInfo.liHeight/2;
|
1080 |
+
that.$menuInner[0].scrollTop = offset;
|
1081 |
+
}
|
1082 |
+
});
|
1083 |
+
|
1084 |
+
this.$menuInner.on('click', 'li a', function (e) {
|
1085 |
+
var $this = $(this),
|
1086 |
+
clickedIndex = $this.parent().data('originalIndex'),
|
1087 |
+
prevValue = that.$element.val(),
|
1088 |
+
prevIndex = that.$element.prop('selectedIndex');
|
1089 |
+
|
1090 |
+
// Don't close on multi choice menu
|
1091 |
+
if (that.multiple) {
|
1092 |
+
e.stopPropagation();
|
1093 |
+
}
|
1094 |
+
|
1095 |
+
e.preventDefault();
|
1096 |
+
|
1097 |
+
//Don't run if we have been disabled
|
1098 |
+
if (!that.isDisabled() && !$this.parent().hasClass('disabled')) {
|
1099 |
+
var $options = that.$element.find('option'),
|
1100 |
+
$option = $options.eq(clickedIndex),
|
1101 |
+
state = $option.prop('selected'),
|
1102 |
+
$optgroup = $option.parent('optgroup'),
|
1103 |
+
maxOptions = that.options.maxOptions,
|
1104 |
+
maxOptionsGrp = $optgroup.data('maxOptions') || false;
|
1105 |
+
|
1106 |
+
if (!that.multiple) { // Deselect all others if not multi select box
|
1107 |
+
$options.prop('selected', false);
|
1108 |
+
$option.prop('selected', true);
|
1109 |
+
that.$menuInner.find('.selected').removeClass('selected');
|
1110 |
+
that.setSelected(clickedIndex, true);
|
1111 |
+
} else { // Toggle the one we have chosen if we are multi select.
|
1112 |
+
$option.prop('selected', !state);
|
1113 |
+
that.setSelected(clickedIndex, !state);
|
1114 |
+
$this.blur();
|
1115 |
+
|
1116 |
+
if (maxOptions !== false || maxOptionsGrp !== false) {
|
1117 |
+
var maxReached = maxOptions < $options.filter(':selected').length,
|
1118 |
+
maxReachedGrp = maxOptionsGrp < $optgroup.find('option:selected').length;
|
1119 |
+
|
1120 |
+
if ((maxOptions && maxReached) || (maxOptionsGrp && maxReachedGrp)) {
|
1121 |
+
if (maxOptions && maxOptions == 1) {
|
1122 |
+
$options.prop('selected', false);
|
1123 |
+
$option.prop('selected', true);
|
1124 |
+
that.$menuInner.find('.selected').removeClass('selected');
|
1125 |
+
that.setSelected(clickedIndex, true);
|
1126 |
+
} else if (maxOptionsGrp && maxOptionsGrp == 1) {
|
1127 |
+
$optgroup.find('option:selected').prop('selected', false);
|
1128 |
+
$option.prop('selected', true);
|
1129 |
+
var optgroupID = $this.parent().data('optgroup');
|
1130 |
+
that.$menuInner.find('[data-optgroup="' + optgroupID + '"]').removeClass('selected');
|
1131 |
+
that.setSelected(clickedIndex, true);
|
1132 |
+
} else {
|
1133 |
+
var maxOptionsArr = (typeof that.options.maxOptionsText === 'function') ?
|
1134 |
+
that.options.maxOptionsText(maxOptions, maxOptionsGrp) : that.options.maxOptionsText,
|
1135 |
+
maxTxt = maxOptionsArr[0].replace('{n}', maxOptions),
|
1136 |
+
maxTxtGrp = maxOptionsArr[1].replace('{n}', maxOptionsGrp),
|
1137 |
+
$notify = $('<div class="notify"></div>');
|
1138 |
+
// If {var} is set in array, replace it
|
1139 |
+
/** @deprecated */
|
1140 |
+
if (maxOptionsArr[2]) {
|
1141 |
+
maxTxt = maxTxt.replace('{var}', maxOptionsArr[2][maxOptions > 1 ? 0 : 1]);
|
1142 |
+
maxTxtGrp = maxTxtGrp.replace('{var}', maxOptionsArr[2][maxOptionsGrp > 1 ? 0 : 1]);
|
1143 |
+
}
|
1144 |
+
|
1145 |
+
$option.prop('selected', false);
|
1146 |
+
|
1147 |
+
that.$menu.append($notify);
|
1148 |
+
|
1149 |
+
if (maxOptions && maxReached) {
|
1150 |
+
$notify.append($('<div>' + maxTxt + '</div>'));
|
1151 |
+
that.$element.trigger('maxReached.bs.select');
|
1152 |
+
}
|
1153 |
+
|
1154 |
+
if (maxOptionsGrp && maxReachedGrp) {
|
1155 |
+
$notify.append($('<div>' + maxTxtGrp + '</div>'));
|
1156 |
+
that.$element.trigger('maxReachedGrp.bs.select');
|
1157 |
+
}
|
1158 |
+
|
1159 |
+
setTimeout(function () {
|
1160 |
+
that.setSelected(clickedIndex, false);
|
1161 |
+
}, 10);
|
1162 |
+
|
1163 |
+
$notify.delay(750).fadeOut(300, function () {
|
1164 |
+
$(this).remove();
|
1165 |
+
});
|
1166 |
+
}
|
1167 |
+
}
|
1168 |
+
}
|
1169 |
+
}
|
1170 |
+
|
1171 |
+
if (!that.multiple) {
|
1172 |
+
that.$button.focus();
|
1173 |
+
} else if (that.options.liveSearch) {
|
1174 |
+
that.$searchbox.focus();
|
1175 |
+
}
|
1176 |
+
|
1177 |
+
// Trigger select 'change'
|
1178 |
+
if ((prevValue != that.$element.val() && that.multiple) || (prevIndex != that.$element.prop('selectedIndex') && !that.multiple)) {
|
1179 |
+
// $option.prop('selected') is current option state (selected/unselected). state is previous option state.
|
1180 |
+
that.$element
|
1181 |
+
.trigger('changed.bs.select', [clickedIndex, $option.prop('selected'), state])
|
1182 |
+
.triggerNative('change');
|
1183 |
+
}
|
1184 |
+
}
|
1185 |
+
});
|
1186 |
+
|
1187 |
+
this.$menu.on('click', 'li.disabled a, .popover-title, .popover-title :not(.close)', function (e) {
|
1188 |
+
if (e.currentTarget == this) {
|
1189 |
+
e.preventDefault();
|
1190 |
+
e.stopPropagation();
|
1191 |
+
if (that.options.liveSearch && !$(e.target).hasClass('close')) {
|
1192 |
+
that.$searchbox.focus();
|
1193 |
+
} else {
|
1194 |
+
that.$button.focus();
|
1195 |
+
}
|
1196 |
+
}
|
1197 |
+
});
|
1198 |
+
|
1199 |
+
this.$menuInner.on('click', '.divider, .dropdown-header', function (e) {
|
1200 |
+
e.preventDefault();
|
1201 |
+
e.stopPropagation();
|
1202 |
+
if (that.options.liveSearch) {
|
1203 |
+
that.$searchbox.focus();
|
1204 |
+
} else {
|
1205 |
+
that.$button.focus();
|
1206 |
+
}
|
1207 |
+
});
|
1208 |
+
|
1209 |
+
this.$menu.on('click', '.popover-title .close', function () {
|
1210 |
+
that.$button.click();
|
1211 |
+
});
|
1212 |
+
|
1213 |
+
this.$searchbox.on('click', function (e) {
|
1214 |
+
e.stopPropagation();
|
1215 |
+
});
|
1216 |
+
|
1217 |
+
this.$menu.on('click', '.actions-btn', function (e) {
|
1218 |
+
if (that.options.liveSearch) {
|
1219 |
+
that.$searchbox.focus();
|
1220 |
+
} else {
|
1221 |
+
that.$button.focus();
|
1222 |
+
}
|
1223 |
+
|
1224 |
+
e.preventDefault();
|
1225 |
+
e.stopPropagation();
|
1226 |
+
|
1227 |
+
if ($(this).hasClass('bs-select-all')) {
|
1228 |
+
that.selectAll();
|
1229 |
+
} else {
|
1230 |
+
that.deselectAll();
|
1231 |
+
}
|
1232 |
+
});
|
1233 |
+
|
1234 |
+
this.$element.change(function () {
|
1235 |
+
that.render(false);
|
1236 |
+
});
|
1237 |
+
},
|
1238 |
+
|
1239 |
+
liveSearchListener: function () {
|
1240 |
+
var that = this,
|
1241 |
+
$no_results = $('<li class="no-results"></li>');
|
1242 |
+
|
1243 |
+
this.$button.on('click.dropdown.data-api touchstart.dropdown.data-api', function () {
|
1244 |
+
that.$menuInner.find('.active').removeClass('active');
|
1245 |
+
if (!!that.$searchbox.val()) {
|
1246 |
+
that.$searchbox.val('');
|
1247 |
+
that.$lis.not('.is-hidden').removeClass('hidden');
|
1248 |
+
if (!!$no_results.parent().length) $no_results.remove();
|
1249 |
+
}
|
1250 |
+
if (!that.multiple) that.$menuInner.find('.selected').addClass('active');
|
1251 |
+
setTimeout(function () {
|
1252 |
+
that.$searchbox.focus();
|
1253 |
+
}, 10);
|
1254 |
+
});
|
1255 |
+
|
1256 |
+
this.$searchbox.on('click.dropdown.data-api focus.dropdown.data-api touchend.dropdown.data-api', function (e) {
|
1257 |
+
e.stopPropagation();
|
1258 |
+
});
|
1259 |
+
|
1260 |
+
this.$searchbox.on('input propertychange', function () {
|
1261 |
+
if (that.$searchbox.val()) {
|
1262 |
+
var $searchBase = that.$lis.not('.is-hidden').removeClass('hidden').children('a');
|
1263 |
+
if (that.options.liveSearchNormalize) {
|
1264 |
+
$searchBase = $searchBase.not(':a' + that._searchStyle() + '("' + normalizeToBase(that.$searchbox.val()) + '")');
|
1265 |
+
} else {
|
1266 |
+
$searchBase = $searchBase.not(':' + that._searchStyle() + '("' + that.$searchbox.val() + '")');
|
1267 |
+
}
|
1268 |
+
$searchBase.parent().addClass('hidden');
|
1269 |
+
|
1270 |
+
that.$lis.filter('.dropdown-header').each(function () {
|
1271 |
+
var $this = $(this),
|
1272 |
+
optgroup = $this.data('optgroup');
|
1273 |
+
|
1274 |
+
if (that.$lis.filter('[data-optgroup=' + optgroup + ']').not($this).not('.hidden').length === 0) {
|
1275 |
+
$this.addClass('hidden');
|
1276 |
+
that.$lis.filter('[data-optgroup=' + optgroup + 'div]').addClass('hidden');
|
1277 |
+
}
|
1278 |
+
});
|
1279 |
+
|
1280 |
+
var $lisVisible = that.$lis.not('.hidden');
|
1281 |
+
|
1282 |
+
// hide divider if first or last visible, or if followed by another divider
|
1283 |
+
$lisVisible.each(function (index) {
|
1284 |
+
var $this = $(this);
|
1285 |
+
|
1286 |
+
if ($this.hasClass('divider') && (
|
1287 |
+
$this.index() === $lisVisible.first().index() ||
|
1288 |
+
$this.index() === $lisVisible.last().index() ||
|
1289 |
+
$lisVisible.eq(index + 1).hasClass('divider'))) {
|
1290 |
+
$this.addClass('hidden');
|
1291 |
+
}
|
1292 |
+
});
|
1293 |
+
|
1294 |
+
if (!that.$lis.not('.hidden, .no-results').length) {
|
1295 |
+
if (!!$no_results.parent().length) {
|
1296 |
+
$no_results.remove();
|
1297 |
+
}
|
1298 |
+
$no_results.html(that.options.noneResultsText.replace('{0}', '"' + htmlEscape(that.$searchbox.val()) + '"')).show();
|
1299 |
+
that.$menuInner.append($no_results);
|
1300 |
+
} else if (!!$no_results.parent().length) {
|
1301 |
+
$no_results.remove();
|
1302 |
+
}
|
1303 |
+
} else {
|
1304 |
+
that.$lis.not('.is-hidden').removeClass('hidden');
|
1305 |
+
if (!!$no_results.parent().length) {
|
1306 |
+
$no_results.remove();
|
1307 |
+
}
|
1308 |
+
}
|
1309 |
+
|
1310 |
+
that.$lis.filter('.active').removeClass('active');
|
1311 |
+
if (that.$searchbox.val()) that.$lis.not('.hidden, .divider, .dropdown-header').eq(0).addClass('active').children('a').focus();
|
1312 |
+
$(this).focus();
|
1313 |
+
});
|
1314 |
+
},
|
1315 |
+
|
1316 |
+
_searchStyle: function () {
|
1317 |
+
var styles = {
|
1318 |
+
begins: 'ibegins',
|
1319 |
+
startsWith: 'ibegins'
|
1320 |
+
};
|
1321 |
+
|
1322 |
+
return styles[this.options.liveSearchStyle] || 'icontains';
|
1323 |
+
},
|
1324 |
+
|
1325 |
+
val: function (value) {
|
1326 |
+
if (typeof value !== 'undefined') {
|
1327 |
+
this.$element.val(value);
|
1328 |
+
this.render();
|
1329 |
+
|
1330 |
+
return this.$element;
|
1331 |
+
} else {
|
1332 |
+
return this.$element.val();
|
1333 |
+
}
|
1334 |
+
},
|
1335 |
+
|
1336 |
+
changeAll: function (status) {
|
1337 |
+
if (typeof status === 'undefined') status = true;
|
1338 |
+
|
1339 |
+
this.findLis();
|
1340 |
+
|
1341 |
+
var $options = this.$element.find('option'),
|
1342 |
+
$lisVisible = this.$lis.not('.divider, .dropdown-header, .disabled, .hidden').toggleClass('selected', status),
|
1343 |
+
lisVisLen = $lisVisible.length,
|
1344 |
+
selectedOptions = [];
|
1345 |
+
|
1346 |
+
for (var i = 0; i < lisVisLen; i++) {
|
1347 |
+
var origIndex = $lisVisible[i].getAttribute('data-original-index');
|
1348 |
+
selectedOptions[selectedOptions.length] = $options.eq(origIndex)[0];
|
1349 |
+
}
|
1350 |
+
|
1351 |
+
$(selectedOptions).prop('selected', status);
|
1352 |
+
|
1353 |
+
this.render(false);
|
1354 |
+
|
1355 |
+
this.$element
|
1356 |
+
.trigger('changed.bs.select')
|
1357 |
+
.triggerNative('change');
|
1358 |
+
},
|
1359 |
+
|
1360 |
+
selectAll: function () {
|
1361 |
+
return this.changeAll(true);
|
1362 |
+
},
|
1363 |
+
|
1364 |
+
deselectAll: function () {
|
1365 |
+
return this.changeAll(false);
|
1366 |
+
},
|
1367 |
+
|
1368 |
+
toggle: function (e) {
|
1369 |
+
e = e || window.event;
|
1370 |
+
|
1371 |
+
if (e) e.stopPropagation();
|
1372 |
+
|
1373 |
+
this.$button.trigger('click');
|
1374 |
+
},
|
1375 |
+
|
1376 |
+
keydown: function (e) {
|
1377 |
+
var $this = $(this),
|
1378 |
+
$parent = $this.is('input') ? $this.parent().parent() : $this.parent(),
|
1379 |
+
$items,
|
1380 |
+
that = $parent.data('this'),
|
1381 |
+
index,
|
1382 |
+
next,
|
1383 |
+
first,
|
1384 |
+
last,
|
1385 |
+
prev,
|
1386 |
+
nextPrev,
|
1387 |
+
prevIndex,
|
1388 |
+
isActive,
|
1389 |
+
selector = ':not(.disabled, .hidden, .dropdown-header, .divider)',
|
1390 |
+
keyCodeMap = {
|
1391 |
+
32: ' ',
|
1392 |
+
48: '0',
|
1393 |
+
49: '1',
|
1394 |
+
50: '2',
|
1395 |
+
51: '3',
|
1396 |
+
52: '4',
|
1397 |
+
53: '5',
|
1398 |
+
54: '6',
|
1399 |
+
55: '7',
|
1400 |
+
56: '8',
|
1401 |
+
57: '9',
|
1402 |
+
59: ';',
|
1403 |
+
65: 'a',
|
1404 |
+
66: 'b',
|
1405 |
+
67: 'c',
|
1406 |
+
68: 'd',
|
1407 |
+
69: 'e',
|
1408 |
+
70: 'f',
|
1409 |
+
71: 'g',
|
1410 |
+
72: 'h',
|
1411 |
+
73: 'i',
|
1412 |
+
74: 'j',
|
1413 |
+
75: 'k',
|
1414 |
+
76: 'l',
|
1415 |
+
77: 'm',
|
1416 |
+
78: 'n',
|
1417 |
+
79: 'o',
|
1418 |
+
80: 'p',
|
1419 |
+
81: 'q',
|
1420 |
+
82: 'r',
|
1421 |
+
83: 's',
|
1422 |
+
84: 't',
|
1423 |
+
85: 'u',
|
1424 |
+
86: 'v',
|
1425 |
+
87: 'w',
|
1426 |
+
88: 'x',
|
1427 |
+
89: 'y',
|
1428 |
+
90: 'z',
|
1429 |
+
96: '0',
|
1430 |
+
97: '1',
|
1431 |
+
98: '2',
|
1432 |
+
99: '3',
|
1433 |
+
100: '4',
|
1434 |
+
101: '5',
|
1435 |
+
102: '6',
|
1436 |
+
103: '7',
|
1437 |
+
104: '8',
|
1438 |
+
105: '9'
|
1439 |
+
};
|
1440 |
+
|
1441 |
+
if (that.options.liveSearch) $parent = $this.parent().parent();
|
1442 |
+
|
1443 |
+
if (that.options.container) $parent = that.$menu;
|
1444 |
+
|
1445 |
+
$items = $('[role=menu] li', $parent);
|
1446 |
+
|
1447 |
+
isActive = that.$newElement.hasClass('open');
|
1448 |
+
|
1449 |
+
if (!isActive && (e.keyCode >= 48 && e.keyCode <= 57 || e.keyCode >= 96 && e.keyCode <= 105 || e.keyCode >= 65 && e.keyCode <= 90)) {
|
1450 |
+
if (!that.options.container) {
|
1451 |
+
that.setSize();
|
1452 |
+
that.$menu.parent().addClass('open');
|
1453 |
+
isActive = true;
|
1454 |
+
} else {
|
1455 |
+
that.$button.trigger('click');
|
1456 |
+
}
|
1457 |
+
that.$searchbox.focus();
|
1458 |
+
}
|
1459 |
+
|
1460 |
+
if (that.options.liveSearch) {
|
1461 |
+
if (/(^9$|27)/.test(e.keyCode.toString(10)) && isActive && that.$menu.find('.active').length === 0) {
|
1462 |
+
e.preventDefault();
|
1463 |
+
that.$menu.parent().removeClass('open');
|
1464 |
+
if (that.options.container) that.$newElement.removeClass('open');
|
1465 |
+
that.$button.focus();
|
1466 |
+
}
|
1467 |
+
// $items contains li elements when liveSearch is enabled
|
1468 |
+
$items = $('[role=menu] li' + selector, $parent);
|
1469 |
+
if (!$this.val() && !/(38|40)/.test(e.keyCode.toString(10))) {
|
1470 |
+
if ($items.filter('.active').length === 0) {
|
1471 |
+
$items = that.$menuInner.find('li');
|
1472 |
+
if (that.options.liveSearchNormalize) {
|
1473 |
+
$items = $items.filter(':a' + that._searchStyle() + '(' + normalizeToBase(keyCodeMap[e.keyCode]) + ')');
|
1474 |
+
} else {
|
1475 |
+
$items = $items.filter(':' + that._searchStyle() + '(' + keyCodeMap[e.keyCode] + ')');
|
1476 |
+
}
|
1477 |
+
}
|
1478 |
+
}
|
1479 |
+
}
|
1480 |
+
|
1481 |
+
if (!$items.length) return;
|
1482 |
+
|
1483 |
+
if (/(38|40)/.test(e.keyCode.toString(10))) {
|
1484 |
+
index = $items.index($items.find('a').filter(':focus').parent());
|
1485 |
+
first = $items.filter(selector).first().index();
|
1486 |
+
last = $items.filter(selector).last().index();
|
1487 |
+
next = $items.eq(index).nextAll(selector).eq(0).index();
|
1488 |
+
prev = $items.eq(index).prevAll(selector).eq(0).index();
|
1489 |
+
nextPrev = $items.eq(next).prevAll(selector).eq(0).index();
|
1490 |
+
|
1491 |
+
if (that.options.liveSearch) {
|
1492 |
+
$items.each(function (i) {
|
1493 |
+
if (!$(this).hasClass('disabled')) {
|
1494 |
+
$(this).data('index', i);
|
1495 |
+
}
|
1496 |
+
});
|
1497 |
+
index = $items.index($items.filter('.active'));
|
1498 |
+
first = $items.first().data('index');
|
1499 |
+
last = $items.last().data('index');
|
1500 |
+
next = $items.eq(index).nextAll().eq(0).data('index');
|
1501 |
+
prev = $items.eq(index).prevAll().eq(0).data('index');
|
1502 |
+
nextPrev = $items.eq(next).prevAll().eq(0).data('index');
|
1503 |
+
}
|
1504 |
+
|
1505 |
+
prevIndex = $this.data('prevIndex');
|
1506 |
+
|
1507 |
+
if (e.keyCode == 38) {
|
1508 |
+
if (that.options.liveSearch) index--;
|
1509 |
+
if (index != nextPrev && index > prev) index = prev;
|
1510 |
+
if (index < first) index = first;
|
1511 |
+
if (index == prevIndex) index = last;
|
1512 |
+
} else if (e.keyCode == 40) {
|
1513 |
+
if (that.options.liveSearch) index++;
|
1514 |
+
if (index == -1) index = 0;
|
1515 |
+
if (index != nextPrev && index < next) index = next;
|
1516 |
+
if (index > last) index = last;
|
1517 |
+
if (index == prevIndex) index = first;
|
1518 |
+
}
|
1519 |
+
|
1520 |
+
$this.data('prevIndex', index);
|
1521 |
+
|
1522 |
+
if (!that.options.liveSearch) {
|
1523 |
+
$items.eq(index).children('a').focus();
|
1524 |
+
} else {
|
1525 |
+
e.preventDefault();
|
1526 |
+
if (!$this.hasClass('dropdown-toggle')) {
|
1527 |
+
$items.removeClass('active').eq(index).addClass('active').children('a').focus();
|
1528 |
+
$this.focus();
|
1529 |
+
}
|
1530 |
+
}
|
1531 |
+
|
1532 |
+
} else if (!$this.is('input')) {
|
1533 |
+
var keyIndex = [],
|
1534 |
+
count,
|
1535 |
+
prevKey;
|
1536 |
+
|
1537 |
+
$items.each(function () {
|
1538 |
+
if (!$(this).hasClass('disabled')) {
|
1539 |
+
if ($.trim($(this).children('a').text().toLowerCase()).substring(0, 1) == keyCodeMap[e.keyCode]) {
|
1540 |
+
keyIndex.push($(this).index());
|
1541 |
+
}
|
1542 |
+
}
|
1543 |
+
});
|
1544 |
+
|
1545 |
+
count = $(document).data('keycount');
|
1546 |
+
count++;
|
1547 |
+
$(document).data('keycount', count);
|
1548 |
+
|
1549 |
+
prevKey = $.trim($(':focus').text().toLowerCase()).substring(0, 1);
|
1550 |
+
|
1551 |
+
if (prevKey != keyCodeMap[e.keyCode]) {
|
1552 |
+
count = 1;
|
1553 |
+
$(document).data('keycount', count);
|
1554 |
+
} else if (count >= keyIndex.length) {
|
1555 |
+
$(document).data('keycount', 0);
|
1556 |
+
if (count > keyIndex.length) count = 1;
|
1557 |
+
}
|
1558 |
+
|
1559 |
+
$items.eq(keyIndex[count - 1]).children('a').focus();
|
1560 |
+
}
|
1561 |
+
|
1562 |
+
// Select focused option if "Enter", "Spacebar" or "Tab" (when selectOnTab is true) are pressed inside the menu.
|
1563 |
+
if ((/(13|32)/.test(e.keyCode.toString(10)) || (/(^9$)/.test(e.keyCode.toString(10)) && that.options.selectOnTab)) && isActive) {
|
1564 |
+
if (!/(32)/.test(e.keyCode.toString(10))) e.preventDefault();
|
1565 |
+
if (!that.options.liveSearch) {
|
1566 |
+
var elem = $(':focus');
|
1567 |
+
elem.click();
|
1568 |
+
// Bring back focus for multiselects
|
1569 |
+
elem.focus();
|
1570 |
+
// Prevent screen from scrolling if the user hit the spacebar
|
1571 |
+
e.preventDefault();
|
1572 |
+
// Fixes spacebar selection of dropdown items in FF & IE
|
1573 |
+
$(document).data('spaceSelect', true);
|
1574 |
+
} else if (!/(32)/.test(e.keyCode.toString(10))) {
|
1575 |
+
that.$menuInner.find('.active a').click();
|
1576 |
+
$this.focus();
|
1577 |
+
}
|
1578 |
+
$(document).data('keycount', 0);
|
1579 |
+
}
|
1580 |
+
|
1581 |
+
if ((/(^9$|27)/.test(e.keyCode.toString(10)) && isActive && (that.multiple || that.options.liveSearch)) || (/(27)/.test(e.keyCode.toString(10)) && !isActive)) {
|
1582 |
+
that.$menu.parent().removeClass('open');
|
1583 |
+
if (that.options.container) that.$newElement.removeClass('open');
|
1584 |
+
that.$button.focus();
|
1585 |
+
}
|
1586 |
+
},
|
1587 |
+
|
1588 |
+
mobile: function () {
|
1589 |
+
this.$element.addClass('mobile-device');
|
1590 |
+
},
|
1591 |
+
|
1592 |
+
refresh: function () {
|
1593 |
+
this.$lis = null;
|
1594 |
+
this.liObj = {};
|
1595 |
+
this.reloadLi();
|
1596 |
+
this.render();
|
1597 |
+
this.checkDisabled();
|
1598 |
+
this.liHeight(true);
|
1599 |
+
this.setStyle();
|
1600 |
+
this.setWidth();
|
1601 |
+
if (this.$lis) this.$searchbox.trigger('propertychange');
|
1602 |
+
|
1603 |
+
this.$element.trigger('refreshed.bs.select');
|
1604 |
+
},
|
1605 |
+
|
1606 |
+
hide: function () {
|
1607 |
+
this.$newElement.hide();
|
1608 |
+
},
|
1609 |
+
|
1610 |
+
show: function () {
|
1611 |
+
this.$newElement.show();
|
1612 |
+
},
|
1613 |
+
|
1614 |
+
remove: function () {
|
1615 |
+
this.$newElement.remove();
|
1616 |
+
this.$element.remove();
|
1617 |
+
},
|
1618 |
+
|
1619 |
+
destroy: function () {
|
1620 |
+
this.$newElement.before(this.$element).remove();
|
1621 |
+
|
1622 |
+
if (this.$bsContainer) {
|
1623 |
+
this.$bsContainer.remove();
|
1624 |
+
} else {
|
1625 |
+
this.$menu.remove();
|
1626 |
+
}
|
1627 |
+
|
1628 |
+
this.$element
|
1629 |
+
.off('.bs.select')
|
1630 |
+
.removeData('selectpicker')
|
1631 |
+
.removeClass('bs-select-hidden selectpicker');
|
1632 |
+
}
|
1633 |
+
};
|
1634 |
+
|
1635 |
+
// SELECTPICKER PLUGIN DEFINITION
|
1636 |
+
// ==============================
|
1637 |
+
function Plugin(option, event) {
|
1638 |
+
// get the args of the outer function..
|
1639 |
+
var args = arguments;
|
1640 |
+
// The arguments of the function are explicitly re-defined from the argument list, because the shift causes them
|
1641 |
+
// to get lost/corrupted in android 2.3 and IE9 #715 #775
|
1642 |
+
var _option = option,
|
1643 |
+
_event = event;
|
1644 |
+
[].shift.apply(args);
|
1645 |
+
|
1646 |
+
var value;
|
1647 |
+
var chain = this.each(function () {
|
1648 |
+
var $this = $(this);
|
1649 |
+
if ($this.is('select')) {
|
1650 |
+
var data = $this.data('selectpicker'),
|
1651 |
+
options = typeof _option == 'object' && _option;
|
1652 |
+
|
1653 |
+
if (!data) {
|
1654 |
+
var config = $.extend({}, Selectpicker.DEFAULTS, $.fn.selectpicker.defaults || {}, $this.data(), options);
|
1655 |
+
config.template = $.extend({}, Selectpicker.DEFAULTS.template, ($.fn.selectpicker.defaults ? $.fn.selectpicker.defaults.template : {}), $this.data().template, options.template);
|
1656 |
+
$this.data('selectpicker', (data = new Selectpicker(this, config, _event)));
|
1657 |
+
} else if (options) {
|
1658 |
+
for (var i in options) {
|
1659 |
+
if (options.hasOwnProperty(i)) {
|
1660 |
+
data.options[i] = options[i];
|
1661 |
+
}
|
1662 |
+
}
|
1663 |
+
}
|
1664 |
+
|
1665 |
+
if (typeof _option == 'string') {
|
1666 |
+
if (data[_option] instanceof Function) {
|
1667 |
+
value = data[_option].apply(data, args);
|
1668 |
+
} else {
|
1669 |
+
value = data.options[_option];
|
1670 |
+
}
|
1671 |
+
}
|
1672 |
+
}
|
1673 |
+
});
|
1674 |
+
|
1675 |
+
if (typeof value !== 'undefined') {
|
1676 |
+
//noinspection JSUnusedAssignment
|
1677 |
+
return value;
|
1678 |
+
} else {
|
1679 |
+
return chain;
|
1680 |
+
}
|
1681 |
+
}
|
1682 |
+
|
1683 |
+
var old = $.fn.selectpicker;
|
1684 |
+
$.fn.selectpicker = Plugin;
|
1685 |
+
$.fn.selectpicker.Constructor = Selectpicker;
|
1686 |
+
|
1687 |
+
// SELECTPICKER NO CONFLICT
|
1688 |
+
// ========================
|
1689 |
+
$.fn.selectpicker.noConflict = function () {
|
1690 |
+
$.fn.selectpicker = old;
|
1691 |
+
return this;
|
1692 |
+
};
|
1693 |
+
|
1694 |
+
$(document)
|
1695 |
+
.data('keycount', 0)
|
1696 |
+
.on('keydown.bs.select', '.bootstrap-select [data-toggle=dropdown], .bootstrap-select [role="menu"], .bs-searchbox input', Selectpicker.prototype.keydown)
|
1697 |
+
.on('focusin.modal', '.bootstrap-select [data-toggle=dropdown], .bootstrap-select [role="menu"], .bs-searchbox input', function (e) {
|
1698 |
+
e.stopPropagation();
|
1699 |
+
});
|
1700 |
+
|
1701 |
+
// SELECTPICKER DATA-API
|
1702 |
+
// =====================
|
1703 |
+
$(window).on('load.bs.select.data-api', function () {
|
1704 |
+
$('.selectpicker').each(function () {
|
1705 |
+
var $selectpicker = $(this);
|
1706 |
+
Plugin.call($selectpicker, $selectpicker.data());
|
1707 |
+
})
|
1708 |
+
});
|
1709 |
+
})(jQuery);
|
inc/js/bootstrap.min.js
ADDED
@@ -0,0 +1,7 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
/*!
|
2 |
+
* Bootstrap v4.3.1 (https://getbootstrap.com/)
|
3 |
+
* Copyright 2011-2019 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors)
|
4 |
+
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
5 |
+
*/
|
6 |
+
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("jquery"),require("popper.js")):"function"==typeof define&&define.amd?define(["exports","jquery","popper.js"],e):e((t=t||self).bootstrap={},t.jQuery,t.Popper)}(this,function(t,g,u){"use strict";function i(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function s(t,e,n){return e&&i(t.prototype,e),n&&i(t,n),t}function l(o){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?arguments[t]:{},e=Object.keys(r);"function"==typeof Object.getOwnPropertySymbols&&(e=e.concat(Object.getOwnPropertySymbols(r).filter(function(t){return Object.getOwnPropertyDescriptor(r,t).enumerable}))),e.forEach(function(t){var e,n,i;e=o,i=r[n=t],n in e?Object.defineProperty(e,n,{value:i,enumerable:!0,configurable:!0,writable:!0}):e[n]=i})}return o}g=g&&g.hasOwnProperty("default")?g.default:g,u=u&&u.hasOwnProperty("default")?u.default:u;var e="transitionend";function n(t){var e=this,n=!1;return g(this).one(_.TRANSITION_END,function(){n=!0}),setTimeout(function(){n||_.triggerTransitionEnd(e)},t),this}var _={TRANSITION_END:"bsTransitionEnd",getUID:function(t){for(;t+=~~(1e6*Math.random()),document.getElementById(t););return t},getSelectorFromElement:function(t){var e=t.getAttribute("data-target");if(!e||"#"===e){var n=t.getAttribute("href");e=n&&"#"!==n?n.trim():""}try{return document.querySelector(e)?e:null}catch(t){return null}},getTransitionDurationFromElement:function(t){if(!t)return 0;var e=g(t).css("transition-duration"),n=g(t).css("transition-delay"),i=parseFloat(e),o=parseFloat(n);return i||o?(e=e.split(",")[0],n=n.split(",")[0],1e3*(parseFloat(e)+parseFloat(n))):0},reflow:function(t){return t.offsetHeight},triggerTransitionEnd:function(t){g(t).trigger(e)},supportsTransitionEnd:function(){return Boolean(e)},isElement:function(t){return(t[0]||t).nodeType},typeCheckConfig:function(t,e,n){for(var i in n)if(Object.prototype.hasOwnProperty.call(n,i)){var o=n[i],r=e[i],s=r&&_.isElement(r)?"element":(a=r,{}.toString.call(a).match(/\s([a-z]+)/i)[1].toLowerCase());if(!new RegExp(o).test(s))throw new Error(t.toUpperCase()+': Option "'+i+'" provided type "'+s+'" but expected type "'+o+'".')}var a},findShadowRoot:function(t){if(!document.documentElement.attachShadow)return null;if("function"!=typeof t.getRootNode)return t instanceof ShadowRoot?t:t.parentNode?_.findShadowRoot(t.parentNode):null;var e=t.getRootNode();return e instanceof ShadowRoot?e:null}};g.fn.emulateTransitionEnd=n,g.event.special[_.TRANSITION_END]={bindType:e,delegateType:e,handle:function(t){if(g(t.target).is(this))return t.handleObj.handler.apply(this,arguments)}};var o="alert",r="bs.alert",a="."+r,c=g.fn[o],h={CLOSE:"close"+a,CLOSED:"closed"+a,CLICK_DATA_API:"click"+a+".data-api"},f="alert",d="fade",m="show",p=function(){function i(t){this._element=t}var t=i.prototype;return t.close=function(t){var e=this._element;t&&(e=this._getRootElement(t)),this._triggerCloseEvent(e).isDefaultPrevented()||this._removeElement(e)},t.dispose=function(){g.removeData(this._element,r),this._element=null},t._getRootElement=function(t){var e=_.getSelectorFromElement(t),n=!1;return e&&(n=document.querySelector(e)),n||(n=g(t).closest("."+f)[0]),n},t._triggerCloseEvent=function(t){var e=g.Event(h.CLOSE);return g(t).trigger(e),e},t._removeElement=function(e){var n=this;if(g(e).removeClass(m),g(e).hasClass(d)){var t=_.getTransitionDurationFromElement(e);g(e).one(_.TRANSITION_END,function(t){return n._destroyElement(e,t)}).emulateTransitionEnd(t)}else this._destroyElement(e)},t._destroyElement=function(t){g(t).detach().trigger(h.CLOSED).remove()},i._jQueryInterface=function(n){return this.each(function(){var t=g(this),e=t.data(r);e||(e=new i(this),t.data(r,e)),"close"===n&&e[n](this)})},i._handleDismiss=function(e){return function(t){t&&t.preventDefault(),e.close(this)}},s(i,null,[{key:"VERSION",get:function(){return"4.3.1"}}]),i}();g(document).on(h.CLICK_DATA_API,'[data-dismiss="alert"]',p._handleDismiss(new p)),g.fn[o]=p._jQueryInterface,g.fn[o].Constructor=p,g.fn[o].noConflict=function(){return g.fn[o]=c,p._jQueryInterface};var v="button",y="bs.button",E="."+y,C=".data-api",T=g.fn[v],S="active",b="btn",I="focus",D='[data-toggle^="button"]',w='[data-toggle="buttons"]',A='input:not([type="hidden"])',N=".active",O=".btn",k={CLICK_DATA_API:"click"+E+C,FOCUS_BLUR_DATA_API:"focus"+E+C+" blur"+E+C},P=function(){function n(t){this._element=t}var t=n.prototype;return t.toggle=function(){var t=!0,e=!0,n=g(this._element).closest(w)[0];if(n){var i=this._element.querySelector(A);if(i){if("radio"===i.type)if(i.checked&&this._element.classList.contains(S))t=!1;else{var o=n.querySelector(N);o&&g(o).removeClass(S)}if(t){if(i.hasAttribute("disabled")||n.hasAttribute("disabled")||i.classList.contains("disabled")||n.classList.contains("disabled"))return;i.checked=!this._element.classList.contains(S),g(i).trigger("change")}i.focus(),e=!1}}e&&this._element.setAttribute("aria-pressed",!this._element.classList.contains(S)),t&&g(this._element).toggleClass(S)},t.dispose=function(){g.removeData(this._element,y),this._element=null},n._jQueryInterface=function(e){return this.each(function(){var t=g(this).data(y);t||(t=new n(this),g(this).data(y,t)),"toggle"===e&&t[e]()})},s(n,null,[{key:"VERSION",get:function(){return"4.3.1"}}]),n}();g(document).on(k.CLICK_DATA_API,D,function(t){t.preventDefault();var e=t.target;g(e).hasClass(b)||(e=g(e).closest(O)),P._jQueryInterface.call(g(e),"toggle")}).on(k.FOCUS_BLUR_DATA_API,D,function(t){var e=g(t.target).closest(O)[0];g(e).toggleClass(I,/^focus(in)?$/.test(t.type))}),g.fn[v]=P._jQueryInterface,g.fn[v].Constructor=P,g.fn[v].noConflict=function(){return g.fn[v]=T,P._jQueryInterface};var L="carousel",j="bs.carousel",H="."+j,R=".data-api",x=g.fn[L],F={interval:5e3,keyboard:!0,slide:!1,pause:"hover",wrap:!0,touch:!0},U={interval:"(number|boolean)",keyboard:"boolean",slide:"(boolean|string)",pause:"(string|boolean)",wrap:"boolean",touch:"boolean"},W="next",q="prev",M="left",K="right",Q={SLIDE:"slide"+H,SLID:"slid"+H,KEYDOWN:"keydown"+H,MOUSEENTER:"mouseenter"+H,MOUSELEAVE:"mouseleave"+H,TOUCHSTART:"touchstart"+H,TOUCHMOVE:"touchmove"+H,TOUCHEND:"touchend"+H,POINTERDOWN:"pointerdown"+H,POINTERUP:"pointerup"+H,DRAG_START:"dragstart"+H,LOAD_DATA_API:"load"+H+R,CLICK_DATA_API:"click"+H+R},B="carousel",V="active",Y="slide",z="carousel-item-right",X="carousel-item-left",$="carousel-item-next",G="carousel-item-prev",J="pointer-event",Z=".active",tt=".active.carousel-item",et=".carousel-item",nt=".carousel-item img",it=".carousel-item-next, .carousel-item-prev",ot=".carousel-indicators",rt="[data-slide], [data-slide-to]",st='[data-ride="carousel"]',at={TOUCH:"touch",PEN:"pen"},lt=function(){function r(t,e){this._items=null,this._interval=null,this._activeElement=null,this._isPaused=!1,this._isSliding=!1,this.touchTimeout=null,this.touchStartX=0,this.touchDeltaX=0,this._config=this._getConfig(e),this._element=t,this._indicatorsElement=this._element.querySelector(ot),this._touchSupported="ontouchstart"in document.documentElement||0<navigator.maxTouchPoints,this._pointerEvent=Boolean(window.PointerEvent||window.MSPointerEvent),this._addEventListeners()}var t=r.prototype;return t.next=function(){this._isSliding||this._slide(W)},t.nextWhenVisible=function(){!document.hidden&&g(this._element).is(":visible")&&"hidden"!==g(this._element).css("visibility")&&this.next()},t.prev=function(){this._isSliding||this._slide(q)},t.pause=function(t){t||(this._isPaused=!0),this._element.querySelector(it)&&(_.triggerTransitionEnd(this._element),this.cycle(!0)),clearInterval(this._interval),this._interval=null},t.cycle=function(t){t||(this._isPaused=!1),this._interval&&(clearInterval(this._interval),this._interval=null),this._config.interval&&!this._isPaused&&(this._interval=setInterval((document.visibilityState?this.nextWhenVisible:this.next).bind(this),this._config.interval))},t.to=function(t){var e=this;this._activeElement=this._element.querySelector(tt);var n=this._getItemIndex(this._activeElement);if(!(t>this._items.length-1||t<0))if(this._isSliding)g(this._element).one(Q.SLID,function(){return e.to(t)});else{if(n===t)return this.pause(),void this.cycle();var i=n<t?W:q;this._slide(i,this._items[t])}},t.dispose=function(){g(this._element).off(H),g.removeData(this._element,j),this._items=null,this._config=null,this._element=null,this._interval=null,this._isPaused=null,this._isSliding=null,this._activeElement=null,this._indicatorsElement=null},t._getConfig=function(t){return t=l({},F,t),_.typeCheckConfig(L,t,U),t},t._handleSwipe=function(){var t=Math.abs(this.touchDeltaX);if(!(t<=40)){var e=t/this.touchDeltaX;0<e&&this.prev(),e<0&&this.next()}},t._addEventListeners=function(){var e=this;this._config.keyboard&&g(this._element).on(Q.KEYDOWN,function(t){return e._keydown(t)}),"hover"===this._config.pause&&g(this._element).on(Q.MOUSEENTER,function(t){return e.pause(t)}).on(Q.MOUSELEAVE,function(t){return e.cycle(t)}),this._config.touch&&this._addTouchEventListeners()},t._addTouchEventListeners=function(){var n=this;if(this._touchSupported){var e=function(t){n._pointerEvent&&at[t.originalEvent.pointerType.toUpperCase()]?n.touchStartX=t.originalEvent.clientX:n._pointerEvent||(n.touchStartX=t.originalEvent.touches[0].clientX)},i=function(t){n._pointerEvent&&at[t.originalEvent.pointerType.toUpperCase()]&&(n.touchDeltaX=t.originalEvent.clientX-n.touchStartX),n._handleSwipe(),"hover"===n._config.pause&&(n.pause(),n.touchTimeout&&clearTimeout(n.touchTimeout),n.touchTimeout=setTimeout(function(t){return n.cycle(t)},500+n._config.interval))};g(this._element.querySelectorAll(nt)).on(Q.DRAG_START,function(t){return t.preventDefault()}),this._pointerEvent?(g(this._element).on(Q.POINTERDOWN,function(t){return e(t)}),g(this._element).on(Q.POINTERUP,function(t){return i(t)}),this._element.classList.add(J)):(g(this._element).on(Q.TOUCHSTART,function(t){return e(t)}),g(this._element).on(Q.TOUCHMOVE,function(t){var e;(e=t).originalEvent.touches&&1<e.originalEvent.touches.length?n.touchDeltaX=0:n.touchDeltaX=e.originalEvent.touches[0].clientX-n.touchStartX}),g(this._element).on(Q.TOUCHEND,function(t){return i(t)}))}},t._keydown=function(t){if(!/input|textarea/i.test(t.target.tagName))switch(t.which){case 37:t.preventDefault(),this.prev();break;case 39:t.preventDefault(),this.next()}},t._getItemIndex=function(t){return this._items=t&&t.parentNode?[].slice.call(t.parentNode.querySelectorAll(et)):[],this._items.indexOf(t)},t._getItemByDirection=function(t,e){var n=t===W,i=t===q,o=this._getItemIndex(e),r=this._items.length-1;if((i&&0===o||n&&o===r)&&!this._config.wrap)return e;var s=(o+(t===q?-1:1))%this._items.length;return-1===s?this._items[this._items.length-1]:this._items[s]},t._triggerSlideEvent=function(t,e){var n=this._getItemIndex(t),i=this._getItemIndex(this._element.querySelector(tt)),o=g.Event(Q.SLIDE,{relatedTarget:t,direction:e,from:i,to:n});return g(this._element).trigger(o),o},t._setActiveIndicatorElement=function(t){if(this._indicatorsElement){var e=[].slice.call(this._indicatorsElement.querySelectorAll(Z));g(e).removeClass(V);var n=this._indicatorsElement.children[this._getItemIndex(t)];n&&g(n).addClass(V)}},t._slide=function(t,e){var n,i,o,r=this,s=this._element.querySelector(tt),a=this._getItemIndex(s),l=e||s&&this._getItemByDirection(t,s),c=this._getItemIndex(l),h=Boolean(this._interval);if(o=t===W?(n=X,i=$,M):(n=z,i=G,K),l&&g(l).hasClass(V))this._isSliding=!1;else if(!this._triggerSlideEvent(l,o).isDefaultPrevented()&&s&&l){this._isSliding=!0,h&&this.pause(),this._setActiveIndicatorElement(l);var u=g.Event(Q.SLID,{relatedTarget:l,direction:o,from:a,to:c});if(g(this._element).hasClass(Y)){g(l).addClass(i),_.reflow(l),g(s).addClass(n),g(l).addClass(n);var f=parseInt(l.getAttribute("data-interval"),10);this._config.interval=f?(this._config.defaultInterval=this._config.defaultInterval||this._config.interval,f):this._config.defaultInterval||this._config.interval;var d=_.getTransitionDurationFromElement(s);g(s).one(_.TRANSITION_END,function(){g(l).removeClass(n+" "+i).addClass(V),g(s).removeClass(V+" "+i+" "+n),r._isSliding=!1,setTimeout(function(){return g(r._element).trigger(u)},0)}).emulateTransitionEnd(d)}else g(s).removeClass(V),g(l).addClass(V),this._isSliding=!1,g(this._element).trigger(u);h&&this.cycle()}},r._jQueryInterface=function(i){return this.each(function(){var t=g(this).data(j),e=l({},F,g(this).data());"object"==typeof i&&(e=l({},e,i));var n="string"==typeof i?i:e.slide;if(t||(t=new r(this,e),g(this).data(j,t)),"number"==typeof i)t.to(i);else if("string"==typeof n){if("undefined"==typeof t[n])throw new TypeError('No method named "'+n+'"');t[n]()}else e.interval&&e.ride&&(t.pause(),t.cycle())})},r._dataApiClickHandler=function(t){var e=_.getSelectorFromElement(this);if(e){var n=g(e)[0];if(n&&g(n).hasClass(B)){var i=l({},g(n).data(),g(this).data()),o=this.getAttribute("data-slide-to");o&&(i.interval=!1),r._jQueryInterface.call(g(n),i),o&&g(n).data(j).to(o),t.preventDefault()}}},s(r,null,[{key:"VERSION",get:function(){return"4.3.1"}},{key:"Default",get:function(){return F}}]),r}();g(document).on(Q.CLICK_DATA_API,rt,lt._dataApiClickHandler),g(window).on(Q.LOAD_DATA_API,function(){for(var t=[].slice.call(document.querySelectorAll(st)),e=0,n=t.length;e<n;e++){var i=g(t[e]);lt._jQueryInterface.call(i,i.data())}}),g.fn[L]=lt._jQueryInterface,g.fn[L].Constructor=lt,g.fn[L].noConflict=function(){return g.fn[L]=x,lt._jQueryInterface};var ct="collapse",ht="bs.collapse",ut="."+ht,ft=g.fn[ct],dt={toggle:!0,parent:""},gt={toggle:"boolean",parent:"(string|element)"},_t={SHOW:"show"+ut,SHOWN:"shown"+ut,HIDE:"hide"+ut,HIDDEN:"hidden"+ut,CLICK_DATA_API:"click"+ut+".data-api"},mt="show",pt="collapse",vt="collapsing",yt="collapsed",Et="width",Ct="height",Tt=".show, .collapsing",St='[data-toggle="collapse"]',bt=function(){function a(e,t){this._isTransitioning=!1,this._element=e,this._config=this._getConfig(t),this._triggerArray=[].slice.call(document.querySelectorAll('[data-toggle="collapse"][href="#'+e.id+'"],[data-toggle="collapse"][data-target="#'+e.id+'"]'));for(var n=[].slice.call(document.querySelectorAll(St)),i=0,o=n.length;i<o;i++){var r=n[i],s=_.getSelectorFromElement(r),a=[].slice.call(document.querySelectorAll(s)).filter(function(t){return t===e});null!==s&&0<a.length&&(this._selector=s,this._triggerArray.push(r))}this._parent=this._config.parent?this._getParent():null,this._config.parent||this._addAriaAndCollapsedClass(this._element,this._triggerArray),this._config.toggle&&this.toggle()}var t=a.prototype;return t.toggle=function(){g(this._element).hasClass(mt)?this.hide():this.show()},t.show=function(){var t,e,n=this;if(!this._isTransitioning&&!g(this._element).hasClass(mt)&&(this._parent&&0===(t=[].slice.call(this._parent.querySelectorAll(Tt)).filter(function(t){return"string"==typeof n._config.parent?t.getAttribute("data-parent")===n._config.parent:t.classList.contains(pt)})).length&&(t=null),!(t&&(e=g(t).not(this._selector).data(ht))&&e._isTransitioning))){var i=g.Event(_t.SHOW);if(g(this._element).trigger(i),!i.isDefaultPrevented()){t&&(a._jQueryInterface.call(g(t).not(this._selector),"hide"),e||g(t).data(ht,null));var o=this._getDimension();g(this._element).removeClass(pt).addClass(vt),this._element.style[o]=0,this._triggerArray.length&&g(this._triggerArray).removeClass(yt).attr("aria-expanded",!0),this.setTransitioning(!0);var r="scroll"+(o[0].toUpperCase()+o.slice(1)),s=_.getTransitionDurationFromElement(this._element);g(this._element).one(_.TRANSITION_END,function(){g(n._element).removeClass(vt).addClass(pt).addClass(mt),n._element.style[o]="",n.setTransitioning(!1),g(n._element).trigger(_t.SHOWN)}).emulateTransitionEnd(s),this._element.style[o]=this._element[r]+"px"}}},t.hide=function(){var t=this;if(!this._isTransitioning&&g(this._element).hasClass(mt)){var e=g.Event(_t.HIDE);if(g(this._element).trigger(e),!e.isDefaultPrevented()){var n=this._getDimension();this._element.style[n]=this._element.getBoundingClientRect()[n]+"px",_.reflow(this._element),g(this._element).addClass(vt).removeClass(pt).removeClass(mt);var i=this._triggerArray.length;if(0<i)for(var o=0;o<i;o++){var r=this._triggerArray[o],s=_.getSelectorFromElement(r);if(null!==s)g([].slice.call(document.querySelectorAll(s))).hasClass(mt)||g(r).addClass(yt).attr("aria-expanded",!1)}this.setTransitioning(!0);this._element.style[n]="";var a=_.getTransitionDurationFromElement(this._element);g(this._element).one(_.TRANSITION_END,function(){t.setTransitioning(!1),g(t._element).removeClass(vt).addClass(pt).trigger(_t.HIDDEN)}).emulateTransitionEnd(a)}}},t.setTransitioning=function(t){this._isTransitioning=t},t.dispose=function(){g.removeData(this._element,ht),this._config=null,this._parent=null,this._element=null,this._triggerArray=null,this._isTransitioning=null},t._getConfig=function(t){return(t=l({},dt,t)).toggle=Boolean(t.toggle),_.typeCheckConfig(ct,t,gt),t},t._getDimension=function(){return g(this._element).hasClass(Et)?Et:Ct},t._getParent=function(){var t,n=this;_.isElement(this._config.parent)?(t=this._config.parent,"undefined"!=typeof this._config.parent.jquery&&(t=this._config.parent[0])):t=document.querySelector(this._config.parent);var e='[data-toggle="collapse"][data-parent="'+this._config.parent+'"]',i=[].slice.call(t.querySelectorAll(e));return g(i).each(function(t,e){n._addAriaAndCollapsedClass(a._getTargetFromElement(e),[e])}),t},t._addAriaAndCollapsedClass=function(t,e){var n=g(t).hasClass(mt);e.length&&g(e).toggleClass(yt,!n).attr("aria-expanded",n)},a._getTargetFromElement=function(t){var e=_.getSelectorFromElement(t);return e?document.querySelector(e):null},a._jQueryInterface=function(i){return this.each(function(){var t=g(this),e=t.data(ht),n=l({},dt,t.data(),"object"==typeof i&&i?i:{});if(!e&&n.toggle&&/show|hide/.test(i)&&(n.toggle=!1),e||(e=new a(this,n),t.data(ht,e)),"string"==typeof i){if("undefined"==typeof e[i])throw new TypeError('No method named "'+i+'"');e[i]()}})},s(a,null,[{key:"VERSION",get:function(){return"4.3.1"}},{key:"Default",get:function(){return dt}}]),a}();g(document).on(_t.CLICK_DATA_API,St,function(t){"A"===t.currentTarget.tagName&&t.preventDefault();var n=g(this),e=_.getSelectorFromElement(this),i=[].slice.call(document.querySelectorAll(e));g(i).each(function(){var t=g(this),e=t.data(ht)?"toggle":n.data();bt._jQueryInterface.call(t,e)})}),g.fn[ct]=bt._jQueryInterface,g.fn[ct].Constructor=bt,g.fn[ct].noConflict=function(){return g.fn[ct]=ft,bt._jQueryInterface};var It="dropdown",Dt="bs.dropdown",wt="."+Dt,At=".data-api",Nt=g.fn[It],Ot=new RegExp("38|40|27"),kt={HIDE:"hide"+wt,HIDDEN:"hidden"+wt,SHOW:"show"+wt,SHOWN:"shown"+wt,CLICK:"click"+wt,CLICK_DATA_API:"click"+wt+At,KEYDOWN_DATA_API:"keydown"+wt+At,KEYUP_DATA_API:"keyup"+wt+At},Pt="disabled",Lt="show",jt="dropup",Ht="dropright",Rt="dropleft",xt="dropdown-menu-right",Ft="position-static",Ut='[data-toggle="dropdown"]',Wt=".dropdown form",qt=".dropdown-menu",Mt=".navbar-nav",Kt=".dropdown-menu .dropdown-item:not(.disabled):not(:disabled)",Qt="top-start",Bt="top-end",Vt="bottom-start",Yt="bottom-end",zt="right-start",Xt="left-start",$t={offset:0,flip:!0,boundary:"scrollParent",reference:"toggle",display:"dynamic"},Gt={offset:"(number|string|function)",flip:"boolean",boundary:"(string|element)",reference:"(string|element)",display:"string"},Jt=function(){function c(t,e){this._element=t,this._popper=null,this._config=this._getConfig(e),this._menu=this._getMenuElement(),this._inNavbar=this._detectNavbar(),this._addEventListeners()}var t=c.prototype;return t.toggle=function(){if(!this._element.disabled&&!g(this._element).hasClass(Pt)){var t=c._getParentFromElement(this._element),e=g(this._menu).hasClass(Lt);if(c._clearMenus(),!e){var n={relatedTarget:this._element},i=g.Event(kt.SHOW,n);if(g(t).trigger(i),!i.isDefaultPrevented()){if(!this._inNavbar){if("undefined"==typeof u)throw new TypeError("Bootstrap's dropdowns require Popper.js (https://popper.js.org/)");var o=this._element;"parent"===this._config.reference?o=t:_.isElement(this._config.reference)&&(o=this._config.reference,"undefined"!=typeof this._config.reference.jquery&&(o=this._config.reference[0])),"scrollParent"!==this._config.boundary&&g(t).addClass(Ft),this._popper=new u(o,this._menu,this._getPopperConfig())}"ontouchstart"in document.documentElement&&0===g(t).closest(Mt).length&&g(document.body).children().on("mouseover",null,g.noop),this._element.focus(),this._element.setAttribute("aria-expanded",!0),g(this._menu).toggleClass(Lt),g(t).toggleClass(Lt).trigger(g.Event(kt.SHOWN,n))}}}},t.show=function(){if(!(this._element.disabled||g(this._element).hasClass(Pt)||g(this._menu).hasClass(Lt))){var t={relatedTarget:this._element},e=g.Event(kt.SHOW,t),n=c._getParentFromElement(this._element);g(n).trigger(e),e.isDefaultPrevented()||(g(this._menu).toggleClass(Lt),g(n).toggleClass(Lt).trigger(g.Event(kt.SHOWN,t)))}},t.hide=function(){if(!this._element.disabled&&!g(this._element).hasClass(Pt)&&g(this._menu).hasClass(Lt)){var t={relatedTarget:this._element},e=g.Event(kt.HIDE,t),n=c._getParentFromElement(this._element);g(n).trigger(e),e.isDefaultPrevented()||(g(this._menu).toggleClass(Lt),g(n).toggleClass(Lt).trigger(g.Event(kt.HIDDEN,t)))}},t.dispose=function(){g.removeData(this._element,Dt),g(this._element).off(wt),this._element=null,(this._menu=null)!==this._popper&&(this._popper.destroy(),this._popper=null)},t.update=function(){this._inNavbar=this._detectNavbar(),null!==this._popper&&this._popper.scheduleUpdate()},t._addEventListeners=function(){var e=this;g(this._element).on(kt.CLICK,function(t){t.preventDefault(),t.stopPropagation(),e.toggle()})},t._getConfig=function(t){return t=l({},this.constructor.Default,g(this._element).data(),t),_.typeCheckConfig(It,t,this.constructor.DefaultType),t},t._getMenuElement=function(){if(!this._menu){var t=c._getParentFromElement(this._element);t&&(this._menu=t.querySelector(qt))}return this._menu},t._getPlacement=function(){var t=g(this._element.parentNode),e=Vt;return t.hasClass(jt)?(e=Qt,g(this._menu).hasClass(xt)&&(e=Bt)):t.hasClass(Ht)?e=zt:t.hasClass(Rt)?e=Xt:g(this._menu).hasClass(xt)&&(e=Yt),e},t._detectNavbar=function(){return 0<g(this._element).closest(".navbar").length},t._getOffset=function(){var e=this,t={};return"function"==typeof this._config.offset?t.fn=function(t){return t.offsets=l({},t.offsets,e._config.offset(t.offsets,e._element)||{}),t}:t.offset=this._config.offset,t},t._getPopperConfig=function(){var t={placement:this._getPlacement(),modifiers:{offset:this._getOffset(),flip:{enabled:this._config.flip},preventOverflow:{boundariesElement:this._config.boundary}}};return"static"===this._config.display&&(t.modifiers.applyStyle={enabled:!1}),t},c._jQueryInterface=function(e){return this.each(function(){var t=g(this).data(Dt);if(t||(t=new c(this,"object"==typeof e?e:null),g(this).data(Dt,t)),"string"==typeof e){if("undefined"==typeof t[e])throw new TypeError('No method named "'+e+'"');t[e]()}})},c._clearMenus=function(t){if(!t||3!==t.which&&("keyup"!==t.type||9===t.which))for(var e=[].slice.call(document.querySelectorAll(Ut)),n=0,i=e.length;n<i;n++){var o=c._getParentFromElement(e[n]),r=g(e[n]).data(Dt),s={relatedTarget:e[n]};if(t&&"click"===t.type&&(s.clickEvent=t),r){var a=r._menu;if(g(o).hasClass(Lt)&&!(t&&("click"===t.type&&/input|textarea/i.test(t.target.tagName)||"keyup"===t.type&&9===t.which)&&g.contains(o,t.target))){var l=g.Event(kt.HIDE,s);g(o).trigger(l),l.isDefaultPrevented()||("ontouchstart"in document.documentElement&&g(document.body).children().off("mouseover",null,g.noop),e[n].setAttribute("aria-expanded","false"),g(a).removeClass(Lt),g(o).removeClass(Lt).trigger(g.Event(kt.HIDDEN,s)))}}}},c._getParentFromElement=function(t){var e,n=_.getSelectorFromElement(t);return n&&(e=document.querySelector(n)),e||t.parentNode},c._dataApiKeydownHandler=function(t){if((/input|textarea/i.test(t.target.tagName)?!(32===t.which||27!==t.which&&(40!==t.which&&38!==t.which||g(t.target).closest(qt).length)):Ot.test(t.which))&&(t.preventDefault(),t.stopPropagation(),!this.disabled&&!g(this).hasClass(Pt))){var e=c._getParentFromElement(this),n=g(e).hasClass(Lt);if(n&&(!n||27!==t.which&&32!==t.which)){var i=[].slice.call(e.querySelectorAll(Kt));if(0!==i.length){var o=i.indexOf(t.target);38===t.which&&0<o&&o--,40===t.which&&o<i.length-1&&o++,o<0&&(o=0),i[o].focus()}}else{if(27===t.which){var r=e.querySelector(Ut);g(r).trigger("focus")}g(this).trigger("click")}}},s(c,null,[{key:"VERSION",get:function(){return"4.3.1"}},{key:"Default",get:function(){return $t}},{key:"DefaultType",get:function(){return Gt}}]),c}();g(document).on(kt.KEYDOWN_DATA_API,Ut,Jt._dataApiKeydownHandler).on(kt.KEYDOWN_DATA_API,qt,Jt._dataApiKeydownHandler).on(kt.CLICK_DATA_API+" "+kt.KEYUP_DATA_API,Jt._clearMenus).on(kt.CLICK_DATA_API,Ut,function(t){t.preventDefault(),t.stopPropagation(),Jt._jQueryInterface.call(g(this),"toggle")}).on(kt.CLICK_DATA_API,Wt,function(t){t.stopPropagation()}),g.fn[It]=Jt._jQueryInterface,g.fn[It].Constructor=Jt,g.fn[It].noConflict=function(){return g.fn[It]=Nt,Jt._jQueryInterface};var Zt="modal",te="bs.modal",ee="."+te,ne=g.fn[Zt],ie={backdrop:!0,keyboard:!0,focus:!0,show:!0},oe={backdrop:"(boolean|string)",keyboard:"boolean",focus:"boolean",show:"boolean"},re={HIDE:"hide"+ee,HIDDEN:"hidden"+ee,SHOW:"show"+ee,SHOWN:"shown"+ee,FOCUSIN:"focusin"+ee,RESIZE:"resize"+ee,CLICK_DISMISS:"click.dismiss"+ee,KEYDOWN_DISMISS:"keydown.dismiss"+ee,MOUSEUP_DISMISS:"mouseup.dismiss"+ee,MOUSEDOWN_DISMISS:"mousedown.dismiss"+ee,CLICK_DATA_API:"click"+ee+".data-api"},se="modal-dialog-scrollable",ae="modal-scrollbar-measure",le="modal-backdrop",ce="modal-open",he="fade",ue="show",fe=".modal-dialog",de=".modal-body",ge='[data-toggle="modal"]',_e='[data-dismiss="modal"]',me=".fixed-top, .fixed-bottom, .is-fixed, .sticky-top",pe=".sticky-top",ve=function(){function o(t,e){this._config=this._getConfig(e),this._element=t,this._dialog=t.querySelector(fe),this._backdrop=null,this._isShown=!1,this._isBodyOverflowing=!1,this._ignoreBackdropClick=!1,this._isTransitioning=!1,this._scrollbarWidth=0}var t=o.prototype;return t.toggle=function(t){return this._isShown?this.hide():this.show(t)},t.show=function(t){var e=this;if(!this._isShown&&!this._isTransitioning){g(this._element).hasClass(he)&&(this._isTransitioning=!0);var n=g.Event(re.SHOW,{relatedTarget:t});g(this._element).trigger(n),this._isShown||n.isDefaultPrevented()||(this._isShown=!0,this._checkScrollbar(),this._setScrollbar(),this._adjustDialog(),this._setEscapeEvent(),this._setResizeEvent(),g(this._element).on(re.CLICK_DISMISS,_e,function(t){return e.hide(t)}),g(this._dialog).on(re.MOUSEDOWN_DISMISS,function(){g(e._element).one(re.MOUSEUP_DISMISS,function(t){g(t.target).is(e._element)&&(e._ignoreBackdropClick=!0)})}),this._showBackdrop(function(){return e._showElement(t)}))}},t.hide=function(t){var e=this;if(t&&t.preventDefault(),this._isShown&&!this._isTransitioning){var n=g.Event(re.HIDE);if(g(this._element).trigger(n),this._isShown&&!n.isDefaultPrevented()){this._isShown=!1;var i=g(this._element).hasClass(he);if(i&&(this._isTransitioning=!0),this._setEscapeEvent(),this._setResizeEvent(),g(document).off(re.FOCUSIN),g(this._element).removeClass(ue),g(this._element).off(re.CLICK_DISMISS),g(this._dialog).off(re.MOUSEDOWN_DISMISS),i){var o=_.getTransitionDurationFromElement(this._element);g(this._element).one(_.TRANSITION_END,function(t){return e._hideModal(t)}).emulateTransitionEnd(o)}else this._hideModal()}}},t.dispose=function(){[window,this._element,this._dialog].forEach(function(t){return g(t).off(ee)}),g(document).off(re.FOCUSIN),g.removeData(this._element,te),this._config=null,this._element=null,this._dialog=null,this._backdrop=null,this._isShown=null,this._isBodyOverflowing=null,this._ignoreBackdropClick=null,this._isTransitioning=null,this._scrollbarWidth=null},t.handleUpdate=function(){this._adjustDialog()},t._getConfig=function(t){return t=l({},ie,t),_.typeCheckConfig(Zt,t,oe),t},t._showElement=function(t){var e=this,n=g(this._element).hasClass(he);this._element.parentNode&&this._element.parentNode.nodeType===Node.ELEMENT_NODE||document.body.appendChild(this._element),this._element.style.display="block",this._element.removeAttribute("aria-hidden"),this._element.setAttribute("aria-modal",!0),g(this._dialog).hasClass(se)?this._dialog.querySelector(de).scrollTop=0:this._element.scrollTop=0,n&&_.reflow(this._element),g(this._element).addClass(ue),this._config.focus&&this._enforceFocus();var i=g.Event(re.SHOWN,{relatedTarget:t}),o=function(){e._config.focus&&e._element.focus(),e._isTransitioning=!1,g(e._element).trigger(i)};if(n){var r=_.getTransitionDurationFromElement(this._dialog);g(this._dialog).one(_.TRANSITION_END,o).emulateTransitionEnd(r)}else o()},t._enforceFocus=function(){var e=this;g(document).off(re.FOCUSIN).on(re.FOCUSIN,function(t){document!==t.target&&e._element!==t.target&&0===g(e._element).has(t.target).length&&e._element.focus()})},t._setEscapeEvent=function(){var e=this;this._isShown&&this._config.keyboard?g(this._element).on(re.KEYDOWN_DISMISS,function(t){27===t.which&&(t.preventDefault(),e.hide())}):this._isShown||g(this._element).off(re.KEYDOWN_DISMISS)},t._setResizeEvent=function(){var e=this;this._isShown?g(window).on(re.RESIZE,function(t){return e.handleUpdate(t)}):g(window).off(re.RESIZE)},t._hideModal=function(){var t=this;this._element.style.display="none",this._element.setAttribute("aria-hidden",!0),this._element.removeAttribute("aria-modal"),this._isTransitioning=!1,this._showBackdrop(function(){g(document.body).removeClass(ce),t._resetAdjustments(),t._resetScrollbar(),g(t._element).trigger(re.HIDDEN)})},t._removeBackdrop=function(){this._backdrop&&(g(this._backdrop).remove(),this._backdrop=null)},t._showBackdrop=function(t){var e=this,n=g(this._element).hasClass(he)?he:"";if(this._isShown&&this._config.backdrop){if(this._backdrop=document.createElement("div"),this._backdrop.className=le,n&&this._backdrop.classList.add(n),g(this._backdrop).appendTo(document.body),g(this._element).on(re.CLICK_DISMISS,function(t){e._ignoreBackdropClick?e._ignoreBackdropClick=!1:t.target===t.currentTarget&&("static"===e._config.backdrop?e._element.focus():e.hide())}),n&&_.reflow(this._backdrop),g(this._backdrop).addClass(ue),!t)return;if(!n)return void t();var i=_.getTransitionDurationFromElement(this._backdrop);g(this._backdrop).one(_.TRANSITION_END,t).emulateTransitionEnd(i)}else if(!this._isShown&&this._backdrop){g(this._backdrop).removeClass(ue);var o=function(){e._removeBackdrop(),t&&t()};if(g(this._element).hasClass(he)){var r=_.getTransitionDurationFromElement(this._backdrop);g(this._backdrop).one(_.TRANSITION_END,o).emulateTransitionEnd(r)}else o()}else t&&t()},t._adjustDialog=function(){var t=this._element.scrollHeight>document.documentElement.clientHeight;!this._isBodyOverflowing&&t&&(this._element.style.paddingLeft=this._scrollbarWidth+"px"),this._isBodyOverflowing&&!t&&(this._element.style.paddingRight=this._scrollbarWidth+"px")},t._resetAdjustments=function(){this._element.style.paddingLeft="",this._element.style.paddingRight=""},t._checkScrollbar=function(){var t=document.body.getBoundingClientRect();this._isBodyOverflowing=t.left+t.right<window.innerWidth,this._scrollbarWidth=this._getScrollbarWidth()},t._setScrollbar=function(){var o=this;if(this._isBodyOverflowing){var t=[].slice.call(document.querySelectorAll(me)),e=[].slice.call(document.querySelectorAll(pe));g(t).each(function(t,e){var n=e.style.paddingRight,i=g(e).css("padding-right");g(e).data("padding-right",n).css("padding-right",parseFloat(i)+o._scrollbarWidth+"px")}),g(e).each(function(t,e){var n=e.style.marginRight,i=g(e).css("margin-right");g(e).data("margin-right",n).css("margin-right",parseFloat(i)-o._scrollbarWidth+"px")});var n=document.body.style.paddingRight,i=g(document.body).css("padding-right");g(document.body).data("padding-right",n).css("padding-right",parseFloat(i)+this._scrollbarWidth+"px")}g(document.body).addClass(ce)},t._resetScrollbar=function(){var t=[].slice.call(document.querySelectorAll(me));g(t).each(function(t,e){var n=g(e).data("padding-right");g(e).removeData("padding-right"),e.style.paddingRight=n||""});var e=[].slice.call(document.querySelectorAll(""+pe));g(e).each(function(t,e){var n=g(e).data("margin-right");"undefined"!=typeof n&&g(e).css("margin-right",n).removeData("margin-right")});var n=g(document.body).data("padding-right");g(document.body).removeData("padding-right"),document.body.style.paddingRight=n||""},t._getScrollbarWidth=function(){var t=document.createElement("div");t.className=ae,document.body.appendChild(t);var e=t.getBoundingClientRect().width-t.clientWidth;return document.body.removeChild(t),e},o._jQueryInterface=function(n,i){return this.each(function(){var t=g(this).data(te),e=l({},ie,g(this).data(),"object"==typeof n&&n?n:{});if(t||(t=new o(this,e),g(this).data(te,t)),"string"==typeof n){if("undefined"==typeof t[n])throw new TypeError('No method named "'+n+'"');t[n](i)}else e.show&&t.show(i)})},s(o,null,[{key:"VERSION",get:function(){return"4.3.1"}},{key:"Default",get:function(){return ie}}]),o}();g(document).on(re.CLICK_DATA_API,ge,function(t){var e,n=this,i=_.getSelectorFromElement(this);i&&(e=document.querySelector(i));var o=g(e).data(te)?"toggle":l({},g(e).data(),g(this).data());"A"!==this.tagName&&"AREA"!==this.tagName||t.preventDefault();var r=g(e).one(re.SHOW,function(t){t.isDefaultPrevented()||r.one(re.HIDDEN,function(){g(n).is(":visible")&&n.focus()})});ve._jQueryInterface.call(g(e),o,this)}),g.fn[Zt]=ve._jQueryInterface,g.fn[Zt].Constructor=ve,g.fn[Zt].noConflict=function(){return g.fn[Zt]=ne,ve._jQueryInterface};var ye=["background","cite","href","itemtype","longdesc","poster","src","xlink:href"],Ee={"*":["class","dir","id","lang","role",/^aria-[\w-]*$/i],a:["target","href","title","rel"],area:[],b:[],br:[],col:[],code:[],div:[],em:[],hr:[],h1:[],h2:[],h3:[],h4:[],h5:[],h6:[],i:[],img:["src","alt","title","width","height"],li:[],ol:[],p:[],pre:[],s:[],small:[],span:[],sub:[],sup:[],strong:[],u:[],ul:[]},Ce=/^(?:(?:https?|mailto|ftp|tel|file):|[^&:/?#]*(?:[/?#]|$))/gi,Te=/^data:(?:image\/(?:bmp|gif|jpeg|jpg|png|tiff|webp)|video\/(?:mpeg|mp4|ogg|webm)|audio\/(?:mp3|oga|ogg|opus));base64,[a-z0-9+/]+=*$/i;function Se(t,s,e){if(0===t.length)return t;if(e&&"function"==typeof e)return e(t);for(var n=(new window.DOMParser).parseFromString(t,"text/html"),a=Object.keys(s),l=[].slice.call(n.body.querySelectorAll("*")),i=function(t,e){var n=l[t],i=n.nodeName.toLowerCase();if(-1===a.indexOf(n.nodeName.toLowerCase()))return n.parentNode.removeChild(n),"continue";var o=[].slice.call(n.attributes),r=[].concat(s["*"]||[],s[i]||[]);o.forEach(function(t){(function(t,e){var n=t.nodeName.toLowerCase();if(-1!==e.indexOf(n))return-1===ye.indexOf(n)||Boolean(t.nodeValue.match(Ce)||t.nodeValue.match(Te));for(var i=e.filter(function(t){return t instanceof RegExp}),o=0,r=i.length;o<r;o++)if(n.match(i[o]))return!0;return!1})(t,r)||n.removeAttribute(t.nodeName)})},o=0,r=l.length;o<r;o++)i(o);return n.body.innerHTML}var be="tooltip",Ie="bs.tooltip",De="."+Ie,we=g.fn[be],Ae="bs-tooltip",Ne=new RegExp("(^|\\s)"+Ae+"\\S+","g"),Oe=["sanitize","whiteList","sanitizeFn"],ke={animation:"boolean",template:"string",title:"(string|element|function)",trigger:"string",delay:"(number|object)",html:"boolean",selector:"(string|boolean)",placement:"(string|function)",offset:"(number|string|function)",container:"(string|element|boolean)",fallbackPlacement:"(string|array)",boundary:"(string|element)",sanitize:"boolean",sanitizeFn:"(null|function)",whiteList:"object"},Pe={AUTO:"auto",TOP:"top",RIGHT:"right",BOTTOM:"bottom",LEFT:"left"},Le={animation:!0,template:'<div class="tooltip" role="tooltip"><div class="arrow"></div><div class="tooltip-inner"></div></div>',trigger:"hover focus",title:"",delay:0,html:!1,selector:!1,placement:"top",offset:0,container:!1,fallbackPlacement:"flip",boundary:"scrollParent",sanitize:!0,sanitizeFn:null,whiteList:Ee},je="show",He="out",Re={HIDE:"hide"+De,HIDDEN:"hidden"+De,SHOW:"show"+De,SHOWN:"shown"+De,INSERTED:"inserted"+De,CLICK:"click"+De,FOCUSIN:"focusin"+De,FOCUSOUT:"focusout"+De,MOUSEENTER:"mouseenter"+De,MOUSELEAVE:"mouseleave"+De},xe="fade",Fe="show",Ue=".tooltip-inner",We=".arrow",qe="hover",Me="focus",Ke="click",Qe="manual",Be=function(){function i(t,e){if("undefined"==typeof u)throw new TypeError("Bootstrap's tooltips require Popper.js (https://popper.js.org/)");this._isEnabled=!0,this._timeout=0,this._hoverState="",this._activeTrigger={},this._popper=null,this.element=t,this.config=this._getConfig(e),this.tip=null,this._setListeners()}var t=i.prototype;return t.enable=function(){this._isEnabled=!0},t.disable=function(){this._isEnabled=!1},t.toggleEnabled=function(){this._isEnabled=!this._isEnabled},t.toggle=function(t){if(this._isEnabled)if(t){var e=this.constructor.DATA_KEY,n=g(t.currentTarget).data(e);n||(n=new this.constructor(t.currentTarget,this._getDelegateConfig()),g(t.currentTarget).data(e,n)),n._activeTrigger.click=!n._activeTrigger.click,n._isWithActiveTrigger()?n._enter(null,n):n._leave(null,n)}else{if(g(this.getTipElement()).hasClass(Fe))return void this._leave(null,this);this._enter(null,this)}},t.dispose=function(){clearTimeout(this._timeout),g.removeData(this.element,this.constructor.DATA_KEY),g(this.element).off(this.constructor.EVENT_KEY),g(this.element).closest(".modal").off("hide.bs.modal"),this.tip&&g(this.tip).remove(),this._isEnabled=null,this._timeout=null,this._hoverState=null,(this._activeTrigger=null)!==this._popper&&this._popper.destroy(),this._popper=null,this.element=null,this.config=null,this.tip=null},t.show=function(){var e=this;if("none"===g(this.element).css("display"))throw new Error("Please use show on visible elements");var t=g.Event(this.constructor.Event.SHOW);if(this.isWithContent()&&this._isEnabled){g(this.element).trigger(t);var n=_.findShadowRoot(this.element),i=g.contains(null!==n?n:this.element.ownerDocument.documentElement,this.element);if(t.isDefaultPrevented()||!i)return;var o=this.getTipElement(),r=_.getUID(this.constructor.NAME);o.setAttribute("id",r),this.element.setAttribute("aria-describedby",r),this.setContent(),this.config.animation&&g(o).addClass(xe);var s="function"==typeof this.config.placement?this.config.placement.call(this,o,this.element):this.config.placement,a=this._getAttachment(s);this.addAttachmentClass(a);var l=this._getContainer();g(o).data(this.constructor.DATA_KEY,this),g.contains(this.element.ownerDocument.documentElement,this.tip)||g(o).appendTo(l),g(this.element).trigger(this.constructor.Event.INSERTED),this._popper=new u(this.element,o,{placement:a,modifiers:{offset:this._getOffset(),flip:{behavior:this.config.fallbackPlacement},arrow:{element:We},preventOverflow:{boundariesElement:this.config.boundary}},onCreate:function(t){t.originalPlacement!==t.placement&&e._handlePopperPlacementChange(t)},onUpdate:function(t){return e._handlePopperPlacementChange(t)}}),g(o).addClass(Fe),"ontouchstart"in document.documentElement&&g(document.body).children().on("mouseover",null,g.noop);var c=function(){e.config.animation&&e._fixTransition();var t=e._hoverState;e._hoverState=null,g(e.element).trigger(e.constructor.Event.SHOWN),t===He&&e._leave(null,e)};if(g(this.tip).hasClass(xe)){var h=_.getTransitionDurationFromElement(this.tip);g(this.tip).one(_.TRANSITION_END,c).emulateTransitionEnd(h)}else c()}},t.hide=function(t){var e=this,n=this.getTipElement(),i=g.Event(this.constructor.Event.HIDE),o=function(){e._hoverState!==je&&n.parentNode&&n.parentNode.removeChild(n),e._cleanTipClass(),e.element.removeAttribute("aria-describedby"),g(e.element).trigger(e.constructor.Event.HIDDEN),null!==e._popper&&e._popper.destroy(),t&&t()};if(g(this.element).trigger(i),!i.isDefaultPrevented()){if(g(n).removeClass(Fe),"ontouchstart"in document.documentElement&&g(document.body).children().off("mouseover",null,g.noop),this._activeTrigger[Ke]=!1,this._activeTrigger[Me]=!1,this._activeTrigger[qe]=!1,g(this.tip).hasClass(xe)){var r=_.getTransitionDurationFromElement(n);g(n).one(_.TRANSITION_END,o).emulateTransitionEnd(r)}else o();this._hoverState=""}},t.update=function(){null!==this._popper&&this._popper.scheduleUpdate()},t.isWithContent=function(){return Boolean(this.getTitle())},t.addAttachmentClass=function(t){g(this.getTipElement()).addClass(Ae+"-"+t)},t.getTipElement=function(){return this.tip=this.tip||g(this.config.template)[0],this.tip},t.setContent=function(){var t=this.getTipElement();this.setElementContent(g(t.querySelectorAll(Ue)),this.getTitle()),g(t).removeClass(xe+" "+Fe)},t.setElementContent=function(t,e){"object"!=typeof e||!e.nodeType&&!e.jquery?this.config.html?(this.config.sanitize&&(e=Se(e,this.config.whiteList,this.config.sanitizeFn)),t.html(e)):t.text(e):this.config.html?g(e).parent().is(t)||t.empty().append(e):t.text(g(e).text())},t.getTitle=function(){var t=this.element.getAttribute("data-original-title");return t||(t="function"==typeof this.config.title?this.config.title.call(this.element):this.config.title),t},t._getOffset=function(){var e=this,t={};return"function"==typeof this.config.offset?t.fn=function(t){return t.offsets=l({},t.offsets,e.config.offset(t.offsets,e.element)||{}),t}:t.offset=this.config.offset,t},t._getContainer=function(){return!1===this.config.container?document.body:_.isElement(this.config.container)?g(this.config.container):g(document).find(this.config.container)},t._getAttachment=function(t){return Pe[t.toUpperCase()]},t._setListeners=function(){var i=this;this.config.trigger.split(" ").forEach(function(t){if("click"===t)g(i.element).on(i.constructor.Event.CLICK,i.config.selector,function(t){return i.toggle(t)});else if(t!==Qe){var e=t===qe?i.constructor.Event.MOUSEENTER:i.constructor.Event.FOCUSIN,n=t===qe?i.constructor.Event.MOUSELEAVE:i.constructor.Event.FOCUSOUT;g(i.element).on(e,i.config.selector,function(t){return i._enter(t)}).on(n,i.config.selector,function(t){return i._leave(t)})}}),g(this.element).closest(".modal").on("hide.bs.modal",function(){i.element&&i.hide()}),this.config.selector?this.config=l({},this.config,{trigger:"manual",selector:""}):this._fixTitle()},t._fixTitle=function(){var t=typeof this.element.getAttribute("data-original-title");(this.element.getAttribute("title")||"string"!==t)&&(this.element.setAttribute("data-original-title",this.element.getAttribute("title")||""),this.element.setAttribute("title",""))},t._enter=function(t,e){var n=this.constructor.DATA_KEY;(e=e||g(t.currentTarget).data(n))||(e=new this.constructor(t.currentTarget,this._getDelegateConfig()),g(t.currentTarget).data(n,e)),t&&(e._activeTrigger["focusin"===t.type?Me:qe]=!0),g(e.getTipElement()).hasClass(Fe)||e._hoverState===je?e._hoverState=je:(clearTimeout(e._timeout),e._hoverState=je,e.config.delay&&e.config.delay.show?e._timeout=setTimeout(function(){e._hoverState===je&&e.show()},e.config.delay.show):e.show())},t._leave=function(t,e){var n=this.constructor.DATA_KEY;(e=e||g(t.currentTarget).data(n))||(e=new this.constructor(t.currentTarget,this._getDelegateConfig()),g(t.currentTarget).data(n,e)),t&&(e._activeTrigger["focusout"===t.type?Me:qe]=!1),e._isWithActiveTrigger()||(clearTimeout(e._timeout),e._hoverState=He,e.config.delay&&e.config.delay.hide?e._timeout=setTimeout(function(){e._hoverState===He&&e.hide()},e.config.delay.hide):e.hide())},t._isWithActiveTrigger=function(){for(var t in this._activeTrigger)if(this._activeTrigger[t])return!0;return!1},t._getConfig=function(t){var e=g(this.element).data();return Object.keys(e).forEach(function(t){-1!==Oe.indexOf(t)&&delete e[t]}),"number"==typeof(t=l({},this.constructor.Default,e,"object"==typeof t&&t?t:{})).delay&&(t.delay={show:t.delay,hide:t.delay}),"number"==typeof t.title&&(t.title=t.title.toString()),"number"==typeof t.content&&(t.content=t.content.toString()),_.typeCheckConfig(be,t,this.constructor.DefaultType),t.sanitize&&(t.template=Se(t.template,t.whiteList,t.sanitizeFn)),t},t._getDelegateConfig=function(){var t={};if(this.config)for(var e in this.config)this.constructor.Default[e]!==this.config[e]&&(t[e]=this.config[e]);return t},t._cleanTipClass=function(){var t=g(this.getTipElement()),e=t.attr("class").match(Ne);null!==e&&e.length&&t.removeClass(e.join(""))},t._handlePopperPlacementChange=function(t){var e=t.instance;this.tip=e.popper,this._cleanTipClass(),this.addAttachmentClass(this._getAttachment(t.placement))},t._fixTransition=function(){var t=this.getTipElement(),e=this.config.animation;null===t.getAttribute("x-placement")&&(g(t).removeClass(xe),this.config.animation=!1,this.hide(),this.show(),this.config.animation=e)},i._jQueryInterface=function(n){return this.each(function(){var t=g(this).data(Ie),e="object"==typeof n&&n;if((t||!/dispose|hide/.test(n))&&(t||(t=new i(this,e),g(this).data(Ie,t)),"string"==typeof n)){if("undefined"==typeof t[n])throw new TypeError('No method named "'+n+'"');t[n]()}})},s(i,null,[{key:"VERSION",get:function(){return"4.3.1"}},{key:"Default",get:function(){return Le}},{key:"NAME",get:function(){return be}},{key:"DATA_KEY",get:function(){return Ie}},{key:"Event",get:function(){return Re}},{key:"EVENT_KEY",get:function(){return De}},{key:"DefaultType",get:function(){return ke}}]),i}();g.fn[be]=Be._jQueryInterface,g.fn[be].Constructor=Be,g.fn[be].noConflict=function(){return g.fn[be]=we,Be._jQueryInterface};var Ve="popover",Ye="bs.popover",ze="."+Ye,Xe=g.fn[Ve],$e="bs-popover",Ge=new RegExp("(^|\\s)"+$e+"\\S+","g"),Je=l({},Be.Default,{placement:"right",trigger:"click",content:"",template:'<div class="popover" role="tooltip"><div class="arrow"></div><h3 class="popover-header"></h3><div class="popover-body"></div></div>'}),Ze=l({},Be.DefaultType,{content:"(string|element|function)"}),tn="fade",en="show",nn=".popover-header",on=".popover-body",rn={HIDE:"hide"+ze,HIDDEN:"hidden"+ze,SHOW:"show"+ze,SHOWN:"shown"+ze,INSERTED:"inserted"+ze,CLICK:"click"+ze,FOCUSIN:"focusin"+ze,FOCUSOUT:"focusout"+ze,MOUSEENTER:"mouseenter"+ze,MOUSELEAVE:"mouseleave"+ze},sn=function(t){var e,n;function i(){return t.apply(this,arguments)||this}n=t,(e=i).prototype=Object.create(n.prototype),(e.prototype.constructor=e).__proto__=n;var o=i.prototype;return o.isWithContent=function(){return this.getTitle()||this._getContent()},o.addAttachmentClass=function(t){g(this.getTipElement()).addClass($e+"-"+t)},o.getTipElement=function(){return this.tip=this.tip||g(this.config.template)[0],this.tip},o.setContent=function(){var t=g(this.getTipElement());this.setElementContent(t.find(nn),this.getTitle());var e=this._getContent();"function"==typeof e&&(e=e.call(this.element)),this.setElementContent(t.find(on),e),t.removeClass(tn+" "+en)},o._getContent=function(){return this.element.getAttribute("data-content")||this.config.content},o._cleanTipClass=function(){var t=g(this.getTipElement()),e=t.attr("class").match(Ge);null!==e&&0<e.length&&t.removeClass(e.join(""))},i._jQueryInterface=function(n){return this.each(function(){var t=g(this).data(Ye),e="object"==typeof n?n:null;if((t||!/dispose|hide/.test(n))&&(t||(t=new i(this,e),g(this).data(Ye,t)),"string"==typeof n)){if("undefined"==typeof t[n])throw new TypeError('No method named "'+n+'"');t[n]()}})},s(i,null,[{key:"VERSION",get:function(){return"4.3.1"}},{key:"Default",get:function(){return Je}},{key:"NAME",get:function(){return Ve}},{key:"DATA_KEY",get:function(){return Ye}},{key:"Event",get:function(){return rn}},{key:"EVENT_KEY",get:function(){return ze}},{key:"DefaultType",get:function(){return Ze}}]),i}(Be);g.fn[Ve]=sn._jQueryInterface,g.fn[Ve].Constructor=sn,g.fn[Ve].noConflict=function(){return g.fn[Ve]=Xe,sn._jQueryInterface};var an="scrollspy",ln="bs.scrollspy",cn="."+ln,hn=g.fn[an],un={offset:10,method:"auto",target:""},fn={offset:"number",method:"string",target:"(string|element)"},dn={ACTIVATE:"activate"+cn,SCROLL:"scroll"+cn,LOAD_DATA_API:"load"+cn+".data-api"},gn="dropdown-item",_n="active",mn='[data-spy="scroll"]',pn=".nav, .list-group",vn=".nav-link",yn=".nav-item",En=".list-group-item",Cn=".dropdown",Tn=".dropdown-item",Sn=".dropdown-toggle",bn="offset",In="position",Dn=function(){function n(t,e){var n=this;this._element=t,this._scrollElement="BODY"===t.tagName?window:t,this._config=this._getConfig(e),this._selector=this._config.target+" "+vn+","+this._config.target+" "+En+","+this._config.target+" "+Tn,this._offsets=[],this._targets=[],this._activeTarget=null,this._scrollHeight=0,g(this._scrollElement).on(dn.SCROLL,function(t){return n._process(t)}),this.refresh(),this._process()}var t=n.prototype;return t.refresh=function(){var e=this,t=this._scrollElement===this._scrollElement.window?bn:In,o="auto"===this._config.method?t:this._config.method,r=o===In?this._getScrollTop():0;this._offsets=[],this._targets=[],this._scrollHeight=this._getScrollHeight(),[].slice.call(document.querySelectorAll(this._selector)).map(function(t){var e,n=_.getSelectorFromElement(t);if(n&&(e=document.querySelector(n)),e){var i=e.getBoundingClientRect();if(i.width||i.height)return[g(e)[o]().top+r,n]}return null}).filter(function(t){return t}).sort(function(t,e){return t[0]-e[0]}).forEach(function(t){e._offsets.push(t[0]),e._targets.push(t[1])})},t.dispose=function(){g.removeData(this._element,ln),g(this._scrollElement).off(cn),this._element=null,this._scrollElement=null,this._config=null,this._selector=null,this._offsets=null,this._targets=null,this._activeTarget=null,this._scrollHeight=null},t._getConfig=function(t){if("string"!=typeof(t=l({},un,"object"==typeof t&&t?t:{})).target){var e=g(t.target).attr("id");e||(e=_.getUID(an),g(t.target).attr("id",e)),t.target="#"+e}return _.typeCheckConfig(an,t,fn),t},t._getScrollTop=function(){return this._scrollElement===window?this._scrollElement.pageYOffset:this._scrollElement.scrollTop},t._getScrollHeight=function(){return this._scrollElement.scrollHeight||Math.max(document.body.scrollHeight,document.documentElement.scrollHeight)},t._getOffsetHeight=function(){return this._scrollElement===window?window.innerHeight:this._scrollElement.getBoundingClientRect().height},t._process=function(){var t=this._getScrollTop()+this._config.offset,e=this._getScrollHeight(),n=this._config.offset+e-this._getOffsetHeight();if(this._scrollHeight!==e&&this.refresh(),n<=t){var i=this._targets[this._targets.length-1];this._activeTarget!==i&&this._activate(i)}else{if(this._activeTarget&&t<this._offsets[0]&&0<this._offsets[0])return this._activeTarget=null,void this._clear();for(var o=this._offsets.length;o--;){this._activeTarget!==this._targets[o]&&t>=this._offsets[o]&&("undefined"==typeof this._offsets[o+1]||t<this._offsets[o+1])&&this._activate(this._targets[o])}}},t._activate=function(e){this._activeTarget=e,this._clear();var t=this._selector.split(",").map(function(t){return t+'[data-target="'+e+'"],'+t+'[href="'+e+'"]'}),n=g([].slice.call(document.querySelectorAll(t.join(","))));n.hasClass(gn)?(n.closest(Cn).find(Sn).addClass(_n),n.addClass(_n)):(n.addClass(_n),n.parents(pn).prev(vn+", "+En).addClass(_n),n.parents(pn).prev(yn).children(vn).addClass(_n)),g(this._scrollElement).trigger(dn.ACTIVATE,{relatedTarget:e})},t._clear=function(){[].slice.call(document.querySelectorAll(this._selector)).filter(function(t){return t.classList.contains(_n)}).forEach(function(t){return t.classList.remove(_n)})},n._jQueryInterface=function(e){return this.each(function(){var t=g(this).data(ln);if(t||(t=new n(this,"object"==typeof e&&e),g(this).data(ln,t)),"string"==typeof e){if("undefined"==typeof t[e])throw new TypeError('No method named "'+e+'"');t[e]()}})},s(n,null,[{key:"VERSION",get:function(){return"4.3.1"}},{key:"Default",get:function(){return un}}]),n}();g(window).on(dn.LOAD_DATA_API,function(){for(var t=[].slice.call(document.querySelectorAll(mn)),e=t.length;e--;){var n=g(t[e]);Dn._jQueryInterface.call(n,n.data())}}),g.fn[an]=Dn._jQueryInterface,g.fn[an].Constructor=Dn,g.fn[an].noConflict=function(){return g.fn[an]=hn,Dn._jQueryInterface};var wn="bs.tab",An="."+wn,Nn=g.fn.tab,On={HIDE:"hide"+An,HIDDEN:"hidden"+An,SHOW:"show"+An,SHOWN:"shown"+An,CLICK_DATA_API:"click"+An+".data-api"},kn="dropdown-menu",Pn="active",Ln="disabled",jn="fade",Hn="show",Rn=".dropdown",xn=".nav, .list-group",Fn=".active",Un="> li > .active",Wn='[data-toggle="tab"], [data-toggle="pill"], [data-toggle="list"]',qn=".dropdown-toggle",Mn="> .dropdown-menu .active",Kn=function(){function i(t){this._element=t}var t=i.prototype;return t.show=function(){var n=this;if(!(this._element.parentNode&&this._element.parentNode.nodeType===Node.ELEMENT_NODE&&g(this._element).hasClass(Pn)||g(this._element).hasClass(Ln))){var t,i,e=g(this._element).closest(xn)[0],o=_.getSelectorFromElement(this._element);if(e){var r="UL"===e.nodeName||"OL"===e.nodeName?Un:Fn;i=(i=g.makeArray(g(e).find(r)))[i.length-1]}var s=g.Event(On.HIDE,{relatedTarget:this._element}),a=g.Event(On.SHOW,{relatedTarget:i});if(i&&g(i).trigger(s),g(this._element).trigger(a),!a.isDefaultPrevented()&&!s.isDefaultPrevented()){o&&(t=document.querySelector(o)),this._activate(this._element,e);var l=function(){var t=g.Event(On.HIDDEN,{relatedTarget:n._element}),e=g.Event(On.SHOWN,{relatedTarget:i});g(i).trigger(t),g(n._element).trigger(e)};t?this._activate(t,t.parentNode,l):l()}}},t.dispose=function(){g.removeData(this._element,wn),this._element=null},t._activate=function(t,e,n){var i=this,o=(!e||"UL"!==e.nodeName&&"OL"!==e.nodeName?g(e).children(Fn):g(e).find(Un))[0],r=n&&o&&g(o).hasClass(jn),s=function(){return i._transitionComplete(t,o,n)};if(o&&r){var a=_.getTransitionDurationFromElement(o);g(o).removeClass(Hn).one(_.TRANSITION_END,s).emulateTransitionEnd(a)}else s()},t._transitionComplete=function(t,e,n){if(e){g(e).removeClass(Pn);var i=g(e.parentNode).find(Mn)[0];i&&g(i).removeClass(Pn),"tab"===e.getAttribute("role")&&e.setAttribute("aria-selected",!1)}if(g(t).addClass(Pn),"tab"===t.getAttribute("role")&&t.setAttribute("aria-selected",!0),_.reflow(t),t.classList.contains(jn)&&t.classList.add(Hn),t.parentNode&&g(t.parentNode).hasClass(kn)){var o=g(t).closest(Rn)[0];if(o){var r=[].slice.call(o.querySelectorAll(qn));g(r).addClass(Pn)}t.setAttribute("aria-expanded",!0)}n&&n()},i._jQueryInterface=function(n){return this.each(function(){var t=g(this),e=t.data(wn);if(e||(e=new i(this),t.data(wn,e)),"string"==typeof n){if("undefined"==typeof e[n])throw new TypeError('No method named "'+n+'"');e[n]()}})},s(i,null,[{key:"VERSION",get:function(){return"4.3.1"}}]),i}();g(document).on(On.CLICK_DATA_API,Wn,function(t){t.preventDefault(),Kn._jQueryInterface.call(g(this),"show")}),g.fn.tab=Kn._jQueryInterface,g.fn.tab.Constructor=Kn,g.fn.tab.noConflict=function(){return g.fn.tab=Nn,Kn._jQueryInterface};var Qn="toast",Bn="bs.toast",Vn="."+Bn,Yn=g.fn[Qn],zn={CLICK_DISMISS:"click.dismiss"+Vn,HIDE:"hide"+Vn,HIDDEN:"hidden"+Vn,SHOW:"show"+Vn,SHOWN:"shown"+Vn},Xn="fade",$n="hide",Gn="show",Jn="showing",Zn={animation:"boolean",autohide:"boolean",delay:"number"},ti={animation:!0,autohide:!0,delay:500},ei='[data-dismiss="toast"]',ni=function(){function i(t,e){this._element=t,this._config=this._getConfig(e),this._timeout=null,this._setListeners()}var t=i.prototype;return t.show=function(){var t=this;g(this._element).trigger(zn.SHOW),this._config.animation&&this._element.classList.add(Xn);var e=function(){t._element.classList.remove(Jn),t._element.classList.add(Gn),g(t._element).trigger(zn.SHOWN),t._config.autohide&&t.hide()};if(this._element.classList.remove($n),this._element.classList.add(Jn),this._config.animation){var n=_.getTransitionDurationFromElement(this._element);g(this._element).one(_.TRANSITION_END,e).emulateTransitionEnd(n)}else e()},t.hide=function(t){var e=this;this._element.classList.contains(Gn)&&(g(this._element).trigger(zn.HIDE),t?this._close():this._timeout=setTimeout(function(){e._close()},this._config.delay))},t.dispose=function(){clearTimeout(this._timeout),this._timeout=null,this._element.classList.contains(Gn)&&this._element.classList.remove(Gn),g(this._element).off(zn.CLICK_DISMISS),g.removeData(this._element,Bn),this._element=null,this._config=null},t._getConfig=function(t){return t=l({},ti,g(this._element).data(),"object"==typeof t&&t?t:{}),_.typeCheckConfig(Qn,t,this.constructor.DefaultType),t},t._setListeners=function(){var t=this;g(this._element).on(zn.CLICK_DISMISS,ei,function(){return t.hide(!0)})},t._close=function(){var t=this,e=function(){t._element.classList.add($n),g(t._element).trigger(zn.HIDDEN)};if(this._element.classList.remove(Gn),this._config.animation){var n=_.getTransitionDurationFromElement(this._element);g(this._element).one(_.TRANSITION_END,e).emulateTransitionEnd(n)}else e()},i._jQueryInterface=function(n){return this.each(function(){var t=g(this),e=t.data(Bn);if(e||(e=new i(this,"object"==typeof n&&n),t.data(Bn,e)),"string"==typeof n){if("undefined"==typeof e[n])throw new TypeError('No method named "'+n+'"');e[n](this)}})},s(i,null,[{key:"VERSION",get:function(){return"4.3.1"}},{key:"DefaultType",get:function(){return Zn}},{key:"Default",get:function(){return ti}}]),i}();g.fn[Qn]=ni._jQueryInterface,g.fn[Qn].Constructor=ni,g.fn[Qn].noConflict=function(){return g.fn[Qn]=Yn,ni._jQueryInterface},function(){if("undefined"==typeof g)throw new TypeError("Bootstrap's JavaScript requires jQuery. jQuery must be included before Bootstrap's JavaScript.");var t=g.fn.jquery.split(" ")[0].split(".");if(t[0]<2&&t[1]<9||1===t[0]&&9===t[1]&&t[2]<1||4<=t[0])throw new Error("Bootstrap's JavaScript requires at least jQuery v1.9.1 but less than v4.0.0")}(),t.Util=_,t.Alert=p,t.Button=P,t.Carousel=lt,t.Collapse=bt,t.Dropdown=Jt,t.Modal=ve,t.Popover=sn,t.Scrollspy=Dn,t.Tab=Kn,t.Toast=ni,t.Tooltip=Be,Object.defineProperty(t,"__esModule",{value:!0})});
|
7 |
+
//# sourceMappingURL=bootstrap.min.js.map
|
inc/js/bootstrap_js.js
DELETED
@@ -1,7 +0,0 @@
|
|
1 |
-
/*!
|
2 |
-
* Bootstrap v3.3.4 (http://getbootstrap.com)
|
3 |
-
* Copyright 2011-2015 Twitter, Inc.
|
4 |
-
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
5 |
-
*/
|
6 |
-
if("undefined"==typeof jQuery)throw new Error("Bootstrap's JavaScript requires jQuery");+function(a){"use strict";var b=a.fn.jquery.split(" ")[0].split(".");if(b[0]<2&&b[1]<9||1==b[0]&&9==b[1]&&b[2]<1)throw new Error("Bootstrap's JavaScript requires jQuery version 1.9.1 or higher")}(jQuery),+function(a){"use strict";function b(){var a=document.createElement("bootstrap"),b={WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"oTransitionEnd otransitionend",transition:"transitionend"};for(var c in b)if(void 0!==a.style[c])return{end:b[c]};return!1}a.fn.emulateTransitionEnd=function(b){var c=!1,d=this;a(this).one("bsTransitionEnd",function(){c=!0});var e=function(){c||a(d).trigger(a.support.transition.end)};return setTimeout(e,b),this},a(function(){a.support.transition=b(),a.support.transition&&(a.event.special.bsTransitionEnd={bindType:a.support.transition.end,delegateType:a.support.transition.end,handle:function(b){return a(b.target).is(this)?b.handleObj.handler.apply(this,arguments):void 0}})})}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var c=a(this),e=c.data("bs.alert");e||c.data("bs.alert",e=new d(this)),"string"==typeof b&&e[b].call(c)})}var c='[data-dismiss="alert"]',d=function(b){a(b).on("click",c,this.close)};d.VERSION="3.3.4",d.TRANSITION_DURATION=150,d.prototype.close=function(b){function c(){g.detach().trigger("closed.bs.alert").remove()}var e=a(this),f=e.attr("data-target");f||(f=e.attr("href"),f=f&&f.replace(/.*(?=#[^\s]*$)/,""));var g=a(f);b&&b.preventDefault(),g.length||(g=e.closest(".alert")),g.trigger(b=a.Event("close.bs.alert")),b.isDefaultPrevented()||(g.removeClass("in"),a.support.transition&&g.hasClass("fade")?g.one("bsTransitionEnd",c).emulateTransitionEnd(d.TRANSITION_DURATION):c())};var e=a.fn.alert;a.fn.alert=b,a.fn.alert.Constructor=d,a.fn.alert.noConflict=function(){return a.fn.alert=e,this},a(document).on("click.bs.alert.data-api",c,d.prototype.close)}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.button"),f="object"==typeof b&&b;e||d.data("bs.button",e=new c(this,f)),"toggle"==b?e.toggle():b&&e.setState(b)})}var c=function(b,d){this.$element=a(b),this.options=a.extend({},c.DEFAULTS,d),this.isLoading=!1};c.VERSION="3.3.4",c.DEFAULTS={loadingText:"loading..."},c.prototype.setState=function(b){var c="disabled",d=this.$element,e=d.is("input")?"val":"html",f=d.data();b+="Text",null==f.resetText&&d.data("resetText",d[e]()),setTimeout(a.proxy(function(){d[e](null==f[b]?this.options[b]:f[b]),"loadingText"==b?(this.isLoading=!0,d.addClass(c).attr(c,c)):this.isLoading&&(this.isLoading=!1,d.removeClass(c).removeAttr(c))},this),0)},c.prototype.toggle=function(){var a=!0,b=this.$element.closest('[data-toggle="buttons"]');if(b.length){var c=this.$element.find("input");"radio"==c.prop("type")&&(c.prop("checked")&&this.$element.hasClass("active")?a=!1:b.find(".active").removeClass("active")),a&&c.prop("checked",!this.$element.hasClass("active")).trigger("change")}else this.$element.attr("aria-pressed",!this.$element.hasClass("active"));a&&this.$element.toggleClass("active")};var d=a.fn.button;a.fn.button=b,a.fn.button.Constructor=c,a.fn.button.noConflict=function(){return a.fn.button=d,this},a(document).on("click.bs.button.data-api",'[data-toggle^="button"]',function(c){var d=a(c.target);d.hasClass("btn")||(d=d.closest(".btn")),b.call(d,"toggle"),c.preventDefault()}).on("focus.bs.button.data-api blur.bs.button.data-api",'[data-toggle^="button"]',function(b){a(b.target).closest(".btn").toggleClass("focus",/^focus(in)?$/.test(b.type))})}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.carousel"),f=a.extend({},c.DEFAULTS,d.data(),"object"==typeof b&&b),g="string"==typeof b?b:f.slide;e||d.data("bs.carousel",e=new c(this,f)),"number"==typeof b?e.to(b):g?e[g]():f.interval&&e.pause().cycle()})}var c=function(b,c){this.$element=a(b),this.$indicators=this.$element.find(".carousel-indicators"),this.options=c,this.paused=null,this.sliding=null,this.interval=null,this.$active=null,this.$items=null,this.options.keyboard&&this.$element.on("keydown.bs.carousel",a.proxy(this.keydown,this)),"hover"==this.options.pause&&!("ontouchstart"in document.documentElement)&&this.$element.on("mouseenter.bs.carousel",a.proxy(this.pause,this)).on("mouseleave.bs.carousel",a.proxy(this.cycle,this))};c.VERSION="3.3.4",c.TRANSITION_DURATION=600,c.DEFAULTS={interval:5e3,pause:"hover",wrap:!0,keyboard:!0},c.prototype.keydown=function(a){if(!/input|textarea/i.test(a.target.tagName)){switch(a.which){case 37:this.prev();break;case 39:this.next();break;default:return}a.preventDefault()}},c.prototype.cycle=function(b){return b||(this.paused=!1),this.interval&&clearInterval(this.interval),this.options.interval&&!this.paused&&(this.interval=setInterval(a.proxy(this.next,this),this.options.interval)),this},c.prototype.getItemIndex=function(a){return this.$items=a.parent().children(".item"),this.$items.index(a||this.$active)},c.prototype.getItemForDirection=function(a,b){var c=this.getItemIndex(b),d="prev"==a&&0===c||"next"==a&&c==this.$items.length-1;if(d&&!this.options.wrap)return b;var e="prev"==a?-1:1,f=(c+e)%this.$items.length;return this.$items.eq(f)},c.prototype.to=function(a){var b=this,c=this.getItemIndex(this.$active=this.$element.find(".item.active"));return a>this.$items.length-1||0>a?void 0:this.sliding?this.$element.one("slid.bs.carousel",function(){b.to(a)}):c==a?this.pause().cycle():this.slide(a>c?"next":"prev",this.$items.eq(a))},c.prototype.pause=function(b){return b||(this.paused=!0),this.$element.find(".next, .prev").length&&a.support.transition&&(this.$element.trigger(a.support.transition.end),this.cycle(!0)),this.interval=clearInterval(this.interval),this},c.prototype.next=function(){return this.sliding?void 0:this.slide("next")},c.prototype.prev=function(){return this.sliding?void 0:this.slide("prev")},c.prototype.slide=function(b,d){var e=this.$element.find(".item.active"),f=d||this.getItemForDirection(b,e),g=this.interval,h="next"==b?"left":"right",i=this;if(f.hasClass("active"))return this.sliding=!1;var j=f[0],k=a.Event("slide.bs.carousel",{relatedTarget:j,direction:h});if(this.$element.trigger(k),!k.isDefaultPrevented()){if(this.sliding=!0,g&&this.pause(),this.$indicators.length){this.$indicators.find(".active").removeClass("active");var l=a(this.$indicators.children()[this.getItemIndex(f)]);l&&l.addClass("active")}var m=a.Event("slid.bs.carousel",{relatedTarget:j,direction:h});return a.support.transition&&this.$element.hasClass("slide")?(f.addClass(b),f[0].offsetWidth,e.addClass(h),f.addClass(h),e.one("bsTransitionEnd",function(){f.removeClass([b,h].join(" ")).addClass("active"),e.removeClass(["active",h].join(" ")),i.sliding=!1,setTimeout(function(){i.$element.trigger(m)},0)}).emulateTransitionEnd(c.TRANSITION_DURATION)):(e.removeClass("active"),f.addClass("active"),this.sliding=!1,this.$element.trigger(m)),g&&this.cycle(),this}};var d=a.fn.carousel;a.fn.carousel=b,a.fn.carousel.Constructor=c,a.fn.carousel.noConflict=function(){return a.fn.carousel=d,this};var e=function(c){var d,e=a(this),f=a(e.attr("data-target")||(d=e.attr("href"))&&d.replace(/.*(?=#[^\s]+$)/,""));if(f.hasClass("carousel")){var g=a.extend({},f.data(),e.data()),h=e.attr("data-slide-to");h&&(g.interval=!1),b.call(f,g),h&&f.data("bs.carousel").to(h),c.preventDefault()}};a(document).on("click.bs.carousel.data-api","[data-slide]",e).on("click.bs.carousel.data-api","[data-slide-to]",e),a(window).on("load",function(){a('[data-ride="carousel"]').each(function(){var c=a(this);b.call(c,c.data())})})}(jQuery),+function(a){"use strict";function b(b){var c,d=b.attr("data-target")||(c=b.attr("href"))&&c.replace(/.*(?=#[^\s]+$)/,"");return a(d)}function c(b){return this.each(function(){var c=a(this),e=c.data("bs.collapse"),f=a.extend({},d.DEFAULTS,c.data(),"object"==typeof b&&b);!e&&f.toggle&&/show|hide/.test(b)&&(f.toggle=!1),e||c.data("bs.collapse",e=new d(this,f)),"string"==typeof b&&e[b]()})}var d=function(b,c){this.$element=a(b),this.options=a.extend({},d.DEFAULTS,c),this.$trigger=a('[data-toggle="collapse"][href="#'+b.id+'"],[data-toggle="collapse"][data-target="#'+b.id+'"]'),this.transitioning=null,this.options.parent?this.$parent=this.getParent():this.addAriaAndCollapsedClass(this.$element,this.$trigger),this.options.toggle&&this.toggle()};d.VERSION="3.3.4",d.TRANSITION_DURATION=350,d.DEFAULTS={toggle:!0},d.prototype.dimension=function(){var a=this.$element.hasClass("width");return a?"width":"height"},d.prototype.show=function(){if(!this.transitioning&&!this.$element.hasClass("in")){var b,e=this.$parent&&this.$parent.children(".panel").children(".in, .collapsing");if(!(e&&e.length&&(b=e.data("bs.collapse"),b&&b.transitioning))){var f=a.Event("show.bs.collapse");if(this.$element.trigger(f),!f.isDefaultPrevented()){e&&e.length&&(c.call(e,"hide"),b||e.data("bs.collapse",null));var g=this.dimension();this.$element.removeClass("collapse").addClass("collapsing")[g](0).attr("aria-expanded",!0),this.$trigger.removeClass("collapsed").attr("aria-expanded",!0),this.transitioning=1;var h=function(){this.$element.removeClass("collapsing").addClass("collapse in")[g](""),this.transitioning=0,this.$element.trigger("shown.bs.collapse")};if(!a.support.transition)return h.call(this);var i=a.camelCase(["scroll",g].join("-"));this.$element.one("bsTransitionEnd",a.proxy(h,this)).emulateTransitionEnd(d.TRANSITION_DURATION)[g](this.$element[0][i])}}}},d.prototype.hide=function(){if(!this.transitioning&&this.$element.hasClass("in")){var b=a.Event("hide.bs.collapse");if(this.$element.trigger(b),!b.isDefaultPrevented()){var c=this.dimension();this.$element[c](this.$element[c]())[0].offsetHeight,this.$element.addClass("collapsing").removeClass("collapse in").attr("aria-expanded",!1),this.$trigger.addClass("collapsed").attr("aria-expanded",!1),this.transitioning=1;var e=function(){this.transitioning=0,this.$element.removeClass("collapsing").addClass("collapse").trigger("hidden.bs.collapse")};return a.support.transition?void this.$element[c](0).one("bsTransitionEnd",a.proxy(e,this)).emulateTransitionEnd(d.TRANSITION_DURATION):e.call(this)}}},d.prototype.toggle=function(){this[this.$element.hasClass("in")?"hide":"show"]()},d.prototype.getParent=function(){return a(this.options.parent).find('[data-toggle="collapse"][data-parent="'+this.options.parent+'"]').each(a.proxy(function(c,d){var e=a(d);this.addAriaAndCollapsedClass(b(e),e)},this)).end()},d.prototype.addAriaAndCollapsedClass=function(a,b){var c=a.hasClass("in");a.attr("aria-expanded",c),b.toggleClass("collapsed",!c).attr("aria-expanded",c)};var e=a.fn.collapse;a.fn.collapse=c,a.fn.collapse.Constructor=d,a.fn.collapse.noConflict=function(){return a.fn.collapse=e,this},a(document).on("click.bs.collapse.data-api",'[data-toggle="collapse"]',function(d){var e=a(this);e.attr("data-target")||d.preventDefault();var f=b(e),g=f.data("bs.collapse"),h=g?"toggle":e.data();c.call(f,h)})}(jQuery),+function(a){"use strict";function b(b){b&&3===b.which||(a(e).remove(),a(f).each(function(){var d=a(this),e=c(d),f={relatedTarget:this};e.hasClass("open")&&(e.trigger(b=a.Event("hide.bs.dropdown",f)),b.isDefaultPrevented()||(d.attr("aria-expanded","false"),e.removeClass("open").trigger("hidden.bs.dropdown",f)))}))}function c(b){var c=b.attr("data-target");c||(c=b.attr("href"),c=c&&/#[A-Za-z]/.test(c)&&c.replace(/.*(?=#[^\s]*$)/,""));var d=c&&a(c);return d&&d.length?d:b.parent()}function d(b){return this.each(function(){var c=a(this),d=c.data("bs.dropdown");d||c.data("bs.dropdown",d=new g(this)),"string"==typeof b&&d[b].call(c)})}var e=".dropdown-backdrop",f='[data-toggle="dropdown"]',g=function(b){a(b).on("click.bs.dropdown",this.toggle)};g.VERSION="3.3.4",g.prototype.toggle=function(d){var e=a(this);if(!e.is(".disabled, :disabled")){var f=c(e),g=f.hasClass("open");if(b(),!g){"ontouchstart"in document.documentElement&&!f.closest(".navbar-nav").length&&a('<div class="dropdown-backdrop"/>').insertAfter(a(this)).on("click",b);var h={relatedTarget:this};if(f.trigger(d=a.Event("show.bs.dropdown",h)),d.isDefaultPrevented())return;e.trigger("focus").attr("aria-expanded","true"),f.toggleClass("open").trigger("shown.bs.dropdown",h)}return!1}},g.prototype.keydown=function(b){if(/(38|40|27|32)/.test(b.which)&&!/input|textarea/i.test(b.target.tagName)){var d=a(this);if(b.preventDefault(),b.stopPropagation(),!d.is(".disabled, :disabled")){var e=c(d),g=e.hasClass("open");if(!g&&27!=b.which||g&&27==b.which)return 27==b.which&&e.find(f).trigger("focus"),d.trigger("click");var h=" li:not(.disabled):visible a",i=e.find('[role="menu"]'+h+', [role="listbox"]'+h);if(i.length){var j=i.index(b.target);38==b.which&&j>0&&j--,40==b.which&&j<i.length-1&&j++,~j||(j=0),i.eq(j).trigger("focus")}}}};var h=a.fn.dropdown;a.fn.dropdown=d,a.fn.dropdown.Constructor=g,a.fn.dropdown.noConflict=function(){return a.fn.dropdown=h,this},a(document).on("click.bs.dropdown.data-api",b).on("click.bs.dropdown.data-api",".dropdown form",function(a){a.stopPropagation()}).on("click.bs.dropdown.data-api",f,g.prototype.toggle).on("keydown.bs.dropdown.data-api",f,g.prototype.keydown).on("keydown.bs.dropdown.data-api",'[role="menu"]',g.prototype.keydown).on("keydown.bs.dropdown.data-api",'[role="listbox"]',g.prototype.keydown)}(jQuery),+function(a){"use strict";function b(b,d){return this.each(function(){var e=a(this),f=e.data("bs.modal"),g=a.extend({},c.DEFAULTS,e.data(),"object"==typeof b&&b);f||e.data("bs.modal",f=new c(this,g)),"string"==typeof b?f[b](d):g.show&&f.show(d)})}var c=function(b,c){this.options=c,this.$body=a(document.body),this.$element=a(b),this.$dialog=this.$element.find(".modal-dialog"),this.$backdrop=null,this.isShown=null,this.originalBodyPad=null,this.scrollbarWidth=0,this.ignoreBackdropClick=!1,this.options.remote&&this.$element.find(".modal-content").load(this.options.remote,a.proxy(function(){this.$element.trigger("loaded.bs.modal")},this))};c.VERSION="3.3.4",c.TRANSITION_DURATION=300,c.BACKDROP_TRANSITION_DURATION=150,c.DEFAULTS={backdrop:!0,keyboard:!0,show:!0},c.prototype.toggle=function(a){return this.isShown?this.hide():this.show(a)},c.prototype.show=function(b){var d=this,e=a.Event("show.bs.modal",{relatedTarget:b});this.$element.trigger(e),this.isShown||e.isDefaultPrevented()||(this.isShown=!0,this.checkScrollbar(),this.setScrollbar(),this.$body.addClass("modal-open"),this.escape(),this.resize(),this.$element.on("click.dismiss.bs.modal",'[data-dismiss="modal"]',a.proxy(this.hide,this)),this.$dialog.on("mousedown.dismiss.bs.modal",function(){d.$element.one("mouseup.dismiss.bs.modal",function(b){a(b.target).is(d.$element)&&(d.ignoreBackdropClick=!0)})}),this.backdrop(function(){var e=a.support.transition&&d.$element.hasClass("fade");d.$element.parent().length||d.$element.appendTo(d.$body),d.$element.show().scrollTop(0),d.adjustDialog(),e&&d.$element[0].offsetWidth,d.$element.addClass("in").attr("aria-hidden",!1),d.enforceFocus();var f=a.Event("shown.bs.modal",{relatedTarget:b});e?d.$dialog.one("bsTransitionEnd",function(){d.$element.trigger("focus").trigger(f)}).emulateTransitionEnd(c.TRANSITION_DURATION):d.$element.trigger("focus").trigger(f)}))},c.prototype.hide=function(b){b&&b.preventDefault(),b=a.Event("hide.bs.modal"),this.$element.trigger(b),this.isShown&&!b.isDefaultPrevented()&&(this.isShown=!1,this.escape(),this.resize(),a(document).off("focusin.bs.modal"),this.$element.removeClass("in").attr("aria-hidden",!0).off("click.dismiss.bs.modal").off("mouseup.dismiss.bs.modal"),this.$dialog.off("mousedown.dismiss.bs.modal"),a.support.transition&&this.$element.hasClass("fade")?this.$element.one("bsTransitionEnd",a.proxy(this.hideModal,this)).emulateTransitionEnd(c.TRANSITION_DURATION):this.hideModal())},c.prototype.enforceFocus=function(){a(document).off("focusin.bs.modal").on("focusin.bs.modal",a.proxy(function(a){this.$element[0]===a.target||this.$element.has(a.target).length||this.$element.trigger("focus")},this))},c.prototype.escape=function(){this.isShown&&this.options.keyboard?this.$element.on("keydown.dismiss.bs.modal",a.proxy(function(a){27==a.which&&this.hide()},this)):this.isShown||this.$element.off("keydown.dismiss.bs.modal")},c.prototype.resize=function(){this.isShown?a(window).on("resize.bs.modal",a.proxy(this.handleUpdate,this)):a(window).off("resize.bs.modal")},c.prototype.hideModal=function(){var a=this;this.$element.hide(),this.backdrop(function(){a.$body.removeClass("modal-open"),a.resetAdjustments(),a.resetScrollbar(),a.$element.trigger("hidden.bs.modal")})},c.prototype.removeBackdrop=function(){this.$backdrop&&this.$backdrop.remove(),this.$backdrop=null},c.prototype.backdrop=function(b){var d=this,e=this.$element.hasClass("fade")?"fade":"";if(this.isShown&&this.options.backdrop){var f=a.support.transition&&e;if(this.$backdrop=a('<div class="modal-backdrop '+e+'" />').appendTo(this.$body),this.$element.on("click.dismiss.bs.modal",a.proxy(function(a){return this.ignoreBackdropClick?void(this.ignoreBackdropClick=!1):void(a.target===a.currentTarget&&("static"==this.options.backdrop?this.$element[0].focus():this.hide()))},this)),f&&this.$backdrop[0].offsetWidth,this.$backdrop.addClass("in"),!b)return;f?this.$backdrop.one("bsTransitionEnd",b).emulateTransitionEnd(c.BACKDROP_TRANSITION_DURATION):b()}else if(!this.isShown&&this.$backdrop){this.$backdrop.removeClass("in");var g=function(){d.removeBackdrop(),b&&b()};a.support.transition&&this.$element.hasClass("fade")?this.$backdrop.one("bsTransitionEnd",g).emulateTransitionEnd(c.BACKDROP_TRANSITION_DURATION):g()}else b&&b()},c.prototype.handleUpdate=function(){this.adjustDialog()},c.prototype.adjustDialog=function(){var a=this.$element[0].scrollHeight>document.documentElement.clientHeight;this.$element.css({paddingLeft:!this.bodyIsOverflowing&&a?this.scrollbarWidth:"",paddingRight:this.bodyIsOverflowing&&!a?this.scrollbarWidth:""})},c.prototype.resetAdjustments=function(){this.$element.css({paddingLeft:"",paddingRight:""})},c.prototype.checkScrollbar=function(){var a=window.innerWidth;if(!a){var b=document.documentElement.getBoundingClientRect();a=b.right-Math.abs(b.left)}this.bodyIsOverflowing=document.body.clientWidth<a,this.scrollbarWidth=this.measureScrollbar()},c.prototype.setScrollbar=function(){var a=parseInt(this.$body.css("padding-right")||0,10);this.originalBodyPad=document.body.style.paddingRight||"",this.bodyIsOverflowing&&this.$body.css("padding-right",a+this.scrollbarWidth)},c.prototype.resetScrollbar=function(){this.$body.css("padding-right",this.originalBodyPad)},c.prototype.measureScrollbar=function(){var a=document.createElement("div");a.className="modal-scrollbar-measure",this.$body.append(a);var b=a.offsetWidth-a.clientWidth;return this.$body[0].removeChild(a),b};var d=a.fn.modal;a.fn.modal=b,a.fn.modal.Constructor=c,a.fn.modal.noConflict=function(){return a.fn.modal=d,this},a(document).on("click.bs.modal.data-api",'[data-toggle="modal"]',function(c){var d=a(this),e=d.attr("href"),f=a(d.attr("data-target")||e&&e.replace(/.*(?=#[^\s]+$)/,"")),g=f.data("bs.modal")?"toggle":a.extend({remote:!/#/.test(e)&&e},f.data(),d.data());d.is("a")&&c.preventDefault(),f.one("show.bs.modal",function(a){a.isDefaultPrevented()||f.one("hidden.bs.modal",function(){d.is(":visible")&&d.trigger("focus")})}),b.call(f,g,this)})}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.tooltip"),f="object"==typeof b&&b;(e||!/destroy|hide/.test(b))&&(e||d.data("bs.tooltip",e=new c(this,f)),"string"==typeof b&&e[b]())})}var c=function(a,b){this.type=null,this.options=null,this.enabled=null,this.timeout=null,this.hoverState=null,this.$element=null,this.init("tooltip",a,b)};c.VERSION="3.3.4",c.TRANSITION_DURATION=150,c.DEFAULTS={animation:!0,placement:"top",selector:!1,template:'<div class="tooltip" role="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>',trigger:"hover focus",title:"",delay:0,html:!1,container:!1,viewport:{selector:"body",padding:0}},c.prototype.init=function(b,c,d){if(this.enabled=!0,this.type=b,this.$element=a(c),this.options=this.getOptions(d),this.$viewport=this.options.viewport&&a(this.options.viewport.selector||this.options.viewport),this.$element[0]instanceof document.constructor&&!this.options.selector)throw new Error("`selector` option must be specified when initializing "+this.type+" on the window.document object!");for(var e=this.options.trigger.split(" "),f=e.length;f--;){var g=e[f];if("click"==g)this.$element.on("click."+this.type,this.options.selector,a.proxy(this.toggle,this));else if("manual"!=g){var h="hover"==g?"mouseenter":"focusin",i="hover"==g?"mouseleave":"focusout";this.$element.on(h+"."+this.type,this.options.selector,a.proxy(this.enter,this)),this.$element.on(i+"."+this.type,this.options.selector,a.proxy(this.leave,this))}}this.options.selector?this._options=a.extend({},this.options,{trigger:"manual",selector:""}):this.fixTitle()},c.prototype.getDefaults=function(){return c.DEFAULTS},c.prototype.getOptions=function(b){return b=a.extend({},this.getDefaults(),this.$element.data(),b),b.delay&&"number"==typeof b.delay&&(b.delay={show:b.delay,hide:b.delay}),b},c.prototype.getDelegateOptions=function(){var b={},c=this.getDefaults();return this._options&&a.each(this._options,function(a,d){c[a]!=d&&(b[a]=d)}),b},c.prototype.enter=function(b){var c=b instanceof this.constructor?b:a(b.currentTarget).data("bs."+this.type);return c&&c.$tip&&c.$tip.is(":visible")?void(c.hoverState="in"):(c||(c=new this.constructor(b.currentTarget,this.getDelegateOptions()),a(b.currentTarget).data("bs."+this.type,c)),clearTimeout(c.timeout),c.hoverState="in",c.options.delay&&c.options.delay.show?void(c.timeout=setTimeout(function(){"in"==c.hoverState&&c.show()},c.options.delay.show)):c.show())},c.prototype.leave=function(b){var c=b instanceof this.constructor?b:a(b.currentTarget).data("bs."+this.type);return c||(c=new this.constructor(b.currentTarget,this.getDelegateOptions()),a(b.currentTarget).data("bs."+this.type,c)),clearTimeout(c.timeout),c.hoverState="out",c.options.delay&&c.options.delay.hide?void(c.timeout=setTimeout(function(){"out"==c.hoverState&&c.hide()},c.options.delay.hide)):c.hide()},c.prototype.show=function(){var b=a.Event("show.bs."+this.type);if(this.hasContent()&&this.enabled){this.$element.trigger(b);var d=a.contains(this.$element[0].ownerDocument.documentElement,this.$element[0]);if(b.isDefaultPrevented()||!d)return;var e=this,f=this.tip(),g=this.getUID(this.type);this.setContent(),f.attr("id",g),this.$element.attr("aria-describedby",g),this.options.animation&&f.addClass("fade");var h="function"==typeof this.options.placement?this.options.placement.call(this,f[0],this.$element[0]):this.options.placement,i=/\s?auto?\s?/i,j=i.test(h);j&&(h=h.replace(i,"")||"top"),f.detach().css({top:0,left:0,display:"block"}).addClass(h).data("bs."+this.type,this),this.options.container?f.appendTo(this.options.container):f.insertAfter(this.$element);var k=this.getPosition(),l=f[0].offsetWidth,m=f[0].offsetHeight;if(j){var n=h,o=this.options.container?a(this.options.container):this.$element.parent(),p=this.getPosition(o);h="bottom"==h&&k.bottom+m>p.bottom?"top":"top"==h&&k.top-m<p.top?"bottom":"right"==h&&k.right+l>p.width?"left":"left"==h&&k.left-l<p.left?"right":h,f.removeClass(n).addClass(h)}var q=this.getCalculatedOffset(h,k,l,m);this.applyPlacement(q,h);var r=function(){var a=e.hoverState;e.$element.trigger("shown.bs."+e.type),e.hoverState=null,"out"==a&&e.leave(e)};a.support.transition&&this.$tip.hasClass("fade")?f.one("bsTransitionEnd",r).emulateTransitionEnd(c.TRANSITION_DURATION):r()}},c.prototype.applyPlacement=function(b,c){var d=this.tip(),e=d[0].offsetWidth,f=d[0].offsetHeight,g=parseInt(d.css("margin-top"),10),h=parseInt(d.css("margin-left"),10);isNaN(g)&&(g=0),isNaN(h)&&(h=0),b.top=b.top+g,b.left=b.left+h,a.offset.setOffset(d[0],a.extend({using:function(a){d.css({top:Math.round(a.top),left:Math.round(a.left)})}},b),0),d.addClass("in");var i=d[0].offsetWidth,j=d[0].offsetHeight;"top"==c&&j!=f&&(b.top=b.top+f-j);var k=this.getViewportAdjustedDelta(c,b,i,j);k.left?b.left+=k.left:b.top+=k.top;var l=/top|bottom/.test(c),m=l?2*k.left-e+i:2*k.top-f+j,n=l?"offsetWidth":"offsetHeight";d.offset(b),this.replaceArrow(m,d[0][n],l)},c.prototype.replaceArrow=function(a,b,c){this.arrow().css(c?"left":"top",50*(1-a/b)+"%").css(c?"top":"left","")},c.prototype.setContent=function(){var a=this.tip(),b=this.getTitle();a.find(".tooltip-inner")[this.options.html?"html":"text"](b),a.removeClass("fade in top bottom left right")},c.prototype.hide=function(b){function d(){"in"!=e.hoverState&&f.detach(),e.$element.removeAttr("aria-describedby").trigger("hidden.bs."+e.type),b&&b()}var e=this,f=a(this.$tip),g=a.Event("hide.bs."+this.type);return this.$element.trigger(g),g.isDefaultPrevented()?void 0:(f.removeClass("in"),a.support.transition&&f.hasClass("fade")?f.one("bsTransitionEnd",d).emulateTransitionEnd(c.TRANSITION_DURATION):d(),this.hoverState=null,this)},c.prototype.fixTitle=function(){var a=this.$element;(a.attr("title")||"string"!=typeof a.attr("data-original-title"))&&a.attr("data-original-title",a.attr("title")||"").attr("title","")},c.prototype.hasContent=function(){return this.getTitle()},c.prototype.getPosition=function(b){b=b||this.$element;var c=b[0],d="BODY"==c.tagName,e=c.getBoundingClientRect();null==e.width&&(e=a.extend({},e,{width:e.right-e.left,height:e.bottom-e.top}));var f=d?{top:0,left:0}:b.offset(),g={scroll:d?document.documentElement.scrollTop||document.body.scrollTop:b.scrollTop()},h=d?{width:a(window).width(),height:a(window).height()}:null;return a.extend({},e,g,h,f)},c.prototype.getCalculatedOffset=function(a,b,c,d){return"bottom"==a?{top:b.top+b.height,left:b.left+b.width/2-c/2}:"top"==a?{top:b.top-d,left:b.left+b.width/2-c/2}:"left"==a?{top:b.top+b.height/2-d/2,left:b.left-c}:{top:b.top+b.height/2-d/2,left:b.left+b.width}},c.prototype.getViewportAdjustedDelta=function(a,b,c,d){var e={top:0,left:0};if(!this.$viewport)return e;var f=this.options.viewport&&this.options.viewport.padding||0,g=this.getPosition(this.$viewport);if(/right|left/.test(a)){var h=b.top-f-g.scroll,i=b.top+f-g.scroll+d;h<g.top?e.top=g.top-h:i>g.top+g.height&&(e.top=g.top+g.height-i)}else{var j=b.left-f,k=b.left+f+c;j<g.left?e.left=g.left-j:k>g.width&&(e.left=g.left+g.width-k)}return e},c.prototype.getTitle=function(){var a,b=this.$element,c=this.options;return a=b.attr("data-original-title")||("function"==typeof c.title?c.title.call(b[0]):c.title)},c.prototype.getUID=function(a){do a+=~~(1e6*Math.random());while(document.getElementById(a));return a},c.prototype.tip=function(){return this.$tip=this.$tip||a(this.options.template)},c.prototype.arrow=function(){return this.$arrow=this.$arrow||this.tip().find(".tooltip-arrow")},c.prototype.enable=function(){this.enabled=!0},c.prototype.disable=function(){this.enabled=!1},c.prototype.toggleEnabled=function(){this.enabled=!this.enabled},c.prototype.toggle=function(b){var c=this;b&&(c=a(b.currentTarget).data("bs."+this.type),c||(c=new this.constructor(b.currentTarget,this.getDelegateOptions()),a(b.currentTarget).data("bs."+this.type,c))),c.tip().hasClass("in")?c.leave(c):c.enter(c)},c.prototype.destroy=function(){var a=this;clearTimeout(this.timeout),this.hide(function(){a.$element.off("."+a.type).removeData("bs."+a.type)})};var d=a.fn.tooltip;a.fn.tooltip=b,a.fn.tooltip.Constructor=c,a.fn.tooltip.noConflict=function(){return a.fn.tooltip=d,this}}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.popover"),f="object"==typeof b&&b;(e||!/destroy|hide/.test(b))&&(e||d.data("bs.popover",e=new c(this,f)),"string"==typeof b&&e[b]())})}var c=function(a,b){this.init("popover",a,b)};if(!a.fn.tooltip)throw new Error("Popover requires tooltip.js");c.VERSION="3.3.4",c.DEFAULTS=a.extend({},a.fn.tooltip.Constructor.DEFAULTS,{placement:"right",trigger:"click",content:"",template:'<div class="popover" role="tooltip"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'}),c.prototype=a.extend({},a.fn.tooltip.Constructor.prototype),c.prototype.constructor=c,c.prototype.getDefaults=function(){return c.DEFAULTS},c.prototype.setContent=function(){var a=this.tip(),b=this.getTitle(),c=this.getContent();a.find(".popover-title")[this.options.html?"html":"text"](b),a.find(".popover-content").children().detach().end()[this.options.html?"string"==typeof c?"html":"append":"text"](c),a.removeClass("fade top bottom left right in"),a.find(".popover-title").html()||a.find(".popover-title").hide()},c.prototype.hasContent=function(){return this.getTitle()||this.getContent()},c.prototype.getContent=function(){var a=this.$element,b=this.options;return a.attr("data-content")||("function"==typeof b.content?b.content.call(a[0]):b.content)},c.prototype.arrow=function(){return this.$arrow=this.$arrow||this.tip().find(".arrow")};var d=a.fn.popover;a.fn.popover=b,a.fn.popover.Constructor=c,a.fn.popover.noConflict=function(){return a.fn.popover=d,this}}(jQuery),+function(a){"use strict";function b(c,d){this.$body=a(document.body),this.$scrollElement=a(a(c).is(document.body)?window:c),this.options=a.extend({},b.DEFAULTS,d),this.selector=(this.options.target||"")+" .nav li > a",this.offsets=[],this.targets=[],this.activeTarget=null,this.scrollHeight=0,this.$scrollElement.on("scroll.bs.scrollspy",a.proxy(this.process,this)),this.refresh(),this.process()}function c(c){return this.each(function(){var d=a(this),e=d.data("bs.scrollspy"),f="object"==typeof c&&c;e||d.data("bs.scrollspy",e=new b(this,f)),"string"==typeof c&&e[c]()})}b.VERSION="3.3.4",b.DEFAULTS={offset:10},b.prototype.getScrollHeight=function(){return this.$scrollElement[0].scrollHeight||Math.max(this.$body[0].scrollHeight,document.documentElement.scrollHeight)},b.prototype.refresh=function(){var b=this,c="offset",d=0;this.offsets=[],this.targets=[],this.scrollHeight=this.getScrollHeight(),a.isWindow(this.$scrollElement[0])||(c="position",d=this.$scrollElement.scrollTop()),this.$body.find(this.selector).map(function(){var b=a(this),e=b.data("target")||b.attr("href"),f=/^#./.test(e)&&a(e);return f&&f.length&&f.is(":visible")&&[[f[c]().top+d,e]]||null}).sort(function(a,b){return a[0]-b[0]}).each(function(){b.offsets.push(this[0]),b.targets.push(this[1])})},b.prototype.process=function(){var a,b=this.$scrollElement.scrollTop()+this.options.offset,c=this.getScrollHeight(),d=this.options.offset+c-this.$scrollElement.height(),e=this.offsets,f=this.targets,g=this.activeTarget;if(this.scrollHeight!=c&&this.refresh(),b>=d)return g!=(a=f[f.length-1])&&this.activate(a);if(g&&b<e[0])return this.activeTarget=null,this.clear();for(a=e.length;a--;)g!=f[a]&&b>=e[a]&&(void 0===e[a+1]||b<e[a+1])&&this.activate(f[a])},b.prototype.activate=function(b){this.activeTarget=b,this.clear();var c=this.selector+'[data-target="'+b+'"],'+this.selector+'[href="'+b+'"]',d=a(c).parents("li").addClass("active");d.parent(".dropdown-menu").length&&(d=d.closest("li.dropdown").addClass("active")),d.trigger("activate.bs.scrollspy")},b.prototype.clear=function(){a(this.selector).parentsUntil(this.options.target,".active").removeClass("active")};var d=a.fn.scrollspy;a.fn.scrollspy=c,a.fn.scrollspy.Constructor=b,a.fn.scrollspy.noConflict=function(){return a.fn.scrollspy=d,this},a(window).on("load.bs.scrollspy.data-api",function(){a('[data-spy="scroll"]').each(function(){var b=a(this);c.call(b,b.data())})})}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.tab");e||d.data("bs.tab",e=new c(this)),"string"==typeof b&&e[b]()})}var c=function(b){this.element=a(b)};c.VERSION="3.3.4",c.TRANSITION_DURATION=150,c.prototype.show=function(){var b=this.element,c=b.closest("ul:not(.dropdown-menu)"),d=b.data("target");if(d||(d=b.attr("href"),d=d&&d.replace(/.*(?=#[^\s]*$)/,"")),!b.parent("li").hasClass("active")){
|
7 |
-
var e=c.find(".active:last a"),f=a.Event("hide.bs.tab",{relatedTarget:b[0]}),g=a.Event("show.bs.tab",{relatedTarget:e[0]});if(e.trigger(f),b.trigger(g),!g.isDefaultPrevented()&&!f.isDefaultPrevented()){var h=a(d);this.activate(b.closest("li"),c),this.activate(h,h.parent(),function(){e.trigger({type:"hidden.bs.tab",relatedTarget:b[0]}),b.trigger({type:"shown.bs.tab",relatedTarget:e[0]})})}}},c.prototype.activate=function(b,d,e){function f(){g.removeClass("active").find("> .dropdown-menu > .active").removeClass("active").end().find('[data-toggle="tab"]').attr("aria-expanded",!1),b.addClass("active").find('[data-toggle="tab"]').attr("aria-expanded",!0),h?(b[0].offsetWidth,b.addClass("in")):b.removeClass("fade"),b.parent(".dropdown-menu").length&&b.closest("li.dropdown").addClass("active").end().find('[data-toggle="tab"]').attr("aria-expanded",!0),e&&e()}var g=d.find("> .active"),h=e&&a.support.transition&&(g.length&&g.hasClass("fade")||!!d.find("> .fade").length);g.length&&h?g.one("bsTransitionEnd",f).emulateTransitionEnd(c.TRANSITION_DURATION):f(),g.removeClass("in")};var d=a.fn.tab;a.fn.tab=b,a.fn.tab.Constructor=c,a.fn.tab.noConflict=function(){return a.fn.tab=d,this};var e=function(c){c.preventDefault(),b.call(a(this),"show")};a(document).on("click.bs.tab.data-api",'[data-toggle="tab"]',e).on("click.bs.tab.data-api",'[data-toggle="pill"]',e)}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.affix"),f="object"==typeof b&&b;e||d.data("bs.affix",e=new c(this,f)),"string"==typeof b&&e[b]()})}var c=function(b,d){this.options=a.extend({},c.DEFAULTS,d),this.$target=a(this.options.target).on("scroll.bs.affix.data-api",a.proxy(this.checkPosition,this)).on("click.bs.affix.data-api",a.proxy(this.checkPositionWithEventLoop,this)),this.$element=a(b),this.affixed=null,this.unpin=null,this.pinnedOffset=null,this.checkPosition()};c.VERSION="3.3.4",c.RESET="affix affix-top affix-bottom",c.DEFAULTS={offset:0,target:window},c.prototype.getState=function(a,b,c,d){var e=this.$target.scrollTop(),f=this.$element.offset(),g=this.$target.height();if(null!=c&&"top"==this.affixed)return c>e?"top":!1;if("bottom"==this.affixed)return null!=c?e+this.unpin<=f.top?!1:"bottom":a-d>=e+g?!1:"bottom";var h=null==this.affixed,i=h?e:f.top,j=h?g:b;return null!=c&&c>=e?"top":null!=d&&i+j>=a-d?"bottom":!1},c.prototype.getPinnedOffset=function(){if(this.pinnedOffset)return this.pinnedOffset;this.$element.removeClass(c.RESET).addClass("affix");var a=this.$target.scrollTop(),b=this.$element.offset();return this.pinnedOffset=b.top-a},c.prototype.checkPositionWithEventLoop=function(){setTimeout(a.proxy(this.checkPosition,this),1)},c.prototype.checkPosition=function(){if(this.$element.is(":visible")){var b=this.$element.height(),d=this.options.offset,e=d.top,f=d.bottom,g=a(document.body).height();"object"!=typeof d&&(f=e=d),"function"==typeof e&&(e=d.top(this.$element)),"function"==typeof f&&(f=d.bottom(this.$element));var h=this.getState(g,b,e,f);if(this.affixed!=h){null!=this.unpin&&this.$element.css("top","");var i="affix"+(h?"-"+h:""),j=a.Event(i+".bs.affix");if(this.$element.trigger(j),j.isDefaultPrevented())return;this.affixed=h,this.unpin="bottom"==h?this.getPinnedOffset():null,this.$element.removeClass(c.RESET).addClass(i).trigger(i.replace("affix","affixed")+".bs.affix")}"bottom"==h&&this.$element.offset({top:g-b-f})}};var d=a.fn.affix;a.fn.affix=b,a.fn.affix.Constructor=c,a.fn.affix.noConflict=function(){return a.fn.affix=d,this},a(window).on("load",function(){a('[data-spy="affix"]').each(function(){var c=a(this),d=c.data();d.offset=d.offset||{},null!=d.offsetBottom&&(d.offset.bottom=d.offsetBottom),null!=d.offsetTop&&(d.offset.top=d.offsetTop),b.call(c,d)})})}(jQuery);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
inc/js/canvg.js
CHANGED
@@ -1,3095 +1,3095 @@
|
|
1 |
-
/*
|
2 |
-
* canvg.js - Javascript SVG parser and renderer on Canvas
|
3 |
-
* MIT Licensed
|
4 |
-
* Gabe Lerner (gabelerner@gmail.com)
|
5 |
-
* http://code.google.com/p/canvg/
|
6 |
-
*
|
7 |
-
* Requires: rgbcolor.js - http://www.phpied.com/rgb-color-parser-in-javascript/
|
8 |
-
*/
|
9 |
-
(function ( global, factory ) {
|
10 |
-
|
11 |
-
'use strict';
|
12 |
-
|
13 |
-
// export as AMD...
|
14 |
-
if ( typeof define !== 'undefined' && define.amd ) {
|
15 |
-
define('canvgModule', [ 'rgbcolor', 'stackblur' ], factory );
|
16 |
-
}
|
17 |
-
|
18 |
-
// ...or as browserify
|
19 |
-
else if ( typeof module !== 'undefined' && module.exports ) {
|
20 |
-
module.exports = factory( require( 'rgbcolor' ), require( 'stackblur' ) );
|
21 |
-
}
|
22 |
-
|
23 |
-
global.canvg = factory( global.RGBColor, global.stackBlur );
|
24 |
-
|
25 |
-
}( typeof window !== 'undefined' ? window : this, function ( RGBColor, stackBlur ) {
|
26 |
-
|
27 |
-
// canvg(target, s)
|
28 |
-
// empty parameters: replace all 'svg' elements on page with 'canvas' elements
|
29 |
-
// target: canvas element or the id of a canvas element
|
30 |
-
// s: svg string, url to svg file, or xml document
|
31 |
-
// opts: optional hash of options
|
32 |
-
// ignoreMouse: true => ignore mouse events
|
33 |
-
// ignoreAnimation: true => ignore animations
|
34 |
-
// ignoreDimensions: true => does not try to resize canvas
|
35 |
-
// ignoreClear: true => does not clear canvas
|
36 |
-
// offsetX: int => draws at a x offset
|
37 |
-
// offsetY: int => draws at a y offset
|
38 |
-
// scaleWidth: int => scales horizontally to width
|
39 |
-
// scaleHeight: int => scales vertically to height
|
40 |
-
// renderCallback: function => will call the function after the first render is completed
|
41 |
-
// forceRedraw: function => will call the function on every frame, if it returns true, will redraw
|
42 |
-
var canvg = function (target, s, opts) {
|
43 |
-
// no parameters
|
44 |
-
if (target == null && s == null && opts == null) {
|
45 |
-
var svgTags = document.querySelectorAll('svg');
|
46 |
-
for (var i=0; i<svgTags.length; i++) {
|
47 |
-
var svgTag = svgTags[i];
|
48 |
-
var c = document.createElement('canvas');
|
49 |
-
c.width = svgTag.clientWidth;
|
50 |
-
c.height = svgTag.clientHeight;
|
51 |
-
svgTag.parentNode.insertBefore(c, svgTag);
|
52 |
-
svgTag.parentNode.removeChild(svgTag);
|
53 |
-
var div = document.createElement('div');
|
54 |
-
div.appendChild(svgTag);
|
55 |
-
canvg(c, div.innerHTML);
|
56 |
-
}
|
57 |
-
return;
|
58 |
-
}
|
59 |
-
|
60 |
-
if (typeof target == 'string') {
|
61 |
-
target = document.getElementById(target);
|
62 |
-
}
|
63 |
-
|
64 |
-
// store class on canvas
|
65 |
-
if (target.svg != null) target.svg.stop();
|
66 |
-
var svg = build(opts || {});
|
67 |
-
// on i.e. 8 for flash canvas, we can't assign the property so check for it
|
68 |
-
if (!(target.childNodes.length == 1 && target.childNodes[0].nodeName == 'OBJECT')) target.svg = svg;
|
69 |
-
|
70 |
-
var ctx = target.getContext('2d');
|
71 |
-
if (typeof s.documentElement != 'undefined') {
|
72 |
-
// load from xml doc
|
73 |
-
svg.loadXmlDoc(ctx, s);
|
74 |
-
}
|
75 |
-
else if (s.substr(0,1) == '<') {
|
76 |
-
// load from xml string
|
77 |
-
svg.loadXml(ctx, s);
|
78 |
-
}
|
79 |
-
else {
|
80 |
-
// load from url
|
81 |
-
svg.load(ctx, s);
|
82 |
-
}
|
83 |
-
}
|
84 |
-
|
85 |
-
// see https://developer.mozilla.org/en-US/docs/Web/API/Element.matches
|
86 |
-
var matchesSelector;
|
87 |
-
if (typeof Element.prototype.matches != 'undefined') {
|
88 |
-
matchesSelector = function(node, selector) {
|
89 |
-
return node.matches(selector);
|
90 |
-
};
|
91 |
-
} else if (typeof Element.prototype.webkitMatchesSelector != 'undefined') {
|
92 |
-
matchesSelector = function(node, selector) {
|
93 |
-
return node.webkitMatchesSelector(selector);
|
94 |
-
};
|
95 |
-
} else if (typeof Element.prototype.mozMatchesSelector != 'undefined') {
|
96 |
-
matchesSelector = function(node, selector) {
|
97 |
-
return node.mozMatchesSelector(selector);
|
98 |
-
};
|
99 |
-
} else if (typeof Element.prototype.msMatchesSelector != 'undefined') {
|
100 |
-
matchesSelector = function(node, selector) {
|
101 |
-
return node.msMatchesSelector(selector);
|
102 |
-
};
|
103 |
-
} else if (typeof Element.prototype.oMatchesSelector != 'undefined') {
|
104 |
-
matchesSelector = function(node, selector) {
|
105 |
-
return node.oMatchesSelector(selector);
|
106 |
-
};
|
107 |
-
} else {
|
108 |
-
// requires Sizzle: https://github.com/jquery/sizzle/wiki/Sizzle-Documentation
|
109 |
-
// or jQuery: http://jquery.com/download/
|
110 |
-
// or Zepto: http://zeptojs.com/#
|
111 |
-
// without it, this is a ReferenceError
|
112 |
-
|
113 |
-
if (typeof jQuery === 'function' || typeof Zepto === 'function') {
|
114 |
-
matchesSelector = function (node, selector) {
|
115 |
-
return $(node).is(selector);
|
116 |
-
};
|
117 |
-
}
|
118 |
-
|
119 |
-
if (typeof matchesSelector === 'undefined') {
|
120 |
-
matchesSelector = Sizzle.matchesSelector;
|
121 |
-
}
|
122 |
-
}
|
123 |
-
|
124 |
-
// slightly modified version of https://github.com/keeganstreet/specificity/blob/master/specificity.js
|
125 |
-
var attributeRegex = /(\[[^\]]+\])/g;
|
126 |
-
var idRegex = /(#[^\s\+>~\.\[:]+)/g;
|
127 |
-
var classRegex = /(\.[^\s\+>~\.\[:]+)/g;
|
128 |
-
var pseudoElementRegex = /(::[^\s\+>~\.\[:]+|:first-line|:first-letter|:before|:after)/gi;
|
129 |
-
var pseudoClassWithBracketsRegex = /(:[\w-]+\([^\)]*\))/gi;
|
130 |
-
var pseudoClassRegex = /(:[^\s\+>~\.\[:]+)/g;
|
131 |
-
var elementRegex = /([^\s\+>~\.\[:]+)/g;
|
132 |
-
function getSelectorSpecificity(selector) {
|
133 |
-
var typeCount = [0, 0, 0];
|
134 |
-
var findMatch = function(regex, type) {
|
135 |
-
var matches = selector.match(regex);
|
136 |
-
if (matches == null) {
|
137 |
-
return;
|
138 |
-
}
|
139 |
-
typeCount[type] += matches.length;
|
140 |
-
selector = selector.replace(regex, ' ');
|
141 |
-
};
|
142 |
-
|
143 |
-
selector = selector.replace(/:not\(([^\)]*)\)/g, ' $1 ');
|
144 |
-
selector = selector.replace(/{[\s\S]*/gm, ' ');
|
145 |
-
findMatch(attributeRegex, 1);
|
146 |
-
findMatch(idRegex, 0);
|
147 |
-
findMatch(classRegex, 1);
|
148 |
-
findMatch(pseudoElementRegex, 2);
|
149 |
-
findMatch(pseudoClassWithBracketsRegex, 1);
|
150 |
-
findMatch(pseudoClassRegex, 1);
|
151 |
-
selector = selector.replace(/[\*\s\+>~]/g, ' ');
|
152 |
-
selector = selector.replace(/[#\.]/g, ' ');
|
153 |
-
findMatch(elementRegex, 2);
|
154 |
-
return typeCount.join('');
|
155 |
-
}
|
156 |
-
|
157 |
-
function build(opts) {
|
158 |
-
var svg = { opts: opts };
|
159 |
-
|
160 |
-
svg.FRAMERATE = 30;
|
161 |
-
svg.MAX_VIRTUAL_PIXELS = 30000;
|
162 |
-
|
163 |
-
svg.log = function(msg) {};
|
164 |
-
if (svg.opts['log'] == true && typeof console != 'undefined') {
|
165 |
-
svg.log = function(msg) { console.log(msg); };
|
166 |
-
};
|
167 |
-
|
168 |
-
// globals
|
169 |
-
svg.init = function(ctx) {
|
170 |
-
var uniqueId = 0;
|
171 |
-
svg.UniqueId = function () { uniqueId++; return 'canvg' + uniqueId; };
|
172 |
-
svg.Definitions = {};
|
173 |
-
svg.Styles = {};
|
174 |
-
svg.StylesSpecificity = {};
|
175 |
-
svg.Animations = [];
|
176 |
-
svg.Images = [];
|
177 |
-
svg.ctx = ctx;
|
178 |
-
svg.ViewPort = new (function () {
|
179 |
-
this.viewPorts = [];
|
180 |
-
this.Clear = function() { this.viewPorts = []; }
|
181 |
-
this.SetCurrent = function(width, height) { this.viewPorts.push({ width: width, height: height }); }
|
182 |
-
this.RemoveCurrent = function() { this.viewPorts.pop(); }
|
183 |
-
this.Current = function() { return this.viewPorts[this.viewPorts.length - 1]; }
|
184 |
-
this.width = function() { return this.Current().width; }
|
185 |
-
this.height = function() { return this.Current().height; }
|
186 |
-
this.ComputeSize = function(d) {
|
187 |
-
if (d != null && typeof d == 'number') return d;
|
188 |
-
if (d == 'x') return this.width();
|
189 |
-
if (d == 'y') return this.height();
|
190 |
-
return Math.sqrt(Math.pow(this.width(), 2) + Math.pow(this.height(), 2)) / Math.sqrt(2);
|
191 |
-
}
|
192 |
-
});
|
193 |
-
}
|
194 |
-
svg.init();
|
195 |
-
|
196 |
-
// images loaded
|
197 |
-
svg.ImagesLoaded = function() {
|
198 |
-
for (var i=0; i<svg.Images.length; i++) {
|
199 |
-
if (!svg.Images[i].loaded) return false;
|
200 |
-
}
|
201 |
-
return true;
|
202 |
-
}
|
203 |
-
|
204 |
-
// trim
|
205 |
-
svg.trim = function(s) { return s.replace(/^\s+|\s+$/g, ''); }
|
206 |
-
|
207 |
-
// compress spaces
|
208 |
-
svg.compressSpaces = function(s) { return s.replace(/[\s\r\t\n]+/gm,' '); }
|
209 |
-
|
210 |
-
// ajax
|
211 |
-
svg.ajax = function(url) {
|
212 |
-
var AJAX;
|
213 |
-
if(window.XMLHttpRequest){AJAX=new XMLHttpRequest();}
|
214 |
-
else{AJAX=new ActiveXObject('Microsoft.XMLHTTP');}
|
215 |
-
if(AJAX){
|
216 |
-
AJAX.open('GET',url,false);
|
217 |
-
AJAX.send(null);
|
218 |
-
return AJAX.responseText;
|
219 |
-
}
|
220 |
-
return null;
|
221 |
-
}
|
222 |
-
|
223 |
-
// parse xml
|
224 |
-
svg.parseXml = function(xml) {
|
225 |
-
if (typeof Windows != 'undefined' && typeof Windows.Data != 'undefined' && typeof Windows.Data.Xml != 'undefined') {
|
226 |
-
var xmlDoc = new Windows.Data.Xml.Dom.XmlDocument();
|
227 |
-
var settings = new Windows.Data.Xml.Dom.XmlLoadSettings();
|
228 |
-
settings.prohibitDtd = false;
|
229 |
-
xmlDoc.loadXml(xml, settings);
|
230 |
-
return xmlDoc;
|
231 |
-
}
|
232 |
-
else if (window.DOMParser)
|
233 |
-
{
|
234 |
-
var parser = new DOMParser();
|
235 |
-
return parser.parseFromString(xml, 'text/xml');
|
236 |
-
}
|
237 |
-
else
|
238 |
-
{
|
239 |
-
xml = xml.replace(/<!DOCTYPE svg[^>]*>/, '');
|
240 |
-
var xmlDoc = new ActiveXObject('Microsoft.XMLDOM');
|
241 |
-
xmlDoc.async = 'false';
|
242 |
-
xmlDoc.loadXML(xml);
|
243 |
-
return xmlDoc;
|
244 |
-
}
|
245 |
-
}
|
246 |
-
|
247 |
-
svg.Property = function(name, value) {
|
248 |
-
this.name = name;
|
249 |
-
this.value = value;
|
250 |
-
}
|
251 |
-
svg.Property.prototype.getValue = function() {
|
252 |
-
return this.value;
|
253 |
-
}
|
254 |
-
|
255 |
-
svg.Property.prototype.hasValue = function() {
|
256 |
-
return (this.value != null && this.value !== '');
|
257 |
-
}
|
258 |
-
|
259 |
-
// return the numerical value of the property
|
260 |
-
svg.Property.prototype.numValue = function() {
|
261 |
-
if (!this.hasValue()) return 0;
|
262 |
-
|
263 |
-
var n = parseFloat(this.value);
|
264 |
-
if ((this.value + '').match(/%$/)) {
|
265 |
-
n = n / 100.0;
|
266 |
-
}
|
267 |
-
return n;
|
268 |
-
}
|
269 |
-
|
270 |
-
svg.Property.prototype.valueOrDefault = function(def) {
|
271 |
-
if (this.hasValue()) return this.value;
|
272 |
-
return def;
|
273 |
-
}
|
274 |
-
|
275 |
-
svg.Property.prototype.numValueOrDefault = function(def) {
|
276 |
-
if (this.hasValue()) return this.numValue();
|
277 |
-
return def;
|
278 |
-
}
|
279 |
-
|
280 |
-
// color extensions
|
281 |
-
// augment the current color value with the opacity
|
282 |
-
svg.Property.prototype.addOpacity = function(opacityProp) {
|
283 |
-
var newValue = this.value;
|
284 |
-
if (opacityProp.value != null && opacityProp.value != '' && typeof this.value == 'string') { // can only add opacity to colors, not patterns
|
285 |
-
var color = new RGBColor(this.value);
|
286 |
-
if (color.ok) {
|
287 |
-
newValue = 'rgba(' + color.r + ', ' + color.g + ', ' + color.b + ', ' + opacityProp.numValue() + ')';
|
288 |
-
}
|
289 |
-
}
|
290 |
-
return new svg.Property(this.name, newValue);
|
291 |
-
}
|
292 |
-
|
293 |
-
// definition extensions
|
294 |
-
// get the definition from the definitions table
|
295 |
-
svg.Property.prototype.getDefinition = function() {
|
296 |
-
var name = this.value.match(/#([^\)'"]+)/);
|
297 |
-
if (name) { name = name[1]; }
|
298 |
-
if (!name) { name = this.value; }
|
299 |
-
return svg.Definitions[name];
|
300 |
-
}
|
301 |
-
|
302 |
-
svg.Property.prototype.isUrlDefinition = function() {
|
303 |
-
return this.value.indexOf('url(') == 0
|
304 |
-
}
|
305 |
-
|
306 |
-
svg.Property.prototype.getFillStyleDefinition = function(e, opacityProp) {
|
307 |
-
var def = this.getDefinition();
|
308 |
-
|
309 |
-
// gradient
|
310 |
-
if (def != null && def.createGradient) {
|
311 |
-
return def.createGradient(svg.ctx, e, opacityProp);
|
312 |
-
}
|
313 |
-
|
314 |
-
// pattern
|
315 |
-
if (def != null && def.createPattern) {
|
316 |
-
if (def.getHrefAttribute().hasValue()) {
|
317 |
-
var pt = def.attribute('patternTransform');
|
318 |
-
def = def.getHrefAttribute().getDefinition();
|
319 |
-
if (pt.hasValue()) { def.attribute('patternTransform', true).value = pt.value; }
|
320 |
-
}
|
321 |
-
return def.createPattern(svg.ctx, e);
|
322 |
-
}
|
323 |
-
|
324 |
-
return null;
|
325 |
-
}
|
326 |
-
|
327 |
-
// length extensions
|
328 |
-
svg.Property.prototype.getDPI = function(viewPort) {
|
329 |
-
return 96.0; // TODO: compute?
|
330 |
-
}
|
331 |
-
|
332 |
-
svg.Property.prototype.getEM = function(viewPort) {
|
333 |
-
var em = 12;
|
334 |
-
|
335 |
-
var fontSize = new svg.Property('fontSize', svg.Font.Parse(svg.ctx.font).fontSize);
|
336 |
-
if (fontSize.hasValue()) em = fontSize.toPixels(viewPort);
|
337 |
-
|
338 |
-
return em;
|
339 |
-
}
|
340 |
-
|
341 |
-
svg.Property.prototype.getUnits = function() {
|
342 |
-
var s = this.value+'';
|
343 |
-
return s.replace(/[0-9\.\-]/g,'');
|
344 |
-
}
|
345 |
-
|
346 |
-
// get the length as pixels
|
347 |
-
svg.Property.prototype.toPixels = function(viewPort, processPercent) {
|
348 |
-
if (!this.hasValue()) return 0;
|
349 |
-
var s = this.value+'';
|
350 |
-
if (s.match(/em$/)) return this.numValue() * this.getEM(viewPort);
|
351 |
-
if (s.match(/ex$/)) return this.numValue() * this.getEM(viewPort) / 2.0;
|
352 |
-
if (s.match(/px$/)) return this.numValue();
|
353 |
-
if (s.match(/pt$/)) return this.numValue() * this.getDPI(viewPort) * (1.0 / 72.0);
|
354 |
-
if (s.match(/pc$/)) return this.numValue() * 15;
|
355 |
-
if (s.match(/cm$/)) return this.numValue() * this.getDPI(viewPort) / 2.54;
|
356 |
-
if (s.match(/mm$/)) return this.numValue() * this.getDPI(viewPort) / 25.4;
|
357 |
-
if (s.match(/in$/)) return this.numValue() * this.getDPI(viewPort);
|
358 |
-
if (s.match(/%$/)) return this.numValue() * svg.ViewPort.ComputeSize(viewPort);
|
359 |
-
var n = this.numValue();
|
360 |
-
if (processPercent && n < 1.0) return n * svg.ViewPort.ComputeSize(viewPort);
|
361 |
-
return n;
|
362 |
-
}
|
363 |
-
|
364 |
-
// time extensions
|
365 |
-
// get the time as milliseconds
|
366 |
-
svg.Property.prototype.toMilliseconds = function() {
|
367 |
-
if (!this.hasValue()) return 0;
|
368 |
-
var s = this.value+'';
|
369 |
-
if (s.match(/s$/)) return this.numValue() * 1000;
|
370 |
-
if (s.match(/ms$/)) return this.numValue();
|
371 |
-
return this.numValue();
|
372 |
-
}
|
373 |
-
|
374 |
-
// angle extensions
|
375 |
-
// get the angle as radians
|
376 |
-
svg.Property.prototype.toRadians = function() {
|
377 |
-
if (!this.hasValue()) return 0;
|
378 |
-
var s = this.value+'';
|
379 |
-
if (s.match(/deg$/)) return this.numValue() * (Math.PI / 180.0);
|
380 |
-
if (s.match(/grad$/)) return this.numValue() * (Math.PI / 200.0);
|
381 |
-
if (s.match(/rad$/)) return this.numValue();
|
382 |
-
return this.numValue() * (Math.PI / 180.0);
|
383 |
-
}
|
384 |
-
|
385 |
-
// text extensions
|
386 |
-
// get the text baseline
|
387 |
-
var textBaselineMapping = {
|
388 |
-
'baseline': 'alphabetic',
|
389 |
-
'before-edge': 'top',
|
390 |
-
'text-before-edge': 'top',
|
391 |
-
'middle': 'middle',
|
392 |
-
'central': 'middle',
|
393 |
-
'after-edge': 'bottom',
|
394 |
-
'text-after-edge': 'bottom',
|
395 |
-
'ideographic': 'ideographic',
|
396 |
-
'alphabetic': 'alphabetic',
|
397 |
-
'hanging': 'hanging',
|
398 |
-
'mathematical': 'alphabetic'
|
399 |
-
};
|
400 |
-
svg.Property.prototype.toTextBaseline = function () {
|
401 |
-
if (!this.hasValue()) return null;
|
402 |
-
return textBaselineMapping[this.value];
|
403 |
-
}
|
404 |
-
|
405 |
-
// fonts
|
406 |
-
svg.Font = new (function() {
|
407 |
-
this.Styles = 'normal|italic|oblique|inherit';
|
408 |
-
this.Variants = 'normal|small-caps|inherit';
|
409 |
-
this.Weights = 'normal|bold|bolder|lighter|100|200|300|400|500|600|700|800|900|inherit';
|
410 |
-
|
411 |
-
this.CreateFont = function(fontStyle, fontVariant, fontWeight, fontSize, fontFamily, inherit) {
|
412 |
-
var f = inherit != null ? this.Parse(inherit) : this.CreateFont('', '', '', '', '', svg.ctx.font);
|
413 |
-
return {
|
414 |
-
fontFamily: fontFamily || f.fontFamily,
|
415 |
-
fontSize: fontSize || f.fontSize,
|
416 |
-
fontStyle: fontStyle || f.fontStyle,
|
417 |
-
fontWeight: fontWeight || f.fontWeight,
|
418 |
-
fontVariant: fontVariant || f.fontVariant,
|
419 |
-
toString: function () { return [this.fontStyle, this.fontVariant, this.fontWeight, this.fontSize, this.fontFamily].join(' ') }
|
420 |
-
}
|
421 |
-
}
|
422 |
-
|
423 |
-
var that = this;
|
424 |
-
this.Parse = function(s) {
|
425 |
-
var f = {};
|
426 |
-
var d = svg.trim(svg.compressSpaces(s || '')).split(' ');
|
427 |
-
var set = { fontSize: false, fontStyle: false, fontWeight: false, fontVariant: false }
|
428 |
-
var ff = '';
|
429 |
-
for (var i=0; i<d.length; i++) {
|
430 |
-
if (!set.fontStyle && that.Styles.indexOf(d[i]) != -1) { if (d[i] != 'inherit') f.fontStyle = d[i]; set.fontStyle = true; }
|
431 |
-
else if (!set.fontVariant && that.Variants.indexOf(d[i]) != -1) { if (d[i] != 'inherit') f.fontVariant = d[i]; set.fontStyle = set.fontVariant = true; }
|
432 |
-
else if (!set.fontWeight && that.Weights.indexOf(d[i]) != -1) { if (d[i] != 'inherit') f.fontWeight = d[i]; set.fontStyle = set.fontVariant = set.fontWeight = true; }
|
433 |
-
else if (!set.fontSize) { if (d[i] != 'inherit') f.fontSize = d[i].split('/')[0]; set.fontStyle = set.fontVariant = set.fontWeight = set.fontSize = true; }
|
434 |
-
else { if (d[i] != 'inherit') ff += d[i]; }
|
435 |
-
} if (ff != '') f.fontFamily = ff;
|
436 |
-
return f;
|
437 |
-
}
|
438 |
-
});
|
439 |
-
|
440 |
-
// points and paths
|
441 |
-
svg.ToNumberArray = function(s) {
|
442 |
-
var a = svg.trim(svg.compressSpaces((s || '').replace(/,/g, ' '))).split(' ');
|
443 |
-
for (var i=0; i<a.length; i++) {
|
444 |
-
a[i] = parseFloat(a[i]);
|
445 |
-
}
|
446 |
-
return a;
|
447 |
-
}
|
448 |
-
svg.Point = function(x, y) {
|
449 |
-
this.x = x;
|
450 |
-
this.y = y;
|
451 |
-
}
|
452 |
-
svg.Point.prototype.angleTo = function(p) {
|
453 |
-
return Math.atan2(p.y - this.y, p.x - this.x);
|
454 |
-
}
|
455 |
-
|
456 |
-
svg.Point.prototype.applyTransform = function(v) {
|
457 |
-
var xp = this.x * v[0] + this.y * v[2] + v[4];
|
458 |
-
var yp = this.x * v[1] + this.y * v[3] + v[5];
|
459 |
-
this.x = xp;
|
460 |
-
this.y = yp;
|
461 |
-
}
|
462 |
-
|
463 |
-
svg.CreatePoint = function(s) {
|
464 |
-
var a = svg.ToNumberArray(s);
|
465 |
-
return new svg.Point(a[0], a[1]);
|
466 |
-
}
|
467 |
-
svg.CreatePath = function(s) {
|
468 |
-
var a = svg.ToNumberArray(s);
|
469 |
-
var path = [];
|
470 |
-
for (var i=0; i<a.length; i+=2) {
|
471 |
-
path.push(new svg.Point(a[i], a[i+1]));
|
472 |
-
}
|
473 |
-
return path;
|
474 |
-
}
|
475 |
-
|
476 |
-
// bounding box
|
477 |
-
svg.BoundingBox = function(x1, y1, x2, y2) { // pass in initial points if you want
|
478 |
-
this.x1 = Number.NaN;
|
479 |
-
this.y1 = Number.NaN;
|
480 |
-
this.x2 = Number.NaN;
|
481 |
-
this.y2 = Number.NaN;
|
482 |
-
|
483 |
-
this.x = function() { return this.x1; }
|
484 |
-
this.y = function() { return this.y1; }
|
485 |
-
this.width = function() { return this.x2 - this.x1; }
|
486 |
-
this.height = function() { return this.y2 - this.y1; }
|
487 |
-
|
488 |
-
this.addPoint = function(x, y) {
|
489 |
-
if (x != null) {
|
490 |
-
if (isNaN(this.x1) || isNaN(this.x2)) {
|
491 |
-
this.x1 = x;
|
492 |
-
this.x2 = x;
|
493 |
-
}
|
494 |
-
if (x < this.x1) this.x1 = x;
|
495 |
-
if (x > this.x2) this.x2 = x;
|
496 |
-
}
|
497 |
-
|
498 |
-
if (y != null) {
|
499 |
-
if (isNaN(this.y1) || isNaN(this.y2)) {
|
500 |
-
this.y1 = y;
|
501 |
-
this.y2 = y;
|
502 |
-
}
|
503 |
-
if (y < this.y1) this.y1 = y;
|
504 |
-
if (y > this.y2) this.y2 = y;
|
505 |
-
}
|
506 |
-
}
|
507 |
-
this.addX = function(x) { this.addPoint(x, null); }
|
508 |
-
this.addY = function(y) { this.addPoint(null, y); }
|
509 |
-
|
510 |
-
this.addBoundingBox = function(bb) {
|
511 |
-
this.addPoint(bb.x1, bb.y1);
|
512 |
-
this.addPoint(bb.x2, bb.y2);
|
513 |
-
}
|
514 |
-
|
515 |
-
this.addQuadraticCurve = function(p0x, p0y, p1x, p1y, p2x, p2y) {
|
516 |
-
var cp1x = p0x + 2/3 * (p1x - p0x); // CP1 = QP0 + 2/3 *(QP1-QP0)
|
517 |
-
var cp1y = p0y + 2/3 * (p1y - p0y); // CP1 = QP0 + 2/3 *(QP1-QP0)
|
518 |
-
var cp2x = cp1x + 1/3 * (p2x - p0x); // CP2 = CP1 + 1/3 *(QP2-QP0)
|
519 |
-
var cp2y = cp1y + 1/3 * (p2y - p0y); // CP2 = CP1 + 1/3 *(QP2-QP0)
|
520 |
-
this.addBezierCurve(p0x, p0y, cp1x, cp2x, cp1y, cp2y, p2x, p2y);
|
521 |
-
}
|
522 |
-
|
523 |
-
this.addBezierCurve = function(p0x, p0y, p1x, p1y, p2x, p2y, p3x, p3y) {
|
524 |
-
// from http://blog.hackers-cafe.net/2009/06/how-to-calculate-bezier-curves-bounding.html
|
525 |
-
var p0 = [p0x, p0y], p1 = [p1x, p1y], p2 = [p2x, p2y], p3 = [p3x, p3y];
|
526 |
-
this.addPoint(p0[0], p0[1]);
|
527 |
-
this.addPoint(p3[0], p3[1]);
|
528 |
-
|
529 |
-
for (i=0; i<=1; i++) {
|
530 |
-
var f = function(t) {
|
531 |
-
return Math.pow(1-t, 3) * p0[i]
|
532 |
-
+ 3 * Math.pow(1-t, 2) * t * p1[i]
|
533 |
-
+ 3 * (1-t) * Math.pow(t, 2) * p2[i]
|
534 |
-
+ Math.pow(t, 3) * p3[i];
|
535 |
-
}
|
536 |
-
|
537 |
-
var b = 6 * p0[i] - 12 * p1[i] + 6 * p2[i];
|
538 |
-
var a = -3 * p0[i] + 9 * p1[i] - 9 * p2[i] + 3 * p3[i];
|
539 |
-
var c = 3 * p1[i] - 3 * p0[i];
|
540 |
-
|
541 |
-
if (a == 0) {
|
542 |
-
if (b == 0) continue;
|
543 |
-
var t = -c / b;
|
544 |
-
if (0 < t && t < 1) {
|
545 |
-
if (i == 0) this.addX(f(t));
|
546 |
-
if (i == 1) this.addY(f(t));
|
547 |
-
}
|
548 |
-
continue;
|
549 |
-
}
|
550 |
-
|
551 |
-
var b2ac = Math.pow(b, 2) - 4 * c * a;
|
552 |
-
if (b2ac < 0) continue;
|
553 |
-
var t1 = (-b + Math.sqrt(b2ac)) / (2 * a);
|
554 |
-
if (0 < t1 && t1 < 1) {
|
555 |
-
if (i == 0) this.addX(f(t1));
|
556 |
-
if (i == 1) this.addY(f(t1));
|
557 |
-
}
|
558 |
-
var t2 = (-b - Math.sqrt(b2ac)) / (2 * a);
|
559 |
-
if (0 < t2 && t2 < 1) {
|
560 |
-
if (i == 0) this.addX(f(t2));
|
561 |
-
if (i == 1) this.addY(f(t2));
|
562 |
-
}
|
563 |
-
}
|
564 |
-
}
|
565 |
-
|
566 |
-
this.isPointInBox = function(x, y) {
|
567 |
-
return (this.x1 <= x && x <= this.x2 && this.y1 <= y && y <= this.y2);
|
568 |
-
}
|
569 |
-
|
570 |
-
this.addPoint(x1, y1);
|
571 |
-
this.addPoint(x2, y2);
|
572 |
-
}
|
573 |
-
|
574 |
-
// transforms
|
575 |
-
svg.Transform = function(v) {
|
576 |
-
var that = this;
|
577 |
-
this.Type = {}
|
578 |
-
|
579 |
-
// translate
|
580 |
-
this.Type.translate = function(s) {
|
581 |
-
this.p = svg.CreatePoint(s);
|
582 |
-
this.apply = function(ctx) {
|
583 |
-
ctx.translate(this.p.x || 0.0, this.p.y || 0.0);
|
584 |
-
}
|
585 |
-
this.unapply = function(ctx) {
|
586 |
-
ctx.translate(-1.0 * this.p.x || 0.0, -1.0 * this.p.y || 0.0);
|
587 |
-
}
|
588 |
-
this.applyToPoint = function(p) {
|
589 |
-
p.applyTransform([1, 0, 0, 1, this.p.x || 0.0, this.p.y || 0.0]);
|
590 |
-
}
|
591 |
-
}
|
592 |
-
|
593 |
-
// rotate
|
594 |
-
this.Type.rotate = function(s) {
|
595 |
-
var a = svg.ToNumberArray(s);
|
596 |
-
this.angle = new svg.Property('angle', a[0]);
|
597 |
-
this.cx = a[1] || 0;
|
598 |
-
this.cy = a[2] || 0;
|
599 |
-
this.apply = function(ctx) {
|
600 |
-
ctx.translate(this.cx, this.cy);
|
601 |
-
ctx.rotate(this.angle.toRadians());
|
602 |
-
ctx.translate(-this.cx, -this.cy);
|
603 |
-
}
|
604 |
-
this.unapply = function(ctx) {
|
605 |
-
ctx.translate(this.cx, this.cy);
|
606 |
-
ctx.rotate(-1.0 * this.angle.toRadians());
|
607 |
-
ctx.translate(-this.cx, -this.cy);
|
608 |
-
}
|
609 |
-
this.applyToPoint = function(p) {
|
610 |
-
var a = this.angle.toRadians();
|
611 |
-
p.applyTransform([1, 0, 0, 1, this.p.x || 0.0, this.p.y || 0.0]);
|
612 |
-
p.applyTransform([Math.cos(a), Math.sin(a), -Math.sin(a), Math.cos(a), 0, 0]);
|
613 |
-
p.applyTransform([1, 0, 0, 1, -this.p.x || 0.0, -this.p.y || 0.0]);
|
614 |
-
}
|
615 |
-
}
|
616 |
-
|
617 |
-
this.Type.scale = function(s) {
|
618 |
-
this.p = svg.CreatePoint(s);
|
619 |
-
this.apply = function(ctx) {
|
620 |
-
ctx.scale(this.p.x || 1.0, this.p.y || this.p.x || 1.0);
|
621 |
-
}
|
622 |
-
this.unapply = function(ctx) {
|
623 |
-
ctx.scale(1.0 / this.p.x || 1.0, 1.0 / this.p.y || this.p.x || 1.0);
|
624 |
-
}
|
625 |
-
this.applyToPoint = function(p) {
|
626 |
-
p.applyTransform([this.p.x || 0.0, 0, 0, this.p.y || 0.0, 0, 0]);
|
627 |
-
}
|
628 |
-
}
|
629 |
-
|
630 |
-
this.Type.matrix = function(s) {
|
631 |
-
this.m = svg.ToNumberArray(s);
|
632 |
-
this.apply = function(ctx) {
|
633 |
-
ctx.transform(this.m[0], this.m[1], this.m[2], this.m[3], this.m[4], this.m[5]);
|
634 |
-
}
|
635 |
-
this.unapply = function(ctx) {
|
636 |
-
var a = this.m[0];
|
637 |
-
var b = this.m[2];
|
638 |
-
var c = this.m[4];
|
639 |
-
var d = this.m[1];
|
640 |
-
var e = this.m[3];
|
641 |
-
var f = this.m[5];
|
642 |
-
var g = 0.0;
|
643 |
-
var h = 0.0;
|
644 |
-
var i = 1.0;
|
645 |
-
var det = 1 / (a*(e*i-f*h)-b*(d*i-f*g)+c*(d*h-e*g));
|
646 |
-
ctx.transform(
|
647 |
-
det*(e*i-f*h),
|
648 |
-
det*(f*g-d*i),
|
649 |
-
det*(c*h-b*i),
|
650 |
-
det*(a*i-c*g),
|
651 |
-
det*(b*f-c*e),
|
652 |
-
det*(c*d-a*f)
|
653 |
-
);
|
654 |
-
}
|
655 |
-
this.applyToPoint = function(p) {
|
656 |
-
p.applyTransform(this.m);
|
657 |
-
}
|
658 |
-
}
|
659 |
-
|
660 |
-
this.Type.SkewBase = function(s) {
|
661 |
-
this.base = that.Type.matrix;
|
662 |
-
this.base(s);
|
663 |
-
this.angle = new svg.Property('angle', s);
|
664 |
-
}
|
665 |
-
this.Type.SkewBase.prototype = new this.Type.matrix;
|
666 |
-
|
667 |
-
this.Type.skewX = function(s) {
|
668 |
-
this.base = that.Type.SkewBase;
|
669 |
-
this.base(s);
|
670 |
-
this.m = [1, 0, Math.tan(this.angle.toRadians()), 1, 0, 0];
|
671 |
-
}
|
672 |
-
this.Type.skewX.prototype = new this.Type.SkewBase;
|
673 |
-
|
674 |
-
this.Type.skewY = function(s) {
|
675 |
-
this.base = that.Type.SkewBase;
|
676 |
-
this.base(s);
|
677 |
-
this.m = [1, Math.tan(this.angle.toRadians()), 0, 1, 0, 0];
|
678 |
-
}
|
679 |
-
this.Type.skewY.prototype = new this.Type.SkewBase;
|
680 |
-
|
681 |
-
this.transforms = [];
|
682 |
-
|
683 |
-
this.apply = function(ctx) {
|
684 |
-
for (var i=0; i<this.transforms.length; i++) {
|
685 |
-
this.transforms[i].apply(ctx);
|
686 |
-
}
|
687 |
-
}
|
688 |
-
|
689 |
-
this.unapply = function(ctx) {
|
690 |
-
for (var i=this.transforms.length-1; i>=0; i--) {
|
691 |
-
this.transforms[i].unapply(ctx);
|
692 |
-
}
|
693 |
-
}
|
694 |
-
|
695 |
-
this.applyToPoint = function(p) {
|
696 |
-
for (var i=0; i<this.transforms.length; i++) {
|
697 |
-
this.transforms[i].applyToPoint(p);
|
698 |
-
}
|
699 |
-
}
|
700 |
-
|
701 |
-
var data = svg.trim(svg.compressSpaces(v)).replace(/\)([a-zA-Z])/g, ') $1').replace(/\)(\s?,\s?)/g,') ').split(/\s(?=[a-z])/);
|
702 |
-
for (var i=0; i<data.length; i++) {
|
703 |
-
var type = svg.trim(data[i].split('(')[0]);
|
704 |
-
var s = data[i].split('(')[1].replace(')','');
|
705 |
-
var transformType = this.Type[type];
|
706 |
-
if (typeof transformType != 'undefined') {
|
707 |
-
var transform = new transformType(s);
|
708 |
-
transform.type = type;
|
709 |
-
this.transforms.push(transform);
|
710 |
-
}
|
711 |
-
}
|
712 |
-
}
|
713 |
-
|
714 |
-
// aspect ratio
|
715 |
-
svg.AspectRatio = function(ctx, aspectRatio, width, desiredWidth, height, desiredHeight, minX, minY, refX, refY) {
|
716 |
-
// aspect ratio - http://www.w3.org/TR/SVG/coords.html#PreserveAspectRatioAttribute
|
717 |
-
aspectRatio = svg.compressSpaces(aspectRatio);
|
718 |
-
aspectRatio = aspectRatio.replace(/^defer\s/,''); // ignore defer
|
719 |
-
var align = aspectRatio.split(' ')[0] || 'xMidYMid';
|
720 |
-
var meetOrSlice = aspectRatio.split(' ')[1] || 'meet';
|
721 |
-
|
722 |
-
// calculate scale
|
723 |
-
var scaleX = width / desiredWidth;
|
724 |
-
var scaleY = height / desiredHeight;
|
725 |
-
var scaleMin = Math.min(scaleX, scaleY);
|
726 |
-
var scaleMax = Math.max(scaleX, scaleY);
|
727 |
-
if (meetOrSlice == 'meet') { desiredWidth *= scaleMin; desiredHeight *= scaleMin; }
|
728 |
-
if (meetOrSlice == 'slice') { desiredWidth *= scaleMax; desiredHeight *= scaleMax; }
|
729 |
-
|
730 |
-
refX = new svg.Property('refX', refX);
|
731 |
-
refY = new svg.Property('refY', refY);
|
732 |
-
if (refX.hasValue() && refY.hasValue()) {
|
733 |
-
ctx.translate(-scaleMin * refX.toPixels('x'), -scaleMin * refY.toPixels('y'));
|
734 |
-
}
|
735 |
-
else {
|
736 |
-
// align
|
737 |
-
if (align.match(/^xMid/) && ((meetOrSlice == 'meet' && scaleMin == scaleY) || (meetOrSlice == 'slice' && scaleMax == scaleY))) ctx.translate(width / 2.0 - desiredWidth / 2.0, 0);
|
738 |
-
if (align.match(/YMid$/) && ((meetOrSlice == 'meet' && scaleMin == scaleX) || (meetOrSlice == 'slice' && scaleMax == scaleX))) ctx.translate(0, height / 2.0 - desiredHeight / 2.0);
|
739 |
-
if (align.match(/^xMax/) && ((meetOrSlice == 'meet' && scaleMin == scaleY) || (meetOrSlice == 'slice' && scaleMax == scaleY))) ctx.translate(width - desiredWidth, 0);
|
740 |
-
if (align.match(/YMax$/) && ((meetOrSlice == 'meet' && scaleMin == scaleX) || (meetOrSlice == 'slice' && scaleMax == scaleX))) ctx.translate(0, height - desiredHeight);
|
741 |
-
}
|
742 |
-
|
743 |
-
// scale
|
744 |
-
if (align == 'none') ctx.scale(scaleX, scaleY);
|
745 |
-
else if (meetOrSlice == 'meet') ctx.scale(scaleMin, scaleMin);
|
746 |
-
else if (meetOrSlice == 'slice') ctx.scale(scaleMax, scaleMax);
|
747 |
-
|
748 |
-
// translate
|
749 |
-
ctx.translate(minX == null ? 0 : -minX, minY == null ? 0 : -minY);
|
750 |
-
}
|
751 |
-
|
752 |
-
// elements
|
753 |
-
svg.Element = {}
|
754 |
-
|
755 |
-
svg.EmptyProperty = new svg.Property('EMPTY', '');
|
756 |
-
|
757 |
-
svg.Element.ElementBase = function(node) {
|
758 |
-
this.attributes = {};
|
759 |
-
this.styles = {};
|
760 |
-
this.stylesSpecificity = {};
|
761 |
-
this.children = [];
|
762 |
-
|
763 |
-
// get or create attribute
|
764 |
-
this.attribute = function(name, createIfNotExists) {
|
765 |
-
var a = this.attributes[name];
|
766 |
-
if (a != null) return a;
|
767 |
-
|
768 |
-
if (createIfNotExists == true) { a = new svg.Property(name, ''); this.attributes[name] = a; }
|
769 |
-
return a || svg.EmptyProperty;
|
770 |
-
}
|
771 |
-
|
772 |
-
this.getHrefAttribute = function() {
|
773 |
-
for (var a in this.attributes) {
|
774 |
-
if (a == 'href' || a.match(/:href$/)) {
|
775 |
-
return this.attributes[a];
|
776 |
-
}
|
777 |
-
}
|
778 |
-
return svg.EmptyProperty;
|
779 |
-
}
|
780 |
-
|
781 |
-
// get or create style, crawls up node tree
|
782 |
-
this.style = function(name, createIfNotExists, skipAncestors) {
|
783 |
-
var s = this.styles[name];
|
784 |
-
if (s != null) return s;
|
785 |
-
|
786 |
-
var a = this.attribute(name);
|
787 |
-
if (a != null && a.hasValue()) {
|
788 |
-
this.styles[name] = a; // move up to me to cache
|
789 |
-
return a;
|
790 |
-
}
|
791 |
-
|
792 |
-
if (skipAncestors != true) {
|
793 |
-
var p = this.parent;
|
794 |
-
if (p != null) {
|
795 |
-
var ps = p.style(name);
|
796 |
-
if (ps != null && ps.hasValue()) {
|
797 |
-
return ps;
|
798 |
-
}
|
799 |
-
}
|
800 |
-
}
|
801 |
-
|
802 |
-
if (createIfNotExists == true) { s = new svg.Property(name, ''); this.styles[name] = s; }
|
803 |
-
return s || svg.EmptyProperty;
|
804 |
-
}
|
805 |
-
|
806 |
-
// base render
|
807 |
-
this.render = function(ctx) {
|
808 |
-
// don't render display=none
|
809 |
-
if (this.style('display').value == 'none') return;
|
810 |
-
|
811 |
-
// don't render visibility=hidden
|
812 |
-
if (this.style('visibility').value == 'hidden') return;
|
813 |
-
|
814 |
-
ctx.save();
|
815 |
-
if (this.style('mask').hasValue()) { // mask
|
816 |
-
var mask = this.style('mask').getDefinition();
|
817 |
-
if (mask != null) mask.apply(ctx, this);
|
818 |
-
}
|
819 |
-
else if (this.style('filter').hasValue()) { // filter
|
820 |
-
var filter = this.style('filter').getDefinition();
|
821 |
-
if (filter != null) filter.apply(ctx, this);
|
822 |
-
}
|
823 |
-
else {
|
824 |
-
this.setContext(ctx);
|
825 |
-
this.renderChildren(ctx);
|
826 |
-
this.clearContext(ctx);
|
827 |
-
}
|
828 |
-
ctx.restore();
|
829 |
-
}
|
830 |
-
|
831 |
-
// base set context
|
832 |
-
this.setContext = function(ctx) {
|
833 |
-
// OVERRIDE ME!
|
834 |
-
}
|
835 |
-
|
836 |
-
// base clear context
|
837 |
-
this.clearContext = function(ctx) {
|
838 |
-
// OVERRIDE ME!
|
839 |
-
}
|
840 |
-
|
841 |
-
// base render children
|
842 |
-
this.renderChildren = function(ctx) {
|
843 |
-
for (var i=0; i<this.children.length; i++) {
|
844 |
-
this.children[i].render(ctx);
|
845 |
-
}
|
846 |
-
}
|
847 |
-
|
848 |
-
this.addChild = function(childNode, create) {
|
849 |
-
var child = childNode;
|
850 |
-
if (create) child = svg.CreateElement(childNode);
|
851 |
-
child.parent = this;
|
852 |
-
if (child.type != 'title') { this.children.push(child); }
|
853 |
-
}
|
854 |
-
|
855 |
-
this.addStylesFromStyleDefinition = function () {
|
856 |
-
// add styles
|
857 |
-
for (var selector in svg.Styles) {
|
858 |
-
if (selector[0] != '@' && matchesSelector(node, selector)) {
|
859 |
-
var styles = svg.Styles[selector];
|
860 |
-
var specificity = svg.StylesSpecificity[selector];
|
861 |
-
if (styles != null) {
|
862 |
-
for (var name in styles) {
|
863 |
-
var existingSpecificity = this.stylesSpecificity[name];
|
864 |
-
if (typeof existingSpecificity == 'undefined') {
|
865 |
-
existingSpecificity = '000';
|
866 |
-
}
|
867 |
-
if (specificity > existingSpecificity) {
|
868 |
-
this.styles[name] = styles[name];
|
869 |
-
this.stylesSpecificity[name] = specificity;
|
870 |
-
}
|
871 |
-
}
|
872 |
-
}
|
873 |
-
}
|
874 |
-
}
|
875 |
-
};
|
876 |
-
|
877 |
-
// Microsoft Edge fix
|
878 |
-
var allUppercase = new RegExp("^[A-Z\-]+$");
|
879 |
-
var normalizeAttributeName = function (name) {
|
880 |
-
if (allUppercase.test(name)) {
|
881 |
-
return name.toLowerCase();
|
882 |
-
}
|
883 |
-
return name;
|
884 |
-
};
|
885 |
-
|
886 |
-
if (node != null && node.nodeType == 1) { //ELEMENT_NODE
|
887 |
-
// add attributes
|
888 |
-
for (var i=0; i<node.attributes.length; i++) {
|
889 |
-
var attribute = node.attributes[i];
|
890 |
-
var nodeName = normalizeAttributeName(attribute.nodeName);
|
891 |
-
this.attributes[nodeName] = new svg.Property(nodeName, attribute.value);
|
892 |
-
}
|
893 |
-
|
894 |
-
this.addStylesFromStyleDefinition();
|
895 |
-
|
896 |
-
// add inline styles
|
897 |
-
if (this.attribute('style').hasValue()) {
|
898 |
-
var styles = this.attribute('style').value.split(';');
|
899 |
-
for (var i=0; i<styles.length; i++) {
|
900 |
-
if (svg.trim(styles[i]) != '') {
|
901 |
-
var style = styles[i].split(':');
|
902 |
-
var name = svg.trim(style[0]);
|
903 |
-
var value = svg.trim(style[1]);
|
904 |
-
this.styles[name] = new svg.Property(name, value);
|
905 |
-
}
|
906 |
-
}
|
907 |
-
}
|
908 |
-
|
909 |
-
// add id
|
910 |
-
if (this.attribute('id').hasValue()) {
|
911 |
-
if (svg.Definitions[this.attribute('id').value] == null) {
|
912 |
-
svg.Definitions[this.attribute('id').value] = this;
|
913 |
-
}
|
914 |
-
}
|
915 |
-
|
916 |
-
// add children
|
917 |
-
for (var i=0; i<node.childNodes.length; i++) {
|
918 |
-
var childNode = node.childNodes[i];
|
919 |
-
if (childNode.nodeType == 1) this.addChild(childNode, true); //ELEMENT_NODE
|
920 |
-
if (this.captureTextNodes && (childNode.nodeType == 3 || childNode.nodeType == 4)) {
|
921 |
-
var text = childNode.value || childNode.text || childNode.textContent || '';
|
922 |
-
if (svg.compressSpaces(text) != '') {
|
923 |
-
this.addChild(new svg.Element.tspan(childNode), false); // TEXT_NODE
|
924 |
-
}
|
925 |
-
}
|
926 |
-
}
|
927 |
-
}
|
928 |
-
}
|
929 |
-
|
930 |
-
svg.Element.RenderedElementBase = function(node) {
|
931 |
-
this.base = svg.Element.ElementBase;
|
932 |
-
this.base(node);
|
933 |
-
|
934 |
-
this.setContext = function(ctx) {
|
935 |
-
// fill
|
936 |
-
if (this.style('fill').isUrlDefinition()) {
|
937 |
-
var fs = this.style('fill').getFillStyleDefinition(this, this.style('fill-opacity'));
|
938 |
-
if (fs != null) ctx.fillStyle = fs;
|
939 |
-
}
|
940 |
-
else if (this.style('fill').hasValue()) {
|
941 |
-
var fillStyle = this.style('fill');
|
942 |
-
if (fillStyle.value == 'currentColor') fillStyle.value = this.style('color').value;
|
943 |
-
if (fillStyle.value != 'inherit') ctx.fillStyle = (fillStyle.value == 'none' ? 'rgba(0,0,0,0)' : fillStyle.value);
|
944 |
-
}
|
945 |
-
if (this.style('fill-opacity').hasValue()) {
|
946 |
-
var fillStyle = new svg.Property('fill', ctx.fillStyle);
|
947 |
-
fillStyle = fillStyle.addOpacity(this.style('fill-opacity'));
|
948 |
-
ctx.fillStyle = fillStyle.value;
|
949 |
-
}
|
950 |
-
|
951 |
-
// stroke
|
952 |
-
if (this.style('stroke').isUrlDefinition()) {
|
953 |
-
var fs = this.style('stroke').getFillStyleDefinition(this, this.style('stroke-opacity'));
|
954 |
-
if (fs != null) ctx.strokeStyle = fs;
|
955 |
-
}
|
956 |
-
else if (this.style('stroke').hasValue()) {
|
957 |
-
var strokeStyle = this.style('stroke');
|
958 |
-
if (strokeStyle.value == 'currentColor') strokeStyle.value = this.style('color').value;
|
959 |
-
if (strokeStyle.value != 'inherit') ctx.strokeStyle = (strokeStyle.value == 'none' ? 'rgba(0,0,0,0)' : strokeStyle.value);
|
960 |
-
}
|
961 |
-
if (this.style('stroke-opacity').hasValue()) {
|
962 |
-
var strokeStyle = new svg.Property('stroke', ctx.strokeStyle);
|
963 |
-
strokeStyle = strokeStyle.addOpacity(this.style('stroke-opacity'));
|
964 |
-
ctx.strokeStyle = strokeStyle.value;
|
965 |
-
}
|
966 |
-
if (this.style('stroke-width').hasValue()) {
|
967 |
-
var newLineWidth = this.style('stroke-width').toPixels();
|
968 |
-
ctx.lineWidth = newLineWidth == 0 ? 0.001 : newLineWidth; // browsers don't respect 0
|
969 |
-
}
|
970 |
-
if (this.style('stroke-linecap').hasValue()) ctx.lineCap = this.style('stroke-linecap').value;
|
971 |
-
if (this.style('stroke-linejoin').hasValue()) ctx.lineJoin = this.style('stroke-linejoin').value;
|
972 |
-
if (this.style('stroke-miterlimit').hasValue()) ctx.miterLimit = this.style('stroke-miterlimit').value;
|
973 |
-
if (this.style('stroke-dasharray').hasValue() && this.style('stroke-dasharray').value != 'none') {
|
974 |
-
var gaps = svg.ToNumberArray(this.style('stroke-dasharray').value);
|
975 |
-
if (typeof ctx.setLineDash != 'undefined') { ctx.setLineDash(gaps); }
|
976 |
-
else if (typeof ctx.webkitLineDash != 'undefined') { ctx.webkitLineDash = gaps; }
|
977 |
-
else if (typeof ctx.mozDash != 'undefined' && !(gaps.length==1 && gaps[0]==0)) { ctx.mozDash = gaps; }
|
978 |
-
|
979 |
-
var offset = this.style('stroke-dashoffset').numValueOrDefault(1);
|
980 |
-
if (typeof ctx.lineDashOffset != 'undefined') { ctx.lineDashOffset = offset; }
|
981 |
-
else if (typeof ctx.webkitLineDashOffset != 'undefined') { ctx.webkitLineDashOffset = offset; }
|
982 |
-
else if (typeof ctx.mozDashOffset != 'undefined') { ctx.mozDashOffset = offset; }
|
983 |
-
}
|
984 |
-
|
985 |
-
// font
|
986 |
-
if (typeof ctx.font != 'undefined') {
|
987 |
-
ctx.font = svg.Font.CreateFont(
|
988 |
-
this.style('font-style').value,
|
989 |
-
this.style('font-variant').value,
|
990 |
-
this.style('font-weight').value,
|
991 |
-
this.style('font-size').hasValue() ? this.style('font-size').toPixels() + 'px' : '',
|
992 |
-
this.style('font-family').value).toString();
|
993 |
-
}
|
994 |
-
|
995 |
-
// transform
|
996 |
-
if (this.style('transform', false, true).hasValue()) {
|
997 |
-
var transform = new svg.Transform(this.style('transform', false, true).value);
|
998 |
-
transform.apply(ctx);
|
999 |
-
}
|
1000 |
-
|
1001 |
-
// clip
|
1002 |
-
if (this.style('clip-path', false, true).hasValue()) {
|
1003 |
-
var clip = this.style('clip-path', false, true).getDefinition();
|
1004 |
-
if (clip != null) clip.apply(ctx);
|
1005 |
-
}
|
1006 |
-
|
1007 |
-
// opacity
|
1008 |
-
if (this.style('opacity').hasValue()) {
|
1009 |
-
ctx.globalAlpha = this.style('opacity').numValue();
|
1010 |
-
}
|
1011 |
-
}
|
1012 |
-
}
|
1013 |
-
svg.Element.RenderedElementBase.prototype = new svg.Element.ElementBase;
|
1014 |
-
|
1015 |
-
svg.Element.PathElementBase = function(node) {
|
1016 |
-
this.base = svg.Element.RenderedElementBase;
|
1017 |
-
this.base(node);
|
1018 |
-
|
1019 |
-
this.path = function(ctx) {
|
1020 |
-
if (ctx != null) ctx.beginPath();
|
1021 |
-
return new svg.BoundingBox();
|
1022 |
-
}
|
1023 |
-
|
1024 |
-
this.renderChildren = function(ctx) {
|
1025 |
-
this.path(ctx);
|
1026 |
-
svg.Mouse.checkPath(this, ctx);
|
1027 |
-
if (ctx.fillStyle != '') {
|
1028 |
-
if (this.style('fill-rule').valueOrDefault('inherit') != 'inherit') { ctx.fill(this.style('fill-rule').value); }
|
1029 |
-
else { ctx.fill(); }
|
1030 |
-
}
|
1031 |
-
if (ctx.strokeStyle != '') ctx.stroke();
|
1032 |
-
|
1033 |
-
var markers = this.getMarkers();
|
1034 |
-
if (markers != null) {
|
1035 |
-
if (this.style('marker-start').isUrlDefinition()) {
|
1036 |
-
var marker = this.style('marker-start').getDefinition();
|
1037 |
-
marker.render(ctx, markers[0][0], markers[0][1]);
|
1038 |
-
}
|
1039 |
-
if (this.style('marker-mid').isUrlDefinition()) {
|
1040 |
-
var marker = this.style('marker-mid').getDefinition();
|
1041 |
-
for (var i=1;i<markers.length-1;i++) {
|
1042 |
-
marker.render(ctx, markers[i][0], markers[i][1]);
|
1043 |
-
}
|
1044 |
-
}
|
1045 |
-
if (this.style('marker-end').isUrlDefinition()) {
|
1046 |
-
var marker = this.style('marker-end').getDefinition();
|
1047 |
-
marker.render(ctx, markers[markers.length-1][0], markers[markers.length-1][1]);
|
1048 |
-
}
|
1049 |
-
}
|
1050 |
-
}
|
1051 |
-
|
1052 |
-
this.getBoundingBox = function() {
|
1053 |
-
return this.path();
|
1054 |
-
}
|
1055 |
-
|
1056 |
-
this.getMarkers = function() {
|
1057 |
-
return null;
|
1058 |
-
}
|
1059 |
-
}
|
1060 |
-
svg.Element.PathElementBase.prototype = new svg.Element.RenderedElementBase;
|
1061 |
-
|
1062 |
-
// svg element
|
1063 |
-
svg.Element.svg = function(node) {
|
1064 |
-
this.base = svg.Element.RenderedElementBase;
|
1065 |
-
this.base(node);
|
1066 |
-
|
1067 |
-
this.baseClearContext = this.clearContext;
|
1068 |
-
this.clearContext = function(ctx) {
|
1069 |
-
this.baseClearContext(ctx);
|
1070 |
-
svg.ViewPort.RemoveCurrent();
|
1071 |
-
}
|
1072 |
-
|
1073 |
-
this.baseSetContext = this.setContext;
|
1074 |
-
this.setContext = function(ctx) {
|
1075 |
-
// initial values and defaults
|
1076 |
-
ctx.strokeStyle = 'rgba(0,0,0,0)';
|
1077 |
-
ctx.lineCap = 'butt';
|
1078 |
-
ctx.lineJoin = 'miter';
|
1079 |
-
ctx.miterLimit = 4;
|
1080 |
-
if (typeof ctx.font != 'undefined' && typeof window.getComputedStyle != 'undefined') {
|
1081 |
-
ctx.font = window.getComputedStyle(ctx.canvas).getPropertyValue('font');
|
1082 |
-
}
|
1083 |
-
|
1084 |
-
this.baseSetContext(ctx);
|
1085 |
-
|
1086 |
-
// create new view port
|
1087 |
-
if (!this.attribute('x').hasValue()) this.attribute('x', true).value = 0;
|
1088 |
-
if (!this.attribute('y').hasValue()) this.attribute('y', true).value = 0;
|
1089 |
-
ctx.translate(this.attribute('x').toPixels('x'), this.attribute('y').toPixels('y'));
|
1090 |
-
|
1091 |
-
var width = svg.ViewPort.width();
|
1092 |
-
var height = svg.ViewPort.height();
|
1093 |
-
|
1094 |
-
if (!this.attribute('width').hasValue()) this.attribute('width', true).value = '100%';
|
1095 |
-
if (!this.attribute('height').hasValue()) this.attribute('height', true).value = '100%';
|
1096 |
-
if (typeof this.root == 'undefined') {
|
1097 |
-
width = this.attribute('width').toPixels('x');
|
1098 |
-
height = this.attribute('height').toPixels('y');
|
1099 |
-
|
1100 |
-
var x = 0;
|
1101 |
-
var y = 0;
|
1102 |
-
if (this.attribute('refX').hasValue() && this.attribute('refY').hasValue()) {
|
1103 |
-
x = -this.attribute('refX').toPixels('x');
|
1104 |
-
y = -this.attribute('refY').toPixels('y');
|
1105 |
-
}
|
1106 |
-
|
1107 |
-
if (this.attribute('overflow').valueOrDefault('hidden') != 'visible') {
|
1108 |
-
ctx.beginPath();
|
1109 |
-
ctx.moveTo(x, y);
|
1110 |
-
ctx.lineTo(width, y);
|
1111 |
-
ctx.lineTo(width, height);
|
1112 |
-
ctx.lineTo(x, height);
|
1113 |
-
ctx.closePath();
|
1114 |
-
ctx.clip();
|
1115 |
-
}
|
1116 |
-
}
|
1117 |
-
svg.ViewPort.SetCurrent(width, height);
|
1118 |
-
|
1119 |
-
// viewbox
|
1120 |
-
if (this.attribute('viewBox').hasValue()) {
|
1121 |
-
var viewBox = svg.ToNumberArray(this.attribute('viewBox').value);
|
1122 |
-
var minX = viewBox[0];
|
1123 |
-
var minY = viewBox[1];
|
1124 |
-
width = viewBox[2];
|
1125 |
-
height = viewBox[3];
|
1126 |
-
|
1127 |
-
svg.AspectRatio(ctx,
|
1128 |
-
this.attribute('preserveAspectRatio').value,
|
1129 |
-
svg.ViewPort.width(),
|
1130 |
-
width,
|
1131 |
-
svg.ViewPort.height(),
|
1132 |
-
height,
|
1133 |
-
minX,
|
1134 |
-
minY,
|
1135 |
-
this.attribute('refX').value,
|
1136 |
-
this.attribute('refY').value);
|
1137 |
-
|
1138 |
-
svg.ViewPort.RemoveCurrent();
|
1139 |
-
svg.ViewPort.SetCurrent(viewBox[2], viewBox[3]);
|
1140 |
-
}
|
1141 |
-
}
|
1142 |
-
}
|
1143 |
-
svg.Element.svg.prototype = new svg.Element.RenderedElementBase;
|
1144 |
-
|
1145 |
-
// rect element
|
1146 |
-
svg.Element.rect = function(node) {
|
1147 |
-
this.base = svg.Element.PathElementBase;
|
1148 |
-
this.base(node);
|
1149 |
-
|
1150 |
-
this.path = function(ctx) {
|
1151 |
-
var x = this.attribute('x').toPixels('x');
|
1152 |
-
var y = this.attribute('y').toPixels('y');
|
1153 |
-
var width = this.attribute('width').toPixels('x');
|
1154 |
-
var height = this.attribute('height').toPixels('y');
|
1155 |
-
var rx = this.attribute('rx').toPixels('x');
|
1156 |
-
var ry = this.attribute('ry').toPixels('y');
|
1157 |
-
if (this.attribute('rx').hasValue() && !this.attribute('ry').hasValue()) ry = rx;
|
1158 |
-
if (this.attribute('ry').hasValue() && !this.attribute('rx').hasValue()) rx = ry;
|
1159 |
-
rx = Math.min(rx, width / 2.0);
|
1160 |
-
ry = Math.min(ry, height / 2.0);
|
1161 |
-
if (ctx != null) {
|
1162 |
-
ctx.beginPath();
|
1163 |
-
ctx.moveTo(x + rx, y);
|
1164 |
-
ctx.lineTo(x + width - rx, y);
|
1165 |
-
ctx.quadraticCurveTo(x + width, y, x + width, y + ry)
|
1166 |
-
ctx.lineTo(x + width, y + height - ry);
|
1167 |
-
ctx.quadraticCurveTo(x + width, y + height, x + width - rx, y + height)
|
1168 |
-
ctx.lineTo(x + rx, y + height);
|
1169 |
-
ctx.quadraticCurveTo(x, y + height, x, y + height - ry)
|
1170 |
-
ctx.lineTo(x, y + ry);
|
1171 |
-
ctx.quadraticCurveTo(x, y, x + rx, y)
|
1172 |
-
ctx.closePath();
|
1173 |
-
}
|
1174 |
-
|
1175 |
-
return new svg.BoundingBox(x, y, x + width, y + height);
|
1176 |
-
}
|
1177 |
-
}
|
1178 |
-
svg.Element.rect.prototype = new svg.Element.PathElementBase;
|
1179 |
-
|
1180 |
-
// circle element
|
1181 |
-
svg.Element.circle = function(node) {
|
1182 |
-
this.base = svg.Element.PathElementBase;
|
1183 |
-
this.base(node);
|
1184 |
-
|
1185 |
-
this.path = function(ctx) {
|
1186 |
-
var cx = this.attribute('cx').toPixels('x');
|
1187 |
-
var cy = this.attribute('cy').toPixels('y');
|
1188 |
-
var r = this.attribute('r').toPixels();
|
1189 |
-
|
1190 |
-
if (ctx != null) {
|
1191 |
-
ctx.beginPath();
|
1192 |
-
ctx.arc(cx, cy, r, 0, Math.PI * 2, true);
|
1193 |
-
ctx.closePath();
|
1194 |
-
}
|
1195 |
-
|
1196 |
-
return new svg.BoundingBox(cx - r, cy - r, cx + r, cy + r);
|
1197 |
-
}
|
1198 |
-
}
|
1199 |
-
svg.Element.circle.prototype = new svg.Element.PathElementBase;
|
1200 |
-
|
1201 |
-
// ellipse element
|
1202 |
-
svg.Element.ellipse = function(node) {
|
1203 |
-
this.base = svg.Element.PathElementBase;
|
1204 |
-
this.base(node);
|
1205 |
-
|
1206 |
-
this.path = function(ctx) {
|
1207 |
-
var KAPPA = 4 * ((Math.sqrt(2) - 1) / 3);
|
1208 |
-
var rx = this.attribute('rx').toPixels('x');
|
1209 |
-
var ry = this.attribute('ry').toPixels('y');
|
1210 |
-
var cx = this.attribute('cx').toPixels('x');
|
1211 |
-
var cy = this.attribute('cy').toPixels('y');
|
1212 |
-
|
1213 |
-
if (ctx != null) {
|
1214 |
-
ctx.beginPath();
|
1215 |
-
ctx.moveTo(cx, cy - ry);
|
1216 |
-
ctx.bezierCurveTo(cx + (KAPPA * rx), cy - ry, cx + rx, cy - (KAPPA * ry), cx + rx, cy);
|
1217 |
-
ctx.bezierCurveTo(cx + rx, cy + (KAPPA * ry), cx + (KAPPA * rx), cy + ry, cx, cy + ry);
|
1218 |
-
ctx.bezierCurveTo(cx - (KAPPA * rx), cy + ry, cx - rx, cy + (KAPPA * ry), cx - rx, cy);
|
1219 |
-
ctx.bezierCurveTo(cx - rx, cy - (KAPPA * ry), cx - (KAPPA * rx), cy - ry, cx, cy - ry);
|
1220 |
-
ctx.closePath();
|
1221 |
-
}
|
1222 |
-
|
1223 |
-
return new svg.BoundingBox(cx - rx, cy - ry, cx + rx, cy + ry);
|
1224 |
-
}
|
1225 |
-
}
|
1226 |
-
svg.Element.ellipse.prototype = new svg.Element.PathElementBase;
|
1227 |
-
|
1228 |
-
// line element
|
1229 |
-
svg.Element.line = function(node) {
|
1230 |
-
this.base = svg.Element.PathElementBase;
|
1231 |
-
this.base(node);
|
1232 |
-
|
1233 |
-
this.getPoints = function() {
|
1234 |
-
return [
|
1235 |
-
new svg.Point(this.attribute('x1').toPixels('x'), this.attribute('y1').toPixels('y')),
|
1236 |
-
new svg.Point(this.attribute('x2').toPixels('x'), this.attribute('y2').toPixels('y'))];
|
1237 |
-
}
|
1238 |
-
|
1239 |
-
this.path = function(ctx) {
|
1240 |
-
var points = this.getPoints();
|
1241 |
-
|
1242 |
-
if (ctx != null) {
|
1243 |
-
ctx.beginPath();
|
1244 |
-
ctx.moveTo(points[0].x, points[0].y);
|
1245 |
-
ctx.lineTo(points[1].x, points[1].y);
|
1246 |
-
}
|
1247 |
-
|
1248 |
-
return new svg.BoundingBox(points[0].x, points[0].y, points[1].x, points[1].y);
|
1249 |
-
}
|
1250 |
-
|
1251 |
-
this.getMarkers = function() {
|
1252 |
-
var points = this.getPoints();
|
1253 |
-
var a = points[0].angleTo(points[1]);
|
1254 |
-
return [[points[0], a], [points[1], a]];
|
1255 |
-
}
|
1256 |
-
}
|
1257 |
-
svg.Element.line.prototype = new svg.Element.PathElementBase;
|
1258 |
-
|
1259 |
-
// polyline element
|
1260 |
-
svg.Element.polyline = function(node) {
|
1261 |
-
this.base = svg.Element.PathElementBase;
|
1262 |
-
this.base(node);
|
1263 |
-
|
1264 |
-
this.points = svg.CreatePath(this.attribute('points').value);
|
1265 |
-
this.path = function(ctx) {
|
1266 |
-
var bb = new svg.BoundingBox(this.points[0].x, this.points[0].y);
|
1267 |
-
if (ctx != null) {
|
1268 |
-
ctx.beginPath();
|
1269 |
-
ctx.moveTo(this.points[0].x, this.points[0].y);
|
1270 |
-
}
|
1271 |
-
for (var i=1; i<this.points.length; i++) {
|
1272 |
-
bb.addPoint(this.points[i].x, this.points[i].y);
|
1273 |
-
if (ctx != null) ctx.lineTo(this.points[i].x, this.points[i].y);
|
1274 |
-
}
|
1275 |
-
return bb;
|
1276 |
-
}
|
1277 |
-
|
1278 |
-
this.getMarkers = function() {
|
1279 |
-
var markers = [];
|
1280 |
-
for (var i=0; i<this.points.length - 1; i++) {
|
1281 |
-
markers.push([this.points[i], this.points[i].angleTo(this.points[i+1])]);
|
1282 |
-
}
|
1283 |
-
if (markers.length > 0) {
|
1284 |
-
markers.push([this.points[this.points.length-1], markers[markers.length-1][1]]);
|
1285 |
-
}
|
1286 |
-
return markers;
|
1287 |
-
}
|
1288 |
-
}
|
1289 |
-
svg.Element.polyline.prototype = new svg.Element.PathElementBase;
|
1290 |
-
|
1291 |
-
// polygon element
|
1292 |
-
svg.Element.polygon = function(node) {
|
1293 |
-
this.base = svg.Element.polyline;
|
1294 |
-
this.base(node);
|
1295 |
-
|
1296 |
-
this.basePath = this.path;
|
1297 |
-
this.path = function(ctx) {
|
1298 |
-
var bb = this.basePath(ctx);
|
1299 |
-
if (ctx != null) {
|
1300 |
-
ctx.lineTo(this.points[0].x, this.points[0].y);
|
1301 |
-
ctx.closePath();
|
1302 |
-
}
|
1303 |
-
return bb;
|
1304 |
-
}
|
1305 |
-
}
|
1306 |
-
svg.Element.polygon.prototype = new svg.Element.polyline;
|
1307 |
-
|
1308 |
-
// path element
|
1309 |
-
svg.Element.path = function(node) {
|
1310 |
-
this.base = svg.Element.PathElementBase;
|
1311 |
-
this.base(node);
|
1312 |
-
|
1313 |
-
var d = this.attribute('d').value;
|
1314 |
-
// TODO: convert to real lexer based on http://www.w3.org/TR/SVG11/paths.html#PathDataBNF
|
1315 |
-
d = d.replace(/,/gm,' '); // get rid of all commas
|
1316 |
-
// As the end of a match can also be the start of the next match, we need to run this replace twice.
|
1317 |
-
for(var i=0; i<2; i++)
|
1318 |
-
d = d.replace(/([MmZzLlHhVvCcSsQqTtAa])([^\s])/gm,'$1 $2'); // suffix commands with spaces
|
1319 |
-
d = d.replace(/([^\s])([MmZzLlHhVvCcSsQqTtAa])/gm,'$1 $2'); // prefix commands with spaces
|
1320 |
-
d = d.replace(/([0-9])([+\-])/gm,'$1 $2'); // separate digits on +- signs
|
1321 |
-
// Again, we need to run this twice to find all occurances
|
1322 |
-
for(var i=0; i<2; i++)
|
1323 |
-
d = d.replace(/(\.[0-9]*)(\.)/gm,'$1 $2'); // separate digits when they start with a comma
|
1324 |
-
d = d.replace(/([Aa](\s+[0-9]+){3})\s+([01])\s*([01])/gm,'$1 $3 $4 '); // shorthand elliptical arc path syntax
|
1325 |
-
d = svg.compressSpaces(d); // compress multiple spaces
|
1326 |
-
d = svg.trim(d);
|
1327 |
-
this.PathParser = new (function(d) {
|
1328 |
-
this.tokens = d.split(' ');
|
1329 |
-
|
1330 |
-
this.reset = function() {
|
1331 |
-
this.i = -1;
|
1332 |
-
this.command = '';
|
1333 |
-
this.previousCommand = '';
|
1334 |
-
this.start = new svg.Point(0, 0);
|
1335 |
-
this.control = new svg.Point(0, 0);
|
1336 |
-
this.current = new svg.Point(0, 0);
|
1337 |
-
this.points = [];
|
1338 |
-
this.angles = [];
|
1339 |
-
}
|
1340 |
-
|
1341 |
-
this.isEnd = function() {
|
1342 |
-
return this.i >= this.tokens.length - 1;
|
1343 |
-
}
|
1344 |
-
|
1345 |
-
this.isCommandOrEnd = function() {
|
1346 |
-
if (this.isEnd()) return true;
|
1347 |
-
return this.tokens[this.i + 1].match(/^[A-Za-z]$/) != null;
|
1348 |
-
}
|
1349 |
-
|
1350 |
-
this.isRelativeCommand = function() {
|
1351 |
-
switch(this.command)
|
1352 |
-
{
|
1353 |
-
case 'm':
|
1354 |
-
case 'l':
|
1355 |
-
case 'h':
|
1356 |
-
case 'v':
|
1357 |
-
case 'c':
|
1358 |
-
case 's':
|
1359 |
-
case 'q':
|
1360 |
-
case 't':
|
1361 |
-
case 'a':
|
1362 |
-
case 'z':
|
1363 |
-
return true;
|
1364 |
-
break;
|
1365 |
-
}
|
1366 |
-
return false;
|
1367 |
-
}
|
1368 |
-
|
1369 |
-
this.getToken = function() {
|
1370 |
-
this.i++;
|
1371 |
-
return this.tokens[this.i];
|
1372 |
-
}
|
1373 |
-
|
1374 |
-
this.getScalar = function() {
|
1375 |
-
return parseFloat(this.getToken());
|
1376 |
-
}
|
1377 |
-
|
1378 |
-
this.nextCommand = function() {
|
1379 |
-
this.previousCommand = this.command;
|
1380 |
-
this.command = this.getToken();
|
1381 |
-
}
|
1382 |
-
|
1383 |
-
this.getPoint = function() {
|
1384 |
-
var p = new svg.Point(this.getScalar(), this.getScalar());
|
1385 |
-
return this.makeAbsolute(p);
|
1386 |
-
}
|
1387 |
-
|
1388 |
-
this.getAsControlPoint = function() {
|
1389 |
-
var p = this.getPoint();
|
1390 |
-
this.control = p;
|
1391 |
-
return p;
|
1392 |
-
}
|
1393 |
-
|
1394 |
-
this.getAsCurrentPoint = function() {
|
1395 |
-
var p = this.getPoint();
|
1396 |
-
this.current = p;
|
1397 |
-
return p;
|
1398 |
-
}
|
1399 |
-
|
1400 |
-
this.getReflectedControlPoint = function() {
|
1401 |
-
if (this.previousCommand.toLowerCase() != 'c' &&
|
1402 |
-
this.previousCommand.toLowerCase() != 's' &&
|
1403 |
-
this.previousCommand.toLowerCase() != 'q' &&
|
1404 |
-
this.previousCommand.toLowerCase() != 't' ){
|
1405 |
-
return this.current;
|
1406 |
-
}
|
1407 |
-
|
1408 |
-
// reflect point
|
1409 |
-
var p = new svg.Point(2 * this.current.x - this.control.x, 2 * this.current.y - this.control.y);
|
1410 |
-
return p;
|
1411 |
-
}
|
1412 |
-
|
1413 |
-
this.makeAbsolute = function(p) {
|
1414 |
-
if (this.isRelativeCommand()) {
|
1415 |
-
p.x += this.current.x;
|
1416 |
-
p.y += this.current.y;
|
1417 |
-
}
|
1418 |
-
return p;
|
1419 |
-
}
|
1420 |
-
|
1421 |
-
this.addMarker = function(p, from, priorTo) {
|
1422 |
-
// if the last angle isn't filled in because we didn't have this point yet ...
|
1423 |
-
if (priorTo != null && this.angles.length > 0 && this.angles[this.angles.length-1] == null) {
|
1424 |
-
this.angles[this.angles.length-1] = this.points[this.points.length-1].angleTo(priorTo);
|
1425 |
-
}
|
1426 |
-
this.addMarkerAngle(p, from == null ? null : from.angleTo(p));
|
1427 |
-
}
|
1428 |
-
|
1429 |
-
this.addMarkerAngle = function(p, a) {
|
1430 |
-
this.points.push(p);
|
1431 |
-
this.angles.push(a);
|
1432 |
-
}
|
1433 |
-
|
1434 |
-
this.getMarkerPoints = function() { return this.points; }
|
1435 |
-
this.getMarkerAngles = function() {
|
1436 |
-
for (var i=0; i<this.angles.length; i++) {
|
1437 |
-
if (this.angles[i] == null) {
|
1438 |
-
for (var j=i+1; j<this.angles.length; j++) {
|
1439 |
-
if (this.angles[j] != null) {
|
1440 |
-
this.angles[i] = this.angles[j];
|
1441 |
-
break;
|
1442 |
-
}
|
1443 |
-
}
|
1444 |
-
}
|
1445 |
-
}
|
1446 |
-
return this.angles;
|
1447 |
-
}
|
1448 |
-
})(d);
|
1449 |
-
|
1450 |
-
this.path = function(ctx) {
|
1451 |
-
var pp = this.PathParser;
|
1452 |
-
pp.reset();
|
1453 |
-
|
1454 |
-
var bb = new svg.BoundingBox();
|
1455 |
-
if (ctx != null) ctx.beginPath();
|
1456 |
-
while (!pp.isEnd()) {
|
1457 |
-
pp.nextCommand();
|
1458 |
-
switch (pp.command) {
|
1459 |
-
case 'M':
|
1460 |
-
case 'm':
|
1461 |
-
var p = pp.getAsCurrentPoint();
|
1462 |
-
pp.addMarker(p);
|
1463 |
-
bb.addPoint(p.x, p.y);
|
1464 |
-
if (ctx != null) ctx.moveTo(p.x, p.y);
|
1465 |
-
pp.start = pp.current;
|
1466 |
-
while (!pp.isCommandOrEnd()) {
|
1467 |
-
var p = pp.getAsCurrentPoint();
|
1468 |
-
pp.addMarker(p, pp.start);
|
1469 |
-
bb.addPoint(p.x, p.y);
|
1470 |
-
if (ctx != null) ctx.lineTo(p.x, p.y);
|
1471 |
-
}
|
1472 |
-
break;
|
1473 |
-
case 'L':
|
1474 |
-
case 'l':
|
1475 |
-
while (!pp.isCommandOrEnd()) {
|
1476 |
-
var c = pp.current;
|
1477 |
-
var p = pp.getAsCurrentPoint();
|
1478 |
-
pp.addMarker(p, c);
|
1479 |
-
bb.addPoint(p.x, p.y);
|
1480 |
-
if (ctx != null) ctx.lineTo(p.x, p.y);
|
1481 |
-
}
|
1482 |
-
break;
|
1483 |
-
case 'H':
|
1484 |
-
case 'h':
|
1485 |
-
while (!pp.isCommandOrEnd()) {
|
1486 |
-
var newP = new svg.Point((pp.isRelativeCommand() ? pp.current.x : 0) + pp.getScalar(), pp.current.y);
|
1487 |
-
pp.addMarker(newP, pp.current);
|
1488 |
-
pp.current = newP;
|
1489 |
-
bb.addPoint(pp.current.x, pp.current.y);
|
1490 |
-
if (ctx != null) ctx.lineTo(pp.current.x, pp.current.y);
|
1491 |
-
}
|
1492 |
-
break;
|
1493 |
-
case 'V':
|
1494 |
-
case 'v':
|
1495 |
-
while (!pp.isCommandOrEnd()) {
|
1496 |
-
var newP = new svg.Point(pp.current.x, (pp.isRelativeCommand() ? pp.current.y : 0) + pp.getScalar());
|
1497 |
-
pp.addMarker(newP, pp.current);
|
1498 |
-
pp.current = newP;
|
1499 |
-
bb.addPoint(pp.current.x, pp.current.y);
|
1500 |
-
if (ctx != null) ctx.lineTo(pp.current.x, pp.current.y);
|
1501 |
-
}
|
1502 |
-
break;
|
1503 |
-
case 'C':
|
1504 |
-
case 'c':
|
1505 |
-
while (!pp.isCommandOrEnd()) {
|
1506 |
-
var curr = pp.current;
|
1507 |
-
var p1 = pp.getPoint();
|
1508 |
-
var cntrl = pp.getAsControlPoint();
|
1509 |
-
var cp = pp.getAsCurrentPoint();
|
1510 |
-
pp.addMarker(cp, cntrl, p1);
|
1511 |
-
bb.addBezierCurve(curr.x, curr.y, p1.x, p1.y, cntrl.x, cntrl.y, cp.x, cp.y);
|
1512 |
-
if (ctx != null) ctx.bezierCurveTo(p1.x, p1.y, cntrl.x, cntrl.y, cp.x, cp.y);
|
1513 |
-
}
|
1514 |
-
break;
|
1515 |
-
case 'S':
|
1516 |
-
case 's':
|
1517 |
-
while (!pp.isCommandOrEnd()) {
|
1518 |
-
var curr = pp.current;
|
1519 |
-
var p1 = pp.getReflectedControlPoint();
|
1520 |
-
var cntrl = pp.getAsControlPoint();
|
1521 |
-
var cp = pp.getAsCurrentPoint();
|
1522 |
-
pp.addMarker(cp, cntrl, p1);
|
1523 |
-
bb.addBezierCurve(curr.x, curr.y, p1.x, p1.y, cntrl.x, cntrl.y, cp.x, cp.y);
|
1524 |
-
if (ctx != null) ctx.bezierCurveTo(p1.x, p1.y, cntrl.x, cntrl.y, cp.x, cp.y);
|
1525 |
-
}
|
1526 |
-
break;
|
1527 |
-
case 'Q':
|
1528 |
-
case 'q':
|
1529 |
-
while (!pp.isCommandOrEnd()) {
|
1530 |
-
var curr = pp.current;
|
1531 |
-
var cntrl = pp.getAsControlPoint();
|
1532 |
-
var cp = pp.getAsCurrentPoint();
|
1533 |
-
pp.addMarker(cp, cntrl, cntrl);
|
1534 |
-
bb.addQuadraticCurve(curr.x, curr.y, cntrl.x, cntrl.y, cp.x, cp.y);
|
1535 |
-
if (ctx != null) ctx.quadraticCurveTo(cntrl.x, cntrl.y, cp.x, cp.y);
|
1536 |
-
}
|
1537 |
-
break;
|
1538 |
-
case 'T':
|
1539 |
-
case 't':
|
1540 |
-
while (!pp.isCommandOrEnd()) {
|
1541 |
-
var curr = pp.current;
|
1542 |
-
var cntrl = pp.getReflectedControlPoint();
|
1543 |
-
pp.control = cntrl;
|
1544 |
-
var cp = pp.getAsCurrentPoint();
|
1545 |
-
pp.addMarker(cp, cntrl, cntrl);
|
1546 |
-
bb.addQuadraticCurve(curr.x, curr.y, cntrl.x, cntrl.y, cp.x, cp.y);
|
1547 |
-
if (ctx != null) ctx.quadraticCurveTo(cntrl.x, cntrl.y, cp.x, cp.y);
|
1548 |
-
}
|
1549 |
-
break;
|
1550 |
-
case 'A':
|
1551 |
-
case 'a':
|
1552 |
-
while (!pp.isCommandOrEnd()) {
|
1553 |
-
var curr = pp.current;
|
1554 |
-
var rx = pp.getScalar();
|
1555 |
-
var ry = pp.getScalar();
|
1556 |
-
var xAxisRotation = pp.getScalar() * (Math.PI / 180.0);
|
1557 |
-
var largeArcFlag = pp.getScalar();
|
1558 |
-
var sweepFlag = pp.getScalar();
|
1559 |
-
var cp = pp.getAsCurrentPoint();
|
1560 |
-
|
1561 |
-
// Conversion from endpoint to center parameterization
|
1562 |
-
// http://www.w3.org/TR/SVG11/implnote.html#ArcImplementationNotes
|
1563 |
-
// x1', y1'
|
1564 |
-
var currp = new svg.Point(
|
1565 |
-
Math.cos(xAxisRotation) * (curr.x - cp.x) / 2.0 + Math.sin(xAxisRotation) * (curr.y - cp.y) / 2.0,
|
1566 |
-
-Math.sin(xAxisRotation) * (curr.x - cp.x) / 2.0 + Math.cos(xAxisRotation) * (curr.y - cp.y) / 2.0
|
1567 |
-
);
|
1568 |
-
// adjust radii
|
1569 |
-
var l = Math.pow(currp.x,2)/Math.pow(rx,2)+Math.pow(currp.y,2)/Math.pow(ry,2);
|
1570 |
-
if (l > 1) {
|
1571 |
-
rx *= Math.sqrt(l);
|
1572 |
-
ry *= Math.sqrt(l);
|
1573 |
-
}
|
1574 |
-
// cx', cy'
|
1575 |
-
var s = (largeArcFlag == sweepFlag ? -1 : 1) * Math.sqrt(
|
1576 |
-
((Math.pow(rx,2)*Math.pow(ry,2))-(Math.pow(rx,2)*Math.pow(currp.y,2))-(Math.pow(ry,2)*Math.pow(currp.x,2))) /
|
1577 |
-
(Math.pow(rx,2)*Math.pow(currp.y,2)+Math.pow(ry,2)*Math.pow(currp.x,2))
|
1578 |
-
);
|
1579 |
-
if (isNaN(s)) s = 0;
|
1580 |
-
var cpp = new svg.Point(s * rx * currp.y / ry, s * -ry * currp.x / rx);
|
1581 |
-
// cx, cy
|
1582 |
-
var centp = new svg.Point(
|
1583 |
-
(curr.x + cp.x) / 2.0 + Math.cos(xAxisRotation) * cpp.x - Math.sin(xAxisRotation) * cpp.y,
|
1584 |
-
(curr.y + cp.y) / 2.0 + Math.sin(xAxisRotation) * cpp.x + Math.cos(xAxisRotation) * cpp.y
|
1585 |
-
);
|
1586 |
-
// vector magnitude
|
1587 |
-
var m = function(v) { return Math.sqrt(Math.pow(v[0],2) + Math.pow(v[1],2)); }
|
1588 |
-
// ratio between two vectors
|
1589 |
-
var r = function(u, v) { return (u[0]*v[0]+u[1]*v[1]) / (m(u)*m(v)) }
|
1590 |
-
// angle between two vectors
|
1591 |
-
var a = function(u, v) { return (u[0]*v[1] < u[1]*v[0] ? -1 : 1) * Math.acos(r(u,v)); }
|
1592 |
-
// initial angle
|
1593 |
-
var a1 = a([1,0], [(currp.x-cpp.x)/rx,(currp.y-cpp.y)/ry]);
|
1594 |
-
// angle delta
|
1595 |
-
var u = [(currp.x-cpp.x)/rx,(currp.y-cpp.y)/ry];
|
1596 |
-
var v = [(-currp.x-cpp.x)/rx,(-currp.y-cpp.y)/ry];
|
1597 |
-
var ad = a(u, v);
|
1598 |
-
if (r(u,v) <= -1) ad = Math.PI;
|
1599 |
-
if (r(u,v) >= 1) ad = 0;
|
1600 |
-
|
1601 |
-
// for markers
|
1602 |
-
var dir = 1 - sweepFlag ? 1.0 : -1.0;
|
1603 |
-
var ah = a1 + dir * (ad / 2.0);
|
1604 |
-
var halfWay = new svg.Point(
|
1605 |
-
centp.x + rx * Math.cos(ah),
|
1606 |
-
centp.y + ry * Math.sin(ah)
|
1607 |
-
);
|
1608 |
-
pp.addMarkerAngle(halfWay, ah - dir * Math.PI / 2);
|
1609 |
-
pp.addMarkerAngle(cp, ah - dir * Math.PI);
|
1610 |
-
|
1611 |
-
bb.addPoint(cp.x, cp.y); // TODO: this is too naive, make it better
|
1612 |
-
if (ctx != null) {
|
1613 |
-
var r = rx > ry ? rx : ry;
|
1614 |
-
var sx = rx > ry ? 1 : rx / ry;
|
1615 |
-
var sy = rx > ry ? ry / rx : 1;
|
1616 |
-
|
1617 |
-
ctx.translate(centp.x, centp.y);
|
1618 |
-
ctx.rotate(xAxisRotation);
|
1619 |
-
ctx.scale(sx, sy);
|
1620 |
-
ctx.arc(0, 0, r, a1, a1 + ad, 1 - sweepFlag);
|
1621 |
-
ctx.scale(1/sx, 1/sy);
|
1622 |
-
ctx.rotate(-xAxisRotation);
|
1623 |
-
ctx.translate(-centp.x, -centp.y);
|
1624 |
-
}
|
1625 |
-
}
|
1626 |
-
break;
|
1627 |
-
case 'Z':
|
1628 |
-
case 'z':
|
1629 |
-
if (ctx != null) ctx.closePath();
|
1630 |
-
pp.current = pp.start;
|
1631 |
-
}
|
1632 |
-
}
|
1633 |
-
|
1634 |
-
return bb;
|
1635 |
-
}
|
1636 |
-
|
1637 |
-
this.getMarkers = function() {
|
1638 |
-
var points = this.PathParser.getMarkerPoints();
|
1639 |
-
var angles = this.PathParser.getMarkerAngles();
|
1640 |
-
|
1641 |
-
var markers = [];
|
1642 |
-
for (var i=0; i<points.length; i++) {
|
1643 |
-
markers.push([points[i], angles[i]]);
|
1644 |
-
}
|
1645 |
-
return markers;
|
1646 |
-
}
|
1647 |
-
}
|
1648 |
-
svg.Element.path.prototype = new svg.Element.PathElementBase;
|
1649 |
-
|
1650 |
-
// pattern element
|
1651 |
-
svg.Element.pattern = function(node) {
|
1652 |
-
this.base = svg.Element.ElementBase;
|
1653 |
-
this.base(node);
|
1654 |
-
|
1655 |
-
this.createPattern = function(ctx, element) {
|
1656 |
-
var width = this.attribute('width').toPixels('x', true);
|
1657 |
-
var height = this.attribute('height').toPixels('y', true);
|
1658 |
-
|
1659 |
-
// render me using a temporary svg element
|
1660 |
-
var tempSvg = new svg.Element.svg();
|
1661 |
-
tempSvg.attributes['viewBox'] = new svg.Property('viewBox', this.attribute('viewBox').value);
|
1662 |
-
tempSvg.attributes['width'] = new svg.Property('width', width + 'px');
|
1663 |
-
tempSvg.attributes['height'] = new svg.Property('height', height + 'px');
|
1664 |
-
tempSvg.attributes['transform'] = new svg.Property('transform', this.attribute('patternTransform').value);
|
1665 |
-
tempSvg.children = this.children;
|
1666 |
-
|
1667 |
-
var c = document.createElement('canvas');
|
1668 |
-
c.width = width;
|
1669 |
-
c.height = height;
|
1670 |
-
var cctx = c.getContext('2d');
|
1671 |
-
if (this.attribute('x').hasValue() && this.attribute('y').hasValue()) {
|
1672 |
-
cctx.translate(this.attribute('x').toPixels('x', true), this.attribute('y').toPixels('y', true));
|
1673 |
-
}
|
1674 |
-
// render 3x3 grid so when we transform there's no white space on edges
|
1675 |
-
for (var x=-1; x<=1; x++) {
|
1676 |
-
for (var y=-1; y<=1; y++) {
|
1677 |
-
cctx.save();
|
1678 |
-
tempSvg.attributes['x'] = new svg.Property('x', x * c.width);
|
1679 |
-
tempSvg.attributes['y'] = new svg.Property('y', y * c.height);
|
1680 |
-
tempSvg.render(cctx);
|
1681 |
-
cctx.restore();
|
1682 |
-
}
|
1683 |
-
}
|
1684 |
-
var pattern = ctx.createPattern(c, 'repeat');
|
1685 |
-
return pattern;
|
1686 |
-
}
|
1687 |
-
}
|
1688 |
-
svg.Element.pattern.prototype = new svg.Element.ElementBase;
|
1689 |
-
|
1690 |
-
// marker element
|
1691 |
-
svg.Element.marker = function(node) {
|
1692 |
-
this.base = svg.Element.ElementBase;
|
1693 |
-
this.base(node);
|
1694 |
-
|
1695 |
-
this.baseRender = this.render;
|
1696 |
-
this.render = function(ctx, point, angle) {
|
1697 |
-
ctx.translate(point.x, point.y);
|
1698 |
-
if (this.attribute('orient').valueOrDefault('auto') == 'auto') ctx.rotate(angle);
|
1699 |
-
if (this.attribute('markerUnits').valueOrDefault('strokeWidth') == 'strokeWidth') ctx.scale(ctx.lineWidth, ctx.lineWidth);
|
1700 |
-
ctx.save();
|
1701 |
-
|
1702 |
-
// render me using a temporary svg element
|
1703 |
-
var tempSvg = new svg.Element.svg();
|
1704 |
-
tempSvg.attributes['viewBox'] = new svg.Property('viewBox', this.attribute('viewBox').value);
|
1705 |
-
tempSvg.attributes['refX'] = new svg.Property('refX', this.attribute('refX').value);
|
1706 |
-
tempSvg.attributes['refY'] = new svg.Property('refY', this.attribute('refY').value);
|
1707 |
-
tempSvg.attributes['width'] = new svg.Property('width', this.attribute('markerWidth').value);
|
1708 |
-
tempSvg.attributes['height'] = new svg.Property('height', this.attribute('markerHeight').value);
|
1709 |
-
tempSvg.attributes['fill'] = new svg.Property('fill', this.attribute('fill').valueOrDefault('black'));
|
1710 |
-
tempSvg.attributes['stroke'] = new svg.Property('stroke', this.attribute('stroke').valueOrDefault('none'));
|
1711 |
-
tempSvg.children = this.children;
|
1712 |
-
tempSvg.render(ctx);
|
1713 |
-
|
1714 |
-
ctx.restore();
|
1715 |
-
if (this.attribute('markerUnits').valueOrDefault('strokeWidth') == 'strokeWidth') ctx.scale(1/ctx.lineWidth, 1/ctx.lineWidth);
|
1716 |
-
if (this.attribute('orient').valueOrDefault('auto') == 'auto') ctx.rotate(-angle);
|
1717 |
-
ctx.translate(-point.x, -point.y);
|
1718 |
-
}
|
1719 |
-
}
|
1720 |
-
svg.Element.marker.prototype = new svg.Element.ElementBase;
|
1721 |
-
|
1722 |
-
// definitions element
|
1723 |
-
svg.Element.defs = function(node) {
|
1724 |
-
this.base = svg.Element.ElementBase;
|
1725 |
-
this.base(node);
|
1726 |
-
|
1727 |
-
this.render = function(ctx) {
|
1728 |
-
// NOOP
|
1729 |
-
}
|
1730 |
-
}
|
1731 |
-
svg.Element.defs.prototype = new svg.Element.ElementBase;
|
1732 |
-
|
1733 |
-
// base for gradients
|
1734 |
-
svg.Element.GradientBase = function(node) {
|
1735 |
-
this.base = svg.Element.ElementBase;
|
1736 |
-
this.base(node);
|
1737 |
-
|
1738 |
-
this.stops = [];
|
1739 |
-
for (var i=0; i<this.children.length; i++) {
|
1740 |
-
var child = this.children[i];
|
1741 |
-
if (child.type == 'stop') this.stops.push(child);
|
1742 |
-
}
|
1743 |
-
|
1744 |
-
this.getGradient = function() {
|
1745 |
-
// OVERRIDE ME!
|
1746 |
-
}
|
1747 |
-
|
1748 |
-
this.gradientUnits = function () {
|
1749 |
-
return this.attribute('gradientUnits').valueOrDefault('objectBoundingBox');
|
1750 |
-
}
|
1751 |
-
|
1752 |
-
this.attributesToInherit = ['gradientUnits'];
|
1753 |
-
|
1754 |
-
this.inheritStopContainer = function (stopsContainer) {
|
1755 |
-
for (var i=0; i<this.attributesToInherit.length; i++) {
|
1756 |
-
var attributeToInherit = this.attributesToInherit[i];
|
1757 |
-
if (!this.attribute(attributeToInherit).hasValue() && stopsContainer.attribute(attributeToInherit).hasValue()) {
|
1758 |
-
this.attribute(attributeToInherit, true).value = stopsContainer.attribute(attributeToInherit).value;
|
1759 |
-
}
|
1760 |
-
}
|
1761 |
-
}
|
1762 |
-
|
1763 |
-
this.createGradient = function(ctx, element, parentOpacityProp) {
|
1764 |
-
var stopsContainer = this;
|
1765 |
-
if (this.getHrefAttribute().hasValue()) {
|
1766 |
-
stopsContainer = this.getHrefAttribute().getDefinition();
|
1767 |
-
this.inheritStopContainer(stopsContainer);
|
1768 |
-
}
|
1769 |
-
|
1770 |
-
var addParentOpacity = function (color) {
|
1771 |
-
if (parentOpacityProp.hasValue()) {
|
1772 |
-
var p = new svg.Property('color', color);
|
1773 |
-
return p.addOpacity(parentOpacityProp).value;
|
1774 |
-
}
|
1775 |
-
return color;
|
1776 |
-
};
|
1777 |
-
|
1778 |
-
var g = this.getGradient(ctx, element);
|
1779 |
-
if (g == null) return addParentOpacity(stopsContainer.stops[stopsContainer.stops.length - 1].color);
|
1780 |
-
for (var i=0; i<stopsContainer.stops.length; i++) {
|
1781 |
-
g.addColorStop(stopsContainer.stops[i].offset, addParentOpacity(stopsContainer.stops[i].color));
|
1782 |
-
}
|
1783 |
-
|
1784 |
-
if (this.attribute('gradientTransform').hasValue()) {
|
1785 |
-
// render as transformed pattern on temporary canvas
|
1786 |
-
var rootView = svg.ViewPort.viewPorts[0];
|
1787 |
-
|
1788 |
-
var rect = new svg.Element.rect();
|
1789 |
-
rect.attributes['x'] = new svg.Property('x', -svg.MAX_VIRTUAL_PIXELS/3.0);
|
1790 |
-
rect.attributes['y'] = new svg.Property('y', -svg.MAX_VIRTUAL_PIXELS/3.0);
|
1791 |
-
rect.attributes['width'] = new svg.Property('width', svg.MAX_VIRTUAL_PIXELS);
|
1792 |
-
rect.attributes['height'] = new svg.Property('height', svg.MAX_VIRTUAL_PIXELS);
|
1793 |
-
|
1794 |
-
var group = new svg.Element.g();
|
1795 |
-
group.attributes['transform'] = new svg.Property('transform', this.attribute('gradientTransform').value);
|
1796 |
-
group.children = [ rect ];
|
1797 |
-
|
1798 |
-
var tempSvg = new svg.Element.svg();
|
1799 |
-
tempSvg.attributes['x'] = new svg.Property('x', 0);
|
1800 |
-
tempSvg.attributes['y'] = new svg.Property('y', 0);
|
1801 |
-
tempSvg.attributes['width'] = new svg.Property('width', rootView.width);
|
1802 |
-
tempSvg.attributes['height'] = new svg.Property('height', rootView.height);
|
1803 |
-
tempSvg.children = [ group ];
|
1804 |
-
|
1805 |
-
var c = document.createElement('canvas');
|
1806 |
-
c.width = rootView.width;
|
1807 |
-
c.height = rootView.height;
|
1808 |
-
var tempCtx = c.getContext('2d');
|
1809 |
-
tempCtx.fillStyle = g;
|
1810 |
-
tempSvg.render(tempCtx);
|
1811 |
-
return tempCtx.createPattern(c, 'no-repeat');
|
1812 |
-
}
|
1813 |
-
|
1814 |
-
return g;
|
1815 |
-
}
|
1816 |
-
}
|
1817 |
-
svg.Element.GradientBase.prototype = new svg.Element.ElementBase;
|
1818 |
-
|
1819 |
-
// linear gradient element
|
1820 |
-
svg.Element.linearGradient = function(node) {
|
1821 |
-
this.base = svg.Element.GradientBase;
|
1822 |
-
this.base(node);
|
1823 |
-
|
1824 |
-
this.attributesToInherit.push('x1');
|
1825 |
-
this.attributesToInherit.push('y1');
|
1826 |
-
this.attributesToInherit.push('x2');
|
1827 |
-
this.attributesToInherit.push('y2');
|
1828 |
-
|
1829 |
-
this.getGradient = function(ctx, element) {
|
1830 |
-
var bb = this.gradientUnits() == 'objectBoundingBox' ? element.getBoundingBox() : null;
|
1831 |
-
|
1832 |
-
if (!this.attribute('x1').hasValue()
|
1833 |
-
&& !this.attribute('y1').hasValue()
|
1834 |
-
&& !this.attribute('x2').hasValue()
|
1835 |
-
&& !this.attribute('y2').hasValue()) {
|
1836 |
-
this.attribute('x1', true).value = 0;
|
1837 |
-
this.attribute('y1', true).value = 0;
|
1838 |
-
this.attribute('x2', true).value = 1;
|
1839 |
-
this.attribute('y2', true).value = 0;
|
1840 |
-
}
|
1841 |
-
|
1842 |
-
var x1 = (this.gradientUnits() == 'objectBoundingBox'
|
1843 |
-
? bb.x() + bb.width() * this.attribute('x1').numValue()
|
1844 |
-
: this.attribute('x1').toPixels('x'));
|
1845 |
-
var y1 = (this.gradientUnits() == 'objectBoundingBox'
|
1846 |
-
? bb.y() + bb.height() * this.attribute('y1').numValue()
|
1847 |
-
: this.attribute('y1').toPixels('y'));
|
1848 |
-
var x2 = (this.gradientUnits() == 'objectBoundingBox'
|
1849 |
-
? bb.x() + bb.width() * this.attribute('x2').numValue()
|
1850 |
-
: this.attribute('x2').toPixels('x'));
|
1851 |
-
var y2 = (this.gradientUnits() == 'objectBoundingBox'
|
1852 |
-
? bb.y() + bb.height() * this.attribute('y2').numValue()
|
1853 |
-
: this.attribute('y2').toPixels('y'));
|
1854 |
-
|
1855 |
-
if (x1 == x2 && y1 == y2) return null;
|
1856 |
-
return ctx.createLinearGradient(x1, y1, x2, y2);
|
1857 |
-
}
|
1858 |
-
}
|
1859 |
-
svg.Element.linearGradient.prototype = new svg.Element.GradientBase;
|
1860 |
-
|
1861 |
-
// radial gradient element
|
1862 |
-
svg.Element.radialGradient = function(node) {
|
1863 |
-
this.base = svg.Element.GradientBase;
|
1864 |
-
this.base(node);
|
1865 |
-
|
1866 |
-
this.attributesToInherit.push('cx');
|
1867 |
-
this.attributesToInherit.push('cy');
|
1868 |
-
this.attributesToInherit.push('r');
|
1869 |
-
this.attributesToInherit.push('fx');
|
1870 |
-
this.attributesToInherit.push('fy');
|
1871 |
-
|
1872 |
-
this.getGradient = function(ctx, element) {
|
1873 |
-
var bb = element.getBoundingBox();
|
1874 |
-
|
1875 |
-
if (!this.attribute('cx').hasValue()) this.attribute('cx', true).value = '50%';
|
1876 |
-
if (!this.attribute('cy').hasValue()) this.attribute('cy', true).value = '50%';
|
1877 |
-
if (!this.attribute('r').hasValue()) this.attribute('r', true).value = '50%';
|
1878 |
-
|
1879 |
-
var cx = (this.gradientUnits() == 'objectBoundingBox'
|
1880 |
-
? bb.x() + bb.width() * this.attribute('cx').numValue()
|
1881 |
-
: this.attribute('cx').toPixels('x'));
|
1882 |
-
var cy = (this.gradientUnits() == 'objectBoundingBox'
|
1883 |
-
? bb.y() + bb.height() * this.attribute('cy').numValue()
|
1884 |
-
: this.attribute('cy').toPixels('y'));
|
1885 |
-
|
1886 |
-
var fx = cx;
|
1887 |
-
var fy = cy;
|
1888 |
-
if (this.attribute('fx').hasValue()) {
|
1889 |
-
fx = (this.gradientUnits() == 'objectBoundingBox'
|
1890 |
-
? bb.x() + bb.width() * this.attribute('fx').numValue()
|
1891 |
-
: this.attribute('fx').toPixels('x'));
|
1892 |
-
}
|
1893 |
-
if (this.attribute('fy').hasValue()) {
|
1894 |
-
fy = (this.gradientUnits() == 'objectBoundingBox'
|
1895 |
-
? bb.y() + bb.height() * this.attribute('fy').numValue()
|
1896 |
-
: this.attribute('fy').toPixels('y'));
|
1897 |
-
}
|
1898 |
-
|
1899 |
-
var r = (this.gradientUnits() == 'objectBoundingBox'
|
1900 |
-
? (bb.width() + bb.height()) / 2.0 * this.attribute('r').numValue()
|
1901 |
-
: this.attribute('r').toPixels());
|
1902 |
-
|
1903 |
-
return ctx.createRadialGradient(fx, fy, 0, cx, cy, r);
|
1904 |
-
}
|
1905 |
-
}
|
1906 |
-
svg.Element.radialGradient.prototype = new svg.Element.GradientBase;
|
1907 |
-
|
1908 |
-
// gradient stop element
|
1909 |
-
svg.Element.stop = function(node) {
|
1910 |
-
this.base = svg.Element.ElementBase;
|
1911 |
-
this.base(node);
|
1912 |
-
|
1913 |
-
this.offset = this.attribute('offset').numValue();
|
1914 |
-
if (this.offset < 0) this.offset = 0;
|
1915 |
-
if (this.offset > 1) this.offset = 1;
|
1916 |
-
|
1917 |
-
var stopColor = this.style('stop-color', true);
|
1918 |
-
if (stopColor.value === '') stopColor.value = '#000';
|
1919 |
-
if (this.style('stop-opacity').hasValue()) stopColor = stopColor.addOpacity(this.style('stop-opacity'));
|
1920 |
-
this.color = stopColor.value;
|
1921 |
-
}
|
1922 |
-
svg.Element.stop.prototype = new svg.Element.ElementBase;
|
1923 |
-
|
1924 |
-
// animation base element
|
1925 |
-
svg.Element.AnimateBase = function(node) {
|
1926 |
-
this.base = svg.Element.ElementBase;
|
1927 |
-
this.base(node);
|
1928 |
-
|
1929 |
-
svg.Animations.push(this);
|
1930 |
-
|
1931 |
-
this.duration = 0.0;
|
1932 |
-
this.begin = this.attribute('begin').toMilliseconds();
|
1933 |
-
this.maxDuration = this.begin + this.attribute('dur').toMilliseconds();
|
1934 |
-
|
1935 |
-
this.getProperty = function() {
|
1936 |
-
var attributeType = this.attribute('attributeType').value;
|
1937 |
-
var attributeName = this.attribute('attributeName').value;
|
1938 |
-
|
1939 |
-
if (attributeType == 'CSS') {
|
1940 |
-
return this.parent.style(attributeName, true);
|
1941 |
-
}
|
1942 |
-
return this.parent.attribute(attributeName, true);
|
1943 |
-
};
|
1944 |
-
|
1945 |
-
this.initialValue = null;
|
1946 |
-
this.initialUnits = '';
|
1947 |
-
this.removed = false;
|
1948 |
-
|
1949 |
-
this.calcValue = function() {
|
1950 |
-
// OVERRIDE ME!
|
1951 |
-
return '';
|
1952 |
-
}
|
1953 |
-
|
1954 |
-
this.update = function(delta) {
|
1955 |
-
// set initial value
|
1956 |
-
if (this.initialValue == null) {
|
1957 |
-
this.initialValue = this.getProperty().value;
|
1958 |
-
this.initialUnits = this.getProperty().getUnits();
|
1959 |
-
}
|
1960 |
-
|
1961 |
-
// if we're past the end time
|
1962 |
-
if (this.duration > this.maxDuration) {
|
1963 |
-
// loop for indefinitely repeating animations
|
1964 |
-
if (this.attribute('repeatCount').value == 'indefinite'
|
1965 |
-
|| this.attribute('repeatDur').value == 'indefinite') {
|
1966 |
-
this.duration = 0.0
|
1967 |
-
}
|
1968 |
-
else if (this.attribute('fill').valueOrDefault('remove') == 'freeze' && !this.frozen) {
|
1969 |
-
this.frozen = true;
|
1970 |
-
this.parent.animationFrozen = true;
|
1971 |
-
this.parent.animationFrozenValue = this.getProperty().value;
|
1972 |
-
}
|
1973 |
-
else if (this.attribute('fill').valueOrDefault('remove') == 'remove' && !this.removed) {
|
1974 |
-
this.removed = true;
|
1975 |
-
this.getProperty().value = this.parent.animationFrozen ? this.parent.animationFrozenValue : this.initialValue;
|
1976 |
-
return true;
|
1977 |
-
}
|
1978 |
-
return false;
|
1979 |
-
}
|
1980 |
-
this.duration = this.duration + delta;
|
1981 |
-
|
1982 |
-
// if we're past the begin time
|
1983 |
-
var updated = false;
|
1984 |
-
if (this.begin < this.duration) {
|
1985 |
-
var newValue = this.calcValue(); // tween
|
1986 |
-
|
1987 |
-
if (this.attribute('type').hasValue()) {
|
1988 |
-
// for transform, etc.
|
1989 |
-
var type = this.attribute('type').value;
|
1990 |
-
newValue = type + '(' + newValue + ')';
|
1991 |
-
}
|
1992 |
-
|
1993 |
-
this.getProperty().value = newValue;
|
1994 |
-
updated = true;
|
1995 |
-
}
|
1996 |
-
|
1997 |
-
return updated;
|
1998 |
-
}
|
1999 |
-
|
2000 |
-
this.from = this.attribute('from');
|
2001 |
-
this.to = this.attribute('to');
|
2002 |
-
this.values = this.attribute('values');
|
2003 |
-
if (this.values.hasValue()) this.values.value = this.values.value.split(';');
|
2004 |
-
|
2005 |
-
// fraction of duration we've covered
|
2006 |
-
this.progress = function() {
|
2007 |
-
var ret = { progress: (this.duration - this.begin) / (this.maxDuration - this.begin) };
|
2008 |
-
if (this.values.hasValue()) {
|
2009 |
-
var p = ret.progress * (this.values.value.length - 1);
|
2010 |
-
var lb = Math.floor(p), ub = Math.ceil(p);
|
2011 |
-
ret.from = new svg.Property('from', parseFloat(this.values.value[lb]));
|
2012 |
-
ret.to = new svg.Property('to', parseFloat(this.values.value[ub]));
|
2013 |
-
ret.progress = (p - lb) / (ub - lb);
|
2014 |
-
}
|
2015 |
-
else {
|
2016 |
-
ret.from = this.from;
|
2017 |
-
ret.to = this.to;
|
2018 |
-
}
|
2019 |
-
return ret;
|
2020 |
-
}
|
2021 |
-
}
|
2022 |
-
svg.Element.AnimateBase.prototype = new svg.Element.ElementBase;
|
2023 |
-
|
2024 |
-
// animate element
|
2025 |
-
svg.Element.animate = function(node) {
|
2026 |
-
this.base = svg.Element.AnimateBase;
|
2027 |
-
this.base(node);
|
2028 |
-
|
2029 |
-
this.calcValue = function() {
|
2030 |
-
var p = this.progress();
|
2031 |
-
|
2032 |
-
// tween value linearly
|
2033 |
-
var newValue = p.from.numValue() + (p.to.numValue() - p.from.numValue()) * p.progress;
|
2034 |
-
return newValue + this.initialUnits;
|
2035 |
-
};
|
2036 |
-
}
|
2037 |
-
svg.Element.animate.prototype = new svg.Element.AnimateBase;
|
2038 |
-
|
2039 |
-
// animate color element
|
2040 |
-
svg.Element.animateColor = function(node) {
|
2041 |
-
this.base = svg.Element.AnimateBase;
|
2042 |
-
this.base(node);
|
2043 |
-
|
2044 |
-
this.calcValue = function() {
|
2045 |
-
var p = this.progress();
|
2046 |
-
var from = new RGBColor(p.from.value);
|
2047 |
-
var to = new RGBColor(p.to.value);
|
2048 |
-
|
2049 |
-
if (from.ok && to.ok) {
|
2050 |
-
// tween color linearly
|
2051 |
-
var r = from.r + (to.r - from.r) * p.progress;
|
2052 |
-
var g = from.g + (to.g - from.g) * p.progress;
|
2053 |
-
var b = from.b + (to.b - from.b) * p.progress;
|
2054 |
-
return 'rgb('+parseInt(r,10)+','+parseInt(g,10)+','+parseInt(b,10)+')';
|
2055 |
-
}
|
2056 |
-
return this.attribute('from').value;
|
2057 |
-
};
|
2058 |
-
}
|
2059 |
-
svg.Element.animateColor.prototype = new svg.Element.AnimateBase;
|
2060 |
-
|
2061 |
-
// animate transform element
|
2062 |
-
svg.Element.animateTransform = function(node) {
|
2063 |
-
this.base = svg.Element.AnimateBase;
|
2064 |
-
this.base(node);
|
2065 |
-
|
2066 |
-
this.calcValue = function() {
|
2067 |
-
var p = this.progress();
|
2068 |
-
|
2069 |
-
// tween value linearly
|
2070 |
-
var from = svg.ToNumberArray(p.from.value);
|
2071 |
-
var to = svg.ToNumberArray(p.to.value);
|
2072 |
-
var newValue = '';
|
2073 |
-
for (var i=0; i<from.length; i++) {
|
2074 |
-
newValue += from[i] + (to[i] - from[i]) * p.progress + ' ';
|
2075 |
-
}
|
2076 |
-
return newValue;
|
2077 |
-
};
|
2078 |
-
}
|
2079 |
-
svg.Element.animateTransform.prototype = new svg.Element.animate;
|
2080 |
-
|
2081 |
-
// font element
|
2082 |
-
svg.Element.font = function(node) {
|
2083 |
-
this.base = svg.Element.ElementBase;
|
2084 |
-
this.base(node);
|
2085 |
-
|
2086 |
-
this.horizAdvX = this.attribute('horiz-adv-x').numValue();
|
2087 |
-
|
2088 |
-
this.isRTL = false;
|
2089 |
-
this.isArabic = false;
|
2090 |
-
this.fontFace = null;
|
2091 |
-
this.missingGlyph = null;
|
2092 |
-
this.glyphs = [];
|
2093 |
-
for (var i=0; i<this.children.length; i++) {
|
2094 |
-
var child = this.children[i];
|
2095 |
-
if (child.type == 'font-face') {
|
2096 |
-
this.fontFace = child;
|
2097 |
-
if (child.style('font-family').hasValue()) {
|
2098 |
-
svg.Definitions[child.style('font-family').value] = this;
|
2099 |
-
}
|
2100 |
-
}
|
2101 |
-
else if (child.type == 'missing-glyph') this.missingGlyph = child;
|
2102 |
-
else if (child.type == 'glyph') {
|
2103 |
-
if (child.arabicForm != '') {
|
2104 |
-
this.isRTL = true;
|
2105 |
-
this.isArabic = true;
|
2106 |
-
if (typeof this.glyphs[child.unicode] == 'undefined') this.glyphs[child.unicode] = [];
|
2107 |
-
this.glyphs[child.unicode][child.arabicForm] = child;
|
2108 |
-
}
|
2109 |
-
else {
|
2110 |
-
this.glyphs[child.unicode] = child;
|
2111 |
-
}
|
2112 |
-
}
|
2113 |
-
}
|
2114 |
-
}
|
2115 |
-
svg.Element.font.prototype = new svg.Element.ElementBase;
|
2116 |
-
|
2117 |
-
// font-face element
|
2118 |
-
svg.Element.fontface = function(node) {
|
2119 |
-
this.base = svg.Element.ElementBase;
|
2120 |
-
this.base(node);
|
2121 |
-
|
2122 |
-
this.ascent = this.attribute('ascent').value;
|
2123 |
-
this.descent = this.attribute('descent').value;
|
2124 |
-
this.unitsPerEm = this.attribute('units-per-em').numValue();
|
2125 |
-
}
|
2126 |
-
svg.Element.fontface.prototype = new svg.Element.ElementBase;
|
2127 |
-
|
2128 |
-
// missing-glyph element
|
2129 |
-
svg.Element.missingglyph = function(node) {
|
2130 |
-
this.base = svg.Element.path;
|
2131 |
-
this.base(node);
|
2132 |
-
|
2133 |
-
this.horizAdvX = 0;
|
2134 |
-
}
|
2135 |
-
svg.Element.missingglyph.prototype = new svg.Element.path;
|
2136 |
-
|
2137 |
-
// glyph element
|
2138 |
-
svg.Element.glyph = function(node) {
|
2139 |
-
this.base = svg.Element.path;
|
2140 |
-
this.base(node);
|
2141 |
-
|
2142 |
-
this.horizAdvX = this.attribute('horiz-adv-x').numValue();
|
2143 |
-
this.unicode = this.attribute('unicode').value;
|
2144 |
-
this.arabicForm = this.attribute('arabic-form').value;
|
2145 |
-
}
|
2146 |
-
svg.Element.glyph.prototype = new svg.Element.path;
|
2147 |
-
|
2148 |
-
// text element
|
2149 |
-
svg.Element.text = function(node) {
|
2150 |
-
this.captureTextNodes = true;
|
2151 |
-
this.base = svg.Element.RenderedElementBase;
|
2152 |
-
this.base(node);
|
2153 |
-
|
2154 |
-
this.baseSetContext = this.setContext;
|
2155 |
-
this.setContext = function(ctx) {
|
2156 |
-
this.baseSetContext(ctx);
|
2157 |
-
|
2158 |
-
var textBaseline = this.style('dominant-baseline').toTextBaseline();
|
2159 |
-
if (textBaseline == null) textBaseline = this.style('alignment-baseline').toTextBaseline();
|
2160 |
-
if (textBaseline != null) ctx.textBaseline = textBaseline;
|
2161 |
-
}
|
2162 |
-
|
2163 |
-
this.getBoundingBox = function () {
|
2164 |
-
var x = this.attribute('x').toPixels('x');
|
2165 |
-
var y = this.attribute('y').toPixels('y');
|
2166 |
-
var fontSize = this.parent.style('font-size').numValueOrDefault(svg.Font.Parse(svg.ctx.font).fontSize);
|
2167 |
-
return new svg.BoundingBox(x, y - fontSize, x + Math.floor(fontSize * 2.0 / 3.0) * this.children[0].getText().length, y);
|
2168 |
-
}
|
2169 |
-
|
2170 |
-
this.renderChildren = function(ctx) {
|
2171 |
-
this.x = this.attribute('x').toPixels('x');
|
2172 |
-
this.y = this.attribute('y').toPixels('y');
|
2173 |
-
if (this.attribute('dx').hasValue()) this.x += this.attribute('dx').toPixels('x');
|
2174 |
-
if (this.attribute('dy').hasValue()) this.y += this.attribute('dy').toPixels('y');
|
2175 |
-
this.x += this.getAnchorDelta(ctx, this, 0);
|
2176 |
-
for (var i=0; i<this.children.length; i++) {
|
2177 |
-
this.renderChild(ctx, this, this, i);
|
2178 |
-
}
|
2179 |
-
}
|
2180 |
-
|
2181 |
-
this.getAnchorDelta = function (ctx, parent, startI) {
|
2182 |
-
var textAnchor = this.style('text-anchor').valueOrDefault('start');
|
2183 |
-
if (textAnchor != 'start') {
|
2184 |
-
var width = 0;
|
2185 |
-
for (var i=startI; i<parent.children.length; i++) {
|
2186 |
-
var child = parent.children[i];
|
2187 |
-
if (i > startI && child.attribute('x').hasValue()) break; // new group
|
2188 |
-
width += child.measureTextRecursive(ctx);
|
2189 |
-
}
|
2190 |
-
return -1 * (textAnchor == 'end' ? width : width / 2.0);
|
2191 |
-
}
|
2192 |
-
return 0;
|
2193 |
-
}
|
2194 |
-
|
2195 |
-
this.renderChild = function(ctx, textParent, parent, i) {
|
2196 |
-
var child = parent.children[i];
|
2197 |
-
if (child.attribute('x').hasValue()) {
|
2198 |
-
child.x = child.attribute('x').toPixels('x') + textParent.getAnchorDelta(ctx, parent, i);
|
2199 |
-
if (child.attribute('dx').hasValue()) child.x += child.attribute('dx').toPixels('x');
|
2200 |
-
}
|
2201 |
-
else {
|
2202 |
-
if (child.attribute('dx').hasValue()) textParent.x += child.attribute('dx').toPixels('x');
|
2203 |
-
child.x = textParent.x;
|
2204 |
-
}
|
2205 |
-
textParent.x = child.x + child.measureText(ctx);
|
2206 |
-
|
2207 |
-
if (child.attribute('y').hasValue()) {
|
2208 |
-
child.y = child.attribute('y').toPixels('y');
|
2209 |
-
if (child.attribute('dy').hasValue()) child.y += child.attribute('dy').toPixels('y');
|
2210 |
-
}
|
2211 |
-
else {
|
2212 |
-
if (child.attribute('dy').hasValue()) textParent.y += child.attribute('dy').toPixels('y');
|
2213 |
-
child.y = textParent.y;
|
2214 |
-
}
|
2215 |
-
textParent.y = child.y;
|
2216 |
-
|
2217 |
-
child.render(ctx);
|
2218 |
-
|
2219 |
-
for (var i=0; i<child.children.length; i++) {
|
2220 |
-
textParent.renderChild(ctx, textParent, child, i);
|
2221 |
-
}
|
2222 |
-
}
|
2223 |
-
}
|
2224 |
-
svg.Element.text.prototype = new svg.Element.RenderedElementBase;
|
2225 |
-
|
2226 |
-
// text base
|
2227 |
-
svg.Element.TextElementBase = function(node) {
|
2228 |
-
this.base = svg.Element.RenderedElementBase;
|
2229 |
-
this.base(node);
|
2230 |
-
|
2231 |
-
this.getGlyph = function(font, text, i) {
|
2232 |
-
var c = text[i];
|
2233 |
-
var glyph = null;
|
2234 |
-
if (font.isArabic) {
|
2235 |
-
var arabicForm = 'isolated';
|
2236 |
-
if ((i==0 || text[i-1]==' ') && i<text.length-2 && text[i+1]!=' ') arabicForm = 'terminal';
|
2237 |
-
if (i>0 && text[i-1]!=' ' && i<text.length-2 && text[i+1]!=' ') arabicForm = 'medial';
|
2238 |
-
if (i>0 && text[i-1]!=' ' && (i == text.length-1 || text[i+1]==' ')) arabicForm = 'initial';
|
2239 |
-
if (typeof font.glyphs[c] != 'undefined') {
|
2240 |
-
glyph = font.glyphs[c][arabicForm];
|
2241 |
-
if (glyph == null && font.glyphs[c].type == 'glyph') glyph = font.glyphs[c];
|
2242 |
-
}
|
2243 |
-
}
|
2244 |
-
else {
|
2245 |
-
glyph = font.glyphs[c];
|
2246 |
-
}
|
2247 |
-
if (glyph == null) glyph = font.missingGlyph;
|
2248 |
-
return glyph;
|
2249 |
-
}
|
2250 |
-
|
2251 |
-
this.renderChildren = function(ctx) {
|
2252 |
-
var customFont = this.parent.style('font-family').getDefinition();
|
2253 |
-
if (customFont != null) {
|
2254 |
-
var fontSize = this.parent.style('font-size').numValueOrDefault(svg.Font.Parse(svg.ctx.font).fontSize);
|
2255 |
-
var fontStyle = this.parent.style('font-style').valueOrDefault(svg.Font.Parse(svg.ctx.font).fontStyle);
|
2256 |
-
var text = this.getText();
|
2257 |
-
if (customFont.isRTL) text = text.split("").reverse().join("");
|
2258 |
-
|
2259 |
-
var dx = svg.ToNumberArray(this.parent.attribute('dx').value);
|
2260 |
-
for (var i=0; i<text.length; i++) {
|
2261 |
-
var glyph = this.getGlyph(customFont, text, i);
|
2262 |
-
var scale = fontSize / customFont.fontFace.unitsPerEm;
|
2263 |
-
ctx.translate(this.x, this.y);
|
2264 |
-
ctx.scale(scale, -scale);
|
2265 |
-
var lw = ctx.lineWidth;
|
2266 |
-
ctx.lineWidth = ctx.lineWidth * customFont.fontFace.unitsPerEm / fontSize;
|
2267 |
-
if (fontStyle == 'italic') ctx.transform(1, 0, .4, 1, 0, 0);
|
2268 |
-
glyph.render(ctx);
|
2269 |
-
if (fontStyle == 'italic') ctx.transform(1, 0, -.4, 1, 0, 0);
|
2270 |
-
ctx.lineWidth = lw;
|
2271 |
-
ctx.scale(1/scale, -1/scale);
|
2272 |
-
ctx.translate(-this.x, -this.y);
|
2273 |
-
|
2274 |
-
this.x += fontSize * (glyph.horizAdvX || customFont.horizAdvX) / customFont.fontFace.unitsPerEm;
|
2275 |
-
if (typeof dx[i] != 'undefined' && !isNaN(dx[i])) {
|
2276 |
-
this.x += dx[i];
|
2277 |
-
}
|
2278 |
-
}
|
2279 |
-
return;
|
2280 |
-
}
|
2281 |
-
|
2282 |
-
if (ctx.fillStyle != '') ctx.fillText(svg.compressSpaces(this.getText()), this.x, this.y);
|
2283 |
-
if (ctx.strokeStyle != '') ctx.strokeText(svg.compressSpaces(this.getText()), this.x, this.y);
|
2284 |
-
}
|
2285 |
-
|
2286 |
-
this.getText = function() {
|
2287 |
-
// OVERRIDE ME
|
2288 |
-
}
|
2289 |
-
|
2290 |
-
this.measureTextRecursive = function(ctx) {
|
2291 |
-
var width = this.measureText(ctx);
|
2292 |
-
for (var i=0; i<this.children.length; i++) {
|
2293 |
-
width += this.children[i].measureTextRecursive(ctx);
|
2294 |
-
}
|
2295 |
-
return width;
|
2296 |
-
}
|
2297 |
-
|
2298 |
-
this.measureText = function(ctx) {
|
2299 |
-
var customFont = this.parent.style('font-family').getDefinition();
|
2300 |
-
if (customFont != null) {
|
2301 |
-
var fontSize = this.parent.style('font-size').numValueOrDefault(svg.Font.Parse(svg.ctx.font).fontSize);
|
2302 |
-
var measure = 0;
|
2303 |
-
var text = this.getText();
|
2304 |
-
if (customFont.isRTL) text = text.split("").reverse().join("");
|
2305 |
-
var dx = svg.ToNumberArray(this.parent.attribute('dx').value);
|
2306 |
-
for (var i=0; i<text.length; i++) {
|
2307 |
-
var glyph = this.getGlyph(customFont, text, i);
|
2308 |
-
measure += (glyph.horizAdvX || customFont.horizAdvX) * fontSize / customFont.fontFace.unitsPerEm;
|
2309 |
-
if (typeof dx[i] != 'undefined' && !isNaN(dx[i])) {
|
2310 |
-
measure += dx[i];
|
2311 |
-
}
|
2312 |
-
}
|
2313 |
-
return measure;
|
2314 |
-
}
|
2315 |
-
|
2316 |
-
var textToMeasure = svg.compressSpaces(this.getText());
|
2317 |
-
if (!ctx.measureText) return textToMeasure.length * 10;
|
2318 |
-
|
2319 |
-
ctx.save();
|
2320 |
-
this.setContext(ctx);
|
2321 |
-
var width = ctx.measureText(textToMeasure).width;
|
2322 |
-
ctx.restore();
|
2323 |
-
return width;
|
2324 |
-
}
|
2325 |
-
}
|
2326 |
-
svg.Element.TextElementBase.prototype = new svg.Element.RenderedElementBase;
|
2327 |
-
|
2328 |
-
// tspan
|
2329 |
-
svg.Element.tspan = function(node) {
|
2330 |
-
this.captureTextNodes = true;
|
2331 |
-
this.base = svg.Element.TextElementBase;
|
2332 |
-
this.base(node);
|
2333 |
-
|
2334 |
-
this.text = svg.compressSpaces(node.value || node.text || node.textContent || '');
|
2335 |
-
this.getText = function() {
|
2336 |
-
// if this node has children, then they own the text
|
2337 |
-
if (this.children.length > 0) { return ''; }
|
2338 |
-
return this.text;
|
2339 |
-
}
|
2340 |
-
}
|
2341 |
-
svg.Element.tspan.prototype = new svg.Element.TextElementBase;
|
2342 |
-
|
2343 |
-
// tref
|
2344 |
-
svg.Element.tref = function(node) {
|
2345 |
-
this.base = svg.Element.TextElementBase;
|
2346 |
-
this.base(node);
|
2347 |
-
|
2348 |
-
this.getText = function() {
|
2349 |
-
var element = this.getHrefAttribute().getDefinition();
|
2350 |
-
if (element != null) return element.children[0].getText();
|
2351 |
-
}
|
2352 |
-
}
|
2353 |
-
svg.Element.tref.prototype = new svg.Element.TextElementBase;
|
2354 |
-
|
2355 |
-
// a element
|
2356 |
-
svg.Element.a = function(node) {
|
2357 |
-
this.base = svg.Element.TextElementBase;
|
2358 |
-
this.base(node);
|
2359 |
-
|
2360 |
-
this.hasText = node.childNodes.length > 0;
|
2361 |
-
for (var i=0; i<node.childNodes.length; i++) {
|
2362 |
-
if (node.childNodes[i].nodeType != 3) this.hasText = false;
|
2363 |
-
}
|
2364 |
-
|
2365 |
-
// this might contain text
|
2366 |
-
this.text = this.hasText ? node.childNodes[0].value : '';
|
2367 |
-
this.getText = function() {
|
2368 |
-
return this.text;
|
2369 |
-
}
|
2370 |
-
|
2371 |
-
this.baseRenderChildren = this.renderChildren;
|
2372 |
-
this.renderChildren = function(ctx) {
|
2373 |
-
if (this.hasText) {
|
2374 |
-
// render as text element
|
2375 |
-
this.baseRenderChildren(ctx);
|
2376 |
-
var fontSize = new svg.Property('fontSize', svg.Font.Parse(svg.ctx.font).fontSize);
|
2377 |
-
svg.Mouse.checkBoundingBox(this, new svg.BoundingBox(this.x, this.y - fontSize.toPixels('y'), this.x + this.measureText(ctx), this.y));
|
2378 |
-
}
|
2379 |
-
else if (this.children.length > 0) {
|
2380 |
-
// render as temporary group
|
2381 |
-
var g = new svg.Element.g();
|
2382 |
-
g.children = this.children;
|
2383 |
-
g.parent = this;
|
2384 |
-
g.render(ctx);
|
2385 |
-
}
|
2386 |
-
}
|
2387 |
-
|
2388 |
-
this.onclick = function() {
|
2389 |
-
window.open(this.getHrefAttribute().value);
|
2390 |
-
}
|
2391 |
-
|
2392 |
-
this.onmousemove = function() {
|
2393 |
-
svg.ctx.canvas.style.cursor = 'pointer';
|
2394 |
-
}
|
2395 |
-
}
|
2396 |
-
svg.Element.a.prototype = new svg.Element.TextElementBase;
|
2397 |
-
|
2398 |
-
// image element
|
2399 |
-
svg.Element.image = function(node) {
|
2400 |
-
this.base = svg.Element.RenderedElementBase;
|
2401 |
-
this.base(node);
|
2402 |
-
|
2403 |
-
var href = this.getHrefAttribute().value;
|
2404 |
-
if (href == '') { return; }
|
2405 |
-
var isSvg = href.match(/\.svg$/)
|
2406 |
-
|
2407 |
-
svg.Images.push(this);
|
2408 |
-
this.loaded = false;
|
2409 |
-
if (!isSvg) {
|
2410 |
-
this.img = document.createElement('img');
|
2411 |
-
if (svg.opts['useCORS'] == true) { this.img.crossOrigin = 'Anonymous'; }
|
2412 |
-
var self = this;
|
2413 |
-
this.img.onload = function() { self.loaded = true; }
|
2414 |
-
this.img.onerror = function() { svg.log('ERROR: image "' + href + '" not found'); self.loaded = true; }
|
2415 |
-
this.img.src = href;
|
2416 |
-
}
|
2417 |
-
else {
|
2418 |
-
this.img = svg.ajax(href);
|
2419 |
-
this.loaded = true;
|
2420 |
-
}
|
2421 |
-
|
2422 |
-
this.renderChildren = function(ctx) {
|
2423 |
-
var x = this.attribute('x').toPixels('x');
|
2424 |
-
var y = this.attribute('y').toPixels('y');
|
2425 |
-
|
2426 |
-
var width = this.attribute('width').toPixels('x');
|
2427 |
-
var height = this.attribute('height').toPixels('y');
|
2428 |
-
if (width == 0 || height == 0) return;
|
2429 |
-
|
2430 |
-
ctx.save();
|
2431 |
-
if (isSvg) {
|
2432 |
-
ctx.drawSvg(this.img, x, y, width, height);
|
2433 |
-
}
|
2434 |
-
else {
|
2435 |
-
ctx.translate(x, y);
|
2436 |
-
svg.AspectRatio(ctx,
|
2437 |
-
this.attribute('preserveAspectRatio').value,
|
2438 |
-
width,
|
2439 |
-
this.img.width,
|
2440 |
-
height,
|
2441 |
-
this.img.height,
|
2442 |
-
0,
|
2443 |
-
0);
|
2444 |
-
ctx.drawImage(this.img, 0, 0);
|
2445 |
-
}
|
2446 |
-
ctx.restore();
|
2447 |
-
}
|
2448 |
-
|
2449 |
-
this.getBoundingBox = function() {
|
2450 |
-
var x = this.attribute('x').toPixels('x');
|
2451 |
-
var y = this.attribute('y').toPixels('y');
|
2452 |
-
var width = this.attribute('width').toPixels('x');
|
2453 |
-
var height = this.attribute('height').toPixels('y');
|
2454 |
-
return new svg.BoundingBox(x, y, x + width, y + height);
|
2455 |
-
}
|
2456 |
-
}
|
2457 |
-
svg.Element.image.prototype = new svg.Element.RenderedElementBase;
|
2458 |
-
|
2459 |
-
// group element
|
2460 |
-
svg.Element.g = function(node) {
|
2461 |
-
this.base = svg.Element.RenderedElementBase;
|
2462 |
-
this.base(node);
|
2463 |
-
|
2464 |
-
this.getBoundingBox = function() {
|
2465 |
-
var bb = new svg.BoundingBox();
|
2466 |
-
for (var i=0; i<this.children.length; i++) {
|
2467 |
-
bb.addBoundingBox(this.children[i].getBoundingBox());
|
2468 |
-
}
|
2469 |
-
return bb;
|
2470 |
-
};
|
2471 |
-
}
|
2472 |
-
svg.Element.g.prototype = new svg.Element.RenderedElementBase;
|
2473 |
-
|
2474 |
-
// symbol element
|
2475 |
-
svg.Element.symbol = function(node) {
|
2476 |
-
this.base = svg.Element.RenderedElementBase;
|
2477 |
-
this.base(node);
|
2478 |
-
|
2479 |
-
this.render = function(ctx) {
|
2480 |
-
// NO RENDER
|
2481 |
-
};
|
2482 |
-
}
|
2483 |
-
svg.Element.symbol.prototype = new svg.Element.RenderedElementBase;
|
2484 |
-
|
2485 |
-
// style element
|
2486 |
-
svg.Element.style = function(node) {
|
2487 |
-
this.base = svg.Element.ElementBase;
|
2488 |
-
this.base(node);
|
2489 |
-
|
2490 |
-
// text, or spaces then CDATA
|
2491 |
-
var css = ''
|
2492 |
-
for (var i=0; i<node.childNodes.length; i++) {
|
2493 |
-
css += node.childNodes[i].data;
|
2494 |
-
}
|
2495 |
-
css = css.replace(/(\/\*([^*]|[\r\n]|(\*+([^*\/]|[\r\n])))*\*+\/)|(^[\s]*\/\/.*)/gm, ''); // remove comments
|
2496 |
-
css = svg.compressSpaces(css); // replace whitespace
|
2497 |
-
var cssDefs = css.split('}');
|
2498 |
-
for (var i=0; i<cssDefs.length; i++) {
|
2499 |
-
if (svg.trim(cssDefs[i]) != '') {
|
2500 |
-
var cssDef = cssDefs[i].split('{');
|
2501 |
-
var cssClasses = cssDef[0].split(',');
|
2502 |
-
var cssProps = cssDef[1].split(';');
|
2503 |
-
for (var j=0; j<cssClasses.length; j++) {
|
2504 |
-
var cssClass = svg.trim(cssClasses[j]);
|
2505 |
-
if (cssClass != '') {
|
2506 |
-
var props = svg.Styles[cssClass] || {};
|
2507 |
-
for (var k=0; k<cssProps.length; k++) {
|
2508 |
-
var prop = cssProps[k].indexOf(':');
|
2509 |
-
var name = cssProps[k].substr(0, prop);
|
2510 |
-
var value = cssProps[k].substr(prop + 1, cssProps[k].length - prop);
|
2511 |
-
if (name != null && value != null) {
|
2512 |
-
props[svg.trim(name)] = new svg.Property(svg.trim(name), svg.trim(value));
|
2513 |
-
}
|
2514 |
-
}
|
2515 |
-
svg.Styles[cssClass] = props;
|
2516 |
-
svg.StylesSpecificity[cssClass] = getSelectorSpecificity(cssClass);
|
2517 |
-
if (cssClass == '@font-face') {
|
2518 |
-
var fontFamily = props['font-family'].value.replace(/"/g,'');
|
2519 |
-
var srcs = props['src'].value.split(',');
|
2520 |
-
for (var s=0; s<srcs.length; s++) {
|
2521 |
-
if (srcs[s].indexOf('format("svg")') > 0) {
|
2522 |
-
var urlStart = srcs[s].indexOf('url');
|
2523 |
-
var urlEnd = srcs[s].indexOf(')', urlStart);
|
2524 |
-
var url = srcs[s].substr(urlStart + 5, urlEnd - urlStart - 6);
|
2525 |
-
var doc = svg.parseXml(svg.ajax(url));
|
2526 |
-
var fonts = doc.getElementsByTagName('font');
|
2527 |
-
for (var f=0; f<fonts.length; f++) {
|
2528 |
-
var font = svg.CreateElement(fonts[f]);
|
2529 |
-
svg.Definitions[fontFamily] = font;
|
2530 |
-
}
|
2531 |
-
}
|
2532 |
-
}
|
2533 |
-
}
|
2534 |
-
}
|
2535 |
-
}
|
2536 |
-
}
|
2537 |
-
}
|
2538 |
-
}
|
2539 |
-
svg.Element.style.prototype = new svg.Element.ElementBase;
|
2540 |
-
|
2541 |
-
// use element
|
2542 |
-
svg.Element.use = function(node) {
|
2543 |
-
this.base = svg.Element.RenderedElementBase;
|
2544 |
-
this.base(node);
|
2545 |
-
|
2546 |
-
this.baseSetContext = this.setContext;
|
2547 |
-
this.setContext = function(ctx) {
|
2548 |
-
this.baseSetContext(ctx);
|
2549 |
-
if (this.attribute('x').hasValue()) ctx.translate(this.attribute('x').toPixels('x'), 0);
|
2550 |
-
if (this.attribute('y').hasValue()) ctx.translate(0, this.attribute('y').toPixels('y'));
|
2551 |
-
}
|
2552 |
-
|
2553 |
-
var element = this.getHrefAttribute().getDefinition();
|
2554 |
-
|
2555 |
-
this.path = function(ctx) {
|
2556 |
-
if (element != null) element.path(ctx);
|
2557 |
-
}
|
2558 |
-
|
2559 |
-
this.getBoundingBox = function() {
|
2560 |
-
if (element != null) return element.getBoundingBox();
|
2561 |
-
}
|
2562 |
-
|
2563 |
-
this.renderChildren = function(ctx) {
|
2564 |
-
if (element != null) {
|
2565 |
-
var tempSvg = element;
|
2566 |
-
if (element.type == 'symbol') {
|
2567 |
-
// render me using a temporary svg element in symbol cases (http://www.w3.org/TR/SVG/struct.html#UseElement)
|
2568 |
-
tempSvg = new svg.Element.svg();
|
2569 |
-
tempSvg.type = 'svg';
|
2570 |
-
tempSvg.attributes['viewBox'] = new svg.Property('viewBox', element.attribute('viewBox').value);
|
2571 |
-
tempSvg.attributes['preserveAspectRatio'] = new svg.Property('preserveAspectRatio', element.attribute('preserveAspectRatio').value);
|
2572 |
-
tempSvg.attributes['overflow'] = new svg.Property('overflow', element.attribute('overflow').value);
|
2573 |
-
tempSvg.children = element.children;
|
2574 |
-
}
|
2575 |
-
if (tempSvg.type == 'svg') {
|
2576 |
-
// if symbol or svg, inherit width/height from me
|
2577 |
-
if (this.attribute('width').hasValue()) tempSvg.attributes['width'] = new svg.Property('width', this.attribute('width').value);
|
2578 |
-
if (this.attribute('height').hasValue()) tempSvg.attributes['height'] = new svg.Property('height', this.attribute('height').value);
|
2579 |
-
}
|
2580 |
-
var oldParent = tempSvg.parent;
|
2581 |
-
tempSvg.parent = null;
|
2582 |
-
tempSvg.render(ctx);
|
2583 |
-
tempSvg.parent = oldParent;
|
2584 |
-
}
|
2585 |
-
}
|
2586 |
-
}
|
2587 |
-
svg.Element.use.prototype = new svg.Element.RenderedElementBase;
|
2588 |
-
|
2589 |
-
// mask element
|
2590 |
-
svg.Element.mask = function(node) {
|
2591 |
-
this.base = svg.Element.ElementBase;
|
2592 |
-
this.base(node);
|
2593 |
-
|
2594 |
-
this.apply = function(ctx, element) {
|
2595 |
-
// render as temp svg
|
2596 |
-
var x = this.attribute('x').toPixels('x');
|
2597 |
-
var y = this.attribute('y').toPixels('y');
|
2598 |
-
var width = this.attribute('width').toPixels('x');
|
2599 |
-
var height = this.attribute('height').toPixels('y');
|
2600 |
-
|
2601 |
-
if (width == 0 && height == 0) {
|
2602 |
-
var bb = new svg.BoundingBox();
|
2603 |
-
for (var i=0; i<this.children.length; i++) {
|
2604 |
-
bb.addBoundingBox(this.children[i].getBoundingBox());
|
2605 |
-
}
|
2606 |
-
var x = Math.floor(bb.x1);
|
2607 |
-
var y = Math.floor(bb.y1);
|
2608 |
-
var width = Math.floor(bb.width());
|
2609 |
-
var height = Math.floor(bb.height());
|
2610 |
-
}
|
2611 |
-
|
2612 |
-
// temporarily remove mask to avoid recursion
|
2613 |
-
var mask = element.attribute('mask').value;
|
2614 |
-
element.attribute('mask').value = '';
|
2615 |
-
|
2616 |
-
var cMask = document.createElement('canvas');
|
2617 |
-
cMask.width = x + width;
|
2618 |
-
cMask.height = y + height;
|
2619 |
-
var maskCtx = cMask.getContext('2d');
|
2620 |
-
this.renderChildren(maskCtx);
|
2621 |
-
|
2622 |
-
var c = document.createElement('canvas');
|
2623 |
-
c.width = x + width;
|
2624 |
-
c.height = y + height;
|
2625 |
-
var tempCtx = c.getContext('2d');
|
2626 |
-
element.render(tempCtx);
|
2627 |
-
tempCtx.globalCompositeOperation = 'destination-in';
|
2628 |
-
tempCtx.fillStyle = maskCtx.createPattern(cMask, 'no-repeat');
|
2629 |
-
tempCtx.fillRect(0, 0, x + width, y + height);
|
2630 |
-
|
2631 |
-
ctx.fillStyle = tempCtx.createPattern(c, 'no-repeat');
|
2632 |
-
ctx.fillRect(0, 0, x + width, y + height);
|
2633 |
-
|
2634 |
-
// reassign mask
|
2635 |
-
element.attribute('mask').value = mask;
|
2636 |
-
}
|
2637 |
-
|
2638 |
-
this.render = function(ctx) {
|
2639 |
-
// NO RENDER
|
2640 |
-
}
|
2641 |
-
}
|
2642 |
-
svg.Element.mask.prototype = new svg.Element.ElementBase;
|
2643 |
-
|
2644 |
-
// clip element
|
2645 |
-
svg.Element.clipPath = function(node) {
|
2646 |
-
this.base = svg.Element.ElementBase;
|
2647 |
-
this.base(node);
|
2648 |
-
|
2649 |
-
this.apply = function(ctx) {
|
2650 |
-
var oldBeginPath = CanvasRenderingContext2D.prototype.beginPath;
|
2651 |
-
CanvasRenderingContext2D.prototype.beginPath = function () { };
|
2652 |
-
|
2653 |
-
var oldClosePath = CanvasRenderingContext2D.prototype.closePath;
|
2654 |
-
CanvasRenderingContext2D.prototype.closePath = function () { };
|
2655 |
-
|
2656 |
-
oldBeginPath.call(ctx);
|
2657 |
-
for (var i=0; i<this.children.length; i++) {
|
2658 |
-
var child = this.children[i];
|
2659 |
-
if (typeof child.path != 'undefined') {
|
2660 |
-
var transform = null;
|
2661 |
-
if (child.style('transform', false, true).hasValue()) {
|
2662 |
-
transform = new svg.Transform(child.style('transform', false, true).value);
|
2663 |
-
transform.apply(ctx);
|
2664 |
-
}
|
2665 |
-
child.path(ctx);
|
2666 |
-
CanvasRenderingContext2D.prototype.closePath = oldClosePath;
|
2667 |
-
if (transform) { transform.unapply(ctx); }
|
2668 |
-
}
|
2669 |
-
}
|
2670 |
-
oldClosePath.call(ctx);
|
2671 |
-
ctx.clip();
|
2672 |
-
|
2673 |
-
CanvasRenderingContext2D.prototype.beginPath = oldBeginPath;
|
2674 |
-
CanvasRenderingContext2D.prototype.closePath = oldClosePath;
|
2675 |
-
}
|
2676 |
-
|
2677 |
-
this.render = function(ctx) {
|
2678 |
-
// NO RENDER
|
2679 |
-
}
|
2680 |
-
}
|
2681 |
-
svg.Element.clipPath.prototype = new svg.Element.ElementBase;
|
2682 |
-
|
2683 |
-
// filters
|
2684 |
-
svg.Element.filter = function(node) {
|
2685 |
-
this.base = svg.Element.ElementBase;
|
2686 |
-
this.base(node);
|
2687 |
-
|
2688 |
-
this.apply = function(ctx, element) {
|
2689 |
-
// render as temp svg
|
2690 |
-
var bb = element.getBoundingBox();
|
2691 |
-
var x = Math.floor(bb.x1);
|
2692 |
-
var y = Math.floor(bb.y1);
|
2693 |
-
var width = Math.floor(bb.width());
|
2694 |
-
var height = Math.floor(bb.height());
|
2695 |
-
|
2696 |
-
// temporarily remove filter to avoid recursion
|
2697 |
-
var filter = element.style('filter').value;
|
2698 |
-
element.style('filter').value = '';
|
2699 |
-
|
2700 |
-
var px = 0, py = 0;
|
2701 |
-
for (var i=0; i<this.children.length; i++) {
|
2702 |
-
var efd = this.children[i].extraFilterDistance || 0;
|
2703 |
-
px = Math.max(px, efd);
|
2704 |
-
py = Math.max(py, efd);
|
2705 |
-
}
|
2706 |
-
|
2707 |
-
var c = document.createElement('canvas');
|
2708 |
-
c.width = width + 2*px;
|
2709 |
-
c.height = height + 2*py;
|
2710 |
-
var tempCtx = c.getContext('2d');
|
2711 |
-
tempCtx.translate(-x + px, -y + py);
|
2712 |
-
element.render(tempCtx);
|
2713 |
-
|
2714 |
-
// apply filters
|
2715 |
-
for (var i=0; i<this.children.length; i++) {
|
2716 |
-
if (typeof this.children[i].apply == 'function') {
|
2717 |
-
this.children[i].apply(tempCtx, 0, 0, width + 2*px, height + 2*py);
|
2718 |
-
}
|
2719 |
-
}
|
2720 |
-
|
2721 |
-
// render on me
|
2722 |
-
ctx.drawImage(c, 0, 0, width + 2*px, height + 2*py, x - px, y - py, width + 2*px, height + 2*py);
|
2723 |
-
|
2724 |
-
// reassign filter
|
2725 |
-
element.style('filter', true).value = filter;
|
2726 |
-
}
|
2727 |
-
|
2728 |
-
this.render = function(ctx) {
|
2729 |
-
// NO RENDER
|
2730 |
-
}
|
2731 |
-
}
|
2732 |
-
svg.Element.filter.prototype = new svg.Element.ElementBase;
|
2733 |
-
|
2734 |
-
svg.Element.feMorphology = function(node) {
|
2735 |
-
this.base = svg.Element.ElementBase;
|
2736 |
-
this.base(node);
|
2737 |
-
|
2738 |
-
this.apply = function(ctx, x, y, width, height) {
|
2739 |
-
// TODO: implement
|
2740 |
-
}
|
2741 |
-
}
|
2742 |
-
svg.Element.feMorphology.prototype = new svg.Element.ElementBase;
|
2743 |
-
|
2744 |
-
svg.Element.feComposite = function(node) {
|
2745 |
-
this.base = svg.Element.ElementBase;
|
2746 |
-
this.base(node);
|
2747 |
-
|
2748 |
-
this.apply = function(ctx, x, y, width, height) {
|
2749 |
-
// TODO: implement
|
2750 |
-
}
|
2751 |
-
}
|
2752 |
-
svg.Element.feComposite.prototype = new svg.Element.ElementBase;
|
2753 |
-
|
2754 |
-
svg.Element.feColorMatrix = function(node) {
|
2755 |
-
this.base = svg.Element.ElementBase;
|
2756 |
-
this.base(node);
|
2757 |
-
|
2758 |
-
var matrix = svg.ToNumberArray(this.attribute('values').value);
|
2759 |
-
switch (this.attribute('type').valueOrDefault('matrix')) { // http://www.w3.org/TR/SVG/filters.html#feColorMatrixElement
|
2760 |
-
case 'saturate':
|
2761 |
-
var s = matrix[0];
|
2762 |
-
matrix = [0.213+0.787*s,0.715-0.715*s,0.072-0.072*s,0,0,
|
2763 |
-
0.213-0.213*s,0.715+0.285*s,0.072-0.072*s,0,0,
|
2764 |
-
0.213-0.213*s,0.715-0.715*s,0.072+0.928*s,0,0,
|
2765 |
-
0,0,0,1,0,
|
2766 |
-
0,0,0,0,1];
|
2767 |
-
break;
|
2768 |
-
case 'hueRotate':
|
2769 |
-
var a = matrix[0] * Math.PI / 180.0;
|
2770 |
-
var c = function (m1,m2,m3) { return m1 + Math.cos(a)*m2 + Math.sin(a)*m3; };
|
2771 |
-
matrix = [c(0.213,0.787,-0.213),c(0.715,-0.715,-0.715),c(0.072,-0.072,0.928),0,0,
|
2772 |
-
c(0.213,-0.213,0.143),c(0.715,0.285,0.140),c(0.072,-0.072,-0.283),0,0,
|
2773 |
-
c(0.213,-0.213,-0.787),c(0.715,-0.715,0.715),c(0.072,0.928,0.072),0,0,
|
2774 |
-
0,0,0,1,0,
|
2775 |
-
0,0,0,0,1];
|
2776 |
-
break;
|
2777 |
-
case 'luminanceToAlpha':
|
2778 |
-
matrix = [0,0,0,0,0,
|
2779 |
-
0,0,0,0,0,
|
2780 |
-
0,0,0,0,0,
|
2781 |
-
0.2125,0.7154,0.0721,0,0,
|
2782 |
-
0,0,0,0,1];
|
2783 |
-
break;
|
2784 |
-
}
|
2785 |
-
|
2786 |
-
function imGet(img, x, y, width, height, rgba) {
|
2787 |
-
return img[y*width*4 + x*4 + rgba];
|
2788 |
-
}
|
2789 |
-
|
2790 |
-
function imSet(img, x, y, width, height, rgba, val) {
|
2791 |
-
img[y*width*4 + x*4 + rgba] = val;
|
2792 |
-
}
|
2793 |
-
|
2794 |
-
function m(i, v) {
|
2795 |
-
var mi = matrix[i];
|
2796 |
-
return mi * (mi < 0 ? v - 255 : v);
|
2797 |
-
}
|
2798 |
-
|
2799 |
-
this.apply = function(ctx, x, y, width, height) {
|
2800 |
-
// assuming x==0 && y==0 for now
|
2801 |
-
var srcData = ctx.getImageData(0, 0, width, height);
|
2802 |
-
for (var y = 0; y < height; y++) {
|
2803 |
-
for (var x = 0; x < width; x++) {
|
2804 |
-
var r = imGet(srcData.data, x, y, width, height, 0);
|
2805 |
-
var g = imGet(srcData.data, x, y, width, height, 1);
|
2806 |
-
var b = imGet(srcData.data, x, y, width, height, 2);
|
2807 |
-
var a = imGet(srcData.data, x, y, width, height, 3);
|
2808 |
-
imSet(srcData.data, x, y, width, height, 0, m(0,r)+m(1,g)+m(2,b)+m(3,a)+m(4,1));
|
2809 |
-
imSet(srcData.data, x, y, width, height, 1, m(5,r)+m(6,g)+m(7,b)+m(8,a)+m(9,1));
|
2810 |
-
imSet(srcData.data, x, y, width, height, 2, m(10,r)+m(11,g)+m(12,b)+m(13,a)+m(14,1));
|
2811 |
-
imSet(srcData.data, x, y, width, height, 3, m(15,r)+m(16,g)+m(17,b)+m(18,a)+m(19,1));
|
2812 |
-
}
|
2813 |
-
}
|
2814 |
-
ctx.clearRect(0, 0, width, height);
|
2815 |
-
ctx.putImageData(srcData, 0, 0);
|
2816 |
-
}
|
2817 |
-
}
|
2818 |
-
svg.Element.feColorMatrix.prototype = new svg.Element.ElementBase;
|
2819 |
-
|
2820 |
-
svg.Element.feGaussianBlur = function(node) {
|
2821 |
-
this.base = svg.Element.ElementBase;
|
2822 |
-
this.base(node);
|
2823 |
-
|
2824 |
-
this.blurRadius = Math.floor(this.attribute('stdDeviation').numValue());
|
2825 |
-
this.extraFilterDistance = this.blurRadius;
|
2826 |
-
|
2827 |
-
this.apply = function(ctx, x, y, width, height) {
|
2828 |
-
if (typeof stackBlur.canvasRGBA == 'undefined') {
|
2829 |
-
svg.log('ERROR: StackBlur.js must be included for blur to work');
|
2830 |
-
return;
|
2831 |
-
}
|
2832 |
-
|
2833 |
-
// StackBlur requires canvas be on document
|
2834 |
-
ctx.canvas.id = svg.UniqueId();
|
2835 |
-
ctx.canvas.style.display = 'none';
|
2836 |
-
document.body.appendChild(ctx.canvas);
|
2837 |
-
stackBlur.canvasRGBA(ctx.canvas.id, x, y, width, height, this.blurRadius);
|
2838 |
-
document.body.removeChild(ctx.canvas);
|
2839 |
-
}
|
2840 |
-
}
|
2841 |
-
svg.Element.feGaussianBlur.prototype = new svg.Element.ElementBase;
|
2842 |
-
|
2843 |
-
// title element, do nothing
|
2844 |
-
svg.Element.title = function(node) {
|
2845 |
-
}
|
2846 |
-
svg.Element.title.prototype = new svg.Element.ElementBase;
|
2847 |
-
|
2848 |
-
// desc element, do nothing
|
2849 |
-
svg.Element.desc = function(node) {
|
2850 |
-
}
|
2851 |
-
svg.Element.desc.prototype = new svg.Element.ElementBase;
|
2852 |
-
|
2853 |
-
svg.Element.MISSING = function(node) {
|
2854 |
-
svg.log('ERROR: Element \'' + node.nodeName + '\' not yet implemented.');
|
2855 |
-
}
|
2856 |
-
svg.Element.MISSING.prototype = new svg.Element.ElementBase;
|
2857 |
-
|
2858 |
-
// element factory
|
2859 |
-
svg.CreateElement = function(node) {
|
2860 |
-
var className = node.nodeName.replace(/^[^:]+:/,''); // remove namespace
|
2861 |
-
className = className.replace(/\-/g,''); // remove dashes
|
2862 |
-
var e = null;
|
2863 |
-
if (typeof svg.Element[className] != 'undefined') {
|
2864 |
-
e = new svg.Element[className](node);
|
2865 |
-
}
|
2866 |
-
else {
|
2867 |
-
e = new svg.Element.MISSING(node);
|
2868 |
-
}
|
2869 |
-
|
2870 |
-
e.type = node.nodeName;
|
2871 |
-
return e;
|
2872 |
-
}
|
2873 |
-
|
2874 |
-
// load from url
|
2875 |
-
svg.load = function(ctx, url) {
|
2876 |
-
svg.loadXml(ctx, svg.ajax(url));
|
2877 |
-
}
|
2878 |
-
|
2879 |
-
// load from xml
|
2880 |
-
svg.loadXml = function(ctx, xml) {
|
2881 |
-
svg.loadXmlDoc(ctx, svg.parseXml(xml));
|
2882 |
-
}
|
2883 |
-
|
2884 |
-
svg.loadXmlDoc = function(ctx, dom) {
|
2885 |
-
svg.init(ctx);
|
2886 |
-
|
2887 |
-
var mapXY = function(p) {
|
2888 |
-
var e = ctx.canvas;
|
2889 |
-
while (e) {
|
2890 |
-
p.x -= e.offsetLeft;
|
2891 |
-
p.y -= e.offsetTop;
|
2892 |
-
e = e.offsetParent;
|
2893 |
-
}
|
2894 |
-
if (window.scrollX) p.x += window.scrollX;
|
2895 |
-
if (window.scrollY) p.y += window.scrollY;
|
2896 |
-
return p;
|
2897 |
-
}
|
2898 |
-
|
2899 |
-
// bind mouse
|
2900 |
-
if (svg.opts['ignoreMouse'] != true) {
|
2901 |
-
ctx.canvas.onclick = function(e) {
|
2902 |
-
var p = mapXY(new svg.Point(e != null ? e.clientX : event.clientX, e != null ? e.clientY : event.clientY));
|
2903 |
-
svg.Mouse.onclick(p.x, p.y);
|
2904 |
-
};
|
2905 |
-
ctx.canvas.onmousemove = function(e) {
|
2906 |
-
var p = mapXY(new svg.Point(e != null ? e.clientX : event.clientX, e != null ? e.clientY : event.clientY));
|
2907 |
-
svg.Mouse.onmousemove(p.x, p.y);
|
2908 |
-
};
|
2909 |
-
}
|
2910 |
-
|
2911 |
-
var e = svg.CreateElement(dom.documentElement);
|
2912 |
-
e.root = true;
|
2913 |
-
e.addStylesFromStyleDefinition();
|
2914 |
-
|
2915 |
-
// render loop
|
2916 |
-
var isFirstRender = true;
|
2917 |
-
var draw = function() {
|
2918 |
-
svg.ViewPort.Clear();
|
2919 |
-
if (ctx.canvas.parentNode) svg.ViewPort.SetCurrent(ctx.canvas.parentNode.clientWidth, ctx.canvas.parentNode.clientHeight);
|
2920 |
-
|
2921 |
-
if (svg.opts['ignoreDimensions'] != true) {
|
2922 |
-
// set canvas size
|
2923 |
-
if (e.style('width').hasValue()) {
|
2924 |
-
ctx.canvas.width = e.style('width').toPixels('x');
|
2925 |
-
ctx.canvas.style.width = ctx.canvas.width + 'px';
|
2926 |
-
}
|
2927 |
-
if (e.style('height').hasValue()) {
|
2928 |
-
ctx.canvas.height = e.style('height').toPixels('y');
|
2929 |
-
ctx.canvas.style.height = ctx.canvas.height + 'px';
|
2930 |
-
}
|
2931 |
-
}
|
2932 |
-
var cWidth = ctx.canvas.clientWidth || ctx.canvas.width;
|
2933 |
-
var cHeight = ctx.canvas.clientHeight || ctx.canvas.height;
|
2934 |
-
if (svg.opts['ignoreDimensions'] == true && e.style('width').hasValue() && e.style('height').hasValue()) {
|
2935 |
-
cWidth = e.style('width').toPixels('x');
|
2936 |
-
cHeight = e.style('height').toPixels('y');
|
2937 |
-
}
|
2938 |
-
svg.ViewPort.SetCurrent(cWidth, cHeight);
|
2939 |
-
|
2940 |
-
if (svg.opts['offsetX'] != null) e.attribute('x', true).value = svg.opts['offsetX'];
|
2941 |
-
if (svg.opts['offsetY'] != null) e.attribute('y', true).value = svg.opts['offsetY'];
|
2942 |
-
if (svg.opts['scaleWidth'] != null || svg.opts['scaleHeight'] != null) {
|
2943 |
-
var xRatio = null, yRatio = null, viewBox = svg.ToNumberArray(e.attribute('viewBox').value);
|
2944 |
-
|
2945 |
-
if (svg.opts['scaleWidth'] != null) {
|
2946 |
-
if (e.attribute('width').hasValue()) xRatio = e.attribute('width').toPixels('x') / svg.opts['scaleWidth'];
|
2947 |
-
else if (!isNaN(viewBox[2])) xRatio = viewBox[2] / svg.opts['scaleWidth'];
|
2948 |
-
}
|
2949 |
-
|
2950 |
-
if (svg.opts['scaleHeight'] != null) {
|
2951 |
-
if (e.attribute('height').hasValue()) yRatio = e.attribute('height').toPixels('y') / svg.opts['scaleHeight'];
|
2952 |
-
else if (!isNaN(viewBox[3])) yRatio = viewBox[3] / svg.opts['scaleHeight'];
|
2953 |
-
}
|
2954 |
-
|
2955 |
-
if (xRatio == null) { xRatio = yRatio; }
|
2956 |
-
if (yRatio == null) { yRatio = xRatio; }
|
2957 |
-
|
2958 |
-
e.attribute('width', true).value = svg.opts['scaleWidth'];
|
2959 |
-
e.attribute('height', true).value = svg.opts['scaleHeight'];
|
2960 |
-
e.style('transform', true, true).value += ' scale('+(1.0/xRatio)+','+(1.0/yRatio)+')';
|
2961 |
-
}
|
2962 |
-
|
2963 |
-
// clear and render
|
2964 |
-
if (svg.opts['ignoreClear'] != true) {
|
2965 |
-
ctx.clearRect(0, 0, cWidth, cHeight);
|
2966 |
-
}
|
2967 |
-
e.render(ctx);
|
2968 |
-
if (isFirstRender) {
|
2969 |
-
isFirstRender = false;
|
2970 |
-
if (typeof svg.opts['renderCallback'] == 'function') svg.opts['renderCallback'](dom);
|
2971 |
-
}
|
2972 |
-
}
|
2973 |
-
|
2974 |
-
var waitingForImages = true;
|
2975 |
-
if (svg.ImagesLoaded()) {
|
2976 |
-
waitingForImages = false;
|
2977 |
-
draw();
|
2978 |
-
}
|
2979 |
-
svg.intervalID = setInterval(function() {
|
2980 |
-
var needUpdate = false;
|
2981 |
-
|
2982 |
-
if (waitingForImages && svg.ImagesLoaded()) {
|
2983 |
-
waitingForImages = false;
|
2984 |
-
needUpdate = true;
|
2985 |
-
}
|
2986 |
-
|
2987 |
-
// need update from mouse events?
|
2988 |
-
if (svg.opts['ignoreMouse'] != true) {
|
2989 |
-
needUpdate = needUpdate | svg.Mouse.hasEvents();
|
2990 |
-
}
|
2991 |
-
|
2992 |
-
// need update from animations?
|
2993 |
-
if (svg.opts['ignoreAnimation'] != true) {
|
2994 |
-
for (var i=0; i<svg.Animations.length; i++) {
|
2995 |
-
needUpdate = needUpdate | svg.Animations[i].update(1000 / svg.FRAMERATE);
|
2996 |
-
}
|
2997 |
-
}
|
2998 |
-
|
2999 |
-
// need update from redraw?
|
3000 |
-
if (typeof svg.opts['forceRedraw'] == 'function') {
|
3001 |
-
if (svg.opts['forceRedraw']() == true) needUpdate = true;
|
3002 |
-
}
|
3003 |
-
|
3004 |
-
// render if needed
|
3005 |
-
if (needUpdate) {
|
3006 |
-
draw();
|
3007 |
-
svg.Mouse.runEvents(); // run and clear our events
|
3008 |
-
}
|
3009 |
-
}, 1000 / svg.FRAMERATE);
|
3010 |
-
}
|
3011 |
-
|
3012 |
-
svg.stop = function() {
|
3013 |
-
if (svg.intervalID) {
|
3014 |
-
clearInterval(svg.intervalID);
|
3015 |
-
}
|
3016 |
-
}
|
3017 |
-
|
3018 |
-
svg.Mouse = new (function() {
|
3019 |
-
this.events = [];
|
3020 |
-
this.hasEvents = function() { return this.events.length != 0; }
|
3021 |
-
|
3022 |
-
this.onclick = function(x, y) {
|
3023 |
-
this.events.push({ type: 'onclick', x: x, y: y,
|
3024 |
-
run: function(e) { if (e.onclick) e.onclick(); }
|
3025 |
-
});
|
3026 |
-
}
|
3027 |
-
|
3028 |
-
this.onmousemove = function(x, y) {
|
3029 |
-
this.events.push({ type: 'onmousemove', x: x, y: y,
|
3030 |
-
run: function(e) { if (e.onmousemove) e.onmousemove(); }
|
3031 |
-
});
|
3032 |
-
}
|
3033 |
-
|
3034 |
-
this.eventElements = [];
|
3035 |
-
|
3036 |
-
this.checkPath = function(element, ctx) {
|
3037 |
-
for (var i=0; i<this.events.length; i++) {
|
3038 |
-
var e = this.events[i];
|
3039 |
-
if (ctx.isPointInPath && ctx.isPointInPath(e.x, e.y)) this.eventElements[i] = element;
|
3040 |
-
}
|
3041 |
-
}
|
3042 |
-
|
3043 |
-
this.checkBoundingBox = function(element, bb) {
|
3044 |
-
for (var i=0; i<this.events.length; i++) {
|
3045 |
-
var e = this.events[i];
|
3046 |
-
if (bb.isPointInBox(e.x, e.y)) this.eventElements[i] = element;
|
3047 |
-
}
|
3048 |
-
}
|
3049 |
-
|
3050 |
-
this.runEvents = function() {
|
3051 |
-
svg.ctx.canvas.style.cursor = '';
|
3052 |
-
|
3053 |
-
for (var i=0; i<this.events.length; i++) {
|
3054 |
-
var e = this.events[i];
|
3055 |
-
var element = this.eventElements[i];
|
3056 |
-
while (element) {
|
3057 |
-
e.run(element);
|
3058 |
-
element = element.parent;
|
3059 |
-
}
|
3060 |
-
}
|
3061 |
-
|
3062 |
-
// done running, clear
|
3063 |
-
this.events = [];
|
3064 |
-
this.eventElements = [];
|
3065 |
-
}
|
3066 |
-
});
|
3067 |
-
|
3068 |
-
return svg;
|
3069 |
-
};
|
3070 |
-
|
3071 |
-
if (typeof CanvasRenderingContext2D != 'undefined') {
|
3072 |
-
CanvasRenderingContext2D.prototype.drawSvg = function(s, dx, dy, dw, dh, opts) {
|
3073 |
-
var cOpts = {
|
3074 |
-
ignoreMouse: true,
|
3075 |
-
ignoreAnimation: true,
|
3076 |
-
ignoreDimensions: true,
|
3077 |
-
ignoreClear: true,
|
3078 |
-
offsetX: dx,
|
3079 |
-
offsetY: dy,
|
3080 |
-
scaleWidth: dw,
|
3081 |
-
scaleHeight: dh
|
3082 |
-
}
|
3083 |
-
|
3084 |
-
for(var prop in opts) {
|
3085 |
-
if(opts.hasOwnProperty(prop)){
|
3086 |
-
cOpts[prop] = opts[prop];
|
3087 |
-
}
|
3088 |
-
}
|
3089 |
-
canvg(this.canvas, s, cOpts);
|
3090 |
-
}
|
3091 |
-
}
|
3092 |
-
|
3093 |
-
return canvg;
|
3094 |
-
|
3095 |
-
}));
|
1 |
+
/*
|
2 |
+
* canvg.js - Javascript SVG parser and renderer on Canvas
|
3 |
+
* MIT Licensed
|
4 |
+
* Gabe Lerner (gabelerner@gmail.com)
|
5 |
+
* http://code.google.com/p/canvg/
|
6 |
+
*
|
7 |
+
* Requires: rgbcolor.js - http://www.phpied.com/rgb-color-parser-in-javascript/
|
8 |
+
*/
|
9 |
+
(function ( global, factory ) {
|
10 |
+
|
11 |
+
'use strict';
|
12 |
+
|
13 |
+
// export as AMD...
|
14 |
+
if ( typeof define !== 'undefined' && define.amd ) {
|
15 |
+
define('canvgModule', [ 'rgbcolor', 'stackblur' ], factory );
|
16 |
+
}
|
17 |
+
|
18 |
+
// ...or as browserify
|
19 |
+
else if ( typeof module !== 'undefined' && module.exports ) {
|
20 |
+
module.exports = factory( require( 'rgbcolor' ), require( 'stackblur' ) );
|
21 |
+
}
|
22 |
+
|
23 |
+
global.canvg = factory( global.RGBColor, global.stackBlur );
|
24 |
+
|
25 |
+
}( typeof window !== 'undefined' ? window : this, function ( RGBColor, stackBlur ) {
|
26 |
+
|
27 |
+
// canvg(target, s)
|
28 |
+
// empty parameters: replace all 'svg' elements on page with 'canvas' elements
|
29 |
+
// target: canvas element or the id of a canvas element
|
30 |
+
// s: svg string, url to svg file, or xml document
|
31 |
+
// opts: optional hash of options
|
32 |
+
// ignoreMouse: true => ignore mouse events
|
33 |
+
// ignoreAnimation: true => ignore animations
|
34 |
+
// ignoreDimensions: true => does not try to resize canvas
|
35 |
+
// ignoreClear: true => does not clear canvas
|
36 |
+
// offsetX: int => draws at a x offset
|
37 |
+
// offsetY: int => draws at a y offset
|
38 |
+
// scaleWidth: int => scales horizontally to width
|
39 |
+
// scaleHeight: int => scales vertically to height
|
40 |
+
// renderCallback: function => will call the function after the first render is completed
|
41 |
+
// forceRedraw: function => will call the function on every frame, if it returns true, will redraw
|
42 |
+
var canvg = function (target, s, opts) {
|
43 |
+
// no parameters
|
44 |
+
if (target == null && s == null && opts == null) {
|
45 |
+
var svgTags = document.querySelectorAll('svg');
|
46 |
+
for (var i=0; i<svgTags.length; i++) {
|
47 |
+
var svgTag = svgTags[i];
|
48 |
+
var c = document.createElement('canvas');
|
49 |
+
c.width = svgTag.clientWidth;
|
50 |
+
c.height = svgTag.clientHeight;
|
51 |
+
svgTag.parentNode.insertBefore(c, svgTag);
|
52 |
+
svgTag.parentNode.removeChild(svgTag);
|
53 |
+
var div = document.createElement('div');
|
54 |
+
div.appendChild(svgTag);
|
55 |
+
canvg(c, div.innerHTML);
|
56 |
+
}
|
57 |
+
return;
|
58 |
+
}
|
59 |
+
|
60 |
+
if (typeof target == 'string') {
|
61 |
+
target = document.getElementById(target);
|
62 |
+
}
|
63 |
+
|
64 |
+
// store class on canvas
|
65 |
+
if (target.svg != null) target.svg.stop();
|
66 |
+
var svg = build(opts || {});
|
67 |
+
// on i.e. 8 for flash canvas, we can't assign the property so check for it
|
68 |
+
if (!(target.childNodes.length == 1 && target.childNodes[0].nodeName == 'OBJECT')) target.svg = svg;
|
69 |
+
|
70 |
+
var ctx = target.getContext('2d');
|
71 |
+
if (typeof s.documentElement != 'undefined') {
|
72 |
+
// load from xml doc
|
73 |
+
svg.loadXmlDoc(ctx, s);
|
74 |
+
}
|
75 |
+
else if (s.substr(0,1) == '<') {
|
76 |
+
// load from xml string
|
77 |
+
svg.loadXml(ctx, s);
|
78 |
+
}
|
79 |
+
else {
|
80 |
+
// load from url
|
81 |
+
svg.load(ctx, s);
|
82 |
+
}
|
83 |
+
}
|
84 |
+
|
85 |
+
// see https://developer.mozilla.org/en-US/docs/Web/API/Element.matches
|
86 |
+
var matchesSelector;
|
87 |
+
if (typeof Element.prototype.matches != 'undefined') {
|
88 |
+
matchesSelector = function(node, selector) {
|
89 |
+
return node.matches(selector);
|
90 |
+
};
|
91 |
+
} else if (typeof Element.prototype.webkitMatchesSelector != 'undefined') {
|
92 |
+
matchesSelector = function(node, selector) {
|
93 |
+
return node.webkitMatchesSelector(selector);
|
94 |
+
};
|
95 |
+
} else if (typeof Element.prototype.mozMatchesSelector != 'undefined') {
|
96 |
+
matchesSelector = function(node, selector) {
|
97 |
+
return node.mozMatchesSelector(selector);
|
98 |
+
};
|
99 |
+
} else if (typeof Element.prototype.msMatchesSelector != 'undefined') {
|
100 |
+
matchesSelector = function(node, selector) {
|
101 |
+
return node.msMatchesSelector(selector);
|
102 |
+
};
|
103 |
+
} else if (typeof Element.prototype.oMatchesSelector != 'undefined') {
|
104 |
+
matchesSelector = function(node, selector) {
|
105 |
+
return node.oMatchesSelector(selector);
|
106 |
+
};
|
107 |
+
} else {
|
108 |
+
// requires Sizzle: https://github.com/jquery/sizzle/wiki/Sizzle-Documentation
|
109 |
+
// or jQuery: http://jquery.com/download/
|
110 |
+
// or Zepto: http://zeptojs.com/#
|
111 |
+
// without it, this is a ReferenceError
|
112 |
+
|
113 |
+
if (typeof jQuery === 'function' || typeof Zepto === 'function') {
|
114 |
+
matchesSelector = function (node, selector) {
|
115 |
+
return $(node).is(selector);
|
116 |
+
};
|
117 |
+
}
|
118 |
+
|
119 |
+
if (typeof matchesSelector === 'undefined') {
|
120 |
+
matchesSelector = Sizzle.matchesSelector;
|
121 |
+
}
|
122 |
+
}
|
123 |
+
|
124 |
+
// slightly modified version of https://github.com/keeganstreet/specificity/blob/master/specificity.js
|
125 |
+
var attributeRegex = /(\[[^\]]+\])/g;
|
126 |
+
var idRegex = /(#[^\s\+>~\.\[:]+)/g;
|
127 |
+
var classRegex = /(\.[^\s\+>~\.\[:]+)/g;
|
128 |
+
var pseudoElementRegex = /(::[^\s\+>~\.\[:]+|:first-line|:first-letter|:before|:after)/gi;
|
129 |
+
var pseudoClassWithBracketsRegex = /(:[\w-]+\([^\)]*\))/gi;
|
130 |
+
var pseudoClassRegex = /(:[^\s\+>~\.\[:]+)/g;
|
131 |
+
var elementRegex = /([^\s\+>~\.\[:]+)/g;
|
132 |
+
function getSelectorSpecificity(selector) {
|
133 |
+
var typeCount = [0, 0, 0];
|
134 |
+
var findMatch = function(regex, type) {
|
135 |
+
var matches = selector.match(regex);
|
136 |
+
if (matches == null) {
|
137 |
+
return;
|
138 |
+
}
|
139 |
+
typeCount[type] += matches.length;
|
140 |
+
selector = selector.replace(regex, ' ');
|
141 |
+
};
|
142 |
+
|
143 |
+
selector = selector.replace(/:not\(([^\)]*)\)/g, ' $1 ');
|
144 |
+
selector = selector.replace(/{[\s\S]*/gm, ' ');
|
145 |
+
findMatch(attributeRegex, 1);
|
146 |
+
findMatch(idRegex, 0);
|
147 |
+
findMatch(classRegex, 1);
|
148 |
+
findMatch(pseudoElementRegex, 2);
|
149 |
+
findMatch(pseudoClassWithBracketsRegex, 1);
|
150 |
+
findMatch(pseudoClassRegex, 1);
|
151 |
+
selector = selector.replace(/[\*\s\+>~]/g, ' ');
|
152 |
+
selector = selector.replace(/[#\.]/g, ' ');
|
153 |
+
findMatch(elementRegex, 2);
|
154 |
+
return typeCount.join('');
|
155 |
+
}
|
156 |
+
|
157 |
+
function build(opts) {
|
158 |
+
var svg = { opts: opts };
|
159 |
+
|
160 |
+
svg.FRAMERATE = 30;
|
161 |
+
svg.MAX_VIRTUAL_PIXELS = 30000;
|
162 |
+
|
163 |
+
svg.log = function(msg) {};
|
164 |
+
if (svg.opts['log'] == true && typeof console != 'undefined') {
|
165 |
+
svg.log = function(msg) { console.log(msg); };
|
166 |
+
};
|
167 |
+
|
168 |
+
// globals
|
169 |
+
svg.init = function(ctx) {
|
170 |
+
var uniqueId = 0;
|
171 |
+
svg.UniqueId = function () { uniqueId++; return 'canvg' + uniqueId; };
|
172 |
+
svg.Definitions = {};
|
173 |
+
svg.Styles = {};
|
174 |
+
svg.StylesSpecificity = {};
|
175 |
+
svg.Animations = [];
|
176 |
+
svg.Images = [];
|
177 |
+
svg.ctx = ctx;
|
178 |
+
svg.ViewPort = new (function () {
|
179 |
+
this.viewPorts = [];
|
180 |
+
this.Clear = function() { this.viewPorts = []; }
|
181 |
+
this.SetCurrent = function(width, height) { this.viewPorts.push({ width: width, height: height }); }
|
182 |
+
this.RemoveCurrent = function() { this.viewPorts.pop(); }
|
183 |
+
this.Current = function() { return this.viewPorts[this.viewPorts.length - 1]; }
|
184 |
+
this.width = function() { return this.Current().width; }
|
185 |
+
this.height = function() { return this.Current().height; }
|
186 |
+
this.ComputeSize = function(d) {
|
187 |
+
if (d != null && typeof d == 'number') return d;
|
188 |
+
if (d == 'x') return this.width();
|
189 |
+
if (d == 'y') return this.height();
|
190 |
+
return Math.sqrt(Math.pow(this.width(), 2) + Math.pow(this.height(), 2)) / Math.sqrt(2);
|
191 |
+
}
|
192 |
+
});
|
193 |
+
}
|
194 |
+
svg.init();
|
195 |
+
|
196 |
+
// images loaded
|
197 |
+
svg.ImagesLoaded = function() {
|
198 |
+
for (var i=0; i<svg.Images.length; i++) {
|
199 |
+
if (!svg.Images[i].loaded) return false;
|
200 |
+
}
|
201 |
+
return true;
|
202 |
+
}
|
203 |
+
|
204 |
+
// trim
|
205 |
+
svg.trim = function(s) { return s.replace(/^\s+|\s+$/g, ''); }
|
206 |
+
|
207 |
+
// compress spaces
|
208 |
+
svg.compressSpaces = function(s) { return s.replace(/[\s\r\t\n]+/gm,' '); }
|
209 |
+
|
210 |
+
// ajax
|
211 |
+
svg.ajax = function(url) {
|
212 |
+
var AJAX;
|
213 |
+
if(window.XMLHttpRequest){AJAX=new XMLHttpRequest();}
|
214 |
+
else{AJAX=new ActiveXObject('Microsoft.XMLHTTP');}
|
215 |
+
if(AJAX){
|
216 |
+
AJAX.open('GET',url,false);
|
217 |
+
AJAX.send(null);
|
218 |
+
return AJAX.responseText;
|
219 |
+
}
|
220 |
+
return null;
|
221 |
+
}
|
222 |
+
|
223 |
+
// parse xml
|
224 |
+
svg.parseXml = function(xml) {
|
225 |
+
if (typeof Windows != 'undefined' && typeof Windows.Data != 'undefined' && typeof Windows.Data.Xml != 'undefined') {
|
226 |
+
var xmlDoc = new Windows.Data.Xml.Dom.XmlDocument();
|
227 |
+
var settings = new Windows.Data.Xml.Dom.XmlLoadSettings();
|
228 |
+
settings.prohibitDtd = false;
|
229 |
+
xmlDoc.loadXml(xml, settings);
|
230 |
+
return xmlDoc;
|
231 |
+
}
|
232 |
+
else if (window.DOMParser)
|
233 |
+
{
|
234 |
+
var parser = new DOMParser();
|
235 |
+
return parser.parseFromString(xml, 'text/xml');
|
236 |
+
}
|
237 |
+
else
|
238 |
+
{
|
239 |
+
xml = xml.replace(/<!DOCTYPE svg[^>]*>/, '');
|
240 |
+
var xmlDoc = new ActiveXObject('Microsoft.XMLDOM');
|
241 |
+
xmlDoc.async = 'false';
|
242 |
+
xmlDoc.loadXML(xml);
|
243 |
+
return xmlDoc;
|
244 |
+
}
|
245 |
+
}
|
246 |
+
|
247 |
+
svg.Property = function(name, value) {
|
248 |
+
this.name = name;
|
249 |
+
this.value = value;
|
250 |
+
}
|
251 |
+
svg.Property.prototype.getValue = function() {
|
252 |
+
return this.value;
|
253 |
+
}
|
254 |
+
|
255 |
+
svg.Property.prototype.hasValue = function() {
|
256 |
+
return (this.value != null && this.value !== '');
|
257 |
+
}
|
258 |
+
|
259 |
+
// return the numerical value of the property
|
260 |
+
svg.Property.prototype.numValue = function() {
|
261 |
+
if (!this.hasValue()) return 0;
|
262 |
+
|
263 |
+
var n = parseFloat(this.value);
|
264 |
+
if ((this.value + '').match(/%$/)) {
|
265 |
+
n = n / 100.0;
|
266 |
+
}
|
267 |
+
return n;
|
268 |
+
}
|
269 |
+
|
270 |
+
svg.Property.prototype.valueOrDefault = function(def) {
|
271 |
+
if (this.hasValue()) return this.value;
|
272 |
+
return def;
|
273 |
+
}
|
274 |
+
|
275 |
+
svg.Property.prototype.numValueOrDefault = function(def) {
|
276 |
+
if (this.hasValue()) return this.numValue();
|
277 |
+
return def;
|
278 |
+
}
|
279 |
+
|
280 |
+
// color extensions
|
281 |
+
// augment the current color value with the opacity
|
282 |
+
svg.Property.prototype.addOpacity = function(opacityProp) {
|
283 |
+
var newValue = this.value;
|
284 |
+
if (opacityProp.value != null && opacityProp.value != '' && typeof this.value == 'string') { // can only add opacity to colors, not patterns
|
285 |
+
var color = new RGBColor(this.value);
|
286 |
+
if (color.ok) {
|
287 |
+
newValue = 'rgba(' + color.r + ', ' + color.g + ', ' + color.b + ', ' + opacityProp.numValue() + ')';
|
288 |
+
}
|
289 |
+
}
|
290 |
+
return new svg.Property(this.name, newValue);
|
291 |
+
}
|
292 |
+
|
293 |
+
// definition extensions
|
294 |
+
// get the definition from the definitions table
|
295 |
+
svg.Property.prototype.getDefinition = function() {
|
296 |
+
var name = this.value.match(/#([^\)'"]+)/);
|
297 |
+
if (name) { name = name[1]; }
|
298 |
+
if (!name) { name = this.value; }
|
299 |
+
return svg.Definitions[name];
|
300 |
+
}
|
301 |
+
|
302 |
+
svg.Property.prototype.isUrlDefinition = function() {
|
303 |
+
return this.value.indexOf('url(') == 0
|
304 |
+
}
|
305 |
+
|
306 |
+
svg.Property.prototype.getFillStyleDefinition = function(e, opacityProp) {
|
307 |
+
var def = this.getDefinition();
|
308 |
+
|
309 |
+
// gradient
|
310 |
+
if (def != null && def.createGradient) {
|
311 |
+
return def.createGradient(svg.ctx, e, opacityProp);
|
312 |
+
}
|
313 |
+
|
314 |
+
// pattern
|
315 |
+
if (def != null && def.createPattern) {
|
316 |
+
if (def.getHrefAttribute().hasValue()) {
|
317 |
+
var pt = def.attribute('patternTransform');
|
318 |
+
def = def.getHrefAttribute().getDefinition();
|
319 |
+
if (pt.hasValue()) { def.attribute('patternTransform', true).value = pt.value; }
|
320 |
+
}
|
321 |
+
return def.createPattern(svg.ctx, e);
|
322 |
+
}
|
323 |
+
|
324 |
+
return null;
|
325 |
+
}
|
326 |
+
|
327 |
+
// length extensions
|
328 |
+
svg.Property.prototype.getDPI = function(viewPort) {
|
329 |
+
return 96.0; // TODO: compute?
|
330 |
+
}
|
331 |
+
|
332 |
+
svg.Property.prototype.getEM = function(viewPort) {
|
333 |
+
var em = 12;
|
334 |
+
|
335 |
+
var fontSize = new svg.Property('fontSize', svg.Font.Parse(svg.ctx.font).fontSize);
|
336 |
+
if (fontSize.hasValue()) em = fontSize.toPixels(viewPort);
|
337 |
+
|
338 |
+
return em;
|
339 |
+
}
|
340 |
+
|
341 |
+
svg.Property.prototype.getUnits = function() {
|
342 |
+
var s = this.value+'';
|
343 |
+
return s.replace(/[0-9\.\-]/g,'');
|
344 |
+
}
|
345 |
+
|
346 |
+
// get the length as pixels
|
347 |
+
svg.Property.prototype.toPixels = function(viewPort, processPercent) {
|
348 |
+
if (!this.hasValue()) return 0;
|
349 |
+
var s = this.value+'';
|
350 |
+
if (s.match(/em$/)) return this.numValue() * this.getEM(viewPort);
|
351 |
+
if (s.match(/ex$/)) return this.numValue() * this.getEM(viewPort) / 2.0;
|
352 |
+
if (s.match(/px$/)) return this.numValue();
|
353 |
+
if (s.match(/pt$/)) return this.numValue() * this.getDPI(viewPort) * (1.0 / 72.0);
|
354 |
+
if (s.match(/pc$/)) return this.numValue() * 15;
|
355 |
+
if (s.match(/cm$/)) return this.numValue() * this.getDPI(viewPort) / 2.54;
|
356 |
+
if (s.match(/mm$/)) return this.numValue() * this.getDPI(viewPort) / 25.4;
|
357 |
+
if (s.match(/in$/)) return this.numValue() * this.getDPI(viewPort);
|
358 |
+
if (s.match(/%$/)) return this.numValue() * svg.ViewPort.ComputeSize(viewPort);
|
359 |
+
var n = this.numValue();
|
360 |
+
if (processPercent && n < 1.0) return n * svg.ViewPort.ComputeSize(viewPort);
|
361 |
+
return n;
|
362 |
+
}
|
363 |
+
|
364 |
+
// time extensions
|
365 |
+
// get the time as milliseconds
|
366 |
+
svg.Property.prototype.toMilliseconds = function() {
|
367 |
+
if (!this.hasValue()) return 0;
|
368 |
+
var s = this.value+'';
|
369 |
+
if (s.match(/s$/)) return this.numValue() * 1000;
|
370 |
+
if (s.match(/ms$/)) return this.numValue();
|
371 |
+
return this.numValue();
|
372 |
+
}
|
373 |
+
|
374 |
+
// angle extensions
|
375 |
+
// get the angle as radians
|
376 |
+
svg.Property.prototype.toRadians = function() {
|
377 |
+
if (!this.hasValue()) return 0;
|
378 |
+
var s = this.value+'';
|
379 |
+
if (s.match(/deg$/)) return this.numValue() * (Math.PI / 180.0);
|
380 |
+
if (s.match(/grad$/)) return this.numValue() * (Math.PI / 200.0);
|
381 |
+
if (s.match(/rad$/)) return this.numValue();
|
382 |
+
return this.numValue() * (Math.PI / 180.0);
|
383 |
+
}
|
384 |
+
|
385 |
+
// text extensions
|
386 |
+
// get the text baseline
|
387 |
+
var textBaselineMapping = {
|
388 |
+
'baseline': 'alphabetic',
|
389 |
+
'before-edge': 'top',
|
390 |
+
'text-before-edge': 'top',
|
391 |
+
'middle': 'middle',
|
392 |
+
'central': 'middle',
|
393 |
+
'after-edge': 'bottom',
|
394 |
+
'text-after-edge': 'bottom',
|
395 |
+
'ideographic': 'ideographic',
|
396 |
+
'alphabetic': 'alphabetic',
|
397 |
+
'hanging': 'hanging',
|
398 |
+
'mathematical': 'alphabetic'
|
399 |
+
};
|
400 |
+
svg.Property.prototype.toTextBaseline = function () {
|
401 |
+
if (!this.hasValue()) return null;
|
402 |
+
return textBaselineMapping[this.value];
|
403 |
+
}
|
404 |
+
|
405 |
+
// fonts
|
406 |
+
svg.Font = new (function() {
|
407 |
+
this.Styles = 'normal|italic|oblique|inherit';
|
408 |
+
this.Variants = 'normal|small-caps|inherit';
|
409 |
+
this.Weights = 'normal|bold|bolder|lighter|100|200|300|400|500|600|700|800|900|inherit';
|
410 |
+
|
411 |
+
this.CreateFont = function(fontStyle, fontVariant, fontWeight, fontSize, fontFamily, inherit) {
|
412 |
+
var f = inherit != null ? this.Parse(inherit) : this.CreateFont('', '', '', '', '', svg.ctx.font);
|
413 |
+
return {
|
414 |
+
fontFamily: fontFamily || f.fontFamily,
|
415 |
+
fontSize: fontSize || f.fontSize,
|
416 |
+
fontStyle: fontStyle || f.fontStyle,
|
417 |
+
fontWeight: fontWeight || f.fontWeight,
|
418 |
+
fontVariant: fontVariant || f.fontVariant,
|
419 |
+
toString: function () { return [this.fontStyle, this.fontVariant, this.fontWeight, this.fontSize, this.fontFamily].join(' ') }
|
420 |
+
}
|
421 |
+
}
|
422 |
+
|
423 |
+
var that = this;
|
424 |
+
this.Parse = function(s) {
|
425 |
+
var f = {};
|
426 |
+
var d = svg.trim(svg.compressSpaces(s || '')).split(' ');
|
427 |
+
var set = { fontSize: false, fontStyle: false, fontWeight: false, fontVariant: false }
|
428 |
+
var ff = '';
|
429 |
+
for (var i=0; i<d.length; i++) {
|
430 |
+
if (!set.fontStyle && that.Styles.indexOf(d[i]) != -1) { if (d[i] != 'inherit') f.fontStyle = d[i]; set.fontStyle = true; }
|
431 |
+
else if (!set.fontVariant && that.Variants.indexOf(d[i]) != -1) { if (d[i] != 'inherit') f.fontVariant = d[i]; set.fontStyle = set.fontVariant = true; }
|
432 |
+
else if (!set.fontWeight && that.Weights.indexOf(d[i]) != -1) { if (d[i] != 'inherit') f.fontWeight = d[i]; set.fontStyle = set.fontVariant = set.fontWeight = true; }
|
433 |
+
else if (!set.fontSize) { if (d[i] != 'inherit') f.fontSize = d[i].split('/')[0]; set.fontStyle = set.fontVariant = set.fontWeight = set.fontSize = true; }
|
434 |
+
else { if (d[i] != 'inherit') ff += d[i]; }
|
435 |
+
} if (ff != '') f.fontFamily = ff;
|
436 |
+
return f;
|
437 |
+
}
|
438 |
+
});
|
439 |
+
|
440 |
+
// points and paths
|
441 |
+
svg.ToNumberArray = function(s) {
|
442 |
+
var a = svg.trim(svg.compressSpaces((s || '').replace(/,/g, ' '))).split(' ');
|
443 |
+
for (var i=0; i<a.length; i++) {
|
444 |
+
a[i] = parseFloat(a[i]);
|
445 |
+
}
|
446 |
+
return a;
|
447 |
+
}
|
448 |
+
svg.Point = function(x, y) {
|
449 |
+
this.x = x;
|
450 |
+
this.y = y;
|
451 |
+
}
|
452 |
+
svg.Point.prototype.angleTo = function(p) {
|
453 |
+
return Math.atan2(p.y - this.y, p.x - this.x);
|
454 |
+
}
|
455 |
+
|
456 |
+
svg.Point.prototype.applyTransform = function(v) {
|
457 |
+
var xp = this.x * v[0] + this.y * v[2] + v[4];
|
458 |
+
var yp = this.x * v[1] + this.y * v[3] + v[5];
|
459 |
+
this.x = xp;
|
460 |
+
this.y = yp;
|
461 |
+
}
|
462 |
+
|
463 |
+
svg.CreatePoint = function(s) {
|
464 |
+
var a = svg.ToNumberArray(s);
|
465 |
+
return new svg.Point(a[0], a[1]);
|
466 |
+
}
|
467 |
+
svg.CreatePath = function(s) {
|
468 |
+
var a = svg.ToNumberArray(s);
|
469 |
+
var path = [];
|
470 |
+
for (var i=0; i<a.length; i+=2) {
|
471 |
+
path.push(new svg.Point(a[i], a[i+1]));
|
472 |
+
}
|
473 |
+
return path;
|
474 |
+
}
|
475 |
+
|
476 |
+
// bounding box
|
477 |
+
svg.BoundingBox = function(x1, y1, x2, y2) { // pass in initial points if you want
|
478 |
+
this.x1 = Number.NaN;
|
479 |
+
this.y1 = Number.NaN;
|
480 |
+
this.x2 = Number.NaN;
|
481 |
+
this.y2 = Number.NaN;
|
482 |
+
|
483 |
+
this.x = function() { return this.x1; }
|
484 |
+
this.y = function() { return this.y1; }
|
485 |
+
this.width = function() { return this.x2 - this.x1; }
|
486 |
+
this.height = function() { return this.y2 - this.y1; }
|
487 |
+
|
488 |
+
this.addPoint = function(x, y) {
|
489 |
+
if (x != null) {
|
490 |
+
if (isNaN(this.x1) || isNaN(this.x2)) {
|
491 |
+
this.x1 = x;
|
492 |
+
this.x2 = x;
|
493 |
+
}
|
494 |
+
if (x < this.x1) this.x1 = x;
|
495 |
+
if (x > this.x2) this.x2 = x;
|
496 |
+
}
|
497 |
+
|
498 |
+
if (y != null) {
|
499 |
+
if (isNaN(this.y1) || isNaN(this.y2)) {
|
500 |
+
this.y1 = y;
|
501 |
+
this.y2 = y;
|
502 |
+
}
|
503 |
+
if (y < this.y1) this.y1 = y;
|
504 |
+
if (y > this.y2) this.y2 = y;
|
505 |
+
}
|
506 |
+
}
|
507 |
+
this.addX = function(x) { this.addPoint(x, null); }
|
508 |
+
this.addY = function(y) { this.addPoint(null, y); }
|
509 |
+
|
510 |
+
this.addBoundingBox = function(bb) {
|
511 |
+
this.addPoint(bb.x1, bb.y1);
|
512 |
+
this.addPoint(bb.x2, bb.y2);
|
513 |
+
}
|
514 |
+
|
515 |
+
this.addQuadraticCurve = function(p0x, p0y, p1x, p1y, p2x, p2y) {
|
516 |
+
var cp1x = p0x + 2/3 * (p1x - p0x); // CP1 = QP0 + 2/3 *(QP1-QP0)
|
517 |
+
var cp1y = p0y + 2/3 * (p1y - p0y); // CP1 = QP0 + 2/3 *(QP1-QP0)
|
518 |
+
var cp2x = cp1x + 1/3 * (p2x - p0x); // CP2 = CP1 + 1/3 *(QP2-QP0)
|
519 |
+
var cp2y = cp1y + 1/3 * (p2y - p0y); // CP2 = CP1 + 1/3 *(QP2-QP0)
|
520 |
+
this.addBezierCurve(p0x, p0y, cp1x, cp2x, cp1y, cp2y, p2x, p2y);
|
521 |
+
}
|
522 |
+
|
523 |
+
this.addBezierCurve = function(p0x, p0y, p1x, p1y, p2x, p2y, p3x, p3y) {
|
524 |
+
// from http://blog.hackers-cafe.net/2009/06/how-to-calculate-bezier-curves-bounding.html
|
525 |
+
var p0 = [p0x, p0y], p1 = [p1x, p1y], p2 = [p2x, p2y], p3 = [p3x, p3y];
|
526 |
+
this.addPoint(p0[0], p0[1]);
|
527 |
+
this.addPoint(p3[0], p3[1]);
|
528 |
+
|
529 |
+
for (i=0; i<=1; i++) {
|
530 |
+
var f = function(t) {
|
531 |
+
return Math.pow(1-t, 3) * p0[i]
|
532 |
+
+ 3 * Math.pow(1-t, 2) * t * p1[i]
|
533 |
+
+ 3 * (1-t) * Math.pow(t, 2) * p2[i]
|
534 |
+
+ Math.pow(t, 3) * p3[i];
|
535 |
+
}
|
536 |
+
|
537 |
+
var b = 6 * p0[i] - 12 * p1[i] + 6 * p2[i];
|
538 |
+
var a = -3 * p0[i] + 9 * p1[i] - 9 * p2[i] + 3 * p3[i];
|
539 |
+
var c = 3 * p1[i] - 3 * p0[i];
|
540 |
+
|
541 |
+
if (a == 0) {
|
542 |
+
if (b == 0) continue;
|
543 |
+
var t = -c / b;
|
544 |
+
if (0 < t && t < 1) {
|
545 |
+
if (i == 0) this.addX(f(t));
|
546 |
+
if (i == 1) this.addY(f(t));
|
547 |
+
}
|
548 |
+
continue;
|
549 |
+
}
|
550 |
+
|
551 |
+
var b2ac = Math.pow(b, 2) - 4 * c * a;
|
552 |
+
if (b2ac < 0) continue;
|
553 |
+
var t1 = (-b + Math.sqrt(b2ac)) / (2 * a);
|
554 |
+
if (0 < t1 && t1 < 1) {
|
555 |
+
if (i == 0) this.addX(f(t1));
|
556 |
+
if (i == 1) this.addY(f(t1));
|
557 |
+
}
|
558 |
+
var t2 = (-b - Math.sqrt(b2ac)) / (2 * a);
|
559 |
+
if (0 < t2 && t2 < 1) {
|
560 |
+
if (i == 0) this.addX(f(t2));
|
561 |
+
if (i == 1) this.addY(f(t2));
|
562 |
+
}
|
563 |
+
}
|
564 |
+
}
|
565 |
+
|
566 |
+
this.isPointInBox = function(x, y) {
|
567 |
+
return (this.x1 <= x && x <= this.x2 && this.y1 <= y && y <= this.y2);
|
568 |
+
}
|
569 |
+
|
570 |
+
this.addPoint(x1, y1);
|
571 |
+
this.addPoint(x2, y2);
|
572 |
+
}
|
573 |
+
|
574 |
+
// transforms
|
575 |
+
svg.Transform = function(v) {
|
576 |
+
var that = this;
|
577 |
+
this.Type = {}
|
578 |
+
|
579 |
+
// translate
|
580 |
+
this.Type.translate = function(s) {
|
581 |
+
this.p = svg.CreatePoint(s);
|
582 |
+
this.apply = function(ctx) {
|
583 |
+
ctx.translate(this.p.x || 0.0, this.p.y || 0.0);
|
584 |
+
}
|
585 |
+
this.unapply = function(ctx) {
|
586 |
+
ctx.translate(-1.0 * this.p.x || 0.0, -1.0 * this.p.y || 0.0);
|
587 |
+
}
|
588 |
+
this.applyToPoint = function(p) {
|
589 |
+
p.applyTransform([1, 0, 0, 1, this.p.x || 0.0, this.p.y || 0.0]);
|
590 |
+
}
|
591 |
+
}
|
592 |
+
|
593 |
+
// rotate
|
594 |
+
this.Type.rotate = function(s) {
|
595 |
+
var a = svg.ToNumberArray(s);
|
596 |
+
this.angle = new svg.Property('angle', a[0]);
|
597 |
+
this.cx = a[1] || 0;
|
598 |
+
this.cy = a[2] || 0;
|
599 |
+
this.apply = function(ctx) {
|
600 |
+
ctx.translate(this.cx, this.cy);
|
601 |
+
ctx.rotate(this.angle.toRadians());
|
602 |
+
ctx.translate(-this.cx, -this.cy);
|
603 |
+
}
|
604 |
+
this.unapply = function(ctx) {
|
605 |
+
ctx.translate(this.cx, this.cy);
|
606 |
+
ctx.rotate(-1.0 * this.angle.toRadians());
|
607 |
+
ctx.translate(-this.cx, -this.cy);
|
608 |
+
}
|
609 |
+
this.applyToPoint = function(p) {
|
610 |
+
var a = this.angle.toRadians();
|
611 |
+
p.applyTransform([1, 0, 0, 1, this.p.x || 0.0, this.p.y || 0.0]);
|
612 |
+
p.applyTransform([Math.cos(a), Math.sin(a), -Math.sin(a), Math.cos(a), 0, 0]);
|
613 |
+
p.applyTransform([1, 0, 0, 1, -this.p.x || 0.0, -this.p.y || 0.0]);
|
614 |
+
}
|
615 |
+
}
|
616 |
+
|
617 |
+
this.Type.scale = function(s) {
|
618 |
+
this.p = svg.CreatePoint(s);
|
619 |
+
this.apply = function(ctx) {
|
620 |
+
ctx.scale(this.p.x || 1.0, this.p.y || this.p.x || 1.0);
|
621 |
+
}
|
622 |
+
this.unapply = function(ctx) {
|
623 |
+
ctx.scale(1.0 / this.p.x || 1.0, 1.0 / this.p.y || this.p.x || 1.0);
|
624 |
+
}
|
625 |
+
this.applyToPoint = function(p) {
|
626 |
+
p.applyTransform([this.p.x || 0.0, 0, 0, this.p.y || 0.0, 0, 0]);
|
627 |
+
}
|
628 |
+
}
|
629 |
+
|
630 |
+
this.Type.matrix = function(s) {
|
631 |
+
this.m = svg.ToNumberArray(s);
|
632 |
+
this.apply = function(ctx) {
|
633 |
+
ctx.transform(this.m[0], this.m[1], this.m[2], this.m[3], this.m[4], this.m[5]);
|
634 |
+
}
|
635 |
+
this.unapply = function(ctx) {
|
636 |
+
var a = this.m[0];
|
637 |
+
var b = this.m[2];
|
638 |
+
var c = this.m[4];
|
639 |
+
var d = this.m[1];
|
640 |
+
var e = this.m[3];
|
641 |
+
var f = this.m[5];
|
642 |
+
var g = 0.0;
|
643 |
+
var h = 0.0;
|
644 |
+
var i = 1.0;
|
645 |
+
var det = 1 / (a*(e*i-f*h)-b*(d*i-f*g)+c*(d*h-e*g));
|
646 |
+
ctx.transform(
|
647 |
+
det*(e*i-f*h),
|
648 |
+
det*(f*g-d*i),
|
649 |
+
det*(c*h-b*i),
|
650 |
+
det*(a*i-c*g),
|
651 |
+
det*(b*f-c*e),
|
652 |
+
det*(c*d-a*f)
|
653 |
+
);
|
654 |
+
}
|
655 |
+
this.applyToPoint = function(p) {
|
656 |
+
p.applyTransform(this.m);
|
657 |
+
}
|
658 |
+
}
|
659 |
+
|
660 |
+
this.Type.SkewBase = function(s) {
|
661 |
+
this.base = that.Type.matrix;
|
662 |
+
this.base(s);
|
663 |
+
this.angle = new svg.Property('angle', s);
|
664 |
+
}
|
665 |
+
this.Type.SkewBase.prototype = new this.Type.matrix;
|
666 |
+
|
667 |
+
this.Type.skewX = function(s) {
|
668 |
+
this.base = that.Type.SkewBase;
|
669 |
+
this.base(s);
|
670 |
+
this.m = [1, 0, Math.tan(this.angle.toRadians()), 1, 0, 0];
|
671 |
+
}
|
672 |
+
this.Type.skewX.prototype = new this.Type.SkewBase;
|
673 |
+
|
674 |
+
this.Type.skewY = function(s) {
|
675 |
+
this.base = that.Type.SkewBase;
|
676 |
+
this.base(s);
|
677 |
+
this.m = [1, Math.tan(this.angle.toRadians()), 0, 1, 0, 0];
|
678 |
+
}
|
679 |
+
this.Type.skewY.prototype = new this.Type.SkewBase;
|
680 |
+
|
681 |
+
this.transforms = [];
|
682 |
+
|
683 |
+
this.apply = function(ctx) {
|
684 |
+
for (var i=0; i<this.transforms.length; i++) {
|
685 |
+
this.transforms[i].apply(ctx);
|
686 |
+
}
|
687 |
+
}
|
688 |
+
|
689 |
+
this.unapply = function(ctx) {
|
690 |
+
for (var i=this.transforms.length-1; i>=0; i--) {
|
691 |
+
this.transforms[i].unapply(ctx);
|
692 |
+
}
|
693 |
+
}
|
694 |
+
|
695 |
+
this.applyToPoint = function(p) {
|
696 |
+
for (var i=0; i<this.transforms.length; i++) {
|
697 |
+
this.transforms[i].applyToPoint(p);
|
698 |
+
}
|
699 |
+
}
|
700 |
+
|
701 |
+
var data = svg.trim(svg.compressSpaces(v)).replace(/\)([a-zA-Z])/g, ') $1').replace(/\)(\s?,\s?)/g,') ').split(/\s(?=[a-z])/);
|
702 |
+
for (var i=0; i<data.length; i++) {
|
703 |
+
var type = svg.trim(data[i].split('(')[0]);
|
704 |
+
var s = data[i].split('(')[1].replace(')','');
|
705 |
+
var transformType = this.Type[type];
|
706 |
+
if (typeof transformType != 'undefined') {
|
707 |
+
var transform = new transformType(s);
|
708 |
+
transform.type = type;
|
709 |
+
this.transforms.push(transform);
|
710 |
+
}
|
711 |
+
}
|
712 |
+
}
|
713 |
+
|
714 |
+
// aspect ratio
|
715 |
+
svg.AspectRatio = function(ctx, aspectRatio, width, desiredWidth, height, desiredHeight, minX, minY, refX, refY) {
|
716 |
+
// aspect ratio - http://www.w3.org/TR/SVG/coords.html#PreserveAspectRatioAttribute
|
717 |
+
aspectRatio = svg.compressSpaces(aspectRatio);
|
718 |
+
aspectRatio = aspectRatio.replace(/^defer\s/,''); // ignore defer
|
719 |
+
var align = aspectRatio.split(' ')[0] || 'xMidYMid';
|
720 |
+
var meetOrSlice = aspectRatio.split(' ')[1] || 'meet';
|
721 |
+
|
722 |
+
// calculate scale
|
723 |
+
var scaleX = width / desiredWidth;
|
724 |
+
var scaleY = height / desiredHeight;
|
725 |
+
var scaleMin = Math.min(scaleX, scaleY);
|
726 |
+
var scaleMax = Math.max(scaleX, scaleY);
|
727 |
+
if (meetOrSlice == 'meet') { desiredWidth *= scaleMin; desiredHeight *= scaleMin; }
|
728 |
+
if (meetOrSlice == 'slice') { desiredWidth *= scaleMax; desiredHeight *= scaleMax; }
|
729 |
+
|
730 |
+
refX = new svg.Property('refX', refX);
|
731 |
+
refY = new svg.Property('refY', refY);
|
732 |
+
if (refX.hasValue() && refY.hasValue()) {
|
733 |
+
ctx.translate(-scaleMin * refX.toPixels('x'), -scaleMin * refY.toPixels('y'));
|
734 |
+
}
|
735 |
+
else {
|
736 |
+
// align
|
737 |
+
if (align.match(/^xMid/) && ((meetOrSlice == 'meet' && scaleMin == scaleY) || (meetOrSlice == 'slice' && scaleMax == scaleY))) ctx.translate(width / 2.0 - desiredWidth / 2.0, 0);
|
738 |
+
if (align.match(/YMid$/) && ((meetOrSlice == 'meet' && scaleMin == scaleX) || (meetOrSlice == 'slice' && scaleMax == scaleX))) ctx.translate(0, height / 2.0 - desiredHeight / 2.0);
|
739 |
+
if (align.match(/^xMax/) && ((meetOrSlice == 'meet' && scaleMin == scaleY) || (meetOrSlice == 'slice' && scaleMax == scaleY))) ctx.translate(width - desiredWidth, 0);
|
740 |
+
if (align.match(/YMax$/) && ((meetOrSlice == 'meet' && scaleMin == scaleX) || (meetOrSlice == 'slice' && scaleMax == scaleX))) ctx.translate(0, height - desiredHeight);
|
741 |
+
}
|
742 |
+
|
743 |
+
// scale
|
744 |
+
if (align == 'none') ctx.scale(scaleX, scaleY);
|
745 |
+
else if (meetOrSlice == 'meet') ctx.scale(scaleMin, scaleMin);
|
746 |
+
else if (meetOrSlice == 'slice') ctx.scale(scaleMax, scaleMax);
|
747 |
+
|
748 |
+
// translate
|
749 |
+
ctx.translate(minX == null ? 0 : -minX, minY == null ? 0 : -minY);
|
750 |
+
}
|
751 |
+
|
752 |
+
// elements
|
753 |
+
svg.Element = {}
|
754 |
+
|
755 |
+
svg.EmptyProperty = new svg.Property('EMPTY', '');
|
756 |
+
|
757 |
+
svg.Element.ElementBase = function(node) {
|
758 |
+
this.attributes = {};
|
759 |
+
this.styles = {};
|
760 |
+
this.stylesSpecificity = {};
|
761 |
+
this.children = [];
|
762 |
+
|
763 |
+
// get or create attribute
|
764 |
+
this.attribute = function(name, createIfNotExists) {
|
765 |
+
var a = this.attributes[name];
|
766 |
+
if (a != null) return a;
|
767 |
+
|
768 |
+
if (createIfNotExists == true) { a = new svg.Property(name, ''); this.attributes[name] = a; }
|
769 |
+
return a || svg.EmptyProperty;
|
770 |
+
}
|
771 |
+
|
772 |
+
this.getHrefAttribute = function() {
|
773 |
+
for (var a in this.attributes) {
|
774 |
+
if (a == 'href' || a.match(/:href$/)) {
|
775 |
+
return this.attributes[a];
|
776 |
+
}
|
777 |
+
}
|
778 |
+
return svg.EmptyProperty;
|
779 |
+
}
|
780 |
+
|
781 |
+
// get or create style, crawls up node tree
|
782 |
+
this.style = function(name, createIfNotExists, skipAncestors) {
|
783 |
+
var s = this.styles[name];
|
784 |
+
if (s != null) return s;
|
785 |
+
|
786 |
+
var a = this.attribute(name);
|
787 |
+
if (a != null && a.hasValue()) {
|
788 |
+
this.styles[name] = a; // move up to me to cache
|
789 |
+
return a;
|
790 |
+
}
|
791 |
+
|
792 |
+
if (skipAncestors != true) {
|
793 |
+
var p = this.parent;
|
794 |
+
if (p != null) {
|
795 |
+
var ps = p.style(name);
|
796 |
+
if (ps != null && ps.hasValue()) {
|
797 |
+
return ps;
|
798 |
+
}
|
799 |
+
}
|
800 |
+
}
|
801 |
+
|
802 |
+
if (createIfNotExists == true) { s = new svg.Property(name, ''); this.styles[name] = s; }
|
803 |
+
return s || svg.EmptyProperty;
|
804 |
+
}
|
805 |
+
|
806 |
+
// base render
|
807 |
+
this.render = function(ctx) {
|
808 |
+
// don't render display=none
|
809 |
+
if (this.style('display').value == 'none') return;
|
810 |
+
|
811 |
+
// don't render visibility=hidden
|
812 |
+
if (this.style('visibility').value == 'hidden') return;
|
813 |
+
|
814 |
+
ctx.save();
|
815 |
+
if (this.style('mask').hasValue()) { // mask
|
816 |
+
var mask = this.style('mask').getDefinition();
|
817 |
+
if (mask != null) mask.apply(ctx, this);
|
818 |
+
}
|
819 |
+
else if (this.style('filter').hasValue()) { // filter
|
820 |
+
var filter = this.style('filter').getDefinition();
|
821 |
+
if (filter != null) filter.apply(ctx, this);
|
822 |
+
}
|
823 |
+
else {
|
824 |
+
this.setContext(ctx);
|
825 |
+
this.renderChildren(ctx);
|
826 |
+
this.clearContext(ctx);
|
827 |
+
}
|
828 |
+
ctx.restore();
|
829 |
+
}
|
830 |
+
|
831 |
+
// base set context
|
832 |
+
this.setContext = function(ctx) {
|
833 |
+
// OVERRIDE ME!
|
834 |
+
}
|
835 |
+
|
836 |
+
// base clear context
|
837 |
+
this.clearContext = function(ctx) {
|
838 |
+
// OVERRIDE ME!
|
839 |
+
}
|
840 |
+
|
841 |
+
// base render children
|
842 |
+
this.renderChildren = function(ctx) {
|
843 |
+
for (var i=0; i<this.children.length; i++) {
|
844 |
+
this.children[i].render(ctx);
|
845 |
+
}
|
846 |
+
}
|
847 |
+
|
848 |
+
this.addChild = function(childNode, create) {
|
849 |
+
var child = childNode;
|
850 |
+
if (create) child = svg.CreateElement(childNode);
|
851 |
+
child.parent = this;
|
852 |
+
if (child.type != 'title') { this.children.push(child); }
|
853 |
+
}
|
854 |
+
|
855 |
+
this.addStylesFromStyleDefinition = function () {
|
856 |
+
// add styles
|
857 |
+
for (var selector in svg.Styles) {
|
858 |
+
if (selector[0] != '@' && matchesSelector(node, selector)) {
|
859 |
+
var styles = svg.Styles[selector];
|
860 |
+
var specificity = svg.StylesSpecificity[selector];
|
861 |
+
if (styles != null) {
|
862 |
+
for (var name in styles) {
|
863 |
+
var existingSpecificity = this.stylesSpecificity[name];
|
864 |
+
if (typeof existingSpecificity == 'undefined') {
|
865 |
+
existingSpecificity = '000';
|
866 |
+
}
|
867 |
+
if (specificity > existingSpecificity) {
|
868 |
+
this.styles[name] = styles[name];
|
869 |
+
this.stylesSpecificity[name] = specificity;
|
870 |
+
}
|
871 |
+
}
|
872 |
+
}
|
873 |
+
}
|
874 |
+
}
|
875 |
+
};
|
876 |
+
|
877 |
+
// Microsoft Edge fix
|
878 |
+
var allUppercase = new RegExp("^[A-Z\-]+$");
|
879 |
+
var normalizeAttributeName = function (name) {
|
880 |
+
if (allUppercase.test(name)) {
|
881 |
+
return name.toLowerCase();
|
882 |
+
}
|
883 |
+
return name;
|
884 |
+
};
|
885 |
+
|
886 |
+
if (node != null && node.nodeType == 1) { //ELEMENT_NODE
|
887 |
+
// add attributes
|
888 |
+
for (var i=0; i<node.attributes.length; i++) {
|
889 |
+
var attribute = node.attributes[i];
|
890 |
+
var nodeName = normalizeAttributeName(attribute.nodeName);
|
891 |
+
this.attributes[nodeName] = new svg.Property(nodeName, attribute.value);
|
892 |
+
}
|
893 |
+
|
894 |
+
this.addStylesFromStyleDefinition();
|
895 |
+
|
896 |
+
// add inline styles
|
897 |
+
if (this.attribute('style').hasValue()) {
|
898 |
+
var styles = this.attribute('style').value.split(';');
|
899 |
+
for (var i=0; i<styles.length; i++) {
|
900 |
+
if (svg.trim(styles[i]) != '') {
|
901 |
+
var style = styles[i].split(':');
|
902 |
+
var name = svg.trim(style[0]);
|
903 |
+
var value = svg.trim(style[1]);
|
904 |
+
this.styles[name] = new svg.Property(name, value);
|
905 |
+
}
|
906 |
+
}
|
907 |
+
}
|
908 |
+
|
909 |
+
// add id
|
910 |
+
if (this.attribute('id').hasValue()) {
|
911 |
+
if (svg.Definitions[this.attribute('id').value] == null) {
|
912 |
+
svg.Definitions[this.attribute('id').value] = this;
|
913 |
+
}
|
914 |
+
}
|
915 |
+
|
916 |
+
// add children
|
917 |
+
for (var i=0; i<node.childNodes.length; i++) {
|
918 |
+
var childNode = node.childNodes[i];
|
919 |
+
if (childNode.nodeType == 1) this.addChild(childNode, true); //ELEMENT_NODE
|
920 |
+
if (this.captureTextNodes && (childNode.nodeType == 3 || childNode.nodeType == 4)) {
|
921 |
+
var text = childNode.value || childNode.text || childNode.textContent || '';
|
922 |
+
if (svg.compressSpaces(text) != '') {
|
923 |
+
this.addChild(new svg.Element.tspan(childNode), false); // TEXT_NODE
|
924 |
+
}
|
925 |
+
}
|
926 |
+
}
|
927 |
+
}
|
928 |
+
}
|
929 |
+
|
930 |
+
svg.Element.RenderedElementBase = function(node) {
|
931 |
+
this.base = svg.Element.ElementBase;
|
932 |
+
this.base(node);
|
933 |
+
|
934 |
+
this.setContext = function(ctx) {
|
935 |
+
// fill
|
936 |
+
if (this.style('fill').isUrlDefinition()) {
|
937 |
+
var fs = this.style('fill').getFillStyleDefinition(this, this.style('fill-opacity'));
|
938 |
+
if (fs != null) ctx.fillStyle = fs;
|
939 |
+
}
|
940 |
+
else if (this.style('fill').hasValue()) {
|
941 |
+
var fillStyle = this.style('fill');
|
942 |
+
if (fillStyle.value == 'currentColor') fillStyle.value = this.style('color').value;
|
943 |
+
if (fillStyle.value != 'inherit') ctx.fillStyle = (fillStyle.value == 'none' ? 'rgba(0,0,0,0)' : fillStyle.value);
|
944 |
+
}
|
945 |
+
if (this.style('fill-opacity').hasValue()) {
|
946 |
+
var fillStyle = new svg.Property('fill', ctx.fillStyle);
|
947 |
+
fillStyle = fillStyle.addOpacity(this.style('fill-opacity'));
|
948 |
+
ctx.fillStyle = fillStyle.value;
|
949 |
+
}
|
950 |
+
|
951 |
+
// stroke
|
952 |
+
if (this.style('stroke').isUrlDefinition()) {
|
953 |
+
var fs = this.style('stroke').getFillStyleDefinition(this, this.style('stroke-opacity'));
|
954 |
+
if (fs != null) ctx.strokeStyle = fs;
|
955 |
+
}
|
956 |
+
else if (this.style('stroke').hasValue()) {
|
957 |
+
var strokeStyle = this.style('stroke');
|
958 |
+
if (strokeStyle.value == 'currentColor') strokeStyle.value = this.style('color').value;
|
959 |
+
if (strokeStyle.value != 'inherit') ctx.strokeStyle = (strokeStyle.value == 'none' ? 'rgba(0,0,0,0)' : strokeStyle.value);
|
960 |
+
}
|
961 |
+
if (this.style('stroke-opacity').hasValue()) {
|
962 |
+
var strokeStyle = new svg.Property('stroke', ctx.strokeStyle);
|
963 |
+
strokeStyle = strokeStyle.addOpacity(this.style('stroke-opacity'));
|
964 |
+
ctx.strokeStyle = strokeStyle.value;
|
965 |
+
}
|
966 |
+
if (this.style('stroke-width').hasValue()) {
|
967 |
+
var newLineWidth = this.style('stroke-width').toPixels();
|
968 |
+
ctx.lineWidth = newLineWidth == 0 ? 0.001 : newLineWidth; // browsers don't respect 0
|
969 |
+
}
|
970 |
+
if (this.style('stroke-linecap').hasValue()) ctx.lineCap = this.style('stroke-linecap').value;
|
971 |
+
if (this.style('stroke-linejoin').hasValue()) ctx.lineJoin = this.style('stroke-linejoin').value;
|
972 |
+
if (this.style('stroke-miterlimit').hasValue()) ctx.miterLimit = this.style('stroke-miterlimit').value;
|
973 |
+
if (this.style('stroke-dasharray').hasValue() && this.style('stroke-dasharray').value != 'none') {
|
974 |
+
var gaps = svg.ToNumberArray(this.style('stroke-dasharray').value);
|
975 |
+
if (typeof ctx.setLineDash != 'undefined') { ctx.setLineDash(gaps); }
|
976 |
+
else if (typeof ctx.webkitLineDash != 'undefined') { ctx.webkitLineDash = gaps; }
|
977 |
+
else if (typeof ctx.mozDash != 'undefined' && !(gaps.length==1 && gaps[0]==0)) { ctx.mozDash = gaps; }
|
978 |
+
|
979 |
+
var offset = this.style('stroke-dashoffset').numValueOrDefault(1);
|
980 |
+
if (typeof ctx.lineDashOffset != 'undefined') { ctx.lineDashOffset = offset; }
|
981 |
+
else if (typeof ctx.webkitLineDashOffset != 'undefined') { ctx.webkitLineDashOffset = offset; }
|
982 |
+
else if (typeof ctx.mozDashOffset != 'undefined') { ctx.mozDashOffset = offset; }
|
983 |
+
}
|
984 |
+
|
985 |
+
// font
|
986 |
+
if (typeof ctx.font != 'undefined') {
|
987 |
+
ctx.font = svg.Font.CreateFont(
|
988 |
+
this.style('font-style').value,
|
989 |
+
this.style('font-variant').value,
|
990 |
+
this.style('font-weight').value,
|
991 |
+
this.style('font-size').hasValue() ? this.style('font-size').toPixels() + 'px' : '',
|
992 |
+
this.style('font-family').value).toString();
|
993 |
+
}
|
994 |
+
|
995 |
+
// transform
|
996 |
+
if (this.style('transform', false, true).hasValue()) {
|
997 |
+
var transform = new svg.Transform(this.style('transform', false, true).value);
|
998 |
+
transform.apply(ctx);
|
999 |
+
}
|
1000 |
+
|
1001 |
+
// clip
|
1002 |
+
if (this.style('clip-path', false, true).hasValue()) {
|
1003 |
+
var clip = this.style('clip-path', false, true).getDefinition();
|
1004 |
+
if (clip != null) clip.apply(ctx);
|
1005 |
+
}
|
1006 |
+
|
1007 |
+
// opacity
|
1008 |
+
if (this.style('opacity').hasValue()) {
|
1009 |
+
ctx.globalAlpha = this.style('opacity').numValue();
|
1010 |
+
}
|
1011 |
+
}
|
1012 |
+
}
|
1013 |
+
svg.Element.RenderedElementBase.prototype = new svg.Element.ElementBase;
|
1014 |
+
|
1015 |
+
svg.Element.PathElementBase = function(node) {
|
1016 |
+
this.base = svg.Element.RenderedElementBase;
|
1017 |
+
this.base(node);
|
1018 |
+
|
1019 |
+
this.path = function(ctx) {
|
1020 |
+
if (ctx != null) ctx.beginPath();
|
1021 |
+
return new svg.BoundingBox();
|
1022 |
+
}
|
1023 |
+
|
1024 |
+
this.renderChildren = function(ctx) {
|
1025 |
+
this.path(ctx);
|
1026 |
+
svg.Mouse.checkPath(this, ctx);
|
1027 |
+
if (ctx.fillStyle != '') {
|
1028 |
+
if (this.style('fill-rule').valueOrDefault('inherit') != 'inherit') { ctx.fill(this.style('fill-rule').value); }
|
1029 |
+
else { ctx.fill(); }
|
1030 |
+
}
|
1031 |
+
if (ctx.strokeStyle != '') ctx.stroke();
|
1032 |
+
|
1033 |
+
var markers = this.getMarkers();
|
1034 |
+
if (markers != null) {
|
1035 |
+
if (this.style('marker-start').isUrlDefinition()) {
|
1036 |
+
var marker = this.style('marker-start').getDefinition();
|
1037 |
+
marker.render(ctx, markers[0][0], markers[0][1]);
|
1038 |
+
}
|
1039 |
+
if (this.style('marker-mid').isUrlDefinition()) {
|
1040 |
+
var marker = this.style('marker-mid').getDefinition();
|
1041 |
+
for (var i=1;i<markers.length-1;i++) {
|
1042 |
+
marker.render(ctx, markers[i][0], markers[i][1]);
|
1043 |
+
}
|
1044 |
+
}
|
1045 |
+
if (this.style('marker-end').isUrlDefinition()) {
|
1046 |
+
var marker = this.style('marker-end').getDefinition();
|
1047 |
+
marker.render(ctx, markers[markers.length-1][0], markers[markers.length-1][1]);
|
1048 |
+
}
|
1049 |
+
}
|
1050 |
+
}
|
1051 |
+
|
1052 |
+
this.getBoundingBox = function() {
|
1053 |
+
return this.path();
|
1054 |
+
}
|
1055 |
+
|
1056 |
+
this.getMarkers = function() {
|
1057 |
+
return null;
|
1058 |
+
}
|
1059 |
+
}
|
1060 |
+
svg.Element.PathElementBase.prototype = new svg.Element.RenderedElementBase;
|
1061 |
+
|
1062 |
+
// svg element
|
1063 |
+
svg.Element.svg = function(node) {
|
1064 |
+
this.base = svg.Element.RenderedElementBase;
|
1065 |
+
this.base(node);
|
1066 |
+
|
1067 |
+
this.baseClearContext = this.clearContext;
|
1068 |
+
this.clearContext = function(ctx) {
|
1069 |
+
this.baseClearContext(ctx);
|
1070 |
+
svg.ViewPort.RemoveCurrent();
|
1071 |
+
}
|
1072 |
+
|
1073 |
+
this.baseSetContext = this.setContext;
|
1074 |
+
this.setContext = function(ctx) {
|
1075 |
+
// initial values and defaults
|
1076 |
+
ctx.strokeStyle = 'rgba(0,0,0,0)';
|
1077 |
+
ctx.lineCap = 'butt';
|
1078 |
+
ctx.lineJoin = 'miter';
|
1079 |
+
ctx.miterLimit = 4;
|
1080 |
+
if (typeof ctx.font != 'undefined' && typeof window.getComputedStyle != 'undefined') {
|
1081 |
+
ctx.font = window.getComputedStyle(ctx.canvas).getPropertyValue('font');
|
1082 |
+
}
|
1083 |
+
|
1084 |
+
this.baseSetContext(ctx);
|
1085 |
+
|
1086 |
+
// create new view port
|
1087 |
+
if (!this.attribute('x').hasValue()) this.attribute('x', true).value = 0;
|
1088 |
+
if (!this.attribute('y').hasValue()) this.attribute('y', true).value = 0;
|
1089 |
+
ctx.translate(this.attribute('x').toPixels('x'), this.attribute('y').toPixels('y'));
|
1090 |
+
|
1091 |
+
var width = svg.ViewPort.width();
|
1092 |
+
var height = svg.ViewPort.height();
|
1093 |
+
|
1094 |
+
if (!this.attribute('width').hasValue()) this.attribute('width', true).value = '100%';
|
1095 |
+
if (!this.attribute('height').hasValue()) this.attribute('height', true).value = '100%';
|
1096 |
+
if (typeof this.root == 'undefined') {
|
1097 |
+
width = this.attribute('width').toPixels('x');
|
1098 |
+
height = this.attribute('height').toPixels('y');
|
1099 |
+
|
1100 |
+
var x = 0;
|
1101 |
+
var y = 0;
|
1102 |
+
if (this.attribute('refX').hasValue() && this.attribute('refY').hasValue()) {
|
1103 |
+
x = -this.attribute('refX').toPixels('x');
|
1104 |
+
y = -this.attribute('refY').toPixels('y');
|
1105 |
+
}
|
1106 |
+
|
1107 |
+
if (this.attribute('overflow').valueOrDefault('hidden') != 'visible') {
|
1108 |
+
ctx.beginPath();
|
1109 |
+
ctx.moveTo(x, y);
|
1110 |
+
ctx.lineTo(width, y);
|
1111 |
+
ctx.lineTo(width, height);
|
1112 |
+
ctx.lineTo(x, height);
|
1113 |
+
ctx.closePath();
|
1114 |
+
ctx.clip();
|
1115 |
+
}
|
1116 |
+
}
|
1117 |
+
svg.ViewPort.SetCurrent(width, height);
|
1118 |
+
|
1119 |
+
// viewbox
|
1120 |
+
if (this.attribute('viewBox').hasValue()) {
|
1121 |
+
var viewBox = svg.ToNumberArray(this.attribute('viewBox').value);
|
1122 |
+
var minX = viewBox[0];
|
1123 |
+
var minY = viewBox[1];
|
1124 |
+
width = viewBox[2];
|
1125 |
+
height = viewBox[3];
|
1126 |
+
|
1127 |
+
svg.AspectRatio(ctx,
|
1128 |
+
this.attribute('preserveAspectRatio').value,
|
1129 |
+
svg.ViewPort.width(),
|
1130 |
+
width,
|
1131 |
+
svg.ViewPort.height(),
|
1132 |
+
height,
|
1133 |
+
minX,
|
1134 |
+
minY,
|
1135 |
+
this.attribute('refX').value,
|
1136 |
+
this.attribute('refY').value);
|
1137 |
+
|
1138 |
+
svg.ViewPort.RemoveCurrent();
|
1139 |
+
svg.ViewPort.SetCurrent(viewBox[2], viewBox[3]);
|
1140 |
+
}
|
1141 |
+
}
|
1142 |
+
}
|
1143 |
+
svg.Element.svg.prototype = new svg.Element.RenderedElementBase;
|
1144 |
+
|
1145 |
+
// rect element
|
1146 |
+
svg.Element.rect = function(node) {
|
1147 |
+
this.base = svg.Element.PathElementBase;
|
1148 |
+
this.base(node);
|
1149 |
+
|
1150 |
+
this.path = function(ctx) {
|
1151 |
+
var x = this.attribute('x').toPixels('x');
|
1152 |
+
var y = this.attribute('y').toPixels('y');
|
1153 |
+
var width = this.attribute('width').toPixels('x');
|
1154 |
+
var height = this.attribute('height').toPixels('y');
|
1155 |
+
var rx = this.attribute('rx').toPixels('x');
|
1156 |
+
var ry = this.attribute('ry').toPixels('y');
|
1157 |
+
if (this.attribute('rx').hasValue() && !this.attribute('ry').hasValue()) ry = rx;
|
1158 |
+
if (this.attribute('ry').hasValue() && !this.attribute('rx').hasValue()) rx = ry;
|
1159 |
+
rx = Math.min(rx, width / 2.0);
|
1160 |
+
ry = Math.min(ry, height / 2.0);
|
1161 |
+
if (ctx != null) {
|
1162 |
+
ctx.beginPath();
|
1163 |
+
ctx.moveTo(x + rx, y);
|
1164 |
+
ctx.lineTo(x + width - rx, y);
|
1165 |
+
ctx.quadraticCurveTo(x + width, y, x + width, y + ry)
|
1166 |
+
ctx.lineTo(x + width, y + height - ry);
|
1167 |
+
ctx.quadraticCurveTo(x + width, y + height, x + width - rx, y + height)
|
1168 |
+
ctx.lineTo(x + rx, y + height);
|
1169 |
+
ctx.quadraticCurveTo(x, y + height, x, y + height - ry)
|
1170 |
+
ctx.lineTo(x, y + ry);
|
1171 |
+
ctx.quadraticCurveTo(x, y, x + rx, y)
|
1172 |
+
ctx.closePath();
|
1173 |
+
}
|
1174 |
+
|
1175 |
+
return new svg.BoundingBox(x, y, x + width, y + height);
|
1176 |
+
}
|
1177 |
+
}
|
1178 |
+
svg.Element.rect.prototype = new svg.Element.PathElementBase;
|
1179 |
+
|
1180 |
+
// circle element
|
1181 |
+
svg.Element.circle = function(node) {
|
1182 |
+
this.base = svg.Element.PathElementBase;
|
1183 |
+
this.base(node);
|
1184 |
+
|
1185 |
+
this.path = function(ctx) {
|
1186 |
+
var cx = this.attribute('cx').toPixels('x');
|
1187 |
+
var cy = this.attribute('cy').toPixels('y');
|
1188 |
+
var r = this.attribute('r').toPixels();
|
1189 |
+
|
1190 |
+
if (ctx != null) {
|
1191 |
+
ctx.beginPath();
|
1192 |
+
ctx.arc(cx, cy, r, 0, Math.PI * 2, true);
|
1193 |
+
ctx.closePath();
|
1194 |
+
}
|
1195 |
+
|
1196 |
+
return new svg.BoundingBox(cx - r, cy - r, cx + r, cy + r);
|
1197 |
+
}
|
1198 |
+
}
|
1199 |
+
svg.Element.circle.prototype = new svg.Element.PathElementBase;
|
1200 |
+
|
1201 |
+
// ellipse element
|
1202 |
+
svg.Element.ellipse = function(node) {
|
1203 |
+
this.base = svg.Element.PathElementBase;
|
1204 |
+
this.base(node);
|
1205 |
+
|
1206 |
+
this.path = function(ctx) {
|
1207 |
+
var KAPPA = 4 * ((Math.sqrt(2) - 1) / 3);
|
1208 |
+
var rx = this.attribute('rx').toPixels('x');
|
1209 |
+
var ry = this.attribute('ry').toPixels('y');
|
1210 |
+
var cx = this.attribute('cx').toPixels('x');
|
1211 |
+
var cy = this.attribute('cy').toPixels('y');
|
1212 |
+
|
1213 |
+
if (ctx != null) {
|
1214 |
+
ctx.beginPath();
|
1215 |
+
ctx.moveTo(cx, cy - ry);
|
1216 |
+
ctx.bezierCurveTo(cx + (KAPPA * rx), cy - ry, cx + rx, cy - (KAPPA * ry), cx + rx, cy);
|
1217 |
+
ctx.bezierCurveTo(cx + rx, cy + (KAPPA * ry), cx + (KAPPA * rx), cy + ry, cx, cy + ry);
|
1218 |
+
ctx.bezierCurveTo(cx - (KAPPA * rx), cy + ry, cx - rx, cy + (KAPPA * ry), cx - rx, cy);
|
1219 |
+
ctx.bezierCurveTo(cx - rx, cy - (KAPPA * ry), cx - (KAPPA * rx), cy - ry, cx, cy - ry);
|
1220 |
+
ctx.closePath();
|
1221 |
+
}
|
1222 |
+
|
1223 |
+
return new svg.BoundingBox(cx - rx, cy - ry, cx + rx, cy + ry);
|
1224 |
+
}
|
1225 |
+
}
|
1226 |
+
svg.Element.ellipse.prototype = new svg.Element.PathElementBase;
|
1227 |
+
|
1228 |
+
// line element
|
1229 |
+
svg.Element.line = function(node) {
|
1230 |
+
this.base = svg.Element.PathElementBase;
|
1231 |
+
this.base(node);
|
1232 |
+
|
1233 |
+
this.getPoints = function() {
|
1234 |
+
return [
|
1235 |
+
new svg.Point(this.attribute('x1').toPixels('x'), this.attribute('y1').toPixels('y')),
|
1236 |
+
new svg.Point(this.attribute('x2').toPixels('x'), this.attribute('y2').toPixels('y'))];
|
1237 |
+
}
|
1238 |
+
|
1239 |
+
this.path = function(ctx) {
|
1240 |
+
var points = this.getPoints();
|
1241 |
+
|
1242 |
+
if (ctx != null) {
|
1243 |
+
ctx.beginPath();
|
1244 |
+
ctx.moveTo(points[0].x, points[0].y);
|
1245 |
+
ctx.lineTo(points[1].x, points[1].y);
|
1246 |
+
}
|
1247 |
+
|
1248 |
+
return new svg.BoundingBox(points[0].x, points[0].y, points[1].x, points[1].y);
|
1249 |
+
}
|
1250 |
+
|
1251 |
+
this.getMarkers = function() {
|
1252 |
+
var points = this.getPoints();
|
1253 |
+
var a = points[0].angleTo(points[1]);
|
1254 |
+
return [[points[0], a], [points[1], a]];
|
1255 |
+
}
|
1256 |
+
}
|
1257 |
+
svg.Element.line.prototype = new svg.Element.PathElementBase;
|
1258 |
+
|
1259 |
+
// polyline element
|
1260 |
+
svg.Element.polyline = function(node) {
|
1261 |
+
this.base = svg.Element.PathElementBase;
|
1262 |
+
this.base(node);
|
1263 |
+
|
1264 |
+
this.points = svg.CreatePath(this.attribute('points').value);
|
1265 |
+
this.path = function(ctx) {
|
1266 |
+
var bb = new svg.BoundingBox(this.points[0].x, this.points[0].y);
|
1267 |
+
if (ctx != null) {
|
1268 |
+
ctx.beginPath();
|
1269 |
+
ctx.moveTo(this.points[0].x, this.points[0].y);
|
1270 |
+
}
|
1271 |
+
for (var i=1; i<this.points.length; i++) {
|
1272 |
+
bb.addPoint(this.points[i].x, this.points[i].y);
|
1273 |
+
if (ctx != null) ctx.lineTo(this.points[i].x, this.points[i].y);
|
1274 |
+
}
|
1275 |
+
return bb;
|
1276 |
+
}
|
1277 |
+
|
1278 |
+
this.getMarkers = function() {
|
1279 |
+
var markers = [];
|
1280 |
+
for (var i=0; i<this.points.length - 1; i++) {
|
1281 |
+
markers.push([this.points[i], this.points[i].angleTo(this.points[i+1])]);
|
1282 |
+
}
|
1283 |
+
if (markers.length > 0) {
|
1284 |
+
markers.push([this.points[this.points.length-1], markers[markers.length-1][1]]);
|
1285 |
+
}
|
1286 |
+
return markers;
|
1287 |
+
}
|
1288 |
+
}
|
1289 |
+
svg.Element.polyline.prototype = new svg.Element.PathElementBase;
|
1290 |
+
|
1291 |
+
// polygon element
|
1292 |
+
svg.Element.polygon = function(node) {
|
1293 |
+
this.base = svg.Element.polyline;
|
1294 |
+
this.base(node);
|
1295 |
+
|
1296 |
+
this.basePath = this.path;
|
1297 |
+
this.path = function(ctx) {
|
1298 |
+
var bb = this.basePath(ctx);
|
1299 |
+
if (ctx != null) {
|
1300 |
+
ctx.lineTo(this.points[0].x, this.points[0].y);
|
1301 |
+
ctx.closePath();
|
1302 |
+
}
|
1303 |
+
return bb;
|
1304 |
+
}
|
1305 |
+
}
|
1306 |
+
svg.Element.polygon.prototype = new svg.Element.polyline;
|
1307 |
+
|
1308 |
+
// path element
|
1309 |
+
svg.Element.path = function(node) {
|
1310 |
+
this.base = svg.Element.PathElementBase;
|
1311 |
+
this.base(node);
|
1312 |
+
|
1313 |
+
var d = this.attribute('d').value;
|
1314 |
+
// TODO: convert to real lexer based on http://www.w3.org/TR/SVG11/paths.html#PathDataBNF
|
1315 |
+
d = d.replace(/,/gm,' '); // get rid of all commas
|
1316 |
+
// As the end of a match can also be the start of the next match, we need to run this replace twice.
|
1317 |
+
for(var i=0; i<2; i++)
|
1318 |
+
d = d.replace(/([MmZzLlHhVvCcSsQqTtAa])([^\s])/gm,'$1 $2'); // suffix commands with spaces
|
1319 |
+
d = d.replace(/([^\s])([MmZzLlHhVvCcSsQqTtAa])/gm,'$1 $2'); // prefix commands with spaces
|
1320 |
+
d = d.replace(/([0-9])([+\-])/gm,'$1 $2'); // separate digits on +- signs
|
1321 |
+
// Again, we need to run this twice to find all occurances
|
1322 |
+
for(var i=0; i<2; i++)
|
1323 |
+
d = d.replace(/(\.[0-9]*)(\.)/gm,'$1 $2'); // separate digits when they start with a comma
|
1324 |
+
d = d.replace(/([Aa](\s+[0-9]+){3})\s+([01])\s*([01])/gm,'$1 $3 $4 '); // shorthand elliptical arc path syntax
|
1325 |
+
d = svg.compressSpaces(d); // compress multiple spaces
|
1326 |
+
d = svg.trim(d);
|
1327 |
+
this.PathParser = new (function(d) {
|
1328 |
+
this.tokens = d.split(' ');
|
1329 |
+
|
1330 |
+
this.reset = function() {
|
1331 |
+
this.i = -1;
|
1332 |
+
this.command = '';
|
1333 |
+
this.previousCommand = '';
|
1334 |
+
this.start = new svg.Point(0, 0);
|
1335 |
+
this.control = new svg.Point(0, 0);
|
1336 |
+
this.current = new svg.Point(0, 0);
|
1337 |
+
this.points = [];
|
1338 |
+
this.angles = [];
|
1339 |
+
}
|
1340 |
+
|
1341 |
+
this.isEnd = function() {
|
1342 |
+
return this.i >= this.tokens.length - 1;
|
1343 |
+
}
|
1344 |
+
|
1345 |
+
this.isCommandOrEnd = function() {
|
1346 |
+
if (this.isEnd()) return true;
|
1347 |
+
return this.tokens[this.i + 1].match(/^[A-Za-z]$/) != null;
|
1348 |
+
}
|
1349 |
+
|
1350 |
+
this.isRelativeCommand = function() {
|
1351 |
+
switch(this.command)
|
1352 |
+
{
|
1353 |
+
case 'm':
|
1354 |
+
case 'l':
|
1355 |
+
case 'h':
|
1356 |
+
case 'v':
|
1357 |
+
case 'c':
|
1358 |
+
case 's':
|
1359 |
+
case 'q':
|
1360 |
+
case 't':
|
1361 |
+
case 'a':
|
1362 |
+
case 'z':
|
1363 |
+
return true;
|
1364 |
+
break;
|
1365 |
+
}
|
1366 |
+
return false;
|
1367 |
+
}
|
1368 |
+
|
1369 |
+
this.getToken = function() {
|
1370 |
+
this.i++;
|
1371 |
+
return this.tokens[this.i];
|
1372 |
+
}
|
1373 |
+
|
1374 |
+
this.getScalar = function() {
|
1375 |
+
return parseFloat(this.getToken());
|
1376 |
+
}
|
1377 |
+
|
1378 |
+
this.nextCommand = function() {
|
1379 |
+
this.previousCommand = this.command;
|
1380 |
+
this.command = this.getToken();
|
1381 |
+
}
|
1382 |
+
|
1383 |
+
this.getPoint = function() {
|
1384 |
+
var p = new svg.Point(this.getScalar(), this.getScalar());
|
1385 |
+
return this.makeAbsolute(p);
|
1386 |
+
}
|
1387 |
+
|
1388 |
+
this.getAsControlPoint = function() {
|
1389 |
+
var p = this.getPoint();
|
1390 |
+
this.control = p;
|
1391 |
+
return p;
|
1392 |
+
}
|
1393 |
+
|
1394 |
+
this.getAsCurrentPoint = function() {
|
1395 |
+
var p = this.getPoint();
|
1396 |
+
this.current = p;
|
1397 |
+
return p;
|
1398 |
+
}
|
1399 |
+
|
1400 |
+
this.getReflectedControlPoint = function() {
|
1401 |
+
if (this.previousCommand.toLowerCase() != 'c' &&
|
1402 |
+
this.previousCommand.toLowerCase() != 's' &&
|
1403 |
+
this.previousCommand.toLowerCase() != 'q' &&
|
1404 |
+
this.previousCommand.toLowerCase() != 't' ){
|
1405 |
+
return this.current;
|
1406 |
+
}
|
1407 |
+
|
1408 |
+
// reflect point
|
1409 |
+
var p = new svg.Point(2 * this.current.x - this.control.x, 2 * this.current.y - this.control.y);
|
1410 |
+
return p;
|
1411 |
+
}
|
1412 |
+
|
1413 |
+
this.makeAbsolute = function(p) {
|
1414 |
+
if (this.isRelativeCommand()) {
|
1415 |
+
p.x += this.current.x;
|
1416 |
+
p.y += this.current.y;
|
1417 |
+
}
|
1418 |
+
return p;
|
1419 |
+
}
|
1420 |
+
|
1421 |
+
this.addMarker = function(p, from, priorTo) {
|
1422 |
+
// if the last angle isn't filled in because we didn't have this point yet ...
|
1423 |
+
if (priorTo != null && this.angles.length > 0 && this.angles[this.angles.length-1] == null) {
|
1424 |
+
this.angles[this.angles.length-1] = this.points[this.points.length-1].angleTo(priorTo);
|
1425 |
+
}
|
1426 |
+
this.addMarkerAngle(p, from == null ? null : from.angleTo(p));
|
1427 |
+
}
|
1428 |
+
|
1429 |
+
this.addMarkerAngle = function(p, a) {
|
1430 |
+
this.points.push(p);
|
1431 |
+
this.angles.push(a);
|
1432 |
+
}
|
1433 |
+
|
1434 |
+
this.getMarkerPoints = function() { return this.points; }
|
1435 |
+
this.getMarkerAngles = function() {
|
1436 |
+
for (var i=0; i<this.angles.length; i++) {
|
1437 |
+
if (this.angles[i] == null) {
|
1438 |
+
for (var j=i+1; j<this.angles.length; j++) {
|
1439 |
+
if (this.angles[j] != null) {
|
1440 |
+
this.angles[i] = this.angles[j];
|
1441 |
+
break;
|
1442 |
+
}
|
1443 |
+
}
|
1444 |
+
}
|
1445 |
+
}
|
1446 |
+
return this.angles;
|
1447 |
+
}
|
1448 |
+
})(d);
|
1449 |
+
|
1450 |
+
this.path = function(ctx) {
|
1451 |
+
var pp = this.PathParser;
|
1452 |
+
pp.reset();
|
1453 |
+
|
1454 |
+
var bb = new svg.BoundingBox();
|
1455 |
+
if (ctx != null) ctx.beginPath();
|
1456 |
+
while (!pp.isEnd()) {
|
1457 |
+
pp.nextCommand();
|
1458 |
+
switch (pp.command) {
|
1459 |
+
case 'M':
|
1460 |
+
case 'm':
|
1461 |
+
var p = pp.getAsCurrentPoint();
|
1462 |
+
pp.addMarker(p);
|
1463 |
+
bb.addPoint(p.x, p.y);
|
1464 |
+
if (ctx != null) ctx.moveTo(p.x, p.y);
|
1465 |
+
pp.start = pp.current;
|
1466 |
+
while (!pp.isCommandOrEnd()) {
|
1467 |
+
var p = pp.getAsCurrentPoint();
|
1468 |
+
pp.addMarker(p, pp.start);
|
1469 |
+
bb.addPoint(p.x, p.y);
|
1470 |
+
if (ctx != null) ctx.lineTo(p.x, p.y);
|
1471 |
+
}
|
1472 |
+
break;
|
1473 |
+
case 'L':
|
1474 |
+
case 'l':
|
1475 |
+
while (!pp.isCommandOrEnd()) {
|
1476 |
+
var c = pp.current;
|
1477 |
+
var p = pp.getAsCurrentPoint();
|
1478 |
+
pp.addMarker(p, c);
|
1479 |
+
bb.addPoint(p.x, p.y);
|
1480 |
+
if (ctx != null) ctx.lineTo(p.x, p.y);
|
1481 |
+
}
|
1482 |
+
break;
|
1483 |
+
case 'H':
|
1484 |
+
case 'h':
|
1485 |
+
while (!pp.isCommandOrEnd()) {
|
1486 |
+
var newP = new svg.Point((pp.isRelativeCommand() ? pp.current.x : 0) + pp.getScalar(), pp.current.y);
|
1487 |
+
pp.addMarker(newP, pp.current);
|
1488 |
+
pp.current = newP;
|
1489 |
+
bb.addPoint(pp.current.x, pp.current.y);
|
1490 |
+
if (ctx != null) ctx.lineTo(pp.current.x, pp.current.y);
|
1491 |
+
}
|
1492 |
+
break;
|
1493 |
+
case 'V':
|
1494 |
+
case 'v':
|
1495 |
+
while (!pp.isCommandOrEnd()) {
|
1496 |
+
var newP = new svg.Point(pp.current.x, (pp.isRelativeCommand() ? pp.current.y : 0) + pp.getScalar());
|
1497 |
+
pp.addMarker(newP, pp.current);
|
1498 |
+
pp.current = newP;
|
1499 |
+
bb.addPoint(pp.current.x, pp.current.y);
|
1500 |
+
if (ctx != null) ctx.lineTo(pp.current.x, pp.current.y);
|
1501 |
+
}
|
1502 |
+
break;
|
1503 |
+
case 'C':
|
1504 |
+
case 'c':
|
1505 |
+
while (!pp.isCommandOrEnd()) {
|
1506 |
+
var curr = pp.current;
|
1507 |
+
var p1 = pp.getPoint();
|
1508 |
+
var cntrl = pp.getAsControlPoint();
|
1509 |
+
var cp = pp.getAsCurrentPoint();
|
1510 |
+
pp.addMarker(cp, cntrl, p1);
|
1511 |
+
bb.addBezierCurve(curr.x, curr.y, p1.x, p1.y, cntrl.x, cntrl.y, cp.x, cp.y);
|
1512 |
+
if (ctx != null) ctx.bezierCurveTo(p1.x, p1.y, cntrl.x, cntrl.y, cp.x, cp.y);
|
1513 |
+
}
|
1514 |
+
break;
|
1515 |
+
case 'S':
|
1516 |
+
case 's':
|
1517 |
+
while (!pp.isCommandOrEnd()) {
|
1518 |
+
var curr = pp.current;
|
1519 |
+
var p1 = pp.getReflectedControlPoint();
|
1520 |
+
var cntrl = pp.getAsControlPoint();
|
1521 |
+
var cp = pp.getAsCurrentPoint();
|
1522 |
+
pp.addMarker(cp, cntrl, p1);
|
1523 |
+
bb.addBezierCurve(curr.x, curr.y, p1.x, p1.y, cntrl.x, cntrl.y, cp.x, cp.y);
|
1524 |
+
if (ctx != null) ctx.bezierCurveTo(p1.x, p1.y, cntrl.x, cntrl.y, cp.x, cp.y);
|
1525 |
+
}
|
1526 |
+
break;
|
1527 |
+
case 'Q':
|
1528 |
+
case 'q':
|
1529 |
+
while (!pp.isCommandOrEnd()) {
|
1530 |
+
var curr = pp.current;
|
1531 |
+
var cntrl = pp.getAsControlPoint();
|
1532 |
+
var cp = pp.getAsCurrentPoint();
|
1533 |
+
pp.addMarker(cp, cntrl, cntrl);
|
1534 |
+
bb.addQuadraticCurve(curr.x, curr.y, cntrl.x, cntrl.y, cp.x, cp.y);
|
1535 |
+
if (ctx != null) ctx.quadraticCurveTo(cntrl.x, cntrl.y, cp.x, cp.y);
|
1536 |
+
}
|
1537 |
+
break;
|
1538 |
+
case 'T':
|
1539 |
+
case 't':
|
1540 |
+
while (!pp.isCommandOrEnd()) {
|
1541 |
+
var curr = pp.current;
|
1542 |
+
var cntrl = pp.getReflectedControlPoint();
|
1543 |
+
pp.control = cntrl;
|
1544 |
+
var cp = pp.getAsCurrentPoint();
|
1545 |
+
pp.addMarker(cp, cntrl, cntrl);
|
1546 |
+
bb.addQuadraticCurve(curr.x, curr.y, cntrl.x, cntrl.y, cp.x, cp.y);
|
1547 |
+
if (ctx != null) ctx.quadraticCurveTo(cntrl.x, cntrl.y, cp.x, cp.y);
|
1548 |
+
}
|
1549 |
+
break;
|
1550 |
+
case 'A':
|
1551 |
+
case 'a':
|
1552 |
+
while (!pp.isCommandOrEnd()) {
|
1553 |
+
var curr = pp.current;
|
1554 |
+
var rx = pp.getScalar();
|
1555 |
+
var ry = pp.getScalar();
|
1556 |
+
var xAxisRotation = pp.getScalar() * (Math.PI / 180.0);
|
1557 |
+
var largeArcFlag = pp.getScalar();
|
1558 |
+
var sweepFlag = pp.getScalar();
|
1559 |
+
var cp = pp.getAsCurrentPoint();
|
1560 |
+
|
1561 |
+
// Conversion from endpoint to center parameterization
|
1562 |
+
// http://www.w3.org/TR/SVG11/implnote.html#ArcImplementationNotes
|
1563 |
+
// x1', y1'
|
1564 |
+
var currp = new svg.Point(
|
1565 |
+
Math.cos(xAxisRotation) * (curr.x - cp.x) / 2.0 + Math.sin(xAxisRotation) * (curr.y - cp.y) / 2.0,
|
1566 |
+
-Math.sin(xAxisRotation) * (curr.x - cp.x) / 2.0 + Math.cos(xAxisRotation) * (curr.y - cp.y) / 2.0
|
1567 |
+
);
|
1568 |
+
// adjust radii
|
1569 |
+
var l = Math.pow(currp.x,2)/Math.pow(rx,2)+Math.pow(currp.y,2)/Math.pow(ry,2);
|
1570 |
+
if (l > 1) {
|
1571 |
+
rx *= Math.sqrt(l);
|
1572 |
+
ry *= Math.sqrt(l);
|
1573 |
+
}
|
1574 |
+
// cx', cy'
|
1575 |
+
var s = (largeArcFlag == sweepFlag ? -1 : 1) * Math.sqrt(
|
1576 |
+
((Math.pow(rx,2)*Math.pow(ry,2))-(Math.pow(rx,2)*Math.pow(currp.y,2))-(Math.pow(ry,2)*Math.pow(currp.x,2))) /
|
1577 |
+
(Math.pow(rx,2)*Math.pow(currp.y,2)+Math.pow(ry,2)*Math.pow(currp.x,2))
|
1578 |
+
);
|
1579 |
+
if (isNaN(s)) s = 0;
|
1580 |
+
var cpp = new svg.Point(s * rx * currp.y / ry, s * -ry * currp.x / rx);
|
1581 |
+
// cx, cy
|
1582 |
+
var centp = new svg.Point(
|
1583 |
+
(curr.x + cp.x) / 2.0 + Math.cos(xAxisRotation) * cpp.x - Math.sin(xAxisRotation) * cpp.y,
|
1584 |
+
(curr.y + cp.y) / 2.0 + Math.sin(xAxisRotation) * cpp.x + Math.cos(xAxisRotation) * cpp.y
|
1585 |
+
);
|
1586 |
+
// vector magnitude
|
1587 |
+
var m = function(v) { return Math.sqrt(Math.pow(v[0],2) + Math.pow(v[1],2)); }
|
1588 |
+
// ratio between two vectors
|
1589 |
+
var r = function(u, v) { return (u[0]*v[0]+u[1]*v[1]) / (m(u)*m(v)) }
|
1590 |
+
// angle between two vectors
|
1591 |
+
var a = function(u, v) { return (u[0]*v[1] < u[1]*v[0] ? -1 : 1) * Math.acos(r(u,v)); }
|
1592 |
+
// initial angle
|
1593 |
+
var a1 = a([1,0], [(currp.x-cpp.x)/rx,(currp.y-cpp.y)/ry]);
|
1594 |
+
// angle delta
|
1595 |
+
var u = [(currp.x-cpp.x)/rx,(currp.y-cpp.y)/ry];
|
1596 |
+
var v = [(-currp.x-cpp.x)/rx,(-currp.y-cpp.y)/ry];
|
1597 |
+
var ad = a(u, v);
|
1598 |
+
if (r(u,v) <= -1) ad = Math.PI;
|
1599 |
+
if (r(u,v) >= 1) ad = 0;
|
1600 |
+
|
1601 |
+
// for markers
|
1602 |
+
var dir = 1 - sweepFlag ? 1.0 : -1.0;
|
1603 |
+
var ah = a1 + dir * (ad / 2.0);
|
1604 |
+
var halfWay = new svg.Point(
|
1605 |
+
centp.x + rx * Math.cos(ah),
|
1606 |
+
centp.y + ry * Math.sin(ah)
|
1607 |
+
);
|
1608 |
+
pp.addMarkerAngle(halfWay, ah - dir * Math.PI / 2);
|
1609 |
+
pp.addMarkerAngle(cp, ah - dir * Math.PI);
|
1610 |
+
|
1611 |
+
bb.addPoint(cp.x, cp.y); // TODO: this is too naive, make it better
|
1612 |
+
if (ctx != null) {
|
1613 |
+
var r = rx > ry ? rx : ry;
|
1614 |
+
var sx = rx > ry ? 1 : rx / ry;
|
1615 |
+
var sy = rx > ry ? ry / rx : 1;
|
1616 |
+
|
1617 |
+
ctx.translate(centp.x, centp.y);
|
1618 |
+
ctx.rotate(xAxisRotation);
|
1619 |
+
ctx.scale(sx, sy);
|
1620 |
+
ctx.arc(0, 0, r, a1, a1 + ad, 1 - sweepFlag);
|
1621 |
+
ctx.scale(1/sx, 1/sy);
|
1622 |
+
ctx.rotate(-xAxisRotation);
|
1623 |
+
ctx.translate(-centp.x, -centp.y);
|
1624 |
+
}
|
1625 |
+
}
|
1626 |
+
break;
|
1627 |
+
case 'Z':
|
1628 |
+
case 'z':
|
1629 |
+
if (ctx != null) ctx.closePath();
|
1630 |
+
pp.current = pp.start;
|
1631 |
+
}
|
1632 |
+
}
|
1633 |
+
|
1634 |
+
return bb;
|
1635 |
+
}
|
1636 |
+
|
1637 |
+
this.getMarkers = function() {
|
1638 |
+
var points = this.PathParser.getMarkerPoints();
|
1639 |
+
var angles = this.PathParser.getMarkerAngles();
|
1640 |
+
|
1641 |
+
var markers = [];
|
1642 |
+
for (var i=0; i<points.length; i++) {
|
1643 |
+
markers.push([points[i], angles[i]]);
|
1644 |
+
}
|
1645 |
+
return markers;
|
1646 |
+
}
|
1647 |
+
}
|
1648 |
+
svg.Element.path.prototype = new svg.Element.PathElementBase;
|
1649 |
+
|
1650 |
+
// pattern element
|
1651 |
+
svg.Element.pattern = function(node) {
|
1652 |
+
this.base = svg.Element.ElementBase;
|
1653 |
+
this.base(node);
|
1654 |
+
|
1655 |
+
this.createPattern = function(ctx, element) {
|
1656 |
+
var width = this.attribute('width').toPixels('x', true);
|
1657 |
+
var height = this.attribute('height').toPixels('y', true);
|
1658 |
+
|
1659 |
+
// render me using a temporary svg element
|
1660 |
+
var tempSvg = new svg.Element.svg();
|
1661 |
+
tempSvg.attributes['viewBox'] = new svg.Property('viewBox', this.attribute('viewBox').value);
|
1662 |
+
tempSvg.attributes['width'] = new svg.Property('width', width + 'px');
|
1663 |
+
tempSvg.attributes['height'] = new svg.Property('height', height + 'px');
|
1664 |
+
tempSvg.attributes['transform'] = new svg.Property('transform', this.attribute('patternTransform').value);
|
1665 |
+
tempSvg.children = this.children;
|
1666 |
+
|
1667 |
+
var c = document.createElement('canvas');
|
1668 |
+
c.width = width;
|
1669 |
+
c.height = height;
|
1670 |
+
var cctx = c.getContext('2d');
|
1671 |
+
if (this.attribute('x').hasValue() && this.attribute('y').hasValue()) {
|
1672 |
+
cctx.translate(this.attribute('x').toPixels('x', true), this.attribute('y').toPixels('y', true));
|
1673 |
+
}
|
1674 |
+
// render 3x3 grid so when we transform there's no white space on edges
|
1675 |
+
for (var x=-1; x<=1; x++) {
|
1676 |
+
for (var y=-1; y<=1; y++) {
|
1677 |
+
cctx.save();
|
1678 |
+
tempSvg.attributes['x'] = new svg.Property('x', x * c.width);
|
1679 |
+
tempSvg.attributes['y'] = new svg.Property('y', y * c.height);
|
1680 |
+
tempSvg.render(cctx);
|
1681 |
+
cctx.restore();
|
1682 |
+
}
|
1683 |
+
}
|
1684 |
+
var pattern = ctx.createPattern(c, 'repeat');
|
1685 |
+
return pattern;
|
1686 |
+
}
|
1687 |
+
}
|
1688 |
+
svg.Element.pattern.prototype = new svg.Element.ElementBase;
|
1689 |
+
|
1690 |
+
// marker element
|
1691 |
+
svg.Element.marker = function(node) {
|
1692 |
+
this.base = svg.Element.ElementBase;
|
1693 |
+
this.base(node);
|
1694 |
+
|
1695 |
+
this.baseRender = this.render;
|
1696 |
+
this.render = function(ctx, point, angle) {
|
1697 |
+
ctx.translate(point.x, point.y);
|
1698 |
+
if (this.attribute('orient').valueOrDefault('auto') == 'auto') ctx.rotate(angle);
|
1699 |
+
if (this.attribute('markerUnits').valueOrDefault('strokeWidth') == 'strokeWidth') ctx.scale(ctx.lineWidth, ctx.lineWidth);
|
1700 |
+
ctx.save();
|
1701 |
+
|
1702 |
+
// render me using a temporary svg element
|
1703 |
+
var tempSvg = new svg.Element.svg();
|
1704 |
+
tempSvg.attributes['viewBox'] = new svg.Property('viewBox', this.attribute('viewBox').value);
|
1705 |
+
tempSvg.attributes['refX'] = new svg.Property('refX', this.attribute('refX').value);
|
1706 |
+
tempSvg.attributes['refY'] = new svg.Property('refY', this.attribute('refY').value);
|
1707 |
+
tempSvg.attributes['width'] = new svg.Property('width', this.attribute('markerWidth').value);
|
1708 |
+
tempSvg.attributes['height'] = new svg.Property('height', this.attribute('markerHeight').value);
|
1709 |
+
tempSvg.attributes['fill'] = new svg.Property('fill', this.attribute('fill').valueOrDefault('black'));
|
1710 |
+
tempSvg.attributes['stroke'] = new svg.Property('stroke', this.attribute('stroke').valueOrDefault('none'));
|
1711 |
+
tempSvg.children = this.children;
|
1712 |
+
tempSvg.render(ctx);
|
1713 |
+
|
1714 |
+
ctx.restore();
|
1715 |
+
if (this.attribute('markerUnits').valueOrDefault('strokeWidth') == 'strokeWidth') ctx.scale(1/ctx.lineWidth, 1/ctx.lineWidth);
|
1716 |
+
if (this.attribute('orient').valueOrDefault('auto') == 'auto') ctx.rotate(-angle);
|
1717 |
+
ctx.translate(-point.x, -point.y);
|
1718 |
+
}
|
1719 |
+
}
|
1720 |
+
svg.Element.marker.prototype = new svg.Element.ElementBase;
|
1721 |
+
|
1722 |
+
// definitions element
|
1723 |
+
svg.Element.defs = function(node) {
|
1724 |
+
this.base = svg.Element.ElementBase;
|
1725 |
+
this.base(node);
|
1726 |
+
|
1727 |
+
this.render = function(ctx) {
|
1728 |
+
// NOOP
|
1729 |
+
}
|
1730 |
+
}
|
1731 |
+
svg.Element.defs.prototype = new svg.Element.ElementBase;
|
1732 |
+
|
1733 |
+
// base for gradients
|
1734 |
+
svg.Element.GradientBase = function(node) {
|
1735 |
+
this.base = svg.Element.ElementBase;
|
1736 |
+
this.base(node);
|
1737 |
+
|
1738 |
+
this.stops = [];
|
1739 |
+
for (var i=0; i<this.children.length; i++) {
|
1740 |
+
var child = this.children[i];
|
1741 |
+
if (child.type == 'stop') this.stops.push(child);
|
1742 |
+
}
|
1743 |
+
|
1744 |
+
this.getGradient = function() {
|
1745 |
+
// OVERRIDE ME!
|
1746 |
+
}
|
1747 |
+
|
1748 |
+
this.gradientUnits = function () {
|
1749 |
+
return this.attribute('gradientUnits').valueOrDefault('objectBoundingBox');
|
1750 |
+
}
|
1751 |
+
|
1752 |
+
this.attributesToInherit = ['gradientUnits'];
|
1753 |
+
|
1754 |
+
this.inheritStopContainer = function (stopsContainer) {
|
1755 |
+
for (var i=0; i<this.attributesToInherit.length; i++) {
|
1756 |
+
var attributeToInherit = this.attributesToInherit[i];
|
1757 |
+
if (!this.attribute(attributeToInherit).hasValue() && stopsContainer.attribute(attributeToInherit).hasValue()) {
|
1758 |
+
this.attribute(attributeToInherit, true).value = stopsContainer.attribute(attributeToInherit).value;
|
1759 |
+
}
|
1760 |
+
}
|
1761 |
+
}
|
1762 |
+
|
1763 |
+
this.createGradient = function(ctx, element, parentOpacityProp) {
|
1764 |
+
var stopsContainer = this;
|
1765 |
+
if (this.getHrefAttribute().hasValue()) {
|
1766 |
+
stopsContainer = this.getHrefAttribute().getDefinition();
|
1767 |
+
this.inheritStopContainer(stopsContainer);
|
1768 |
+
}
|
1769 |
+
|
1770 |
+
var addParentOpacity = function (color) {
|
1771 |
+
if (parentOpacityProp.hasValue()) {
|
1772 |
+
var p = new svg.Property('color', color);
|
1773 |
+
return p.addOpacity(parentOpacityProp).value;
|
1774 |
+
}
|
1775 |
+
return color;
|
1776 |
+
};
|
1777 |
+
|
1778 |
+
var g = this.getGradient(ctx, element);
|
1779 |
+
if (g == null) return addParentOpacity(stopsContainer.stops[stopsContainer.stops.length - 1].color);
|
1780 |
+
for (var i=0; i<stopsContainer.stops.length; i++) {
|
1781 |
+
g.addColorStop(stopsContainer.stops[i].offset, addParentOpacity(stopsContainer.stops[i].color));
|
1782 |
+
}
|
1783 |
+
|
1784 |
+
if (this.attribute('gradientTransform').hasValue()) {
|
1785 |
+
// render as transformed pattern on temporary canvas
|
1786 |
+
var rootView = svg.ViewPort.viewPorts[0];
|
1787 |
+
|
1788 |
+
var rect = new svg.Element.rect();
|
1789 |
+
rect.attributes['x'] = new svg.Property('x', -svg.MAX_VIRTUAL_PIXELS/3.0);
|
1790 |
+
rect.attributes['y'] = new svg.Property('y', -svg.MAX_VIRTUAL_PIXELS/3.0);
|
1791 |
+
rect.attributes['width'] = new svg.Property('width', svg.MAX_VIRTUAL_PIXELS);
|
1792 |
+
rect.attributes['height'] = new svg.Property('height', svg.MAX_VIRTUAL_PIXELS);
|
1793 |
+
|
1794 |
+
var group = new svg.Element.g();
|
1795 |
+
group.attributes['transform'] = new svg.Property('transform', this.attribute('gradientTransform').value);
|
1796 |
+
group.children = [ rect ];
|
1797 |
+
|
1798 |
+
var tempSvg = new svg.Element.svg();
|
1799 |
+
tempSvg.attributes['x'] = new svg.Property('x', 0);
|
1800 |
+
tempSvg.attributes['y'] = new svg.Property('y', 0);
|
1801 |
+
tempSvg.attributes['width'] = new svg.Property('width', rootView.width);
|
1802 |
+
tempSvg.attributes['height'] = new svg.Property('height', rootView.height);
|
1803 |
+
tempSvg.children = [ group ];
|
1804 |
+
|
1805 |
+
var c = document.createElement('canvas');
|
1806 |
+
c.width = rootView.width;
|
1807 |
+
c.height = rootView.height;
|
1808 |
+
var tempCtx = c.getContext('2d');
|
1809 |
+
tempCtx.fillStyle = g;
|
1810 |
+
tempSvg.render(tempCtx);
|
1811 |
+
return tempCtx.createPattern(c, 'no-repeat');
|
1812 |
+
}
|
1813 |
+
|
1814 |
+
return g;
|
1815 |
+
}
|
1816 |
+
}
|
1817 |
+
svg.Element.GradientBase.prototype = new svg.Element.ElementBase;
|
1818 |
+
|
1819 |
+
// linear gradient element
|
1820 |
+
svg.Element.linearGradient = function(node) {
|
1821 |
+
this.base = svg.Element.GradientBase;
|
1822 |
+
this.base(node);
|
1823 |
+
|
1824 |
+
this.attributesToInherit.push('x1');
|
1825 |
+
this.attributesToInherit.push('y1');
|
1826 |
+
this.attributesToInherit.push('x2');
|
1827 |
+
this.attributesToInherit.push('y2');
|
1828 |
+
|
1829 |
+
this.getGradient = function(ctx, element) {
|
1830 |
+
var bb = this.gradientUnits() == 'objectBoundingBox' ? element.getBoundingBox() : null;
|
1831 |
+
|
1832 |
+
if (!this.attribute('x1').hasValue()
|
1833 |
+
&& !this.attribute('y1').hasValue()
|
1834 |
+
&& !this.attribute('x2').hasValue()
|
1835 |
+
&& !this.attribute('y2').hasValue()) {
|
1836 |
+
this.attribute('x1', true).value = 0;
|
1837 |
+
this.attribute('y1', true).value = 0;
|
1838 |
+
this.attribute('x2', true).value = 1;
|
1839 |
+
this.attribute('y2', true).value = 0;
|
1840 |
+
}
|
1841 |
+
|
1842 |
+
var x1 = (this.gradientUnits() == 'objectBoundingBox'
|
1843 |
+
? bb.x() + bb.width() * this.attribute('x1').numValue()
|
1844 |
+
: this.attribute('x1').toPixels('x'));
|
1845 |
+
var y1 = (this.gradientUnits() == 'objectBoundingBox'
|
1846 |
+
? bb.y() + bb.height() * this.attribute('y1').numValue()
|
1847 |
+
: this.attribute('y1').toPixels('y'));
|
1848 |
+
var x2 = (this.gradientUnits() == 'objectBoundingBox'
|
1849 |
+
? bb.x() + bb.width() * this.attribute('x2').numValue()
|
1850 |
+
: this.attribute('x2').toPixels('x'));
|
1851 |
+
var y2 = (this.gradientUnits() == 'objectBoundingBox'
|
1852 |
+
? bb.y() + bb.height() * this.attribute('y2').numValue()
|
1853 |
+
: this.attribute('y2').toPixels('y'));
|
1854 |
+
|
1855 |
+
if (x1 == x2 && y1 == y2) return null;
|
1856 |
+
return ctx.createLinearGradient(x1, y1, x2, y2);
|
1857 |
+
}
|
1858 |
+
}
|
1859 |
+
svg.Element.linearGradient.prototype = new svg.Element.GradientBase;
|
1860 |
+
|
1861 |
+
// radial gradient element
|
1862 |
+
svg.Element.radialGradient = function(node) {
|
1863 |
+
this.base = svg.Element.GradientBase;
|
1864 |
+
this.base(node);
|
1865 |
+
|
1866 |
+
this.attributesToInherit.push('cx');
|
1867 |
+
this.attributesToInherit.push('cy');
|
1868 |
+
this.attributesToInherit.push('r');
|
1869 |
+
this.attributesToInherit.push('fx');
|
1870 |
+
this.attributesToInherit.push('fy');
|
1871 |
+
|
1872 |
+
this.getGradient = function(ctx, element) {
|
1873 |
+
var bb = element.getBoundingBox();
|
1874 |
+
|
1875 |
+
if (!this.attribute('cx').hasValue()) this.attribute('cx', true).value = '50%';
|
1876 |
+
if (!this.attribute('cy').hasValue()) this.attribute('cy', true).value = '50%';
|
1877 |
+
if (!this.attribute('r').hasValue()) this.attribute('r', true).value = '50%';
|
1878 |
+
|
1879 |
+
var cx = (this.gradientUnits() == 'objectBoundingBox'
|
1880 |
+
? bb.x() + bb.width() * this.attribute('cx').numValue()
|
1881 |
+
: this.attribute('cx').toPixels('x'));
|
1882 |
+
var cy = (this.gradientUnits() == 'objectBoundingBox'
|
1883 |
+
? bb.y() + bb.height() * this.attribute('cy').numValue()
|
1884 |
+
: this.attribute('cy').toPixels('y'));
|
1885 |
+
|
1886 |
+
var fx = cx;
|
1887 |
+
var fy = cy;
|
1888 |
+
if (this.attribute('fx').hasValue()) {
|
1889 |
+
fx = (this.gradientUnits() == 'objectBoundingBox'
|
1890 |
+
? bb.x() + bb.width() * this.attribute('fx').numValue()
|
1891 |
+
: this.attribute('fx').toPixels('x'));
|
1892 |
+
}
|
1893 |
+
if (this.attribute('fy').hasValue()) {
|
1894 |
+
fy = (this.gradientUnits() == 'objectBoundingBox'
|
1895 |
+
? bb.y() + bb.height() * this.attribute('fy').numValue()
|
1896 |
+
: this.attribute('fy').toPixels('y'));
|
1897 |
+
}
|
1898 |
+
|
1899 |
+
var r = (this.gradientUnits() == 'objectBoundingBox'
|
1900 |
+
? (bb.width() + bb.height()) / 2.0 * this.attribute('r').numValue()
|
1901 |
+
: this.attribute('r').toPixels());
|
1902 |
+
|
1903 |
+
return ctx.createRadialGradient(fx, fy, 0, cx, cy, r);
|
1904 |
+
}
|
1905 |
+
}
|
1906 |
+
svg.Element.radialGradient.prototype = new svg.Element.GradientBase;
|
1907 |
+
|
1908 |
+
// gradient stop element
|
1909 |
+
svg.Element.stop = function(node) {
|
1910 |
+
this.base = svg.Element.ElementBase;
|
1911 |
+
this.base(node);
|
1912 |
+
|
1913 |
+
this.offset = this.attribute('offset').numValue();
|
1914 |
+
if (this.offset < 0) this.offset = 0;
|
1915 |
+
if (this.offset > 1) this.offset = 1;
|
1916 |
+
|
1917 |
+
var stopColor = this.style('stop-color', true);
|
1918 |
+
if (stopColor.value === '') stopColor.value = '#000';
|
1919 |
+
if (this.style('stop-opacity').hasValue()) stopColor = stopColor.addOpacity(this.style('stop-opacity'));
|
1920 |
+
this.color = stopColor.value;
|
1921 |
+
}
|
1922 |
+
svg.Element.stop.prototype = new svg.Element.ElementBase;
|
1923 |
+
|
1924 |
+
// animation base element
|
1925 |
+
svg.Element.AnimateBase = function(node) {
|
1926 |
+
this.base = svg.Element.ElementBase;
|
1927 |
+
this.base(node);
|
1928 |
+
|
1929 |
+
svg.Animations.push(this);
|
1930 |
+
|
1931 |
+
this.duration = 0.0;
|
1932 |
+
this.begin = this.attribute('begin').toMilliseconds();
|
1933 |
+
this.maxDuration = this.begin + this.attribute('dur').toMilliseconds();
|
1934 |
+
|
1935 |
+
this.getProperty = function() {
|
1936 |
+
var attributeType = this.attribute('attributeType').value;
|
1937 |
+
var attributeName = this.attribute('attributeName').value;
|
1938 |
+
|
1939 |
+
if (attributeType == 'CSS') {
|
1940 |
+
return this.parent.style(attributeName, true);
|
1941 |
+
}
|
1942 |
+
return this.parent.attribute(attributeName, true);
|
1943 |
+
};
|
1944 |
+
|
1945 |
+
this.initialValue = null;
|
1946 |
+
this.initialUnits = '';
|
1947 |
+
this.removed = false;
|
1948 |
+
|
1949 |
+
this.calcValue = function() {
|
1950 |
+
// OVERRIDE ME!
|
1951 |
+
return '';
|
1952 |
+
}
|
1953 |
+
|
1954 |
+
this.update = function(delta) {
|
1955 |
+
// set initial value
|
1956 |
+
if (this.initialValue == null) {
|
1957 |
+
this.initialValue = this.getProperty().value;
|
1958 |
+
this.initialUnits = this.getProperty().getUnits();
|
1959 |
+
}
|
1960 |
+
|
1961 |
+
// if we're past the end time
|
1962 |
+
if (this.duration > this.maxDuration) {
|
1963 |
+
// loop for indefinitely repeating animations
|
1964 |
+
if (this.attribute('repeatCount').value == 'indefinite'
|
1965 |
+
|| this.attribute('repeatDur').value == 'indefinite') {
|
1966 |
+
this.duration = 0.0
|
1967 |
+
}
|
1968 |
+
else if (this.attribute('fill').valueOrDefault('remove') == 'freeze' && !this.frozen) {
|
1969 |
+
this.frozen = true;
|
1970 |
+
this.parent.animationFrozen = true;
|
1971 |
+
this.parent.animationFrozenValue = this.getProperty().value;
|
1972 |
+
}
|
1973 |
+
else if (this.attribute('fill').valueOrDefault('remove') == 'remove' && !this.removed) {
|
1974 |
+
this.removed = true;
|
1975 |
+
this.getProperty().value = this.parent.animationFrozen ? this.parent.animationFrozenValue : this.initialValue;
|
1976 |
+
return true;
|
1977 |
+
}
|
1978 |
+
return false;
|
1979 |
+
}
|
1980 |
+
this.duration = this.duration + delta;
|
1981 |
+
|
1982 |
+
// if we're past the begin time
|
1983 |
+
var updated = false;
|
1984 |
+
if (this.begin < this.duration) {
|
1985 |
+
var newValue = this.calcValue(); // tween
|
1986 |
+
|
1987 |
+
if (this.attribute('type').hasValue()) {
|
1988 |
+
// for transform, etc.
|
1989 |
+
var type = this.attribute('type').value;
|
1990 |
+
newValue = type + '(' + newValue + ')';
|
1991 |
+
}
|
1992 |
+
|
1993 |
+
this.getProperty().value = newValue;
|
1994 |
+
updated = true;
|
1995 |
+
}
|
1996 |
+
|
1997 |
+
return updated;
|
1998 |
+
}
|
1999 |
+
|
2000 |
+
this.from = this.attribute('from');
|
2001 |
+
this.to = this.attribute('to');
|
2002 |
+
this.values = this.attribute('values');
|
2003 |
+
if (this.values.hasValue()) this.values.value = this.values.value.split(';');
|
2004 |
+
|
2005 |
+
// fraction of duration we've covered
|
2006 |
+
this.progress = function() {
|
2007 |
+
var ret = { progress: (this.duration - this.begin) / (this.maxDuration - this.begin) };
|
2008 |
+
if (this.values.hasValue()) {
|
2009 |
+
var p = ret.progress * (this.values.value.length - 1);
|
2010 |
+
var lb = Math.floor(p), ub = Math.ceil(p);
|
2011 |
+
ret.from = new svg.Property('from', parseFloat(this.values.value[lb]));
|
2012 |
+
ret.to = new svg.Property('to', parseFloat(this.values.value[ub]));
|
2013 |
+
ret.progress = (p - lb) / (ub - lb);
|
2014 |
+
}
|
2015 |
+
else {
|
2016 |
+
ret.from = this.from;
|
2017 |
+
ret.to = this.to;
|
2018 |
+
}
|
2019 |
+
return ret;
|
2020 |
+
}
|
2021 |
+
}
|
2022 |
+
svg.Element.AnimateBase.prototype = new svg.Element.ElementBase;
|
2023 |
+
|
2024 |
+
// animate element
|
2025 |
+
svg.Element.animate = function(node) {
|
2026 |
+
this.base = svg.Element.AnimateBase;
|
2027 |
+
this.base(node);
|
2028 |
+
|
2029 |
+
this.calcValue = function() {
|
2030 |
+
var p = this.progress();
|
2031 |
+
|
2032 |
+
// tween value linearly
|
2033 |
+
var newValue = p.from.numValue() + (p.to.numValue() - p.from.numValue()) * p.progress;
|
2034 |
+
return newValue + this.initialUnits;
|
2035 |
+
};
|
2036 |
+
}
|
2037 |
+
svg.Element.animate.prototype = new svg.Element.AnimateBase;
|
2038 |
+
|
2039 |
+
// animate color element
|
2040 |
+
svg.Element.animateColor = function(node) {
|
2041 |
+
this.base = svg.Element.AnimateBase;
|
2042 |
+
this.base(node);
|
2043 |
+
|
2044 |
+
this.calcValue = function() {
|
2045 |
+
var p = this.progress();
|
2046 |
+
var from = new RGBColor(p.from.value);
|
2047 |
+
var to = new RGBColor(p.to.value);
|
2048 |
+
|
2049 |
+
if (from.ok && to.ok) {
|
2050 |
+
// tween color linearly
|
2051 |
+
var r = from.r + (to.r - from.r) * p.progress;
|
2052 |
+
var g = from.g + (to.g - from.g) * p.progress;
|
2053 |
+
var b = from.b + (to.b - from.b) * p.progress;
|
2054 |
+
return 'rgb('+parseInt(r,10)+','+parseInt(g,10)+','+parseInt(b,10)+')';
|
2055 |
+
}
|
2056 |
+
return this.attribute('from').value;
|
2057 |
+
};
|
2058 |
+
}
|
2059 |
+
svg.Element.animateColor.prototype = new svg.Element.AnimateBase;
|
2060 |
+
|
2061 |
+
// animate transform element
|
2062 |
+
svg.Element.animateTransform = function(node) {
|
2063 |
+
this.base = svg.Element.AnimateBase;
|
2064 |
+
this.base(node);
|
2065 |
+
|
2066 |
+
this.calcValue = function() {
|
2067 |
+
var p = this.progress();
|
2068 |
+
|
2069 |
+
// tween value linearly
|
2070 |
+
var from = svg.ToNumberArray(p.from.value);
|
2071 |
+
var to = svg.ToNumberArray(p.to.value);
|
2072 |
+
var newValue = '';
|
2073 |
+
for (var i=0; i<from.length; i++) {
|
2074 |
+
newValue += from[i] + (to[i] - from[i]) * p.progress + ' ';
|
2075 |
+
}
|
2076 |
+
return newValue;
|
2077 |
+
};
|
2078 |
+
}
|
2079 |
+
svg.Element.animateTransform.prototype = new svg.Element.animate;
|
2080 |
+
|
2081 |
+
// font element
|
2082 |
+
svg.Element.font = function(node) {
|
2083 |
+
this.base = svg.Element.ElementBase;
|
2084 |
+
this.base(node);
|
2085 |
+
|
2086 |
+
this.horizAdvX = this.attribute('horiz-adv-x').numValue();
|
2087 |
+
|
2088 |
+
this.isRTL = false;
|
2089 |
+
this.isArabic = false;
|
2090 |
+
this.fontFace = null;
|
2091 |
+
this.missingGlyph = null;
|
2092 |
+
this.glyphs = [];
|
2093 |
+
for (var i=0; i<this.children.length; i++) {
|
2094 |
+
var child = this.children[i];
|
2095 |
+
if (child.type == 'font-face') {
|
2096 |
+
this.fontFace = child;
|
2097 |
+
if (child.style('font-family').hasValue()) {
|
2098 |
+
svg.Definitions[child.style('font-family').value] = this;
|
2099 |
+
}
|
2100 |
+
}
|
2101 |
+
else if (child.type == 'missing-glyph') this.missingGlyph = child;
|
2102 |
+
else if (child.type == 'glyph') {
|
2103 |
+
if (child.arabicForm != '') {
|
2104 |
+
this.isRTL = true;
|
2105 |
+
this.isArabic = true;
|
2106 |
+
if (typeof this.glyphs[child.unicode] == 'undefined') this.glyphs[child.unicode] = [];
|
2107 |
+
this.glyphs[child.unicode][child.arabicForm] = child;
|
2108 |
+
}
|
2109 |
+
else {
|
2110 |
+
this.glyphs[child.unicode] = child;
|
2111 |
+
}
|
2112 |
+
}
|
2113 |
+
}
|
2114 |
+
}
|
2115 |
+
svg.Element.font.prototype = new svg.Element.ElementBase;
|
2116 |
+
|
2117 |
+
// font-face element
|
2118 |
+
svg.Element.fontface = function(node) {
|
2119 |
+
this.base = svg.Element.ElementBase;
|
2120 |
+
this.base(node);
|
2121 |
+
|
2122 |
+
this.ascent = this.attribute('ascent').value;
|
2123 |
+
this.descent = this.attribute('descent').value;
|
2124 |
+
this.unitsPerEm = this.attribute('units-per-em').numValue();
|
2125 |
+
}
|
2126 |
+
svg.Element.fontface.prototype = new svg.Element.ElementBase;
|
2127 |
+
|
2128 |
+
// missing-glyph element
|
2129 |
+
svg.Element.missingglyph = function(node) {
|
2130 |
+
this.base = svg.Element.path;
|
2131 |
+
this.base(node);
|
2132 |
+
|
2133 |
+
this.horizAdvX = 0;
|
2134 |
+
}
|
2135 |
+
svg.Element.missingglyph.prototype = new svg.Element.path;
|
2136 |
+
|
2137 |
+
// glyph element
|
2138 |
+
svg.Element.glyph = function(node) {
|
2139 |
+
this.base = svg.Element.path;
|
2140 |
+
this.base(node);
|
2141 |
+
|
2142 |
+
this.horizAdvX = this.attribute('horiz-adv-x').numValue();
|
2143 |
+
this.unicode = this.attribute('unicode').value;
|
2144 |
+
this.arabicForm = this.attribute('arabic-form').value;
|
2145 |
+
}
|
2146 |
+
svg.Element.glyph.prototype = new svg.Element.path;
|
2147 |
+
|
2148 |
+
// text element
|
2149 |
+
svg.Element.text = function(node) {
|
2150 |
+
this.captureTextNodes = true;
|
2151 |
+
this.base = svg.Element.RenderedElementBase;
|
2152 |
+
this.base(node);
|
2153 |
+
|
2154 |
+
this.baseSetContext = this.setContext;
|
2155 |
+
this.setContext = function(ctx) {
|
2156 |
+
this.baseSetContext(ctx);
|
2157 |
+
|
2158 |
+
var textBaseline = this.style('dominant-baseline').toTextBaseline();
|
2159 |
+
if (textBaseline == null) textBaseline = this.style('alignment-baseline').toTextBaseline();
|
2160 |
+
if (textBaseline != null) ctx.textBaseline = textBaseline;
|
2161 |
+
}
|
2162 |
+
|
2163 |
+
this.getBoundingBox = function () {
|
2164 |
+
var x = this.attribute('x').toPixels('x');
|
2165 |
+
var y = this.attribute('y').toPixels('y');
|
2166 |
+
var fontSize = this.parent.style('font-size').numValueOrDefault(svg.Font.Parse(svg.ctx.font).fontSize);
|
2167 |
+
return new svg.BoundingBox(x, y - fontSize, x + Math.floor(fontSize * 2.0 / 3.0) * this.children[0].getText().length, y);
|
2168 |
+
}
|
2169 |
+
|
2170 |
+
this.renderChildren = function(ctx) {
|
2171 |
+
this.x = this.attribute('x').toPixels('x');
|
2172 |
+
this.y = this.attribute('y').toPixels('y');
|
2173 |
+
if (this.attribute('dx').hasValue()) this.x += this.attribute('dx').toPixels('x');
|
2174 |
+
if (this.attribute('dy').hasValue()) this.y += this.attribute('dy').toPixels('y');
|
2175 |
+
this.x += this.getAnchorDelta(ctx, this, 0);
|
2176 |
+
for (var i=0; i<this.children.length; i++) {
|
2177 |
+
this.renderChild(ctx, this, this, i);
|
2178 |
+
}
|
2179 |
+
}
|
2180 |
+
|
2181 |
+
this.getAnchorDelta = function (ctx, parent, startI) {
|
2182 |
+
var textAnchor = this.style('text-anchor').valueOrDefault('start');
|
2183 |
+
if (textAnchor != 'start') {
|
2184 |
+
var width = 0;
|
2185 |
+
for (var i=startI; i<parent.children.length; i++) {
|
2186 |
+
var child = parent.children[i];
|
2187 |
+
if (i > startI && child.attribute('x').hasValue()) break; // new group
|
2188 |
+
width += child.measureTextRecursive(ctx);
|
2189 |
+
}
|
2190 |
+
return -1 * (textAnchor == 'end' ? width : width / 2.0);
|
2191 |
+
}
|
2192 |
+
return 0;
|
2193 |
+
}
|
2194 |
+
|
2195 |
+
this.renderChild = function(ctx, textParent, parent, i) {
|
2196 |
+
var child = parent.children[i];
|
2197 |
+
if (child.attribute('x').hasValue()) {
|
2198 |
+
child.x = child.attribute('x').toPixels('x') + textParent.getAnchorDelta(ctx, parent, i);
|
2199 |
+
if (child.attribute('dx').hasValue()) child.x += child.attribute('dx').toPixels('x');
|
2200 |
+
}
|
2201 |
+
else {
|
2202 |
+
if (child.attribute('dx').hasValue()) textParent.x += child.attribute('dx').toPixels('x');
|
2203 |
+
child.x = textParent.x;
|
2204 |
+
}
|
2205 |
+
textParent.x = child.x + child.measureText(ctx);
|
2206 |
+
|
2207 |
+
if (child.attribute('y').hasValue()) {
|
2208 |
+
child.y = child.attribute('y').toPixels('y');
|
2209 |
+
if (child.attribute('dy').hasValue()) child.y += child.attribute('dy').toPixels('y');
|
2210 |
+
}
|
2211 |
+
else {
|
2212 |
+
if (child.attribute('dy').hasValue()) textParent.y += child.attribute('dy').toPixels('y');
|
2213 |
+
child.y = textParent.y;
|
2214 |
+
}
|
2215 |
+
textParent.y = child.y;
|
2216 |
+
|
2217 |
+
child.render(ctx);
|
2218 |
+
|
2219 |
+
for (var i=0; i<child.children.length; i++) {
|
2220 |
+
textParent.renderChild(ctx, textParent, child, i);
|
2221 |
+
}
|
2222 |
+
}
|
2223 |
+
}
|
2224 |
+
svg.Element.text.prototype = new svg.Element.RenderedElementBase;
|
2225 |
+
|
2226 |
+
// text base
|
2227 |
+
svg.Element.TextElementBase = function(node) {
|
2228 |
+
this.base = svg.Element.RenderedElementBase;
|
2229 |
+
this.base(node);
|
2230 |
+
|
2231 |
+
this.getGlyph = function(font, text, i) {
|
2232 |
+
var c = text[i];
|
2233 |
+
var glyph = null;
|
2234 |
+
if (font.isArabic) {
|
2235 |
+
var arabicForm = 'isolated';
|
2236 |
+
if ((i==0 || text[i-1]==' ') && i<text.length-2 && text[i+1]!=' ') arabicForm = 'terminal';
|
2237 |
+
if (i>0 && text[i-1]!=' ' && i<text.length-2 && text[i+1]!=' ') arabicForm = 'medial';
|
2238 |
+
if (i>0 && text[i-1]!=' ' && (i == text.length-1 || text[i+1]==' ')) arabicForm = 'initial';
|
2239 |
+
if (typeof font.glyphs[c] != 'undefined') {
|
2240 |
+
glyph = font.glyphs[c][arabicForm];
|
2241 |
+
if (glyph == null && font.glyphs[c].type == 'glyph') glyph = font.glyphs[c];
|
2242 |
+
}
|
2243 |
+
}
|
2244 |
+
else {
|
2245 |
+
glyph = font.glyphs[c];
|
2246 |
+
}
|
2247 |
+
if (glyph == null) glyph = font.missingGlyph;
|
2248 |
+
return glyph;
|
2249 |
+
}
|
2250 |
+
|
2251 |
+
this.renderChildren = function(ctx) {
|
2252 |
+
var customFont = this.parent.style('font-family').getDefinition();
|
2253 |
+
if (customFont != null) {
|
2254 |
+
var fontSize = this.parent.style('font-size').numValueOrDefault(svg.Font.Parse(svg.ctx.font).fontSize);
|
2255 |
+
var fontStyle = this.parent.style('font-style').valueOrDefault(svg.Font.Parse(svg.ctx.font).fontStyle);
|
2256 |
+
var text = this.getText();
|
2257 |
+
if (customFont.isRTL) text = text.split("").reverse().join("");
|
2258 |
+
|
2259 |
+
var dx = svg.ToNumberArray(this.parent.attribute('dx').value);
|
2260 |
+
for (var i=0; i<text.length; i++) {
|
2261 |
+
var glyph = this.getGlyph(customFont, text, i);
|
2262 |
+
var scale = fontSize / customFont.fontFace.unitsPerEm;
|
2263 |
+
ctx.translate(this.x, this.y);
|
2264 |
+
ctx.scale(scale, -scale);
|
2265 |
+
var lw = ctx.lineWidth;
|
2266 |
+
ctx.lineWidth = ctx.lineWidth * customFont.fontFace.unitsPerEm / fontSize;
|
2267 |
+
if (fontStyle == 'italic') ctx.transform(1, 0, .4, 1, 0, 0);
|
2268 |
+
glyph.render(ctx);
|
2269 |
+
if (fontStyle == 'italic') ctx.transform(1, 0, -.4, 1, 0, 0);
|
2270 |
+
ctx.lineWidth = lw;
|
2271 |
+
ctx.scale(1/scale, -1/scale);
|
2272 |
+
ctx.translate(-this.x, -this.y);
|
2273 |
+
|
2274 |
+
this.x += fontSize * (glyph.horizAdvX || customFont.horizAdvX) / customFont.fontFace.unitsPerEm;
|
2275 |
+
if (typeof dx[i] != 'undefined' && !isNaN(dx[i])) {
|
2276 |
+
this.x += dx[i];
|
2277 |
+
}
|
2278 |
+
}
|
2279 |
+
return;
|
2280 |
+
}
|
2281 |
+
|
2282 |
+
if (ctx.fillStyle != '') ctx.fillText(svg.compressSpaces(this.getText()), this.x, this.y);
|
2283 |
+
if (ctx.strokeStyle != '') ctx.strokeText(svg.compressSpaces(this.getText()), this.x, this.y);
|
2284 |
+
}
|
2285 |
+
|
2286 |
+
this.getText = function() {
|
2287 |
+
// OVERRIDE ME
|
2288 |
+
}
|
2289 |
+
|
2290 |
+
this.measureTextRecursive = function(ctx) {
|
2291 |
+
var width = this.measureText(ctx);
|
2292 |
+
for (var i=0; i<this.children.length; i++) {
|
2293 |
+
width += this.children[i].measureTextRecursive(ctx);
|
2294 |
+
}
|
2295 |
+
return width;
|
2296 |
+
}
|
2297 |
+
|
2298 |
+
this.measureText = function(ctx) {
|
2299 |
+
var customFont = this.parent.style('font-family').getDefinition();
|
2300 |
+
if (customFont != null) {
|
2301 |
+
var fontSize = this.parent.style('font-size').numValueOrDefault(svg.Font.Parse(svg.ctx.font).fontSize);
|
2302 |
+
var measure = 0;
|
2303 |
+
var text = this.getText();
|
2304 |
+
if (customFont.isRTL) text = text.split("").reverse().join("");
|
2305 |
+
var dx = svg.ToNumberArray(this.parent.attribute('dx').value);
|
2306 |
+
for (var i=0; i<text.length; i++) {
|
2307 |
+
var glyph = this.getGlyph(customFont, text, i);
|
2308 |
+
measure += (glyph.horizAdvX || customFont.horizAdvX) * fontSize / customFont.fontFace.unitsPerEm;
|
2309 |
+
if (typeof dx[i] != 'undefined' && !isNaN(dx[i])) {
|
2310 |
+
measure += dx[i];
|
2311 |
+
}
|
2312 |
+
}
|
2313 |
+
return measure;
|
2314 |
+
}
|
2315 |
+
|
2316 |
+
var textToMeasure = svg.compressSpaces(this.getText());
|
2317 |
+
if (!ctx.measureText) return textToMeasure.length * 10;
|
2318 |
+
|
2319 |
+
ctx.save();
|
2320 |
+
this.setContext(ctx);
|
2321 |
+
var width = ctx.measureText(textToMeasure).width;
|
2322 |
+
ctx.restore();
|
2323 |
+
return width;
|
2324 |
+
}
|
2325 |
+
}
|
2326 |
+
svg.Element.TextElementBase.prototype = new svg.Element.RenderedElementBase;
|
2327 |
+
|
2328 |
+
// tspan
|
2329 |
+
svg.Element.tspan = function(node) {
|
2330 |
+
this.captureTextNodes = true;
|
2331 |
+
this.base = svg.Element.TextElementBase;
|
2332 |
+
this.base(node);
|
2333 |
+
|
2334 |
+
this.text = svg.compressSpaces(node.value || node.text || node.textContent || '');
|
2335 |
+
this.getText = function() {
|
2336 |
+
// if this node has children, then they own the text
|
2337 |
+
if (this.children.length > 0) { return ''; }
|
2338 |
+
return this.text;
|
2339 |
+
}
|
2340 |
+
}
|
2341 |
+
svg.Element.tspan.prototype = new svg.Element.TextElementBase;
|
2342 |
+
|
2343 |
+
// tref
|
2344 |
+
svg.Element.tref = function(node) {
|
2345 |
+
this.base = svg.Element.TextElementBase;
|
2346 |
+
this.base(node);
|
2347 |
+
|
2348 |
+
this.getText = function() {
|
2349 |
+
var element = this.getHrefAttribute().getDefinition();
|
2350 |
+
if (element != null) return element.children[0].getText();
|
2351 |
+
}
|
2352 |
+
}
|
2353 |
+
svg.Element.tref.prototype = new svg.Element.TextElementBase;
|
2354 |
+
|
2355 |
+
// a element
|
2356 |
+
svg.Element.a = function(node) {
|
2357 |
+
this.base = svg.Element.TextElementBase;
|
2358 |
+
this.base(node);
|
2359 |
+
|
2360 |
+
this.hasText = node.childNodes.length > 0;
|
2361 |
+
for (var i=0; i<node.childNodes.length; i++) {
|
2362 |
+
if (node.childNodes[i].nodeType != 3) this.hasText = false;
|
2363 |
+
}
|
2364 |
+
|
2365 |
+
// this might contain text
|
2366 |
+
this.text = this.hasText ? node.childNodes[0].value : '';
|
2367 |
+
this.getText = function() {
|
2368 |
+
return this.text;
|
2369 |
+
}
|
2370 |
+
|
2371 |
+
this.baseRenderChildren = this.renderChildren;
|
2372 |
+
this.renderChildren = function(ctx) {
|
2373 |
+
if (this.hasText) {
|
2374 |
+
// render as text element
|
2375 |
+
this.baseRenderChildren(ctx);
|
2376 |
+
var fontSize = new svg.Property('fontSize', svg.Font.Parse(svg.ctx.font).fontSize);
|
2377 |
+
svg.Mouse.checkBoundingBox(this, new svg.BoundingBox(this.x, this.y - fontSize.toPixels('y'), this.x + this.measureText(ctx), this.y));
|
2378 |
+
}
|
2379 |
+
else if (this.children.length > 0) {
|
2380 |
+
// render as temporary group
|
2381 |
+
var g = new svg.Element.g();
|
2382 |
+
g.children = this.children;
|
2383 |
+
g.parent = this;
|
2384 |
+
g.render(ctx);
|
2385 |
+
}
|
2386 |
+
}
|
2387 |
+
|
2388 |
+
this.onclick = function() {
|
2389 |
+
window.open(this.getHrefAttribute().value);
|
2390 |
+
}
|
2391 |
+
|
2392 |
+
this.onmousemove = function() {
|
2393 |
+
svg.ctx.canvas.style.cursor = 'pointer';
|
2394 |
+
}
|
2395 |
+
}
|
2396 |
+
svg.Element.a.prototype = new svg.Element.TextElementBase;
|
2397 |
+
|
2398 |
+
// image element
|
2399 |
+
svg.Element.image = function(node) {
|
2400 |
+
this.base = svg.Element.RenderedElementBase;
|
2401 |
+
this.base(node);
|
2402 |
+
|
2403 |
+
var href = this.getHrefAttribute().value;
|
2404 |
+
if (href == '') { return; }
|
2405 |
+
var isSvg = href.match(/\.svg$/)
|
2406 |
+
|
2407 |
+
svg.Images.push(this);
|
2408 |
+
this.loaded = false;
|
2409 |
+
if (!isSvg) {
|
2410 |
+
this.img = document.createElement('img');
|
2411 |
+
if (svg.opts['useCORS'] == true) { this.img.crossOrigin = 'Anonymous'; }
|
2412 |
+
var self = this;
|
2413 |
+
this.img.onload = function() { self.loaded = true; }
|
2414 |
+
this.img.onerror = function() { svg.log('ERROR: image "' + href + '" not found'); self.loaded = true; }
|
2415 |
+
this.img.src = href;
|
2416 |
+
}
|
2417 |
+
else {
|
2418 |
+
this.img = svg.ajax(href);
|
2419 |
+
this.loaded = true;
|
2420 |
+
}
|
2421 |
+
|
2422 |
+
this.renderChildren = function(ctx) {
|
2423 |
+
var x = this.attribute('x').toPixels('x');
|
2424 |
+
var y = this.attribute('y').toPixels('y');
|
2425 |
+
|
2426 |
+
var width = this.attribute('width').toPixels('x');
|
2427 |
+
var height = this.attribute('height').toPixels('y');
|
2428 |
+
if (width == 0 || height == 0) return;
|
2429 |
+
|
2430 |
+
ctx.save();
|
2431 |
+
if (isSvg) {
|
2432 |
+
ctx.drawSvg(this.img, x, y, width, height);
|
2433 |
+
}
|
2434 |
+
else {
|
2435 |
+
ctx.translate(x, y);
|
2436 |
+
svg.AspectRatio(ctx,
|
2437 |
+
this.attribute('preserveAspectRatio').value,
|
2438 |
+
width,
|
2439 |
+
this.img.width,
|
2440 |
+
height,
|
2441 |
+
this.img.height,
|
2442 |
+
0,
|
2443 |
+
0);
|
2444 |
+
ctx.drawImage(this.img, 0, 0);
|
2445 |
+
}
|
2446 |
+
ctx.restore();
|
2447 |
+
}
|
2448 |
+
|
2449 |
+
this.getBoundingBox = function() {
|
2450 |
+
var x = this.attribute('x').toPixels('x');
|
2451 |
+
var y = this.attribute('y').toPixels('y');
|
2452 |
+
var width = this.attribute('width').toPixels('x');
|
2453 |
+
var height = this.attribute('height').toPixels('y');
|
2454 |
+
return new svg.BoundingBox(x, y, x + width, y + height);
|
2455 |
+
}
|
2456 |
+
}
|
2457 |
+
svg.Element.image.prototype = new svg.Element.RenderedElementBase;
|
2458 |
+
|
2459 |
+
// group element
|
2460 |
+
svg.Element.g = function(node) {
|
2461 |
+
this.base = svg.Element.RenderedElementBase;
|
2462 |
+
this.base(node);
|
2463 |
+
|
2464 |
+
this.getBoundingBox = function() {
|
2465 |
+
var bb = new svg.BoundingBox();
|
2466 |
+
for (var i=0; i<this.children.length; i++) {
|
2467 |
+
bb.addBoundingBox(this.children[i].getBoundingBox());
|
2468 |
+
}
|
2469 |
+
return bb;
|
2470 |
+
};
|
2471 |
+
}
|
2472 |
+
svg.Element.g.prototype = new svg.Element.RenderedElementBase;
|
2473 |
+
|
2474 |
+
// symbol element
|
2475 |
+
svg.Element.symbol = function(node) {
|
2476 |
+
this.base = svg.Element.RenderedElementBase;
|
2477 |
+
this.base(node);
|
2478 |
+
|
2479 |
+
this.render = function(ctx) {
|
2480 |
+
// NO RENDER
|
2481 |
+
};
|
2482 |
+
}
|
2483 |
+
svg.Element.symbol.prototype = new svg.Element.RenderedElementBase;
|
2484 |
+
|
2485 |
+
// style element
|
2486 |
+
svg.Element.style = function(node) {
|
2487 |
+
this.base = svg.Element.ElementBase;
|
2488 |
+
this.base(node);
|
2489 |
+
|
2490 |
+
// text, or spaces then CDATA
|
2491 |
+
var css = ''
|
2492 |
+
for (var i=0; i<node.childNodes.length; i++) {
|
2493 |
+
css += node.childNodes[i].data;
|
2494 |
+
}
|
2495 |
+
css = css.replace(/(\/\*([^*]|[\r\n]|(\*+([^*\/]|[\r\n])))*\*+\/)|(^[\s]*\/\/.*)/gm, ''); // remove comments
|
2496 |
+
css = svg.compressSpaces(css); // replace whitespace
|
2497 |
+
var cssDefs = css.split('}');
|
2498 |
+
for (var i=0; i<cssDefs.length; i++) {
|
2499 |
+
if (svg.trim(cssDefs[i]) != '') {
|
2500 |
+
var cssDef = cssDefs[i].split('{');
|
2501 |
+
var cssClasses = cssDef[0].split(',');
|
2502 |
+
var cssProps = cssDef[1].split(';');
|
2503 |
+
for (var j=0; j<cssClasses.length; j++) {
|
2504 |
+
var cssClass = svg.trim(cssClasses[j]);
|
2505 |
+
if (cssClass != '') {
|
2506 |
+
var props = svg.Styles[cssClass] || {};
|
2507 |
+
for (var k=0; k<cssProps.length; k++) {
|
2508 |
+
var prop = cssProps[k].indexOf(':');
|
2509 |
+
var name = cssProps[k].substr(0, prop);
|
2510 |
+
var value = cssProps[k].substr(prop + 1, cssProps[k].length - prop);
|
2511 |
+
if (name != null && value != null) {
|
2512 |
+
props[svg.trim(name)] = new svg.Property(svg.trim(name), svg.trim(value));
|
2513 |
+
}
|
2514 |
+
}
|
2515 |
+
svg.Styles[cssClass] = props;
|
2516 |
+
svg.StylesSpecificity[cssClass] = getSelectorSpecificity(cssClass);
|
2517 |
+
if (cssClass == '@font-face') {
|
2518 |
+
var fontFamily = props['font-family'].value.replace(/"/g,'');
|
2519 |
+
var srcs = props['src'].value.split(',');
|
2520 |
+
for (var s=0; s<srcs.length; s++) {
|
2521 |
+
if (srcs[s].indexOf('format("svg")') > 0) {
|
2522 |
+
var urlStart = srcs[s].indexOf('url');
|
2523 |
+
var urlEnd = srcs[s].indexOf(')', urlStart);
|
2524 |
+
var url = srcs[s].substr(urlStart + 5, urlEnd - urlStart - 6);
|
2525 |
+
var doc = svg.parseXml(svg.ajax(url));
|
2526 |
+
var fonts = doc.getElementsByTagName('font');
|
2527 |
+
for (var f=0; f<fonts.length; f++) {
|
2528 |
+
var font = svg.CreateElement(fonts[f]);
|
2529 |
+
svg.Definitions[fontFamily] = font;
|
2530 |
+
}
|
2531 |
+
}
|
2532 |
+
}
|
2533 |
+
}
|
2534 |
+
}
|
2535 |
+
}
|
2536 |
+
}
|
2537 |
+
}
|
2538 |
+
}
|
2539 |
+
svg.Element.style.prototype = new svg.Element.ElementBase;
|
2540 |
+
|
2541 |
+
// use element
|
2542 |
+
svg.Element.use = function(node) {
|
2543 |
+
this.base = svg.Element.RenderedElementBase;
|
2544 |
+
this.base(node);
|
2545 |
+
|
2546 |
+
this.baseSetContext = this.setContext;
|
2547 |
+
this.setContext = function(ctx) {
|
2548 |
+
this.baseSetContext(ctx);
|
2549 |
+
if (this.attribute('x').hasValue()) ctx.translate(this.attribute('x').toPixels('x'), 0);
|
2550 |
+
if (this.attribute('y').hasValue()) ctx.translate(0, this.attribute('y').toPixels('y'));
|
2551 |
+
}
|
2552 |
+
|
2553 |
+
var element = this.getHrefAttribute().getDefinition();
|
2554 |
+
|
2555 |
+
this.path = function(ctx) {
|
2556 |
+
if (element != null) element.path(ctx);
|
2557 |
+
}
|
2558 |
+
|
2559 |
+
this.getBoundingBox = function() {
|
2560 |
+
if (element != null) return element.getBoundingBox();
|
2561 |
+
}
|
2562 |
+
|
2563 |
+
this.renderChildren = function(ctx) {
|
2564 |
+
if (element != null) {
|
2565 |
+
var tempSvg = element;
|
2566 |
+
if (element.type == 'symbol') {
|
2567 |
+
// render me using a temporary svg element in symbol cases (http://www.w3.org/TR/SVG/struct.html#UseElement)
|
2568 |
+
tempSvg = new svg.Element.svg();
|
2569 |
+
tempSvg.type = 'svg';
|
2570 |
+
tempSvg.attributes['viewBox'] = new svg.Property('viewBox', element.attribute('viewBox').value);
|
2571 |
+
tempSvg.attributes['preserveAspectRatio'] = new svg.Property('preserveAspectRatio', element.attribute('preserveAspectRatio').value);
|
2572 |
+
tempSvg.attributes['overflow'] = new svg.Property('overflow', element.attribute('overflow').value);
|
2573 |
+
tempSvg.children = element.children;
|
2574 |
+
}
|
2575 |
+
if (tempSvg.type == 'svg') {
|
2576 |
+
// if symbol or svg, inherit width/height from me
|
2577 |
+
if (this.attribute('width').hasValue()) tempSvg.attributes['width'] = new svg.Property('width', this.attribute('width').value);
|
2578 |
+
if (this.attribute('height').hasValue()) tempSvg.attributes['height'] = new svg.Property('height', this.attribute('height').value);
|
2579 |
+
}
|
2580 |
+
var oldParent = tempSvg.parent;
|
2581 |
+
tempSvg.parent = null;
|
2582 |
+
tempSvg.render(ctx);
|
2583 |
+
tempSvg.parent = oldParent;
|
2584 |
+
}
|
2585 |
+
}
|
2586 |
+
}
|
2587 |
+
svg.Element.use.prototype = new svg.Element.RenderedElementBase;
|
2588 |
+
|
2589 |
+
// mask element
|
2590 |
+
svg.Element.mask = function(node) {
|
2591 |
+
this.base = svg.Element.ElementBase;
|
2592 |
+
this.base(node);
|
2593 |
+
|
2594 |
+
this.apply = function(ctx, element) {
|
2595 |
+
// render as temp svg
|
2596 |
+
var x = this.attribute('x').toPixels('x');
|
2597 |
+
var y = this.attribute('y').toPixels('y');
|
2598 |
+
var width = this.attribute('width').toPixels('x');
|
2599 |
+
var height = this.attribute('height').toPixels('y');
|
2600 |
+
|
2601 |
+
if (width == 0 && height == 0) {
|
2602 |
+
var bb = new svg.BoundingBox();
|
2603 |
+
for (var i=0; i<this.children.length; i++) {
|
2604 |
+
bb.addBoundingBox(this.children[i].getBoundingBox());
|
2605 |
+
}
|
2606 |
+
var x = Math.floor(bb.x1);
|
2607 |
+
var y = Math.floor(bb.y1);
|
2608 |
+
var width = Math.floor(bb.width());
|
2609 |
+
var height = Math.floor(bb.height());
|
2610 |
+
}
|
2611 |
+
|
2612 |
+
// temporarily remove mask to avoid recursion
|
2613 |
+
var mask = element.attribute('mask').value;
|
2614 |
+
element.attribute('mask').value = '';
|
2615 |
+
|
2616 |
+
var cMask = document.createElement('canvas');
|
2617 |
+
cMask.width = x + width;
|
2618 |
+
cMask.height = y + height;
|
2619 |
+
var maskCtx = cMask.getContext('2d');
|
2620 |
+
this.renderChildren(maskCtx);
|
2621 |
+
|
2622 |
+
var c = document.createElement('canvas');
|
2623 |
+
c.width = x + width;
|
2624 |
+
c.height = y + height;
|
2625 |
+
var tempCtx = c.getContext('2d');
|
2626 |
+
element.render(tempCtx);
|
2627 |
+
tempCtx.globalCompositeOperation = 'destination-in';
|
2628 |
+
tempCtx.fillStyle = maskCtx.createPattern(cMask, 'no-repeat');
|
2629 |
+
tempCtx.fillRect(0, 0, x + width, y + height);
|
2630 |
+
|
2631 |
+
ctx.fillStyle = tempCtx.createPattern(c, 'no-repeat');
|
2632 |
+
ctx.fillRect(0, 0, x + width, y + height);
|
2633 |
+
|
2634 |
+
// reassign mask
|
2635 |
+
element.attribute('mask').value = mask;
|
2636 |
+
}
|
2637 |
+
|
2638 |
+
this.render = function(ctx) {
|
2639 |
+
// NO RENDER
|
2640 |
+
}
|
2641 |
+
}
|
2642 |
+
svg.Element.mask.prototype = new svg.Element.ElementBase;
|
2643 |
+
|
2644 |
+
// clip element
|
2645 |
+
svg.Element.clipPath = function(node) {
|
2646 |
+
this.base = svg.Element.ElementBase;
|
2647 |
+
this.base(node);
|
2648 |
+
|
2649 |
+
this.apply = function(ctx) {
|
2650 |
+
var oldBeginPath = CanvasRenderingContext2D.prototype.beginPath;
|
2651 |
+
CanvasRenderingContext2D.prototype.beginPath = function () { };
|
2652 |
+
|
2653 |
+
var oldClosePath = CanvasRenderingContext2D.prototype.closePath;
|
2654 |
+
CanvasRenderingContext2D.prototype.closePath = function () { };
|
2655 |
+
|
2656 |
+
oldBeginPath.call(ctx);
|
2657 |
+
for (var i=0; i<this.children.length; i++) {
|
2658 |
+
var child = this.children[i];
|
2659 |
+
if (typeof child.path != 'undefined') {
|
2660 |
+
var transform = null;
|
2661 |
+
if (child.style('transform', false, true).hasValue()) {
|
2662 |
+
transform = new svg.Transform(child.style('transform', false, true).value);
|
2663 |
+
transform.apply(ctx);
|
2664 |
+
}
|
2665 |
+
child.path(ctx);
|
2666 |
+
CanvasRenderingContext2D.prototype.closePath = oldClosePath;
|
2667 |
+
if (transform) { transform.unapply(ctx); }
|
2668 |
+
}
|
2669 |
+
}
|
2670 |
+
oldClosePath.call(ctx);
|
2671 |
+
ctx.clip();
|
2672 |
+
|
2673 |
+
CanvasRenderingContext2D.prototype.beginPath = oldBeginPath;
|
2674 |
+
CanvasRenderingContext2D.prototype.closePath = oldClosePath;
|
2675 |
+
}
|
2676 |
+
|
2677 |
+
this.render = function(ctx) {
|
2678 |
+
// NO RENDER
|
2679 |
+
}
|
2680 |
+
}
|
2681 |
+
svg.Element.clipPath.prototype = new svg.Element.ElementBase;
|
2682 |
+
|
2683 |
+
// filters
|
2684 |
+
svg.Element.filter = function(node) {
|
2685 |
+
this.base = svg.Element.ElementBase;
|
2686 |
+
this.base(node);
|
2687 |
+
|
2688 |
+
this.apply = function(ctx, element) {
|
2689 |
+
// render as temp svg
|
2690 |
+
var bb = element.getBoundingBox();
|
2691 |
+
var x = Math.floor(bb.x1);
|
2692 |
+
var y = Math.floor(bb.y1);
|
2693 |
+
var width = Math.floor(bb.width());
|
2694 |
+
var height = Math.floor(bb.height());
|
2695 |
+
|
2696 |
+
// temporarily remove filter to avoid recursion
|
2697 |
+
var filter = element.style('filter').value;
|
2698 |
+
element.style('filter').value = '';
|
2699 |
+
|
2700 |
+
var px = 0, py = 0;
|
2701 |
+
for (var i=0; i<this.children.length; i++) {
|
2702 |
+
var efd = this.children[i].extraFilterDistance || 0;
|
2703 |
+
px = Math.max(px, efd);
|
2704 |
+
py = Math.max(py, efd);
|
2705 |
+
}
|
2706 |
+
|
2707 |
+
var c = document.createElement('canvas');
|
2708 |
+
c.width = width + 2*px;
|
2709 |
+
c.height = height + 2*py;
|
2710 |
+
var tempCtx = c.getContext('2d');
|
2711 |
+
tempCtx.translate(-x + px, -y + py);
|
2712 |
+
element.render(tempCtx);
|
2713 |
+
|
2714 |
+
// apply filters
|
2715 |
+
for (var i=0; i<this.children.length; i++) {
|
2716 |
+
if (typeof this.children[i].apply == 'function') {
|
2717 |
+
this.children[i].apply(tempCtx, 0, 0, width + 2*px, height + 2*py);
|
2718 |
+
}
|
2719 |
+
}
|
2720 |
+
|
2721 |
+
// render on me
|
2722 |
+
ctx.drawImage(c, 0, 0, width + 2*px, height + 2*py, x - px, y - py, width + 2*px, height + 2*py);
|
2723 |
+
|
2724 |
+
// reassign filter
|
2725 |
+
element.style('filter', true).value = filter;
|
2726 |
+
}
|
2727 |
+
|
2728 |
+
this.render = function(ctx) {
|
2729 |
+
// NO RENDER
|
2730 |
+
}
|
2731 |
+
}
|
2732 |
+
svg.Element.filter.prototype = new svg.Element.ElementBase;
|
2733 |
+
|
2734 |
+
svg.Element.feMorphology = function(node) {
|
2735 |
+
this.base = svg.Element.ElementBase;
|
2736 |
+
this.base(node);
|
2737 |
+
|
2738 |
+
this.apply = function(ctx, x, y, width, height) {
|
2739 |
+
// TODO: implement
|
2740 |
+
}
|
2741 |
+
}
|
2742 |
+
svg.Element.feMorphology.prototype = new svg.Element.ElementBase;
|
2743 |
+
|
2744 |
+
svg.Element.feComposite = function(node) {
|
2745 |
+
this.base = svg.Element.ElementBase;
|
2746 |
+
this.base(node);
|
2747 |
+
|
2748 |
+
this.apply = function(ctx, x, y, width, height) {
|
2749 |
+
// TODO: implement
|
2750 |
+
}
|
2751 |
+
}
|
2752 |
+
svg.Element.feComposite.prototype = new svg.Element.ElementBase;
|
2753 |
+
|
2754 |
+
svg.Element.feColorMatrix = function(node) {
|
2755 |
+
this.base = svg.Element.ElementBase;
|
2756 |
+
this.base(node);
|
2757 |
+
|
2758 |
+
var matrix = svg.ToNumberArray(this.attribute('values').value);
|
2759 |
+
switch (this.attribute('type').valueOrDefault('matrix')) { // http://www.w3.org/TR/SVG/filters.html#feColorMatrixElement
|
2760 |
+
case 'saturate':
|
2761 |
+
var s = matrix[0];
|
2762 |
+
matrix = [0.213+0.787*s,0.715-0.715*s,0.072-0.072*s,0,0,
|
2763 |
+
0.213-0.213*s,0.715+0.285*s,0.072-0.072*s,0,0,
|
2764 |
+
0.213-0.213*s,0.715-0.715*s,0.072+0.928*s,0,0,
|
2765 |
+
0,0,0,1,0,
|
2766 |
+
0,0,0,0,1];
|
2767 |
+
break;
|
2768 |
+
case 'hueRotate':
|
2769 |
+
var a = matrix[0] * Math.PI / 180.0;
|
2770 |
+
var c = function (m1,m2,m3) { return m1 + Math.cos(a)*m2 + Math.sin(a)*m3; };
|
2771 |
+
matrix = [c(0.213,0.787,-0.213),c(0.715,-0.715,-0.715),c(0.072,-0.072,0.928),0,0,
|
2772 |
+
c(0.213,-0.213,0.143),c(0.715,0.285,0.140),c(0.072,-0.072,-0.283),0,0,
|
2773 |
+
c(0.213,-0.213,-0.787),c(0.715,-0.715,0.715),c(0.072,0.928,0.072),0,0,
|
2774 |
+
0,0,0,1,0,
|
2775 |
+
0,0,0,0,1];
|
2776 |
+
break;
|
2777 |
+
case 'luminanceToAlpha':
|
2778 |
+
matrix = [0,0,0,0,0,
|
2779 |
+
0,0,0,0,0,
|
2780 |
+
0,0,0,0,0,
|
2781 |
+
0.2125,0.7154,0.0721,0,0,
|
2782 |
+
0,0,0,0,1];
|
2783 |
+
break;
|
2784 |
+
}
|
2785 |
+
|
2786 |
+
function imGet(img, x, y, width, height, rgba) {
|
2787 |
+
return img[y*width*4 + x*4 + rgba];
|
2788 |
+
}
|
2789 |
+
|
2790 |
+
function imSet(img, x, y, width, height, rgba, val) {
|
2791 |
+
img[y*width*4 + x*4 + rgba] = val;
|
2792 |
+
}
|
2793 |
+
|
2794 |
+
function m(i, v) {
|
2795 |
+
var mi = matrix[i];
|
2796 |
+
return mi * (mi < 0 ? v - 255 : v);
|
2797 |
+
}
|
2798 |
+
|
2799 |
+
this.apply = function(ctx, x, y, width, height) {
|
2800 |
+
// assuming x==0 && y==0 for now
|
2801 |
+
var srcData = ctx.getImageData(0, 0, width, height);
|
2802 |
+
for (var y = 0; y < height; y++) {
|
2803 |
+
for (var x = 0; x < width; x++) {
|
2804 |
+
var r = imGet(srcData.data, x, y, width, height, 0);
|
2805 |
+
var g = imGet(srcData.data, x, y, width, height, 1);
|
2806 |
+
var b = imGet(srcData.data, x, y, width, height, 2);
|
2807 |
+
var a = imGet(srcData.data, x, y, width, height, 3);
|
2808 |
+
imSet(srcData.data, x, y, width, height, 0, m(0,r)+m(1,g)+m(2,b)+m(3,a)+m(4,1));
|
2809 |
+
imSet(srcData.data, x, y, width, height, 1, m(5,r)+m(6,g)+m(7,b)+m(8,a)+m(9,1));
|
2810 |
+
imSet(srcData.data, x, y, width, height, 2, m(10,r)+m(11,g)+m(12,b)+m(13,a)+m(14,1));
|
2811 |
+
imSet(srcData.data, x, y, width, height, 3, m(15,r)+m(16,g)+m(17,b)+m(18,a)+m(19,1));
|
2812 |
+
}
|
2813 |
+
}
|
2814 |
+
ctx.clearRect(0, 0, width, height);
|
2815 |
+
ctx.putImageData(srcData, 0, 0);
|
2816 |
+
}
|
2817 |
+
}
|
2818 |
+
svg.Element.feColorMatrix.prototype = new svg.Element.ElementBase;
|
2819 |
+
|
2820 |
+
svg.Element.feGaussianBlur = function(node) {
|
2821 |
+
this.base = svg.Element.ElementBase;
|
2822 |
+
this.base(node);
|
2823 |
+
|
2824 |
+
this.blurRadius = Math.floor(this.attribute('stdDeviation').numValue());
|
2825 |
+
this.extraFilterDistance = this.blurRadius;
|
2826 |
+
|
2827 |
+
this.apply = function(ctx, x, y, width, height) {
|
2828 |
+
if (typeof stackBlur.canvasRGBA == 'undefined') {
|
2829 |
+
svg.log('ERROR: StackBlur.js must be included for blur to work');
|
2830 |
+
return;
|
2831 |
+
}
|
2832 |
+
|
2833 |
+
// StackBlur requires canvas be on document
|
2834 |
+
ctx.canvas.id = svg.UniqueId();
|
2835 |
+
ctx.canvas.style.display = 'none';
|
2836 |
+
document.body.appendChild(ctx.canvas);
|
2837 |
+
stackBlur.canvasRGBA(ctx.canvas.id, x, y, width, height, this.blurRadius);
|
2838 |
+
document.body.removeChild(ctx.canvas);
|
2839 |
+
}
|
2840 |
+
}
|
2841 |
+
svg.Element.feGaussianBlur.prototype = new svg.Element.ElementBase;
|
2842 |
+
|
2843 |
+
// title element, do nothing
|
2844 |
+
svg.Element.title = function(node) {
|
2845 |
+
}
|
2846 |
+
svg.Element.title.prototype = new svg.Element.ElementBase;
|
2847 |
+
|
2848 |
+
// desc element, do nothing
|
2849 |
+
svg.Element.desc = function(node) {
|
2850 |
+
}
|
2851 |
+
svg.Element.desc.prototype = new svg.Element.ElementBase;
|
2852 |
+
|
2853 |
+
svg.Element.MISSING = function(node) {
|
2854 |
+
svg.log('ERROR: Element \'' + node.nodeName + '\' not yet implemented.');
|
2855 |
+
}
|
2856 |
+
svg.Element.MISSING.prototype = new svg.Element.ElementBase;
|
2857 |
+
|
2858 |
+
// element factory
|
2859 |
+
svg.CreateElement = function(node) {
|
2860 |
+
var className = node.nodeName.replace(/^[^:]+:/,''); // remove namespace
|
2861 |
+
className = className.replace(/\-/g,''); // remove dashes
|
2862 |
+
var e = null;
|
2863 |
+
if (typeof svg.Element[className] != 'undefined') {
|
2864 |
+
e = new svg.Element[className](node);
|
2865 |
+
}
|
2866 |
+
else {
|
2867 |
+
e = new svg.Element.MISSING(node);
|
2868 |
+
}
|
2869 |
+
|
2870 |
+
e.type = node.nodeName;
|
2871 |
+
return e;
|
2872 |
+
}
|
2873 |
+
|
2874 |
+
// load from url
|
2875 |
+
svg.load = function(ctx, url) {
|
2876 |
+
svg.loadXml(ctx, svg.ajax(url));
|
2877 |
+
}
|
2878 |
+
|
2879 |
+
// load from xml
|
2880 |
+
svg.loadXml = function(ctx, xml) {
|
2881 |
+
svg.loadXmlDoc(ctx, svg.parseXml(xml));
|
2882 |
+
}
|
2883 |
+
|
2884 |
+
svg.loadXmlDoc = function(ctx, dom) {
|
2885 |
+
svg.init(ctx);
|
2886 |
+
|
2887 |
+
var mapXY = function(p) {
|
2888 |
+
var e = ctx.canvas;
|
2889 |
+
while (e) {
|
2890 |
+
p.x -= e.offsetLeft;
|
2891 |
+
p.y -= e.offsetTop;
|
2892 |
+
e = e.offsetParent;
|
2893 |
+
}
|
2894 |
+
if (window.scrollX) p.x += window.scrollX;
|
2895 |
+
if (window.scrollY) p.y += window.scrollY;
|
2896 |
+
return p;
|
2897 |
+
}
|
2898 |
+
|
2899 |
+
// bind mouse
|
2900 |
+
if (svg.opts['ignoreMouse'] != true) {
|
2901 |
+
ctx.canvas.onclick = function(e) {
|
2902 |
+
var p = mapXY(new svg.Point(e != null ? e.clientX : event.clientX, e != null ? e.clientY : event.clientY));
|
2903 |
+
svg.Mouse.onclick(p.x, p.y);
|
2904 |
+
};
|
2905 |
+
ctx.canvas.onmousemove = function(e) {
|
2906 |
+
var p = mapXY(new svg.Point(e != null ? e.clientX : event.clientX, e != null ? e.clientY : event.clientY));
|
2907 |
+
svg.Mouse.onmousemove(p.x, p.y);
|
2908 |
+
};
|
2909 |
+
}
|
2910 |
+
|
2911 |
+
var e = svg.CreateElement(dom.documentElement);
|
2912 |
+
e.root = true;
|
2913 |
+
e.addStylesFromStyleDefinition();
|
2914 |
+
|
2915 |
+
// render loop
|
2916 |
+
var isFirstRender = true;
|
2917 |
+
var draw = function() {
|
2918 |
+
svg.ViewPort.Clear();
|
2919 |
+
if (ctx.canvas.parentNode) svg.ViewPort.SetCurrent(ctx.canvas.parentNode.clientWidth, ctx.canvas.parentNode.clientHeight);
|
2920 |
+
|
2921 |
+
if (svg.opts['ignoreDimensions'] != true) {
|
2922 |
+
// set canvas size
|
2923 |
+
if (e.style('width').hasValue()) {
|
2924 |
+
ctx.canvas.width = e.style('width').toPixels('x');
|
2925 |
+
ctx.canvas.style.width = ctx.canvas.width + 'px';
|
2926 |
+
}
|
2927 |
+
if (e.style('height').hasValue()) {
|
2928 |
+
ctx.canvas.height = e.style('height').toPixels('y');
|
2929 |
+
ctx.canvas.style.height = ctx.canvas.height + 'px';
|
2930 |
+
}
|
2931 |
+
}
|
2932 |
+
var cWidth = ctx.canvas.clientWidth || ctx.canvas.width;
|
2933 |
+
var cHeight = ctx.canvas.clientHeight || ctx.canvas.height;
|
2934 |
+
if (svg.opts['ignoreDimensions'] == true && e.style('width').hasValue() && e.style('height').hasValue()) {
|
2935 |
+
cWidth = e.style('width').toPixels('x');
|
2936 |
+
cHeight = e.style('height').toPixels('y');
|
2937 |
+
}
|
2938 |
+
svg.ViewPort.SetCurrent(cWidth, cHeight);
|
2939 |
+
|
2940 |
+
if (svg.opts['offsetX'] != null) e.attribute('x', true).value = svg.opts['offsetX'];
|
2941 |
+
if (svg.opts['offsetY'] != null) e.attribute('y', true).value = svg.opts['offsetY'];
|
2942 |
+
if (svg.opts['scaleWidth'] != null || svg.opts['scaleHeight'] != null) {
|
2943 |
+
var xRatio = null, yRatio = null, viewBox = svg.ToNumberArray(e.attribute('viewBox').value);
|
2944 |
+
|
2945 |
+
if (svg.opts['scaleWidth'] != null) {
|
2946 |
+
if (e.attribute('width').hasValue()) xRatio = e.attribute('width').toPixels('x') / svg.opts['scaleWidth'];
|
2947 |
+
else if (!isNaN(viewBox[2])) xRatio = viewBox[2] / svg.opts['scaleWidth'];
|
2948 |
+
}
|
2949 |
+
|
2950 |
+
if (svg.opts['scaleHeight'] != null) {
|
2951 |
+
if (e.attribute('height').hasValue()) yRatio = e.attribute('height').toPixels('y') / svg.opts['scaleHeight'];
|
2952 |
+
else if (!isNaN(viewBox[3])) yRatio = viewBox[3] / svg.opts['scaleHeight'];
|
2953 |
+
}
|
2954 |
+
|
2955 |
+
if (xRatio == null) { xRatio = yRatio; }
|
2956 |
+
if (yRatio == null) { yRatio = xRatio; }
|
2957 |
+
|
2958 |
+
e.attribute('width', true).value = svg.opts['scaleWidth'];
|
2959 |
+
e.attribute('height', true).value = svg.opts['scaleHeight'];
|
2960 |
+
e.style('transform', true, true).value += ' scale('+(1.0/xRatio)+','+(1.0/yRatio)+')';
|
2961 |
+
}
|
2962 |
+
|
2963 |
+
// clear and render
|
2964 |
+
if (svg.opts['ignoreClear'] != true) {
|
2965 |
+
ctx.clearRect(0, 0, cWidth, cHeight);
|
2966 |
+
}
|
2967 |
+
e.render(ctx);
|
2968 |
+
if (isFirstRender) {
|
2969 |
+
isFirstRender = false;
|
2970 |
+
if (typeof svg.opts['renderCallback'] == 'function') svg.opts['renderCallback'](dom);
|
2971 |
+
}
|
2972 |
+
}
|
2973 |
+
|
2974 |
+
var waitingForImages = true;
|
2975 |
+
if (svg.ImagesLoaded()) {
|
2976 |
+
waitingForImages = false;
|
2977 |
+
draw();
|
2978 |
+
}
|
2979 |
+
svg.intervalID = setInterval(function() {
|
2980 |
+
var needUpdate = false;
|
2981 |
+
|
2982 |
+
if (waitingForImages && svg.ImagesLoaded()) {
|
2983 |
+
waitingForImages = false;
|
2984 |
+
needUpdate = true;
|
2985 |
+
}
|
2986 |
+
|
2987 |
+
// need update from mouse events?
|
2988 |
+
if (svg.opts['ignoreMouse'] != true) {
|
2989 |
+
needUpdate = needUpdate | svg.Mouse.hasEvents();
|
2990 |
+
}
|
2991 |
+
|
2992 |
+
// need update from animations?
|
2993 |
+
if (svg.opts['ignoreAnimation'] != true) {
|
2994 |
+
for (var i=0; i<svg.Animations.length; i++) {
|
2995 |
+
needUpdate = needUpdate | svg.Animations[i].update(1000 / svg.FRAMERATE);
|
2996 |
+
}
|
2997 |
+
}
|
2998 |
+
|
2999 |
+
// need update from redraw?
|
3000 |
+
if (typeof svg.opts['forceRedraw'] == 'function') {
|
3001 |
+
if (svg.opts['forceRedraw']() == true) needUpdate = true;
|
3002 |
+
}
|
3003 |
+
|
3004 |
+
// render if needed
|
3005 |
+
if (needUpdate) {
|
3006 |
+
draw();
|
3007 |
+
svg.Mouse.runEvents(); // run and clear our events
|
3008 |
+
}
|
3009 |
+
}, 1000 / svg.FRAMERATE);
|
3010 |
+
}
|
3011 |
+
|
3012 |
+
svg.stop = function() {
|
3013 |
+
if (svg.intervalID) {
|
3014 |
+
clearInterval(svg.intervalID);
|
3015 |
+
}
|
3016 |
+
}
|
3017 |
+
|
3018 |
+
svg.Mouse = new (function() {
|
3019 |
+
this.events = [];
|
3020 |
+
this.hasEvents = function() { return this.events.length != 0; }
|
3021 |
+
|
3022 |
+
this.onclick = function(x, y) {
|
3023 |
+
this.events.push({ type: 'onclick', x: x, y: y,
|
3024 |
+
run: function(e) { if (e.onclick) e.onclick(); }
|
3025 |
+
});
|
3026 |
+
}
|
3027 |
+
|
3028 |
+
this.onmousemove = function(x, y) {
|
3029 |
+
this.events.push({ type: 'onmousemove', x: x, y: y,
|
3030 |
+
run: function(e) { if (e.onmousemove) e.onmousemove(); }
|
3031 |
+
});
|
3032 |
+
}
|
3033 |
+
|
3034 |
+
this.eventElements = [];
|
3035 |
+
|
3036 |
+
this.checkPath = function(element, ctx) {
|
3037 |
+
for (var i=0; i<this.events.length; i++) {
|
3038 |
+
var e = this.events[i];
|
3039 |
+
if (ctx.isPointInPath && ctx.isPointInPath(e.x, e.y)) this.eventElements[i] = element;
|
3040 |
+
}
|
3041 |
+
}
|
3042 |
+
|
3043 |
+
this.checkBoundingBox = function(element, bb) {
|
3044 |
+
for (var i=0; i<this.events.length; i++) {
|
3045 |
+
var e = this.events[i];
|
3046 |
+
if (bb.isPointInBox(e.x, e.y)) this.eventElements[i] = element;
|
3047 |
+
}
|
3048 |
+
}
|
3049 |
+
|
3050 |
+
this.runEvents = function() {
|
3051 |
+
svg.ctx.canvas.style.cursor = '';
|
3052 |
+
|
3053 |
+
for (var i=0; i<this.events.length; i++) {
|
3054 |
+
var e = this.events[i];
|
3055 |
+
var element = this.eventElements[i];
|
3056 |
+
while (element) {
|
3057 |
+
e.run(element);
|
3058 |
+
element = element.parent;
|
3059 |
+
}
|
3060 |
+
}
|
3061 |
+
|
3062 |
+
// done running, clear
|
3063 |
+
this.events = [];
|
3064 |
+
this.eventElements = [];
|
3065 |
+
}
|
3066 |
+
});
|
3067 |
+
|
3068 |
+
return svg;
|
3069 |
+
};
|
3070 |
+
|
3071 |
+
if (typeof CanvasRenderingContext2D != 'undefined') {
|
3072 |
+
CanvasRenderingContext2D.prototype.drawSvg = function(s, dx, dy, dw, dh, opts) {
|
3073 |
+
var cOpts = {
|
3074 |
+
ignoreMouse: true,
|
3075 |
+
ignoreAnimation: true,
|
3076 |
+
ignoreDimensions: true,
|
3077 |
+
ignoreClear: true,
|
3078 |
+
offsetX: dx,
|
3079 |
+
offsetY: dy,
|
3080 |
+
scaleWidth: dw,
|
3081 |
+
scaleHeight: dh
|
3082 |
+
}
|
3083 |
+
|
3084 |
+
for(var prop in opts) {
|
3085 |
+
if(opts.hasOwnProperty(prop)){
|
3086 |
+
cOpts[prop] = opts[prop];
|
3087 |
+
}
|
3088 |
+
}
|
3089 |
+
canvg(this.canvas, s, cOpts);
|
3090 |
+
}
|
3091 |
+
}
|
3092 |
+
|
3093 |
+
return canvg;
|
3094 |
+
|
3095 |
+
}));
|
inc/js/chosen.jquery.js
CHANGED
@@ -1,1285 +1,1285 @@
|
|
1 |
-
/*!
|
2 |
-
Chosen, a Select Box Enhancer for jQuery and Prototype
|
3 |
-
by Patrick Filler for Harvest, http://getharvest.com
|
4 |
-
|
5 |
-
Version 1.5.1
|
6 |
-
Full source at https://github.com/harvesthq/chosen
|
7 |
-
Copyright (c) 2011-2016 Harvest http://getharvest.com
|
8 |
-
|
9 |
-
MIT License, https://github.com/harvesthq/chosen/blob/master/LICENSE.md
|
10 |
-
This file is generated by `grunt build`, do not edit it by hand.
|
11 |
-
*/
|
12 |
-
|
13 |
-
(function() {
|
14 |
-
var $, AbstractChosen, Chosen, SelectParser, _ref,
|
15 |
-
__hasProp = {}.hasOwnProperty,
|
16 |
-
__extends = function(child, parent) { for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; };
|
17 |
-
|
18 |
-
SelectParser = (function() {
|
19 |
-
function SelectParser() {
|
20 |
-
this.options_index = 0;
|
21 |
-
this.parsed = [];
|
22 |
-
}
|
23 |
-
|
24 |
-
SelectParser.prototype.add_node = function(child) {
|
25 |
-
if (child.nodeName.toUpperCase() === "OPTGROUP") {
|
26 |
-
return this.add_group(child);
|
27 |
-
} else {
|
28 |
-
return this.add_option(child);
|
29 |
-
}
|
30 |
-
};
|
31 |
-
|
32 |
-
SelectParser.prototype.add_group = function(group) {
|
33 |
-
var group_position, option, _i, _len, _ref, _results;
|
34 |
-
group_position = this.parsed.length;
|
35 |
-
this.parsed.push({
|
36 |
-
array_index: group_position,
|
37 |
-
group: true,
|
38 |
-
label: this.escapeExpression(group.label),
|
39 |
-
title: group.title ? group.title : void 0,
|
40 |
-
children: 0,
|
41 |
-
disabled: group.disabled,
|
42 |
-
classes: group.className
|
43 |
-
});
|
44 |
-
_ref = group.childNodes;
|
45 |
-
_results = [];
|
46 |
-
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
47 |
-
option = _ref[_i];
|
48 |
-
_results.push(this.add_option(option, group_position, group.disabled));
|
49 |
-
}
|
50 |
-
return _results;
|
51 |
-
};
|
52 |
-
|
53 |
-
SelectParser.prototype.add_option = function(option, group_position, group_disabled) {
|
54 |
-
if (option.nodeName.toUpperCase() === "OPTION") {
|
55 |
-
if (option.text !== "") {
|
56 |
-
if (group_position != null) {
|
57 |
-
this.parsed[group_position].children += 1;
|
58 |
-
}
|
59 |
-
this.parsed.push({
|
60 |
-
array_index: this.parsed.length,
|
61 |
-
options_index: this.options_index,
|
62 |
-
value: option.value,
|
63 |
-
text: option.text,
|
64 |
-
html: option.innerHTML,
|
65 |
-
title: option.title ? option.title : void 0,
|
66 |
-
selected: option.selected,
|
67 |
-
disabled: group_disabled === true ? group_disabled : option.disabled,
|
68 |
-
group_array_index: group_position,
|
69 |
-
group_label: group_position != null ? this.parsed[group_position].label : null,
|
70 |
-
classes: option.className,
|
71 |
-
style: option.style.cssText
|
72 |
-
});
|
73 |
-
} else {
|
74 |
-
this.parsed.push({
|
75 |
-
array_index: this.parsed.length,
|
76 |
-
options_index: this.options_index,
|
77 |
-
empty: true
|
78 |
-
});
|
79 |
-
}
|
80 |
-
return this.options_index += 1;
|
81 |
-
}
|
82 |
-
};
|
83 |
-
|
84 |
-
SelectParser.prototype.escapeExpression = function(text) {
|
85 |
-
var map, unsafe_chars;
|
86 |
-
if ((text == null) || text === false) {
|
87 |
-
return "";
|
88 |
-
}
|
89 |
-
if (!/[\&\<\>\"\'\`]/.test(text)) {
|
90 |
-
return text;
|
91 |
-
}
|
92 |
-
map = {
|
93 |
-
"<": "<",
|
94 |
-
">": ">",
|
95 |
-
'"': """,
|
96 |
-
"'": "'",
|
97 |
-
"`": "`"
|
98 |
-
};
|
99 |
-
unsafe_chars = /&(?!\w+;)|[\<\>\"\'\`]/g;
|
100 |
-
return text.replace(unsafe_chars, function(chr) {
|
101 |
-
return map[chr] || "&";
|
102 |
-
});
|
103 |
-
};
|
104 |
-
|
105 |
-
return SelectParser;
|
106 |
-
|
107 |
-
})();
|
108 |
-
|
109 |
-
SelectParser.select_to_array = function(select) {
|
110 |
-
var child, parser, _i, _len, _ref;
|
111 |
-
parser = new SelectParser();
|
112 |
-
_ref = select.childNodes;
|
113 |
-
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
114 |
-
child = _ref[_i];
|
115 |
-
parser.add_node(child);
|
116 |
-
}
|
117 |
-
return parser.parsed;
|
118 |
-
};
|
119 |
-
|
120 |
-
AbstractChosen = (function() {
|
121 |
-
function AbstractChosen(form_field, options) {
|
122 |
-
this.form_field = form_field;
|
123 |
-
this.options = options != null ? options : {};
|
124 |
-
if (!AbstractChosen.browser_is_supported()) {
|
125 |
-
return;
|
126 |
-
}
|
127 |
-
this.is_multiple = this.form_field.multiple;
|
128 |
-
this.set_default_text();
|
129 |
-
this.set_default_values();
|
130 |
-
this.setup();
|
131 |
-
this.set_up_html();
|
132 |
-
this.register_observers();
|
133 |
-
this.on_ready();
|
134 |
-
}
|
135 |
-
|
136 |
-
AbstractChosen.prototype.set_default_values = function() {
|
137 |
-
var _this = this;
|
138 |
-
this.click_test_action = function(evt) {
|
139 |
-
return _this.test_active_click(evt);
|
140 |
-
};
|
141 |
-
this.activate_action = function(evt) {
|
142 |
-
return _this.activate_field(evt);
|
143 |
-
};
|
144 |
-
this.active_field = false;
|
145 |
-
this.mouse_on_container = false;
|
146 |
-
this.results_showing = false;
|
147 |
-
this.result_highlighted = null;
|
148 |
-
this.allow_single_deselect = (this.options.allow_single_deselect != null) && (this.form_field.options[0] != null) && this.form_field.options[0].text === "" ? this.options.allow_single_deselect : false;
|
149 |
-
this.disable_search_threshold = this.options.disable_search_threshold || 0;
|
150 |
-
this.disable_search = this.options.disable_search || false;
|
151 |
-
this.enable_split_word_search = this.options.enable_split_word_search != null ? this.options.enable_split_word_search : true;
|
152 |
-
this.group_search = this.options.group_search != null ? this.options.group_search : true;
|
153 |
-
this.search_contains = this.options.search_contains || false;
|
154 |
-
this.single_backstroke_delete = this.options.single_backstroke_delete != null ? this.options.single_backstroke_delete : true;
|
155 |
-
this.max_selected_options = this.options.max_selected_options || Infinity;
|
156 |
-
this.inherit_select_classes = this.options.inherit_select_classes || false;
|
157 |
-
this.display_selected_options = this.options.display_selected_options != null ? this.options.display_selected_options : true;
|
158 |
-
this.display_disabled_options = this.options.display_disabled_options != null ? this.options.display_disabled_options : true;
|
159 |
-
this.include_group_label_in_selected = this.options.include_group_label_in_selected || false;
|
160 |
-
return this.max_shown_results = this.options.max_shown_results || Number.POSITIVE_INFINITY;
|
161 |
-
};
|
162 |
-
|
163 |
-
AbstractChosen.prototype.set_default_text = function() {
|
164 |
-
if (this.form_field.getAttribute("data-placeholder")) {
|
165 |
-
this.default_text = this.form_field.getAttribute("data-placeholder");
|
166 |
-
} else if (this.is_multiple) {
|
167 |
-
this.default_text = this.options.placeholder_text_multiple || this.options.placeholder_text || AbstractChosen.default_multiple_text;
|
168 |
-
} else {
|
169 |
-
this.default_text = this.options.placeholder_text_single || this.options.placeholder_text || AbstractChosen.default_single_text;
|
170 |
-
}
|
171 |
-
return this.results_none_found = this.form_field.getAttribute("data-no_results_text") || this.options.no_results_text || AbstractChosen.default_no_result_text;
|
172 |
-
};
|
173 |
-
|
174 |
-
AbstractChosen.prototype.choice_label = function(item) {
|
175 |
-
if (this.include_group_label_in_selected && (item.group_label != null)) {
|
176 |
-
return "<b class='group-name'>" + item.group_label + "</b>" + item.html;
|
177 |
-
} else {
|
178 |
-
return item.html;
|
179 |
-
}
|
180 |
-
};
|
181 |
-
|
182 |
-
AbstractChosen.prototype.mouse_enter = function() {
|
183 |
-
return this.mouse_on_container = true;
|
184 |
-
};
|
185 |
-
|
186 |
-
AbstractChosen.prototype.mouse_leave = function() {
|
187 |
-
return this.mouse_on_container = false;
|
188 |
-
};
|
189 |
-
|
190 |
-
AbstractChosen.prototype.input_focus = function(evt) {
|
191 |
-
var _this = this;
|
192 |
-
if (this.is_multiple) {
|
193 |
-
if (!this.active_field) {
|
194 |
-
return setTimeout((function() {
|
195 |
-
return _this.container_mousedown();
|
196 |
-
}), 50);
|
197 |
-
}
|
198 |
-
} else {
|
199 |
-
if (!this.active_field) {
|
200 |
-
return this.activate_field();
|
201 |
-
}
|
202 |
-
}
|
203 |
-
};
|
204 |
-
|
205 |
-
AbstractChosen.prototype.input_blur = function(evt) {
|
206 |
-
var _this = this;
|
207 |
-
if (!this.mouse_on_container) {
|
208 |
-
this.active_field = false;
|
209 |
-
return setTimeout((function() {
|
210 |
-
return _this.blur_test();
|
211 |
-
}), 100);
|
212 |
-
}
|
213 |
-
};
|
214 |
-
|
215 |
-
AbstractChosen.prototype.results_option_build = function(options) {
|
216 |
-
var content, data, data_content, shown_results, _i, _len, _ref;
|
217 |
-
content = '';
|
218 |
-
shown_results = 0;
|
219 |
-
_ref = this.results_data;
|
220 |
-
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
221 |
-
data = _ref[_i];
|
222 |
-
data_content = '';
|
223 |
-
if (data.group) {
|
224 |
-
data_content = this.result_add_group(data);
|
225 |
-
} else {
|
226 |
-
data_content = this.result_add_option(data);
|
227 |
-
}
|
228 |
-
if (data_content !== '') {
|
229 |
-
shown_results++;
|
230 |
-
content += data_content;
|
231 |
-
}
|
232 |
-
if (options != null ? options.first : void 0) {
|
233 |
-
if (data.selected && this.is_multiple) {
|
234 |
-
this.choice_build(data);
|
235 |
-
} else if (data.selected && !this.is_multiple) {
|
236 |
-
this.single_set_selected_text(this.choice_label(data));
|
237 |
-
}
|
238 |
-
}
|
239 |
-
if (shown_results >= this.max_shown_results) {
|
240 |
-
break;
|
241 |
-
}
|
242 |
-
}
|
243 |
-
return content;
|
244 |
-
};
|
245 |
-
|
246 |
-
AbstractChosen.prototype.result_add_option = function(option) {
|
247 |
-
var classes, option_el;
|
248 |
-
if (!option.search_match) {
|
249 |
-
return '';
|
250 |
-
}
|
251 |
-
if (!this.include_option_in_results(option)) {
|
252 |
-
return '';
|
253 |
-
}
|
254 |
-
classes = [];
|
255 |
-
if (!option.disabled && !(option.selected && this.is_multiple)) {
|
256 |
-
classes.push("active-result");
|
257 |
-
}
|
258 |
-
if (option.disabled && !(option.selected && this.is_multiple)) {
|
259 |
-
classes.push("disabled-result");
|
260 |
-
}
|
261 |
-
if (option.selected) {
|
262 |
-
classes.push("result-selected");
|
263 |
-
}
|
264 |
-
if (option.group_array_index != null) {
|
265 |
-
classes.push("group-option");
|
266 |
-
}
|
267 |
-
if (option.classes !== "") {
|
268 |
-
classes.push(option.classes);
|
269 |
-
}
|
270 |
-
option_el = document.createElement("li");
|
271 |
-
option_el.className = classes.join(" ");
|
272 |
-
option_el.style.cssText = option.style;
|
273 |
-
option_el.setAttribute("data-option-array-index", option.array_index);
|
274 |
-
option_el.innerHTML = option.search_text;
|
275 |
-
if (option.title) {
|
276 |
-
option_el.title = option.title;
|
277 |
-
}
|
278 |
-
return this.outerHTML(option_el);
|
279 |
-
};
|
280 |
-
|
281 |
-
AbstractChosen.prototype.result_add_group = function(group) {
|
282 |
-
var classes, group_el;
|
283 |
-
if (!(group.search_match || group.group_match)) {
|
284 |
-
return '';
|
285 |
-
}
|
286 |
-
if (!(group.active_options > 0)) {
|
287 |
-
return '';
|
288 |
-
}
|
289 |
-
classes = [];
|
290 |
-
classes.push("group-result");
|
291 |
-
if (group.classes) {
|
292 |
-
classes.push(group.classes);
|
293 |
-
}
|
294 |
-
group_el = document.createElement("li");
|
295 |
-
group_el.className = classes.join(" ");
|
296 |
-
group_el.innerHTML = group.search_text;
|
297 |
-
if (group.title) {
|
298 |
-
group_el.title = group.title;
|
299 |
-
}
|
300 |
-
return this.outerHTML(group_el);
|
301 |
-
};
|
302 |
-
|
303 |
-
AbstractChosen.prototype.results_update_field = function() {
|
304 |
-
this.set_default_text();
|
305 |
-
if (!this.is_multiple) {
|
306 |
-
this.results_reset_cleanup();
|
307 |
-
}
|
308 |
-
this.result_clear_highlight();
|
309 |
-
this.results_build();
|
310 |
-
if (this.results_showing) {
|
311 |
-
return this.winnow_results();
|
312 |
-
}
|
313 |
-
};
|
314 |
-
|
315 |
-
AbstractChosen.prototype.reset_single_select_options = function() {
|
316 |
-
var result, _i, _len, _ref, _results;
|
317 |
-
_ref = this.results_data;
|
318 |
-
_results = [];
|
319 |
-
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
320 |
-
result = _ref[_i];
|
321 |
-
if (result.selected) {
|
322 |
-
_results.push(result.selected = false);
|
323 |
-
} else {
|
324 |
-
_results.push(void 0);
|
325 |
-
}
|
326 |
-
}
|
327 |
-
return _results;
|
328 |
-
};
|
329 |
-
|
330 |
-
AbstractChosen.prototype.results_toggle = function() {
|
331 |
-
if (this.results_showing) {
|
332 |
-
return this.results_hide();
|
333 |
-
} else {
|
334 |
-
return this.results_show();
|
335 |
-
}
|
336 |
-
};
|
337 |
-
|
338 |
-
AbstractChosen.prototype.results_search = function(evt) {
|
339 |
-
if (this.results_showing) {
|
340 |
-
return this.winnow_results();
|
341 |
-
} else {
|
342 |
-
return this.results_show();
|
343 |
-
}
|
344 |
-
};
|
345 |
-
|
346 |
-
AbstractChosen.prototype.winnow_results = function() {
|
347 |
-
var escapedSearchText, option, regex, results, results_group, searchText, startpos, text, zregex, _i, _len, _ref;
|
348 |
-
this.no_results_clear();
|
349 |
-
results = 0;
|
350 |
-
searchText = this.get_search_text();
|
351 |
-
escapedSearchText = searchText.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, "\\$&");
|
352 |
-
zregex = new RegExp(escapedSearchText, 'i');
|
353 |
-
regex = this.get_search_regex(escapedSearchText);
|
354 |
-
_ref = this.results_data;
|
355 |
-
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
356 |
-
option = _ref[_i];
|
357 |
-
option.search_match = false;
|
358 |
-
results_group = null;
|
359 |
-
if (this.include_option_in_results(option)) {
|
360 |
-
if (option.group) {
|
361 |
-
option.group_match = false;
|
362 |
-
option.active_options = 0;
|
363 |
-
}
|
364 |
-
if ((option.group_array_index != null) && this.results_data[option.group_array_index]) {
|
365 |
-
results_group = this.results_data[option.group_array_index];
|
366 |
-
if (results_group.active_options === 0 && results_group.search_match) {
|
367 |
-
results += 1;
|
368 |
-
}
|
369 |
-
results_group.active_options += 1;
|
370 |
-
}
|
371 |
-
option.search_text = option.group ? option.label : option.html;
|
372 |
-
if (!(option.group && !this.group_search)) {
|
373 |
-
option.search_match = this.search_string_match(option.search_text, regex);
|
374 |
-
if (option.search_match && !option.group) {
|
375 |
-
results += 1;
|
376 |
-
}
|
377 |
-
if (option.search_match) {
|
378 |
-
if (searchText.length) {
|
379 |
-
startpos = option.search_text.search(zregex);
|
380 |
-
text = option.search_text.substr(0, startpos + searchText.length) + '</em>' + option.search_text.substr(startpos + searchText.length);
|
381 |
-
option.search_text = text.substr(0, startpos) + '<em>' + text.substr(startpos);
|
382 |
-
}
|
383 |
-
if (results_group != null) {
|
384 |
-
results_group.group_match = true;
|
385 |
-
}
|
386 |
-
} else if ((option.group_array_index != null) && this.results_data[option.group_array_index].search_match) {
|
387 |
-
option.search_match = true;
|
388 |
-
}
|
389 |
-
}
|
390 |
-
}
|
391 |
-
}
|
392 |
-
this.result_clear_highlight();
|
393 |
-
if (results < 1 && searchText.length) {
|
394 |
-
this.update_results_content("");
|
395 |
-
return this.no_results(searchText);
|
396 |
-
} else {
|
397 |
-
this.update_results_content(this.results_option_build());
|
398 |
-
return this.winnow_results_set_highlight();
|
399 |
-
}
|
400 |
-
};
|
401 |
-
|
402 |
-
AbstractChosen.prototype.get_search_regex = function(escaped_search_string) {
|
403 |
-
var regex_anchor;
|
404 |
-
regex_anchor = this.search_contains ? "" : "^";
|
405 |
-
return new RegExp(regex_anchor + escaped_search_string, 'i');
|
406 |
-
};
|
407 |
-
|
408 |
-
AbstractChosen.prototype.search_string_match = function(search_string, regex) {
|
409 |
-
var part, parts, _i, _len;
|
410 |
-
if (regex.test(search_string)) {
|
411 |
-
return true;
|
412 |
-
} else if (this.enable_split_word_search && (search_string.indexOf(" ") >= 0 || search_string.indexOf("[") === 0)) {
|
413 |
-
parts = search_string.replace(/\[|\]/g, "").split(" ");
|
414 |
-
if (parts.length) {
|
415 |
-
for (_i = 0, _len = parts.length; _i < _len; _i++) {
|
416 |
-
part = parts[_i];
|
417 |
-
if (regex.test(part)) {
|
418 |
-
return true;
|
419 |
-
}
|
420 |
-
}
|
421 |
-
}
|
422 |
-
}
|
423 |
-
};
|
424 |
-
|
425 |
-
AbstractChosen.prototype.choices_count = function() {
|
426 |
-
var option, _i, _len, _ref;
|
427 |
-
if (this.selected_option_count != null) {
|
428 |
-
return this.selected_option_count;
|
429 |
-
}
|
430 |
-
this.selected_option_count = 0;
|
431 |
-
_ref = this.form_field.options;
|
432 |
-
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
433 |
-
option = _ref[_i];
|
434 |
-
if (option.selected) {
|
435 |
-
this.selected_option_count += 1;
|
436 |
-
}
|
437 |
-
}
|
438 |
-
return this.selected_option_count;
|
439 |
-
};
|
440 |
-
|
441 |
-
AbstractChosen.prototype.choices_click = function(evt) {
|
442 |
-
evt.preventDefault();
|
443 |
-
if (!(this.results_showing || this.is_disabled)) {
|
444 |
-
return this.results_show();
|
445 |
-
}
|
446 |
-
};
|
447 |
-
|
448 |
-
AbstractChosen.prototype.keyup_checker = function(evt) {
|
449 |
-
var stroke, _ref;
|
450 |
-
stroke = (_ref = evt.which) != null ? _ref : evt.keyCode;
|
451 |
-
this.search_field_scale();
|
452 |
-
switch (stroke) {
|
453 |
-
case 8:
|
454 |
-
if (this.is_multiple && this.backstroke_length < 1 && this.choices_count() > 0) {
|
455 |
-
return this.keydown_backstroke();
|
456 |
-
} else if (!this.pending_backstroke) {
|
457 |
-
this.result_clear_highlight();
|
458 |
-
return this.results_search();
|
459 |
-
}
|
460 |
-
break;
|
461 |
-
case 13:
|
462 |
-
evt.preventDefault();
|
463 |
-
if (this.results_showing) {
|
464 |
-
return this.result_select(evt);
|
465 |
-
}
|
466 |
-
break;
|
467 |
-
case 27:
|
468 |
-
if (this.results_showing) {
|
469 |
-
this.results_hide();
|
470 |
-
}
|
471 |
-
return true;
|
472 |
-
case 9:
|
473 |
-
case 38:
|
474 |
-
case 40:
|
475 |
-
case 16:
|
476 |
-
case 91:
|
477 |
-
case 17:
|
478 |
-
case 18:
|
479 |
-
break;
|
480 |
-
default:
|
481 |
-
return this.results_search();
|
482 |
-
}
|
483 |
-
};
|
484 |
-
|
485 |
-
AbstractChosen.prototype.clipboard_event_checker = function(evt) {
|
486 |
-
var _this = this;
|
487 |
-
return setTimeout((function() {
|
488 |
-
return _this.results_search();
|
489 |
-
}), 50);
|
490 |
-
};
|
491 |
-
|
492 |
-
AbstractChosen.prototype.container_width = function() {
|
493 |
-
if (this.options.width != null) {
|
494 |
-
return this.options.width;
|
495 |
-
} else {
|
496 |
-
//return "" + this.form_field.offsetWidth + "px";
|
497 |
-
return "100%";
|
498 |
-
}
|
499 |
-
};
|
500 |
-
|
501 |
-
AbstractChosen.prototype.include_option_in_results = function(option) {
|
502 |
-
if (this.is_multiple && (!this.display_selected_options && option.selected)) {
|
503 |
-
return false;
|
504 |
-
}
|
505 |
-
if (!this.display_disabled_options && option.disabled) {
|
506 |
-
return false;
|
507 |
-
}
|
508 |
-
if (option.empty) {
|
509 |
-
return false;
|
510 |
-
}
|
511 |
-
return true;
|
512 |
-
};
|
513 |
-
|
514 |
-
AbstractChosen.prototype.search_results_touchstart = function(evt) {
|
515 |
-
this.touch_started = true;
|
516 |
-
return this.search_results_mouseover(evt);
|
517 |
-
};
|
518 |
-
|
519 |
-
AbstractChosen.prototype.search_results_touchmove = function(evt) {
|
520 |
-
this.touch_started = false;
|
521 |
-
return this.search_results_mouseout(evt);
|
522 |
-
};
|
523 |
-
|
524 |
-
AbstractChosen.prototype.search_results_touchend = function(evt) {
|
525 |
-
if (this.touch_started) {
|
526 |
-
return this.search_results_mouseup(evt);
|
527 |
-
}
|
528 |
-
};
|
529 |
-
|
530 |
-
AbstractChosen.prototype.outerHTML = function(element) {
|
531 |
-
var tmp;
|
532 |
-
if (element.outerHTML) {
|
533 |
-
return element.outerHTML;
|
534 |
-
}
|
535 |
-
tmp = document.createElement("div");
|
536 |
-
tmp.appendChild(element);
|
537 |
-
return tmp.innerHTML;
|
538 |
-
};
|
539 |
-
|
540 |
-
AbstractChosen.browser_is_supported = function() {
|
541 |
-
if (/iP(od|hone)/i.test(window.navigator.userAgent)) {
|
542 |
-
return false;
|
543 |
-
}
|
544 |
-
if (/Android/i.test(window.navigator.userAgent)) {
|
545 |
-
if (/Mobile/i.test(window.navigator.userAgent)) {
|
546 |
-
return false;
|
547 |
-
}
|
548 |
-
}
|
549 |
-
if (/IEMobile/i.test(window.navigator.userAgent)) {
|
550 |
-
return false;
|
551 |
-
}
|
552 |
-
if (/Windows Phone/i.test(window.navigator.userAgent)) {
|
553 |
-
return false;
|
554 |
-
}
|
555 |
-
if (/BlackBerry/i.test(window.navigator.userAgent)) {
|
556 |
-
return false;
|
557 |
-
}
|
558 |
-
if (/BB10/i.test(window.navigator.userAgent)) {
|
559 |
-
return false;
|
560 |
-
}
|
561 |
-
if (window.navigator.appName === "Microsoft Internet Explorer") {
|
562 |
-
return document.documentMode >= 8;
|
563 |
-
}
|
564 |
-
return true;
|
565 |
-
};
|
566 |
-
|
567 |
-
AbstractChosen.default_multiple_text = "Select report";
|
568 |
-
|
569 |
-
AbstractChosen.default_single_text = "Select an Option";
|
570 |
-
|
571 |
-
AbstractChosen.default_no_result_text = "No results match";
|
572 |
-
|
573 |
-
return AbstractChosen;
|
574 |
-
|
575 |
-
})();
|
576 |
-
|
577 |
-
$ = jQuery;
|
578 |
-
|
579 |
-
$.fn.extend({
|
580 |
-
chosen: function(options) {
|
581 |
-
if (!AbstractChosen.browser_is_supported()) {
|
582 |
-
return this;
|
583 |
-
}
|
584 |
-
return this.each(function(input_field) {
|
585 |
-
var $this, chosen;
|
586 |
-
$this = $(this);
|
587 |
-
chosen = $this.data('chosen');
|
588 |
-
if (options === 'destroy') {
|
589 |
-
if (chosen instanceof Chosen) {
|
590 |
-
chosen.destroy();
|
591 |
-
}
|
592 |
-
return;
|
593 |
-
}
|
594 |
-
if (!(chosen instanceof Chosen)) {
|
595 |
-
$this.data('chosen', new Chosen(this, options));
|
596 |
-
}
|
597 |
-
});
|
598 |
-
}
|
599 |
-
});
|
600 |
-
|
601 |
-
Chosen = (function(_super) {
|
602 |
-
__extends(Chosen, _super);
|
603 |
-
|
604 |
-
function Chosen() {
|
605 |
-
_ref = Chosen.__super__.constructor.apply(this, arguments);
|
606 |
-
return _ref;
|
607 |
-
}
|
608 |
-
|
609 |
-
Chosen.prototype.setup = function() {
|
610 |
-
this.form_field_jq = $(this.form_field);
|
611 |
-
this.current_selectedIndex = this.form_field.selectedIndex;
|
612 |
-
return this.is_rtl = this.form_field_jq.hasClass("chosen-rtl");
|
613 |
-
};
|
614 |
-
|
615 |
-
Chosen.prototype.set_up_html = function() {
|
616 |
-
var container_classes, container_props;
|
617 |
-
container_classes = ["chosen-container"];
|
618 |
-
container_classes.push("chosen-container-" + (this.is_multiple ? "multi" : "single"));
|
619 |
-
if (this.inherit_select_classes && this.form_field.className) {
|
620 |
-
container_classes.push(this.form_field.className);
|
621 |
-
}
|
622 |
-
if (this.is_rtl) {
|
623 |
-
container_classes.push("chosen-rtl");
|
624 |
-
}
|
625 |
-
container_props = {
|
626 |
-
'class': container_classes.join(' '),
|
627 |
-
'style': "width: " + (this.container_width()) + ";",
|
628 |
-
'title': this.form_field.title
|
629 |
-
};
|
630 |
-
if (this.form_field.id.length) {
|
631 |
-
container_props.id = this.form_field.id.replace(/[^\w]/g, '_') + "_chosen";
|
632 |
-
}
|
633 |
-
this.container = $("<div />", container_props);
|
634 |
-
if (this.is_multiple) {
|
635 |
-
this.container.html('<ul class="chosen-choices"><li class="search-field"><input type="text" value="' + this.default_text + '" class="default" autocomplete="off" style="width:25px;" /></li></ul><div class="chosen-drop"><ul class="chosen-results"></ul></div>');
|
636 |
-
} else {
|
637 |
-
this.container.html('<a class="chosen-single chosen-default"><span>' + this.default_text + '</span><div><b></b></div></a><div class="chosen-drop"><div class="chosen-search"><input type="text" autocomplete="off" /></div><ul class="chosen-results"></ul></div>');
|
638 |
-
}
|
639 |
-
this.form_field_jq.hide().after(this.container);
|
640 |
-
this.dropdown = this.container.find('div.chosen-drop').first();
|
641 |
-
this.search_field = this.container.find('input').first();
|
642 |
-
this.search_results = this.container.find('ul.chosen-results').first();
|
643 |
-
this.search_field_scale();
|
644 |
-
this.search_no_results = this.container.find('li.no-results').first();
|
645 |
-
if (this.is_multiple) {
|
646 |
-
this.search_choices = this.container.find('ul.chosen-choices').first();
|
647 |
-
this.search_container = this.container.find('li.search-field').first();
|
648 |
-
} else {
|
649 |
-
this.search_container = this.container.find('div.chosen-search').first();
|
650 |
-
this.selected_item = this.container.find('.chosen-single').first();
|
651 |
-
}
|
652 |
-
this.results_build();
|
653 |
-
this.set_tab_index();
|
654 |
-
return this.set_label_behavior();
|
655 |
-
};
|
656 |
-
|
657 |
-
Chosen.prototype.on_ready = function() {
|
658 |
-
return this.form_field_jq.trigger("chosen:ready", {
|
659 |
-
chosen: this
|
660 |
-
});
|
661 |
-
};
|
662 |
-
|
663 |
-
Chosen.prototype.register_observers = function() {
|
664 |
-
var _this = this;
|
665 |
-
this.container.bind('touchstart.chosen', function(evt) {
|
666 |
-
_this.container_mousedown(evt);
|
667 |
-
return evt.preventDefault();
|
668 |
-
});
|
669 |
-
this.container.bind('touchend.chosen', function(evt) {
|
670 |
-
_this.container_mouseup(evt);
|
671 |
-
return evt.preventDefault();
|
672 |
-
});
|
673 |
-
this.container.bind('mousedown.chosen', function(evt) {
|
674 |
-
_this.container_mousedown(evt);
|
675 |
-
});
|
676 |
-
this.container.bind('mouseup.chosen', function(evt) {
|
677 |
-
_this.container_mouseup(evt);
|
678 |
-
});
|
679 |
-
this.container.bind('mouseenter.chosen', function(evt) {
|
680 |
-
_this.mouse_enter(evt);
|
681 |
-
});
|
682 |
-
this.container.bind('mouseleave.chosen', function(evt) {
|
683 |
-
_this.mouse_leave(evt);
|
684 |
-
});
|
685 |
-
this.search_results.bind('mouseup.chosen', function(evt) {
|
686 |
-
_this.search_results_mouseup(evt);
|
687 |
-
});
|
688 |
-
this.search_results.bind('mouseover.chosen', function(evt) {
|
689 |
-
_this.search_results_mouseover(evt);
|
690 |
-
});
|
691 |
-
this.search_results.bind('mouseout.chosen', function(evt) {
|
692 |
-
_this.search_results_mouseout(evt);
|
693 |
-
});
|
694 |
-
this.search_results.bind('mousewheel.chosen DOMMouseScroll.chosen', function(evt) {
|
695 |
-
_this.search_results_mousewheel(evt);
|
696 |
-
});
|
697 |
-
this.search_results.bind('touchstart.chosen', function(evt) {
|
698 |
-
_this.search_results_touchstart(evt);
|
699 |
-
});
|
700 |
-
this.search_results.bind('touchmove.chosen', function(evt) {
|
701 |
-
_this.search_results_touchmove(evt);
|
702 |
-
});
|
703 |
-
this.search_results.bind('touchend.chosen', function(evt) {
|
704 |
-
_this.search_results_touchend(evt);
|
705 |
-
});
|
706 |
-
this.form_field_jq.bind("chosen:updated.chosen", function(evt) {
|
707 |
-
_this.results_update_field(evt);
|
708 |
-
});
|
709 |
-
this.form_field_jq.bind("chosen:activate.chosen", function(evt) {
|
710 |
-
_this.activate_field(evt);
|
711 |
-
});
|
712 |
-
this.form_field_jq.bind("chosen:open.chosen", function(evt) {
|
713 |
-
_this.container_mousedown(evt);
|
714 |
-
});
|
715 |
-
this.form_field_jq.bind("chosen:close.chosen", function(evt) {
|
716 |
-
_this.input_blur(evt);
|
717 |
-
});
|
718 |
-
this.search_field.bind('blur.chosen', function(evt) {
|
719 |
-
_this.input_blur(evt);
|
720 |
-
});
|
721 |
-
this.search_field.bind('keyup.chosen', function(evt) {
|
722 |
-
_this.keyup_checker(evt);
|
723 |
-
});
|
724 |
-
this.search_field.bind('keydown.chosen', function(evt) {
|
725 |
-
_this.keydown_checker(evt);
|
726 |
-
});
|
727 |
-
this.search_field.bind('focus.chosen', function(evt) {
|
728 |
-
_this.input_focus(evt);
|
729 |
-
});
|
730 |
-
this.search_field.bind('cut.chosen', function(evt) {
|
731 |
-
_this.clipboard_event_checker(evt);
|
732 |
-
});
|
733 |
-
this.search_field.bind('paste.chosen', function(evt) {
|
734 |
-
_this.clipboard_event_checker(evt);
|
735 |
-
});
|
736 |
-
if (this.is_multiple) {
|
737 |
-
return this.search_choices.bind('click.chosen', function(evt) {
|
738 |
-
_this.choices_click(evt);
|
739 |
-
});
|
740 |
-
} else {
|
741 |
-
return this.container.bind('click.chosen', function(evt) {
|
742 |
-
evt.preventDefault();
|
743 |
-
});
|
744 |
-
}
|
745 |
-
};
|
746 |
-
|
747 |
-
Chosen.prototype.destroy = function() {
|
748 |
-
$(this.container[0].ownerDocument).unbind("click.chosen", this.click_test_action);
|
749 |
-
if (this.search_field[0].tabIndex) {
|
750 |
-
this.form_field_jq[0].tabIndex = this.search_field[0].tabIndex;
|
751 |
-
}
|
752 |
-
this.container.remove();
|
753 |
-
this.form_field_jq.removeData('chosen');
|
754 |
-
return this.form_field_jq.show();
|
755 |
-
};
|
756 |
-
|
757 |
-
Chosen.prototype.search_field_disabled = function() {
|
758 |
-
this.is_disabled = this.form_field_jq[0].disabled;
|
759 |
-
if (this.is_disabled) {
|
760 |
-
this.container.addClass('chosen-disabled');
|
761 |
-
this.search_field[0].disabled = true;
|
762 |
-
if (!this.is_multiple) {
|
763 |
-
this.selected_item.unbind("focus.chosen", this.activate_action);
|
764 |
-
}
|
765 |
-
return this.close_field();
|
766 |
-
} else {
|
767 |
-
this.container.removeClass('chosen-disabled');
|
768 |
-
this.search_field[0].disabled = false;
|
769 |
-
if (!this.is_multiple) {
|
770 |
-
return this.selected_item.bind("focus.chosen", this.activate_action);
|
771 |
-
}
|
772 |
-
}
|
773 |
-
};
|
774 |
-
|
775 |
-
Chosen.prototype.container_mousedown = function(evt) {
|
776 |
-
if (!this.is_disabled) {
|
777 |
-
if (evt && evt.type === "mousedown" && !this.results_showing) {
|
778 |
-
evt.preventDefault();
|
779 |
-
}
|
780 |
-
if (!((evt != null) && ($(evt.target)).hasClass("search-choice-close"))) {
|
781 |
-
if (!this.active_field) {
|
782 |
-
if (this.is_multiple) {
|
783 |
-
this.search_field.val("");
|
784 |
-
}
|
785 |
-
$(this.container[0].ownerDocument).bind('click.chosen', this.click_test_action);
|
786 |
-
this.results_show();
|
787 |
-
} else if (!this.is_multiple && evt && (($(evt.target)[0] === this.selected_item[0]) || $(evt.target).parents("a.chosen-single").length)) {
|
788 |
-
evt.preventDefault();
|
789 |
-
this.results_toggle();
|
790 |
-
}
|
791 |
-
return this.activate_field();
|
792 |
-
}
|
793 |
-
}
|
794 |
-
};
|
795 |
-
|
796 |
-
Chosen.prototype.container_mouseup = function(evt) {
|
797 |
-
if (evt.target.nodeName === "ABBR" && !this.is_disabled) {
|
798 |
-
return this.results_reset(evt);
|
799 |
-
}
|
800 |
-
};
|
801 |
-
|
802 |
-
Chosen.prototype.search_results_mousewheel = function(evt) {
|
803 |
-
var delta;
|
804 |
-
if (evt.originalEvent) {
|
805 |
-
delta = evt.originalEvent.deltaY || -evt.originalEvent.wheelDelta || evt.originalEvent.detail;
|
806 |
-
}
|
807 |
-
if (delta != null) {
|
808 |
-
evt.preventDefault();
|
809 |
-
if (evt.type === 'DOMMouseScroll') {
|
810 |
-
delta = delta * 40;
|
811 |
-
}
|
812 |
-
return this.search_results.scrollTop(delta + this.search_results.scrollTop());
|
813 |
-
}
|
814 |
-
};
|
815 |
-
|
816 |
-
Chosen.prototype.blur_test = function(evt) {
|
817 |
-
if (!this.active_field && this.container.hasClass("chosen-container-active")) {
|
818 |
-
return this.close_field();
|
819 |
-
}
|
820 |
-
};
|
821 |
-
|
822 |
-
Chosen.prototype.close_field = function() {
|
823 |
-
$(this.container[0].ownerDocument).unbind("click.chosen", this.click_test_action);
|
824 |
-
this.active_field = false;
|
825 |
-
this.results_hide();
|
826 |
-
this.container.removeClass("chosen-container-active");
|
827 |
-
this.clear_backstroke();
|
828 |
-
this.show_search_field_default();
|
829 |
-
return this.search_field_scale();
|
830 |
-
};
|
831 |
-
|
832 |
-
Chosen.prototype.activate_field = function() {
|
833 |
-
this.container.addClass("chosen-container-active");
|
834 |
-
this.active_field = true;
|
835 |
-
this.search_field.val(this.search_field.val());
|
836 |
-
return this.search_field.focus();
|
837 |
-
};
|
838 |
-
|
839 |
-
Chosen.prototype.test_active_click = function(evt) {
|
840 |
-
var active_container;
|
841 |
-
active_container = $(evt.target).closest('.chosen-container');
|
842 |
-
if (active_container.length && this.container[0] === active_container[0]) {
|
843 |
-
return this.active_field = true;
|
844 |
-
} else {
|
845 |
-
return this.close_field();
|
846 |
-
}
|
847 |
-
};
|
848 |
-
|
849 |
-
Chosen.prototype.results_build = function() {
|
850 |
-
this.parsing = true;
|
851 |
-
this.selected_option_count = null;
|
852 |
-
this.results_data = SelectParser.select_to_array(this.form_field);
|
853 |
-
if (this.is_multiple) {
|
854 |
-
this.search_choices.find("li.search-choice").remove();
|
855 |
-
} else if (!this.is_multiple) {
|
856 |
-
this.single_set_selected_text();
|
857 |
-
if (this.disable_search || this.form_field.options.length <= this.disable_search_threshold) {
|
858 |
-
this.search_field[0].readOnly = true;
|
859 |
-
this.container.addClass("chosen-container-single-nosearch");
|
860 |
-
} else {
|
861 |
-
this.search_field[0].readOnly = false;
|
862 |
-
this.container.removeClass("chosen-container-single-nosearch");
|
863 |
-
}
|
864 |
-
}
|
865 |
-
this.update_results_content(this.results_option_build({
|
866 |
-
first: true
|
867 |
-
}));
|
868 |
-
this.search_field_disabled();
|
869 |
-
this.show_search_field_default();
|
870 |
-
this.search_field_scale();
|
871 |
-
return this.parsing = false;
|
872 |
-
};
|
873 |
-
|
874 |
-
Chosen.prototype.result_do_highlight = function(el) {
|
875 |
-
var high_bottom, high_top, maxHeight, visible_bottom, visible_top;
|
876 |
-
if (el.length) {
|
877 |
-
this.result_clear_highlight();
|
878 |
-
this.result_highlight = el;
|
879 |
-
this.result_highlight.addClass("highlighted");
|
880 |
-
maxHeight = parseInt(this.search_results.css("maxHeight"), 10);
|
881 |
-
visible_top = this.search_results.scrollTop();
|
882 |
-
visible_bottom = maxHeight + visible_top;
|
883 |
-
high_top = this.result_highlight.position().top + this.search_results.scrollTop();
|
884 |
-
high_bottom = high_top + this.result_highlight.outerHeight();
|
885 |
-
if (high_bottom >= visible_bottom) {
|
886 |
-
return this.search_results.scrollTop((high_bottom - maxHeight) > 0 ? high_bottom - maxHeight : 0);
|
887 |
-
} else if (high_top < visible_top) {
|
888 |
-
return this.search_results.scrollTop(high_top);
|
889 |
-
}
|
890 |
-
}
|
891 |
-
};
|
892 |
-
|
893 |
-
Chosen.prototype.result_clear_highlight = function() {
|
894 |
-
if (this.result_highlight) {
|
895 |
-
this.result_highlight.removeClass("highlighted");
|
896 |
-
}
|
897 |
-
return this.result_highlight = null;
|
898 |
-
};
|
899 |
-
|
900 |
-
Chosen.prototype.results_show = function() {
|
901 |
-
if (this.is_multiple && this.max_selected_options <= this.choices_count()) {
|
902 |
-
this.form_field_jq.trigger("chosen:maxselected", {
|
903 |
-
chosen: this
|
904 |
-
});
|
905 |
-
return false;
|
906 |
-
}
|
907 |
-
this.container.addClass("chosen-with-drop");
|
908 |
-
this.results_showing = true;
|
909 |
-
this.search_field.focus();
|
910 |
-
this.search_field.val(this.search_field.val());
|
911 |
-
this.winnow_results();
|
912 |
-
return this.form_field_jq.trigger("chosen:showing_dropdown", {
|
913 |
-
chosen: this
|
914 |
-
});
|
915 |
-
};
|
916 |
-
|
917 |
-
Chosen.prototype.update_results_content = function(content) {
|
918 |
-
return this.search_results.html(content);
|
919 |
-
};
|
920 |
-
|
921 |
-
Chosen.prototype.results_hide = function() {
|
922 |
-
if (this.results_showing) {
|
923 |
-
this.result_clear_highlight();
|
924 |
-
this.container.removeClass("chosen-with-drop");
|
925 |
-
this.form_field_jq.trigger("chosen:hiding_dropdown", {
|
926 |
-
chosen: this
|
927 |
-
});
|
928 |
-
}
|
929 |
-
return this.results_showing = false;
|
930 |
-
};
|
931 |
-
|
932 |
-
Chosen.prototype.set_tab_index = function(el) {
|
933 |
-
var ti;
|
934 |
-
if (this.form_field.tabIndex) {
|
935 |
-
ti = this.form_field.tabIndex;
|
936 |
-
this.form_field.tabIndex = -1;
|
937 |
-
return this.search_field[0].tabIndex = ti;
|
938 |
-
}
|
939 |
-
};
|
940 |
-
|
941 |
-
Chosen.prototype.set_label_behavior = function() {
|
942 |
-
var _this = this;
|
943 |
-
this.form_field_label = this.form_field_jq.parents("label");
|
944 |
-
if (!this.form_field_label.length && this.form_field.id.length) {
|
945 |
-
this.form_field_label = $("label[for='" + this.form_field.id + "']");
|
946 |
-
}
|
947 |
-
if (this.form_field_label.length > 0) {
|
948 |
-
return this.form_field_label.bind('click.chosen', function(evt) {
|
949 |
-
if (_this.is_multiple) {
|
950 |
-
return _this.container_mousedown(evt);
|
951 |
-
} else {
|
952 |
-
return _this.activate_field();
|
953 |
-
}
|
954 |
-
});
|
955 |
-
}
|
956 |
-
};
|
957 |
-
|
958 |
-
Chosen.prototype.show_search_field_default = function() {
|
959 |
-
if (this.is_multiple && this.choices_count() < 1 && !this.active_field) {
|
960 |
-
this.search_field.val(this.default_text);
|
961 |
-
return this.search_field.addClass("default");
|
962 |
-
} else {
|
963 |
-
this.search_field.val("");
|
964 |
-
return this.search_field.removeClass("default");
|
965 |
-
}
|
966 |
-
};
|
967 |
-
|
968 |
-
Chosen.prototype.search_results_mouseup = function(evt) {
|
969 |
-
var target;
|
970 |
-
target = $(evt.target).hasClass("active-result") ? $(evt.target) : $(evt.target).parents(".active-result").first();
|
971 |
-
if (target.length) {
|
972 |
-
this.result_highlight = target;
|
973 |
-
this.result_select(evt);
|
974 |
-
return this.search_field.focus();
|
975 |
-
}
|
976 |
-
};
|
977 |
-
|
978 |
-
Chosen.prototype.search_results_mouseover = function(evt) {
|
979 |
-
var target;
|
980 |
-
target = $(evt.target).hasClass("active-result") ? $(evt.target) : $(evt.target).parents(".active-result").first();
|
981 |
-
if (target) {
|
982 |
-
return this.result_do_highlight(target);
|
983 |
-
}
|
984 |
-
};
|
985 |
-
|
986 |
-
Chosen.prototype.search_results_mouseout = function(evt) {
|
987 |
-
if ($(evt.target).hasClass("active-result" || $(evt.target).parents('.active-result').first())) {
|
988 |
-
return this.result_clear_highlight();
|
989 |
-
}
|
990 |
-
};
|
991 |
-
|
992 |
-
Chosen.prototype.choice_build = function(item) {
|
993 |
-
var choice, close_link,
|
994 |
-
_this = this;
|
995 |
-
choice = $('<li />', {
|
996 |
-
"class": "search-choice"
|
997 |
-
}).html("<span>" + (this.choice_label(item)) + "</span>");
|
998 |
-
if (item.disabled) {
|
999 |
-
choice.addClass('search-choice-disabled');
|
1000 |
-
} else {
|
1001 |
-
close_link = $('<a />', {
|
1002 |
-
"class": 'search-choice-close',
|
1003 |
-
'data-option-array-index': item.array_index
|
1004 |
-
});
|
1005 |
-
close_link.bind('click.chosen', function(evt) {
|
1006 |
-
return _this.choice_destroy_link_click(evt);
|
1007 |
-
});
|
1008 |
-
choice.append(close_link);
|
1009 |
-
}
|
1010 |
-
return this.search_container.before(choice);
|
1011 |
-
};
|
1012 |
-
|
1013 |
-
Chosen.prototype.choice_destroy_link_click = function(evt) {
|
1014 |
-
evt.preventDefault();
|
1015 |
-
evt.stopPropagation();
|
1016 |
-
if (!this.is_disabled) {
|
1017 |
-
return this.choice_destroy($(evt.target));
|
1018 |
-
}
|
1019 |
-
};
|
1020 |
-
|
1021 |
-
Chosen.prototype.choice_destroy = function(link) {
|
1022 |
-
if (this.result_deselect(link[0].getAttribute("data-option-array-index"))) {
|
1023 |
-
this.show_search_field_default();
|
1024 |
-
if (this.is_multiple && this.choices_count() > 0 && this.search_field.val().length < 1) {
|
1025 |
-
this.results_hide();
|
1026 |
-
}
|
1027 |
-
link.parents('li').first().remove();
|
1028 |
-
return this.search_field_scale();
|
1029 |
-
}
|
1030 |
-
};
|
1031 |
-
|
1032 |
-
Chosen.prototype.results_reset = function() {
|
1033 |
-
this.reset_single_select_options();
|
1034 |
-
this.form_field.options[0].selected = true;
|
1035 |
-
this.single_set_selected_text();
|
1036 |
-
this.show_search_field_default();
|
1037 |
-
this.results_reset_cleanup();
|
1038 |
-
this.form_field_jq.trigger("change");
|
1039 |
-
if (this.active_field) {
|
1040 |
-
return this.results_hide();
|
1041 |
-
}
|
1042 |
-
};
|
1043 |
-
|
1044 |
-
Chosen.prototype.results_reset_cleanup = function() {
|
1045 |
-
this.current_selectedIndex = this.form_field.selectedIndex;
|
1046 |
-
return this.selected_item.find("abbr").remove();
|
1047 |
-
};
|
1048 |
-
|
1049 |
-
Chosen.prototype.result_select = function(evt) {
|
1050 |
-
var high, item;
|
1051 |
-
if (this.result_highlight) {
|
1052 |
-
high = this.result_highlight;
|
1053 |
-
this.result_clear_highlight();
|
1054 |
-
if (this.is_multiple && this.max_selected_options <= this.choices_count()) {
|
1055 |
-
this.form_field_jq.trigger("chosen:maxselected", {
|
1056 |
-
chosen: this
|
1057 |
-
});
|
1058 |
-
return false;
|
1059 |
-
}
|
1060 |
-
if (this.is_multiple) {
|
1061 |
-
high.removeClass("active-result");
|
1062 |
-
} else {
|
1063 |
-
this.reset_single_select_options();
|
1064 |
-
}
|
1065 |
-
high.addClass("result-selected");
|
1066 |
-
item = this.results_data[high[0].getAttribute("data-option-array-index")];
|
1067 |
-
item.selected = true;
|
1068 |
-
this.form_field.options[item.options_index].selected = true;
|
1069 |
-
this.selected_option_count = null;
|
1070 |
-
if (this.is_multiple) {
|
1071 |
-
this.choice_build(item);
|
1072 |
-
} else {
|
1073 |
-
this.single_set_selected_text(this.choice_label(item));
|
1074 |
-
}
|
1075 |
-
if (!((evt.metaKey || evt.ctrlKey) && this.is_multiple)) {
|
1076 |
-
this.results_hide();
|
1077 |
-
}
|
1078 |
-
this.show_search_field_default();
|
1079 |
-
if (this.is_multiple || this.form_field.selectedIndex !== this.current_selectedIndex) {
|
1080 |
-
this.form_field_jq.trigger("change", {
|
1081 |
-
'selected': this.form_field.options[item.options_index].value
|
1082 |
-
});
|
1083 |
-
}
|
1084 |
-
this.current_selectedIndex = this.form_field.selectedIndex;
|
1085 |
-
evt.preventDefault();
|
1086 |
-
return this.search_field_scale();
|
1087 |
-
}
|
1088 |
-
};
|
1089 |
-
|
1090 |
-
Chosen.prototype.single_set_selected_text = function(text) {
|
1091 |
-
if (text == null) {
|
1092 |
-
text = this.default_text;
|
1093 |
-
}
|
1094 |
-
if (text === this.default_text) {
|
1095 |
-
this.selected_item.addClass("chosen-default");
|
1096 |
-
} else {
|
1097 |
-
this.single_deselect_control_build();
|
1098 |
-
this.selected_item.removeClass("chosen-default");
|
1099 |
-
}
|
1100 |
-
return this.selected_item.find("span").html(text);
|
1101 |
-
};
|
1102 |
-
|
1103 |
-
Chosen.prototype.result_deselect = function(pos) {
|
1104 |
-
var result_data;
|
1105 |
-
result_data = this.results_data[pos];
|
1106 |
-
if (!this.form_field.options[result_data.options_index].disabled) {
|
1107 |
-
result_data.selected = false;
|
1108 |
-
this.form_field.options[result_data.options_index].selected = false;
|
1109 |
-
this.selected_option_count = null;
|
1110 |
-
this.result_clear_highlight();
|
1111 |
-
if (this.results_showing) {
|
1112 |
-
this.winnow_results();
|
1113 |
-
}
|
1114 |
-
this.form_field_jq.trigger("change", {
|
1115 |
-
deselected: this.form_field.options[result_data.options_index].value
|
1116 |
-
});
|
1117 |
-
this.search_field_scale();
|
1118 |
-
return true;
|
1119 |
-
} else {
|
1120 |
-
return false;
|
1121 |
-
}
|
1122 |
-
};
|
1123 |
-
|
1124 |
-
Chosen.prototype.single_deselect_control_build = function() {
|
1125 |
-
if (!this.allow_single_deselect) {
|
1126 |
-
return;
|
1127 |
-
}
|
1128 |
-
if (!this.selected_item.find("abbr").length) {
|
1129 |
-
this.selected_item.find("span").first().after("<abbr class=\"search-choice-close\"></abbr>");
|
1130 |
-
}
|
1131 |
-
return this.selected_item.addClass("chosen-single-with-deselect");
|
1132 |
-
};
|
1133 |
-
|
1134 |
-
Chosen.prototype.get_search_text = function() {
|
1135 |
-
return $('<div/>').text($.trim(this.search_field.val())).html();
|
1136 |
-
};
|
1137 |
-
|
1138 |
-
Chosen.prototype.winnow_results_set_highlight = function() {
|
1139 |
-
var do_high, selected_results;
|
1140 |
-
selected_results = !this.is_multiple ? this.search_results.find(".result-selected.active-result") : [];
|
1141 |
-
do_high = selected_results.length ? selected_results.first() : this.search_results.find(".active-result").first();
|
1142 |
-
if (do_high != null) {
|
1143 |
-
return this.result_do_highlight(do_high);
|
1144 |
-
}
|
1145 |
-
};
|
1146 |
-
|
1147 |
-
Chosen.prototype.no_results = function(terms) {
|
1148 |
-
var no_results_html;
|
1149 |
-
no_results_html = $('<li class="no-results">' + this.results_none_found + ' "<span></span>"</li>');
|
1150 |
-
no_results_html.find("span").first().html(terms);
|
1151 |
-
this.search_results.append(no_results_html);
|
1152 |
-
return this.form_field_jq.trigger("chosen:no_results", {
|
1153 |
-
chosen: this
|
1154 |
-
});
|
1155 |
-
};
|
1156 |
-
|
1157 |
-
Chosen.prototype.no_results_clear = function() {
|
1158 |
-
return this.search_results.find(".no-results").remove();
|
1159 |
-
};
|
1160 |
-
|
1161 |
-
Chosen.prototype.keydown_arrow = function() {
|
1162 |
-
var next_sib;
|
1163 |
-
if (this.results_showing && this.result_highlight) {
|
1164 |
-
next_sib = this.result_highlight.nextAll("li.active-result").first();
|
1165 |
-
if (next_sib) {
|
1166 |
-
return this.result_do_highlight(next_sib);
|
1167 |
-
}
|
1168 |
-
} else {
|
1169 |
-
return this.results_show();
|
1170 |
-
}
|
1171 |
-
};
|
1172 |
-
|
1173 |
-
Chosen.prototype.keyup_arrow = function() {
|
1174 |
-
var prev_sibs;
|
1175 |
-
if (!this.results_showing && !this.is_multiple) {
|
1176 |
-
return this.results_show();
|
1177 |
-
} else if (this.result_highlight) {
|
1178 |
-
prev_sibs = this.result_highlight.prevAll("li.active-result");
|
1179 |
-
if (prev_sibs.length) {
|
1180 |
-
return this.result_do_highlight(prev_sibs.first());
|
1181 |
-
} else {
|
1182 |
-
if (this.choices_count() > 0) {
|
1183 |
-
this.results_hide();
|
1184 |
-
}
|
1185 |
-
return this.result_clear_highlight();
|
1186 |
-
}
|
1187 |
-
}
|
1188 |
-
};
|
1189 |
-
|
1190 |
-
Chosen.prototype.keydown_backstroke = function() {
|
1191 |
-
var next_available_destroy;
|
1192 |
-
if (this.pending_backstroke) {
|
1193 |
-
this.choice_destroy(this.pending_backstroke.find("a").first());
|
1194 |
-
return this.clear_backstroke();
|
1195 |
-
} else {
|
1196 |
-
next_available_destroy = this.search_container.siblings("li.search-choice").last();
|
1197 |
-
if (next_available_destroy.length && !next_available_destroy.hasClass("search-choice-disabled")) {
|
1198 |
-
this.pending_backstroke = next_available_destroy;
|
1199 |
-
if (this.single_backstroke_delete) {
|
1200 |
-
return this.keydown_backstroke();
|
1201 |
-
} else {
|
1202 |
-
return this.pending_backstroke.addClass("search-choice-focus");
|
1203 |
-
}
|
1204 |
-
}
|
1205 |
-
}
|
1206 |
-
};
|
1207 |
-
|
1208 |
-
Chosen.prototype.clear_backstroke = function() {
|
1209 |
-
if (this.pending_backstroke) {
|
1210 |
-
this.pending_backstroke.removeClass("search-choice-focus");
|
1211 |
-
}
|
1212 |
-
return this.pending_backstroke = null;
|
1213 |
-
};
|
1214 |
-
|
1215 |
-
Chosen.prototype.keydown_checker = function(evt) {
|
1216 |
-
var stroke, _ref1;
|
1217 |
-
stroke = (_ref1 = evt.which) != null ? _ref1 : evt.keyCode;
|
1218 |
-
this.search_field_scale();
|
1219 |
-
if (stroke !== 8 && this.pending_backstroke) {
|
1220 |
-
this.clear_backstroke();
|
1221 |
-
}
|
1222 |
-
switch (stroke) {
|
1223 |
-
case 8:
|
1224 |
-
this.backstroke_length = this.search_field.val().length;
|
1225 |
-
break;
|
1226 |
-
case 9:
|
1227 |
-
if (this.results_showing && !this.is_multiple) {
|
1228 |
-
this.result_select(evt);
|
1229 |
-
}
|
1230 |
-
this.mouse_on_container = false;
|
1231 |
-
break;
|
1232 |
-
case 13:
|
1233 |
-
if (this.results_showing) {
|
1234 |
-
evt.preventDefault();
|
1235 |
-
}
|
1236 |
-
break;
|
1237 |
-
case 32:
|
1238 |
-
if (this.disable_search) {
|
1239 |
-
evt.preventDefault();
|
1240 |
-
}
|
1241 |
-
break;
|
1242 |
-
case 38:
|
1243 |
-
evt.preventDefault();
|
1244 |
-
this.keyup_arrow();
|
1245 |
-
break;
|
1246 |
-
case 40:
|
1247 |
-
evt.preventDefault();
|
1248 |
-
this.keydown_arrow();
|
1249 |
-
break;
|
1250 |
-
}
|
1251 |
-
};
|
1252 |
-
|
1253 |
-
Chosen.prototype.search_field_scale = function() {
|
1254 |
-
var div, f_width, h, style, style_block, styles, w, _i, _len;
|
1255 |
-
if (this.is_multiple) {
|
1256 |
-
h = 0;
|
1257 |
-
w = 0;
|
1258 |
-
style_block = "position:absolute; left: -1000px; top: -1000px; display:none;";
|
1259 |
-
styles = ['font-size', 'font-style', 'font-weight', 'font-family', 'line-height', 'text-transform', 'letter-spacing'];
|
1260 |
-
for (_i = 0, _len = styles.length; _i < _len; _i++) {
|
1261 |
-
style = styles[_i];
|
1262 |
-
style_block += style + ":" + this.search_field.css(style) + ";";
|
1263 |
-
}
|
1264 |
-
div = $('<div />', {
|
1265 |
-
'style': style_block
|
1266 |
-
});
|
1267 |
-
div.text(this.search_field.val());
|
1268 |
-
$('body').append(div);
|
1269 |
-
w = div.width() + 25;
|
1270 |
-
div.remove();
|
1271 |
-
f_width = this.container.outerWidth();
|
1272 |
-
if (w > f_width - 10) {
|
1273 |
-
w = f_width - 10;
|
1274 |
-
}
|
1275 |
-
return this.search_field.css({
|
1276 |
-
'width': w + 'px'
|
1277 |
-
});
|
1278 |
-
}
|
1279 |
-
};
|
1280 |
-
|
1281 |
-
return Chosen;
|
1282 |
-
|
1283 |
-
})(AbstractChosen);
|
1284 |
-
|
1285 |
}).call(this);
|
1 |
+
/*!
|
2 |
+
Chosen, a Select Box Enhancer for jQuery and Prototype
|
3 |
+
by Patrick Filler for Harvest, http://getharvest.com
|
4 |
+
|
5 |
+
Version 1.5.1
|
6 |
+
Full source at https://github.com/harvesthq/chosen
|
7 |
+
Copyright (c) 2011-2016 Harvest http://getharvest.com
|
8 |
+
|
9 |
+
MIT License, https://github.com/harvesthq/chosen/blob/master/LICENSE.md
|
10 |
+
This file is generated by `grunt build`, do not edit it by hand.
|
11 |
+
*/
|
12 |
+
|
13 |
+
(function() {
|
14 |
+
var $, AbstractChosen, Chosen, SelectParser, _ref,
|
15 |
+
__hasProp = {}.hasOwnProperty,
|
16 |
+
__extends = function(child, parent) { for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; };
|
17 |
+
|
18 |
+
SelectParser = (function() {
|
19 |
+
function SelectParser() {
|
20 |
+
this.options_index = 0;
|
21 |
+
this.parsed = [];
|
22 |
+
}
|
23 |
+
|
24 |
+
SelectParser.prototype.add_node = function(child) {
|
25 |
+
if (child.nodeName.toUpperCase() === "OPTGROUP") {
|
26 |
+
return this.add_group(child);
|
27 |
+
} else {
|
28 |
+
return this.add_option(child);
|
29 |
+
}
|
30 |
+
};
|
31 |
+
|
32 |
+
SelectParser.prototype.add_group = function(group) {
|
33 |
+
var group_position, option, _i, _len, _ref, _results;
|
34 |
+
group_position = this.parsed.length;
|
35 |
+
this.parsed.push({
|
36 |
+
array_index: group_position,
|
37 |
+
group: true,
|
38 |
+
label: this.escapeExpression(group.label),
|
39 |
+
title: group.title ? group.title : void 0,
|
40 |
+
children: 0,
|
41 |
+
disabled: group.disabled,
|
42 |
+
classes: group.className
|
43 |
+
});
|
44 |
+
_ref = group.childNodes;
|
45 |
+
_results = [];
|
46 |
+
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
47 |
+
option = _ref[_i];
|
48 |
+
_results.push(this.add_option(option, group_position, group.disabled));
|
49 |
+
}
|
50 |
+
return _results;
|
51 |
+
};
|
52 |
+
|
53 |
+
SelectParser.prototype.add_option = function(option, group_position, group_disabled) {
|
54 |
+
if (option.nodeName.toUpperCase() === "OPTION") {
|
55 |
+
if (option.text !== "") {
|
56 |
+
if (group_position != null) {
|
57 |
+
this.parsed[group_position].children += 1;
|
58 |
+
}
|
59 |
+
this.parsed.push({
|
60 |
+
array_index: this.parsed.length,
|
61 |
+
options_index: this.options_index,
|
62 |
+
value: option.value,
|
63 |
+
text: option.text,
|
64 |
+
html: option.innerHTML,
|
65 |
+
title: option.title ? option.title : void 0,
|
66 |
+
selected: option.selected,
|
67 |
+
disabled: group_disabled === true ? group_disabled : option.disabled,
|
68 |
+
group_array_index: group_position,
|
69 |
+
group_label: group_position != null ? this.parsed[group_position].label : null,
|
70 |
+
classes: option.className,
|
71 |
+
style: option.style.cssText
|
72 |
+
});
|
73 |
+
} else {
|
74 |
+
this.parsed.push({
|
75 |
+
array_index: this.parsed.length,
|
76 |
+
options_index: this.options_index,
|
77 |
+
empty: true
|
78 |
+
});
|
79 |
+
}
|
80 |
+
return this.options_index += 1;
|
81 |
+
}
|
82 |
+
};
|
83 |
+
|
84 |
+
SelectParser.prototype.escapeExpression = function(text) {
|
85 |
+
var map, unsafe_chars;
|
86 |
+
if ((text == null) || text === false) {
|
87 |
+
return "";
|
88 |
+
}
|
89 |
+
if (!/[\&\<\>\"\'\`]/.test(text)) {
|
90 |
+
return text;
|
91 |
+
}
|
92 |
+
map = {
|
93 |
+
"<": "<",
|
94 |
+
">": ">",
|
95 |
+
'"': """,
|
96 |
+
"'": "'",
|
97 |
+
"`": "`"
|
98 |
+
};
|
99 |
+
unsafe_chars = /&(?!\w+;)|[\<\>\"\'\`]/g;
|
100 |
+
return text.replace(unsafe_chars, function(chr) {
|
101 |
+
return map[chr] || "&";
|
102 |
+
});
|
103 |
+
};
|
104 |
+
|
105 |
+
return SelectParser;
|
106 |
+
|
107 |
+
})();
|
108 |
+
|
109 |
+
SelectParser.select_to_array = function(select) {
|
110 |
+
var child, parser, _i, _len, _ref;
|
111 |
+
parser = new SelectParser();
|
112 |
+
_ref = select.childNodes;
|
113 |
+
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
114 |
+
child = _ref[_i];
|
115 |
+
parser.add_node(child);
|
116 |
+
}
|
117 |
+
return parser.parsed;
|
118 |
+
};
|
119 |
+
|
120 |
+
AbstractChosen = (function() {
|
121 |
+
function AbstractChosen(form_field, options) {
|
122 |
+
this.form_field = form_field;
|
123 |
+
this.options = options != null ? options : {};
|
124 |
+
if (!AbstractChosen.browser_is_supported()) {
|
125 |
+
return;
|
126 |
+
}
|
127 |
+
this.is_multiple = this.form_field.multiple;
|
128 |
+
this.set_default_text();
|
129 |
+
this.set_default_values();
|
130 |
+
this.setup();
|
131 |
+
this.set_up_html();
|
132 |
+
this.register_observers();
|
133 |
+
this.on_ready();
|
134 |
+
}
|
135 |
+
|
136 |
+
AbstractChosen.prototype.set_default_values = function() {
|
137 |
+
var _this = this;
|
138 |
+
this.click_test_action = function(evt) {
|
139 |
+
return _this.test_active_click(evt);
|
140 |
+
};
|
141 |
+
this.activate_action = function(evt) {
|
142 |
+
return _this.activate_field(evt);
|
143 |
+
};
|
144 |
+
this.active_field = false;
|
145 |
+
this.mouse_on_container = false;
|
146 |
+
this.results_showing = false;
|
147 |
+
this.result_highlighted = null;
|
148 |
+
this.allow_single_deselect = (this.options.allow_single_deselect != null) && (this.form_field.options[0] != null) && this.form_field.options[0].text === "" ? this.options.allow_single_deselect : false;
|
149 |
+
this.disable_search_threshold = this.options.disable_search_threshold || 0;
|
150 |
+
this.disable_search = this.options.disable_search || false;
|
151 |
+
this.enable_split_word_search = this.options.enable_split_word_search != null ? this.options.enable_split_word_search : true;
|
152 |
+
this.group_search = this.options.group_search != null ? this.options.group_search : true;
|
153 |
+
this.search_contains = this.options.search_contains || false;
|
154 |
+
this.single_backstroke_delete = this.options.single_backstroke_delete != null ? this.options.single_backstroke_delete : true;
|
155 |
+
this.max_selected_options = this.options.max_selected_options || Infinity;
|
156 |
+
this.inherit_select_classes = this.options.inherit_select_classes || false;
|
157 |
+
this.display_selected_options = this.options.display_selected_options != null ? this.options.display_selected_options : true;
|
158 |
+
this.display_disabled_options = this.options.display_disabled_options != null ? this.options.display_disabled_options : true;
|
159 |
+
this.include_group_label_in_selected = this.options.include_group_label_in_selected || false;
|
160 |
+
return this.max_shown_results = this.options.max_shown_results || Number.POSITIVE_INFINITY;
|
161 |
+
};
|
162 |
+
|
163 |
+
AbstractChosen.prototype.set_default_text = function() {
|
164 |
+
if (this.form_field.getAttribute("data-placeholder")) {
|
165 |
+
this.default_text = this.form_field.getAttribute("data-placeholder");
|
166 |
+
} else if (this.is_multiple) {
|
167 |
+
this.default_text = this.options.placeholder_text_multiple || this.options.placeholder_text || AbstractChosen.default_multiple_text;
|
168 |
+
} else {
|
169 |
+
this.default_text = this.options.placeholder_text_single || this.options.placeholder_text || AbstractChosen.default_single_text;
|
170 |
+
}
|
171 |
+
return this.results_none_found = this.form_field.getAttribute("data-no_results_text") || this.options.no_results_text || AbstractChosen.default_no_result_text;
|
172 |
+
};
|
173 |
+
|
174 |
+
AbstractChosen.prototype.choice_label = function(item) {
|
175 |
+
if (this.include_group_label_in_selected && (item.group_label != null)) {
|
176 |
+
return "<b class='group-name'>" + item.group_label + "</b>" + item.html;
|
177 |
+
} else {
|
178 |
+
return item.html;
|
179 |
+
}
|
180 |
+
};
|
181 |
+
|
182 |
+
AbstractChosen.prototype.mouse_enter = function() {
|
183 |
+
return this.mouse_on_container = true;
|
184 |
+
};
|
185 |
+
|
186 |
+
AbstractChosen.prototype.mouse_leave = function() {
|
187 |
+
return this.mouse_on_container = false;
|
188 |
+
};
|
189 |
+
|
190 |
+
AbstractChosen.prototype.input_focus = function(evt) {
|
191 |
+
var _this = this;
|
192 |
+
if (this.is_multiple) {
|
193 |
+
if (!this.active_field) {
|
194 |
+
return setTimeout((function() {
|
195 |
+
return _this.container_mousedown();
|
196 |
+
}), 50);
|
197 |
+
}
|
198 |
+
} else {
|
199 |
+
if (!this.active_field) {
|
200 |
+
return this.activate_field();
|
201 |
+
}
|
202 |
+
}
|
203 |
+
};
|
204 |
+
|
205 |
+
AbstractChosen.prototype.input_blur = function(evt) {
|
206 |
+
var _this = this;
|
207 |
+
if (!this.mouse_on_container) {
|
208 |
+
this.active_field = false;
|
209 |
+
return setTimeout((function() {
|
210 |
+
return _this.blur_test();
|
211 |
+
}), 100);
|
212 |
+
}
|
213 |
+
};
|
214 |
+
|
215 |
+
AbstractChosen.prototype.results_option_build = function(options) {
|
216 |
+
var content, data, data_content, shown_results, _i, _len, _ref;
|
217 |
+
content = '';
|
218 |
+
shown_results = 0;
|
219 |
+
_ref = this.results_data;
|
220 |
+
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
221 |
+
data = _ref[_i];
|
222 |
+
data_content = '';
|
223 |
+
if (data.group) {
|
224 |
+
data_content = this.result_add_group(data);
|
225 |
+
} else {
|
226 |
+
data_content = this.result_add_option(data);
|
227 |
+
}
|
228 |
+
if (data_content !== '') {
|
229 |
+
shown_results++;
|
230 |
+
content += data_content;
|
231 |
+
}
|
232 |
+
if (options != null ? options.first : void 0) {
|
233 |
+
if (data.selected && this.is_multiple) {
|
234 |
+
this.choice_build(data);
|
235 |
+
} else if (data.selected && !this.is_multiple) {
|
236 |
+
this.single_set_selected_text(this.choice_label(data));
|
237 |
+
}
|
238 |
+
}
|
239 |
+
if (shown_results >= this.max_shown_results) {
|
240 |
+
break;
|
241 |
+
}
|
242 |
+
}
|
243 |
+
return content;
|
244 |
+
};
|
245 |
+
|
246 |
+
AbstractChosen.prototype.result_add_option = function(option) {
|
247 |
+
var classes, option_el;
|
248 |
+
if (!option.search_match) {
|
249 |
+
return '';
|
250 |
+
}
|
251 |
+
if (!this.include_option_in_results(option)) {
|
252 |
+
return '';
|
253 |
+
}
|
254 |
+
classes = [];
|
255 |
+
if (!option.disabled && !(option.selected && this.is_multiple)) {
|
256 |
+
classes.push("active-result");
|
257 |
+
}
|
258 |
+
if (option.disabled && !(option.selected && this.is_multiple)) {
|
259 |
+
classes.push("disabled-result");
|
260 |
+
}
|
261 |
+
if (option.selected) {
|
262 |
+
classes.push("result-selected");
|
263 |
+
}
|
264 |
+
if (option.group_array_index != null) {
|
265 |
+
classes.push("group-option");
|
266 |
+
}
|
267 |
+
if (option.classes !== "") {
|
268 |
+
classes.push(option.classes);
|
269 |
+
}
|
270 |
+
option_el = document.createElement("li");
|
271 |
+
option_el.className = classes.join(" ");
|
272 |
+
option_el.style.cssText = option.style;
|
273 |
+
option_el.setAttribute("data-option-array-index", option.array_index);
|
274 |
+
option_el.innerHTML = option.search_text;
|
275 |
+
if (option.title) {
|
276 |
+
option_el.title = option.title;
|
277 |
+
}
|
278 |
+
return this.outerHTML(option_el);
|
279 |
+
};
|
280 |
+
|
281 |
+
AbstractChosen.prototype.result_add_group = function(group) {
|
282 |
+
var classes, group_el;
|
283 |
+
if (!(group.search_match || group.group_match)) {
|
284 |
+
return '';
|
285 |
+
}
|
286 |
+
if (!(group.active_options > 0)) {
|
287 |
+
return '';
|
288 |
+
}
|
289 |
+
classes = [];
|
290 |
+
classes.push("group-result");
|
291 |
+
if (group.classes) {
|
292 |
+
classes.push(group.classes);
|
293 |
+
}
|
294 |
+
group_el = document.createElement("li");
|
295 |
+
group_el.className = classes.join(" ");
|
296 |
+
group_el.innerHTML = group.search_text;
|
297 |
+
if (group.title) {
|
298 |
+
group_el.title = group.title;
|
299 |
+
}
|
300 |
+
return this.outerHTML(group_el);
|
301 |
+
};
|
302 |
+
|
303 |
+
AbstractChosen.prototype.results_update_field = function() {
|
304 |
+
this.set_default_text();
|
305 |
+
if (!this.is_multiple) {
|
306 |
+
this.results_reset_cleanup();
|
307 |
+
}
|
308 |
+
this.result_clear_highlight();
|
309 |
+
this.results_build();
|
310 |
+
if (this.results_showing) {
|
311 |
+
return this.winnow_results();
|
312 |
+
}
|
313 |
+
};
|
314 |
+
|
315 |
+
AbstractChosen.prototype.reset_single_select_options = function() {
|
316 |
+
var result, _i, _len, _ref, _results;
|
317 |
+
_ref = this.results_data;
|
318 |
+
_results = [];
|
319 |
+
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
320 |
+
result = _ref[_i];
|
321 |
+
if (result.selected) {
|
322 |
+
_results.push(result.selected = false);
|
323 |
+
} else {
|
324 |
+
_results.push(void 0);
|
325 |
+
}
|
326 |
+
}
|
327 |
+
return _results;
|
328 |
+
};
|
329 |
+
|
330 |
+
AbstractChosen.prototype.results_toggle = function() {
|
331 |
+
if (this.results_showing) {
|
332 |
+
return this.results_hide();
|
333 |
+
} else {
|
334 |
+
return this.results_show();
|
335 |
+
}
|
336 |
+
};
|
337 |
+
|
338 |
+
AbstractChosen.prototype.results_search = function(evt) {
|
339 |
+
if (this.results_showing) {
|
340 |
+
return this.winnow_results();
|
341 |
+
} else {
|
342 |
+
return this.results_show();
|
343 |
+
}
|
344 |
+
};
|
345 |
+
|
346 |
+
AbstractChosen.prototype.winnow_results = function() {
|
347 |
+
var escapedSearchText, option, regex, results, results_group, searchText, startpos, text, zregex, _i, _len, _ref;
|
348 |
+
this.no_results_clear();
|
349 |
+
results = 0;
|
350 |
+
searchText = this.get_search_text();
|
351 |
+
escapedSearchText = searchText.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, "\\$&");
|
352 |
+
zregex = new RegExp(escapedSearchText, 'i');
|
353 |
+
regex = this.get_search_regex(escapedSearchText);
|
354 |
+
_ref = this.results_data;
|
355 |
+
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
356 |
+
option = _ref[_i];
|
357 |
+
option.search_match = false;
|
358 |
+
results_group = null;
|
359 |
+
if (this.include_option_in_results(option)) {
|
360 |
+
if (option.group) {
|
361 |
+
option.group_match = false;
|
362 |
+
option.active_options = 0;
|
363 |
+
}
|
364 |
+
if ((option.group_array_index != null) && this.results_data[option.group_array_index]) {
|
365 |
+
results_group = this.results_data[option.group_array_index];
|
366 |
+
if (results_group.active_options === 0 && results_group.search_match) {
|
367 |
+
results += 1;
|
368 |
+
}
|
369 |
+
results_group.active_options += 1;
|
370 |
+
}
|
371 |
+
option.search_text = option.group ? option.label : option.html;
|
372 |
+
if (!(option.group && !this.group_search)) {
|
373 |
+
option.search_match = this.search_string_match(option.search_text, regex);
|
374 |
+
if (option.search_match && !option.group) {
|
375 |
+
results += 1;
|
376 |
+
}
|
377 |
+
if (option.search_match) {
|
378 |
+
if (searchText.length) {
|
379 |
+
startpos = option.search_text.search(zregex);
|
380 |
+
text = option.search_text.substr(0, startpos + searchText.length) + '</em>' + option.search_text.substr(startpos + searchText.length);
|
381 |
+
option.search_text = text.substr(0, startpos) + '<em>' + text.substr(startpos);
|
382 |
+
}
|
383 |
+
if (results_group != null) {
|
384 |
+
results_group.group_match = true;
|
385 |
+
}
|
386 |
+
} else if ((option.group_array_index != null) && this.results_data[option.group_array_index].search_match) {
|
387 |
+
option.search_match = true;
|
388 |
+
}
|
389 |
+
}
|
390 |
+
}
|
391 |
+
}
|
392 |
+
this.result_clear_highlight();
|
393 |
+
if (results < 1 && searchText.length) {
|
394 |
+
this.update_results_content("");
|
395 |
+
return this.no_results(searchText);
|
396 |
+
} else {
|
397 |
+
this.update_results_content(this.results_option_build());
|
398 |
+
return this.winnow_results_set_highlight();
|
399 |
+
}
|
400 |
+
};
|
401 |
+
|
402 |
+
AbstractChosen.prototype.get_search_regex = function(escaped_search_string) {
|
403 |
+
var regex_anchor;
|
404 |
+
regex_anchor = this.search_contains ? "" : "^";
|
405 |
+
return new RegExp(regex_anchor + escaped_search_string, 'i');
|
406 |
+
};
|
407 |
+
|
408 |
+
AbstractChosen.prototype.search_string_match = function(search_string, regex) {
|
409 |
+
var part, parts, _i, _len;
|
410 |
+
if (regex.test(search_string)) {
|
411 |
+
return true;
|
412 |
+
} else if (this.enable_split_word_search && (search_string.indexOf(" ") >= 0 || search_string.indexOf("[") === 0)) {
|
413 |
+
parts = search_string.replace(/\[|\]/g, "").split(" ");
|
414 |
+
if (parts.length) {
|
415 |
+
for (_i = 0, _len = parts.length; _i < _len; _i++) {
|
416 |
+
part = parts[_i];
|
417 |
+
if (regex.test(part)) {
|
418 |
+
return true;
|
419 |
+
}
|
420 |
+
}
|
421 |
+
}
|
422 |
+
}
|
423 |
+
};
|
424 |
+
|
425 |
+
AbstractChosen.prototype.choices_count = function() {
|
426 |
+
var option, _i, _len, _ref;
|
427 |
+
if (this.selected_option_count != null) {
|
428 |
+
return this.selected_option_count;
|
429 |
+
}
|
430 |
+
this.selected_option_count = 0;
|
431 |
+
_ref = this.form_field.options;
|
432 |
+
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
|
433 |
+
option = _ref[_i];
|
434 |
+
if (option.selected) {
|
435 |
+
this.selected_option_count += 1;
|
436 |
+
}
|
437 |
+
}
|
438 |
+
return this.selected_option_count;
|
439 |
+
};
|
440 |
+
|
441 |
+
AbstractChosen.prototype.choices_click = function(evt) {
|
442 |
+
evt.preventDefault();
|
443 |
+
if (!(this.results_showing || this.is_disabled)) {
|
444 |
+
return this.results_show();
|
445 |
+
}
|
446 |
+
};
|
447 |
+
|
448 |
+
AbstractChosen.prototype.keyup_checker = function(evt) {
|
449 |
+
var stroke, _ref;
|
450 |
+
stroke = (_ref = evt.which) != null ? _ref : evt.keyCode;
|
451 |
+
this.search_field_scale();
|
452 |
+
switch (stroke) {
|
453 |
+
case 8:
|
454 |
+
if (this.is_multiple && this.backstroke_length < 1 && this.choices_count() > 0) {
|
455 |
+
return this.keydown_backstroke();
|
456 |
+
} else if (!this.pending_backstroke) {
|
457 |
+
this.result_clear_highlight();
|
458 |
+
return this.results_search();
|
459 |
+
}
|
460 |
+
break;
|
461 |
+
case 13:
|
462 |
+
evt.preventDefault();
|
463 |
+
if (this.results_showing) {
|
464 |
+
return this.result_select(evt);
|
465 |
+
}
|
466 |
+
break;
|
467 |
+
case 27:
|
468 |
+
if (this.results_showing) {
|
469 |
+
this.results_hide();
|
470 |
+
}
|
471 |
+
return true;
|
472 |
+
case 9:
|
473 |
+
case 38:
|
474 |
+
case 40:
|
475 |
+
case 16:
|
476 |
+
case 91:
|
477 |
+
case 17:
|
478 |
+
case 18:
|
479 |
+
break;
|
480 |
+
default:
|
481 |
+
return this.results_search();
|
482 |
+
}
|
483 |
+
};
|
484 |
+
|
485 |
+
AbstractChosen.prototype.clipboard_event_checker = function(evt) {
|
486 |
+
var _this = this;
|
487 |
+
return setTimeout((function() {
|
488 |
+
return _this.results_search();
|
489 |
+
}), 50);
|
490 |
+
};
|
491 |
+
|
492 |
+
AbstractChosen.prototype.container_width = function() {
|
493 |
+
if (this.options.width != null) {
|
494 |
+
return this.options.width;
|
495 |
+
} else {
|
496 |
+
//return "" + this.form_field.offsetWidth + "px";
|
497 |
+
return "100%";
|
498 |
+
}
|
499 |
+
};
|
500 |
+
|
501 |
+
AbstractChosen.prototype.include_option_in_results = function(option) {
|
502 |
+
if (this.is_multiple && (!this.display_selected_options && option.selected)) {
|
503 |
+
return false;
|
504 |
+
}
|
505 |
+
if (!this.display_disabled_options && option.disabled) {
|
506 |
+
return false;
|
507 |
+
}
|
508 |
+
if (option.empty) {
|
509 |
+
return false;
|
510 |
+
}
|
511 |
+
return true;
|
512 |
+
};
|
513 |
+
|
514 |
+
AbstractChosen.prototype.search_results_touchstart = function(evt) {
|
515 |
+
this.touch_started = true;
|
516 |
+
return this.search_results_mouseover(evt);
|
517 |
+
};
|
518 |
+
|
519 |
+
AbstractChosen.prototype.search_results_touchmove = function(evt) {
|
520 |
+
this.touch_started = false;
|
521 |
+
return this.search_results_mouseout(evt);
|
522 |
+
};
|
523 |
+
|
524 |
+
AbstractChosen.prototype.search_results_touchend = function(evt) {
|
525 |
+
if (this.touch_started) {
|
526 |
+
return this.search_results_mouseup(evt);
|
527 |
+
}
|
528 |
+
};
|
529 |
+
|
530 |
+
AbstractChosen.prototype.outerHTML = function(element) {
|
531 |
+
var tmp;
|
532 |
+
if (element.outerHTML) {
|
533 |
+
return element.outerHTML;
|
534 |
+
}
|
535 |
+
tmp = document.createElement("div");
|
536 |
+
tmp.appendChild(element);
|
537 |
+
return tmp.innerHTML;
|
538 |
+
};
|
539 |
+
|
540 |
+
AbstractChosen.browser_is_supported = function() {
|
541 |
+
if (/iP(od|hone)/i.test(window.navigator.userAgent)) {
|
542 |
+
return false;
|
543 |
+
}
|
544 |
+
if (/Android/i.test(window.navigator.userAgent)) {
|
545 |
+
if (/Mobile/i.test(window.navigator.userAgent)) {
|
546 |
+
return false;
|
547 |
+
}
|
548 |
+
}
|
549 |
+
if (/IEMobile/i.test(window.navigator.userAgent)) {
|
550 |
+
return false;
|
551 |
+
}
|
552 |
+
if (/Windows Phone/i.test(window.navigator.userAgent)) {
|
553 |
+
return false;
|
554 |
+
}
|
555 |
+
if (/BlackBerry/i.test(window.navigator.userAgent)) {
|
556 |
+
return false;
|
557 |
+
}
|
558 |
+
if (/BB10/i.test(window.navigator.userAgent)) {
|
559 |
+
return false;
|
560 |
+
}
|
561 |
+
if (window.navigator.appName === "Microsoft Internet Explorer") {
|
562 |
+
return document.documentMode >= 8;
|
563 |
+
}
|
564 |
+
return true;
|
565 |
+
};
|
566 |
+
|
567 |
+
AbstractChosen.default_multiple_text = "Select report";
|
568 |
+
|
569 |
+
AbstractChosen.default_single_text = "Select an Option";
|
570 |
+
|
571 |
+
AbstractChosen.default_no_result_text = "No results match";
|
572 |
+
|
573 |
+
return AbstractChosen;
|
574 |
+
|
575 |
+
})();
|
576 |
+
|
577 |
+
$ = jQuery;
|
578 |
+
|
579 |
+
$.fn.extend({
|
580 |
+
chosen: function(options) {
|
581 |
+
if (!AbstractChosen.browser_is_supported()) {
|
582 |
+
return this;
|
583 |
+
}
|
584 |
+
return this.each(function(input_field) {
|
585 |
+
var $this, chosen;
|
586 |
+
$this = $(this);
|
587 |
+
chosen = $this.data('chosen');
|
588 |
+
if (options === 'destroy') {
|
589 |
+
if (chosen instanceof Chosen) {
|
590 |
+
chosen.destroy();
|
591 |
+
}
|
592 |
+
return;
|
593 |
+
}
|
594 |
+
if (!(chosen instanceof Chosen)) {
|
595 |
+
$this.data('chosen', new Chosen(this, options));
|
596 |
+
}
|
597 |
+
});
|
598 |
+
}
|
599 |
+
});
|
600 |
+
|
601 |
+
Chosen = (function(_super) {
|
602 |
+
__extends(Chosen, _super);
|
603 |
+
|
604 |
+
function Chosen() {
|
605 |
+
_ref = Chosen.__super__.constructor.apply(this, arguments);
|
606 |
+
return _ref;
|
607 |
+
}
|
608 |
+
|
609 |
+
Chosen.prototype.setup = function() {
|
610 |
+
this.form_field_jq = $(this.form_field);
|
611 |
+
this.current_selectedIndex = this.form_field.selectedIndex;
|
612 |
+
return this.is_rtl = this.form_field_jq.hasClass("chosen-rtl");
|
613 |
+
};
|
614 |
+
|
615 |
+
Chosen.prototype.set_up_html = function() {
|
616 |
+
var container_classes, container_props;
|
617 |
+
container_classes = ["chosen-container"];
|
618 |
+
container_classes.push("chosen-container-" + (this.is_multiple ? "multi" : "single"));
|
619 |
+
if (this.inherit_select_classes && this.form_field.className) {
|
620 |
+
container_classes.push(this.form_field.className);
|
621 |
+
}
|
622 |
+
if (this.is_rtl) {
|
623 |
+
container_classes.push("chosen-rtl");
|
624 |
+
}
|
625 |
+
container_props = {
|
626 |
+
'class': container_classes.join(' '),
|
627 |
+
'style': "width: " + (this.container_width()) + ";",
|
628 |
+
'title': this.form_field.title
|
629 |
+
};
|
630 |
+
if (this.form_field.id.length) {
|
631 |
+
container_props.id = this.form_field.id.replace(/[^\w]/g, '_') + "_chosen";
|
632 |
+
}
|
633 |
+
this.container = $("<div />", container_props);
|
634 |
+
if (this.is_multiple) {
|
635 |
+
this.container.html('<ul class="chosen-choices"><li class="search-field"><input type="text" value="' + this.default_text + '" class="default" autocomplete="off" style="width:25px;" /></li></ul><div class="chosen-drop"><ul class="chosen-results"></ul></div>');
|
636 |
+
} else {
|
637 |
+
this.container.html('<a class="chosen-single chosen-default"><span>' + this.default_text + '</span><div><b></b></div></a><div class="chosen-drop"><div class="chosen-search"><input type="text" autocomplete="off" /></div><ul class="chosen-results"></ul></div>');
|
638 |
+
}
|
639 |
+
this.form_field_jq.hide().after(this.container);
|
640 |
+
this.dropdown = this.container.find('div.chosen-drop').first();
|
641 |
+
this.search_field = this.container.find('input').first();
|
642 |
+
this.search_results = this.container.find('ul.chosen-results').first();
|
643 |
+
this.search_field_scale();
|
644 |
+
this.search_no_results = this.container.find('li.no-results').first();
|
645 |
+
if (this.is_multiple) {
|
646 |
+
this.search_choices = this.container.find('ul.chosen-choices').first();
|
647 |
+
this.search_container = this.container.find('li.search-field').first();
|
648 |
+
} else {
|
649 |
+
this.search_container = this.container.find('div.chosen-search').first();
|
650 |
+
this.selected_item = this.container.find('.chosen-single').first();
|
651 |
+
}
|
652 |
+
this.results_build();
|
653 |
+
this.set_tab_index();
|
654 |
+
return this.set_label_behavior();
|
655 |
+
};
|
656 |
+
|
657 |
+
Chosen.prototype.on_ready = function() {
|
658 |
+
return this.form_field_jq.trigger("chosen:ready", {
|
659 |
+
chosen: this
|
660 |
+
});
|
661 |
+
};
|
662 |
+
|
663 |
+
Chosen.prototype.register_observers = function() {
|
664 |
+
var _this = this;
|
665 |
+
this.container.bind('touchstart.chosen', function(evt) {
|
666 |
+
_this.container_mousedown(evt);
|
667 |
+
return evt.preventDefault();
|
668 |
+
});
|
669 |
+
this.container.bind('touchend.chosen', function(evt) {
|
670 |
+
_this.container_mouseup(evt);
|
671 |
+
return evt.preventDefault();
|
672 |
+
});
|
673 |
+
this.container.bind('mousedown.chosen', function(evt) {
|
674 |
+
_this.container_mousedown(evt);
|
675 |
+
});
|
676 |
+
this.container.bind('mouseup.chosen', function(evt) {
|
677 |
+
_this.container_mouseup(evt);
|
678 |
+
});
|
679 |
+
this.container.bind('mouseenter.chosen', function(evt) {
|
680 |
+
_this.mouse_enter(evt);
|
681 |
+
});
|
682 |
+
this.container.bind('mouseleave.chosen', function(evt) {
|
683 |
+
_this.mouse_leave(evt);
|
684 |
+
});
|
685 |
+
this.search_results.bind('mouseup.chosen', function(evt) {
|
686 |
+
_this.search_results_mouseup(evt);
|
687 |
+
});
|
688 |
+
this.search_results.bind('mouseover.chosen', function(evt) {
|
689 |
+
_this.search_results_mouseover(evt);
|
690 |
+
});
|
691 |
+
this.search_results.bind('mouseout.chosen', function(evt) {
|
692 |
+
_this.search_results_mouseout(evt);
|
693 |
+
});
|
694 |
+
this.search_results.bind('mousewheel.chosen DOMMouseScroll.chosen', function(evt) {
|
695 |
+
_this.search_results_mousewheel(evt);
|
696 |
+
});
|
697 |
+
this.search_results.bind('touchstart.chosen', function(evt) {
|
698 |
+
_this.search_results_touchstart(evt);
|
699 |
+
});
|
700 |
+
this.search_results.bind('touchmove.chosen', function(evt) {
|
701 |
+
_this.search_results_touchmove(evt);
|
702 |
+
});
|
703 |
+
this.search_results.bind('touchend.chosen', function(evt) {
|
704 |
+
_this.search_results_touchend(evt);
|
705 |
+
});
|
706 |
+
this.form_field_jq.bind("chosen:updated.chosen", function(evt) {
|
707 |
+
_this.results_update_field(evt);
|
708 |
+
});
|
709 |
+
this.form_field_jq.bind("chosen:activate.chosen", function(evt) {
|
710 |
+
_this.activate_field(evt);
|
711 |
+
});
|
712 |
+
this.form_field_jq.bind("chosen:open.chosen", function(evt) {
|
713 |
+
_this.container_mousedown(evt);
|
714 |
+
});
|
715 |
+
this.form_field_jq.bind("chosen:close.chosen", function(evt) {
|
716 |
+
_this.input_blur(evt);
|
717 |
+
});
|
718 |
+
this.search_field.bind('blur.chosen', function(evt) {
|
719 |
+
_this.input_blur(evt);
|
720 |
+
});
|
721 |
+
this.search_field.bind('keyup.chosen', function(evt) {
|
722 |
+
_this.keyup_checker(evt);
|
723 |
+
});
|
724 |
+
this.search_field.bind('keydown.chosen', function(evt) {
|
725 |
+
_this.keydown_checker(evt);
|
726 |
+
});
|
727 |
+
this.search_field.bind('focus.chosen', function(evt) {
|
728 |
+
_this.input_focus(evt);
|
729 |
+
});
|
730 |
+
this.search_field.bind('cut.chosen', function(evt) {
|
731 |
+
_this.clipboard_event_checker(evt);
|
732 |
+
});
|
733 |
+
this.search_field.bind('paste.chosen', function(evt) {
|
734 |
+
_this.clipboard_event_checker(evt);
|
735 |
+
});
|
736 |
+
if (this.is_multiple) {
|
737 |
+
return this.search_choices.bind('click.chosen', function(evt) {
|
738 |
+
_this.choices_click(evt);
|
739 |
+
});
|
740 |
+
} else {
|
741 |
+
return this.container.bind('click.chosen', function(evt) {
|
742 |
+
evt.preventDefault();
|
743 |
+
});
|
744 |
+
}
|
745 |
+
};
|
746 |
+
|
747 |
+
Chosen.prototype.destroy = function() {
|
748 |
+
$(this.container[0].ownerDocument).unbind("click.chosen", this.click_test_action);
|
749 |
+
if (this.search_field[0].tabIndex) {
|
750 |
+
this.form_field_jq[0].tabIndex = this.search_field[0].tabIndex;
|
751 |
+
}
|
752 |
+
this.container.remove();
|
753 |
+
this.form_field_jq.removeData('chosen');
|
754 |
+
return this.form_field_jq.show();
|
755 |
+
};
|
756 |
+
|
757 |
+
Chosen.prototype.search_field_disabled = function() {
|
758 |
+
this.is_disabled = this.form_field_jq[0].disabled;
|
759 |
+
if (this.is_disabled) {
|
760 |
+
this.container.addClass('chosen-disabled');
|
761 |
+
this.search_field[0].disabled = true;
|
762 |
+
if (!this.is_multiple) {
|
763 |
+
this.selected_item.unbind("focus.chosen", this.activate_action);
|
764 |
+
}
|
765 |
+
return this.close_field();
|
766 |
+
} else {
|
767 |
+
this.container.removeClass('chosen-disabled');
|
768 |
+
this.search_field[0].disabled = false;
|
769 |
+
if (!this.is_multiple) {
|
770 |
+
return this.selected_item.bind("focus.chosen", this.activate_action);
|
771 |
+
}
|
772 |
+
}
|
773 |
+
};
|
774 |
+
|
775 |
+
Chosen.prototype.container_mousedown = function(evt) {
|
776 |
+
if (!this.is_disabled) {
|
777 |
+
if (evt && evt.type === "mousedown" && !this.results_showing) {
|
778 |
+
evt.preventDefault();
|
779 |
+
}
|
780 |
+
if (!((evt != null) && ($(evt.target)).hasClass("search-choice-close"))) {
|
781 |
+
if (!this.active_field) {
|
782 |
+
if (this.is_multiple) {
|
783 |
+
this.search_field.val("");
|
784 |
+
}
|
785 |
+
$(this.container[0].ownerDocument).bind('click.chosen', this.click_test_action);
|
786 |
+
this.results_show();
|
787 |
+
} else if (!this.is_multiple && evt && (($(evt.target)[0] === this.selected_item[0]) || $(evt.target).parents("a.chosen-single").length)) {
|
788 |
+
evt.preventDefault();
|
789 |
+
this.results_toggle();
|
790 |
+
}
|
791 |
+
return this.activate_field();
|
792 |
+
}
|
793 |
+
}
|
794 |
+
};
|
795 |
+
|
796 |
+
Chosen.prototype.container_mouseup = function(evt) {
|
797 |
+
if (evt.target.nodeName === "ABBR" && !this.is_disabled) {
|
798 |
+
return this.results_reset(evt);
|
799 |
+
}
|
800 |
+
};
|
801 |
+
|
802 |
+
Chosen.prototype.search_results_mousewheel = function(evt) {
|
803 |
+
var delta;
|
804 |
+
if (evt.originalEvent) {
|
805 |
+
delta = evt.originalEvent.deltaY || -evt.originalEvent.wheelDelta || evt.originalEvent.detail;
|
806 |
+
}
|
807 |
+
if (delta != null) {
|
808 |
+
evt.preventDefault();
|
809 |
+
if (evt.type === 'DOMMouseScroll') {
|
810 |
+
delta = delta * 40;
|
811 |
+
}
|
812 |
+
return this.search_results.scrollTop(delta + this.search_results.scrollTop());
|
813 |
+
}
|
814 |
+
};
|
815 |
+
|
816 |
+
Chosen.prototype.blur_test = function(evt) {
|
817 |
+
if (!this.active_field && this.container.hasClass("chosen-container-active")) {
|
818 |
+
return this.close_field();
|
819 |
+
}
|
820 |
+
};
|
821 |
+
|
822 |
+
Chosen.prototype.close_field = function() {
|
823 |
+
$(this.container[0].ownerDocument).unbind("click.chosen", this.click_test_action);
|
824 |
+
this.active_field = false;
|
825 |
+
this.results_hide();
|
826 |
+
this.container.removeClass("chosen-container-active");
|
827 |
+
this.clear_backstroke();
|
828 |
+
this.show_search_field_default();
|
829 |
+
return this.search_field_scale();
|
830 |
+
};
|
831 |
+
|
832 |
+
Chosen.prototype.activate_field = function() {
|
833 |
+
this.container.addClass("chosen-container-active");
|
834 |
+
this.active_field = true;
|
835 |
+
this.search_field.val(this.search_field.val());
|
836 |
+
return this.search_field.focus();
|
837 |
+
};
|
838 |
+
|
839 |
+
Chosen.prototype.test_active_click = function(evt) {
|
840 |
+
var active_container;
|
841 |
+
active_container = $(evt.target).closest('.chosen-container');
|
842 |
+
if (active_container.length && this.container[0] === active_container[0]) {
|
843 |
+
return this.active_field = true;
|
844 |
+
} else {
|
845 |
+
return this.close_field();
|
846 |
+
}
|
847 |
+
};
|
848 |
+
|
849 |
+
Chosen.prototype.results_build = function() {
|
850 |
+
this.parsing = true;
|
851 |
+
this.selected_option_count = null;
|
852 |
+
this.results_data = SelectParser.select_to_array(this.form_field);
|
853 |
+
if (this.is_multiple) {
|
854 |
+
this.search_choices.find("li.search-choice").remove();
|
855 |
+
} else if (!this.is_multiple) {
|
856 |
+
this.single_set_selected_text();
|
857 |
+
if (this.disable_search || this.form_field.options.length <= this.disable_search_threshold) {
|
858 |
+
this.search_field[0].readOnly = true;
|
859 |
+
this.container.addClass("chosen-container-single-nosearch");
|
860 |
+
} else {
|
861 |
+
this.search_field[0].readOnly = false;
|
862 |
+
this.container.removeClass("chosen-container-single-nosearch");
|
863 |
+
}
|
864 |
+
}
|
865 |
+
this.update_results_content(this.results_option_build({
|
866 |
+
first: true
|
867 |
+
}));
|
868 |
+
this.search_field_disabled();
|
869 |
+
this.show_search_field_default();
|
870 |
+
this.search_field_scale();
|
871 |
+
return this.parsing = false;
|
872 |
+
};
|
873 |
+
|
874 |
+
Chosen.prototype.result_do_highlight = function(el) {
|
875 |
+
var high_bottom, high_top, maxHeight, visible_bottom, visible_top;
|
876 |
+
if (el.length) {
|
877 |
+
this.result_clear_highlight();
|
878 |
+
this.result_highlight = el;
|
879 |
+
this.result_highlight.addClass("highlighted");
|
880 |
+
maxHeight = parseInt(this.search_results.css("maxHeight"), 10);
|
881 |
+
visible_top = this.search_results.scrollTop();
|
882 |
+
visible_bottom = maxHeight + visible_top;
|
883 |
+
high_top = this.result_highlight.position().top + this.search_results.scrollTop();
|
884 |
+
high_bottom = high_top + this.result_highlight.outerHeight();
|
885 |
+
if (high_bottom >= visible_bottom) {
|
886 |
+
return this.search_results.scrollTop((high_bottom - maxHeight) > 0 ? high_bottom - maxHeight : 0);
|
887 |
+
} else if (high_top < visible_top) {
|
888 |
+
return this.search_results.scrollTop(high_top);
|
889 |
+
}
|
890 |
+
}
|
891 |
+
};
|
892 |
+
|
893 |
+
Chosen.prototype.result_clear_highlight = function() {
|
894 |
+
if (this.result_highlight) {
|
895 |
+
this.result_highlight.removeClass("highlighted");
|
896 |
+
}
|
897 |
+
return this.result_highlight = null;
|
898 |
+
};
|
899 |
+
|
900 |
+
Chosen.prototype.results_show = function() {
|
901 |
+
if (this.is_multiple && this.max_selected_options <= this.choices_count()) {
|
902 |
+
this.form_field_jq.trigger("chosen:maxselected", {
|
903 |
+
chosen: this
|
904 |
+
});
|
905 |
+
return false;
|
906 |
+
}
|
907 |
+
this.container.addClass("chosen-with-drop");
|
908 |
+
this.results_showing = true;
|
909 |
+
this.search_field.focus();
|
910 |
+
this.search_field.val(this.search_field.val());
|
911 |
+
this.winnow_results();
|
912 |
+
return this.form_field_jq.trigger("chosen:showing_dropdown", {
|
913 |
+
chosen: this
|
914 |
+
});
|
915 |
+
};
|
916 |
+
|
917 |
+
Chosen.prototype.update_results_content = function(content) {
|
918 |
+
return this.search_results.html(content);
|
919 |
+
};
|
920 |
+
|
921 |
+
Chosen.prototype.results_hide = function() {
|
922 |
+
if (this.results_showing) {
|
923 |
+
this.result_clear_highlight();
|
924 |
+
this.container.removeClass("chosen-with-drop");
|
925 |
+
this.form_field_jq.trigger("chosen:hiding_dropdown", {
|
926 |
+
chosen: this
|
927 |
+
});
|
928 |
+
}
|
929 |
+
return this.results_showing = false;
|
930 |
+
};
|
931 |
+
|
932 |
+
Chosen.prototype.set_tab_index = function(el) {
|
933 |
+
var ti;
|
934 |
+
if (this.form_field.tabIndex) {
|
935 |
+
ti = this.form_field.tabIndex;
|
936 |
+
this.form_field.tabIndex = -1;
|
937 |
+
return this.search_field[0].tabIndex = ti;
|
938 |
+
}
|
939 |
+
};
|
940 |
+
|
941 |
+
Chosen.prototype.set_label_behavior = function() {
|
942 |
+
var _this = this;
|
943 |
+
this.form_field_label = this.form_field_jq.parents("label");
|
944 |
+
if (!this.form_field_label.length && this.form_field.id.length) {
|
945 |
+
this.form_field_label = $("label[for='" + this.form_field.id + "']");
|
946 |
+
}
|
947 |
+
if (this.form_field_label.length > 0) {
|
948 |
+
return this.form_field_label.bind('click.chosen', function(evt) {
|
949 |
+
if (_this.is_multiple) {
|
950 |
+
return _this.container_mousedown(evt);
|
951 |
+
} else {
|
952 |
+
return _this.activate_field();
|
953 |
+
}
|
954 |
+
});
|
955 |
+
}
|
956 |
+
};
|
957 |
+
|
958 |
+
Chosen.prototype.show_search_field_default = function() {
|
959 |
+
if (this.is_multiple && this.choices_count() < 1 && !this.active_field) {
|
960 |
+
this.search_field.val(this.default_text);
|
961 |
+
return this.search_field.addClass("default");
|
962 |
+
} else {
|
963 |
+
this.search_field.val("");
|
964 |
+
return this.search_field.removeClass("default");
|
965 |
+
}
|
966 |
+
};
|
967 |
+
|
968 |
+
Chosen.prototype.search_results_mouseup = function(evt) {
|
969 |
+
var target;
|
970 |
+
target = $(evt.target).hasClass("active-result") ? $(evt.target) : $(evt.target).parents(".active-result").first();
|
971 |
+
if (target.length) {
|
972 |
+
this.result_highlight = target;
|
973 |
+
this.result_select(evt);
|
974 |
+
return this.search_field.focus();
|
975 |
+
}
|
976 |
+
};
|
977 |
+
|
978 |
+
Chosen.prototype.search_results_mouseover = function(evt) {
|
979 |
+
var target;
|
980 |
+
target = $(evt.target).hasClass("active-result") ? $(evt.target) : $(evt.target).parents(".active-result").first();
|
981 |
+
if (target) {
|
982 |
+
return this.result_do_highlight(target);
|
983 |
+
}
|
984 |
+
};
|
985 |
+
|
986 |
+
Chosen.prototype.search_results_mouseout = function(evt) {
|
987 |
+
if ($(evt.target).hasClass("active-result" || $(evt.target).parents('.active-result').first())) {
|
988 |
+
return this.result_clear_highlight();
|
989 |
+
}
|
990 |
+
};
|
991 |
+
|
992 |
+
Chosen.prototype.choice_build = function(item) {
|
993 |
+
var choice, close_link,
|
994 |
+
_this = this;
|
995 |
+
choice = $('<li />', {
|
996 |
+
"class": "search-choice"
|
997 |
+
}).html("<span>" + (this.choice_label(item)) + "</span>");
|
998 |
+
if (item.disabled) {
|
999 |
+
choice.addClass('search-choice-disabled');
|
1000 |
+
} else {
|
1001 |
+
close_link = $('<a />', {
|
1002 |
+
"class": 'search-choice-close',
|
1003 |
+
'data-option-array-index': item.array_index
|
1004 |
+
});
|
1005 |
+
close_link.bind('click.chosen', function(evt) {
|
1006 |
+
return _this.choice_destroy_link_click(evt);
|
1007 |
+
});
|
1008 |
+
choice.append(close_link);
|
1009 |
+
}
|
1010 |
+
return this.search_container.before(choice);
|
1011 |
+
};
|
1012 |
+
|
1013 |
+
Chosen.prototype.choice_destroy_link_click = function(evt) {
|
1014 |
+
evt.preventDefault();
|
1015 |
+
evt.stopPropagation();
|
1016 |
+
if (!this.is_disabled) {
|
1017 |
+
return this.choice_destroy($(evt.target));
|
1018 |
+
}
|
1019 |
+
};
|
1020 |
+
|
1021 |
+
Chosen.prototype.choice_destroy = function(link) {
|
1022 |
+
if (this.result_deselect(link[0].getAttribute("data-option-array-index"))) {
|
1023 |
+
this.show_search_field_default();
|
1024 |
+
if (this.is_multiple && this.choices_count() > 0 && this.search_field.val().length < 1) {
|
1025 |
+
this.results_hide();
|
1026 |
+
}
|
1027 |
+
link.parents('li').first().remove();
|
1028 |
+
return this.search_field_scale();
|
1029 |
+
}
|
1030 |
+
};
|
1031 |
+
|
1032 |
+
Chosen.prototype.results_reset = function() {
|
1033 |
+
this.reset_single_select_options();
|
1034 |
+
this.form_field.options[0].selected = true;
|
1035 |
+
this.single_set_selected_text();
|
1036 |
+
this.show_search_field_default();
|
1037 |
+
this.results_reset_cleanup();
|
1038 |
+
this.form_field_jq.trigger("change");
|
1039 |
+
if (this.active_field) {
|
1040 |
+
return this.results_hide();
|
1041 |
+
}
|
1042 |
+
};
|
1043 |
+
|
1044 |
+
Chosen.prototype.results_reset_cleanup = function() {
|
1045 |
+
this.current_selectedIndex = this.form_field.selectedIndex;
|
1046 |
+
return this.selected_item.find("abbr").remove();
|
1047 |
+
};
|
1048 |
+
|
1049 |
+
Chosen.prototype.result_select = function(evt) {
|
1050 |
+
var high, item;
|
1051 |
+
if (this.result_highlight) {
|
1052 |
+
high = this.result_highlight;
|
1053 |
+
this.result_clear_highlight();
|
1054 |
+
if (this.is_multiple && this.max_selected_options <= this.choices_count()) {
|
1055 |
+
this.form_field_jq.trigger("chosen:maxselected", {
|
1056 |
+
chosen: this
|
1057 |
+
});
|
1058 |
+
return false;
|
1059 |
+
}
|
1060 |
+
if (this.is_multiple) {
|
1061 |
+
high.removeClass("active-result");
|
1062 |
+
} else {
|
1063 |
+
this.reset_single_select_options();
|
1064 |
+
}
|
1065 |
+
high.addClass("result-selected");
|
1066 |
+
item = this.results_data[high[0].getAttribute("data-option-array-index")];
|
1067 |
+
item.selected = true;
|
1068 |
+
this.form_field.options[item.options_index].selected = true;
|
1069 |
+
this.selected_option_count = null;
|
1070 |
+
if (this.is_multiple) {
|
1071 |
+
this.choice_build(item);
|
1072 |
+
} else {
|
1073 |
+
this.single_set_selected_text(this.choice_label(item));
|
1074 |
+
}
|
1075 |
+
if (!((evt.metaKey || evt.ctrlKey) && this.is_multiple)) {
|
1076 |
+
this.results_hide();
|
1077 |
+
}
|
1078 |
+
this.show_search_field_default();
|
1079 |
+
if (this.is_multiple || this.form_field.selectedIndex !== this.current_selectedIndex) {
|
1080 |
+
this.form_field_jq.trigger("change", {
|
1081 |
+
'selected': this.form_field.options[item.options_index].value
|
1082 |
+
});
|
1083 |
+
}
|
1084 |
+
this.current_selectedIndex = this.form_field.selectedIndex;
|
1085 |
+
evt.preventDefault();
|
1086 |
+
return this.search_field_scale();
|
1087 |
+
}
|
1088 |
+
};
|
1089 |
+
|
1090 |
+
Chosen.prototype.single_set_selected_text = function(text) {
|
1091 |
+
if (text == null) {
|
1092 |
+
text = this.default_text;
|
1093 |
+
}
|
1094 |
+
if (text === this.default_text) {
|
1095 |
+
this.selected_item.addClass("chosen-default");
|
1096 |
+
} else {
|
1097 |
+
this.single_deselect_control_build();
|
1098 |
+
this.selected_item.removeClass("chosen-default");
|
1099 |
+
}
|
1100 |
+
return this.selected_item.find("span").html(text);
|
1101 |
+
};
|
1102 |
+
|
1103 |
+
Chosen.prototype.result_deselect = function(pos) {
|
1104 |
+
var result_data;
|
1105 |
+
result_data = this.results_data[pos];
|
1106 |
+
if (!this.form_field.options[result_data.options_index].disabled) {
|
1107 |
+
result_data.selected = false;
|
1108 |
+
this.form_field.options[result_data.options_index].selected = false;
|
1109 |
+
this.selected_option_count = null;
|
1110 |
+
this.result_clear_highlight();
|
1111 |
+
if (this.results_showing) {
|
1112 |
+
this.winnow_results();
|
1113 |
+
}
|
1114 |
+
this.form_field_jq.trigger("change", {
|
1115 |
+
deselected: this.form_field.options[result_data.options_index].value
|
1116 |
+
});
|
1117 |
+
this.search_field_scale();
|
1118 |
+
return true;
|
1119 |
+
} else {
|
1120 |
+
return false;
|
1121 |
+
}
|
1122 |
+
};
|
1123 |
+
|
1124 |
+
Chosen.prototype.single_deselect_control_build = function() {
|
1125 |
+
if (!this.allow_single_deselect) {
|
1126 |
+
return;
|
1127 |
+
}
|
1128 |
+
if (!this.selected_item.find("abbr").length) {
|
1129 |
+
this.selected_item.find("span").first().after("<abbr class=\"search-choice-close\"></abbr>");
|
1130 |
+
}
|
1131 |
+
return this.selected_item.addClass("chosen-single-with-deselect");
|
1132 |
+
};
|
1133 |
+
|
1134 |
+
Chosen.prototype.get_search_text = function() {
|
1135 |
+
return $('<div/>').text($.trim(this.search_field.val())).html();
|
1136 |
+
};
|
1137 |
+
|
1138 |
+
Chosen.prototype.winnow_results_set_highlight = function() {
|
1139 |
+
var do_high, selected_results;
|
1140 |
+
selected_results = !this.is_multiple ? this.search_results.find(".result-selected.active-result") : [];
|
1141 |
+
do_high = selected_results.length ? selected_results.first() : this.search_results.find(".active-result").first();
|
1142 |
+
if (do_high != null) {
|
1143 |
+
return this.result_do_highlight(do_high);
|
1144 |
+
}
|
1145 |
+
};
|
1146 |
+
|
1147 |
+
Chosen.prototype.no_results = function(terms) {
|
1148 |
+
var no_results_html;
|
1149 |
+
no_results_html = $('<li class="no-results">' + this.results_none_found + ' "<span></span>"</li>');
|
1150 |
+
no_results_html.find("span").first().html(terms);
|
1151 |
+
this.search_results.append(no_results_html);
|
1152 |
+
return this.form_field_jq.trigger("chosen:no_results", {
|
1153 |
+
chosen: this
|
1154 |
+
});
|
1155 |
+
};
|
1156 |
+
|
1157 |
+
Chosen.prototype.no_results_clear = function() {
|
1158 |
+
return this.search_results.find(".no-results").remove();
|
1159 |
+
};
|
1160 |
+
|
1161 |
+
Chosen.prototype.keydown_arrow = function() {
|
1162 |
+
var next_sib;
|
1163 |
+
if (this.results_showing && this.result_highlight) {
|
1164 |
+
next_sib = this.result_highlight.nextAll("li.active-result").first();
|
1165 |
+
if (next_sib) {
|
1166 |
+
return this.result_do_highlight(next_sib);
|
1167 |
+
}
|
1168 |
+
} else {
|
1169 |
+
return this.results_show();
|
1170 |
+
}
|
1171 |
+
};
|
1172 |
+
|
1173 |
+
Chosen.prototype.keyup_arrow = function() {
|
1174 |
+
var prev_sibs;
|
1175 |
+
if (!this.results_showing && !this.is_multiple) {
|
1176 |
+
return this.results_show();
|
1177 |
+
} else if (this.result_highlight) {
|
1178 |
+
prev_sibs = this.result_highlight.prevAll("li.active-result");
|
1179 |
+
if (prev_sibs.length) {
|
1180 |
+
return this.result_do_highlight(prev_sibs.first());
|
1181 |
+
} else {
|
1182 |
+
if (this.choices_count() > 0) {
|
1183 |
+
this.results_hide();
|
1184 |
+
}
|
1185 |
+
return this.result_clear_highlight();
|
1186 |
+
}
|
1187 |
+
}
|
1188 |
+
};
|
1189 |
+
|
1190 |
+
Chosen.prototype.keydown_backstroke = function() {
|
1191 |
+
var next_available_destroy;
|
1192 |
+
if (this.pending_backstroke) {
|
1193 |
+
this.choice_destroy(this.pending_backstroke.find("a").first());
|
1194 |
+
return this.clear_backstroke();
|
1195 |
+
} else {
|
1196 |
+
next_available_destroy = this.search_container.siblings("li.search-choice").last();
|
1197 |
+
if (next_available_destroy.length && !next_available_destroy.hasClass("search-choice-disabled")) {
|
1198 |
+
this.pending_backstroke = next_available_destroy;
|
1199 |
+
if (this.single_backstroke_delete) {
|
1200 |
+
return this.keydown_backstroke();
|
1201 |
+
} else {
|
1202 |
+
return this.pending_backstroke.addClass("search-choice-focus");
|
1203 |
+
}
|
1204 |
+
}
|
1205 |
+
}
|
1206 |
+
};
|
1207 |
+
|
1208 |
+
Chosen.prototype.clear_backstroke = function() {
|
1209 |
+
if (this.pending_backstroke) {
|
1210 |
+
this.pending_backstroke.removeClass("search-choice-focus");
|
1211 |
+
}
|
1212 |
+
return this.pending_backstroke = null;
|
1213 |
+
};
|
1214 |
+
|
1215 |
+
Chosen.prototype.keydown_checker = function(evt) {
|
1216 |
+
var stroke, _ref1;
|
1217 |
+
stroke = (_ref1 = evt.which) != null ? _ref1 : evt.keyCode;
|
1218 |
+
this.search_field_scale();
|
1219 |
+
if (stroke !== 8 && this.pending_backstroke) {
|
1220 |
+
this.clear_backstroke();
|
1221 |
+
}
|
1222 |
+
switch (stroke) {
|
1223 |
+
case 8:
|
1224 |
+
this.backstroke_length = this.search_field.val().length;
|
1225 |
+
break;
|
1226 |
+
case 9:
|
1227 |
+
if (this.results_showing && !this.is_multiple) {
|
1228 |
+
this.result_select(evt);
|
1229 |
+
}
|
1230 |
+
this.mouse_on_container = false;
|
1231 |
+
break;
|
1232 |
+
case 13:
|
1233 |
+
if (this.results_showing) {
|
1234 |
+
evt.preventDefault();
|
1235 |
+
}
|
1236 |
+
break;
|
1237 |
+
case 32:
|
1238 |
+
if (this.disable_search) {
|
1239 |
+
evt.preventDefault();
|
1240 |
+
}
|
1241 |
+
break;
|
1242 |
+
case 38:
|
1243 |
+
evt.preventDefault();
|
1244 |
+
this.keyup_arrow();
|
1245 |
+
break;
|
1246 |
+
case 40:
|
1247 |
+
evt.preventDefault();
|
1248 |
+
this.keydown_arrow();
|
1249 |
+
break;
|
1250 |
+
}
|
1251 |
+
};
|
1252 |
+
|
1253 |
+
Chosen.prototype.search_field_scale = function() {
|
1254 |
+
var div, f_width, h, style, style_block, styles, w, _i, _len;
|
1255 |
+
if (this.is_multiple) {
|
1256 |
+
h = 0;
|
1257 |
+
w = 0;
|
1258 |
+
style_block = "position:absolute; left: -1000px; top: -1000px; display:none;";
|
1259 |
+
styles = ['font-size', 'font-style', 'font-weight', 'font-family', 'line-height', 'text-transform', 'letter-spacing'];
|
1260 |
+
for (_i = 0, _len = styles.length; _i < _len; _i++) {
|
1261 |
+
style = styles[_i];
|
1262 |
+
style_block += style + ":" + this.search_field.css(style) + ";";
|
1263 |
+
}
|
1264 |
+
div = $('<div />', {
|
1265 |
+
'style': style_block
|
1266 |
+
});
|
1267 |
+
div.text(this.search_field.val());
|
1268 |
+
$('body').append(div);
|
1269 |
+
w = div.width() + 25;
|
1270 |
+
div.remove();
|
1271 |
+
f_width = this.container.outerWidth();
|
1272 |
+
if (w > f_width - 10) {
|
1273 |
+
w = f_width - 10;
|
1274 |
+
}
|
1275 |
+
return this.search_field.css({
|
1276 |
+
'width': w + 'px'
|
1277 |
+
});
|
1278 |
+
}
|
1279 |
+
};
|
1280 |
+
|
1281 |
+
return Chosen;
|
1282 |
+
|
1283 |
+
})(AbstractChosen);
|
1284 |
+
|
1285 |
}).call(this);
|
inc/js/images/lens.svg
CHANGED
@@ -1,7 +1,7 @@
|
|
1 |
-
<?xml version="1.0" encoding="utf-8"?>
|
2 |
-
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
3 |
-
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="19px" height="19px" viewBox="0 0 19 19">
|
4 |
-
<circle cx="9" cy="9" r="7" stroke="#000000" stroke-width="1.5" fill-opacity="0"/>
|
5 |
-
<line x1="6" y1="9" x2="12" y2="9" stroke="#000000" stroke-width="1.5"/>
|
6 |
-
<line x1="14" y1="14" x2="19" y2="19" stroke="#000000" stroke-width="1.5"/>
|
7 |
</svg>
|
1 |
+
<?xml version="1.0" encoding="utf-8"?>
|
2 |
+
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
|
3 |
+
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="19px" height="19px" viewBox="0 0 19 19">
|
4 |
+
<circle cx="9" cy="9" r="7" stroke="#000000" stroke-width="1.5" fill-opacity="0"/>
|
5 |
+
<line x1="6" y1="9" x2="12" y2="9" stroke="#000000" stroke-width="1.5"/>
|
6 |
+
<line x1="14" y1="14" x2="19" y2="19" stroke="#000000" stroke-width="1.5"/>
|
7 |
</svg>
|
inc/js/jquery.cookie.js
CHANGED
@@ -1,117 +1,117 @@
|
|
1 |
-
/*!
|
2 |
-
* jQuery Cookie Plugin v1.4.1
|
3 |
-
* https://github.com/carhartl/jquery-cookie
|
4 |
-
*
|
5 |
-
* Copyright 2013 Klaus Hartl
|
6 |
-
* Released under the MIT license
|
7 |
-
*/
|
8 |
-
(function (factory) {
|
9 |
-
if (typeof define === 'function' && define.amd) {
|
10 |
-
// AMD
|
11 |
-
define(['jquery'], factory);
|
12 |
-
} else if (typeof exports === 'object') {
|
13 |
-
// CommonJS
|
14 |
-
factory(require('jquery'));
|
15 |
-
} else {
|
16 |
-
// Browser globals
|
17 |
-
factory(jQuery);
|
18 |
-
}
|
19 |
-
}(function ($) {
|
20 |
-
|
21 |
-
var pluses = /\+/g;
|
22 |
-
|
23 |
-
function encode(s) {
|
24 |
-
return config.raw ? s : encodeURIComponent(s);
|
25 |
-
}
|
26 |
-
|
27 |
-
function decode(s) {
|
28 |
-
return config.raw ? s : decodeURIComponent(s);
|
29 |
-
}
|
30 |
-
|
31 |
-
function stringifyCookieValue(value) {
|
32 |
-
return encode(config.json ? JSON.stringify(value) : String(value));
|
33 |
-
}
|
34 |
-
|
35 |
-
function parseCookieValue(s) {
|
36 |
-
if (s.indexOf('"') === 0) {
|
37 |
-
// This is a quoted cookie as according to RFC2068, unescape...
|
38 |
-
s = s.slice(1, -1).replace(/\\"/g, '"').replace(/\\\\/g, '\\');
|
39 |
-
}
|
40 |
-
|
41 |
-
try {
|
42 |
-
// Replace server-side written pluses with spaces.
|
43 |
-
// If we can't decode the cookie, ignore it, it's unusable.
|
44 |
-
// If we can't parse the cookie, ignore it, it's unusable.
|
45 |
-
s = decodeURIComponent(s.replace(pluses, ' '));
|
46 |
-
return config.json ? JSON.parse(s) : s;
|
47 |
-
} catch(e) {}
|
48 |
-
}
|
49 |
-
|
50 |
-
function read(s, converter) {
|
51 |
-
var value = config.raw ? s : parseCookieValue(s);
|
52 |
-
return $.isFunction(converter) ? converter(value) : value;
|
53 |
-
}
|
54 |
-
|
55 |
-
var config = $.cookie = function (key, value, options) {
|
56 |
-
|
57 |
-
// Write
|
58 |
-
|
59 |
-
if (value !== undefined && !$.isFunction(value)) {
|
60 |
-
options = $.extend({}, config.defaults, options);
|
61 |
-
|
62 |
-
if (typeof options.expires === 'number') {
|
63 |
-
var days = options.expires, t = options.expires = new Date();
|
64 |
-
t.setTime(+t + days * 864e+5);
|
65 |
-
}
|
66 |
-
|
67 |
-
return (document.cookie = [
|
68 |
-
encode(key), '=', stringifyCookieValue(value),
|
69 |
-
options.expires ? '; expires=' + options.expires.toUTCString() : '', // use expires attribute, max-age is not supported by IE
|
70 |
-
options.path ? '; path=' + options.path : '',
|
71 |
-
options.domain ? '; domain=' + options.domain : '',
|
72 |
-
options.secure ? '; secure' : ''
|
73 |
-
].join(''));
|
74 |
-
}
|
75 |
-
|
76 |
-
// Read
|
77 |
-
|
78 |
-
var result = key ? undefined : {};
|
79 |
-
|
80 |
-
// To prevent the for loop in the first place assign an empty array
|
81 |
-
// in case there are no cookies at all. Also prevents odd result when
|
82 |
-
// calling $.cookie().
|
83 |
-
var cookies = document.cookie ? document.cookie.split('; ') : [];
|
84 |
-
|
85 |
-
for (var i = 0, l = cookies.length; i < l; i++) {
|
86 |
-
var parts = cookies[i].split('=');
|
87 |
-
var name = decode(parts.shift());
|
88 |
-
var cookie = parts.join('=');
|
89 |
-
|
90 |
-
if (key && key === name) {
|
91 |
-
// If second argument (value) is a function it's a converter...
|
92 |
-
result = read(cookie, value);
|
93 |
-
break;
|
94 |
-
}
|
95 |
-
|
96 |
-
// Prevent storing a cookie that we couldn't decode.
|
97 |
-
if (!key && (cookie = read(cookie)) !== undefined) {
|
98 |
-
result[name] = cookie;
|
99 |
-
}
|
100 |
-
}
|
101 |
-
|
102 |
-
return result;
|
103 |
-
};
|
104 |
-
|
105 |
-
config.defaults = {};
|
106 |
-
|
107 |
-
$.removeCookie = function (key, options) {
|
108 |
-
if ($.cookie(key) === undefined) {
|
109 |
-
return false;
|
110 |
-
}
|
111 |
-
|
112 |
-
// Must not alter options, thus extending a fresh object...
|
113 |
-
$.cookie(key, '', $.extend({}, options, { expires: -1 }));
|
114 |
-
return !$.cookie(key);
|
115 |
-
};
|
116 |
-
|
117 |
-
}));
|
1 |
+
/*!
|
2 |
+
* jQuery Cookie Plugin v1.4.1
|
3 |
+
* https://github.com/carhartl/jquery-cookie
|
4 |
+
*
|
5 |
+
* Copyright 2013 Klaus Hartl
|
6 |
+
* Released under the MIT license
|
7 |
+
*/
|
8 |
+
(function (factory) {
|
9 |
+
if (typeof define === 'function' && define.amd) {
|
10 |
+
// AMD
|
11 |
+
define(['jquery'], factory);
|
12 |
+
} else if (typeof exports === 'object') {
|
13 |
+
// CommonJS
|
14 |
+
factory(require('jquery'));
|
15 |
+
} else {
|
16 |
+
// Browser globals
|
17 |
+
factory(jQuery);
|
18 |
+
}
|
19 |
+
}(function ($) {
|
20 |
+
|
21 |
+
var pluses = /\+/g;
|
22 |
+
|
23 |
+
function encode(s) {
|
24 |
+
return config.raw ? s : encodeURIComponent(s);
|
25 |
+
}
|
26 |
+
|
27 |
+
function decode(s) {
|
28 |
+
return config.raw ? s : decodeURIComponent(s);
|
29 |
+
}
|
30 |
+
|
31 |
+
function stringifyCookieValue(value) {
|
32 |
+
return encode(config.json ? JSON.stringify(value) : String(value));
|
33 |
+
}
|
34 |
+
|
35 |
+
function parseCookieValue(s) {
|
36 |
+
if (s.indexOf('"') === 0) {
|
37 |
+
// This is a quoted cookie as according to RFC2068, unescape...
|
38 |
+
s = s.slice(1, -1).replace(/\\"/g, '"').replace(/\\\\/g, '\\');
|
39 |
+
}
|
40 |
+
|
41 |
+
try {
|
42 |
+
// Replace server-side written pluses with spaces.
|
43 |
+
// If we can't decode the cookie, ignore it, it's unusable.
|
44 |
+
// If we can't parse the cookie, ignore it, it's unusable.
|
45 |
+
s = decodeURIComponent(s.replace(pluses, ' '));
|
46 |
+
return config.json ? JSON.parse(s) : s;
|
47 |
+
} catch(e) {}
|
48 |
+
}
|
49 |
+
|
50 |
+
function read(s, converter) {
|
51 |
+
var value = config.raw ? s : parseCookieValue(s);
|
52 |
+
return $.isFunction(converter) ? converter(value) : value;
|
53 |
+
}
|
54 |
+
|
55 |
+
var config = $.cookie = function (key, value, options) {
|
56 |
+
|
57 |
+
// Write
|
58 |
+
|
59 |
+
if (value !== undefined && !$.isFunction(value)) {
|
60 |
+
options = $.extend({}, config.defaults, options);
|
61 |
+
|
62 |
+
if (typeof options.expires === 'number') {
|
63 |
+
var days = options.expires, t = options.expires = new Date();
|
64 |
+
t.setTime(+t + days * 864e+5);
|
65 |
+
}
|
66 |
+
|
67 |
+
return (document.cookie = [
|
68 |
+
encode(key), '=', stringifyCookieValue(value),
|
69 |
+
options.expires ? '; expires=' + options.expires.toUTCString() : '', // use expires attribute, max-age is not supported by IE
|
70 |
+
options.path ? '; path=' + options.path : '',
|
71 |
+
options.domain ? '; domain=' + options.domain : '',
|
72 |
+
options.secure ? '; secure' : ''
|
73 |
+
].join(''));
|
74 |
+
}
|
75 |
+
|
76 |
+
// Read
|
77 |
+
|
78 |
+
var result = key ? undefined : {};
|
79 |
+
|
80 |
+
// To prevent the for loop in the first place assign an empty array
|
81 |
+
// in case there are no cookies at all. Also prevents odd result when
|
82 |
+
// calling $.cookie().
|
83 |
+
var cookies = document.cookie ? document.cookie.split('; ') : [];
|
84 |
+
|
85 |
+
for (var i = 0, l = cookies.length; i < l; i++) {
|
86 |
+
var parts = cookies[i].split('=');
|
87 |
+
var name = decode(parts.shift());
|
88 |
+
var cookie = parts.join('=');
|
89 |
+
|
90 |
+
if (key && key === name) {
|
91 |
+
// If second argument (value) is a function it's a converter...
|
92 |
+
result = read(cookie, value);
|
93 |
+
break;
|
94 |
+
}
|
95 |
+
|
96 |
+
// Prevent storing a cookie that we couldn't decode.
|
97 |
+
if (!key && (cookie = read(cookie)) !== undefined) {
|
98 |
+
result[name] = cookie;
|
99 |
+
}
|
100 |
+
}
|
101 |
+
|
102 |
+
return result;
|
103 |
+
};
|
104 |
+
|
105 |
+
config.defaults = {};
|
106 |
+
|
107 |
+
$.removeCookie = function (key, options) {
|
108 |
+
if ($.cookie(key) === undefined) {
|
109 |
+
return false;
|
110 |
+
}
|
111 |
+
|
112 |
+
// Must not alter options, thus extending a fresh object...
|
113 |
+
$.cookie(key, '', $.extend({}, options, { expires: -1 }));
|
114 |
+
return !$.cookie(key);
|
115 |
+
};
|
116 |
+
|
117 |
+
}));
|
inc/js/js_highlight.js
CHANGED
@@ -1,2 +1,2 @@
|
|
1 |
-
/*! highlight.js v9.2.0 | BSD3 License | git.io/hljslicense */
|
2 |
!function(e){var n="object"==typeof window&&window||"object"==typeof self&&self;"undefined"!=typeof exports?e(exports):n&&(n.hljs=e({}),"function"==typeof define&&define.amd&&define([],function(){return n.hljs}))}(function(e){function n(e){return e.replace(/&/gm,"&").replace(/</gm,"<").replace(/>/gm,">")}function t(e){return e.nodeName.toLowerCase()}function r(e,n){var t=e&&e.exec(n);return t&&0==t.index}function a(e){return/^(no-?highlight|plain|text)$/i.test(e)}function i(e){var n,t,r,i=e.className+" ";if(i+=e.parentNode?e.parentNode.className:"",t=/\blang(?:uage)?-([\w-]+)\b/i.exec(i))return w(t[1])?t[1]:"no-highlight";for(i=i.split(/\s+/),n=0,r=i.length;r>n;n++)if(w(i[n])||a(i[n]))return i[n]}function o(e,n){var t,r={};for(t in e)r[t]=e[t];if(n)for(t in n)r[t]=n[t];return r}function u(e){var n=[];return function r(e,a){for(var i=e.firstChild;i;i=i.nextSibling)3==i.nodeType?a+=i.nodeValue.length:1==i.nodeType&&(n.push({event:"start",offset:a,node:i}),a=r(i,a),t(i).match(/br|hr|img|input/)||n.push({event:"stop",offset:a,node:i}));return a}(e,0),n}function c(e,r,a){function i(){return e.length&&r.length?e[0].offset!=r[0].offset?e[0].offset<r[0].offset?e:r:"start"==r[0].event?e:r:e.length?e:r}function o(e){function r(e){return" "+e.nodeName+'="'+n(e.value)+'"'}f+="<"+t(e)+Array.prototype.map.call(e.attributes,r).join("")+">"}function u(e){f+="</"+t(e)+">"}function c(e){("start"==e.event?o:u)(e.node)}for(var s=0,f="",l=[];e.length||r.length;){var g=i();if(f+=n(a.substr(s,g[0].offset-s)),s=g[0].offset,g==e){l.reverse().forEach(u);do c(g.splice(0,1)[0]),g=i();while(g==e&&g.length&&g[0].offset==s);l.reverse().forEach(o)}else"start"==g[0].event?l.push(g[0].node):l.pop(),c(g.splice(0,1)[0])}return f+n(a.substr(s))}function s(e){function n(e){return e&&e.source||e}function t(t,r){return new RegExp(n(t),"m"+(e.cI?"i":"")+(r?"g":""))}function r(a,i){if(!a.compiled){if(a.compiled=!0,a.k=a.k||a.bK,a.k){var u={},c=function(n,t){e.cI&&(t=t.toLowerCase()),t.split(" ").forEach(function(e){var t=e.split("|");u[t[0]]=[n,t[1]?Number(t[1]):1]})};"string"==typeof a.k?c("keyword",a.k):Object.keys(a.k).forEach(function(e){c(e,a.k[e])}),a.k=u}a.lR=t(a.l||/\b\w+\b/,!0),i&&(a.bK&&(a.b="\\b("+a.bK.split(" ").join("|")+")\\b"),a.b||(a.b=/\B|\b/),a.bR=t(a.b),a.e||a.eW||(a.e=/\B|\b/),a.e&&(a.eR=t(a.e)),a.tE=n(a.e)||"",a.eW&&i.tE&&(a.tE+=(a.e?"|":"")+i.tE)),a.i&&(a.iR=t(a.i)),void 0===a.r&&(a.r=1),a.c||(a.c=[]);var s=[];a.c.forEach(function(e){e.v?e.v.forEach(function(n){s.push(o(e,n))}):s.push("self"==e?a:e)}),a.c=s,a.c.forEach(function(e){r(e,a)}),a.starts&&r(a.starts,i);var f=a.c.map(function(e){return e.bK?"\\.?("+e.b+")\\.?":e.b}).concat([a.tE,a.i]).map(n).filter(Boolean);a.t=f.length?t(f.join("|"),!0):{exec:function(){return null}}}}r(e)}function f(e,t,a,i){function o(e,n){for(var t=0;t<n.c.length;t++)if(r(n.c[t].bR,e))return n.c[t]}function u(e,n){if(r(e.eR,n)){for(;e.endsParent&&e.parent;)e=e.parent;return e}return e.eW?u(e.parent,n):void 0}function c(e,n){return!a&&r(n.iR,e)}function g(e,n){var t=N.cI?n[0].toLowerCase():n[0];return e.k.hasOwnProperty(t)&&e.k[t]}function p(e,n,t,r){var a=r?"":E.classPrefix,i='<span class="'+a,o=t?"":"</span>";return i+=e+'">',i+n+o}function h(){if(!k.k)return n(M);var e="",t=0;k.lR.lastIndex=0;for(var r=k.lR.exec(M);r;){e+=n(M.substr(t,r.index-t));var a=g(k,r);a?(B+=a[1],e+=p(a[0],n(r[0]))):e+=n(r[0]),t=k.lR.lastIndex,r=k.lR.exec(M)}return e+n(M.substr(t))}function d(){var e="string"==typeof k.sL;if(e&&!R[k.sL])return n(M);var t=e?f(k.sL,M,!0,y[k.sL]):l(M,k.sL.length?k.sL:void 0);return k.r>0&&(B+=t.r),e&&(y[k.sL]=t.top),p(t.language,t.value,!1,!0)}function b(){L+=void 0!==k.sL?d():h(),M=""}function v(e,n){L+=e.cN?p(e.cN,"",!0):"",k=Object.create(e,{parent:{value:k}})}function m(e,n){if(M+=e,void 0===n)return b(),0;var t=o(n,k);if(t)return t.skip?M+=n:(t.eB&&(M+=n),b(),t.rB||t.eB||(M=n)),v(t,n),t.rB?0:n.length;var r=u(k,n);if(r){var a=k;a.skip?M+=n:(a.rE||a.eE||(M+=n),b(),a.eE&&(M=n));do k.cN&&(L+="</span>"),k.skip||(B+=k.r),k=k.parent;while(k!=r.parent);return r.starts&&v(r.starts,""),a.rE?0:n.length}if(c(n,k))throw new Error('Illegal lexeme "'+n+'" for mode "'+(k.cN||"<unnamed>")+'"');return M+=n,n.length||1}var N=w(e);if(!N)throw new Error('Unknown language: "'+e+'"');s(N);var x,k=i||N,y={},L="";for(x=k;x!=N;x=x.parent)x.cN&&(L=p(x.cN,"",!0)+L);var M="",B=0;try{for(var C,j,I=0;;){if(k.t.lastIndex=I,C=k.t.exec(t),!C)break;j=m(t.substr(I,C.index-I),C[0]),I=C.index+j}for(m(t.substr(I)),x=k;x.parent;x=x.parent)x.cN&&(L+="</span>");return{r:B,value:L,language:e,top:k}}catch(O){if(-1!=O.message.indexOf("Illegal"))return{r:0,value:n(t)};throw O}}function l(e,t){t=t||E.languages||Object.keys(R);var r={r:0,value:n(e)},a=r;return t.forEach(function(n){if(w(n)){var t=f(n,e,!1);t.language=n,t.r>a.r&&(a=t),t.r>r.r&&(a=r,r=t)}}),a.language&&(r.second_best=a),r}function g(e){return E.tabReplace&&(e=e.replace(/^((<[^>]+>|\t)+)/gm,function(e,n){return n.replace(/\t/g,E.tabReplace)})),E.useBR&&(e=e.replace(/\n/g,"<br>")),e}function p(e,n,t){var r=n?x[n]:t,a=[e.trim()];return e.match(/\bhljs\b/)||a.push("hljs"),-1===e.indexOf(r)&&a.push(r),a.join(" ").trim()}function h(e){var n=i(e);if(!a(n)){var t;E.useBR?(t=document.createElementNS("http://www.w3.org/1999/xhtml","div"),t.innerHTML=e.innerHTML.replace(/\n/g,"").replace(/<br[ \/]*>/g,"\n")):t=e;var r=t.textContent,o=n?f(n,r,!0):l(r),s=u(t);if(s.length){var h=document.createElementNS("http://www.w3.org/1999/xhtml","div");h.innerHTML=o.value,o.value=c(s,u(h),r)}o.value=g(o.value),e.innerHTML=o.value,e.className=p(e.className,n,o.language),e.result={language:o.language,re:o.r},o.second_best&&(e.second_best={language:o.second_best.language,re:o.second_best.r})}}function d(e){E=o(E,e)}function b(){if(!b.called){b.called=!0;var e=document.querySelectorAll("pre code");Array.prototype.forEach.call(e,h)}}function v(){addEventListener("DOMContentLoaded",b,!1),addEventListener("load",b,!1)}function m(n,t){var r=R[n]=t(e);r.aliases&&r.aliases.forEach(function(e){x[e]=n})}function N(){return Object.keys(R)}function w(e){return e=(e||"").toLowerCase(),R[e]||R[x[e]]}var E={classPrefix:"hljs-",tabReplace:null,useBR:!1,languages:void 0},R={},x={};return e.highlight=f,e.highlightAuto=l,e.fixMarkup=g,e.highlightBlock=h,e.configure=d,e.initHighlighting=b,e.initHighlightingOnLoad=v,e.registerLanguage=m,e.listLanguages=N,e.getLanguage=w,e.inherit=o,e.IR="[a-zA-Z]\\w*",e.UIR="[a-zA-Z_]\\w*",e.NR="\\b\\d+(\\.\\d+)?",e.CNR="(-?)(\\b0[xX][a-fA-F0-9]+|(\\b\\d+(\\.\\d*)?|\\.\\d+)([eE][-+]?\\d+)?)",e.BNR="\\b(0b[01]+)",e.RSR="!|!=|!==|%|%=|&|&&|&=|\\*|\\*=|\\+|\\+=|,|-|-=|/=|/|:|;|<<|<<=|<=|<|===|==|=|>>>=|>>=|>=|>>>|>>|>|\\?|\\[|\\{|\\(|\\^|\\^=|\\||\\|=|\\|\\||~",e.BE={b:"\\\\[\\s\\S]",r:0},e.ASM={cN:"string",b:"'",e:"'",i:"\\n",c:[e.BE]},e.QSM={cN:"string",b:'"',e:'"',i:"\\n",c:[e.BE]},e.PWM={b:/\b(a|an|the|are|I|I'm|isn't|don't|doesn't|won't|but|just|should|pretty|simply|enough|gonna|going|wtf|so|such|will|you|your|like)\b/},e.C=function(n,t,r){var a=e.inherit({cN:"comment",b:n,e:t,c:[]},r||{});return a.c.push(e.PWM),a.c.push({cN:"doctag",b:"(?:TODO|FIXME|NOTE|BUG|XXX):",r:0}),a},e.CLCM=e.C("//","$"),e.CBCM=e.C("/\\*","\\*/"),e.HCM=e.C("#","$"),e.NM={cN:"number",b:e.NR,r:0},e.CNM={cN:"number",b:e.CNR,r:0},e.BNM={cN:"number",b:e.BNR,r:0},e.CSSNM={cN:"number",b:e.NR+"(%|em|ex|ch|rem|vw|vh|vmin|vmax|cm|mm|in|pt|pc|px|deg|grad|rad|turn|s|ms|Hz|kHz|dpi|dpcm|dppx)?",r:0},e.RM={cN:"regexp",b:/\//,e:/\/[gimuy]*/,i:/\n/,c:[e.BE,{b:/\[/,e:/\]/,r:0,c:[e.BE]}]},e.TM={cN:"title",b:e.IR,r:0},e.UTM={cN:"title",b:e.UIR,r:0},e.METHOD_GUARD={b:"\\.\\s*"+e.UIR,r:0},e});hljs.registerLanguage("javascript",function(e){return{aliases:["js","jsx"],k:{keyword:"in of if for while finally var new function do return void else break catch instanceof with throw case default try this switch continue typeof delete let yield const export super debugger as async await static import from as",literal:"true false null undefined NaN Infinity",built_in:"eval isFinite isNaN parseFloat parseInt decodeURI decodeURIComponent encodeURI encodeURIComponent escape unescape Object Function Boolean Error EvalError InternalError RangeError ReferenceError StopIteration SyntaxError TypeError URIError Number Math Date String RegExp Array Float32Array Float64Array Int16Array Int32Array Int8Array Uint16Array Uint32Array Uint8Array Uint8ClampedArray ArrayBuffer DataView JSON Intl arguments require module console window document Symbol Set Map WeakSet WeakMap Proxy Reflect Promise"},c:[{cN:"meta",r:10,b:/^\s*['"]use (strict|asm)['"]/},{cN:"meta",b:/^#!/,e:/$/},e.ASM,e.QSM,{cN:"string",b:"`",e:"`",c:[e.BE,{cN:"subst",b:"\\$\\{",e:"\\}"}]},e.CLCM,e.CBCM,{cN:"number",v:[{b:"\\b(0[bB][01]+)"},{b:"\\b(0[oO][0-7]+)"},{b:e.CNR}],r:0},{b:"("+e.RSR+"|\\b(case|return|throw)\\b)\\s*",k:"return throw case",c:[e.CLCM,e.CBCM,e.RM,{b:/</,e:/(\/\w+|\w+\/)>/,sL:"xml",c:[{b:/<\w+\/>/,skip:!0},{b:/<\w+/,e:/(\/\w+|\w+\/)>/,skip:!0,c:["self"]}]}],r:0},{cN:"function",bK:"function",e:/\{/,eE:!0,c:[e.inherit(e.TM,{b:/[A-Za-z$_][0-9A-Za-z$_]*/}),{cN:"params",b:/\(/,e:/\)/,eB:!0,eE:!0,c:[e.CLCM,e.CBCM]}],i:/\[|%/},{b:/\$[(.]/},e.METHOD_GUARD,{cN:"class",bK:"class",e:/[{;=]/,eE:!0,i:/[:"\[\]]/,c:[{bK:"extends"},e.UTM]},{bK:"constructor",e:/\{/,eE:!0}],i:/#(?!!)/}});hljs.registerLanguage("json",function(e){var i={literal:"true false null"},n=[e.QSM,e.CNM],r={e:",",eW:!0,eE:!0,c:n,k:i},t={b:"{",e:"}",c:[{cN:"attr",b:/"/,e:/"/,c:[e.BE],i:"\\n"},e.inherit(r,{b:/:/})],i:"\\S"},c={b:"\\[",e:"\\]",c:[e.inherit(r)],i:"\\S"};return n.splice(n.length,0,t,c),{c:n,k:i,i:"\\S"}});
|
1 |
+
/*! highlight.js v9.2.0 | BSD3 License | git.io/hljslicense */
|
2 |
!function(e){var n="object"==typeof window&&window||"object"==typeof self&&self;"undefined"!=typeof exports?e(exports):n&&(n.hljs=e({}),"function"==typeof define&&define.amd&&define([],function(){return n.hljs}))}(function(e){function n(e){return e.replace(/&/gm,"&").replace(/</gm,"<").replace(/>/gm,">")}function t(e){return e.nodeName.toLowerCase()}function r(e,n){var t=e&&e.exec(n);return t&&0==t.index}function a(e){return/^(no-?highlight|plain|text)$/i.test(e)}function i(e){var n,t,r,i=e.className+" ";if(i+=e.parentNode?e.parentNode.className:"",t=/\blang(?:uage)?-([\w-]+)\b/i.exec(i))return w(t[1])?t[1]:"no-highlight";for(i=i.split(/\s+/),n=0,r=i.length;r>n;n++)if(w(i[n])||a(i[n]))return i[n]}function o(e,n){var t,r={};for(t in e)r[t]=e[t];if(n)for(t in n)r[t]=n[t];return r}function u(e){var n=[];return function r(e,a){for(var i=e.firstChild;i;i=i.nextSibling)3==i.nodeType?a+=i.nodeValue.length:1==i.nodeType&&(n.push({event:"start",offset:a,node:i}),a=r(i,a),t(i).match(/br|hr|img|input/)||n.push({event:"stop",offset:a,node:i}));return a}(e,0),n}function c(e,r,a){function i(){return e.length&&r.length?e[0].offset!=r[0].offset?e[0].offset<r[0].offset?e:r:"start"==r[0].event?e:r:e.length?e:r}function o(e){function r(e){return" "+e.nodeName+'="'+n(e.value)+'"'}f+="<"+t(e)+Array.prototype.map.call(e.attributes,r).join("")+">"}function u(e){f+="</"+t(e)+">"}function c(e){("start"==e.event?o:u)(e.node)}for(var s=0,f="",l=[];e.length||r.length;){var g=i();if(f+=n(a.substr(s,g[0].offset-s)),s=g[0].offset,g==e){l.reverse().forEach(u);do c(g.splice(0,1)[0]),g=i();while(g==e&&g.length&&g[0].offset==s);l.reverse().forEach(o)}else"start"==g[0].event?l.push(g[0].node):l.pop(),c(g.splice(0,1)[0])}return f+n(a.substr(s))}function s(e){function n(e){return e&&e.source||e}function t(t,r){return new RegExp(n(t),"m"+(e.cI?"i":"")+(r?"g":""))}function r(a,i){if(!a.compiled){if(a.compiled=!0,a.k=a.k||a.bK,a.k){var u={},c=function(n,t){e.cI&&(t=t.toLowerCase()),t.split(" ").forEach(function(e){var t=e.split("|");u[t[0]]=[n,t[1]?Number(t[1]):1]})};"string"==typeof a.k?c("keyword",a.k):Object.keys(a.k).forEach(function(e){c(e,a.k[e])}),a.k=u}a.lR=t(a.l||/\b\w+\b/,!0),i&&(a.bK&&(a.b="\\b("+a.bK.split(" ").join("|")+")\\b"),a.b||(a.b=/\B|\b/),a.bR=t(a.b),a.e||a.eW||(a.e=/\B|\b/),a.e&&(a.eR=t(a.e)),a.tE=n(a.e)||"",a.eW&&i.tE&&(a.tE+=(a.e?"|":"")+i.tE)),a.i&&(a.iR=t(a.i)),void 0===a.r&&(a.r=1),a.c||(a.c=[]);var s=[];a.c.forEach(function(e){e.v?e.v.forEach(function(n){s.push(o(e,n))}):s.push("self"==e?a:e)}),a.c=s,a.c.forEach(function(e){r(e,a)}),a.starts&&r(a.starts,i);var f=a.c.map(function(e){return e.bK?"\\.?("+e.b+")\\.?":e.b}).concat([a.tE,a.i]).map(n).filter(Boolean);a.t=f.length?t(f.join("|"),!0):{exec:function(){return null}}}}r(e)}function f(e,t,a,i){function o(e,n){for(var t=0;t<n.c.length;t++)if(r(n.c[t].bR,e))return n.c[t]}function u(e,n){if(r(e.eR,n)){for(;e.endsParent&&e.parent;)e=e.parent;return e}return e.eW?u(e.parent,n):void 0}function c(e,n){return!a&&r(n.iR,e)}function g(e,n){var t=N.cI?n[0].toLowerCase():n[0];return e.k.hasOwnProperty(t)&&e.k[t]}function p(e,n,t,r){var a=r?"":E.classPrefix,i='<span class="'+a,o=t?"":"</span>";return i+=e+'">',i+n+o}function h(){if(!k.k)return n(M);var e="",t=0;k.lR.lastIndex=0;for(var r=k.lR.exec(M);r;){e+=n(M.substr(t,r.index-t));var a=g(k,r);a?(B+=a[1],e+=p(a[0],n(r[0]))):e+=n(r[0]),t=k.lR.lastIndex,r=k.lR.exec(M)}return e+n(M.substr(t))}function d(){var e="string"==typeof k.sL;if(e&&!R[k.sL])return n(M);var t=e?f(k.sL,M,!0,y[k.sL]):l(M,k.sL.length?k.sL:void 0);return k.r>0&&(B+=t.r),e&&(y[k.sL]=t.top),p(t.language,t.value,!1,!0)}function b(){L+=void 0!==k.sL?d():h(),M=""}function v(e,n){L+=e.cN?p(e.cN,"",!0):"",k=Object.create(e,{parent:{value:k}})}function m(e,n){if(M+=e,void 0===n)return b(),0;var t=o(n,k);if(t)return t.skip?M+=n:(t.eB&&(M+=n),b(),t.rB||t.eB||(M=n)),v(t,n),t.rB?0:n.length;var r=u(k,n);if(r){var a=k;a.skip?M+=n:(a.rE||a.eE||(M+=n),b(),a.eE&&(M=n));do k.cN&&(L+="</span>"),k.skip||(B+=k.r),k=k.parent;while(k!=r.parent);return r.starts&&v(r.starts,""),a.rE?0:n.length}if(c(n,k))throw new Error('Illegal lexeme "'+n+'" for mode "'+(k.cN||"<unnamed>")+'"');return M+=n,n.length||1}var N=w(e);if(!N)throw new Error('Unknown language: "'+e+'"');s(N);var x,k=i||N,y={},L="";for(x=k;x!=N;x=x.parent)x.cN&&(L=p(x.cN,"",!0)+L);var M="",B=0;try{for(var C,j,I=0;;){if(k.t.lastIndex=I,C=k.t.exec(t),!C)break;j=m(t.substr(I,C.index-I),C[0]),I=C.index+j}for(m(t.substr(I)),x=k;x.parent;x=x.parent)x.cN&&(L+="</span>");return{r:B,value:L,language:e,top:k}}catch(O){if(-1!=O.message.indexOf("Illegal"))return{r:0,value:n(t)};throw O}}function l(e,t){t=t||E.languages||Object.keys(R);var r={r:0,value:n(e)},a=r;return t.forEach(function(n){if(w(n)){var t=f(n,e,!1);t.language=n,t.r>a.r&&(a=t),t.r>r.r&&(a=r,r=t)}}),a.language&&(r.second_best=a),r}function g(e){return E.tabReplace&&(e=e.replace(/^((<[^>]+>|\t)+)/gm,function(e,n){return n.replace(/\t/g,E.tabReplace)})),E.useBR&&(e=e.replace(/\n/g,"<br>")),e}function p(e,n,t){var r=n?x[n]:t,a=[e.trim()];return e.match(/\bhljs\b/)||a.push("hljs"),-1===e.indexOf(r)&&a.push(r),a.join(" ").trim()}function h(e){var n=i(e);if(!a(n)){var t;E.useBR?(t=document.createElementNS("http://www.w3.org/1999/xhtml","div"),t.innerHTML=e.innerHTML.replace(/\n/g,"").replace(/<br[ \/]*>/g,"\n")):t=e;var r=t.textContent,o=n?f(n,r,!0):l(r),s=u(t);if(s.length){var h=document.createElementNS("http://www.w3.org/1999/xhtml","div");h.innerHTML=o.value,o.value=c(s,u(h),r)}o.value=g(o.value),e.innerHTML=o.value,e.className=p(e.className,n,o.language),e.result={language:o.language,re:o.r},o.second_best&&(e.second_best={language:o.second_best.language,re:o.second_best.r})}}function d(e){E=o(E,e)}function b(){if(!b.called){b.called=!0;var e=document.querySelectorAll("pre code");Array.prototype.forEach.call(e,h)}}function v(){addEventListener("DOMContentLoaded",b,!1),addEventListener("load",b,!1)}function m(n,t){var r=R[n]=t(e);r.aliases&&r.aliases.forEach(function(e){x[e]=n})}function N(){return Object.keys(R)}function w(e){return e=(e||"").toLowerCase(),R[e]||R[x[e]]}var E={classPrefix:"hljs-",tabReplace:null,useBR:!1,languages:void 0},R={},x={};return e.highlight=f,e.highlightAuto=l,e.fixMarkup=g,e.highlightBlock=h,e.configure=d,e.initHighlighting=b,e.initHighlightingOnLoad=v,e.registerLanguage=m,e.listLanguages=N,e.getLanguage=w,e.inherit=o,e.IR="[a-zA-Z]\\w*",e.UIR="[a-zA-Z_]\\w*",e.NR="\\b\\d+(\\.\\d+)?",e.CNR="(-?)(\\b0[xX][a-fA-F0-9]+|(\\b\\d+(\\.\\d*)?|\\.\\d+)([eE][-+]?\\d+)?)",e.BNR="\\b(0b[01]+)",e.RSR="!|!=|!==|%|%=|&|&&|&=|\\*|\\*=|\\+|\\+=|,|-|-=|/=|/|:|;|<<|<<=|<=|<|===|==|=|>>>=|>>=|>=|>>>|>>|>|\\?|\\[|\\{|\\(|\\^|\\^=|\\||\\|=|\\|\\||~",e.BE={b:"\\\\[\\s\\S]",r:0},e.ASM={cN:"string",b:"'",e:"'",i:"\\n",c:[e.BE]},e.QSM={cN:"string",b:'"',e:'"',i:"\\n",c:[e.BE]},e.PWM={b:/\b(a|an|the|are|I|I'm|isn't|don't|doesn't|won't|but|just|should|pretty|simply|enough|gonna|going|wtf|so|such|will|you|your|like)\b/},e.C=function(n,t,r){var a=e.inherit({cN:"comment",b:n,e:t,c:[]},r||{});return a.c.push(e.PWM),a.c.push({cN:"doctag",b:"(?:TODO|FIXME|NOTE|BUG|XXX):",r:0}),a},e.CLCM=e.C("//","$"),e.CBCM=e.C("/\\*","\\*/"),e.HCM=e.C("#","$"),e.NM={cN:"number",b:e.NR,r:0},e.CNM={cN:"number",b:e.CNR,r:0},e.BNM={cN:"number",b:e.BNR,r:0},e.CSSNM={cN:"number",b:e.NR+"(%|em|ex|ch|rem|vw|vh|vmin|vmax|cm|mm|in|pt|pc|px|deg|grad|rad|turn|s|ms|Hz|kHz|dpi|dpcm|dppx)?",r:0},e.RM={cN:"regexp",b:/\//,e:/\/[gimuy]*/,i:/\n/,c:[e.BE,{b:/\[/,e:/\]/,r:0,c:[e.BE]}]},e.TM={cN:"title",b:e.IR,r:0},e.UTM={cN:"title",b:e.UIR,r:0},e.METHOD_GUARD={b:"\\.\\s*"+e.UIR,r:0},e});hljs.registerLanguage("javascript",function(e){return{aliases:["js","jsx"],k:{keyword:"in of if for while finally var new function do return void else break catch instanceof with throw case default try this switch continue typeof delete let yield const export super debugger as async await static import from as",literal:"true false null undefined NaN Infinity",built_in:"eval isFinite isNaN parseFloat parseInt decodeURI decodeURIComponent encodeURI encodeURIComponent escape unescape Object Function Boolean Error EvalError InternalError RangeError ReferenceError StopIteration SyntaxError TypeError URIError Number Math Date String RegExp Array Float32Array Float64Array Int16Array Int32Array Int8Array Uint16Array Uint32Array Uint8Array Uint8ClampedArray ArrayBuffer DataView JSON Intl arguments require module console window document Symbol Set Map WeakSet WeakMap Proxy Reflect Promise"},c:[{cN:"meta",r:10,b:/^\s*['"]use (strict|asm)['"]/},{cN:"meta",b:/^#!/,e:/$/},e.ASM,e.QSM,{cN:"string",b:"`",e:"`",c:[e.BE,{cN:"subst",b:"\\$\\{",e:"\\}"}]},e.CLCM,e.CBCM,{cN:"number",v:[{b:"\\b(0[bB][01]+)"},{b:"\\b(0[oO][0-7]+)"},{b:e.CNR}],r:0},{b:"("+e.RSR+"|\\b(case|return|throw)\\b)\\s*",k:"return throw case",c:[e.CLCM,e.CBCM,e.RM,{b:/</,e:/(\/\w+|\w+\/)>/,sL:"xml",c:[{b:/<\w+\/>/,skip:!0},{b:/<\w+/,e:/(\/\w+|\w+\/)>/,skip:!0,c:["self"]}]}],r:0},{cN:"function",bK:"function",e:/\{/,eE:!0,c:[e.inherit(e.TM,{b:/[A-Za-z$_][0-9A-Za-z$_]*/}),{cN:"params",b:/\(/,e:/\)/,eB:!0,eE:!0,c:[e.CLCM,e.CBCM]}],i:/\[|%/},{b:/\$[(.]/},e.METHOD_GUARD,{cN:"class",bK:"class",e:/[{;=]/,eE:!0,i:/[:"\[\]]/,c:[{bK:"extends"},e.UTM]},{bK:"constructor",e:/\{/,eE:!0}],i:/#(?!!)/}});hljs.registerLanguage("json",function(e){var i={literal:"true false null"},n=[e.QSM,e.CNM],r={e:",",eW:!0,eE:!0,c:n,k:i},t={b:"{",e:"}",c:[{cN:"attr",b:/"/,e:/"/,c:[e.BE],i:"\\n"},e.inherit(r,{b:/:/})],i:"\\S"},c={b:"\\[",e:"\\]",c:[e.inherit(r)],i:"\\S"};return n.splice(n.length,0,t,c),{c:n,k:i,i:"\\S"}});
|
inc/js/loader.js
CHANGED
@@ -1,147 +1,147 @@
|
|
1 |
-
(function (){ var b="",aa="\x00",ba="\n",ca="\n//# sourceURL=",da="\n;return exports});\n//# sourceURL=",k=" ",ea="  ",fa=" onreadystatechange='goog.onScriptLoad_(this, ",ga=" should not be enumerable in Object.prototype.",l='"',ha='");',ia='">\x3c/script>',ja="#",ka="$1",la="%s",q="&",ma="�",na="e",oa="'",pa="&",qa=">",ra="<",sa=""",ta="'",ua="(^",va=")' ",wa=")([a-z])",xa=");",ya=", ",za="-",Aa="-$1",r=".",Ba="..",Ca="...",u="/",Da="/loader.js",v="0",Ea="0,(function(){",w=": ",
|
2 |
-
x="<",Fa="\x3c/script>",Ga="<br />",Ha="<br>",Ia='<script type="text/javascript" src="',Ja='<script type="text/javascript">',Ka=">",La=">\x3c/script>",Ma="?",Na="Already loaded ",Pa="American Samoa",Qa="Antigua and Barbuda",Ra="Assertion failed",Sa="BY_WHOLE",y="Bolivia",z="Bosna i Hercegovina",Ta="Botswana",Ua="British Virgin Islands",Va="Cayman Islands",Wa="Christmas Island",Xa="Expected Element but got %s: %s.",Ya="Expected array but got %s: %s.",Za="Expected boolean but got %s: %s.",$a="Expected function but got %s: %s.",
|
3 |
-
ab="Expected instanceof %s but got %s.",bb="Expected number but got %s: %s.",cb="Expected object but got %s: %s.",db="Expected string but got %s: %s.",eb="Failure",fb="Falkland Islands",B="Ghana",gb="Guin\u00e9e \u00e9quatoriale",hb="Guyane fran\u00e7aise",ib="HEAD",jb="Honduras",kb="Indonesia",lb="Itoophiyaa",mb="JavaScript",nb="Kalaallit Nunaat",ob="Kiribati",pb="Load packages + dependencies - previous: ",qb="Loading css files: ",rb="LocaleNameConstants",sb="Luxembourg",tb="Madagascar",ub="Marshall Islands",
|
4 |
-
C="Micronesia",vb="Moldova, Republica",wb="Nederlandse Antillen",xb="New Zealand",D="Nigeria",yb="Norfolk Island",zb="Northern Mariana Islands",Ab="Nouvelle-Cal\u00e9donie",E="Papua New Guinea",Bb="Paraguay",Cb="Philippines",Db="Polyn\u00e9sie fran\u00e7aise",Eb="Puerto Rico",Fb="Rep\u00fablica Dominicana",F="Rwanda",Gb="Rywvaneth Unys",Hb="R\u00e9publique centrafricaine",Ib="R\u00e9publique d\u00e9mocratique du Congo",Jb="SCRIPT",Kb="Saint Kitts and Nevis",Lb="Saint Vincent and the Grenadines",Mb=
|
5 |
-
"Saint-Pierre-et-Miquelon",Nb="Serbia and Montenegro",Ob="Seychelles",Pb="Slovensk\u00e1 republika",Qb="Solomon Islands",G="South Africa",Rb="Svalbard og Jan Mayen",Ub="Swaziland",Vb="S\u00e3o Tom\u00e9 e Pr\u00edncipe",H="S\u00e9n\u00e9gal",Wb="Tanzania",Xb="Timor Leste",I="Tokelau",Yb="Turks and Caicos Islands",J="Tuvalu",K="T\u00fcrkiye",Zb="U.S. Virgin Islands",$b="United Kingdom",ac="United States",bc="United States Minor Outlying Islands",cc="Unknown or Invalid Region",L="Vanuatu",dc="Wallis-et-Futuna",
|
6 |
-
ec="[object Array]",fc="[object Function]",gc="[object Window]",hc="\\$1",ic="\\s",jc="\\u",kc="\\x",lc="\\x08",mc="]+",M="_",nc="amp",oc="annotatedtimeline",N="array",pc="base.js",qc="boolean",O="browserchart",rc="call",sc="callback after loading ",tc="charts",P="complete",uc="corechart",vc="div",wc="document",Q="dygraph",xc="e",yc="en",zc="end loadScript: ",Ac="error",R="function",Bc="g",Cc="get",Dc="goog",Ec="goog.loadModule(",Fc='goog.loadModule(function(exports) {"use strict";',Gc='goog.retrieveAndExecModule_("',
|
7 |
-
Hc="goog_",Ic="google",Jc="google.charts.load",Kc="google.charts.load version ",Lc="gt",Mc="head",Nc="href",Oc="id",Pc="iframe",S="imagechart",Qc="javascript",Rc="link",Sc="load",Tc="load-css-",Uc="loadCSSFile: ",Vc="loadScript: ",Wc="loading css failed: ",Xc="lt",Yc="native code",Zc="none",$c="null",ad="number",bd="o",T="object",cd="onload",dd="quot",ed="rel",fd="removeAttribute",gd="script",hd="splice",id="string",jd="stylesheet",kd="text/css",ld="text/javascript",U="top",md="type",V="ui",nd="ui_base",
|
8 |
-
od="unknown",pd="unknown type name",qd="var ",rd="var _evalTest_ = 1;",sd="visualization",td="webfontloader",ud="write",vd="{cssFile}",wd="{language}",xd="{package}",yd="{prefix}",zd="{prefix}/{version}/css/{cssFile}",Ad="{prefix}/{version}/third_party/{package}",Bd="{version}",Cd="|[",Dd="})",Ed="~",Fd="\u0080",Gd="\u010cesk\u00e1 republika",Hd="\u0411\u0435\u043b\u0430\u0440\u0443\u0441\u044c",Id="\u041a\u044b\u0440\u0433\u044b\u0437\u0441\u0442\u0430\u043d",Jd="\u043c\u043e\u043d\u0433\u043e\u043b\u044c\u0441\u043a\u0438\u0439",
|
9 |
-
Kd="\u0540\u0561\u0575\u0561\u057d\u057f\u0561\u0576\u056b \u0540\u0561\u0576\u0580\u0561\u057a\u0565\u057f\u0578\u0582\u0569\u056b\u0582\u0576",Ld="\u0627\u0641\u063a\u0627\u0646\u0633\u062a\u0627\u0646",Md="\u0627\u0644\u0627\u0645\u0627\u0631\u0627\u062a \u0627\u0644\u0639\u0631\u0628\u064a\u0629 \u0627\u0644\u0645\u062a\u062d\u062f\u0629",Nd="\u0627\u0644\u0635\u062d\u0631\u0627\u0621 \u0627\u0644\u063a\u0631\u0628\u064a\u0629",Od="\u0627\u0644\u0645\u0645\u0644\u0643\u0629 \u0627\u0644\u0639\u0631\u0628\u064a\u0629 \u0627\u0644\u0633\u0639\u0648\u062f\u064a\u0629",
|
10 |
-
Pd="\u0627\u0644\u0648\u0644\u0627\u064a\u0627\u062a \u0627\u0644\u0645\u062a\u062d\u062f\u0629 \u0627\u0644\u0623\u0645\u0631\u064a\u0643\u064a\u0629",Qd="\u062c\u0632\u0631 \u0627\u0644\u0642\u0645\u0631",Rd="\u067e\u0627\u06a9\u0633\u062a\u0627\u0646",W="\u092d\u093e\u0930\u0924",X="\u12a2\u1275\u12ee\u1335\u12eb",Sd="\uc870\uc120 \ubbfc\uc8fc\uc8fc\uc758 \uc778\ubbfc \uacf5\ud654\uad6d",Td="\ufffd";function Y(){return function(){}}var Z=Z||{};Z.global=this;Z.P=function(a){return void 0!==a};
|
11 |
-
Z.Aa=function(a,c,d){a=a.split(r);d=d||Z.global;a[0]in d||!d.execScript||d.execScript(qd+a[0]);for(var e;a.length&&(e=a.shift());)!a.length&&Z.P(c)?d[e]=c:d=d[e]?d[e]:d[e]={}};Z.ue=function(a,c){Z.Aa(a,c)};Z.H=!0;Z.Cd=yc;Z.ra=!0;Z.ec=!1;Z.Ob=!Z.H;Z.Ya=!1;Z.Gf=function(a){if(Z.La())throw Error("goog.provide can not be used within a goog.module.");Z.fb(a)};Z.fb=function(a,c){Z.Aa(a,c)};Z.mc=/^[a-zA-Z_$][a-zA-Z0-9._$]*$/;
|
12 |
-
Z.Oa=function(a){if(!Z.h(a)||!a||-1==a.search(Z.mc))throw Error("Invalid module identifier");if(!Z.La())throw Error("Module "+a+" has been loaded incorrectly.");if(Z.j.Pa)throw Error("goog.module may only be called once per module.");Z.j.Pa=a};Z.Oa.get=Y();Z.Oa.Ge=Y();Z.j=null;Z.La=function(){return null!=Z.j};Z.Oa.xa=function(){Z.j.xa=!0};Z.Zf=function(a){if(Z.Ob)throw a=a||b,Error("Importing test-only code into non-debug environment"+(a?w+a:r));};Z.Be=Y();
|
13 |
-
Z.kb=function(){for(var a=[Ic,tc,Sc],c=Z.global,d;d=a.shift();)if(Z.Ic(c[d]))c=c[d];else return null;return c};Z.Re=function(a,c){var d=c||Z.global,e;for(e in a)d[e]=a[e]};Z.Id=function(a,c,d,e){if(Z.Wa){var f;a=a.replace(/\\/g,u);var g=Z.i;e&&typeof e!==qc||(e=e?{module:Dc}:{});for(var h=0;f=c[h];h++)g.U[f]=a,g.Ra[a]=e.module==Dc;for(e=0;c=d[e];e++)a in g.G||(g.G[a]={}),g.G[a][c]=!0}};Z.yg=!1;Z.zd=!0;Z.uf=function(a){Z.global.console&&Z.global.console.error(a)};Z.Uf=Y();Z.F=b;Z.Bf=Y();
|
14 |
-
Z.Hd=function(){throw Error("unimplemented abstract method");};Z.Jd=function(a){a.Fe=function(){if(a.vb)return a.vb;Z.H&&(Z.wb[Z.wb.length]=a);return a.vb=new a}};Z.wb=[];Z.Vb=!0;Z.cc=Z.H;Z.Sc={};Z.Wa=!1;
|
15 |
-
Z.Wa&&(Z.i={Ra:{},U:{},G:{},Hb:{},qa:{},X:{}},Z.tb=function(){var a=Z.global.document;return null!=a&&ud in a},Z.Ac=function(){if(Z.P(Z.global.Lb))Z.F=Z.global.Lb;else if(Z.tb())for(var a=Z.global.document.getElementsByTagName(Jb),c=a.length-1;0<=c;--c){var d=a[c].src,e=d.lastIndexOf(Ma),e=-1==e?d.length:e;if(d.substr(e-7,7)==pc){Z.F=d.substr(0,e-7);break}}},Z.Ha=function(a,c){(Z.global.rd||Z.od)(a,c)&&(Z.i.qa[a]=!0)},Z.Ub=!(Z.global.atob||!Z.global.document||!Z.global.document.all),Z.Gc=function(a){Z.Ha(b,
|
16 |
-
Gc+a+ha)&&(Z.i.qa[a]=!0)},Z.Sa=[],Z.Ag=function(a,c){return Z.Vb&&Z.P(Z.global.JSON)?Ec+Z.global.JSON.stringify(c+ca+a+ba)+xa:Fc+c+da+a+ba},Z.Rc=function(){var a=Z.Sa.length;if(0<a){var c=Z.Sa;Z.Sa=[];for(var d=0;d<a;d++)Z.Bb(c[d])}},Z.vf=function(a){Z.xb(a)&&Z.nc(a)&&Z.Bb(Z.F+Z.Ga(a))},Z.xb=function(a){return(a=Z.Ga(a))&&Z.i.Ra[a]?Z.F+a in Z.i.X:!1},Z.nc=function(a){if((a=Z.Ga(a))&&a in Z.i.G)for(var c in Z.i.G[a])if(!Z.Mc(c)&&!Z.xb(c))return!1;return!0},Z.Bb=function(a){if(a in Z.i.X){var c=Z.i.X[a];
|
17 |
-
delete Z.i.X[a];Z.Fc(c)}},Z.tf=Y(),Z.sf=function(a){var c=Z.j;try{Z.j={Pa:void 0,xa:!1};var d;if(Z.yb(a))d=a.call(Z.global,{});else if(Z.h(a))d=Z.Pc.call(Z.global,a);else throw Error("Invalid module definition");var e=Z.j.Pa;if(!Z.h(e)||!e)throw Error('Invalid module name "'+e+l);Z.j.xa?Z.fb(e,d):Z.cc&&Object.seal&&Object.seal(d);Z.Sc[e]=d}finally{Z.j=c}},Z.Pc=function(a){eval(a);return{}},Z.md=function(a){Z.global.document.write(Ia+a+ia)},Z.pc=function(a){var c=Z.global.document,d=c.createElement(gd);
|
18 |
-
d.type=ld;d.src=a;d.defer=!1;d.async=!1;c.head.appendChild(d)},Z.od=function(a,c){if(Z.tb()){var d=Z.global.document;if(!Z.Ya&&d.readyState==P){if(/\bdeps.js$/.test(a))return!1;throw Error('Cannot write "'+a+'" after document load');}var e=Z.Ub;void 0===c?e?(e=fa+ ++Z.zb+va,d.write(Ia+a+l+e+La)):Z.Ya?Z.pc(a):Z.md(a):d.write(Ja+c+Fa);return!0}return!1},Z.zb=0,Z.Df=function(a,c){a.readyState==P&&Z.zb==c&&Z.Rc();return!0},Z.Bg=function(a){function c(a){if(!(a in f.qa||a in f.Hb)){f.Hb[a]=!0;if(a in f.G)for(var g in f.G[a])if(!Z.Mc(g))if(g in
|
19 |
-
f.U)c(f.U[g]);else throw Error("Undefined nameToPath for "+g);a in e||(e[a]=!0,d.push(a))}}var d=[],e={},f=Z.i;c(a);for(a=0;a<d.length;a++){var g=d[a];Z.i.qa[g]=!0}var h=Z.j;Z.j=null;for(a=0;a<d.length;a++)if(g=d[a])f.Ra[g]?Z.Gc(Z.F+g):Z.Ha(Z.F+g);else throw Z.j=h,Error("Undefined script input");Z.j=h},Z.Ga=function(a){return a in Z.i.U?Z.i.U[a]:null},Z.Ac(),Z.global.td||Z.Ha(Z.F+"deps.js"));
|
20 |
-
Z.yf=function(a){a=a.split(u);for(var c=0;c<a.length;)a[c]==r?a.splice(c,1):c&&a[c]==Ba&&a[c-1]&&a[c-1]!=Ba?a.splice(--c,2):c++;return a.join(u)};Z.rf=function(a){if(Z.global.Mb)return Z.global.Mb(a);var c=new Z.global.XMLHttpRequest;c.open(Cc,a,!1);c.send();return c.responseText};Z.Vf=Y();
|
21 |
-
Z.s=function(a){var c=typeof a;if(c==T)if(a){if(a instanceof Array)return N;if(a instanceof Object)return c;var d=Object.prototype.toString.call(a);if(d==gc)return T;if(d==ec||typeof a.length==ad&&"undefined"!=typeof a.splice&&"undefined"!=typeof a.propertyIsEnumerable&&!a.propertyIsEnumerable(hd))return N;if(d==fc||"undefined"!=typeof a.call&&"undefined"!=typeof a.propertyIsEnumerable&&!a.propertyIsEnumerable(rc))return R}else return $c;else if(c==R&&"undefined"==typeof a.call)return T;return c};
|
22 |
-
Z.gf=function(a){return null===a};Z.Ic=function(a){return null!=a};Z.isArray=function(a){return Z.s(a)==N};Z.Ja=function(a){var c=Z.s(a);return c==N||c==T&&typeof a.length==ad};Z.bf=function(a){return Z.$(a)&&typeof a.getFullYear==R};Z.h=function(a){return typeof a==id};Z.Hc=function(a){return typeof a==qc};Z.Lc=function(a){return typeof a==ad};Z.yb=function(a){return Z.s(a)==R};Z.$=function(a){var c=typeof a;return c==T&&null!=a||c==R};Z.qb=function(a){return a[Z.D]||(a[Z.D]=++Z.hd)};Z.Se=function(a){return!!a[Z.D]};
|
23 |
-
Z.Zc=function(a){null!==a&&fd in a&&a.removeAttribute(Z.D);try{delete a[Z.D]}catch(c){}};Z.D="closure_uid_"+(1E9*Math.random()>>>0);Z.hd=0;Z.De=Z.qb;Z.Rf=Z.Zc;Z.uc=function(a){var c=Z.s(a);if(c==T||c==N){if(a.clone)return a.clone();var c=c==N?[]:{},d;for(d in a)c[d]=Z.uc(a[d]);return c}return a};Z.tc=function(a,c,d){return a.call.apply(a.bind,arguments)};
|
24 |
-
Z.rc=function(a,c,d){if(!a)throw Error();if(2<arguments.length){var e=Array.prototype.slice.call(arguments,2);return function(){var d=Array.prototype.slice.call(arguments);Array.prototype.unshift.apply(d,e);return a.apply(c,d)}}return function(){return a.apply(c,arguments)}};Z.bind=function(a,c,d){Function.prototype.bind&&-1!=Function.prototype.bind.toString().indexOf(Yc)?Z.bind=Z.tc:Z.bind=Z.rc;return Z.bind.apply(null,arguments)};
|
25 |
-
Z.Wc=function(a,c){var d=Array.prototype.slice.call(arguments,1);return function(){var c=d.slice();c.push.apply(c,arguments);return a.apply(this,c)}};Z.wf=function(a,c){for(var d in c)a[d]=c[d]};Z.now=Z.ra&&Date.now||function(){return+new Date};
|
26 |
-
Z.Fc=function(a){if(Z.global.execScript)Z.global.execScript(a,mb);else if(Z.global.eval){if(null==Z.Y)if(Z.global.eval(rd),"undefined"!=typeof Z.global._evalTest_){try{delete Z.global._evalTest_}catch(e){}Z.Y=!0}else Z.Y=!1;if(Z.Y)Z.global.eval(a);else{var c=Z.global.document,d=c.createElement(Jb);d.type=ld;d.defer=!1;d.appendChild(c.createTextNode(a));c.body.appendChild(d);c.body.removeChild(d)}}else throw Error("goog.globalEval not available");};Z.Y=null;
|
27 |
-
Z.Ce=function(a,c){function d(a){a=a.split(za);for(var c=[],d=0;d<a.length;d++)c.push(e(a[d]));return c.join(za)}function e(a){return Z.gb[a]||a}var f;f=Z.gb?Z.xc==Sa?e:d:function(a){return a};return c?a+za+f(c):f(a)};Z.Wf=function(a,c){Z.gb=a;Z.xc=c};Z.Je=function(a,c){c&&(a=a.replace(/\{\$([^}]+)}/g,function(a,e){return null!=c&&e in c?c[e]:a}));return a};Z.Ke=function(a){return a};Z.Ba=function(a,c){Z.Aa(a,c,void 0)};Z.ze=function(a,c,d){a[c]=d};
|
28 |
-
Z.Ia=function(a,c){function d(){}d.prototype=c.prototype;a.oa=c.prototype;a.prototype=new d;a.prototype.constructor=a;a.qc=function(a,d,g){for(var h=Array(arguments.length-2),m=2;m<arguments.length;m++)h[m-2]=arguments[m];return c.prototype[d].apply(a,h)}};
|
29 |
-
Z.qc=function(a,c,d){var e=arguments.callee.caller;if(Z.ec||Z.H&&!e)throw Error("arguments.caller not defined. goog.base() cannot be used with strict mode code. See http://www.ecma-international.org/ecma-262/5.1/#sec-C");if(e.oa){for(var f=Array(arguments.length-1),g=1;g<arguments.length;g++)f[g-1]=arguments[g];return e.oa.constructor.apply(a,f)}f=Array(arguments.length-2);for(g=2;g<arguments.length;g++)f[g-2]=arguments[g];for(var g=!1,h=a.constructor;h;h=h.oa&&h.oa.constructor)if(h.prototype[c]===
|
30 |
-
e)g=!0;else if(g)return h.prototype[c].apply(a,f);if(a[c]===e)return a.constructor.prototype[c].apply(a,f);throw Error("goog.base called from a method of one name to a method of a different name");};Z.scope=function(a){if(Z.La())throw Error("goog.scope is not supported within a goog.module.");a.call(Z.global)};
|
31 |
-
Z.u=function(a,c){var d=c.constructor,e=c.cd;d&&d!=Object.prototype.constructor||(d=function(){throw Error("cannot instantiate an interface (no constructor defined).");});d=Z.u.vc(d,a);a&&Z.Ia(d,a);delete c.constructor;delete c.cd;Z.u.$a(d.prototype,c);null!=e&&(e instanceof Function?e(d):Z.u.$a(d,e));return d};Z.u.bc=Z.H;
|
32 |
-
Z.u.vc=function(a,c){if(Z.u.bc&&Object.seal instanceof Function){if(c&&c.prototype&&c.prototype[Z.kc])return a;var d=function(){var c=a.apply(this,arguments)||this;c[Z.D]=c[Z.D];this.constructor===d&&Object.seal(c);return c};return d}return a};Z.u.Za="constructor hasOwnProperty isPrototypeOf propertyIsEnumerable toLocaleString toString valueOf".split(" ");
|
33 |
-
Z.u.$a=function(a,c){for(var d in c)Object.prototype.hasOwnProperty.call(c,d)&&(a[d]=c[d]);for(var e=0;e<Z.u.Za.length;e++)d=Z.u.Za[e],Object.prototype.hasOwnProperty.call(c,d)&&(a[d]=c[d])};Z.gg=Y();Z.kc="goog_defineClass_legacy_unsealable";Z.debug={};Z.debug.Error=function(a){if(Error.captureStackTrace)Error.captureStackTrace(this,Z.debug.Error);else{var c=Error().stack;c&&(this.stack=c)}a&&(this.message=String(a))};Z.Ia(Z.debug.Error,Error);Z.debug.Error.prototype.name="CustomError";Z.hb={};Z.hb.$b={Pb:1,pd:2,Gd:3,qd:4,Bd:5,Ad:6,Fd:7,ud:8,wd:9,yd:10,xd:11,Dd:12};Z.c={};Z.c.Xa=!1;Z.c.Rb=!1;Z.c.lc={Yb:"\u00a0"};Z.c.startsWith=function(a,c){return 0==a.lastIndexOf(c,0)};Z.c.endsWith=function(a,c){var d=a.length-c.length;return 0<=d&&a.indexOf(c,d)==d};Z.c.je=function(a,c){return 0==Z.c.eb(c,a.substr(0,c.length))};Z.c.fe=function(a,c){return 0==Z.c.eb(c,a.substr(a.length-c.length,c.length))};Z.c.ge=function(a,c){return a.toLowerCase()==c.toLowerCase()};
|
34 |
-
Z.c.dd=function(a,c){for(var d=a.split(la),e=b,f=Array.prototype.slice.call(arguments,1);f.length&&1<d.length;)e+=d.shift()+f.shift();return e+d.join(la)};Z.c.le=function(a){return a.replace(/[\s\xa0]+/g,k).replace(/^\s+|\s+$/g,b)};Z.c.Ka=function(a){return/^[\s\xa0]*$/.test(a)};Z.c.df=function(a){return 0==a.length};Z.c.Jc=Z.c.Ka;Z.c.Kc=function(a){return Z.c.Ka(Z.c.Tc(a))};Z.c.cf=Z.c.Kc;Z.c.$e=function(a){return!/[^\t\n\r ]/.test(a)};Z.c.Ye=function(a){return!/[^a-zA-Z]/.test(a)};Z.c.hf=function(a){return!/[^0-9]/.test(a)};
|
35 |
-
Z.c.Ze=function(a){return!/[^a-zA-Z0-9]/.test(a)};Z.c.lf=function(a){return a==k};Z.c.mf=function(a){return 1==a.length&&a>=k&&a<=Ed||a>=Fd&&a<=Td};Z.c.eg=function(a){return a.replace(/(\r\n|\r|\n)+/g,k)};Z.c.Yd=function(a){return a.replace(/(\r\n|\r|\n)/g,ba)};Z.c.Af=function(a){return a.replace(/\xa0|\s/g,k)};Z.c.zf=function(a){return a.replace(/\xa0|[ \t]+/g,k)};Z.c.ke=function(a){return a.replace(/[\t\r\n ]+/g,k).replace(/^[\t\r\n ]+|[\t\r\n ]+$/g,b)};
|
36 |
-
Z.c.trim=Z.ra&&String.prototype.trim?function(a){return a.trim()}:function(a){return a.replace(/^[\s\xa0]+|[\s\xa0]+$/g,b)};Z.c.trimLeft=function(a){return a.replace(/^[\s\xa0]+/,b)};Z.c.trimRight=function(a){return a.replace(/[\s\xa0]+$/,b)};Z.c.eb=function(a,c){var d=String(a).toLowerCase(),e=String(c).toLowerCase();return d<e?-1:d==e?0:1};
|
37 |
-
Z.c.Db=function(a,c,d){if(a==c)return 0;if(!a)return-1;if(!c)return 1;for(var e=a.toLowerCase().match(d),f=c.toLowerCase().match(d),g=Math.min(e.length,f.length),h=0;h<g;h++){d=e[h];var m=f[h];if(d!=m)return a=parseInt(d,10),!isNaN(a)&&(c=parseInt(m,10),!isNaN(c)&&a-c)?a-c:d<m?-1:1}return e.length!=f.length?e.length-f.length:a<c?-1:1};Z.c.We=function(a,c){return Z.c.Db(a,c,/\d+|\D+/g)};Z.c.Dc=function(a,c){return Z.c.Db(a,c,/\d+|\.\d+|\D+/g)};Z.c.Cf=Z.c.Dc;Z.c.xg=function(a){return encodeURIComponent(String(a))};
|
38 |
-
Z.c.wg=function(a){return decodeURIComponent(a.replace(/\+/g,k))};Z.c.Uc=function(a,c){return a.replace(/(\r\n|\r|\n)/g,c?Ga:Ha)};Z.c.rb=function(a){if(!Z.c.Jb.test(a))return a;-1!=a.indexOf(q)&&(a=a.replace(Z.c.Kb,pa));-1!=a.indexOf(x)&&(a=a.replace(Z.c.Xb,ra));-1!=a.indexOf(Ka)&&(a=a.replace(Z.c.Sb,qa));-1!=a.indexOf(l)&&(a=a.replace(Z.c.ac,sa));-1!=a.indexOf(ta)&&(a=a.replace(Z.c.dc,oa));-1!=a.indexOf(aa)&&(a=a.replace(Z.c.Zb,ma));Z.c.Xa&&-1!=a.indexOf(xc)&&(a=a.replace(Z.c.Qb,na));return a};
|
39 |
-
Z.c.Kb=/&/g;Z.c.Xb=/</g;Z.c.Sb=/>/g;Z.c.ac=/"/g;Z.c.dc=/'/g;Z.c.Zb=/\x00/g;Z.c.Qb=/e/g;Z.c.Jb=Z.c.Xa?/[\x00&<>"'e]/:/[\x00&<>"']/;Z.c.Fb=function(a){return Z.c.contains(a,q)?!Z.c.Rb&&wc in Z.global?Z.c.Gb(a):Z.c.jd(a):a};Z.c.vg=function(a,c){return Z.c.contains(a,q)?Z.c.Gb(a,c):a};
|
40 |
-
Z.c.Gb=function(a,c){var d={"&":q,"<":x,">":Ka,""":l},e;e=c?c.createElement(vc):Z.global.document.createElement(vc);return a.replace(Z.c.Tb,function(a,c){var h=d[a];if(h)return h;if(c.charAt(0)==ja){var m=Number(v+c.substr(1));isNaN(m)||(h=String.fromCharCode(m))}h||(e.innerHTML=a+k,h=e.firstChild.nodeValue.slice(0,-1));return d[a]=h})};
|
41 |
-
Z.c.jd=function(a){return a.replace(/&([^;]+);/g,function(a,d){switch(d){case nc:return q;case Xc:return x;case Lc:return Ka;case dd:return l;default:if(d.charAt(0)==ja){var e=Number(v+d.substr(1));if(!isNaN(e))return String.fromCharCode(e)}return a}})};Z.c.Tb=/&([^;\s<&]+);?/g;Z.c.zg=function(a,c){return Z.c.Uc(a.replace(/ /g,ea),c)};Z.c.Ff=function(a){return a.replace(/(^|[\n ]) /g,ka+Z.c.lc.Yb)};
|
42 |
-
Z.c.fg=function(a,c){for(var d=c.length,e=0;e<d;e++){var f=1==d?c:c.charAt(e);if(a.charAt(0)==f&&a.charAt(a.length-1)==f)return a.substring(1,a.length-1)}return a};Z.c.truncate=function(a,c,d){d&&(a=Z.c.Fb(a));a.length>c&&(a=a.substring(0,c-3)+Ca);d&&(a=Z.c.rb(a));return a};
|
43 |
-
Z.c.rg=function(a,c,d,e){d&&(a=Z.c.Fb(a));if(e&&a.length>c)e>c&&(e=c),a=a.substring(0,c-e)+Ca+a.substring(a.length-e);else if(a.length>c){e=Math.floor(c/2);var f=a.length-e;a=a.substring(0,e+c%2)+Ca+a.substring(f)}d&&(a=Z.c.rb(a));return a};Z.c.Va={"\x00":"\\0","\b":"\\b","\f":"\\f","\n":"\\n","\r":"\\r","\t":"\\t","\x0B":"\\x0B",'"':'\\"',"\\":"\\\\","<":x};Z.c.ea={"'":"\\'"};
|
44 |
-
Z.c.quote=function(a){a=String(a);for(var c=[l],d=0;d<a.length;d++){var e=a.charAt(d),f=e.charCodeAt(0);c[d+1]=Z.c.Va[e]||(31<f&&127>f?e:Z.c.ib(e))}c.push(l);return c.join(b)};Z.c.ye=function(a){for(var c=[],d=0;d<a.length;d++)c[d]=Z.c.ib(a.charAt(d));return c.join(b)};
|
45 |
-
Z.c.ib=function(a){if(a in Z.c.ea)return Z.c.ea[a];if(a in Z.c.Va)return Z.c.ea[a]=Z.c.Va[a];var c=a,d=a.charCodeAt(0);if(31<d&&127>d)c=a;else{if(256>d){if(c=kc,16>d||256<d)c+=v}else c=jc,4096>d&&(c+=v);c+=d.toString(16).toUpperCase()}return Z.c.ea[a]=c};Z.c.contains=function(a,c){return-1!=a.indexOf(c)};Z.c.$d=function(a,c){return Z.c.contains(a.toLowerCase(),c.toLowerCase())};Z.c.qe=function(a,c){return a&&c?a.split(c).length-1:0};
|
46 |
-
Z.c.L=function(a,c,d){var e=a;0<=c&&c<a.length&&0<d&&(e=a.substr(0,c)+a.substr(c+d,a.length-c-d));return e};Z.c.remove=function(a,c){var d=new RegExp(Z.c.Ta(c),b);return a.replace(d,b)};Z.c.Of=function(a,c){var d=new RegExp(Z.c.Ta(c),Bc);return a.replace(d,b)};Z.c.Ta=function(a){return String(a).replace(/([-()\[\]{}+?*.$\^|,:#<!\\])/g,hc).replace(/\x08/g,lc)};Z.c.repeat=String.prototype.repeat?function(a,c){return a.repeat(c)}:function(a,c){return Array(c+1).join(a)};
|
47 |
-
Z.c.Ef=function(a,c,d){a=Z.P(d)?a.toFixed(d):String(a);d=a.indexOf(r);-1==d&&(d=a.length);return Z.c.repeat(v,Math.max(0,c-d))+a};Z.c.Tc=function(a){return null==a?b:String(a)};Z.c.Xd=function(a){return Array.prototype.join.call(arguments,b)};Z.c.Ne=function(){return Math.floor(2147483648*Math.random()).toString(36)+Math.abs(Math.floor(2147483648*Math.random())^Z.now()).toString(36)};
|
48 |
-
Z.c.oe=function(a,c){for(var d=0,e=Z.c.trim(String(a)).split(r),f=Z.c.trim(String(c)).split(r),g=Math.max(e.length,f.length),h=0;0==d&&h<g;h++){var m=e[h]||b,n=f[h]||b,p=/(\d*)(\D*)/g,Oa=/(\d*)(\D*)/g;do{var A=p.exec(m)||[b,b,b],t=Oa.exec(n)||[b,b,b];if(0==A[0].length&&0==t[0].length)break;d=Z.c.ua(0==A[1].length?0:parseInt(A[1],10),0==t[1].length?0:parseInt(t[1],10))||Z.c.ua(0==A[2].length,0==t[2].length)||Z.c.ua(A[2],t[2])}while(0==d)}return d};Z.c.ua=function(a,c){return a<c?-1:a>c?1:0};
|
49 |
-
Z.c.Te=function(a){for(var c=0,d=0;d<a.length;++d)c=31*c+a.charCodeAt(d)>>>0;return c};Z.c.kd=2147483648*Math.random()|0;Z.c.re=function(){return Hc+Z.c.kd++};Z.c.jg=function(a){var c=Number(a);return 0==c&&Z.c.Ka(a)?NaN:c};Z.c.ef=function(a){return/^[a-z]+([A-Z][a-z]*)*$/.test(a)};Z.c.nf=function(a){return/^([A-Z][a-z]*)+$/.test(a)};Z.c.hg=function(a){return String(a).replace(/\-([a-z])/g,function(a,d){return d.toUpperCase()})};Z.c.pg=function(a){return String(a).replace(/([A-Z])/g,Aa).toLowerCase()};
|
50 |
-
Z.c.qg=function(a,c){var d=Z.h(c)?Z.c.Ta(c):ic;return a.replace(new RegExp(ua+(d?Cd+d+mc:b)+wa,Bc),function(a,c,d){return c+d.toUpperCase()})};Z.c.Zd=function(a){return String(a.charAt(0)).toUpperCase()+String(a.substr(1)).toLowerCase()};Z.c.parseInt=function(a){isFinite(a)&&(a=String(a));return Z.h(a)?/^\s*-?0x/i.test(a)?parseInt(a,16):parseInt(a,10):NaN};Z.c.cg=function(a,c,d){a=a.split(c);for(var e=[];0<d&&a.length;)e.push(a.shift()),d--;a.length&&e.push(a.join(c));return e};
|
51 |
-
Z.c.qf=function(a,c){if(c)typeof c==id&&(c=[c]);else return a;for(var d=-1,e=0;e<c.length;e++)if(c[e]!=b){var f=a.lastIndexOf(c[e]);f>d&&(d=f)}return-1==d?a:a.slice(d+1)};Z.c.we=function(a,c){var d=[],e=[];if(a==c)return 0;if(!a.length||!c.length)return Math.max(a.length,c.length);for(var f=0;f<c.length+1;f++)d[f]=f;for(f=0;f<a.length;f++){e[0]=f+1;for(var g=0;g<c.length;g++)e[g+1]=Math.min(e[g]+1,d[g+1]+1,d[g]+Number(a[f]!=c[g]));for(g=0;g<d.length;g++)d[g]=e[g]}return e[c.length]};Z.g={};Z.g.o=Z.H;Z.g.V=function(a,c){c.unshift(a);Z.debug.Error.call(this,Z.c.dd.apply(null,c));c.shift()};Z.Ia(Z.g.V,Z.debug.Error);Z.g.V.prototype.name="AssertionError";Z.g.Nb=function(a){throw a;};Z.g.ya=Z.g.Nb;Z.g.A=function(a,c,d,e){var f=Ra;if(d)var f=f+(w+d),g=e;else a&&(f+=w+a,g=c);a=new Z.g.V(b+f,g||[]);Z.g.ya(a)};Z.g.Xf=function(a){Z.g.o&&(Z.g.ya=a)};Z.g.assert=function(a,c,d){Z.g.o&&!a&&Z.g.A(b,null,c,Array.prototype.slice.call(arguments,2));return a};
|
52 |
-
Z.g.Ca=function(a,c){Z.g.o&&Z.g.ya(new Z.g.V(eb+(a?w+a:b),Array.prototype.slice.call(arguments,1)))};Z.g.Pd=function(a,c,d){Z.g.o&&!Z.Lc(a)&&Z.g.A(bb,[Z.s(a),a],c,Array.prototype.slice.call(arguments,2));return a};Z.g.Sd=function(a,c,d){Z.g.o&&!Z.h(a)&&Z.g.A(db,[Z.s(a),a],c,Array.prototype.slice.call(arguments,2));return a};Z.g.Nd=function(a,c,d){Z.g.o&&!Z.yb(a)&&Z.g.A($a,[Z.s(a),a],c,Array.prototype.slice.call(arguments,2));return a};
|
53 |
-
Z.g.Qd=function(a,c,d){Z.g.o&&!Z.$(a)&&Z.g.A(cb,[Z.s(a),a],c,Array.prototype.slice.call(arguments,2));return a};Z.g.Kd=function(a,c,d){Z.g.o&&!Z.isArray(a)&&Z.g.A(Ya,[Z.s(a),a],c,Array.prototype.slice.call(arguments,2));return a};Z.g.Ld=function(a,c,d){Z.g.o&&!Z.Hc(a)&&Z.g.A(Za,[Z.s(a),a],c,Array.prototype.slice.call(arguments,2));return a};Z.g.Md=function(a,c,d){!Z.g.o||Z.$(a)&&a.nodeType==Z.hb.$b.Pb||Z.g.A(Xa,[Z.s(a),a],c,Array.prototype.slice.call(arguments,2));return a};
|
54 |
-
Z.g.Od=function(a,c,d,e){!Z.g.o||a instanceof c||Z.g.A(ab,[Z.g.pb(c),Z.g.pb(a)],d,Array.prototype.slice.call(arguments,3));return a};Z.g.Rd=function(){for(var a in Object.prototype)Z.g.Ca(a+ga)};Z.g.pb=function(a){return a instanceof Function?a.displayName||a.name||pd:a instanceof Object?a.constructor.displayName||a.constructor.name||Object.prototype.toString.call(a):null===a?$c:typeof a};Z.f={};Z.w=Z.ra;Z.f.v=!1;Z.f.Xc=function(a){return a[a.length-1]};Z.f.pf=Z.f.Xc;Z.f.indexOf=Z.w&&(Z.f.v||Array.prototype.indexOf)?function(a,c,d){return Array.prototype.indexOf.call(a,c,d)}:function(a,c,d){d=null==d?0:0>d?Math.max(0,a.length+d):d;if(Z.h(a))return Z.h(c)&&1==c.length?a.indexOf(c,d):-1;for(;d<a.length;d++)if(d in a&&a[d]===c)return d;return-1};
|
55 |
-
Z.f.lastIndexOf=Z.w&&(Z.f.v||Array.prototype.lastIndexOf)?function(a,c,d){return Array.prototype.lastIndexOf.call(a,c,null==d?a.length-1:d)}:function(a,c,d){d=null==d?a.length-1:d;0>d&&(d=Math.max(0,a.length+d));if(Z.h(a))return Z.h(c)&&1==c.length?a.lastIndexOf(c,d):-1;for(;0<=d;d--)if(d in a&&a[d]===c)return d;return-1};
|
56 |
-
Z.f.forEach=Z.w&&(Z.f.v||Array.prototype.forEach)?function(a,c,d){Array.prototype.forEach.call(a,c,d)}:function(a,c,d){for(var e=a.length,f=Z.h(a)?a.split(b):a,g=0;g<e;g++)g in f&&c.call(d,f[g],g,a)};Z.f.jb=function(a,c){for(var d=Z.h(a)?a.split(b):a,e=a.length-1;0<=e;--e)e in d&&c.call(void 0,d[e],e,a)};
|
57 |
-
Z.f.filter=Z.w&&(Z.f.v||Array.prototype.filter)?function(a,c,d){return Array.prototype.filter.call(a,c,d)}:function(a,c,d){for(var e=a.length,f=[],g=0,h=Z.h(a)?a.split(b):a,m=0;m<e;m++)if(m in h){var n=h[m];c.call(d,n,m,a)&&(f[g++]=n)}return f};Z.f.map=Z.w&&(Z.f.v||Array.prototype.map)?function(a,c,d){return Array.prototype.map.call(a,c,d)}:function(a,c,d){for(var e=a.length,f=Array(e),g=Z.h(a)?a.split(b):a,h=0;h<e;h++)h in g&&(f[h]=c.call(d,g[h],h,a));return f};
|
58 |
-
Z.f.reduce=Z.w&&(Z.f.v||Array.prototype.reduce)?function(a,c,d,e){e&&(c=Z.bind(c,e));return Array.prototype.reduce.call(a,c,d)}:function(a,c,d,e){var f=d;Z.f.forEach(a,function(d,h){f=c.call(e,f,d,h,a)});return f};Z.f.reduceRight=Z.w&&(Z.f.v||Array.prototype.reduceRight)?function(a,c,d,e){e&&(c=Z.bind(c,e));return Array.prototype.reduceRight.call(a,c,d)}:function(a,c,d,e){var f=d;Z.f.jb(a,function(d,h){f=c.call(e,f,d,h,a)});return f};
|
59 |
-
Z.f.some=Z.w&&(Z.f.v||Array.prototype.some)?function(a,c,d){return Array.prototype.some.call(a,c,d)}:function(a,c,d){for(var e=a.length,f=Z.h(a)?a.split(b):a,g=0;g<e;g++)if(g in f&&c.call(d,f[g],g,a))return!0;return!1};Z.f.every=Z.w&&(Z.f.v||Array.prototype.every)?function(a,c,d){return Array.prototype.every.call(a,c,d)}:function(a,c,d){for(var e=a.length,f=Z.h(a)?a.split(b):a,g=0;g<e;g++)if(g in f&&!c.call(d,f[g],g,a))return!1;return!0};
|
60 |
-
Z.f.count=function(a,c,d){var e=0;Z.f.forEach(a,function(a,g,h){c.call(d,a,g,h)&&++e},d);return e};Z.f.find=function(a,c,d){c=Z.f.findIndex(a,c,d);return 0>c?null:Z.h(a)?a.charAt(c):a[c]};Z.f.findIndex=function(a,c,d){for(var e=a.length,f=Z.h(a)?a.split(b):a,g=0;g<e;g++)if(g in f&&c.call(d,f[g],g,a))return g;return-1};Z.f.Ae=function(a,c,d){c=Z.f.Bc(a,c,d);return 0>c?null:Z.h(a)?a.charAt(c):a[c]};
|
61 |
-
Z.f.Bc=function(a,c,d){for(var e=Z.h(a)?a.split(b):a,f=a.length-1;0<=f;f--)if(f in e&&c.call(d,e[f],f,a))return f;return-1};Z.f.contains=function(a,c){return 0<=Z.f.indexOf(a,c)};Z.f.Jc=function(a){return 0==a.length};Z.f.clear=function(a){if(!Z.isArray(a))for(var c=a.length-1;0<=c;c--)delete a[c];a.length=0};Z.f.Ue=function(a,c){Z.f.contains(a,c)||a.push(c)};Z.f.ub=function(a,c,d){Z.f.splice(a,d,0,c)};Z.f.Ve=function(a,c,d){Z.Wc(Z.f.splice,a,d,0).apply(null,c)};
|
62 |
-
Z.f.insertBefore=function(a,c,d){var e;2==arguments.length||0>(e=Z.f.indexOf(a,d))?a.push(c):Z.f.ub(a,c,e)};Z.f.remove=function(a,c){var d=Z.f.indexOf(a,c),e;(e=0<=d)&&Z.f.L(a,d);return e};Z.f.Tf=function(a,c){var d=Z.f.lastIndexOf(a,c);return 0<=d?(Z.f.L(a,d),!0):!1};Z.f.L=function(a,c){return 1==Array.prototype.splice.call(a,c,1).length};Z.f.Sf=function(a,c,d){c=Z.f.findIndex(a,c,d);return 0<=c?(Z.f.L(a,c),!0):!1};
|
63 |
-
Z.f.Pf=function(a,c,d){var e=0;Z.f.jb(a,function(f,g){c.call(d,f,g,a)&&Z.f.L(a,g)&&e++});return e};Z.f.concat=function(a){return Array.prototype.concat.apply(Array.prototype,arguments)};Z.f.join=function(a){return Array.prototype.concat.apply(Array.prototype,arguments)};Z.f.fd=function(a){var c=a.length;if(0<c){for(var d=Array(c),e=0;e<c;e++)d[e]=a[e];return d}return[]};Z.f.clone=Z.f.fd;
|
64 |
-
Z.f.extend=function(a,c){for(var d=1;d<arguments.length;d++){var e=arguments[d];if(Z.Ja(e)){var f=a.length||0,g=e.length||0;a.length=f+g;for(var h=0;h<g;h++)a[f+h]=e[h]}else a.push(e)}};Z.f.splice=function(a,c,d,e){return Array.prototype.splice.apply(a,Z.f.slice(arguments,1))};Z.f.slice=function(a,c,d){return 2>=arguments.length?Array.prototype.slice.call(a,c):Array.prototype.slice.call(a,c,d)};
|
65 |
-
Z.f.Qf=function(a,c,d){function e(a){return Z.$(a)?bd+Z.qb(a):(typeof a).charAt(0)+a}c=c||a;d=d||e;for(var f={},g=0,h=0;h<a.length;){var m=a[h++],n=d(m);Object.prototype.hasOwnProperty.call(f,n)||(f[n]=!0,c[g++]=m)}c.length=g};Z.f.bb=function(a,c,d){return Z.f.cb(a,d||Z.f.B,!1,c)};Z.f.Vd=function(a,c,d){return Z.f.cb(a,c,!0,void 0,d)};Z.f.cb=function(a,c,d,e,f){for(var g=0,h=a.length,m;g<h;){var n=g+h>>1,p;p=d?c.call(f,a[n],n,a):c(e,a[n]);0<p?g=n+1:(h=n,m=!p)}return m?g:~g};
|
66 |
-
Z.f.sort=function(a,c){a.sort(c||Z.f.B)};Z.f.dg=function(a,c){for(var d=Array(a.length),e=0;e<a.length;e++)d[e]={index:e,value:a[e]};var f=c||Z.f.B;Z.f.sort(d,function(a,c){return f(a.value,c.value)||a.index-c.index});for(e=0;e<a.length;e++)a[e]=d[e].value};Z.f.bd=function(a,c,d){var e=d||Z.f.B;Z.f.sort(a,function(a,d){return e(c(a),c(d))})};Z.f.ag=function(a,c,d){Z.f.bd(a,function(a){return a[c]},d)};
|
67 |
-
Z.f.kf=function(a,c,d){c=c||Z.f.B;for(var e=1;e<a.length;e++){var f=c(a[e-1],a[e]);if(0<f||0==f&&d)return!1}return!0};Z.f.xe=function(a,c,d){if(!Z.Ja(a)||!Z.Ja(c)||a.length!=c.length)return!1;var e=a.length;d=d||Z.f.yc;for(var f=0;f<e;f++)if(!d(a[f],c[f]))return!1;return!0};Z.f.me=function(a,c,d){d=d||Z.f.B;for(var e=Math.min(a.length,c.length),f=0;f<e;f++){var g=d(a[f],c[f]);if(0!=g)return g}return Z.f.B(a.length,c.length)};Z.f.B=function(a,c){return a>c?1:a<c?-1:0};
|
68 |
-
Z.f.Xe=function(a,c){return-Z.f.B(a,c)};Z.f.yc=function(a,c){return a===c};Z.f.Td=function(a,c,d){d=Z.f.bb(a,c,d);return 0>d?(Z.f.ub(a,c,-(d+1)),!0):!1};Z.f.Ud=function(a,c,d){c=Z.f.bb(a,c,d);return 0<=c?Z.f.L(a,c):!1};Z.f.Wd=function(a,c,d){for(var e={},f=0;f<a.length;f++){var g=a[f],h=c.call(d,g,f,a);Z.P(h)&&(e[h]||(e[h]=[])).push(g)}return e};Z.f.og=function(a,c,d){var e={};Z.f.forEach(a,function(f,g){e[c.call(d,f,g,a)]=f});return e};
|
69 |
-
Z.f.Hf=function(a,c,d){var e=[],f=0,g=a;d=d||1;void 0!==c&&(f=a,g=c);if(0>d*(g-f))return[];if(0<d)for(a=f;a<g;a+=d)e.push(a);else for(a=f;a>g;a+=d)e.push(a);return e};Z.f.repeat=function(a,c){for(var d=[],e=0;e<c;e++)d[e]=a;return d};Z.f.Cc=function(a){for(var c=[],d=0;d<arguments.length;d++){var e=arguments[d];if(Z.isArray(e))for(var f=0;f<e.length;f+=8192)for(var g=Z.f.Cc.apply(null,Z.f.slice(e,f,f+8192)),h=0;h<g.length;h++)c.push(g[h]);else c.push(e)}return c};
|
70 |
-
Z.f.rotate=function(a,c){a.length&&(c%=a.length,0<c?Array.prototype.unshift.apply(a,a.splice(-c,c)):0>c&&Array.prototype.push.apply(a,a.splice(0,-c)));return a};Z.f.xf=function(a,c,d){c=Array.prototype.splice.call(a,c,1);Array.prototype.splice.call(a,d,0,c[0])};
|
71 |
-
Z.f.Cg=function(a){if(!arguments.length)return[];for(var c=[],d=arguments[0].length,e=1;e<arguments.length;e++)arguments[e].length<d&&(d=arguments[e].length);for(e=0;e<d;e++){for(var f=[],g=0;g<arguments.length;g++)f.push(arguments[g][e]);c.push(f)}return c};Z.f.$f=function(a,c){for(var d=c||Math.random,e=a.length-1;0<e;e--){var f=Math.floor(d()*(e+1)),g=a[e];a[e]=a[f];a[f]=g}};Z.f.pe=function(a,c){var d=[];Z.f.forEach(c,function(c){d.push(a[c])});return d};Z.locale={};
|
72 |
-
Z.locale.J={COUNTRY:{AD:"Andorra",AE:Md,AF:Ld,AG:Qa,AI:"Anguilla",AL:"Shqip\u00ebria",AM:Kd,AN:wb,AO:"Angola",AQ:"Antarctica",AR:"Argentina",AS:Pa,AT:"\u00d6sterreich",AU:"Australia",AW:"Aruba",AX:"\u00c5land",AZ:"Az\u0259rbaycan",BA:z,BB:"Barbados",BD:"\u09ac\u09be\u0982\u09b2\u09be\u09a6\u09c7\u09b6",BE:"Belgi\u00eb",BF:"Burkina Faso",BG:"\u0411\u044a\u043b\u0433\u0430\u0440\u0438\u044f",BH:"\u0627\u0644\u0628\u062d\u0631\u064a\u0646",BI:"Burundi",BJ:"B\u00e9nin",BM:"Bermuda",BN:"Brunei",BO:y,BR:"Brasil",
|
73 |
-
BS:"Bahamas",BT:"\u092d\u0942\u091f\u093e\u0928",BV:"Bouvet Island",BW:Ta,BY:Hd,BZ:"Belize",CA:"Canada",CC:"Cocos (Keeling) Islands",CD:Ib,CF:Hb,CG:"Congo",CH:"Schweiz",CI:"C\u00f4te d\u2019Ivoire",CK:"Cook Islands",CL:"Chile",CM:"Cameroun",CN:"\u4e2d\u56fd",CO:"Colombia",CR:"Costa Rica",CS:Nb,CU:"Cuba",CV:"Cabo Verde",CX:Wa,CY:"\u039a\u03cd\u03c0\u03c1\u03bf\u03c2",CZ:Gd,DD:"East Germany",DE:"Deutschland",DJ:"Jabuuti",DK:"Danmark",DM:"Dominica",DO:Fb,DZ:"\u0627\u0644\u062c\u0632\u0627\u0626\u0631",
|
74 |
-
EC:"Ecuador",EE:"Eesti",EG:"\u0645\u0635\u0631",EH:Nd,ER:"\u0627\u0631\u064a\u062a\u0631\u064a\u0627",ES:"Espa\u00f1a",ET:X,FI:"Suomi",FJ:"\u092b\u093f\u091c\u0940",FK:fb,FM:C,FO:"F\u00f8royar",FR:"France",FX:"Metropolitan France",GA:"Gabon",GB:$b,GD:"Grenada",GE:"\u10e1\u10d0\u10e5\u10d0\u10e0\u10d7\u10d5\u10d4\u10da\u10dd",GF:hb,GG:"Guernsey",GH:B,GI:"Gibraltar",GL:nb,GM:"Gambia",GN:"Guin\u00e9e",GP:"Guadeloupe",GQ:gb,GR:"\u0395\u03bb\u03bb\u03ac\u03b4\u03b1",GS:"South Georgia and the South Sandwich Islands",
|
75 |
-
GT:"Guatemala",GU:"Guam",GW:"Guin\u00e9 Bissau",GY:"Guyana",HK:"\u9999\u6e2f",HM:"Heard Island and McDonald Islands",HN:jb,HR:"Hrvatska",HT:"Ha\u00efti",HU:"Magyarorsz\u00e1g",ID:kb,IE:"Ireland",IL:"\u05d9\u05e9\u05e8\u05d0\u05dc",IM:"Isle of Man",IN:W,IO:"British Indian Ocean Territory",IQ:"\u0627\u0644\u0639\u0631\u0627\u0642",IR:"\u0627\u06cc\u0631\u0627\u0646",IS:"\u00cdsland",IT:"Italia",JE:"Jersey",JM:"Jamaica",JO:"\u0627\u0644\u0623\u0631\u062f\u0646",JP:"\u65e5\u672c",KE:"Kenya",KG:Id,KH:"\u1780\u1798\u17d2\u1796\u17bb\u1787\u17b6",
|
76 |
-
KI:ob,KM:Qd,KN:Kb,KP:Sd,KR:"\ub300\ud55c\ubbfc\uad6d",KW:"\u0627\u0644\u0643\u0648\u064a\u062a",KY:Va,KZ:"\u041a\u0430\u0437\u0430\u0445\u0441\u0442\u0430\u043d",LA:"\u0e25\u0e32\u0e27",LB:"\u0644\u0628\u0646\u0627\u0646",LC:"Saint Lucia",LI:"Liechtenstein",LK:"\u0b87\u0bb2\u0b99\u0bcd\u0b95\u0bc8",LR:"Liberia",LS:"Lesotho",LT:"Lietuva",LU:sb,LV:"Latvija",LY:"\u0644\u064a\u0628\u064a\u0627",MA:"\u0627\u0644\u0645\u063a\u0631\u0628",MC:"Monaco",MD:vb,ME:"\u0426\u0440\u043d\u0430 \u0413\u043e\u0440\u0430",
|
77 |
-
MG:tb,MH:ub,MK:"\u041c\u0430\u043a\u0435\u0434\u043e\u043d\u0438\u0458\u0430",ML:"\u0645\u0627\u0644\u064a",MM:"Myanmar",MN:"\u8499\u53e4",MO:"\u6fb3\u95e8",MP:zb,MQ:"Martinique",MR:"\u0645\u0648\u0631\u064a\u062a\u0627\u0646\u064a\u0627",MS:"Montserrat",MT:"Malta",MU:"Mauritius",MV:"Maldives",MW:"Malawi",MX:"M\u00e9xico",MY:"Malaysia",MZ:"Mo\u00e7ambique",NA:"Namibia",NC:Ab,NE:"Niger",NF:yb,NG:D,NI:"Nicaragua",NL:"Nederland",NO:"Norge",NP:"\u0928\u0947\u092a\u093e\u0932",NR:"Nauru",NT:"Neutral Zone",
|
78 |
-
NU:"Niue",NZ:xb,OM:"\u0639\u0645\u0627\u0646",PA:"Panam\u00e1",PE:"Per\u00fa",PF:Db,PG:E,PH:Cb,PK:Rd,PL:"Polska",PM:Mb,PN:"Pitcairn",PR:Eb,PS:"\u0641\u0644\u0633\u0637\u064a\u0646",PT:"Portugal",PW:"Palau",PY:Bb,QA:"\u0642\u0637\u0631",QO:"Outlying Oceania",QU:"European Union",RE:"R\u00e9union",RO:"Rom\u00e2nia",RS:"\u0421\u0440\u0431\u0438\u0458\u0430",RU:"\u0420\u043e\u0441\u0441\u0438\u044f",RW:F,SA:Od,SB:Qb,SC:Ob,SD:"\u0627\u0644\u0633\u0648\u062f\u0627\u0646",SE:"Sverige",SG:"\u65b0\u52a0\u5761",
|
79 |
-
SH:"Saint Helena",SI:"Slovenija",SJ:Rb,SK:Pb,SL:"Sierra Leone",SM:"San Marino",SN:H,SO:"Somali",SR:"Suriname",ST:Vb,SU:"Union of Soviet Socialist Republics",SV:"El Salvador",SY:"\u0633\u0648\u0631\u064a\u0627",SZ:Ub,TC:Yb,TD:"\u062a\u0634\u0627\u062f",TF:"French Southern Territories",TG:"Togo",TH:"\u0e1b\u0e23\u0e30\u0e40\u0e17\u0e28\u0e44\u0e17\u0e22",TJ:"\u062a\u0627\u062c\u06cc\u06a9\u0633\u062a\u0627\u0646",TK:I,TL:Xb,TM:"\u0422\u0443\u0440\u043a\u043c\u0435\u043d\u0438\u0441\u0442\u0430\u043d",
|
80 |
-
TN:"\u062a\u0648\u0646\u0633",TO:"Tonga",TR:K,TT:"Trinidad y Tobago",TV:J,TW:"\u53f0\u6e7e",TZ:Wb,UA:"\u0423\u043a\u0440\u0430\u0457\u043d\u0430",UG:"Uganda",UM:bc,US:ac,UY:"Uruguay",UZ:"\u040e\u0437\u0431\u0435\u043a\u0438\u0441\u0442\u043e\u043d",VA:"Vaticano",VC:Lb,VE:"Venezuela",VG:Ua,VI:Zb,VN:"Vi\u1ec7t Nam",VU:L,WF:dc,WS:"Samoa",YD:"People's Democratic Republic of Yemen",YE:"\u0627\u0644\u064a\u0645\u0646",YT:"Mayotte",ZA:G,ZM:"Zambia",ZW:"Zimbabwe",ZZ:cc,aa_DJ:"Jabuuti",aa_ER:"\u00c9rythr\u00e9e",
|
81 |
-
aa_ER_SAAHO:"\u00c9rythr\u00e9e",aa_ET:lb,af_NA:"Namibi\u00eb",af_ZA:"Suid-Afrika",ak_GH:B,am_ET:X,ar_AE:Md,ar_BH:"\u0627\u0644\u0628\u062d\u0631\u064a\u0646",ar_DJ:"\u062c\u064a\u0628\u0648\u062a\u064a",ar_DZ:"\u0627\u0644\u062c\u0632\u0627\u0626\u0631",ar_EG:"\u0645\u0635\u0631",ar_EH:Nd,ar_ER:"\u0627\u0631\u064a\u062a\u0631\u064a\u0627",ar_IL:"\u0627\u0633\u0631\u0627\u0626\u064a\u0644",ar_IQ:"\u0627\u0644\u0639\u0631\u0627\u0642",ar_JO:"\u0627\u0644\u0623\u0631\u062f\u0646",ar_KM:Qd,ar_KW:"\u0627\u0644\u0643\u0648\u064a\u062a",
|
82 |
-
ar_LB:"\u0644\u0628\u0646\u0627\u0646",ar_LY:"\u0644\u064a\u0628\u064a\u0627",ar_MA:"\u0627\u0644\u0645\u063a\u0631\u0628",ar_MR:"\u0645\u0648\u0631\u064a\u062a\u0627\u0646\u064a\u0627",ar_OM:"\u0639\u0645\u0627\u0646",ar_PS:"\u0641\u0644\u0633\u0637\u064a\u0646",ar_QA:"\u0642\u0637\u0631",ar_SA:Od,ar_SD:"\u0627\u0644\u0633\u0648\u062f\u0627\u0646",ar_SY:"\u0633\u0648\u0631\u064a\u0627",ar_TD:"\u062a\u0634\u0627\u062f",ar_TN:"\u062a\u0648\u0646\u0633",ar_YE:"\u0627\u0644\u064a\u0645\u0646",as_IN:"\u09ad\u09be\u09f0\u09a4",
|
83 |
-
ay_BO:y,az_AZ:"Az\u0259rbaycan",az_Cyrl_AZ:"\u0410\u0437\u04d9\u0440\u0431\u0430\u0458\u04b9\u0430\u043d",az_Latn_AZ:"Azerbaycan",be_BY:Hd,bg_BG:"\u0411\u044a\u043b\u0433\u0430\u0440\u0438\u044f",bi_VU:L,bn_BD:"\u09ac\u09be\u0982\u09b2\u09be\u09a6\u09c7\u09b6",bn_IN:"\u09ad\u09be\u09b0\u09a4",bo_CN:"\u0f62\u0f92\u0fb1\u0f0b\u0f53\u0f42",bo_IN:"\u0f62\u0f92\u0fb1\u0f0b\u0f42\u0f62\u0f0b",bs_BA:z,byn_ER:"\u12a4\u122d\u1275\u122b",ca_AD:"Andorra",ca_ES:"Espanya",cch_NG:D,ch_GU:"Guam",chk_FM:C,cop_Arab_EG:"\u0645\u0635\u0631",
|
84 |
-
cop_Arab_US:Pd,cop_EG:"\u0645\u0635\u0631",cop_US:Pd,cs_CZ:Gd,cy_GB:"Prydain Fawr",da_DK:"Danmark",da_GL:"Gr\u00f8nland",de_AT:"\u00d6sterreich",de_BE:"Belgien",de_CH:"Schweiz",de_DE:"Deutschland",de_LI:"Liechtenstein",de_LU:"Luxemburg",dv_MV:"Maldives",dz_BT:"Bhutan",ee_GH:B,ee_TG:"Togo",efi_NG:D,el_CY:"\u039a\u03cd\u03c0\u03c1\u03bf\u03c2",el_GR:"\u0395\u03bb\u03bb\u03ac\u03b4\u03b1",en_AG:Qa,en_AI:"Anguilla",en_AS:Pa,en_AU:"Australia",en_BB:"Barbados",en_BE:"Belgium",en_BM:"Bermuda",en_BS:"Bahamas",
|
85 |
-
en_BW:Ta,en_BZ:"Belize",en_CA:"Canada",en_CC:"Cocos Islands",en_CK:"Cook Islands",en_CM:"Cameroon",en_CX:Wa,en_DM:"Dominica",en_FJ:"Fiji",en_FK:fb,en_FM:C,en_GB:$b,en_GD:"Grenada",en_GG:"Guernsey",en_GH:B,en_GI:"Gibraltar",en_GM:"Gambia",en_GU:"Guam",en_GY:"Guyana",en_HK:"Hong Kong",en_HN:jb,en_IE:"Ireland",en_IM:"Isle of Man",en_IN:"India",en_JE:"Jersey",en_JM:"Jamaica",en_KE:"Kenya",en_KI:ob,en_KN:Kb,en_KY:Va,en_LC:"Saint Lucia",en_LR:"Liberia",en_LS:"Lesotho",en_MH:ub,en_MP:zb,en_MS:"Montserrat",
|
86 |
-
en_MT:"Malta",en_MU:"Mauritius",en_MW:"Malawi",en_NA:"Namibia",en_NF:yb,en_NG:D,en_NR:"Nauru",en_NU:"Niue",en_NZ:xb,en_PG:E,en_PH:Cb,en_PK:"Pakistan",en_PN:"Pitcairn",en_PR:Eb,en_RW:F,en_SB:Qb,en_SC:Ob,en_SG:"Singapore",en_SH:"Saint Helena",en_SL:"Sierra Leone",en_SZ:Ub,en_TC:Yb,en_TK:I,en_TO:"Tonga",en_TT:"Trinidad and Tobago",en_TV:J,en_TZ:Wb,en_UG:"Uganda",en_UM:bc,en_US:ac,en_US_POSIX:ac,en_VC:Lb,en_VG:Ua,en_VI:Zb,en_VU:L,en_WS:"Samoa",en_ZA:G,en_ZM:"Zambia",en_ZW:"Zimbabwe",es_AR:"Argentina",
|
87 |
-
es_BO:y,es_CL:"Chile",es_CO:"Colombia",es_CR:"Costa Rica",es_CU:"Cuba",es_DO:Fb,es_EC:"Ecuador",es_ES:"Espa\u00f1a",es_GQ:"Guinea Ecuatorial",es_GT:"Guatemala",es_HN:jb,es_MX:"M\u00e9xico",es_NI:"Nicaragua",es_PA:"Panam\u00e1",es_PE:"Per\u00fa",es_PH:"Filipinas",es_PR:Eb,es_PY:Bb,es_SV:"El Salvador",es_US:"Estados Unidos",es_UY:"Uruguay",es_VE:"Venezuela",et_EE:"Eesti",eu_ES:"Espainia",fa_AF:Ld,fa_IR:"\u0627\u06cc\u0631\u0627\u0646",fi_FI:"Suomi",fil_PH:Cb,fj_FJ:"Fiji",fo_FO:"F\u00f8royar",fr_BE:"Belgique",
|
88 |
-
fr_BF:"Burkina Faso",fr_BI:"Burundi",fr_BJ:"B\u00e9nin",fr_CA:"Canada",fr_CD:Ib,fr_CF:Hb,fr_CG:"Congo",fr_CH:"Suisse",fr_CI:"C\u00f4te d\u2019Ivoire",fr_CM:"Cameroun",fr_DJ:"Djibouti",fr_DZ:"Alg\u00e9rie",fr_FR:"France",fr_GA:"Gabon",fr_GF:hb,fr_GN:"Guin\u00e9e",fr_GP:"Guadeloupe",fr_GQ:gb,fr_HT:"Ha\u00efti",fr_KM:"Comores",fr_LU:sb,fr_MA:"Maroc",fr_MC:"Monaco",fr_MG:tb,fr_ML:"Mali",fr_MQ:"Martinique",fr_MU:"Maurice",fr_NC:Ab,fr_NE:"Niger",fr_PF:Db,fr_PM:Mb,fr_RE:"R\u00e9union",fr_RW:F,fr_SC:Ob,fr_SN:H,
|
89 |
-
fr_SY:"Syrie",fr_TD:"Tchad",fr_TG:"Togo",fr_TN:"Tunisie",fr_VU:L,fr_WF:dc,fr_YT:"Mayotte",fur_IT:"Italia",ga_IE:"\u00c9ire",gaa_GH:B,gez_ER:"\u12a4\u122d\u1275\u122b",gez_ET:X,gil_KI:ob,gl_ES:"Espa\u00f1a",gn_PY:Bb,gu_IN:"\u0aad\u0abe\u0ab0\u0aa4",gv_GB:Gb,ha_Arab_NG:"\u0646\u064a\u062c\u064a\u0631\u064a\u0627",ha_GH:"\u063a\u0627\u0646\u0627",ha_Latn_GH:B,ha_Latn_NE:"Niger",ha_Latn_NG:"Nig\u00e9ria",ha_NE:"\u0627\u0644\u0646\u064a\u062c\u0631",ha_NG:"\u0646\u064a\u062c\u064a\u0631\u064a\u0627",haw_US:"\u02bbAmelika Hui P\u016b \u02bbIa",
|
90 |
-
he_IL:"\u05d9\u05e9\u05e8\u05d0\u05dc",hi_IN:W,ho_PG:E,hr_BA:z,hr_HR:"Hrvatska",ht_HT:"Ha\u00efti",hu_HU:"Magyarorsz\u00e1g",hy_AM:Kd,hy_AM_REVISED:Kd,id_ID:kb,ig_NG:D,ii_CN:"\ua34f\ua1e9",is_IS:"\u00cdsland",it_CH:"Svizzera",it_IT:"Italia",it_SM:"San Marino",ja_JP:"\u65e5\u672c",ka_GE:"\u10e1\u10d0\u10e5\u10d0\u10e0\u10d7\u10d5\u10d4\u10da\u10dd",kaj_NG:D,kam_KE:"Kenya",kcg_NG:D,kfo_NG:"Nig\u00e9ria",kk_KZ:"\u049a\u0430\u0437\u0430\u049b\u0441\u0442\u0430\u043d",kl_GL:nb,km_KH:"\u1780\u1798\u17d2\u1796\u17bb\u1787\u17b6",
|
91 |
-
kn_IN:"\u0cad\u0cbe\u0cb0\u0ca4",ko_KP:Sd,ko_KR:"\ub300\ud55c\ubbfc\uad6d",kok_IN:W,kos_FM:C,kpe_GN:"Guin\u00e9e",kpe_LR:"Lib\u00e9ria",ks_IN:W,ku_IQ:"Irak",ku_IR:"\u0130ran",ku_Latn_IQ:"Irak",ku_Latn_IR:"\u0130ran",ku_Latn_SY:"Suriye",ku_Latn_TR:K,ku_SY:"Suriye",ku_TR:K,kw_GB:Gb,ky_Cyrl_KG:Id,ky_KG:"K\u0131rg\u0131zistan",la_VA:"Vaticano",lb_LU:sb,ln_CD:Ib,ln_CG:"Kongo",lo_LA:"Laos",lt_LT:"Lietuva",lv_LV:"Latvija",mg_MG:tb,mh_MH:ub,mi_NZ:xb,mk_MK:"\u041c\u0430\u043a\u0435\u0434\u043e\u043d\u0438\u0458\u0430",
|
92 |
-
ml_IN:"\u0d07\u0d28\u0d4d\u0d24\u0d4d\u0d2f",mn_Cyrl_MN:"\u041c\u043e\u043d\u0433\u043e\u043b\u0438\u044f",mn_MN:"\u041c\u043e\u043d\u0433\u043e\u043b\u0438\u044f",mr_IN:W,ms_BN:"Brunei",ms_MY:"Malaysia",ms_SG:"Singapura",mt_MT:"Malta",my_MM:"Myanmar",na_NR:"Nauru",nb_NO:"Norge",nb_SJ:Rb,ne_NP:"\u0928\u0947\u092a\u093e\u0932",niu_NU:"Niue",nl_AN:wb,nl_AW:"Aruba",nl_BE:"Belgi\u00eb",nl_NL:"Nederland",nl_SR:"Suriname",nn_NO:"Noreg",nr_ZA:G,nso_ZA:G,ny_MW:"Malawi",om_ET:lb,om_KE:"Keeniyaa",or_IN:"\u0b2d\u0b3e\u0b30\u0b24",
|
93 |
-
pa_Arab_PK:Rd,pa_Guru_IN:"\u0a2d\u0a3e\u0a30\u0a24",pa_IN:"\u0a2d\u0a3e\u0a30\u0a24",pa_PK:Rd,pap_AN:wb,pau_PW:"Palau",pl_PL:"Polska",pon_FM:C,ps_AF:Ld,pt_AO:"Angola",pt_BR:"Brasil",pt_CV:"Cabo Verde",pt_GW:"Guin\u00e9 Bissau",pt_MZ:"Mo\u00e7ambique",pt_PT:"Portugal",pt_ST:Vb,pt_TL:Xb,qu_BO:y,qu_PE:"Per\u00fa",rm_CH:"Schweiz",rn_BI:"Burundi",ro_MD:vb,ro_RO:"Rom\u00e2nia",ru_BY:Hd,ru_KG:Id,ru_KZ:"\u041a\u0430\u0437\u0430\u0445\u0441\u0442\u0430\u043d",ru_RU:"\u0420\u043e\u0441\u0441\u0438\u044f",ru_UA:"\u0423\u043a\u0440\u0430\u0438\u043d\u0430",
|
94 |
-
rw_RW:F,sa_IN:W,sd_Deva_IN:W,sd_IN:W,se_FI:"Finland",se_NO:"Norge",sg_CF:Hb,sh_BA:"Bosnia and Herzegovina",sh_CS:Nb,si_LK:"Sri Lanka",sid_ET:lb,sk_SK:Pb,sl_SI:"Slovenija",sm_AS:Pa,sm_WS:"Samoa",so_DJ:"Jabuuti",so_ET:"Itoobiya",so_KE:"Kiiniya",so_SO:"Soomaaliya",sq_AL:"Shqip\u00ebria",sr_BA:"\u0411\u043e\u0441\u043d\u0430 \u0438 \u0425\u0435\u0440\u0446\u0435\u0433\u043e\u0432\u0438\u043d\u0430",sr_CS:"\u0421\u0440\u0431\u0438\u0458\u0430 \u0438 \u0426\u0440\u043d\u0430 \u0413\u043e\u0440\u0430",sr_Cyrl_BA:"\u0411\u043e\u0441\u043d\u0438\u044f",
|
95 |
-
sr_Cyrl_CS:"\u0421\u0435\u0440\u0431\u0438\u044f \u0438 \u0427\u0435\u0440\u043d\u043e\u0433\u043e\u0440\u0438\u044f",sr_Cyrl_ME:"\u0427\u0435\u0440\u043d\u043e\u0433\u043e\u0440\u0438\u044f",sr_Cyrl_RS:"\u0421\u0435\u0440\u0431\u0438\u044f",sr_Latn_BA:z,sr_Latn_CS:"Srbija i Crna Gora",sr_Latn_ME:"Crna Gora",sr_Latn_RS:"Srbija",sr_ME:"\u0426\u0440\u043d\u0430 \u0413\u043e\u0440\u0430",sr_RS:"\u0421\u0440\u0431\u0438\u0458\u0430",ss_SZ:Ub,ss_ZA:G,st_LS:"Lesotho",st_ZA:G,su_ID:kb,sv_AX:"\u00c5land",
|
96 |
-
sv_FI:"Finland",sv_SE:"Sverige",sw_KE:"Kenya",sw_TZ:Wb,sw_UG:"Uganda",swb_KM:Qd,syr_SY:"Syria",ta_IN:"\u0b87\u0ba8\u0bcd\u0ba4\u0bbf\u0baf\u0bbe",ta_LK:"\u0b87\u0bb2\u0b99\u0bcd\u0b95\u0bc8",ta_SG:"\u0b9a\u0bbf\u0b99\u0bcd\u0b95\u0baa\u0bcd\u0baa\u0bc2\u0bb0\u0bcd",te_IN:"\u0c2d\u0c3e\u0c30\u0c24 \u0c26\u0c47\u0c33\u0c02",tet_TL:Xb,tg_Cyrl_TJ:"\u0422\u0430\u0434\u0436\u0438\u043a\u0438\u0441\u0442\u0430\u043d",tg_TJ:"\u062a\u0627\u062c\u06a9\u0633\u062a\u0627\u0646",th_TH:"\u0e1b\u0e23\u0e30\u0e40\u0e17\u0e28\u0e44\u0e17\u0e22",
|
97 |
-
ti_ER:"\u12a4\u122d\u1275\u122b",ti_ET:X,tig_ER:"\u12a4\u122d\u1275\u122b",tk_TM:"\u062a\u0631\u06a9\u0645\u0646\u0633\u062a\u0627\u0646",tkl_TK:I,tn_BW:Ta,tn_ZA:G,to_TO:"Tonga",tpi_PG:E,tr_CY:"G\u00fcney K\u0131br\u0131s Rum Kesimi",tr_TR:K,ts_ZA:G,tt_RU:"\u0420\u043e\u0441\u0441\u0438\u044f",tvl_TV:J,ty_PF:Db,uk_UA:"\u0423\u043a\u0440\u0430\u0457\u043d\u0430",uli_FM:C,und_ZZ:cc,ur_IN:"\u0628\u06be\u0627\u0631\u062a",ur_PK:Rd,uz_AF:"Afganistan",uz_Arab_AF:Ld,uz_Cyrl_UZ:"\u0423\u0437\u0431\u0435\u043a\u0438\u0441\u0442\u0430\u043d",
|
98 |
-
uz_Latn_UZ:"O\u02bfzbekiston",uz_UZ:"\u040e\u0437\u0431\u0435\u043a\u0438\u0441\u0442\u043e\u043d",ve_ZA:G,vi_VN:"Vi\u1ec7t Nam",wal_ET:X,wo_Arab_SN:"\u0627\u0644\u0633\u0646\u063a\u0627\u0644",wo_Latn_SN:H,wo_SN:H,xh_ZA:G,yap_FM:C,yo_NG:D,zh_CN:"\u4e2d\u56fd",zh_HK:"\u9999\u6e2f",zh_Hans_CN:"\u4e2d\u56fd",zh_Hans_SG:"\u65b0\u52a0\u5761",zh_Hant_HK:"\u4e2d\u83ef\u4eba\u6c11\u5171\u548c\u570b\u9999\u6e2f\u7279\u5225\u884c\u653f\u5340",zh_Hant_MO:"\u6fb3\u9580",zh_Hant_TW:"\u81fa\u7063",zh_MO:"\u6fb3\u95e8",
|
99 |
-
zh_SG:"\u65b0\u52a0\u5761",zh_TW:"\u53f0\u6e7e",zu_ZA:G},LANGUAGE:{aa:"afar",ab:"\u0430\u0431\u0445\u0430\u0437\u0441\u043a\u0438\u0439",ace:"Aceh",ach:"Acoli",ada:"Adangme",ady:"\u0430\u0434\u044b\u0433\u0435\u0439\u0441\u043a\u0438\u0439",ae:"Avestan",af:"Afrikaans",afa:"Afro-Asiatic Language",afh:"Afrihili",ain:"Ainu",ak:"Akan",akk:"Akkadian",ale:"Aleut",alg:"Algonquian Language",alt:"Southern Altai",am:"\u12a0\u121b\u122d\u129b",an:"Aragonese",ang:"Old English",anp:"Angika",apa:"Apache Language",
|
100 |
-
ar:"\u0627\u0644\u0639\u0631\u0628\u064a\u0629",arc:"Aramaic",arn:"Araucanian",arp:"Arapaho",art:"Artificial Language",arw:"Arawak",as:"\u0985\u09b8\u09ae\u09c0\u09af\u09bc\u09be",ast:"asturiano",ath:"Athapascan Language",aus:"Australian Language",av:"\u0430\u0432\u0430\u0440\u0441\u043a\u0438\u0439",awa:"Awadhi",ay:"aimara",az:"az\u0259rbaycanca",az_Arab:"\u062a\u0631\u06a9\u06cc \u0622\u0630\u0631\u0628\u0627\u06cc\u062c\u0627\u0646\u06cc",az_Cyrl:"\u0410\u0437\u04d9\u0440\u0431\u0430\u0458\u04b9\u0430\u043d",
|
101 |
-
az_Latn:"Azerice",ba:"\u0431\u0430\u0448\u043a\u0438\u0440\u0441\u043a\u0438\u0439",bad:"Banda",bai:"Bamileke Language",bal:"\u0628\u0644\u0648\u0686\u06cc",ban:"Balin",bas:"Basa",bat:"Baltic Language",be:"\u0431\u0435\u043b\u0430\u0440\u0443\u0441\u043a\u0430\u044f",bej:"Beja",bem:"Bemba",ber:"Berber",bg:"\u0431\u044a\u043b\u0433\u0430\u0440\u0441\u043a\u0438",bh:"\u092c\u093f\u0939\u093e\u0930\u0940",bho:"Bhojpuri",bi:"bichelamar ; bislama",bik:"Bikol",bin:"Bini",bla:"Siksika",bm:"bambara",bn:"\u09ac\u09be\u0982\u09b2\u09be",
|
102 |
-
bnt:"Bantu",bo:"\u0f54\u0f7c\u0f51\u0f0b\u0f66\u0f90\u0f51\u0f0b",br:"breton",bra:"Braj",bs:"Bosanski",btk:"Batak",bua:"Buriat",bug:"Bugis",byn:"\u1265\u120a\u1295",ca:"catal\u00e0",cad:"Caddo",cai:"Central American Indian Language",car:"Carib",cau:"Caucasian Language",cch:"Atsam",ce:"\u0447\u0435\u0447\u0435\u043d\u0441\u043a\u0438\u0439",ceb:"Cebuano",cel:"Celtic Language",ch:"Chamorro",chb:"Chibcha",chg:"Chagatai",chk:"Chuukese",chm:"\u043c\u0430\u0440\u0438\u0439\u0441\u043a\u0438\u0439 (\u0447\u0435\u0440\u0435\u043c\u0438\u0441\u0441\u043a\u0438\u0439)",
|
103 |
-
chn:"Chinook Jargon",cho:"Choctaw",chp:"Chipewyan",chr:"Cherokee",chy:"Cheyenne",cmc:"Chamic Language",co:"corse",cop:"\u0642\u0628\u0637\u064a\u0629",cop_Arab:"\u0642\u0628\u0637\u064a\u0629",cpe:"English-based Creole or Pidgin",cpf:"French-based Creole or Pidgin",cpp:"Portuguese-based Creole or Pidgin",cr:"Cree",crh:"Crimean Turkish",crp:"Creole or Pidgin",cs:"\u010de\u0161tina",csb:"Kashubian",cu:"Church Slavic",cus:"Cushitic Language",cv:"\u0447\u0443\u0432\u0430\u0448\u0441\u043a\u0438\u0439",
|
104 |
-
cy:"Cymraeg",da:"dansk",dak:"Dakota",dar:"\u0434\u0430\u0440\u0433\u0432\u0430",day:"Dayak",de:"Deutsch",del:"Delaware",den:"Slave",dgr:"Dogrib",din:"Dinka",doi:"\u0627\u0644\u062f\u0648\u062c\u0631\u0649",dra:"Dravidian Language",dsb:"Lower Sorbian",dua:"Duala",dum:"Middle Dutch",dv:"Divehi",dyu:"dioula",dz:"\u0f62\u0fab\u0f7c\u0f44\u0f0b\u0f41",ee:"Ewe",efi:"Efik",egy:"Ancient Egyptian",eka:"Ekajuk",el:"\u0395\u03bb\u03bb\u03b7\u03bd\u03b9\u03ba\u03ac",elx:"Elamite",en:"English",enm:"Middle English",
|
105 |
-
eo:"esperanto",es:"espa\u00f1ol",et:"eesti",eu:"euskara",ewo:"Ewondo",fa:"\u0641\u0627\u0631\u0633\u06cc",fan:"fang",fat:"Fanti",ff:"Fulah",fi:"suomi",fil:"Filipino",fiu:"Finno-Ugrian Language",fj:"Fijian",fo:"f\u00f8royskt",fon:"Fon",fr:"fran\u00e7ais",frm:"Middle French",fro:"Old French",frr:"Northern Frisian",frs:"Eastern Frisian",fur:"friulano",fy:"Fries",ga:"Gaeilge",gaa:"Ga",gay:"Gayo",gba:"Gbaya",gd:"Scottish Gaelic",gem:"Germanic Language",gez:"\u130d\u12d5\u12dd\u129b",gil:"Gilbertese",gl:"galego",
|
106 |
-
gmh:"Middle High German",gn:"guaran\u00ed",goh:"Old High German",gon:"Gondi",gor:"Gorontalo",got:"Gothic",grb:"Grebo",grc:"\u0391\u03c1\u03c7\u03b1\u03af\u03b1 \u0395\u03bb\u03bb\u03b7\u03bd\u03b9\u03ba\u03ac",gsw:"Schweizerdeutsch",gu:"\u0a97\u0ac1\u0a9c\u0ab0\u0abe\u0aa4\u0ac0",gv:"Gaelg",gwi:"Gwich\u02bcin",ha:"\u0627\u0644\u0647\u0648\u0633\u0627",ha_Arab:"\u0627\u0644\u0647\u0648\u0633\u0627",ha_Latn:"haoussa",hai:"Haida",haw:"\u02bb\u014dlelo Hawai\u02bbi",he:"\u05e2\u05d1\u05e8\u05d9\u05ea",
|
107 |
-
hi:"\u0939\u093f\u0902\u0926\u0940",hil:"Hiligaynon",him:"Himachali",hit:"Hittite",hmn:"Hmong",ho:"Hiri Motu",hr:"hrvatski",hsb:"Upper Sorbian",ht:"ha\u00eftien",hu:"magyar",hup:"Hupa",hy:"\u0540\u0561\u0575\u0565\u0580\u0567\u0576",hz:"Herero",ia:"interlingvao",iba:"Iban",id:"Bahasa Indonesia",ie:"Interlingue",ig:"Igbo",ii:"\ua188\ua320\ua259",ijo:"Ijo",ik:"Inupiaq",ilo:"Iloko",inc:"Indic Language",ine:"Indo-European Language",inh:"\u0438\u043d\u0433\u0443\u0448\u0441\u043a\u0438\u0439",io:"Ido",
|
108 |
-
ira:"Iranian Language",iro:"Iroquoian Language",is:"\u00edslenska",it:"italiano",iu:"Inuktitut",ja:"\u65e5\u672c\u8a9e",jbo:"Lojban",jpr:"Judeo-Persian",jrb:"Judeo-Arabic",jv:"Jawa",ka:"\u10e5\u10d0\u10e0\u10d7\u10e3\u10da\u10d8",kaa:"\u043a\u0430\u0440\u0430\u043a\u0430\u043b\u043f\u0430\u043a\u0441\u043a\u0438\u0439",kab:"kabyle",kac:"Kachin",kaj:"Jju",kam:"Kamba",kar:"Karen",kaw:"Kawi",kbd:"\u043a\u0430\u0431\u0430\u0440\u0434\u0438\u043d\u0441\u043a\u0438\u0439",kcg:"Tyap",kfo:"koro",kg:"Kongo",
|
109 |
-
kha:"Khasi",khi:"Khoisan Language",kho:"Khotanese",ki:"Kikuyu",kj:"Kuanyama",kk:"\u049a\u0430\u0437\u0430\u049b",kl:"kalaallisut",km:"\u1797\u17b6\u179f\u17b6\u1781\u17d2\u1798\u17c2\u179a",kmb:"quimbundo",kn:"\u0c95\u0ca8\u0ccd\u0ca8\u0ca1",ko:"\ud55c\uad6d\uc5b4",kok:"\u0915\u094b\u0902\u0915\u0923\u0940",kos:"Kosraean",kpe:"kpell\u00e9",kr:"Kanuri",krc:"\u043a\u0430\u0440\u0430\u0447\u0430\u0435\u0432\u043e-\u0431\u0430\u043b\u043a\u0430\u0440\u0441\u043a\u0438\u0439",krl:"\u043a\u0430\u0440\u0435\u043b\u044c\u0441\u043a\u0438\u0439",
|
110 |
-
kro:"Kru",kru:"Kurukh",ks:"\u0915\u093e\u0936\u094d\u092e\u093f\u0930\u0940",ku:"K\u00fcrt\u00e7e",ku_Arab:"\u0627\u0644\u0643\u0631\u062f\u064a\u0629",ku_Latn:"K\u00fcrt\u00e7e",kum:"\u043a\u0443\u043c\u044b\u043a\u0441\u043a\u0438\u0439",kut:"Kutenai",kv:"Komi",kw:"kernewek",ky:"K\u0131rg\u0131zca",ky_Arab:"\u0627\u0644\u0642\u064a\u0631\u063a\u0633\u062a\u0627\u0646\u064a\u0629",ky_Cyrl:"\u043a\u0438\u0440\u0433\u0438\u0437\u0441\u043a\u0438\u0439",la:"latino",lad:"\u05dc\u05d3\u05d9\u05e0\u05d5",
|
111 |
-
lah:"\u0644\u0627\u0647\u0646\u062f\u0627",lam:"Lamba",lb:"luxembourgeois",lez:"\u043b\u0435\u0437\u0433\u0438\u043d\u0441\u043a\u0438\u0439",lg:"Ganda",li:"Limburgs",ln:"lingala",lo:"Lao",lol:"mongo",loz:"Lozi",lt:"lietuvi\u0173",lu:"luba-katanga",lua:"luba-lulua",lui:"Luiseno",lun:"Lunda",luo:"Luo",lus:"Lushai",lv:"latvie\u0161u",mad:"Madura",mag:"Magahi",mai:"Maithili",mak:"Makassar",man:"Mandingo",map:"Austronesian",mas:"Masai",mdf:"\u043c\u043e\u043a\u0448\u0430",mdr:"Mandar",men:"Mende",mg:"malgache",
|
112 |
-
mga:"Middle Irish",mh:"Marshallese",mi:"Maori",mic:"Micmac",min:"Minangkabau",mis:"Miscellaneous Language",mk:"\u043c\u0430\u043a\u0435\u0434\u043e\u043d\u0441\u043a\u0438",mkh:"Mon-Khmer Language",ml:"\u0d2e\u0d32\u0d2f\u0d3e\u0d33\u0d02",mn:Jd,mn_Cyrl:Jd,mn_Mong:Jd,mnc:"Manchu",mni:"Manipuri",mno:"Manobo Language",mo:"Moldavian",moh:"Mohawk",mos:"mor\u00e9 ; mossi",mr:"\u092e\u0930\u093e\u0920\u0940",ms:"Bahasa Melayu",mt:"Malti",mul:"Multiple Languages",mun:"Munda Language",mus:"Creek",mwl:"Mirandese",
|
113 |
-
mwr:"Marwari",my:"Burmese",myn:"Mayan Language",myv:"\u044d\u0440\u0437\u044f",na:"Nauru",nah:"Nahuatl",nai:"North American Indian Language",nap:"napoletano",nb:"norsk bokm\u00e5l",nd:"North Ndebele",nds:"Low German",ne:"\u0928\u0947\u092a\u093e\u0932\u0940","new":"Newari",ng:"Ndonga",nia:"Nias",nic:"Niger-Kordofanian Language",niu:"Niuean",nl:"Nederlands",nn:"nynorsk",no:"Norwegian",nog:"\u043d\u043e\u0433\u0430\u0439\u0441\u043a\u0438\u0439",non:"Old Norse",nqo:"N\u2019Ko",nr:"South Ndebele",nso:"Northern Sotho",
|
114 |
-
nub:"Nubian Language",nv:"Navajo",nwc:"Classical Newari",ny:"nianja; chicheua; cheua",nym:"Nyamwezi",nyn:"Nyankole",nyo:"Nyoro",nzi:"Nzima",oc:"occitan",oj:"Ojibwa",om:"Oromoo",or:"\u0b13\u0b21\u0b3c\u0b3f\u0b06",os:"\u043e\u0441\u0435\u0442\u0438\u043d\u0441\u043a\u0438\u0439",osa:"Osage",ota:"Ottoman Turkish",oto:"Otomian Language",pa:"\u0a2a\u0a70\u0a1c\u0a3e\u0a2c\u0a40",pa_Arab:"\u067e\u0646\u062c\u0627\u0628",pa_Guru:"\u0a2a\u0a70\u0a1c\u0a3e\u0a2c\u0a40",paa:"Papuan Language",pag:"Pangasinan",
|
115 |
-
pal:"Pahlavi",pam:"Pampanga",pap:"Papiamento",pau:"Palauan",peo:"Old Persian",phi:"Philippine Language",phn:"Phoenician",pi:"\u0e1a\u0e32\u0e25\u0e35",pl:"polski",pon:"Pohnpeian",pra:"Prakrit Language",pro:"Old Proven\u00e7al",ps:"\u067e\u069a\u062a\u0648",pt:"portugu\u00eas",qu:"quechua",raj:"Rajasthani",rap:"Rapanui",rar:"Rarotongan",rm:"R\u00e4toromanisch",rn:"roundi",ro:"rom\u00e2n\u0103",roa:"Romance Language",rom:"Romany",ru:"\u0440\u0443\u0441\u0441\u043a\u0438\u0439",rup:"Aromanian",rw:"rwanda",
|
116 |
-
sa:"\u0938\u0902\u0938\u094d\u0915\u0943\u0924 \u092d\u093e\u0937\u093e",sad:"Sandawe",sah:"\u044f\u043a\u0443\u0442\u0441\u043a\u0438\u0439",sai:"South American Indian Language",sal:"Salishan Language",sam:"\u05d0\u05e8\u05de\u05d9\u05ea \u05e9\u05d5\u05de\u05e8\u05d5\u05e0\u05d9\u05ea",sas:"Sasak",sat:"Santali",sc:"Sardinian",scn:"siciliano",sco:"Scots",sd:"\u0938\u093f\u0928\u094d\u0927\u0940",sd_Arab:"\u0633\u0646\u062f\u06cc",sd_Deva:"\u0938\u093f\u0928\u094d\u0927\u0940",se:"nordsamiska",sel:"\u0441\u0435\u043b\u044c\u043a\u0443\u043f\u0441\u043a\u0438\u0439",
|
117 |
-
sem:"Semitic Language",sg:"sangho",sga:"Old Irish",sgn:"Sign Language",sh:"Serbo-Croatian",shn:"Shan",si:"Sinhalese",sid:"Sidamo",sio:"Siouan Language",sit:"Sino-Tibetan Language",sk:"slovensk\u00fd",sl:"sloven\u0161\u010dina",sla:"Slavic Language",sm:"Samoan",sma:"sydsamiska",smi:"Sami Language",smj:"lulesamiska",smn:"Inari Sami",sms:"Skolt Sami",sn:"Shona",snk:"sonink\u00e9",so:"Soomaali",sog:"Sogdien",son:"Songhai",sq:"shqipe",sr:"\u0421\u0440\u043f\u0441\u043a\u0438",sr_Cyrl:"\u0441\u0435\u0440\u0431\u0441\u043a\u0438\u0439",
|
118 |
-
sr_Latn:"Srpski",srn:"Sranantongo",srr:"s\u00e9r\u00e8re",ss:"Swati",ssa:"Nilo-Saharan Language",st:"Sesotho",su:"Sundan",suk:"Sukuma",sus:"soussou",sux:"Sumerian",sv:"svenska",sw:"Kiswahili",syc:"Classical Syriac",syr:"Syriac",ta:"\u0ba4\u0bae\u0bbf\u0bb4\u0bcd",tai:"Tai Language",te:"\u0c24\u0c46\u0c32\u0c41\u0c17\u0c41",tem:"Timne",ter:"Tereno",tet:"t\u00e9tum",tg:"\u062a\u0627\u062c\u06a9",tg_Arab:"\u062a\u0627\u062c\u06a9",tg_Cyrl:"\u0442\u0430\u0434\u0436\u0438\u043a\u0441\u043a\u0438\u0439",
|
119 |
-
th:"\u0e44\u0e17\u0e22",ti:"\u1275\u130d\u122d\u129b",tig:"\u1275\u130d\u1228",tiv:"Tiv",tk:"\u062a\u0631\u06a9\u0645\u0646\u06cc",tkl:I,tl:"Tagalog",tlh:"Klingon",tli:"Tlingit",tmh:"tamacheq",tn:"Tswana",to:"Tonga",tog:"Nyasa Tonga",tpi:"Tok Pisin",tr:"T\u00fcrk\u00e7e",ts:"Tsonga",tsi:"Tsimshian",tt:"\u0442\u0430\u0442\u0430\u0440\u0441\u043a\u0438\u0439",tum:"Tumbuka",tup:"Tupi Language",tut:"\u0430\u043b\u0442\u0430\u0439\u0441\u043a\u0438\u0435 (\u0434\u0440\u0443\u0433\u0438\u0435)",tvl:J,tw:"Twi",
|
120 |
-
ty:"tahitien",tyv:"\u0442\u0443\u0432\u0438\u043d\u0441\u043a\u0438\u0439",udm:"\u0443\u0434\u043c\u0443\u0440\u0442\u0441\u043a\u0438\u0439",ug:"\u0443\u0439\u0433\u0443\u0440\u0441\u043a\u0438\u0439",uga:"Ugaritic",uk:"\u0443\u043a\u0440\u0430\u0457\u043d\u0441\u044c\u043a\u0430",umb:"umbundu",und:"English",ur:"\u0627\u0631\u062f\u0648",uz:"\u040e\u0437\u0431\u0435\u043a",uz_Arab:"\u0627\u06c9\u0632\u0628\u06d0\u06a9",uz_Cyrl:"\u0443\u0437\u0431\u0435\u043a\u0441\u043a\u0438\u0439",uz_Latn:"o'zbekcha",
|
121 |
-
vai:"Vai",ve:"Venda",vi:"Ti\u1ebfng Vi\u1ec7t",vo:"volapuko",vot:"Votic",wa:"Wallonisch",wak:"Wakashan Language",wal:"Walamo",war:"Waray",was:"Washo",wen:"Sorbian Language",wo:"wolof",wo_Arab:"\u0627\u0644\u0648\u0644\u0648\u0641",wo_Latn:"wolof",xal:"\u043a\u0430\u043b\u043c\u044b\u0446\u043a\u0438\u0439",xh:"Xhosa",yao:"iao",yap:"Yapese",yi:"\u05d9\u05d9\u05d3\u05d9\u05e9",yo:"Yoruba",ypk:"Yupik Language",za:"Zhuang",zap:"Zapotec",zen:"Zenaga",zh:"\u4e2d\u6587",zh_Hans:"\u4e2d\u6587",zh_Hant:"\u4e2d\u6587",
|
122 |
-
znd:"Zande",zu:"Zulu",zun:"Zuni",zxx:"No linguistic content",zza:"Zaza"}};Z.locale.Yf=function(a){a=a.replace(/-/g,M);Z.locale.N=a};Z.locale.Fa=function(){Z.locale.N||(Z.locale.N=yc);return Z.locale.N};Z.locale.I={vd:"DateTimeConstants",Ed:"NumberFormatConstants",gc:"TimeZoneConstants",Wb:rb,hc:"TimeZoneSelectedIds",jc:"TimeZoneSelectedShortNames",ic:"TimeZoneSelectedLongNames",fc:"TimeZoneAllLongNames"};Z.locale.Ea=function(a){return(a=a.match(/^\w{2,3}([-_]|$)/))?a[0].replace(/[_-]/g,b):b};
|
123 |
-
Z.locale.mb=function(a){return(a=a.match(/[-_]([a-zA-Z]{2}|\d{3})([-_]|$)/))?a[0].replace(/[_-]/g,b):b};Z.locale.Pe=function(a){a=a.split(/[-_]/g);return 1<a.length&&a[1].match(/^[a-zA-Z]{4}$/)?a[1]:b};Z.locale.Qe=function(a){return(a=a.match(/[-_]([a-z]{2,})/))?a[1]:b};Z.locale.Le=function(a){var c=Z.locale.Ea(a)+M+Z.locale.mb(a);return c in Z.locale.J.COUNTRY?Z.locale.J.COUNTRY[c]:a};Z.locale.He=function(a,c){c||(c=Z.locale.ob());var d=Z.locale.mb(a);return d in c.COUNTRY?c.COUNTRY[d]:a};
|
124 |
-
Z.locale.Me=function(a){if(a in Z.locale.J.LANGUAGE)return Z.locale.J.LANGUAGE[a];var c=Z.locale.Ea(a);return c in Z.locale.J.LANGUAGE?Z.locale.J.LANGUAGE[c]:a};Z.locale.Ie=function(a,c){c||(c=Z.locale.ob());if(a in c.LANGUAGE)return c.LANGUAGE[a];var d=Z.locale.Ea(a);return d in c.LANGUAGE?c.LANGUAGE[d]:a};Z.locale.K=function(a,c,d){Z.locale.l[c]||(Z.locale.l[c]={});Z.locale.l[c][d]=a;Z.locale.N||(Z.locale.N=d)};Z.locale.jf=function(a,c){return a in Z.locale.l&&c in Z.locale.l[a]};Z.locale.l={};
|
125 |
-
Z.locale.Kf=function(a,c){Z.locale.K(a,Z.locale.I.gc,c)};Z.locale.If=function(a,c){Z.locale.K(a,Z.locale.I.Wb,c)};Z.locale.Lf=function(a,c){Z.locale.K(a,Z.locale.I.hc,c)};Z.locale.Nf=function(a,c){Z.locale.K(a,Z.locale.I.jc,c)};Z.locale.Mf=function(a,c){Z.locale.K(a,Z.locale.I.ic,c)};Z.locale.Jf=function(a,c){Z.locale.K(a,Z.locale.I.fc,c)};Z.locale.ob=function(){var a=Z.locale.Fa(),a=a?a:Z.locale.Fa();return rb in Z.locale.l?Z.locale.l.LocaleNameConstants[a]:void 0};
|
126 |
-
Z.locale.Oe=function(a,c){var d=c?c:Z.locale.Fa();if(a in Z.locale.l){if(d in Z.locale.l[a])return Z.locale.l[a][d];d=d.split(M);return 1<d.length&&d[0]in Z.locale.l[a]?Z.locale.l[a][d[0]]:Z.locale.l[a].en}};var google={a:{}};google.a.b={};
|
127 |
-
google.a.b.languages={af:!0,am:!0,az:!0,ar:!0,arb:"ar",bg:!0,bn:!0,ca:!0,cs:!0,cmn:"zh",da:!0,de:!0,el:!0,en:!0,en_gb:!0,es:!0,es_419:!0,et:!0,eu:!0,fa:!0,fi:!0,fil:!0,fr:!0,fr_ca:!0,gl:!0,ka:!0,gu:!0,he:"iw",hi:!0,hr:!0,hu:!0,hy:!0,id:!0,"in":Oc,is:!0,it:!0,iw:!0,ja:!0,ji:"yi",jv:!1,jw:"jv",km:!0,kn:!0,ko:!0,lo:!0,lt:!0,lv:!0,ml:!0,mn:!0,mo:"ro",mr:!0,ms:!0,nb:"no",ne:!0,nl:!0,no:!0,pl:!0,pt:"pt_br",pt_br:!0,pt_pt:!0,ro:!0,ru:!0,si:!0,sk:!0,sl:!0,sr:!0,sv:!0,sw:!0,swh:"sw",ta:!0,te:!0,th:!0,tl:"fil",
|
128 |
-
tr:!0,uk:!0,ur:!0,vi:!0,yi:!1,zh:"zh_cn",zh_cn:!0,zh_hk:!0,zh_tw:!0,zsm:"ms",zu:!0};google.a.b.S={};google.a.b.T=od;google.a.b.log=Y();google.a.b.error=Y();google.a.b.Z=!1;google.a.b.O=window;google.a.b.ld={current:"44",upcoming:"44",41:U,42:U,43:U,44:U};google.a.b.Ua={gstatic:{prefix:"https://www.gstatic.com/charts",debug:"{prefix}/debug/{version}/jsapi_debug_{package}_module.js",compiled:"{prefix}/{version}/js/jsapi_compiled_{package}_module.js",i18n:"{prefix}/{version}/i18n/jsapi_compiled_i18n_{package}_module__{language}.js",css:zd,css_debug:zd,third_party:Ad,third_party_gen:Ad}};
|
129 |
-
google.a.b.m=google.a.b.Ua.gstatic;
|
130 |
-
google.a.b.zc={"default":[],format:[],ui:["format","default"],ui_base:["format","default"],annotatedtimeline:[V],annotationchart:[V,"controls",uc,"table"],areachart:[V,O],bar:[V,Q,td],barchart:[V,O],browserchart:[V],calendar:[V],charteditor:[V,uc,S,oc,"gauge","motionchart","orgchart","table"],charteditor_base:[nd,uc,S,oc,"gauge","motionchart","orgchart","table_base"],columnchart:[V,O],controls:[V],controls_base:[nd],corechart:[V],gantt:[V,Q],gauge:[V],geochart:[V],geomap:[V],geomap_base:[nd],helloworld:[V],
|
131 |
-
imageareachart:[V,S],imagebarchart:[V,S],imagelinechart:[V,S],imagechart:[V],imagepiechart:[V,S],imagesparkline:[V,S],intensitymap:[V],line:[V,Q,td],linechart:[V,O],map:[V],motionchart:[V],orgchart:[V],overtimecharts:[V,uc],piechart:[V,O],sankey:["d3","d3.sankey",V],scatter:[V,Q,td],scatterchart:[V,O],table:[V],table_base:[nd],timeline:[V,Q],treemap:[V],wordtree:[V]};google.a.b.ed={d3:"d3/d3.js","d3.sankey":"d3/d3.sankey.js",webfontloader:"webfontloader/webfont.js"};google.a.b.Eb={dygraph:"dygraphs/dygraph-tickers-combined.js"};
|
132 |
-
google.a.b.wc={annotatedtimeline:"/annotatedtimeline/annotatedtimeline.css",annotationchart:"annotationchart/annotationchart.css",charteditor:"charteditor/charteditor.css",charteditor_base:"charteditor/charteditor_base.css",controls:"controls/controls.css",imagesparkline:"imagesparkline/imagesparkline.css",intensitymap:"intensitymap/intensitymap.css",orgchart:"orgchart/orgchart.css",table:"table/table.css",table_base:"table/table_base.css",ui:["util/util.css","core/tooltip.css"],ui_base:"util/util_base.css"};
|
133 |
-
google.a.b.va=function(a,c){for(var d=c||{},e=[],f=0;f<a.length;f++){var g=a[f];if(!d[g]){d[g]=!0;var h=google.a.b.zc[g]||[];0<h.length&&(e=e.concat(google.a.b.va(h,d)));e.push(g)}}return e};google.a.b.Ec=function(a){for(var c={},d=[],e=0;e<a.length;e++){var f=google.a.b.wc[a[e]];Z.isArray(f)||(f=[f]);for(var g=0;g<f.length;g++){var h=f[g];h&&!c[h]&&(c[h]=!0,d.push(h))}}return d};
|
134 |
-
google.a.b.$c=function(a,c){if(c)if("undefined"===typeof a.onload){var d=!1;a.onreadystatechange=function(){d||(a.readyState&&a.readyState!==P?google.a.b.O.setTimeout(a.onreadystatechange,0):(d=!0,delete a.onreadystatechange,google.a.b.O.setTimeout(c,0)))}}else a.onload=c};
|
135 |
-
google.a.b.Ab=function(a,c,d){google.a.b.log(Vc+a);var e=c.createElement(gd);e.type=ld;e.language=Qc;e.async=!1;e.defer=!1;c=c.body||c.head||c.getElementsByTagName(ib).item(0)||c.documentElement;c.insertBefore(e,c.lastChild);d&&google.a.b.$c(e,d);e.src=a;google.a.b.log(zc+a)};
|
136 |
-
google.a.b.Qc=function(a,c){function d(c){var e=google.a.b.sb,f=a[c++];if(f){var g=f,h=google.a.b.ed[f];h?(g=h,f===td&&(e=window.document),f=google.a.b.m.third_party):google.a.b.Eb[f]?(g=google.a.b.Eb[f],f=google.a.b.m.third_party_gen):f=google.a.b.Z?n:t?Oa:p;g=f.replace(yd,m).replace(Bd,A).replace(wd,t).replace(xd,g);google.a.b.Ab(g,e);d(c)}}function e(){for(var d=[],e=0;e<a.length;e++)d.push(Sb[a[e]]);eval(Ea+d.join(b)+Dd)();google.a.b.O.setTimeout(c,0)}a=google.a.b.va(a);for(var f=[],g=0;g<a.length;g++){var h=
|
137 |
-
a[g];google.a.b.S[h]||f.push(h)}a=f;google.a.b.log(pb+a);var m=google.a.b.m.prefix,n=google.a.b.m.debug,p=google.a.b.m.compiled,Oa=google.a.b.m.i18n,A=google.a.b.T,t=google.a.b.Ma;t===yc&&(t=null);var Sb={},Tb=a.length;google.a.b.Vc=function(a,c){google.a.b.log(sc+a);Sb[a]=c;google.a.b.S[a]=!0;Tb--;0===Tb&&e()};d(0)};
|
138 |
-
google.a.b.W=function(a){function c(){g=!0;for(var a=e.length,c=0;c<a;c++)e[c]()}function d(){h=!0;for(var a=f.length,c=0;c<a;c++)f[c]()}var e=[],f=[],g=!1,h=!1;google.a.b.W.count||(google.a.b.W.count=0);var m=Tc+google.a.b.W.count++,n={done:function(a){e.push(a);g&&a();return n},Ca:function(a){f.push(a);h&&a();return n}},p=document.createElement(Rc);p.setAttribute(Oc,m);p.setAttribute(ed,jd);p.setAttribute(md,kd);"undefined"!==typeof p.addEventListener?(p.addEventListener(Sc,c,!1),p.addEventListener(Ac,
|
139 |
-
d,!1)):"undefined"!==typeof p.attachEvent&&p.attachEvent(cd,function(){var a,e=document.styleSheets.length;try{for(;e--;)if(a=document.styleSheets[e],a.id===m){c();return}}catch(f){}g||d()});document.getElementsByTagName(Mc)[0].appendChild(p);p.setAttribute(Nc,a);return n};google.a.b.Nc=function(a,c){google.a.b.log(Uc+a);google.a.b.W(a).done(c).Ca(function(){google.a.b.error(Wc+a)})};
|
140 |
-
google.a.b.Oc=function(a,c){a=google.a.b.va(a);var d=google.a.b.Ec(a);if(null===d||0===d.length)c();else{google.a.b.log(qb+d.join(ya));var e=google.a.b.m.prefix,f=google.a.b.m.css;google.a.b.Z&&(f=google.a.b.m.css_debug||f);var g=google.a.b.T,h=function(a){var n=d[a],p;p=a<d.length-1?function(){h(a+1)}:c;google.a.b.S[n]?(google.a.b.log(Na+n),google.a.b.O.setTimeout(p,0)):(google.a.b.S[n]=!0,n=f.replace(yd,e).replace(Bd,g).replace(vd,n),google.a.b.Nc(n,p))};h(0)}};
|
141 |
-
google.a.b.Ee=function(){var a=google.a.b.C;if(!a){a=google.a.b.C=document.createElement(Pc);google.a.b.C=a;a.name=Jc;(document.body||document.head||document).appendChild(a);a.style.display=Zc;var c=google.a.b.sb=a.contentDocument?a.contentDocument:a.contentWindow?a.contentWindow.document:a.document;c.open();c.writeln(b);c.close()}return a};
|
142 |
-
google.a.b.Cb=function(a){for(var c=a.replace(/-/g,M).toLowerCase();Z.h(c);)a=c,c=google.a.b.languages[c],c===a&&(c=!1);c||(a.match(/_[^_]+$/)?(a=a.replace(/_[^_]+$/,b),a=google.a.b.Cb(a)):a=yc);return a};
|
143 |
-
google.a.b.Yc=function(a,c){c.log&&(google.a.b.log=c.log);c.error&&(google.a.b.error=c.error);var d=c.debug,e=c.language||b,e=google.a.b.Cb(e);a||(a=c.version||od);(google.a.b.T&&google.a.b.T!==a||google.a.b.Ma&&google.a.b.Ma!==e||google.a.b.Z!==d)&&google.a.b.C&&google.a.b.C.parentNode&&(google.a.b.C.parentNode.removeChild(google.a.b.C),google.a.b.C=null,google.a.b.S={});google.a.b.T=a;google.a.b.Ma=e;google.a.b.Z=d};google.a.b.R=!1;google.a.b.ma=!1;google.a.b.loaded=!1;google.a.b.Da=[];
|
144 |
-
google.a.b.load=function(a,c,d){var e;e=a.match(/^(testing\/)?(.*)/);var f=e[1]||b;for(a=e[2];;){e=google.a.b.ld[a];if(null==e||e===U)break;a=e}google.a.b.m=d||google.a.b.Ua[a]||google.a.b.Ua.gstatic;a=f+a;if(null==e)f=function(){Z.kb()(a,c,d)},google.a.b.R?google.a.b.M(f):(google.a.b.R=!0,google.a.b.Ab(google.a.b.m.prefix+u+a+Da,window.document,f));else{if(google.a.b.R)throw Error("google.charts.load() cannot be called more than once with version 44 or earlier.");google.a.b.R=!0;if(google.a.b.ma)google.a.b.M(function(){google.a.b.load(a,
|
145 |
-
c)});else{google.a.b.loaded=!1;google.a.b.ma=!0;google.a.b.Yc(a,c);google.a.b.log(Kc+a);window.google=window.google||{};google.visualization=google.visualization||{};google.visualization.ModulePath=google.a.b.m.prefix;google.a.b.C=null;google.a.b.O=window;google.a.b.sb=document;var g=function(){google.a.b.ma=!1;google.a.b.loaded=!0;google.a.b.Na()},h=c.packages;google.a.b.M(c.callback);google.a.b.Oc(h,function(){google.a.b.Qc(h,g)})}}};
|
146 |
-
google.a.b.M=function(a){a&&google.a.b.Da.push(a);google.a.b.loaded&&!google.a.b.ma&&google.a.b.Na()};google.a.b.ad=function(a){if(window.addEventListener)window.addEventListener(Sc,a,!1);else if(window.attachEvent)window.attachEvent(cd,a);else{var c=window.onload;window.onload=function(d){c&&c(d);a()}}};google.a.b.Ib=document&&document.readyState===P;google.a.b.ad(function(){google.a.b.Ib=!0;google.a.b.Na()});
|
147 |
google.a.b.Na=function(){if(google.a.b.R&&google.a.b.loaded&&(google.a.b.Ib||document.readyState===P))for(;0<google.a.b.Da.length;)google.a.b.Da.shift()()};google.a.b.Qa=function(a,c){google.a.b.Vc(a,c)};if(Z.kb())throw Error("Google Charts loader.js can only be loaded once.");google.a.load=function(a,c,d){a===sd&&(a=c,c=d);google.a.b.load(String(a),c||{})};google.a.M=function(a){google.a.b.M(a)};google.a.Qa=function(a,c){google.a.b.Qa(a,c)};Z.Ba(Jc,google.a.load);Z.Ba("google.charts.setOnLoadCallback",google.a.M);Z.Ba("google.charts.packageLoadedCallback",google.a.Qa); })();
|
1 |
+
(function (){ var b="",aa="\x00",ba="\n",ca="\n//# sourceURL=",da="\n;return exports});\n//# sourceURL=",k=" ",ea="  ",fa=" onreadystatechange='goog.onScriptLoad_(this, ",ga=" should not be enumerable in Object.prototype.",l='"',ha='");',ia='">\x3c/script>',ja="#",ka="$1",la="%s",q="&",ma="�",na="e",oa="'",pa="&",qa=">",ra="<",sa=""",ta="'",ua="(^",va=")' ",wa=")([a-z])",xa=");",ya=", ",za="-",Aa="-$1",r=".",Ba="..",Ca="...",u="/",Da="/loader.js",v="0",Ea="0,(function(){",w=": ",
|
2 |
+
x="<",Fa="\x3c/script>",Ga="<br />",Ha="<br>",Ia='<script type="text/javascript" src="',Ja='<script type="text/javascript">',Ka=">",La=">\x3c/script>",Ma="?",Na="Already loaded ",Pa="American Samoa",Qa="Antigua and Barbuda",Ra="Assertion failed",Sa="BY_WHOLE",y="Bolivia",z="Bosna i Hercegovina",Ta="Botswana",Ua="British Virgin Islands",Va="Cayman Islands",Wa="Christmas Island",Xa="Expected Element but got %s: %s.",Ya="Expected array but got %s: %s.",Za="Expected boolean but got %s: %s.",$a="Expected function but got %s: %s.",
|
3 |
+
ab="Expected instanceof %s but got %s.",bb="Expected number but got %s: %s.",cb="Expected object but got %s: %s.",db="Expected string but got %s: %s.",eb="Failure",fb="Falkland Islands",B="Ghana",gb="Guin\u00e9e \u00e9quatoriale",hb="Guyane fran\u00e7aise",ib="HEAD",jb="Honduras",kb="Indonesia",lb="Itoophiyaa",mb="JavaScript",nb="Kalaallit Nunaat",ob="Kiribati",pb="Load packages + dependencies - previous: ",qb="Loading css files: ",rb="LocaleNameConstants",sb="Luxembourg",tb="Madagascar",ub="Marshall Islands",
|
4 |
+
C="Micronesia",vb="Moldova, Republica",wb="Nederlandse Antillen",xb="New Zealand",D="Nigeria",yb="Norfolk Island",zb="Northern Mariana Islands",Ab="Nouvelle-Cal\u00e9donie",E="Papua New Guinea",Bb="Paraguay",Cb="Philippines",Db="Polyn\u00e9sie fran\u00e7aise",Eb="Puerto Rico",Fb="Rep\u00fablica Dominicana",F="Rwanda",Gb="Rywvaneth Unys",Hb="R\u00e9publique centrafricaine",Ib="R\u00e9publique d\u00e9mocratique du Congo",Jb="SCRIPT",Kb="Saint Kitts and Nevis",Lb="Saint Vincent and the Grenadines",Mb=
|
5 |
+
"Saint-Pierre-et-Miquelon",Nb="Serbia and Montenegro",Ob="Seychelles",Pb="Slovensk\u00e1 republika",Qb="Solomon Islands",G="South Africa",Rb="Svalbard og Jan Mayen",Ub="Swaziland",Vb="S\u00e3o Tom\u00e9 e Pr\u00edncipe",H="S\u00e9n\u00e9gal",Wb="Tanzania",Xb="Timor Leste",I="Tokelau",Yb="Turks and Caicos Islands",J="Tuvalu",K="T\u00fcrkiye",Zb="U.S. Virgin Islands",$b="United Kingdom",ac="United States",bc="United States Minor Outlying Islands",cc="Unknown or Invalid Region",L="Vanuatu",dc="Wallis-et-Futuna",
|
6 |
+
ec="[object Array]",fc="[object Function]",gc="[object Window]",hc="\\$1",ic="\\s",jc="\\u",kc="\\x",lc="\\x08",mc="]+",M="_",nc="amp",oc="annotatedtimeline",N="array",pc="base.js",qc="boolean",O="browserchart",rc="call",sc="callback after loading ",tc="charts",P="complete",uc="corechart",vc="div",wc="document",Q="dygraph",xc="e",yc="en",zc="end loadScript: ",Ac="error",R="function",Bc="g",Cc="get",Dc="goog",Ec="goog.loadModule(",Fc='goog.loadModule(function(exports) {"use strict";',Gc='goog.retrieveAndExecModule_("',
|
7 |
+
Hc="goog_",Ic="google",Jc="google.charts.load",Kc="google.charts.load version ",Lc="gt",Mc="head",Nc="href",Oc="id",Pc="iframe",S="imagechart",Qc="javascript",Rc="link",Sc="load",Tc="load-css-",Uc="loadCSSFile: ",Vc="loadScript: ",Wc="loading css failed: ",Xc="lt",Yc="native code",Zc="none",$c="null",ad="number",bd="o",T="object",cd="onload",dd="quot",ed="rel",fd="removeAttribute",gd="script",hd="splice",id="string",jd="stylesheet",kd="text/css",ld="text/javascript",U="top",md="type",V="ui",nd="ui_base",
|
8 |
+
od="unknown",pd="unknown type name",qd="var ",rd="var _evalTest_ = 1;",sd="visualization",td="webfontloader",ud="write",vd="{cssFile}",wd="{language}",xd="{package}",yd="{prefix}",zd="{prefix}/{version}/css/{cssFile}",Ad="{prefix}/{version}/third_party/{package}",Bd="{version}",Cd="|[",Dd="})",Ed="~",Fd="\u0080",Gd="\u010cesk\u00e1 republika",Hd="\u0411\u0435\u043b\u0430\u0440\u0443\u0441\u044c",Id="\u041a\u044b\u0440\u0433\u044b\u0437\u0441\u0442\u0430\u043d",Jd="\u043c\u043e\u043d\u0433\u043e\u043b\u044c\u0441\u043a\u0438\u0439",
|
9 |
+
Kd="\u0540\u0561\u0575\u0561\u057d\u057f\u0561\u0576\u056b \u0540\u0561\u0576\u0580\u0561\u057a\u0565\u057f\u0578\u0582\u0569\u056b\u0582\u0576",Ld="\u0627\u0641\u063a\u0627\u0646\u0633\u062a\u0627\u0646",Md="\u0627\u0644\u0627\u0645\u0627\u0631\u0627\u062a \u0627\u0644\u0639\u0631\u0628\u064a\u0629 \u0627\u0644\u0645\u062a\u062d\u062f\u0629",Nd="\u0627\u0644\u0635\u062d\u0631\u0627\u0621 \u0627\u0644\u063a\u0631\u0628\u064a\u0629",Od="\u0627\u0644\u0645\u0645\u0644\u0643\u0629 \u0627\u0644\u0639\u0631\u0628\u064a\u0629 \u0627\u0644\u0633\u0639\u0648\u062f\u064a\u0629",
|
10 |
+
Pd="\u0627\u0644\u0648\u0644\u0627\u064a\u0627\u062a \u0627\u0644\u0645\u062a\u062d\u062f\u0629 \u0627\u0644\u0623\u0645\u0631\u064a\u0643\u064a\u0629",Qd="\u062c\u0632\u0631 \u0627\u0644\u0642\u0645\u0631",Rd="\u067e\u0627\u06a9\u0633\u062a\u0627\u0646",W="\u092d\u093e\u0930\u0924",X="\u12a2\u1275\u12ee\u1335\u12eb",Sd="\uc870\uc120 \ubbfc\uc8fc\uc8fc\uc758 \uc778\ubbfc \uacf5\ud654\uad6d",Td="\ufffd";function Y(){return function(){}}var Z=Z||{};Z.global=this;Z.P=function(a){return void 0!==a};
|
11 |
+
Z.Aa=function(a,c,d){a=a.split(r);d=d||Z.global;a[0]in d||!d.execScript||d.execScript(qd+a[0]);for(var e;a.length&&(e=a.shift());)!a.length&&Z.P(c)?d[e]=c:d=d[e]?d[e]:d[e]={}};Z.ue=function(a,c){Z.Aa(a,c)};Z.H=!0;Z.Cd=yc;Z.ra=!0;Z.ec=!1;Z.Ob=!Z.H;Z.Ya=!1;Z.Gf=function(a){if(Z.La())throw Error("goog.provide can not be used within a goog.module.");Z.fb(a)};Z.fb=function(a,c){Z.Aa(a,c)};Z.mc=/^[a-zA-Z_$][a-zA-Z0-9._$]*$/;
|
12 |
+
Z.Oa=function(a){if(!Z.h(a)||!a||-1==a.search(Z.mc))throw Error("Invalid module identifier");if(!Z.La())throw Error("Module "+a+" has been loaded incorrectly.");if(Z.j.Pa)throw Error("goog.module may only be called once per module.");Z.j.Pa=a};Z.Oa.get=Y();Z.Oa.Ge=Y();Z.j=null;Z.La=function(){return null!=Z.j};Z.Oa.xa=function(){Z.j.xa=!0};Z.Zf=function(a){if(Z.Ob)throw a=a||b,Error("Importing test-only code into non-debug environment"+(a?w+a:r));};Z.Be=Y();
|
13 |
+
Z.kb=function(){for(var a=[Ic,tc,Sc],c=Z.global,d;d=a.shift();)if(Z.Ic(c[d]))c=c[d];else return null;return c};Z.Re=function(a,c){var d=c||Z.global,e;for(e in a)d[e]=a[e]};Z.Id=function(a,c,d,e){if(Z.Wa){var f;a=a.replace(/\\/g,u);var g=Z.i;e&&typeof e!==qc||(e=e?{module:Dc}:{});for(var h=0;f=c[h];h++)g.U[f]=a,g.Ra[a]=e.module==Dc;for(e=0;c=d[e];e++)a in g.G||(g.G[a]={}),g.G[a][c]=!0}};Z.yg=!1;Z.zd=!0;Z.uf=function(a){Z.global.console&&Z.global.console.error(a)};Z.Uf=Y();Z.F=b;Z.Bf=Y();
|
14 |
+
Z.Hd=function(){throw Error("unimplemented abstract method");};Z.Jd=function(a){a.Fe=function(){if(a.vb)return a.vb;Z.H&&(Z.wb[Z.wb.length]=a);return a.vb=new a}};Z.wb=[];Z.Vb=!0;Z.cc=Z.H;Z.Sc={};Z.Wa=!1;
|
15 |
+
Z.Wa&&(Z.i={Ra:{},U:{},G:{},Hb:{},qa:{},X:{}},Z.tb=function(){var a=Z.global.document;return null!=a&&ud in a},Z.Ac=function(){if(Z.P(Z.global.Lb))Z.F=Z.global.Lb;else if(Z.tb())for(var a=Z.global.document.getElementsByTagName(Jb),c=a.length-1;0<=c;--c){var d=a[c].src,e=d.lastIndexOf(Ma),e=-1==e?d.length:e;if(d.substr(e-7,7)==pc){Z.F=d.substr(0,e-7);break}}},Z.Ha=function(a,c){(Z.global.rd||Z.od)(a,c)&&(Z.i.qa[a]=!0)},Z.Ub=!(Z.global.atob||!Z.global.document||!Z.global.document.all),Z.Gc=function(a){Z.Ha(b,
|
16 |
+
Gc+a+ha)&&(Z.i.qa[a]=!0)},Z.Sa=[],Z.Ag=function(a,c){return Z.Vb&&Z.P(Z.global.JSON)?Ec+Z.global.JSON.stringify(c+ca+a+ba)+xa:Fc+c+da+a+ba},Z.Rc=function(){var a=Z.Sa.length;if(0<a){var c=Z.Sa;Z.Sa=[];for(var d=0;d<a;d++)Z.Bb(c[d])}},Z.vf=function(a){Z.xb(a)&&Z.nc(a)&&Z.Bb(Z.F+Z.Ga(a))},Z.xb=function(a){return(a=Z.Ga(a))&&Z.i.Ra[a]?Z.F+a in Z.i.X:!1},Z.nc=function(a){if((a=Z.Ga(a))&&a in Z.i.G)for(var c in Z.i.G[a])if(!Z.Mc(c)&&!Z.xb(c))return!1;return!0},Z.Bb=function(a){if(a in Z.i.X){var c=Z.i.X[a];
|
17 |
+
delete Z.i.X[a];Z.Fc(c)}},Z.tf=Y(),Z.sf=function(a){var c=Z.j;try{Z.j={Pa:void 0,xa:!1};var d;if(Z.yb(a))d=a.call(Z.global,{});else if(Z.h(a))d=Z.Pc.call(Z.global,a);else throw Error("Invalid module definition");var e=Z.j.Pa;if(!Z.h(e)||!e)throw Error('Invalid module name "'+e+l);Z.j.xa?Z.fb(e,d):Z.cc&&Object.seal&&Object.seal(d);Z.Sc[e]=d}finally{Z.j=c}},Z.Pc=function(a){eval(a);return{}},Z.md=function(a){Z.global.document.write(Ia+a+ia)},Z.pc=function(a){var c=Z.global.document,d=c.createElement(gd);
|
18 |
+
d.type=ld;d.src=a;d.defer=!1;d.async=!1;c.head.appendChild(d)},Z.od=function(a,c){if(Z.tb()){var d=Z.global.document;if(!Z.Ya&&d.readyState==P){if(/\bdeps.js$/.test(a))return!1;throw Error('Cannot write "'+a+'" after document load');}var e=Z.Ub;void 0===c?e?(e=fa+ ++Z.zb+va,d.write(Ia+a+l+e+La)):Z.Ya?Z.pc(a):Z.md(a):d.write(Ja+c+Fa);return!0}return!1},Z.zb=0,Z.Df=function(a,c){a.readyState==P&&Z.zb==c&&Z.Rc();return!0},Z.Bg=function(a){function c(a){if(!(a in f.qa||a in f.Hb)){f.Hb[a]=!0;if(a in f.G)for(var g in f.G[a])if(!Z.Mc(g))if(g in
|
19 |
+
f.U)c(f.U[g]);else throw Error("Undefined nameToPath for "+g);a in e||(e[a]=!0,d.push(a))}}var d=[],e={},f=Z.i;c(a);for(a=0;a<d.length;a++){var g=d[a];Z.i.qa[g]=!0}var h=Z.j;Z.j=null;for(a=0;a<d.length;a++)if(g=d[a])f.Ra[g]?Z.Gc(Z.F+g):Z.Ha(Z.F+g);else throw Z.j=h,Error("Undefined script input");Z.j=h},Z.Ga=function(a){return a in Z.i.U?Z.i.U[a]:null},Z.Ac(),Z.global.td||Z.Ha(Z.F+"deps.js"));
|
20 |
+
Z.yf=function(a){a=a.split(u);for(var c=0;c<a.length;)a[c]==r?a.splice(c,1):c&&a[c]==Ba&&a[c-1]&&a[c-1]!=Ba?a.splice(--c,2):c++;return a.join(u)};Z.rf=function(a){if(Z.global.Mb)return Z.global.Mb(a);var c=new Z.global.XMLHttpRequest;c.open(Cc,a,!1);c.send();return c.responseText};Z.Vf=Y();
|
21 |
+
Z.s=function(a){var c=typeof a;if(c==T)if(a){if(a instanceof Array)return N;if(a instanceof Object)return c;var d=Object.prototype.toString.call(a);if(d==gc)return T;if(d==ec||typeof a.length==ad&&"undefined"!=typeof a.splice&&"undefined"!=typeof a.propertyIsEnumerable&&!a.propertyIsEnumerable(hd))return N;if(d==fc||"undefined"!=typeof a.call&&"undefined"!=typeof a.propertyIsEnumerable&&!a.propertyIsEnumerable(rc))return R}else return $c;else if(c==R&&"undefined"==typeof a.call)return T;return c};
|
22 |
+
Z.gf=function(a){return null===a};Z.Ic=function(a){return null!=a};Z.isArray=function(a){return Z.s(a)==N};Z.Ja=function(a){var c=Z.s(a);return c==N||c==T&&typeof a.length==ad};Z.bf=function(a){return Z.$(a)&&typeof a.getFullYear==R};Z.h=function(a){return typeof a==id};Z.Hc=function(a){return typeof a==qc};Z.Lc=function(a){return typeof a==ad};Z.yb=function(a){return Z.s(a)==R};Z.$=function(a){var c=typeof a;return c==T&&null!=a||c==R};Z.qb=function(a){return a[Z.D]||(a[Z.D]=++Z.hd)};Z.Se=function(a){return!!a[Z.D]};
|
23 |
+
Z.Zc=function(a){null!==a&&fd in a&&a.removeAttribute(Z.D);try{delete a[Z.D]}catch(c){}};Z.D="closure_uid_"+(1E9*Math.random()>>>0);Z.hd=0;Z.De=Z.qb;Z.Rf=Z.Zc;Z.uc=function(a){var c=Z.s(a);if(c==T||c==N){if(a.clone)return a.clone();var c=c==N?[]:{},d;for(d in a)c[d]=Z.uc(a[d]);return c}return a};Z.tc=function(a,c,d){return a.call.apply(a.bind,arguments)};
|
24 |
+
Z.rc=function(a,c,d){if(!a)throw Error();if(2<arguments.length){var e=Array.prototype.slice.call(arguments,2);return function(){var d=Array.prototype.slice.call(arguments);Array.prototype.unshift.apply(d,e);return a.apply(c,d)}}return function(){return a.apply(c,arguments)}};Z.bind=function(a,c,d){Function.prototype.bind&&-1!=Function.prototype.bind.toString().indexOf(Yc)?Z.bind=Z.tc:Z.bind=Z.rc;return Z.bind.apply(null,arguments)};
|
25 |
+
Z.Wc=function(a,c){var d=Array.prototype.slice.call(arguments,1);return function(){var c=d.slice();c.push.apply(c,arguments);return a.apply(this,c)}};Z.wf=function(a,c){for(var d in c)a[d]=c[d]};Z.now=Z.ra&&Date.now||function(){return+new Date};
|
26 |
+
Z.Fc=function(a){if(Z.global.execScript)Z.global.execScript(a,mb);else if(Z.global.eval){if(null==Z.Y)if(Z.global.eval(rd),"undefined"!=typeof Z.global._evalTest_){try{delete Z.global._evalTest_}catch(e){}Z.Y=!0}else Z.Y=!1;if(Z.Y)Z.global.eval(a);else{var c=Z.global.document,d=c.createElement(Jb);d.type=ld;d.defer=!1;d.appendChild(c.createTextNode(a));c.body.appendChild(d);c.body.removeChild(d)}}else throw Error("goog.globalEval not available");};Z.Y=null;
|
27 |
+
Z.Ce=function(a,c){function d(a){a=a.split(za);for(var c=[],d=0;d<a.length;d++)c.push(e(a[d]));return c.join(za)}function e(a){return Z.gb[a]||a}var f;f=Z.gb?Z.xc==Sa?e:d:function(a){return a};return c?a+za+f(c):f(a)};Z.Wf=function(a,c){Z.gb=a;Z.xc=c};Z.Je=function(a,c){c&&(a=a.replace(/\{\$([^}]+)}/g,function(a,e){return null!=c&&e in c?c[e]:a}));return a};Z.Ke=function(a){return a};Z.Ba=function(a,c){Z.Aa(a,c,void 0)};Z.ze=function(a,c,d){a[c]=d};
|
28 |
+
Z.Ia=function(a,c){function d(){}d.prototype=c.prototype;a.oa=c.prototype;a.prototype=new d;a.prototype.constructor=a;a.qc=function(a,d,g){for(var h=Array(arguments.length-2),m=2;m<arguments.length;m++)h[m-2]=arguments[m];return c.prototype[d].apply(a,h)}};
|
29 |
+
Z.qc=function(a,c,d){var e=arguments.callee.caller;if(Z.ec||Z.H&&!e)throw Error("arguments.caller not defined. goog.base() cannot be used with strict mode code. See http://www.ecma-international.org/ecma-262/5.1/#sec-C");if(e.oa){for(var f=Array(arguments.length-1),g=1;g<arguments.length;g++)f[g-1]=arguments[g];return e.oa.constructor.apply(a,f)}f=Array(arguments.length-2);for(g=2;g<arguments.length;g++)f[g-2]=arguments[g];for(var g=!1,h=a.constructor;h;h=h.oa&&h.oa.constructor)if(h.prototype[c]===
|
30 |
+
e)g=!0;else if(g)return h.prototype[c].apply(a,f);if(a[c]===e)return a.constructor.prototype[c].apply(a,f);throw Error("goog.base called from a method of one name to a method of a different name");};Z.scope=function(a){if(Z.La())throw Error("goog.scope is not supported within a goog.module.");a.call(Z.global)};
|
31 |
+
Z.u=function(a,c){var d=c.constructor,e=c.cd;d&&d!=Object.prototype.constructor||(d=function(){throw Error("cannot instantiate an interface (no constructor defined).");});d=Z.u.vc(d,a);a&&Z.Ia(d,a);delete c.constructor;delete c.cd;Z.u.$a(d.prototype,c);null!=e&&(e instanceof Function?e(d):Z.u.$a(d,e));return d};Z.u.bc=Z.H;
|
32 |
+
Z.u.vc=function(a,c){if(Z.u.bc&&Object.seal instanceof Function){if(c&&c.prototype&&c.prototype[Z.kc])return a;var d=function(){var c=a.apply(this,arguments)||this;c[Z.D]=c[Z.D];this.constructor===d&&Object.seal(c);return c};return d}return a};Z.u.Za="constructor hasOwnProperty isPrototypeOf propertyIsEnumerable toLocaleString toString valueOf".split(" ");
|
33 |
+
Z.u.$a=function(a,c){for(var d in c)Object.prototype.hasOwnProperty.call(c,d)&&(a[d]=c[d]);for(var e=0;e<Z.u.Za.length;e++)d=Z.u.Za[e],Object.prototype.hasOwnProperty.call(c,d)&&(a[d]=c[d])};Z.gg=Y();Z.kc="goog_defineClass_legacy_unsealable";Z.debug={};Z.debug.Error=function(a){if(Error.captureStackTrace)Error.captureStackTrace(this,Z.debug.Error);else{var c=Error().stack;c&&(this.stack=c)}a&&(this.message=String(a))};Z.Ia(Z.debug.Error,Error);Z.debug.Error.prototype.name="CustomError";Z.hb={};Z.hb.$b={Pb:1,pd:2,Gd:3,qd:4,Bd:5,Ad:6,Fd:7,ud:8,wd:9,yd:10,xd:11,Dd:12};Z.c={};Z.c.Xa=!1;Z.c.Rb=!1;Z.c.lc={Yb:"\u00a0"};Z.c.startsWith=function(a,c){return 0==a.lastIndexOf(c,0)};Z.c.endsWith=function(a,c){var d=a.length-c.length;return 0<=d&&a.indexOf(c,d)==d};Z.c.je=function(a,c){return 0==Z.c.eb(c,a.substr(0,c.length))};Z.c.fe=function(a,c){return 0==Z.c.eb(c,a.substr(a.length-c.length,c.length))};Z.c.ge=function(a,c){return a.toLowerCase()==c.toLowerCase()};
|
34 |
+
Z.c.dd=function(a,c){for(var d=a.split(la),e=b,f=Array.prototype.slice.call(arguments,1);f.length&&1<d.length;)e+=d.shift()+f.shift();return e+d.join(la)};Z.c.le=function(a){return a.replace(/[\s\xa0]+/g,k).replace(/^\s+|\s+$/g,b)};Z.c.Ka=function(a){return/^[\s\xa0]*$/.test(a)};Z.c.df=function(a){return 0==a.length};Z.c.Jc=Z.c.Ka;Z.c.Kc=function(a){return Z.c.Ka(Z.c.Tc(a))};Z.c.cf=Z.c.Kc;Z.c.$e=function(a){return!/[^\t\n\r ]/.test(a)};Z.c.Ye=function(a){return!/[^a-zA-Z]/.test(a)};Z.c.hf=function(a){return!/[^0-9]/.test(a)};
|
35 |
+
Z.c.Ze=function(a){return!/[^a-zA-Z0-9]/.test(a)};Z.c.lf=function(a){return a==k};Z.c.mf=function(a){return 1==a.length&&a>=k&&a<=Ed||a>=Fd&&a<=Td};Z.c.eg=function(a){return a.replace(/(\r\n|\r|\n)+/g,k)};Z.c.Yd=function(a){return a.replace(/(\r\n|\r|\n)/g,ba)};Z.c.Af=function(a){return a.replace(/\xa0|\s/g,k)};Z.c.zf=function(a){return a.replace(/\xa0|[ \t]+/g,k)};Z.c.ke=function(a){return a.replace(/[\t\r\n ]+/g,k).replace(/^[\t\r\n ]+|[\t\r\n ]+$/g,b)};
|
36 |
+
Z.c.trim=Z.ra&&String.prototype.trim?function(a){return a.trim()}:function(a){return a.replace(/^[\s\xa0]+|[\s\xa0]+$/g,b)};Z.c.trimLeft=function(a){return a.replace(/^[\s\xa0]+/,b)};Z.c.trimRight=function(a){return a.replace(/[\s\xa0]+$/,b)};Z.c.eb=function(a,c){var d=String(a).toLowerCase(),e=String(c).toLowerCase();return d<e?-1:d==e?0:1};
|
37 |
+
Z.c.Db=function(a,c,d){if(a==c)return 0;if(!a)return-1;if(!c)return 1;for(var e=a.toLowerCase().match(d),f=c.toLowerCase().match(d),g=Math.min(e.length,f.length),h=0;h<g;h++){d=e[h];var m=f[h];if(d!=m)return a=parseInt(d,10),!isNaN(a)&&(c=parseInt(m,10),!isNaN(c)&&a-c)?a-c:d<m?-1:1}return e.length!=f.length?e.length-f.length:a<c?-1:1};Z.c.We=function(a,c){return Z.c.Db(a,c,/\d+|\D+/g)};Z.c.Dc=function(a,c){return Z.c.Db(a,c,/\d+|\.\d+|\D+/g)};Z.c.Cf=Z.c.Dc;Z.c.xg=function(a){return encodeURIComponent(String(a))};
|
38 |
+
Z.c.wg=function(a){return decodeURIComponent(a.replace(/\+/g,k))};Z.c.Uc=function(a,c){return a.replace(/(\r\n|\r|\n)/g,c?Ga:Ha)};Z.c.rb=function(a){if(!Z.c.Jb.test(a))return a;-1!=a.indexOf(q)&&(a=a.replace(Z.c.Kb,pa));-1!=a.indexOf(x)&&(a=a.replace(Z.c.Xb,ra));-1!=a.indexOf(Ka)&&(a=a.replace(Z.c.Sb,qa));-1!=a.indexOf(l)&&(a=a.replace(Z.c.ac,sa));-1!=a.indexOf(ta)&&(a=a.replace(Z.c.dc,oa));-1!=a.indexOf(aa)&&(a=a.replace(Z.c.Zb,ma));Z.c.Xa&&-1!=a.indexOf(xc)&&(a=a.replace(Z.c.Qb,na));return a};
|
39 |
+
Z.c.Kb=/&/g;Z.c.Xb=/</g;Z.c.Sb=/>/g;Z.c.ac=/"/g;Z.c.dc=/'/g;Z.c.Zb=/\x00/g;Z.c.Qb=/e/g;Z.c.Jb=Z.c.Xa?/[\x00&<>"'e]/:/[\x00&<>"']/;Z.c.Fb=function(a){return Z.c.contains(a,q)?!Z.c.Rb&&wc in Z.global?Z.c.Gb(a):Z.c.jd(a):a};Z.c.vg=function(a,c){return Z.c.contains(a,q)?Z.c.Gb(a,c):a};
|
40 |
+
Z.c.Gb=function(a,c){var d={"&":q,"<":x,">":Ka,""":l},e;e=c?c.createElement(vc):Z.global.document.createElement(vc);return a.replace(Z.c.Tb,function(a,c){var h=d[a];if(h)return h;if(c.charAt(0)==ja){var m=Number(v+c.substr(1));isNaN(m)||(h=String.fromCharCode(m))}h||(e.innerHTML=a+k,h=e.firstChild.nodeValue.slice(0,-1));return d[a]=h})};
|
41 |
+
Z.c.jd=function(a){return a.replace(/&([^;]+);/g,function(a,d){switch(d){case nc:return q;case Xc:return x;case Lc:return Ka;case dd:return l;default:if(d.charAt(0)==ja){var e=Number(v+d.substr(1));if(!isNaN(e))return String.fromCharCode(e)}return a}})};Z.c.Tb=/&([^;\s<&]+);?/g;Z.c.zg=function(a,c){return Z.c.Uc(a.replace(/ /g,ea),c)};Z.c.Ff=function(a){return a.replace(/(^|[\n ]) /g,ka+Z.c.lc.Yb)};
|
42 |
+
Z.c.fg=function(a,c){for(var d=c.length,e=0;e<d;e++){var f=1==d?c:c.charAt(e);if(a.charAt(0)==f&&a.charAt(a.length-1)==f)return a.substring(1,a.length-1)}return a};Z.c.truncate=function(a,c,d){d&&(a=Z.c.Fb(a));a.length>c&&(a=a.substring(0,c-3)+Ca);d&&(a=Z.c.rb(a));return a};
|
43 |
+
Z.c.rg=function(a,c,d,e){d&&(a=Z.c.Fb(a));if(e&&a.length>c)e>c&&(e=c),a=a.substring(0,c-e)+Ca+a.substring(a.length-e);else if(a.length>c){e=Math.floor(c/2);var f=a.length-e;a=a.substring(0,e+c%2)+Ca+a.substring(f)}d&&(a=Z.c.rb(a));return a};Z.c.Va={"\x00":"\\0","\b":"\\b","\f":"\\f","\n":"\\n","\r":"\\r","\t":"\\t","\x0B":"\\x0B",'"':'\\"',"\\":"\\\\","<":x};Z.c.ea={"'":"\\'"};
|
44 |
+
Z.c.quote=function(a){a=String(a);for(var c=[l],d=0;d<a.length;d++){var e=a.charAt(d),f=e.charCodeAt(0);c[d+1]=Z.c.Va[e]||(31<f&&127>f?e:Z.c.ib(e))}c.push(l);return c.join(b)};Z.c.ye=function(a){for(var c=[],d=0;d<a.length;d++)c[d]=Z.c.ib(a.charAt(d));return c.join(b)};
|
45 |
+
Z.c.ib=function(a){if(a in Z.c.ea)return Z.c.ea[a];if(a in Z.c.Va)return Z.c.ea[a]=Z.c.Va[a];var c=a,d=a.charCodeAt(0);if(31<d&&127>d)c=a;else{if(256>d){if(c=kc,16>d||256<d)c+=v}else c=jc,4096>d&&(c+=v);c+=d.toString(16).toUpperCase()}return Z.c.ea[a]=c};Z.c.contains=function(a,c){return-1!=a.indexOf(c)};Z.c.$d=function(a,c){return Z.c.contains(a.toLowerCase(),c.toLowerCase())};Z.c.qe=function(a,c){return a&&c?a.split(c).length-1:0};
|
46 |
+
Z.c.L=function(a,c,d){var e=a;0<=c&&c<a.length&&0<d&&(e=a.substr(0,c)+a.substr(c+d,a.length-c-d));return e};Z.c.remove=function(a,c){var d=new RegExp(Z.c.Ta(c),b);return a.replace(d,b)};Z.c.Of=function(a,c){var d=new RegExp(Z.c.Ta(c),Bc);return a.replace(d,b)};Z.c.Ta=function(a){return String(a).replace(/([-()\[\]{}+?*.$\^|,:#<!\\])/g,hc).replace(/\x08/g,lc)};Z.c.repeat=String.prototype.repeat?function(a,c){return a.repeat(c)}:function(a,c){return Array(c+1).join(a)};
|
47 |
+
Z.c.Ef=function(a,c,d){a=Z.P(d)?a.toFixed(d):String(a);d=a.indexOf(r);-1==d&&(d=a.length);return Z.c.repeat(v,Math.max(0,c-d))+a};Z.c.Tc=function(a){return null==a?b:String(a)};Z.c.Xd=function(a){return Array.prototype.join.call(arguments,b)};Z.c.Ne=function(){return Math.floor(2147483648*Math.random()).toString(36)+Math.abs(Math.floor(2147483648*Math.random())^Z.now()).toString(36)};
|
48 |
+
Z.c.oe=function(a,c){for(var d=0,e=Z.c.trim(String(a)).split(r),f=Z.c.trim(String(c)).split(r),g=Math.max(e.length,f.length),h=0;0==d&&h<g;h++){var m=e[h]||b,n=f[h]||b,p=/(\d*)(\D*)/g,Oa=/(\d*)(\D*)/g;do{var A=p.exec(m)||[b,b,b],t=Oa.exec(n)||[b,b,b];if(0==A[0].length&&0==t[0].length)break;d=Z.c.ua(0==A[1].length?0:parseInt(A[1],10),0==t[1].length?0:parseInt(t[1],10))||Z.c.ua(0==A[2].length,0==t[2].length)||Z.c.ua(A[2],t[2])}while(0==d)}return d};Z.c.ua=function(a,c){return a<c?-1:a>c?1:0};
|
49 |
+
Z.c.Te=function(a){for(var c=0,d=0;d<a.length;++d)c=31*c+a.charCodeAt(d)>>>0;return c};Z.c.kd=2147483648*Math.random()|0;Z.c.re=function(){return Hc+Z.c.kd++};Z.c.jg=function(a){var c=Number(a);return 0==c&&Z.c.Ka(a)?NaN:c};Z.c.ef=function(a){return/^[a-z]+([A-Z][a-z]*)*$/.test(a)};Z.c.nf=function(a){return/^([A-Z][a-z]*)+$/.test(a)};Z.c.hg=function(a){return String(a).replace(/\-([a-z])/g,function(a,d){return d.toUpperCase()})};Z.c.pg=function(a){return String(a).replace(/([A-Z])/g,Aa).toLowerCase()};
|
50 |
+
Z.c.qg=function(a,c){var d=Z.h(c)?Z.c.Ta(c):ic;return a.replace(new RegExp(ua+(d?Cd+d+mc:b)+wa,Bc),function(a,c,d){return c+d.toUpperCase()})};Z.c.Zd=function(a){return String(a.charAt(0)).toUpperCase()+String(a.substr(1)).toLowerCase()};Z.c.parseInt=function(a){isFinite(a)&&(a=String(a));return Z.h(a)?/^\s*-?0x/i.test(a)?parseInt(a,16):parseInt(a,10):NaN};Z.c.cg=function(a,c,d){a=a.split(c);for(var e=[];0<d&&a.length;)e.push(a.shift()),d--;a.length&&e.push(a.join(c));return e};
|
51 |
+
Z.c.qf=function(a,c){if(c)typeof c==id&&(c=[c]);else return a;for(var d=-1,e=0;e<c.length;e++)if(c[e]!=b){var f=a.lastIndexOf(c[e]);f>d&&(d=f)}return-1==d?a:a.slice(d+1)};Z.c.we=function(a,c){var d=[],e=[];if(a==c)return 0;if(!a.length||!c.length)return Math.max(a.length,c.length);for(var f=0;f<c.length+1;f++)d[f]=f;for(f=0;f<a.length;f++){e[0]=f+1;for(var g=0;g<c.length;g++)e[g+1]=Math.min(e[g]+1,d[g+1]+1,d[g]+Number(a[f]!=c[g]));for(g=0;g<d.length;g++)d[g]=e[g]}return e[c.length]};Z.g={};Z.g.o=Z.H;Z.g.V=function(a,c){c.unshift(a);Z.debug.Error.call(this,Z.c.dd.apply(null,c));c.shift()};Z.Ia(Z.g.V,Z.debug.Error);Z.g.V.prototype.name="AssertionError";Z.g.Nb=function(a){throw a;};Z.g.ya=Z.g.Nb;Z.g.A=function(a,c,d,e){var f=Ra;if(d)var f=f+(w+d),g=e;else a&&(f+=w+a,g=c);a=new Z.g.V(b+f,g||[]);Z.g.ya(a)};Z.g.Xf=function(a){Z.g.o&&(Z.g.ya=a)};Z.g.assert=function(a,c,d){Z.g.o&&!a&&Z.g.A(b,null,c,Array.prototype.slice.call(arguments,2));return a};
|
52 |
+
Z.g.Ca=function(a,c){Z.g.o&&Z.g.ya(new Z.g.V(eb+(a?w+a:b),Array.prototype.slice.call(arguments,1)))};Z.g.Pd=function(a,c,d){Z.g.o&&!Z.Lc(a)&&Z.g.A(bb,[Z.s(a),a],c,Array.prototype.slice.call(arguments,2));return a};Z.g.Sd=function(a,c,d){Z.g.o&&!Z.h(a)&&Z.g.A(db,[Z.s(a),a],c,Array.prototype.slice.call(arguments,2));return a};Z.g.Nd=function(a,c,d){Z.g.o&&!Z.yb(a)&&Z.g.A($a,[Z.s(a),a],c,Array.prototype.slice.call(arguments,2));return a};
|
53 |
+
Z.g.Qd=function(a,c,d){Z.g.o&&!Z.$(a)&&Z.g.A(cb,[Z.s(a),a],c,Array.prototype.slice.call(arguments,2));return a};Z.g.Kd=function(a,c,d){Z.g.o&&!Z.isArray(a)&&Z.g.A(Ya,[Z.s(a),a],c,Array.prototype.slice.call(arguments,2));return a};Z.g.Ld=function(a,c,d){Z.g.o&&!Z.Hc(a)&&Z.g.A(Za,[Z.s(a),a],c,Array.prototype.slice.call(arguments,2));return a};Z.g.Md=function(a,c,d){!Z.g.o||Z.$(a)&&a.nodeType==Z.hb.$b.Pb||Z.g.A(Xa,[Z.s(a),a],c,Array.prototype.slice.call(arguments,2));return a};
|
54 |
+
Z.g.Od=function(a,c,d,e){!Z.g.o||a instanceof c||Z.g.A(ab,[Z.g.pb(c),Z.g.pb(a)],d,Array.prototype.slice.call(arguments,3));return a};Z.g.Rd=function(){for(var a in Object.prototype)Z.g.Ca(a+ga)};Z.g.pb=function(a){return a instanceof Function?a.displayName||a.name||pd:a instanceof Object?a.constructor.displayName||a.constructor.name||Object.prototype.toString.call(a):null===a?$c:typeof a};Z.f={};Z.w=Z.ra;Z.f.v=!1;Z.f.Xc=function(a){return a[a.length-1]};Z.f.pf=Z.f.Xc;Z.f.indexOf=Z.w&&(Z.f.v||Array.prototype.indexOf)?function(a,c,d){return Array.prototype.indexOf.call(a,c,d)}:function(a,c,d){d=null==d?0:0>d?Math.max(0,a.length+d):d;if(Z.h(a))return Z.h(c)&&1==c.length?a.indexOf(c,d):-1;for(;d<a.length;d++)if(d in a&&a[d]===c)return d;return-1};
|
55 |
+
Z.f.lastIndexOf=Z.w&&(Z.f.v||Array.prototype.lastIndexOf)?function(a,c,d){return Array.prototype.lastIndexOf.call(a,c,null==d?a.length-1:d)}:function(a,c,d){d=null==d?a.length-1:d;0>d&&(d=Math.max(0,a.length+d));if(Z.h(a))return Z.h(c)&&1==c.length?a.lastIndexOf(c,d):-1;for(;0<=d;d--)if(d in a&&a[d]===c)return d;return-1};
|
56 |
+
Z.f.forEach=Z.w&&(Z.f.v||Array.prototype.forEach)?function(a,c,d){Array.prototype.forEach.call(a,c,d)}:function(a,c,d){for(var e=a.length,f=Z.h(a)?a.split(b):a,g=0;g<e;g++)g in f&&c.call(d,f[g],g,a)};Z.f.jb=function(a,c){for(var d=Z.h(a)?a.split(b):a,e=a.length-1;0<=e;--e)e in d&&c.call(void 0,d[e],e,a)};
|
57 |
+
Z.f.filter=Z.w&&(Z.f.v||Array.prototype.filter)?function(a,c,d){return Array.prototype.filter.call(a,c,d)}:function(a,c,d){for(var e=a.length,f=[],g=0,h=Z.h(a)?a.split(b):a,m=0;m<e;m++)if(m in h){var n=h[m];c.call(d,n,m,a)&&(f[g++]=n)}return f};Z.f.map=Z.w&&(Z.f.v||Array.prototype.map)?function(a,c,d){return Array.prototype.map.call(a,c,d)}:function(a,c,d){for(var e=a.length,f=Array(e),g=Z.h(a)?a.split(b):a,h=0;h<e;h++)h in g&&(f[h]=c.call(d,g[h],h,a));return f};
|
58 |
+
Z.f.reduce=Z.w&&(Z.f.v||Array.prototype.reduce)?function(a,c,d,e){e&&(c=Z.bind(c,e));return Array.prototype.reduce.call(a,c,d)}:function(a,c,d,e){var f=d;Z.f.forEach(a,function(d,h){f=c.call(e,f,d,h,a)});return f};Z.f.reduceRight=Z.w&&(Z.f.v||Array.prototype.reduceRight)?function(a,c,d,e){e&&(c=Z.bind(c,e));return Array.prototype.reduceRight.call(a,c,d)}:function(a,c,d,e){var f=d;Z.f.jb(a,function(d,h){f=c.call(e,f,d,h,a)});return f};
|
59 |
+
Z.f.some=Z.w&&(Z.f.v||Array.prototype.some)?function(a,c,d){return Array.prototype.some.call(a,c,d)}:function(a,c,d){for(var e=a.length,f=Z.h(a)?a.split(b):a,g=0;g<e;g++)if(g in f&&c.call(d,f[g],g,a))return!0;return!1};Z.f.every=Z.w&&(Z.f.v||Array.prototype.every)?function(a,c,d){return Array.prototype.every.call(a,c,d)}:function(a,c,d){for(var e=a.length,f=Z.h(a)?a.split(b):a,g=0;g<e;g++)if(g in f&&!c.call(d,f[g],g,a))return!1;return!0};
|
60 |
+
Z.f.count=function(a,c,d){var e=0;Z.f.forEach(a,function(a,g,h){c.call(d,a,g,h)&&++e},d);return e};Z.f.find=function(a,c,d){c=Z.f.findIndex(a,c,d);return 0>c?null:Z.h(a)?a.charAt(c):a[c]};Z.f.findIndex=function(a,c,d){for(var e=a.length,f=Z.h(a)?a.split(b):a,g=0;g<e;g++)if(g in f&&c.call(d,f[g],g,a))return g;return-1};Z.f.Ae=function(a,c,d){c=Z.f.Bc(a,c,d);return 0>c?null:Z.h(a)?a.charAt(c):a[c]};
|
61 |
+
Z.f.Bc=function(a,c,d){for(var e=Z.h(a)?a.split(b):a,f=a.length-1;0<=f;f--)if(f in e&&c.call(d,e[f],f,a))return f;return-1};Z.f.contains=function(a,c){return 0<=Z.f.indexOf(a,c)};Z.f.Jc=function(a){return 0==a.length};Z.f.clear=function(a){if(!Z.isArray(a))for(var c=a.length-1;0<=c;c--)delete a[c];a.length=0};Z.f.Ue=function(a,c){Z.f.contains(a,c)||a.push(c)};Z.f.ub=function(a,c,d){Z.f.splice(a,d,0,c)};Z.f.Ve=function(a,c,d){Z.Wc(Z.f.splice,a,d,0).apply(null,c)};
|
62 |
+
Z.f.insertBefore=function(a,c,d){var e;2==arguments.length||0>(e=Z.f.indexOf(a,d))?a.push(c):Z.f.ub(a,c,e)};Z.f.remove=function(a,c){var d=Z.f.indexOf(a,c),e;(e=0<=d)&&Z.f.L(a,d);return e};Z.f.Tf=function(a,c){var d=Z.f.lastIndexOf(a,c);return 0<=d?(Z.f.L(a,d),!0):!1};Z.f.L=function(a,c){return 1==Array.prototype.splice.call(a,c,1).length};Z.f.Sf=function(a,c,d){c=Z.f.findIndex(a,c,d);return 0<=c?(Z.f.L(a,c),!0):!1};
|
63 |
+
Z.f.Pf=function(a,c,d){var e=0;Z.f.jb(a,function(f,g){c.call(d,f,g,a)&&Z.f.L(a,g)&&e++});return e};Z.f.concat=function(a){return Array.prototype.concat.apply(Array.prototype,arguments)};Z.f.join=function(a){return Array.prototype.concat.apply(Array.prototype,arguments)};Z.f.fd=function(a){var c=a.length;if(0<c){for(var d=Array(c),e=0;e<c;e++)d[e]=a[e];return d}return[]};Z.f.clone=Z.f.fd;
|
64 |
+
Z.f.extend=function(a,c){for(var d=1;d<arguments.length;d++){var e=arguments[d];if(Z.Ja(e)){var f=a.length||0,g=e.length||0;a.length=f+g;for(var h=0;h<g;h++)a[f+h]=e[h]}else a.push(e)}};Z.f.splice=function(a,c,d,e){return Array.prototype.splice.apply(a,Z.f.slice(arguments,1))};Z.f.slice=function(a,c,d){return 2>=arguments.length?Array.prototype.slice.call(a,c):Array.prototype.slice.call(a,c,d)};
|
65 |
+
Z.f.Qf=function(a,c,d){function e(a){return Z.$(a)?bd+Z.qb(a):(typeof a).charAt(0)+a}c=c||a;d=d||e;for(var f={},g=0,h=0;h<a.length;){var m=a[h++],n=d(m);Object.prototype.hasOwnProperty.call(f,n)||(f[n]=!0,c[g++]=m)}c.length=g};Z.f.bb=function(a,c,d){return Z.f.cb(a,d||Z.f.B,!1,c)};Z.f.Vd=function(a,c,d){return Z.f.cb(a,c,!0,void 0,d)};Z.f.cb=function(a,c,d,e,f){for(var g=0,h=a.length,m;g<h;){var n=g+h>>1,p;p=d?c.call(f,a[n],n,a):c(e,a[n]);0<p?g=n+1:(h=n,m=!p)}return m?g:~g};
|
66 |
+
Z.f.sort=function(a,c){a.sort(c||Z.f.B)};Z.f.dg=function(a,c){for(var d=Array(a.length),e=0;e<a.length;e++)d[e]={index:e,value:a[e]};var f=c||Z.f.B;Z.f.sort(d,function(a,c){return f(a.value,c.value)||a.index-c.index});for(e=0;e<a.length;e++)a[e]=d[e].value};Z.f.bd=function(a,c,d){var e=d||Z.f.B;Z.f.sort(a,function(a,d){return e(c(a),c(d))})};Z.f.ag=function(a,c,d){Z.f.bd(a,function(a){return a[c]},d)};
|
67 |
+
Z.f.kf=function(a,c,d){c=c||Z.f.B;for(var e=1;e<a.length;e++){var f=c(a[e-1],a[e]);if(0<f||0==f&&d)return!1}return!0};Z.f.xe=function(a,c,d){if(!Z.Ja(a)||!Z.Ja(c)||a.length!=c.length)return!1;var e=a.length;d=d||Z.f.yc;for(var f=0;f<e;f++)if(!d(a[f],c[f]))return!1;return!0};Z.f.me=function(a,c,d){d=d||Z.f.B;for(var e=Math.min(a.length,c.length),f=0;f<e;f++){var g=d(a[f],c[f]);if(0!=g)return g}return Z.f.B(a.length,c.length)};Z.f.B=function(a,c){return a>c?1:a<c?-1:0};
|
68 |
+
Z.f.Xe=function(a,c){return-Z.f.B(a,c)};Z.f.yc=function(a,c){return a===c};Z.f.Td=function(a,c,d){d=Z.f.bb(a,c,d);return 0>d?(Z.f.ub(a,c,-(d+1)),!0):!1};Z.f.Ud=function(a,c,d){c=Z.f.bb(a,c,d);return 0<=c?Z.f.L(a,c):!1};Z.f.Wd=function(a,c,d){for(var e={},f=0;f<a.length;f++){var g=a[f],h=c.call(d,g,f,a);Z.P(h)&&(e[h]||(e[h]=[])).push(g)}return e};Z.f.og=function(a,c,d){var e={};Z.f.forEach(a,function(f,g){e[c.call(d,f,g,a)]=f});return e};
|
69 |
+
Z.f.Hf=function(a,c,d){var e=[],f=0,g=a;d=d||1;void 0!==c&&(f=a,g=c);if(0>d*(g-f))return[];if(0<d)for(a=f;a<g;a+=d)e.push(a);else for(a=f;a>g;a+=d)e.push(a);return e};Z.f.repeat=function(a,c){for(var d=[],e=0;e<c;e++)d[e]=a;return d};Z.f.Cc=function(a){for(var c=[],d=0;d<arguments.length;d++){var e=arguments[d];if(Z.isArray(e))for(var f=0;f<e.length;f+=8192)for(var g=Z.f.Cc.apply(null,Z.f.slice(e,f,f+8192)),h=0;h<g.length;h++)c.push(g[h]);else c.push(e)}return c};
|
70 |
+
Z.f.rotate=function(a,c){a.length&&(c%=a.length,0<c?Array.prototype.unshift.apply(a,a.splice(-c,c)):0>c&&Array.prototype.push.apply(a,a.splice(0,-c)));return a};Z.f.xf=function(a,c,d){c=Array.prototype.splice.call(a,c,1);Array.prototype.splice.call(a,d,0,c[0])};
|
71 |
+
Z.f.Cg=function(a){if(!arguments.length)return[];for(var c=[],d=arguments[0].length,e=1;e<arguments.length;e++)arguments[e].length<d&&(d=arguments[e].length);for(e=0;e<d;e++){for(var f=[],g=0;g<arguments.length;g++)f.push(arguments[g][e]);c.push(f)}return c};Z.f.$f=function(a,c){for(var d=c||Math.random,e=a.length-1;0<e;e--){var f=Math.floor(d()*(e+1)),g=a[e];a[e]=a[f];a[f]=g}};Z.f.pe=function(a,c){var d=[];Z.f.forEach(c,function(c){d.push(a[c])});return d};Z.locale={};
|
72 |
+
Z.locale.J={COUNTRY:{AD:"Andorra",AE:Md,AF:Ld,AG:Qa,AI:"Anguilla",AL:"Shqip\u00ebria",AM:Kd,AN:wb,AO:"Angola",AQ:"Antarctica",AR:"Argentina",AS:Pa,AT:"\u00d6sterreich",AU:"Australia",AW:"Aruba",AX:"\u00c5land",AZ:"Az\u0259rbaycan",BA:z,BB:"Barbados",BD:"\u09ac\u09be\u0982\u09b2\u09be\u09a6\u09c7\u09b6",BE:"Belgi\u00eb",BF:"Burkina Faso",BG:"\u0411\u044a\u043b\u0433\u0430\u0440\u0438\u044f",BH:"\u0627\u0644\u0628\u062d\u0631\u064a\u0646",BI:"Burundi",BJ:"B\u00e9nin",BM:"Bermuda",BN:"Brunei",BO:y,BR:"Brasil",
|
73 |
+
BS:"Bahamas",BT:"\u092d\u0942\u091f\u093e\u0928",BV:"Bouvet Island",BW:Ta,BY:Hd,BZ:"Belize",CA:"Canada",CC:"Cocos (Keeling) Islands",CD:Ib,CF:Hb,CG:"Congo",CH:"Schweiz",CI:"C\u00f4te d\u2019Ivoire",CK:"Cook Islands",CL:"Chile",CM:"Cameroun",CN:"\u4e2d\u56fd",CO:"Colombia",CR:"Costa Rica",CS:Nb,CU:"Cuba",CV:"Cabo Verde",CX:Wa,CY:"\u039a\u03cd\u03c0\u03c1\u03bf\u03c2",CZ:Gd,DD:"East Germany",DE:"Deutschland",DJ:"Jabuuti",DK:"Danmark",DM:"Dominica",DO:Fb,DZ:"\u0627\u0644\u062c\u0632\u0627\u0626\u0631",
|
74 |
+
EC:"Ecuador",EE:"Eesti",EG:"\u0645\u0635\u0631",EH:Nd,ER:"\u0627\u0631\u064a\u062a\u0631\u064a\u0627",ES:"Espa\u00f1a",ET:X,FI:"Suomi",FJ:"\u092b\u093f\u091c\u0940",FK:fb,FM:C,FO:"F\u00f8royar",FR:"France",FX:"Metropolitan France",GA:"Gabon",GB:$b,GD:"Grenada",GE:"\u10e1\u10d0\u10e5\u10d0\u10e0\u10d7\u10d5\u10d4\u10da\u10dd",GF:hb,GG:"Guernsey",GH:B,GI:"Gibraltar",GL:nb,GM:"Gambia",GN:"Guin\u00e9e",GP:"Guadeloupe",GQ:gb,GR:"\u0395\u03bb\u03bb\u03ac\u03b4\u03b1",GS:"South Georgia and the South Sandwich Islands",
|
75 |
+
GT:"Guatemala",GU:"Guam",GW:"Guin\u00e9 Bissau",GY:"Guyana",HK:"\u9999\u6e2f",HM:"Heard Island and McDonald Islands",HN:jb,HR:"Hrvatska",HT:"Ha\u00efti",HU:"Magyarorsz\u00e1g",ID:kb,IE:"Ireland",IL:"\u05d9\u05e9\u05e8\u05d0\u05dc",IM:"Isle of Man",IN:W,IO:"British Indian Ocean Territory",IQ:"\u0627\u0644\u0639\u0631\u0627\u0642",IR:"\u0627\u06cc\u0631\u0627\u0646",IS:"\u00cdsland",IT:"Italia",JE:"Jersey",JM:"Jamaica",JO:"\u0627\u0644\u0623\u0631\u062f\u0646",JP:"\u65e5\u672c",KE:"Kenya",KG:Id,KH:"\u1780\u1798\u17d2\u1796\u17bb\u1787\u17b6",
|
76 |
+
KI:ob,KM:Qd,KN:Kb,KP:Sd,KR:"\ub300\ud55c\ubbfc\uad6d",KW:"\u0627\u0644\u0643\u0648\u064a\u062a",KY:Va,KZ:"\u041a\u0430\u0437\u0430\u0445\u0441\u0442\u0430\u043d",LA:"\u0e25\u0e32\u0e27",LB:"\u0644\u0628\u0646\u0627\u0646",LC:"Saint Lucia",LI:"Liechtenstein",LK:"\u0b87\u0bb2\u0b99\u0bcd\u0b95\u0bc8",LR:"Liberia",LS:"Lesotho",LT:"Lietuva",LU:sb,LV:"Latvija",LY:"\u0644\u064a\u0628\u064a\u0627",MA:"\u0627\u0644\u0645\u063a\u0631\u0628",MC:"Monaco",MD:vb,ME:"\u0426\u0440\u043d\u0430 \u0413\u043e\u0440\u0430",
|
77 |
+
MG:tb,MH:ub,MK:"\u041c\u0430\u043a\u0435\u0434\u043e\u043d\u0438\u0458\u0430",ML:"\u0645\u0627\u0644\u064a",MM:"Myanmar",MN:"\u8499\u53e4",MO:"\u6fb3\u95e8",MP:zb,MQ:"Martinique",MR:"\u0645\u0648\u0631\u064a\u062a\u0627\u0646\u064a\u0627",MS:"Montserrat",MT:"Malta",MU:"Mauritius",MV:"Maldives",MW:"Malawi",MX:"M\u00e9xico",MY:"Malaysia",MZ:"Mo\u00e7ambique",NA:"Namibia",NC:Ab,NE:"Niger",NF:yb,NG:D,NI:"Nicaragua",NL:"Nederland",NO:"Norge",NP:"\u0928\u0947\u092a\u093e\u0932",NR:"Nauru",NT:"Neutral Zone",
|
78 |
+
NU:"Niue",NZ:xb,OM:"\u0639\u0645\u0627\u0646",PA:"Panam\u00e1",PE:"Per\u00fa",PF:Db,PG:E,PH:Cb,PK:Rd,PL:"Polska",PM:Mb,PN:"Pitcairn",PR:Eb,PS:"\u0641\u0644\u0633\u0637\u064a\u0646",PT:"Portugal",PW:"Palau",PY:Bb,QA:"\u0642\u0637\u0631",QO:"Outlying Oceania",QU:"European Union",RE:"R\u00e9union",RO:"Rom\u00e2nia",RS:"\u0421\u0440\u0431\u0438\u0458\u0430",RU:"\u0420\u043e\u0441\u0441\u0438\u044f",RW:F,SA:Od,SB:Qb,SC:Ob,SD:"\u0627\u0644\u0633\u0648\u062f\u0627\u0646",SE:"Sverige",SG:"\u65b0\u52a0\u5761",
|
79 |
+
SH:"Saint Helena",SI:"Slovenija",SJ:Rb,SK:Pb,SL:"Sierra Leone",SM:"San Marino",SN:H,SO:"Somali",SR:"Suriname",ST:Vb,SU:"Union of Soviet Socialist Republics",SV:"El Salvador",SY:"\u0633\u0648\u0631\u064a\u0627",SZ:Ub,TC:Yb,TD:"\u062a\u0634\u0627\u062f",TF:"French Southern Territories",TG:"Togo",TH:"\u0e1b\u0e23\u0e30\u0e40\u0e17\u0e28\u0e44\u0e17\u0e22",TJ:"\u062a\u0627\u062c\u06cc\u06a9\u0633\u062a\u0627\u0646",TK:I,TL:Xb,TM:"\u0422\u0443\u0440\u043a\u043c\u0435\u043d\u0438\u0441\u0442\u0430\u043d",
|
80 |
+
TN:"\u062a\u0648\u0646\u0633",TO:"Tonga",TR:K,TT:"Trinidad y Tobago",TV:J,TW:"\u53f0\u6e7e",TZ:Wb,UA:"\u0423\u043a\u0440\u0430\u0457\u043d\u0430",UG:"Uganda",UM:bc,US:ac,UY:"Uruguay",UZ:"\u040e\u0437\u0431\u0435\u043a\u0438\u0441\u0442\u043e\u043d",VA:"Vaticano",VC:Lb,VE:"Venezuela",VG:Ua,VI:Zb,VN:"Vi\u1ec7t Nam",VU:L,WF:dc,WS:"Samoa",YD:"People's Democratic Republic of Yemen",YE:"\u0627\u0644\u064a\u0645\u0646",YT:"Mayotte",ZA:G,ZM:"Zambia",ZW:"Zimbabwe",ZZ:cc,aa_DJ:"Jabuuti",aa_ER:"\u00c9rythr\u00e9e",
|
81 |
+
aa_ER_SAAHO:"\u00c9rythr\u00e9e",aa_ET:lb,af_NA:"Namibi\u00eb",af_ZA:"Suid-Afrika",ak_GH:B,am_ET:X,ar_AE:Md,ar_BH:"\u0627\u0644\u0628\u062d\u0631\u064a\u0646",ar_DJ:"\u062c\u064a\u0628\u0648\u062a\u064a",ar_DZ:"\u0627\u0644\u062c\u0632\u0627\u0626\u0631",ar_EG:"\u0645\u0635\u0631",ar_EH:Nd,ar_ER:"\u0627\u0631\u064a\u062a\u0631\u064a\u0627",ar_IL:"\u0627\u0633\u0631\u0627\u0626\u064a\u0644",ar_IQ:"\u0627\u0644\u0639\u0631\u0627\u0642",ar_JO:"\u0627\u0644\u0623\u0631\u062f\u0646",ar_KM:Qd,ar_KW:"\u0627\u0644\u0643\u0648\u064a\u062a",
|
82 |
+
ar_LB:"\u0644\u0628\u0646\u0627\u0646",ar_LY:"\u0644\u064a\u0628\u064a\u0627",ar_MA:"\u0627\u0644\u0645\u063a\u0631\u0628",ar_MR:"\u0645\u0648\u0631\u064a\u062a\u0627\u0646\u064a\u0627",ar_OM:"\u0639\u0645\u0627\u0646",ar_PS:"\u0641\u0644\u0633\u0637\u064a\u0646",ar_QA:"\u0642\u0637\u0631",ar_SA:Od,ar_SD:"\u0627\u0644\u0633\u0648\u062f\u0627\u0646",ar_SY:"\u0633\u0648\u0631\u064a\u0627",ar_TD:"\u062a\u0634\u0627\u062f",ar_TN:"\u062a\u0648\u0646\u0633",ar_YE:"\u0627\u0644\u064a\u0645\u0646",as_IN:"\u09ad\u09be\u09f0\u09a4",
|
83 |
+
ay_BO:y,az_AZ:"Az\u0259rbaycan",az_Cyrl_AZ:"\u0410\u0437\u04d9\u0440\u0431\u0430\u0458\u04b9\u0430\u043d",az_Latn_AZ:"Azerbaycan",be_BY:Hd,bg_BG:"\u0411\u044a\u043b\u0433\u0430\u0440\u0438\u044f",bi_VU:L,bn_BD:"\u09ac\u09be\u0982\u09b2\u09be\u09a6\u09c7\u09b6",bn_IN:"\u09ad\u09be\u09b0\u09a4",bo_CN:"\u0f62\u0f92\u0fb1\u0f0b\u0f53\u0f42",bo_IN:"\u0f62\u0f92\u0fb1\u0f0b\u0f42\u0f62\u0f0b",bs_BA:z,byn_ER:"\u12a4\u122d\u1275\u122b",ca_AD:"Andorra",ca_ES:"Espanya",cch_NG:D,ch_GU:"Guam",chk_FM:C,cop_Arab_EG:"\u0645\u0635\u0631",
|
84 |
+
cop_Arab_US:Pd,cop_EG:"\u0645\u0635\u0631",cop_US:Pd,cs_CZ:Gd,cy_GB:"Prydain Fawr",da_DK:"Danmark",da_GL:"Gr\u00f8nland",de_AT:"\u00d6sterreich",de_BE:"Belgien",de_CH:"Schweiz",de_DE:"Deutschland",de_LI:"Liechtenstein",de_LU:"Luxemburg",dv_MV:"Maldives",dz_BT:"Bhutan",ee_GH:B,ee_TG:"Togo",efi_NG:D,el_CY:"\u039a\u03cd\u03c0\u03c1\u03bf\u03c2",el_GR:"\u0395\u03bb\u03bb\u03ac\u03b4\u03b1",en_AG:Qa,en_AI:"Anguilla",en_AS:Pa,en_AU:"Australia",en_BB:"Barbados",en_BE:"Belgium",en_BM:"Bermuda",en_BS:"Bahamas",
|
85 |
+
en_BW:Ta,en_BZ:"Belize",en_CA:"Canada",en_CC:"Cocos Islands",en_CK:"Cook Islands",en_CM:"Cameroon",en_CX:Wa,en_DM:"Dominica",en_FJ:"Fiji",en_FK:fb,en_FM:C,en_GB:$b,en_GD:"Grenada",en_GG:"Guernsey",en_GH:B,en_GI:"Gibraltar",en_GM:"Gambia",en_GU:"Guam",en_GY:"Guyana",en_HK:"Hong Kong",en_HN:jb,en_IE:"Ireland",en_IM:"Isle of Man",en_IN:"India",en_JE:"Jersey",en_JM:"Jamaica",en_KE:"Kenya",en_KI:ob,en_KN:Kb,en_KY:Va,en_LC:"Saint Lucia",en_LR:"Liberia",en_LS:"Lesotho",en_MH:ub,en_MP:zb,en_MS:"Montserrat",
|
86 |
+
en_MT:"Malta",en_MU:"Mauritius",en_MW:"Malawi",en_NA:"Namibia",en_NF:yb,en_NG:D,en_NR:"Nauru",en_NU:"Niue",en_NZ:xb,en_PG:E,en_PH:Cb,en_PK:"Pakistan",en_PN:"Pitcairn",en_PR:Eb,en_RW:F,en_SB:Qb,en_SC:Ob,en_SG:"Singapore",en_SH:"Saint Helena",en_SL:"Sierra Leone",en_SZ:Ub,en_TC:Yb,en_TK:I,en_TO:"Tonga",en_TT:"Trinidad and Tobago",en_TV:J,en_TZ:Wb,en_UG:"Uganda",en_UM:bc,en_US:ac,en_US_POSIX:ac,en_VC:Lb,en_VG:Ua,en_VI:Zb,en_VU:L,en_WS:"Samoa",en_ZA:G,en_ZM:"Zambia",en_ZW:"Zimbabwe",es_AR:"Argentina",
|
87 |
+
es_BO:y,es_CL:"Chile",es_CO:"Colombia",es_CR:"Costa Rica",es_CU:"Cuba",es_DO:Fb,es_EC:"Ecuador",es_ES:"Espa\u00f1a",es_GQ:"Guinea Ecuatorial",es_GT:"Guatemala",es_HN:jb,es_MX:"M\u00e9xico",es_NI:"Nicaragua",es_PA:"Panam\u00e1",es_PE:"Per\u00fa",es_PH:"Filipinas",es_PR:Eb,es_PY:Bb,es_SV:"El Salvador",es_US:"Estados Unidos",es_UY:"Uruguay",es_VE:"Venezuela",et_EE:"Eesti",eu_ES:"Espainia",fa_AF:Ld,fa_IR:"\u0627\u06cc\u0631\u0627\u0646",fi_FI:"Suomi",fil_PH:Cb,fj_FJ:"Fiji",fo_FO:"F\u00f8royar",fr_BE:"Belgique",
|
88 |
+
fr_BF:"Burkina Faso",fr_BI:"Burundi",fr_BJ:"B\u00e9nin",fr_CA:"Canada",fr_CD:Ib,fr_CF:Hb,fr_CG:"Congo",fr_CH:"Suisse",fr_CI:"C\u00f4te d\u2019Ivoire",fr_CM:"Cameroun",fr_DJ:"Djibouti",fr_DZ:"Alg\u00e9rie",fr_FR:"France",fr_GA:"Gabon",fr_GF:hb,fr_GN:"Guin\u00e9e",fr_GP:"Guadeloupe",fr_GQ:gb,fr_HT:"Ha\u00efti",fr_KM:"Comores",fr_LU:sb,fr_MA:"Maroc",fr_MC:"Monaco",fr_MG:tb,fr_ML:"Mali",fr_MQ:"Martinique",fr_MU:"Maurice",fr_NC:Ab,fr_NE:"Niger",fr_PF:Db,fr_PM:Mb,fr_RE:"R\u00e9union",fr_RW:F,fr_SC:Ob,fr_SN:H,
|
89 |
+
fr_SY:"Syrie",fr_TD:"Tchad",fr_TG:"Togo",fr_TN:"Tunisie",fr_VU:L,fr_WF:dc,fr_YT:"Mayotte",fur_IT:"Italia",ga_IE:"\u00c9ire",gaa_GH:B,gez_ER:"\u12a4\u122d\u1275\u122b",gez_ET:X,gil_KI:ob,gl_ES:"Espa\u00f1a",gn_PY:Bb,gu_IN:"\u0aad\u0abe\u0ab0\u0aa4",gv_GB:Gb,ha_Arab_NG:"\u0646\u064a\u062c\u064a\u0631\u064a\u0627",ha_GH:"\u063a\u0627\u0646\u0627",ha_Latn_GH:B,ha_Latn_NE:"Niger",ha_Latn_NG:"Nig\u00e9ria",ha_NE:"\u0627\u0644\u0646\u064a\u062c\u0631",ha_NG:"\u0646\u064a\u062c\u064a\u0631\u064a\u0627",haw_US:"\u02bbAmelika Hui P\u016b \u02bbIa",
|
90 |
+
he_IL:"\u05d9\u05e9\u05e8\u05d0\u05dc",hi_IN:W,ho_PG:E,hr_BA:z,hr_HR:"Hrvatska",ht_HT:"Ha\u00efti",hu_HU:"Magyarorsz\u00e1g",hy_AM:Kd,hy_AM_REVISED:Kd,id_ID:kb,ig_NG:D,ii_CN:"\ua34f\ua1e9",is_IS:"\u00cdsland",it_CH:"Svizzera",it_IT:"Italia",it_SM:"San Marino",ja_JP:"\u65e5\u672c",ka_GE:"\u10e1\u10d0\u10e5\u10d0\u10e0\u10d7\u10d5\u10d4\u10da\u10dd",kaj_NG:D,kam_KE:"Kenya",kcg_NG:D,kfo_NG:"Nig\u00e9ria",kk_KZ:"\u049a\u0430\u0437\u0430\u049b\u0441\u0442\u0430\u043d",kl_GL:nb,km_KH:"\u1780\u1798\u17d2\u1796\u17bb\u1787\u17b6",
|
91 |
+
kn_IN:"\u0cad\u0cbe\u0cb0\u0ca4",ko_KP:Sd,ko_KR:"\ub300\ud55c\ubbfc\uad6d",kok_IN:W,kos_FM:C,kpe_GN:"Guin\u00e9e",kpe_LR:"Lib\u00e9ria",ks_IN:W,ku_IQ:"Irak",ku_IR:"\u0130ran",ku_Latn_IQ:"Irak",ku_Latn_IR:"\u0130ran",ku_Latn_SY:"Suriye",ku_Latn_TR:K,ku_SY:"Suriye",ku_TR:K,kw_GB:Gb,ky_Cyrl_KG:Id,ky_KG:"K\u0131rg\u0131zistan",la_VA:"Vaticano",lb_LU:sb,ln_CD:Ib,ln_CG:"Kongo",lo_LA:"Laos",lt_LT:"Lietuva",lv_LV:"Latvija",mg_MG:tb,mh_MH:ub,mi_NZ:xb,mk_MK:"\u041c\u0430\u043a\u0435\u0434\u043e\u043d\u0438\u0458\u0430",
|
92 |
+
ml_IN:"\u0d07\u0d28\u0d4d\u0d24\u0d4d\u0d2f",mn_Cyrl_MN:"\u041c\u043e\u043d\u0433\u043e\u043b\u0438\u044f",mn_MN:"\u041c\u043e\u043d\u0433\u043e\u043b\u0438\u044f",mr_IN:W,ms_BN:"Brunei",ms_MY:"Malaysia",ms_SG:"Singapura",mt_MT:"Malta",my_MM:"Myanmar",na_NR:"Nauru",nb_NO:"Norge",nb_SJ:Rb,ne_NP:"\u0928\u0947\u092a\u093e\u0932",niu_NU:"Niue",nl_AN:wb,nl_AW:"Aruba",nl_BE:"Belgi\u00eb",nl_NL:"Nederland",nl_SR:"Suriname",nn_NO:"Noreg",nr_ZA:G,nso_ZA:G,ny_MW:"Malawi",om_ET:lb,om_KE:"Keeniyaa",or_IN:"\u0b2d\u0b3e\u0b30\u0b24",
|
93 |
+
pa_Arab_PK:Rd,pa_Guru_IN:"\u0a2d\u0a3e\u0a30\u0a24",pa_IN:"\u0a2d\u0a3e\u0a30\u0a24",pa_PK:Rd,pap_AN:wb,pau_PW:"Palau",pl_PL:"Polska",pon_FM:C,ps_AF:Ld,pt_AO:"Angola",pt_BR:"Brasil",pt_CV:"Cabo Verde",pt_GW:"Guin\u00e9 Bissau",pt_MZ:"Mo\u00e7ambique",pt_PT:"Portugal",pt_ST:Vb,pt_TL:Xb,qu_BO:y,qu_PE:"Per\u00fa",rm_CH:"Schweiz",rn_BI:"Burundi",ro_MD:vb,ro_RO:"Rom\u00e2nia",ru_BY:Hd,ru_KG:Id,ru_KZ:"\u041a\u0430\u0437\u0430\u0445\u0441\u0442\u0430\u043d",ru_RU:"\u0420\u043e\u0441\u0441\u0438\u044f",ru_UA:"\u0423\u043a\u0440\u0430\u0438\u043d\u0430",
|
94 |
+
rw_RW:F,sa_IN:W,sd_Deva_IN:W,sd_IN:W,se_FI:"Finland",se_NO:"Norge",sg_CF:Hb,sh_BA:"Bosnia and Herzegovina",sh_CS:Nb,si_LK:"Sri Lanka",sid_ET:lb,sk_SK:Pb,sl_SI:"Slovenija",sm_AS:Pa,sm_WS:"Samoa",so_DJ:"Jabuuti",so_ET:"Itoobiya",so_KE:"Kiiniya",so_SO:"Soomaaliya",sq_AL:"Shqip\u00ebria",sr_BA:"\u0411\u043e\u0441\u043d\u0430 \u0438 \u0425\u0435\u0440\u0446\u0435\u0433\u043e\u0432\u0438\u043d\u0430",sr_CS:"\u0421\u0440\u0431\u0438\u0458\u0430 \u0438 \u0426\u0440\u043d\u0430 \u0413\u043e\u0440\u0430",sr_Cyrl_BA:"\u0411\u043e\u0441\u043d\u0438\u044f",
|
95 |
+
sr_Cyrl_CS:"\u0421\u0435\u0440\u0431\u0438\u044f \u0438 \u0427\u0435\u0440\u043d\u043e\u0433\u043e\u0440\u0438\u044f",sr_Cyrl_ME:"\u0427\u0435\u0440\u043d\u043e\u0433\u043e\u0440\u0438\u044f",sr_Cyrl_RS:"\u0421\u0435\u0440\u0431\u0438\u044f",sr_Latn_BA:z,sr_Latn_CS:"Srbija i Crna Gora",sr_Latn_ME:"Crna Gora",sr_Latn_RS:"Srbija",sr_ME:"\u0426\u0440\u043d\u0430 \u0413\u043e\u0440\u0430",sr_RS:"\u0421\u0440\u0431\u0438\u0458\u0430",ss_SZ:Ub,ss_ZA:G,st_LS:"Lesotho",st_ZA:G,su_ID:kb,sv_AX:"\u00c5land",
|
96 |
+
sv_FI:"Finland",sv_SE:"Sverige",sw_KE:"Kenya",sw_TZ:Wb,sw_UG:"Uganda",swb_KM:Qd,syr_SY:"Syria",ta_IN:"\u0b87\u0ba8\u0bcd\u0ba4\u0bbf\u0baf\u0bbe",ta_LK:"\u0b87\u0bb2\u0b99\u0bcd\u0b95\u0bc8",ta_SG:"\u0b9a\u0bbf\u0b99\u0bcd\u0b95\u0baa\u0bcd\u0baa\u0bc2\u0bb0\u0bcd",te_IN:"\u0c2d\u0c3e\u0c30\u0c24 \u0c26\u0c47\u0c33\u0c02",tet_TL:Xb,tg_Cyrl_TJ:"\u0422\u0430\u0434\u0436\u0438\u043a\u0438\u0441\u0442\u0430\u043d",tg_TJ:"\u062a\u0627\u062c\u06a9\u0633\u062a\u0627\u0646",th_TH:"\u0e1b\u0e23\u0e30\u0e40\u0e17\u0e28\u0e44\u0e17\u0e22",
|
97 |
+
ti_ER:"\u12a4\u122d\u1275\u122b",ti_ET:X,tig_ER:"\u12a4\u122d\u1275\u122b",tk_TM:"\u062a\u0631\u06a9\u0645\u0646\u0633\u062a\u0627\u0646",tkl_TK:I,tn_BW:Ta,tn_ZA:G,to_TO:"Tonga",tpi_PG:E,tr_CY:"G\u00fcney K\u0131br\u0131s Rum Kesimi",tr_TR:K,ts_ZA:G,tt_RU:"\u0420\u043e\u0441\u0441\u0438\u044f",tvl_TV:J,ty_PF:Db,uk_UA:"\u0423\u043a\u0440\u0430\u0457\u043d\u0430",uli_FM:C,und_ZZ:cc,ur_IN:"\u0628\u06be\u0627\u0631\u062a",ur_PK:Rd,uz_AF:"Afganistan",uz_Arab_AF:Ld,uz_Cyrl_UZ:"\u0423\u0437\u0431\u0435\u043a\u0438\u0441\u0442\u0430\u043d",
|
98 |
+
uz_Latn_UZ:"O\u02bfzbekiston",uz_UZ:"\u040e\u0437\u0431\u0435\u043a\u0438\u0441\u0442\u043e\u043d",ve_ZA:G,vi_VN:"Vi\u1ec7t Nam",wal_ET:X,wo_Arab_SN:"\u0627\u0644\u0633\u0646\u063a\u0627\u0644",wo_Latn_SN:H,wo_SN:H,xh_ZA:G,yap_FM:C,yo_NG:D,zh_CN:"\u4e2d\u56fd",zh_HK:"\u9999\u6e2f",zh_Hans_CN:"\u4e2d\u56fd",zh_Hans_SG:"\u65b0\u52a0\u5761",zh_Hant_HK:"\u4e2d\u83ef\u4eba\u6c11\u5171\u548c\u570b\u9999\u6e2f\u7279\u5225\u884c\u653f\u5340",zh_Hant_MO:"\u6fb3\u9580",zh_Hant_TW:"\u81fa\u7063",zh_MO:"\u6fb3\u95e8",
|
99 |
+
zh_SG:"\u65b0\u52a0\u5761",zh_TW:"\u53f0\u6e7e",zu_ZA:G},LANGUAGE:{aa:"afar",ab:"\u0430\u0431\u0445\u0430\u0437\u0441\u043a\u0438\u0439",ace:"Aceh",ach:"Acoli",ada:"Adangme",ady:"\u0430\u0434\u044b\u0433\u0435\u0439\u0441\u043a\u0438\u0439",ae:"Avestan",af:"Afrikaans",afa:"Afro-Asiatic Language",afh:"Afrihili",ain:"Ainu",ak:"Akan",akk:"Akkadian",ale:"Aleut",alg:"Algonquian Language",alt:"Southern Altai",am:"\u12a0\u121b\u122d\u129b",an:"Aragonese",ang:"Old English",anp:"Angika",apa:"Apache Language",
|
100 |
+
ar:"\u0627\u0644\u0639\u0631\u0628\u064a\u0629",arc:"Aramaic",arn:"Araucanian",arp:"Arapaho",art:"Artificial Language",arw:"Arawak",as:"\u0985\u09b8\u09ae\u09c0\u09af\u09bc\u09be",ast:"asturiano",ath:"Athapascan Language",aus:"Australian Language",av:"\u0430\u0432\u0430\u0440\u0441\u043a\u0438\u0439",awa:"Awadhi",ay:"aimara",az:"az\u0259rbaycanca",az_Arab:"\u062a\u0631\u06a9\u06cc \u0622\u0630\u0631\u0628\u0627\u06cc\u062c\u0627\u0646\u06cc",az_Cyrl:"\u0410\u0437\u04d9\u0440\u0431\u0430\u0458\u04b9\u0430\u043d",
|
101 |
+
az_Latn:"Azerice",ba:"\u0431\u0430\u0448\u043a\u0438\u0440\u0441\u043a\u0438\u0439",bad:"Banda",bai:"Bamileke Language",bal:"\u0628\u0644\u0648\u0686\u06cc",ban:"Balin",bas:"Basa",bat:"Baltic Language",be:"\u0431\u0435\u043b\u0430\u0440\u0443\u0441\u043a\u0430\u044f",bej:"Beja",bem:"Bemba",ber:"Berber",bg:"\u0431\u044a\u043b\u0433\u0430\u0440\u0441\u043a\u0438",bh:"\u092c\u093f\u0939\u093e\u0930\u0940",bho:"Bhojpuri",bi:"bichelamar ; bislama",bik:"Bikol",bin:"Bini",bla:"Siksika",bm:"bambara",bn:"\u09ac\u09be\u0982\u09b2\u09be",
|
102 |
+
bnt:"Bantu",bo:"\u0f54\u0f7c\u0f51\u0f0b\u0f66\u0f90\u0f51\u0f0b",br:"breton",bra:"Braj",bs:"Bosanski",btk:"Batak",bua:"Buriat",bug:"Bugis",byn:"\u1265\u120a\u1295",ca:"catal\u00e0",cad:"Caddo",cai:"Central American Indian Language",car:"Carib",cau:"Caucasian Language",cch:"Atsam",ce:"\u0447\u0435\u0447\u0435\u043d\u0441\u043a\u0438\u0439",ceb:"Cebuano",cel:"Celtic Language",ch:"Chamorro",chb:"Chibcha",chg:"Chagatai",chk:"Chuukese",chm:"\u043c\u0430\u0440\u0438\u0439\u0441\u043a\u0438\u0439 (\u0447\u0435\u0440\u0435\u043c\u0438\u0441\u0441\u043a\u0438\u0439)",
|
103 |
+
chn:"Chinook Jargon",cho:"Choctaw",chp:"Chipewyan",chr:"Cherokee",chy:"Cheyenne",cmc:"Chamic Language",co:"corse",cop:"\u0642\u0628\u0637\u064a\u0629",cop_Arab:"\u0642\u0628\u0637\u064a\u0629",cpe:"English-based Creole or Pidgin",cpf:"French-based Creole or Pidgin",cpp:"Portuguese-based Creole or Pidgin",cr:"Cree",crh:"Crimean Turkish",crp:"Creole or Pidgin",cs:"\u010de\u0161tina",csb:"Kashubian",cu:"Church Slavic",cus:"Cushitic Language",cv:"\u0447\u0443\u0432\u0430\u0448\u0441\u043a\u0438\u0439",
|
104 |
+
cy:"Cymraeg",da:"dansk",dak:"Dakota",dar:"\u0434\u0430\u0440\u0433\u0432\u0430",day:"Dayak",de:"Deutsch",del:"Delaware",den:"Slave",dgr:"Dogrib",din:"Dinka",doi:"\u0627\u0644\u062f\u0648\u062c\u0631\u0649",dra:"Dravidian Language",dsb:"Lower Sorbian",dua:"Duala",dum:"Middle Dutch",dv:"Divehi",dyu:"dioula",dz:"\u0f62\u0fab\u0f7c\u0f44\u0f0b\u0f41",ee:"Ewe",efi:"Efik",egy:"Ancient Egyptian",eka:"Ekajuk",el:"\u0395\u03bb\u03bb\u03b7\u03bd\u03b9\u03ba\u03ac",elx:"Elamite",en:"English",enm:"Middle English",
|
105 |
+
eo:"esperanto",es:"espa\u00f1ol",et:"eesti",eu:"euskara",ewo:"Ewondo",fa:"\u0641\u0627\u0631\u0633\u06cc",fan:"fang",fat:"Fanti",ff:"Fulah",fi:"suomi",fil:"Filipino",fiu:"Finno-Ugrian Language",fj:"Fijian",fo:"f\u00f8royskt",fon:"Fon",fr:"fran\u00e7ais",frm:"Middle French",fro:"Old French",frr:"Northern Frisian",frs:"Eastern Frisian",fur:"friulano",fy:"Fries",ga:"Gaeilge",gaa:"Ga",gay:"Gayo",gba:"Gbaya",gd:"Scottish Gaelic",gem:"Germanic Language",gez:"\u130d\u12d5\u12dd\u129b",gil:"Gilbertese",gl:"galego",
|
106 |
+
gmh:"Middle High German",gn:"guaran\u00ed",goh:"Old High German",gon:"Gondi",gor:"Gorontalo",got:"Gothic",grb:"Grebo",grc:"\u0391\u03c1\u03c7\u03b1\u03af\u03b1 \u0395\u03bb\u03bb\u03b7\u03bd\u03b9\u03ba\u03ac",gsw:"Schweizerdeutsch",gu:"\u0a97\u0ac1\u0a9c\u0ab0\u0abe\u0aa4\u0ac0",gv:"Gaelg",gwi:"Gwich\u02bcin",ha:"\u0627\u0644\u0647\u0648\u0633\u0627",ha_Arab:"\u0627\u0644\u0647\u0648\u0633\u0627",ha_Latn:"haoussa",hai:"Haida",haw:"\u02bb\u014dlelo Hawai\u02bbi",he:"\u05e2\u05d1\u05e8\u05d9\u05ea",
|
107 |
+
hi:"\u0939\u093f\u0902\u0926\u0940",hil:"Hiligaynon",him:"Himachali",hit:"Hittite",hmn:"Hmong",ho:"Hiri Motu",hr:"hrvatski",hsb:"Upper Sorbian",ht:"ha\u00eftien",hu:"magyar",hup:"Hupa",hy:"\u0540\u0561\u0575\u0565\u0580\u0567\u0576",hz:"Herero",ia:"interlingvao",iba:"Iban",id:"Bahasa Indonesia",ie:"Interlingue",ig:"Igbo",ii:"\ua188\ua320\ua259",ijo:"Ijo",ik:"Inupiaq",ilo:"Iloko",inc:"Indic Language",ine:"Indo-European Language",inh:"\u0438\u043d\u0433\u0443\u0448\u0441\u043a\u0438\u0439",io:"Ido",
|
108 |
+
ira:"Iranian Language",iro:"Iroquoian Language",is:"\u00edslenska",it:"italiano",iu:"Inuktitut",ja:"\u65e5\u672c\u8a9e",jbo:"Lojban",jpr:"Judeo-Persian",jrb:"Judeo-Arabic",jv:"Jawa",ka:"\u10e5\u10d0\u10e0\u10d7\u10e3\u10da\u10d8",kaa:"\u043a\u0430\u0440\u0430\u043a\u0430\u043b\u043f\u0430\u043a\u0441\u043a\u0438\u0439",kab:"kabyle",kac:"Kachin",kaj:"Jju",kam:"Kamba",kar:"Karen",kaw:"Kawi",kbd:"\u043a\u0430\u0431\u0430\u0440\u0434\u0438\u043d\u0441\u043a\u0438\u0439",kcg:"Tyap",kfo:"koro",kg:"Kongo",
|
109 |
+
kha:"Khasi",khi:"Khoisan Language",kho:"Khotanese",ki:"Kikuyu",kj:"Kuanyama",kk:"\u049a\u0430\u0437\u0430\u049b",kl:"kalaallisut",km:"\u1797\u17b6\u179f\u17b6\u1781\u17d2\u1798\u17c2\u179a",kmb:"quimbundo",kn:"\u0c95\u0ca8\u0ccd\u0ca8\u0ca1",ko:"\ud55c\uad6d\uc5b4",kok:"\u0915\u094b\u0902\u0915\u0923\u0940",kos:"Kosraean",kpe:"kpell\u00e9",kr:"Kanuri",krc:"\u043a\u0430\u0440\u0430\u0447\u0430\u0435\u0432\u043e-\u0431\u0430\u043b\u043a\u0430\u0440\u0441\u043a\u0438\u0439",krl:"\u043a\u0430\u0440\u0435\u043b\u044c\u0441\u043a\u0438\u0439",
|
110 |
+
kro:"Kru",kru:"Kurukh",ks:"\u0915\u093e\u0936\u094d\u092e\u093f\u0930\u0940",ku:"K\u00fcrt\u00e7e",ku_Arab:"\u0627\u0644\u0643\u0631\u062f\u064a\u0629",ku_Latn:"K\u00fcrt\u00e7e",kum:"\u043a\u0443\u043c\u044b\u043a\u0441\u043a\u0438\u0439",kut:"Kutenai",kv:"Komi",kw:"kernewek",ky:"K\u0131rg\u0131zca",ky_Arab:"\u0627\u0644\u0642\u064a\u0631\u063a\u0633\u062a\u0627\u0646\u064a\u0629",ky_Cyrl:"\u043a\u0438\u0440\u0433\u0438\u0437\u0441\u043a\u0438\u0439",la:"latino",lad:"\u05dc\u05d3\u05d9\u05e0\u05d5",
|
111 |
+
lah:"\u0644\u0627\u0647\u0646\u062f\u0627",lam:"Lamba",lb:"luxembourgeois",lez:"\u043b\u0435\u0437\u0433\u0438\u043d\u0441\u043a\u0438\u0439",lg:"Ganda",li:"Limburgs",ln:"lingala",lo:"Lao",lol:"mongo",loz:"Lozi",lt:"lietuvi\u0173",lu:"luba-katanga",lua:"luba-lulua",lui:"Luiseno",lun:"Lunda",luo:"Luo",lus:"Lushai",lv:"latvie\u0161u",mad:"Madura",mag:"Magahi",mai:"Maithili",mak:"Makassar",man:"Mandingo",map:"Austronesian",mas:"Masai",mdf:"\u043c\u043e\u043a\u0448\u0430",mdr:"Mandar",men:"Mende",mg:"malgache",
|
112 |
+
mga:"Middle Irish",mh:"Marshallese",mi:"Maori",mic:"Micmac",min:"Minangkabau",mis:"Miscellaneous Language",mk:"\u043c\u0430\u043a\u0435\u0434\u043e\u043d\u0441\u043a\u0438",mkh:"Mon-Khmer Language",ml:"\u0d2e\u0d32\u0d2f\u0d3e\u0d33\u0d02",mn:Jd,mn_Cyrl:Jd,mn_Mong:Jd,mnc:"Manchu",mni:"Manipuri",mno:"Manobo Language",mo:"Moldavian",moh:"Mohawk",mos:"mor\u00e9 ; mossi",mr:"\u092e\u0930\u093e\u0920\u0940",ms:"Bahasa Melayu",mt:"Malti",mul:"Multiple Languages",mun:"Munda Language",mus:"Creek",mwl:"Mirandese",
|
113 |
+
mwr:"Marwari",my:"Burmese",myn:"Mayan Language",myv:"\u044d\u0440\u0437\u044f",na:"Nauru",nah:"Nahuatl",nai:"North American Indian Language",nap:"napoletano",nb:"norsk bokm\u00e5l",nd:"North Ndebele",nds:"Low German",ne:"\u0928\u0947\u092a\u093e\u0932\u0940","new":"Newari",ng:"Ndonga",nia:"Nias",nic:"Niger-Kordofanian Language",niu:"Niuean",nl:"Nederlands",nn:"nynorsk",no:"Norwegian",nog:"\u043d\u043e\u0433\u0430\u0439\u0441\u043a\u0438\u0439",non:"Old Norse",nqo:"N\u2019Ko",nr:"South Ndebele",nso:"Northern Sotho",
|
114 |
+
nub:"Nubian Language",nv:"Navajo",nwc:"Classical Newari",ny:"nianja; chicheua; cheua",nym:"Nyamwezi",nyn:"Nyankole",nyo:"Nyoro",nzi:"Nzima",oc:"occitan",oj:"Ojibwa",om:"Oromoo",or:"\u0b13\u0b21\u0b3c\u0b3f\u0b06",os:"\u043e\u0441\u0435\u0442\u0438\u043d\u0441\u043a\u0438\u0439",osa:"Osage",ota:"Ottoman Turkish",oto:"Otomian Language",pa:"\u0a2a\u0a70\u0a1c\u0a3e\u0a2c\u0a40",pa_Arab:"\u067e\u0646\u062c\u0627\u0628",pa_Guru:"\u0a2a\u0a70\u0a1c\u0a3e\u0a2c\u0a40",paa:"Papuan Language",pag:"Pangasinan",
|
115 |
+
pal:"Pahlavi",pam:"Pampanga",pap:"Papiamento",pau:"Palauan",peo:"Old Persian",phi:"Philippine Language",phn:"Phoenician",pi:"\u0e1a\u0e32\u0e25\u0e35",pl:"polski",pon:"Pohnpeian",pra:"Prakrit Language",pro:"Old Proven\u00e7al",ps:"\u067e\u069a\u062a\u0648",pt:"portugu\u00eas",qu:"quechua",raj:"Rajasthani",rap:"Rapanui",rar:"Rarotongan",rm:"R\u00e4toromanisch",rn:"roundi",ro:"rom\u00e2n\u0103",roa:"Romance Language",rom:"Romany",ru:"\u0440\u0443\u0441\u0441\u043a\u0438\u0439",rup:"Aromanian",rw:"rwanda",
|
116 |
+
sa:"\u0938\u0902\u0938\u094d\u0915\u0943\u0924 \u092d\u093e\u0937\u093e",sad:"Sandawe",sah:"\u044f\u043a\u0443\u0442\u0441\u043a\u0438\u0439",sai:"South American Indian Language",sal:"Salishan Language",sam:"\u05d0\u05e8\u05de\u05d9\u05ea \u05e9\u05d5\u05de\u05e8\u05d5\u05e0\u05d9\u05ea",sas:"Sasak",sat:"Santali",sc:"Sardinian",scn:"siciliano",sco:"Scots",sd:"\u0938\u093f\u0928\u094d\u0927\u0940",sd_Arab:"\u0633\u0646\u062f\u06cc",sd_Deva:"\u0938\u093f\u0928\u094d\u0927\u0940",se:"nordsamiska",sel:"\u0441\u0435\u043b\u044c\u043a\u0443\u043f\u0441\u043a\u0438\u0439",
|
117 |
+
sem:"Semitic Language",sg:"sangho",sga:"Old Irish",sgn:"Sign Language",sh:"Serbo-Croatian",shn:"Shan",si:"Sinhalese",sid:"Sidamo",sio:"Siouan Language",sit:"Sino-Tibetan Language",sk:"slovensk\u00fd",sl:"sloven\u0161\u010dina",sla:"Slavic Language",sm:"Samoan",sma:"sydsamiska",smi:"Sami Language",smj:"lulesamiska",smn:"Inari Sami",sms:"Skolt Sami",sn:"Shona",snk:"sonink\u00e9",so:"Soomaali",sog:"Sogdien",son:"Songhai",sq:"shqipe",sr:"\u0421\u0440\u043f\u0441\u043a\u0438",sr_Cyrl:"\u0441\u0435\u0440\u0431\u0441\u043a\u0438\u0439",
|
118 |
+
sr_Latn:"Srpski",srn:"Sranantongo",srr:"s\u00e9r\u00e8re",ss:"Swati",ssa:"Nilo-Saharan Language",st:"Sesotho",su:"Sundan",suk:"Sukuma",sus:"soussou",sux:"Sumerian",sv:"svenska",sw:"Kiswahili",syc:"Classical Syriac",syr:"Syriac",ta:"\u0ba4\u0bae\u0bbf\u0bb4\u0bcd",tai:"Tai Language",te:"\u0c24\u0c46\u0c32\u0c41\u0c17\u0c41",tem:"Timne",ter:"Tereno",tet:"t\u00e9tum",tg:"\u062a\u0627\u062c\u06a9",tg_Arab:"\u062a\u0627\u062c\u06a9",tg_Cyrl:"\u0442\u0430\u0434\u0436\u0438\u043a\u0441\u043a\u0438\u0439",
|
119 |
+
th:"\u0e44\u0e17\u0e22",ti:"\u1275\u130d\u122d\u129b",tig:"\u1275\u130d\u1228",tiv:"Tiv",tk:"\u062a\u0631\u06a9\u0645\u0646\u06cc",tkl:I,tl:"Tagalog",tlh:"Klingon",tli:"Tlingit",tmh:"tamacheq",tn:"Tswana",to:"Tonga",tog:"Nyasa Tonga",tpi:"Tok Pisin",tr:"T\u00fcrk\u00e7e",ts:"Tsonga",tsi:"Tsimshian",tt:"\u0442\u0430\u0442\u0430\u0440\u0441\u043a\u0438\u0439",tum:"Tumbuka",tup:"Tupi Language",tut:"\u0430\u043b\u0442\u0430\u0439\u0441\u043a\u0438\u0435 (\u0434\u0440\u0443\u0433\u0438\u0435)",tvl:J,tw:"Twi",
|
120 |
+
ty:"tahitien",tyv:"\u0442\u0443\u0432\u0438\u043d\u0441\u043a\u0438\u0439",udm:"\u0443\u0434\u043c\u0443\u0440\u0442\u0441\u043a\u0438\u0439",ug:"\u0443\u0439\u0433\u0443\u0440\u0441\u043a\u0438\u0439",uga:"Ugaritic",uk:"\u0443\u043a\u0440\u0430\u0457\u043d\u0441\u044c\u043a\u0430",umb:"umbundu",und:"English",ur:"\u0627\u0631\u062f\u0648",uz:"\u040e\u0437\u0431\u0435\u043a",uz_Arab:"\u0627\u06c9\u0632\u0628\u06d0\u06a9",uz_Cyrl:"\u0443\u0437\u0431\u0435\u043a\u0441\u043a\u0438\u0439",uz_Latn:"o'zbekcha",
|
121 |
+
vai:"Vai",ve:"Venda",vi:"Ti\u1ebfng Vi\u1ec7t",vo:"volapuko",vot:"Votic",wa:"Wallonisch",wak:"Wakashan Language",wal:"Walamo",war:"Waray",was:"Washo",wen:"Sorbian Language",wo:"wolof",wo_Arab:"\u0627\u0644\u0648\u0644\u0648\u0641",wo_Latn:"wolof",xal:"\u043a\u0430\u043b\u043c\u044b\u0446\u043a\u0438\u0439",xh:"Xhosa",yao:"iao",yap:"Yapese",yi:"\u05d9\u05d9\u05d3\u05d9\u05e9",yo:"Yoruba",ypk:"Yupik Language",za:"Zhuang",zap:"Zapotec",zen:"Zenaga",zh:"\u4e2d\u6587",zh_Hans:"\u4e2d\u6587",zh_Hant:"\u4e2d\u6587",
|
122 |
+
znd:"Zande",zu:"Zulu",zun:"Zuni",zxx:"No linguistic content",zza:"Zaza"}};Z.locale.Yf=function(a){a=a.replace(/-/g,M);Z.locale.N=a};Z.locale.Fa=function(){Z.locale.N||(Z.locale.N=yc);return Z.locale.N};Z.locale.I={vd:"DateTimeConstants",Ed:"NumberFormatConstants",gc:"TimeZoneConstants",Wb:rb,hc:"TimeZoneSelectedIds",jc:"TimeZoneSelectedShortNames",ic:"TimeZoneSelectedLongNames",fc:"TimeZoneAllLongNames"};Z.locale.Ea=function(a){return(a=a.match(/^\w{2,3}([-_]|$)/))?a[0].replace(/[_-]/g,b):b};
|
123 |
+
Z.locale.mb=function(a){return(a=a.match(/[-_]([a-zA-Z]{2}|\d{3})([-_]|$)/))?a[0].replace(/[_-]/g,b):b};Z.locale.Pe=function(a){a=a.split(/[-_]/g);return 1<a.length&&a[1].match(/^[a-zA-Z]{4}$/)?a[1]:b};Z.locale.Qe=function(a){return(a=a.match(/[-_]([a-z]{2,})/))?a[1]:b};Z.locale.Le=function(a){var c=Z.locale.Ea(a)+M+Z.locale.mb(a);return c in Z.locale.J.COUNTRY?Z.locale.J.COUNTRY[c]:a};Z.locale.He=function(a,c){c||(c=Z.locale.ob());var d=Z.locale.mb(a);return d in c.COUNTRY?c.COUNTRY[d]:a};
|
124 |
+
Z.locale.Me=function(a){if(a in Z.locale.J.LANGUAGE)return Z.locale.J.LANGUAGE[a];var c=Z.locale.Ea(a);return c in Z.locale.J.LANGUAGE?Z.locale.J.LANGUAGE[c]:a};Z.locale.Ie=function(a,c){c||(c=Z.locale.ob());if(a in c.LANGUAGE)return c.LANGUAGE[a];var d=Z.locale.Ea(a);return d in c.LANGUAGE?c.LANGUAGE[d]:a};Z.locale.K=function(a,c,d){Z.locale.l[c]||(Z.locale.l[c]={});Z.locale.l[c][d]=a;Z.locale.N||(Z.locale.N=d)};Z.locale.jf=function(a,c){return a in Z.locale.l&&c in Z.locale.l[a]};Z.locale.l={};
|
125 |
+
Z.locale.Kf=function(a,c){Z.locale.K(a,Z.locale.I.gc,c)};Z.locale.If=function(a,c){Z.locale.K(a,Z.locale.I.Wb,c)};Z.locale.Lf=function(a,c){Z.locale.K(a,Z.locale.I.hc,c)};Z.locale.Nf=function(a,c){Z.locale.K(a,Z.locale.I.jc,c)};Z.locale.Mf=function(a,c){Z.locale.K(a,Z.locale.I.ic,c)};Z.locale.Jf=function(a,c){Z.locale.K(a,Z.locale.I.fc,c)};Z.locale.ob=function(){var a=Z.locale.Fa(),a=a?a:Z.locale.Fa();return rb in Z.locale.l?Z.locale.l.LocaleNameConstants[a]:void 0};
|
126 |
+
Z.locale.Oe=function(a,c){var d=c?c:Z.locale.Fa();if(a in Z.locale.l){if(d in Z.locale.l[a])return Z.locale.l[a][d];d=d.split(M);return 1<d.length&&d[0]in Z.locale.l[a]?Z.locale.l[a][d[0]]:Z.locale.l[a].en}};var google={a:{}};google.a.b={};
|
127 |
+
google.a.b.languages={af:!0,am:!0,az:!0,ar:!0,arb:"ar",bg:!0,bn:!0,ca:!0,cs:!0,cmn:"zh",da:!0,de:!0,el:!0,en:!0,en_gb:!0,es:!0,es_419:!0,et:!0,eu:!0,fa:!0,fi:!0,fil:!0,fr:!0,fr_ca:!0,gl:!0,ka:!0,gu:!0,he:"iw",hi:!0,hr:!0,hu:!0,hy:!0,id:!0,"in":Oc,is:!0,it:!0,iw:!0,ja:!0,ji:"yi",jv:!1,jw:"jv",km:!0,kn:!0,ko:!0,lo:!0,lt:!0,lv:!0,ml:!0,mn:!0,mo:"ro",mr:!0,ms:!0,nb:"no",ne:!0,nl:!0,no:!0,pl:!0,pt:"pt_br",pt_br:!0,pt_pt:!0,ro:!0,ru:!0,si:!0,sk:!0,sl:!0,sr:!0,sv:!0,sw:!0,swh:"sw",ta:!0,te:!0,th:!0,tl:"fil",
|
128 |
+
tr:!0,uk:!0,ur:!0,vi:!0,yi:!1,zh:"zh_cn",zh_cn:!0,zh_hk:!0,zh_tw:!0,zsm:"ms",zu:!0};google.a.b.S={};google.a.b.T=od;google.a.b.log=Y();google.a.b.error=Y();google.a.b.Z=!1;google.a.b.O=window;google.a.b.ld={current:"44",upcoming:"44",41:U,42:U,43:U,44:U};google.a.b.Ua={gstatic:{prefix:"https://www.gstatic.com/charts",debug:"{prefix}/debug/{version}/jsapi_debug_{package}_module.js",compiled:"{prefix}/{version}/js/jsapi_compiled_{package}_module.js",i18n:"{prefix}/{version}/i18n/jsapi_compiled_i18n_{package}_module__{language}.js",css:zd,css_debug:zd,third_party:Ad,third_party_gen:Ad}};
|
129 |
+
google.a.b.m=google.a.b.Ua.gstatic;
|
130 |
+
google.a.b.zc={"default":[],format:[],ui:["format","default"],ui_base:["format","default"],annotatedtimeline:[V],annotationchart:[V,"controls",uc,"table"],areachart:[V,O],bar:[V,Q,td],barchart:[V,O],browserchart:[V],calendar:[V],charteditor:[V,uc,S,oc,"gauge","motionchart","orgchart","table"],charteditor_base:[nd,uc,S,oc,"gauge","motionchart","orgchart","table_base"],columnchart:[V,O],controls:[V],controls_base:[nd],corechart:[V],gantt:[V,Q],gauge:[V],geochart:[V],geomap:[V],geomap_base:[nd],helloworld:[V],
|
131 |
+
imageareachart:[V,S],imagebarchart:[V,S],imagelinechart:[V,S],imagechart:[V],imagepiechart:[V,S],imagesparkline:[V,S],intensitymap:[V],line:[V,Q,td],linechart:[V,O],map:[V],motionchart:[V],orgchart:[V],overtimecharts:[V,uc],piechart:[V,O],sankey:["d3","d3.sankey",V],scatter:[V,Q,td],scatterchart:[V,O],table:[V],table_base:[nd],timeline:[V,Q],treemap:[V],wordtree:[V]};google.a.b.ed={d3:"d3/d3.js","d3.sankey":"d3/d3.sankey.js",webfontloader:"webfontloader/webfont.js"};google.a.b.Eb={dygraph:"dygraphs/dygraph-tickers-combined.js"};
|
132 |
+
google.a.b.wc={annotatedtimeline:"/annotatedtimeline/annotatedtimeline.css",annotationchart:"annotationchart/annotationchart.css",charteditor:"charteditor/charteditor.css",charteditor_base:"charteditor/charteditor_base.css",controls:"controls/controls.css",imagesparkline:"imagesparkline/imagesparkline.css",intensitymap:"intensitymap/intensitymap.css",orgchart:"orgchart/orgchart.css",table:"table/table.css",table_base:"table/table_base.css",ui:["util/util.css","core/tooltip.css"],ui_base:"util/util_base.css"};
|
133 |
+
google.a.b.va=function(a,c){for(var d=c||{},e=[],f=0;f<a.length;f++){var g=a[f];if(!d[g]){d[g]=!0;var h=google.a.b.zc[g]||[];0<h.length&&(e=e.concat(google.a.b.va(h,d)));e.push(g)}}return e};google.a.b.Ec=function(a){for(var c={},d=[],e=0;e<a.length;e++){var f=google.a.b.wc[a[e]];Z.isArray(f)||(f=[f]);for(var g=0;g<f.length;g++){var h=f[g];h&&!c[h]&&(c[h]=!0,d.push(h))}}return d};
|
134 |
+
google.a.b.$c=function(a,c){if(c)if("undefined"===typeof a.onload){var d=!1;a.onreadystatechange=function(){d||(a.readyState&&a.readyState!==P?google.a.b.O.setTimeout(a.onreadystatechange,0):(d=!0,delete a.onreadystatechange,google.a.b.O.setTimeout(c,0)))}}else a.onload=c};
|
135 |
+
google.a.b.Ab=function(a,c,d){google.a.b.log(Vc+a);var e=c.createElement(gd);e.type=ld;e.language=Qc;e.async=!1;e.defer=!1;c=c.body||c.head||c.getElementsByTagName(ib).item(0)||c.documentElement;c.insertBefore(e,c.lastChild);d&&google.a.b.$c(e,d);e.src=a;google.a.b.log(zc+a)};
|
136 |
+
google.a.b.Qc=function(a,c){function d(c){var e=google.a.b.sb,f=a[c++];if(f){var g=f,h=google.a.b.ed[f];h?(g=h,f===td&&(e=window.document),f=google.a.b.m.third_party):google.a.b.Eb[f]?(g=google.a.b.Eb[f],f=google.a.b.m.third_party_gen):f=google.a.b.Z?n:t?Oa:p;g=f.replace(yd,m).replace(Bd,A).replace(wd,t).replace(xd,g);google.a.b.Ab(g,e);d(c)}}function e(){for(var d=[],e=0;e<a.length;e++)d.push(Sb[a[e]]);eval(Ea+d.join(b)+Dd)();google.a.b.O.setTimeout(c,0)}a=google.a.b.va(a);for(var f=[],g=0;g<a.length;g++){var h=
|
137 |
+
a[g];google.a.b.S[h]||f.push(h)}a=f;google.a.b.log(pb+a);var m=google.a.b.m.prefix,n=google.a.b.m.debug,p=google.a.b.m.compiled,Oa=google.a.b.m.i18n,A=google.a.b.T,t=google.a.b.Ma;t===yc&&(t=null);var Sb={},Tb=a.length;google.a.b.Vc=function(a,c){google.a.b.log(sc+a);Sb[a]=c;google.a.b.S[a]=!0;Tb--;0===Tb&&e()};d(0)};
|
138 |
+
google.a.b.W=function(a){function c(){g=!0;for(var a=e.length,c=0;c<a;c++)e[c]()}function d(){h=!0;for(var a=f.length,c=0;c<a;c++)f[c]()}var e=[],f=[],g=!1,h=!1;google.a.b.W.count||(google.a.b.W.count=0);var m=Tc+google.a.b.W.count++,n={done:function(a){e.push(a);g&&a();return n},Ca:function(a){f.push(a);h&&a();return n}},p=document.createElement(Rc);p.setAttribute(Oc,m);p.setAttribute(ed,jd);p.setAttribute(md,kd);"undefined"!==typeof p.addEventListener?(p.addEventListener(Sc,c,!1),p.addEventListener(Ac,
|
139 |
+
d,!1)):"undefined"!==typeof p.attachEvent&&p.attachEvent(cd,function(){var a,e=document.styleSheets.length;try{for(;e--;)if(a=document.styleSheets[e],a.id===m){c();return}}catch(f){}g||d()});document.getElementsByTagName(Mc)[0].appendChild(p);p.setAttribute(Nc,a);return n};google.a.b.Nc=function(a,c){google.a.b.log(Uc+a);google.a.b.W(a).done(c).Ca(function(){google.a.b.error(Wc+a)})};
|
140 |
+
google.a.b.Oc=function(a,c){a=google.a.b.va(a);var d=google.a.b.Ec(a);if(null===d||0===d.length)c();else{google.a.b.log(qb+d.join(ya));var e=google.a.b.m.prefix,f=google.a.b.m.css;google.a.b.Z&&(f=google.a.b.m.css_debug||f);var g=google.a.b.T,h=function(a){var n=d[a],p;p=a<d.length-1?function(){h(a+1)}:c;google.a.b.S[n]?(google.a.b.log(Na+n),google.a.b.O.setTimeout(p,0)):(google.a.b.S[n]=!0,n=f.replace(yd,e).replace(Bd,g).replace(vd,n),google.a.b.Nc(n,p))};h(0)}};
|
141 |
+
google.a.b.Ee=function(){var a=google.a.b.C;if(!a){a=google.a.b.C=document.createElement(Pc);google.a.b.C=a;a.name=Jc;(document.body||document.head||document).appendChild(a);a.style.display=Zc;var c=google.a.b.sb=a.contentDocument?a.contentDocument:a.contentWindow?a.contentWindow.document:a.document;c.open();c.writeln(b);c.close()}return a};
|
142 |
+
google.a.b.Cb=function(a){for(var c=a.replace(/-/g,M).toLowerCase();Z.h(c);)a=c,c=google.a.b.languages[c],c===a&&(c=!1);c||(a.match(/_[^_]+$/)?(a=a.replace(/_[^_]+$/,b),a=google.a.b.Cb(a)):a=yc);return a};
|
143 |
+
google.a.b.Yc=function(a,c){c.log&&(google.a.b.log=c.log);c.error&&(google.a.b.error=c.error);var d=c.debug,e=c.language||b,e=google.a.b.Cb(e);a||(a=c.version||od);(google.a.b.T&&google.a.b.T!==a||google.a.b.Ma&&google.a.b.Ma!==e||google.a.b.Z!==d)&&google.a.b.C&&google.a.b.C.parentNode&&(google.a.b.C.parentNode.removeChild(google.a.b.C),google.a.b.C=null,google.a.b.S={});google.a.b.T=a;google.a.b.Ma=e;google.a.b.Z=d};google.a.b.R=!1;google.a.b.ma=!1;google.a.b.loaded=!1;google.a.b.Da=[];
|
144 |
+
google.a.b.load=function(a,c,d){var e;e=a.match(/^(testing\/)?(.*)/);var f=e[1]||b;for(a=e[2];;){e=google.a.b.ld[a];if(null==e||e===U)break;a=e}google.a.b.m=d||google.a.b.Ua[a]||google.a.b.Ua.gstatic;a=f+a;if(null==e)f=function(){Z.kb()(a,c,d)},google.a.b.R?google.a.b.M(f):(google.a.b.R=!0,google.a.b.Ab(google.a.b.m.prefix+u+a+Da,window.document,f));else{if(google.a.b.R)throw Error("google.charts.load() cannot be called more than once with version 44 or earlier.");google.a.b.R=!0;if(google.a.b.ma)google.a.b.M(function(){google.a.b.load(a,
|
145 |
+
c)});else{google.a.b.loaded=!1;google.a.b.ma=!0;google.a.b.Yc(a,c);google.a.b.log(Kc+a);window.google=window.google||{};google.visualization=google.visualization||{};google.visualization.ModulePath=google.a.b.m.prefix;google.a.b.C=null;google.a.b.O=window;google.a.b.sb=document;var g=function(){google.a.b.ma=!1;google.a.b.loaded=!0;google.a.b.Na()},h=c.packages;google.a.b.M(c.callback);google.a.b.Oc(h,function(){google.a.b.Qc(h,g)})}}};
|
146 |
+
google.a.b.M=function(a){a&&google.a.b.Da.push(a);google.a.b.loaded&&!google.a.b.ma&&google.a.b.Na()};google.a.b.ad=function(a){if(window.addEventListener)window.addEventListener(Sc,a,!1);else if(window.attachEvent)window.attachEvent(cd,a);else{var c=window.onload;window.onload=function(d){c&&c(d);a()}}};google.a.b.Ib=document&&document.readyState===P;google.a.b.ad(function(){google.a.b.Ib=!0;google.a.b.Na()});
|
147 |
google.a.b.Na=function(){if(google.a.b.R&&google.a.b.loaded&&(google.a.b.Ib||document.readyState===P))for(;0<google.a.b.Da.length;)google.a.b.Da.shift()()};google.a.b.Qa=function(a,c){google.a.b.Vc(a,c)};if(Z.kb())throw Error("Google Charts loader.js can only be loaded once.");google.a.load=function(a,c,d){a===sd&&(a=c,c=d);google.a.b.load(String(a),c||{})};google.a.M=function(a){google.a.b.M(a)};google.a.Qa=function(a,c){google.a.b.Qa(a,c)};Z.Ba(Jc,google.a.load);Z.Ba("google.charts.setOnLoadCallback",google.a.M);Z.Ba("google.charts.packageLoadedCallback",google.a.Qa); })();
|
inc/js/moment.min.js
CHANGED
@@ -1,7 +1,7 @@
|
|
1 |
-
//! moment.js
|
2 |
-
//! version : 2.12.0
|
3 |
-
//! authors : Tim Wood, Iskren Chernev, Moment.js contributors
|
4 |
-
//! license : MIT
|
5 |
-
//! momentjs.com
|
6 |
-
!function(a,b){"object"==typeof exports&&"undefined"!=typeof module?module.exports=b():"function"==typeof define&&define.amd?define(b):a.moment=b()}(this,function(){"use strict";function a(){return Zc.apply(null,arguments)}function b(a){Zc=a}function c(a){return a instanceof Array||"[object Array]"===Object.prototype.toString.call(a)}function d(a){return a instanceof Date||"[object Date]"===Object.prototype.toString.call(a)}function e(a,b){var c,d=[];for(c=0;c<a.length;++c)d.push(b(a[c],c));return d}function f(a,b){return Object.prototype.hasOwnProperty.call(a,b)}function g(a,b){for(var c in b)f(b,c)&&(a[c]=b[c]);return f(b,"toString")&&(a.toString=b.toString),f(b,"valueOf")&&(a.valueOf=b.valueOf),a}function h(a,b,c,d){return Ia(a,b,c,d,!0).utc()}function i(){return{empty:!1,unusedTokens:[],unusedInput:[],overflow:-2,charsLeftOver:0,nullInput:!1,invalidMonth:null,invalidFormat:!1,userInvalidated:!1,iso:!1}}function j(a){return null==a._pf&&(a._pf=i()),a._pf}function k(a){if(null==a._isValid){var b=j(a);a._isValid=!(isNaN(a._d.getTime())||!(b.overflow<0)||b.empty||b.invalidMonth||b.invalidWeekday||b.nullInput||b.invalidFormat||b.userInvalidated),a._strict&&(a._isValid=a._isValid&&0===b.charsLeftOver&&0===b.unusedTokens.length&&void 0===b.bigHour)}return a._isValid}function l(a){var b=h(NaN);return null!=a?g(j(b),a):j(b).userInvalidated=!0,b}function m(a){return void 0===a}function n(a,b){var c,d,e;if(m(b._isAMomentObject)||(a._isAMomentObject=b._isAMomentObject),m(b._i)||(a._i=b._i),m(b._f)||(a._f=b._f),m(b._l)||(a._l=b._l),m(b._strict)||(a._strict=b._strict),m(b._tzm)||(a._tzm=b._tzm),m(b._isUTC)||(a._isUTC=b._isUTC),m(b._offset)||(a._offset=b._offset),m(b._pf)||(a._pf=j(b)),m(b._locale)||(a._locale=b._locale),$c.length>0)for(c in $c)d=$c[c],e=b[d],m(e)||(a[d]=e);return a}function o(b){n(this,b),this._d=new Date(null!=b._d?b._d.getTime():NaN),_c===!1&&(_c=!0,a.updateOffset(this),_c=!1)}function p(a){return a instanceof o||null!=a&&null!=a._isAMomentObject}function q(a){return 0>a?Math.ceil(a):Math.floor(a)}function r(a){var b=+a,c=0;return 0!==b&&isFinite(b)&&(c=q(b)),c}function s(a,b,c){var d,e=Math.min(a.length,b.length),f=Math.abs(a.length-b.length),g=0;for(d=0;e>d;d++)(c&&a[d]!==b[d]||!c&&r(a[d])!==r(b[d]))&&g++;return g+f}function t(b){a.suppressDeprecationWarnings===!1&&"undefined"!=typeof console&&console.warn&&console.warn("Deprecation warning: "+b)}function u(a,b){var c=!0;return g(function(){return c&&(t(a+"\nArguments: "+Array.prototype.slice.call(arguments).join(", ")+"\n"+(new Error).stack),c=!1),b.apply(this,arguments)},b)}function v(a,b){ad[a]||(t(b),ad[a]=!0)}function w(a){return a instanceof Function||"[object Function]"===Object.prototype.toString.call(a)}function x(a){return"[object Object]"===Object.prototype.toString.call(a)}function y(a){var b,c;for(c in a)b=a[c],w(b)?this[c]=b:this["_"+c]=b;this._config=a,this._ordinalParseLenient=new RegExp(this._ordinalParse.source+"|"+/\d{1,2}/.source)}function z(a,b){var c,d=g({},a);for(c in b)f(b,c)&&(x(a[c])&&x(b[c])?(d[c]={},g(d[c],a[c]),g(d[c],b[c])):null!=b[c]?d[c]=b[c]:delete d[c]);return d}function A(a){null!=a&&this.set(a)}function B(a){return a?a.toLowerCase().replace("_","-"):a}function C(a){for(var b,c,d,e,f=0;f<a.length;){for(e=B(a[f]).split("-"),b=e.length,c=B(a[f+1]),c=c?c.split("-"):null;b>0;){if(d=D(e.slice(0,b).join("-")))return d;if(c&&c.length>=b&&s(e,c,!0)>=b-1)break;b--}f++}return null}function D(a){var b=null;if(!cd[a]&&"undefined"!=typeof module&&module&&module.exports)try{b=bd._abbr,require("./locale/"+a),E(b)}catch(c){}return cd[a]}function E(a,b){var c;return a&&(c=m(b)?H(a):F(a,b),c&&(bd=c)),bd._abbr}function F(a,b){return null!==b?(b.abbr=a,null!=cd[a]?(v("defineLocaleOverride","use moment.updateLocale(localeName, config) to change an existing locale. moment.defineLocale(localeName, config) should only be used for creating a new locale"),b=z(cd[a]._config,b)):null!=b.parentLocale&&(null!=cd[b.parentLocale]?b=z(cd[b.parentLocale]._config,b):v("parentLocaleUndefined","specified parentLocale is not defined yet")),cd[a]=new A(b),E(a),cd[a]):(delete cd[a],null)}function G(a,b){if(null!=b){var c;null!=cd[a]&&(b=z(cd[a]._config,b)),c=new A(b),c.parentLocale=cd[a],cd[a]=c,E(a)}else null!=cd[a]&&(null!=cd[a].parentLocale?cd[a]=cd[a].parentLocale:null!=cd[a]&&delete cd[a]);return cd[a]}function H(a){var b;if(a&&a._locale&&a._locale._abbr&&(a=a._locale._abbr),!a)return bd;if(!c(a)){if(b=D(a))return b;a=[a]}return C(a)}function I(){return Object.keys(cd)}function J(a,b){var c=a.toLowerCase();dd[c]=dd[c+"s"]=dd[b]=a}function K(a){return"string"==typeof a?dd[a]||dd[a.toLowerCase()]:void 0}function L(a){var b,c,d={};for(c in a)f(a,c)&&(b=K(c),b&&(d[b]=a[c]));return d}function M(b,c){return function(d){return null!=d?(O(this,b,d),a.updateOffset(this,c),this):N(this,b)}}function N(a,b){return a.isValid()?a._d["get"+(a._isUTC?"UTC":"")+b]():NaN}function O(a,b,c){a.isValid()&&a._d["set"+(a._isUTC?"UTC":"")+b](c)}function P(a,b){var c;if("object"==typeof a)for(c in a)this.set(c,a[c]);else if(a=K(a),w(this[a]))return this[a](b);return this}function Q(a,b,c){var d=""+Math.abs(a),e=b-d.length,f=a>=0;return(f?c?"+":"":"-")+Math.pow(10,Math.max(0,e)).toString().substr(1)+d}function R(a,b,c,d){var e=d;"string"==typeof d&&(e=function(){return this[d]()}),a&&(hd[a]=e),b&&(hd[b[0]]=function(){return Q(e.apply(this,arguments),b[1],b[2])}),c&&(hd[c]=function(){return this.localeData().ordinal(e.apply(this,arguments),a)})}function S(a){return a.match(/\[[\s\S]/)?a.replace(/^\[|\]$/g,""):a.replace(/\\/g,"")}function T(a){var b,c,d=a.match(ed);for(b=0,c=d.length;c>b;b++)hd[d[b]]?d[b]=hd[d[b]]:d[b]=S(d[b]);return function(e){var f="";for(b=0;c>b;b++)f+=d[b]instanceof Function?d[b].call(e,a):d[b];return f}}function U(a,b){return a.isValid()?(b=V(b,a.localeData()),gd[b]=gd[b]||T(b),gd[b](a)):a.localeData().invalidDate()}function V(a,b){function c(a){return b.longDateFormat(a)||a}var d=5;for(fd.lastIndex=0;d>=0&&fd.test(a);)a=a.replace(fd,c),fd.lastIndex=0,d-=1;return a}function W(a,b,c){zd[a]=w(b)?b:function(a,d){return a&&c?c:b}}function X(a,b){return f(zd,a)?zd[a](b._strict,b._locale):new RegExp(Y(a))}function Y(a){return Z(a.replace("\\","").replace(/\\(\[)|\\(\])|\[([^\]\[]*)\]|\\(.)/g,function(a,b,c,d,e){return b||c||d||e}))}function Z(a){return a.replace(/[-\/\\^$*+?.()|[\]{}]/g,"\\$&")}function $(a,b){var c,d=b;for("string"==typeof a&&(a=[a]),"number"==typeof b&&(d=function(a,c){c[b]=r(a)}),c=0;c<a.length;c++)Ad[a[c]]=d}function _(a,b){$(a,function(a,c,d,e){d._w=d._w||{},b(a,d._w,d,e)})}function aa(a,b,c){null!=b&&f(Ad,a)&&Ad[a](b,c._a,c,a)}function ba(a,b){return new Date(Date.UTC(a,b+1,0)).getUTCDate()}function ca(a,b){return c(this._months)?this._months[a.month()]:this._months[Kd.test(b)?"format":"standalone"][a.month()]}function da(a,b){return c(this._monthsShort)?this._monthsShort[a.month()]:this._monthsShort[Kd.test(b)?"format":"standalone"][a.month()]}function ea(a,b,c){var d,e,f;for(this._monthsParse||(this._monthsParse=[],this._longMonthsParse=[],this._shortMonthsParse=[]),d=0;12>d;d++){if(e=h([2e3,d]),c&&!this._longMonthsParse[d]&&(this._longMonthsParse[d]=new RegExp("^"+this.months(e,"").replace(".","")+"$","i"),this._shortMonthsParse[d]=new RegExp("^"+this.monthsShort(e,"").replace(".","")+"$","i")),c||this._monthsParse[d]||(f="^"+this.months(e,"")+"|^"+this.monthsShort(e,""),this._monthsParse[d]=new RegExp(f.replace(".",""),"i")),c&&"MMMM"===b&&this._longMonthsParse[d].test(a))return d;if(c&&"MMM"===b&&this._shortMonthsParse[d].test(a))return d;if(!c&&this._monthsParse[d].test(a))return d}}function fa(a,b){var c;if(!a.isValid())return a;if("string"==typeof b)if(/^\d+$/.test(b))b=r(b);else if(b=a.localeData().monthsParse(b),"number"!=typeof b)return a;return c=Math.min(a.date(),ba(a.year(),b)),a._d["set"+(a._isUTC?"UTC":"")+"Month"](b,c),a}function ga(b){return null!=b?(fa(this,b),a.updateOffset(this,!0),this):N(this,"Month")}function ha(){return ba(this.year(),this.month())}function ia(a){return this._monthsParseExact?(f(this,"_monthsRegex")||ka.call(this),a?this._monthsShortStrictRegex:this._monthsShortRegex):this._monthsShortStrictRegex&&a?this._monthsShortStrictRegex:this._monthsShortRegex}function ja(a){return this._monthsParseExact?(f(this,"_monthsRegex")||ka.call(this),a?this._monthsStrictRegex:this._monthsRegex):this._monthsStrictRegex&&a?this._monthsStrictRegex:this._monthsRegex}function ka(){function a(a,b){return b.length-a.length}var b,c,d=[],e=[],f=[];for(b=0;12>b;b++)c=h([2e3,b]),d.push(this.monthsShort(c,"")),e.push(this.months(c,"")),f.push(this.months(c,"")),f.push(this.monthsShort(c,""));for(d.sort(a),e.sort(a),f.sort(a),b=0;12>b;b++)d[b]=Z(d[b]),e[b]=Z(e[b]),f[b]=Z(f[b]);this._monthsRegex=new RegExp("^("+f.join("|")+")","i"),this._monthsShortRegex=this._monthsRegex,this._monthsStrictRegex=new RegExp("^("+e.join("|")+")$","i"),this._monthsShortStrictRegex=new RegExp("^("+d.join("|")+")$","i")}function la(a){var b,c=a._a;return c&&-2===j(a).overflow&&(b=c[Cd]<0||c[Cd]>11?Cd:c[Dd]<1||c[Dd]>ba(c[Bd],c[Cd])?Dd:c[Ed]<0||c[Ed]>24||24===c[Ed]&&(0!==c[Fd]||0!==c[Gd]||0!==c[Hd])?Ed:c[Fd]<0||c[Fd]>59?Fd:c[Gd]<0||c[Gd]>59?Gd:c[Hd]<0||c[Hd]>999?Hd:-1,j(a)._overflowDayOfYear&&(Bd>b||b>Dd)&&(b=Dd),j(a)._overflowWeeks&&-1===b&&(b=Id),j(a)._overflowWeekday&&-1===b&&(b=Jd),j(a).overflow=b),a}function ma(a){var b,c,d,e,f,g,h=a._i,i=Pd.exec(h)||Qd.exec(h);if(i){for(j(a).iso=!0,b=0,c=Sd.length;c>b;b++)if(Sd[b][1].exec(i[1])){e=Sd[b][0],d=Sd[b][2]!==!1;break}if(null==e)return void(a._isValid=!1);if(i[3]){for(b=0,c=Td.length;c>b;b++)if(Td[b][1].exec(i[3])){f=(i[2]||" ")+Td[b][0];break}if(null==f)return void(a._isValid=!1)}if(!d&&null!=f)return void(a._isValid=!1);if(i[4]){if(!Rd.exec(i[4]))return void(a._isValid=!1);g="Z"}a._f=e+(f||"")+(g||""),Ba(a)}else a._isValid=!1}function na(b){var c=Ud.exec(b._i);return null!==c?void(b._d=new Date(+c[1])):(ma(b),void(b._isValid===!1&&(delete b._isValid,a.createFromInputFallback(b))))}function oa(a,b,c,d,e,f,g){var h=new Date(a,b,c,d,e,f,g);return 100>a&&a>=0&&isFinite(h.getFullYear())&&h.setFullYear(a),h}function pa(a){var b=new Date(Date.UTC.apply(null,arguments));return 100>a&&a>=0&&isFinite(b.getUTCFullYear())&&b.setUTCFullYear(a),b}function qa(a){return ra(a)?366:365}function ra(a){return a%4===0&&a%100!==0||a%400===0}function sa(){return ra(this.year())}function ta(a,b,c){var d=7+b-c,e=(7+pa(a,0,d).getUTCDay()-b)%7;return-e+d-1}function ua(a,b,c,d,e){var f,g,h=(7+c-d)%7,i=ta(a,d,e),j=1+7*(b-1)+h+i;return 0>=j?(f=a-1,g=qa(f)+j):j>qa(a)?(f=a+1,g=j-qa(a)):(f=a,g=j),{year:f,dayOfYear:g}}function va(a,b,c){var d,e,f=ta(a.year(),b,c),g=Math.floor((a.dayOfYear()-f-1)/7)+1;return 1>g?(e=a.year()-1,d=g+wa(e,b,c)):g>wa(a.year(),b,c)?(d=g-wa(a.year(),b,c),e=a.year()+1):(e=a.year(),d=g),{week:d,year:e}}function wa(a,b,c){var d=ta(a,b,c),e=ta(a+1,b,c);return(qa(a)-d+e)/7}function xa(a,b,c){return null!=a?a:null!=b?b:c}function ya(b){var c=new Date(a.now());return b._useUTC?[c.getUTCFullYear(),c.getUTCMonth(),c.getUTCDate()]:[c.getFullYear(),c.getMonth(),c.getDate()]}function za(a){var b,c,d,e,f=[];if(!a._d){for(d=ya(a),a._w&&null==a._a[Dd]&&null==a._a[Cd]&&Aa(a),a._dayOfYear&&(e=xa(a._a[Bd],d[Bd]),a._dayOfYear>qa(e)&&(j(a)._overflowDayOfYear=!0),c=pa(e,0,a._dayOfYear),a._a[Cd]=c.getUTCMonth(),a._a[Dd]=c.getUTCDate()),b=0;3>b&&null==a._a[b];++b)a._a[b]=f[b]=d[b];for(;7>b;b++)a._a[b]=f[b]=null==a._a[b]?2===b?1:0:a._a[b];24===a._a[Ed]&&0===a._a[Fd]&&0===a._a[Gd]&&0===a._a[Hd]&&(a._nextDay=!0,a._a[Ed]=0),a._d=(a._useUTC?pa:oa).apply(null,f),null!=a._tzm&&a._d.setUTCMinutes(a._d.getUTCMinutes()-a._tzm),a._nextDay&&(a._a[Ed]=24)}}function Aa(a){var b,c,d,e,f,g,h,i;b=a._w,null!=b.GG||null!=b.W||null!=b.E?(f=1,g=4,c=xa(b.GG,a._a[Bd],va(Ja(),1,4).year),d=xa(b.W,1),e=xa(b.E,1),(1>e||e>7)&&(i=!0)):(f=a._locale._week.dow,g=a._locale._week.doy,c=xa(b.gg,a._a[Bd],va(Ja(),f,g).year),d=xa(b.w,1),null!=b.d?(e=b.d,(0>e||e>6)&&(i=!0)):null!=b.e?(e=b.e+f,(b.e<0||b.e>6)&&(i=!0)):e=f),1>d||d>wa(c,f,g)?j(a)._overflowWeeks=!0:null!=i?j(a)._overflowWeekday=!0:(h=ua(c,d,e,f,g),a._a[Bd]=h.year,a._dayOfYear=h.dayOfYear)}function Ba(b){if(b._f===a.ISO_8601)return void ma(b);b._a=[],j(b).empty=!0;var c,d,e,f,g,h=""+b._i,i=h.length,k=0;for(e=V(b._f,b._locale).match(ed)||[],c=0;c<e.length;c++)f=e[c],d=(h.match(X(f,b))||[])[0],d&&(g=h.substr(0,h.indexOf(d)),g.length>0&&j(b).unusedInput.push(g),h=h.slice(h.indexOf(d)+d.length),k+=d.length),hd[f]?(d?j(b).empty=!1:j(b).unusedTokens.push(f),aa(f,d,b)):b._strict&&!d&&j(b).unusedTokens.push(f);j(b).charsLeftOver=i-k,h.length>0&&j(b).unusedInput.push(h),j(b).bigHour===!0&&b._a[Ed]<=12&&b._a[Ed]>0&&(j(b).bigHour=void 0),b._a[Ed]=Ca(b._locale,b._a[Ed],b._meridiem),za(b),la(b)}function Ca(a,b,c){var d;return null==c?b:null!=a.meridiemHour?a.meridiemHour(b,c):null!=a.isPM?(d=a.isPM(c),d&&12>b&&(b+=12),d||12!==b||(b=0),b):b}function Da(a){var b,c,d,e,f;if(0===a._f.length)return j(a).invalidFormat=!0,void(a._d=new Date(NaN));for(e=0;e<a._f.length;e++)f=0,b=n({},a),null!=a._useUTC&&(b._useUTC=a._useUTC),b._f=a._f[e],Ba(b),k(b)&&(f+=j(b).charsLeftOver,f+=10*j(b).unusedTokens.length,j(b).score=f,(null==d||d>f)&&(d=f,c=b));g(a,c||b)}function Ea(a){if(!a._d){var b=L(a._i);a._a=e([b.year,b.month,b.day||b.date,b.hour,b.minute,b.second,b.millisecond],function(a){return a&&parseInt(a,10)}),za(a)}}function Fa(a){var b=new o(la(Ga(a)));return b._nextDay&&(b.add(1,"d"),b._nextDay=void 0),b}function Ga(a){var b=a._i,e=a._f;return a._locale=a._locale||H(a._l),null===b||void 0===e&&""===b?l({nullInput:!0}):("string"==typeof b&&(a._i=b=a._locale.preparse(b)),p(b)?new o(la(b)):(c(e)?Da(a):e?Ba(a):d(b)?a._d=b:Ha(a),k(a)||(a._d=null),a))}function Ha(b){var f=b._i;void 0===f?b._d=new Date(a.now()):d(f)?b._d=new Date(+f):"string"==typeof f?na(b):c(f)?(b._a=e(f.slice(0),function(a){return parseInt(a,10)}),za(b)):"object"==typeof f?Ea(b):"number"==typeof f?b._d=new Date(f):a.createFromInputFallback(b)}function Ia(a,b,c,d,e){var f={};return"boolean"==typeof c&&(d=c,c=void 0),f._isAMomentObject=!0,f._useUTC=f._isUTC=e,f._l=c,f._i=a,f._f=b,f._strict=d,Fa(f)}function Ja(a,b,c,d){return Ia(a,b,c,d,!1)}function Ka(a,b){var d,e;if(1===b.length&&c(b[0])&&(b=b[0]),!b.length)return Ja();for(d=b[0],e=1;e<b.length;++e)(!b[e].isValid()||b[e][a](d))&&(d=b[e]);return d}function La(){var a=[].slice.call(arguments,0);return Ka("isBefore",a)}function Ma(){var a=[].slice.call(arguments,0);return Ka("isAfter",a)}function Na(a){var b=L(a),c=b.year||0,d=b.quarter||0,e=b.month||0,f=b.week||0,g=b.day||0,h=b.hour||0,i=b.minute||0,j=b.second||0,k=b.millisecond||0;this._milliseconds=+k+1e3*j+6e4*i+36e5*h,this._days=+g+7*f,this._months=+e+3*d+12*c,this._data={},this._locale=H(),this._bubble()}function Oa(a){return a instanceof Na}function Pa(a,b){R(a,0,0,function(){var a=this.utcOffset(),c="+";return 0>a&&(a=-a,c="-"),c+Q(~~(a/60),2)+b+Q(~~a%60,2)})}function Qa(a,b){var c=(b||"").match(a)||[],d=c[c.length-1]||[],e=(d+"").match(Zd)||["-",0,0],f=+(60*e[1])+r(e[2]);return"+"===e[0]?f:-f}function Ra(b,c){var e,f;return c._isUTC?(e=c.clone(),f=(p(b)||d(b)?+b:+Ja(b))-+e,e._d.setTime(+e._d+f),a.updateOffset(e,!1),e):Ja(b).local()}function Sa(a){return 15*-Math.round(a._d.getTimezoneOffset()/15)}function Ta(b,c){var d,e=this._offset||0;return this.isValid()?null!=b?("string"==typeof b?b=Qa(wd,b):Math.abs(b)<16&&(b=60*b),!this._isUTC&&c&&(d=Sa(this)),this._offset=b,this._isUTC=!0,null!=d&&this.add(d,"m"),e!==b&&(!c||this._changeInProgress?ib(this,cb(b-e,"m"),1,!1):this._changeInProgress||(this._changeInProgress=!0,a.updateOffset(this,!0),this._changeInProgress=null)),this):this._isUTC?e:Sa(this):null!=b?this:NaN}function Ua(a,b){return null!=a?("string"!=typeof a&&(a=-a),this.utcOffset(a,b),this):-this.utcOffset()}function Va(a){return this.utcOffset(0,a)}function Wa(a){return this._isUTC&&(this.utcOffset(0,a),this._isUTC=!1,a&&this.subtract(Sa(this),"m")),this}function Xa(){return this._tzm?this.utcOffset(this._tzm):"string"==typeof this._i&&this.utcOffset(Qa(vd,this._i)),this}function Ya(a){return this.isValid()?(a=a?Ja(a).utcOffset():0,(this.utcOffset()-a)%60===0):!1}function Za(){return this.utcOffset()>this.clone().month(0).utcOffset()||this.utcOffset()>this.clone().month(5).utcOffset()}function $a(){if(!m(this._isDSTShifted))return this._isDSTShifted;var a={};if(n(a,this),a=Ga(a),a._a){var b=a._isUTC?h(a._a):Ja(a._a);this._isDSTShifted=this.isValid()&&s(a._a,b.toArray())>0}else this._isDSTShifted=!1;return this._isDSTShifted}function _a(){return this.isValid()?!this._isUTC:!1}function ab(){return this.isValid()?this._isUTC:!1}function bb(){return this.isValid()?this._isUTC&&0===this._offset:!1}function cb(a,b){var c,d,e,g=a,h=null;return Oa(a)?g={ms:a._milliseconds,d:a._days,M:a._months}:"number"==typeof a?(g={},b?g[b]=a:g.milliseconds=a):(h=$d.exec(a))?(c="-"===h[1]?-1:1,g={y:0,d:r(h[Dd])*c,h:r(h[Ed])*c,m:r(h[Fd])*c,s:r(h[Gd])*c,ms:r(h[Hd])*c}):(h=_d.exec(a))?(c="-"===h[1]?-1:1,g={y:db(h[2],c),M:db(h[3],c),w:db(h[4],c),d:db(h[5],c),h:db(h[6],c),m:db(h[7],c),s:db(h[8],c)}):null==g?g={}:"object"==typeof g&&("from"in g||"to"in g)&&(e=fb(Ja(g.from),Ja(g.to)),g={},g.ms=e.milliseconds,g.M=e.months),d=new Na(g),Oa(a)&&f(a,"_locale")&&(d._locale=a._locale),d}function db(a,b){var c=a&&parseFloat(a.replace(",","."));return(isNaN(c)?0:c)*b}function eb(a,b){var c={milliseconds:0,months:0};return c.months=b.month()-a.month()+12*(b.year()-a.year()),a.clone().add(c.months,"M").isAfter(b)&&--c.months,c.milliseconds=+b-+a.clone().add(c.months,"M"),c}function fb(a,b){var c;return a.isValid()&&b.isValid()?(b=Ra(b,a),a.isBefore(b)?c=eb(a,b):(c=eb(b,a),c.milliseconds=-c.milliseconds,c.months=-c.months),c):{milliseconds:0,months:0}}function gb(a){return 0>a?-1*Math.round(-1*a):Math.round(a)}function hb(a,b){return function(c,d){var e,f;return null===d||isNaN(+d)||(v(b,"moment()."+b+"(period, number) is deprecated. Please use moment()."+b+"(number, period)."),f=c,c=d,d=f),c="string"==typeof c?+c:c,e=cb(c,d),ib(this,e,a),this}}function ib(b,c,d,e){var f=c._milliseconds,g=gb(c._days),h=gb(c._months);b.isValid()&&(e=null==e?!0:e,f&&b._d.setTime(+b._d+f*d),g&&O(b,"Date",N(b,"Date")+g*d),h&&fa(b,N(b,"Month")+h*d),e&&a.updateOffset(b,g||h))}function jb(a,b){var c=a||Ja(),d=Ra(c,this).startOf("day"),e=this.diff(d,"days",!0),f=-6>e?"sameElse":-1>e?"lastWeek":0>e?"lastDay":1>e?"sameDay":2>e?"nextDay":7>e?"nextWeek":"sameElse",g=b&&(w(b[f])?b[f]():b[f]);return this.format(g||this.localeData().calendar(f,this,Ja(c)))}function kb(){return new o(this)}function lb(a,b){var c=p(a)?a:Ja(a);return this.isValid()&&c.isValid()?(b=K(m(b)?"millisecond":b),"millisecond"===b?+this>+c:+c<+this.clone().startOf(b)):!1}function mb(a,b){var c=p(a)?a:Ja(a);return this.isValid()&&c.isValid()?(b=K(m(b)?"millisecond":b),"millisecond"===b?+c>+this:+this.clone().endOf(b)<+c):!1}function nb(a,b,c){return this.isAfter(a,c)&&this.isBefore(b,c)}function ob(a,b){var c,d=p(a)?a:Ja(a);return this.isValid()&&d.isValid()?(b=K(b||"millisecond"),"millisecond"===b?+this===+d:(c=+d,+this.clone().startOf(b)<=c&&c<=+this.clone().endOf(b))):!1}function pb(a,b){return this.isSame(a,b)||this.isAfter(a,b)}function qb(a,b){return this.isSame(a,b)||this.isBefore(a,b)}function rb(a,b,c){var d,e,f,g;return this.isValid()?(d=Ra(a,this),d.isValid()?(e=6e4*(d.utcOffset()-this.utcOffset()),b=K(b),"year"===b||"month"===b||"quarter"===b?(g=sb(this,d),"quarter"===b?g/=3:"year"===b&&(g/=12)):(f=this-d,g="second"===b?f/1e3:"minute"===b?f/6e4:"hour"===b?f/36e5:"day"===b?(f-e)/864e5:"week"===b?(f-e)/6048e5:f),c?g:q(g)):NaN):NaN}function sb(a,b){var c,d,e=12*(b.year()-a.year())+(b.month()-a.month()),f=a.clone().add(e,"months");return 0>b-f?(c=a.clone().add(e-1,"months"),d=(b-f)/(f-c)):(c=a.clone().add(e+1,"months"),d=(b-f)/(c-f)),-(e+d)}function tb(){return this.clone().locale("en").format("ddd MMM DD YYYY HH:mm:ss [GMT]ZZ")}function ub(){var a=this.clone().utc();return 0<a.year()&&a.year()<=9999?w(Date.prototype.toISOString)?this.toDate().toISOString():U(a,"YYYY-MM-DD[T]HH:mm:ss.SSS[Z]"):U(a,"YYYYYY-MM-DD[T]HH:mm:ss.SSS[Z]")}function vb(b){var c=U(this,b||a.defaultFormat);return this.localeData().postformat(c)}function wb(a,b){return this.isValid()&&(p(a)&&a.isValid()||Ja(a).isValid())?cb({to:this,from:a}).locale(this.locale()).humanize(!b):this.localeData().invalidDate()}function xb(a){return this.from(Ja(),a)}function yb(a,b){return this.isValid()&&(p(a)&&a.isValid()||Ja(a).isValid())?cb({from:this,to:a}).locale(this.locale()).humanize(!b):this.localeData().invalidDate()}function zb(a){return this.to(Ja(),a)}function Ab(a){var b;return void 0===a?this._locale._abbr:(b=H(a),null!=b&&(this._locale=b),this)}function Bb(){return this._locale}function Cb(a){switch(a=K(a)){case"year":this.month(0);case"quarter":case"month":this.date(1);case"week":case"isoWeek":case"day":this.hours(0);case"hour":this.minutes(0);case"minute":this.seconds(0);case"second":this.milliseconds(0)}return"week"===a&&this.weekday(0),"isoWeek"===a&&this.isoWeekday(1),"quarter"===a&&this.month(3*Math.floor(this.month()/3)),this}function Db(a){return a=K(a),void 0===a||"millisecond"===a?this:this.startOf(a).add(1,"isoWeek"===a?"week":a).subtract(1,"ms")}function Eb(){return+this._d-6e4*(this._offset||0)}function Fb(){return Math.floor(+this/1e3)}function Gb(){return this._offset?new Date(+this):this._d}function Hb(){var a=this;return[a.year(),a.month(),a.date(),a.hour(),a.minute(),a.second(),a.millisecond()]}function Ib(){var a=this;return{years:a.year(),months:a.month(),date:a.date(),hours:a.hours(),minutes:a.minutes(),seconds:a.seconds(),milliseconds:a.milliseconds()}}function Jb(){return this.isValid()?this.toISOString():null}function Kb(){return k(this)}function Lb(){return g({},j(this))}function Mb(){return j(this).overflow}function Nb(){return{input:this._i,format:this._f,locale:this._locale,isUTC:this._isUTC,strict:this._strict}}function Ob(a,b){R(0,[a,a.length],0,b)}function Pb(a){return Tb.call(this,a,this.week(),this.weekday(),this.localeData()._week.dow,this.localeData()._week.doy)}function Qb(a){return Tb.call(this,a,this.isoWeek(),this.isoWeekday(),1,4)}function Rb(){return wa(this.year(),1,4)}function Sb(){var a=this.localeData()._week;return wa(this.year(),a.dow,a.doy)}function Tb(a,b,c,d,e){var f;return null==a?va(this,d,e).year:(f=wa(a,d,e),b>f&&(b=f),Ub.call(this,a,b,c,d,e))}function Ub(a,b,c,d,e){var f=ua(a,b,c,d,e),g=pa(f.year,0,f.dayOfYear);return this.year(g.getUTCFullYear()),this.month(g.getUTCMonth()),this.date(g.getUTCDate()),this}function Vb(a){return null==a?Math.ceil((this.month()+1)/3):this.month(3*(a-1)+this.month()%3)}function Wb(a){return va(a,this._week.dow,this._week.doy).week}function Xb(){return this._week.dow}function Yb(){return this._week.doy}function Zb(a){var b=this.localeData().week(this);return null==a?b:this.add(7*(a-b),"d")}function $b(a){var b=va(this,1,4).week;return null==a?b:this.add(7*(a-b),"d")}function _b(a,b){return"string"!=typeof a?a:isNaN(a)?(a=b.weekdaysParse(a),"number"==typeof a?a:null):parseInt(a,10)}function ac(a,b){return c(this._weekdays)?this._weekdays[a.day()]:this._weekdays[this._weekdays.isFormat.test(b)?"format":"standalone"][a.day()]}function bc(a){return this._weekdaysShort[a.day()]}function cc(a){return this._weekdaysMin[a.day()]}function dc(a,b,c){var d,e,f;for(this._weekdaysParse||(this._weekdaysParse=[],this._minWeekdaysParse=[],this._shortWeekdaysParse=[],this._fullWeekdaysParse=[]),d=0;7>d;d++){if(e=Ja([2e3,1]).day(d),c&&!this._fullWeekdaysParse[d]&&(this._fullWeekdaysParse[d]=new RegExp("^"+this.weekdays(e,"").replace(".",".?")+"$","i"),this._shortWeekdaysParse[d]=new RegExp("^"+this.weekdaysShort(e,"").replace(".",".?")+"$","i"),this._minWeekdaysParse[d]=new RegExp("^"+this.weekdaysMin(e,"").replace(".",".?")+"$","i")),this._weekdaysParse[d]||(f="^"+this.weekdays(e,"")+"|^"+this.weekdaysShort(e,"")+"|^"+this.weekdaysMin(e,""),this._weekdaysParse[d]=new RegExp(f.replace(".",""),"i")),c&&"dddd"===b&&this._fullWeekdaysParse[d].test(a))return d;if(c&&"ddd"===b&&this._shortWeekdaysParse[d].test(a))return d;if(c&&"dd"===b&&this._minWeekdaysParse[d].test(a))return d;if(!c&&this._weekdaysParse[d].test(a))return d}}function ec(a){if(!this.isValid())return null!=a?this:NaN;var b=this._isUTC?this._d.getUTCDay():this._d.getDay();return null!=a?(a=_b(a,this.localeData()),this.add(a-b,"d")):b}function fc(a){if(!this.isValid())return null!=a?this:NaN;var b=(this.day()+7-this.localeData()._week.dow)%7;return null==a?b:this.add(a-b,"d")}function gc(a){return this.isValid()?null==a?this.day()||7:this.day(this.day()%7?a:a-7):null!=a?this:NaN}function hc(a){var b=Math.round((this.clone().startOf("day")-this.clone().startOf("year"))/864e5)+1;return null==a?b:this.add(a-b,"d")}function ic(){return this.hours()%12||12}function jc(a,b){R(a,0,0,function(){return this.localeData().meridiem(this.hours(),this.minutes(),b)})}function kc(a,b){return b._meridiemParse}function lc(a){return"p"===(a+"").toLowerCase().charAt(0)}function mc(a,b,c){return a>11?c?"pm":"PM":c?"am":"AM"}function nc(a,b){b[Hd]=r(1e3*("0."+a))}function oc(){return this._isUTC?"UTC":""}function pc(){return this._isUTC?"Coordinated Universal Time":""}function qc(a){return Ja(1e3*a)}function rc(){return Ja.apply(null,arguments).parseZone()}function sc(a,b,c){var d=this._calendar[a];return w(d)?d.call(b,c):d}function tc(a){var b=this._longDateFormat[a],c=this._longDateFormat[a.toUpperCase()];return b||!c?b:(this._longDateFormat[a]=c.replace(/MMMM|MM|DD|dddd/g,function(a){return a.slice(1)}),this._longDateFormat[a])}function uc(){return this._invalidDate}function vc(a){return this._ordinal.replace("%d",a)}function wc(a){return a}function xc(a,b,c,d){var e=this._relativeTime[c];return w(e)?e(a,b,c,d):e.replace(/%d/i,a)}function yc(a,b){var c=this._relativeTime[a>0?"future":"past"];return w(c)?c(b):c.replace(/%s/i,b)}function zc(a,b,c,d){var e=H(),f=h().set(d,b);return e[c](f,a)}function Ac(a,b,c,d,e){if("number"==typeof a&&(b=a,a=void 0),a=a||"",null!=b)return zc(a,b,c,e);var f,g=[];for(f=0;d>f;f++)g[f]=zc(a,f,c,e);return g}function Bc(a,b){return Ac(a,b,"months",12,"month")}function Cc(a,b){return Ac(a,b,"monthsShort",12,"month")}function Dc(a,b){return Ac(a,b,"weekdays",7,"day")}function Ec(a,b){return Ac(a,b,"weekdaysShort",7,"day")}function Fc(a,b){return Ac(a,b,"weekdaysMin",7,"day")}function Gc(){var a=this._data;return this._milliseconds=xe(this._milliseconds),this._days=xe(this._days),this._months=xe(this._months),a.milliseconds=xe(a.milliseconds),a.seconds=xe(a.seconds),a.minutes=xe(a.minutes),a.hours=xe(a.hours),a.months=xe(a.months),a.years=xe(a.years),this}function Hc(a,b,c,d){var e=cb(b,c);return a._milliseconds+=d*e._milliseconds,a._days+=d*e._days,a._months+=d*e._months,a._bubble()}function Ic(a,b){return Hc(this,a,b,1)}function Jc(a,b){return Hc(this,a,b,-1)}function Kc(a){return 0>a?Math.floor(a):Math.ceil(a)}function Lc(){var a,b,c,d,e,f=this._milliseconds,g=this._days,h=this._months,i=this._data;return f>=0&&g>=0&&h>=0||0>=f&&0>=g&&0>=h||(f+=864e5*Kc(Nc(h)+g),g=0,h=0),i.milliseconds=f%1e3,a=q(f/1e3),i.seconds=a%60,b=q(a/60),i.minutes=b%60,c=q(b/60),i.hours=c%24,g+=q(c/24),e=q(Mc(g)),h+=e,g-=Kc(Nc(e)),d=q(h/12),h%=12,i.days=g,i.months=h,i.years=d,this}function Mc(a){return 4800*a/146097}function Nc(a){return 146097*a/4800}function Oc(a){var b,c,d=this._milliseconds;if(a=K(a),"month"===a||"year"===a)return b=this._days+d/864e5,c=this._months+Mc(b),"month"===a?c:c/12;switch(b=this._days+Math.round(Nc(this._months)),a){case"week":return b/7+d/6048e5;case"day":return b+d/864e5;case"hour":return 24*b+d/36e5;case"minute":return 1440*b+d/6e4;case"second":return 86400*b+d/1e3;case"millisecond":return Math.floor(864e5*b)+d;default:throw new Error("Unknown unit "+a)}}function Pc(){return this._milliseconds+864e5*this._days+this._months%12*2592e6+31536e6*r(this._months/12)}function Qc(a){return function(){return this.as(a)}}function Rc(a){return a=K(a),this[a+"s"]()}function Sc(a){return function(){return this._data[a]}}function Tc(){return q(this.days()/7)}function Uc(a,b,c,d,e){return e.relativeTime(b||1,!!c,a,d)}function Vc(a,b,c){var d=cb(a).abs(),e=Ne(d.as("s")),f=Ne(d.as("m")),g=Ne(d.as("h")),h=Ne(d.as("d")),i=Ne(d.as("M")),j=Ne(d.as("y")),k=e<Oe.s&&["s",e]||1>=f&&["m"]||f<Oe.m&&["mm",f]||1>=g&&["h"]||g<Oe.h&&["hh",g]||1>=h&&["d"]||h<Oe.d&&["dd",h]||1>=i&&["M"]||i<Oe.M&&["MM",i]||1>=j&&["y"]||["yy",j];return k[2]=b,k[3]=+a>0,k[4]=c,Uc.apply(null,k)}function Wc(a,b){return void 0===Oe[a]?!1:void 0===b?Oe[a]:(Oe[a]=b,!0)}function Xc(a){var b=this.localeData(),c=Vc(this,!a,b);return a&&(c=b.pastFuture(+this,c)),b.postformat(c)}function Yc(){var a,b,c,d=Pe(this._milliseconds)/1e3,e=Pe(this._days),f=Pe(this._months);a=q(d/60),b=q(a/60),d%=60,a%=60,c=q(f/12),f%=12;var g=c,h=f,i=e,j=b,k=a,l=d,m=this.asSeconds();return m?(0>m?"-":"")+"P"+(g?g+"Y":"")+(h?h+"M":"")+(i?i+"D":"")+(j||k||l?"T":"")+(j?j+"H":"")+(k?k+"M":"")+(l?l+"S":""):"P0D"}var Zc,$c=a.momentProperties=[],_c=!1,ad={};a.suppressDeprecationWarnings=!1;var bd,cd={},dd={},ed=/(\[[^\[]*\])|(\\)?([Hh]mm(ss)?|Mo|MM?M?M?|Do|DDDo|DD?D?D?|ddd?d?|do?|w[o|w]?|W[o|W]?|Qo?|YYYYYY|YYYYY|YYYY|YY|gg(ggg?)?|GG(GGG?)?|e|E|a|A|hh?|HH?|mm?|ss?|S{1,9}|x|X|zz?|ZZ?|.)/g,fd=/(\[[^\[]*\])|(\\)?(LTS|LT|LL?L?L?|l{1,4})/g,gd={},hd={},id=/\d/,jd=/\d\d/,kd=/\d{3}/,ld=/\d{4}/,md=/[+-]?\d{6}/,nd=/\d\d?/,od=/\d\d\d\d?/,pd=/\d\d\d\d\d\d?/,qd=/\d{1,3}/,rd=/\d{1,4}/,sd=/[+-]?\d{1,6}/,td=/\d+/,ud=/[+-]?\d+/,vd=/Z|[+-]\d\d:?\d\d/gi,wd=/Z|[+-]\d\d(?::?\d\d)?/gi,xd=/[+-]?\d+(\.\d{1,3})?/,yd=/[0-9]*['a-z\u00A0-\u05FF\u0700-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+|[\u0600-\u06FF\/]+(\s*?[\u0600-\u06FF]+){1,2}/i,zd={},Ad={},Bd=0,Cd=1,Dd=2,Ed=3,Fd=4,Gd=5,Hd=6,Id=7,Jd=8;R("M",["MM",2],"Mo",function(){return this.month()+1}),R("MMM",0,0,function(a){return this.localeData().monthsShort(this,a)}),R("MMMM",0,0,function(a){return this.localeData().months(this,a)}),J("month","M"),W("M",nd),W("MM",nd,jd),W("MMM",function(a,b){return b.monthsShortRegex(a)}),W("MMMM",function(a,b){return b.monthsRegex(a)}),$(["M","MM"],function(a,b){b[Cd]=r(a)-1}),$(["MMM","MMMM"],function(a,b,c,d){var e=c._locale.monthsParse(a,d,c._strict);null!=e?b[Cd]=e:j(c).invalidMonth=a});var Kd=/D[oD]?(\[[^\[\]]*\]|\s+)+MMMM?/,Ld="January_February_March_April_May_June_July_August_September_October_November_December".split("_"),Md="Jan_Feb_Mar_Apr_May_Jun_Jul_Aug_Sep_Oct_Nov_Dec".split("_"),Nd=yd,Od=yd,Pd=/^\s*((?:[+-]\d{6}|\d{4})-(?:\d\d-\d\d|W\d\d-\d|W\d\d|\d\d\d|\d\d))(?:(T| )(\d\d(?::\d\d(?::\d\d(?:[.,]\d+)?)?)?)([\+\-]\d\d(?::?\d\d)?|\s*Z)?)?/,Qd=/^\s*((?:[+-]\d{6}|\d{4})(?:\d\d\d\d|W\d\d\d|W\d\d|\d\d\d|\d\d))(?:(T| )(\d\d(?:\d\d(?:\d\d(?:[.,]\d+)?)?)?)([\+\-]\d\d(?::?\d\d)?|\s*Z)?)?/,Rd=/Z|[+-]\d\d(?::?\d\d)?/,Sd=[["YYYYYY-MM-DD",/[+-]\d{6}-\d\d-\d\d/],["YYYY-MM-DD",/\d{4}-\d\d-\d\d/],["GGGG-[W]WW-E",/\d{4}-W\d\d-\d/],["GGGG-[W]WW",/\d{4}-W\d\d/,!1],["YYYY-DDD",/\d{4}-\d{3}/],["YYYY-MM",/\d{4}-\d\d/,!1],["YYYYYYMMDD",/[+-]\d{10}/],["YYYYMMDD",/\d{8}/],["GGGG[W]WWE",/\d{4}W\d{3}/],["GGGG[W]WW",/\d{4}W\d{2}/,!1],["YYYYDDD",/\d{7}/]],Td=[["HH:mm:ss.SSSS",/\d\d:\d\d:\d\d\.\d+/],["HH:mm:ss,SSSS",/\d\d:\d\d:\d\d,\d+/],["HH:mm:ss",/\d\d:\d\d:\d\d/],["HH:mm",/\d\d:\d\d/],["HHmmss.SSSS",/\d\d\d\d\d\d\.\d+/],["HHmmss,SSSS",/\d\d\d\d\d\d,\d+/],["HHmmss",/\d\d\d\d\d\d/],["HHmm",/\d\d\d\d/],["HH",/\d\d/]],Ud=/^\/?Date\((\-?\d+)/i;a.createFromInputFallback=u("moment construction falls back to js Date. This is discouraged and will be removed in upcoming major release. Please refer to https://github.com/moment/moment/issues/1407 for more info.",function(a){a._d=new Date(a._i+(a._useUTC?" UTC":""))}),R("Y",0,0,function(){var a=this.year();return 9999>=a?""+a:"+"+a}),R(0,["YY",2],0,function(){return this.year()%100}),R(0,["YYYY",4],0,"year"),R(0,["YYYYY",5],0,"year"),R(0,["YYYYYY",6,!0],0,"year"),J("year","y"),W("Y",ud),W("YY",nd,jd),W("YYYY",rd,ld),W("YYYYY",sd,md),W("YYYYYY",sd,md),$(["YYYYY","YYYYYY"],Bd),$("YYYY",function(b,c){c[Bd]=2===b.length?a.parseTwoDigitYear(b):r(b);
|
7 |
}),$("YY",function(b,c){c[Bd]=a.parseTwoDigitYear(b)}),$("Y",function(a,b){b[Bd]=parseInt(a,10)}),a.parseTwoDigitYear=function(a){return r(a)+(r(a)>68?1900:2e3)};var Vd=M("FullYear",!1);a.ISO_8601=function(){};var Wd=u("moment().min is deprecated, use moment.max instead. https://github.com/moment/moment/issues/1548",function(){var a=Ja.apply(null,arguments);return this.isValid()&&a.isValid()?this>a?this:a:l()}),Xd=u("moment().max is deprecated, use moment.min instead. https://github.com/moment/moment/issues/1548",function(){var a=Ja.apply(null,arguments);return this.isValid()&&a.isValid()?a>this?this:a:l()}),Yd=function(){return Date.now?Date.now():+new Date};Pa("Z",":"),Pa("ZZ",""),W("Z",wd),W("ZZ",wd),$(["Z","ZZ"],function(a,b,c){c._useUTC=!0,c._tzm=Qa(wd,a)});var Zd=/([\+\-]|\d\d)/gi;a.updateOffset=function(){};var $d=/^(\-)?(?:(\d*)[. ])?(\d+)\:(\d+)(?:\:(\d+)\.?(\d{3})?\d*)?$/,_d=/^(-)?P(?:([0-9,.]*)Y)?(?:([0-9,.]*)M)?(?:([0-9,.]*)W)?(?:([0-9,.]*)D)?(?:T(?:([0-9,.]*)H)?(?:([0-9,.]*)M)?(?:([0-9,.]*)S)?)?$/;cb.fn=Na.prototype;var ae=hb(1,"add"),be=hb(-1,"subtract");a.defaultFormat="YYYY-MM-DDTHH:mm:ssZ";var ce=u("moment().lang() is deprecated. Instead, use moment().localeData() to get the language configuration. Use moment().locale() to change languages.",function(a){return void 0===a?this.localeData():this.locale(a)});R(0,["gg",2],0,function(){return this.weekYear()%100}),R(0,["GG",2],0,function(){return this.isoWeekYear()%100}),Ob("gggg","weekYear"),Ob("ggggg","weekYear"),Ob("GGGG","isoWeekYear"),Ob("GGGGG","isoWeekYear"),J("weekYear","gg"),J("isoWeekYear","GG"),W("G",ud),W("g",ud),W("GG",nd,jd),W("gg",nd,jd),W("GGGG",rd,ld),W("gggg",rd,ld),W("GGGGG",sd,md),W("ggggg",sd,md),_(["gggg","ggggg","GGGG","GGGGG"],function(a,b,c,d){b[d.substr(0,2)]=r(a)}),_(["gg","GG"],function(b,c,d,e){c[e]=a.parseTwoDigitYear(b)}),R("Q",0,"Qo","quarter"),J("quarter","Q"),W("Q",id),$("Q",function(a,b){b[Cd]=3*(r(a)-1)}),R("w",["ww",2],"wo","week"),R("W",["WW",2],"Wo","isoWeek"),J("week","w"),J("isoWeek","W"),W("w",nd),W("ww",nd,jd),W("W",nd),W("WW",nd,jd),_(["w","ww","W","WW"],function(a,b,c,d){b[d.substr(0,1)]=r(a)});var de={dow:0,doy:6};R("D",["DD",2],"Do","date"),J("date","D"),W("D",nd),W("DD",nd,jd),W("Do",function(a,b){return a?b._ordinalParse:b._ordinalParseLenient}),$(["D","DD"],Dd),$("Do",function(a,b){b[Dd]=r(a.match(nd)[0],10)});var ee=M("Date",!0);R("d",0,"do","day"),R("dd",0,0,function(a){return this.localeData().weekdaysMin(this,a)}),R("ddd",0,0,function(a){return this.localeData().weekdaysShort(this,a)}),R("dddd",0,0,function(a){return this.localeData().weekdays(this,a)}),R("e",0,0,"weekday"),R("E",0,0,"isoWeekday"),J("day","d"),J("weekday","e"),J("isoWeekday","E"),W("d",nd),W("e",nd),W("E",nd),W("dd",yd),W("ddd",yd),W("dddd",yd),_(["dd","ddd","dddd"],function(a,b,c,d){var e=c._locale.weekdaysParse(a,d,c._strict);null!=e?b.d=e:j(c).invalidWeekday=a}),_(["d","e","E"],function(a,b,c,d){b[d]=r(a)});var fe="Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"),ge="Sun_Mon_Tue_Wed_Thu_Fri_Sat".split("_"),he="Su_Mo_Tu_We_Th_Fr_Sa".split("_");R("DDD",["DDDD",3],"DDDo","dayOfYear"),J("dayOfYear","DDD"),W("DDD",qd),W("DDDD",kd),$(["DDD","DDDD"],function(a,b,c){c._dayOfYear=r(a)}),R("H",["HH",2],0,"hour"),R("h",["hh",2],0,ic),R("hmm",0,0,function(){return""+ic.apply(this)+Q(this.minutes(),2)}),R("hmmss",0,0,function(){return""+ic.apply(this)+Q(this.minutes(),2)+Q(this.seconds(),2)}),R("Hmm",0,0,function(){return""+this.hours()+Q(this.minutes(),2)}),R("Hmmss",0,0,function(){return""+this.hours()+Q(this.minutes(),2)+Q(this.seconds(),2)}),jc("a",!0),jc("A",!1),J("hour","h"),W("a",kc),W("A",kc),W("H",nd),W("h",nd),W("HH",nd,jd),W("hh",nd,jd),W("hmm",od),W("hmmss",pd),W("Hmm",od),W("Hmmss",pd),$(["H","HH"],Ed),$(["a","A"],function(a,b,c){c._isPm=c._locale.isPM(a),c._meridiem=a}),$(["h","hh"],function(a,b,c){b[Ed]=r(a),j(c).bigHour=!0}),$("hmm",function(a,b,c){var d=a.length-2;b[Ed]=r(a.substr(0,d)),b[Fd]=r(a.substr(d)),j(c).bigHour=!0}),$("hmmss",function(a,b,c){var d=a.length-4,e=a.length-2;b[Ed]=r(a.substr(0,d)),b[Fd]=r(a.substr(d,2)),b[Gd]=r(a.substr(e)),j(c).bigHour=!0}),$("Hmm",function(a,b,c){var d=a.length-2;b[Ed]=r(a.substr(0,d)),b[Fd]=r(a.substr(d))}),$("Hmmss",function(a,b,c){var d=a.length-4,e=a.length-2;b[Ed]=r(a.substr(0,d)),b[Fd]=r(a.substr(d,2)),b[Gd]=r(a.substr(e))});var ie=/[ap]\.?m?\.?/i,je=M("Hours",!0);R("m",["mm",2],0,"minute"),J("minute","m"),W("m",nd),W("mm",nd,jd),$(["m","mm"],Fd);var ke=M("Minutes",!1);R("s",["ss",2],0,"second"),J("second","s"),W("s",nd),W("ss",nd,jd),$(["s","ss"],Gd);var le=M("Seconds",!1);R("S",0,0,function(){return~~(this.millisecond()/100)}),R(0,["SS",2],0,function(){return~~(this.millisecond()/10)}),R(0,["SSS",3],0,"millisecond"),R(0,["SSSS",4],0,function(){return 10*this.millisecond()}),R(0,["SSSSS",5],0,function(){return 100*this.millisecond()}),R(0,["SSSSSS",6],0,function(){return 1e3*this.millisecond()}),R(0,["SSSSSSS",7],0,function(){return 1e4*this.millisecond()}),R(0,["SSSSSSSS",8],0,function(){return 1e5*this.millisecond()}),R(0,["SSSSSSSSS",9],0,function(){return 1e6*this.millisecond()}),J("millisecond","ms"),W("S",qd,id),W("SS",qd,jd),W("SSS",qd,kd);var me;for(me="SSSS";me.length<=9;me+="S")W(me,td);for(me="S";me.length<=9;me+="S")$(me,nc);var ne=M("Milliseconds",!1);R("z",0,0,"zoneAbbr"),R("zz",0,0,"zoneName");var oe=o.prototype;oe.add=ae,oe.calendar=jb,oe.clone=kb,oe.diff=rb,oe.endOf=Db,oe.format=vb,oe.from=wb,oe.fromNow=xb,oe.to=yb,oe.toNow=zb,oe.get=P,oe.invalidAt=Mb,oe.isAfter=lb,oe.isBefore=mb,oe.isBetween=nb,oe.isSame=ob,oe.isSameOrAfter=pb,oe.isSameOrBefore=qb,oe.isValid=Kb,oe.lang=ce,oe.locale=Ab,oe.localeData=Bb,oe.max=Xd,oe.min=Wd,oe.parsingFlags=Lb,oe.set=P,oe.startOf=Cb,oe.subtract=be,oe.toArray=Hb,oe.toObject=Ib,oe.toDate=Gb,oe.toISOString=ub,oe.toJSON=Jb,oe.toString=tb,oe.unix=Fb,oe.valueOf=Eb,oe.creationData=Nb,oe.year=Vd,oe.isLeapYear=sa,oe.weekYear=Pb,oe.isoWeekYear=Qb,oe.quarter=oe.quarters=Vb,oe.month=ga,oe.daysInMonth=ha,oe.week=oe.weeks=Zb,oe.isoWeek=oe.isoWeeks=$b,oe.weeksInYear=Sb,oe.isoWeeksInYear=Rb,oe.date=ee,oe.day=oe.days=ec,oe.weekday=fc,oe.isoWeekday=gc,oe.dayOfYear=hc,oe.hour=oe.hours=je,oe.minute=oe.minutes=ke,oe.second=oe.seconds=le,oe.millisecond=oe.milliseconds=ne,oe.utcOffset=Ta,oe.utc=Va,oe.local=Wa,oe.parseZone=Xa,oe.hasAlignedHourOffset=Ya,oe.isDST=Za,oe.isDSTShifted=$a,oe.isLocal=_a,oe.isUtcOffset=ab,oe.isUtc=bb,oe.isUTC=bb,oe.zoneAbbr=oc,oe.zoneName=pc,oe.dates=u("dates accessor is deprecated. Use date instead.",ee),oe.months=u("months accessor is deprecated. Use month instead",ga),oe.years=u("years accessor is deprecated. Use year instead",Vd),oe.zone=u("moment().zone is deprecated, use moment().utcOffset instead. https://github.com/moment/moment/issues/1779",Ua);var pe=oe,qe={sameDay:"[Today at] LT",nextDay:"[Tomorrow at] LT",nextWeek:"dddd [at] LT",lastDay:"[Yesterday at] LT",lastWeek:"[Last] dddd [at] LT",sameElse:"L"},re={LTS:"h:mm:ss A",LT:"h:mm A",L:"MM/DD/YYYY",LL:"MMMM D, YYYY",LLL:"MMMM D, YYYY h:mm A",LLLL:"dddd, MMMM D, YYYY h:mm A"},se="Invalid date",te="%d",ue=/\d{1,2}/,ve={future:"in %s",past:"%s ago",s:"a few seconds",m:"a minute",mm:"%d minutes",h:"an hour",hh:"%d hours",d:"a day",dd:"%d days",M:"a month",MM:"%d months",y:"a year",yy:"%d years"},we=A.prototype;we._calendar=qe,we.calendar=sc,we._longDateFormat=re,we.longDateFormat=tc,we._invalidDate=se,we.invalidDate=uc,we._ordinal=te,we.ordinal=vc,we._ordinalParse=ue,we.preparse=wc,we.postformat=wc,we._relativeTime=ve,we.relativeTime=xc,we.pastFuture=yc,we.set=y,we.months=ca,we._months=Ld,we.monthsShort=da,we._monthsShort=Md,we.monthsParse=ea,we._monthsRegex=Od,we.monthsRegex=ja,we._monthsShortRegex=Nd,we.monthsShortRegex=ia,we.week=Wb,we._week=de,we.firstDayOfYear=Yb,we.firstDayOfWeek=Xb,we.weekdays=ac,we._weekdays=fe,we.weekdaysMin=cc,we._weekdaysMin=he,we.weekdaysShort=bc,we._weekdaysShort=ge,we.weekdaysParse=dc,we.isPM=lc,we._meridiemParse=ie,we.meridiem=mc,E("en",{ordinalParse:/\d{1,2}(th|st|nd|rd)/,ordinal:function(a){var b=a%10,c=1===r(a%100/10)?"th":1===b?"st":2===b?"nd":3===b?"rd":"th";return a+c}}),a.lang=u("moment.lang is deprecated. Use moment.locale instead.",E),a.langData=u("moment.langData is deprecated. Use moment.localeData instead.",H);var xe=Math.abs,ye=Qc("ms"),ze=Qc("s"),Ae=Qc("m"),Be=Qc("h"),Ce=Qc("d"),De=Qc("w"),Ee=Qc("M"),Fe=Qc("y"),Ge=Sc("milliseconds"),He=Sc("seconds"),Ie=Sc("minutes"),Je=Sc("hours"),Ke=Sc("days"),Le=Sc("months"),Me=Sc("years"),Ne=Math.round,Oe={s:45,m:45,h:22,d:26,M:11},Pe=Math.abs,Qe=Na.prototype;Qe.abs=Gc,Qe.add=Ic,Qe.subtract=Jc,Qe.as=Oc,Qe.asMilliseconds=ye,Qe.asSeconds=ze,Qe.asMinutes=Ae,Qe.asHours=Be,Qe.asDays=Ce,Qe.asWeeks=De,Qe.asMonths=Ee,Qe.asYears=Fe,Qe.valueOf=Pc,Qe._bubble=Lc,Qe.get=Rc,Qe.milliseconds=Ge,Qe.seconds=He,Qe.minutes=Ie,Qe.hours=Je,Qe.days=Ke,Qe.weeks=Tc,Qe.months=Le,Qe.years=Me,Qe.humanize=Xc,Qe.toISOString=Yc,Qe.toString=Yc,Qe.toJSON=Yc,Qe.locale=Ab,Qe.localeData=Bb,Qe.toIsoString=u("toIsoString() is deprecated. Please use toISOString() instead (notice the capitals)",Yc),Qe.lang=ce,R("X",0,0,"unix"),R("x",0,0,"valueOf"),W("x",ud),W("X",xd),$("X",function(a,b,c){c._d=new Date(1e3*parseFloat(a,10))}),$("x",function(a,b,c){c._d=new Date(r(a))}),a.version="2.12.0",b(Ja),a.fn=pe,a.min=La,a.max=Ma,a.now=Yd,a.utc=h,a.unix=qc,a.months=Bc,a.isDate=d,a.locale=E,a.invalid=l,a.duration=cb,a.isMoment=p,a.weekdays=Dc,a.parseZone=rc,a.localeData=H,a.isDuration=Oa,a.monthsShort=Cc,a.weekdaysMin=Fc,a.defineLocale=F,a.updateLocale=G,a.locales=I,a.weekdaysShort=Ec,a.normalizeUnits=K,a.relativeTimeThreshold=Wc,a.prototype=pe;var Re=a;return Re});
|
1 |
+
//! moment.js
|
2 |
+
//! version : 2.12.0
|
3 |
+
//! authors : Tim Wood, Iskren Chernev, Moment.js contributors
|
4 |
+
//! license : MIT
|
5 |
+
//! momentjs.com
|
6 |
+
!function(a,b){"object"==typeof exports&&"undefined"!=typeof module?module.exports=b():"function"==typeof define&&define.amd?define(b):a.moment=b()}(this,function(){"use strict";function a(){return Zc.apply(null,arguments)}function b(a){Zc=a}function c(a){return a instanceof Array||"[object Array]"===Object.prototype.toString.call(a)}function d(a){return a instanceof Date||"[object Date]"===Object.prototype.toString.call(a)}function e(a,b){var c,d=[];for(c=0;c<a.length;++c)d.push(b(a[c],c));return d}function f(a,b){return Object.prototype.hasOwnProperty.call(a,b)}function g(a,b){for(var c in b)f(b,c)&&(a[c]=b[c]);return f(b,"toString")&&(a.toString=b.toString),f(b,"valueOf")&&(a.valueOf=b.valueOf),a}function h(a,b,c,d){return Ia(a,b,c,d,!0).utc()}function i(){return{empty:!1,unusedTokens:[],unusedInput:[],overflow:-2,charsLeftOver:0,nullInput:!1,invalidMonth:null,invalidFormat:!1,userInvalidated:!1,iso:!1}}function j(a){return null==a._pf&&(a._pf=i()),a._pf}function k(a){if(null==a._isValid){var b=j(a);a._isValid=!(isNaN(a._d.getTime())||!(b.overflow<0)||b.empty||b.invalidMonth||b.invalidWeekday||b.nullInput||b.invalidFormat||b.userInvalidated),a._strict&&(a._isValid=a._isValid&&0===b.charsLeftOver&&0===b.unusedTokens.length&&void 0===b.bigHour)}return a._isValid}function l(a){var b=h(NaN);return null!=a?g(j(b),a):j(b).userInvalidated=!0,b}function m(a){return void 0===a}function n(a,b){var c,d,e;if(m(b._isAMomentObject)||(a._isAMomentObject=b._isAMomentObject),m(b._i)||(a._i=b._i),m(b._f)||(a._f=b._f),m(b._l)||(a._l=b._l),m(b._strict)||(a._strict=b._strict),m(b._tzm)||(a._tzm=b._tzm),m(b._isUTC)||(a._isUTC=b._isUTC),m(b._offset)||(a._offset=b._offset),m(b._pf)||(a._pf=j(b)),m(b._locale)||(a._locale=b._locale),$c.length>0)for(c in $c)d=$c[c],e=b[d],m(e)||(a[d]=e);return a}function o(b){n(this,b),this._d=new Date(null!=b._d?b._d.getTime():NaN),_c===!1&&(_c=!0,a.updateOffset(this),_c=!1)}function p(a){return a instanceof o||null!=a&&null!=a._isAMomentObject}function q(a){return 0>a?Math.ceil(a):Math.floor(a)}function r(a){var b=+a,c=0;return 0!==b&&isFinite(b)&&(c=q(b)),c}function s(a,b,c){var d,e=Math.min(a.length,b.length),f=Math.abs(a.length-b.length),g=0;for(d=0;e>d;d++)(c&&a[d]!==b[d]||!c&&r(a[d])!==r(b[d]))&&g++;return g+f}function t(b){a.suppressDeprecationWarnings===!1&&"undefined"!=typeof console&&console.warn&&console.warn("Deprecation warning: "+b)}function u(a,b){var c=!0;return g(function(){return c&&(t(a+"\nArguments: "+Array.prototype.slice.call(arguments).join(", ")+"\n"+(new Error).stack),c=!1),b.apply(this,arguments)},b)}function v(a,b){ad[a]||(t(b),ad[a]=!0)}function w(a){return a instanceof Function||"[object Function]"===Object.prototype.toString.call(a)}function x(a){return"[object Object]"===Object.prototype.toString.call(a)}function y(a){var b,c;for(c in a)b=a[c],w(b)?this[c]=b:this["_"+c]=b;this._config=a,this._ordinalParseLenient=new RegExp(this._ordinalParse.source+"|"+/\d{1,2}/.source)}function z(a,b){var c,d=g({},a);for(c in b)f(b,c)&&(x(a[c])&&x(b[c])?(d[c]={},g(d[c],a[c]),g(d[c],b[c])):null!=b[c]?d[c]=b[c]:delete d[c]);return d}function A(a){null!=a&&this.set(a)}function B(a){return a?a.toLowerCase().replace("_","-"):a}function C(a){for(var b,c,d,e,f=0;f<a.length;){for(e=B(a[f]).split("-"),b=e.length,c=B(a[f+1]),c=c?c.split("-"):null;b>0;){if(d=D(e.slice(0,b).join("-")))return d;if(c&&c.length>=b&&s(e,c,!0)>=b-1)break;b--}f++}return null}function D(a){var b=null;if(!cd[a]&&"undefined"!=typeof module&&module&&module.exports)try{b=bd._abbr,require("./locale/"+a),E(b)}catch(c){}return cd[a]}function E(a,b){var c;return a&&(c=m(b)?H(a):F(a,b),c&&(bd=c)),bd._abbr}function F(a,b){return null!==b?(b.abbr=a,null!=cd[a]?(v("defineLocaleOverride","use moment.updateLocale(localeName, config) to change an existing locale. moment.defineLocale(localeName, config) should only be used for creating a new locale"),b=z(cd[a]._config,b)):null!=b.parentLocale&&(null!=cd[b.parentLocale]?b=z(cd[b.parentLocale]._config,b):v("parentLocaleUndefined","specified parentLocale is not defined yet")),cd[a]=new A(b),E(a),cd[a]):(delete cd[a],null)}function G(a,b){if(null!=b){var c;null!=cd[a]&&(b=z(cd[a]._config,b)),c=new A(b),c.parentLocale=cd[a],cd[a]=c,E(a)}else null!=cd[a]&&(null!=cd[a].parentLocale?cd[a]=cd[a].parentLocale:null!=cd[a]&&delete cd[a]);return cd[a]}function H(a){var b;if(a&&a._locale&&a._locale._abbr&&(a=a._locale._abbr),!a)return bd;if(!c(a)){if(b=D(a))return b;a=[a]}return C(a)}function I(){return Object.keys(cd)}function J(a,b){var c=a.toLowerCase();dd[c]=dd[c+"s"]=dd[b]=a}function K(a){return"string"==typeof a?dd[a]||dd[a.toLowerCase()]:void 0}function L(a){var b,c,d={};for(c in a)f(a,c)&&(b=K(c),b&&(d[b]=a[c]));return d}function M(b,c){return function(d){return null!=d?(O(this,b,d),a.updateOffset(this,c),this):N(this,b)}}function N(a,b){return a.isValid()?a._d["get"+(a._isUTC?"UTC":"")+b]():NaN}function O(a,b,c){a.isValid()&&a._d["set"+(a._isUTC?"UTC":"")+b](c)}function P(a,b){var c;if("object"==typeof a)for(c in a)this.set(c,a[c]);else if(a=K(a),w(this[a]))return this[a](b);return this}function Q(a,b,c){var d=""+Math.abs(a),e=b-d.length,f=a>=0;return(f?c?"+":"":"-")+Math.pow(10,Math.max(0,e)).toString().substr(1)+d}function R(a,b,c,d){var e=d;"string"==typeof d&&(e=function(){return this[d]()}),a&&(hd[a]=e),b&&(hd[b[0]]=function(){return Q(e.apply(this,arguments),b[1],b[2])}),c&&(hd[c]=function(){return this.localeData().ordinal(e.apply(this,arguments),a)})}function S(a){return a.match(/\[[\s\S]/)?a.replace(/^\[|\]$/g,""):a.replace(/\\/g,"")}function T(a){var b,c,d=a.match(ed);for(b=0,c=d.length;c>b;b++)hd[d[b]]?d[b]=hd[d[b]]:d[b]=S(d[b]);return function(e){var f="";for(b=0;c>b;b++)f+=d[b]instanceof Function?d[b].call(e,a):d[b];return f}}function U(a,b){return a.isValid()?(b=V(b,a.localeData()),gd[b]=gd[b]||T(b),gd[b](a)):a.localeData().invalidDate()}function V(a,b){function c(a){return b.longDateFormat(a)||a}var d=5;for(fd.lastIndex=0;d>=0&&fd.test(a);)a=a.replace(fd,c),fd.lastIndex=0,d-=1;return a}function W(a,b,c){zd[a]=w(b)?b:function(a,d){return a&&c?c:b}}function X(a,b){return f(zd,a)?zd[a](b._strict,b._locale):new RegExp(Y(a))}function Y(a){return Z(a.replace("\\","").replace(/\\(\[)|\\(\])|\[([^\]\[]*)\]|\\(.)/g,function(a,b,c,d,e){return b||c||d||e}))}function Z(a){return a.replace(/[-\/\\^$*+?.()|[\]{}]/g,"\\$&")}function $(a,b){var c,d=b;for("string"==typeof a&&(a=[a]),"number"==typeof b&&(d=function(a,c){c[b]=r(a)}),c=0;c<a.length;c++)Ad[a[c]]=d}function _(a,b){$(a,function(a,c,d,e){d._w=d._w||{},b(a,d._w,d,e)})}function aa(a,b,c){null!=b&&f(Ad,a)&&Ad[a](b,c._a,c,a)}function ba(a,b){return new Date(Date.UTC(a,b+1,0)).getUTCDate()}function ca(a,b){return c(this._months)?this._months[a.month()]:this._months[Kd.test(b)?"format":"standalone"][a.month()]}function da(a,b){return c(this._monthsShort)?this._monthsShort[a.month()]:this._monthsShort[Kd.test(b)?"format":"standalone"][a.month()]}function ea(a,b,c){var d,e,f;for(this._monthsParse||(this._monthsParse=[],this._longMonthsParse=[],this._shortMonthsParse=[]),d=0;12>d;d++){if(e=h([2e3,d]),c&&!this._longMonthsParse[d]&&(this._longMonthsParse[d]=new RegExp("^"+this.months(e,"").replace(".","")+"$","i"),this._shortMonthsParse[d]=new RegExp("^"+this.monthsShort(e,"").replace(".","")+"$","i")),c||this._monthsParse[d]||(f="^"+this.months(e,"")+"|^"+this.monthsShort(e,""),this._monthsParse[d]=new RegExp(f.replace(".",""),"i")),c&&"MMMM"===b&&this._longMonthsParse[d].test(a))return d;if(c&&"MMM"===b&&this._shortMonthsParse[d].test(a))return d;if(!c&&this._monthsParse[d].test(a))return d}}function fa(a,b){var c;if(!a.isValid())return a;if("string"==typeof b)if(/^\d+$/.test(b))b=r(b);else if(b=a.localeData().monthsParse(b),"number"!=typeof b)return a;return c=Math.min(a.date(),ba(a.year(),b)),a._d["set"+(a._isUTC?"UTC":"")+"Month"](b,c),a}function ga(b){return null!=b?(fa(this,b),a.updateOffset(this,!0),this):N(this,"Month")}function ha(){return ba(this.year(),this.month())}function ia(a){return this._monthsParseExact?(f(this,"_monthsRegex")||ka.call(this),a?this._monthsShortStrictRegex:this._monthsShortRegex):this._monthsShortStrictRegex&&a?this._monthsShortStrictRegex:this._monthsShortRegex}function ja(a){return this._monthsParseExact?(f(this,"_monthsRegex")||ka.call(this),a?this._monthsStrictRegex:this._monthsRegex):this._monthsStrictRegex&&a?this._monthsStrictRegex:this._monthsRegex}function ka(){function a(a,b){return b.length-a.length}var b,c,d=[],e=[],f=[];for(b=0;12>b;b++)c=h([2e3,b]),d.push(this.monthsShort(c,"")),e.push(this.months(c,"")),f.push(this.months(c,"")),f.push(this.monthsShort(c,""));for(d.sort(a),e.sort(a),f.sort(a),b=0;12>b;b++)d[b]=Z(d[b]),e[b]=Z(e[b]),f[b]=Z(f[b]);this._monthsRegex=new RegExp("^("+f.join("|")+")","i"),this._monthsShortRegex=this._monthsRegex,this._monthsStrictRegex=new RegExp("^("+e.join("|")+")$","i"),this._monthsShortStrictRegex=new RegExp("^("+d.join("|")+")$","i")}function la(a){var b,c=a._a;return c&&-2===j(a).overflow&&(b=c[Cd]<0||c[Cd]>11?Cd:c[Dd]<1||c[Dd]>ba(c[Bd],c[Cd])?Dd:c[Ed]<0||c[Ed]>24||24===c[Ed]&&(0!==c[Fd]||0!==c[Gd]||0!==c[Hd])?Ed:c[Fd]<0||c[Fd]>59?Fd:c[Gd]<0||c[Gd]>59?Gd:c[Hd]<0||c[Hd]>999?Hd:-1,j(a)._overflowDayOfYear&&(Bd>b||b>Dd)&&(b=Dd),j(a)._overflowWeeks&&-1===b&&(b=Id),j(a)._overflowWeekday&&-1===b&&(b=Jd),j(a).overflow=b),a}function ma(a){var b,c,d,e,f,g,h=a._i,i=Pd.exec(h)||Qd.exec(h);if(i){for(j(a).iso=!0,b=0,c=Sd.length;c>b;b++)if(Sd[b][1].exec(i[1])){e=Sd[b][0],d=Sd[b][2]!==!1;break}if(null==e)return void(a._isValid=!1);if(i[3]){for(b=0,c=Td.length;c>b;b++)if(Td[b][1].exec(i[3])){f=(i[2]||" ")+Td[b][0];break}if(null==f)return void(a._isValid=!1)}if(!d&&null!=f)return void(a._isValid=!1);if(i[4]){if(!Rd.exec(i[4]))return void(a._isValid=!1);g="Z"}a._f=e+(f||"")+(g||""),Ba(a)}else a._isValid=!1}function na(b){var c=Ud.exec(b._i);return null!==c?void(b._d=new Date(+c[1])):(ma(b),void(b._isValid===!1&&(delete b._isValid,a.createFromInputFallback(b))))}function oa(a,b,c,d,e,f,g){var h=new Date(a,b,c,d,e,f,g);return 100>a&&a>=0&&isFinite(h.getFullYear())&&h.setFullYear(a),h}function pa(a){var b=new Date(Date.UTC.apply(null,arguments));return 100>a&&a>=0&&isFinite(b.getUTCFullYear())&&b.setUTCFullYear(a),b}function qa(a){return ra(a)?366:365}function ra(a){return a%4===0&&a%100!==0||a%400===0}function sa(){return ra(this.year())}function ta(a,b,c){var d=7+b-c,e=(7+pa(a,0,d).getUTCDay()-b)%7;return-e+d-1}function ua(a,b,c,d,e){var f,g,h=(7+c-d)%7,i=ta(a,d,e),j=1+7*(b-1)+h+i;return 0>=j?(f=a-1,g=qa(f)+j):j>qa(a)?(f=a+1,g=j-qa(a)):(f=a,g=j),{year:f,dayOfYear:g}}function va(a,b,c){var d,e,f=ta(a.year(),b,c),g=Math.floor((a.dayOfYear()-f-1)/7)+1;return 1>g?(e=a.year()-1,d=g+wa(e,b,c)):g>wa(a.year(),b,c)?(d=g-wa(a.year(),b,c),e=a.year()+1):(e=a.year(),d=g),{week:d,year:e}}function wa(a,b,c){var d=ta(a,b,c),e=ta(a+1,b,c);return(qa(a)-d+e)/7}function xa(a,b,c){return null!=a?a:null!=b?b:c}function ya(b){var c=new Date(a.now());return b._useUTC?[c.getUTCFullYear(),c.getUTCMonth(),c.getUTCDate()]:[c.getFullYear(),c.getMonth(),c.getDate()]}function za(a){var b,c,d,e,f=[];if(!a._d){for(d=ya(a),a._w&&null==a._a[Dd]&&null==a._a[Cd]&&Aa(a),a._dayOfYear&&(e=xa(a._a[Bd],d[Bd]),a._dayOfYear>qa(e)&&(j(a)._overflowDayOfYear=!0),c=pa(e,0,a._dayOfYear),a._a[Cd]=c.getUTCMonth(),a._a[Dd]=c.getUTCDate()),b=0;3>b&&null==a._a[b];++b)a._a[b]=f[b]=d[b];for(;7>b;b++)a._a[b]=f[b]=null==a._a[b]?2===b?1:0:a._a[b];24===a._a[Ed]&&0===a._a[Fd]&&0===a._a[Gd]&&0===a._a[Hd]&&(a._nextDay=!0,a._a[Ed]=0),a._d=(a._useUTC?pa:oa).apply(null,f),null!=a._tzm&&a._d.setUTCMinutes(a._d.getUTCMinutes()-a._tzm),a._nextDay&&(a._a[Ed]=24)}}function Aa(a){var b,c,d,e,f,g,h,i;b=a._w,null!=b.GG||null!=b.W||null!=b.E?(f=1,g=4,c=xa(b.GG,a._a[Bd],va(Ja(),1,4).year),d=xa(b.W,1),e=xa(b.E,1),(1>e||e>7)&&(i=!0)):(f=a._locale._week.dow,g=a._locale._week.doy,c=xa(b.gg,a._a[Bd],va(Ja(),f,g).year),d=xa(b.w,1),null!=b.d?(e=b.d,(0>e||e>6)&&(i=!0)):null!=b.e?(e=b.e+f,(b.e<0||b.e>6)&&(i=!0)):e=f),1>d||d>wa(c,f,g)?j(a)._overflowWeeks=!0:null!=i?j(a)._overflowWeekday=!0:(h=ua(c,d,e,f,g),a._a[Bd]=h.year,a._dayOfYear=h.dayOfYear)}function Ba(b){if(b._f===a.ISO_8601)return void ma(b);b._a=[],j(b).empty=!0;var c,d,e,f,g,h=""+b._i,i=h.length,k=0;for(e=V(b._f,b._locale).match(ed)||[],c=0;c<e.length;c++)f=e[c],d=(h.match(X(f,b))||[])[0],d&&(g=h.substr(0,h.indexOf(d)),g.length>0&&j(b).unusedInput.push(g),h=h.slice(h.indexOf(d)+d.length),k+=d.length),hd[f]?(d?j(b).empty=!1:j(b).unusedTokens.push(f),aa(f,d,b)):b._strict&&!d&&j(b).unusedTokens.push(f);j(b).charsLeftOver=i-k,h.length>0&&j(b).unusedInput.push(h),j(b).bigHour===!0&&b._a[Ed]<=12&&b._a[Ed]>0&&(j(b).bigHour=void 0),b._a[Ed]=Ca(b._locale,b._a[Ed],b._meridiem),za(b),la(b)}function Ca(a,b,c){var d;return null==c?b:null!=a.meridiemHour?a.meridiemHour(b,c):null!=a.isPM?(d=a.isPM(c),d&&12>b&&(b+=12),d||12!==b||(b=0),b):b}function Da(a){var b,c,d,e,f;if(0===a._f.length)return j(a).invalidFormat=!0,void(a._d=new Date(NaN));for(e=0;e<a._f.length;e++)f=0,b=n({},a),null!=a._useUTC&&(b._useUTC=a._useUTC),b._f=a._f[e],Ba(b),k(b)&&(f+=j(b).charsLeftOver,f+=10*j(b).unusedTokens.length,j(b).score=f,(null==d||d>f)&&(d=f,c=b));g(a,c||b)}function Ea(a){if(!a._d){var b=L(a._i);a._a=e([b.year,b.month,b.day||b.date,b.hour,b.minute,b.second,b.millisecond],function(a){return a&&parseInt(a,10)}),za(a)}}function Fa(a){var b=new o(la(Ga(a)));return b._nextDay&&(b.add(1,"d"),b._nextDay=void 0),b}function Ga(a){var b=a._i,e=a._f;return a._locale=a._locale||H(a._l),null===b||void 0===e&&""===b?l({nullInput:!0}):("string"==typeof b&&(a._i=b=a._locale.preparse(b)),p(b)?new o(la(b)):(c(e)?Da(a):e?Ba(a):d(b)?a._d=b:Ha(a),k(a)||(a._d=null),a))}function Ha(b){var f=b._i;void 0===f?b._d=new Date(a.now()):d(f)?b._d=new Date(+f):"string"==typeof f?na(b):c(f)?(b._a=e(f.slice(0),function(a){return parseInt(a,10)}),za(b)):"object"==typeof f?Ea(b):"number"==typeof f?b._d=new Date(f):a.createFromInputFallback(b)}function Ia(a,b,c,d,e){var f={};return"boolean"==typeof c&&(d=c,c=void 0),f._isAMomentObject=!0,f._useUTC=f._isUTC=e,f._l=c,f._i=a,f._f=b,f._strict=d,Fa(f)}function Ja(a,b,c,d){return Ia(a,b,c,d,!1)}function Ka(a,b){var d,e;if(1===b.length&&c(b[0])&&(b=b[0]),!b.length)return Ja();for(d=b[0],e=1;e<b.length;++e)(!b[e].isValid()||b[e][a](d))&&(d=b[e]);return d}function La(){var a=[].slice.call(arguments,0);return Ka("isBefore",a)}function Ma(){var a=[].slice.call(arguments,0);return Ka("isAfter",a)}function Na(a){var b=L(a),c=b.year||0,d=b.quarter||0,e=b.month||0,f=b.week||0,g=b.day||0,h=b.hour||0,i=b.minute||0,j=b.second||0,k=b.millisecond||0;this._milliseconds=+k+1e3*j+6e4*i+36e5*h,this._days=+g+7*f,this._months=+e+3*d+12*c,this._data={},this._locale=H(),this._bubble()}function Oa(a){return a instanceof Na}function Pa(a,b){R(a,0,0,function(){var a=this.utcOffset(),c="+";return 0>a&&(a=-a,c="-"),c+Q(~~(a/60),2)+b+Q(~~a%60,2)})}function Qa(a,b){var c=(b||"").match(a)||[],d=c[c.length-1]||[],e=(d+"").match(Zd)||["-",0,0],f=+(60*e[1])+r(e[2]);return"+"===e[0]?f:-f}function Ra(b,c){var e,f;return c._isUTC?(e=c.clone(),f=(p(b)||d(b)?+b:+Ja(b))-+e,e._d.setTime(+e._d+f),a.updateOffset(e,!1),e):Ja(b).local()}function Sa(a){return 15*-Math.round(a._d.getTimezoneOffset()/15)}function Ta(b,c){var d,e=this._offset||0;return this.isValid()?null!=b?("string"==typeof b?b=Qa(wd,b):Math.abs(b)<16&&(b=60*b),!this._isUTC&&c&&(d=Sa(this)),this._offset=b,this._isUTC=!0,null!=d&&this.add(d,"m"),e!==b&&(!c||this._changeInProgress?ib(this,cb(b-e,"m"),1,!1):this._changeInProgress||(this._changeInProgress=!0,a.updateOffset(this,!0),this._changeInProgress=null)),this):this._isUTC?e:Sa(this):null!=b?this:NaN}function Ua(a,b){return null!=a?("string"!=typeof a&&(a=-a),this.utcOffset(a,b),this):-this.utcOffset()}function Va(a){return this.utcOffset(0,a)}function Wa(a){return this._isUTC&&(this.utcOffset(0,a),this._isUTC=!1,a&&this.subtract(Sa(this),"m")),this}function Xa(){return this._tzm?this.utcOffset(this._tzm):"string"==typeof this._i&&this.utcOffset(Qa(vd,this._i)),this}function Ya(a){return this.isValid()?(a=a?Ja(a).utcOffset():0,(this.utcOffset()-a)%60===0):!1}function Za(){return this.utcOffset()>this.clone().month(0).utcOffset()||this.utcOffset()>this.clone().month(5).utcOffset()}function $a(){if(!m(this._isDSTShifted))return this._isDSTShifted;var a={};if(n(a,this),a=Ga(a),a._a){var b=a._isUTC?h(a._a):Ja(a._a);this._isDSTShifted=this.isValid()&&s(a._a,b.toArray())>0}else this._isDSTShifted=!1;return this._isDSTShifted}function _a(){return this.isValid()?!this._isUTC:!1}function ab(){return this.isValid()?this._isUTC:!1}function bb(){return this.isValid()?this._isUTC&&0===this._offset:!1}function cb(a,b){var c,d,e,g=a,h=null;return Oa(a)?g={ms:a._milliseconds,d:a._days,M:a._months}:"number"==typeof a?(g={},b?g[b]=a:g.milliseconds=a):(h=$d.exec(a))?(c="-"===h[1]?-1:1,g={y:0,d:r(h[Dd])*c,h:r(h[Ed])*c,m:r(h[Fd])*c,s:r(h[Gd])*c,ms:r(h[Hd])*c}):(h=_d.exec(a))?(c="-"===h[1]?-1:1,g={y:db(h[2],c),M:db(h[3],c),w:db(h[4],c),d:db(h[5],c),h:db(h[6],c),m:db(h[7],c),s:db(h[8],c)}):null==g?g={}:"object"==typeof g&&("from"in g||"to"in g)&&(e=fb(Ja(g.from),Ja(g.to)),g={},g.ms=e.milliseconds,g.M=e.months),d=new Na(g),Oa(a)&&f(a,"_locale")&&(d._locale=a._locale),d}function db(a,b){var c=a&&parseFloat(a.replace(",","."));return(isNaN(c)?0:c)*b}function eb(a,b){var c={milliseconds:0,months:0};return c.months=b.month()-a.month()+12*(b.year()-a.year()),a.clone().add(c.months,"M").isAfter(b)&&--c.months,c.milliseconds=+b-+a.clone().add(c.months,"M"),c}function fb(a,b){var c;return a.isValid()&&b.isValid()?(b=Ra(b,a),a.isBefore(b)?c=eb(a,b):(c=eb(b,a),c.milliseconds=-c.milliseconds,c.months=-c.months),c):{milliseconds:0,months:0}}function gb(a){return 0>a?-1*Math.round(-1*a):Math.round(a)}function hb(a,b){return function(c,d){var e,f;return null===d||isNaN(+d)||(v(b,"moment()."+b+"(period, number) is deprecated. Please use moment()."+b+"(number, period)."),f=c,c=d,d=f),c="string"==typeof c?+c:c,e=cb(c,d),ib(this,e,a),this}}function ib(b,c,d,e){var f=c._milliseconds,g=gb(c._days),h=gb(c._months);b.isValid()&&(e=null==e?!0:e,f&&b._d.setTime(+b._d+f*d),g&&O(b,"Date",N(b,"Date")+g*d),h&&fa(b,N(b,"Month")+h*d),e&&a.updateOffset(b,g||h))}function jb(a,b){var c=a||Ja(),d=Ra(c,this).startOf("day"),e=this.diff(d,"days",!0),f=-6>e?"sameElse":-1>e?"lastWeek":0>e?"lastDay":1>e?"sameDay":2>e?"nextDay":7>e?"nextWeek":"sameElse",g=b&&(w(b[f])?b[f]():b[f]);return this.format(g||this.localeData().calendar(f,this,Ja(c)))}function kb(){return new o(this)}function lb(a,b){var c=p(a)?a:Ja(a);return this.isValid()&&c.isValid()?(b=K(m(b)?"millisecond":b),"millisecond"===b?+this>+c:+c<+this.clone().startOf(b)):!1}function mb(a,b){var c=p(a)?a:Ja(a);return this.isValid()&&c.isValid()?(b=K(m(b)?"millisecond":b),"millisecond"===b?+c>+this:+this.clone().endOf(b)<+c):!1}function nb(a,b,c){return this.isAfter(a,c)&&this.isBefore(b,c)}function ob(a,b){var c,d=p(a)?a:Ja(a);return this.isValid()&&d.isValid()?(b=K(b||"millisecond"),"millisecond"===b?+this===+d:(c=+d,+this.clone().startOf(b)<=c&&c<=+this.clone().endOf(b))):!1}function pb(a,b){return this.isSame(a,b)||this.isAfter(a,b)}function qb(a,b){return this.isSame(a,b)||this.isBefore(a,b)}function rb(a,b,c){var d,e,f,g;return this.isValid()?(d=Ra(a,this),d.isValid()?(e=6e4*(d.utcOffset()-this.utcOffset()),b=K(b),"year"===b||"month"===b||"quarter"===b?(g=sb(this,d),"quarter"===b?g/=3:"year"===b&&(g/=12)):(f=this-d,g="second"===b?f/1e3:"minute"===b?f/6e4:"hour"===b?f/36e5:"day"===b?(f-e)/864e5:"week"===b?(f-e)/6048e5:f),c?g:q(g)):NaN):NaN}function sb(a,b){var c,d,e=12*(b.year()-a.year())+(b.month()-a.month()),f=a.clone().add(e,"months");return 0>b-f?(c=a.clone().add(e-1,"months"),d=(b-f)/(f-c)):(c=a.clone().add(e+1,"months"),d=(b-f)/(c-f)),-(e+d)}function tb(){return this.clone().locale("en").format("ddd MMM DD YYYY HH:mm:ss [GMT]ZZ")}function ub(){var a=this.clone().utc();return 0<a.year()&&a.year()<=9999?w(Date.prototype.toISOString)?this.toDate().toISOString():U(a,"YYYY-MM-DD[T]HH:mm:ss.SSS[Z]"):U(a,"YYYYYY-MM-DD[T]HH:mm:ss.SSS[Z]")}function vb(b){var c=U(this,b||a.defaultFormat);return this.localeData().postformat(c)}function wb(a,b){return this.isValid()&&(p(a)&&a.isValid()||Ja(a).isValid())?cb({to:this,from:a}).locale(this.locale()).humanize(!b):this.localeData().invalidDate()}function xb(a){return this.from(Ja(),a)}function yb(a,b){return this.isValid()&&(p(a)&&a.isValid()||Ja(a).isValid())?cb({from:this,to:a}).locale(this.locale()).humanize(!b):this.localeData().invalidDate()}function zb(a){return this.to(Ja(),a)}function Ab(a){var b;return void 0===a?this._locale._abbr:(b=H(a),null!=b&&(this._locale=b),this)}function Bb(){return this._locale}function Cb(a){switch(a=K(a)){case"year":this.month(0);case"quarter":case"month":this.date(1);case"week":case"isoWeek":case"day":this.hours(0);case"hour":this.minutes(0);case"minute":this.seconds(0);case"second":this.milliseconds(0)}return"week"===a&&this.weekday(0),"isoWeek"===a&&this.isoWeekday(1),"quarter"===a&&this.month(3*Math.floor(this.month()/3)),this}function Db(a){return a=K(a),void 0===a||"millisecond"===a?this:this.startOf(a).add(1,"isoWeek"===a?"week":a).subtract(1,"ms")}function Eb(){return+this._d-6e4*(this._offset||0)}function Fb(){return Math.floor(+this/1e3)}function Gb(){return this._offset?new Date(+this):this._d}function Hb(){var a=this;return[a.year(),a.month(),a.date(),a.hour(),a.minute(),a.second(),a.millisecond()]}function Ib(){var a=this;return{years:a.year(),months:a.month(),date:a.date(),hours:a.hours(),minutes:a.minutes(),seconds:a.seconds(),milliseconds:a.milliseconds()}}function Jb(){return this.isValid()?this.toISOString():null}function Kb(){return k(this)}function Lb(){return g({},j(this))}function Mb(){return j(this).overflow}function Nb(){return{input:this._i,format:this._f,locale:this._locale,isUTC:this._isUTC,strict:this._strict}}function Ob(a,b){R(0,[a,a.length],0,b)}function Pb(a){return Tb.call(this,a,this.week(),this.weekday(),this.localeData()._week.dow,this.localeData()._week.doy)}function Qb(a){return Tb.call(this,a,this.isoWeek(),this.isoWeekday(),1,4)}function Rb(){return wa(this.year(),1,4)}function Sb(){var a=this.localeData()._week;return wa(this.year(),a.dow,a.doy)}function Tb(a,b,c,d,e){var f;return null==a?va(this,d,e).year:(f=wa(a,d,e),b>f&&(b=f),Ub.call(this,a,b,c,d,e))}function Ub(a,b,c,d,e){var f=ua(a,b,c,d,e),g=pa(f.year,0,f.dayOfYear);return this.year(g.getUTCFullYear()),this.month(g.getUTCMonth()),this.date(g.getUTCDate()),this}function Vb(a){return null==a?Math.ceil((this.month()+1)/3):this.month(3*(a-1)+this.month()%3)}function Wb(a){return va(a,this._week.dow,this._week.doy).week}function Xb(){return this._week.dow}function Yb(){return this._week.doy}function Zb(a){var b=this.localeData().week(this);return null==a?b:this.add(7*(a-b),"d")}function $b(a){var b=va(this,1,4).week;return null==a?b:this.add(7*(a-b),"d")}function _b(a,b){return"string"!=typeof a?a:isNaN(a)?(a=b.weekdaysParse(a),"number"==typeof a?a:null):parseInt(a,10)}function ac(a,b){return c(this._weekdays)?this._weekdays[a.day()]:this._weekdays[this._weekdays.isFormat.test(b)?"format":"standalone"][a.day()]}function bc(a){return this._weekdaysShort[a.day()]}function cc(a){return this._weekdaysMin[a.day()]}function dc(a,b,c){var d,e,f;for(this._weekdaysParse||(this._weekdaysParse=[],this._minWeekdaysParse=[],this._shortWeekdaysParse=[],this._fullWeekdaysParse=[]),d=0;7>d;d++){if(e=Ja([2e3,1]).day(d),c&&!this._fullWeekdaysParse[d]&&(this._fullWeekdaysParse[d]=new RegExp("^"+this.weekdays(e,"").replace(".",".?")+"$","i"),this._shortWeekdaysParse[d]=new RegExp("^"+this.weekdaysShort(e,"").replace(".",".?")+"$","i"),this._minWeekdaysParse[d]=new RegExp("^"+this.weekdaysMin(e,"").replace(".",".?")+"$","i")),this._weekdaysParse[d]||(f="^"+this.weekdays(e,"")+"|^"+this.weekdaysShort(e,"")+"|^"+this.weekdaysMin(e,""),this._weekdaysParse[d]=new RegExp(f.replace(".",""),"i")),c&&"dddd"===b&&this._fullWeekdaysParse[d].test(a))return d;if(c&&"ddd"===b&&this._shortWeekdaysParse[d].test(a))return d;if(c&&"dd"===b&&this._minWeekdaysParse[d].test(a))return d;if(!c&&this._weekdaysParse[d].test(a))return d}}function ec(a){if(!this.isValid())return null!=a?this:NaN;var b=this._isUTC?this._d.getUTCDay():this._d.getDay();return null!=a?(a=_b(a,this.localeData()),this.add(a-b,"d")):b}function fc(a){if(!this.isValid())return null!=a?this:NaN;var b=(this.day()+7-this.localeData()._week.dow)%7;return null==a?b:this.add(a-b,"d")}function gc(a){return this.isValid()?null==a?this.day()||7:this.day(this.day()%7?a:a-7):null!=a?this:NaN}function hc(a){var b=Math.round((this.clone().startOf("day")-this.clone().startOf("year"))/864e5)+1;return null==a?b:this.add(a-b,"d")}function ic(){return this.hours()%12||12}function jc(a,b){R(a,0,0,function(){return this.localeData().meridiem(this.hours(),this.minutes(),b)})}function kc(a,b){return b._meridiemParse}function lc(a){return"p"===(a+"").toLowerCase().charAt(0)}function mc(a,b,c){return a>11?c?"pm":"PM":c?"am":"AM"}function nc(a,b){b[Hd]=r(1e3*("0."+a))}function oc(){return this._isUTC?"UTC":""}function pc(){return this._isUTC?"Coordinated Universal Time":""}function qc(a){return Ja(1e3*a)}function rc(){return Ja.apply(null,arguments).parseZone()}function sc(a,b,c){var d=this._calendar[a];return w(d)?d.call(b,c):d}function tc(a){var b=this._longDateFormat[a],c=this._longDateFormat[a.toUpperCase()];return b||!c?b:(this._longDateFormat[a]=c.replace(/MMMM|MM|DD|dddd/g,function(a){return a.slice(1)}),this._longDateFormat[a])}function uc(){return this._invalidDate}function vc(a){return this._ordinal.replace("%d",a)}function wc(a){return a}function xc(a,b,c,d){var e=this._relativeTime[c];return w(e)?e(a,b,c,d):e.replace(/%d/i,a)}function yc(a,b){var c=this._relativeTime[a>0?"future":"past"];return w(c)?c(b):c.replace(/%s/i,b)}function zc(a,b,c,d){var e=H(),f=h().set(d,b);return e[c](f,a)}function Ac(a,b,c,d,e){if("number"==typeof a&&(b=a,a=void 0),a=a||"",null!=b)return zc(a,b,c,e);var f,g=[];for(f=0;d>f;f++)g[f]=zc(a,f,c,e);return g}function Bc(a,b){return Ac(a,b,"months",12,"month")}function Cc(a,b){return Ac(a,b,"monthsShort",12,"month")}function Dc(a,b){return Ac(a,b,"weekdays",7,"day")}function Ec(a,b){return Ac(a,b,"weekdaysShort",7,"day")}function Fc(a,b){return Ac(a,b,"weekdaysMin",7,"day")}function Gc(){var a=this._data;return this._milliseconds=xe(this._milliseconds),this._days=xe(this._days),this._months=xe(this._months),a.milliseconds=xe(a.milliseconds),a.seconds=xe(a.seconds),a.minutes=xe(a.minutes),a.hours=xe(a.hours),a.months=xe(a.months),a.years=xe(a.years),this}function Hc(a,b,c,d){var e=cb(b,c);return a._milliseconds+=d*e._milliseconds,a._days+=d*e._days,a._months+=d*e._months,a._bubble()}function Ic(a,b){return Hc(this,a,b,1)}function Jc(a,b){return Hc(this,a,b,-1)}function Kc(a){return 0>a?Math.floor(a):Math.ceil(a)}function Lc(){var a,b,c,d,e,f=this._milliseconds,g=this._days,h=this._months,i=this._data;return f>=0&&g>=0&&h>=0||0>=f&&0>=g&&0>=h||(f+=864e5*Kc(Nc(h)+g),g=0,h=0),i.milliseconds=f%1e3,a=q(f/1e3),i.seconds=a%60,b=q(a/60),i.minutes=b%60,c=q(b/60),i.hours=c%24,g+=q(c/24),e=q(Mc(g)),h+=e,g-=Kc(Nc(e)),d=q(h/12),h%=12,i.days=g,i.months=h,i.years=d,this}function Mc(a){return 4800*a/146097}function Nc(a){return 146097*a/4800}function Oc(a){var b,c,d=this._milliseconds;if(a=K(a),"month"===a||"year"===a)return b=this._days+d/864e5,c=this._months+Mc(b),"month"===a?c:c/12;switch(b=this._days+Math.round(Nc(this._months)),a){case"week":return b/7+d/6048e5;case"day":return b+d/864e5;case"hour":return 24*b+d/36e5;case"minute":return 1440*b+d/6e4;case"second":return 86400*b+d/1e3;case"millisecond":return Math.floor(864e5*b)+d;default:throw new Error("Unknown unit "+a)}}function Pc(){return this._milliseconds+864e5*this._days+this._months%12*2592e6+31536e6*r(this._months/12)}function Qc(a){return function(){return this.as(a)}}function Rc(a){return a=K(a),this[a+"s"]()}function Sc(a){return function(){return this._data[a]}}function Tc(){return q(this.days()/7)}function Uc(a,b,c,d,e){return e.relativeTime(b||1,!!c,a,d)}function Vc(a,b,c){var d=cb(a).abs(),e=Ne(d.as("s")),f=Ne(d.as("m")),g=Ne(d.as("h")),h=Ne(d.as("d")),i=Ne(d.as("M")),j=Ne(d.as("y")),k=e<Oe.s&&["s",e]||1>=f&&["m"]||f<Oe.m&&["mm",f]||1>=g&&["h"]||g<Oe.h&&["hh",g]||1>=h&&["d"]||h<Oe.d&&["dd",h]||1>=i&&["M"]||i<Oe.M&&["MM",i]||1>=j&&["y"]||["yy",j];return k[2]=b,k[3]=+a>0,k[4]=c,Uc.apply(null,k)}function Wc(a,b){return void 0===Oe[a]?!1:void 0===b?Oe[a]:(Oe[a]=b,!0)}function Xc(a){var b=this.localeData(),c=Vc(this,!a,b);return a&&(c=b.pastFuture(+this,c)),b.postformat(c)}function Yc(){var a,b,c,d=Pe(this._milliseconds)/1e3,e=Pe(this._days),f=Pe(this._months);a=q(d/60),b=q(a/60),d%=60,a%=60,c=q(f/12),f%=12;var g=c,h=f,i=e,j=b,k=a,l=d,m=this.asSeconds();return m?(0>m?"-":"")+"P"+(g?g+"Y":"")+(h?h+"M":"")+(i?i+"D":"")+(j||k||l?"T":"")+(j?j+"H":"")+(k?k+"M":"")+(l?l+"S":""):"P0D"}var Zc,$c=a.momentProperties=[],_c=!1,ad={};a.suppressDeprecationWarnings=!1;var bd,cd={},dd={},ed=/(\[[^\[]*\])|(\\)?([Hh]mm(ss)?|Mo|MM?M?M?|Do|DDDo|DD?D?D?|ddd?d?|do?|w[o|w]?|W[o|W]?|Qo?|YYYYYY|YYYYY|YYYY|YY|gg(ggg?)?|GG(GGG?)?|e|E|a|A|hh?|HH?|mm?|ss?|S{1,9}|x|X|zz?|ZZ?|.)/g,fd=/(\[[^\[]*\])|(\\)?(LTS|LT|LL?L?L?|l{1,4})/g,gd={},hd={},id=/\d/,jd=/\d\d/,kd=/\d{3}/,ld=/\d{4}/,md=/[+-]?\d{6}/,nd=/\d\d?/,od=/\d\d\d\d?/,pd=/\d\d\d\d\d\d?/,qd=/\d{1,3}/,rd=/\d{1,4}/,sd=/[+-]?\d{1,6}/,td=/\d+/,ud=/[+-]?\d+/,vd=/Z|[+-]\d\d:?\d\d/gi,wd=/Z|[+-]\d\d(?::?\d\d)?/gi,xd=/[+-]?\d+(\.\d{1,3})?/,yd=/[0-9]*['a-z\u00A0-\u05FF\u0700-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+|[\u0600-\u06FF\/]+(\s*?[\u0600-\u06FF]+){1,2}/i,zd={},Ad={},Bd=0,Cd=1,Dd=2,Ed=3,Fd=4,Gd=5,Hd=6,Id=7,Jd=8;R("M",["MM",2],"Mo",function(){return this.month()+1}),R("MMM",0,0,function(a){return this.localeData().monthsShort(this,a)}),R("MMMM",0,0,function(a){return this.localeData().months(this,a)}),J("month","M"),W("M",nd),W("MM",nd,jd),W("MMM",function(a,b){return b.monthsShortRegex(a)}),W("MMMM",function(a,b){return b.monthsRegex(a)}),$(["M","MM"],function(a,b){b[Cd]=r(a)-1}),$(["MMM","MMMM"],function(a,b,c,d){var e=c._locale.monthsParse(a,d,c._strict);null!=e?b[Cd]=e:j(c).invalidMonth=a});var Kd=/D[oD]?(\[[^\[\]]*\]|\s+)+MMMM?/,Ld="January_February_March_April_May_June_July_August_September_October_November_December".split("_"),Md="Jan_Feb_Mar_Apr_May_Jun_Jul_Aug_Sep_Oct_Nov_Dec".split("_"),Nd=yd,Od=yd,Pd=/^\s*((?:[+-]\d{6}|\d{4})-(?:\d\d-\d\d|W\d\d-\d|W\d\d|\d\d\d|\d\d))(?:(T| )(\d\d(?::\d\d(?::\d\d(?:[.,]\d+)?)?)?)([\+\-]\d\d(?::?\d\d)?|\s*Z)?)?/,Qd=/^\s*((?:[+-]\d{6}|\d{4})(?:\d\d\d\d|W\d\d\d|W\d\d|\d\d\d|\d\d))(?:(T| )(\d\d(?:\d\d(?:\d\d(?:[.,]\d+)?)?)?)([\+\-]\d\d(?::?\d\d)?|\s*Z)?)?/,Rd=/Z|[+-]\d\d(?::?\d\d)?/,Sd=[["YYYYYY-MM-DD",/[+-]\d{6}-\d\d-\d\d/],["YYYY-MM-DD",/\d{4}-\d\d-\d\d/],["GGGG-[W]WW-E",/\d{4}-W\d\d-\d/],["GGGG-[W]WW",/\d{4}-W\d\d/,!1],["YYYY-DDD",/\d{4}-\d{3}/],["YYYY-MM",/\d{4}-\d\d/,!1],["YYYYYYMMDD",/[+-]\d{10}/],["YYYYMMDD",/\d{8}/],["GGGG[W]WWE",/\d{4}W\d{3}/],["GGGG[W]WW",/\d{4}W\d{2}/,!1],["YYYYDDD",/\d{7}/]],Td=[["HH:mm:ss.SSSS",/\d\d:\d\d:\d\d\.\d+/],["HH:mm:ss,SSSS",/\d\d:\d\d:\d\d,\d+/],["HH:mm:ss",/\d\d:\d\d:\d\d/],["HH:mm",/\d\d:\d\d/],["HHmmss.SSSS",/\d\d\d\d\d\d\.\d+/],["HHmmss,SSSS",/\d\d\d\d\d\d,\d+/],["HHmmss",/\d\d\d\d\d\d/],["HHmm",/\d\d\d\d/],["HH",/\d\d/]],Ud=/^\/?Date\((\-?\d+)/i;a.createFromInputFallback=u("moment construction falls back to js Date. This is discouraged and will be removed in upcoming major release. Please refer to https://github.com/moment/moment/issues/1407 for more info.",function(a){a._d=new Date(a._i+(a._useUTC?" UTC":""))}),R("Y",0,0,function(){var a=this.year();return 9999>=a?""+a:"+"+a}),R(0,["YY",2],0,function(){return this.year()%100}),R(0,["YYYY",4],0,"year"),R(0,["YYYYY",5],0,"year"),R(0,["YYYYYY",6,!0],0,"year"),J("year","y"),W("Y",ud),W("YY",nd,jd),W("YYYY",rd,ld),W("YYYYY",sd,md),W("YYYYYY",sd,md),$(["YYYYY","YYYYYY"],Bd),$("YYYY",function(b,c){c[Bd]=2===b.length?a.parseTwoDigitYear(b):r(b);
|
7 |
}),$("YY",function(b,c){c[Bd]=a.parseTwoDigitYear(b)}),$("Y",function(a,b){b[Bd]=parseInt(a,10)}),a.parseTwoDigitYear=function(a){return r(a)+(r(a)>68?1900:2e3)};var Vd=M("FullYear",!1);a.ISO_8601=function(){};var Wd=u("moment().min is deprecated, use moment.max instead. https://github.com/moment/moment/issues/1548",function(){var a=Ja.apply(null,arguments);return this.isValid()&&a.isValid()?this>a?this:a:l()}),Xd=u("moment().max is deprecated, use moment.min instead. https://github.com/moment/moment/issues/1548",function(){var a=Ja.apply(null,arguments);return this.isValid()&&a.isValid()?a>this?this:a:l()}),Yd=function(){return Date.now?Date.now():+new Date};Pa("Z",":"),Pa("ZZ",""),W("Z",wd),W("ZZ",wd),$(["Z","ZZ"],function(a,b,c){c._useUTC=!0,c._tzm=Qa(wd,a)});var Zd=/([\+\-]|\d\d)/gi;a.updateOffset=function(){};var $d=/^(\-)?(?:(\d*)[. ])?(\d+)\:(\d+)(?:\:(\d+)\.?(\d{3})?\d*)?$/,_d=/^(-)?P(?:([0-9,.]*)Y)?(?:([0-9,.]*)M)?(?:([0-9,.]*)W)?(?:([0-9,.]*)D)?(?:T(?:([0-9,.]*)H)?(?:([0-9,.]*)M)?(?:([0-9,.]*)S)?)?$/;cb.fn=Na.prototype;var ae=hb(1,"add"),be=hb(-1,"subtract");a.defaultFormat="YYYY-MM-DDTHH:mm:ssZ";var ce=u("moment().lang() is deprecated. Instead, use moment().localeData() to get the language configuration. Use moment().locale() to change languages.",function(a){return void 0===a?this.localeData():this.locale(a)});R(0,["gg",2],0,function(){return this.weekYear()%100}),R(0,["GG",2],0,function(){return this.isoWeekYear()%100}),Ob("gggg","weekYear"),Ob("ggggg","weekYear"),Ob("GGGG","isoWeekYear"),Ob("GGGGG","isoWeekYear"),J("weekYear","gg"),J("isoWeekYear","GG"),W("G",ud),W("g",ud),W("GG",nd,jd),W("gg",nd,jd),W("GGGG",rd,ld),W("gggg",rd,ld),W("GGGGG",sd,md),W("ggggg",sd,md),_(["gggg","ggggg","GGGG","GGGGG"],function(a,b,c,d){b[d.substr(0,2)]=r(a)}),_(["gg","GG"],function(b,c,d,e){c[e]=a.parseTwoDigitYear(b)}),R("Q",0,"Qo","quarter"),J("quarter","Q"),W("Q",id),$("Q",function(a,b){b[Cd]=3*(r(a)-1)}),R("w",["ww",2],"wo","week"),R("W",["WW",2],"Wo","isoWeek"),J("week","w"),J("isoWeek","W"),W("w",nd),W("ww",nd,jd),W("W",nd),W("WW",nd,jd),_(["w","ww","W","WW"],function(a,b,c,d){b[d.substr(0,1)]=r(a)});var de={dow:0,doy:6};R("D",["DD",2],"Do","date"),J("date","D"),W("D",nd),W("DD",nd,jd),W("Do",function(a,b){return a?b._ordinalParse:b._ordinalParseLenient}),$(["D","DD"],Dd),$("Do",function(a,b){b[Dd]=r(a.match(nd)[0],10)});var ee=M("Date",!0);R("d",0,"do","day"),R("dd",0,0,function(a){return this.localeData().weekdaysMin(this,a)}),R("ddd",0,0,function(a){return this.localeData().weekdaysShort(this,a)}),R("dddd",0,0,function(a){return this.localeData().weekdays(this,a)}),R("e",0,0,"weekday"),R("E",0,0,"isoWeekday"),J("day","d"),J("weekday","e"),J("isoWeekday","E"),W("d",nd),W("e",nd),W("E",nd),W("dd",yd),W("ddd",yd),W("dddd",yd),_(["dd","ddd","dddd"],function(a,b,c,d){var e=c._locale.weekdaysParse(a,d,c._strict);null!=e?b.d=e:j(c).invalidWeekday=a}),_(["d","e","E"],function(a,b,c,d){b[d]=r(a)});var fe="Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"),ge="Sun_Mon_Tue_Wed_Thu_Fri_Sat".split("_"),he="Su_Mo_Tu_We_Th_Fr_Sa".split("_");R("DDD",["DDDD",3],"DDDo","dayOfYear"),J("dayOfYear","DDD"),W("DDD",qd),W("DDDD",kd),$(["DDD","DDDD"],function(a,b,c){c._dayOfYear=r(a)}),R("H",["HH",2],0,"hour"),R("h",["hh",2],0,ic),R("hmm",0,0,function(){return""+ic.apply(this)+Q(this.minutes(),2)}),R("hmmss",0,0,function(){return""+ic.apply(this)+Q(this.minutes(),2)+Q(this.seconds(),2)}),R("Hmm",0,0,function(){return""+this.hours()+Q(this.minutes(),2)}),R("Hmmss",0,0,function(){return""+this.hours()+Q(this.minutes(),2)+Q(this.seconds(),2)}),jc("a",!0),jc("A",!1),J("hour","h"),W("a",kc),W("A",kc),W("H",nd),W("h",nd),W("HH",nd,jd),W("hh",nd,jd),W("hmm",od),W("hmmss",pd),W("Hmm",od),W("Hmmss",pd),$(["H","HH"],Ed),$(["a","A"],function(a,b,c){c._isPm=c._locale.isPM(a),c._meridiem=a}),$(["h","hh"],function(a,b,c){b[Ed]=r(a),j(c).bigHour=!0}),$("hmm",function(a,b,c){var d=a.length-2;b[Ed]=r(a.substr(0,d)),b[Fd]=r(a.substr(d)),j(c).bigHour=!0}),$("hmmss",function(a,b,c){var d=a.length-4,e=a.length-2;b[Ed]=r(a.substr(0,d)),b[Fd]=r(a.substr(d,2)),b[Gd]=r(a.substr(e)),j(c).bigHour=!0}),$("Hmm",function(a,b,c){var d=a.length-2;b[Ed]=r(a.substr(0,d)),b[Fd]=r(a.substr(d))}),$("Hmmss",function(a,b,c){var d=a.length-4,e=a.length-2;b[Ed]=r(a.substr(0,d)),b[Fd]=r(a.substr(d,2)),b[Gd]=r(a.substr(e))});var ie=/[ap]\.?m?\.?/i,je=M("Hours",!0);R("m",["mm",2],0,"minute"),J("minute","m"),W("m",nd),W("mm",nd,jd),$(["m","mm"],Fd);var ke=M("Minutes",!1);R("s",["ss",2],0,"second"),J("second","s"),W("s",nd),W("ss",nd,jd),$(["s","ss"],Gd);var le=M("Seconds",!1);R("S",0,0,function(){return~~(this.millisecond()/100)}),R(0,["SS",2],0,function(){return~~(this.millisecond()/10)}),R(0,["SSS",3],0,"millisecond"),R(0,["SSSS",4],0,function(){return 10*this.millisecond()}),R(0,["SSSSS",5],0,function(){return 100*this.millisecond()}),R(0,["SSSSSS",6],0,function(){return 1e3*this.millisecond()}),R(0,["SSSSSSS",7],0,function(){return 1e4*this.millisecond()}),R(0,["SSSSSSSS",8],0,function(){return 1e5*this.millisecond()}),R(0,["SSSSSSSSS",9],0,function(){return 1e6*this.millisecond()}),J("millisecond","ms"),W("S",qd,id),W("SS",qd,jd),W("SSS",qd,kd);var me;for(me="SSSS";me.length<=9;me+="S")W(me,td);for(me="S";me.length<=9;me+="S")$(me,nc);var ne=M("Milliseconds",!1);R("z",0,0,"zoneAbbr"),R("zz",0,0,"zoneName");var oe=o.prototype;oe.add=ae,oe.calendar=jb,oe.clone=kb,oe.diff=rb,oe.endOf=Db,oe.format=vb,oe.from=wb,oe.fromNow=xb,oe.to=yb,oe.toNow=zb,oe.get=P,oe.invalidAt=Mb,oe.isAfter=lb,oe.isBefore=mb,oe.isBetween=nb,oe.isSame=ob,oe.isSameOrAfter=pb,oe.isSameOrBefore=qb,oe.isValid=Kb,oe.lang=ce,oe.locale=Ab,oe.localeData=Bb,oe.max=Xd,oe.min=Wd,oe.parsingFlags=Lb,oe.set=P,oe.startOf=Cb,oe.subtract=be,oe.toArray=Hb,oe.toObject=Ib,oe.toDate=Gb,oe.toISOString=ub,oe.toJSON=Jb,oe.toString=tb,oe.unix=Fb,oe.valueOf=Eb,oe.creationData=Nb,oe.year=Vd,oe.isLeapYear=sa,oe.weekYear=Pb,oe.isoWeekYear=Qb,oe.quarter=oe.quarters=Vb,oe.month=ga,oe.daysInMonth=ha,oe.week=oe.weeks=Zb,oe.isoWeek=oe.isoWeeks=$b,oe.weeksInYear=Sb,oe.isoWeeksInYear=Rb,oe.date=ee,oe.day=oe.days=ec,oe.weekday=fc,oe.isoWeekday=gc,oe.dayOfYear=hc,oe.hour=oe.hours=je,oe.minute=oe.minutes=ke,oe.second=oe.seconds=le,oe.millisecond=oe.milliseconds=ne,oe.utcOffset=Ta,oe.utc=Va,oe.local=Wa,oe.parseZone=Xa,oe.hasAlignedHourOffset=Ya,oe.isDST=Za,oe.isDSTShifted=$a,oe.isLocal=_a,oe.isUtcOffset=ab,oe.isUtc=bb,oe.isUTC=bb,oe.zoneAbbr=oc,oe.zoneName=pc,oe.dates=u("dates accessor is deprecated. Use date instead.",ee),oe.months=u("months accessor is deprecated. Use month instead",ga),oe.years=u("years accessor is deprecated. Use year instead",Vd),oe.zone=u("moment().zone is deprecated, use moment().utcOffset instead. https://github.com/moment/moment/issues/1779",Ua);var pe=oe,qe={sameDay:"[Today at] LT",nextDay:"[Tomorrow at] LT",nextWeek:"dddd [at] LT",lastDay:"[Yesterday at] LT",lastWeek:"[Last] dddd [at] LT",sameElse:"L"},re={LTS:"h:mm:ss A",LT:"h:mm A",L:"MM/DD/YYYY",LL:"MMMM D, YYYY",LLL:"MMMM D, YYYY h:mm A",LLLL:"dddd, MMMM D, YYYY h:mm A"},se="Invalid date",te="%d",ue=/\d{1,2}/,ve={future:"in %s",past:"%s ago",s:"a few seconds",m:"a minute",mm:"%d minutes",h:"an hour",hh:"%d hours",d:"a day",dd:"%d days",M:"a month",MM:"%d months",y:"a year",yy:"%d years"},we=A.prototype;we._calendar=qe,we.calendar=sc,we._longDateFormat=re,we.longDateFormat=tc,we._invalidDate=se,we.invalidDate=uc,we._ordinal=te,we.ordinal=vc,we._ordinalParse=ue,we.preparse=wc,we.postformat=wc,we._relativeTime=ve,we.relativeTime=xc,we.pastFuture=yc,we.set=y,we.months=ca,we._months=Ld,we.monthsShort=da,we._monthsShort=Md,we.monthsParse=ea,we._monthsRegex=Od,we.monthsRegex=ja,we._monthsShortRegex=Nd,we.monthsShortRegex=ia,we.week=Wb,we._week=de,we.firstDayOfYear=Yb,we.firstDayOfWeek=Xb,we.weekdays=ac,we._weekdays=fe,we.weekdaysMin=cc,we._weekdaysMin=he,we.weekdaysShort=bc,we._weekdaysShort=ge,we.weekdaysParse=dc,we.isPM=lc,we._meridiemParse=ie,we.meridiem=mc,E("en",{ordinalParse:/\d{1,2}(th|st|nd|rd)/,ordinal:function(a){var b=a%10,c=1===r(a%100/10)?"th":1===b?"st":2===b?"nd":3===b?"rd":"th";return a+c}}),a.lang=u("moment.lang is deprecated. Use moment.locale instead.",E),a.langData=u("moment.langData is deprecated. Use moment.localeData instead.",H);var xe=Math.abs,ye=Qc("ms"),ze=Qc("s"),Ae=Qc("m"),Be=Qc("h"),Ce=Qc("d"),De=Qc("w"),Ee=Qc("M"),Fe=Qc("y"),Ge=Sc("milliseconds"),He=Sc("seconds"),Ie=Sc("minutes"),Je=Sc("hours"),Ke=Sc("days"),Le=Sc("months"),Me=Sc("years"),Ne=Math.round,Oe={s:45,m:45,h:22,d:26,M:11},Pe=Math.abs,Qe=Na.prototype;Qe.abs=Gc,Qe.add=Ic,Qe.subtract=Jc,Qe.as=Oc,Qe.asMilliseconds=ye,Qe.asSeconds=ze,Qe.asMinutes=Ae,Qe.asHours=Be,Qe.asDays=Ce,Qe.asWeeks=De,Qe.asMonths=Ee,Qe.asYears=Fe,Qe.valueOf=Pc,Qe._bubble=Lc,Qe.get=Rc,Qe.milliseconds=Ge,Qe.seconds=He,Qe.minutes=Ie,Qe.hours=Je,Qe.days=Ke,Qe.weeks=Tc,Qe.months=Le,Qe.years=Me,Qe.humanize=Xc,Qe.toISOString=Yc,Qe.toString=Yc,Qe.toJSON=Yc,Qe.locale=Ab,Qe.localeData=Bb,Qe.toIsoString=u("toIsoString() is deprecated. Please use toISOString() instead (notice the capitals)",Yc),Qe.lang=ce,R("X",0,0,"unix"),R("x",0,0,"valueOf"),W("x",ud),W("X",xd),$("X",function(a,b,c){c._d=new Date(1e3*parseFloat(a,10))}),$("x",function(a,b,c){c._d=new Date(r(a))}),a.version="2.12.0",b(Ja),a.fn=pe,a.min=La,a.max=Ma,a.now=Yd,a.utc=h,a.unix=qc,a.months=Bc,a.isDate=d,a.locale=E,a.invalid=l,a.duration=cb,a.isMoment=p,a.weekdays=Dc,a.parseZone=rc,a.localeData=H,a.isDuration=Oa,a.monthsShort=Cc,a.weekdaysMin=Fc,a.defineLocale=F,a.updateLocale=G,a.locales=I,a.weekdaysShort=Ec,a.normalizeUnits=K,a.relativeTimeThreshold=Wc,a.prototype=pe;var Re=a;return Re});
|
inc/js/rgbcolor.js
CHANGED
@@ -1,304 +1,304 @@
|
|
1 |
-
/**
|
2 |
-
* A class to parse color values
|
3 |
-
* @author Stoyan Stefanov <sstoo@gmail.com>
|
4 |
-
* @link http://www.phpied.com/rgb-color-parser-in-javascript/
|
5 |
-
* @license Use it if you like it
|
6 |
-
*/
|
7 |
-
|
8 |
-
(function ( global ) {
|
9 |
-
|
10 |
-
function RGBColor(color_string)
|
11 |
-
{
|
12 |
-
this.ok = false;
|
13 |
-
|
14 |
-
// strip any leading #
|
15 |
-
if (color_string.charAt(0) == '#') { // remove # if any
|
16 |
-
color_string = color_string.substr(1,6);
|
17 |
-
}
|
18 |
-
|
19 |
-
color_string = color_string.replace(/ /g,'');
|
20 |
-
color_string = color_string.toLowerCase();
|
21 |
-
|
22 |
-
// before getting into regexps, try simple matches
|
23 |
-
// and overwrite the input
|
24 |
-
var simple_colors = {
|
25 |
-
aliceblue: 'f0f8ff',
|
26 |
-
antiquewhite: 'faebd7',
|
27 |
-
aqua: '00ffff',
|
28 |
-
aquamarine: '7fffd4',
|
29 |
-
azure: 'f0ffff',
|
30 |
-
beige: 'f5f5dc',
|
31 |
-
bisque: 'ffe4c4',
|
32 |
-
black: '000000',
|
33 |
-
blanchedalmond: 'ffebcd',
|
34 |
-
blue: '0000ff',
|
35 |
-
blueviolet: '8a2be2',
|
36 |
-
brown: 'a52a2a',
|
37 |
-
burlywood: 'deb887',
|
38 |
-
cadetblue: '5f9ea0',
|
39 |
-
chartreuse: '7fff00',
|
40 |
-
chocolate: 'd2691e',
|
41 |
-
coral: 'ff7f50',
|
42 |
-
cornflowerblue: '6495ed',
|
43 |
-
cornsilk: 'fff8dc',
|
44 |
-
crimson: 'dc143c',
|
45 |
-
cyan: '00ffff',
|
46 |
-
darkblue: '00008b',
|
47 |
-
darkcyan: '008b8b',
|
48 |
-
darkgoldenrod: 'b8860b',
|
49 |
-
darkgray: 'a9a9a9',
|
50 |
-
darkgreen: '006400',
|
51 |
-
darkkhaki: 'bdb76b',
|
52 |
-
darkmagenta: '8b008b',
|
53 |
-
darkolivegreen: '556b2f',
|
54 |
-
darkorange: 'ff8c00',
|
55 |
-
darkorchid: '9932cc',
|
56 |
-
darkred: '8b0000',
|
57 |
-
darksalmon: 'e9967a',
|
58 |
-
darkseagreen: '8fbc8f',
|
59 |
-
darkslateblue: '483d8b',
|
60 |
-
darkslategray: '2f4f4f',
|
61 |
-
darkturquoise: '00ced1',
|
62 |
-
darkviolet: '9400d3',
|
63 |
-
deeppink: 'ff1493',
|
64 |
-
deepskyblue: '00bfff',
|
65 |
-
dimgray: '696969',
|
66 |
-
dodgerblue: '1e90ff',
|
67 |
-
feldspar: 'd19275',
|
68 |
-
firebrick: 'b22222',
|
69 |
-
floralwhite: 'fffaf0',
|
70 |
-
forestgreen: '228b22',
|
71 |
-
fuchsia: 'ff00ff',
|
72 |
-
gainsboro: 'dcdcdc',
|
73 |
-
ghostwhite: 'f8f8ff',
|
74 |
-
gold: 'ffd700',
|
75 |
-
goldenrod: 'daa520',
|
76 |
-
gray: '808080',
|
77 |
-
green: '008000',
|
78 |
-
greenyellow: 'adff2f',
|
79 |
-
honeydew: 'f0fff0',
|
80 |
-
hotpink: 'ff69b4',
|
81 |
-
indianred : 'cd5c5c',
|
82 |
-
indigo : '4b0082',
|
83 |
-
ivory: 'fffff0',
|
84 |
-
khaki: 'f0e68c',
|
85 |
-
lavender: 'e6e6fa',
|
86 |
-
lavenderblush: 'fff0f5',
|
87 |
-
lawngreen: '7cfc00',
|
88 |
-
lemonchiffon: 'fffacd',
|
89 |
-
lightblue: 'add8e6',
|
90 |
-
lightcoral: 'f08080',
|
91 |
-
lightcyan: 'e0ffff',
|
92 |
-
lightgoldenrodyellow: 'fafad2',
|
93 |
-
lightgrey: 'd3d3d3',
|
94 |
-
lightgreen: '90ee90',
|
95 |
-
lightpink: 'ffb6c1',
|
96 |
-
lightsalmon: 'ffa07a',
|
97 |
-
lightseagreen: '20b2aa',
|
98 |
-
lightskyblue: '87cefa',
|
99 |
-
lightslateblue: '8470ff',
|
100 |
-
lightslategray: '778899',
|
101 |
-
lightsteelblue: 'b0c4de',
|
102 |
-
lightyellow: 'ffffe0',
|
103 |
-
lime: '00ff00',
|
104 |
-
limegreen: '32cd32',
|
105 |
-
linen: 'faf0e6',
|
106 |
-
magenta: 'ff00ff',
|
107 |
-
maroon: '800000',
|
108 |
-
mediumaquamarine: '66cdaa',
|
109 |
-
mediumblue: '0000cd',
|
110 |
-
mediumorchid: 'ba55d3',
|
111 |
-
mediumpurple: '9370d8',
|
112 |
-
mediumseagreen: '3cb371',
|
113 |
-
mediumslateblue: '7b68ee',
|
114 |
-
mediumspringgreen: '00fa9a',
|
115 |
-
mediumturquoise: '48d1cc',
|
116 |
-
mediumvioletred: 'c71585',
|
117 |
-
midnightblue: '191970',
|
118 |
-
mintcream: 'f5fffa',
|
119 |
-
mistyrose: 'ffe4e1',
|
120 |
-
moccasin: 'ffe4b5',
|
121 |
-
navajowhite: 'ffdead',
|
122 |
-
navy: '000080',
|
123 |
-
oldlace: 'fdf5e6',
|
124 |
-
olive: '808000',
|
125 |
-
olivedrab: '6b8e23',
|
126 |
-
orange: 'ffa500',
|
127 |
-
orangered: 'ff4500',
|
128 |
-
orchid: 'da70d6',
|
129 |
-
palegoldenrod: 'eee8aa',
|
130 |
-
palegreen: '98fb98',
|
131 |
-
paleturquoise: 'afeeee',
|
132 |
-
palevioletred: 'd87093',
|
133 |
-
papayawhip: 'ffefd5',
|
134 |
-
peachpuff: 'ffdab9',
|
135 |
-
peru: 'cd853f',
|
136 |
-
pink: 'ffc0cb',
|
137 |
-
plum: 'dda0dd',
|
138 |
-
powderblue: 'b0e0e6',
|
139 |
-
purple: '800080',
|
140 |
-
red: 'ff0000',
|
141 |
-
rosybrown: 'bc8f8f',
|
142 |
-
royalblue: '4169e1',
|
143 |
-
saddlebrown: '8b4513',
|
144 |
-
salmon: 'fa8072',
|
145 |
-
sandybrown: 'f4a460',
|
146 |
-
seagreen: '2e8b57',
|
147 |
-
seashell: 'fff5ee',
|
148 |
-
sienna: 'a0522d',
|
149 |
-
silver: 'c0c0c0',
|
150 |
-
skyblue: '87ceeb',
|
151 |
-
slateblue: '6a5acd',
|
152 |
-
slategray: '708090',
|
153 |
-
snow: 'fffafa',
|
154 |
-
springgreen: '00ff7f',
|
155 |
-
steelblue: '4682b4',
|
156 |
-
tan: 'd2b48c',
|
157 |
-
teal: '008080',
|
158 |
-
thistle: 'd8bfd8',
|
159 |
-
tomato: 'ff6347',
|
160 |
-
turquoise: '40e0d0',
|
161 |
-
violet: 'ee82ee',
|
162 |
-
violetred: 'd02090',
|
163 |
-
wheat: 'f5deb3',
|
164 |
-
white: 'ffffff',
|
165 |
-
whitesmoke: 'f5f5f5',
|
166 |
-
yellow: 'ffff00',
|
167 |
-
yellowgreen: '9acd32'
|
168 |
-
};
|
169 |
-
for (var key in simple_colors) {
|
170 |
-
if (color_string == key) {
|
171 |
-
color_string = simple_colors[key];
|
172 |
-
}
|
173 |
-
}
|
174 |
-
// emd of simple type-in colors
|
175 |
-
|
176 |
-
// array of color definition objects
|
177 |
-
var color_defs = [
|
178 |
-
{
|
179 |
-
re: /^rgb\((\d{1,3}),\s*(\d{1,3}),\s*(\d{1,3})\)$/,
|
180 |
-
example: ['rgb(123, 234, 45)', 'rgb(255,234,245)'],
|
181 |
-
process: function (bits){
|
182 |
-
return [
|
183 |
-
parseInt(bits[1]),
|
184 |
-
parseInt(bits[2]),
|
185 |
-
parseInt(bits[3])
|
186 |
-
];
|
187 |
-
}
|
188 |
-
},
|
189 |
-
{
|
190 |
-
re: /^(\w{2})(\w{2})(\w{2})$/,
|
191 |
-
example: ['#00ff00', '336699'],
|
192 |
-
process: function (bits){
|
193 |
-
return [
|
194 |
-
parseInt(bits[1], 16),
|
195 |
-
parseInt(bits[2], 16),
|
196 |
-
parseInt(bits[3], 16)
|
197 |
-
];
|
198 |
-
}
|
199 |
-
},
|
200 |
-
{
|
201 |
-
re: /^(\w{1})(\w{1})(\w{1})$/,
|
202 |
-
example: ['#fb0', 'f0f'],
|
203 |
-
process: function (bits){
|
204 |
-
return [
|
205 |
-
parseInt(bits[1] + bits[1], 16),
|
206 |
-
parseInt(bits[2] + bits[2], 16),
|
207 |
-
parseInt(bits[3] + bits[3], 16)
|
208 |
-
];
|
209 |
-
}
|
210 |
-
}
|
211 |
-
];
|
212 |
-
|
213 |
-
// search through the definitions to find a match
|
214 |
-
for (var i = 0; i < color_defs.length; i++) {
|
215 |
-
var re = color_defs[i].re;
|
216 |
-
var processor = color_defs[i].process;
|
217 |
-
var bits = re.exec(color_string);
|
218 |
-
if (bits) {
|
219 |
-
channels = processor(bits);
|
220 |
-
this.r = channels[0];
|
221 |
-
this.g = channels[1];
|
222 |
-
this.b = channels[2];
|
223 |
-
this.ok = true;
|
224 |
-
}
|
225 |
-
|
226 |
-
}
|
227 |
-
|
228 |
-
// validate/cleanup values
|
229 |
-
this.r = (this.r < 0 || isNaN(this.r)) ? 0 : ((this.r > 255) ? 255 : this.r);
|
230 |
-
this.g = (this.g < 0 || isNaN(this.g)) ? 0 : ((this.g > 255) ? 255 : this.g);
|
231 |
-
this.b = (this.b < 0 || isNaN(this.b)) ? 0 : ((this.b > 255) ? 255 : this.b);
|
232 |
-
|
233 |
-
// some getters
|
234 |
-
this.toRGB = function () {
|
235 |
-
return 'rgb(' + this.r + ', ' + this.g + ', ' + this.b + ')';
|
236 |
-
}
|
237 |
-
this.toHex = function () {
|
238 |
-
var r = this.r.toString(16);
|
239 |
-
var g = this.g.toString(16);
|
240 |
-
var b = this.b.toString(16);
|
241 |
-
if (r.length == 1) r = '0' + r;
|
242 |
-
if (g.length == 1) g = '0' + g;
|
243 |
-
if (b.length == 1) b = '0' + b;
|
244 |
-
return '#' + r + g + b;
|
245 |
-
}
|
246 |
-
|
247 |
-
// help
|
248 |
-
this.getHelpXML = function () {
|
249 |
-
|
250 |
-
var examples = new Array();
|
251 |
-
// add regexps
|
252 |
-
for (var i = 0; i < color_defs.length; i++) {
|
253 |
-
var example = color_defs[i].example;
|
254 |
-
for (var j = 0; j < example.length; j++) {
|
255 |
-
examples[examples.length] = example[j];
|
256 |
-
}
|
257 |
-
}
|
258 |
-
// add type-in colors
|
259 |
-
for (var sc in simple_colors) {
|
260 |
-
examples[examples.length] = sc;
|
261 |
-
}
|
262 |
-
|
263 |
-
var xml = document.createElement('ul');
|
264 |
-
xml.setAttribute('id', 'rgbcolor-examples');
|
265 |
-
for (var i = 0; i < examples.length; i++) {
|
266 |
-
try {
|
267 |
-
var list_item = document.createElement('li');
|
268 |
-
var list_color = new RGBColor(examples[i]);
|
269 |
-
var example_div = document.createElement('div');
|
270 |
-
example_div.style.cssText =
|
271 |
-
'margin: 3px; '
|
272 |
-
+ 'border: 1px solid black; '
|
273 |
-
+ 'background:' + list_color.toHex() + '; '
|
274 |
-
+ 'color:' + list_color.toHex()
|
275 |
-
;
|
276 |
-
example_div.appendChild(document.createTextNode('test'));
|
277 |
-
var list_item_value = document.createTextNode(
|
278 |
-
' ' + examples[i] + ' -> ' + list_color.toRGB() + ' -> ' + list_color.toHex()
|
279 |
-
);
|
280 |
-
list_item.appendChild(example_div);
|
281 |
-
list_item.appendChild(list_item_value);
|
282 |
-
xml.appendChild(list_item);
|
283 |
-
|
284 |
-
} catch(e){}
|
285 |
-
}
|
286 |
-
return xml;
|
287 |
-
|
288 |
-
}
|
289 |
-
|
290 |
-
}
|
291 |
-
|
292 |
-
// export as AMD...
|
293 |
-
if ( typeof define !== 'undefined' && define.amd ) {
|
294 |
-
define( function () { return RGBColor; });
|
295 |
-
}
|
296 |
-
|
297 |
-
// ...or as browserify
|
298 |
-
else if ( typeof module !== 'undefined' && module.exports ) {
|
299 |
-
module.exports = RGBColor;
|
300 |
-
}
|
301 |
-
|
302 |
-
global.RGBColor = RGBColor;
|
303 |
-
|
304 |
}( typeof window !== 'undefined' ? window : this ));
|
1 |
+
/**
|
2 |
+
* A class to parse color values
|
3 |
+
* @author Stoyan Stefanov <sstoo@gmail.com>
|
4 |
+
* @link http://www.phpied.com/rgb-color-parser-in-javascript/
|
5 |
+
* @license Use it if you like it
|
6 |
+
*/
|
7 |
+
|
8 |
+
(function ( global ) {
|
9 |
+
|
10 |
+
function RGBColor(color_string)
|
11 |
+
{
|
12 |
+
this.ok = false;
|
13 |
+
|
14 |
+
// strip any leading #
|
15 |
+
if (color_string.charAt(0) == '#') { // remove # if any
|
16 |
+
color_string = color_string.substr(1,6);
|
17 |
+
}
|
18 |
+
|
19 |
+
color_string = color_string.replace(/ /g,'');
|
20 |
+
color_string = color_string.toLowerCase();
|
21 |
+
|
22 |
+
// before getting into regexps, try simple matches
|
23 |
+
// and overwrite the input
|
24 |
+
var simple_colors = {
|
25 |
+
aliceblue: 'f0f8ff',
|
26 |
+
antiquewhite: 'faebd7',
|
27 |
+
aqua: '00ffff',
|
28 |
+
aquamarine: '7fffd4',
|
29 |
+
azure: 'f0ffff',
|
30 |
+
beige: 'f5f5dc',
|
31 |
+
bisque: 'ffe4c4',
|
32 |
+
black: '000000',
|
33 |
+
blanchedalmond: 'ffebcd',
|
34 |
+
blue: '0000ff',
|
35 |
+
blueviolet: '8a2be2',
|
36 |
+
brown: 'a52a2a',
|
37 |
+
burlywood: 'deb887',
|
38 |
+
cadetblue: '5f9ea0',
|
39 |
+
chartreuse: '7fff00',
|
40 |
+
chocolate: 'd2691e',
|
41 |
+
coral: 'ff7f50',
|
42 |
+
cornflowerblue: '6495ed',
|
43 |
+
cornsilk: 'fff8dc',
|
44 |
+
crimson: 'dc143c',
|
45 |
+
cyan: '00ffff',
|
46 |
+
darkblue: '00008b',
|
47 |
+
darkcyan: '008b8b',
|
48 |
+
darkgoldenrod: 'b8860b',
|
49 |
+
darkgray: 'a9a9a9',
|
50 |
+
darkgreen: '006400',
|
51 |
+
darkkhaki: 'bdb76b',
|
52 |
+
darkmagenta: '8b008b',
|
53 |
+
darkolivegreen: '556b2f',
|
54 |
+
darkorange: 'ff8c00',
|
55 |
+
darkorchid: '9932cc',
|
56 |
+
darkred: '8b0000',
|
57 |
+
darksalmon: 'e9967a',
|
58 |
+
darkseagreen: '8fbc8f',
|
59 |
+
darkslateblue: '483d8b',
|
60 |
+
darkslategray: '2f4f4f',
|
61 |
+
darkturquoise: '00ced1',
|
62 |
+
darkviolet: '9400d3',
|
63 |
+
deeppink: 'ff1493',
|
64 |
+
deepskyblue: '00bfff',
|
65 |
+
dimgray: '696969',
|
66 |
+
dodgerblue: '1e90ff',
|
67 |
+
feldspar: 'd19275',
|
68 |
+
firebrick: 'b22222',
|
69 |
+
floralwhite: 'fffaf0',
|
70 |
+
forestgreen: '228b22',
|
71 |
+
fuchsia: 'ff00ff',
|
72 |
+
gainsboro: 'dcdcdc',
|
73 |
+
ghostwhite: 'f8f8ff',
|
74 |
+
gold: 'ffd700',
|
75 |
+
goldenrod: 'daa520',
|
76 |
+
gray: '808080',
|
77 |
+
green: '008000',
|
78 |
+
greenyellow: 'adff2f',
|
79 |
+
honeydew: 'f0fff0',
|
80 |
+
hotpink: 'ff69b4',
|
81 |
+
indianred : 'cd5c5c',
|
82 |
+
indigo : '4b0082',
|
83 |
+
ivory: 'fffff0',
|
84 |
+
khaki: 'f0e68c',
|
85 |
+
lavender: 'e6e6fa',
|
86 |
+
lavenderblush: 'fff0f5',
|
87 |
+
lawngreen: '7cfc00',
|
88 |
+
lemonchiffon: 'fffacd',
|
89 |
+
lightblue: 'add8e6',
|
90 |
+
lightcoral: 'f08080',
|
91 |
+
lightcyan: 'e0ffff',
|
92 |
+
lightgoldenrodyellow: 'fafad2',
|
93 |
+
lightgrey: 'd3d3d3',
|
94 |
+
lightgreen: '90ee90',
|
95 |
+
lightpink: 'ffb6c1',
|
96 |
+
lightsalmon: 'ffa07a',
|
97 |
+
lightseagreen: '20b2aa',
|
98 |
+
lightskyblue: '87cefa',
|
99 |
+
lightslateblue: '8470ff',
|
100 |
+
lightslategray: '778899',
|
101 |
+
lightsteelblue: 'b0c4de',
|
102 |
+
lightyellow: 'ffffe0',
|
103 |
+
lime: '00ff00',
|
104 |
+
limegreen: '32cd32',
|
105 |
+
linen: 'faf0e6',
|
106 |
+
magenta: 'ff00ff',
|
107 |
+
maroon: '800000',
|
108 |
+
mediumaquamarine: '66cdaa',
|
109 |
+
mediumblue: '0000cd',
|
110 |
+
mediumorchid: 'ba55d3',
|
111 |
+
mediumpurple: '9370d8',
|
112 |
+
mediumseagreen: '3cb371',
|
113 |
+
mediumslateblue: '7b68ee',
|
114 |
+
mediumspringgreen: '00fa9a',
|
115 |
+
mediumturquoise: '48d1cc',
|
116 |
+
mediumvioletred: 'c71585',
|
117 |
+
midnightblue: '191970',
|
118 |
+
mintcream: 'f5fffa',
|
119 |
+
mistyrose: 'ffe4e1',
|
120 |
+
moccasin: 'ffe4b5',
|
121 |
+
navajowhite: 'ffdead',
|
122 |
+
navy: '000080',
|
123 |
+
oldlace: 'fdf5e6',
|
124 |
+
olive: '808000',
|
125 |
+
olivedrab: '6b8e23',
|
126 |
+
orange: 'ffa500',
|
127 |
+
orangered: 'ff4500',
|
128 |
+
orchid: 'da70d6',
|
129 |
+
palegoldenrod: 'eee8aa',
|
130 |
+
palegreen: '98fb98',
|
131 |
+
paleturquoise: 'afeeee',
|
132 |
+
palevioletred: 'd87093',
|
133 |
+
papayawhip: 'ffefd5',
|
134 |
+
peachpuff: 'ffdab9',
|
135 |
+
peru: 'cd853f',
|
136 |
+
pink: 'ffc0cb',
|
137 |
+
plum: 'dda0dd',
|
138 |
+
powderblue: 'b0e0e6',
|
139 |
+
purple: '800080',
|
140 |
+
red: 'ff0000',
|
141 |
+
rosybrown: 'bc8f8f',
|
142 |
+
royalblue: '4169e1',
|
143 |
+
saddlebrown: '8b4513',
|
144 |
+
salmon: 'fa8072',
|
145 |
+
sandybrown: 'f4a460',
|
146 |
+
seagreen: '2e8b57',
|
147 |
+
seashell: 'fff5ee',
|
148 |
+
sienna: 'a0522d',
|
149 |
+
silver: 'c0c0c0',
|
150 |
+
skyblue: '87ceeb',
|
151 |
+
slateblue: '6a5acd',
|
152 |
+
slategray: '708090',
|
153 |
+
snow: 'fffafa',
|
154 |
+
springgreen: '00ff7f',
|
155 |
+
steelblue: '4682b4',
|
156 |
+
tan: 'd2b48c',
|
157 |
+
teal: '008080',
|
158 |
+
thistle: 'd8bfd8',
|
159 |
+
tomato: 'ff6347',
|
160 |
+
turquoise: '40e0d0',
|
161 |
+
violet: 'ee82ee',
|
162 |
+
violetred: 'd02090',
|
163 |
+
wheat: 'f5deb3',
|
164 |
+
white: 'ffffff',
|
165 |
+
whitesmoke: 'f5f5f5',
|
166 |
+
yellow: 'ffff00',
|
167 |
+
yellowgreen: '9acd32'
|
168 |
+
};
|
169 |
+
for (var key in simple_colors) {
|
170 |
+
if (color_string == key) {
|
171 |
+
color_string = simple_colors[key];
|
172 |
+
}
|
173 |
+
}
|
174 |
+
// emd of simple type-in colors
|
175 |
+
|
176 |
+
// array of color definition objects
|
177 |
+
var color_defs = [
|
178 |
+
{
|
179 |
+
re: /^rgb\((\d{1,3}),\s*(\d{1,3}),\s*(\d{1,3})\)$/,
|
180 |
+
example: ['rgb(123, 234, 45)', 'rgb(255,234,245)'],
|
181 |
+
process: function (bits){
|
182 |
+
return [
|
183 |
+
parseInt(bits[1]),
|
184 |
+
parseInt(bits[2]),
|
185 |
+
parseInt(bits[3])
|
186 |
+
];
|
187 |
+
}
|
188 |
+
},
|
189 |
+
{
|
190 |
+
re: /^(\w{2})(\w{2})(\w{2})$/,
|
191 |
+
example: ['#00ff00', '336699'],
|
192 |
+
process: function (bits){
|
193 |
+
return [
|
194 |
+
parseInt(bits[1], 16),
|
195 |
+
parseInt(bits[2], 16),
|
196 |
+
parseInt(bits[3], 16)
|
197 |
+
];
|
198 |
+
}
|
199 |
+
},
|
200 |
+
{
|
201 |
+
re: /^(\w{1})(\w{1})(\w{1})$/,
|
202 |
+
example: ['#fb0', 'f0f'],
|
203 |
+
process: function (bits){
|
204 |
+
return [
|
205 |
+
parseInt(bits[1] + bits[1], 16),
|
206 |
+
parseInt(bits[2] + bits[2], 16),
|
207 |
+
parseInt(bits[3] + bits[3], 16)
|
208 |
+
];
|
209 |
+
}
|
210 |
+
}
|
211 |
+
];
|
212 |
+
|
213 |
+
// search through the definitions to find a match
|
214 |
+
for (var i = 0; i < color_defs.length; i++) {
|
215 |
+
var re = color_defs[i].re;
|
216 |
+
var processor = color_defs[i].process;
|
217 |
+
var bits = re.exec(color_string);
|
218 |
+
if (bits) {
|
219 |
+
channels = processor(bits);
|
220 |
+
this.r = channels[0];
|
221 |
+
this.g = channels[1];
|
222 |
+
this.b = channels[2];
|
223 |
+
this.ok = true;
|
224 |
+
}
|
225 |
+
|
226 |
+
}
|
227 |
+
|
228 |
+
// validate/cleanup values
|
229 |
+
this.r = (this.r < 0 || isNaN(this.r)) ? 0 : ((this.r > 255) ? 255 : this.r);
|
230 |
+
this.g = (this.g < 0 || isNaN(this.g)) ? 0 : ((this.g > 255) ? 255 : this.g);
|
231 |
+
this.b = (this.b < 0 || isNaN(this.b)) ? 0 : ((this.b > 255) ? 255 : this.b);
|
232 |
+
|
233 |
+
// some getters
|
234 |
+
this.toRGB = function () {
|
235 |
+
return 'rgb(' + this.r + ', ' + this.g + ', ' + this.b + ')';
|
236 |
+
}
|
237 |
+
this.toHex = function () {
|
238 |
+
var r = this.r.toString(16);
|
239 |
+
var g = this.g.toString(16);
|
240 |
+
var b = this.b.toString(16);
|
241 |
+
if (r.length == 1) r = '0' + r;
|
242 |
+
if (g.length == 1) g = '0' + g;
|
243 |
+
if (b.length == 1) b = '0' + b;
|
244 |
+
return '#' + r + g + b;
|
245 |
+
}
|
246 |
+
|
247 |
+
// help
|
248 |
+
this.getHelpXML = function () {
|
249 |
+
|
250 |
+
var examples = new Array();
|
251 |
+
// add regexps
|
252 |
+
for (var i = 0; i < color_defs.length; i++) {
|
253 |
+
var example = color_defs[i].example;
|
254 |
+
for (var j = 0; j < example.length; j++) {
|
255 |
+
examples[examples.length] = example[j];
|
256 |
+
}
|
257 |
+
}
|
258 |
+
// add type-in colors
|
259 |
+
for (var sc in simple_colors) {
|
260 |
+
examples[examples.length] = sc;
|
261 |
+
}
|
262 |
+
|
263 |
+
var xml = document.createElement('ul');
|
264 |
+
xml.setAttribute('id', 'rgbcolor-examples');
|
265 |
+
for (var i = 0; i < examples.length; i++) {
|
266 |
+
try {
|
267 |
+
var list_item = document.createElement('li');
|
268 |
+
var list_color = new RGBColor(examples[i]);
|
269 |
+
var example_div = document.createElement('div');
|
270 |
+
example_div.style.cssText =
|
271 |
+
'margin: 3px; '
|
272 |
+
+ 'border: 1px solid black; '
|
273 |
+
+ 'background:' + list_color.toHex() + '; '
|
274 |
+
+ 'color:' + list_color.toHex()
|
275 |
+
;
|
276 |
+
example_div.appendChild(document.createTextNode('test'));
|
277 |
+
var list_item_value = document.createTextNode(
|
278 |
+
' ' + examples[i] + ' -> ' + list_color.toRGB() + ' -> ' + list_color.toHex()
|
279 |
+
);
|
280 |
+
list_item.appendChild(example_div);
|
281 |
+
list_item.appendChild(list_item_value);
|
282 |
+
xml.appendChild(list_item);
|
283 |
+
|
284 |
+
} catch(e){}
|
285 |
+
}
|
286 |
+
return xml;
|
287 |
+
|
288 |
+
}
|
289 |
+
|
290 |
+
}
|
291 |
+
|
292 |
+
// export as AMD...
|
293 |
+
if ( typeof define !== 'undefined' && define.amd ) {
|
294 |
+
define( function () { return RGBColor; });
|
295 |
+
}
|
296 |
+
|
297 |
+
// ...or as browserify
|
298 |
+
else if ( typeof module !== 'undefined' && module.exports ) {
|
299 |
+
module.exports = RGBColor;
|
300 |
+
}
|
301 |
+
|
302 |
+
global.RGBColor = RGBColor;
|
303 |
+
|
304 |
}( typeof window !== 'undefined' ? window : this ));
|
include/gawd_csv_file.php
CHANGED
@@ -432,7 +432,7 @@ class GAWD_CSV_FILE extends GAWD_FILE {
|
|
432 |
private function get_columns() {
|
433 |
$dimension = isset($_REQUEST["dimension"]) ? sanitize_text_field($_REQUEST["dimension"]) : 'Date';
|
434 |
$columns = array($this->column_names);
|
435 |
-
$_REQUEST['gawd_dimension'] = isset($_REQUEST['gawd_dimension']) ? $_REQUEST['gawd_dimension'] : $dimension;
|
436 |
if($_REQUEST['gawd_dimension'] == "Session Duration Bucket"){
|
437 |
$_data = array();
|
438 |
//$j = 1;
|
@@ -498,7 +498,7 @@ class GAWD_CSV_FILE extends GAWD_FILE {
|
|
498 |
$val = $val;
|
499 |
}
|
500 |
else{
|
501 |
-
if($cols != preg_replace('!\s+!',' ',trim(ucfirst(preg_replace('/([A-Z])/', ' $1', $_REQUEST['gawd_dimension']))))){
|
502 |
$percentage_of_total = isset($this->data_sum[$cols]) ? $this->data_sum[$cols] != '0' ? floatval($val)/$this->data_sum[$cols]*100 : 0 : '';
|
503 |
if($percentage_of_total != ''){
|
504 |
$percentage_of_total = number_format(floatval($percentage_of_total),2, '.', ',');
|
@@ -516,7 +516,7 @@ class GAWD_CSV_FILE extends GAWD_FILE {
|
|
516 |
$row = array();
|
517 |
foreach ($this->column_names as $cols) {
|
518 |
$cols = preg_replace('!\s+!',' ',trim(ucfirst(preg_replace('/([A-Z])/', ' $1', $cols))));
|
519 |
-
if($cols == 'No' || $cols == $dimension || $cols == preg_replace('!\s+!',' ',trim(ucfirst(preg_replace('/([A-Z])/', ' $1', $_REQUEST['gawd_dimension']))))){
|
520 |
$row[] = ' ';
|
521 |
}
|
522 |
else{
|
432 |
private function get_columns() {
|
433 |
$dimension = isset($_REQUEST["dimension"]) ? sanitize_text_field($_REQUEST["dimension"]) : 'Date';
|
434 |
$columns = array($this->column_names);
|
435 |
+
$_REQUEST['gawd_dimension'] = isset($_REQUEST['gawd_dimension']) ? sanitize_text_field($_REQUEST['gawd_dimension']) : $dimension;
|
436 |
if($_REQUEST['gawd_dimension'] == "Session Duration Bucket"){
|
437 |
$_data = array();
|
438 |
//$j = 1;
|
498 |
$val = $val;
|
499 |
}
|
500 |
else{
|
501 |
+
if($cols != preg_replace('!\s+!',' ',trim(ucfirst(preg_replace('/([A-Z])/', ' $1', sanitize_text_field($_REQUEST['gawd_dimension'])))))){
|
502 |
$percentage_of_total = isset($this->data_sum[$cols]) ? $this->data_sum[$cols] != '0' ? floatval($val)/$this->data_sum[$cols]*100 : 0 : '';
|
503 |
if($percentage_of_total != ''){
|
504 |
$percentage_of_total = number_format(floatval($percentage_of_total),2, '.', ',');
|
516 |
$row = array();
|
517 |
foreach ($this->column_names as $cols) {
|
518 |
$cols = preg_replace('!\s+!',' ',trim(ucfirst(preg_replace('/([A-Z])/', ' $1', $cols))));
|
519 |
+
if($cols == 'No' || $cols == $dimension || $cols == preg_replace('!\s+!',' ',trim(ucfirst(preg_replace('/([A-Z])/', ' $1', sanitize_text_field($_REQUEST['gawd_dimension'])))))){
|
520 |
$row[] = ' ';
|
521 |
}
|
522 |
else{
|
include/gawd_file.php
CHANGED
@@ -76,9 +76,9 @@ abstract class GAWD_FILE {
|
|
76 |
public function get_request_data($obj,$ajax = true, $email_data = null, $dimension_recc = null, $start_date = null, $end_date = null, $metric_compare_recc = null, $metric_recc = null) {
|
77 |
$gawd_user_data = get_option('gawd_user_data');
|
78 |
$this->site_title = $gawd_user_data['web_property_name'];
|
79 |
-
$this->img = isset($_REQUEST["img"]) && $_REQUEST["img"] != '' ? $_REQUEST["img"] : '';
|
80 |
-
$this->start_date = isset($_REQUEST["gawd_start_date"]) && $_REQUEST["gawd_start_date"] != '' ? $_REQUEST["gawd_start_date"] : date('Y-m-d', strtotime('-7 days'));
|
81 |
-
$this->end_date = isset($_REQUEST["gawd_end_date"]) && $_REQUEST["gawd_end_date"] != '' ? $_REQUEST["gawd_end_date"] : date('Y-m-d', strtotime('-1 days'));
|
82 |
if(isset($_REQUEST["gawd_metric"])){
|
83 |
$metric = sanitize_text_field($_REQUEST["gawd_metric"]);
|
84 |
}
|
@@ -92,7 +92,7 @@ abstract class GAWD_FILE {
|
|
92 |
}
|
93 |
$this->set_metric($metric);
|
94 |
$this->country_filter = isset($_REQUEST["country_filter"]) ? sanitize_text_field($_REQUEST["country_filter"]) : '';
|
95 |
-
$this->custom = isset( $_REQUEST["custom"] ) && $_REQUEST["custom"] != '' ? $_REQUEST["custom"] : '';
|
96 |
|
97 |
$this->geo_type = isset($_REQUEST["geo_type"]) ? sanitize_text_field($_REQUEST["geo_type"]) : '';
|
98 |
if(isset($_REQUEST["gawd_metric_compare"])){
|
@@ -118,7 +118,7 @@ abstract class GAWD_FILE {
|
|
118 |
$this->second_end_date = isset($_REQUEST["second_end_date"]) ? sanitize_text_field($_REQUEST["second_end_date"]) : '';
|
119 |
/////END COMPARED PAGES VARIABLES////
|
120 |
|
121 |
-
$this->_data_compare = isset($_REQUEST["_data_compare"]) ? ($_REQUEST["_data_compare"]) : '';
|
122 |
|
123 |
if(isset($_REQUEST["gawd_dimension"]) && $dimension_recc == null){
|
124 |
$dimension = sanitize_text_field($_REQUEST["gawd_dimension"]);
|
@@ -144,7 +144,7 @@ abstract class GAWD_FILE {
|
|
144 |
if($this->tab_name == 'goals'){
|
145 |
$dimension_arg = $this->tab_name;
|
146 |
}
|
147 |
-
$this->filter_type = isset($_REQUEST["filter_type"]) &&
|
148 |
$this->set_colum_names($dimension);
|
149 |
$this->dimension = ($this->filter_type != 'Date') ? $this->filter_type : $dimension;
|
150 |
if(strpos($this->dimension,'dimension') >-1){
|
76 |
public function get_request_data($obj,$ajax = true, $email_data = null, $dimension_recc = null, $start_date = null, $end_date = null, $metric_compare_recc = null, $metric_recc = null) {
|
77 |
$gawd_user_data = get_option('gawd_user_data');
|
78 |
$this->site_title = $gawd_user_data['web_property_name'];
|
79 |
+
$this->img = isset($_REQUEST["img"]) && $_REQUEST["img"] != '' ? sanitize_text_field($_REQUEST["img"]) : '';
|
80 |
+
$this->start_date = isset($_REQUEST["gawd_start_date"]) && $_REQUEST["gawd_start_date"] != '' ? sanitize_text_field($_REQUEST["gawd_start_date"]) : date('Y-m-d', strtotime('-7 days'));
|
81 |
+
$this->end_date = isset($_REQUEST["gawd_end_date"]) && $_REQUEST["gawd_end_date"] != '' ? sanitize_text_field($_REQUEST["gawd_end_date"]) : date('Y-m-d', strtotime('-1 days'));
|
82 |
if(isset($_REQUEST["gawd_metric"])){
|
83 |
$metric = sanitize_text_field($_REQUEST["gawd_metric"]);
|
84 |
}
|
92 |
}
|
93 |
$this->set_metric($metric);
|
94 |
$this->country_filter = isset($_REQUEST["country_filter"]) ? sanitize_text_field($_REQUEST["country_filter"]) : '';
|
95 |
+
$this->custom = isset( $_REQUEST["custom"] ) && $_REQUEST["custom"] != '' ? sanitize_text_field($_REQUEST["custom"]) : '';
|
96 |
|
97 |
$this->geo_type = isset($_REQUEST["geo_type"]) ? sanitize_text_field($_REQUEST["geo_type"]) : '';
|
98 |
if(isset($_REQUEST["gawd_metric_compare"])){
|
118 |
$this->second_end_date = isset($_REQUEST["second_end_date"]) ? sanitize_text_field($_REQUEST["second_end_date"]) : '';
|
119 |
/////END COMPARED PAGES VARIABLES////
|
120 |
|
121 |
+
$this->_data_compare = isset($_REQUEST["_data_compare"]) ? sanitize_text_field($_REQUEST["_data_compare"]) : '';
|
122 |
|
123 |
if(isset($_REQUEST["gawd_dimension"]) && $dimension_recc == null){
|
124 |
$dimension = sanitize_text_field($_REQUEST["gawd_dimension"]);
|
144 |
if($this->tab_name == 'goals'){
|
145 |
$dimension_arg = $this->tab_name;
|
146 |
}
|
147 |
+
$this->filter_type = isset($_REQUEST["filter_type"]) && $_REQUEST["filter_type"] != '' ? sanitize_text_field($_REQUEST["filter_type"]) : 'Date';
|
148 |
$this->set_colum_names($dimension);
|
149 |
$this->dimension = ($this->filter_type != 'Date') ? $this->filter_type : $dimension;
|
150 |
if(strpos($this->dimension,'dimension') >-1){
|
include/gawd_pdf_file.php
CHANGED
@@ -125,7 +125,7 @@ return;//todo
|
|
125 |
}
|
126 |
$dimension = isset($_REQUEST["dimension"]) ? sanitize_text_field($_REQUEST["dimension"]) : 'Date';
|
127 |
if($flag === true){
|
128 |
-
$_REQUEST['gawd_dimension'] = isset($_REQUEST['gawd_dimension']) ? preg_replace('!\s+!',' ',trim(ucfirst(preg_replace('/([A-Z])/', ' $1', $_REQUEST['gawd_dimension'])))) : $dimension;
|
129 |
$count = count($this->column_names) - 1;
|
130 |
if($dimension == 'pagePath'){
|
131 |
$count = 9.5;
|
125 |
}
|
126 |
$dimension = isset($_REQUEST["dimension"]) ? sanitize_text_field($_REQUEST["dimension"]) : 'Date';
|
127 |
if($flag === true){
|
128 |
+
$_REQUEST['gawd_dimension'] = isset($_REQUEST['gawd_dimension']) ? preg_replace('!\s+!',' ',trim(ucfirst(preg_replace('/([A-Z])/', ' $1', sanitize_text_field($_REQUEST['gawd_dimension']))))) : $dimension;
|
129 |
$count = count($this->column_names) - 1;
|
130 |
if($dimension == 'pagePath'){
|
131 |
$count = 9.5;
|
library/gawd-custom-ajax-class.php
CHANGED
@@ -996,11 +996,11 @@ class GAWD_custom_ajax_class {
|
|
996 |
|
997 |
|
998 |
private function parse_data(){
|
999 |
-
$this->action = (!empty($_REQUEST['gawd_action'])) ? $_REQUEST['gawd_action'] : "";
|
1000 |
-
$this->request_data = (!empty($_REQUEST['gawd_data'])) ?
|
1001 |
-
$this->nonce_data = (!empty($_REQUEST['gawd_nonce_data'])) ?
|
1002 |
if(isset($_REQUEST['gawd_view_id'])){
|
1003 |
-
$this->view_id = $_REQUEST['gawd_view_id'];
|
1004 |
}
|
1005 |
}
|
1006 |
|
@@ -1063,7 +1063,7 @@ class GAWD_custom_ajax_class {
|
|
1063 |
) ||
|
1064 |
(
|
1065 |
isset($_REQUEST['gawd_cron_token']) &&
|
1066 |
-
GAWD_helper::check_cron_token($_REQUEST['gawd_cron_token'])
|
1067 |
)
|
1068 |
) {
|
1069 |
return true;
|
996 |
|
997 |
|
998 |
private function parse_data(){
|
999 |
+
$this->action = (!empty($_REQUEST['gawd_action'])) ? sanitize_text_field($_REQUEST['gawd_action']) : "";
|
1000 |
+
$this->request_data = (!empty($_REQUEST['gawd_data'])) ? GAWD_helper::validate_string('gawd_data', array()) : array();
|
1001 |
+
$this->nonce_data = (!empty($_REQUEST['gawd_nonce_data'])) ? GAWD_helper::validate_string('gawd_nonce_data', array()) : array();
|
1002 |
if(isset($_REQUEST['gawd_view_id'])){
|
1003 |
+
$this->view_id = GAWD_helper::validate_string($_REQUEST['gawd_view_id']);
|
1004 |
}
|
1005 |
}
|
1006 |
|
1063 |
) ||
|
1064 |
(
|
1065 |
isset($_REQUEST['gawd_cron_token']) &&
|
1066 |
+
GAWD_helper::check_cron_token(sanitize_text_field($_REQUEST['gawd_cron_token']))
|
1067 |
)
|
1068 |
) {
|
1069 |
return true;
|
library/gawd-email-class.php
CHANGED
@@ -39,8 +39,8 @@ class GAWD_email {
|
|
39 |
return false;
|
40 |
}
|
41 |
|
42 |
-
$this->email_to = $_POST['email_info']['email_to'];
|
43 |
-
$this->email_from = (isset($_POST['email_info']['email_from'])) ? $_POST['email_info']['email_from'] : get_option('admin_email');
|
44 |
|
45 |
if(empty($this->email_from)) {
|
46 |
$this->set_error('no_email_from', 'No email');
|
@@ -48,15 +48,19 @@ class GAWD_email {
|
|
48 |
}
|
49 |
|
50 |
|
51 |
-
$this->period = (isset($_POST['email_info']['period'])) ? $_POST['email_info']['period'] : "once";
|
52 |
-
$this->subject = (isset($_POST['email_info']['subject'])) ? $_POST['email_info']['subject'] : "";
|
53 |
-
$this->content = (isset($_POST['email_info']['content'])) ? $_POST['email_info']['content'] : "";
|
54 |
-
$this->week_day = (isset($_POST['email_info']['week_day'])) ? $_POST['email_info']['week_day'] : "";
|
55 |
-
$this->month_day = (isset($_POST['email_info']['month_day'])) ? $_POST['email_info']['month_day'] : "1";
|
56 |
-
$this->time = (isset($_POST['email_info']['email_time'])) ? $_POST['email_info']['email_time'] : "00:00";
|
57 |
-
$this->view_id = (isset($_POST['email_info']['view_id'])) ? $_POST['email_info']['view_id'] : "";
|
58 |
-
$this->other_info = (isset($_POST['email_info']['other_info'])) ? $_POST['email_info']['other_info'] : array();
|
59 |
|
|
|
|
|
|
|
|
|
|
|
60 |
|
61 |
return true;
|
62 |
}
|
39 |
return false;
|
40 |
}
|
41 |
|
42 |
+
$this->email_to = sanitize_text_field($_POST['email_info']['email_to']);
|
43 |
+
$this->email_from = (isset($_POST['email_info']['email_from'])) ? sanitize_text_field($_POST['email_info']['email_from']) : get_option('admin_email');
|
44 |
|
45 |
if(empty($this->email_from)) {
|
46 |
$this->set_error('no_email_from', 'No email');
|
48 |
}
|
49 |
|
50 |
|
51 |
+
$this->period = (isset($_POST['email_info']['period'])) ? sanitize_text_field($_POST['email_info']['period']) : "once";
|
52 |
+
$this->subject = (isset($_POST['email_info']['subject'])) ? sanitize_text_field($_POST['email_info']['subject']) : "";
|
53 |
+
$this->content = (isset($_POST['email_info']['content'])) ? sanitize_text_field($_POST['email_info']['content']) : "";
|
54 |
+
$this->week_day = (isset($_POST['email_info']['week_day'])) ? sanitize_text_field($_POST['email_info']['week_day']) : "";
|
55 |
+
$this->month_day = (isset($_POST['email_info']['month_day'])) ? sanitize_text_field($_POST['email_info']['month_day']) : "1";
|
56 |
+
$this->time = (isset($_POST['email_info']['email_time'])) ? sanitize_text_field($_POST['email_info']['email_time']) : "00:00";
|
57 |
+
$this->view_id = (isset($_POST['email_info']['view_id'])) ? sanitize_text_field($_POST['email_info']['view_id']) : "";
|
|
|
58 |
|
59 |
+
if(isset($_POST['email_info']) && isset($_POST['email_info']['other_info'])){
|
60 |
+
$this->other_info = GAWD_helper::validate_string_array($_POST['email_info']['other_info']);
|
61 |
+
}else{
|
62 |
+
$this->other_info = array();
|
63 |
+
}
|
64 |
|
65 |
return true;
|
66 |
}
|
library/gawd-helper-class.php
CHANGED
@@ -583,4 +583,43 @@ class GAWD_helper {
|
|
583 |
</div>
|
584 |
<?php }
|
585 |
|
586 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
583 |
</div>
|
584 |
<?php }
|
585 |
|
586 |
+
public static function validate_string($key , $default=""){
|
587 |
+
if (isset($_GET[$key])) {
|
588 |
+
$data = $_GET[$key];
|
589 |
+
}
|
590 |
+
elseif (isset($_POST[$key])) {
|
591 |
+
$data = $_POST[$key];
|
592 |
+
}
|
593 |
+
elseif (isset($_REQUEST[$key])) {
|
594 |
+
$data = $_REQUEST[$key];
|
595 |
+
}
|
596 |
+
else {
|
597 |
+
$data = $default;
|
598 |
+
}
|
599 |
+
if(is_array($data)){
|
600 |
+
$arr_data = array_map(array('GAWD_helper','tw_sanitize_text'), $data );
|
601 |
+
return $arr_data;
|
602 |
+
}
|
603 |
+
$return_data = sanitize_text_field($data);
|
604 |
+
return $return_data;
|
605 |
+
}
|
606 |
+
|
607 |
+
public function tw_sanitize_text($val){
|
608 |
+
if(is_array($val)){
|
609 |
+
return self::validate_string_array($val);
|
610 |
+
}
|
611 |
+
return sanitize_text_field($val);
|
612 |
+
}
|
613 |
+
|
614 |
+
|
615 |
+
public static function validate_string_array($data){
|
616 |
+
if(is_array($data)){
|
617 |
+
$arr_data = array_map(array("GAWD_helper", "tw_sanitize_text"), $data );
|
618 |
+
return $arr_data;
|
619 |
+
}
|
620 |
+
$return_data = sanitize_text_field($data);
|
621 |
+
return $return_data;
|
622 |
+
}
|
623 |
+
|
624 |
+
}
|
625 |
+
|
readme.txt
CHANGED
@@ -1,404 +1,24 @@
|
|
1 |
-
===
|
2 |
-
Contributors:
|
3 |
-
Tags: google analytics, statistics, tracking, analytics dashboard, ga, google analytics dashboard, analytics, stats, googleanalytics, ecommerce tracking, custom reports, custom dimensions
|
4 |
Requires at least: 3.9
|
5 |
-
Tested up to: 5.
|
6 |
-
Stable tag: 1.2.
|
7 |
License: GPLv2 or later
|
8 |
License URI: http://www.gnu.org/licenses/gpl-2.0.html
|
9 |
|
10 |
-
View and customize all
|
11 |
|
12 |
== Description ==
|
13 |
|
14 |
-
View and customize all
|
15 |
= Useful Links: =
|
16 |
|
17 |
[Live Demo](https://admindemo.10web.io/?product_name=google-analytics)
|
18 |
|
19 |
|
20 |
-
[Premium
|
21 |
|
22 |
|
23 |
[Special Offer for all Premium Plugins](https://10web.io/plugins-bundle-pricing/)
|
24 |
|
25 |
https://www.youtube.com/watch?v=n1f7ECVFNPI
|
26 |
-
|
27 |
-
Having a hard time customizing Google Analytics reports?
|
28 |
-
|
29 |
-
Need metrics that you can’t find in Google Analytics?
|
30 |
-
|
31 |
-
Are you tired of going to different websites for website management and stats overview?
|
32 |
-
|
33 |
-
|
34 |
-
|
35 |
-
== Google Analytics by 10Web Features ==
|
36 |
-
|
37 |
-
**Get All Reports from Google Analytics**
|
38 |
-
All types of reports are available in your WordPress dashboard.
|
39 |
-
|
40 |
-
**Display Reports on Front-End**
|
41 |
-
Get key stats about posts displayed right on the page.
|
42 |
-
|
43 |
-
**Get E-Commerce Reports\***
|
44 |
-
See how conversions work and how much you earn online.
|
45 |
-
|
46 |
-
**Manage Goals**
|
47 |
-
Set goals on your WordPress dashboard and constantly manage them.
|
48 |
-
|
49 |
-
**Integrate Google Ads & AdSense**
|
50 |
-
Get data about ads on your website in the same dashboard.
|
51 |
-
|
52 |
-
**Customize Reports**
|
53 |
-
Select the metrics you want to see and choose how you want them displayed.
|
54 |
-
|
55 |
-
**Setup WordPress Dimensions\***
|
56 |
-
Add Tags, Use Types, Post Types, Categories, and Publication Date as custom dimensions.
|
57 |
-
|
58 |
-
**Receive Notifications and Alerts**
|
59 |
-
Get alerts and pushover notifications when selected metrics reach their highest or lowest points.
|
60 |
-
|
61 |
-
**Export in CSV and Send Emails**
|
62 |
-
Share reports via automated email and export them in CSV.
|
63 |
-
|
64 |
-
**Filter Tracked Data\***
|
65 |
-
Exclude certain user types, locations or IP addresses with custom tracking codes.
|
66 |
-
|
67 |
-
_\* Premium version only_
|
68 |
-
|
69 |
-
|
70 |
-
== Outstanding Customer Care ==
|
71 |
-
* Rapid response
|
72 |
-
We won’t make you wait more than a few hours.
|
73 |
-
|
74 |
-
* Quick issue resolution
|
75 |
-
We’ll resolve your issue within 24 hours.
|
76 |
-
|
77 |
-
|
78 |
-
== Customize Your Analytics ==
|
79 |
-
1. Buy Google Analytics Plugin
|
80 |
-
2. Login with your Google Account
|
81 |
-
3. Track your traffic
|
82 |
-
|
83 |
-
> **[Premium features](https://10web.io/plugins/wordpress-google-analytics/)**
|
84 |
-
>
|
85 |
-
> * Permissions for users/roles
|
86 |
-
> * Custom metrics and reports
|
87 |
-
> * E-commerce reports
|
88 |
-
> * Reports on Google AdWords and AdSense
|
89 |
-
> * Tracking filters for users/roles
|
90 |
-
> * Alerts
|
91 |
-
> * Priority support and updates
|
92 |
-
|
93 |
-
|
94 |
-
|
95 |
-
## SETTINGS/CUSTOMIZATION
|
96 |
-
|
97 |
-
_*Some customizations described here are available in Premium version. Please refer to premium features below._
|
98 |
-
|
99 |
-
The plugin adds the Google Analytics tracking code to your website and brings all your site stats into your dashboard.The plugin has a user friendly admin section, where you can configure tracking options, view the preset and custom configured reports, set tracking filters and exclusions, and configure the plugin settings. The reporting section of the plugin provides an extensive data information about pretty much any activity taking place on your website. You can customise Analytics options under the settings tab of the plugin. Here you can configure alerts and the Pushover notifications by setting alert conditions and choosing the period for receiving alerts. From the same section you can set tracking filters by country, region, city or IP address. Data from these sources will be filtered out from the reports.
|
100 |
-
|
101 |
-
For more advanced users, there are advanced setting options, to enable cross domain tracking,enable frontend/backend reports for posts and pages, choose roles for viewing frontend reports, and many more.
|
102 |
-
|
103 |
-
Under the goals management tab you can set and configure different goal types,and track targeted activities.To configure custom reports you’ll need to choose the metric and the dimension you want to get a report for. It will appear under the reports section shortly.
|
104 |
-
There are many more features in the plugin that can help you dive deep into the statistics, monitor your site’s performance and actually improve it. To learn more, check out the plugin’s user guide.
|
105 |
-
|
106 |
-
= Privacy Notices =
|
107 |
-
|
108 |
-
Google Analytics by 10Web plugin adds GA JS code to the site (optionally) and is used to get GA reports from admin area. It sends analytics data to Google. Whether it will send any personal data to Google, depends on how you set up your website. For example, do not expose emails or other personally identifiable information to Google via URLs. Do not send form submissions via analytics to Google. By default, all the IPs of visitors are anonymized. Personal data processing by Google is explained in their privacy policy https://policies.google.com/privacy. The plugin retrieves from Google and caches data of your GA account and analytics reports in WordPress site database to provide optimization. Reports data is stored in DB for some small period of time (less than 24h). Your GA account data is preserved in your website database as long as you decide to keep it. The plugin asks for your consent to collect site administrator’s email address and site URL to offer customer support, deals and discounts on premium products and more.
|
109 |
-
|
110 |
-
== Frequently Asked Questions ==
|
111 |
-
|
112 |
-
= How can I connect the plugin to my Google Analytics account? =
|
113 |
-
|
114 |
-
Click on Analytics menu item, which will start Google Analytics account authorization process. Click Authenticate button and login to your Google account.
|
115 |
-
|
116 |
-
A window asking for relevant permissions will appear. Click Allow and copy the authentication code from the text input. You will be redirected to plugin’s Tracking page.
|
117 |
-
|
118 |
-
Here you can add a web property on your Analytics account using current WordPress website. Provide a Name for the property and click Add. You can check and manage web properties from your Analytics account, Admin page.
|
119 |
-
|
120 |
-
Alternatively, you can click Later and configure the web property any other time.
|
121 |
-
|
122 |
-
You can Reauthenticate in Settings section anytime in case you need to use a different Google account to monitor Analytics tracking.
|
123 |
-
|
124 |
-
|
125 |
-
= What reports can I see in the plugin? =
|
126 |
-
|
127 |
-
The plugin enables you to view various analytics reports from your WordPress dashboard, including the following:
|
128 |
-
Audience. Report of your website audience. Provides details about new and returning users of your website, sessions, bounces, pageviews, page/sessions and session durations.
|
129 |
-
Real Time. Shows the number of active users visiting your website pages at that second.
|
130 |
-
Demographics. Displays tracking statistics of your website users based on their age and gender.
|
131 |
-
Interests. Provides tracking information about site users depending on Affinity Categories (e.g. Music Lovers or Mobile Enthusiasts), In-Market Segments (based on online product purchase interests) and Other Categories (most specific identification, for example, tennis lovers among Sports Fans).
|
132 |
-
Geo. Geo-identifier report is built from interactions of location (countries, cities) and language of your website users.
|
133 |
-
Behavior. Compares number of New visitors and Returning users of your website in percents. You can check the duration of sessions with Engagement report.
|
134 |
-
Technology. Identifies tracking of the site based on operating systems and browsers visitors use.
|
135 |
-
Mobile. Shows statistics of mobile and desktop devices visitors have used while interacting with your website.
|
136 |
-
Custom Dimensions. Reports of Custom Dimensions you have added will be displayed under this tab. Step-by-step guide for the setup is in Custom Dimensions section of this guide.
|
137 |
-
Traffic Source. Displays overall graph of traffic sources directing to your website.
|
138 |
-
AdWords. If your website is registered on Google AdWords, you can link its Analytics to AdWords, and gather relevant tracking information with this report.
|
139 |
-
Pages. Pages report table will provide you information about Bounces, Entrances, Pageviews, Unique Pageviews, time spent on pages, Exits and Average page loading time.
|
140 |
-
Site Speed. Shows the average load time of your website during specified date range.
|
141 |
-
Events. Displays the report based on Events you set up on Analytics of your website. Graphs are built based on Event Labels, Categories and Actions.
|
142 |
-
Goals. Set Goals from Goal Management and review their reports under this tab. Instructions to set up goals will be provided in Goal Management section of this guide.
|
143 |
-
Ecommerce. Check sales statistics of your website by revenues, transactions, products and performance.
|
144 |
-
AdSense. Link your Analytics and AdSense accounts from Admin settings and keep track of AdSense tracking under this report.
|
145 |
-
Custom Reports. Add Custom Reports from any metric and dimension in Custom Reports page, and view relevant tracking information in this tab.
|
146 |
-
|
147 |
-
|
148 |
-
= How can I add a custom report in the plugin? =
|
149 |
-
|
150 |
-
Besides the built-in report types, the plugin also provides the functionality to configure Custom Reports and view related statistics within Reports page.
|
151 |
-
Start with providing a Name for your Custom Report. Then select a Metric and Dimension, based on which the statistics will be built.
|
152 |
-
For example, you can select Organic Searches as the metric and Keyword as the dimension. This custom setup will let you have a report based on the keywords, which visitors use to find your website with search engines.
|
153 |
-
You can view and manage created Custom Reports on the same page. The list will appear with a table under options of Custom Reports.
|
154 |
-
|
155 |
-
= Can I export the reports from the analytics plugin? =
|
156 |
-
|
157 |
-
You can export current report to CSV and PDF formats. Hover on Export button and click one of the options to download your analytics report.
|
158 |
-
Moreover, the same report can be sent via email to one or more recipients which you specify. The mails can be sent one time, as well as periodically. Click the Email button to start the setup. A popup window will appear with the following options:
|
159 |
-
|
160 |
-
From. This is the email address, from which the report will be sent. It is the address you defined for your Administrator account, and it can be changed from WordPress Settings > General > Email Address option.
|
161 |
-
To. Determine the recipients of the report email by providing their email addresses separated by commas.
|
162 |
-
Subject. Write a subject for the email. It is set to the report title by default, but you can modify it and have a customized title.
|
163 |
-
Attachment. Pick the type of the attachment for your report. It can be sent as a CSV or a PDF file.
|
164 |
-
Frequency. Set the frequency for sending out report emails. The following options are available:
|
165 |
-
Once. The report is sent only one time.
|
166 |
-
Daily. The email is sent each day.
|
167 |
-
Weekly. Chose this option to send the report every week. Make sure to set the day of the week, when the email will be sent.
|
168 |
-
Monthly. Set the reports to be sent every month. Select the day of the month, when the email will be sent.
|
169 |
-
Additional Message. You can add any e-mail content to go along with your Analytics report.
|
170 |
-
The scheduled e-mails can be deleted from Settings > Emails page of the plugin.
|
171 |
-
|
172 |
-
|
173 |
-
= Can I set goals in the plugin? =
|
174 |
-
|
175 |
-
Goals in Google Analytics lets you track targeted activities, which users complete on your website. A completed activity is called conversion. You can set visiting a certain page as a goal, for example, or have users stay on your website a certain period of time. Other examples of goals can be checkout for a shopping site, and setting a certain number of pageviews per session.
|
176 |
-
You can set and manage goals for your website tracking in Google Analytics by 10Web > Goal Management page. Note, that Goals configured with the plugin are set only to the domain on which the plugin is installed.
|
177 |
-
Select the View that you’re going to track and configure the following options based on the type of goal you would like to set:
|
178 |
-
Provide a Name for the goal and choose its Type from one of the following:
|
179 |
-
Destination. Set a specific URL for the goal, for example, your ecommerce website shop page. When a user visits it, it will be counted as a goal conversion. You can set the destination using one of these conditions:
|
180 |
-
|
181 |
-
* Equals to. Should be the exact URL of the page you are using to set the goal.
|
182 |
-
* Begins with. Mentions the beginning of the tracked page link.
|
183 |
-
* Regular expression. This option will search all the visited links with the specified Regular Expression. E.g., if you set it to "test", and users visit URLs which contain “test”, this will be considered as a conversion.
|
184 |
-
|
185 |
-
Duration. Determine the time period, during which you need users to stay on your website to complete the goal. Goals of this type are controlled with less than and greater than conditions.
|
186 |
-
Pages/Screens per session. Choose the number of page/screen views per session, and set the goal using less than and greater than conditions.
|
187 |
-
|
188 |
-
|
189 |
-
= How can I link my AdSense and AdWords accounts to the plugin? =
|
190 |
-
|
191 |
-
**AdSense**
|
192 |
-
|
193 |
-
If you have an authorized account on Google AdSense, you can link it to Google Analytics and view its tracking information among plugin reports.
|
194 |
-
Open your Google Analytics account, choose the account you want to link with AdSense and navigate to Admin tab. You will see AdSense Linking option under Product Linking settings. Open AdSense Linking and click on New AdSense Link button.
|
195 |
-
Afterwards choose the necessary AdSense account you'd like to link with your Google Analytics, then click Continue. Choose the views, where you would like to have AdSense data. The accounts will be connected after clicking Enable Link and then Done.
|
196 |
-
|
197 |
-
**AdWords**
|
198 |
-
|
199 |
-
Firstly make sure you have a AdWords account, or create one here. Open your Google Analytics account, choose the website you are tracking and go to Admin. Click on Adwords Linking from Product Linking settings.
|
200 |
-
After toolbox opens, make sure all the necessary AdWords accounts are marked as checked and click Continue. Provide Link group title and click Link Accounts after enabling necessary link groups for AdWords Tracking. Related tracking reports will appear on your Reports page automatically.
|
201 |
-
|
202 |
-
|
203 |
-
== Changelog ==
|
204 |
-
|
205 |
-
= 1.2.4 =
|
206 |
-
* Changed: Links to 10Web.io.
|
207 |
-
|
208 |
-
= 1.2.3 =
|
209 |
-
* Added: Alerts functionality
|
210 |
-
* Added: Emails functionality
|
211 |
-
* Fixed: Exclude tracking for user
|
212 |
-
|
213 |
-
= 1.2.2 =
|
214 |
-
* Fixed: Use of deprecated function in PHP 7.2
|
215 |
-
* Fixed: Notices in custom reports page
|
216 |
-
|
217 |
-
= 1.2.1 =
|
218 |
-
* Fixed: PHP error if PHP version < 5.5
|
219 |
-
|
220 |
-
= 1.2.0 =
|
221 |
-
* Improved: Plugin core functionality is rewritten. The plugin is faster and consumes less memory now.
|
222 |
-
* Improved: Google API client library is used in non-conflicting way.
|
223 |
-
* Improved: The size of the plugin is smaller now due to stripped version of Google library
|
224 |
-
* Improved: Better UX: some menues of the plugin are hidden when plugin has not been configured properly.
|
225 |
-
* Improved: UX when using custom client ID and secret
|
226 |
-
* Improved: New UI of reports, charts and tables
|
227 |
-
* Fixed: Security issues
|
228 |
-
* Fixed: Compatibility issues with Yoast SEO and UpdraftPlus plugins
|
229 |
-
* Fixed: Error notices if no web-property or multiple web-properties correspond to current site
|
230 |
-
* Fixed: Reports for page/post and frontend templates in metaboxes, admin bar, admin list screens and widget
|
231 |
-
* Fixed: User roles management
|
232 |
-
* Fixed: PHP error in admin reports for ecommerce
|
233 |
-
* Fixed: Numerous minor bugs
|
234 |
-
* Changed: Tracking settings are moved to settings page, as a separate tab
|
235 |
-
* Changed: Widgets options
|
236 |
-
* Changed: Emails, alerts, pushover and export features are temporary disabled
|
237 |
-
|
238 |
-
= 1.1.8 =
|
239 |
-
* Changed: Changed: Introducing brand new free plugin: SEO by 10Web.
|
240 |
-
|
241 |
-
= 1.1.7 =
|
242 |
-
* Changed: Deactivation popup.
|
243 |
-
|
244 |
-
= 1.1.6 =
|
245 |
-
* Added: Links to Reviews and Support Forum
|
246 |
-
|
247 |
-
= 1.1.5 =
|
248 |
-
* Fixed: PHP 5.4.0 compatibility
|
249 |
-
|
250 |
-
|
251 |
-
= 1.1.4 =
|
252 |
-
* Fixed: Compatibility issues with Constant Contact Forms, Updraftplus, Image Optimizer WD, Backup WD and some other plugins
|
253 |
-
* Fixed: JS errors on page/post editor
|
254 |
-
* Fixed: Old user account data partially preserved after reauthorization and uninstall
|
255 |
-
|
256 |
-
= 1.1.3 =
|
257 |
-
* Fixed: Empty settings page when plugin has token but accounts data lost for some reason
|
258 |
-
* Changed: Show notification to install Backup WD plugin only on plugin pages.
|
259 |
-
|
260 |
-
= 1.1.2 =
|
261 |
-
* Fixed: Conflict with some other plugins using Google API PHP library
|
262 |
-
* Fixed: Unable to authorize again after logout
|
263 |
-
* Fixed: JS errors on page/post editor if user not authenticated
|
264 |
-
* Change: Introducing Backup WD plugin
|
265 |
-
|
266 |
-
= 1.1.1 =
|
267 |
-
* Fixed: Reports for pages/posts in metabox
|
268 |
-
* Fixed: Multiple requests to Web-Dorado API for updates (Pro)
|
269 |
-
* Fixed: Multiple requests to Google Analytics API for management accounts
|
270 |
-
* Fixed: PHP 5.4.0 compatibility
|
271 |
-
* Changed: WD library initialization
|
272 |
-
|
273 |
-
= 1.1.0 =
|
274 |
-
* Changed: Improved UX of authentication
|
275 |
-
* Changed: Google API PHP Client library updated to the latest 2.2.0 version
|
276 |
-
* Changed: WD library updated to version 1.0.10
|
277 |
-
* Fixed: Fatal errors when WordPress could not establish secure connection with Google Analytics API
|
278 |
-
* Fixed: VanillaJS tracking code instead of jQuery
|
279 |
-
* Fixed: Escaping of custom tracking code
|
280 |
-
* Fixed: PHP notices in pages without global $post variable
|
281 |
-
|
282 |
-
= 1.0.22 =
|
283 |
-
* Changed: We temporarily disabled reports in admin dashboard and mailing
|
284 |
-
|
285 |
-
= 1.0.21 =
|
286 |
-
* Fixed: Network activation
|
287 |
-
|
288 |
-
= 1.0.20 =
|
289 |
-
* Fixed: Admin styles conflict because of bootstrap.css
|
290 |
-
|
291 |
-
= 1.0.19 =
|
292 |
-
* Changed: Show web-property-related message only in analytics page
|
293 |
-
* Fixed: Style conflict with jquery-ui.css
|
294 |
-
* Fixed: Error on PHP4
|
295 |
-
|
296 |
-
= 1.0.18 =
|
297 |
-
* Fixed: Bug on city/pageview report
|
298 |
-
|
299 |
-
= 1.0.17 =
|
300 |
-
* Added: Overview page
|
301 |
-
* Removed: Featured Plugins, Featured Themes pages
|
302 |
-
|
303 |
-
= 1.0.16 =
|
304 |
-
* Fixed: Bug on pagePath
|
305 |
-
* Changed: Message about deleted web property
|
306 |
-
|
307 |
-
= 1.0.15 =
|
308 |
-
* Fixed: Bug on date picker
|
309 |
-
* Changed: Improved error handling
|
310 |
-
* Added: New featured plugins
|
311 |
-
|
312 |
-
= 1.0.14 =
|
313 |
-
* Fixed: Analytics back end menu position conflict
|
314 |
-
* Fixed: Bug on deleted property check
|
315 |
-
* Added: Error log
|
316 |
-
|
317 |
-
= 1.0.13 =
|
318 |
-
* Fixed: Bug on Custom code option in tracking
|
319 |
-
|
320 |
-
= 1.0.12 =
|
321 |
-
* Fixed: Bug on report by individual post/page
|
322 |
-
|
323 |
-
= 1.0.11 =
|
324 |
-
* Added: Custom code option in tracking
|
325 |
-
|
326 |
-
= 1.0.10 =
|
327 |
-
* Fixed: Bug on sending a report to an email once
|
328 |
-
* Changed: New logo in dashboard menu and notices
|
329 |
-
* Fixed: Width issue with some reports
|
330 |
-
|
331 |
-
|
332 |
-
= 1.0.9 =
|
333 |
-
* Added: Option to select the time of the day for scheduled emails
|
334 |
-
* Changed: Save authenticate code with enter button
|
335 |
-
* Changed: Select permissions for user groups in a pop-up (Settings page)
|
336 |
-
* Fixed: minor bugs
|
337 |
-
|
338 |
-
= 1.0.8 =
|
339 |
-
* Added: Google Analytics reports for custom post types
|
340 |
-
* Added: New icon in the menu
|
341 |
-
* Added: New header on WordPress.org
|
342 |
-
* Fixed: JS error on creating new pages/posts
|
343 |
-
|
344 |
-
= 1.0.7 =
|
345 |
-
* Fixed: Bug in Site Content reports
|
346 |
-
|
347 |
-
= 1.0.6 =
|
348 |
-
* Fixed: User guide links
|
349 |
-
* Fixed: Bug on datepicker
|
350 |
-
* Fixed: Error when deleting the web property
|
351 |
-
* Added: Validation on the form for adding goals
|
352 |
-
|
353 |
-
= 1.0.5 =
|
354 |
-
* Fixed: PHP version conflict
|
355 |
-
* Added: Pro flags about additional functionality available in Pro version
|
356 |
-
* Added: Explanation texts and links to documenta
|
1 |
+
=== 10WebAnalytics ===
|
2 |
+
Contributors: 10web
|
|
|
3 |
Requires at least: 3.9
|
4 |
+
Tested up to: 5.1
|
5 |
+
Stable tag: 1.2.8
|
6 |
License: GPLv2 or later
|
7 |
License URI: http://www.gnu.org/licenses/gpl-2.0.html
|
8 |
|
9 |
+
View and customize all GoogleAnalytics reports directly in your WordPress dashboard.
|
10 |
|
11 |
== Description ==
|
12 |
|
13 |
+
View and customize all GoogleAnalytics reports directly in your WordPress dashboard.
|
14 |
= Useful Links: =
|
15 |
|
16 |
[Live Demo](https://admindemo.10web.io/?product_name=google-analytics)
|
17 |
|
18 |
|
19 |
+
[10WebAnalytics Premium](https://10web.io/plugins/wordpress-google-analytics/)
|
20 |
|
21 |
|
22 |
[Special Offer for all Premium Plugins](https://10web.io/plugins-bundle-pricing/)
|
23 |
|
24 |
https://www.youtube.com/watch?v=n1f7ECVFNPI
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|