author | ymh <ymh.work@gmail.com> |
Mon, 08 Sep 2025 19:44:41 +0200 | |
changeset 23 | 417f20492bf7 |
parent 22 | 8c2e4d02f4ef |
permissions | -rw-r--r-- |
9 | 1 |
/** |
2 |
* @output wp-admin/js/common.js |
|
3 |
*/ |
|
4 |
||
16 | 5 |
/* global setUserSetting, ajaxurl, alert, confirm, pagenow */ |
9 | 6 |
/* global columns, screenMeta */ |
7 |
||
8 |
/** |
|
9 |
* Adds common WordPress functionality to the window. |
|
10 |
* |
|
11 |
* @param {jQuery} $ jQuery object. |
|
12 |
* @param {Object} window The window object. |
|
13 |
* @param {mixed} undefined Unused. |
|
14 |
*/ |
|
5 | 15 |
( function( $, window, undefined ) { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
16 |
var $document = $( document ), |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
17 |
$window = $( window ), |
16 | 18 |
$body = $( document.body ), |
19 |
__ = wp.i18n.__, |
|
20 |
sprintf = wp.i18n.sprintf; |
|
21 |
||
22 |
/** |
|
23 |
* Throws an error for a deprecated property. |
|
24 |
* |
|
25 |
* @since 5.5.1 |
|
26 |
* |
|
27 |
* @param {string} propName The property that was used. |
|
28 |
* @param {string} version The version of WordPress that deprecated the property. |
|
29 |
* @param {string} replacement The property that should have been used. |
|
30 |
*/ |
|
31 |
function deprecatedProperty( propName, version, replacement ) { |
|
32 |
var message; |
|
33 |
||
34 |
if ( 'undefined' !== typeof replacement ) { |
|
35 |
message = sprintf( |
|
36 |
/* translators: 1: Deprecated property name, 2: Version number, 3: Alternative property name. */ |
|
37 |
__( '%1$s is deprecated since version %2$s! Use %3$s instead.' ), |
|
38 |
propName, |
|
39 |
version, |
|
40 |
replacement |
|
41 |
); |
|
42 |
} else { |
|
43 |
message = sprintf( |
|
44 |
/* translators: 1: Deprecated property name, 2: Version number. */ |
|
45 |
__( '%1$s is deprecated since version %2$s with no alternative available.' ), |
|
46 |
propName, |
|
47 |
version |
|
48 |
); |
|
49 |
} |
|
50 |
||
51 |
window.console.warn( message ); |
|
52 |
} |
|
53 |
||
54 |
/** |
|
55 |
* Deprecate all properties on an object. |
|
56 |
* |
|
57 |
* @since 5.5.1 |
|
18 | 58 |
* @since 5.6.0 Added the `version` parameter. |
16 | 59 |
* |
60 |
* @param {string} name The name of the object, i.e. commonL10n. |
|
61 |
* @param {object} l10nObject The object to deprecate the properties on. |
|
18 | 62 |
* @param {string} version The version of WordPress that deprecated the property. |
16 | 63 |
* |
64 |
* @return {object} The object with all its properties deprecated. |
|
65 |
*/ |
|
18 | 66 |
function deprecateL10nObject( name, l10nObject, version ) { |
16 | 67 |
var deprecatedObject = {}; |
68 |
||
69 |
Object.keys( l10nObject ).forEach( function( key ) { |
|
70 |
var prop = l10nObject[ key ]; |
|
71 |
var propName = name + '.' + key; |
|
72 |
||
73 |
if ( 'object' === typeof prop ) { |
|
74 |
Object.defineProperty( deprecatedObject, key, { get: function() { |
|
18 | 75 |
deprecatedProperty( propName, version, prop.alternative ); |
16 | 76 |
return prop.func(); |
77 |
} } ); |
|
78 |
} else { |
|
79 |
Object.defineProperty( deprecatedObject, key, { get: function() { |
|
18 | 80 |
deprecatedProperty( propName, version, 'wp.i18n' ); |
16 | 81 |
return prop; |
82 |
} } ); |
|
83 |
} |
|
84 |
} ); |
|
85 |
||
86 |
return deprecatedObject; |
|
87 |
} |
|
88 |
||
89 |
window.wp.deprecateL10nObject = deprecateL10nObject; |
|
90 |
||
91 |
/** |
|
92 |
* Removed in 5.5.0, needed for back-compatibility. |
|
93 |
* |
|
94 |
* @since 2.6.0 |
|
95 |
* @deprecated 5.5.0 |
|
96 |
*/ |
|
97 |
window.commonL10n = window.commonL10n || { |
|
98 |
warnDelete: '', |
|
99 |
dismiss: '', |
|
100 |
collapseMenu: '', |
|
101 |
expandMenu: '' |
|
102 |
}; |
|
103 |
||
18 | 104 |
window.commonL10n = deprecateL10nObject( 'commonL10n', window.commonL10n, '5.5.0' ); |
16 | 105 |
|
106 |
/** |
|
107 |
* Removed in 5.5.0, needed for back-compatibility. |
|
108 |
* |
|
109 |
* @since 3.3.0 |
|
110 |
* @deprecated 5.5.0 |
|
111 |
*/ |
|
112 |
window.wpPointerL10n = window.wpPointerL10n || { |
|
113 |
dismiss: '' |
|
114 |
}; |
|
115 |
||
18 | 116 |
window.wpPointerL10n = deprecateL10nObject( 'wpPointerL10n', window.wpPointerL10n, '5.5.0' ); |
16 | 117 |
|
118 |
/** |
|
119 |
* Removed in 5.5.0, needed for back-compatibility. |
|
120 |
* |
|
121 |
* @since 4.3.0 |
|
122 |
* @deprecated 5.5.0 |
|
123 |
*/ |
|
124 |
window.userProfileL10n = window.userProfileL10n || { |
|
125 |
warn: '', |
|
126 |
warnWeak: '', |
|
127 |
show: '', |
|
128 |
hide: '', |
|
129 |
cancel: '', |
|
130 |
ariaShow: '', |
|
131 |
ariaHide: '' |
|
132 |
}; |
|
133 |
||
18 | 134 |
window.userProfileL10n = deprecateL10nObject( 'userProfileL10n', window.userProfileL10n, '5.5.0' ); |
16 | 135 |
|
136 |
/** |
|
137 |
* Removed in 5.5.0, needed for back-compatibility. |
|
138 |
* |
|
139 |
* @since 4.9.6 |
|
140 |
* @deprecated 5.5.0 |
|
141 |
*/ |
|
142 |
window.privacyToolsL10n = window.privacyToolsL10n || { |
|
143 |
noDataFound: '', |
|
144 |
foundAndRemoved: '', |
|
145 |
noneRemoved: '', |
|
146 |
someNotRemoved: '', |
|
147 |
removalError: '', |
|
148 |
emailSent: '', |
|
149 |
noExportFile: '', |
|
150 |
exportError: '' |
|
151 |
}; |
|
152 |
||
18 | 153 |
window.privacyToolsL10n = deprecateL10nObject( 'privacyToolsL10n', window.privacyToolsL10n, '5.5.0' ); |
16 | 154 |
|
155 |
/** |
|
156 |
* Removed in 5.5.0, needed for back-compatibility. |
|
157 |
* |
|
158 |
* @since 3.6.0 |
|
159 |
* @deprecated 5.5.0 |
|
160 |
*/ |
|
161 |
window.authcheckL10n = { |
|
162 |
beforeunload: '' |
|
163 |
}; |
|
164 |
||
18 | 165 |
window.authcheckL10n = window.authcheckL10n || deprecateL10nObject( 'authcheckL10n', window.authcheckL10n, '5.5.0' ); |
16 | 166 |
|
167 |
/** |
|
168 |
* Removed in 5.5.0, needed for back-compatibility. |
|
169 |
* |
|
170 |
* @since 2.8.0 |
|
171 |
* @deprecated 5.5.0 |
|
172 |
*/ |
|
173 |
window.tagsl10n = { |
|
174 |
noPerm: '', |
|
175 |
broken: '' |
|
176 |
}; |
|
177 |
||
18 | 178 |
window.tagsl10n = window.tagsl10n || deprecateL10nObject( 'tagsl10n', window.tagsl10n, '5.5.0' ); |
16 | 179 |
|
180 |
/** |
|
181 |
* Removed in 5.5.0, needed for back-compatibility. |
|
182 |
* |
|
183 |
* @since 2.5.0 |
|
184 |
* @deprecated 5.5.0 |
|
185 |
*/ |
|
186 |
window.adminCommentsL10n = window.adminCommentsL10n || { |
|
187 |
hotkeys_highlight_first: { |
|
188 |
alternative: 'window.adminCommentsSettings.hotkeys_highlight_first', |
|
189 |
func: function() { return window.adminCommentsSettings.hotkeys_highlight_first; } |
|
190 |
}, |
|
191 |
hotkeys_highlight_last: { |
|
192 |
alternative: 'window.adminCommentsSettings.hotkeys_highlight_last', |
|
193 |
func: function() { return window.adminCommentsSettings.hotkeys_highlight_last; } |
|
194 |
}, |
|
195 |
replyApprove: '', |
|
196 |
reply: '', |
|
197 |
warnQuickEdit: '', |
|
198 |
warnCommentChanges: '', |
|
199 |
docTitleComments: '', |
|
200 |
docTitleCommentsCount: '' |
|
201 |
}; |
|
202 |
||
18 | 203 |
window.adminCommentsL10n = deprecateL10nObject( 'adminCommentsL10n', window.adminCommentsL10n, '5.5.0' ); |
16 | 204 |
|
205 |
/** |
|
206 |
* Removed in 5.5.0, needed for back-compatibility. |
|
207 |
* |
|
208 |
* @since 2.5.0 |
|
209 |
* @deprecated 5.5.0 |
|
210 |
*/ |
|
211 |
window.tagsSuggestL10n = window.tagsSuggestL10n || { |
|
212 |
tagDelimiter: '', |
|
213 |
removeTerm: '', |
|
214 |
termSelected: '', |
|
215 |
termAdded: '', |
|
216 |
termRemoved: '' |
|
217 |
}; |
|
218 |
||
18 | 219 |
window.tagsSuggestL10n = deprecateL10nObject( 'tagsSuggestL10n', window.tagsSuggestL10n, '5.5.0' ); |
16 | 220 |
|
221 |
/** |
|
222 |
* Removed in 5.5.0, needed for back-compatibility. |
|
223 |
* |
|
224 |
* @since 3.5.0 |
|
225 |
* @deprecated 5.5.0 |
|
226 |
*/ |
|
227 |
window.wpColorPickerL10n = window.wpColorPickerL10n || { |
|
228 |
clear: '', |
|
229 |
clearAriaLabel: '', |
|
230 |
defaultString: '', |
|
231 |
defaultAriaLabel: '', |
|
232 |
pick: '', |
|
233 |
defaultLabel: '' |
|
234 |
}; |
|
235 |
||
18 | 236 |
window.wpColorPickerL10n = deprecateL10nObject( 'wpColorPickerL10n', window.wpColorPickerL10n, '5.5.0' ); |
16 | 237 |
|
238 |
/** |
|
239 |
* Removed in 5.5.0, needed for back-compatibility. |
|
240 |
* |
|
241 |
* @since 2.7.0 |
|
242 |
* @deprecated 5.5.0 |
|
243 |
*/ |
|
244 |
window.attachMediaBoxL10n = window.attachMediaBoxL10n || { |
|
245 |
error: '' |
|
246 |
}; |
|
247 |
||
18 | 248 |
window.attachMediaBoxL10n = deprecateL10nObject( 'attachMediaBoxL10n', window.attachMediaBoxL10n, '5.5.0' ); |
16 | 249 |
|
250 |
/** |
|
251 |
* Removed in 5.5.0, needed for back-compatibility. |
|
252 |
* |
|
253 |
* @since 2.5.0 |
|
254 |
* @deprecated 5.5.0 |
|
255 |
*/ |
|
256 |
window.postL10n = window.postL10n || { |
|
257 |
ok: '', |
|
258 |
cancel: '', |
|
259 |
publishOn: '', |
|
260 |
publishOnFuture: '', |
|
261 |
publishOnPast: '', |
|
262 |
dateFormat: '', |
|
263 |
showcomm: '', |
|
264 |
endcomm: '', |
|
265 |
publish: '', |
|
266 |
schedule: '', |
|
267 |
update: '', |
|
268 |
savePending: '', |
|
269 |
saveDraft: '', |
|
270 |
'private': '', |
|
271 |
'public': '', |
|
272 |
publicSticky: '', |
|
273 |
password: '', |
|
274 |
privatelyPublished: '', |
|
275 |
published: '', |
|
276 |
saveAlert: '', |
|
277 |
savingText: '', |
|
278 |
permalinkSaved: '' |
|
279 |
}; |
|
280 |
||
18 | 281 |
window.postL10n = deprecateL10nObject( 'postL10n', window.postL10n, '5.5.0' ); |
16 | 282 |
|
283 |
/** |
|
284 |
* Removed in 5.5.0, needed for back-compatibility. |
|
285 |
* |
|
286 |
* @since 2.7.0 |
|
287 |
* @deprecated 5.5.0 |
|
288 |
*/ |
|
289 |
window.inlineEditL10n = window.inlineEditL10n || { |
|
290 |
error: '', |
|
291 |
ntdeltitle: '', |
|
292 |
notitle: '', |
|
293 |
comma: '', |
|
294 |
saved: '' |
|
295 |
}; |
|
296 |
||
18 | 297 |
window.inlineEditL10n = deprecateL10nObject( 'inlineEditL10n', window.inlineEditL10n, '5.5.0' ); |
16 | 298 |
|
299 |
/** |
|
300 |
* Removed in 5.5.0, needed for back-compatibility. |
|
301 |
* |
|
302 |
* @since 2.7.0 |
|
303 |
* @deprecated 5.5.0 |
|
304 |
*/ |
|
305 |
window.plugininstallL10n = window.plugininstallL10n || { |
|
306 |
plugin_information: '', |
|
307 |
plugin_modal_label: '', |
|
308 |
ays: '' |
|
309 |
}; |
|
310 |
||
18 | 311 |
window.plugininstallL10n = deprecateL10nObject( 'plugininstallL10n', window.plugininstallL10n, '5.5.0' ); |
16 | 312 |
|
313 |
/** |
|
314 |
* Removed in 5.5.0, needed for back-compatibility. |
|
315 |
* |
|
316 |
* @since 3.0.0 |
|
317 |
* @deprecated 5.5.0 |
|
318 |
*/ |
|
319 |
window.navMenuL10n = window.navMenuL10n || { |
|
320 |
noResultsFound: '', |
|
321 |
warnDeleteMenu: '', |
|
322 |
saveAlert: '', |
|
323 |
untitled: '' |
|
324 |
}; |
|
325 |
||
18 | 326 |
window.navMenuL10n = deprecateL10nObject( 'navMenuL10n', window.navMenuL10n, '5.5.0' ); |
16 | 327 |
|
328 |
/** |
|
329 |
* Removed in 5.5.0, needed for back-compatibility. |
|
330 |
* |
|
331 |
* @since 2.5.0 |
|
332 |
* @deprecated 5.5.0 |
|
333 |
*/ |
|
334 |
window.commentL10n = window.commentL10n || { |
|
335 |
submittedOn: '', |
|
336 |
dateFormat: '' |
|
337 |
}; |
|
338 |
||
18 | 339 |
window.commentL10n = deprecateL10nObject( 'commentL10n', window.commentL10n, '5.5.0' ); |
16 | 340 |
|
341 |
/** |
|
342 |
* Removed in 5.5.0, needed for back-compatibility. |
|
343 |
* |
|
344 |
* @since 2.9.0 |
|
345 |
* @deprecated 5.5.0 |
|
346 |
*/ |
|
347 |
window.setPostThumbnailL10n = window.setPostThumbnailL10n || { |
|
348 |
setThumbnail: '', |
|
349 |
saving: '', |
|
350 |
error: '', |
|
351 |
done: '' |
|
352 |
}; |
|
353 |
||
18 | 354 |
window.setPostThumbnailL10n = deprecateL10nObject( 'setPostThumbnailL10n', window.setPostThumbnailL10n, '5.5.0' ); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
355 |
|
9 | 356 |
/** |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
357 |
* Removed in 6.5.0, needed for back-compatibility. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
358 |
* |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
359 |
* @since 4.5.0 |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
360 |
* @deprecated 6.5.0 |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
361 |
*/ |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
362 |
window.uiAutocompleteL10n = window.uiAutocompleteL10n || { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
363 |
noResults: '', |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
364 |
oneResult: '', |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
365 |
manyResults: '', |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
366 |
itemSelected: '' |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
367 |
}; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
368 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
369 |
window.uiAutocompleteL10n = deprecateL10nObject( 'uiAutocompleteL10n', window.uiAutocompleteL10n, '6.5.0' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
370 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
371 |
/** |
9 | 372 |
* Removed in 3.3.0, needed for back-compatibility. |
373 |
* |
|
374 |
* @since 2.7.0 |
|
375 |
* @deprecated 3.3.0 |
|
376 |
*/ |
|
377 |
window.adminMenu = { |
|
0 | 378 |
init : function() {}, |
379 |
fold : function() {}, |
|
380 |
restoreMenuState : function() {}, |
|
381 |
toggle : function() {}, |
|
382 |
favorites : function() {} |
|
383 |
}; |
|
384 |
||
9 | 385 |
// Show/hide/save table columns. |
386 |
window.columns = { |
|
387 |
||
388 |
/** |
|
389 |
* Initializes the column toggles in the screen options. |
|
390 |
* |
|
391 |
* Binds an onClick event to the checkboxes to show or hide the table columns |
|
392 |
* based on their toggled state. And persists the toggled state. |
|
393 |
* |
|
394 |
* @since 2.7.0 |
|
395 |
* |
|
16 | 396 |
* @return {void} |
9 | 397 |
*/ |
0 | 398 |
init : function() { |
399 |
var that = this; |
|
18 | 400 |
$('.hide-column-tog', '#adv-settings').on( 'click', function() { |
0 | 401 |
var $t = $(this), column = $t.val(); |
402 |
if ( $t.prop('checked') ) |
|
403 |
that.checked(column); |
|
404 |
else |
|
405 |
that.unchecked(column); |
|
406 |
||
407 |
columns.saveManageColumnsState(); |
|
408 |
}); |
|
409 |
}, |
|
410 |
||
9 | 411 |
/** |
412 |
* Saves the toggled state for the columns. |
|
413 |
* |
|
414 |
* Saves whether the columns should be shown or hidden on a page. |
|
415 |
* |
|
416 |
* @since 3.0.0 |
|
417 |
* |
|
16 | 418 |
* @return {void} |
9 | 419 |
*/ |
0 | 420 |
saveManageColumnsState : function() { |
421 |
var hidden = this.hidden(); |
|
22
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
422 |
$.post( |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
423 |
ajaxurl, |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
424 |
{ |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
425 |
action: 'hidden-columns', |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
426 |
hidden: hidden, |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
427 |
screenoptionnonce: $('#screenoptionnonce').val(), |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
428 |
page: pagenow |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
429 |
}, |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
430 |
function() { |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
431 |
wp.a11y.speak( __( 'Screen Options updated.' ) ); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
432 |
} |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
433 |
); |
0 | 434 |
}, |
435 |
||
9 | 436 |
/** |
437 |
* Makes a column visible and adjusts the column span for the table. |
|
438 |
* |
|
439 |
* @since 3.0.0 |
|
440 |
* @param {string} column The column name. |
|
441 |
* |
|
16 | 442 |
* @return {void} |
9 | 443 |
*/ |
0 | 444 |
checked : function(column) { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
445 |
$('.column-' + column).removeClass( 'hidden' ); |
0 | 446 |
this.colSpanChange(+1); |
447 |
}, |
|
448 |
||
9 | 449 |
/** |
450 |
* Hides a column and adjusts the column span for the table. |
|
451 |
* |
|
452 |
* @since 3.0.0 |
|
453 |
* @param {string} column The column name. |
|
454 |
* |
|
16 | 455 |
* @return {void} |
9 | 456 |
*/ |
0 | 457 |
unchecked : function(column) { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
458 |
$('.column-' + column).addClass( 'hidden' ); |
0 | 459 |
this.colSpanChange(-1); |
460 |
}, |
|
461 |
||
9 | 462 |
/** |
463 |
* Gets all hidden columns. |
|
464 |
* |
|
465 |
* @since 3.0.0 |
|
466 |
* |
|
16 | 467 |
* @return {string} The hidden column names separated by a comma. |
9 | 468 |
*/ |
0 | 469 |
hidden : function() { |
9 | 470 |
return $( '.manage-column[id]' ).filter( '.hidden' ).map(function() { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
471 |
return this.id; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
472 |
}).get().join( ',' ); |
0 | 473 |
}, |
474 |
||
9 | 475 |
/** |
476 |
* Gets the checked column toggles from the screen options. |
|
477 |
* |
|
478 |
* @since 3.0.0 |
|
479 |
* |
|
16 | 480 |
* @return {string} String containing the checked column names. |
9 | 481 |
*/ |
0 | 482 |
useCheckboxesForHidden : function() { |
483 |
this.hidden = function(){ |
|
484 |
return $('.hide-column-tog').not(':checked').map(function() { |
|
485 |
var id = this.id; |
|
486 |
return id.substring( id, id.length - 5 ); |
|
487 |
}).get().join(','); |
|
488 |
}; |
|
489 |
}, |
|
490 |
||
9 | 491 |
/** |
492 |
* Adjusts the column span for the table. |
|
493 |
* |
|
494 |
* @since 3.1.0 |
|
495 |
* |
|
16 | 496 |
* @param {number} diff The modifier for the column span. |
9 | 497 |
*/ |
0 | 498 |
colSpanChange : function(diff) { |
499 |
var $t = $('table').find('.colspanchange'), n; |
|
500 |
if ( !$t.length ) |
|
501 |
return; |
|
502 |
n = parseInt( $t.attr('colspan'), 10 ) + diff; |
|
503 |
$t.attr('colspan', n.toString()); |
|
504 |
} |
|
5 | 505 |
}; |
0 | 506 |
|
18 | 507 |
$( function() { columns.init(); } ); |
0 | 508 |
|
9 | 509 |
/** |
510 |
* Validates that the required form fields are not empty. |
|
511 |
* |
|
512 |
* @since 2.9.0 |
|
513 |
* |
|
514 |
* @param {jQuery} form The form to validate. |
|
515 |
* |
|
16 | 516 |
* @return {boolean} Returns true if all required fields are not an empty string. |
9 | 517 |
*/ |
518 |
window.validateForm = function( form ) { |
|
5 | 519 |
return !$( form ) |
520 |
.find( '.form-required' ) |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
521 |
.filter( function() { return $( ':input:visible', this ).val() === ''; } ) |
5 | 522 |
.addClass( 'form-invalid' ) |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
523 |
.find( ':input:visible' ) |
18 | 524 |
.on( 'change', function() { $( this ).closest( '.form-invalid' ).removeClass( 'form-invalid' ); } ) |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
525 |
.length; |
5 | 526 |
}; |
0 | 527 |
|
16 | 528 |
// Stub for doing better warnings. |
9 | 529 |
/** |
530 |
* Shows message pop-up notice or confirmation message. |
|
531 |
* |
|
532 |
* @since 2.7.0 |
|
533 |
* |
|
534 |
* @type {{warn: showNotice.warn, note: showNotice.note}} |
|
535 |
* |
|
16 | 536 |
* @return {void} |
9 | 537 |
*/ |
538 |
window.showNotice = { |
|
539 |
||
540 |
/** |
|
541 |
* Shows a delete confirmation pop-up message. |
|
542 |
* |
|
543 |
* @since 2.7.0 |
|
544 |
* |
|
16 | 545 |
* @return {boolean} Returns true if the message is confirmed. |
9 | 546 |
*/ |
0 | 547 |
warn : function() { |
16 | 548 |
if ( confirm( __( 'You are about to permanently delete these items from your site.\nThis action cannot be undone.\n\'Cancel\' to stop, \'OK\' to delete.' ) ) ) { |
0 | 549 |
return true; |
550 |
} |
|
551 |
||
552 |
return false; |
|
553 |
}, |
|
554 |
||
9 | 555 |
/** |
556 |
* Shows an alert message. |
|
557 |
* |
|
558 |
* @since 2.7.0 |
|
559 |
* |
|
560 |
* @param text The text to display in the message. |
|
561 |
*/ |
|
0 | 562 |
note : function(text) { |
563 |
alert(text); |
|
564 |
} |
|
565 |
}; |
|
566 |
||
9 | 567 |
/** |
568 |
* Represents the functions for the meta screen options panel. |
|
569 |
* |
|
570 |
* @since 3.2.0 |
|
571 |
* |
|
572 |
* @type {{element: null, toggles: null, page: null, init: screenMeta.init, |
|
573 |
* toggleEvent: screenMeta.toggleEvent, open: screenMeta.open, |
|
574 |
* close: screenMeta.close}} |
|
575 |
* |
|
16 | 576 |
* @return {void} |
9 | 577 |
*/ |
578 |
window.screenMeta = { |
|
0 | 579 |
element: null, // #screen-meta |
580 |
toggles: null, // .screen-meta-toggle |
|
581 |
page: null, // #wpcontent |
|
582 |
||
9 | 583 |
/** |
584 |
* Initializes the screen meta options panel. |
|
585 |
* |
|
586 |
* @since 3.2.0 |
|
587 |
* |
|
16 | 588 |
* @return {void} |
9 | 589 |
*/ |
0 | 590 |
init: function() { |
591 |
this.element = $('#screen-meta'); |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
592 |
this.toggles = $( '#screen-meta-links' ).find( '.show-settings' ); |
0 | 593 |
this.page = $('#wpcontent'); |
594 |
||
18 | 595 |
this.toggles.on( 'click', this.toggleEvent ); |
0 | 596 |
}, |
597 |
||
9 | 598 |
/** |
599 |
* Toggles the screen meta options panel. |
|
600 |
* |
|
601 |
* @since 3.2.0 |
|
602 |
* |
|
16 | 603 |
* @return {void} |
9 | 604 |
*/ |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
605 |
toggleEvent: function() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
606 |
var panel = $( '#' + $( this ).attr( 'aria-controls' ) ); |
0 | 607 |
|
608 |
if ( !panel.length ) |
|
609 |
return; |
|
610 |
||
611 |
if ( panel.is(':visible') ) |
|
612 |
screenMeta.close( panel, $(this) ); |
|
613 |
else |
|
614 |
screenMeta.open( panel, $(this) ); |
|
615 |
}, |
|
616 |
||
9 | 617 |
/** |
618 |
* Opens the screen meta options panel. |
|
619 |
* |
|
620 |
* @since 3.2.0 |
|
621 |
* |
|
622 |
* @param {jQuery} panel The screen meta options panel div. |
|
623 |
* @param {jQuery} button The toggle button. |
|
624 |
* |
|
16 | 625 |
* @return {void} |
9 | 626 |
*/ |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
627 |
open: function( panel, button ) { |
0 | 628 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
629 |
$( '#screen-meta-links' ).find( '.screen-meta-toggle' ).not( button.parent() ).css( 'visibility', 'hidden' ); |
0 | 630 |
|
631 |
panel.parent().show(); |
|
9 | 632 |
|
633 |
/** |
|
634 |
* Sets the focus to the meta options panel and adds the necessary CSS classes. |
|
635 |
* |
|
636 |
* @since 3.2.0 |
|
637 |
* |
|
16 | 638 |
* @return {void} |
9 | 639 |
*/ |
0 | 640 |
panel.slideDown( 'fast', function() { |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
641 |
panel.removeClass( 'hidden' ).trigger( 'focus' ); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
642 |
button.addClass( 'screen-meta-active' ).attr( 'aria-expanded', true ); |
0 | 643 |
}); |
5 | 644 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
645 |
$document.trigger( 'screen:options:open' ); |
0 | 646 |
}, |
647 |
||
9 | 648 |
/** |
649 |
* Closes the screen meta options panel. |
|
650 |
* |
|
651 |
* @since 3.2.0 |
|
652 |
* |
|
653 |
* @param {jQuery} panel The screen meta options panel div. |
|
654 |
* @param {jQuery} button The toggle button. |
|
655 |
* |
|
16 | 656 |
* @return {void} |
9 | 657 |
*/ |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
658 |
close: function( panel, button ) { |
9 | 659 |
/** |
660 |
* Hides the screen meta options panel. |
|
661 |
* |
|
662 |
* @since 3.2.0 |
|
663 |
* |
|
16 | 664 |
* @return {void} |
9 | 665 |
*/ |
0 | 666 |
panel.slideUp( 'fast', function() { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
667 |
button.removeClass( 'screen-meta-active' ).attr( 'aria-expanded', false ); |
0 | 668 |
$('.screen-meta-toggle').css('visibility', ''); |
669 |
panel.parent().hide(); |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
670 |
panel.addClass( 'hidden' ); |
0 | 671 |
}); |
5 | 672 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
673 |
$document.trigger( 'screen:options:close' ); |
0 | 674 |
} |
675 |
}; |
|
676 |
||
677 |
/** |
|
9 | 678 |
* Initializes the help tabs in the help panel. |
679 |
* |
|
680 |
* @param {Event} e The event object. |
|
681 |
* |
|
16 | 682 |
* @return {void} |
0 | 683 |
*/ |
18 | 684 |
$('.contextual-help-tabs').on( 'click', 'a', function(e) { |
0 | 685 |
var link = $(this), |
686 |
panel; |
|
687 |
||
688 |
e.preventDefault(); |
|
689 |
||
690 |
// Don't do anything if the click is for the tab already showing. |
|
691 |
if ( link.is('.active a') ) |
|
692 |
return false; |
|
693 |
||
16 | 694 |
// Links. |
0 | 695 |
$('.contextual-help-tabs .active').removeClass('active'); |
696 |
link.parent('li').addClass('active'); |
|
697 |
||
698 |
panel = $( link.attr('href') ); |
|
699 |
||
16 | 700 |
// Panels. |
0 | 701 |
$('.help-tab-content').not( panel ).removeClass('active').hide(); |
702 |
panel.addClass('active').show(); |
|
703 |
}); |
|
704 |
||
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
705 |
/** |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
706 |
* Update custom permalink structure via buttons. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
707 |
*/ |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
708 |
var permalinkStructureFocused = false, |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
709 |
$permalinkStructure = $( '#permalink_structure' ), |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
710 |
$permalinkStructureInputs = $( '.permalink-structure input:radio' ), |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
711 |
$permalinkCustomSelection = $( '#custom_selection' ), |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
712 |
$availableStructureTags = $( '.form-table.permalink-structure .available-structure-tags button' ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
713 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
714 |
// Change permalink structure input when selecting one of the common structures. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
715 |
$permalinkStructureInputs.on( 'change', function() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
716 |
if ( 'custom' === this.value ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
717 |
return; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
718 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
719 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
720 |
$permalinkStructure.val( this.value ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
721 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
722 |
// Update button states after selection. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
723 |
$availableStructureTags.each( function() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
724 |
changeStructureTagButtonState( $( this ) ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
725 |
} ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
726 |
} ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
727 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
728 |
$permalinkStructure.on( 'click input', function() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
729 |
$permalinkCustomSelection.prop( 'checked', true ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
730 |
} ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
731 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
732 |
// Check if the permalink structure input field has had focus at least once. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
733 |
$permalinkStructure.on( 'focus', function( event ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
734 |
permalinkStructureFocused = true; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
735 |
$( this ).off( event ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
736 |
} ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
737 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
738 |
/** |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
739 |
* Enables or disables a structure tag button depending on its usage. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
740 |
* |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
741 |
* If the structure is already used in the custom permalink structure, |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
742 |
* it will be disabled. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
743 |
* |
16 | 744 |
* @param {Object} button Button jQuery object. |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
745 |
*/ |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
746 |
function changeStructureTagButtonState( button ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
747 |
if ( -1 !== $permalinkStructure.val().indexOf( button.text().trim() ) ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
748 |
button.attr( 'data-label', button.attr( 'aria-label' ) ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
749 |
button.attr( 'aria-label', button.attr( 'data-used' ) ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
750 |
button.attr( 'aria-pressed', true ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
751 |
button.addClass( 'active' ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
752 |
} else if ( button.attr( 'data-label' ) ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
753 |
button.attr( 'aria-label', button.attr( 'data-label' ) ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
754 |
button.attr( 'aria-pressed', false ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
755 |
button.removeClass( 'active' ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
756 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
757 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
758 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
759 |
// Check initial button state. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
760 |
$availableStructureTags.each( function() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
761 |
changeStructureTagButtonState( $( this ) ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
762 |
} ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
763 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
764 |
// Observe permalink structure field and disable buttons of tags that are already present. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
765 |
$permalinkStructure.on( 'change', function() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
766 |
$availableStructureTags.each( function() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
767 |
changeStructureTagButtonState( $( this ) ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
768 |
} ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
769 |
} ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
770 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
771 |
$availableStructureTags.on( 'click', function() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
772 |
var permalinkStructureValue = $permalinkStructure.val(), |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
773 |
selectionStart = $permalinkStructure[ 0 ].selectionStart, |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
774 |
selectionEnd = $permalinkStructure[ 0 ].selectionEnd, |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
775 |
textToAppend = $( this ).text().trim(), |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
776 |
textToAnnounce, |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
777 |
newSelectionStart; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
778 |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
779 |
if ( $( this ).hasClass( 'active' ) ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
780 |
textToAnnounce = $( this ).attr( 'data-removed' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
781 |
} else { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
782 |
textToAnnounce = $( this ).attr( 'data-added' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
783 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
784 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
785 |
// Remove structure tag if already part of the structure. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
786 |
if ( -1 !== permalinkStructureValue.indexOf( textToAppend ) ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
787 |
permalinkStructureValue = permalinkStructureValue.replace( textToAppend + '/', '' ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
788 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
789 |
$permalinkStructure.val( '/' === permalinkStructureValue ? '' : permalinkStructureValue ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
790 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
791 |
// Announce change to screen readers. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
792 |
$( '#custom_selection_updated' ).text( textToAnnounce ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
793 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
794 |
// Disable button. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
795 |
changeStructureTagButtonState( $( this ) ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
796 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
797 |
return; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
798 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
799 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
800 |
// Input field never had focus, move selection to end of input. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
801 |
if ( ! permalinkStructureFocused && 0 === selectionStart && 0 === selectionEnd ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
802 |
selectionStart = selectionEnd = permalinkStructureValue.length; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
803 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
804 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
805 |
$permalinkCustomSelection.prop( 'checked', true ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
806 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
807 |
// Prepend and append slashes if necessary. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
808 |
if ( '/' !== permalinkStructureValue.substr( 0, selectionStart ).substr( -1 ) ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
809 |
textToAppend = '/' + textToAppend; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
810 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
811 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
812 |
if ( '/' !== permalinkStructureValue.substr( selectionEnd, 1 ) ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
813 |
textToAppend = textToAppend + '/'; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
814 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
815 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
816 |
// Insert structure tag at the specified position. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
817 |
$permalinkStructure.val( permalinkStructureValue.substr( 0, selectionStart ) + textToAppend + permalinkStructureValue.substr( selectionEnd ) ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
818 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
819 |
// Announce change to screen readers. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
820 |
$( '#custom_selection_updated' ).text( textToAnnounce ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
821 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
822 |
// Disable button. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
823 |
changeStructureTagButtonState( $( this ) ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
824 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
825 |
// If input had focus give it back with cursor right after appended text. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
826 |
if ( permalinkStructureFocused && $permalinkStructure[0].setSelectionRange ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
827 |
newSelectionStart = ( permalinkStructureValue.substr( 0, selectionStart ) + textToAppend ).length; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
828 |
$permalinkStructure[0].setSelectionRange( newSelectionStart, newSelectionStart ); |
18 | 829 |
$permalinkStructure.trigger( 'focus' ); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
830 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
831 |
} ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
832 |
|
18 | 833 |
$( function() { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
834 |
var checks, first, last, checked, sliced, mobileEvent, transitionTimeout, focusedRowActions, |
5 | 835 |
lastClicked = false, |
836 |
pageInput = $('input.current-page'), |
|
837 |
currentPage = pageInput.val(), |
|
838 |
isIOS = /iPhone|iPad|iPod/.test( navigator.userAgent ), |
|
839 |
isAndroid = navigator.userAgent.indexOf( 'Android' ) !== -1, |
|
840 |
$adminMenuWrap = $( '#adminmenuwrap' ), |
|
841 |
$wpwrap = $( '#wpwrap' ), |
|
842 |
$adminmenu = $( '#adminmenu' ), |
|
843 |
$overlay = $( '#wp-responsive-overlay' ), |
|
844 |
$toolbar = $( '#wp-toolbar' ), |
|
845 |
$toolbarPopups = $toolbar.find( 'a[aria-haspopup="true"]' ), |
|
846 |
$sortables = $('.meta-box-sortables'), |
|
847 |
wpResponsiveActive = false, |
|
848 |
$adminbar = $( '#wpadminbar' ), |
|
849 |
lastScrollPosition = 0, |
|
850 |
pinnedMenuTop = false, |
|
851 |
pinnedMenuBottom = false, |
|
852 |
menuTop = 0, |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
853 |
menuState, |
5 | 854 |
menuIsPinned = false, |
855 |
height = { |
|
856 |
window: $window.height(), |
|
857 |
wpwrap: $wpwrap.height(), |
|
858 |
adminbar: $adminbar.height(), |
|
859 |
menu: $adminMenuWrap.height() |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
860 |
}, |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
861 |
$headerEnd = $( '.wp-header-end' ); |
5 | 862 |
|
9 | 863 |
/** |
864 |
* Makes the fly-out submenu header clickable, when the menu is folded. |
|
865 |
* |
|
866 |
* @param {Event} e The event object. |
|
867 |
* |
|
16 | 868 |
* @return {void} |
9 | 869 |
*/ |
5 | 870 |
$adminmenu.on('click.wp-submenu-head', '.wp-submenu-head', function(e){ |
0 | 871 |
$(e.target).parent().siblings('a').get(0).click(); |
872 |
}); |
|
873 |
||
9 | 874 |
/** |
875 |
* Collapses the admin menu. |
|
876 |
* |
|
16 | 877 |
* @return {void} |
9 | 878 |
*/ |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
879 |
$( '#collapse-button' ).on( 'click.collapse-menu', function() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
880 |
var viewportWidth = getViewportWidth() || 961; |
0 | 881 |
|
16 | 882 |
// Reset any compensation for submenus near the bottom of the screen. |
0 | 883 |
$('#adminmenu div.wp-submenu').css('margin-top', ''); |
884 |
||
19 | 885 |
if ( viewportWidth <= 960 ) { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
886 |
if ( $body.hasClass('auto-fold') ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
887 |
$body.removeClass('auto-fold').removeClass('folded'); |
0 | 888 |
setUserSetting('unfold', 1); |
889 |
setUserSetting('mfold', 'o'); |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
890 |
menuState = 'open'; |
0 | 891 |
} else { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
892 |
$body.addClass('auto-fold'); |
0 | 893 |
setUserSetting('unfold', 0); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
894 |
menuState = 'folded'; |
0 | 895 |
} |
896 |
} else { |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
897 |
if ( $body.hasClass('folded') ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
898 |
$body.removeClass('folded'); |
0 | 899 |
setUserSetting('mfold', 'o'); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
900 |
menuState = 'open'; |
0 | 901 |
} else { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
902 |
$body.addClass('folded'); |
0 | 903 |
setUserSetting('mfold', 'f'); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
904 |
menuState = 'folded'; |
0 | 905 |
} |
906 |
} |
|
5 | 907 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
908 |
$document.trigger( 'wp-collapse-menu', { state: menuState } ); |
0 | 909 |
}); |
910 |
||
9 | 911 |
/** |
912 |
* Ensures an admin submenu is within the visual viewport. |
|
5 | 913 |
* |
914 |
* @since 4.1.0 |
|
915 |
* |
|
916 |
* @param {jQuery} $menuItem The parent menu item containing the submenu. |
|
9 | 917 |
* |
16 | 918 |
* @return {void} |
5 | 919 |
*/ |
920 |
function adjustSubmenu( $menuItem ) { |
|
921 |
var bottomOffset, pageHeight, adjustment, theFold, menutop, wintop, maxtop, |
|
922 |
$submenu = $menuItem.find( '.wp-submenu' ); |
|
923 |
||
924 |
menutop = $menuItem.offset().top; |
|
925 |
wintop = $window.scrollTop(); |
|
16 | 926 |
maxtop = menutop - wintop - 30; // max = make the top of the sub almost touch admin bar. |
5 | 927 |
|
16 | 928 |
bottomOffset = menutop + $submenu.height() + 1; // Bottom offset of the menu. |
929 |
pageHeight = $wpwrap.height(); // Height of the entire page. |
|
5 | 930 |
adjustment = 60 + bottomOffset - pageHeight; |
16 | 931 |
theFold = $window.height() + wintop - 50; // The fold. |
5 | 932 |
|
933 |
if ( theFold < ( bottomOffset - adjustment ) ) { |
|
934 |
adjustment = bottomOffset - theFold; |
|
935 |
} |
|
936 |
||
937 |
if ( adjustment > maxtop ) { |
|
938 |
adjustment = maxtop; |
|
939 |
} |
|
940 |
||
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
941 |
if ( adjustment > 1 && $('#wp-admin-bar-menu-toggle').is(':hidden') ) { |
5 | 942 |
$submenu.css( 'margin-top', '-' + adjustment + 'px' ); |
943 |
} else { |
|
944 |
$submenu.css( 'margin-top', '' ); |
|
945 |
} |
|
946 |
} |
|
947 |
||
16 | 948 |
if ( 'ontouchstart' in window || /IEMobile\/[1-9]/.test(navigator.userAgent) ) { // Touch screen device. |
949 |
// iOS Safari works with touchstart, the rest work with click. |
|
5 | 950 |
mobileEvent = isIOS ? 'touchstart' : 'click'; |
0 | 951 |
|
9 | 952 |
/** |
953 |
* Closes any open submenus when touch/click is not on the menu. |
|
954 |
* |
|
955 |
* @param {Event} e The event object. |
|
956 |
* |
|
16 | 957 |
* @return {void} |
9 | 958 |
*/ |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
959 |
$body.on( mobileEvent+'.wp-mobile-hover', function(e) { |
5 | 960 |
if ( $adminmenu.data('wp-responsive') ) { |
961 |
return; |
|
962 |
} |
|
963 |
||
964 |
if ( ! $( e.target ).closest( '#adminmenu' ).length ) { |
|
965 |
$adminmenu.find( 'li.opensub' ).removeClass( 'opensub' ); |
|
966 |
} |
|
0 | 967 |
}); |
968 |
||
9 | 969 |
/** |
970 |
* Handles the opening or closing the submenu based on the mobile click|touch event. |
|
971 |
* |
|
972 |
* @param {Event} event The event object. |
|
973 |
* |
|
16 | 974 |
* @return {void} |
9 | 975 |
*/ |
5 | 976 |
$adminmenu.find( 'a.wp-has-submenu' ).on( mobileEvent + '.wp-mobile-hover', function( event ) { |
977 |
var $menuItem = $(this).parent(); |
|
978 |
||
979 |
if ( $adminmenu.data( 'wp-responsive' ) ) { |
|
980 |
return; |
|
981 |
} |
|
0 | 982 |
|
16 | 983 |
/* |
984 |
* Show the sub instead of following the link if: |
|
985 |
* - the submenu is not open. |
|
986 |
* - the submenu is not shown inline or the menu is not folded. |
|
987 |
*/ |
|
5 | 988 |
if ( ! $menuItem.hasClass( 'opensub' ) && ( ! $menuItem.hasClass( 'wp-menu-open' ) || $menuItem.width() < 40 ) ) { |
989 |
event.preventDefault(); |
|
990 |
adjustSubmenu( $menuItem ); |
|
991 |
$adminmenu.find( 'li.opensub' ).removeClass( 'opensub' ); |
|
992 |
$menuItem.addClass('opensub'); |
|
0 | 993 |
} |
994 |
}); |
|
995 |
} |
|
996 |
||
5 | 997 |
if ( ! isIOS && ! isAndroid ) { |
998 |
$adminmenu.find( 'li.wp-has-submenu' ).hoverIntent({ |
|
9 | 999 |
|
1000 |
/** |
|
1001 |
* Opens the submenu when hovered over the menu item for desktops. |
|
1002 |
* |
|
16 | 1003 |
* @return {void} |
9 | 1004 |
*/ |
5 | 1005 |
over: function() { |
1006 |
var $menuItem = $( this ), |
|
1007 |
$submenu = $menuItem.find( '.wp-submenu' ), |
|
1008 |
top = parseInt( $submenu.css( 'top' ), 10 ); |
|
0 | 1009 |
|
16 | 1010 |
if ( isNaN( top ) || top > -5 ) { // The submenu is visible. |
5 | 1011 |
return; |
1012 |
} |
|
0 | 1013 |
|
5 | 1014 |
if ( $adminmenu.data( 'wp-responsive' ) ) { |
16 | 1015 |
// The menu is in responsive mode, bail. |
5 | 1016 |
return; |
1017 |
} |
|
0 | 1018 |
|
5 | 1019 |
adjustSubmenu( $menuItem ); |
1020 |
$adminmenu.find( 'li.opensub' ).removeClass( 'opensub' ); |
|
1021 |
$menuItem.addClass( 'opensub' ); |
|
1022 |
}, |
|
9 | 1023 |
|
1024 |
/** |
|
1025 |
* Closes the submenu when no longer hovering the menu item. |
|
1026 |
* |
|
16 | 1027 |
* @return {void} |
9 | 1028 |
*/ |
5 | 1029 |
out: function(){ |
1030 |
if ( $adminmenu.data( 'wp-responsive' ) ) { |
|
16 | 1031 |
// The menu is in responsive mode, bail. |
5 | 1032 |
return; |
1033 |
} |
|
0 | 1034 |
|
5 | 1035 |
$( this ).removeClass( 'opensub' ).find( '.wp-submenu' ).css( 'margin-top', '' ); |
1036 |
}, |
|
1037 |
timeout: 200, |
|
1038 |
sensitivity: 7, |
|
1039 |
interval: 90 |
|
1040 |
}); |
|
0 | 1041 |
|
9 | 1042 |
/** |
1043 |
* Opens the submenu on when focused on the menu item. |
|
1044 |
* |
|
1045 |
* @param {Event} event The event object. |
|
1046 |
* |
|
16 | 1047 |
* @return {void} |
9 | 1048 |
*/ |
5 | 1049 |
$adminmenu.on( 'focus.adminmenu', '.wp-submenu a', function( event ) { |
1050 |
if ( $adminmenu.data( 'wp-responsive' ) ) { |
|
16 | 1051 |
// The menu is in responsive mode, bail. |
5 | 1052 |
return; |
1053 |
} |
|
1054 |
||
1055 |
$( event.target ).closest( 'li.menu-top' ).addClass( 'opensub' ); |
|
9 | 1056 |
|
1057 |
/** |
|
1058 |
* Closes the submenu on blur from the menu item. |
|
1059 |
* |
|
1060 |
* @param {Event} event The event object. |
|
1061 |
* |
|
16 | 1062 |
* @return {void} |
9 | 1063 |
*/ |
5 | 1064 |
}).on( 'blur.adminmenu', '.wp-submenu a', function( event ) { |
1065 |
if ( $adminmenu.data( 'wp-responsive' ) ) { |
|
1066 |
return; |
|
1067 |
} |
|
1068 |
||
1069 |
$( event.target ).closest( 'li.menu-top' ).removeClass( 'opensub' ); |
|
9 | 1070 |
|
1071 |
/** |
|
1072 |
* Adjusts the size for the submenu. |
|
1073 |
* |
|
16 | 1074 |
* @return {void} |
9 | 1075 |
*/ |
5 | 1076 |
}).find( 'li.wp-has-submenu.wp-not-current-submenu' ).on( 'focusin.adminmenu', function() { |
1077 |
adjustSubmenu( $( this ) ); |
|
1078 |
}); |
|
1079 |
} |
|
0 | 1080 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1081 |
/* |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1082 |
* The `.below-h2` class is here just for backward compatibility with plugins |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1083 |
* that are (incorrectly) using it. Do not use. Use `.inline` instead. See #34570. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1084 |
* If '.wp-header-end' is found, append the notices after it otherwise |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1085 |
* after the first h1 or h2 heading found within the main content. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1086 |
*/ |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1087 |
if ( ! $headerEnd.length ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1088 |
$headerEnd = $( '.wrap h1, .wrap h2' ).first(); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1089 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1090 |
$( 'div.updated, div.error, div.notice' ).not( '.inline, .below-h2' ).insertAfter( $headerEnd ); |
5 | 1091 |
|
9 | 1092 |
/** |
1093 |
* Makes notices dismissible. |
|
1094 |
* |
|
1095 |
* @since 4.4.0 |
|
1096 |
* |
|
16 | 1097 |
* @return {void} |
9 | 1098 |
*/ |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1099 |
function makeNoticesDismissible() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1100 |
$( '.notice.is-dismissible' ).each( function() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1101 |
var $el = $( this ), |
16 | 1102 |
$button = $( '<button type="button" class="notice-dismiss"><span class="screen-reader-text"></span></button>' ); |
5 | 1103 |
|
18 | 1104 |
if ( $el.find( '.notice-dismiss' ).length ) { |
1105 |
return; |
|
1106 |
} |
|
1107 |
||
16 | 1108 |
// Ensure plain text. |
1109 |
$button.find( '.screen-reader-text' ).text( __( 'Dismiss this notice.' ) ); |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1110 |
$button.on( 'click.wp-dismiss-notice', function( event ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1111 |
event.preventDefault(); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1112 |
$el.fadeTo( 100, 0, function() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1113 |
$el.slideUp( 100, function() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1114 |
$el.remove(); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1115 |
}); |
5 | 1116 |
}); |
1117 |
}); |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1118 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1119 |
$el.append( $button ); |
5 | 1120 |
}); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1121 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1122 |
|
22
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1123 |
$document.on( 'wp-updates-notice-added wp-plugin-install-error wp-plugin-update-error wp-plugin-delete-error wp-theme-install-error wp-theme-delete-error wp-notice-added', makeNoticesDismissible ); |
0 | 1124 |
|
16 | 1125 |
// Init screen meta. |
0 | 1126 |
screenMeta.init(); |
1127 |
||
9 | 1128 |
/** |
1129 |
* Checks a checkbox. |
|
1130 |
* |
|
1131 |
* This event needs to be delegated. Ticket #37973. |
|
1132 |
* |
|
16 | 1133 |
* @return {boolean} Returns whether a checkbox is checked or not. |
9 | 1134 |
*/ |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1135 |
$body.on( 'click', 'tbody > tr > .check-column :checkbox', function( event ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1136 |
// Shift click to select a range of checkboxes. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1137 |
if ( 'undefined' == event.shiftKey ) { return true; } |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1138 |
if ( event.shiftKey ) { |
0 | 1139 |
if ( !lastClicked ) { return true; } |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1140 |
checks = $( lastClicked ).closest( 'form' ).find( ':checkbox' ).filter( ':visible:enabled' ); |
0 | 1141 |
first = checks.index( lastClicked ); |
1142 |
last = checks.index( this ); |
|
1143 |
checked = $(this).prop('checked'); |
|
1144 |
if ( 0 < first && 0 < last && first != last ) { |
|
1145 |
sliced = ( last > first ) ? checks.slice( first, last ) : checks.slice( last, first ); |
|
1146 |
sliced.prop( 'checked', function() { |
|
1147 |
if ( $(this).closest('tr').is(':visible') ) |
|
1148 |
return checked; |
|
1149 |
||
1150 |
return false; |
|
1151 |
}); |
|
1152 |
} |
|
1153 |
} |
|
1154 |
lastClicked = this; |
|
1155 |
||
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1156 |
// Toggle the "Select all" checkboxes depending if the other ones are all checked or not. |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1157 |
var unchecked = $(this).closest('tbody').find('tr').find(':checkbox').filter(':visible:enabled').not(':checked'); |
9 | 1158 |
|
1159 |
/** |
|
1160 |
* Determines if all checkboxes are checked. |
|
1161 |
* |
|
16 | 1162 |
* @return {boolean} Returns true if there are no unchecked checkboxes. |
9 | 1163 |
*/ |
0 | 1164 |
$(this).closest('table').children('thead, tfoot').find(':checkbox').prop('checked', function() { |
5 | 1165 |
return ( 0 === unchecked.length ); |
0 | 1166 |
}); |
1167 |
||
1168 |
return true; |
|
1169 |
}); |
|
1170 |
||
9 | 1171 |
/** |
1172 |
* Controls all the toggles on bulk toggle change. |
|
1173 |
* |
|
1174 |
* When the bulk checkbox is changed, all the checkboxes in the tables are changed accordingly. |
|
1175 |
* When the shift-button is pressed while changing the bulk checkbox the checkboxes in the table are inverted. |
|
1176 |
* |
|
1177 |
* This event needs to be delegated. Ticket #37973. |
|
1178 |
* |
|
1179 |
* @param {Event} event The event object. |
|
1180 |
* |
|
16 | 1181 |
* @return {boolean} |
9 | 1182 |
*/ |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1183 |
$body.on( 'click.wp-toggle-checkboxes', 'thead .check-column :checkbox, tfoot .check-column :checkbox', function( event ) { |
5 | 1184 |
var $this = $(this), |
1185 |
$table = $this.closest( 'table' ), |
|
1186 |
controlChecked = $this.prop('checked'), |
|
1187 |
toggle = event.shiftKey || $this.data('wp-toggle'); |
|
0 | 1188 |
|
5 | 1189 |
$table.children( 'tbody' ).filter(':visible') |
1190 |
.children().children('.check-column').find(':checkbox') |
|
9 | 1191 |
/** |
1192 |
* Updates the checked state on the checkbox in the table. |
|
1193 |
* |
|
16 | 1194 |
* @return {boolean} True checks the checkbox, False unchecks the checkbox. |
9 | 1195 |
*/ |
5 | 1196 |
.prop('checked', function() { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1197 |
if ( $(this).is(':hidden,:disabled') ) { |
5 | 1198 |
return false; |
1199 |
} |
|
1200 |
||
1201 |
if ( toggle ) { |
|
1202 |
return ! $(this).prop( 'checked' ); |
|
1203 |
} else if ( controlChecked ) { |
|
1204 |
return true; |
|
1205 |
} |
|
1206 |
||
0 | 1207 |
return false; |
5 | 1208 |
}); |
0 | 1209 |
|
5 | 1210 |
$table.children('thead, tfoot').filter(':visible') |
1211 |
.children().children('.check-column').find(':checkbox') |
|
9 | 1212 |
|
1213 |
/** |
|
1214 |
* Syncs the bulk checkboxes on the top and bottom of the table. |
|
1215 |
* |
|
16 | 1216 |
* @return {boolean} True checks the checkbox, False unchecks the checkbox. |
9 | 1217 |
*/ |
5 | 1218 |
.prop('checked', function() { |
1219 |
if ( toggle ) { |
|
1220 |
return false; |
|
1221 |
} else if ( controlChecked ) { |
|
1222 |
return true; |
|
1223 |
} |
|
1224 |
||
0 | 1225 |
return false; |
5 | 1226 |
}); |
0 | 1227 |
}); |
1228 |
||
9 | 1229 |
/** |
18 | 1230 |
* Marries a secondary control to its primary control. |
1231 |
* |
|
1232 |
* @param {jQuery} topSelector The top selector element. |
|
1233 |
* @param {jQuery} topSubmit The top submit element. |
|
1234 |
* @param {jQuery} bottomSelector The bottom selector element. |
|
1235 |
* @param {jQuery} bottomSubmit The bottom submit element. |
|
1236 |
* @return {void} |
|
1237 |
*/ |
|
1238 |
function marryControls( topSelector, topSubmit, bottomSelector, bottomSubmit ) { |
|
1239 |
/** |
|
1240 |
* Updates the primary selector when the secondary selector is changed. |
|
1241 |
* |
|
1242 |
* @since 5.7.0 |
|
1243 |
* |
|
1244 |
* @return {void} |
|
1245 |
*/ |
|
1246 |
function updateTopSelector() { |
|
1247 |
topSelector.val($(this).val()); |
|
1248 |
} |
|
1249 |
bottomSelector.on('change', updateTopSelector); |
|
1250 |
||
1251 |
/** |
|
1252 |
* Updates the secondary selector when the primary selector is changed. |
|
1253 |
* |
|
1254 |
* @since 5.7.0 |
|
1255 |
* |
|
1256 |
* @return {void} |
|
1257 |
*/ |
|
1258 |
function updateBottomSelector() { |
|
1259 |
bottomSelector.val($(this).val()); |
|
1260 |
} |
|
1261 |
topSelector.on('change', updateBottomSelector); |
|
1262 |
||
1263 |
/** |
|
1264 |
* Triggers the primary submit when then secondary submit is clicked. |
|
1265 |
* |
|
1266 |
* @since 5.7.0 |
|
1267 |
* |
|
1268 |
* @return {void} |
|
1269 |
*/ |
|
1270 |
function triggerSubmitClick(e) { |
|
1271 |
e.preventDefault(); |
|
1272 |
e.stopPropagation(); |
|
1273 |
||
1274 |
topSubmit.trigger('click'); |
|
1275 |
} |
|
1276 |
bottomSubmit.on('click', triggerSubmitClick); |
|
1277 |
} |
|
1278 |
||
1279 |
// Marry the secondary "Bulk actions" controls to the primary controls: |
|
1280 |
marryControls( $('#bulk-action-selector-top'), $('#doaction'), $('#bulk-action-selector-bottom'), $('#doaction2') ); |
|
1281 |
||
1282 |
// Marry the secondary "Change role to" controls to the primary controls: |
|
1283 |
marryControls( $('#new_role'), $('#changeit'), $('#new_role2'), $('#changeit2') ); |
|
1284 |
||
22
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1285 |
var addAdminNotice = function( data ) { |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1286 |
var $notice = $( data.selector ), |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1287 |
$headerEnd = $( '.wp-header-end' ), |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1288 |
type, |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1289 |
dismissible, |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1290 |
$adminNotice; |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1291 |
|
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1292 |
delete data.selector; |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1293 |
|
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1294 |
dismissible = ( data.dismissible && data.dismissible === true ) ? ' is-dismissible' : ''; |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1295 |
type = ( data.type ) ? data.type : 'info'; |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1296 |
|
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1297 |
$adminNotice = '<div id="' + data.id + '" class="notice notice-' + data.type + dismissible + '"><p>' + data.message + '</p></div>'; |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1298 |
|
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1299 |
// Check if this admin notice already exists. |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1300 |
if ( ! $notice.length ) { |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1301 |
$notice = $( '#' + data.id ); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1302 |
} |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1303 |
|
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1304 |
if ( $notice.length ) { |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1305 |
$notice.replaceWith( $adminNotice ); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1306 |
} else if ( $headerEnd.length ) { |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1307 |
$headerEnd.after( $adminNotice ); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1308 |
} else { |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1309 |
if ( 'customize' === pagenow ) { |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1310 |
$( '.customize-themes-notifications' ).append( $adminNotice ); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1311 |
} else { |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1312 |
$( '.wrap' ).find( '> h1' ).after( $adminNotice ); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1313 |
} |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1314 |
} |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1315 |
|
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1316 |
$document.trigger( 'wp-notice-added' ); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1317 |
}; |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1318 |
|
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1319 |
$( '.bulkactions' ).parents( 'form' ).on( 'submit', function( event ) { |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1320 |
var form = this, |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1321 |
submitterName = event.originalEvent && event.originalEvent.submitter ? event.originalEvent.submitter.name : false, |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1322 |
currentPageSelector = form.querySelector( '#current-page-selector' ); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1323 |
|
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1324 |
if ( currentPageSelector && currentPageSelector.defaultValue !== currentPageSelector.value ) { |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1325 |
return; // Pagination form submission. |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1326 |
} |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1327 |
|
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1328 |
// Observe submissions from posts lists for 'bulk_action' or users lists for 'new_role'. |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1329 |
var bulkFieldRelations = { |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1330 |
'bulk_action' : window.bulkActionObserverIds.bulk_action, |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1331 |
'changeit' : window.bulkActionObserverIds.changeit |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1332 |
}; |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1333 |
if ( ! Object.keys( bulkFieldRelations ).includes( submitterName ) ) { |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1334 |
return; |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1335 |
} |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1336 |
|
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1337 |
var values = new FormData(form); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1338 |
var value = values.get( bulkFieldRelations[ submitterName ] ) || '-1'; |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1339 |
|
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1340 |
// Check that the action is not the default one. |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1341 |
if ( value !== '-1' ) { |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1342 |
// Check that at least one item is selected. |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1343 |
var itemsSelected = form.querySelectorAll( '.wp-list-table tbody .check-column input[type="checkbox"]:checked' ); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1344 |
|
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1345 |
if ( itemsSelected.length > 0 ) { |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1346 |
return; |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1347 |
} |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1348 |
} |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1349 |
event.preventDefault(); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1350 |
event.stopPropagation(); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1351 |
$( 'html, body' ).animate( { scrollTop: 0 } ); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1352 |
|
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1353 |
var errorMessage = __( 'Please select at least one item to perform this action on.' ); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1354 |
addAdminNotice( { |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1355 |
id: 'no-items-selected', |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1356 |
type: 'error', |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1357 |
message: errorMessage, |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1358 |
dismissible: true, |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1359 |
} ); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1360 |
|
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1361 |
wp.a11y.speak( errorMessage ); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1362 |
}); |
8c2e4d02f4ef
Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents:
21
diff
changeset
|
1363 |
|
18 | 1364 |
/** |
9 | 1365 |
* Shows row actions on focus of its parent container element or any other elements contained within. |
1366 |
* |
|
16 | 1367 |
* @return {void} |
9 | 1368 |
*/ |
5 | 1369 |
$( '#wpbody-content' ).on({ |
1370 |
focusin: function() { |
|
1371 |
clearTimeout( transitionTimeout ); |
|
1372 |
focusedRowActions = $( this ).find( '.row-actions' ); |
|
1373 |
// transitionTimeout is necessary for Firefox, but Chrome won't remove the CSS class without a little help. |
|
1374 |
$( '.row-actions' ).not( this ).removeClass( 'visible' ); |
|
1375 |
focusedRowActions.addClass( 'visible' ); |
|
1376 |
}, |
|
1377 |
focusout: function() { |
|
1378 |
// Tabbing between post title and .row-actions links needs a brief pause, otherwise |
|
1379 |
// the .row-actions div gets hidden in transit in some browsers (ahem, Firefox). |
|
1380 |
transitionTimeout = setTimeout( function() { |
|
1381 |
focusedRowActions.removeClass( 'visible' ); |
|
1382 |
}, 30 ); |
|
1383 |
} |
|
18 | 1384 |
}, '.table-view-list .has-row-actions' ); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1385 |
|
16 | 1386 |
// Toggle list table rows on small screens. |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1387 |
$( 'tbody' ).on( 'click', '.toggle-row', function() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1388 |
$( this ).closest( 'tr' ).toggleClass( 'is-expanded' ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1389 |
}); |
0 | 1390 |
|
18 | 1391 |
$('#default-password-nag-no').on( 'click', function() { |
0 | 1392 |
setUserSetting('default_password_nag', 'hide'); |
1393 |
$('div.default-password-nag').hide(); |
|
1394 |
return false; |
|
1395 |
}); |
|
1396 |
||
9 | 1397 |
/** |
19 | 1398 |
* Handles tab keypresses in theme and plugin file editor textareas. |
9 | 1399 |
* |
1400 |
* @param {Event} e The event object. |
|
1401 |
* |
|
16 | 1402 |
* @return {void} |
9 | 1403 |
*/ |
18 | 1404 |
$('#newcontent').on('keydown.wpevent_InsertTab', function(e) { |
0 | 1405 |
var el = e.target, selStart, selEnd, val, scroll, sel; |
1406 |
||
9 | 1407 |
// After pressing escape key (keyCode: 27), the tab key should tab out of the textarea. |
1408 |
if ( e.keyCode == 27 ) { |
|
16 | 1409 |
// When pressing Escape: Opera 12 and 27 blur form fields, IE 8 clears them. |
5 | 1410 |
e.preventDefault(); |
0 | 1411 |
$(el).data('tab-out', true); |
1412 |
return; |
|
1413 |
} |
|
1414 |
||
9 | 1415 |
// Only listen for plain tab key (keyCode: 9) without any modifiers. |
1416 |
if ( e.keyCode != 9 || e.ctrlKey || e.altKey || e.shiftKey ) |
|
0 | 1417 |
return; |
1418 |
||
9 | 1419 |
// After tabbing out, reset it so next time the tab key can be used again. |
0 | 1420 |
if ( $(el).data('tab-out') ) { |
1421 |
$(el).data('tab-out', false); |
|
1422 |
return; |
|
1423 |
} |
|
1424 |
||
1425 |
selStart = el.selectionStart; |
|
1426 |
selEnd = el.selectionEnd; |
|
1427 |
val = el.value; |
|
1428 |
||
9 | 1429 |
// If any text is selected, replace the selection with a tab character. |
0 | 1430 |
if ( document.selection ) { |
1431 |
el.focus(); |
|
1432 |
sel = document.selection.createRange(); |
|
1433 |
sel.text = '\t'; |
|
1434 |
} else if ( selStart >= 0 ) { |
|
1435 |
scroll = this.scrollTop; |
|
1436 |
el.value = val.substring(0, selStart).concat('\t', val.substring(selEnd) ); |
|
1437 |
el.selectionStart = el.selectionEnd = selStart + 1; |
|
1438 |
this.scrollTop = scroll; |
|
1439 |
} |
|
1440 |
||
9 | 1441 |
// Cancel the regular tab functionality, to prevent losing focus of the textarea. |
0 | 1442 |
if ( e.stopPropagation ) |
1443 |
e.stopPropagation(); |
|
1444 |
if ( e.preventDefault ) |
|
1445 |
e.preventDefault(); |
|
1446 |
}); |
|
1447 |
||
9 | 1448 |
// Reset page number variable for new filters/searches but not for bulk actions. See #17685. |
0 | 1449 |
if ( pageInput.length ) { |
9 | 1450 |
|
1451 |
/** |
|
1452 |
* Handles pagination variable when filtering the list table. |
|
1453 |
* |
|
1454 |
* Set the pagination argument to the first page when the post-filter form is submitted. |
|
1455 |
* This happens when pressing the 'filter' button on the list table page. |
|
1456 |
* |
|
1457 |
* The pagination argument should not be touched when the bulk action dropdowns are set to do anything. |
|
1458 |
* |
|
1459 |
* The form closest to the pageInput is the post-filter form. |
|
1460 |
* |
|
16 | 1461 |
* @return {void} |
9 | 1462 |
*/ |
18 | 1463 |
pageInput.closest('form').on( 'submit', function() { |
9 | 1464 |
/* |
1465 |
* action = bulk action dropdown at the top of the table |
|
1466 |
*/ |
|
18 | 1467 |
if ( $('select[name="action"]').val() == -1 && pageInput.val() == currentPage ) |
0 | 1468 |
pageInput.val('1'); |
1469 |
}); |
|
1470 |
} |
|
1471 |
||
9 | 1472 |
/** |
1473 |
* Resets the bulk actions when the search button is clicked. |
|
1474 |
* |
|
16 | 1475 |
* @return {void} |
9 | 1476 |
*/ |
18 | 1477 |
$('.search-box input[type="search"], .search-box input[type="submit"]').on( 'mousedown', function () { |
0 | 1478 |
$('select[name^="action"]').val('-1'); |
1479 |
}); |
|
1480 |
||
9 | 1481 |
/** |
1482 |
* Scrolls into view when focus.scroll-into-view is triggered. |
|
1483 |
* |
|
1484 |
* @param {Event} e The event object. |
|
1485 |
* |
|
16 | 1486 |
* @return {void} |
9 | 1487 |
*/ |
0 | 1488 |
$('#contextual-help-link, #show-settings-link').on( 'focus.scroll-into-view', function(e){ |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1489 |
if ( e.target.scrollIntoViewIfNeeded ) |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1490 |
e.target.scrollIntoViewIfNeeded(false); |
0 | 1491 |
}); |
1492 |
||
9 | 1493 |
/** |
1494 |
* Disables the submit upload buttons when no data is entered. |
|
1495 |
* |
|
16 | 1496 |
* @return {void} |
9 | 1497 |
*/ |
0 | 1498 |
(function(){ |
1499 |
var button, input, form = $('form.wp-upload-form'); |
|
9 | 1500 |
|
1501 |
// Exit when no upload form is found. |
|
0 | 1502 |
if ( ! form.length ) |
1503 |
return; |
|
9 | 1504 |
|
0 | 1505 |
button = form.find('input[type="submit"]'); |
1506 |
input = form.find('input[type="file"]'); |
|
1507 |
||
9 | 1508 |
/** |
1509 |
* Determines if any data is entered in any file upload input. |
|
1510 |
* |
|
1511 |
* @since 3.5.0 |
|
1512 |
* |
|
16 | 1513 |
* @return {void} |
9 | 1514 |
*/ |
0 | 1515 |
function toggleUploadButton() { |
9 | 1516 |
// When no inputs have a value, disable the upload buttons. |
0 | 1517 |
button.prop('disabled', '' === input.map( function() { |
1518 |
return $(this).val(); |
|
1519 |
}).get().join('')); |
|
1520 |
} |
|
9 | 1521 |
|
1522 |
// Update the status initially. |
|
0 | 1523 |
toggleUploadButton(); |
9 | 1524 |
// Update the status when any file input changes. |
0 | 1525 |
input.on('change', toggleUploadButton); |
1526 |
})(); |
|
5 | 1527 |
|
9 | 1528 |
/** |
1529 |
* Pins the menu while distraction-free writing is enabled. |
|
1530 |
* |
|
1531 |
* @param {Event} event Event data. |
|
1532 |
* |
|
1533 |
* @since 4.1.0 |
|
1534 |
* |
|
16 | 1535 |
* @return {void} |
9 | 1536 |
*/ |
5 | 1537 |
function pinMenu( event ) { |
1538 |
var windowPos = $window.scrollTop(), |
|
1539 |
resizing = ! event || event.type !== 'scroll'; |
|
1540 |
||
16 | 1541 |
if ( isIOS || $adminmenu.data( 'wp-responsive' ) ) { |
5 | 1542 |
return; |
1543 |
} |
|
1544 |
||
9 | 1545 |
/* |
1546 |
* When the menu is higher than the window and smaller than the entire page. |
|
1547 |
* It should be adjusted to be able to see the entire menu. |
|
1548 |
* |
|
1549 |
* Otherwise it can be accessed normally. |
|
1550 |
*/ |
|
5 | 1551 |
if ( height.menu + height.adminbar < height.window || |
1552 |
height.menu + height.adminbar + 20 > height.wpwrap ) { |
|
1553 |
unpinMenu(); |
|
1554 |
return; |
|
1555 |
} |
|
1556 |
||
1557 |
menuIsPinned = true; |
|
1558 |
||
9 | 1559 |
// If the menu is higher than the window, compensate on scroll. |
5 | 1560 |
if ( height.menu + height.adminbar > height.window ) { |
9 | 1561 |
// Check for overscrolling, this happens when swiping up at the top of the document in modern browsers. |
5 | 1562 |
if ( windowPos < 0 ) { |
9 | 1563 |
// Stick the menu to the top. |
5 | 1564 |
if ( ! pinnedMenuTop ) { |
1565 |
pinnedMenuTop = true; |
|
1566 |
pinnedMenuBottom = false; |
|
1567 |
||
1568 |
$adminMenuWrap.css({ |
|
1569 |
position: 'fixed', |
|
1570 |
top: '', |
|
1571 |
bottom: '' |
|
1572 |
}); |
|
1573 |
} |
|
1574 |
||
1575 |
return; |
|
1576 |
} else if ( windowPos + height.window > $document.height() - 1 ) { |
|
9 | 1577 |
// When overscrolling at the bottom, stick the menu to the bottom. |
5 | 1578 |
if ( ! pinnedMenuBottom ) { |
1579 |
pinnedMenuBottom = true; |
|
1580 |
pinnedMenuTop = false; |
|
1581 |
||
1582 |
$adminMenuWrap.css({ |
|
1583 |
position: 'fixed', |
|
1584 |
top: '', |
|
1585 |
bottom: 0 |
|
1586 |
}); |
|
1587 |
} |
|
1588 |
||
1589 |
return; |
|
1590 |
} |
|
1591 |
||
1592 |
if ( windowPos > lastScrollPosition ) { |
|
9 | 1593 |
// When a down scroll has been detected. |
1594 |
||
1595 |
// If it was pinned to the top, unpin and calculate relative scroll. |
|
5 | 1596 |
if ( pinnedMenuTop ) { |
1597 |
pinnedMenuTop = false; |
|
9 | 1598 |
// Calculate new offset position. |
5 | 1599 |
menuTop = $adminMenuWrap.offset().top - height.adminbar - ( windowPos - lastScrollPosition ); |
1600 |
||
1601 |
if ( menuTop + height.menu + height.adminbar < windowPos + height.window ) { |
|
1602 |
menuTop = windowPos + height.window - height.menu - height.adminbar; |
|
1603 |
} |
|
1604 |
||
1605 |
$adminMenuWrap.css({ |
|
1606 |
position: 'absolute', |
|
1607 |
top: menuTop, |
|
1608 |
bottom: '' |
|
1609 |
}); |
|
1610 |
} else if ( ! pinnedMenuBottom && $adminMenuWrap.offset().top + height.menu < windowPos + height.window ) { |
|
9 | 1611 |
// Pin it to the bottom. |
5 | 1612 |
pinnedMenuBottom = true; |
1613 |
||
1614 |
$adminMenuWrap.css({ |
|
1615 |
position: 'fixed', |
|
1616 |
top: '', |
|
1617 |
bottom: 0 |
|
1618 |
}); |
|
1619 |
} |
|
1620 |
} else if ( windowPos < lastScrollPosition ) { |
|
9 | 1621 |
// When a scroll up is detected. |
1622 |
||
1623 |
// If it was pinned to the bottom, unpin and calculate relative scroll. |
|
5 | 1624 |
if ( pinnedMenuBottom ) { |
1625 |
pinnedMenuBottom = false; |
|
9 | 1626 |
|
1627 |
// Calculate new offset position. |
|
5 | 1628 |
menuTop = $adminMenuWrap.offset().top - height.adminbar + ( lastScrollPosition - windowPos ); |
1629 |
||
1630 |
if ( menuTop + height.menu > windowPos + height.window ) { |
|
1631 |
menuTop = windowPos; |
|
1632 |
} |
|
1633 |
||
1634 |
$adminMenuWrap.css({ |
|
1635 |
position: 'absolute', |
|
1636 |
top: menuTop, |
|
1637 |
bottom: '' |
|
1638 |
}); |
|
1639 |
} else if ( ! pinnedMenuTop && $adminMenuWrap.offset().top >= windowPos + height.adminbar ) { |
|
9 | 1640 |
|
1641 |
// Pin it to the top. |
|
5 | 1642 |
pinnedMenuTop = true; |
1643 |
||
1644 |
$adminMenuWrap.css({ |
|
1645 |
position: 'fixed', |
|
1646 |
top: '', |
|
1647 |
bottom: '' |
|
1648 |
}); |
|
1649 |
} |
|
1650 |
} else if ( resizing ) { |
|
9 | 1651 |
// Window is being resized. |
1652 |
||
5 | 1653 |
pinnedMenuTop = pinnedMenuBottom = false; |
9 | 1654 |
|
1655 |
// Calculate the new offset. |
|
5 | 1656 |
menuTop = windowPos + height.window - height.menu - height.adminbar - 1; |
1657 |
||
1658 |
if ( menuTop > 0 ) { |
|
1659 |
$adminMenuWrap.css({ |
|
1660 |
position: 'absolute', |
|
1661 |
top: menuTop, |
|
1662 |
bottom: '' |
|
1663 |
}); |
|
1664 |
} else { |
|
1665 |
unpinMenu(); |
|
1666 |
} |
|
1667 |
} |
|
1668 |
} |
|
1669 |
||
1670 |
lastScrollPosition = windowPos; |
|
1671 |
} |
|
1672 |
||
9 | 1673 |
/** |
1674 |
* Determines the height of certain elements. |
|
1675 |
* |
|
1676 |
* @since 4.1.0 |
|
1677 |
* |
|
16 | 1678 |
* @return {void} |
9 | 1679 |
*/ |
5 | 1680 |
function resetHeights() { |
1681 |
height = { |
|
1682 |
window: $window.height(), |
|
1683 |
wpwrap: $wpwrap.height(), |
|
1684 |
adminbar: $adminbar.height(), |
|
1685 |
menu: $adminMenuWrap.height() |
|
1686 |
}; |
|
1687 |
} |
|
1688 |
||
9 | 1689 |
/** |
1690 |
* Unpins the menu. |
|
1691 |
* |
|
1692 |
* @since 4.1.0 |
|
1693 |
* |
|
16 | 1694 |
* @return {void} |
9 | 1695 |
*/ |
5 | 1696 |
function unpinMenu() { |
1697 |
if ( isIOS || ! menuIsPinned ) { |
|
1698 |
return; |
|
1699 |
} |
|
1700 |
||
1701 |
pinnedMenuTop = pinnedMenuBottom = menuIsPinned = false; |
|
1702 |
$adminMenuWrap.css({ |
|
1703 |
position: '', |
|
1704 |
top: '', |
|
1705 |
bottom: '' |
|
1706 |
}); |
|
1707 |
} |
|
1708 |
||
9 | 1709 |
/** |
1710 |
* Pins and unpins the menu when applicable. |
|
1711 |
* |
|
1712 |
* @since 4.1.0 |
|
1713 |
* |
|
16 | 1714 |
* @return {void} |
9 | 1715 |
*/ |
5 | 1716 |
function setPinMenu() { |
1717 |
resetHeights(); |
|
1718 |
||
1719 |
if ( $adminmenu.data('wp-responsive') ) { |
|
1720 |
$body.removeClass( 'sticky-menu' ); |
|
1721 |
unpinMenu(); |
|
1722 |
} else if ( height.menu + height.adminbar > height.window ) { |
|
1723 |
pinMenu(); |
|
1724 |
$body.removeClass( 'sticky-menu' ); |
|
1725 |
} else { |
|
1726 |
$body.addClass( 'sticky-menu' ); |
|
1727 |
unpinMenu(); |
|
1728 |
} |
|
1729 |
} |
|
1730 |
||
1731 |
if ( ! isIOS ) { |
|
1732 |
$window.on( 'scroll.pin-menu', pinMenu ); |
|
1733 |
$document.on( 'tinymce-editor-init.pin-menu', function( event, editor ) { |
|
1734 |
editor.on( 'wp-autoresize', resetHeights ); |
|
1735 |
}); |
|
1736 |
} |
|
1737 |
||
9 | 1738 |
/** |
1739 |
* Changes the sortables and responsiveness of metaboxes. |
|
1740 |
* |
|
1741 |
* @since 3.8.0 |
|
1742 |
* |
|
16 | 1743 |
* @return {void} |
9 | 1744 |
*/ |
5 | 1745 |
window.wpResponsive = { |
9 | 1746 |
|
1747 |
/** |
|
1748 |
* Initializes the wpResponsive object. |
|
1749 |
* |
|
1750 |
* @since 3.8.0 |
|
1751 |
* |
|
16 | 1752 |
* @return {void} |
9 | 1753 |
*/ |
5 | 1754 |
init: function() { |
1755 |
var self = this; |
|
1756 |
||
16 | 1757 |
this.maybeDisableSortables = this.maybeDisableSortables.bind( this ); |
1758 |
||
1759 |
// Modify functionality based on custom activate/deactivate event. |
|
5 | 1760 |
$document.on( 'wp-responsive-activate.wp-responsive', function() { |
1761 |
self.activate(); |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1762 |
self.toggleAriaHasPopup( 'add' ); |
5 | 1763 |
}).on( 'wp-responsive-deactivate.wp-responsive', function() { |
1764 |
self.deactivate(); |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1765 |
self.toggleAriaHasPopup( 'remove' ); |
5 | 1766 |
}); |
1767 |
||
1768 |
$( '#wp-admin-bar-menu-toggle a' ).attr( 'aria-expanded', 'false' ); |
|
1769 |
||
9 | 1770 |
// Toggle sidebar when toggle is clicked. |
5 | 1771 |
$( '#wp-admin-bar-menu-toggle' ).on( 'click.wp-responsive', function( event ) { |
1772 |
event.preventDefault(); |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1773 |
|
16 | 1774 |
// Close any open toolbar submenus. |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1775 |
$adminbar.find( '.hover' ).removeClass( 'hover' ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1776 |
|
5 | 1777 |
$wpwrap.toggleClass( 'wp-responsive-open' ); |
1778 |
if ( $wpwrap.hasClass( 'wp-responsive-open' ) ) { |
|
1779 |
$(this).find('a').attr( 'aria-expanded', 'true' ); |
|
18 | 1780 |
$( '#adminmenu a:first' ).trigger( 'focus' ); |
5 | 1781 |
} else { |
1782 |
$(this).find('a').attr( 'aria-expanded', 'false' ); |
|
1783 |
} |
|
1784 |
} ); |
|
1785 |
||
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1786 |
// Close sidebar when target moves outside of toggle and sidebar. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1787 |
$( document ).on( 'click', function( event ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1788 |
if ( ! $wpwrap.hasClass( 'wp-responsive-open' ) || ! document.hasFocus() ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1789 |
return; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1790 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1791 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1792 |
var focusIsInToggle = $.contains( $( '#wp-admin-bar-menu-toggle' )[0], event.target ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1793 |
var focusIsInSidebar = $.contains( $( '#adminmenuwrap' )[0], event.target ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1794 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1795 |
if ( ! focusIsInToggle && ! focusIsInSidebar ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1796 |
$( '#wp-admin-bar-menu-toggle' ).trigger( 'click.wp-responsive' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1797 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1798 |
} ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1799 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1800 |
// Close sidebar when a keypress completes outside of toggle and sidebar. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1801 |
$( document ).on( 'keyup', function( event ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1802 |
var toggleButton = $( '#wp-admin-bar-menu-toggle' )[0]; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1803 |
if ( ! $wpwrap.hasClass( 'wp-responsive-open' ) ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1804 |
return; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1805 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1806 |
if ( 27 === event.keyCode ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1807 |
$( toggleButton ).trigger( 'click.wp-responsive' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1808 |
$( toggleButton ).find( 'a' ).trigger( 'focus' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1809 |
} else { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1810 |
if ( 9 === event.keyCode ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1811 |
var sidebar = $( '#adminmenuwrap' )[0]; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1812 |
var focusedElement = event.relatedTarget || document.activeElement; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1813 |
// A brief delay is required to allow focus to switch to another element. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1814 |
setTimeout( function() { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1815 |
var focusIsInToggle = $.contains( toggleButton, focusedElement ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1816 |
var focusIsInSidebar = $.contains( sidebar, focusedElement ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1817 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1818 |
if ( ! focusIsInToggle && ! focusIsInSidebar ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1819 |
$( toggleButton ).trigger( 'click.wp-responsive' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1820 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1821 |
}, 10 ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1822 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1823 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1824 |
}); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1825 |
|
9 | 1826 |
// Add menu events. |
5 | 1827 |
$adminmenu.on( 'click.wp-responsive', 'li.wp-has-submenu > a', function( event ) { |
1828 |
if ( ! $adminmenu.data('wp-responsive') ) { |
|
1829 |
return; |
|
1830 |
} |
|
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1831 |
let state = ( 'false' === $( this ).attr( 'aria-expanded' ) ) ? 'true' : 'false'; |
5 | 1832 |
$( this ).parent( 'li' ).toggleClass( 'selected' ); |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1833 |
$( this ).attr( 'aria-expanded', state ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1834 |
$( this ).trigger( 'focus' ); |
5 | 1835 |
event.preventDefault(); |
1836 |
}); |
|
1837 |
||
1838 |
self.trigger(); |
|
18 | 1839 |
$document.on( 'wp-window-resized.wp-responsive', this.trigger.bind( this ) ); |
5 | 1840 |
|
19 | 1841 |
// This needs to run later as UI Sortable may be initialized when the document is ready. |
16 | 1842 |
$window.on( 'load.wp-responsive', this.maybeDisableSortables ); |
1843 |
$document.on( 'postbox-toggled', this.maybeDisableSortables ); |
|
1844 |
||
1845 |
// When the screen columns are changed, potentially disable sortables. |
|
1846 |
$( '#screen-options-wrap input' ).on( 'click', this.maybeDisableSortables ); |
|
1847 |
}, |
|
5 | 1848 |
|
16 | 1849 |
/** |
1850 |
* Disable sortables if there is only one metabox, or the screen is in one column mode. Otherwise, enable sortables. |
|
1851 |
* |
|
1852 |
* @since 5.3.0 |
|
1853 |
* |
|
1854 |
* @return {void} |
|
1855 |
*/ |
|
1856 |
maybeDisableSortables: function() { |
|
1857 |
var width = navigator.userAgent.indexOf('AppleWebKit/') > -1 ? $window.width() : window.innerWidth; |
|
1858 |
||
1859 |
if ( |
|
1860 |
( width <= 782 ) || |
|
1861 |
( 1 >= $sortables.find( '.ui-sortable-handle:visible' ).length && jQuery( '.columns-prefs-1 input' ).prop( 'checked' ) ) |
|
1862 |
) { |
|
1863 |
this.disableSortables(); |
|
1864 |
} else { |
|
1865 |
this.enableSortables(); |
|
1866 |
} |
|
5 | 1867 |
}, |
1868 |
||
9 | 1869 |
/** |
1870 |
* Changes properties of body and admin menu. |
|
1871 |
* |
|
1872 |
* Pins and unpins the menu and adds the auto-fold class to the body. |
|
1873 |
* Makes the admin menu responsive and disables the metabox sortables. |
|
1874 |
* |
|
1875 |
* @since 3.8.0 |
|
1876 |
* |
|
16 | 1877 |
* @return {void} |
9 | 1878 |
*/ |
5 | 1879 |
activate: function() { |
1880 |
setPinMenu(); |
|
1881 |
||
1882 |
if ( ! $body.hasClass( 'auto-fold' ) ) { |
|
1883 |
$body.addClass( 'auto-fold' ); |
|
1884 |
} |
|
1885 |
||
1886 |
$adminmenu.data( 'wp-responsive', 1 ); |
|
1887 |
this.disableSortables(); |
|
1888 |
}, |
|
1889 |
||
9 | 1890 |
/** |
1891 |
* Changes properties of admin menu and enables metabox sortables. |
|
1892 |
* |
|
1893 |
* Pin and unpin the menu. |
|
1894 |
* Removes the responsiveness of the admin menu and enables the metabox sortables. |
|
1895 |
* |
|
1896 |
* @since 3.8.0 |
|
1897 |
* |
|
16 | 1898 |
* @return {void} |
9 | 1899 |
*/ |
5 | 1900 |
deactivate: function() { |
1901 |
setPinMenu(); |
|
1902 |
$adminmenu.removeData('wp-responsive'); |
|
16 | 1903 |
|
1904 |
this.maybeDisableSortables(); |
|
5 | 1905 |
}, |
1906 |
||
9 | 1907 |
/** |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1908 |
* Toggles the aria-haspopup attribute for the responsive admin menu. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1909 |
* |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1910 |
* The aria-haspopup attribute is only necessary for the responsive menu. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1911 |
* See ticket https://core.trac.wordpress.org/ticket/43095 |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1912 |
* |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1913 |
* @since 6.6.0 |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1914 |
* |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1915 |
* @param {string} action Whether to add or remove the aria-haspopup attribute. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1916 |
* |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1917 |
* @return {void} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1918 |
*/ |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1919 |
toggleAriaHasPopup: function( action ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1920 |
var elements = $adminmenu.find( '[data-ariahaspopup]' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1921 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1922 |
if ( action === 'add' ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1923 |
elements.each( function() { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1924 |
$( this ).attr( 'aria-haspopup', 'menu' ).attr( 'aria-expanded', 'false' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1925 |
} ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1926 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1927 |
return; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1928 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1929 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1930 |
elements.each( function() { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1931 |
$( this ).removeAttr( 'aria-haspopup' ).removeAttr( 'aria-expanded' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1932 |
} ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1933 |
}, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1934 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
1935 |
/** |
9 | 1936 |
* Sets the responsiveness and enables the overlay based on the viewport width. |
1937 |
* |
|
1938 |
* @since 3.8.0 |
|
1939 |
* |
|
16 | 1940 |
* @return {void} |
9 | 1941 |
*/ |
5 | 1942 |
trigger: function() { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1943 |
var viewportWidth = getViewportWidth(); |
5 | 1944 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1945 |
// Exclude IE < 9, it doesn't support @media CSS rules. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1946 |
if ( ! viewportWidth ) { |
5 | 1947 |
return; |
1948 |
} |
|
1949 |
||
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1950 |
if ( viewportWidth <= 782 ) { |
5 | 1951 |
if ( ! wpResponsiveActive ) { |
1952 |
$document.trigger( 'wp-responsive-activate' ); |
|
1953 |
wpResponsiveActive = true; |
|
1954 |
} |
|
1955 |
} else { |
|
1956 |
if ( wpResponsiveActive ) { |
|
1957 |
$document.trigger( 'wp-responsive-deactivate' ); |
|
1958 |
wpResponsiveActive = false; |
|
1959 |
} |
|
1960 |
} |
|
1961 |
||
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
1962 |
if ( viewportWidth <= 480 ) { |
5 | 1963 |
this.enableOverlay(); |
1964 |
} else { |
|
1965 |
this.disableOverlay(); |
|
1966 |
} |
|
16 | 1967 |
|
1968 |
this.maybeDisableSortables(); |
|
5 | 1969 |
}, |
1970 |
||
9 | 1971 |
/** |
1972 |
* Inserts a responsive overlay and toggles the window. |
|
1973 |
* |
|
1974 |
* @since 3.8.0 |
|
1975 |
* |
|
16 | 1976 |
* @return {void} |
9 | 1977 |
*/ |
5 | 1978 |
enableOverlay: function() { |
1979 |
if ( $overlay.length === 0 ) { |
|
1980 |
$overlay = $( '<div id="wp-responsive-overlay"></div>' ) |
|
1981 |
.insertAfter( '#wpcontent' ) |
|
1982 |
.hide() |
|
1983 |
.on( 'click.wp-responsive', function() { |
|
1984 |
$toolbar.find( '.menupop.hover' ).removeClass( 'hover' ); |
|
1985 |
$( this ).hide(); |
|
1986 |
}); |
|
1987 |
} |
|
1988 |
||
1989 |
$toolbarPopups.on( 'click.wp-responsive', function() { |
|
1990 |
$overlay.show(); |
|
1991 |
}); |
|
1992 |
}, |
|
1993 |
||
9 | 1994 |
/** |
1995 |
* Disables the responsive overlay and removes the overlay. |
|
1996 |
* |
|
1997 |
* @since 3.8.0 |
|
1998 |
* |
|
16 | 1999 |
* @return {void} |
9 | 2000 |
*/ |
5 | 2001 |
disableOverlay: function() { |
2002 |
$toolbarPopups.off( 'click.wp-responsive' ); |
|
2003 |
$overlay.hide(); |
|
2004 |
}, |
|
2005 |
||
9 | 2006 |
/** |
2007 |
* Disables sortables. |
|
2008 |
* |
|
2009 |
* @since 3.8.0 |
|
2010 |
* |
|
16 | 2011 |
* @return {void} |
9 | 2012 |
*/ |
5 | 2013 |
disableSortables: function() { |
2014 |
if ( $sortables.length ) { |
|
2015 |
try { |
|
9 | 2016 |
$sortables.sortable( 'disable' ); |
16 | 2017 |
$sortables.find( '.ui-sortable-handle' ).addClass( 'is-non-sortable' ); |
9 | 2018 |
} catch ( e ) {} |
5 | 2019 |
} |
2020 |
}, |
|
2021 |
||
9 | 2022 |
/** |
2023 |
* Enables sortables. |
|
2024 |
* |
|
2025 |
* @since 3.8.0 |
|
2026 |
* |
|
16 | 2027 |
* @return {void} |
9 | 2028 |
*/ |
5 | 2029 |
enableSortables: function() { |
2030 |
if ( $sortables.length ) { |
|
2031 |
try { |
|
9 | 2032 |
$sortables.sortable( 'enable' ); |
16 | 2033 |
$sortables.find( '.ui-sortable-handle' ).removeClass( 'is-non-sortable' ); |
9 | 2034 |
} catch ( e ) {} |
5 | 2035 |
} |
2036 |
} |
|
2037 |
}; |
|
2038 |
||
9 | 2039 |
/** |
2040 |
* Add an ARIA role `button` to elements that behave like UI controls when JavaScript is on. |
|
2041 |
* |
|
2042 |
* @since 4.5.0 |
|
2043 |
* |
|
16 | 2044 |
* @return {void} |
9 | 2045 |
*/ |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2046 |
function aria_button_if_js() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2047 |
$( '.aria-button-if-js' ).attr( 'role', 'button' ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2048 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2049 |
|
18 | 2050 |
$( document ).on( 'ajaxComplete', function() { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2051 |
aria_button_if_js(); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2052 |
}); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2053 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2054 |
/** |
9 | 2055 |
* Get the viewport width. |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2056 |
* |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2057 |
* @since 4.7.0 |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2058 |
* |
16 | 2059 |
* @return {number|boolean} The current viewport width or false if the |
2060 |
* browser doesn't support innerWidth (IE < 9). |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2061 |
*/ |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2062 |
function getViewportWidth() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2063 |
var viewportWidth = false; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2064 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2065 |
if ( window.innerWidth ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2066 |
// On phones, window.innerWidth is affected by zooming. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2067 |
viewportWidth = Math.max( window.innerWidth, document.documentElement.clientWidth ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2068 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2069 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2070 |
return viewportWidth; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2071 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2072 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2073 |
/** |
9 | 2074 |
* Sets the admin menu collapsed/expanded state. |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2075 |
* |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2076 |
* Sets the global variable `menuState` and triggers a custom event passing |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2077 |
* the current menu state. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2078 |
* |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2079 |
* @since 4.7.0 |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2080 |
* |
16 | 2081 |
* @return {void} |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2082 |
*/ |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2083 |
function setMenuState() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2084 |
var viewportWidth = getViewportWidth() || 961; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2085 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2086 |
if ( viewportWidth <= 782 ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2087 |
menuState = 'responsive'; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2088 |
} else if ( $body.hasClass( 'folded' ) || ( $body.hasClass( 'auto-fold' ) && viewportWidth <= 960 && viewportWidth > 782 ) ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2089 |
menuState = 'folded'; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2090 |
} else { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2091 |
menuState = 'open'; |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2092 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2093 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2094 |
$document.trigger( 'wp-menu-state-set', { state: menuState } ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2095 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2096 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2097 |
// Set the menu state when the window gets resized. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2098 |
$document.on( 'wp-window-resized.set-menu-state', setMenuState ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2099 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2100 |
/** |
9 | 2101 |
* Sets ARIA attributes on the collapse/expand menu button. |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2102 |
* |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2103 |
* When the admin menu is open or folded, updates the `aria-expanded` and |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2104 |
* `aria-label` attributes of the button to give feedback to assistive |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2105 |
* technologies. In the responsive view, the button is always hidden. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2106 |
* |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2107 |
* @since 4.7.0 |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2108 |
* |
16 | 2109 |
* @return {void} |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2110 |
*/ |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2111 |
$document.on( 'wp-menu-state-set wp-collapse-menu', function( event, eventData ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2112 |
var $collapseButton = $( '#collapse-button' ), |
16 | 2113 |
ariaExpanded, ariaLabelText; |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2114 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2115 |
if ( 'folded' === eventData.state ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2116 |
ariaExpanded = 'false'; |
16 | 2117 |
ariaLabelText = __( 'Expand Main menu' ); |
2118 |
} else { |
|
2119 |
ariaExpanded = 'true'; |
|
2120 |
ariaLabelText = __( 'Collapse Main menu' ); |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2121 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2122 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2123 |
$collapseButton.attr({ |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2124 |
'aria-expanded': ariaExpanded, |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2125 |
'aria-label': ariaLabelText |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2126 |
}); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2127 |
}); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2128 |
|
5 | 2129 |
window.wpResponsive.init(); |
2130 |
setPinMenu(); |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2131 |
setMenuState(); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2132 |
makeNoticesDismissible(); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2133 |
aria_button_if_js(); |
5 | 2134 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2135 |
$document.on( 'wp-pin-menu wp-window-resized.pin-menu postboxes-columnchange.pin-menu postbox-toggled.pin-menu wp-collapse-menu.pin-menu wp-scroll-start.pin-menu', setPinMenu ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2136 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2137 |
// Set initial focus on a specific element. |
18 | 2138 |
$( '.wp-initial-focus' ).trigger( 'focus' ); |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2139 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2140 |
// Toggle update details on update-core.php. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2141 |
$body.on( 'click', '.js-update-details-toggle', function() { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2142 |
var $updateNotice = $( this ).closest( '.js-update-details' ), |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2143 |
$progressDiv = $( '#' + $updateNotice.data( 'update-details' ) ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2144 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2145 |
/* |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2146 |
* When clicking on "Show details" move the progress div below the update |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2147 |
* notice. Make sure it gets moved just the first time. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2148 |
*/ |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2149 |
if ( ! $progressDiv.hasClass( 'update-details-moved' ) ) { |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2150 |
$progressDiv.insertAfter( $updateNotice ).addClass( 'update-details-moved' ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2151 |
} |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2152 |
|
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2153 |
// Toggle the progress div visibility. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2154 |
$progressDiv.toggle(); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2155 |
// Toggle the Show Details button expanded state. |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2156 |
$( this ).attr( 'aria-expanded', $progressDiv.is( ':visible' ) ); |
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2157 |
}); |
0 | 2158 |
}); |
2159 |
||
16 | 2160 |
/** |
2161 |
* Hides the update button for expired plugin or theme uploads. |
|
2162 |
* |
|
2163 |
* On the "Update plugin/theme from uploaded zip" screen, once the upload has expired, |
|
2164 |
* hides the "Replace current with uploaded" button and displays a warning. |
|
2165 |
* |
|
2166 |
* @since 5.5.0 |
|
2167 |
*/ |
|
18 | 2168 |
$( function( $ ) { |
16 | 2169 |
var $overwrite, $warning; |
2170 |
||
2171 |
if ( ! $body.hasClass( 'update-php' ) ) { |
|
2172 |
return; |
|
2173 |
} |
|
2174 |
||
2175 |
$overwrite = $( 'a.update-from-upload-overwrite' ); |
|
2176 |
$warning = $( '.update-from-upload-expired' ); |
|
2177 |
||
2178 |
if ( ! $overwrite.length || ! $warning.length ) { |
|
2179 |
return; |
|
2180 |
} |
|
2181 |
||
2182 |
window.setTimeout( |
|
2183 |
function() { |
|
2184 |
$overwrite.hide(); |
|
2185 |
$warning.removeClass( 'hidden' ); |
|
2186 |
||
2187 |
if ( window.wp && window.wp.a11y ) { |
|
2188 |
window.wp.a11y.speak( $warning.text() ); |
|
2189 |
} |
|
2190 |
}, |
|
2191 |
7140000 // 119 minutes. The uploaded file is deleted after 2 hours. |
|
2192 |
); |
|
2193 |
} ); |
|
2194 |
||
9 | 2195 |
// Fire a custom jQuery event at the end of window resize. |
5 | 2196 |
( function() { |
2197 |
var timeout; |
|
2198 |
||
9 | 2199 |
/** |
2200 |
* Triggers the WP window-resize event. |
|
2201 |
* |
|
2202 |
* @since 3.8.0 |
|
2203 |
* |
|
16 | 2204 |
* @return {void} |
9 | 2205 |
*/ |
5 | 2206 |
function triggerEvent() { |
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2207 |
$document.trigger( 'wp-window-resized' ); |
5 | 2208 |
} |
2209 |
||
9 | 2210 |
/** |
2211 |
* Fires the trigger event again after 200 ms. |
|
2212 |
* |
|
2213 |
* @since 3.8.0 |
|
2214 |
* |
|
16 | 2215 |
* @return {void} |
9 | 2216 |
*/ |
5 | 2217 |
function fireOnce() { |
2218 |
window.clearTimeout( timeout ); |
|
2219 |
timeout = window.setTimeout( triggerEvent, 200 ); |
|
2220 |
} |
|
0 | 2221 |
|
7
cf61fcea0001
resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents:
5
diff
changeset
|
2222 |
$window.on( 'resize.wp-fire-once', fireOnce ); |
5 | 2223 |
}()); |
0 | 2224 |
|
5 | 2225 |
// Make Windows 8 devices play along nicely. |
2226 |
(function(){ |
|
2227 |
if ( '-ms-user-select' in document.documentElement.style && navigator.userAgent.match(/IEMobile\/10\.0/) ) { |
|
2228 |
var msViewportStyle = document.createElement( 'style' ); |
|
2229 |
msViewportStyle.appendChild( |
|
2230 |
document.createTextNode( '@-ms-viewport{width:auto!important}' ) |
|
2231 |
); |
|
2232 |
document.getElementsByTagName( 'head' )[0].appendChild( msViewportStyle ); |
|
2233 |
} |
|
2234 |
})(); |
|
0 | 2235 |
|
5 | 2236 |
}( jQuery, window )); |
21
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2237 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2238 |
/** |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2239 |
* Freeze animated plugin icons when reduced motion is enabled. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2240 |
* |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2241 |
* When the user has enabled the 'prefers-reduced-motion' setting, this module |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2242 |
* stops animations for all GIFs on the page with the class 'plugin-icon' or |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2243 |
* plugin icon images in the update plugins table. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2244 |
* |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2245 |
* @since 6.4.0 |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2246 |
*/ |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2247 |
(function() { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2248 |
// Private variables and methods. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2249 |
var priv = {}, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2250 |
pub = {}, |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2251 |
mediaQuery; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2252 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2253 |
// Initialize pauseAll to false; it will be set to true if reduced motion is preferred. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2254 |
priv.pauseAll = false; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2255 |
if ( window.matchMedia ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2256 |
mediaQuery = window.matchMedia( '(prefers-reduced-motion: reduce)' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2257 |
if ( ! mediaQuery || mediaQuery.matches ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2258 |
priv.pauseAll = true; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2259 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2260 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2261 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2262 |
// Method to replace animated GIFs with a static frame. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2263 |
priv.freezeAnimatedPluginIcons = function( img ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2264 |
var coverImage = function() { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2265 |
var width = img.width; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2266 |
var height = img.height; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2267 |
var canvas = document.createElement( 'canvas' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2268 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2269 |
// Set canvas dimensions. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2270 |
canvas.width = width; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2271 |
canvas.height = height; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2272 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2273 |
// Copy classes from the image to the canvas. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2274 |
canvas.className = img.className; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2275 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2276 |
// Check if the image is inside a specific table. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2277 |
var isInsideUpdateTable = img.closest( '#update-plugins-table' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2278 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2279 |
if ( isInsideUpdateTable ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2280 |
// Transfer computed styles from image to canvas. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2281 |
var computedStyles = window.getComputedStyle( img ), |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2282 |
i, max; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2283 |
for ( i = 0, max = computedStyles.length; i < max; i++ ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2284 |
var propName = computedStyles[ i ]; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2285 |
var propValue = computedStyles.getPropertyValue( propName ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2286 |
canvas.style[ propName ] = propValue; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2287 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2288 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2289 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2290 |
// Draw the image onto the canvas. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2291 |
canvas.getContext( '2d' ).drawImage( img, 0, 0, width, height ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2292 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2293 |
// Set accessibility attributes on canvas. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2294 |
canvas.setAttribute( 'aria-hidden', 'true' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2295 |
canvas.setAttribute( 'role', 'presentation' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2296 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2297 |
// Insert canvas before the image and set the image to be near-invisible. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2298 |
var parent = img.parentNode; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2299 |
parent.insertBefore( canvas, img ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2300 |
img.style.opacity = 0.01; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2301 |
img.style.width = '0px'; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2302 |
img.style.height = '0px'; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2303 |
}; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2304 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2305 |
// If the image is already loaded, apply the coverImage function. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2306 |
if ( img.complete ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2307 |
coverImage(); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2308 |
} else { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2309 |
// Otherwise, wait for the image to load. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2310 |
img.addEventListener( 'load', coverImage, true ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2311 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2312 |
}; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2313 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2314 |
// Public method to freeze all relevant GIFs on the page. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2315 |
pub.freezeAll = function() { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2316 |
var images = document.querySelectorAll( '.plugin-icon, #update-plugins-table img' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2317 |
for ( var x = 0; x < images.length; x++ ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2318 |
if ( /\.gif(?:\?|$)/i.test( images[ x ].src ) ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2319 |
priv.freezeAnimatedPluginIcons( images[ x ] ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2320 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2321 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2322 |
}; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2323 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2324 |
// Only run the freezeAll method if the user prefers reduced motion. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2325 |
if ( true === priv.pauseAll ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2326 |
pub.freezeAll(); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2327 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2328 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2329 |
// Listen for jQuery AJAX events. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2330 |
( function( $ ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2331 |
if ( window.pagenow === 'plugin-install' ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2332 |
// Only listen for ajaxComplete if this is the plugin-install.php page. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2333 |
$( document ).ajaxComplete( function( event, xhr, settings ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2334 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2335 |
// Check if this is the 'search-install-plugins' request. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2336 |
if ( settings.data && typeof settings.data === 'string' && settings.data.includes( 'action=search-install-plugins' ) ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2337 |
// Recheck if the user prefers reduced motion. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2338 |
if ( window.matchMedia ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2339 |
var mediaQuery = window.matchMedia( '(prefers-reduced-motion: reduce)' ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2340 |
if ( mediaQuery.matches ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2341 |
pub.freezeAll(); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2342 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2343 |
} else { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2344 |
// Fallback for browsers that don't support matchMedia. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2345 |
if ( true === priv.pauseAll ) { |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2346 |
pub.freezeAll(); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2347 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2348 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2349 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2350 |
} ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2351 |
} |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2352 |
} )( jQuery ); |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2353 |
|
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2354 |
// Expose public methods. |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2355 |
return pub; |
48c4eec2b7e6
Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents:
19
diff
changeset
|
2356 |
})(); |