IgniteUp – Coming Soon and Maintenance Mode - Version 3.4.3

Version Description

Download this release

Release Info

Developer ceylonsystems
Plugin Icon 128x128 IgniteUp – Coming Soon and Maintenance Mode
Version 3.4.3
Comparing to
See all releases

Code changes from version 3.4.2 to 3.4.3

igniteup.php CHANGED
@@ -3,7 +3,7 @@
3
  Plugin Name: IgniteUp
4
  Plugin URI: http://getigniteup.com
5
  Description: IgniteUp is a powerful plugin which allows you to keep your site on launchpad till ignite-up and to build amazing coming soon pages.
6
- Version: 3.4.1
7
  Author: Ceylon Systems
8
  Author URI: http://getigniteup.com
9
  License: GPLv2 or later
@@ -14,4 +14,4 @@
14
  require_once 'includes/core-import.php';
15
  require_once 'includes/core-helpers.php';
16
 
17
- new CSComingSoonCreator(__FILE__, '3.4.1');
3
  Plugin Name: IgniteUp
4
  Plugin URI: http://getigniteup.com
5
  Description: IgniteUp is a powerful plugin which allows you to keep your site on launchpad till ignite-up and to build amazing coming soon pages.
6
+ Version: 3.4.3
7
  Author: Ceylon Systems
8
  Author URI: http://getigniteup.com
9
  License: GPLv2 or later
14
  require_once 'includes/core-import.php';
15
  require_once 'includes/core-helpers.php';
16
 
17
+ new CSComingSoonCreator(__FILE__, '3.4.3');
includes/class-admin-options.php CHANGED
@@ -1,6 +1,6 @@
1
  <?php
2
 
3
- class CSAdminOptions
4
  {
5
 
6
  public static $gener_options = array('enable', 'cs_page_title', 'skipfor', 'skip_with_get_request', 'whitelisted_ips', 'powered_by', 'customcss', 'favicon_url', 'send_status');
@@ -79,9 +79,9 @@ class CSAdminOptions
79
  ksort($templates);
80
 
81
  /*
82
- *
83
  * Check for incompatible templates.
84
- *
85
  */
86
  foreach ($templates as $template => $option) {
87
  if (isset($option['igniteup_version']) && floatval($option['igniteup_version']) > floatval($version)) {
@@ -111,15 +111,15 @@ class CSAdminOptions
111
  /**
112
  * Returns a requested default string.
113
  * Available Strings are listed below.
114
- *
115
- * CountDown: days, hours, minutes, secs, mins
116
- *
117
  * Forms: subscribe_thankyou, contact_success, contact_failed
118
- *
119
- * Common: invalid_email, existing_email, sending, error
120
- *
121
  * @param string $key slug
122
- * @return string Requested translatable string
123
  */
124
  public static function getDefaultStrings($key)
125
  {
@@ -133,7 +133,7 @@ class CSAdminOptions
133
 
134
  /**
135
  * Array of default strings
136
- *
137
  * @return array
138
  */
139
  static function messageBag()
@@ -141,9 +141,9 @@ class CSAdminOptions
141
  return array(
142
 
143
  /*
144
- *
145
  * Subscribe Form
146
- *
147
  */
148
  'subscribe_text' => __('Subscribe', CSCS_TEXT_DOMAIN),
149
  'subscribe_done' => __('Subscribed', CSCS_TEXT_DOMAIN),
@@ -153,17 +153,17 @@ class CSAdminOptions
153
  'subscribe_thankyou' => __('Thanks for subscribing!', CSCS_TEXT_DOMAIN), //Subscribe form on SUCCESS
154
 
155
  /*
156
- *
157
  * Contact Form
158
- *
159
  */
160
  'contact_success' => __("Thanks for making a sound!", CSCS_TEXT_DOMAIN), //Contact form on SUCCESS
161
  'contact_failed' => __("Message not sent.", CSCS_TEXT_DOMAIN), //Contact form on !SUCCESS
162
 
163
  /*
164
- *
165
  * Common
166
- *
167
  */
168
  'invalid_email' => __("Please enter a valid email.", CSCS_TEXT_DOMAIN),
169
  'existing_email' => __("That email is already with us.", CSCS_TEXT_DOMAIN),
@@ -171,9 +171,9 @@ class CSAdminOptions
171
  'error' => __("Something Went Wrong.", CSCS_TEXT_DOMAIN),
172
 
173
  /*
174
- *
175
  * Countdown
176
- *
177
  */
178
  'days' => __('DAY<span id="day-s">S</span>', CSCS_TEXT_DOMAIN),
179
  'hours' => __('HOUR<span id="hrs-s">S</span>', CSCS_TEXT_DOMAIN),
1
  <?php
2
 
3
+ class CSAdminOptions
4
  {
5
 
6
  public static $gener_options = array('enable', 'cs_page_title', 'skipfor', 'skip_with_get_request', 'whitelisted_ips', 'powered_by', 'customcss', 'favicon_url', 'send_status');
79
  ksort($templates);
80
 
81
  /*
82
+ *
83
  * Check for incompatible templates.
84
+ *
85
  */
86
  foreach ($templates as $template => $option) {
87
  if (isset($option['igniteup_version']) && floatval($option['igniteup_version']) > floatval($version)) {
111
  /**
112
  * Returns a requested default string.
113
  * Available Strings are listed below.
114
+ *
115
+ * CountDown: days, hours, minutes, secs, mins
116
+ *
117
  * Forms: subscribe_thankyou, contact_success, contact_failed
118
+ *
119
+ * Common: invalid_email, existing_email, sending, error
120
+ *
121
  * @param string $key slug
122
+ * @return string Requested translatable string
123
  */
124
  public static function getDefaultStrings($key)
125
  {
133
 
134
  /**
135
  * Array of default strings
136
+ *
137
  * @return array
138
  */
139
  static function messageBag()
141
  return array(
142
 
143
  /*
144
+ *
145
  * Subscribe Form
146
+ *
147
  */
148
  'subscribe_text' => __('Subscribe', CSCS_TEXT_DOMAIN),
149
  'subscribe_done' => __('Subscribed', CSCS_TEXT_DOMAIN),
153
  'subscribe_thankyou' => __('Thanks for subscribing!', CSCS_TEXT_DOMAIN), //Subscribe form on SUCCESS
154
 
155
  /*
156
+ *
157
  * Contact Form
158
+ *
159
  */
160
  'contact_success' => __("Thanks for making a sound!", CSCS_TEXT_DOMAIN), //Contact form on SUCCESS
161
  'contact_failed' => __("Message not sent.", CSCS_TEXT_DOMAIN), //Contact form on !SUCCESS
162
 
163
  /*
164
+ *
165
  * Common
166
+ *
167
  */
168
  'invalid_email' => __("Please enter a valid email.", CSCS_TEXT_DOMAIN),
169
  'existing_email' => __("That email is already with us.", CSCS_TEXT_DOMAIN),
171
  'error' => __("Something Went Wrong.", CSCS_TEXT_DOMAIN),
172
 
173
  /*
174
+ *
175
  * Countdown
176
+ *
177
  */
178
  'days' => __('DAY<span id="day-s">S</span>', CSCS_TEXT_DOMAIN),
179
  'hours' => __('HOUR<span id="hrs-s">S</span>', CSCS_TEXT_DOMAIN),
includes/class-coming-soon-creator.php CHANGED
@@ -163,23 +163,18 @@ class CSComingSoonCreator
163
  if (isset($_GET['page']) && ($_GET['page'] == 'cscs_options' || $_GET['page'] == 'cscs_subscribers')) {
164
  wp_enqueue_style('wp-color-picker');
165
 
166
- wp_enqueue_style('codemirror-main', plugin_dir_url(CSCS_FILE) . 'includes/css/codemirror/codemirror.css');
167
- wp_enqueue_style('codemirror-theme', plugin_dir_url(CSCS_FILE) . 'includes/css/codemirror/ttcn.css');
168
  wp_enqueue_style('jquery-timepicker-css', plugin_dir_url(CSCS_FILE) . 'includes/css/jquery.timepicker.min.css');
169
- wp_enqueue_script('jquery');
170
 
 
171
  wp_enqueue_script('jquery-form', false, array('jquery'));
172
  wp_enqueue_script('jquery-timepicker', plugin_dir_url(CSCS_FILE) . 'includes/js/jquery.timepicker.min.js', array('jquery'), CSCS_CURRENT_VERSION, true);
173
  wp_enqueue_script('jquery-ui-accordion', false, array('jquery'));
174
  wp_enqueue_script('jquery-ui-datepicker');
175
- wp_enqueue_style('jquery-ui-theme', '//code.jquery.com/ui/1.11.4/themes/flick/jquery-ui.css');
176
  wp_enqueue_script('bootstrap-switch', plugin_dir_url(CSCS_FILE) . 'includes/js/bootstrap-switch.min.js', array('jquery'), CSCS_CURRENT_VERSION, true);
177
  wp_enqueue_script('igniteup', plugin_dir_url(CSCS_FILE) . 'includes/js/main.js', array('jquery', 'wp-color-picker', 'jquery-timepicker'), CSCS_CURRENT_VERSION, true);
178
- wp_enqueue_script('codemirror-main', plugin_dir_url(CSCS_FILE) . 'includes/js/codemirror/codemirror.js', array(), CSCS_CURRENT_VERSION, true);
179
- wp_enqueue_script('codemirror-helper-css', plugin_dir_url(CSCS_FILE) . 'includes/js/codemirror/css.js', array('codemirror-main'), CSCS_CURRENT_VERSION, true);
180
- wp_enqueue_script('codemirror-helper-js', plugin_dir_url(CSCS_FILE) . 'includes/js/codemirror/javascript.js', array('codemirror-main'), CSCS_CURRENT_VERSION, true);
181
- wp_enqueue_script('codemirror-helper-xml', plugin_dir_url(CSCS_FILE) . 'includes/js/codemirror/xml.js', array('codemirror-main'), CSCS_CURRENT_VERSION, true);
182
- wp_enqueue_script('codemirror-helper-html', plugin_dir_url(CSCS_FILE) . 'includes/js/codemirror/htmlmixed.js', array('codemirror-main', 'codemirror-helper-css', 'codemirror-helper-js', 'codemirror-helper-xml'), CSCS_CURRENT_VERSION, true);
183
  wp_enqueue_media();
184
  }
185
  }
@@ -200,8 +195,8 @@ class CSComingSoonCreator
200
  {
201
  if (!isset($_POST['activate_template']) || empty($_POST['activate_template']) || !is_super_admin())
202
  return;
203
- update_option(CSCS_DEFTEMP_OPTION, $_POST['activate_template']);
204
- header('Location: ' . $_SERVER['REQUEST_URI'] . '&activated=yes');
205
  }
206
 
207
  private function getActiveTemplateObject()
@@ -330,15 +325,15 @@ class CSComingSoonCreator
330
 
331
  public function subscribeEmail()
332
  {
333
- $email = isset($_REQUEST['cs_email']) ? trim($_REQUEST['cs_email']) : '';
334
  $errorInput = CSAdminOptions::getDefaultStrings('alert_error_invalid_email');
335
- if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
336
  echo json_encode(array('status' => FALSE, 'error' => TRUE, 'message' => wp_kses_post($errorInput)));
337
  wp_die();
338
  }
339
  $name = '';
340
  if (!empty($_REQUEST['cs_name']))
341
- $name = filter_var($_REQUEST['cs_name'], FILTER_SANITIZE_STRING);
342
 
343
  global $wpdb;
344
  $errorAlreadyExists = CSAdminOptions::getDefaultStrings('alert_error_already_exists');
@@ -358,19 +353,19 @@ class CSComingSoonCreator
358
 
359
  public function sendContactForm()
360
  {
361
- $name = trim($_REQUEST['contact_name']);
362
- $email = trim($_REQUEST['contact_email']);
363
- $subject = isset($_REQUEST['contact_subject']) ? trim($_REQUEST['contact_subject']) : NULL;
364
- $message = trim($_REQUEST['contact_message']);
365
  // Create the email and send the message
366
  $cs_receive_email_addr = CSCS_GENEROPTION_PREFIX . 'receive_email_addr';
367
  $admin_email = get_bloginfo('admin_email');
368
  $to = get_option($cs_receive_email_addr, $admin_email);
369
  $email_subject = sprintf(__('%1$s Sent you a Message via %2$s Contact Form', CSCS_TEXT_DOMAIN), $name, get_bloginfo('name'));
370
- $subjectHTML = isset($subject) ? "<h3>" . nl2br(str_replace("\'", "'", filter_var($subject, FILTER_SANITIZE_STRING))) . "</h3>" : '';
371
  $email_body = "<html><body>" .
372
  $subjectHTML .
373
- "<p>" . nl2br(str_replace("\'", "'", filter_var($message, FILTER_SANITIZE_STRING))) . "</p><hr>" .
374
  "<h4>" . __('This message was sent to you via IgniteUp Contact Form', CSCS_TEXT_DOMAIN) . "</h4>" .
375
  "<p>" . __('Name:', CSCS_TEXT_DOMAIN) . " $name<br>" .
376
  __('Email:', CSCS_TEXT_DOMAIN) . " $email</p>" .
@@ -543,198 +538,196 @@ class CSComingSoonCreator
543
  * Custom CSS and Header scritps field
544
  */
545
  $custom_css = get_option(CSCS_GENEROPTION_PREFIX . 'customcss', '');
546
- ?>
547
- <style>
548
- #wp-admin-bar-igniteup_enabled {
549
- background-color: #C70000 !important;
550
- }
551
-
552
- #wp-admin-bar-igniteup_enabled:hover a {
553
- background: #A20A0A !important;
554
- color: #FFFFFF !important;
555
- }
556
-
557
- body::before {
558
- background: none !important;
559
- }
560
-
561
- <?php echo $custom_css;
562
- ?>
563
- </style>
564
- <?php
565
  }
566
 
567
- /*
568
- *
 
 
 
 
 
 
569
  * WP Head elements for older theme versions
570
- *
571
  */
572
 
573
- public function wpHeadForOldThemes()
574
- {
575
- $favicon_url = get_option(CSCS_GENEROPTION_PREFIX . 'favicon_url');
576
- if (!empty($favicon_url))
577
- echo '<link rel="shortcut icon" href="' . $favicon_url . '" />';
578
- echo '<script type="text/javascript">igniteup_ajaxurl = "' . admin_url('admin-ajax.php') . '";</script>';
579
- }
580
 
581
- /*
582
- *
583
  * Publish footer scripts
584
- *
585
  */
586
 
587
- public function footerScripts()
588
- {
589
- /*
590
  * Do action for template scripts
591
  */
592
 
593
- do_action('igniteup_scripts_' . CSCS_DEFAULT_TEMPLATE);
594
- }
595
 
596
- /*
597
- *
598
  * Enable an admin notice if there are incompatible templates
599
- *
600
  */
601
 
602
- public function noncompatible_theme_notice()
603
- {
604
- if (!CSAdminOptions::getTemplates(TRUE)) //Check if any non-compatible theme exists.
605
- return;
606
- ?>
607
- <div class="error">
608
- <p><?php printf(__('There\'re themes not supporting current IgniteUp version (%1$s). To fix <a href="%2$s">Update IgniteUp</a> now!', CSCS_TEXT_DOMAIN), 'v' . CSCS_CURRENT_VERSION, admin_url('update-core.php')); ?></p>
609
- </div>
610
- <?php
611
- }
612
 
613
- /*
614
- *
615
  * Help page subscription form action
616
- *
617
  */
618
 
619
- public function adminSubscribe()
620
- {
621
- header('Content-type: application/json; charset=utf-8');
622
- $email = $_POST['admin_filled_email'];
623
- $error = FALSE;
624
- $message = '';
625
- if (empty($email)) {
626
- echo json_encode(array('error' => TRUE, 'message' => 'Please provide your email address!'));
627
- wp_die();
628
- }
629
 
630
- if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
631
- echo json_encode(array('error' => TRUE, 'message' => 'Please enter a valid email address!'));
632
- wp_die();
633
- }
634
 
635
- $resp = wp_remote_post(
636
- 'http://getigniteup.com/api/subscribe',
637
- array(
638
- 'body' => array('ignitmailsubscr' => TRUE, 'ignitmailaddress' => $email),
639
- 'timeout' => 20
640
- )
641
- );
642
-
643
- if (is_wp_error($resp)) {
644
- $error = TRUE;
645
- $message = 'Something went wrong. Please try again!';
646
- }
647
 
648
- $curr_user = get_current_user_id();
649
- if (!$error && !empty($curr_user)) {
650
- update_user_meta($curr_user, 'igniteup_admin_subscribed', '1');
651
- }
652
 
653
- echo json_encode(array('error' => $error, 'message' => $message));
654
- wp_die();
 
655
  }
656
 
657
- /*
658
- *
 
 
 
 
659
  * Notify admin about a new subscriber
660
- *
661
  */
662
 
663
- public function notifySubscriber($email, $name = NULL)
664
- {
665
- $cs_receive_email_addr = CSCS_GENEROPTION_PREFIX . 'receive_email_addr';
666
- $admin_email = get_bloginfo('admin_email');
667
- $to = get_option($cs_receive_email_addr, $admin_email);
668
- $email_subject = __("You have a new subscriber!", CSCS_TEXT_DOMAIN);
669
- $email_body = "<html><body>" .
670
- "<h4>" . __('You have a new subscriber to your website via IgniteUp subscribe form.', CSCS_TEXT_DOMAIN) . "</h4>" .
671
- "<p>" . __('Name:', CSCS_TEXT_DOMAIN) . " $name<br>" .
672
- __('Email:', CSCS_TEXT_DOMAIN) . " $email</p>" .
673
- "<p><a href='" . admin_url('admin.php?page=cscs_subscribers') . "'>View all subscribers</a></p>" .
674
- "</body></html>";
675
-
676
- $status = wp_mail($to, $email_subject, $email_body, array("MIME-Version: 1.0", "Content-Type: text/html; charset=UTF-8"));
677
- return $status;
678
- }
679
 
680
- /*
681
- *
 
 
 
 
682
  * Igniteup_head action
683
- *
684
  */
685
 
686
- public static function perfomIgniteUpHead()
687
- {
688
- do_action('igniteup_head');
689
- }
690
 
691
- /*
692
- *
693
  * Igniteup_footer action
694
- *
695
  */
696
 
697
- public static function perfomIgniteUpFooter()
698
- {
699
- do_action('igniteup_footer');
700
- }
701
 
702
- /*
703
- *
704
  * Read theme options
705
- *
706
  */
707
 
708
- public static function igniteUpGetOption($key, $default = NULL)
709
- {
710
- global $the_cs_template_options;
711
- $value = !empty($the_cs_template_options[$key]) ? $the_cs_template_options[$key] : $default;
712
- return $value;
713
- }
714
-
715
- /**
716
- *
717
- * Clean all custom options saved in the database on plugin deactivation
718
- *
719
- */
720
-
721
- public function deactivationCleanp()
722
- {
723
- $temps = CSAdminOptions::getTemplates();
724
- foreach($temps as $temp){
725
- foreach($temp['options'] as $key => $opt){
726
- delete_option(CSCS_TEMPLATEOPTION_PREFIX . $temp['folder_name'] . "_" . $key);
727
- }
728
- }
729
 
730
- foreach(CSAdminOptions::$gener_options as $opt){
731
- delete_option(CSCS_GENEROPTION_PREFIX . $opt);
732
- }
 
 
733
 
734
- foreach(CSAdminOptions::$common_options as $opt){
735
- delete_option(CSCS_GENEROPTION_PREFIX . $opt);
 
 
 
 
736
  }
 
737
 
 
 
 
738
 
 
 
739
  }
740
  }
 
163
  if (isset($_GET['page']) && ($_GET['page'] == 'cscs_options' || $_GET['page'] == 'cscs_subscribers')) {
164
  wp_enqueue_style('wp-color-picker');
165
 
166
+ wp_enqueue_style('codemirror-main', plugin_dir_url(CSCS_FILE) . 'includes/css/codemirror.min.css');
 
167
  wp_enqueue_style('jquery-timepicker-css', plugin_dir_url(CSCS_FILE) . 'includes/css/jquery.timepicker.min.css');
168
+ wp_enqueue_style('jquery-ui-custom', plugin_dir_url(CSCS_FILE) . 'includes/css/jquery-ui.min.css');
169
 
170
+ wp_enqueue_script('jquery');
171
  wp_enqueue_script('jquery-form', false, array('jquery'));
172
  wp_enqueue_script('jquery-timepicker', plugin_dir_url(CSCS_FILE) . 'includes/js/jquery.timepicker.min.js', array('jquery'), CSCS_CURRENT_VERSION, true);
173
  wp_enqueue_script('jquery-ui-accordion', false, array('jquery'));
174
  wp_enqueue_script('jquery-ui-datepicker');
 
175
  wp_enqueue_script('bootstrap-switch', plugin_dir_url(CSCS_FILE) . 'includes/js/bootstrap-switch.min.js', array('jquery'), CSCS_CURRENT_VERSION, true);
176
  wp_enqueue_script('igniteup', plugin_dir_url(CSCS_FILE) . 'includes/js/main.js', array('jquery', 'wp-color-picker', 'jquery-timepicker'), CSCS_CURRENT_VERSION, true);
177
+ wp_enqueue_script('codemirror-main', plugin_dir_url(CSCS_FILE) . 'includes/js/codemirror.min.js', array(), CSCS_CURRENT_VERSION, true);
 
 
 
 
178
  wp_enqueue_media();
179
  }
180
  }
195
  {
196
  if (!isset($_POST['activate_template']) || empty($_POST['activate_template']) || !is_super_admin())
197
  return;
198
+ update_option(CSCS_DEFTEMP_OPTION, sanitize_key($_POST['activate_template']));
199
+ header('Location: ' . sanitize_url($_SERVER['REQUEST_URI'] . '&activated=yes'));
200
  }
201
 
202
  private function getActiveTemplateObject()
325
 
326
  public function subscribeEmail()
327
  {
328
+ $email = sanitize_email(isset($_REQUEST['cs_email']) ? trim($_REQUEST['cs_email']) : '');
329
  $errorInput = CSAdminOptions::getDefaultStrings('alert_error_invalid_email');
330
+ if (empty($email)) {
331
  echo json_encode(array('status' => FALSE, 'error' => TRUE, 'message' => wp_kses_post($errorInput)));
332
  wp_die();
333
  }
334
  $name = '';
335
  if (!empty($_REQUEST['cs_name']))
336
+ $name = sanitize_text_field($_REQUEST['cs_name']);
337
 
338
  global $wpdb;
339
  $errorAlreadyExists = CSAdminOptions::getDefaultStrings('alert_error_already_exists');
353
 
354
  public function sendContactForm()
355
  {
356
+ $name = sanitize_text_field($_REQUEST['contact_name']);
357
+ $email = sanitize_email($_REQUEST['contact_email']);
358
+ $subject = sanitize_text_field($_REQUEST['contact_subject']) ? trim($_REQUEST['contact_subject']) : NULL;
359
+ $message = sanitize_textarea_field($_REQUEST['contact_message']);
360
  // Create the email and send the message
361
  $cs_receive_email_addr = CSCS_GENEROPTION_PREFIX . 'receive_email_addr';
362
  $admin_email = get_bloginfo('admin_email');
363
  $to = get_option($cs_receive_email_addr, $admin_email);
364
  $email_subject = sprintf(__('%1$s Sent you a Message via %2$s Contact Form', CSCS_TEXT_DOMAIN), $name, get_bloginfo('name'));
365
+ $subjectHTML = isset($subject) ? "<h3>" . nl2br(str_replace("\'", "'", $subject)) . "</h3>" : '';
366
  $email_body = "<html><body>" .
367
  $subjectHTML .
368
+ "<p>" . nl2br($message) . "</p><hr>" .
369
  "<h4>" . __('This message was sent to you via IgniteUp Contact Form', CSCS_TEXT_DOMAIN) . "</h4>" .
370
  "<p>" . __('Name:', CSCS_TEXT_DOMAIN) . " $name<br>" .
371
  __('Email:', CSCS_TEXT_DOMAIN) . " $email</p>" .
538
  * Custom CSS and Header scritps field
539
  */
540
  $custom_css = get_option(CSCS_GENEROPTION_PREFIX . 'customcss', '');
541
+ ?>
542
+ <style>
543
+ #wp-admin-bar-igniteup_enabled {
544
+ background-color: #C70000 !important;
545
+ }
546
+
547
+ #wp-admin-bar-igniteup_enabled:hover a {
548
+ background: #A20A0A !important;
549
+ color: #FFFFFF !important;
550
+ }
551
+
552
+ body::before {
553
+ background: none !important;
 
 
 
 
 
 
554
  }
555
 
556
+ <?php echo $custom_css;
557
+ ?>
558
+ </style>
559
+ <?php
560
+ }
561
+
562
+ /*
563
+ *
564
  * WP Head elements for older theme versions
565
+ *
566
  */
567
 
568
+ public function wpHeadForOldThemes()
569
+ {
570
+ $favicon_url = get_option(CSCS_GENEROPTION_PREFIX . 'favicon_url');
571
+ if (!empty($favicon_url))
572
+ echo '<link rel="shortcut icon" href="' . esc_url($favicon_url) . '" />';
573
+ echo '<script type="text/javascript">igniteup_ajaxurl = "' . admin_url('admin-ajax.php') . '";</script>';
574
+ }
575
 
576
+ /*
577
+ *
578
  * Publish footer scripts
579
+ *
580
  */
581
 
582
+ public function footerScripts()
583
+ {
584
+ /*
585
  * Do action for template scripts
586
  */
587
 
588
+ do_action('igniteup_scripts_' . CSCS_DEFAULT_TEMPLATE);
589
+ }
590
 
591
+ /*
592
+ *
593
  * Enable an admin notice if there are incompatible templates
594
+ *
595
  */
596
 
597
+ public function noncompatible_theme_notice()
598
+ {
599
+ if (!CSAdminOptions::getTemplates(TRUE)) //Check if any non-compatible theme exists.
600
+ return;
601
+ ?>
602
+ <div class="error">
603
+ <p><?php printf(__('There\'re themes not supporting current IgniteUp version (%1$s). To fix <a href="%2$s">Update IgniteUp</a> now!', CSCS_TEXT_DOMAIN), 'v' . CSCS_CURRENT_VERSION, admin_url('update-core.php')); ?></p>
604
+ </div>
605
+ <?php
606
+ }
607
 
608
+ /*
609
+ *
610
  * Help page subscription form action
611
+ *
612
  */
613
 
614
+ public function adminSubscribe()
615
+ {
616
+ header('Content-type: application/json; charset=utf-8');
617
+ $email = sanitize_email($_POST['admin_filled_email']);
618
+ $error = FALSE;
619
+ $message = '';
620
+ if (empty($email)) {
621
+ echo json_encode(array('error' => TRUE, 'message' => 'Please provide your email address!'));
622
+ wp_die();
623
+ }
624
 
625
+ if (!filter_var($email, FILTER_VALIDATE_EMAIL)) {
626
+ echo json_encode(array('error' => TRUE, 'message' => 'Please enter a valid email address!'));
627
+ wp_die();
628
+ }
629
 
630
+ $resp = wp_remote_post(
631
+ 'http://getigniteup.com/api/subscribe',
632
+ array(
633
+ 'body' => array('ignitmailsubscr' => TRUE, 'ignitmailaddress' => $email),
634
+ 'timeout' => 20
635
+ )
636
+ );
 
 
 
 
 
637
 
638
+ if (is_wp_error($resp)) {
639
+ $error = TRUE;
640
+ $message = 'Something went wrong. Please try again!';
641
+ }
642
 
643
+ $curr_user = get_current_user_id();
644
+ if (!$error && !empty($curr_user)) {
645
+ update_user_meta($curr_user, 'igniteup_admin_subscribed', '1');
646
  }
647
 
648
+ echo json_encode(array('error' => $error, 'message' => $message));
649
+ wp_die();
650
+ }
651
+
652
+ /*
653
+ *
654
  * Notify admin about a new subscriber
655
+ *
656
  */
657
 
658
+ public function notifySubscriber($email, $name = NULL)
659
+ {
660
+ $cs_receive_email_addr = CSCS_GENEROPTION_PREFIX . 'receive_email_addr';
661
+ $admin_email = get_bloginfo('admin_email');
662
+ $to = get_option($cs_receive_email_addr, $admin_email);
663
+ $email_subject = __("You have a new subscriber!", CSCS_TEXT_DOMAIN);
664
+ $email_body = "<html><body>" .
665
+ "<h4>" . __('You have a new subscriber to your website via IgniteUp subscribe form.', CSCS_TEXT_DOMAIN) . "</h4>" .
666
+ "<p>" . __('Name:', CSCS_TEXT_DOMAIN) . " $name<br>" .
667
+ __('Email:', CSCS_TEXT_DOMAIN) . " $email</p>" .
668
+ "<p><a href='" . admin_url('admin.php?page=cscs_subscribers') . "'>View all subscribers</a></p>" .
669
+ "</body></html>";
 
 
 
 
670
 
671
+ $status = wp_mail($to, $email_subject, $email_body, array("MIME-Version: 1.0", "Content-Type: text/html; charset=UTF-8"));
672
+ return $status;
673
+ }
674
+
675
+ /*
676
+ *
677
  * Igniteup_head action
678
+ *
679
  */
680
 
681
+ public static function perfomIgniteUpHead()
682
+ {
683
+ do_action('igniteup_head');
684
+ }
685
 
686
+ /*
687
+ *
688
  * Igniteup_footer action
689
+ *
690
  */
691
 
692
+ public static function perfomIgniteUpFooter()
693
+ {
694
+ do_action('igniteup_footer');
695
+ }
696
 
697
+ /*
698
+ *
699
  * Read theme options
700
+ *
701
  */
702
 
703
+ public static function igniteUpGetOption($key, $default = NULL)
704
+ {
705
+ global $the_cs_template_options;
706
+ $value = !empty($the_cs_template_options[$key]) ? $the_cs_template_options[$key] : $default;
707
+ return $value;
708
+ }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
709
 
710
+ /**
711
+ *
712
+ * Clean all custom options saved in the database on plugin deactivation
713
+ *
714
+ */
715
 
716
+ public function deactivationCleanp()
717
+ {
718
+ $temps = CSAdminOptions::getTemplates();
719
+ foreach ($temps as $temp) {
720
+ foreach ($temp['options'] as $key => $opt) {
721
+ delete_option(CSCS_TEMPLATEOPTION_PREFIX . $temp['folder_name'] . "_" . $key);
722
  }
723
+ }
724
 
725
+ foreach (CSAdminOptions::$gener_options as $opt) {
726
+ delete_option(CSCS_GENEROPTION_PREFIX . $opt);
727
+ }
728
 
729
+ foreach (CSAdminOptions::$common_options as $opt) {
730
+ delete_option(CSCS_GENEROPTION_PREFIX . $opt);
731
  }
732
  }
733
+ }
includes/css/bootstrap-switch.min.css CHANGED
@@ -1,22 +1,10 @@
1
- /* ========================================================================
2
- * bootstrap-switch - v3.3.2
3
- * http://www.bootstrap-switch.org
4
- * ========================================================================
5
- * Copyright 2012-2013 Mattia Larentis
6
- *
7
- * ========================================================================
8
- * Licensed under the Apache License, Version 2.0 (the "License");
9
- * you may not use this file except in compliance with the License.
10
- * You may obtain a copy of the License at
11
- *
12
- * http://www.apache.org/licenses/LICENSE-2.0
13
- *
14
- * Unless required by applicable law or agreed to in writing, software
15
- * distributed under the License is distributed on an "AS IS" BASIS,
16
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17
- * See the License for the specific language governing permissions and
18
- * limitations under the License.
19
- * ========================================================================
20
- */
21
 
22
- .bootstrap-switch{display:inline-block;direction:ltr;cursor:pointer;border-radius:4px;border:1px solid #ccc;position:relative;text-align:left;overflow:hidden;line-height:8px;z-index:0;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;vertical-align:middle;-webkit-transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s;-o-transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s;transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s}.bootstrap-switch .bootstrap-switch-container{display:inline-block;top:0;border-radius:4px;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}.bootstrap-switch .bootstrap-switch-handle-off,.bootstrap-switch .bootstrap-switch-handle-on,.bootstrap-switch .bootstrap-switch-label{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;cursor:pointer;display:inline-block!important;height:100%;padding:6px 12px;font-size:14px;line-height:20px}.bootstrap-switch .bootstrap-switch-handle-off,.bootstrap-switch .bootstrap-switch-handle-on{text-align:center;z-index:1}.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-primary,.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-primary{color:#fff;background:#337ab7}.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-info,.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-info{color:#fff;background:#5bc0de}.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-success,.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-success{color:#fff;background:#5cb85c}.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-warning,.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-warning{background:#f0ad4e;color:#fff}.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-danger,.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-danger{color:#fff;background:#d9534f}.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-default,.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-default{color:#000;background:#eee}.bootstrap-switch .bootstrap-switch-label{text-align:center;margin-top:-1px;margin-bottom:-1px;z-index:100;color:#333;background:#fff}.bootstrap-switch .bootstrap-switch-handle-on{border-bottom-left-radius:3px;border-top-left-radius:3px}.bootstrap-switch .bootstrap-switch-handle-off{border-bottom-right-radius:3px;border-top-right-radius:3px}.bootstrap-switch input[type=radio],.bootstrap-switch input[type=checkbox]{position:absolute!important;top:0;left:0;margin:0;z-index:-1;opacity:0;filter:alpha(opacity=0)}.bootstrap-switch.bootstrap-switch-mini .bootstrap-switch-handle-off,.bootstrap-switch.bootstrap-switch-mini .bootstrap-switch-handle-on,.bootstrap-switch.bootstrap-switch-mini .bootstrap-switch-label{padding:1px 5px;font-size:12px;line-height:1.5}.bootstrap-switch.bootstrap-switch-small .bootstrap-switch-handle-off,.bootstrap-switch.bootstrap-switch-small .bootstrap-switch-handle-on,.bootstrap-switch.bootstrap-switch-small .bootstrap-switch-label{padding:5px 10px;font-size:12px;line-height:1.5}.bootstrap-switch.bootstrap-switch-large .bootstrap-switch-handle-off,.bootstrap-switch.bootstrap-switch-large .bootstrap-switch-handle-on,.bootstrap-switch.bootstrap-switch-large .bootstrap-switch-label{padding:6px 16px;font-size:18px;line-height:1.3333333}.bootstrap-switch.bootstrap-switch-disabled,.bootstrap-switch.bootstrap-switch-indeterminate,.bootstrap-switch.bootstrap-switch-readonly{cursor:default!important}.bootstrap-switch.bootstrap-switch-disabled .bootstrap-switch-handle-off,.bootstrap-switch.bootstrap-switch-disabled .bootstrap-switch-handle-on,.bootstrap-switch.bootstrap-switch-disabled .bootstrap-switch-label,.bootstrap-switch.bootstrap-switch-indeterminate .bootstrap-switch-handle-off,.bootstrap-switch.bootstrap-switch-indeterminate .bootstrap-switch-handle-on,.bootstrap-switch.bootstrap-switch-indeterminate .bootstrap-switch-label,.bootstrap-switch.bootstrap-switch-readonly .bootstrap-switch-handle-off,.bootstrap-switch.bootstrap-switch-readonly .bootstrap-switch-handle-on,.bootstrap-switch.bootstrap-switch-readonly .bootstrap-switch-label{opacity:.5;filter:alpha(opacity=50);cursor:default!important}.bootstrap-switch.bootstrap-switch-animate .bootstrap-switch-container{-webkit-transition:margin-left .5s;-o-transition:margin-left .5s;transition:margin-left .5s}.bootstrap-switch.bootstrap-switch-inverse .bootstrap-switch-handle-on{border-radius:0 3px 3px 0}.bootstrap-switch.bootstrap-switch-inverse .bootstrap-switch-handle-off{border-radius:3px 0 0 3px}.bootstrap-switch.bootstrap-switch-focused{border-color:#66afe9;outline:0;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6);box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6)}.bootstrap-switch.bootstrap-switch-inverse.bootstrap-switch-off .bootstrap-switch-label,.bootstrap-switch.bootstrap-switch-on .bootstrap-switch-label{border-bottom-right-radius:3px;border-top-right-radius:3px}.bootstrap-switch.bootstrap-switch-inverse.bootstrap-switch-on .bootstrap-switch-label,.bootstrap-switch.bootstrap-switch-off .bootstrap-switch-label{border-bottom-left-radius:3px;border-top-left-radius:3px}
1
+ /**
2
+ * bootstrap-switch - Turn checkboxes and radio buttons into toggle switches.
3
+ *
4
+ * @version v3.3.5
5
+ * @homepage https://bttstrp.github.io/bootstrap-switch
6
+ * @author Mattia Larentis <mattia@larentis.eu> (http://larentis.eu)
7
+ * @license MIT
8
+ */
 
 
 
 
 
 
 
 
 
 
 
 
9
 
10
+ .bootstrap-switch{display:inline-block;direction:ltr;cursor:pointer;border-radius:4px;border:1px solid #ccc;position:relative;text-align:left;overflow:hidden;line-height:8px;z-index:0;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;vertical-align:middle;-webkit-transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s;-o-transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s;transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s}.bootstrap-switch .bootstrap-switch-container{display:inline-block;top:0;border-radius:4px;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}.bootstrap-switch .bootstrap-switch-handle-off,.bootstrap-switch .bootstrap-switch-handle-on,.bootstrap-switch .bootstrap-switch-label{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;cursor:pointer;display:table-cell;vertical-align:middle;padding:6px 12px;font-size:14px;line-height:20px}.bootstrap-switch .bootstrap-switch-handle-off,.bootstrap-switch .bootstrap-switch-handle-on{text-align:center;z-index:1}.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-primary,.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-primary{color:#fff;background:#337ab7}.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-info,.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-info{color:#fff;background:#5bc0de}.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-success,.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-success{color:#fff;background:#5cb85c}.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-warning,.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-warning{background:#f0ad4e;color:#fff}.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-danger,.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-danger{color:#fff;background:#d9534f}.bootstrap-switch .bootstrap-switch-handle-off.bootstrap-switch-default,.bootstrap-switch .bootstrap-switch-handle-on.bootstrap-switch-default{color:#000;background:#eee}.bootstrap-switch .bootstrap-switch-label{text-align:center;margin-top:-1px;margin-bottom:-1px;z-index:100;color:#333;background:#fff}.bootstrap-switch span::before{content:"\200b"}.bootstrap-switch .bootstrap-switch-handle-on{border-bottom-left-radius:3px;border-top-left-radius:3px}.bootstrap-switch .bootstrap-switch-handle-off{border-bottom-right-radius:3px;border-top-right-radius:3px}.bootstrap-switch input[type=radio],.bootstrap-switch input[type=checkbox]{position:absolute!important;top:0;left:0;margin:0;z-index:-1;opacity:0;filter:alpha(opacity=0);visibility:hidden}.bootstrap-switch.bootstrap-switch-mini .bootstrap-switch-handle-off,.bootstrap-switch.bootstrap-switch-mini .bootstrap-switch-handle-on,.bootstrap-switch.bootstrap-switch-mini .bootstrap-switch-label{padding:1px 5px;font-size:12px;line-height:1.5}.bootstrap-switch.bootstrap-switch-small .bootstrap-switch-handle-off,.bootstrap-switch.bootstrap-switch-small .bootstrap-switch-handle-on,.bootstrap-switch.bootstrap-switch-small .bootstrap-switch-label{padding:5px 10px;font-size:12px;line-height:1.5}.bootstrap-switch.bootstrap-switch-large .bootstrap-switch-handle-off,.bootstrap-switch.bootstrap-switch-large .bootstrap-switch-handle-on,.bootstrap-switch.bootstrap-switch-large .bootstrap-switch-label{padding:6px 16px;font-size:18px;line-height:1.3333333}.bootstrap-switch.bootstrap-switch-disabled,.bootstrap-switch.bootstrap-switch-indeterminate,.bootstrap-switch.bootstrap-switch-readonly{cursor:default!important}.bootstrap-switch.bootstrap-switch-disabled .bootstrap-switch-handle-off,.bootstrap-switch.bootstrap-switch-disabled .bootstrap-switch-handle-on,.bootstrap-switch.bootstrap-switch-disabled .bootstrap-switch-label,.bootstrap-switch.bootstrap-switch-indeterminate .bootstrap-switch-handle-off,.bootstrap-switch.bootstrap-switch-indeterminate .bootstrap-switch-handle-on,.bootstrap-switch.bootstrap-switch-indeterminate .bootstrap-switch-label,.bootstrap-switch.bootstrap-switch-readonly .bootstrap-switch-handle-off,.bootstrap-switch.bootstrap-switch-readonly .bootstrap-switch-handle-on,.bootstrap-switch.bootstrap-switch-readonly .bootstrap-switch-label{opacity:.5;filter:alpha(opacity=50);cursor:default!important}.bootstrap-switch.bootstrap-switch-animate .bootstrap-switch-container{-webkit-transition:margin-left .5s;-o-transition:margin-left .5s;transition:margin-left .5s}.bootstrap-switch.bootstrap-switch-inverse .bootstrap-switch-handle-on{border-radius:0 3px 3px 0}.bootstrap-switch.bootstrap-switch-inverse .bootstrap-switch-handle-off{border-radius:3px 0 0 3px}.bootstrap-switch.bootstrap-switch-focused{border-color:#66afe9;outline:0;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6);box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6)}.bootstrap-switch.bootstrap-switch-inverse.bootstrap-switch-off .bootstrap-switch-label,.bootstrap-switch.bootstrap-switch-on .bootstrap-switch-label{border-bottom-right-radius:3px;border-top-right-radius:3px}.bootstrap-switch.bootstrap-switch-inverse.bootstrap-switch-on .bootstrap-switch-label,.bootstrap-switch.bootstrap-switch-off .bootstrap-switch-label{border-bottom-left-radius:3px;border-top-left-radius:3px}
includes/css/bootstrap.min.css CHANGED
@@ -1,5 +1,6 @@
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
- *//*! normalize.css v3.0.2 | MIT License | git.io/normalize */html{font-family:sans-serif;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}body{margin:0}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{display:block}audio,canvas,progress,video{display:inline-block;vertical-align:baseline}audio:not([controls]){display:none;height:0}[hidden],template{display:none}a{background-color:transparent}a:active,a:hover{outline:0}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:700}dfn{font-style:italic}h1{margin:.67em 0;font-size:2em}mark{color:#000;background:#ff0}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}img{border:0}svg:not(:root){overflow:hidden}figure{margin:1em 40px}hr{height:0;-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box}pre{overflow:auto}code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}button,input,optgroup,select,textarea{margin:0;font:inherit;color:inherit}button{overflow:visible}button,select{text-transform:none}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{padding:0;border:0}input{line-height:normal}input[type=checkbox],input[type=radio]{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;padding:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{height:auto}input[type=search]{-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;-webkit-appearance:textfield}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}fieldset{padding:.35em .625em .75em;margin:0 2px;border:1px solid silver}legend{padding:0;border:0}textarea{overflow:auto}optgroup{font-weight:700}table{border-spacing:0;border-collapse:collapse}td,th{padding:0}/*! Source: https://github.com/h5bp/html5-boilerplate/blob/master/src/css/main.css */@media print{*,:after,:before{color:#000!important;text-shadow:none!important;background:0 0!important;-webkit-box-shadow:none!important;box-shadow:none!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}abbr[title]:after{content:" (" attr(title) ")"}a[href^="javascript:"]:after,a[href^="#"]:after{content:""}blockquote,pre{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}img{max-width:100%!important}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}select{background:#fff!important}.navbar{display:none}.btn>.caret,.dropup>.btn>.caret{border-top-color:#000!important}.label{border:1px solid #000}.table{border-collapse:collapse!important}.table td,.table th{background-color:#fff!important}.table-bordered td,.table-bordered th{border:1px solid #ddd!important}}@font-face{font-family:'Glyphicons Halflings';src:url(../fonts/glyphicons-halflings-regular.eot);src:url(../fonts/glyphicons-halflings-regular.eot?#iefix) format('embedded-opentype'),url(../fonts/glyphicons-halflings-regular.woff2) format('woff2'),url(../fonts/glyphicons-halflings-regular.woff) format('woff'),url(../fonts/glyphicons-halflings-regular.ttf) format('truetype'),url(../fonts/glyphicons-halflings-regular.svg#glyphicons_halflingsregular) format('svg')}.glyphicon{position:relative;top:1px;display:inline-block;font-family:'Glyphicons Halflings';font-style:normal;font-weight:400;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.glyphicon-asterisk:before{content:"\2a"}.glyphicon-plus:before{content:"\2b"}.glyphicon-eur:before,.glyphicon-euro:before{content:"\20ac"}.glyphicon-minus:before{content:"\2212"}.glyphicon-cloud:before{content:"\2601"}.glyphicon-envelope:before{content:"\2709"}.glyphicon-pencil:before{content:"\270f"}.glyphicon-glass:before{content:"\e001"}.glyphicon-music:before{content:"\e002"}.glyphicon-search:before{content:"\e003"}.glyphicon-heart:before{content:"\e005"}.glyphicon-star:before{content:"\e006"}.glyphicon-star-empty:before{content:"\e007"}.glyphicon-user:before{content:"\e008"}.glyphicon-film:before{content:"\e009"}.glyphicon-th-large:before{content:"\e010"}.glyphicon-th:before{content:"\e011"}.glyphicon-th-list:before{content:"\e012"}.glyphicon-ok:before{content:"\e013"}.glyphicon-remove:before{content:"\e014"}.glyphicon-zoom-in:before{content:"\e015"}.glyphicon-zoom-out:before{content:"\e016"}.glyphicon-off:before{content:"\e017"}.glyphicon-signal:before{content:"\e018"}.glyphicon-cog:before{content:"\e019"}.glyphicon-trash:before{content:"\e020"}.glyphicon-home:before{content:"\e021"}.glyphicon-file:before{content:"\e022"}.glyphicon-time:before{content:"\e023"}.glyphicon-road:before{content:"\e024"}.glyphicon-download-alt:before{content:"\e025"}.glyphicon-download:before{content:"\e026"}.glyphicon-upload:before{content:"\e027"}.glyphicon-inbox:before{content:"\e028"}.glyphicon-play-circle:before{content:"\e029"}.glyphicon-repeat:before{content:"\e030"}.glyphicon-refresh:before{content:"\e031"}.glyphicon-list-alt:before{content:"\e032"}.glyphicon-lock:before{content:"\e033"}.glyphicon-flag:before{content:"\e034"}.glyphicon-headphones:before{content:"\e035"}.glyphicon-volume-off:before{content:"\e036"}.glyphicon-volume-down:before{content:"\e037"}.glyphicon-volume-up:before{content:"\e038"}.glyphicon-qrcode:before{content:"\e039"}.glyphicon-barcode:before{content:"\e040"}.glyphicon-tag:before{content:"\e041"}.glyphicon-tags:before{content:"\e042"}.glyphicon-book:before{content:"\e043"}.glyphicon-bookmark:before{content:"\e044"}.glyphicon-print:before{content:"\e045"}.glyphicon-camera:before{content:"\e046"}.glyphicon-font:before{content:"\e047"}.glyphicon-bold:before{content:"\e048"}.glyphicon-italic:before{content:"\e049"}.glyphicon-text-height:before{content:"\e050"}.glyphicon-text-width:before{content:"\e051"}.glyphicon-align-left:before{content:"\e052"}.glyphicon-align-center:before{content:"\e053"}.glyphicon-align-right:before{content:"\e054"}.glyphicon-align-justify:before{content:"\e055"}.glyphicon-list:before{content:"\e056"}.glyphicon-indent-left:before{content:"\e057"}.glyphicon-indent-right:before{content:"\e058"}.glyphicon-facetime-video:before{content:"\e059"}.glyphicon-picture:before{content:"\e060"}.glyphicon-map-marker:before{content:"\e062"}.glyphicon-adjust:before{content:"\e063"}.glyphicon-tint:before{content:"\e064"}.glyphicon-edit:before{content:"\e065"}.glyphicon-share:before{content:"\e066"}.glyphicon-check:before{content:"\e067"}.glyphicon-move:before{content:"\e068"}.glyphicon-step-backward:before{content:"\e069"}.glyphicon-fast-backward:before{content:"\e070"}.glyphicon-backward:before{content:"\e071"}.glyphicon-play:before{content:"\e072"}.glyphicon-pause:before{content:"\e073"}.glyphicon-stop:before{content:"\e074"}.glyphicon-forward:before{content:"\e075"}.glyphicon-fast-forward:before{content:"\e076"}.glyphicon-step-forward:before{content:"\e077"}.glyphicon-eject:before{content:"\e078"}.glyphicon-chevron-left:before{content:"\e079"}.glyphicon-chevron-right:before{content:"\e080"}.glyphicon-plus-sign:before{content:"\e081"}.glyphicon-minus-sign:before{content:"\e082"}.glyphicon-remove-sign:before{content:"\e083"}.glyphicon-ok-sign:before{content:"\e084"}.glyphicon-question-sign:before{content:"\e085"}.glyphicon-info-sign:before{content:"\e086"}.glyphicon-screenshot:before{content:"\e087"}.glyphicon-remove-circle:before{content:"\e088"}.glyphicon-ok-circle:before{content:"\e089"}.glyphicon-ban-circle:before{content:"\e090"}.glyphicon-arrow-left:before{content:"\e091"}.glyphicon-arrow-right:before{content:"\e092"}.glyphicon-arrow-up:before{content:"\e093"}.glyphicon-arrow-down:before{content:"\e094"}.glyphicon-share-alt:before{content:"\e095"}.glyphicon-resize-full:before{content:"\e096"}.glyphicon-resize-small:before{content:"\e097"}.glyphicon-exclamation-sign:before{content:"\e101"}.glyphicon-gift:before{content:"\e102"}.glyphicon-leaf:before{content:"\e103"}.glyphicon-fire:before{content:"\e104"}.glyphicon-eye-open:before{content:"\e105"}.glyphicon-eye-close:before{content:"\e106"}.glyphicon-warning-sign:before{content:"\e107"}.glyphicon-plane:before{content:"\e108"}.glyphicon-calendar:before{content:"\e109"}.glyphicon-random:before{content:"\e110"}.glyphicon-comment:before{content:"\e111"}.glyphicon-magnet:before{content:"\e112"}.glyphicon-chevron-up:before{content:"\e113"}.glyphicon-chevron-down:before{content:"\e114"}.glyphicon-retweet:before{content:"\e115"}.glyphicon-shopping-cart:before{content:"\e116"}.glyphicon-folder-close:before{content:"\e117"}.glyphicon-folder-open:before{content:"\e118"}.glyphicon-resize-vertical:before{content:"\e119"}.glyphicon-resize-horizontal:before{content:"\e120"}.glyphicon-hdd:before{content:"\e121"}.glyphicon-bullhorn:before{content:"\e122"}.glyphicon-bell:before{content:"\e123"}.glyphicon-certificate:before{content:"\e124"}.glyphicon-thumbs-up:before{content:"\e125"}.glyphicon-thumbs-down:before{content:"\e126"}.glyphicon-hand-right:before{content:"\e127"}.glyphicon-hand-left:before{content:"\e128"}.glyphicon-hand-up:before{content:"\e129"}.glyphicon-hand-down:before{content:"\e130"}.glyphicon-circle-arrow-right:before{content:"\e131"}.glyphicon-circle-arrow-left:before{content:"\e132"}.glyphicon-circle-arrow-up:before{content:"\e133"}.glyphicon-circle-arrow-down:before{content:"\e134"}.glyphicon-globe:before{content:"\e135"}.glyphicon-wrench:before{content:"\e136"}.glyphicon-tasks:before{content:"\e137"}.glyphicon-filter:before{content:"\e138"}.glyphicon-briefcase:before{content:"\e139"}.glyphicon-fullscreen:before{content:"\e140"}.glyphicon-dashboard:before{content:"\e141"}.glyphicon-paperclip:before{content:"\e142"}.glyphicon-heart-empty:before{content:"\e143"}.glyphicon-link:before{content:"\e144"}.glyphicon-phone:before{content:"\e145"}.glyphicon-pushpin:before{content:"\e146"}.glyphicon-usd:before{content:"\e148"}.glyphicon-gbp:before{content:"\e149"}.glyphicon-sort:before{content:"\e150"}.glyphicon-sort-by-alphabet:before{content:"\e151"}.glyphicon-sort-by-alphabet-alt:before{content:"\e152"}.glyphicon-sort-by-order:before{content:"\e153"}.glyphicon-sort-by-order-alt:before{content:"\e154"}.glyphicon-sort-by-attributes:before{content:"\e155"}.glyphicon-sort-by-attributes-alt:before{content:"\e156"}.glyphicon-unchecked:before{content:"\e157"}.glyphicon-expand:before{content:"\e158"}.glyphicon-collapse-down:before{content:"\e159"}.glyphicon-collapse-up:before{content:"\e160"}.glyphicon-log-in:before{content:"\e161"}.glyphicon-flash:before{content:"\e162"}.glyphicon-log-out:before{content:"\e163"}.glyphicon-new-window:before{content:"\e164"}.glyphicon-record:before{content:"\e165"}.glyphicon-save:before{content:"\e166"}.glyphicon-open:before{content:"\e167"}.glyphicon-saved:before{content:"\e168"}.glyphicon-import:before{content:"\e169"}.glyphicon-export:before{content:"\e170"}.glyphicon-send:before{content:"\e171"}.glyphicon-floppy-disk:before{content:"\e172"}.glyphicon-floppy-saved:before{content:"\e173"}.glyphicon-floppy-remove:before{content:"\e174"}.glyphicon-floppy-save:before{content:"\e175"}.glyphicon-floppy-open:before{content:"\e176"}.glyphicon-credit-card:before{content:"\e177"}.glyphicon-transfer:before{content:"\e178"}.glyphicon-cutlery:before{content:"\e179"}.glyphicon-header:before{content:"\e180"}.glyphicon-compressed:before{content:"\e181"}.glyphicon-earphone:before{content:"\e182"}.glyphicon-phone-alt:before{content:"\e183"}.glyphicon-tower:before{content:"\e184"}.glyphicon-stats:before{content:"\e185"}.glyphicon-sd-video:before{content:"\e186"}.glyphicon-hd-video:before{content:"\e187"}.glyphicon-subtitles:before{content:"\e188"}.glyphicon-sound-stereo:before{content:"\e189"}.glyphicon-sound-dolby:before{content:"\e190"}.glyphicon-sound-5-1:before{content:"\e191"}.glyphicon-sound-6-1:before{content:"\e192"}.glyphicon-sound-7-1:before{content:"\e193"}.glyphicon-copyright-mark:before{content:"\e194"}.glyphicon-registration-mark:before{content:"\e195"}.glyphicon-cloud-download:before{content:"\e197"}.glyphicon-cloud-upload:before{content:"\e198"}.glyphicon-tree-conifer:before{content:"\e199"}.glyphicon-tree-deciduous:before{content:"\e200"}.glyphicon-cd:before{content:"\e201"}.glyphicon-save-file:before{content:"\e202"}.glyphicon-open-file:before{content:"\e203"}.glyphicon-level-up:before{content:"\e204"}.glyphicon-copy:before{content:"\e205"}.glyphicon-paste:before{content:"\e206"}.glyphicon-alert:before{content:"\e209"}.glyphicon-equalizer:before{content:"\e210"}.glyphicon-king:before{content:"\e211"}.glyphicon-queen:before{content:"\e212"}.glyphicon-pawn:before{content:"\e213"}.glyphicon-bishop:before{content:"\e214"}.glyphicon-knight:before{content:"\e215"}.glyphicon-baby-formula:before{content:"\e216"}.glyphicon-tent:before{content:"\26fa"}.glyphicon-blackboard:before{content:"\e218"}.glyphicon-bed:before{content:"\e219"}.glyphicon-apple:before{content:"\f8ff"}.glyphicon-erase:before{content:"\e221"}.glyphicon-hourglass:before{content:"\231b"}.glyphicon-lamp:before{content:"\e223"}.glyphicon-duplicate:before{content:"\e224"}.glyphicon-piggy-bank:before{content:"\e225"}.glyphicon-scissors:before{content:"\e226"}.glyphicon-bitcoin:before{content:"\e227"}.glyphicon-btc:before{content:"\e227"}.glyphicon-xbt:before{content:"\e227"}.glyphicon-yen:before{content:"\00a5"}.glyphicon-jpy:before{content:"\00a5"}.glyphicon-ruble:before{content:"\20bd"}.glyphicon-rub:before{content:"\20bd"}.glyphicon-scale:before{content:"\e230"}.glyphicon-ice-lolly:before{content:"\e231"}.glyphicon-ice-lolly-tasted:before{content:"\e232"}.glyphicon-education:before{content:"\e233"}.glyphicon-option-horizontal:before{content:"\e234"}.glyphicon-option-vertical:before{content:"\e235"}.glyphicon-menu-hamburger:before{content:"\e236"}.glyphicon-modal-window:before{content:"\e237"}.glyphicon-oil:before{content:"\e238"}.glyphicon-grain:before{content:"\e239"}.glyphicon-sunglasses:before{content:"\e240"}.glyphicon-text-size:before{content:"\e241"}.glyphicon-text-color:before{content:"\e242"}.glyphicon-text-background:before{content:"\e243"}.glyphicon-object-align-top:before{content:"\e244"}.glyphicon-object-align-bottom:before{content:"\e245"}.glyphicon-object-align-horizontal:before{content:"\e246"}.glyphicon-object-align-left:before{content:"\e247"}.glyphicon-object-align-vertical:before{content:"\e248"}.glyphicon-object-align-right:before{content:"\e249"}.glyphicon-triangle-right:before{content:"\e250"}.glyphicon-triangle-left:before{content:"\e251"}.glyphicon-triangle-bottom:before{content:"\e252"}.glyphicon-triangle-top:before{content:"\e253"}.glyphicon-console:before{content:"\e254"}.glyphicon-superscript:before{content:"\e255"}.glyphicon-subscript:before{content:"\e256"}.glyphicon-menu-left:before{content:"\e257"}.glyphicon-menu-right:before{content:"\e258"}.glyphicon-menu-down:before{content:"\e259"}.glyphicon-menu-up:before{content:"\e260"}*{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}:after,:before{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}html{font-size:10px;-webkit-tap-highlight-color:rgba(0,0,0,0)}body{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:14px;line-height:1.42857143;color:#333;background-color:#fff}button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}a{color:#337ab7;text-decoration:none}a:focus,a:hover{color:#23527c;text-decoration:underline}a:focus{outline:thin dotted;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}figure{margin:0}img{vertical-align:middle}.carousel-inner>.item>a>img,.carousel-inner>.item>img,.img-responsive,.thumbnail a>img,.thumbnail>img{display:block;max-width:100%;height:auto}.img-rounded{border-radius:6px}.img-thumbnail{display:inline-block;max-width:100%;height:auto;padding:4px;line-height:1.42857143;background-color:#fff;border:1px solid #ddd;border-radius:4px;-webkit-transition:all .2s ease-in-out;-o-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.img-circle{border-radius:50%}hr{margin-top:20px;margin-bottom:20px;border:0;border-top:1px solid #eee}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;margin:0;overflow:visible;clip:auto}[role=button]{cursor:pointer}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{font-family:inherit;font-weight:500;line-height:1.1;color:inherit}.h1 .small,.h1 small,.h2 .small,.h2 small,.h3 .small,.h3 small,.h4 .small,.h4 small,.h5 .small,.h5 small,.h6 .small,.h6 small,h1 .small,h1 small,h2 .small,h2 small,h3 .small,h3 small,h4 .small,h4 small,h5 .small,h5 small,h6 .small,h6 small{font-weight:400;line-height:1;color:#777}.h1,.h2,.h3,h1,h2,h3{margin-top:20px;margin-bottom:10px}.h1 .small,.h1 small,.h2 .small,.h2 small,.h3 .small,.h3 small,h1 .small,h1 small,h2 .small,h2 small,h3 .small,h3 small{font-size:65%}.h4,.h5,.h6,h4,h5,h6{margin-top:10px;margin-bottom:10px}.h4 .small,.h4 small,.h5 .small,.h5 small,.h6 .small,.h6 small,h4 .small,h4 small,h5 .small,h5 small,h6 .small,h6 small{font-size:75%}.h1,h1{font-size:36px}.h2,h2{font-size:30px}.h3,h3{font-size:24px}.h4,h4{font-size:18px}.h5,h5{font-size:14px}.h6,h6{font-size:12px}p{margin:0 0 10px}.lead{margin-bottom:20px;font-size:16px;font-weight:300;line-height:1.4}@media (min-width:768px){.lead{font-size:21px}}.small,small{font-size:85%}.mark,mark{padding:.2em;background-color:#fcf8e3}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}.text-justify{text-align:justify}.text-nowrap{white-space:nowrap}.text-lowercase{text-transform:lowercase}.text-uppercase{text-transform:uppercase}.text-capitalize{text-transform:capitalize}.text-muted{color:#777}.text-primary{color:#337ab7}a.text-primary:hover{color:#286090}.text-success{color:#3c763d}a.text-success:hover{color:#2b542c}.text-info{color:#31708f}a.text-info:hover{color:#245269}.text-warning{color:#8a6d3b}a.text-warning:hover{color:#66512c}.text-danger{color:#a94442}a.text-danger:hover{color:#843534}.bg-primary{color:#fff;background-color:#337ab7}a.bg-primary:hover{background-color:#286090}.bg-success{background-color:#dff0d8}a.bg-success:hover{background-color:#c1e2b3}.bg-info{background-color:#d9edf7}a.bg-info:hover{background-color:#afd9ee}.bg-warning{background-color:#fcf8e3}a.bg-warning:hover{background-color:#f7ecb5}.bg-danger{background-color:#f2dede}a.bg-danger:hover{background-color:#e4b9b9}.page-header{padding-bottom:9px;margin:40px 0 20px;border-bottom:1px solid #eee}ol,ul{margin-top:0;margin-bottom:10px}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}.list-unstyled{padding-left:0;list-style:none}.list-inline{padding-left:0;margin-left:-5px;list-style:none}.list-inline>li{display:inline-block;padding-right:5px;padding-left:5px}dl{margin-top:0;margin-bottom:20px}dd,dt{line-height:1.42857143}dt{font-weight:700}dd{margin-left:0}@media (min-width:768px){.dl-horizontal dt{float:left;width:160px;overflow:hidden;clear:left;text-align:right;text-overflow:ellipsis;white-space:nowrap}.dl-horizontal dd{margin-left:180px}}abbr[data-original-title],abbr[title]{cursor:help;border-bottom:1px dotted #777}.initialism{font-size:90%;text-transform:uppercase}blockquote{padding:10px 20px;margin:0 0 20px;font-size:17.5px;border-left:5px solid #eee}blockquote ol:last-child,blockquote p:last-child,blockquote ul:last-child{margin-bottom:0}blockquote .small,blockquote footer,blockquote small{display:block;font-size:80%;line-height:1.42857143;color:#777}blockquote .small:before,blockquote footer:before,blockquote small:before{content:'\2014 \00A0'}.blockquote-reverse,blockquote.pull-right{padding-right:15px;padding-left:0;text-align:right;border-right:5px solid #eee;border-left:0}.blockquote-reverse .small:before,.blockquote-reverse footer:before,.blockquote-reverse small:before,blockquote.pull-right .small:before,blockquote.pull-right footer:before,blockquote.pull-right small:before{content:''}.blockquote-reverse .small:after,.blockquote-reverse footer:after,.blockquote-reverse small:after,blockquote.pull-right .small:after,blockquote.pull-right footer:after,blockquote.pull-right small:after{content:'\00A0 \2014'}address{margin-bottom:20px;font-style:normal;line-height:1.42857143}code,kbd,pre,samp{font-family:Menlo,Monaco,Consolas,"Courier New",monospace}code{padding:2px 4px;font-size:90%;color:#c7254e;background-color:#f9f2f4;border-radius:4px}kbd{padding:2px 4px;font-size:90%;color:#fff;background-color:#333;border-radius:3px;-webkit-box-shadow:inset 0 -1px 0 rgba(0,0,0,.25);box-shadow:inset 0 -1px 0 rgba(0,0,0,.25)}kbd kbd{padding:0;font-size:100%;font-weight:700;-webkit-box-shadow:none;box-shadow:none}pre{display:block;padding:9.5px;margin:0 0 10px;font-size:13px;line-height:1.42857143;color:#333;word-break:break-all;word-wrap:break-word;background-color:#f5f5f5;border:1px solid #ccc;border-radius:4px}pre code{padding:0;font-size:inherit;color:inherit;white-space:pre-wrap;background-color:transparent;border-radius:0}.pre-scrollable{max-height:340px;overflow-y:scroll}.container{padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}@media (min-width:768px){.container{width:750px}}@media (min-width:992px){.container{width:970px}}@media (min-width:1200px){.container{width:1170px}}.container-fluid{padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}.row{margin-right:-15px;margin-left:-15px}.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9,.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9,.col-xs-1,.col-xs-10,.col-xs-11,.col-xs-12,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9{position:relative;min-height:1px;padding-right:15px;padding-left:15px}.col-xs-1,.col-xs-10,.col-xs-11,.col-xs-12,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9{float:left}.col-xs-12{width:100%}.col-xs-11{width:91.66666667%}.col-xs-10{width:83.33333333%}.col-xs-9{width:75%}.col-xs-8{width:66.66666667%}.col-xs-7{width:58.33333333%}.col-xs-6{width:50%}.col-xs-5{width:41.66666667%}.col-xs-4{width:33.33333333%}.col-xs-3{width:25%}.col-xs-2{width:16.66666667%}.col-xs-1{width:8.33333333%}.col-xs-pull-12{right:100%}.col-xs-pull-11{right:91.66666667%}.col-xs-pull-10{right:83.33333333%}.col-xs-pull-9{right:75%}.col-xs-pull-8{right:66.66666667%}.col-xs-pull-7{right:58.33333333%}.col-xs-pull-6{right:50%}.col-xs-pull-5{right:41.66666667%}.col-xs-pull-4{right:33.33333333%}.col-xs-pull-3{right:25%}.col-xs-pull-2{right:16.66666667%}.col-xs-pull-1{right:8.33333333%}.col-xs-pull-0{right:auto}.col-xs-push-12{left:100%}.col-xs-push-11{left:91.66666667%}.col-xs-push-10{left:83.33333333%}.col-xs-push-9{left:75%}.col-xs-push-8{left:66.66666667%}.col-xs-push-7{left:58.33333333%}.col-xs-push-6{left:50%}.col-xs-push-5{left:41.66666667%}.col-xs-push-4{left:33.33333333%}.col-xs-push-3{left:25%}.col-xs-push-2{left:16.66666667%}.col-xs-push-1{left:8.33333333%}.col-xs-push-0{left:auto}.col-xs-offset-12{margin-left:100%}.col-xs-offset-11{margin-left:91.66666667%}.col-xs-offset-10{margin-left:83.33333333%}.col-xs-offset-9{margin-left:75%}.col-xs-offset-8{margin-left:66.66666667%}.col-xs-offset-7{margin-left:58.33333333%}.col-xs-offset-6{margin-left:50%}.col-xs-offset-5{margin-left:41.66666667%}.col-xs-offset-4{margin-left:33.33333333%}.col-xs-offset-3{margin-left:25%}.col-xs-offset-2{margin-left:16.66666667%}.col-xs-offset-1{margin-left:8.33333333%}.col-xs-offset-0{margin-left:0}@media (min-width:768px){.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9{float:left}.col-sm-12{width:100%}.col-sm-11{width:91.66666667%}.col-sm-10{width:83.33333333%}.col-sm-9{width:75%}.col-sm-8{width:66.66666667%}.col-sm-7{width:58.33333333%}.col-sm-6{width:50%}.col-sm-5{width:41.66666667%}.col-sm-4{width:33.33333333%}.col-sm-3{width:25%}.col-sm-2{width:16.66666667%}.col-sm-1{width:8.33333333%}.col-sm-pull-12{right:100%}.col-sm-pull-11{right:91.66666667%}.col-sm-pull-10{right:83.33333333%}.col-sm-pull-9{right:75%}.col-sm-pull-8{right:66.66666667%}.col-sm-pull-7{right:58.33333333%}.col-sm-pull-6{right:50%}.col-sm-pull-5{right:41.66666667%}.col-sm-pull-4{right:33.33333333%}.col-sm-pull-3{right:25%}.col-sm-pull-2{right:16.66666667%}.col-sm-pull-1{right:8.33333333%}.col-sm-pull-0{right:auto}.col-sm-push-12{left:100%}.col-sm-push-11{left:91.66666667%}.col-sm-push-10{left:83.33333333%}.col-sm-push-9{left:75%}.col-sm-push-8{left:66.66666667%}.col-sm-push-7{left:58.33333333%}.col-sm-push-6{left:50%}.col-sm-push-5{left:41.66666667%}.col-sm-push-4{left:33.33333333%}.col-sm-push-3{left:25%}.col-sm-push-2{left:16.66666667%}.col-sm-push-1{left:8.33333333%}.col-sm-push-0{left:auto}.col-sm-offset-12{margin-left:100%}.col-sm-offset-11{margin-left:91.66666667%}.col-sm-offset-10{margin-left:83.33333333%}.col-sm-offset-9{margin-left:75%}.col-sm-offset-8{margin-left:66.66666667%}.col-sm-offset-7{margin-left:58.33333333%}.col-sm-offset-6{margin-left:50%}.col-sm-offset-5{margin-left:41.66666667%}.col-sm-offset-4{margin-left:33.33333333%}.col-sm-offset-3{margin-left:25%}.col-sm-offset-2{margin-left:16.66666667%}.col-sm-offset-1{margin-left:8.33333333%}.col-sm-offset-0{margin-left:0}}@media (min-width:992px){.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9{float:left}.col-md-12{width:100%}.col-md-11{width:91.66666667%}.col-md-10{width:83.33333333%}.col-md-9{width:75%}.col-md-8{width:66.66666667%}.col-md-7{width:58.33333333%}.col-md-6{width:50%}.col-md-5{width:41.66666667%}.col-md-4{width:33.33333333%}.col-md-3{width:25%}.col-md-2{width:16.66666667%}.col-md-1{width:8.33333333%}.col-md-pull-12{right:100%}.col-md-pull-11{right:91.66666667%}.col-md-pull-10{right:83.33333333%}.col-md-pull-9{right:75%}.col-md-pull-8{right:66.66666667%}.col-md-pull-7{right:58.33333333%}.col-md-pull-6{right:50%}.col-md-pull-5{right:41.66666667%}.col-md-pull-4{right:33.33333333%}.col-md-pull-3{right:25%}.col-md-pull-2{right:16.66666667%}.col-md-pull-1{right:8.33333333%}.col-md-pull-0{right:auto}.col-md-push-12{left:100%}.col-md-push-11{left:91.66666667%}.col-md-push-10{left:83.33333333%}.col-md-push-9{left:75%}.col-md-push-8{left:66.66666667%}.col-md-push-7{left:58.33333333%}.col-md-push-6{left:50%}.col-md-push-5{left:41.66666667%}.col-md-push-4{left:33.33333333%}.col-md-push-3{left:25%}.col-md-push-2{left:16.66666667%}.col-md-push-1{left:8.33333333%}.col-md-push-0{left:auto}.col-md-offset-12{margin-left:100%}.col-md-offset-11{margin-left:91.66666667%}.col-md-offset-10{margin-left:83.33333333%}.col-md-offset-9{margin-left:75%}.col-md-offset-8{margin-left:66.66666667%}.col-md-offset-7{margin-left:58.33333333%}.col-md-offset-6{margin-left:50%}.col-md-offset-5{margin-left:41.66666667%}.col-md-offset-4{margin-left:33.33333333%}.col-md-offset-3{margin-left:25%}.col-md-offset-2{margin-left:16.66666667%}.col-md-offset-1{margin-left:8.33333333%}.col-md-offset-0{margin-left:0}}@media (min-width:1200px){.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9{float:left}.col-lg-12{width:100%}.col-lg-11{width:91.66666667%}.col-lg-10{width:83.33333333%}.col-lg-9{width:75%}.col-lg-8{width:66.66666667%}.col-lg-7{width:58.33333333%}.col-lg-6{width:50%}.col-lg-5{width:41.66666667%}.col-lg-4{width:33.33333333%}.col-lg-3{width:25%}.col-lg-2{width:16.66666667%}.col-lg-1{width:8.33333333%}.col-lg-pull-12{right:100%}.col-lg-pull-11{right:91.66666667%}.col-lg-pull-10{right:83.33333333%}.col-lg-pull-9{right:75%}.col-lg-pull-8{right:66.66666667%}.col-lg-pull-7{right:58.33333333%}.col-lg-pull-6{right:50%}.col-lg-pull-5{right:41.66666667%}.col-lg-pull-4{right:33.33333333%}.col-lg-pull-3{right:25%}.col-lg-pull-2{right:16.66666667%}.col-lg-pull-1{right:8.33333333%}.col-lg-pull-0{right:auto}.col-lg-push-12{left:100%}.col-lg-push-11{left:91.66666667%}.col-lg-push-10{left:83.33333333%}.col-lg-push-9{left:75%}.col-lg-push-8{left:66.66666667%}.col-lg-push-7{left:58.33333333%}.col-lg-push-6{left:50%}.col-lg-push-5{left:41.66666667%}.col-lg-push-4{left:33.33333333%}.col-lg-push-3{left:25%}.col-lg-push-2{left:16.66666667%}.col-lg-push-1{left:8.33333333%}.col-lg-push-0{left:auto}.col-lg-offset-12{margin-left:100%}.col-lg-offset-11{margin-left:91.66666667%}.col-lg-offset-10{margin-left:83.33333333%}.col-lg-offset-9{margin-left:75%}.col-lg-offset-8{margin-left:66.66666667%}.col-lg-offset-7{margin-left:58.33333333%}.col-lg-offset-6{margin-left:50%}.col-lg-offset-5{margin-left:41.66666667%}.col-lg-offset-4{margin-left:33.33333333%}.col-lg-offset-3{margin-left:25%}.col-lg-offset-2{margin-left:16.66666667%}.col-lg-offset-1{margin-left:8.33333333%}.col-lg-offset-0{margin-left:0}}table{background-color:transparent}caption{padding-top:8px;padding-bottom:8px;color:#777;text-align:left}th{text-align:left}.table{width:100%;max-width:100%;margin-bottom:20px}.table>tbody>tr>td,.table>tbody>tr>th,.table>tfoot>tr>td,.table>tfoot>tr>th,.table>thead>tr>td,.table>thead>tr>th{padding:8px;line-height:1.42857143;vertical-align:top;border-top:1px solid #ddd}.table>thead>tr>th{vertical-align:bottom;border-bottom:2px solid #ddd}.table>caption+thead>tr:first-child>td,.table>caption+thead>tr:first-child>th,.table>colgroup+thead>tr:first-child>td,.table>colgroup+thead>tr:first-child>th,.table>thead:first-child>tr:first-child>td,.table>thead:first-child>tr:first-child>th{border-top:0}.table>tbody+tbody{border-top:2px solid #ddd}.table .table{background-color:#fff}.table-condensed>tbody>tr>td,.table-condensed>tbody>tr>th,.table-condensed>tfoot>tr>td,.table-condensed>tfoot>tr>th,.table-condensed>thead>tr>td,.table-condensed>thead>tr>th{padding:5px}.table-bordered{border:1px solid #ddd}.table-bordered>tbody>tr>td,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>td,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border:1px solid #ddd}.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border-bottom-width:2px}.table-striped>tbody>tr:nth-of-type(odd){background-color:#f9f9f9}.table-hover>tbody>tr:hover{background-color:#f5f5f5}table col[class*=col-]{position:static;display:table-column;float:none}table td[class*=col-],table th[class*=col-]{position:static;display:table-cell;float:none}.table>tbody>tr.active>td,.table>tbody>tr.active>th,.table>tbody>tr>td.active,.table>tbody>tr>th.active,.table>tfoot>tr.active>td,.table>tfoot>tr.active>th,.table>tfoot>tr>td.active,.table>tfoot>tr>th.active,.table>thead>tr.active>td,.table>thead>tr.active>th,.table>thead>tr>td.active,.table>thead>tr>th.active{background-color:#f5f5f5}.table-hover>tbody>tr.active:hover>td,.table-hover>tbody>tr.active:hover>th,.table-hover>tbody>tr:hover>.active,.table-hover>tbody>tr>td.active:hover,.table-hover>tbody>tr>th.active:hover{background-color:#e8e8e8}.table>tbody>tr.success>td,.table>tbody>tr.success>th,.table>tbody>tr>td.success,.table>tbody>tr>th.success,.table>tfoot>tr.success>td,.table>tfoot>tr.success>th,.table>tfoot>tr>td.success,.table>tfoot>tr>th.success,.table>thead>tr.success>td,.table>thead>tr.success>th,.table>thead>tr>td.success,.table>thead>tr>th.success{background-color:#dff0d8}.table-hover>tbody>tr.success:hover>td,.table-hover>tbody>tr.success:hover>th,.table-hover>tbody>tr:hover>.success,.table-hover>tbody>tr>td.success:hover,.table-hover>tbody>tr>th.success:hover{background-color:#d0e9c6}.table>tbody>tr.info>td,.table>tbody>tr.info>th,.table>tbody>tr>td.info,.table>tbody>tr>th.info,.table>tfoot>tr.info>td,.table>tfoot>tr.info>th,.table>tfoot>tr>td.info,.table>tfoot>tr>th.info,.table>thead>tr.info>td,.table>thead>tr.info>th,.table>thead>tr>td.info,.table>thead>tr>th.info{background-color:#d9edf7}.table-hover>tbody>tr.info:hover>td,.table-hover>tbody>tr.info:hover>th,.table-hover>tbody>tr:hover>.info,.table-hover>tbody>tr>td.info:hover,.table-hover>tbody>tr>th.info:hover{background-color:#c4e3f3}.table>tbody>tr.warning>td,.table>tbody>tr.warning>th,.table>tbody>tr>td.warning,.table>tbody>tr>th.warning,.table>tfoot>tr.warning>td,.table>tfoot>tr.warning>th,.table>tfoot>tr>td.warning,.table>tfoot>tr>th.warning,.table>thead>tr.warning>td,.table>thead>tr.warning>th,.table>thead>tr>td.warning,.table>thead>tr>th.warning{background-color:#fcf8e3}.table-hover>tbody>tr.warning:hover>td,.table-hover>tbody>tr.warning:hover>th,.table-hover>tbody>tr:hover>.warning,.table-hover>tbody>tr>td.warning:hover,.table-hover>tbody>tr>th.warning:hover{background-color:#faf2cc}.table>tbody>tr.danger>td,.table>tbody>tr.danger>th,.table>tbody>tr>td.danger,.table>tbody>tr>th.danger,.table>tfoot>tr.danger>td,.table>tfoot>tr.danger>th,.table>tfoot>tr>td.danger,.table>tfoot>tr>th.danger,.table>thead>tr.danger>td,.table>thead>tr.danger>th,.table>thead>tr>td.danger,.table>thead>tr>th.danger{background-color:#f2dede}.table-hover>tbody>tr.danger:hover>td,.table-hover>tbody>tr.danger:hover>th,.table-hover>tbody>tr:hover>.danger,.table-hover>tbody>tr>td.danger:hover,.table-hover>tbody>tr>th.danger:hover{background-color:#ebcccc}.table-responsive{min-height:.01%;overflow-x:auto}@media screen and (max-width:767px){.table-responsive{width:100%;margin-bottom:15px;overflow-y:hidden;-ms-overflow-style:-ms-autohiding-scrollbar;border:1px solid #ddd}.table-responsive>.table{margin-bottom:0}.table-responsive>.table>tbody>tr>td,.table-responsive>.table>tbody>tr>th,.table-responsive>.table>tfoot>tr>td,.table-responsive>.table>tfoot>tr>th,.table-responsive>.table>thead>tr>td,.table-responsive>.table>thead>tr>th{white-space:nowrap}.table-responsive>.table-bordered{border:0}.table-responsive>.table-bordered>tbody>tr>td:first-child,.table-responsive>.table-bordered>tbody>tr>th:first-child,.table-responsive>.table-bordered>tfoot>tr>td:first-child,.table-responsive>.table-bordered>tfoot>tr>th:first-child,.table-responsive>.table-bordered>thead>tr>td:first-child,.table-responsive>.table-bordered>thead>tr>th:first-child{border-left:0}.table-responsive>.table-bordered>tbody>tr>td:last-child,.table-responsive>.table-bordered>tbody>tr>th:last-child,.table-responsive>.table-bordered>tfoot>tr>td:last-child,.table-responsive>.table-bordered>tfoot>tr>th:last-child,.table-responsive>.table-bordered>thead>tr>td:last-child,.table-responsive>.table-bordered>thead>tr>th:last-child{border-right:0}.table-responsive>.table-bordered>tbody>tr:last-child>td,.table-responsive>.table-bordered>tbody>tr:last-child>th,.table-responsive>.table-bordered>tfoot>tr:last-child>td,.table-responsive>.table-bordered>tfoot>tr:last-child>th{border-bottom:0}}fieldset{min-width:0;padding:0;margin:0;border:0}legend{display:block;width:100%;padding:0;margin-bottom:20px;font-size:21px;line-height:inherit;color:#333;border:0;border-bottom:1px solid #e5e5e5}label{display:inline-block;max-width:100%;margin-bottom:5px;font-weight:700}input[type=search]{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}input[type=checkbox],input[type=radio]{margin:4px 0 0;margin-top:1px \9;line-height:normal}input[type=file]{display:block}input[type=range]{display:block;width:100%}select[multiple],select[size]{height:auto}input[type=file]:focus,input[type=checkbox]:focus,input[type=radio]:focus{outline:thin dotted;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}output{display:block;padding-top:7px;font-size:14px;line-height:1.42857143;color:#555}.form-control{display:block;width:100%;height:34px;padding:6px 12px;font-size:14px;line-height:1.42857143;color:#555;background-color:#fff;background-image:none;border:1px solid #ccc;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075);-webkit-transition:border-color ease-in-out .15s,-webkit-box-shadow ease-in-out .15s;-o-transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s;transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s}.form-control:focus{border-color:#66afe9;outline:0;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6);box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6)}.form-control::-moz-placeholder{color:#999;opacity:1}.form-control:-ms-input-placeholder{color:#999}.form-control::-webkit-input-placeholder{color:#999}.form-control[disabled],.form-control[readonly],fieldset[disabled] .form-control{background-color:#eee;opacity:1}.form-control[disabled],fieldset[disabled] .form-control{cursor:not-allowed}textarea.form-control{height:auto}input[type=search]{-webkit-appearance:none}@media screen and (-webkit-min-device-pixel-ratio:0){input[type=date],input[type=time],input[type=datetime-local],input[type=month]{line-height:34px}.input-group-sm input[type=date],.input-group-sm input[type=time],.input-group-sm input[type=datetime-local],.input-group-sm input[type=month],input[type=date].input-sm,input[type=time].input-sm,input[type=datetime-local].input-sm,input[type=month].input-sm{line-height:30px}.input-group-lg input[type=date],.input-group-lg input[type=time],.input-group-lg input[type=datetime-local],.input-group-lg input[type=month],input[type=date].input-lg,input[type=time].input-lg,input[type=datetime-local].input-lg,input[type=month].input-lg{line-height:46px}}.form-group{margin-bottom:15px}.checkbox,.radio{position:relative;display:block;margin-top:10px;margin-bottom:10px}.checkbox label,.radio label{min-height:20px;padding-left:20px;margin-bottom:0;font-weight:400;cursor:pointer}.checkbox input[type=checkbox],.checkbox-inline input[type=checkbox],.radio input[type=radio],.radio-inline input[type=radio]{position:absolute;margin-top:4px \9;margin-left:-20px}.checkbox+.checkbox,.radio+.radio{margin-top:-5px}.checkbox-inline,.radio-inline{position:relative;display:inline-block;padding-left:20px;margin-bottom:0;font-weight:400;vertical-align:middle;cursor:pointer}.checkbox-inline+.checkbox-inline,.radio-inline+.radio-inline{margin-top:0;margin-left:10px}fieldset[disabled] input[type=checkbox],fieldset[disabled] input[type=radio],input[type=checkbox].disabled,input[type=checkbox][disabled],input[type=radio].disabled,input[type=radio][disabled]{cursor:not-allowed}.checkbox-inline.disabled,.radio-inline.disabled,fieldset[disabled] .checkbox-inline,fieldset[disabled] .radio-inline{cursor:not-allowed}.checkbox.disabled label,.radio.disabled label,fieldset[disabled] .checkbox label,fieldset[disabled] .radio label{cursor:not-allowed}.form-control-static{min-height:34px;padding-top:7px;padding-bottom:7px;margin-bottom:0}.form-control-static.input-lg,.form-control-static.input-sm{padding-right:0;padding-left:0}.input-sm{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}select.input-sm{height:30px;line-height:30px}select[multiple].input-sm,textarea.input-sm{height:auto}.form-group-sm .form-control{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}select.form-group-sm .form-control{height:30px;line-height:30px}select[multiple].form-group-sm .form-control,textarea.form-group-sm .form-control{height:auto}.form-group-sm .form-control-static{height:30px;min-height:32px;padding:5px 10px;font-size:12px;line-height:1.5}.input-lg{height:46px;padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}select.input-lg{height:46px;line-height:46px}select[multiple].input-lg,textarea.input-lg{height:auto}.form-group-lg .form-control{height:46px;padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}select.form-group-lg .form-control{height:46px;line-height:46px}select[multiple].form-group-lg .form-control,textarea.form-group-lg .form-control{height:auto}.form-group-lg .form-control-static{height:46px;min-height:38px;padding:10px 16px;font-size:18px;line-height:1.3333333}.has-feedback{position:relative}.has-feedback .form-control{padding-right:42.5px}.form-control-feedback{position:absolute;top:0;right:0;z-index:2;display:block;width:34px;height:34px;line-height:34px;text-align:center;pointer-events:none}.input-lg+.form-control-feedback{width:46px;height:46px;line-height:46px}.input-sm+.form-control-feedback{width:30px;height:30px;line-height:30px}.has-success .checkbox,.has-success .checkbox-inline,.has-success .control-label,.has-success .help-block,.has-success .radio,.has-success .radio-inline,.has-success.checkbox label,.has-success.checkbox-inline label,.has-success.radio label,.has-success.radio-inline label{color:#3c763d}.has-success .form-control{border-color:#3c763d;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-success .form-control:focus{border-color:#2b542c;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #67b168;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #67b168}.has-success .input-group-addon{color:#3c763d;background-color:#dff0d8;border-color:#3c763d}.has-success .form-control-feedback{color:#3c763d}.has-warning .checkbox,.has-warning .checkbox-inline,.has-warning .control-label,.has-warning .help-block,.has-warning .radio,.has-warning .radio-inline,.has-warning.checkbox label,.has-warning.checkbox-inline label,.has-warning.radio label,.has-warning.radio-inline label{color:#8a6d3b}.has-warning .form-control{border-color:#8a6d3b;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-warning .form-control:focus{border-color:#66512c;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #c0a16b;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #c0a16b}.has-warning .input-group-addon{color:#8a6d3b;background-color:#fcf8e3;border-color:#8a6d3b}.has-warning .form-control-feedback{color:#8a6d3b}.has-error .checkbox,.has-error .checkbox-inline,.has-error .control-label,.has-error .help-block,.has-error .radio,.has-error .radio-inline,.has-error.checkbox label,.has-error.checkbox-inline label,.has-error.radio label,.has-error.radio-inline label{color:#a94442}.has-error .form-control{border-color:#a94442;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-error .form-control:focus{border-color:#843534;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #ce8483;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #ce8483}.has-error .input-group-addon{color:#a94442;background-color:#f2dede;border-color:#a94442}.has-error .form-control-feedback{color:#a94442}.has-feedback label~.form-control-feedback{top:25px}.has-feedback label.sr-only~.form-control-feedback{top:0}.help-block{display:block;margin-top:5px;margin-bottom:10px;color:#737373}@media (min-width:768px){.form-inline .form-group{display:inline-block;margin-bottom:0;vertical-align:middle}.form-inline .form-control{display:inline-block;width:auto;vertical-align:middle}.form-inline .form-control-static{display:inline-block}.form-inline .input-group{display:inline-table;vertical-align:middle}.form-inline .input-group .form-control,.form-inline .input-group .input-group-addon,.form-inline .input-group .input-group-btn{width:auto}.form-inline .input-group>.form-control{width:100%}.form-inline .control-label{margin-bottom:0;vertical-align:middle}.form-inline .checkbox,.form-inline .radio{display:inline-block;margin-top:0;margin-bottom:0;vertical-align:middle}.form-inline .checkbox label,.form-inline .radio label{padding-left:0}.form-inline .checkbox input[type=checkbox],.form-inline .radio input[type=radio]{position:relative;margin-left:0}.form-inline .has-feedback .form-control-feedback{top:0}}.form-horizontal .checkbox,.form-horizontal .checkbox-inline,.form-horizontal .radio,.form-horizontal .radio-inline{padding-top:7px;margin-top:0;margin-bottom:0}.form-horizontal .checkbox,.form-horizontal .radio{min-height:27px}.form-horizontal .form-group{margin-right:-15px;margin-left:-15px}@media (min-width:768px){.form-horizontal .control-label{padding-top:7px;margin-bottom:0;text-align:right}}.form-horizontal .has-feedback .form-control-feedback{right:15px}@media (min-width:768px){.form-horizontal .form-group-lg .control-label{padding-top:14.33px}}@media (min-width:768px){.form-horizontal .form-group-sm .control-label{padding-top:6px}}.btn{display:inline-block;padding:6px 12px;margin-bottom:0;font-size:14px;font-weight:400;line-height:1.42857143;text-align:center;white-space:nowrap;vertical-align:middle;-ms-touch-action:manipulation;touch-action:manipulation;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-image:none;border:1px solid transparent;border-radius:4px}.btn.active.focus,.btn.active:focus,.btn.focus,.btn:active.focus,.btn:active:focus,.btn:focus{outline:thin dotted;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}.btn.focus,.btn:focus,.btn:hover{color:#333;text-decoration:none}.btn.active,.btn:active{background-image:none;outline:0;-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,.125);box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.btn.disabled,.btn[disabled],fieldset[disabled] .btn{pointer-events:none;cursor:not-allowed;filter:alpha(opacity=65);-webkit-box-shadow:none;box-shadow:none;opacity:.65}.btn-default{color:#333;background-color:#fff;border-color:#ccc}.btn-default.active,.btn-default.focus,.btn-default:active,.btn-default:focus,.btn-default:hover,.open>.dropdown-toggle.btn-default{color:#333;background-color:#e6e6e6;border-color:#adadad}.btn-default.active,.btn-default:active,.open>.dropdown-toggle.btn-default{background-image:none}.btn-default.disabled,.btn-default.disabled.active,.btn-default.disabled.focus,.btn-default.disabled:active,.btn-default.disabled:focus,.btn-default.disabled:hover,.btn-default[disabled],.btn-default[disabled].active,.btn-default[disabled].focus,.btn-default[disabled]:active,.btn-default[disabled]:focus,.btn-default[disabled]:hover,fieldset[disabled] .btn-default,fieldset[disabled] .btn-default.active,fieldset[disabled] .btn-default.focus,fieldset[disabled] .btn-default:active,fieldset[disabled] .btn-default:focus,fieldset[disabled] .btn-default:hover{background-color:#fff;border-color:#ccc}.btn-default .badge{color:#fff;background-color:#333}.btn-primary{color:#fff;background-color:#337ab7;border-color:#2e6da4}.btn-primary.active,.btn-primary.focus,.btn-primary:active,.btn-primary:focus,.btn-primary:hover,.open>.dropdown-toggle.btn-primary{color:#fff;background-color:#286090;border-color:#204d74}.btn-primary.active,.btn-primary:active,.open>.dropdown-toggle.btn-primary{background-image:none}.btn-primary.disabled,.btn-primary.disabled.active,.btn-primary.disabled.focus,.btn-primary.disabled:active,.btn-primary.disabled:focus,.btn-primary.disabled:hover,.btn-primary[disabled],.btn-primary[disabled].active,.btn-primary[disabled].focus,.btn-primary[disabled]:active,.btn-primary[disabled]:focus,.btn-primary[disabled]:hover,fieldset[disabled] .btn-primary,fieldset[disabled] .btn-primary.active,fieldset[disabled] .btn-primary.focus,fieldset[disabled] .btn-primary:active,fieldset[disabled] .btn-primary:focus,fieldset[disabled] .btn-primary:hover{background-color:#337ab7;border-color:#2e6da4}.btn-primary .badge{color:#337ab7;background-color:#fff}.btn-success{color:#fff;background-color:#5cb85c;border-color:#4cae4c}.btn-success.active,.btn-success.focus,.btn-success:active,.btn-success:focus,.btn-success:hover,.open>.dropdown-toggle.btn-success{color:#fff;background-color:#449d44;border-color:#398439}.btn-success.active,.btn-success:active,.open>.dropdown-toggle.btn-success{background-image:none}.btn-success.disabled,.btn-success.disabled.active,.btn-success.disabled.focus,.btn-success.disabled:active,.btn-success.disabled:focus,.btn-success.disabled:hover,.btn-success[disabled],.btn-success[disabled].active,.btn-success[disabled].focus,.btn-success[disabled]:active,.btn-success[disabled]:focus,.btn-success[disabled]:hover,fieldset[disabled] .btn-success,fieldset[disabled] .btn-success.active,fieldset[disabled] .btn-success.focus,fieldset[disabled] .btn-success:active,fieldset[disabled] .btn-success:focus,fieldset[disabled] .btn-success:hover{background-color:#5cb85c;border-color:#4cae4c}.btn-success .badge{color:#5cb85c;background-color:#fff}.btn-info{color:#fff;background-color:#5bc0de;border-color:#46b8da}.btn-info.active,.btn-info.focus,.btn-info:active,.btn-info:focus,.btn-info:hover,.open>.dropdown-toggle.btn-info{color:#fff;background-color:#31b0d5;border-color:#269abc}.btn-info.active,.btn-info:active,.open>.dropdown-toggle.btn-info{background-image:none}.btn-info.disabled,.btn-info.disabled.active,.btn-info.disabled.focus,.btn-info.disabled:active,.btn-info.disabled:focus,.btn-info.disabled:hover,.btn-info[disabled],.btn-info[disabled].active,.btn-info[disabled].focus,.btn-info[disabled]:active,.btn-info[disabled]:focus,.btn-info[disabled]:hover,fieldset[disabled] .btn-info,fieldset[disabled] .btn-info.active,fieldset[disabled] .btn-info.focus,fieldset[disabled] .btn-info:active,fieldset[disabled] .btn-info:focus,fieldset[disabled] .btn-info:hover{background-color:#5bc0de;border-color:#46b8da}.btn-info .badge{color:#5bc0de;background-color:#fff}.btn-warning{color:#fff;background-color:#f0ad4e;border-color:#eea236}.btn-warning.active,.btn-warning.focus,.btn-warning:active,.btn-warning:focus,.btn-warning:hover,.open>.dropdown-toggle.btn-warning{color:#fff;background-color:#ec971f;border-color:#d58512}.btn-warning.active,.btn-warning:active,.open>.dropdown-toggle.btn-warning{background-image:none}.btn-warning.disabled,.btn-warning.disabled.active,.btn-warning.disabled.focus,.btn-warning.disabled:active,.btn-warning.disabled:focus,.btn-warning.disabled:hover,.btn-warning[disabled],.btn-warning[disabled].active,.btn-warning[disabled].focus,.btn-warning[disabled]:active,.btn-warning[disabled]:focus,.btn-warning[disabled]:hover,fieldset[disabled] .btn-warning,fieldset[disabled] .btn-warning.active,fieldset[disabled] .btn-warning.focus,fieldset[disabled] .btn-warning:active,fieldset[disabled] .btn-warning:focus,fieldset[disabled] .btn-warning:hover{background-color:#f0ad4e;border-color:#eea236}.btn-warning .badge{color:#f0ad4e;background-color:#fff}.btn-danger{color:#fff;background-color:#d9534f;border-color:#d43f3a}.btn-danger.active,.btn-danger.focus,.btn-danger:active,.btn-danger:focus,.btn-danger:hover,.open>.dropdown-toggle.btn-danger{color:#fff;background-color:#c9302c;border-color:#ac2925}.btn-danger.active,.btn-danger:active,.open>.dropdown-toggle.btn-danger{background-image:none}.btn-danger.disabled,.btn-danger.disabled.active,.btn-danger.disabled.focus,.btn-danger.disabled:active,.btn-danger.disabled:focus,.btn-danger.disabled:hover,.btn-danger[disabled],.btn-danger[disabled].active,.btn-danger[disabled].focus,.btn-danger[disabled]:active,.btn-danger[disabled]:focus,.btn-danger[disabled]:hover,fieldset[disabled] .btn-danger,fieldset[disabled] .btn-danger.active,fieldset[disabled] .btn-danger.focus,fieldset[disabled] .btn-danger:active,fieldset[disabled] .btn-danger:focus,fieldset[disabled] .btn-danger:hover{background-color:#d9534f;border-color:#d43f3a}.btn-danger .badge{color:#d9534f;background-color:#fff}.btn-link{font-weight:400;color:#337ab7;border-radius:0}.btn-link,.btn-link.active,.btn-link:active,.btn-link[disabled],fieldset[disabled] .btn-link{background-color:transparent;-webkit-box-shadow:none;box-shadow:none}.btn-link,.btn-link:active,.btn-link:focus,.btn-link:hover{border-color:transparent}.btn-link:focus,.btn-link:hover{color:#23527c;text-decoration:underline;background-color:transparent}.btn-link[disabled]:focus,.btn-link[disabled]:hover,fieldset[disabled] .btn-link:focus,fieldset[disabled] .btn-link:hover{color:#777;text-decoration:none}.btn-group-lg>.btn,.btn-lg{padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}.btn-group-sm>.btn,.btn-sm{padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}.btn-group-xs>.btn,.btn-xs{padding:1px 5px;font-size:12px;line-height:1.5;border-radius:3px}.btn-block{display:block;width:100%}.btn-block+.btn-block{margin-top:5px}input[type=button].btn-block,input[type=reset].btn-block,input[type=submit].btn-block{width:100%}.fade{opacity:0;-webkit-transition:opacity .15s linear;-o-transition:opacity .15s linear;transition:opacity .15s linear}.fade.in{opacity:1}.collapse{display:none}.collapse.in{display:block}tr.collapse.in{display:table-row}tbody.collapse.in{display:table-row-group}.collapsing{position:relative;height:0;overflow:hidden;-webkit-transition-timing-function:ease;-o-transition-timing-function:ease;transition-timing-function:ease;-webkit-transition-duration:.35s;-o-transition-duration:.35s;transition-duration:.35s;-webkit-transition-property:height,visibility;-o-transition-property:height,visibility;transition-property:height,visibility}.caret{display:inline-block;width:0;height:0;margin-left:2px;vertical-align:middle;border-top:4px dashed;border-right:4px solid transparent;border-left:4px solid transparent}.dropdown,.dropup{position:relative}.dropdown-toggle:focus{outline:0}.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;float:left;min-width:160px;padding:5px 0;margin:2px 0 0;font-size:14px;text-align:left;list-style:none;background-color:#fff;-webkit-background-clip:padding-box;background-clip:padding-box;border:1px solid #ccc;border:1px solid rgba(0,0,0,.15);border-radius:4px;-webkit-box-shadow:0 6px 12px rgba(0,0,0,.175);box-shadow:0 6px 12px rgba(0,0,0,.175)}.dropdown-menu.pull-right{right:0;left:auto}.dropdown-menu .divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.dropdown-menu>li>a{display:block;padding:3px 20px;clear:both;font-weight:400;line-height:1.42857143;color:#333;white-space:nowrap}.dropdown-menu>li>a:focus,.dropdown-menu>li>a:hover{color:#262626;text-decoration:none;background-color:#f5f5f5}.dropdown-menu>.active>a,.dropdown-menu>.active>a:focus,.dropdown-menu>.active>a:hover{color:#fff;text-decoration:none;background-color:#337ab7;outline:0}.dropdown-menu>.disabled>a,.dropdown-menu>.disabled>a:focus,.dropdown-menu>.disabled>a:hover{color:#777}.dropdown-menu>.disabled>a:focus,.dropdown-menu>.disabled>a:hover{text-decoration:none;cursor:not-allowed;background-color:transparent;background-image:none;filter:progid:DXImageTransform.Microsoft.gradient(enabled=false)}.open>.dropdown-menu{display:block}.open>a{outline:0}.dropdown-menu-right{right:0;left:auto}.dropdown-menu-left{right:auto;left:0}.dropdown-header{display:block;padding:3px 20px;font-size:12px;line-height:1.42857143;color:#777;white-space:nowrap}.dropdown-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:990}.pull-right>.dropdown-menu{right:0;left:auto}.dropup .caret,.navbar-fixed-bottom .dropdown .caret{content:"";border-top:0;border-bottom:4px solid}.dropup .dropdown-menu,.navbar-fixed-bottom .dropdown .dropdown-menu{top:auto;bottom:100%;margin-bottom:2px}@media (min-width:768px){.navbar-right .dropdown-menu{right:0;left:auto}.navbar-right .dropdown-menu-left{right:auto;left:0}}.btn-group,.btn-group-vertical{position:relative;display:inline-block;vertical-align:middle}.btn-group-vertical>.btn,.btn-group>.btn{position:relative;float:left}.btn-group-vertical>.btn.active,.btn-group-vertical>.btn:active,.btn-group-vertical>.btn:focus,.btn-group-vertical>.btn:hover,.btn-group>.btn.active,.btn-group>.btn:active,.btn-group>.btn:focus,.btn-group>.btn:hover{z-index:2}.btn-group .btn+.btn,.btn-group .btn+.btn-group,.btn-group .btn-group+.btn,.btn-group .btn-group+.btn-group{margin-left:-1px}.btn-toolbar{margin-left:-5px}.btn-toolbar .btn-group,.btn-toolbar .input-group{float:left}.btn-toolbar>.btn,.btn-toolbar>.btn-group,.btn-toolbar>.input-group{margin-left:5px}.btn-group>.btn:not(:first-child):not(:last-child):not(.dropdown-toggle){border-radius:0}.btn-group>.btn:first-child{margin-left:0}.btn-group>.btn:first-child:not(:last-child):not(.dropdown-toggle){border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn:last-child:not(:first-child),.btn-group>.dropdown-toggle:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.btn-group>.btn-group{float:left}.btn-group>.btn-group:not(:first-child):not(:last-child)>.btn{border-radius:0}.btn-group>.btn-group:first-child:not(:last-child)>.btn:last-child,.btn-group>.btn-group:first-child:not(:last-child)>.dropdown-toggle{border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn-group:last-child:not(:first-child)>.btn:first-child{border-top-left-radius:0;border-bottom-left-radius:0}.btn-group .dropdown-toggle:active,.btn-group.open .dropdown-toggle{outline:0}.btn-group>.btn+.dropdown-toggle{padding-right:8px;padding-left:8px}.btn-group>.btn-lg+.dropdown-toggle{padding-right:12px;padding-left:12px}.btn-group.open .dropdown-toggle{-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,.125);box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.btn-group.open .dropdown-toggle.btn-link{-webkit-box-shadow:none;box-shadow:none}.btn .caret{margin-left:0}.btn-lg .caret{border-width:5px 5px 0;border-bottom-width:0}.dropup .btn-lg .caret{border-width:0 5px 5px}.btn-group-vertical>.btn,.btn-group-vertical>.btn-group,.btn-group-vertical>.btn-group>.btn{display:block;float:none;width:100%;max-width:100%}.btn-group-vertical>.btn-group>.btn{float:none}.btn-group-vertical>.btn+.btn,.btn-group-vertical>.btn+.btn-group,.btn-group-vertical>.btn-group+.btn,.btn-group-vertical>.btn-group+.btn-group{margin-top:-1px;margin-left:0}.btn-group-vertical>.btn:not(:first-child):not(:last-child){border-radius:0}.btn-group-vertical>.btn:first-child:not(:last-child){border-top-right-radius:4px;border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn:last-child:not(:first-child){border-top-left-radius:0;border-top-right-radius:0;border-bottom-left-radius:4px}.btn-group-vertical>.btn-group:not(:first-child):not(:last-child)>.btn{border-radius:0}.btn-group-vertical>.btn-group:first-child:not(:last-child)>.btn:last-child,.btn-group-vertical>.btn-group:first-child:not(:last-child)>.dropdown-toggle{border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn-group:last-child:not(:first-child)>.btn:first-child{border-top-left-radius:0;border-top-right-radius:0}.btn-group-justified{display:table;width:100%;table-layout:fixed;border-collapse:separate}.btn-group-justified>.btn,.btn-group-justified>.btn-group{display:table-cell;float:none;width:1%}.btn-group-justified>.btn-group .btn{width:100%}.btn-group-justified>.btn-group .dropdown-menu{left:auto}[data-toggle=buttons]>.btn input[type=checkbox],[data-toggle=buttons]>.btn input[type=radio],[data-toggle=buttons]>.btn-group>.btn input[type=checkbox],[data-toggle=buttons]>.btn-group>.btn input[type=radio]{position:absolute;clip:rect(0,0,0,0);pointer-events:none}.input-group{position:relative;display:table;border-collapse:separate}.input-group[class*=col-]{float:none;padding-right:0;padding-left:0}.input-group .form-control{position:relative;z-index:2;float:left;width:100%;margin-bottom:0}.input-group-lg>.form-control,.input-group-lg>.input-group-addon,.input-group-lg>.input-group-btn>.btn{height:46px;padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}select.input-group-lg>.form-control,select.input-group-lg>.input-group-addon,select.input-group-lg>.input-group-btn>.btn{height:46px;line-height:46px}select[multiple].input-group-lg>.form-control,select[multiple].input-group-lg>.input-group-addon,select[multiple].input-group-lg>.input-group-btn>.btn,textarea.input-group-lg>.form-control,textarea.input-group-lg>.input-group-addon,textarea.input-group-lg>.input-group-btn>.btn{height:auto}.input-group-sm>.form-control,.input-group-sm>.input-group-addon,.input-group-sm>.input-group-btn>.btn{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}select.input-group-sm>.form-control,select.input-group-sm>.input-group-addon,select.input-group-sm>.input-group-btn>.btn{height:30px;line-height:30px}select[multiple].input-group-sm>.form-control,select[multiple].input-group-sm>.input-group-addon,select[multiple].input-group-sm>.input-group-btn>.btn,textarea.input-group-sm>.form-control,textarea.input-group-sm>.input-group-addon,textarea.input-group-sm>.input-group-btn>.btn{height:auto}.input-group .form-control,.input-group-addon,.input-group-btn{display:table-cell}.input-group .form-control:not(:first-child):not(:last-child),.input-group-addon:not(:first-child):not(:last-child),.input-group-btn:not(:first-child):not(:last-child){border-radius:0}.input-group-addon,.input-group-btn{width:1%;white-space:nowrap;vertical-align:middle}.input-group-addon{padding:6px 12px;font-size:14px;font-weight:400;line-height:1;color:#555;text-align:center;background-color:#eee;border:1px solid #ccc;border-radius:4px}.input-group-addon.input-sm{padding:5px 10px;font-size:12px;border-radius:3px}.input-group-addon.input-lg{padding:10px 16px;font-size:18px;border-radius:6px}.input-group-addon input[type=checkbox],.input-group-addon input[type=radio]{margin-top:0}.input-group .form-control:first-child,.input-group-addon:first-child,.input-group-btn:first-child>.btn,.input-group-btn:first-child>.btn-group>.btn,.input-group-btn:first-child>.dropdown-toggle,.input-group-btn:last-child>.btn-group:not(:last-child)>.btn,.input-group-btn:last-child>.btn:not(:last-child):not(.dropdown-toggle){border-top-right-radius:0;border-bottom-right-radius:0}.input-group-addon:first-child{border-right:0}.input-group .form-control:last-child,.input-group-addon:last-child,.input-group-btn:first-child>.btn-group:not(:first-child)>.btn,.input-group-btn:first-child>.btn:not(:first-child),.input-group-btn:last-child>.btn,.input-group-btn:last-child>.btn-group>.btn,.input-group-btn:last-child>.dropdown-toggle{border-top-left-radius:0;border-bottom-left-radius:0}.input-group-addon:last-child{border-left:0}.input-group-btn{position:relative;font-size:0;white-space:nowrap}.input-group-btn>.btn{position:relative}.input-group-btn>.btn+.btn{margin-left:-1px}.input-group-btn>.btn:active,.input-group-btn>.btn:focus,.input-group-btn>.btn:hover{z-index:2}.input-group-btn:first-child>.btn,.input-group-btn:first-child>.btn-group{margin-right:-1px}.input-group-btn:last-child>.btn,.input-group-btn:last-child>.btn-group{margin-left:-1px}.nav{padding-left:0;margin-bottom:0;list-style:none}.nav>li{position:relative;display:block}.nav>li>a{position:relative;display:block;padding:10px 15px}.nav>li>a:focus,.nav>li>a:hover{text-decoration:none;background-color:#eee}.nav>li.disabled>a{color:#777}.nav>li.disabled>a:focus,.nav>li.disabled>a:hover{color:#777;text-decoration:none;cursor:not-allowed;background-color:transparent}.nav .open>a,.nav .open>a:focus,.nav .open>a:hover{background-color:#eee;border-color:#337ab7}.nav .nav-divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.nav>li>a>img{max-width:none}.nav-tabs{border-bottom:1px solid #ddd}.nav-tabs>li{float:left;margin-bottom:-1px}.nav-tabs>li>a{margin-right:2px;line-height:1.42857143;border:1px solid transparent;border-radius:4px 4px 0 0}.nav-tabs>li>a:hover{border-color:#eee #eee #ddd}.nav-tabs>li.active>a,.nav-tabs>li.active>a:focus,.nav-tabs>li.active>a:hover{color:#555;cursor:default;background-color:#fff;border:1px solid #ddd;border-bottom-color:transparent}.nav-tabs.nav-justified{width:100%;border-bottom:0}.nav-tabs.nav-justified>li{float:none}.nav-tabs.nav-justified>li>a{margin-bottom:5px;text-align:center}.nav-tabs.nav-justified>.dropdown .dropdown-menu{top:auto;left:auto}@media (min-width:768px){.nav-tabs.nav-justified>li{display:table-cell;width:1%}.nav-tabs.nav-justified>li>a{margin-bottom:0}}.nav-tabs.nav-justified>li>a{margin-right:0;border-radius:4px}.nav-tabs.nav-justified>.active>a,.nav-tabs.nav-justified>.active>a:focus,.nav-tabs.nav-justified>.active>a:hover{border:1px solid #ddd}@media (min-width:768px){.nav-tabs.nav-justified>li>a{border-bottom:1px solid #ddd;border-radius:4px 4px 0 0}.nav-tabs.nav-justified>.active>a,.nav-tabs.nav-justified>.active>a:focus,.nav-tabs.nav-justified>.active>a:hover{border-bottom-color:#fff}}.nav-pills>li{float:left}.nav-pills>li>a{border-radius:4px}.nav-pills>li+li{margin-left:2px}.nav-pills>li.active>a,.nav-pills>li.active>a:focus,.nav-pills>li.active>a:hover{color:#fff;background-color:#337ab7}.nav-stacked>li{float:none}.nav-stacked>li+li{margin-top:2px;margin-left:0}.nav-justified{width:100%}.nav-justified>li{float:none}.nav-justified>li>a{margin-bottom:5px;text-align:center}.nav-justified>.dropdown .dropdown-menu{top:auto;left:auto}@media (min-width:768px){.nav-justified>li{display:table-cell;width:1%}.nav-justified>li>a{margin-bottom:0}}.nav-tabs-justified{border-bottom:0}.nav-tabs-justified>li>a{margin-right:0;border-radius:4px}.nav-tabs-justified>.active>a,.nav-tabs-justified>.active>a:focus,.nav-tabs-justified>.active>a:hover{border:1px solid #ddd}@media (min-width:768px){.nav-tabs-justified>li>a{border-bottom:1px solid #ddd;border-radius:4px 4px 0 0}.nav-tabs-justified>.active>a,.nav-tabs-justified>.active>a:focus,.nav-tabs-justified>.active>a:hover{border-bottom-color:#fff}}.tab-content>.tab-pane{display:none}.tab-content>.active{display:block}.nav-tabs .dropdown-menu{margin-top:-1px;border-top-left-radius:0;border-top-right-radius:0}.navbar{position:relative;min-height:50px;margin-bottom:20px;border:1px solid transparent}@media (min-width:768px){.navbar{border-radius:4px}}@media (min-width:768px){.navbar-header{float:left}}.navbar-collapse{padding-right:15px;padding-left:15px;overflow-x:visible;-webkit-overflow-scrolling:touch;border-top:1px solid transparent;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,.1);box-shadow:inset 0 1px 0 rgba(255,255,255,.1)}.navbar-collapse.in{overflow-y:auto}@media (min-width:768px){.navbar-collapse{width:auto;border-top:0;-webkit-box-shadow:none;box-shadow:none}.navbar-collapse.collapse{display:block!important;height:auto!important;padding-bottom:0;overflow:visible!important}.navbar-collapse.in{overflow-y:visible}.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse,.navbar-static-top .navbar-collapse{padding-right:0;padding-left:0}}.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse{max-height:340px}@media (max-device-width:480px)and (orientation:landscape){.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse{max-height:200px}}.container-fluid>.navbar-collapse,.container-fluid>.navbar-header,.container>.navbar-collapse,.container>.navbar-header{margin-right:-15px;margin-left:-15px}@media (min-width:768px){.container-fluid>.navbar-collapse,.container-fluid>.navbar-header,.container>.navbar-collapse,.container>.navbar-header{margin-right:0;margin-left:0}}.navbar-static-top{z-index:1000;border-width:0 0 1px}@media (min-width:768px){.navbar-static-top{border-radius:0}}.navbar-fixed-bottom,.navbar-fixed-top{position:fixed;right:0;left:0;z-index:1030}@media (min-width:768px){.navbar-fixed-bottom,.navbar-fixed-top{border-radius:0}}.navbar-fixed-top{top:0;border-width:0 0 1px}.navbar-fixed-bottom{bottom:0;margin-bottom:0;border-width:1px 0 0}.navbar-brand{float:left;height:50px;padding:15px 15px;font-size:18px;line-height:20px}.navbar-brand:focus,.navbar-brand:hover{text-decoration:none}.navbar-brand>img{display:block}@media (min-width:768px){.navbar>.container .navbar-brand,.navbar>.container-fluid .navbar-brand{margin-left:-15px}}.navbar-toggle{position:relative;float:right;padding:9px 10px;margin-top:8px;margin-right:15px;margin-bottom:8px;background-color:transparent;background-image:none;border:1px solid transparent;border-radius:4px}.navbar-toggle:focus{outline:0}.navbar-toggle .icon-bar{display:block;width:22px;height:2px;border-radius:1px}.navbar-toggle .icon-bar+.icon-bar{margin-top:4px}@media (min-width:768px){.navbar-toggle{display:none}}.navbar-nav{margin:7.5px -15px}.navbar-nav>li>a{padding-top:10px;padding-bottom:10px;line-height:20px}@media (max-width:767px){.navbar-nav .open .dropdown-menu{position:static;float:none;width:auto;margin-top:0;background-color:transparent;border:0;-webkit-box-shadow:none;box-shadow:none}.navbar-nav .open .dropdown-menu .dropdown-header,.navbar-nav .open .dropdown-menu>li>a{padding:5px 15px 5px 25px}.navbar-nav .open .dropdown-menu>li>a{line-height:20px}.navbar-nav .open .dropdown-menu>li>a:focus,.navbar-nav .open .dropdown-menu>li>a:hover{background-image:none}}@media (min-width:768px){.navbar-nav{float:left;margin:0}.navbar-nav>li{float:left}.navbar-nav>li>a{padding-top:15px;padding-bottom:15px}}.navbar-form{padding:10px 15px;margin-top:8px;margin-right:-15px;margin-bottom:8px;margin-left:-15px;border-top:1px solid transparent;border-bottom:1px solid transparent;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 1px 0 rgba(255,255,255,.1);box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 1px 0 rgba(255,255,255,.1)}@media (min-width:768px){.navbar-form .form-group{display:inline-block;margin-bottom:0;vertical-align:middle}.navbar-form .form-control{display:inline-block;width:auto;vertical-align:middle}.navbar-form .form-control-static{display:inline-block}.navbar-form .input-group{display:inline-table;vertical-align:middle}.navbar-form .input-group .form-control,.navbar-form .input-group .input-group-addon,.navbar-form .input-group .input-group-btn{width:auto}.navbar-form .input-group>.form-control{width:100%}.navbar-form .control-label{margin-bottom:0;vertical-align:middle}.navbar-form .checkbox,.navbar-form .radio{display:inline-block;margin-top:0;margin-bottom:0;vertical-align:middle}.navbar-form .checkbox label,.navbar-form .radio label{padding-left:0}.navbar-form .checkbox input[type=checkbox],.navbar-form .radio input[type=radio]{position:relative;margin-left:0}.navbar-form .has-feedback .form-control-feedback{top:0}}@media (max-width:767px){.navbar-form .form-group{margin-bottom:5px}.navbar-form .form-group:last-child{margin-bottom:0}}@media (min-width:768px){.navbar-form{width:auto;padding-top:0;padding-bottom:0;margin-right:0;margin-left:0;border:0;-webkit-box-shadow:none;box-shadow:none}}.navbar-nav>li>.dropdown-menu{margin-top:0;border-top-left-radius:0;border-top-right-radius:0}.navbar-fixed-bottom .navbar-nav>li>.dropdown-menu{margin-bottom:0;border-top-left-radius:4px;border-top-right-radius:4px;border-bottom-right-radius:0;border-bottom-left-radius:0}.navbar-btn{margin-top:8px;margin-bottom:8px}.navbar-btn.btn-sm{margin-top:10px;margin-bottom:10px}.navbar-btn.btn-xs{margin-top:14px;margin-bottom:14px}.navbar-text{margin-top:15px;margin-bottom:15px}@media (min-width:768px){.navbar-text{float:left;margin-right:15px;margin-left:15px}}@media (min-width:768px){.navbar-left{float:left!important}.navbar-right{float:right!important;margin-right:-15px}.navbar-right~.navbar-right{margin-right:0}}.navbar-default{background-color:#f8f8f8;border-color:#e7e7e7}.navbar-default .navbar-brand{color:#777}.navbar-default .navbar-brand:focus,.navbar-default .navbar-brand:hover{color:#5e5e5e;background-color:transparent}.navbar-default .navbar-text{color:#777}.navbar-default .navbar-nav>li>a{color:#777}.navbar-default .navbar-nav>li>a:focus,.navbar-default .navbar-nav>li>a:hover{color:#333;background-color:transparent}.navbar-default .navbar-nav>.active>a,.navbar-default .navbar-nav>.active>a:focus,.navbar-default .navbar-nav>.active>a:hover{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav>.disabled>a,.navbar-default .navbar-nav>.disabled>a:focus,.navbar-default .navbar-nav>.disabled>a:hover{color:#ccc;background-color:transparent}.navbar-default .navbar-toggle{border-color:#ddd}.navbar-default .navbar-toggle:focus,.navbar-default .navbar-toggle:hover{background-color:#ddd}.navbar-default .navbar-toggle .icon-bar{background-color:#888}.navbar-default .navbar-collapse,.navbar-default .navbar-form{border-color:#e7e7e7}.navbar-default .navbar-nav>.open>a,.navbar-default .navbar-nav>.open>a:focus,.navbar-default .navbar-nav>.open>a:hover{color:#555;background-color:#e7e7e7}@media (max-width:767px){.navbar-default .navbar-nav .open .dropdown-menu>li>a{color:#777}.navbar-default .navbar-nav .open .dropdown-menu>li>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>li>a:hover{color:#333;background-color:transparent}.navbar-default .navbar-nav .open .dropdown-menu>.active>a,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:hover{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:hover{color:#ccc;background-color:transparent}}.navbar-default .navbar-link{color:#777}.navbar-default .navbar-link:hover{color:#333}.navbar-default .btn-link{color:#777}.navbar-default .btn-link:focus,.navbar-default .btn-link:hover{color:#333}.navbar-default .btn-link[disabled]:focus,.navbar-default .btn-link[disabled]:hover,fieldset[disabled] .navbar-default .btn-link:focus,fieldset[disabled] .navbar-default .btn-link:hover{color:#ccc}.navbar-inverse{background-color:#222;border-color:#080808}.navbar-inverse .navbar-brand{color:#9d9d9d}.navbar-inverse .navbar-brand:focus,.navbar-inverse .navbar-brand:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-text{color:#9d9d9d}.navbar-inverse .navbar-nav>li>a{color:#9d9d9d}.navbar-inverse .navbar-nav>li>a:focus,.navbar-inverse .navbar-nav>li>a:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav>.active>a,.navbar-inverse .navbar-nav>.active>a:focus,.navbar-inverse .navbar-nav>.active>a:hover{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav>.disabled>a,.navbar-inverse .navbar-nav>.disabled>a:focus,.navbar-inverse .navbar-nav>.disabled>a:hover{color:#444;background-color:transparent}.navbar-inverse .navbar-toggle{border-color:#333}.navbar-inverse .navbar-toggle:focus,.navbar-inverse .navbar-toggle:hover{background-color:#333}.navbar-inverse .navbar-toggle .icon-bar{background-color:#fff}.navbar-inverse .navbar-collapse,.navbar-inverse .navbar-form{border-color:#101010}.navbar-inverse .navbar-nav>.open>a,.navbar-inverse .navbar-nav>.open>a:focus,.navbar-inverse .navbar-nav>.open>a:hover{color:#fff;background-color:#080808}@media (max-width:767px){.navbar-inverse .navbar-nav .open .dropdown-menu>.dropdown-header{border-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu .divider{background-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a{color:#9d9d9d}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:hover{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:hover{color:#444;background-color:transparent}}.navbar-inverse .navbar-link{color:#9d9d9d}.navbar-inverse .navbar-link:hover{color:#fff}.navbar-inverse .btn-link{color:#9d9d9d}.navbar-inverse .btn-link:focus,.navbar-inverse .btn-link:hover{color:#fff}.navbar-inverse .btn-link[disabled]:focus,.navbar-inverse .btn-link[disabled]:hover,fieldset[disabled] .navbar-inverse .btn-link:focus,fieldset[disabled] .navbar-inverse .btn-link:hover{color:#444}.breadcrumb{padding:8px 15px;margin-bottom:20px;list-style:none;background-color:#f5f5f5;border-radius:4px}.breadcrumb>li{display:inline-block}.breadcrumb>li+li:before{padding:0 5px;color:#ccc;content:"/\00a0"}.breadcrumb>.active{color:#777}.pagination{display:inline-block;padding-left:0;margin:20px 0;border-radius:4px}.pagination>li{display:inline}.pagination>li>a,.pagination>li>span{position:relative;float:left;padding:6px 12px;margin-left:-1px;line-height:1.42857143;color:#337ab7;text-decoration:none;background-color:#fff;border:1px solid #ddd}.pagination>li:first-child>a,.pagination>li:first-child>span{margin-left:0;border-top-left-radius:4px;border-bottom-left-radius:4px}.pagination>li:last-child>a,.pagination>li:last-child>span{border-top-right-radius:4px;border-bottom-right-radius:4px}.pagination>li>a:focus,.pagination>li>a:hover,.pagination>li>span:focus,.pagination>li>span:hover{color:#23527c;background-color:#eee;border-color:#ddd}.pagination>.active>a,.pagination>.active>a:focus,.pagination>.active>a:hover,.pagination>.active>span,.pagination>.active>span:focus,.pagination>.active>span:hover{z-index:2;color:#fff;cursor:default;background-color:#337ab7;border-color:#337ab7}.pagination>.disabled>a,.pagination>.disabled>a:focus,.pagination>.disabled>a:hover,.pagination>.disabled>span,.pagination>.disabled>span:focus,.pagination>.disabled>span:hover{color:#777;cursor:not-allowed;background-color:#fff;border-color:#ddd}.pagination-lg>li>a,.pagination-lg>li>span{padding:10px 16px;font-size:18px}.pagination-lg>li:first-child>a,.pagination-lg>li:first-child>span{border-top-left-radius:6px;border-bottom-left-radius:6px}.pagination-lg>li:last-child>a,.pagination-lg>li:last-child>span{border-top-right-radius:6px;border-bottom-right-radius:6px}.pagination-sm>li>a,.pagination-sm>li>span{padding:5px 10px;font-size:12px}.pagination-sm>li:first-child>a,.pagination-sm>li:first-child>span{border-top-left-radius:3px;border-bottom-left-radius:3px}.pagination-sm>li:last-child>a,.pagination-sm>li:last-child>span{border-top-right-radius:3px;border-bottom-right-radius:3px}.pager{padding-left:0;margin:20px 0;text-align:center;list-style:none}.pager li{display:inline}.pager li>a,.pager li>span{display:inline-block;padding:5px 14px;background-color:#fff;border:1px solid #ddd;border-radius:15px}.pager li>a:focus,.pager li>a:hover{text-decoration:none;background-color:#eee}.pager .next>a,.pager .next>span{float:right}.pager .previous>a,.pager .previous>span{float:left}.pager .disabled>a,.pager .disabled>a:focus,.pager .disabled>a:hover,.pager .disabled>span{color:#777;cursor:not-allowed;background-color:#fff}.label{display:inline;padding:.2em .6em .3em;font-size:75%;font-weight:700;line-height:1;color:#fff;text-align:center;white-space:nowrap;vertical-align:baseline;border-radius:.25em}a.label:focus,a.label:hover{color:#fff;text-decoration:none;cursor:pointer}.label:empty{display:none}.btn .label{position:relative;top:-1px}.label-default{background-color:#777}.label-default[href]:focus,.label-default[href]:hover{background-color:#5e5e5e}.label-primary{background-color:#337ab7}.label-primary[href]:focus,.label-primary[href]:hover{background-color:#286090}.label-success{background-color:#5cb85c}.label-success[href]:focus,.label-success[href]:hover{background-color:#449d44}.label-info{background-color:#5bc0de}.label-info[href]:focus,.label-info[href]:hover{background-color:#31b0d5}.label-warning{background-color:#f0ad4e}.label-warning[href]:focus,.label-warning[href]:hover{background-color:#ec971f}.label-danger{background-color:#d9534f}.label-danger[href]:focus,.label-danger[href]:hover{background-color:#c9302c}.badge{display:inline-block;min-width:10px;padding:3px 7px;font-size:12px;font-weight:700;line-height:1;color:#fff;text-align:center;white-space:nowrap;vertical-align:baseline;background-color:#777;border-radius:10px}.badge:empty{display:none}.btn .badge{position:relative;top:-1px}.btn-group-xs>.btn .badge,.btn-xs .badge{top:0;padding:1px 5px}a.badge:focus,a.badge:hover{color:#fff;text-decoration:none;cursor:pointer}.list-group-item.active>.badge,.nav-pills>.active>a>.badge{color:#337ab7;background-color:#fff}.list-group-item>.badge{float:right}.list-group-item>.badge+.badge{margin-right:5px}.nav-pills>li>a>.badge{margin-left:3px}.jumbotron{padding:30px 15px;margin-bottom:30px;color:inherit;background-color:#eee}.jumbotron .h1,.jumbotron h1{color:inherit}.jumbotron p{margin-bottom:15px;font-size:21px;font-weight:200}.jumbotron>hr{border-top-color:#d5d5d5}.container .jumbotron,.container-fluid .jumbotron{border-radius:6px}.jumbotron .container{max-width:100%}@media screen and (min-width:768px){.jumbotron{padding:48px 0}.container .jumbotron,.container-fluid .jumbotron{padding-right:60px;padding-left:60px}.jumbotron .h1,.jumbotron h1{font-size:63px}}.thumbnail{display:block;padding:4px;margin-bottom:20px;line-height:1.42857143;background-color:#fff;border:1px solid #ddd;border-radius:4px;-webkit-transition:border .2s ease-in-out;-o-transition:border .2s ease-in-out;transition:border .2s ease-in-out}.thumbnail a>img,.thumbnail>img{margin-right:auto;margin-left:auto}a.thumbnail.active,a.thumbnail:focus,a.thumbnail:hover{border-color:#337ab7}.thumbnail .caption{padding:9px;color:#333}.alert{padding:15px;margin-bottom:20px;border:1px solid transparent;border-radius:4px}.alert h4{margin-top:0;color:inherit}.alert .alert-link{font-weight:700}.alert>p,.alert>ul{margin-bottom:0}.alert>p+p{margin-top:5px}.alert-dismissable,.alert-dismissible{padding-right:35px}.alert-dismissable .close,.alert-dismissible .close{position:relative;top:-2px;right:-21px;color:inherit}.alert-success{color:#3c763d;background-color:#dff0d8;border-color:#d6e9c6}.alert-success hr{border-top-color:#c9e2b3}.alert-success .alert-link{color:#2b542c}.alert-info{color:#31708f;background-color:#d9edf7;border-color:#bce8f1}.alert-info hr{border-top-color:#a6e1ec}.alert-info .alert-link{color:#245269}.alert-warning{color:#8a6d3b;background-color:#fcf8e3;border-color:#faebcc}.alert-warning hr{border-top-color:#f7e1b5}.alert-warning .alert-link{color:#66512c}.alert-danger{color:#a94442;background-color:#f2dede;border-color:#ebccd1}.alert-danger hr{border-top-color:#e4b9c0}.alert-danger .alert-link{color:#843534}@-webkit-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-o-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}.progress{height:20px;margin-bottom:20px;overflow:hidden;background-color:#f5f5f5;border-radius:4px;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,.1);box-shadow:inset 0 1px 2px rgba(0,0,0,.1)}.progress-bar{float:left;width:0;height:100%;font-size:12px;line-height:20px;color:#fff;text-align:center;background-color:#337ab7;-webkit-box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);-webkit-transition:width .6s ease;-o-transition:width .6s ease;transition:width .6s ease}.progress-bar-striped,.progress-striped .progress-bar{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);-webkit-background-size:40px 40px;background-size:40px 40px}.progress-bar.active,.progress.active .progress-bar{-webkit-animation:progress-bar-stripes 2s linear infinite;-o-animation:progress-bar-stripes 2s linear infinite;animation:progress-bar-stripes 2s linear infinite}.progress-bar-success{background-color:#5cb85c}.progress-striped .progress-bar-success{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-info{background-color:#5bc0de}.progress-striped .progress-bar-info{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-warning{background-color:#f0ad4e}.progress-striped .progress-bar-warning{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-danger{background-color:#d9534f}.progress-striped .progress-bar-danger{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.media{margin-top:15px}.media:first-child{margin-top:0}.media,.media-body{overflow:hidden;zoom:1}.media-body{width:10000px}.media-object{display:block}.media-right,.media>.pull-right{padding-left:10px}.media-left,.media>.pull-left{padding-right:10px}.media-body,.media-left,.media-right{display:table-cell;vertical-align:top}.media-middle{vertical-align:middle}.media-bottom{vertical-align:bottom}.media-heading{margin-top:0;margin-bottom:5px}.media-list{padding-left:0;list-style:none}.list-group{padding-left:0;margin-bottom:20px}.list-group-item{position:relative;display:block;padding:10px 15px;margin-bottom:-1px;background-color:#fff;border:1px solid #ddd}.list-group-item:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.list-group-item:last-child{margin-bottom:0;border-bottom-right-radius:4px;border-bottom-left-radius:4px}a.list-group-item{color:#555}a.list-group-item .list-group-item-heading{color:#333}a.list-group-item:focus,a.list-group-item:hover{color:#555;text-decoration:none;background-color:#f5f5f5}.list-group-item.disabled,.list-group-item.disabled:focus,.list-group-item.disabled:hover{color:#777;cursor:not-allowed;background-color:#eee}.list-group-item.disabled .list-group-item-heading,.list-group-item.disabled:focus .list-group-item-heading,.list-group-item.disabled:hover .list-group-item-heading{color:inherit}.list-group-item.disabled .list-group-item-text,.list-group-item.disabled:focus .list-group-item-text,.list-group-item.disabled:hover .list-group-item-text{color:#777}.list-group-item.active,.list-group-item.active:focus,.list-group-item.active:hover{z-index:2;color:#fff;background-color:#337ab7;border-color:#337ab7}.list-group-item.active .list-group-item-heading,.list-group-item.active .list-group-item-heading>.small,.list-group-item.active .list-group-item-heading>small,.list-group-item.active:focus .list-group-item-heading,.list-group-item.active:focus .list-group-item-heading>.small,.list-group-item.active:focus .list-group-item-heading>small,.list-group-item.active:hover .list-group-item-heading,.list-group-item.active:hover .list-group-item-heading>.small,.list-group-item.active:hover .list-group-item-heading>small{color:inherit}.list-group-item.active .list-group-item-text,.list-group-item.active:focus .list-group-item-text,.list-group-item.active:hover .list-group-item-text{color:#c7ddef}.list-group-item-success{color:#3c763d;background-color:#dff0d8}a.list-group-item-success{color:#3c763d}a.list-group-item-success .list-group-item-heading{color:inherit}a.list-group-item-success:focus,a.list-group-item-success:hover{color:#3c763d;background-color:#d0e9c6}a.list-group-item-success.active,a.list-group-item-success.active:focus,a.list-group-item-success.active:hover{color:#fff;background-color:#3c763d;border-color:#3c763d}.list-group-item-info{color:#31708f;background-color:#d9edf7}a.list-group-item-info{color:#31708f}a.list-group-item-info .list-group-item-heading{color:inherit}a.list-group-item-info:focus,a.list-group-item-info:hover{color:#31708f;background-color:#c4e3f3}a.list-group-item-info.active,a.list-group-item-info.active:focus,a.list-group-item-info.active:hover{color:#fff;background-color:#31708f;border-color:#31708f}.list-group-item-warning{color:#8a6d3b;background-color:#fcf8e3}a.list-group-item-warning{color:#8a6d3b}a.list-group-item-warning .list-group-item-heading{color:inherit}a.list-group-item-warning:focus,a.list-group-item-warning:hover{color:#8a6d3b;background-color:#faf2cc}a.list-group-item-warning.active,a.list-group-item-warning.active:focus,a.list-group-item-warning.active:hover{color:#fff;background-color:#8a6d3b;border-color:#8a6d3b}.list-group-item-danger{color:#a94442;background-color:#f2dede}a.list-group-item-danger{color:#a94442}a.list-group-item-danger .list-group-item-heading{color:inherit}a.list-group-item-danger:focus,a.list-group-item-danger:hover{color:#a94442;background-color:#ebcccc}a.list-group-item-danger.active,a.list-group-item-danger.active:focus,a.list-group-item-danger.active:hover{color:#fff;background-color:#a94442;border-color:#a94442}.list-group-item-heading{margin-top:0;margin-bottom:5px}.list-group-item-text{margin-bottom:0;line-height:1.3}.panel{margin-bottom:20px;background-color:#fff;border:1px solid transparent;border-radius:4px;-webkit-box-shadow:0 1px 1px rgba(0,0,0,.05);box-shadow:0 1px 1px rgba(0,0,0,.05)}.panel-body{padding:15px}.panel-heading{padding:10px 15px;border-bottom:1px solid transparent;border-top-left-radius:3px;border-top-right-radius:3px}.panel-heading>.dropdown .dropdown-toggle{color:inherit}.panel-title{margin-top:0;margin-bottom:0;font-size:16px;color:inherit}.panel-title>.small,.panel-title>.small>a,.panel-title>a,.panel-title>small,.panel-title>small>a{color:inherit}.panel-footer{padding:10px 15px;background-color:#f5f5f5;border-top:1px solid #ddd;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.list-group,.panel>.panel-collapse>.list-group{margin-bottom:0}.panel>.list-group .list-group-item,.panel>.panel-collapse>.list-group .list-group-item{border-width:1px 0;border-radius:0}.panel>.list-group:first-child .list-group-item:first-child,.panel>.panel-collapse>.list-group:first-child .list-group-item:first-child{border-top:0;border-top-left-radius:3px;border-top-right-radius:3px}.panel>.list-group:last-child .list-group-item:last-child,.panel>.panel-collapse>.list-group:last-child .list-group-item:last-child{border-bottom:0;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel-heading+.list-group .list-group-item:first-child{border-top-width:0}.list-group+.panel-footer{border-top-width:0}.panel>.panel-collapse>.table,.panel>.table,.panel>.table-responsive>.table{margin-bottom:0}.panel>.panel-collapse>.table caption,.panel>.table caption,.panel>.table-responsive>.table caption{padding-right:15px;padding-left:15px}.panel>.table-responsive:first-child>.table:first-child,.panel>.table:first-child{border-top-left-radius:3px;border-top-right-radius:3px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child,.panel>.table:first-child>thead:first-child>tr:first-child{border-top-left-radius:3px;border-top-right-radius:3px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child td:first-child,.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child th:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child td:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child th:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child td:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child th:first-child,.panel>.table:first-child>thead:first-child>tr:first-child td:first-child,.panel>.table:first-child>thead:first-child>tr:first-child th:first-child{border-top-left-radius:3px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child td:last-child,.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child th:last-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child td:last-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child th:last-child,.panel>.table:first-child>tbody:first-child>tr:first-child td:last-child,.panel>.table:first-child>tbody:first-child>tr:first-child th:last-child,.panel>.table:first-child>thead:first-child>tr:first-child td:last-child,.panel>.table:first-child>thead:first-child>tr:first-child th:last-child{border-top-right-radius:3px}.panel>.table-responsive:last-child>.table:last-child,.panel>.table:last-child{border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child{border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child td:first-child,.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child th:first-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child td:first-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child th:first-child,.panel>.table:last-child>tbody:last-child>tr:last-child td:first-child,.panel>.table:last-child>tbody:last-child>tr:last-child th:first-child,.panel>.table:last-child>tfoot:last-child>tr:last-child td:first-child,.panel>.table:last-child>tfoot:last-child>tr:last-child th:first-child{border-bottom-left-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child td:last-child,.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child th:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child td:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child th:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child td:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child th:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child td:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child th:last-child{border-bottom-right-radius:3px}.panel>.panel-body+.table,.panel>.panel-body+.table-responsive,.panel>.table+.panel-body,.panel>.table-responsive+.panel-body{border-top:1px solid #ddd}.panel>.table>tbody:first-child>tr:first-child td,.panel>.table>tbody:first-child>tr:first-child th{border-top:0}.panel>.table-bordered,.panel>.table-responsive>.table-bordered{border:0}.panel>.table-bordered>tbody>tr>td:first-child,.panel>.table-bordered>tbody>tr>th:first-child,.panel>.table-bordered>tfoot>tr>td:first-child,.panel>.table-bordered>tfoot>tr>th:first-child,.panel>.table-bordered>thead>tr>td:first-child,.panel>.table-bordered>thead>tr>th:first-child,.panel>.table-responsive>.table-bordered>tbody>tr>td:first-child,.panel>.table-responsive>.table-bordered>tbody>tr>th:first-child,.panel>.table-responsive>.table-bordered>tfoot>tr>td:first-child,.panel>.table-responsive>.table-bordered>tfoot>tr>th:first-child,.panel>.table-responsive>.table-bordered>thead>tr>td:first-child,.panel>.table-responsive>.table-bordered>thead>tr>th:first-child{border-left:0}.panel>.table-bordered>tbody>tr>td:last-child,.panel>.table-bordered>tbody>tr>th:last-child,.panel>.table-bordered>tfoot>tr>td:last-child,.panel>.table-bordered>tfoot>tr>th:last-child,.panel>.table-bordered>thead>tr>td:last-child,.panel>.table-bordered>thead>tr>th:last-child,.panel>.table-responsive>.table-bordered>tbody>tr>td:last-child,.panel>.table-responsive>.table-bordered>tbody>tr>th:last-child,.panel>.table-responsive>.table-bordered>tfoot>tr>td:last-child,.panel>.table-responsive>.table-bordered>tfoot>tr>th:last-child,.panel>.table-responsive>.table-bordered>thead>tr>td:last-child,.panel>.table-responsive>.table-bordered>thead>tr>th:last-child{border-right:0}.panel>.table-bordered>tbody>tr:first-child>td,.panel>.table-bordered>tbody>tr:first-child>th,.panel>.table-bordered>thead>tr:first-child>td,.panel>.table-bordered>thead>tr:first-child>th,.panel>.table-responsive>.table-bordered>tbody>tr:first-child>td,.panel>.table-responsive>.table-bordered>tbody>tr:first-child>th,.panel>.table-responsive>.table-bordered>thead>tr:first-child>td,.panel>.table-responsive>.table-bordered>thead>tr:first-child>th{border-bottom:0}.panel>.table-bordered>tbody>tr:last-child>td,.panel>.table-bordered>tbody>tr:last-child>th,.panel>.table-bordered>tfoot>tr:last-child>td,.panel>.table-bordered>tfoot>tr:last-child>th,.panel>.table-responsive>.table-bordered>tbody>tr:last-child>td,.panel>.table-responsive>.table-bordered>tbody>tr:last-child>th,.panel>.table-responsive>.table-bordered>tfoot>tr:last-child>td,.panel>.table-responsive>.table-bordered>tfoot>tr:last-child>th{border-bottom:0}.panel>.table-responsive{margin-bottom:0;border:0}.panel-group{margin-bottom:20px}.panel-group .panel{margin-bottom:0;border-radius:4px}.panel-group .panel+.panel{margin-top:5px}.panel-group .panel-heading{border-bottom:0}.panel-group .panel-heading+.panel-collapse>.list-group,.panel-group .panel-heading+.panel-collapse>.panel-body{border-top:1px solid #ddd}.panel-group .panel-footer{border-top:0}.panel-group .panel-footer+.panel-collapse .panel-body{border-bottom:1px solid #ddd}.panel-default{border-color:#ddd}.panel-default>.panel-heading{color:#333;background-color:#f5f5f5;border-color:#ddd}.panel-default>.panel-heading+.panel-collapse>.panel-body{border-top-color:#ddd}.panel-default>.panel-heading .badge{color:#f5f5f5;background-color:#333}.panel-default>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#ddd}.panel-primary{border-color:#337ab7}.panel-primary>.panel-heading{color:#fff;background-color:#337ab7;border-color:#337ab7}.panel-primary>.panel-heading+.panel-collapse>.panel-body{border-top-color:#337ab7}.panel-primary>.panel-heading .badge{color:#337ab7;background-color:#fff}.panel-primary>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#337ab7}.panel-success{border-color:#d6e9c6}.panel-success>.panel-heading{color:#3c763d;background-color:#dff0d8;border-color:#d6e9c6}.panel-success>.panel-heading+.panel-collapse>.panel-body{border-top-color:#d6e9c6}.panel-success>.panel-heading .badge{color:#dff0d8;background-color:#3c763d}.panel-success>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#d6e9c6}.panel-info{border-color:#bce8f1}.panel-info>.panel-heading{color:#31708f;background-color:#d9edf7;border-color:#bce8f1}.panel-info>.panel-heading+.panel-collapse>.panel-body{border-top-color:#bce8f1}.panel-info>.panel-heading .badge{color:#d9edf7;background-color:#31708f}.panel-info>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#bce8f1}.panel-warning{border-color:#faebcc}.panel-warning>.panel-heading{color:#8a6d3b;background-color:#fcf8e3;border-color:#faebcc}.panel-warning>.panel-heading+.panel-collapse>.panel-body{border-top-color:#faebcc}.panel-warning>.panel-heading .badge{color:#fcf8e3;background-color:#8a6d3b}.panel-warning>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#faebcc}.panel-danger{border-color:#ebccd1}.panel-danger>.panel-heading{color:#a94442;background-color:#f2dede;border-color:#ebccd1}.panel-danger>.panel-heading+.panel-collapse>.panel-body{border-top-color:#ebccd1}.panel-danger>.panel-heading .badge{color:#f2dede;background-color:#a94442}.panel-danger>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#ebccd1}.embed-responsive{position:relative;display:block;height:0;padding:0;overflow:hidden}.embed-responsive .embed-responsive-item,.embed-responsive embed,.embed-responsive iframe,.embed-responsive object,.embed-responsive video{position:absolute;top:0;bottom:0;left:0;width:100%;height:100%;border:0}.embed-responsive-16by9{padding-bottom:56.25%}.embed-responsive-4by3{padding-bottom:75%}.well{min-height:20px;padding:19px;margin-bottom:20px;background-color:#f5f5f5;border:1px solid #e3e3e3;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.05);box-shadow:inset 0 1px 1px rgba(0,0,0,.05)}.well blockquote{border-color:#ddd;border-color:rgba(0,0,0,.15)}.well-lg{padding:24px;border-radius:6px}.well-sm{padding:9px;border-radius:3px}.close{float:right;font-size:21px;font-weight:700;line-height:1;color:#000;text-shadow:0 1px 0 #fff;filter:alpha(opacity=20);opacity:.2}.close:focus,.close:hover{color:#000;text-decoration:none;cursor:pointer;filter:alpha(opacity=50);opacity:.5}button.close{-webkit-appearance:none;padding:0;cursor:pointer;background:0 0;border:0}.modal-open{overflow:hidden}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1050;display:none;overflow:hidden;-webkit-overflow-scrolling:touch;outline:0}.modal.fade .modal-dialog{-webkit-transition:-webkit-transform .3s ease-out;-o-transition:-o-transform .3s ease-out;transition:transform .3s ease-out;-webkit-transform:translate(0,-25%);-ms-transform:translate(0,-25%);-o-transform:translate(0,-25%);transform:translate(0,-25%)}.modal.in .modal-dialog{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);-o-transform:translate(0,0);transform:translate(0,0)}.modal-open .modal{overflow-x:hidden;overflow-y:auto}.modal-dialog{position:relative;width:auto;margin:10px}.modal-content{position:relative;background-color:#fff;-webkit-background-clip:padding-box;background-clip:padding-box;border:1px solid #999;border:1px solid rgba(0,0,0,.2);border-radius:6px;outline:0;-webkit-box-shadow:0 3px 9px rgba(0,0,0,.5);box-shadow:0 3px 9px rgba(0,0,0,.5)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1040;background-color:#000}.modal-backdrop.fade{filter:alpha(opacity=0);opacity:0}.modal-backdrop.in{filter:alpha(opacity=50);opacity:.5}.modal-header{min-height:16.43px;padding:15px;border-bottom:1px solid #e5e5e5}.modal-header .close{margin-top:-2px}.modal-title{margin:0;line-height:1.42857143}.modal-body{position:relative;padding:15px}.modal-footer{padding:15px;text-align:right;border-top:1px solid #e5e5e5}.modal-footer .btn+.btn{margin-bottom:0;margin-left:5px}.modal-footer .btn-group .btn+.btn{margin-left:-1px}.modal-footer .btn-block+.btn-block{margin-left:0}.modal-scrollbar-measure{position:absolute;top:-9999px;width:50px;height:50px;overflow:scroll}@media (min-width:768px){.modal-dialog{width:600px;margin:30px auto}.modal-content{-webkit-box-shadow:0 5px 15px rgba(0,0,0,.5);box-shadow:0 5px 15px rgba(0,0,0,.5)}.modal-sm{width:300px}}@media (min-width:992px){.modal-lg{width:900px}}.tooltip{position:absolute;z-index:1070;display:block;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:12px;font-weight:400;line-height:1.4;filter:alpha(opacity=0);opacity:0}.tooltip.in{filter:alpha(opacity=90);opacity:.9}.tooltip.top{padding:5px 0;margin-top:-3px}.tooltip.right{padding:0 5px;margin-left:3px}.tooltip.bottom{padding:5px 0;margin-top:3px}.tooltip.left{padding:0 5px;margin-left:-3px}.tooltip-inner{max-width:200px;padding:3px 8px;color:#fff;text-align:center;text-decoration:none;background-color:#000;border-radius:4px}.tooltip-arrow{position:absolute;width:0;height:0;border-color:transparent;border-style:solid}.tooltip.top .tooltip-arrow{bottom:0;left:50%;margin-left:-5px;border-width:5px 5px 0;border-top-color:#000}.tooltip.top-left .tooltip-arrow{right:5px;bottom:0;margin-bottom:-5px;border-width:5px 5px 0;border-top-color:#000}.tooltip.top-right .tooltip-arrow{bottom:0;left:5px;margin-bottom:-5px;border-width:5px 5px 0;border-top-color:#000}.tooltip.right .tooltip-arrow{top:50%;left:0;margin-top:-5px;border-width:5px 5px 5px 0;border-right-color:#000}.tooltip.left .tooltip-arrow{top:50%;right:0;margin-top:-5px;border-width:5px 0 5px 5px;border-left-color:#000}.tooltip.bottom .tooltip-arrow{top:0;left:50%;margin-left:-5px;border-width:0 5px 5px;border-bottom-color:#000}.tooltip.bottom-left .tooltip-arrow{top:0;right:5px;margin-top:-5px;border-width:0 5px 5px;border-bottom-color:#000}.tooltip.bottom-right .tooltip-arrow{top:0;left:5px;margin-top:-5px;border-width:0 5px 5px;border-bottom-color:#000}.popover{position:absolute;top:0;left:0;z-index:1060;display:none;max-width:276px;padding:1px;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:14px;font-weight:400;line-height:1.42857143;text-align:left;white-space:normal;background-color:#fff;-webkit-background-clip:padding-box;background-clip:padding-box;border:1px solid #ccc;border:1px solid rgba(0,0,0,.2);border-radius:6px;-webkit-box-shadow:0 5px 10px rgba(0,0,0,.2);box-shadow:0 5px 10px rgba(0,0,0,.2)}.popover.top{margin-top:-10px}.popover.right{margin-left:10px}.popover.bottom{margin-top:10px}.popover.left{margin-left:-10px}.popover-title{padding:8px 14px;margin:0;font-size:14px;background-color:#f7f7f7;border-bottom:1px solid #ebebeb;border-radius:5px 5px 0 0}.popover-content{padding:9px 14px}.popover>.arrow,.popover>.arrow:after{position:absolute;display:block;width:0;height:0;border-color:transparent;border-style:solid}.popover>.arrow{border-width:11px}.popover>.arrow:after{content:"";border-width:10px}.popover.top>.arrow{bottom:-11px;left:50%;margin-left:-11px;border-top-color:#999;border-top-color:rgba(0,0,0,.25);border-bottom-width:0}.popover.top>.arrow:after{bottom:1px;margin-left:-10px;content:" ";border-top-color:#fff;border-bottom-width:0}.popover.right>.arrow{top:50%;left:-11px;margin-top:-11px;border-right-color:#999;border-right-color:rgba(0,0,0,.25);border-left-width:0}.popover.right>.arrow:after{bottom:-10px;left:1px;content:" ";border-right-color:#fff;border-left-width:0}.popover.bottom>.arrow{top:-11px;left:50%;margin-left:-11px;border-top-width:0;border-bottom-color:#999;border-bottom-color:rgba(0,0,0,.25)}.popover.bottom>.arrow:after{top:1px;margin-left:-10px;content:" ";border-top-width:0;border-bottom-color:#fff}.popover.left>.arrow{top:50%;right:-11px;margin-top:-11px;border-right-width:0;border-left-color:#999;border-left-color:rgba(0,0,0,.25)}.popover.left>.arrow:after{right:1px;bottom:-10px;content:" ";border-right-width:0;border-left-color:#fff}.carousel{position:relative}.carousel-inner{position:relative;width:100%;overflow:hidden}.carousel-inner>.item{position:relative;display:none;-webkit-transition:.6s ease-in-out left;-o-transition:.6s ease-in-out left;transition:.6s ease-in-out left}.carousel-inner>.item>a>img,.carousel-inner>.item>img{line-height:1}@media all and (transform-3d),(-webkit-transform-3d){.carousel-inner>.item{-webkit-transition:-webkit-transform .6s ease-in-out;-o-transition:-o-transform .6s ease-in-out;transition:transform .6s ease-in-out;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-perspective:1000;perspective:1000}.carousel-inner>.item.active.right,.carousel-inner>.item.next{left:0;-webkit-transform:translate3d(100%,0,0);transform:translate3d(100%,0,0)}.carousel-inner>.item.active.left,.carousel-inner>.item.prev{left:0;-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0)}.carousel-inner>.item.active,.carousel-inner>.item.next.left,.carousel-inner>.item.prev.right{left:0;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}.carousel-inner>.active,.carousel-inner>.next,.carousel-inner>.prev{display:block}.carousel-inner>.active{left:0}.carousel-inner>.next,.carousel-inner>.prev{position:absolute;top:0;width:100%}.carousel-inner>.next{left:100%}.carousel-inner>.prev{left:-100%}.carousel-inner>.next.left,.carousel-inner>.prev.right{left:0}.carousel-inner>.active.left{left:-100%}.carousel-inner>.active.right{left:100%}.carousel-control{position:absolute;top:0;bottom:0;left:0;width:15%;font-size:20px;color:#fff;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.6);filter:alpha(opacity=50);opacity:.5}.carousel-control.left{background-image:-webkit-linear-gradient(left,rgba(0,0,0,.5) 0,rgba(0,0,0,.0001) 100%);background-image:-o-linear-gradient(left,rgba(0,0,0,.5) 0,rgba(0,0,0,.0001) 100%);background-image:-webkit-gradient(linear,left top,right top,from(rgba(0,0,0,.5)),to(rgba(0,0,0,.0001)));background-image:linear-gradient(to right,rgba(0,0,0,.5) 0,rgba(0,0,0,.0001) 100%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#80000000', endColorstr='#00000000', GradientType=1);background-repeat:repeat-x}.carousel-control.right{right:0;left:auto;background-image:-webkit-linear-gradient(left,rgba(0,0,0,.0001) 0,rgba(0,0,0,.5) 100%);background-image:-o-linear-gradient(left,rgba(0,0,0,.0001) 0,rgba(0,0,0,.5) 100%);background-image:-webkit-gradient(linear,left top,right top,from(rgba(0,0,0,.0001)),to(rgba(0,0,0,.5)));background-image:linear-gradient(to right,rgba(0,0,0,.0001) 0,rgba(0,0,0,.5) 100%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#80000000', GradientType=1);background-repeat:repeat-x}.carousel-control:focus,.carousel-control:hover{color:#fff;text-decoration:none;filter:alpha(opacity=90);outline:0;opacity:.9}.carousel-control .glyphicon-chevron-left,.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next,.carousel-control .icon-prev{position:absolute;top:50%;z-index:5;display:inline-block}.carousel-control .glyphicon-chevron-left,.carousel-control .icon-prev{left:50%;margin-left:-10px}.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next{right:50%;margin-right:-10px}.carousel-control .icon-next,.carousel-control .icon-prev{width:20px;height:20px;margin-top:-10px;font-family:serif;line-height:1}.carousel-control .icon-prev:before{content:'\2039'}.carousel-control .icon-next:before{content:'\203a'}.carousel-indicators{position:absolute;bottom:10px;left:50%;z-index:15;width:60%;padding-left:0;margin-left:-30%;text-align:center;list-style:none}.carousel-indicators li{display:inline-block;width:10px;height:10px;margin:1px;text-indent:-999px;cursor:pointer;background-color:#000 \9;background-color:rgba(0,0,0,0);border:1px solid #fff;border-radius:10px}.carousel-indicators .active{width:12px;height:12px;margin:0;background-color:#fff}.carousel-caption{position:absolute;right:15%;bottom:20px;left:15%;z-index:10;padding-top:20px;padding-bottom:20px;color:#fff;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.6)}.carousel-caption .btn{text-shadow:none}@media screen and (min-width:768px){.carousel-control .glyphicon-chevron-left,.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next,.carousel-control .icon-prev{width:30px;height:30px;margin-top:-15px;font-size:30px}.carousel-control .glyphicon-chevron-left,.carousel-control .icon-prev{margin-left:-15px}.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next{margin-right:-15px}.carousel-caption{right:20%;left:20%;padding-bottom:30px}.carousel-indicators{bottom:20px}}.btn-group-vertical>.btn-group:after,.btn-group-vertical>.btn-group:before,.btn-toolbar:after,.btn-toolbar:before,.clearfix:after,.clearfix:before,.container-fluid:after,.container-fluid:before,.container:after,.container:before,.dl-horizontal dd:after,.dl-horizontal dd:before,.form-horizontal .form-group:after,.form-horizontal .form-group:before,.modal-footer:after,.modal-footer:before,.nav:after,.nav:before,.navbar-collapse:after,.navbar-collapse:before,.navbar-header:after,.navbar-header:before,.navbar:after,.navbar:before,.pager:after,.pager:before,.panel-body:after,.panel-body:before,.row:after,.row:before{display:table;content:" "}.btn-group-vertical>.btn-group:after,.btn-toolbar:after,.clearfix:after,.container-fluid:after,.container:after,.dl-horizontal dd:after,.form-horizontal .form-group:after,.modal-footer:after,.nav:after,.navbar-collapse:after,.navbar-header:after,.navbar:after,.pager:after,.panel-body:after,.row:after{clear:both}.center-block{display:block;margin-right:auto;margin-left:auto}.pull-right{float:right!important}.pull-left{float:left!important}.hide{display:none!important}.show{display:block!important}.invisible{visibility:hidden}.text-hide{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0}.hidden{display:none!important}.affix{position:fixed}@-ms-viewport{width:device-width}.visible-lg,.visible-md,.visible-sm,.visible-xs{display:none!important}.visible-lg-block,.visible-lg-inline,.visible-lg-inline-block,.visible-md-block,.visible-md-inline,.visible-md-inline-block,.visible-sm-block,.visible-sm-inline,.visible-sm-inline-block,.visible-xs-block,.visible-xs-inline,.visible-xs-inline-block{display:none!important}@media (max-width:767px){.visible-xs{display:block!important}table.visible-xs{display:table}tr.visible-xs{display:table-row!important}td.visible-xs,th.visible-xs{display:table-cell!important}}@media (max-width:767px){.visible-xs-block{display:block!important}}@media (max-width:767px){.visible-xs-inline{display:inline!important}}@media (max-width:767px){.visible-xs-inline-block{display:inline-block!important}}@media (min-width:768px)and (max-width:991px){.visible-sm{display:block!important}table.visible-sm{display:table}tr.visible-sm{display:table-row!important}td.visible-sm,th.visible-sm{display:table-cell!important}}@media (min-width:768px)and (max-width:991px){.visible-sm-block{display:block!important}}@media (min-width:768px)and (max-width:991px){.visible-sm-inline{display:inline!important}}@media (min-width:768px)and (max-width:991px){.visible-sm-inline-block{display:inline-block!important}}@media (min-width:992px)and (max-width:1199px){.visible-md{display:block!important}table.visible-md{display:table}tr.visible-md{display:table-row!important}td.visible-md,th.visible-md{display:table-cell!important}}@media (min-width:992px)and (max-width:1199px){.visible-md-block{display:block!important}}@media (min-width:992px)and (max-width:1199px){.visible-md-inline{display:inline!important}}@media (min-width:992px)and (max-width:1199px){.visible-md-inline-block{display:inline-block!important}}@media (min-width:1200px){.visible-lg{display:block!important}table.visible-lg{display:table}tr.visible-lg{display:table-row!important}td.visible-lg,th.visible-lg{display:table-cell!important}}@media (min-width:1200px){.visible-lg-block{display:block!important}}@media (min-width:1200px){.visible-lg-inline{display:inline!important}}@media (min-width:1200px){.visible-lg-inline-block{display:inline-block!important}}@media (max-width:767px){.hidden-xs{display:none!important}}@media (min-width:768px)and (max-width:991px){.hidden-sm{display:none!important}}@media (min-width:992px)and (max-width:1199px){.hidden-md{display:none!important}}@media (min-width:1200px){.hidden-lg{display:none!important}}.visible-print{display:none!important}@media print{.visible-print{display:block!important}table.visible-print{display:table}tr.visible-print{display:table-row!important}td.visible-print,th.visible-print{display:table-cell!important}}.visible-print-block{display:none!important}@media print{.visible-print-block{display:block!important}}.visible-print-inline{display:none!important}@media print{.visible-print-inline{display:inline!important}}.visible-print-inline-block{display:none!important}@media print{.visible-print-inline-block{display:inline-block!important}}@media print{.hidden-print{display:none!important}}
 
1
  /*!
2
+ * Bootstrap v3.4.1 (https://getbootstrap.com/)
3
+ * Copyright 2011-2019 Twitter, Inc.
4
  * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
5
+ *//*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{display:block}audio,canvas,progress,video{display:inline-block;vertical-align:baseline}audio:not([controls]){display:none;height:0}[hidden],template{display:none}a{background-color:transparent}a:active,a:hover{outline:0}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;-moz-text-decoration:underline dotted;text-decoration:underline dotted}b,strong{font-weight:700}dfn{font-style:italic}h1{font-size:2em;margin:.67em 0}mark{background:#ff0;color:#000}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}img{border:0}svg:not(:root){overflow:hidden}figure{margin:1em 40px}hr{-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;height:0}pre{overflow:auto}code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}button,input,optgroup,select,textarea{color:inherit;font:inherit;margin:0}button{overflow:visible}button,select{text-transform:none}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}input{line-height:normal}input[type=checkbox],input[type=radio]{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;padding:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{height:auto}input[type=search]{-webkit-appearance:textfield;-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend{border:0;padding:0}textarea{overflow:auto}optgroup{font-weight:700}table{border-collapse:collapse;border-spacing:0}td,th{padding:0}/*! Source: https://github.com/h5bp/html5-boilerplate/blob/master/src/css/main.css */@media print{*,:after,:before{color:#000!important;text-shadow:none!important;background:0 0!important;-webkit-box-shadow:none!important;box-shadow:none!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}abbr[title]:after{content:" (" attr(title) ")"}a[href^="#"]:after,a[href^="javascript:"]:after{content:""}blockquote,pre{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}img{max-width:100%!important}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}.navbar{display:none}.btn>.caret,.dropup>.btn>.caret{border-top-color:#000!important}.label{border:1px solid #000}.table{border-collapse:collapse!important}.table td,.table th{background-color:#fff!important}.table-bordered td,.table-bordered th{border:1px solid #ddd!important}}@font-face{font-family:"Glyphicons Halflings";src:url(../fonts/glyphicons-halflings-regular.eot);src:url(../fonts/glyphicons-halflings-regular.eot?#iefix) format("embedded-opentype"),url(../fonts/glyphicons-halflings-regular.woff2) format("woff2"),url(../fonts/glyphicons-halflings-regular.woff) format("woff"),url(../fonts/glyphicons-halflings-regular.ttf) format("truetype"),url(../fonts/glyphicons-halflings-regular.svg#glyphicons_halflingsregular) format("svg")}.glyphicon{position:relative;top:1px;display:inline-block;font-family:"Glyphicons Halflings";font-style:normal;font-weight:400;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.glyphicon-asterisk:before{content:"\002a"}.glyphicon-plus:before{content:"\002b"}.glyphicon-eur:before,.glyphicon-euro:before{content:"\20ac"}.glyphicon-minus:before{content:"\2212"}.glyphicon-cloud:before{content:"\2601"}.glyphicon-envelope:before{content:"\2709"}.glyphicon-pencil:before{content:"\270f"}.glyphicon-glass:before{content:"\e001"}.glyphicon-music:before{content:"\e002"}.glyphicon-search:before{content:"\e003"}.glyphicon-heart:before{content:"\e005"}.glyphicon-star:before{content:"\e006"}.glyphicon-star-empty:before{content:"\e007"}.glyphicon-user:before{content:"\e008"}.glyphicon-film:before{content:"\e009"}.glyphicon-th-large:before{content:"\e010"}.glyphicon-th:before{content:"\e011"}.glyphicon-th-list:before{content:"\e012"}.glyphicon-ok:before{content:"\e013"}.glyphicon-remove:before{content:"\e014"}.glyphicon-zoom-in:before{content:"\e015"}.glyphicon-zoom-out:before{content:"\e016"}.glyphicon-off:before{content:"\e017"}.glyphicon-signal:before{content:"\e018"}.glyphicon-cog:before{content:"\e019"}.glyphicon-trash:before{content:"\e020"}.glyphicon-home:before{content:"\e021"}.glyphicon-file:before{content:"\e022"}.glyphicon-time:before{content:"\e023"}.glyphicon-road:before{content:"\e024"}.glyphicon-download-alt:before{content:"\e025"}.glyphicon-download:before{content:"\e026"}.glyphicon-upload:before{content:"\e027"}.glyphicon-inbox:before{content:"\e028"}.glyphicon-play-circle:before{content:"\e029"}.glyphicon-repeat:before{content:"\e030"}.glyphicon-refresh:before{content:"\e031"}.glyphicon-list-alt:before{content:"\e032"}.glyphicon-lock:before{content:"\e033"}.glyphicon-flag:before{content:"\e034"}.glyphicon-headphones:before{content:"\e035"}.glyphicon-volume-off:before{content:"\e036"}.glyphicon-volume-down:before{content:"\e037"}.glyphicon-volume-up:before{content:"\e038"}.glyphicon-qrcode:before{content:"\e039"}.glyphicon-barcode:before{content:"\e040"}.glyphicon-tag:before{content:"\e041"}.glyphicon-tags:before{content:"\e042"}.glyphicon-book:before{content:"\e043"}.glyphicon-bookmark:before{content:"\e044"}.glyphicon-print:before{content:"\e045"}.glyphicon-camera:before{content:"\e046"}.glyphicon-font:before{content:"\e047"}.glyphicon-bold:before{content:"\e048"}.glyphicon-italic:before{content:"\e049"}.glyphicon-text-height:before{content:"\e050"}.glyphicon-text-width:before{content:"\e051"}.glyphicon-align-left:before{content:"\e052"}.glyphicon-align-center:before{content:"\e053"}.glyphicon-align-right:before{content:"\e054"}.glyphicon-align-justify:before{content:"\e055"}.glyphicon-list:before{content:"\e056"}.glyphicon-indent-left:before{content:"\e057"}.glyphicon-indent-right:before{content:"\e058"}.glyphicon-facetime-video:before{content:"\e059"}.glyphicon-picture:before{content:"\e060"}.glyphicon-map-marker:before{content:"\e062"}.glyphicon-adjust:before{content:"\e063"}.glyphicon-tint:before{content:"\e064"}.glyphicon-edit:before{content:"\e065"}.glyphicon-share:before{content:"\e066"}.glyphicon-check:before{content:"\e067"}.glyphicon-move:before{content:"\e068"}.glyphicon-step-backward:before{content:"\e069"}.glyphicon-fast-backward:before{content:"\e070"}.glyphicon-backward:before{content:"\e071"}.glyphicon-play:before{content:"\e072"}.glyphicon-pause:before{content:"\e073"}.glyphicon-stop:before{content:"\e074"}.glyphicon-forward:before{content:"\e075"}.glyphicon-fast-forward:before{content:"\e076"}.glyphicon-step-forward:before{content:"\e077"}.glyphicon-eject:before{content:"\e078"}.glyphicon-chevron-left:before{content:"\e079"}.glyphicon-chevron-right:before{content:"\e080"}.glyphicon-plus-sign:before{content:"\e081"}.glyphicon-minus-sign:before{content:"\e082"}.glyphicon-remove-sign:before{content:"\e083"}.glyphicon-ok-sign:before{content:"\e084"}.glyphicon-question-sign:before{content:"\e085"}.glyphicon-info-sign:before{content:"\e086"}.glyphicon-screenshot:before{content:"\e087"}.glyphicon-remove-circle:before{content:"\e088"}.glyphicon-ok-circle:before{content:"\e089"}.glyphicon-ban-circle:before{content:"\e090"}.glyphicon-arrow-left:before{content:"\e091"}.glyphicon-arrow-right:before{content:"\e092"}.glyphicon-arrow-up:before{content:"\e093"}.glyphicon-arrow-down:before{content:"\e094"}.glyphicon-share-alt:before{content:"\e095"}.glyphicon-resize-full:before{content:"\e096"}.glyphicon-resize-small:before{content:"\e097"}.glyphicon-exclamation-sign:before{content:"\e101"}.glyphicon-gift:before{content:"\e102"}.glyphicon-leaf:before{content:"\e103"}.glyphicon-fire:before{content:"\e104"}.glyphicon-eye-open:before{content:"\e105"}.glyphicon-eye-close:before{content:"\e106"}.glyphicon-warning-sign:before{content:"\e107"}.glyphicon-plane:before{content:"\e108"}.glyphicon-calendar:before{content:"\e109"}.glyphicon-random:before{content:"\e110"}.glyphicon-comment:before{content:"\e111"}.glyphicon-magnet:before{content:"\e112"}.glyphicon-chevron-up:before{content:"\e113"}.glyphicon-chevron-down:before{content:"\e114"}.glyphicon-retweet:before{content:"\e115"}.glyphicon-shopping-cart:before{content:"\e116"}.glyphicon-folder-close:before{content:"\e117"}.glyphicon-folder-open:before{content:"\e118"}.glyphicon-resize-vertical:before{content:"\e119"}.glyphicon-resize-horizontal:before{content:"\e120"}.glyphicon-hdd:before{content:"\e121"}.glyphicon-bullhorn:before{content:"\e122"}.glyphicon-bell:before{content:"\e123"}.glyphicon-certificate:before{content:"\e124"}.glyphicon-thumbs-up:before{content:"\e125"}.glyphicon-thumbs-down:before{content:"\e126"}.glyphicon-hand-right:before{content:"\e127"}.glyphicon-hand-left:before{content:"\e128"}.glyphicon-hand-up:before{content:"\e129"}.glyphicon-hand-down:before{content:"\e130"}.glyphicon-circle-arrow-right:before{content:"\e131"}.glyphicon-circle-arrow-left:before{content:"\e132"}.glyphicon-circle-arrow-up:before{content:"\e133"}.glyphicon-circle-arrow-down:before{content:"\e134"}.glyphicon-globe:before{content:"\e135"}.glyphicon-wrench:before{content:"\e136"}.glyphicon-tasks:before{content:"\e137"}.glyphicon-filter:before{content:"\e138"}.glyphicon-briefcase:before{content:"\e139"}.glyphicon-fullscreen:before{content:"\e140"}.glyphicon-dashboard:before{content:"\e141"}.glyphicon-paperclip:before{content:"\e142"}.glyphicon-heart-empty:before{content:"\e143"}.glyphicon-link:before{content:"\e144"}.glyphicon-phone:before{content:"\e145"}.glyphicon-pushpin:before{content:"\e146"}.glyphicon-usd:before{content:"\e148"}.glyphicon-gbp:before{content:"\e149"}.glyphicon-sort:before{content:"\e150"}.glyphicon-sort-by-alphabet:before{content:"\e151"}.glyphicon-sort-by-alphabet-alt:before{content:"\e152"}.glyphicon-sort-by-order:before{content:"\e153"}.glyphicon-sort-by-order-alt:before{content:"\e154"}.glyphicon-sort-by-attributes:before{content:"\e155"}.glyphicon-sort-by-attributes-alt:before{content:"\e156"}.glyphicon-unchecked:before{content:"\e157"}.glyphicon-expand:before{content:"\e158"}.glyphicon-collapse-down:before{content:"\e159"}.glyphicon-collapse-up:before{content:"\e160"}.glyphicon-log-in:before{content:"\e161"}.glyphicon-flash:before{content:"\e162"}.glyphicon-log-out:before{content:"\e163"}.glyphicon-new-window:before{content:"\e164"}.glyphicon-record:before{content:"\e165"}.glyphicon-save:before{content:"\e166"}.glyphicon-open:before{content:"\e167"}.glyphicon-saved:before{content:"\e168"}.glyphicon-import:before{content:"\e169"}.glyphicon-export:before{content:"\e170"}.glyphicon-send:before{content:"\e171"}.glyphicon-floppy-disk:before{content:"\e172"}.glyphicon-floppy-saved:before{content:"\e173"}.glyphicon-floppy-remove:before{content:"\e174"}.glyphicon-floppy-save:before{content:"\e175"}.glyphicon-floppy-open:before{content:"\e176"}.glyphicon-credit-card:before{content:"\e177"}.glyphicon-transfer:before{content:"\e178"}.glyphicon-cutlery:before{content:"\e179"}.glyphicon-header:before{content:"\e180"}.glyphicon-compressed:before{content:"\e181"}.glyphicon-earphone:before{content:"\e182"}.glyphicon-phone-alt:before{content:"\e183"}.glyphicon-tower:before{content:"\e184"}.glyphicon-stats:before{content:"\e185"}.glyphicon-sd-video:before{content:"\e186"}.glyphicon-hd-video:before{content:"\e187"}.glyphicon-subtitles:before{content:"\e188"}.glyphicon-sound-stereo:before{content:"\e189"}.glyphicon-sound-dolby:before{content:"\e190"}.glyphicon-sound-5-1:before{content:"\e191"}.glyphicon-sound-6-1:before{content:"\e192"}.glyphicon-sound-7-1:before{content:"\e193"}.glyphicon-copyright-mark:before{content:"\e194"}.glyphicon-registration-mark:before{content:"\e195"}.glyphicon-cloud-download:before{content:"\e197"}.glyphicon-cloud-upload:before{content:"\e198"}.glyphicon-tree-conifer:before{content:"\e199"}.glyphicon-tree-deciduous:before{content:"\e200"}.glyphicon-cd:before{content:"\e201"}.glyphicon-save-file:before{content:"\e202"}.glyphicon-open-file:before{content:"\e203"}.glyphicon-level-up:before{content:"\e204"}.glyphicon-copy:before{content:"\e205"}.glyphicon-paste:before{content:"\e206"}.glyphicon-alert:before{content:"\e209"}.glyphicon-equalizer:before{content:"\e210"}.glyphicon-king:before{content:"\e211"}.glyphicon-queen:before{content:"\e212"}.glyphicon-pawn:before{content:"\e213"}.glyphicon-bishop:before{content:"\e214"}.glyphicon-knight:before{content:"\e215"}.glyphicon-baby-formula:before{content:"\e216"}.glyphicon-tent:before{content:"\26fa"}.glyphicon-blackboard:before{content:"\e218"}.glyphicon-bed:before{content:"\e219"}.glyphicon-apple:before{content:"\f8ff"}.glyphicon-erase:before{content:"\e221"}.glyphicon-hourglass:before{content:"\231b"}.glyphicon-lamp:before{content:"\e223"}.glyphicon-duplicate:before{content:"\e224"}.glyphicon-piggy-bank:before{content:"\e225"}.glyphicon-scissors:before{content:"\e226"}.glyphicon-bitcoin:before{content:"\e227"}.glyphicon-btc:before{content:"\e227"}.glyphicon-xbt:before{content:"\e227"}.glyphicon-yen:before{content:"\00a5"}.glyphicon-jpy:before{content:"\00a5"}.glyphicon-ruble:before{content:"\20bd"}.glyphicon-rub:before{content:"\20bd"}.glyphicon-scale:before{content:"\e230"}.glyphicon-ice-lolly:before{content:"\e231"}.glyphicon-ice-lolly-tasted:before{content:"\e232"}.glyphicon-education:before{content:"\e233"}.glyphicon-option-horizontal:before{content:"\e234"}.glyphicon-option-vertical:before{content:"\e235"}.glyphicon-menu-hamburger:before{content:"\e236"}.glyphicon-modal-window:before{content:"\e237"}.glyphicon-oil:before{content:"\e238"}.glyphicon-grain:before{content:"\e239"}.glyphicon-sunglasses:before{content:"\e240"}.glyphicon-text-size:before{content:"\e241"}.glyphicon-text-color:before{content:"\e242"}.glyphicon-text-background:before{content:"\e243"}.glyphicon-object-align-top:before{content:"\e244"}.glyphicon-object-align-bottom:before{content:"\e245"}.glyphicon-object-align-horizontal:before{content:"\e246"}.glyphicon-object-align-left:before{content:"\e247"}.glyphicon-object-align-vertical:before{content:"\e248"}.glyphicon-object-align-right:before{content:"\e249"}.glyphicon-triangle-right:before{content:"\e250"}.glyphicon-triangle-left:before{content:"\e251"}.glyphicon-triangle-bottom:before{content:"\e252"}.glyphicon-triangle-top:before{content:"\e253"}.glyphicon-console:before{content:"\e254"}.glyphicon-superscript:before{content:"\e255"}.glyphicon-subscript:before{content:"\e256"}.glyphicon-menu-left:before{content:"\e257"}.glyphicon-menu-right:before{content:"\e258"}.glyphicon-menu-down:before{content:"\e259"}.glyphicon-menu-up:before{content:"\e260"}*{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}:after,:before{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}html{font-size:10px;-webkit-tap-highlight-color:rgba(0,0,0,0)}body{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:14px;line-height:1.42857143;color:#333;background-color:#fff}button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}a{color:#337ab7;text-decoration:none}a:focus,a:hover{color:#23527c;text-decoration:underline}a:focus{outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}figure{margin:0}img{vertical-align:middle}.carousel-inner>.item>a>img,.carousel-inner>.item>img,.img-responsive,.thumbnail a>img,.thumbnail>img{display:block;max-width:100%;height:auto}.img-rounded{border-radius:6px}.img-thumbnail{padding:4px;line-height:1.42857143;background-color:#fff;border:1px solid #ddd;border-radius:4px;-webkit-transition:all .2s ease-in-out;-o-transition:all .2s ease-in-out;transition:all .2s ease-in-out;display:inline-block;max-width:100%;height:auto}.img-circle{border-radius:50%}hr{margin-top:20px;margin-bottom:20px;border:0;border-top:1px solid #eee}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;margin:0;overflow:visible;clip:auto}[role=button]{cursor:pointer}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{font-family:inherit;font-weight:500;line-height:1.1;color:inherit}.h1 .small,.h1 small,.h2 .small,.h2 small,.h3 .small,.h3 small,.h4 .small,.h4 small,.h5 .small,.h5 small,.h6 .small,.h6 small,h1 .small,h1 small,h2 .small,h2 small,h3 .small,h3 small,h4 .small,h4 small,h5 .small,h5 small,h6 .small,h6 small{font-weight:400;line-height:1;color:#777}.h1,.h2,.h3,h1,h2,h3{margin-top:20px;margin-bottom:10px}.h1 .small,.h1 small,.h2 .small,.h2 small,.h3 .small,.h3 small,h1 .small,h1 small,h2 .small,h2 small,h3 .small,h3 small{font-size:65%}.h4,.h5,.h6,h4,h5,h6{margin-top:10px;margin-bottom:10px}.h4 .small,.h4 small,.h5 .small,.h5 small,.h6 .small,.h6 small,h4 .small,h4 small,h5 .small,h5 small,h6 .small,h6 small{font-size:75%}.h1,h1{font-size:36px}.h2,h2{font-size:30px}.h3,h3{font-size:24px}.h4,h4{font-size:18px}.h5,h5{font-size:14px}.h6,h6{font-size:12px}p{margin:0 0 10px}.lead{margin-bottom:20px;font-size:16px;font-weight:300;line-height:1.4}@media (min-width:768px){.lead{font-size:21px}}.small,small{font-size:85%}.mark,mark{padding:.2em;background-color:#fcf8e3}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}.text-justify{text-align:justify}.text-nowrap{white-space:nowrap}.text-lowercase{text-transform:lowercase}.text-uppercase{text-transform:uppercase}.text-capitalize{text-transform:capitalize}.text-muted{color:#777}.text-primary{color:#337ab7}a.text-primary:focus,a.text-primary:hover{color:#286090}.text-success{color:#3c763d}a.text-success:focus,a.text-success:hover{color:#2b542c}.text-info{color:#31708f}a.text-info:focus,a.text-info:hover{color:#245269}.text-warning{color:#8a6d3b}a.text-warning:focus,a.text-warning:hover{color:#66512c}.text-danger{color:#a94442}a.text-danger:focus,a.text-danger:hover{color:#843534}.bg-primary{color:#fff;background-color:#337ab7}a.bg-primary:focus,a.bg-primary:hover{background-color:#286090}.bg-success{background-color:#dff0d8}a.bg-success:focus,a.bg-success:hover{background-color:#c1e2b3}.bg-info{background-color:#d9edf7}a.bg-info:focus,a.bg-info:hover{background-color:#afd9ee}.bg-warning{background-color:#fcf8e3}a.bg-warning:focus,a.bg-warning:hover{background-color:#f7ecb5}.bg-danger{background-color:#f2dede}a.bg-danger:focus,a.bg-danger:hover{background-color:#e4b9b9}.page-header{padding-bottom:9px;margin:40px 0 20px;border-bottom:1px solid #eee}ol,ul{margin-top:0;margin-bottom:10px}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}.list-unstyled{padding-left:0;list-style:none}.list-inline{padding-left:0;list-style:none;margin-left:-5px}.list-inline>li{display:inline-block;padding-right:5px;padding-left:5px}dl{margin-top:0;margin-bottom:20px}dd,dt{line-height:1.42857143}dt{font-weight:700}dd{margin-left:0}@media (min-width:768px){.dl-horizontal dt{float:left;width:160px;clear:left;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dl-horizontal dd{margin-left:180px}}abbr[data-original-title],abbr[title]{cursor:help}.initialism{font-size:90%;text-transform:uppercase}blockquote{padding:10px 20px;margin:0 0 20px;font-size:17.5px;border-left:5px solid #eee}blockquote ol:last-child,blockquote p:last-child,blockquote ul:last-child{margin-bottom:0}blockquote .small,blockquote footer,blockquote small{display:block;font-size:80%;line-height:1.42857143;color:#777}blockquote .small:before,blockquote footer:before,blockquote small:before{content:"\2014 \00A0"}.blockquote-reverse,blockquote.pull-right{padding-right:15px;padding-left:0;text-align:right;border-right:5px solid #eee;border-left:0}.blockquote-reverse .small:before,.blockquote-reverse footer:before,.blockquote-reverse small:before,blockquote.pull-right .small:before,blockquote.pull-right footer:before,blockquote.pull-right small:before{content:""}.blockquote-reverse .small:after,.blockquote-reverse footer:after,.blockquote-reverse small:after,blockquote.pull-right .small:after,blockquote.pull-right footer:after,blockquote.pull-right small:after{content:"\00A0 \2014"}address{margin-bottom:20px;font-style:normal;line-height:1.42857143}code,kbd,pre,samp{font-family:Menlo,Monaco,Consolas,"Courier New",monospace}code{padding:2px 4px;font-size:90%;color:#c7254e;background-color:#f9f2f4;border-radius:4px}kbd{padding:2px 4px;font-size:90%;color:#fff;background-color:#333;border-radius:3px;-webkit-box-shadow:inset 0 -1px 0 rgba(0,0,0,.25);box-shadow:inset 0 -1px 0 rgba(0,0,0,.25)}kbd kbd{padding:0;font-size:100%;font-weight:700;-webkit-box-shadow:none;box-shadow:none}pre{display:block;padding:9.5px;margin:0 0 10px;font-size:13px;line-height:1.42857143;color:#333;word-break:break-all;word-wrap:break-word;background-color:#f5f5f5;border:1px solid #ccc;border-radius:4px}pre code{padding:0;font-size:inherit;color:inherit;white-space:pre-wrap;background-color:transparent;border-radius:0}.pre-scrollable{max-height:340px;overflow-y:scroll}.container{padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}@media (min-width:768px){.container{width:750px}}@media (min-width:992px){.container{width:970px}}@media (min-width:1200px){.container{width:1170px}}.container-fluid{padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}.row{margin-right:-15px;margin-left:-15px}.row-no-gutters{margin-right:0;margin-left:0}.row-no-gutters [class*=col-]{padding-right:0;padding-left:0}.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9,.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9,.col-xs-1,.col-xs-10,.col-xs-11,.col-xs-12,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9{position:relative;min-height:1px;padding-right:15px;padding-left:15px}.col-xs-1,.col-xs-10,.col-xs-11,.col-xs-12,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9{float:left}.col-xs-12{width:100%}.col-xs-11{width:91.66666667%}.col-xs-10{width:83.33333333%}.col-xs-9{width:75%}.col-xs-8{width:66.66666667%}.col-xs-7{width:58.33333333%}.col-xs-6{width:50%}.col-xs-5{width:41.66666667%}.col-xs-4{width:33.33333333%}.col-xs-3{width:25%}.col-xs-2{width:16.66666667%}.col-xs-1{width:8.33333333%}.col-xs-pull-12{right:100%}.col-xs-pull-11{right:91.66666667%}.col-xs-pull-10{right:83.33333333%}.col-xs-pull-9{right:75%}.col-xs-pull-8{right:66.66666667%}.col-xs-pull-7{right:58.33333333%}.col-xs-pull-6{right:50%}.col-xs-pull-5{right:41.66666667%}.col-xs-pull-4{right:33.33333333%}.col-xs-pull-3{right:25%}.col-xs-pull-2{right:16.66666667%}.col-xs-pull-1{right:8.33333333%}.col-xs-pull-0{right:auto}.col-xs-push-12{left:100%}.col-xs-push-11{left:91.66666667%}.col-xs-push-10{left:83.33333333%}.col-xs-push-9{left:75%}.col-xs-push-8{left:66.66666667%}.col-xs-push-7{left:58.33333333%}.col-xs-push-6{left:50%}.col-xs-push-5{left:41.66666667%}.col-xs-push-4{left:33.33333333%}.col-xs-push-3{left:25%}.col-xs-push-2{left:16.66666667%}.col-xs-push-1{left:8.33333333%}.col-xs-push-0{left:auto}.col-xs-offset-12{margin-left:100%}.col-xs-offset-11{margin-left:91.66666667%}.col-xs-offset-10{margin-left:83.33333333%}.col-xs-offset-9{margin-left:75%}.col-xs-offset-8{margin-left:66.66666667%}.col-xs-offset-7{margin-left:58.33333333%}.col-xs-offset-6{margin-left:50%}.col-xs-offset-5{margin-left:41.66666667%}.col-xs-offset-4{margin-left:33.33333333%}.col-xs-offset-3{margin-left:25%}.col-xs-offset-2{margin-left:16.66666667%}.col-xs-offset-1{margin-left:8.33333333%}.col-xs-offset-0{margin-left:0}@media (min-width:768px){.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9{float:left}.col-sm-12{width:100%}.col-sm-11{width:91.66666667%}.col-sm-10{width:83.33333333%}.col-sm-9{width:75%}.col-sm-8{width:66.66666667%}.col-sm-7{width:58.33333333%}.col-sm-6{width:50%}.col-sm-5{width:41.66666667%}.col-sm-4{width:33.33333333%}.col-sm-3{width:25%}.col-sm-2{width:16.66666667%}.col-sm-1{width:8.33333333%}.col-sm-pull-12{right:100%}.col-sm-pull-11{right:91.66666667%}.col-sm-pull-10{right:83.33333333%}.col-sm-pull-9{right:75%}.col-sm-pull-8{right:66.66666667%}.col-sm-pull-7{right:58.33333333%}.col-sm-pull-6{right:50%}.col-sm-pull-5{right:41.66666667%}.col-sm-pull-4{right:33.33333333%}.col-sm-pull-3{right:25%}.col-sm-pull-2{right:16.66666667%}.col-sm-pull-1{right:8.33333333%}.col-sm-pull-0{right:auto}.col-sm-push-12{left:100%}.col-sm-push-11{left:91.66666667%}.col-sm-push-10{left:83.33333333%}.col-sm-push-9{left:75%}.col-sm-push-8{left:66.66666667%}.col-sm-push-7{left:58.33333333%}.col-sm-push-6{left:50%}.col-sm-push-5{left:41.66666667%}.col-sm-push-4{left:33.33333333%}.col-sm-push-3{left:25%}.col-sm-push-2{left:16.66666667%}.col-sm-push-1{left:8.33333333%}.col-sm-push-0{left:auto}.col-sm-offset-12{margin-left:100%}.col-sm-offset-11{margin-left:91.66666667%}.col-sm-offset-10{margin-left:83.33333333%}.col-sm-offset-9{margin-left:75%}.col-sm-offset-8{margin-left:66.66666667%}.col-sm-offset-7{margin-left:58.33333333%}.col-sm-offset-6{margin-left:50%}.col-sm-offset-5{margin-left:41.66666667%}.col-sm-offset-4{margin-left:33.33333333%}.col-sm-offset-3{margin-left:25%}.col-sm-offset-2{margin-left:16.66666667%}.col-sm-offset-1{margin-left:8.33333333%}.col-sm-offset-0{margin-left:0}}@media (min-width:992px){.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9{float:left}.col-md-12{width:100%}.col-md-11{width:91.66666667%}.col-md-10{width:83.33333333%}.col-md-9{width:75%}.col-md-8{width:66.66666667%}.col-md-7{width:58.33333333%}.col-md-6{width:50%}.col-md-5{width:41.66666667%}.col-md-4{width:33.33333333%}.col-md-3{width:25%}.col-md-2{width:16.66666667%}.col-md-1{width:8.33333333%}.col-md-pull-12{right:100%}.col-md-pull-11{right:91.66666667%}.col-md-pull-10{right:83.33333333%}.col-md-pull-9{right:75%}.col-md-pull-8{right:66.66666667%}.col-md-pull-7{right:58.33333333%}.col-md-pull-6{right:50%}.col-md-pull-5{right:41.66666667%}.col-md-pull-4{right:33.33333333%}.col-md-pull-3{right:25%}.col-md-pull-2{right:16.66666667%}.col-md-pull-1{right:8.33333333%}.col-md-pull-0{right:auto}.col-md-push-12{left:100%}.col-md-push-11{left:91.66666667%}.col-md-push-10{left:83.33333333%}.col-md-push-9{left:75%}.col-md-push-8{left:66.66666667%}.col-md-push-7{left:58.33333333%}.col-md-push-6{left:50%}.col-md-push-5{left:41.66666667%}.col-md-push-4{left:33.33333333%}.col-md-push-3{left:25%}.col-md-push-2{left:16.66666667%}.col-md-push-1{left:8.33333333%}.col-md-push-0{left:auto}.col-md-offset-12{margin-left:100%}.col-md-offset-11{margin-left:91.66666667%}.col-md-offset-10{margin-left:83.33333333%}.col-md-offset-9{margin-left:75%}.col-md-offset-8{margin-left:66.66666667%}.col-md-offset-7{margin-left:58.33333333%}.col-md-offset-6{margin-left:50%}.col-md-offset-5{margin-left:41.66666667%}.col-md-offset-4{margin-left:33.33333333%}.col-md-offset-3{margin-left:25%}.col-md-offset-2{margin-left:16.66666667%}.col-md-offset-1{margin-left:8.33333333%}.col-md-offset-0{margin-left:0}}@media (min-width:1200px){.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9{float:left}.col-lg-12{width:100%}.col-lg-11{width:91.66666667%}.col-lg-10{width:83.33333333%}.col-lg-9{width:75%}.col-lg-8{width:66.66666667%}.col-lg-7{width:58.33333333%}.col-lg-6{width:50%}.col-lg-5{width:41.66666667%}.col-lg-4{width:33.33333333%}.col-lg-3{width:25%}.col-lg-2{width:16.66666667%}.col-lg-1{width:8.33333333%}.col-lg-pull-12{right:100%}.col-lg-pull-11{right:91.66666667%}.col-lg-pull-10{right:83.33333333%}.col-lg-pull-9{right:75%}.col-lg-pull-8{right:66.66666667%}.col-lg-pull-7{right:58.33333333%}.col-lg-pull-6{right:50%}.col-lg-pull-5{right:41.66666667%}.col-lg-pull-4{right:33.33333333%}.col-lg-pull-3{right:25%}.col-lg-pull-2{right:16.66666667%}.col-lg-pull-1{right:8.33333333%}.col-lg-pull-0{right:auto}.col-lg-push-12{left:100%}.col-lg-push-11{left:91.66666667%}.col-lg-push-10{left:83.33333333%}.col-lg-push-9{left:75%}.col-lg-push-8{left:66.66666667%}.col-lg-push-7{left:58.33333333%}.col-lg-push-6{left:50%}.col-lg-push-5{left:41.66666667%}.col-lg-push-4{left:33.33333333%}.col-lg-push-3{left:25%}.col-lg-push-2{left:16.66666667%}.col-lg-push-1{left:8.33333333%}.col-lg-push-0{left:auto}.col-lg-offset-12{margin-left:100%}.col-lg-offset-11{margin-left:91.66666667%}.col-lg-offset-10{margin-left:83.33333333%}.col-lg-offset-9{margin-left:75%}.col-lg-offset-8{margin-left:66.66666667%}.col-lg-offset-7{margin-left:58.33333333%}.col-lg-offset-6{margin-left:50%}.col-lg-offset-5{margin-left:41.66666667%}.col-lg-offset-4{margin-left:33.33333333%}.col-lg-offset-3{margin-left:25%}.col-lg-offset-2{margin-left:16.66666667%}.col-lg-offset-1{margin-left:8.33333333%}.col-lg-offset-0{margin-left:0}}table{background-color:transparent}table col[class*=col-]{position:static;display:table-column;float:none}table td[class*=col-],table th[class*=col-]{position:static;display:table-cell;float:none}caption{padding-top:8px;padding-bottom:8px;color:#777;text-align:left}th{text-align:left}.table{width:100%;max-width:100%;margin-bottom:20px}.table>tbody>tr>td,.table>tbody>tr>th,.table>tfoot>tr>td,.table>tfoot>tr>th,.table>thead>tr>td,.table>thead>tr>th{padding:8px;line-height:1.42857143;vertical-align:top;border-top:1px solid #ddd}.table>thead>tr>th{vertical-align:bottom;border-bottom:2px solid #ddd}.table>caption+thead>tr:first-child>td,.table>caption+thead>tr:first-child>th,.table>colgroup+thead>tr:first-child>td,.table>colgroup+thead>tr:first-child>th,.table>thead:first-child>tr:first-child>td,.table>thead:first-child>tr:first-child>th{border-top:0}.table>tbody+tbody{border-top:2px solid #ddd}.table .table{background-color:#fff}.table-condensed>tbody>tr>td,.table-condensed>tbody>tr>th,.table-condensed>tfoot>tr>td,.table-condensed>tfoot>tr>th,.table-condensed>thead>tr>td,.table-condensed>thead>tr>th{padding:5px}.table-bordered{border:1px solid #ddd}.table-bordered>tbody>tr>td,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>td,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border:1px solid #ddd}.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border-bottom-width:2px}.table-striped>tbody>tr:nth-of-type(odd){background-color:#f9f9f9}.table-hover>tbody>tr:hover{background-color:#f5f5f5}.table>tbody>tr.active>td,.table>tbody>tr.active>th,.table>tbody>tr>td.active,.table>tbody>tr>th.active,.table>tfoot>tr.active>td,.table>tfoot>tr.active>th,.table>tfoot>tr>td.active,.table>tfoot>tr>th.active,.table>thead>tr.active>td,.table>thead>tr.active>th,.table>thead>tr>td.active,.table>thead>tr>th.active{background-color:#f5f5f5}.table-hover>tbody>tr.active:hover>td,.table-hover>tbody>tr.active:hover>th,.table-hover>tbody>tr:hover>.active,.table-hover>tbody>tr>td.active:hover,.table-hover>tbody>tr>th.active:hover{background-color:#e8e8e8}.table>tbody>tr.success>td,.table>tbody>tr.success>th,.table>tbody>tr>td.success,.table>tbody>tr>th.success,.table>tfoot>tr.success>td,.table>tfoot>tr.success>th,.table>tfoot>tr>td.success,.table>tfoot>tr>th.success,.table>thead>tr.success>td,.table>thead>tr.success>th,.table>thead>tr>td.success,.table>thead>tr>th.success{background-color:#dff0d8}.table-hover>tbody>tr.success:hover>td,.table-hover>tbody>tr.success:hover>th,.table-hover>tbody>tr:hover>.success,.table-hover>tbody>tr>td.success:hover,.table-hover>tbody>tr>th.success:hover{background-color:#d0e9c6}.table>tbody>tr.info>td,.table>tbody>tr.info>th,.table>tbody>tr>td.info,.table>tbody>tr>th.info,.table>tfoot>tr.info>td,.table>tfoot>tr.info>th,.table>tfoot>tr>td.info,.table>tfoot>tr>th.info,.table>thead>tr.info>td,.table>thead>tr.info>th,.table>thead>tr>td.info,.table>thead>tr>th.info{background-color:#d9edf7}.table-hover>tbody>tr.info:hover>td,.table-hover>tbody>tr.info:hover>th,.table-hover>tbody>tr:hover>.info,.table-hover>tbody>tr>td.info:hover,.table-hover>tbody>tr>th.info:hover{background-color:#c4e3f3}.table>tbody>tr.warning>td,.table>tbody>tr.warning>th,.table>tbody>tr>td.warning,.table>tbody>tr>th.warning,.table>tfoot>tr.warning>td,.table>tfoot>tr.warning>th,.table>tfoot>tr>td.warning,.table>tfoot>tr>th.warning,.table>thead>tr.warning>td,.table>thead>tr.warning>th,.table>thead>tr>td.warning,.table>thead>tr>th.warning{background-color:#fcf8e3}.table-hover>tbody>tr.warning:hover>td,.table-hover>tbody>tr.warning:hover>th,.table-hover>tbody>tr:hover>.warning,.table-hover>tbody>tr>td.warning:hover,.table-hover>tbody>tr>th.warning:hover{background-color:#faf2cc}.table>tbody>tr.danger>td,.table>tbody>tr.danger>th,.table>tbody>tr>td.danger,.table>tbody>tr>th.danger,.table>tfoot>tr.danger>td,.table>tfoot>tr.danger>th,.table>tfoot>tr>td.danger,.table>tfoot>tr>th.danger,.table>thead>tr.danger>td,.table>thead>tr.danger>th,.table>thead>tr>td.danger,.table>thead>tr>th.danger{background-color:#f2dede}.table-hover>tbody>tr.danger:hover>td,.table-hover>tbody>tr.danger:hover>th,.table-hover>tbody>tr:hover>.danger,.table-hover>tbody>tr>td.danger:hover,.table-hover>tbody>tr>th.danger:hover{background-color:#ebcccc}.table-responsive{min-height:.01%;overflow-x:auto}@media screen and (max-width:767px){.table-responsive{width:100%;margin-bottom:15px;overflow-y:hidden;-ms-overflow-style:-ms-autohiding-scrollbar;border:1px solid #ddd}.table-responsive>.table{margin-bottom:0}.table-responsive>.table>tbody>tr>td,.table-responsive>.table>tbody>tr>th,.table-responsive>.table>tfoot>tr>td,.table-responsive>.table>tfoot>tr>th,.table-responsive>.table>thead>tr>td,.table-responsive>.table>thead>tr>th{white-space:nowrap}.table-responsive>.table-bordered{border:0}.table-responsive>.table-bordered>tbody>tr>td:first-child,.table-responsive>.table-bordered>tbody>tr>th:first-child,.table-responsive>.table-bordered>tfoot>tr>td:first-child,.table-responsive>.table-bordered>tfoot>tr>th:first-child,.table-responsive>.table-bordered>thead>tr>td:first-child,.table-responsive>.table-bordered>thead>tr>th:first-child{border-left:0}.table-responsive>.table-bordered>tbody>tr>td:last-child,.table-responsive>.table-bordered>tbody>tr>th:last-child,.table-responsive>.table-bordered>tfoot>tr>td:last-child,.table-responsive>.table-bordered>tfoot>tr>th:last-child,.table-responsive>.table-bordered>thead>tr>td:last-child,.table-responsive>.table-bordered>thead>tr>th:last-child{border-right:0}.table-responsive>.table-bordered>tbody>tr:last-child>td,.table-responsive>.table-bordered>tbody>tr:last-child>th,.table-responsive>.table-bordered>tfoot>tr:last-child>td,.table-responsive>.table-bordered>tfoot>tr:last-child>th{border-bottom:0}}fieldset{min-width:0;padding:0;margin:0;border:0}legend{display:block;width:100%;padding:0;margin-bottom:20px;font-size:21px;line-height:inherit;color:#333;border:0;border-bottom:1px solid #e5e5e5}label{display:inline-block;max-width:100%;margin-bottom:5px;font-weight:700}input[type=search]{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none}input[type=checkbox],input[type=radio]{margin:4px 0 0;margin-top:1px\9;line-height:normal}fieldset[disabled] input[type=checkbox],fieldset[disabled] input[type=radio],input[type=checkbox].disabled,input[type=checkbox][disabled],input[type=radio].disabled,input[type=radio][disabled]{cursor:not-allowed}input[type=file]{display:block}input[type=range]{display:block;width:100%}select[multiple],select[size]{height:auto}input[type=checkbox]:focus,input[type=file]:focus,input[type=radio]:focus{outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}output{display:block;padding-top:7px;font-size:14px;line-height:1.42857143;color:#555}.form-control{display:block;width:100%;height:34px;padding:6px 12px;font-size:14px;line-height:1.42857143;color:#555;background-color:#fff;background-image:none;border:1px solid #ccc;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075);-webkit-transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s;-o-transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s;-webkit-transition:border-color ease-in-out .15s,-webkit-box-shadow ease-in-out .15s;transition:border-color ease-in-out .15s,-webkit-box-shadow ease-in-out .15s;transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s;transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s,-webkit-box-shadow ease-in-out .15s}.form-control:focus{border-color:#66afe9;outline:0;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6);box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6)}.form-control::-moz-placeholder{color:#999;opacity:1}.form-control:-ms-input-placeholder{color:#999}.form-control::-webkit-input-placeholder{color:#999}.form-control::-ms-expand{background-color:transparent;border:0}.form-control[disabled],.form-control[readonly],fieldset[disabled] .form-control{background-color:#eee;opacity:1}.form-control[disabled],fieldset[disabled] .form-control{cursor:not-allowed}textarea.form-control{height:auto}@media screen and (-webkit-min-device-pixel-ratio:0){input[type=date].form-control,input[type=datetime-local].form-control,input[type=month].form-control,input[type=time].form-control{line-height:34px}.input-group-sm input[type=date],.input-group-sm input[type=datetime-local],.input-group-sm input[type=month],.input-group-sm input[type=time],input[type=date].input-sm,input[type=datetime-local].input-sm,input[type=month].input-sm,input[type=time].input-sm{line-height:30px}.input-group-lg input[type=date],.input-group-lg input[type=datetime-local],.input-group-lg input[type=month],.input-group-lg input[type=time],input[type=date].input-lg,input[type=datetime-local].input-lg,input[type=month].input-lg,input[type=time].input-lg{line-height:46px}}.form-group{margin-bottom:15px}.checkbox,.radio{position:relative;display:block;margin-top:10px;margin-bottom:10px}.checkbox.disabled label,.radio.disabled label,fieldset[disabled] .checkbox label,fieldset[disabled] .radio label{cursor:not-allowed}.checkbox label,.radio label{min-height:20px;padding-left:20px;margin-bottom:0;font-weight:400;cursor:pointer}.checkbox input[type=checkbox],.checkbox-inline input[type=checkbox],.radio input[type=radio],.radio-inline input[type=radio]{position:absolute;margin-top:4px\9;margin-left:-20px}.checkbox+.checkbox,.radio+.radio{margin-top:-5px}.checkbox-inline,.radio-inline{position:relative;display:inline-block;padding-left:20px;margin-bottom:0;font-weight:400;vertical-align:middle;cursor:pointer}.checkbox-inline.disabled,.radio-inline.disabled,fieldset[disabled] .checkbox-inline,fieldset[disabled] .radio-inline{cursor:not-allowed}.checkbox-inline+.checkbox-inline,.radio-inline+.radio-inline{margin-top:0;margin-left:10px}.form-control-static{min-height:34px;padding-top:7px;padding-bottom:7px;margin-bottom:0}.form-control-static.input-lg,.form-control-static.input-sm{padding-right:0;padding-left:0}.input-sm{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}select.input-sm{height:30px;line-height:30px}select[multiple].input-sm,textarea.input-sm{height:auto}.form-group-sm .form-control{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}.form-group-sm select.form-control{height:30px;line-height:30px}.form-group-sm select[multiple].form-control,.form-group-sm textarea.form-control{height:auto}.form-group-sm .form-control-static{height:30px;min-height:32px;padding:6px 10px;font-size:12px;line-height:1.5}.input-lg{height:46px;padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}select.input-lg{height:46px;line-height:46px}select[multiple].input-lg,textarea.input-lg{height:auto}.form-group-lg .form-control{height:46px;padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}.form-group-lg select.form-control{height:46px;line-height:46px}.form-group-lg select[multiple].form-control,.form-group-lg textarea.form-control{height:auto}.form-group-lg .form-control-static{height:46px;min-height:38px;padding:11px 16px;font-size:18px;line-height:1.3333333}.has-feedback{position:relative}.has-feedback .form-control{padding-right:42.5px}.form-control-feedback{position:absolute;top:0;right:0;z-index:2;display:block;width:34px;height:34px;line-height:34px;text-align:center;pointer-events:none}.form-group-lg .form-control+.form-control-feedback,.input-group-lg+.form-control-feedback,.input-lg+.form-control-feedback{width:46px;height:46px;line-height:46px}.form-group-sm .form-control+.form-control-feedback,.input-group-sm+.form-control-feedback,.input-sm+.form-control-feedback{width:30px;height:30px;line-height:30px}.has-success .checkbox,.has-success .checkbox-inline,.has-success .control-label,.has-success .help-block,.has-success .radio,.has-success .radio-inline,.has-success.checkbox label,.has-success.checkbox-inline label,.has-success.radio label,.has-success.radio-inline label{color:#3c763d}.has-success .form-control{border-color:#3c763d;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-success .form-control:focus{border-color:#2b542c;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #67b168;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #67b168}.has-success .input-group-addon{color:#3c763d;background-color:#dff0d8;border-color:#3c763d}.has-success .form-control-feedback{color:#3c763d}.has-warning .checkbox,.has-warning .checkbox-inline,.has-warning .control-label,.has-warning .help-block,.has-warning .radio,.has-warning .radio-inline,.has-warning.checkbox label,.has-warning.checkbox-inline label,.has-warning.radio label,.has-warning.radio-inline label{color:#8a6d3b}.has-warning .form-control{border-color:#8a6d3b;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-warning .form-control:focus{border-color:#66512c;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #c0a16b;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #c0a16b}.has-warning .input-group-addon{color:#8a6d3b;background-color:#fcf8e3;border-color:#8a6d3b}.has-warning .form-control-feedback{color:#8a6d3b}.has-error .checkbox,.has-error .checkbox-inline,.has-error .control-label,.has-error .help-block,.has-error .radio,.has-error .radio-inline,.has-error.checkbox label,.has-error.checkbox-inline label,.has-error.radio label,.has-error.radio-inline label{color:#a94442}.has-error .form-control{border-color:#a94442;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-error .form-control:focus{border-color:#843534;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #ce8483;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #ce8483}.has-error .input-group-addon{color:#a94442;background-color:#f2dede;border-color:#a94442}.has-error .form-control-feedback{color:#a94442}.has-feedback label~.form-control-feedback{top:25px}.has-feedback label.sr-only~.form-control-feedback{top:0}.help-block{display:block;margin-top:5px;margin-bottom:10px;color:#737373}@media (min-width:768px){.form-inline .form-group{display:inline-block;margin-bottom:0;vertical-align:middle}.form-inline .form-control{display:inline-block;width:auto;vertical-align:middle}.form-inline .form-control-static{display:inline-block}.form-inline .input-group{display:inline-table;vertical-align:middle}.form-inline .input-group .form-control,.form-inline .input-group .input-group-addon,.form-inline .input-group .input-group-btn{width:auto}.form-inline .input-group>.form-control{width:100%}.form-inline .control-label{margin-bottom:0;vertical-align:middle}.form-inline .checkbox,.form-inline .radio{display:inline-block;margin-top:0;margin-bottom:0;vertical-align:middle}.form-inline .checkbox label,.form-inline .radio label{padding-left:0}.form-inline .checkbox input[type=checkbox],.form-inline .radio input[type=radio]{position:relative;margin-left:0}.form-inline .has-feedback .form-control-feedback{top:0}}.form-horizontal .checkbox,.form-horizontal .checkbox-inline,.form-horizontal .radio,.form-horizontal .radio-inline{padding-top:7px;margin-top:0;margin-bottom:0}.form-horizontal .checkbox,.form-horizontal .radio{min-height:27px}.form-horizontal .form-group{margin-right:-15px;margin-left:-15px}@media (min-width:768px){.form-horizontal .control-label{padding-top:7px;margin-bottom:0;text-align:right}}.form-horizontal .has-feedback .form-control-feedback{right:15px}@media (min-width:768px){.form-horizontal .form-group-lg .control-label{padding-top:11px;font-size:18px}}@media (min-width:768px){.form-horizontal .form-group-sm .control-label{padding-top:6px;font-size:12px}}.btn{display:inline-block;margin-bottom:0;font-weight:400;text-align:center;white-space:nowrap;vertical-align:middle;-ms-touch-action:manipulation;touch-action:manipulation;cursor:pointer;background-image:none;border:1px solid transparent;padding:6px 12px;font-size:14px;line-height:1.42857143;border-radius:4px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.btn.active.focus,.btn.active:focus,.btn.focus,.btn:active.focus,.btn:active:focus,.btn:focus{outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}.btn.focus,.btn:focus,.btn:hover{color:#333;text-decoration:none}.btn.active,.btn:active{background-image:none;outline:0;-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,.125);box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.btn.disabled,.btn[disabled],fieldset[disabled] .btn{cursor:not-allowed;filter:alpha(opacity=65);opacity:.65;-webkit-box-shadow:none;box-shadow:none}a.btn.disabled,fieldset[disabled] a.btn{pointer-events:none}.btn-default{color:#333;background-color:#fff;border-color:#ccc}.btn-default.focus,.btn-default:focus{color:#333;background-color:#e6e6e6;border-color:#8c8c8c}.btn-default:hover{color:#333;background-color:#e6e6e6;border-color:#adadad}.btn-default.active,.btn-default:active,.open>.dropdown-toggle.btn-default{color:#333;background-color:#e6e6e6;background-image:none;border-color:#adadad}.btn-default.active.focus,.btn-default.active:focus,.btn-default.active:hover,.btn-default:active.focus,.btn-default:active:focus,.btn-default:active:hover,.open>.dropdown-toggle.btn-default.focus,.open>.dropdown-toggle.btn-default:focus,.open>.dropdown-toggle.btn-default:hover{color:#333;background-color:#d4d4d4;border-color:#8c8c8c}.btn-default.disabled.focus,.btn-default.disabled:focus,.btn-default.disabled:hover,.btn-default[disabled].focus,.btn-default[disabled]:focus,.btn-default[disabled]:hover,fieldset[disabled] .btn-default.focus,fieldset[disabled] .btn-default:focus,fieldset[disabled] .btn-default:hover{background-color:#fff;border-color:#ccc}.btn-default .badge{color:#fff;background-color:#333}.btn-primary{color:#fff;background-color:#337ab7;border-color:#2e6da4}.btn-primary.focus,.btn-primary:focus{color:#fff;background-color:#286090;border-color:#122b40}.btn-primary:hover{color:#fff;background-color:#286090;border-color:#204d74}.btn-primary.active,.btn-primary:active,.open>.dropdown-toggle.btn-primary{color:#fff;background-color:#286090;background-image:none;border-color:#204d74}.btn-primary.active.focus,.btn-primary.active:focus,.btn-primary.active:hover,.btn-primary:active.focus,.btn-primary:active:focus,.btn-primary:active:hover,.open>.dropdown-toggle.btn-primary.focus,.open>.dropdown-toggle.btn-primary:focus,.open>.dropdown-toggle.btn-primary:hover{color:#fff;background-color:#204d74;border-color:#122b40}.btn-primary.disabled.focus,.btn-primary.disabled:focus,.btn-primary.disabled:hover,.btn-primary[disabled].focus,.btn-primary[disabled]:focus,.btn-primary[disabled]:hover,fieldset[disabled] .btn-primary.focus,fieldset[disabled] .btn-primary:focus,fieldset[disabled] .btn-primary:hover{background-color:#337ab7;border-color:#2e6da4}.btn-primary .badge{color:#337ab7;background-color:#fff}.btn-success{color:#fff;background-color:#5cb85c;border-color:#4cae4c}.btn-success.focus,.btn-success:focus{color:#fff;background-color:#449d44;border-color:#255625}.btn-success:hover{color:#fff;background-color:#449d44;border-color:#398439}.btn-success.active,.btn-success:active,.open>.dropdown-toggle.btn-success{color:#fff;background-color:#449d44;background-image:none;border-color:#398439}.btn-success.active.focus,.btn-success.active:focus,.btn-success.active:hover,.btn-success:active.focus,.btn-success:active:focus,.btn-success:active:hover,.open>.dropdown-toggle.btn-success.focus,.open>.dropdown-toggle.btn-success:focus,.open>.dropdown-toggle.btn-success:hover{color:#fff;background-color:#398439;border-color:#255625}.btn-success.disabled.focus,.btn-success.disabled:focus,.btn-success.disabled:hover,.btn-success[disabled].focus,.btn-success[disabled]:focus,.btn-success[disabled]:hover,fieldset[disabled] .btn-success.focus,fieldset[disabled] .btn-success:focus,fieldset[disabled] .btn-success:hover{background-color:#5cb85c;border-color:#4cae4c}.btn-success .badge{color:#5cb85c;background-color:#fff}.btn-info{color:#fff;background-color:#5bc0de;border-color:#46b8da}.btn-info.focus,.btn-info:focus{color:#fff;background-color:#31b0d5;border-color:#1b6d85}.btn-info:hover{color:#fff;background-color:#31b0d5;border-color:#269abc}.btn-info.active,.btn-info:active,.open>.dropdown-toggle.btn-info{color:#fff;background-color:#31b0d5;background-image:none;border-color:#269abc}.btn-info.active.focus,.btn-info.active:focus,.btn-info.active:hover,.btn-info:active.focus,.btn-info:active:focus,.btn-info:active:hover,.open>.dropdown-toggle.btn-info.focus,.open>.dropdown-toggle.btn-info:focus,.open>.dropdown-toggle.btn-info:hover{color:#fff;background-color:#269abc;border-color:#1b6d85}.btn-info.disabled.focus,.btn-info.disabled:focus,.btn-info.disabled:hover,.btn-info[disabled].focus,.btn-info[disabled]:focus,.btn-info[disabled]:hover,fieldset[disabled] .btn-info.focus,fieldset[disabled] .btn-info:focus,fieldset[disabled] .btn-info:hover{background-color:#5bc0de;border-color:#46b8da}.btn-info .badge{color:#5bc0de;background-color:#fff}.btn-warning{color:#fff;background-color:#f0ad4e;border-color:#eea236}.btn-warning.focus,.btn-warning:focus{color:#fff;background-color:#ec971f;border-color:#985f0d}.btn-warning:hover{color:#fff;background-color:#ec971f;border-color:#d58512}.btn-warning.active,.btn-warning:active,.open>.dropdown-toggle.btn-warning{color:#fff;background-color:#ec971f;background-image:none;border-color:#d58512}.btn-warning.active.focus,.btn-warning.active:focus,.btn-warning.active:hover,.btn-warning:active.focus,.btn-warning:active:focus,.btn-warning:active:hover,.open>.dropdown-toggle.btn-warning.focus,.open>.dropdown-toggle.btn-warning:focus,.open>.dropdown-toggle.btn-warning:hover{color:#fff;background-color:#d58512;border-color:#985f0d}.btn-warning.disabled.focus,.btn-warning.disabled:focus,.btn-warning.disabled:hover,.btn-warning[disabled].focus,.btn-warning[disabled]:focus,.btn-warning[disabled]:hover,fieldset[disabled] .btn-warning.focus,fieldset[disabled] .btn-warning:focus,fieldset[disabled] .btn-warning:hover{background-color:#f0ad4e;border-color:#eea236}.btn-warning .badge{color:#f0ad4e;background-color:#fff}.btn-danger{color:#fff;background-color:#d9534f;border-color:#d43f3a}.btn-danger.focus,.btn-danger:focus{color:#fff;background-color:#c9302c;border-color:#761c19}.btn-danger:hover{color:#fff;background-color:#c9302c;border-color:#ac2925}.btn-danger.active,.btn-danger:active,.open>.dropdown-toggle.btn-danger{color:#fff;background-color:#c9302c;background-image:none;border-color:#ac2925}.btn-danger.active.focus,.btn-danger.active:focus,.btn-danger.active:hover,.btn-danger:active.focus,.btn-danger:active:focus,.btn-danger:active:hover,.open>.dropdown-toggle.btn-danger.focus,.open>.dropdown-toggle.btn-danger:focus,.open>.dropdown-toggle.btn-danger:hover{color:#fff;background-color:#ac2925;border-color:#761c19}.btn-danger.disabled.focus,.btn-danger.disabled:focus,.btn-danger.disabled:hover,.btn-danger[disabled].focus,.btn-danger[disabled]:focus,.btn-danger[disabled]:hover,fieldset[disabled] .btn-danger.focus,fieldset[disabled] .btn-danger:focus,fieldset[disabled] .btn-danger:hover{background-color:#d9534f;border-color:#d43f3a}.btn-danger .badge{color:#d9534f;background-color:#fff}.btn-link{font-weight:400;color:#337ab7;border-radius:0}.btn-link,.btn-link.active,.btn-link:active,.btn-link[disabled],fieldset[disabled] .btn-link{background-color:transparent;-webkit-box-shadow:none;box-shadow:none}.btn-link,.btn-link:active,.btn-link:focus,.btn-link:hover{border-color:transparent}.btn-link:focus,.btn-link:hover{color:#23527c;text-decoration:underline;background-color:transparent}.btn-link[disabled]:focus,.btn-link[disabled]:hover,fieldset[disabled] .btn-link:focus,fieldset[disabled] .btn-link:hover{color:#777;text-decoration:none}.btn-group-lg>.btn,.btn-lg{padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}.btn-group-sm>.btn,.btn-sm{padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}.btn-group-xs>.btn,.btn-xs{padding:1px 5px;font-size:12px;line-height:1.5;border-radius:3px}.btn-block{display:block;width:100%}.btn-block+.btn-block{margin-top:5px}input[type=button].btn-block,input[type=reset].btn-block,input[type=submit].btn-block{width:100%}.fade{opacity:0;-webkit-transition:opacity .15s linear;-o-transition:opacity .15s linear;transition:opacity .15s linear}.fade.in{opacity:1}.collapse{display:none}.collapse.in{display:block}tr.collapse.in{display:table-row}tbody.collapse.in{display:table-row-group}.collapsing{position:relative;height:0;overflow:hidden;-webkit-transition-property:height,visibility;-o-transition-property:height,visibility;transition-property:height,visibility;-webkit-transition-duration:.35s;-o-transition-duration:.35s;transition-duration:.35s;-webkit-transition-timing-function:ease;-o-transition-timing-function:ease;transition-timing-function:ease}.caret{display:inline-block;width:0;height:0;margin-left:2px;vertical-align:middle;border-top:4px dashed;border-top:4px solid\9;border-right:4px solid transparent;border-left:4px solid transparent}.dropdown,.dropup{position:relative}.dropdown-toggle:focus{outline:0}.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;float:left;min-width:160px;padding:5px 0;margin:2px 0 0;font-size:14px;text-align:left;list-style:none;background-color:#fff;background-clip:padding-box;border:1px solid #ccc;border:1px solid rgba(0,0,0,.15);border-radius:4px;-webkit-box-shadow:0 6px 12px rgba(0,0,0,.175);box-shadow:0 6px 12px rgba(0,0,0,.175)}.dropdown-menu.pull-right{right:0;left:auto}.dropdown-menu .divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.dropdown-menu>li>a{display:block;padding:3px 20px;clear:both;font-weight:400;line-height:1.42857143;color:#333;white-space:nowrap}.dropdown-menu>li>a:focus,.dropdown-menu>li>a:hover{color:#262626;text-decoration:none;background-color:#f5f5f5}.dropdown-menu>.active>a,.dropdown-menu>.active>a:focus,.dropdown-menu>.active>a:hover{color:#fff;text-decoration:none;background-color:#337ab7;outline:0}.dropdown-menu>.disabled>a,.dropdown-menu>.disabled>a:focus,.dropdown-menu>.disabled>a:hover{color:#777}.dropdown-menu>.disabled>a:focus,.dropdown-menu>.disabled>a:hover{text-decoration:none;cursor:not-allowed;background-color:transparent;background-image:none;filter:progid:DXImageTransform.Microsoft.gradient(enabled=false)}.open>.dropdown-menu{display:block}.open>a{outline:0}.dropdown-menu-right{right:0;left:auto}.dropdown-menu-left{right:auto;left:0}.dropdown-header{display:block;padding:3px 20px;font-size:12px;line-height:1.42857143;color:#777;white-space:nowrap}.dropdown-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:990}.pull-right>.dropdown-menu{right:0;left:auto}.dropup .caret,.navbar-fixed-bottom .dropdown .caret{content:"";border-top:0;border-bottom:4px dashed;border-bottom:4px solid\9}.dropup .dropdown-menu,.navbar-fixed-bottom .dropdown .dropdown-menu{top:auto;bottom:100%;margin-bottom:2px}@media (min-width:768px){.navbar-right .dropdown-menu{right:0;left:auto}.navbar-right .dropdown-menu-left{right:auto;left:0}}.btn-group,.btn-group-vertical{position:relative;display:inline-block;vertical-align:middle}.btn-group-vertical>.btn,.btn-group>.btn{position:relative;float:left}.btn-group-vertical>.btn.active,.btn-group-vertical>.btn:active,.btn-group-vertical>.btn:focus,.btn-group-vertical>.btn:hover,.btn-group>.btn.active,.btn-group>.btn:active,.btn-group>.btn:focus,.btn-group>.btn:hover{z-index:2}.btn-group .btn+.btn,.btn-group .btn+.btn-group,.btn-group .btn-group+.btn,.btn-group .btn-group+.btn-group{margin-left:-1px}.btn-toolbar{margin-left:-5px}.btn-toolbar .btn,.btn-toolbar .btn-group,.btn-toolbar .input-group{float:left}.btn-toolbar>.btn,.btn-toolbar>.btn-group,.btn-toolbar>.input-group{margin-left:5px}.btn-group>.btn:not(:first-child):not(:last-child):not(.dropdown-toggle){border-radius:0}.btn-group>.btn:first-child{margin-left:0}.btn-group>.btn:first-child:not(:last-child):not(.dropdown-toggle){border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn:last-child:not(:first-child),.btn-group>.dropdown-toggle:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.btn-group>.btn-group{float:left}.btn-group>.btn-group:not(:first-child):not(:last-child)>.btn{border-radius:0}.btn-group>.btn-group:first-child:not(:last-child)>.btn:last-child,.btn-group>.btn-group:first-child:not(:last-child)>.dropdown-toggle{border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn-group:last-child:not(:first-child)>.btn:first-child{border-top-left-radius:0;border-bottom-left-radius:0}.btn-group .dropdown-toggle:active,.btn-group.open .dropdown-toggle{outline:0}.btn-group>.btn+.dropdown-toggle{padding-right:8px;padding-left:8px}.btn-group>.btn-lg+.dropdown-toggle{padding-right:12px;padding-left:12px}.btn-group.open .dropdown-toggle{-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,.125);box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.btn-group.open .dropdown-toggle.btn-link{-webkit-box-shadow:none;box-shadow:none}.btn .caret{margin-left:0}.btn-lg .caret{border-width:5px 5px 0;border-bottom-width:0}.dropup .btn-lg .caret{border-width:0 5px 5px}.btn-group-vertical>.btn,.btn-group-vertical>.btn-group,.btn-group-vertical>.btn-group>.btn{display:block;float:none;width:100%;max-width:100%}.btn-group-vertical>.btn-group>.btn{float:none}.btn-group-vertical>.btn+.btn,.btn-group-vertical>.btn+.btn-group,.btn-group-vertical>.btn-group+.btn,.btn-group-vertical>.btn-group+.btn-group{margin-top:-1px;margin-left:0}.btn-group-vertical>.btn:not(:first-child):not(:last-child){border-radius:0}.btn-group-vertical>.btn:first-child:not(:last-child){border-top-left-radius:4px;border-top-right-radius:4px;border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn:last-child:not(:first-child){border-top-left-radius:0;border-top-right-radius:0;border-bottom-right-radius:4px;border-bottom-left-radius:4px}.btn-group-vertical>.btn-group:not(:first-child):not(:last-child)>.btn{border-radius:0}.btn-group-vertical>.btn-group:first-child:not(:last-child)>.btn:last-child,.btn-group-vertical>.btn-group:first-child:not(:last-child)>.dropdown-toggle{border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn-group:last-child:not(:first-child)>.btn:first-child{border-top-left-radius:0;border-top-right-radius:0}.btn-group-justified{display:table;width:100%;table-layout:fixed;border-collapse:separate}.btn-group-justified>.btn,.btn-group-justified>.btn-group{display:table-cell;float:none;width:1%}.btn-group-justified>.btn-group .btn{width:100%}.btn-group-justified>.btn-group .dropdown-menu{left:auto}[data-toggle=buttons]>.btn input[type=checkbox],[data-toggle=buttons]>.btn input[type=radio],[data-toggle=buttons]>.btn-group>.btn input[type=checkbox],[data-toggle=buttons]>.btn-group>.btn input[type=radio]{position:absolute;clip:rect(0,0,0,0);pointer-events:none}.input-group{position:relative;display:table;border-collapse:separate}.input-group[class*=col-]{float:none;padding-right:0;padding-left:0}.input-group .form-control{position:relative;z-index:2;float:left;width:100%;margin-bottom:0}.input-group .form-control:focus{z-index:3}.input-group-lg>.form-control,.input-group-lg>.input-group-addon,.input-group-lg>.input-group-btn>.btn{height:46px;padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}select.input-group-lg>.form-control,select.input-group-lg>.input-group-addon,select.input-group-lg>.input-group-btn>.btn{height:46px;line-height:46px}select[multiple].input-group-lg>.form-control,select[multiple].input-group-lg>.input-group-addon,select[multiple].input-group-lg>.input-group-btn>.btn,textarea.input-group-lg>.form-control,textarea.input-group-lg>.input-group-addon,textarea.input-group-lg>.input-group-btn>.btn{height:auto}.input-group-sm>.form-control,.input-group-sm>.input-group-addon,.input-group-sm>.input-group-btn>.btn{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}select.input-group-sm>.form-control,select.input-group-sm>.input-group-addon,select.input-group-sm>.input-group-btn>.btn{height:30px;line-height:30px}select[multiple].input-group-sm>.form-control,select[multiple].input-group-sm>.input-group-addon,select[multiple].input-group-sm>.input-group-btn>.btn,textarea.input-group-sm>.form-control,textarea.input-group-sm>.input-group-addon,textarea.input-group-sm>.input-group-btn>.btn{height:auto}.input-group .form-control,.input-group-addon,.input-group-btn{display:table-cell}.input-group .form-control:not(:first-child):not(:last-child),.input-group-addon:not(:first-child):not(:last-child),.input-group-btn:not(:first-child):not(:last-child){border-radius:0}.input-group-addon,.input-group-btn{width:1%;white-space:nowrap;vertical-align:middle}.input-group-addon{padding:6px 12px;font-size:14px;font-weight:400;line-height:1;color:#555;text-align:center;background-color:#eee;border:1px solid #ccc;border-radius:4px}.input-group-addon.input-sm{padding:5px 10px;font-size:12px;border-radius:3px}.input-group-addon.input-lg{padding:10px 16px;font-size:18px;border-radius:6px}.input-group-addon input[type=checkbox],.input-group-addon input[type=radio]{margin-top:0}.input-group .form-control:first-child,.input-group-addon:first-child,.input-group-btn:first-child>.btn,.input-group-btn:first-child>.btn-group>.btn,.input-group-btn:first-child>.dropdown-toggle,.input-group-btn:last-child>.btn-group:not(:last-child)>.btn,.input-group-btn:last-child>.btn:not(:last-child):not(.dropdown-toggle){border-top-right-radius:0;border-bottom-right-radius:0}.input-group-addon:first-child{border-right:0}.input-group .form-control:last-child,.input-group-addon:last-child,.input-group-btn:first-child>.btn-group:not(:first-child)>.btn,.input-group-btn:first-child>.btn:not(:first-child),.input-group-btn:last-child>.btn,.input-group-btn:last-child>.btn-group>.btn,.input-group-btn:last-child>.dropdown-toggle{border-top-left-radius:0;border-bottom-left-radius:0}.input-group-addon:last-child{border-left:0}.input-group-btn{position:relative;font-size:0;white-space:nowrap}.input-group-btn>.btn{position:relative}.input-group-btn>.btn+.btn{margin-left:-1px}.input-group-btn>.btn:active,.input-group-btn>.btn:focus,.input-group-btn>.btn:hover{z-index:2}.input-group-btn:first-child>.btn,.input-group-btn:first-child>.btn-group{margin-right:-1px}.input-group-btn:last-child>.btn,.input-group-btn:last-child>.btn-group{z-index:2;margin-left:-1px}.nav{padding-left:0;margin-bottom:0;list-style:none}.nav>li{position:relative;display:block}.nav>li>a{position:relative;display:block;padding:10px 15px}.nav>li>a:focus,.nav>li>a:hover{text-decoration:none;background-color:#eee}.nav>li.disabled>a{color:#777}.nav>li.disabled>a:focus,.nav>li.disabled>a:hover{color:#777;text-decoration:none;cursor:not-allowed;background-color:transparent}.nav .open>a,.nav .open>a:focus,.nav .open>a:hover{background-color:#eee;border-color:#337ab7}.nav .nav-divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.nav>li>a>img{max-width:none}.nav-tabs{border-bottom:1px solid #ddd}.nav-tabs>li{float:left;margin-bottom:-1px}.nav-tabs>li>a{margin-right:2px;line-height:1.42857143;border:1px solid transparent;border-radius:4px 4px 0 0}.nav-tabs>li>a:hover{border-color:#eee #eee #ddd}.nav-tabs>li.active>a,.nav-tabs>li.active>a:focus,.nav-tabs>li.active>a:hover{color:#555;cursor:default;background-color:#fff;border:1px solid #ddd;border-bottom-color:transparent}.nav-tabs.nav-justified{width:100%;border-bottom:0}.nav-tabs.nav-justified>li{float:none}.nav-tabs.nav-justified>li>a{margin-bottom:5px;text-align:center}.nav-tabs.nav-justified>.dropdown .dropdown-menu{top:auto;left:auto}@media (min-width:768px){.nav-tabs.nav-justified>li{display:table-cell;width:1%}.nav-tabs.nav-justified>li>a{margin-bottom:0}}.nav-tabs.nav-justified>li>a{margin-right:0;border-radius:4px}.nav-tabs.nav-justified>.active>a,.nav-tabs.nav-justified>.active>a:focus,.nav-tabs.nav-justified>.active>a:hover{border:1px solid #ddd}@media (min-width:768px){.nav-tabs.nav-justified>li>a{border-bottom:1px solid #ddd;border-radius:4px 4px 0 0}.nav-tabs.nav-justified>.active>a,.nav-tabs.nav-justified>.active>a:focus,.nav-tabs.nav-justified>.active>a:hover{border-bottom-color:#fff}}.nav-pills>li{float:left}.nav-pills>li>a{border-radius:4px}.nav-pills>li+li{margin-left:2px}.nav-pills>li.active>a,.nav-pills>li.active>a:focus,.nav-pills>li.active>a:hover{color:#fff;background-color:#337ab7}.nav-stacked>li{float:none}.nav-stacked>li+li{margin-top:2px;margin-left:0}.nav-justified{width:100%}.nav-justified>li{float:none}.nav-justified>li>a{margin-bottom:5px;text-align:center}.nav-justified>.dropdown .dropdown-menu{top:auto;left:auto}@media (min-width:768px){.nav-justified>li{display:table-cell;width:1%}.nav-justified>li>a{margin-bottom:0}}.nav-tabs-justified{border-bottom:0}.nav-tabs-justified>li>a{margin-right:0;border-radius:4px}.nav-tabs-justified>.active>a,.nav-tabs-justified>.active>a:focus,.nav-tabs-justified>.active>a:hover{border:1px solid #ddd}@media (min-width:768px){.nav-tabs-justified>li>a{border-bottom:1px solid #ddd;border-radius:4px 4px 0 0}.nav-tabs-justified>.active>a,.nav-tabs-justified>.active>a:focus,.nav-tabs-justified>.active>a:hover{border-bottom-color:#fff}}.tab-content>.tab-pane{display:none}.tab-content>.active{display:block}.nav-tabs .dropdown-menu{margin-top:-1px;border-top-left-radius:0;border-top-right-radius:0}.navbar{position:relative;min-height:50px;margin-bottom:20px;border:1px solid transparent}@media (min-width:768px){.navbar{border-radius:4px}}@media (min-width:768px){.navbar-header{float:left}}.navbar-collapse{padding-right:15px;padding-left:15px;overflow-x:visible;border-top:1px solid transparent;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,.1);box-shadow:inset 0 1px 0 rgba(255,255,255,.1);-webkit-overflow-scrolling:touch}.navbar-collapse.in{overflow-y:auto}@media (min-width:768px){.navbar-collapse{width:auto;border-top:0;-webkit-box-shadow:none;box-shadow:none}.navbar-collapse.collapse{display:block!important;height:auto!important;padding-bottom:0;overflow:visible!important}.navbar-collapse.in{overflow-y:visible}.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse,.navbar-static-top .navbar-collapse{padding-right:0;padding-left:0}}.navbar-fixed-bottom,.navbar-fixed-top{position:fixed;right:0;left:0;z-index:1030}.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse{max-height:340px}@media (max-device-width:480px) and (orientation:landscape){.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse{max-height:200px}}@media (min-width:768px){.navbar-fixed-bottom,.navbar-fixed-top{border-radius:0}}.navbar-fixed-top{top:0;border-width:0 0 1px}.navbar-fixed-bottom{bottom:0;margin-bottom:0;border-width:1px 0 0}.container-fluid>.navbar-collapse,.container-fluid>.navbar-header,.container>.navbar-collapse,.container>.navbar-header{margin-right:-15px;margin-left:-15px}@media (min-width:768px){.container-fluid>.navbar-collapse,.container-fluid>.navbar-header,.container>.navbar-collapse,.container>.navbar-header{margin-right:0;margin-left:0}}.navbar-static-top{z-index:1000;border-width:0 0 1px}@media (min-width:768px){.navbar-static-top{border-radius:0}}.navbar-brand{float:left;height:50px;padding:15px 15px;font-size:18px;line-height:20px}.navbar-brand:focus,.navbar-brand:hover{text-decoration:none}.navbar-brand>img{display:block}@media (min-width:768px){.navbar>.container .navbar-brand,.navbar>.container-fluid .navbar-brand{margin-left:-15px}}.navbar-toggle{position:relative;float:right;padding:9px 10px;margin-right:15px;margin-top:8px;margin-bottom:8px;background-color:transparent;background-image:none;border:1px solid transparent;border-radius:4px}.navbar-toggle:focus{outline:0}.navbar-toggle .icon-bar{display:block;width:22px;height:2px;border-radius:1px}.navbar-toggle .icon-bar+.icon-bar{margin-top:4px}@media (min-width:768px){.navbar-toggle{display:none}}.navbar-nav{margin:7.5px -15px}.navbar-nav>li>a{padding-top:10px;padding-bottom:10px;line-height:20px}@media (max-width:767px){.navbar-nav .open .dropdown-menu{position:static;float:none;width:auto;margin-top:0;background-color:transparent;border:0;-webkit-box-shadow:none;box-shadow:none}.navbar-nav .open .dropdown-menu .dropdown-header,.navbar-nav .open .dropdown-menu>li>a{padding:5px 15px 5px 25px}.navbar-nav .open .dropdown-menu>li>a{line-height:20px}.navbar-nav .open .dropdown-menu>li>a:focus,.navbar-nav .open .dropdown-menu>li>a:hover{background-image:none}}@media (min-width:768px){.navbar-nav{float:left;margin:0}.navbar-nav>li{float:left}.navbar-nav>li>a{padding-top:15px;padding-bottom:15px}}.navbar-form{padding:10px 15px;margin-right:-15px;margin-left:-15px;border-top:1px solid transparent;border-bottom:1px solid transparent;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 1px 0 rgba(255,255,255,.1);box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 1px 0 rgba(255,255,255,.1);margin-top:8px;margin-bottom:8px}@media (min-width:768px){.navbar-form .form-group{display:inline-block;margin-bottom:0;vertical-align:middle}.navbar-form .form-control{display:inline-block;width:auto;vertical-align:middle}.navbar-form .form-control-static{display:inline-block}.navbar-form .input-group{display:inline-table;vertical-align:middle}.navbar-form .input-group .form-control,.navbar-form .input-group .input-group-addon,.navbar-form .input-group .input-group-btn{width:auto}.navbar-form .input-group>.form-control{width:100%}.navbar-form .control-label{margin-bottom:0;vertical-align:middle}.navbar-form .checkbox,.navbar-form .radio{display:inline-block;margin-top:0;margin-bottom:0;vertical-align:middle}.navbar-form .checkbox label,.navbar-form .radio label{padding-left:0}.navbar-form .checkbox input[type=checkbox],.navbar-form .radio input[type=radio]{position:relative;margin-left:0}.navbar-form .has-feedback .form-control-feedback{top:0}}@media (max-width:767px){.navbar-form .form-group{margin-bottom:5px}.navbar-form .form-group:last-child{margin-bottom:0}}@media (min-width:768px){.navbar-form{width:auto;padding-top:0;padding-bottom:0;margin-right:0;margin-left:0;border:0;-webkit-box-shadow:none;box-shadow:none}}.navbar-nav>li>.dropdown-menu{margin-top:0;border-top-left-radius:0;border-top-right-radius:0}.navbar-fixed-bottom .navbar-nav>li>.dropdown-menu{margin-bottom:0;border-top-left-radius:4px;border-top-right-radius:4px;border-bottom-right-radius:0;border-bottom-left-radius:0}.navbar-btn{margin-top:8px;margin-bottom:8px}.navbar-btn.btn-sm{margin-top:10px;margin-bottom:10px}.navbar-btn.btn-xs{margin-top:14px;margin-bottom:14px}.navbar-text{margin-top:15px;margin-bottom:15px}@media (min-width:768px){.navbar-text{float:left;margin-right:15px;margin-left:15px}}@media (min-width:768px){.navbar-left{float:left!important}.navbar-right{float:right!important;margin-right:-15px}.navbar-right~.navbar-right{margin-right:0}}.navbar-default{background-color:#f8f8f8;border-color:#e7e7e7}.navbar-default .navbar-brand{color:#777}.navbar-default .navbar-brand:focus,.navbar-default .navbar-brand:hover{color:#5e5e5e;background-color:transparent}.navbar-default .navbar-text{color:#777}.navbar-default .navbar-nav>li>a{color:#777}.navbar-default .navbar-nav>li>a:focus,.navbar-default .navbar-nav>li>a:hover{color:#333;background-color:transparent}.navbar-default .navbar-nav>.active>a,.navbar-default .navbar-nav>.active>a:focus,.navbar-default .navbar-nav>.active>a:hover{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav>.disabled>a,.navbar-default .navbar-nav>.disabled>a:focus,.navbar-default .navbar-nav>.disabled>a:hover{color:#ccc;background-color:transparent}.navbar-default .navbar-nav>.open>a,.navbar-default .navbar-nav>.open>a:focus,.navbar-default .navbar-nav>.open>a:hover{color:#555;background-color:#e7e7e7}@media (max-width:767px){.navbar-default .navbar-nav .open .dropdown-menu>li>a{color:#777}.navbar-default .navbar-nav .open .dropdown-menu>li>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>li>a:hover{color:#333;background-color:transparent}.navbar-default .navbar-nav .open .dropdown-menu>.active>a,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:hover{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:hover{color:#ccc;background-color:transparent}}.navbar-default .navbar-toggle{border-color:#ddd}.navbar-default .navbar-toggle:focus,.navbar-default .navbar-toggle:hover{background-color:#ddd}.navbar-default .navbar-toggle .icon-bar{background-color:#888}.navbar-default .navbar-collapse,.navbar-default .navbar-form{border-color:#e7e7e7}.navbar-default .navbar-link{color:#777}.navbar-default .navbar-link:hover{color:#333}.navbar-default .btn-link{color:#777}.navbar-default .btn-link:focus,.navbar-default .btn-link:hover{color:#333}.navbar-default .btn-link[disabled]:focus,.navbar-default .btn-link[disabled]:hover,fieldset[disabled] .navbar-default .btn-link:focus,fieldset[disabled] .navbar-default .btn-link:hover{color:#ccc}.navbar-inverse{background-color:#222;border-color:#080808}.navbar-inverse .navbar-brand{color:#9d9d9d}.navbar-inverse .navbar-brand:focus,.navbar-inverse .navbar-brand:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-text{color:#9d9d9d}.navbar-inverse .navbar-nav>li>a{color:#9d9d9d}.navbar-inverse .navbar-nav>li>a:focus,.navbar-inverse .navbar-nav>li>a:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav>.active>a,.navbar-inverse .navbar-nav>.active>a:focus,.navbar-inverse .navbar-nav>.active>a:hover{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav>.disabled>a,.navbar-inverse .navbar-nav>.disabled>a:focus,.navbar-inverse .navbar-nav>.disabled>a:hover{color:#444;background-color:transparent}.navbar-inverse .navbar-nav>.open>a,.navbar-inverse .navbar-nav>.open>a:focus,.navbar-inverse .navbar-nav>.open>a:hover{color:#fff;background-color:#080808}@media (max-width:767px){.navbar-inverse .navbar-nav .open .dropdown-menu>.dropdown-header{border-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu .divider{background-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a{color:#9d9d9d}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:hover{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:hover{color:#444;background-color:transparent}}.navbar-inverse .navbar-toggle{border-color:#333}.navbar-inverse .navbar-toggle:focus,.navbar-inverse .navbar-toggle:hover{background-color:#333}.navbar-inverse .navbar-toggle .icon-bar{background-color:#fff}.navbar-inverse .navbar-collapse,.navbar-inverse .navbar-form{border-color:#101010}.navbar-inverse .navbar-link{color:#9d9d9d}.navbar-inverse .navbar-link:hover{color:#fff}.navbar-inverse .btn-link{color:#9d9d9d}.navbar-inverse .btn-link:focus,.navbar-inverse .btn-link:hover{color:#fff}.navbar-inverse .btn-link[disabled]:focus,.navbar-inverse .btn-link[disabled]:hover,fieldset[disabled] .navbar-inverse .btn-link:focus,fieldset[disabled] .navbar-inverse .btn-link:hover{color:#444}.breadcrumb{padding:8px 15px;margin-bottom:20px;list-style:none;background-color:#f5f5f5;border-radius:4px}.breadcrumb>li{display:inline-block}.breadcrumb>li+li:before{padding:0 5px;color:#ccc;content:"/\00a0"}.breadcrumb>.active{color:#777}.pagination{display:inline-block;padding-left:0;margin:20px 0;border-radius:4px}.pagination>li{display:inline}.pagination>li>a,.pagination>li>span{position:relative;float:left;padding:6px 12px;margin-left:-1px;line-height:1.42857143;color:#337ab7;text-decoration:none;background-color:#fff;border:1px solid #ddd}.pagination>li>a:focus,.pagination>li>a:hover,.pagination>li>span:focus,.pagination>li>span:hover{z-index:2;color:#23527c;background-color:#eee;border-color:#ddd}.pagination>li:first-child>a,.pagination>li:first-child>span{margin-left:0;border-top-left-radius:4px;border-bottom-left-radius:4px}.pagination>li:last-child>a,.pagination>li:last-child>span{border-top-right-radius:4px;border-bottom-right-radius:4px}.pagination>.active>a,.pagination>.active>a:focus,.pagination>.active>a:hover,.pagination>.active>span,.pagination>.active>span:focus,.pagination>.active>span:hover{z-index:3;color:#fff;cursor:default;background-color:#337ab7;border-color:#337ab7}.pagination>.disabled>a,.pagination>.disabled>a:focus,.pagination>.disabled>a:hover,.pagination>.disabled>span,.pagination>.disabled>span:focus,.pagination>.disabled>span:hover{color:#777;cursor:not-allowed;background-color:#fff;border-color:#ddd}.pagination-lg>li>a,.pagination-lg>li>span{padding:10px 16px;font-size:18px;line-height:1.3333333}.pagination-lg>li:first-child>a,.pagination-lg>li:first-child>span{border-top-left-radius:6px;border-bottom-left-radius:6px}.pagination-lg>li:last-child>a,.pagination-lg>li:last-child>span{border-top-right-radius:6px;border-bottom-right-radius:6px}.pagination-sm>li>a,.pagination-sm>li>span{padding:5px 10px;font-size:12px;line-height:1.5}.pagination-sm>li:first-child>a,.pagination-sm>li:first-child>span{border-top-left-radius:3px;border-bottom-left-radius:3px}.pagination-sm>li:last-child>a,.pagination-sm>li:last-child>span{border-top-right-radius:3px;border-bottom-right-radius:3px}.pager{padding-left:0;margin:20px 0;text-align:center;list-style:none}.pager li{display:inline}.pager li>a,.pager li>span{display:inline-block;padding:5px 14px;background-color:#fff;border:1px solid #ddd;border-radius:15px}.pager li>a:focus,.pager li>a:hover{text-decoration:none;background-color:#eee}.pager .next>a,.pager .next>span{float:right}.pager .previous>a,.pager .previous>span{float:left}.pager .disabled>a,.pager .disabled>a:focus,.pager .disabled>a:hover,.pager .disabled>span{color:#777;cursor:not-allowed;background-color:#fff}.label{display:inline;padding:.2em .6em .3em;font-size:75%;font-weight:700;line-height:1;color:#fff;text-align:center;white-space:nowrap;vertical-align:baseline;border-radius:.25em}a.label:focus,a.label:hover{color:#fff;text-decoration:none;cursor:pointer}.label:empty{display:none}.btn .label{position:relative;top:-1px}.label-default{background-color:#777}.label-default[href]:focus,.label-default[href]:hover{background-color:#5e5e5e}.label-primary{background-color:#337ab7}.label-primary[href]:focus,.label-primary[href]:hover{background-color:#286090}.label-success{background-color:#5cb85c}.label-success[href]:focus,.label-success[href]:hover{background-color:#449d44}.label-info{background-color:#5bc0de}.label-info[href]:focus,.label-info[href]:hover{background-color:#31b0d5}.label-warning{background-color:#f0ad4e}.label-warning[href]:focus,.label-warning[href]:hover{background-color:#ec971f}.label-danger{background-color:#d9534f}.label-danger[href]:focus,.label-danger[href]:hover{background-color:#c9302c}.badge{display:inline-block;min-width:10px;padding:3px 7px;font-size:12px;font-weight:700;line-height:1;color:#fff;text-align:center;white-space:nowrap;vertical-align:middle;background-color:#777;border-radius:10px}.badge:empty{display:none}.btn .badge{position:relative;top:-1px}.btn-group-xs>.btn .badge,.btn-xs .badge{top:0;padding:1px 5px}a.badge:focus,a.badge:hover{color:#fff;text-decoration:none;cursor:pointer}.list-group-item.active>.badge,.nav-pills>.active>a>.badge{color:#337ab7;background-color:#fff}.list-group-item>.badge{float:right}.list-group-item>.badge+.badge{margin-right:5px}.nav-pills>li>a>.badge{margin-left:3px}.jumbotron{padding-top:30px;padding-bottom:30px;margin-bottom:30px;color:inherit;background-color:#eee}.jumbotron .h1,.jumbotron h1{color:inherit}.jumbotron p{margin-bottom:15px;font-size:21px;font-weight:200}.jumbotron>hr{border-top-color:#d5d5d5}.container .jumbotron,.container-fluid .jumbotron{padding-right:15px;padding-left:15px;border-radius:6px}.jumbotron .container{max-width:100%}@media screen and (min-width:768px){.jumbotron{padding-top:48px;padding-bottom:48px}.container .jumbotron,.container-fluid .jumbotron{padding-right:60px;padding-left:60px}.jumbotron .h1,.jumbotron h1{font-size:63px}}.thumbnail{display:block;padding:4px;margin-bottom:20px;line-height:1.42857143;background-color:#fff;border:1px solid #ddd;border-radius:4px;-webkit-transition:border .2s ease-in-out;-o-transition:border .2s ease-in-out;transition:border .2s ease-in-out}.thumbnail a>img,.thumbnail>img{margin-right:auto;margin-left:auto}a.thumbnail.active,a.thumbnail:focus,a.thumbnail:hover{border-color:#337ab7}.thumbnail .caption{padding:9px;color:#333}.alert{padding:15px;margin-bottom:20px;border:1px solid transparent;border-radius:4px}.alert h4{margin-top:0;color:inherit}.alert .alert-link{font-weight:700}.alert>p,.alert>ul{margin-bottom:0}.alert>p+p{margin-top:5px}.alert-dismissable,.alert-dismissible{padding-right:35px}.alert-dismissable .close,.alert-dismissible .close{position:relative;top:-2px;right:-21px;color:inherit}.alert-success{color:#3c763d;background-color:#dff0d8;border-color:#d6e9c6}.alert-success hr{border-top-color:#c9e2b3}.alert-success .alert-link{color:#2b542c}.alert-info{color:#31708f;background-color:#d9edf7;border-color:#bce8f1}.alert-info hr{border-top-color:#a6e1ec}.alert-info .alert-link{color:#245269}.alert-warning{color:#8a6d3b;background-color:#fcf8e3;border-color:#faebcc}.alert-warning hr{border-top-color:#f7e1b5}.alert-warning .alert-link{color:#66512c}.alert-danger{color:#a94442;background-color:#f2dede;border-color:#ebccd1}.alert-danger hr{border-top-color:#e4b9c0}.alert-danger .alert-link{color:#843534}@-webkit-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-o-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}.progress{height:20px;margin-bottom:20px;overflow:hidden;background-color:#f5f5f5;border-radius:4px;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,.1);box-shadow:inset 0 1px 2px rgba(0,0,0,.1)}.progress-bar{float:left;width:0%;height:100%;font-size:12px;line-height:20px;color:#fff;text-align:center;background-color:#337ab7;-webkit-box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);-webkit-transition:width .6s ease;-o-transition:width .6s ease;transition:width .6s ease}.progress-bar-striped,.progress-striped .progress-bar{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);-webkit-background-size:40px 40px;background-size:40px 40px}.progress-bar.active,.progress.active .progress-bar{-webkit-animation:progress-bar-stripes 2s linear infinite;-o-animation:progress-bar-stripes 2s linear infinite;animation:progress-bar-stripes 2s linear infinite}.progress-bar-success{background-color:#5cb85c}.progress-striped .progress-bar-success{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-info{background-color:#5bc0de}.progress-striped .progress-bar-info{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-warning{background-color:#f0ad4e}.progress-striped .progress-bar-warning{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-danger{background-color:#d9534f}.progress-striped .progress-bar-danger{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.media{margin-top:15px}.media:first-child{margin-top:0}.media,.media-body{overflow:hidden;zoom:1}.media-body{width:10000px}.media-object{display:block}.media-object.img-thumbnail{max-width:none}.media-right,.media>.pull-right{padding-left:10px}.media-left,.media>.pull-left{padding-right:10px}.media-body,.media-left,.media-right{display:table-cell;vertical-align:top}.media-middle{vertical-align:middle}.media-bottom{vertical-align:bottom}.media-heading{margin-top:0;margin-bottom:5px}.media-list{padding-left:0;list-style:none}.list-group{padding-left:0;margin-bottom:20px}.list-group-item{position:relative;display:block;padding:10px 15px;margin-bottom:-1px;background-color:#fff;border:1px solid #ddd}.list-group-item:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.list-group-item:last-child{margin-bottom:0;border-bottom-right-radius:4px;border-bottom-left-radius:4px}.list-group-item.disabled,.list-group-item.disabled:focus,.list-group-item.disabled:hover{color:#777;cursor:not-allowed;background-color:#eee}.list-group-item.disabled .list-group-item-heading,.list-group-item.disabled:focus .list-group-item-heading,.list-group-item.disabled:hover .list-group-item-heading{color:inherit}.list-group-item.disabled .list-group-item-text,.list-group-item.disabled:focus .list-group-item-text,.list-group-item.disabled:hover .list-group-item-text{color:#777}.list-group-item.active,.list-group-item.active:focus,.list-group-item.active:hover{z-index:2;color:#fff;background-color:#337ab7;border-color:#337ab7}.list-group-item.active .list-group-item-heading,.list-group-item.active .list-group-item-heading>.small,.list-group-item.active .list-group-item-heading>small,.list-group-item.active:focus .list-group-item-heading,.list-group-item.active:focus .list-group-item-heading>.small,.list-group-item.active:focus .list-group-item-heading>small,.list-group-item.active:hover .list-group-item-heading,.list-group-item.active:hover .list-group-item-heading>.small,.list-group-item.active:hover .list-group-item-heading>small{color:inherit}.list-group-item.active .list-group-item-text,.list-group-item.active:focus .list-group-item-text,.list-group-item.active:hover .list-group-item-text{color:#c7ddef}a.list-group-item,button.list-group-item{color:#555}a.list-group-item .list-group-item-heading,button.list-group-item .list-group-item-heading{color:#333}a.list-group-item:focus,a.list-group-item:hover,button.list-group-item:focus,button.list-group-item:hover{color:#555;text-decoration:none;background-color:#f5f5f5}button.list-group-item{width:100%;text-align:left}.list-group-item-success{color:#3c763d;background-color:#dff0d8}a.list-group-item-success,button.list-group-item-success{color:#3c763d}a.list-group-item-success .list-group-item-heading,button.list-group-item-success .list-group-item-heading{color:inherit}a.list-group-item-success:focus,a.list-group-item-success:hover,button.list-group-item-success:focus,button.list-group-item-success:hover{color:#3c763d;background-color:#d0e9c6}a.list-group-item-success.active,a.list-group-item-success.active:focus,a.list-group-item-success.active:hover,button.list-group-item-success.active,button.list-group-item-success.active:focus,button.list-group-item-success.active:hover{color:#fff;background-color:#3c763d;border-color:#3c763d}.list-group-item-info{color:#31708f;background-color:#d9edf7}a.list-group-item-info,button.list-group-item-info{color:#31708f}a.list-group-item-info .list-group-item-heading,button.list-group-item-info .list-group-item-heading{color:inherit}a.list-group-item-info:focus,a.list-group-item-info:hover,button.list-group-item-info:focus,button.list-group-item-info:hover{color:#31708f;background-color:#c4e3f3}a.list-group-item-info.active,a.list-group-item-info.active:focus,a.list-group-item-info.active:hover,button.list-group-item-info.active,button.list-group-item-info.active:focus,button.list-group-item-info.active:hover{color:#fff;background-color:#31708f;border-color:#31708f}.list-group-item-warning{color:#8a6d3b;background-color:#fcf8e3}a.list-group-item-warning,button.list-group-item-warning{color:#8a6d3b}a.list-group-item-warning .list-group-item-heading,button.list-group-item-warning .list-group-item-heading{color:inherit}a.list-group-item-warning:focus,a.list-group-item-warning:hover,button.list-group-item-warning:focus,button.list-group-item-warning:hover{color:#8a6d3b;background-color:#faf2cc}a.list-group-item-warning.active,a.list-group-item-warning.active:focus,a.list-group-item-warning.active:hover,button.list-group-item-warning.active,button.list-group-item-warning.active:focus,button.list-group-item-warning.active:hover{color:#fff;background-color:#8a6d3b;border-color:#8a6d3b}.list-group-item-danger{color:#a94442;background-color:#f2dede}a.list-group-item-danger,button.list-group-item-danger{color:#a94442}a.list-group-item-danger .list-group-item-heading,button.list-group-item-danger .list-group-item-heading{color:inherit}a.list-group-item-danger:focus,a.list-group-item-danger:hover,button.list-group-item-danger:focus,button.list-group-item-danger:hover{color:#a94442;background-color:#ebcccc}a.list-group-item-danger.active,a.list-group-item-danger.active:focus,a.list-group-item-danger.active:hover,button.list-group-item-danger.active,button.list-group-item-danger.active:focus,button.list-group-item-danger.active:hover{color:#fff;background-color:#a94442;border-color:#a94442}.list-group-item-heading{margin-top:0;margin-bottom:5px}.list-group-item-text{margin-bottom:0;line-height:1.3}.panel{margin-bottom:20px;background-color:#fff;border:1px solid transparent;border-radius:4px;-webkit-box-shadow:0 1px 1px rgba(0,0,0,.05);box-shadow:0 1px 1px rgba(0,0,0,.05)}.panel-body{padding:15px}.panel-heading{padding:10px 15px;border-bottom:1px solid transparent;border-top-left-radius:3px;border-top-right-radius:3px}.panel-heading>.dropdown .dropdown-toggle{color:inherit}.panel-title{margin-top:0;margin-bottom:0;font-size:16px;color:inherit}.panel-title>.small,.panel-title>.small>a,.panel-title>a,.panel-title>small,.panel-title>small>a{color:inherit}.panel-footer{padding:10px 15px;background-color:#f5f5f5;border-top:1px solid #ddd;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.list-group,.panel>.panel-collapse>.list-group{margin-bottom:0}.panel>.list-group .list-group-item,.panel>.panel-collapse>.list-group .list-group-item{border-width:1px 0;border-radius:0}.panel>.list-group:first-child .list-group-item:first-child,.panel>.panel-collapse>.list-group:first-child .list-group-item:first-child{border-top:0;border-top-left-radius:3px;border-top-right-radius:3px}.panel>.list-group:last-child .list-group-item:last-child,.panel>.panel-collapse>.list-group:last-child .list-group-item:last-child{border-bottom:0;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.panel-heading+.panel-collapse>.list-group .list-group-item:first-child{border-top-left-radius:0;border-top-right-radius:0}.panel-heading+.list-group .list-group-item:first-child{border-top-width:0}.list-group+.panel-footer{border-top-width:0}.panel>.panel-collapse>.table,.panel>.table,.panel>.table-responsive>.table{margin-bottom:0}.panel>.panel-collapse>.table caption,.panel>.table caption,.panel>.table-responsive>.table caption{padding-right:15px;padding-left:15px}.panel>.table-responsive:first-child>.table:first-child,.panel>.table:first-child{border-top-left-radius:3px;border-top-right-radius:3px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child,.panel>.table:first-child>thead:first-child>tr:first-child{border-top-left-radius:3px;border-top-right-radius:3px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child td:first-child,.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child th:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child td:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child th:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child td:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child th:first-child,.panel>.table:first-child>thead:first-child>tr:first-child td:first-child,.panel>.table:first-child>thead:first-child>tr:first-child th:first-child{border-top-left-radius:3px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child td:last-child,.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child th:last-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child td:last-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child th:last-child,.panel>.table:first-child>tbody:first-child>tr:first-child td:last-child,.panel>.table:first-child>tbody:first-child>tr:first-child th:last-child,.panel>.table:first-child>thead:first-child>tr:first-child td:last-child,.panel>.table:first-child>thead:first-child>tr:first-child th:last-child{border-top-right-radius:3px}.panel>.table-responsive:last-child>.table:last-child,.panel>.table:last-child{border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child{border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child td:first-child,.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child th:first-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child td:first-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child th:first-child,.panel>.table:last-child>tbody:last-child>tr:last-child td:first-child,.panel>.table:last-child>tbody:last-child>tr:last-child th:first-child,.panel>.table:last-child>tfoot:last-child>tr:last-child td:first-child,.panel>.table:last-child>tfoot:last-child>tr:last-child th:first-child{border-bottom-left-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child td:last-child,.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child th:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child td:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child th:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child td:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child th:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child td:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child th:last-child{border-bottom-right-radius:3px}.panel>.panel-body+.table,.panel>.panel-body+.table-responsive,.panel>.table+.panel-body,.panel>.table-responsive+.panel-body{border-top:1px solid #ddd}.panel>.table>tbody:first-child>tr:first-child td,.panel>.table>tbody:first-child>tr:first-child th{border-top:0}.panel>.table-bordered,.panel>.table-responsive>.table-bordered{border:0}.panel>.table-bordered>tbody>tr>td:first-child,.panel>.table-bordered>tbody>tr>th:first-child,.panel>.table-bordered>tfoot>tr>td:first-child,.panel>.table-bordered>tfoot>tr>th:first-child,.panel>.table-bordered>thead>tr>td:first-child,.panel>.table-bordered>thead>tr>th:first-child,.panel>.table-responsive>.table-bordered>tbody>tr>td:first-child,.panel>.table-responsive>.table-bordered>tbody>tr>th:first-child,.panel>.table-responsive>.table-bordered>tfoot>tr>td:first-child,.panel>.table-responsive>.table-bordered>tfoot>tr>th:first-child,.panel>.table-responsive>.table-bordered>thead>tr>td:first-child,.panel>.table-responsive>.table-bordered>thead>tr>th:first-child{border-left:0}.panel>.table-bordered>tbody>tr>td:last-child,.panel>.table-bordered>tbody>tr>th:last-child,.panel>.table-bordered>tfoot>tr>td:last-child,.panel>.table-bordered>tfoot>tr>th:last-child,.panel>.table-bordered>thead>tr>td:last-child,.panel>.table-bordered>thead>tr>th:last-child,.panel>.table-responsive>.table-bordered>tbody>tr>td:last-child,.panel>.table-responsive>.table-bordered>tbody>tr>th:last-child,.panel>.table-responsive>.table-bordered>tfoot>tr>td:last-child,.panel>.table-responsive>.table-bordered>tfoot>tr>th:last-child,.panel>.table-responsive>.table-bordered>thead>tr>td:last-child,.panel>.table-responsive>.table-bordered>thead>tr>th:last-child{border-right:0}.panel>.table-bordered>tbody>tr:first-child>td,.panel>.table-bordered>tbody>tr:first-child>th,.panel>.table-bordered>thead>tr:first-child>td,.panel>.table-bordered>thead>tr:first-child>th,.panel>.table-responsive>.table-bordered>tbody>tr:first-child>td,.panel>.table-responsive>.table-bordered>tbody>tr:first-child>th,.panel>.table-responsive>.table-bordered>thead>tr:first-child>td,.panel>.table-responsive>.table-bordered>thead>tr:first-child>th{border-bottom:0}.panel>.table-bordered>tbody>tr:last-child>td,.panel>.table-bordered>tbody>tr:last-child>th,.panel>.table-bordered>tfoot>tr:last-child>td,.panel>.table-bordered>tfoot>tr:last-child>th,.panel>.table-responsive>.table-bordered>tbody>tr:last-child>td,.panel>.table-responsive>.table-bordered>tbody>tr:last-child>th,.panel>.table-responsive>.table-bordered>tfoot>tr:last-child>td,.panel>.table-responsive>.table-bordered>tfoot>tr:last-child>th{border-bottom:0}.panel>.table-responsive{margin-bottom:0;border:0}.panel-group{margin-bottom:20px}.panel-group .panel{margin-bottom:0;border-radius:4px}.panel-group .panel+.panel{margin-top:5px}.panel-group .panel-heading{border-bottom:0}.panel-group .panel-heading+.panel-collapse>.list-group,.panel-group .panel-heading+.panel-collapse>.panel-body{border-top:1px solid #ddd}.panel-group .panel-footer{border-top:0}.panel-group .panel-footer+.panel-collapse .panel-body{border-bottom:1px solid #ddd}.panel-default{border-color:#ddd}.panel-default>.panel-heading{color:#333;background-color:#f5f5f5;border-color:#ddd}.panel-default>.panel-heading+.panel-collapse>.panel-body{border-top-color:#ddd}.panel-default>.panel-heading .badge{color:#f5f5f5;background-color:#333}.panel-default>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#ddd}.panel-primary{border-color:#337ab7}.panel-primary>.panel-heading{color:#fff;background-color:#337ab7;border-color:#337ab7}.panel-primary>.panel-heading+.panel-collapse>.panel-body{border-top-color:#337ab7}.panel-primary>.panel-heading .badge{color:#337ab7;background-color:#fff}.panel-primary>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#337ab7}.panel-success{border-color:#d6e9c6}.panel-success>.panel-heading{color:#3c763d;background-color:#dff0d8;border-color:#d6e9c6}.panel-success>.panel-heading+.panel-collapse>.panel-body{border-top-color:#d6e9c6}.panel-success>.panel-heading .badge{color:#dff0d8;background-color:#3c763d}.panel-success>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#d6e9c6}.panel-info{border-color:#bce8f1}.panel-info>.panel-heading{color:#31708f;background-color:#d9edf7;border-color:#bce8f1}.panel-info>.panel-heading+.panel-collapse>.panel-body{border-top-color:#bce8f1}.panel-info>.panel-heading .badge{color:#d9edf7;background-color:#31708f}.panel-info>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#bce8f1}.panel-warning{border-color:#faebcc}.panel-warning>.panel-heading{color:#8a6d3b;background-color:#fcf8e3;border-color:#faebcc}.panel-warning>.panel-heading+.panel-collapse>.panel-body{border-top-color:#faebcc}.panel-warning>.panel-heading .badge{color:#fcf8e3;background-color:#8a6d3b}.panel-warning>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#faebcc}.panel-danger{border-color:#ebccd1}.panel-danger>.panel-heading{color:#a94442;background-color:#f2dede;border-color:#ebccd1}.panel-danger>.panel-heading+.panel-collapse>.panel-body{border-top-color:#ebccd1}.panel-danger>.panel-heading .badge{color:#f2dede;background-color:#a94442}.panel-danger>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#ebccd1}.embed-responsive{position:relative;display:block;height:0;padding:0;overflow:hidden}.embed-responsive .embed-responsive-item,.embed-responsive embed,.embed-responsive iframe,.embed-responsive object,.embed-responsive video{position:absolute;top:0;bottom:0;left:0;width:100%;height:100%;border:0}.embed-responsive-16by9{padding-bottom:56.25%}.embed-responsive-4by3{padding-bottom:75%}.well{min-height:20px;padding:19px;margin-bottom:20px;background-color:#f5f5f5;border:1px solid #e3e3e3;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.05);box-shadow:inset 0 1px 1px rgba(0,0,0,.05)}.well blockquote{border-color:#ddd;border-color:rgba(0,0,0,.15)}.well-lg{padding:24px;border-radius:6px}.well-sm{padding:9px;border-radius:3px}.close{float:right;font-size:21px;font-weight:700;line-height:1;color:#000;text-shadow:0 1px 0 #fff;filter:alpha(opacity=20);opacity:.2}.close:focus,.close:hover{color:#000;text-decoration:none;cursor:pointer;filter:alpha(opacity=50);opacity:.5}button.close{padding:0;cursor:pointer;background:0 0;border:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}.modal-open{overflow:hidden}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1050;display:none;overflow:hidden;-webkit-overflow-scrolling:touch;outline:0}.modal.fade .modal-dialog{-webkit-transform:translate(0,-25%);-ms-transform:translate(0,-25%);-o-transform:translate(0,-25%);transform:translate(0,-25%);-webkit-transition:-webkit-transform .3s ease-out;-o-transition:-o-transform .3s ease-out;transition:-webkit-transform .3s ease-out;transition:transform .3s ease-out;transition:transform .3s ease-out,-webkit-transform .3s ease-out,-o-transform .3s ease-out}.modal.in .modal-dialog{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);-o-transform:translate(0,0);transform:translate(0,0)}.modal-open .modal{overflow-x:hidden;overflow-y:auto}.modal-dialog{position:relative;width:auto;margin:10px}.modal-content{position:relative;background-color:#fff;background-clip:padding-box;border:1px solid #999;border:1px solid rgba(0,0,0,.2);border-radius:6px;-webkit-box-shadow:0 3px 9px rgba(0,0,0,.5);box-shadow:0 3px 9px rgba(0,0,0,.5);outline:0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1040;background-color:#000}.modal-backdrop.fade{filter:alpha(opacity=0);opacity:0}.modal-backdrop.in{filter:alpha(opacity=50);opacity:.5}.modal-header{padding:15px;border-bottom:1px solid #e5e5e5}.modal-header .close{margin-top:-2px}.modal-title{margin:0;line-height:1.42857143}.modal-body{position:relative;padding:15px}.modal-footer{padding:15px;text-align:right;border-top:1px solid #e5e5e5}.modal-footer .btn+.btn{margin-bottom:0;margin-left:5px}.modal-footer .btn-group .btn+.btn{margin-left:-1px}.modal-footer .btn-block+.btn-block{margin-left:0}.modal-scrollbar-measure{position:absolute;top:-9999px;width:50px;height:50px;overflow:scroll}@media (min-width:768px){.modal-dialog{width:600px;margin:30px auto}.modal-content{-webkit-box-shadow:0 5px 15px rgba(0,0,0,.5);box-shadow:0 5px 15px rgba(0,0,0,.5)}.modal-sm{width:300px}}@media (min-width:992px){.modal-lg{width:900px}}.tooltip{position:absolute;z-index:1070;display:block;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-style:normal;font-weight:400;line-height:1.42857143;line-break:auto;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;word-wrap:normal;white-space:normal;font-size:12px;filter:alpha(opacity=0);opacity:0}.tooltip.in{filter:alpha(opacity=90);opacity:.9}.tooltip.top{padding:5px 0;margin-top:-3px}.tooltip.right{padding:0 5px;margin-left:3px}.tooltip.bottom{padding:5px 0;margin-top:3px}.tooltip.left{padding:0 5px;margin-left:-3px}.tooltip.top .tooltip-arrow{bottom:0;left:50%;margin-left:-5px;border-width:5px 5px 0;border-top-color:#000}.tooltip.top-left .tooltip-arrow{right:5px;bottom:0;margin-bottom:-5px;border-width:5px 5px 0;border-top-color:#000}.tooltip.top-right .tooltip-arrow{bottom:0;left:5px;margin-bottom:-5px;border-width:5px 5px 0;border-top-color:#000}.tooltip.right .tooltip-arrow{top:50%;left:0;margin-top:-5px;border-width:5px 5px 5px 0;border-right-color:#000}.tooltip.left .tooltip-arrow{top:50%;right:0;margin-top:-5px;border-width:5px 0 5px 5px;border-left-color:#000}.tooltip.bottom .tooltip-arrow{top:0;left:50%;margin-left:-5px;border-width:0 5px 5px;border-bottom-color:#000}.tooltip.bottom-left .tooltip-arrow{top:0;right:5px;margin-top:-5px;border-width:0 5px 5px;border-bottom-color:#000}.tooltip.bottom-right .tooltip-arrow{top:0;left:5px;margin-top:-5px;border-width:0 5px 5px;border-bottom-color:#000}.tooltip-inner{max-width:200px;padding:3px 8px;color:#fff;text-align:center;background-color:#000;border-radius:4px}.tooltip-arrow{position:absolute;width:0;height:0;border-color:transparent;border-style:solid}.popover{position:absolute;top:0;left:0;z-index:1060;display:none;max-width:276px;padding:1px;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-style:normal;font-weight:400;line-height:1.42857143;line-break:auto;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;word-wrap:normal;white-space:normal;font-size:14px;background-color:#fff;background-clip:padding-box;border:1px solid #ccc;border:1px solid rgba(0,0,0,.2);border-radius:6px;-webkit-box-shadow:0 5px 10px rgba(0,0,0,.2);box-shadow:0 5px 10px rgba(0,0,0,.2)}.popover.top{margin-top:-10px}.popover.right{margin-left:10px}.popover.bottom{margin-top:10px}.popover.left{margin-left:-10px}.popover>.arrow{border-width:11px}.popover>.arrow,.popover>.arrow:after{position:absolute;display:block;width:0;height:0;border-color:transparent;border-style:solid}.popover>.arrow:after{content:"";border-width:10px}.popover.top>.arrow{bottom:-11px;left:50%;margin-left:-11px;border-top-color:#999;border-top-color:rgba(0,0,0,.25);border-bottom-width:0}.popover.top>.arrow:after{bottom:1px;margin-left:-10px;content:" ";border-top-color:#fff;border-bottom-width:0}.popover.right>.arrow{top:50%;left:-11px;margin-top:-11px;border-right-color:#999;border-right-color:rgba(0,0,0,.25);border-left-width:0}.popover.right>.arrow:after{bottom:-10px;left:1px;content:" ";border-right-color:#fff;border-left-width:0}.popover.bottom>.arrow{top:-11px;left:50%;margin-left:-11px;border-top-width:0;border-bottom-color:#999;border-bottom-color:rgba(0,0,0,.25)}.popover.bottom>.arrow:after{top:1px;margin-left:-10px;content:" ";border-top-width:0;border-bottom-color:#fff}.popover.left>.arrow{top:50%;right:-11px;margin-top:-11px;border-right-width:0;border-left-color:#999;border-left-color:rgba(0,0,0,.25)}.popover.left>.arrow:after{right:1px;bottom:-10px;content:" ";border-right-width:0;border-left-color:#fff}.popover-title{padding:8px 14px;margin:0;font-size:14px;background-color:#f7f7f7;border-bottom:1px solid #ebebeb;border-radius:5px 5px 0 0}.popover-content{padding:9px 14px}.carousel{position:relative}.carousel-inner{position:relative;width:100%;overflow:hidden}.carousel-inner>.item{position:relative;display:none;-webkit-transition:.6s ease-in-out left;-o-transition:.6s ease-in-out left;transition:.6s ease-in-out left}.carousel-inner>.item>a>img,.carousel-inner>.item>img{line-height:1}@media all and (transform-3d),(-webkit-transform-3d){.carousel-inner>.item{-webkit-transition:-webkit-transform .6s ease-in-out;-o-transition:-o-transform .6s ease-in-out;transition:-webkit-transform .6s ease-in-out;transition:transform .6s ease-in-out;transition:transform .6s ease-in-out,-webkit-transform .6s ease-in-out,-o-transform .6s ease-in-out;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-perspective:1000px;perspective:1000px}.carousel-inner>.item.active.right,.carousel-inner>.item.next{-webkit-transform:translate3d(100%,0,0);transform:translate3d(100%,0,0);left:0}.carousel-inner>.item.active.left,.carousel-inner>.item.prev{-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0);left:0}.carousel-inner>.item.active,.carousel-inner>.item.next.left,.carousel-inner>.item.prev.right{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0);left:0}}.carousel-inner>.active,.carousel-inner>.next,.carousel-inner>.prev{display:block}.carousel-inner>.active{left:0}.carousel-inner>.next,.carousel-inner>.prev{position:absolute;top:0;width:100%}.carousel-inner>.next{left:100%}.carousel-inner>.prev{left:-100%}.carousel-inner>.next.left,.carousel-inner>.prev.right{left:0}.carousel-inner>.active.left{left:-100%}.carousel-inner>.active.right{left:100%}.carousel-control{position:absolute;top:0;bottom:0;left:0;width:15%;font-size:20px;color:#fff;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.6);background-color:rgba(0,0,0,0);filter:alpha(opacity=50);opacity:.5}.carousel-control.left{background-image:-webkit-linear-gradient(left,rgba(0,0,0,.5) 0,rgba(0,0,0,.0001) 100%);background-image:-o-linear-gradient(left,rgba(0,0,0,.5) 0,rgba(0,0,0,.0001) 100%);background-image:-webkit-gradient(linear,left top,right top,from(rgba(0,0,0,.5)),to(rgba(0,0,0,.0001)));background-image:linear-gradient(to right,rgba(0,0,0,.5) 0,rgba(0,0,0,.0001) 100%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#80000000', endColorstr='#00000000', GradientType=1);background-repeat:repeat-x}.carousel-control.right{right:0;left:auto;background-image:-webkit-linear-gradient(left,rgba(0,0,0,.0001) 0,rgba(0,0,0,.5) 100%);background-image:-o-linear-gradient(left,rgba(0,0,0,.0001) 0,rgba(0,0,0,.5) 100%);background-image:-webkit-gradient(linear,left top,right top,from(rgba(0,0,0,.0001)),to(rgba(0,0,0,.5)));background-image:linear-gradient(to right,rgba(0,0,0,.0001) 0,rgba(0,0,0,.5) 100%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#80000000', GradientType=1);background-repeat:repeat-x}.carousel-control:focus,.carousel-control:hover{color:#fff;text-decoration:none;outline:0;filter:alpha(opacity=90);opacity:.9}.carousel-control .glyphicon-chevron-left,.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next,.carousel-control .icon-prev{position:absolute;top:50%;z-index:5;display:inline-block;margin-top:-10px}.carousel-control .glyphicon-chevron-left,.carousel-control .icon-prev{left:50%;margin-left:-10px}.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next{right:50%;margin-right:-10px}.carousel-control .icon-next,.carousel-control .icon-prev{width:20px;height:20px;font-family:serif;line-height:1}.carousel-control .icon-prev:before{content:"\2039"}.carousel-control .icon-next:before{content:"\203a"}.carousel-indicators{position:absolute;bottom:10px;left:50%;z-index:15;width:60%;padding-left:0;margin-left:-30%;text-align:center;list-style:none}.carousel-indicators li{display:inline-block;width:10px;height:10px;margin:1px;text-indent:-999px;cursor:pointer;background-color:#000\9;background-color:rgba(0,0,0,0);border:1px solid #fff;border-radius:10px}.carousel-indicators .active{width:12px;height:12px;margin:0;background-color:#fff}.carousel-caption{position:absolute;right:15%;bottom:20px;left:15%;z-index:10;padding-top:20px;padding-bottom:20px;color:#fff;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.6)}.carousel-caption .btn{text-shadow:none}@media screen and (min-width:768px){.carousel-control .glyphicon-chevron-left,.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next,.carousel-control .icon-prev{width:30px;height:30px;margin-top:-10px;font-size:30px}.carousel-control .glyphicon-chevron-left,.carousel-control .icon-prev{margin-left:-10px}.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next{margin-right:-10px}.carousel-caption{right:20%;left:20%;padding-bottom:30px}.carousel-indicators{bottom:20px}}.btn-group-vertical>.btn-group:after,.btn-group-vertical>.btn-group:before,.btn-toolbar:after,.btn-toolbar:before,.clearfix:after,.clearfix:before,.container-fluid:after,.container-fluid:before,.container:after,.container:before,.dl-horizontal dd:after,.dl-horizontal dd:before,.form-horizontal .form-group:after,.form-horizontal .form-group:before,.modal-footer:after,.modal-footer:before,.modal-header:after,.modal-header:before,.nav:after,.nav:before,.navbar-collapse:after,.navbar-collapse:before,.navbar-header:after,.navbar-header:before,.navbar:after,.navbar:before,.pager:after,.pager:before,.panel-body:after,.panel-body:before,.row:after,.row:before{display:table;content:" "}.btn-group-vertical>.btn-group:after,.btn-toolbar:after,.clearfix:after,.container-fluid:after,.container:after,.dl-horizontal dd:after,.form-horizontal .form-group:after,.modal-footer:after,.modal-header:after,.nav:after,.navbar-collapse:after,.navbar-header:after,.navbar:after,.pager:after,.panel-body:after,.row:after{clear:both}.center-block{display:block;margin-right:auto;margin-left:auto}.pull-right{float:right!important}.pull-left{float:left!important}.hide{display:none!important}.show{display:block!important}.invisible{visibility:hidden}.text-hide{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0}.hidden{display:none!important}.affix{position:fixed}@-ms-viewport{width:device-width}.visible-lg,.visible-md,.visible-sm,.visible-xs{display:none!important}.visible-lg-block,.visible-lg-inline,.visible-lg-inline-block,.visible-md-block,.visible-md-inline,.visible-md-inline-block,.visible-sm-block,.visible-sm-inline,.visible-sm-inline-block,.visible-xs-block,.visible-xs-inline,.visible-xs-inline-block{display:none!important}@media (max-width:767px){.visible-xs{display:block!important}table.visible-xs{display:table!important}tr.visible-xs{display:table-row!important}td.visible-xs,th.visible-xs{display:table-cell!important}}@media (max-width:767px){.visible-xs-block{display:block!important}}@media (max-width:767px){.visible-xs-inline{display:inline!important}}@media (max-width:767px){.visible-xs-inline-block{display:inline-block!important}}@media (min-width:768px) and (max-width:991px){.visible-sm{display:block!important}table.visible-sm{display:table!important}tr.visible-sm{display:table-row!important}td.visible-sm,th.visible-sm{display:table-cell!important}}@media (min-width:768px) and (max-width:991px){.visible-sm-block{display:block!important}}@media (min-width:768px) and (max-width:991px){.visible-sm-inline{display:inline!important}}@media (min-width:768px) and (max-width:991px){.visible-sm-inline-block{display:inline-block!important}}@media (min-width:992px) and (max-width:1199px){.visible-md{display:block!important}table.visible-md{display:table!important}tr.visible-md{display:table-row!important}td.visible-md,th.visible-md{display:table-cell!important}}@media (min-width:992px) and (max-width:1199px){.visible-md-block{display:block!important}}@media (min-width:992px) and (max-width:1199px){.visible-md-inline{display:inline!important}}@media (min-width:992px) and (max-width:1199px){.visible-md-inline-block{display:inline-block!important}}@media (min-width:1200px){.visible-lg{display:block!important}table.visible-lg{display:table!important}tr.visible-lg{display:table-row!important}td.visible-lg,th.visible-lg{display:table-cell!important}}@media (min-width:1200px){.visible-lg-block{display:block!important}}@media (min-width:1200px){.visible-lg-inline{display:inline!important}}@media (min-width:1200px){.visible-lg-inline-block{display:inline-block!important}}@media (max-width:767px){.hidden-xs{display:none!important}}@media (min-width:768px) and (max-width:991px){.hidden-sm{display:none!important}}@media (min-width:992px) and (max-width:1199px){.hidden-md{display:none!important}}@media (min-width:1200px){.hidden-lg{display:none!important}}.visible-print{display:none!important}@media print{.visible-print{display:block!important}table.visible-print{display:table!important}tr.visible-print{display:table-row!important}td.visible-print,th.visible-print{display:table-cell!important}}.visible-print-block{display:none!important}@media print{.visible-print-block{display:block!important}}.visible-print-inline{display:none!important}@media print{.visible-print-inline{display:inline!important}}.visible-print-inline-block{display:none!important}@media print{.visible-print-inline-block{display:inline-block!important}}@media print{.hidden-print{display:none!important}}
6
+ /*# sourceMappingURL=bootstrap.min.css.map */
includes/css/codemirror.min.css ADDED
@@ -0,0 +1,2 @@
 
 
1
+ .CodeMirror{font-family:monospace;height:300px;color:#000;direction:ltr}.CodeMirror-lines{padding:4px 0}.CodeMirror pre.CodeMirror-line,.CodeMirror pre.CodeMirror-line-like{padding:0 4px}.CodeMirror-gutter-filler,.CodeMirror-scrollbar-filler{background-color:#fff}.CodeMirror-gutters{border-right:1px solid #ddd;background-color:#f7f7f7;white-space:nowrap}.CodeMirror-linenumber{padding:0 3px 0 5px;min-width:20px;text-align:right;color:#999;white-space:nowrap}.CodeMirror-guttermarker{color:#000}.CodeMirror-guttermarker-subtle{color:#999}.CodeMirror-cursor{border-left:1px solid #000;border-right:none;width:0}.CodeMirror div.CodeMirror-secondarycursor{border-left:1px solid silver}.cm-fat-cursor .CodeMirror-cursor{width:auto;border:0!important;background:#7e7}.cm-fat-cursor div.CodeMirror-cursors{z-index:1}.cm-fat-cursor-mark{background-color:rgba(20,255,20,.5);-webkit-animation:blink 1.06s steps(1) infinite;-moz-animation:blink 1.06s steps(1) infinite;animation:blink 1.06s steps(1) infinite}.cm-animate-fat-cursor{width:auto;border:0;-webkit-animation:blink 1.06s steps(1) infinite;-moz-animation:blink 1.06s steps(1) infinite;animation:blink 1.06s steps(1) infinite;background-color:#7e7}@-moz-keyframes blink{50%{background-color:transparent}}@-webkit-keyframes blink{50%{background-color:transparent}}@keyframes blink{50%{background-color:transparent}}.cm-tab{display:inline-block;text-decoration:inherit}.CodeMirror-rulers{position:absolute;left:0;right:0;top:-50px;bottom:0;overflow:hidden}.CodeMirror-ruler{border-left:1px solid #ccc;top:0;bottom:0;position:absolute}.cm-s-default .cm-header{color:#00f}.cm-s-default .cm-quote{color:#090}.cm-negative{color:#d44}.cm-positive{color:#292}.cm-header,.cm-strong{font-weight:700}.cm-em{font-style:italic}.cm-link{text-decoration:underline}.cm-strikethrough{text-decoration:line-through}.cm-s-default .cm-keyword{color:#708}.cm-s-default .cm-atom{color:#219}.cm-s-default .cm-number{color:#164}.cm-s-default .cm-def{color:#00f}.cm-s-default .cm-variable-2{color:#05a}.cm-s-default .cm-type,.cm-s-default .cm-variable-3{color:#085}.cm-s-default .cm-comment{color:#a50}.cm-s-default .cm-string{color:#a11}.cm-s-default .cm-string-2{color:#f50}.cm-s-default .cm-meta{color:#555}.cm-s-default .cm-qualifier{color:#555}.cm-s-default .cm-builtin{color:#30a}.cm-s-default .cm-bracket{color:#997}.cm-s-default .cm-tag{color:#170}.cm-s-default .cm-attribute{color:#00c}.cm-s-default .cm-hr{color:#999}.cm-s-default .cm-link{color:#00c}.cm-s-default .cm-error{color:red}.cm-invalidchar{color:red}.CodeMirror-composing{border-bottom:2px solid}div.CodeMirror span.CodeMirror-matchingbracket{color:#0b0}div.CodeMirror span.CodeMirror-nonmatchingbracket{color:#a22}.CodeMirror-matchingtag{background:rgba(255,150,0,.3)}.CodeMirror-activeline-background{background:#e8f2ff}.CodeMirror{position:relative;overflow:hidden;background:#fff}.CodeMirror-scroll{overflow:scroll!important;margin-bottom:-30px;margin-right:-30px;padding-bottom:30px;height:100%;outline:0;position:relative}.CodeMirror-sizer{position:relative;border-right:30px solid transparent}.CodeMirror-gutter-filler,.CodeMirror-hscrollbar,.CodeMirror-scrollbar-filler,.CodeMirror-vscrollbar{position:absolute;z-index:6;display:none}.CodeMirror-vscrollbar{right:0;top:0;overflow-x:hidden;overflow-y:scroll}.CodeMirror-hscrollbar{bottom:0;left:0;overflow-y:hidden;overflow-x:scroll}.CodeMirror-scrollbar-filler{right:0;bottom:0}.CodeMirror-gutter-filler{left:0;bottom:0}.CodeMirror-gutters{position:absolute;left:0;top:0;min-height:100%;z-index:3}.CodeMirror-gutter{white-space:normal;height:100%;display:inline-block;vertical-align:top;margin-bottom:-30px}.CodeMirror-gutter-wrapper{position:absolute;z-index:4;background:0 0!important;border:none!important}.CodeMirror-gutter-background{position:absolute;top:0;bottom:0;z-index:4}.CodeMirror-gutter-elt{position:absolute;cursor:default;z-index:4}.CodeMirror-gutter-wrapper ::selection{background-color:transparent}.CodeMirror-gutter-wrapper ::-moz-selection{background-color:transparent}.CodeMirror-lines{cursor:text;min-height:1px}.CodeMirror pre.CodeMirror-line,.CodeMirror pre.CodeMirror-line-like{-moz-border-radius:0;-webkit-border-radius:0;border-radius:0;border-width:0;background:0 0;font-family:inherit;font-size:inherit;margin:0;white-space:pre;word-wrap:normal;line-height:inherit;color:inherit;z-index:2;position:relative;overflow:visible;-webkit-tap-highlight-color:transparent;-webkit-font-variant-ligatures:contextual;font-variant-ligatures:contextual}.CodeMirror-wrap pre.CodeMirror-line,.CodeMirror-wrap pre.CodeMirror-line-like{word-wrap:break-word;white-space:pre-wrap;word-break:normal}.CodeMirror-linebackground{position:absolute;left:0;right:0;top:0;bottom:0;z-index:0}.CodeMirror-linewidget{position:relative;z-index:2;padding:.1px}.CodeMirror-rtl pre{direction:rtl}.CodeMirror-code{outline:0}.CodeMirror-gutter,.CodeMirror-gutters,.CodeMirror-linenumber,.CodeMirror-scroll,.CodeMirror-sizer{-moz-box-sizing:content-box;box-sizing:content-box}.CodeMirror-measure{position:absolute;width:100%;height:0;overflow:hidden;visibility:hidden}.CodeMirror-cursor{position:absolute;pointer-events:none}.CodeMirror-measure pre{position:static}div.CodeMirror-cursors{visibility:hidden;position:relative;z-index:3}div.CodeMirror-dragcursors{visibility:visible}.CodeMirror-focused div.CodeMirror-cursors{visibility:visible}.CodeMirror-selected{background:#d9d9d9}.CodeMirror-focused .CodeMirror-selected{background:#d7d4f0}.CodeMirror-crosshair{cursor:crosshair}.CodeMirror-line::selection,.CodeMirror-line>span::selection,.CodeMirror-line>span>span::selection{background:#d7d4f0}.CodeMirror-line::-moz-selection,.CodeMirror-line>span::-moz-selection,.CodeMirror-line>span>span::-moz-selection{background:#d7d4f0}.cm-searching{background-color:#ffa;background-color:rgba(255,255,0,.4)}.cm-force-border{padding-right:.1px}@media print{.CodeMirror div.CodeMirror-cursors{visibility:hidden}}.cm-tab-wrap-hack:after{content:''}span.CodeMirror-selectedtext{background:0 0}
2
+ /*# sourceMappingURL=codemirror.min.css.map */
includes/css/codemirror/codemirror.css DELETED
@@ -1,340 +0,0 @@
1
- /* BASICS */
2
-
3
- .CodeMirror {
4
- /* Set height, width, borders, and global font properties here */
5
- font-family: monospace;
6
- height: 300px;
7
- color: black;
8
- }
9
-
10
- /* PADDING */
11
-
12
- .CodeMirror-lines {
13
- padding: 4px 0; /* Vertical padding around content */
14
- }
15
- .CodeMirror pre {
16
- padding: 0 4px; /* Horizontal padding of content */
17
- }
18
-
19
- .CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler {
20
- background-color: white; /* The little square between H and V scrollbars */
21
- }
22
-
23
- /* GUTTER */
24
-
25
- .CodeMirror-gutters {
26
- border-right: 1px solid #ddd;
27
- background-color: #f7f7f7;
28
- white-space: nowrap;
29
- }
30
- .CodeMirror-linenumbers {}
31
- .CodeMirror-linenumber {
32
- padding: 0 3px 0 5px;
33
- min-width: 20px;
34
- text-align: right;
35
- color: #999;
36
- white-space: nowrap;
37
- }
38
-
39
- .CodeMirror-guttermarker { color: black; }
40
- .CodeMirror-guttermarker-subtle { color: #999; }
41
-
42
- /* CURSOR */
43
-
44
- .CodeMirror-cursor {
45
- border-left: 1px solid black;
46
- border-right: none;
47
- width: 0;
48
- }
49
- /* Shown when moving in bi-directional text */
50
- .CodeMirror div.CodeMirror-secondarycursor {
51
- border-left: 1px solid silver;
52
- }
53
- .cm-fat-cursor .CodeMirror-cursor {
54
- width: auto;
55
- border: 0 !important;
56
- background: #7e7;
57
- }
58
- .cm-fat-cursor div.CodeMirror-cursors {
59
- z-index: 1;
60
- }
61
-
62
- .cm-animate-fat-cursor {
63
- width: auto;
64
- border: 0;
65
- -webkit-animation: blink 1.06s steps(1) infinite;
66
- -moz-animation: blink 1.06s steps(1) infinite;
67
- animation: blink 1.06s steps(1) infinite;
68
- background-color: #7e7;
69
- }
70
- @-moz-keyframes blink {
71
- 0% {}
72
- 50% { background-color: transparent; }
73
- 100% {}
74
- }
75
- @-webkit-keyframes blink {
76
- 0% {}
77
- 50% { background-color: transparent; }
78
- 100% {}
79
- }
80
- @keyframes blink {
81
- 0% {}
82
- 50% { background-color: transparent; }
83
- 100% {}
84
- }
85
-
86
- /* Can style cursor different in overwrite (non-insert) mode */
87
- .CodeMirror-overwrite .CodeMirror-cursor {}
88
-
89
- .cm-tab { display: inline-block; text-decoration: inherit; }
90
-
91
- .CodeMirror-rulers {
92
- position: absolute;
93
- left: 0; right: 0; top: -50px; bottom: -20px;
94
- overflow: hidden;
95
- }
96
- .CodeMirror-ruler {
97
- border-left: 1px solid #ccc;
98
- top: 0; bottom: 0;
99
- position: absolute;
100
- }
101
-
102
- /* DEFAULT THEME */
103
-
104
- .cm-s-default .cm-header {color: blue;}
105
- .cm-s-default .cm-quote {color: #090;}
106
- .cm-negative {color: #d44;}
107
- .cm-positive {color: #292;}
108
- .cm-header, .cm-strong {font-weight: bold;}
109
- .cm-em {font-style: italic;}
110
- .cm-link {text-decoration: underline;}
111
- .cm-strikethrough {text-decoration: line-through;}
112
-
113
- .cm-s-default .cm-keyword {color: #708;}
114
- .cm-s-default .cm-atom {color: #219;}
115
- .cm-s-default .cm-number {color: #164;}
116
- .cm-s-default .cm-def {color: #00f;}
117
- .cm-s-default .cm-variable,
118
- .cm-s-default .cm-punctuation,
119
- .cm-s-default .cm-property,
120
- .cm-s-default .cm-operator {}
121
- .cm-s-default .cm-variable-2 {color: #05a;}
122
- .cm-s-default .cm-variable-3 {color: #085;}
123
- .cm-s-default .cm-comment {color: #a50;}
124
- .cm-s-default .cm-string {color: #a11;}
125
- .cm-s-default .cm-string-2 {color: #f50;}
126
- .cm-s-default .cm-meta {color: #555;}
127
- .cm-s-default .cm-qualifier {color: #555;}
128
- .cm-s-default .cm-builtin {color: #30a;}
129
- .cm-s-default .cm-bracket {color: #997;}
130
- .cm-s-default .cm-tag {color: #170;}
131
- .cm-s-default .cm-attribute {color: #00c;}
132
- .cm-s-default .cm-hr {color: #999;}
133
- .cm-s-default .cm-link {color: #00c;}
134
-
135
- .cm-s-default .cm-error {color: #f00;}
136
- .cm-invalidchar {color: #f00;}
137
-
138
- .CodeMirror-composing { border-bottom: 2px solid; }
139
-
140
- /* Default styles for common addons */
141
-
142
- div.CodeMirror span.CodeMirror-matchingbracket {color: #0f0;}
143
- div.CodeMirror span.CodeMirror-nonmatchingbracket {color: #f22;}
144
- .CodeMirror-matchingtag { background: rgba(255, 150, 0, .3); }
145
- .CodeMirror-activeline-background {background: #e8f2ff;}
146
-
147
- /* STOP */
148
-
149
- /* The rest of this file contains styles related to the mechanics of
150
- the editor. You probably shouldn't touch them. */
151
-
152
- .CodeMirror {
153
- position: relative;
154
- overflow: hidden;
155
- background: white;
156
- }
157
-
158
- .CodeMirror-scroll {
159
- overflow: scroll !important; /* Things will break if this is overridden */
160
- /* 30px is the magic margin used to hide the element's real scrollbars */
161
- /* See overflow: hidden in .CodeMirror */
162
- margin-bottom: -30px; margin-right: -30px;
163
- padding-bottom: 30px;
164
- height: 100%;
165
- outline: none; /* Prevent dragging from highlighting the element */
166
- position: relative;
167
- }
168
- .CodeMirror-sizer {
169
- position: relative;
170
- border-right: 30px solid transparent;
171
- }
172
-
173
- /* The fake, visible scrollbars. Used to force redraw during scrolling
174
- before actual scrolling happens, thus preventing shaking and
175
- flickering artifacts. */
176
- .CodeMirror-vscrollbar, .CodeMirror-hscrollbar, .CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler {
177
- position: absolute;
178
- z-index: 6;
179
- display: none;
180
- }
181
- .CodeMirror-vscrollbar {
182
- right: 0; top: 0;
183
- overflow-x: hidden;
184
- overflow-y: scroll;
185
- }
186
- .CodeMirror-hscrollbar {
187
- bottom: 0; left: 0;
188
- overflow-y: hidden;
189
- overflow-x: scroll;
190
- }
191
- .CodeMirror-scrollbar-filler {
192
- right: 0; bottom: 0;
193
- }
194
- .CodeMirror-gutter-filler {
195
- left: 0; bottom: 0;
196
- }
197
-
198
- .CodeMirror-gutters {
199
- position: absolute; left: 0; top: 0;
200
- min-height: 100%;
201
- z-index: 3;
202
- }
203
- .CodeMirror-gutter {
204
- white-space: normal;
205
- height: 100%;
206
- display: inline-block;
207
- vertical-align: top;
208
- margin-bottom: -30px;
209
- }
210
- .CodeMirror-gutter-wrapper {
211
- position: absolute;
212
- z-index: 4;
213
- background: none !important;
214
- border: none !important;
215
- }
216
- .CodeMirror-gutter-background {
217
- position: absolute;
218
- top: 0; bottom: 0;
219
- z-index: 4;
220
- }
221
- .CodeMirror-gutter-elt {
222
- position: absolute;
223
- cursor: default;
224
- z-index: 4;
225
- }
226
- .CodeMirror-gutter-wrapper ::selection { background-color: transparent }
227
- .CodeMirror-gutter-wrapper ::-moz-selection { background-color: transparent }
228
-
229
- .CodeMirror-lines {
230
- cursor: text;
231
- min-height: 1px; /* prevents collapsing before first draw */
232
- }
233
- .CodeMirror pre {
234
- /* Reset some styles that the rest of the page might have set */
235
- -moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0;
236
- border-width: 0;
237
- background: transparent;
238
- font-family: inherit;
239
- font-size: inherit;
240
- margin: 0;
241
- white-space: pre;
242
- word-wrap: normal;
243
- line-height: inherit;
244
- color: inherit;
245
- z-index: 2;
246
- position: relative;
247
- overflow: visible;
248
- -webkit-tap-highlight-color: transparent;
249
- -webkit-font-variant-ligatures: contextual;
250
- font-variant-ligatures: contextual;
251
- }
252
- .CodeMirror-wrap pre {
253
- word-wrap: break-word;
254
- white-space: pre-wrap;
255
- word-break: normal;
256
- }
257
-
258
- .CodeMirror-linebackground {
259
- position: absolute;
260
- left: 0; right: 0; top: 0; bottom: 0;
261
- z-index: 0;
262
- }
263
-
264
- .CodeMirror-linewidget {
265
- position: relative;
266
- z-index: 2;
267
- overflow: auto;
268
- }
269
-
270
- .CodeMirror-widget {}
271
-
272
- .CodeMirror-rtl pre { direction: rtl; }
273
-
274
- .CodeMirror-code {
275
- outline: none;
276
- }
277
-
278
- /* Force content-box sizing for the elements where we expect it */
279
- .CodeMirror-scroll,
280
- .CodeMirror-sizer,
281
- .CodeMirror-gutter,
282
- .CodeMirror-gutters,
283
- .CodeMirror-linenumber {
284
- -moz-box-sizing: content-box;
285
- box-sizing: content-box;
286
- }
287
-
288
- .CodeMirror-measure {
289
- position: absolute;
290
- width: 100%;
291
- height: 0;
292
- overflow: hidden;
293
- visibility: hidden;
294
- }
295
-
296
- .CodeMirror-cursor {
297
- position: absolute;
298
- pointer-events: none;
299
- }
300
- .CodeMirror-measure pre { position: static; }
301
-
302
- div.CodeMirror-cursors {
303
- visibility: hidden;
304
- position: relative;
305
- z-index: 3;
306
- }
307
- div.CodeMirror-dragcursors {
308
- visibility: visible;
309
- }
310
-
311
- .CodeMirror-focused div.CodeMirror-cursors {
312
- visibility: visible;
313
- }
314
-
315
- .CodeMirror-selected { background: #d9d9d9; }
316
- .CodeMirror-focused .CodeMirror-selected { background: #d7d4f0; }
317
- .CodeMirror-crosshair { cursor: crosshair; }
318
- .CodeMirror-line::selection, .CodeMirror-line > span::selection, .CodeMirror-line > span > span::selection { background: #d7d4f0; }
319
- .CodeMirror-line::-moz-selection, .CodeMirror-line > span::-moz-selection, .CodeMirror-line > span > span::-moz-selection { background: #d7d4f0; }
320
-
321
- .cm-searching {
322
- background: #ffa;
323
- background: rgba(255, 255, 0, .4);
324
- }
325
-
326
- /* Used to force a border model for a node */
327
- .cm-force-border { padding-right: .1px; }
328
-
329
- @media print {
330
- /* Hide the cursor when printing */
331
- .CodeMirror div.CodeMirror-cursors {
332
- visibility: hidden;
333
- }
334
- }
335
-
336
- /* See issue #2901 */
337
- .cm-tab-wrap-hack:after { content: ''; }
338
-
339
- /* Help users use markselection to safely style text background */
340
- span.CodeMirror-selectedtext { background: none; }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
includes/css/codemirror/ttcn.css DELETED
@@ -1,64 +0,0 @@
1
- .cm-s-ttcn .cm-quote { color: #090; }
2
- .cm-s-ttcn .cm-negative { color: #d44; }
3
- .cm-s-ttcn .cm-positive { color: #292; }
4
- .cm-s-ttcn .cm-header, .cm-strong { font-weight: bold; }
5
- .cm-s-ttcn .cm-em { font-style: italic; }
6
- .cm-s-ttcn .cm-link { text-decoration: underline; }
7
- .cm-s-ttcn .cm-strikethrough { text-decoration: line-through; }
8
- .cm-s-ttcn .cm-header { color: #00f; font-weight: bold; }
9
-
10
- .cm-s-ttcn .cm-atom { color: #219; }
11
- .cm-s-ttcn .cm-attribute { color: #00c; }
12
- .cm-s-ttcn .cm-bracket { color: #997; }
13
- .cm-s-ttcn .cm-comment { color: #333333; }
14
- .cm-s-ttcn .cm-def { color: #00f; }
15
- .cm-s-ttcn .cm-em { font-style: italic; }
16
- .cm-s-ttcn .cm-error { color: #f00; }
17
- .cm-s-ttcn .cm-hr { color: #999; }
18
- .cm-s-ttcn .cm-invalidchar { color: #f00; }
19
- .cm-s-ttcn .cm-keyword { font-weight:bold; }
20
- .cm-s-ttcn .cm-link { color: #00c; text-decoration: underline; }
21
- .cm-s-ttcn .cm-meta { color: #555; }
22
- .cm-s-ttcn .cm-negative { color: #d44; }
23
- .cm-s-ttcn .cm-positive { color: #292; }
24
- .cm-s-ttcn .cm-qualifier { color: #555; }
25
- .cm-s-ttcn .cm-strikethrough { text-decoration: line-through; }
26
- .cm-s-ttcn .cm-string { color: #006400; }
27
- .cm-s-ttcn .cm-string-2 { color: #f50; }
28
- .cm-s-ttcn .cm-strong { font-weight: bold; }
29
- .cm-s-ttcn .cm-tag { color: #170; }
30
- .cm-s-ttcn .cm-variable { color: #8B2252; }
31
- .cm-s-ttcn .cm-variable-2 { color: #05a; }
32
- .cm-s-ttcn .cm-variable-3 { color: #085; }
33
-
34
- .cm-s-ttcn .cm-invalidchar { color: #f00; }
35
-
36
- /* ASN */
37
- .cm-s-ttcn .cm-accessTypes,
38
- .cm-s-ttcn .cm-compareTypes { color: #27408B; }
39
- .cm-s-ttcn .cm-cmipVerbs { color: #8B2252; }
40
- .cm-s-ttcn .cm-modifier { color:#D2691E; }
41
- .cm-s-ttcn .cm-status { color:#8B4545; }
42
- .cm-s-ttcn .cm-storage { color:#A020F0; }
43
- .cm-s-ttcn .cm-tags { color:#006400; }
44
-
45
- /* CFG */
46
- .cm-s-ttcn .cm-externalCommands { color: #8B4545; font-weight:bold; }
47
- .cm-s-ttcn .cm-fileNCtrlMaskOptions,
48
- .cm-s-ttcn .cm-sectionTitle { color: #2E8B57; font-weight:bold; }
49
-
50
- /* TTCN */
51
- .cm-s-ttcn .cm-booleanConsts,
52
- .cm-s-ttcn .cm-otherConsts,
53
- .cm-s-ttcn .cm-verdictConsts { color: #006400; }
54
- .cm-s-ttcn .cm-configOps,
55
- .cm-s-ttcn .cm-functionOps,
56
- .cm-s-ttcn .cm-portOps,
57
- .cm-s-ttcn .cm-sutOps,
58
- .cm-s-ttcn .cm-timerOps,
59
- .cm-s-ttcn .cm-verdictOps { color: #0000FF; }
60
- .cm-s-ttcn .cm-preprocessor,
61
- .cm-s-ttcn .cm-templateMatch,
62
- .cm-s-ttcn .cm-ttcn3Macros { color: #27408B; }
63
- .cm-s-ttcn .cm-types { color: #A52A2A; font-weight:bold; }
64
- .cm-s-ttcn .cm-visibilityModifiers { font-weight:bold; }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
includes/css/jquery-ui.min.css ADDED
@@ -0,0 +1,7 @@
 
 
 
 
 
 
 
1
+ /*! jQuery UI - v1.13.2 - 2022-07-14
2
+ * http://jqueryui.com
3
+ * Includes: core.css, accordion.css, autocomplete.css, menu.css, button.css, controlgroup.css, checkboxradio.css, datepicker.css, dialog.css, draggable.css, resizable.css, progressbar.css, selectable.css, selectmenu.css, slider.css, sortable.css, spinner.css, tabs.css, tooltip.css, theme.css
4
+ * To view and modify this theme, visit http://jqueryui.com/themeroller/?bgShadowXPos=&bgOverlayXPos=&bgErrorXPos=&bgHighlightXPos=&bgContentXPos=&bgHeaderXPos=&bgActiveXPos=&bgHoverXPos=&bgDefaultXPos=&bgShadowYPos=&bgOverlayYPos=&bgErrorYPos=&bgHighlightYPos=&bgContentYPos=&bgHeaderYPos=&bgActiveYPos=&bgHoverYPos=&bgDefaultYPos=&bgShadowRepeat=&bgOverlayRepeat=&bgErrorRepeat=&bgHighlightRepeat=&bgContentRepeat=&bgHeaderRepeat=&bgActiveRepeat=&bgHoverRepeat=&bgDefaultRepeat=&iconsHover=url(%22images%2Fui-icons_555555_256x240.png%22)&iconsHighlight=url(%22images%2Fui-icons_777620_256x240.png%22)&iconsHeader=url(%22images%2Fui-icons_444444_256x240.png%22)&iconsError=url(%22images%2Fui-icons_cc0000_256x240.png%22)&iconsDefault=url(%22images%2Fui-icons_777777_256x240.png%22)&iconsContent=url(%22images%2Fui-icons_444444_256x240.png%22)&iconsActive=url(%22images%2Fui-icons_ffffff_256x240.png%22)&bgImgUrlShadow=&bgImgUrlOverlay=&bgImgUrlHover=&bgImgUrlHighlight=&bgImgUrlHeader=&bgImgUrlError=&bgImgUrlDefault=&bgImgUrlContent=&bgImgUrlActive=&opacityFilterShadow=Alpha(Opacity%3D30)&opacityFilterOverlay=Alpha(Opacity%3D30)&opacityShadowPerc=30&opacityOverlayPerc=30&iconColorHover=%23555555&iconColorHighlight=%23777620&iconColorHeader=%23444444&iconColorError=%23cc0000&iconColorDefault=%23777777&iconColorContent=%23444444&iconColorActive=%23ffffff&bgImgOpacityShadow=0&bgImgOpacityOverlay=0&bgImgOpacityError=95&bgImgOpacityHighlight=55&bgImgOpacityContent=75&bgImgOpacityHeader=75&bgImgOpacityActive=65&bgImgOpacityHover=75&bgImgOpacityDefault=75&bgTextureShadow=flat&bgTextureOverlay=flat&bgTextureError=flat&bgTextureHighlight=flat&bgTextureContent=flat&bgTextureHeader=flat&bgTextureActive=flat&bgTextureHover=flat&bgTextureDefault=flat&cornerRadius=3px&fwDefault=normal&ffDefault=Arial%2CHelvetica%2Csans-serif&fsDefault=1em&cornerRadiusShadow=8px&thicknessShadow=5px&offsetLeftShadow=0px&offsetTopShadow=0px&opacityShadow=.3&bgColorShadow=%23666666&opacityOverlay=.3&bgColorOverlay=%23aaaaaa&fcError=%235f3f3f&borderColorError=%23f1a899&bgColorError=%23fddfdf&fcHighlight=%23777620&borderColorHighlight=%23dad55e&bgColorHighlight=%23fffa90&fcContent=%23333333&borderColorContent=%23dddddd&bgColorContent=%23ffffff&fcHeader=%23333333&borderColorHeader=%23dddddd&bgColorHeader=%23e9e9e9&fcActive=%23ffffff&borderColorActive=%23003eff&bgColorActive=%23007fff&fcHover=%232b2b2b&borderColorHover=%23cccccc&bgColorHover=%23ededed&fcDefault=%23454545&borderColorDefault=%23c5c5c5&bgColorDefault=%23f6f6f6
5
+ * Copyright jQuery Foundation and other contributors; Licensed MIT */
6
+
7
+ .ui-helper-hidden{display:none}.ui-helper-hidden-accessible{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.ui-helper-reset{margin:0;padding:0;border:0;outline:0;line-height:1.3;text-decoration:none;font-size:100%;list-style:none}.ui-helper-clearfix:before,.ui-helper-clearfix:after{content:"";display:table;border-collapse:collapse}.ui-helper-clearfix:after{clear:both}.ui-helper-zfix{width:100%;height:100%;top:0;left:0;position:absolute;opacity:0;-ms-filter:"alpha(opacity=0)"}.ui-front{z-index:100}.ui-state-disabled{cursor:default!important;pointer-events:none}.ui-icon{display:inline-block;vertical-align:middle;margin-top:-.25em;position:relative;text-indent:-99999px;overflow:hidden;background-repeat:no-repeat}.ui-widget-icon-block{left:50%;margin-left:-8px;display:block}.ui-widget-overlay{position:fixed;top:0;left:0;width:100%;height:100%}.ui-accordion .ui-accordion-header{display:block;cursor:pointer;position:relative;margin:2px 0 0 0;padding:.5em .5em .5em .7em;font-size:100%}.ui-accordion .ui-accordion-content{padding:1em 2.2em;border-top:0;overflow:auto}.ui-autocomplete{position:absolute;top:0;left:0;cursor:default}.ui-menu{list-style:none;padding:0;margin:0;display:block;outline:0}.ui-menu .ui-menu{position:absolute}.ui-menu .ui-menu-item{margin:0;cursor:pointer;list-style-image:url("")}.ui-menu .ui-menu-item-wrapper{position:relative;padding:3px 1em 3px .4em}.ui-menu .ui-menu-divider{margin:5px 0;height:0;font-size:0;line-height:0;border-width:1px 0 0 0}.ui-menu .ui-state-focus,.ui-menu .ui-state-active{margin:-1px}.ui-menu-icons{position:relative}.ui-menu-icons .ui-menu-item-wrapper{padding-left:2em}.ui-menu .ui-icon{position:absolute;top:0;bottom:0;left:.2em;margin:auto 0}.ui-menu .ui-menu-icon{left:auto;right:0}.ui-button{padding:.4em 1em;display:inline-block;position:relative;line-height:normal;margin-right:.1em;cursor:pointer;vertical-align:middle;text-align:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:visible}.ui-button,.ui-button:link,.ui-button:visited,.ui-button:hover,.ui-button:active{text-decoration:none}.ui-button-icon-only{width:2em;box-sizing:border-box;text-indent:-9999px;white-space:nowrap}input.ui-button.ui-button-icon-only{text-indent:0}.ui-button-icon-only .ui-icon{position:absolute;top:50%;left:50%;margin-top:-8px;margin-left:-8px}.ui-button.ui-icon-notext .ui-icon{padding:0;width:2.1em;height:2.1em;text-indent:-9999px;white-space:nowrap}input.ui-button.ui-icon-notext .ui-icon{width:auto;height:auto;text-indent:0;white-space:normal;padding:.4em 1em}input.ui-button::-moz-focus-inner,button.ui-button::-moz-focus-inner{border:0;padding:0}.ui-controlgroup{vertical-align:middle;display:inline-block}.ui-controlgroup > .ui-controlgroup-item{float:left;margin-left:0;margin-right:0}.ui-controlgroup > .ui-controlgroup-item:focus,.ui-controlgroup > .ui-controlgroup-item.ui-visual-focus{z-index:9999}.ui-controlgroup-vertical > .ui-controlgroup-item{display:block;float:none;width:100%;margin-top:0;margin-bottom:0;text-align:left}.ui-controlgroup-vertical .ui-controlgroup-item{box-sizing:border-box}.ui-controlgroup .ui-controlgroup-label{padding:.4em 1em}.ui-controlgroup .ui-controlgroup-label span{font-size:80%}.ui-controlgroup-horizontal .ui-controlgroup-label + .ui-controlgroup-item{border-left:none}.ui-controlgroup-vertical .ui-controlgroup-label + .ui-controlgroup-item{border-top:none}.ui-controlgroup-horizontal .ui-controlgroup-label.ui-widget-content{border-right:none}.ui-controlgroup-vertical .ui-controlgroup-label.ui-widget-content{border-bottom:none}.ui-controlgroup-vertical .ui-spinner-input{width:75%;width:calc( 100% - 2.4em )}.ui-controlgroup-vertical .ui-spinner .ui-spinner-up{border-top-style:solid}.ui-checkboxradio-label .ui-icon-background{box-shadow:inset 1px 1px 1px #ccc;border-radius:.12em;border:none}.ui-checkboxradio-radio-label .ui-icon-background{width:16px;height:16px;border-radius:1em;overflow:visible;border:none}.ui-checkboxradio-radio-label.ui-checkboxradio-checked .ui-icon,.ui-checkboxradio-radio-label.ui-checkboxradio-checked:hover .ui-icon{background-image:none;width:8px;height:8px;border-width:4px;border-style:solid}.ui-checkboxradio-disabled{pointer-events:none}.ui-datepicker{width:17em;padding:.2em .2em 0;display:none}.ui-datepicker .ui-datepicker-header{position:relative;padding:.2em 0}.ui-datepicker .ui-datepicker-prev,.ui-datepicker .ui-datepicker-next{position:absolute;top:2px;width:1.8em;height:1.8em}.ui-datepicker .ui-datepicker-prev-hover,.ui-datepicker .ui-datepicker-next-hover{top:1px}.ui-datepicker .ui-datepicker-prev{left:2px}.ui-datepicker .ui-datepicker-next{right:2px}.ui-datepicker .ui-datepicker-prev-hover{left:1px}.ui-datepicker .ui-datepicker-next-hover{right:1px}.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}.ui-datepicker .ui-datepicker-title{margin:0 2.3em;line-height:1.8em;text-align:center}.ui-datepicker .ui-datepicker-title select{font-size:1em;margin:1px 0}.ui-datepicker select.ui-datepicker-month,.ui-datepicker select.ui-datepicker-year{width:45%}.ui-datepicker table{width:100%;font-size:.9em;border-collapse:collapse;margin:0 0 .4em}.ui-datepicker th{padding:.7em .3em;text-align:center;font-weight:bold;border:0}.ui-datepicker td{border:0;padding:1px}.ui-datepicker td span,.ui-datepicker td a{display:block;padding:.2em;text-align:right;text-decoration:none}.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}.ui-datepicker .ui-datepicker-buttonpane button{float:right;margin:.5em .2em .4em;cursor:pointer;padding:.2em .6em .3em .6em;width:auto;overflow:visible}.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current{float:left}.ui-datepicker.ui-datepicker-multi{width:auto}.ui-datepicker-multi .ui-datepicker-group{float:left}.ui-datepicker-multi .ui-datepicker-group table{width:95%;margin:0 auto .4em}.ui-datepicker-multi-2 .ui-datepicker-group{width:50%}.ui-datepicker-multi-3 .ui-datepicker-group{width:33.3%}.ui-datepicker-multi-4 .ui-datepicker-group{width:25%}.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header,.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header{border-left-width:0}.ui-datepicker-multi .ui-datepicker-buttonpane{clear:left}.ui-datepicker-row-break{clear:both;width:100%;font-size:0}.ui-datepicker-rtl{direction:rtl}.ui-datepicker-rtl .ui-datepicker-prev{right:2px;left:auto}.ui-datepicker-rtl .ui-datepicker-next{left:2px;right:auto}.ui-datepicker-rtl .ui-datepicker-prev:hover{right:1px;left:auto}.ui-datepicker-rtl .ui-datepicker-next:hover{left:1px;right:auto}.ui-datepicker-rtl .ui-datepicker-buttonpane{clear:right}.ui-datepicker-rtl .ui-datepicker-buttonpane button{float:left}.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current,.ui-datepicker-rtl .ui-datepicker-group{float:right}.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header,.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header{border-right-width:0;border-left-width:1px}.ui-datepicker .ui-icon{display:block;text-indent:-99999px;overflow:hidden;background-repeat:no-repeat;left:.5em;top:.3em}.ui-dialog{position:absolute;top:0;left:0;padding:.2em;outline:0}.ui-dialog .ui-dialog-titlebar{padding:.4em 1em;position:relative}.ui-dialog .ui-dialog-title{float:left;margin:.1em 0;white-space:nowrap;width:90%;overflow:hidden;text-overflow:ellipsis}.ui-dialog .ui-dialog-titlebar-close{position:absolute;right:.3em;top:50%;width:20px;margin:-10px 0 0 0;padding:1px;height:20px}.ui-dialog .ui-dialog-content{position:relative;border:0;padding:.5em 1em;background:none;overflow:auto}.ui-dialog .ui-dialog-buttonpane{text-align:left;border-width:1px 0 0 0;background-image:none;margin-top:.5em;padding:.3em 1em .5em .4em}.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset{float:right}.ui-dialog .ui-dialog-buttonpane button{margin:.5em .4em .5em 0;cursor:pointer}.ui-dialog .ui-resizable-n{height:2px;top:0}.ui-dialog .ui-resizable-e{width:2px;right:0}.ui-dialog .ui-resizable-s{height:2px;bottom:0}.ui-dialog .ui-resizable-w{width:2px;left:0}.ui-dialog .ui-resizable-se,.ui-dialog .ui-resizable-sw,.ui-dialog .ui-resizable-ne,.ui-dialog .ui-resizable-nw{width:7px;height:7px}.ui-dialog .ui-resizable-se{right:0;bottom:0}.ui-dialog .ui-resizable-sw{left:0;bottom:0}.ui-dialog .ui-resizable-ne{right:0;top:0}.ui-dialog .ui-resizable-nw{left:0;top:0}.ui-draggable .ui-dialog-titlebar{cursor:move}.ui-draggable-handle{-ms-touch-action:none;touch-action:none}.ui-resizable{position:relative}.ui-resizable-handle{position:absolute;font-size:0.1px;display:block;-ms-touch-action:none;touch-action:none}.ui-resizable-disabled .ui-resizable-handle,.ui-resizable-autohide .ui-resizable-handle{display:none}.ui-resizable-n{cursor:n-resize;height:7px;width:100%;top:-5px;left:0}.ui-resizable-s{cursor:s-resize;height:7px;width:100%;bottom:-5px;left:0}.ui-resizable-e{cursor:e-resize;width:7px;right:-5px;top:0;height:100%}.ui-resizable-w{cursor:w-resize;width:7px;left:-5px;top:0;height:100%}.ui-resizable-se{cursor:se-resize;width:12px;height:12px;right:1px;bottom:1px}.ui-resizable-sw{cursor:sw-resize;width:9px;height:9px;left:-5px;bottom:-5px}.ui-resizable-nw{cursor:nw-resize;width:9px;height:9px;left:-5px;top:-5px}.ui-resizable-ne{cursor:ne-resize;width:9px;height:9px;right:-5px;top:-5px}.ui-progressbar{height:2em;text-align:left;overflow:hidden}.ui-progressbar .ui-progressbar-value{margin:-1px;height:100%}.ui-progressbar .ui-progressbar-overlay{background:url("");height:100%;-ms-filter:"alpha(opacity=25)";opacity:0.25}.ui-progressbar-indeterminate .ui-progressbar-value{background-image:none}.ui-selectable{-ms-touch-action:none;touch-action:none}.ui-selectable-helper{position:absolute;z-index:100;border:1px dotted black}.ui-selectmenu-menu{padding:0;margin:0;position:absolute;top:0;left:0;display:none}.ui-selectmenu-menu .ui-menu{overflow:auto;overflow-x:hidden;padding-bottom:1px}.ui-selectmenu-menu .ui-menu .ui-selectmenu-optgroup{font-size:1em;font-weight:bold;line-height:1.5;padding:2px 0.4em;margin:0.5em 0 0 0;height:auto;border:0}.ui-selectmenu-open{display:block}.ui-selectmenu-text{display:block;margin-right:20px;overflow:hidden;text-overflow:ellipsis}.ui-selectmenu-button.ui-button{text-align:left;white-space:nowrap;width:14em}.ui-selectmenu-icon.ui-icon{float:right;margin-top:0}.ui-slider{position:relative;text-align:left}.ui-slider .ui-slider-handle{position:absolute;z-index:2;width:1.2em;height:1.2em;cursor:pointer;-ms-touch-action:none;touch-action:none}.ui-slider .ui-slider-range{position:absolute;z-index:1;font-size:.7em;display:block;border:0;background-position:0 0}.ui-slider.ui-state-disabled .ui-slider-handle,.ui-slider.ui-state-disabled .ui-slider-range{filter:inherit}.ui-slider-horizontal{height:.8em}.ui-slider-horizontal .ui-slider-handle{top:-.3em;margin-left:-.6em}.ui-slider-horizontal .ui-slider-range{top:0;height:100%}.ui-slider-horizontal .ui-slider-range-min{left:0}.ui-slider-horizontal .ui-slider-range-max{right:0}.ui-slider-vertical{width:.8em;height:100px}.ui-slider-vertical .ui-slider-handle{left:-.3em;margin-left:0;margin-bottom:-.6em}.ui-slider-vertical .ui-slider-range{left:0;width:100%}.ui-slider-vertical .ui-slider-range-min{bottom:0}.ui-slider-vertical .ui-slider-range-max{top:0}.ui-sortable-handle{-ms-touch-action:none;touch-action:none}.ui-spinner{position:relative;display:inline-block;overflow:hidden;padding:0;vertical-align:middle}.ui-spinner-input{border:none;background:none;color:inherit;padding:.222em 0;margin:.2em 0;vertical-align:middle;margin-left:.4em;margin-right:2em}.ui-spinner-button{width:1.6em;height:50%;font-size:.5em;padding:0;margin:0;text-align:center;position:absolute;cursor:default;display:block;overflow:hidden;right:0}.ui-spinner a.ui-spinner-button{border-top-style:none;border-bottom-style:none;border-right-style:none}.ui-spinner-up{top:0}.ui-spinner-down{bottom:0}.ui-tabs{position:relative;padding:.2em}.ui-tabs .ui-tabs-nav{margin:0;padding:.2em .2em 0}.ui-tabs .ui-tabs-nav li{list-style:none;float:left;position:relative;top:0;margin:1px .2em 0 0;border-bottom-width:0;padding:0;white-space:nowrap}.ui-tabs .ui-tabs-nav .ui-tabs-anchor{float:left;padding:.5em 1em;text-decoration:none}.ui-tabs .ui-tabs-nav li.ui-tabs-active{margin-bottom:-1px;padding-bottom:1px}.ui-tabs .ui-tabs-nav li.ui-tabs-active .ui-tabs-anchor,.ui-tabs .ui-tabs-nav li.ui-state-disabled .ui-tabs-anchor,.ui-tabs .ui-tabs-nav li.ui-tabs-loading .ui-tabs-anchor{cursor:text}.ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-active .ui-tabs-anchor{cursor:pointer}.ui-tabs .ui-tabs-panel{display:block;border-width:0;padding:1em 1.4em;background:none}.ui-tooltip{padding:8px;position:absolute;z-index:9999;max-width:300px}body .ui-tooltip{border-width:2px}.ui-widget{font-family:Arial,Helvetica,sans-serif;font-size:1em}.ui-widget .ui-widget{font-size:1em}.ui-widget input,.ui-widget select,.ui-widget textarea,.ui-widget button{font-family:Arial,Helvetica,sans-serif;font-size:1em}.ui-widget.ui-widget-content{border:1px solid #c5c5c5}.ui-widget-content{border:1px solid #ddd;background:#fff;color:#333}.ui-widget-content a{color:#333}.ui-widget-header{border:1px solid #ddd;background:#e9e9e9;color:#333;font-weight:bold}.ui-widget-header a{color:#333}.ui-state-default,.ui-widget-content .ui-state-default,.ui-widget-header .ui-state-default,.ui-button,html .ui-button.ui-state-disabled:hover,html .ui-button.ui-state-disabled:active{border:1px solid #c5c5c5;background:#f6f6f6;font-weight:normal;color:#454545}.ui-state-default a,.ui-state-default a:link,.ui-state-default a:visited,a.ui-button,a:link.ui-button,a:visited.ui-button,.ui-button{color:#454545;text-decoration:none}.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,.ui-button:hover,.ui-button:focus{border:1px solid #ccc;background:#ededed;font-weight:normal;color:#2b2b2b}.ui-state-hover a,.ui-state-hover a:hover,.ui-state-hover a:link,.ui-state-hover a:visited,.ui-state-focus a,.ui-state-focus a:hover,.ui-state-focus a:link,.ui-state-focus a:visited,a.ui-button:hover,a.ui-button:focus{color:#2b2b2b;text-decoration:none}.ui-visual-focus{box-shadow:0 0 3px 1px rgb(94,158,214)}.ui-state-active,.ui-widget-content .ui-state-active,.ui-widget-header .ui-state-active,a.ui-button:active,.ui-button:active,.ui-button.ui-state-active:hover{border:1px solid #003eff;background:#007fff;font-weight:normal;color:#fff}.ui-icon-background,.ui-state-active .ui-icon-background{border:#003eff;background-color:#fff}.ui-state-active a,.ui-state-active a:link,.ui-state-active a:visited{color:#fff;text-decoration:none}.ui-state-highlight,.ui-widget-content .ui-state-highlight,.ui-widget-header .ui-state-highlight{border:1px solid #dad55e;background:#fffa90;color:#777620}.ui-state-checked{border:1px solid #dad55e;background:#fffa90}.ui-state-highlight a,.ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a{color:#777620}.ui-state-error,.ui-widget-content .ui-state-error,.ui-widget-header .ui-state-error{border:1px solid #f1a899;background:#fddfdf;color:#5f3f3f}.ui-state-error a,.ui-widget-content .ui-state-error a,.ui-widget-header .ui-state-error a{color:#5f3f3f}.ui-state-error-text,.ui-widget-content .ui-state-error-text,.ui-widget-header .ui-state-error-text{color:#5f3f3f}.ui-priority-primary,.ui-widget-content .ui-priority-primary,.ui-widget-header .ui-priority-primary{font-weight:bold}.ui-priority-secondary,.ui-widget-content .ui-priority-secondary,.ui-widget-header .ui-priority-secondary{opacity:.7;-ms-filter:"alpha(opacity=70)";font-weight:normal}.ui-state-disabled,.ui-widget-content .ui-state-disabled,.ui-widget-header .ui-state-disabled{opacity:.35;-ms-filter:"alpha(opacity=35)";background-image:none}.ui-state-disabled .ui-icon{-ms-filter:"alpha(opacity=35)"}.ui-icon{width:16px;height:16px}.ui-icon,.ui-widget-content .ui-icon{background-image:url("images/ui-icons_444444_256x240.png")}.ui-widget-header .ui-icon{background-image:url("images/ui-icons_444444_256x240.png")}.ui-state-hover .ui-icon,.ui-state-focus .ui-icon,.ui-button:hover .ui-icon,.ui-button:focus .ui-icon{background-image:url("images/ui-icons_555555_256x240.png")}.ui-state-active .ui-icon,.ui-button:active .ui-icon{background-image:url("images/ui-icons_ffffff_256x240.png")}.ui-state-highlight .ui-icon,.ui-button .ui-state-highlight.ui-icon{background-image:url("images/ui-icons_777620_256x240.png")}.ui-state-error .ui-icon,.ui-state-error-text .ui-icon{background-image:url("images/ui-icons_cc0000_256x240.png")}.ui-button .ui-icon{background-image:url("images/ui-icons_777777_256x240.png")}.ui-icon-blank.ui-icon-blank.ui-icon-blank{background-image:none}.ui-icon-caret-1-n{background-position:0 0}.ui-icon-caret-1-ne{background-position:-16px 0}.ui-icon-caret-1-e{background-position:-32px 0}.ui-icon-caret-1-se{background-position:-48px 0}.ui-icon-caret-1-s{background-position:-65px 0}.ui-icon-caret-1-sw{background-position:-80px 0}.ui-icon-caret-1-w{background-position:-96px 0}.ui-icon-caret-1-nw{background-position:-112px 0}.ui-icon-caret-2-n-s{background-position:-128px 0}.ui-icon-caret-2-e-w{background-position:-144px 0}.ui-icon-triangle-1-n{background-position:0 -16px}.ui-icon-triangle-1-ne{background-position:-16px -16px}.ui-icon-triangle-1-e{background-position:-32px -16px}.ui-icon-triangle-1-se{background-position:-48px -16px}.ui-icon-triangle-1-s{background-position:-65px -16px}.ui-icon-triangle-1-sw{background-position:-80px -16px}.ui-icon-triangle-1-w{background-position:-96px -16px}.ui-icon-triangle-1-nw{background-position:-112px -16px}.ui-icon-triangle-2-n-s{background-position:-128px -16px}.ui-icon-triangle-2-e-w{background-position:-144px -16px}.ui-icon-arrow-1-n{background-position:0 -32px}.ui-icon-arrow-1-ne{background-position:-16px -32px}.ui-icon-arrow-1-e{background-position:-32px -32px}.ui-icon-arrow-1-se{background-position:-48px -32px}.ui-icon-arrow-1-s{background-position:-65px -32px}.ui-icon-arrow-1-sw{background-position:-80px -32px}.ui-icon-arrow-1-w{background-position:-96px -32px}.ui-icon-arrow-1-nw{background-position:-112px -32px}.ui-icon-arrow-2-n-s{background-position:-128px -32px}.ui-icon-arrow-2-ne-sw{background-position:-144px -32px}.ui-icon-arrow-2-e-w{background-position:-160px -32px}.ui-icon-arrow-2-se-nw{background-position:-176px -32px}.ui-icon-arrowstop-1-n{background-position:-192px -32px}.ui-icon-arrowstop-1-e{background-position:-208px -32px}.ui-icon-arrowstop-1-s{background-position:-224px -32px}.ui-icon-arrowstop-1-w{background-position:-240px -32px}.ui-icon-arrowthick-1-n{background-position:1px -48px}.ui-icon-arrowthick-1-ne{background-position:-16px -48px}.ui-icon-arrowthick-1-e{background-position:-32px -48px}.ui-icon-arrowthick-1-se{background-position:-48px -48px}.ui-icon-arrowthick-1-s{background-position:-64px -48px}.ui-icon-arrowthick-1-sw{background-position:-80px -48px}.ui-icon-arrowthick-1-w{background-position:-96px -48px}.ui-icon-arrowthick-1-nw{background-position:-112px -48px}.ui-icon-arrowthick-2-n-s{background-position:-128px -48px}.ui-icon-arrowthick-2-ne-sw{background-position:-144px -48px}.ui-icon-arrowthick-2-e-w{background-position:-160px -48px}.ui-icon-arrowthick-2-se-nw{background-position:-176px -48px}.ui-icon-arrowthickstop-1-n{background-position:-192px -48px}.ui-icon-arrowthickstop-1-e{background-position:-208px -48px}.ui-icon-arrowthickstop-1-s{background-position:-224px -48px}.ui-icon-arrowthickstop-1-w{background-position:-240px -48px}.ui-icon-arrowreturnthick-1-w{background-position:0 -64px}.ui-icon-arrowreturnthick-1-n{background-position:-16px -64px}.ui-icon-arrowreturnthick-1-e{background-position:-32px -64px}.ui-icon-arrowreturnthick-1-s{background-position:-48px -64px}.ui-icon-arrowreturn-1-w{background-position:-64px -64px}.ui-icon-arrowreturn-1-n{background-position:-80px -64px}.ui-icon-arrowreturn-1-e{background-position:-96px -64px}.ui-icon-arrowreturn-1-s{background-position:-112px -64px}.ui-icon-arrowrefresh-1-w{background-position:-128px -64px}.ui-icon-arrowrefresh-1-n{background-position:-144px -64px}.ui-icon-arrowrefresh-1-e{background-position:-160px -64px}.ui-icon-arrowrefresh-1-s{background-position:-176px -64px}.ui-icon-arrow-4{background-position:0 -80px}.ui-icon-arrow-4-diag{background-position:-16px -80px}.ui-icon-extlink{background-position:-32px -80px}.ui-icon-newwin{background-position:-48px -80px}.ui-icon-refresh{background-position:-64px -80px}.ui-icon-shuffle{background-position:-80px -80px}.ui-icon-transfer-e-w{background-position:-96px -80px}.ui-icon-transferthick-e-w{background-position:-112px -80px}.ui-icon-folder-collapsed{background-position:0 -96px}.ui-icon-folder-open{background-position:-16px -96px}.ui-icon-document{background-position:-32px -96px}.ui-icon-document-b{background-position:-48px -96px}.ui-icon-note{background-position:-64px -96px}.ui-icon-mail-closed{background-position:-80px -96px}.ui-icon-mail-open{background-position:-96px -96px}.ui-icon-suitcase{background-position:-112px -96px}.ui-icon-comment{background-position:-128px -96px}.ui-icon-person{background-position:-144px -96px}.ui-icon-print{background-position:-160px -96px}.ui-icon-trash{background-position:-176px -96px}.ui-icon-locked{background-position:-192px -96px}.ui-icon-unlocked{background-position:-208px -96px}.ui-icon-bookmark{background-position:-224px -96px}.ui-icon-tag{background-position:-240px -96px}.ui-icon-home{background-position:0 -112px}.ui-icon-flag{background-position:-16px -112px}.ui-icon-calendar{background-position:-32px -112px}.ui-icon-cart{background-position:-48px -112px}.ui-icon-pencil{background-position:-64px -112px}.ui-icon-clock{background-position:-80px -112px}.ui-icon-disk{background-position:-96px -112px}.ui-icon-calculator{background-position:-112px -112px}.ui-icon-zoomin{background-position:-128px -112px}.ui-icon-zoomout{background-position:-144px -112px}.ui-icon-search{background-position:-160px -112px}.ui-icon-wrench{background-position:-176px -112px}.ui-icon-gear{background-position:-192px -112px}.ui-icon-heart{background-position:-208px -112px}.ui-icon-star{background-position:-224px -112px}.ui-icon-link{background-position:-240px -112px}.ui-icon-cancel{background-position:0 -128px}.ui-icon-plus{background-position:-16px -128px}.ui-icon-plusthick{background-position:-32px -128px}.ui-icon-minus{background-position:-48px -128px}.ui-icon-minusthick{background-position:-64px -128px}.ui-icon-close{background-position:-80px -128px}.ui-icon-closethick{background-position:-96px -128px}.ui-icon-key{background-position:-112px -128px}.ui-icon-lightbulb{background-position:-128px -128px}.ui-icon-scissors{background-position:-144px -128px}.ui-icon-clipboard{background-position:-160px -128px}.ui-icon-copy{background-position:-176px -128px}.ui-icon-contact{background-position:-192px -128px}.ui-icon-image{background-position:-208px -128px}.ui-icon-video{background-position:-224px -128px}.ui-icon-script{background-position:-240px -128px}.ui-icon-alert{background-position:0 -144px}.ui-icon-info{background-position:-16px -144px}.ui-icon-notice{background-position:-32px -144px}.ui-icon-help{background-position:-48px -144px}.ui-icon-check{background-position:-64px -144px}.ui-icon-bullet{background-position:-80px -144px}.ui-icon-radio-on{background-position:-96px -144px}.ui-icon-radio-off{background-position:-112px -144px}.ui-icon-pin-w{background-position:-128px -144px}.ui-icon-pin-s{background-position:-144px -144px}.ui-icon-play{background-position:0 -160px}.ui-icon-pause{background-position:-16px -160px}.ui-icon-seek-next{background-position:-32px -160px}.ui-icon-seek-prev{background-position:-48px -160px}.ui-icon-seek-end{background-position:-64px -160px}.ui-icon-seek-start{background-position:-80px -160px}.ui-icon-seek-first{background-position:-80px -160px}.ui-icon-stop{background-position:-96px -160px}.ui-icon-eject{background-position:-112px -160px}.ui-icon-volume-off{background-position:-128px -160px}.ui-icon-volume-on{background-position:-144px -160px}.ui-icon-power{background-position:0 -176px}.ui-icon-signal-diag{background-position:-16px -176px}.ui-icon-signal{background-position:-32px -176px}.ui-icon-battery-0{background-position:-48px -176px}.ui-icon-battery-1{background-position:-64px -176px}.ui-icon-battery-2{background-position:-80px -176px}.ui-icon-battery-3{background-position:-96px -176px}.ui-icon-circle-plus{background-position:0 -192px}.ui-icon-circle-minus{background-position:-16px -192px}.ui-icon-circle-close{background-position:-32px -192px}.ui-icon-circle-triangle-e{background-position:-48px -192px}.ui-icon-circle-triangle-s{background-position:-64px -192px}.ui-icon-circle-triangle-w{background-position:-80px -192px}.ui-icon-circle-triangle-n{background-position:-96px -192px}.ui-icon-circle-arrow-e{background-position:-112px -192px}.ui-icon-circle-arrow-s{background-position:-128px -192px}.ui-icon-circle-arrow-w{background-position:-144px -192px}.ui-icon-circle-arrow-n{background-position:-160px -192px}.ui-icon-circle-zoomin{background-position:-176px -192px}.ui-icon-circle-zoomout{background-position:-192px -192px}.ui-icon-circle-check{background-position:-208px -192px}.ui-icon-circlesmall-plus{background-position:0 -208px}.ui-icon-circlesmall-minus{background-position:-16px -208px}.ui-icon-circlesmall-close{background-position:-32px -208px}.ui-icon-squaresmall-plus{background-position:-48px -208px}.ui-icon-squaresmall-minus{background-position:-64px -208px}.ui-icon-squaresmall-close{background-position:-80px -208px}.ui-icon-grip-dotted-vertical{background-position:0 -224px}.ui-icon-grip-dotted-horizontal{background-position:-16px -224px}.ui-icon-grip-solid-vertical{background-position:-32px -224px}.ui-icon-grip-solid-horizontal{background-position:-48px -224px}.ui-icon-gripsmall-diagonal-se{background-position:-64px -224px}.ui-icon-grip-diagonal-se{background-position:-80px -224px}.ui-corner-all,.ui-corner-top,.ui-corner-left,.ui-corner-tl{border-top-left-radius:3px}.ui-corner-all,.ui-corner-top,.ui-corner-right,.ui-corner-tr{border-top-right-radius:3px}.ui-corner-all,.ui-corner-bottom,.ui-corner-left,.ui-corner-bl{border-bottom-left-radius:3px}.ui-corner-all,.ui-corner-bottom,.ui-corner-right,.ui-corner-br{border-bottom-right-radius:3px}.ui-widget-overlay{background:#aaa;opacity:.003;-ms-filter:Alpha(Opacity=.3)}.ui-widget-shadow{-webkit-box-shadow:0 0 5px #666;box-shadow:0 0 5px #666}
includes/css/jquery.timepicker.min.css CHANGED
@@ -1,11 +1,11 @@
1
  /**
2
- * jQuery Timepicker - v1.3.2 - 2014-09-13
3
  * http://timepicker.co
4
  *
5
  * Enhances standard form input fields helping users to select (or type) times.
6
  *
7
- * Copyright (c) 2014 Willington Vega; Licensed MIT, GPL
8
  */
9
 
10
 
11
- .ui-timepicker-container{position:absolute;overflow:hidden;box-sizing:border-box}.ui-timepicker{box-sizing:content-box;display:block;height:205px;list-style:none outside none;margin:0;padding:0 1px;text-align:center}.ui-timepicker-viewport{box-sizing:content-box;display:block;height:205px;margin:0;padding:0;overflow:auto;overflow-x:hidden}.ui-timepicker-standard{font-family:Verdana,Arial,sans-serif;background-color:#FFF;border:1px solid #AAA;color:#222;margin:0;padding:2px}.ui-timepicker-standard a{border:1px solid transparent;color:#222;display:block;text-decoration:none}.ui-timepicker-standard .ui-state-hover{background-color:#DADADA;border:1px solid #999;font-weight:400;color:#212121}.ui-timepicker-standard .ui-menu-item{margin:0;padding:0}.ui-timepicker-corners,.ui-timepicker-corners .ui-corner-all{-moz-border-radius:4px;-webkit-border-radius:4px;border-radius:4px}.ui-timepicker-hidden{display:none}.ui-timepicker-no-scrollbar .ui-timepicker{border:0}
1
  /**
2
+ * jQuery Timepicker - v1.3.5 - 2016-07-10
3
  * http://timepicker.co
4
  *
5
  * Enhances standard form input fields helping users to select (or type) times.
6
  *
7
+ * Copyright (c) 2016 Willington Vega; Licensed MIT, GPL
8
  */
9
 
10
 
11
+ .ui-timepicker-container{position:absolute;overflow:hidden;box-sizing:border-box}.ui-timepicker{box-sizing:content-box;display:block;height:205px;list-style:none outside none;margin:0;padding:0 1px;text-align:center}.ui-timepicker-viewport{box-sizing:content-box;display:block;height:205px;margin:0;padding:0;overflow:auto;overflow-x:hidden}.ui-timepicker-standard{font-family:Verdana,Arial,sans-serif;font-size:1.1em;background-color:#FFF;border:1px solid #AAA;color:#222;margin:0;padding:2px}.ui-timepicker-standard a{border:1px solid transparent;color:#222;display:block;padding:.2em .4em;text-decoration:none}.ui-timepicker-standard .ui-state-hover{background-color:#DADADA;border:1px solid #999;font-weight:400;color:#212121}.ui-timepicker-standard .ui-menu-item{margin:0;padding:0}.ui-timepicker-corners,.ui-timepicker-corners .ui-corner-all{-moz-border-radius:4px;-webkit-border-radius:4px;border-radius:4px}.ui-timepicker-hidden{display:none}.ui-timepicker-no-scrollbar .ui-timepicker{border:0}
includes/js/bootstrap-switch.min.js CHANGED
@@ -1,22 +1,10 @@
1
- /* ========================================================================
2
- * bootstrap-switch - v3.3.2
3
- * http://www.bootstrap-switch.org
4
- * ========================================================================
5
- * Copyright 2012-2013 Mattia Larentis
6
- *
7
- * ========================================================================
8
- * Licensed under the Apache License, Version 2.0 (the "License");
9
- * you may not use this file except in compliance with the License.
10
- * You may obtain a copy of the License at
11
- *
12
- * http://www.apache.org/licenses/LICENSE-2.0
13
- *
14
- * Unless required by applicable law or agreed to in writing, software
15
- * distributed under the License is distributed on an "AS IS" BASIS,
16
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17
- * See the License for the specific language governing permissions and
18
- * limitations under the License.
19
- * ========================================================================
20
- */
21
 
22
- (function(){var t=[].slice;!function(e,i){"use strict";var n;return n=function(){function t(t,i){null==i&&(i={}),this.$element=e(t),this.options=e.extend({},e.fn.bootstrapSwitch.defaults,{state:this.$element.is(":checked"),size:this.$element.data("size"),animate:this.$element.data("animate"),disabled:this.$element.is(":disabled"),readonly:this.$element.is("[readonly]"),indeterminate:this.$element.data("indeterminate"),inverse:this.$element.data("inverse"),radioAllOff:this.$element.data("radio-all-off"),onColor:this.$element.data("on-color"),offColor:this.$element.data("off-color"),onText:this.$element.data("on-text"),offText:this.$element.data("off-text"),labelText:this.$element.data("label-text"),handleWidth:this.$element.data("handle-width"),labelWidth:this.$element.data("label-width"),baseClass:this.$element.data("base-class"),wrapperClass:this.$element.data("wrapper-class")},i),this.prevOptions={},this.$wrapper=e("<div>",{"class":function(t){return function(){var e;return e=[""+t.options.baseClass].concat(t._getClasses(t.options.wrapperClass)),e.push(t.options.state?t.options.baseClass+"-on":t.options.baseClass+"-off"),null!=t.options.size&&e.push(t.options.baseClass+"-"+t.options.size),t.options.disabled&&e.push(t.options.baseClass+"-disabled"),t.options.readonly&&e.push(t.options.baseClass+"-readonly"),t.options.indeterminate&&e.push(t.options.baseClass+"-indeterminate"),t.options.inverse&&e.push(t.options.baseClass+"-inverse"),t.$element.attr("id")&&e.push(t.options.baseClass+"-id-"+t.$element.attr("id")),e.join(" ")}}(this)()}),this.$container=e("<div>",{"class":this.options.baseClass+"-container"}),this.$on=e("<span>",{html:this.options.onText,"class":this.options.baseClass+"-handle-on "+this.options.baseClass+"-"+this.options.onColor}),this.$off=e("<span>",{html:this.options.offText,"class":this.options.baseClass+"-handle-off "+this.options.baseClass+"-"+this.options.offColor}),this.$label=e("<span>",{html:this.options.labelText,"class":this.options.baseClass+"-label"}),this.$element.on("init.bootstrapSwitch",function(e){return function(){return e.options.onInit.apply(t,arguments)}}(this)),this.$element.on("switchChange.bootstrapSwitch",function(i){return function(n){return!1===i.options.onSwitchChange.apply(t,arguments)?i.$element.is(":radio")?e("[name='"+i.$element.attr("name")+"']").trigger("previousState.bootstrapSwitch",!0):i.$element.trigger("previousState.bootstrapSwitch",!0):void 0}}(this)),this.$container=this.$element.wrap(this.$container).parent(),this.$wrapper=this.$container.wrap(this.$wrapper).parent(),this.$element.before(this.options.inverse?this.$off:this.$on).before(this.$label).before(this.options.inverse?this.$on:this.$off),this.options.indeterminate&&this.$element.prop("indeterminate",!0),this._init(),this._elementHandlers(),this._handleHandlers(),this._labelHandlers(),this._formHandler(),this._externalLabelHandler(),this.$element.trigger("init.bootstrapSwitch",this.options.state)}return t.prototype._constructor=t,t.prototype.setPrevOptions=function(){return this.prevOptions=e.extend(!0,{},this.options)},t.prototype.state=function(t,i){return"undefined"==typeof t?this.options.state:this.options.disabled||this.options.readonly?this.$element:this.options.state&&!this.options.radioAllOff&&this.$element.is(":radio")?this.$element:(this.$element.is(":radio")?e("[name='"+this.$element.attr("name")+"']").trigger("setPreviousOptions.bootstrapSwitch"):this.$element.trigger("setPreviousOptions.bootstrapSwitch"),this.options.indeterminate&&this.indeterminate(!1),t=!!t,this.$element.prop("checked",t).trigger("change.bootstrapSwitch",i),this.$element)},t.prototype.toggleState=function(t){return this.options.disabled||this.options.readonly?this.$element:this.options.indeterminate?(this.indeterminate(!1),this.state(!0)):this.$element.prop("checked",!this.options.state).trigger("change.bootstrapSwitch",t)},t.prototype.size=function(t){return"undefined"==typeof t?this.options.size:(null!=this.options.size&&this.$wrapper.removeClass(this.options.baseClass+"-"+this.options.size),t&&this.$wrapper.addClass(this.options.baseClass+"-"+t),this._width(),this._containerPosition(),this.options.size=t,this.$element)},t.prototype.animate=function(t){return"undefined"==typeof t?this.options.animate:(t=!!t,t===this.options.animate?this.$element:this.toggleAnimate())},t.prototype.toggleAnimate=function(){return this.options.animate=!this.options.animate,this.$wrapper.toggleClass(this.options.baseClass+"-animate"),this.$element},t.prototype.disabled=function(t){return"undefined"==typeof t?this.options.disabled:(t=!!t,t===this.options.disabled?this.$element:this.toggleDisabled())},t.prototype.toggleDisabled=function(){return this.options.disabled=!this.options.disabled,this.$element.prop("disabled",this.options.disabled),this.$wrapper.toggleClass(this.options.baseClass+"-disabled"),this.$element},t.prototype.readonly=function(t){return"undefined"==typeof t?this.options.readonly:(t=!!t,t===this.options.readonly?this.$element:this.toggleReadonly())},t.prototype.toggleReadonly=function(){return this.options.readonly=!this.options.readonly,this.$element.prop("readonly",this.options.readonly),this.$wrapper.toggleClass(this.options.baseClass+"-readonly"),this.$element},t.prototype.indeterminate=function(t){return"undefined"==typeof t?this.options.indeterminate:(t=!!t,t===this.options.indeterminate?this.$element:this.toggleIndeterminate())},t.prototype.toggleIndeterminate=function(){return this.options.indeterminate=!this.options.indeterminate,this.$element.prop("indeterminate",this.options.indeterminate),this.$wrapper.toggleClass(this.options.baseClass+"-indeterminate"),this._containerPosition(),this.$element},t.prototype.inverse=function(t){return"undefined"==typeof t?this.options.inverse:(t=!!t,t===this.options.inverse?this.$element:this.toggleInverse())},t.prototype.toggleInverse=function(){var t,e;return this.$wrapper.toggleClass(this.options.baseClass+"-inverse"),e=this.$on.clone(!0),t=this.$off.clone(!0),this.$on.replaceWith(t),this.$off.replaceWith(e),this.$on=t,this.$off=e,this.options.inverse=!this.options.inverse,this.$element},t.prototype.onColor=function(t){var e;return e=this.options.onColor,"undefined"==typeof t?e:(null!=e&&this.$on.removeClass(this.options.baseClass+"-"+e),this.$on.addClass(this.options.baseClass+"-"+t),this.options.onColor=t,this.$element)},t.prototype.offColor=function(t){var e;return e=this.options.offColor,"undefined"==typeof t?e:(null!=e&&this.$off.removeClass(this.options.baseClass+"-"+e),this.$off.addClass(this.options.baseClass+"-"+t),this.options.offColor=t,this.$element)},t.prototype.onText=function(t){return"undefined"==typeof t?this.options.onText:(this.$on.html(t),this._width(),this._containerPosition(),this.options.onText=t,this.$element)},t.prototype.offText=function(t){return"undefined"==typeof t?this.options.offText:(this.$off.html(t),this._width(),this._containerPosition(),this.options.offText=t,this.$element)},t.prototype.labelText=function(t){return"undefined"==typeof t?this.options.labelText:(this.$label.html(t),this._width(),this.options.labelText=t,this.$element)},t.prototype.handleWidth=function(t){return"undefined"==typeof t?this.options.handleWidth:(this.options.handleWidth=t,this._width(),this._containerPosition(),this.$element)},t.prototype.labelWidth=function(t){return"undefined"==typeof t?this.options.labelWidth:(this.options.labelWidth=t,this._width(),this._containerPosition(),this.$element)},t.prototype.baseClass=function(t){return this.options.baseClass},t.prototype.wrapperClass=function(t){return"undefined"==typeof t?this.options.wrapperClass:(t||(t=e.fn.bootstrapSwitch.defaults.wrapperClass),this.$wrapper.removeClass(this._getClasses(this.options.wrapperClass).join(" ")),this.$wrapper.addClass(this._getClasses(t).join(" ")),this.options.wrapperClass=t,this.$element)},t.prototype.radioAllOff=function(t){return"undefined"==typeof t?this.options.radioAllOff:(t=!!t,t===this.options.radioAllOff?this.$element:(this.options.radioAllOff=t,this.$element))},t.prototype.onInit=function(t){return"undefined"==typeof t?this.options.onInit:(t||(t=e.fn.bootstrapSwitch.defaults.onInit),this.options.onInit=t,this.$element)},t.prototype.onSwitchChange=function(t){return"undefined"==typeof t?this.options.onSwitchChange:(t||(t=e.fn.bootstrapSwitch.defaults.onSwitchChange),this.options.onSwitchChange=t,this.$element)},t.prototype.destroy=function(){var t;return t=this.$element.closest("form"),t.length&&t.off("reset.bootstrapSwitch").removeData("bootstrap-switch"),this.$container.children().not(this.$element).remove(),this.$element.unwrap().unwrap().off(".bootstrapSwitch").removeData("bootstrap-switch"),this.$element},t.prototype._width=function(){var t,e;return t=this.$on.add(this.$off),t.add(this.$label).css("width",""),e="auto"===this.options.handleWidth?Math.max(this.$on.width(),this.$off.width()):this.options.handleWidth,t.width(e),this.$label.width(function(t){return function(i,n){return"auto"!==t.options.labelWidth?t.options.labelWidth:e>n?e:n}}(this)),this._handleWidth=this.$on.outerWidth(),this._labelWidth=this.$label.outerWidth(),this.$container.width(2*this._handleWidth+this._labelWidth),this.$wrapper.width(this._handleWidth+this._labelWidth)},t.prototype._containerPosition=function(t,e){return null==t&&(t=this.options.state),this.$container.css("margin-left",function(e){return function(){var i;return i=[0,"-"+e._handleWidth+"px"],e.options.indeterminate?"-"+e._handleWidth/2+"px":t?e.options.inverse?i[1]:i[0]:e.options.inverse?i[0]:i[1]}}(this)),e?setTimeout(function(){return e()},50):void 0},t.prototype._init=function(){var t,e;return t=function(t){return function(){return t.setPrevOptions(),t._width(),t._containerPosition(null,function(){return t.options.animate?t.$wrapper.addClass(t.options.baseClass+"-animate"):void 0})}}(this),this.$wrapper.is(":visible")?t():e=i.setInterval(function(n){return function(){return n.$wrapper.is(":visible")?(t(),i.clearInterval(e)):void 0}}(this),50)},t.prototype._elementHandlers=function(){return this.$element.on({"setPreviousOptions.bootstrapSwitch":function(t){return function(e){return t.setPrevOptions()}}(this),"previousState.bootstrapSwitch":function(t){return function(e){return t.options=t.prevOptions,t.options.indeterminate&&t.$wrapper.addClass(t.options.baseClass+"-indeterminate"),t.$element.prop("checked",t.options.state).trigger("change.bootstrapSwitch",!0)}}(this),"change.bootstrapSwitch":function(t){return function(i,n){var o;return i.preventDefault(),i.stopImmediatePropagation(),o=t.$element.is(":checked"),t._containerPosition(o),o!==t.options.state?(t.options.state=o,t.$wrapper.toggleClass(t.options.baseClass+"-off").toggleClass(t.options.baseClass+"-on"),n?void 0:(t.$element.is(":radio")&&e("[name='"+t.$element.attr("name")+"']").not(t.$element).prop("checked",!1).trigger("change.bootstrapSwitch",!0),t.$element.trigger("switchChange.bootstrapSwitch",[o]))):void 0}}(this),"focus.bootstrapSwitch":function(t){return function(e){return e.preventDefault(),t.$wrapper.addClass(t.options.baseClass+"-focused")}}(this),"blur.bootstrapSwitch":function(t){return function(e){return e.preventDefault(),t.$wrapper.removeClass(t.options.baseClass+"-focused")}}(this),"keydown.bootstrapSwitch":function(t){return function(e){if(e.which&&!t.options.disabled&&!t.options.readonly)switch(e.which){case 37:return e.preventDefault(),e.stopImmediatePropagation(),t.state(!1);case 39:return e.preventDefault(),e.stopImmediatePropagation(),t.state(!0)}}}(this)})},t.prototype._handleHandlers=function(){return this.$on.on("click.bootstrapSwitch",function(t){return function(e){return e.preventDefault(),e.stopPropagation(),t.state(!1),t.$element.trigger("focus.bootstrapSwitch")}}(this)),this.$off.on("click.bootstrapSwitch",function(t){return function(e){return e.preventDefault(),e.stopPropagation(),t.state(!0),t.$element.trigger("focus.bootstrapSwitch")}}(this))},t.prototype._labelHandlers=function(){return this.$label.on({click:function(t){return t.stopPropagation()},"mousedown.bootstrapSwitch touchstart.bootstrapSwitch":function(t){return function(e){return t._dragStart||t.options.disabled||t.options.readonly?void 0:(e.preventDefault(),e.stopPropagation(),t._dragStart=(e.pageX||e.originalEvent.touches[0].pageX)-parseInt(t.$container.css("margin-left"),10),t.options.animate&&t.$wrapper.removeClass(t.options.baseClass+"-animate"),t.$element.trigger("focus.bootstrapSwitch"))}}(this),"mousemove.bootstrapSwitch touchmove.bootstrapSwitch":function(t){return function(e){var i;if(null!=t._dragStart&&(e.preventDefault(),i=(e.pageX||e.originalEvent.touches[0].pageX)-t._dragStart,!(i<-t._handleWidth||i>0)))return t._dragEnd=i,t.$container.css("margin-left",t._dragEnd+"px")}}(this),"mouseup.bootstrapSwitch touchend.bootstrapSwitch":function(t){return function(e){var i;if(t._dragStart)return e.preventDefault(),t.options.animate&&t.$wrapper.addClass(t.options.baseClass+"-animate"),t._dragEnd?(i=t._dragEnd>-(t._handleWidth/2),t._dragEnd=!1,t.state(t.options.inverse?!i:i)):t.state(!t.options.state),t._dragStart=!1}}(this),"mouseleave.bootstrapSwitch":function(t){return function(e){return t.$label.trigger("mouseup.bootstrapSwitch")}}(this)})},t.prototype._externalLabelHandler=function(){var t;return t=this.$element.closest("label"),t.on("click",function(e){return function(i){return i.preventDefault(),i.stopImmediatePropagation(),i.target===t[0]?e.toggleState():void 0}}(this))},t.prototype._formHandler=function(){var t;return t=this.$element.closest("form"),t.data("bootstrap-switch")?void 0:t.on("reset.bootstrapSwitch",function(){return i.setTimeout(function(){return t.find("input").filter(function(){return e(this).data("bootstrap-switch")}).each(function(){return e(this).bootstrapSwitch("state",this.checked)})},1)}).data("bootstrap-switch",!0)},t.prototype._getClasses=function(t){var i,n,o,s;if(!e.isArray(t))return[this.options.baseClass+"-"+t];for(n=[],o=0,s=t.length;s>o;o++)i=t[o],n.push(this.options.baseClass+"-"+i);return n},t}(),e.fn.bootstrapSwitch=function(){var i,o,s;return o=arguments[0],i=2<=arguments.length?t.call(arguments,1):[],s=this,this.each(function(){var t,a;return t=e(this),a=t.data("bootstrap-switch"),a||t.data("bootstrap-switch",a=new n(this,o)),"string"==typeof o?s=a[o].apply(a,i):void 0}),s},e.fn.bootstrapSwitch.Constructor=n,e.fn.bootstrapSwitch.defaults={state:!0,size:null,animate:!0,disabled:!1,readonly:!1,indeterminate:!1,inverse:!1,radioAllOff:!1,onColor:"primary",offColor:"default",onText:"ON",offText:"OFF",labelText:"&nbsp;",handleWidth:"auto",labelWidth:"auto",baseClass:"bootstrap-switch",wrapperClass:"wrapper",onInit:function(){},onSwitchChange:function(){}}}(window.jQuery,window)}).call(this);
1
+ /**
2
+ * bootstrap-switch - Turn checkboxes and radio buttons into toggle switches.
3
+ *
4
+ * @version v3.3.5
5
+ * @homepage https://bttstrp.github.io/bootstrap-switch
6
+ * @author Mattia Larentis <mattia@larentis.eu> (http://larentis.eu)
7
+ * @license MIT
8
+ */
 
 
 
 
 
 
 
 
 
 
 
 
9
 
10
+ (function(a,b){if('function'==typeof define&&define.amd)define(['jquery'],b);else if('undefined'!=typeof exports)b(require('jquery'));else{b(a.jquery),a.bootstrapSwitch={exports:{}}.exports}})(this,function(a){'use strict';function c(x,y){if(!(x instanceof y))throw new TypeError('Cannot call a class as a function')}function d(x,y){var z=x.state,A=x.size,B=x.disabled,C=x.readonly,D=x.indeterminate,E=x.inverse;return[z?'on':'off',A,B?'disabled':void 0,C?'readonly':void 0,D?'indeterminate':void 0,E?'inverse':void 0,y?'id-'+y:void 0].filter(function(F){return null==F})}function e(){return{state:this.$element.is(':checked'),size:this.$element.data('size'),animate:this.$element.data('animate'),disabled:this.$element.is(':disabled'),readonly:this.$element.is('[readonly]'),indeterminate:this.$element.data('indeterminate'),inverse:this.$element.data('inverse'),radioAllOff:this.$element.data('radio-all-off'),onColor:this.$element.data('on-color'),offColor:this.$element.data('off-color'),onText:this.$element.data('on-text'),offText:this.$element.data('off-text'),labelText:this.$element.data('label-text'),handleWidth:this.$element.data('handle-width'),labelWidth:this.$element.data('label-width'),baseClass:this.$element.data('base-class'),wrapperClass:this.$element.data('wrapper-class')}}function f(){var x=this,y=this.$on.add(this.$off).add(this.$label).css('width',''),z='auto'===this.options.handleWidth?Math.round(Math.max(this.$on.width(),this.$off.width())):this.options.handleWidth;return y.width(z),this.$label.width(function(A,B){return'auto'===x.options.labelWidth?B<z?z:B:x.options.labelWidth}),this.privateHandleWidth=this.$on.outerWidth(),this.privateLabelWidth=this.$label.outerWidth(),this.$container.width(2*this.privateHandleWidth+this.privateLabelWidth),this.$wrapper.width(this.privateHandleWidth+this.privateLabelWidth)}function g(){var x=this,y=0<arguments.length&&arguments[0]!==void 0?arguments[0]:this.ope;this.$container.css('margin-left',function(){var z=[0,'-'+x.privateHandleWidth+'px'];return x.options.indeterminate?'-'+x.privateHandleWidth/2+'px':y?x.options.inverse?z[1]:z[0]:x.options.inverse?z[0]:z[1]})}function h(x){return this.options.baseClass+'-'+x}function j(){var x=this,y=function(){x.setPrevOptions(),f.call(x),g.call(x),setTimeout(function(){return x.options.animate&&x.$wrapper.addClass(h.call(x,'animate'))},50)};if(this.$wrapper.is(':visible'))return void y();var z=window.setInterval(function(){return x.$wrapper.is(':visible')&&(y()||!0)&&window.clearInterval(z)},50)}function k(){var x=this;return this.$element.on({'setPreviousOptions.bootstrapSwitch':function(){return x.setPrevOptions()},'previousState.bootstrapSwitch':function(){x.options=x.prevOptions,x.options.indeterminate&&x.$wrapper.addClass(h.call(x,'indeterminate')),x.$element.prop('checked',x.options.state).trigger('change.bootstrapSwitch',!0)},'change.bootstrapSwitch':function(z,A){z.preventDefault(),z.stopImmediatePropagation();var B=x.$element.is(':checked');g.call(x,B);B===x.options.state||(x.options.state=B,x.$wrapper.toggleClass(h.call(x,'off')).toggleClass(h.call(x,'on')),!A&&(x.$element.is(':radio')&&u('[name="'+x.$element.attr('name')+'"]').not(x.$element).prop('checked',!1).trigger('change.bootstrapSwitch',!0),x.$element.trigger('switchChange.bootstrapSwitch',[B])))},'focus.bootstrapSwitch':function(z){z.preventDefault(),x.$wrapper.addClass(h.call(x,'focused'))},'blur.bootstrapSwitch':function(z){z.preventDefault(),x.$wrapper.removeClass(h.call(x,'focused'))},'keydown.bootstrapSwitch':function(z){!z.which||x.options.disabled||x.options.readonly||(37===z.which||39===z.which)&&(z.preventDefault(),z.stopImmediatePropagation(),x.state(39===z.which))}})}function l(){var x=this;return this.$on.on('click.bootstrapSwitch',function(y){return y.preventDefault(),y.stopPropagation(),x.state(!1),x.$element.trigger('focus.bootstrapSwitch')}),this.$off.on('click.bootstrapSwitch',function(y){return y.preventDefault(),y.stopPropagation(),x.state(!0),x.$element.trigger('focus.bootstrapSwitch')})}function m(){var x=this,y=void 0,z=void 0;this.$label.on({click:function(C){C.stopPropagation()},'mousedown.bootstrapSwitch touchstart.bootstrapSwitch':function(C){y||x.options.disabled||x.options.readonly||(C.preventDefault(),C.stopPropagation(),y=(C.pageX||C.originalEvent.touches[0].pageX)-parseInt(x.$container.css('margin-left'),10),x.options.animate&&x.$wrapper.removeClass(h.call(x,'animate')),x.$element.trigger('focus.bootstrapSwitch'))},'mousemove.bootstrapSwitch touchmove.bootstrapSwitch':function(C){if(null!=y){var D=(C.pageX||C.originalEvent.touches[0].pageX)-y;C.preventDefault(),D<-x.privateHandleWidth||0<D||(z=D,x.$container.css('margin-left',z+'px'))}},'mouseup.bootstrapSwitch touchend.bootstrapSwitch':function(C){if(y){if(C.preventDefault(),x.options.animate&&x.$wrapper.addClass(h.call(x,'animate')),z){var D=z>-(x.privateHandleWidth/2);z=!1,x.state(x.options.inverse?!D:D)}else x.state(!x.options.state);y=!1}},'mouseleave.bootstrapSwitch':function(){x.$label.trigger('mouseup.bootstrapSwitch')}})}function n(){var x=this,y=this.$element.closest('label');y.on('click',function(z){z.preventDefault(),z.stopImmediatePropagation(),z.target===y[0]&&x.toggleState()})}function o(){function x(){return u(this).data('bootstrap-switch')}function y(){return u(this).bootstrapSwitch('state',this.checked)}var z=this.$element.closest('form');z.data('bootstrap-switch')||z.on('reset.bootstrapSwitch',function(){window.setTimeout(function(){z.find('input').filter(x).each(y)},1)}).data('bootstrap-switch',!0)}function p(x){var y=this;return u.isArray(x)?x.map(function(z){return h.call(y,z)}):[h.call(this,x)]}var r=function(x){return x&&x.__esModule?x:{default:x}}(a),s=Object.assign||function(x){for(var z,y=1;y<arguments.length;y++)for(var A in z=arguments[y],z)Object.prototype.hasOwnProperty.call(z,A)&&(x[A]=z[A]);return x},t=function(){function x(y,z){for(var B,A=0;A<z.length;A++)B=z[A],B.enumerable=B.enumerable||!1,B.configurable=!0,'value'in B&&(B.writable=!0),Object.defineProperty(y,B.key,B)}return function(y,z,A){return z&&x(y.prototype,z),A&&x(y,A),y}}(),u=r.default||window.jQuery||window.$,w=function(){function x(y){var z=this,A=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{};c(this,x),this.$element=u(y),this.options=u.extend({},u.fn.bootstrapSwitch.defaults,e.call(this),A),this.prevOptions={},this.$wrapper=u('<div>',{class:function(){return d(z.options,z.$element.attr('id')).map(function(C){return h.call(z,C)}).concat([z.options.baseClass],p.call(z,z.options.wrapperClass)).join(' ')}}),this.$container=u('<div>',{class:h.call(this,'container')}),this.$on=u('<span>',{html:this.options.onText,class:h.call(this,'handle-on')+' '+h.call(this,this.options.onColor)}),this.$off=u('<span>',{html:this.options.offText,class:h.call(this,'handle-off')+' '+h.call(this,this.options.offColor)}),this.$label=u('<span>',{html:this.options.labelText,class:h.call(this,'label')}),this.$element.on('init.bootstrapSwitch',function(){return z.options.onInit(y)}),this.$element.on('switchChange.bootstrapSwitch',function(){for(var B=arguments.length,C=Array(B),D=0;D<B;D++)C[D]=arguments[D];var E=z.options.onSwitchChange.apply(y,C);!1===E&&(z.$element.is(':radio')?u('[name="'+z.$element.attr('name')+'"]').trigger('previousState.bootstrapSwitch',!0):z.$element.trigger('previousState.bootstrapSwitch',!0))}),this.$container=this.$element.wrap(this.$container).parent(),this.$wrapper=this.$container.wrap(this.$wrapper).parent(),this.$element.before(this.options.inverse?this.$off:this.$on).before(this.$label).before(this.options.inverse?this.$on:this.$off),this.options.indeterminate&&this.$element.prop('indeterminate',!0),j.call(this),k.call(this),l.call(this),m.call(this),o.call(this),n.call(this),this.$element.trigger('init.bootstrapSwitch',this.options.state)}return t(x,[{key:'setPrevOptions',value:function(){this.prevOptions=s({},this.options)}},{key:'state',value:function(z,A){return'undefined'==typeof z?this.options.state:this.options.disabled||this.options.readonly||this.options.state&&!this.options.radioAllOff&&this.$element.is(':radio')?this.$element:(this.$element.is(':radio')?u('[name="'+this.$element.attr('name')+'"]').trigger('setPreviousOptions.bootstrapSwitch'):this.$element.trigger('setPreviousOptions.bootstrapSwitch'),this.options.indeterminate&&this.indeterminate(!1),this.$element.prop('checked',!!z).trigger('change.bootstrapSwitch',A),this.$element)}},{key:'toggleState',value:function(z){return this.options.disabled||this.options.readonly?this.$element:this.options.indeterminate?(this.indeterminate(!1),this.state(!0)):this.$element.prop('checked',!this.options.state).trigger('change.bootstrapSwitch',z)}},{key:'size',value:function(z){return'undefined'==typeof z?this.options.size:(null!=this.options.size&&this.$wrapper.removeClass(h.call(this,this.options.size)),z&&this.$wrapper.addClass(h.call(this,z)),f.call(this),g.call(this),this.options.size=z,this.$element)}},{key:'animate',value:function(z){return'undefined'==typeof z?this.options.animate:this.options.animate===!!z?this.$element:this.toggleAnimate()}},{key:'toggleAnimate',value:function(){return this.options.animate=!this.options.animate,this.$wrapper.toggleClass(h.call(this,'animate')),this.$element}},{key:'disabled',value:function(z){return'undefined'==typeof z?this.options.disabled:this.options.disabled===!!z?this.$element:this.toggleDisabled()}},{key:'toggleDisabled',value:function(){return this.options.disabled=!this.options.disabled,this.$element.prop('disabled',this.options.disabled),this.$wrapper.toggleClass(h.call(this,'disabled')),this.$element}},{key:'readonly',value:function(z){return'undefined'==typeof z?this.options.readonly:this.options.readonly===!!z?this.$element:this.toggleReadonly()}},{key:'toggleReadonly',value:function(){return this.options.readonly=!this.options.readonly,this.$element.prop('readonly',this.options.readonly),this.$wrapper.toggleClass(h.call(this,'readonly')),this.$element}},{key:'indeterminate',value:function(z){return'undefined'==typeof z?this.options.indeterminate:this.options.indeterminate===!!z?this.$element:this.toggleIndeterminate()}},{key:'toggleIndeterminate',value:function(){return this.options.indeterminate=!this.options.indeterminate,this.$element.prop('indeterminate',this.options.indeterminate),this.$wrapper.toggleClass(h.call(this,'indeterminate')),g.call(this),this.$element}},{key:'inverse',value:function(z){return'undefined'==typeof z?this.options.inverse:this.options.inverse===!!z?this.$element:this.toggleInverse()}},{key:'toggleInverse',value:function(){this.$wrapper.toggleClass(h.call(this,'inverse'));var z=this.$on.clone(!0),A=this.$off.clone(!0);return this.$on.replaceWith(A),this.$off.replaceWith(z),this.$on=A,this.$off=z,this.options.inverse=!this.options.inverse,this.$element}},{key:'onColor',value:function(z){return'undefined'==typeof z?this.options.onColor:(this.options.onColor&&this.$on.removeClass(h.call(this,this.options.onColor)),this.$on.addClass(h.call(this,z)),this.options.onColor=z,this.$element)}},{key:'offColor',value:function(z){return'undefined'==typeof z?this.options.offColor:(this.options.offColor&&this.$off.removeClass(h.call(this,this.options.offColor)),this.$off.addClass(h.call(this,z)),this.options.offColor=z,this.$element)}},{key:'onText',value:function(z){return'undefined'==typeof z?this.options.onText:(this.$on.html(z),f.call(this),g.call(this),this.options.onText=z,this.$element)}},{key:'offText',value:function(z){return'undefined'==typeof z?this.options.offText:(this.$off.html(z),f.call(this),g.call(this),this.options.offText=z,this.$element)}},{key:'labelText',value:function(z){return'undefined'==typeof z?this.options.labelText:(this.$label.html(z),f.call(this),this.options.labelText=z,this.$element)}},{key:'handleWidth',value:function(z){return'undefined'==typeof z?this.options.handleWidth:(this.options.handleWidth=z,f.call(this),g.call(this),this.$element)}},{key:'labelWidth',value:function(z){return'undefined'==typeof z?this.options.labelWidth:(this.options.labelWidth=z,f.call(this),g.call(this),this.$element)}},{key:'baseClass',value:function(){return this.options.baseClass}},{key:'wrapperClass',value:function(z){if('undefined'==typeof z)return this.options.wrapperClass;var y=z||u.fn.bootstrapSwitch.defaults.wrapperClass;return this.$wrapper.removeClass(p.call(this,this.options.wrapperClass).join(' ')),this.$wrapper.addClass(p.call(this,y).join(' ')),this.options.wrapperClass=y,this.$element}},{key:'radioAllOff',value:function(z){if('undefined'==typeof z)return this.options.radioAllOff;var A=!!z;return this.options.radioAllOff===A?this.$element:(this.options.radioAllOff=A,this.$element)}},{key:'onInit',value:function(z){return'undefined'==typeof z?this.options.onInit:(this.options.onInit=z||u.fn.bootstrapSwitch.defaults.onInit,this.$element)}},{key:'onSwitchChange',value:function(z){return'undefined'==typeof z?this.options.onSwitchChange:(this.options.onSwitchChange=z||u.fn.bootstrapSwitch.defaults.onSwitchChange,this.$element)}},{key:'destroy',value:function(){var z=this.$element.closest('form');return z.length&&z.off('reset.bootstrapSwitch').removeData('bootstrap-switch'),this.$container.children().not(this.$element).remove(),this.$element.unwrap().unwrap().off('.bootstrapSwitch').removeData('bootstrap-switch'),this.$element}}]),x}();u.fn.bootstrapSwitch=function(x){for(var z=arguments.length,A=Array(1<z?z-1:0),B=1;B<z;B++)A[B-1]=arguments[B];return Array.prototype.reduce.call(this,function(C,D){var E=u(D),F=E.data('bootstrap-switch'),G=F||new w(D,x);return F||E.data('bootstrap-switch',G),'string'==typeof x?G[x].apply(G,A):C},this)},u.fn.bootstrapSwitch.Constructor=w,u.fn.bootstrapSwitch.defaults={state:!0,size:null,animate:!0,disabled:!1,readonly:!1,indeterminate:!1,inverse:!1,radioAllOff:!1,onColor:'primary',offColor:'default',onText:'ON',offText:'OFF',labelText:'&nbsp',handleWidth:'auto',labelWidth:'auto',baseClass:'bootstrap-switch',wrapperClass:'wrapper',onInit:function(){},onSwitchChange:function(){}}});
includes/js/codemirror.min.js ADDED
@@ -0,0 +1 @@
 
1
+ !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):(e=e||self).CodeMirror=t()}(this,function(){"use strict";var e=navigator.userAgent,t=navigator.platform,g=/gecko\/\d/i.test(e),r=/MSIE \d/.test(e),n=/Trident\/(?:[7-9]|\d{2,})\..*rv:(\d+)/.exec(e),i=/Edge\/(\d+)/.exec(e),x=r||n||i,C=x&&(r?document.documentMode||6:+(i||n)[1]),b=!i&&/WebKit\//.test(e),o=b&&/Qt\/\d+\.\d+/.test(e),l=!i&&/Chrome\//.test(e),v=/Opera\//.test(e),a=/Apple Computer/.test(navigator.vendor),s=/Mac OS X 1\d\D([8-9]|\d\d)\D/.test(e),u=/PhantomJS/.test(e),c=!i&&/AppleWebKit/.test(e)&&/Mobile\/\w+/.test(e),h=/Android/.test(e),f=c||h||/webOS|BlackBerry|Opera Mini|Opera Mobi|IEMobile/i.test(e),w=c||/Mac/.test(t),d=/\bCrOS\b/.test(e),p=/win/i.test(t),m=v&&e.match(/Version\/(\d*\.\d*)/);(m=m&&Number(m[1]))&&15<=m&&(b=!(v=!1));var y=w&&(o||v&&(null==m||m<12.11)),S=g||x&&9<=C;function L(e){return new RegExp("(^|\\s)"+e+"(?:$|\\s)\\s*")}var k,T=function(e,t){var r=e.className,n=L(t).exec(r);if(n){var i=r.slice(n.index+n[0].length);e.className=r.slice(0,n.index)+(i?n[1]+i:"")}};function M(e){for(var t=e.childNodes.length;0<t;--t)e.removeChild(e.firstChild);return e}function N(e,t){return M(e).appendChild(t)}function A(e,t,r,n){var i=document.createElement(e);if(r&&(i.className=r),n&&(i.style.cssText=n),"string"==typeof t)i.appendChild(document.createTextNode(t));else if(t)for(var o=0;o<t.length;++o)i.appendChild(t[o]);return i}function O(e,t,r,n){var i=A(e,t,r,n);return i.setAttribute("role","presentation"),i}function D(e,t){if(3==t.nodeType&&(t=t.parentNode),e.contains)return e.contains(t);do{if(11==t.nodeType&&(t=t.host),t==e)return!0}while(t=t.parentNode)}function W(){var t;try{t=document.activeElement}catch(e){t=document.body||null}for(;t&&t.shadowRoot&&t.shadowRoot.activeElement;)t=t.shadowRoot.activeElement;return t}function H(e,t){var r=e.className;L(t).test(r)||(e.className+=(r?" ":"")+t)}function F(e,t){for(var r=e.split(" "),n=0;n<r.length;n++)r[n]&&!L(r[n]).test(t)&&(t+=" "+r[n]);return t}k=document.createRange?function(e,t,r,n){var i=document.createRange();return i.setEnd(n||e,r),i.setStart(e,t),i}:function(e,t,r){var n=document.body.createTextRange();try{n.moveToElementText(e.parentNode)}catch(e){return n}return n.collapse(!0),n.moveEnd("character",r),n.moveStart("character",t),n};var P=function(e){e.select()};function E(e){var t=Array.prototype.slice.call(arguments,1);return function(){return e.apply(null,t)}}function I(e,t,r){for(var n in t=t||{},e)!e.hasOwnProperty(n)||!1===r&&t.hasOwnProperty(n)||(t[n]=e[n]);return t}function z(e,t,r,n,i){null==t&&-1==(t=e.search(/[^\s\u00a0]/))&&(t=e.length);for(var o=n||0,l=i||0;;){var s=e.indexOf("\t",o);if(s<0||t<=s)return l+(t-o);l+=s-o,l+=r-l%r,o=s+1}}c?P=function(e){e.selectionStart=0,e.selectionEnd=e.value.length}:x&&(P=function(e){try{e.select()}catch(e){}});var R=function(){this.id=null,this.f=null,this.time=0,this.handler=E(this.onTimeout,this)};function B(e,t){for(var r=0;r<e.length;++r)if(e[r]==t)return r;return-1}R.prototype.onTimeout=function(e){e.id=0,e.time<=+new Date?e.f():setTimeout(e.handler,e.time-new Date)},R.prototype.set=function(e,t){this.f=t;var r=+new Date+e;(!this.id||r<this.time)&&(clearTimeout(this.id),this.id=setTimeout(this.handler,e),this.time=r)};var G=30,U={toString:function(){return"CodeMirror.Pass"}},V={scroll:!1},K={origin:"*mouse"},j={origin:"+move"};function X(e,t,r){for(var n=0,i=0;;){var o=e.indexOf("\t",n);-1==o&&(o=e.length);var l=o-n;if(o==e.length||t<=i+l)return n+Math.min(l,t-i);if(i+=o-n,n=o+1,t<=(i+=r-i%r))return n}}var Y=[""];function _(e){for(;Y.length<=e;)Y.push($(Y)+" ");return Y[e]}function $(e){return e[e.length-1]}function q(e,t){for(var r=[],n=0;n<e.length;n++)r[n]=t(e[n],n);return r}function Z(){}function Q(e,t){var r;return r=Object.create?Object.create(e):(Z.prototype=e,new Z),t&&I(t,r),r}var J=/[\u00df\u0587\u0590-\u05f4\u0600-\u06ff\u3040-\u309f\u30a0-\u30ff\u3400-\u4db5\u4e00-\u9fcc\uac00-\ud7af]/;function ee(e){return/\w/.test(e)||"€"<e&&(e.toUpperCase()!=e.toLowerCase()||J.test(e))}function te(e,t){return t?!!(-1<t.source.indexOf("\\w")&&ee(e))||t.test(e):ee(e)}function re(e){for(var t in e)if(e.hasOwnProperty(t)&&e[t])return;return 1}var ne=/[\u0300-\u036f\u0483-\u0489\u0591-\u05bd\u05bf\u05c1\u05c2\u05c4\u05c5\u05c7\u0610-\u061a\u064b-\u065e\u0670\u06d6-\u06dc\u06de-\u06e4\u06e7\u06e8\u06ea-\u06ed\u0711\u0730-\u074a\u07a6-\u07b0\u07eb-\u07f3\u0816-\u0819\u081b-\u0823\u0825-\u0827\u0829-\u082d\u0900-\u0902\u093c\u0941-\u0948\u094d\u0951-\u0955\u0962\u0963\u0981\u09bc\u09be\u09c1-\u09c4\u09cd\u09d7\u09e2\u09e3\u0a01\u0a02\u0a3c\u0a41\u0a42\u0a47\u0a48\u0a4b-\u0a4d\u0a51\u0a70\u0a71\u0a75\u0a81\u0a82\u0abc\u0ac1-\u0ac5\u0ac7\u0ac8\u0acd\u0ae2\u0ae3\u0b01\u0b3c\u0b3e\u0b3f\u0b41-\u0b44\u0b4d\u0b56\u0b57\u0b62\u0b63\u0b82\u0bbe\u0bc0\u0bcd\u0bd7\u0c3e-\u0c40\u0c46-\u0c48\u0c4a-\u0c4d\u0c55\u0c56\u0c62\u0c63\u0cbc\u0cbf\u0cc2\u0cc6\u0ccc\u0ccd\u0cd5\u0cd6\u0ce2\u0ce3\u0d3e\u0d41-\u0d44\u0d4d\u0d57\u0d62\u0d63\u0dca\u0dcf\u0dd2-\u0dd4\u0dd6\u0ddf\u0e31\u0e34-\u0e3a\u0e47-\u0e4e\u0eb1\u0eb4-\u0eb9\u0ebb\u0ebc\u0ec8-\u0ecd\u0f18\u0f19\u0f35\u0f37\u0f39\u0f71-\u0f7e\u0f80-\u0f84\u0f86\u0f87\u0f90-\u0f97\u0f99-\u0fbc\u0fc6\u102d-\u1030\u1032-\u1037\u1039\u103a\u103d\u103e\u1058\u1059\u105e-\u1060\u1071-\u1074\u1082\u1085\u1086\u108d\u109d\u135f\u1712-\u1714\u1732-\u1734\u1752\u1753\u1772\u1773\u17b7-\u17bd\u17c6\u17c9-\u17d3\u17dd\u180b-\u180d\u18a9\u1920-\u1922\u1927\u1928\u1932\u1939-\u193b\u1a17\u1a18\u1a56\u1a58-\u1a5e\u1a60\u1a62\u1a65-\u1a6c\u1a73-\u1a7c\u1a7f\u1b00-\u1b03\u1b34\u1b36-\u1b3a\u1b3c\u1b42\u1b6b-\u1b73\u1b80\u1b81\u1ba2-\u1ba5\u1ba8\u1ba9\u1c2c-\u1c33\u1c36\u1c37\u1cd0-\u1cd2\u1cd4-\u1ce0\u1ce2-\u1ce8\u1ced\u1dc0-\u1de6\u1dfd-\u1dff\u200c\u200d\u20d0-\u20f0\u2cef-\u2cf1\u2de0-\u2dff\u302a-\u302f\u3099\u309a\ua66f-\ua672\ua67c\ua67d\ua6f0\ua6f1\ua802\ua806\ua80b\ua825\ua826\ua8c4\ua8e0-\ua8f1\ua926-\ua92d\ua947-\ua951\ua980-\ua982\ua9b3\ua9b6-\ua9b9\ua9bc\uaa29-\uaa2e\uaa31\uaa32\uaa35\uaa36\uaa43\uaa4c\uaab0\uaab2-\uaab4\uaab7\uaab8\uaabe\uaabf\uaac1\uabe5\uabe8\uabed\udc00-\udfff\ufb1e\ufe00-\ufe0f\ufe20-\ufe26\uff9e\uff9f]/;function ie(e){return 768<=e.charCodeAt(0)&&ne.test(e)}function oe(e,t,r){for(;(r<0?0<t:t<e.length)&&ie(e.charAt(t));)t+=r;return t}function le(e,t,r){for(var n=r<t?-1:1;;){if(t==r)return t;var i=(t+r)/2,o=n<0?Math.ceil(i):Math.floor(i);if(o==t)return e(o)?t:r;e(o)?r=o:t=o+n}}var se=null;function ae(e,t,r){var n;se=null;for(var i=0;i<e.length;++i){var o=e[i];if(o.from<t&&o.to>t)return i;o.to==t&&(o.from!=o.to&&"before"==r?n=i:se=i),o.from==t&&(o.from!=o.to&&"before"!=r?n=i:se=i)}return null!=n?n:se}var ue,ce,he,fe,de,pe,ge,ve=(ue="bbbbbbbbbtstwsbbbbbbbbbbbbbbssstwNN%%%NNNNNN,N,N1111111111NNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNbbbbbbsbbbbbbbbbbbbbbbbbbbbbbbbbb,N%%%%NNNNLNNNNN%%11NLNNN1LNNNNNLLLLLLLLLLLLLLLLLLLLLLLNLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLN",ce="nnnnnnNNr%%r,rNNmmmmmmmmmmmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmmmmmmmmmmmmmmmnnnnnnnnnn%nnrrrmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmnNmmmmmmrrmmNmmmmrr1111111111",he=/[\u0590-\u05f4\u0600-\u06ff\u0700-\u08ac]/,fe=/[stwN]/,de=/[LRr]/,pe=/[Lb1n]/,ge=/[1n]/,function(e,t){var r="ltr"==t?"L":"R";if(0==e.length||"ltr"==t&&!he.test(e))return!1;for(var n,i=e.length,o=[],l=0;l<i;++l)o.push((n=e.charCodeAt(l))<=247?ue.charAt(n):1424<=n&&n<=1524?"R":1536<=n&&n<=1785?ce.charAt(n-1536):1774<=n&&n<=2220?"r":8192<=n&&n<=8203?"w":8204==n?"b":"L");for(var s=0,a=r;s<i;++s){var u=o[s];"m"==u?o[s]=a:a=u}for(var c=0,h=r;c<i;++c){var f=o[c];"1"==f&&"r"==h?o[c]="n":de.test(f)&&"r"==(h=f)&&(o[c]="R")}for(var d=1,p=o[0];d<i-1;++d){var g=o[d];"+"==g&&"1"==p&&"1"==o[d+1]?o[d]="1":","!=g||p!=o[d+1]||"1"!=p&&"n"!=p||(o[d]=p),p=g}for(var v=0;v<i;++v){var m=o[v];if(","==m)o[v]="N";else if("%"==m){var y=void 0;for(y=v+1;y<i&&"%"==o[y];++y);for(var b=v&&"!"==o[v-1]||y<i&&"1"==o[y]?"1":"N",w=v;w<y;++w)o[w]=b;v=y-1}}for(var x=0,C=r;x<i;++x){var S=o[x];"L"==C&&"1"==S?o[x]="L":de.test(S)&&(C=S)}for(var L=0;L<i;++L)if(fe.test(o[L])){var k=void 0;for(k=L+1;k<i&&fe.test(o[k]);++k);for(var T="L"==(L?o[L-1]:r),M=T==("L"==(k<i?o[k]:r))?T?"L":"R":r,N=L;N<k;++N)o[N]=M;L=k-1}for(var O,A=[],D=0;D<i;)if(pe.test(o[D])){var W=D;for(++D;D<i&&pe.test(o[D]);++D);A.push(new me(0,W,D))}else{var H=D,F=A.length,P="rtl"==t?1:0;for(++D;D<i&&"L"!=o[D];++D);for(var E=H;E<D;)if(ge.test(o[E])){H<E&&(A.splice(F,0,new me(1,H,E)),F+=P);var I=E;for(++E;E<D&&ge.test(o[E]);++E);A.splice(F,0,new me(2,I,E)),F+=P,H=E}else++E;H<D&&A.splice(F,0,new me(1,H,D))}return"ltr"==t&&(1==A[0].level&&(O=e.match(/^\s+/))&&(A[0].from=O[0].length,A.unshift(new me(0,0,O[0].length))),1==$(A).level&&(O=e.match(/\s+$/))&&($(A).to-=O[0].length,A.push(new me(0,i-O[0].length,i)))),"rtl"==t?A.reverse():A});function me(e,t,r){this.level=e,this.from=t,this.to=r}function ye(e,t){var r=e.order;return null==r&&(r=e.order=ve(e.text,t)),r}var be=[],we=function(e,t,r){if(e.addEventListener)e.addEventListener(t,r,!1);else if(e.attachEvent)e.attachEvent("on"+t,r);else{var n=e._handlers||(e._handlers={});n[t]=(n[t]||be).concat(r)}};function xe(e,t){return e._handlers&&e._handlers[t]||be}function Ce(e,t,r){if(e.removeEventListener)e.removeEventListener(t,r,!1);else if(e.detachEvent)e.detachEvent("on"+t,r);else{var n=e._handlers,i=n&&n[t];if(i){var o=B(i,r);-1<o&&(n[t]=i.slice(0,o).concat(i.slice(o+1)))}}}function Se(e,t){var r=xe(e,t);if(r.length)for(var n=Array.prototype.slice.call(arguments,2),i=0;i<r.length;++i)r[i].apply(null,n)}function Le(e,t,r){return"string"==typeof t&&(t={type:t,preventDefault:function(){this.defaultPrevented=!0}}),Se(e,r||t.type,e,t),Ae(t)||t.codemirrorIgnore}function ke(e){var t=e._handlers&&e._handlers.cursorActivity;if(t)for(var r=e.curOp.cursorActivityHandlers||(e.curOp.cursorActivityHandlers=[]),n=0;n<t.length;++n)-1==B(r,t[n])&&r.push(t[n])}function Te(e,t){return 0<xe(e,t).length}function Me(e){e.prototype.on=function(e,t){we(this,e,t)},e.prototype.off=function(e,t){Ce(this,e,t)}}function Ne(e){e.preventDefault?e.preventDefault():e.returnValue=!1}function Oe(e){e.stopPropagation?e.stopPropagation():e.cancelBubble=!0}function Ae(e){return null!=e.defaultPrevented?e.defaultPrevented:0==e.returnValue}function De(e){Ne(e),Oe(e)}function We(e){return e.target||e.srcElement}function He(e){var t=e.which;return null==t&&(1&e.button?t=1:2&e.button?t=3:4&e.button&&(t=2)),w&&e.ctrlKey&&1==t&&(t=3),t}var Fe,Pe,Ee=function(){if(x&&C<9)return!1;var e=A("div");return"draggable"in e||"dragDrop"in e}();function Ie(e){if(null==Fe){var t=A("span","​");N(e,A("span",[t,document.createTextNode("x")])),0!=e.firstChild.offsetHeight&&(Fe=t.offsetWidth<=1&&2<t.offsetHeight&&!(x&&C<8))}var r=Fe?A("span","​"):A("span"," ",null,"display: inline-block; width: 1px; margin-right: -1px");return r.setAttribute("cm-text",""),r}function ze(e){if(null!=Pe)return Pe;var t=N(e,document.createTextNode("AخA")),r=k(t,0,1).getBoundingClientRect(),n=k(t,1,2).getBoundingClientRect();return M(e),r&&r.left!=r.right&&(Pe=n.right-r.right<3)}var Re,Be=3!="\n\nb".split(/\n/).length?function(e){for(var t=0,r=[],n=e.length;t<=n;){var i=e.indexOf("\n",t);-1==i&&(i=e.length);var o=e.slice(t,"\r"==e.charAt(i-1)?i-1:i),l=o.indexOf("\r");-1!=l?(r.push(o.slice(0,l)),t+=l+1):(r.push(o),t=i+1)}return r}:function(e){return e.split(/\r\n?|\n/)},Ge=window.getSelection?function(e){try{return e.selectionStart!=e.selectionEnd}catch(e){return!1}}:function(e){var t;try{t=e.ownerDocument.selection.createRange()}catch(e){}return!(!t||t.parentElement()!=e)&&0!=t.compareEndPoints("StartToEnd",t)},Ue="oncopy"in(Re=A("div"))||(Re.setAttribute("oncopy","return;"),"function"==typeof Re.oncopy),Ve=null;var Ke={},je={};function Xe(e){if("string"==typeof e&&je.hasOwnProperty(e))e=je[e];else if(e&&"string"==typeof e.name&&je.hasOwnProperty(e.name)){var t=je[e.name];"string"==typeof t&&(t={name:t}),(e=Q(t,e)).name=t.name}else{if("string"==typeof e&&/^[\w\-]+\/[\w\-]+\+xml$/.test(e))return Xe("application/xml");if("string"==typeof e&&/^[\w\-]+\/[\w\-]+\+json$/.test(e))return Xe("application/json")}return"string"==typeof e?{name:e}:e||{name:"null"}}function Ye(e,t){t=Xe(t);var r=Ke[t.name];if(!r)return Ye(e,"text/plain");var n=r(e,t);if(_e.hasOwnProperty(t.name)){var i=_e[t.name];for(var o in i)i.hasOwnProperty(o)&&(n.hasOwnProperty(o)&&(n["_"+o]=n[o]),n[o]=i[o])}if(n.name=t.name,t.helperType&&(n.helperType=t.helperType),t.modeProps)for(var l in t.modeProps)n[l]=t.modeProps[l];return n}var _e={};function $e(e,t){I(t,_e.hasOwnProperty(e)?_e[e]:_e[e]={})}function qe(e,t){if(!0===t)return t;if(e.copyState)return e.copyState(t);var r={};for(var n in t){var i=t[n];i instanceof Array&&(i=i.concat([])),r[n]=i}return r}function Ze(e,t){for(var r;e.innerMode&&(r=e.innerMode(t))&&r.mode!=e;)t=r.state,e=r.mode;return r||{mode:e,state:t}}function Qe(e,t,r){return!e.startState||e.startState(t,r)}var Je=function(e,t,r){this.pos=this.start=0,this.string=e,this.tabSize=t||8,this.lastColumnPos=this.lastColumnValue=0,this.lineStart=0,this.lineOracle=r};function et(e,t){if((t-=e.first)<0||t>=e.size)throw new Error("There is no line "+(t+e.first)+" in the document.");for(var r=e;!r.lines;)for(var n=0;;++n){var i=r.children[n],o=i.chunkSize();if(t<o){r=i;break}t-=o}return r.lines[t]}function tt(e,r,n){var i=[],o=r.line;return e.iter(r.line,n.line+1,function(e){var t=e.text;o==n.line&&(t=t.slice(0,n.ch)),o==r.line&&(t=t.slice(r.ch)),i.push(t),++o}),i}function rt(e,t,r){var n=[];return e.iter(t,r,function(e){n.push(e.text)}),n}function nt(e,t){var r=t-e.height;if(r)for(var n=e;n;n=n.parent)n.height+=r}function it(e){if(null==e.parent)return null;for(var t=e.parent,r=B(t.lines,e),n=t.parent;n;n=(t=n).parent)for(var i=0;n.children[i]!=t;++i)r+=n.children[i].chunkSize();return r+t.first}function ot(e,t){var r=e.first;e:do{for(var n=0;n<e.children.length;++n){var i=e.children[n],o=i.height;if(t<o){e=i;continue e}t-=o,r+=i.chunkSize()}return r}while(!e.lines);for(var l=0;l<e.lines.length;++l){var s=e.lines[l].height;if(t<s)break;t-=s}return r+l}function lt(e,t){return t>=e.first&&t<e.first+e.size}function st(e,t){return String(e.lineNumberFormatter(t+e.firstLineNumber))}function at(e,t,r){if(void 0===r&&(r=null),!(this instanceof at))return new at(e,t,r);this.line=e,this.ch=t,this.sticky=r}function ut(e,t){return e.line-t.line||e.ch-t.ch}function ct(e,t){return e.sticky==t.sticky&&0==ut(e,t)}function ht(e){return at(e.line,e.ch)}function ft(e,t){return ut(e,t)<0?t:e}function dt(e,t){return ut(e,t)<0?e:t}function pt(e,t){return Math.max(e.first,Math.min(t,e.first+e.size-1))}function gt(e,t){if(t.line<e.first)return at(e.first,0);var r,n,i,o=e.first+e.size-1;return t.line>o?at(o,et(e,o).text.length):(n=et(e,(r=t).line).text.length,null==(i=r.ch)||n<i?at(r.line,n):i<0?at(r.line,0):r)}function vt(e,t){for(var r=[],n=0;n<t.length;n++)r[n]=gt(e,t[n]);return r}Je.prototype.eol=function(){return this.pos>=this.string.length},Je.prototype.sol=function(){return this.pos==this.lineStart},Je.prototype.peek=function(){return this.string.charAt(this.pos)||void 0},Je.prototype.next=function(){if(this.pos<this.string.length)return this.string.charAt(this.pos++)},Je.prototype.eat=function(e){var t=this.string.charAt(this.pos);if("string"==typeof e?t==e:t&&(e.test?e.test(t):e(t)))return++this.pos,t},Je.prototype.eatWhile=function(e){for(var t=this.pos;this.eat(e););return this.pos>t},Je.prototype.eatSpace=function(){for(var e=this.pos;/[\s\u00a0]/.test(this.string.charAt(this.pos));)++this.pos;return this.pos>e},Je.prototype.skipToEnd=function(){this.pos=this.string.length},Je.prototype.skipTo=function(e){var t=this.string.indexOf(e,this.pos);if(-1<t)return this.pos=t,!0},Je.prototype.backUp=function(e){this.pos-=e},Je.prototype.column=function(){return this.lastColumnPos<this.start&&(this.lastColumnValue=z(this.string,this.start,this.tabSize,this.lastColumnPos,this.lastColumnValue),this.lastColumnPos=this.start),this.lastColumnValue-(this.lineStart?z(this.string,this.lineStart,this.tabSize):0)},Je.prototype.indentation=function(){return z(this.string,null,this.tabSize)-(this.lineStart?z(this.string,this.lineStart,this.tabSize):0)},Je.prototype.match=function(e,t,r){if("string"!=typeof e){var n=this.string.slice(this.pos).match(e);return n&&0<n.index?null:(n&&!1!==t&&(this.pos+=n[0].length),n)}function i(e){return r?e.toLowerCase():e}if(i(this.string.substr(this.pos,e.length))==i(e))return!1!==t&&(this.pos+=e.length),!0},Je.prototype.current=function(){return this.string.slice(this.start,this.pos)},Je.prototype.hideFirstChars=function(e,t){this.lineStart+=e;try{return t()}finally{this.lineStart-=e}},Je.prototype.lookAhead=function(e){var t=this.lineOracle;return t&&t.lookAhead(e)},Je.prototype.baseToken=function(){var e=this.lineOracle;return e&&e.baseToken(this.pos)};var mt=function(e,t){this.state=e,this.lookAhead=t},yt=function(e,t,r,n){this.state=t,this.doc=e,this.line=r,this.maxLookAhead=n||0,this.baseTokens=null,this.baseTokenPos=1};function bt(t,r,n,e){var a=[t.state.modeGen],i={};Nt(t,r.text,t.doc.mode,n,function(e,t){return a.push(e,t)},i,e);for(var u=n.state,o=function(e){n.baseTokens=a;var o=t.state.overlays[e],l=1,s=0;n.state=!0,Nt(t,r.text,o.mode,n,function(e,t){for(var r=l;s<e;){var n=a[l];e<n&&a.splice(l,1,e,a[l+1],n),l+=2,s=Math.min(e,n)}if(t)if(o.opaque)a.splice(r,l-r,e,"overlay "+t),l=r+2;else for(;r<l;r+=2){var i=a[r+1];a[r+1]=(i?i+" ":"")+"overlay "+t}},i),n.state=u,n.baseTokens=null,n.baseTokenPos=1},l=0;l<t.state.overlays.length;++l)o(l);return{styles:a,classes:i.bgClass||i.textClass?i:null}}function wt(e,t,r){if(!t.styles||t.styles[0]!=e.state.modeGen){var n=xt(e,it(t)),i=t.text.length>e.options.maxHighlightLength&&qe(e.doc.mode,n.state),o=bt(e,t,n);i&&(n.state=i),t.stateAfter=n.save(!i),t.styles=o.styles,o.classes?t.styleClasses=o.classes:t.styleClasses&&(t.styleClasses=null),r===e.doc.highlightFrontier&&(e.doc.modeFrontier=Math.max(e.doc.modeFrontier,++e.doc.highlightFrontier))}return t.styles}function xt(r,n,e){var t=r.doc,i=r.display;if(!t.mode.startState)return new yt(t,!0,n);var o=function(e,t,r){for(var n,i,o=e.doc,l=r?-1:t-(e.doc.mode.innerMode?1e3:100),s=t;l<s;--s){if(s<=o.first)return o.first;var a=et(o,s-1),u=a.stateAfter;if(u&&(!r||s+(u instanceof mt?u.lookAhead:0)<=o.modeFrontier))return s;var c=z(a.text,null,e.options.tabSize);(null==i||c<n)&&(i=s-1,n=c)}return i}(r,n,e),l=o>t.first&&et(t,o-1).stateAfter,s=l?yt.fromSaved(t,l,o):new yt(t,Qe(t.mode),o);return t.iter(o,n,function(e){Ct(r,e.text,s);var t=s.line;e.stateAfter=t==n-1||t%5==0||t>=i.viewFrom&&t<i.viewTo?s.save():null,s.nextLine()}),e&&(t.modeFrontier=s.line),s}function Ct(e,t,r,n){var i=e.doc.mode,o=new Je(t,e.options.tabSize,r);for(o.start=o.pos=n||0,""==t&&St(i,r.state);!o.eol();)Lt(i,o,r.state),o.start=o.pos}function St(e,t){if(e.blankLine)return e.blankLine(t);if(e.innerMode){var r=Ze(e,t);return r.mode.blankLine?r.mode.blankLine(r.state):void 0}}function Lt(e,t,r,n){for(var i=0;i<10;i++){n&&(n[0]=Ze(e,r).mode);var o=e.token(t,r);if(t.pos>t.start)return o}throw new Error("Mode "+e.name+" failed to advance stream.")}yt.prototype.lookAhead=function(e){var t=this.doc.getLine(this.line+e);return null!=t&&e>this.maxLookAhead&&(this.maxLookAhead=e),t},yt.prototype.baseToken=function(e){if(!this.baseTokens)return null;for(;this.baseTokens[this.baseTokenPos]<=e;)this.baseTokenPos+=2;var t=this.baseTokens[this.baseTokenPos+1];return{type:t&&t.replace(/( |^)overlay .*/,""),size:this.baseTokens[this.baseTokenPos]-e}},yt.prototype.nextLine=function(){this.line++,0<this.maxLookAhead&&this.maxLookAhead--},yt.fromSaved=function(e,t,r){return t instanceof mt?new yt(e,qe(e.mode,t.state),r,t.lookAhead):new yt(e,qe(e.mode,t),r)},yt.prototype.save=function(e){var t=!1!==e?qe(this.doc.mode,this.state):this.state;return 0<this.maxLookAhead?new mt(t,this.maxLookAhead):t};var kt=function(e,t,r){this.start=e.start,this.end=e.pos,this.string=e.current(),this.type=t||null,this.state=r};function Tt(e,t,r,n){var i,o,l=e.doc,s=l.mode,a=et(l,(t=gt(l,t)).line),u=xt(e,t.line,r),c=new Je(a.text,e.options.tabSize,u);for(n&&(o=[]);(n||c.pos<t.ch)&&!c.eol();)c.start=c.pos,i=Lt(s,c,u.state),n&&o.push(new kt(c,i,qe(l.mode,u.state)));return n?o:new kt(c,i,u.state)}function Mt(e,t){if(e)for(;;){var r=e.match(/(?:^|\s+)line-(background-)?(\S+)/);if(!r)break;e=e.slice(0,r.index)+e.slice(r.index+r[0].length);var n=r[1]?"bgClass":"textClass";null==t[n]?t[n]=r[2]:new RegExp("(?:^|s)"+r[2]+"(?:$|s)").test(t[n])||(t[n]+=" "+r[2])}return e}function Nt(e,t,r,n,i,o,l){var s=r.flattenSpans;null==s&&(s=e.options.flattenSpans);var a,u=0,c=null,h=new Je(t,e.options.tabSize,n),f=e.options.addModeClass&&[null];for(""==t&&Mt(St(r,n.state),o);!h.eol();){if(a=h.pos>e.options.maxHighlightLength?(s=!1,l&&Ct(e,t,n,h.pos),h.pos=t.length,null):Mt(Lt(r,h,n.state,f),o),f){var d=f[0].name;d&&(a="m-"+(a?d+" "+a:d))}if(!s||c!=a){for(;u<h.start;)i(u=Math.min(h.start,u+5e3),c);c=a}h.start=h.pos}for(;u<h.pos;){var p=Math.min(h.pos,u+5e3);i(p,c),u=p}}var Ot=!1,At=!1;function Dt(e,t,r){this.marker=e,this.from=t,this.to=r}function Wt(e,t){if(e)for(var r=0;r<e.length;++r){var n=e[r];if(n.marker==t)return n}}function Ht(e,t){for(var r,n=0;n<e.length;++n)e[n]!=t&&(r=r||[]).push(e[n]);return r}function Ft(e,t){if(t.full)return null;var r=lt(e,t.from.line)&&et(e,t.from.line).markedSpans,n=lt(e,t.to.line)&&et(e,t.to.line).markedSpans;if(!r&&!n)return null;var i=t.from.ch,o=t.to.ch,l=0==ut(t.from,t.to),s=function(e,t,r){var n;if(e)for(var i=0;i<e.length;++i){var o=e[i],l=o.marker;if(null==o.from||(l.inclusiveLeft?o.from<=t:o.from<t)||o.from==t&&"bookmark"==l.type&&(!r||!o.marker.insertLeft)){var s=null==o.to||(l.inclusiveRight?o.to>=t:o.to>t);(n=n||[]).push(new Dt(l,o.from,s?null:o.to))}}return n}(r,i,l),a=function(e,t,r){var n;if(e)for(var i=0;i<e.length;++i){var o=e[i],l=o.marker;if(null==o.to||(l.inclusiveRight?o.to>=t:o.to>t)||o.from==t&&"bookmark"==l.type&&(!r||o.marker.insertLeft)){var s=null==o.from||(l.inclusiveLeft?o.from<=t:o.from<t);(n=n||[]).push(new Dt(l,s?null:o.from-t,null==o.to?null:o.to-t))}}return n}(n,o,l),u=1==t.text.length,c=$(t.text).length+(u?i:0);if(s)for(var h=0;h<s.length;++h){var f=s[h];if(null==f.to){var d=Wt(a,f.marker);d?u&&(f.to=null==d.to?null:d.to+c):f.to=i}}if(a)for(var p=0;p<a.length;++p){var g=a[p];if(null!=g.to&&(g.to+=c),null==g.from)Wt(s,g.marker)||(g.from=c,u&&(s=s||[]).push(g));else g.from+=c,u&&(s=s||[]).push(g)}s=s&&Pt(s),a&&a!=s&&(a=Pt(a));var v=[s];if(!u){var m,y=t.text.length-2;if(0<y&&s)for(var b=0;b<s.length;++b)null==s[b].to&&(m=m||[]).push(new Dt(s[b].marker,null,null));for(var w=0;w<y;++w)v.push(m);v.push(a)}return v}function Pt(e){for(var t=0;t<e.length;++t){var r=e[t];null!=r.from&&r.from==r.to&&!1!==r.marker.clearWhenEmpty&&e.splice(t--,1)}return e.length?e:null}function Et(e){var t=e.markedSpans;if(t){for(var r=0;r<t.length;++r)t[r].marker.detachLine(e);e.markedSpans=null}}function It(e,t){if(t){for(var r=0;r<t.length;++r)t[r].marker.attachLine(e);e.markedSpans=t}}function zt(e){return e.inclusiveLeft?-1:0}function Rt(e){return e.inclusiveRight?1:0}function Bt(e,t){var r=e.lines.length-t.lines.length;if(0!=r)return r;var n=e.find(),i=t.find(),o=ut(n.from,i.from)||zt(e)-zt(t);if(o)return-o;var l=ut(n.to,i.to)||Rt(e)-Rt(t);return l||t.id-e.id}function Gt(e,t){var r,n=At&&e.markedSpans;if(n)for(var i=void 0,o=0;o<n.length;++o)(i=n[o]).marker.collapsed&&null==(t?i.from:i.to)&&(!r||Bt(r,i.marker)<0)&&(r=i.marker);return r}function Ut(e){return Gt(e,!0)}function Vt(e){return Gt(e,!1)}function Kt(e,t){var r,n=At&&e.markedSpans;if(n)for(var i=0;i<n.length;++i){var o=n[i];o.marker.collapsed&&(null==o.from||o.from<t)&&(null==o.to||o.to>t)&&(!r||Bt(r,o.marker)<0)&&(r=o.marker)}return r}function jt(e,t,r,n,i){var o=et(e,t),l=At&&o.markedSpans;if(l)for(var s=0;s<l.length;++s){var a=l[s];if(a.marker.collapsed){var u=a.marker.find(0),c=ut(u.from,r)||zt(a.marker)-zt(i),h=ut(u.to,n)||Rt(a.marker)-Rt(i);if(!(0<=c&&h<=0||c<=0&&0<=h)&&(c<=0&&(a.marker.inclusiveRight&&i.inclusiveLeft?0<=ut(u.to,r):0<ut(u.to,r))||0<=c&&(a.marker.inclusiveRight&&i.inclusiveLeft?ut(u.from,n)<=0:ut(u.from,n)<0)))return 1}}}function Xt(e){for(var t;t=Ut(e);)e=t.find(-1,!0).line;return e}function Yt(e,t){var r=et(e,t),n=Xt(r);return r==n?t:it(n)}function _t(e,t){if(t>e.lastLine())return t;var r,n=et(e,t);if(!$t(e,n))return t;for(;r=Vt(n);)n=r.find(1,!0).line;return it(n)+1}function $t(e,t){var r=At&&t.markedSpans;if(r)for(var n=void 0,i=0;i<r.length;++i)if((n=r[i]).marker.collapsed){if(null==n.from)return!0;if(!n.marker.widgetNode&&0==n.from&&n.marker.inclusiveLeft&&qt(e,t,n))return!0}}function qt(e,t,r){if(null==r.to){var n=r.marker.find(1,!0);return qt(e,n.line,Wt(n.line.markedSpans,r.marker))}if(r.marker.inclusiveRight&&r.to==t.text.length)return!0;for(var i=void 0,o=0;o<t.markedSpans.length;++o)if((i=t.markedSpans[o]).marker.collapsed&&!i.marker.widgetNode&&i.from==r.to&&(null==i.to||i.to!=r.from)&&(i.marker.inclusiveLeft||r.marker.inclusiveRight)&&qt(e,t,i))return!0}function Zt(e){for(var t=0,r=(e=Xt(e)).parent,n=0;n<r.lines.length;++n){var i=r.lines[n];if(i==e)break;t+=i.height}for(var o=r.parent;o;o=(r=o).parent)for(var l=0;l<o.children.length;++l){var s=o.children[l];if(s==r)break;t+=s.height}return t}function Qt(e){if(0==e.height)return 0;for(var t,r=e.text.length,n=e;t=Ut(n);){var i=t.find(0,!0);n=i.from.line,r+=i.from.ch-i.to.ch}for(n=e;t=Vt(n);){var o=t.find(0,!0);r-=n.text.length-o.from.ch,r+=(n=o.to.line).text.length-o.to.ch}return r}function Jt(e){var r=e.display,t=e.doc;r.maxLine=et(t,t.first),r.maxLineLength=Qt(r.maxLine),r.maxLineChanged=!0,t.iter(function(e){var t=Qt(e);t>r.maxLineLength&&(r.maxLineLength=t,r.maxLine=e)})}var er=function(e,t,r){this.text=e,It(this,t),this.height=r?r(this):1};er.prototype.lineNo=function(){return it(this)},Me(er);var tr={},rr={};function nr(e,t){if(!e||/^\s*$/.test(e))return null;var r=t.addModeClass?rr:tr;return r[e]||(r[e]=e.replace(/\S+/g,"cm-$&"))}function ir(e,t){var r=O("span",null,null,b?"padding-right: .1px":null),n={pre:O("pre",[r],"CodeMirror-line"),content:r,col:0,pos:0,cm:e,trailingSpace:!1,splitSpaces:e.getOption("lineWrapping")};t.measure={};for(var i=0;i<=(t.rest?t.rest.length:0);i++){var o=i?t.rest[i-1]:t.line,l=void 0;n.pos=0,n.addToken=lr,ze(e.display.measure)&&(l=ye(o,e.doc.direction))&&(n.addToken=sr(n.addToken,l)),n.map=[],ur(o,n,wt(e,o,t!=e.display.externalMeasured&&it(o))),o.styleClasses&&(o.styleClasses.bgClass&&(n.bgClass=F(o.styleClasses.bgClass,n.bgClass||"")),o.styleClasses.textClass&&(n.textClass=F(o.styleClasses.textClass,n.textClass||""))),0==n.map.length&&n.map.push(0,0,n.content.appendChild(Ie(e.display.measure))),0==i?(t.measure.map=n.map,t.measure.cache={}):((t.measure.maps||(t.measure.maps=[])).push(n.map),(t.measure.caches||(t.measure.caches=[])).push({}))}if(b){var s=n.content.lastChild;(/\bcm-tab\b/.test(s.className)||s.querySelector&&s.querySelector(".cm-tab"))&&(n.content.className="cm-tab-wrap-hack")}return Se(e,"renderLine",e,t.line,n.pre),n.pre.className&&(n.textClass=F(n.pre.className,n.textClass||"")),n}function or(e){var t=A("span","•","cm-invalidchar");return t.title="\\u"+e.charCodeAt(0).toString(16),t.setAttribute("aria-label",t.title),t}function lr(e,t,r,n,i,o,l){if(t){var s,a=e.splitSpaces?function(e,t){if(1<e.length&&!/ /.test(e))return e;for(var r=t,n="",i=0;i<e.length;i++){var o=e.charAt(i);" "!=o||!r||i!=e.length-1&&32!=e.charCodeAt(i+1)||(o=" "),n+=o,r=" "==o}return n}(t,e.trailingSpace):t,u=e.cm.state.specialChars,c=!1;if(u.test(t)){s=document.createDocumentFragment();for(var h=0;;){u.lastIndex=h;var f=u.exec(t),d=f?f.index-h:t.length-h;if(d){var p=document.createTextNode(a.slice(h,h+d));x&&C<9?s.appendChild(A("span",[p])):s.appendChild(p),e.map.push(e.pos,e.pos+d,p),e.col+=d,e.pos+=d}if(!f)break;h+=1+d;var g=void 0;if("\t"==f[0]){var v=e.cm.options.tabSize,m=v-e.col%v;(g=s.appendChild(A("span",_(m),"cm-tab"))).setAttribute("role","presentation"),g.setAttribute("cm-text","\t"),e.col+=m}else"\r"==f[0]||"\n"==f[0]?(g=s.appendChild(A("span","\r"==f[0]?"␍":"␤","cm-invalidchar"))).setAttribute("cm-text",f[0]):((g=e.cm.options.specialCharPlaceholder(f[0])).setAttribute("cm-text",f[0]),x&&C<9?s.appendChild(A("span",[g])):s.appendChild(g)),e.col+=1;e.map.push(e.pos,e.pos+1,g),e.pos++}}else e.col+=t.length,s=document.createTextNode(a),e.map.push(e.pos,e.pos+t.length,s),x&&C<9&&(c=!0),e.pos+=t.length;if(e.trailingSpace=32==a.charCodeAt(t.length-1),r||n||i||c||o){var y=r||"";n&&(y+=n),i&&(y+=i);var b=A("span",[s],y,o);if(l)for(var w in l)l.hasOwnProperty(w)&&"style"!=w&&"class"!=w&&b.setAttribute(w,l[w]);return e.content.appendChild(b)}e.content.appendChild(s)}}function sr(h,f){return function(e,t,r,n,i,o,l){r=r?r+" cm-force-border":"cm-force-border";for(var s=e.pos,a=s+t.length;;){for(var u=void 0,c=0;c<f.length&&!((u=f[c]).to>s&&u.from<=s);c++);if(u.to>=a)return h(e,t,r,n,i,o,l);h(e,t.slice(0,u.to-s),r,n,null,o,l),n=null,t=t.slice(u.to-s),s=u.to}}}function ar(e,t,r,n){var i=!n&&r.widgetNode;i&&e.map.push(e.pos,e.pos+t,i),!n&&e.cm.display.input.needsContentAttribute&&(i=i||e.content.appendChild(document.createElement("span"))).setAttribute("cm-marker",r.id),i&&(e.cm.display.input.setUneditable(i),e.content.appendChild(i)),e.pos+=t,e.trailingSpace=!1}function ur(e,t,r){var n=e.markedSpans,i=e.text,o=0;if(n)for(var l,s,a,u,c,h,f,d=i.length,p=0,g=1,v="",m=0;;){if(m==p){a=u=c=s="",h=f=null,m=1/0;for(var y=[],b=void 0,w=0;w<n.length;++w){var x=n[w],C=x.marker;if("bookmark"==C.type&&x.from==p&&C.widgetNode)y.push(C);else if(x.from<=p&&(null==x.to||x.to>p||C.collapsed&&x.to==p&&x.from==p)){if(null!=x.to&&x.to!=p&&m>x.to&&(m=x.to,u=""),C.className&&(a+=" "+C.className),C.css&&(s=(s?s+";":"")+C.css),C.startStyle&&x.from==p&&(c+=" "+C.startStyle),C.endStyle&&x.to==m&&(b=b||[]).push(C.endStyle,x.to),C.title&&((f=f||{}).title=C.title),C.attributes)for(var S in C.attributes)(f=f||{})[S]=C.attributes[S];C.collapsed&&(!h||Bt(h.marker,C)<0)&&(h=x)}else x.from>p&&m>x.from&&(m=x.from)}if(b)for(var L=0;L<b.length;L+=2)b[L+1]==m&&(u+=" "+b[L]);if(!h||h.from==p)for(var k=0;k<y.length;++k)ar(t,0,y[k]);if(h&&(h.from||0)==p){if(ar(t,(null==h.to?d+1:h.to)-p,h.marker,null==h.from),null==h.to)return;h.to==p&&(h=!1)}}if(d<=p)break;for(var T=Math.min(d,m);;){if(v){var M=p+v.length;if(!h){var N=T<M?v.slice(0,T-p):v;t.addToken(t,N,l?l+a:a,c,p+N.length==m?u:"",s,f)}if(T<=M){v=v.slice(T-p),p=T;break}p=M,c=""}v=i.slice(o,o=r[g++]),l=nr(r[g++],t.cm.options)}}else for(var O=1;O<r.length;O+=2)t.addToken(t,i.slice(o,o=r[O]),nr(r[O+1],t.cm.options))}function cr(e,t,r){this.line=t,this.rest=function(e){for(var t,r;t=Vt(e);)e=t.find(1,!0).line,(r=r||[]).push(e);return r}(t),this.size=this.rest?it($(this.rest))-r+1:1,this.node=this.text=null,this.hidden=$t(e,t)}function hr(e,t,r){for(var n,i=[],o=t;o<r;o=n){var l=new cr(e.doc,et(e.doc,o),o);n=o+l.size,i.push(l)}return i}var fr=null;function dr(e,t){var r=e.ownsGroup;if(r)try{!function(e){var t=e.delayedCallbacks,r=0;do{for(;r<t.length;r++)t[r].call(null);for(var n=0;n<e.ops.length;n++){var i=e.ops[n];if(i.cursorActivityHandlers)for(;i.cursorActivityCalled<i.cursorActivityHandlers.length;)i.cursorActivityHandlers[i.cursorActivityCalled++].call(null,i.cm)}}while(r<t.length)}(r)}finally{fr=null,t(r)}}var pr=null;function gr(e,t){var r=xe(e,t);if(r.length){var n,i=Array.prototype.slice.call(arguments,2);fr?n=fr.delayedCallbacks:pr?n=pr:(n=pr=[],setTimeout(vr,0));for(var o=function(e){n.push(function(){return r[e].apply(null,i)})},l=0;l<r.length;++l)o(l)}}function vr(){var e=pr;pr=null;for(var t=0;t<e.length;++t)e[t]()}function mr(e,t,r,n){for(var i=0;i<t.changes.length;i++){var o=t.changes[i];"text"==o?wr(e,t):"gutter"==o?Cr(e,t,r,n):"class"==o?xr(e,t):"widget"==o&&Sr(e,t,n)}t.changes=null}function yr(e){return e.node==e.text&&(e.node=A("div",null,null,"position: relative"),e.text.parentNode&&e.text.parentNode.replaceChild(e.node,e.text),e.node.appendChild(e.text),x&&C<8&&(e.node.style.zIndex=2)),e.node}function br(e,t){var r=e.display.externalMeasured;return r&&r.line==t.line?(e.display.externalMeasured=null,t.measure=r.measure,r.built):ir(e,t)}function wr(e,t){var r=t.text.className,n=br(e,t);t.text==t.node&&(t.node=n.pre),t.text.parentNode.replaceChild(n.pre,t.text),t.text=n.pre,n.bgClass!=t.bgClass||n.textClass!=t.textClass?(t.bgClass=n.bgClass,t.textClass=n.textClass,xr(e,t)):r&&(t.text.className=r)}function xr(e,t){!function(e,t){var r=t.bgClass?t.bgClass+" "+(t.line.bgClass||""):t.line.bgClass;if(r&&(r+=" CodeMirror-linebackground"),t.background)r?t.background.className=r:(t.background.parentNode.removeChild(t.background),t.background=null);else if(r){var n=yr(t);t.background=n.insertBefore(A("div",null,r),n.firstChild),e.display.input.setUneditable(t.background)}}(e,t),t.line.wrapClass?yr(t).className=t.line.wrapClass:t.node!=t.text&&(t.node.className="");var r=t.textClass?t.textClass+" "+(t.line.textClass||""):t.line.textClass;t.text.className=r||""}function Cr(e,t,r,n){if(t.gutter&&(t.node.removeChild(t.gutter),t.gutter=null),t.gutterBackground&&(t.node.removeChild(t.gutterBackground),t.gutterBackground=null),t.line.gutterClass){var i=yr(t);t.gutterBackground=A("div",null,"CodeMirror-gutter-background "+t.line.gutterClass,"left: "+(e.options.fixedGutter?n.fixedPos:-n.gutterTotalWidth)+"px; width: "+n.gutterTotalWidth+"px"),e.display.input.setUneditable(t.gutterBackground),i.insertBefore(t.gutterBackground,t.text)}var o=t.line.gutterMarkers;if(e.options.lineNumbers||o){var l=yr(t),s=t.gutter=A("div",null,"CodeMirror-gutter-wrapper","left: "+(e.options.fixedGutter?n.fixedPos:-n.gutterTotalWidth)+"px");if(e.display.input.setUneditable(s),l.insertBefore(s,t.text),t.line.gutterClass&&(s.className+=" "+t.line.gutterClass),!e.options.lineNumbers||o&&o["CodeMirror-linenumbers"]||(t.lineNumber=s.appendChild(A("div",st(e.options,r),"CodeMirror-linenumber CodeMirror-gutter-elt","left: "+n.gutterLeft["CodeMirror-linenumbers"]+"px; width: "+e.display.lineNumInnerWidth+"px"))),o)for(var a=0;a<e.display.gutterSpecs.length;++a){var u=e.display.gutterSpecs[a].className,c=o.hasOwnProperty(u)&&o[u];c&&s.appendChild(A("div",[c],"CodeMirror-gutter-elt","left: "+n.gutterLeft[u]+"px; width: "+n.gutterWidth[u]+"px"))}}}function Sr(e,t,r){t.alignable&&(t.alignable=null);for(var n=L("CodeMirror-linewidget"),i=t.node.firstChild,o=void 0;i;i=o)o=i.nextSibling,n.test(i.className)&&t.node.removeChild(i);Lr(e,t,r)}function Lr(e,t,r){if(kr(e,t.line,t,r,!0),t.rest)for(var n=0;n<t.rest.length;n++)kr(e,t.rest[n],t,r,!1)}function kr(e,t,r,n,i){if(t.widgets)for(var o=yr(r),l=0,s=t.widgets;l<s.length;++l){var a=s[l],u=A("div",[a.node],"CodeMirror-linewidget"+(a.className?" "+a.className:""));a.handleMouseEvents||u.setAttribute("cm-ignore-events","true"),Tr(a,u,r,n),e.display.input.setUneditable(u),i&&a.above?o.insertBefore(u,r.gutter||r.text):o.appendChild(u),gr(a,"redraw")}}function Tr(e,t,r,n){if(e.noHScroll){(r.alignable||(r.alignable=[])).push(t);var i=n.wrapperWidth;t.style.left=n.fixedPos+"px",e.coverGutter||(i-=n.gutterTotalWidth,t.style.paddingLeft=n.gutterTotalWidth+"px"),t.style.width=i+"px"}e.coverGutter&&(t.style.zIndex=5,t.style.position="relative",e.noHScroll||(t.style.marginLeft=-n.gutterTotalWidth+"px"))}function Mr(e){if(null!=e.height)return e.height;var t=e.doc.cm;if(!t)return 0;if(!D(document.body,e.node)){var r="position: relative;";e.coverGutter&&(r+="margin-left: -"+t.display.gutters.offsetWidth+"px;"),e.noHScroll&&(r+="width: "+t.display.wrapper.clientWidth+"px;"),N(t.display.measure,A("div",[e.node],null,r))}return e.height=e.node.parentNode.offsetHeight}function Nr(e,t){for(var r=We(t);r!=e.wrapper;r=r.parentNode)if(!r||1==r.nodeType&&"true"==r.getAttribute("cm-ignore-events")||r.parentNode==e.sizer&&r!=e.mover)return 1}function Or(e){return e.lineSpace.offsetTop}function Ar(e){return e.mover.offsetHeight-e.lineSpace.offsetHeight}function Dr(e){if(e.cachedPaddingH)return e.cachedPaddingH;var t=N(e.measure,A("pre","x","CodeMirror-line-like")),r=window.getComputedStyle?window.getComputedStyle(t):t.currentStyle,n={left:parseInt(r.paddingLeft),right:parseInt(r.paddingRight)};return isNaN(n.left)||isNaN(n.right)||(e.cachedPaddingH=n),n}function Wr(e){return G-e.display.nativeBarWidth}function Hr(e){return e.display.scroller.clientWidth-Wr(e)-e.display.barWidth}function Fr(e){return e.display.scroller.clientHeight-Wr(e)-e.display.barHeight}function Pr(e,t,r){if(e.line==t)return{map:e.measure.map,cache:e.measure.cache};for(var n=0;n<e.rest.length;n++)if(e.rest[n]==t)return{map:e.measure.maps[n],cache:e.measure.caches[n]};for(var i=0;i<e.rest.length;i++)if(it(e.rest[i])>r)return{map:e.measure.maps[i],cache:e.measure.caches[i],before:!0}}function Er(e,t,r,n){return Rr(e,zr(e,t),r,n)}function Ir(e,t){if(t>=e.display.viewFrom&&t<e.display.viewTo)return e.display.view[gn(e,t)];var r=e.display.externalMeasured;return r&&t>=r.lineN&&t<r.lineN+r.size?r:void 0}function zr(e,t){var r=it(t),n=Ir(e,r);n&&!n.text?n=null:n&&n.changes&&(mr(e,n,r,cn(e)),e.curOp.forceUpdate=!0);var i=Pr(n=n||function(e,t){var r=it(t=Xt(t)),n=e.display.externalMeasured=new cr(e.doc,t,r);n.lineN=r;var i=n.built=ir(e,n);return n.text=i.pre,N(e.display.lineMeasure,i.pre),n}(e,t),t,r);return{line:t,view:n,rect:null,map:i.map,cache:i.cache,before:i.before,hasHeights:!1}}function Rr(e,t,r,n,i){t.before&&(r=-1);var o,l=r+(n||"");return t.cache.hasOwnProperty(l)?o=t.cache[l]:(t.rect||(t.rect=t.view.text.getBoundingClientRect()),t.hasHeights||(function(e,t,r){var n=e.options.lineWrapping,i=n&&Hr(e);if(!t.measure.heights||n&&t.measure.width!=i){var o=t.measure.heights=[];if(n){t.measure.width=i;for(var l=t.text.firstChild.getClientRects(),s=0;s<l.length-1;s++){var a=l[s],u=l[s+1];2<Math.abs(a.bottom-u.bottom)&&o.push((a.bottom+u.top)/2-r.top)}}o.push(r.bottom-r.top)}}(e,t.view,t.rect),t.hasHeights=!0),(o=function(e,t,r,n){var i,o=Ur(t.map,r,n),l=o.node,s=o.start,a=o.end,u=o.collapse;if(3==l.nodeType){for(var c=0;c<4;c++){for(;s&&ie(t.line.text.charAt(o.coverStart+s));)--s;for(;o.coverStart+a<o.coverEnd&&ie(t.line.text.charAt(o.coverStart+a));)++a;if((i=x&&C<9&&0==s&&a==o.coverEnd-o.coverStart?l.parentNode.getBoundingClientRect():Vr(k(l,s,a).getClientRects(),n)).left||i.right||0==s)break;a=s,--s,u="right"}x&&C<11&&(i=function(e,t){if(!window.screen||null==screen.logicalXDPI||screen.logicalXDPI==screen.deviceXDPI||!function(e){if(null!=Ve)return Ve;var t=N(e,A("span","x")),r=t.getBoundingClientRect(),n=k(t,0,1).getBoundingClientRect();return Ve=1<Math.abs(r.left-n.left)}(e))return t;var r=screen.logicalXDPI/screen.deviceXDPI,n=screen.logicalYDPI/screen.deviceYDPI;return{left:t.left*r,right:t.right*r,top:t.top*n,bottom:t.bottom*n}}(e.display.measure,i))}else{var h;0<s&&(u=n="right"),i=e.options.lineWrapping&&1<(h=l.getClientRects()).length?h["right"==n?h.length-1:0]:l.getBoundingClientRect()}if(x&&C<9&&!s&&(!i||!i.left&&!i.right)){var f=l.parentNode.getClientRects()[0];i=f?{left:f.left,right:f.left+un(e.display),top:f.top,bottom:f.bottom}:Gr}for(var d=i.top-t.rect.top,p=i.bottom-t.rect.top,g=(d+p)/2,v=t.view.measure.heights,m=0;m<v.length-1&&!(g<v[m]);m++);var y=m?v[m-1]:0,b=v[m],w={left:("right"==u?i.right:i.left)-t.rect.left,right:("left"==u?i.left:i.right)-t.rect.left,top:y,bottom:b};i.left||i.right||(w.bogus=!0);e.options.singleCursorHeightPerLine||(w.rtop=d,w.rbottom=p);return w}(e,t,r,n)).bogus||(t.cache[l]=o)),{left:o.left,right:o.right,top:i?o.rtop:o.top,bottom:i?o.rbottom:o.bottom}}var Br,Gr={left:0,right:0,top:0,bottom:0};function Ur(e,t,r){for(var n,i,o,l,s,a,u=0;u<e.length;u+=3)if(s=e[u],a=e[u+1],t<s?(i=0,o=1,l="left"):t<a?o=(i=t-s)+1:(u==e.length-3||t==a&&e[u+3]>t)&&(i=(o=a-s)-1,a<=t&&(l="right")),null!=i){if(n=e[u+2],s==a&&r==(n.insertLeft?"left":"right")&&(l=r),"left"==r&&0==i)for(;u&&e[u-2]==e[u-3]&&e[u-1].insertLeft;)n=e[2+(u-=3)],l="left";if("right"==r&&i==a-s)for(;u<e.length-3&&e[u+3]==e[u+4]&&!e[u+5].insertLeft;)n=e[(u+=3)+2],l="right";break}return{node:n,start:i,end:o,collapse:l,coverStart:s,coverEnd:a}}function Vr(e,t){var r=Gr;if("left"==t)for(var n=0;n<e.length&&(r=e[n]).left==r.right;n++);else for(var i=e.length-1;0<=i&&(r=e[i]).left==r.right;i--);return r}function Kr(e){if(e.measure&&(e.measure.cache={},e.measure.heights=null,e.rest))for(var t=0;t<e.rest.length;t++)e.measure.caches[t]={}}function jr(e){e.display.externalMeasure=null,M(e.display.lineMeasure);for(var t=0;t<e.display.view.length;t++)Kr(e.display.view[t])}function Xr(e){jr(e),e.display.cachedCharWidth=e.display.cachedTextHeight=e.display.cachedPaddingH=null,e.options.lineWrapping||(e.display.maxLineChanged=!0),e.display.lineNumChars=null}function Yr(){return l&&h?-(document.body.getBoundingClientRect().left-parseInt(getComputedStyle(document.body).marginLeft)):window.pageXOffset||(document.documentElement||document.body).scrollLeft}function _r(){return l&&h?-(document.body.getBoundingClientRect().top-parseInt(getComputedStyle(document.body).marginTop)):window.pageYOffset||(document.documentElement||document.body).scrollTop}function $r(e){var t=0;if(e.widgets)for(var r=0;r<e.widgets.length;++r)e.widgets[r].above&&(t+=Mr(e.widgets[r]));return t}function qr(e,t,r,n,i){if(!i){var o=$r(t);r.top+=o,r.bottom+=o}if("line"==n)return r;n=n||"local";var l=Zt(t);if("local"==n?l+=Or(e.display):l-=e.display.viewOffset,"page"==n||"window"==n){var s=e.display.lineSpace.getBoundingClientRect();l+=s.top+("window"==n?0:_r());var a=s.left+("window"==n?0:Yr());r.left+=a,r.right+=a}return r.top+=l,r.bottom+=l,r}function Zr(e,t,r){if("div"==r)return t;var n=t.left,i=t.top;if("page"==r)n-=Yr(),i-=_r();else if("local"==r||!r){var o=e.display.sizer.getBoundingClientRect();n+=o.left,i+=o.top}var l=e.display.lineSpace.getBoundingClientRect();return{left:n-l.left,top:i-l.top}}function Qr(e,t,r,n,i){return qr(e,n=n||et(e.doc,t.line),Er(e,n,t.ch,i),r)}function Jr(n,e,i,o,l,s){function a(e,t){var r=Rr(n,l,e,t?"right":"left",s);return t?r.left=r.right:r.right=r.left,qr(n,o,r,i)}o=o||et(n.doc,e.line),l=l||zr(n,o);var u=ye(o,n.doc.direction),t=e.ch,r=e.sticky;if(t>=o.text.length?(t=o.text.length,r="before"):t<=0&&(t=0,r="after"),!u)return a("before"==r?t-1:t,"before"==r);function c(e,t,r){return a(r?e-1:e,1==u[t].level!=r)}var h=ae(u,t,r),f=se,d=c(t,h,"before"==r);return null!=f&&(d.other=c(t,f,"before"!=r)),d}function en(e,t){var r=0;t=gt(e.doc,t),e.options.lineWrapping||(r=un(e.display)*t.ch);var n=et(e.doc,t.line),i=Zt(n)+Or(e.display);return{left:r,right:r,top:i,bottom:i+n.height}}function tn(e,t,r,n,i){var o=at(e,t,r);return o.xRel=i,n&&(o.outside=n),o}function rn(e,t,r){var n=e.doc;if((r+=e.display.viewOffset)<0)return tn(n.first,0,null,-1,-1);var i=ot(n,r),o=n.first+n.size-1;if(o<i)return tn(n.first+n.size-1,et(n,o).text.length,null,1,1);t<0&&(t=0);for(var l=et(n,i);;){var s=sn(e,l,i,t,r),a=Kt(l,s.ch+(0<s.xRel||0<s.outside?1:0));if(!a)return s;var u=a.find(1);if(u.line==i)return u;l=et(n,i=u.line)}}function nn(t,e,r,n){n-=$r(e);var i=e.text.length,o=le(function(e){return Rr(t,r,e-1).bottom<=n},i,0);return{begin:o,end:i=le(function(e){return Rr(t,r,e).top>n},o,i)}}function on(e,t,r,n){return nn(e,t,r=r||zr(e,t),qr(e,t,Rr(e,r,n),"line").top)}function ln(e,t,r,n){return!(e.bottom<=r)&&(e.top>r||(n?e.left:e.right)>t)}function sn(r,e,t,n,i){i-=Zt(e);var o=zr(r,e),l=$r(e),s=0,a=e.text.length,u=!0,c=ye(e,r.doc.direction);if(c){var h=(r.options.lineWrapping?function(e,t,r,n,i,o,l){var s=nn(e,t,n,l),a=s.begin,u=s.end;/\s/.test(t.text.charAt(u-1))&&u--;for(var c=null,h=null,f=0;f<i.length;f++){var d=i[f];if(!(d.from>=u||d.to<=a)){var p=1!=d.level,g=Rr(e,n,p?Math.min(u,d.to)-1:Math.max(a,d.from)).right,v=g<o?o-g+1e9:g-o;(!c||v<h)&&(c=d,h=v)}}c=c||i[i.length-1];c.from<a&&(c={from:a,to:c.to,level:c.level});c.to>u&&(c={from:c.from,to:u,level:c.level});return c}:function(n,i,o,l,s,a,u){var e=le(function(e){var t=s[e],r=1!=t.level;return ln(Jr(n,at(o,r?t.to:t.from,r?"before":"after"),"line",i,l),a,u,!0)},0,s.length-1),t=s[e];if(0<e){var r=1!=t.level,c=Jr(n,at(o,r?t.from:t.to,r?"after":"before"),"line",i,l);ln(c,a,u,!0)&&c.top>u&&(t=s[e-1])}return t})(r,e,t,o,c,n,i);s=(u=1!=h.level)?h.from:h.to-1,a=u?h.to:h.from-1}var f,d,p=null,g=null,v=le(function(e){var t=Rr(r,o,e);return t.top+=l,t.bottom+=l,ln(t,n,i,!1)&&(t.top<=i&&t.left<=n&&(p=e,g=t),1)},s,a),m=!1;if(g){var y=n-g.left<g.right-n,b=y==u;v=p+(b?0:1),d=b?"after":"before",f=y?g.left:g.right}else{u||v!=a&&v!=s||v++,d=0==v?"after":v==e.text.length?"before":Rr(r,o,v-(u?1:0)).bottom+l<=i==u?"after":"before";var w=Jr(r,at(t,v,d),"line",e,o);f=w.left,m=i<w.top?-1:i>=w.bottom?1:0}return tn(t,v=oe(e.text,v,1),d,m,n-f)}function an(e){if(null!=e.cachedTextHeight)return e.cachedTextHeight;if(null==Br){Br=A("pre",null,"CodeMirror-line-like");for(var t=0;t<49;++t)Br.appendChild(document.createTextNode("x")),Br.appendChild(A("br"));Br.appendChild(document.createTextNode("x"))}N(e.measure,Br);var r=Br.offsetHeight/50;return 3<r&&(e.cachedTextHeight=r),M(e.measure),r||1}function un(e){if(null!=e.cachedCharWidth)return e.cachedCharWidth;var t=A("span","xxxxxxxxxx"),r=A("pre",[t],"CodeMirror-line-like");N(e.measure,r);var n=t.getBoundingClientRect(),i=(n.right-n.left)/10;return 2<i&&(e.cachedCharWidth=i),i||10}function cn(e){for(var t=e.display,r={},n={},i=t.gutters.clientLeft,o=t.gutters.firstChild,l=0;o;o=o.nextSibling,++l){var s=e.display.gutterSpecs[l].className;r[s]=o.offsetLeft+o.clientLeft+i,n[s]=o.clientWidth}return{fixedPos:hn(t),gutterTotalWidth:t.gutters.offsetWidth,gutterLeft:r,gutterWidth:n,wrapperWidth:t.wrapper.clientWidth}}function hn(e){return e.scroller.getBoundingClientRect().left-e.sizer.getBoundingClientRect().left}function fn(n){var i=an(n.display),o=n.options.lineWrapping,l=o&&Math.max(5,n.display.scroller.clientWidth/un(n.display)-3);return function(e){if($t(n.doc,e))return 0;var t=0;if(e.widgets)for(var r=0;r<e.widgets.length;r++)e.widgets[r].height&&(t+=e.widgets[r].height);return o?t+(Math.ceil(e.text.length/l)||1)*i:t+i}}function dn(e){var t=e.doc,r=fn(e);t.iter(function(e){var t=r(e);t!=e.height&&nt(e,t)})}function pn(e,t,r,n){var i=e.display;if(!r&&"true"==We(t).getAttribute("cm-not-content"))return null;var o,l,s=i.lineSpace.getBoundingClientRect();try{o=t.clientX-s.left,l=t.clientY-s.top}catch(t){return null}var a,u=rn(e,o,l);if(n&&0<u.xRel&&(a=et(e.doc,u.line).text).length==u.ch){var c=z(a,a.length,e.options.tabSize)-a.length;u=at(u.line,Math.max(0,Math.round((o-Dr(e.display).left)/un(e.display))-c))}return u}function gn(e,t){if(t>=e.display.viewTo)return null;if((t-=e.display.viewFrom)<0)return null;for(var r=e.display.view,n=0;n<r.length;n++)if((t-=r[n].size)<0)return n}function vn(e,t,r,n){null==t&&(t=e.doc.first),null==r&&(r=e.doc.first+e.doc.size),n=n||0;var i=e.display;if(n&&r<i.viewTo&&(null==i.updateLineNumbers||i.updateLineNumbers>t)&&(i.updateLineNumbers=t),e.curOp.viewChanged=!0,t>=i.viewTo)At&&Yt(e.doc,t)<i.viewTo&&yn(e);else if(r<=i.viewFrom)At&&_t(e.doc,r+n)>i.viewFrom?yn(e):(i.viewFrom+=n,i.viewTo+=n);else if(t<=i.viewFrom&&r>=i.viewTo)yn(e);else if(t<=i.viewFrom){var o=bn(e,r,r+n,1);o?(i.view=i.view.slice(o.index),i.viewFrom=o.lineN,i.viewTo+=n):yn(e)}else if(r>=i.viewTo){var l=bn(e,t,t,-1);l?(i.view=i.view.slice(0,l.index),i.viewTo=l.lineN):yn(e)}else{var s=bn(e,t,t,-1),a=bn(e,r,r+n,1);s&&a?(i.view=i.view.slice(0,s.index).concat(hr(e,s.lineN,a.lineN)).concat(i.view.slice(a.index)),i.viewTo+=n):yn(e)}var u=i.externalMeasured;u&&(r<u.lineN?u.lineN+=n:t<u.lineN+u.size&&(i.externalMeasured=null))}function mn(e,t,r){e.curOp.viewChanged=!0;var n=e.display,i=e.display.externalMeasured;if(i&&t>=i.lineN&&t<i.lineN+i.size&&(n.externalMeasured=null),!(t<n.viewFrom||t>=n.viewTo)){var o=n.view[gn(e,t)];if(null!=o.node){var l=o.changes||(o.changes=[]);-1==B(l,r)&&l.push(r)}}}function yn(e){e.display.viewFrom=e.display.viewTo=e.doc.first,e.display.view=[],e.display.viewOffset=0}function bn(e,t,r,n){var i,o=gn(e,t),l=e.display.view;if(!At||r==e.doc.first+e.doc.size)return{index:o,lineN:r};for(var s=e.display.viewFrom,a=0;a<o;a++)s+=l[a].size;if(s!=t){if(0<n){if(o==l.length-1)return null;i=s+l[o].size-t,o++}else i=s-t;t+=i,r+=i}for(;Yt(e.doc,r)!=r;){if(o==(n<0?0:l.length-1))return null;r+=n*l[o-(n<0?1:0)].size,o+=n}return{index:o,lineN:r}}function wn(e){for(var t=e.display.view,r=0,n=0;n<t.length;n++){var i=t[n];i.hidden||i.node&&!i.changes||++r}return r}function xn(e){e.display.input.showSelection(e.display.input.prepareSelection())}function Cn(e,t){void 0===t&&(t=!0);for(var r=e.doc,n={},i=n.cursors=document.createDocumentFragment(),o=n.selection=document.createDocumentFragment(),l=0;l<r.sel.ranges.length;l++)if(t||l!=r.sel.primIndex){var s=r.sel.ranges[l];if(!(s.from().line>=e.display.viewTo||s.to().line<e.display.viewFrom)){var a=s.empty();(a||e.options.showCursorWhenSelecting)&&Sn(e,s.head,i),a||kn(e,s,o)}}return n}function Sn(e,t,r){var n=Jr(e,t,"div",null,null,!e.options.singleCursorHeightPerLine),i=r.appendChild(A("div"," ","CodeMirror-cursor"));if(i.style.left=n.left+"px",i.style.top=n.top+"px",i.style.height=Math.max(0,n.bottom-n.top)*e.options.cursorHeight+"px",n.other){var o=r.appendChild(A("div"," ","CodeMirror-cursor CodeMirror-secondarycursor"));o.style.display="",o.style.left=n.other.left+"px",o.style.top=n.other.top+"px",o.style.height=.85*(n.other.bottom-n.other.top)+"px"}}function Ln(e,t){return e.top-t.top||e.left-t.left}function kn(l,e,t){var r=l.display,n=l.doc,i=document.createDocumentFragment(),o=Dr(l.display),T=o.left,M=Math.max(r.sizerWidth,Hr(l)-r.sizer.offsetLeft)-o.right,N="ltr"==n.direction;function O(e,t,r,n){t<0&&(t=0),t=Math.round(t),n=Math.round(n),i.appendChild(A("div",null,"CodeMirror-selected","position: absolute; left: "+e+"px;\n top: "+t+"px; width: "+(null==r?M-e:r)+"px;\n height: "+(n-t)+"px"))}function s(r,y,b){var w,x,o=et(n,r),C=o.text.length;function S(e,t){return Qr(l,at(r,e),"div",o,t)}function L(e,t,r){var n=on(l,o,null,e),i="ltr"==t==("after"==r)?"left":"right";return S("after"==r?n.begin:n.end-(/\s/.test(o.text.charAt(n.end-1))?2:1),i)[i]}var k=ye(o,n.direction);return function(e,t,r,n){if(!e)return n(t,r,"ltr",0);for(var i=!1,o=0;o<e.length;++o){var l=e[o];(l.from<r&&l.to>t||t==r&&l.to==t)&&(n(Math.max(l.from,t),Math.min(l.to,r),1==l.level?"rtl":"ltr",o),i=!0)}i||n(t,r,"ltr")}(k,y||0,null==b?C:b,function(e,t,r,n){var i="ltr"==r,o=S(e,i?"left":"right"),l=S(t-1,i?"right":"left"),s=null==y&&0==e,a=null==b&&t==C,u=0==n,c=!k||n==k.length-1;if(l.top-o.top<=3){var h=(N?a:s)&&c,f=(N?s:a)&&u?T:(i?o:l).left,d=h?M:(i?l:o).right;O(f,o.top,d-f,o.bottom)}else{var p,g,v,m;m=i?(p=N&&s&&u?T:o.left,g=N?M:L(e,r,"before"),v=N?T:L(t,r,"after"),N&&a&&c?M:l.right):(p=N?L(e,r,"before"):T,g=!N&&s&&u?M:o.right,v=!N&&a&&c?T:l.left,N?L(t,r,"after"):M),O(p,o.top,g-p,o.bottom),o.bottom<l.top&&O(T,o.bottom,null,l.top),O(v,l.top,m-v,l.bottom)}(!w||Ln(o,w)<0)&&(w=o),Ln(l,w)<0&&(w=l),(!x||Ln(o,x)<0)&&(x=o),Ln(l,x)<0&&(x=l)}),{start:w,end:x}}var a=e.from(),u=e.to();if(a.line==u.line)s(a.line,a.ch,u.ch);else{var c=et(n,a.line),h=et(n,u.line),f=Xt(c)==Xt(h),d=s(a.line,a.ch,f?c.text.length+1:null).end,p=s(u.line,f?0:null,u.ch).start;f&&(d.top<p.top-2?(O(d.right,d.top,null,d.bottom),O(T,p.top,p.left,p.bottom)):O(d.right,d.top,p.left-d.right,d.bottom)),d.bottom<p.top&&O(T,d.bottom,null,p.top)}t.appendChild(i)}function Tn(e){if(e.state.focused){var t=e.display;clearInterval(t.blinker);var r=!0;t.cursorDiv.style.visibility="",0<e.options.cursorBlinkRate?t.blinker=setInterval(function(){return t.cursorDiv.style.visibility=(r=!r)?"":"hidden"},e.options.cursorBlinkRate):e.options.cursorBlinkRate<0&&(t.cursorDiv.style.visibility="hidden")}}function Mn(e){e.state.focused||(e.display.input.focus(),On(e))}function Nn(e){e.state.delayingBlurEvent=!0,setTimeout(function(){e.state.delayingBlurEvent&&(e.state.delayingBlurEvent=!1,An(e))},100)}function On(e,t){e.state.delayingBlurEvent&&(e.state.delayingBlurEvent=!1),"nocursor"!=e.options.readOnly&&(e.state.focused||(Se(e,"focus",e,t),e.state.focused=!0,H(e.display.wrapper,"CodeMirror-focused"),e.curOp||e.display.selForContextMenu==e.doc.sel||(e.display.input.reset(),b&&setTimeout(function(){return e.display.input.reset(!0)},20)),e.display.input.receivedFocus()),Tn(e))}function An(e,t){e.state.delayingBlurEvent||(e.state.focused&&(Se(e,"blur",e,t),e.state.focused=!1,T(e.display.wrapper,"CodeMirror-focused")),clearInterval(e.display.blinker),setTimeout(function(){e.state.focused||(e.display.shift=!1)},150))}function Dn(e){for(var t=e.display,r=t.lineDiv.offsetTop,n=0;n<t.view.length;n++){var i=t.view[n],o=e.options.lineWrapping,l=void 0,s=0;if(!i.hidden){if(x&&C<8){var a=i.node.offsetTop+i.node.offsetHeight;l=a-r,r=a}else{var u=i.node.getBoundingClientRect();l=u.bottom-u.top,!o&&i.text.firstChild&&(s=i.text.firstChild.getBoundingClientRect().right-u.left-1)}var c=i.line.height-l;if((.005<c||c<-.005)&&(nt(i.line,l),Wn(i.line),i.rest))for(var h=0;h<i.rest.length;h++)Wn(i.rest[h]);if(s>e.display.sizerWidth){var f=Math.ceil(s/un(e.display));f>e.display.maxLineLength&&(e.display.maxLineLength=f,e.display.maxLine=i.line,e.display.maxLineChanged=!0)}}}}function Wn(e){if(e.widgets)for(var t=0;t<e.widgets.length;++t){var r=e.widgets[t],n=r.node.parentNode;n&&(r.height=n.offsetHeight)}}function Hn(e,t,r){var n=r&&null!=r.top?Math.max(0,r.top):e.scroller.scrollTop;n=Math.floor(n-Or(e));var i=r&&null!=r.bottom?r.bottom:n+e.wrapper.clientHeight,o=ot(t,n),l=ot(t,i);if(r&&r.ensure){var s=r.ensure.from.line,a=r.ensure.to.line;s<o?l=ot(t,Zt(et(t,o=s))+e.wrapper.clientHeight):Math.min(a,t.lastLine())>=l&&(o=ot(t,Zt(et(t,a))-e.wrapper.clientHeight),l=a)}return{from:o,to:Math.max(l,o+1)}}function Fn(e,t){var r=e.display,n=an(e.display);t.top<0&&(t.top=0);var i=e.curOp&&null!=e.curOp.scrollTop?e.curOp.scrollTop:r.scroller.scrollTop,o=Fr(e),l={};t.bottom-t.top>o&&(t.bottom=t.top+o);var s=e.doc.height+Ar(r),a=t.top<n,u=t.bottom>s-n;if(t.top<i)l.scrollTop=a?0:t.top;else if(t.bottom>i+o){var c=Math.min(t.top,(u?s:t.bottom)-o);c!=i&&(l.scrollTop=c)}var h=e.curOp&&null!=e.curOp.scrollLeft?e.curOp.scrollLeft:r.scroller.scrollLeft,f=Hr(e)-(e.options.fixedGutter?r.gutters.offsetWidth:0),d=t.right-t.left>f;return d&&(t.right=t.left+f),t.left<10?l.scrollLeft=0:t.left<h?l.scrollLeft=Math.max(0,t.left-(d?0:10)):t.right>f+h-3&&(l.scrollLeft=t.right+(d?0:10)-f),l}function Pn(e,t){null!=t&&(zn(e),e.curOp.scrollTop=(null==e.curOp.scrollTop?e.doc.scrollTop:e.curOp.scrollTop)+t)}function En(e){zn(e);var t=e.getCursor();e.curOp.scrollToPos={from:t,to:t,margin:e.options.cursorScrollMargin}}function In(e,t,r){null==t&&null==r||zn(e),null!=t&&(e.curOp.scrollLeft=t),null!=r&&(e.curOp.scrollTop=r)}function zn(e){var t=e.curOp.scrollToPos;t&&(e.curOp.scrollToPos=null,Rn(e,en(e,t.from),en(e,t.to),t.margin))}function Rn(e,t,r,n){var i=Fn(e,{left:Math.min(t.left,r.left),top:Math.min(t.top,r.top)-n,right:Math.max(t.right,r.right),bottom:Math.max(t.bottom,r.bottom)+n});In(e,i.scrollLeft,i.scrollTop)}function Bn(e,t){Math.abs(e.doc.scrollTop-t)<2||(g||fi(e,{top:t}),Gn(e,t,!0),g&&fi(e),si(e,100))}function Gn(e,t,r){t=Math.max(0,Math.min(e.display.scroller.scrollHeight-e.display.scroller.clientHeight,t)),e.display.scroller.scrollTop==t&&!r||(e.doc.scrollTop=t,e.display.scrollbars.setScrollTop(t),e.display.scroller.scrollTop!=t&&(e.display.scroller.scrollTop=t))}function Un(e,t,r,n){t=Math.max(0,Math.min(t,e.display.scroller.scrollWidth-e.display.scroller.clientWidth)),(r?t==e.doc.scrollLeft:Math.abs(e.doc.scrollLeft-t)<2)&&!n||(e.doc.scrollLeft=t,gi(e),e.display.scroller.scrollLeft!=t&&(e.display.scroller.scrollLeft=t),e.display.scrollbars.setScrollLeft(t))}function Vn(e){var t=e.display,r=t.gutters.offsetWidth,n=Math.round(e.doc.height+Ar(e.display));return{clientHeight:t.scroller.clientHeight,viewHeight:t.wrapper.clientHeight,scrollWidth:t.scroller.scrollWidth,clientWidth:t.scroller.clientWidth,viewWidth:t.wrapper.clientWidth,barLeft:e.options.fixedGutter?r:0,docHeight:n,scrollHeight:n+Wr(e)+t.barHeight,nativeBarWidth:t.nativeBarWidth,gutterWidth:r}}function Kn(e,t,r){this.cm=r;var n=this.vert=A("div",[A("div",null,null,"min-width: 1px")],"CodeMirror-vscrollbar"),i=this.horiz=A("div",[A("div",null,null,"height: 100%; min-height: 1px")],"CodeMirror-hscrollbar");n.tabIndex=i.tabIndex=-1,e(n),e(i),we(n,"scroll",function(){n.clientHeight&&t(n.scrollTop,"vertical")}),we(i,"scroll",function(){i.clientWidth&&t(i.scrollLeft,"horizontal")}),this.checkedZeroWidth=!1,x&&C<8&&(this.horiz.style.minHeight=this.vert.style.minWidth="18px")}Kn.prototype.update=function(e){var t=e.scrollWidth>e.clientWidth+1,r=e.scrollHeight>e.clientHeight+1,n=e.nativeBarWidth;if(r){this.vert.style.display="block",this.vert.style.bottom=t?n+"px":"0";var i=e.viewHeight-(t?n:0);this.vert.firstChild.style.height=Math.max(0,e.scrollHeight-e.clientHeight+i)+"px"}else this.vert.style.display="",this.vert.firstChild.style.height="0";if(t){this.horiz.style.display="block",this.horiz.style.right=r?n+"px":"0",this.horiz.style.left=e.barLeft+"px";var o=e.viewWidth-e.barLeft-(r?n:0);this.horiz.firstChild.style.width=Math.max(0,e.scrollWidth-e.clientWidth+o)+"px"}else this.horiz.style.display="",this.horiz.firstChild.style.width="0";return!this.checkedZeroWidth&&0<e.clientHeight&&(0==n&&this.zeroWidthHack(),this.checkedZeroWidth=!0),{right:r?n:0,bottom:t?n:0}},Kn.prototype.setScrollLeft=function(e){this.horiz.scrollLeft!=e&&(this.horiz.scrollLeft=e),this.disableHoriz&&this.enableZeroWidthBar(this.horiz,this.disableHoriz,"horiz")},Kn.prototype.setScrollTop=function(e){this.vert.scrollTop!=e&&(this.vert.scrollTop=e),this.disableVert&&this.enableZeroWidthBar(this.vert,this.disableVert,"vert")},Kn.prototype.zeroWidthHack=function(){var e=w&&!s?"12px":"18px";this.horiz.style.height=this.vert.style.width=e,this.horiz.style.pointerEvents=this.vert.style.pointerEvents="none",this.disableHoriz=new R,this.disableVert=new R},Kn.prototype.enableZeroWidthBar=function(r,n,i){r.style.pointerEvents="auto",n.set(1e3,function e(){var t=r.getBoundingClientRect();("vert"==i?document.elementFromPoint(t.right-1,(t.top+t.bottom)/2):document.elementFromPoint((t.right+t.left)/2,t.bottom-1))!=r?r.style.pointerEvents="none":n.set(1e3,e)})},Kn.prototype.clear=function(){var e=this.horiz.parentNode;e.removeChild(this.horiz),e.removeChild(this.vert)};function jn(){}function Xn(e,t){t=t||Vn(e);var r=e.display.barWidth,n=e.display.barHeight;Yn(e,t);for(var i=0;i<4&&r!=e.display.barWidth||n!=e.display.barHeight;i++)r!=e.display.barWidth&&e.options.lineWrapping&&Dn(e),Yn(e,Vn(e)),r=e.display.barWidth,n=e.display.barHeight}function Yn(e,t){var r=e.display,n=r.scrollbars.update(t);r.sizer.style.paddingRight=(r.barWidth=n.right)+"px",r.sizer.style.paddingBottom=(r.barHeight=n.bottom)+"px",r.heightForcer.style.borderBottom=n.bottom+"px solid transparent",n.right&&n.bottom?(r.scrollbarFiller.style.display="block",r.scrollbarFiller.style.height=n.bottom+"px",r.scrollbarFiller.style.width=n.right+"px"):r.scrollbarFiller.style.display="",n.bottom&&e.options.coverGutterNextToScrollbar&&e.options.fixedGutter?(r.gutterFiller.style.display="block",r.gutterFiller.style.height=n.bottom+"px",r.gutterFiller.style.width=t.gutterWidth+"px"):r.gutterFiller.style.display=""}jn.prototype.update=function(){return{bottom:0,right:0}},jn.prototype.setScrollLeft=function(){},jn.prototype.setScrollTop=function(){},jn.prototype.clear=function(){};var _n={native:Kn,null:jn};function $n(r){r.display.scrollbars&&(r.display.scrollbars.clear(),r.display.scrollbars.addClass&&T(r.display.wrapper,r.display.scrollbars.addClass)),r.display.scrollbars=new _n[r.options.scrollbarStyle](function(e){r.display.wrapper.insertBefore(e,r.display.scrollbarFiller),we(e,"mousedown",function(){r.state.focused&&setTimeout(function(){return r.display.input.focus()},0)}),e.setAttribute("cm-not-content","true")},function(e,t){("horizontal"==t?Un:Bn)(r,e)},r),r.display.scrollbars.addClass&&H(r.display.wrapper,r.display.scrollbars.addClass)}var qn=0;function Zn(e){var t;e.curOp={cm:e,viewChanged:!1,startHeight:e.doc.height,forceUpdate:!1,updateInput:0,typing:!1,changeObjs:null,cursorActivityHandlers:null,cursorActivityCalled:0,selectionChanged:!1,updateMaxLine:!1,scrollLeft:null,scrollTop:null,scrollToPos:null,focus:!1,id:++qn},t=e.curOp,fr?fr.ops.push(t):t.ownsGroup=fr={ops:[t],delayedCallbacks:[]}}function Qn(e){var t=e.curOp;t&&dr(t,function(e){for(var t=0;t<e.ops.length;t++)e.ops[t].cm.curOp=null;!function(e){for(var t=e.ops,r=0;r<t.length;r++)Jn(t[r]);for(var n=0;n<t.length;n++)(i=t[n]).updatedDisplay=i.mustUpdate&&ci(i.cm,i.update);var i;for(var o=0;o<t.length;o++)ei(t[o]);for(var l=0;l<t.length;l++)ti(t[l]);for(var s=0;s<t.length;s++)ri(t[s])}(e)})}function Jn(e){var t,r,n=e.cm,i=n.display;!(r=(t=n).display).scrollbarsClipped&&r.scroller.offsetWidth&&(r.nativeBarWidth=r.scroller.offsetWidth-r.scroller.clientWidth,r.heightForcer.style.height=Wr(t)+"px",r.sizer.style.marginBottom=-r.nativeBarWidth+"px",r.sizer.style.borderRightWidth=Wr(t)+"px",r.scrollbarsClipped=!0),e.updateMaxLine&&Jt(n),e.mustUpdate=e.viewChanged||e.forceUpdate||null!=e.scrollTop||e.scrollToPos&&(e.scrollToPos.from.line<i.viewFrom||e.scrollToPos.to.line>=i.viewTo)||i.maxLineChanged&&n.options.lineWrapping,e.update=e.mustUpdate&&new ui(n,e.mustUpdate&&{top:e.scrollTop,ensure:e.scrollToPos},e.forceUpdate)}function ei(e){var t=e.cm,r=t.display;e.updatedDisplay&&Dn(t),e.barMeasure=Vn(t),r.maxLineChanged&&!t.options.lineWrapping&&(e.adjustWidthTo=Er(t,r.maxLine,r.maxLine.text.length).left+3,t.display.sizerWidth=e.adjustWidthTo,e.barMeasure.scrollWidth=Math.max(r.scroller.clientWidth,r.sizer.offsetLeft+e.adjustWidthTo+Wr(t)+t.display.barWidth),e.maxScrollLeft=Math.max(0,r.sizer.offsetLeft+e.adjustWidthTo-Hr(t))),(e.updatedDisplay||e.selectionChanged)&&(e.preparedSelection=r.input.prepareSelection())}function ti(e){var t=e.cm;null!=e.adjustWidthTo&&(t.display.sizer.style.minWidth=e.adjustWidthTo+"px",e.maxScrollLeft<t.doc.scrollLeft&&Un(t,Math.min(t.display.scroller.scrollLeft,e.maxScrollLeft),!0),t.display.maxLineChanged=!1);var r=e.focus&&e.focus==W();e.preparedSelection&&t.display.input.showSelection(e.preparedSelection,r),!e.updatedDisplay&&e.startHeight==t.doc.height||Xn(t,e.barMeasure),e.updatedDisplay&&pi(t,e.barMeasure),e.selectionChanged&&Tn(t),t.state.focused&&e.updateInput&&t.display.input.reset(e.typing),r&&Mn(e.cm)}function ri(e){var t=e.cm,r=t.display,n=t.doc;e.updatedDisplay&&hi(t,e.update),null==r.wheelStartX||null==e.scrollTop&&null==e.scrollLeft&&!e.scrollToPos||(r.wheelStartX=r.wheelStartY=null),null!=e.scrollTop&&Gn(t,e.scrollTop,e.forceScroll),null!=e.scrollLeft&&Un(t,e.scrollLeft,!0,!0),e.scrollToPos&&function(e,t){if(!Le(e,"scrollCursorIntoView")){var r=e.display,n=r.sizer.getBoundingClientRect(),i=null;if(t.top+n.top<0?i=!0:t.bottom+n.top>(window.innerHeight||document.documentElement.clientHeight)&&(i=!1),null!=i&&!u){var o=A("div","​",null,"position: absolute;\n top: "+(t.top-r.viewOffset-Or(e.display))+"px;\n height: "+(t.bottom-t.top+Wr(e)+r.barHeight)+"px;\n left: "+t.left+"px; width: "+Math.max(2,t.right-t.left)+"px;");e.display.lineSpace.appendChild(o),o.scrollIntoView(i),e.display.lineSpace.removeChild(o)}}}(t,function(e,t,r,n){var i;null==n&&(n=0),e.options.lineWrapping||t!=r||(r="before"==(t=t.ch?at(t.line,"before"==t.sticky?t.ch-1:t.ch,"after"):t).sticky?at(t.line,t.ch+1,"before"):t);for(var o=0;o<5;o++){var l=!1,s=Jr(e,t),a=r&&r!=t?Jr(e,r):s,u=Fn(e,i={left:Math.min(s.left,a.left),top:Math.min(s.top,a.top)-n,right:Math.max(s.left,a.left),bottom:Math.max(s.bottom,a.bottom)+n}),c=e.doc.scrollTop,h=e.doc.scrollLeft;if(null!=u.scrollTop&&(Bn(e,u.scrollTop),1<Math.abs(e.doc.scrollTop-c)&&(l=!0)),null!=u.scrollLeft&&(Un(e,u.scrollLeft),1<Math.abs(e.doc.scrollLeft-h)&&(l=!0)),!l)break}return i}(t,gt(n,e.scrollToPos.from),gt(n,e.scrollToPos.to),e.scrollToPos.margin));var i=e.maybeHiddenMarkers,o=e.maybeUnhiddenMarkers;if(i)for(var l=0;l<i.length;++l)i[l].lines.length||Se(i[l],"hide");if(o)for(var s=0;s<o.length;++s)o[s].lines.length&&Se(o[s],"unhide");r.wrapper.offsetHeight&&(n.scrollTop=t.display.scroller.scrollTop),e.changeObjs&&Se(t,"changes",t,e.changeObjs),e.update&&e.update.finish()}function ni(e,t){if(e.curOp)return t();Zn(e);try{return t()}finally{Qn(e)}}function ii(e,t){return function(){if(e.curOp)return t.apply(e,arguments);Zn(e);try{return t.apply(e,arguments)}finally{Qn(e)}}}function oi(e){return function(){if(this.curOp)return e.apply(this,arguments);Zn(this);try{return e.apply(this,arguments)}finally{Qn(this)}}}function li(t){return function(){var e=this.cm;if(!e||e.curOp)return t.apply(this,arguments);Zn(e);try{return t.apply(this,arguments)}finally{Qn(e)}}}function si(e,t){e.doc.highlightFrontier<e.display.viewTo&&e.state.highlight.set(t,E(ai,e))}function ai(a){var u=a.doc;if(!(u.highlightFrontier>=a.display.viewTo)){var c=+new Date+a.options.workTime,h=xt(a,u.highlightFrontier),f=[];u.iter(h.line,Math.min(u.first+u.size,a.display.viewTo+500),function(e){if(h.line>=a.display.viewFrom){var t=e.styles,r=e.text.length>a.options.maxHighlightLength?qe(u.mode,h.state):null,n=bt(a,e,h,!0);r&&(h.state=r),e.styles=n.styles;var i=e.styleClasses,o=n.classes;o?e.styleClasses=o:i&&(e.styleClasses=null);for(var l=!t||t.length!=e.styles.length||i!=o&&(!i||!o||i.bgClass!=o.bgClass||i.textClass!=o.textClass),s=0;!l&&s<t.length;++s)l=t[s]!=e.styles[s];l&&f.push(h.line),e.stateAfter=h.save(),h.nextLine()}else e.text.length<=a.options.maxHighlightLength&&Ct(a,e.text,h),e.stateAfter=h.line%5==0?h.save():null,h.nextLine();if(+new Date>c)return si(a,a.options.workDelay),!0}),u.highlightFrontier=h.line,u.modeFrontier=Math.max(u.modeFrontier,h.line),f.length&&ni(a,function(){for(var e=0;e<f.length;e++)mn(a,f[e],"text")})}}var ui=function(e,t,r){var n=e.display;this.viewport=t,this.visible=Hn(n,e.doc,t),this.editorIsHidden=!n.wrapper.offsetWidth,this.wrapperHeight=n.wrapper.clientHeight,this.wrapperWidth=n.wrapper.clientWidth,this.oldDisplayWidth=Hr(e),this.force=r,this.dims=cn(e),this.events=[]};function ci(e,t){var r=e.display,n=e.doc;if(t.editorIsHidden)return yn(e),!1;if(!t.force&&t.visible.from>=r.viewFrom&&t.visible.to<=r.viewTo&&(null==r.updateLineNumbers||r.updateLineNumbers>=r.viewTo)&&r.renderedView==r.view&&0==wn(e))return!1;vi(e)&&(yn(e),t.dims=cn(e));var i=n.first+n.size,o=Math.max(t.visible.from-e.options.viewportMargin,n.first),l=Math.min(i,t.visible.to+e.options.viewportMargin);r.viewFrom<o&&o-r.viewFrom<20&&(o=Math.max(n.first,r.viewFrom)),r.viewTo>l&&r.viewTo-l<20&&(l=Math.min(i,r.viewTo)),At&&(o=Yt(e.doc,o),l=_t(e.doc,l));var s,a,u,c,h=o!=r.viewFrom||l!=r.viewTo||r.lastWrapHeight!=t.wrapperHeight||r.lastWrapWidth!=t.wrapperWidth;a=o,u=l,0==(c=(s=e).display).view.length||a>=c.viewTo||u<=c.viewFrom?(c.view=hr(s,a,u),c.viewFrom=a):(c.viewFrom>a?c.view=hr(s,a,c.viewFrom).concat(c.view):c.viewFrom<a&&(c.view=c.view.slice(gn(s,a))),c.viewFrom=a,c.viewTo<u?c.view=c.view.concat(hr(s,c.viewTo,u)):c.viewTo>u&&(c.view=c.view.slice(0,gn(s,u)))),c.viewTo=u,r.viewOffset=Zt(et(e.doc,r.viewFrom)),e.display.mover.style.top=r.viewOffset+"px";var f=wn(e);if(!h&&0==f&&!t.force&&r.renderedView==r.view&&(null==r.updateLineNumbers||r.updateLineNumbers>=r.viewTo))return!1;var d=function(e){if(e.hasFocus())return null;var t=W();if(!t||!D(e.display.lineDiv,t))return null;var r={activeElt:t};if(window.getSelection){var n=window.getSelection();n.anchorNode&&n.extend&&D(e.display.lineDiv,n.anchorNode)&&(r.anchorNode=n.anchorNode,r.anchorOffset=n.anchorOffset,r.focusNode=n.focusNode,r.focusOffset=n.focusOffset)}return r}(e);return 4<f&&(r.lineDiv.style.display="none"),function(r,e,t){var n=r.display,i=r.options.lineNumbers,o=n.lineDiv,l=o.firstChild;function s(e){var t=e.nextSibling;return b&&w&&r.display.currentWheelTarget==e?e.style.display="none":e.parentNode.removeChild(e),t}for(var a=n.view,u=n.viewFrom,c=0;c<a.length;c++){var h=a[c];if(!h.hidden)if(h.node&&h.node.parentNode==o){for(;l!=h.node;)l=s(l);var f=i&&null!=e&&e<=u&&h.lineNumber;h.changes&&(-1<B(h.changes,"gutter")&&(f=!1),mr(r,h,u,t)),f&&(M(h.lineNumber),h.lineNumber.appendChild(document.createTextNode(st(r.options,u)))),l=h.node.nextSibling}else{var d=(v=u,m=t,y=br(p=r,g=h),g.text=g.node=y.pre,y.bgClass&&(g.bgClass=y.bgClass),y.textClass&&(g.textClass=y.textClass),xr(p,g),Cr(p,g,v,m),Lr(p,g,m),g.node);o.insertBefore(d,l)}u+=h.size}var p,g,v,m,y;for(;l;)l=s(l)}(e,r.updateLineNumbers,t.dims),4<f&&(r.lineDiv.style.display=""),r.renderedView=r.view,function(e){if(e&&e.activeElt&&e.activeElt!=W()&&(e.activeElt.focus(),e.anchorNode&&D(document.body,e.anchorNode)&&D(document.body,e.focusNode))){var t=window.getSelection(),r=document.createRange();r.setEnd(e.anchorNode,e.anchorOffset),r.collapse(!1),t.removeAllRanges(),t.addRange(r),t.extend(e.focusNode,e.focusOffset)}}(d),M(r.cursorDiv),M(r.selectionDiv),r.gutters.style.height=r.sizer.style.minHeight=0,h&&(r.lastWrapHeight=t.wrapperHeight,r.lastWrapWidth=t.wrapperWidth,si(e,400)),!(r.updateLineNumbers=null)}function hi(e,t){for(var r=t.viewport,n=!0;;n=!1){if(n&&e.options.lineWrapping&&t.oldDisplayWidth!=Hr(e))n&&(t.visible=Hn(e.display,e.doc,r));else if(r&&null!=r.top&&(r={top:Math.min(e.doc.height+Ar(e.display)-Fr(e),r.top)}),t.visible=Hn(e.display,e.doc,r),t.visible.from>=e.display.viewFrom&&t.visible.to<=e.display.viewTo)break;if(!ci(e,t))break;Dn(e);var i=Vn(e);xn(e),Xn(e,i),pi(e,i),t.force=!1}t.signal(e,"update",e),e.display.viewFrom==e.display.reportedViewFrom&&e.display.viewTo==e.display.reportedViewTo||(t.signal(e,"viewportChange",e,e.display.viewFrom,e.display.viewTo),e.display.reportedViewFrom=e.display.viewFrom,e.display.reportedViewTo=e.display.viewTo)}function fi(e,t){var r=new ui(e,t);if(ci(e,r)){Dn(e),hi(e,r);var n=Vn(e);xn(e),Xn(e,n),pi(e,n),r.finish()}}function di(e){var t=e.gutters.offsetWidth;e.sizer.style.marginLeft=t+"px"}function pi(e,t){e.display.sizer.style.minHeight=t.docHeight+"px",e.display.heightForcer.style.top=t.docHeight+"px",e.display.gutters.style.height=t.docHeight+e.display.barHeight+Wr(e)+"px"}function gi(e){var t=e.display,r=t.view;if(t.alignWidgets||t.gutters.firstChild&&e.options.fixedGutter){for(var n=hn(t)-t.scroller.scrollLeft+e.doc.scrollLeft,i=t.gutters.offsetWidth,o=n+"px",l=0;l<r.length;l++)if(!r[l].hidden){e.options.fixedGutter&&(r[l].gutter&&(r[l].gutter.style.left=o),r[l].gutterBackground&&(r[l].gutterBackground.style.left=o));var s=r[l].alignable;if(s)for(var a=0;a<s.length;a++)s[a].style.left=o}e.options.fixedGutter&&(t.gutters.style.left=n+i+"px")}}function vi(e){if(e.options.lineNumbers){var t=e.doc,r=st(e.options,t.first+t.size-1),n=e.display;if(r.length!=n.lineNumChars){var i=n.measure.appendChild(A("div",[A("div",r)],"CodeMirror-linenumber CodeMirror-gutter-elt")),o=i.firstChild.offsetWidth,l=i.offsetWidth-o;return n.lineGutter.style.width="",n.lineNumInnerWidth=Math.max(o,n.lineGutter.offsetWidth-l)+1,n.lineNumWidth=n.lineNumInnerWidth+l,n.lineNumChars=n.lineNumInnerWidth?r.length:-1,n.lineGutter.style.width=n.lineNumWidth+"px",di(e.display),1}}}function mi(e,t){for(var r=[],n=!1,i=0;i<e.length;i++){var o=e[i],l=null;if("string"!=typeof o&&(l=o.style,o=o.className),"CodeMirror-linenumbers"==o){if(!t)continue;n=!0}r.push({className:o,style:l})}return t&&!n&&r.push({className:"CodeMirror-linenumbers",style:null}),r}function yi(e){var t=e.gutters,r=e.gutterSpecs;M(t),e.lineGutter=null;for(var n=0;n<r.length;++n){var i=r[n],o=i.className,l=i.style,s=t.appendChild(A("div",null,"CodeMirror-gutter "+o));l&&(s.style.cssText=l),"CodeMirror-linenumbers"==o&&((e.lineGutter=s).style.width=(e.lineNumWidth||1)+"px")}t.style.display=r.length?"":"none",di(e)}function bi(e){yi(e.display),vn(e),gi(e)}function wi(e,t,r,n){var i=this;this.input=r,i.scrollbarFiller=A("div",null,"CodeMirror-scrollbar-filler"),i.scrollbarFiller.setAttribute("cm-not-content","true"),i.gutterFiller=A("div",null,"CodeMirror-gutter-filler"),i.gutterFiller.setAttribute("cm-not-content","true"),i.lineDiv=O("div",null,"CodeMirror-code"),i.selectionDiv=A("div",null,null,"position: relative; z-index: 1"),i.cursorDiv=A("div",null,"CodeMirror-cursors"),i.measure=A("div",null,"CodeMirror-measure"),i.lineMeasure=A("div",null,"CodeMirror-measure"),i.lineSpace=O("div",[i.measure,i.lineMeasure,i.selectionDiv,i.cursorDiv,i.lineDiv],null,"position: relative; outline: none");var o=O("div",[i.lineSpace],"CodeMirror-lines");i.mover=A("div",[o],null,"position: relative"),i.sizer=A("div",[i.mover],"CodeMirror-sizer"),i.sizerWidth=null,i.heightForcer=A("div",null,null,"position: absolute; height: "+G+"px; width: 1px;"),i.gutters=A("div",null,"CodeMirror-gutters"),i.lineGutter=null,i.scroller=A("div",[i.sizer,i.heightForcer,i.gutters],"CodeMirror-scroll"),i.scroller.setAttribute("tabIndex","-1"),i.wrapper=A("div",[i.scrollbarFiller,i.gutterFiller,i.scroller],"CodeMirror"),x&&C<8&&(i.gutters.style.zIndex=-1,i.scroller.style.paddingRight=0),b||g&&f||(i.scroller.draggable=!0),e&&(e.appendChild?e.appendChild(i.wrapper):e(i.wrapper)),i.viewFrom=i.viewTo=t.first,i.reportedViewFrom=i.reportedViewTo=t.first,i.view=[],i.renderedView=null,i.externalMeasured=null,i.viewOffset=0,i.lastWrapHeight=i.lastWrapWidth=0,i.updateLineNumbers=null,i.nativeBarWidth=i.barHeight=i.barWidth=0,i.scrollbarsClipped=!1,i.lineNumWidth=i.lineNumInnerWidth=i.lineNumChars=null,i.alignWidgets=!1,i.cachedCharWidth=i.cachedTextHeight=i.cachedPaddingH=null,i.maxLine=null,i.maxLineLength=0,i.maxLineChanged=!1,i.wheelDX=i.wheelDY=i.wheelStartX=i.wheelStartY=null,i.shift=!1,i.selForContextMenu=null,i.activeTouch=null,i.gutterSpecs=mi(n.gutters,n.lineNumbers),yi(i),r.init(i)}ui.prototype.signal=function(e,t){Te(e,t)&&this.events.push(arguments)},ui.prototype.finish=function(){for(var e=0;e<this.events.length;e++)Se.apply(null,this.events[e])};var xi=0,Ci=null;function Si(e){var t=e.wheelDeltaX,r=e.wheelDeltaY;return null==t&&e.detail&&e.axis==e.HORIZONTAL_AXIS&&(t=e.detail),null==r&&e.detail&&e.axis==e.VERTICAL_AXIS?r=e.detail:null==r&&(r=e.wheelDelta),{x:t,y:r}}function Li(e){var t=Si(e);return t.x*=Ci,t.y*=Ci,t}function ki(e,t){var r=Si(t),n=r.x,i=r.y,o=e.display,l=o.scroller,s=l.scrollWidth>l.clientWidth,a=l.scrollHeight>l.clientHeight;if(n&&s||i&&a){if(i&&w&&b)e:for(var u=t.target,c=o.view;u!=l;u=u.parentNode)for(var h=0;h<c.length;h++)if(c[h].node==u){e.display.currentWheelTarget=u;break e}if(n&&!g&&!v&&null!=Ci)return i&&a&&Bn(e,Math.max(0,l.scrollTop+i*Ci)),Un(e,Math.max(0,l.scrollLeft+n*Ci)),(!i||i&&a)&&Ne(t),void(o.wheelStartX=null);if(i&&null!=Ci){var f=i*Ci,d=e.doc.scrollTop,p=d+o.wrapper.clientHeight;f<0?d=Math.max(0,d+f-50):p=Math.min(e.doc.height,p+f+50),fi(e,{top:d,bottom:p})}xi<20&&(null==o.wheelStartX?(o.wheelStartX=l.scrollLeft,o.wheelStartY=l.scrollTop,o.wheelDX=n,o.wheelDY=i,setTimeout(function(){if(null!=o.wheelStartX){var e=l.scrollLeft-o.wheelStartX,t=l.scrollTop-o.wheelStartY,r=t&&o.wheelDY&&t/o.wheelDY||e&&o.wheelDX&&e/o.wheelDX;o.wheelStartX=o.wheelStartY=null,r&&(Ci=(Ci*xi+r)/(xi+1),++xi)}},200)):(o.wheelDX+=n,o.wheelDY+=i))}}x?Ci=-.53:g?Ci=15:l?Ci=-.7:a&&(Ci=-1/3);var Ti=function(e,t){this.ranges=e,this.primIndex=t};Ti.prototype.primary=function(){return this.ranges[this.primIndex]},Ti.prototype.equals=function(e){if(e==this)return!0;if(e.primIndex!=this.primIndex||e.ranges.length!=this.ranges.length)return!1;for(var t=0;t<this.ranges.length;t++){var r=this.ranges[t],n=e.ranges[t];if(!ct(r.anchor,n.anchor)||!ct(r.head,n.head))return!1}return!0},Ti.prototype.deepCopy=function(){for(var e=[],t=0;t<this.ranges.length;t++)e[t]=new Mi(ht(this.ranges[t].anchor),ht(this.ranges[t].head));return new Ti(e,this.primIndex)},Ti.prototype.somethingSelected=function(){for(var e=0;e<this.ranges.length;e++)if(!this.ranges[e].empty())return!0;return!1},Ti.prototype.contains=function(e,t){t=t||e;for(var r=0;r<this.ranges.length;r++){var n=this.ranges[r];if(0<=ut(t,n.from())&&ut(e,n.to())<=0)return r}return-1};var Mi=function(e,t){this.anchor=e,this.head=t};function Ni(e,t,r){var n=e&&e.options.selectionsMayTouch,i=t[r];t.sort(function(e,t){return ut(e.from(),t.from())}),r=B(t,i);for(var o=1;o<t.length;o++){var l=t[o],s=t[o-1],a=ut(s.to(),l.from());if(n&&!l.empty()?0<a:0<=a){var u=dt(s.from(),l.from()),c=ft(s.to(),l.to()),h=s.empty()?l.from()==l.head:s.from()==s.head;o<=r&&--r,t.splice(--o,2,new Mi(h?c:u,h?u:c))}}return new Ti(t,r)}function Oi(e,t){return new Ti([new Mi(e,t||e)],0)}function Ai(e){return e.text?at(e.from.line+e.text.length-1,$(e.text).length+(1==e.text.length?e.from.ch:0)):e.to}function Di(e,t){if(ut(e,t.from)<0)return e;if(ut(e,t.to)<=0)return Ai(t);var r=e.line+t.text.length-(t.to.line-t.from.line)-1,n=e.ch;return e.line==t.to.line&&(n+=Ai(t).ch-t.to.ch),at(r,n)}function Wi(e,t){for(var r=[],n=0;n<e.sel.ranges.length;n++){var i=e.sel.ranges[n];r.push(new Mi(Di(i.anchor,t),Di(i.head,t)))}return Ni(e.cm,r,e.sel.primIndex)}function Hi(e,t,r){return e.line==t.line?at(r.line,e.ch-t.ch+r.ch):at(r.line+(e.line-t.line),e.ch)}function Fi(e){e.doc.mode=Ye(e.options,e.doc.modeOption),Pi(e)}function Pi(e){e.doc.iter(function(e){e.stateAfter&&(e.stateAfter=null),e.styles&&(e.styles=null)}),e.doc.modeFrontier=e.doc.highlightFrontier=e.doc.first,si(e,100),e.state.modeGen++,e.curOp&&vn(e)}function Ei(e,t){return 0==t.from.ch&&0==t.to.ch&&""==$(t.text)&&(!e.cm||e.cm.options.wholeLineUpdateBefore)}function Ii(e,n,t,i){function o(e){return t?t[e]:null}function r(e,t,r){!function(e,t,r,n){e.text=t,e.stateAfter&&(e.stateAfter=null),e.styles&&(e.styles=null),null!=e.order&&(e.order=null),Et(e),It(e,r);var i=n?n(e):1;i!=e.height&&nt(e,i)}(e,t,r,i),gr(e,"change",e,n)}function l(e,t){for(var r=[],n=e;n<t;++n)r.push(new er(u[n],o(n),i));return r}var s=n.from,a=n.to,u=n.text,c=et(e,s.line),h=et(e,a.line),f=$(u),d=o(u.length-1),p=a.line-s.line;if(n.full)e.insert(0,l(0,u.length)),e.remove(u.length,e.size-u.length);else if(Ei(e,n)){var g=l(0,u.length-1);r(h,h.text,d),p&&e.remove(s.line,p),g.length&&e.insert(s.line,g)}else if(c==h)if(1==u.length)r(c,c.text.slice(0,s.ch)+f+c.text.slice(a.ch),d);else{var v=l(1,u.length-1);v.push(new er(f+c.text.slice(a.ch),d,i)),r(c,c.text.slice(0,s.ch)+u[0],o(0)),e.insert(s.line+1,v)}else if(1==u.length)r(c,c.text.slice(0,s.ch)+u[0]+h.text.slice(a.ch),o(0)),e.remove(s.line+1,p);else{r(c,c.text.slice(0,s.ch)+u[0],o(0)),r(h,f+h.text.slice(a.ch),d);var m=l(1,u.length-1);1<p&&e.remove(s.line+1,p-1),e.insert(s.line+1,m)}gr(e,"change",e,n)}function zi(e,s,a){!function e(t,r,n){if(t.linked)for(var i=0;i<t.linked.length;++i){var o=t.linked[i];if(o.doc!=r){var l=n&&o.sharedHist;a&&!l||(s(o.doc,l),e(o.doc,t,l))}}}(e,null,!0)}function Ri(e,t){if(t.cm)throw new Error("This document is already in use.");dn((e.doc=t).cm=e),Fi(e),Bi(e),e.options.lineWrapping||Jt(e),e.options.mode=t.modeOption,vn(e)}function Bi(e){("rtl"==e.doc.direction?H:T)(e.display.lineDiv,"CodeMirror-rtl")}function Gi(e){this.done=[],this.undone=[],this.undoDepth=1/0,this.lastModTime=this.lastSelTime=0,this.lastOp=this.lastSelOp=null,this.lastOrigin=this.lastSelOrigin=null,this.generation=this.maxGeneration=e||1}function Ui(e,t){var r={from:ht(t.from),to:Ai(t),text:tt(e,t.from,t.to)};return Yi(e,r,t.from.line,t.to.line+1),zi(e,function(e){return Yi(e,r,t.from.line,t.to.line+1)},!0),r}function Vi(e){for(;e.length;){if(!$(e).ranges)break;e.pop()}}function Ki(e,t,r,n){var i=e.history;i.undone.length=0;var o,l,s,a=+new Date;if((i.lastOp==n||i.lastOrigin==t.origin&&t.origin&&("+"==t.origin.charAt(0)&&i.lastModTime>a-(e.cm?e.cm.options.historyEventDelay:500)||"*"==t.origin.charAt(0)))&&(o=(s=i).lastOp==n?(Vi(s.done),$(s.done)):s.done.length&&!$(s.done).ranges?$(s.done):1<s.done.length&&!s.done[s.done.length-2].ranges?(s.done.pop(),$(s.done)):void 0))l=$(o.changes),0==ut(t.from,t.to)&&0==ut(t.from,l.to)?l.to=Ai(t):o.changes.push(Ui(e,t));else{var u=$(i.done);for(u&&u.ranges||Xi(e.sel,i.done),o={changes:[Ui(e,t)],generation:i.generation},i.done.push(o);i.done.length>i.undoDepth;)i.done.shift(),i.done[0].ranges||i.done.shift()}i.done.push(r),i.generation=++i.maxGeneration,i.lastModTime=i.lastSelTime=a,i.lastOp=i.lastSelOp=n,i.lastOrigin=i.lastSelOrigin=t.origin,l||Se(e,"historyAdded")}function ji(e,t,r,n){var i,o,l,s,a,u=e.history,c=n&&n.origin;r==u.lastSelOp||c&&u.lastSelOrigin==c&&(u.lastModTime==u.lastSelTime&&u.lastOrigin==c||(i=e,o=c,l=$(u.done),s=t,"*"==(a=o.charAt(0))||"+"==a&&l.ranges.length==s.ranges.length&&l.somethingSelected()==s.somethingSelected()&&new Date-i.history.lastSelTime<=(i.cm?i.cm.options.historyEventDelay:500)))?u.done[u.done.length-1]=t:Xi(t,u.done),u.lastSelTime=+new Date,u.lastSelOrigin=c,u.lastSelOp=r,n&&!1!==n.clearRedo&&Vi(u.undone)}function Xi(e,t){var r=$(t);r&&r.ranges&&r.equals(e)||t.push(e)}function Yi(t,r,e,n){var i=r["spans_"+t.id],o=0;t.iter(Math.max(t.first,e),Math.min(t.first+t.size,n),function(e){e.markedSpans&&((i=i||(r["spans_"+t.id]={}))[o]=e.markedSpans),++o})}function _i(e){if(!e)return null;for(var t,r=0;r<e.length;++r)e[r].marker.explicitlyCleared?t=t||e.slice(0,r):t&&t.push(e[r]);return t?t.length?t:null:e}function $i(e,t){var r=function(e,t){var r=t["spans_"+e.id];if(!r)return null;for(var n=[],i=0;i<t.text.length;++i)n.push(_i(r[i]));return n}(e,t),n=Ft(e,t);if(!r)return n;if(!n)return r;for(var i=0;i<r.length;++i){var o=r[i],l=n[i];if(o&&l)e:for(var s=0;s<l.length;++s){for(var a=l[s],u=0;u<o.length;++u)if(o[u].marker==a.marker)continue e;o.push(a)}else l&&(r[i]=l)}return r}function qi(e,t,r){for(var n=[],i=0;i<e.length;++i){var o=e[i];if(o.ranges)n.push(r?Ti.prototype.deepCopy.call(o):o);else{var l=o.changes,s=[];n.push({changes:s});for(var a=0;a<l.length;++a){var u=l[a],c=void 0;if(s.push({from:u.from,to:u.to,text:u.text}),t)for(var h in u)(c=h.match(/^spans_(\d+)$/))&&-1<B(t,Number(c[1]))&&($(s)[h]=u[h],delete u[h])}}}return n}function Zi(e,t,r,n){if(n){var i=e.anchor;if(r){var o=ut(t,i)<0;o!=ut(r,i)<0?(i=t,t=r):o!=ut(t,r)<0&&(t=r)}return new Mi(i,t)}return new Mi(r||t,t)}function Qi(e,t,r,n,i){null==i&&(i=e.cm&&(e.cm.display.shift||e.extend)),no(e,new Ti([Zi(e.sel.primary(),t,r,i)],0),n)}function Ji(e,t,r){for(var n=[],i=e.cm&&(e.cm.display.shift||e.extend),o=0;o<e.sel.ranges.length;o++)n[o]=Zi(e.sel.ranges[o],t[o],null,i);no(e,Ni(e.cm,n,e.sel.primIndex),r)}function eo(e,t,r,n){var i=e.sel.ranges.slice(0);i[t]=r,no(e,Ni(e.cm,i,e.sel.primIndex),n)}function to(e,t,r,n){no(e,Oi(t,r),n)}function ro(e,t,r){var n=e.history.done,i=$(n);i&&i.ranges?io(e,n[n.length-1]=t,r):no(e,t,r)}function no(e,t,r){io(e,t,r),ji(e,e.sel,e.cm?e.cm.curOp.id:NaN,r)}function io(e,t,r){var n,i,o,l;(Te(e,"beforeSelectionChange")||e.cm&&Te(e.cm,"beforeSelectionChange"))&&(n=e,o=r,l={ranges:(i=t).ranges,update:function(e){this.ranges=[];for(var t=0;t<e.length;t++)this.ranges[t]=new Mi(gt(n,e[t].anchor),gt(n,e[t].head))},origin:o&&o.origin},Se(n,"beforeSelectionChange",n,l),n.cm&&Se(n.cm,"beforeSelectionChange",n.cm,l),t=l.ranges!=i.ranges?Ni(n.cm,l.ranges,l.ranges.length-1):i);var s=r&&r.bias||(ut(t.primary().head,e.sel.primary().head)<0?-1:1);oo(e,so(e,t,s,!0)),r&&!1===r.scroll||!e.cm||En(e.cm)}function oo(e,t){t.equals(e.sel)||(e.sel=t,e.cm&&(e.cm.curOp.updateInput=1,e.cm.curOp.selectionChanged=!0,ke(e.cm)),gr(e,"cursorActivity",e))}function lo(e){oo(e,so(e,e.sel,null,!1))}function so(e,t,r,n){for(var i,o=0;o<t.ranges.length;o++){var l=t.ranges[o],s=t.ranges.length==e.sel.ranges.length&&e.sel.ranges[o],a=uo(e,l.anchor,s&&s.anchor,r,n),u=uo(e,l.head,s&&s.head,r,n);!i&&a==l.anchor&&u==l.head||((i=i||t.ranges.slice(0,o))[o]=new Mi(a,u))}return i?Ni(e.cm,i,t.primIndex):t}function ao(e,t,r,n,i){var o=et(e,t.line);if(o.markedSpans)for(var l=0;l<o.markedSpans.length;++l){var s=o.markedSpans[l],a=s.marker,u="selectLeft"in a?!a.selectLeft:a.inclusiveLeft,c="selectRight"in a?!a.selectRight:a.inclusiveRight;if((null==s.from||(u?s.from<=t.ch:s.from<t.ch))&&(null==s.to||(c?s.to>=t.ch:s.to>t.ch))){if(i&&(Se(a,"beforeCursorEnter"),a.explicitlyCleared)){if(o.markedSpans){--l;continue}break}if(!a.atomic)continue;if(r){var h=a.find(n<0?1:-1),f=void 0;if((n<0?c:u)&&(h=co(e,h,-n,h&&h.line==t.line?o:null)),h&&h.line==t.line&&(f=ut(h,r))&&(n<0?f<0:0<f))return ao(e,h,t,n,i)}var d=a.find(n<0?-1:1);return(n<0?u:c)&&(d=co(e,d,n,d.line==t.line?o:null)),d?ao(e,d,t,n,i):null}}return t}function uo(e,t,r,n,i){var o=n||1,l=ao(e,t,r,o,i)||!i&&ao(e,t,r,o,!0)||ao(e,t,r,-o,i)||!i&&ao(e,t,r,-o,!0);return l||(e.cantEdit=!0,at(e.first,0))}function co(e,t,r,n){return r<0&&0==t.ch?t.line>e.first?gt(e,at(t.line-1)):null:0<r&&t.ch==(n||et(e,t.line)).text.length?t.line<e.first+e.size-1?at(t.line+1,0):null:new at(t.line,t.ch+r)}function ho(e){e.setSelection(at(e.firstLine(),0),at(e.lastLine()),V)}function fo(i,e,t){var o={canceled:!1,from:e.from,to:e.to,text:e.text,origin:e.origin,cancel:function(){return o.canceled=!0}};return t&&(o.update=function(e,t,r,n){e&&(o.from=gt(i,e)),t&&(o.to=gt(i,t)),r&&(o.text=r),void 0!==n&&(o.origin=n)}),Se(i,"beforeChange",i,o),i.cm&&Se(i.cm,"beforeChange",i.cm,o),o.canceled?(i.cm&&(i.cm.curOp.updateInput=2),null):{from:o.from,to:o.to,text:o.text,origin:o.origin}}function po(e,t,r){if(e.cm){if(!e.cm.curOp)return ii(e.cm,po)(e,t,r);if(e.cm.state.suppressEdits)return}if(!(Te(e,"beforeChange")||e.cm&&Te(e.cm,"beforeChange"))||(t=fo(e,t,!0))){var n=Ot&&!r&&function(e,t,r){var n=null;if(e.iter(t.line,r.line+1,function(e){if(e.markedSpans)for(var t=0;t<e.markedSpans.length;++t){var r=e.markedSpans[t].marker;!r.readOnly||n&&-1!=B(n,r)||(n=n||[]).push(r)}}),!n)return null;for(var i=[{from:t,to:r}],o=0;o<n.length;++o)for(var l=n[o],s=l.find(0),a=0;a<i.length;++a){var u=i[a];if(!(ut(u.to,s.from)<0||0<ut(u.from,s.to))){var c=[a,1],h=ut(u.from,s.from),f=ut(u.to,s.to);(h<0||!l.inclusiveLeft&&!h)&&c.push({from:u.from,to:s.from}),(0<f||!l.inclusiveRight&&!f)&&c.push({from:s.to,to:u.to}),i.splice.apply(i,c),a+=c.length-3}}return i}(e,t.from,t.to);if(n)for(var i=n.length-1;0<=i;--i)go(e,{from:n[i].from,to:n[i].to,text:i?[""]:t.text,origin:t.origin});else go(e,t)}}function go(e,r){if(1!=r.text.length||""!=r.text[0]||0!=ut(r.from,r.to)){var t=Wi(e,r);Ki(e,r,t,e.cm?e.cm.curOp.id:NaN),yo(e,r,t,Ft(e,r));var n=[];zi(e,function(e,t){t||-1!=B(n,e.history)||(Co(e.history,r),n.push(e.history)),yo(e,r,null,Ft(e,r))})}}function vo(i,o,e){var t=i.cm&&i.cm.state.suppressEdits;if(!t||e){for(var l,r=i.history,n=i.sel,s="undo"==o?r.done:r.undone,a="undo"==o?r.undone:r.done,u=0;u<s.length&&(l=s[u],e?!l.ranges||l.equals(i.sel):l.ranges);u++);if(u!=s.length){for(r.lastOrigin=r.lastSelOrigin=null;;){if(!(l=s.pop()).ranges){if(t)return void s.push(l);break}if(Xi(l,a),e&&!l.equals(i.sel))return void no(i,l,{clearRedo:!1});n=l}var c=[];Xi(n,a),a.push({changes:c,generation:r.generation}),r.generation=l.generation||++r.maxGeneration;for(var h=Te(i,"beforeChange")||i.cm&&Te(i.cm,"beforeChange"),f=function(e){var r=l.changes[e];if(r.origin=o,h&&!fo(i,r,!1))return s.length=0,{};c.push(Ui(i,r));var t=e?Wi(i,r):$(s);yo(i,r,t,$i(i,r)),!e&&i.cm&&i.cm.scrollIntoView({from:r.from,to:Ai(r)});var n=[];zi(i,function(e,t){t||-1!=B(n,e.history)||(Co(e.history,r),n.push(e.history)),yo(e,r,null,$i(e,r))})},d=l.changes.length-1;0<=d;--d){var p=f(d);if(p)return p.v}}}}function mo(e,t){if(0!=t&&(e.first+=t,e.sel=new Ti(q(e.sel.ranges,function(e){return new Mi(at(e.anchor.line+t,e.anchor.ch),at(e.head.line+t,e.head.ch))}),e.sel.primIndex),e.cm)){vn(e.cm,e.first,e.first-t,t);for(var r=e.cm.display,n=r.viewFrom;n<r.viewTo;n++)mn(e.cm,n,"gutter")}}function yo(e,t,r,n){if(e.cm&&!e.cm.curOp)return ii(e.cm,yo)(e,t,r,n);if(t.to.line<e.first)mo(e,t.text.length-1-(t.to.line-t.from.line));else if(!(t.from.line>e.lastLine())){if(t.from.line<e.first){var i=t.text.length-1-(e.first-t.from.line);mo(e,i),t={from:at(e.first,0),to:at(t.to.line+i,t.to.ch),text:[$(t.text)],origin:t.origin}}var o=e.lastLine();t.to.line>o&&(t={from:t.from,to:at(o,et(e,o).text.length),text:[t.text[0]],origin:t.origin}),t.removed=tt(e,t.from,t.to),r=r||Wi(e,t),e.cm?function(e,t,r){var n=e.doc,i=e.display,o=t.from,l=t.to,s=!1,a=o.line;e.options.lineWrapping||(a=it(Xt(et(n,o.line))),n.iter(a,l.line+1,function(e){if(e==i.maxLine)return s=!0}));-1<n.sel.contains(t.from,t.to)&&ke(e);Ii(n,t,r,fn(e)),e.options.lineWrapping||(n.iter(a,o.line+t.text.length,function(e){var t=Qt(e);t>i.maxLineLength&&(i.maxLine=e,i.maxLineLength=t,i.maxLineChanged=!0,s=!1)}),s&&(e.curOp.updateMaxLine=!0));(function(e,t){if(e.modeFrontier=Math.min(e.modeFrontier,t),!(e.highlightFrontier<t-10)){for(var r=e.first,n=t-1;r<n;n--){var i=et(e,n).stateAfter;if(i&&(!(i instanceof mt)||n+i.lookAhead<t)){r=n+1;break}}e.highlightFrontier=Math.min(e.highlightFrontier,r)}})(n,o.line),si(e,400);var u=t.text.length-(l.line-o.line)-1;t.full?vn(e):o.line!=l.line||1!=t.text.length||Ei(e.doc,t)?vn(e,o.line,l.line+1,u):mn(e,o.line,"text");var c=Te(e,"changes"),h=Te(e,"change");if(h||c){var f={from:o,to:l,text:t.text,removed:t.removed,origin:t.origin};h&&gr(e,"change",e,f),c&&(e.curOp.changeObjs||(e.curOp.changeObjs=[])).push(f)}e.display.selForContextMenu=null}(e.cm,t,n):Ii(e,t,n),io(e,r,V),e.cantEdit&&uo(e,at(e.firstLine(),0))&&(e.cantEdit=!1)}}function bo(e,t,r,n,i){var o;ut(n=n||r,r)<0&&(r=(o=[n,r])[0],n=o[1]),"string"==typeof t&&(t=e.splitLines(t)),po(e,{from:r,to:n,text:t,origin:i})}function wo(e,t,r,n){r<e.line?e.line+=n:t<e.line&&(e.line=t,e.ch=0)}function xo(e,t,r,n){for(var i=0;i<e.length;++i){var o=e[i],l=!0;if(o.ranges){o.copied||((o=e[i]=o.deepCopy()).copied=!0);for(var s=0;s<o.ranges.length;s++)wo(o.ranges[s].anchor,t,r,n),wo(o.ranges[s].head,t,r,n)}else{for(var a=0;a<o.changes.length;++a){var u=o.changes[a];if(r<u.from.line)u.from=at(u.from.line+n,u.from.ch),u.to=at(u.to.line+n,u.to.ch);else if(t<=u.to.line){l=!1;break}}l||(e.splice(0,i+1),i=0)}}}function Co(e,t){var r=t.from.line,n=t.to.line,i=t.text.length-(n-r)-1;xo(e.done,r,n,i),xo(e.undone,r,n,i)}function So(e,t,r,n){var i=t,o=t;return"number"==typeof t?o=et(e,pt(e,t)):i=it(t),null==i?null:(n(o,i)&&e.cm&&mn(e.cm,i,r),o)}function Lo(e){this.lines=e,this.parent=null;for(var t=0,r=0;r<e.length;++r)e[r].parent=this,t+=e[r].height;this.height=t}function ko(e){this.children=e;for(var t=0,r=0,n=0;n<e.length;++n){var i=e[n];t+=i.chunkSize(),r+=i.height,i.parent=this}this.size=t,this.height=r,this.parent=null}Mi.prototype.from=function(){return dt(this.anchor,this.head)},Mi.prototype.to=function(){return ft(this.anchor,this.head)},Mi.prototype.empty=function(){return this.head.line==this.anchor.line&&this.head.ch==this.anchor.ch},Lo.prototype={chunkSize:function(){return this.lines.length},removeInner:function(e,t){for(var r=e,n=e+t;r<n;++r){var i=this.lines[r];this.height-=i.height,(o=i).parent=null,Et(o),gr(i,"delete")}var o;this.lines.splice(e,t)},collapse:function(e){e.push.apply(e,this.lines)},insertInner:function(e,t,r){this.height+=r,this.lines=this.lines.slice(0,e).concat(t).concat(this.lines.slice(e));for(var n=0;n<t.length;++n)t[n].parent=this},iterN:function(e,t,r){for(var n=e+t;e<n;++e)if(r(this.lines[e]))return!0}},ko.prototype={chunkSize:function(){return this.size},removeInner:function(e,t){this.size-=t;for(var r=0;r<this.children.length;++r){var n=this.children[r],i=n.chunkSize();if(e<i){var o=Math.min(t,i-e),l=n.height;if(n.removeInner(e,o),this.height-=l-n.height,i==o&&(this.children.splice(r--,1),n.parent=null),0==(t-=o))break;e=0}else e-=i}if(this.size-t<25&&(1<this.children.length||!(this.children[0]instanceof Lo))){var s=[];this.collapse(s),this.children=[new Lo(s)],this.children[0].parent=this}},collapse:function(e){for(var t=0;t<this.children.length;++t)this.children[t].collapse(e)},insertInner:function(e,t,r){this.size+=t.length,this.height+=r;for(var n=0;n<this.children.length;++n){var i=this.children[n],o=i.chunkSize();if(e<=o){if(i.insertInner(e,t,r),i.lines&&50<i.lines.length){for(var l=i.lines.length%25+25,s=l;s<i.lines.length;){var a=new Lo(i.lines.slice(s,s+=25));i.height-=a.height,this.children.splice(++n,0,a),a.parent=this}i.lines=i.lines.slice(0,l),this.maybeSpill()}break}e-=o}},maybeSpill:function(){if(!(this.children.length<=10)){var e=this;do{var t=new ko(e.children.splice(e.children.length-5,5));if(e.parent){e.size-=t.size,e.height-=t.height;var r=B(e.parent.children,e);e.parent.children.splice(r+1,0,t)}else{var n=new ko(e.children);(n.parent=e).children=[n,t],e=n}t.parent=e.parent}while(10<e.children.length);e.parent.maybeSpill()}},iterN:function(e,t,r){for(var n=0;n<this.children.length;++n){var i=this.children[n],o=i.chunkSize();if(e<o){var l=Math.min(t,o-e);if(i.iterN(e,l,r))return!0;if(0==(t-=l))break;e=0}else e-=o}}};function To(e,t,r){if(r)for(var n in r)r.hasOwnProperty(n)&&(this[n]=r[n]);this.doc=e,this.node=t}function Mo(e,t,r){Zt(t)<(e.curOp&&e.curOp.scrollTop||e.doc.scrollTop)&&Pn(e,r)}To.prototype.clear=function(){var e=this.doc.cm,t=this.line.widgets,r=this.line,n=it(r);if(null!=n&&t){for(var i=0;i<t.length;++i)t[i]==this&&t.splice(i--,1);t.length||(r.widgets=null);var o=Mr(this);nt(r,Math.max(0,r.height-o)),e&&(ni(e,function(){Mo(e,r,-o),mn(e,n,"widget")}),gr(e,"lineWidgetCleared",e,this,n))}},To.prototype.changed=function(){var e=this,t=this.height,r=this.doc.cm,n=this.line;this.height=null;var i=Mr(this)-t;i&&($t(this.doc,n)||nt(n,n.height+i),r&&ni(r,function(){r.curOp.forceUpdate=!0,Mo(r,n,i),gr(r,"lineWidgetChanged",r,e,it(n))}))},Me(To);var No=0,Oo=function(e,t){this.lines=[],this.type=t,this.doc=e,this.id=++No};function Ao(t,n,i,e,r){if(e&&e.shared)return function(e,r,n,i,o){(i=I(i)).shared=!1;var l=[Ao(e,r,n,i,o)],s=l[0],a=i.widgetNode;return zi(e,function(e){a&&(i.widgetNode=a.cloneNode(!0)),l.push(Ao(e,gt(e,r),gt(e,n),i,o));for(var t=0;t<e.linked.length;++t)if(e.linked[t].isParent)return;s=$(l)}),new Do(l,s)}(t,n,i,e,r);if(t.cm&&!t.cm.curOp)return ii(t.cm,Ao)(t,n,i,e,r);var o=new Oo(t,r),l=ut(n,i);if(e&&I(e,o,!1),0<l||0==l&&!1!==o.clearWhenEmpty)return o;if(o.replacedWith&&(o.collapsed=!0,o.widgetNode=O("span",[o.replacedWith],"CodeMirror-widget"),e.handleMouseEvents||o.widgetNode.setAttribute("cm-ignore-events","true"),e.insertLeft&&(o.widgetNode.insertLeft=!0)),o.collapsed){if(jt(t,n.line,n,i,o)||n.line!=i.line&&jt(t,i.line,n,i,o))throw new Error("Inserting collapsed marker partially overlapping an existing one");At=!0}o.addToHistory&&Ki(t,{from:n,to:i,origin:"markText"},t.sel,NaN);var s,a=n.line,u=t.cm;if(t.iter(a,i.line+1,function(e){var t,r;u&&o.collapsed&&!u.options.lineWrapping&&Xt(e)==u.display.maxLine&&(s=!0),o.collapsed&&a!=n.line&&nt(e,0),t=e,r=new Dt(o,a==n.line?n.ch:null,a==i.line?i.ch:null),t.markedSpans=t.markedSpans?t.markedSpans.concat([r]):[r],r.marker.attachLine(t),++a}),o.collapsed&&t.iter(n.line,i.line+1,function(e){$t(t,e)&&nt(e,0)}),o.clearOnEnter&&we(o,"beforeCursorEnter",function(){return o.clear()}),o.readOnly&&(Ot=!0,(t.history.done.length||t.history.undone.length)&&t.clearHistory()),o.collapsed&&(o.id=++No,o.atomic=!0),u){if(s&&(u.curOp.updateMaxLine=!0),o.collapsed)vn(u,n.line,i.line+1);else if(o.className||o.startStyle||o.endStyle||o.css||o.attributes||o.title)for(var c=n.line;c<=i.line;c++)mn(u,c,"text");o.atomic&&lo(u.doc),gr(u,"markerAdded",u,o)}return o}Oo.prototype.clear=function(){if(!this.explicitlyCleared){var e=this.doc.cm,t=e&&!e.curOp;if(t&&Zn(e),Te(this,"clear")){var r=this.find();r&&gr(this,"clear",r.from,r.to)}for(var n=null,i=null,o=0;o<this.lines.length;++o){var l=this.lines[o],s=Wt(l.markedSpans,this);e&&!this.collapsed?mn(e,it(l),"text"):e&&(null!=s.to&&(i=it(l)),null!=s.from&&(n=it(l))),l.markedSpans=Ht(l.markedSpans,s),null==s.from&&this.collapsed&&!$t(this.doc,l)&&e&&nt(l,an(e.display))}if(e&&this.collapsed&&!e.options.lineWrapping)for(var a=0;a<this.lines.length;++a){var u=Xt(this.lines[a]),c=Qt(u);c>e.display.maxLineLength&&(e.display.maxLine=u,e.display.maxLineLength=c,e.display.maxLineChanged=!0)}null!=n&&e&&this.collapsed&&vn(e,n,i+1),this.lines.length=0,this.explicitlyCleared=!0,this.atomic&&this.doc.cantEdit&&(this.doc.cantEdit=!1,e&&lo(e.doc)),e&&gr(e,"markerCleared",e,this,n,i),t&&Qn(e),this.parent&&this.parent.clear()}},Oo.prototype.find=function(e,t){var r,n;null==e&&"bookmark"==this.type&&(e=1);for(var i=0;i<this.lines.length;++i){var o=this.lines[i],l=Wt(o.markedSpans,this);if(null!=l.from&&(r=at(t?o:it(o),l.from),-1==e))return r;if(null!=l.to&&(n=at(t?o:it(o),l.to),1==e))return n}return r&&{from:r,to:n}},Oo.prototype.changed=function(){var o=this,l=this.find(-1,!0),s=this,a=this.doc.cm;l&&a&&ni(a,function(){var e=l.line,t=it(l.line),r=Ir(a,t);if(r&&(Kr(r),a.curOp.selectionChanged=a.curOp.forceUpdate=!0),a.curOp.updateMaxLine=!0,!$t(s.doc,e)&&null!=s.height){var n=s.height;s.height=null;var i=Mr(s)-n;i&&nt(e,e.height+i)}gr(a,"markerChanged",a,o)})},Oo.prototype.attachLine=function(e){if(!this.lines.length&&this.doc.cm){var t=this.doc.cm.curOp;t.maybeHiddenMarkers&&-1!=B(t.maybeHiddenMarkers,this)||(t.maybeUnhiddenMarkers||(t.maybeUnhiddenMarkers=[])).push(this)}this.lines.push(e)},Oo.prototype.detachLine=function(e){if(this.lines.splice(B(this.lines,e),1),!this.lines.length&&this.doc.cm){var t=this.doc.cm.curOp;(t.maybeHiddenMarkers||(t.maybeHiddenMarkers=[])).push(this)}},Me(Oo);var Do=function(e,t){this.markers=e,this.primary=t;for(var r=0;r<e.length;++r)e[r].parent=this};function Wo(e){return e.findMarks(at(e.first,0),e.clipPos(at(e.lastLine())),function(e){return e.parent})}function Ho(o){for(var e=function(e){var t=o[e],r=[t.primary.doc];zi(t.primary.doc,function(e){return r.push(e)});for(var n=0;n<t.markers.length;n++){var i=t.markers[n];-1==B(r,i.doc)&&(i.parent=null,t.markers.splice(n--,1))}},t=0;t<o.length;t++)e(t)}Do.prototype.clear=function(){if(!this.explicitlyCleared){this.explicitlyCleared=!0;for(var e=0;e<this.markers.length;++e)this.markers[e].clear();gr(this,"clear")}},Do.prototype.find=function(e,t){return this.primary.find(e,t)},Me(Do);var Fo=0,Po=function(e,t,r,n,i){if(!(this instanceof Po))return new Po(e,t,r,n,i);null==r&&(r=0),ko.call(this,[new Lo([new er("",null)])]),this.first=r,this.scrollTop=this.scrollLeft=0,this.cantEdit=!1,this.cleanGeneration=1,this.modeFrontier=this.highlightFrontier=r;var o=at(r,0);this.sel=Oi(o),this.history=new Gi(null),this.id=++Fo,this.modeOption=t,this.lineSep=n,this.direction="rtl"==i?"rtl":"ltr",this.extend=!1,"string"==typeof e&&(e=this.splitLines(e)),Ii(this,{from:o,to:o,text:e}),no(this,Oi(o),V)};Po.prototype=Q(ko.prototype,{constructor:Po,iter:function(e,t,r){r?this.iterN(e-this.first,t-e,r):this.iterN(this.first,this.first+this.size,e)},insert:function(e,t){for(var r=0,n=0;n<t.length;++n)r+=t[n].height;this.insertInner(e-this.first,t,r)},remove:function(e,t){this.removeInner(e-this.first,t)},getValue:function(e){var t=rt(this,this.first,this.first+this.size);return!1===e?t:t.join(e||this.lineSeparator())},setValue:li(function(e){var t=at(this.first,0),r=this.first+this.size-1;po(this,{from:t,to:at(r,et(this,r).text.length),text:this.splitLines(e),origin:"setValue",full:!0},!0),this.cm&&In(this.cm,0,0),no(this,Oi(t),V)}),replaceRange:function(e,t,r,n){bo(this,e,t=gt(this,t),r=r?gt(this,r):t,n)},getRange:function(e,t,r){var n=tt(this,gt(this,e),gt(this,t));return!1===r?n:n.join(r||this.lineSeparator())},getLine:function(e){var t=this.getLineHandle(e);return t&&t.text},getLineHandle:function(e){if(lt(this,e))return et(this,e)},getLineNumber:function(e){return it(e)},getLineHandleVisualStart:function(e){return"number"==typeof e&&(e=et(this,e)),Xt(e)},lineCount:function(){return this.size},firstLine:function(){return this.first},lastLine:function(){return this.first+this.size-1},clipPos:function(e){return gt(this,e)},getCursor:function(e){var t=this.sel.primary();return null==e||"head"==e?t.head:"anchor"==e?t.anchor:"end"==e||"to"==e||!1===e?t.to():t.from()},listSelections:function(){return this.sel.ranges},somethingSelected:function(){return this.sel.somethingSelected()},setCursor:li(function(e,t,r){to(this,gt(this,"number"==typeof e?at(e,t||0):e),null,r)}),setSelection:li(function(e,t,r){to(this,gt(this,e),gt(this,t||e),r)}),extendSelection:li(function(e,t,r){Qi(this,gt(this,e),t&&gt(this,t),r)}),extendSelections:li(function(e,t){Ji(this,vt(this,e),t)}),extendSelectionsBy:li(function(e,t){Ji(this,vt(this,q(this.sel.ranges,e)),t)}),setSelections:li(function(e,t,r){if(e.length){for(var n=[],i=0;i<e.length;i++)n[i]=new Mi(gt(this,e[i].anchor),gt(this,e[i].head));null==t&&(t=Math.min(e.length-1,this.sel.primIndex)),no(this,Ni(this.cm,n,t),r)}}),addSelection:li(function(e,t,r){var n=this.sel.ranges.slice(0);n.push(new Mi(gt(this,e),gt(this,t||e))),no(this,Ni(this.cm,n,n.length-1),r)}),getSelection:function(e){for(var t,r=this.sel.ranges,n=0;n<r.length;n++){var i=tt(this,r[n].from(),r[n].to());t=t?t.concat(i):i}return!1===e?t:t.join(e||this.lineSeparator())},getSelections:function(e){for(var t=[],r=this.sel.ranges,n=0;n<r.length;n++){var i=tt(this,r[n].from(),r[n].to());!1!==e&&(i=i.join(e||this.lineSeparator())),t[n]=i}return t},replaceSelection:function(e,t,r){for(var n=[],i=0;i<this.sel.ranges.length;i++)n[i]=e;this.replaceSelections(n,t,r||"+input")},replaceSelections:li(function(e,t,r){for(var n=[],i=this.sel,o=0;o<i.ranges.length;o++){var l=i.ranges[o];n[o]={from:l.from(),to:l.to(),text:this.splitLines(e[o]),origin:r}}for(var s=t&&"end"!=t&&function(e,t,r){for(var n=[],i=at(e.first,0),o=i,l=0;l<t.length;l++){var s=t[l],a=Hi(s.from,i,o),u=Hi(Ai(s),i,o);if(i=s.to,o=u,"around"==r){var c=e.sel.ranges[l],h=ut(c.head,c.anchor)<0;n[l]=new Mi(h?u:a,h?a:u)}else n[l]=new Mi(a,a)}return new Ti(n,e.sel.primIndex)}(this,n,t),a=n.length-1;0<=a;a--)po(this,n[a]);s?ro(this,s):this.cm&&En(this.cm)}),undo:li(function(){vo(this,"undo")}),redo:li(function(){vo(this,"redo")}),undoSelection:li(function(){vo(this,"undo",!0)}),redoSelection:li(function(){vo(this,"redo",!0)}),setExtending:function(e){this.extend=e},getExtending:function(){return this.extend},historySize:function(){for(var e=this.history,t=0,r=0,n=0;n<e.done.length;n++)e.done[n].ranges||++t;for(var i=0;i<e.undone.length;i++)e.undone[i].ranges||++r;return{undo:t,redo:r}},clearHistory:function(){var t=this;this.history=new Gi(this.history.maxGeneration),zi(this,function(e){return e.history=t.history},!0)},markClean:function(){this.cleanGeneration=this.changeGeneration(!0)},changeGeneration:function(e){return e&&(this.history.lastOp=this.history.lastSelOp=this.history.lastOrigin=null),this.history.generation},isClean:function(e){return this.history.generation==(e||this.cleanGeneration)},getHistory:function(){return{done:qi(this.history.done),undone:qi(this.history.undone)}},setHistory:function(e){var t=this.history=new Gi(this.history.maxGeneration);t.done=qi(e.done.slice(0),null,!0),t.undone=qi(e.undone.slice(0),null,!0)},setGutterMarker:li(function(e,r,n){return So(this,e,"gutter",function(e){var t=e.gutterMarkers||(e.gutterMarkers={});return!(t[r]=n)&&re(t)&&(e.gutterMarkers=null),1})}),clearGutter:li(function(t){var r=this;this.iter(function(e){e.gutterMarkers&&e.gutterMarkers[t]&&So(r,e,"gutter",function(){return e.gutterMarkers[t]=null,re(e.gutterMarkers)&&(e.gutterMarkers=null),1})})}),lineInfo:function(e){var t;if("number"==typeof e){if(!lt(this,e))return null;if(!(e=et(this,t=e)))return null}else if(null==(t=it(e)))return null;return{line:t,handle:e,text:e.text,gutterMarkers:e.gutterMarkers,textClass:e.textClass,bgClass:e.bgClass,wrapClass:e.wrapClass,widgets:e.widgets}},addLineClass:li(function(e,r,n){return So(this,e,"gutter"==r?"gutter":"class",function(e){var t="text"==r?"textClass":"background"==r?"bgClass":"gutter"==r?"gutterClass":"wrapClass";if(e[t]){if(L(n).test(e[t]))return;e[t]+=" "+n}else e[t]=n;return 1})}),removeLineClass:li(function(e,o,l){return So(this,e,"gutter"==o?"gutter":"class",function(e){var t="text"==o?"textClass":"background"==o?"bgClass":"gutter"==o?"gutterClass":"wrapClass",r=e[t];if(r){if(null==l)e[t]=null;else{var n=r.match(L(l));if(!n)return;var i=n.index+n[0].length;e[t]=r.slice(0,n.index)+(n.index&&i!=r.length?" ":"")+r.slice(i)||null}return 1}})}),addLineWidget:li(function(e,t,r){return i=e,o=new To(n=this,t,r),(l=n.cm)&&o.noHScroll&&(l.display.alignWidgets=!0),So(n,i,"widget",function(e){var t=e.widgets||(e.widgets=[]);if(null==o.insertAt?t.push(o):t.splice(Math.min(t.length-1,Math.max(0,o.insertAt)),0,o),o.line=e,l&&!$t(n,e)){var r=Zt(e)<n.scrollTop;nt(e,e.height+Mr(o)),r&&Pn(l,o.height),l.curOp.forceUpdate=!0}return 1}),l&&gr(l,"lineWidgetAdded",l,o,"number"==typeof i?i:it(i)),o;var n,i,o,l}),removeLineWidget:function(e){e.clear()},markText:function(e,t,r){return Ao(this,gt(this,e),gt(this,t),r,r&&r.type||"range")},setBookmark:function(e,t){var r={replacedWith:t&&(null==t.nodeType?t.widget:t),insertLeft:t&&t.insertLeft,clearWhenEmpty:!1,shared:t&&t.shared,handleMouseEvents:t&&t.handleMouseEvents};return Ao(this,e=gt(this,e),e,r,"bookmark")},findMarksAt:function(e){var t=[],r=et(this,(e=gt(this,e)).line).markedSpans;if(r)for(var n=0;n<r.length;++n){var i=r[n];(null==i.from||i.from<=e.ch)&&(null==i.to||i.to>=e.ch)&&t.push(i.marker.parent||i.marker)}return t},findMarks:function(i,o,l){i=gt(this,i),o=gt(this,o);var s=[],a=i.line;return this.iter(i.line,o.line+1,function(e){var t=e.markedSpans;if(t)for(var r=0;r<t.length;r++){var n=t[r];null!=n.to&&a==i.line&&i.ch>=n.to||null==n.from&&a!=i.line||null!=n.from&&a==o.line&&n.from>=o.ch||l&&!l(n.marker)||s.push(n.marker.parent||n.marker)}++a}),s},getAllMarks:function(){var n=[];return this.iter(function(e){var t=e.markedSpans;if(t)for(var r=0;r<t.length;++r)null!=t[r].from&&n.push(t[r].marker)}),n},posFromIndex:function(r){var n,i=this.first,o=this.lineSeparator().length;return this.iter(function(e){var t=e.text.length+o;if(r<t)return n=r,!0;r-=t,++i}),gt(this,at(i,n))},indexFromPos:function(e){var t=(e=gt(this,e)).ch;if(e.line<this.first||e.ch<0)return 0;var r=this.lineSeparator().length;return this.iter(this.first,e.line,function(e){t+=e.text.length+r}),t},copy:function(e){var t=new Po(rt(this,this.first,this.first+this.size),this.modeOption,this.first,this.lineSep,this.direction);return t.scrollTop=this.scrollTop,t.scrollLeft=this.scrollLeft,t.sel=this.sel,t.extend=!1,e&&(t.history.undoDepth=this.history.undoDepth,t.setHistory(this.getHistory())),t},linkedDoc:function(e){e=e||{};var t=this.first,r=this.first+this.size;null!=e.from&&e.from>t&&(t=e.from),null!=e.to&&e.to<r&&(r=e.to);var n=new Po(rt(this,t,r),e.mode||this.modeOption,t,this.lineSep,this.direction);return e.sharedHist&&(n.history=this.history),(this.linked||(this.linked=[])).push({doc:n,sharedHist:e.sharedHist}),n.linked=[{doc:this,isParent:!0,sharedHist:e.sharedHist}],function(e,t){for(var r=0;r<t.length;r++){var n=t[r],i=n.find(),o=e.clipPos(i.from),l=e.clipPos(i.to);if(ut(o,l)){var s=Ao(e,o,l,n.primary,n.primary.type);n.markers.push(s),s.parent=n}}}(n,Wo(this)),n},unlinkDoc:function(e){if(e instanceof Wl&&(e=e.doc),this.linked)for(var t=0;t<this.linked.length;++t){if(this.linked[t].doc==e){this.linked.splice(t,1),e.unlinkDoc(this),Ho(Wo(this));break}}if(e.history==this.history){var r=[e.id];zi(e,function(e){return r.push(e.id)},!0),e.history=new Gi(null),e.history.done=qi(this.history.done,r),e.history.undone=qi(this.history.undone,r)}},iterLinkedDocs:function(e){zi(this,e)},getMode:function(){return this.mode},getEditor:function(){return this.cm},splitLines:function(e){return this.lineSep?e.split(this.lineSep):Be(e)},lineSeparator:function(){return this.lineSep||"\n"},setDirection:li(function(e){var t;"rtl"!=e&&(e="ltr"),e!=this.direction&&(this.direction=e,this.iter(function(e){return e.order=null}),this.cm&&ni(t=this.cm,function(){Bi(t),vn(t)}))})}),Po.prototype.eachLine=Po.prototype.iter;var Eo=0;function Io(e){var n=this;if(zo(n),!Le(n,e)&&!Nr(n.display,e)){Ne(e),x&&(Eo=+new Date);var t=pn(n,e,!0),r=e.dataTransfer.files;if(t&&!n.isReadOnly())if(r&&r.length&&window.FileReader&&window.File)for(var i=r.length,o=Array(i),l=0,s=function(){++l==i&&ii(n,function(){var e={from:t=gt(n.doc,t),to:t,text:n.doc.splitLines(o.filter(function(e){return null!=e}).join(n.doc.lineSeparator())),origin:"paste"};po(n.doc,e),ro(n.doc,Oi(gt(n.doc,t),gt(n.doc,Ai(e))))})()},a=function(e,t){if(n.options.allowDropFileTypes&&-1==B(n.options.allowDropFileTypes,e.type))s();else{var r=new FileReader;r.onerror=function(){return s()},r.onload=function(){var e=r.result;/[\x00-\x08\x0e-\x1f]{2}/.test(e)||(o[t]=e),s()},r.readAsText(e)}},u=0;u<r.length;u++)a(r[u],u);else{if(n.state.draggingText&&-1<n.doc.sel.contains(t))return n.state.draggingText(e),void setTimeout(function(){return n.display.input.focus()},20);try{var c=e.dataTransfer.getData("Text");if(c){var h;if(n.state.draggingText&&!n.state.draggingText.copy&&(h=n.listSelections()),io(n.doc,Oi(t,t)),h)for(var f=0;f<h.length;++f)bo(n.doc,"",h[f].anchor,h[f].head,"drag");n.replaceSelection(c,"around","paste"),n.display.input.focus()}}catch(e){}}}}function zo(e){e.display.dragCursor&&(e.display.lineSpace.removeChild(e.display.dragCursor),e.display.dragCursor=null)}function Ro(t){if(document.getElementsByClassName){for(var e=document.getElementsByClassName("CodeMirror"),r=[],n=0;n<e.length;n++){var i=e[n].CodeMirror;i&&r.push(i)}r.length&&r[0].operation(function(){for(var e=0;e<r.length;e++)t(r[e])})}}var Bo=!1;function Go(){var e;Bo||(we(window,"resize",function(){null==e&&(e=setTimeout(function(){e=null,Ro(Uo)},100))}),we(window,"blur",function(){return Ro(An)}),Bo=!0)}function Uo(e){var t=e.display;t.cachedCharWidth=t.cachedTextHeight=t.cachedPaddingH=null,t.scrollbarsClipped=!1,e.setSize()}for(var Vo={3:"Pause",8:"Backspace",9:"Tab",13:"Enter",16:"Shift",17:"Ctrl",18:"Alt",19:"Pause",20:"CapsLock",27:"Esc",32:"Space",33:"PageUp",34:"PageDown",35:"End",36:"Home",37:"Left",38:"Up",39:"Right",40:"Down",44:"PrintScrn",45:"Insert",46:"Delete",59:";",61:"=",91:"Mod",92:"Mod",93:"Mod",106:"*",107:"=",109:"-",110:".",111:"/",145:"ScrollLock",173:"-",186:";",187:"=",188:",",189:"-",190:".",191:"/",192:"`",219:"[",220:"\\",221:"]",222:"'",63232:"Up",63233:"Down",63234:"Left",63235:"Right",63272:"Delete",63273:"Home",63275:"End",63276:"PageUp",63277:"PageDown",63302:"Insert"},Ko=0;Ko<10;Ko++)Vo[Ko+48]=Vo[Ko+96]=String(Ko);for(var jo=65;jo<=90;jo++)Vo[jo]=String.fromCharCode(jo);for(var Xo=1;Xo<=12;Xo++)Vo[Xo+111]=Vo[Xo+63235]="F"+Xo;var Yo={};function _o(e){var t,r,n,i,o=e.split(/-(?!$)/);e=o[o.length-1];for(var l=0;l<o.length-1;l++){var s=o[l];if(/^(cmd|meta|m)$/i.test(s))i=!0;else if(/^a(lt)?$/i.test(s))t=!0;else if(/^(c|ctrl|control)$/i.test(s))r=!0;else{if(!/^s(hift)?$/i.test(s))throw new Error("Unrecognized modifier name: "+s);n=!0}}return t&&(e="Alt-"+e),r&&(e="Ctrl-"+e),i&&(e="Cmd-"+e),n&&(e="Shift-"+e),e}function $o(e){var t={};for(var r in e)if(e.hasOwnProperty(r)){var n=e[r];if(/^(name|fallthrough|(de|at)tach)$/.test(r))continue;if("..."==n){delete e[r];continue}for(var i=q(r.split(" "),_o),o=0;o<i.length;o++){var l=void 0,s=void 0;l=o==i.length-1?(s=i.join(" "),n):(s=i.slice(0,o+1).join(" "),"...");var a=t[s];if(a){if(a!=l)throw new Error("Inconsistent bindings for "+s)}else t[s]=l}delete e[r]}for(var u in t)e[u]=t[u];return e}function qo(e,t,r,n){var i=(t=el(t)).call?t.call(e,n):t[e];if(!1===i)return"nothing";if("..."===i)return"multi";if(null!=i&&r(i))return"handled";if(t.fallthrough){if("[object Array]"!=Object.prototype.toString.call(t.fallthrough))return qo(e,t.fallthrough,r,n);for(var o=0;o<t.fallthrough.length;o++){var l=qo(e,t.fallthrough[o],r,n);if(l)return l}}}function Zo(e){var t="string"==typeof e?e:Vo[e.keyCode];return"Ctrl"==t||"Alt"==t||"Shift"==t||"Mod"==t}function Qo(e,t,r){var n=e;return t.altKey&&"Alt"!=n&&(e="Alt-"+e),(y?t.metaKey:t.ctrlKey)&&"Ctrl"!=n&&(e="Ctrl-"+e),(y?t.ctrlKey:t.metaKey)&&"Cmd"!=n&&(e="Cmd-"+e),!r&&t.shiftKey&&"Shift"!=n&&(e="Shift-"+e),e}function Jo(e,t){if(v&&34==e.keyCode&&e.char)return!1;var r=Vo[e.keyCode];return null!=r&&!e.altGraphKey&&(3==e.keyCode&&e.code&&(r=e.code),Qo(r,e,t))}function el(e){return"string"==typeof e?Yo[e]:e}function tl(t,e){for(var r=t.doc.sel.ranges,n=[],i=0;i<r.length;i++){for(var o=e(r[i]);n.length&&ut(o.from,$(n).to)<=0;){var l=n.pop();if(ut(l.from,o.from)<0){o.from=l.from;break}}n.push(o)}ni(t,function(){for(var e=n.length-1;0<=e;e--)bo(t.doc,"",n[e].from,n[e].to,"+delete");En(t)})}function rl(e,t,r){var n=oe(e.text,t+r,r);return n<0||n>e.text.length?null:n}function nl(e,t,r){var n=rl(e,t.ch,r);return null==n?null:new at(t.line,n,r<0?"after":"before")}function il(e,t,r,n,i){if(e){"rtl"==t.doc.direction&&(i=-i);var o=ye(r,t.doc.direction);if(o){var l,s=i<0?$(o):o[0],a=i<0==(1==s.level)?"after":"before";if(0<s.level||"rtl"==t.doc.direction){var u=zr(t,r);l=i<0?r.text.length-1:0;var c=Rr(t,u,l).top;l=le(function(e){return Rr(t,u,e).top==c},i<0==(1==s.level)?s.from:s.to-1,l),"before"==a&&(l=rl(r,l,1))}else l=i<0?s.to:s.from;return new at(n,l,a)}}return new at(n,i<0?r.text.length:0,i<0?"before":"after")}function ol(t,r,s,e){var a=ye(r,t.doc.direction);if(!a)return nl(r,s,e);s.ch>=r.text.length?(s.ch=r.text.length,s.sticky="before"):s.ch<=0&&(s.ch=0,s.sticky="after");var n=ae(a,s.ch,s.sticky),i=a[n];if("ltr"==t.doc.direction&&i.level%2==0&&(0<e?i.to>s.ch:i.from<s.ch))return nl(r,s,e);function u(e,t){return rl(r,e instanceof at?e.ch:e,t)}function o(e){return t.options.lineWrapping?(l=l||zr(t,r),on(t,r,l,e)):{begin:0,end:r.text.length}}var l,c=o("before"==s.sticky?u(s,-1):s.ch);if("rtl"==t.doc.direction||1==i.level){var h=1==i.level==e<0,f=u(s,h?1:-1);if(null!=f&&(h?f<=i.to&&f<=c.end:f>=i.from&&f>=c.begin)){var d=h?"before":"after";return new at(s.line,f,d)}}function p(e,t,r){for(var n=function(e,t){return t?new at(s.line,u(e,1),"before"):new at(s.line,e,"after")};0<=e&&e<a.length;e+=t){var i=a[e],o=0<t==(1!=i.level),l=o?r.begin:u(r.end,-1);if(i.from<=l&&l<i.to)return n(l,o);if(l=o?i.from:u(i.to,-1),r.begin<=l&&l<r.end)return n(l,o)}}var g=p(n+e,e,c);if(g)return g;var v=0<e?c.end:u(c.begin,-1);return null==v||0<e&&v==r.text.length||!(g=p(0<e?0:a.length-1,e,o(v)))?null:g}Yo.basic={Left:"goCharLeft",Right:"goCharRight",Up:"goLineUp",Down:"goLineDown",End:"goLineEnd",Home:"goLineStartSmart",PageUp:"goPageUp",PageDown:"goPageDown",Delete:"delCharAfter",Backspace:"delCharBefore","Shift-Backspace":"delCharBefore",Tab:"defaultTab","Shift-Tab":"indentAuto",Enter:"newlineAndIndent",Insert:"toggleOverwrite",Esc:"singleSelection"},Yo.pcDefault={"Ctrl-A":"selectAll","Ctrl-D":"deleteLine","Ctrl-Z":"undo","Shift-Ctrl-Z":"redo","Ctrl-Y":"redo","Ctrl-Home":"goDocStart","Ctrl-End":"goDocEnd","Ctrl-Up":"goLineUp","Ctrl-Down":"goLineDown","Ctrl-Left":"goGroupLeft","Ctrl-Right":"goGroupRight","Alt-Left":"goLineStart","Alt-Right":"goLineEnd","Ctrl-Backspace":"delGroupBefore","Ctrl-Delete":"delGroupAfter","Ctrl-S":"save","Ctrl-F":"find","Ctrl-G":"findNext","Shift-Ctrl-G":"findPrev","Shift-Ctrl-F":"replace","Shift-Ctrl-R":"replaceAll","Ctrl-[":"indentLess","Ctrl-]":"indentMore","Ctrl-U":"undoSelection","Shift-Ctrl-U":"redoSelection","Alt-U":"redoSelection",fallthrough:"basic"},Yo.emacsy={"Ctrl-F":"goCharRight","Ctrl-B":"goCharLeft","Ctrl-P":"goLineUp","Ctrl-N":"goLineDown","Alt-F":"goWordRight","Alt-B":"goWordLeft","Ctrl-A":"goLineStart","Ctrl-E":"goLineEnd","Ctrl-V":"goPageDown","Shift-Ctrl-V":"goPageUp","Ctrl-D":"delCharAfter","Ctrl-H":"delCharBefore","Alt-D":"delWordAfter","Alt-Backspace":"delWordBefore","Ctrl-K":"killLine","Ctrl-T":"transposeChars","Ctrl-O":"openLine"},Yo.macDefault={"Cmd-A":"selectAll","Cmd-D":"deleteLine","Cmd-Z":"undo","Shift-Cmd-Z":"redo","Cmd-Y":"redo","Cmd-Home":"goDocStart","Cmd-Up":"goDocStart","Cmd-End":"goDocEnd","Cmd-Down":"goDocEnd","Alt-Left":"goGroupLeft","Alt-Right":"goGroupRight","Cmd-Left":"goLineLeft","Cmd-Right":"goLineRight","Alt-Backspace":"delGroupBefore","Ctrl-Alt-Backspace":"delGroupAfter","Alt-Delete":"delGroupAfter","Cmd-S":"save","Cmd-F":"find","Cmd-G":"findNext","Shift-Cmd-G":"findPrev","Cmd-Alt-F":"replace","Shift-Cmd-Alt-F":"replaceAll","Cmd-[":"indentLess","Cmd-]":"indentMore","Cmd-Backspace":"delWrappedLineLeft","Cmd-Delete":"delWrappedLineRight","Cmd-U":"undoSelection","Shift-Cmd-U":"redoSelection","Ctrl-Up":"goDocStart","Ctrl-Down":"goDocEnd",fallthrough:["basic","emacsy"]},Yo.default=w?Yo.macDefault:Yo.pcDefault;var ll={selectAll:ho,singleSelection:function(e){return e.setSelection(e.getCursor("anchor"),e.getCursor("head"),V)},killLine:function(r){return tl(r,function(e){if(e.empty()){var t=et(r.doc,e.head.line).text.length;return e.head.ch==t&&e.head.line<r.lastLine()?{from:e.head,to:at(e.head.line+1,0)}:{from:e.head,to:at(e.head.line,t)}}return{from:e.from(),to:e.to()}})},deleteLine:function(t){return tl(t,function(e){return{from:at(e.from().line,0),to:gt(t.doc,at(e.to().line+1,0))}})},delLineLeft:function(e){return tl(e,function(e){return{from:at(e.from().line,0),to:e.from()}})},delWrappedLineLeft:function(r){return tl(r,function(e){var t=r.charCoords(e.head,"div").top+5;return{from:r.coordsChar({left:0,top:t},"div"),to:e.from()}})},delWrappedLineRight:function(n){return tl(n,function(e){var t=n.charCoords(e.head,"div").top+5,r=n.coordsChar({left:n.display.lineDiv.offsetWidth+100,top:t},"div");return{from:e.from(),to:r}})},undo:function(e){return e.undo()},redo:function(e){return e.redo()},undoSelection:function(e){return e.undoSelection()},redoSelection:function(e){return e.redoSelection()},goDocStart:function(e){return e.extendSelection(at(e.firstLine(),0))},goDocEnd:function(e){return e.extendSelection(at(e.lastLine()))},goLineStart:function(t){return t.extendSelectionsBy(function(e){return sl(t,e.head.line)},{origin:"+move",bias:1})},goLineStartSmart:function(t){return t.extendSelectionsBy(function(e){return al(t,e.head)},{origin:"+move",bias:1})},goLineEnd:function(t){return t.extendSelectionsBy(function(e){return function(e,t){var r=et(e.doc,t),n=function(e){for(var t;t=Vt(e);)e=t.find(1,!0).line;return e}(r);n!=r&&(t=it(n));return il(!0,e,r,t,-1)}(t,e.head.line)},{origin:"+move",bias:-1})},goLineRight:function(r){return r.extendSelectionsBy(function(e){var t=r.cursorCoords(e.head,"div").top+5;return r.coordsChar({left:r.display.lineDiv.offsetWidth+100,top:t},"div")},j)},goLineLeft:function(r){return r.extendSelectionsBy(function(e){var t=r.cursorCoords(e.head,"div").top+5;return r.coordsChar({left:0,top:t},"div")},j)},goLineLeftSmart:function(n){return n.extendSelectionsBy(function(e){var t=n.cursorCoords(e.head,"div").top+5,r=n.coordsChar({left:0,top:t},"div");return r.ch<n.getLine(r.line).search(/\S/)?al(n,e.head):r},j)},goLineUp:function(e){return e.moveV(-1,"line")},goLineDown:function(e){return e.moveV(1,"line")},goPageUp:function(e){return e.moveV(-1,"page")},goPageDown:function(e){return e.moveV(1,"page")},goCharLeft:function(e){return e.moveH(-1,"char")},goCharRight:function(e){return e.moveH(1,"char")},goColumnLeft:function(e){return e.moveH(-1,"column")},goColumnRight:function(e){return e.moveH(1,"column")},goWordLeft:function(e){return e.moveH(-1,"word")},goGroupRight:function(e){return e.moveH(1,"group")},goGroupLeft:function(e){return e.moveH(-1,"group")},goWordRight:function(e){return e.moveH(1,"word")},delCharBefore:function(e){return e.deleteH(-1,"char")},delCharAfter:function(e){return e.deleteH(1,"char")},delWordBefore:function(e){return e.deleteH(-1,"word")},delWordAfter:function(e){return e.deleteH(1,"word")},delGroupBefore:function(e){return e.deleteH(-1,"group")},delGroupAfter:function(e){return e.deleteH(1,"group")},indentAuto:function(e){return e.indentSelection("smart")},indentMore:function(e){return e.indentSelection("add")},indentLess:function(e){return e.indentSelection("subtract")},insertTab:function(e){return e.replaceSelection("\t")},insertSoftTab:function(e){for(var t=[],r=e.listSelections(),n=e.options.tabSize,i=0;i<r.length;i++){var o=r[i].from(),l=z(e.getLine(o.line),o.ch,n);t.push(_(n-l%n))}e.replaceSelections(t)},defaultTab:function(e){e.somethingSelected()?e.indentSelection("add"):e.execCommand("insertTab")},transposeChars:function(l){return ni(l,function(){for(var e=l.listSelections(),t=[],r=0;r<e.length;r++)if(e[r].empty()){var n=e[r].head,i=et(l.doc,n.line).text;if(i)if(n.ch==i.length&&(n=new at(n.line,n.ch-1)),0<n.ch)n=new at(n.line,n.ch+1),l.replaceRange(i.charAt(n.ch-1)+i.charAt(n.ch-2),at(n.line,n.ch-2),n,"+transpose");else if(n.line>l.doc.first){var o=et(l.doc,n.line-1).text;o&&(n=new at(n.line,1),l.replaceRange(i.charAt(0)+l.doc.lineSeparator()+o.charAt(o.length-1),at(n.line-1,o.length-1),n,"+transpose"))}t.push(new Mi(n,n))}l.setSelections(t)})},newlineAndIndent:function(n){return ni(n,function(){for(var e=n.listSelections(),t=e.length-1;0<=t;t--)n.replaceRange(n.doc.lineSeparator(),e[t].anchor,e[t].head,"+input");e=n.listSelections();for(var r=0;r<e.length;r++)n.indentLine(e[r].from().line,null,!0);En(n)})},openLine:function(e){return e.replaceSelection("\n","start")},toggleOverwrite:function(e){return e.toggleOverwrite()}};function sl(e,t){var r=et(e.doc,t),n=Xt(r);return n!=r&&(t=it(n)),il(!0,e,n,t,1)}function al(e,t){var r=sl(e,t.line),n=et(e.doc,r.line),i=ye(n,e.doc.direction);if(i&&0!=i[0].level)return r;var o=Math.max(r.ch,n.text.search(/\S/)),l=t.line==r.line&&t.ch<=o&&t.ch;return at(r.line,l?0:o,r.sticky)}function ul(e,t,r){if("string"==typeof t&&!(t=ll[t]))return!1;e.display.input.ensurePolled();var n=e.display.shift,i=!1;try{e.isReadOnly()&&(e.state.suppressEdits=!0),r&&(e.display.shift=!1),i=t(e)!=U}finally{e.display.shift=n,e.state.suppressEdits=!1}return i}var cl=new R;function hl(e,t,r,n){var i=e.state.keySeq;if(i){if(Zo(t))return"handled";if(/\'$/.test(t)?e.state.keySeq=null:cl.set(50,function(){e.state.keySeq==i&&(e.state.keySeq=null,e.display.input.reset())}),fl(e,i+" "+t,r,n))return!0}return fl(e,t,r,n)}function fl(e,t,r,n){var i=function(e,t,r){for(var n=0;n<e.state.keyMaps.length;n++){var i=qo(t,e.state.keyMaps[n],r,e);if(i)return i}return e.options.extraKeys&&qo(t,e.options.extraKeys,r,e)||qo(t,e.options.keyMap,r,e)}(e,t,n);return"multi"==i&&(e.state.keySeq=t),"handled"==i&&gr(e,"keyHandled",e,t,r),"handled"!=i&&"multi"!=i||(Ne(r),Tn(e)),!!i}function dl(t,e){var r=Jo(e,!0);return!!r&&(e.shiftKey&&!t.state.keySeq?hl(t,"Shift-"+r,e,function(e){return ul(t,e,!0)})||hl(t,r,e,function(e){if("string"==typeof e?/^go[A-Z]/.test(e):e.motion)return ul(t,e)}):hl(t,r,e,function(e){return ul(t,e)}))}var pl=null;function gl(e){var t=this;if(t.curOp.focus=W(),!Le(t,e)){x&&C<11&&27==e.keyCode&&(e.returnValue=!1);var r=e.keyCode;t.display.shift=16==r||e.shiftKey;var n,i=dl(t,e);v&&(pl=i?r:null,!i&&88==r&&!Ue&&(w?e.metaKey:e.ctrlKey)&&t.replaceSelection("",null,"cut")),g&&!w&&!i&&46==r&&e.shiftKey&&!e.ctrlKey&&document.execCommand&&document.execCommand("cut"),18!=r||/\bCodeMirror-crosshair\b/.test(t.display.lineDiv.className)||(H(n=t.display.lineDiv,"CodeMirror-crosshair"),we(document,"keyup",o),we(document,"mouseover",o))}function o(e){18!=e.keyCode&&e.altKey||(T(n,"CodeMirror-crosshair"),Ce(document,"keyup",o),Ce(document,"mouseover",o))}}function vl(e){16==e.keyCode&&(this.doc.sel.shift=!1),Le(this,e)}function ml(e){var t=this;if(!(Nr(t.display,e)||Le(t,e)||e.ctrlKey&&!e.altKey||w&&e.metaKey)){var r=e.keyCode,n=e.charCode;if(v&&r==pl)return pl=null,void Ne(e);if(!v||e.which&&!(e.which<10)||!dl(t,e)){var i,o=String.fromCharCode(null==n?r:n);if("\b"!=o)if(!hl(i=t,"'"+o+"'",e,function(e){return ul(i,e,!0)}))t.display.input.onKeyPress(e)}}}var yl,bl,wl=function(e,t,r){this.time=e,this.pos=t,this.button=r};function xl(e){var t=this,r=t.display;if(!(Le(t,e)||r.activeTouch&&r.input.supportsTouch()))if(r.input.ensurePolled(),r.shift=e.shiftKey,Nr(r,e))b||(r.scroller.draggable=!1,setTimeout(function(){return r.scroller.draggable=!0},100));else if(!Ll(t,e)){var n,i,o,l=pn(t,e),s=He(e),a=l?(n=l,i=s,o=+new Date,bl&&bl.compare(o,n,i)?(yl=bl=null,"triple"):yl&&yl.compare(o,n,i)?(bl=new wl(o,n,i),yl=null,"double"):(yl=new wl(o,n,i),bl=null,"single")):"single";window.focus(),1==s&&t.state.selectingText&&t.state.selectingText(e),l&&function(r,e,n,t,i){var o="Click";"double"==t?o="Double"+o:"triple"==t&&(o="Triple"+o);return hl(r,Qo(o=(1==e?"Left":2==e?"Middle":"Right")+o,i),i,function(e){if("string"==typeof e&&(e=ll[e]),!e)return!1;var t=!1;try{r.isReadOnly()&&(r.state.suppressEdits=!0),t=e(r,n)!=U}finally{r.state.suppressEdits=!1}return t})}(t,s,l,a,e)||(1==s?l?function(e,t,r,n){x?setTimeout(E(Mn,e),0):e.curOp.focus=W();var i,o=function(e,t,r){var n=e.getOption("configureMouse"),i=n?n(e,t,r):{};if(null==i.unit){var o=d?r.shiftKey&&r.metaKey:r.altKey;i.unit=o?"rectangle":"single"==t?"char":"double"==t?"word":"line"}null!=i.extend&&!e.doc.extend||(i.extend=e.doc.extend||r.shiftKey);null==i.addNew&&(i.addNew=w?r.metaKey:r.ctrlKey);null==i.moveOnDrag&&(i.moveOnDrag=!(w?r.altKey:r.ctrlKey));return i}(e,r,n),l=e.doc.sel;(e.options.dragDrop&&Ee&&!e.isReadOnly()&&"single"==r&&-1<(i=l.contains(t))&&(ut((i=l.ranges[i]).from(),t)<0||0<t.xRel)&&(0<ut(i.to(),t)||t.xRel<0)?function(t,r,n,i){var o=t.display,l=!1,s=ii(t,function(e){b&&(o.scroller.draggable=!1),t.state.draggingText=!1,Ce(o.wrapper.ownerDocument,"mouseup",s),Ce(o.wrapper.ownerDocument,"mousemove",a),Ce(o.scroller,"dragstart",u),Ce(o.scroller,"drop",s),l||(Ne(e),i.addNew||Qi(t.doc,n,null,null,i.extend),b||x&&9==C?setTimeout(function(){o.wrapper.ownerDocument.body.focus(),o.input.focus()},20):o.input.focus())}),a=function(e){l=l||10<=Math.abs(r.clientX-e.clientX)+Math.abs(r.clientY-e.clientY)},u=function(){return l=!0};b&&(o.scroller.draggable=!0);(t.state.draggingText=s).copy=!i.moveOnDrag,o.scroller.dragDrop&&o.scroller.dragDrop();we(o.wrapper.ownerDocument,"mouseup",s),we(o.wrapper.ownerDocument,"mousemove",a),we(o.scroller,"dragstart",u),we(o.scroller,"drop",s),Nn(t),setTimeout(function(){return o.input.focus()},20)}:function(v,e,m,y){var l=v.display,b=v.doc;Ne(e);var w,x,C=b.sel,t=C.ranges;y.addNew&&!y.extend?(x=b.sel.contains(m),w=-1<x?t[x]:new Mi(m,m)):(w=b.sel.primary(),x=b.sel.primIndex);if("rectangle"==y.unit)y.addNew||(w=new Mi(m,m)),m=pn(v,e,!0,!0),x=-1;else{var r=Cl(v,m,y.unit);w=y.extend?Zi(w,r.anchor,r.head,y.extend):r}y.addNew?-1==x?(x=t.length,no(b,Ni(v,t.concat([w]),x),{scroll:!1,origin:"*mouse"})):1<t.length&&t[x].empty()&&"char"==y.unit&&!y.extend?(no(b,Ni(v,t.slice(0,x).concat(t.slice(x+1)),0),{scroll:!1,origin:"*mouse"}),C=b.sel):eo(b,x,w,K):(no(b,new Ti([w],x=0),K),C=b.sel);var S=m;function s(e){if(0!=ut(S,e))if(S=e,"rectangle"==y.unit){for(var t=[],r=v.options.tabSize,n=z(et(b,m.line).text,m.ch,r),i=z(et(b,e.line).text,e.ch,r),o=Math.min(n,i),l=Math.max(n,i),s=Math.min(m.line,e.line),a=Math.min(v.lastLine(),Math.max(m.line,e.line));s<=a;s++){var u=et(b,s).text,c=X(u,o,r);o==l?t.push(new Mi(at(s,c),at(s,c))):u.length>c&&t.push(new Mi(at(s,c),at(s,X(u,l,r))))}t.length||t.push(new Mi(m,m)),no(b,Ni(v,C.ranges.slice(0,x).concat(t),x),{origin:"*mouse",scroll:!1}),v.scrollIntoView(e)}else{var h,f=w,d=Cl(v,e,y.unit),p=f.anchor;p=0<ut(d.anchor,p)?(h=d.head,dt(f.from(),d.anchor)):(h=d.anchor,ft(f.to(),d.head));var g=C.ranges.slice(0);g[x]=function(e,t){var r=t.anchor,n=t.head,i=et(e.doc,r.line);if(0==ut(r,n)&&r.sticky==n.sticky)return t;var o=ye(i);if(!o)return t;var l=ae(o,r.ch,r.sticky),s=o[l];if(s.from!=r.ch&&s.to!=r.ch)return t;var a,u=l+(s.from==r.ch==(1!=s.level)?0:1);if(0==u||u==o.length)return t;if(n.line!=r.line)a=0<(n.line-r.line)*("ltr"==e.doc.direction?1:-1);else{var c=ae(o,n.ch,n.sticky),h=c-l||(n.ch-r.ch)*(1==s.level?-1:1);a=c==u-1||c==u?h<0:0<h}var f=o[u+(a?-1:0)],d=a==(1==f.level),p=d?f.from:f.to,g=d?"after":"before";return r.ch==p&&r.sticky==g?t:new Mi(new at(r.line,p,g),n)}(v,new Mi(gt(b,p),h)),no(b,Ni(v,g,x),K)}}var a=l.wrapper.getBoundingClientRect(),u=0;function n(e){v.state.selectingText=!1,u=1/0,e&&(Ne(e),l.input.focus()),Ce(l.wrapper.ownerDocument,"mousemove",i),Ce(l.wrapper.ownerDocument,"mouseup",o),b.history.lastSelOrigin=null}var i=ii(v,function(e){(0!==e.buttons&&He(e)?function e(t){var r=++u,n=pn(v,t,!0,"rectangle"==y.unit);if(n)if(0!=ut(n,S)){v.curOp.focus=W(),s(n);var i=Hn(l,b);(n.line>=i.to||n.line<i.from)&&setTimeout(ii(v,function(){u==r&&e(t)}),150)}else{var o=t.clientY<a.top?-20:t.clientY>a.bottom?20:0;o&&setTimeout(ii(v,function(){u==r&&(l.scroller.scrollTop+=o,e(t))}),50)}}:n)(e)}),o=ii(v,n);v.state.selectingText=o,we(l.wrapper.ownerDocument,"mousemove",i),we(l.wrapper.ownerDocument,"mouseup",o)})(e,n,t,o)}(t,l,a,e):We(e)==r.scroller&&Ne(e):2==s?(l&&Qi(t.doc,l),setTimeout(function(){return r.input.focus()},20)):3==s&&(S?t.display.input.onContextMenu(e):Nn(t)))}}function Cl(e,t,r){if("char"==r)return new Mi(t,t);if("word"==r)return e.findWordAt(t);if("line"==r)return new Mi(at(t.line,0),gt(e.doc,at(t.line+1,0)));var n=r(e,t);return new Mi(n.from,n.to)}function Sl(e,t,r,n){var i,o;if(t.touches)i=t.touches[0].clientX,o=t.touches[0].clientY;else try{i=t.clientX,o=t.clientY}catch(t){return!1}if(i>=Math.floor(e.display.gutters.getBoundingClientRect().right))return!1;n&&Ne(t);var l=e.display,s=l.lineDiv.getBoundingClientRect();if(o>s.bottom||!Te(e,r))return Ae(t);o-=s.top-l.viewOffset;for(var a=0;a<e.display.gutterSpecs.length;++a){var u=l.gutters.childNodes[a];if(u&&u.getBoundingClientRect().right>=i)return Se(e,r,e,ot(e.doc,o),e.display.gutterSpecs[a].className,t),Ae(t)}}function Ll(e,t){return Sl(e,t,"gutterClick",!0)}function kl(e,t){var r,n;Nr(e.display,t)||(n=t,Te(r=e,"gutterContextMenu")&&Sl(r,n,"gutterContextMenu",!1))||Le(e,t,"contextmenu")||S||e.display.input.onContextMenu(t)}function Tl(e){e.display.wrapper.className=e.display.wrapper.className.replace(/\s*cm-s-\S+/g,"")+e.options.theme.replace(/(^|\s)\s*/g," cm-s-"),Xr(e)}wl.prototype.compare=function(e,t,r){return this.time+400>e&&0==ut(t,this.pos)&&r==this.button};var Ml={toString:function(){return"CodeMirror.Init"}},Nl={},Ol={};function Al(e,t,r){if(!t!=!(r&&r!=Ml)){var n=e.display.dragFunctions,i=t?we:Ce;i(e.display.scroller,"dragstart",n.start),i(e.display.scroller,"dragenter",n.enter),i(e.display.scroller,"dragover",n.over),i(e.display.scroller,"dragleave",n.leave),i(e.display.scroller,"drop",n.drop)}}function Dl(e){e.options.lineWrapping?(H(e.display.wrapper,"CodeMirror-wrap"),e.display.sizer.style.minWidth="",e.display.sizerWidth=null):(T(e.display.wrapper,"CodeMirror-wrap"),Jt(e)),dn(e),vn(e),Xr(e),setTimeout(function(){return Xn(e)},100)}function Wl(e,t){var r=this;if(!(this instanceof Wl))return new Wl(e,t);this.options=t=t?I(t):{},I(Nl,t,!1);var n=t.value;"string"==typeof n?n=new Po(n,t.mode,null,t.lineSeparator,t.direction):t.mode&&(n.modeOption=t.mode),this.doc=n;var i=new Wl.inputStyles[t.inputStyle](this),o=this.display=new wi(e,n,i,t);for(var l in Tl(o.wrapper.CodeMirror=this),t.lineWrapping&&(this.display.wrapper.className+=" CodeMirror-wrap"),$n(this),this.state={keyMaps:[],overlays:[],modeGen:0,overwrite:!1,delayingBlurEvent:!1,focused:!1,suppressEdits:!1,pasteIncoming:-1,cutIncoming:-1,selectingText:!1,draggingText:!1,highlight:new R,keySeq:null,specialChars:null},t.autofocus&&!f&&o.input.focus(),x&&C<11&&setTimeout(function(){return r.display.input.reset(!0)},20),function(i){var o=i.display;we(o.scroller,"mousedown",ii(i,xl)),we(o.scroller,"dblclick",x&&C<11?ii(i,function(e){if(!Le(i,e)){var t=pn(i,e);if(t&&!Ll(i,e)&&!Nr(i.display,e)){Ne(e);var r=i.findWordAt(t);Qi(i.doc,r.anchor,r.head)}}}):function(e){return Le(i,e)||Ne(e)});we(o.scroller,"contextmenu",function(e){return kl(i,e)}),we(o.input.getField(),"contextmenu",function(e){o.scroller.contains(e.target)||kl(i,e)});var r,n={end:0};function l(){o.activeTouch&&(r=setTimeout(function(){return o.activeTouch=null},1e3),(n=o.activeTouch).end=+new Date)}function s(e,t){if(null==t.left)return 1;var r=t.left-e.left,n=t.top-e.top;return 400<r*r+n*n}we(o.scroller,"touchstart",function(e){if(!Le(i,e)&&!function(e){if(1==e.touches.length){var t=e.touches[0];return t.radiusX<=1&&t.radiusY<=1}}(e)&&!Ll(i,e)){o.input.ensurePolled(),clearTimeout(r);var t=+new Date;o.activeTouch={start:t,moved:!1,prev:t-n.end<=300?n:null},1==e.touches.length&&(o.activeTouch.left=e.touches[0].pageX,o.activeTouch.top=e.touches[0].pageY)}}),we(o.scroller,"touchmove",function(){o.activeTouch&&(o.activeTouch.moved=!0)}),we(o.scroller,"touchend",function(e){var t=o.activeTouch;if(t&&!Nr(o,e)&&null!=t.left&&!t.moved&&new Date-t.start<300){var r,n=i.coordsChar(o.activeTouch,"page");r=!t.prev||s(t,t.prev)?new Mi(n,n):!t.prev.prev||s(t,t.prev.prev)?i.findWordAt(n):new Mi(at(n.line,0),gt(i.doc,at(n.line+1,0))),i.setSelection(r.anchor,r.head),i.focus(),Ne(e)}l()}),we(o.scroller,"touchcancel",l),we(o.scroller,"scroll",function(){o.scroller.clientHeight&&(Bn(i,o.scroller.scrollTop),Un(i,o.scroller.scrollLeft,!0),Se(i,"scroll",i))}),we(o.scroller,"mousewheel",function(e){return ki(i,e)}),we(o.scroller,"DOMMouseScroll",function(e){return ki(i,e)}),we(o.wrapper,"scroll",function(){return o.wrapper.scrollTop=o.wrapper.scrollLeft=0}),o.dragFunctions={enter:function(e){Le(i,e)||De(e)},over:function(e){Le(i,e)||(function(e,t){var r=pn(e,t);if(r){var n=document.createDocumentFragment();Sn(e,r,n),e.display.dragCursor||(e.display.dragCursor=A("div",null,"CodeMirror-cursors CodeMirror-dragcursors"),e.display.lineSpace.insertBefore(e.display.dragCursor,e.display.cursorDiv)),N(e.display.dragCursor,n)}}(i,e),De(e))},start:function(e){return function(e,t){if(x&&(!e.state.draggingText||new Date-Eo<100))De(t);else if(!Le(e,t)&&!Nr(e.display,t)&&(t.dataTransfer.setData("Text",e.getSelection()),t.dataTransfer.effectAllowed="copyMove",t.dataTransfer.setDragImage&&!a)){var r=A("img",null,null,"position: fixed; left: 0; top: 0;");r.src="",v&&(r.width=r.height=1,e.display.wrapper.appendChild(r),r._top=r.offsetTop),t.dataTransfer.setDragImage(r,0,0),v&&r.parentNode.removeChild(r)}}(i,e)},drop:ii(i,Io),leave:function(e){Le(i,e)||zo(i)}};var e=o.input.getField();we(e,"keyup",function(e){return vl.call(i,e)}),we(e,"keydown",ii(i,gl)),we(e,"keypress",ii(i,ml)),we(e,"focus",function(e){return On(i,e)}),we(e,"blur",function(e){return An(i,e)})}(this),Go(),Zn(this),this.curOp.forceUpdate=!0,Ri(this,n),t.autofocus&&!f||this.hasFocus()?setTimeout(E(On,this),20):An(this),Ol)Ol.hasOwnProperty(l)&&Ol[l](this,t[l],Ml);vi(this),t.finishInit&&t.finishInit(this);for(var s=0;s<Hl.length;++s)Hl[s](this);Qn(this),b&&t.lineWrapping&&"optimizelegibility"==getComputedStyle(o.lineDiv).textRendering&&(o.lineDiv.style.textRendering="auto")}Wl.defaults=Nl,Wl.optionHandlers=Ol;var Hl=[];function Fl(e,t,r,n){var i,o=e.doc;null==r&&(r="add"),"smart"==r&&(o.mode.indent?i=xt(e,t).state:r="prev");var l=e.options.tabSize,s=et(o,t),a=z(s.text,null,l);s.stateAfter&&(s.stateAfter=null);var u,c=s.text.match(/^\s*/)[0];if(n||/\S/.test(s.text)){if("smart"==r&&((u=o.mode.indent(i,s.text.slice(c.length),s.text))==U||150<u)){if(!n)return;r="prev"}}else u=0,r="not";"prev"==r?u=t>o.first?z(et(o,t-1).text,null,l):0:"add"==r?u=a+e.options.indentUnit:"subtract"==r?u=a-e.options.indentUnit:"number"==typeof r&&(u=a+r),u=Math.max(0,u);var h="",f=0;if(e.options.indentWithTabs)for(var d=Math.floor(u/l);d;--d)f+=l,h+="\t";if(f<u&&(h+=_(u-f)),h!=c)return bo(o,h,at(t,0),at(t,c.length),"+input"),!(s.stateAfter=null);for(var p=0;p<o.sel.ranges.length;p++){var g=o.sel.ranges[p];if(g.head.line==t&&g.head.ch<c.length){var v=at(t,c.length);eo(o,p,new Mi(v,v));break}}}Wl.defineInitHook=function(e){return Hl.push(e)};var Pl=null;function El(e){Pl=e}function Il(e,t,r,n,i){var o=e.doc;e.display.shift=!1,n=n||o.sel;var l=new Date-200,s="paste"==i||e.state.pasteIncoming>l,a=Be(t),u=null;if(s&&1<n.ranges.length)if(Pl&&Pl.text.join("\n")==t){if(n.ranges.length%Pl.text.length==0){u=[];for(var c=0;c<Pl.text.length;c++)u.push(o.splitLines(Pl.text[c]))}}else a.length==n.ranges.length&&e.options.pasteLinesPerSelection&&(u=q(a,function(e){return[e]}));for(var h=e.curOp.updateInput,f=n.ranges.length-1;0<=f;f--){var d=n.ranges[f],p=d.from(),g=d.to();d.empty()&&(r&&0<r?p=at(p.line,p.ch-r):e.state.overwrite&&!s?g=at(g.line,Math.min(et(o,g.line).text.length,g.ch+$(a).length)):s&&Pl&&Pl.lineWise&&Pl.text.join("\n")==t&&(p=g=at(p.line,0)));var v={from:p,to:g,text:u?u[f%u.length]:a,origin:i||(s?"paste":e.state.cutIncoming>l?"cut":"+input")};po(e.doc,v),gr(e,"inputRead",e,v)}t&&!s&&Rl(e,t),En(e),e.curOp.updateInput<2&&(e.curOp.updateInput=h),e.curOp.typing=!0,e.state.pasteIncoming=e.state.cutIncoming=-1}function zl(e,t){var r=e.clipboardData&&e.clipboardData.getData("Text");return r&&(e.preventDefault(),t.isReadOnly()||t.options.disableInput||ni(t,function(){return Il(t,r,0,null,"paste")}),1)}function Rl(e,t){if(e.options.electricChars&&e.options.smartIndent)for(var r=e.doc.sel,n=r.ranges.length-1;0<=n;n--){var i=r.ranges[n];if(!(100<i.head.ch||n&&r.ranges[n-1].head.line==i.head.line)){var o=e.getModeAt(i.head),l=!1;if(o.electricChars){for(var s=0;s<o.electricChars.length;s++)if(-1<t.indexOf(o.electricChars.charAt(s))){l=Fl(e,i.head.line,"smart");break}}else o.electricInput&&o.electricInput.test(et(e.doc,i.head.line).text.slice(0,i.head.ch))&&(l=Fl(e,i.head.line,"smart"));l&&gr(e,"electricInput",e,i.head.line)}}}function Bl(e){for(var t=[],r=[],n=0;n<e.doc.sel.ranges.length;n++){var i=e.doc.sel.ranges[n].head.line,o={anchor:at(i,0),head:at(i+1,0)};r.push(o),t.push(e.getRange(o.anchor,o.head))}return{text:t,ranges:r}}function Gl(e,t,r,n){e.setAttribute("autocorrect",r?"":"off"),e.setAttribute("autocapitalize",n?"":"off"),e.setAttribute("spellcheck",!!t)}function Ul(){var e=A("textarea",null,null,"position: absolute; bottom: -1em; padding: 0; width: 1px; height: 1em; outline: none"),t=A("div",[e],null,"overflow: hidden; position: relative; width: 3px; height: 0px;");return b?e.style.width="1000px":e.setAttribute("wrap","off"),c&&(e.style.border="1px solid black"),Gl(e),t}function Vl(n,i,o,e,l){var t=i,r=o,s=et(n,i.line),a=l&&"rtl"==n.direction?-o:o;function u(e){var t,r;if(null==(t=l?ol(n.cm,s,i,o):nl(s,i,o))){if(e||(r=i.line+a)<n.first||r>=n.first+n.size||(i=new at(r,i.ch,i.sticky),!(s=et(n,r))))return;i=il(l,n.cm,s,i.line,a)}else i=t;return 1}if("char"==e)u();else if("column"==e)u(!0);else if("word"==e||"group"==e)for(var c=null,h="group"==e,f=n.cm&&n.cm.getHelper(i,"wordChars"),d=!0;!(o<0)||u(!d);d=!1){var p=s.text.charAt(i.ch)||"\n",g=te(p,f)?"w":h&&"\n"==p?"n":!h||/\s/.test(p)?null:"p";if(!h||d||g||(g="s"),c&&c!=g){o<0&&(o=1,u(),i.sticky="after");break}if(g&&(c=g),0<o&&!u(!d))break}var v=uo(n,i,t,r,!0);return ct(t,v)&&(v.hitSide=!0),v}function Kl(e,t,r,n){var i,o,l=e.doc,s=t.left;if("page"==n){var a=Math.min(e.display.wrapper.clientHeight,window.innerHeight||document.documentElement.clientHeight),u=Math.max(a-.5*an(e.display),3);i=(0<r?t.bottom:t.top)+r*u}else"line"==n&&(i=0<r?t.bottom+3:t.top-3);for(;(o=rn(e,s,i)).outside;){if(r<0?i<=0:i>=l.height){o.hitSide=!0;break}i+=5*r}return o}function jl(e){this.cm=e,this.lastAnchorNode=this.lastAnchorOffset=this.lastFocusNode=this.lastFocusOffset=null,this.polling=new R,this.composing=null,this.gracePeriod=!1,this.readDOMTimeout=null}function Xl(e,t){var r=Ir(e,t.line);if(!r||r.hidden)return null;var n=et(e.doc,t.line),i=Pr(r,n,t.line),o=ye(n,e.doc.direction),l="left";o&&(l=ae(o,t.ch)%2?"right":"left");var s=Ur(i.map,t.ch,l);return s.offset="right"==s.collapse?s.end:s.start,s}function Yl(e,t){return t&&(e.bad=!0),e}function _l(e,t,r){var n;if(t==e.display.lineDiv){if(!(n=e.display.lineDiv.childNodes[r]))return Yl(e.clipPos(at(e.display.viewTo-1)),!0);t=null,r=0}else for(n=t;;n=n.parentNode){if(!n||n==e.display.lineDiv)return null;if(n.parentNode&&n.parentNode==e.display.lineDiv)break}for(var i=0;i<e.display.view.length;i++){var o=e.display.view[i];if(o.node==n)return $l(o,t,r)}}function $l(u,e,t){var r=u.text.firstChild,n=!1;if(!e||!D(r,e))return Yl(at(it(u.line),0),!0);if(e==r&&(n=!0,e=r.childNodes[t],t=0,!e)){var i=u.rest?$(u.rest):u.line;return Yl(at(it(i),i.text.length),n)}var o=3==e.nodeType?e:null,l=e;for(o||1!=e.childNodes.length||3!=e.firstChild.nodeType||(o=e.firstChild,t=t&&o.nodeValue.length);l.parentNode!=r;)l=l.parentNode;var c=u.measure,h=c.maps;function s(e,t,r){for(var n=-1;n<(h?h.length:0);n++)for(var i=n<0?c.map:h[n],o=0;o<i.length;o+=3){var l=i[o+2];if(l==e||l==t){var s=it(n<0?u.line:u.rest[n]),a=i[o]+r;return(r<0||l!=e)&&(a=i[o+(r?1:0)]),at(s,a)}}}var a=s(o,l,t);if(a)return Yl(a,n);for(var f=l.nextSibling,d=o?o.nodeValue.length-t:0;f;f=f.nextSibling){if(a=s(f,f.firstChild,0))return Yl(at(a.line,a.ch-d),n);d+=f.textContent.length}for(var p=l.previousSibling,g=t;p;p=p.previousSibling){if(a=s(p,p.firstChild,-1))return Yl(at(a.line,a.ch+g),n);g+=p.textContent.length}}jl.prototype.init=function(e){var t=this,l=this,s=l.cm,a=l.div=e.lineDiv;function r(e){if(!Le(s,e)){if(s.somethingSelected())El({lineWise:!1,text:s.getSelections()}),"cut"==e.type&&s.replaceSelection("",null,"cut");else{if(!s.options.lineWiseCopyCut)return;var t=Bl(s);El({lineWise:!0,text:t.text}),"cut"==e.type&&s.operation(function(){s.setSelections(t.ranges,0,V),s.replaceSelection("",null,"cut")})}if(e.clipboardData){e.clipboardData.clearData();var r=Pl.text.join("\n");if(e.clipboardData.setData("Text",r),e.clipboardData.getData("Text")==r)return void e.preventDefault()}var n=Ul(),i=n.firstChild;s.display.lineSpace.insertBefore(n,s.display.lineSpace.firstChild),i.value=Pl.text.join("\n");var o=document.activeElement;P(i),setTimeout(function(){s.display.lineSpace.removeChild(n),o.focus(),o==a&&l.showPrimarySelection()},50)}}Gl(a,s.options.spellcheck,s.options.autocorrect,s.options.autocapitalize),we(a,"paste",function(e){Le(s,e)||zl(e,s)||C<=11&&setTimeout(ii(s,function(){return t.updateFromDOM()}),20)}),we(a,"compositionstart",function(e){t.composing={data:e.data,done:!1}}),we(a,"compositionupdate",function(e){t.composing||(t.composing={data:e.data,done:!1})}),we(a,"compositionend",function(e){t.composing&&(e.data!=t.composing.data&&t.readFromDOMSoon(),t.composing.done=!0)}),we(a,"touchstart",function(){return l.forceCompositionEnd()}),we(a,"input",function(){t.composing||t.readFromDOMSoon()}),we(a,"copy",r),we(a,"cut",r)},jl.prototype.prepareSelection=function(){var e=Cn(this.cm,!1);return e.focus=document.activeElement==this.div,e},jl.prototype.showSelection=function(e,t){e&&this.cm.display.view.length&&((e.focus||t)&&this.showPrimarySelection(),this.showMultipleSelections(e))},jl.prototype.getSelection=function(){return this.cm.display.wrapper.ownerDocument.getSelection()},jl.prototype.showPrimarySelection=function(){var e=this.getSelection(),t=this.cm,r=t.doc.sel.primary(),n=r.from(),i=r.to();if(t.display.viewTo==t.display.viewFrom||n.line>=t.display.viewTo||i.line<t.display.viewFrom)e.removeAllRanges();else{var o=_l(t,e.anchorNode,e.anchorOffset),l=_l(t,e.focusNode,e.focusOffset);if(!o||o.bad||!l||l.bad||0!=ut(dt(o,l),n)||0!=ut(ft(o,l),i)){var s=t.display.view,a=n.line>=t.display.viewFrom&&Xl(t,n)||{node:s[0].measure.map[2],offset:0},u=i.line<t.display.viewTo&&Xl(t,i);if(!u){var c=s[s.length-1].measure,h=c.maps?c.maps[c.maps.length-1]:c.map;u={node:h[h.length-1],offset:h[h.length-2]-h[h.length-3]}}if(a&&u){var f,d=e.rangeCount&&e.getRangeAt(0);try{f=k(a.node,a.offset,u.offset,u.node)}catch(e){}f&&(!g&&t.state.focused?(e.collapse(a.node,a.offset),f.collapsed||(e.removeAllRanges(),e.addRange(f))):(e.removeAllRanges(),e.addRange(f)),d&&null==e.anchorNode?e.addRange(d):g&&this.startGracePeriod()),this.rememberSelection()}else e.removeAllRanges()}}},jl.prototype.startGracePeriod=function(){var e=this;clearTimeout(this.gracePeriod),this.gracePeriod=setTimeout(function(){e.gracePeriod=!1,e.selectionChanged()&&e.cm.operation(function(){return e.cm.curOp.selectionChanged=!0})},20)},jl.prototype.showMultipleSelections=function(e){N(this.cm.display.cursorDiv,e.cursors),N(this.cm.display.selectionDiv,e.selection)},jl.prototype.rememberSelection=function(){var e=this.getSelection();this.lastAnchorNode=e.anchorNode,this.lastAnchorOffset=e.anchorOffset,this.lastFocusNode=e.focusNode,this.lastFocusOffset=e.focusOffset},jl.prototype.selectionInEditor=function(){var e=this.getSelection();if(!e.rangeCount)return!1;var t=e.getRangeAt(0).commonAncestorContainer;return D(this.div,t)},jl.prototype.focus=function(){"nocursor"!=this.cm.options.readOnly&&(this.selectionInEditor()&&document.activeElement==this.div||this.showSelection(this.prepareSelection(),!0),this.div.focus())},jl.prototype.blur=function(){this.div.blur()},jl.prototype.getField=function(){return this.div},jl.prototype.supportsTouch=function(){return!0},jl.prototype.receivedFocus=function(){var t=this;this.selectionInEditor()?this.pollSelection():ni(this.cm,function(){return t.cm.curOp.selectionChanged=!0}),this.polling.set(this.cm.options.pollInterval,function e(){t.cm.state.focused&&(t.pollSelection(),t.polling.set(t.cm.options.pollInterval,e))})},jl.prototype.selectionChanged=function(){var e=this.getSelection();return e.anchorNode!=this.lastAnchorNode||e.anchorOffset!=this.lastAnchorOffset||e.focusNode!=this.lastFocusNode||e.focusOffset!=this.lastFocusOffset},jl.prototype.pollSelection=function(){if(null==this.readDOMTimeout&&!this.gracePeriod&&this.selectionChanged()){var e=this.getSelection(),t=this.cm;if(h&&l&&this.cm.display.gutterSpecs.length&&function(e){for(var t=e;t;t=t.parentNode)if(/CodeMirror-gutter-wrapper/.test(t.className))return 1;return}(e.anchorNode))return this.cm.triggerOnKeyDown({type:"keydown",keyCode:8,preventDefault:Math.abs}),this.blur(),void this.focus();if(!this.composing){this.rememberSelection();var r=_l(t,e.anchorNode,e.anchorOffset),n=_l(t,e.focusNode,e.focusOffset);r&&n&&ni(t,function(){no(t.doc,Oi(r,n),V),(r.bad||n.bad)&&(t.curOp.selectionChanged=!0)})}}},jl.prototype.pollContent=function(){null!=this.readDOMTimeout&&(clearTimeout(this.readDOMTimeout),this.readDOMTimeout=null);var e,t,r,n=this.cm,i=n.display,o=n.doc.sel.primary(),l=o.from(),s=o.to();if(0==l.ch&&l.line>n.firstLine()&&(l=at(l.line-1,et(n.doc,l.line-1).length)),s.ch==et(n.doc,s.line).text.length&&s.line<n.lastLine()&&(s=at(s.line+1,0)),l.line<i.viewFrom||s.line>i.viewTo-1)return!1;r=l.line==i.viewFrom||0==(e=gn(n,l.line))?(t=it(i.view[0].line),i.view[0].node):(t=it(i.view[e].line),i.view[e-1].node.nextSibling);var a,u,c=gn(n,s.line);if(u=c==i.view.length-1?(a=i.viewTo-1,i.lineDiv.lastChild):(a=it(i.view[c+1].line)-1,i.view[c+1].node.previousSibling),!r)return!1;for(var h=n.doc.splitLines(function(a,e,t,u,c){var r="",h=!1,f=a.doc.lineSeparator(),d=!1;function p(){h&&(r+=f,d&&(r+=f),h=d=!1)}function g(e){e&&(p(),r+=e)}function v(e){if(1==e.nodeType){var t=e.getAttribute("cm-text");if(t)return void g(t);var r,n=e.getAttribute("cm-marker");if(n){var i=a.findMarks(at(u,0),at(c+1,0),(s=+n,function(e){return e.id==s}));return void(i.length&&(r=i[0].find(0))&&g(tt(a.doc,r.from,r.to).join(f)))}if("false"==e.getAttribute("contenteditable"))return;var o=/^(pre|div|p|li|table|br)$/i.test(e.nodeName);if(!/^br$/i.test(e.nodeName)&&0==e.textContent.length)return;o&&p();for(var l=0;l<e.childNodes.length;l++)v(e.childNodes[l]);/^(pre|p)$/i.test(e.nodeName)&&(d=!0),o&&(h=!0)}else 3==e.nodeType&&g(e.nodeValue.replace(/\u200b/g,"").replace(/\u00a0/g," "));var s}for(;v(e),e!=t;)e=e.nextSibling,d=!1;return r}(n,r,u,t,a)),f=tt(n.doc,at(t,0),at(a,et(n.doc,a).text.length));1<h.length&&1<f.length;)if($(h)==$(f))h.pop(),f.pop(),a--;else{if(h[0]!=f[0])break;h.shift(),f.shift(),t++}for(var d=0,p=0,g=h[0],v=f[0],m=Math.min(g.length,v.length);d<m&&g.charCodeAt(d)==v.charCodeAt(d);)++d;for(var y=$(h),b=$(f),w=Math.min(y.length-(1==h.length?d:0),b.length-(1==f.length?d:0));p<w&&y.charCodeAt(y.length-p-1)==b.charCodeAt(b.length-p-1);)++p;if(1==h.length&&1==f.length&&t==l.line)for(;d&&d>l.ch&&y.charCodeAt(y.length-p-1)==b.charCodeAt(b.length-p-1);)d--,p++;h[h.length-1]=y.slice(0,y.length-p).replace(/^\u200b+/,""),h[0]=h[0].slice(d).replace(/\u200b+$/,"");var x=at(t,d),C=at(a,f.length?$(f).length-p:0);return 1<h.length||h[0]||ut(x,C)?(bo(n.doc,h,x,C,"+input"),!0):void 0},jl.prototype.ensurePolled=function(){this.forceCompositionEnd()},jl.prototype.reset=function(){this.forceCompositionEnd()},jl.prototype.forceCompositionEnd=function(){this.composing&&(clearTimeout(this.readDOMTimeout),this.composing=null,this.updateFromDOM(),this.div.blur(),this.div.focus())},jl.prototype.readFromDOMSoon=function(){var e=this;null==this.readDOMTimeout&&(this.readDOMTimeout=setTimeout(function(){if(e.readDOMTimeout=null,e.composing){if(!e.composing.done)return;e.composing=null}e.updateFromDOM()},80))},jl.prototype.updateFromDOM=function(){var e=this;!this.cm.isReadOnly()&&this.pollContent()||ni(this.cm,function(){return vn(e.cm)})},jl.prototype.setUneditable=function(e){e.contentEditable="false"},jl.prototype.onKeyPress=function(e){0==e.charCode||this.composing||(e.preventDefault(),this.cm.isReadOnly()||ii(this.cm,Il)(this.cm,String.fromCharCode(null==e.charCode?e.keyCode:e.charCode),0))},jl.prototype.readOnlyChanged=function(e){this.div.contentEditable=String("nocursor"!=e)},jl.prototype.onContextMenu=function(){},jl.prototype.resetPosition=function(){},jl.prototype.needsContentAttribute=!0;function ql(e){this.cm=e,this.prevInput="",this.pollingFast=!1,this.polling=new R,this.hasSelection=!1,this.composing=null}var Zl,Ql,Jl,es,ts;function rs(e,t,n,r){Zl.defaults[e]=t,n&&(Ql[e]=r?function(e,t,r){r!=Ml&&n(e,t,r)}:n)}ql.prototype.init=function(r){var e=this,n=this,i=this.cm;this.createField(r);var o=this.textarea;function t(e){if(!Le(i,e)){if(i.somethingSelected())El({lineWise:!1,text:i.getSelections()});else{if(!i.options.lineWiseCopyCut)return;var t=Bl(i);El({lineWise:!0,text:t.text}),"cut"==e.type?i.setSelections(t.ranges,null,V):(n.prevInput="",o.value=t.text.join("\n"),P(o))}"cut"==e.type&&(i.state.cutIncoming=+new Date)}}r.wrapper.insertBefore(this.wrapper,r.wrapper.firstChild),c&&(o.style.width="0px"),we(o,"input",function(){x&&9<=C&&e.hasSelection&&(e.hasSelection=null),n.poll()}),we(o,"paste",function(e){Le(i,e)||zl(e,i)||(i.state.pasteIncoming=+new Date,n.fastPoll())}),we(o,"cut",t),we(o,"copy",t),we(r.scroller,"paste",function(e){if(!Nr(r,e)&&!Le(i,e)){if(!o.dispatchEvent)return i.state.pasteIncoming=+new Date,void n.focus();var t=new Event("paste");t.clipboardData=e.clipboardData,o.dispatchEvent(t)}}),we(r.lineSpace,"selectstart",function(e){Nr(r,e)||Ne(e)}),we(o,"compositionstart",function(){var e=i.getCursor("from");n.composing&&n.composing.range.clear(),n.composing={start:e,range:i.markText(e,i.getCursor("to"),{className:"CodeMirror-composing"})}}),we(o,"compositionend",function(){n.composing&&(n.poll(),n.composing.range.clear(),n.composing=null)})},ql.prototype.createField=function(e){this.wrapper=Ul(),this.textarea=this.wrapper.firstChild},ql.prototype.prepareSelection=function(){var e=this.cm,t=e.display,r=e.doc,n=Cn(e);if(e.options.moveInputWithCursor){var i=Jr(e,r.sel.primary().head,"div"),o=t.wrapper.getBoundingClientRect(),l=t.lineDiv.getBoundingClientRect();n.teTop=Math.max(0,Math.min(t.wrapper.clientHeight-10,i.top+l.top-o.top)),n.teLeft=Math.max(0,Math.min(t.wrapper.clientWidth-10,i.left+l.left-o.left))}return n},ql.prototype.showSelection=function(e){var t=this.cm.display;N(t.cursorDiv,e.cursors),N(t.selectionDiv,e.selection),null!=e.teTop&&(this.wrapper.style.top=e.teTop+"px",this.wrapper.style.left=e.teLeft+"px")},ql.prototype.reset=function(e){if(!this.contextMenuPending&&!this.composing){var t=this.cm;if(t.somethingSelected()){this.prevInput="";var r=t.getSelection();this.textarea.value=r,t.state.focused&&P(this.textarea),x&&9<=C&&(this.hasSelection=r)}else e||(this.prevInput=this.textarea.value="",x&&9<=C&&(this.hasSelection=null))}},ql.prototype.getField=function(){return this.textarea},ql.prototype.supportsTouch=function(){return!1},ql.prototype.focus=function(){if("nocursor"!=this.cm.options.readOnly&&(!f||W()!=this.textarea))try{this.textarea.focus()}catch(e){}},ql.prototype.blur=function(){this.textarea.blur()},ql.prototype.resetPosition=function(){this.wrapper.style.top=this.wrapper.style.left=0},ql.prototype.receivedFocus=function(){this.slowPoll()},ql.prototype.slowPoll=function(){var e=this;this.pollingFast||this.polling.set(this.cm.options.pollInterval,function(){e.poll(),e.cm.state.focused&&e.slowPoll()})},ql.prototype.fastPoll=function(){var t=!1,r=this;r.pollingFast=!0,r.polling.set(20,function e(){r.poll()||t?(r.pollingFast=!1,r.slowPoll()):(t=!0,r.polling.set(60,e))})},ql.prototype.poll=function(){var e=this,t=this.cm,r=this.textarea,n=this.prevInput;if(this.contextMenuPending||!t.state.focused||Ge(r)&&!n&&!this.composing||t.isReadOnly()||t.options.disableInput||t.state.keySeq)return!1;var i=r.value;if(i==n&&!t.somethingSelected())return!1;if(x&&9<=C&&this.hasSelection===i||w&&/[\uf700-\uf7ff]/.test(i))return t.display.input.reset(),!1;if(t.doc.sel==t.display.selForContextMenu){var o=i.charCodeAt(0);if(8203!=o||n||(n="​"),8666==o)return this.reset(),this.cm.execCommand("undo")}for(var l=0,s=Math.min(n.length,i.length);l<s&&n.charCodeAt(l)==i.charCodeAt(l);)++l;return ni(t,function(){Il(t,i.slice(l),n.length-l,null,e.composing?"*compose":null),1e3<i.length||-1<i.indexOf("\n")?r.value=e.prevInput="":e.prevInput=i,e.composing&&(e.composing.range.clear(),e.composing.range=t.markText(e.composing.start,t.getCursor("to"),{className:"CodeMirror-composing"}))}),!0},ql.prototype.ensurePolled=function(){this.pollingFast&&this.poll()&&(this.pollingFast=!1)},ql.prototype.onKeyPress=function(){x&&9<=C&&(this.hasSelection=null),this.fastPoll()},ql.prototype.onContextMenu=function(e){var r=this,n=r.cm,i=n.display,o=r.textarea;r.contextMenuPending&&r.contextMenuPending();var t=pn(n,e),l=i.scroller.scrollTop;if(t&&!v){n.options.resetSelectionOnContextMenu&&-1==n.doc.sel.contains(t)&&ii(n,no)(n.doc,Oi(t),V);var s,a=o.style.cssText,u=r.wrapper.style.cssText,c=r.wrapper.offsetParent.getBoundingClientRect();if(r.wrapper.style.cssText="position: static",o.style.cssText="position: absolute; width: 30px; height: 30px;\n top: "+(e.clientY-c.top-5)+"px; left: "+(e.clientX-c.left-5)+"px;\n z-index: 1000; background: "+(x?"rgba(255, 255, 255, .05)":"transparent")+";\n outline: none; border-width: 0; outline: none; overflow: hidden; opacity: .05; filter: alpha(opacity=5);",b&&(s=window.scrollY),i.input.focus(),b&&window.scrollTo(null,s),i.input.reset(),n.somethingSelected()||(o.value=r.prevInput=" "),r.contextMenuPending=d,i.selForContextMenu=n.doc.sel,clearTimeout(i.detectingSelectAll),x&&9<=C&&f(),S){De(e);var h=function(){Ce(window,"mouseup",h),setTimeout(d,20)};we(window,"mouseup",h)}else setTimeout(d,50)}function f(){if(null!=o.selectionStart){var e=n.somethingSelected(),t="​"+(e?o.value:"");o.value="⇚",o.value=t,r.prevInput=e?"":"​",o.selectionStart=1,o.selectionEnd=t.length,i.selForContextMenu=n.doc.sel}}function d(){if(r.contextMenuPending==d&&(r.contextMenuPending=!1,r.wrapper.style.cssText=u,o.style.cssText=a,x&&C<9&&i.scrollbars.setScrollTop(i.scroller.scrollTop=l),null!=o.selectionStart)){(!x||x&&C<9)&&f();var e=0,t=function(){i.selForContextMenu==n.doc.sel&&0==o.selectionStart&&0<o.selectionEnd&&"​"==r.prevInput?ii(n,ho)(n):e++<10?i.detectingSelectAll=setTimeout(t,500):(i.selForContextMenu=null,i.input.reset())};i.detectingSelectAll=setTimeout(t,200)}}},ql.prototype.readOnlyChanged=function(e){e||this.reset(),this.textarea.disabled="nocursor"==e},ql.prototype.setUneditable=function(){},ql.prototype.needsContentAttribute=!1,Ql=(Zl=Wl).optionHandlers,Zl.defineOption=rs,Zl.Init=Ml,rs("value","",function(e,t){return e.setValue(t)},!0),rs("mode",null,function(e,t){e.doc.modeOption=t,Fi(e)},!0),rs("indentUnit",2,Fi,!0),rs("indentWithTabs",!1),rs("smartIndent",!0),rs("tabSize",4,function(e){Pi(e),Xr(e),vn(e)},!0),rs("lineSeparator",null,function(e,n){if(e.doc.lineSep=n){var i=[],o=e.doc.first;e.doc.iter(function(e){for(var t=0;;){var r=e.text.indexOf(n,t);if(-1==r)break;t=r+n.length,i.push(at(o,r))}o++});for(var t=i.length-1;0<=t;t--)bo(e.doc,n,i[t],at(i[t].line,i[t].ch+n.length))}}),rs("specialChars",/[\u0000-\u001f\u007f-\u009f\u00ad\u061c\u200b-\u200f\u2028\u2029\ufeff\ufff9-\ufffc]/g,function(e,t,r){e.state.specialChars=new RegExp(t.source+(t.test("\t")?"":"|\t"),"g"),r!=Ml&&e.refresh()}),rs("specialCharPlaceholder",or,function(e){return e.refresh()},!0),rs("electricChars",!0),rs("inputStyle",f?"contenteditable":"textarea",function(){throw new Error("inputStyle can not (yet) be changed in a running editor")},!0),rs("spellcheck",!1,function(e,t){return e.getInputField().spellcheck=t},!0),rs("autocorrect",!1,function(e,t){return e.getInputField().autocorrect=t},!0),rs("autocapitalize",!1,function(e,t){return e.getInputField().autocapitalize=t},!0),rs("rtlMoveVisually",!p),rs("wholeLineUpdateBefore",!0),rs("theme","default",function(e){Tl(e),bi(e)},!0),rs("keyMap","default",function(e,t,r){var n=el(t),i=r!=Ml&&el(r);i&&i.detach&&i.detach(e,n),n.attach&&n.attach(e,i||null)}),rs("extraKeys",null),rs("configureMouse",null),rs("lineWrapping",!1,Dl,!0),rs("gutters",[],function(e,t){e.display.gutterSpecs=mi(t,e.options.lineNumbers),bi(e)},!0),rs("fixedGutter",!0,function(e,t){e.display.gutters.style.left=t?hn(e.display)+"px":"0",e.refresh()},!0),rs("coverGutterNextToScrollbar",!1,function(e){return Xn(e)},!0),rs("scrollbarStyle","native",function(e){$n(e),Xn(e),e.display.scrollbars.setScrollTop(e.doc.scrollTop),e.display.scrollbars.setScrollLeft(e.doc.scrollLeft)},!0),rs("lineNumbers",!1,function(e,t){e.display.gutterSpecs=mi(e.options.gutters,t),bi(e)},!0),rs("firstLineNumber",1,bi,!0),rs("lineNumberFormatter",function(e){return e},bi,!0),rs("showCursorWhenSelecting",!1,xn,!0),rs("resetSelectionOnContextMenu",!0),rs("lineWiseCopyCut",!0),rs("pasteLinesPerSelection",!0),rs("selectionsMayTouch",!1),rs("readOnly",!1,function(e,t){"nocursor"==t&&(An(e),e.display.input.blur()),e.display.input.readOnlyChanged(t)}),rs("disableInput",!1,function(e,t){t||e.display.input.reset()},!0),rs("dragDrop",!0,Al),rs("allowDropFileTypes",null),rs("cursorBlinkRate",530),rs("cursorScrollMargin",0),rs("cursorHeight",1,xn,!0),rs("singleCursorHeightPerLine",!0,xn,!0),rs("workTime",100),rs("workDelay",100),rs("flattenSpans",!0,Pi,!0),rs("addModeClass",!1,Pi,!0),rs("pollInterval",100),rs("undoDepth",200,function(e,t){return e.doc.history.undoDepth=t}),rs("historyEventDelay",1250),rs("viewportMargin",10,function(e){return e.refresh()},!0),rs("maxHighlightLength",1e4,Pi,!0),rs("moveInputWithCursor",!0,function(e,t){t||e.display.input.resetPosition()}),rs("tabindex",null,function(e,t){return e.display.input.getField().tabIndex=t||""}),rs("autofocus",null),rs("direction","ltr",function(e,t){return e.doc.setDirection(t)},!0),rs("phrases",null),es=(Jl=Wl).optionHandlers,ts=Jl.helpers={},Jl.prototype={constructor:Jl,focus:function(){window.focus(),this.display.input.focus()},setOption:function(e,t){var r=this.options,n=r[e];r[e]==t&&"mode"!=e||(r[e]=t,es.hasOwnProperty(e)&&ii(this,es[e])(this,t,n),Se(this,"optionChange",this,e))},getOption:function(e){return this.options[e]},getDoc:function(){return this.doc},addKeyMap:function(e,t){this.state.keyMaps[t?"push":"unshift"](el(e))},removeKeyMap:function(e){for(var t=this.state.keyMaps,r=0;r<t.length;++r)if(t[r]==e||t[r].name==e)return t.splice(r,1),!0},addOverlay:oi(function(e,t){var r=e.token?e:Jl.getMode(this.options,e);if(r.startState)throw new Error("Overlays may not be stateful.");!function(e,t,r){for(var n=0,i=r(t);n<e.length&&r(e[n])<=i;)n++;e.splice(n,0,t)}(this.state.overlays,{mode:r,modeSpec:e,opaque:t&&t.opaque,priority:t&&t.priority||0},function(e){return e.priority}),this.state.modeGen++,vn(this)}),removeOverlay:oi(function(e){for(var t=this.state.overlays,r=0;r<t.length;++r){var n=t[r].modeSpec;if(n==e||"string"==typeof e&&n.name==e)return t.splice(r,1),this.state.modeGen++,void vn(this)}}),indentLine:oi(function(e,t,r){"string"!=typeof t&&"number"!=typeof t&&(t=null==t?this.options.smartIndent?"smart":"prev":t?"add":"subtract"),lt(this.doc,e)&&Fl(this,e,t,r)}),indentSelection:oi(function(e){for(var t=this.doc.sel.ranges,r=-1,n=0;n<t.length;n++){var i=t[n];if(i.empty())i.head.line>r&&(Fl(this,i.head.line,e,!0),r=i.head.line,n==this.doc.sel.primIndex&&En(this));else{var o=i.from(),l=i.to(),s=Math.max(r,o.line);r=Math.min(this.lastLine(),l.line-(l.ch?0:1))+1;for(var a=s;a<r;++a)Fl(this,a,e);var u=this.doc.sel.ranges;0==o.ch&&t.length==u.length&&0<u[n].from().ch&&eo(this.doc,n,new Mi(o,u[n].to()),V)}}}),getTokenAt:function(e,t){return Tt(this,e,t)},getLineTokens:function(e,t){return Tt(this,at(e),t,!0)},getTokenTypeAt:function(e){e=gt(this.doc,e);var t,r=wt(this,et(this.doc,e.line)),n=0,i=(r.length-1)/2,o=e.ch;if(0==o)t=r[2];else for(;;){var l=n+i>>1;if((l?r[2*l-1]:0)>=o)i=l;else{if(!(r[2*l+1]<o)){t=r[2*l+2];break}n=1+l}}var s=t?t.indexOf("overlay "):-1;return s<0?t:0==s?null:t.slice(0,s-1)},getModeAt:function(e){var t=this.doc.mode;return t.innerMode?Jl.innerMode(t,this.getTokenAt(e).state).mode:t},getHelper:function(e,t){return this.getHelpers(e,t)[0]},getHelpers:function(e,t){var r=[];if(!ts.hasOwnProperty(t))return r;var n=ts[t],i=this.getModeAt(e);if("string"==typeof i[t])n[i[t]]&&r.push(n[i[t]]);else if(i[t])for(var o=0;o<i[t].length;o++){var l=n[i[t][o]];l&&r.push(l)}else i.helperType&&n[i.helperType]?r.push(n[i.helperType]):n[i.name]&&r.push(n[i.name]);for(var s=0;s<n._global.length;s++){var a=n._global[s];a.pred(i,this)&&-1==B(r,a.val)&&r.push(a.val)}return r},getStateAfter:function(e,t){var r=this.doc;return xt(this,(e=pt(r,null==e?r.first+r.size-1:e))+1,t).state},cursorCoords:function(e,t){var r=this.doc.sel.primary();return Jr(this,null==e?r.head:"object"==typeof e?gt(this.doc,e):e?r.from():r.to(),t||"page")},charCoords:function(e,t){return Qr(this,gt(this.doc,e),t||"page")},coordsChar:function(e,t){return rn(this,(e=Zr(this,e,t||"page")).left,e.top)},lineAtHeight:function(e,t){return e=Zr(this,{top:e,left:0},t||"page").top,ot(this.doc,e+this.display.viewOffset)},heightAtLine:function(e,t,r){var n,i=!1;if("number"==typeof e){var o=this.doc.first+this.doc.size-1;e<this.doc.first?e=this.doc.first:o<e&&(e=o,i=!0),n=et(this.doc,e)}else n=e;return qr(this,n,{top:0,left:0},t||"page",r||i).top+(i?this.doc.height-Zt(n):0)},defaultTextHeight:function(){return an(this.display)},defaultCharWidth:function(){return un(this.display)},getViewport:function(){return{from:this.display.viewFrom,to:this.display.viewTo}},addWidget:function(e,t,r,n,i){var o,l,s,a=this.display,u=(e=Jr(this,gt(this.doc,e))).bottom,c=e.left;if(t.style.position="absolute",t.setAttribute("cm-ignore-events","true"),this.display.input.setUneditable(t),a.sizer.appendChild(t),"over"==n)u=e.top;else if("above"==n||"near"==n){var h=Math.max(a.wrapper.clientHeight,this.doc.height),f=Math.max(a.sizer.clientWidth,a.lineSpace.clientWidth);("above"==n||e.bottom+t.offsetHeight>h)&&e.top>t.offsetHeight?u=e.top-t.offsetHeight:e.bottom+t.offsetHeight<=h&&(u=e.bottom),c+t.offsetWidth>f&&(c=f-t.offsetWidth)}t.style.top=u+"px",t.style.left=t.style.right="","right"==i?(c=a.sizer.clientWidth-t.offsetWidth,t.style.right="0px"):("left"==i?c=0:"middle"==i&&(c=(a.sizer.clientWidth-t.offsetWidth)/2),t.style.left=c+"px"),r&&(o=this,l={left:c,top:u,right:c+t.offsetWidth,bottom:u+t.offsetHeight},null!=(s=Fn(o,l)).scrollTop&&Bn(o,s.scrollTop),null!=s.scrollLeft&&Un(o,s.scrollLeft))},triggerOnKeyDown:oi(gl),triggerOnKeyPress:oi(ml),triggerOnKeyUp:vl,triggerOnMouseDown:oi(xl),execCommand:function(e){if(ll.hasOwnProperty(e))return ll[e].call(null,this)},triggerElectric:oi(function(e){Rl(this,e)}),findPosH:function(e,t,r,n){var i=1;t<0&&(i=-1,t=-t);for(var o=gt(this.doc,e),l=0;l<t&&!(o=Vl(this.doc,o,i,r,n)).hitSide;++l);return o},moveH:oi(function(t,r){var n=this;this.extendSelectionsBy(function(e){return n.display.shift||n.doc.extend||e.empty()?Vl(n.doc,e.head,t,r,n.options.rtlMoveVisually):t<0?e.from():e.to()},j)}),deleteH:oi(function(r,n){var e=this.doc.sel,i=this.doc;e.somethingSelected()?i.replaceSelection("",null,"+delete"):tl(this,function(e){var t=Vl(i,e.head,r,n,!1);return r<0?{from:t,to:e.head}:{from:e.head,to:t}})}),findPosV:function(e,t,r,n){var i=1,o=n;t<0&&(i=-1,t=-t);for(var l=gt(this.doc,e),s=0;s<t;++s){var a=Jr(this,l,"div");if(null==o?o=a.left:a.left=o,(l=Kl(this,a,i,r)).hitSide)break}return l},moveV:oi(function(n,i){var o=this,l=this.doc,s=[],a=!this.display.shift&&!l.extend&&l.sel.somethingSelected();if(l.extendSelectionsBy(function(e){if(a)return n<0?e.from():e.to();var t=Jr(o,e.head,"div");null!=e.goalColumn&&(t.left=e.goalColumn),s.push(t.left);var r=Kl(o,t,n,i);return"page"==i&&e==l.sel.primary()&&Pn(o,Qr(o,r,"div").top-t.top),r},j),s.length)for(var e=0;e<l.sel.ranges.length;e++)l.sel.ranges[e].goalColumn=s[e]}),findWordAt:function(e){var t=et(this.doc,e.line).text,r=e.ch,n=e.ch;if(t){var i=this.getHelper(e,"wordChars");"before"!=e.sticky&&n!=t.length||!r?++n:--r;for(var o=t.charAt(r),l=te(o,i)?function(e){return te(e,i)}:/\s/.test(o)?function(e){return/\s/.test(e)}:function(e){return!/\s/.test(e)&&!te(e)};0<r&&l(t.charAt(r-1));)--r;for(;n<t.length&&l(t.charAt(n));)++n}return new Mi(at(e.line,r),at(e.line,n))},toggleOverwrite:function(e){null!=e&&e==this.state.overwrite||(((this.state.overwrite=!this.state.overwrite)?H:T)(this.display.cursorDiv,"CodeMirror-overwrite"),Se(this,"overwriteToggle",this,this.state.overwrite))},hasFocus:function(){return this.display.input.getField()==W()},isReadOnly:function(){return!(!this.options.readOnly&&!this.doc.cantEdit)},scrollTo:oi(function(e,t){In(this,e,t)}),getScrollInfo:function(){var e=this.display.scroller;return{left:e.scrollLeft,top:e.scrollTop,height:e.scrollHeight-Wr(this)-this.display.barHeight,width:e.scrollWidth-Wr(this)-this.display.barWidth,clientHeight:Fr(this),clientWidth:Hr(this)}},scrollIntoView:oi(function(e,t){var r,n;null==e?(e={from:this.doc.sel.primary().head,to:null},null==t&&(t=this.options.cursorScrollMargin)):"number"==typeof e?e={from:at(e,0),to:null}:null==e.from&&(e={from:e,to:null}),e.to||(e.to=e.from),e.margin=t||0,null!=e.from.line?(n=e,zn(r=this),r.curOp.scrollToPos=n):Rn(this,e.from,e.to,e.margin)}),setSize:oi(function(e,t){function r(e){return"number"==typeof e||/^\d+$/.test(String(e))?e+"px":e}var n=this;null!=e&&(this.display.wrapper.style.width=r(e)),null!=t&&(this.display.wrapper.style.height=r(t)),this.options.lineWrapping&&jr(this);var i=this.display.viewFrom;this.doc.iter(i,this.display.viewTo,function(e){if(e.widgets)for(var t=0;t<e.widgets.length;t++)if(e.widgets[t].noHScroll){mn(n,i,"widget");break}++i}),this.curOp.forceUpdate=!0,Se(this,"refresh",this)}),operation:function(e){return ni(this,e)},startOperation:function(){return Zn(this)},endOperation:function(){return Qn(this)},refresh:oi(function(){var e=this.display.cachedTextHeight;vn(this),this.curOp.forceUpdate=!0,Xr(this),In(this,this.doc.scrollLeft,this.doc.scrollTop),di(this.display),(null==e||.5<Math.abs(e-an(this.display)))&&dn(this),Se(this,"refresh",this)}),swapDoc:oi(function(e){var t=this.doc;return t.cm=null,this.state.selectingText&&this.state.selectingText(),Ri(this,e),Xr(this),this.display.input.reset(),In(this,e.scrollLeft,e.scrollTop),this.curOp.forceScroll=!0,gr(this,"swapDoc",this,t),t}),phrase:function(e){var t=this.options.phrases;return t&&Object.prototype.hasOwnProperty.call(t,e)?t[e]:e},getInputField:function(){return this.display.input.getField()},getWrapperElement:function(){return this.display.wrapper},getScrollerElement:function(){return this.display.scroller},getGutterElement:function(){return this.display.gutters}},Me(Jl),Jl.registerHelper=function(e,t,r){ts.hasOwnProperty(e)||(ts[e]=Jl[e]={_global:[]}),ts[e][t]=r},Jl.registerGlobalHelper=function(e,t,r,n){Jl.registerHelper(e,t,n),ts[e]._global.push({pred:r,val:n})};var ns,is="iter insert remove copy getEditor constructor".split(" ");for(var os in Po.prototype)Po.prototype.hasOwnProperty(os)&&B(is,os)<0&&(Wl.prototype[os]=function(e){return function(){return e.apply(this.doc,arguments)}}(Po.prototype[os]));return Me(Po),Wl.inputStyles={textarea:ql,contenteditable:jl},Wl.defineMode=function(e){Wl.defaults.mode||"null"==e||(Wl.defaults.mode=e),function(e,t){2<arguments.length&&(t.dependencies=Array.prototype.slice.call(arguments,2)),Ke[e]=t}.apply(this,arguments)},Wl.defineMIME=function(e,t){je[e]=t},Wl.defineMode("null",function(){return{token:function(e){return e.skipToEnd()}}}),Wl.defineMIME("text/plain","null"),Wl.defineExtension=function(e,t){Wl.prototype[e]=t},Wl.defineDocExtension=function(e,t){Po.prototype[e]=t},Wl.fromTextArea=function(t,r){if((r=r?I(r):{}).value=t.value,!r.tabindex&&t.tabIndex&&(r.tabindex=t.tabIndex),!r.placeholder&&t.placeholder&&(r.placeholder=t.placeholder),null==r.autofocus){var e=W();r.autofocus=e==t||null!=t.getAttribute("autofocus")&&e==document.body}function n(){t.value=s.getValue()}var i;if(t.form&&(we(t.form,"submit",n),!r.leaveSubmitMethodAlone)){var o=t.form;i=o.submit;try{var l=o.submit=function(){n(),o.submit=i,o.submit(),o.submit=l}}catch(e){}}r.finishInit=function(e){e.save=n,e.getTextArea=function(){return t},e.toTextArea=function(){e.toTextArea=isNaN,n(),t.parentNode.removeChild(e.getWrapperElement()),t.style.display="",t.form&&(Ce(t.form,"submit",n),r.leaveSubmitMethodAlone||"function"!=typeof t.form.submit||(t.form.submit=i))}},t.style.display="none";var s=Wl(function(e){return t.parentNode.insertBefore(e,t.nextSibling)},r);return s},(ns=Wl).off=Ce,ns.on=we,ns.wheelEventPixels=Li,ns.Doc=Po,ns.splitLines=Be,ns.countColumn=z,ns.findColumn=X,ns.isWordChar=ee,ns.Pass=U,ns.signal=Se,ns.Line=er,ns.changeEnd=Ai,ns.scrollbarModel=_n,ns.Pos=at,ns.cmpPos=ut,ns.modes=Ke,ns.mimeModes=je,ns.resolveMode=Xe,ns.getMode=Ye,ns.modeExtensions=_e,ns.extendMode=$e,ns.copyState=qe,ns.startState=Qe,ns.innerMode=Ze,ns.commands=ll,ns.keyMap=Yo,ns.keyName=Jo,ns.isModifierKey=Zo,ns.lookupKey=qo,ns.normalizeKeyMap=$o,ns.StringStream=Je,ns.SharedTextMarker=Do,ns.TextMarker=Oo,ns.LineWidget=To,ns.e_preventDefault=Ne,ns.e_stopPropagation=Oe,ns.e_stop=De,ns.addClass=H,ns.contains=D,ns.rmClass=T,ns.keyNames=Vo,Wl.version="5.52.2",Wl});
includes/js/codemirror/codemirror.js DELETED
@@ -1,9351 +0,0 @@
1
- // CodeMirror, copyright (c) by Marijn Haverbeke and others
2
- // Distributed under an MIT license: http://codemirror.net/LICENSE
3
-
4
- // This is CodeMirror (http://codemirror.net), a code editor
5
- // implemented in JavaScript on top of the browser's DOM.
6
- //
7
- // You can find some technical background for some of the code below
8
- // at http://marijnhaverbeke.nl/blog/#cm-internals .
9
-
10
- (function (global, factory) {
11
- typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
12
- typeof define === 'function' && define.amd ? define(factory) :
13
- (global.CodeMirror = factory());
14
- }(this, (function () { 'use strict';
15
-
16
- // Kludges for bugs and behavior differences that can't be feature
17
- // detected are enabled based on userAgent etc sniffing.
18
- var userAgent = navigator.userAgent
19
- var platform = navigator.platform
20
-
21
- var gecko = /gecko\/\d/i.test(userAgent)
22
- var ie_upto10 = /MSIE \d/.test(userAgent)
23
- var ie_11up = /Trident\/(?:[7-9]|\d{2,})\..*rv:(\d+)/.exec(userAgent)
24
- var edge = /Edge\/(\d+)/.exec(userAgent)
25
- var ie = ie_upto10 || ie_11up || edge
26
- var ie_version = ie && (ie_upto10 ? document.documentMode || 6 : +(edge || ie_11up)[1])
27
- var webkit = !edge && /WebKit\//.test(userAgent)
28
- var qtwebkit = webkit && /Qt\/\d+\.\d+/.test(userAgent)
29
- var chrome = !edge && /Chrome\//.test(userAgent)
30
- var presto = /Opera\//.test(userAgent)
31
- var safari = /Apple Computer/.test(navigator.vendor)
32
- var mac_geMountainLion = /Mac OS X 1\d\D([8-9]|\d\d)\D/.test(userAgent)
33
- var phantom = /PhantomJS/.test(userAgent)
34
-
35
- var ios = !edge && /AppleWebKit/.test(userAgent) && /Mobile\/\w+/.test(userAgent)
36
- var android = /Android/.test(userAgent)
37
- // This is woefully incomplete. Suggestions for alternative methods welcome.
38
- var mobile = ios || android || /webOS|BlackBerry|Opera Mini|Opera Mobi|IEMobile/i.test(userAgent)
39
- var mac = ios || /Mac/.test(platform)
40
- var chromeOS = /\bCrOS\b/.test(userAgent)
41
- var windows = /win/i.test(platform)
42
-
43
- var presto_version = presto && userAgent.match(/Version\/(\d*\.\d*)/)
44
- if (presto_version) { presto_version = Number(presto_version[1]) }
45
- if (presto_version && presto_version >= 15) { presto = false; webkit = true }
46
- // Some browsers use the wrong event properties to signal cmd/ctrl on OS X
47
- var flipCtrlCmd = mac && (qtwebkit || presto && (presto_version == null || presto_version < 12.11))
48
- var captureRightClick = gecko || (ie && ie_version >= 9)
49
-
50
- function classTest(cls) { return new RegExp("(^|\\s)" + cls + "(?:$|\\s)\\s*") }
51
-
52
- var rmClass = function(node, cls) {
53
- var current = node.className
54
- var match = classTest(cls).exec(current)
55
- if (match) {
56
- var after = current.slice(match.index + match[0].length)
57
- node.className = current.slice(0, match.index) + (after ? match[1] + after : "")
58
- }
59
- }
60
-
61
- function removeChildren(e) {
62
- for (var count = e.childNodes.length; count > 0; --count)
63
- { e.removeChild(e.firstChild) }
64
- return e
65
- }
66
-
67
- function removeChildrenAndAdd(parent, e) {
68
- return removeChildren(parent).appendChild(e)
69
- }
70
-
71
- function elt(tag, content, className, style) {
72
- var e = document.createElement(tag)
73
- if (className) { e.className = className }
74
- if (style) { e.style.cssText = style }
75
- if (typeof content == "string") { e.appendChild(document.createTextNode(content)) }
76
- else if (content) { for (var i = 0; i < content.length; ++i) { e.appendChild(content[i]) } }
77
- return e
78
- }
79
- // wrapper for elt, which removes the elt from the accessibility tree
80
- function eltP(tag, content, className, style) {
81
- var e = elt(tag, content, className, style)
82
- e.setAttribute("role", "presentation")
83
- return e
84
- }
85
-
86
- var range
87
- if (document.createRange) { range = function(node, start, end, endNode) {
88
- var r = document.createRange()
89
- r.setEnd(endNode || node, end)
90
- r.setStart(node, start)
91
- return r
92
- } }
93
- else { range = function(node, start, end) {
94
- var r = document.body.createTextRange()
95
- try { r.moveToElementText(node.parentNode) }
96
- catch(e) { return r }
97
- r.collapse(true)
98
- r.moveEnd("character", end)
99
- r.moveStart("character", start)
100
- return r
101
- } }
102
-
103
- function contains(parent, child) {
104
- if (child.nodeType == 3) // Android browser always returns false when child is a textnode
105
- { child = child.parentNode }
106
- if (parent.contains)
107
- { return parent.contains(child) }
108
- do {
109
- if (child.nodeType == 11) { child = child.host }
110
- if (child == parent) { return true }
111
- } while (child = child.parentNode)
112
- }
113
-
114
- function activeElt() {
115
- // IE and Edge may throw an "Unspecified Error" when accessing document.activeElement.
116
- // IE < 10 will throw when accessed while the page is loading or in an iframe.
117
- // IE > 9 and Edge will throw when accessed in an iframe if document.body is unavailable.
118
- var activeElement
119
- try {
120
- activeElement = document.activeElement
121
- } catch(e) {
122
- activeElement = document.body || null
123
- }
124
- while (activeElement && activeElement.shadowRoot && activeElement.shadowRoot.activeElement)
125
- { activeElement = activeElement.shadowRoot.activeElement }
126
- return activeElement
127
- }
128
-
129
- function addClass(node, cls) {
130
- var current = node.className
131
- if (!classTest(cls).test(current)) { node.className += (current ? " " : "") + cls }
132
- }
133
- function joinClasses(a, b) {
134
- var as = a.split(" ")
135
- for (var i = 0; i < as.length; i++)
136
- { if (as[i] && !classTest(as[i]).test(b)) { b += " " + as[i] } }
137
- return b
138
- }
139
-
140
- var selectInput = function(node) { node.select() }
141
- if (ios) // Mobile Safari apparently has a bug where select() is broken.
142
- { selectInput = function(node) { node.selectionStart = 0; node.selectionEnd = node.value.length } }
143
- else if (ie) // Suppress mysterious IE10 errors
144
- { selectInput = function(node) { try { node.select() } catch(_e) {} } }
145
-
146
- function bind(f) {
147
- var args = Array.prototype.slice.call(arguments, 1)
148
- return function(){return f.apply(null, args)}
149
- }
150
-
151
- function copyObj(obj, target, overwrite) {
152
- if (!target) { target = {} }
153
- for (var prop in obj)
154
- { if (obj.hasOwnProperty(prop) && (overwrite !== false || !target.hasOwnProperty(prop)))
155
- { target[prop] = obj[prop] } }
156
- return target
157
- }
158
-
159
- // Counts the column offset in a string, taking tabs into account.
160
- // Used mostly to find indentation.
161
- function countColumn(string, end, tabSize, startIndex, startValue) {
162
- if (end == null) {
163
- end = string.search(/[^\s\u00a0]/)
164
- if (end == -1) { end = string.length }
165
- }
166
- for (var i = startIndex || 0, n = startValue || 0;;) {
167
- var nextTab = string.indexOf("\t", i)
168
- if (nextTab < 0 || nextTab >= end)
169
- { return n + (end - i) }
170
- n += nextTab - i
171
- n += tabSize - (n % tabSize)
172
- i = nextTab + 1
173
- }
174
- }
175
-
176
- var Delayed = function() {this.id = null};
177
- Delayed.prototype.set = function (ms, f) {
178
- clearTimeout(this.id)
179
- this.id = setTimeout(f, ms)
180
- };
181
-
182
- function indexOf(array, elt) {
183
- for (var i = 0; i < array.length; ++i)
184
- { if (array[i] == elt) { return i } }
185
- return -1
186
- }
187
-
188
- // Number of pixels added to scroller and sizer to hide scrollbar
189
- var scrollerGap = 30
190
-
191
- // Returned or thrown by various protocols to signal 'I'm not
192
- // handling this'.
193
- var Pass = {toString: function(){return "CodeMirror.Pass"}}
194
-
195
- // Reused option objects for setSelection & friends
196
- var sel_dontScroll = {scroll: false};
197
- var sel_mouse = {origin: "*mouse"};
198
- var sel_move = {origin: "+move"};
199
- // The inverse of countColumn -- find the offset that corresponds to
200
- // a particular column.
201
- function findColumn(string, goal, tabSize) {
202
- for (var pos = 0, col = 0;;) {
203
- var nextTab = string.indexOf("\t", pos)
204
- if (nextTab == -1) { nextTab = string.length }
205
- var skipped = nextTab - pos
206
- if (nextTab == string.length || col + skipped >= goal)
207
- { return pos + Math.min(skipped, goal - col) }
208
- col += nextTab - pos
209
- col += tabSize - (col % tabSize)
210
- pos = nextTab + 1
211
- if (col >= goal) { return pos }
212
- }
213
- }
214
-
215
- var spaceStrs = [""]
216
- function spaceStr(n) {
217
- while (spaceStrs.length <= n)
218
- { spaceStrs.push(lst(spaceStrs) + " ") }
219
- return spaceStrs[n]
220
- }
221
-
222
- function lst(arr) { return arr[arr.length-1] }
223
-
224
- function map(array, f) {
225
- var out = []
226
- for (var i = 0; i < array.length; i++) { out[i] = f(array[i], i) }
227
- return out
228
- }
229
-
230
- function insertSorted(array, value, score) {
231
- var pos = 0, priority = score(value)
232
- while (pos < array.length && score(array[pos]) <= priority) { pos++ }
233
- array.splice(pos, 0, value)
234
- }
235
-
236
- function nothing() {}
237
-
238
- function createObj(base, props) {
239
- var inst
240
- if (Object.create) {
241
- inst = Object.create(base)
242
- } else {
243
- nothing.prototype = base
244
- inst = new nothing()
245
- }
246
- if (props) { copyObj(props, inst) }
247
- return inst
248
- }
249
-
250
- var nonASCIISingleCaseWordChar = /[\u00df\u0587\u0590-\u05f4\u0600-\u06ff\u3040-\u309f\u30a0-\u30ff\u3400-\u4db5\u4e00-\u9fcc\uac00-\ud7af]/
251
- function isWordCharBasic(ch) {
252
- return /\w/.test(ch) || ch > "\x80" &&
253
- (ch.toUpperCase() != ch.toLowerCase() || nonASCIISingleCaseWordChar.test(ch))
254
- }
255
- function isWordChar(ch, helper) {
256
- if (!helper) { return isWordCharBasic(ch) }
257
- if (helper.source.indexOf("\\w") > -1 && isWordCharBasic(ch)) { return true }
258
- return helper.test(ch)
259
- }
260
-
261
- function isEmpty(obj) {
262
- for (var n in obj) { if (obj.hasOwnProperty(n) && obj[n]) { return false } }
263
- return true
264
- }
265
-
266
- // Extending unicode characters. A series of a non-extending char +
267
- // any number of extending chars is treated as a single unit as far
268
- // as editing and measuring is concerned. This is not fully correct,
269
- // since some scripts/fonts/browsers also treat other configurations
270
- // of code points as a group.
271
- var extendingChars = /[\u0300-\u036f\u0483-\u0489\u0591-\u05bd\u05bf\u05c1\u05c2\u05c4\u05c5\u05c7\u0610-\u061a\u064b-\u065e\u0670\u06d6-\u06dc\u06de-\u06e4\u06e7\u06e8\u06ea-\u06ed\u0711\u0730-\u074a\u07a6-\u07b0\u07eb-\u07f3\u0816-\u0819\u081b-\u0823\u0825-\u0827\u0829-\u082d\u0900-\u0902\u093c\u0941-\u0948\u094d\u0951-\u0955\u0962\u0963\u0981\u09bc\u09be\u09c1-\u09c4\u09cd\u09d7\u09e2\u09e3\u0a01\u0a02\u0a3c\u0a41\u0a42\u0a47\u0a48\u0a4b-\u0a4d\u0a51\u0a70\u0a71\u0a75\u0a81\u0a82\u0abc\u0ac1-\u0ac5\u0ac7\u0ac8\u0acd\u0ae2\u0ae3\u0b01\u0b3c\u0b3e\u0b3f\u0b41-\u0b44\u0b4d\u0b56\u0b57\u0b62\u0b63\u0b82\u0bbe\u0bc0\u0bcd\u0bd7\u0c3e-\u0c40\u0c46-\u0c48\u0c4a-\u0c4d\u0c55\u0c56\u0c62\u0c63\u0cbc\u0cbf\u0cc2\u0cc6\u0ccc\u0ccd\u0cd5\u0cd6\u0ce2\u0ce3\u0d3e\u0d41-\u0d44\u0d4d\u0d57\u0d62\u0d63\u0dca\u0dcf\u0dd2-\u0dd4\u0dd6\u0ddf\u0e31\u0e34-\u0e3a\u0e47-\u0e4e\u0eb1\u0eb4-\u0eb9\u0ebb\u0ebc\u0ec8-\u0ecd\u0f18\u0f19\u0f35\u0f37\u0f39\u0f71-\u0f7e\u0f80-\u0f84\u0f86\u0f87\u0f90-\u0f97\u0f99-\u0fbc\u0fc6\u102d-\u1030\u1032-\u1037\u1039\u103a\u103d\u103e\u1058\u1059\u105e-\u1060\u1071-\u1074\u1082\u1085\u1086\u108d\u109d\u135f\u1712-\u1714\u1732-\u1734\u1752\u1753\u1772\u1773\u17b7-\u17bd\u17c6\u17c9-\u17d3\u17dd\u180b-\u180d\u18a9\u1920-\u1922\u1927\u1928\u1932\u1939-\u193b\u1a17\u1a18\u1a56\u1a58-\u1a5e\u1a60\u1a62\u1a65-\u1a6c\u1a73-\u1a7c\u1a7f\u1b00-\u1b03\u1b34\u1b36-\u1b3a\u1b3c\u1b42\u1b6b-\u1b73\u1b80\u1b81\u1ba2-\u1ba5\u1ba8\u1ba9\u1c2c-\u1c33\u1c36\u1c37\u1cd0-\u1cd2\u1cd4-\u1ce0\u1ce2-\u1ce8\u1ced\u1dc0-\u1de6\u1dfd-\u1dff\u200c\u200d\u20d0-\u20f0\u2cef-\u2cf1\u2de0-\u2dff\u302a-\u302f\u3099\u309a\ua66f-\ua672\ua67c\ua67d\ua6f0\ua6f1\ua802\ua806\ua80b\ua825\ua826\ua8c4\ua8e0-\ua8f1\ua926-\ua92d\ua947-\ua951\ua980-\ua982\ua9b3\ua9b6-\ua9b9\ua9bc\uaa29-\uaa2e\uaa31\uaa32\uaa35\uaa36\uaa43\uaa4c\uaab0\uaab2-\uaab4\uaab7\uaab8\uaabe\uaabf\uaac1\uabe5\uabe8\uabed\udc00-\udfff\ufb1e\ufe00-\ufe0f\ufe20-\ufe26\uff9e\uff9f]/
272
- function isExtendingChar(ch) { return ch.charCodeAt(0) >= 768 && extendingChars.test(ch) }
273
-
274
- // Returns a number from the range [`0`; `str.length`] unless `pos` is outside that range.
275
- function skipExtendingChars(str, pos, dir) {
276
- while ((dir < 0 ? pos > 0 : pos < str.length) && isExtendingChar(str.charAt(pos))) { pos += dir }
277
- return pos
278
- }
279
-
280
- // Returns the value from the range [`from`; `to`] that satisfies
281
- // `pred` and is closest to `from`. Assumes that at least `to` satisfies `pred`.
282
- function findFirst(pred, from, to) {
283
- for (;;) {
284
- if (Math.abs(from - to) <= 1) { return pred(from) ? from : to }
285
- var mid = Math.floor((from + to) / 2)
286
- if (pred(mid)) { to = mid }
287
- else { from = mid }
288
- }
289
- }
290
-
291
- // The display handles the DOM integration, both for input reading
292
- // and content drawing. It holds references to DOM nodes and
293
- // display-related state.
294
-
295
- function Display(place, doc, input) {
296
- var d = this
297
- this.input = input
298
-
299
- // Covers bottom-right square when both scrollbars are present.
300
- d.scrollbarFiller = elt("div", null, "CodeMirror-scrollbar-filler")
301
- d.scrollbarFiller.setAttribute("cm-not-content", "true")
302
- // Covers bottom of gutter when coverGutterNextToScrollbar is on
303
- // and h scrollbar is present.
304
- d.gutterFiller = elt("div", null, "CodeMirror-gutter-filler")
305
- d.gutterFiller.setAttribute("cm-not-content", "true")
306
- // Will contain the actual code, positioned to cover the viewport.
307
- d.lineDiv = eltP("div", null, "CodeMirror-code")
308
- // Elements are added to these to represent selection and cursors.
309
- d.selectionDiv = elt("div", null, null, "position: relative; z-index: 1")
310
- d.cursorDiv = elt("div", null, "CodeMirror-cursors")
311
- // A visibility: hidden element used to find the size of things.
312
- d.measure = elt("div", null, "CodeMirror-measure")
313
- // When lines outside of the viewport are measured, they are drawn in this.
314
- d.lineMeasure = elt("div", null, "CodeMirror-measure")
315
- // Wraps everything that needs to exist inside the vertically-padded coordinate system
316
- d.lineSpace = eltP("div", [d.measure, d.lineMeasure, d.selectionDiv, d.cursorDiv, d.lineDiv],
317
- null, "position: relative; outline: none")
318
- var lines = eltP("div", [d.lineSpace], "CodeMirror-lines")
319
- // Moved around its parent to cover visible view.
320
- d.mover = elt("div", [lines], null, "position: relative")
321
- // Set to the height of the document, allowing scrolling.
322
- d.sizer = elt("div", [d.mover], "CodeMirror-sizer")
323
- d.sizerWidth = null
324
- // Behavior of elts with overflow: auto and padding is
325
- // inconsistent across browsers. This is used to ensure the
326
- // scrollable area is big enough.
327
- d.heightForcer = elt("div", null, null, "position: absolute; height: " + scrollerGap + "px; width: 1px;")
328
- // Will contain the gutters, if any.
329
- d.gutters = elt("div", null, "CodeMirror-gutters")
330
- d.lineGutter = null
331
- // Actual scrollable element.
332
- d.scroller = elt("div", [d.sizer, d.heightForcer, d.gutters], "CodeMirror-scroll")
333
- d.scroller.setAttribute("tabIndex", "-1")
334
- // The element in which the editor lives.
335
- d.wrapper = elt("div", [d.scrollbarFiller, d.gutterFiller, d.scroller], "CodeMirror")
336
-
337
- // Work around IE7 z-index bug (not perfect, hence IE7 not really being supported)
338
- if (ie && ie_version < 8) { d.gutters.style.zIndex = -1; d.scroller.style.paddingRight = 0 }
339
- if (!webkit && !(gecko && mobile)) { d.scroller.draggable = true }
340
-
341
- if (place) {
342
- if (place.appendChild) { place.appendChild(d.wrapper) }
343
- else { place(d.wrapper) }
344
- }
345
-
346
- // Current rendered range (may be bigger than the view window).
347
- d.viewFrom = d.viewTo = doc.first
348
- d.reportedViewFrom = d.reportedViewTo = doc.first
349
- // Information about the rendered lines.
350
- d.view = []
351
- d.renderedView = null
352
- // Holds info about a single rendered line when it was rendered
353
- // for measurement, while not in view.
354
- d.externalMeasured = null
355
- // Empty space (in pixels) above the view
356
- d.viewOffset = 0
357
- d.lastWrapHeight = d.lastWrapWidth = 0
358
- d.updateLineNumbers = null
359
-
360
- d.nativeBarWidth = d.barHeight = d.barWidth = 0
361
- d.scrollbarsClipped = false
362
-
363
- // Used to only resize the line number gutter when necessary (when
364
- // the amount of lines crosses a boundary that makes its width change)
365
- d.lineNumWidth = d.lineNumInnerWidth = d.lineNumChars = null
366
- // Set to true when a non-horizontal-scrolling line widget is
367
- // added. As an optimization, line widget aligning is skipped when
368
- // this is false.
369
- d.alignWidgets = false
370
-
371
- d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null
372
-
373
- // Tracks the maximum line length so that the horizontal scrollbar
374
- // can be kept static when scrolling.
375
- d.maxLine = null
376
- d.maxLineLength = 0
377
- d.maxLineChanged = false
378
-
379
- // Used for measuring wheel scrolling granularity
380
- d.wheelDX = d.wheelDY = d.wheelStartX = d.wheelStartY = null
381
-
382
- // True when shift is held down.
383
- d.shift = false
384
-
385
- // Used to track whether anything happened since the context menu
386
- // was opened.
387
- d.selForContextMenu = null
388
-
389
- d.activeTouch = null
390
-
391
- input.init(d)
392
- }
393
-
394
- // Find the line object corresponding to the given line number.
395
- function getLine(doc, n) {
396
- n -= doc.first
397
- if (n < 0 || n >= doc.size) { throw new Error("There is no line " + (n + doc.first) + " in the document.") }
398
- var chunk = doc
399
- while (!chunk.lines) {
400
- for (var i = 0;; ++i) {
401
- var child = chunk.children[i], sz = child.chunkSize()
402
- if (n < sz) { chunk = child; break }
403
- n -= sz
404
- }
405
- }
406
- return chunk.lines[n]
407
- }
408
-
409
- // Get the part of a document between two positions, as an array of
410
- // strings.
411
- function getBetween(doc, start, end) {
412
- var out = [], n = start.line
413
- doc.iter(start.line, end.line + 1, function (line) {
414
- var text = line.text
415
- if (n == end.line) { text = text.slice(0, end.ch) }
416
- if (n == start.line) { text = text.slice(start.ch) }
417
- out.push(text)
418
- ++n
419
- })
420
- return out
421
- }
422
- // Get the lines between from and to, as array of strings.
423
- function getLines(doc, from, to) {
424
- var out = []
425
- doc.iter(from, to, function (line) { out.push(line.text) }) // iter aborts when callback returns truthy value
426
- return out
427
- }
428
-
429
- // Update the height of a line, propagating the height change
430
- // upwards to parent nodes.
431
- function updateLineHeight(line, height) {
432
- var diff = height - line.height
433
- if (diff) { for (var n = line; n; n = n.parent) { n.height += diff } }
434
- }
435
-
436
- // Given a line object, find its line number by walking up through
437
- // its parent links.
438
- function lineNo(line) {
439
- if (line.parent == null) { return null }
440
- var cur = line.parent, no = indexOf(cur.lines, line)
441
- for (var chunk = cur.parent; chunk; cur = chunk, chunk = chunk.parent) {
442
- for (var i = 0;; ++i) {
443
- if (chunk.children[i] == cur) { break }
444
- no += chunk.children[i].chunkSize()
445
- }
446
- }
447
- return no + cur.first
448
- }
449
-
450
- // Find the line at the given vertical position, using the height
451
- // information in the document tree.
452
- function lineAtHeight(chunk, h) {
453
- var n = chunk.first
454
- outer: do {
455
- for (var i$1 = 0; i$1 < chunk.children.length; ++i$1) {
456
- var child = chunk.children[i$1], ch = child.height
457
- if (h < ch) { chunk = child; continue outer }
458
- h -= ch
459
- n += child.chunkSize()
460
- }
461
- return n
462
- } while (!chunk.lines)
463
- var i = 0
464
- for (; i < chunk.lines.length; ++i) {
465
- var line = chunk.lines[i], lh = line.height
466
- if (h < lh) { break }
467
- h -= lh
468
- }
469
- return n + i
470
- }
471
-
472
- function isLine(doc, l) {return l >= doc.first && l < doc.first + doc.size}
473
-
474
- function lineNumberFor(options, i) {
475
- return String(options.lineNumberFormatter(i + options.firstLineNumber))
476
- }
477
-
478
- // A Pos instance represents a position within the text.
479
- function Pos(line, ch, sticky) {
480
- if ( sticky === void 0 ) sticky = null;
481
-
482
- if (!(this instanceof Pos)) { return new Pos(line, ch, sticky) }
483
- this.line = line
484
- this.ch = ch
485
- this.sticky = sticky
486
- }
487
-
488
- // Compare two positions, return 0 if they are the same, a negative
489
- // number when a is less, and a positive number otherwise.
490
- function cmp(a, b) { return a.line - b.line || a.ch - b.ch }
491
-
492
- function equalCursorPos(a, b) { return a.sticky == b.sticky && cmp(a, b) == 0 }
493
-
494
- function copyPos(x) {return Pos(x.line, x.ch)}
495
- function maxPos(a, b) { return cmp(a, b) < 0 ? b : a }
496
- function minPos(a, b) { return cmp(a, b) < 0 ? a : b }
497
-
498
- // Most of the external API clips given positions to make sure they
499
- // actually exist within the document.
500
- function clipLine(doc, n) {return Math.max(doc.first, Math.min(n, doc.first + doc.size - 1))}
501
- function clipPos(doc, pos) {
502
- if (pos.line < doc.first) { return Pos(doc.first, 0) }
503
- var last = doc.first + doc.size - 1
504
- if (pos.line > last) { return Pos(last, getLine(doc, last).text.length) }
505
- return clipToLen(pos, getLine(doc, pos.line).text.length)
506
- }
507
- function clipToLen(pos, linelen) {
508
- var ch = pos.ch
509
- if (ch == null || ch > linelen) { return Pos(pos.line, linelen) }
510
- else if (ch < 0) { return Pos(pos.line, 0) }
511
- else { return pos }
512
- }
513
- function clipPosArray(doc, array) {
514
- var out = []
515
- for (var i = 0; i < array.length; i++) { out[i] = clipPos(doc, array[i]) }
516
- return out
517
- }
518
-
519
- // Optimize some code when these features are not used.
520
- var sawReadOnlySpans = false;
521
- var sawCollapsedSpans = false;
522
- function seeReadOnlySpans() {
523
- sawReadOnlySpans = true
524
- }
525
-
526
- function seeCollapsedSpans() {
527
- sawCollapsedSpans = true
528
- }
529
-
530
- // TEXTMARKER SPANS
531
-
532
- function MarkedSpan(marker, from, to) {
533
- this.marker = marker
534
- this.from = from; this.to = to
535
- }
536
-
537
- // Search an array of spans for a span matching the given marker.
538
- function getMarkedSpanFor(spans, marker) {
539
- if (spans) { for (var i = 0; i < spans.length; ++i) {
540
- var span = spans[i]
541
- if (span.marker == marker) { return span }
542
- } }
543
- }
544
- // Remove a span from an array, returning undefined if no spans are
545
- // left (we don't store arrays for lines without spans).
546
- function removeMarkedSpan(spans, span) {
547
- var r
548
- for (var i = 0; i < spans.length; ++i)
549
- { if (spans[i] != span) { (r || (r = [])).push(spans[i]) } }
550
- return r
551
- }
552
- // Add a span to a line.
553
- function addMarkedSpan(line, span) {
554
- line.markedSpans = line.markedSpans ? line.markedSpans.concat([span]) : [span]
555
- span.marker.attachLine(line)
556
- }
557
-
558
- // Used for the algorithm that adjusts markers for a change in the
559
- // document. These functions cut an array of spans at a given
560
- // character position, returning an array of remaining chunks (or
561
- // undefined if nothing remains).
562
- function markedSpansBefore(old, startCh, isInsert) {
563
- var nw
564
- if (old) { for (var i = 0; i < old.length; ++i) {
565
- var span = old[i], marker = span.marker
566
- var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= startCh : span.from < startCh)
567
- if (startsBefore || span.from == startCh && marker.type == "bookmark" && (!isInsert || !span.marker.insertLeft)) {
568
- var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= startCh : span.to > startCh)
569
- ;(nw || (nw = [])).push(new MarkedSpan(marker, span.from, endsAfter ? null : span.to))
570
- }
571
- } }
572
- return nw
573
- }
574
- function markedSpansAfter(old, endCh, isInsert) {
575
- var nw
576
- if (old) { for (var i = 0; i < old.length; ++i) {
577
- var span = old[i], marker = span.marker
578
- var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= endCh : span.to > endCh)
579
- if (endsAfter || span.from == endCh && marker.type == "bookmark" && (!isInsert || span.marker.insertLeft)) {
580
- var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= endCh : span.from < endCh)
581
- ;(nw || (nw = [])).push(new MarkedSpan(marker, startsBefore ? null : span.from - endCh,
582
- span.to == null ? null : span.to - endCh))
583
- }
584
- } }
585
- return nw
586
- }
587
-
588
- // Given a change object, compute the new set of marker spans that
589
- // cover the line in which the change took place. Removes spans
590
- // entirely within the change, reconnects spans belonging to the
591
- // same marker that appear on both sides of the change, and cuts off
592
- // spans partially within the change. Returns an array of span
593
- // arrays with one element for each line in (after) the change.
594
- function stretchSpansOverChange(doc, change) {
595
- if (change.full) { return null }
596
- var oldFirst = isLine(doc, change.from.line) && getLine(doc, change.from.line).markedSpans
597
- var oldLast = isLine(doc, change.to.line) && getLine(doc, change.to.line).markedSpans
598
- if (!oldFirst && !oldLast) { return null }
599
-
600
- var startCh = change.from.ch, endCh = change.to.ch, isInsert = cmp(change.from, change.to) == 0
601
- // Get the spans that 'stick out' on both sides
602
- var first = markedSpansBefore(oldFirst, startCh, isInsert)
603
- var last = markedSpansAfter(oldLast, endCh, isInsert)
604
-
605
- // Next, merge those two ends
606
- var sameLine = change.text.length == 1, offset = lst(change.text).length + (sameLine ? startCh : 0)
607
- if (first) {
608
- // Fix up .to properties of first
609
- for (var i = 0; i < first.length; ++i) {
610
- var span = first[i]
611
- if (span.to == null) {
612
- var found = getMarkedSpanFor(last, span.marker)
613
- if (!found) { span.to = startCh }
614
- else if (sameLine) { span.to = found.to == null ? null : found.to + offset }
615
- }
616
- }
617
- }
618
- if (last) {
619
- // Fix up .from in last (or move them into first in case of sameLine)
620
- for (var i$1 = 0; i$1 < last.length; ++i$1) {
621
- var span$1 = last[i$1]
622
- if (span$1.to != null) { span$1.to += offset }
623
- if (span$1.from == null) {
624
- var found$1 = getMarkedSpanFor(first, span$1.marker)
625
- if (!found$1) {
626
- span$1.from = offset
627
- if (sameLine) { (first || (first = [])).push(span$1) }
628
- }
629
- } else {
630
- span$1.from += offset
631
- if (sameLine) { (first || (first = [])).push(span$1) }
632
- }
633
- }
634
- }
635
- // Make sure we didn't create any zero-length spans
636
- if (first) { first = clearEmptySpans(first) }
637
- if (last && last != first) { last = clearEmptySpans(last) }
638
-
639
- var newMarkers = [first]
640
- if (!sameLine) {
641
- // Fill gap with whole-line-spans
642
- var gap = change.text.length - 2, gapMarkers
643
- if (gap > 0 && first)
644
- { for (var i$2 = 0; i$2 < first.length; ++i$2)
645
- { if (first[i$2].to == null)
646
- { (gapMarkers || (gapMarkers = [])).push(new MarkedSpan(first[i$2].marker, null, null)) } } }
647
- for (var i$3 = 0; i$3 < gap; ++i$3)
648
- { newMarkers.push(gapMarkers) }
649
- newMarkers.push(last)
650
- }
651
- return newMarkers
652
- }
653
-
654
- // Remove spans that are empty and don't have a clearWhenEmpty
655
- // option of false.
656
- function clearEmptySpans(spans) {
657
- for (var i = 0; i < spans.length; ++i) {
658
- var span = spans[i]
659
- if (span.from != null && span.from == span.to && span.marker.clearWhenEmpty !== false)
660
- { spans.splice(i--, 1) }
661
- }
662
- if (!spans.length) { return null }
663
- return spans
664
- }
665
-
666
- // Used to 'clip' out readOnly ranges when making a change.
667
- function removeReadOnlyRanges(doc, from, to) {
668
- var markers = null
669
- doc.iter(from.line, to.line + 1, function (line) {
670
- if (line.markedSpans) { for (var i = 0; i < line.markedSpans.length; ++i) {
671
- var mark = line.markedSpans[i].marker
672
- if (mark.readOnly && (!markers || indexOf(markers, mark) == -1))
673
- { (markers || (markers = [])).push(mark) }
674
- } }
675
- })
676
- if (!markers) { return null }
677
- var parts = [{from: from, to: to}]
678
- for (var i = 0; i < markers.length; ++i) {
679
- var mk = markers[i], m = mk.find(0)
680
- for (var j = 0; j < parts.length; ++j) {
681
- var p = parts[j]
682
- if (cmp(p.to, m.from) < 0 || cmp(p.from, m.to) > 0) { continue }
683
- var newParts = [j, 1], dfrom = cmp(p.from, m.from), dto = cmp(p.to, m.to)
684
- if (dfrom < 0 || !mk.inclusiveLeft && !dfrom)
685
- { newParts.push({from: p.from, to: m.from}) }
686
- if (dto > 0 || !mk.inclusiveRight && !dto)
687
- { newParts.push({from: m.to, to: p.to}) }
688
- parts.splice.apply(parts, newParts)
689
- j += newParts.length - 3
690
- }
691
- }
692
- return parts
693
- }
694
-
695
- // Connect or disconnect spans from a line.
696
- function detachMarkedSpans(line) {
697
- var spans = line.markedSpans
698
- if (!spans) { return }
699
- for (var i = 0; i < spans.length; ++i)
700
- { spans[i].marker.detachLine(line) }
701
- line.markedSpans = null
702
- }
703
- function attachMarkedSpans(line, spans) {
704
- if (!spans) { return }
705
- for (var i = 0; i < spans.length; ++i)
706
- { spans[i].marker.attachLine(line) }
707
- line.markedSpans = spans
708
- }
709
-
710
- // Helpers used when computing which overlapping collapsed span
711
- // counts as the larger one.
712
- function extraLeft(marker) { return marker.inclusiveLeft ? -1 : 0 }
713
- function extraRight(marker) { return marker.inclusiveRight ? 1 : 0 }
714
-
715
- // Returns a number indicating which of two overlapping collapsed
716
- // spans is larger (and thus includes the other). Falls back to
717
- // comparing ids when the spans cover exactly the same range.
718
- function compareCollapsedMarkers(a, b) {
719
- var lenDiff = a.lines.length - b.lines.length
720
- if (lenDiff != 0) { return lenDiff }
721
- var aPos = a.find(), bPos = b.find()
722
- var fromCmp = cmp(aPos.from, bPos.from) || extraLeft(a) - extraLeft(b)
723
- if (fromCmp) { return -fromCmp }
724
- var toCmp = cmp(aPos.to, bPos.to) || extraRight(a) - extraRight(b)
725
- if (toCmp) { return toCmp }
726
- return b.id - a.id
727
- }
728
-
729
- // Find out whether a line ends or starts in a collapsed span. If
730
- // so, return the marker for that span.
731
- function collapsedSpanAtSide(line, start) {
732
- var sps = sawCollapsedSpans && line.markedSpans, found
733
- if (sps) { for (var sp = (void 0), i = 0; i < sps.length; ++i) {
734
- sp = sps[i]
735
- if (sp.marker.collapsed && (start ? sp.from : sp.to) == null &&
736
- (!found || compareCollapsedMarkers(found, sp.marker) < 0))
737
- { found = sp.marker }
738
- } }
739
- return found
740
- }
741
- function collapsedSpanAtStart(line) { return collapsedSpanAtSide(line, true) }
742
- function collapsedSpanAtEnd(line) { return collapsedSpanAtSide(line, false) }
743
-
744
- // Test whether there exists a collapsed span that partially
745
- // overlaps (covers the start or end, but not both) of a new span.
746
- // Such overlap is not allowed.
747
- function conflictingCollapsedRange(doc, lineNo, from, to, marker) {
748
- var line = getLine(doc, lineNo)
749
- var sps = sawCollapsedSpans && line.markedSpans
750
- if (sps) { for (var i = 0; i < sps.length; ++i) {
751
- var sp = sps[i]
752
- if (!sp.marker.collapsed) { continue }
753
- var found = sp.marker.find(0)
754
- var fromCmp = cmp(found.from, from) || extraLeft(sp.marker) - extraLeft(marker)
755
- var toCmp = cmp(found.to, to) || extraRight(sp.marker) - extraRight(marker)
756
- if (fromCmp >= 0 && toCmp <= 0 || fromCmp <= 0 && toCmp >= 0) { continue }
757
- if (fromCmp <= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.to, from) >= 0 : cmp(found.to, from) > 0) ||
758
- fromCmp >= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.from, to) <= 0 : cmp(found.from, to) < 0))
759
- { return true }
760
- } }
761
- }
762
-
763
- // A visual line is a line as drawn on the screen. Folding, for
764
- // example, can cause multiple logical lines to appear on the same
765
- // visual line. This finds the start of the visual line that the
766
- // given line is part of (usually that is the line itself).
767
- function visualLine(line) {
768
- var merged
769
- while (merged = collapsedSpanAtStart(line))
770
- { line = merged.find(-1, true).line }
771
- return line
772
- }
773
-
774
- function visualLineEnd(line) {
775
- var merged
776
- while (merged = collapsedSpanAtEnd(line))
777
- { line = merged.find(1, true).line }
778
- return line
779
- }
780
-
781
- // Returns an array of logical lines that continue the visual line
782
- // started by the argument, or undefined if there are no such lines.
783
- function visualLineContinued(line) {
784
- var merged, lines
785
- while (merged = collapsedSpanAtEnd(line)) {
786
- line = merged.find(1, true).line
787
- ;(lines || (lines = [])).push(line)
788
- }
789
- return lines
790
- }
791
-
792
- // Get the line number of the start of the visual line that the
793
- // given line number is part of.
794
- function visualLineNo(doc, lineN) {
795
- var line = getLine(doc, lineN), vis = visualLine(line)
796
- if (line == vis) { return lineN }
797
- return lineNo(vis)
798
- }
799
-
800
- // Get the line number of the start of the next visual line after
801
- // the given line.
802
- function visualLineEndNo(doc, lineN) {
803
- if (lineN > doc.lastLine()) { return lineN }
804
- var line = getLine(doc, lineN), merged
805
- if (!lineIsHidden(doc, line)) { return lineN }
806
- while (merged = collapsedSpanAtEnd(line))
807
- { line = merged.find(1, true).line }
808
- return lineNo(line) + 1
809
- }
810
-
811
- // Compute whether a line is hidden. Lines count as hidden when they
812
- // are part of a visual line that starts with another line, or when
813
- // they are entirely covered by collapsed, non-widget span.
814
- function lineIsHidden(doc, line) {
815
- var sps = sawCollapsedSpans && line.markedSpans
816
- if (sps) { for (var sp = (void 0), i = 0; i < sps.length; ++i) {
817
- sp = sps[i]
818
- if (!sp.marker.collapsed) { continue }
819
- if (sp.from == null) { return true }
820
- if (sp.marker.widgetNode) { continue }
821
- if (sp.from == 0 && sp.marker.inclusiveLeft && lineIsHiddenInner(doc, line, sp))
822
- { return true }
823
- } }
824
- }
825
- function lineIsHiddenInner(doc, line, span) {
826
- if (span.to == null) {
827
- var end = span.marker.find(1, true)
828
- return lineIsHiddenInner(doc, end.line, getMarkedSpanFor(end.line.markedSpans, span.marker))
829
- }
830
- if (span.marker.inclusiveRight && span.to == line.text.length)
831
- { return true }
832
- for (var sp = (void 0), i = 0; i < line.markedSpans.length; ++i) {
833
- sp = line.markedSpans[i]
834
- if (sp.marker.collapsed && !sp.marker.widgetNode && sp.from == span.to &&
835
- (sp.to == null || sp.to != span.from) &&
836
- (sp.marker.inclusiveLeft || span.marker.inclusiveRight) &&
837
- lineIsHiddenInner(doc, line, sp)) { return true }
838
- }
839
- }
840
-
841
- // Find the height above the given line.
842
- function heightAtLine(lineObj) {
843
- lineObj = visualLine(lineObj)
844
-
845
- var h = 0, chunk = lineObj.parent
846
- for (var i = 0; i < chunk.lines.length; ++i) {
847
- var line = chunk.lines[i]
848
- if (line == lineObj) { break }
849
- else { h += line.height }
850
- }
851
- for (var p = chunk.parent; p; chunk = p, p = chunk.parent) {
852
- for (var i$1 = 0; i$1 < p.children.length; ++i$1) {
853
- var cur = p.children[i$1]
854
- if (cur == chunk) { break }
855
- else { h += cur.height }
856
- }
857
- }
858
- return h
859
- }
860
-
861
- // Compute the character length of a line, taking into account
862
- // collapsed ranges (see markText) that might hide parts, and join
863
- // other lines onto it.
864
- function lineLength(line) {
865
- if (line.height == 0) { return 0 }
866
- var len = line.text.length, merged, cur = line
867
- while (merged = collapsedSpanAtStart(cur)) {
868
- var found = merged.find(0, true)
869
- cur = found.from.line
870
- len += found.from.ch - found.to.ch
871
- }
872
- cur = line
873
- while (merged = collapsedSpanAtEnd(cur)) {
874
- var found$1 = merged.find(0, true)
875
- len -= cur.text.length - found$1.from.ch
876
- cur = found$1.to.line
877
- len += cur.text.length - found$1.to.ch
878
- }
879
- return len
880
- }
881
-
882
- // Find the longest line in the document.
883
- function findMaxLine(cm) {
884
- var d = cm.display, doc = cm.doc
885
- d.maxLine = getLine(doc, doc.first)
886
- d.maxLineLength = lineLength(d.maxLine)
887
- d.maxLineChanged = true
888
- doc.iter(function (line) {
889
- var len = lineLength(line)
890
- if (len > d.maxLineLength) {
891
- d.maxLineLength = len
892
- d.maxLine = line
893
- }
894
- })
895
- }
896
-
897
- // BIDI HELPERS
898
-
899
- function iterateBidiSections(order, from, to, f) {
900
- if (!order) { return f(from, to, "ltr") }
901
- var found = false
902
- for (var i = 0; i < order.length; ++i) {
903
- var part = order[i]
904
- if (part.from < to && part.to > from || from == to && part.to == from) {
905
- f(Math.max(part.from, from), Math.min(part.to, to), part.level == 1 ? "rtl" : "ltr")
906
- found = true
907
- }
908
- }
909
- if (!found) { f(from, to, "ltr") }
910
- }
911
-
912
- var bidiOther = null
913
- function getBidiPartAt(order, ch, sticky) {
914
- var found
915
- bidiOther = null
916
- for (var i = 0; i < order.length; ++i) {
917
- var cur = order[i]
918
- if (cur.from < ch && cur.to > ch) { return i }
919
- if (cur.to == ch) {
920
- if (cur.from != cur.to && sticky == "before") { found = i }
921
- else { bidiOther = i }
922
- }
923
- if (cur.from == ch) {
924
- if (cur.from != cur.to && sticky != "before") { found = i }
925
- else { bidiOther = i }
926
- }
927
- }
928
- return found != null ? found : bidiOther
929
- }
930
-
931
- // Bidirectional ordering algorithm
932
- // See http://unicode.org/reports/tr9/tr9-13.html for the algorithm
933
- // that this (partially) implements.
934
-
935
- // One-char codes used for character types:
936
- // L (L): Left-to-Right
937
- // R (R): Right-to-Left
938
- // r (AL): Right-to-Left Arabic
939
- // 1 (EN): European Number
940
- // + (ES): European Number Separator
941
- // % (ET): European Number Terminator
942
- // n (AN): Arabic Number
943
- // , (CS): Common Number Separator
944
- // m (NSM): Non-Spacing Mark
945
- // b (BN): Boundary Neutral
946
- // s (B): Paragraph Separator
947
- // t (S): Segment Separator
948
- // w (WS): Whitespace
949
- // N (ON): Other Neutrals
950
-
951
- // Returns null if characters are ordered as they appear
952
- // (left-to-right), or an array of sections ({from, to, level}
953
- // objects) in the order in which they occur visually.
954
- var bidiOrdering = (function() {
955
- // Character types for codepoints 0 to 0xff
956
- var lowTypes = "bbbbbbbbbtstwsbbbbbbbbbbbbbbssstwNN%%%NNNNNN,N,N1111111111NNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNbbbbbbsbbbbbbbbbbbbbbbbbbbbbbbbbb,N%%%%NNNNLNNNNN%%11NLNNN1LNNNNNLLLLLLLLLLLLLLLLLLLLLLLNLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLN"
957
- // Character types for codepoints 0x600 to 0x6f9
958
- var arabicTypes = "nnnnnnNNr%%r,rNNmmmmmmmmmmmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmmmmmmmmmmmmmmmnnnnnnnnnn%nnrrrmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmnNmmmmmmrrmmNmmmmrr1111111111"
959
- function charType(code) {
960
- if (code <= 0xf7) { return lowTypes.charAt(code) }
961
- else if (0x590 <= code && code <= 0x5f4) { return "R" }
962
- else if (0x600 <= code && code <= 0x6f9) { return arabicTypes.charAt(code - 0x600) }
963
- else if (0x6ee <= code && code <= 0x8ac) { return "r" }
964
- else if (0x2000 <= code && code <= 0x200b) { return "w" }
965
- else if (code == 0x200c) { return "b" }
966
- else { return "L" }
967
- }
968
-
969
- var bidiRE = /[\u0590-\u05f4\u0600-\u06ff\u0700-\u08ac]/
970
- var isNeutral = /[stwN]/, isStrong = /[LRr]/, countsAsLeft = /[Lb1n]/, countsAsNum = /[1n]/
971
-
972
- function BidiSpan(level, from, to) {
973
- this.level = level
974
- this.from = from; this.to = to
975
- }
976
-
977
- return function(str, direction) {
978
- var outerType = direction == "ltr" ? "L" : "R"
979
-
980
- if (str.length == 0 || direction == "ltr" && !bidiRE.test(str)) { return false }
981
- var len = str.length, types = []
982
- for (var i = 0; i < len; ++i)
983
- { types.push(charType(str.charCodeAt(i))) }
984
-
985
- // W1. Examine each non-spacing mark (NSM) in the level run, and
986
- // change the type of the NSM to the type of the previous
987
- // character. If the NSM is at the start of the level run, it will
988
- // get the type of sor.
989
- for (var i$1 = 0, prev = outerType; i$1 < len; ++i$1) {
990
- var type = types[i$1]
991
- if (type == "m") { types[i$1] = prev }
992
- else { prev = type }
993
- }
994
-
995
- // W2. Search backwards from each instance of a European number
996
- // until the first strong type (R, L, AL, or sor) is found. If an
997
- // AL is found, change the type of the European number to Arabic
998
- // number.
999
- // W3. Change all ALs to R.
1000
- for (var i$2 = 0, cur = outerType; i$2 < len; ++i$2) {
1001
- var type$1 = types[i$2]
1002
- if (type$1 == "1" && cur == "r") { types[i$2] = "n" }
1003
- else if (isStrong.test(type$1)) { cur = type$1; if (type$1 == "r") { types[i$2] = "R" } }
1004
- }
1005
-
1006
- // W4. A single European separator between two European numbers
1007
- // changes to a European number. A single common separator between
1008
- // two numbers of the same type changes to that type.
1009
- for (var i$3 = 1, prev$1 = types[0]; i$3 < len - 1; ++i$3) {
1010
- var type$2 = types[i$3]
1011
- if (type$2 == "+" && prev$1 == "1" && types[i$3+1] == "1") { types[i$3] = "1" }
1012
- else if (type$2 == "," && prev$1 == types[i$3+1] &&
1013
- (prev$1 == "1" || prev$1 == "n")) { types[i$3] = prev$1 }
1014
- prev$1 = type$2
1015
- }
1016
-
1017
- // W5. A sequence of European terminators adjacent to European
1018
- // numbers changes to all European numbers.
1019
- // W6. Otherwise, separators and terminators change to Other
1020
- // Neutral.
1021
- for (var i$4 = 0; i$4 < len; ++i$4) {
1022
- var type$3 = types[i$4]
1023
- if (type$3 == ",") { types[i$4] = "N" }
1024
- else if (type$3 == "%") {
1025
- var end = (void 0)
1026
- for (end = i$4 + 1; end < len && types[end] == "%"; ++end) {}
1027
- var replace = (i$4 && types[i$4-1] == "!") || (end < len && types[end] == "1") ? "1" : "N"
1028
- for (var j = i$4; j < end; ++j) { types[j] = replace }
1029
- i$4 = end - 1
1030
- }
1031
- }
1032
-
1033
- // W7. Search backwards from each instance of a European number
1034
- // until the first strong type (R, L, or sor) is found. If an L is
1035
- // found, then change the type of the European number to L.
1036
- for (var i$5 = 0, cur$1 = outerType; i$5 < len; ++i$5) {
1037
- var type$4 = types[i$5]
1038
- if (cur$1 == "L" && type$4 == "1") { types[i$5] = "L" }
1039
- else if (isStrong.test(type$4)) { cur$1 = type$4 }
1040
- }
1041
-
1042
- // N1. A sequence of neutrals takes the direction of the
1043
- // surrounding strong text if the text on both sides has the same
1044
- // direction. European and Arabic numbers act as if they were R in
1045
- // terms of their influence on neutrals. Start-of-level-run (sor)
1046
- // and end-of-level-run (eor) are used at level run boundaries.
1047
- // N2. Any remaining neutrals take the embedding direction.
1048
- for (var i$6 = 0; i$6 < len; ++i$6) {
1049
- if (isNeutral.test(types[i$6])) {
1050
- var end$1 = (void 0)
1051
- for (end$1 = i$6 + 1; end$1 < len && isNeutral.test(types[end$1]); ++end$1) {}
1052
- var before = (i$6 ? types[i$6-1] : outerType) == "L"
1053
- var after = (end$1 < len ? types[end$1] : outerType) == "L"
1054
- var replace$1 = before == after ? (before ? "L" : "R") : outerType
1055
- for (var j$1 = i$6; j$1 < end$1; ++j$1) { types[j$1] = replace$1 }
1056
- i$6 = end$1 - 1
1057
- }
1058
- }
1059
-
1060
- // Here we depart from the documented algorithm, in order to avoid
1061
- // building up an actual levels array. Since there are only three
1062
- // levels (0, 1, 2) in an implementation that doesn't take
1063
- // explicit embedding into account, we can build up the order on
1064
- // the fly, without following the level-based algorithm.
1065
- var order = [], m
1066
- for (var i$7 = 0; i$7 < len;) {
1067
- if (countsAsLeft.test(types[i$7])) {
1068
- var start = i$7
1069
- for (++i$7; i$7 < len && countsAsLeft.test(types[i$7]); ++i$7) {}
1070
- order.push(new BidiSpan(0, start, i$7))
1071
- } else {
1072
- var pos = i$7, at = order.length
1073
- for (++i$7; i$7 < len && types[i$7] != "L"; ++i$7) {}
1074
- for (var j$2 = pos; j$2 < i$7;) {
1075
- if (countsAsNum.test(types[j$2])) {
1076
- if (pos < j$2) { order.splice(at, 0, new BidiSpan(1, pos, j$2)) }
1077
- var nstart = j$2
1078
- for (++j$2; j$2 < i$7 && countsAsNum.test(types[j$2]); ++j$2) {}
1079
- order.splice(at, 0, new BidiSpan(2, nstart, j$2))
1080
- pos = j$2
1081
- } else { ++j$2 }
1082
- }
1083
- if (pos < i$7) { order.splice(at, 0, new BidiSpan(1, pos, i$7)) }
1084
- }
1085
- }
1086
- if (order[0].level == 1 && (m = str.match(/^\s+/))) {
1087
- order[0].from = m[0].length
1088
- order.unshift(new BidiSpan(0, 0, m[0].length))
1089
- }
1090
- if (lst(order).level == 1 && (m = str.match(/\s+$/))) {
1091
- lst(order).to -= m[0].length
1092
- order.push(new BidiSpan(0, len - m[0].length, len))
1093
- }
1094
-
1095
- return direction == "rtl" ? order.reverse() : order
1096
- }
1097
- })()
1098
-
1099
- // Get the bidi ordering for the given line (and cache it). Returns
1100
- // false for lines that are fully left-to-right, and an array of
1101
- // BidiSpan objects otherwise.
1102
- function getOrder(line, direction) {
1103
- var order = line.order
1104
- if (order == null) { order = line.order = bidiOrdering(line.text, direction) }
1105
- return order
1106
- }
1107
-
1108
- function moveCharLogically(line, ch, dir) {
1109
- var target = skipExtendingChars(line.text, ch + dir, dir)
1110
- return target < 0 || target > line.text.length ? null : target
1111
- }
1112
-
1113
- function moveLogically(line, start, dir) {
1114
- var ch = moveCharLogically(line, start.ch, dir)
1115
- return ch == null ? null : new Pos(start.line, ch, dir < 0 ? "after" : "before")
1116
- }
1117
-
1118
- function endOfLine(visually, cm, lineObj, lineNo, dir) {
1119
- if (visually) {
1120
- var order = getOrder(lineObj, cm.doc.direction)
1121
- if (order) {
1122
- var part = dir < 0 ? lst(order) : order[0]
1123
- var moveInStorageOrder = (dir < 0) == (part.level == 1)
1124
- var sticky = moveInStorageOrder ? "after" : "before"
1125
- var ch
1126
- // With a wrapped rtl chunk (possibly spanning multiple bidi parts),
1127
- // it could be that the last bidi part is not on the last visual line,
1128
- // since visual lines contain content order-consecutive chunks.
1129
- // Thus, in rtl, we are looking for the first (content-order) character
1130
- // in the rtl chunk that is on the last line (that is, the same line
1131
- // as the last (content-order) character).
1132
- if (part.level > 0) {
1133
- var prep = prepareMeasureForLine(cm, lineObj)
1134
- ch = dir < 0 ? lineObj.text.length - 1 : 0
1135
- var targetTop = measureCharPrepared(cm, prep, ch).top
1136
- ch = findFirst(function (ch) { return measureCharPrepared(cm, prep, ch).top == targetTop; }, (dir < 0) == (part.level == 1) ? part.from : part.to - 1, ch)
1137
- if (sticky == "before") { ch = moveCharLogically(lineObj, ch, 1) }
1138
- } else { ch = dir < 0 ? part.to : part.from }
1139
- return new Pos(lineNo, ch, sticky)
1140
- }
1141
- }
1142
- return new Pos(lineNo, dir < 0 ? lineObj.text.length : 0, dir < 0 ? "before" : "after")
1143
- }
1144
-
1145
- function moveVisually(cm, line, start, dir) {
1146
- var bidi = getOrder(line, cm.doc.direction)
1147
- if (!bidi) { return moveLogically(line, start, dir) }
1148
- if (start.ch >= line.text.length) {
1149
- start.ch = line.text.length
1150
- start.sticky = "before"
1151
- } else if (start.ch <= 0) {
1152
- start.ch = 0
1153
- start.sticky = "after"
1154
- }
1155
- var partPos = getBidiPartAt(bidi, start.ch, start.sticky), part = bidi[partPos]
1156
- if (cm.doc.direction == "ltr" && part.level % 2 == 0 && (dir > 0 ? part.to > start.ch : part.from < start.ch)) {
1157
- // Case 1: We move within an ltr part in an ltr editor. Even with wrapped lines,
1158
- // nothing interesting happens.
1159
- return moveLogically(line, start, dir)
1160
- }
1161
-
1162
- var mv = function (pos, dir) { return moveCharLogically(line, pos instanceof Pos ? pos.ch : pos, dir); }
1163
- var prep
1164
- var getWrappedLineExtent = function (ch) {
1165
- if (!cm.options.lineWrapping) { return {begin: 0, end: line.text.length} }
1166
- prep = prep || prepareMeasureForLine(cm, line)
1167
- return wrappedLineExtentChar(cm, line, prep, ch)
1168
- }
1169
- var wrappedLineExtent = getWrappedLineExtent(start.sticky == "before" ? mv(start, -1) : start.ch)
1170
-
1171
- if (cm.doc.direction == "rtl" || part.level == 1) {
1172
- var moveInStorageOrder = (part.level == 1) == (dir < 0)
1173
- var ch = mv(start, moveInStorageOrder ? 1 : -1)
1174
- if (ch != null && (!moveInStorageOrder ? ch >= part.from && ch >= wrappedLineExtent.begin : ch <= part.to && ch <= wrappedLineExtent.end)) {
1175
- // Case 2: We move within an rtl part or in an rtl editor on the same visual line
1176
- var sticky = moveInStorageOrder ? "before" : "after"
1177
- return new Pos(start.line, ch, sticky)
1178
- }
1179
- }
1180
-
1181
- // Case 3: Could not move within this bidi part in this visual line, so leave
1182
- // the current bidi part
1183
-
1184
- var searchInVisualLine = function (partPos, dir, wrappedLineExtent) {
1185
- var getRes = function (ch, moveInStorageOrder) { return moveInStorageOrder
1186
- ? new Pos(start.line, mv(ch, 1), "before")
1187
- : new Pos(start.line, ch, "after"); }
1188
-
1189
- for (; partPos >= 0 && partPos < bidi.length; partPos += dir) {
1190
- var part = bidi[partPos]
1191
- var moveInStorageOrder = (dir > 0) == (part.level != 1)
1192
- var ch = moveInStorageOrder ? wrappedLineExtent.begin : mv(wrappedLineExtent.end, -1)
1193
- if (part.from <= ch && ch < part.to) { return getRes(ch, moveInStorageOrder) }
1194
- ch = moveInStorageOrder ? part.from : mv(part.to, -1)
1195
- if (wrappedLineExtent.begin <= ch && ch < wrappedLineExtent.end) { return getRes(ch, moveInStorageOrder) }
1196
- }
1197
- }
1198
-
1199
- // Case 3a: Look for other bidi parts on the same visual line
1200
- var res = searchInVisualLine(partPos + dir, dir, wrappedLineExtent)
1201
- if (res) { return res }
1202
-
1203
- // Case 3b: Look for other bidi parts on the next visual line
1204
- var nextCh = dir > 0 ? wrappedLineExtent.end : mv(wrappedLineExtent.begin, -1)
1205
- if (nextCh != null && !(dir > 0 && nextCh == line.text.length)) {
1206
- res = searchInVisualLine(dir > 0 ? 0 : bidi.length - 1, dir, getWrappedLineExtent(nextCh))
1207
- if (res) { return res }
1208
- }
1209
-
1210
- // Case 4: Nowhere to move
1211
- return null
1212
- }
1213
-
1214
- // EVENT HANDLING
1215
-
1216
- // Lightweight event framework. on/off also work on DOM nodes,
1217
- // registering native DOM handlers.
1218
-
1219
- var noHandlers = []
1220
-
1221
- var on = function(emitter, type, f) {
1222
- if (emitter.addEventListener) {
1223
- emitter.addEventListener(type, f, false)
1224
- } else if (emitter.attachEvent) {
1225
- emitter.attachEvent("on" + type, f)
1226
- } else {
1227
- var map = emitter._handlers || (emitter._handlers = {})
1228
- map[type] = (map[type] || noHandlers).concat(f)
1229
- }
1230
- }
1231
-
1232
- function getHandlers(emitter, type) {
1233
- return emitter._handlers && emitter._handlers[type] || noHandlers
1234
- }
1235
-
1236
- function off(emitter, type, f) {
1237
- if (emitter.removeEventListener) {
1238
- emitter.removeEventListener(type, f, false)
1239
- } else if (emitter.detachEvent) {
1240
- emitter.detachEvent("on" + type, f)
1241
- } else {
1242
- var map = emitter._handlers, arr = map && map[type]
1243
- if (arr) {
1244
- var index = indexOf(arr, f)
1245
- if (index > -1)
1246
- { map[type] = arr.slice(0, index).concat(arr.slice(index + 1)) }
1247
- }
1248
- }
1249
- }
1250
-
1251
- function signal(emitter, type /*, values...*/) {
1252
- var handlers = getHandlers(emitter, type)
1253
- if (!handlers.length) { return }
1254
- var args = Array.prototype.slice.call(arguments, 2)
1255
- for (var i = 0; i < handlers.length; ++i) { handlers[i].apply(null, args) }
1256
- }
1257
-
1258
- // The DOM events that CodeMirror handles can be overridden by
1259
- // registering a (non-DOM) handler on the editor for the event name,
1260
- // and preventDefault-ing the event in that handler.
1261
- function signalDOMEvent(cm, e, override) {
1262
- if (typeof e == "string")
1263
- { e = {type: e, preventDefault: function() { this.defaultPrevented = true }} }
1264
- signal(cm, override || e.type, cm, e)
1265
- return e_defaultPrevented(e) || e.codemirrorIgnore
1266
- }
1267
-
1268
- function signalCursorActivity(cm) {
1269
- var arr = cm._handlers && cm._handlers.cursorActivity
1270
- if (!arr) { return }
1271
- var set = cm.curOp.cursorActivityHandlers || (cm.curOp.cursorActivityHandlers = [])
1272
- for (var i = 0; i < arr.length; ++i) { if (indexOf(set, arr[i]) == -1)
1273
- { set.push(arr[i]) } }
1274
- }
1275
-
1276
- function hasHandler(emitter, type) {
1277
- return getHandlers(emitter, type).length > 0
1278
- }
1279
-
1280
- // Add on and off methods to a constructor's prototype, to make
1281
- // registering events on such objects more convenient.
1282
- function eventMixin(ctor) {
1283
- ctor.prototype.on = function(type, f) {on(this, type, f)}
1284
- ctor.prototype.off = function(type, f) {off(this, type, f)}
1285
- }
1286
-
1287
- // Due to the fact that we still support jurassic IE versions, some
1288
- // compatibility wrappers are needed.
1289
-
1290
- function e_preventDefault(e) {
1291
- if (e.preventDefault) { e.preventDefault() }
1292
- else { e.returnValue = false }
1293
- }
1294
- function e_stopPropagation(e) {
1295
- if (e.stopPropagation) { e.stopPropagation() }
1296
- else { e.cancelBubble = true }
1297
- }
1298
- function e_defaultPrevented(e) {
1299
- return e.defaultPrevented != null ? e.defaultPrevented : e.returnValue == false
1300
- }
1301
- function e_stop(e) {e_preventDefault(e); e_stopPropagation(e)}
1302
-
1303
- function e_target(e) {return e.target || e.srcElement}
1304
- function e_button(e) {
1305
- var b = e.which
1306
- if (b == null) {
1307
- if (e.button & 1) { b = 1 }
1308
- else if (e.button & 2) { b = 3 }
1309
- else if (e.button & 4) { b = 2 }
1310
- }
1311
- if (mac && e.ctrlKey && b == 1) { b = 3 }
1312
- return b
1313
- }
1314
-
1315
- // Detect drag-and-drop
1316
- var dragAndDrop = function() {
1317
- // There is *some* kind of drag-and-drop support in IE6-8, but I
1318
- // couldn't get it to work yet.
1319
- if (ie && ie_version < 9) { return false }
1320
- var div = elt('div')
1321
- return "draggable" in div || "dragDrop" in div
1322
- }()
1323
-
1324
- var zwspSupported
1325
- function zeroWidthElement(measure) {
1326
- if (zwspSupported == null) {
1327
- var test = elt("span", "\u200b")
1328
- removeChildrenAndAdd(measure, elt("span", [test, document.createTextNode("x")]))
1329
- if (measure.firstChild.offsetHeight != 0)
1330
- { zwspSupported = test.offsetWidth <= 1 && test.offsetHeight > 2 && !(ie && ie_version < 8) }
1331
- }
1332
- var node = zwspSupported ? elt("span", "\u200b") :
1333
- elt("span", "\u00a0", null, "display: inline-block; width: 1px; margin-right: -1px")
1334
- node.setAttribute("cm-text", "")
1335
- return node
1336
- }
1337
-
1338
- // Feature-detect IE's crummy client rect reporting for bidi text
1339
- var badBidiRects
1340
- function hasBadBidiRects(measure) {
1341
- if (badBidiRects != null) { return badBidiRects }
1342
- var txt = removeChildrenAndAdd(measure, document.createTextNode("A\u062eA"))
1343
- var r0 = range(txt, 0, 1).getBoundingClientRect()
1344
- var r1 = range(txt, 1, 2).getBoundingClientRect()
1345
- removeChildren(measure)
1346
- if (!r0 || r0.left == r0.right) { return false } // Safari returns null in some cases (#2780)
1347
- return badBidiRects = (r1.right - r0.right < 3)
1348
- }
1349
-
1350
- // See if "".split is the broken IE version, if so, provide an
1351
- // alternative way to split lines.
1352
- var splitLinesAuto = "\n\nb".split(/\n/).length != 3 ? function (string) {
1353
- var pos = 0, result = [], l = string.length
1354
- while (pos <= l) {
1355
- var nl = string.indexOf("\n", pos)
1356
- if (nl == -1) { nl = string.length }
1357
- var line = string.slice(pos, string.charAt(nl - 1) == "\r" ? nl - 1 : nl)
1358
- var rt = line.indexOf("\r")
1359
- if (rt != -1) {
1360
- result.push(line.slice(0, rt))
1361
- pos += rt + 1
1362
- } else {
1363
- result.push(line)
1364
- pos = nl + 1
1365
- }
1366
- }
1367
- return result
1368
- } : function (string) { return string.split(/\r\n?|\n/); }
1369
-
1370
- var hasSelection = window.getSelection ? function (te) {
1371
- try { return te.selectionStart != te.selectionEnd }
1372
- catch(e) { return false }
1373
- } : function (te) {
1374
- var range
1375
- try {range = te.ownerDocument.selection.createRange()}
1376
- catch(e) {}
1377
- if (!range || range.parentElement() != te) { return false }
1378
- return range.compareEndPoints("StartToEnd", range) != 0
1379
- }
1380
-
1381
- var hasCopyEvent = (function () {
1382
- var e = elt("div")
1383
- if ("oncopy" in e) { return true }
1384
- e.setAttribute("oncopy", "return;")
1385
- return typeof e.oncopy == "function"
1386
- })()
1387
-
1388
- var badZoomedRects = null
1389
- function hasBadZoomedRects(measure) {
1390
- if (badZoomedRects != null) { return badZoomedRects }
1391
- var node = removeChildrenAndAdd(measure, elt("span", "x"))
1392
- var normal = node.getBoundingClientRect()
1393
- var fromRange = range(node, 0, 1).getBoundingClientRect()
1394
- return badZoomedRects = Math.abs(normal.left - fromRange.left) > 1
1395
- }
1396
-
1397
- var modes = {};
1398
- var mimeModes = {};
1399
- // Extra arguments are stored as the mode's dependencies, which is
1400
- // used by (legacy) mechanisms like loadmode.js to automatically
1401
- // load a mode. (Preferred mechanism is the require/define calls.)
1402
- function defineMode(name, mode) {
1403
- if (arguments.length > 2)
1404
- { mode.dependencies = Array.prototype.slice.call(arguments, 2) }
1405
- modes[name] = mode
1406
- }
1407
-
1408
- function defineMIME(mime, spec) {
1409
- mimeModes[mime] = spec
1410
- }
1411
-
1412
- // Given a MIME type, a {name, ...options} config object, or a name
1413
- // string, return a mode config object.
1414
- function resolveMode(spec) {
1415
- if (typeof spec == "string" && mimeModes.hasOwnProperty(spec)) {
1416
- spec = mimeModes[spec]
1417
- } else if (spec && typeof spec.name == "string" && mimeModes.hasOwnProperty(spec.name)) {
1418
- var found = mimeModes[spec.name]
1419
- if (typeof found == "string") { found = {name: found} }
1420
- spec = createObj(found, spec)
1421
- spec.name = found.name
1422
- } else if (typeof spec == "string" && /^[\w\-]+\/[\w\-]+\+xml$/.test(spec)) {
1423
- return resolveMode("application/xml")
1424
- } else if (typeof spec == "string" && /^[\w\-]+\/[\w\-]+\+json$/.test(spec)) {
1425
- return resolveMode("application/json")
1426
- }
1427
- if (typeof spec == "string") { return {name: spec} }
1428
- else { return spec || {name: "null"} }
1429
- }
1430
-
1431
- // Given a mode spec (anything that resolveMode accepts), find and
1432
- // initialize an actual mode object.
1433
- function getMode(options, spec) {
1434
- spec = resolveMode(spec)
1435
- var mfactory = modes[spec.name]
1436
- if (!mfactory) { return getMode(options, "text/plain") }
1437
- var modeObj = mfactory(options, spec)
1438
- if (modeExtensions.hasOwnProperty(spec.name)) {
1439
- var exts = modeExtensions[spec.name]
1440
- for (var prop in exts) {
1441
- if (!exts.hasOwnProperty(prop)) { continue }
1442
- if (modeObj.hasOwnProperty(prop)) { modeObj["_" + prop] = modeObj[prop] }
1443
- modeObj[prop] = exts[prop]
1444
- }
1445
- }
1446
- modeObj.name = spec.name
1447
- if (spec.helperType) { modeObj.helperType = spec.helperType }
1448
- if (spec.modeProps) { for (var prop$1 in spec.modeProps)
1449
- { modeObj[prop$1] = spec.modeProps[prop$1] } }
1450
-
1451
- return modeObj
1452
- }
1453
-
1454
- // This can be used to attach properties to mode objects from
1455
- // outside the actual mode definition.
1456
- var modeExtensions = {}
1457
- function extendMode(mode, properties) {
1458
- var exts = modeExtensions.hasOwnProperty(mode) ? modeExtensions[mode] : (modeExtensions[mode] = {})
1459
- copyObj(properties, exts)
1460
- }
1461
-
1462
- function copyState(mode, state) {
1463
- if (state === true) { return state }
1464
- if (mode.copyState) { return mode.copyState(state) }
1465
- var nstate = {}
1466
- for (var n in state) {
1467
- var val = state[n]
1468
- if (val instanceof Array) { val = val.concat([]) }
1469
- nstate[n] = val
1470
- }
1471
- return nstate
1472
- }
1473
-
1474
- // Given a mode and a state (for that mode), find the inner mode and
1475
- // state at the position that the state refers to.
1476
- function innerMode(mode, state) {
1477
- var info
1478
- while (mode.innerMode) {
1479
- info = mode.innerMode(state)
1480
- if (!info || info.mode == mode) { break }
1481
- state = info.state
1482
- mode = info.mode
1483
- }
1484
- return info || {mode: mode, state: state}
1485
- }
1486
-
1487
- function startState(mode, a1, a2) {
1488
- return mode.startState ? mode.startState(a1, a2) : true
1489
- }
1490
-
1491
- // STRING STREAM
1492
-
1493
- // Fed to the mode parsers, provides helper functions to make
1494
- // parsers more succinct.
1495
-
1496
- var StringStream = function(string, tabSize) {
1497
- this.pos = this.start = 0
1498
- this.string = string
1499
- this.tabSize = tabSize || 8
1500
- this.lastColumnPos = this.lastColumnValue = 0
1501
- this.lineStart = 0
1502
- };
1503
-
1504
- StringStream.prototype.eol = function () {return this.pos >= this.string.length};
1505
- StringStream.prototype.sol = function () {return this.pos == this.lineStart};
1506
- StringStream.prototype.peek = function () {return this.string.charAt(this.pos) || undefined};
1507
- StringStream.prototype.next = function () {
1508
- if (this.pos < this.string.length)
1509
- { return this.string.charAt(this.pos++) }
1510
- };
1511
- StringStream.prototype.eat = function (match) {
1512
- var ch = this.string.charAt(this.pos)
1513
- var ok
1514
- if (typeof match == "string") { ok = ch == match }
1515
- else { ok = ch && (match.test ? match.test(ch) : match(ch)) }
1516
- if (ok) {++this.pos; return ch}
1517
- };
1518
- StringStream.prototype.eatWhile = function (match) {
1519
- var start = this.pos
1520
- while (this.eat(match)){}
1521
- return this.pos > start
1522
- };
1523
- StringStream.prototype.eatSpace = function () {
1524
- var this$1 = this;
1525
-
1526
- var start = this.pos
1527
- while (/[\s\u00a0]/.test(this.string.charAt(this.pos))) { ++this$1.pos }
1528
- return this.pos > start
1529
- };
1530
- StringStream.prototype.skipToEnd = function () {this.pos = this.string.length};
1531
- StringStream.prototype.skipTo = function (ch) {
1532
- var found = this.string.indexOf(ch, this.pos)
1533
- if (found > -1) {this.pos = found; return true}
1534
- };
1535
- StringStream.prototype.backUp = function (n) {this.pos -= n};
1536
- StringStream.prototype.column = function () {
1537
- if (this.lastColumnPos < this.start) {
1538
- this.lastColumnValue = countColumn(this.string, this.start, this.tabSize, this.lastColumnPos, this.lastColumnValue)
1539
- this.lastColumnPos = this.start
1540
- }
1541
- return this.lastColumnValue - (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0)
1542
- };
1543
- StringStream.prototype.indentation = function () {
1544
- return countColumn(this.string, null, this.tabSize) -
1545
- (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0)
1546
- };
1547
- StringStream.prototype.match = function (pattern, consume, caseInsensitive) {
1548
- if (typeof pattern == "string") {
1549
- var cased = function (str) { return caseInsensitive ? str.toLowerCase() : str; }
1550
- var substr = this.string.substr(this.pos, pattern.length)
1551
- if (cased(substr) == cased(pattern)) {
1552
- if (consume !== false) { this.pos += pattern.length }
1553
- return true
1554
- }
1555
- } else {
1556
- var match = this.string.slice(this.pos).match(pattern)
1557
- if (match && match.index > 0) { return null }
1558
- if (match && consume !== false) { this.pos += match[0].length }
1559
- return match
1560
- }
1561
- };
1562
- StringStream.prototype.current = function (){return this.string.slice(this.start, this.pos)};
1563
- StringStream.prototype.hideFirstChars = function (n, inner) {
1564
- this.lineStart += n
1565
- try { return inner() }
1566
- finally { this.lineStart -= n }
1567
- };
1568
-
1569
- // Compute a style array (an array starting with a mode generation
1570
- // -- for invalidation -- followed by pairs of end positions and
1571
- // style strings), which is used to highlight the tokens on the
1572
- // line.
1573
- function highlightLine(cm, line, state, forceToEnd) {
1574
- // A styles array always starts with a number identifying the
1575
- // mode/overlays that it is based on (for easy invalidation).
1576
- var st = [cm.state.modeGen], lineClasses = {}
1577
- // Compute the base array of styles
1578
- runMode(cm, line.text, cm.doc.mode, state, function (end, style) { return st.push(end, style); },
1579
- lineClasses, forceToEnd)
1580
-
1581
- // Run overlays, adjust style array.
1582
- var loop = function ( o ) {
1583
- var overlay = cm.state.overlays[o], i = 1, at = 0
1584
- runMode(cm, line.text, overlay.mode, true, function (end, style) {
1585
- var start = i
1586
- // Ensure there's a token end at the current position, and that i points at it
1587
- while (at < end) {
1588
- var i_end = st[i]
1589
- if (i_end > end)
1590
- { st.splice(i, 1, end, st[i+1], i_end) }
1591
- i += 2
1592
- at = Math.min(end, i_end)
1593
- }
1594
- if (!style) { return }
1595
- if (overlay.opaque) {
1596
- st.splice(start, i - start, end, "overlay " + style)
1597
- i = start + 2
1598
- } else {
1599
- for (; start < i; start += 2) {
1600
- var cur = st[start+1]
1601
- st[start+1] = (cur ? cur + " " : "") + "overlay " + style
1602
- }
1603
- }
1604
- }, lineClasses)
1605
- };
1606
-
1607
- for (var o = 0; o < cm.state.overlays.length; ++o) loop( o );
1608
-
1609
- return {styles: st, classes: lineClasses.bgClass || lineClasses.textClass ? lineClasses : null}
1610
- }
1611
-
1612
- function getLineStyles(cm, line, updateFrontier) {
1613
- if (!line.styles || line.styles[0] != cm.state.modeGen) {
1614
- var state = getStateBefore(cm, lineNo(line))
1615
- var result = highlightLine(cm, line, line.text.length > cm.options.maxHighlightLength ? copyState(cm.doc.mode, state) : state)
1616
- line.stateAfter = state
1617
- line.styles = result.styles
1618
- if (result.classes) { line.styleClasses = result.classes }
1619
- else if (line.styleClasses) { line.styleClasses = null }
1620
- if (updateFrontier === cm.doc.frontier) { cm.doc.frontier++ }
1621
- }
1622
- return line.styles
1623
- }
1624
-
1625
- function getStateBefore(cm, n, precise) {
1626
- var doc = cm.doc, display = cm.display
1627
- if (!doc.mode.startState) { return true }
1628
- var pos = findStartLine(cm, n, precise), state = pos > doc.first && getLine(doc, pos-1).stateAfter
1629
- if (!state) { state = startState(doc.mode) }
1630
- else { state = copyState(doc.mode, state) }
1631
- doc.iter(pos, n, function (line) {
1632
- processLine(cm, line.text, state)
1633
- var save = pos == n - 1 || pos % 5 == 0 || pos >= display.viewFrom && pos < display.viewTo
1634
- line.stateAfter = save ? copyState(doc.mode, state) : null
1635
- ++pos
1636
- })
1637
- if (precise) { doc.frontier = pos }
1638
- return state
1639
- }
1640
-
1641
- // Lightweight form of highlight -- proceed over this line and
1642
- // update state, but don't save a style array. Used for lines that
1643
- // aren't currently visible.
1644
- function processLine(cm, text, state, startAt) {
1645
- var mode = cm.doc.mode
1646
- var stream = new StringStream(text, cm.options.tabSize)
1647
- stream.start = stream.pos = startAt || 0
1648
- if (text == "") { callBlankLine(mode, state) }
1649
- while (!stream.eol()) {
1650
- readToken(mode, stream, state)
1651
- stream.start = stream.pos
1652
- }
1653
- }
1654
-
1655
- function callBlankLine(mode, state) {
1656
- if (mode.blankLine) { return mode.blankLine(state) }
1657
- if (!mode.innerMode) { return }
1658
- var inner = innerMode(mode, state)
1659
- if (inner.mode.blankLine) { return inner.mode.blankLine(inner.state) }
1660
- }
1661
-
1662
- function readToken(mode, stream, state, inner) {
1663
- for (var i = 0; i < 10; i++) {
1664
- if (inner) { inner[0] = innerMode(mode, state).mode }
1665
- var style = mode.token(stream, state)
1666
- if (stream.pos > stream.start) { return style }
1667
- }
1668
- throw new Error("Mode " + mode.name + " failed to advance stream.")
1669
- }
1670
-
1671
- // Utility for getTokenAt and getLineTokens
1672
- function takeToken(cm, pos, precise, asArray) {
1673
- var getObj = function (copy) { return ({
1674
- start: stream.start, end: stream.pos,
1675
- string: stream.current(),
1676
- type: style || null,
1677
- state: copy ? copyState(doc.mode, state) : state
1678
- }); }
1679
-
1680
- var doc = cm.doc, mode = doc.mode, style
1681
- pos = clipPos(doc, pos)
1682
- var line = getLine(doc, pos.line), state = getStateBefore(cm, pos.line, precise)
1683
- var stream = new StringStream(line.text, cm.options.tabSize), tokens
1684
- if (asArray) { tokens = [] }
1685
- while ((asArray || stream.pos < pos.ch) && !stream.eol()) {
1686
- stream.start = stream.pos
1687
- style = readToken(mode, stream, state)
1688
- if (asArray) { tokens.push(getObj(true)) }
1689
- }
1690
- return asArray ? tokens : getObj()
1691
- }
1692
-
1693
- function extractLineClasses(type, output) {
1694
- if (type) { for (;;) {
1695
- var lineClass = type.match(/(?:^|\s+)line-(background-)?(\S+)/)
1696
- if (!lineClass) { break }
1697
- type = type.slice(0, lineClass.index) + type.slice(lineClass.index + lineClass[0].length)
1698
- var prop = lineClass[1] ? "bgClass" : "textClass"
1699
- if (output[prop] == null)
1700
- { output[prop] = lineClass[2] }
1701
- else if (!(new RegExp("(?:^|\s)" + lineClass[2] + "(?:$|\s)")).test(output[prop]))
1702
- { output[prop] += " " + lineClass[2] }
1703
- } }
1704
- return type
1705
- }
1706
-
1707
- // Run the given mode's parser over a line, calling f for each token.
1708
- function runMode(cm, text, mode, state, f, lineClasses, forceToEnd) {
1709
- var flattenSpans = mode.flattenSpans
1710
- if (flattenSpans == null) { flattenSpans = cm.options.flattenSpans }
1711
- var curStart = 0, curStyle = null
1712
- var stream = new StringStream(text, cm.options.tabSize), style
1713
- var inner = cm.options.addModeClass && [null]
1714
- if (text == "") { extractLineClasses(callBlankLine(mode, state), lineClasses) }
1715
- while (!stream.eol()) {
1716
- if (stream.pos > cm.options.maxHighlightLength) {
1717
- flattenSpans = false
1718
- if (forceToEnd) { processLine(cm, text, state, stream.pos) }
1719
- stream.pos = text.length
1720
- style = null
1721
- } else {
1722
- style = extractLineClasses(readToken(mode, stream, state, inner), lineClasses)
1723
- }
1724
- if (inner) {
1725
- var mName = inner[0].name
1726
- if (mName) { style = "m-" + (style ? mName + " " + style : mName) }
1727
- }
1728
- if (!flattenSpans || curStyle != style) {
1729
- while (curStart < stream.start) {
1730
- curStart = Math.min(stream.start, curStart + 5000)
1731
- f(curStart, curStyle)
1732
- }
1733
- curStyle = style
1734
- }
1735
- stream.start = stream.pos
1736
- }
1737
- while (curStart < stream.pos) {
1738
- // Webkit seems to refuse to render text nodes longer than 57444
1739
- // characters, and returns inaccurate measurements in nodes
1740
- // starting around 5000 chars.
1741
- var pos = Math.min(stream.pos, curStart + 5000)
1742
- f(pos, curStyle)
1743
- curStart = pos
1744
- }
1745
- }
1746
-
1747
- // Finds the line to start with when starting a parse. Tries to
1748
- // find a line with a stateAfter, so that it can start with a
1749
- // valid state. If that fails, it returns the line with the
1750
- // smallest indentation, which tends to need the least context to
1751
- // parse correctly.
1752
- function findStartLine(cm, n, precise) {
1753
- var minindent, minline, doc = cm.doc
1754
- var lim = precise ? -1 : n - (cm.doc.mode.innerMode ? 1000 : 100)
1755
- for (var search = n; search > lim; --search) {
1756
- if (search <= doc.first) { return doc.first }
1757
- var line = getLine(doc, search - 1)
1758
- if (line.stateAfter && (!precise || search <= doc.frontier)) { return search }
1759
- var indented = countColumn(line.text, null, cm.options.tabSize)
1760
- if (minline == null || minindent > indented) {
1761
- minline = search - 1
1762
- minindent = indented
1763
- }
1764
- }
1765
- return minline
1766
- }
1767
-
1768
- // LINE DATA STRUCTURE
1769
-
1770
- // Line objects. These hold state related to a line, including
1771
- // highlighting info (the styles array).
1772
- var Line = function(text, markedSpans, estimateHeight) {
1773
- this.text = text
1774
- attachMarkedSpans(this, markedSpans)
1775
- this.height = estimateHeight ? estimateHeight(this) : 1
1776
- };
1777
-
1778
- Line.prototype.lineNo = function () { return lineNo(this) };
1779
- eventMixin(Line)
1780
-
1781
- // Change the content (text, markers) of a line. Automatically
1782
- // invalidates cached information and tries to re-estimate the
1783
- // line's height.
1784
- function updateLine(line, text, markedSpans, estimateHeight) {
1785
- line.text = text
1786
- if (line.stateAfter) { line.stateAfter = null }
1787
- if (line.styles) { line.styles = null }
1788
- if (line.order != null) { line.order = null }
1789
- detachMarkedSpans(line)
1790
- attachMarkedSpans(line, markedSpans)
1791
- var estHeight = estimateHeight ? estimateHeight(line) : 1
1792
- if (estHeight != line.height) { updateLineHeight(line, estHeight) }
1793
- }
1794
-
1795
- // Detach a line from the document tree and its markers.
1796
- function cleanUpLine(line) {
1797
- line.parent = null
1798
- detachMarkedSpans(line)
1799
- }
1800
-
1801
- // Convert a style as returned by a mode (either null, or a string
1802
- // containing one or more styles) to a CSS style. This is cached,
1803
- // and also looks for line-wide styles.
1804
- var styleToClassCache = {};
1805
- var styleToClassCacheWithMode = {};
1806
- function interpretTokenStyle(style, options) {
1807
- if (!style || /^\s*$/.test(style)) { return null }
1808
- var cache = options.addModeClass ? styleToClassCacheWithMode : styleToClassCache
1809
- return cache[style] ||
1810
- (cache[style] = style.replace(/\S+/g, "cm-$&"))
1811
- }
1812
-
1813
- // Render the DOM representation of the text of a line. Also builds
1814
- // up a 'line map', which points at the DOM nodes that represent
1815
- // specific stretches of text, and is used by the measuring code.
1816
- // The returned object contains the DOM node, this map, and
1817
- // information about line-wide styles that were set by the mode.
1818
- function buildLineContent(cm, lineView) {
1819
- // The padding-right forces the element to have a 'border', which
1820
- // is needed on Webkit to be able to get line-level bounding
1821
- // rectangles for it (in measureChar).
1822
- var content = eltP("span", null, null, webkit ? "padding-right: .1px" : null)
1823
- var builder = {pre: eltP("pre", [content], "CodeMirror-line"), content: content,
1824
- col: 0, pos: 0, cm: cm,
1825
- trailingSpace: false,
1826
- splitSpaces: (ie || webkit) && cm.getOption("lineWrapping")}
1827
- lineView.measure = {}
1828
-
1829
- // Iterate over the logical lines that make up this visual line.
1830
- for (var i = 0; i <= (lineView.rest ? lineView.rest.length : 0); i++) {
1831
- var line = i ? lineView.rest[i - 1] : lineView.line, order = (void 0)
1832
- builder.pos = 0
1833
- builder.addToken = buildToken
1834
- // Optionally wire in some hacks into the token-rendering
1835
- // algorithm, to deal with browser quirks.
1836
- if (hasBadBidiRects(cm.display.measure) && (order = getOrder(line, cm.doc.direction)))
1837
- { builder.addToken = buildTokenBadBidi(builder.addToken, order) }
1838
- builder.map = []
1839
- var allowFrontierUpdate = lineView != cm.display.externalMeasured && lineNo(line)
1840
- insertLineContent(line, builder, getLineStyles(cm, line, allowFrontierUpdate))
1841
- if (line.styleClasses) {
1842
- if (line.styleClasses.bgClass)
1843
- { builder.bgClass = joinClasses(line.styleClasses.bgClass, builder.bgClass || "") }
1844
- if (line.styleClasses.textClass)
1845
- { builder.textClass = joinClasses(line.styleClasses.textClass, builder.textClass || "") }
1846
- }
1847
-
1848
- // Ensure at least a single node is present, for measuring.
1849
- if (builder.map.length == 0)
1850
- { builder.map.push(0, 0, builder.content.appendChild(zeroWidthElement(cm.display.measure))) }
1851
-
1852
- // Store the map and a cache object for the current logical line
1853
- if (i == 0) {
1854
- lineView.measure.map = builder.map
1855
- lineView.measure.cache = {}
1856
- } else {
1857
- ;(lineView.measure.maps || (lineView.measure.maps = [])).push(builder.map)
1858
- ;(lineView.measure.caches || (lineView.measure.caches = [])).push({})
1859
- }
1860
- }
1861
-
1862
- // See issue #2901
1863
- if (webkit) {
1864
- var last = builder.content.lastChild
1865
- if (/\bcm-tab\b/.test(last.className) || (last.querySelector && last.querySelector(".cm-tab")))
1866
- { builder.content.className = "cm-tab-wrap-hack" }
1867
- }
1868
-
1869
- signal(cm, "renderLine", cm, lineView.line, builder.pre)
1870
- if (builder.pre.className)
1871
- { builder.textClass = joinClasses(builder.pre.className, builder.textClass || "") }
1872
-
1873
- return builder
1874
- }
1875
-
1876
- function defaultSpecialCharPlaceholder(ch) {
1877
- var token = elt("span", "\u2022", "cm-invalidchar")
1878
- token.title = "\\u" + ch.charCodeAt(0).toString(16)
1879
- token.setAttribute("aria-label", token.title)
1880
- return token
1881
- }
1882
-
1883
- // Build up the DOM representation for a single token, and add it to
1884
- // the line map. Takes care to render special characters separately.
1885
- function buildToken(builder, text, style, startStyle, endStyle, title, css) {
1886
- if (!text) { return }
1887
- var displayText = builder.splitSpaces ? splitSpaces(text, builder.trailingSpace) : text
1888
- var special = builder.cm.state.specialChars, mustWrap = false
1889
- var content
1890
- if (!special.test(text)) {
1891
- builder.col += text.length
1892
- content = document.createTextNode(displayText)
1893
- builder.map.push(builder.pos, builder.pos + text.length, content)
1894
- if (ie && ie_version < 9) { mustWrap = true }
1895
- builder.pos += text.length
1896
- } else {
1897
- content = document.createDocumentFragment()
1898
- var pos = 0
1899
- while (true) {
1900
- special.lastIndex = pos
1901
- var m = special.exec(text)
1902
- var skipped = m ? m.index - pos : text.length - pos
1903
- if (skipped) {
1904
- var txt = document.createTextNode(displayText.slice(pos, pos + skipped))
1905
- if (ie && ie_version < 9) { content.appendChild(elt("span", [txt])) }
1906
- else { content.appendChild(txt) }
1907
- builder.map.push(builder.pos, builder.pos + skipped, txt)
1908
- builder.col += skipped
1909
- builder.pos += skipped
1910
- }
1911
- if (!m) { break }
1912
- pos += skipped + 1
1913
- var txt$1 = (void 0)
1914
- if (m[0] == "\t") {
1915
- var tabSize = builder.cm.options.tabSize, tabWidth = tabSize - builder.col % tabSize
1916
- txt$1 = content.appendChild(elt("span", spaceStr(tabWidth), "cm-tab"))
1917
- txt$1.setAttribute("role", "presentation")
1918
- txt$1.setAttribute("cm-text", "\t")
1919
- builder.col += tabWidth
1920
- } else if (m[0] == "\r" || m[0] == "\n") {
1921
- txt$1 = content.appendChild(elt("span", m[0] == "\r" ? "\u240d" : "\u2424", "cm-invalidchar"))
1922
- txt$1.setAttribute("cm-text", m[0])
1923
- builder.col += 1
1924
- } else {
1925
- txt$1 = builder.cm.options.specialCharPlaceholder(m[0])
1926
- txt$1.setAttribute("cm-text", m[0])
1927
- if (ie && ie_version < 9) { content.appendChild(elt("span", [txt$1])) }
1928
- else { content.appendChild(txt$1) }
1929
- builder.col += 1
1930
- }
1931
- builder.map.push(builder.pos, builder.pos + 1, txt$1)
1932
- builder.pos++
1933
- }
1934
- }
1935
- builder.trailingSpace = displayText.charCodeAt(text.length - 1) == 32
1936
- if (style || startStyle || endStyle || mustWrap || css) {
1937
- var fullStyle = style || ""
1938
- if (startStyle) { fullStyle += startStyle }
1939
- if (endStyle) { fullStyle += endStyle }
1940
- var token = elt("span", [content], fullStyle, css)
1941
- if (title) { token.title = title }
1942
- return builder.content.appendChild(token)
1943
- }
1944
- builder.content.appendChild(content)
1945
- }
1946
-
1947
- function splitSpaces(text, trailingBefore) {
1948
- if (text.length > 1 && !/ /.test(text)) { return text }
1949
- var spaceBefore = trailingBefore, result = ""
1950
- for (var i = 0; i < text.length; i++) {
1951
- var ch = text.charAt(i)
1952
- if (ch == " " && spaceBefore && (i == text.length - 1 || text.charCodeAt(i + 1) == 32))
1953
- { ch = "\u00a0" }
1954
- result += ch
1955
- spaceBefore = ch == " "
1956
- }
1957
- return result
1958
- }
1959
-
1960
- // Work around nonsense dimensions being reported for stretches of
1961
- // right-to-left text.
1962
- function buildTokenBadBidi(inner, order) {
1963
- return function (builder, text, style, startStyle, endStyle, title, css) {
1964
- style = style ? style + " cm-force-border" : "cm-force-border"
1965
- var start = builder.pos, end = start + text.length
1966
- for (;;) {
1967
- // Find the part that overlaps with the start of this text
1968
- var part = (void 0)
1969
- for (var i = 0; i < order.length; i++) {
1970
- part = order[i]
1971
- if (part.to > start && part.from <= start) { break }
1972
- }
1973
- if (part.to >= end) { return inner(builder, text, style, startStyle, endStyle, title, css) }
1974
- inner(builder, text.slice(0, part.to - start), style, startStyle, null, title, css)
1975
- startStyle = null
1976
- text = text.slice(part.to - start)
1977
- start = part.to
1978
- }
1979
- }
1980
- }
1981
-
1982
- function buildCollapsedSpan(builder, size, marker, ignoreWidget) {
1983
- var widget = !ignoreWidget && marker.widgetNode
1984
- if (widget) { builder.map.push(builder.pos, builder.pos + size, widget) }
1985
- if (!ignoreWidget && builder.cm.display.input.needsContentAttribute) {
1986
- if (!widget)
1987
- { widget = builder.content.appendChild(document.createElement("span")) }
1988
- widget.setAttribute("cm-marker", marker.id)
1989
- }
1990
- if (widget) {
1991
- builder.cm.display.input.setUneditable(widget)
1992
- builder.content.appendChild(widget)
1993
- }
1994
- builder.pos += size
1995
- builder.trailingSpace = false
1996
- }
1997
-
1998
- // Outputs a number of spans to make up a line, taking highlighting
1999
- // and marked text into account.
2000
- function insertLineContent(line, builder, styles) {
2001
- var spans = line.markedSpans, allText = line.text, at = 0
2002
- if (!spans) {
2003
- for (var i$1 = 1; i$1 < styles.length; i$1+=2)
2004
- { builder.addToken(builder, allText.slice(at, at = styles[i$1]), interpretTokenStyle(styles[i$1+1], builder.cm.options)) }
2005
- return
2006
- }
2007
-
2008
- var len = allText.length, pos = 0, i = 1, text = "", style, css
2009
- var nextChange = 0, spanStyle, spanEndStyle, spanStartStyle, title, collapsed
2010
- for (;;) {
2011
- if (nextChange == pos) { // Update current marker set
2012
- spanStyle = spanEndStyle = spanStartStyle = title = css = ""
2013
- collapsed = null; nextChange = Infinity
2014
- var foundBookmarks = [], endStyles = (void 0)
2015
- for (var j = 0; j < spans.length; ++j) {
2016
- var sp = spans[j], m = sp.marker
2017
- if (m.type == "bookmark" && sp.from == pos && m.widgetNode) {
2018
- foundBookmarks.push(m)
2019
- } else if (sp.from <= pos && (sp.to == null || sp.to > pos || m.collapsed && sp.to == pos && sp.from == pos)) {
2020
- if (sp.to != null && sp.to != pos && nextChange > sp.to) {
2021
- nextChange = sp.to
2022
- spanEndStyle = ""
2023
- }
2024
- if (m.className) { spanStyle += " " + m.className }
2025
- if (m.css) { css = (css ? css + ";" : "") + m.css }
2026
- if (m.startStyle && sp.from == pos) { spanStartStyle += " " + m.startStyle }
2027
- if (m.endStyle && sp.to == nextChange) { (endStyles || (endStyles = [])).push(m.endStyle, sp.to) }
2028
- if (m.title && !title) { title = m.title }
2029
- if (m.collapsed && (!collapsed || compareCollapsedMarkers(collapsed.marker, m) < 0))
2030
- { collapsed = sp }
2031
- } else if (sp.from > pos && nextChange > sp.from) {
2032
- nextChange = sp.from
2033
- }
2034
- }
2035
- if (endStyles) { for (var j$1 = 0; j$1 < endStyles.length; j$1 += 2)
2036
- { if (endStyles[j$1 + 1] == nextChange) { spanEndStyle += " " + endStyles[j$1] } } }
2037
-
2038
- if (!collapsed || collapsed.from == pos) { for (var j$2 = 0; j$2 < foundBookmarks.length; ++j$2)
2039
- { buildCollapsedSpan(builder, 0, foundBookmarks[j$2]) } }
2040
- if (collapsed && (collapsed.from || 0) == pos) {
2041
- buildCollapsedSpan(builder, (collapsed.to == null ? len + 1 : collapsed.to) - pos,
2042
- collapsed.marker, collapsed.from == null)
2043
- if (collapsed.to == null) { return }
2044
- if (collapsed.to == pos) { collapsed = false }
2045
- }
2046
- }
2047
- if (pos >= len) { break }
2048
-
2049
- var upto = Math.min(len, nextChange)
2050
- while (true) {
2051
- if (text) {
2052
- var end = pos + text.length
2053
- if (!collapsed) {
2054
- var tokenText = end > upto ? text.slice(0, upto - pos) : text
2055
- builder.addToken(builder, tokenText, style ? style + spanStyle : spanStyle,
2056
- spanStartStyle, pos + tokenText.length == nextChange ? spanEndStyle : "", title, css)
2057
- }
2058
- if (end >= upto) {text = text.slice(upto - pos); pos = upto; break}
2059
- pos = end
2060
- spanStartStyle = ""
2061
- }
2062
- text = allText.slice(at, at = styles[i++])
2063
- style = interpretTokenStyle(styles[i++], builder.cm.options)
2064
- }
2065
- }
2066
- }
2067
-
2068
-
2069
- // These objects are used to represent the visible (currently drawn)
2070
- // part of the document. A LineView may correspond to multiple
2071
- // logical lines, if those are connected by collapsed ranges.
2072
- function LineView(doc, line, lineN) {
2073
- // The starting line
2074
- this.line = line
2075
- // Continuing lines, if any
2076
- this.rest = visualLineContinued(line)
2077
- // Number of logical lines in this visual line
2078
- this.size = this.rest ? lineNo(lst(this.rest)) - lineN + 1 : 1
2079
- this.node = this.text = null
2080
- this.hidden = lineIsHidden(doc, line)
2081
- }
2082
-
2083
- // Create a range of LineView objects for the given lines.
2084
- function buildViewArray(cm, from, to) {
2085
- var array = [], nextPos
2086
- for (var pos = from; pos < to; pos = nextPos) {
2087
- var view = new LineView(cm.doc, getLine(cm.doc, pos), pos)
2088
- nextPos = pos + view.size
2089
- array.push(view)
2090
- }
2091
- return array
2092
- }
2093
-
2094
- var operationGroup = null
2095
-
2096
- function pushOperation(op) {
2097
- if (operationGroup) {
2098
- operationGroup.ops.push(op)
2099
- } else {
2100
- op.ownsGroup = operationGroup = {
2101
- ops: [op],
2102
- delayedCallbacks: []
2103
- }
2104
- }
2105
- }
2106
-
2107
- function fireCallbacksForOps(group) {
2108
- // Calls delayed callbacks and cursorActivity handlers until no
2109
- // new ones appear
2110
- var callbacks = group.delayedCallbacks, i = 0
2111
- do {
2112
- for (; i < callbacks.length; i++)
2113
- { callbacks[i].call(null) }
2114
- for (var j = 0; j < group.ops.length; j++) {
2115
- var op = group.ops[j]
2116
- if (op.cursorActivityHandlers)
2117
- { while (op.cursorActivityCalled < op.cursorActivityHandlers.length)
2118
- { op.cursorActivityHandlers[op.cursorActivityCalled++].call(null, op.cm) } }
2119
- }
2120
- } while (i < callbacks.length)
2121
- }
2122
-
2123
- function finishOperation(op, endCb) {
2124
- var group = op.ownsGroup
2125
- if (!group) { return }
2126
-
2127
- try { fireCallbacksForOps(group) }
2128
- finally {
2129
- operationGroup = null
2130
- endCb(group)
2131
- }
2132
- }
2133
-
2134
- var orphanDelayedCallbacks = null
2135
-
2136
- // Often, we want to signal events at a point where we are in the
2137
- // middle of some work, but don't want the handler to start calling
2138
- // other methods on the editor, which might be in an inconsistent
2139
- // state or simply not expect any other events to happen.
2140
- // signalLater looks whether there are any handlers, and schedules
2141
- // them to be executed when the last operation ends, or, if no
2142
- // operation is active, when a timeout fires.
2143
- function signalLater(emitter, type /*, values...*/) {
2144
- var arr = getHandlers(emitter, type)
2145
- if (!arr.length) { return }
2146
- var args = Array.prototype.slice.call(arguments, 2), list
2147
- if (operationGroup) {
2148
- list = operationGroup.delayedCallbacks
2149
- } else if (orphanDelayedCallbacks) {
2150
- list = orphanDelayedCallbacks
2151
- } else {
2152
- list = orphanDelayedCallbacks = []
2153
- setTimeout(fireOrphanDelayed, 0)
2154
- }
2155
- var loop = function ( i ) {
2156
- list.push(function () { return arr[i].apply(null, args); })
2157
- };
2158
-
2159
- for (var i = 0; i < arr.length; ++i)
2160
- loop( i );
2161
- }
2162
-
2163
- function fireOrphanDelayed() {
2164
- var delayed = orphanDelayedCallbacks
2165
- orphanDelayedCallbacks = null
2166
- for (var i = 0; i < delayed.length; ++i) { delayed[i]() }
2167
- }
2168
-
2169
- // When an aspect of a line changes, a string is added to
2170
- // lineView.changes. This updates the relevant part of the line's
2171
- // DOM structure.
2172
- function updateLineForChanges(cm, lineView, lineN, dims) {
2173
- for (var j = 0; j < lineView.changes.length; j++) {
2174
- var type = lineView.changes[j]
2175
- if (type == "text") { updateLineText(cm, lineView) }
2176
- else if (type == "gutter") { updateLineGutter(cm, lineView, lineN, dims) }
2177
- else if (type == "class") { updateLineClasses(cm, lineView) }
2178
- else if (type == "widget") { updateLineWidgets(cm, lineView, dims) }
2179
- }
2180
- lineView.changes = null
2181
- }
2182
-
2183
- // Lines with gutter elements, widgets or a background class need to
2184
- // be wrapped, and have the extra elements added to the wrapper div
2185
- function ensureLineWrapped(lineView) {
2186
- if (lineView.node == lineView.text) {
2187
- lineView.node = elt("div", null, null, "position: relative")
2188
- if (lineView.text.parentNode)
2189
- { lineView.text.parentNode.replaceChild(lineView.node, lineView.text) }
2190
- lineView.node.appendChild(lineView.text)
2191
- if (ie && ie_version < 8) { lineView.node.style.zIndex = 2 }
2192
- }
2193
- return lineView.node
2194
- }
2195
-
2196
- function updateLineBackground(cm, lineView) {
2197
- var cls = lineView.bgClass ? lineView.bgClass + " " + (lineView.line.bgClass || "") : lineView.line.bgClass
2198
- if (cls) { cls += " CodeMirror-linebackground" }
2199
- if (lineView.background) {
2200
- if (cls) { lineView.background.className = cls }
2201
- else { lineView.background.parentNode.removeChild(lineView.background); lineView.background = null }
2202
- } else if (cls) {
2203
- var wrap = ensureLineWrapped(lineView)
2204
- lineView.background = wrap.insertBefore(elt("div", null, cls), wrap.firstChild)
2205
- cm.display.input.setUneditable(lineView.background)
2206
- }
2207
- }
2208
-
2209
- // Wrapper around buildLineContent which will reuse the structure
2210
- // in display.externalMeasured when possible.
2211
- function getLineContent(cm, lineView) {
2212
- var ext = cm.display.externalMeasured
2213
- if (ext && ext.line == lineView.line) {
2214
- cm.display.externalMeasured = null
2215
- lineView.measure = ext.measure
2216
- return ext.built
2217
- }
2218
- return buildLineContent(cm, lineView)
2219
- }
2220
-
2221
- // Redraw the line's text. Interacts with the background and text
2222
- // classes because the mode may output tokens that influence these
2223
- // classes.
2224
- function updateLineText(cm, lineView) {
2225
- var cls = lineView.text.className
2226
- var built = getLineContent(cm, lineView)
2227
- if (lineView.text == lineView.node) { lineView.node = built.pre }
2228
- lineView.text.parentNode.replaceChild(built.pre, lineView.text)
2229
- lineView.text = built.pre
2230
- if (built.bgClass != lineView.bgClass || built.textClass != lineView.textClass) {
2231
- lineView.bgClass = built.bgClass
2232
- lineView.textClass = built.textClass
2233
- updateLineClasses(cm, lineView)
2234
- } else if (cls) {
2235
- lineView.text.className = cls
2236
- }
2237
- }
2238
-
2239
- function updateLineClasses(cm, lineView) {
2240
- updateLineBackground(cm, lineView)
2241
- if (lineView.line.wrapClass)
2242
- { ensureLineWrapped(lineView).className = lineView.line.wrapClass }
2243
- else if (lineView.node != lineView.text)
2244
- { lineView.node.className = "" }
2245
- var textClass = lineView.textClass ? lineView.textClass + " " + (lineView.line.textClass || "") : lineView.line.textClass
2246
- lineView.text.className = textClass || ""
2247
- }
2248
-
2249
- function updateLineGutter(cm, lineView, lineN, dims) {
2250
- if (lineView.gutter) {
2251
- lineView.node.removeChild(lineView.gutter)
2252
- lineView.gutter = null
2253
- }
2254
- if (lineView.gutterBackground) {
2255
- lineView.node.removeChild(lineView.gutterBackground)
2256
- lineView.gutterBackground = null
2257
- }
2258
- if (lineView.line.gutterClass) {
2259
- var wrap = ensureLineWrapped(lineView)
2260
- lineView.gutterBackground = elt("div", null, "CodeMirror-gutter-background " + lineView.line.gutterClass,
2261
- ("left: " + (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) + "px; width: " + (dims.gutterTotalWidth) + "px"))
2262
- cm.display.input.setUneditable(lineView.gutterBackground)
2263
- wrap.insertBefore(lineView.gutterBackground, lineView.text)
2264
- }
2265
- var markers = lineView.line.gutterMarkers
2266
- if (cm.options.lineNumbers || markers) {
2267
- var wrap$1 = ensureLineWrapped(lineView)
2268
- var gutterWrap = lineView.gutter = elt("div", null, "CodeMirror-gutter-wrapper", ("left: " + (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) + "px"))
2269
- cm.display.input.setUneditable(gutterWrap)
2270
- wrap$1.insertBefore(gutterWrap, lineView.text)
2271
- if (lineView.line.gutterClass)
2272
- { gutterWrap.className += " " + lineView.line.gutterClass }
2273
- if (cm.options.lineNumbers && (!markers || !markers["CodeMirror-linenumbers"]))
2274
- { lineView.lineNumber = gutterWrap.appendChild(
2275
- elt("div", lineNumberFor(cm.options, lineN),
2276
- "CodeMirror-linenumber CodeMirror-gutter-elt",
2277
- ("left: " + (dims.gutterLeft["CodeMirror-linenumbers"]) + "px; width: " + (cm.display.lineNumInnerWidth) + "px"))) }
2278
- if (markers) { for (var k = 0; k < cm.options.gutters.length; ++k) {
2279
- var id = cm.options.gutters[k], found = markers.hasOwnProperty(id) && markers[id]
2280
- if (found)
2281
- { gutterWrap.appendChild(elt("div", [found], "CodeMirror-gutter-elt",
2282
- ("left: " + (dims.gutterLeft[id]) + "px; width: " + (dims.gutterWidth[id]) + "px"))) }
2283
- } }
2284
- }
2285
- }
2286
-
2287
- function updateLineWidgets(cm, lineView, dims) {
2288
- if (lineView.alignable) { lineView.alignable = null }
2289
- for (var node = lineView.node.firstChild, next = (void 0); node; node = next) {
2290
- next = node.nextSibling
2291
- if (node.className == "CodeMirror-linewidget")
2292
- { lineView.node.removeChild(node) }
2293
- }
2294
- insertLineWidgets(cm, lineView, dims)
2295
- }
2296
-
2297
- // Build a line's DOM representation from scratch
2298
- function buildLineElement(cm, lineView, lineN, dims) {
2299
- var built = getLineContent(cm, lineView)
2300
- lineView.text = lineView.node = built.pre
2301
- if (built.bgClass) { lineView.bgClass = built.bgClass }
2302
- if (built.textClass) { lineView.textClass = built.textClass }
2303
-
2304
- updateLineClasses(cm, lineView)
2305
- updateLineGutter(cm, lineView, lineN, dims)
2306
- insertLineWidgets(cm, lineView, dims)
2307
- return lineView.node
2308
- }
2309
-
2310
- // A lineView may contain multiple logical lines (when merged by
2311
- // collapsed spans). The widgets for all of them need to be drawn.
2312
- function insertLineWidgets(cm, lineView, dims) {
2313
- insertLineWidgetsFor(cm, lineView.line, lineView, dims, true)
2314
- if (lineView.rest) { for (var i = 0; i < lineView.rest.length; i++)
2315
- { insertLineWidgetsFor(cm, lineView.rest[i], lineView, dims, false) } }
2316
- }
2317
-
2318
- function insertLineWidgetsFor(cm, line, lineView, dims, allowAbove) {
2319
- if (!line.widgets) { return }
2320
- var wrap = ensureLineWrapped(lineView)
2321
- for (var i = 0, ws = line.widgets; i < ws.length; ++i) {
2322
- var widget = ws[i], node = elt("div", [widget.node], "CodeMirror-linewidget")
2323
- if (!widget.handleMouseEvents) { node.setAttribute("cm-ignore-events", "true") }
2324
- positionLineWidget(widget, node, lineView, dims)
2325
- cm.display.input.setUneditable(node)
2326
- if (allowAbove && widget.above)
2327
- { wrap.insertBefore(node, lineView.gutter || lineView.text) }
2328
- else
2329
- { wrap.appendChild(node) }
2330
- signalLater(widget, "redraw")
2331
- }
2332
- }
2333
-
2334
- function positionLineWidget(widget, node, lineView, dims) {
2335
- if (widget.noHScroll) {
2336
- ;(lineView.alignable || (lineView.alignable = [])).push(node)
2337
- var width = dims.wrapperWidth
2338
- node.style.left = dims.fixedPos + "px"
2339
- if (!widget.coverGutter) {
2340
- width -= dims.gutterTotalWidth
2341
- node.style.paddingLeft = dims.gutterTotalWidth + "px"
2342
- }
2343
- node.style.width = width + "px"
2344
- }
2345
- if (widget.coverGutter) {
2346
- node.style.zIndex = 5
2347
- node.style.position = "relative"
2348
- if (!widget.noHScroll) { node.style.marginLeft = -dims.gutterTotalWidth + "px" }
2349
- }
2350
- }
2351
-
2352
- function widgetHeight(widget) {
2353
- if (widget.height != null) { return widget.height }
2354
- var cm = widget.doc.cm
2355
- if (!cm) { return 0 }
2356
- if (!contains(document.body, widget.node)) {
2357
- var parentStyle = "position: relative;"
2358
- if (widget.coverGutter)
2359
- { parentStyle += "margin-left: -" + cm.display.gutters.offsetWidth + "px;" }
2360
- if (widget.noHScroll)
2361
- { parentStyle += "width: " + cm.display.wrapper.clientWidth + "px;" }
2362
- removeChildrenAndAdd(cm.display.measure, elt("div", [widget.node], null, parentStyle))
2363
- }
2364
- return widget.height = widget.node.parentNode.offsetHeight
2365
- }
2366
-
2367
- // Return true when the given mouse event happened in a widget
2368
- function eventInWidget(display, e) {
2369
- for (var n = e_target(e); n != display.wrapper; n = n.parentNode) {
2370
- if (!n || (n.nodeType == 1 && n.getAttribute("cm-ignore-events") == "true") ||
2371
- (n.parentNode == display.sizer && n != display.mover))
2372
- { return true }
2373
- }
2374
- }
2375
-
2376
- // POSITION MEASUREMENT
2377
-
2378
- function paddingTop(display) {return display.lineSpace.offsetTop}
2379
- function paddingVert(display) {return display.mover.offsetHeight - display.lineSpace.offsetHeight}
2380
- function paddingH(display) {
2381
- if (display.cachedPaddingH) { return display.cachedPaddingH }
2382
- var e = removeChildrenAndAdd(display.measure, elt("pre", "x"))
2383
- var style = window.getComputedStyle ? window.getComputedStyle(e) : e.currentStyle
2384
- var data = {left: parseInt(style.paddingLeft), right: parseInt(style.paddingRight)}
2385
- if (!isNaN(data.left) && !isNaN(data.right)) { display.cachedPaddingH = data }
2386
- return data
2387
- }
2388
-
2389
- function scrollGap(cm) { return scrollerGap - cm.display.nativeBarWidth }
2390
- function displayWidth(cm) {
2391
- return cm.display.scroller.clientWidth - scrollGap(cm) - cm.display.barWidth
2392
- }
2393
- function displayHeight(cm) {
2394
- return cm.display.scroller.clientHeight - scrollGap(cm) - cm.display.barHeight
2395
- }
2396
-
2397
- // Ensure the lineView.wrapping.heights array is populated. This is
2398
- // an array of bottom offsets for the lines that make up a drawn
2399
- // line. When lineWrapping is on, there might be more than one
2400
- // height.
2401
- function ensureLineHeights(cm, lineView, rect) {
2402
- var wrapping = cm.options.lineWrapping
2403
- var curWidth = wrapping && displayWidth(cm)
2404
- if (!lineView.measure.heights || wrapping && lineView.measure.width != curWidth) {
2405
- var heights = lineView.measure.heights = []
2406
- if (wrapping) {
2407
- lineView.measure.width = curWidth
2408
- var rects = lineView.text.firstChild.getClientRects()
2409
- for (var i = 0; i < rects.length - 1; i++) {
2410
- var cur = rects[i], next = rects[i + 1]
2411
- if (Math.abs(cur.bottom - next.bottom) > 2)
2412
- { heights.push((cur.bottom + next.top) / 2 - rect.top) }
2413
- }
2414
- }
2415
- heights.push(rect.bottom - rect.top)
2416
- }
2417
- }
2418
-
2419
- // Find a line map (mapping character offsets to text nodes) and a
2420
- // measurement cache for the given line number. (A line view might
2421
- // contain multiple lines when collapsed ranges are present.)
2422
- function mapFromLineView(lineView, line, lineN) {
2423
- if (lineView.line == line)
2424
- { return {map: lineView.measure.map, cache: lineView.measure.cache} }
2425
- for (var i = 0; i < lineView.rest.length; i++)
2426
- { if (lineView.rest[i] == line)
2427
- { return {map: lineView.measure.maps[i], cache: lineView.measure.caches[i]} } }
2428
- for (var i$1 = 0; i$1 < lineView.rest.length; i$1++)
2429
- { if (lineNo(lineView.rest[i$1]) > lineN)
2430
- { return {map: lineView.measure.maps[i$1], cache: lineView.measure.caches[i$1], before: true} } }
2431
- }
2432
-
2433
- // Render a line into the hidden node display.externalMeasured. Used
2434
- // when measurement is needed for a line that's not in the viewport.
2435
- function updateExternalMeasurement(cm, line) {
2436
- line = visualLine(line)
2437
- var lineN = lineNo(line)
2438
- var view = cm.display.externalMeasured = new LineView(cm.doc, line, lineN)
2439
- view.lineN = lineN
2440
- var built = view.built = buildLineContent(cm, view)
2441
- view.text = built.pre
2442
- removeChildrenAndAdd(cm.display.lineMeasure, built.pre)
2443
- return view
2444
- }
2445
-
2446
- // Get a {top, bottom, left, right} box (in line-local coordinates)
2447
- // for a given character.
2448
- function measureChar(cm, line, ch, bias) {
2449
- return measureCharPrepared(cm, prepareMeasureForLine(cm, line), ch, bias)
2450
- }
2451
-
2452
- // Find a line view that corresponds to the given line number.
2453
- function findViewForLine(cm, lineN) {
2454
- if (lineN >= cm.display.viewFrom && lineN < cm.display.viewTo)
2455
- { return cm.display.view[findViewIndex(cm, lineN)] }
2456
- var ext = cm.display.externalMeasured
2457
- if (ext && lineN >= ext.lineN && lineN < ext.lineN + ext.size)
2458
- { return ext }
2459
- }
2460
-
2461
- // Measurement can be split in two steps, the set-up work that
2462
- // applies to the whole line, and the measurement of the actual
2463
- // character. Functions like coordsChar, that need to do a lot of
2464
- // measurements in a row, can thus ensure that the set-up work is
2465
- // only done once.
2466
- function prepareMeasureForLine(cm, line) {
2467
- var lineN = lineNo(line)
2468
- var view = findViewForLine(cm, lineN)
2469
- if (view && !view.text) {
2470
- view = null
2471
- } else if (view && view.changes) {
2472
- updateLineForChanges(cm, view, lineN, getDimensions(cm))
2473
- cm.curOp.forceUpdate = true
2474
- }
2475
- if (!view)
2476
- { view = updateExternalMeasurement(cm, line) }
2477
-
2478
- var info = mapFromLineView(view, line, lineN)
2479
- return {
2480
- line: line, view: view, rect: null,
2481
- map: info.map, cache: info.cache, before: info.before,
2482
- hasHeights: false
2483
- }
2484
- }
2485
-
2486
- // Given a prepared measurement object, measures the position of an
2487
- // actual character (or fetches it from the cache).
2488
- function measureCharPrepared(cm, prepared, ch, bias, varHeight) {
2489
- if (prepared.before) { ch = -1 }
2490
- var key = ch + (bias || ""), found
2491
- if (prepared.cache.hasOwnProperty(key)) {
2492
- found = prepared.cache[key]
2493
- } else {
2494
- if (!prepared.rect)
2495
- { prepared.rect = prepared.view.text.getBoundingClientRect() }
2496
- if (!prepared.hasHeights) {
2497
- ensureLineHeights(cm, prepared.view, prepared.rect)
2498
- prepared.hasHeights = true
2499
- }
2500
- found = measureCharInner(cm, prepared, ch, bias)
2501
- if (!found.bogus) { prepared.cache[key] = found }
2502
- }
2503
- return {left: found.left, right: found.right,
2504
- top: varHeight ? found.rtop : found.top,
2505
- bottom: varHeight ? found.rbottom : found.bottom}
2506
- }
2507
-
2508
- var nullRect = {left: 0, right: 0, top: 0, bottom: 0}
2509
-
2510
- function nodeAndOffsetInLineMap(map, ch, bias) {
2511
- var node, start, end, collapse, mStart, mEnd
2512
- // First, search the line map for the text node corresponding to,
2513
- // or closest to, the target character.
2514
- for (var i = 0; i < map.length; i += 3) {
2515
- mStart = map[i]
2516
- mEnd = map[i + 1]
2517
- if (ch < mStart) {
2518
- start = 0; end = 1
2519
- collapse = "left"
2520
- } else if (ch < mEnd) {
2521
- start = ch - mStart
2522
- end = start + 1
2523
- } else if (i == map.length - 3 || ch == mEnd && map[i + 3] > ch) {
2524
- end = mEnd - mStart
2525
- start = end - 1
2526
- if (ch >= mEnd) { collapse = "right" }
2527
- }
2528
- if (start != null) {
2529
- node = map[i + 2]
2530
- if (mStart == mEnd && bias == (node.insertLeft ? "left" : "right"))
2531
- { collapse = bias }
2532
- if (bias == "left" && start == 0)
2533
- { while (i && map[i - 2] == map[i - 3] && map[i - 1].insertLeft) {
2534
- node = map[(i -= 3) + 2]
2535
- collapse = "left"
2536
- } }
2537
- if (bias == "right" && start == mEnd - mStart)
2538
- { while (i < map.length - 3 && map[i + 3] == map[i + 4] && !map[i + 5].insertLeft) {
2539
- node = map[(i += 3) + 2]
2540
- collapse = "right"
2541
- } }
2542
- break
2543
- }
2544
- }
2545
- return {node: node, start: start, end: end, collapse: collapse, coverStart: mStart, coverEnd: mEnd}
2546
- }
2547
-
2548
- function getUsefulRect(rects, bias) {
2549
- var rect = nullRect
2550
- if (bias == "left") { for (var i = 0; i < rects.length; i++) {
2551
- if ((rect = rects[i]).left != rect.right) { break }
2552
- } } else { for (var i$1 = rects.length - 1; i$1 >= 0; i$1--) {
2553
- if ((rect = rects[i$1]).left != rect.right) { break }
2554
- } }
2555
- return rect
2556
- }
2557
-
2558
- function measureCharInner(cm, prepared, ch, bias) {
2559
- var place = nodeAndOffsetInLineMap(prepared.map, ch, bias)
2560
- var node = place.node, start = place.start, end = place.end, collapse = place.collapse
2561
-
2562
- var rect
2563
- if (node.nodeType == 3) { // If it is a text node, use a range to retrieve the coordinates.
2564
- for (var i$1 = 0; i$1 < 4; i$1++) { // Retry a maximum of 4 times when nonsense rectangles are returned
2565
- while (start && isExtendingChar(prepared.line.text.charAt(place.coverStart + start))) { --start }
2566
- while (place.coverStart + end < place.coverEnd && isExtendingChar(prepared.line.text.charAt(place.coverStart + end))) { ++end }
2567
- if (ie && ie_version < 9 && start == 0 && end == place.coverEnd - place.coverStart)
2568
- { rect = node.parentNode.getBoundingClientRect() }
2569
- else
2570
- { rect = getUsefulRect(range(node, start, end).getClientRects(), bias) }
2571
- if (rect.left || rect.right || start == 0) { break }
2572
- end = start
2573
- start = start - 1
2574
- collapse = "right"
2575
- }
2576
- if (ie && ie_version < 11) { rect = maybeUpdateRectForZooming(cm.display.measure, rect) }
2577
- } else { // If it is a widget, simply get the box for the whole widget.
2578
- if (start > 0) { collapse = bias = "right" }
2579
- var rects
2580
- if (cm.options.lineWrapping && (rects = node.getClientRects()).length > 1)
2581
- { rect = rects[bias == "right" ? rects.length - 1 : 0] }
2582
- else
2583
- { rect = node.getBoundingClientRect() }
2584
- }
2585
- if (ie && ie_version < 9 && !start && (!rect || !rect.left && !rect.right)) {
2586
- var rSpan = node.parentNode.getClientRects()[0]
2587
- if (rSpan)
2588
- { rect = {left: rSpan.left, right: rSpan.left + charWidth(cm.display), top: rSpan.top, bottom: rSpan.bottom} }
2589
- else
2590
- { rect = nullRect }
2591
- }
2592
-
2593
- var rtop = rect.top - prepared.rect.top, rbot = rect.bottom - prepared.rect.top
2594
- var mid = (rtop + rbot) / 2
2595
- var heights = prepared.view.measure.heights
2596
- var i = 0
2597
- for (; i < heights.length - 1; i++)
2598
- { if (mid < heights[i]) { break } }
2599
- var top = i ? heights[i - 1] : 0, bot = heights[i]
2600
- var result = {left: (collapse == "right" ? rect.right : rect.left) - prepared.rect.left,
2601
- right: (collapse == "left" ? rect.left : rect.right) - prepared.rect.left,
2602
- top: top, bottom: bot}
2603
- if (!rect.left && !rect.right) { result.bogus = true }
2604
- if (!cm.options.singleCursorHeightPerLine) { result.rtop = rtop; result.rbottom = rbot }
2605
-
2606
- return result
2607
- }
2608
-
2609
- // Work around problem with bounding client rects on ranges being
2610
- // returned incorrectly when zoomed on IE10 and below.
2611
- function maybeUpdateRectForZooming(measure, rect) {
2612
- if (!window.screen || screen.logicalXDPI == null ||
2613
- screen.logicalXDPI == screen.deviceXDPI || !hasBadZoomedRects(measure))
2614
- { return rect }
2615
- var scaleX = screen.logicalXDPI / screen.deviceXDPI
2616
- var scaleY = screen.logicalYDPI / screen.deviceYDPI
2617
- return {left: rect.left * scaleX, right: rect.right * scaleX,
2618
- top: rect.top * scaleY, bottom: rect.bottom * scaleY}
2619
- }
2620
-
2621
- function clearLineMeasurementCacheFor(lineView) {
2622
- if (lineView.measure) {
2623
- lineView.measure.cache = {}
2624
- lineView.measure.heights = null
2625
- if (lineView.rest) { for (var i = 0; i < lineView.rest.length; i++)
2626
- { lineView.measure.caches[i] = {} } }
2627
- }
2628
- }
2629
-
2630
- function clearLineMeasurementCache(cm) {
2631
- cm.display.externalMeasure = null
2632
- removeChildren(cm.display.lineMeasure)
2633
- for (var i = 0; i < cm.display.view.length; i++)
2634
- { clearLineMeasurementCacheFor(cm.display.view[i]) }
2635
- }
2636
-
2637
- function clearCaches(cm) {
2638
- clearLineMeasurementCache(cm)
2639
- cm.display.cachedCharWidth = cm.display.cachedTextHeight = cm.display.cachedPaddingH = null
2640
- if (!cm.options.lineWrapping) { cm.display.maxLineChanged = true }
2641
- cm.display.lineNumChars = null
2642
- }
2643
-
2644
- function pageScrollX() {
2645
- // Work around https://bugs.chromium.org/p/chromium/issues/detail?id=489206
2646
- // which causes page_Offset and bounding client rects to use
2647
- // different reference viewports and invalidate our calculations.
2648
- if (chrome && android) { return -(document.body.getBoundingClientRect().left - parseInt(getComputedStyle(document.body).marginLeft)) }
2649
- return window.pageXOffset || (document.documentElement || document.body).scrollLeft
2650
- }
2651
- function pageScrollY() {
2652
- if (chrome && android) { return -(document.body.getBoundingClientRect().top - parseInt(getComputedStyle(document.body).marginTop)) }
2653
- return window.pageYOffset || (document.documentElement || document.body).scrollTop
2654
- }
2655
-
2656
- // Converts a {top, bottom, left, right} box from line-local
2657
- // coordinates into another coordinate system. Context may be one of
2658
- // "line", "div" (display.lineDiv), "local"./null (editor), "window",
2659
- // or "page".
2660
- function intoCoordSystem(cm, lineObj, rect, context, includeWidgets) {
2661
- if (!includeWidgets && lineObj.widgets) { for (var i = 0; i < lineObj.widgets.length; ++i) { if (lineObj.widgets[i].above) {
2662
- var size = widgetHeight(lineObj.widgets[i])
2663
- rect.top += size; rect.bottom += size
2664
- } } }
2665
- if (context == "line") { return rect }
2666
- if (!context) { context = "local" }
2667
- var yOff = heightAtLine(lineObj)
2668
- if (context == "local") { yOff += paddingTop(cm.display) }
2669
- else { yOff -= cm.display.viewOffset }
2670
- if (context == "page" || context == "window") {
2671
- var lOff = cm.display.lineSpace.getBoundingClientRect()
2672
- yOff += lOff.top + (context == "window" ? 0 : pageScrollY())
2673
- var xOff = lOff.left + (context == "window" ? 0 : pageScrollX())
2674
- rect.left += xOff; rect.right += xOff
2675
- }
2676
- rect.top += yOff; rect.bottom += yOff
2677
- return rect
2678
- }
2679
-
2680
- // Coverts a box from "div" coords to another coordinate system.
2681
- // Context may be "window", "page", "div", or "local"./null.
2682
- function fromCoordSystem(cm, coords, context) {
2683
- if (context == "div") { return coords }
2684
- var left = coords.left, top = coords.top
2685
- // First move into "page" coordinate system
2686
- if (context == "page") {
2687
- left -= pageScrollX()
2688
- top -= pageScrollY()
2689
- } else if (context == "local" || !context) {
2690
- var localBox = cm.display.sizer.getBoundingClientRect()
2691
- left += localBox.left
2692
- top += localBox.top
2693
- }
2694
-
2695
- var lineSpaceBox = cm.display.lineSpace.getBoundingClientRect()
2696
- return {left: left - lineSpaceBox.left, top: top - lineSpaceBox.top}
2697
- }
2698
-
2699
- function charCoords(cm, pos, context, lineObj, bias) {
2700
- if (!lineObj) { lineObj = getLine(cm.doc, pos.line) }
2701
- return intoCoordSystem(cm, lineObj, measureChar(cm, lineObj, pos.ch, bias), context)
2702
- }
2703
-
2704
- // Returns a box for a given cursor position, which may have an
2705
- // 'other' property containing the position of the secondary cursor
2706
- // on a bidi boundary.
2707
- // A cursor Pos(line, char, "before") is on the same visual line as `char - 1`
2708
- // and after `char - 1` in writing order of `char - 1`
2709
- // A cursor Pos(line, char, "after") is on the same visual line as `char`
2710
- // and before `char` in writing order of `char`
2711
- // Examples (upper-case letters are RTL, lower-case are LTR):
2712
- // Pos(0, 1, ...)
2713
- // before after
2714
- // ab a|b a|b
2715
- // aB a|B aB|
2716
- // Ab |Ab A|b
2717
- // AB B|A B|A
2718
- // Every position after the last character on a line is considered to stick
2719
- // to the last character on the line.
2720
- function cursorCoords(cm, pos, context, lineObj, preparedMeasure, varHeight) {
2721
- lineObj = lineObj || getLine(cm.doc, pos.line)
2722
- if (!preparedMeasure) { preparedMeasure = prepareMeasureForLine(cm, lineObj) }
2723
- function get(ch, right) {
2724
- var m = measureCharPrepared(cm, preparedMeasure, ch, right ? "right" : "left", varHeight)
2725
- if (right) { m.left = m.right; } else { m.right = m.left }
2726
- return intoCoordSystem(cm, lineObj, m, context)
2727
- }
2728
- var order = getOrder(lineObj, cm.doc.direction), ch = pos.ch, sticky = pos.sticky
2729
- if (ch >= lineObj.text.length) {
2730
- ch = lineObj.text.length
2731
- sticky = "before"
2732
- } else if (ch <= 0) {
2733
- ch = 0
2734
- sticky = "after"
2735
- }
2736
- if (!order) { return get(sticky == "before" ? ch - 1 : ch, sticky == "before") }
2737
-
2738
- function getBidi(ch, partPos, invert) {
2739
- var part = order[partPos], right = (part.level % 2) != 0
2740
- return get(invert ? ch - 1 : ch, right != invert)
2741
- }
2742
- var partPos = getBidiPartAt(order, ch, sticky)
2743
- var other = bidiOther
2744
- var val = getBidi(ch, partPos, sticky == "before")
2745
- if (other != null) { val.other = getBidi(ch, other, sticky != "before") }
2746
- return val
2747
- }
2748
-
2749
- // Used to cheaply estimate the coordinates for a position. Used for
2750
- // intermediate scroll updates.
2751
- function estimateCoords(cm, pos) {
2752
- var left = 0
2753
- pos = clipPos(cm.doc, pos)
2754
- if (!cm.options.lineWrapping) { left = charWidth(cm.display) * pos.ch }
2755
- var lineObj = getLine(cm.doc, pos.line)
2756
- var top = heightAtLine(lineObj) + paddingTop(cm.display)
2757
- return {left: left, right: left, top: top, bottom: top + lineObj.height}
2758
- }
2759
-
2760
- // Positions returned by coordsChar contain some extra information.
2761
- // xRel is the relative x position of the input coordinates compared
2762
- // to the found position (so xRel > 0 means the coordinates are to
2763
- // the right of the character position, for example). When outside
2764
- // is true, that means the coordinates lie outside the line's
2765
- // vertical range.
2766
- function PosWithInfo(line, ch, sticky, outside, xRel) {
2767
- var pos = Pos(line, ch, sticky)
2768
- pos.xRel = xRel
2769
- if (outside) { pos.outside = true }
2770
- return pos
2771
- }
2772
-
2773
- // Compute the character position closest to the given coordinates.
2774
- // Input must be lineSpace-local ("div" coordinate system).
2775
- function coordsChar(cm, x, y) {
2776
- var doc = cm.doc
2777
- y += cm.display.viewOffset
2778
- if (y < 0) { return PosWithInfo(doc.first, 0, null, true, -1) }
2779
- var lineN = lineAtHeight(doc, y), last = doc.first + doc.size - 1
2780
- if (lineN > last)
2781
- { return PosWithInfo(doc.first + doc.size - 1, getLine(doc, last).text.length, null, true, 1) }
2782
- if (x < 0) { x = 0 }
2783
-
2784
- var lineObj = getLine(doc, lineN)
2785
- for (;;) {
2786
- var found = coordsCharInner(cm, lineObj, lineN, x, y)
2787
- var merged = collapsedSpanAtEnd(lineObj)
2788
- var mergedPos = merged && merged.find(0, true)
2789
- if (merged && (found.ch > mergedPos.from.ch || found.ch == mergedPos.from.ch && found.xRel > 0))
2790
- { lineN = lineNo(lineObj = mergedPos.to.line) }
2791
- else
2792
- { return found }
2793
- }
2794
- }
2795
-
2796
- function wrappedLineExtent(cm, lineObj, preparedMeasure, y) {
2797
- var measure = function (ch) { return intoCoordSystem(cm, lineObj, measureCharPrepared(cm, preparedMeasure, ch), "line"); }
2798
- var end = lineObj.text.length
2799
- var begin = findFirst(function (ch) { return measure(ch - 1).bottom <= y; }, end, 0)
2800
- end = findFirst(function (ch) { return measure(ch).top > y; }, begin, end)
2801
- return {begin: begin, end: end}
2802
- }
2803
-
2804
- function wrappedLineExtentChar(cm, lineObj, preparedMeasure, target) {
2805
- var targetTop = intoCoordSystem(cm, lineObj, measureCharPrepared(cm, preparedMeasure, target), "line").top
2806
- return wrappedLineExtent(cm, lineObj, preparedMeasure, targetTop)
2807
- }
2808
-
2809
- function coordsCharInner(cm, lineObj, lineNo, x, y) {
2810
- y -= heightAtLine(lineObj)
2811
- var begin = 0, end = lineObj.text.length
2812
- var preparedMeasure = prepareMeasureForLine(cm, lineObj)
2813
- var pos
2814
- var order = getOrder(lineObj, cm.doc.direction)
2815
- if (order) {
2816
- if (cm.options.lineWrapping) {
2817
- ;var assign;
2818
- ((assign = wrappedLineExtent(cm, lineObj, preparedMeasure, y), begin = assign.begin, end = assign.end, assign))
2819
- }
2820
- pos = new Pos(lineNo, begin)
2821
- var beginLeft = cursorCoords(cm, pos, "line", lineObj, preparedMeasure).left
2822
- var dir = beginLeft < x ? 1 : -1
2823
- var prevDiff, diff = beginLeft - x, prevPos
2824
- do {
2825
- prevDiff = diff
2826
- prevPos = pos
2827
- pos = moveVisually(cm, lineObj, pos, dir)
2828
- if (pos == null || pos.ch < begin || end <= (pos.sticky == "before" ? pos.ch - 1 : pos.ch)) {
2829
- pos = prevPos
2830
- break
2831
- }
2832
- diff = cursorCoords(cm, pos, "line", lineObj, preparedMeasure).left - x
2833
- } while ((dir < 0) != (diff < 0) && (Math.abs(diff) <= Math.abs(prevDiff)))
2834
- if (Math.abs(diff) > Math.abs(prevDiff)) {
2835
- if ((diff < 0) == (prevDiff < 0)) { throw new Error("Broke out of infinite loop in coordsCharInner") }
2836
- pos = prevPos
2837
- }
2838
- } else {
2839
- var ch = findFirst(function (ch) {
2840
- var box = intoCoordSystem(cm, lineObj, measureCharPrepared(cm, preparedMeasure, ch), "line")
2841
- if (box.top > y) {
2842
- // For the cursor stickiness
2843
- end = Math.min(ch, end)
2844
- return true
2845
- }
2846
- else if (box.bottom <= y) { return false }
2847
- else if (box.left > x) { return true }
2848
- else if (box.right < x) { return false }
2849
- else { return (x - box.left < box.right - x) }
2850
- }, begin, end)
2851
- ch = skipExtendingChars(lineObj.text, ch, 1)
2852
- pos = new Pos(lineNo, ch, ch == end ? "before" : "after")
2853
- }
2854
- var coords = cursorCoords(cm, pos, "line", lineObj, preparedMeasure)
2855
- if (y < coords.top || coords.bottom < y) { pos.outside = true }
2856
- pos.xRel = x < coords.left ? -1 : (x > coords.right ? 1 : 0)
2857
- return pos
2858
- }
2859
-
2860
- var measureText
2861
- // Compute the default text height.
2862
- function textHeight(display) {
2863
- if (display.cachedTextHeight != null) { return display.cachedTextHeight }
2864
- if (measureText == null) {
2865
- measureText = elt("pre")
2866
- // Measure a bunch of lines, for browsers that compute
2867
- // fractional heights.
2868
- for (var i = 0; i < 49; ++i) {
2869
- measureText.appendChild(document.createTextNode("x"))
2870
- measureText.appendChild(elt("br"))
2871
- }
2872
- measureText.appendChild(document.createTextNode("x"))
2873
- }
2874
- removeChildrenAndAdd(display.measure, measureText)
2875
- var height = measureText.offsetHeight / 50
2876
- if (height > 3) { display.cachedTextHeight = height }
2877
- removeChildren(display.measure)
2878
- return height || 1
2879
- }
2880
-
2881
- // Compute the default character width.
2882
- function charWidth(display) {
2883
- if (display.cachedCharWidth != null) { return display.cachedCharWidth }
2884
- var anchor = elt("span", "xxxxxxxxxx")
2885
- var pre = elt("pre", [anchor])
2886
- removeChildrenAndAdd(display.measure, pre)
2887
- var rect = anchor.getBoundingClientRect(), width = (rect.right - rect.left) / 10
2888
- if (width > 2) { display.cachedCharWidth = width }
2889
- return width || 10
2890
- }
2891
-
2892
- // Do a bulk-read of the DOM positions and sizes needed to draw the
2893
- // view, so that we don't interleave reading and writing to the DOM.
2894
- function getDimensions(cm) {
2895
- var d = cm.display, left = {}, width = {}
2896
- var gutterLeft = d.gutters.clientLeft
2897
- for (var n = d.gutters.firstChild, i = 0; n; n = n.nextSibling, ++i) {
2898
- left[cm.options.gutters[i]] = n.offsetLeft + n.clientLeft + gutterLeft
2899
- width[cm.options.gutters[i]] = n.clientWidth
2900
- }
2901
- return {fixedPos: compensateForHScroll(d),
2902
- gutterTotalWidth: d.gutters.offsetWidth,
2903
- gutterLeft: left,
2904
- gutterWidth: width,
2905
- wrapperWidth: d.wrapper.clientWidth}
2906
- }
2907
-
2908
- // Computes display.scroller.scrollLeft + display.gutters.offsetWidth,
2909
- // but using getBoundingClientRect to get a sub-pixel-accurate
2910
- // result.
2911
- function compensateForHScroll(display) {
2912
- return display.scroller.getBoundingClientRect().left - display.sizer.getBoundingClientRect().left
2913
- }
2914
-
2915
- // Returns a function that estimates the height of a line, to use as
2916
- // first approximation until the line becomes visible (and is thus
2917
- // properly measurable).
2918
- function estimateHeight(cm) {
2919
- var th = textHeight(cm.display), wrapping = cm.options.lineWrapping
2920
- var perLine = wrapping && Math.max(5, cm.display.scroller.clientWidth / charWidth(cm.display) - 3)
2921
- return function (line) {
2922
- if (lineIsHidden(cm.doc, line)) { return 0 }
2923
-
2924
- var widgetsHeight = 0
2925
- if (line.widgets) { for (var i = 0; i < line.widgets.length; i++) {
2926
- if (line.widgets[i].height) { widgetsHeight += line.widgets[i].height }
2927
- } }
2928
-
2929
- if (wrapping)
2930
- { return widgetsHeight + (Math.ceil(line.text.length / perLine) || 1) * th }
2931
- else
2932
- { return widgetsHeight + th }
2933
- }
2934
- }
2935
-
2936
- function estimateLineHeights(cm) {
2937
- var doc = cm.doc, est = estimateHeight(cm)
2938
- doc.iter(function (line) {
2939
- var estHeight = est(line)
2940
- if (estHeight != line.height) { updateLineHeight(line, estHeight) }
2941
- })
2942
- }
2943
-
2944
- // Given a mouse event, find the corresponding position. If liberal
2945
- // is false, it checks whether a gutter or scrollbar was clicked,
2946
- // and returns null if it was. forRect is used by rectangular
2947
- // selections, and tries to estimate a character position even for
2948
- // coordinates beyond the right of the text.
2949
- function posFromMouse(cm, e, liberal, forRect) {
2950
- var display = cm.display
2951
- if (!liberal && e_target(e).getAttribute("cm-not-content") == "true") { return null }
2952
-
2953
- var x, y, space = display.lineSpace.getBoundingClientRect()
2954
- // Fails unpredictably on IE[67] when mouse is dragged around quickly.
2955
- try { x = e.clientX - space.left; y = e.clientY - space.top }
2956
- catch (e) { return null }
2957
- var coords = coordsChar(cm, x, y), line
2958
- if (forRect && coords.xRel == 1 && (line = getLine(cm.doc, coords.line).text).length == coords.ch) {
2959
- var colDiff = countColumn(line, line.length, cm.options.tabSize) - line.length
2960
- coords = Pos(coords.line, Math.max(0, Math.round((x - paddingH(cm.display).left) / charWidth(cm.display)) - colDiff))
2961
- }
2962
- return coords
2963
- }
2964
-
2965
- // Find the view element corresponding to a given line. Return null
2966
- // when the line isn't visible.
2967
- function findViewIndex(cm, n) {
2968
- if (n >= cm.display.viewTo) { return null }
2969
- n -= cm.display.viewFrom
2970
- if (n < 0) { return null }
2971
- var view = cm.display.view
2972
- for (var i = 0; i < view.length; i++) {
2973
- n -= view[i].size
2974
- if (n < 0) { return i }
2975
- }
2976
- }
2977
-
2978
- function updateSelection(cm) {
2979
- cm.display.input.showSelection(cm.display.input.prepareSelection())
2980
- }
2981
-
2982
- function prepareSelection(cm, primary) {
2983
- var doc = cm.doc, result = {}
2984
- var curFragment = result.cursors = document.createDocumentFragment()
2985
- var selFragment = result.selection = document.createDocumentFragment()
2986
-
2987
- for (var i = 0; i < doc.sel.ranges.length; i++) {
2988
- if (primary === false && i == doc.sel.primIndex) { continue }
2989
- var range = doc.sel.ranges[i]
2990
- if (range.from().line >= cm.display.viewTo || range.to().line < cm.display.viewFrom) { continue }
2991
- var collapsed = range.empty()
2992
- if (collapsed || cm.options.showCursorWhenSelecting)
2993
- { drawSelectionCursor(cm, range.head, curFragment) }
2994
- if (!collapsed)
2995
- { drawSelectionRange(cm, range, selFragment) }
2996
- }
2997
- return result
2998
- }
2999
-
3000
- // Draws a cursor for the given range
3001
- function drawSelectionCursor(cm, head, output) {
3002
- var pos = cursorCoords(cm, head, "div", null, null, !cm.options.singleCursorHeightPerLine)
3003
-
3004
- var cursor = output.appendChild(elt("div", "\u00a0", "CodeMirror-cursor"))
3005
- cursor.style.left = pos.left + "px"
3006
- cursor.style.top = pos.top + "px"
3007
- cursor.style.height = Math.max(0, pos.bottom - pos.top) * cm.options.cursorHeight + "px"
3008
-
3009
- if (pos.other) {
3010
- // Secondary cursor, shown when on a 'jump' in bi-directional text
3011
- var otherCursor = output.appendChild(elt("div", "\u00a0", "CodeMirror-cursor CodeMirror-secondarycursor"))
3012
- otherCursor.style.display = ""
3013
- otherCursor.style.left = pos.other.left + "px"
3014
- otherCursor.style.top = pos.other.top + "px"
3015
- otherCursor.style.height = (pos.other.bottom - pos.other.top) * .85 + "px"
3016
- }
3017
- }
3018
-
3019
- // Draws the given range as a highlighted selection
3020
- function drawSelectionRange(cm, range, output) {
3021
- var display = cm.display, doc = cm.doc
3022
- var fragment = document.createDocumentFragment()
3023
- var padding = paddingH(cm.display), leftSide = padding.left
3024
- var rightSide = Math.max(display.sizerWidth, displayWidth(cm) - display.sizer.offsetLeft) - padding.right
3025
-
3026
- function add(left, top, width, bottom) {
3027
- if (top < 0) { top = 0 }
3028
- top = Math.round(top)
3029
- bottom = Math.round(bottom)
3030
- fragment.appendChild(elt("div", null, "CodeMirror-selected", ("position: absolute; left: " + left + "px;\n top: " + top + "px; width: " + (width == null ? rightSide - left : width) + "px;\n height: " + (bottom - top) + "px")))
3031
- }
3032
-
3033
- function drawForLine(line, fromArg, toArg) {
3034
- var lineObj = getLine(doc, line)
3035
- var lineLen = lineObj.text.length
3036
- var start, end
3037
- function coords(ch, bias) {
3038
- return charCoords(cm, Pos(line, ch), "div", lineObj, bias)
3039
- }
3040
-
3041
- iterateBidiSections(getOrder(lineObj, doc.direction), fromArg || 0, toArg == null ? lineLen : toArg, function (from, to, dir) {
3042
- var leftPos = coords(from, "left"), rightPos, left, right
3043
- if (from == to) {
3044
- rightPos = leftPos
3045
- left = right = leftPos.left
3046
- } else {
3047
- rightPos = coords(to - 1, "right")
3048
- if (dir == "rtl") { var tmp = leftPos; leftPos = rightPos; rightPos = tmp }
3049
- left = leftPos.left
3050
- right = rightPos.right
3051
- }
3052
- if (fromArg == null && from == 0) { left = leftSide }
3053
- if (rightPos.top - leftPos.top > 3) { // Different lines, draw top part
3054
- add(left, leftPos.top, null, leftPos.bottom)
3055
- left = leftSide
3056
- if (leftPos.bottom < rightPos.top) { add(left, leftPos.bottom, null, rightPos.top) }
3057
- }
3058
- if (toArg == null && to == lineLen) { right = rightSide }
3059
- if (!start || leftPos.top < start.top || leftPos.top == start.top && leftPos.left < start.left)
3060
- { start = leftPos }
3061
- if (!end || rightPos.bottom > end.bottom || rightPos.bottom == end.bottom && rightPos.right > end.right)
3062
- { end = rightPos }
3063
- if (left < leftSide + 1) { left = leftSide }
3064
- add(left, rightPos.top, right - left, rightPos.bottom)
3065
- })
3066
- return {start: start, end: end}
3067
- }
3068
-
3069
- var sFrom = range.from(), sTo = range.to()
3070
- if (sFrom.line == sTo.line) {
3071
- drawForLine(sFrom.line, sFrom.ch, sTo.ch)
3072
- } else {
3073
- var fromLine = getLine(doc, sFrom.line), toLine = getLine(doc, sTo.line)
3074
- var singleVLine = visualLine(fromLine) == visualLine(toLine)
3075
- var leftEnd = drawForLine(sFrom.line, sFrom.ch, singleVLine ? fromLine.text.length + 1 : null).end
3076
- var rightStart = drawForLine(sTo.line, singleVLine ? 0 : null, sTo.ch).start
3077
- if (singleVLine) {
3078
- if (leftEnd.top < rightStart.top - 2) {
3079
- add(leftEnd.right, leftEnd.top, null, leftEnd.bottom)
3080
- add(leftSide, rightStart.top, rightStart.left, rightStart.bottom)
3081
- } else {
3082
- add(leftEnd.right, leftEnd.top, rightStart.left - leftEnd.right, leftEnd.bottom)
3083
- }
3084
- }
3085
- if (leftEnd.bottom < rightStart.top)
3086
- { add(leftSide, leftEnd.bottom, null, rightStart.top) }
3087
- }
3088
-
3089
- output.appendChild(fragment)
3090
- }
3091
-
3092
- // Cursor-blinking
3093
- function restartBlink(cm) {
3094
- if (!cm.state.focused) { return }
3095
- var display = cm.display
3096
- clearInterval(display.blinker)
3097
- var on = true
3098
- display.cursorDiv.style.visibility = ""
3099
- if (cm.options.cursorBlinkRate > 0)
3100
- { display.blinker = setInterval(function () { return display.cursorDiv.style.visibility = (on = !on) ? "" : "hidden"; },
3101
- cm.options.cursorBlinkRate) }
3102
- else if (cm.options.cursorBlinkRate < 0)
3103
- { display.cursorDiv.style.visibility = "hidden" }
3104
- }
3105
-
3106
- function ensureFocus(cm) {
3107
- if (!cm.state.focused) { cm.display.input.focus(); onFocus(cm) }
3108
- }
3109
-
3110
- function delayBlurEvent(cm) {
3111
- cm.state.delayingBlurEvent = true
3112
- setTimeout(function () { if (cm.state.delayingBlurEvent) {
3113
- cm.state.delayingBlurEvent = false
3114
- onBlur(cm)
3115
- } }, 100)
3116
- }
3117
-
3118
- function onFocus(cm, e) {
3119
- if (cm.state.delayingBlurEvent) { cm.state.delayingBlurEvent = false }
3120
-
3121
- if (cm.options.readOnly == "nocursor") { return }
3122
- if (!cm.state.focused) {
3123
- signal(cm, "focus", cm, e)
3124
- cm.state.focused = true
3125
- addClass(cm.display.wrapper, "CodeMirror-focused")
3126
- // This test prevents this from firing when a context
3127
- // menu is closed (since the input reset would kill the
3128
- // select-all detection hack)
3129
- if (!cm.curOp && cm.display.selForContextMenu != cm.doc.sel) {
3130
- cm.display.input.reset()
3131
- if (webkit) { setTimeout(function () { return cm.display.input.reset(true); }, 20) } // Issue #1730
3132
- }
3133
- cm.display.input.receivedFocus()
3134
- }
3135
- restartBlink(cm)
3136
- }
3137
- function onBlur(cm, e) {
3138
- if (cm.state.delayingBlurEvent) { return }
3139
-
3140
- if (cm.state.focused) {
3141
- signal(cm, "blur", cm, e)
3142
- cm.state.focused = false
3143
- rmClass(cm.display.wrapper, "CodeMirror-focused")
3144
- }
3145
- clearInterval(cm.display.blinker)
3146
- setTimeout(function () { if (!cm.state.focused) { cm.display.shift = false } }, 150)
3147
- }
3148
-
3149
- // Read the actual heights of the rendered lines, and update their
3150
- // stored heights to match.
3151
- function updateHeightsInViewport(cm) {
3152
- var display = cm.display
3153
- var prevBottom = display.lineDiv.offsetTop
3154
- for (var i = 0; i < display.view.length; i++) {
3155
- var cur = display.view[i], height = (void 0)
3156
- if (cur.hidden) { continue }
3157
- if (ie && ie_version < 8) {
3158
- var bot = cur.node.offsetTop + cur.node.offsetHeight
3159
- height = bot - prevBottom
3160
- prevBottom = bot
3161
- } else {
3162
- var box = cur.node.getBoundingClientRect()
3163
- height = box.bottom - box.top
3164
- }
3165
- var diff = cur.line.height - height
3166
- if (height < 2) { height = textHeight(display) }
3167
- if (diff > .001 || diff < -.001) {
3168
- updateLineHeight(cur.line, height)
3169
- updateWidgetHeight(cur.line)
3170
- if (cur.rest) { for (var j = 0; j < cur.rest.length; j++)
3171
- { updateWidgetHeight(cur.rest[j]) } }
3172
- }
3173
- }
3174
- }
3175
-
3176
- // Read and store the height of line widgets associated with the
3177
- // given line.
3178
- function updateWidgetHeight(line) {
3179
- if (line.widgets) { for (var i = 0; i < line.widgets.length; ++i)
3180
- { line.widgets[i].height = line.widgets[i].node.parentNode.offsetHeight } }
3181
- }
3182
-
3183
- // Compute the lines that are visible in a given viewport (defaults
3184
- // the the current scroll position). viewport may contain top,
3185
- // height, and ensure (see op.scrollToPos) properties.
3186
- function visibleLines(display, doc, viewport) {
3187
- var top = viewport && viewport.top != null ? Math.max(0, viewport.top) : display.scroller.scrollTop
3188
- top = Math.floor(top - paddingTop(display))
3189
- var bottom = viewport && viewport.bottom != null ? viewport.bottom : top + display.wrapper.clientHeight
3190
-
3191
- var from = lineAtHeight(doc, top), to = lineAtHeight(doc, bottom)
3192
- // Ensure is a {from: {line, ch}, to: {line, ch}} object, and
3193
- // forces those lines into the viewport (if possible).
3194
- if (viewport && viewport.ensure) {
3195
- var ensureFrom = viewport.ensure.from.line, ensureTo = viewport.ensure.to.line
3196
- if (ensureFrom < from) {
3197
- from = ensureFrom
3198
- to = lineAtHeight(doc, heightAtLine(getLine(doc, ensureFrom)) + display.wrapper.clientHeight)
3199
- } else if (Math.min(ensureTo, doc.lastLine()) >= to) {
3200
- from = lineAtHeight(doc, heightAtLine(getLine(doc, ensureTo)) - display.wrapper.clientHeight)
3201
- to = ensureTo
3202
- }
3203
- }
3204
- return {from: from, to: Math.max(to, from + 1)}
3205
- }
3206
-
3207
- // Re-align line numbers and gutter marks to compensate for
3208
- // horizontal scrolling.
3209
- function alignHorizontally(cm) {
3210
- var display = cm.display, view = display.view
3211
- if (!display.alignWidgets && (!display.gutters.firstChild || !cm.options.fixedGutter)) { return }
3212
- var comp = compensateForHScroll(display) - display.scroller.scrollLeft + cm.doc.scrollLeft
3213
- var gutterW = display.gutters.offsetWidth, left = comp + "px"
3214
- for (var i = 0; i < view.length; i++) { if (!view[i].hidden) {
3215
- if (cm.options.fixedGutter) {
3216
- if (view[i].gutter)
3217
- { view[i].gutter.style.left = left }
3218
- if (view[i].gutterBackground)
3219
- { view[i].gutterBackground.style.left = left }
3220
- }
3221
- var align = view[i].alignable
3222
- if (align) { for (var j = 0; j < align.length; j++)
3223
- { align[j].style.left = left } }
3224
- } }
3225
- if (cm.options.fixedGutter)
3226
- { display.gutters.style.left = (comp + gutterW) + "px" }
3227
- }
3228
-
3229
- // Used to ensure that the line number gutter is still the right
3230
- // size for the current document size. Returns true when an update
3231
- // is needed.
3232
- function maybeUpdateLineNumberWidth(cm) {
3233
- if (!cm.options.lineNumbers) { return false }
3234
- var doc = cm.doc, last = lineNumberFor(cm.options, doc.first + doc.size - 1), display = cm.display
3235
- if (last.length != display.lineNumChars) {
3236
- var test = display.measure.appendChild(elt("div", [elt("div", last)],
3237
- "CodeMirror-linenumber CodeMirror-gutter-elt"))
3238
- var innerW = test.firstChild.offsetWidth, padding = test.offsetWidth - innerW
3239
- display.lineGutter.style.width = ""
3240
- display.lineNumInnerWidth = Math.max(innerW, display.lineGutter.offsetWidth - padding) + 1
3241
- display.lineNumWidth = display.lineNumInnerWidth + padding
3242
- display.lineNumChars = display.lineNumInnerWidth ? last.length : -1
3243
- display.lineGutter.style.width = display.lineNumWidth + "px"
3244
- updateGutterSpace(cm)
3245
- return true
3246
- }
3247
- return false
3248
- }
3249
-
3250
- // SCROLLING THINGS INTO VIEW
3251
-
3252
- // If an editor sits on the top or bottom of the window, partially
3253
- // scrolled out of view, this ensures that the cursor is visible.
3254
- function maybeScrollWindow(cm, rect) {
3255
- if (signalDOMEvent(cm, "scrollCursorIntoView")) { return }
3256
-
3257
- var display = cm.display, box = display.sizer.getBoundingClientRect(), doScroll = null
3258
- if (rect.top + box.top < 0) { doScroll = true }
3259
- else if (rect.bottom + box.top > (window.innerHeight || document.documentElement.clientHeight)) { doScroll = false }
3260
- if (doScroll != null && !phantom) {
3261
- var scrollNode = elt("div", "\u200b", null, ("position: absolute;\n top: " + (rect.top - display.viewOffset - paddingTop(cm.display)) + "px;\n height: " + (rect.bottom - rect.top + scrollGap(cm) + display.barHeight) + "px;\n left: " + (rect.left) + "px; width: " + (Math.max(2, rect.right - rect.left)) + "px;"))
3262
- cm.display.lineSpace.appendChild(scrollNode)
3263
- scrollNode.scrollIntoView(doScroll)
3264
- cm.display.lineSpace.removeChild(scrollNode)
3265
- }
3266
- }
3267
-
3268
- // Scroll a given position into view (immediately), verifying that
3269
- // it actually became visible (as line heights are accurately
3270
- // measured, the position of something may 'drift' during drawing).
3271
- function scrollPosIntoView(cm, pos, end, margin) {
3272
- if (margin == null) { margin = 0 }
3273
- var rect
3274
- for (var limit = 0; limit < 5; limit++) {
3275
- var changed = false
3276
- var coords = cursorCoords(cm, pos)
3277
- var endCoords = !end || end == pos ? coords : cursorCoords(cm, end)
3278
- rect = {left: Math.min(coords.left, endCoords.left),
3279
- top: Math.min(coords.top, endCoords.top) - margin,
3280
- right: Math.max(coords.left, endCoords.left),
3281
- bottom: Math.max(coords.bottom, endCoords.bottom) + margin}
3282
- var scrollPos = calculateScrollPos(cm, rect)
3283
- var startTop = cm.doc.scrollTop, startLeft = cm.doc.scrollLeft
3284
- if (scrollPos.scrollTop != null) {
3285
- updateScrollTop(cm, scrollPos.scrollTop)
3286
- if (Math.abs(cm.doc.scrollTop - startTop) > 1) { changed = true }
3287
- }
3288
- if (scrollPos.scrollLeft != null) {
3289
- setScrollLeft(cm, scrollPos.scrollLeft)
3290
- if (Math.abs(cm.doc.scrollLeft - startLeft) > 1) { changed = true }
3291
- }
3292
- if (!changed) { break }
3293
- }
3294
- return rect
3295
- }
3296
-
3297
- // Scroll a given set of coordinates into view (immediately).
3298
- function scrollIntoView(cm, rect) {
3299
- var scrollPos = calculateScrollPos(cm, rect)
3300
- if (scrollPos.scrollTop != null) { updateScrollTop(cm, scrollPos.scrollTop) }
3301
- if (scrollPos.scrollLeft != null) { setScrollLeft(cm, scrollPos.scrollLeft) }
3302
- }
3303
-
3304
- // Calculate a new scroll position needed to scroll the given
3305
- // rectangle into view. Returns an object with scrollTop and
3306
- // scrollLeft properties. When these are undefined, the
3307
- // vertical/horizontal position does not need to be adjusted.
3308
- function calculateScrollPos(cm, rect) {
3309
- var display = cm.display, snapMargin = textHeight(cm.display)
3310
- if (rect.top < 0) { rect.top = 0 }
3311
- var screentop = cm.curOp && cm.curOp.scrollTop != null ? cm.curOp.scrollTop : display.scroller.scrollTop
3312
- var screen = displayHeight(cm), result = {}
3313
- if (rect.bottom - rect.top > screen) { rect.bottom = rect.top + screen }
3314
- var docBottom = cm.doc.height + paddingVert(display)
3315
- var atTop = rect.top < snapMargin, atBottom = rect.bottom > docBottom - snapMargin
3316
- if (rect.top < screentop) {
3317
- result.scrollTop = atTop ? 0 : rect.top
3318
- } else if (rect.bottom > screentop + screen) {
3319
- var newTop = Math.min(rect.top, (atBottom ? docBottom : rect.bottom) - screen)
3320
- if (newTop != screentop) { result.scrollTop = newTop }
3321
- }
3322
-
3323
- var screenleft = cm.curOp && cm.curOp.scrollLeft != null ? cm.curOp.scrollLeft : display.scroller.scrollLeft
3324
- var screenw = displayWidth(cm) - (cm.options.fixedGutter ? display.gutters.offsetWidth : 0)
3325
- var tooWide = rect.right - rect.left > screenw
3326
- if (tooWide) { rect.right = rect.left + screenw }
3327
- if (rect.left < 10)
3328
- { result.scrollLeft = 0 }
3329
- else if (rect.left < screenleft)
3330
- { result.scrollLeft = Math.max(0, rect.left - (tooWide ? 0 : 10)) }
3331
- else if (rect.right > screenw + screenleft - 3)
3332
- { result.scrollLeft = rect.right + (tooWide ? 0 : 10) - screenw }
3333
- return result
3334
- }
3335
-
3336
- // Store a relative adjustment to the scroll position in the current
3337
- // operation (to be applied when the operation finishes).
3338
- function addToScrollTop(cm, top) {
3339
- if (top == null) { return }
3340
- resolveScrollToPos(cm)
3341
- cm.curOp.scrollTop = (cm.curOp.scrollTop == null ? cm.doc.scrollTop : cm.curOp.scrollTop) + top
3342
- }
3343
-
3344
- // Make sure that at the end of the operation the current cursor is
3345
- // shown.
3346
- function ensureCursorVisible(cm) {
3347
- resolveScrollToPos(cm)
3348
- var cur = cm.getCursor(), from = cur, to = cur
3349
- if (!cm.options.lineWrapping) {
3350
- from = cur.ch ? Pos(cur.line, cur.ch - 1) : cur
3351
- to = Pos(cur.line, cur.ch + 1)
3352
- }
3353
- cm.curOp.scrollToPos = {from: from, to: to, margin: cm.options.cursorScrollMargin}
3354
- }
3355
-
3356
- function scrollToCoords(cm, x, y) {
3357
- if (x != null || y != null) { resolveScrollToPos(cm) }
3358
- if (x != null) { cm.curOp.scrollLeft = x }
3359
- if (y != null) { cm.curOp.scrollTop = y }
3360
- }
3361
-
3362
- function scrollToRange(cm, range) {
3363
- resolveScrollToPos(cm)
3364
- cm.curOp.scrollToPos = range
3365
- }
3366
-
3367
- // When an operation has its scrollToPos property set, and another
3368
- // scroll action is applied before the end of the operation, this
3369
- // 'simulates' scrolling that position into view in a cheap way, so
3370
- // that the effect of intermediate scroll commands is not ignored.
3371
- function resolveScrollToPos(cm) {
3372
- var range = cm.curOp.scrollToPos
3373
- if (range) {
3374
- cm.curOp.scrollToPos = null
3375
- var from = estimateCoords(cm, range.from), to = estimateCoords(cm, range.to)
3376
- scrollToCoordsRange(cm, from, to, range.margin)
3377
- }
3378
- }
3379
-
3380
- function scrollToCoordsRange(cm, from, to, margin) {
3381
- var sPos = calculateScrollPos(cm, {
3382
- left: Math.min(from.left, to.left),
3383
- top: Math.min(from.top, to.top) - margin,
3384
- right: Math.max(from.right, to.right),
3385
- bottom: Math.max(from.bottom, to.bottom) + margin
3386
- })
3387
- scrollToCoords(cm, sPos.scrollLeft, sPos.scrollTop)
3388
- }
3389
-
3390
- // Sync the scrollable area and scrollbars, ensure the viewport
3391
- // covers the visible area.
3392
- function updateScrollTop(cm, val) {
3393
- if (Math.abs(cm.doc.scrollTop - val) < 2) { return }
3394
- if (!gecko) { updateDisplaySimple(cm, {top: val}) }
3395
- setScrollTop(cm, val, true)
3396
- if (gecko) { updateDisplaySimple(cm) }
3397
- startWorker(cm, 100)
3398
- }
3399
-
3400
- function setScrollTop(cm, val, forceScroll) {
3401
- val = Math.min(cm.display.scroller.scrollHeight - cm.display.scroller.clientHeight, val)
3402
- if (cm.display.scroller.scrollTop == val && !forceScroll) { return }
3403
- cm.doc.scrollTop = val
3404
- cm.display.scrollbars.setScrollTop(val)
3405
- if (cm.display.scroller.scrollTop != val) { cm.display.scroller.scrollTop = val }
3406
- }
3407
-
3408
- // Sync scroller and scrollbar, ensure the gutter elements are
3409
- // aligned.
3410
- function setScrollLeft(cm, val, isScroller, forceScroll) {
3411
- val = Math.min(val, cm.display.scroller.scrollWidth - cm.display.scroller.clientWidth)
3412
- if ((isScroller ? val == cm.doc.scrollLeft : Math.abs(cm.doc.scrollLeft - val) < 2) && !forceScroll) { return }
3413
- cm.doc.scrollLeft = val
3414
- alignHorizontally(cm)
3415
- if (cm.display.scroller.scrollLeft != val) { cm.display.scroller.scrollLeft = val }
3416
- cm.display.scrollbars.setScrollLeft(val)
3417
- }
3418
-
3419
- // SCROLLBARS
3420
-
3421
- // Prepare DOM reads needed to update the scrollbars. Done in one
3422
- // shot to minimize update/measure roundtrips.
3423
- function measureForScrollbars(cm) {
3424
- var d = cm.display, gutterW = d.gutters.offsetWidth
3425
- var docH = Math.round(cm.doc.height + paddingVert(cm.display))
3426
- return {
3427
- clientHeight: d.scroller.clientHeight,
3428
- viewHeight: d.wrapper.clientHeight,
3429
- scrollWidth: d.scroller.scrollWidth, clientWidth: d.scroller.clientWidth,
3430
- viewWidth: d.wrapper.clientWidth,
3431
- barLeft: cm.options.fixedGutter ? gutterW : 0,
3432
- docHeight: docH,
3433
- scrollHeight: docH + scrollGap(cm) + d.barHeight,
3434
- nativeBarWidth: d.nativeBarWidth,
3435
- gutterWidth: gutterW
3436
- }
3437
- }
3438
-
3439
- var NativeScrollbars = function(place, scroll, cm) {
3440
- this.cm = cm
3441
- var vert = this.vert = elt("div", [elt("div", null, null, "min-width: 1px")], "CodeMirror-vscrollbar")
3442
- var horiz = this.horiz = elt("div", [elt("div", null, null, "height: 100%; min-height: 1px")], "CodeMirror-hscrollbar")
3443
- place(vert); place(horiz)
3444
-
3445
- on(vert, "scroll", function () {
3446
- if (vert.clientHeight) { scroll(vert.scrollTop, "vertical") }
3447
- })
3448
- on(horiz, "scroll", function () {
3449
- if (horiz.clientWidth) { scroll(horiz.scrollLeft, "horizontal") }
3450
- })
3451
-
3452
- this.checkedZeroWidth = false
3453
- // Need to set a minimum width to see the scrollbar on IE7 (but must not set it on IE8).
3454
- if (ie && ie_version < 8) { this.horiz.style.minHeight = this.vert.style.minWidth = "18px" }
3455
- };
3456
-
3457
- NativeScrollbars.prototype.update = function (measure) {
3458
- var needsH = measure.scrollWidth > measure.clientWidth + 1
3459
- var needsV = measure.scrollHeight > measure.clientHeight + 1
3460
- var sWidth = measure.nativeBarWidth
3461
-
3462
- if (needsV) {
3463
- this.vert.style.display = "block"
3464
- this.vert.style.bottom = needsH ? sWidth + "px" : "0"
3465
- var totalHeight = measure.viewHeight - (needsH ? sWidth : 0)
3466
- // A bug in IE8 can cause this value to be negative, so guard it.
3467
- this.vert.firstChild.style.height =
3468
- Math.max(0, measure.scrollHeight - measure.clientHeight + totalHeight) + "px"
3469
- } else {
3470
- this.vert.style.display = ""
3471
- this.vert.firstChild.style.height = "0"
3472
- }
3473
-
3474
- if (needsH) {
3475
- this.horiz.style.display = "block"
3476
- this.horiz.style.right = needsV ? sWidth + "px" : "0"
3477
- this.horiz.style.left = measure.barLeft + "px"
3478
- var totalWidth = measure.viewWidth - measure.barLeft - (needsV ? sWidth : 0)
3479
- this.horiz.firstChild.style.width =
3480
- Math.max(0, measure.scrollWidth - measure.clientWidth + totalWidth) + "px"
3481
- } else {
3482
- this.horiz.style.display = ""
3483
- this.horiz.firstChild.style.width = "0"
3484
- }
3485
-
3486
- if (!this.checkedZeroWidth && measure.clientHeight > 0) {
3487
- if (sWidth == 0) { this.zeroWidthHack() }
3488
- this.checkedZeroWidth = true
3489
- }
3490
-
3491
- return {right: needsV ? sWidth : 0, bottom: needsH ? sWidth : 0}
3492
- };
3493
-
3494
- NativeScrollbars.prototype.setScrollLeft = function (pos) {
3495
- if (this.horiz.scrollLeft != pos) { this.horiz.scrollLeft = pos }
3496
- if (this.disableHoriz) { this.enableZeroWidthBar(this.horiz, this.disableHoriz, "horiz") }
3497
- };
3498
-
3499
- NativeScrollbars.prototype.setScrollTop = function (pos) {
3500
- if (this.vert.scrollTop != pos) { this.vert.scrollTop = pos }
3501
- if (this.disableVert) { this.enableZeroWidthBar(this.vert, this.disableVert, "vert") }
3502
- };
3503
-
3504
- NativeScrollbars.prototype.zeroWidthHack = function () {
3505
- var w = mac && !mac_geMountainLion ? "12px" : "18px"
3506
- this.horiz.style.height = this.vert.style.width = w
3507
- this.horiz.style.pointerEvents = this.vert.style.pointerEvents = "none"
3508
- this.disableHoriz = new Delayed
3509
- this.disableVert = new Delayed
3510
- };
3511
-
3512
- NativeScrollbars.prototype.enableZeroWidthBar = function (bar, delay, type) {
3513
- bar.style.pointerEvents = "auto"
3514
- function maybeDisable() {
3515
- // To find out whether the scrollbar is still visible, we
3516
- // check whether the element under the pixel in the bottom
3517
- // right corner of the scrollbar box is the scrollbar box
3518
- // itself (when the bar is still visible) or its filler child
3519
- // (when the bar is hidden). If it is still visible, we keep
3520
- // it enabled, if it's hidden, we disable pointer events.
3521
- var box = bar.getBoundingClientRect()
3522
- var elt = type == "vert" ? document.elementFromPoint(box.right - 1, (box.top + box.bottom) / 2)
3523
- : document.elementFromPoint((box.right + box.left) / 2, box.bottom - 1)
3524
- if (elt != bar) { bar.style.pointerEvents = "none" }
3525
- else { delay.set(1000, maybeDisable) }
3526
- }
3527
- delay.set(1000, maybeDisable)
3528
- };
3529
-
3530
- NativeScrollbars.prototype.clear = function () {
3531
- var parent = this.horiz.parentNode
3532
- parent.removeChild(this.horiz)
3533
- parent.removeChild(this.vert)
3534
- };
3535
-
3536
- var NullScrollbars = function () {};
3537
-
3538
- NullScrollbars.prototype.update = function () { return {bottom: 0, right: 0} };
3539
- NullScrollbars.prototype.setScrollLeft = function () {};
3540
- NullScrollbars.prototype.setScrollTop = function () {};
3541
- NullScrollbars.prototype.clear = function () {};
3542
-
3543
- function updateScrollbars(cm, measure) {
3544
- if (!measure) { measure = measureForScrollbars(cm) }
3545
- var startWidth = cm.display.barWidth, startHeight = cm.display.barHeight
3546
- updateScrollbarsInner(cm, measure)
3547
- for (var i = 0; i < 4 && startWidth != cm.display.barWidth || startHeight != cm.display.barHeight; i++) {
3548
- if (startWidth != cm.display.barWidth && cm.options.lineWrapping)
3549
- { updateHeightsInViewport(cm) }
3550
- updateScrollbarsInner(cm, measureForScrollbars(cm))
3551
- startWidth = cm.display.barWidth; startHeight = cm.display.barHeight
3552
- }
3553
- }
3554
-
3555
- // Re-synchronize the fake scrollbars with the actual size of the
3556
- // content.
3557
- function updateScrollbarsInner(cm, measure) {
3558
- var d = cm.display
3559
- var sizes = d.scrollbars.update(measure)
3560
-
3561
- d.sizer.style.paddingRight = (d.barWidth = sizes.right) + "px"
3562
- d.sizer.style.paddingBottom = (d.barHeight = sizes.bottom) + "px"
3563
- d.heightForcer.style.borderBottom = sizes.bottom + "px solid transparent"
3564
-
3565
- if (sizes.right && sizes.bottom) {
3566
- d.scrollbarFiller.style.display = "block"
3567
- d.scrollbarFiller.style.height = sizes.bottom + "px"
3568
- d.scrollbarFiller.style.width = sizes.right + "px"
3569
- } else { d.scrollbarFiller.style.display = "" }
3570
- if (sizes.bottom && cm.options.coverGutterNextToScrollbar && cm.options.fixedGutter) {
3571
- d.gutterFiller.style.display = "block"
3572
- d.gutterFiller.style.height = sizes.bottom + "px"
3573
- d.gutterFiller.style.width = measure.gutterWidth + "px"
3574
- } else { d.gutterFiller.style.display = "" }
3575
- }
3576
-
3577
- var scrollbarModel = {"native": NativeScrollbars, "null": NullScrollbars}
3578
-
3579
- function initScrollbars(cm) {
3580
- if (cm.display.scrollbars) {
3581
- cm.display.scrollbars.clear()
3582
- if (cm.display.scrollbars.addClass)
3583
- { rmClass(cm.display.wrapper, cm.display.scrollbars.addClass) }
3584
- }
3585
-
3586
- cm.display.scrollbars = new scrollbarModel[cm.options.scrollbarStyle](function (node) {
3587
- cm.display.wrapper.insertBefore(node, cm.display.scrollbarFiller)
3588
- // Prevent clicks in the scrollbars from killing focus
3589
- on(node, "mousedown", function () {
3590
- if (cm.state.focused) { setTimeout(function () { return cm.display.input.focus(); }, 0) }
3591
- })
3592
- node.setAttribute("cm-not-content", "true")
3593
- }, function (pos, axis) {
3594
- if (axis == "horizontal") { setScrollLeft(cm, pos) }
3595
- else { updateScrollTop(cm, pos) }
3596
- }, cm)
3597
- if (cm.display.scrollbars.addClass)
3598
- { addClass(cm.display.wrapper, cm.display.scrollbars.addClass) }
3599
- }
3600
-
3601
- // Operations are used to wrap a series of changes to the editor
3602
- // state in such a way that each change won't have to update the
3603
- // cursor and display (which would be awkward, slow, and
3604
- // error-prone). Instead, display updates are batched and then all
3605
- // combined and executed at once.
3606
-
3607
- var nextOpId = 0
3608
- // Start a new operation.
3609
- function startOperation(cm) {
3610
- cm.curOp = {
3611
- cm: cm,
3612
- viewChanged: false, // Flag that indicates that lines might need to be redrawn
3613
- startHeight: cm.doc.height, // Used to detect need to update scrollbar
3614
- forceUpdate: false, // Used to force a redraw
3615
- updateInput: null, // Whether to reset the input textarea
3616
- typing: false, // Whether this reset should be careful to leave existing text (for compositing)
3617
- changeObjs: null, // Accumulated changes, for firing change events
3618
- cursorActivityHandlers: null, // Set of handlers to fire cursorActivity on
3619
- cursorActivityCalled: 0, // Tracks which cursorActivity handlers have been called already
3620
- selectionChanged: false, // Whether the selection needs to be redrawn
3621
- updateMaxLine: false, // Set when the widest line needs to be determined anew
3622
- scrollLeft: null, scrollTop: null, // Intermediate scroll position, not pushed to DOM yet
3623
- scrollToPos: null, // Used to scroll to a specific position
3624
- focus: false,
3625
- id: ++nextOpId // Unique ID
3626
- }
3627
- pushOperation(cm.curOp)
3628
- }
3629
-
3630
- // Finish an operation, updating the display and signalling delayed events
3631
- function endOperation(cm) {
3632
- var op = cm.curOp
3633
- finishOperation(op, function (group) {
3634
- for (var i = 0; i < group.ops.length; i++)
3635
- { group.ops[i].cm.curOp = null }
3636
- endOperations(group)
3637
- })
3638
- }
3639
-
3640
- // The DOM updates done when an operation finishes are batched so
3641
- // that the minimum number of relayouts are required.
3642
- function endOperations(group) {
3643
- var ops = group.ops
3644
- for (var i = 0; i < ops.length; i++) // Read DOM
3645
- { endOperation_R1(ops[i]) }
3646
- for (var i$1 = 0; i$1 < ops.length; i$1++) // Write DOM (maybe)
3647
- { endOperation_W1(ops[i$1]) }
3648
- for (var i$2 = 0; i$2 < ops.length; i$2++) // Read DOM
3649
- { endOperation_R2(ops[i$2]) }
3650
- for (var i$3 = 0; i$3 < ops.length; i$3++) // Write DOM (maybe)
3651
- { endOperation_W2(ops[i$3]) }
3652
- for (var i$4 = 0; i$4 < ops.length; i$4++) // Read DOM
3653
- { endOperation_finish(ops[i$4]) }
3654
- }
3655
-
3656
- function endOperation_R1(op) {
3657
- var cm = op.cm, display = cm.display
3658
- maybeClipScrollbars(cm)
3659
- if (op.updateMaxLine) { findMaxLine(cm) }
3660
-
3661
- op.mustUpdate = op.viewChanged || op.forceUpdate || op.scrollTop != null ||
3662
- op.scrollToPos && (op.scrollToPos.from.line < display.viewFrom ||
3663
- op.scrollToPos.to.line >= display.viewTo) ||
3664
- display.maxLineChanged && cm.options.lineWrapping
3665
- op.update = op.mustUpdate &&
3666
- new DisplayUpdate(cm, op.mustUpdate && {top: op.scrollTop, ensure: op.scrollToPos}, op.forceUpdate)
3667
- }
3668
-
3669
- function endOperation_W1(op) {
3670
- op.updatedDisplay = op.mustUpdate && updateDisplayIfNeeded(op.cm, op.update)
3671
- }
3672
-
3673
- function endOperation_R2(op) {
3674
- var cm = op.cm, display = cm.display
3675
- if (op.updatedDisplay) { updateHeightsInViewport(cm) }
3676
-
3677
- op.barMeasure = measureForScrollbars(cm)
3678
-
3679
- // If the max line changed since it was last measured, measure it,
3680
- // and ensure the document's width matches it.
3681
- // updateDisplay_W2 will use these properties to do the actual resizing
3682
- if (display.maxLineChanged && !cm.options.lineWrapping) {
3683
- op.adjustWidthTo = measureChar(cm, display.maxLine, display.maxLine.text.length).left + 3
3684
- cm.display.sizerWidth = op.adjustWidthTo
3685
- op.barMeasure.scrollWidth =
3686
- Math.max(display.scroller.clientWidth, display.sizer.offsetLeft + op.adjustWidthTo + scrollGap(cm) + cm.display.barWidth)
3687
- op.maxScrollLeft = Math.max(0, display.sizer.offsetLeft + op.adjustWidthTo - displayWidth(cm))
3688
- }
3689
-
3690
- if (op.updatedDisplay || op.selectionChanged)
3691
- { op.preparedSelection = display.input.prepareSelection(op.focus) }
3692
- }
3693
-
3694
- function endOperation_W2(op) {
3695
- var cm = op.cm
3696
-
3697
- if (op.adjustWidthTo != null) {
3698
- cm.display.sizer.style.minWidth = op.adjustWidthTo + "px"
3699
- if (op.maxScrollLeft < cm.doc.scrollLeft)
3700
- { setScrollLeft(cm, Math.min(cm.display.scroller.scrollLeft, op.maxScrollLeft), true) }
3701
- cm.display.maxLineChanged = false
3702
- }
3703
-
3704
- var takeFocus = op.focus && op.focus == activeElt() && (!document.hasFocus || document.hasFocus())
3705
- if (op.preparedSelection)
3706
- { cm.display.input.showSelection(op.preparedSelection, takeFocus) }
3707
- if (op.updatedDisplay || op.startHeight != cm.doc.height)
3708
- { updateScrollbars(cm, op.barMeasure) }
3709
- if (op.updatedDisplay)
3710
- { setDocumentHeight(cm, op.barMeasure) }
3711
-
3712
- if (op.selectionChanged) { restartBlink(cm) }
3713
-
3714
- if (cm.state.focused && op.updateInput)
3715
- { cm.display.input.reset(op.typing) }
3716
- if (takeFocus) { ensureFocus(op.cm) }
3717
- }
3718
-
3719
- function endOperation_finish(op) {
3720
- var cm = op.cm, display = cm.display, doc = cm.doc
3721
-
3722
- if (op.updatedDisplay) { postUpdateDisplay(cm, op.update) }
3723
-
3724
- // Abort mouse wheel delta measurement, when scrolling explicitly
3725
- if (display.wheelStartX != null && (op.scrollTop != null || op.scrollLeft != null || op.scrollToPos))
3726
- { display.wheelStartX = display.wheelStartY = null }
3727
-
3728
- // Propagate the scroll position to the actual DOM scroller
3729
- if (op.scrollTop != null) { setScrollTop(cm, op.scrollTop, op.forceScroll) }
3730
-
3731
- if (op.scrollLeft != null) { setScrollLeft(cm, op.scrollLeft, true, true) }
3732
- // If we need to scroll a specific position into view, do so.
3733
- if (op.scrollToPos) {
3734
- var rect = scrollPosIntoView(cm, clipPos(doc, op.scrollToPos.from),
3735
- clipPos(doc, op.scrollToPos.to), op.scrollToPos.margin)
3736
- maybeScrollWindow(cm, rect)
3737
- }
3738
-
3739
- // Fire events for markers that are hidden/unidden by editing or
3740
- // undoing
3741
- var hidden = op.maybeHiddenMarkers, unhidden = op.maybeUnhiddenMarkers
3742
- if (hidden) { for (var i = 0; i < hidden.length; ++i)
3743
- { if (!hidden[i].lines.length) { signal(hidden[i], "hide") } } }
3744
- if (unhidden) { for (var i$1 = 0; i$1 < unhidden.length; ++i$1)
3745
- { if (unhidden[i$1].lines.length) { signal(unhidden[i$1], "unhide") } } }
3746
-
3747
- if (display.wrapper.offsetHeight)
3748
- { doc.scrollTop = cm.display.scroller.scrollTop }
3749
-
3750
- // Fire change events, and delayed event handlers
3751
- if (op.changeObjs)
3752
- { signal(cm, "changes", cm, op.changeObjs) }
3753
- if (op.update)
3754
- { op.update.finish() }
3755
- }
3756
-
3757
- // Run the given function in an operation
3758
- function runInOp(cm, f) {
3759
- if (cm.curOp) { return f() }
3760
- startOperation(cm)
3761
- try { return f() }
3762
- finally { endOperation(cm) }
3763
- }
3764
- // Wraps a function in an operation. Returns the wrapped function.
3765
- function operation(cm, f) {
3766
- return function() {
3767
- if (cm.curOp) { return f.apply(cm, arguments) }
3768
- startOperation(cm)
3769
- try { return f.apply(cm, arguments) }
3770
- finally { endOperation(cm) }
3771
- }
3772
- }
3773
- // Used to add methods to editor and doc instances, wrapping them in
3774
- // operations.
3775
- function methodOp(f) {
3776
- return function() {
3777
- if (this.curOp) { return f.apply(this, arguments) }
3778
- startOperation(this)
3779
- try { return f.apply(this, arguments) }
3780
- finally { endOperation(this) }
3781
- }
3782
- }
3783
- function docMethodOp(f) {
3784
- return function() {
3785
- var cm = this.cm
3786
- if (!cm || cm.curOp) { return f.apply(this, arguments) }
3787
- startOperation(cm)
3788
- try { return f.apply(this, arguments) }
3789
- finally { endOperation(cm) }
3790
- }
3791
- }
3792
-
3793
- // Updates the display.view data structure for a given change to the
3794
- // document. From and to are in pre-change coordinates. Lendiff is
3795
- // the amount of lines added or subtracted by the change. This is
3796
- // used for changes that span multiple lines, or change the way
3797
- // lines are divided into visual lines. regLineChange (below)
3798
- // registers single-line changes.
3799
- function regChange(cm, from, to, lendiff) {
3800
- if (from == null) { from = cm.doc.first }
3801
- if (to == null) { to = cm.doc.first + cm.doc.size }
3802
- if (!lendiff) { lendiff = 0 }
3803
-
3804
- var display = cm.display
3805
- if (lendiff && to < display.viewTo &&
3806
- (display.updateLineNumbers == null || display.updateLineNumbers > from))
3807
- { display.updateLineNumbers = from }
3808
-
3809
- cm.curOp.viewChanged = true
3810
-
3811
- if (from >= display.viewTo) { // Change after
3812
- if (sawCollapsedSpans && visualLineNo(cm.doc, from) < display.viewTo)
3813
- { resetView(cm) }
3814
- } else if (to <= display.viewFrom) { // Change before
3815
- if (sawCollapsedSpans && visualLineEndNo(cm.doc, to + lendiff) > display.viewFrom) {
3816
- resetView(cm)
3817
- } else {
3818
- display.viewFrom += lendiff
3819
- display.viewTo += lendiff
3820
- }
3821
- } else if (from <= display.viewFrom && to >= display.viewTo) { // Full overlap
3822
- resetView(cm)
3823
- } else if (from <= display.viewFrom) { // Top overlap
3824
- var cut = viewCuttingPoint(cm, to, to + lendiff, 1)
3825
- if (cut) {
3826
- display.view = display.view.slice(cut.index)
3827
- display.viewFrom = cut.lineN
3828
- display.viewTo += lendiff
3829
- } else {
3830
- resetView(cm)
3831
- }
3832
- } else if (to >= display.viewTo) { // Bottom overlap
3833
- var cut$1 = viewCuttingPoint(cm, from, from, -1)
3834
- if (cut$1) {
3835
- display.view = display.view.slice(0, cut$1.index)
3836
- display.viewTo = cut$1.lineN
3837
- } else {
3838
- resetView(cm)
3839
- }
3840
- } else { // Gap in the middle
3841
- var cutTop = viewCuttingPoint(cm, from, from, -1)
3842
- var cutBot = viewCuttingPoint(cm, to, to + lendiff, 1)
3843
- if (cutTop && cutBot) {
3844
- display.view = display.view.slice(0, cutTop.index)
3845
- .concat(buildViewArray(cm, cutTop.lineN, cutBot.lineN))
3846
- .concat(display.view.slice(cutBot.index))
3847
- display.viewTo += lendiff
3848
- } else {
3849
- resetView(cm)
3850
- }
3851
- }
3852
-
3853
- var ext = display.externalMeasured
3854
- if (ext) {
3855
- if (to < ext.lineN)
3856
- { ext.lineN += lendiff }
3857
- else if (from < ext.lineN + ext.size)
3858
- { display.externalMeasured = null }
3859
- }
3860
- }
3861
-
3862
- // Register a change to a single line. Type must be one of "text",
3863
- // "gutter", "class", "widget"
3864
- function regLineChange(cm, line, type) {
3865
- cm.curOp.viewChanged = true
3866
- var display = cm.display, ext = cm.display.externalMeasured
3867
- if (ext && line >= ext.lineN && line < ext.lineN + ext.size)
3868
- { display.externalMeasured = null }
3869
-
3870
- if (line < display.viewFrom || line >= display.viewTo) { return }
3871
- var lineView = display.view[findViewIndex(cm, line)]
3872
- if (lineView.node == null) { return }
3873
- var arr = lineView.changes || (lineView.changes = [])
3874
- if (indexOf(arr, type) == -1) { arr.push(type) }
3875
- }
3876
-
3877
- // Clear the view.
3878
- function resetView(cm) {
3879
- cm.display.viewFrom = cm.display.viewTo = cm.doc.first
3880
- cm.display.view = []
3881
- cm.display.viewOffset = 0
3882
- }
3883
-
3884
- function viewCuttingPoint(cm, oldN, newN, dir) {
3885
- var index = findViewIndex(cm, oldN), diff, view = cm.display.view
3886
- if (!sawCollapsedSpans || newN == cm.doc.first + cm.doc.size)
3887
- { return {index: index, lineN: newN} }
3888
- var n = cm.display.viewFrom
3889
- for (var i = 0; i < index; i++)
3890
- { n += view[i].size }
3891
- if (n != oldN) {
3892
- if (dir > 0) {
3893
- if (index == view.length - 1) { return null }
3894
- diff = (n + view[index].size) - oldN
3895
- index++
3896
- } else {
3897
- diff = n - oldN
3898
- }
3899
- oldN += diff; newN += diff
3900
- }
3901
- while (visualLineNo(cm.doc, newN) != newN) {
3902
- if (index == (dir < 0 ? 0 : view.length - 1)) { return null }
3903
- newN += dir * view[index - (dir < 0 ? 1 : 0)].size
3904
- index += dir
3905
- }
3906
- return {index: index, lineN: newN}
3907
- }
3908
-
3909
- // Force the view to cover a given range, adding empty view element
3910
- // or clipping off existing ones as needed.
3911
- function adjustView(cm, from, to) {
3912
- var display = cm.display, view = display.view
3913
- if (view.length == 0 || from >= display.viewTo || to <= display.viewFrom) {
3914
- display.view = buildViewArray(cm, from, to)
3915
- display.viewFrom = from
3916
- } else {
3917
- if (display.viewFrom > from)
3918
- { display.view = buildViewArray(cm, from, display.viewFrom).concat(display.view) }
3919
- else if (display.viewFrom < from)
3920
- { display.view = display.view.slice(findViewIndex(cm, from)) }
3921
- display.viewFrom = from
3922
- if (display.viewTo < to)
3923
- { display.view = display.view.concat(buildViewArray(cm, display.viewTo, to)) }
3924
- else if (display.viewTo > to)
3925
- { display.view = display.view.slice(0, findViewIndex(cm, to)) }
3926
- }
3927
- display.viewTo = to
3928
- }
3929
-
3930
- // Count the number of lines in the view whose DOM representation is
3931
- // out of date (or nonexistent).
3932
- function countDirtyView(cm) {
3933
- var view = cm.display.view, dirty = 0
3934
- for (var i = 0; i < view.length; i++) {
3935
- var lineView = view[i]
3936
- if (!lineView.hidden && (!lineView.node || lineView.changes)) { ++dirty }
3937
- }
3938
- return dirty
3939
- }
3940
-
3941
- // HIGHLIGHT WORKER
3942
-
3943
- function startWorker(cm, time) {
3944
- if (cm.doc.mode.startState && cm.doc.frontier < cm.display.viewTo)
3945
- { cm.state.highlight.set(time, bind(highlightWorker, cm)) }
3946
- }
3947
-
3948
- function highlightWorker(cm) {
3949
- var doc = cm.doc
3950
- if (doc.frontier < doc.first) { doc.frontier = doc.first }
3951
- if (doc.frontier >= cm.display.viewTo) { return }
3952
- var end = +new Date + cm.options.workTime
3953
- var state = copyState(doc.mode, getStateBefore(cm, doc.frontier))
3954
- var changedLines = []
3955
-
3956
- doc.iter(doc.frontier, Math.min(doc.first + doc.size, cm.display.viewTo + 500), function (line) {
3957
- if (doc.frontier >= cm.display.viewFrom) { // Visible
3958
- var oldStyles = line.styles, tooLong = line.text.length > cm.options.maxHighlightLength
3959
- var highlighted = highlightLine(cm, line, tooLong ? copyState(doc.mode, state) : state, true)
3960
- line.styles = highlighted.styles
3961
- var oldCls = line.styleClasses, newCls = highlighted.classes
3962
- if (newCls) { line.styleClasses = newCls }
3963
- else if (oldCls) { line.styleClasses = null }
3964
- var ischange = !oldStyles || oldStyles.length != line.styles.length ||
3965
- oldCls != newCls && (!oldCls || !newCls || oldCls.bgClass != newCls.bgClass || oldCls.textClass != newCls.textClass)
3966
- for (var i = 0; !ischange && i < oldStyles.length; ++i) { ischange = oldStyles[i] != line.styles[i] }
3967
- if (ischange) { changedLines.push(doc.frontier) }
3968
- line.stateAfter = tooLong ? state : copyState(doc.mode, state)
3969
- } else {
3970
- if (line.text.length <= cm.options.maxHighlightLength)
3971
- { processLine(cm, line.text, state) }
3972
- line.stateAfter = doc.frontier % 5 == 0 ? copyState(doc.mode, state) : null
3973
- }
3974
- ++doc.frontier
3975
- if (+new Date > end) {
3976
- startWorker(cm, cm.options.workDelay)
3977
- return true
3978
- }
3979
- })
3980
- if (changedLines.length) { runInOp(cm, function () {
3981
- for (var i = 0; i < changedLines.length; i++)
3982
- { regLineChange(cm, changedLines[i], "text") }
3983
- }) }
3984
- }
3985
-
3986
- // DISPLAY DRAWING
3987
-
3988
- var DisplayUpdate = function(cm, viewport, force) {
3989
- var display = cm.display
3990
-
3991
- this.viewport = viewport
3992
- // Store some values that we'll need later (but don't want to force a relayout for)
3993
- this.visible = visibleLines(display, cm.doc, viewport)
3994
- this.editorIsHidden = !display.wrapper.offsetWidth
3995
- this.wrapperHeight = display.wrapper.clientHeight
3996
- this.wrapperWidth = display.wrapper.clientWidth
3997
- this.oldDisplayWidth = displayWidth(cm)
3998
- this.force = force
3999
- this.dims = getDimensions(cm)
4000
- this.events = []
4001
- };
4002
-
4003
- DisplayUpdate.prototype.signal = function (emitter, type) {
4004
- if (hasHandler(emitter, type))
4005
- { this.events.push(arguments) }
4006
- };
4007
- DisplayUpdate.prototype.finish = function () {
4008
- var this$1 = this;
4009
-
4010
- for (var i = 0; i < this.events.length; i++)
4011
- { signal.apply(null, this$1.events[i]) }
4012
- };
4013
-
4014
- function maybeClipScrollbars(cm) {
4015
- var display = cm.display
4016
- if (!display.scrollbarsClipped && display.scroller.offsetWidth) {
4017
- display.nativeBarWidth = display.scroller.offsetWidth - display.scroller.clientWidth
4018
- display.heightForcer.style.height = scrollGap(cm) + "px"
4019
- display.sizer.style.marginBottom = -display.nativeBarWidth + "px"
4020
- display.sizer.style.borderRightWidth = scrollGap(cm) + "px"
4021
- display.scrollbarsClipped = true
4022
- }
4023
- }
4024
-
4025
- function selectionSnapshot(cm) {
4026
- if (cm.hasFocus()) { return null }
4027
- var active = activeElt()
4028
- if (!active || !contains(cm.display.lineDiv, active)) { return null }
4029
- var result = {activeElt: active}
4030
- if (window.getSelection) {
4031
- var sel = window.getSelection()
4032
- if (sel.anchorNode && sel.extend && contains(cm.display.lineDiv, sel.anchorNode)) {
4033
- result.anchorNode = sel.anchorNode
4034
- result.anchorOffset = sel.anchorOffset
4035
- result.focusNode = sel.focusNode
4036
- result.focusOffset = sel.focusOffset
4037
- }
4038
- }
4039
- return result
4040
- }
4041
-
4042
- function restoreSelection(snapshot) {
4043
- if (!snapshot || !snapshot.activeElt || snapshot.activeElt == activeElt()) { return }
4044
- snapshot.activeElt.focus()
4045
- if (snapshot.anchorNode && contains(document.body, snapshot.anchorNode) && contains(document.body, snapshot.focusNode)) {
4046
- var sel = window.getSelection(), range = document.createRange()
4047
- range.setEnd(snapshot.anchorNode, snapshot.anchorOffset)
4048
- range.collapse(false)
4049
- sel.removeAllRanges()
4050
- sel.addRange(range)
4051
- sel.extend(snapshot.focusNode, snapshot.focusOffset)
4052
- }
4053
- }
4054
-
4055
- // Does the actual updating of the line display. Bails out
4056
- // (returning false) when there is nothing to be done and forced is
4057
- // false.
4058
- function updateDisplayIfNeeded(cm, update) {
4059
- var display = cm.display, doc = cm.doc
4060
-
4061
- if (update.editorIsHidden) {
4062
- resetView(cm)
4063
- return false
4064
- }
4065
-
4066
- // Bail out if the visible area is already rendered and nothing changed.
4067
- if (!update.force &&
4068
- update.visible.from >= display.viewFrom && update.visible.to <= display.viewTo &&
4069
- (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo) &&
4070
- display.renderedView == display.view && countDirtyView(cm) == 0)
4071
- { return false }
4072
-
4073
- if (maybeUpdateLineNumberWidth(cm)) {
4074
- resetView(cm)
4075
- update.dims = getDimensions(cm)
4076
- }
4077
-
4078
- // Compute a suitable new viewport (from & to)
4079
- var end = doc.first + doc.size
4080
- var from = Math.max(update.visible.from - cm.options.viewportMargin, doc.first)
4081
- var to = Math.min(end, update.visible.to + cm.options.viewportMargin)
4082
- if (display.viewFrom < from && from - display.viewFrom < 20) { from = Math.max(doc.first, display.viewFrom) }
4083
- if (display.viewTo > to && display.viewTo - to < 20) { to = Math.min(end, display.viewTo) }
4084
- if (sawCollapsedSpans) {
4085
- from = visualLineNo(cm.doc, from)
4086
- to = visualLineEndNo(cm.doc, to)
4087
- }
4088
-
4089
- var different = from != display.viewFrom || to != display.viewTo ||
4090
- display.lastWrapHeight != update.wrapperHeight || display.lastWrapWidth != update.wrapperWidth
4091
- adjustView(cm, from, to)
4092
-
4093
- display.viewOffset = heightAtLine(getLine(cm.doc, display.viewFrom))
4094
- // Position the mover div to align with the current scroll position
4095
- cm.display.mover.style.top = display.viewOffset + "px"
4096
-
4097
- var toUpdate = countDirtyView(cm)
4098
- if (!different && toUpdate == 0 && !update.force && display.renderedView == display.view &&
4099
- (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo))
4100
- { return false }
4101
-
4102
- // For big changes, we hide the enclosing element during the
4103
- // update, since that speeds up the operations on most browsers.
4104
- var selSnapshot = selectionSnapshot(cm)
4105
- if (toUpdate > 4) { display.lineDiv.style.display = "none" }
4106
- patchDisplay(cm, display.updateLineNumbers, update.dims)
4107
- if (toUpdate > 4) { display.lineDiv.style.display = "" }
4108
- display.renderedView = display.view
4109
- // There might have been a widget with a focused element that got
4110
- // hidden or updated, if so re-focus it.
4111
- restoreSelection(selSnapshot)
4112
-
4113
- // Prevent selection and cursors from interfering with the scroll
4114
- // width and height.
4115
- removeChildren(display.cursorDiv)
4116
- removeChildren(display.selectionDiv)
4117
- display.gutters.style.height = display.sizer.style.minHeight = 0
4118
-
4119
- if (different) {
4120
- display.lastWrapHeight = update.wrapperHeight
4121
- display.lastWrapWidth = update.wrapperWidth
4122
- startWorker(cm, 400)
4123
- }
4124
-
4125
- display.updateLineNumbers = null
4126
-
4127
- return true
4128
- }
4129
-
4130
- function postUpdateDisplay(cm, update) {
4131
- var viewport = update.viewport
4132
-
4133
- for (var first = true;; first = false) {
4134
- if (!first || !cm.options.lineWrapping || update.oldDisplayWidth == displayWidth(cm)) {
4135
- // Clip forced viewport to actual scrollable area.
4136
- if (viewport && viewport.top != null)
4137
- { viewport = {top: Math.min(cm.doc.height + paddingVert(cm.display) - displayHeight(cm), viewport.top)} }
4138
- // Updated line heights might result in the drawn area not
4139
- // actually covering the viewport. Keep looping until it does.
4140
- update.visible = visibleLines(cm.display, cm.doc, viewport)
4141
- if (update.visible.from >= cm.display.viewFrom && update.visible.to <= cm.display.viewTo)
4142
- { break }
4143
- }
4144
- if (!updateDisplayIfNeeded(cm, update)) { break }
4145
- updateHeightsInViewport(cm)
4146
- var barMeasure = measureForScrollbars(cm)
4147
- updateSelection(cm)
4148
- updateScrollbars(cm, barMeasure)
4149
- setDocumentHeight(cm, barMeasure)
4150
- }
4151
-
4152
- update.signal(cm, "update", cm)
4153
- if (cm.display.viewFrom != cm.display.reportedViewFrom || cm.display.viewTo != cm.display.reportedViewTo) {
4154
- update.signal(cm, "viewportChange", cm, cm.display.viewFrom, cm.display.viewTo)
4155
- cm.display.reportedViewFrom = cm.display.viewFrom; cm.display.reportedViewTo = cm.display.viewTo
4156
- }
4157
- }
4158
-
4159
- function updateDisplaySimple(cm, viewport) {
4160
- var update = new DisplayUpdate(cm, viewport)
4161
- if (updateDisplayIfNeeded(cm, update)) {
4162
- updateHeightsInViewport(cm)
4163
- postUpdateDisplay(cm, update)
4164
- var barMeasure = measureForScrollbars(cm)
4165
- updateSelection(cm)
4166
- updateScrollbars(cm, barMeasure)
4167
- setDocumentHeight(cm, barMeasure)
4168
- update.finish()
4169
- }
4170
- }
4171
-
4172
- // Sync the actual display DOM structure with display.view, removing
4173
- // nodes for lines that are no longer in view, and creating the ones
4174
- // that are not there yet, and updating the ones that are out of
4175
- // date.
4176
- function patchDisplay(cm, updateNumbersFrom, dims) {
4177
- var display = cm.display, lineNumbers = cm.options.lineNumbers
4178
- var container = display.lineDiv, cur = container.firstChild
4179
-
4180
- function rm(node) {
4181
- var next = node.nextSibling
4182
- // Works around a throw-scroll bug in OS X Webkit
4183
- if (webkit && mac && cm.display.currentWheelTarget == node)
4184
- { node.style.display = "none" }
4185
- else
4186
- { node.parentNode.removeChild(node) }
4187
- return next
4188
- }
4189
-
4190
- var view = display.view, lineN = display.viewFrom
4191
- // Loop over the elements in the view, syncing cur (the DOM nodes
4192
- // in display.lineDiv) with the view as we go.
4193
- for (var i = 0; i < view.length; i++) {
4194
- var lineView = view[i]
4195
- if (lineView.hidden) {
4196
- } else if (!lineView.node || lineView.node.parentNode != container) { // Not drawn yet
4197
- var node = buildLineElement(cm, lineView, lineN, dims)
4198
- container.insertBefore(node, cur)
4199
- } else { // Already drawn
4200
- while (cur != lineView.node) { cur = rm(cur) }
4201
- var updateNumber = lineNumbers && updateNumbersFrom != null &&
4202
- updateNumbersFrom <= lineN && lineView.lineNumber
4203
- if (lineView.changes) {
4204
- if (indexOf(lineView.changes, "gutter") > -1) { updateNumber = false }
4205
- updateLineForChanges(cm, lineView, lineN, dims)
4206
- }
4207
- if (updateNumber) {
4208
- removeChildren(lineView.lineNumber)
4209
- lineView.lineNumber.appendChild(document.createTextNode(lineNumberFor(cm.options, lineN)))
4210
- }
4211
- cur = lineView.node.nextSibling
4212
- }
4213
- lineN += lineView.size
4214
- }
4215
- while (cur) { cur = rm(cur) }
4216
- }
4217
-
4218
- function updateGutterSpace(cm) {
4219
- var width = cm.display.gutters.offsetWidth
4220
- cm.display.sizer.style.marginLeft = width + "px"
4221
- }
4222
-
4223
- function setDocumentHeight(cm, measure) {
4224
- cm.display.sizer.style.minHeight = measure.docHeight + "px"
4225
- cm.display.heightForcer.style.top = measure.docHeight + "px"
4226
- cm.display.gutters.style.height = (measure.docHeight + cm.display.barHeight + scrollGap(cm)) + "px"
4227
- }
4228
-
4229
- // Rebuild the gutter elements, ensure the margin to the left of the
4230
- // code matches their width.
4231
- function updateGutters(cm) {
4232
- var gutters = cm.display.gutters, specs = cm.options.gutters
4233
- removeChildren(gutters)
4234
- var i = 0
4235
- for (; i < specs.length; ++i) {
4236
- var gutterClass = specs[i]
4237
- var gElt = gutters.appendChild(elt("div", null, "CodeMirror-gutter " + gutterClass))
4238
- if (gutterClass == "CodeMirror-linenumbers") {
4239
- cm.display.lineGutter = gElt
4240
- gElt.style.width = (cm.display.lineNumWidth || 1) + "px"
4241
- }
4242
- }
4243
- gutters.style.display = i ? "" : "none"
4244
- updateGutterSpace(cm)
4245
- }
4246
-
4247
- // Make sure the gutters options contains the element
4248
- // "CodeMirror-linenumbers" when the lineNumbers option is true.
4249
- function setGuttersForLineNumbers(options) {
4250
- var found = indexOf(options.gutters, "CodeMirror-linenumbers")
4251
- if (found == -1 && options.lineNumbers) {
4252
- options.gutters = options.gutters.concat(["CodeMirror-linenumbers"])
4253
- } else if (found > -1 && !options.lineNumbers) {
4254
- options.gutters = options.gutters.slice(0)
4255
- options.gutters.splice(found, 1)
4256
- }
4257
- }
4258
-
4259
- var wheelSamples = 0;
4260
- var wheelPixelsPerUnit = null;
4261
- // Fill in a browser-detected starting value on browsers where we
4262
- // know one. These don't have to be accurate -- the result of them
4263
- // being wrong would just be a slight flicker on the first wheel
4264
- // scroll (if it is large enough).
4265
- if (ie) { wheelPixelsPerUnit = -.53 }
4266
- else if (gecko) { wheelPixelsPerUnit = 15 }
4267
- else if (chrome) { wheelPixelsPerUnit = -.7 }
4268
- else if (safari) { wheelPixelsPerUnit = -1/3 }
4269
-
4270
- function wheelEventDelta(e) {
4271
- var dx = e.wheelDeltaX, dy = e.wheelDeltaY
4272
- if (dx == null && e.detail && e.axis == e.HORIZONTAL_AXIS) { dx = e.detail }
4273
- if (dy == null && e.detail && e.axis == e.VERTICAL_AXIS) { dy = e.detail }
4274
- else if (dy == null) { dy = e.wheelDelta }
4275
- return {x: dx, y: dy}
4276
- }
4277
- function wheelEventPixels(e) {
4278
- var delta = wheelEventDelta(e)
4279
- delta.x *= wheelPixelsPerUnit
4280
- delta.y *= wheelPixelsPerUnit
4281
- return delta
4282
- }
4283
-
4284
- function onScrollWheel(cm, e) {
4285
- var delta = wheelEventDelta(e), dx = delta.x, dy = delta.y
4286
-
4287
- var display = cm.display, scroll = display.scroller
4288
- // Quit if there's nothing to scroll here
4289
- var canScrollX = scroll.scrollWidth > scroll.clientWidth
4290
- var canScrollY = scroll.scrollHeight > scroll.clientHeight
4291
- if (!(dx && canScrollX || dy && canScrollY)) { return }
4292
-
4293
- // Webkit browsers on OS X abort momentum scrolls when the target
4294
- // of the scroll event is removed from the scrollable element.
4295
- // This hack (see related code in patchDisplay) makes sure the
4296
- // element is kept around.
4297
- if (dy && mac && webkit) {
4298
- outer: for (var cur = e.target, view = display.view; cur != scroll; cur = cur.parentNode) {
4299
- for (var i = 0; i < view.length; i++) {
4300
- if (view[i].node == cur) {
4301
- cm.display.currentWheelTarget = cur
4302
- break outer
4303
- }
4304
- }
4305
- }
4306
- }
4307
-
4308
- // On some browsers, horizontal scrolling will cause redraws to
4309
- // happen before the gutter has been realigned, causing it to
4310
- // wriggle around in a most unseemly way. When we have an
4311
- // estimated pixels/delta value, we just handle horizontal
4312
- // scrolling entirely here. It'll be slightly off from native, but
4313
- // better than glitching out.
4314
- if (dx && !gecko && !presto && wheelPixelsPerUnit != null) {
4315
- if (dy && canScrollY)
4316
- { updateScrollTop(cm, Math.max(0, scroll.scrollTop + dy * wheelPixelsPerUnit)) }
4317
- setScrollLeft(cm, Math.max(0, scroll.scrollLeft + dx * wheelPixelsPerUnit))
4318
- // Only prevent default scrolling if vertical scrolling is
4319
- // actually possible. Otherwise, it causes vertical scroll
4320
- // jitter on OSX trackpads when deltaX is small and deltaY
4321
- // is large (issue #3579)
4322
- if (!dy || (dy && canScrollY))
4323
- { e_preventDefault(e) }
4324
- display.wheelStartX = null // Abort measurement, if in progress
4325
- return
4326
- }
4327
-
4328
- // 'Project' the visible viewport to cover the area that is being
4329
- // scrolled into view (if we know enough to estimate it).
4330
- if (dy && wheelPixelsPerUnit != null) {
4331
- var pixels = dy * wheelPixelsPerUnit
4332
- var top = cm.doc.scrollTop, bot = top + display.wrapper.clientHeight
4333
- if (pixels < 0) { top = Math.max(0, top + pixels - 50) }
4334
- else { bot = Math.min(cm.doc.height, bot + pixels + 50) }
4335
- updateDisplaySimple(cm, {top: top, bottom: bot})
4336
- }
4337
-
4338
- if (wheelSamples < 20) {
4339
- if (display.wheelStartX == null) {
4340
- display.wheelStartX = scroll.scrollLeft; display.wheelStartY = scroll.scrollTop
4341
- display.wheelDX = dx; display.wheelDY = dy
4342
- setTimeout(function () {
4343
- if (display.wheelStartX == null) { return }
4344
- var movedX = scroll.scrollLeft - display.wheelStartX
4345
- var movedY = scroll.scrollTop - display.wheelStartY
4346
- var sample = (movedY && display.wheelDY && movedY / display.wheelDY) ||
4347
- (movedX && display.wheelDX && movedX / display.wheelDX)
4348
- display.wheelStartX = display.wheelStartY = null
4349
- if (!sample) { return }
4350
- wheelPixelsPerUnit = (wheelPixelsPerUnit * wheelSamples + sample) / (wheelSamples + 1)
4351
- ++wheelSamples
4352
- }, 200)
4353
- } else {
4354
- display.wheelDX += dx; display.wheelDY += dy
4355
- }
4356
- }
4357
- }
4358
-
4359
- // Selection objects are immutable. A new one is created every time
4360
- // the selection changes. A selection is one or more non-overlapping
4361
- // (and non-touching) ranges, sorted, and an integer that indicates
4362
- // which one is the primary selection (the one that's scrolled into
4363
- // view, that getCursor returns, etc).
4364
- var Selection = function(ranges, primIndex) {
4365
- this.ranges = ranges
4366
- this.primIndex = primIndex
4367
- };
4368
-
4369
- Selection.prototype.primary = function () { return this.ranges[this.primIndex] };
4370
-
4371
- Selection.prototype.equals = function (other) {
4372
- var this$1 = this;
4373
-
4374
- if (other == this) { return true }
4375
- if (other.primIndex != this.primIndex || other.ranges.length != this.ranges.length) { return false }
4376
- for (var i = 0; i < this.ranges.length; i++) {
4377
- var here = this$1.ranges[i], there = other.ranges[i]
4378
- if (!equalCursorPos(here.anchor, there.anchor) || !equalCursorPos(here.head, there.head)) { return false }
4379
- }
4380
- return true
4381
- };
4382
-
4383
- Selection.prototype.deepCopy = function () {
4384
- var this$1 = this;
4385
-
4386
- var out = []
4387
- for (var i = 0; i < this.ranges.length; i++)
4388
- { out[i] = new Range(copyPos(this$1.ranges[i].anchor), copyPos(this$1.ranges[i].head)) }
4389
- return new Selection(out, this.primIndex)
4390
- };
4391
-
4392
- Selection.prototype.somethingSelected = function () {
4393
- var this$1 = this;
4394
-
4395
- for (var i = 0; i < this.ranges.length; i++)
4396
- { if (!this$1.ranges[i].empty()) { return true } }
4397
- return false
4398
- };
4399
-
4400
- Selection.prototype.contains = function (pos, end) {
4401
- var this$1 = this;
4402
-
4403
- if (!end) { end = pos }
4404
- for (var i = 0; i < this.ranges.length; i++) {
4405
- var range = this$1.ranges[i]
4406
- if (cmp(end, range.from()) >= 0 && cmp(pos, range.to()) <= 0)
4407
- { return i }
4408
- }
4409
- return -1
4410
- };
4411
-
4412
- var Range = function(anchor, head) {
4413
- this.anchor = anchor; this.head = head
4414
- };
4415
-
4416
- Range.prototype.from = function () { return minPos(this.anchor, this.head) };
4417
- Range.prototype.to = function () { return maxPos(this.anchor, this.head) };
4418
- Range.prototype.empty = function () { return this.head.line == this.anchor.line && this.head.ch == this.anchor.ch };
4419
-
4420
- // Take an unsorted, potentially overlapping set of ranges, and
4421
- // build a selection out of it. 'Consumes' ranges array (modifying
4422
- // it).
4423
- function normalizeSelection(ranges, primIndex) {
4424
- var prim = ranges[primIndex]
4425
- ranges.sort(function (a, b) { return cmp(a.from(), b.from()); })
4426
- primIndex = indexOf(ranges, prim)
4427
- for (var i = 1; i < ranges.length; i++) {
4428
- var cur = ranges[i], prev = ranges[i - 1]
4429
- if (cmp(prev.to(), cur.from()) >= 0) {
4430
- var from = minPos(prev.from(), cur.from()), to = maxPos(prev.to(), cur.to())
4431
- var inv = prev.empty() ? cur.from() == cur.head : prev.from() == prev.head
4432
- if (i <= primIndex) { --primIndex }
4433
- ranges.splice(--i, 2, new Range(inv ? to : from, inv ? from : to))
4434
- }
4435
- }
4436
- return new Selection(ranges, primIndex)
4437
- }
4438
-
4439
- function simpleSelection(anchor, head) {
4440
- return new Selection([new Range(anchor, head || anchor)], 0)
4441
- }
4442
-
4443
- // Compute the position of the end of a change (its 'to' property
4444
- // refers to the pre-change end).
4445
- function changeEnd(change) {
4446
- if (!change.text) { return change.to }
4447
- return Pos(change.from.line + change.text.length - 1,
4448
- lst(change.text).length + (change.text.length == 1 ? change.from.ch : 0))
4449
- }
4450
-
4451
- // Adjust a position to refer to the post-change position of the
4452
- // same text, or the end of the change if the change covers it.
4453
- function adjustForChange(pos, change) {
4454
- if (cmp(pos, change.from) < 0) { return pos }
4455
- if (cmp(pos, change.to) <= 0) { return changeEnd(change) }
4456
-
4457
- var line = pos.line + change.text.length - (change.to.line - change.from.line) - 1, ch = pos.ch
4458
- if (pos.line == change.to.line) { ch += changeEnd(change).ch - change.to.ch }
4459
- return Pos(line, ch)
4460
- }
4461
-
4462
- function computeSelAfterChange(doc, change) {
4463
- var out = []
4464
- for (var i = 0; i < doc.sel.ranges.length; i++) {
4465
- var range = doc.sel.ranges[i]
4466
- out.push(new Range(adjustForChange(range.anchor, change),
4467
- adjustForChange(range.head, change)))
4468
- }
4469
- return normalizeSelection(out, doc.sel.primIndex)
4470
- }
4471
-
4472
- function offsetPos(pos, old, nw) {
4473
- if (pos.line == old.line)
4474
- { return Pos(nw.line, pos.ch - old.ch + nw.ch) }
4475
- else
4476
- { return Pos(nw.line + (pos.line - old.line), pos.ch) }
4477
- }
4478
-
4479
- // Used by replaceSelections to allow moving the selection to the
4480
- // start or around the replaced test. Hint may be "start" or "around".
4481
- function computeReplacedSel(doc, changes, hint) {
4482
- var out = []
4483
- var oldPrev = Pos(doc.first, 0), newPrev = oldPrev
4484
- for (var i = 0; i < changes.length; i++) {
4485
- var change = changes[i]
4486
- var from = offsetPos(change.from, oldPrev, newPrev)
4487
- var to = offsetPos(changeEnd(change), oldPrev, newPrev)
4488
- oldPrev = change.to
4489
- newPrev = to
4490
- if (hint == "around") {
4491
- var range = doc.sel.ranges[i], inv = cmp(range.head, range.anchor) < 0
4492
- out[i] = new Range(inv ? to : from, inv ? from : to)
4493
- } else {
4494
- out[i] = new Range(from, from)
4495
- }
4496
- }
4497
- return new Selection(out, doc.sel.primIndex)
4498
- }
4499
-
4500
- // Used to get the editor into a consistent state again when options change.
4501
-
4502
- function loadMode(cm) {
4503
- cm.doc.mode = getMode(cm.options, cm.doc.modeOption)
4504
- resetModeState(cm)
4505
- }
4506
-
4507
- function resetModeState(cm) {
4508
- cm.doc.iter(function (line) {
4509
- if (line.stateAfter) { line.stateAfter = null }
4510
- if (line.styles) { line.styles = null }
4511
- })
4512
- cm.doc.frontier = cm.doc.first
4513
- startWorker(cm, 100)
4514
- cm.state.modeGen++
4515
- if (cm.curOp) { regChange(cm) }
4516
- }
4517
-
4518
- // DOCUMENT DATA STRUCTURE
4519
-
4520
- // By default, updates that start and end at the beginning of a line
4521
- // are treated specially, in order to make the association of line
4522
- // widgets and marker elements with the text behave more intuitive.
4523
- function isWholeLineUpdate(doc, change) {
4524
- return change.from.ch == 0 && change.to.ch == 0 && lst(change.text) == "" &&
4525
- (!doc.cm || doc.cm.options.wholeLineUpdateBefore)
4526
- }
4527
-
4528
- // Perform a change on the document data structure.
4529
- function updateDoc(doc, change, markedSpans, estimateHeight) {
4530
- function spansFor(n) {return markedSpans ? markedSpans[n] : null}
4531
- function update(line, text, spans) {
4532
- updateLine(line, text, spans, estimateHeight)
4533
- signalLater(line, "change", line, change)
4534
- }
4535
- function linesFor(start, end) {
4536
- var result = []
4537
- for (var i = start; i < end; ++i)
4538
- { result.push(new Line(text[i], spansFor(i), estimateHeight)) }
4539
- return result
4540
- }
4541
-
4542
- var from = change.from, to = change.to, text = change.text
4543
- var firstLine = getLine(doc, from.line), lastLine = getLine(doc, to.line)
4544
- var lastText = lst(text), lastSpans = spansFor(text.length - 1), nlines = to.line - from.line
4545
-
4546
- // Adjust the line structure
4547
- if (change.full) {
4548
- doc.insert(0, linesFor(0, text.length))
4549
- doc.remove(text.length, doc.size - text.length)
4550
- } else if (isWholeLineUpdate(doc, change)) {
4551
- // This is a whole-line replace. Treated specially to make
4552
- // sure line objects move the way they are supposed to.
4553
- var added = linesFor(0, text.length - 1)
4554
- update(lastLine, lastLine.text, lastSpans)
4555
- if (nlines) { doc.remove(from.line, nlines) }
4556
- if (added.length) { doc.insert(from.line, added) }
4557
- } else if (firstLine == lastLine) {
4558
- if (text.length == 1) {
4559
- update(firstLine, firstLine.text.slice(0, from.ch) + lastText + firstLine.text.slice(to.ch), lastSpans)
4560
- } else {
4561
- var added$1 = linesFor(1, text.length - 1)
4562
- added$1.push(new Line(lastText + firstLine.text.slice(to.ch), lastSpans, estimateHeight))
4563
- update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0))
4564
- doc.insert(from.line + 1, added$1)
4565
- }
4566
- } else if (text.length == 1) {
4567
- update(firstLine, firstLine.text.slice(0, from.ch) + text[0] + lastLine.text.slice(to.ch), spansFor(0))
4568
- doc.remove(from.line + 1, nlines)
4569
- } else {
4570
- update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0))
4571
- update(lastLine, lastText + lastLine.text.slice(to.ch), lastSpans)
4572
- var added$2 = linesFor(1, text.length - 1)
4573
- if (nlines > 1) { doc.remove(from.line + 1, nlines - 1) }
4574
- doc.insert(from.line + 1, added$2)
4575
- }
4576
-
4577
- signalLater(doc, "change", doc, change)
4578
- }
4579
-
4580
- // Call f for all linked documents.
4581
- function linkedDocs(doc, f, sharedHistOnly) {
4582
- function propagate(doc, skip, sharedHist) {
4583
- if (doc.linked) { for (var i = 0; i < doc.linked.length; ++i) {
4584
- var rel = doc.linked[i]
4585
- if (rel.doc == skip) { continue }
4586
- var shared = sharedHist && rel.sharedHist
4587
- if (sharedHistOnly && !shared) { continue }
4588
- f(rel.doc, shared)
4589
- propagate(rel.doc, doc, shared)
4590
- } }
4591
- }
4592
- propagate(doc, null, true)
4593
- }
4594
-
4595
- // Attach a document to an editor.
4596
- function attachDoc(cm, doc) {
4597
- if (doc.cm) { throw new Error("This document is already in use.") }
4598
- cm.doc = doc
4599
- doc.cm = cm
4600
- estimateLineHeights(cm)
4601
- loadMode(cm)
4602
- setDirectionClass(cm)
4603
- if (!cm.options.lineWrapping) { findMaxLine(cm) }
4604
- cm.options.mode = doc.modeOption
4605
- regChange(cm)
4606
- }
4607
-
4608
- function setDirectionClass(cm) {
4609
- ;(cm.doc.direction == "rtl" ? addClass : rmClass)(cm.display.lineDiv, "CodeMirror-rtl")
4610
- }
4611
-
4612
- function directionChanged(cm) {
4613
- runInOp(cm, function () {
4614
- setDirectionClass(cm)
4615
- regChange(cm)
4616
- })
4617
- }
4618
-
4619
- function History(startGen) {
4620
- // Arrays of change events and selections. Doing something adds an
4621
- // event to done and clears undo. Undoing moves events from done
4622
- // to undone, redoing moves them in the other direction.
4623
- this.done = []; this.undone = []
4624
- this.undoDepth = Infinity
4625
- // Used to track when changes can be merged into a single undo
4626
- // event
4627
- this.lastModTime = this.lastSelTime = 0
4628
- this.lastOp = this.lastSelOp = null
4629
- this.lastOrigin = this.lastSelOrigin = null
4630
- // Used by the isClean() method
4631
- this.generation = this.maxGeneration = startGen || 1
4632
- }
4633
-
4634
- // Create a history change event from an updateDoc-style change
4635
- // object.
4636
- function historyChangeFromChange(doc, change) {
4637
- var histChange = {from: copyPos(change.from), to: changeEnd(change), text: getBetween(doc, change.from, change.to)}
4638
- attachLocalSpans(doc, histChange, change.from.line, change.to.line + 1)
4639
- linkedDocs(doc, function (doc) { return attachLocalSpans(doc, histChange, change.from.line, change.to.line + 1); }, true)
4640
- return histChange
4641
- }
4642
-
4643
- // Pop all selection events off the end of a history array. Stop at
4644
- // a change event.
4645
- function clearSelectionEvents(array) {
4646
- while (array.length) {
4647
- var last = lst(array)
4648
- if (last.ranges) { array.pop() }
4649
- else { break }
4650
- }
4651
- }
4652
-
4653
- // Find the top change event in the history. Pop off selection
4654
- // events that are in the way.
4655
- function lastChangeEvent(hist, force) {
4656
- if (force) {
4657
- clearSelectionEvents(hist.done)
4658
- return lst(hist.done)
4659
- } else if (hist.done.length && !lst(hist.done).ranges) {
4660
- return lst(hist.done)
4661
- } else if (hist.done.length > 1 && !hist.done[hist.done.length - 2].ranges) {
4662
- hist.done.pop()
4663
- return lst(hist.done)
4664
- }
4665
- }
4666
-
4667
- // Register a change in the history. Merges changes that are within
4668
- // a single operation, or are close together with an origin that
4669
- // allows merging (starting with "+") into a single event.
4670
- function addChangeToHistory(doc, change, selAfter, opId) {
4671
- var hist = doc.history
4672
- hist.undone.length = 0
4673
- var time = +new Date, cur
4674
- var last
4675
-
4676
- if ((hist.lastOp == opId ||
4677
- hist.lastOrigin == change.origin && change.origin &&
4678
- ((change.origin.charAt(0) == "+" && doc.cm && hist.lastModTime > time - doc.cm.options.historyEventDelay) ||
4679
- change.origin.charAt(0) == "*")) &&
4680
- (cur = lastChangeEvent(hist, hist.lastOp == opId))) {
4681
- // Merge this change into the last event
4682
- last = lst(cur.changes)
4683
- if (cmp(change.from, change.to) == 0 && cmp(change.from, last.to) == 0) {
4684
- // Optimized case for simple insertion -- don't want to add
4685
- // new changesets for every character typed
4686
- last.to = changeEnd(change)
4687
- } else {
4688
- // Add new sub-event
4689
- cur.changes.push(historyChangeFromChange(doc, change))
4690
- }
4691
- } else {
4692
- // Can not be merged, start a new event.
4693
- var before = lst(hist.done)
4694
- if (!before || !before.ranges)
4695
- { pushSelectionToHistory(doc.sel, hist.done) }
4696
- cur = {changes: [historyChangeFromChange(doc, change)],
4697
- generation: hist.generation}
4698
- hist.done.push(cur)
4699
- while (hist.done.length > hist.undoDepth) {
4700
- hist.done.shift()
4701
- if (!hist.done[0].ranges) { hist.done.shift() }
4702
- }
4703
- }
4704
- hist.done.push(selAfter)
4705
- hist.generation = ++hist.maxGeneration
4706
- hist.lastModTime = hist.lastSelTime = time
4707
- hist.lastOp = hist.lastSelOp = opId
4708
- hist.lastOrigin = hist.lastSelOrigin = change.origin
4709
-
4710
- if (!last) { signal(doc, "historyAdded") }
4711
- }
4712
-
4713
- function selectionEventCanBeMerged(doc, origin, prev, sel) {
4714
- var ch = origin.charAt(0)
4715
- return ch == "*" ||
4716
- ch == "+" &&
4717
- prev.ranges.length == sel.ranges.length &&
4718
- prev.somethingSelected() == sel.somethingSelected() &&
4719
- new Date - doc.history.lastSelTime <= (doc.cm ? doc.cm.options.historyEventDelay : 500)
4720
- }
4721
-
4722
- // Called whenever the selection changes, sets the new selection as
4723
- // the pending selection in the history, and pushes the old pending
4724
- // selection into the 'done' array when it was significantly
4725
- // different (in number of selected ranges, emptiness, or time).
4726
- function addSelectionToHistory(doc, sel, opId, options) {
4727
- var hist = doc.history, origin = options && options.origin
4728
-
4729
- // A new event is started when the previous origin does not match
4730
- // the current, or the origins don't allow matching. Origins
4731
- // starting with * are always merged, those starting with + are
4732
- // merged when similar and close together in time.
4733
- if (opId == hist.lastSelOp ||
4734
- (origin && hist.lastSelOrigin == origin &&
4735
- (hist.lastModTime == hist.lastSelTime && hist.lastOrigin == origin ||
4736
- selectionEventCanBeMerged(doc, origin, lst(hist.done), sel))))
4737
- { hist.done[hist.done.length - 1] = sel }
4738
- else
4739
- { pushSelectionToHistory(sel, hist.done) }
4740
-
4741
- hist.lastSelTime = +new Date
4742
- hist.lastSelOrigin = origin
4743
- hist.lastSelOp = opId
4744
- if (options && options.clearRedo !== false)
4745
- { clearSelectionEvents(hist.undone) }
4746
- }
4747
-
4748
- function pushSelectionToHistory(sel, dest) {
4749
- var top = lst(dest)
4750
- if (!(top && top.ranges && top.equals(sel)))
4751
- { dest.push(sel) }
4752
- }
4753
-
4754
- // Used to store marked span information in the history.
4755
- function attachLocalSpans(doc, change, from, to) {
4756
- var existing = change["spans_" + doc.id], n = 0
4757
- doc.iter(Math.max(doc.first, from), Math.min(doc.first + doc.size, to), function (line) {
4758
- if (line.markedSpans)
4759
- { (existing || (existing = change["spans_" + doc.id] = {}))[n] = line.markedSpans }
4760
- ++n
4761
- })
4762
- }
4763
-
4764
- // When un/re-doing restores text containing marked spans, those
4765
- // that have been explicitly cleared should not be restored.
4766
- function removeClearedSpans(spans) {
4767
- if (!spans) { return null }
4768
- var out
4769
- for (var i = 0; i < spans.length; ++i) {
4770
- if (spans[i].marker.explicitlyCleared) { if (!out) { out = spans.slice(0, i) } }
4771
- else if (out) { out.push(spans[i]) }
4772
- }
4773
- return !out ? spans : out.length ? out : null
4774
- }
4775
-
4776
- // Retrieve and filter the old marked spans stored in a change event.
4777
- function getOldSpans(doc, change) {
4778
- var found = change["spans_" + doc.id]
4779
- if (!found) { return null }
4780
- var nw = []
4781
- for (var i = 0; i < change.text.length; ++i)
4782
- { nw.push(removeClearedSpans(found[i])) }
4783
- return nw
4784
- }
4785
-
4786
- // Used for un/re-doing changes from the history. Combines the
4787
- // result of computing the existing spans with the set of spans that
4788
- // existed in the history (so that deleting around a span and then
4789
- // undoing brings back the span).
4790
- function mergeOldSpans(doc, change) {
4791
- var old = getOldSpans(doc, change)
4792
- var stretched = stretchSpansOverChange(doc, change)
4793
- if (!old) { return stretched }
4794
- if (!stretched) { return old }
4795
-
4796
- for (var i = 0; i < old.length; ++i) {
4797
- var oldCur = old[i], stretchCur = stretched[i]
4798
- if (oldCur && stretchCur) {
4799
- spans: for (var j = 0; j < stretchCur.length; ++j) {
4800
- var span = stretchCur[j]
4801
- for (var k = 0; k < oldCur.length; ++k)
4802
- { if (oldCur[k].marker == span.marker) { continue spans } }
4803
- oldCur.push(span)
4804
- }
4805
- } else if (stretchCur) {
4806
- old[i] = stretchCur
4807
- }
4808
- }
4809
- return old
4810
- }
4811
-
4812
- // Used both to provide a JSON-safe object in .getHistory, and, when
4813
- // detaching a document, to split the history in two
4814
- function copyHistoryArray(events, newGroup, instantiateSel) {
4815
- var copy = []
4816
- for (var i = 0; i < events.length; ++i) {
4817
- var event = events[i]
4818
- if (event.ranges) {
4819
- copy.push(instantiateSel ? Selection.prototype.deepCopy.call(event) : event)
4820
- continue
4821
- }
4822
- var changes = event.changes, newChanges = []
4823
- copy.push({changes: newChanges})
4824
- for (var j = 0; j < changes.length; ++j) {
4825
- var change = changes[j], m = (void 0)
4826
- newChanges.push({from: change.from, to: change.to, text: change.text})
4827
- if (newGroup) { for (var prop in change) { if (m = prop.match(/^spans_(\d+)$/)) {
4828
- if (indexOf(newGroup, Number(m[1])) > -1) {
4829
- lst(newChanges)[prop] = change[prop]
4830
- delete change[prop]
4831
- }
4832
- } } }
4833
- }
4834
- }
4835
- return copy
4836
- }
4837
-
4838
- // The 'scroll' parameter given to many of these indicated whether
4839
- // the new cursor position should be scrolled into view after
4840
- // modifying the selection.
4841
-
4842
- // If shift is held or the extend flag is set, extends a range to
4843
- // include a given position (and optionally a second position).
4844
- // Otherwise, simply returns the range between the given positions.
4845
- // Used for cursor motion and such.
4846
- function extendRange(doc, range, head, other) {
4847
- if (doc.cm && doc.cm.display.shift || doc.extend) {
4848
- var anchor = range.anchor
4849
- if (other) {
4850
- var posBefore = cmp(head, anchor) < 0
4851
- if (posBefore != (cmp(other, anchor) < 0)) {
4852
- anchor = head
4853
- head = other
4854
- } else if (posBefore != (cmp(head, other) < 0)) {
4855
- head = other
4856
- }
4857
- }
4858
- return new Range(anchor, head)
4859
- } else {
4860
- return new Range(other || head, head)
4861
- }
4862
- }
4863
-
4864
- // Extend the primary selection range, discard the rest.
4865
- function extendSelection(doc, head, other, options) {
4866
- setSelection(doc, new Selection([extendRange(doc, doc.sel.primary(), head, other)], 0), options)
4867
- }
4868
-
4869
- // Extend all selections (pos is an array of selections with length
4870
- // equal the number of selections)
4871
- function extendSelections(doc, heads, options) {
4872
- var out = []
4873
- for (var i = 0; i < doc.sel.ranges.length; i++)
4874
- { out[i] = extendRange(doc, doc.sel.ranges[i], heads[i], null) }
4875
- var newSel = normalizeSelection(out, doc.sel.primIndex)
4876
- setSelection(doc, newSel, options)
4877
- }
4878
-
4879
- // Updates a single range in the selection.
4880
- function replaceOneSelection(doc, i, range, options) {
4881
- var ranges = doc.sel.ranges.slice(0)
4882
- ranges[i] = range
4883
- setSelection(doc, normalizeSelection(ranges, doc.sel.primIndex), options)
4884
- }
4885
-
4886
- // Reset the selection to a single range.
4887
- function setSimpleSelection(doc, anchor, head, options) {
4888
- setSelection(doc, simpleSelection(anchor, head), options)
4889
- }
4890
-
4891
- // Give beforeSelectionChange handlers a change to influence a
4892
- // selection update.
4893
- function filterSelectionChange(doc, sel, options) {
4894
- var obj = {
4895
- ranges: sel.ranges,
4896
- update: function(ranges) {
4897
- var this$1 = this;
4898
-
4899
- this.ranges = []
4900
- for (var i = 0; i < ranges.length; i++)
4901
- { this$1.ranges[i] = new Range(clipPos(doc, ranges[i].anchor),
4902
- clipPos(doc, ranges[i].head)) }
4903
- },
4904
- origin: options && options.origin
4905
- }
4906
- signal(doc, "beforeSelectionChange", doc, obj)
4907
- if (doc.cm) { signal(doc.cm, "beforeSelectionChange", doc.cm, obj) }
4908
- if (obj.ranges != sel.ranges) { return normalizeSelection(obj.ranges, obj.ranges.length - 1) }
4909
- else { return sel }
4910
- }
4911
-
4912
- function setSelectionReplaceHistory(doc, sel, options) {
4913
- var done = doc.history.done, last = lst(done)
4914
- if (last && last.ranges) {
4915
- done[done.length - 1] = sel
4916
- setSelectionNoUndo(doc, sel, options)
4917
- } else {
4918
- setSelection(doc, sel, options)
4919
- }
4920
- }
4921
-
4922
- // Set a new selection.
4923
- function setSelection(doc, sel, options) {
4924
- setSelectionNoUndo(doc, sel, options)
4925
- addSelectionToHistory(doc, doc.sel, doc.cm ? doc.cm.curOp.id : NaN, options)
4926
- }
4927
-
4928
- function setSelectionNoUndo(doc, sel, options) {
4929
- if (hasHandler(doc, "beforeSelectionChange") || doc.cm && hasHandler(doc.cm, "beforeSelectionChange"))
4930
- { sel = filterSelectionChange(doc, sel, options) }
4931
-
4932
- var bias = options && options.bias ||
4933
- (cmp(sel.primary().head, doc.sel.primary().head) < 0 ? -1 : 1)
4934
- setSelectionInner(doc, skipAtomicInSelection(doc, sel, bias, true))
4935
-
4936
- if (!(options && options.scroll === false) && doc.cm)
4937
- { ensureCursorVisible(doc.cm) }
4938
- }
4939
-
4940
- function setSelectionInner(doc, sel) {
4941
- if (sel.equals(doc.sel)) { return }
4942
-
4943
- doc.sel = sel
4944
-
4945
- if (doc.cm) {
4946
- doc.cm.curOp.updateInput = doc.cm.curOp.selectionChanged = true
4947
- signalCursorActivity(doc.cm)
4948
- }
4949
- signalLater(doc, "cursorActivity", doc)
4950
- }
4951
-
4952
- // Verify that the selection does not partially select any atomic
4953
- // marked ranges.
4954
- function reCheckSelection(doc) {
4955
- setSelectionInner(doc, skipAtomicInSelection(doc, doc.sel, null, false))
4956
- }
4957
-
4958
- // Return a selection that does not partially select any atomic
4959
- // ranges.
4960
- function skipAtomicInSelection(doc, sel, bias, mayClear) {
4961
- var out
4962
- for (var i = 0; i < sel.ranges.length; i++) {
4963
- var range = sel.ranges[i]
4964
- var old = sel.ranges.length == doc.sel.ranges.length && doc.sel.ranges[i]
4965
- var newAnchor = skipAtomic(doc, range.anchor, old && old.anchor, bias, mayClear)
4966
- var newHead = skipAtomic(doc, range.head, old && old.head, bias, mayClear)
4967
- if (out || newAnchor != range.anchor || newHead != range.head) {
4968
- if (!out) { out = sel.ranges.slice(0, i) }
4969
- out[i] = new Range(newAnchor, newHead)
4970
- }
4971
- }
4972
- return out ? normalizeSelection(out, sel.primIndex) : sel
4973
- }
4974
-
4975
- function skipAtomicInner(doc, pos, oldPos, dir, mayClear) {
4976
- var line = getLine(doc, pos.line)
4977
- if (line.markedSpans) { for (var i = 0; i < line.markedSpans.length; ++i) {
4978
- var sp = line.markedSpans[i], m = sp.marker
4979
- if ((sp.from == null || (m.inclusiveLeft ? sp.from <= pos.ch : sp.from < pos.ch)) &&
4980
- (sp.to == null || (m.inclusiveRight ? sp.to >= pos.ch : sp.to > pos.ch))) {
4981
- if (mayClear) {
4982
- signal(m, "beforeCursorEnter")
4983
- if (m.explicitlyCleared) {
4984
- if (!line.markedSpans) { break }
4985
- else {--i; continue}
4986
- }
4987
- }
4988
- if (!m.atomic) { continue }
4989
-
4990
- if (oldPos) {
4991
- var near = m.find(dir < 0 ? 1 : -1), diff = (void 0)
4992
- if (dir < 0 ? m.inclusiveRight : m.inclusiveLeft)
4993
- { near = movePos(doc, near, -dir, near && near.line == pos.line ? line : null) }
4994
- if (near && near.line == pos.line && (diff = cmp(near, oldPos)) && (dir < 0 ? diff < 0 : diff > 0))
4995
- { return skipAtomicInner(doc, near, pos, dir, mayClear) }
4996
- }
4997
-
4998
- var far = m.find(dir < 0 ? -1 : 1)
4999
- if (dir < 0 ? m.inclusiveLeft : m.inclusiveRight)
5000
- { far = movePos(doc, far, dir, far.line == pos.line ? line : null) }
5001
- return far ? skipAtomicInner(doc, far, pos, dir, mayClear) : null
5002
- }
5003
- } }
5004
- return pos
5005
- }
5006
-
5007
- // Ensure a given position is not inside an atomic range.
5008
- function skipAtomic(doc, pos, oldPos, bias, mayClear) {
5009
- var dir = bias || 1
5010
- var found = skipAtomicInner(doc, pos, oldPos, dir, mayClear) ||
5011
- (!mayClear && skipAtomicInner(doc, pos, oldPos, dir, true)) ||
5012
- skipAtomicInner(doc, pos, oldPos, -dir, mayClear) ||
5013
- (!mayClear && skipAtomicInner(doc, pos, oldPos, -dir, true))
5014
- if (!found) {
5015
- doc.cantEdit = true
5016
- return Pos(doc.first, 0)
5017
- }
5018
- return found
5019
- }
5020
-
5021
- function movePos(doc, pos, dir, line) {
5022
- if (dir < 0 && pos.ch == 0) {
5023
- if (pos.line > doc.first) { return clipPos(doc, Pos(pos.line - 1)) }
5024
- else { return null }
5025
- } else if (dir > 0 && pos.ch == (line || getLine(doc, pos.line)).text.length) {
5026
- if (pos.line < doc.first + doc.size - 1) { return Pos(pos.line + 1, 0) }
5027
- else { return null }
5028
- } else {
5029
- return new Pos(pos.line, pos.ch + dir)
5030
- }
5031
- }
5032
-
5033
- function selectAll(cm) {
5034
- cm.setSelection(Pos(cm.firstLine(), 0), Pos(cm.lastLine()), sel_dontScroll)
5035
- }
5036
-
5037
- // UPDATING
5038
-
5039
- // Allow "beforeChange" event handlers to influence a change
5040
- function filterChange(doc, change, update) {
5041
- var obj = {
5042
- canceled: false,
5043
- from: change.from,
5044
- to: change.to,
5045
- text: change.text,
5046
- origin: change.origin,
5047
- cancel: function () { return obj.canceled = true; }
5048
- }
5049
- if (update) { obj.update = function (from, to, text, origin) {
5050
- if (from) { obj.from = clipPos(doc, from) }
5051
- if (to) { obj.to = clipPos(doc, to) }
5052
- if (text) { obj.text = text }
5053
- if (origin !== undefined) { obj.origin = origin }
5054
- } }
5055
- signal(doc, "beforeChange", doc, obj)
5056
- if (doc.cm) { signal(doc.cm, "beforeChange", doc.cm, obj) }
5057
-
5058
- if (obj.canceled) { return null }
5059
- return {from: obj.from, to: obj.to, text: obj.text, origin: obj.origin}
5060
- }
5061
-
5062
- // Apply a change to a document, and add it to the document's
5063
- // history, and propagating it to all linked documents.
5064
- function makeChange(doc, change, ignoreReadOnly) {
5065
- if (doc.cm) {
5066
- if (!doc.cm.curOp) { return operation(doc.cm, makeChange)(doc, change, ignoreReadOnly) }
5067
- if (doc.cm.state.suppressEdits) { return }
5068
- }
5069
-
5070
- if (hasHandler(doc, "beforeChange") || doc.cm && hasHandler(doc.cm, "beforeChange")) {
5071
- change = filterChange(doc, change, true)
5072
- if (!change) { return }
5073
- }
5074
-
5075
- // Possibly split or suppress the update based on the presence
5076
- // of read-only spans in its range.
5077
- var split = sawReadOnlySpans && !ignoreReadOnly && removeReadOnlyRanges(doc, change.from, change.to)
5078
- if (split) {
5079
- for (var i = split.length - 1; i >= 0; --i)
5080
- { makeChangeInner(doc, {from: split[i].from, to: split[i].to, text: i ? [""] : change.text}) }
5081
- } else {
5082
- makeChangeInner(doc, change)
5083
- }
5084
- }
5085
-
5086
- function makeChangeInner(doc, change) {
5087
- if (change.text.length == 1 && change.text[0] == "" && cmp(change.from, change.to) == 0) { return }
5088
- var selAfter = computeSelAfterChange(doc, change)
5089
- addChangeToHistory(doc, change, selAfter, doc.cm ? doc.cm.curOp.id : NaN)
5090
-
5091
- makeChangeSingleDoc(doc, change, selAfter, stretchSpansOverChange(doc, change))
5092
- var rebased = []
5093
-
5094
- linkedDocs(doc, function (doc, sharedHist) {
5095
- if (!sharedHist && indexOf(rebased, doc.history) == -1) {
5096
- rebaseHist(doc.history, change)
5097
- rebased.push(doc.history)
5098
- }
5099
- makeChangeSingleDoc(doc, change, null, stretchSpansOverChange(doc, change))
5100
- })
5101
- }
5102
-
5103
- // Revert a change stored in a document's history.
5104
- function makeChangeFromHistory(doc, type, allowSelectionOnly) {
5105
- if (doc.cm && doc.cm.state.suppressEdits && !allowSelectionOnly) { return }
5106
-
5107
- var hist = doc.history, event, selAfter = doc.sel
5108
- var source = type == "undo" ? hist.done : hist.undone, dest = type == "undo" ? hist.undone : hist.done
5109
-
5110
- // Verify that there is a useable event (so that ctrl-z won't
5111
- // needlessly clear selection events)
5112
- var i = 0
5113
- for (; i < source.length; i++) {
5114
- event = source[i]
5115
- if (allowSelectionOnly ? event.ranges && !event.equals(doc.sel) : !event.ranges)
5116
- { break }
5117
- }
5118
- if (i == source.length) { return }
5119
- hist.lastOrigin = hist.lastSelOrigin = null
5120
-
5121
- for (;;) {
5122
- event = source.pop()
5123
- if (event.ranges) {
5124
- pushSelectionToHistory(event, dest)
5125
- if (allowSelectionOnly && !event.equals(doc.sel)) {
5126
- setSelection(doc, event, {clearRedo: false})
5127
- return
5128
- }
5129
- selAfter = event
5130
- }
5131
- else { break }
5132
- }
5133
-
5134
- // Build up a reverse change object to add to the opposite history
5135
- // stack (redo when undoing, and vice versa).
5136
- var antiChanges = []
5137
- pushSelectionToHistory(selAfter, dest)
5138
- dest.push({changes: antiChanges, generation: hist.generation})
5139
- hist.generation = event.generation || ++hist.maxGeneration
5140
-
5141
- var filter = hasHandler(doc, "beforeChange") || doc.cm && hasHandler(doc.cm, "beforeChange")
5142
-
5143
- var loop = function ( i ) {
5144
- var change = event.changes[i]
5145
- change.origin = type
5146
- if (filter && !filterChange(doc, change, false)) {
5147
- source.length = 0
5148
- return {}
5149
- }
5150
-
5151
- antiChanges.push(historyChangeFromChange(doc, change))
5152
-
5153
- var after = i ? computeSelAfterChange(doc, change) : lst(source)
5154
- makeChangeSingleDoc(doc, change, after, mergeOldSpans(doc, change))
5155
- if (!i && doc.cm) { doc.cm.scrollIntoView({from: change.from, to: changeEnd(change)}) }
5156
- var rebased = []
5157
-
5158
- // Propagate to the linked documents
5159
- linkedDocs(doc, function (doc, sharedHist) {
5160
- if (!sharedHist && indexOf(rebased, doc.history) == -1) {
5161
- rebaseHist(doc.history, change)
5162
- rebased.push(doc.history)
5163
- }
5164
- makeChangeSingleDoc(doc, change, null, mergeOldSpans(doc, change))
5165
- })
5166
- };
5167
-
5168
- for (var i$1 = event.changes.length - 1; i$1 >= 0; --i$1) {
5169
- var returned = loop( i$1 );
5170
-
5171
- if ( returned ) return returned.v;
5172
- }
5173
- }
5174
-
5175
- // Sub-views need their line numbers shifted when text is added
5176
- // above or below them in the parent document.
5177
- function shiftDoc(doc, distance) {
5178
- if (distance == 0) { return }
5179
- doc.first += distance
5180
- doc.sel = new Selection(map(doc.sel.ranges, function (range) { return new Range(
5181
- Pos(range.anchor.line + distance, range.anchor.ch),
5182
- Pos(range.head.line + distance, range.head.ch)
5183
- ); }), doc.sel.primIndex)
5184
- if (doc.cm) {
5185
- regChange(doc.cm, doc.first, doc.first - distance, distance)
5186
- for (var d = doc.cm.display, l = d.viewFrom; l < d.viewTo; l++)
5187
- { regLineChange(doc.cm, l, "gutter") }
5188
- }
5189
- }
5190
-
5191
- // More lower-level change function, handling only a single document
5192
- // (not linked ones).
5193
- function makeChangeSingleDoc(doc, change, selAfter, spans) {
5194
- if (doc.cm && !doc.cm.curOp)
5195
- { return operation(doc.cm, makeChangeSingleDoc)(doc, change, selAfter, spans) }
5196
-
5197
- if (change.to.line < doc.first) {
5198
- shiftDoc(doc, change.text.length - 1 - (change.to.line - change.from.line))
5199
- return
5200
- }
5201
- if (change.from.line > doc.lastLine()) { return }
5202
-
5203
- // Clip the change to the size of this doc
5204
- if (change.from.line < doc.first) {
5205
- var shift = change.text.length - 1 - (doc.first - change.from.line)
5206
- shiftDoc(doc, shift)
5207
- change = {from: Pos(doc.first, 0), to: Pos(change.to.line + shift, change.to.ch),
5208
- text: [lst(change.text)], origin: change.origin}
5209
- }
5210
- var last = doc.lastLine()
5211
- if (change.to.line > last) {
5212
- change = {from: change.from, to: Pos(last, getLine(doc, last).text.length),
5213
- text: [change.text[0]], origin: change.origin}
5214
- }
5215
-
5216
- change.removed = getBetween(doc, change.from, change.to)
5217
-
5218
- if (!selAfter) { selAfter = computeSelAfterChange(doc, change) }
5219
- if (doc.cm) { makeChangeSingleDocInEditor(doc.cm, change, spans) }
5220
- else { updateDoc(doc, change, spans) }
5221
- setSelectionNoUndo(doc, selAfter, sel_dontScroll)
5222
- }
5223
-
5224
- // Handle the interaction of a change to a document with the editor
5225
- // that this document is part of.
5226
- function makeChangeSingleDocInEditor(cm, change, spans) {
5227
- var doc = cm.doc, display = cm.display, from = change.from, to = change.to
5228
-
5229
- var recomputeMaxLength = false, checkWidthStart = from.line
5230
- if (!cm.options.lineWrapping) {
5231
- checkWidthStart = lineNo(visualLine(getLine(doc, from.line)))
5232
- doc.iter(checkWidthStart, to.line + 1, function (line) {
5233
- if (line == display.maxLine) {
5234
- recomputeMaxLength = true
5235
- return true
5236
- }
5237
- })
5238
- }
5239
-
5240
- if (doc.sel.contains(change.from, change.to) > -1)
5241
- { signalCursorActivity(cm) }
5242
-
5243
- updateDoc(doc, change, spans, estimateHeight(cm))
5244
-
5245
- if (!cm.options.lineWrapping) {
5246
- doc.iter(checkWidthStart, from.line + change.text.length, function (line) {
5247
- var len = lineLength(line)
5248
- if (len > display.maxLineLength) {
5249
- display.maxLine = line
5250
- display.maxLineLength = len
5251
- display.maxLineChanged = true
5252
- recomputeMaxLength = false
5253
- }
5254
- })
5255
- if (recomputeMaxLength) { cm.curOp.updateMaxLine = true }
5256
- }
5257
-
5258
- // Adjust frontier, schedule worker
5259
- doc.frontier = Math.min(doc.frontier, from.line)
5260
- startWorker(cm, 400)
5261
-
5262
- var lendiff = change.text.length - (to.line - from.line) - 1
5263
- // Remember that these lines changed, for updating the display
5264
- if (change.full)
5265
- { regChange(cm) }
5266
- else if (from.line == to.line && change.text.length == 1 && !isWholeLineUpdate(cm.doc, change))
5267
- { regLineChange(cm, from.line, "text") }
5268
- else
5269
- { regChange(cm, from.line, to.line + 1, lendiff) }
5270
-
5271
- var changesHandler = hasHandler(cm, "changes"), changeHandler = hasHandler(cm, "change")
5272
- if (changeHandler || changesHandler) {
5273
- var obj = {
5274
- from: from, to: to,
5275
- text: change.text,
5276
- removed: change.removed,
5277
- origin: change.origin
5278
- }
5279
- if (changeHandler) { signalLater(cm, "change", cm, obj) }
5280
- if (changesHandler) { (cm.curOp.changeObjs || (cm.curOp.changeObjs = [])).push(obj) }
5281
- }
5282
- cm.display.selForContextMenu = null
5283
- }
5284
-
5285
- function replaceRange(doc, code, from, to, origin) {
5286
- if (!to) { to = from }
5287
- if (cmp(to, from) < 0) { var tmp = to; to = from; from = tmp }
5288
- if (typeof code == "string") { code = doc.splitLines(code) }
5289
- makeChange(doc, {from: from, to: to, text: code, origin: origin})
5290
- }
5291
-
5292
- // Rebasing/resetting history to deal with externally-sourced changes
5293
-
5294
- function rebaseHistSelSingle(pos, from, to, diff) {
5295
- if (to < pos.line) {
5296
- pos.line += diff
5297
- } else if (from < pos.line) {
5298
- pos.line = from
5299
- pos.ch = 0
5300
- }
5301
- }
5302
-
5303
- // Tries to rebase an array of history events given a change in the
5304
- // document. If the change touches the same lines as the event, the
5305
- // event, and everything 'behind' it, is discarded. If the change is
5306
- // before the event, the event's positions are updated. Uses a
5307
- // copy-on-write scheme for the positions, to avoid having to
5308
- // reallocate them all on every rebase, but also avoid problems with
5309
- // shared position objects being unsafely updated.
5310
- function rebaseHistArray(array, from, to, diff) {
5311
- for (var i = 0; i < array.length; ++i) {
5312
- var sub = array[i], ok = true
5313
- if (sub.ranges) {
5314
- if (!sub.copied) { sub = array[i] = sub.deepCopy(); sub.copied = true }
5315
- for (var j = 0; j < sub.ranges.length; j++) {
5316
- rebaseHistSelSingle(sub.ranges[j].anchor, from, to, diff)
5317
- rebaseHistSelSingle(sub.ranges[j].head, from, to, diff)
5318
- }
5319
- continue
5320
- }
5321
- for (var j$1 = 0; j$1 < sub.changes.length; ++j$1) {
5322
- var cur = sub.changes[j$1]
5323
- if (to < cur.from.line) {
5324
- cur.from = Pos(cur.from.line + diff, cur.from.ch)
5325
- cur.to = Pos(cur.to.line + diff, cur.to.ch)
5326
- } else if (from <= cur.to.line) {
5327
- ok = false
5328
- break
5329
- }
5330
- }
5331
- if (!ok) {
5332
- array.splice(0, i + 1)
5333
- i = 0
5334
- }
5335
- }
5336
- }
5337
-
5338
- function rebaseHist(hist, change) {
5339
- var from = change.from.line, to = change.to.line, diff = change.text.length - (to - from) - 1
5340
- rebaseHistArray(hist.done, from, to, diff)
5341
- rebaseHistArray(hist.undone, from, to, diff)
5342
- }
5343
-
5344
- // Utility for applying a change to a line by handle or number,
5345
- // returning the number and optionally registering the line as
5346
- // changed.
5347
- function changeLine(doc, handle, changeType, op) {
5348
- var no = handle, line = handle
5349
- if (typeof handle == "number") { line = getLine(doc, clipLine(doc, handle)) }
5350
- else { no = lineNo(handle) }
5351
- if (no == null) { return null }
5352
- if (op(line, no) && doc.cm) { regLineChange(doc.cm, no, changeType) }
5353
- return line
5354
- }
5355
-
5356
- // The document is represented as a BTree consisting of leaves, with
5357
- // chunk of lines in them, and branches, with up to ten leaves or
5358
- // other branch nodes below them. The top node is always a branch
5359
- // node, and is the document object itself (meaning it has
5360
- // additional methods and properties).
5361
- //
5362
- // All nodes have parent links. The tree is used both to go from
5363
- // line numbers to line objects, and to go from objects to numbers.
5364
- // It also indexes by height, and is used to convert between height
5365
- // and line object, and to find the total height of the document.
5366
- //
5367
- // See also http://marijnhaverbeke.nl/blog/codemirror-line-tree.html
5368
-
5369
- var LeafChunk = function(lines) {
5370
- var this$1 = this;
5371
-
5372
- this.lines = lines
5373
- this.parent = null
5374
- var height = 0
5375
- for (var i = 0; i < lines.length; ++i) {
5376
- lines[i].parent = this$1
5377
- height += lines[i].height
5378
- }
5379
- this.height = height
5380
- };
5381
-
5382
- LeafChunk.prototype.chunkSize = function () { return this.lines.length };
5383
-
5384
- // Remove the n lines at offset 'at'.
5385
- LeafChunk.prototype.removeInner = function (at, n) {
5386
- var this$1 = this;
5387
-
5388
- for (var i = at, e = at + n; i < e; ++i) {
5389
- var line = this$1.lines[i]
5390
- this$1.height -= line.height
5391
- cleanUpLine(line)
5392
- signalLater(line, "delete")
5393
- }
5394
- this.lines.splice(at, n)
5395
- };
5396
-
5397
- // Helper used to collapse a small branch into a single leaf.
5398
- LeafChunk.prototype.collapse = function (lines) {
5399
- lines.push.apply(lines, this.lines)
5400
- };
5401
-
5402
- // Insert the given array of lines at offset 'at', count them as
5403
- // having the given height.
5404
- LeafChunk.prototype.insertInner = function (at, lines, height) {
5405
- var this$1 = this;
5406
-
5407
- this.height += height
5408
- this.lines = this.lines.slice(0, at).concat(lines).concat(this.lines.slice(at))
5409
- for (var i = 0; i < lines.length; ++i) { lines[i].parent = this$1 }
5410
- };
5411
-
5412
- // Used to iterate over a part of the tree.
5413
- LeafChunk.prototype.iterN = function (at, n, op) {
5414
- var this$1 = this;
5415
-
5416
- for (var e = at + n; at < e; ++at)
5417
- { if (op(this$1.lines[at])) { return true } }
5418
- };
5419
-
5420
- var BranchChunk = function(children) {
5421
- var this$1 = this;
5422
-
5423
- this.children = children
5424
- var size = 0, height = 0
5425
- for (var i = 0; i < children.length; ++i) {
5426
- var ch = children[i]
5427
- size += ch.chunkSize(); height += ch.height
5428
- ch.parent = this$1
5429
- }
5430
- this.size = size
5431
- this.height = height
5432
- this.parent = null
5433
- };
5434
-
5435
- BranchChunk.prototype.chunkSize = function () { return this.size };
5436
-
5437
- BranchChunk.prototype.removeInner = function (at, n) {
5438
- var this$1 = this;
5439
-
5440
- this.size -= n
5441
- for (var i = 0; i < this.children.length; ++i) {
5442
- var child = this$1.children[i], sz = child.chunkSize()
5443
- if (at < sz) {
5444
- var rm = Math.min(n, sz - at), oldHeight = child.height
5445
- child.removeInner(at, rm)
5446
- this$1.height -= oldHeight - child.height
5447
- if (sz == rm) { this$1.children.splice(i--, 1); child.parent = null }
5448
- if ((n -= rm) == 0) { break }
5449
- at = 0
5450
- } else { at -= sz }
5451
- }
5452
- // If the result is smaller than 25 lines, ensure that it is a
5453
- // single leaf node.
5454
- if (this.size - n < 25 &&
5455
- (this.children.length > 1 || !(this.children[0] instanceof LeafChunk))) {
5456
- var lines = []
5457
- this.collapse(lines)
5458
- this.children = [new LeafChunk(lines)]
5459
- this.children[0].parent = this
5460
- }
5461
- };
5462
-
5463
- BranchChunk.prototype.collapse = function (lines) {
5464
- var this$1 = this;
5465
-
5466
- for (var i = 0; i < this.children.length; ++i) { this$1.children[i].collapse(lines) }
5467
- };
5468
-
5469
- BranchChunk.prototype.insertInner = function (at, lines, height) {
5470
- var this$1 = this;
5471
-
5472
- this.size += lines.length
5473
- this.height += height
5474
- for (var i = 0; i < this.children.length; ++i) {
5475
- var child = this$1.children[i], sz = child.chunkSize()
5476
- if (at <= sz) {
5477
- child.insertInner(at, lines, height)
5478
- if (child.lines && child.lines.length > 50) {
5479
- // To avoid memory thrashing when child.lines is huge (e.g. first view of a large file), it's never spliced.
5480
- // Instead, small slices are taken. They're taken in order because sequential memory accesses are fastest.
5481
- var remaining = child.lines.length % 25 + 25
5482
- for (var pos = remaining; pos < child.lines.length;) {
5483
- var leaf = new LeafChunk(child.lines.slice(pos, pos += 25))
5484
- child.height -= leaf.height
5485
- this$1.children.splice(++i, 0, leaf)
5486
- leaf.parent = this$1
5487
- }
5488
- child.lines = child.lines.slice(0, remaining)
5489
- this$1.maybeSpill()
5490
- }
5491
- break
5492
- }
5493
- at -= sz
5494
- }
5495
- };
5496
-
5497
- // When a node has grown, check whether it should be split.
5498
- BranchChunk.prototype.maybeSpill = function () {
5499
- if (this.children.length <= 10) { return }
5500
- var me = this
5501
- do {
5502
- var spilled = me.children.splice(me.children.length - 5, 5)
5503
- var sibling = new BranchChunk(spilled)
5504
- if (!me.parent) { // Become the parent node
5505
- var copy = new BranchChunk(me.children)
5506
- copy.parent = me
5507
- me.children = [copy, sibling]
5508
- me = copy
5509
- } else {
5510
- me.size -= sibling.size
5511
- me.height -= sibling.height
5512
- var myIndex = indexOf(me.parent.children, me)
5513
- me.parent.children.splice(myIndex + 1, 0, sibling)
5514
- }
5515
- sibling.parent = me.parent
5516
- } while (me.children.length > 10)
5517
- me.parent.maybeSpill()
5518
- };
5519
-
5520
- BranchChunk.prototype.iterN = function (at, n, op) {
5521
- var this$1 = this;
5522
-
5523
- for (var i = 0; i < this.children.length; ++i) {
5524
- var child = this$1.children[i], sz = child.chunkSize()
5525
- if (at < sz) {
5526
- var used = Math.min(n, sz - at)
5527
- if (child.iterN(at, used, op)) { return true }
5528
- if ((n -= used) == 0) { break }
5529
- at = 0
5530
- } else { at -= sz }
5531
- }
5532
- };
5533
-
5534
- // Line widgets are block elements displayed above or below a line.
5535
-
5536
- var LineWidget = function(doc, node, options) {
5537
- var this$1 = this;
5538
-
5539
- if (options) { for (var opt in options) { if (options.hasOwnProperty(opt))
5540
- { this$1[opt] = options[opt] } } }
5541
- this.doc = doc
5542
- this.node = node
5543
- };
5544
-
5545
- LineWidget.prototype.clear = function () {
5546
- var this$1 = this;
5547
-
5548
- var cm = this.doc.cm, ws = this.line.widgets, line = this.line, no = lineNo(line)
5549
- if (no == null || !ws) { return }
5550
- for (var i = 0; i < ws.length; ++i) { if (ws[i] == this$1) { ws.splice(i--, 1) } }
5551
- if (!ws.length) { line.widgets = null }
5552
- var height = widgetHeight(this)
5553
- updateLineHeight(line, Math.max(0, line.height - height))
5554
- if (cm) {
5555
- runInOp(cm, function () {
5556
- adjustScrollWhenAboveVisible(cm, line, -height)
5557
- regLineChange(cm, no, "widget")
5558
- })
5559
- signalLater(cm, "lineWidgetCleared", cm, this, no)
5560
- }
5561
- };
5562
-
5563
- LineWidget.prototype.changed = function () {
5564
- var this$1 = this;
5565
-
5566
- var oldH = this.height, cm = this.doc.cm, line = this.line
5567
- this.height = null
5568
- var diff = widgetHeight(this) - oldH
5569
- if (!diff) { return }
5570
- updateLineHeight(line, line.height + diff)
5571
- if (cm) {
5572
- runInOp(cm, function () {
5573
- cm.curOp.forceUpdate = true
5574
- adjustScrollWhenAboveVisible(cm, line, diff)
5575
- signalLater(cm, "lineWidgetChanged", cm, this$1, lineNo(line))
5576
- })
5577
- }
5578
- };
5579
- eventMixin(LineWidget)
5580
-
5581
- function adjustScrollWhenAboveVisible(cm, line, diff) {
5582
- if (heightAtLine(line) < ((cm.curOp && cm.curOp.scrollTop) || cm.doc.scrollTop))
5583
- { addToScrollTop(cm, diff) }
5584
- }
5585
-
5586
- function addLineWidget(doc, handle, node, options) {
5587
- var widget = new LineWidget(doc, node, options)
5588
- var cm = doc.cm
5589
- if (cm && widget.noHScroll) { cm.display.alignWidgets = true }
5590
- changeLine(doc, handle, "widget", function (line) {
5591
- var widgets = line.widgets || (line.widgets = [])
5592
- if (widget.insertAt == null) { widgets.push(widget) }
5593
- else { widgets.splice(Math.min(widgets.length - 1, Math.max(0, widget.insertAt)), 0, widget) }
5594
- widget.line = line
5595
- if (cm && !lineIsHidden(doc, line)) {
5596
- var aboveVisible = heightAtLine(line) < doc.scrollTop
5597
- updateLineHeight(line, line.height + widgetHeight(widget))
5598
- if (aboveVisible) { addToScrollTop(cm, widget.height) }
5599
- cm.curOp.forceUpdate = true
5600
- }
5601
- return true
5602
- })
5603
- signalLater(cm, "lineWidgetAdded", cm, widget, typeof handle == "number" ? handle : lineNo(handle))
5604
- return widget
5605
- }
5606
-
5607
- // TEXTMARKERS
5608
-
5609
- // Created with markText and setBookmark methods. A TextMarker is a
5610
- // handle that can be used to clear or find a marked position in the
5611
- // document. Line objects hold arrays (markedSpans) containing
5612
- // {from, to, marker} object pointing to such marker objects, and
5613
- // indicating that such a marker is present on that line. Multiple
5614
- // lines may point to the same marker when it spans across lines.
5615
- // The spans will have null for their from/to properties when the
5616
- // marker continues beyond the start/end of the line. Markers have
5617
- // links back to the lines they currently touch.
5618
-
5619
- // Collapsed markers have unique ids, in order to be able to order
5620
- // them, which is needed for uniquely determining an outer marker
5621
- // when they overlap (they may nest, but not partially overlap).
5622
- var nextMarkerId = 0
5623
-
5624
- var TextMarker = function(doc, type) {
5625
- this.lines = []
5626
- this.type = type
5627
- this.doc = doc
5628
- this.id = ++nextMarkerId
5629
- };
5630
-
5631
- // Clear the marker.
5632
- TextMarker.prototype.clear = function () {
5633
- var this$1 = this;
5634
-
5635
- if (this.explicitlyCleared) { return }
5636
- var cm = this.doc.cm, withOp = cm && !cm.curOp
5637
- if (withOp) { startOperation(cm) }
5638
- if (hasHandler(this, "clear")) {
5639
- var found = this.find()
5640
- if (found) { signalLater(this, "clear", found.from, found.to) }
5641
- }
5642
- var min = null, max = null
5643
- for (var i = 0; i < this.lines.length; ++i) {
5644
- var line = this$1.lines[i]
5645
- var span = getMarkedSpanFor(line.markedSpans, this$1)
5646
- if (cm && !this$1.collapsed) { regLineChange(cm, lineNo(line), "text") }
5647
- else if (cm) {
5648
- if (span.to != null) { max = lineNo(line) }
5649
- if (span.from != null) { min = lineNo(line) }
5650
- }
5651
- line.markedSpans = removeMarkedSpan(line.markedSpans, span)
5652
- if (span.from == null && this$1.collapsed && !lineIsHidden(this$1.doc, line) && cm)
5653
- { updateLineHeight(line, textHeight(cm.display)) }
5654
- }
5655
- if (cm && this.collapsed && !cm.options.lineWrapping) { for (var i$1 = 0; i$1 < this.lines.length; ++i$1) {
5656
- var visual = visualLine(this$1.lines[i$1]), len = lineLength(visual)
5657
- if (len > cm.display.maxLineLength) {
5658
- cm.display.maxLine = visual
5659
- cm.display.maxLineLength = len
5660
- cm.display.maxLineChanged = true
5661
- }
5662
- } }
5663
-
5664
- if (min != null && cm && this.collapsed) { regChange(cm, min, max + 1) }
5665
- this.lines.length = 0
5666
- this.explicitlyCleared = true
5667
- if (this.atomic && this.doc.cantEdit) {
5668
- this.doc.cantEdit = false
5669
- if (cm) { reCheckSelection(cm.doc) }
5670
- }
5671
- if (cm) { signalLater(cm, "markerCleared", cm, this, min, max) }
5672
- if (withOp) { endOperation(cm) }
5673
- if (this.parent) { this.parent.clear() }
5674
- };
5675
-
5676
- // Find the position of the marker in the document. Returns a {from,
5677
- // to} object by default. Side can be passed to get a specific side
5678
- // -- 0 (both), -1 (left), or 1 (right). When lineObj is true, the
5679
- // Pos objects returned contain a line object, rather than a line
5680
- // number (used to prevent looking up the same line twice).
5681
- TextMarker.prototype.find = function (side, lineObj) {
5682
- var this$1 = this;
5683
-
5684
- if (side == null && this.type == "bookmark") { side = 1 }
5685
- var from, to
5686
- for (var i = 0; i < this.lines.length; ++i) {
5687
- var line = this$1.lines[i]
5688
- var span = getMarkedSpanFor(line.markedSpans, this$1)
5689
- if (span.from != null) {
5690
- from = Pos(lineObj ? line : lineNo(line), span.from)
5691
- if (side == -1) { return from }
5692
- }
5693
- if (span.to != null) {
5694
- to = Pos(lineObj ? line : lineNo(line), span.to)
5695
- if (side == 1) { return to }
5696
- }
5697
- }
5698
- return from && {from: from, to: to}
5699
- };
5700
-
5701
- // Signals that the marker's widget changed, and surrounding layout
5702
- // should be recomputed.
5703
- TextMarker.prototype.changed = function () {
5704
- var this$1 = this;
5705
-
5706
- var pos = this.find(-1, true), widget = this, cm = this.doc.cm
5707
- if (!pos || !cm) { return }
5708
- runInOp(cm, function () {
5709
- var line = pos.line, lineN = lineNo(pos.line)
5710
- var view = findViewForLine(cm, lineN)
5711
- if (view) {
5712
- clearLineMeasurementCacheFor(view)
5713
- cm.curOp.selectionChanged = cm.curOp.forceUpdate = true
5714
- }
5715
- cm.curOp.updateMaxLine = true
5716
- if (!lineIsHidden(widget.doc, line) && widget.height != null) {
5717
- var oldHeight = widget.height
5718
- widget.height = null
5719
- var dHeight = widgetHeight(widget) - oldHeight
5720
- if (dHeight)
5721
- { updateLineHeight(line, line.height + dHeight) }
5722
- }
5723
- signalLater(cm, "markerChanged", cm, this$1)
5724
- })
5725
- };
5726
-
5727
- TextMarker.prototype.attachLine = function (line) {
5728
- if (!this.lines.length && this.doc.cm) {
5729
- var op = this.doc.cm.curOp
5730
- if (!op.maybeHiddenMarkers || indexOf(op.maybeHiddenMarkers, this) == -1)
5731
- { (op.maybeUnhiddenMarkers || (op.maybeUnhiddenMarkers = [])).push(this) }
5732
- }
5733
- this.lines.push(line)
5734
- };
5735
-
5736
- TextMarker.prototype.detachLine = function (line) {
5737
- this.lines.splice(indexOf(this.lines, line), 1)
5738
- if (!this.lines.length && this.doc.cm) {
5739
- var op = this.doc.cm.curOp
5740
- ;(op.maybeHiddenMarkers || (op.maybeHiddenMarkers = [])).push(this)
5741
- }
5742
- };
5743
- eventMixin(TextMarker)
5744
-
5745
- // Create a marker, wire it up to the right lines, and
5746
- function markText(doc, from, to, options, type) {
5747
- // Shared markers (across linked documents) are handled separately
5748
- // (markTextShared will call out to this again, once per
5749
- // document).
5750
- if (options && options.shared) { return markTextShared(doc, from, to, options, type) }
5751
- // Ensure we are in an operation.
5752
- if (doc.cm && !doc.cm.curOp) { return operation(doc.cm, markText)(doc, from, to, options, type) }
5753
-
5754
- var marker = new TextMarker(doc, type), diff = cmp(from, to)
5755
- if (options) { copyObj(options, marker, false) }
5756
- // Don't connect empty markers unless clearWhenEmpty is false
5757
- if (diff > 0 || diff == 0 && marker.clearWhenEmpty !== false)
5758
- { return marker }
5759
- if (marker.replacedWith) {
5760
- // Showing up as a widget implies collapsed (widget replaces text)
5761
- marker.collapsed = true
5762
- marker.widgetNode = eltP("span", [marker.replacedWith], "CodeMirror-widget")
5763
- if (!options.handleMouseEvents) { marker.widgetNode.setAttribute("cm-ignore-events", "true") }
5764
- if (options.insertLeft) { marker.widgetNode.insertLeft = true }
5765
- }
5766
- if (marker.collapsed) {
5767
- if (conflictingCollapsedRange(doc, from.line, from, to, marker) ||
5768
- from.line != to.line && conflictingCollapsedRange(doc, to.line, from, to, marker))
5769
- { throw new Error("Inserting collapsed marker partially overlapping an existing one") }
5770
- seeCollapsedSpans()
5771
- }
5772
-
5773
- if (marker.addToHistory)
5774
- { addChangeToHistory(doc, {from: from, to: to, origin: "markText"}, doc.sel, NaN) }
5775
-
5776
- var curLine = from.line, cm = doc.cm, updateMaxLine
5777
- doc.iter(curLine, to.line + 1, function (line) {
5778
- if (cm && marker.collapsed && !cm.options.lineWrapping && visualLine(line) == cm.display.maxLine)
5779
- { updateMaxLine = true }
5780
- if (marker.collapsed && curLine != from.line) { updateLineHeight(line, 0) }
5781
- addMarkedSpan(line, new MarkedSpan(marker,
5782
- curLine == from.line ? from.ch : null,
5783
- curLine == to.line ? to.ch : null))
5784
- ++curLine
5785
- })
5786
- // lineIsHidden depends on the presence of the spans, so needs a second pass
5787
- if (marker.collapsed) { doc.iter(from.line, to.line + 1, function (line) {
5788
- if (lineIsHidden(doc, line)) { updateLineHeight(line, 0) }
5789
- }) }
5790
-
5791
- if (marker.clearOnEnter) { on(marker, "beforeCursorEnter", function () { return marker.clear(); }) }
5792
-
5793
- if (marker.readOnly) {
5794
- seeReadOnlySpans()
5795
- if (doc.history.done.length || doc.history.undone.length)
5796
- { doc.clearHistory() }
5797
- }
5798
- if (marker.collapsed) {
5799
- marker.id = ++nextMarkerId
5800
- marker.atomic = true
5801
- }
5802
- if (cm) {
5803
- // Sync editor state
5804
- if (updateMaxLine) { cm.curOp.updateMaxLine = true }
5805
- if (marker.collapsed)
5806
- { regChange(cm, from.line, to.line + 1) }
5807
- else if (marker.className || marker.title || marker.startStyle || marker.endStyle || marker.css)
5808
- { for (var i = from.line; i <= to.line; i++) { regLineChange(cm, i, "text") } }
5809
- if (marker.atomic) { reCheckSelection(cm.doc) }
5810
- signalLater(cm, "markerAdded", cm, marker)
5811
- }
5812
- return marker
5813
- }
5814
-
5815
- // SHARED TEXTMARKERS
5816
-
5817
- // A shared marker spans multiple linked documents. It is
5818
- // implemented as a meta-marker-object controlling multiple normal
5819
- // markers.
5820
- var SharedTextMarker = function(markers, primary) {
5821
- var this$1 = this;
5822
-
5823
- this.markers = markers
5824
- this.primary = primary
5825
- for (var i = 0; i < markers.length; ++i)
5826
- { markers[i].parent = this$1 }
5827
- };
5828
-
5829
- SharedTextMarker.prototype.clear = function () {
5830
- var this$1 = this;
5831
-
5832
- if (this.explicitlyCleared) { return }
5833
- this.explicitlyCleared = true
5834
- for (var i = 0; i < this.markers.length; ++i)
5835
- { this$1.markers[i].clear() }
5836
- signalLater(this, "clear")
5837
- };
5838
-
5839
- SharedTextMarker.prototype.find = function (side, lineObj) {
5840
- return this.primary.find(side, lineObj)
5841
- };
5842
- eventMixin(SharedTextMarker)
5843
-
5844
- function markTextShared(doc, from, to, options, type) {
5845
- options = copyObj(options)
5846
- options.shared = false
5847
- var markers = [markText(doc, from, to, options, type)], primary = markers[0]
5848
- var widget = options.widgetNode
5849
- linkedDocs(doc, function (doc) {
5850
- if (widget) { options.widgetNode = widget.cloneNode(true) }
5851
- markers.push(markText(doc, clipPos(doc, from), clipPos(doc, to), options, type))
5852
- for (var i = 0; i < doc.linked.length; ++i)
5853
- { if (doc.linked[i].isParent) { return } }
5854
- primary = lst(markers)
5855
- })
5856
- return new SharedTextMarker(markers, primary)
5857
- }
5858
-
5859
- function findSharedMarkers(doc) {
5860
- return doc.findMarks(Pos(doc.first, 0), doc.clipPos(Pos(doc.lastLine())), function (m) { return m.parent; })
5861
- }
5862
-
5863
- function copySharedMarkers(doc, markers) {
5864
- for (var i = 0; i < markers.length; i++) {
5865
- var marker = markers[i], pos = marker.find()
5866
- var mFrom = doc.clipPos(pos.from), mTo = doc.clipPos(pos.to)
5867
- if (cmp(mFrom, mTo)) {
5868
- var subMark = markText(doc, mFrom, mTo, marker.primary, marker.primary.type)
5869
- marker.markers.push(subMark)
5870
- subMark.parent = marker
5871
- }
5872
- }
5873
- }
5874
-
5875
- function detachSharedMarkers(markers) {
5876
- var loop = function ( i ) {
5877
- var marker = markers[i], linked = [marker.primary.doc]
5878
- linkedDocs(marker.primary.doc, function (d) { return linked.push(d); })
5879
- for (var j = 0; j < marker.markers.length; j++) {
5880
- var subMarker = marker.markers[j]
5881
- if (indexOf(linked, subMarker.doc) == -1) {
5882
- subMarker.parent = null
5883
- marker.markers.splice(j--, 1)
5884
- }
5885
- }
5886
- };
5887
-
5888
- for (var i = 0; i < markers.length; i++) loop( i );
5889
- }
5890
-
5891
- var nextDocId = 0
5892
- var Doc = function(text, mode, firstLine, lineSep, direction) {
5893
- if (!(this instanceof Doc)) { return new Doc(text, mode, firstLine, lineSep, direction) }
5894
- if (firstLine == null) { firstLine = 0 }
5895
-
5896
- BranchChunk.call(this, [new LeafChunk([new Line("", null)])])
5897
- this.first = firstLine
5898
- this.scrollTop = this.scrollLeft = 0
5899
- this.cantEdit = false
5900
- this.cleanGeneration = 1
5901
- this.frontier = firstLine
5902
- var start = Pos(firstLine, 0)
5903
- this.sel = simpleSelection(start)
5904
- this.history = new History(null)
5905
- this.id = ++nextDocId
5906
- this.modeOption = mode
5907
- this.lineSep = lineSep
5908
- this.direction = (direction == "rtl") ? "rtl" : "ltr"
5909
- this.extend = false
5910
-
5911
- if (typeof text == "string") { text = this.splitLines(text) }
5912
- updateDoc(this, {from: start, to: start, text: text})
5913
- setSelection(this, simpleSelection(start), sel_dontScroll)
5914
- }
5915
-
5916
- Doc.prototype = createObj(BranchChunk.prototype, {
5917
- constructor: Doc,
5918
- // Iterate over the document. Supports two forms -- with only one
5919
- // argument, it calls that for each line in the document. With
5920
- // three, it iterates over the range given by the first two (with
5921
- // the second being non-inclusive).
5922
- iter: function(from, to, op) {
5923
- if (op) { this.iterN(from - this.first, to - from, op) }
5924
- else { this.iterN(this.first, this.first + this.size, from) }
5925
- },
5926
-
5927
- // Non-public interface for adding and removing lines.
5928
- insert: function(at, lines) {
5929
- var height = 0
5930
- for (var i = 0; i < lines.length; ++i) { height += lines[i].height }
5931
- this.insertInner(at - this.first, lines, height)
5932
- },
5933
- remove: function(at, n) { this.removeInner(at - this.first, n) },
5934
-
5935
- // From here, the methods are part of the public interface. Most
5936
- // are also available from CodeMirror (editor) instances.
5937
-
5938
- getValue: function(lineSep) {
5939
- var lines = getLines(this, this.first, this.first + this.size)
5940
- if (lineSep === false) { return lines }
5941
- return lines.join(lineSep || this.lineSeparator())
5942
- },
5943
- setValue: docMethodOp(function(code) {
5944
- var top = Pos(this.first, 0), last = this.first + this.size - 1
5945
- makeChange(this, {from: top, to: Pos(last, getLine(this, last).text.length),
5946
- text: this.splitLines(code), origin: "setValue", full: true}, true)
5947
- if (this.cm) { scrollToCoords(this.cm, 0, 0) }
5948
- setSelection(this, simpleSelection(top), sel_dontScroll)
5949
- }),
5950
- replaceRange: function(code, from, to, origin) {
5951
- from = clipPos(this, from)
5952
- to = to ? clipPos(this, to) : from
5953
- replaceRange(this, code, from, to, origin)
5954
- },
5955
- getRange: function(from, to, lineSep) {
5956
- var lines = getBetween(this, clipPos(this, from), clipPos(this, to))
5957
- if (lineSep === false) { return lines }
5958
- return lines.join(lineSep || this.lineSeparator())
5959
- },
5960
-
5961
- getLine: function(line) {var l = this.getLineHandle(line); return l && l.text},
5962
-
5963
- getLineHandle: function(line) {if (isLine(this, line)) { return getLine(this, line) }},
5964
- getLineNumber: function(line) {return lineNo(line)},
5965
-
5966
- getLineHandleVisualStart: function(line) {
5967
- if (typeof line == "number") { line = getLine(this, line) }
5968
- return visualLine(line)
5969
- },
5970
-
5971
- lineCount: function() {return this.size},
5972
- firstLine: function() {return this.first},
5973
- lastLine: function() {return this.first + this.size - 1},
5974
-
5975
- clipPos: function(pos) {return clipPos(this, pos)},
5976
-
5977
- getCursor: function(start) {
5978
- var range = this.sel.primary(), pos
5979
- if (start == null || start == "head") { pos = range.head }
5980
- else if (start == "anchor") { pos = range.anchor }
5981
- else if (start == "end" || start == "to" || start === false) { pos = range.to() }
5982
- else { pos = range.from() }
5983
- return pos
5984
- },
5985
- listSelections: function() { return this.sel.ranges },
5986
- somethingSelected: function() {return this.sel.somethingSelected()},
5987
-
5988
- setCursor: docMethodOp(function(line, ch, options) {
5989
- setSimpleSelection(this, clipPos(this, typeof line == "number" ? Pos(line, ch || 0) : line), null, options)
5990
- }),
5991
- setSelection: docMethodOp(function(anchor, head, options) {
5992
- setSimpleSelection(this, clipPos(this, anchor), clipPos(this, head || anchor), options)
5993
- }),
5994
- extendSelection: docMethodOp(function(head, other, options) {
5995
- extendSelection(this, clipPos(this, head), other && clipPos(this, other), options)
5996
- }),
5997
- extendSelections: docMethodOp(function(heads, options) {
5998
- extendSelections(this, clipPosArray(this, heads), options)
5999
- }),
6000
- extendSelectionsBy: docMethodOp(function(f, options) {
6001
- var heads = map(this.sel.ranges, f)
6002
- extendSelections(this, clipPosArray(this, heads), options)
6003
- }),
6004
- setSelections: docMethodOp(function(ranges, primary, options) {
6005
- var this$1 = this;
6006
-
6007
- if (!ranges.length) { return }
6008
- var out = []
6009
- for (var i = 0; i < ranges.length; i++)
6010
- { out[i] = new Range(clipPos(this$1, ranges[i].anchor),
6011
- clipPos(this$1, ranges[i].head)) }
6012
- if (primary == null) { primary = Math.min(ranges.length - 1, this.sel.primIndex) }
6013
- setSelection(this, normalizeSelection(out, primary), options)
6014
- }),
6015
- addSelection: docMethodOp(function(anchor, head, options) {
6016
- var ranges = this.sel.ranges.slice(0)
6017
- ranges.push(new Range(clipPos(this, anchor), clipPos(this, head || anchor)))
6018
- setSelection(this, normalizeSelection(ranges, ranges.length - 1), options)
6019
- }),
6020
-
6021
- getSelection: function(lineSep) {
6022
- var this$1 = this;
6023
-
6024
- var ranges = this.sel.ranges, lines
6025
- for (var i = 0; i < ranges.length; i++) {
6026
- var sel = getBetween(this$1, ranges[i].from(), ranges[i].to())
6027
- lines = lines ? lines.concat(sel) : sel
6028
- }
6029
- if (lineSep === false) { return lines }
6030
- else { return lines.join(lineSep || this.lineSeparator()) }
6031
- },
6032
- getSelections: function(lineSep) {
6033
- var this$1 = this;
6034
-
6035
- var parts = [], ranges = this.sel.ranges
6036
- for (var i = 0; i < ranges.length; i++) {
6037
- var sel = getBetween(this$1, ranges[i].from(), ranges[i].to())
6038
- if (lineSep !== false) { sel = sel.join(lineSep || this$1.lineSeparator()) }
6039
- parts[i] = sel
6040
- }
6041
- return parts
6042
- },
6043
- replaceSelection: function(code, collapse, origin) {
6044
- var dup = []
6045
- for (var i = 0; i < this.sel.ranges.length; i++)
6046
- { dup[i] = code }
6047
- this.replaceSelections(dup, collapse, origin || "+input")
6048
- },
6049
- replaceSelections: docMethodOp(function(code, collapse, origin) {
6050
- var this$1 = this;
6051
-
6052
- var changes = [], sel = this.sel
6053
- for (var i = 0; i < sel.ranges.length; i++) {
6054
- var range = sel.ranges[i]
6055
- changes[i] = {from: range.from(), to: range.to(), text: this$1.splitLines(code[i]), origin: origin}
6056
- }
6057
- var newSel = collapse && collapse != "end" && computeReplacedSel(this, changes, collapse)
6058
- for (var i$1 = changes.length - 1; i$1 >= 0; i$1--)
6059
- { makeChange(this$1, changes[i$1]) }
6060
- if (newSel) { setSelectionReplaceHistory(this, newSel) }
6061
- else if (this.cm) { ensureCursorVisible(this.cm) }
6062
- }),
6063
- undo: docMethodOp(function() {makeChangeFromHistory(this, "undo")}),
6064
- redo: docMethodOp(function() {makeChangeFromHistory(this, "redo")}),
6065
- undoSelection: docMethodOp(function() {makeChangeFromHistory(this, "undo", true)}),
6066
- redoSelection: docMethodOp(function() {makeChangeFromHistory(this, "redo", true)}),
6067
-
6068
- setExtending: function(val) {this.extend = val},
6069
- getExtending: function() {return this.extend},
6070
-
6071
- historySize: function() {
6072
- var hist = this.history, done = 0, undone = 0
6073
- for (var i = 0; i < hist.done.length; i++) { if (!hist.done[i].ranges) { ++done } }
6074
- for (var i$1 = 0; i$1 < hist.undone.length; i$1++) { if (!hist.undone[i$1].ranges) { ++undone } }
6075
- return {undo: done, redo: undone}
6076
- },
6077
- clearHistory: function() {this.history = new History(this.history.maxGeneration)},
6078
-
6079
- markClean: function() {
6080
- this.cleanGeneration = this.changeGeneration(true)
6081
- },
6082
- changeGeneration: function(forceSplit) {
6083
- if (forceSplit)
6084
- { this.history.lastOp = this.history.lastSelOp = this.history.lastOrigin = null }
6085
- return this.history.generation
6086
- },
6087
- isClean: function (gen) {
6088
- return this.history.generation == (gen || this.cleanGeneration)
6089
- },
6090
-
6091
- getHistory: function() {
6092
- return {done: copyHistoryArray(this.history.done),
6093
- undone: copyHistoryArray(this.history.undone)}
6094
- },
6095
- setHistory: function(histData) {
6096
- var hist = this.history = new History(this.history.maxGeneration)
6097
- hist.done = copyHistoryArray(histData.done.slice(0), null, true)
6098
- hist.undone = copyHistoryArray(histData.undone.slice(0), null, true)
6099
- },
6100
-
6101
- setGutterMarker: docMethodOp(function(line, gutterID, value) {
6102
- return changeLine(this, line, "gutter", function (line) {
6103
- var markers = line.gutterMarkers || (line.gutterMarkers = {})
6104
- markers[gutterID] = value
6105
- if (!value && isEmpty(markers)) { line.gutterMarkers = null }
6106
- return true
6107
- })
6108
- }),
6109
-
6110
- clearGutter: docMethodOp(function(gutterID) {
6111
- var this$1 = this;
6112
-
6113
- this.iter(function (line) {
6114
- if (line.gutterMarkers && line.gutterMarkers[gutterID]) {
6115
- changeLine(this$1, line, "gutter", function () {
6116
- line.gutterMarkers[gutterID] = null
6117
- if (isEmpty(line.gutterMarkers)) { line.gutterMarkers = null }
6118
- return true
6119
- })
6120
- }
6121
- })
6122
- }),
6123
-
6124
- lineInfo: function(line) {
6125
- var n
6126
- if (typeof line == "number") {
6127
- if (!isLine(this, line)) { return null }
6128
- n = line
6129
- line = getLine(this, line)
6130
- if (!line) { return null }
6131
- } else {
6132
- n = lineNo(line)
6133
- if (n == null) { return null }
6134
- }
6135
- return {line: n, handle: line, text: line.text, gutterMarkers: line.gutterMarkers,
6136
- textClass: line.textClass, bgClass: line.bgClass, wrapClass: line.wrapClass,
6137
- widgets: line.widgets}
6138
- },
6139
-
6140
- addLineClass: docMethodOp(function(handle, where, cls) {
6141
- return changeLine(this, handle, where == "gutter" ? "gutter" : "class", function (line) {
6142
- var prop = where == "text" ? "textClass"
6143
- : where == "background" ? "bgClass"
6144
- : where == "gutter" ? "gutterClass" : "wrapClass"
6145
- if (!line[prop]) { line[prop] = cls }
6146
- else if (classTest(cls).test(line[prop])) { return false }
6147
- else { line[prop] += " " + cls }
6148
- return true
6149
- })
6150
- }),
6151
- removeLineClass: docMethodOp(function(handle, where, cls) {
6152
- return changeLine(this, handle, where == "gutter" ? "gutter" : "class", function (line) {
6153
- var prop = where == "text" ? "textClass"
6154
- : where == "background" ? "bgClass"
6155
- : where == "gutter" ? "gutterClass" : "wrapClass"
6156
- var cur = line[prop]
6157
- if (!cur) { return false }
6158
- else if (cls == null) { line[prop] = null }
6159
- else {
6160
- var found = cur.match(classTest(cls))
6161
- if (!found) { return false }
6162
- var end = found.index + found[0].length
6163
- line[prop] = cur.slice(0, found.index) + (!found.index || end == cur.length ? "" : " ") + cur.slice(end) || null
6164
- }
6165
- return true
6166
- })
6167
- }),
6168
-
6169
- addLineWidget: docMethodOp(function(handle, node, options) {
6170
- return addLineWidget(this, handle, node, options)
6171
- }),
6172
- removeLineWidget: function(widget) { widget.clear() },
6173
-
6174
- markText: function(from, to, options) {
6175
- return markText(this, clipPos(this, from), clipPos(this, to), options, options && options.type || "range")
6176
- },
6177
- setBookmark: function(pos, options) {
6178
- var realOpts = {replacedWith: options && (options.nodeType == null ? options.widget : options),
6179
- insertLeft: options && options.insertLeft,
6180
- clearWhenEmpty: false, shared: options && options.shared,
6181
- handleMouseEvents: options && options.handleMouseEvents}
6182
- pos = clipPos(this, pos)
6183
- return markText(this, pos, pos, realOpts, "bookmark")
6184
- },
6185
- findMarksAt: function(pos) {
6186
- pos = clipPos(this, pos)
6187
- var markers = [], spans = getLine(this, pos.line).markedSpans
6188
- if (spans) { for (var i = 0; i < spans.length; ++i) {
6189
- var span = spans[i]
6190
- if ((span.from == null || span.from <= pos.ch) &&
6191
- (span.to == null || span.to >= pos.ch))
6192
- { markers.push(span.marker.parent || span.marker) }
6193
- } }
6194
- return markers
6195
- },
6196
- findMarks: function(from, to, filter) {
6197
- from = clipPos(this, from); to = clipPos(this, to)
6198
- var found = [], lineNo = from.line
6199
- this.iter(from.line, to.line + 1, function (line) {
6200
- var spans = line.markedSpans
6201
- if (spans) { for (var i = 0; i < spans.length; i++) {
6202
- var span = spans[i]
6203
- if (!(span.to != null && lineNo == from.line && from.ch >= span.to ||
6204
- span.from == null && lineNo != from.line ||
6205
- span.from != null && lineNo == to.line && span.from >= to.ch) &&
6206
- (!filter || filter(span.marker)))
6207
- { found.push(span.marker.parent || span.marker) }
6208
- } }
6209
- ++lineNo
6210
- })
6211
- return found
6212
- },
6213
- getAllMarks: function() {
6214
- var markers = []
6215
- this.iter(function (line) {
6216
- var sps = line.markedSpans
6217
- if (sps) { for (var i = 0; i < sps.length; ++i)
6218
- { if (sps[i].from != null) { markers.push(sps[i].marker) } } }
6219
- })
6220
- return markers
6221
- },
6222
-
6223
- posFromIndex: function(off) {
6224
- var ch, lineNo = this.first, sepSize = this.lineSeparator().length
6225
- this.iter(function (line) {
6226
- var sz = line.text.length + sepSize
6227
- if (sz > off) { ch = off; return true }
6228
- off -= sz
6229
- ++lineNo
6230
- })
6231
- return clipPos(this, Pos(lineNo, ch))
6232
- },
6233
- indexFromPos: function (coords) {
6234
- coords = clipPos(this, coords)
6235
- var index = coords.ch
6236
- if (coords.line < this.first || coords.ch < 0) { return 0 }
6237
- var sepSize = this.lineSeparator().length
6238
- this.iter(this.first, coords.line, function (line) { // iter aborts when callback returns a truthy value
6239
- index += line.text.length + sepSize
6240
- })
6241
- return index
6242
- },
6243
-
6244
- copy: function(copyHistory) {
6245
- var doc = new Doc(getLines(this, this.first, this.first + this.size),
6246
- this.modeOption, this.first, this.lineSep, this.direction)
6247
- doc.scrollTop = this.scrollTop; doc.scrollLeft = this.scrollLeft
6248
- doc.sel = this.sel
6249
- doc.extend = false
6250
- if (copyHistory) {
6251
- doc.history.undoDepth = this.history.undoDepth
6252
- doc.setHistory(this.getHistory())
6253
- }
6254
- return doc
6255
- },
6256
-
6257
- linkedDoc: function(options) {
6258
- if (!options) { options = {} }
6259
- var from = this.first, to = this.first + this.size
6260
- if (options.from != null && options.from > from) { from = options.from }
6261
- if (options.to != null && options.to < to) { to = options.to }
6262
- var copy = new Doc(getLines(this, from, to), options.mode || this.modeOption, from, this.lineSep, this.direction)
6263
- if (options.sharedHist) { copy.history = this.history
6264
- ; }(this.linked || (this.linked = [])).push({doc: copy, sharedHist: options.sharedHist})
6265
- copy.linked = [{doc: this, isParent: true, sharedHist: options.sharedHist}]
6266
- copySharedMarkers(copy, findSharedMarkers(this))
6267
- return copy
6268
- },
6269
- unlinkDoc: function(other) {
6270
- var this$1 = this;
6271
-
6272
- if (other instanceof CodeMirror) { other = other.doc }
6273
- if (this.linked) { for (var i = 0; i < this.linked.length; ++i) {
6274
- var link = this$1.linked[i]
6275
- if (link.doc != other) { continue }
6276
- this$1.linked.splice(i, 1)
6277
- other.unlinkDoc(this$1)
6278
- detachSharedMarkers(findSharedMarkers(this$1))
6279
- break
6280
- } }
6281
- // If the histories were shared, split them again
6282
- if (other.history == this.history) {
6283
- var splitIds = [other.id]
6284
- linkedDocs(other, function (doc) { return splitIds.push(doc.id); }, true)
6285
- other.history = new History(null)
6286
- other.history.done = copyHistoryArray(this.history.done, splitIds)
6287
- other.history.undone = copyHistoryArray(this.history.undone, splitIds)
6288
- }
6289
- },
6290
- iterLinkedDocs: function(f) {linkedDocs(this, f)},
6291
-
6292
- getMode: function() {return this.mode},
6293
- getEditor: function() {return this.cm},
6294
-
6295
- splitLines: function(str) {
6296
- if (this.lineSep) { return str.split(this.lineSep) }
6297
- return splitLinesAuto(str)
6298
- },
6299
- lineSeparator: function() { return this.lineSep || "\n" },
6300
-
6301
- setDirection: docMethodOp(function (dir) {
6302
- if (dir != "rtl") { dir = "ltr" }
6303
- if (dir == this.direction) { return }
6304
- this.direction = dir
6305
- this.iter(function (line) { return line.order = null; })
6306
- if (this.cm) { directionChanged(this.cm) }
6307
- })
6308
- })
6309
-
6310
- // Public alias.
6311
- Doc.prototype.eachLine = Doc.prototype.iter
6312
-
6313
- // Kludge to work around strange IE behavior where it'll sometimes
6314
- // re-fire a series of drag-related events right after the drop (#1551)
6315
- var lastDrop = 0
6316
-
6317
- function onDrop(e) {
6318
- var cm = this
6319
- clearDragCursor(cm)
6320
- if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e))
6321
- { return }
6322
- e_preventDefault(e)
6323
- if (ie) { lastDrop = +new Date }
6324
- var pos = posFromMouse(cm, e, true), files = e.dataTransfer.files
6325
- if (!pos || cm.isReadOnly()) { return }
6326
- // Might be a file drop, in which case we simply extract the text
6327
- // and insert it.
6328
- if (files && files.length && window.FileReader && window.File) {
6329
- var n = files.length, text = Array(n), read = 0
6330
- var loadFile = function (file, i) {
6331
- if (cm.options.allowDropFileTypes &&
6332
- indexOf(cm.options.allowDropFileTypes, file.type) == -1)
6333
- { return }
6334
-
6335
- var reader = new FileReader
6336
- reader.onload = operation(cm, function () {
6337
- var content = reader.result
6338
- if (/[\x00-\x08\x0e-\x1f]{2}/.test(content)) { content = "" }
6339
- text[i] = content
6340
- if (++read == n) {
6341
- pos = clipPos(cm.doc, pos)
6342
- var change = {from: pos, to: pos,
6343
- text: cm.doc.splitLines(text.join(cm.doc.lineSeparator())),
6344
- origin: "paste"}
6345
- makeChange(cm.doc, change)
6346
- setSelectionReplaceHistory(cm.doc, simpleSelection(pos, changeEnd(change)))
6347
- }
6348
- })
6349
- reader.readAsText(file)
6350
- }
6351
- for (var i = 0; i < n; ++i) { loadFile(files[i], i) }
6352
- } else { // Normal drop
6353
- // Don't do a replace if the drop happened inside of the selected text.
6354
- if (cm.state.draggingText && cm.doc.sel.contains(pos) > -1) {
6355
- cm.state.draggingText(e)
6356
- // Ensure the editor is re-focused
6357
- setTimeout(function () { return cm.display.input.focus(); }, 20)
6358
- return
6359
- }
6360
- try {
6361
- var text$1 = e.dataTransfer.getData("Text")
6362
- if (text$1) {
6363
- var selected
6364
- if (cm.state.draggingText && !cm.state.draggingText.copy)
6365
- { selected = cm.listSelections() }
6366
- setSelectionNoUndo(cm.doc, simpleSelection(pos, pos))
6367
- if (selected) { for (var i$1 = 0; i$1 < selected.length; ++i$1)
6368
- { replaceRange(cm.doc, "", selected[i$1].anchor, selected[i$1].head, "drag") } }
6369
- cm.replaceSelection(text$1, "around", "paste")
6370
- cm.display.input.focus()
6371
- }
6372
- }
6373
- catch(e){}
6374
- }
6375
- }
6376
-
6377
- function onDragStart(cm, e) {
6378
- if (ie && (!cm.state.draggingText || +new Date - lastDrop < 100)) { e_stop(e); return }
6379
- if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e)) { return }
6380
-
6381
- e.dataTransfer.setData("Text", cm.getSelection())
6382
- e.dataTransfer.effectAllowed = "copyMove"
6383
-
6384
- // Use dummy image instead of default browsers image.
6385
- // Recent Safari (~6.0.2) have a tendency to segfault when this happens, so we don't do it there.
6386
- if (e.dataTransfer.setDragImage && !safari) {
6387
- var img = elt("img", null, null, "position: fixed; left: 0; top: 0;")
6388
- img.src = ""
6389
- if (presto) {
6390
- img.width = img.height = 1
6391
- cm.display.wrapper.appendChild(img)
6392
- // Force a relayout, or Opera won't use our image for some obscure reason
6393
- img._top = img.offsetTop
6394
- }
6395
- e.dataTransfer.setDragImage(img, 0, 0)
6396
- if (presto) { img.parentNode.removeChild(img) }
6397
- }
6398
- }
6399
-
6400
- function onDragOver(cm, e) {
6401
- var pos = posFromMouse(cm, e)
6402
- if (!pos) { return }
6403
- var frag = document.createDocumentFragment()
6404
- drawSelectionCursor(cm, pos, frag)
6405
- if (!cm.display.dragCursor) {
6406
- cm.display.dragCursor = elt("div", null, "CodeMirror-cursors CodeMirror-dragcursors")
6407
- cm.display.lineSpace.insertBefore(cm.display.dragCursor, cm.display.cursorDiv)
6408
- }
6409
- removeChildrenAndAdd(cm.display.dragCursor, frag)
6410
- }
6411
-
6412
- function clearDragCursor(cm) {
6413
- if (cm.display.dragCursor) {
6414
- cm.display.lineSpace.removeChild(cm.display.dragCursor)
6415
- cm.display.dragCursor = null
6416
- }
6417
- }
6418
-
6419
- // These must be handled carefully, because naively registering a
6420
- // handler for each editor will cause the editors to never be
6421
- // garbage collected.
6422
-
6423
- function forEachCodeMirror(f) {
6424
- if (!document.body.getElementsByClassName) { return }
6425
- var byClass = document.body.getElementsByClassName("CodeMirror")
6426
- for (var i = 0; i < byClass.length; i++) {
6427
- var cm = byClass[i].CodeMirror
6428
- if (cm) { f(cm) }
6429
- }
6430
- }
6431
-
6432
- var globalsRegistered = false
6433
- function ensureGlobalHandlers() {
6434
- if (globalsRegistered) { return }
6435
- registerGlobalHandlers()
6436
- globalsRegistered = true
6437
- }
6438
- function registerGlobalHandlers() {
6439
- // When the window resizes, we need to refresh active editors.
6440
- var resizeTimer
6441
- on(window, "resize", function () {
6442
- if (resizeTimer == null) { resizeTimer = setTimeout(function () {
6443
- resizeTimer = null
6444
- forEachCodeMirror(onResize)
6445
- }, 100) }
6446
- })
6447
- // When the window loses focus, we want to show the editor as blurred
6448
- on(window, "blur", function () { return forEachCodeMirror(onBlur); })
6449
- }
6450
- // Called when the window resizes
6451
- function onResize(cm) {
6452
- var d = cm.display
6453
- if (d.lastWrapHeight == d.wrapper.clientHeight && d.lastWrapWidth == d.wrapper.clientWidth)
6454
- { return }
6455
- // Might be a text scaling operation, clear size caches.
6456
- d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null
6457
- d.scrollbarsClipped = false
6458
- cm.setSize()
6459
- }
6460
-
6461
- var keyNames = {
6462
- 3: "Enter", 8: "Backspace", 9: "Tab", 13: "Enter", 16: "Shift", 17: "Ctrl", 18: "Alt",
6463
- 19: "Pause", 20: "CapsLock", 27: "Esc", 32: "Space", 33: "PageUp", 34: "PageDown", 35: "End",
6464
- 36: "Home", 37: "Left", 38: "Up", 39: "Right", 40: "Down", 44: "PrintScrn", 45: "Insert",
6465
- 46: "Delete", 59: ";", 61: "=", 91: "Mod", 92: "Mod", 93: "Mod",
6466
- 106: "*", 107: "=", 109: "-", 110: ".", 111: "/", 127: "Delete",
6467
- 173: "-", 186: ";", 187: "=", 188: ",", 189: "-", 190: ".", 191: "/", 192: "`", 219: "[", 220: "\\",
6468
- 221: "]", 222: "'", 63232: "Up", 63233: "Down", 63234: "Left", 63235: "Right", 63272: "Delete",
6469
- 63273: "Home", 63275: "End", 63276: "PageUp", 63277: "PageDown", 63302: "Insert"
6470
- }
6471
-
6472
- // Number keys
6473
- for (var i = 0; i < 10; i++) { keyNames[i + 48] = keyNames[i + 96] = String(i) }
6474
- // Alphabetic keys
6475
- for (var i$1 = 65; i$1 <= 90; i$1++) { keyNames[i$1] = String.fromCharCode(i$1) }
6476
- // Function keys
6477
- for (var i$2 = 1; i$2 <= 12; i$2++) { keyNames[i$2 + 111] = keyNames[i$2 + 63235] = "F" + i$2 }
6478
-
6479
- var keyMap = {}
6480
-
6481
- keyMap.basic = {
6482
- "Left": "goCharLeft", "Right": "goCharRight", "Up": "goLineUp", "Down": "goLineDown",
6483
- "End": "goLineEnd", "Home": "goLineStartSmart", "PageUp": "goPageUp", "PageDown": "goPageDown",
6484
- "Delete": "delCharAfter", "Backspace": "delCharBefore", "Shift-Backspace": "delCharBefore",
6485
- "Tab": "defaultTab", "Shift-Tab": "indentAuto",
6486
- "Enter": "newlineAndIndent", "Insert": "toggleOverwrite",
6487
- "Esc": "singleSelection"
6488
- }
6489
- // Note that the save and find-related commands aren't defined by
6490
- // default. User code or addons can define them. Unknown commands
6491
- // are simply ignored.
6492
- keyMap.pcDefault = {
6493
- "Ctrl-A": "selectAll", "Ctrl-D": "deleteLine", "Ctrl-Z": "undo", "Shift-Ctrl-Z": "redo", "Ctrl-Y": "redo",
6494
- "Ctrl-Home": "goDocStart", "Ctrl-End": "goDocEnd", "Ctrl-Up": "goLineUp", "Ctrl-Down": "goLineDown",
6495
- "Ctrl-Left": "goGroupLeft", "Ctrl-Right": "goGroupRight", "Alt-Left": "goLineStart", "Alt-Right": "goLineEnd",
6496
- "Ctrl-Backspace": "delGroupBefore", "Ctrl-Delete": "delGroupAfter", "Ctrl-S": "save", "Ctrl-F": "find",
6497
- "Ctrl-G": "findNext", "Shift-Ctrl-G": "findPrev", "Shift-Ctrl-F": "replace", "Shift-Ctrl-R": "replaceAll",
6498
- "Ctrl-[": "indentLess", "Ctrl-]": "indentMore",
6499
- "Ctrl-U": "undoSelection", "Shift-Ctrl-U": "redoSelection", "Alt-U": "redoSelection",
6500
- fallthrough: "basic"
6501
- }
6502
- // Very basic readline/emacs-style bindings, which are standard on Mac.
6503
- keyMap.emacsy = {
6504
- "Ctrl-F": "goCharRight", "Ctrl-B": "goCharLeft", "Ctrl-P": "goLineUp", "Ctrl-N": "goLineDown",
6505
- "Alt-F": "goWordRight", "Alt-B": "goWordLeft", "Ctrl-A": "goLineStart", "Ctrl-E": "goLineEnd",
6506
- "Ctrl-V": "goPageDown", "Shift-Ctrl-V": "goPageUp", "Ctrl-D": "delCharAfter", "Ctrl-H": "delCharBefore",
6507
- "Alt-D": "delWordAfter", "Alt-Backspace": "delWordBefore", "Ctrl-K": "killLine", "Ctrl-T": "transposeChars",
6508
- "Ctrl-O": "openLine"
6509
- }
6510
- keyMap.macDefault = {
6511
- "Cmd-A": "selectAll", "Cmd-D": "deleteLine", "Cmd-Z": "undo", "Shift-Cmd-Z": "redo", "Cmd-Y": "redo",
6512
- "Cmd-Home": "goDocStart", "Cmd-Up": "goDocStart", "Cmd-End": "goDocEnd", "Cmd-Down": "goDocEnd", "Alt-Left": "goGroupLeft",
6513
- "Alt-Right": "goGroupRight", "Cmd-Left": "goLineLeft", "Cmd-Right": "goLineRight", "Alt-Backspace": "delGroupBefore",
6514
- "Ctrl-Alt-Backspace": "delGroupAfter", "Alt-Delete": "delGroupAfter", "Cmd-S": "save", "Cmd-F": "find",
6515
- "Cmd-G": "findNext", "Shift-Cmd-G": "findPrev", "Cmd-Alt-F": "replace", "Shift-Cmd-Alt-F": "replaceAll",
6516
- "Cmd-[": "indentLess", "Cmd-]": "indentMore", "Cmd-Backspace": "delWrappedLineLeft", "Cmd-Delete": "delWrappedLineRight",
6517
- "Cmd-U": "undoSelection", "Shift-Cmd-U": "redoSelection", "Ctrl-Up": "goDocStart", "Ctrl-Down": "goDocEnd",
6518
- fallthrough: ["basic", "emacsy"]
6519
- }
6520
- keyMap["default"] = mac ? keyMap.macDefault : keyMap.pcDefault
6521
-
6522
- // KEYMAP DISPATCH
6523
-
6524
- function normalizeKeyName(name) {
6525
- var parts = name.split(/-(?!$)/)
6526
- name = parts[parts.length - 1]
6527
- var alt, ctrl, shift, cmd
6528
- for (var i = 0; i < parts.length - 1; i++) {
6529
- var mod = parts[i]
6530
- if (/^(cmd|meta|m)$/i.test(mod)) { cmd = true }
6531
- else if (/^a(lt)?$/i.test(mod)) { alt = true }
6532
- else if (/^(c|ctrl|control)$/i.test(mod)) { ctrl = true }
6533
- else if (/^s(hift)?$/i.test(mod)) { shift = true }
6534
- else { throw new Error("Unrecognized modifier name: " + mod) }
6535
- }
6536
- if (alt) { name = "Alt-" + name }
6537
- if (ctrl) { name = "Ctrl-" + name }
6538
- if (cmd) { name = "Cmd-" + name }
6539
- if (shift) { name = "Shift-" + name }
6540
- return name
6541
- }
6542
-
6543
- // This is a kludge to keep keymaps mostly working as raw objects
6544
- // (backwards compatibility) while at the same time support features
6545
- // like normalization and multi-stroke key bindings. It compiles a
6546
- // new normalized keymap, and then updates the old object to reflect
6547
- // this.
6548
- function normalizeKeyMap(keymap) {
6549
- var copy = {}
6550
- for (var keyname in keymap) { if (keymap.hasOwnProperty(keyname)) {
6551
- var value = keymap[keyname]
6552
- if (/^(name|fallthrough|(de|at)tach)$/.test(keyname)) { continue }
6553
- if (value == "...") { delete keymap[keyname]; continue }
6554
-
6555
- var keys = map(keyname.split(" "), normalizeKeyName)
6556
- for (var i = 0; i < keys.length; i++) {
6557
- var val = (void 0), name = (void 0)
6558
- if (i == keys.length - 1) {
6559
- name = keys.join(" ")
6560
- val = value
6561
- } else {
6562
- name = keys.slice(0, i + 1).join(" ")
6563
- val = "..."
6564
- }
6565
- var prev = copy[name]
6566
- if (!prev) { copy[name] = val }
6567
- else if (prev != val) { throw new Error("Inconsistent bindings for " + name) }
6568
- }
6569
- delete keymap[keyname]
6570
- } }
6571
- for (var prop in copy) { keymap[prop] = copy[prop] }
6572
- return keymap
6573
- }
6574
-
6575
- function lookupKey(key, map, handle, context) {
6576
- map = getKeyMap(map)
6577
- var found = map.call ? map.call(key, context) : map[key]
6578
- if (found === false) { return "nothing" }
6579
- if (found === "...") { return "multi" }
6580
- if (found != null && handle(found)) { return "handled" }
6581
-
6582
- if (map.fallthrough) {
6583
- if (Object.prototype.toString.call(map.fallthrough) != "[object Array]")
6584
- { return lookupKey(key, map.fallthrough, handle, context) }
6585
- for (var i = 0; i < map.fallthrough.length; i++) {
6586
- var result = lookupKey(key, map.fallthrough[i], handle, context)
6587
- if (result) { return result }
6588
- }
6589
- }
6590
- }
6591
-
6592
- // Modifier key presses don't count as 'real' key presses for the
6593
- // purpose of keymap fallthrough.
6594
- function isModifierKey(value) {
6595
- var name = typeof value == "string" ? value : keyNames[value.keyCode]
6596
- return name == "Ctrl" || name == "Alt" || name == "Shift" || name == "Mod"
6597
- }
6598
-
6599
- // Look up the name of a key as indicated by an event object.
6600
- function keyName(event, noShift) {
6601
- if (presto && event.keyCode == 34 && event["char"]) { return false }
6602
- var base = keyNames[event.keyCode], name = base
6603
- if (name == null || event.altGraphKey) { return false }
6604
- if (event.altKey && base != "Alt") { name = "Alt-" + name }
6605
- if ((flipCtrlCmd ? event.metaKey : event.ctrlKey) && base != "Ctrl") { name = "Ctrl-" + name }
6606
- if ((flipCtrlCmd ? event.ctrlKey : event.metaKey) && base != "Cmd") { name = "Cmd-" + name }
6607
- if (!noShift && event.shiftKey && base != "Shift") { name = "Shift-" + name }
6608
- return name
6609
- }
6610
-
6611
- function getKeyMap(val) {
6612
- return typeof val == "string" ? keyMap[val] : val
6613
- }
6614
-
6615
- // Helper for deleting text near the selection(s), used to implement
6616
- // backspace, delete, and similar functionality.
6617
- function deleteNearSelection(cm, compute) {
6618
- var ranges = cm.doc.sel.ranges, kill = []
6619
- // Build up a set of ranges to kill first, merging overlapping
6620
- // ranges.
6621
- for (var i = 0; i < ranges.length; i++) {
6622
- var toKill = compute(ranges[i])
6623
- while (kill.length && cmp(toKill.from, lst(kill).to) <= 0) {
6624
- var replaced = kill.pop()
6625
- if (cmp(replaced.from, toKill.from) < 0) {
6626
- toKill.from = replaced.from
6627
- break
6628
- }
6629
- }
6630
- kill.push(toKill)
6631
- }
6632
- // Next, remove those actual ranges.
6633
- runInOp(cm, function () {
6634
- for (var i = kill.length - 1; i >= 0; i--)
6635
- { replaceRange(cm.doc, "", kill[i].from, kill[i].to, "+delete") }
6636
- ensureCursorVisible(cm)
6637
- })
6638
- }
6639
-
6640
- // Commands are parameter-less actions that can be performed on an
6641
- // editor, mostly used for keybindings.
6642
- var commands = {
6643
- selectAll: selectAll,
6644
- singleSelection: function (cm) { return cm.setSelection(cm.getCursor("anchor"), cm.getCursor("head"), sel_dontScroll); },
6645
- killLine: function (cm) { return deleteNearSelection(cm, function (range) {
6646
- if (range.empty()) {
6647
- var len = getLine(cm.doc, range.head.line).text.length
6648
- if (range.head.ch == len && range.head.line < cm.lastLine())
6649
- { return {from: range.head, to: Pos(range.head.line + 1, 0)} }
6650
- else
6651
- { return {from: range.head, to: Pos(range.head.line, len)} }
6652
- } else {
6653
- return {from: range.from(), to: range.to()}
6654
- }
6655
- }); },
6656
- deleteLine: function (cm) { return deleteNearSelection(cm, function (range) { return ({
6657
- from: Pos(range.from().line, 0),
6658
- to: clipPos(cm.doc, Pos(range.to().line + 1, 0))
6659
- }); }); },
6660
- delLineLeft: function (cm) { return deleteNearSelection(cm, function (range) { return ({
6661
- from: Pos(range.from().line, 0), to: range.from()
6662
- }); }); },
6663
- delWrappedLineLeft: function (cm) { return deleteNearSelection(cm, function (range) {
6664
- var top = cm.charCoords(range.head, "div").top + 5
6665
- var leftPos = cm.coordsChar({left: 0, top: top}, "div")
6666
- return {from: leftPos, to: range.from()}
6667
- }); },
6668
- delWrappedLineRight: function (cm) { return deleteNearSelection(cm, function (range) {
6669
- var top = cm.charCoords(range.head, "div").top + 5
6670
- var rightPos = cm.coordsChar({left: cm.display.lineDiv.offsetWidth + 100, top: top}, "div")
6671
- return {from: range.from(), to: rightPos }
6672
- }); },
6673
- undo: function (cm) { return cm.undo(); },
6674
- redo: function (cm) { return cm.redo(); },
6675
- undoSelection: function (cm) { return cm.undoSelection(); },
6676
- redoSelection: function (cm) { return cm.redoSelection(); },
6677
- goDocStart: function (cm) { return cm.extendSelection(Pos(cm.firstLine(), 0)); },
6678
- goDocEnd: function (cm) { return cm.extendSelection(Pos(cm.lastLine())); },
6679
- goLineStart: function (cm) { return cm.extendSelectionsBy(function (range) { return lineStart(cm, range.head.line); },
6680
- {origin: "+move", bias: 1}
6681
- ); },
6682
- goLineStartSmart: function (cm) { return cm.extendSelectionsBy(function (range) { return lineStartSmart(cm, range.head); },
6683
- {origin: "+move", bias: 1}
6684
- ); },
6685
- goLineEnd: function (cm) { return cm.extendSelectionsBy(function (range) { return lineEnd(cm, range.head.line); },
6686
- {origin: "+move", bias: -1}
6687
- ); },
6688
- goLineRight: function (cm) { return cm.extendSelectionsBy(function (range) {
6689
- var top = cm.charCoords(range.head, "div").top + 5
6690
- return cm.coordsChar({left: cm.display.lineDiv.offsetWidth + 100, top: top}, "div")
6691
- }, sel_move); },
6692
- goLineLeft: function (cm) { return cm.extendSelectionsBy(function (range) {
6693
- var top = cm.charCoords(range.head, "div").top + 5
6694
- return cm.coordsChar({left: 0, top: top}, "div")
6695
- }, sel_move); },
6696
- goLineLeftSmart: function (cm) { return cm.extendSelectionsBy(function (range) {
6697
- var top = cm.charCoords(range.head, "div").top + 5
6698
- var pos = cm.coordsChar({left: 0, top: top}, "div")
6699
- if (pos.ch < cm.getLine(pos.line).search(/\S/)) { return lineStartSmart(cm, range.head) }
6700
- return pos
6701
- }, sel_move); },
6702
- goLineUp: function (cm) { return cm.moveV(-1, "line"); },
6703
- goLineDown: function (cm) { return cm.moveV(1, "line"); },
6704
- goPageUp: function (cm) { return cm.moveV(-1, "page"); },
6705
- goPageDown: function (cm) { return cm.moveV(1, "page"); },
6706
- goCharLeft: function (cm) { return cm.moveH(-1, "char"); },
6707
- goCharRight: function (cm) { return cm.moveH(1, "char"); },
6708
- goColumnLeft: function (cm) { return cm.moveH(-1, "column"); },
6709
- goColumnRight: function (cm) { return cm.moveH(1, "column"); },
6710
- goWordLeft: function (cm) { return cm.moveH(-1, "word"); },
6711
- goGroupRight: function (cm) { return cm.moveH(1, "group"); },
6712
- goGroupLeft: function (cm) { return cm.moveH(-1, "group"); },
6713
- goWordRight: function (cm) { return cm.moveH(1, "word"); },
6714
- delCharBefore: function (cm) { return cm.deleteH(-1, "char"); },
6715
- delCharAfter: function (cm) { return cm.deleteH(1, "char"); },
6716
- delWordBefore: function (cm) { return cm.deleteH(-1, "word"); },
6717
- delWordAfter: function (cm) { return cm.deleteH(1, "word"); },
6718
- delGroupBefore: function (cm) { return cm.deleteH(-1, "group"); },
6719
- delGroupAfter: function (cm) { return cm.deleteH(1, "group"); },
6720
- indentAuto: function (cm) { return cm.indentSelection("smart"); },
6721
- indentMore: function (cm) { return cm.indentSelection("add"); },
6722
- indentLess: function (cm) { return cm.indentSelection("subtract"); },
6723
- insertTab: function (cm) { return cm.replaceSelection("\t"); },
6724
- insertSoftTab: function (cm) {
6725
- var spaces = [], ranges = cm.listSelections(), tabSize = cm.options.tabSize
6726
- for (var i = 0; i < ranges.length; i++) {
6727
- var pos = ranges[i].from()
6728
- var col = countColumn(cm.getLine(pos.line), pos.ch, tabSize)
6729
- spaces.push(spaceStr(tabSize - col % tabSize))
6730
- }
6731
- cm.replaceSelections(spaces)
6732
- },
6733
- defaultTab: function (cm) {
6734
- if (cm.somethingSelected()) { cm.indentSelection("add") }
6735
- else { cm.execCommand("insertTab") }
6736
- },
6737
- // Swap the two chars left and right of each selection's head.
6738
- // Move cursor behind the two swapped characters afterwards.
6739
- //
6740
- // Doesn't consider line feeds a character.
6741
- // Doesn't scan more than one line above to find a character.
6742
- // Doesn't do anything on an empty line.
6743
- // Doesn't do anything with non-empty selections.
6744
- transposeChars: function (cm) { return runInOp(cm, function () {
6745
- var ranges = cm.listSelections(), newSel = []
6746
- for (var i = 0; i < ranges.length; i++) {
6747
- if (!ranges[i].empty()) { continue }
6748
- var cur = ranges[i].head, line = getLine(cm.doc, cur.line).text
6749
- if (line) {
6750
- if (cur.ch == line.length) { cur = new Pos(cur.line, cur.ch - 1) }
6751
- if (cur.ch > 0) {
6752
- cur = new Pos(cur.line, cur.ch + 1)
6753
- cm.replaceRange(line.charAt(cur.ch - 1) + line.charAt(cur.ch - 2),
6754
- Pos(cur.line, cur.ch - 2), cur, "+transpose")
6755
- } else if (cur.line > cm.doc.first) {
6756
- var prev = getLine(cm.doc, cur.line - 1).text
6757
- if (prev) {
6758
- cur = new Pos(cur.line, 1)
6759
- cm.replaceRange(line.charAt(0) + cm.doc.lineSeparator() +
6760
- prev.charAt(prev.length - 1),
6761
- Pos(cur.line - 1, prev.length - 1), cur, "+transpose")
6762
- }
6763
- }
6764
- }
6765
- newSel.push(new Range(cur, cur))
6766
- }
6767
- cm.setSelections(newSel)
6768
- }); },
6769
- newlineAndIndent: function (cm) { return runInOp(cm, function () {
6770
- var sels = cm.listSelections()
6771
- for (var i = sels.length - 1; i >= 0; i--)
6772
- { cm.replaceRange(cm.doc.lineSeparator(), sels[i].anchor, sels[i].head, "+input") }
6773
- sels = cm.listSelections()
6774
- for (var i$1 = 0; i$1 < sels.length; i$1++)
6775
- { cm.indentLine(sels[i$1].from().line, null, true) }
6776
- ensureCursorVisible(cm)
6777
- }); },
6778
- openLine: function (cm) { return cm.replaceSelection("\n", "start"); },
6779
- toggleOverwrite: function (cm) { return cm.toggleOverwrite(); }
6780
- }
6781
-
6782
-
6783
- function lineStart(cm, lineN) {
6784
- var line = getLine(cm.doc, lineN)
6785
- var visual = visualLine(line)
6786
- if (visual != line) { lineN = lineNo(visual) }
6787
- return endOfLine(true, cm, visual, lineN, 1)
6788
- }
6789
- function lineEnd(cm, lineN) {
6790
- var line = getLine(cm.doc, lineN)
6791
- var visual = visualLineEnd(line)
6792
- if (visual != line) { lineN = lineNo(visual) }
6793
- return endOfLine(true, cm, line, lineN, -1)
6794
- }
6795
- function lineStartSmart(cm, pos) {
6796
- var start = lineStart(cm, pos.line)
6797
- var line = getLine(cm.doc, start.line)
6798
- var order = getOrder(line, cm.doc.direction)
6799
- if (!order || order[0].level == 0) {
6800
- var firstNonWS = Math.max(0, line.text.search(/\S/))
6801
- var inWS = pos.line == start.line && pos.ch <= firstNonWS && pos.ch
6802
- return Pos(start.line, inWS ? 0 : firstNonWS, start.sticky)
6803
- }
6804
- return start
6805
- }
6806
-
6807
- // Run a handler that was bound to a key.
6808
- function doHandleBinding(cm, bound, dropShift) {
6809
- if (typeof bound == "string") {
6810
- bound = commands[bound]
6811
- if (!bound) { return false }
6812
- }
6813
- // Ensure previous input has been read, so that the handler sees a
6814
- // consistent view of the document
6815
- cm.display.input.ensurePolled()
6816
- var prevShift = cm.display.shift, done = false
6817
- try {
6818
- if (cm.isReadOnly()) { cm.state.suppressEdits = true }
6819
- if (dropShift) { cm.display.shift = false }
6820
- done = bound(cm) != Pass
6821
- } finally {
6822
- cm.display.shift = prevShift
6823
- cm.state.suppressEdits = false
6824
- }
6825
- return done
6826
- }
6827
-
6828
- function lookupKeyForEditor(cm, name, handle) {
6829
- for (var i = 0; i < cm.state.keyMaps.length; i++) {
6830
- var result = lookupKey(name, cm.state.keyMaps[i], handle, cm)
6831
- if (result) { return result }
6832
- }
6833
- return (cm.options.extraKeys && lookupKey(name, cm.options.extraKeys, handle, cm))
6834
- || lookupKey(name, cm.options.keyMap, handle, cm)
6835
- }
6836
-
6837
- var stopSeq = new Delayed
6838
- function dispatchKey(cm, name, e, handle) {
6839
- var seq = cm.state.keySeq
6840
- if (seq) {
6841
- if (isModifierKey(name)) { return "handled" }
6842
- stopSeq.set(50, function () {
6843
- if (cm.state.keySeq == seq) {
6844
- cm.state.keySeq = null
6845
- cm.display.input.reset()
6846
- }
6847
- })
6848
- name = seq + " " + name
6849
- }
6850
- var result = lookupKeyForEditor(cm, name, handle)
6851
-
6852
- if (result == "multi")
6853
- { cm.state.keySeq = name }
6854
- if (result == "handled")
6855
- { signalLater(cm, "keyHandled", cm, name, e) }
6856
-
6857
- if (result == "handled" || result == "multi") {
6858
- e_preventDefault(e)
6859
- restartBlink(cm)
6860
- }
6861
-
6862
- if (seq && !result && /\'$/.test(name)) {
6863
- e_preventDefault(e)
6864
- return true
6865
- }
6866
- return !!result
6867
- }
6868
-
6869
- // Handle a key from the keydown event.
6870
- function handleKeyBinding(cm, e) {
6871
- var name = keyName(e, true)
6872
- if (!name) { return false }
6873
-
6874
- if (e.shiftKey && !cm.state.keySeq) {
6875
- // First try to resolve full name (including 'Shift-'). Failing
6876
- // that, see if there is a cursor-motion command (starting with
6877
- // 'go') bound to the keyname without 'Shift-'.
6878
- return dispatchKey(cm, "Shift-" + name, e, function (b) { return doHandleBinding(cm, b, true); })
6879
- || dispatchKey(cm, name, e, function (b) {
6880
- if (typeof b == "string" ? /^go[A-Z]/.test(b) : b.motion)
6881
- { return doHandleBinding(cm, b) }
6882
- })
6883
- } else {
6884
- return dispatchKey(cm, name, e, function (b) { return doHandleBinding(cm, b); })
6885
- }
6886
- }
6887
-
6888
- // Handle a key from the keypress event
6889
- function handleCharBinding(cm, e, ch) {
6890
- return dispatchKey(cm, "'" + ch + "'", e, function (b) { return doHandleBinding(cm, b, true); })
6891
- }
6892
-
6893
- var lastStoppedKey = null
6894
- function onKeyDown(e) {
6895
- var cm = this
6896
- cm.curOp.focus = activeElt()
6897
- if (signalDOMEvent(cm, e)) { return }
6898
- // IE does strange things with escape.
6899
- if (ie && ie_version < 11 && e.keyCode == 27) { e.returnValue = false }
6900
- var code = e.keyCode
6901
- cm.display.shift = code == 16 || e.shiftKey
6902
- var handled = handleKeyBinding(cm, e)
6903
- if (presto) {
6904
- lastStoppedKey = handled ? code : null
6905
- // Opera has no cut event... we try to at least catch the key combo
6906
- if (!handled && code == 88 && !hasCopyEvent && (mac ? e.metaKey : e.ctrlKey))
6907
- { cm.replaceSelection("", null, "cut") }
6908
- }
6909
-
6910
- // Turn mouse into crosshair when Alt is held on Mac.
6911
- if (code == 18 && !/\bCodeMirror-crosshair\b/.test(cm.display.lineDiv.className))
6912
- { showCrossHair(cm) }
6913
- }
6914
-
6915
- function showCrossHair(cm) {
6916
- var lineDiv = cm.display.lineDiv
6917
- addClass(lineDiv, "CodeMirror-crosshair")
6918
-
6919
- function up(e) {
6920
- if (e.keyCode == 18 || !e.altKey) {
6921
- rmClass(lineDiv, "CodeMirror-crosshair")
6922
- off(document, "keyup", up)
6923
- off(document, "mouseover", up)
6924
- }
6925
- }
6926
- on(document, "keyup", up)
6927
- on(document, "mouseover", up)
6928
- }
6929
-
6930
- function onKeyUp(e) {
6931
- if (e.keyCode == 16) { this.doc.sel.shift = false }
6932
- signalDOMEvent(this, e)
6933
- }
6934
-
6935
- function onKeyPress(e) {
6936
- var cm = this
6937
- if (eventInWidget(cm.display, e) || signalDOMEvent(cm, e) || e.ctrlKey && !e.altKey || mac && e.metaKey) { return }
6938
- var keyCode = e.keyCode, charCode = e.charCode
6939
- if (presto && keyCode == lastStoppedKey) {lastStoppedKey = null; e_preventDefault(e); return}
6940
- if ((presto && (!e.which || e.which < 10)) && handleKeyBinding(cm, e)) { return }
6941
- var ch = String.fromCharCode(charCode == null ? keyCode : charCode)
6942
- // Some browsers fire keypress events for backspace
6943
- if (ch == "\x08") { return }
6944
- if (handleCharBinding(cm, e, ch)) { return }
6945
- cm.display.input.onKeyPress(e)
6946
- }
6947
-
6948
- // A mouse down can be a single click, double click, triple click,
6949
- // start of selection drag, start of text drag, new cursor
6950
- // (ctrl-click), rectangle drag (alt-drag), or xwin
6951
- // middle-click-paste. Or it might be a click on something we should
6952
- // not interfere with, such as a scrollbar or widget.
6953
- function onMouseDown(e) {
6954
- var cm = this, display = cm.display
6955
- if (signalDOMEvent(cm, e) || display.activeTouch && display.input.supportsTouch()) { return }
6956
- display.input.ensurePolled()
6957
- display.shift = e.shiftKey
6958
-
6959
- if (eventInWidget(display, e)) {
6960
- if (!webkit) {
6961
- // Briefly turn off draggability, to allow widgets to do
6962
- // normal dragging things.
6963
- display.scroller.draggable = false
6964
- setTimeout(function () { return display.scroller.draggable = true; }, 100)
6965
- }
6966
- return
6967
- }
6968
- if (clickInGutter(cm, e)) { return }
6969
- var start = posFromMouse(cm, e)
6970
- window.focus()
6971
-
6972
- switch (e_button(e)) {
6973
- case 1:
6974
- // #3261: make sure, that we're not starting a second selection
6975
- if (cm.state.selectingText)
6976
- { cm.state.selectingText(e) }
6977
- else if (start)
6978
- { leftButtonDown(cm, e, start) }
6979
- else if (e_target(e) == display.scroller)
6980
- { e_preventDefault(e) }
6981
- break
6982
- case 2:
6983
- if (webkit) { cm.state.lastMiddleDown = +new Date }
6984
- if (start) { extendSelection(cm.doc, start) }
6985
- setTimeout(function () { return display.input.focus(); }, 20)
6986
- e_preventDefault(e)
6987
- break
6988
- case 3:
6989
- if (captureRightClick) { onContextMenu(cm, e) }
6990
- else { delayBlurEvent(cm) }
6991
- break
6992
- }
6993
- }
6994
-
6995
- var lastClick;
6996
- var lastDoubleClick;
6997
- function leftButtonDown(cm, e, start) {
6998
- if (ie) { setTimeout(bind(ensureFocus, cm), 0) }
6999
- else { cm.curOp.focus = activeElt() }
7000
-
7001
- var now = +new Date, type
7002
- if (lastDoubleClick && lastDoubleClick.time > now - 400 && cmp(lastDoubleClick.pos, start) == 0) {
7003
- type = "triple"
7004
- } else if (lastClick && lastClick.time > now - 400 && cmp(lastClick.pos, start) == 0) {
7005
- type = "double"
7006
- lastDoubleClick = {time: now, pos: start}
7007
- } else {
7008
- type = "single"
7009
- lastClick = {time: now, pos: start}
7010
- }
7011
-
7012
- var sel = cm.doc.sel, modifier = mac ? e.metaKey : e.ctrlKey, contained
7013
- if (cm.options.dragDrop && dragAndDrop && !cm.isReadOnly() &&
7014
- type == "single" && (contained = sel.contains(start)) > -1 &&
7015
- (cmp((contained = sel.ranges[contained]).from(), start) < 0 || start.xRel > 0) &&
7016
- (cmp(contained.to(), start) > 0 || start.xRel < 0))
7017
- { leftButtonStartDrag(cm, e, start, modifier) }
7018
- else
7019
- { leftButtonSelect(cm, e, start, type, modifier) }
7020
- }
7021
-
7022
- // Start a text drag. When it ends, see if any dragging actually
7023
- // happen, and treat as a click if it didn't.
7024
- function leftButtonStartDrag(cm, e, start, modifier) {
7025
- var display = cm.display, moved = false
7026
- var dragEnd = operation(cm, function (e) {
7027
- if (webkit) { display.scroller.draggable = false }
7028
- cm.state.draggingText = false
7029
- off(document, "mouseup", dragEnd)
7030
- off(document, "mousemove", mouseMove)
7031
- off(display.scroller, "dragstart", dragStart)
7032
- off(display.scroller, "drop", dragEnd)
7033
- if (!moved) {
7034
- e_preventDefault(e)
7035
- if (!modifier)
7036
- { extendSelection(cm.doc, start) }
7037
- // Work around unexplainable focus problem in IE9 (#2127) and Chrome (#3081)
7038
- if (webkit || ie && ie_version == 9)
7039
- { setTimeout(function () {document.body.focus(); display.input.focus()}, 20) }
7040
- else
7041
- { display.input.focus() }
7042
- }
7043
- })
7044
- var mouseMove = function(e2) {
7045
- moved = moved || Math.abs(e.clientX - e2.clientX) + Math.abs(e.clientY - e2.clientY) >= 10
7046
- }
7047
- var dragStart = function () { return moved = true; }
7048
- // Let the drag handler handle this.
7049
- if (webkit) { display.scroller.draggable = true }
7050
- cm.state.draggingText = dragEnd
7051
- dragEnd.copy = mac ? e.altKey : e.ctrlKey
7052
- // IE's approach to draggable
7053
- if (display.scroller.dragDrop) { display.scroller.dragDrop() }
7054
- on(document, "mouseup", dragEnd)
7055
- on(document, "mousemove", mouseMove)
7056
- on(display.scroller, "dragstart", dragStart)
7057
- on(display.scroller, "drop", dragEnd)
7058
-
7059
- delayBlurEvent(cm)
7060
- setTimeout(function () { return display.input.focus(); }, 20)
7061
- }
7062
-
7063
- // Normal selection, as opposed to text dragging.
7064
- function leftButtonSelect(cm, e, start, type, addNew) {
7065
- var display = cm.display, doc = cm.doc
7066
- e_preventDefault(e)
7067
-
7068
- var ourRange, ourIndex, startSel = doc.sel, ranges = startSel.ranges
7069
- if (addNew && !e.shiftKey) {
7070
- ourIndex = doc.sel.contains(start)
7071
- if (ourIndex > -1)
7072
- { ourRange = ranges[ourIndex] }
7073
- else
7074
- { ourRange = new Range(start, start) }
7075
- } else {
7076
- ourRange = doc.sel.primary()
7077
- ourIndex = doc.sel.primIndex
7078
- }
7079
-
7080
- if (chromeOS ? e.shiftKey && e.metaKey : e.altKey) {
7081
- type = "rect"
7082
- if (!addNew) { ourRange = new Range(start, start) }
7083
- start = posFromMouse(cm, e, true, true)
7084
- ourIndex = -1
7085
- } else if (type == "double") {
7086
- var word = cm.findWordAt(start)
7087
- if (cm.display.shift || doc.extend)
7088
- { ourRange = extendRange(doc, ourRange, word.anchor, word.head) }
7089
- else
7090
- { ourRange = word }
7091
- } else if (type == "triple") {
7092
- var line = new Range(Pos(start.line, 0), clipPos(doc, Pos(start.line + 1, 0)))
7093
- if (cm.display.shift || doc.extend)
7094
- { ourRange = extendRange(doc, ourRange, line.anchor, line.head) }
7095
- else
7096
- { ourRange = line }
7097
- } else {
7098
- ourRange = extendRange(doc, ourRange, start)
7099
- }
7100
-
7101
- if (!addNew) {
7102
- ourIndex = 0
7103
- setSelection(doc, new Selection([ourRange], 0), sel_mouse)
7104
- startSel = doc.sel
7105
- } else if (ourIndex == -1) {
7106
- ourIndex = ranges.length
7107
- setSelection(doc, normalizeSelection(ranges.concat([ourRange]), ourIndex),
7108
- {scroll: false, origin: "*mouse"})
7109
- } else if (ranges.length > 1 && ranges[ourIndex].empty() && type == "single" && !e.shiftKey) {
7110
- setSelection(doc, normalizeSelection(ranges.slice(0, ourIndex).concat(ranges.slice(ourIndex + 1)), 0),
7111
- {scroll: false, origin: "*mouse"})
7112
- startSel = doc.sel
7113
- } else {
7114
- replaceOneSelection(doc, ourIndex, ourRange, sel_mouse)
7115
- }
7116
-
7117
- var lastPos = start
7118
- function extendTo(pos) {
7119
- if (cmp(lastPos, pos) == 0) { return }
7120
- lastPos = pos
7121
-
7122
- if (type == "rect") {
7123
- var ranges = [], tabSize = cm.options.tabSize
7124
- var startCol = countColumn(getLine(doc, start.line).text, start.ch, tabSize)
7125
- var posCol = countColumn(getLine(doc, pos.line).text, pos.ch, tabSize)
7126
- var left = Math.min(startCol, posCol), right = Math.max(startCol, posCol)
7127
- for (var line = Math.min(start.line, pos.line), end = Math.min(cm.lastLine(), Math.max(start.line, pos.line));
7128
- line <= end; line++) {
7129
- var text = getLine(doc, line).text, leftPos = findColumn(text, left, tabSize)
7130
- if (left == right)
7131
- { ranges.push(new Range(Pos(line, leftPos), Pos(line, leftPos))) }
7132
- else if (text.length > leftPos)
7133
- { ranges.push(new Range(Pos(line, leftPos), Pos(line, findColumn(text, right, tabSize)))) }
7134
- }
7135
- if (!ranges.length) { ranges.push(new Range(start, start)) }
7136
- setSelection(doc, normalizeSelection(startSel.ranges.slice(0, ourIndex).concat(ranges), ourIndex),
7137
- {origin: "*mouse", scroll: false})
7138
- cm.scrollIntoView(pos)
7139
- } else {
7140
- var oldRange = ourRange
7141
- var anchor = oldRange.anchor, head = pos
7142
- if (type != "single") {
7143
- var range
7144
- if (type == "double")
7145
- { range = cm.findWordAt(pos) }
7146
- else
7147
- { range = new Range(Pos(pos.line, 0), clipPos(doc, Pos(pos.line + 1, 0))) }
7148
- if (cmp(range.anchor, anchor) > 0) {
7149
- head = range.head
7150
- anchor = minPos(oldRange.from(), range.anchor)
7151
- } else {
7152
- head = range.anchor
7153
- anchor = maxPos(oldRange.to(), range.head)
7154
- }
7155
- }
7156
- var ranges$1 = startSel.ranges.slice(0)
7157
- ranges$1[ourIndex] = new Range(clipPos(doc, anchor), head)
7158
- setSelection(doc, normalizeSelection(ranges$1, ourIndex), sel_mouse)
7159
- }
7160
- }
7161
-
7162
- var editorSize = display.wrapper.getBoundingClientRect()
7163
- // Used to ensure timeout re-tries don't fire when another extend
7164
- // happened in the meantime (clearTimeout isn't reliable -- at
7165
- // least on Chrome, the timeouts still happen even when cleared,
7166
- // if the clear happens after their scheduled firing time).
7167
- var counter = 0
7168
-
7169
- function extend(e) {
7170
- var curCount = ++counter
7171
- var cur = posFromMouse(cm, e, true, type == "rect")
7172
- if (!cur) { return }
7173
- if (cmp(cur, lastPos) != 0) {
7174
- cm.curOp.focus = activeElt()
7175
- extendTo(cur)
7176
- var visible = visibleLines(display, doc)
7177
- if (cur.line >= visible.to || cur.line < visible.from)
7178
- { setTimeout(operation(cm, function () {if (counter == curCount) { extend(e) }}), 150) }
7179
- } else {
7180
- var outside = e.clientY < editorSize.top ? -20 : e.clientY > editorSize.bottom ? 20 : 0
7181
- if (outside) { setTimeout(operation(cm, function () {
7182
- if (counter != curCount) { return }
7183
- display.scroller.scrollTop += outside
7184
- extend(e)
7185
- }), 50) }
7186
- }
7187
- }
7188
-
7189
- function done(e) {
7190
- cm.state.selectingText = false
7191
- counter = Infinity
7192
- e_preventDefault(e)
7193
- display.input.focus()
7194
- off(document, "mousemove", move)
7195
- off(document, "mouseup", up)
7196
- doc.history.lastSelOrigin = null
7197
- }
7198
-
7199
- var move = operation(cm, function (e) {
7200
- if (!e_button(e)) { done(e) }
7201
- else { extend(e) }
7202
- })
7203
- var up = operation(cm, done)
7204
- cm.state.selectingText = up
7205
- on(document, "mousemove", move)
7206
- on(document, "mouseup", up)
7207
- }
7208
-
7209
-
7210
- // Determines whether an event happened in the gutter, and fires the
7211
- // handlers for the corresponding event.
7212
- function gutterEvent(cm, e, type, prevent) {
7213
- var mX, mY
7214
- try { mX = e.clientX; mY = e.clientY }
7215
- catch(e) { return false }
7216
- if (mX >= Math.floor(cm.display.gutters.getBoundingClientRect().right)) { return false }
7217
- if (prevent) { e_preventDefault(e) }
7218
-
7219
- var display = cm.display
7220
- var lineBox = display.lineDiv.getBoundingClientRect()
7221
-
7222
- if (mY > lineBox.bottom || !hasHandler(cm, type)) { return e_defaultPrevented(e) }
7223
- mY -= lineBox.top - display.viewOffset
7224
-
7225
- for (var i = 0; i < cm.options.gutters.length; ++i) {
7226
- var g = display.gutters.childNodes[i]
7227
- if (g && g.getBoundingClientRect().right >= mX) {
7228
- var line = lineAtHeight(cm.doc, mY)
7229
- var gutter = cm.options.gutters[i]
7230
- signal(cm, type, cm, line, gutter, e)
7231
- return e_defaultPrevented(e)
7232
- }
7233
- }
7234
- }
7235
-
7236
- function clickInGutter(cm, e) {
7237
- return gutterEvent(cm, e, "gutterClick", true)
7238
- }
7239
-
7240
- // CONTEXT MENU HANDLING
7241
-
7242
- // To make the context menu work, we need to briefly unhide the
7243
- // textarea (making it as unobtrusive as possible) to let the
7244
- // right-click take effect on it.
7245
- function onContextMenu(cm, e) {
7246
- if (eventInWidget(cm.display, e) || contextMenuInGutter(cm, e)) { return }
7247
- if (signalDOMEvent(cm, e, "contextmenu")) { return }
7248
- cm.display.input.onContextMenu(e)
7249
- }
7250
-
7251
- function contextMenuInGutter(cm, e) {
7252
- if (!hasHandler(cm, "gutterContextMenu")) { return false }
7253
- return gutterEvent(cm, e, "gutterContextMenu", false)
7254
- }
7255
-
7256
- function themeChanged(cm) {
7257
- cm.display.wrapper.className = cm.display.wrapper.className.replace(/\s*cm-s-\S+/g, "") +
7258
- cm.options.theme.replace(/(^|\s)\s*/g, " cm-s-")
7259
- clearCaches(cm)
7260
- }
7261
-
7262
- var Init = {toString: function(){return "CodeMirror.Init"}}
7263
-
7264
- var defaults = {}
7265
- var optionHandlers = {}
7266
-
7267
- function defineOptions(CodeMirror) {
7268
- var optionHandlers = CodeMirror.optionHandlers
7269
-
7270
- function option(name, deflt, handle, notOnInit) {
7271
- CodeMirror.defaults[name] = deflt
7272
- if (handle) { optionHandlers[name] =
7273
- notOnInit ? function (cm, val, old) {if (old != Init) { handle(cm, val, old) }} : handle }
7274
- }
7275
-
7276
- CodeMirror.defineOption = option
7277
-
7278
- // Passed to option handlers when there is no old value.
7279
- CodeMirror.Init = Init
7280
-
7281
- // These two are, on init, called from the constructor because they
7282
- // have to be initialized before the editor can start at all.
7283
- option("value", "", function (cm, val) { return cm.setValue(val); }, true)
7284
- option("mode", null, function (cm, val) {
7285
- cm.doc.modeOption = val
7286
- loadMode(cm)
7287
- }, true)
7288
-
7289
- option("indentUnit", 2, loadMode, true)
7290
- option("indentWithTabs", false)
7291
- option("smartIndent", true)
7292
- option("tabSize", 4, function (cm) {
7293
- resetModeState(cm)
7294
- clearCaches(cm)
7295
- regChange(cm)
7296
- }, true)
7297
- option("lineSeparator", null, function (cm, val) {
7298
- cm.doc.lineSep = val
7299
- if (!val) { return }
7300
- var newBreaks = [], lineNo = cm.doc.first
7301
- cm.doc.iter(function (line) {
7302
- for (var pos = 0;;) {
7303
- var found = line.text.indexOf(val, pos)
7304
- if (found == -1) { break }
7305
- pos = found + val.length
7306
- newBreaks.push(Pos(lineNo, found))
7307
- }
7308
- lineNo++
7309
- })
7310
- for (var i = newBreaks.length - 1; i >= 0; i--)
7311
- { replaceRange(cm.doc, val, newBreaks[i], Pos(newBreaks[i].line, newBreaks[i].ch + val.length)) }
7312
- })
7313
- option("specialChars", /[\u0000-\u001f\u007f-\u009f\u00ad\u061c\u200b-\u200f\u2028\u2029\ufeff]/g, function (cm, val, old) {
7314
- cm.state.specialChars = new RegExp(val.source + (val.test("\t") ? "" : "|\t"), "g")
7315
- if (old != Init) { cm.refresh() }
7316
- })
7317
- option("specialCharPlaceholder", defaultSpecialCharPlaceholder, function (cm) { return cm.refresh(); }, true)
7318
- option("electricChars", true)
7319
- option("inputStyle", mobile ? "contenteditable" : "textarea", function () {
7320
- throw new Error("inputStyle can not (yet) be changed in a running editor") // FIXME
7321
- }, true)
7322
- option("spellcheck", false, function (cm, val) { return cm.getInputField().spellcheck = val; }, true)
7323
- option("rtlMoveVisually", !windows)
7324
- option("wholeLineUpdateBefore", true)
7325
-
7326
- option("theme", "default", function (cm) {
7327
- themeChanged(cm)
7328
- guttersChanged(cm)
7329
- }, true)
7330
- option("keyMap", "default", function (cm, val, old) {
7331
- var next = getKeyMap(val)
7332
- var prev = old != Init && getKeyMap(old)
7333
- if (prev && prev.detach) { prev.detach(cm, next) }
7334
- if (next.attach) { next.attach(cm, prev || null) }
7335
- })
7336
- option("extraKeys", null)
7337
-
7338
- option("lineWrapping", false, wrappingChanged, true)
7339
- option("gutters", [], function (cm) {
7340
- setGuttersForLineNumbers(cm.options)
7341
- guttersChanged(cm)
7342
- }, true)
7343
- option("fixedGutter", true, function (cm, val) {
7344
- cm.display.gutters.style.left = val ? compensateForHScroll(cm.display) + "px" : "0"
7345
- cm.refresh()
7346
- }, true)
7347
- option("coverGutterNextToScrollbar", false, function (cm) { return updateScrollbars(cm); }, true)
7348
- option("scrollbarStyle", "native", function (cm) {
7349
- initScrollbars(cm)
7350
- updateScrollbars(cm)
7351
- cm.display.scrollbars.setScrollTop(cm.doc.scrollTop)
7352
- cm.display.scrollbars.setScrollLeft(cm.doc.scrollLeft)
7353
- }, true)
7354
- option("lineNumbers", false, function (cm) {
7355
- setGuttersForLineNumbers(cm.options)
7356
- guttersChanged(cm)
7357
- }, true)
7358
- option("firstLineNumber", 1, guttersChanged, true)
7359
- option("lineNumberFormatter", function (integer) { return integer; }, guttersChanged, true)
7360
- option("showCursorWhenSelecting", false, updateSelection, true)
7361
-
7362
- option("resetSelectionOnContextMenu", true)
7363
- option("lineWiseCopyCut", true)
7364
-
7365
- option("readOnly", false, function (cm, val) {
7366
- if (val == "nocursor") {
7367
- onBlur(cm)
7368
- cm.display.input.blur()
7369
- cm.display.disabled = true
7370
- } else {
7371
- cm.display.disabled = false
7372
- }
7373
- cm.display.input.readOnlyChanged(val)
7374
- })
7375
- option("disableInput", false, function (cm, val) {if (!val) { cm.display.input.reset() }}, true)
7376
- option("dragDrop", true, dragDropChanged)
7377
- option("allowDropFileTypes", null)
7378
-
7379
- option("cursorBlinkRate", 530)
7380
- option("cursorScrollMargin", 0)
7381
- option("cursorHeight", 1, updateSelection, true)
7382
- option("singleCursorHeightPerLine", true, updateSelection, true)
7383
- option("workTime", 100)
7384
- option("workDelay", 100)
7385
- option("flattenSpans", true, resetModeState, true)
7386
- option("addModeClass", false, resetModeState, true)
7387
- option("pollInterval", 100)
7388
- option("undoDepth", 200, function (cm, val) { return cm.doc.history.undoDepth = val; })
7389
- option("historyEventDelay", 1250)
7390
- option("viewportMargin", 10, function (cm) { return cm.refresh(); }, true)
7391
- option("maxHighlightLength", 10000, resetModeState, true)
7392
- option("moveInputWithCursor", true, function (cm, val) {
7393
- if (!val) { cm.display.input.resetPosition() }
7394
- })
7395
-
7396
- option("tabindex", null, function (cm, val) { return cm.display.input.getField().tabIndex = val || ""; })
7397
- option("autofocus", null)
7398
- option("direction", "ltr", function (cm, val) { return cm.doc.setDirection(val); }, true)
7399
- }
7400
-
7401
- function guttersChanged(cm) {
7402
- updateGutters(cm)
7403
- regChange(cm)
7404
- alignHorizontally(cm)
7405
- }
7406
-
7407
- function dragDropChanged(cm, value, old) {
7408
- var wasOn = old && old != Init
7409
- if (!value != !wasOn) {
7410
- var funcs = cm.display.dragFunctions
7411
- var toggle = value ? on : off
7412
- toggle(cm.display.scroller, "dragstart", funcs.start)
7413
- toggle(cm.display.scroller, "dragenter", funcs.enter)
7414
- toggle(cm.display.scroller, "dragover", funcs.over)
7415
- toggle(cm.display.scroller, "dragleave", funcs.leave)
7416
- toggle(cm.display.scroller, "drop", funcs.drop)
7417
- }
7418
- }
7419
-
7420
- function wrappingChanged(cm) {
7421
- if (cm.options.lineWrapping) {
7422
- addClass(cm.display.wrapper, "CodeMirror-wrap")
7423
- cm.display.sizer.style.minWidth = ""
7424
- cm.display.sizerWidth = null
7425
- } else {
7426
- rmClass(cm.display.wrapper, "CodeMirror-wrap")
7427
- findMaxLine(cm)
7428
- }
7429
- estimateLineHeights(cm)
7430
- regChange(cm)
7431
- clearCaches(cm)
7432
- setTimeout(function () { return updateScrollbars(cm); }, 100)
7433
- }
7434
-
7435
- // A CodeMirror instance represents an editor. This is the object
7436
- // that user code is usually dealing with.
7437
-
7438
- function CodeMirror(place, options) {
7439
- var this$1 = this;
7440
-
7441
- if (!(this instanceof CodeMirror)) { return new CodeMirror(place, options) }
7442
-
7443
- this.options = options = options ? copyObj(options) : {}
7444
- // Determine effective options based on given values and defaults.
7445
- copyObj(defaults, options, false)
7446
- setGuttersForLineNumbers(options)
7447
-
7448
- var doc = options.value
7449
- if (typeof doc == "string") { doc = new Doc(doc, options.mode, null, options.lineSeparator, options.direction) }
7450
- this.doc = doc
7451
-
7452
- var input = new CodeMirror.inputStyles[options.inputStyle](this)
7453
- var display = this.display = new Display(place, doc, input)
7454
- display.wrapper.CodeMirror = this
7455
- updateGutters(this)
7456
- themeChanged(this)
7457
- if (options.lineWrapping)
7458
- { this.display.wrapper.className += " CodeMirror-wrap" }
7459
- initScrollbars(this)
7460
-
7461
- this.state = {
7462
- keyMaps: [], // stores maps added by addKeyMap
7463
- overlays: [], // highlighting overlays, as added by addOverlay
7464
- modeGen: 0, // bumped when mode/overlay changes, used to invalidate highlighting info
7465
- overwrite: false,
7466
- delayingBlurEvent: false,
7467
- focused: false,
7468
- suppressEdits: false, // used to disable editing during key handlers when in readOnly mode
7469
- pasteIncoming: false, cutIncoming: false, // help recognize paste/cut edits in input.poll
7470
- selectingText: false,
7471
- draggingText: false,
7472
- highlight: new Delayed(), // stores highlight worker timeout
7473
- keySeq: null, // Unfinished key sequence
7474
- specialChars: null
7475
- }
7476
-
7477
- if (options.autofocus && !mobile) { display.input.focus() }
7478
-
7479
- // Override magic textarea content restore that IE sometimes does
7480
- // on our hidden textarea on reload
7481
- if (ie && ie_version < 11) { setTimeout(function () { return this$1.display.input.reset(true); }, 20) }
7482
-
7483
- registerEventHandlers(this)
7484
- ensureGlobalHandlers()
7485
-
7486
- startOperation(this)
7487
- this.curOp.forceUpdate = true
7488
- attachDoc(this, doc)
7489
-
7490
- if ((options.autofocus && !mobile) || this.hasFocus())
7491
- { setTimeout(bind(onFocus, this), 20) }
7492
- else
7493
- { onBlur(this) }
7494
-
7495
- for (var opt in optionHandlers) { if (optionHandlers.hasOwnProperty(opt))
7496
- { optionHandlers[opt](this$1, options[opt], Init) } }
7497
- maybeUpdateLineNumberWidth(this)
7498
- if (options.finishInit) { options.finishInit(this) }
7499
- for (var i = 0; i < initHooks.length; ++i) { initHooks[i](this$1) }
7500
- endOperation(this)
7501
- // Suppress optimizelegibility in Webkit, since it breaks text
7502
- // measuring on line wrapping boundaries.
7503
- if (webkit && options.lineWrapping &&
7504
- getComputedStyle(display.lineDiv).textRendering == "optimizelegibility")
7505
- { display.lineDiv.style.textRendering = "auto" }
7506
- }
7507
-
7508
- // The default configuration options.
7509
- CodeMirror.defaults = defaults
7510
- // Functions to run when options are changed.
7511
- CodeMirror.optionHandlers = optionHandlers
7512
-
7513
- // Attach the necessary event handlers when initializing the editor
7514
- function registerEventHandlers(cm) {
7515
- var d = cm.display
7516
- on(d.scroller, "mousedown", operation(cm, onMouseDown))
7517
- // Older IE's will not fire a second mousedown for a double click
7518
- if (ie && ie_version < 11)
7519
- { on(d.scroller, "dblclick", operation(cm, function (e) {
7520
- if (signalDOMEvent(cm, e)) { return }
7521
- var pos = posFromMouse(cm, e)
7522
- if (!pos || clickInGutter(cm, e) || eventInWidget(cm.display, e)) { return }
7523
- e_preventDefault(e)
7524
- var word = cm.findWordAt(pos)
7525
- extendSelection(cm.doc, word.anchor, word.head)
7526
- })) }
7527
- else
7528
- { on(d.scroller, "dblclick", function (e) { return signalDOMEvent(cm, e) || e_preventDefault(e); }) }
7529
- // Some browsers fire contextmenu *after* opening the menu, at
7530
- // which point we can't mess with it anymore. Context menu is
7531
- // handled in onMouseDown for these browsers.
7532
- if (!captureRightClick) { on(d.scroller, "contextmenu", function (e) { return onContextMenu(cm, e); }) }
7533
-
7534
- // Used to suppress mouse event handling when a touch happens
7535
- var touchFinished, prevTouch = {end: 0}
7536
- function finishTouch() {
7537
- if (d.activeTouch) {
7538
- touchFinished = setTimeout(function () { return d.activeTouch = null; }, 1000)
7539
- prevTouch = d.activeTouch
7540
- prevTouch.end = +new Date
7541
- }
7542
- }
7543
- function isMouseLikeTouchEvent(e) {
7544
- if (e.touches.length != 1) { return false }
7545
- var touch = e.touches[0]
7546
- return touch.radiusX <= 1 && touch.radiusY <= 1
7547
- }
7548
- function farAway(touch, other) {
7549
- if (other.left == null) { return true }
7550
- var dx = other.left - touch.left, dy = other.top - touch.top
7551
- return dx * dx + dy * dy > 20 * 20
7552
- }
7553
- on(d.scroller, "touchstart", function (e) {
7554
- if (!signalDOMEvent(cm, e) && !isMouseLikeTouchEvent(e)) {
7555
- d.input.ensurePolled()
7556
- clearTimeout(touchFinished)
7557
- var now = +new Date
7558
- d.activeTouch = {start: now, moved: false,
7559
- prev: now - prevTouch.end <= 300 ? prevTouch : null}
7560
- if (e.touches.length == 1) {
7561
- d.activeTouch.left = e.touches[0].pageX
7562
- d.activeTouch.top = e.touches[0].pageY
7563
- }
7564
- }
7565
- })
7566
- on(d.scroller, "touchmove", function () {
7567
- if (d.activeTouch) { d.activeTouch.moved = true }
7568
- })
7569
- on(d.scroller, "touchend", function (e) {
7570
- var touch = d.activeTouch
7571
- if (touch && !eventInWidget(d, e) && touch.left != null &&
7572
- !touch.moved && new Date - touch.start < 300) {
7573
- var pos = cm.coordsChar(d.activeTouch, "page"), range
7574
- if (!touch.prev || farAway(touch, touch.prev)) // Single tap
7575
- { range = new Range(pos, pos) }
7576
- else if (!touch.prev.prev || farAway(touch, touch.prev.prev)) // Double tap
7577
- { range = cm.findWordAt(pos) }
7578
- else // Triple tap
7579
- { range = new Range(Pos(pos.line, 0), clipPos(cm.doc, Pos(pos.line + 1, 0))) }
7580
- cm.setSelection(range.anchor, range.head)
7581
- cm.focus()
7582
- e_preventDefault(e)
7583
- }
7584
- finishTouch()
7585
- })
7586
- on(d.scroller, "touchcancel", finishTouch)
7587
-
7588
- // Sync scrolling between fake scrollbars and real scrollable
7589
- // area, ensure viewport is updated when scrolling.
7590
- on(d.scroller, "scroll", function () {
7591
- if (d.scroller.clientHeight) {
7592
- updateScrollTop(cm, d.scroller.scrollTop)
7593
- setScrollLeft(cm, d.scroller.scrollLeft, true)
7594
- signal(cm, "scroll", cm)
7595
- }
7596
- })
7597
-
7598
- // Listen to wheel events in order to try and update the viewport on time.
7599
- on(d.scroller, "mousewheel", function (e) { return onScrollWheel(cm, e); })
7600
- on(d.scroller, "DOMMouseScroll", function (e) { return onScrollWheel(cm, e); })
7601
-
7602
- // Prevent wrapper from ever scrolling
7603
- on(d.wrapper, "scroll", function () { return d.wrapper.scrollTop = d.wrapper.scrollLeft = 0; })
7604
-
7605
- d.dragFunctions = {
7606
- enter: function (e) {if (!signalDOMEvent(cm, e)) { e_stop(e) }},
7607
- over: function (e) {if (!signalDOMEvent(cm, e)) { onDragOver(cm, e); e_stop(e) }},
7608
- start: function (e) { return onDragStart(cm, e); },
7609
- drop: operation(cm, onDrop),
7610
- leave: function (e) {if (!signalDOMEvent(cm, e)) { clearDragCursor(cm) }}
7611
- }
7612
-
7613
- var inp = d.input.getField()
7614
- on(inp, "keyup", function (e) { return onKeyUp.call(cm, e); })
7615
- on(inp, "keydown", operation(cm, onKeyDown))
7616
- on(inp, "keypress", operation(cm, onKeyPress))
7617
- on(inp, "focus", function (e) { return onFocus(cm, e); })
7618
- on(inp, "blur", function (e) { return onBlur(cm, e); })
7619
- }
7620
-
7621
- var initHooks = []
7622
- CodeMirror.defineInitHook = function (f) { return initHooks.push(f); }
7623
-
7624
- // Indent the given line. The how parameter can be "smart",
7625
- // "add"/null, "subtract", or "prev". When aggressive is false
7626
- // (typically set to true for forced single-line indents), empty
7627
- // lines are not indented, and places where the mode returns Pass
7628
- // are left alone.
7629
- function indentLine(cm, n, how, aggressive) {
7630
- var doc = cm.doc, state
7631
- if (how == null) { how = "add" }
7632
- if (how == "smart") {
7633
- // Fall back to "prev" when the mode doesn't have an indentation
7634
- // method.
7635
- if (!doc.mode.indent) { how = "prev" }
7636
- else { state = getStateBefore(cm, n) }
7637
- }
7638
-
7639
- var tabSize = cm.options.tabSize
7640
- var line = getLine(doc, n), curSpace = countColumn(line.text, null, tabSize)
7641
- if (line.stateAfter) { line.stateAfter = null }
7642
- var curSpaceString = line.text.match(/^\s*/)[0], indentation
7643
- if (!aggressive && !/\S/.test(line.text)) {
7644
- indentation = 0
7645
- how = "not"
7646
- } else if (how == "smart") {
7647
- indentation = doc.mode.indent(state, line.text.slice(curSpaceString.length), line.text)
7648
- if (indentation == Pass || indentation > 150) {
7649
- if (!aggressive) { return }
7650
- how = "prev"
7651
- }
7652
- }
7653
- if (how == "prev") {
7654
- if (n > doc.first) { indentation = countColumn(getLine(doc, n-1).text, null, tabSize) }
7655
- else { indentation = 0 }
7656
- } else if (how == "add") {
7657
- indentation = curSpace + cm.options.indentUnit
7658
- } else if (how == "subtract") {
7659
- indentation = curSpace - cm.options.indentUnit
7660
- } else if (typeof how == "number") {
7661
- indentation = curSpace + how
7662
- }
7663
- indentation = Math.max(0, indentation)
7664
-
7665
- var indentString = "", pos = 0
7666
- if (cm.options.indentWithTabs)
7667
- { for (var i = Math.floor(indentation / tabSize); i; --i) {pos += tabSize; indentString += "\t"} }
7668
- if (pos < indentation) { indentString += spaceStr(indentation - pos) }
7669
-
7670
- if (indentString != curSpaceString) {
7671
- replaceRange(doc, indentString, Pos(n, 0), Pos(n, curSpaceString.length), "+input")
7672
- line.stateAfter = null
7673
- return true
7674
- } else {
7675
- // Ensure that, if the cursor was in the whitespace at the start
7676
- // of the line, it is moved to the end of that space.
7677
- for (var i$1 = 0; i$1 < doc.sel.ranges.length; i$1++) {
7678
- var range = doc.sel.ranges[i$1]
7679
- if (range.head.line == n && range.head.ch < curSpaceString.length) {
7680
- var pos$1 = Pos(n, curSpaceString.length)
7681
- replaceOneSelection(doc, i$1, new Range(pos$1, pos$1))
7682
- break
7683
- }
7684
- }
7685
- }
7686
- }
7687
-
7688
- // This will be set to a {lineWise: bool, text: [string]} object, so
7689
- // that, when pasting, we know what kind of selections the copied
7690
- // text was made out of.
7691
- var lastCopied = null
7692
-
7693
- function setLastCopied(newLastCopied) {
7694
- lastCopied = newLastCopied
7695
- }
7696
-
7697
- function applyTextInput(cm, inserted, deleted, sel, origin) {
7698
- var doc = cm.doc
7699
- cm.display.shift = false
7700
- if (!sel) { sel = doc.sel }
7701
-
7702
- var paste = cm.state.pasteIncoming || origin == "paste"
7703
- var textLines = splitLinesAuto(inserted), multiPaste = null
7704
- // When pasing N lines into N selections, insert one line per selection
7705
- if (paste && sel.ranges.length > 1) {
7706
- if (lastCopied && lastCopied.text.join("\n") == inserted) {
7707
- if (sel.ranges.length % lastCopied.text.length == 0) {
7708
- multiPaste = []
7709
- for (var i = 0; i < lastCopied.text.length; i++)
7710
- { multiPaste.push(doc.splitLines(lastCopied.text[i])) }
7711
- }
7712
- } else if (textLines.length == sel.ranges.length) {
7713
- multiPaste = map(textLines, function (l) { return [l]; })
7714
- }
7715
- }
7716
-
7717
- var updateInput
7718
- // Normal behavior is to insert the new text into every selection
7719
- for (var i$1 = sel.ranges.length - 1; i$1 >= 0; i$1--) {
7720
- var range = sel.ranges[i$1]
7721
- var from = range.from(), to = range.to()
7722
- if (range.empty()) {
7723
- if (deleted && deleted > 0) // Handle deletion
7724
- { from = Pos(from.line, from.ch - deleted) }
7725
- else if (cm.state.overwrite && !paste) // Handle overwrite
7726
- { to = Pos(to.line, Math.min(getLine(doc, to.line).text.length, to.ch + lst(textLines).length)) }
7727
- else if (lastCopied && lastCopied.lineWise && lastCopied.text.join("\n") == inserted)
7728
- { from = to = Pos(from.line, 0) }
7729
- }
7730
- updateInput = cm.curOp.updateInput
7731
- var changeEvent = {from: from, to: to, text: multiPaste ? multiPaste[i$1 % multiPaste.length] : textLines,
7732
- origin: origin || (paste ? "paste" : cm.state.cutIncoming ? "cut" : "+input")}
7733
- makeChange(cm.doc, changeEvent)
7734
- signalLater(cm, "inputRead", cm, changeEvent)
7735
- }
7736
- if (inserted && !paste)
7737
- { triggerElectric(cm, inserted) }
7738
-
7739
- ensureCursorVisible(cm)
7740
- cm.curOp.updateInput = updateInput
7741
- cm.curOp.typing = true
7742
- cm.state.pasteIncoming = cm.state.cutIncoming = false
7743
- }
7744
-
7745
- function handlePaste(e, cm) {
7746
- var pasted = e.clipboardData && e.clipboardData.getData("Text")
7747
- if (pasted) {
7748
- e.preventDefault()
7749
- if (!cm.isReadOnly() && !cm.options.disableInput)
7750
- { runInOp(cm, function () { return applyTextInput(cm, pasted, 0, null, "paste"); }) }
7751
- return true
7752
- }
7753
- }
7754
-
7755
- function triggerElectric(cm, inserted) {
7756
- // When an 'electric' character is inserted, immediately trigger a reindent
7757
- if (!cm.options.electricChars || !cm.options.smartIndent) { return }
7758
- var sel = cm.doc.sel
7759
-
7760
- for (var i = sel.ranges.length - 1; i >= 0; i--) {
7761
- var range = sel.ranges[i]
7762
- if (range.head.ch > 100 || (i && sel.ranges[i - 1].head.line == range.head.line)) { continue }
7763
- var mode = cm.getModeAt(range.head)
7764
- var indented = false
7765
- if (mode.electricChars) {
7766
- for (var j = 0; j < mode.electricChars.length; j++)
7767
- { if (inserted.indexOf(mode.electricChars.charAt(j)) > -1) {
7768
- indented = indentLine(cm, range.head.line, "smart")
7769
- break
7770
- } }
7771
- } else if (mode.electricInput) {
7772
- if (mode.electricInput.test(getLine(cm.doc, range.head.line).text.slice(0, range.head.ch)))
7773
- { indented = indentLine(cm, range.head.line, "smart") }
7774
- }
7775
- if (indented) { signalLater(cm, "electricInput", cm, range.head.line) }
7776
- }
7777
- }
7778
-
7779
- function copyableRanges(cm) {
7780
- var text = [], ranges = []
7781
- for (var i = 0; i < cm.doc.sel.ranges.length; i++) {
7782
- var line = cm.doc.sel.ranges[i].head.line
7783
- var lineRange = {anchor: Pos(line, 0), head: Pos(line + 1, 0)}
7784
- ranges.push(lineRange)
7785
- text.push(cm.getRange(lineRange.anchor, lineRange.head))
7786
- }
7787
- return {text: text, ranges: ranges}
7788
- }
7789
-
7790
- function disableBrowserMagic(field, spellcheck) {
7791
- field.setAttribute("autocorrect", "off")
7792
- field.setAttribute("autocapitalize", "off")
7793
- field.setAttribute("spellcheck", !!spellcheck)
7794
- }
7795
-
7796
- function hiddenTextarea() {
7797
- var te = elt("textarea", null, null, "position: absolute; bottom: -1em; padding: 0; width: 1px; height: 1em; outline: none")
7798
- var div = elt("div", [te], null, "overflow: hidden; position: relative; width: 3px; height: 0px;")
7799
- // The textarea is kept positioned near the cursor to prevent the
7800
- // fact that it'll be scrolled into view on input from scrolling
7801
- // our fake cursor out of view. On webkit, when wrap=off, paste is
7802
- // very slow. So make the area wide instead.
7803
- if (webkit) { te.style.width = "1000px" }
7804
- else { te.setAttribute("wrap", "off") }
7805
- // If border: 0; -- iOS fails to open keyboard (issue #1287)
7806
- if (ios) { te.style.border = "1px solid black" }
7807
- disableBrowserMagic(te)
7808
- return div
7809
- }
7810
-
7811
- // The publicly visible API. Note that methodOp(f) means
7812
- // 'wrap f in an operation, performed on its `this` parameter'.
7813
-
7814
- // This is not the complete set of editor methods. Most of the
7815
- // methods defined on the Doc type are also injected into
7816
- // CodeMirror.prototype, for backwards compatibility and
7817
- // convenience.
7818
-
7819
- function addEditorMethods(CodeMirror) {
7820
- var optionHandlers = CodeMirror.optionHandlers
7821
-
7822
- var helpers = CodeMirror.helpers = {}
7823
-
7824
- CodeMirror.prototype = {
7825
- constructor: CodeMirror,
7826
- focus: function(){window.focus(); this.display.input.focus()},
7827
-
7828
- setOption: function(option, value) {
7829
- var options = this.options, old = options[option]
7830
- if (options[option] == value && option != "mode") { return }
7831
- options[option] = value
7832
- if (optionHandlers.hasOwnProperty(option))
7833
- { operation(this, optionHandlers[option])(this, value, old) }
7834
- signal(this, "optionChange", this, option)
7835
- },
7836
-
7837
- getOption: function(option) {return this.options[option]},
7838
- getDoc: function() {return this.doc},
7839
-
7840
- addKeyMap: function(map, bottom) {
7841
- this.state.keyMaps[bottom ? "push" : "unshift"](getKeyMap(map))
7842
- },
7843
- removeKeyMap: function(map) {
7844
- var maps = this.state.keyMaps
7845
- for (var i = 0; i < maps.length; ++i)
7846
- { if (maps[i] == map || maps[i].name == map) {
7847
- maps.splice(i, 1)
7848
- return true
7849
- } }
7850
- },
7851
-
7852
- addOverlay: methodOp(function(spec, options) {
7853
- var mode = spec.token ? spec : CodeMirror.getMode(this.options, spec)
7854
- if (mode.startState) { throw new Error("Overlays may not be stateful.") }
7855
- insertSorted(this.state.overlays,
7856
- {mode: mode, modeSpec: spec, opaque: options && options.opaque,
7857
- priority: (options && options.priority) || 0},
7858
- function (overlay) { return overlay.priority; })
7859
- this.state.modeGen++
7860
- regChange(this)
7861
- }),
7862
- removeOverlay: methodOp(function(spec) {
7863
- var this$1 = this;
7864
-
7865
- var overlays = this.state.overlays
7866
- for (var i = 0; i < overlays.length; ++i) {
7867
- var cur = overlays[i].modeSpec
7868
- if (cur == spec || typeof spec == "string" && cur.name == spec) {
7869
- overlays.splice(i, 1)
7870
- this$1.state.modeGen++
7871
- regChange(this$1)
7872
- return
7873
- }
7874
- }
7875
- }),
7876
-
7877
- indentLine: methodOp(function(n, dir, aggressive) {
7878
- if (typeof dir != "string" && typeof dir != "number") {
7879
- if (dir == null) { dir = this.options.smartIndent ? "smart" : "prev" }
7880
- else { dir = dir ? "add" : "subtract" }
7881
- }
7882
- if (isLine(this.doc, n)) { indentLine(this, n, dir, aggressive) }
7883
- }),
7884
- indentSelection: methodOp(function(how) {
7885
- var this$1 = this;
7886
-
7887
- var ranges = this.doc.sel.ranges, end = -1
7888
- for (var i = 0; i < ranges.length; i++) {
7889
- var range = ranges[i]
7890
- if (!range.empty()) {
7891
- var from = range.from(), to = range.to()
7892
- var start = Math.max(end, from.line)
7893
- end = Math.min(this$1.lastLine(), to.line - (to.ch ? 0 : 1)) + 1
7894
- for (var j = start; j < end; ++j)
7895
- { indentLine(this$1, j, how) }
7896
- var newRanges = this$1.doc.sel.ranges
7897
- if (from.ch == 0 && ranges.length == newRanges.length && newRanges[i].from().ch > 0)
7898
- { replaceOneSelection(this$1.doc, i, new Range(from, newRanges[i].to()), sel_dontScroll) }
7899
- } else if (range.head.line > end) {
7900
- indentLine(this$1, range.head.line, how, true)
7901
- end = range.head.line
7902
- if (i == this$1.doc.sel.primIndex) { ensureCursorVisible(this$1) }
7903
- }
7904
- }
7905
- }),
7906
-
7907
- // Fetch the parser token for a given character. Useful for hacks
7908
- // that want to inspect the mode state (say, for completion).
7909
- getTokenAt: function(pos, precise) {
7910
- return takeToken(this, pos, precise)
7911
- },
7912
-
7913
- getLineTokens: function(line, precise) {
7914
- return takeToken(this, Pos(line), precise, true)
7915
- },
7916
-
7917
- getTokenTypeAt: function(pos) {
7918
- pos = clipPos(this.doc, pos)
7919
- var styles = getLineStyles(this, getLine(this.doc, pos.line))
7920
- var before = 0, after = (styles.length - 1) / 2, ch = pos.ch
7921
- var type
7922
- if (ch == 0) { type = styles[2] }
7923
- else { for (;;) {
7924
- var mid = (before + after) >> 1
7925
- if ((mid ? styles[mid * 2 - 1] : 0) >= ch) { after = mid }
7926
- else if (styles[mid * 2 + 1] < ch) { before = mid + 1 }
7927
- else { type = styles[mid * 2 + 2]; break }
7928
- } }
7929
- var cut = type ? type.indexOf("overlay ") : -1
7930
- return cut < 0 ? type : cut == 0 ? null : type.slice(0, cut - 1)
7931
- },
7932
-
7933
- getModeAt: function(pos) {
7934
- var mode = this.doc.mode
7935
- if (!mode.innerMode) { return mode }
7936
- return CodeMirror.innerMode(mode, this.getTokenAt(pos).state).mode
7937
- },
7938
-
7939
- getHelper: function(pos, type) {
7940
- return this.getHelpers(pos, type)[0]
7941
- },
7942
-
7943
- getHelpers: function(pos, type) {
7944
- var this$1 = this;
7945
-
7946
- var found = []
7947
- if (!helpers.hasOwnProperty(type)) { return found }
7948
- var help = helpers[type], mode = this.getModeAt(pos)
7949
- if (typeof mode[type] == "string") {
7950
- if (help[mode[type]]) { found.push(help[mode[type]]) }
7951
- } else if (mode[type]) {
7952
- for (var i = 0; i < mode[type].length; i++) {
7953
- var val = help[mode[type][i]]
7954
- if (val) { found.push(val) }
7955
- }
7956
- } else if (mode.helperType && help[mode.helperType]) {
7957
- found.push(help[mode.helperType])
7958
- } else if (help[mode.name]) {
7959
- found.push(help[mode.name])
7960
- }
7961
- for (var i$1 = 0; i$1 < help._global.length; i$1++) {
7962
- var cur = help._global[i$1]
7963
- if (cur.pred(mode, this$1) && indexOf(found, cur.val) == -1)
7964
- { found.push(cur.val) }
7965
- }
7966
- return found
7967
- },
7968
-
7969
- getStateAfter: function(line, precise) {
7970
- var doc = this.doc
7971
- line = clipLine(doc, line == null ? doc.first + doc.size - 1: line)
7972
- return getStateBefore(this, line + 1, precise)
7973
- },
7974
-
7975
- cursorCoords: function(start, mode) {
7976
- var pos, range = this.doc.sel.primary()
7977
- if (start == null) { pos = range.head }
7978
- else if (typeof start == "object") { pos = clipPos(this.doc, start) }
7979
- else { pos = start ? range.from() : range.to() }
7980
- return cursorCoords(this, pos, mode || "page")
7981
- },
7982
-
7983
- charCoords: function(pos, mode) {
7984
- return charCoords(this, clipPos(this.doc, pos), mode || "page")
7985
- },
7986
-
7987
- coordsChar: function(coords, mode) {
7988
- coords = fromCoordSystem(this, coords, mode || "page")
7989
- return coordsChar(this, coords.left, coords.top)
7990
- },
7991
-
7992
- lineAtHeight: function(height, mode) {
7993
- height = fromCoordSystem(this, {top: height, left: 0}, mode || "page").top
7994
- return lineAtHeight(this.doc, height + this.display.viewOffset)
7995
- },
7996
- heightAtLine: function(line, mode, includeWidgets) {
7997
- var end = false, lineObj
7998
- if (typeof line == "number") {
7999
- var last = this.doc.first + this.doc.size - 1
8000
- if (line < this.doc.first) { line = this.doc.first }
8001
- else if (line > last) { line = last; end = true }
8002
- lineObj = getLine(this.doc, line)
8003
- } else {
8004
- lineObj = line
8005
- }
8006
- return intoCoordSystem(this, lineObj, {top: 0, left: 0}, mode || "page", includeWidgets || end).top +
8007
- (end ? this.doc.height - heightAtLine(lineObj) : 0)
8008
- },
8009
-
8010
- defaultTextHeight: function() { return textHeight(this.display) },
8011
- defaultCharWidth: function() { return charWidth(this.display) },
8012
-
8013
- getViewport: function() { return {from: this.display.viewFrom, to: this.display.viewTo}},
8014
-
8015
- addWidget: function(pos, node, scroll, vert, horiz) {
8016
- var display = this.display
8017
- pos = cursorCoords(this, clipPos(this.doc, pos))
8018
- var top = pos.bottom, left = pos.left
8019
- node.style.position = "absolute"
8020
- node.setAttribute("cm-ignore-events", "true")
8021
- this.display.input.setUneditable(node)
8022
- display.sizer.appendChild(node)
8023
- if (vert == "over") {
8024
- top = pos.top
8025
- } else if (vert == "above" || vert == "near") {
8026
- var vspace = Math.max(display.wrapper.clientHeight, this.doc.height),
8027
- hspace = Math.max(display.sizer.clientWidth, display.lineSpace.clientWidth)
8028
- // Default to positioning above (if specified and possible); otherwise default to positioning below
8029
- if ((vert == 'above' || pos.bottom + node.offsetHeight > vspace) && pos.top > node.offsetHeight)
8030
- { top = pos.top - node.offsetHeight }
8031
- else if (pos.bottom + node.offsetHeight <= vspace)
8032
- { top = pos.bottom }
8033
- if (left + node.offsetWidth > hspace)
8034
- { left = hspace - node.offsetWidth }
8035
- }
8036
- node.style.top = top + "px"
8037
- node.style.left = node.style.right = ""
8038
- if (horiz == "right") {
8039
- left = display.sizer.clientWidth - node.offsetWidth
8040
- node.style.right = "0px"
8041
- } else {
8042
- if (horiz == "left") { left = 0 }
8043
- else if (horiz == "middle") { left = (display.sizer.clientWidth - node.offsetWidth) / 2 }
8044
- node.style.left = left + "px"
8045
- }
8046
- if (scroll)
8047
- { scrollIntoView(this, {left: left, top: top, right: left + node.offsetWidth, bottom: top + node.offsetHeight}) }
8048
- },
8049
-
8050
- triggerOnKeyDown: methodOp(onKeyDown),
8051
- triggerOnKeyPress: methodOp(onKeyPress),
8052
- triggerOnKeyUp: onKeyUp,
8053
-
8054
- execCommand: function(cmd) {
8055
- if (commands.hasOwnProperty(cmd))
8056
- { return commands[cmd].call(null, this) }
8057
- },
8058
-
8059
- triggerElectric: methodOp(function(text) { triggerElectric(this, text) }),
8060
-
8061
- findPosH: function(from, amount, unit, visually) {
8062
- var this$1 = this;
8063
-
8064
- var dir = 1
8065
- if (amount < 0) { dir = -1; amount = -amount }
8066
- var cur = clipPos(this.doc, from)
8067
- for (var i = 0; i < amount; ++i) {
8068
- cur = findPosH(this$1.doc, cur, dir, unit, visually)
8069
- if (cur.hitSide) { break }
8070
- }
8071
- return cur
8072
- },
8073
-
8074
- moveH: methodOp(function(dir, unit) {
8075
- var this$1 = this;
8076
-
8077
- this.extendSelectionsBy(function (range) {
8078
- if (this$1.display.shift || this$1.doc.extend || range.empty())
8079
- { return findPosH(this$1.doc, range.head, dir, unit, this$1.options.rtlMoveVisually) }
8080
- else
8081
- { return dir < 0 ? range.from() : range.to() }
8082
- }, sel_move)
8083
- }),
8084
-
8085
- deleteH: methodOp(function(dir, unit) {
8086
- var sel = this.doc.sel, doc = this.doc
8087
- if (sel.somethingSelected())
8088
- { doc.replaceSelection("", null, "+delete") }
8089
- else
8090
- { deleteNearSelection(this, function (range) {
8091
- var other = findPosH(doc, range.head, dir, unit, false)
8092
- return dir < 0 ? {from: other, to: range.head} : {from: range.head, to: other}
8093
- }) }
8094
- }),
8095
-
8096
- findPosV: function(from, amount, unit, goalColumn) {
8097
- var this$1 = this;
8098
-
8099
- var dir = 1, x = goalColumn
8100
- if (amount < 0) { dir = -1; amount = -amount }
8101
- var cur = clipPos(this.doc, from)
8102
- for (var i = 0; i < amount; ++i) {
8103
- var coords = cursorCoords(this$1, cur, "div")
8104
- if (x == null) { x = coords.left }
8105
- else { coords.left = x }
8106
- cur = findPosV(this$1, coords, dir, unit)
8107
- if (cur.hitSide) { break }
8108
- }
8109
- return cur
8110
- },
8111
-
8112
- moveV: methodOp(function(dir, unit) {
8113
- var this$1 = this;
8114
-
8115
- var doc = this.doc, goals = []
8116
- var collapse = !this.display.shift && !doc.extend && doc.sel.somethingSelected()
8117
- doc.extendSelectionsBy(function (range) {
8118
- if (collapse)
8119
- { return dir < 0 ? range.from() : range.to() }
8120
- var headPos = cursorCoords(this$1, range.head, "div")
8121
- if (range.goalColumn != null) { headPos.left = range.goalColumn }
8122
- goals.push(headPos.left)
8123
- var pos = findPosV(this$1, headPos, dir, unit)
8124
- if (unit == "page" && range == doc.sel.primary())
8125
- { addToScrollTop(this$1, charCoords(this$1, pos, "div").top - headPos.top) }
8126
- return pos
8127
- }, sel_move)
8128
- if (goals.length) { for (var i = 0; i < doc.sel.ranges.length; i++)
8129
- { doc.sel.ranges[i].goalColumn = goals[i] } }
8130
- }),
8131
-
8132
- // Find the word at the given position (as returned by coordsChar).
8133
- findWordAt: function(pos) {
8134
- var doc = this.doc, line = getLine(doc, pos.line).text
8135
- var start = pos.ch, end = pos.ch
8136
- if (line) {
8137
- var helper = this.getHelper(pos, "wordChars")
8138
- if ((pos.sticky == "before" || end == line.length) && start) { --start; } else { ++end }
8139
- var startChar = line.charAt(start)
8140
- var check = isWordChar(startChar, helper)
8141
- ? function (ch) { return isWordChar(ch, helper); }
8142
- : /\s/.test(startChar) ? function (ch) { return /\s/.test(ch); }
8143
- : function (ch) { return (!/\s/.test(ch) && !isWordChar(ch)); }
8144
- while (start > 0 && check(line.charAt(start - 1))) { --start }
8145
- while (end < line.length && check(line.charAt(end))) { ++end }
8146
- }
8147
- return new Range(Pos(pos.line, start), Pos(pos.line, end))
8148
- },
8149
-
8150
- toggleOverwrite: function(value) {
8151
- if (value != null && value == this.state.overwrite) { return }
8152
- if (this.state.overwrite = !this.state.overwrite)
8153
- { addClass(this.display.cursorDiv, "CodeMirror-overwrite") }
8154
- else
8155
- { rmClass(this.display.cursorDiv, "CodeMirror-overwrite") }
8156
-
8157
- signal(this, "overwriteToggle", this, this.state.overwrite)
8158
- },
8159
- hasFocus: function() { return this.display.input.getField() == activeElt() },
8160
- isReadOnly: function() { return !!(this.options.readOnly || this.doc.cantEdit) },
8161
-
8162
- scrollTo: methodOp(function (x, y) { scrollToCoords(this, x, y) }),
8163
- getScrollInfo: function() {
8164
- var scroller = this.display.scroller
8165
- return {left: scroller.scrollLeft, top: scroller.scrollTop,
8166
- height: scroller.scrollHeight - scrollGap(this) - this.display.barHeight,
8167
- width: scroller.scrollWidth - scrollGap(this) - this.display.barWidth,
8168
- clientHeight: displayHeight(this), clientWidth: displayWidth(this)}
8169
- },
8170
-
8171
- scrollIntoView: methodOp(function(range, margin) {
8172
- if (range == null) {
8173
- range = {from: this.doc.sel.primary().head, to: null}
8174
- if (margin == null) { margin = this.options.cursorScrollMargin }
8175
- } else if (typeof range == "number") {
8176
- range = {from: Pos(range, 0), to: null}
8177
- } else if (range.from == null) {
8178
- range = {from: range, to: null}
8179
- }
8180
- if (!range.to) { range.to = range.from }
8181
- range.margin = margin || 0
8182
-
8183
- if (range.from.line != null) {
8184
- scrollToRange(this, range)
8185
- } else {
8186
- scrollToCoordsRange(this, range.from, range.to, range.margin)
8187
- }
8188
- }),
8189
-
8190
- setSize: methodOp(function(width, height) {
8191
- var this$1 = this;
8192
-
8193
- var interpret = function (val) { return typeof val == "number" || /^\d+$/.test(String(val)) ? val + "px" : val; }
8194
- if (width != null) { this.display.wrapper.style.width = interpret(width) }
8195
- if (height != null) { this.display.wrapper.style.height = interpret(height) }
8196
- if (this.options.lineWrapping) { clearLineMeasurementCache(this) }
8197
- var lineNo = this.display.viewFrom
8198
- this.doc.iter(lineNo, this.display.viewTo, function (line) {
8199
- if (line.widgets) { for (var i = 0; i < line.widgets.length; i++)
8200
- { if (line.widgets[i].noHScroll) { regLineChange(this$1, lineNo, "widget"); break } } }
8201
- ++lineNo
8202
- })
8203
- this.curOp.forceUpdate = true
8204
- signal(this, "refresh", this)
8205
- }),
8206
-
8207
- operation: function(f){return runInOp(this, f)},
8208
-
8209
- refresh: methodOp(function() {
8210
- var oldHeight = this.display.cachedTextHeight
8211
- regChange(this)
8212
- this.curOp.forceUpdate = true
8213
- clearCaches(this)
8214
- scrollToCoords(this, this.doc.scrollLeft, this.doc.scrollTop)
8215
- updateGutterSpace(this)
8216
- if (oldHeight == null || Math.abs(oldHeight - textHeight(this.display)) > .5)
8217
- { estimateLineHeights(this) }
8218
- signal(this, "refresh", this)
8219
- }),
8220
-
8221
- swapDoc: methodOp(function(doc) {
8222
- var old = this.doc
8223
- old.cm = null
8224
- attachDoc(this, doc)
8225
- clearCaches(this)
8226
- this.display.input.reset()
8227
- scrollToCoords(this, doc.scrollLeft, doc.scrollTop)
8228
- this.curOp.forceScroll = true
8229
- signalLater(this, "swapDoc", this, old)
8230
- return old
8231
- }),
8232
-
8233
- getInputField: function(){return this.display.input.getField()},
8234
- getWrapperElement: function(){return this.display.wrapper},
8235
- getScrollerElement: function(){return this.display.scroller},
8236
- getGutterElement: function(){return this.display.gutters}
8237
- }
8238
- eventMixin(CodeMirror)
8239
-
8240
- CodeMirror.registerHelper = function(type, name, value) {
8241
- if (!helpers.hasOwnProperty(type)) { helpers[type] = CodeMirror[type] = {_global: []} }
8242
- helpers[type][name] = value
8243
- }
8244
- CodeMirror.registerGlobalHelper = function(type, name, predicate, value) {
8245
- CodeMirror.registerHelper(type, name, value)
8246
- helpers[type]._global.push({pred: predicate, val: value})
8247
- }
8248
- }
8249
-
8250
- // Used for horizontal relative motion. Dir is -1 or 1 (left or
8251
- // right), unit can be "char", "column" (like char, but doesn't
8252
- // cross line boundaries), "word" (across next word), or "group" (to
8253
- // the start of next group of word or non-word-non-whitespace
8254
- // chars). The visually param controls whether, in right-to-left
8255
- // text, direction 1 means to move towards the next index in the
8256
- // string, or towards the character to the right of the current
8257
- // position. The resulting position will have a hitSide=true
8258
- // property if it reached the end of the document.
8259
- function findPosH(doc, pos, dir, unit, visually) {
8260
- var oldPos = pos
8261
- var origDir = dir
8262
- var lineObj = getLine(doc, pos.line)
8263
- function findNextLine() {
8264
- var l = pos.line + dir
8265
- if (l < doc.first || l >= doc.first + doc.size) { return false }
8266
- pos = new Pos(l, pos.ch, pos.sticky)
8267
- return lineObj = getLine(doc, l)
8268
- }
8269
- function moveOnce(boundToLine) {
8270
- var next
8271
- if (visually) {
8272
- next = moveVisually(doc.cm, lineObj, pos, dir)
8273
- } else {
8274
- next = moveLogically(lineObj, pos, dir)
8275
- }
8276
- if (next == null) {
8277
- if (!boundToLine && findNextLine())
8278
- { pos = endOfLine(visually, doc.cm, lineObj, pos.line, dir) }
8279
- else
8280
- { return false }
8281
- } else {
8282
- pos = next
8283
- }
8284
- return true
8285
- }
8286
-
8287
- if (unit == "char") {
8288
- moveOnce()
8289
- } else if (unit == "column") {
8290
- moveOnce(true)
8291
- } else if (unit == "word" || unit == "group") {
8292
- var sawType = null, group = unit == "group"
8293
- var helper = doc.cm && doc.cm.getHelper(pos, "wordChars")
8294
- for (var first = true;; first = false) {
8295
- if (dir < 0 && !moveOnce(!first)) { break }
8296
- var cur = lineObj.text.charAt(pos.ch) || "\n"
8297
- var type = isWordChar(cur, helper) ? "w"
8298
- : group && cur == "\n" ? "n"
8299
- : !group || /\s/.test(cur) ? null
8300
- : "p"
8301
- if (group && !first && !type) { type = "s" }
8302
- if (sawType && sawType != type) {
8303
- if (dir < 0) {dir = 1; moveOnce(); pos.sticky = "after"}
8304
- break
8305
- }
8306
-
8307
- if (type) { sawType = type }
8308
- if (dir > 0 && !moveOnce(!first)) { break }
8309
- }
8310
- }
8311
- var result = skipAtomic(doc, pos, oldPos, origDir, true)
8312
- if (equalCursorPos(oldPos, result)) { result.hitSide = true }
8313
- return result
8314
- }
8315
-
8316
- // For relative vertical movement. Dir may be -1 or 1. Unit can be
8317
- // "page" or "line". The resulting position will have a hitSide=true
8318
- // property if it reached the end of the document.
8319
- function findPosV(cm, pos, dir, unit) {
8320
- var doc = cm.doc, x = pos.left, y
8321
- if (unit == "page") {
8322
- var pageSize = Math.min(cm.display.wrapper.clientHeight, window.innerHeight || document.documentElement.clientHeight)
8323
- var moveAmount = Math.max(pageSize - .5 * textHeight(cm.display), 3)
8324
- y = (dir > 0 ? pos.bottom : pos.top) + dir * moveAmount
8325
-
8326
- } else if (unit == "line") {
8327
- y = dir > 0 ? pos.bottom + 3 : pos.top - 3
8328
- }
8329
- var target
8330
- for (;;) {
8331
- target = coordsChar(cm, x, y)
8332
- if (!target.outside) { break }
8333
- if (dir < 0 ? y <= 0 : y >= doc.height) { target.hitSide = true; break }
8334
- y += dir * 5
8335
- }
8336
- return target
8337
- }
8338
-
8339
- // CONTENTEDITABLE INPUT STYLE
8340
-
8341
- var ContentEditableInput = function(cm) {
8342
- this.cm = cm
8343
- this.lastAnchorNode = this.lastAnchorOffset = this.lastFocusNode = this.lastFocusOffset = null
8344
- this.polling = new Delayed()
8345
- this.composing = null
8346
- this.gracePeriod = false
8347
- this.readDOMTimeout = null
8348
- };
8349
-
8350
- ContentEditableInput.prototype.init = function (display) {
8351
- var this$1 = this;
8352
-
8353
- var input = this, cm = input.cm
8354
- var div = input.div = display.lineDiv
8355
- disableBrowserMagic(div, cm.options.spellcheck)
8356
-
8357
- on(div, "paste", function (e) {
8358
- if (signalDOMEvent(cm, e) || handlePaste(e, cm)) { return }
8359
- // IE doesn't fire input events, so we schedule a read for the pasted content in this way
8360
- if (ie_version <= 11) { setTimeout(operation(cm, function () { return this$1.updateFromDOM(); }), 20) }
8361
- })
8362
-
8363
- on(div, "compositionstart", function (e) {
8364
- this$1.composing = {data: e.data, done: false}
8365
- })
8366
- on(div, "compositionupdate", function (e) {
8367
- if (!this$1.composing) { this$1.composing = {data: e.data, done: false} }
8368
- })
8369
- on(div, "compositionend", function (e) {
8370
- if (this$1.composing) {
8371
- if (e.data != this$1.composing.data) { this$1.readFromDOMSoon() }
8372
- this$1.composing.done = true
8373
- }
8374
- })
8375
-
8376
- on(div, "touchstart", function () { return input.forceCompositionEnd(); })
8377
-
8378
- on(div, "input", function () {
8379
- if (!this$1.composing) { this$1.readFromDOMSoon() }
8380
- })
8381
-
8382
- function onCopyCut(e) {
8383
- if (signalDOMEvent(cm, e)) { return }
8384
- if (cm.somethingSelected()) {
8385
- setLastCopied({lineWise: false, text: cm.getSelections()})
8386
- if (e.type == "cut") { cm.replaceSelection("", null, "cut") }
8387
- } else if (!cm.options.lineWiseCopyCut) {
8388
- return
8389
- } else {
8390
- var ranges = copyableRanges(cm)
8391
- setLastCopied({lineWise: true, text: ranges.text})
8392
- if (e.type == "cut") {
8393
- cm.operation(function () {
8394
- cm.setSelections(ranges.ranges, 0, sel_dontScroll)
8395
- cm.replaceSelection("", null, "cut")
8396
- })
8397
- }
8398
- }
8399
- if (e.clipboardData) {
8400
- e.clipboardData.clearData()
8401
- var content = lastCopied.text.join("\n")
8402
- // iOS exposes the clipboard API, but seems to discard content inserted into it
8403
- e.clipboardData.setData("Text", content)
8404
- if (e.clipboardData.getData("Text") == content) {
8405
- e.preventDefault()
8406
- return
8407
- }
8408
- }
8409
- // Old-fashioned briefly-focus-a-textarea hack
8410
- var kludge = hiddenTextarea(), te = kludge.firstChild
8411
- cm.display.lineSpace.insertBefore(kludge, cm.display.lineSpace.firstChild)
8412
- te.value = lastCopied.text.join("\n")
8413
- var hadFocus = document.activeElement
8414
- selectInput(te)
8415
- setTimeout(function () {
8416
- cm.display.lineSpace.removeChild(kludge)
8417
- hadFocus.focus()
8418
- if (hadFocus == div) { input.showPrimarySelection() }
8419
- }, 50)
8420
- }
8421
- on(div, "copy", onCopyCut)
8422
- on(div, "cut", onCopyCut)
8423
- };
8424
-
8425
- ContentEditableInput.prototype.prepareSelection = function () {
8426
- var result = prepareSelection(this.cm, false)
8427
- result.focus = this.cm.state.focused
8428
- return result
8429
- };
8430
-
8431
- ContentEditableInput.prototype.showSelection = function (info, takeFocus) {
8432
- if (!info || !this.cm.display.view.length) { return }
8433
- if (info.focus || takeFocus) { this.showPrimarySelection() }
8434
- this.showMultipleSelections(info)
8435
- };
8436
-
8437
- ContentEditableInput.prototype.showPrimarySelection = function () {
8438
- var sel = window.getSelection(), cm = this.cm, prim = cm.doc.sel.primary()
8439
- var from = prim.from(), to = prim.to()
8440
-
8441
- if (cm.display.viewTo == cm.display.viewFrom || from.line >= cm.display.viewTo || to.line < cm.display.viewFrom) {
8442
- sel.removeAllRanges()
8443
- return
8444
- }
8445
-
8446
- var curAnchor = domToPos(cm, sel.anchorNode, sel.anchorOffset)
8447
- var curFocus = domToPos(cm, sel.focusNode, sel.focusOffset)
8448
- if (curAnchor && !curAnchor.bad && curFocus && !curFocus.bad &&
8449
- cmp(minPos(curAnchor, curFocus), from) == 0 &&
8450
- cmp(maxPos(curAnchor, curFocus), to) == 0)
8451
- { return }
8452
-
8453
- var view = cm.display.view
8454
- var start = (from.line >= cm.display.viewFrom && posToDOM(cm, from)) ||
8455
- {node: view[0].measure.map[2], offset: 0}
8456
- var end = to.line < cm.display.viewTo && posToDOM(cm, to)
8457
- if (!end) {
8458
- var measure = view[view.length - 1].measure
8459
- var map = measure.maps ? measure.maps[measure.maps.length - 1] : measure.map
8460
- end = {node: map[map.length - 1], offset: map[map.length - 2] - map[map.length - 3]}
8461
- }
8462
-
8463
- if (!start || !end) {
8464
- sel.removeAllRanges()
8465
- return
8466
- }
8467
-
8468
- var old = sel.rangeCount && sel.getRangeAt(0), rng
8469
- try { rng = range(start.node, start.offset, end.offset, end.node) }
8470
- catch(e) {} // Our model of the DOM might be outdated, in which case the range we try to set can be impossible
8471
- if (rng) {
8472
- if (!gecko && cm.state.focused) {
8473
- sel.collapse(start.node, start.offset)
8474
- if (!rng.collapsed) {
8475
- sel.removeAllRanges()
8476
- sel.addRange(rng)
8477
- }
8478
- } else {
8479
- sel.removeAllRanges()
8480
- sel.addRange(rng)
8481
- }
8482
- if (old && sel.anchorNode == null) { sel.addRange(old) }
8483
- else if (gecko) { this.startGracePeriod() }
8484
- }
8485
- this.rememberSelection()
8486
- };
8487
-
8488
- ContentEditableInput.prototype.startGracePeriod = function () {
8489
- var this$1 = this;
8490
-
8491
- clearTimeout(this.gracePeriod)
8492
- this.gracePeriod = setTimeout(function () {
8493
- this$1.gracePeriod = false
8494
- if (this$1.selectionChanged())
8495
- { this$1.cm.operation(function () { return this$1.cm.curOp.selectionChanged = true; }) }
8496
- }, 20)
8497
- };
8498
-
8499
- ContentEditableInput.prototype.showMultipleSelections = function (info) {
8500
- removeChildrenAndAdd(this.cm.display.cursorDiv, info.cursors)
8501
- removeChildrenAndAdd(this.cm.display.selectionDiv, info.selection)
8502
- };
8503
-
8504
- ContentEditableInput.prototype.rememberSelection = function () {
8505
- var sel = window.getSelection()
8506
- this.lastAnchorNode = sel.anchorNode; this.lastAnchorOffset = sel.anchorOffset
8507
- this.lastFocusNode = sel.focusNode; this.lastFocusOffset = sel.focusOffset
8508
- };
8509
-
8510
- ContentEditableInput.prototype.selectionInEditor = function () {
8511
- var sel = window.getSelection()
8512
- if (!sel.rangeCount) { return false }
8513
- var node = sel.getRangeAt(0).commonAncestorContainer
8514
- return contains(this.div, node)
8515
- };
8516
-
8517
- ContentEditableInput.prototype.focus = function () {
8518
- if (this.cm.options.readOnly != "nocursor") {
8519
- if (!this.selectionInEditor())
8520
- { this.showSelection(this.prepareSelection(), true) }
8521
- this.div.focus()
8522
- }
8523
- };
8524
- ContentEditableInput.prototype.blur = function () { this.div.blur() };
8525
- ContentEditableInput.prototype.getField = function () { return this.div };
8526
-
8527
- ContentEditableInput.prototype.supportsTouch = function () { return true };
8528
-
8529
- ContentEditableInput.prototype.receivedFocus = function () {
8530
- var input = this
8531
- if (this.selectionInEditor())
8532
- { this.pollSelection() }
8533
- else
8534
- { runInOp(this.cm, function () { return input.cm.curOp.selectionChanged = true; }) }
8535
-
8536
- function poll() {
8537
- if (input.cm.state.focused) {
8538
- input.pollSelection()
8539
- input.polling.set(input.cm.options.pollInterval, poll)
8540
- }
8541
- }
8542
- this.polling.set(this.cm.options.pollInterval, poll)
8543
- };
8544
-
8545
- ContentEditableInput.prototype.selectionChanged = function () {
8546
- var sel = window.getSelection()
8547
- return sel.anchorNode != this.lastAnchorNode || sel.anchorOffset != this.lastAnchorOffset ||
8548
- sel.focusNode != this.lastFocusNode || sel.focusOffset != this.lastFocusOffset
8549
- };
8550
-
8551
- ContentEditableInput.prototype.pollSelection = function () {
8552
- if (this.readDOMTimeout != null || this.gracePeriod || !this.selectionChanged()) { return }
8553
- var sel = window.getSelection(), cm = this.cm
8554
- // On Android Chrome (version 56, at least), backspacing into an
8555
- // uneditable block element will put the cursor in that element,
8556
- // and then, because it's not editable, hide the virtual keyboard.
8557
- // Because Android doesn't allow us to actually detect backspace
8558
- // presses in a sane way, this code checks for when that happens
8559
- // and simulates a backspace press in this case.
8560
- if (android && chrome && this.cm.options.gutters.length && isInGutter(sel.anchorNode)) {
8561
- this.cm.triggerOnKeyDown({type: "keydown", keyCode: 8, preventDefault: Math.abs})
8562
- this.blur()
8563
- this.focus()
8564
- return
8565
- }
8566
- if (this.composing) { return }
8567
- this.rememberSelection()
8568
- var anchor = domToPos(cm, sel.anchorNode, sel.anchorOffset)
8569
- var head = domToPos(cm, sel.focusNode, sel.focusOffset)
8570
- if (anchor && head) { runInOp(cm, function () {
8571
- setSelection(cm.doc, simpleSelection(anchor, head), sel_dontScroll)
8572
- if (anchor.bad || head.bad) { cm.curOp.selectionChanged = true }
8573
- }) }
8574
- };
8575
-
8576
- ContentEditableInput.prototype.pollContent = function () {
8577
- if (this.readDOMTimeout != null) {
8578
- clearTimeout(this.readDOMTimeout)
8579
- this.readDOMTimeout = null
8580
- }
8581
-
8582
- var cm = this.cm, display = cm.display, sel = cm.doc.sel.primary()
8583
- var from = sel.from(), to = sel.to()
8584
- if (from.ch == 0 && from.line > cm.firstLine())
8585
- { from = Pos(from.line - 1, getLine(cm.doc, from.line - 1).length) }
8586
- if (to.ch == getLine(cm.doc, to.line).text.length && to.line < cm.lastLine())
8587
- { to = Pos(to.line + 1, 0) }
8588
- if (from.line < display.viewFrom || to.line > display.viewTo - 1) { return false }
8589
-
8590
- var fromIndex, fromLine, fromNode
8591
- if (from.line == display.viewFrom || (fromIndex = findViewIndex(cm, from.line)) == 0) {
8592
- fromLine = lineNo(display.view[0].line)
8593
- fromNode = display.view[0].node
8594
- } else {
8595
- fromLine = lineNo(display.view[fromIndex].line)
8596
- fromNode = display.view[fromIndex - 1].node.nextSibling
8597
- }
8598
- var toIndex = findViewIndex(cm, to.line)
8599
- var toLine, toNode
8600
- if (toIndex == display.view.length - 1) {
8601
- toLine = display.viewTo - 1
8602
- toNode = display.lineDiv.lastChild
8603
- } else {
8604
- toLine = lineNo(display.view[toIndex + 1].line) - 1
8605
- toNode = display.view[toIndex + 1].node.previousSibling
8606
- }
8607
-
8608
- if (!fromNode) { return false }
8609
- var newText = cm.doc.splitLines(domTextBetween(cm, fromNode, toNode, fromLine, toLine))
8610
- var oldText = getBetween(cm.doc, Pos(fromLine, 0), Pos(toLine, getLine(cm.doc, toLine).text.length))
8611
- while (newText.length > 1 && oldText.length > 1) {
8612
- if (lst(newText) == lst(oldText)) { newText.pop(); oldText.pop(); toLine-- }
8613
- else if (newText[0] == oldText[0]) { newText.shift(); oldText.shift(); fromLine++ }
8614
- else { break }
8615
- }
8616
-
8617
- var cutFront = 0, cutEnd = 0
8618
- var newTop = newText[0], oldTop = oldText[0], maxCutFront = Math.min(newTop.length, oldTop.length)
8619
- while (cutFront < maxCutFront && newTop.charCodeAt(cutFront) == oldTop.charCodeAt(cutFront))
8620
- { ++cutFront }
8621
- var newBot = lst(newText), oldBot = lst(oldText)
8622
- var maxCutEnd = Math.min(newBot.length - (newText.length == 1 ? cutFront : 0),
8623
- oldBot.length - (oldText.length == 1 ? cutFront : 0))
8624
- while (cutEnd < maxCutEnd &&
8625
- newBot.charCodeAt(newBot.length - cutEnd - 1) == oldBot.charCodeAt(oldBot.length - cutEnd - 1))
8626
- { ++cutEnd }
8627
- // Try to move start of change to start of selection if ambiguous
8628
- if (newText.length == 1 && oldText.length == 1 && fromLine == from.line) {
8629
- while (cutFront && cutFront > from.ch &&
8630
- newBot.charCodeAt(newBot.length - cutEnd - 1) == oldBot.charCodeAt(oldBot.length - cutEnd - 1)) {
8631
- cutFront--
8632
- cutEnd++
8633
- }
8634
- }
8635
-
8636
- newText[newText.length - 1] = newBot.slice(0, newBot.length - cutEnd).replace(/^\u200b+/, "")
8637
- newText[0] = newText[0].slice(cutFront).replace(/\u200b+$/, "")
8638
-
8639
- var chFrom = Pos(fromLine, cutFront)
8640
- var chTo = Pos(toLine, oldText.length ? lst(oldText).length - cutEnd : 0)
8641
- if (newText.length > 1 || newText[0] || cmp(chFrom, chTo)) {
8642
- replaceRange(cm.doc, newText, chFrom, chTo, "+input")
8643
- return true
8644
- }
8645
- };
8646
-
8647
- ContentEditableInput.prototype.ensurePolled = function () {
8648
- this.forceCompositionEnd()
8649
- };
8650
- ContentEditableInput.prototype.reset = function () {
8651
- this.forceCompositionEnd()
8652
- };
8653
- ContentEditableInput.prototype.forceCompositionEnd = function () {
8654
- if (!this.composing) { return }
8655
- clearTimeout(this.readDOMTimeout)
8656
- this.composing = null
8657
- this.updateFromDOM()
8658
- this.div.blur()
8659
- this.div.focus()
8660
- };
8661
- ContentEditableInput.prototype.readFromDOMSoon = function () {
8662
- var this$1 = this;
8663
-
8664
- if (this.readDOMTimeout != null) { return }
8665
- this.readDOMTimeout = setTimeout(function () {
8666
- this$1.readDOMTimeout = null
8667
- if (this$1.composing) {
8668
- if (this$1.composing.done) { this$1.composing = null }
8669
- else { return }
8670
- }
8671
- this$1.updateFromDOM()
8672
- }, 80)
8673
- };
8674
-
8675
- ContentEditableInput.prototype.updateFromDOM = function () {
8676
- var this$1 = this;
8677
-
8678
- if (this.cm.isReadOnly() || !this.pollContent())
8679
- { runInOp(this.cm, function () { return regChange(this$1.cm); }) }
8680
- };
8681
-
8682
- ContentEditableInput.prototype.setUneditable = function (node) {
8683
- node.contentEditable = "false"
8684
- };
8685
-
8686
- ContentEditableInput.prototype.onKeyPress = function (e) {
8687
- if (e.charCode == 0) { return }
8688
- e.preventDefault()
8689
- if (!this.cm.isReadOnly())
8690
- { operation(this.cm, applyTextInput)(this.cm, String.fromCharCode(e.charCode == null ? e.keyCode : e.charCode), 0) }
8691
- };
8692
-
8693
- ContentEditableInput.prototype.readOnlyChanged = function (val) {
8694
- this.div.contentEditable = String(val != "nocursor")
8695
- };
8696
-
8697
- ContentEditableInput.prototype.onContextMenu = function () {};
8698
- ContentEditableInput.prototype.resetPosition = function () {};
8699
-
8700
- ContentEditableInput.prototype.needsContentAttribute = true
8701
-
8702
- function posToDOM(cm, pos) {
8703
- var view = findViewForLine(cm, pos.line)
8704
- if (!view || view.hidden) { return null }
8705
- var line = getLine(cm.doc, pos.line)
8706
- var info = mapFromLineView(view, line, pos.line)
8707
-
8708
- var order = getOrder(line, cm.doc.direction), side = "left"
8709
- if (order) {
8710
- var partPos = getBidiPartAt(order, pos.ch)
8711
- side = partPos % 2 ? "right" : "left"
8712
- }
8713
- var result = nodeAndOffsetInLineMap(info.map, pos.ch, side)
8714
- result.offset = result.collapse == "right" ? result.end : result.start
8715
- return result
8716
- }
8717
-
8718
- function isInGutter(node) {
8719
- for (var scan = node; scan; scan = scan.parentNode)
8720
- { if (/CodeMirror-gutter-wrapper/.test(scan.className)) { return true } }
8721
- return false
8722
- }
8723
-
8724
- function badPos(pos, bad) { if (bad) { pos.bad = true; } return pos }
8725
-
8726
- function domTextBetween(cm, from, to, fromLine, toLine) {
8727
- var text = "", closing = false, lineSep = cm.doc.lineSeparator()
8728
- function recognizeMarker(id) { return function (marker) { return marker.id == id; } }
8729
- function close() {
8730
- if (closing) {
8731
- text += lineSep
8732
- closing = false
8733
- }
8734
- }
8735
- function addText(str) {
8736
- if (str) {
8737
- close()
8738
- text += str
8739
- }
8740
- }
8741
- function walk(node) {
8742
- if (node.nodeType == 1) {
8743
- var cmText = node.getAttribute("cm-text")
8744
- if (cmText != null) {
8745
- addText(cmText || node.textContent.replace(/\u200b/g, ""))
8746
- return
8747
- }
8748
- var markerID = node.getAttribute("cm-marker"), range
8749
- if (markerID) {
8750
- var found = cm.findMarks(Pos(fromLine, 0), Pos(toLine + 1, 0), recognizeMarker(+markerID))
8751
- if (found.length && (range = found[0].find()))
8752
- { addText(getBetween(cm.doc, range.from, range.to).join(lineSep)) }
8753
- return
8754
- }
8755
- if (node.getAttribute("contenteditable") == "false") { return }
8756
- var isBlock = /^(pre|div|p)$/i.test(node.nodeName)
8757
- if (isBlock) { close() }
8758
- for (var i = 0; i < node.childNodes.length; i++)
8759
- { walk(node.childNodes[i]) }
8760
- if (isBlock) { closing = true }
8761
- } else if (node.nodeType == 3) {
8762
- addText(node.nodeValue)
8763
- }
8764
- }
8765
- for (;;) {
8766
- walk(from)
8767
- if (from == to) { break }
8768
- from = from.nextSibling
8769
- }
8770
- return text
8771
- }
8772
-
8773
- function domToPos(cm, node, offset) {
8774
- var lineNode
8775
- if (node == cm.display.lineDiv) {
8776
- lineNode = cm.display.lineDiv.childNodes[offset]
8777
- if (!lineNode) { return badPos(cm.clipPos(Pos(cm.display.viewTo - 1)), true) }
8778
- node = null; offset = 0
8779
- } else {
8780
- for (lineNode = node;; lineNode = lineNode.parentNode) {
8781
- if (!lineNode || lineNode == cm.display.lineDiv) { return null }
8782
- if (lineNode.parentNode && lineNode.parentNode == cm.display.lineDiv) { break }
8783
- }
8784
- }
8785
- for (var i = 0; i < cm.display.view.length; i++) {
8786
- var lineView = cm.display.view[i]
8787
- if (lineView.node == lineNode)
8788
- { return locateNodeInLineView(lineView, node, offset) }
8789
- }
8790
- }
8791
-
8792
- function locateNodeInLineView(lineView, node, offset) {
8793
- var wrapper = lineView.text.firstChild, bad = false
8794
- if (!node || !contains(wrapper, node)) { return badPos(Pos(lineNo(lineView.line), 0), true) }
8795
- if (node == wrapper) {
8796
- bad = true
8797
- node = wrapper.childNodes[offset]
8798
- offset = 0
8799
- if (!node) {
8800
- var line = lineView.rest ? lst(lineView.rest) : lineView.line
8801
- return badPos(Pos(lineNo(line), line.text.length), bad)
8802
- }
8803
- }
8804
-
8805
- var textNode = node.nodeType == 3 ? node : null, topNode = node
8806
- if (!textNode && node.childNodes.length == 1 && node.firstChild.nodeType == 3) {
8807
- textNode = node.firstChild
8808
- if (offset) { offset = textNode.nodeValue.length }
8809
- }
8810
- while (topNode.parentNode != wrapper) { topNode = topNode.parentNode }
8811
- var measure = lineView.measure, maps = measure.maps
8812
-
8813
- function find(textNode, topNode, offset) {
8814
- for (var i = -1; i < (maps ? maps.length : 0); i++) {
8815
- var map = i < 0 ? measure.map : maps[i]
8816
- for (var j = 0; j < map.length; j += 3) {
8817
- var curNode = map[j + 2]
8818
- if (curNode == textNode || curNode == topNode) {
8819
- var line = lineNo(i < 0 ? lineView.line : lineView.rest[i])
8820
- var ch = map[j] + offset
8821
- if (offset < 0 || curNode != textNode) { ch = map[j + (offset ? 1 : 0)] }
8822
- return Pos(line, ch)
8823
- }
8824
- }
8825
- }
8826
- }
8827
- var found = find(textNode, topNode, offset)
8828
- if (found) { return badPos(found, bad) }
8829
-
8830
- // FIXME this is all really shaky. might handle the few cases it needs to handle, but likely to cause problems
8831
- for (var after = topNode.nextSibling, dist = textNode ? textNode.nodeValue.length - offset : 0; after; after = after.nextSibling) {
8832
- found = find(after, after.firstChild, 0)
8833
- if (found)
8834
- { return badPos(Pos(found.line, found.ch - dist), bad) }
8835
- else
8836
- { dist += after.textContent.length }
8837
- }
8838
- for (var before = topNode.previousSibling, dist$1 = offset; before; before = before.previousSibling) {
8839
- found = find(before, before.firstChild, -1)
8840
- if (found)
8841
- { return badPos(Pos(found.line, found.ch + dist$1), bad) }
8842
- else
8843
- { dist$1 += before.textContent.length }
8844
- }
8845
- }
8846
-
8847
- // TEXTAREA INPUT STYLE
8848
-
8849
- var TextareaInput = function(cm) {
8850
- this.cm = cm
8851
- // See input.poll and input.reset
8852
- this.prevInput = ""
8853
-
8854
- // Flag that indicates whether we expect input to appear real soon
8855
- // now (after some event like 'keypress' or 'input') and are
8856
- // polling intensively.
8857
- this.pollingFast = false
8858
- // Self-resetting timeout for the poller
8859
- this.polling = new Delayed()
8860
- // Tracks when input.reset has punted to just putting a short
8861
- // string into the textarea instead of the full selection.
8862
- this.inaccurateSelection = false
8863
- // Used to work around IE issue with selection being forgotten when focus moves away from textarea
8864
- this.hasSelection = false
8865
- this.composing = null
8866
- };
8867
-
8868
- TextareaInput.prototype.init = function (display) {
8869
- var this$1 = this;
8870
-
8871
- var input = this, cm = this.cm
8872
-
8873
- // Wraps and hides input textarea
8874
- var div = this.wrapper = hiddenTextarea()
8875
- // The semihidden textarea that is focused when the editor is
8876
- // focused, and receives input.
8877
- var te = this.textarea = div.firstChild
8878
- display.wrapper.insertBefore(div, display.wrapper.firstChild)
8879
-
8880
- // Needed to hide big blue blinking cursor on Mobile Safari (doesn't seem to work in iOS 8 anymore)
8881
- if (ios) { te.style.width = "0px" }
8882
-
8883
- on(te, "input", function () {
8884
- if (ie && ie_version >= 9 && this$1.hasSelection) { this$1.hasSelection = null }
8885
- input.poll()
8886
- })
8887
-
8888
- on(te, "paste", function (e) {
8889
- if (signalDOMEvent(cm, e) || handlePaste(e, cm)) { return }
8890
-
8891
- cm.state.pasteIncoming = true
8892
- input.fastPoll()
8893
- })
8894
-
8895
- function prepareCopyCut(e) {
8896
- if (signalDOMEvent(cm, e)) { return }
8897
- if (cm.somethingSelected()) {
8898
- setLastCopied({lineWise: false, text: cm.getSelections()})
8899
- if (input.inaccurateSelection) {
8900
- input.prevInput = ""
8901
- input.inaccurateSelection = false
8902
- te.value = lastCopied.text.join("\n")
8903
- selectInput(te)
8904
- }
8905
- } else if (!cm.options.lineWiseCopyCut) {
8906
- return
8907
- } else {
8908
- var ranges = copyableRanges(cm)
8909
- setLastCopied({lineWise: true, text: ranges.text})
8910
- if (e.type == "cut") {
8911
- cm.setSelections(ranges.ranges, null, sel_dontScroll)
8912
- } else {
8913
- input.prevInput = ""
8914
- te.value = ranges.text.join("\n")
8915
- selectInput(te)
8916
- }
8917
- }
8918
- if (e.type == "cut") { cm.state.cutIncoming = true }
8919
- }
8920
- on(te, "cut", prepareCopyCut)
8921
- on(te, "copy", prepareCopyCut)
8922
-
8923
- on(display.scroller, "paste", function (e) {
8924
- if (eventInWidget(display, e) || signalDOMEvent(cm, e)) { return }
8925
- cm.state.pasteIncoming = true
8926
- input.focus()
8927
- })
8928
-
8929
- // Prevent normal selection in the editor (we handle our own)
8930
- on(display.lineSpace, "selectstart", function (e) {
8931
- if (!eventInWidget(display, e)) { e_preventDefault(e) }
8932
- })
8933
-
8934
- on(te, "compositionstart", function () {
8935
- var start = cm.getCursor("from")
8936
- if (input.composing) { input.composing.range.clear() }
8937
- input.composing = {
8938
- start: start,
8939
- range: cm.markText(start, cm.getCursor("to"), {className: "CodeMirror-composing"})
8940
- }
8941
- })
8942
- on(te, "compositionend", function () {
8943
- if (input.composing) {
8944
- input.poll()
8945
- input.composing.range.clear()
8946
- input.composing = null
8947
- }
8948
- })
8949
- };
8950
-
8951
- TextareaInput.prototype.prepareSelection = function () {
8952
- // Redraw the selection and/or cursor
8953
- var cm = this.cm, display = cm.display, doc = cm.doc
8954
- var result = prepareSelection(cm)
8955
-
8956
- // Move the hidden textarea near the cursor to prevent scrolling artifacts
8957
- if (cm.options.moveInputWithCursor) {
8958
- var headPos = cursorCoords(cm, doc.sel.primary().head, "div")
8959
- var wrapOff = display.wrapper.getBoundingClientRect(), lineOff = display.lineDiv.getBoundingClientRect()
8960
- result.teTop = Math.max(0, Math.min(display.wrapper.clientHeight - 10,
8961
- headPos.top + lineOff.top - wrapOff.top))
8962
- result.teLeft = Math.max(0, Math.min(display.wrapper.clientWidth - 10,
8963
- headPos.left + lineOff.left - wrapOff.left))
8964
- }
8965
-
8966
- return result
8967
- };
8968
-
8969
- TextareaInput.prototype.showSelection = function (drawn) {
8970
- var cm = this.cm, display = cm.display
8971
- removeChildrenAndAdd(display.cursorDiv, drawn.cursors)
8972
- removeChildrenAndAdd(display.selectionDiv, drawn.selection)
8973
- if (drawn.teTop != null) {
8974
- this.wrapper.style.top = drawn.teTop + "px"
8975
- this.wrapper.style.left = drawn.teLeft + "px"
8976
- }
8977
- };
8978
-
8979
- // Reset the input to correspond to the selection (or to be empty,
8980
- // when not typing and nothing is selected)
8981
- TextareaInput.prototype.reset = function (typing) {
8982
- if (this.contextMenuPending || this.composing) { return }
8983
- var minimal, selected, cm = this.cm, doc = cm.doc
8984
- if (cm.somethingSelected()) {
8985
- this.prevInput = ""
8986
- var range = doc.sel.primary()
8987
- minimal = hasCopyEvent &&
8988
- (range.to().line - range.from().line > 100 || (selected = cm.getSelection()).length > 1000)
8989
- var content = minimal ? "-" : selected || cm.getSelection()
8990
- this.textarea.value = content
8991
- if (cm.state.focused) { selectInput(this.textarea) }
8992
- if (ie && ie_version >= 9) { this.hasSelection = content }
8993
- } else if (!typing) {
8994
- this.prevInput = this.textarea.value = ""
8995
- if (ie && ie_version >= 9) { this.hasSelection = null }
8996
- }
8997
- this.inaccurateSelection = minimal
8998
- };
8999
-
9000
- TextareaInput.prototype.getField = function () { return this.textarea };
9001
-
9002
- TextareaInput.prototype.supportsTouch = function () { return false };
9003
-
9004
- TextareaInput.prototype.focus = function () {
9005
- if (this.cm.options.readOnly != "nocursor" && (!mobile || activeElt() != this.textarea)) {
9006
- try { this.textarea.focus() }
9007
- catch (e) {} // IE8 will throw if the textarea is display: none or not in DOM
9008
- }
9009
- };
9010
-
9011
- TextareaInput.prototype.blur = function () { this.textarea.blur() };
9012
-
9013
- TextareaInput.prototype.resetPosition = function () {
9014
- this.wrapper.style.top = this.wrapper.style.left = 0
9015
- };
9016
-
9017
- TextareaInput.prototype.receivedFocus = function () { this.slowPoll() };
9018
-
9019
- // Poll for input changes, using the normal rate of polling. This
9020
- // runs as long as the editor is focused.
9021
- TextareaInput.prototype.slowPoll = function () {
9022
- var this$1 = this;
9023
-
9024
- if (this.pollingFast) { return }
9025
- this.polling.set(this.cm.options.pollInterval, function () {
9026
- this$1.poll()
9027
- if (this$1.cm.state.focused) { this$1.slowPoll() }
9028
- })
9029
- };
9030
-
9031
- // When an event has just come in that is likely to add or change
9032
- // something in the input textarea, we poll faster, to ensure that
9033
- // the change appears on the screen quickly.
9034
- TextareaInput.prototype.fastPoll = function () {
9035
- var missed = false, input = this
9036
- input.pollingFast = true
9037
- function p() {
9038
- var changed = input.poll()
9039
- if (!changed && !missed) {missed = true; input.polling.set(60, p)}
9040
- else {input.pollingFast = false; input.slowPoll()}
9041
- }
9042
- input.polling.set(20, p)
9043
- };
9044
-
9045
- // Read input from the textarea, and update the document to match.
9046
- // When something is selected, it is present in the textarea, and
9047
- // selected (unless it is huge, in which case a placeholder is
9048
- // used). When nothing is selected, the cursor sits after previously
9049
- // seen text (can be empty), which is stored in prevInput (we must
9050
- // not reset the textarea when typing, because that breaks IME).
9051
- TextareaInput.prototype.poll = function () {
9052
- var this$1 = this;
9053
-
9054
- var cm = this.cm, input = this.textarea, prevInput = this.prevInput
9055
- // Since this is called a *lot*, try to bail out as cheaply as
9056
- // possible when it is clear that nothing happened. hasSelection
9057
- // will be the case when there is a lot of text in the textarea,
9058
- // in which case reading its value would be expensive.
9059
- if (this.contextMenuPending || !cm.state.focused ||
9060
- (hasSelection(input) && !prevInput && !this.composing) ||
9061
- cm.isReadOnly() || cm.options.disableInput || cm.state.keySeq)
9062
- { return false }
9063
-
9064
- var text = input.value
9065
- // If nothing changed, bail.
9066
- if (text == prevInput && !cm.somethingSelected()) { return false }
9067
- // Work around nonsensical selection resetting in IE9/10, and
9068
- // inexplicable appearance of private area unicode characters on
9069
- // some key combos in Mac (#2689).
9070
- if (ie && ie_version >= 9 && this.hasSelection === text ||
9071
- mac && /[\uf700-\uf7ff]/.test(text)) {
9072
- cm.display.input.reset()
9073
- return false
9074
- }
9075
-
9076
- if (cm.doc.sel == cm.display.selForContextMenu) {
9077
- var first = text.charCodeAt(0)
9078
- if (first == 0x200b && !prevInput) { prevInput = "\u200b" }
9079
- if (first == 0x21da) { this.reset(); return this.cm.execCommand("undo") }
9080
- }
9081
- // Find the part of the input that is actually new
9082
- var same = 0, l = Math.min(prevInput.length, text.length)
9083
- while (same < l && prevInput.charCodeAt(same) == text.charCodeAt(same)) { ++same }
9084
-
9085
- runInOp(cm, function () {
9086
- applyTextInput(cm, text.slice(same), prevInput.length - same,
9087
- null, this$1.composing ? "*compose" : null)
9088
-
9089
- // Don't leave long text in the textarea, since it makes further polling slow
9090
- if (text.length > 1000 || text.indexOf("\n") > -1) { input.value = this$1.prevInput = "" }
9091
- else { this$1.prevInput = text }
9092
-
9093
- if (this$1.composing) {
9094
- this$1.composing.range.clear()
9095
- this$1.composing.range = cm.markText(this$1.composing.start, cm.getCursor("to"),
9096
- {className: "CodeMirror-composing"})
9097
- }
9098
- })
9099
- return true
9100
- };
9101
-
9102
- TextareaInput.prototype.ensurePolled = function () {
9103
- if (this.pollingFast && this.poll()) { this.pollingFast = false }
9104
- };
9105
-
9106
- TextareaInput.prototype.onKeyPress = function () {
9107
- if (ie && ie_version >= 9) { this.hasSelection = null }
9108
- this.fastPoll()
9109
- };
9110
-
9111
- TextareaInput.prototype.onContextMenu = function (e) {
9112
- var input = this, cm = input.cm, display = cm.display, te = input.textarea
9113
- var pos = posFromMouse(cm, e), scrollPos = display.scroller.scrollTop
9114
- if (!pos || presto) { return } // Opera is difficult.
9115
-
9116
- // Reset the current text selection only if the click is done outside of the selection
9117
- // and 'resetSelectionOnContextMenu' option is true.
9118
- var reset = cm.options.resetSelectionOnContextMenu
9119
- if (reset && cm.doc.sel.contains(pos) == -1)
9120
- { operation(cm, setSelection)(cm.doc, simpleSelection(pos), sel_dontScroll) }
9121
-
9122
- var oldCSS = te.style.cssText, oldWrapperCSS = input.wrapper.style.cssText
9123
- input.wrapper.style.cssText = "position: absolute"
9124
- var wrapperBox = input.wrapper.getBoundingClientRect()
9125
- te.style.cssText = "position: absolute; width: 30px; height: 30px;\n top: " + (e.clientY - wrapperBox.top - 5) + "px; left: " + (e.clientX - wrapperBox.left - 5) + "px;\n z-index: 1000; background: " + (ie ? "rgba(255, 255, 255, .05)" : "transparent") + ";\n outline: none; border-width: 0; outline: none; overflow: hidden; opacity: .05; filter: alpha(opacity=5);"
9126
- var oldScrollY
9127
- if (webkit) { oldScrollY = window.scrollY } // Work around Chrome issue (#2712)
9128
- display.input.focus()
9129
- if (webkit) { window.scrollTo(null, oldScrollY) }
9130
- display.input.reset()
9131
- // Adds "Select all" to context menu in FF
9132
- if (!cm.somethingSelected()) { te.value = input.prevInput = " " }
9133
- input.contextMenuPending = true
9134
- display.selForContextMenu = cm.doc.sel
9135
- clearTimeout(display.detectingSelectAll)
9136
-
9137
- // Select-all will be greyed out if there's nothing to select, so
9138
- // this adds a zero-width space so that we can later check whether
9139
- // it got selected.
9140
- function prepareSelectAllHack() {
9141
- if (te.selectionStart != null) {
9142
- var selected = cm.somethingSelected()
9143
- var extval = "\u200b" + (selected ? te.value : "")
9144
- te.value = "\u21da" // Used to catch context-menu undo
9145
- te.value = extval
9146
- input.prevInput = selected ? "" : "\u200b"
9147
- te.selectionStart = 1; te.selectionEnd = extval.length
9148
- // Re-set this, in case some other handler touched the
9149
- // selection in the meantime.
9150
- display.selForContextMenu = cm.doc.sel
9151
- }
9152
- }
9153
- function rehide() {
9154
- input.contextMenuPending = false
9155
- input.wrapper.style.cssText = oldWrapperCSS
9156
- te.style.cssText = oldCSS
9157
- if (ie && ie_version < 9) { display.scrollbars.setScrollTop(display.scroller.scrollTop = scrollPos) }
9158
-
9159
- // Try to detect the user choosing select-all
9160
- if (te.selectionStart != null) {
9161
- if (!ie || (ie && ie_version < 9)) { prepareSelectAllHack() }
9162
- var i = 0, poll = function () {
9163
- if (display.selForContextMenu == cm.doc.sel && te.selectionStart == 0 &&
9164
- te.selectionEnd > 0 && input.prevInput == "\u200b") {
9165
- operation(cm, selectAll)(cm)
9166
- } else if (i++ < 10) {
9167
- display.detectingSelectAll = setTimeout(poll, 500)
9168
- } else {
9169
- display.selForContextMenu = null
9170
- display.input.reset()
9171
- }
9172
- }
9173
- display.detectingSelectAll = setTimeout(poll, 200)
9174
- }
9175
- }
9176
-
9177
- if (ie && ie_version >= 9) { prepareSelectAllHack() }
9178
- if (captureRightClick) {
9179
- e_stop(e)
9180
- var mouseup = function () {
9181
- off(window, "mouseup", mouseup)
9182
- setTimeout(rehide, 20)
9183
- }
9184
- on(window, "mouseup", mouseup)
9185
- } else {
9186
- setTimeout(rehide, 50)
9187
- }
9188
- };
9189
-
9190
- TextareaInput.prototype.readOnlyChanged = function (val) {
9191
- if (!val) { this.reset() }
9192
- };
9193
-
9194
- TextareaInput.prototype.setUneditable = function () {};
9195
-
9196
- TextareaInput.prototype.needsContentAttribute = false
9197
-
9198
- function fromTextArea(textarea, options) {
9199
- options = options ? copyObj(options) : {}
9200
- options.value = textarea.value
9201
- if (!options.tabindex && textarea.tabIndex)
9202
- { options.tabindex = textarea.tabIndex }
9203
- if (!options.placeholder && textarea.placeholder)
9204
- { options.placeholder = textarea.placeholder }
9205
- // Set autofocus to true if this textarea is focused, or if it has
9206
- // autofocus and no other element is focused.
9207
- if (options.autofocus == null) {
9208
- var hasFocus = activeElt()
9209
- options.autofocus = hasFocus == textarea ||
9210
- textarea.getAttribute("autofocus") != null && hasFocus == document.body
9211
- }
9212
-
9213
- function save() {textarea.value = cm.getValue()}
9214
-
9215
- var realSubmit
9216
- if (textarea.form) {
9217
- on(textarea.form, "submit", save)
9218
- // Deplorable hack to make the submit method do the right thing.
9219
- if (!options.leaveSubmitMethodAlone) {
9220
- var form = textarea.form
9221
- realSubmit = form.submit
9222
- try {
9223
- var wrappedSubmit = form.submit = function () {
9224
- save()
9225
- form.submit = realSubmit
9226
- form.submit()
9227
- form.submit = wrappedSubmit
9228
- }
9229
- } catch(e) {}
9230
- }
9231
- }
9232
-
9233
- options.finishInit = function (cm) {
9234
- cm.save = save
9235
- cm.getTextArea = function () { return textarea; }
9236
- cm.toTextArea = function () {
9237
- cm.toTextArea = isNaN // Prevent this from being ran twice
9238
- save()
9239
- textarea.parentNode.removeChild(cm.getWrapperElement())
9240
- textarea.style.display = ""
9241
- if (textarea.form) {
9242
- off(textarea.form, "submit", save)
9243
- if (typeof textarea.form.submit == "function")
9244
- { textarea.form.submit = realSubmit }
9245
- }
9246
- }
9247
- }
9248
-
9249
- textarea.style.display = "none"
9250
- var cm = CodeMirror(function (node) { return textarea.parentNode.insertBefore(node, textarea.nextSibling); },
9251
- options)
9252
- return cm
9253
- }
9254
-
9255
- function addLegacyProps(CodeMirror) {
9256
- CodeMirror.off = off
9257
- CodeMirror.on = on
9258
- CodeMirror.wheelEventPixels = wheelEventPixels
9259
- CodeMirror.Doc = Doc
9260
- CodeMirror.splitLines = splitLinesAuto
9261
- CodeMirror.countColumn = countColumn
9262
- CodeMirror.findColumn = findColumn
9263
- CodeMirror.isWordChar = isWordCharBasic
9264
- CodeMirror.Pass = Pass
9265
- CodeMirror.signal = signal
9266
- CodeMirror.Line = Line
9267
- CodeMirror.changeEnd = changeEnd
9268
- CodeMirror.scrollbarModel = scrollbarModel
9269
- CodeMirror.Pos = Pos
9270
- CodeMirror.cmpPos = cmp
9271
- CodeMirror.modes = modes
9272
- CodeMirror.mimeModes = mimeModes
9273
- CodeMirror.resolveMode = resolveMode
9274
- CodeMirror.getMode = getMode
9275
- CodeMirror.modeExtensions = modeExtensions
9276
- CodeMirror.extendMode = extendMode
9277
- CodeMirror.copyState = copyState
9278
- CodeMirror.startState = startState
9279
- CodeMirror.innerMode = innerMode
9280
- CodeMirror.commands = commands
9281
- CodeMirror.keyMap = keyMap
9282
- CodeMirror.keyName = keyName
9283
- CodeMirror.isModifierKey = isModifierKey
9284
- CodeMirror.lookupKey = lookupKey
9285
- CodeMirror.normalizeKeyMap = normalizeKeyMap
9286
- CodeMirror.StringStream = StringStream
9287
- CodeMirror.SharedTextMarker = SharedTextMarker
9288
- CodeMirror.TextMarker = TextMarker
9289
- CodeMirror.LineWidget = LineWidget
9290
- CodeMirror.e_preventDefault = e_preventDefault
9291
- CodeMirror.e_stopPropagation = e_stopPropagation
9292
- CodeMirror.e_stop = e_stop
9293
- CodeMirror.addClass = addClass
9294
- CodeMirror.contains = contains
9295
- CodeMirror.rmClass = rmClass
9296
- CodeMirror.keyNames = keyNames
9297
- }
9298
-
9299
- // EDITOR CONSTRUCTOR
9300
-
9301
- defineOptions(CodeMirror)
9302
-
9303
- addEditorMethods(CodeMirror)
9304
-
9305
- // Set up methods on CodeMirror's prototype to redirect to the editor's document.
9306
- var dontDelegate = "iter insert remove copy getEditor constructor".split(" ")
9307
- for (var prop in Doc.prototype) { if (Doc.prototype.hasOwnProperty(prop) && indexOf(dontDelegate, prop) < 0)
9308
- { CodeMirror.prototype[prop] = (function(method) {
9309
- return function() {return method.apply(this.doc, arguments)}
9310
- })(Doc.prototype[prop]) } }
9311
-
9312
- eventMixin(Doc)
9313
-
9314
- // INPUT HANDLING
9315
-
9316
- CodeMirror.inputStyles = {"textarea": TextareaInput, "contenteditable": ContentEditableInput}
9317
-
9318
- // MODE DEFINITION AND QUERYING
9319
-
9320
- // Extra arguments are stored as the mode's dependencies, which is
9321
- // used by (legacy) mechanisms like loadmode.js to automatically
9322
- // load a mode. (Preferred mechanism is the require/define calls.)
9323
- CodeMirror.defineMode = function(name/*, mode, …*/) {
9324
- if (!CodeMirror.defaults.mode && name != "null") { CodeMirror.defaults.mode = name }
9325
- defineMode.apply(this, arguments)
9326
- }
9327
-
9328
- CodeMirror.defineMIME = defineMIME
9329
-
9330
- // Minimal default mode.
9331
- CodeMirror.defineMode("null", function () { return ({token: function (stream) { return stream.skipToEnd(); }}); })
9332
- CodeMirror.defineMIME("text/plain", "null")
9333
-
9334
- // EXTENSIONS
9335
-
9336
- CodeMirror.defineExtension = function (name, func) {
9337
- CodeMirror.prototype[name] = func
9338
- }
9339
- CodeMirror.defineDocExtension = function (name, func) {
9340
- Doc.prototype[name] = func
9341
- }
9342
-
9343
- CodeMirror.fromTextArea = fromTextArea
9344
-
9345
- addLegacyProps(CodeMirror)
9346
-
9347
- CodeMirror.version = "5.26.0"
9348
-
9349
- return CodeMirror;
9350
-
9351
- })));
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
includes/js/codemirror/css.js DELETED
@@ -1,830 +0,0 @@
1
- // CodeMirror, copyright (c) by Marijn Haverbeke and others
2
- // Distributed under an MIT license: http://codemirror.net/LICENSE
3
-
4
- (function(mod) {
5
- if (typeof exports == "object" && typeof module == "object") // CommonJS
6
- mod(require("../../lib/codemirror"));
7
- else if (typeof define == "function" && define.amd) // AMD
8
- define(["../../lib/codemirror"], mod);
9
- else // Plain browser env
10
- mod(CodeMirror);
11
- })(function(CodeMirror) {
12
- "use strict";
13
-
14
- CodeMirror.defineMode("css", function(config, parserConfig) {
15
- var inline = parserConfig.inline
16
- if (!parserConfig.propertyKeywords) parserConfig = CodeMirror.resolveMode("text/css");
17
-
18
- var indentUnit = config.indentUnit,
19
- tokenHooks = parserConfig.tokenHooks,
20
- documentTypes = parserConfig.documentTypes || {},
21
- mediaTypes = parserConfig.mediaTypes || {},
22
- mediaFeatures = parserConfig.mediaFeatures || {},
23
- mediaValueKeywords = parserConfig.mediaValueKeywords || {},
24
- propertyKeywords = parserConfig.propertyKeywords || {},
25
- nonStandardPropertyKeywords = parserConfig.nonStandardPropertyKeywords || {},
26
- fontProperties = parserConfig.fontProperties || {},
27
- counterDescriptors = parserConfig.counterDescriptors || {},
28
- colorKeywords = parserConfig.colorKeywords || {},
29
- valueKeywords = parserConfig.valueKeywords || {},
30
- allowNested = parserConfig.allowNested,
31
- lineComment = parserConfig.lineComment,
32
- supportsAtComponent = parserConfig.supportsAtComponent === true;
33
-
34
- var type, override;
35
- function ret(style, tp) { type = tp; return style; }
36
-
37
- // Tokenizers
38
-
39
- function tokenBase(stream, state) {
40
- var ch = stream.next();
41
- if (tokenHooks[ch]) {
42
- var result = tokenHooks[ch](stream, state);
43
- if (result !== false) return result;
44
- }
45
- if (ch == "@") {
46
- stream.eatWhile(/[\w\\\-]/);
47
- return ret("def", stream.current());
48
- } else if (ch == "=" || (ch == "~" || ch == "|") && stream.eat("=")) {
49
- return ret(null, "compare");
50
- } else if (ch == "\"" || ch == "'") {
51
- state.tokenize = tokenString(ch);
52
- return state.tokenize(stream, state);
53
- } else if (ch == "#") {
54
- stream.eatWhile(/[\w\\\-]/);
55
- return ret("atom", "hash");
56
- } else if (ch == "!") {
57
- stream.match(/^\s*\w*/);
58
- return ret("keyword", "important");
59
- } else if (/\d/.test(ch) || ch == "." && stream.eat(/\d/)) {
60
- stream.eatWhile(/[\w.%]/);
61
- return ret("number", "unit");
62
- } else if (ch === "-") {
63
- if (/[\d.]/.test(stream.peek())) {
64
- stream.eatWhile(/[\w.%]/);
65
- return ret("number", "unit");
66
- } else if (stream.match(/^-[\w\\\-]+/)) {
67
- stream.eatWhile(/[\w\\\-]/);
68
- if (stream.match(/^\s*:/, false))
69
- return ret("variable-2", "variable-definition");
70
- return ret("variable-2", "variable");
71
- } else if (stream.match(/^\w+-/)) {
72
- return ret("meta", "meta");
73
- }
74
- } else if (/[,+>*\/]/.test(ch)) {
75
- return ret(null, "select-op");
76
- } else if (ch == "." && stream.match(/^-?[_a-z][_a-z0-9-]*/i)) {
77
- return ret("qualifier", "qualifier");
78
- } else if (/[:;{}\[\]\(\)]/.test(ch)) {
79
- return ret(null, ch);
80
- } else if ((ch == "u" && stream.match(/rl(-prefix)?\(/)) ||
81
- (ch == "d" && stream.match("omain(")) ||
82
- (ch == "r" && stream.match("egexp("))) {
83
- stream.backUp(1);
84
- state.tokenize = tokenParenthesized;
85
- return ret("property", "word");
86
- } else if (/[\w\\\-]/.test(ch)) {
87
- stream.eatWhile(/[\w\\\-]/);
88
- return ret("property", "word");
89
- } else {
90
- return ret(null, null);
91
- }
92
- }
93
-
94
- function tokenString(quote) {
95
- return function(stream, state) {
96
- var escaped = false, ch;
97
- while ((ch = stream.next()) != null) {
98
- if (ch == quote && !escaped) {
99
- if (quote == ")") stream.backUp(1);
100
- break;
101
- }
102
- escaped = !escaped && ch == "\\";
103
- }
104
- if (ch == quote || !escaped && quote != ")") state.tokenize = null;
105
- return ret("string", "string");
106
- };
107
- }
108
-
109
- function tokenParenthesized(stream, state) {
110
- stream.next(); // Must be '('
111
- if (!stream.match(/\s*[\"\')]/, false))
112
- state.tokenize = tokenString(")");
113
- else
114
- state.tokenize = null;
115
- return ret(null, "(");
116
- }
117
-
118
- // Context management
119
-
120
- function Context(type, indent, prev) {
121
- this.type = type;
122
- this.indent = indent;
123
- this.prev = prev;
124
- }
125
-
126
- function pushContext(state, stream, type, indent) {
127
- state.context = new Context(type, stream.indentation() + (indent === false ? 0 : indentUnit), state.context);
128
- return type;
129
- }
130
-
131
- function popContext(state) {
132
- if (state.context.prev)
133
- state.context = state.context.prev;
134
- return state.context.type;
135
- }
136
-
137
- function pass(type, stream, state) {
138
- return states[state.context.type](type, stream, state);
139
- }
140
- function popAndPass(type, stream, state, n) {
141
- for (var i = n || 1; i > 0; i--)
142
- state.context = state.context.prev;
143
- return pass(type, stream, state);
144
- }
145
-
146
- // Parser
147
-
148
- function wordAsValue(stream) {
149
- var word = stream.current().toLowerCase();
150
- if (valueKeywords.hasOwnProperty(word))
151
- override = "atom";
152
- else if (colorKeywords.hasOwnProperty(word))
153
- override = "keyword";
154
- else
155
- override = "variable";
156
- }
157
-
158
- var states = {};
159
-
160
- states.top = function(type, stream, state) {
161
- if (type == "{") {
162
- return pushContext(state, stream, "block");
163
- } else if (type == "}" && state.context.prev) {
164
- return popContext(state);
165
- } else if (supportsAtComponent && /@component/.test(type)) {
166
- return pushContext(state, stream, "atComponentBlock");
167
- } else if (/^@(-moz-)?document$/.test(type)) {
168
- return pushContext(state, stream, "documentTypes");
169
- } else if (/^@(media|supports|(-moz-)?document|import)$/.test(type)) {
170
- return pushContext(state, stream, "atBlock");
171
- } else if (/^@(font-face|counter-style)/.test(type)) {
172
- state.stateArg = type;
173
- return "restricted_atBlock_before";
174
- } else if (/^@(-(moz|ms|o|webkit)-)?keyframes$/.test(type)) {
175
- return "keyframes";
176
- } else if (type && type.charAt(0) == "@") {
177
- return pushContext(state, stream, "at");
178
- } else if (type == "hash") {
179
- override = "builtin";
180
- } else if (type == "word") {
181
- override = "tag";
182
- } else if (type == "variable-definition") {
183
- return "maybeprop";
184
- } else if (type == "interpolation") {
185
- return pushContext(state, stream, "interpolation");
186
- } else if (type == ":") {
187
- return "pseudo";
188
- } else if (allowNested && type == "(") {
189
- return pushContext(state, stream, "parens");
190
- }
191
- return state.context.type;
192
- };
193
-
194
- states.block = function(type, stream, state) {
195
- if (type == "word") {
196
- var word = stream.current().toLowerCase();
197
- if (propertyKeywords.hasOwnProperty(word)) {
198
- override = "property";
199
- return "maybeprop";
200
- } else if (nonStandardPropertyKeywords.hasOwnProperty(word)) {
201
- override = "string-2";
202
- return "maybeprop";
203
- } else if (allowNested) {
204
- override = stream.match(/^\s*:(?:\s|$)/, false) ? "property" : "tag";
205
- return "block";
206
- } else {
207
- override += " error";
208
- return "maybeprop";
209
- }
210
- } else if (type == "meta") {
211
- return "block";
212
- } else if (!allowNested && (type == "hash" || type == "qualifier")) {
213
- override = "error";
214
- return "block";
215
- } else {
216
- return states.top(type, stream, state);
217
- }
218
- };
219
-
220
- states.maybeprop = function(type, stream, state) {
221
- if (type == ":") return pushContext(state, stream, "prop");
222
- return pass(type, stream, state);
223
- };
224
-
225
- states.prop = function(type, stream, state) {
226
- if (type == ";") return popContext(state);
227
- if (type == "{" && allowNested) return pushContext(state, stream, "propBlock");
228
- if (type == "}" || type == "{") return popAndPass(type, stream, state);
229
- if (type == "(") return pushContext(state, stream, "parens");
230
-
231
- if (type == "hash" && !/^#([0-9a-fA-f]{3,4}|[0-9a-fA-f]{6}|[0-9a-fA-f]{8})$/.test(stream.current())) {
232
- override += " error";
233
- } else if (type == "word") {
234
- wordAsValue(stream);
235
- } else if (type == "interpolation") {
236
- return pushContext(state, stream, "interpolation");
237
- }
238
- return "prop";
239
- };
240
-
241
- states.propBlock = function(type, _stream, state) {
242
- if (type == "}") return popContext(state);
243
- if (type == "word") { override = "property"; return "maybeprop"; }
244
- return state.context.type;
245
- };
246
-
247
- states.parens = function(type, stream, state) {
248
- if (type == "{" || type == "}") return popAndPass(type, stream, state);
249
- if (type == ")") return popContext(state);
250
- if (type == "(") return pushContext(state, stream, "parens");
251
- if (type == "interpolation") return pushContext(state, stream, "interpolation");
252
- if (type == "word") wordAsValue(stream);
253
- return "parens";
254
- };
255
-
256
- states.pseudo = function(type, stream, state) {
257
- if (type == "meta") return "pseudo";
258
-
259
- if (type == "word") {
260
- override = "variable-3";
261
- return state.context.type;
262
- }
263
- return pass(type, stream, state);
264
- };
265
-
266
- states.documentTypes = function(type, stream, state) {
267
- if (type == "word" && documentTypes.hasOwnProperty(stream.current())) {
268
- override = "tag";
269
- return state.context.type;
270
- } else {
271
- return states.atBlock(type, stream, state);
272
- }
273
- };
274
-
275
- states.atBlock = function(type, stream, state) {
276
- if (type == "(") return pushContext(state, stream, "atBlock_parens");
277
- if (type == "}" || type == ";") return popAndPass(type, stream, state);
278
- if (type == "{") return popContext(state) && pushContext(state, stream, allowNested ? "block" : "top");
279
-
280
- if (type == "interpolation") return pushContext(state, stream, "interpolation");
281
-
282
- if (type == "word") {
283
- var word = stream.current().toLowerCase();
284
- if (word == "only" || word == "not" || word == "and" || word == "or")
285
- override = "keyword";
286
- else if (mediaTypes.hasOwnProperty(word))
287
- override = "attribute";
288
- else if (mediaFeatures.hasOwnProperty(word))
289
- override = "property";
290
- else if (mediaValueKeywords.hasOwnProperty(word))
291
- override = "keyword";
292
- else if (propertyKeywords.hasOwnProperty(word))
293
- override = "property";
294
- else if (nonStandardPropertyKeywords.hasOwnProperty(word))
295
- override = "string-2";
296
- else if (valueKeywords.hasOwnProperty(word))
297
- override = "atom";
298
- else if (colorKeywords.hasOwnProperty(word))
299
- override = "keyword";
300
- else
301
- override = "error";
302
- }
303
- return state.context.type;
304
- };
305
-
306
- states.atComponentBlock = function(type, stream, state) {
307
- if (type == "}")
308
- return popAndPass(type, stream, state);
309
- if (type == "{")
310
- return popContext(state) && pushContext(state, stream, allowNested ? "block" : "top", false);
311
- if (type == "word")
312
- override = "error";
313
- return state.context.type;
314
- };
315
-
316
- states.atBlock_parens = function(type, stream, state) {
317
- if (type == ")") return popContext(state);
318
- if (type == "{" || type == "}") return popAndPass(type, stream, state, 2);
319
- return states.atBlock(type, stream, state);
320
- };
321
-
322
- states.restricted_atBlock_before = function(type, stream, state) {
323
- if (type == "{")
324
- return pushContext(state, stream, "restricted_atBlock");
325
- if (type == "word" && state.stateArg == "@counter-style") {
326
- override = "variable";
327
- return "restricted_atBlock_before";
328
- }
329
- return pass(type, stream, state);
330
- };
331
-
332
- states.restricted_atBlock = function(type, stream, state) {
333
- if (type == "}") {
334
- state.stateArg = null;
335
- return popContext(state);
336
- }
337
- if (type == "word") {
338
- if ((state.stateArg == "@font-face" && !fontProperties.hasOwnProperty(stream.current().toLowerCase())) ||
339
- (state.stateArg == "@counter-style" && !counterDescriptors.hasOwnProperty(stream.current().toLowerCase())))
340
- override = "error";
341
- else
342
- override = "property";
343
- return "maybeprop";
344
- }
345
- return "restricted_atBlock";
346
- };
347
-
348
- states.keyframes = function(type, stream, state) {
349
- if (type == "word") { override = "variable"; return "keyframes"; }
350
- if (type == "{") return pushContext(state, stream, "top");
351
- return pass(type, stream, state);
352
- };
353
-
354
- states.at = function(type, stream, state) {
355
- if (type == ";") return popContext(state);
356
- if (type == "{" || type == "}") return popAndPass(type, stream, state);
357
- if (type == "word") override = "tag";
358
- else if (type == "hash") override = "builtin";
359
- return "at";
360
- };
361
-
362
- states.interpolation = function(type, stream, state) {
363
- if (type == "}") return popContext(state);
364
- if (type == "{" || type == ";") return popAndPass(type, stream, state);
365
- if (type == "word") override = "variable";
366
- else if (type != "variable" && type != "(" && type != ")") override = "error";
367
- return "interpolation";
368
- };
369
-
370
- return {
371
- startState: function(base) {
372
- return {tokenize: null,
373
- state: inline ? "block" : "top",
374
- stateArg: null,
375
- context: new Context(inline ? "block" : "top", base || 0, null)};
376
- },
377
-
378
- token: function(stream, state) {
379
- if (!state.tokenize && stream.eatSpace()) return null;
380
- var style = (state.tokenize || tokenBase)(stream, state);
381
- if (style && typeof style == "object") {
382
- type = style[1];
383
- style = style[0];
384
- }
385
- override = style;
386
- state.state = states[state.state](type, stream, state);
387
- return override;
388
- },
389
-
390
- indent: function(state, textAfter) {
391
- var cx = state.context, ch = textAfter && textAfter.charAt(0);
392
- var indent = cx.indent;
393
- if (cx.type == "prop" && (ch == "}" || ch == ")")) cx = cx.prev;
394
- if (cx.prev) {
395
- if (ch == "}" && (cx.type == "block" || cx.type == "top" ||
396
- cx.type == "interpolation" || cx.type == "restricted_atBlock")) {
397
- // Resume indentation from parent context.
398
- cx = cx.prev;
399
- indent = cx.indent;
400
- } else if (ch == ")" && (cx.type == "parens" || cx.type == "atBlock_parens") ||
401
- ch == "{" && (cx.type == "at" || cx.type == "atBlock")) {
402
- // Dedent relative to current context.
403
- indent = Math.max(0, cx.indent - indentUnit);
404
- }
405
- }
406
- return indent;
407
- },
408
-
409
- electricChars: "}",
410
- blockCommentStart: "/*",
411
- blockCommentEnd: "*/",
412
- lineComment: lineComment,
413
- fold: "brace"
414
- };
415
- });
416
-
417
- function keySet(array) {
418
- var keys = {};
419
- for (var i = 0; i < array.length; ++i) {
420
- keys[array[i].toLowerCase()] = true;
421
- }
422
- return keys;
423
- }
424
-
425
- var documentTypes_ = [
426
- "domain", "regexp", "url", "url-prefix"
427
- ], documentTypes = keySet(documentTypes_);
428
-
429
- var mediaTypes_ = [
430
- "all", "aural", "braille", "handheld", "print", "projection", "screen",
431
- "tty", "tv", "embossed"
432
- ], mediaTypes = keySet(mediaTypes_);
433
-
434
- var mediaFeatures_ = [
435
- "width", "min-width", "max-width", "height", "min-height", "max-height",
436
- "device-width", "min-device-width", "max-device-width", "device-height",
437
- "min-device-height", "max-device-height", "aspect-ratio",
438
- "min-aspect-ratio", "max-aspect-ratio", "device-aspect-ratio",
439
- "min-device-aspect-ratio", "max-device-aspect-ratio", "color", "min-color",
440
- "max-color", "color-index", "min-color-index", "max-color-index",
441
- "monochrome", "min-monochrome", "max-monochrome", "resolution",
442
- "min-resolution", "max-resolution", "scan", "grid", "orientation",
443
- "device-pixel-ratio", "min-device-pixel-ratio", "max-device-pixel-ratio",
444
- "pointer", "any-pointer", "hover", "any-hover"
445
- ], mediaFeatures = keySet(mediaFeatures_);
446
-
447
- var mediaValueKeywords_ = [
448
- "landscape", "portrait", "none", "coarse", "fine", "on-demand", "hover",
449
- "interlace", "progressive"
450
- ], mediaValueKeywords = keySet(mediaValueKeywords_);
451
-
452
- var propertyKeywords_ = [
453
- "align-content", "align-items", "align-self", "alignment-adjust",
454
- "alignment-baseline", "anchor-point", "animation", "animation-delay",
455
- "animation-direction", "animation-duration", "animation-fill-mode",
456
- "animation-iteration-count", "animation-name", "animation-play-state",
457
- "animation-timing-function", "appearance", "azimuth", "backface-visibility",
458
- "background", "background-attachment", "background-blend-mode", "background-clip",
459
- "background-color", "background-image", "background-origin", "background-position",
460
- "background-repeat", "background-size", "baseline-shift", "binding",
461
- "bleed", "bookmark-label", "bookmark-level", "bookmark-state",
462
- "bookmark-target", "border", "border-bottom", "border-bottom-color",
463
- "border-bottom-left-radius", "border-bottom-right-radius",
464
- "border-bottom-style", "border-bottom-width", "border-collapse",
465
- "border-color", "border-image", "border-image-outset",
466
- "border-image-repeat", "border-image-slice", "border-image-source",
467
- "border-image-width", "border-left", "border-left-color",
468
- "border-left-style", "border-left-width", "border-radius", "border-right",
469
- "border-right-color", "border-right-style", "border-right-width",
470
- "border-spacing", "border-style", "border-top", "border-top-color",
471
- "border-top-left-radius", "border-top-right-radius", "border-top-style",
472
- "border-top-width", "border-width", "bottom", "box-decoration-break",
473
- "box-shadow", "box-sizing", "break-after", "break-before", "break-inside",
474
- "caption-side", "caret-color", "clear", "clip", "color", "color-profile", "column-count",
475
- "column-fill", "column-gap", "column-rule", "column-rule-color",
476
- "column-rule-style", "column-rule-width", "column-span", "column-width",
477
- "columns", "content", "counter-increment", "counter-reset", "crop", "cue",
478
- "cue-after", "cue-before", "cursor", "direction", "display",
479
- "dominant-baseline", "drop-initial-after-adjust",
480
- "drop-initial-after-align", "drop-initial-before-adjust",
481
- "drop-initial-before-align", "drop-initial-size", "drop-initial-value",
482
- "elevation", "empty-cells", "fit", "fit-position", "flex", "flex-basis",
483
- "flex-direction", "flex-flow", "flex-grow", "flex-shrink", "flex-wrap",
484
- "float", "float-offset", "flow-from", "flow-into", "font", "font-feature-settings",
485
- "font-family", "font-kerning", "font-language-override", "font-size", "font-size-adjust",
486
- "font-stretch", "font-style", "font-synthesis", "font-variant",
487
- "font-variant-alternates", "font-variant-caps", "font-variant-east-asian",
488
- "font-variant-ligatures", "font-variant-numeric", "font-variant-position",
489
- "font-weight", "grid", "grid-area", "grid-auto-columns", "grid-auto-flow",
490
- "grid-auto-rows", "grid-column", "grid-column-end", "grid-column-gap",
491
- "grid-column-start", "grid-gap", "grid-row", "grid-row-end", "grid-row-gap",
492
- "grid-row-start", "grid-template", "grid-template-areas", "grid-template-columns",
493
- "grid-template-rows", "hanging-punctuation", "height", "hyphens",
494
- "icon", "image-orientation", "image-rendering", "image-resolution",
495
- "inline-box-align", "justify-content", "justify-items", "justify-self", "left", "letter-spacing",
496
- "line-break", "line-height", "line-stacking", "line-stacking-ruby",
497
- "line-stacking-shift", "line-stacking-strategy", "list-style",
498
- "list-style-image", "list-style-position", "list-style-type", "margin",
499
- "margin-bottom", "margin-left", "margin-right", "margin-top",
500
- "marks", "marquee-direction", "marquee-loop",
501
- "marquee-play-count", "marquee-speed", "marquee-style", "max-height",
502
- "max-width", "min-height", "min-width", "move-to", "nav-down", "nav-index",
503
- "nav-left", "nav-right", "nav-up", "object-fit", "object-position",
504
- "opacity", "order", "orphans", "outline",
505
- "outline-color", "outline-offset", "outline-style", "outline-width",
506
- "overflow", "overflow-style", "overflow-wrap", "overflow-x", "overflow-y",
507
- "padding", "padding-bottom", "padding-left", "padding-right", "padding-top",
508
- "page", "page-break-after", "page-break-before", "page-break-inside",
509
- "page-policy", "pause", "pause-after", "pause-before", "perspective",
510
- "perspective-origin", "pitch", "pitch-range", "place-content", "place-items", "place-self", "play-during", "position",
511
- "presentation-level", "punctuation-trim", "quotes", "region-break-after",
512
- "region-break-before", "region-break-inside", "region-fragment",
513
- "rendering-intent", "resize", "rest", "rest-after", "rest-before", "richness",
514
- "right", "rotation", "rotation-point", "ruby-align", "ruby-overhang",
515
- "ruby-position", "ruby-span", "shape-image-threshold", "shape-inside", "shape-margin",
516
- "shape-outside", "size", "speak", "speak-as", "speak-header",
517
- "speak-numeral", "speak-punctuation", "speech-rate", "stress", "string-set",
518
- "tab-size", "table-layout", "target", "target-name", "target-new",
519
- "target-position", "text-align", "text-align-last", "text-decoration",
520
- "text-decoration-color", "text-decoration-line", "text-decoration-skip",
521
- "text-decoration-style", "text-emphasis", "text-emphasis-color",
522
- "text-emphasis-position", "text-emphasis-style", "text-height",
523
- "text-indent", "text-justify", "text-outline", "text-overflow", "text-shadow",
524
- "text-size-adjust", "text-space-collapse", "text-transform", "text-underline-position",
525
- "text-wrap", "top", "transform", "transform-origin", "transform-style",
526
- "transition", "transition-delay", "transition-duration",
527
- "transition-property", "transition-timing-function", "unicode-bidi",
528
- "user-select", "vertical-align", "visibility", "voice-balance", "voice-duration",
529
- "voice-family", "voice-pitch", "voice-range", "voice-rate", "voice-stress",
530
- "voice-volume", "volume", "white-space", "widows", "width", "will-change", "word-break",
531
- "word-spacing", "word-wrap", "z-index",
532
- // SVG-specific
533
- "clip-path", "clip-rule", "mask", "enable-background", "filter", "flood-color",
534
- "flood-opacity", "lighting-color", "stop-color", "stop-opacity", "pointer-events",
535
- "color-interpolation", "color-interpolation-filters",
536
- "color-rendering", "fill", "fill-opacity", "fill-rule", "image-rendering",
537
- "marker", "marker-end", "marker-mid", "marker-start", "shape-rendering", "stroke",
538
- "stroke-dasharray", "stroke-dashoffset", "stroke-linecap", "stroke-linejoin",
539
- "stroke-miterlimit", "stroke-opacity", "stroke-width", "text-rendering",
540
- "baseline-shift", "dominant-baseline", "glyph-orientation-horizontal",
541
- "glyph-orientation-vertical", "text-anchor", "writing-mode"
542
- ], propertyKeywords = keySet(propertyKeywords_);
543
-
544
- var nonStandardPropertyKeywords_ = [
545
- "scrollbar-arrow-color", "scrollbar-base-color", "scrollbar-dark-shadow-color",
546
- "scrollbar-face-color", "scrollbar-highlight-color", "scrollbar-shadow-color",
547
- "scrollbar-3d-light-color", "scrollbar-track-color", "shape-inside",
548
- "searchfield-cancel-button", "searchfield-decoration", "searchfield-results-button",
549
- "searchfield-results-decoration", "zoom"
550
- ], nonStandardPropertyKeywords = keySet(nonStandardPropertyKeywords_);
551
-
552
- var fontProperties_ = [
553
- "font-family", "src", "unicode-range", "font-variant", "font-feature-settings",
554
- "font-stretch", "font-weight", "font-style"
555
- ], fontProperties = keySet(fontProperties_);
556
-
557
- var counterDescriptors_ = [
558
- "additive-symbols", "fallback", "negative", "pad", "prefix", "range",
559
- "speak-as", "suffix", "symbols", "system"
560
- ], counterDescriptors = keySet(counterDescriptors_);
561
-
562
- var colorKeywords_ = [
563
- "aliceblue", "antiquewhite", "aqua", "aquamarine", "azure", "beige",
564
- "bisque", "black", "blanchedalmond", "blue", "blueviolet", "brown",
565
- "burlywood", "cadetblue", "chartreuse", "chocolate", "coral", "cornflowerblue",
566
- "cornsilk", "crimson", "cyan", "darkblue", "darkcyan", "darkgoldenrod",
567
- "darkgray", "darkgreen", "darkkhaki", "darkmagenta", "darkolivegreen",
568
- "darkorange", "darkorchid", "darkred", "darksalmon", "darkseagreen",
569
- "darkslateblue", "darkslategray", "darkturquoise", "darkviolet",
570
- "deeppink", "deepskyblue", "dimgray", "dodgerblue", "firebrick",
571
- "floralwhite", "forestgreen", "fuchsia", "gainsboro", "ghostwhite",
572
- "gold", "goldenrod", "gray", "grey", "green", "greenyellow", "honeydew",
573
- "hotpink", "indianred", "indigo", "ivory", "khaki", "lavender",
574
- "lavenderblush", "lawngreen", "lemonchiffon", "lightblue", "lightcoral",
575
- "lightcyan", "lightgoldenrodyellow", "lightgray", "lightgreen", "lightpink",
576
- "lightsalmon", "lightseagreen", "lightskyblue", "lightslategray",
577
- "lightsteelblue", "lightyellow", "lime", "limegreen", "linen", "magenta",
578
- "maroon", "mediumaquamarine", "mediumblue", "mediumorchid", "mediumpurple",
579
- "mediumseagreen", "mediumslateblue", "mediumspringgreen", "mediumturquoise",
580
- "mediumvioletred", "midnightblue", "mintcream", "mistyrose", "moccasin",
581
- "navajowhite", "navy", "oldlace", "olive", "olivedrab", "orange", "orangered",
582
- "orchid", "palegoldenrod", "palegreen", "paleturquoise", "palevioletred",
583
- "papayawhip", "peachpuff", "peru", "pink", "plum", "powderblue",
584
- "purple", "rebeccapurple", "red", "rosybrown", "royalblue", "saddlebrown",
585
- "salmon", "sandybrown", "seagreen", "seashell", "sienna", "silver", "skyblue",
586
- "slateblue", "slategray", "snow", "springgreen", "steelblue", "tan",
587
- "teal", "thistle", "tomato", "turquoise", "violet", "wheat", "white",
588
- "whitesmoke", "yellow", "yellowgreen"
589
- ], colorKeywords = keySet(colorKeywords_);
590
-
591
- var valueKeywords_ = [
592
- "above", "absolute", "activeborder", "additive", "activecaption", "afar",
593
- "after-white-space", "ahead", "alias", "all", "all-scroll", "alphabetic", "alternate",
594
- "always", "amharic", "amharic-abegede", "antialiased", "appworkspace",
595
- "arabic-indic", "armenian", "asterisks", "attr", "auto", "auto-flow", "avoid", "avoid-column", "avoid-page",
596
- "avoid-region", "background", "backwards", "baseline", "below", "bidi-override", "binary",
597
- "bengali", "blink", "block", "block-axis", "bold", "bolder", "border", "border-box",
598
- "both", "bottom", "break", "break-all", "break-word", "bullets", "button", "button-bevel",
599
- "buttonface", "buttonhighlight", "buttonshadow", "buttontext", "calc", "cambodian",
600
- "capitalize", "caps-lock-indicator", "caption", "captiontext", "caret",
601
- "cell", "center", "checkbox", "circle", "cjk-decimal", "cjk-earthly-branch",
602
- "cjk-heavenly-stem", "cjk-ideographic", "clear", "clip", "close-quote",
603
- "col-resize", "collapse", "color", "color-burn", "color-dodge", "column", "column-reverse",
604
- "compact", "condensed", "contain", "content", "contents",
605
- "content-box", "context-menu", "continuous", "copy", "counter", "counters", "cover", "crop",
606
- "cross", "crosshair", "currentcolor", "cursive", "cyclic", "darken", "dashed", "decimal",
607
- "decimal-leading-zero", "default", "default-button", "dense", "destination-atop",
608
- "destination-in", "destination-out", "destination-over", "devanagari", "difference",
609
- "disc", "discard", "disclosure-closed", "disclosure-open", "document",
610
- "dot-dash", "dot-dot-dash",
611
- "dotted", "double", "down", "e-resize", "ease", "ease-in", "ease-in-out", "ease-out",
612
- "element", "ellipse", "ellipsis", "embed", "end", "ethiopic", "ethiopic-abegede",
613
- "ethiopic-abegede-am-et", "ethiopic-abegede-gez", "ethiopic-abegede-ti-er",
614
- "ethiopic-abegede-ti-et", "ethiopic-halehame-aa-er",
615
- "ethiopic-halehame-aa-et", "ethiopic-halehame-am-et",
616
- "ethiopic-halehame-gez", "ethiopic-halehame-om-et",
617
- "ethiopic-halehame-sid-et", "ethiopic-halehame-so-et",
618
- "ethiopic-halehame-ti-er", "ethiopic-halehame-ti-et", "ethiopic-halehame-tig",
619
- "ethiopic-numeric", "ew-resize", "exclusion", "expanded", "extends", "extra-condensed",
620
- "extra-expanded", "fantasy", "fast", "fill", "fixed", "flat", "flex", "flex-end", "flex-start", "footnotes",
621
- "forwards", "from", "geometricPrecision", "georgian", "graytext", "grid", "groove",
622
- "gujarati", "gurmukhi", "hand", "hangul", "hangul-consonant", "hard-light", "hebrew",
623
- "help", "hidden", "hide", "higher", "highlight", "highlighttext",
624
- "hiragana", "hiragana-iroha", "horizontal", "hsl", "hsla", "hue", "icon", "ignore",
625
- "inactiveborder", "inactivecaption", "inactivecaptiontext", "infinite",
626
- "infobackground", "infotext", "inherit", "initial", "inline", "inline-axis",
627
- "inline-block", "inline-flex", "inline-grid", "inline-table", "inset", "inside", "intrinsic", "invert",
628
- "italic", "japanese-formal", "japanese-informal", "justify", "kannada",
629
- "katakana", "katakana-iroha", "keep-all", "khmer",
630
- "korean-hangul-formal", "korean-hanja-formal", "korean-hanja-informal",
631
- "landscape", "lao", "large", "larger", "left", "level", "lighter", "lighten",
632
- "line-through", "linear", "linear-gradient", "lines", "list-item", "listbox", "listitem",
633
- "local", "logical", "loud", "lower", "lower-alpha", "lower-armenian",
634
- "lower-greek", "lower-hexadecimal", "lower-latin", "lower-norwegian",
635
- "lower-roman", "lowercase", "ltr", "luminosity", "malayalam", "match", "matrix", "matrix3d",
636
- "media-controls-background", "media-current-time-display",
637
- "media-fullscreen-button", "media-mute-button", "media-play-button",
638
- "media-return-to-realtime-button", "media-rewind-button",
639
- "media-seek-back-button", "media-seek-forward-button", "media-slider",
640
- "media-sliderthumb", "media-time-remaining-display", "media-volume-slider",
641
- "media-volume-slider-container", "media-volume-sliderthumb", "medium",
642
- "menu", "menulist", "menulist-button", "menulist-text",
643
- "menulist-textfield", "menutext", "message-box", "middle", "min-intrinsic",
644
- "mix", "mongolian", "monospace", "move", "multiple", "multiply", "myanmar", "n-resize",
645
- "narrower", "ne-resize", "nesw-resize", "no-close-quote", "no-drop",
646
- "no-open-quote", "no-repeat", "none", "normal", "not-allowed", "nowrap",
647
- "ns-resize", "numbers", "numeric", "nw-resize", "nwse-resize", "oblique", "octal", "opacity", "open-quote",
648
- "optimizeLegibility", "optimizeSpeed", "oriya", "oromo", "outset",
649
- "outside", "outside-shape", "overlay", "overline", "padding", "padding-box",
650
- "painted", "page", "paused", "persian", "perspective", "plus-darker", "plus-lighter",
651
- "pointer", "polygon", "portrait", "pre", "pre-line", "pre-wrap", "preserve-3d",
652
- "progress", "push-button", "radial-gradient", "radio", "read-only",
653
- "read-write", "read-write-plaintext-only", "rectangle", "region",
654
- "relative", "repeat", "repeating-linear-gradient",
655
- "repeating-radial-gradient", "repeat-x", "repeat-y", "reset", "reverse",
656
- "rgb", "rgba", "ridge", "right", "rotate", "rotate3d", "rotateX", "rotateY",
657
- "rotateZ", "round", "row", "row-resize", "row-reverse", "rtl", "run-in", "running",
658
- "s-resize", "sans-serif", "saturation", "scale", "scale3d", "scaleX", "scaleY", "scaleZ", "screen",
659
- "scroll", "scrollbar", "scroll-position", "se-resize", "searchfield",
660
- "searchfield-cancel-button", "searchfield-decoration",
661
- "searchfield-results-button", "searchfield-results-decoration", "self-start", "self-end",
662
- "semi-condensed", "semi-expanded", "separate", "serif", "show", "sidama",
663
- "simp-chinese-formal", "simp-chinese-informal", "single",
664
- "skew", "skewX", "skewY", "skip-white-space", "slide", "slider-horizontal",
665
- "slider-vertical", "sliderthumb-horizontal", "sliderthumb-vertical", "slow",
666
- "small", "small-caps", "small-caption", "smaller", "soft-light", "solid", "somali",
667
- "source-atop", "source-in", "source-out", "source-over", "space", "space-around", "space-between", "space-evenly", "spell-out", "square",
668
- "square-button", "start", "static", "status-bar", "stretch", "stroke", "sub",
669
- "subpixel-antialiased", "super", "sw-resize", "symbolic", "symbols", "system-ui", "table",
670
- "table-caption", "table-cell", "table-column", "table-column-group",
671
- "table-footer-group", "table-header-group", "table-row", "table-row-group",
672
- "tamil",
673
- "telugu", "text", "text-bottom", "text-top", "textarea", "textfield", "thai",
674
- "thick", "thin", "threeddarkshadow", "threedface", "threedhighlight",
675
- "threedlightshadow", "threedshadow", "tibetan", "tigre", "tigrinya-er",
676
- "tigrinya-er-abegede", "tigrinya-et", "tigrinya-et-abegede", "to", "top",
677
- "trad-chinese-formal", "trad-chinese-informal", "transform",
678
- "translate", "translate3d", "translateX", "translateY", "translateZ",
679
- "transparent", "ultra-condensed", "ultra-expanded", "underline", "unset", "up",
680
- "upper-alpha", "upper-armenian", "upper-greek", "upper-hexadecimal",
681
- "upper-latin", "upper-norwegian", "upper-roman", "uppercase", "urdu", "url",
682
- "var", "vertical", "vertical-text", "visible", "visibleFill", "visiblePainted",
683
- "visibleStroke", "visual", "w-resize", "wait", "wave", "wider",
684
- "window", "windowframe", "windowtext", "words", "wrap", "wrap-reverse", "x-large", "x-small", "xor",
685
- "xx-large", "xx-small"
686
- ], valueKeywords = keySet(valueKeywords_);
687
-
688
- var allWords = documentTypes_.concat(mediaTypes_).concat(mediaFeatures_).concat(mediaValueKeywords_)
689
- .concat(propertyKeywords_).concat(nonStandardPropertyKeywords_).concat(colorKeywords_)
690
- .concat(valueKeywords_);
691
- CodeMirror.registerHelper("hintWords", "css", allWords);
692
-
693
- function tokenCComment(stream, state) {
694
- var maybeEnd = false, ch;
695
- while ((ch = stream.next()) != null) {
696
- if (maybeEnd && ch == "/") {
697
- state.tokenize = null;
698
- break;
699
- }
700
- maybeEnd = (ch == "*");
701
- }
702
- return ["comment", "comment"];
703
- }
704
-
705
- CodeMirror.defineMIME("text/css", {
706
- documentTypes: documentTypes,
707
- mediaTypes: mediaTypes,
708
- mediaFeatures: mediaFeatures,
709
- mediaValueKeywords: mediaValueKeywords,
710
- propertyKeywords: propertyKeywords,
711
- nonStandardPropertyKeywords: nonStandardPropertyKeywords,
712
- fontProperties: fontProperties,
713
- counterDescriptors: counterDescriptors,
714
- colorKeywords: colorKeywords,
715
- valueKeywords: valueKeywords,
716
- tokenHooks: {
717
- "/": function(stream, state) {
718
- if (!stream.eat("*")) return false;
719
- state.tokenize = tokenCComment;
720
- return tokenCComment(stream, state);
721
- }
722
- },
723
- name: "css"
724
- });
725
-
726
- CodeMirror.defineMIME("text/x-scss", {
727
- mediaTypes: mediaTypes,
728
- mediaFeatures: mediaFeatures,
729
- mediaValueKeywords: mediaValueKeywords,
730
- propertyKeywords: propertyKeywords,
731
- nonStandardPropertyKeywords: nonStandardPropertyKeywords,
732
- colorKeywords: colorKeywords,
733
- valueKeywords: valueKeywords,
734
- fontProperties: fontProperties,
735
- allowNested: true,
736
- lineComment: "//",
737
- tokenHooks: {
738
- "/": function(stream, state) {
739
- if (stream.eat("/")) {
740
- stream.skipToEnd();
741
- return ["comment", "comment"];
742
- } else if (stream.eat("*")) {
743
- state.tokenize = tokenCComment;
744
- return tokenCComment(stream, state);
745
- } else {
746
- return ["operator", "operator"];
747
- }
748
- },
749
- ":": function(stream) {
750
- if (stream.match(/\s*\{/, false))
751
- return [null, null]
752
- return false;
753
- },
754
- "$": function(stream) {
755
- stream.match(/^[\w-]+/);
756
- if (stream.match(/^\s*:/, false))
757
- return ["variable-2", "variable-definition"];
758
- return ["variable-2", "variable"];
759
- },
760
- "#": function(stream) {
761
- if (!stream.eat("{")) return false;
762
- return [null, "interpolation"];
763
- }
764
- },
765
- name: "css",
766
- helperType: "scss"
767
- });
768
-
769
- CodeMirror.defineMIME("text/x-less", {
770
- mediaTypes: mediaTypes,
771
- mediaFeatures: mediaFeatures,
772
- mediaValueKeywords: mediaValueKeywords,
773
- propertyKeywords: propertyKeywords,
774
- nonStandardPropertyKeywords: nonStandardPropertyKeywords,
775
- colorKeywords: colorKeywords,
776
- valueKeywords: valueKeywords,
777
- fontProperties: fontProperties,
778
- allowNested: true,
779
- lineComment: "//",
780
- tokenHooks: {
781
- "/": function(stream, state) {
782
- if (stream.eat("/")) {
783
- stream.skipToEnd();
784
- return ["comment", "comment"];
785
- } else if (stream.eat("*")) {
786
- state.tokenize = tokenCComment;
787
- return tokenCComment(stream, state);
788
- } else {
789
- return ["operator", "operator"];
790
- }
791
- },
792
- "@": function(stream) {
793
- if (stream.eat("{")) return [null, "interpolation"];
794
- if (stream.match(/^(charset|document|font-face|import|(-(moz|ms|o|webkit)-)?keyframes|media|namespace|page|supports)\b/, false)) return false;
795
- stream.eatWhile(/[\w\\\-]/);
796
- if (stream.match(/^\s*:/, false))
797
- return ["variable-2", "variable-definition"];
798
- return ["variable-2", "variable"];
799
- },
800
- "&": function() {
801
- return ["atom", "atom"];
802
- }
803
- },
804
- name: "css",
805
- helperType: "less"
806
- });
807
-
808
- CodeMirror.defineMIME("text/x-gss", {
809
- documentTypes: documentTypes,
810
- mediaTypes: mediaTypes,
811
- mediaFeatures: mediaFeatures,
812
- propertyKeywords: propertyKeywords,
813
- nonStandardPropertyKeywords: nonStandardPropertyKeywords,
814
- fontProperties: fontProperties,
815
- counterDescriptors: counterDescriptors,
816
- colorKeywords: colorKeywords,
817
- valueKeywords: valueKeywords,
818
- supportsAtComponent: true,
819
- tokenHooks: {
820
- "/": function(stream, state) {
821
- if (!stream.eat("*")) return false;
822
- state.tokenize = tokenCComment;
823
- return tokenCComment(stream, state);
824
- }
825
- },
826
- name: "css",
827
- helperType: "gss"
828
- });
829
-
830
- });
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
includes/js/codemirror/htmlmixed.js DELETED
@@ -1,152 +0,0 @@
1
- // CodeMirror, copyright (c) by Marijn Haverbeke and others
2
- // Distributed under an MIT license: http://codemirror.net/LICENSE
3
-
4
- (function(mod) {
5
- if (typeof exports == "object" && typeof module == "object") // CommonJS
6
- mod(require("../../lib/codemirror"), require("../xml/xml"), require("../javascript/javascript"), require("../css/css"));
7
- else if (typeof define == "function" && define.amd) // AMD
8
- define(["../../lib/codemirror", "../xml/xml", "../javascript/javascript", "../css/css"], mod);
9
- else // Plain browser env
10
- mod(CodeMirror);
11
- })(function(CodeMirror) {
12
- "use strict";
13
-
14
- var defaultTags = {
15
- script: [
16
- ["lang", /(javascript|babel)/i, "javascript"],
17
- ["type", /^(?:text|application)\/(?:x-)?(?:java|ecma)script$|^module$|^$/i, "javascript"],
18
- ["type", /./, "text/plain"],
19
- [null, null, "javascript"]
20
- ],
21
- style: [
22
- ["lang", /^css$/i, "css"],
23
- ["type", /^(text\/)?(x-)?(stylesheet|css)$/i, "css"],
24
- ["type", /./, "text/plain"],
25
- [null, null, "css"]
26
- ]
27
- };
28
-
29
- function maybeBackup(stream, pat, style) {
30
- var cur = stream.current(), close = cur.search(pat);
31
- if (close > -1) {
32
- stream.backUp(cur.length - close);
33
- } else if (cur.match(/<\/?$/)) {
34
- stream.backUp(cur.length);
35
- if (!stream.match(pat, false)) stream.match(cur);
36
- }
37
- return style;
38
- }
39
-
40
- var attrRegexpCache = {};
41
- function getAttrRegexp(attr) {
42
- var regexp = attrRegexpCache[attr];
43
- if (regexp) return regexp;
44
- return attrRegexpCache[attr] = new RegExp("\\s+" + attr + "\\s*=\\s*('|\")?([^'\"]+)('|\")?\\s*");
45
- }
46
-
47
- function getAttrValue(text, attr) {
48
- var match = text.match(getAttrRegexp(attr))
49
- return match ? /^\s*(.*?)\s*$/.exec(match[2])[1] : ""
50
- }
51
-
52
- function getTagRegexp(tagName, anchored) {
53
- return new RegExp((anchored ? "^" : "") + "<\/\s*" + tagName + "\s*>", "i");
54
- }
55
-
56
- function addTags(from, to) {
57
- for (var tag in from) {
58
- var dest = to[tag] || (to[tag] = []);
59
- var source = from[tag];
60
- for (var i = source.length - 1; i >= 0; i--)
61
- dest.unshift(source[i])
62
- }
63
- }
64
-
65
- function findMatchingMode(tagInfo, tagText) {
66
- for (var i = 0; i < tagInfo.length; i++) {
67
- var spec = tagInfo[i];
68
- if (!spec[0] || spec[1].test(getAttrValue(tagText, spec[0]))) return spec[2];
69
- }
70
- }
71
-
72
- CodeMirror.defineMode("htmlmixed", function (config, parserConfig) {
73
- var htmlMode = CodeMirror.getMode(config, {
74
- name: "xml",
75
- htmlMode: true,
76
- multilineTagIndentFactor: parserConfig.multilineTagIndentFactor,
77
- multilineTagIndentPastTag: parserConfig.multilineTagIndentPastTag
78
- });
79
-
80
- var tags = {};
81
- var configTags = parserConfig && parserConfig.tags, configScript = parserConfig && parserConfig.scriptTypes;
82
- addTags(defaultTags, tags);
83
- if (configTags) addTags(configTags, tags);
84
- if (configScript) for (var i = configScript.length - 1; i >= 0; i--)
85
- tags.script.unshift(["type", configScript[i].matches, configScript[i].mode])
86
-
87
- function html(stream, state) {
88
- var style = htmlMode.token(stream, state.htmlState), tag = /\btag\b/.test(style), tagName
89
- if (tag && !/[<>\s\/]/.test(stream.current()) &&
90
- (tagName = state.htmlState.tagName && state.htmlState.tagName.toLowerCase()) &&
91
- tags.hasOwnProperty(tagName)) {
92
- state.inTag = tagName + " "
93
- } else if (state.inTag && tag && />$/.test(stream.current())) {
94
- var inTag = /^([\S]+) (.*)/.exec(state.inTag)
95
- state.inTag = null
96
- var modeSpec = stream.current() == ">" && findMatchingMode(tags[inTag[1]], inTag[2])
97
- var mode = CodeMirror.getMode(config, modeSpec)
98
- var endTagA = getTagRegexp(inTag[1], true), endTag = getTagRegexp(inTag[1], false);
99
- state.token = function (stream, state) {
100
- if (stream.match(endTagA, false)) {
101
- state.token = html;
102
- state.localState = state.localMode = null;
103
- return null;
104
- }
105
- return maybeBackup(stream, endTag, state.localMode.token(stream, state.localState));
106
- };
107
- state.localMode = mode;
108
- state.localState = CodeMirror.startState(mode, htmlMode.indent(state.htmlState, ""));
109
- } else if (state.inTag) {
110
- state.inTag += stream.current()
111
- if (stream.eol()) state.inTag += " "
112
- }
113
- return style;
114
- };
115
-
116
- return {
117
- startState: function () {
118
- var state = CodeMirror.startState(htmlMode);
119
- return {token: html, inTag: null, localMode: null, localState: null, htmlState: state};
120
- },
121
-
122
- copyState: function (state) {
123
- var local;
124
- if (state.localState) {
125
- local = CodeMirror.copyState(state.localMode, state.localState);
126
- }
127
- return {token: state.token, inTag: state.inTag,
128
- localMode: state.localMode, localState: local,
129
- htmlState: CodeMirror.copyState(htmlMode, state.htmlState)};
130
- },
131
-
132
- token: function (stream, state) {
133
- return state.token(stream, state);
134
- },
135
-
136
- indent: function (state, textAfter, line) {
137
- if (!state.localMode || /^\s*<\//.test(textAfter))
138
- return htmlMode.indent(state.htmlState, textAfter);
139
- else if (state.localMode.indent)
140
- return state.localMode.indent(state.localState, textAfter, line);
141
- else
142
- return CodeMirror.Pass;
143
- },
144
-
145
- innerMode: function (state) {
146
- return {state: state.localState || state.htmlState, mode: state.localMode || htmlMode};
147
- }
148
- };
149
- }, "xml", "javascript", "css");
150
-
151
- CodeMirror.defineMIME("text/html", "htmlmixed");
152
- });
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
includes/js/codemirror/javascript.js DELETED
@@ -1,813 +0,0 @@
1
- // CodeMirror, copyright (c) by Marijn Haverbeke and others
2
- // Distributed under an MIT license: http://codemirror.net/LICENSE
3
-
4
- (function(mod) {
5
- if (typeof exports == "object" && typeof module == "object") // CommonJS
6
- mod(require("../../lib/codemirror"));
7
- else if (typeof define == "function" && define.amd) // AMD
8
- define(["../../lib/codemirror"], mod);
9
- else // Plain browser env
10
- mod(CodeMirror);
11
- })(function(CodeMirror) {
12
- "use strict";
13
-
14
- function expressionAllowed(stream, state, backUp) {
15
- return /^(?:operator|sof|keyword c|case|new|export|default|[\[{}\(,;:]|=>)$/.test(state.lastType) ||
16
- (state.lastType == "quasi" && /\{\s*$/.test(stream.string.slice(0, stream.pos - (backUp || 0))))
17
- }
18
-
19
- CodeMirror.defineMode("javascript", function(config, parserConfig) {
20
- var indentUnit = config.indentUnit;
21
- var statementIndent = parserConfig.statementIndent;
22
- var jsonldMode = parserConfig.jsonld;
23
- var jsonMode = parserConfig.json || jsonldMode;
24
- var isTS = parserConfig.typescript;
25
- var wordRE = parserConfig.wordCharacters || /[\w$\xa1-\uffff]/;
26
-
27
- // Tokenizer
28
-
29
- var keywords = function(){
30
- function kw(type) {return {type: type, style: "keyword"};}
31
- var A = kw("keyword a"), B = kw("keyword b"), C = kw("keyword c");
32
- var operator = kw("operator"), atom = {type: "atom", style: "atom"};
33
-
34
- var jsKeywords = {
35
- "if": kw("if"), "while": A, "with": A, "else": B, "do": B, "try": B, "finally": B,
36
- "return": C, "break": C, "continue": C, "new": kw("new"), "delete": C, "throw": C, "debugger": C,
37
- "var": kw("var"), "const": kw("var"), "let": kw("var"),
38
- "function": kw("function"), "catch": kw("catch"),
39
- "for": kw("for"), "switch": kw("switch"), "case": kw("case"), "default": kw("default"),
40
- "in": operator, "typeof": operator, "instanceof": operator,
41
- "true": atom, "false": atom, "null": atom, "undefined": atom, "NaN": atom, "Infinity": atom,
42
- "this": kw("this"), "class": kw("class"), "super": kw("atom"),
43
- "yield": C, "export": kw("export"), "import": kw("import"), "extends": C,
44
- "await": C, "async": kw("async")
45
- };
46
-
47
- // Extend the 'normal' keywords with the TypeScript language extensions
48
- if (isTS) {
49
- var type = {type: "variable", style: "variable-3"};
50
- var tsKeywords = {
51
- // object-like things
52
- "interface": kw("class"),
53
- "implements": C,
54
- "namespace": C,
55
- "module": kw("module"),
56
- "enum": kw("module"),
57
-
58
- // scope modifiers
59
- "public": kw("modifier"),
60
- "private": kw("modifier"),
61
- "protected": kw("modifier"),
62
- "abstract": kw("modifier"),
63
-
64
- // operators
65
- "as": operator,
66
-
67
- // types
68
- "string": type, "number": type, "boolean": type, "any": type
69
- };
70
-
71
- for (var attr in tsKeywords) {
72
- jsKeywords[attr] = tsKeywords[attr];
73
- }
74
- }
75
-
76
- return jsKeywords;
77
- }();
78
-
79
- var isOperatorChar = /[+\-*&%=<>!?|~^@]/;
80
- var isJsonldKeyword = /^@(context|id|value|language|type|container|list|set|reverse|index|base|vocab|graph)"/;
81
-
82
- function readRegexp(stream) {
83
- var escaped = false, next, inSet = false;
84
- while ((next = stream.next()) != null) {
85
- if (!escaped) {
86
- if (next == "/" && !inSet) return;
87
- if (next == "[") inSet = true;
88
- else if (inSet && next == "]") inSet = false;
89
- }
90
- escaped = !escaped && next == "\\";
91
- }
92
- }
93
-
94
- // Used as scratch variables to communicate multiple values without
95
- // consing up tons of objects.
96
- var type, content;
97
- function ret(tp, style, cont) {
98
- type = tp; content = cont;
99
- return style;
100
- }
101
- function tokenBase(stream, state) {
102
- var ch = stream.next();
103
- if (ch == '"' || ch == "'") {
104
- state.tokenize = tokenString(ch);
105
- return state.tokenize(stream, state);
106
- } else if (ch == "." && stream.match(/^\d+(?:[eE][+\-]?\d+)?/)) {
107
- return ret("number", "number");
108
- } else if (ch == "." && stream.match("..")) {
109
- return ret("spread", "meta");
110
- } else if (/[\[\]{}\(\),;\:\.]/.test(ch)) {
111
- return ret(ch);
112
- } else if (ch == "=" && stream.eat(">")) {
113
- return ret("=>", "operator");
114
- } else if (ch == "0" && stream.eat(/x/i)) {
115
- stream.eatWhile(/[\da-f]/i);
116
- return ret("number", "number");
117
- } else if (ch == "0" && stream.eat(/o/i)) {
118
- stream.eatWhile(/[0-7]/i);
119
- return ret("number", "number");
120
- } else if (ch == "0" && stream.eat(/b/i)) {
121
- stream.eatWhile(/[01]/i);
122
- return ret("number", "number");
123
- } else if (/\d/.test(ch)) {
124
- stream.match(/^\d*(?:\.\d*)?(?:[eE][+\-]?\d+)?/);
125
- return ret("number", "number");
126
- } else if (ch == "/") {
127
- if (stream.eat("*")) {
128
- state.tokenize = tokenComment;
129
- return tokenComment(stream, state);
130
- } else if (stream.eat("/")) {
131
- stream.skipToEnd();
132
- return ret("comment", "comment");
133
- } else if (expressionAllowed(stream, state, 1)) {
134
- readRegexp(stream);
135
- stream.match(/^\b(([gimyu])(?![gimyu]*\2))+\b/);
136
- return ret("regexp", "string-2");
137
- } else {
138
- stream.eatWhile(isOperatorChar);
139
- return ret("operator", "operator", stream.current());
140
- }
141
- } else if (ch == "`") {
142
- state.tokenize = tokenQuasi;
143
- return tokenQuasi(stream, state);
144
- } else if (ch == "#") {
145
- stream.skipToEnd();
146
- return ret("error", "error");
147
- } else if (isOperatorChar.test(ch)) {
148
- if (ch != ">" || !state.lexical || state.lexical.type != ">")
149
- stream.eatWhile(isOperatorChar);
150
- return ret("operator", "operator", stream.current());
151
- } else if (wordRE.test(ch)) {
152
- stream.eatWhile(wordRE);
153
- var word = stream.current(), known = keywords.propertyIsEnumerable(word) && keywords[word];
154
- return (known && state.lastType != ".") ? ret(known.type, known.style, word) :
155
- ret("variable", "variable", word);
156
- }
157
- }
158
-
159
- function tokenString(quote) {
160
- return function(stream, state) {
161
- var escaped = false, next;
162
- if (jsonldMode && stream.peek() == "@" && stream.match(isJsonldKeyword)){
163
- state.tokenize = tokenBase;
164
- return ret("jsonld-keyword", "meta");
165
- }
166
- while ((next = stream.next()) != null) {
167
- if (next == quote && !escaped) break;
168
- escaped = !escaped && next == "\\";
169
- }
170
- if (!escaped) state.tokenize = tokenBase;
171
- return ret("string", "string");
172
- };
173
- }
174
-
175
- function tokenComment(stream, state) {
176
- var maybeEnd = false, ch;
177
- while (ch = stream.next()) {
178
- if (ch == "/" && maybeEnd) {
179
- state.tokenize = tokenBase;
180
- break;
181
- }
182
- maybeEnd = (ch == "*");
183
- }
184
- return ret("comment", "comment");
185
- }
186
-
187
- function tokenQuasi(stream, state) {
188
- var escaped = false, next;
189
- while ((next = stream.next()) != null) {
190
- if (!escaped && (next == "`" || next == "$" && stream.eat("{"))) {
191
- state.tokenize = tokenBase;
192
- break;
193
- }
194
- escaped = !escaped && next == "\\";
195
- }
196
- return ret("quasi", "string-2", stream.current());
197
- }
198
-
199
- var brackets = "([{}])";
200
- // This is a crude lookahead trick to try and notice that we're
201
- // parsing the argument patterns for a fat-arrow function before we
202
- // actually hit the arrow token. It only works if the arrow is on
203
- // the same line as the arguments and there's no strange noise
204
- // (comments) in between. Fallback is to only notice when we hit the
205
- // arrow, and not declare the arguments as locals for the arrow
206
- // body.
207
- function findFatArrow(stream, state) {
208
- if (state.fatArrowAt) state.fatArrowAt = null;
209
- var arrow = stream.string.indexOf("=>", stream.start);
210
- if (arrow < 0) return;
211
-
212
- if (isTS) { // Try to skip TypeScript return type declarations after the arguments
213
- var m = /:\s*(?:\w+(?:<[^>]*>|\[\])?|\{[^}]*\})\s*$/.exec(stream.string.slice(stream.start, arrow))
214
- if (m) arrow = m.index
215
- }
216
-
217
- var depth = 0, sawSomething = false;
218
- for (var pos = arrow - 1; pos >= 0; --pos) {
219
- var ch = stream.string.charAt(pos);
220
- var bracket = brackets.indexOf(ch);
221
- if (bracket >= 0 && bracket < 3) {
222
- if (!depth) { ++pos; break; }
223
- if (--depth == 0) { if (ch == "(") sawSomething = true; break; }
224
- } else if (bracket >= 3 && bracket < 6) {
225
- ++depth;
226
- } else if (wordRE.test(ch)) {
227
- sawSomething = true;
228
- } else if (/["'\/]/.test(ch)) {
229
- return;
230
- } else if (sawSomething && !depth) {
231
- ++pos;
232
- break;
233
- }
234
- }
235
- if (sawSomething && !depth) state.fatArrowAt = pos;
236
- }
237
-
238
- // Parser
239
-
240
- var atomicTypes = {"atom": true, "number": true, "variable": true, "string": true, "regexp": true, "this": true, "jsonld-keyword": true};
241
-
242
- function JSLexical(indented, column, type, align, prev, info) {
243
- this.indented = indented;
244
- this.column = column;
245
- this.type = type;
246
- this.prev = prev;
247
- this.info = info;
248
- if (align != null) this.align = align;
249
- }
250
-
251
- function inScope(state, varname) {
252
- for (var v = state.localVars; v; v = v.next)
253
- if (v.name == varname) return true;
254
- for (var cx = state.context; cx; cx = cx.prev) {
255
- for (var v = cx.vars; v; v = v.next)
256
- if (v.name == varname) return true;
257
- }
258
- }
259
-
260
- function parseJS(state, style, type, content, stream) {
261
- var cc = state.cc;
262
- // Communicate our context to the combinators.
263
- // (Less wasteful than consing up a hundred closures on every call.)
264
- cx.state = state; cx.stream = stream; cx.marked = null, cx.cc = cc; cx.style = style;
265
-
266
- if (!state.lexical.hasOwnProperty("align"))
267
- state.lexical.align = true;
268
-
269
- while(true) {
270
- var combinator = cc.length ? cc.pop() : jsonMode ? expression : statement;
271
- if (combinator(type, content)) {
272
- while(cc.length && cc[cc.length - 1].lex)
273
- cc.pop()();
274
- if (cx.marked) return cx.marked;
275
- if (type == "variable" && inScope(state, content)) return "variable-2";
276
- return style;
277
- }
278
- }
279
- }
280
-
281
- // Combinator utils
282
-
283
- var cx = {state: null, column: null, marked: null, cc: null};
284
- function pass() {
285
- for (var i = arguments.length - 1; i >= 0; i--) cx.cc.push(arguments[i]);
286
- }
287
- function cont() {
288
- pass.apply(null, arguments);
289
- return true;
290
- }
291
- function register(varname) {
292
- function inList(list) {
293
- for (var v = list; v; v = v.next)
294
- if (v.name == varname) return true;
295
- return false;
296
- }
297
- var state = cx.state;
298
- cx.marked = "def";
299
- if (state.context) {
300
- if (inList(state.localVars)) return;
301
- state.localVars = {name: varname, next: state.localVars};
302
- } else {
303
- if (inList(state.globalVars)) return;
304
- if (parserConfig.globalVars)
305
- state.globalVars = {name: varname, next: state.globalVars};
306
- }
307
- }
308
-
309
- // Combinators
310
-
311
- var defaultVars = {name: "this", next: {name: "arguments"}};
312
- function pushcontext() {
313
- cx.state.context = {prev: cx.state.context, vars: cx.state.localVars};
314
- cx.state.localVars = defaultVars;
315
- }
316
- function popcontext() {
317
- cx.state.localVars = cx.state.context.vars;
318
- cx.state.context = cx.state.context.prev;
319
- }
320
- function pushlex(type, info) {
321
- var result = function() {
322
- var state = cx.state, indent = state.indented;
323
- if (state.lexical.type == "stat") indent = state.lexical.indented;
324
- else for (var outer = state.lexical; outer && outer.type == ")" && outer.align; outer = outer.prev)
325
- indent = outer.indented;
326
- state.lexical = new JSLexical(indent, cx.stream.column(), type, null, state.lexical, info);
327
- };
328
- result.lex = true;
329
- return result;
330
- }
331
- function poplex() {
332
- var state = cx.state;
333
- if (state.lexical.prev) {
334
- if (state.lexical.type == ")")
335
- state.indented = state.lexical.indented;
336
- state.lexical = state.lexical.prev;
337
- }
338
- }
339
- poplex.lex = true;
340
-
341
- function expect(wanted) {
342
- function exp(type) {
343
- if (type == wanted) return cont();
344
- else if (wanted == ";") return pass();
345
- else return cont(exp);
346
- };
347
- return exp;
348
- }
349
-
350
- function statement(type, value) {
351
- if (type == "var") return cont(pushlex("vardef", value.length), vardef, expect(";"), poplex);
352
- if (type == "keyword a") return cont(pushlex("form"), parenExpr, statement, poplex);
353
- if (type == "keyword b") return cont(pushlex("form"), statement, poplex);
354
- if (type == "{") return cont(pushlex("}"), block, poplex);
355
- if (type == ";") return cont();
356
- if (type == "if") {
357
- if (cx.state.lexical.info == "else" && cx.state.cc[cx.state.cc.length - 1] == poplex)
358
- cx.state.cc.pop()();
359
- return cont(pushlex("form"), parenExpr, statement, poplex, maybeelse);
360
- }
361
- if (type == "function") return cont(functiondef);
362
- if (type == "for") return cont(pushlex("form"), forspec, statement, poplex);
363
- if (type == "variable") {
364
- if (isTS && value == "type") {
365
- cx.marked = "keyword"
366
- return cont(typeexpr, expect("operator"), typeexpr, expect(";"));
367
- } else {
368
- return cont(pushlex("stat"), maybelabel);
369
- }
370
- }
371
- if (type == "switch") return cont(pushlex("form"), parenExpr, expect("{"), pushlex("}", "switch"),
372
- block, poplex, poplex);
373
- if (type == "case") return cont(expression, expect(":"));
374
- if (type == "default") return cont(expect(":"));
375
- if (type == "catch") return cont(pushlex("form"), pushcontext, expect("("), funarg, expect(")"),
376
- statement, poplex, popcontext);
377
- if (type == "class") return cont(pushlex("form"), className, poplex);
378
- if (type == "export") return cont(pushlex("stat"), afterExport, poplex);
379
- if (type == "import") return cont(pushlex("stat"), afterImport, poplex);
380
- if (type == "module") return cont(pushlex("form"), pattern, expect("{"), pushlex("}"), block, poplex, poplex)
381
- if (type == "async") return cont(statement)
382
- if (value == "@") return cont(expression, statement)
383
- return pass(pushlex("stat"), expression, expect(";"), poplex);
384
- }
385
- function expression(type) {
386
- return expressionInner(type, false);
387
- }
388
- function expressionNoComma(type) {
389
- return expressionInner(type, true);
390
- }
391
- function parenExpr(type) {
392
- if (type != "(") return pass()
393
- return cont(pushlex(")"), expression, expect(")"), poplex)
394
- }
395
- function expressionInner(type, noComma) {
396
- if (cx.state.fatArrowAt == cx.stream.start) {
397
- var body = noComma ? arrowBodyNoComma : arrowBody;
398
- if (type == "(") return cont(pushcontext, pushlex(")"), commasep(pattern, ")"), poplex, expect("=>"), body, popcontext);
399
- else if (type == "variable") return pass(pushcontext, pattern, expect("=>"), body, popcontext);
400
- }
401
-
402
- var maybeop = noComma ? maybeoperatorNoComma : maybeoperatorComma;
403
- if (atomicTypes.hasOwnProperty(type)) return cont(maybeop);
404
- if (type == "function") return cont(functiondef, maybeop);
405
- if (type == "class") return cont(pushlex("form"), classExpression, poplex);
406
- if (type == "keyword c" || type == "async") return cont(noComma ? maybeexpressionNoComma : maybeexpression);
407
- if (type == "(") return cont(pushlex(")"), maybeexpression, expect(")"), poplex, maybeop);
408
- if (type == "operator" || type == "spread") return cont(noComma ? expressionNoComma : expression);
409
- if (type == "[") return cont(pushlex("]"), arrayLiteral, poplex, maybeop);
410
- if (type == "{") return contCommasep(objprop, "}", null, maybeop);
411
- if (type == "quasi") return pass(quasi, maybeop);
412
- if (type == "new") return cont(maybeTarget(noComma));
413
- return cont();
414
- }
415
- function maybeexpression(type) {
416
- if (type.match(/[;\}\)\],]/)) return pass();
417
- return pass(expression);
418
- }
419
- function maybeexpressionNoComma(type) {
420
- if (type.match(/[;\}\)\],]/)) return pass();
421
- return pass(expressionNoComma);
422
- }
423
-
424
- function maybeoperatorComma(type, value) {
425
- if (type == ",") return cont(expression);
426
- return maybeoperatorNoComma(type, value, false);
427
- }
428
- function maybeoperatorNoComma(type, value, noComma) {
429
- var me = noComma == false ? maybeoperatorComma : maybeoperatorNoComma;
430
- var expr = noComma == false ? expression : expressionNoComma;
431
- if (type == "=>") return cont(pushcontext, noComma ? arrowBodyNoComma : arrowBody, popcontext);
432
- if (type == "operator") {
433
- if (/\+\+|--/.test(value)) return cont(me);
434
- if (value == "?") return cont(expression, expect(":"), expr);
435
- return cont(expr);
436
- }
437
- if (type == "quasi") { return pass(quasi, me); }
438
- if (type == ";") return;
439
- if (type == "(") return contCommasep(expressionNoComma, ")", "call", me);
440
- if (type == ".") return cont(property, me);
441
- if (type == "[") return cont(pushlex("]"), maybeexpression, expect("]"), poplex, me);
442
- }
443
- function quasi(type, value) {
444
- if (type != "quasi") return pass();
445
- if (value.slice(value.length - 2) != "${") return cont(quasi);
446
- return cont(expression, continueQuasi);
447
- }
448
- function continueQuasi(type) {
449
- if (type == "}") {
450
- cx.marked = "string-2";
451
- cx.state.tokenize = tokenQuasi;
452
- return cont(quasi);
453
- }
454
- }
455
- function arrowBody(type) {
456
- findFatArrow(cx.stream, cx.state);
457
- return pass(type == "{" ? statement : expression);
458
- }
459
- function arrowBodyNoComma(type) {
460
- findFatArrow(cx.stream, cx.state);
461
- return pass(type == "{" ? statement : expressionNoComma);
462
- }
463
- function maybeTarget(noComma) {
464
- return function(type) {
465
- if (type == ".") return cont(noComma ? targetNoComma : target);
466
- else return pass(noComma ? expressionNoComma : expression);
467
- };
468
- }
469
- function target(_, value) {
470
- if (value == "target") { cx.marked = "keyword"; return cont(maybeoperatorComma); }
471
- }
472
- function targetNoComma(_, value) {
473
- if (value == "target") { cx.marked = "keyword"; return cont(maybeoperatorNoComma); }
474
- }
475
- function maybelabel(type) {
476
- if (type == ":") return cont(poplex, statement);
477
- return pass(maybeoperatorComma, expect(";"), poplex);
478
- }
479
- function property(type) {
480
- if (type == "variable") {cx.marked = "property"; return cont();}
481
- }
482
- function objprop(type, value) {
483
- if (type == "async") {
484
- cx.marked = "property";
485
- return cont(objprop);
486
- } else if (type == "variable" || cx.style == "keyword") {
487
- cx.marked = "property";
488
- if (value == "get" || value == "set") return cont(getterSetter);
489
- return cont(afterprop);
490
- } else if (type == "number" || type == "string") {
491
- cx.marked = jsonldMode ? "property" : (cx.style + " property");
492
- return cont(afterprop);
493
- } else if (type == "jsonld-keyword") {
494
- return cont(afterprop);
495
- } else if (type == "modifier") {
496
- return cont(objprop)
497
- } else if (type == "[") {
498
- return cont(expression, expect("]"), afterprop);
499
- } else if (type == "spread") {
500
- return cont(expression);
501
- } else if (type == ":") {
502
- return pass(afterprop)
503
- }
504
- }
505
- function getterSetter(type) {
506
- if (type != "variable") return pass(afterprop);
507
- cx.marked = "property";
508
- return cont(functiondef);
509
- }
510
- function afterprop(type) {
511
- if (type == ":") return cont(expressionNoComma);
512
- if (type == "(") return pass(functiondef);
513
- }
514
- function commasep(what, end, sep) {
515
- function proceed(type, value) {
516
- if (sep ? sep.indexOf(type) > -1 : type == ",") {
517
- var lex = cx.state.lexical;
518
- if (lex.info == "call") lex.pos = (lex.pos || 0) + 1;
519
- return cont(function(type, value) {
520
- if (type == end || value == end) return pass()
521
- return pass(what)
522
- }, proceed);
523
- }
524
- if (type == end || value == end) return cont();
525
- return cont(expect(end));
526
- }
527
- return function(type, value) {
528
- if (type == end || value == end) return cont();
529
- return pass(what, proceed);
530
- };
531
- }
532
- function contCommasep(what, end, info) {
533
- for (var i = 3; i < arguments.length; i++)
534
- cx.cc.push(arguments[i]);
535
- return cont(pushlex(end, info), commasep(what, end), poplex);
536
- }
537
- function block(type) {
538
- if (type == "}") return cont();
539
- return pass(statement, block);
540
- }
541
- function maybetype(type, value) {
542
- if (isTS) {
543
- if (type == ":") return cont(typeexpr);
544
- if (value == "?") return cont(maybetype);
545
- }
546
- }
547
- function typeexpr(type) {
548
- if (type == "variable") {cx.marked = "variable-3"; return cont(afterType);}
549
- if (type == "string" || type == "number" || type == "atom") return cont(afterType);
550
- if (type == "{") return cont(pushlex("}"), commasep(typeprop, "}", ",;"), poplex, afterType)
551
- if (type == "(") return cont(commasep(typearg, ")"), maybeReturnType)
552
- }
553
- function maybeReturnType(type) {
554
- if (type == "=>") return cont(typeexpr)
555
- }
556
- function typeprop(type, value) {
557
- if (type == "variable" || cx.style == "keyword") {
558
- cx.marked = "property"
559
- return cont(typeprop)
560
- } else if (value == "?") {
561
- return cont(typeprop)
562
- } else if (type == ":") {
563
- return cont(typeexpr)
564
- } else if (type == "[") {
565
- return cont(expression, maybetype, expect("]"), typeprop)
566
- }
567
- }
568
- function typearg(type) {
569
- if (type == "variable") return cont(typearg)
570
- else if (type == ":") return cont(typeexpr)
571
- }
572
- function afterType(type, value) {
573
- if (value == "<") return cont(pushlex(">"), commasep(typeexpr, ">"), poplex, afterType)
574
- if (value == "|" || type == ".") return cont(typeexpr)
575
- if (type == "[") return cont(expect("]"), afterType)
576
- if (value == "extends") return cont(typeexpr)
577
- }
578
- function vardef() {
579
- return pass(pattern, maybetype, maybeAssign, vardefCont);
580
- }
581
- function pattern(type, value) {
582
- if (type == "modifier") return cont(pattern)
583
- if (type == "variable") { register(value); return cont(); }
584
- if (type == "spread") return cont(pattern);
585
- if (type == "[") return contCommasep(pattern, "]");
586
- if (type == "{") return contCommasep(proppattern, "}");
587
- }
588
- function proppattern(type, value) {
589
- if (type == "variable" && !cx.stream.match(/^\s*:/, false)) {
590
- register(value);
591
- return cont(maybeAssign);
592
- }
593
- if (type == "variable") cx.marked = "property";
594
- if (type == "spread") return cont(pattern);
595
- if (type == "}") return pass();
596
- return cont(expect(":"), pattern, maybeAssign);
597
- }
598
- function maybeAssign(_type, value) {
599
- if (value == "=") return cont(expressionNoComma);
600
- }
601
- function vardefCont(type) {
602
- if (type == ",") return cont(vardef);
603
- }
604
- function maybeelse(type, value) {
605
- if (type == "keyword b" && value == "else") return cont(pushlex("form", "else"), statement, poplex);
606
- }
607
- function forspec(type) {
608
- if (type == "(") return cont(pushlex(")"), forspec1, expect(")"), poplex);
609
- }
610
- function forspec1(type) {
611
- if (type == "var") return cont(vardef, expect(";"), forspec2);
612
- if (type == ";") return cont(forspec2);
613
- if (type == "variable") return cont(formaybeinof);
614
- return pass(expression, expect(";"), forspec2);
615
- }
616
- function formaybeinof(_type, value) {
617
- if (value == "in" || value == "of") { cx.marked = "keyword"; return cont(expression); }
618
- return cont(maybeoperatorComma, forspec2);
619
- }
620
- function forspec2(type, value) {
621
- if (type == ";") return cont(forspec3);
622
- if (value == "in" || value == "of") { cx.marked = "keyword"; return cont(expression); }
623
- return pass(expression, expect(";"), forspec3);
624
- }
625
- function forspec3(type) {
626
- if (type != ")") cont(expression);
627
- }
628
- function functiondef(type, value) {
629
- if (value == "*") {cx.marked = "keyword"; return cont(functiondef);}
630
- if (type == "variable") {register(value); return cont(functiondef);}
631
- if (type == "(") return cont(pushcontext, pushlex(")"), commasep(funarg, ")"), poplex, maybetype, statement, popcontext);
632
- if (isTS && value == "<") return cont(pushlex(">"), commasep(typeexpr, ">"), poplex, functiondef)
633
- }
634
- function funarg(type) {
635
- if (type == "spread") return cont(funarg);
636
- return pass(pattern, maybetype, maybeAssign);
637
- }
638
- function classExpression(type, value) {
639
- // Class expressions may have an optional name.
640
- if (type == "variable") return className(type, value);
641
- return classNameAfter(type, value);
642
- }
643
- function className(type, value) {
644
- if (type == "variable") {register(value); return cont(classNameAfter);}
645
- }
646
- function classNameAfter(type, value) {
647
- if (value == "<") return cont(pushlex(">"), commasep(typeexpr, ">"), poplex, classNameAfter)
648
- if (value == "extends" || value == "implements" || (isTS && type == ","))
649
- return cont(isTS ? typeexpr : expression, classNameAfter);
650
- if (type == "{") return cont(pushlex("}"), classBody, poplex);
651
- }
652
- function classBody(type, value) {
653
- if (type == "variable" || cx.style == "keyword") {
654
- if ((value == "async" || value == "static" || value == "get" || value == "set" ||
655
- (isTS && (value == "public" || value == "private" || value == "protected" || value == "readonly" || value == "abstract"))) &&
656
- cx.stream.match(/^\s+[\w$\xa1-\uffff]/, false)) {
657
- cx.marked = "keyword";
658
- return cont(classBody);
659
- }
660
- cx.marked = "property";
661
- return cont(isTS ? classfield : functiondef, classBody);
662
- }
663
- if (type == "[")
664
- return cont(expression, expect("]"), isTS ? classfield : functiondef, classBody)
665
- if (value == "*") {
666
- cx.marked = "keyword";
667
- return cont(classBody);
668
- }
669
- if (type == ";") return cont(classBody);
670
- if (type == "}") return cont();
671
- if (value == "@") return cont(expression, classBody)
672
- }
673
- function classfield(type, value) {
674
- if (value == "?") return cont(classfield)
675
- if (type == ":") return cont(typeexpr, maybeAssign)
676
- if (value == "=") return cont(expressionNoComma)
677
- return pass(functiondef)
678
- }
679
- function afterExport(type, value) {
680
- if (value == "*") { cx.marked = "keyword"; return cont(maybeFrom, expect(";")); }
681
- if (value == "default") { cx.marked = "keyword"; return cont(expression, expect(";")); }
682
- if (type == "{") return cont(commasep(exportField, "}"), maybeFrom, expect(";"));
683
- return pass(statement);
684
- }
685
- function exportField(type, value) {
686
- if (value == "as") { cx.marked = "keyword"; return cont(expect("variable")); }
687
- if (type == "variable") return pass(expressionNoComma, exportField);
688
- }
689
- function afterImport(type) {
690
- if (type == "string") return cont();
691
- return pass(importSpec, maybeMoreImports, maybeFrom);
692
- }
693
- function importSpec(type, value) {
694
- if (type == "{") return contCommasep(importSpec, "}");
695
- if (type == "variable") register(value);
696
- if (value == "*") cx.marked = "keyword";
697
- return cont(maybeAs);
698
- }
699
- function maybeMoreImports(type) {
700
- if (type == ",") return cont(importSpec, maybeMoreImports)
701
- }
702
- function maybeAs(_type, value) {
703
- if (value == "as") { cx.marked = "keyword"; return cont(importSpec); }
704
- }
705
- function maybeFrom(_type, value) {
706
- if (value == "from") { cx.marked = "keyword"; return cont(expression); }
707
- }
708
- function arrayLiteral(type) {
709
- if (type == "]") return cont();
710
- return pass(commasep(expressionNoComma, "]"));
711
- }
712
-
713
- function isContinuedStatement(state, textAfter) {
714
- return state.lastType == "operator" || state.lastType == "," ||
715
- isOperatorChar.test(textAfter.charAt(0)) ||
716
- /[,.]/.test(textAfter.charAt(0));
717
- }
718
-
719
- // Interface
720
-
721
- return {
722
- startState: function(basecolumn) {
723
- var state = {
724
- tokenize: tokenBase,
725
- lastType: "sof",
726
- cc: [],
727
- lexical: new JSLexical((basecolumn || 0) - indentUnit, 0, "block", false),
728
- localVars: parserConfig.localVars,
729
- context: parserConfig.localVars && {vars: parserConfig.localVars},
730
- indented: basecolumn || 0
731
- };
732
- if (parserConfig.globalVars && typeof parserConfig.globalVars == "object")
733
- state.globalVars = parserConfig.globalVars;
734
- return state;
735
- },
736
-
737
- token: function(stream, state) {
738
- if (stream.sol()) {
739
- if (!state.lexical.hasOwnProperty("align"))
740
- state.lexical.align = false;
741
- state.indented = stream.indentation();
742
- findFatArrow(stream, state);
743
- }
744
- if (state.tokenize != tokenComment && stream.eatSpace()) return null;
745
- var style = state.tokenize(stream, state);
746
- if (type == "comment") return style;
747
- state.lastType = type == "operator" && (content == "++" || content == "--") ? "incdec" : type;
748
- return parseJS(state, style, type, content, stream);
749
- },
750
-
751
- indent: function(state, textAfter) {
752
- if (state.tokenize == tokenComment) return CodeMirror.Pass;
753
- if (state.tokenize != tokenBase) return 0;
754
- var firstChar = textAfter && textAfter.charAt(0), lexical = state.lexical, top
755
- // Kludge to prevent 'maybelse' from blocking lexical scope pops
756
- if (!/^\s*else\b/.test(textAfter)) for (var i = state.cc.length - 1; i >= 0; --i) {
757
- var c = state.cc[i];
758
- if (c == poplex) lexical = lexical.prev;
759
- else if (c != maybeelse) break;
760
- }
761
- while ((lexical.type == "stat" || lexical.type == "form") &&
762
- (firstChar == "}" || ((top = state.cc[state.cc.length - 1]) &&
763
- (top == maybeoperatorComma || top == maybeoperatorNoComma) &&
764
- !/^[,\.=+\-*:?[\(]/.test(textAfter))))
765
- lexical = lexical.prev;
766
- if (statementIndent && lexical.type == ")" && lexical.prev.type == "stat")
767
- lexical = lexical.prev;
768
- var type = lexical.type, closing = firstChar == type;
769
-
770
- if (type == "vardef") return lexical.indented + (state.lastType == "operator" || state.lastType == "," ? lexical.info + 1 : 0);
771
- else if (type == "form" && firstChar == "{") return lexical.indented;
772
- else if (type == "form") return lexical.indented + indentUnit;
773
- else if (type == "stat")
774
- return lexical.indented + (isContinuedStatement(state, textAfter) ? statementIndent || indentUnit : 0);
775
- else if (lexical.info == "switch" && !closing && parserConfig.doubleIndentSwitch != false)
776
- return lexical.indented + (/^(?:case|default)\b/.test(textAfter) ? indentUnit : 2 * indentUnit);
777
- else if (lexical.align) return lexical.column + (closing ? 0 : 1);
778
- else return lexical.indented + (closing ? 0 : indentUnit);
779
- },
780
-
781
- electricInput: /^\s*(?:case .*?:|default:|\{|\})$/,
782
- blockCommentStart: jsonMode ? null : "/*",
783
- blockCommentEnd: jsonMode ? null : "*/",
784
- lineComment: jsonMode ? null : "//",
785
- fold: "brace",
786
- closeBrackets: "()[]{}''\"\"``",
787
-
788
- helperType: jsonMode ? "json" : "javascript",
789
- jsonldMode: jsonldMode,
790
- jsonMode: jsonMode,
791
-
792
- expressionAllowed: expressionAllowed,
793
- skipExpression: function(state) {
794
- var top = state.cc[state.cc.length - 1]
795
- if (top == expression || top == expressionNoComma) state.cc.pop()
796
- }
797
- };
798
- });
799
-
800
- CodeMirror.registerHelper("wordChars", "javascript", /[\w$]/);
801
-
802
- CodeMirror.defineMIME("text/javascript", "javascript");
803
- CodeMirror.defineMIME("text/ecmascript", "javascript");
804
- CodeMirror.defineMIME("application/javascript", "javascript");
805
- CodeMirror.defineMIME("application/x-javascript", "javascript");
806
- CodeMirror.defineMIME("application/ecmascript", "javascript");
807
- CodeMirror.defineMIME("application/json", {name: "javascript", json: true});
808
- CodeMirror.defineMIME("application/x-json", {name: "javascript", json: true});
809
- CodeMirror.defineMIME("application/ld+json", {name: "javascript", jsonld: true});
810
- CodeMirror.defineMIME("text/typescript", { name: "javascript", typescript: true });
811
- CodeMirror.defineMIME("application/typescript", { name: "javascript", typescript: true });
812
-
813
- });
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
includes/js/codemirror/xml.js DELETED
@@ -1,394 +0,0 @@
1
- // CodeMirror, copyright (c) by Marijn Haverbeke and others
2
- // Distributed under an MIT license: http://codemirror.net/LICENSE
3
-
4
- (function(mod) {
5
- if (typeof exports == "object" && typeof module == "object") // CommonJS
6
- mod(require("../../lib/codemirror"));
7
- else if (typeof define == "function" && define.amd) // AMD
8
- define(["../../lib/codemirror"], mod);
9
- else // Plain browser env
10
- mod(CodeMirror);
11
- })(function(CodeMirror) {
12
- "use strict";
13
-
14
- var htmlConfig = {
15
- autoSelfClosers: {'area': true, 'base': true, 'br': true, 'col': true, 'command': true,
16
- 'embed': true, 'frame': true, 'hr': true, 'img': true, 'input': true,
17
- 'keygen': true, 'link': true, 'meta': true, 'param': true, 'source': true,
18
- 'track': true, 'wbr': true, 'menuitem': true},
19
- implicitlyClosed: {'dd': true, 'li': true, 'optgroup': true, 'option': true, 'p': true,
20
- 'rp': true, 'rt': true, 'tbody': true, 'td': true, 'tfoot': true,
21
- 'th': true, 'tr': true},
22
- contextGrabbers: {
23
- 'dd': {'dd': true, 'dt': true},
24
- 'dt': {'dd': true, 'dt': true},
25
- 'li': {'li': true},
26
- 'option': {'option': true, 'optgroup': true},
27
- 'optgroup': {'optgroup': true},
28
- 'p': {'address': true, 'article': true, 'aside': true, 'blockquote': true, 'dir': true,
29
- 'div': true, 'dl': true, 'fieldset': true, 'footer': true, 'form': true,
30
- 'h1': true, 'h2': true, 'h3': true, 'h4': true, 'h5': true, 'h6': true,
31
- 'header': true, 'hgroup': true, 'hr': true, 'menu': true, 'nav': true, 'ol': true,
32
- 'p': true, 'pre': true, 'section': true, 'table': true, 'ul': true},
33
- 'rp': {'rp': true, 'rt': true},
34
- 'rt': {'rp': true, 'rt': true},
35
- 'tbody': {'tbody': true, 'tfoot': true},
36
- 'td': {'td': true, 'th': true},
37
- 'tfoot': {'tbody': true},
38
- 'th': {'td': true, 'th': true},
39
- 'thead': {'tbody': true, 'tfoot': true},
40
- 'tr': {'tr': true}
41
- },
42
- doNotIndent: {"pre": true},
43
- allowUnquoted: true,
44
- allowMissing: true,
45
- caseFold: true
46
- }
47
-
48
- var xmlConfig = {
49
- autoSelfClosers: {},
50
- implicitlyClosed: {},
51
- contextGrabbers: {},
52
- doNotIndent: {},
53
- allowUnquoted: false,
54
- allowMissing: false,
55
- caseFold: false
56
- }
57
-
58
- CodeMirror.defineMode("xml", function(editorConf, config_) {
59
- var indentUnit = editorConf.indentUnit
60
- var config = {}
61
- var defaults = config_.htmlMode ? htmlConfig : xmlConfig
62
- for (var prop in defaults) config[prop] = defaults[prop]
63
- for (var prop in config_) config[prop] = config_[prop]
64
-
65
- // Return variables for tokenizers
66
- var type, setStyle;
67
-
68
- function inText(stream, state) {
69
- function chain(parser) {
70
- state.tokenize = parser;
71
- return parser(stream, state);
72
- }
73
-
74
- var ch = stream.next();
75
- if (ch == "<") {
76
- if (stream.eat("!")) {
77
- if (stream.eat("[")) {
78
- if (stream.match("CDATA[")) return chain(inBlock("atom", "]]>"));
79
- else return null;
80
- } else if (stream.match("--")) {
81
- return chain(inBlock("comment", "-->"));
82
- } else if (stream.match("DOCTYPE", true, true)) {
83
- stream.eatWhile(/[\w\._\-]/);
84
- return chain(doctype(1));
85
- } else {
86
- return null;
87
- }
88
- } else if (stream.eat("?")) {
89
- stream.eatWhile(/[\w\._\-]/);
90
- state.tokenize = inBlock("meta", "?>");
91
- return "meta";
92
- } else {
93
- type = stream.eat("/") ? "closeTag" : "openTag";
94
- state.tokenize = inTag;
95
- return "tag bracket";
96
- }
97
- } else if (ch == "&") {
98
- var ok;
99
- if (stream.eat("#")) {
100
- if (stream.eat("x")) {
101
- ok = stream.eatWhile(/[a-fA-F\d]/) && stream.eat(";");
102
- } else {
103
- ok = stream.eatWhile(/[\d]/) && stream.eat(";");
104
- }
105
- } else {
106
- ok = stream.eatWhile(/[\w\.\-:]/) && stream.eat(";");
107
- }
108
- return ok ? "atom" : "error";
109
- } else {
110
- stream.eatWhile(/[^&<]/);
111
- return null;
112
- }
113
- }
114
- inText.isInText = true;
115
-
116
- function inTag(stream, state) {
117
- var ch = stream.next();
118
- if (ch == ">" || (ch == "/" && stream.eat(">"))) {
119
- state.tokenize = inText;
120
- type = ch == ">" ? "endTag" : "selfcloseTag";
121
- return "tag bracket";
122
- } else if (ch == "=") {
123
- type = "equals";
124
- return null;
125
- } else if (ch == "<") {
126
- state.tokenize = inText;
127
- state.state = baseState;
128
- state.tagName = state.tagStart = null;
129
- var next = state.tokenize(stream, state);
130
- return next ? next + " tag error" : "tag error";
131
- } else if (/[\'\"]/.test(ch)) {
132
- state.tokenize = inAttribute(ch);
133
- state.stringStartCol = stream.column();
134
- return state.tokenize(stream, state);
135
- } else {
136
- stream.match(/^[^\s\u00a0=<>\"\']*[^\s\u00a0=<>\"\'\/]/);
137
- return "word";
138
- }
139
- }
140
-
141
- function inAttribute(quote) {
142
- var closure = function(stream, state) {
143
- while (!stream.eol()) {
144
- if (stream.next() == quote) {
145
- state.tokenize = inTag;
146
- break;
147
- }
148
- }
149
- return "string";
150
- };
151
- closure.isInAttribute = true;
152
- return closure;
153
- }
154
-
155
- function inBlock(style, terminator) {
156
- return function(stream, state) {
157
- while (!stream.eol()) {
158
- if (stream.match(terminator)) {
159
- state.tokenize = inText;
160
- break;
161
- }
162
- stream.next();
163
- }
164
- return style;
165
- };
166
- }
167
- function doctype(depth) {
168
- return function(stream, state) {
169
- var ch;
170
- while ((ch = stream.next()) != null) {
171
- if (ch == "<") {
172
- state.tokenize = doctype(depth + 1);
173
- return state.tokenize(stream, state);
174
- } else if (ch == ">") {
175
- if (depth == 1) {
176
- state.tokenize = inText;
177
- break;
178
- } else {
179
- state.tokenize = doctype(depth - 1);
180
- return state.tokenize(stream, state);
181
- }
182
- }
183
- }
184
- return "meta";
185
- };
186
- }
187
-
188
- function Context(state, tagName, startOfLine) {
189
- this.prev = state.context;
190
- this.tagName = tagName;
191
- this.indent = state.indented;
192
- this.startOfLine = startOfLine;
193
- if (config.doNotIndent.hasOwnProperty(tagName) || (state.context && state.context.noIndent))
194
- this.noIndent = true;
195
- }
196
- function popContext(state) {
197
- if (state.context) state.context = state.context.prev;
198
- }
199
- function maybePopContext(state, nextTagName) {
200
- var parentTagName;
201
- while (true) {
202
- if (!state.context) {
203
- return;
204
- }
205
- parentTagName = state.context.tagName;
206
- if (!config.contextGrabbers.hasOwnProperty(parentTagName) ||
207
- !config.contextGrabbers[parentTagName].hasOwnProperty(nextTagName)) {
208
- return;
209
- }
210
- popContext(state);
211
- }
212
- }
213
-
214
- function baseState(type, stream, state) {
215
- if (type == "openTag") {
216
- state.tagStart = stream.column();
217
- return tagNameState;
218
- } else if (type == "closeTag") {
219
- return closeTagNameState;
220
- } else {
221
- return baseState;
222
- }
223
- }
224
- function tagNameState(type, stream, state) {
225
- if (type == "word") {
226
- state.tagName = stream.current();
227
- setStyle = "tag";
228
- return attrState;
229
- } else {
230
- setStyle = "error";
231
- return tagNameState;
232
- }
233
- }
234
- function closeTagNameState(type, stream, state) {
235
- if (type == "word") {
236
- var tagName = stream.current();
237
- if (state.context && state.context.tagName != tagName &&
238
- config.implicitlyClosed.hasOwnProperty(state.context.tagName))
239
- popContext(state);
240
- if ((state.context && state.context.tagName == tagName) || config.matchClosing === false) {
241
- setStyle = "tag";
242
- return closeState;
243
- } else {
244
- setStyle = "tag error";
245
- return closeStateErr;
246
- }
247
- } else {
248
- setStyle = "error";
249
- return closeStateErr;
250
- }
251
- }
252
-
253
- function closeState(type, _stream, state) {
254
- if (type != "endTag") {
255
- setStyle = "error";
256
- return closeState;
257
- }
258
- popContext(state);
259
- return baseState;
260
- }
261
- function closeStateErr(type, stream, state) {
262
- setStyle = "error";
263
- return closeState(type, stream, state);
264
- }
265
-
266
- function attrState(type, _stream, state) {
267
- if (type == "word") {
268
- setStyle = "attribute";
269
- return attrEqState;
270
- } else if (type == "endTag" || type == "selfcloseTag") {
271
- var tagName = state.tagName, tagStart = state.tagStart;
272
- state.tagName = state.tagStart = null;
273
- if (type == "selfcloseTag" ||
274
- config.autoSelfClosers.hasOwnProperty(tagName)) {
275
- maybePopContext(state, tagName);
276
- } else {
277
- maybePopContext(state, tagName);
278
- state.context = new Context(state, tagName, tagStart == state.indented);
279
- }
280
- return baseState;
281
- }
282
- setStyle = "error";
283
- return attrState;
284
- }
285
- function attrEqState(type, stream, state) {
286
- if (type == "equals") return attrValueState;
287
- if (!config.allowMissing) setStyle = "error";
288
- return attrState(type, stream, state);
289
- }
290
- function attrValueState(type, stream, state) {
291
- if (type == "string") return attrContinuedState;
292
- if (type == "word" && config.allowUnquoted) {setStyle = "string"; return attrState;}
293
- setStyle = "error";
294
- return attrState(type, stream, state);
295
- }
296
- function attrContinuedState(type, stream, state) {
297
- if (type == "string") return attrContinuedState;
298
- return attrState(type, stream, state);
299
- }
300
-
301
- return {
302
- startState: function(baseIndent) {
303
- var state = {tokenize: inText,
304
- state: baseState,
305
- indented: baseIndent || 0,
306
- tagName: null, tagStart: null,
307
- context: null}
308
- if (baseIndent != null) state.baseIndent = baseIndent
309
- return state
310
- },
311
-
312
- token: function(stream, state) {
313
- if (!state.tagName && stream.sol())
314
- state.indented = stream.indentation();
315
-
316
- if (stream.eatSpace()) return null;
317
- type = null;
318
- var style = state.tokenize(stream, state);
319
- if ((style || type) && style != "comment") {
320
- setStyle = null;
321
- state.state = state.state(type || style, stream, state);
322
- if (setStyle)
323
- style = setStyle == "error" ? style + " error" : setStyle;
324
- }
325
- return style;
326
- },
327
-
328
- indent: function(state, textAfter, fullLine) {
329
- var context = state.context;
330
- // Indent multi-line strings (e.g. css).
331
- if (state.tokenize.isInAttribute) {
332
- if (state.tagStart == state.indented)
333
- return state.stringStartCol + 1;
334
- else
335
- return state.indented + indentUnit;
336
- }
337
- if (context && context.noIndent) return CodeMirror.Pass;
338
- if (state.tokenize != inTag && state.tokenize != inText)
339
- return fullLine ? fullLine.match(/^(\s*)/)[0].length : 0;
340
- // Indent the starts of attribute names.
341
- if (state.tagName) {
342
- if (config.multilineTagIndentPastTag !== false)
343
- return state.tagStart + state.tagName.length + 2;
344
- else
345
- return state.tagStart + indentUnit * (config.multilineTagIndentFactor || 1);
346
- }
347
- if (config.alignCDATA && /<!\[CDATA\[/.test(textAfter)) return 0;
348
- var tagAfter = textAfter && /^<(\/)?([\w_:\.-]*)/.exec(textAfter);
349
- if (tagAfter && tagAfter[1]) { // Closing tag spotted
350
- while (context) {
351
- if (context.tagName == tagAfter[2]) {
352
- context = context.prev;
353
- break;
354
- } else if (config.implicitlyClosed.hasOwnProperty(context.tagName)) {
355
- context = context.prev;
356
- } else {
357
- break;
358
- }
359
- }
360
- } else if (tagAfter) { // Opening tag spotted
361
- while (context) {
362
- var grabbers = config.contextGrabbers[context.tagName];
363
- if (grabbers && grabbers.hasOwnProperty(tagAfter[2]))
364
- context = context.prev;
365
- else
366
- break;
367
- }
368
- }
369
- while (context && context.prev && !context.startOfLine)
370
- context = context.prev;
371
- if (context) return context.indent + indentUnit;
372
- else return state.baseIndent || 0;
373
- },
374
-
375
- electricInput: /<\/[\s\w:]+>$/,
376
- blockCommentStart: "<!--",
377
- blockCommentEnd: "-->",
378
-
379
- configuration: config.htmlMode ? "html" : "xml",
380
- helperType: config.htmlMode ? "html" : "xml",
381
-
382
- skipAttribute: function(state) {
383
- if (state.state == attrValueState)
384
- state.state = attrState
385
- }
386
- };
387
- });
388
-
389
- CodeMirror.defineMIME("text/xml", "xml");
390
- CodeMirror.defineMIME("application/xml", "xml");
391
- if (!CodeMirror.mimeModes.hasOwnProperty("text/html"))
392
- CodeMirror.defineMIME("text/html", {name: "xml", htmlMode: true});
393
-
394
- });
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
includes/js/jquery-ui/images/ui-icons_444444_256x240.png DELETED
Binary file
includes/js/jquery-ui/images/ui-icons_555555_256x240.png DELETED
Binary file
includes/js/jquery-ui/images/ui-icons_777620_256x240.png DELETED
Binary file
includes/js/jquery-ui/images/ui-icons_777777_256x240.png DELETED
Binary file
includes/js/jquery-ui/images/ui-icons_cc0000_256x240.png DELETED
Binary file
includes/js/jquery-ui/images/ui-icons_ffffff_256x240.png DELETED
Binary file
includes/js/jquery-ui/jquery-ui.min.css DELETED
@@ -1,7 +0,0 @@
1
- /*! jQuery UI - v1.12.1 - 2016-09-14
2
- * http://jqueryui.com
3
- * Includes: core.css, accordion.css, autocomplete.css, menu.css, button.css, controlgroup.css, checkboxradio.css, datepicker.css, dialog.css, draggable.css, resizable.css, progressbar.css, selectable.css, selectmenu.css, slider.css, sortable.css, spinner.css, tabs.css, tooltip.css, theme.css
4
- * To view and modify this theme, visit http://jqueryui.com/themeroller/?bgShadowXPos=&bgOverlayXPos=&bgErrorXPos=&bgHighlightXPos=&bgContentXPos=&bgHeaderXPos=&bgActiveXPos=&bgHoverXPos=&bgDefaultXPos=&bgShadowYPos=&bgOverlayYPos=&bgErrorYPos=&bgHighlightYPos=&bgContentYPos=&bgHeaderYPos=&bgActiveYPos=&bgHoverYPos=&bgDefaultYPos=&bgShadowRepeat=&bgOverlayRepeat=&bgErrorRepeat=&bgHighlightRepeat=&bgContentRepeat=&bgHeaderRepeat=&bgActiveRepeat=&bgHoverRepeat=&bgDefaultRepeat=&iconsHover=url(%22images%2Fui-icons_555555_256x240.png%22)&iconsHighlight=url(%22images%2Fui-icons_777620_256x240.png%22)&iconsHeader=url(%22images%2Fui-icons_444444_256x240.png%22)&iconsError=url(%22images%2Fui-icons_cc0000_256x240.png%22)&iconsDefault=url(%22images%2Fui-icons_777777_256x240.png%22)&iconsContent=url(%22images%2Fui-icons_444444_256x240.png%22)&iconsActive=url(%22images%2Fui-icons_ffffff_256x240.png%22)&bgImgUrlShadow=&bgImgUrlOverlay=&bgImgUrlHover=&bgImgUrlHighlight=&bgImgUrlHeader=&bgImgUrlError=&bgImgUrlDefault=&bgImgUrlContent=&bgImgUrlActive=&opacityFilterShadow=Alpha(Opacity%3D30)&opacityFilterOverlay=Alpha(Opacity%3D30)&opacityShadowPerc=30&opacityOverlayPerc=30&iconColorHover=%23555555&iconColorHighlight=%23777620&iconColorHeader=%23444444&iconColorError=%23cc0000&iconColorDefault=%23777777&iconColorContent=%23444444&iconColorActive=%23ffffff&bgImgOpacityShadow=0&bgImgOpacityOverlay=0&bgImgOpacityError=95&bgImgOpacityHighlight=55&bgImgOpacityContent=75&bgImgOpacityHeader=75&bgImgOpacityActive=65&bgImgOpacityHover=75&bgImgOpacityDefault=75&bgTextureShadow=flat&bgTextureOverlay=flat&bgTextureError=flat&bgTextureHighlight=flat&bgTextureContent=flat&bgTextureHeader=flat&bgTextureActive=flat&bgTextureHover=flat&bgTextureDefault=flat&cornerRadius=3px&fwDefault=normal&ffDefault=Arial%2CHelvetica%2Csans-serif&fsDefault=1em&cornerRadiusShadow=8px&thicknessShadow=5px&offsetLeftShadow=0px&offsetTopShadow=0px&opacityShadow=.3&bgColorShadow=%23666666&opacityOverlay=.3&bgColorOverlay=%23aaaaaa&fcError=%235f3f3f&borderColorError=%23f1a899&bgColorError=%23fddfdf&fcHighlight=%23777620&borderColorHighlight=%23dad55e&bgColorHighlight=%23fffa90&fcContent=%23333333&borderColorContent=%23dddddd&bgColorContent=%23ffffff&fcHeader=%23333333&borderColorHeader=%23dddddd&bgColorHeader=%23e9e9e9&fcActive=%23ffffff&borderColorActive=%23003eff&bgColorActive=%23007fff&fcHover=%232b2b2b&borderColorHover=%23cccccc&bgColorHover=%23ededed&fcDefault=%23454545&borderColorDefault=%23c5c5c5&bgColorDefault=%23f6f6f6
5
- * Copyright jQuery Foundation and other contributors; Licensed MIT */
6
-
7
- .ui-helper-hidden{display:none}.ui-helper-hidden-accessible{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.ui-helper-reset{margin:0;padding:0;border:0;outline:0;line-height:1.3;text-decoration:none;font-size:100%;list-style:none}.ui-helper-clearfix:before,.ui-helper-clearfix:after{content:"";display:table;border-collapse:collapse}.ui-helper-clearfix:after{clear:both}.ui-helper-zfix{width:100%;height:100%;top:0;left:0;position:absolute;opacity:0;filter:Alpha(Opacity=0)}.ui-front{z-index:100}.ui-state-disabled{cursor:default!important;pointer-events:none}.ui-icon{display:inline-block;vertical-align:middle;margin-top:-.25em;position:relative;text-indent:-99999px;overflow:hidden;background-repeat:no-repeat}.ui-widget-icon-block{left:50%;margin-left:-8px;display:block}.ui-widget-overlay{position:fixed;top:0;left:0;width:100%;height:100%}.ui-accordion .ui-accordion-header{display:block;cursor:pointer;position:relative;margin:2px 0 0 0;padding:.5em .5em .5em .7em;font-size:100%}.ui-accordion .ui-accordion-content{padding:1em 2.2em;border-top:0;overflow:auto}.ui-autocomplete{position:absolute;top:0;left:0;cursor:default}.ui-menu{list-style:none;padding:0;margin:0;display:block;outline:0}.ui-menu .ui-menu{position:absolute}.ui-menu .ui-menu-item{margin:0;cursor:pointer;list-style-image:url("")}.ui-menu .ui-menu-item-wrapper{position:relative;padding:3px 1em 3px .4em}.ui-menu .ui-menu-divider{margin:5px 0;height:0;font-size:0;line-height:0;border-width:1px 0 0 0}.ui-menu .ui-state-focus,.ui-menu .ui-state-active{margin:-1px}.ui-menu-icons{position:relative}.ui-menu-icons .ui-menu-item-wrapper{padding-left:2em}.ui-menu .ui-icon{position:absolute;top:0;bottom:0;left:.2em;margin:auto 0}.ui-menu .ui-menu-icon{left:auto;right:0}.ui-button{padding:.4em 1em;display:inline-block;position:relative;line-height:normal;margin-right:.1em;cursor:pointer;vertical-align:middle;text-align:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:visible}.ui-button,.ui-button:link,.ui-button:visited,.ui-button:hover,.ui-button:active{text-decoration:none}.ui-button-icon-only{width:2em;box-sizing:border-box;text-indent:-9999px;white-space:nowrap}input.ui-button.ui-button-icon-only{text-indent:0}.ui-button-icon-only .ui-icon{position:absolute;top:50%;left:50%;margin-top:-8px;margin-left:-8px}.ui-button.ui-icon-notext .ui-icon{padding:0;width:2.1em;height:2.1em;text-indent:-9999px;white-space:nowrap}input.ui-button.ui-icon-notext .ui-icon{width:auto;height:auto;text-indent:0;white-space:normal;padding:.4em 1em}input.ui-button::-moz-focus-inner,button.ui-button::-moz-focus-inner{border:0;padding:0}.ui-controlgroup{vertical-align:middle;display:inline-block}.ui-controlgroup > .ui-controlgroup-item{float:left;margin-left:0;margin-right:0}.ui-controlgroup > .ui-controlgroup-item:focus,.ui-controlgroup > .ui-controlgroup-item.ui-visual-focus{z-index:9999}.ui-controlgroup-vertical > .ui-controlgroup-item{display:block;float:none;width:100%;margin-top:0;margin-bottom:0;text-align:left}.ui-controlgroup-vertical .ui-controlgroup-item{box-sizing:border-box}.ui-controlgroup .ui-controlgroup-label{padding:.4em 1em}.ui-controlgroup .ui-controlgroup-label span{font-size:80%}.ui-controlgroup-horizontal .ui-controlgroup-label + .ui-controlgroup-item{border-left:none}.ui-controlgroup-vertical .ui-controlgroup-label + .ui-controlgroup-item{border-top:none}.ui-controlgroup-horizontal .ui-controlgroup-label.ui-widget-content{border-right:none}.ui-controlgroup-vertical .ui-controlgroup-label.ui-widget-content{border-bottom:none}.ui-controlgroup-vertical .ui-spinner-input{width:75%;width:calc( 100% - 2.4em )}.ui-controlgroup-vertical .ui-spinner .ui-spinner-up{border-top-style:solid}.ui-checkboxradio-label .ui-icon-background{box-shadow:inset 1px 1px 1px #ccc;border-radius:.12em;border:none}.ui-checkboxradio-radio-label .ui-icon-background{width:16px;height:16px;border-radius:1em;overflow:visible;border:none}.ui-checkboxradio-radio-label.ui-checkboxradio-checked .ui-icon,.ui-checkboxradio-radio-label.ui-checkboxradio-checked:hover .ui-icon{background-image:none;width:8px;height:8px;border-width:4px;border-style:solid}.ui-checkboxradio-disabled{pointer-events:none}.ui-datepicker{width:17em;padding:.2em .2em 0;display:none}.ui-datepicker .ui-datepicker-header{position:relative;padding:.2em 0}.ui-datepicker .ui-datepicker-prev,.ui-datepicker .ui-datepicker-next{position:absolute;top:2px;width:1.8em;height:1.8em}.ui-datepicker .ui-datepicker-prev-hover,.ui-datepicker .ui-datepicker-next-hover{top:1px}.ui-datepicker .ui-datepicker-prev{left:2px}.ui-datepicker .ui-datepicker-next{right:2px}.ui-datepicker .ui-datepicker-prev-hover{left:1px}.ui-datepicker .ui-datepicker-next-hover{right:1px}.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}.ui-datepicker .ui-datepicker-title{margin:0 2.3em;line-height:1.8em;text-align:center}.ui-datepicker .ui-datepicker-title select{font-size:1em;margin:1px 0}.ui-datepicker select.ui-datepicker-month,.ui-datepicker select.ui-datepicker-year{width:45%}.ui-datepicker table{width:100%;font-size:.9em;border-collapse:collapse;margin:0 0 .4em}.ui-datepicker th{padding:.7em .3em;text-align:center;font-weight:bold;border:0}.ui-datepicker td{border:0;padding:1px}.ui-datepicker td span,.ui-datepicker td a{display:block;padding:.2em;text-align:right;text-decoration:none}.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}.ui-datepicker .ui-datepicker-buttonpane button{float:right;margin:.5em .2em .4em;cursor:pointer;padding:.2em .6em .3em .6em;width:auto;overflow:visible}.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current{float:left}.ui-datepicker.ui-datepicker-multi{width:auto}.ui-datepicker-multi .ui-datepicker-group{float:left}.ui-datepicker-multi .ui-datepicker-group table{width:95%;margin:0 auto .4em}.ui-datepicker-multi-2 .ui-datepicker-group{width:50%}.ui-datepicker-multi-3 .ui-datepicker-group{width:33.3%}.ui-datepicker-multi-4 .ui-datepicker-group{width:25%}.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header,.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header{border-left-width:0}.ui-datepicker-multi .ui-datepicker-buttonpane{clear:left}.ui-datepicker-row-break{clear:both;width:100%;font-size:0}.ui-datepicker-rtl{direction:rtl}.ui-datepicker-rtl .ui-datepicker-prev{right:2px;left:auto}.ui-datepicker-rtl .ui-datepicker-next{left:2px;right:auto}.ui-datepicker-rtl .ui-datepicker-prev:hover{right:1px;left:auto}.ui-datepicker-rtl .ui-datepicker-next:hover{left:1px;right:auto}.ui-datepicker-rtl .ui-datepicker-buttonpane{clear:right}.ui-datepicker-rtl .ui-datepicker-buttonpane button{float:left}.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current,.ui-datepicker-rtl .ui-datepicker-group{float:right}.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header,.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header{border-right-width:0;border-left-width:1px}.ui-datepicker .ui-icon{display:block;text-indent:-99999px;overflow:hidden;background-repeat:no-repeat;left:.5em;top:.3em}.ui-dialog{position:absolute;top:0;left:0;padding:.2em;outline:0}.ui-dialog .ui-dialog-titlebar{padding:.4em 1em;position:relative}.ui-dialog .ui-dialog-title{float:left;margin:.1em 0;white-space:nowrap;width:90%;overflow:hidden;text-overflow:ellipsis}.ui-dialog .ui-dialog-titlebar-close{position:absolute;right:.3em;top:50%;width:20px;margin:-10px 0 0 0;padding:1px;height:20px}.ui-dialog .ui-dialog-content{position:relative;border:0;padding:.5em 1em;background:none;overflow:auto}.ui-dialog .ui-dialog-buttonpane{text-align:left;border-width:1px 0 0 0;background-image:none;margin-top:.5em;padding:.3em 1em .5em .4em}.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset{float:right}.ui-dialog .ui-dialog-buttonpane button{margin:.5em .4em .5em 0;cursor:pointer}.ui-dialog .ui-resizable-n{height:2px;top:0}.ui-dialog .ui-resizable-e{width:2px;right:0}.ui-dialog .ui-resizable-s{height:2px;bottom:0}.ui-dialog .ui-resizable-w{width:2px;left:0}.ui-dialog .ui-resizable-se,.ui-dialog .ui-resizable-sw,.ui-dialog .ui-resizable-ne,.ui-dialog .ui-resizable-nw{width:7px;height:7px}.ui-dialog .ui-resizable-se{right:0;bottom:0}.ui-dialog .ui-resizable-sw{left:0;bottom:0}.ui-dialog .ui-resizable-ne{right:0;top:0}.ui-dialog .ui-resizable-nw{left:0;top:0}.ui-draggable .ui-dialog-titlebar{cursor:move}.ui-draggable-handle{-ms-touch-action:none;touch-action:none}.ui-resizable{position:relative}.ui-resizable-handle{position:absolute;font-size:0.1px;display:block;-ms-touch-action:none;touch-action:none}.ui-resizable-disabled .ui-resizable-handle,.ui-resizable-autohide .ui-resizable-handle{display:none}.ui-resizable-n{cursor:n-resize;height:7px;width:100%;top:-5px;left:0}.ui-resizable-s{cursor:s-resize;height:7px;width:100%;bottom:-5px;left:0}.ui-resizable-e{cursor:e-resize;width:7px;right:-5px;top:0;height:100%}.ui-resizable-w{cursor:w-resize;width:7px;left:-5px;top:0;height:100%}.ui-resizable-se{cursor:se-resize;width:12px;height:12px;right:1px;bottom:1px}.ui-resizable-sw{cursor:sw-resize;width:9px;height:9px;left:-5px;bottom:-5px}.ui-resizable-nw{cursor:nw-resize;width:9px;height:9px;left:-5px;top:-5px}.ui-resizable-ne{cursor:ne-resize;width:9px;height:9px;right:-5px;top:-5px}.ui-progressbar{height:2em;text-align:left;overflow:hidden}.ui-progressbar .ui-progressbar-value{margin:-1px;height:100%}.ui-progressbar .ui-progressbar-overlay{background:url("");height:100%;filter:alpha(opacity=25);opacity:0.25}.ui-progressbar-indeterminate .ui-progressbar-value{background-image:none}.ui-selectable{-ms-touch-action:none;touch-action:none}.ui-selectable-helper{position:absolute;z-index:100;border:1px dotted black}.ui-selectmenu-menu{padding:0;margin:0;position:absolute;top:0;left:0;display:none}.ui-selectmenu-menu .ui-menu{overflow:auto;overflow-x:hidden;padding-bottom:1px}.ui-selectmenu-menu .ui-menu .ui-selectmenu-optgroup{font-size:1em;font-weight:bold;line-height:1.5;padding:2px 0.4em;margin:0.5em 0 0 0;height:auto;border:0}.ui-selectmenu-open{display:block}.ui-selectmenu-text{display:block;margin-right:20px;overflow:hidden;text-overflow:ellipsis}.ui-selectmenu-button.ui-button{text-align:left;white-space:nowrap;width:14em}.ui-selectmenu-icon.ui-icon{float:right;margin-top:0}.ui-slider{position:relative;text-align:left}.ui-slider .ui-slider-handle{position:absolute;z-index:2;width:1.2em;height:1.2em;cursor:default;-ms-touch-action:none;touch-action:none}.ui-slider .ui-slider-range{position:absolute;z-index:1;font-size:.7em;display:block;border:0;background-position:0 0}.ui-slider.ui-state-disabled .ui-slider-handle,.ui-slider.ui-state-disabled .ui-slider-range{filter:inherit}.ui-slider-horizontal{height:.8em}.ui-slider-horizontal .ui-slider-handle{top:-.3em;margin-left:-.6em}.ui-slider-horizontal .ui-slider-range{top:0;height:100%}.ui-slider-horizontal .ui-slider-range-min{left:0}.ui-slider-horizontal .ui-slider-range-max{right:0}.ui-slider-vertical{width:.8em;height:100px}.ui-slider-vertical .ui-slider-handle{left:-.3em;margin-left:0;margin-bottom:-.6em}.ui-slider-vertical .ui-slider-range{left:0;width:100%}.ui-slider-vertical .ui-slider-range-min{bottom:0}.ui-slider-vertical .ui-slider-range-max{top:0}.ui-sortable-handle{-ms-touch-action:none;touch-action:none}.ui-spinner{position:relative;display:inline-block;overflow:hidden;padding:0;vertical-align:middle}.ui-spinner-input{border:none;background:none;color:inherit;padding:.222em 0;margin:.2em 0;vertical-align:middle;margin-left:.4em;margin-right:2em}.ui-spinner-button{width:1.6em;height:50%;font-size:.5em;padding:0;margin:0;text-align:center;position:absolute;cursor:default;display:block;overflow:hidden;right:0}.ui-spinner a.ui-spinner-button{border-top-style:none;border-bottom-style:none;border-right-style:none}.ui-spinner-up{top:0}.ui-spinner-down{bottom:0}.ui-tabs{position:relative;padding:.2em}.ui-tabs .ui-tabs-nav{margin:0;padding:.2em .2em 0}.ui-tabs .ui-tabs-nav li{list-style:none;float:left;position:relative;top:0;margin:1px .2em 0 0;border-bottom-width:0;padding:0;white-space:nowrap}.ui-tabs .ui-tabs-nav .ui-tabs-anchor{float:left;padding:.5em 1em;text-decoration:none}.ui-tabs .ui-tabs-nav li.ui-tabs-active{margin-bottom:-1px;padding-bottom:1px}.ui-tabs .ui-tabs-nav li.ui-tabs-active .ui-tabs-anchor,.ui-tabs .ui-tabs-nav li.ui-state-disabled .ui-tabs-anchor,.ui-tabs .ui-tabs-nav li.ui-tabs-loading .ui-tabs-anchor{cursor:text}.ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-active .ui-tabs-anchor{cursor:pointer}.ui-tabs .ui-tabs-panel{display:block;border-width:0;padding:1em 1.4em;background:none}.ui-tooltip{padding:8px;position:absolute;z-index:9999;max-width:300px}body .ui-tooltip{border-width:2px}.ui-widget{font-family:Arial,Helvetica,sans-serif;font-size:1em}.ui-widget .ui-widget{font-size:1em}.ui-widget input,.ui-widget select,.ui-widget textarea,.ui-widget button{font-family:Arial,Helvetica,sans-serif;font-size:1em}.ui-widget.ui-widget-content{border:1px solid #c5c5c5}.ui-widget-content{border:1px solid #ddd;background:#fff;color:#333}.ui-widget-content a{color:#333}.ui-widget-header{border:1px solid #ddd;background:#e9e9e9;color:#333;font-weight:bold}.ui-widget-header a{color:#333}.ui-state-default,.ui-widget-content .ui-state-default,.ui-widget-header .ui-state-default,.ui-button,html .ui-button.ui-state-disabled:hover,html .ui-button.ui-state-disabled:active{border:1px solid #c5c5c5;background:#f6f6f6;font-weight:normal;color:#454545}.ui-state-default a,.ui-state-default a:link,.ui-state-default a:visited,a.ui-button,a:link.ui-button,a:visited.ui-button,.ui-button{color:#454545;text-decoration:none}.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,.ui-button:hover,.ui-button:focus{border:1px solid #ccc;background:#ededed;font-weight:normal;color:#2b2b2b}.ui-state-hover a,.ui-state-hover a:hover,.ui-state-hover a:link,.ui-state-hover a:visited,.ui-state-focus a,.ui-state-focus a:hover,.ui-state-focus a:link,.ui-state-focus a:visited,a.ui-button:hover,a.ui-button:focus{color:#2b2b2b;text-decoration:none}.ui-visual-focus{box-shadow:0 0 3px 1px rgb(94,158,214)}.ui-state-active,.ui-widget-content .ui-state-active,.ui-widget-header .ui-state-active,a.ui-button:active,.ui-button:active,.ui-button.ui-state-active:hover{border:1px solid #003eff;background:#007fff;font-weight:normal;color:#fff}.ui-icon-background,.ui-state-active .ui-icon-background{border:#003eff;background-color:#fff}.ui-state-active a,.ui-state-active a:link,.ui-state-active a:visited{color:#fff;text-decoration:none}.ui-state-highlight,.ui-widget-content .ui-state-highlight,.ui-widget-header .ui-state-highlight{border:1px solid #dad55e;background:#fffa90;color:#777620}.ui-state-checked{border:1px solid #dad55e;background:#fffa90}.ui-state-highlight a,.ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a{color:#777620}.ui-state-error,.ui-widget-content .ui-state-error,.ui-widget-header .ui-state-error{border:1px solid #f1a899;background:#fddfdf;color:#5f3f3f}.ui-state-error a,.ui-widget-content .ui-state-error a,.ui-widget-header .ui-state-error a{color:#5f3f3f}.ui-state-error-text,.ui-widget-content .ui-state-error-text,.ui-widget-header .ui-state-error-text{color:#5f3f3f}.ui-priority-primary,.ui-widget-content .ui-priority-primary,.ui-widget-header .ui-priority-primary{font-weight:bold}.ui-priority-secondary,.ui-widget-content .ui-priority-secondary,.ui-widget-header .ui-priority-secondary{opacity:.7;filter:Alpha(Opacity=70);font-weight:normal}.ui-state-disabled,.ui-widget-content .ui-state-disabled,.ui-widget-header .ui-state-disabled{opacity:.35;filter:Alpha(Opacity=35);background-image:none}.ui-state-disabled .ui-icon{filter:Alpha(Opacity=35)}.ui-icon{width:16px;height:16px}.ui-icon,.ui-widget-content .ui-icon{background-image:url("images/ui-icons_444444_256x240.png")}.ui-widget-header .ui-icon{background-image:url("images/ui-icons_444444_256x240.png")}.ui-state-hover .ui-icon,.ui-state-focus .ui-icon,.ui-button:hover .ui-icon,.ui-button:focus .ui-icon{background-image:url("images/ui-icons_555555_256x240.png")}.ui-state-active .ui-icon,.ui-button:active .ui-icon{background-image:url("images/ui-icons_ffffff_256x240.png")}.ui-state-highlight .ui-icon,.ui-button .ui-state-highlight.ui-icon{background-image:url("images/ui-icons_777620_256x240.png")}.ui-state-error .ui-icon,.ui-state-error-text .ui-icon{background-image:url("images/ui-icons_cc0000_256x240.png")}.ui-button .ui-icon{background-image:url("images/ui-icons_777777_256x240.png")}.ui-icon-blank{background-position:16px 16px}.ui-icon-caret-1-n{background-position:0 0}.ui-icon-caret-1-ne{background-position:-16px 0}.ui-icon-caret-1-e{background-position:-32px 0}.ui-icon-caret-1-se{background-position:-48px 0}.ui-icon-caret-1-s{background-position:-65px 0}.ui-icon-caret-1-sw{background-position:-80px 0}.ui-icon-caret-1-w{background-position:-96px 0}.ui-icon-caret-1-nw{background-position:-112px 0}.ui-icon-caret-2-n-s{background-position:-128px 0}.ui-icon-caret-2-e-w{background-position:-144px 0}.ui-icon-triangle-1-n{background-position:0 -16px}.ui-icon-triangle-1-ne{background-position:-16px -16px}.ui-icon-triangle-1-e{background-position:-32px -16px}.ui-icon-triangle-1-se{background-position:-48px -16px}.ui-icon-triangle-1-s{background-position:-65px -16px}.ui-icon-triangle-1-sw{background-position:-80px -16px}.ui-icon-triangle-1-w{background-position:-96px -16px}.ui-icon-triangle-1-nw{background-position:-112px -16px}.ui-icon-triangle-2-n-s{background-position:-128px -16px}.ui-icon-triangle-2-e-w{background-position:-144px -16px}.ui-icon-arrow-1-n{background-position:0 -32px}.ui-icon-arrow-1-ne{background-position:-16px -32px}.ui-icon-arrow-1-e{background-position:-32px -32px}.ui-icon-arrow-1-se{background-position:-48px -32px}.ui-icon-arrow-1-s{background-position:-65px -32px}.ui-icon-arrow-1-sw{background-position:-80px -32px}.ui-icon-arrow-1-w{background-position:-96px -32px}.ui-icon-arrow-1-nw{background-position:-112px -32px}.ui-icon-arrow-2-n-s{background-position:-128px -32px}.ui-icon-arrow-2-ne-sw{background-position:-144px -32px}.ui-icon-arrow-2-e-w{background-position:-160px -32px}.ui-icon-arrow-2-se-nw{background-position:-176px -32px}.ui-icon-arrowstop-1-n{background-position:-192px -32px}.ui-icon-arrowstop-1-e{background-position:-208px -32px}.ui-icon-arrowstop-1-s{background-position:-224px -32px}.ui-icon-arrowstop-1-w{background-position:-240px -32px}.ui-icon-arrowthick-1-n{background-position:1px -48px}.ui-icon-arrowthick-1-ne{background-position:-16px -48px}.ui-icon-arrowthick-1-e{background-position:-32px -48px}.ui-icon-arrowthick-1-se{background-position:-48px -48px}.ui-icon-arrowthick-1-s{background-position:-64px -48px}.ui-icon-arrowthick-1-sw{background-position:-80px -48px}.ui-icon-arrowthick-1-w{background-position:-96px -48px}.ui-icon-arrowthick-1-nw{background-position:-112px -48px}.ui-icon-arrowthick-2-n-s{background-position:-128px -48px}.ui-icon-arrowthick-2-ne-sw{background-position:-144px -48px}.ui-icon-arrowthick-2-e-w{background-position:-160px -48px}.ui-icon-arrowthick-2-se-nw{background-position:-176px -48px}.ui-icon-arrowthickstop-1-n{background-position:-192px -48px}.ui-icon-arrowthickstop-1-e{background-position:-208px -48px}.ui-icon-arrowthickstop-1-s{background-position:-224px -48px}.ui-icon-arrowthickstop-1-w{background-position:-240px -48px}.ui-icon-arrowreturnthick-1-w{background-position:0 -64px}.ui-icon-arrowreturnthick-1-n{background-position:-16px -64px}.ui-icon-arrowreturnthick-1-e{background-position:-32px -64px}.ui-icon-arrowreturnthick-1-s{background-position:-48px -64px}.ui-icon-arrowreturn-1-w{background-position:-64px -64px}.ui-icon-arrowreturn-1-n{background-position:-80px -64px}.ui-icon-arrowreturn-1-e{background-position:-96px -64px}.ui-icon-arrowreturn-1-s{background-position:-112px -64px}.ui-icon-arrowrefresh-1-w{background-position:-128px -64px}.ui-icon-arrowrefresh-1-n{background-position:-144px -64px}.ui-icon-arrowrefresh-1-e{background-position:-160px -64px}.ui-icon-arrowrefresh-1-s{background-position:-176px -64px}.ui-icon-arrow-4{background-position:0 -80px}.ui-icon-arrow-4-diag{background-position:-16px -80px}.ui-icon-extlink{background-position:-32px -80px}.ui-icon-newwin{background-position:-48px -80px}.ui-icon-refresh{background-position:-64px -80px}.ui-icon-shuffle{background-position:-80px -80px}.ui-icon-transfer-e-w{background-position:-96px -80px}.ui-icon-transferthick-e-w{background-position:-112px -80px}.ui-icon-folder-collapsed{background-position:0 -96px}.ui-icon-folder-open{background-position:-16px -96px}.ui-icon-document{background-position:-32px -96px}.ui-icon-document-b{background-position:-48px -96px}.ui-icon-note{background-position:-64px -96px}.ui-icon-mail-closed{background-position:-80px -96px}.ui-icon-mail-open{background-position:-96px -96px}.ui-icon-suitcase{background-position:-112px -96px}.ui-icon-comment{background-position:-128px -96px}.ui-icon-person{background-position:-144px -96px}.ui-icon-print{background-position:-160px -96px}.ui-icon-trash{background-position:-176px -96px}.ui-icon-locked{background-position:-192px -96px}.ui-icon-unlocked{background-position:-208px -96px}.ui-icon-bookmark{background-position:-224px -96px}.ui-icon-tag{background-position:-240px -96px}.ui-icon-home{background-position:0 -112px}.ui-icon-flag{background-position:-16px -112px}.ui-icon-calendar{background-position:-32px -112px}.ui-icon-cart{background-position:-48px -112px}.ui-icon-pencil{background-position:-64px -112px}.ui-icon-clock{background-position:-80px -112px}.ui-icon-disk{background-position:-96px -112px}.ui-icon-calculator{background-position:-112px -112px}.ui-icon-zoomin{background-position:-128px -112px}.ui-icon-zoomout{background-position:-144px -112px}.ui-icon-search{background-position:-160px -112px}.ui-icon-wrench{background-position:-176px -112px}.ui-icon-gear{background-position:-192px -112px}.ui-icon-heart{background-position:-208px -112px}.ui-icon-star{background-position:-224px -112px}.ui-icon-link{background-position:-240px -112px}.ui-icon-cancel{background-position:0 -128px}.ui-icon-plus{background-position:-16px -128px}.ui-icon-plusthick{background-position:-32px -128px}.ui-icon-minus{background-position:-48px -128px}.ui-icon-minusthick{background-position:-64px -128px}.ui-icon-close{background-position:-80px -128px}.ui-icon-closethick{background-position:-96px -128px}.ui-icon-key{background-position:-112px -128px}.ui-icon-lightbulb{background-position:-128px -128px}.ui-icon-scissors{background-position:-144px -128px}.ui-icon-clipboard{background-position:-160px -128px}.ui-icon-copy{background-position:-176px -128px}.ui-icon-contact{background-position:-192px -128px}.ui-icon-image{background-position:-208px -128px}.ui-icon-video{background-position:-224px -128px}.ui-icon-script{background-position:-240px -128px}.ui-icon-alert{background-position:0 -144px}.ui-icon-info{background-position:-16px -144px}.ui-icon-notice{background-position:-32px -144px}.ui-icon-help{background-position:-48px -144px}.ui-icon-check{background-position:-64px -144px}.ui-icon-bullet{background-position:-80px -144px}.ui-icon-radio-on{background-position:-96px -144px}.ui-icon-radio-off{background-position:-112px -144px}.ui-icon-pin-w{background-position:-128px -144px}.ui-icon-pin-s{background-position:-144px -144px}.ui-icon-play{background-position:0 -160px}.ui-icon-pause{background-position:-16px -160px}.ui-icon-seek-next{background-position:-32px -160px}.ui-icon-seek-prev{background-position:-48px -160px}.ui-icon-seek-end{background-position:-64px -160px}.ui-icon-seek-start{background-position:-80px -160px}.ui-icon-seek-first{background-position:-80px -160px}.ui-icon-stop{background-position:-96px -160px}.ui-icon-eject{background-position:-112px -160px}.ui-icon-volume-off{background-position:-128px -160px}.ui-icon-volume-on{background-position:-144px -160px}.ui-icon-power{background-position:0 -176px}.ui-icon-signal-diag{background-position:-16px -176px}.ui-icon-signal{background-position:-32px -176px}.ui-icon-battery-0{background-position:-48px -176px}.ui-icon-battery-1{background-position:-64px -176px}.ui-icon-battery-2{background-position:-80px -176px}.ui-icon-battery-3{background-position:-96px -176px}.ui-icon-circle-plus{background-position:0 -192px}.ui-icon-circle-minus{background-position:-16px -192px}.ui-icon-circle-close{background-position:-32px -192px}.ui-icon-circle-triangle-e{background-position:-48px -192px}.ui-icon-circle-triangle-s{background-position:-64px -192px}.ui-icon-circle-triangle-w{background-position:-80px -192px}.ui-icon-circle-triangle-n{background-position:-96px -192px}.ui-icon-circle-arrow-e{background-position:-112px -192px}.ui-icon-circle-arrow-s{background-position:-128px -192px}.ui-icon-circle-arrow-w{background-position:-144px -192px}.ui-icon-circle-arrow-n{background-position:-160px -192px}.ui-icon-circle-zoomin{background-position:-176px -192px}.ui-icon-circle-zoomout{background-position:-192px -192px}.ui-icon-circle-check{background-position:-208px -192px}.ui-icon-circlesmall-plus{background-position:0 -208px}.ui-icon-circlesmall-minus{background-position:-16px -208px}.ui-icon-circlesmall-close{background-position:-32px -208px}.ui-icon-squaresmall-plus{background-position:-48px -208px}.ui-icon-squaresmall-minus{background-position:-64px -208px}.ui-icon-squaresmall-close{background-position:-80px -208px}.ui-icon-grip-dotted-vertical{background-position:0 -224px}.ui-icon-grip-dotted-horizontal{background-position:-16px -224px}.ui-icon-grip-solid-vertical{background-position:-32px -224px}.ui-icon-grip-solid-horizontal{background-position:-48px -224px}.ui-icon-gripsmall-diagonal-se{background-position:-64px -224px}.ui-icon-grip-diagonal-se{background-position:-80px -224px}.ui-corner-all,.ui-corner-top,.ui-corner-left,.ui-corner-tl{border-top-left-radius:3px}.ui-corner-all,.ui-corner-top,.ui-corner-right,.ui-corner-tr{border-top-right-radius:3px}.ui-corner-all,.ui-corner-bottom,.ui-corner-left,.ui-corner-bl{border-bottom-left-radius:3px}.ui-corner-all,.ui-corner-bottom,.ui-corner-right,.ui-corner-br{border-bottom-right-radius:3px}.ui-widget-overlay{background:#aaa;opacity:.003;filter:Alpha(Opacity=.3)}.ui-widget-shadow{-webkit-box-shadow:0 0 5px #666;box-shadow:0 0 5px #666}
 
 
 
 
 
 
 
includes/js/jquery-ui/jquery-ui.min.js DELETED
@@ -1,13 +0,0 @@
1
- /*! jQuery UI - v1.12.1 - 2016-09-14
2
- * http://jqueryui.com
3
- * Includes: widget.js, position.js, data.js, disable-selection.js, effect.js, effects/effect-blind.js, effects/effect-bounce.js, effects/effect-clip.js, effects/effect-drop.js, effects/effect-explode.js, effects/effect-fade.js, effects/effect-fold.js, effects/effect-highlight.js, effects/effect-puff.js, effects/effect-pulsate.js, effects/effect-scale.js, effects/effect-shake.js, effects/effect-size.js, effects/effect-slide.js, effects/effect-transfer.js, focusable.js, form-reset-mixin.js, jquery-1-7.js, keycode.js, labels.js, scroll-parent.js, tabbable.js, unique-id.js, widgets/accordion.js, widgets/autocomplete.js, widgets/button.js, widgets/checkboxradio.js, widgets/controlgroup.js, widgets/datepicker.js, widgets/dialog.js, widgets/draggable.js, widgets/droppable.js, widgets/menu.js, widgets/mouse.js, widgets/progressbar.js, widgets/resizable.js, widgets/selectable.js, widgets/selectmenu.js, widgets/slider.js, widgets/sortable.js, widgets/spinner.js, widgets/tabs.js, widgets/tooltip.js
4
- * Copyright jQuery Foundation and other contributors; Licensed MIT */
5
-
6
- (function(t){"function"==typeof define&&define.amd?define(["jquery"],t):t(jQuery)})(function(t){function e(t){for(var e=t.css("visibility");"inherit"===e;)t=t.parent(),e=t.css("visibility");return"hidden"!==e}function i(t){for(var e,i;t.length&&t[0]!==document;){if(e=t.css("position"),("absolute"===e||"relative"===e||"fixed"===e)&&(i=parseInt(t.css("zIndex"),10),!isNaN(i)&&0!==i))return i;t=t.parent()}return 0}function s(){this._curInst=null,this._keyEvent=!1,this._disabledInputs=[],this._datepickerShowing=!1,this._inDialog=!1,this._mainDivId="ui-datepicker-div",this._inlineClass="ui-datepicker-inline",this._appendClass="ui-datepicker-append",this._triggerClass="ui-datepicker-trigger",this._dialogClass="ui-datepicker-dialog",this._disableClass="ui-datepicker-disabled",this._unselectableClass="ui-datepicker-unselectable",this._currentClass="ui-datepicker-current-day",this._dayOverClass="ui-datepicker-days-cell-over",this.regional=[],this.regional[""]={closeText:"Done",prevText:"Prev",nextText:"Next",currentText:"Today",monthNames:["January","February","March","April","May","June","July","August","September","October","November","December"],monthNamesShort:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],dayNames:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],dayNamesShort:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],dayNamesMin:["Su","Mo","Tu","We","Th","Fr","Sa"],weekHeader:"Wk",dateFormat:"mm/dd/yy",firstDay:0,isRTL:!1,showMonthAfterYear:!1,yearSuffix:""},this._defaults={showOn:"focus",showAnim:"fadeIn",showOptions:{},defaultDate:null,appendText:"",buttonText:"...",buttonImage:"",buttonImageOnly:!1,hideIfNoPrevNext:!1,navigationAsDateFormat:!1,gotoCurrent:!1,changeMonth:!1,changeYear:!1,yearRange:"c-10:c+10",showOtherMonths:!1,selectOtherMonths:!1,showWeek:!1,calculateWeek:this.iso8601Week,shortYearCutoff:"+10",minDate:null,maxDate:null,duration:"fast",beforeShowDay:null,beforeShow:null,onSelect:null,onChangeMonthYear:null,onClose:null,numberOfMonths:1,showCurrentAtPos:0,stepMonths:1,stepBigMonths:12,altField:"",altFormat:"",constrainInput:!0,showButtonPanel:!1,autoSize:!1,disabled:!1},t.extend(this._defaults,this.regional[""]),this.regional.en=t.extend(!0,{},this.regional[""]),this.regional["en-US"]=t.extend(!0,{},this.regional.en),this.dpDiv=n(t("<div id='"+this._mainDivId+"' class='ui-datepicker ui-widget ui-widget-content ui-helper-clearfix ui-corner-all'></div>"))}function n(e){var i="button, .ui-datepicker-prev, .ui-datepicker-next, .ui-datepicker-calendar td a";return e.on("mouseout",i,function(){t(this).removeClass("ui-state-hover"),-1!==this.className.indexOf("ui-datepicker-prev")&&t(this).removeClass("ui-datepicker-prev-hover"),-1!==this.className.indexOf("ui-datepicker-next")&&t(this).removeClass("ui-datepicker-next-hover")}).on("mouseover",i,o)}function o(){t.datepicker._isDisabledDatepicker(m.inline?m.dpDiv.parent()[0]:m.input[0])||(t(this).parents(".ui-datepicker-calendar").find("a").removeClass("ui-state-hover"),t(this).addClass("ui-state-hover"),-1!==this.className.indexOf("ui-datepicker-prev")&&t(this).addClass("ui-datepicker-prev-hover"),-1!==this.className.indexOf("ui-datepicker-next")&&t(this).addClass("ui-datepicker-next-hover"))}function a(e,i){t.extend(e,i);for(var s in i)null==i[s]&&(e[s]=i[s]);return e}function r(t){return function(){var e=this.element.val();t.apply(this,arguments),this._refresh(),e!==this.element.val()&&this._trigger("change")}}t.ui=t.ui||{},t.ui.version="1.12.1";var h=0,l=Array.prototype.slice;t.cleanData=function(e){return function(i){var s,n,o;for(o=0;null!=(n=i[o]);o++)try{s=t._data(n,"events"),s&&s.remove&&t(n).triggerHandler("remove")}catch(a){}e(i)}}(t.cleanData),t.widget=function(e,i,s){var n,o,a,r={},h=e.split(".")[0];e=e.split(".")[1];var l=h+"-"+e;return s||(s=i,i=t.Widget),t.isArray(s)&&(s=t.extend.apply(null,[{}].concat(s))),t.expr[":"][l.toLowerCase()]=function(e){return!!t.data(e,l)},t[h]=t[h]||{},n=t[h][e],o=t[h][e]=function(t,e){return this._createWidget?(arguments.length&&this._createWidget(t,e),void 0):new o(t,e)},t.extend(o,n,{version:s.version,_proto:t.extend({},s),_childConstructors:[]}),a=new i,a.options=t.widget.extend({},a.options),t.each(s,function(e,s){return t.isFunction(s)?(r[e]=function(){function t(){return i.prototype[e].apply(this,arguments)}function n(t){return i.prototype[e].apply(this,t)}return function(){var e,i=this._super,o=this._superApply;return this._super=t,this._superApply=n,e=s.apply(this,arguments),this._super=i,this._superApply=o,e}}(),void 0):(r[e]=s,void 0)}),o.prototype=t.widget.extend(a,{widgetEventPrefix:n?a.widgetEventPrefix||e:e},r,{constructor:o,namespace:h,widgetName:e,widgetFullName:l}),n?(t.each(n._childConstructors,function(e,i){var s=i.prototype;t.widget(s.namespace+"."+s.widgetName,o,i._proto)}),delete n._childConstructors):i._childConstructors.push(o),t.widget.bridge(e,o),o},t.widget.extend=function(e){for(var i,s,n=l.call(arguments,1),o=0,a=n.length;a>o;o++)for(i in n[o])s=n[o][i],n[o].hasOwnProperty(i)&&void 0!==s&&(e[i]=t.isPlainObject(s)?t.isPlainObject(e[i])?t.widget.extend({},e[i],s):t.widget.extend({},s):s);return e},t.widget.bridge=function(e,i){var s=i.prototype.widgetFullName||e;t.fn[e]=function(n){var o="string"==typeof n,a=l.call(arguments,1),r=this;return o?this.length||"instance"!==n?this.each(function(){var i,o=t.data(this,s);return"instance"===n?(r=o,!1):o?t.isFunction(o[n])&&"_"!==n.charAt(0)?(i=o[n].apply(o,a),i!==o&&void 0!==i?(r=i&&i.jquery?r.pushStack(i.get()):i,!1):void 0):t.error("no such method '"+n+"' for "+e+" widget instance"):t.error("cannot call methods on "+e+" prior to initialization; "+"attempted to call method '"+n+"'")}):r=void 0:(a.length&&(n=t.widget.extend.apply(null,[n].concat(a))),this.each(function(){var e=t.data(this,s);e?(e.option(n||{}),e._init&&e._init()):t.data(this,s,new i(n,this))})),r}},t.Widget=function(){},t.Widget._childConstructors=[],t.Widget.prototype={widgetName:"widget",widgetEventPrefix:"",defaultElement:"<div>",options:{classes:{},disabled:!1,create:null},_createWidget:function(e,i){i=t(i||this.defaultElement||this)[0],this.element=t(i),this.uuid=h++,this.eventNamespace="."+this.widgetName+this.uuid,this.bindings=t(),this.hoverable=t(),this.focusable=t(),this.classesElementLookup={},i!==this&&(t.data(i,this.widgetFullName,this),this._on(!0,this.element,{remove:function(t){t.target===i&&this.destroy()}}),this.document=t(i.style?i.ownerDocument:i.document||i),this.window=t(this.document[0].defaultView||this.document[0].parentWindow)),this.options=t.widget.extend({},this.options,this._getCreateOptions(),e),this._create(),this.options.disabled&&this._setOptionDisabled(this.options.disabled),this._trigger("create",null,this._getCreateEventData()),this._init()},_getCreateOptions:function(){return{}},_getCreateEventData:t.noop,_create:t.noop,_init:t.noop,destroy:function(){var e=this;this._destroy(),t.each(this.classesElementLookup,function(t,i){e._removeClass(i,t)}),this.element.off(this.eventNamespace).removeData(this.widgetFullName),this.widget().off(this.eventNamespace).removeAttr("aria-disabled"),this.bindings.off(this.eventNamespace)},_destroy:t.noop,widget:function(){return this.element},option:function(e,i){var s,n,o,a=e;if(0===arguments.length)return t.widget.extend({},this.options);if("string"==typeof e)if(a={},s=e.split("."),e=s.shift(),s.length){for(n=a[e]=t.widget.extend({},this.options[e]),o=0;s.length-1>o;o++)n[s[o]]=n[s[o]]||{},n=n[s[o]];if(e=s.pop(),1===arguments.length)return void 0===n[e]?null:n[e];n[e]=i}else{if(1===arguments.length)return void 0===this.options[e]?null:this.options[e];a[e]=i}return this._setOptions(a),this},_setOptions:function(t){var e;for(e in t)this._setOption(e,t[e]);return this},_setOption:function(t,e){return"classes"===t&&this._setOptionClasses(e),this.options[t]=e,"disabled"===t&&this._setOptionDisabled(e),this},_setOptionClasses:function(e){var i,s,n;for(i in e)n=this.classesElementLookup[i],e[i]!==this.options.classes[i]&&n&&n.length&&(s=t(n.get()),this._removeClass(n,i),s.addClass(this._classes({element:s,keys:i,classes:e,add:!0})))},_setOptionDisabled:function(t){this._toggleClass(this.widget(),this.widgetFullName+"-disabled",null,!!t),t&&(this._removeClass(this.hoverable,null,"ui-state-hover"),this._removeClass(this.focusable,null,"ui-state-focus"))},enable:function(){return this._setOptions({disabled:!1})},disable:function(){return this._setOptions({disabled:!0})},_classes:function(e){function i(i,o){var a,r;for(r=0;i.length>r;r++)a=n.classesElementLookup[i[r]]||t(),a=e.add?t(t.unique(a.get().concat(e.element.get()))):t(a.not(e.element).get()),n.classesElementLookup[i[r]]=a,s.push(i[r]),o&&e.classes[i[r]]&&s.push(e.classes[i[r]])}var s=[],n=this;return e=t.extend({element:this.element,classes:this.options.classes||{}},e),this._on(e.element,{remove:"_untrackClassesElement"}),e.keys&&i(e.keys.match(/\S+/g)||[],!0),e.extra&&i(e.extra.match(/\S+/g)||[]),s.join(" ")},_untrackClassesElement:function(e){var i=this;t.each(i.classesElementLookup,function(s,n){-1!==t.inArray(e.target,n)&&(i.classesElementLookup[s]=t(n.not(e.target).get()))})},_removeClass:function(t,e,i){return this._toggleClass(t,e,i,!1)},_addClass:function(t,e,i){return this._toggleClass(t,e,i,!0)},_toggleClass:function(t,e,i,s){s="boolean"==typeof s?s:i;var n="string"==typeof t||null===t,o={extra:n?e:i,keys:n?t:e,element:n?this.element:t,add:s};return o.element.toggleClass(this._classes(o),s),this},_on:function(e,i,s){var n,o=this;"boolean"!=typeof e&&(s=i,i=e,e=!1),s?(i=n=t(i),this.bindings=this.bindings.add(i)):(s=i,i=this.element,n=this.widget()),t.each(s,function(s,a){function r(){return e||o.options.disabled!==!0&&!t(this).hasClass("ui-state-disabled")?("string"==typeof a?o[a]:a).apply(o,arguments):void 0}"string"!=typeof a&&(r.guid=a.guid=a.guid||r.guid||t.guid++);var h=s.match(/^([\w:-]*)\s*(.*)$/),l=h[1]+o.eventNamespace,c=h[2];c?n.on(l,c,r):i.on(l,r)})},_off:function(e,i){i=(i||"").split(" ").join(this.eventNamespace+" ")+this.eventNamespace,e.off(i).off(i),this.bindings=t(this.bindings.not(e).get()),this.focusable=t(this.focusable.not(e).get()),this.hoverable=t(this.hoverable.not(e).get())},_delay:function(t,e){function i(){return("string"==typeof t?s[t]:t).apply(s,arguments)}var s=this;return setTimeout(i,e||0)},_hoverable:function(e){this.hoverable=this.hoverable.add(e),this._on(e,{mouseenter:function(e){this._addClass(t(e.currentTarget),null,"ui-state-hover")},mouseleave:function(e){this._removeClass(t(e.currentTarget),null,"ui-state-hover")}})},_focusable:function(e){this.focusable=this.focusable.add(e),this._on(e,{focusin:function(e){this._addClass(t(e.currentTarget),null,"ui-state-focus")},focusout:function(e){this._removeClass(t(e.currentTarget),null,"ui-state-focus")}})},_trigger:function(e,i,s){var n,o,a=this.options[e];if(s=s||{},i=t.Event(i),i.type=(e===this.widgetEventPrefix?e:this.widgetEventPrefix+e).toLowerCase(),i.target=this.element[0],o=i.originalEvent)for(n in o)n in i||(i[n]=o[n]);return this.element.trigger(i,s),!(t.isFunction(a)&&a.apply(this.element[0],[i].concat(s))===!1||i.isDefaultPrevented())}},t.each({show:"fadeIn",hide:"fadeOut"},function(e,i){t.Widget.prototype["_"+e]=function(s,n,o){"string"==typeof n&&(n={effect:n});var a,r=n?n===!0||"number"==typeof n?i:n.effect||i:e;n=n||{},"number"==typeof n&&(n={duration:n}),a=!t.isEmptyObject(n),n.complete=o,n.delay&&s.delay(n.delay),a&&t.effects&&t.effects.effect[r]?s[e](n):r!==e&&s[r]?s[r](n.duration,n.easing,o):s.queue(function(i){t(this)[e](),o&&o.call(s[0]),i()})}}),t.widget,function(){function e(t,e,i){return[parseFloat(t[0])*(u.test(t[0])?e/100:1),parseFloat(t[1])*(u.test(t[1])?i/100:1)]}function i(e,i){return parseInt(t.css(e,i),10)||0}function s(e){var i=e[0];return 9===i.nodeType?{width:e.width(),height:e.height(),offset:{top:0,left:0}}:t.isWindow(i)?{width:e.width(),height:e.height(),offset:{top:e.scrollTop(),left:e.scrollLeft()}}:i.preventDefault?{width:0,height:0,offset:{top:i.pageY,left:i.pageX}}:{width:e.outerWidth(),height:e.outerHeight(),offset:e.offset()}}var n,o=Math.max,a=Math.abs,r=/left|center|right/,h=/top|center|bottom/,l=/[\+\-]\d+(\.[\d]+)?%?/,c=/^\w+/,u=/%$/,d=t.fn.position;t.position={scrollbarWidth:function(){if(void 0!==n)return n;var e,i,s=t("<div style='display:block;position:absolute;width:50px;height:50px;overflow:hidden;'><div style='height:100px;width:auto;'></div></div>"),o=s.children()[0];return t("body").append(s),e=o.offsetWidth,s.css("overflow","scroll"),i=o.offsetWidth,e===i&&(i=s[0].clientWidth),s.remove(),n=e-i},getScrollInfo:function(e){var i=e.isWindow||e.isDocument?"":e.element.css("overflow-x"),s=e.isWindow||e.isDocument?"":e.element.css("overflow-y"),n="scroll"===i||"auto"===i&&e.width<e.element[0].scrollWidth,o="scroll"===s||"auto"===s&&e.height<e.element[0].scrollHeight;return{width:o?t.position.scrollbarWidth():0,height:n?t.position.scrollbarWidth():0}},getWithinInfo:function(e){var i=t(e||window),s=t.isWindow(i[0]),n=!!i[0]&&9===i[0].nodeType,o=!s&&!n;return{element:i,isWindow:s,isDocument:n,offset:o?t(e).offset():{left:0,top:0},scrollLeft:i.scrollLeft(),scrollTop:i.scrollTop(),width:i.outerWidth(),height:i.outerHeight()}}},t.fn.position=function(n){if(!n||!n.of)return d.apply(this,arguments);n=t.extend({},n);var u,p,f,g,m,_,v=t(n.of),b=t.position.getWithinInfo(n.within),y=t.position.getScrollInfo(b),w=(n.collision||"flip").split(" "),k={};return _=s(v),v[0].preventDefault&&(n.at="left top"),p=_.width,f=_.height,g=_.offset,m=t.extend({},g),t.each(["my","at"],function(){var t,e,i=(n[this]||"").split(" ");1===i.length&&(i=r.test(i[0])?i.concat(["center"]):h.test(i[0])?["center"].concat(i):["center","center"]),i[0]=r.test(i[0])?i[0]:"center",i[1]=h.test(i[1])?i[1]:"center",t=l.exec(i[0]),e=l.exec(i[1]),k[this]=[t?t[0]:0,e?e[0]:0],n[this]=[c.exec(i[0])[0],c.exec(i[1])[0]]}),1===w.length&&(w[1]=w[0]),"right"===n.at[0]?m.left+=p:"center"===n.at[0]&&(m.left+=p/2),"bottom"===n.at[1]?m.top+=f:"center"===n.at[1]&&(m.top+=f/2),u=e(k.at,p,f),m.left+=u[0],m.top+=u[1],this.each(function(){var s,r,h=t(this),l=h.outerWidth(),c=h.outerHeight(),d=i(this,"marginLeft"),_=i(this,"marginTop"),x=l+d+i(this,"marginRight")+y.width,C=c+_+i(this,"marginBottom")+y.height,D=t.extend({},m),I=e(k.my,h.outerWidth(),h.outerHeight());"right"===n.my[0]?D.left-=l:"center"===n.my[0]&&(D.left-=l/2),"bottom"===n.my[1]?D.top-=c:"center"===n.my[1]&&(D.top-=c/2),D.left+=I[0],D.top+=I[1],s={marginLeft:d,marginTop:_},t.each(["left","top"],function(e,i){t.ui.position[w[e]]&&t.ui.position[w[e]][i](D,{targetWidth:p,targetHeight:f,elemWidth:l,elemHeight:c,collisionPosition:s,collisionWidth:x,collisionHeight:C,offset:[u[0]+I[0],u[1]+I[1]],my:n.my,at:n.at,within:b,elem:h})}),n.using&&(r=function(t){var e=g.left-D.left,i=e+p-l,s=g.top-D.top,r=s+f-c,u={target:{element:v,left:g.left,top:g.top,width:p,height:f},element:{element:h,left:D.left,top:D.top,width:l,height:c},horizontal:0>i?"left":e>0?"right":"center",vertical:0>r?"top":s>0?"bottom":"middle"};l>p&&p>a(e+i)&&(u.horizontal="center"),c>f&&f>a(s+r)&&(u.vertical="middle"),u.important=o(a(e),a(i))>o(a(s),a(r))?"horizontal":"vertical",n.using.call(this,t,u)}),h.offset(t.extend(D,{using:r}))})},t.ui.position={fit:{left:function(t,e){var i,s=e.within,n=s.isWindow?s.scrollLeft:s.offset.left,a=s.width,r=t.left-e.collisionPosition.marginLeft,h=n-r,l=r+e.collisionWidth-a-n;e.collisionWidth>a?h>0&&0>=l?(i=t.left+h+e.collisionWidth-a-n,t.left+=h-i):t.left=l>0&&0>=h?n:h>l?n+a-e.collisionWidth:n:h>0?t.left+=h:l>0?t.left-=l:t.left=o(t.left-r,t.left)},top:function(t,e){var i,s=e.within,n=s.isWindow?s.scrollTop:s.offset.top,a=e.within.height,r=t.top-e.collisionPosition.marginTop,h=n-r,l=r+e.collisionHeight-a-n;e.collisionHeight>a?h>0&&0>=l?(i=t.top+h+e.collisionHeight-a-n,t.top+=h-i):t.top=l>0&&0>=h?n:h>l?n+a-e.collisionHeight:n:h>0?t.top+=h:l>0?t.top-=l:t.top=o(t.top-r,t.top)}},flip:{left:function(t,e){var i,s,n=e.within,o=n.offset.left+n.scrollLeft,r=n.width,h=n.isWindow?n.scrollLeft:n.offset.left,l=t.left-e.collisionPosition.marginLeft,c=l-h,u=l+e.collisionWidth-r-h,d="left"===e.my[0]?-e.elemWidth:"right"===e.my[0]?e.elemWidth:0,p="left"===e.at[0]?e.targetWidth:"right"===e.at[0]?-e.targetWidth:0,f=-2*e.offset[0];0>c?(i=t.left+d+p+f+e.collisionWidth-r-o,(0>i||a(c)>i)&&(t.left+=d+p+f)):u>0&&(s=t.left-e.collisionPosition.marginLeft+d+p+f-h,(s>0||u>a(s))&&(t.left+=d+p+f))},top:function(t,e){var i,s,n=e.within,o=n.offset.top+n.scrollTop,r=n.height,h=n.isWindow?n.scrollTop:n.offset.top,l=t.top-e.collisionPosition.marginTop,c=l-h,u=l+e.collisionHeight-r-h,d="top"===e.my[1],p=d?-e.elemHeight:"bottom"===e.my[1]?e.elemHeight:0,f="top"===e.at[1]?e.targetHeight:"bottom"===e.at[1]?-e.targetHeight:0,g=-2*e.offset[1];0>c?(s=t.top+p+f+g+e.collisionHeight-r-o,(0>s||a(c)>s)&&(t.top+=p+f+g)):u>0&&(i=t.top-e.collisionPosition.marginTop+p+f+g-h,(i>0||u>a(i))&&(t.top+=p+f+g))}},flipfit:{left:function(){t.ui.position.flip.left.apply(this,arguments),t.ui.position.fit.left.apply(this,arguments)},top:function(){t.ui.position.flip.top.apply(this,arguments),t.ui.position.fit.top.apply(this,arguments)}}}}(),t.ui.position,t.extend(t.expr[":"],{data:t.expr.createPseudo?t.expr.createPseudo(function(e){return function(i){return!!t.data(i,e)}}):function(e,i,s){return!!t.data(e,s[3])}}),t.fn.extend({disableSelection:function(){var t="onselectstart"in document.createElement("div")?"selectstart":"mousedown";return function(){return this.on(t+".ui-disableSelection",function(t){t.preventDefault()})}}(),enableSelection:function(){return this.off(".ui-disableSelection")}});var c="ui-effects-",u="ui-effects-style",d="ui-effects-animated",p=t;t.effects={effect:{}},function(t,e){function i(t,e,i){var s=u[e.type]||{};return null==t?i||!e.def?null:e.def:(t=s.floor?~~t:parseFloat(t),isNaN(t)?e.def:s.mod?(t+s.mod)%s.mod:0>t?0:t>s.max?s.max:t)}function s(i){var s=l(),n=s._rgba=[];return i=i.toLowerCase(),f(h,function(t,o){var a,r=o.re.exec(i),h=r&&o.parse(r),l=o.space||"rgba";return h?(a=s[l](h),s[c[l].cache]=a[c[l].cache],n=s._rgba=a._rgba,!1):e}),n.length?("0,0,0,0"===n.join()&&t.extend(n,o.transparent),s):o[i]}function n(t,e,i){return i=(i+1)%1,1>6*i?t+6*(e-t)*i:1>2*i?e:2>3*i?t+6*(e-t)*(2/3-i):t}var o,a="backgroundColor borderBottomColor borderLeftColor borderRightColor borderTopColor color columnRuleColor outlineColor textDecorationColor textEmphasisColor",r=/^([\-+])=\s*(\d+\.?\d*)/,h=[{re:/rgba?\(\s*(\d{1,3})\s*,\s*(\d{1,3})\s*,\s*(\d{1,3})\s*(?:,\s*(\d?(?:\.\d+)?)\s*)?\)/,parse:function(t){return[t[1],t[2],t[3],t[4]]}},{re:/rgba?\(\s*(\d+(?:\.\d+)?)\%\s*,\s*(\d+(?:\.\d+)?)\%\s*,\s*(\d+(?:\.\d+)?)\%\s*(?:,\s*(\d?(?:\.\d+)?)\s*)?\)/,parse:function(t){return[2.55*t[1],2.55*t[2],2.55*t[3],t[4]]}},{re:/#([a-f0-9]{2})([a-f0-9]{2})([a-f0-9]{2})/,parse:function(t){return[parseInt(t[1],16),parseInt(t[2],16),parseInt(t[3],16)]}},{re:/#([a-f0-9])([a-f0-9])([a-f0-9])/,parse:function(t){return[parseInt(t[1]+t[1],16),parseInt(t[2]+t[2],16),parseInt(t[3]+t[3],16)]}},{re:/hsla?\(\s*(\d+(?:\.\d+)?)\s*,\s*(\d+(?:\.\d+)?)\%\s*,\s*(\d+(?:\.\d+)?)\%\s*(?:,\s*(\d?(?:\.\d+)?)\s*)?\)/,space:"hsla",parse:function(t){return[t[1],t[2]/100,t[3]/100,t[4]]}}],l=t.Color=function(e,i,s,n){return new t.Color.fn.parse(e,i,s,n)},c={rgba:{props:{red:{idx:0,type:"byte"},green:{idx:1,type:"byte"},blue:{idx:2,type:"byte"}}},hsla:{props:{hue:{idx:0,type:"degrees"},saturation:{idx:1,type:"percent"},lightness:{idx:2,type:"percent"}}}},u={"byte":{floor:!0,max:255},percent:{max:1},degrees:{mod:360,floor:!0}},d=l.support={},p=t("<p>")[0],f=t.each;p.style.cssText="background-color:rgba(1,1,1,.5)",d.rgba=p.style.backgroundColor.indexOf("rgba")>-1,f(c,function(t,e){e.cache="_"+t,e.props.alpha={idx:3,type:"percent",def:1}}),l.fn=t.extend(l.prototype,{parse:function(n,a,r,h){if(n===e)return this._rgba=[null,null,null,null],this;(n.jquery||n.nodeType)&&(n=t(n).css(a),a=e);var u=this,d=t.type(n),p=this._rgba=[];return a!==e&&(n=[n,a,r,h],d="array"),"string"===d?this.parse(s(n)||o._default):"array"===d?(f(c.rgba.props,function(t,e){p[e.idx]=i(n[e.idx],e)}),this):"object"===d?(n instanceof l?f(c,function(t,e){n[e.cache]&&(u[e.cache]=n[e.cache].slice())}):f(c,function(e,s){var o=s.cache;f(s.props,function(t,e){if(!u[o]&&s.to){if("alpha"===t||null==n[t])return;u[o]=s.to(u._rgba)}u[o][e.idx]=i(n[t],e,!0)}),u[o]&&0>t.inArray(null,u[o].slice(0,3))&&(u[o][3]=1,s.from&&(u._rgba=s.from(u[o])))}),this):e},is:function(t){var i=l(t),s=!0,n=this;return f(c,function(t,o){var a,r=i[o.cache];return r&&(a=n[o.cache]||o.to&&o.to(n._rgba)||[],f(o.props,function(t,i){return null!=r[i.idx]?s=r[i.idx]===a[i.idx]:e})),s}),s},_space:function(){var t=[],e=this;return f(c,function(i,s){e[s.cache]&&t.push(i)}),t.pop()},transition:function(t,e){var s=l(t),n=s._space(),o=c[n],a=0===this.alpha()?l("transparent"):this,r=a[o.cache]||o.to(a._rgba),h=r.slice();return s=s[o.cache],f(o.props,function(t,n){var o=n.idx,a=r[o],l=s[o],c=u[n.type]||{};null!==l&&(null===a?h[o]=l:(c.mod&&(l-a>c.mod/2?a+=c.mod:a-l>c.mod/2&&(a-=c.mod)),h[o]=i((l-a)*e+a,n)))}),this[n](h)},blend:function(e){if(1===this._rgba[3])return this;var i=this._rgba.slice(),s=i.pop(),n=l(e)._rgba;return l(t.map(i,function(t,e){return(1-s)*n[e]+s*t}))},toRgbaString:function(){var e="rgba(",i=t.map(this._rgba,function(t,e){return null==t?e>2?1:0:t});return 1===i[3]&&(i.pop(),e="rgb("),e+i.join()+")"},toHslaString:function(){var e="hsla(",i=t.map(this.hsla(),function(t,e){return null==t&&(t=e>2?1:0),e&&3>e&&(t=Math.round(100*t)+"%"),t});return 1===i[3]&&(i.pop(),e="hsl("),e+i.join()+")"},toHexString:function(e){var i=this._rgba.slice(),s=i.pop();return e&&i.push(~~(255*s)),"#"+t.map(i,function(t){return t=(t||0).toString(16),1===t.length?"0"+t:t}).join("")},toString:function(){return 0===this._rgba[3]?"transparent":this.toRgbaString()}}),l.fn.parse.prototype=l.fn,c.hsla.to=function(t){if(null==t[0]||null==t[1]||null==t[2])return[null,null,null,t[3]];var e,i,s=t[0]/255,n=t[1]/255,o=t[2]/255,a=t[3],r=Math.max(s,n,o),h=Math.min(s,n,o),l=r-h,c=r+h,u=.5*c;return e=h===r?0:s===r?60*(n-o)/l+360:n===r?60*(o-s)/l+120:60*(s-n)/l+240,i=0===l?0:.5>=u?l/c:l/(2-c),[Math.round(e)%360,i,u,null==a?1:a]},c.hsla.from=function(t){if(null==t[0]||null==t[1]||null==t[2])return[null,null,null,t[3]];var e=t[0]/360,i=t[1],s=t[2],o=t[3],a=.5>=s?s*(1+i):s+i-s*i,r=2*s-a;return[Math.round(255*n(r,a,e+1/3)),Math.round(255*n(r,a,e)),Math.round(255*n(r,a,e-1/3)),o]},f(c,function(s,n){var o=n.props,a=n.cache,h=n.to,c=n.from;l.fn[s]=function(s){if(h&&!this[a]&&(this[a]=h(this._rgba)),s===e)return this[a].slice();var n,r=t.type(s),u="array"===r||"object"===r?s:arguments,d=this[a].slice();return f(o,function(t,e){var s=u["object"===r?t:e.idx];null==s&&(s=d[e.idx]),d[e.idx]=i(s,e)}),c?(n=l(c(d)),n[a]=d,n):l(d)},f(o,function(e,i){l.fn[e]||(l.fn[e]=function(n){var o,a=t.type(n),h="alpha"===e?this._hsla?"hsla":"rgba":s,l=this[h](),c=l[i.idx];return"undefined"===a?c:("function"===a&&(n=n.call(this,c),a=t.type(n)),null==n&&i.empty?this:("string"===a&&(o=r.exec(n),o&&(n=c+parseFloat(o[2])*("+"===o[1]?1:-1))),l[i.idx]=n,this[h](l)))})})}),l.hook=function(e){var i=e.split(" ");f(i,function(e,i){t.cssHooks[i]={set:function(e,n){var o,a,r="";if("transparent"!==n&&("string"!==t.type(n)||(o=s(n)))){if(n=l(o||n),!d.rgba&&1!==n._rgba[3]){for(a="backgroundColor"===i?e.parentNode:e;(""===r||"transparent"===r)&&a&&a.style;)try{r=t.css(a,"backgroundColor"),a=a.parentNode}catch(h){}n=n.blend(r&&"transparent"!==r?r:"_default")}n=n.toRgbaString()}try{e.style[i]=n}catch(h){}}},t.fx.step[i]=function(e){e.colorInit||(e.start=l(e.elem,i),e.end=l(e.end),e.colorInit=!0),t.cssHooks[i].set(e.elem,e.start.transition(e.end,e.pos))}})},l.hook(a),t.cssHooks.borderColor={expand:function(t){var e={};return f(["Top","Right","Bottom","Left"],function(i,s){e["border"+s+"Color"]=t}),e}},o=t.Color.names={aqua:"#00ffff",black:"#000000",blue:"#0000ff",fuchsia:"#ff00ff",gray:"#808080",green:"#008000",lime:"#00ff00",maroon:"#800000",navy:"#000080",olive:"#808000",purple:"#800080",red:"#ff0000",silver:"#c0c0c0",teal:"#008080",white:"#ffffff",yellow:"#ffff00",transparent:[null,null,null,0],_default:"#ffffff"}}(p),function(){function e(e){var i,s,n=e.ownerDocument.defaultView?e.ownerDocument.defaultView.getComputedStyle(e,null):e.currentStyle,o={};if(n&&n.length&&n[0]&&n[n[0]])for(s=n.length;s--;)i=n[s],"string"==typeof n[i]&&(o[t.camelCase(i)]=n[i]);else for(i in n)"string"==typeof n[i]&&(o[i]=n[i]);return o}function i(e,i){var s,o,a={};for(s in i)o=i[s],e[s]!==o&&(n[s]||(t.fx.step[s]||!isNaN(parseFloat(o)))&&(a[s]=o));return a}var s=["add","remove","toggle"],n={border:1,borderBottom:1,borderColor:1,borderLeft:1,borderRight:1,borderTop:1,borderWidth:1,margin:1,padding:1};t.each(["borderLeftStyle","borderRightStyle","borderBottomStyle","borderTopStyle"],function(e,i){t.fx.step[i]=function(t){("none"!==t.end&&!t.setAttr||1===t.pos&&!t.setAttr)&&(p.style(t.elem,i,t.end),t.setAttr=!0)}}),t.fn.addBack||(t.fn.addBack=function(t){return this.add(null==t?this.prevObject:this.prevObject.filter(t))}),t.effects.animateClass=function(n,o,a,r){var h=t.speed(o,a,r);return this.queue(function(){var o,a=t(this),r=a.attr("class")||"",l=h.children?a.find("*").addBack():a;l=l.map(function(){var i=t(this);return{el:i,start:e(this)}}),o=function(){t.each(s,function(t,e){n[e]&&a[e+"Class"](n[e])})},o(),l=l.map(function(){return this.end=e(this.el[0]),this.diff=i(this.start,this.end),this}),a.attr("class",r),l=l.map(function(){var e=this,i=t.Deferred(),s=t.extend({},h,{queue:!1,complete:function(){i.resolve(e)}});return this.el.animate(this.diff,s),i.promise()}),t.when.apply(t,l.get()).done(function(){o(),t.each(arguments,function(){var e=this.el;t.each(this.diff,function(t){e.css(t,"")})}),h.complete.call(a[0])})})},t.fn.extend({addClass:function(e){return function(i,s,n,o){return s?t.effects.animateClass.call(this,{add:i},s,n,o):e.apply(this,arguments)}}(t.fn.addClass),removeClass:function(e){return function(i,s,n,o){return arguments.length>1?t.effects.animateClass.call(this,{remove:i},s,n,o):e.apply(this,arguments)}}(t.fn.removeClass),toggleClass:function(e){return function(i,s,n,o,a){return"boolean"==typeof s||void 0===s?n?t.effects.animateClass.call(this,s?{add:i}:{remove:i},n,o,a):e.apply(this,arguments):t.effects.animateClass.call(this,{toggle:i},s,n,o)}}(t.fn.toggleClass),switchClass:function(e,i,s,n,o){return t.effects.animateClass.call(this,{add:i,remove:e},s,n,o)}})}(),function(){function e(e,i,s,n){return t.isPlainObject(e)&&(i=e,e=e.effect),e={effect:e},null==i&&(i={}),t.isFunction(i)&&(n=i,s=null,i={}),("number"==typeof i||t.fx.speeds[i])&&(n=s,s=i,i={}),t.isFunction(s)&&(n=s,s=null),i&&t.extend(e,i),s=s||i.duration,e.duration=t.fx.off?0:"number"==typeof s?s:s in t.fx.speeds?t.fx.speeds[s]:t.fx.speeds._default,e.complete=n||i.complete,e}function i(e){return!e||"number"==typeof e||t.fx.speeds[e]?!0:"string"!=typeof e||t.effects.effect[e]?t.isFunction(e)?!0:"object"!=typeof e||e.effect?!1:!0:!0}function s(t,e){var i=e.outerWidth(),s=e.outerHeight(),n=/^rect\((-?\d*\.?\d*px|-?\d+%|auto),?\s*(-?\d*\.?\d*px|-?\d+%|auto),?\s*(-?\d*\.?\d*px|-?\d+%|auto),?\s*(-?\d*\.?\d*px|-?\d+%|auto)\)$/,o=n.exec(t)||["",0,i,s,0];return{top:parseFloat(o[1])||0,right:"auto"===o[2]?i:parseFloat(o[2]),bottom:"auto"===o[3]?s:parseFloat(o[3]),left:parseFloat(o[4])||0}}t.expr&&t.expr.filters&&t.expr.filters.animated&&(t.expr.filters.animated=function(e){return function(i){return!!t(i).data(d)||e(i)}}(t.expr.filters.animated)),t.uiBackCompat!==!1&&t.extend(t.effects,{save:function(t,e){for(var i=0,s=e.length;s>i;i++)null!==e[i]&&t.data(c+e[i],t[0].style[e[i]])},restore:function(t,e){for(var i,s=0,n=e.length;n>s;s++)null!==e[s]&&(i=t.data(c+e[s]),t.css(e[s],i))},setMode:function(t,e){return"toggle"===e&&(e=t.is(":hidden")?"show":"hide"),e},createWrapper:function(e){if(e.parent().is(".ui-effects-wrapper"))return e.parent();var i={width:e.outerWidth(!0),height:e.outerHeight(!0),"float":e.css("float")},s=t("<div></div>").addClass("ui-effects-wrapper").css({fontSize:"100%",background:"transparent",border:"none",margin:0,padding:0}),n={width:e.width(),height:e.height()},o=document.activeElement;try{o.id}catch(a){o=document.body}return e.wrap(s),(e[0]===o||t.contains(e[0],o))&&t(o).trigger("focus"),s=e.parent(),"static"===e.css("position")?(s.css({position:"relative"}),e.css({position:"relative"})):(t.extend(i,{position:e.css("position"),zIndex:e.css("z-index")}),t.each(["top","left","bottom","right"],function(t,s){i[s]=e.css(s),isNaN(parseInt(i[s],10))&&(i[s]="auto")}),e.css({position:"relative",top:0,left:0,right:"auto",bottom:"auto"})),e.css(n),s.css(i).show()},removeWrapper:function(e){var i=document.activeElement;return e.parent().is(".ui-effects-wrapper")&&(e.parent().replaceWith(e),(e[0]===i||t.contains(e[0],i))&&t(i).trigger("focus")),e}}),t.extend(t.effects,{version:"1.12.1",define:function(e,i,s){return s||(s=i,i="effect"),t.effects.effect[e]=s,t.effects.effect[e].mode=i,s},scaledDimensions:function(t,e,i){if(0===e)return{height:0,width:0,outerHeight:0,outerWidth:0};var s="horizontal"!==i?(e||100)/100:1,n="vertical"!==i?(e||100)/100:1;return{height:t.height()*n,width:t.width()*s,outerHeight:t.outerHeight()*n,outerWidth:t.outerWidth()*s}},clipToBox:function(t){return{width:t.clip.right-t.clip.left,height:t.clip.bottom-t.clip.top,left:t.clip.left,top:t.clip.top}},unshift:function(t,e,i){var s=t.queue();e>1&&s.splice.apply(s,[1,0].concat(s.splice(e,i))),t.dequeue()},saveStyle:function(t){t.data(u,t[0].style.cssText)},restoreStyle:function(t){t[0].style.cssText=t.data(u)||"",t.removeData(u)},mode:function(t,e){var i=t.is(":hidden");return"toggle"===e&&(e=i?"show":"hide"),(i?"hide"===e:"show"===e)&&(e="none"),e},getBaseline:function(t,e){var i,s;switch(t[0]){case"top":i=0;break;case"middle":i=.5;break;case"bottom":i=1;break;default:i=t[0]/e.height}switch(t[1]){case"left":s=0;break;case"center":s=.5;break;case"right":s=1;break;default:s=t[1]/e.width}return{x:s,y:i}},createPlaceholder:function(e){var i,s=e.css("position"),n=e.position();return e.css({marginTop:e.css("marginTop"),marginBottom:e.css("marginBottom"),marginLeft:e.css("marginLeft"),marginRight:e.css("marginRight")}).outerWidth(e.outerWidth()).outerHeight(e.outerHeight()),/^(static|relative)/.test(s)&&(s="absolute",i=t("<"+e[0].nodeName+">").insertAfter(e).css({display:/^(inline|ruby)/.test(e.css("display"))?"inline-block":"block",visibility:"hidden",marginTop:e.css("marginTop"),marginBottom:e.css("marginBottom"),marginLeft:e.css("marginLeft"),marginRight:e.css("marginRight"),"float":e.css("float")}).outerWidth(e.outerWidth()).outerHeight(e.outerHeight()).addClass("ui-effects-placeholder"),e.data(c+"placeholder",i)),e.css({position:s,left:n.left,top:n.top}),i},removePlaceholder:function(t){var e=c+"placeholder",i=t.data(e);i&&(i.remove(),t.removeData(e))},cleanUp:function(e){t.effects.restoreStyle(e),t.effects.removePlaceholder(e)},setTransition:function(e,i,s,n){return n=n||{},t.each(i,function(t,i){var o=e.cssUnit(i);o[0]>0&&(n[i]=o[0]*s+o[1])}),n}}),t.fn.extend({effect:function(){function i(e){function i(){r.removeData(d),t.effects.cleanUp(r),"hide"===s.mode&&r.hide(),a()}function a(){t.isFunction(h)&&h.call(r[0]),t.isFunction(e)&&e()}var r=t(this);s.mode=c.shift(),t.uiBackCompat===!1||o?"none"===s.mode?(r[l](),a()):n.call(r[0],s,i):(r.is(":hidden")?"hide"===l:"show"===l)?(r[l](),a()):n.call(r[0],s,a)}var s=e.apply(this,arguments),n=t.effects.effect[s.effect],o=n.mode,a=s.queue,r=a||"fx",h=s.complete,l=s.mode,c=[],u=function(e){var i=t(this),s=t.effects.mode(i,l)||o;i.data(d,!0),c.push(s),o&&("show"===s||s===o&&"hide"===s)&&i.show(),o&&"none"===s||t.effects.saveStyle(i),t.isFunction(e)&&e()};return t.fx.off||!n?l?this[l](s.duration,h):this.each(function(){h&&h.call(this)}):a===!1?this.each(u).each(i):this.queue(r,u).queue(r,i)},show:function(t){return function(s){if(i(s))return t.apply(this,arguments);var n=e.apply(this,arguments);return n.mode="show",this.effect.call(this,n)
7
- }}(t.fn.show),hide:function(t){return function(s){if(i(s))return t.apply(this,arguments);var n=e.apply(this,arguments);return n.mode="hide",this.effect.call(this,n)}}(t.fn.hide),toggle:function(t){return function(s){if(i(s)||"boolean"==typeof s)return t.apply(this,arguments);var n=e.apply(this,arguments);return n.mode="toggle",this.effect.call(this,n)}}(t.fn.toggle),cssUnit:function(e){var i=this.css(e),s=[];return t.each(["em","px","%","pt"],function(t,e){i.indexOf(e)>0&&(s=[parseFloat(i),e])}),s},cssClip:function(t){return t?this.css("clip","rect("+t.top+"px "+t.right+"px "+t.bottom+"px "+t.left+"px)"):s(this.css("clip"),this)},transfer:function(e,i){var s=t(this),n=t(e.to),o="fixed"===n.css("position"),a=t("body"),r=o?a.scrollTop():0,h=o?a.scrollLeft():0,l=n.offset(),c={top:l.top-r,left:l.left-h,height:n.innerHeight(),width:n.innerWidth()},u=s.offset(),d=t("<div class='ui-effects-transfer'></div>").appendTo("body").addClass(e.className).css({top:u.top-r,left:u.left-h,height:s.innerHeight(),width:s.innerWidth(),position:o?"fixed":"absolute"}).animate(c,e.duration,e.easing,function(){d.remove(),t.isFunction(i)&&i()})}}),t.fx.step.clip=function(e){e.clipInit||(e.start=t(e.elem).cssClip(),"string"==typeof e.end&&(e.end=s(e.end,e.elem)),e.clipInit=!0),t(e.elem).cssClip({top:e.pos*(e.end.top-e.start.top)+e.start.top,right:e.pos*(e.end.right-e.start.right)+e.start.right,bottom:e.pos*(e.end.bottom-e.start.bottom)+e.start.bottom,left:e.pos*(e.end.left-e.start.left)+e.start.left})}}(),function(){var e={};t.each(["Quad","Cubic","Quart","Quint","Expo"],function(t,i){e[i]=function(e){return Math.pow(e,t+2)}}),t.extend(e,{Sine:function(t){return 1-Math.cos(t*Math.PI/2)},Circ:function(t){return 1-Math.sqrt(1-t*t)},Elastic:function(t){return 0===t||1===t?t:-Math.pow(2,8*(t-1))*Math.sin((80*(t-1)-7.5)*Math.PI/15)},Back:function(t){return t*t*(3*t-2)},Bounce:function(t){for(var e,i=4;((e=Math.pow(2,--i))-1)/11>t;);return 1/Math.pow(4,3-i)-7.5625*Math.pow((3*e-2)/22-t,2)}}),t.each(e,function(e,i){t.easing["easeIn"+e]=i,t.easing["easeOut"+e]=function(t){return 1-i(1-t)},t.easing["easeInOut"+e]=function(t){return.5>t?i(2*t)/2:1-i(-2*t+2)/2}})}();var f=t.effects;t.effects.define("blind","hide",function(e,i){var s={up:["bottom","top"],vertical:["bottom","top"],down:["top","bottom"],left:["right","left"],horizontal:["right","left"],right:["left","right"]},n=t(this),o=e.direction||"up",a=n.cssClip(),r={clip:t.extend({},a)},h=t.effects.createPlaceholder(n);r.clip[s[o][0]]=r.clip[s[o][1]],"show"===e.mode&&(n.cssClip(r.clip),h&&h.css(t.effects.clipToBox(r)),r.clip=a),h&&h.animate(t.effects.clipToBox(r),e.duration,e.easing),n.animate(r,{queue:!1,duration:e.duration,easing:e.easing,complete:i})}),t.effects.define("bounce",function(e,i){var s,n,o,a=t(this),r=e.mode,h="hide"===r,l="show"===r,c=e.direction||"up",u=e.distance,d=e.times||5,p=2*d+(l||h?1:0),f=e.duration/p,g=e.easing,m="up"===c||"down"===c?"top":"left",_="up"===c||"left"===c,v=0,b=a.queue().length;for(t.effects.createPlaceholder(a),o=a.css(m),u||(u=a["top"===m?"outerHeight":"outerWidth"]()/3),l&&(n={opacity:1},n[m]=o,a.css("opacity",0).css(m,_?2*-u:2*u).animate(n,f,g)),h&&(u/=Math.pow(2,d-1)),n={},n[m]=o;d>v;v++)s={},s[m]=(_?"-=":"+=")+u,a.animate(s,f,g).animate(n,f,g),u=h?2*u:u/2;h&&(s={opacity:0},s[m]=(_?"-=":"+=")+u,a.animate(s,f,g)),a.queue(i),t.effects.unshift(a,b,p+1)}),t.effects.define("clip","hide",function(e,i){var s,n={},o=t(this),a=e.direction||"vertical",r="both"===a,h=r||"horizontal"===a,l=r||"vertical"===a;s=o.cssClip(),n.clip={top:l?(s.bottom-s.top)/2:s.top,right:h?(s.right-s.left)/2:s.right,bottom:l?(s.bottom-s.top)/2:s.bottom,left:h?(s.right-s.left)/2:s.left},t.effects.createPlaceholder(o),"show"===e.mode&&(o.cssClip(n.clip),n.clip=s),o.animate(n,{queue:!1,duration:e.duration,easing:e.easing,complete:i})}),t.effects.define("drop","hide",function(e,i){var s,n=t(this),o=e.mode,a="show"===o,r=e.direction||"left",h="up"===r||"down"===r?"top":"left",l="up"===r||"left"===r?"-=":"+=",c="+="===l?"-=":"+=",u={opacity:0};t.effects.createPlaceholder(n),s=e.distance||n["top"===h?"outerHeight":"outerWidth"](!0)/2,u[h]=l+s,a&&(n.css(u),u[h]=c+s,u.opacity=1),n.animate(u,{queue:!1,duration:e.duration,easing:e.easing,complete:i})}),t.effects.define("explode","hide",function(e,i){function s(){b.push(this),b.length===u*d&&n()}function n(){p.css({visibility:"visible"}),t(b).remove(),i()}var o,a,r,h,l,c,u=e.pieces?Math.round(Math.sqrt(e.pieces)):3,d=u,p=t(this),f=e.mode,g="show"===f,m=p.show().css("visibility","hidden").offset(),_=Math.ceil(p.outerWidth()/d),v=Math.ceil(p.outerHeight()/u),b=[];for(o=0;u>o;o++)for(h=m.top+o*v,c=o-(u-1)/2,a=0;d>a;a++)r=m.left+a*_,l=a-(d-1)/2,p.clone().appendTo("body").wrap("<div></div>").css({position:"absolute",visibility:"visible",left:-a*_,top:-o*v}).parent().addClass("ui-effects-explode").css({position:"absolute",overflow:"hidden",width:_,height:v,left:r+(g?l*_:0),top:h+(g?c*v:0),opacity:g?0:1}).animate({left:r+(g?0:l*_),top:h+(g?0:c*v),opacity:g?1:0},e.duration||500,e.easing,s)}),t.effects.define("fade","toggle",function(e,i){var s="show"===e.mode;t(this).css("opacity",s?0:1).animate({opacity:s?1:0},{queue:!1,duration:e.duration,easing:e.easing,complete:i})}),t.effects.define("fold","hide",function(e,i){var s=t(this),n=e.mode,o="show"===n,a="hide"===n,r=e.size||15,h=/([0-9]+)%/.exec(r),l=!!e.horizFirst,c=l?["right","bottom"]:["bottom","right"],u=e.duration/2,d=t.effects.createPlaceholder(s),p=s.cssClip(),f={clip:t.extend({},p)},g={clip:t.extend({},p)},m=[p[c[0]],p[c[1]]],_=s.queue().length;h&&(r=parseInt(h[1],10)/100*m[a?0:1]),f.clip[c[0]]=r,g.clip[c[0]]=r,g.clip[c[1]]=0,o&&(s.cssClip(g.clip),d&&d.css(t.effects.clipToBox(g)),g.clip=p),s.queue(function(i){d&&d.animate(t.effects.clipToBox(f),u,e.easing).animate(t.effects.clipToBox(g),u,e.easing),i()}).animate(f,u,e.easing).animate(g,u,e.easing).queue(i),t.effects.unshift(s,_,4)}),t.effects.define("highlight","show",function(e,i){var s=t(this),n={backgroundColor:s.css("backgroundColor")};"hide"===e.mode&&(n.opacity=0),t.effects.saveStyle(s),s.css({backgroundImage:"none",backgroundColor:e.color||"#ffff99"}).animate(n,{queue:!1,duration:e.duration,easing:e.easing,complete:i})}),t.effects.define("size",function(e,i){var s,n,o,a=t(this),r=["fontSize"],h=["borderTopWidth","borderBottomWidth","paddingTop","paddingBottom"],l=["borderLeftWidth","borderRightWidth","paddingLeft","paddingRight"],c=e.mode,u="effect"!==c,d=e.scale||"both",p=e.origin||["middle","center"],f=a.css("position"),g=a.position(),m=t.effects.scaledDimensions(a),_=e.from||m,v=e.to||t.effects.scaledDimensions(a,0);t.effects.createPlaceholder(a),"show"===c&&(o=_,_=v,v=o),n={from:{y:_.height/m.height,x:_.width/m.width},to:{y:v.height/m.height,x:v.width/m.width}},("box"===d||"both"===d)&&(n.from.y!==n.to.y&&(_=t.effects.setTransition(a,h,n.from.y,_),v=t.effects.setTransition(a,h,n.to.y,v)),n.from.x!==n.to.x&&(_=t.effects.setTransition(a,l,n.from.x,_),v=t.effects.setTransition(a,l,n.to.x,v))),("content"===d||"both"===d)&&n.from.y!==n.to.y&&(_=t.effects.setTransition(a,r,n.from.y,_),v=t.effects.setTransition(a,r,n.to.y,v)),p&&(s=t.effects.getBaseline(p,m),_.top=(m.outerHeight-_.outerHeight)*s.y+g.top,_.left=(m.outerWidth-_.outerWidth)*s.x+g.left,v.top=(m.outerHeight-v.outerHeight)*s.y+g.top,v.left=(m.outerWidth-v.outerWidth)*s.x+g.left),a.css(_),("content"===d||"both"===d)&&(h=h.concat(["marginTop","marginBottom"]).concat(r),l=l.concat(["marginLeft","marginRight"]),a.find("*[width]").each(function(){var i=t(this),s=t.effects.scaledDimensions(i),o={height:s.height*n.from.y,width:s.width*n.from.x,outerHeight:s.outerHeight*n.from.y,outerWidth:s.outerWidth*n.from.x},a={height:s.height*n.to.y,width:s.width*n.to.x,outerHeight:s.height*n.to.y,outerWidth:s.width*n.to.x};n.from.y!==n.to.y&&(o=t.effects.setTransition(i,h,n.from.y,o),a=t.effects.setTransition(i,h,n.to.y,a)),n.from.x!==n.to.x&&(o=t.effects.setTransition(i,l,n.from.x,o),a=t.effects.setTransition(i,l,n.to.x,a)),u&&t.effects.saveStyle(i),i.css(o),i.animate(a,e.duration,e.easing,function(){u&&t.effects.restoreStyle(i)})})),a.animate(v,{queue:!1,duration:e.duration,easing:e.easing,complete:function(){var e=a.offset();0===v.opacity&&a.css("opacity",_.opacity),u||(a.css("position","static"===f?"relative":f).offset(e),t.effects.saveStyle(a)),i()}})}),t.effects.define("scale",function(e,i){var s=t(this),n=e.mode,o=parseInt(e.percent,10)||(0===parseInt(e.percent,10)?0:"effect"!==n?0:100),a=t.extend(!0,{from:t.effects.scaledDimensions(s),to:t.effects.scaledDimensions(s,o,e.direction||"both"),origin:e.origin||["middle","center"]},e);e.fade&&(a.from.opacity=1,a.to.opacity=0),t.effects.effect.size.call(this,a,i)}),t.effects.define("puff","hide",function(e,i){var s=t.extend(!0,{},e,{fade:!0,percent:parseInt(e.percent,10)||150});t.effects.effect.scale.call(this,s,i)}),t.effects.define("pulsate","show",function(e,i){var s=t(this),n=e.mode,o="show"===n,a="hide"===n,r=o||a,h=2*(e.times||5)+(r?1:0),l=e.duration/h,c=0,u=1,d=s.queue().length;for((o||!s.is(":visible"))&&(s.css("opacity",0).show(),c=1);h>u;u++)s.animate({opacity:c},l,e.easing),c=1-c;s.animate({opacity:c},l,e.easing),s.queue(i),t.effects.unshift(s,d,h+1)}),t.effects.define("shake",function(e,i){var s=1,n=t(this),o=e.direction||"left",a=e.distance||20,r=e.times||3,h=2*r+1,l=Math.round(e.duration/h),c="up"===o||"down"===o?"top":"left",u="up"===o||"left"===o,d={},p={},f={},g=n.queue().length;for(t.effects.createPlaceholder(n),d[c]=(u?"-=":"+=")+a,p[c]=(u?"+=":"-=")+2*a,f[c]=(u?"-=":"+=")+2*a,n.animate(d,l,e.easing);r>s;s++)n.animate(p,l,e.easing).animate(f,l,e.easing);n.animate(p,l,e.easing).animate(d,l/2,e.easing).queue(i),t.effects.unshift(n,g,h+1)}),t.effects.define("slide","show",function(e,i){var s,n,o=t(this),a={up:["bottom","top"],down:["top","bottom"],left:["right","left"],right:["left","right"]},r=e.mode,h=e.direction||"left",l="up"===h||"down"===h?"top":"left",c="up"===h||"left"===h,u=e.distance||o["top"===l?"outerHeight":"outerWidth"](!0),d={};t.effects.createPlaceholder(o),s=o.cssClip(),n=o.position()[l],d[l]=(c?-1:1)*u+n,d.clip=o.cssClip(),d.clip[a[h][1]]=d.clip[a[h][0]],"show"===r&&(o.cssClip(d.clip),o.css(l,d[l]),d.clip=s,d[l]=n),o.animate(d,{queue:!1,duration:e.duration,easing:e.easing,complete:i})});var f;t.uiBackCompat!==!1&&(f=t.effects.define("transfer",function(e,i){t(this).transfer(e,i)})),t.ui.focusable=function(i,s){var n,o,a,r,h,l=i.nodeName.toLowerCase();return"area"===l?(n=i.parentNode,o=n.name,i.href&&o&&"map"===n.nodeName.toLowerCase()?(a=t("img[usemap='#"+o+"']"),a.length>0&&a.is(":visible")):!1):(/^(input|select|textarea|button|object)$/.test(l)?(r=!i.disabled,r&&(h=t(i).closest("fieldset")[0],h&&(r=!h.disabled))):r="a"===l?i.href||s:s,r&&t(i).is(":visible")&&e(t(i)))},t.extend(t.expr[":"],{focusable:function(e){return t.ui.focusable(e,null!=t.attr(e,"tabindex"))}}),t.ui.focusable,t.fn.form=function(){return"string"==typeof this[0].form?this.closest("form"):t(this[0].form)},t.ui.formResetMixin={_formResetHandler:function(){var e=t(this);setTimeout(function(){var i=e.data("ui-form-reset-instances");t.each(i,function(){this.refresh()})})},_bindFormResetHandler:function(){if(this.form=this.element.form(),this.form.length){var t=this.form.data("ui-form-reset-instances")||[];t.length||this.form.on("reset.ui-form-reset",this._formResetHandler),t.push(this),this.form.data("ui-form-reset-instances",t)}},_unbindFormResetHandler:function(){if(this.form.length){var e=this.form.data("ui-form-reset-instances");e.splice(t.inArray(this,e),1),e.length?this.form.data("ui-form-reset-instances",e):this.form.removeData("ui-form-reset-instances").off("reset.ui-form-reset")}}},"1.7"===t.fn.jquery.substring(0,3)&&(t.each(["Width","Height"],function(e,i){function s(e,i,s,o){return t.each(n,function(){i-=parseFloat(t.css(e,"padding"+this))||0,s&&(i-=parseFloat(t.css(e,"border"+this+"Width"))||0),o&&(i-=parseFloat(t.css(e,"margin"+this))||0)}),i}var n="Width"===i?["Left","Right"]:["Top","Bottom"],o=i.toLowerCase(),a={innerWidth:t.fn.innerWidth,innerHeight:t.fn.innerHeight,outerWidth:t.fn.outerWidth,outerHeight:t.fn.outerHeight};t.fn["inner"+i]=function(e){return void 0===e?a["inner"+i].call(this):this.each(function(){t(this).css(o,s(this,e)+"px")})},t.fn["outer"+i]=function(e,n){return"number"!=typeof e?a["outer"+i].call(this,e):this.each(function(){t(this).css(o,s(this,e,!0,n)+"px")})}}),t.fn.addBack=function(t){return this.add(null==t?this.prevObject:this.prevObject.filter(t))}),t.ui.keyCode={BACKSPACE:8,COMMA:188,DELETE:46,DOWN:40,END:35,ENTER:13,ESCAPE:27,HOME:36,LEFT:37,PAGE_DOWN:34,PAGE_UP:33,PERIOD:190,RIGHT:39,SPACE:32,TAB:9,UP:38},t.ui.escapeSelector=function(){var t=/([!"#$%&'()*+,.\/:;<=>?@[\]^`{|}~])/g;return function(e){return e.replace(t,"\\$1")}}(),t.fn.labels=function(){var e,i,s,n,o;return this[0].labels&&this[0].labels.length?this.pushStack(this[0].labels):(n=this.eq(0).parents("label"),s=this.attr("id"),s&&(e=this.eq(0).parents().last(),o=e.add(e.length?e.siblings():this.siblings()),i="label[for='"+t.ui.escapeSelector(s)+"']",n=n.add(o.find(i).addBack(i))),this.pushStack(n))},t.fn.scrollParent=function(e){var i=this.css("position"),s="absolute"===i,n=e?/(auto|scroll|hidden)/:/(auto|scroll)/,o=this.parents().filter(function(){var e=t(this);return s&&"static"===e.css("position")?!1:n.test(e.css("overflow")+e.css("overflow-y")+e.css("overflow-x"))}).eq(0);return"fixed"!==i&&o.length?o:t(this[0].ownerDocument||document)},t.extend(t.expr[":"],{tabbable:function(e){var i=t.attr(e,"tabindex"),s=null!=i;return(!s||i>=0)&&t.ui.focusable(e,s)}}),t.fn.extend({uniqueId:function(){var t=0;return function(){return this.each(function(){this.id||(this.id="ui-id-"+ ++t)})}}(),removeUniqueId:function(){return this.each(function(){/^ui-id-\d+$/.test(this.id)&&t(this).removeAttr("id")})}}),t.widget("ui.accordion",{version:"1.12.1",options:{active:0,animate:{},classes:{"ui-accordion-header":"ui-corner-top","ui-accordion-header-collapsed":"ui-corner-all","ui-accordion-content":"ui-corner-bottom"},collapsible:!1,event:"click",header:"> li > :first-child, > :not(li):even",heightStyle:"auto",icons:{activeHeader:"ui-icon-triangle-1-s",header:"ui-icon-triangle-1-e"},activate:null,beforeActivate:null},hideProps:{borderTopWidth:"hide",borderBottomWidth:"hide",paddingTop:"hide",paddingBottom:"hide",height:"hide"},showProps:{borderTopWidth:"show",borderBottomWidth:"show",paddingTop:"show",paddingBottom:"show",height:"show"},_create:function(){var e=this.options;this.prevShow=this.prevHide=t(),this._addClass("ui-accordion","ui-widget ui-helper-reset"),this.element.attr("role","tablist"),e.collapsible||e.active!==!1&&null!=e.active||(e.active=0),this._processPanels(),0>e.active&&(e.active+=this.headers.length),this._refresh()},_getCreateEventData:function(){return{header:this.active,panel:this.active.length?this.active.next():t()}},_createIcons:function(){var e,i,s=this.options.icons;s&&(e=t("<span>"),this._addClass(e,"ui-accordion-header-icon","ui-icon "+s.header),e.prependTo(this.headers),i=this.active.children(".ui-accordion-header-icon"),this._removeClass(i,s.header)._addClass(i,null,s.activeHeader)._addClass(this.headers,"ui-accordion-icons"))},_destroyIcons:function(){this._removeClass(this.headers,"ui-accordion-icons"),this.headers.children(".ui-accordion-header-icon").remove()},_destroy:function(){var t;this.element.removeAttr("role"),this.headers.removeAttr("role aria-expanded aria-selected aria-controls tabIndex").removeUniqueId(),this._destroyIcons(),t=this.headers.next().css("display","").removeAttr("role aria-hidden aria-labelledby").removeUniqueId(),"content"!==this.options.heightStyle&&t.css("height","")},_setOption:function(t,e){return"active"===t?(this._activate(e),void 0):("event"===t&&(this.options.event&&this._off(this.headers,this.options.event),this._setupEvents(e)),this._super(t,e),"collapsible"!==t||e||this.options.active!==!1||this._activate(0),"icons"===t&&(this._destroyIcons(),e&&this._createIcons()),void 0)},_setOptionDisabled:function(t){this._super(t),this.element.attr("aria-disabled",t),this._toggleClass(null,"ui-state-disabled",!!t),this._toggleClass(this.headers.add(this.headers.next()),null,"ui-state-disabled",!!t)},_keydown:function(e){if(!e.altKey&&!e.ctrlKey){var i=t.ui.keyCode,s=this.headers.length,n=this.headers.index(e.target),o=!1;switch(e.keyCode){case i.RIGHT:case i.DOWN:o=this.headers[(n+1)%s];break;case i.LEFT:case i.UP:o=this.headers[(n-1+s)%s];break;case i.SPACE:case i.ENTER:this._eventHandler(e);break;case i.HOME:o=this.headers[0];break;case i.END:o=this.headers[s-1]}o&&(t(e.target).attr("tabIndex",-1),t(o).attr("tabIndex",0),t(o).trigger("focus"),e.preventDefault())}},_panelKeyDown:function(e){e.keyCode===t.ui.keyCode.UP&&e.ctrlKey&&t(e.currentTarget).prev().trigger("focus")},refresh:function(){var e=this.options;this._processPanels(),e.active===!1&&e.collapsible===!0||!this.headers.length?(e.active=!1,this.active=t()):e.active===!1?this._activate(0):this.active.length&&!t.contains(this.element[0],this.active[0])?this.headers.length===this.headers.find(".ui-state-disabled").length?(e.active=!1,this.active=t()):this._activate(Math.max(0,e.active-1)):e.active=this.headers.index(this.active),this._destroyIcons(),this._refresh()},_processPanels:function(){var t=this.headers,e=this.panels;this.headers=this.element.find(this.options.header),this._addClass(this.headers,"ui-accordion-header ui-accordion-header-collapsed","ui-state-default"),this.panels=this.headers.next().filter(":not(.ui-accordion-content-active)").hide(),this._addClass(this.panels,"ui-accordion-content","ui-helper-reset ui-widget-content"),e&&(this._off(t.not(this.headers)),this._off(e.not(this.panels)))},_refresh:function(){var e,i=this.options,s=i.heightStyle,n=this.element.parent();this.active=this._findActive(i.active),this._addClass(this.active,"ui-accordion-header-active","ui-state-active")._removeClass(this.active,"ui-accordion-header-collapsed"),this._addClass(this.active.next(),"ui-accordion-content-active"),this.active.next().show(),this.headers.attr("role","tab").each(function(){var e=t(this),i=e.uniqueId().attr("id"),s=e.next(),n=s.uniqueId().attr("id");e.attr("aria-controls",n),s.attr("aria-labelledby",i)}).next().attr("role","tabpanel"),this.headers.not(this.active).attr({"aria-selected":"false","aria-expanded":"false",tabIndex:-1}).next().attr({"aria-hidden":"true"}).hide(),this.active.length?this.active.attr({"aria-selected":"true","aria-expanded":"true",tabIndex:0}).next().attr({"aria-hidden":"false"}):this.headers.eq(0).attr("tabIndex",0),this._createIcons(),this._setupEvents(i.event),"fill"===s?(e=n.height(),this.element.siblings(":visible").each(function(){var i=t(this),s=i.css("position");"absolute"!==s&&"fixed"!==s&&(e-=i.outerHeight(!0))}),this.headers.each(function(){e-=t(this).outerHeight(!0)}),this.headers.next().each(function(){t(this).height(Math.max(0,e-t(this).innerHeight()+t(this).height()))}).css("overflow","auto")):"auto"===s&&(e=0,this.headers.next().each(function(){var i=t(this).is(":visible");i||t(this).show(),e=Math.max(e,t(this).css("height","").height()),i||t(this).hide()}).height(e))},_activate:function(e){var i=this._findActive(e)[0];i!==this.active[0]&&(i=i||this.active[0],this._eventHandler({target:i,currentTarget:i,preventDefault:t.noop}))},_findActive:function(e){return"number"==typeof e?this.headers.eq(e):t()},_setupEvents:function(e){var i={keydown:"_keydown"};e&&t.each(e.split(" "),function(t,e){i[e]="_eventHandler"}),this._off(this.headers.add(this.headers.next())),this._on(this.headers,i),this._on(this.headers.next(),{keydown:"_panelKeyDown"}),this._hoverable(this.headers),this._focusable(this.headers)},_eventHandler:function(e){var i,s,n=this.options,o=this.active,a=t(e.currentTarget),r=a[0]===o[0],h=r&&n.collapsible,l=h?t():a.next(),c=o.next(),u={oldHeader:o,oldPanel:c,newHeader:h?t():a,newPanel:l};e.preventDefault(),r&&!n.collapsible||this._trigger("beforeActivate",e,u)===!1||(n.active=h?!1:this.headers.index(a),this.active=r?t():a,this._toggle(u),this._removeClass(o,"ui-accordion-header-active","ui-state-active"),n.icons&&(i=o.children(".ui-accordion-header-icon"),this._removeClass(i,null,n.icons.activeHeader)._addClass(i,null,n.icons.header)),r||(this._removeClass(a,"ui-accordion-header-collapsed")._addClass(a,"ui-accordion-header-active","ui-state-active"),n.icons&&(s=a.children(".ui-accordion-header-icon"),this._removeClass(s,null,n.icons.header)._addClass(s,null,n.icons.activeHeader)),this._addClass(a.next(),"ui-accordion-content-active")))},_toggle:function(e){var i=e.newPanel,s=this.prevShow.length?this.prevShow:e.oldPanel;this.prevShow.add(this.prevHide).stop(!0,!0),this.prevShow=i,this.prevHide=s,this.options.animate?this._animate(i,s,e):(s.hide(),i.show(),this._toggleComplete(e)),s.attr({"aria-hidden":"true"}),s.prev().attr({"aria-selected":"false","aria-expanded":"false"}),i.length&&s.length?s.prev().attr({tabIndex:-1,"aria-expanded":"false"}):i.length&&this.headers.filter(function(){return 0===parseInt(t(this).attr("tabIndex"),10)}).attr("tabIndex",-1),i.attr("aria-hidden","false").prev().attr({"aria-selected":"true","aria-expanded":"true",tabIndex:0})},_animate:function(t,e,i){var s,n,o,a=this,r=0,h=t.css("box-sizing"),l=t.length&&(!e.length||t.index()<e.index()),c=this.options.animate||{},u=l&&c.down||c,d=function(){a._toggleComplete(i)};return"number"==typeof u&&(o=u),"string"==typeof u&&(n=u),n=n||u.easing||c.easing,o=o||u.duration||c.duration,e.length?t.length?(s=t.show().outerHeight(),e.animate(this.hideProps,{duration:o,easing:n,step:function(t,e){e.now=Math.round(t)}}),t.hide().animate(this.showProps,{duration:o,easing:n,complete:d,step:function(t,i){i.now=Math.round(t),"height"!==i.prop?"content-box"===h&&(r+=i.now):"content"!==a.options.heightStyle&&(i.now=Math.round(s-e.outerHeight()-r),r=0)}}),void 0):e.animate(this.hideProps,o,n,d):t.animate(this.showProps,o,n,d)},_toggleComplete:function(t){var e=t.oldPanel,i=e.prev();this._removeClass(e,"ui-accordion-content-active"),this._removeClass(i,"ui-accordion-header-active")._addClass(i,"ui-accordion-header-collapsed"),e.length&&(e.parent()[0].className=e.parent()[0].className),this._trigger("activate",null,t)}}),t.ui.safeActiveElement=function(t){var e;try{e=t.activeElement}catch(i){e=t.body}return e||(e=t.body),e.nodeName||(e=t.body),e},t.widget("ui.menu",{version:"1.12.1",defaultElement:"<ul>",delay:300,options:{icons:{submenu:"ui-icon-caret-1-e"},items:"> *",menus:"ul",position:{my:"left top",at:"right top"},role:"menu",blur:null,focus:null,select:null},_create:function(){this.activeMenu=this.element,this.mouseHandled=!1,this.element.uniqueId().attr({role:this.options.role,tabIndex:0}),this._addClass("ui-menu","ui-widget ui-widget-content"),this._on({"mousedown .ui-menu-item":function(t){t.preventDefault()},"click .ui-menu-item":function(e){var i=t(e.target),s=t(t.ui.safeActiveElement(this.document[0]));!this.mouseHandled&&i.not(".ui-state-disabled").length&&(this.select(e),e.isPropagationStopped()||(this.mouseHandled=!0),i.has(".ui-menu").length?this.expand(e):!this.element.is(":focus")&&s.closest(".ui-menu").length&&(this.element.trigger("focus",[!0]),this.active&&1===this.active.parents(".ui-menu").length&&clearTimeout(this.timer)))},"mouseenter .ui-menu-item":function(e){if(!this.previousFilter){var i=t(e.target).closest(".ui-menu-item"),s=t(e.currentTarget);i[0]===s[0]&&(this._removeClass(s.siblings().children(".ui-state-active"),null,"ui-state-active"),this.focus(e,s))}},mouseleave:"collapseAll","mouseleave .ui-menu":"collapseAll",focus:function(t,e){var i=this.active||this.element.find(this.options.items).eq(0);e||this.focus(t,i)},blur:function(e){this._delay(function(){var i=!t.contains(this.element[0],t.ui.safeActiveElement(this.document[0]));i&&this.collapseAll(e)})},keydown:"_keydown"}),this.refresh(),this._on(this.document,{click:function(t){this._closeOnDocumentClick(t)&&this.collapseAll(t),this.mouseHandled=!1}})},_destroy:function(){var e=this.element.find(".ui-menu-item").removeAttr("role aria-disabled"),i=e.children(".ui-menu-item-wrapper").removeUniqueId().removeAttr("tabIndex role aria-haspopup");this.element.removeAttr("aria-activedescendant").find(".ui-menu").addBack().removeAttr("role aria-labelledby aria-expanded aria-hidden aria-disabled tabIndex").removeUniqueId().show(),i.children().each(function(){var e=t(this);e.data("ui-menu-submenu-caret")&&e.remove()})},_keydown:function(e){var i,s,n,o,a=!0;switch(e.keyCode){case t.ui.keyCode.PAGE_UP:this.previousPage(e);break;case t.ui.keyCode.PAGE_DOWN:this.nextPage(e);break;case t.ui.keyCode.HOME:this._move("first","first",e);break;case t.ui.keyCode.END:this._move("last","last",e);break;case t.ui.keyCode.UP:this.previous(e);break;case t.ui.keyCode.DOWN:this.next(e);break;case t.ui.keyCode.LEFT:this.collapse(e);break;case t.ui.keyCode.RIGHT:this.active&&!this.active.is(".ui-state-disabled")&&this.expand(e);break;case t.ui.keyCode.ENTER:case t.ui.keyCode.SPACE:this._activate(e);break;case t.ui.keyCode.ESCAPE:this.collapse(e);break;default:a=!1,s=this.previousFilter||"",o=!1,n=e.keyCode>=96&&105>=e.keyCode?""+(e.keyCode-96):String.fromCharCode(e.keyCode),clearTimeout(this.filterTimer),n===s?o=!0:n=s+n,i=this._filterMenuItems(n),i=o&&-1!==i.index(this.active.next())?this.active.nextAll(".ui-menu-item"):i,i.length||(n=String.fromCharCode(e.keyCode),i=this._filterMenuItems(n)),i.length?(this.focus(e,i),this.previousFilter=n,this.filterTimer=this._delay(function(){delete this.previousFilter},1e3)):delete this.previousFilter}a&&e.preventDefault()},_activate:function(t){this.active&&!this.active.is(".ui-state-disabled")&&(this.active.children("[aria-haspopup='true']").length?this.expand(t):this.select(t))},refresh:function(){var e,i,s,n,o,a=this,r=this.options.icons.submenu,h=this.element.find(this.options.menus);this._toggleClass("ui-menu-icons",null,!!this.element.find(".ui-icon").length),s=h.filter(":not(.ui-menu)").hide().attr({role:this.options.role,"aria-hidden":"true","aria-expanded":"false"}).each(function(){var e=t(this),i=e.prev(),s=t("<span>").data("ui-menu-submenu-caret",!0);a._addClass(s,"ui-menu-icon","ui-icon "+r),i.attr("aria-haspopup","true").prepend(s),e.attr("aria-labelledby",i.attr("id"))}),this._addClass(s,"ui-menu","ui-widget ui-widget-content ui-front"),e=h.add(this.element),i=e.find(this.options.items),i.not(".ui-menu-item").each(function(){var e=t(this);a._isDivider(e)&&a._addClass(e,"ui-menu-divider","ui-widget-content")}),n=i.not(".ui-menu-item, .ui-menu-divider"),o=n.children().not(".ui-menu").uniqueId().attr({tabIndex:-1,role:this._itemRole()}),this._addClass(n,"ui-menu-item")._addClass(o,"ui-menu-item-wrapper"),i.filter(".ui-state-disabled").attr("aria-disabled","true"),this.active&&!t.contains(this.element[0],this.active[0])&&this.blur()},_itemRole:function(){return{menu:"menuitem",listbox:"option"}[this.options.role]},_setOption:function(t,e){if("icons"===t){var i=this.element.find(".ui-menu-icon");this._removeClass(i,null,this.options.icons.submenu)._addClass(i,null,e.submenu)}this._super(t,e)},_setOptionDisabled:function(t){this._super(t),this.element.attr("aria-disabled",t+""),this._toggleClass(null,"ui-state-disabled",!!t)},focus:function(t,e){var i,s,n;this.blur(t,t&&"focus"===t.type),this._scrollIntoView(e),this.active=e.first(),s=this.active.children(".ui-menu-item-wrapper"),this._addClass(s,null,"ui-state-active"),this.options.role&&this.element.attr("aria-activedescendant",s.attr("id")),n=this.active.parent().closest(".ui-menu-item").children(".ui-menu-item-wrapper"),this._addClass(n,null,"ui-state-active"),t&&"keydown"===t.type?this._close():this.timer=this._delay(function(){this._close()},this.delay),i=e.children(".ui-menu"),i.length&&t&&/^mouse/.test(t.type)&&this._startOpening(i),this.activeMenu=e.parent(),this._trigger("focus",t,{item:e})},_scrollIntoView:function(e){var i,s,n,o,a,r;this._hasScroll()&&(i=parseFloat(t.css(this.activeMenu[0],"borderTopWidth"))||0,s=parseFloat(t.css(this.activeMenu[0],"paddingTop"))||0,n=e.offset().top-this.activeMenu.offset().top-i-s,o=this.activeMenu.scrollTop(),a=this.activeMenu.height(),r=e.outerHeight(),0>n?this.activeMenu.scrollTop(o+n):n+r>a&&this.activeMenu.scrollTop(o+n-a+r))},blur:function(t,e){e||clearTimeout(this.timer),this.active&&(this._removeClass(this.active.children(".ui-menu-item-wrapper"),null,"ui-state-active"),this._trigger("blur",t,{item:this.active}),this.active=null)},_startOpening:function(t){clearTimeout(this.timer),"true"===t.attr("aria-hidden")&&(this.timer=this._delay(function(){this._close(),this._open(t)},this.delay))},_open:function(e){var i=t.extend({of:this.active},this.options.position);clearTimeout(this.timer),this.element.find(".ui-menu").not(e.parents(".ui-menu")).hide().attr("aria-hidden","true"),e.show().removeAttr("aria-hidden").attr("aria-expanded","true").position(i)},collapseAll:function(e,i){clearTimeout(this.timer),this.timer=this._delay(function(){var s=i?this.element:t(e&&e.target).closest(this.element.find(".ui-menu"));s.length||(s=this.element),this._close(s),this.blur(e),this._removeClass(s.find(".ui-state-active"),null,"ui-state-active"),this.activeMenu=s},this.delay)},_close:function(t){t||(t=this.active?this.active.parent():this.element),t.find(".ui-menu").hide().attr("aria-hidden","true").attr("aria-expanded","false")},_closeOnDocumentClick:function(e){return!t(e.target).closest(".ui-menu").length},_isDivider:function(t){return!/[^\-\u2014\u2013\s]/.test(t.text())},collapse:function(t){var e=this.active&&this.active.parent().closest(".ui-menu-item",this.element);e&&e.length&&(this._close(),this.focus(t,e))},expand:function(t){var e=this.active&&this.active.children(".ui-menu ").find(this.options.items).first();e&&e.length&&(this._open(e.parent()),this._delay(function(){this.focus(t,e)}))},next:function(t){this._move("next","first",t)},previous:function(t){this._move("prev","last",t)},isFirstItem:function(){return this.active&&!this.active.prevAll(".ui-menu-item").length},isLastItem:function(){return this.active&&!this.active.nextAll(".ui-menu-item").length},_move:function(t,e,i){var s;this.active&&(s="first"===t||"last"===t?this.active["first"===t?"prevAll":"nextAll"](".ui-menu-item").eq(-1):this.active[t+"All"](".ui-menu-item").eq(0)),s&&s.length&&this.active||(s=this.activeMenu.find(this.options.items)[e]()),this.focus(i,s)},nextPage:function(e){var i,s,n;return this.active?(this.isLastItem()||(this._hasScroll()?(s=this.active.offset().top,n=this.element.height(),this.active.nextAll(".ui-menu-item").each(function(){return i=t(this),0>i.offset().top-s-n}),this.focus(e,i)):this.focus(e,this.activeMenu.find(this.options.items)[this.active?"last":"first"]())),void 0):(this.next(e),void 0)},previousPage:function(e){var i,s,n;return this.active?(this.isFirstItem()||(this._hasScroll()?(s=this.active.offset().top,n=this.element.height(),this.active.prevAll(".ui-menu-item").each(function(){return i=t(this),i.offset().top-s+n>0}),this.focus(e,i)):this.focus(e,this.activeMenu.find(this.options.items).first())),void 0):(this.next(e),void 0)},_hasScroll:function(){return this.element.outerHeight()<this.element.prop("scrollHeight")},select:function(e){this.active=this.active||t(e.target).closest(".ui-menu-item");var i={item:this.active};this.active.has(".ui-menu").length||this.collapseAll(e,!0),this._trigger("select",e,i)},_filterMenuItems:function(e){var i=e.replace(/[\-\[\]{}()*+?.,\\\^$|#\s]/g,"\\$&"),s=RegExp("^"+i,"i");return this.activeMenu.find(this.options.items).filter(".ui-menu-item").filter(function(){return s.test(t.trim(t(this).children(".ui-menu-item-wrapper").text()))})}}),t.widget("ui.autocomplete",{version:"1.12.1",defaultElement:"<input>",options:{appendTo:null,autoFocus:!1,delay:300,minLength:1,position:{my:"left top",at:"left bottom",collision:"none"},source:null,change:null,close:null,focus:null,open:null,response:null,search:null,select:null},requestIndex:0,pending:0,_create:function(){var e,i,s,n=this.element[0].nodeName.toLowerCase(),o="textarea"===n,a="input"===n;
8
- this.isMultiLine=o||!a&&this._isContentEditable(this.element),this.valueMethod=this.element[o||a?"val":"text"],this.isNewMenu=!0,this._addClass("ui-autocomplete-input"),this.element.attr("autocomplete","off"),this._on(this.element,{keydown:function(n){if(this.element.prop("readOnly"))return e=!0,s=!0,i=!0,void 0;e=!1,s=!1,i=!1;var o=t.ui.keyCode;switch(n.keyCode){case o.PAGE_UP:e=!0,this._move("previousPage",n);break;case o.PAGE_DOWN:e=!0,this._move("nextPage",n);break;case o.UP:e=!0,this._keyEvent("previous",n);break;case o.DOWN:e=!0,this._keyEvent("next",n);break;case o.ENTER:this.menu.active&&(e=!0,n.preventDefault(),this.menu.select(n));break;case o.TAB:this.menu.active&&this.menu.select(n);break;case o.ESCAPE:this.menu.element.is(":visible")&&(this.isMultiLine||this._value(this.term),this.close(n),n.preventDefault());break;default:i=!0,this._searchTimeout(n)}},keypress:function(s){if(e)return e=!1,(!this.isMultiLine||this.menu.element.is(":visible"))&&s.preventDefault(),void 0;if(!i){var n=t.ui.keyCode;switch(s.keyCode){case n.PAGE_UP:this._move("previousPage",s);break;case n.PAGE_DOWN:this._move("nextPage",s);break;case n.UP:this._keyEvent("previous",s);break;case n.DOWN:this._keyEvent("next",s)}}},input:function(t){return s?(s=!1,t.preventDefault(),void 0):(this._searchTimeout(t),void 0)},focus:function(){this.selectedItem=null,this.previous=this._value()},blur:function(t){return this.cancelBlur?(delete this.cancelBlur,void 0):(clearTimeout(this.searching),this.close(t),this._change(t),void 0)}}),this._initSource(),this.menu=t("<ul>").appendTo(this._appendTo()).menu({role:null}).hide().menu("instance"),this._addClass(this.menu.element,"ui-autocomplete","ui-front"),this._on(this.menu.element,{mousedown:function(e){e.preventDefault(),this.cancelBlur=!0,this._delay(function(){delete this.cancelBlur,this.element[0]!==t.ui.safeActiveElement(this.document[0])&&this.element.trigger("focus")})},menufocus:function(e,i){var s,n;return this.isNewMenu&&(this.isNewMenu=!1,e.originalEvent&&/^mouse/.test(e.originalEvent.type))?(this.menu.blur(),this.document.one("mousemove",function(){t(e.target).trigger(e.originalEvent)}),void 0):(n=i.item.data("ui-autocomplete-item"),!1!==this._trigger("focus",e,{item:n})&&e.originalEvent&&/^key/.test(e.originalEvent.type)&&this._value(n.value),s=i.item.attr("aria-label")||n.value,s&&t.trim(s).length&&(this.liveRegion.children().hide(),t("<div>").text(s).appendTo(this.liveRegion)),void 0)},menuselect:function(e,i){var s=i.item.data("ui-autocomplete-item"),n=this.previous;this.element[0]!==t.ui.safeActiveElement(this.document[0])&&(this.element.trigger("focus"),this.previous=n,this._delay(function(){this.previous=n,this.selectedItem=s})),!1!==this._trigger("select",e,{item:s})&&this._value(s.value),this.term=this._value(),this.close(e),this.selectedItem=s}}),this.liveRegion=t("<div>",{role:"status","aria-live":"assertive","aria-relevant":"additions"}).appendTo(this.document[0].body),this._addClass(this.liveRegion,null,"ui-helper-hidden-accessible"),this._on(this.window,{beforeunload:function(){this.element.removeAttr("autocomplete")}})},_destroy:function(){clearTimeout(this.searching),this.element.removeAttr("autocomplete"),this.menu.element.remove(),this.liveRegion.remove()},_setOption:function(t,e){this._super(t,e),"source"===t&&this._initSource(),"appendTo"===t&&this.menu.element.appendTo(this._appendTo()),"disabled"===t&&e&&this.xhr&&this.xhr.abort()},_isEventTargetInWidget:function(e){var i=this.menu.element[0];return e.target===this.element[0]||e.target===i||t.contains(i,e.target)},_closeOnClickOutside:function(t){this._isEventTargetInWidget(t)||this.close()},_appendTo:function(){var e=this.options.appendTo;return e&&(e=e.jquery||e.nodeType?t(e):this.document.find(e).eq(0)),e&&e[0]||(e=this.element.closest(".ui-front, dialog")),e.length||(e=this.document[0].body),e},_initSource:function(){var e,i,s=this;t.isArray(this.options.source)?(e=this.options.source,this.source=function(i,s){s(t.ui.autocomplete.filter(e,i.term))}):"string"==typeof this.options.source?(i=this.options.source,this.source=function(e,n){s.xhr&&s.xhr.abort(),s.xhr=t.ajax({url:i,data:e,dataType:"json",success:function(t){n(t)},error:function(){n([])}})}):this.source=this.options.source},_searchTimeout:function(t){clearTimeout(this.searching),this.searching=this._delay(function(){var e=this.term===this._value(),i=this.menu.element.is(":visible"),s=t.altKey||t.ctrlKey||t.metaKey||t.shiftKey;(!e||e&&!i&&!s)&&(this.selectedItem=null,this.search(null,t))},this.options.delay)},search:function(t,e){return t=null!=t?t:this._value(),this.term=this._value(),t.length<this.options.minLength?this.close(e):this._trigger("search",e)!==!1?this._search(t):void 0},_search:function(t){this.pending++,this._addClass("ui-autocomplete-loading"),this.cancelSearch=!1,this.source({term:t},this._response())},_response:function(){var e=++this.requestIndex;return t.proxy(function(t){e===this.requestIndex&&this.__response(t),this.pending--,this.pending||this._removeClass("ui-autocomplete-loading")},this)},__response:function(t){t&&(t=this._normalize(t)),this._trigger("response",null,{content:t}),!this.options.disabled&&t&&t.length&&!this.cancelSearch?(this._suggest(t),this._trigger("open")):this._close()},close:function(t){this.cancelSearch=!0,this._close(t)},_close:function(t){this._off(this.document,"mousedown"),this.menu.element.is(":visible")&&(this.menu.element.hide(),this.menu.blur(),this.isNewMenu=!0,this._trigger("close",t))},_change:function(t){this.previous!==this._value()&&this._trigger("change",t,{item:this.selectedItem})},_normalize:function(e){return e.length&&e[0].label&&e[0].value?e:t.map(e,function(e){return"string"==typeof e?{label:e,value:e}:t.extend({},e,{label:e.label||e.value,value:e.value||e.label})})},_suggest:function(e){var i=this.menu.element.empty();this._renderMenu(i,e),this.isNewMenu=!0,this.menu.refresh(),i.show(),this._resizeMenu(),i.position(t.extend({of:this.element},this.options.position)),this.options.autoFocus&&this.menu.next(),this._on(this.document,{mousedown:"_closeOnClickOutside"})},_resizeMenu:function(){var t=this.menu.element;t.outerWidth(Math.max(t.width("").outerWidth()+1,this.element.outerWidth()))},_renderMenu:function(e,i){var s=this;t.each(i,function(t,i){s._renderItemData(e,i)})},_renderItemData:function(t,e){return this._renderItem(t,e).data("ui-autocomplete-item",e)},_renderItem:function(e,i){return t("<li>").append(t("<div>").text(i.label)).appendTo(e)},_move:function(t,e){return this.menu.element.is(":visible")?this.menu.isFirstItem()&&/^previous/.test(t)||this.menu.isLastItem()&&/^next/.test(t)?(this.isMultiLine||this._value(this.term),this.menu.blur(),void 0):(this.menu[t](e),void 0):(this.search(null,e),void 0)},widget:function(){return this.menu.element},_value:function(){return this.valueMethod.apply(this.element,arguments)},_keyEvent:function(t,e){(!this.isMultiLine||this.menu.element.is(":visible"))&&(this._move(t,e),e.preventDefault())},_isContentEditable:function(t){if(!t.length)return!1;var e=t.prop("contentEditable");return"inherit"===e?this._isContentEditable(t.parent()):"true"===e}}),t.extend(t.ui.autocomplete,{escapeRegex:function(t){return t.replace(/[\-\[\]{}()*+?.,\\\^$|#\s]/g,"\\$&")},filter:function(e,i){var s=RegExp(t.ui.autocomplete.escapeRegex(i),"i");return t.grep(e,function(t){return s.test(t.label||t.value||t)})}}),t.widget("ui.autocomplete",t.ui.autocomplete,{options:{messages:{noResults:"No search results.",results:function(t){return t+(t>1?" results are":" result is")+" available, use up and down arrow keys to navigate."}}},__response:function(e){var i;this._superApply(arguments),this.options.disabled||this.cancelSearch||(i=e&&e.length?this.options.messages.results(e.length):this.options.messages.noResults,this.liveRegion.children().hide(),t("<div>").text(i).appendTo(this.liveRegion))}}),t.ui.autocomplete;var g=/ui-corner-([a-z]){2,6}/g;t.widget("ui.controlgroup",{version:"1.12.1",defaultElement:"<div>",options:{direction:"horizontal",disabled:null,onlyVisible:!0,items:{button:"input[type=button], input[type=submit], input[type=reset], button, a",controlgroupLabel:".ui-controlgroup-label",checkboxradio:"input[type='checkbox'], input[type='radio']",selectmenu:"select",spinner:".ui-spinner-input"}},_create:function(){this._enhance()},_enhance:function(){this.element.attr("role","toolbar"),this.refresh()},_destroy:function(){this._callChildMethod("destroy"),this.childWidgets.removeData("ui-controlgroup-data"),this.element.removeAttr("role"),this.options.items.controlgroupLabel&&this.element.find(this.options.items.controlgroupLabel).find(".ui-controlgroup-label-contents").contents().unwrap()},_initWidgets:function(){var e=this,i=[];t.each(this.options.items,function(s,n){var o,a={};return n?"controlgroupLabel"===s?(o=e.element.find(n),o.each(function(){var e=t(this);e.children(".ui-controlgroup-label-contents").length||e.contents().wrapAll("<span class='ui-controlgroup-label-contents'></span>")}),e._addClass(o,null,"ui-widget ui-widget-content ui-state-default"),i=i.concat(o.get()),void 0):(t.fn[s]&&(a=e["_"+s+"Options"]?e["_"+s+"Options"]("middle"):{classes:{}},e.element.find(n).each(function(){var n=t(this),o=n[s]("instance"),r=t.widget.extend({},a);if("button"!==s||!n.parent(".ui-spinner").length){o||(o=n[s]()[s]("instance")),o&&(r.classes=e._resolveClassesValues(r.classes,o)),n[s](r);var h=n[s]("widget");t.data(h[0],"ui-controlgroup-data",o?o:n[s]("instance")),i.push(h[0])}})),void 0):void 0}),this.childWidgets=t(t.unique(i)),this._addClass(this.childWidgets,"ui-controlgroup-item")},_callChildMethod:function(e){this.childWidgets.each(function(){var i=t(this),s=i.data("ui-controlgroup-data");s&&s[e]&&s[e]()})},_updateCornerClass:function(t,e){var i="ui-corner-top ui-corner-bottom ui-corner-left ui-corner-right ui-corner-all",s=this._buildSimpleOptions(e,"label").classes.label;this._removeClass(t,null,i),this._addClass(t,null,s)},_buildSimpleOptions:function(t,e){var i="vertical"===this.options.direction,s={classes:{}};return s.classes[e]={middle:"",first:"ui-corner-"+(i?"top":"left"),last:"ui-corner-"+(i?"bottom":"right"),only:"ui-corner-all"}[t],s},_spinnerOptions:function(t){var e=this._buildSimpleOptions(t,"ui-spinner");return e.classes["ui-spinner-up"]="",e.classes["ui-spinner-down"]="",e},_buttonOptions:function(t){return this._buildSimpleOptions(t,"ui-button")},_checkboxradioOptions:function(t){return this._buildSimpleOptions(t,"ui-checkboxradio-label")},_selectmenuOptions:function(t){var e="vertical"===this.options.direction;return{width:e?"auto":!1,classes:{middle:{"ui-selectmenu-button-open":"","ui-selectmenu-button-closed":""},first:{"ui-selectmenu-button-open":"ui-corner-"+(e?"top":"tl"),"ui-selectmenu-button-closed":"ui-corner-"+(e?"top":"left")},last:{"ui-selectmenu-button-open":e?"":"ui-corner-tr","ui-selectmenu-button-closed":"ui-corner-"+(e?"bottom":"right")},only:{"ui-selectmenu-button-open":"ui-corner-top","ui-selectmenu-button-closed":"ui-corner-all"}}[t]}},_resolveClassesValues:function(e,i){var s={};return t.each(e,function(n){var o=i.options.classes[n]||"";o=t.trim(o.replace(g,"")),s[n]=(o+" "+e[n]).replace(/\s+/g," ")}),s},_setOption:function(t,e){return"direction"===t&&this._removeClass("ui-controlgroup-"+this.options.direction),this._super(t,e),"disabled"===t?(this._callChildMethod(e?"disable":"enable"),void 0):(this.refresh(),void 0)},refresh:function(){var e,i=this;this._addClass("ui-controlgroup ui-controlgroup-"+this.options.direction),"horizontal"===this.options.direction&&this._addClass(null,"ui-helper-clearfix"),this._initWidgets(),e=this.childWidgets,this.options.onlyVisible&&(e=e.filter(":visible")),e.length&&(t.each(["first","last"],function(t,s){var n=e[s]().data("ui-controlgroup-data");if(n&&i["_"+n.widgetName+"Options"]){var o=i["_"+n.widgetName+"Options"](1===e.length?"only":s);o.classes=i._resolveClassesValues(o.classes,n),n.element[n.widgetName](o)}else i._updateCornerClass(e[s](),s)}),this._callChildMethod("refresh"))}}),t.widget("ui.checkboxradio",[t.ui.formResetMixin,{version:"1.12.1",options:{disabled:null,label:null,icon:!0,classes:{"ui-checkboxradio-label":"ui-corner-all","ui-checkboxradio-icon":"ui-corner-all"}},_getCreateOptions:function(){var e,i,s=this,n=this._super()||{};return this._readType(),i=this.element.labels(),this.label=t(i[i.length-1]),this.label.length||t.error("No label found for checkboxradio widget"),this.originalLabel="",this.label.contents().not(this.element[0]).each(function(){s.originalLabel+=3===this.nodeType?t(this).text():this.outerHTML}),this.originalLabel&&(n.label=this.originalLabel),e=this.element[0].disabled,null!=e&&(n.disabled=e),n},_create:function(){var t=this.element[0].checked;this._bindFormResetHandler(),null==this.options.disabled&&(this.options.disabled=this.element[0].disabled),this._setOption("disabled",this.options.disabled),this._addClass("ui-checkboxradio","ui-helper-hidden-accessible"),this._addClass(this.label,"ui-checkboxradio-label","ui-button ui-widget"),"radio"===this.type&&this._addClass(this.label,"ui-checkboxradio-radio-label"),this.options.label&&this.options.label!==this.originalLabel?this._updateLabel():this.originalLabel&&(this.options.label=this.originalLabel),this._enhance(),t&&(this._addClass(this.label,"ui-checkboxradio-checked","ui-state-active"),this.icon&&this._addClass(this.icon,null,"ui-state-hover")),this._on({change:"_toggleClasses",focus:function(){this._addClass(this.label,null,"ui-state-focus ui-visual-focus")},blur:function(){this._removeClass(this.label,null,"ui-state-focus ui-visual-focus")}})},_readType:function(){var e=this.element[0].nodeName.toLowerCase();this.type=this.element[0].type,"input"===e&&/radio|checkbox/.test(this.type)||t.error("Can't create checkboxradio on element.nodeName="+e+" and element.type="+this.type)},_enhance:function(){this._updateIcon(this.element[0].checked)},widget:function(){return this.label},_getRadioGroup:function(){var e,i=this.element[0].name,s="input[name='"+t.ui.escapeSelector(i)+"']";return i?(e=this.form.length?t(this.form[0].elements).filter(s):t(s).filter(function(){return 0===t(this).form().length}),e.not(this.element)):t([])},_toggleClasses:function(){var e=this.element[0].checked;this._toggleClass(this.label,"ui-checkboxradio-checked","ui-state-active",e),this.options.icon&&"checkbox"===this.type&&this._toggleClass(this.icon,null,"ui-icon-check ui-state-checked",e)._toggleClass(this.icon,null,"ui-icon-blank",!e),"radio"===this.type&&this._getRadioGroup().each(function(){var e=t(this).checkboxradio("instance");e&&e._removeClass(e.label,"ui-checkboxradio-checked","ui-state-active")})},_destroy:function(){this._unbindFormResetHandler(),this.icon&&(this.icon.remove(),this.iconSpace.remove())},_setOption:function(t,e){return"label"!==t||e?(this._super(t,e),"disabled"===t?(this._toggleClass(this.label,null,"ui-state-disabled",e),this.element[0].disabled=e,void 0):(this.refresh(),void 0)):void 0},_updateIcon:function(e){var i="ui-icon ui-icon-background ";this.options.icon?(this.icon||(this.icon=t("<span>"),this.iconSpace=t("<span> </span>"),this._addClass(this.iconSpace,"ui-checkboxradio-icon-space")),"checkbox"===this.type?(i+=e?"ui-icon-check ui-state-checked":"ui-icon-blank",this._removeClass(this.icon,null,e?"ui-icon-blank":"ui-icon-check")):i+="ui-icon-blank",this._addClass(this.icon,"ui-checkboxradio-icon",i),e||this._removeClass(this.icon,null,"ui-icon-check ui-state-checked"),this.icon.prependTo(this.label).after(this.iconSpace)):void 0!==this.icon&&(this.icon.remove(),this.iconSpace.remove(),delete this.icon)},_updateLabel:function(){var t=this.label.contents().not(this.element[0]);this.icon&&(t=t.not(this.icon[0])),this.iconSpace&&(t=t.not(this.iconSpace[0])),t.remove(),this.label.append(this.options.label)},refresh:function(){var t=this.element[0].checked,e=this.element[0].disabled;this._updateIcon(t),this._toggleClass(this.label,"ui-checkboxradio-checked","ui-state-active",t),null!==this.options.label&&this._updateLabel(),e!==this.options.disabled&&this._setOptions({disabled:e})}}]),t.ui.checkboxradio,t.widget("ui.button",{version:"1.12.1",defaultElement:"<button>",options:{classes:{"ui-button":"ui-corner-all"},disabled:null,icon:null,iconPosition:"beginning",label:null,showLabel:!0},_getCreateOptions:function(){var t,e=this._super()||{};return this.isInput=this.element.is("input"),t=this.element[0].disabled,null!=t&&(e.disabled=t),this.originalLabel=this.isInput?this.element.val():this.element.html(),this.originalLabel&&(e.label=this.originalLabel),e},_create:function(){!this.option.showLabel&!this.options.icon&&(this.options.showLabel=!0),null==this.options.disabled&&(this.options.disabled=this.element[0].disabled||!1),this.hasTitle=!!this.element.attr("title"),this.options.label&&this.options.label!==this.originalLabel&&(this.isInput?this.element.val(this.options.label):this.element.html(this.options.label)),this._addClass("ui-button","ui-widget"),this._setOption("disabled",this.options.disabled),this._enhance(),this.element.is("a")&&this._on({keyup:function(e){e.keyCode===t.ui.keyCode.SPACE&&(e.preventDefault(),this.element[0].click?this.element[0].click():this.element.trigger("click"))}})},_enhance:function(){this.element.is("button")||this.element.attr("role","button"),this.options.icon&&(this._updateIcon("icon",this.options.icon),this._updateTooltip())},_updateTooltip:function(){this.title=this.element.attr("title"),this.options.showLabel||this.title||this.element.attr("title",this.options.label)},_updateIcon:function(e,i){var s="iconPosition"!==e,n=s?this.options.iconPosition:i,o="top"===n||"bottom"===n;this.icon?s&&this._removeClass(this.icon,null,this.options.icon):(this.icon=t("<span>"),this._addClass(this.icon,"ui-button-icon","ui-icon"),this.options.showLabel||this._addClass("ui-button-icon-only")),s&&this._addClass(this.icon,null,i),this._attachIcon(n),o?(this._addClass(this.icon,null,"ui-widget-icon-block"),this.iconSpace&&this.iconSpace.remove()):(this.iconSpace||(this.iconSpace=t("<span> </span>"),this._addClass(this.iconSpace,"ui-button-icon-space")),this._removeClass(this.icon,null,"ui-wiget-icon-block"),this._attachIconSpace(n))},_destroy:function(){this.element.removeAttr("role"),this.icon&&this.icon.remove(),this.iconSpace&&this.iconSpace.remove(),this.hasTitle||this.element.removeAttr("title")},_attachIconSpace:function(t){this.icon[/^(?:end|bottom)/.test(t)?"before":"after"](this.iconSpace)},_attachIcon:function(t){this.element[/^(?:end|bottom)/.test(t)?"append":"prepend"](this.icon)},_setOptions:function(t){var e=void 0===t.showLabel?this.options.showLabel:t.showLabel,i=void 0===t.icon?this.options.icon:t.icon;e||i||(t.showLabel=!0),this._super(t)},_setOption:function(t,e){"icon"===t&&(e?this._updateIcon(t,e):this.icon&&(this.icon.remove(),this.iconSpace&&this.iconSpace.remove())),"iconPosition"===t&&this._updateIcon(t,e),"showLabel"===t&&(this._toggleClass("ui-button-icon-only",null,!e),this._updateTooltip()),"label"===t&&(this.isInput?this.element.val(e):(this.element.html(e),this.icon&&(this._attachIcon(this.options.iconPosition),this._attachIconSpace(this.options.iconPosition)))),this._super(t,e),"disabled"===t&&(this._toggleClass(null,"ui-state-disabled",e),this.element[0].disabled=e,e&&this.element.blur())},refresh:function(){var t=this.element.is("input, button")?this.element[0].disabled:this.element.hasClass("ui-button-disabled");t!==this.options.disabled&&this._setOptions({disabled:t}),this._updateTooltip()}}),t.uiBackCompat!==!1&&(t.widget("ui.button",t.ui.button,{options:{text:!0,icons:{primary:null,secondary:null}},_create:function(){this.options.showLabel&&!this.options.text&&(this.options.showLabel=this.options.text),!this.options.showLabel&&this.options.text&&(this.options.text=this.options.showLabel),this.options.icon||!this.options.icons.primary&&!this.options.icons.secondary?this.options.icon&&(this.options.icons.primary=this.options.icon):this.options.icons.primary?this.options.icon=this.options.icons.primary:(this.options.icon=this.options.icons.secondary,this.options.iconPosition="end"),this._super()},_setOption:function(t,e){return"text"===t?(this._super("showLabel",e),void 0):("showLabel"===t&&(this.options.text=e),"icon"===t&&(this.options.icons.primary=e),"icons"===t&&(e.primary?(this._super("icon",e.primary),this._super("iconPosition","beginning")):e.secondary&&(this._super("icon",e.secondary),this._super("iconPosition","end"))),this._superApply(arguments),void 0)}}),t.fn.button=function(e){return function(){return!this.length||this.length&&"INPUT"!==this[0].tagName||this.length&&"INPUT"===this[0].tagName&&"checkbox"!==this.attr("type")&&"radio"!==this.attr("type")?e.apply(this,arguments):(t.ui.checkboxradio||t.error("Checkboxradio widget missing"),0===arguments.length?this.checkboxradio({icon:!1}):this.checkboxradio.apply(this,arguments))}}(t.fn.button),t.fn.buttonset=function(){return t.ui.controlgroup||t.error("Controlgroup widget missing"),"option"===arguments[0]&&"items"===arguments[1]&&arguments[2]?this.controlgroup.apply(this,[arguments[0],"items.button",arguments[2]]):"option"===arguments[0]&&"items"===arguments[1]?this.controlgroup.apply(this,[arguments[0],"items.button"]):("object"==typeof arguments[0]&&arguments[0].items&&(arguments[0].items={button:arguments[0].items}),this.controlgroup.apply(this,arguments))}),t.ui.button,t.extend(t.ui,{datepicker:{version:"1.12.1"}});var m;t.extend(s.prototype,{markerClassName:"hasDatepicker",maxRows:4,_widgetDatepicker:function(){return this.dpDiv},setDefaults:function(t){return a(this._defaults,t||{}),this},_attachDatepicker:function(e,i){var s,n,o;s=e.nodeName.toLowerCase(),n="div"===s||"span"===s,e.id||(this.uuid+=1,e.id="dp"+this.uuid),o=this._newInst(t(e),n),o.settings=t.extend({},i||{}),"input"===s?this._connectDatepicker(e,o):n&&this._inlineDatepicker(e,o)},_newInst:function(e,i){var s=e[0].id.replace(/([^A-Za-z0-9_\-])/g,"\\\\$1");return{id:s,input:e,selectedDay:0,selectedMonth:0,selectedYear:0,drawMonth:0,drawYear:0,inline:i,dpDiv:i?n(t("<div class='"+this._inlineClass+" ui-datepicker ui-widget ui-widget-content ui-helper-clearfix ui-corner-all'></div>")):this.dpDiv}},_connectDatepicker:function(e,i){var s=t(e);i.append=t([]),i.trigger=t([]),s.hasClass(this.markerClassName)||(this._attachments(s,i),s.addClass(this.markerClassName).on("keydown",this._doKeyDown).on("keypress",this._doKeyPress).on("keyup",this._doKeyUp),this._autoSize(i),t.data(e,"datepicker",i),i.settings.disabled&&this._disableDatepicker(e))},_attachments:function(e,i){var s,n,o,a=this._get(i,"appendText"),r=this._get(i,"isRTL");i.append&&i.append.remove(),a&&(i.append=t("<span class='"+this._appendClass+"'>"+a+"</span>"),e[r?"before":"after"](i.append)),e.off("focus",this._showDatepicker),i.trigger&&i.trigger.remove(),s=this._get(i,"showOn"),("focus"===s||"both"===s)&&e.on("focus",this._showDatepicker),("button"===s||"both"===s)&&(n=this._get(i,"buttonText"),o=this._get(i,"buttonImage"),i.trigger=t(this._get(i,"buttonImageOnly")?t("<img/>").addClass(this._triggerClass).attr({src:o,alt:n,title:n}):t("<button type='button'></button>").addClass(this._triggerClass).html(o?t("<img/>").attr({src:o,alt:n,title:n}):n)),e[r?"before":"after"](i.trigger),i.trigger.on("click",function(){return t.datepicker._datepickerShowing&&t.datepicker._lastInput===e[0]?t.datepicker._hideDatepicker():t.datepicker._datepickerShowing&&t.datepicker._lastInput!==e[0]?(t.datepicker._hideDatepicker(),t.datepicker._showDatepicker(e[0])):t.datepicker._showDatepicker(e[0]),!1}))},_autoSize:function(t){if(this._get(t,"autoSize")&&!t.inline){var e,i,s,n,o=new Date(2009,11,20),a=this._get(t,"dateFormat");a.match(/[DM]/)&&(e=function(t){for(i=0,s=0,n=0;t.length>n;n++)t[n].length>i&&(i=t[n].length,s=n);return s},o.setMonth(e(this._get(t,a.match(/MM/)?"monthNames":"monthNamesShort"))),o.setDate(e(this._get(t,a.match(/DD/)?"dayNames":"dayNamesShort"))+20-o.getDay())),t.input.attr("size",this._formatDate(t,o).length)}},_inlineDatepicker:function(e,i){var s=t(e);s.hasClass(this.markerClassName)||(s.addClass(this.markerClassName).append(i.dpDiv),t.data(e,"datepicker",i),this._setDate(i,this._getDefaultDate(i),!0),this._updateDatepicker(i),this._updateAlternate(i),i.settings.disabled&&this._disableDatepicker(e),i.dpDiv.css("display","block"))},_dialogDatepicker:function(e,i,s,n,o){var r,h,l,c,u,d=this._dialogInst;return d||(this.uuid+=1,r="dp"+this.uuid,this._dialogInput=t("<input type='text' id='"+r+"' style='position: absolute; top: -100px; width: 0px;'/>"),this._dialogInput.on("keydown",this._doKeyDown),t("body").append(this._dialogInput),d=this._dialogInst=this._newInst(this._dialogInput,!1),d.settings={},t.data(this._dialogInput[0],"datepicker",d)),a(d.settings,n||{}),i=i&&i.constructor===Date?this._formatDate(d,i):i,this._dialogInput.val(i),this._pos=o?o.length?o:[o.pageX,o.pageY]:null,this._pos||(h=document.documentElement.clientWidth,l=document.documentElement.clientHeight,c=document.documentElement.scrollLeft||document.body.scrollLeft,u=document.documentElement.scrollTop||document.body.scrollTop,this._pos=[h/2-100+c,l/2-150+u]),this._dialogInput.css("left",this._pos[0]+20+"px").css("top",this._pos[1]+"px"),d.settings.onSelect=s,this._inDialog=!0,this.dpDiv.addClass(this._dialogClass),this._showDatepicker(this._dialogInput[0]),t.blockUI&&t.blockUI(this.dpDiv),t.data(this._dialogInput[0],"datepicker",d),this},_destroyDatepicker:function(e){var i,s=t(e),n=t.data(e,"datepicker");s.hasClass(this.markerClassName)&&(i=e.nodeName.toLowerCase(),t.removeData(e,"datepicker"),"input"===i?(n.append.remove(),n.trigger.remove(),s.removeClass(this.markerClassName).off("focus",this._showDatepicker).off("keydown",this._doKeyDown).off("keypress",this._doKeyPress).off("keyup",this._doKeyUp)):("div"===i||"span"===i)&&s.removeClass(this.markerClassName).empty(),m===n&&(m=null))},_enableDatepicker:function(e){var i,s,n=t(e),o=t.data(e,"datepicker");n.hasClass(this.markerClassName)&&(i=e.nodeName.toLowerCase(),"input"===i?(e.disabled=!1,o.trigger.filter("button").each(function(){this.disabled=!1}).end().filter("img").css({opacity:"1.0",cursor:""})):("div"===i||"span"===i)&&(s=n.children("."+this._inlineClass),s.children().removeClass("ui-state-disabled"),s.find("select.ui-datepicker-month, select.ui-datepicker-year").prop("disabled",!1)),this._disabledInputs=t.map(this._disabledInputs,function(t){return t===e?null:t}))},_disableDatepicker:function(e){var i,s,n=t(e),o=t.data(e,"datepicker");n.hasClass(this.markerClassName)&&(i=e.nodeName.toLowerCase(),"input"===i?(e.disabled=!0,o.trigger.filter("button").each(function(){this.disabled=!0}).end().filter("img").css({opacity:"0.5",cursor:"default"})):("div"===i||"span"===i)&&(s=n.children("."+this._inlineClass),s.children().addClass("ui-state-disabled"),s.find("select.ui-datepicker-month, select.ui-datepicker-year").prop("disabled",!0)),this._disabledInputs=t.map(this._disabledInputs,function(t){return t===e?null:t}),this._disabledInputs[this._disabledInputs.length]=e)},_isDisabledDatepicker:function(t){if(!t)return!1;for(var e=0;this._disabledInputs.length>e;e++)if(this._disabledInputs[e]===t)return!0;return!1},_getInst:function(e){try{return t.data(e,"datepicker")}catch(i){throw"Missing instance data for this datepicker"}},_optionDatepicker:function(e,i,s){var n,o,r,h,l=this._getInst(e);return 2===arguments.length&&"string"==typeof i?"defaults"===i?t.extend({},t.datepicker._defaults):l?"all"===i?t.extend({},l.settings):this._get(l,i):null:(n=i||{},"string"==typeof i&&(n={},n[i]=s),l&&(this._curInst===l&&this._hideDatepicker(),o=this._getDateDatepicker(e,!0),r=this._getMinMaxDate(l,"min"),h=this._getMinMaxDate(l,"max"),a(l.settings,n),null!==r&&void 0!==n.dateFormat&&void 0===n.minDate&&(l.settings.minDate=this._formatDate(l,r)),null!==h&&void 0!==n.dateFormat&&void 0===n.maxDate&&(l.settings.maxDate=this._formatDate(l,h)),"disabled"in n&&(n.disabled?this._disableDatepicker(e):this._enableDatepicker(e)),this._attachments(t(e),l),this._autoSize(l),this._setDate(l,o),this._updateAlternate(l),this._updateDatepicker(l)),void 0)},_changeDatepicker:function(t,e,i){this._optionDatepicker(t,e,i)},_refreshDatepicker:function(t){var e=this._getInst(t);e&&this._updateDatepicker(e)},_setDateDatepicker:function(t,e){var i=this._getInst(t);i&&(this._setDate(i,e),this._updateDatepicker(i),this._updateAlternate(i))},_getDateDatepicker:function(t,e){var i=this._getInst(t);return i&&!i.inline&&this._setDateFromField(i,e),i?this._getDate(i):null},_doKeyDown:function(e){var i,s,n,o=t.datepicker._getInst(e.target),a=!0,r=o.dpDiv.is(".ui-datepicker-rtl");if(o._keyEvent=!0,t.datepicker._datepickerShowing)switch(e.keyCode){case 9:t.datepicker._hideDatepicker(),a=!1;break;case 13:return n=t("td."+t.datepicker._dayOverClass+":not(."+t.datepicker._currentClass+")",o.dpDiv),n[0]&&t.datepicker._selectDay(e.target,o.selectedMonth,o.selectedYear,n[0]),i=t.datepicker._get(o,"onSelect"),i?(s=t.datepicker._formatDate(o),i.apply(o.input?o.input[0]:null,[s,o])):t.datepicker._hideDatepicker(),!1;case 27:t.datepicker._hideDatepicker();break;case 33:t.datepicker._adjustDate(e.target,e.ctrlKey?-t.datepicker._get(o,"stepBigMonths"):-t.datepicker._get(o,"stepMonths"),"M");break;case 34:t.datepicker._adjustDate(e.target,e.ctrlKey?+t.datepicker._get(o,"stepBigMonths"):+t.datepicker._get(o,"stepMonths"),"M");break;case 35:(e.ctrlKey||e.metaKey)&&t.datepicker._clearDate(e.target),a=e.ctrlKey||e.metaKey;break;case 36:(e.ctrlKey||e.metaKey)&&t.datepicker._gotoToday(e.target),a=e.ctrlKey||e.metaKey;break;case 37:(e.ctrlKey||e.metaKey)&&t.datepicker._adjustDate(e.target,r?1:-1,"D"),a=e.ctrlKey||e.metaKey,e.originalEvent.altKey&&t.datepicker._adjustDate(e.target,e.ctrlKey?-t.datepicker._get(o,"stepBigMonths"):-t.datepicker._get(o,"stepMonths"),"M");break;case 38:(e.ctrlKey||e.metaKey)&&t.datepicker._adjustDate(e.target,-7,"D"),a=e.ctrlKey||e.metaKey;break;case 39:(e.ctrlKey||e.metaKey)&&t.datepicker._adjustDate(e.target,r?-1:1,"D"),a=e.ctrlKey||e.metaKey,e.originalEvent.altKey&&t.datepicker._adjustDate(e.target,e.ctrlKey?+t.datepicker._get(o,"stepBigMonths"):+t.datepicker._get(o,"stepMonths"),"M");break;case 40:(e.ctrlKey||e.metaKey)&&t.datepicker._adjustDate(e.target,7,"D"),a=e.ctrlKey||e.metaKey;break;default:a=!1}else 36===e.keyCode&&e.ctrlKey?t.datepicker._showDatepicker(this):a=!1;a&&(e.preventDefault(),e.stopPropagation())},_doKeyPress:function(e){var i,s,n=t.datepicker._getInst(e.target);return t.datepicker._get(n,"constrainInput")?(i=t.datepicker._possibleChars(t.datepicker._get(n,"dateFormat")),s=String.fromCharCode(null==e.charCode?e.keyCode:e.charCode),e.ctrlKey||e.metaKey||" ">s||!i||i.indexOf(s)>-1):void 0},_doKeyUp:function(e){var i,s=t.datepicker._getInst(e.target);if(s.input.val()!==s.lastVal)try{i=t.datepicker.parseDate(t.datepicker._get(s,"dateFormat"),s.input?s.input.val():null,t.datepicker._getFormatConfig(s)),i&&(t.datepicker._setDateFromField(s),t.datepicker._updateAlternate(s),t.datepicker._updateDatepicker(s))}catch(n){}return!0},_showDatepicker:function(e){if(e=e.target||e,"input"!==e.nodeName.toLowerCase()&&(e=t("input",e.parentNode)[0]),!t.datepicker._isDisabledDatepicker(e)&&t.datepicker._lastInput!==e){var s,n,o,r,h,l,c;s=t.datepicker._getInst(e),t.datepicker._curInst&&t.datepicker._curInst!==s&&(t.datepicker._curInst.dpDiv.stop(!0,!0),s&&t.datepicker._datepickerShowing&&t.datepicker._hideDatepicker(t.datepicker._curInst.input[0])),n=t.datepicker._get(s,"beforeShow"),o=n?n.apply(e,[e,s]):{},o!==!1&&(a(s.settings,o),s.lastVal=null,t.datepicker._lastInput=e,t.datepicker._setDateFromField(s),t.datepicker._inDialog&&(e.value=""),t.datepicker._pos||(t.datepicker._pos=t.datepicker._findPos(e),t.datepicker._pos[1]+=e.offsetHeight),r=!1,t(e).parents().each(function(){return r|="fixed"===t(this).css("position"),!r}),h={left:t.datepicker._pos[0],top:t.datepicker._pos[1]},t.datepicker._pos=null,s.dpDiv.empty(),s.dpDiv.css({position:"absolute",display:"block",top:"-1000px"}),t.datepicker._updateDatepicker(s),h=t.datepicker._checkOffset(s,h,r),s.dpDiv.css({position:t.datepicker._inDialog&&t.blockUI?"static":r?"fixed":"absolute",display:"none",left:h.left+"px",top:h.top+"px"}),s.inline||(l=t.datepicker._get(s,"showAnim"),c=t.datepicker._get(s,"duration"),s.dpDiv.css("z-index",i(t(e))+1),t.datepicker._datepickerShowing=!0,t.effects&&t.effects.effect[l]?s.dpDiv.show(l,t.datepicker._get(s,"showOptions"),c):s.dpDiv[l||"show"](l?c:null),t.datepicker._shouldFocusInput(s)&&s.input.trigger("focus"),t.datepicker._curInst=s))
9
- }},_updateDatepicker:function(e){this.maxRows=4,m=e,e.dpDiv.empty().append(this._generateHTML(e)),this._attachHandlers(e);var i,s=this._getNumberOfMonths(e),n=s[1],a=17,r=e.dpDiv.find("."+this._dayOverClass+" a");r.length>0&&o.apply(r.get(0)),e.dpDiv.removeClass("ui-datepicker-multi-2 ui-datepicker-multi-3 ui-datepicker-multi-4").width(""),n>1&&e.dpDiv.addClass("ui-datepicker-multi-"+n).css("width",a*n+"em"),e.dpDiv[(1!==s[0]||1!==s[1]?"add":"remove")+"Class"]("ui-datepicker-multi"),e.dpDiv[(this._get(e,"isRTL")?"add":"remove")+"Class"]("ui-datepicker-rtl"),e===t.datepicker._curInst&&t.datepicker._datepickerShowing&&t.datepicker._shouldFocusInput(e)&&e.input.trigger("focus"),e.yearshtml&&(i=e.yearshtml,setTimeout(function(){i===e.yearshtml&&e.yearshtml&&e.dpDiv.find("select.ui-datepicker-year:first").replaceWith(e.yearshtml),i=e.yearshtml=null},0))},_shouldFocusInput:function(t){return t.input&&t.input.is(":visible")&&!t.input.is(":disabled")&&!t.input.is(":focus")},_checkOffset:function(e,i,s){var n=e.dpDiv.outerWidth(),o=e.dpDiv.outerHeight(),a=e.input?e.input.outerWidth():0,r=e.input?e.input.outerHeight():0,h=document.documentElement.clientWidth+(s?0:t(document).scrollLeft()),l=document.documentElement.clientHeight+(s?0:t(document).scrollTop());return i.left-=this._get(e,"isRTL")?n-a:0,i.left-=s&&i.left===e.input.offset().left?t(document).scrollLeft():0,i.top-=s&&i.top===e.input.offset().top+r?t(document).scrollTop():0,i.left-=Math.min(i.left,i.left+n>h&&h>n?Math.abs(i.left+n-h):0),i.top-=Math.min(i.top,i.top+o>l&&l>o?Math.abs(o+r):0),i},_findPos:function(e){for(var i,s=this._getInst(e),n=this._get(s,"isRTL");e&&("hidden"===e.type||1!==e.nodeType||t.expr.filters.hidden(e));)e=e[n?"previousSibling":"nextSibling"];return i=t(e).offset(),[i.left,i.top]},_hideDatepicker:function(e){var i,s,n,o,a=this._curInst;!a||e&&a!==t.data(e,"datepicker")||this._datepickerShowing&&(i=this._get(a,"showAnim"),s=this._get(a,"duration"),n=function(){t.datepicker._tidyDialog(a)},t.effects&&(t.effects.effect[i]||t.effects[i])?a.dpDiv.hide(i,t.datepicker._get(a,"showOptions"),s,n):a.dpDiv["slideDown"===i?"slideUp":"fadeIn"===i?"fadeOut":"hide"](i?s:null,n),i||n(),this._datepickerShowing=!1,o=this._get(a,"onClose"),o&&o.apply(a.input?a.input[0]:null,[a.input?a.input.val():"",a]),this._lastInput=null,this._inDialog&&(this._dialogInput.css({position:"absolute",left:"0",top:"-100px"}),t.blockUI&&(t.unblockUI(),t("body").append(this.dpDiv))),this._inDialog=!1)},_tidyDialog:function(t){t.dpDiv.removeClass(this._dialogClass).off(".ui-datepicker-calendar")},_checkExternalClick:function(e){if(t.datepicker._curInst){var i=t(e.target),s=t.datepicker._getInst(i[0]);(i[0].id!==t.datepicker._mainDivId&&0===i.parents("#"+t.datepicker._mainDivId).length&&!i.hasClass(t.datepicker.markerClassName)&&!i.closest("."+t.datepicker._triggerClass).length&&t.datepicker._datepickerShowing&&(!t.datepicker._inDialog||!t.blockUI)||i.hasClass(t.datepicker.markerClassName)&&t.datepicker._curInst!==s)&&t.datepicker._hideDatepicker()}},_adjustDate:function(e,i,s){var n=t(e),o=this._getInst(n[0]);this._isDisabledDatepicker(n[0])||(this._adjustInstDate(o,i+("M"===s?this._get(o,"showCurrentAtPos"):0),s),this._updateDatepicker(o))},_gotoToday:func