WP Maintenance Mode - Version 1.8.8

Version Description

(06/05/2013) = * Fix path to localized flash content * Fix preview function * Add ukrainian translation * Add czech translation * Fix exclude function for IP * Security fix for save status via Ajax

Download this release

Release Info

Developer Bueltge
Plugin Icon 128x128 WP Maintenance Mode
Version 1.8.8
Comparing to
See all releases

Code changes from version 1.8.7 to 1.8.8

css/jquery.countdown.css CHANGED
@@ -1,51 +1,51 @@
1
- /* jQuery Countdown styles 1.5.11. */
2
- .hasCountdown {
3
- border: 1px solid #ccc;
4
- background-color: #eee;
5
- }
6
- .countdown_rtl {
7
- direction: rtl;
8
- }
9
- .countdown_holding span {
10
- background-color: #ccc;
11
- }
12
- .countdown_row {
13
- clear: both;
14
- width: 100%;
15
- padding: 0px 2px;
16
- text-align: center;
17
- }
18
- .countdown_show1 .countdown_section {
19
- width: 98%;
20
- }
21
- .countdown_show2 .countdown_section {
22
- width: 48%;
23
- }
24
- .countdown_show3 .countdown_section {
25
- width: 32.5%;
26
- }
27
- .countdown_show4 .countdown_section {
28
- width: 24.5%;
29
- }
30
- .countdown_show5 .countdown_section {
31
- width: 19.5%;
32
- }
33
- .countdown_show6 .countdown_section {
34
- width: 16.25%;
35
- }
36
- .countdown_show7 .countdown_section {
37
- width: 14%;
38
- }
39
- .countdown_section {
40
- display: block;
41
- float: left;
42
- font-size: 75%;
43
- text-align: center;
44
- }
45
- .countdown_amount {
46
- font-size: 200%;
47
- }
48
- .countdown_descr {
49
- display: block;
50
- width: 100%;
51
- }
1
+ /* jQuery Countdown styles 1.5.11. */
2
+ .hasCountdown {
3
+ border: 1px solid #ccc;
4
+ background-color: #eee;
5
+ }
6
+ .countdown_rtl {
7
+ direction: rtl;
8
+ }
9
+ .countdown_holding span {
10
+ background-color: #ccc;
11
+ }
12
+ .countdown_row {
13
+ clear: both;
14
+ width: 100%;
15
+ padding: 0px 2px;
16
+ text-align: center;
17
+ }
18
+ .countdown_show1 .countdown_section {
19
+ width: 98%;
20
+ }
21
+ .countdown_show2 .countdown_section {
22
+ width: 48%;
23
+ }
24
+ .countdown_show3 .countdown_section {
25
+ width: 32.5%;
26
+ }
27
+ .countdown_show4 .countdown_section {
28
+ width: 24.5%;
29
+ }
30
+ .countdown_show5 .countdown_section {
31
+ width: 19.5%;
32
+ }
33
+ .countdown_show6 .countdown_section {
34
+ width: 16.25%;
35
+ }
36
+ .countdown_show7 .countdown_section {
37
+ width: 14%;
38
+ }
39
+ .countdown_section {
40
+ display: block;
41
+ float: left;
42
+ font-size: 75%;
43
+ text-align: center;
44
+ }
45
+ .countdown_amount {
46
+ font-size: 200%;
47
+ }
48
+ .countdown_descr {
49
+ display: block;
50
+ width: 100%;
51
+ }
css/style.css CHANGED
@@ -1,36 +1,36 @@
1
- #wm_config_tr, #wm_config_tr td {
2
- padding: 0;
3
- }
4
-
5
- #wm_config_row {
6
- margin: 10px;
7
- }
8
-
9
- .config_hidden {
10
- display: none;
11
- }
12
-
13
- #wm_message, #wm_message_update, #wm_message_active, #wm_message_active2, #wm_message_update2 {
14
- display: none;
15
- }
16
-
17
- #wphead #mm_in_admin_header {
18
- font: normal 11px Georgia, "Times New Roman", "Bitstream Charter", Times, serif;
19
- line-height: 17px;
20
- padding: 17px 0 0 0;
21
- float: left;
22
- color: #464646;
23
- }
24
- #wphead a#mm_in_admin_header:hover {
25
- text-decoration: underline;
26
- }
27
- /*
28
- .plugins-php #TB_window, .plugins-php #TB_window iframe {
29
- width: 96% !important;
30
- left: 1% !important;
31
- margin-left: 1% !important;
32
- }
33
- .plugins-php #TB_window iframe {
34
- width: 99% !important;
35
- }
36
  */
1
+ #wm_config_tr, #wm_config_tr td {
2
+ padding: 0;
3
+ }
4
+
5
+ #wm_config_row {
6
+ margin: 10px;
7
+ }
8
+
9
+ .config_hidden {
10
+ display: none;
11
+ }
12
+
13
+ #wm_message, #wm_message_update, #wm_message_active, #wm_message_active2, #wm_message_update2 {
14
+ display: none;
15
+ }
16
+
17
+ #wphead #mm_in_admin_header {
18
+ font: normal 11px Georgia, "Times New Roman", "Bitstream Charter", Times, serif;
19
+ line-height: 17px;
20
+ padding: 17px 0 0 0;
21
+ float: left;
22
+ color: #464646;
23
+ }
24
+ #wphead a#mm_in_admin_header:hover {
25
+ text-decoration: underline;
26
+ }
27
+ /*
28
+ .plugins-php #TB_window, .plugins-php #TB_window iframe {
29
+ width: 96% !important;
30
+ left: 1% !important;
31
+ margin-left: 1% !important;
32
+ }
33
+ .plugins-php #TB_window iframe {
34
+ width: 99% !important;
35
+ }
36
  */
inc/login-form.php CHANGED
@@ -1,57 +1,57 @@
1
- <?php
2
- /**
3
- * WordPress Login Form
4
- *
5
- * @since 11/25/2012
6
- * @uses [loginform redirect="http://my-redirect-url.com"]
7
- */
8
-
9
- class WPMaintenanceMode_Login_Form extends WPMaintenanceMode {
10
-
11
- public function __construct() {
12
-
13
- add_shortcode( 'loginform', array( $this, 'login_form_shortcode' ) );
14
- }
15
-
16
- public static function get_options() {
17
-
18
- return parent::get_options();
19
- }
20
-
21
- /**
22
- * Get a default login form
23
- *
24
- * @param $atts Array
25
- * @param $content String
26
- */
27
- public function login_form_shortcode( $atts, $content = NULL ) {
28
-
29
- $value = $this->get_options();
30
-
31
- extract( shortcode_atts(
32
- array(
33
- 'redirect' => ''
34
- ),
35
- $atts
36
- ) );
37
-
38
- // set default link
39
- if ( '' == get_permalink() )
40
- $redirect_default_url = home_url( '/' );
41
-
42
- if ( ! isset( $value['rewrite'] ) || empty( $value['rewrite'] ) )
43
- $redirect_url = $redirect_default_url;
44
- else
45
- $redirect_url = $value['rewrite'];
46
-
47
- $form = wp_login_form( array(
48
- 'echo' => FALSE,
49
- 'redirect' => $redirect_url
50
- ) );
51
-
52
- return $form;
53
- }
54
-
55
- } // end class
56
- new WPMaintenanceMode_Login_Form();
57
-
1
+ <?php
2
+ /**
3
+ * WordPress Login Form
4
+ *
5
+ * @since 11/25/2012
6
+ * @uses [loginform redirect="http://my-redirect-url.com"]
7
+ */
8
+
9
+ class WPMaintenanceMode_Login_Form extends WPMaintenanceMode {
10
+
11
+ public function __construct() {
12
+
13
+ add_shortcode( 'loginform', array( $this, 'login_form_shortcode' ) );
14
+ }
15
+
16
+ public static function get_options() {
17
+
18
+ return parent::get_options();
19
+ }
20
+
21
+ /**
22
+ * Get a default login form
23
+ *
24
+ * @param $atts Array
25
+ * @param $content String
26
+ */
27
+ public function login_form_shortcode( $atts, $content = NULL ) {
28
+
29
+ $value = $this->get_options();
30
+
31
+ extract( shortcode_atts(
32
+ array(
33
+ 'redirect' => ''
34
+ ),
35
+ $atts
36
+ ) );
37
+
38
+ // set default link
39
+ if ( '' == get_permalink() )
40
+ $redirect_default_url = home_url( '/' );
41
+
42
+ if ( ! isset( $value['rewrite'] ) || empty( $value['rewrite'] ) )
43
+ $redirect_url = $redirect_default_url;
44
+ else
45
+ $redirect_url = $value['rewrite'];
46
+
47
+ $form = wp_login_form( array(
48
+ 'echo' => FALSE,
49
+ 'redirect' => $redirect_url
50
+ ) );
51
+
52
+ return $form;
53
+ }
54
+
55
+ } // end class
56
+ new WPMaintenanceMode_Login_Form();
57
+
inc/wp-maintenance-mode-settings.php CHANGED
@@ -1,441 +1,441 @@
1
- <?php
2
- /**
3
- * Settings markup
4
- *
5
- * @since 09/20/2012
6
- */
7
- class WPMaintenanceMode_Settings {
8
-
9
- protected static $classobj;
10
-
11
- public function __construct() {
12
-
13
- if ( ! is_admin() )
14
- return;
15
-
16
- if ( is_multisite() && is_plugin_active_for_network( plugin_basename( FB_WM_BASENAME ) ) ) {
17
- // multisite install
18
- add_filter( 'network_admin_plugin_action_links', array( $this, 'add_settings_link' ), 10, 2 );
19
- add_action( 'after_plugin_row_' . FB_WM_BASENAME, array( 'WPMaintenanceMode_Settings', 'add_config_form'), 10, 3 );
20
- } else {
21
- // Single mode install of WP
22
- if ( version_compare( $GLOBALS['wp_version'], '2.7alpha', '>' ) ) {
23
- add_action( 'after_plugin_row_' . FB_WM_BASENAME, array( 'WPMaintenanceMode_Settings', 'add_config_form'), 10, 3 );
24
- add_filter( 'plugin_action_links_' . FB_WM_BASENAME, array( $this, 'add_settings_link' ), 10, 2 );
25
- } else {
26
- add_action( 'after_plugin_row', array( 'WPMaintenanceMode_Settings', 'add_config_form'), 10, 3 );
27
- add_filter( 'plugin_action_links', array( $this, 'add_settings_link' ), 10, 2 );
28
- }
29
- }
30
-
31
- wp_enqueue_style( 'wp-maintenance-mode-options', plugin_dir_url( FB_WM_BASENAME ) . 'css/style.css' );
32
- }
33
-
34
- /**
35
- * Handler for the action 'init'. Instantiates this class.
36
- *
37
- * @since 2.0.0
38
- * @access public
39
- * @return $classobj
40
- */
41
- public static function get_object() {
42
-
43
- if ( NULL === self :: $classobj ) {
44
- self :: $classobj = new self;
45
- }
46
-
47
- return self :: $classobj;
48
- }
49
-
50
- function add_settings_link( $links, $file ) {
51
-
52
- if ( plugin_basename( FB_WM_BASENAME ) == $file )
53
- array_unshift(
54
- $links,
55
- sprintf( '<a id="wm-pluginconflink" href="javascript:void(0)" title="Configure this plugin">%s</a>', __('Settings') )
56
- );
57
-
58
- return $links;
59
- }
60
-
61
-
62
- function network_admin_add_settings_link( $links, $file ) {
63
-
64
- if ( plugin_basename( FB_WM_BASENAME ) == $file )
65
- $links[] = '<a id="wm-pluginconflink" href="javascript:void(0)" title="Configure this plugin">' . __('Settings') . '</a>';
66
-
67
- return $links;
68
- }
69
-
70
- /**
71
- * Add settings markup
72
- *
73
- * @param $wm_pluginfile Object
74
- * @param $wm_plugindata Object (array)
75
- * @param $wm_context Object (all, active, inactive)
76
- * @return void
77
- */
78
- public function add_config_form( $wm_pluginfile, $wm_plugindata, $wm_context ) {
79
- global $wp_roles;
80
-
81
- //if ( 0 < count($_POST['checked']) )
82
- // return;
83
-
84
- if ( is_multisite() && is_plugin_active_for_network( FB_WM_BASENAME ) )
85
- $value = get_site_option( FB_WM_TEXTDOMAIN );
86
- else
87
- $value = get_option( FB_WM_TEXTDOMAIN );
88
-
89
- // check the additional settings
90
- if ( ! isset( $value['notice'] ) )
91
- $value['notice'] = 1;
92
- if ( ! isset( $value['bypass'] ) )
93
- $value['bypass'] = 0;
94
- ?>
95
- <tr id="wm_config_tr" >
96
- <td colspan="3">
97
-
98
- <div id="wm_config_row" class="<?php echo ( isset($_GET['show']) && 'wmconfig' == $_GET['show'] ) ? '' : 'config_hidden' ;?>">
99
- <div class="updated fade" id="wm_message_update" style="background-color: #FFFBCC;">
100
- <p><?php echo sprintf( __( 'Plugin %s settings <strong>updated</strong>.', FB_WM_TEXTDOMAIN ), $wm_plugindata['Name'] ); ?></p>
101
- </div>
102
- <div class="error fade" id="wm_message_active" >
103
- <p><?php echo sprintf( __( 'Plugin %s active status <strong>updated</strong>.', FB_WM_TEXTDOMAIN ), $wm_plugindata['Name'] ); ?></p>
104
- </div>
105
-
106
- <h4><?php _e( 'Plugin Activate', FB_WM_TEXTDOMAIN ); ?></h4>
107
- <input type="hidden" name="wm_action" value="wm_config-active" />
108
- <p>
109
- <select name="wm_config-active" id="wm_config-active">
110
- <option value="0"<?php if ( isset($value['active']) && 0 === $value['active'] ) { echo ' selected="selected"'; } ?>><?php _e('False', FB_WM_TEXTDOMAIN ); ?> </option>
111
- <option value="1"<?php if ( isset($value['active']) && 1 === $value['active'] ) { echo ' selected="selected"'; } ?>><?php _e('True', FB_WM_TEXTDOMAIN ); ?> </option>
112
- </select>
113
- <input id="wm_config_active" type="button" value="<?php _e( 'Update', FB_WM_TEXTDOMAIN ); ?>" class="button-primary" />
114
- </p>
115
- <div class="plugin-update-tr">
116
- <p id="wm_message_active2" class="update-message"><?php echo sprintf( __( 'Plugin %s active status <strong>updated</strong>.', FB_WM_TEXTDOMAIN ), $wm_plugindata['Name'] ); ?></p>
117
- </div>
118
-
119
- <h4><?php _e( 'Plugin Settings', FB_WM_TEXTDOMAIN ); ?></h4>
120
- <input type="hidden" name="wm_action" value="wm_config-update" />
121
-
122
- <table class="form-table">
123
- <tr valign="top">
124
- <th scope="row">
125
- <label for="wm_config-radio"><?php _e( 'Countdown:', FB_WM_TEXTDOMAIN ); ?></label>
126
- </th>
127
- <td>
128
- <select name="wm_config-radio" id="wm_config-radio">
129
- <option value="0" <?php selected( $value['radio'], 0 ); ?>><?php _e('False', FB_WM_TEXTDOMAIN ); ?> </option>
130
- <option value="1" <?php selected( $value['radio'], 1 ); ?>><?php _e('True', FB_WM_TEXTDOMAIN ); ?> </option>
131
- </select>
132
- </td>
133
- </tr>
134
- <tr valign="top">
135
- <th scope="row">
136
- <label for="wm_config-date" title="<?php _e( 'Click for datepicker', FB_WM_TEXTDOMAIN ); ?>"><?php _e( 'Date:', FB_WM_TEXTDOMAIN ); ?></label>
137
- </th>
138
- <td>
139
- <input size="30" title="<?php _e( 'Click for datepicker', FB_WM_TEXTDOMAIN ); ?>" type="text" id="wm_config-date" name="wm_config-date" value="<?php if ( isset($value['date']) ) echo $value['date']; ?>" /><br />
140
- <small><?php _e( 'Activate countdown for using this. Use value and unit or use the countdown and set the date.', FB_WM_TEXTDOMAIN ); ?></small>
141
- </td>
142
- </tr>
143
- <tr valign="top">
144
- <th scope="row">
145
- <label for="wm_config-time"><?php _e( 'Value:', FB_WM_TEXTDOMAIN ); ?></label>
146
- </th>
147
- <td class="alternate">
148
- <input size="5" type="text" id="wm_config-time" name="wm_config-time" value="<?php if( isset($value['time']) ) echo $value['time']; ?>" />
149
- </td>
150
- </tr>
151
- <tr valign="top">
152
- <th scope="row">
153
- <label for="wm_config-unit"><?php _e( 'Unit:', FB_WM_TEXTDOMAIN ); ?></label>
154
- </th>
155
- <td class="alternate">
156
- <select name="wm_config-unit" id="wm_config-unit">
157
- <option value="0" <?php selected( $value['unit'], 0 ); ?>><?php _e('second', FB_WM_TEXTDOMAIN ); ?> </option>
158
- <option value="1" <?php selected( $value['unit'], 1 ); ?>><?php _e('minute', FB_WM_TEXTDOMAIN ); ?> </option>
159
- <option value="2" <?php selected( $value['unit'], 2 ); ?>><?php _e('hour', FB_WM_TEXTDOMAIN ); ?> </option>
160
- <option value="3" <?php selected( $value['unit'], 3 ); ?>><?php _e('day', FB_WM_TEXTDOMAIN ); ?> </option>
161
- <option value="4" <?php selected( $value['unit'], 4 ); ?>><?php _e('week', FB_WM_TEXTDOMAIN ); ?> </option>
162
- <option value="5" <?php selected( $value['unit'], 5 ); ?>><?php _e('month', FB_WM_TEXTDOMAIN ); ?> </option>
163
- <option value="6" <?php selected( $value['unit'], 6 ); ?>><?php _e('year', FB_WM_TEXTDOMAIN ); ?> </option>
164
- </select>
165
- </td>
166
- </tr>
167
- <tr valign="top">
168
- <th scope="row">
169
- <label for="wm_config-link"><?php _e( 'Link:', FB_WM_TEXTDOMAIN ); ?></label>
170
- </th>
171
- <td>
172
- <select name="wm_config-link" id="wm_config-link">
173
- <option value="0" <?php selected( $value['link'], 0 ); ?>><?php _e('False', FB_WM_TEXTDOMAIN ); ?> </option>
174
- <option value="1" <?php selected( $value['link'], 1 ); ?>><?php _e('True', FB_WM_TEXTDOMAIN ); ?> </option>
175
- </select>
176
- <br />
177
- <small><?php _e( 'Please leave a link to the plugin- and design-author on your maintenance mode site.', FB_WM_TEXTDOMAIN ); ?></small>
178
- </td>
179
- </tr>
180
- <tr valign="top">
181
- <th scope="row">
182
- <label for="wm_config-admin_link"><?php _e( 'Admin Link:', FB_WM_TEXTDOMAIN ); ?></label>
183
- </th>
184
- <td>
185
- <select name="wm_config-admin_link" id="wm_config-admin_link">
186
- <option value="0" <?php selected( $value['admin_link'], 0 ); ?>><?php _e('False', FB_WM_TEXTDOMAIN ); ?> </option>
187
- <option value="1" <?php selected( $value['admin_link'], 1 ); ?>><?php _e('True', FB_WM_TEXTDOMAIN ); ?> </option>
188
- </select>
189
- <br />
190
- <small><?php _e( 'Do you will a link to the admin area of your install?', FB_WM_TEXTDOMAIN ); ?></small>
191
- </td>
192
- </tr>
193
- <tr valign="top">
194
- <th scope="row">
195
- <label for="wm_config-theme"><?php _e( 'CSS Style:', FB_WM_TEXTDOMAIN ); ?></label>
196
- </th>
197
- <td class="alternate">
198
- <select name="wm_config-theme" id="wm_config-theme">
199
- <option value="0" <?php selected( $value['theme'], 0 ); ?>><?php _e('Own CSS Stylesheet', FB_WM_TEXTDOMAIN ); ?> </option>
200
- <option value="1" <?php selected( $value['theme'], 1 ); ?>><?php _e('Simple Text', FB_WM_TEXTDOMAIN ); ?> </option>
201
- <option value="2" <?php selected( $value['theme'], 2 ); ?>><?php _e('The Truck', FB_WM_TEXTDOMAIN ); ?> </option>
202
- <option value="3" <?php selected( $value['theme'], 3 ); ?>><?php _e('The Sun', FB_WM_TEXTDOMAIN ); ?> </option>
203
- <option value="4" <?php selected( $value['theme'], 4 ); ?>><?php _e('The FF Error', FB_WM_TEXTDOMAIN ); ?> </option>
204
- <option value="5" <?php selected( $value['theme'], 5 ); ?>><?php _e('Monster', FB_WM_TEXTDOMAIN ); ?> </option>
205
- <option value="6" <?php selected( $value['theme'], 6 ); ?>><?php _e('Chastely', FB_WM_TEXTDOMAIN ); ?> </option>
206
- <option value="7" <?php selected( $value['theme'], 7 ); ?>><?php _e('Only Typo', FB_WM_TEXTDOMAIN ); ?> </option>
207
- <option value="8" <?php selected( $value['theme'], 8 ); ?>><?php _e('Paint', FB_WM_TEXTDOMAIN ); ?> </option>
208
- <option value="9" <?php selected( $value['theme'], 9 ); ?>><?php _e('Animate (Flash)', FB_WM_TEXTDOMAIN ); ?> </option>
209
- <option value="10" <?php selected( $value['theme'], 10 ); ?>><?php _e('Damask', FB_WM_TEXTDOMAIN ); ?> </option>
210
- <option value="11" <?php selected( $value['theme'], 11 ); ?>><?php _e('Lego', FB_WM_TEXTDOMAIN ); ?> </option>
211
- <option value="12" <?php selected( $value['theme'], 12 ); ?>><?php _e('Chemistry', FB_WM_TEXTDOMAIN ); ?> </option>
212
- </select>
213
- </td>
214
- </tr>
215
- <tr valign="top">
216
- <th scope="row">
217
- <label for="wm_config-styleurl"><?php _e( 'Own CSS Style URL:', FB_WM_TEXTDOMAIN ); ?></label>
218
- </th>
219
- <td class="alternate">
220
- <input size="30" type="text" id="wm_config-styleurl" name="wm_config-styleurl" value="<?php if ( isset($value['styleurl']) ) echo $value['styleurl']; ?>" /> <small><?php _e( 'URL to the css-file (incl. http://)', FB_WM_TEXTDOMAIN ); ?></small>
221
- <br />
222
- <small><?php _e( '<strong>Caution:</strong> Please don&acute;t copy the stylesheet in your plugin folder, it will be deleted on the next automatical update of the plugin!', FB_WM_TEXTDOMAIN ); ?></small>
223
- </td>
224
- </tr>
225
- <tr valign="top">
226
- <th scope="row">
227
- <label for="wm_config-preview"><?php _e( 'Preview', FB_WM_TEXTDOMAIN ); ?></label>
228
- </th>
229
- <td class="alternate" style="padding:5px 0 0 0;">
230
- <script type="text/javascript">
231
- <!--
232
- var viewportwidth,
233
- viewportheight;
234
- if (typeof window.innerWidth != 'undefined' ) {
235
- viewportwidth = window.innerWidth-80,
236
- viewportheight = window.innerHeight-100
237
- } else if (typeof document.documentElement != 'undefined'
238
- && typeof document.documentElement.clientWidth !=
239
- 'undefined' && document.documentElement.clientWidth != 0)
240
- {
241
- viewportwidth = document.documentElement.clientWidth,
242
- viewportheight = document.documentElement.clientHeight
243
- } else { // older versions of IE
244
- viewportwidth = document.getElementsByTagName('body' )[0].clientWidth,
245
- viewportheight = document.getElementsByTagName('body' )[0].clientHeight
246
- }
247
- document.write('<a onclick="return false;" href="<?php echo WP_PLUGIN_URL . '/'
248
- . FB_WM_BASEDIR; ?>/index.php?KeepThis=true&amp;TB_iframe=true&amp;height='
249
- + viewportheight + '&amp;width=' + viewportwidth
250
- + '&amp;modal=false" class="thickbox button"><?php _e( 'Preview', FB_WM_TEXTDOMAIN ); ?></a>' );
251
- //-->
252
- </script>
253
- </td>
254
- </tr>
255
- <tr valign="top">
256
- <th scope="row">
257
- <label for="wm_config-index"><?php _e( 'noindex, nofollow:', FB_WM_TEXTDOMAIN ); ?></label>
258
- </th>
259
- <td>
260
- <select name="wm_config-index" id="wm_config-index">
261
- <option value="0" <?php selected( $value['index'], 0 ); ?>><?php _e('False', FB_WM_TEXTDOMAIN ); ?> </option>
262
- <option value="1" <?php selected( $value['index'], 1 ); ?>><?php _e('True', FB_WM_TEXTDOMAIN ); ?> </option>
263
- </select>
264
- <br />
265
- <small><?php _e( 'The robots meta tag lets you utilize a granular, page-specific approach to controlling how an individual page should be indexed and served to users in search results. Set TRUE for noindex, nofollow; set FALSE for index, follow.', FB_WM_TEXTDOMAIN ); ?></small>
266
- </td>
267
- </tr>
268
- <tr valign="top">
269
- <th scope="row">
270
- <label for="wm_config-title"><?php _e( 'Title:', FB_WM_TEXTDOMAIN ); ?></label>
271
- </th>
272
- <td>
273
- <input size="30" type="text" id="wm_config-title" name="wm_config-title" value="<?php if ( isset($value['title']) ) echo $value['title']; ?>" /> <small><?php _e( 'Leave empty for default.', FB_WM_TEXTDOMAIN ); ?></small>
274
- </td>
275
- </tr>
276
- <tr valign="top">
277
- <th scope="row">
278
- <label for="wm_config-header"><?php _e( 'Header:', FB_WM_TEXTDOMAIN ); ?></label>
279
- </th>
280
- <td class="alternate">
281
- <input size="30" type="text" id="wm_config-header" name="wm_config-header" value="<?php if ( isset($value['header']) ) echo $value['header']; ?>" /> <small><?php _e( 'Leave empty for default.', FB_WM_TEXTDOMAIN ); ?></small>
282
- </td>
283
- </tr>
284
- <tr valign="top">
285
- <th scope="row">
286
- <label for="wm_config-heading"><?php _e( 'Heading:', FB_WM_TEXTDOMAIN ); ?></label>
287
- </th>
288
- <td>
289
- <input size="30" type="text" id="wm_config-heading" name="wm_config-heading" value="<?php if ( isset($value['heading']) ) echo $value['heading']; ?>" /> <small><?php _e( 'Leave empty for default.', FB_WM_TEXTDOMAIN ); ?></small>
290
- </td>
291
- </tr>
292
- <tr valign="top">
293
- <th scope="row">
294
- <label for="wm_config-text"><?php _e( 'Text:', FB_WM_TEXTDOMAIN ); ?></label>
295
- </th>
296
- <td class="alternate">
297
- <textarea class="code" style="width: 95%;" cols="40" rows="4" name="wm_config-text" id="wm_config-text"><?php if ( isset($value['text']) ) echo esc_attr($value['text']); ?></textarea>
298
- <br />
299
- <small>
300
- <?php _e( 'Use the first <em>%1$s</em> for the time value or countdown and second <em>%2$s</em> for the unit of the time or countdown-value; HTML and Shortcodes are possible.', FB_WM_TEXTDOMAIN ); ?>
301
- <?php _e( 'Use <code>[loginform]</code> for add the default login form in the maintenance page.', FB_WM_TEXTDOMAIN ); ?>
302
- </small>
303
- </td>
304
- </tr>
305
- <tr valign="top">
306
- <th scope="row">
307
- <label for="wm_config-exclude"><?php _e( 'Exclude:', FB_WM_TEXTDOMAIN ); ?></label>
308
- </th>
309
- <td>
310
- <?php
311
- if ( isset($value['exclude']) && '' !== $value['exclude'][0] ) {
312
- if ( is_array( $value['exclude'] ) && 1 <= count($value['exclude']) ) {
313
- $value_exclude = implode( ', ', $value['exclude'] );
314
- } else {
315
- $value_exclude = $value['exclude'];
316
- }
317
- } else {
318
- $value_exclude = NULL;
319
- }
320
- ?>
321
- <input class="large-text" size="30" type="text" id="wm_config-exclude" name="wm_config-exclude" value="<?php echo $value_exclude; ?>" />
322
- <br />
323
- <small><?php _e( 'Exclude feed, pages, posts, archives or IPs from the maintenance mode. Add the Slug of page or post as a comma-separated list.<br />Example:', FB_WM_TEXTDOMAIN ); ?> <code>wp-cron, feed, wp-admin, ?page_id=12, about, category/test, 127.0.0.1</code></small>
324
- </td>
325
- </tr>
326
-
327
- <tr valign="top">
328
- <th scope="row">
329
- <label for="wm_config-bypass"><?php _e( 'Bypass for Search Bots:', FB_WM_TEXTDOMAIN ); ?></label>
330
- </th>
331
- <td>
332
- <select name="wm_config-bypass" id="wm_config-bypass">
333
- <option value="0" <?php selected( $value['bypass'], 0 ); ?>><?php _e('False', FB_WM_TEXTDOMAIN ); ?> </option>
334
- <option value="1" <?php selected( $value['bypass'], 1 ); ?>><?php _e('True', FB_WM_TEXTDOMAIN ); ?> </option>
335
- </select>
336
- <small><?php _e( 'Allow Search Bots to bypass maintenance mode?', FB_WM_TEXTDOMAIN ); ?></small>
337
- </td>
338
- </tr>
339
-
340
- <tr valign="top">
341
- <th scope="row">
342
- <label for="wm_config-role"><?php _e( 'Backend Role:', FB_WM_TEXTDOMAIN ); ?></label>
343
- </th>
344
- <td class="alternate">
345
- <select name="wm_config-role" id="wm_config-role">
346
- <?php
347
- // fallback
348
- if ( ! isset($value['role'][0]) )
349
- $value['role'][0] = NULL;
350
-
351
- foreach ( $wp_roles->roles as $role => $name ) {
352
- if ( function_exists('translate_user_role') )
353
- $role_name = translate_user_role( $name['name'] );
354
- elseif ( function_exists('before_last_bar') )
355
- $role_name = before_last_bar( $name['name'], 'User role' );
356
- else
357
- $role_name = strrpos( $name['name'], '|' );
358
-
359
- if ($value['role'][0] !== $role)
360
- $selected = '';
361
- else
362
- $selected = ' selected="selected"';
363
- echo '<option value="' . $role . '"' . $selected . '>' . $role_name . ' (' . $role . ')' . ' </option>';
364
- }
365
- ?>
366
- </select>
367
- <small><?php _e( 'Allowed userrole to access the backend of this blog.', FB_WM_TEXTDOMAIN ); ?>
368
- <?php if ( is_multisite() ) { _e( 'Super Admin has always access.', FB_WM_TEXTDOMAIN ); } ?></small>
369
- </td>
370
- </tr>
371
- <tr valign="top">
372
- <th scope="row">
373
- <label for="wm_config-role_frontend"><?php _e( 'Frontend Role:', FB_WM_TEXTDOMAIN ); ?></label>
374
- </th>
375
- <td class="alternate">
376
- <select name="wm_config-role_frontend" id="wm_config-role_frontend">
377
- <?php
378
- // fallback
379
- if ( ! isset($value['role_frontend'][0]) )
380
- $value['role_frontend'][0] = NULL;
381
-
382
- foreach ( $wp_roles->roles as $role_frontend => $name ) {
383
- if ( function_exists('translate_user_role') )
384
- $role_name = translate_user_role( $name['name'] );
385
- elseif ( function_exists('before_last_bar') )
386
- $role_name = before_last_bar( $name['name'], 'User role' );
387
- else
388
- $role_name = strrpos( $name['name'], '|' );
389
-
390
- if ($value['role_frontend'][0] !== $role_frontend)
391
- $selected = '';
392
- else
393
- $selected = ' selected="selected"';
394
- echo '<option value="' . $role_frontend . '"' . $selected . '>' . $role_name . ' (' . $role_frontend . ')' . ' </option>';
395
- }
396
- ?>
397
- </select>
398
- <small><?php _e( 'Allowed userrole to see the frontend of this blog.', FB_WM_TEXTDOMAIN ); ?>
399
- <?php if ( is_multisite() ) { _e( 'Super Admin has always access.', FB_WM_TEXTDOMAIN ); } ?></small>
400
- </td>
401
- </tr>
402
- <tr valign="top">
403
- <th scope="row">
404
- <label for="wm_config-rewrite"><?php _e( 'Redirection:', FB_WM_TEXTDOMAIN ); ?></label>
405
- </th>
406
- <td class="alternate">
407
- <input class="large-text" size="30" type="text" id="wm_config-rewrite" name="wm_config-rewrite" value="<?php if ( isset($value['rewrite']) ) echo $value['rewrite']; ?>" />
408
- <br />
409
- <small><?php _e( 'If you want that after the login the destination address is not standard to the dashboard, then defining a URL. (incl. http://)', FB_WM_TEXTDOMAIN ); ?></small>
410
- </td>
411
- </tr>
412
-
413
- <tr valign="top">
414
- <th scope="row">
415
- <label for="wm_config-notice"><?php _e( 'Notice:', FB_WM_TEXTDOMAIN ); ?></label>
416
- </th>
417
- <td>
418
- <select name="wm_config-notice" id="wm_config-notice">
419
- <option value="0" <?php selected( $value['notice'], 0 ); ?>><?php _e('False', FB_WM_TEXTDOMAIN ); ?> </option>
420
- <option value="1" <?php selected( $value['notice'], 1 ); ?>><?php _e('True', FB_WM_TEXTDOMAIN ); ?> </option>
421
- </select>
422
- <small><?php _e( 'Do you will see all notices, inside backend, the Admin Bar and the login screen?', FB_WM_TEXTDOMAIN ); ?></small>
423
- </td>
424
- </tr>
425
-
426
- </table>
427
- <br />
428
- <div class="plugin-update-tr">
429
- <p id="wm_message_update2" class="update-message"><?php echo sprintf( __( 'Plugin %s settings <strong>updated</strong>.', FB_WM_TEXTDOMAIN ), $wm_plugindata['Name'] ); ?></p>
430
- </div>
431
- <p id="submitbutton">
432
- <input id="wm_config_submit" type="button" value="<?php _e( 'Save', FB_WM_TEXTDOMAIN ); ?>" class="button-secondary" />
433
- </p>
434
- </div>
435
-
436
- </td>
437
- </tr>
438
- <?php
439
- }
440
-
441
- } // end class
1
+ <?php
2
+ /**
3
+ * Settings markup
4
+ *
5
+ * @since 09/20/2012
6
+ */
7
+ class WPMaintenanceMode_Settings {
8
+
9
+ protected static $classobj;
10
+
11
+ public function __construct() {
12
+
13
+ if ( ! is_admin() )
14
+ return;
15
+
16
+ if ( is_multisite() && is_plugin_active_for_network( plugin_basename( FB_WM_BASENAME ) ) ) {
17
+ // multisite install
18
+ add_filter( 'network_admin_plugin_action_links', array( $this, 'add_settings_link' ), 10, 2 );
19
+ add_action( 'after_plugin_row_' . FB_WM_BASENAME, array( 'WPMaintenanceMode_Settings', 'add_config_form'), 10, 3 );
20
+ } else {
21
+ // Single mode install of WP
22
+ if ( version_compare( $GLOBALS['wp_version'], '2.7alpha', '>' ) ) {
23
+ add_action( 'after_plugin_row_' . FB_WM_BASENAME, array( 'WPMaintenanceMode_Settings', 'add_config_form'), 10, 3 );
24
+ add_filter( 'plugin_action_links_' . FB_WM_BASENAME, array( $this, 'add_settings_link' ), 10, 2 );
25
+ } else {
26
+ add_action( 'after_plugin_row', array( 'WPMaintenanceMode_Settings', 'add_config_form'), 10, 3 );
27
+ add_filter( 'plugin_action_links', array( $this, 'add_settings_link' ), 10, 2 );
28
+ }
29
+ }
30
+
31
+ wp_enqueue_style( 'wp-maintenance-mode-options', plugin_dir_url( FB_WM_BASENAME ) . 'css/style.css' );
32
+ }
33
+
34
+ /**
35
+ * Handler for the action 'init'. Instantiates this class.
36
+ *
37
+ * @since 2.0.0
38
+ * @access public
39
+ * @return $classobj
40
+ */
41
+ public static function get_object() {
42
+
43
+ if ( NULL === self :: $classobj ) {
44
+ self :: $classobj = new self;
45
+ }
46
+
47
+ return self :: $classobj;
48
+ }
49
+
50
+ function add_settings_link( $links, $file ) {
51
+
52
+ if ( plugin_basename( FB_WM_BASENAME ) == $file )
53
+ array_unshift(
54
+ $links,
55
+ sprintf( '<a id="wm-pluginconflink" href="javascript:void(0)" title="Configure this plugin">%s</a>', __('Settings') )
56
+ );
57
+
58
+ return $links;
59
+ }
60
+
61
+
62
+ function network_admin_add_settings_link( $links, $file ) {
63
+
64
+ if ( plugin_basename( FB_WM_BASENAME ) == $file )
65
+ $links[] = '<a id="wm-pluginconflink" href="javascript:void(0)" title="Configure this plugin">' . __('Settings') . '</a>';
66
+
67
+ return $links;
68
+ }
69
+
70
+ /**
71
+ * Add settings markup
72
+ *
73
+ * @param $wm_pluginfile Object
74
+ * @param $wm_plugindata Object (array)
75
+ * @param $wm_context Object (all, active, inactive)
76
+ * @return void
77
+ */
78
+ public function add_config_form( $wm_pluginfile, $wm_plugindata, $wm_context ) {
79
+ global $wp_roles;
80
+
81
+ //if ( 0 < count($_POST['checked']) )
82
+ // return;
83
+
84
+ if ( is_multisite() && is_plugin_active_for_network( FB_WM_BASENAME ) )
85
+ $value = get_site_option( FB_WM_TEXTDOMAIN );
86
+ else
87
+ $value = get_option( FB_WM_TEXTDOMAIN );
88
+
89
+ // check the additional settings
90
+ if ( ! isset( $value['notice'] ) )
91
+ $value['notice'] = 1;
92
+ if ( ! isset( $value['bypass'] ) )
93
+ $value['bypass'] = 0;
94
+ ?>
95
+ <tr id="wm_config_tr" >
96
+ <td colspan="3">
97
+
98
+ <div id="wm_config_row" class="<?php echo ( isset($_GET['show']) && 'wmconfig' == $_GET['show'] ) ? '' : 'config_hidden' ;?>">
99
+ <div class="updated fade" id="wm_message_update" style="background-color: #FFFBCC;">
100
+ <p><?php echo sprintf( __( 'Plugin %s settings <strong>updated</strong>.', FB_WM_TEXTDOMAIN ), $wm_plugindata['Name'] ); ?></p>
101
+ </div>
102
+ <div class="error fade" id="wm_message_active" >
103
+ <p><?php echo sprintf( __( 'Plugin %s active status <strong>updated</strong>.', FB_WM_TEXTDOMAIN ), $wm_plugindata['Name'] ); ?></p>
104
+ </div>
105
+
106
+ <h4><?php _e( 'Plugin Activate', FB_WM_TEXTDOMAIN ); ?></h4>
107
+ <input type="hidden" name="wm_action" value="wm_config-active" />
108
+ <p>
109
+ <select name="wm_config-active" id="wm_config-active">
110
+ <option value="0"<?php if ( isset($value['active']) && 0 === $value['active'] ) { echo ' selected="selected"'; } ?>><?php _e('False', FB_WM_TEXTDOMAIN ); ?> </option>
111
+ <option value="1"<?php if ( isset($value['active']) && 1 === $value['active'] ) { echo ' selected="selected"'; } ?>><?php _e('True', FB_WM_TEXTDOMAIN ); ?> </option>
112
+ </select>
113
+ <input id="wm_config_active" type="button" value="<?php _e( 'Update', FB_WM_TEXTDOMAIN ); ?>" class="button-primary" />
114
+ </p>
115
+ <div class="plugin-update-tr">
116
+ <p id="wm_message_active2" class="update-message"><?php echo sprintf( __( 'Plugin %s active status <strong>updated</strong>.', FB_WM_TEXTDOMAIN ), $wm_plugindata['Name'] ); ?></p>
117
+ </div>
118
+
119
+ <h4><?php _e( 'Plugin Settings', FB_WM_TEXTDOMAIN ); ?></h4>
120
+ <input type="hidden" name="wm_action" value="wm_config-update" />
121
+
122
+ <table class="form-table">
123
+ <tr valign="top">
124
+ <th scope="row">
125
+ <label for="wm_config-radio"><?php _e( 'Countdown:', FB_WM_TEXTDOMAIN ); ?></label>
126
+ </th>
127
+ <td>
128
+ <select name="wm_config-radio" id="wm_config-radio">
129
+ <option value="0" <?php selected( $value['radio'], 0 ); ?>><?php _e('False', FB_WM_TEXTDOMAIN ); ?> </option>
130
+ <option value="1" <?php selected( $value['radio'], 1 ); ?>><?php _e('True', FB_WM_TEXTDOMAIN ); ?> </option>
131
+ </select>
132
+ </td>
133
+ </tr>
134
+ <tr valign="top">
135
+ <th scope="row">
136
+ <label for="wm_config-date" title="<?php _e( 'Click for datepicker', FB_WM_TEXTDOMAIN ); ?>"><?php _e( 'Date:', FB_WM_TEXTDOMAIN ); ?></label>
137
+ </th>
138
+ <td>
139
+ <input size="30" title="<?php _e( 'Click for datepicker', FB_WM_TEXTDOMAIN ); ?>" type="text" id="wm_config-date" name="wm_config-date" value="<?php if ( isset($value['date']) ) echo $value['date']; ?>" /><br />
140
+ <small><?php _e( 'Activate countdown for using this. Use value and unit or use the countdown and set the date.', FB_WM_TEXTDOMAIN ); ?></small>
141
+ </td>
142
+ </tr>
143
+ <tr valign="top">
144
+ <th scope="row">
145
+ <label for="wm_config-time"><?php _e( 'Value:', FB_WM_TEXTDOMAIN ); ?></label>
146
+ </th>
147
+ <td class="alternate">
148
+ <input size="5" type="text" id="wm_config-time" name="wm_config-time" value="<?php if( isset($value['time']) ) echo $value['time']; ?>" />
149
+ </td>
150
+ </tr>
151
+ <tr valign="top">
152
+ <th scope="row">
153
+ <label for="wm_config-unit"><?php _e( 'Unit:', FB_WM_TEXTDOMAIN ); ?></label>
154
+ </th>
155
+ <td class="alternate">
156
+ <select name="wm_config-unit" id="wm_config-unit">
157
+ <option value="0" <?php selected( $value['unit'], 0 ); ?>><?php _e('second', FB_WM_TEXTDOMAIN ); ?> </option>
158
+ <option value="1" <?php selected( $value['unit'], 1 ); ?>><?php _e('minute', FB_WM_TEXTDOMAIN ); ?> </option>
159
+ <option value="2" <?php selected( $value['unit'], 2 ); ?>><?php _e('hour', FB_WM_TEXTDOMAIN ); ?> </option>
160
+ <option value="3" <?php selected( $value['unit'], 3 ); ?>><?php _e('day', FB_WM_TEXTDOMAIN ); ?> </option>
161
+ <option value="4" <?php selected( $value['unit'], 4 ); ?>><?php _e('week', FB_WM_TEXTDOMAIN ); ?> </option>
162
+ <option value="5" <?php selected( $value['unit'], 5 ); ?>><?php _e('month', FB_WM_TEXTDOMAIN ); ?> </option>
163
+ <option value="6" <?php selected( $value['unit'], 6 ); ?>><?php _e('year', FB_WM_TEXTDOMAIN ); ?> </option>
164
+ </select>
165
+ </td>
166
+ </tr>
167
+ <tr valign="top">
168
+ <th scope="row">
169
+ <label for="wm_config-link"><?php _e( 'Link:', FB_WM_TEXTDOMAIN ); ?></label>
170
+ </th>
171
+ <td>
172
+ <select name="wm_config-link" id="wm_config-link">
173
+ <option value="0" <?php selected( $value['link'], 0 ); ?>><?php _e('False', FB_WM_TEXTDOMAIN ); ?> </option>
174
+ <option value="1" <?php selected( $value['link'], 1 ); ?>><?php _e('True', FB_WM_TEXTDOMAIN ); ?> </option>
175
+ </select>
176
+ <br />
177
+ <small><?php _e( 'Please leave a link to the plugin- and design-author on your maintenance mode site.', FB_WM_TEXTDOMAIN ); ?></small>
178
+ </td>
179
+ </tr>
180
+ <tr valign="top">
181
+ <th scope="row">
182
+ <label for="wm_config-admin_link"><?php _e( 'Admin Link:', FB_WM_TEXTDOMAIN ); ?></label>
183
+ </th>
184
+ <td>
185
+ <select name="wm_config-admin_link" id="wm_config-admin_link">
186
+ <option value="0" <?php selected( $value['admin_link'], 0 ); ?>><?php _e('False', FB_WM_TEXTDOMAIN ); ?> </option>
187
+ <option value="1" <?php selected( $value['admin_link'], 1 ); ?>><?php _e('True', FB_WM_TEXTDOMAIN ); ?> </option>
188
+ </select>
189
+ <br />
190
+ <small><?php _e( 'Do you will a link to the admin area of your install?', FB_WM_TEXTDOMAIN ); ?></small>
191
+ </td>
192
+ </tr>
193
+ <tr valign="top">
194
+ <th scope="row">
195
+ <label for="wm_config-theme"><?php _e( 'CSS Style:', FB_WM_TEXTDOMAIN ); ?></label>
196
+ </th>
197
+ <td class="alternate">
198
+ <select name="wm_config-theme" id="wm_config-theme">
199
+ <option value="0" <?php selected( $value['theme'], 0 ); ?>><?php _e('Own CSS Stylesheet', FB_WM_TEXTDOMAIN ); ?> </option>
200
+ <option value="1" <?php selected( $value['theme'], 1 ); ?>><?php _e('Simple Text', FB_WM_TEXTDOMAIN ); ?> </option>
201
+ <option value="2" <?php selected( $value['theme'], 2 ); ?>><?php _e('The Truck', FB_WM_TEXTDOMAIN ); ?> </option>
202
+ <option value="3" <?php selected( $value['theme'], 3 ); ?>><?php _e('The Sun', FB_WM_TEXTDOMAIN ); ?> </option>
203
+ <option value="4" <?php selected( $value['theme'], 4 ); ?>><?php _e('The FF Error', FB_WM_TEXTDOMAIN ); ?> </option>
204
+ <option value="5" <?php selected( $value['theme'], 5 ); ?>><?php _e('Monster', FB_WM_TEXTDOMAIN ); ?> </option>
205
+ <option value="6" <?php selected( $value['theme'], 6 ); ?>><?php _e('Chastely', FB_WM_TEXTDOMAIN ); ?> </option>
206
+ <option value="7" <?php selected( $value['theme'], 7 ); ?>><?php _e('Only Typo', FB_WM_TEXTDOMAIN ); ?> </option>
207
+ <option value="8" <?php selected( $value['theme'], 8 ); ?>><?php _e('Paint', FB_WM_TEXTDOMAIN ); ?> </option>
208
+ <option value="9" <?php selected( $value['theme'], 9 ); ?>><?php _e('Animate (Flash)', FB_WM_TEXTDOMAIN ); ?> </option>
209
+ <option value="10" <?php selected( $value['theme'], 10 ); ?>><?php _e('Damask', FB_WM_TEXTDOMAIN ); ?> </option>
210
+ <option value="11" <?php selected( $value['theme'], 11 ); ?>><?php _e('Lego', FB_WM_TEXTDOMAIN ); ?> </option>
211
+ <option value="12" <?php selected( $value['theme'], 12 ); ?>><?php _e('Chemistry', FB_WM_TEXTDOMAIN ); ?> </option>
212
+ </select>
213
+ </td>
214
+ </tr>
215
+ <tr valign="top">
216
+ <th scope="row">
217
+ <label for="wm_config-styleurl"><?php _e( 'Own CSS Style URL:', FB_WM_TEXTDOMAIN ); ?></label>
218
+ </th>
219
+ <td class="alternate">
220
+ <input size="30" type="text" id="wm_config-styleurl" name="wm_config-styleurl" value="<?php if ( isset($value['styleurl']) ) echo $value['styleurl']; ?>" /> <small><?php _e( 'URL to the css-file (incl. http://)', FB_WM_TEXTDOMAIN ); ?></small>
221
+ <br />
222
+ <small><?php _e( '<strong>Caution:</strong> Please don&acute;t copy the stylesheet in your plugin folder, it will be deleted on the next automatical update of the plugin!', FB_WM_TEXTDOMAIN ); ?></small>
223
+ </td>
224
+ </tr>
225
+ <tr valign="top">
226
+ <th scope="row">
227
+ <label for="wm_config-preview"><?php _e( 'Preview', FB_WM_TEXTDOMAIN ); ?></label>
228
+ </th>
229
+ <td class="alternate" style="padding:5px 0 0 0;">
230
+ <script type="text/javascript">
231
+ <!--
232
+ var viewportwidth,
233
+ viewportheight;
234
+ if (typeof window.innerWidth != 'undefined' ) {
235
+ viewportwidth = window.innerWidth-80,
236
+ viewportheight = window.innerHeight-100
237
+ } else if (typeof document.documentElement != 'undefined'
238
+ && typeof document.documentElement.clientWidth !=
239
+ 'undefined' && document.documentElement.clientWidth != 0)
240
+ {
241
+ viewportwidth = document.documentElement.clientWidth,
242
+ viewportheight = document.documentElement.clientHeight
243
+ } else { // older versions of IE
244
+ viewportwidth = document.getElementsByTagName('body' )[0].clientWidth,
245
+ viewportheight = document.getElementsByTagName('body' )[0].clientHeight
246
+ }
247
+ document.write('<a onclick="return false;" href="<?php echo WP_PLUGIN_URL . '/'
248
+ . FB_WM_BASEDIR; ?>/index.php?KeepThis=true&amp;TB_iframe=true&amp;height='
249
+ + viewportheight + '&amp;width=' + viewportwidth
250
+ + '&amp;modal=false" class="thickbox button"><?php _e( 'Preview', FB_WM_TEXTDOMAIN ); ?></a>' );
251
+ //-->
252
+ </script>
253
+ </td>
254
+ </tr>
255
+ <tr valign="top">
256
+ <th scope="row">
257
+ <label for="wm_config-index"><?php _e( 'noindex, nofollow:', FB_WM_TEXTDOMAIN ); ?></label>
258
+ </th>
259
+ <td>
260
+ <select name="wm_config-index" id="wm_config-index">
261
+ <option value="0" <?php selected( $value['index'], 0 ); ?>><?php _e('False', FB_WM_TEXTDOMAIN ); ?> </option>
262
+ <option value="1" <?php selected( $value['index'], 1 ); ?>><?php _e('True', FB_WM_TEXTDOMAIN ); ?> </option>
263
+ </select>
264
+ <br />
265
+ <small><?php _e( 'The robots meta tag lets you utilize a granular, page-specific approach to controlling how an individual page should be indexed and served to users in search results. Set TRUE for noindex, nofollow; set FALSE for index, follow.', FB_WM_TEXTDOMAIN ); ?></small>
266
+ </td>
267
+ </tr>
268
+ <tr valign="top">
269
+ <th scope="row">
270
+ <label for="wm_config-title"><?php _e( 'Title:', FB_WM_TEXTDOMAIN ); ?></label>
271
+ </th>
272
+ <td>
273
+ <input size="30" type="text" id="wm_config-title" name="wm_config-title" value="<?php if ( isset($value['title']) ) echo $value['title']; ?>" /> <small><?php _e( 'Leave empty for default.', FB_WM_TEXTDOMAIN ); ?></small>
274
+ </td>
275
+ </tr>
276
+ <tr valign="top">
277
+ <th scope="row">
278
+ <label for="wm_config-header"><?php _e( 'Header:', FB_WM_TEXTDOMAIN ); ?></label>
279
+ </th>
280
+ <td class="alternate">
281
+ <input size="30" type="text" id="wm_config-header" name="wm_config-header" value="<?php if ( isset($value['header']) ) echo $value['header']; ?>" /> <small><?php _e( 'Leave empty for default.', FB_WM_TEXTDOMAIN ); ?></small>
282
+ </td>
283
+ </tr>
284
+ <tr valign="top">
285
+ <th scope="row">
286
+ <label for="wm_config-heading"><?php _e( 'Heading:', FB_WM_TEXTDOMAIN ); ?></label>
287
+ </th>
288
+ <td>
289
+ <input size="30" type="text" id="wm_config-heading" name="wm_config-heading" value="<?php if ( isset($value['heading']) ) echo $value['heading']; ?>" /> <small><?php _e( 'Leave empty for default.', FB_WM_TEXTDOMAIN ); ?></small>
290
+ </td>
291
+ </tr>
292
+ <tr valign="top">
293
+ <th scope="row">
294
+ <label for="wm_config-text"><?php _e( 'Text:', FB_WM_TEXTDOMAIN ); ?></label>
295
+ </th>
296
+ <td class="alternate">
297
+ <textarea class="code" style="width: 95%;" cols="40" rows="4" name="wm_config-text" id="wm_config-text"><?php if ( isset($value['text']) ) echo esc_attr($value['text']); ?></textarea>
298
+ <br />
299
+ <small>
300
+ <?php _e( 'Use the first <em>%1$s</em> for the time value or countdown and second <em>%2$s</em> for the unit of the time or countdown-value; HTML and Shortcodes are possible.', FB_WM_TEXTDOMAIN ); ?>
301
+ <?php _e( 'Use <code>[loginform]</code> for add the default login form in the maintenance page.', FB_WM_TEXTDOMAIN ); ?>
302
+ </small>
303
+ </td>
304
+ </tr>
305
+ <tr valign="top">
306
+ <th scope="row">
307
+ <label for="wm_config-exclude"><?php _e( 'Exclude:', FB_WM_TEXTDOMAIN ); ?></label>
308
+ </th>
309
+ <td>
310
+ <?php
311
+ if ( isset($value['exclude']) && '' !== $value['exclude'][0] ) {
312
+ if ( is_array( $value['exclude'] ) && 1 <= count($value['exclude']) ) {
313
+ $value_exclude = implode( ', ', $value['exclude'] );
314
+ } else {
315
+ $value_exclude = $value['exclude'];
316
+ }
317
+ } else {
318
+ $value_exclude = NULL;
319
+ }
320
+ ?>
321
+ <input class="large-text" size="30" type="text" id="wm_config-exclude" name="wm_config-exclude" value="<?php echo $value_exclude; ?>" />
322
+ <br />
323
+ <small><?php _e( 'Exclude feed, pages, posts, archives or IPs from the maintenance mode. Add the Slug of page or post as a comma-separated list.<br />Example:', FB_WM_TEXTDOMAIN ); ?> <code>wp-cron, feed, wp-admin, ?page_id=12, about, category/test, 127.0.0.1</code></small>
324
+ </td>
325
+ </tr>
326
+
327
+ <tr valign="top">
328
+ <th scope="row">
329
+ <label for="wm_config-bypass"><?php _e( 'Bypass for Search Bots:', FB_WM_TEXTDOMAIN ); ?></label>
330
+ </th>
331
+ <td>
332
+ <select name="wm_config-bypass" id="wm_config-bypass">
333
+ <option value="0" <?php selected( $value['bypass'], 0 ); ?>><?php _e('False', FB_WM_TEXTDOMAIN ); ?> </option>
334
+ <option value="1" <?php selected( $value['bypass'], 1 ); ?>><?php _e('True', FB_WM_TEXTDOMAIN ); ?> </option>
335
+ </select>
336
+ <small><?php _e( 'Allow Search Bots to bypass maintenance mode?', FB_WM_TEXTDOMAIN ); ?></small>
337
+ </td>
338
+ </tr>
339
+
340
+ <tr valign="top">
341
+ <th scope="row">
342
+ <label for="wm_config-role"><?php _e( 'Backend Role:', FB_WM_TEXTDOMAIN ); ?></label>
343
+ </th>
344
+ <td class="alternate">
345
+ <select name="wm_config-role" id="wm_config-role">
346
+ <?php
347
+ // fallback
348
+ if ( ! isset($value['role'][0]) )
349
+ $value['role'][0] = NULL;
350
+
351
+ foreach ( $wp_roles->roles as $role => $name ) {
352
+ if ( function_exists('translate_user_role') )
353
+ $role_name = translate_user_role( $name['name'] );
354
+ elseif ( function_exists('before_last_bar') )
355
+ $role_name = before_last_bar( $name['name'], 'User role' );
356
+ else
357
+ $role_name = strrpos( $name['name'], '|' );
358
+
359
+ if ($value['role'][0] !== $role)
360
+ $selected = '';
361
+ else
362
+ $selected = ' selected="selected"';
363
+ echo '<option value="' . $role . '"' . $selected . '>' . $role_name . ' (' . $role . ')' . ' </option>';
364
+ }
365
+ ?>
366
+ </select>
367
+ <small><?php _e( 'Allowed userrole to access the backend of this blog.', FB_WM_TEXTDOMAIN ); ?>
368
+ <?php if ( is_multisite() ) { _e( 'Super Admin has always access.', FB_WM_TEXTDOMAIN ); } ?></small>
369
+ </td>
370
+ </tr>
371
+ <tr valign="top">
372
+ <th scope="row">
373
+ <label for="wm_config-role_frontend"><?php _e( 'Frontend Role:', FB_WM_TEXTDOMAIN ); ?></label>
374
+ </th>
375
+ <td class="alternate">
376
+ <select name="wm_config-role_frontend" id="wm_config-role_frontend">
377
+ <?php
378
+ // fallback
379
+ if ( ! isset($value['role_frontend'][0]) )
380
+ $value['role_frontend'][0] = NULL;
381
+
382
+ foreach ( $wp_roles->roles as $role_frontend => $name ) {
383
+ if ( function_exists('translate_user_role') )
384
+ $role_name = translate_user_role( $name['name'] );
385
+ elseif ( function_exists('before_last_bar') )
386
+ $role_name = before_last_bar( $name['name'], 'User role' );
387
+ else
388
+ $role_name = strrpos( $name['name'], '|' );
389
+
390
+ if ($value['role_frontend'][0] !== $role_frontend)
391
+ $selected = '';
392
+ else
393
+ $selected = ' selected="selected"';
394
+ echo '<option value="' . $role_frontend . '"' . $selected . '>' . $role_name . ' (' . $role_frontend . ')' . ' </option>';
395
+ }
396
+ ?>
397
+ </select>
398
+ <small><?php _e( 'Allowed userrole to see the frontend of this blog.', FB_WM_TEXTDOMAIN ); ?>
399
+ <?php if ( is_multisite() ) { _e( 'Super Admin has always access.', FB_WM_TEXTDOMAIN ); } ?></small>
400
+ </td>
401
+ </tr>
402
+ <tr valign="top">
403
+ <th scope="row">
404
+ <label for="wm_config-rewrite"><?php _e( 'Redirection:', FB_WM_TEXTDOMAIN ); ?></label>
405
+ </th>
406
+ <td class="alternate">
407
+ <input class="large-text" size="30" type="text" id="wm_config-rewrite" name="wm_config-rewrite" value="<?php if ( isset($value['rewrite']) ) echo $value['rewrite']; ?>" />
408
+ <br />
409
+ <small><?php _e( 'If you want that after the login the destination address is not standard to the dashboard, then defining a URL. (incl. http://)', FB_WM_TEXTDOMAIN ); ?></small>
410
+ </td>
411
+ </tr>
412
+
413
+ <tr valign="top">
414
+ <th scope="row">
415
+ <label for="wm_config-notice"><?php _e( 'Notice:', FB_WM_TEXTDOMAIN ); ?></label>
416
+ </th>
417
+ <td>
418
+ <select name="wm_config-notice" id="wm_config-notice">
419
+ <option value="0" <?php selected( $value['notice'], 0 ); ?>><?php _e('False', FB_WM_TEXTDOMAIN ); ?> </option>
420
+ <option value="1" <?php selected( $value['notice'], 1 ); ?>><?php _e('True', FB_WM_TEXTDOMAIN ); ?> </option>
421
+ </select>
422
+ <small><?php _e( 'Do you will see all notices, inside backend, the Admin Bar and the login screen?', FB_WM_TEXTDOMAIN ); ?></small>
423
+ </td>
424
+ </tr>
425
+
426
+ </table>
427
+ <br />
428
+ <div class="plugin-update-tr">
429
+ <p id="wm_message_update2" class="update-message"><?php echo sprintf( __( 'Plugin %s settings <strong>updated</strong>.', FB_WM_TEXTDOMAIN ), $wm_plugindata['Name'] ); ?></p>
430
+ </div>
431
+ <p id="submitbutton">
432
+ <input id="wm_config_submit" type="button" value="<?php _e( 'Save', FB_WM_TEXTDOMAIN ); ?>" class="button-secondary" />
433
+ </p>
434
+ </div>
435
+
436
+ </td>
437
+ </tr>
438
+ <?php
439
+ }
440
+
441
+ } // end class
index.php CHANGED
@@ -1,30 +1,30 @@
1
- <?php
2
-
3
- if ( ! function_exists( 'fb_find_wp_config_path' ) ) {
4
- function fb_find_wp_config_path() {
5
-
6
- $dir = dirname(__FILE__);
7
-
8
- do {
9
- if( file_exists( $dir . "/wp-config.php" ) ) {
10
- return $dir;
11
- var_dump($dir);
12
- }
13
- } while ( $dir = realpath( "$dir/.." ) );
14
-
15
- return NULL;
16
- }
17
- }
18
-
19
- if ( ! defined( 'ABSPATH' ) ) {
20
- define( 'WP_USE_THEMES', FALSE );
21
- require_once( fb_find_wp_config_path() . '/wp-config.php' );
22
- }
23
-
24
- if( ! defined( 'ABSPATH' ) || ! current_user_can('unfiltered_html') ) {
25
- wp_die( __('Cheatin&#8217; uh?') );
26
- exit;
27
- }
28
- // Allow alternative splash page
29
- if ( ! file_exists( WP_CONTENT_DIR . '/wp-maintenance-mode.php' ) )
30
- include 'site.php';
1
+ <?php
2
+
3
+ if ( ! function_exists( 'fb_find_wp_config_path' ) ) {
4
+ function fb_find_wp_config_path() {
5
+
6
+ $dir = dirname(__FILE__);
7
+
8
+ do {
9
+ if( file_exists( $dir . "/wp-config.php" ) ) {
10
+ return $dir;
11
+ var_dump($dir);
12
+ }
13
+ } while ( $dir = realpath( "$dir/.." ) );
14
+
15
+ return NULL;
16
+ }
17
+ }
18
+
19
+ if ( ! defined( 'ABSPATH' ) ) {
20
+ define( 'WP_USE_THEMES', FALSE );
21
+ require_once( fb_find_wp_config_path() . '/wp-config.php' );
22
+ }
23
+
24
+ if( ! defined( 'ABSPATH' ) || ! current_user_can('unfiltered_html') ) {
25
+ wp_die( __('Cheatin&#8217; uh?') );
26
+ exit;
27
+ }
28
+ // Allow alternative splash page
29
+ if ( ! file_exists( WP_CONTENT_DIR . '/wp-maintenance-mode.php' ) )
30
+ include 'site.php';
js/jquery-ui-timepicker-addon.js CHANGED
@@ -1,1919 +1,1919 @@
1
- /*
2
- * jQuery timepicker addon
3
- * By: Trent Richardson [http://trentrichardson.com]
4
- * Version 1.2
5
- * Last Modified: 02/02/2013
6
- *
7
- * Copyright 2013 Trent Richardson
8
- * You may use this project under MIT or GPL licenses.
9
- * http://trentrichardson.com/Impromptu/GPL-LICENSE.txt
10
- * http://trentrichardson.com/Impromptu/MIT-LICENSE.txt
11
- */
12
-
13
- /*jslint evil: true, white: false, undef: false, nomen: false */
14
-
15
- (function($) {
16
-
17
- /*
18
- * Lets not redefine timepicker, Prevent "Uncaught RangeError: Maximum call stack size exceeded"
19
- */
20
- $.ui.timepicker = $.ui.timepicker || {};
21
- if ($.ui.timepicker.version) {
22
- return;
23
- }
24
-
25
- /*
26
- * Extend jQueryUI, get it started with our version number
27
- */
28
- $.extend($.ui, {
29
- timepicker: {
30
- version: "1.2"
31
- }
32
- });
33
-
34
- /*
35
- * Timepicker manager.
36
- * Use the singleton instance of this class, $.timepicker, to interact with the time picker.
37
- * Settings for (groups of) time pickers are maintained in an instance object,
38
- * allowing multiple different settings on the same page.
39
- */
40
- var Timepicker = function() {
41
- this.regional = []; // Available regional settings, indexed by language code
42
- this.regional[''] = { // Default regional settings
43
- currentText: 'Now',
44
- closeText: 'Done',
45
- amNames: ['AM', 'A'],
46
- pmNames: ['PM', 'P'],
47
- timeFormat: 'HH:mm',
48
- timeSuffix: '',
49
- timeOnlyTitle: 'Choose Time',
50
- timeText: 'Time',
51
- hourText: 'Hour',
52
- minuteText: 'Minute',
53
- secondText: 'Second',
54
- millisecText: 'Millisecond',
55
- timezoneText: 'Time Zone',
56
- isRTL: false
57
- };
58
- this._defaults = { // Global defaults for all the datetime picker instances
59
- showButtonPanel: true,
60
- timeOnly: false,
61
- showHour: true,
62
- showMinute: true,
63
- showSecond: false,
64
- showMillisec: false,
65
- showTimezone: false,
66
- showTime: true,
67
- stepHour: 1,
68
- stepMinute: 1,
69
- stepSecond: 1,
70
- stepMillisec: 1,
71
- hour: 0,
72
- minute: 0,
73
- second: 0,
74
- millisec: 0,
75
- timezone: null,
76
- useLocalTimezone: false,
77
- defaultTimezone: "+0000",
78
- hourMin: 0,
79
- minuteMin: 0,
80
- secondMin: 0,
81
- millisecMin: 0,
82
- hourMax: 23,
83
- minuteMax: 59,
84
- secondMax: 59,
85
- millisecMax: 999,
86
- minDateTime: null,
87
- maxDateTime: null,
88
- onSelect: null,
89
- hourGrid: 0,
90
- minuteGrid: 0,
91
- secondGrid: 0,
92
- millisecGrid: 0,
93
- alwaysSetTime: true,
94
- separator: ' ',
95
- altFieldTimeOnly: true,
96
- altTimeFormat: null,
97
- altSeparator: null,
98
- altTimeSuffix: null,
99
- pickerTimeFormat: null,
100
- pickerTimeSuffix: null,
101
- showTimepicker: true,
102
- timezoneIso8601: false,
103
- timezoneList: null,
104
- addSliderAccess: false,
105
- sliderAccessArgs: null,
106
- controlType: 'slider',
107
- defaultValue: null,
108
- parse: 'strict'
109
- };
110
- $.extend(this._defaults, this.regional['']);
111
- };
112
-
113
- $.extend(Timepicker.prototype, {
114
- $input: null,
115
- $altInput: null,
116
- $timeObj: null,
117
- inst: null,
118
- hour_slider: null,
119
- minute_slider: null,
120
- second_slider: null,
121
- millisec_slider: null,
122
- timezone_select: null,
123
- hour: 0,
124
- minute: 0,
125
- second: 0,
126
- millisec: 0,
127
- timezone: null,
128
- defaultTimezone: "+0000",
129
- hourMinOriginal: null,
130
- minuteMinOriginal: null,
131
- secondMinOriginal: null,
132
- millisecMinOriginal: null,
133
- hourMaxOriginal: null,
134
- minuteMaxOriginal: null,
135
- secondMaxOriginal: null,
136
- millisecMaxOriginal: null,
137
- ampm: '',
138
- formattedDate: '',
139
- formattedTime: '',
140
- formattedDateTime: '',
141
- timezoneList: null,
142
- units: ['hour','minute','second','millisec'],
143
- control: null,
144
-
145
- /*
146
- * Override the default settings for all instances of the time picker.
147
- * @param settings object - the new settings to use as defaults (anonymous object)
148
- * @return the manager object
149
- */
150
- setDefaults: function(settings) {
151
- extendRemove(this._defaults, settings || {});
152
- return this;
153
- },
154
-
155
- /*
156
- * Create a new Timepicker instance
157
- */
158
- _newInst: function($input, o) {
159
- var tp_inst = new Timepicker(),
160
- inlineSettings = {},
161
- fns = {},
162
- overrides, i;
163
-
164
- for (var attrName in this._defaults) {
165
- if(this._defaults.hasOwnProperty(attrName)){
166
- var attrValue = $input.attr('time:' + attrName);
167
- if (attrValue) {
168
- try {
169
- inlineSettings[attrName] = eval(attrValue);
170
- } catch (err) {
171
- inlineSettings[attrName] = attrValue;
172
- }
173
- }
174
- }
175
- }
176
- overrides = {
177
- beforeShow: function (input, dp_inst) {
178
- if ($.isFunction(tp_inst._defaults.evnts.beforeShow)) {
179
- return tp_inst._defaults.evnts.beforeShow.call($input[0], input, dp_inst, tp_inst);
180
- }
181
- },
182
- onChangeMonthYear: function (year, month, dp_inst) {
183
- // Update the time as well : this prevents the time from disappearing from the $input field.
184
- tp_inst._updateDateTime(dp_inst);
185
- if ($.isFunction(tp_inst._defaults.evnts.onChangeMonthYear)) {
186
- tp_inst._defaults.evnts.onChangeMonthYear.call($input[0], year, month, dp_inst, tp_inst);
187
- }
188
- },
189
- onClose: function (dateText, dp_inst) {
190
- if (tp_inst.timeDefined === true && $input.val() !== '') {
191
- tp_inst._updateDateTime(dp_inst);
192
- }
193
- if ($.isFunction(tp_inst._defaults.evnts.onClose)) {
194
- tp_inst._defaults.evnts.onClose.call($input[0], dateText, dp_inst, tp_inst);
195
- }
196
- }
197
- };
198
- for (i in overrides) {
199
- if (overrides.hasOwnProperty(i)) {
200
- fns[i] = o[i] || null;
201
- }
202
- }
203
- tp_inst._defaults = $.extend({}, this._defaults, inlineSettings, o, overrides, {
204
- evnts:fns,
205
- timepicker: tp_inst // add timepicker as a property of datepicker: $.datepicker._get(dp_inst, 'timepicker');
206
- });
207
- tp_inst.amNames = $.map(tp_inst._defaults.amNames, function(val) {
208
- return val.toUpperCase();
209
- });
210
- tp_inst.pmNames = $.map(tp_inst._defaults.pmNames, function(val) {
211
- return val.toUpperCase();
212
- });
213
-
214
- // controlType is string - key to our this._controls
215
- if(typeof(tp_inst._defaults.controlType) === 'string'){
216
- if($.fn[tp_inst._defaults.controlType] === undefined){
217
- tp_inst._defaults.controlType = 'select';
218
- }
219
- tp_inst.control = tp_inst._controls[tp_inst._defaults.controlType];
220
- }
221
- // controlType is an object and must implement create, options, value methods
222
- else{
223
- tp_inst.control = tp_inst._defaults.controlType;
224
- }
225
-
226
- if (tp_inst._defaults.timezoneList === null) {
227
- var timezoneList = ['-1200', '-1100', '-1000', '-0930', '-0900', '-0800', '-0700', '-0600', '-0500', '-0430', '-0400', '-0330', '-0300', '-0200', '-0100', '+0000',
228
- '+0100', '+0200', '+0300', '+0330', '+0400', '+0430', '+0500', '+0530', '+0545', '+0600', '+0630', '+0700', '+0800', '+0845', '+0900', '+0930',
229
- '+1000', '+1030', '+1100', '+1130', '+1200', '+1245', '+1300', '+1400'];
230
-
231
- if (tp_inst._defaults.timezoneIso8601) {
232
- timezoneList = $.map(timezoneList, function(val) {
233
- return val == '+0000' ? 'Z' : (val.substring(0, 3) + ':' + val.substring(3));
234
- });
235
- }
236
- tp_inst._defaults.timezoneList = timezoneList;
237
- }
238
-
239
- tp_inst.timezone = tp_inst._defaults.timezone;
240
- tp_inst.hour = tp_inst._defaults.hour < tp_inst._defaults.hourMin? tp_inst._defaults.hourMin :
241
- tp_inst._defaults.hour > tp_inst._defaults.hourMax? tp_inst._defaults.hourMax : tp_inst._defaults.hour;
242
- tp_inst.minute = tp_inst._defaults.minute < tp_inst._defaults.minuteMin? tp_inst._defaults.minuteMin :
243
- tp_inst._defaults.minute > tp_inst._defaults.minuteMax? tp_inst._defaults.minuteMax : tp_inst._defaults.minute;
244
- tp_inst.second = tp_inst._defaults.second < tp_inst._defaults.secondMin? tp_inst._defaults.secondMin :
245
- tp_inst._defaults.second > tp_inst._defaults.secondMax? tp_inst._defaults.secondMax : tp_inst._defaults.second;
246
- tp_inst.millisec = tp_inst._defaults.millisec < tp_inst._defaults.millisecMin? tp_inst._defaults.millisecMin :
247
- tp_inst._defaults.millisec > tp_inst._defaults.millisecMax? tp_inst._defaults.millisecMax : tp_inst._defaults.millisec;
248
- tp_inst.ampm = '';
249
- tp_inst.$input = $input;
250
-
251
- if (o.altField) {
252
- tp_inst.$altInput = $(o.altField).css({
253
- cursor: 'pointer'
254
- }).focus(function() {
255
- $input.trigger("focus");
256
- });
257
- }
258
-
259
- if (tp_inst._defaults.minDate === 0 || tp_inst._defaults.minDateTime === 0) {
260
- tp_inst._defaults.minDate = new Date();
261
- }
262
- if (tp_inst._defaults.maxDate === 0 || tp_inst._defaults.maxDateTime === 0) {
263
- tp_inst._defaults.maxDate = new Date();
264
- }
265
-
266
- // datepicker needs minDate/maxDate, timepicker needs minDateTime/maxDateTime..
267
- if (tp_inst._defaults.minDate !== undefined && tp_inst._defaults.minDate instanceof Date) {
268
- tp_inst._defaults.minDateTime = new Date(tp_inst._defaults.minDate.getTime());
269
- }
270
- if (tp_inst._defaults.minDateTime !== undefined && tp_inst._defaults.minDateTime instanceof Date) {
271
- tp_inst._defaults.minDate = new Date(tp_inst._defaults.minDateTime.getTime());
272
- }
273
- if (tp_inst._defaults.maxDate !== undefined && tp_inst._defaults.maxDate instanceof Date) {
274
- tp_inst._defaults.maxDateTime = new Date(tp_inst._defaults.maxDate.getTime());
275
- }
276
- if (tp_inst._defaults.maxDateTime !== undefined && tp_inst._defaults.maxDateTime instanceof Date) {
277
- tp_inst._defaults.maxDate = new Date(tp_inst._defaults.maxDateTime.getTime());
278
- }
279
- tp_inst.$input.bind('focus', function() {
280
- tp_inst._onFocus();
281
- });
282
-
283
- return tp_inst;
284
- },
285
-
286
- /*
287
- * add our sliders to the calendar
288
- */
289
- _addTimePicker: function(dp_inst) {
290
- var currDT = (this.$altInput && this._defaults.altFieldTimeOnly) ? this.$input.val() + ' ' + this.$altInput.val() : this.$input.val();
291
-
292
- this.timeDefined = this._parseTime(currDT);
293
- this._limitMinMaxDateTime(dp_inst, false);
294
- this._injectTimePicker();
295
- },
296
-
297
- /*
298
- * parse the time string from input value or _setTime
299
- */
300
- _parseTime: function(timeString, withDate) {
301
- if (!this.inst) {
302
- this.inst = $.datepicker._getInst(this.$input[0]);
303
- }
304
-
305
- if (withDate || !this._defaults.timeOnly) {
306
- var dp_dateFormat = $.datepicker._get(this.inst, 'dateFormat');
307
- try {
308
- var parseRes = parseDateTimeInternal(dp_dateFormat, this._defaults.timeFormat, timeString, $.datepicker._getFormatConfig(this.inst), this._defaults);
309
- if (!parseRes.timeObj) {
310
- return false;
311
- }
312
- $.extend(this, parseRes.timeObj);
313
- } catch (err) {
314
- $.timepicker.log("Error parsing the date/time string: " + err +
315
- "\ndate/time string = " + timeString +
316
- "\ntimeFormat = " + this._defaults.timeFormat +
317
- "\ndateFormat = " + dp_dateFormat);
318
- return false;
319
- }
320
- return true;
321
- } else {
322
- var timeObj = $.datepicker.parseTime(this._defaults.timeFormat, timeString, this._defaults);
323
- if (!timeObj) {
324
- return false;
325
- }
326
- $.extend(this, timeObj);
327
- return true;
328
- }
329
- },
330
-
331
- /*
332
- * generate and inject html for timepicker into ui datepicker
333
- */
334
- _injectTimePicker: function() {
335
- var $dp = this.inst.dpDiv,
336
- o = this.inst.settings,
337
- tp_inst = this,
338
- litem = '',
339
- uitem = '',
340
- max = {},
341
- gridSize = {},
342
- size = null;
343
-
344
- // Prevent displaying twice
345
- if ($dp.find("div.ui-timepicker-div").length === 0 && o.showTimepicker) {
346
- var noDisplay = ' style="display:none;"',
347
- html = '<div class="ui-timepicker-div'+ (o.isRTL? ' ui-timepicker-rtl' : '') +'"><dl>' + '<dt class="ui_tpicker_time_label"' + ((o.showTime) ? '' : noDisplay) + '>' + o.timeText + '</dt>' +
348
- '<dd class="ui_tpicker_time"' + ((o.showTime) ? '' : noDisplay) + '></dd>';
349
-
350
- // Create the markup
351
- for(var i=0,l=this.units.length; i<l; i++){
352
- litem = this.units[i];
353
- uitem = litem.substr(0,1).toUpperCase() + litem.substr(1);
354
- // Added by Peter Medeiros:
355
- // - Figure out what the hour/minute/second max should be based on the step values.
356
- // - Example: if stepMinute is 15, then minMax is 45.
357
- max[litem] = parseInt((o[litem+'Max'] - ((o[litem+'Max'] - o[litem+'Min']) % o['step'+uitem])), 10);
358
- gridSize[litem] = 0;
359
-
360
- html += '<dt class="ui_tpicker_'+ litem +'_label"' + ((o['show'+uitem]) ? '' : noDisplay) + '>' + o[litem +'Text'] + '</dt>' +
361
- '<dd class="ui_tpicker_'+ litem +'"><div class="ui_tpicker_'+ litem +'_slider"' + ((o['show'+uitem]) ? '' : noDisplay) + '></div>';
362
-
363
- if (o['show'+uitem] && o[litem+'Grid'] > 0) {
364
- html += '<div style="padding-left: 1px"><table class="ui-tpicker-grid-label"><tr>';
365
-
366
- if(litem == 'hour'){
367
- for (var h = o[litem+'Min']; h <= max[litem]; h += parseInt(o[litem+'Grid'], 10)) {
368
- gridSize[litem]++;
369
- var tmph = $.datepicker.formatTime(useAmpm(o.pickerTimeFormat || o.timeFormat)? 'hht':'HH', {hour:h}, o);
370
- html += '<td data-for="'+litem+'">' + tmph + '</td>';
371
- }
372
- }
373
- else{
374
- for (var m = o[litem+'Min']; m <= max[litem]; m += parseInt(o[litem+'Grid'], 10)) {
375
- gridSize[litem]++;
376
- html += '<td data-for="'+litem+'">' + ((m < 10) ? '0' : '') + m + '</td>';
377
- }
378
- }
379
-
380
- html += '</tr></table></div>';
381
- }
382
- html += '</dd>';
383
- }
384
-
385
- // Timezone
386
- html += '<dt class="ui_tpicker_timezone_label"' + ((o.showTimezone) ? '' : noDisplay) + '>' + o.timezoneText + '</dt>';
387
- html += '<dd class="ui_tpicker_timezone" ' + ((o.showTimezone) ? '' : noDisplay) + '></dd>';
388
-
389
- // Create the elements from string
390
- html += '</dl></div>';
391
- var $tp = $(html);
392
-
393
- // if we only want time picker...
394
- if (o.timeOnly === true) {
395
- $tp.prepend('<div class="ui-widget-header ui-helper-clearfix ui-corner-all">' + '<div class="ui-datepicker-title">' + o.timeOnlyTitle + '</div>' + '</div>');
396
- $dp.find('.ui-datepicker-header, .ui-datepicker-calendar').hide();
397
- }
398
-
399
- // add sliders, adjust grids, add events
400
- for(var i=0,l=tp_inst.units.length; i<l; i++){
401
- litem = tp_inst.units[i];
402
- uitem = litem.substr(0,1).toUpperCase() + litem.substr(1);
403
-
404
- // add the slider
405
- tp_inst[litem+'_slider'] = tp_inst.control.create(tp_inst, $tp.find('.ui_tpicker_'+litem+'_slider'), litem, tp_inst[litem], o[litem+'Min'], max[litem], o['step'+uitem]);
406
-
407
- // adjust the grid and add click event
408
- if (o['show'+uitem] && o[litem+'Grid'] > 0) {
409
- size = 100 * gridSize[litem] * o[litem+'Grid'] / (max[litem] - o[litem+'Min']);
410
- $tp.find('.ui_tpicker_'+litem+' table').css({
411
- width: size + "%",
412
- marginLeft: o.isRTL? '0' : ((size / (-2 * gridSize[litem])) + "%"),
413
- marginRight: o.isRTL? ((size / (-2 * gridSize[litem])) + "%") : '0',
414
- borderCollapse: 'collapse'
415
- }).find("td").click(function(e){
416
- var $t = $(this),
417
- h = $t.html(),
418
- n = parseInt(h.replace(/[^0-9]/g),10),
419
- ap = h.replace(/[^apm]/ig),
420
- f = $t.data('for'); // loses scope, so we use data-for
421
-
422
- if(f == 'hour'){
423
- if(ap.indexOf('p') !== -1 && n < 12){
424
- n += 12;
425
- }
426
- else{
427
- if(ap.indexOf('a') !== -1 && n === 12){
428
- n = 0;
429
- }
430
- }
431
- }
432
-
433
- tp_inst.control.value(tp_inst, tp_inst[f+'_slider'], litem, n);
434
-
435
- tp_inst._onTimeChange();
436
- tp_inst._onSelectHandler();
437
- })
438
- .css({
439
- cursor: 'pointer',
440
- width: (100 / gridSize[litem]) + '%',
441
- textAlign: 'center',
442
- overflow: 'hidden'
443
- });
444
- } // end if grid > 0
445
- } // end for loop
446
-
447
- // Add timezone options
448
- this.timezone_select = $tp.find('.ui_tpicker_timezone').append('<select></select>').find("select");
449
- $.fn.append.apply(this.timezone_select,
450
- $.map(o.timezoneList, function(val, idx) {
451
- return $("<option />").val(typeof val == "object" ? val.value : val).text(typeof val == "object" ? val.label : val);
452
- }));
453
- if (typeof(this.timezone) != "undefined" && this.timezone !== null && this.timezone !== "") {
454
- var local_date = new Date(this.inst.selectedYear, this.inst.selectedMonth, this.inst.selectedDay, 12);
455
- var local_timezone = $.timepicker.timeZoneOffsetString(local_date);
456
- if (local_timezone == this.timezone) {
457
- selectLocalTimeZone(tp_inst);
458
- } else {
459
- this.timezone_select.val(this.timezone);
460
- }
461
- } else {
462
- if (typeof(this.hour) != "undefined" && this.hour !== null && this.hour !== "") {
463
- this.timezone_select.val(o.defaultTimezone);
464
- } else {
465
- selectLocalTimeZone(tp_inst);
466
- }
467
- }
468
- this.timezone_select.change(function() {
469
- tp_inst._defaults.useLocalTimezone = false;
470
- tp_inst._onTimeChange();
471
- tp_inst._onSelectHandler();
472
- });
473
- // End timezone options
474
-
475
- // inject timepicker into datepicker
476
- var $buttonPanel = $dp.find('.ui-datepicker-buttonpane');
477
- if ($buttonPanel.length) {
478
- $buttonPanel.before($tp);
479
- } else {
480
- $dp.append($tp);
481
- }
482
-
483
- this.$timeObj = $tp.find('.ui_tpicker_time');
484
-
485
- if (this.inst !== null) {
486
- var timeDefined = this.timeDefined;
487
- this._onTimeChange();
488
- this.timeDefined = timeDefined;
489
- }
490
-
491
- // slideAccess integration: http://trentrichardson.com/2011/11/11/jquery-ui-sliders-and-touch-accessibility/
492
- if (this._defaults.addSliderAccess) {
493
- var sliderAccessArgs = this._defaults.sliderAccessArgs,
494
- rtl = this._defaults.isRTL;
495
- sliderAccessArgs.isRTL = rtl;
496
-
497
- setTimeout(function() { // fix for inline mode
498
- if ($tp.find('.ui-slider-access').length === 0) {
499
- $tp.find('.ui-slider:visible').sliderAccess(sliderAccessArgs);
500
-
501
- // fix any grids since sliders are shorter
502
- var sliderAccessWidth = $tp.find('.ui-slider-access:eq(0)').outerWidth(true);
503
- if (sliderAccessWidth) {
504
- $tp.find('table:visible').each(function() {
505
- var $g = $(this),
506
- oldWidth = $g.outerWidth(),
507
- oldMarginLeft = $g.css(rtl? 'marginRight':'marginLeft').toString().replace('%', ''),
508
- newWidth = oldWidth - sliderAccessWidth,
509
- newMarginLeft = ((oldMarginLeft * newWidth) / oldWidth) + '%',
510
- css = { width: newWidth, marginRight: 0, marginLeft: 0 };
511
- css[rtl? 'marginRight':'marginLeft'] = newMarginLeft;
512
- $g.css(css);
513
- });
514
- }
515
- }
516
- }, 10);
517
- }
518
- // end slideAccess integration
519
-
520
- }
521
- },
522
-
523
- /*
524
- * This function tries to limit the ability to go outside the
525
- * min/max date range
526
- */
527
- _limitMinMaxDateTime: function(dp_inst, adjustSliders) {
528
- var o = this._defaults,
529
- dp_date = new Date(dp_inst.selectedYear, dp_inst.selectedMonth, dp_inst.selectedDay);
530
-
531
- if (!this._defaults.showTimepicker) {
532
- return;
533
- } // No time so nothing to check here
534
-
535
- if ($.datepicker._get(dp_inst, 'minDateTime') !== null && $.datepicker._get(dp_inst, 'minDateTime') !== undefined && dp_date) {
536
- var minDateTime = $.datepicker._get(dp_inst, 'minDateTime'),
537
- minDateTimeDate = new Date(minDateTime.getFullYear(), minDateTime.getMonth(), minDateTime.getDate(), 0, 0, 0, 0);
538
-
539
- if (this.hourMinOriginal === null || this.minuteMinOriginal === null || this.secondMinOriginal === null || this.millisecMinOriginal === null) {
540
- this.hourMinOriginal = o.hourMin;
541
- this.minuteMinOriginal = o.minuteMin;
542
- this.secondMinOriginal = o.secondMin;
543
- this.millisecMinOriginal = o.millisecMin;
544
- }
545
-
546
- if (dp_inst.settings.timeOnly || minDateTimeDate.getTime() == dp_date.getTime()) {
547
- this._defaults.hourMin = minDateTime.getHours();
548
- if (this.hour <= this._defaults.hourMin) {
549
- this.hour = this._defaults.hourMin;
550
- this._defaults.minuteMin = minDateTime.getMinutes();
551
- if (this.minute <= this._defaults.minuteMin) {
552
- this.minute = this._defaults.minuteMin;
553
- this._defaults.secondMin = minDateTime.getSeconds();
554
- if (this.second <= this._defaults.secondMin) {
555
- this.second = this._defaults.secondMin;
556
- this._defaults.millisecMin = minDateTime.getMilliseconds();
557
- } else {
558
- if (this.millisec < this._defaults.millisecMin) {
559
- this.millisec = this._defaults.millisecMin;
560
- }
561
- this._defaults.millisecMin = this.millisecMinOriginal;
562
- }
563
- } else {
564
- this._defaults.secondMin = this.secondMinOriginal;
565
- this._defaults.millisecMin = this.millisecMinOriginal;
566
- }
567
- } else {
568
- this._defaults.minuteMin = this.minuteMinOriginal;
569
- this._defaults.secondMin = this.secondMinOriginal;
570
- this._defaults.millisecMin = this.millisecMinOriginal;
571
- }
572
- } else {
573
- this._defaults.hourMin = this.hourMinOriginal;
574
- this._defaults.minuteMin = this.minuteMinOriginal;
575
- this._defaults.secondMin = this.secondMinOriginal;
576
- this._defaults.millisecMin = this.millisecMinOriginal;
577
- }
578
- }
579
-
580
- if ($.datepicker._get(dp_inst, 'maxDateTime') !== null && $.datepicker._get(dp_inst, 'maxDateTime') !== undefined && dp_date) {
581
- var maxDateTime = $.datepicker._get(dp_inst, 'maxDateTime'),
582
- maxDateTimeDate = new Date(maxDateTime.getFullYear(), maxDateTime.getMonth(), maxDateTime.getDate(), 0, 0, 0, 0);
583
-
584
- if (this.hourMaxOriginal === null || this.minuteMaxOriginal === null || this.secondMaxOriginal === null) {
585
- this.hourMaxOriginal = o.hourMax;
586
- this.minuteMaxOriginal = o.minuteMax;
587
- this.secondMaxOriginal = o.secondMax;
588
- this.millisecMaxOriginal = o.millisecMax;
589
- }
590
-
591
- if (dp_inst.settings.timeOnly || maxDateTimeDate.getTime() == dp_date.getTime()) {
592
- this._defaults.hourMax = maxDateTime.getHours();
593
- if (this.hour >= this._defaults.hourMax) {
594
- this.hour = this._defaults.hourMax;
595
- this._defaults.minuteMax = maxDateTime.getMinutes();
596
- if (this.minute >= this._defaults.minuteMax) {
597
- this.minute = this._defaults.minuteMax;
598
- this._defaults.secondMax = maxDateTime.getSeconds();
599
- if (this.second >= this._defaults.secondMax) {
600
- this.second = this._defaults.secondMax;
601
- this._defaults.millisecMax = maxDateTime.getMilliseconds();
602
- } else {
603
- if (this.millisec > this._defaults.millisecMax) {
604
- this.millisec = this._defaults.millisecMax;
605
- }
606
- this._defaults.millisecMax = this.millisecMaxOriginal;
607
- }
608
- } else {
609
- this._defaults.secondMax = this.secondMaxOriginal;
610
- this._defaults.millisecMax = this.millisecMaxOriginal;
611
- }
612
- } else {
613
- this._defaults.minuteMax = this.minuteMaxOriginal;
614
- this._defaults.secondMax = this.secondMaxOriginal;
615
- this._defaults.millisecMax = this.millisecMaxOriginal;
616
- }
617
- } else {
618
- this._defaults.hourMax = this.hourMaxOriginal;
619
- this._defaults.minuteMax = this.minuteMaxOriginal;
620
- this._defaults.secondMax = this.secondMaxOriginal;
621
- this._defaults.millisecMax = this.millisecMaxOriginal;
622
- }
623
- }
624
-
625
- if (adjustSliders !== undefined && adjustSliders === true) {
626
- var hourMax = parseInt((this._defaults.hourMax - ((this._defaults.hourMax - this._defaults.hourMin) % this._defaults.stepHour)), 10),
627
- minMax = parseInt((this._defaults.minuteMax - ((this._defaults.minuteMax - this._defaults.minuteMin) % this._defaults.stepMinute)), 10),
628
- secMax = parseInt((this._defaults.secondMax - ((this._defaults.secondMax - this._defaults.secondMin) % this._defaults.stepSecond)), 10),
629
- millisecMax = parseInt((this._defaults.millisecMax - ((this._defaults.millisecMax - this._defaults.millisecMin) % this._defaults.stepMillisec)), 10);
630
-
631
- if (this.hour_slider) {
632
- this.control.options(this, this.hour_slider, 'hour', { min: this._defaults.hourMin, max: hourMax });
633
- this.control.value(this, this.hour_slider, 'hour', this.hour - (this.hour % this._defaults.stepHour));
634
- }
635
- if (this.minute_slider) {
636
- this.control.options(this, this.minute_slider, 'minute', { min: this._defaults.minuteMin, max: minMax });
637
- this.control.value(this, this.minute_slider, 'minute', this.minute - (this.minute % this._defaults.stepMinute));
638
- }
639
- if (this.second_slider) {
640
- this.control.options(this, this.second_slider, 'second', { min: this._defaults.secondMin, max: secMax });
641
- this.control.value(this, this.second_slider, 'second', this.second - (this.second % this._defaults.stepSecond));
642
- }
643
- if (this.millisec_slider) {
644
- this.control.options(this, this.millisec_slider, 'millisec', { min: this._defaults.millisecMin, max: millisecMax });
645
- this.control.value(this, this.millisec_slider, 'millisec', this.millisec - (this.millisec % this._defaults.stepMillisec));
646
- }
647
- }
648
-
649
- },
650
-
651
- /*
652
- * when a slider moves, set the internal time...
653
- * on time change is also called when the time is updated in the text field
654
- */
655
- _onTimeChange: function() {
656
- var hour = (this.hour_slider) ? this.control.value(this, this.hour_slider, 'hour') : false,
657
- minute = (this.minute_slider) ? this.control.value(this, this.minute_slider, 'minute') : false,
658
- second = (this.second_slider) ? this.control.value(this, this.second_slider, 'second') : false,
659
- millisec = (this.millisec_slider) ? this.control.value(this, this.millisec_slider, 'millisec') : false,
660
- timezone = (this.timezone_select) ? this.timezone_select.val() : false,
661
- o = this._defaults,
662
- pickerTimeFormat = o.pickerTimeFormat || o.timeFormat,
663
- pickerTimeSuffix = o.pickerTimeSuffix || o.timeSuffix;
664
-
665
- if (typeof(hour) == 'object') {
666
- hour = false;
667
- }
668
- if (typeof(minute) == 'object') {
669
- minute = false;
670
- }
671
- if (typeof(second) == 'object') {
672
- second = false;
673
- }
674
- if (typeof(millisec) == 'object') {
675
- millisec = false;
676
- }
677
- if (typeof(timezone) == 'object') {
678
- timezone = false;
679
- }
680
-
681
- if (hour !== false) {
682
- hour = parseInt(hour, 10);
683
- }
684
- if (minute !== false) {
685
- minute = parseInt(minute, 10);
686
- }
687
- if (second !== false) {
688
- second = parseInt(second, 10);
689
- }
690
- if (millisec !== false) {
691
- millisec = parseInt(millisec, 10);
692
- }
693
-
694
- var ampm = o[hour < 12 ? 'amNames' : 'pmNames'][0];
695
-
696
- // If the update was done in the input field, the input field should not be updated.
697
- // If the update was done using the sliders, update the input field.
698
- var hasChanged = (hour != this.hour || minute != this.minute || second != this.second || millisec != this.millisec
699
- || (this.ampm.length > 0 && (hour < 12) != ($.inArray(this.ampm.toUpperCase(), this.amNames) !== -1))
700
- || ((this.timezone === null && timezone != this.defaultTimezone) || (this.timezone !== null && timezone != this.timezone)));
701
-
702
- if (hasChanged) {
703
-
704
- if (hour !== false) {
705
- this.hour = hour;
706
- }
707
- if (minute !== false) {
708
- this.minute = minute;
709
- }
710
- if (second !== false) {
711
- this.second = second;
712
- }
713
- if (millisec !== false) {
714
- this.millisec = millisec;
715
- }
716
- if (timezone !== false) {
717
- this.timezone = timezone;
718
- }
719
-
720
- if (!this.inst) {
721
- this.inst = $.datepicker._getInst(this.$input[0]);
722
- }
723
-
724
- this._limitMinMaxDateTime(this.inst, true);
725
- }
726
- if (useAmpm(o.timeFormat)) {
727
- this.ampm = ampm;
728
- }
729
-
730
- // Updates the time within the timepicker
731
- this.formattedTime = $.datepicker.formatTime(o.timeFormat, this, o);
732
- if (this.$timeObj) {
733
- if(pickerTimeFormat === o.timeFormat){
734
- this.$timeObj.text(this.formattedTime + pickerTimeSuffix);
735
- }
736
- else{
737
- this.$timeObj.text($.datepicker.formatTime(pickerTimeFormat, this, o) + pickerTimeSuffix);
738
- }
739
- }
740
-
741
- this.timeDefined = true;
742
- if (hasChanged) {
743
- this._updateDateTime();
744
- }
745
- },
746
-
747
- /*
748
- * call custom onSelect.
749
- * bind to sliders slidestop, and grid click.
750
- */
751
- _onSelectHandler: function() {
752
- var onSelect = this._defaults.onSelect || this.inst.settings.onSelect;
753
- var inputEl = this.$input ? this.$input[0] : null;
754
- if (onSelect && inputEl) {
755
- onSelect.apply(inputEl, [this.formattedDateTime, this]);
756
- }
757
- },
758
-
759
- /*
760
- * update our input with the new date time..
761
- */
762
- _updateDateTime: function(dp_inst) {
763
- dp_inst = this.inst || dp_inst;
764
- var dt = $.datepicker._daylightSavingAdjust(new Date(dp_inst.selectedYear, dp_inst.selectedMonth, dp_inst.selectedDay)),
765
- dateFmt = $.datepicker._get(dp_inst, 'dateFormat'),
766
- formatCfg = $.datepicker._getFormatConfig(dp_inst),
767
- timeAvailable = dt !== null && this.timeDefined;
768
- this.formattedDate = $.datepicker.formatDate(dateFmt, (dt === null ? new Date() : dt), formatCfg);
769
- var formattedDateTime = this.formattedDate;
770
-
771
- // if a slider was changed but datepicker doesn't have a value yet, set it
772
- if(dp_inst.lastVal==""){
773
- dp_inst.currentYear=dp_inst.selectedYear;
774
- dp_inst.currentMonth=dp_inst.selectedMonth;
775
- dp_inst.currentDay=dp_inst.selectedDay;
776
- }
777
-
778
- /*
779
- * remove following lines to force every changes in date picker to change the input value
780
- * Bug descriptions: when an input field has a default value, and click on the field to pop up the date picker.
781
- * If the user manually empty the value in the input field, the date picker will never change selected value.
782
- */
783
- //if (dp_inst.lastVal !== undefined && (dp_inst.lastVal.length > 0 && this.$input.val().length === 0)) {
784
- // return;
785
- //}
786
-
787
- if (this._defaults.timeOnly === true) {
788
- formattedDateTime = this.formattedTime;
789
- } else if (this._defaults.timeOnly !== true && (this._defaults.alwaysSetTime || timeAvailable)) {
790
- formattedDateTime += this._defaults.separator + this.formattedTime + this._defaults.timeSuffix;
791
- }
792
-
793
- this.formattedDateTime = formattedDateTime;
794
-
795
- if (!this._defaults.showTimepicker) {
796
- this.$input.val(this.formattedDate);
797
- } else if (this.$altInput && this._defaults.altFieldTimeOnly === true) {
798
- this.$altInput.val(this.formattedTime);
799
- this.$input.val(this.formattedDate);
800
- } else if (this.$altInput) {
801
- this.$input.val(formattedDateTime);
802
- var altFormattedDateTime = '',
803
- altSeparator = this._defaults.altSeparator ? this._defaults.altSeparator : this._defaults.separator,
804
- altTimeSuffix = this._defaults.altTimeSuffix ? this._defaults.altTimeSuffix : this._defaults.timeSuffix;
805
-
806
- if (this._defaults.altFormat) altFormattedDateTime = $.datepicker.formatDate(this._defaults.altFormat, (dt === null ? new Date() : dt), formatCfg);
807
- else altFormattedDateTime = this.formattedDate;
808
- if (altFormattedDateTime) altFormattedDateTime += altSeparator;
809
- if (this._defaults.altTimeFormat) altFormattedDateTime += $.datepicker.formatTime(this._defaults.altTimeFormat, this, this._defaults) + altTimeSuffix;
810
- else altFormattedDateTime += this.formattedTime + altTimeSuffix;
811
- this.$altInput.val(altFormattedDateTime);
812
- } else {
813
- this.$input.val(formattedDateTime);
814
- }
815
-
816
- this.$input.trigger("change");
817
- },
818
-
819
- _onFocus: function() {
820
- if (!this.$input.val() && this._defaults.defaultValue) {
821
- this.$input.val(this._defaults.defaultValue);
822
- var inst = $.datepicker._getInst(this.$input.get(0)),
823
- tp_inst = $.datepicker._get(inst, 'timepicker');
824
- if (tp_inst) {
825
- if (tp_inst._defaults.timeOnly && (inst.input.val() != inst.lastVal)) {
826
- try {
827
- $.datepicker._updateDatepicker(inst);
828
- } catch (err) {
829
- $.timepicker.log(err);
830
- }
831
- }
832
- }
833
- }
834
- },
835
-
836
- /*
837
- * Small abstraction to control types
838
- * We can add more, just be sure to follow the pattern: create, options, value
839
- */
840
- _controls: {
841
- // slider methods
842
- slider: {
843
- create: function(tp_inst, obj, unit, val, min, max, step){
844
- var rtl = tp_inst._defaults.isRTL; // if rtl go -60->0 instead of 0->60
845
- return obj.prop('slide', null).slider({
846
- orientation: "horizontal",
847
- value: rtl? val*-1 : val,
848
- min: rtl? max*-1 : min,
849
- max: rtl? min*-1 : max,
850
- step: step,
851
- slide: function(event, ui) {
852
- tp_inst.control.value(tp_inst, $(this), unit, rtl? ui.value*-1:ui.value);
853
- tp_inst._onTimeChange();
854
- },
855
- stop: function(event, ui) {
856
- tp_inst._onSelectHandler();
857
- }
858
- });
859
- },
860
- options: function(tp_inst, obj, unit, opts, val){
861
- if(tp_inst._defaults.isRTL){
862
- if(typeof(opts) == 'string'){
863
- if(opts == 'min' || opts == 'max'){
864
- if(val !== undefined)
865
- return obj.slider(opts, val*-1);
866
- return Math.abs(obj.slider(opts));
867
- }
868
- return obj.slider(opts);
869
- }
870
- var min = opts.min,
871
- max = opts.max;
872
- opts.min = opts.max = null;
873
- if(min !== undefined)
874
- opts.max = min * -1;
875
- if(max !== undefined)
876
- opts.min = max * -1;
877
- return obj.slider(opts);
878
- }
879
- if(typeof(opts) == 'string' && val !== undefined)
880
- return obj.slider(opts, val);
881
- return obj.slider(opts);
882
- },
883
- value: function(tp_inst, obj, unit, val){
884
- if(tp_inst._defaults.isRTL){
885
- if(val !== undefined)
886
- return obj.slider('value', val*-1);
887
- return Math.abs(obj.slider('value'));
888
- }
889
- if(val !== undefined)
890
- return obj.slider('value', val);
891
- return obj.slider('value');
892
- }
893
- },
894
- // select methods
895
- select: {
896
- create: function(tp_inst, obj, unit, val, min, max, step){
897
- var sel = '<select class="ui-timepicker-select" data-unit="'+ unit +'" data-min="'+ min +'" data-max="'+ max +'" data-step="'+ step +'">',
898
- ul = tp_inst._defaults.timeFormat.indexOf('t') !== -1? 'toLowerCase':'toUpperCase',
899
- m = 0;
900
-
901
- for(var i=min; i<=max; i+=step){
902
- sel += '<option value="'+ i +'"'+ (i==val? ' selected':'') +'>';
903
- if(unit == 'hour' && useAmpm(tp_inst._defaults.pickerTimeFormat || tp_inst._defaults.timeFormat))
904
- sel += $.datepicker.formatTime("hh TT", {hour:i}, tp_inst._defaults);
905
- else if(unit == 'millisec' || i >= 10) sel += i;
906
- else sel += '0'+ i.toString();
907
- sel += '</option>';
908
- }
909
- sel += '</select>';
910
-
911
- obj.children('select').remove();
912
-
913
- $(sel).appendTo(obj).change(function(e){
914
- tp_inst._onTimeChange();
915
- tp_inst._onSelectHandler();
916
- });
917
-
918
- return obj;
919
- },
920
- options: function(tp_inst, obj, unit, opts, val){
921
- var o = {},
922
- $t = obj.children('select');
923
- if(typeof(opts) == 'string'){
924
- if(val === undefined)
925
- return $t.data(opts);
926
- o[opts] = val;
927
- }
928
- else o = opts;
929
- return tp_inst.control.create(tp_inst, obj, $t.data('unit'), $t.val(), o.min || $t.data('min'), o.max || $t.data('max'), o.step || $t.data('step'));
930
- },
931
- value: function(tp_inst, obj, unit, val){
932
- var $t = obj.children('select');
933
- if(val !== undefined)
934
- return $t.val(val);
935
- return $t.val();
936
- }
937
- }
938
- } // end _controls
939
-
940
- });
941
-
942
- $.fn.extend({
943
- /*
944
- * shorthand just to use timepicker..
945
- */
946
- timepicker: function(o) {
947
- o = o || {};
948
- var tmp_args = Array.prototype.slice.call(arguments);
949
-
950
- if (typeof o == 'object') {
951
- tmp_args[0] = $.extend(o, {
952
- timeOnly: true
953
- });
954
- }
955
-
956
- return $(this).each(function() {
957
- $.fn.datetimepicker.apply($(this), tmp_args);
958
- });
959
- },
960
-
961
- /*
962
- * extend timepicker to datepicker
963
- */
964
- datetimepicker: function(o) {
965
- o = o || {};
966
- var tmp_args = arguments;
967
-
968
- if (typeof(o) == 'string') {
969
- if (o == 'getDate') {
970
- return $.fn.datepicker.apply($(this[0]), tmp_args);
971
- } else {
972
- return this.each(function() {
973
- var $t = $(this);
974
- $t.datepicker.apply($t, tmp_args);
975
- });
976
- }
977
- } else {
978
- return this.each(function() {
979
- var $t = $(this);
980
- $t.datepicker($.timepicker._newInst($t, o)._defaults);
981
- });
982
- }
983
- }
984
- });
985
-
986
- /*
987
- * Public Utility to parse date and time
988
- */
989
- $.datepicker.parseDateTime = function(dateFormat, timeFormat, dateTimeString, dateSettings, timeSettings) {
990
- var parseRes = parseDateTimeInternal(dateFormat, timeFormat, dateTimeString, dateSettings, timeSettings);
991
- if (parseRes.timeObj) {
992
- var t = parseRes.timeObj;
993
- parseRes.date.setHours(t.hour, t.minute, t.second, t.millisec);
994
- }
995
-
996
- return parseRes.date;
997
- };
998
-
999
- /*
1000
- * Public utility to parse time
1001
- */
1002
- $.datepicker.parseTime = function(timeFormat, timeString, options) {
1003
- var o = extendRemove(extendRemove({}, $.timepicker._defaults), options || {});
1004
-
1005
- // Strict parse requires the timeString to match the timeFormat exactly
1006
- var strictParse = function(f, s, o){
1007
-
1008
- // pattern for standard and localized AM/PM markers
1009
- var getPatternAmpm = function(amNames, pmNames) {
1010
- var markers = [];
1011
- if (amNames) {
1012
- $.merge(markers, amNames);
1013
- }
1014
- if (pmNames) {
1015
- $.merge(markers, pmNames);
1016
- }
1017
- markers = $.map(markers, function(val) {
1018
- return val.replace(/[.*+?|()\[\]{}\\]/g, '\\$&');
1019
- });
1020
- return '(' + markers.join('|') + ')?';
1021
- };
1022
-
1023
- // figure out position of time elements.. cause js cant do named captures
1024
- var getFormatPositions = function(timeFormat) {
1025
- var finds = timeFormat.toLowerCase().match(/(h{1,2}|m{1,2}|s{1,2}|l{1}|t{1,2}|z|'.*?')/g),
1026
- orders = {
1027
- h: -1,
1028
- m: -1,
1029
- s: -1,
1030
- l: -1,
1031
- t: -1,
1032
- z: -1
1033
- };
1034
-
1035
- if (finds) {
1036
- for (var i = 0; i < finds.length; i++) {
1037
- if (orders[finds[i].toString().charAt(0)] == -1) {
1038
- orders[finds[i].toString().charAt(0)] = i + 1;
1039
- }
1040
- }
1041
- }
1042
- return orders;
1043
- };
1044
-
1045
- var regstr = '^' + f.toString()
1046
- .replace(/([hH]{1,2}|mm?|ss?|[tT]{1,2}|[lz]|'.*?')/g, function (match) {
1047
- var ml = match.length;
1048
- switch (match.charAt(0).toLowerCase()) {
1049
- case 'h': return ml === 1? '(\\d?\\d)':'(\\d{'+ml+'})';
1050
- case 'm': return ml === 1? '(\\d?\\d)':'(\\d{'+ml+'})';
1051
- case 's': return ml === 1? '(\\d?\\d)':'(\\d{'+ml+'})';
1052
- case 'l': return '(\\d?\\d?\\d)';
1053
- case 'z': return '(z|[-+]\\d\\d:?\\d\\d|\\S+)?';
1054
- case 't': return getPatternAmpm(o.amNames, o.pmNames);
1055
- default: // literal escaped in quotes
1056
- return '(' + match.replace(/\'/g, "").replace(/(\.|\$|\^|\\|\/|\(|\)|\[|\]|\?|\+|\*)/g, function (m) { return "\\" + m; }) + ')?';
1057
- }
1058
- })
1059
- .replace(/\s/g, '\\s?') +
1060
- o.timeSuffix + '$',
1061
- order = getFormatPositions(f),
1062
- ampm = '',
1063
- treg;
1064
-
1065
- treg = s.match(new RegExp(regstr, 'i'));
1066
-
1067
- var resTime = {
1068
- hour: 0,
1069
- minute: 0,
1070
- second: 0,
1071
- millisec: 0
1072
- };
1073
-
1074
- if (treg) {
1075
- if (order.t !== -1) {
1076
- if (treg[order.t] === undefined || treg[order.t].length === 0) {
1077
- ampm = '';
1078
- resTime.ampm = '';
1079
- } else {
1080
- ampm = $.inArray(treg[order.t].toUpperCase(), o.amNames) !== -1 ? 'AM' : 'PM';
1081
- resTime.ampm = o[ampm == 'AM' ? 'amNames' : 'pmNames'][0];
1082
- }
1083
- }
1084
-
1085
- if (order.h !== -1) {
1086
- if (ampm == 'AM' && treg[order.h] == '12') {
1087
- resTime.hour = 0; // 12am = 0 hour
1088
- } else {
1089
- if (ampm == 'PM' && treg[order.h] != '12') {
1090
- resTime.hour = parseInt(treg[order.h], 10) + 12; // 12pm = 12 hour, any other pm = hour + 12
1091
- } else {
1092
- resTime.hour = Number(treg[order.h]);
1093
- }
1094
- }
1095
- }
1096
-
1097
- if (order.m !== -1) {
1098
- resTime.minute = Number(treg[order.m]);
1099
- }
1100
- if (order.s !== -1) {
1101
- resTime.second = Number(treg[order.s]);
1102
- }
1103
- if (order.l !== -1) {
1104
- resTime.millisec = Number(treg[order.l]);
1105
- }
1106
- if (order.z !== -1 && treg[order.z] !== undefined) {
1107
- var tz = treg[order.z].toUpperCase();
1108
- switch (tz.length) {
1109
- case 1:
1110
- // Z
1111
- tz = o.timezoneIso8601 ? 'Z' : '+0000';
1112
- break;
1113
- case 5:
1114
- // +hhmm
1115
- if (o.timezoneIso8601) {
1116
- tz = tz.substring(1) == '0000' ? 'Z' : tz.substring(0, 3) + ':' + tz.substring(3);
1117
- }
1118
- break;
1119
- case 6:
1120
- // +hh:mm
1121
- if (!o.timezoneIso8601) {
1122
- tz = tz == 'Z' || tz.substring(1) == '00:00' ? '+0000' : tz.replace(/:/, '');
1123
- } else {
1124
- if (tz.substring(1) == '00:00') {
1125
- tz = 'Z';
1126
- }
1127
- }
1128
- break;
1129
- }
1130
- resTime.timezone = tz;
1131
- }
1132
-
1133
-
1134
- return resTime;
1135
- }
1136
- return false;
1137
- };// end strictParse
1138
-
1139
- // First try JS Date, if that fails, use strictParse
1140
- var looseParse = function(f,s,o){
1141
- try{
1142
- var d = new Date('2012-01-01 '+ s);
1143
- if(isNaN(d.getTime())){
1144
- d = new Date('2012-01-01T'+ s);
1145
- if(isNaN(d.getTime())){
1146
- d = new Date('01/01/2012 '+ s);
1147
- if(isNaN(d.getTime())){
1148
- throw "Unable to parse time with native Date: "+ s;
1149
- }
1150
- }
1151
- }
1152
-
1153
- return {
1154
- hour: d.getHours(),
1155
- minute: d.getMinutes(),
1156
- second: d.getSeconds(),
1157
- millisec: d.getMilliseconds(),
1158
- timezone: $.timepicker.timeZoneOffsetString(d)
1159
- };
1160
- }
1161
- catch(err){
1162
- try{
1163
- return strictParse(f,s,o);
1164
- }
1165
- catch(err2){
1166
- $.timepicker.log("Unable to parse \ntimeString: "+ s +"\ntimeFormat: "+ f);
1167
- }
1168
- }
1169
- return false;
1170
- }; // end looseParse
1171
-
1172
- if(typeof o.parse === "function"){
1173
- return o.parse(timeFormat, timeString, o)
1174
- }
1175
- if(o.parse === 'loose'){
1176
- return looseParse(timeFormat, timeString, o);
1177
- }
1178
- return strictParse(timeFormat, timeString, o);
1179
- };
1180
-
1181
- /*
1182
- * Public utility to format the time
1183
- * format = string format of the time
1184
- * time = a {}, not a Date() for timezones
1185
- * options = essentially the regional[].. amNames, pmNames, ampm
1186
- */
1187
- $.datepicker.formatTime = function(format, time, options) {
1188
- options = options || {};
1189
- options = $.extend({}, $.timepicker._defaults, options);
1190
- time = $.extend({
1191
- hour: 0,
1192
- minute: 0,
1193
- second: 0,
1194
- millisec: 0,
1195
- timezone: '+0000'
1196
- }, time);
1197
-
1198
- var tmptime = format,
1199
- ampmName = options.amNames[0],
1200
- hour = parseInt(time.hour, 10);
1201
-
1202
- if (hour > 11) {
1203
- ampmName = options.pmNames[0];
1204
- }
1205
-
1206
- tmptime = tmptime.replace(/(?:HH?|hh?|mm?|ss?|[tT]{1,2}|[lz]|('.*?'|".*?"))/g, function(match) {
1207
- switch (match) {
1208
- case 'HH':
1209
- return ('0' + hour).slice(-2);
1210
- case 'H':
1211
- return hour;
1212
- case 'hh':
1213
- return ('0' + convert24to12(hour)).slice(-2);
1214
- case 'h':
1215
- return convert24to12(hour);
1216
- case 'mm':
1217
- return ('0' + time.minute).slice(-2);
1218
- case 'm':
1219
- return time.minute;
1220
- case 'ss':
1221
- return ('0' + time.second).slice(-2);
1222
- case 's':
1223
- return time.second;
1224
- case 'l':
1225
- return ('00' + time.millisec).slice(-3);
1226
- case 'z':
1227
- return time.timezone === null? options.defaultTimezone : time.timezone;
1228
- case 'T':
1229
- return ampmName.charAt(0).toUpperCase();
1230
- case 'TT':
1231
- return ampmName.toUpperCase();
1232
- case 't':
1233
- return ampmName.charAt(0).toLowerCase();
1234
- case 'tt':
1235
- return ampmName.toLowerCase();
1236
- default:
1237
- return match.replace(/\'/g, "") || "'";
1238
- }
1239
- });
1240
-
1241
- tmptime = $.trim(tmptime);
1242
- return tmptime;
1243
- };
1244
-
1245
- /*
1246
- * the bad hack :/ override datepicker so it doesnt close on select
1247
- // inspired: http://stackoverflow.com/questions/1252512/jquery-datepicker-prevent-closing-picker-when-clicking-a-date/1762378#1762378
1248
- */
1249
- $.datepicker._base_selectDate = $.datepicker._selectDate;
1250
- $.datepicker._selectDate = function(id, dateStr) {
1251
- var inst = this._getInst($(id)[0]),
1252
- tp_inst = this._get(inst, 'timepicker');
1253
-
1254
- if (tp_inst) {
1255
- tp_inst._limitMinMaxDateTime(inst, true);
1256
- inst.inline = inst.stay_open = true;
1257
- //This way the onSelect handler called from calendarpicker get the full dateTime
1258
- this._base_selectDate(id, dateStr);
1259
- inst.inline = inst.stay_open = false;
1260
- this._notifyChange(inst);
1261
- this._updateDatepicker(inst);
1262
- } else {
1263
- this._base_selectDate(id, dateStr);
1264
- }
1265
- };
1266
-
1267
- /*
1268
- * second bad hack :/ override datepicker so it triggers an event when changing the input field
1269
- * and does not redraw the datepicker on every selectDate event
1270
- */
1271
- $.datepicker._base_updateDatepicker = $.datepicker._updateDatepicker;
1272
- $.datepicker._updateDatepicker = function(inst) {
1273
-
1274
- // don't popup the datepicker if there is another instance already opened
1275
- var input = inst.input[0];
1276
- if ($.datepicker._curInst && $.datepicker._curInst != inst && $.datepicker._datepickerShowing && $.datepicker._lastInput != input) {
1277
- return;
1278
- }
1279
-
1280
- if (typeof(inst.stay_open) !== 'boolean' || inst.stay_open === false) {
1281
-
1282
- this._base_updateDatepicker(inst);
1283
-
1284
- // Reload the time control when changing something in the input text field.
1285
- var tp_inst = this._get(inst, 'timepicker');
1286
- if (tp_inst) {
1287
- tp_inst._addTimePicker(inst);
1288
-
1289
- // if (tp_inst._defaults.useLocalTimezone) { //checks daylight saving with the new date.
1290
- // var date = new Date(inst.selectedYear, inst.selectedMonth, inst.selectedDay, 12);
1291
- // selectLocalTimeZone(tp_inst, date);
1292
- // tp_inst._onTimeChange();
1293
- // }
1294
- }
1295
- }
1296
- };
1297
-
1298
- /*
1299
- * third bad hack :/ override datepicker so it allows spaces and colon in the input field
1300
- */
1301
- $.datepicker._base_doKeyPress = $.datepicker._doKeyPress;
1302
- $.datepicker._doKeyPress = function(event) {
1303
- var inst = $.datepicker._getInst(event.target),
1304
- tp_inst = $.datepicker._get(inst, 'timepicker');
1305
-
1306
- if (tp_inst) {
1307
- if ($.datepicker._get(inst, 'constrainInput')) {
1308
- var ampm = useAmpm(tp_inst._defaults.timeFormat),
1309
- dateChars = $.datepicker._possibleChars($.datepicker._get(inst, 'dateFormat')),
1310
- datetimeChars = tp_inst._defaults.timeFormat.toString()
1311
- .replace(/[hms]/g, '')
1312
- .replace(/TT/g, ampm ? 'APM' : '')
1313
- .replace(/Tt/g, ampm ? 'AaPpMm' : '')
1314
- .replace(/tT/g, ampm ? 'AaPpMm' : '')
1315
- .replace(/T/g, ampm ? 'AP' : '')
1316
- .replace(/tt/g, ampm ? 'apm' : '')
1317
- .replace(/t/g, ampm ? 'ap' : '') +
1318
- " " + tp_inst._defaults.separator +
1319
- tp_inst._defaults.timeSuffix +
1320
- (tp_inst._defaults.showTimezone ? tp_inst._defaults.timezoneList.join('') : '') +
1321
- (tp_inst._defaults.amNames.join('')) + (tp_inst._defaults.pmNames.join('')) +
1322
- dateChars,
1323
- chr = String.fromCharCode(event.charCode === undefined ? event.keyCode : event.charCode);
1324
- return event.ctrlKey || (chr < ' ' || !dateChars || datetimeChars.indexOf(chr) > -1);
1325
- }
1326
- }
1327
-
1328
- return $.datepicker._base_doKeyPress(event);
1329
- };
1330
-
1331
- /*
1332
- * Fourth bad hack :/ override _updateAlternate function used in inline mode to init altField
1333
- */
1334
- $.datepicker._base_updateAlternate = $.datepicker._updateAlternate;
1335
- /* Update any alternate field to synchronise with the main field. */
1336
- $.datepicker._updateAlternate = function(inst) {
1337
- var tp_inst = this._get(inst, 'timepicker');
1338
- if(tp_inst){
1339
- var altField = tp_inst._defaults.altField;
1340
- if (altField) { // update alternate field too
1341
- var altFormat = tp_inst._defaults.altFormat || tp_inst._defaults.dateFormat,
1342
- date = this._getDate(inst),
1343
- formatCfg = $.datepicker._getFormatConfig(inst),
1344
- altFormattedDateTime = '',
1345
- altSeparator = tp_inst._defaults.altSeparator ? tp_inst._defaults.altSeparator : tp_inst._defaults.separator,
1346
- altTimeSuffix = tp_inst._defaults.altTimeSuffix ? tp_inst._defaults.altTimeSuffix : tp_inst._defaults.timeSuffix,
1347
- altTimeFormat = tp_inst._defaults.altTimeFormat !== null ? tp_inst._defaults.altTimeFormat : tp_inst._defaults.timeFormat;
1348
-
1349
- altFormattedDateTime += $.datepicker.formatTime(altTimeFormat, tp_inst, tp_inst._defaults) + altTimeSuffix;
1350
- if(!tp_inst._defaults.timeOnly && !tp_inst._defaults.altFieldTimeOnly && date !== null){
1351
- if(tp_inst._defaults.altFormat)
1352
- altFormattedDateTime = $.datepicker.formatDate(tp_inst._defaults.altFormat, date, formatCfg) + altSeparator + altFormattedDateTime;
1353
- else altFormattedDateTime = tp_inst.formattedDate + altSeparator + altFormattedDateTime;
1354
- }
1355
- $(altField).val(altFormattedDateTime);
1356
- }
1357
- }
1358
- else{
1359
- $.datepicker._base_updateAlternate(inst);
1360
- }
1361
- };
1362
-
1363
- /*
1364
- * Override key up event to sync manual input changes.
1365
- */
1366
- $.datepicker._base_doKeyUp = $.datepicker._doKeyUp;
1367
- $.datepicker._doKeyUp = function(event) {
1368
- var inst = $.datepicker._getInst(event.target),
1369
- tp_inst = $.datepicker._get(inst, 'timepicker');
1370
-
1371
- if (tp_inst) {
1372
- if (tp_inst._defaults.timeOnly && (inst.input.val() != inst.lastVal)) {
1373
- try {
1374
- $.datepicker._updateDatepicker(inst);
1375
- } catch (err) {
1376
- $.timepicker.log(err);
1377
- }
1378
- }
1379
- }
1380
-
1381
- return $.datepicker._base_doKeyUp(event);
1382
- };
1383
-
1384
- /*
1385
- * override "Today" button to also grab the time.
1386
- */
1387
- $.datepicker._base_gotoToday = $.datepicker._gotoToday;
1388
- $.datepicker._gotoToday = function(id) {
1389
- var inst = this._getInst($(id)[0]),
1390
- $dp = inst.dpDiv;
1391
- this._base_gotoToday(id);
1392
- var tp_inst = this._get(inst, 'timepicker');
1393
- selectLocalTimeZone(tp_inst);
1394
- var now = new Date();
1395
- this._setTime(inst, now);
1396
- $('.ui-datepicker-today', $dp).click();
1397
- };
1398
-
1399
- /*
1400
- * Disable & enable the Time in the datetimepicker
1401
- */
1402
- $.datepicker._disableTimepickerDatepicker = function(target) {
1403
- var inst = this._getInst(target);
1404
- if (!inst) {
1405
- return;
1406
- }
1407
-
1408
- var tp_inst = this._get(inst, 'timepicker');
1409
- $(target).datepicker('getDate'); // Init selected[Year|Month|Day]
1410
- if (tp_inst) {
1411
- tp_inst._defaults.showTimepicker = false;
1412
- tp_inst._updateDateTime(inst);
1413
- }
1414
- };
1415
-
1416
- $.datepicker._enableTimepickerDatepicker = function(target) {
1417
- var inst = this._getInst(target);
1418
- if (!inst) {
1419
- return;
1420
- }
1421
-
1422
- var tp_inst = this._get(inst, 'timepicker');
1423
- $(target).datepicker('getDate'); // Init selected[Year|Month|Day]
1424
- if (tp_inst) {
1425
- tp_inst._defaults.showTimepicker = true;
1426
- tp_inst._addTimePicker(inst); // Could be disabled on page load
1427
- tp_inst._updateDateTime(inst);
1428
- }
1429
- };
1430
-
1431
- /*
1432
- * Create our own set time function
1433
- */
1434
- $.datepicker._setTime = function(inst, date) {
1435
- var tp_inst = this._get(inst, 'timepicker');
1436
- if (tp_inst) {
1437
- var defaults = tp_inst._defaults;
1438
-
1439
- // calling _setTime with no date sets time to defaults
1440
- tp_inst.hour = date ? date.getHours() : defaults.hour;
1441
- tp_inst.minute = date ? date.getMinutes() : defaults.minute;
1442
- tp_inst.second = date ? date.getSeconds() : defaults.second;
1443
- tp_inst.millisec = date ? date.getMilliseconds() : defaults.millisec;
1444
-
1445
- //check if within min/max times..
1446
- tp_inst._limitMinMaxDateTime(inst, true);
1447
-
1448
- tp_inst._onTimeChange();
1449
- tp_inst._updateDateTime(inst);
1450
- }
1451
- };
1452
-
1453
- /*
1454
- * Create new public method to set only time, callable as $().datepicker('setTime', date)
1455
- */
1456
- $.datepicker._setTimeDatepicker = function(target, date, withDate) {
1457
- var inst = this._getInst(target);
1458
- if (!inst) {
1459
- return;
1460
- }
1461
-
1462
- var tp_inst = this._get(inst, 'timepicker');
1463
-
1464
- if (tp_inst) {
1465
- this._setDateFromField(inst);
1466
- var tp_date;
1467
- if (date) {
1468
- if (typeof date == "string") {
1469
- tp_inst._parseTime(date, withDate);
1470
- tp_date = new Date();
1471
- tp_date.setHours(tp_inst.hour, tp_inst.minute, tp_inst.second, tp_inst.millisec);
1472
- } else {
1473
- tp_date = new Date(date.getTime());
1474
- }
1475
- if (tp_date.toString() == 'Invalid Date') {
1476
- tp_date = undefined;
1477
- }
1478
- this._setTime(inst, tp_date);
1479
- }
1480
- }
1481
-
1482
- };
1483
-
1484
- /*
1485
- * override setDate() to allow setting time too within Date object
1486
- */
1487
- $.datepicker._base_setDateDatepicker = $.datepicker._setDateDatepicker;
1488
- $.datepicker._setDateDatepicker = function(target, date) {
1489
- var inst = this._getInst(target);
1490
- if (!inst) {
1491
- return;
1492
- }
1493
-
1494
- var tp_date = (date instanceof Date) ? new Date(date.getTime()) : date;
1495
-
1496
- this._updateDatepicker(inst);
1497
- this._base_setDateDatepicker.apply(this, arguments);
1498
- this._setTimeDatepicker(target, tp_date, true);
1499
- };
1500
-
1501
- /*
1502
- * override getDate() to allow getting time too within Date object
1503
- */
1504
- $.datepicker._base_getDateDatepicker = $.datepicker._getDateDatepicker;
1505
- $.datepicker._getDateDatepicker = function(target, noDefault) {
1506
- var inst = this._getInst(target);
1507
- if (!inst) {
1508
- return;
1509
- }
1510
-
1511
- var tp_inst = this._get(inst, 'timepicker');
1512
-
1513
- if (tp_inst) {
1514
- // if it hasn't yet been defined, grab from field
1515
- if(inst.lastVal === undefined){
1516
- this._setDateFromField(inst, noDefault);
1517
- }
1518
-
1519
- var date = this._getDate(inst);
1520
- if (date && tp_inst._parseTime($(target).val(), tp_inst.timeOnly)) {
1521
- date.setHours(tp_inst.hour, tp_inst.minute, tp_inst.second, tp_inst.millisec);
1522
- }
1523
- return date;
1524
- }
1525
- return this._base_getDateDatepicker(target, noDefault);
1526
- };
1527
-
1528
- /*
1529
- * override parseDate() because UI 1.8.14 throws an error about "Extra characters"
1530
- * An option in datapicker to ignore extra format characters would be nicer.
1531
- */
1532
- $.datepicker._base_parseDate = $.datepicker.parseDate;
1533
- $.datepicker.parseDate = function(format, value, settings) {
1534
- var date;
1535
- try {
1536
- date = this._base_parseDate(format, value, settings);
1537
- } catch (err) {
1538
- // Hack! The error message ends with a colon, a space, and
1539
- // the "extra" characters. We rely on that instead of
1540
- // attempting to perfectly reproduce the parsing algorithm.
1541
- date = this._base_parseDate(format, value.substring(0,value.length-(err.length-err.indexOf(':')-2)), settings);
1542
- $.timepicker.log("Error parsing the date string: " + err + "\ndate string = " + value + "\ndate format = " + format);
1543
- }
1544
- return date;
1545
- };
1546
-
1547
- /*
1548
- * override formatDate to set date with time to the input
1549
- */
1550
- $.datepicker._base_formatDate = $.datepicker._formatDate;
1551
- $.datepicker._formatDate = function(inst, day, month, year) {
1552
- var tp_inst = this._get(inst, 'timepicker');
1553
- if (tp_inst) {
1554
- tp_inst._updateDateTime(inst);
1555
- return tp_inst.$input.val();
1556
- }
1557
- return this._base_formatDate(inst);
1558
- };
1559
-
1560
- /*
1561
- * override options setter to add time to maxDate(Time) and minDate(Time). MaxDate
1562
- */
1563
- $.datepicker._base_optionDatepicker = $.datepicker._optionDatepicker;
1564
- $.datepicker._optionDatepicker = function(target, name, value) {
1565
- var inst = this._getInst(target),
1566
- name_clone;
1567
- if (!inst) {
1568
- return null;
1569
- }
1570
-
1571
- var tp_inst = this._get(inst, 'timepicker');
1572
- if (tp_inst) {
1573
- var min = null,
1574
- max = null,
1575
- onselect = null,
1576
- overrides = tp_inst._defaults.evnts,
1577
- fns = {},
1578
- prop;
1579
- if (typeof name == 'string') { // if min/max was set with the string
1580
- if (name === 'minDate' || name === 'minDateTime') {
1581
- min = value;
1582
- } else if (name === 'maxDate' || name === 'maxDateTime') {
1583
- max = value;
1584
- } else if (name === 'onSelect') {
1585
- onselect = value;
1586
- } else if (overrides.hasOwnProperty(name)) {
1587
- if (typeof (value) === 'undefined') {
1588
- return overrides[name];
1589
- }
1590
- fns[name] = value;
1591
- name_clone = {}; //empty results in exiting function after overrides updated
1592
- }
1593
- } else if (typeof name == 'object') { //if min/max was set with the JSON
1594
- if (name.minDate) {
1595
- min = name.minDate;
1596
- } else if (name.minDateTime) {
1597
- min = name.minDateTime;
1598
- } else if (name.maxDate) {
1599
- max = name.maxDate;
1600
- } else if (name.maxDateTime) {
1601
- max = name.maxDateTime;
1602
- }
1603
- for (prop in overrides) {
1604
- if (overrides.hasOwnProperty(prop) && name[prop]) {
1605
- fns[prop] = name[prop];
1606
- }
1607
- }
1608
- }
1609
- for (prop in fns) {
1610
- if (fns.hasOwnProperty(prop)) {
1611
- overrides[prop] = fns[prop];
1612
- if (!name_clone) { name_clone = $.extend({}, name);}
1613
- delete name_clone[prop];
1614
- }
1615
- }
1616
- if (name_clone && isEmptyObject(name_clone)) { return; }
1617
- if (min) { //if min was set
1618
- if (min === 0) {
1619
- min = new Date();
1620
- } else {
1621
- min = new Date(min);
1622
- }
1623
- tp_inst._defaults.minDate = min;
1624
- tp_inst._defaults.minDateTime = min;
1625
- } else if (max) { //if max was set
1626
- if (max === 0) {
1627
- max = new Date();
1628
- } else {
1629
- max = new Date(max);
1630
- }
1631
- tp_inst._defaults.maxDate = max;
1632
- tp_inst._defaults.maxDateTime = max;
1633
- } else if (onselect) {
1634
- tp_inst._defaults.onSelect = onselect;
1635
- }
1636
- }
1637
- if (value === undefined) {
1638
- return this._base_optionDatepicker.call($.datepicker, target, name);
1639
- }
1640
- return this._base_optionDatepicker.call($.datepicker, target, name_clone || name, value);
1641
- };
1642
- /*
1643
- * jQuery isEmptyObject does not check hasOwnProperty - if someone has added to the object prototype,
1644
- * it will return false for all objects
1645
- */
1646
- var isEmptyObject = function(obj) {
1647
- var prop;
1648
- for (prop in obj) {
1649
- if (obj.hasOwnProperty(obj)) {
1650
- return false;
1651
- }
1652
- }
1653
- return true;
1654
- };
1655
-
1656
- /*
1657
- * jQuery extend now ignores nulls!