123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705 |
- <?php
- /**
- * WordPress scripts and styles default loader.
- *
- * Several constants are used to manage the loading, concatenating and compression of scripts and CSS:
- * define('SCRIPT_DEBUG', true); loads the development (non-minified) versions of all scripts and CSS, and disables compression and concatenation,
- * define('CONCATENATE_SCRIPTS', false); disables compression and concatenation of scripts and CSS,
- * define('COMPRESS_SCRIPTS', false); disables compression of scripts,
- * define('COMPRESS_CSS', false); disables compression of CSS,
- * define('ENFORCE_GZIP', true); forces gzip for compression (default is deflate).
- *
- * The globals $concatenate_scripts, $compress_scripts and $compress_css can be set by plugins
- * to temporarily override the above settings. Also a compression test is run once and the result is saved
- * as option 'can_compress_scripts' (0/1). The test will run again if that option is deleted.
- *
- * @package WordPress
- */
- /** WordPress Dependency Class */
- require ABSPATH . WPINC . '/class-wp-dependency.php';
- /** WordPress Dependencies Class */
- require ABSPATH . WPINC . '/class-wp-dependencies.php';
- /** WordPress Scripts Class */
- require ABSPATH . WPINC . '/class-wp-scripts.php';
- /** WordPress Scripts Functions */
- require ABSPATH . WPINC . '/functions.wp-scripts.php';
- /** WordPress Styles Class */
- require ABSPATH . WPINC . '/class-wp-styles.php';
- /** WordPress Styles Functions */
- require ABSPATH . WPINC . '/functions.wp-styles.php';
- /**
- * Registers TinyMCE scripts.
- *
- * @since 5.0.0
- *
- * @global string $tinymce_version
- * @global bool $concatenate_scripts
- * @global bool $compress_scripts
- *
- * @param WP_Scripts $scripts WP_Scripts object.
- * @param bool $force_uncompressed Whether to forcibly prevent gzip compression. Default false.
- */
- function wp_register_tinymce_scripts( $scripts, $force_uncompressed = false ) {
- global $tinymce_version, $concatenate_scripts, $compress_scripts;
- $suffix = wp_scripts_get_suffix();
- $dev_suffix = wp_scripts_get_suffix( 'dev' );
- script_concat_settings();
- $compressed = $compress_scripts && $concatenate_scripts && isset( $_SERVER['HTTP_ACCEPT_ENCODING'] )
- && false !== stripos( $_SERVER['HTTP_ACCEPT_ENCODING'], 'gzip' ) && ! $force_uncompressed;
- // Load tinymce.js when running from /src, otherwise load wp-tinymce.js.gz (in production)
- // or tinymce.min.js (when SCRIPT_DEBUG is true).
- if ( $compressed ) {
- $scripts->add( 'wp-tinymce', includes_url( 'js/tinymce/' ) . 'wp-tinymce.js', array(), $tinymce_version );
- } else {
- $scripts->add( 'wp-tinymce-root', includes_url( 'js/tinymce/' ) . "tinymce$dev_suffix.js", array(), $tinymce_version );
- $scripts->add( 'wp-tinymce', includes_url( 'js/tinymce/' ) . "plugins/compat3x/plugin$dev_suffix.js", array( 'wp-tinymce-root' ), $tinymce_version );
- }
- $scripts->add( 'wp-tinymce-lists', includes_url( "js/tinymce/plugins/lists/plugin$suffix.js" ), array( 'wp-tinymce' ), $tinymce_version );
- }
- /**
- * Registers all the WordPress vendor scripts that are in the standardized
- * `js/dist/vendor/` location.
- *
- * For the order of `$scripts->add` see `wp_default_scripts`.
- *
- * @since 5.0.0
- *
- * @global WP_Locale $wp_locale WordPress date and time locale object.
- *
- * @param WP_Scripts $scripts WP_Scripts object.
- */
- function wp_default_packages_vendor( $scripts ) {
- global $wp_locale;
- $suffix = wp_scripts_get_suffix();
- $vendor_scripts = array(
- 'react' => array( 'wp-polyfill' ),
- 'react-dom' => array( 'react' ),
- 'regenerator-runtime',
- 'moment',
- 'lodash',
- 'wp-polyfill-fetch',
- 'wp-polyfill-formdata',
- 'wp-polyfill-node-contains',
- 'wp-polyfill-url',
- 'wp-polyfill-dom-rect',
- 'wp-polyfill-element-closest',
- 'wp-polyfill-object-fit',
- 'wp-polyfill' => array( 'regenerator-runtime' ),
- );
- $vendor_scripts_versions = array(
- 'react' => '17.0.1',
- 'react-dom' => '17.0.1',
- 'regenerator-runtime' => '0.13.9',
- 'moment' => '2.29.4',
- 'lodash' => '4.17.19',
- 'wp-polyfill-fetch' => '3.6.2',
- 'wp-polyfill-formdata' => '4.0.10',
- 'wp-polyfill-node-contains' => '4.4.0',
- 'wp-polyfill-url' => '3.6.4',
- 'wp-polyfill-dom-rect' => '4.4.0',
- 'wp-polyfill-element-closest' => '2.0.2',
- 'wp-polyfill-object-fit' => '2.3.5',
- 'wp-polyfill' => '3.15.0',
- );
- foreach ( $vendor_scripts as $handle => $dependencies ) {
- if ( is_string( $dependencies ) ) {
- $handle = $dependencies;
- $dependencies = array();
- }
- $path = "/wp-includes/js/dist/vendor/$handle$suffix.js";
- $version = $vendor_scripts_versions[ $handle ];
- $scripts->add( $handle, $path, $dependencies, $version, 1 );
- }
- did_action( 'init' ) && $scripts->add_inline_script( 'lodash', 'window.lodash = _.noConflict();' );
- did_action( 'init' ) && $scripts->add_inline_script(
- 'moment',
- sprintf(
- "moment.updateLocale( '%s', %s );",
- get_user_locale(),
- wp_json_encode(
- array(
- 'months' => array_values( $wp_locale->month ),
- 'monthsShort' => array_values( $wp_locale->month_abbrev ),
- 'weekdays' => array_values( $wp_locale->weekday ),
- 'weekdaysShort' => array_values( $wp_locale->weekday_abbrev ),
- 'week' => array(
- 'dow' => (int) get_option( 'start_of_week', 0 ),
- ),
- 'longDateFormat' => array(
- 'LT' => get_option( 'time_format', __( 'g:i a' ) ),
- 'LTS' => null,
- 'L' => null,
- 'LL' => get_option( 'date_format', __( 'F j, Y' ) ),
- 'LLL' => __( 'F j, Y g:i a' ),
- 'LLLL' => null,
- ),
- )
- )
- ),
- 'after'
- );
- }
- /**
- * Returns contents of an inline script used in appending polyfill scripts for
- * browsers which fail the provided tests. The provided array is a mapping from
- * a condition to verify feature support to its polyfill script handle.
- *
- * @since 5.0.0
- *
- * @param WP_Scripts $scripts WP_Scripts object.
- * @param string[] $tests Features to detect.
- * @return string Conditional polyfill inline script.
- */
- function wp_get_script_polyfill( $scripts, $tests ) {
- $polyfill = '';
- foreach ( $tests as $test => $handle ) {
- if ( ! array_key_exists( $handle, $scripts->registered ) ) {
- continue;
- }
- $src = $scripts->registered[ $handle ]->src;
- $ver = $scripts->registered[ $handle ]->ver;
- if ( ! preg_match( '|^(https?:)?//|', $src ) && ! ( $scripts->content_url && 0 === strpos( $src, $scripts->content_url ) ) ) {
- $src = $scripts->base_url . $src;
- }
- if ( ! empty( $ver ) ) {
- $src = add_query_arg( 'ver', $ver, $src );
- }
- /** This filter is documented in wp-includes/class-wp-scripts.php */
- $src = esc_url( apply_filters( 'script_loader_src', $src, $handle ) );
- if ( ! $src ) {
- continue;
- }
- $polyfill .= (
- // Test presence of feature...
- '( ' . $test . ' ) || ' .
- /*
- * ...appending polyfill on any failures. Cautious viewers may balk
- * at the `document.write`. Its caveat of synchronous mid-stream
- * blocking write is exactly the behavior we need though.
- */
- 'document.write( \'<script src="' .
- $src .
- '"></scr\' + \'ipt>\' );'
- );
- }
- return $polyfill;
- }
- /**
- * Registers development scripts that integrate with `@wordpress/scripts`.
- *
- * @see https://github.com/WordPress/gutenberg/tree/trunk/packages/scripts#start
- *
- * @since 6.0.0
- *
- * @param WP_Scripts $scripts WP_Scripts object.
- */
- function wp_register_development_scripts( $scripts ) {
- if (
- ! defined( 'SCRIPT_DEBUG' ) || ! SCRIPT_DEBUG
- || empty( $scripts->registered['react'] )
- || defined( 'WP_RUN_CORE_TESTS' )
- ) {
- return;
- }
- $development_scripts = array(
- 'react-refresh-entry',
- 'react-refresh-runtime',
- );
- foreach ( $development_scripts as $script_name ) {
- $assets = include ABSPATH . WPINC . '/assets/script-loader-' . $script_name . '.php';
- if ( ! is_array( $assets ) ) {
- return;
- }
- $scripts->add(
- 'wp-' . $script_name,
- '/wp-includes/js/dist/development/' . $script_name . '.js',
- $assets['dependencies'],
- $assets['version']
- );
- }
- // See https://github.com/pmmmwh/react-refresh-webpack-plugin/blob/main/docs/TROUBLESHOOTING.md#externalising-react.
- $scripts->registered['react']->deps[] = 'wp-react-refresh-entry';
- }
- /**
- * Registers all the WordPress packages scripts that are in the standardized
- * `js/dist/` location.
- *
- * For the order of `$scripts->add` see `wp_default_scripts`.
- *
- * @since 5.0.0
- *
- * @param WP_Scripts $scripts WP_Scripts object.
- */
- function wp_default_packages_scripts( $scripts ) {
- $suffix = defined( 'WP_RUN_CORE_TESTS' ) ? '.min' : wp_scripts_get_suffix();
- /*
- * Expects multidimensional array like:
- *
- * 'a11y.js' => array('dependencies' => array(...), 'version' => '...'),
- * 'annotations.js' => array('dependencies' => array(...), 'version' => '...'),
- * 'api-fetch.js' => array(...
- */
- $assets = include ABSPATH . WPINC . "/assets/script-loader-packages{$suffix}.php";
- foreach ( $assets as $file_name => $package_data ) {
- $basename = str_replace( $suffix . '.js', '', basename( $file_name ) );
- $handle = 'wp-' . $basename;
- $path = "/wp-includes/js/dist/{$basename}{$suffix}.js";
- if ( ! empty( $package_data['dependencies'] ) ) {
- $dependencies = $package_data['dependencies'];
- } else {
- $dependencies = array();
- }
- // Add dependencies that cannot be detected and generated by build tools.
- switch ( $handle ) {
- case 'wp-block-library':
- array_push( $dependencies, 'editor' );
- break;
- case 'wp-edit-post':
- array_push( $dependencies, 'media-models', 'media-views', 'postbox', 'wp-dom-ready' );
- break;
- case 'wp-preferences':
- array_push( $dependencies, 'wp-preferences-persistence' );
- break;
- }
- $scripts->add( $handle, $path, $dependencies, $package_data['version'], 1 );
- if ( in_array( 'wp-i18n', $dependencies, true ) ) {
- $scripts->set_translations( $handle );
- }
- /*
- * Manually set the text direction localization after wp-i18n is printed.
- * This ensures that wp.i18n.isRTL() returns true in RTL languages.
- * We cannot use $scripts->set_translations( 'wp-i18n' ) to do this
- * because WordPress prints a script's translations *before* the script,
- * which means, in the case of wp-i18n, that wp.i18n.setLocaleData()
- * is called before wp.i18n is defined.
- */
- if ( 'wp-i18n' === $handle ) {
- $ltr = _x( 'ltr', 'text direction' );
- $script = sprintf( "wp.i18n.setLocaleData( { 'text direction\u0004ltr': [ '%s' ] } );", $ltr );
- $scripts->add_inline_script( $handle, $script, 'after' );
- }
- }
- }
- /**
- * Adds inline scripts required for the WordPress JavaScript packages.
- *
- * @since 5.0.0
- *
- * @global WP_Locale $wp_locale WordPress date and time locale object.
- * @global wpdb $wpdb WordPress database abstraction object.
- *
- * @param WP_Scripts $scripts WP_Scripts object.
- */
- function wp_default_packages_inline_scripts( $scripts ) {
- global $wp_locale, $wpdb;
- if ( isset( $scripts->registered['wp-api-fetch'] ) ) {
- $scripts->registered['wp-api-fetch']->deps[] = 'wp-hooks';
- }
- $scripts->add_inline_script(
- 'wp-api-fetch',
- sprintf(
- 'wp.apiFetch.use( wp.apiFetch.createRootURLMiddleware( "%s" ) );',
- sanitize_url( get_rest_url() )
- ),
- 'after'
- );
- $scripts->add_inline_script(
- 'wp-api-fetch',
- implode(
- "\n",
- array(
- sprintf(
- 'wp.apiFetch.nonceMiddleware = wp.apiFetch.createNonceMiddleware( "%s" );',
- wp_installing() ? '' : wp_create_nonce( 'wp_rest' )
- ),
- 'wp.apiFetch.use( wp.apiFetch.nonceMiddleware );',
- 'wp.apiFetch.use( wp.apiFetch.mediaUploadMiddleware );',
- sprintf(
- 'wp.apiFetch.nonceEndpoint = "%s";',
- admin_url( 'admin-ajax.php?action=rest-nonce' )
- ),
- )
- ),
- 'after'
- );
- $meta_key = $wpdb->get_blog_prefix() . 'persisted_preferences';
- $user_id = get_current_user_id();
- $preload_data = get_user_meta( $user_id, $meta_key, true );
- $scripts->add_inline_script(
- 'wp-preferences',
- sprintf(
- '( function() {
- var serverData = %s;
- var userId = "%d";
- var persistenceLayer = wp.preferencesPersistence.__unstableCreatePersistenceLayer( serverData, userId );
- var preferencesStore = wp.preferences.store;
- wp.data.dispatch( preferencesStore ).setPersistenceLayer( persistenceLayer );
- } ) ();',
- wp_json_encode( $preload_data ),
- $user_id
- )
- );
- // Backwards compatibility - configure the old wp-data persistence system.
- $scripts->add_inline_script(
- 'wp-data',
- implode(
- "\n",
- array(
- '( function() {',
- ' var userId = ' . get_current_user_ID() . ';',
- ' var storageKey = "WP_DATA_USER_" + userId;',
- ' wp.data',
- ' .use( wp.data.plugins.persistence, { storageKey: storageKey } );',
- '} )();',
- )
- )
- );
- // Calculate the timezone abbr (EDT, PST) if possible.
- $timezone_string = get_option( 'timezone_string', 'UTC' );
- $timezone_abbr = '';
- if ( ! empty( $timezone_string ) ) {
- $timezone_date = new DateTime( 'now', new DateTimeZone( $timezone_string ) );
- $timezone_abbr = $timezone_date->format( 'T' );
- }
- $scripts->add_inline_script(
- 'wp-date',
- sprintf(
- 'wp.date.setSettings( %s );',
- wp_json_encode(
- array(
- 'l10n' => array(
- 'locale' => get_user_locale(),
- 'months' => array_values( $wp_locale->month ),
- 'monthsShort' => array_values( $wp_locale->month_abbrev ),
- 'weekdays' => array_values( $wp_locale->weekday ),
- 'weekdaysShort' => array_values( $wp_locale->weekday_abbrev ),
- 'meridiem' => (object) $wp_locale->meridiem,
- 'relative' => array(
- /* translators: %s: Duration. */
- 'future' => __( '%s from now' ),
- /* translators: %s: Duration. */
- 'past' => __( '%s ago' ),
- ),
- 'startOfWeek' => (int) get_option( 'start_of_week', 0 ),
- ),
- 'formats' => array(
- /* translators: Time format, see https://www.php.net/manual/datetime.format.php */
- 'time' => get_option( 'time_format', __( 'g:i a' ) ),
- /* translators: Date format, see https://www.php.net/manual/datetime.format.php */
- 'date' => get_option( 'date_format', __( 'F j, Y' ) ),
- /* translators: Date/Time format, see https://www.php.net/manual/datetime.format.php */
- 'datetime' => __( 'F j, Y g:i a' ),
- /* translators: Abbreviated date/time format, see https://www.php.net/manual/datetime.format.php */
- 'datetimeAbbreviated' => __( 'M j, Y g:i a' ),
- ),
- 'timezone' => array(
- 'offset' => (float) get_option( 'gmt_offset', 0 ),
- 'string' => $timezone_string,
- 'abbr' => $timezone_abbr,
- ),
- )
- )
- ),
- 'after'
- );
- // Loading the old editor and its config to ensure the classic block works as expected.
- $scripts->add_inline_script(
- 'editor',
- 'window.wp.oldEditor = window.wp.editor;',
- 'after'
- );
- /*
- * wp-editor module is exposed as window.wp.editor.
- * Problem: there is quite some code expecting window.wp.oldEditor object available under window.wp.editor.
- * Solution: fuse the two objects together to maintain backward compatibility.
- * For more context, see https://github.com/WordPress/gutenberg/issues/33203.
- */
- $scripts->add_inline_script(
- 'wp-editor',
- 'Object.assign( window.wp.editor, window.wp.oldEditor );',
- 'after'
- );
- }
- /**
- * Adds inline scripts required for the TinyMCE in the block editor.
- *
- * These TinyMCE init settings are used to extend and override the default settings
- * from `_WP_Editors::default_settings()` for the Classic block.
- *
- * @since 5.0.0
- *
- * @global WP_Scripts $wp_scripts
- */
- function wp_tinymce_inline_scripts() {
- global $wp_scripts;
- /** This filter is documented in wp-includes/class-wp-editor.php */
- $editor_settings = apply_filters( 'wp_editor_settings', array( 'tinymce' => true ), 'classic-block' );
- $tinymce_plugins = array(
- 'charmap',
- 'colorpicker',
- 'hr',
- 'lists',
- 'media',
- 'paste',
- 'tabfocus',
- 'textcolor',
- 'fullscreen',
- 'wordpress',
- 'wpautoresize',
- 'wpeditimage',
- 'wpemoji',
- 'wpgallery',
- 'wplink',
- 'wpdialogs',
- 'wptextpattern',
- 'wpview',
- );
- /** This filter is documented in wp-includes/class-wp-editor.php */
- $tinymce_plugins = apply_filters( 'tiny_mce_plugins', $tinymce_plugins, 'classic-block' );
- $tinymce_plugins = array_unique( $tinymce_plugins );
- $disable_captions = false;
- // Runs after `tiny_mce_plugins` but before `mce_buttons`.
- /** This filter is documented in wp-admin/includes/media.php */
- if ( apply_filters( 'disable_captions', '' ) ) {
- $disable_captions = true;
- }
- $toolbar1 = array(
- 'formatselect',
- 'bold',
- 'italic',
- 'bullist',
- 'numlist',
- 'blockquote',
- 'alignleft',
- 'aligncenter',
- 'alignright',
- 'link',
- 'unlink',
- 'wp_more',
- 'spellchecker',
- 'wp_add_media',
- 'wp_adv',
- );
- /** This filter is documented in wp-includes/class-wp-editor.php */
- $toolbar1 = apply_filters( 'mce_buttons', $toolbar1, 'classic-block' );
- $toolbar2 = array(
- 'strikethrough',
- 'hr',
- 'forecolor',
- 'pastetext',
- 'removeformat',
- 'charmap',
- 'outdent',
- 'indent',
- 'undo',
- 'redo',
- 'wp_help',
- );
- /** This filter is documented in wp-includes/class-wp-editor.php */
- $toolbar2 = apply_filters( 'mce_buttons_2', $toolbar2, 'classic-block' );
- /** This filter is documented in wp-includes/class-wp-editor.php */
- $toolbar3 = apply_filters( 'mce_buttons_3', array(), 'classic-block' );
- /** This filter is documented in wp-includes/class-wp-editor.php */
- $toolbar4 = apply_filters( 'mce_buttons_4', array(), 'classic-block' );
- /** This filter is documented in wp-includes/class-wp-editor.php */
- $external_plugins = apply_filters( 'mce_external_plugins', array(), 'classic-block' );
- $tinymce_settings = array(
- 'plugins' => implode( ',', $tinymce_plugins ),
- 'toolbar1' => implode( ',', $toolbar1 ),
- 'toolbar2' => implode( ',', $toolbar2 ),
- 'toolbar3' => implode( ',', $toolbar3 ),
- 'toolbar4' => implode( ',', $toolbar4 ),
- 'external_plugins' => wp_json_encode( $external_plugins ),
- 'classic_block_editor' => true,
- );
- if ( $disable_captions ) {
- $tinymce_settings['wpeditimage_disable_captions'] = true;
- }
- if ( ! empty( $editor_settings['tinymce'] ) && is_array( $editor_settings['tinymce'] ) ) {
- array_merge( $tinymce_settings, $editor_settings['tinymce'] );
- }
- /** This filter is documented in wp-includes/class-wp-editor.php */
- $tinymce_settings = apply_filters( 'tiny_mce_before_init', $tinymce_settings, 'classic-block' );
- // Do "by hand" translation from PHP array to js object.
- // Prevents breakage in some custom settings.
- $init_obj = '';
- foreach ( $tinymce_settings as $key => $value ) {
- if ( is_bool( $value ) ) {
- $val = $value ? 'true' : 'false';
- $init_obj .= $key . ':' . $val . ',';
- continue;
- } elseif ( ! empty( $value ) && is_string( $value ) && (
- ( '{' === $value[0] && '}' === $value[ strlen( $value ) - 1 ] ) ||
- ( '[' === $value[0] && ']' === $value[ strlen( $value ) - 1 ] ) ||
- preg_match( '/^\(?function ?\(/', $value ) ) ) {
- $init_obj .= $key . ':' . $value . ',';
- continue;
- }
- $init_obj .= $key . ':"' . $value . '",';
- }
- $init_obj = '{' . trim( $init_obj, ' ,' ) . '}';
- $script = 'window.wpEditorL10n = {
- tinymce: {
- baseURL: ' . wp_json_encode( includes_url( 'js/tinymce' ) ) . ',
- suffix: ' . ( SCRIPT_DEBUG ? '""' : '".min"' ) . ',
- settings: ' . $init_obj . ',
- }
- }';
- $wp_scripts->add_inline_script( 'wp-block-library', $script, 'before' );
- }
- /**
- * Registers all the WordPress packages scripts.
- *
- * @since 5.0.0
- *
- * @param WP_Scripts $scripts WP_Scripts object.
- */
- function wp_default_packages( $scripts ) {
- wp_default_packages_vendor( $scripts );
- wp_register_development_scripts( $scripts );
- wp_register_tinymce_scripts( $scripts );
- wp_default_packages_scripts( $scripts );
- if ( did_action( 'init' ) ) {
- wp_default_packages_inline_scripts( $scripts );
- }
- }
- /**
- * Returns the suffix that can be used for the scripts.
- *
- * There are two suffix types, the normal one and the dev suffix.
- *
- * @since 5.0.0
- *
- * @param string $type The type of suffix to retrieve.
- * @return string The script suffix.
- */
- function wp_scripts_get_suffix( $type = '' ) {
- static $suffixes;
- if ( null === $suffixes ) {
- // Include an unmodified $wp_version.
- require ABSPATH . WPINC . '/version.php';
- $develop_src = false !== strpos( $wp_version, '-src' );
- if ( ! defined( 'SCRIPT_DEBUG' ) ) {
- define( 'SCRIPT_DEBUG', $develop_src );
- }
- $suffix = SCRIPT_DEBUG ? '' : '.min';
- $dev_suffix = $develop_src ? '' : '.min';
- $suffixes = array(
- 'suffix' => $suffix,
- 'dev_suffix' => $dev_suffix,
- );
- }
- if ( 'dev' === $type ) {
- return $suffixes['dev_suffix'];
- }
- return $suffixes['suffix'];
- }
- /**
- * Registers all WordPress scripts.
- *
- * Localizes some of them.
- * args order: `$scripts->add( 'handle', 'url', 'dependencies', 'query-string', 1 );`
- * when last arg === 1 queues the script for the footer
- *
- * @since 2.6.0
- *
- * @param WP_Scripts $scripts WP_Scripts object.
- */
- function wp_default_scripts( $scripts ) {
- $suffix = wp_scripts_get_suffix();
- $dev_suffix = wp_scripts_get_suffix( 'dev' );
- $guessurl = site_url();
- if ( ! $guessurl ) {
- $guessed_url = true;
- $guessurl = wp_guess_url();
- }
- $scripts->base_url = $guessurl;
- $scripts->content_url = defined( 'WP_CONTENT_URL' ) ? WP_CONTENT_URL : '';
- $scripts->default_version = get_bloginfo( 'version' );
- $scripts->default_dirs = array( '/wp-admin/js/', '/wp-includes/js/' );
- $scripts->add( 'utils', "/wp-includes/js/utils$suffix.js" );
- did_action( 'init' ) && $scripts->localize(
- 'utils',
- 'userSettings',
- array(
- 'url' => (string) SITECOOKIEPATH,
- 'uid' => (string) get_current_user_id(),
- 'time' => (string) time(),
- 'secure' => (string) ( 'https' === parse_url( site_url(), PHP_URL_SCHEME ) ),
- )
- );
- $scripts->add( 'common', "/wp-admin/js/common$suffix.js", array( 'jquery', 'hoverIntent', 'utils' ), false, 1 );
- $scripts->set_translations( 'common' );
- $scripts->add( 'wp-sanitize', "/wp-includes/js/wp-sanitize$suffix.js", array(), false, 1 );
- $scripts->add( 'sack', "/wp-includes/js/tw-sack$suffix.js", array(), '1.6.1', 1 );
- $scripts->add( 'quicktags', "/wp-includes/js/quicktags$suffix.js", array(), false, 1 );
- did_action( 'init' ) && $scripts->localize(
- 'quicktags',
- 'quicktagsL10n',
- array(
- 'closeAllOpenTags' => __( 'Close all open tags' ),
- 'closeTags' => __( 'close tags' ),
- 'enterURL' => __( 'Enter the URL' ),
- 'enterImageURL' => __( 'Enter the URL of the image' ),
- 'enterImageDescription' => __( 'Enter a description of the image' ),
- 'textdirection' => __( 'text direction' ),
- 'toggleTextdirection' => __( 'Toggle Editor Text Direction' ),
- 'dfw' => __( 'Distraction-free writing mode' ),
- 'strong' => __( 'Bold' ),
- 'strongClose' => __( 'Close bold tag' ),
- 'em' => __( 'Italic' ),
- 'emClose' => __( 'Close italic tag' ),
- 'link' => __( 'Insert link' ),
- 'blockquote' => __( 'Blockquote' ),
- 'blockquoteClose' => __( 'Close blockquote tag' ),
- 'del' => __( 'Deleted text (strikethrough)' ),
- 'delClose' => __( 'Close deleted text tag' ),
- 'ins' => __( 'Inserted text' ),
- 'insClose' => __( 'Close inserted text tag' ),
- 'image' => __( 'Insert image' ),
- 'ul' => __( 'Bulleted list' ),
- 'ulClose' => __( 'Close bulleted list tag' ),
- 'ol' => __( 'Numbered list' ),
- 'olClose' => __( 'Close numbered list tag' ),
- 'li' => __( 'List item' ),
- 'liClose' => __( 'Close list item tag' ),
- 'code' => __( 'Code' ),
- 'codeClose' => __( 'Close code tag' ),
- 'more' => __( 'Insert Read More tag' ),
- )
- );
- $scripts->add( 'colorpicker', "/wp-includes/js/colorpicker$suffix.js", array( 'prototype' ), '3517m' );
- $scripts->add( 'editor', "/wp-admin/js/editor$suffix.js", array( 'utils', 'jquery' ), false, 1 );
- $scripts->add( 'clipboard', "/wp-includes/js/clipboard$suffix.js", array(), '2.0.11', 1 );
- $scripts->add( 'wp-ajax-response', "/wp-includes/js/wp-ajax-response$suffix.js", array( 'jquery', 'wp-a11y' ), false, 1 );
- did_action( 'init' ) && $scripts->localize(
- 'wp-ajax-response',
- 'wpAjax',
- array(
- 'noPerm' => __( 'Sorry, you are not allowed to do that.' ),
- 'broken' => __( 'Something went wrong.' ),
- )
- );
- $scripts->add( 'wp-api-request', "/wp-includes/js/api-request$suffix.js", array( 'jquery' ), false, 1 );
- // `wpApiSettings` is also used by `wp-api`, which depends on this script.
- did_action( 'init' ) && $scripts->localize(
- 'wp-api-request',
- 'wpApiSettings',
- array(
- 'root' => sanitize_url( get_rest_url() ),
- 'nonce' => wp_installing() ? '' : wp_create_nonce( 'wp_rest' ),
- 'versionString' => 'wp/v2/',
- )
- );
- $scripts->add( 'wp-pointer', "/wp-includes/js/wp-pointer$suffix.js", array( 'jquery-ui-core' ), false, 1 );
- $scripts->set_translations( 'wp-pointer' );
- $scripts->add( 'autosave', "/wp-includes/js/autosave$suffix.js", array( 'heartbeat' ), false, 1 );
- $scripts->add( 'heartbeat', "/wp-includes/js/heartbeat$suffix.js", array( 'jquery', 'wp-hooks' ), false, 1 );
- did_action( 'init' ) && $scripts->localize(
- 'heartbeat',
- 'heartbeatSettings',
- /**
- * Filters the Heartbeat settings.
- *
- * @since 3.6.0
- *
- * @param array $settings Heartbeat settings array.
- */
- apply_filters( 'heartbeat_settings', array() )
- );
- $scripts->add( 'wp-auth-check', "/wp-includes/js/wp-auth-check$suffix.js", array( 'heartbeat' ), false, 1 );
- $scripts->set_translations( 'wp-auth-check' );
- $scripts->add( 'wp-lists', "/wp-includes/js/wp-lists$suffix.js", array( 'wp-ajax-response', 'jquery-color' ), false, 1 );
- // WordPress no longer uses or bundles Prototype or script.aculo.us. These are now pulled from an external source.
- $scripts->add( 'prototype', 'https://ajax.googleapis.com/ajax/libs/prototype/1.7.1.0/prototype.js', array(), '1.7.1' );
- $scripts->add( 'scriptaculous-root', 'https://ajax.googleapis.com/ajax/libs/scriptaculous/1.9.0/scriptaculous.js', array( 'prototype' ), '1.9.0' );
- $scripts->add( 'scriptaculous-builder', 'https://ajax.googleapis.com/ajax/libs/scriptaculous/1.9.0/builder.js', array( 'scriptaculous-root' ), '1.9.0' );
- $scripts->add( 'scriptaculous-dragdrop', 'https://ajax.googleapis.com/ajax/libs/scriptaculous/1.9.0/dragdrop.js', array( 'scriptaculous-builder', 'scriptaculous-effects' ), '1.9.0' );
- $scripts->add( 'scriptaculous-effects', 'https://ajax.googleapis.com/ajax/libs/scriptaculous/1.9.0/effects.js', array( 'scriptaculous-root' ), '1.9.0' );
- $scripts->add( 'scriptaculous-slider', 'https://ajax.googleapis.com/ajax/libs/scriptaculous/1.9.0/slider.js', array( 'scriptaculous-effects' ), '1.9.0' );
- $scripts->add( 'scriptaculous-sound', 'https://ajax.googleapis.com/ajax/libs/scriptaculous/1.9.0/sound.js', array( 'scriptaculous-root' ), '1.9.0' );
- $scripts->add( 'scriptaculous-controls', 'https://ajax.googleapis.com/ajax/libs/scriptaculous/1.9.0/controls.js', array( 'scriptaculous-root' ), '1.9.0' );
- $scripts->add( 'scriptaculous', false, array( 'scriptaculous-dragdrop', 'scriptaculous-slider', 'scriptaculous-controls' ) );
- // Not used in core, replaced by Jcrop.js.
- $scripts->add( 'cropper', '/wp-includes/js/crop/cropper.js', array( 'scriptaculous-dragdrop' ) );
- // jQuery.
- // The unminified jquery.js and jquery-migrate.js are included to facilitate debugging.
- $scripts->add( 'jquery', false, array( 'jquery-core', 'jquery-migrate' ), '3.6.1' );
- $scripts->add( 'jquery-core', "/wp-includes/js/jquery/jquery$suffix.js", array(), '3.6.1' );
- $scripts->add( 'jquery-migrate', "/wp-includes/js/jquery/jquery-migrate$suffix.js", array(), '3.3.2' );
- // Full jQuery UI.
- // The build process in 1.12.1 has changed significantly.
- // In order to keep backwards compatibility, and to keep the optimized loading,
- // the source files were flattened and included with some modifications for AMD loading.
- // A notable change is that 'jquery-ui-core' now contains 'jquery-ui-position' and 'jquery-ui-widget'.
- $scripts->add( 'jquery-ui-core', "/wp-includes/js/jquery/ui/core$suffix.js", array( 'jquery' ), '1.13.2', 1 );
- $scripts->add( 'jquery-effects-core', "/wp-includes/js/jquery/ui/effect$suffix.js", array( 'jquery' ), '1.13.2', 1 );
- $scripts->add( 'jquery-effects-blind', "/wp-includes/js/jquery/ui/effect-blind$suffix.js", array( 'jquery-effects-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-effects-bounce', "/wp-includes/js/jquery/ui/effect-bounce$suffix.js", array( 'jquery-effects-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-effects-clip', "/wp-includes/js/jquery/ui/effect-clip$suffix.js", array( 'jquery-effects-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-effects-drop', "/wp-includes/js/jquery/ui/effect-drop$suffix.js", array( 'jquery-effects-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-effects-explode', "/wp-includes/js/jquery/ui/effect-explode$suffix.js", array( 'jquery-effects-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-effects-fade', "/wp-includes/js/jquery/ui/effect-fade$suffix.js", array( 'jquery-effects-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-effects-fold', "/wp-includes/js/jquery/ui/effect-fold$suffix.js", array( 'jquery-effects-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-effects-highlight', "/wp-includes/js/jquery/ui/effect-highlight$suffix.js", array( 'jquery-effects-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-effects-puff', "/wp-includes/js/jquery/ui/effect-puff$suffix.js", array( 'jquery-effects-core', 'jquery-effects-scale' ), '1.13.2', 1 );
- $scripts->add( 'jquery-effects-pulsate', "/wp-includes/js/jquery/ui/effect-pulsate$suffix.js", array( 'jquery-effects-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-effects-scale', "/wp-includes/js/jquery/ui/effect-scale$suffix.js", array( 'jquery-effects-core', 'jquery-effects-size' ), '1.13.2', 1 );
- $scripts->add( 'jquery-effects-shake', "/wp-includes/js/jquery/ui/effect-shake$suffix.js", array( 'jquery-effects-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-effects-size', "/wp-includes/js/jquery/ui/effect-size$suffix.js", array( 'jquery-effects-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-effects-slide', "/wp-includes/js/jquery/ui/effect-slide$suffix.js", array( 'jquery-effects-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-effects-transfer', "/wp-includes/js/jquery/ui/effect-transfer$suffix.js", array( 'jquery-effects-core' ), '1.13.2', 1 );
- // Widgets
- $scripts->add( 'jquery-ui-accordion', "/wp-includes/js/jquery/ui/accordion$suffix.js", array( 'jquery-ui-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-autocomplete', "/wp-includes/js/jquery/ui/autocomplete$suffix.js", array( 'jquery-ui-menu', 'wp-a11y' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-button', "/wp-includes/js/jquery/ui/button$suffix.js", array( 'jquery-ui-core', 'jquery-ui-controlgroup', 'jquery-ui-checkboxradio' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-datepicker', "/wp-includes/js/jquery/ui/datepicker$suffix.js", array( 'jquery-ui-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-dialog', "/wp-includes/js/jquery/ui/dialog$suffix.js", array( 'jquery-ui-resizable', 'jquery-ui-draggable', 'jquery-ui-button' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-menu', "/wp-includes/js/jquery/ui/menu$suffix.js", array( 'jquery-ui-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-mouse', "/wp-includes/js/jquery/ui/mouse$suffix.js", array( 'jquery-ui-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-progressbar', "/wp-includes/js/jquery/ui/progressbar$suffix.js", array( 'jquery-ui-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-selectmenu', "/wp-includes/js/jquery/ui/selectmenu$suffix.js", array( 'jquery-ui-menu' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-slider', "/wp-includes/js/jquery/ui/slider$suffix.js", array( 'jquery-ui-mouse' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-spinner', "/wp-includes/js/jquery/ui/spinner$suffix.js", array( 'jquery-ui-button' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-tabs', "/wp-includes/js/jquery/ui/tabs$suffix.js", array( 'jquery-ui-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-tooltip', "/wp-includes/js/jquery/ui/tooltip$suffix.js", array( 'jquery-ui-core' ), '1.13.2', 1 );
- // New in 1.12.1
- $scripts->add( 'jquery-ui-checkboxradio', "/wp-includes/js/jquery/ui/checkboxradio$suffix.js", array( 'jquery-ui-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-controlgroup', "/wp-includes/js/jquery/ui/controlgroup$suffix.js", array( 'jquery-ui-core' ), '1.13.2', 1 );
- // Interactions
- $scripts->add( 'jquery-ui-draggable', "/wp-includes/js/jquery/ui/draggable$suffix.js", array( 'jquery-ui-mouse' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-droppable', "/wp-includes/js/jquery/ui/droppable$suffix.js", array( 'jquery-ui-draggable' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-resizable', "/wp-includes/js/jquery/ui/resizable$suffix.js", array( 'jquery-ui-mouse' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-selectable', "/wp-includes/js/jquery/ui/selectable$suffix.js", array( 'jquery-ui-mouse' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-sortable', "/wp-includes/js/jquery/ui/sortable$suffix.js", array( 'jquery-ui-mouse' ), '1.13.2', 1 );
- // As of 1.12.1 `jquery-ui-position` and `jquery-ui-widget` are part of `jquery-ui-core`.
- // Listed here for back-compat.
- $scripts->add( 'jquery-ui-position', false, array( 'jquery-ui-core' ), '1.13.2', 1 );
- $scripts->add( 'jquery-ui-widget', false, array( 'jquery-ui-core' ), '1.13.2', 1 );
- // Strings for 'jquery-ui-autocomplete' live region messages.
- did_action( 'init' ) && $scripts->localize(
- 'jquery-ui-autocomplete',
- 'uiAutocompleteL10n',
- array(
- 'noResults' => __( 'No results found.' ),
- /* translators: Number of results found when using jQuery UI Autocomplete. */
- 'oneResult' => __( '1 result found. Use up and down arrow keys to navigate.' ),
- /* translators: %d: Number of results found when using jQuery UI Autocomplete. */
- 'manyResults' => __( '%d results found. Use up and down arrow keys to navigate.' ),
- 'itemSelected' => __( 'Item selected.' ),
- )
- );
- // Deprecated, not used in core, most functionality is included in jQuery 1.3.
- $scripts->add( 'jquery-form', "/wp-includes/js/jquery/jquery.form$suffix.js", array( 'jquery' ), '4.3.0', 1 );
- // jQuery plugins.
- $scripts->add( 'jquery-color', '/wp-includes/js/jquery/jquery.color.min.js', array( 'jquery' ), '2.2.0', 1 );
- $scripts->add( 'schedule', '/wp-includes/js/jquery/jquery.schedule.js', array( 'jquery' ), '20m', 1 );
- $scripts->add( 'jquery-query', '/wp-includes/js/jquery/jquery.query.js', array( 'jquery' ), '2.2.3', 1 );
- $scripts->add( 'jquery-serialize-object', '/wp-includes/js/jquery/jquery.serialize-object.js', array( 'jquery' ), '0.2-wp', 1 );
- $scripts->add( 'jquery-hotkeys', "/wp-includes/js/jquery/jquery.hotkeys$suffix.js", array( 'jquery' ), '0.0.2m', 1 );
- $scripts->add( 'jquery-table-hotkeys', "/wp-includes/js/jquery/jquery.table-hotkeys$suffix.js", array( 'jquery', 'jquery-hotkeys' ), false, 1 );
- $scripts->add( 'jquery-touch-punch', '/wp-includes/js/jquery/jquery.ui.touch-punch.js', array( 'jquery-ui-core', 'jquery-ui-mouse' ), '0.2.2', 1 );
- // Not used any more, registered for backward compatibility.
- $scripts->add( 'suggest', "/wp-includes/js/jquery/suggest$suffix.js", array( 'jquery' ), '1.1-20110113', 1 );
- // Masonry v2 depended on jQuery. v3 does not. The older jquery-masonry handle is a shiv.
- // It sets jQuery as a dependency, as the theme may have been implicitly loading it this way.
- $scripts->add( 'imagesloaded', '/wp-includes/js/imagesloaded.min.js', array(), '4.1.4', 1 );
- $scripts->add( 'masonry', '/wp-includes/js/masonry.min.js', array( 'imagesloaded' ), '4.2.2', 1 );
- $scripts->add( 'jquery-masonry', '/wp-includes/js/jquery/jquery.masonry.min.js', array( 'jquery', 'masonry' ), '3.1.2b', 1 );
- $scripts->add( 'thickbox', '/wp-includes/js/thickbox/thickbox.js', array( 'jquery' ), '3.1-20121105', 1 );
- did_action( 'init' ) && $scripts->localize(
- 'thickbox',
- 'thickboxL10n',
- array(
- 'next' => __( 'Next >' ),
- 'prev' => __( '< Prev' ),
- 'image' => __( 'Image' ),
- 'of' => __( 'of' ),
- 'close' => __( 'Close' ),
- 'noiframes' => __( 'This feature requires inline frames. You have iframes disabled or your browser does not support them.' ),
- 'loadingAnimation' => includes_url( 'js/thickbox/loadingAnimation.gif' ),
- )
- );
- // Not used in core, replaced by imgAreaSelect.
- $scripts->add( 'jcrop', '/wp-includes/js/jcrop/jquery.Jcrop.min.js', array( 'jquery' ), '0.9.15' );
- $scripts->add( 'swfobject', '/wp-includes/js/swfobject.js', array(), '2.2-20120417' );
- // Error messages for Plupload.
- $uploader_l10n = array(
- 'queue_limit_exceeded' => __( 'You have attempted to queue too many files.' ),
- /* translators: %s: File name. */
- 'file_exceeds_size_limit' => __( '%s exceeds the maximum upload size for this site.' ),
- 'zero_byte_file' => __( 'This file is empty. Please try another.' ),
- 'invalid_filetype' => __( 'Sorry, you are not allowed to upload this file type.' ),
- 'not_an_image' => __( 'This file is not an image. Please try another.' ),
- 'image_memory_exceeded' => __( 'Memory exceeded. Please try another smaller file.' ),
- 'image_dimensions_exceeded' => __( 'This is larger than the maximum size. Please try another.' ),
- 'default_error' => __( 'An error occurred in the upload. Please try again later.' ),
- 'missing_upload_url' => __( 'There was a configuration error. Please contact the server administrator.' ),
- 'upload_limit_exceeded' => __( 'You may only upload 1 file.' ),
- 'http_error' => __( 'Unexpected response from the server. The file may have been uploaded successfully. Check in the Media Library or reload the page.' ),
- 'http_error_image' => __( 'The server cannot process the image. This can happen if the server is busy or does not have enough resources to complete the task. Uploading a smaller image may help. Suggested maximum size is 2560 pixels.' ),
- 'upload_failed' => __( 'Upload failed.' ),
- /* translators: 1: Opening link tag, 2: Closing link tag. */
- 'big_upload_failed' => __( 'Please try uploading this file with the %1$sbrowser uploader%2$s.' ),
- /* translators: %s: File name. */
- 'big_upload_queued' => __( '%s exceeds the maximum upload size for the multi-file uploader when used in your browser.' ),
- 'io_error' => __( 'IO error.' ),
- 'security_error' => __( 'Security error.' ),
- 'file_cancelled' => __( 'File canceled.' ),
- 'upload_stopped' => __( 'Upload stopped.' ),
- 'dismiss' => __( 'Dismiss' ),
- 'crunching' => __( 'Crunching…' ),
- 'deleted' => __( 'moved to the Trash.' ),
- /* translators: %s: File name. */
- 'error_uploading' => __( '“%s” has failed to upload.' ),
- 'unsupported_image' => __( 'This image cannot be displayed in a web browser. For best results convert it to JPEG before uploading.' ),
- 'noneditable_image' => __( 'This image cannot be processed by the web server. Convert it to JPEG or PNG before uploading.' ),
- 'file_url_copied' => __( 'The file URL has been copied to your clipboard' ),
- );
- $scripts->add( 'moxiejs', "/wp-includes/js/plupload/moxie$suffix.js", array(), '1.3.5' );
- $scripts->add( 'plupload', "/wp-includes/js/plupload/plupload$suffix.js", array( 'moxiejs' ), '2.1.9' );
- // Back compat handles:
- foreach ( array( 'all', 'html5', 'flash', 'silverlight', 'html4' ) as $handle ) {
- $scripts->add( "plupload-$handle", false, array( 'plupload' ), '2.1.1' );
- }
- $scripts->add( 'plupload-handlers', "/wp-includes/js/plupload/handlers$suffix.js", array( 'clipboard', 'jquery', 'plupload', 'underscore', 'wp-a11y', 'wp-i18n' ) );
- did_action( 'init' ) && $scripts->localize( 'plupload-handlers', 'pluploadL10n', $uploader_l10n );
- $scripts->add( 'wp-plupload', "/wp-includes/js/plupload/wp-plupload$suffix.js", array( 'plupload', 'jquery', 'json2', 'media-models' ), false, 1 );
- did_action( 'init' ) && $scripts->localize( 'wp-plupload', 'pluploadL10n', $uploader_l10n );
- // Keep 'swfupload' for back-compat.
- $scripts->add( 'swfupload', '/wp-includes/js/swfupload/swfupload.js', array(), '2201-20110113' );
- $scripts->add( 'swfupload-all', false, array( 'swfupload' ), '2201' );
- $scripts->add( 'swfupload-handlers', "/wp-includes/js/swfupload/handlers$suffix.js", array( 'swfupload-all', 'jquery' ), '2201-20110524' );
- did_action( 'init' ) && $scripts->localize( 'swfupload-handlers', 'swfuploadL10n', $uploader_l10n );
- $scripts->add( 'comment-reply', "/wp-includes/js/comment-reply$suffix.js", array(), false, 1 );
- $scripts->add( 'json2', "/wp-includes/js/json2$suffix.js", array(), '2015-05-03' );
- did_action( 'init' ) && $scripts->add_data( 'json2', 'conditional', 'lt IE 8' );
- $scripts->add( 'underscore', "/wp-includes/js/underscore$dev_suffix.js", array(), '1.13.4', 1 );
- $scripts->add( 'backbone', "/wp-includes/js/backbone$dev_suffix.js", array( 'underscore', 'jquery' ), '1.4.1', 1 );
- $scripts->add( 'wp-util', "/wp-includes/js/wp-util$suffix.js", array( 'underscore', 'jquery' ), false, 1 );
- did_action( 'init' ) && $scripts->localize(
- 'wp-util',
- '_wpUtilSettings',
- array(
- 'ajax' => array(
- 'url' => admin_url( 'admin-ajax.php', 'relative' ),
- ),
- )
- );
- $scripts->add( 'wp-backbone', "/wp-includes/js/wp-backbone$suffix.js", array( 'backbone', 'wp-util' ), false, 1 );
- $scripts->add( 'revisions', "/wp-admin/js/revisions$suffix.js", array( 'wp-backbone', 'jquery-ui-slider', 'hoverIntent' ), false, 1 );
- $scripts->add( 'imgareaselect', "/wp-includes/js/imgareaselect/jquery.imgareaselect$suffix.js", array( 'jquery' ), false, 1 );
- $scripts->add( 'mediaelement', false, array( 'jquery', 'mediaelement-core', 'mediaelement-migrate' ), '4.2.17', 1 );
- $scripts->add( 'mediaelement-core', "/wp-includes/js/mediaelement/mediaelement-and-player$suffix.js", array(), '4.2.17', 1 );
- $scripts->add( 'mediaelement-migrate', "/wp-includes/js/mediaelement/mediaelement-migrate$suffix.js", array(), false, 1 );
- did_action( 'init' ) && $scripts->add_inline_script(
- 'mediaelement-core',
- sprintf(
- 'var mejsL10n = %s;',
- wp_json_encode(
- array(
- 'language' => strtolower( strtok( determine_locale(), '_-' ) ),
- 'strings' => array(
- 'mejs.download-file' => __( 'Download File' ),
- 'mejs.install-flash' => __( 'You are using a browser that does not have Flash player enabled or installed. Please turn on your Flash player plugin or download the latest version from https://get.adobe.com/flashplayer/' ),
- 'mejs.fullscreen' => __( 'Fullscreen' ),
- 'mejs.play' => __( 'Play' ),
- 'mejs.pause' => __( 'Pause' ),
- 'mejs.time-slider' => __( 'Time Slider' ),
- 'mejs.time-help-text' => __( 'Use Left/Right Arrow keys to advance one second, Up/Down arrows to advance ten seconds.' ),
- 'mejs.live-broadcast' => __( 'Live Broadcast' ),
- 'mejs.volume-help-text' => __( 'Use Up/Down Arrow keys to increase or decrease volume.' ),
- 'mejs.unmute' => __( 'Unmute' ),
- 'mejs.mute' => __( 'Mute' ),
- 'mejs.volume-slider' => __( 'Volume Slider' ),
- 'mejs.video-player' => __( 'Video Player' ),
- 'mejs.audio-player' => __( 'Audio Player' ),
- 'mejs.captions-subtitles' => __( 'Captions/Subtitles' ),
- 'mejs.captions-chapters' => __( 'Chapters' ),
- 'mejs.none' => __( 'None' ),
- 'mejs.afrikaans' => __( 'Afrikaans' ),
- 'mejs.albanian' => __( 'Albanian' ),
- 'mejs.arabic' => __( 'Arabic' ),
- 'mejs.belarusian' => __( 'Belarusian' ),
- 'mejs.bulgarian' => __( 'Bulgarian' ),
- 'mejs.catalan' => __( 'Catalan' ),
- 'mejs.chinese' => __( 'Chinese' ),
- 'mejs.chinese-simplified' => __( 'Chinese (Simplified)' ),
- 'mejs.chinese-traditional' => __( 'Chinese (Traditional)' ),
- 'mejs.croatian' => __( 'Croatian' ),
- 'mejs.czech' => __( 'Czech' ),
- 'mejs.danish' => __( 'Danish' ),
- 'mejs.dutch' => __( 'Dutch' ),
- 'mejs.english' => __( 'English' ),
- 'mejs.estonian' => __( 'Estonian' ),
- 'mejs.filipino' => __( 'Filipino' ),
- 'mejs.finnish' => __( 'Finnish' ),
- 'mejs.french' => __( 'French' ),
- 'mejs.galician' => __( 'Galician' ),
- 'mejs.german' => __( 'German' ),
- 'mejs.greek' => __( 'Greek' ),
- 'mejs.haitian-creole' => __( 'Haitian Creole' ),
- 'mejs.hebrew' => __( 'Hebrew' ),
- 'mejs.hindi' => __( 'Hindi' ),
- 'mejs.hungarian' => __( 'Hungarian' ),
- 'mejs.icelandic' => __( 'Icelandic' ),
- 'mejs.indonesian' => __( 'Indonesian' ),
- 'mejs.irish' => __( 'Irish' ),
- 'mejs.italian' => __( 'Italian' ),
- 'mejs.japanese' => __( 'Japanese' ),
- 'mejs.korean' => __( 'Korean' ),
- 'mejs.latvian' => __( 'Latvian' ),
- 'mejs.lithuanian' => __( 'Lithuanian' ),
- 'mejs.macedonian' => __( 'Macedonian' ),
- 'mejs.malay' => __( 'Malay' ),
- 'mejs.maltese' => __( 'Maltese' ),
- 'mejs.norwegian' => __( 'Norwegian' ),
- 'mejs.persian' => __( 'Persian' ),
- 'mejs.polish' => __( 'Polish' ),
- 'mejs.portuguese' => __( 'Portuguese' ),
- 'mejs.romanian' => __( 'Romanian' ),
- 'mejs.russian' => __( 'Russian' ),
- 'mejs.serbian' => __( 'Serbian' ),
- 'mejs.slovak' => __( 'Slovak' ),
- 'mejs.slovenian' => __( 'Slovenian' ),
- 'mejs.spanish' => __( 'Spanish' ),
- 'mejs.swahili' => __( 'Swahili' ),
- 'mejs.swedish' => __( 'Swedish' ),
- 'mejs.tagalog' => __( 'Tagalog' ),
- 'mejs.thai' => __( 'Thai' ),
- 'mejs.turkish' => __( 'Turkish' ),
- 'mejs.ukrainian' => __( 'Ukrainian' ),
- 'mejs.vietnamese' => __( 'Vietnamese' ),
- 'mejs.welsh' => __( 'Welsh' ),
- 'mejs.yiddish' => __( 'Yiddish' ),
- ),
- )
- )
- ),
- 'before'
- );
- $scripts->add( 'mediaelement-vimeo', '/wp-includes/js/mediaelement/renderers/vimeo.min.js', array( 'mediaelement' ), '4.2.17', 1 );
- $scripts->add( 'wp-mediaelement', "/wp-includes/js/mediaelement/wp-mediaelement$suffix.js", array( 'mediaelement' ), false, 1 );
- $mejs_settings = array(
- 'pluginPath' => includes_url( 'js/mediaelement/', 'relative' ),
- 'classPrefix' => 'mejs-',
- 'stretching' => 'responsive',
- );
- did_action( 'init' ) && $scripts->localize(
- 'mediaelement',
- '_wpmejsSettings',
- /**
- * Filters the MediaElement configuration settings.
- *
- * @since 4.4.0
- *
- * @param array $mejs_settings MediaElement settings array.
- */
- apply_filters( 'mejs_settings', $mejs_settings )
- );
- $scripts->add( 'wp-codemirror', '/wp-includes/js/codemirror/codemirror.min.js', array(), '5.29.1-alpha-ee20357' );
- $scripts->add( 'csslint', '/wp-includes/js/codemirror/csslint.js', array(), '1.0.5' );
- $scripts->add( 'esprima', '/wp-includes/js/codemirror/esprima.js', array(), '4.0.0' );
- $scripts->add( 'jshint', '/wp-includes/js/codemirror/fakejshint.js', array( 'esprima' ), '2.9.5' );
- $scripts->add( 'jsonlint', '/wp-includes/js/codemirror/jsonlint.js', array(), '1.6.2' );
- $scripts->add( 'htmlhint', '/wp-includes/js/codemirror/htmlhint.js', array(), '0.9.14-xwp' );
- $scripts->add( 'htmlhint-kses', '/wp-includes/js/codemirror/htmlhint-kses.js', array( 'htmlhint' ) );
- $scripts->add( 'code-editor', "/wp-admin/js/code-editor$suffix.js", array( 'jquery', 'wp-codemirror', 'underscore' ) );
- $scripts->add( 'wp-theme-plugin-editor', "/wp-admin/js/theme-plugin-editor$suffix.js", array( 'common', 'wp-util', 'wp-sanitize', 'jquery', 'jquery-ui-core', 'wp-a11y', 'underscore' ) );
- $scripts->set_translations( 'wp-theme-plugin-editor' );
- $scripts->add( 'wp-playlist', "/wp-includes/js/mediaelement/wp-playlist$suffix.js", array( 'wp-util', 'backbone', 'mediaelement' ), false, 1 );
- $scripts->add( 'zxcvbn-async', "/wp-includes/js/zxcvbn-async$suffix.js", array(), '1.0' );
- did_action( 'init' ) && $scripts->localize(
- 'zxcvbn-async',
- '_zxcvbnSettings',
- array(
- 'src' => empty( $guessed_url ) ? includes_url( '/js/zxcvbn.min.js' ) : $scripts->base_url . '/wp-includes/js/zxcvbn.min.js',
- )
- );
- $scripts->add( 'password-strength-meter', "/wp-admin/js/password-strength-meter$suffix.js", array( 'jquery', 'zxcvbn-async' ), false, 1 );
- did_action( 'init' ) && $scripts->localize(
- 'password-strength-meter',
- 'pwsL10n',
- array(
- 'unknown' => _x( 'Password strength unknown', 'password strength' ),
- 'short' => _x( 'Very weak', 'password strength' ),
- 'bad' => _x( 'Weak', 'password strength' ),
- 'good' => _x( 'Medium', 'password strength' ),
- 'strong' => _x( 'Strong', 'password strength' ),
- 'mismatch' => _x( 'Mismatch', 'password mismatch' ),
- )
- );
- $scripts->set_translations( 'password-strength-meter' );
- $scripts->add( 'application-passwords', "/wp-admin/js/application-passwords$suffix.js", array( 'jquery', 'wp-util', 'wp-api-request', 'wp-date', 'wp-i18n', 'wp-hooks' ), false, 1 );
- $scripts->set_translations( 'application-passwords' );
- $scripts->add( 'auth-app', "/wp-admin/js/auth-app$suffix.js", array( 'jquery', 'wp-api-request', 'wp-i18n', 'wp-hooks' ), false, 1 );
- $scripts->set_translations( 'auth-app' );
- $scripts->add( 'user-profile', "/wp-admin/js/user-profile$suffix.js", array( 'jquery', 'password-strength-meter', 'wp-util' ), false, 1 );
- $scripts->set_translations( 'user-profile' );
- $user_id = isset( $_GET['user_id'] ) ? (int) $_GET['user_id'] : 0;
- did_action( 'init' ) && $scripts->localize(
- 'user-profile',
- 'userProfileL10n',
- array(
- 'user_id' => $user_id,
- 'nonce' => wp_installing() ? '' : wp_create_nonce( 'reset-password-for-' . $user_id ),
- )
- );
- $scripts->add( 'language-chooser', "/wp-admin/js/language-chooser$suffix.js", array( 'jquery' ), false, 1 );
- $scripts->add( 'user-suggest', "/wp-admin/js/user-suggest$suffix.js", array( 'jquery-ui-autocomplete' ), false, 1 );
- $scripts->add( 'admin-bar', "/wp-includes/js/admin-bar$suffix.js", array( 'hoverintent-js' ), false, 1 );
- $scripts->add( 'wplink', "/wp-includes/js/wplink$suffix.js", array( 'jquery', 'wp-a11y' ), false, 1 );
- did_action( 'init' ) && $scripts->localize(
- 'wplink',
- 'wpLinkL10n',
- array(
- 'title' => __( 'Insert/edit link' ),
- 'update' => __( 'Update' ),
- 'save' => __( 'Add Link' ),
- 'noTitle' => __( '(no title)' ),
- 'noMatchesFound' => __( 'No results found.' ),
- 'linkSelected' => __( 'Link selected.' ),
- 'linkInserted' => __( 'Link inserted.' ),
- /* translators: Minimum input length in characters to start searching posts in the "Insert/edit link" modal. */
- 'minInputLength' => (int) _x( '3', 'minimum input length for searching post links' ),
- )
- );
- $scripts->add( 'wpdialogs', "/wp-includes/js/wpdialog$suffix.js", array( 'jquery-ui-dialog' ), false, 1 );
- $scripts->add( 'word-count', "/wp-admin/js/word-count$suffix.js", array(), false, 1 );
- $scripts->add( 'media-upload', "/wp-admin/js/media-upload$suffix.js", array( 'thickbox', 'shortcode' ), false, 1 );
- $scripts->add( 'hoverIntent', "/wp-includes/js/hoverIntent$suffix.js", array( 'jquery' ), '1.10.2', 1 );
- // JS-only version of hoverintent (no dependencies).
- $scripts->add( 'hoverintent-js', '/wp-includes/js/hoverintent-js.min.js', array(), '2.2.1', 1 );
- $scripts->add( 'customize-base', "/wp-includes/js/customize-base$suffix.js", array( 'jquery', 'json2', 'underscore' ), false, 1 );
- $scripts->add( 'customize-loader', "/wp-includes/js/customize-loader$suffix.js", array( 'customize-base' ), false, 1 );
- $scripts->add( 'customize-preview', "/wp-includes/js/customize-preview$suffix.js", array( 'wp-a11y', 'customize-base' ), false, 1 );
- $scripts->add( 'customize-models', '/wp-includes/js/customize-models.js', array( 'underscore', 'backbone' ), false, 1 );
- $scripts->add( 'customize-views', '/wp-includes/js/customize-views.js', array( 'jquery', 'underscore', 'imgareaselect', 'customize-models', 'media-editor', 'media-views' ), false, 1 );
- $scripts->add( 'customize-controls', "/wp-admin/js/customize-controls$suffix.js", array( 'customize-base', 'wp-a11y', 'wp-util', 'jquery-ui-core' ), false, 1 );
- did_action( 'init' ) && $scripts->localize(
- 'customize-controls',
- '_wpCustomizeControlsL10n',
- array(
- 'activate' => __( 'Activate & Publish' ),
- 'save' => __( 'Save & Publish' ), // @todo Remove as not required.
- 'publish' => __( 'Publish' ),
- 'published' => __( 'Published' ),
- 'saveDraft' => __( 'Save Draft' ),
- 'draftSaved' => __( 'Draft Saved' ),
- 'updating' => __( 'Updating' ),
- 'schedule' => _x( 'Schedule', 'customizer changeset action/button label' ),
- 'scheduled' => _x( 'Scheduled', 'customizer changeset status' ),
- 'invalid' => __( 'Invalid' ),
- 'saveBeforeShare' => __( 'Please save your changes in order to share the preview.' ),
- 'futureDateError' => __( 'You must supply a future date to schedule.' ),
- 'saveAlert' => __( 'The changes you made will be lost if you navigate away from this page.' ),
- 'saved' => __( 'Saved' ),
- 'cancel' => __( 'Cancel' ),
- 'close' => __( 'Close' ),
- 'action' => __( 'Action' ),
- 'discardChanges' => __( 'Discard changes' ),
- 'cheatin' => __( 'Something went wrong.' ),
- 'notAllowedHeading' => __( 'You need a higher level of permission.' ),
- 'notAllowed' => __( 'Sorry, you are not allowed to customize this site.' ),
- 'previewIframeTitle' => __( 'Site Preview' ),
- 'loginIframeTitle' => __( 'Session expired' ),
- 'collapseSidebar' => _x( 'Hide Controls', 'label for hide controls button without length constraints' ),
- 'expandSidebar' => _x( 'Show Controls', 'label for hide controls button without length constraints' ),
- 'untitledBlogName' => __( '(Untitled)' ),
- 'unknownRequestFail' => __( 'Looks like something’s gone wrong. Wait a couple seconds, and then try again.' ),
- 'themeDownloading' => __( 'Downloading your new theme…' ),
- 'themePreviewWait' => __( 'Setting up your live preview. This may take a bit.' ),
- 'revertingChanges' => __( 'Reverting unpublished changes…' ),
- 'trashConfirm' => __( 'Are you sure you want to discard your unpublished changes?' ),
- /* translators: %s: Display name of the user who has taken over the changeset in customizer. */
- 'takenOverMessage' => __( '%s has taken over and is currently customizing.' ),
- /* translators: %s: URL to the Customizer to load the autosaved version. */
- 'autosaveNotice' => __( 'There is a more recent autosave of your changes than the one you are previewing. <a href="%s">Restore the autosave</a>' ),
- 'videoHeaderNotice' => __( 'This theme does not support video headers on this page. Navigate to the front page or another page that supports video headers.' ),
- // Used for overriding the file types allowed in Plupload.
- 'allowedFiles' => __( 'Allowed Files' ),
- 'customCssError' => array(
- /* translators: %d: Error count. */
- 'singular' => _n( 'There is %d error which must be fixed before you can save.', 'There are %d errors which must be fixed before you can save.', 1 ),
- /* translators: %d: Error count. */
- 'plural' => _n( 'There is %d error which must be fixed before you can save.', 'There are %d errors which must be fixed before you can save.', 2 ),
- // @todo This is lacking, as some languages have a dedicated dual form. For proper handling of plurals in JS, see #20491.
- ),
- 'pageOnFrontError' => __( 'Homepage and posts page must be different.' ),
- 'saveBlockedError' => array(
- /* translators: %s: Number of invalid settings. */
- 'singular' => _n( 'Unable to save due to %s invalid setting.', 'Unable to save due to %s invalid settings.', 1 ),
- /* translators: %s: Number of invalid settings. */
- 'plural' => _n( 'Unable to save due to %s invalid setting.', 'Unable to save due to %s invalid settings.', 2 ),
- // @todo This is lacking, as some languages have a dedicated dual form. For proper handling of plurals in JS, see #20491.
- ),
- 'scheduleDescription' => __( 'Schedule your customization changes to publish ("go live") at a future date.' ),
- 'themePreviewUnavailable' => __( 'Sorry, you cannot preview new themes when you have changes scheduled or saved as a draft. Please publish your changes, or wait until they publish to preview new themes.' ),
- 'themeInstallUnavailable' => sprintf(
- /* translators: %s: URL to Add Themes admin screen. */
- __( 'You will not be able to install new themes from here yet since your install requires SFTP credentials. For now, please <a href="%s">add themes in the admin</a>.' ),
- esc_url( admin_url( 'theme-install.php' ) )
- ),
- 'publishSettings' => __( 'Publish Settings' ),
- 'invalidDate' => __( 'Invalid date.' ),
- 'invalidValue' => __( 'Invalid value.' ),
- 'blockThemeNotification' => sprintf(
- /* translators: 1: Link to Site Editor documentation on HelpHub, 2: HTML button. */
- __( 'Hurray! Your theme supports site editing with blocks. <a href="%1$s">Tell me more</a>. %2$s' ),
- __( 'https://wordpress.org/support/article/site-editor/' ),
- sprintf(
- '<button type="button" data-action="%1$s" class="button switch-to-editor">%2$s</button>',
- esc_url( admin_url( 'site-editor.php' ) ),
- __( 'Use Site Editor' )
- )
- ),
- )
- );
- $scripts->add( 'customize-selective-refresh', "/wp-includes/js/customize-selective-refresh$suffix.js", array( 'jquery', 'wp-util', 'customize-preview' ), false, 1 );
- $scripts->add( 'customize-widgets', "/wp-admin/js/customize-widgets$suffix.js", array( 'jquery', 'jquery-ui-sortable', 'jquery-ui-droppable', 'wp-backbone', 'customize-controls' ), false, 1 );
- $scripts->add( 'customize-preview-widgets', "/wp-includes/js/customize-preview-widgets$suffix.js", array( 'jquery', 'wp-util', 'customize-preview', 'customize-selective-refresh' ), false, 1 );
- $scripts->add( 'customize-nav-menus', "/wp-admin/js/customize-nav-menus$suffix.js", array( 'jquery', 'wp-backbone', 'customize-controls', 'accordion', 'nav-menu', 'wp-sanitize' ), false, 1 );
- $scripts->add( 'customize-preview-nav-menus', "/wp-includes/js/customize-preview-nav-menus$suffix.js", array( 'jquery', 'wp-util', 'customize-preview', 'customize-selective-refresh' ), false, 1 );
- $scripts->add( 'wp-custom-header', "/wp-includes/js/wp-custom-header$suffix.js", array( 'wp-a11y' ), false, 1 );
- $scripts->add( 'accordion', "/wp-admin/js/accordion$suffix.js", array( 'jquery' ), false, 1 );
- $scripts->add( 'shortcode', "/wp-includes/js/shortcode$suffix.js", array( 'underscore' ), false, 1 );
- $scripts->add( 'media-models', "/wp-includes/js/media-models$suffix.js", array( 'wp-backbone' ), false, 1 );
- did_action( 'init' ) && $scripts->localize(
- 'media-models',
- '_wpMediaModelsL10n',
- array(
- 'settings' => array(
- 'ajaxurl' => admin_url( 'admin-ajax.php', 'relative' ),
- 'post' => array( 'id' => 0 ),
- ),
- )
- );
- $scripts->add( 'wp-embed', "/wp-includes/js/wp-embed$suffix.js", array(), false, 1 );
- // To enqueue media-views or media-editor, call wp_enqueue_media().
- // Both rely on numerous settings, styles, and templates to operate correctly.
- $scripts->add( 'media-views', "/wp-includes/js/media-views$suffix.js", array( 'utils', 'media-models', 'wp-plupload', 'jquery-ui-sortable', 'wp-mediaelement', 'wp-api-request', 'wp-a11y', 'clipboard' ), false, 1 );
- $scripts->set_translations( 'media-views' );
- $scripts->add( 'media-editor', "/wp-includes/js/media-editor$suffix.js", array( 'shortcode', 'media-views' ), false, 1 );
- $scripts->set_translations( 'media-editor' );
- $scripts->add( 'media-audiovideo', "/wp-includes/js/media-audiovideo$suffix.js", array( 'media-editor' ), false, 1 );
- $scripts->add( 'mce-view', "/wp-includes/js/mce-view$suffix.js", array( 'shortcode', 'jquery', 'media-views', 'media-audiovideo' ), false, 1 );
- $scripts->add( 'wp-api', "/wp-includes/js/wp-api$suffix.js", array( 'jquery', 'backbone', 'underscore', 'wp-api-request' ), false, 1 );
- if ( is_admin() ) {
- $scripts->add( 'admin-tags', "/wp-admin/js/tags$suffix.js", array( 'jquery', 'wp-ajax-response' ), false, 1 );
- $scripts->set_translations( 'admin-tags' );
- $scripts->add( 'admin-comments', "/wp-admin/js/edit-comments$suffix.js", array( 'wp-lists', 'quicktags', 'jquery-query' ), false, 1 );
- $scripts->set_translations( 'admin-comments' );
- did_action( 'init' ) && $scripts->localize(
- 'admin-comments',
- 'adminCommentsSettings',
- array(
- 'hotkeys_highlight_first' => isset( $_GET['hotkeys_highlight_first'] ),
- 'hotkeys_highlight_last' => isset( $_GET['hotkeys_highlight_last'] ),
- )
- );
- $scripts->add( 'xfn', "/wp-admin/js/xfn$suffix.js", array( 'jquery' ), false, 1 );
- $scripts->add( 'postbox', "/wp-admin/js/postbox$suffix.js", array( 'jquery-ui-sortable', 'wp-a11y' ), false, 1 );
- $scripts->set_translations( 'postbox' );
- $scripts->add( 'tags-box', "/wp-admin/js/tags-box$suffix.js", array( 'jquery', 'tags-suggest' ), false, 1 );
- $scripts->set_translations( 'tags-box' );
- $scripts->add( 'tags-suggest', "/wp-admin/js/tags-suggest$suffix.js", array( 'jquery-ui-autocomplete', 'wp-a11y' ), false, 1 );
- $scripts->set_translations( 'tags-suggest' );
- $scripts->add( 'post', "/wp-admin/js/post$suffix.js", array( 'suggest', 'wp-lists', 'postbox', 'tags-box', 'underscore', 'word-count', 'wp-a11y', 'wp-sanitize', 'clipboard' ), false, 1 );
- $scripts->set_translations( 'post' );
- $scripts->add( 'editor-expand', "/wp-admin/js/editor-expand$suffix.js", array( 'jquery', 'underscore' ), false, 1 );
- $scripts->add( 'link', "/wp-admin/js/link$suffix.js", array( 'wp-lists', 'postbox' ), false, 1 );
- $scripts->add( 'comment', "/wp-admin/js/comment$suffix.js", array( 'jquery', 'postbox' ), false, 1 );
- $scripts->set_translations( 'comment' );
- $scripts->add( 'admin-gallery', "/wp-admin/js/gallery$suffix.js", array( 'jquery-ui-sortable' ) );
- $scripts->add( 'admin-widgets', "/wp-admin/js/widgets$suffix.js", array( 'jquery-ui-sortable', 'jquery-ui-draggable', 'jquery-ui-droppable', 'wp-a11y' ), false, 1 );
- $scripts->set_translations( 'admin-widgets' );
- $scripts->add( 'media-widgets', "/wp-admin/js/widgets/media-widgets$suffix.js", array( 'jquery', 'media-models', 'media-views', 'wp-api-request' ) );
- $scripts->add_inline_script( 'media-widgets', 'wp.mediaWidgets.init();', 'after' );
- $scripts->add( 'media-audio-widget', "/wp-admin/js/widgets/media-audio-widget$suffix.js", array( 'media-widgets', 'media-audiovideo' ) );
- $scripts->add( 'media-image-widget', "/wp-admin/js/widgets/media-image-widget$suffix.js", array( 'media-widgets' ) );
- $scripts->add( 'media-gallery-widget', "/wp-admin/js/widgets/media-gallery-widget$suffix.js", array( 'media-widgets' ) );
- $scripts->add( 'media-video-widget', "/wp-admin/js/widgets/media-video-widget$suffix.js", array( 'media-widgets', 'media-audiovideo', 'wp-api-request' ) );
- $scripts->add( 'text-widgets', "/wp-admin/js/widgets/text-widgets$suffix.js", array( 'jquery', 'backbone', 'editor', 'wp-util', 'wp-a11y' ) );
- $scripts->add( 'custom-html-widgets', "/wp-admin/js/widgets/custom-html-widgets$suffix.js", array( 'jquery', 'backbone', 'wp-util', 'jquery-ui-core', 'wp-a11y' ) );
- $scripts->add( 'theme', "/wp-admin/js/theme$suffix.js", array( 'wp-backbone', 'wp-a11y', 'customize-base' ), false, 1 );
- $scripts->add( 'inline-edit-post', "/wp-admin/js/inline-edit-post$suffix.js", array( 'jquery', 'tags-suggest', 'wp-a11y' ), false, 1 );
- $scripts->set_translations( 'inline-edit-post' );
- $scripts->add( 'inline-edit-tax', "/wp-admin/js/inline-edit-tax$suffix.js", array( 'jquery', 'wp-a11y' ), false, 1 );
- $scripts->set_translations( 'inline-edit-tax' );
- $scripts->add( 'plugin-install', "/wp-admin/js/plugin-install$suffix.js", array( 'jquery', 'jquery-ui-core', 'thickbox' ), false, 1 );
- $scripts->set_translations( 'plugin-install' );
- $scripts->add( 'site-health', "/wp-admin/js/site-health$suffix.js", array( 'clipboard', 'jquery', 'wp-util', 'wp-a11y', 'wp-api-request', 'wp-url', 'wp-i18n', 'wp-hooks' ), false, 1 );
- $scripts->set_translations( 'site-health' );
- $scripts->add( 'privacy-tools', "/wp-admin/js/privacy-tools$suffix.js", array( 'jquery', 'wp-a11y' ), false, 1 );
- $scripts->set_translations( 'privacy-tools' );
- $scripts->add( 'updates', "/wp-admin/js/updates$suffix.js", array( 'common', 'jquery', 'wp-util', 'wp-a11y', 'wp-sanitize', 'wp-i18n' ), false, 1 );
- $scripts->set_translations( 'updates' );
- did_action( 'init' ) && $scripts->localize(
- 'updates',
- '_wpUpdatesSettings',
- array(
- 'ajax_nonce' => wp_installing() ? '' : wp_create_nonce( 'updates' ),
- )
- );
- $scripts->add( 'farbtastic', '/wp-admin/js/farbtastic.js', array( 'jquery' ), '1.2' );
- $scripts->add( 'iris', '/wp-admin/js/iris.min.js', array( 'jquery-ui-draggable', 'jquery-ui-slider', 'jquery-touch-punch' ), '1.1.1', 1 );
- $scripts->add( 'wp-color-picker', "/wp-admin/js/color-picker$suffix.js", array( 'iris' ), false, 1 );
- $scripts->set_translations( 'wp-color-picker' );
- $scripts->add( 'dashboard', "/wp-admin/js/dashboard$suffix.js", array( 'jquery', 'admin-comments', 'postbox', 'wp-util', 'wp-a11y', 'wp-date' ), false, 1 );
- $scripts->set_translations( 'dashboard' );
- $scripts->add( 'list-revisions', "/wp-includes/js/wp-list-revisions$suffix.js" );
- $scripts->add( 'media-grid', "/wp-includes/js/media-grid$suffix.js", array( 'media-editor' ), false, 1 );
- $scripts->add( 'media', "/wp-admin/js/media$suffix.js", array( 'jquery', 'clipboard', 'wp-i18n', 'wp-a11y' ), false, 1 );
- $scripts->set_translations( 'media' );
- $scripts->add( 'image-edit', "/wp-admin/js/image-edit$suffix.js", array( 'jquery', 'jquery-ui-core', 'json2', 'imgareaselect', 'wp-a11y' ), false, 1 );
- $scripts->set_translations( 'image-edit' );
- $scripts->add( 'set-post-thumbnail', "/wp-admin/js/set-post-thumbnail$suffix.js", array( 'jquery' ), false, 1 );
- $scripts->set_translations( 'set-post-thumbnail' );
- /*
- * Navigation Menus: Adding underscore as a dependency to utilize _.debounce
- * see https://core.trac.wordpress.org/ticket/42321
- */
- $scripts->add( 'nav-menu', "/wp-admin/js/nav-menu$suffix.js", array( 'jquery-ui-sortable', 'jquery-ui-draggable', 'jquery-ui-droppable', 'wp-lists', 'postbox', 'json2', 'underscore' ) );
- $scripts->set_translations( 'nav-menu' );
- $scripts->add( 'custom-header', '/wp-admin/js/custom-header.js', array( 'jquery-masonry' ), false, 1 );
- $scripts->add( 'custom-background', "/wp-admin/js/custom-background$suffix.js", array( 'wp-color-picker', 'media-views' ), false, 1 );
- $scripts->add( 'media-gallery', "/wp-admin/js/media-gallery$suffix.js", array( 'jquery' ), false, 1 );
- $scripts->add( 'svg-painter', '/wp-admin/js/svg-painter.js', array( 'jquery' ), false, 1 );
- }
- }
- /**
- * Assigns default styles to $styles object.
- *
- * Nothing is returned, because the $styles parameter is passed by reference.
- * Meaning that whatever object is passed will be updated without having to
- * reassign the variable that was passed back to the same value. This saves
- * memory.
- *
- * Adding default styles is not the only task, it also assigns the base_url
- * property, the default version, and text direction for the object.
- *
- * @since 2.6.0
- *
- * @global array $editor_styles
- *
- * @param WP_Styles $styles
- */
- function wp_default_styles( $styles ) {
- global $editor_styles;
- // Include an unmodified $wp_version.
- require ABSPATH . WPINC . '/version.php';
- if ( ! defined( 'SCRIPT_DEBUG' ) ) {
- define( 'SCRIPT_DEBUG', false !== strpos( $wp_version, '-src' ) );
- }
- $guessurl = site_url();
- if ( ! $guessurl ) {
- $guessurl = wp_guess_url();
- }
- $styles->base_url = $guessurl;
- $styles->content_url = defined( 'WP_CONTENT_URL' ) ? WP_CONTENT_URL : '';
- $styles->default_version = get_bloginfo( 'version' );
- $styles->text_direction = function_exists( 'is_rtl' ) && is_rtl() ? 'rtl' : 'ltr';
- $styles->default_dirs = array( '/wp-admin/', '/wp-includes/css/' );
- // Open Sans is no longer used by core, but may be relied upon by themes and plugins.
- $open_sans_font_url = '';
- /*
- * translators: If there are characters in your language that are not supported
- * by Open Sans, translate this to 'off'. Do not translate into your own language.
- */
- if ( 'off' !== _x( 'on', 'Open Sans font: on or off' ) ) {
- $subsets = 'latin,latin-ext';
- /*
- * translators: To add an additional Open Sans character subset specific to your language,
- * translate this to 'greek', 'cyrillic' or 'vietnamese'. Do not translate into your own language.
- */
- $subset = _x( 'no-subset', 'Open Sans font: add new subset (greek, cyrillic, vietnamese)' );
- if ( 'cyrillic' === $subset ) {
- $subsets .= ',cyrillic,cyrillic-ext';
- } elseif ( 'greek' === $subset ) {
- $subsets .= ',greek,greek-ext';
- } elseif ( 'vietnamese' === $subset ) {
- $subsets .= ',vietnamese';
- }
- // Hotlink Open Sans, for now.
- $open_sans_font_url = "https://fonts.googleapis.com/css?family=Open+Sans:300italic,400italic,600italic,300,400,600&subset=$subsets&display=fallback";
- }
- // Register a stylesheet for the selected admin color scheme.
- $styles->add( 'colors', true, array( 'wp-admin', 'buttons' ) );
- $suffix = SCRIPT_DEBUG ? '' : '.min';
- // Admin CSS.
- $styles->add( 'common', "/wp-admin/css/common$suffix.css" );
- $styles->add( 'forms', "/wp-admin/css/forms$suffix.css" );
- $styles->add( 'admin-menu', "/wp-admin/css/admin-menu$suffix.css" );
- $styles->add( 'dashboard', "/wp-admin/css/dashboard$suffix.css" );
- $styles->add( 'list-tables', "/wp-admin/css/list-tables$suffix.css" );
- $styles->add( 'edit', "/wp-admin/css/edit$suffix.css" );
- $styles->add( 'revisions', "/wp-admin/css/revisions$suffix.css" );
- $styles->add( 'media', "/wp-admin/css/media$suffix.css" );
- $styles->add( 'themes', "/wp-admin/css/themes$suffix.css" );
- $styles->add( 'about', "/wp-admin/css/about$suffix.css" );
- $styles->add( 'nav-menus', "/wp-admin/css/nav-menus$suffix.css" );
- $styles->add( 'widgets', "/wp-admin/css/widgets$suffix.css", array( 'wp-pointer' ) );
- $styles->add( 'site-icon', "/wp-admin/css/site-icon$suffix.css" );
- $styles->add( 'l10n', "/wp-admin/css/l10n$suffix.css" );
- $styles->add( 'code-editor', "/wp-admin/css/code-editor$suffix.css", array( 'wp-codemirror' ) );
- $styles->add( 'site-health', "/wp-admin/css/site-health$suffix.css" );
- $styles->add( 'wp-admin', false, array( 'dashicons', 'common', 'forms', 'admin-menu', 'dashboard', 'list-tables', 'edit', 'revisions', 'media', 'themes', 'about', 'nav-menus', 'widgets', 'site-icon', 'l10n' ) );
- $styles->add( 'login', "/wp-admin/css/login$suffix.css", array( 'dashicons', 'buttons', 'forms', 'l10n' ) );
- $styles->add( 'install', "/wp-admin/css/install$suffix.css", array( 'dashicons', 'buttons', 'forms', 'l10n' ) );
- $styles->add( 'wp-color-picker', "/wp-admin/css/color-picker$suffix.css" );
- $styles->add( 'customize-controls', "/wp-admin/css/customize-controls$suffix.css", array( 'wp-admin', 'colors', 'imgareaselect' ) );
- $styles->add( 'customize-widgets', "/wp-admin/css/customize-widgets$suffix.css", array( 'wp-admin', 'colors' ) );
- $styles->add( 'customize-nav-menus', "/wp-admin/css/customize-nav-menus$suffix.css", array( 'wp-admin', 'colors' ) );
- // Common dependencies.
- $styles->add( 'buttons', "/wp-includes/css/buttons$suffix.css" );
- $styles->add( 'dashicons', "/wp-includes/css/dashicons$suffix.css" );
- // Includes CSS.
- $styles->add( 'admin-bar', "/wp-includes/css/admin-bar$suffix.css", array( 'dashicons' ) );
- $styles->add( 'wp-auth-check', "/wp-includes/css/wp-auth-check$suffix.css", array( 'dashicons' ) );
- $styles->add( 'editor-buttons', "/wp-includes/css/editor$suffix.css", array( 'dashicons' ) );
- $styles->add( 'media-views', "/wp-includes/css/media-views$suffix.css", array( 'buttons', 'dashicons', 'wp-mediaelement' ) );
- $styles->add( 'wp-pointer', "/wp-includes/css/wp-pointer$suffix.css", array( 'dashicons' ) );
- $styles->add( 'customize-preview', "/wp-includes/css/customize-preview$suffix.css", array( 'dashicons' ) );
- $styles->add( 'wp-embed-template-ie', "/wp-includes/css/wp-embed-template-ie$suffix.css" );
- $styles->add_data( 'wp-embed-template-ie', 'conditional', 'lte IE 8' );
- // External libraries and friends.
- $styles->add( 'imgareaselect', '/wp-includes/js/imgareaselect/imgareaselect.css', array(), '0.9.8' );
- $styles->add( 'wp-jquery-ui-dialog', "/wp-includes/css/jquery-ui-dialog$suffix.css", array( 'dashicons' ) );
- $styles->add( 'mediaelement', '/wp-includes/js/mediaelement/mediaelementplayer-legacy.min.css', array(), '4.2.17' );
- $styles->add( 'wp-mediaelement', "/wp-includes/js/mediaelement/wp-mediaelement$suffix.css", array( 'mediaelement' ) );
- $styles->add( 'thickbox', '/wp-includes/js/thickbox/thickbox.css', array( 'dashicons' ) );
- $styles->add( 'wp-codemirror', '/wp-includes/js/codemirror/codemirror.min.css', array(), '5.29.1-alpha-ee20357' );
- // Deprecated CSS.
- $styles->add( 'deprecated-media', "/wp-admin/css/deprecated-media$suffix.css" );
- $styles->add( 'farbtastic', "/wp-admin/css/farbtastic$suffix.css", array(), '1.3u1' );
- $styles->add( 'jcrop', '/wp-includes/js/jcrop/jquery.Jcrop.min.css', array(), '0.9.15' );
- $styles->add( 'colors-fresh', false, array( 'wp-admin', 'buttons' ) ); // Old handle.
- $styles->add( 'open-sans', $open_sans_font_url ); // No longer used in core as of 4.6.
- // Noto Serif is no longer used by core, but may be relied upon by themes and plugins.
- $fonts_url = '';
- /*
- * translators: Use this to specify the proper Google Font name and variants
- * to load that is supported by your language. Do not translate.
- * Set to 'off' to disable loading.
- */
- $font_family = _x( 'Noto Serif:400,400i,700,700i', 'Google Font Name and Variants' );
- if ( 'off' !== $font_family ) {
- $fonts_url = 'https://fonts.googleapis.com/css?family=' . urlencode( $font_family );
- }
- $styles->add( 'wp-editor-font', $fonts_url ); // No longer used in core as of 5.7.
- $block_library_theme_path = WPINC . "/css/dist/block-library/theme$suffix.css";
- $styles->add( 'wp-block-library-theme', "/$block_library_theme_path" );
- $styles->add_data( 'wp-block-library-theme', 'path', ABSPATH . $block_library_theme_path );
- $styles->add(
- 'wp-reset-editor-styles',
- "/wp-includes/css/dist/block-library/reset$suffix.css",
- array( 'common', 'forms' ) // Make sure the reset is loaded after the default WP Admin styles.
- );
- $styles->add(
- 'wp-editor-classic-layout-styles',
- "/wp-includes/css/dist/edit-post/classic$suffix.css",
- array()
- );
- $wp_edit_blocks_dependencies = array(
- 'wp-components',
- 'wp-editor',
- // This need to be added before the block library styles,
- // The block library styles override the "reset" styles.
- 'wp-reset-editor-styles',
- 'wp-block-library',
- 'wp-reusable-blocks',
- );
- // Only load the default layout and margin styles for themes without theme.json file.
- if ( ! WP_Theme_JSON_Resolver::theme_has_support() ) {
- $wp_edit_blocks_dependencies[] = 'wp-editor-classic-layout-styles';
- }
- if ( ! is_array( $editor_styles ) || count( $editor_styles ) === 0 ) {
- // Include opinionated block styles if no $editor_styles are declared, so the editor never appears broken.
- $wp_edit_blocks_dependencies[] = 'wp-block-library-theme';
- }
- $styles->add(
- 'wp-edit-blocks',
- "/wp-includes/css/dist/block-library/editor$suffix.css",
- $wp_edit_blocks_dependencies
- );
- $package_styles = array(
- 'block-editor' => array( 'wp-components' ),
- 'block-library' => array(),
- 'block-directory' => array(),
- 'components' => array(),
- 'edit-post' => array(
- 'wp-components',
- 'wp-block-editor',
- 'wp-editor',
- 'wp-edit-blocks',
- 'wp-block-library',
- 'wp-nux',
- ),
- 'editor' => array(
- 'wp-components',
- 'wp-block-editor',
- 'wp-nux',
- 'wp-reusable-blocks',
- ),
- 'format-library' => array(),
- 'list-reusable-blocks' => array( 'wp-components' ),
- 'reusable-blocks' => array( 'wp-components' ),
- 'nux' => array( 'wp-components' ),
- 'widgets' => array(
- 'wp-components',
- ),
- 'edit-widgets' => array(
- 'wp-widgets',
- 'wp-block-editor',
- 'wp-edit-blocks',
- 'wp-block-library',
- 'wp-reusable-blocks',
- ),
- 'customize-widgets' => array(
- 'wp-widgets',
- 'wp-block-editor',
- 'wp-edit-blocks',
- 'wp-block-library',
- 'wp-reusable-blocks',
- ),
- 'edit-site' => array(
- 'wp-components',
- 'wp-block-editor',
- 'wp-edit-blocks',
- ),
- );
- foreach ( $package_styles as $package => $dependencies ) {
- $handle = 'wp-' . $package;
- $path = "/wp-includes/css/dist/$package/style$suffix.css";
- if ( 'block-library' === $package && wp_should_load_separate_core_block_assets() ) {
- $path = "/wp-includes/css/dist/$package/common$suffix.css";
- }
- $styles->add( $handle, $path, $dependencies );
- $styles->add_data( $handle, 'path', ABSPATH . $path );
- }
- // RTL CSS.
- $rtl_styles = array(
- // Admin CSS.
- 'common',
- 'forms',
- 'admin-menu',
- 'dashboard',
- 'list-tables',
- 'edit',
- 'revisions',
- 'media',
- 'themes',
- 'about',
- 'nav-menus',
- 'widgets',
- 'site-icon',
- 'l10n',
- 'install',
- 'wp-color-picker',
- 'customize-controls',
- 'customize-widgets',
- 'customize-nav-menus',
- 'customize-preview',
- 'login',
- 'site-health',
- // Includes CSS.
- 'buttons',
- 'admin-bar',
- 'wp-auth-check',
- 'editor-buttons',
- 'media-views',
- 'wp-pointer',
- 'wp-jquery-ui-dialog',
- // Package styles.
- 'wp-reset-editor-styles',
- 'wp-editor-classic-layout-styles',
- 'wp-block-library-theme',
- 'wp-edit-blocks',
- 'wp-block-editor',
- 'wp-block-library',
- 'wp-block-directory',
- 'wp-components',
- 'wp-customize-widgets',
- 'wp-edit-post',
- 'wp-edit-site',
- 'wp-edit-widgets',
- 'wp-editor',
- 'wp-format-library',
- 'wp-list-reusable-blocks',
- 'wp-reusable-blocks',
- 'wp-nux',
- 'wp-widgets',
- // Deprecated CSS.
- 'deprecated-media',
- 'farbtastic',
- );
- foreach ( $rtl_styles as $rtl_style ) {
- $styles->add_data( $rtl_style, 'rtl', 'replace' );
- if ( $suffix ) {
- $styles->add_data( $rtl_style, 'suffix', $suffix );
- }
- }
- }
- /**
- * Reorders JavaScript scripts array to place prototype before jQuery.
- *
- * @since 2.3.1
- *
- * @param string[] $js_array JavaScript scripts array
- * @return string[] Reordered array, if needed.
- */
- function wp_prototype_before_jquery( $js_array ) {
- $prototype = array_search( 'prototype', $js_array, true );
- if ( false === $prototype ) {
- return $js_array;
- }
- $jquery = array_search( 'jquery', $js_array, true );
- if ( false === $jquery ) {
- return $js_array;
- }
- if ( $prototype < $jquery ) {
- return $js_array;
- }
- unset( $js_array[ $prototype ] );
- array_splice( $js_array, $jquery, 0, 'prototype' );
- return $js_array;
- }
- /**
- * Loads localized data on print rather than initialization.
- *
- * These localizations require information that may not be loaded even by init.
- *
- * @since 2.5.0
- */
- function wp_just_in_time_script_localization() {
- wp_localize_script(
- 'autosave',
- 'autosaveL10n',
- array(
- 'autosaveInterval' => AUTOSAVE_INTERVAL,
- 'blog_id' => get_current_blog_id(),
- )
- );
- wp_localize_script(
- 'mce-view',
- 'mceViewL10n',
- array(
- 'shortcodes' => ! empty( $GLOBALS['shortcode_tags'] ) ? array_keys( $GLOBALS['shortcode_tags'] ) : array(),
- )
- );
- wp_localize_script(
- 'word-count',
- 'wordCountL10n',
- array(
- /*
- * translators: If your word count is based on single characters (e.g. East Asian characters),
- * enter 'characters_excluding_spaces' or 'characters_including_spaces'. Otherwise, enter 'words'.
- * Do not translate into your own language.
- */
- 'type' => _x( 'words', 'Word count type. Do not translate!' ),
- 'shortcodes' => ! empty( $GLOBALS['shortcode_tags'] ) ? array_keys( $GLOBALS['shortcode_tags'] ) : array(),
- )
- );
- }
- /**
- * Localizes the jQuery UI datepicker.
- *
- * @since 4.6.0
- *
- * @link https://api.jqueryui.com/datepicker/#options
- *
- * @global WP_Locale $wp_locale WordPress date and time locale object.
- */
- function wp_localize_jquery_ui_datepicker() {
- global $wp_locale;
- if ( ! wp_script_is( 'jquery-ui-datepicker', 'enqueued' ) ) {
- return;
- }
- // Convert the PHP date format into jQuery UI's format.
- $datepicker_date_format = str_replace(
- array(
- 'd',
- 'j',
- 'l',
- 'z', // Day.
- 'F',
- 'M',
- 'n',
- 'm', // Month.
- 'Y',
- 'y', // Year.
- ),
- array(
- 'dd',
- 'd',
- 'DD',
- 'o',
- 'MM',
- 'M',
- 'm',
- 'mm',
- 'yy',
- 'y',
- ),
- get_option( 'date_format' )
- );
- $datepicker_defaults = wp_json_encode(
- array(
- 'closeText' => __( 'Close' ),
- 'currentText' => __( 'Today' ),
- 'monthNames' => array_values( $wp_locale->month ),
- 'monthNamesShort' => array_values( $wp_locale->month_abbrev ),
- 'nextText' => __( 'Next' ),
- 'prevText' => __( 'Previous' ),
- 'dayNames' => array_values( $wp_locale->weekday ),
- 'dayNamesShort' => array_values( $wp_locale->weekday_abbrev ),
- 'dayNamesMin' => array_values( $wp_locale->weekday_initial ),
- 'dateFormat' => $datepicker_date_format,
- 'firstDay' => absint( get_option( 'start_of_week' ) ),
- 'isRTL' => $wp_locale->is_rtl(),
- )
- );
- wp_add_inline_script( 'jquery-ui-datepicker', "jQuery(function(jQuery){jQuery.datepicker.setDefaults({$datepicker_defaults});});" );
- }
- /**
- * Localizes community events data that needs to be passed to dashboard.js.
- *
- * @since 4.8.0
- */
- function wp_localize_community_events() {
- if ( ! wp_script_is( 'dashboard' ) ) {
- return;
- }
- require_once ABSPATH . 'wp-admin/includes/class-wp-community-events.php';
- $user_id = get_current_user_id();
- $saved_location = get_user_option( 'community-events-location', $user_id );
- $saved_ip_address = isset( $saved_location['ip'] ) ? $saved_location['ip'] : false;
- $current_ip_address = WP_Community_Events::get_unsafe_client_ip();
- /*
- * If the user's location is based on their IP address, then update their
- * location when their IP address changes. This allows them to see events
- * in their current city when travelling. Otherwise, they would always be
- * shown events in the city where they were when they first loaded the
- * Dashboard, which could have been months or years ago.
- */
- if ( $saved_ip_address && $current_ip_address && $current_ip_address !== $saved_ip_address ) {
- $saved_location['ip'] = $current_ip_address;
- update_user_meta( $user_id, 'community-events-location', $saved_location );
- }
- $events_client = new WP_Community_Events( $user_id, $saved_location );
- wp_localize_script(
- 'dashboard',
- 'communityEventsData',
- array(
- 'nonce' => wp_create_nonce( 'community_events' ),
- 'cache' => $events_client->get_cached_events(),
- 'time_format' => get_option( 'time_format' ),
- )
- );
- }
- /**
- * Administration Screen CSS for changing the styles.
- *
- * If installing the 'wp-admin/' directory will be replaced with './'.
- *
- * The $_wp_admin_css_colors global manages the Administration Screens CSS
- * stylesheet that is loaded. The option that is set is 'admin_color' and is the
- * color and key for the array. The value for the color key is an object with
- * a 'url' parameter that has the URL path to the CSS file.
- *
- * The query from $src parameter will be appended to the URL that is given from
- * the $_wp_admin_css_colors array value URL.
- *
- * @since 2.6.0
- *
- * @global array $_wp_admin_css_colors
- *
- * @param string $src Source URL.
- * @param string $handle Either 'colors' or 'colors-rtl'.
- * @return string|false URL path to CSS stylesheet for Administration Screens.
- */
- function wp_style_loader_src( $src, $handle ) {
- global $_wp_admin_css_colors;
- if ( wp_installing() ) {
- return preg_replace( '#^wp-admin/#', './', $src );
- }
- if ( 'colors' === $handle ) {
- $color = get_user_option( 'admin_color' );
- if ( empty( $color ) || ! isset( $_wp_admin_css_colors[ $color ] ) ) {
- $color = 'fresh';
- }
- $color = $_wp_admin_css_colors[ $color ];
- $url = $color->url;
- if ( ! $url ) {
- return false;
- }
- $parsed = parse_url( $src );
- if ( isset( $parsed['query'] ) && $parsed['query'] ) {
- wp_parse_str( $parsed['query'], $qv );
- $url = add_query_arg( $qv, $url );
- }
- return $url;
- }
- return $src;
- }
- /**
- * Prints the script queue in the HTML head on admin pages.
- *
- * Postpones the scripts that were queued for the footer.
- * print_footer_scripts() is called in the footer to print these scripts.
- *
- * @since 2.8.0
- *
- * @see wp_print_scripts()
- *
- * @global bool $concatenate_scripts
- *
- * @return array
- */
- function print_head_scripts() {
- global $concatenate_scripts;
- if ( ! did_action( 'wp_print_scripts' ) ) {
- /** This action is documented in wp-includes/functions.wp-scripts.php */
- do_action( 'wp_print_scripts' );
- }
- $wp_scripts = wp_scripts();
- script_concat_settings();
- $wp_scripts->do_concat = $concatenate_scripts;
- $wp_scripts->do_head_items();
- /**
- * Filters whether to print the head scripts.
- *
- * @since 2.8.0
- *
- * @param bool $print Whether to print the head scripts. Default true.
- */
- if ( apply_filters( 'print_head_scripts', true ) ) {
- _print_scripts();
- }
- $wp_scripts->reset();
- return $wp_scripts->done;
- }
- /**
- * Prints the scripts that were queued for the footer or too late for the HTML head.
- *
- * @since 2.8.0
- *
- * @global WP_Scripts $wp_scripts
- * @global bool $concatenate_scripts
- *
- * @return array
- */
- function print_footer_scripts() {
- global $wp_scripts, $concatenate_scripts;
- if ( ! ( $wp_scripts instanceof WP_Scripts ) ) {
- return array(); // No need to run if not instantiated.
- }
- script_concat_settings();
- $wp_scripts->do_concat = $concatenate_scripts;
- $wp_scripts->do_footer_items();
- /**
- * Filters whether to print the footer scripts.
- *
- * @since 2.8.0
- *
- * @param bool $print Whether to print the footer scripts. Default true.
- */
- if ( apply_filters( 'print_footer_scripts', true ) ) {
- _print_scripts();
- }
- $wp_scripts->reset();
- return $wp_scripts->done;
- }
- /**
- * Prints scripts (internal use only)
- *
- * @ignore
- *
- * @global WP_Scripts $wp_scripts
- * @global bool $compress_scripts
- */
- function _print_scripts() {
- global $wp_scripts, $compress_scripts;
- $zip = $compress_scripts ? 1 : 0;
- if ( $zip && defined( 'ENFORCE_GZIP' ) && ENFORCE_GZIP ) {
- $zip = 'gzip';
- }
- $concat = trim( $wp_scripts->concat, ', ' );
- $type_attr = current_theme_supports( 'html5', 'script' ) ? '' : " type='text/javascript'";
- if ( $concat ) {
- if ( ! empty( $wp_scripts->print_code ) ) {
- echo "\n<script{$type_attr}>\n";
- echo "/* <![CDATA[ */\n"; // Not needed in HTML 5.
- echo $wp_scripts->print_code;
- echo "/* ]]> */\n";
- echo "</script>\n";
- }
- $concat = str_split( $concat, 128 );
- $concatenated = '';
- foreach ( $concat as $key => $chunk ) {
- $concatenated .= "&load%5Bchunk_{$key}%5D={$chunk}";
- }
- $src = $wp_scripts->base_url . "/wp-admin/load-scripts.php?c={$zip}" . $concatenated . '&ver=' . $wp_scripts->default_version;
- echo "<script{$type_attr} src='" . esc_attr( $src ) . "'></script>\n";
- }
- if ( ! empty( $wp_scripts->print_html ) ) {
- echo $wp_scripts->print_html;
- }
- }
- /**
- * Prints the script queue in the HTML head on the front end.
- *
- * Postpones the scripts that were queued for the footer.
- * wp_print_footer_scripts() is called in the footer to print these scripts.
- *
- * @since 2.8.0
- *
- * @global WP_Scripts $wp_scripts
- *
- * @return array
- */
- function wp_print_head_scripts() {
- global $wp_scripts;
- if ( ! did_action( 'wp_print_scripts' ) ) {
- /** This action is documented in wp-includes/functions.wp-scripts.php */
- do_action( 'wp_print_scripts' );
- }
- if ( ! ( $wp_scripts instanceof WP_Scripts ) ) {
- return array(); // No need to run if nothing is queued.
- }
- return print_head_scripts();
- }
- /**
- * Private, for use in *_footer_scripts hooks
- *
- * @since 3.3.0
- */
- function _wp_footer_scripts() {
- print_late_styles();
- print_footer_scripts();
- }
- /**
- * Hooks to print the scripts and styles in the footer.
- *
- * @since 2.8.0
- */
- function wp_print_footer_scripts() {
- /**
- * Fires when footer scripts are printed.
- *
- * @since 2.8.0
- */
- do_action( 'wp_print_footer_scripts' );
- }
- /**
- * Wrapper for do_action( 'wp_enqueue_scripts' ).
- *
- * Allows plugins to queue scripts for the front end using wp_enqueue_script().
- * Runs first in wp_head() where all is_home(), is_page(), etc. functions are available.
- *
- * @since 2.8.0
- */
- function wp_enqueue_scripts() {
- /**
- * Fires when scripts and styles are enqueued.
- *
- * @since 2.8.0
- */
- do_action( 'wp_enqueue_scripts' );
- }
- /**
- * Prints the styles queue in the HTML head on admin pages.
- *
- * @since 2.8.0
- *
- * @global bool $concatenate_scripts
- *
- * @return array
- */
- function print_admin_styles() {
- global $concatenate_scripts;
- $wp_styles = wp_styles();
- script_concat_settings();
- $wp_styles->do_concat = $concatenate_scripts;
- $wp_styles->do_items( false );
- /**
- * Filters whether to print the admin styles.
- *
- * @since 2.8.0
- *
- * @param bool $print Whether to print the admin styles. Default true.
- */
- if ( apply_filters( 'print_admin_styles', true ) ) {
- _print_styles();
- }
- $wp_styles->reset();
- return $wp_styles->done;
- }
- /**
- * Prints the styles that were queued too late for the HTML head.
- *
- * @since 3.3.0
- *
- * @global WP_Styles $wp_styles
- * @global bool $concatenate_scripts
- *
- * @return array|void
- */
- function print_late_styles() {
- global $wp_styles, $concatenate_scripts;
- if ( ! ( $wp_styles instanceof WP_Styles ) ) {
- return;
- }
- script_concat_settings();
- $wp_styles->do_concat = $concatenate_scripts;
- $wp_styles->do_footer_items();
- /**
- * Filters whether to print the styles queued too late for the HTML head.
- *
- * @since 3.3.0
- *
- * @param bool $print Whether to print the 'late' styles. Default true.
- */
- if ( apply_filters( 'print_late_styles', true ) ) {
- _print_styles();
- }
- $wp_styles->reset();
- return $wp_styles->done;
- }
- /**
- * Prints styles (internal use only).
- *
- * @ignore
- * @since 3.3.0
- *
- * @global bool $compress_css
- */
- function _print_styles() {
- global $compress_css;
- $wp_styles = wp_styles();
- $zip = $compress_css ? 1 : 0;
- if ( $zip && defined( 'ENFORCE_GZIP' ) && ENFORCE_GZIP ) {
- $zip = 'gzip';
- }
- $concat = trim( $wp_styles->concat, ', ' );
- $type_attr = current_theme_supports( 'html5', 'style' ) ? '' : ' type="text/css"';
- if ( $concat ) {
- $dir = $wp_styles->text_direction;
- $ver = $wp_styles->default_version;
- $concat = str_split( $concat, 128 );
- $concatenated = '';
- foreach ( $concat as $key => $chunk ) {
- $concatenated .= "&load%5Bchunk_{$key}%5D={$chunk}";
- }
- $href = $wp_styles->base_url . "/wp-admin/load-styles.php?c={$zip}&dir={$dir}" . $concatenated . '&ver=' . $ver;
- echo "<link rel='stylesheet' href='" . esc_attr( $href ) . "'{$type_attr} media='all' />\n";
- if ( ! empty( $wp_styles->print_code ) ) {
- echo "<style{$type_attr}>\n";
- echo $wp_styles->print_code;
- echo "\n</style>\n";
- }
- }
- if ( ! empty( $wp_styles->print_html ) ) {
- echo $wp_styles->print_html;
- }
- }
- /**
- * Determines the concatenation and compression settings for scripts and styles.
- *
- * @since 2.8.0
- *
- * @global bool $concatenate_scripts
- * @global bool $compress_scripts
- * @global bool $compress_css
- */
- function script_concat_settings() {
- global $concatenate_scripts, $compress_scripts, $compress_css;
- $compressed_output = ( ini_get( 'zlib.output_compression' ) || 'ob_gzhandler' === ini_get( 'output_handler' ) );
- $can_compress_scripts = ! wp_installing() && get_site_option( 'can_compress_scripts' );
- if ( ! isset( $concatenate_scripts ) ) {
- $concatenate_scripts = defined( 'CONCATENATE_SCRIPTS' ) ? CONCATENATE_SCRIPTS : true;
- if ( ( ! is_admin() && ! did_action( 'login_init' ) ) || ( defined( 'SCRIPT_DEBUG' ) && SCRIPT_DEBUG ) ) {
- $concatenate_scripts = false;
- }
- }
- if ( ! isset( $compress_scripts ) ) {
- $compress_scripts = defined( 'COMPRESS_SCRIPTS' ) ? COMPRESS_SCRIPTS : true;
- if ( $compress_scripts && ( ! $can_compress_scripts || $compressed_output ) ) {
- $compress_scripts = false;
- }
- }
- if ( ! isset( $compress_css ) ) {
- $compress_css = defined( 'COMPRESS_CSS' ) ? COMPRESS_CSS : true;
- if ( $compress_css && ( ! $can_compress_scripts || $compressed_output ) ) {
- $compress_css = false;
- }
- }
- }
- /**
- * Handles the enqueueing of block scripts and styles that are common to both
- * the editor and the front-end.
- *
- * @since 5.0.0
- */
- function wp_common_block_scripts_and_styles() {
- if ( is_admin() && ! wp_should_load_block_editor_scripts_and_styles() ) {
- return;
- }
- wp_enqueue_style( 'wp-block-library' );
- if ( current_theme_supports( 'wp-block-styles' ) ) {
- if ( wp_should_load_separate_core_block_assets() ) {
- $suffix = defined( 'SCRIPT_DEBUG' ) && SCRIPT_DEBUG ? 'css' : 'min.css';
- $files = glob( __DIR__ . "/blocks/**/theme.$suffix" );
- foreach ( $files as $path ) {
- $block_name = basename( dirname( $path ) );
- if ( is_rtl() && file_exists( __DIR__ . "/blocks/$block_name/theme-rtl.$suffix" ) ) {
- $path = __DIR__ . "/blocks/$block_name/theme-rtl.$suffix";
- }
- wp_add_inline_style( "wp-block-{$block_name}", file_get_contents( $path ) );
- }
- } else {
- wp_enqueue_style( 'wp-block-library-theme' );
- }
- }
- /**
- * Fires after enqueuing block assets for both editor and front-end.
- *
- * Call `add_action` on any hook before 'wp_enqueue_scripts'.
- *
- * In the function call you supply, simply use `wp_enqueue_script` and
- * `wp_enqueue_style` to add your functionality to the Gutenberg editor.
- *
- * @since 5.0.0
- */
- do_action( 'enqueue_block_assets' );
- }
- /**
- * Applies a filter to the list of style nodes that comes from WP_Theme_JSON::get_style_nodes().
- *
- * This particular filter removes all of the blocks from the array.
- *
- * We want WP_Theme_JSON to be ignorant of the implementation details of how the CSS is being used.
- * This filter allows us to modify the output of WP_Theme_JSON depending on whether or not we are
- * loading separate assets, without making the class aware of that detail.
- *
- * @since 6.1.0
- *
- * @param array $nodes The nodes to filter.
- * @return array A filtered array of style nodes.
- */
- function wp_filter_out_block_nodes( $nodes ) {
- return array_filter(
- $nodes,
- function( $node ) {
- return ! in_array( 'blocks', $node['path'], true );
- },
- ARRAY_FILTER_USE_BOTH
- );
- }
- /**
- * Enqueues the global styles defined via theme.json.
- *
- * @since 5.8.0
- */
- function wp_enqueue_global_styles() {
- $separate_assets = wp_should_load_separate_core_block_assets();
- $is_block_theme = wp_is_block_theme();
- $is_classic_theme = ! $is_block_theme;
- /*
- * Global styles should be printed in the head when loading all styles combined.
- * The footer should only be used to print global styles for classic themes with separate core assets enabled.
- *
- * See https://core.trac.wordpress.org/ticket/53494.
- */
- if (
- ( $is_block_theme && doing_action( 'wp_footer' ) ) ||
- ( $is_classic_theme && doing_action( 'wp_footer' ) && ! $separate_assets ) ||
- ( $is_classic_theme && doing_action( 'wp_enqueue_scripts' ) && $separate_assets )
- ) {
- return;
- }
- /*
- * If loading the CSS for each block separately, then load the theme.json CSS conditionally.
- * This removes the CSS from the global-styles stylesheet and adds it to the inline CSS for each block.
- * This filter must be registered before calling wp_get_global_stylesheet();
- */
- add_filter( 'wp_theme_json_get_style_nodes', 'wp_filter_out_block_nodes' );
- $stylesheet = wp_get_global_stylesheet();
- if ( empty( $stylesheet ) ) {
- return;
- }
- wp_register_style( 'global-styles', false, array(), true, true );
- wp_add_inline_style( 'global-styles', $stylesheet );
- wp_enqueue_style( 'global-styles' );
- // Add each block as an inline css.
- wp_add_global_styles_for_blocks();
- }
- /**
- * Renders the SVG filters supplied by theme.json.
- *
- * Note that this doesn't render the per-block user-defined
- * filters which are handled by wp_render_duotone_support,
- * but it should be rendered before the filtered content
- * in the body to satisfy Safari's rendering quirks.
- *
- * @since 5.9.1
- */
- function wp_global_styles_render_svg_filters() {
- /*
- * When calling via the in_admin_header action, we only want to render the
- * SVGs on block editor pages.
- */
- if (
- is_admin() &&
- ! get_current_screen()->is_block_editor()
- ) {
- return;
- }
- $filters = wp_get_global_styles_svg_filters();
- if ( ! empty( $filters ) ) {
- echo $filters;
- }
- }
- /**
- * Checks if the editor scripts and styles for all registered block types
- * should be enqueued on the current screen.
- *
- * @since 5.6.0
- *
- * @global WP_Screen $current_screen WordPress current screen object.
- *
- * @return bool Whether scripts and styles should be enqueued.
- */
- function wp_should_load_block_editor_scripts_and_styles() {
- global $current_screen;
- $is_block_editor_screen = ( $current_screen instanceof WP_Screen ) && $current_screen->is_block_editor();
- /**
- * Filters the flag that decides whether or not block editor scripts and styles
- * are going to be enqueued on the current screen.
- *
- * @since 5.6.0
- *
- * @param bool $is_block_editor_screen Current value of the flag.
- */
- return apply_filters( 'should_load_block_editor_scripts_and_styles', $is_block_editor_screen );
- }
- /**
- * Checks whether separate styles should be loaded for core blocks on-render.
- *
- * When this function returns true, other functions ensure that core blocks
- * only load their assets on-render, and each block loads its own, individual
- * assets. Third-party blocks only load their assets when rendered.
- *
- * When this function returns false, all core block assets are loaded regardless
- * of whether they are rendered in a page or not, because they are all part of
- * the `block-library/style.css` file. Assets for third-party blocks are always
- * enqueued regardless of whether they are rendered or not.
- *
- * This only affects front end and not the block editor screens.
- *
- * @see wp_enqueue_registered_block_scripts_and_styles()
- * @see register_block_style_handle()
- *
- * @since 5.8.0
- *
- * @return bool Whether separate assets will be loaded.
- */
- function wp_should_load_separate_core_block_assets() {
- if ( is_admin() || is_feed() || ( defined( 'REST_REQUEST' ) && REST_REQUEST ) ) {
- return false;
- }
- /**
- * Filters whether block styles should be loaded separately.
- *
- * Returning false loads all core block assets, regardless of whether they are rendered
- * in a page or not. Returning true loads core block assets only when they are rendered.
- *
- * @since 5.8.0
- *
- * @param bool $load_separate_assets Whether separate assets will be loaded.
- * Default false (all block assets are loaded, even when not used).
- */
- return apply_filters( 'should_load_separate_core_block_assets', false );
- }
- /**
- * Enqueues registered block scripts and styles, depending on current rendered
- * context (only enqueuing editor scripts while in context of the editor).
- *
- * @since 5.0.0
- *
- * @global WP_Screen $current_screen WordPress current screen object.
- */
- function wp_enqueue_registered_block_scripts_and_styles() {
- global $current_screen;
- if ( wp_should_load_separate_core_block_assets() ) {
- return;
- }
- $load_editor_scripts_and_styles = is_admin() && wp_should_load_block_editor_scripts_and_styles();
- $block_registry = WP_Block_Type_Registry::get_instance();
- foreach ( $block_registry->get_all_registered() as $block_name => $block_type ) {
- // Front-end and editor styles.
- foreach ( $block_type->style_handles as $style_handle ) {
- wp_enqueue_style( $style_handle );
- }
- // Front-end and editor scripts.
- foreach ( $block_type->script_handles as $script_handle ) {
- wp_enqueue_script( $script_handle );
- }
- if ( $load_editor_scripts_and_styles ) {
- // Editor styles.
- foreach ( $block_type->editor_style_handles as $editor_style_handle ) {
- wp_enqueue_style( $editor_style_handle );
- }
- // Editor scripts.
- foreach ( $block_type->editor_script_handles as $editor_script_handle ) {
- wp_enqueue_script( $editor_script_handle );
- }
- }
- }
- }
- /**
- * Function responsible for enqueuing the styles required for block styles functionality on the editor and on the frontend.
- *
- * @since 5.3.0
- *
- * @global WP_Styles $wp_styles
- */
- function enqueue_block_styles_assets() {
- global $wp_styles;
- $block_styles = WP_Block_Styles_Registry::get_instance()->get_all_registered();
- foreach ( $block_styles as $block_name => $styles ) {
- foreach ( $styles as $style_properties ) {
- if ( isset( $style_properties['style_handle'] ) ) {
- // If the site loads separate styles per-block, enqueue the stylesheet on render.
- if ( wp_should_load_separate_core_block_assets() ) {
- add_filter(
- 'render_block',
- function( $html, $block ) use ( $block_name, $style_properties ) {
- if ( $block['blockName'] === $block_name ) {
- wp_enqueue_style( $style_properties['style_handle'] );
- }
- return $html;
- },
- 10,
- 2
- );
- } else {
- wp_enqueue_style( $style_properties['style_handle'] );
- }
- }
- if ( isset( $style_properties['inline_style'] ) ) {
- // Default to "wp-block-library".
- $handle = 'wp-block-library';
- // If the site loads separate styles per-block, check if the block has a stylesheet registered.
- if ( wp_should_load_separate_core_block_assets() ) {
- $block_stylesheet_handle = generate_block_asset_handle( $block_name, 'style' );
- if ( isset( $wp_styles->registered[ $block_stylesheet_handle ] ) ) {
- $handle = $block_stylesheet_handle;
- }
- }
- // Add inline styles to the calculated handle.
- wp_add_inline_style( $handle, $style_properties['inline_style'] );
- }
- }
- }
- }
- /**
- * Function responsible for enqueuing the assets required for block styles functionality on the editor.
- *
- * @since 5.3.0
- */
- function enqueue_editor_block_styles_assets() {
- $block_styles = WP_Block_Styles_Registry::get_instance()->get_all_registered();
- $register_script_lines = array( '( function() {' );
- foreach ( $block_styles as $block_name => $styles ) {
- foreach ( $styles as $style_properties ) {
- $block_style = array(
- 'name' => $style_properties['name'],
- 'label' => $style_properties['label'],
- );
- if ( isset( $style_properties['is_default'] ) ) {
- $block_style['isDefault'] = $style_properties['is_default'];
- }
- $register_script_lines[] = sprintf(
- ' wp.blocks.registerBlockStyle( \'%s\', %s );',
- $block_name,
- wp_json_encode( $block_style )
- );
- }
- }
- $register_script_lines[] = '} )();';
- $inline_script = implode( "\n", $register_script_lines );
- wp_register_script( 'wp-block-styles', false, array( 'wp-blocks' ), true, true );
- wp_add_inline_script( 'wp-block-styles', $inline_script );
- wp_enqueue_script( 'wp-block-styles' );
- }
- /**
- * Enqueues the assets required for the block directory within the block editor.
- *
- * @since 5.5.0
- */
- function wp_enqueue_editor_block_directory_assets() {
- wp_enqueue_script( 'wp-block-directory' );
- wp_enqueue_style( 'wp-block-directory' );
- }
- /**
- * Enqueues the assets required for the format library within the block editor.
- *
- * @since 5.8.0
- */
- function wp_enqueue_editor_format_library_assets() {
- wp_enqueue_script( 'wp-format-library' );
- wp_enqueue_style( 'wp-format-library' );
- }
- /**
- * Sanitizes an attributes array into an attributes string to be placed inside a `<script>` tag.
- *
- * Automatically injects type attribute if needed.
- * Used by {@see wp_get_script_tag()} and {@see wp_get_inline_script_tag()}.
- *
- * @since 5.7.0
- *
- * @param array $attributes Key-value pairs representing `<script>` tag attributes.
- * @return string String made of sanitized `<script>` tag attributes.
- */
- function wp_sanitize_script_attributes( $attributes ) {
- $html5_script_support = ! is_admin() && ! current_theme_supports( 'html5', 'script' );
- $attributes_string = '';
- // If HTML5 script tag is supported, only the attribute name is added
- // to $attributes_string for entries with a boolean value, and that are true.
- foreach ( $attributes as $attribute_name => $attribute_value ) {
- if ( is_bool( $attribute_value ) ) {
- if ( $attribute_value ) {
- $attributes_string .= $html5_script_support ? sprintf( ' %1$s="%2$s"', esc_attr( $attribute_name ), esc_attr( $attribute_name ) ) : ' ' . esc_attr( $attribute_name );
- }
- } else {
- $attributes_string .= sprintf( ' %1$s="%2$s"', esc_attr( $attribute_name ), esc_attr( $attribute_value ) );
- }
- }
- return $attributes_string;
- }
- /**
- * Formats `<script>` loader tags.
- *
- * It is possible to inject attributes in the `<script>` tag via the {@see 'wp_script_attributes'} filter.
- * Automatically injects type attribute if needed.
- *
- * @since 5.7.0
- *
- * @param array $attributes Key-value pairs representing `<script>` tag attributes.
- * @return string String containing `<script>` opening and closing tags.
- */
- function wp_get_script_tag( $attributes ) {
- if ( ! isset( $attributes['type'] ) && ! is_admin() && ! current_theme_supports( 'html5', 'script' ) ) {
- $attributes['type'] = 'text/javascript';
- }
- /**
- * Filters attributes to be added to a script tag.
- *
- * @since 5.7.0
- *
- * @param array $attributes Key-value pairs representing `<script>` tag attributes.
- * Only the attribute name is added to the `<script>` tag for
- * entries with a boolean value, and that are true.
- */
- $attributes = apply_filters( 'wp_script_attributes', $attributes );
- return sprintf( "<script%s></script>\n", wp_sanitize_script_attributes( $attributes ) );
- }
- /**
- * Prints formatted `<script>` loader tag.
- *
- * It is possible to inject attributes in the `<script>` tag via the {@see 'wp_script_attributes'} filter.
- * Automatically injects type attribute if needed.
- *
- * @since 5.7.0
- *
- * @param array $attributes Key-value pairs representing `<script>` tag attributes.
- */
- function wp_print_script_tag( $attributes ) {
- echo wp_get_script_tag( $attributes );
- }
- /**
- * Wraps inline JavaScript in `<script>` tag.
- *
- * It is possible to inject attributes in the `<script>` tag via the {@see 'wp_script_attributes'} filter.
- * Automatically injects type attribute if needed.
- *
- * @since 5.7.0
- *
- * @param string $javascript Inline JavaScript code.
- * @param array $attributes Optional. Key-value pairs representing `<script>` tag attributes.
- * @return string String containing inline JavaScript code wrapped around `<script>` tag.
- */
- function wp_get_inline_script_tag( $javascript, $attributes = array() ) {
- if ( ! isset( $attributes['type'] ) && ! is_admin() && ! current_theme_supports( 'html5', 'script' ) ) {
- $attributes['type'] = 'text/javascript';
- }
- /**
- * Filters attributes to be added to a script tag.
- *
- * @since 5.7.0
- *
- * @param array $attributes Key-value pairs representing `<script>` tag attributes.
- * Only the attribute name is added to the `<script>` tag for
- * entries with a boolean value, and that are true.
- * @param string $javascript Inline JavaScript code.
- */
- $attributes = apply_filters( 'wp_inline_script_attributes', $attributes, $javascript );
- $javascript = "\n" . trim( $javascript, "\n\r " ) . "\n";
- return sprintf( "<script%s>%s</script>\n", wp_sanitize_script_attributes( $attributes ), $javascript );
- }
- /**
- * Prints inline JavaScript wrapped in `<script>` tag.
- *
- * It is possible to inject attributes in the `<script>` tag via the {@see 'wp_script_attributes'} filter.
- * Automatically injects type attribute if needed.
- *
- * @since 5.7.0
- *
- * @param string $javascript Inline JavaScript code.
- * @param array $attributes Optional. Key-value pairs representing `<script>` tag attributes.
- */
- function wp_print_inline_script_tag( $javascript, $attributes = array() ) {
- echo wp_get_inline_script_tag( $javascript, $attributes );
- }
- /**
- * Allows small styles to be inlined.
- *
- * This improves performance and sustainability, and is opt-in. Stylesheets can opt in
- * by adding `path` data using `wp_style_add_data`, and defining the file's absolute path:
- *
- * wp_style_add_data( $style_handle, 'path', $file_path );
- *
- * @since 5.8.0
- *
- * @global WP_Styles $wp_styles
- */
- function wp_maybe_inline_styles() {
- global $wp_styles;
- $total_inline_limit = 20000;
- /**
- * The maximum size of inlined styles in bytes.
- *
- * @since 5.8.0
- *
- * @param int $total_inline_limit The file-size threshold, in bytes. Default 20000.
- */
- $total_inline_limit = apply_filters( 'styles_inline_size_limit', $total_inline_limit );
- $styles = array();
- // Build an array of styles that have a path defined.
- foreach ( $wp_styles->queue as $handle ) {
- if ( wp_styles()->get_data( $handle, 'path' ) && file_exists( $wp_styles->registered[ $handle ]->extra['path'] ) ) {
- $styles[] = array(
- 'handle' => $handle,
- 'src' => $wp_styles->registered[ $handle ]->src,
- 'path' => $wp_styles->registered[ $handle ]->extra['path'],
- 'size' => filesize( $wp_styles->registered[ $handle ]->extra['path'] ),
- );
- }
- }
- if ( ! empty( $styles ) ) {
- // Reorder styles array based on size.
- usort(
- $styles,
- static function( $a, $b ) {
- return ( $a['size'] <= $b['size'] ) ? -1 : 1;
- }
- );
- /*
- * The total inlined size.
- *
- * On each iteration of the loop, if a style gets added inline the value of this var increases
- * to reflect the total size of inlined styles.
- */
- $total_inline_size = 0;
- // Loop styles.
- foreach ( $styles as $style ) {
- // Size check. Since styles are ordered by size, we can break the loop.
- if ( $total_inline_size + $style['size'] > $total_inline_limit ) {
- break;
- }
- // Get the styles if we don't already have them.
- $style['css'] = file_get_contents( $style['path'] );
- // Check if the style contains relative URLs that need to be modified.
- // URLs relative to the stylesheet's path should be converted to relative to the site's root.
- $style['css'] = _wp_normalize_relative_css_links( $style['css'], $style['src'] );
- // Set `src` to `false` and add styles inline.
- $wp_styles->registered[ $style['handle'] ]->src = false;
- if ( empty( $wp_styles->registered[ $style['handle'] ]->extra['after'] ) ) {
- $wp_styles->registered[ $style['handle'] ]->extra['after'] = array();
- }
- array_unshift( $wp_styles->registered[ $style['handle'] ]->extra['after'], $style['css'] );
- // Add the styles size to the $total_inline_size var.
- $total_inline_size += (int) $style['size'];
- }
- }
- }
- /**
- * Makes URLs relative to the WordPress installation.
- *
- * @since 5.9.0
- * @access private
- *
- * @param string $css The CSS to make URLs relative to the WordPress installation.
- * @param string $stylesheet_url The URL to the stylesheet.
- *
- * @return string The CSS with URLs made relative to the WordPress installation.
- */
- function _wp_normalize_relative_css_links( $css, $stylesheet_url ) {
- $has_src_results = preg_match_all( '#url\s*\(\s*[\'"]?\s*([^\'"\)]+)#', $css, $src_results );
- if ( $has_src_results ) {
- // Loop through the URLs to find relative ones.
- foreach ( $src_results[1] as $src_index => $src_result ) {
- // Skip if this is an absolute URL.
- if ( 0 === strpos( $src_result, 'http' ) || 0 === strpos( $src_result, '//' ) ) {
- continue;
- }
- // Skip if the URL is an HTML ID.
- if ( str_starts_with( $src_result, '#' ) ) {
- continue;
- }
- // Skip if the URL is a data URI.
- if ( str_starts_with( $src_result, 'data:' ) ) {
- continue;
- }
- // Build the absolute URL.
- $absolute_url = dirname( $stylesheet_url ) . '/' . $src_result;
- $absolute_url = str_replace( '/./', '/', $absolute_url );
- // Convert to URL related to the site root.
- $relative_url = wp_make_link_relative( $absolute_url );
- // Replace the URL in the CSS.
- $css = str_replace(
- $src_results[0][ $src_index ],
- str_replace( $src_result, $relative_url, $src_results[0][ $src_index ] ),
- $css
- );
- }
- }
- return $css;
- }
- /**
- * Function that enqueues the CSS Custom Properties coming from theme.json.
- *
- * @since 5.9.0
- */
- function wp_enqueue_global_styles_css_custom_properties() {
- wp_register_style( 'global-styles-css-custom-properties', false, array(), true, true );
- wp_add_inline_style( 'global-styles-css-custom-properties', wp_get_global_stylesheet( array( 'variables' ) ) );
- wp_enqueue_style( 'global-styles-css-custom-properties' );
- }
- /**
- * Hooks inline styles in the proper place, depending on the active theme.
- *
- * @since 5.9.1
- * @since 6.1.0 Added the `$priority` parameter.
- *
- * For block themes, styles are loaded in the head.
- * For classic ones, styles are loaded in the body because the wp_head action happens before render_block.
- *
- * @link https://core.trac.wordpress.org/ticket/53494.
- *
- * @param string $style String containing the CSS styles to be added.
- * @param int $priority To set the priority for the add_action.
- */
- function wp_enqueue_block_support_styles( $style, $priority = 10 ) {
- $action_hook_name = 'wp_footer';
- if ( wp_is_block_theme() ) {
- $action_hook_name = 'wp_head';
- }
- add_action(
- $action_hook_name,
- static function () use ( $style ) {
- echo "<style>$style</style>\n";
- },
- $priority
- );
- }
- /**
- * Fetches, processes and compiles stored core styles, then combines and renders them to the page.
- * Styles are stored via the style engine API.
- *
- * @link https://developer.wordpress.org/block-editor/reference-guides/packages/packages-style-engine/
- *
- * @since 6.1.0
- *
- * @param array $options {
- * Optional. An array of options to pass to wp_style_engine_get_stylesheet_from_context(). Default empty array.
- *
- * @type bool $optimize Whether to optimize the CSS output, e.g., combine rules. Default is `false`.
- * @type bool $prettify Whether to add new lines and indents to output. Default is the test of whether the global constant `SCRIPT_DEBUG` is defined.
- * }
- *
- * @return void
- */
- function wp_enqueue_stored_styles( $options = array() ) {
- $is_block_theme = wp_is_block_theme();
- $is_classic_theme = ! $is_block_theme;
- /*
- * For block themes, this function prints stored styles in the header.
- * For classic themes, in the footer.
- */
- if (
- ( $is_block_theme && doing_action( 'wp_footer' ) ) ||
- ( $is_classic_theme && doing_action( 'wp_enqueue_scripts' ) )
- ) {
- return;
- }
- $core_styles_keys = array( 'block-supports' );
- $compiled_core_stylesheet = '';
- $style_tag_id = 'core';
- // Adds comment if code is prettified to identify core styles sections in debugging.
- $should_prettify = isset( $options['prettify'] ) ? true === $options['prettify'] : defined( 'SCRIPT_DEBUG' ) && SCRIPT_DEBUG;
- foreach ( $core_styles_keys as $style_key ) {
- if ( $should_prettify ) {
- $compiled_core_stylesheet .= "/**\n * Core styles: $style_key\n */\n";
- }
- // Chains core store ids to signify what the styles contain.
- $style_tag_id .= '-' . $style_key;
- $compiled_core_stylesheet .= wp_style_engine_get_stylesheet_from_context( $style_key, $options );
- }
- // Combines Core styles.
- if ( ! empty( $compiled_core_stylesheet ) ) {
- wp_register_style( $style_tag_id, false, array(), true, true );
- wp_add_inline_style( $style_tag_id, $compiled_core_stylesheet );
- wp_enqueue_style( $style_tag_id );
- }
- // Prints out any other stores registered by themes or otherwise.
- $additional_stores = WP_Style_Engine_CSS_Rules_Store::get_stores();
- foreach ( array_keys( $additional_stores ) as $store_name ) {
- if ( in_array( $store_name, $core_styles_keys, true ) ) {
- continue;
- }
- $styles = wp_style_engine_get_stylesheet_from_context( $store_name, $options );
- if ( ! empty( $styles ) ) {
- $key = "wp-style-engine-$store_name";
- wp_register_style( $key, false, array(), true, true );
- wp_add_inline_style( $key, $styles );
- wp_enqueue_style( $key );
- }
- }
- }
- /**
- * Enqueues a stylesheet for a specific block.
- *
- * If the theme has opted-in to separate-styles loading,
- * then the stylesheet will be enqueued on-render,
- * otherwise when the block inits.
- *
- * @since 5.9.0
- *
- * @param string $block_name The block-name, including namespace.
- * @param array $args An array of arguments [handle,src,deps,ver,media].
- */
- function wp_enqueue_block_style( $block_name, $args ) {
- $args = wp_parse_args(
- $args,
- array(
- 'handle' => '',
- 'src' => '',
- 'deps' => array(),
- 'ver' => false,
- 'media' => 'all',
- )
- );
- /**
- * Callback function to register and enqueue styles.
- *
- * @param string $content When the callback is used for the render_block filter,
- * the content needs to be returned so the function parameter
- * is to ensure the content exists.
- * @return string Block content.
- */
- $callback = static function( $content ) use ( $args ) {
- // Register the stylesheet.
- if ( ! empty( $args['src'] ) ) {
- wp_register_style( $args['handle'], $args['src'], $args['deps'], $args['ver'], $args['media'] );
- }
- // Add `path` data if provided.
- if ( isset( $args['path'] ) ) {
- wp_style_add_data( $args['handle'], 'path', $args['path'] );
- // Get the RTL file path.
- $rtl_file_path = str_replace( '.css', '-rtl.css', $args['path'] );
- // Add RTL stylesheet.
- if ( file_exists( $rtl_file_path ) ) {
- wp_style_add_data( $args['handle'], 'rtl', 'replace' );
- if ( is_rtl() ) {
- wp_style_add_data( $args['handle'], 'path', $rtl_file_path );
- }
- }
- }
- // Enqueue the stylesheet.
- wp_enqueue_style( $args['handle'] );
- return $content;
- };
- $hook = did_action( 'wp_enqueue_scripts' ) ? 'wp_footer' : 'wp_enqueue_scripts';
- if ( wp_should_load_separate_core_block_assets() ) {
- /**
- * Callback function to register and enqueue styles.
- *
- * @param string $content The block content.
- * @param array $block The full block, including name and attributes.
- * @return string Block content.
- */
- $callback_separate = static function( $content, $block ) use ( $block_name, $callback ) {
- if ( ! empty( $block['blockName'] ) && $block_name === $block['blockName'] ) {
- return $callback( $content );
- }
- return $content;
- };
- /*
- * The filter's callback here is an anonymous function because
- * using a named function in this case is not possible.
- *
- * The function cannot be unhooked, however, users are still able
- * to dequeue the stylesheets registered/enqueued by the callback
- * which is why in this case, using an anonymous function
- * was deemed acceptable.
- */
- add_filter( 'render_block', $callback_separate, 10, 2 );
- return;
- }
- /*
- * The filter's callback here is an anonymous function because
- * using a named function in this case is not possible.
- *
- * The function cannot be unhooked, however, users are still able
- * to dequeue the stylesheets registered/enqueued by the callback
- * which is why in this case, using an anonymous function
- * was deemed acceptable.
- */
- add_filter( $hook, $callback );
- // Enqueue assets in the editor.
- add_action( 'enqueue_block_assets', $callback );
- }
- /**
- * Runs the theme.json webfonts handler.
- *
- * Using `WP_Theme_JSON_Resolver`, it gets the fonts defined
- * in the `theme.json` for the current selection and style
- * variations, validates the font-face properties, generates
- * the '@font-face' style declarations, and then enqueues the
- * styles for both the editor and front-end.
- *
- * Design Notes:
- * This is not a public API, but rather an internal handler.
- * A future public Webfonts API will replace this stopgap code.
- *
- * This code design is intentional.
- * a. It hides the inner-workings.
- * b. It does not expose API ins or outs for consumption.
- * c. It only works with a theme's `theme.json`.
- *
- * Why?
- * a. To avoid backwards-compatibility issues when
- * the Webfonts API is introduced in Core.
- * b. To make `fontFace` declarations in `theme.json` work.
- *
- * @link https://github.com/WordPress/gutenberg/issues/40472
- *
- * @since 6.0.0
- * @access private
- */
- function _wp_theme_json_webfonts_handler() {
- // Block themes are unavailable during installation.
- if ( wp_installing() ) {
- return;
- }
- // Webfonts to be processed.
- $registered_webfonts = array();
- /**
- * Gets the webfonts from theme.json.
- *
- * @since 6.0.0
- *
- * @return array Array of defined webfonts.
- */
- $fn_get_webfonts_from_theme_json = static function() {
- // Get settings from theme.json.
- $settings = WP_Theme_JSON_Resolver::get_merged_data()->get_settings();
- // If in the editor, add webfonts defined in variations.
- if ( is_admin() || ( defined( 'REST_REQUEST' ) && REST_REQUEST ) ) {
- $variations = WP_Theme_JSON_Resolver::get_style_variations();
- foreach ( $variations as $variation ) {
- // Skip if fontFamilies are not defined in the variation.
- if ( empty( $variation['settings']['typography']['fontFamilies'] ) ) {
- continue;
- }
- // Initialize the array structure.
- if ( empty( $settings['typography'] ) ) {
- $settings['typography'] = array();
- }
- if ( empty( $settings['typography']['fontFamilies'] ) ) {
- $settings['typography']['fontFamilies'] = array();
- }
- if ( empty( $settings['typography']['fontFamilies']['theme'] ) ) {
- $settings['typography']['fontFamilies']['theme'] = array();
- }
- // Combine variations with settings. Remove duplicates.
- $settings['typography']['fontFamilies']['theme'] = array_merge( $settings['typography']['fontFamilies']['theme'], $variation['settings']['typography']['fontFamilies']['theme'] );
- $settings['typography']['fontFamilies'] = array_unique( $settings['typography']['fontFamilies'] );
- }
- }
- // Bail out early if there are no settings for webfonts.
- if ( empty( $settings['typography']['fontFamilies'] ) ) {
- return array();
- }
- $webfonts = array();
- // Look for fontFamilies.
- foreach ( $settings['typography']['fontFamilies'] as $font_families ) {
- foreach ( $font_families as $font_family ) {
- // Skip if fontFace is not defined.
- if ( empty( $font_family['fontFace'] ) ) {
- continue;
- }
- // Skip if fontFace is not an array of webfonts.
- if ( ! is_array( $font_family['fontFace'] ) ) {
- continue;
- }
- $webfonts = array_merge( $webfonts, $font_family['fontFace'] );
- }
- }
- return $webfonts;
- };
- /**
- * Transforms each 'src' into an URI by replacing 'file:./'
- * placeholder from theme.json.
- *
- * The absolute path to the webfont file(s) cannot be defined in
- * theme.json. `file:./` is the placeholder which is replaced by
- * the theme's URL path to the theme's root.
- *
- * @since 6.0.0
- *
- * @param array $src Webfont file(s) `src`.
- * @return array Webfont's `src` in URI.
- */
- $fn_transform_src_into_uri = static function( array $src ) {
- foreach ( $src as $key => $url ) {
- // Tweak the URL to be relative to the theme root.
- if ( ! str_starts_with( $url, 'file:./' ) ) {
- continue;
- }
- $src[ $key ] = get_theme_file_uri( str_replace( 'file:./', '', $url ) );
- }
- return $src;
- };
- /**
- * Converts the font-face properties (i.e. keys) into kebab-case.
- *
- * @since 6.0.0
- *
- * @param array $font_face Font face to convert.
- * @return array Font faces with each property in kebab-case format.
- */
- $fn_convert_keys_to_kebab_case = static function( array $font_face ) {
- foreach ( $font_face as $property => $value ) {
- $kebab_case = _wp_to_kebab_case( $property );
- $font_face[ $kebab_case ] = $value;
- if ( $kebab_case !== $property ) {
- unset( $font_face[ $property ] );
- }
- }
- return $font_face;
- };
- /**
- * Validates a webfont.
- *
- * @since 6.0.0
- *
- * @param array $webfont The webfont arguments.
- * @return array|false The validated webfont arguments, or false if the webfont is invalid.
- */
- $fn_validate_webfont = static function( $webfont ) {
- $webfont = wp_parse_args(
- $webfont,
- array(
- 'font-family' => '',
- 'font-style' => 'normal',
- 'font-weight' => '400',
- 'font-display' => 'fallback',
- 'src' => array(),
- )
- );
- // Check the font-family.
- if ( empty( $webfont['font-family'] ) || ! is_string( $webfont['font-family'] ) ) {
- trigger_error( __( 'Webfont font family must be a non-empty string.' ) );
- return false;
- }
- // Check that the `src` property is defined and a valid type.
- if ( empty( $webfont['src'] ) || ( ! is_string( $webfont['src'] ) && ! is_array( $webfont['src'] ) ) ) {
- trigger_error( __( 'Webfont src must be a non-empty string or an array of strings.' ) );
- return false;
- }
- // Validate the `src` property.
- foreach ( (array) $webfont['src'] as $src ) {
- if ( ! is_string( $src ) || '' === trim( $src ) ) {
- trigger_error( __( 'Each webfont src must be a non-empty string.' ) );
- return false;
- }
- }
- // Check the font-weight.
- if ( ! is_string( $webfont['font-weight'] ) && ! is_int( $webfont['font-weight'] ) ) {
- trigger_error( __( 'Webfont font weight must be a properly formatted string or integer.' ) );
- return false;
- }
- // Check the font-display.
- if ( ! in_array( $webfont['font-display'], array( 'auto', 'block', 'fallback', 'swap' ), true ) ) {
- $webfont['font-display'] = 'fallback';
- }
- $valid_props = array(
- 'ascend-override',
- 'descend-override',
- 'font-display',
- 'font-family',
- 'font-stretch',
- 'font-style',
- 'font-weight',
- 'font-variant',
- 'font-feature-settings',
- 'font-variation-settings',
- 'line-gap-override',
- 'size-adjust',
- 'src',
- 'unicode-range',
- );
- foreach ( $webfont as $prop => $value ) {
- if ( ! in_array( $prop, $valid_props, true ) ) {
- unset( $webfont[ $prop ] );
- }
- }
- return $webfont;
- };
- /**
- * Registers webfonts declared in theme.json.
- *
- * @since 6.0.0
- *
- * @uses $registered_webfonts To access and update the registered webfonts registry (passed by reference).
- * @uses $fn_get_webfonts_from_theme_json To run the function that gets the webfonts from theme.json.
- * @uses $fn_convert_keys_to_kebab_case To run the function that converts keys into kebab-case.
- * @uses $fn_validate_webfont To run the function that validates each font-face (webfont) from theme.json.
- */
- $fn_register_webfonts = static function() use ( &$registered_webfonts, $fn_get_webfonts_from_theme_json, $fn_convert_keys_to_kebab_case, $fn_validate_webfont, $fn_transform_src_into_uri ) {
- $registered_webfonts = array();
- foreach ( $fn_get_webfonts_from_theme_json() as $webfont ) {
- if ( ! is_array( $webfont ) ) {
- continue;
- }
- $webfont = $fn_convert_keys_to_kebab_case( $webfont );
- $webfont = $fn_validate_webfont( $webfont );
- $webfont['src'] = $fn_transform_src_into_uri( (array) $webfont['src'] );
- // Skip if not valid.
- if ( empty( $webfont ) ) {
- continue;
- }
- $registered_webfonts[] = $webfont;
- }
- };
- /**
- * Orders 'src' items to optimize for browser support.
- *
- * @since 6.0.0
- *
- * @param array $webfont Webfont to process.
- * @return array Ordered `src` items.
- */
- $fn_order_src = static function( array $webfont ) {
- $src = array();
- $src_ordered = array();
- foreach ( $webfont['src'] as $url ) {
- // Add data URIs first.
- if ( str_starts_with( trim( $url ), 'data:' ) ) {
- $src_ordered[] = array(
- 'url' => $url,
- 'format' => 'data',
- );
- continue;
- }
- $format = pathinfo( $url, PATHINFO_EXTENSION );
- $src[ $format ] = $url;
- }
- // Add woff2.
- if ( ! empty( $src['woff2'] ) ) {
- $src_ordered[] = array(
- 'url' => sanitize_url( $src['woff2'] ),
- 'format' => 'woff2',
- );
- }
- // Add woff.
- if ( ! empty( $src['woff'] ) ) {
- $src_ordered[] = array(
- 'url' => sanitize_url( $src['woff'] ),
- 'format' => 'woff',
- );
- }
- // Add ttf.
- if ( ! empty( $src['ttf'] ) ) {
- $src_ordered[] = array(
- 'url' => sanitize_url( $src['ttf'] ),
- 'format' => 'truetype',
- );
- }
- // Add eot.
- if ( ! empty( $src['eot'] ) ) {
- $src_ordered[] = array(
- 'url' => sanitize_url( $src['eot'] ),
- 'format' => 'embedded-opentype',
- );
- }
- // Add otf.
- if ( ! empty( $src['otf'] ) ) {
- $src_ordered[] = array(
- 'url' => sanitize_url( $src['otf'] ),
- 'format' => 'opentype',
- );
- }
- $webfont['src'] = $src_ordered;
- return $webfont;
- };
- /**
- * Compiles the 'src' into valid CSS.
- *
- * @since 6.0.0
- *
- * @param string $font_family Font family.
- * @param array $value Value to process.
- * @return string The CSS.
- */
- $fn_compile_src = static function( $font_family, array $value ) {
- $src = "local($font_family)";
- foreach ( $value as $item ) {
- if (
- str_starts_with( $item['url'], site_url() ) ||
- str_starts_with( $item['url'], home_url() )
- ) {
- $item['url'] = wp_make_link_relative( $item['url'] );
- }
- $src .= ( 'data' === $item['format'] )
- ? ", url({$item['url']})"
- : ", url('{$item['url']}') format('{$item['format']}')";
- }
- return $src;
- };
- /**
- * Compiles the font variation settings.
- *
- * @since 6.0.0
- *
- * @param array $font_variation_settings Array of font variation settings.
- * @return string The CSS.
- */
- $fn_compile_variations = static function( array $font_variation_settings ) {
- $variations = '';
- foreach ( $font_variation_settings as $key => $value ) {
- $variations .= "$key $value";
- }
- return $variations;
- };
- /**
- * Builds the font-family's CSS.
- *
- * @since 6.0.0
- *
- * @uses $fn_compile_src To run the function that compiles the src.
- * @uses $fn_compile_variations To run the function that compiles the variations.
- *
- * @param array $webfont Webfont to process.
- * @return string This font-family's CSS.
- */
- $fn_build_font_face_css = static function( array $webfont ) use ( $fn_compile_src, $fn_compile_variations ) {
- $css = '';
- // Wrap font-family in quotes if it contains spaces.
- if (
- str_contains( $webfont['font-family'], ' ' ) &&
- ! str_contains( $webfont['font-family'], '"' ) &&
- ! str_contains( $webfont['font-family'], "'" )
- ) {
- $webfont['font-family'] = '"' . $webfont['font-family'] . '"';
- }
- foreach ( $webfont as $key => $value ) {
- /*
- * Skip "provider", since it's for internal API use,
- * and not a valid CSS property.
- */
- if ( 'provider' === $key ) {
- continue;
- }
- // Compile the "src" parameter.
- if ( 'src' === $key ) {
- $value = $fn_compile_src( $webfont['font-family'], $value );
- }
- // If font-variation-settings is an array, convert it to a string.
- if ( 'font-variation-settings' === $key && is_array( $value ) ) {
- $value = $fn_compile_variations( $value );
- }
- if ( ! empty( $value ) ) {
- $css .= "$key:$value;";
- }
- }
- return $css;
- };
- /**
- * Gets the '@font-face' CSS styles for locally-hosted font files.
- *
- * @since 6.0.0
- *
- * @uses $registered_webfonts To access and update the registered webfonts registry (passed by reference).
- * @uses $fn_order_src To run the function that orders the src.
- * @uses $fn_build_font_face_css To run the function that builds the font-face CSS.
- *
- * @return string The `@font-face` CSS.
- */
- $fn_get_css = static function() use ( &$registered_webfonts, $fn_order_src, $fn_build_font_face_css ) {
- $css = '';
- foreach ( $registered_webfonts as $webfont ) {
- // Order the webfont's `src` items to optimize for browser support.
- $webfont = $fn_order_src( $webfont );
- // Build the @font-face CSS for this webfont.
- $css .= '@font-face{' . $fn_build_font_face_css( $webfont ) . '}';
- }
- return $css;
- };
- /**
- * Generates and enqueues webfonts styles.
- *
- * @since 6.0.0
- *
- * @uses $fn_get_css To run the function that gets the CSS.
- */
- $fn_generate_and_enqueue_styles = static function() use ( $fn_get_css ) {
- // Generate the styles.
- $styles = $fn_get_css();
- // Bail out if there are no styles to enqueue.
- if ( '' === $styles ) {
- return;
- }
- // Enqueue the stylesheet.
- wp_register_style( 'wp-webfonts', '' );
- wp_enqueue_style( 'wp-webfonts' );
- // Add the styles to the stylesheet.
- wp_add_inline_style( 'wp-webfonts', $styles );
- };
- /**
- * Generates and enqueues editor styles.
- *
- * @since 6.0.0
- *
- * @uses $fn_get_css To run the function that gets the CSS.
- */
- $fn_generate_and_enqueue_editor_styles = static function() use ( $fn_get_css ) {
- // Generate the styles.
- $styles = $fn_get_css();
- // Bail out if there are no styles to enqueue.
- if ( '' === $styles ) {
- return;
- }
- wp_add_inline_style( 'wp-block-library', $styles );
- };
- add_action( 'wp_loaded', $fn_register_webfonts );
- add_action( 'wp_enqueue_scripts', $fn_generate_and_enqueue_styles );
- add_action( 'admin_init', $fn_generate_and_enqueue_editor_styles );
- }
- /**
- * Loads classic theme styles on classic themes in the frontend.
- *
- * This is needed for backwards compatibility for button blocks specifically.
- *
- * @since 6.1.0
- */
- function wp_enqueue_classic_theme_styles() {
- if ( ! WP_Theme_JSON_Resolver::theme_has_support() ) {
- $suffix = wp_scripts_get_suffix();
- wp_register_style( 'classic-theme-styles', '/' . WPINC . "/css/classic-themes$suffix.css", array(), true );
- wp_enqueue_style( 'classic-theme-styles' );
- }
- }
- /**
- * Loads classic theme styles on classic themes in the editor.
- *
- * This is needed for backwards compatibility for button blocks specifically.
- *
- * @since 6.1.0
- *
- * @param array $editor_settings The array of editor settings.
- * @return array A filtered array of editor settings.
- */
- function wp_add_editor_classic_theme_styles( $editor_settings ) {
- if ( WP_Theme_JSON_Resolver::theme_has_support() ) {
- return $editor_settings;
- }
- $suffix = wp_scripts_get_suffix();
- $classic_theme_styles = ABSPATH . WPINC . "/css/classic-themes$suffix.css";
- // This follows the pattern of get_block_editor_theme_styles,
- // but we can't use get_block_editor_theme_styles directly as it
- // only handles external files or theme files.
- $classic_theme_styles_settings = array(
- 'css' => file_get_contents( $classic_theme_styles ),
- '__unstableType' => 'core',
- 'isGlobalStyles' => false,
- );
- // Add these settings to the start of the array so that themes can override them.
- array_unshift( $editor_settings['styles'], $classic_theme_styles_settings );
- return $editor_settings;
- }
|