| [ Index ] |
PHP Cross Reference of WordPress Trunk (Updated Daily) |
[Summary view] [Print] [Text view]
1 var __create = Object.create; 2 var __defProp = Object.defineProperty; 3 var __getOwnPropDesc = Object.getOwnPropertyDescriptor; 4 var __getOwnPropNames = Object.getOwnPropertyNames; 5 var __getProtoOf = Object.getPrototypeOf; 6 var __hasOwnProp = Object.prototype.hasOwnProperty; 7 var __commonJS = (cb, mod) => function __require() { 8 return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports; 9 }; 10 var __export = (target, all) => { 11 for (var name in all) 12 __defProp(target, name, { get: all[name], enumerable: true }); 13 }; 14 var __copyProps = (to, from, except, desc) => { 15 if (from && typeof from === "object" || typeof from === "function") { 16 for (let key of __getOwnPropNames(from)) 17 if (!__hasOwnProp.call(to, key) && key !== except) 18 __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); 19 } 20 return to; 21 }; 22 var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( 23 // If the importer is in node compatibility mode or this is not an ESM 24 // file that has been converted to a CommonJS file using a Babel- 25 // compatible transform (i.e. "__esModule" has not been set), then set 26 // "default" to the CommonJS "module.exports" for node compatibility. 27 isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, 28 mod 29 )); 30 31 // package-external:@wordpress/element 32 var require_element = __commonJS({ 33 "package-external:@wordpress/element"(exports, module) { 34 module.exports = window.wp.element; 35 } 36 }); 37 38 // package-external:@wordpress/data 39 var require_data = __commonJS({ 40 "package-external:@wordpress/data"(exports, module) { 41 module.exports = window.wp.data; 42 } 43 }); 44 45 // package-external:@wordpress/i18n 46 var require_i18n = __commonJS({ 47 "package-external:@wordpress/i18n"(exports, module) { 48 module.exports = window.wp.i18n; 49 } 50 }); 51 52 // package-external:@wordpress/components 53 var require_components = __commonJS({ 54 "package-external:@wordpress/components"(exports, module) { 55 module.exports = window.wp.components; 56 } 57 }); 58 59 // vendor-external:react/jsx-runtime 60 var require_jsx_runtime = __commonJS({ 61 "vendor-external:react/jsx-runtime"(exports, module) { 62 module.exports = window.ReactJSXRuntime; 63 } 64 }); 65 66 // package-external:@wordpress/core-data 67 var require_core_data = __commonJS({ 68 "package-external:@wordpress/core-data"(exports, module) { 69 module.exports = window.wp.coreData; 70 } 71 }); 72 73 // package-external:@wordpress/commands 74 var require_commands = __commonJS({ 75 "package-external:@wordpress/commands"(exports, module) { 76 module.exports = window.wp.commands; 77 } 78 }); 79 80 // package-external:@wordpress/editor 81 var require_editor = __commonJS({ 82 "package-external:@wordpress/editor"(exports, module) { 83 module.exports = window.wp.editor; 84 } 85 }); 86 87 // package-external:@wordpress/compose 88 var require_compose = __commonJS({ 89 "package-external:@wordpress/compose"(exports, module) { 90 module.exports = window.wp.compose; 91 } 92 }); 93 94 // package-external:@wordpress/primitives 95 var require_primitives = __commonJS({ 96 "package-external:@wordpress/primitives"(exports, module) { 97 module.exports = window.wp.primitives; 98 } 99 }); 100 101 // package-external:@wordpress/html-entities 102 var require_html_entities = __commonJS({ 103 "package-external:@wordpress/html-entities"(exports, module) { 104 module.exports = window.wp.htmlEntities; 105 } 106 }); 107 108 // package-external:@wordpress/keycodes 109 var require_keycodes = __commonJS({ 110 "package-external:@wordpress/keycodes"(exports, module) { 111 module.exports = window.wp.keycodes; 112 } 113 }); 114 115 // package-external:@wordpress/url 116 var require_url = __commonJS({ 117 "package-external:@wordpress/url"(exports, module) { 118 module.exports = window.wp.url; 119 } 120 }); 121 122 // package-external:@wordpress/private-apis 123 var require_private_apis = __commonJS({ 124 "package-external:@wordpress/private-apis"(exports, module) { 125 module.exports = window.wp.privateApis; 126 } 127 }); 128 129 // package-external:@wordpress/keyboard-shortcuts 130 var require_keyboard_shortcuts = __commonJS({ 131 "package-external:@wordpress/keyboard-shortcuts"(exports, module) { 132 module.exports = window.wp.keyboardShortcuts; 133 } 134 }); 135 136 // package-external:@wordpress/theme 137 var require_theme = __commonJS({ 138 "package-external:@wordpress/theme"(exports, module) { 139 module.exports = window.wp.theme; 140 } 141 }); 142 143 // packages/boot/build-module/components/app/index.js 144 var import_element15 = __toESM(require_element()); 145 var import_data11 = __toESM(require_data()); 146 147 // packages/boot/build-module/components/app/router.js 148 var import_i18n11 = __toESM(require_i18n()); 149 var import_element14 = __toESM(require_element()); 150 151 // node_modules/clsx/dist/clsx.mjs 152 function r(e) { 153 var t, f, n = ""; 154 if ("string" == typeof e || "number" == typeof e) n += e; 155 else if ("object" == typeof e) if (Array.isArray(e)) { 156 var o = e.length; 157 for (t = 0; t < o; t++) e[t] && (f = r(e[t])) && (n && (n += " "), n += f); 158 } else for (f in e) e[f] && (n && (n += " "), n += f); 159 return n; 160 } 161 function clsx() { 162 for (var e, t, f = 0, n = "", o = arguments.length; f < o; f++) (e = arguments[f]) && (t = r(e)) && (n && (n += " "), n += t); 163 return n; 164 } 165 var clsx_default = clsx; 166 167 // packages/admin-ui/build-module/navigable-region/index.js 168 var import_element = __toESM(require_element()); 169 var import_jsx_runtime = __toESM(require_jsx_runtime()); 170 var NavigableRegion = (0, import_element.forwardRef)( 171 ({ children, className, ariaLabel, as: Tag = "div", ...props }, ref) => { 172 return /* @__PURE__ */ (0, import_jsx_runtime.jsx)( 173 Tag, 174 { 175 ref, 176 className: clsx_default("admin-ui-navigable-region", className), 177 "aria-label": ariaLabel, 178 role: "region", 179 tabIndex: "-1", 180 ...props, 181 children 182 } 183 ); 184 } 185 ); 186 NavigableRegion.displayName = "NavigableRegion"; 187 var navigable_region_default = NavigableRegion; 188 189 // packages/admin-ui/build-module/page/header.js 190 var import_components2 = __toESM(require_components()); 191 192 // packages/admin-ui/build-module/page/sidebar-toggle-slot.js 193 var import_components = __toESM(require_components()); 194 var { Fill: SidebarToggleFill, Slot: SidebarToggleSlot } = (0, import_components.createSlotFill)("SidebarToggle"); 195 196 // packages/admin-ui/build-module/page/header.js 197 var import_jsx_runtime2 = __toESM(require_jsx_runtime()); 198 function Header({ 199 breadcrumbs, 200 badges, 201 title, 202 subTitle, 203 actions, 204 showSidebarToggle = true 205 }) { 206 return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(import_components2.__experimentalVStack, { className: "admin-ui-page__header", as: "header", children: [ 207 /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(import_components2.__experimentalHStack, { justify: "space-between", spacing: 2, children: [ 208 /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(import_components2.__experimentalHStack, { spacing: 2, justify: "left", children: [ 209 showSidebarToggle && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)( 210 SidebarToggleSlot, 211 { 212 bubblesVirtually: true, 213 className: "admin-ui-page__sidebar-toggle-slot" 214 } 215 ), 216 title && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(import_components2.__experimentalHeading, { as: "h2", level: 3, weight: 500, truncate: true, children: title }), 217 breadcrumbs, 218 badges 219 ] }), 220 /* @__PURE__ */ (0, import_jsx_runtime2.jsx)( 221 import_components2.__experimentalHStack, 222 { 223 style: { width: "auto", flexShrink: 0 }, 224 spacing: 2, 225 className: "admin-ui-page__header-actions", 226 children: actions 227 } 228 ) 229 ] }), 230 subTitle && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("p", { className: "admin-ui-page__header-subtitle", children: subTitle }) 231 ] }); 232 } 233 234 // packages/admin-ui/build-module/page/index.js 235 var import_jsx_runtime3 = __toESM(require_jsx_runtime()); 236 function Page({ 237 breadcrumbs, 238 badges, 239 title, 240 subTitle, 241 children, 242 className, 243 actions, 244 hasPadding = false, 245 showSidebarToggle = true 246 }) { 247 const classes = clsx_default("admin-ui-page", className); 248 return /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)(navigable_region_default, { className: classes, ariaLabel: title, children: [ 249 (title || breadcrumbs || badges) && /* @__PURE__ */ (0, import_jsx_runtime3.jsx)( 250 Header, 251 { 252 breadcrumbs, 253 badges, 254 title, 255 subTitle, 256 actions, 257 showSidebarToggle 258 } 259 ), 260 hasPadding ? /* @__PURE__ */ (0, import_jsx_runtime3.jsx)("div", { className: "admin-ui-page__content has-padding", children }) : children 261 ] }); 262 } 263 Page.SidebarToggleFill = SidebarToggleFill; 264 var page_default = Page; 265 266 // packages/boot/build-module/components/app/router.js 267 var import_data10 = __toESM(require_data()); 268 var import_core_data6 = __toESM(require_core_data()); 269 import { 270 privateApis as routePrivateApis6 271 } from "@wordpress/route"; 272 273 // packages/boot/build-module/components/root/index.js 274 var import_commands2 = __toESM(require_commands()); 275 var import_editor4 = __toESM(require_editor()); 276 var import_compose4 = __toESM(require_compose()); 277 var import_components14 = __toESM(require_components()); 278 import { privateApis as routePrivateApis5 } from "@wordpress/route"; 279 280 // packages/icons/build-module/icon/index.js 281 var import_element2 = __toESM(require_element()); 282 var icon_default = (0, import_element2.forwardRef)( 283 ({ icon, size = 24, ...props }, ref) => { 284 return (0, import_element2.cloneElement)(icon, { 285 width: size, 286 height: size, 287 ...props, 288 ref 289 }); 290 } 291 ); 292 293 // packages/icons/build-module/library/arrow-up-left.js 294 var import_primitives = __toESM(require_primitives()); 295 var import_jsx_runtime4 = __toESM(require_jsx_runtime()); 296 var arrow_up_left_default = /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(import_primitives.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(import_primitives.Path, { d: "M14 6H6v8h1.5V8.5L17 18l1-1-9.5-9.5H14V6Z" }) }); 297 298 // packages/icons/build-module/library/check.js 299 var import_primitives2 = __toESM(require_primitives()); 300 var import_jsx_runtime5 = __toESM(require_jsx_runtime()); 301 var check_default = /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_primitives2.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_primitives2.Path, { d: "M16.5 7.5 10 13.9l-2.5-2.4-1 1 3.5 3.6 7.5-7.6z" }) }); 302 303 // packages/icons/build-module/library/chevron-down-small.js 304 var import_primitives3 = __toESM(require_primitives()); 305 var import_jsx_runtime6 = __toESM(require_jsx_runtime()); 306 var chevron_down_small_default = /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(import_primitives3.SVG, { viewBox: "0 0 24 24", xmlns: "http://www.w3.org/2000/svg", children: /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(import_primitives3.Path, { d: "m15.99 10.889-3.988 3.418-3.988-3.418.976-1.14 3.012 2.582 3.012-2.581.976 1.139Z" }) }); 307 308 // packages/icons/build-module/library/chevron-left-small.js 309 var import_primitives4 = __toESM(require_primitives()); 310 var import_jsx_runtime7 = __toESM(require_jsx_runtime()); 311 var chevron_left_small_default = /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(import_primitives4.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(import_primitives4.Path, { d: "m13.1 16-3.4-4 3.4-4 1.1 1-2.6 3 2.6 3-1.1 1z" }) }); 312 313 // packages/icons/build-module/library/chevron-left.js 314 var import_primitives5 = __toESM(require_primitives()); 315 var import_jsx_runtime8 = __toESM(require_jsx_runtime()); 316 var chevron_left_default = /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(import_primitives5.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(import_primitives5.Path, { d: "M14.6 7l-1.2-1L8 12l5.4 6 1.2-1-4.6-5z" }) }); 317 318 // packages/icons/build-module/library/chevron-right-small.js 319 var import_primitives6 = __toESM(require_primitives()); 320 var import_jsx_runtime9 = __toESM(require_jsx_runtime()); 321 var chevron_right_small_default = /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_primitives6.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_primitives6.Path, { d: "M10.8622 8.04053L14.2805 12.0286L10.8622 16.0167L9.72327 15.0405L12.3049 12.0286L9.72327 9.01672L10.8622 8.04053Z" }) }); 322 323 // packages/icons/build-module/library/chevron-right.js 324 var import_primitives7 = __toESM(require_primitives()); 325 var import_jsx_runtime10 = __toESM(require_jsx_runtime()); 326 var chevron_right_default = /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(import_primitives7.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(import_primitives7.Path, { d: "M10.6 6L9.4 7l4.6 5-4.6 5 1.2 1 5.4-6z" }) }); 327 328 // packages/icons/build-module/library/menu.js 329 var import_primitives8 = __toESM(require_primitives()); 330 var import_jsx_runtime11 = __toESM(require_jsx_runtime()); 331 var menu_default = /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(import_primitives8.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(import_primitives8.Path, { d: "M5 5v1.5h14V5H5zm0 7.8h14v-1.5H5v1.5zM5 19h14v-1.5H5V19z" }) }); 332 333 // packages/icons/build-module/library/search.js 334 var import_primitives9 = __toESM(require_primitives()); 335 var import_jsx_runtime12 = __toESM(require_jsx_runtime()); 336 var search_default = /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_primitives9.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_primitives9.Path, { d: "M13 5c-3.3 0-6 2.7-6 6 0 1.4.5 2.7 1.3 3.7l-3.8 3.8 1.1 1.1 3.8-3.8c1 .8 2.3 1.3 3.7 1.3 3.3 0 6-2.7 6-6S16.3 5 13 5zm0 10.5c-2.5 0-4.5-2-4.5-4.5s2-4.5 4.5-4.5 4.5 2 4.5 4.5-2 4.5-4.5 4.5z" }) }); 337 338 // packages/icons/build-module/library/wordpress.js 339 var import_primitives10 = __toESM(require_primitives()); 340 var import_jsx_runtime13 = __toESM(require_jsx_runtime()); 341 var wordpress_default = /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(import_primitives10.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "-2 -2 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(import_primitives10.Path, { d: "M20 10c0-5.51-4.49-10-10-10C4.48 0 0 4.49 0 10c0 5.52 4.48 10 10 10 5.51 0 10-4.48 10-10zM7.78 15.37L4.37 6.22c.55-.02 1.17-.08 1.17-.08.5-.06.44-1.13-.06-1.11 0 0-1.45.11-2.37.11-.18 0-.37 0-.58-.01C4.12 2.69 6.87 1.11 10 1.11c2.33 0 4.45.87 6.05 2.34-.68-.11-1.65.39-1.65 1.58 0 .74.45 1.36.9 2.1.35.61.55 1.36.55 2.46 0 1.49-1.4 5-1.4 5l-3.03-8.37c.54-.02.82-.17.82-.17.5-.05.44-1.25-.06-1.22 0 0-1.44.12-2.38.12-.87 0-2.33-.12-2.33-.12-.5-.03-.56 1.2-.06 1.22l.92.08 1.26 3.41zM17.41 10c.24-.64.74-1.87.43-4.25.7 1.29 1.05 2.71 1.05 4.25 0 3.29-1.73 6.24-4.4 7.78.97-2.59 1.94-5.2 2.92-7.78zM6.1 18.09C3.12 16.65 1.11 13.53 1.11 10c0-1.3.23-2.48.72-3.59C3.25 10.3 4.67 14.2 6.1 18.09zm4.03-6.63l2.58 6.98c-.86.29-1.76.45-2.71.45-.79 0-1.57-.11-2.29-.33.81-2.38 1.62-4.74 2.42-7.1z" }) }); 342 343 // packages/boot/build-module/components/root/index.js 344 var import_element13 = __toESM(require_element()); 345 var import_i18n10 = __toESM(require_i18n()); 346 347 // packages/boot/build-module/components/site-hub/index.js 348 var import_data2 = __toESM(require_data()); 349 var import_components3 = __toESM(require_components()); 350 var import_i18n2 = __toESM(require_i18n()); 351 var import_core_data2 = __toESM(require_core_data()); 352 var import_html_entities = __toESM(require_html_entities()); 353 var import_keycodes = __toESM(require_keycodes()); 354 var import_commands = __toESM(require_commands()); 355 var import_url = __toESM(require_url()); 356 357 // packages/boot/build-module/components/site-icon-link/index.js 358 import { Link, privateApis as routePrivateApis } from "@wordpress/route"; 359 360 // packages/boot/build-module/lock-unlock.js 361 var import_private_apis = __toESM(require_private_apis()); 362 var { lock, unlock } = (0, import_private_apis.__dangerousOptInToUnstableAPIsOnlyForCoreModules)( 363 "I acknowledge private features are not for use in themes or plugins and doing so will break in the next version of WordPress.", 364 "@wordpress/boot" 365 ); 366 367 // packages/boot/build-module/components/site-icon/index.js 368 var import_data = __toESM(require_data()); 369 var import_i18n = __toESM(require_i18n()); 370 var import_core_data = __toESM(require_core_data()); 371 var import_jsx_runtime14 = __toESM(require_jsx_runtime()); 372 var css = `/** 373 * SCSS Variables. 374 * 375 * Please use variables from this sheet to ensure consistency across the UI. 376 * Don't add to this sheet unless you're pretty sure the value will be reused in many places. 377 * For example, don't add rules to this sheet that affect block visuals. It's purely for UI. 378 */ 379 /** 380 * Colors 381 */ 382 /** 383 * Fonts & basic variables. 384 */ 385 /** 386 * Typography 387 */ 388 /** 389 * Grid System. 390 * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/ 391 */ 392 /** 393 * Radius scale. 394 */ 395 /** 396 * Elevation scale. 397 */ 398 /** 399 * Dimensions. 400 */ 401 /** 402 * Mobile specific styles 403 */ 404 /** 405 * Editor styles. 406 */ 407 /** 408 * Block & Editor UI. 409 */ 410 /** 411 * Block paddings. 412 */ 413 /** 414 * React Native specific. 415 * These variables do not appear to be used anywhere else. 416 */ 417 .boot-site-icon { 418 display: flex; 419 } 420 421 .boot-site-icon__icon { 422 width: 32px; 423 height: 32px; 424 color: var(--wpds-color-fg-content-neutral, #1e1e1e); 425 } 426 427 .boot-site-icon__image { 428 width: 32px; 429 height: 32px; 430 object-fit: cover; 431 aspect-ratio: 1/1; 432 border-radius: var(--wpds-border-radius-surface-md, 4px); 433 } 434 /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/site-icon","sources":["../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../node_modules/@wordpress/base-styles/_colors.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEjKA;EACC;;;AAGD;EACC,OFkDc;EEjDd,QFiDc;EEhDd;;;AAGD;EACC,OF4Cc;EE3Cd,QF2Cc;EE1Cd;EACA;EACA","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","@use \"@wordpress/base-styles/variables\";\n\n.boot-site-icon {\n\tdisplay: flex;\n}\n\n.boot-site-icon__icon {\n\twidth: variables.$grid-unit-40;\n\theight: variables.$grid-unit-40;\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n}\n\n.boot-site-icon__image {\n\twidth: variables.$grid-unit-40;\n\theight: variables.$grid-unit-40;\n\tobject-fit: cover;\n\taspect-ratio: 1 / 1;\n\tborder-radius: var(--wpds-border-radius-surface-md, 4px);\n}\n"]} */`; 435 document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css)); 436 function SiteIcon({ className }) { 437 const { isRequestingSite, siteIconUrl } = (0, import_data.useSelect)((select) => { 438 const { getEntityRecord } = select(import_core_data.store); 439 const siteData = getEntityRecord( 440 "root", 441 "__unstableBase", 442 void 0 443 ); 444 return { 445 isRequestingSite: !siteData, 446 siteIconUrl: siteData?.site_icon_url 447 }; 448 }, []); 449 let icon = null; 450 if (isRequestingSite && !siteIconUrl) { 451 icon = /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("div", { className: "boot-site-icon__image" }); 452 } else { 453 icon = siteIconUrl ? /* @__PURE__ */ (0, import_jsx_runtime14.jsx)( 454 "img", 455 { 456 className: "boot-site-icon__image", 457 alt: (0, import_i18n.__)("Site Icon"), 458 src: siteIconUrl 459 } 460 ) : /* @__PURE__ */ (0, import_jsx_runtime14.jsx)( 461 icon_default, 462 { 463 className: "boot-site-icon__icon", 464 icon: wordpress_default, 465 size: 48 466 } 467 ); 468 } 469 return /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("div", { className: clsx_default(className, "boot-site-icon"), children: icon }); 470 } 471 var site_icon_default = SiteIcon; 472 473 // packages/boot/build-module/components/site-icon-link/index.js 474 var import_jsx_runtime15 = __toESM(require_jsx_runtime()); 475 var css2 = `/** 476 * SCSS Variables. 477 * 478 * Please use variables from this sheet to ensure consistency across the UI. 479 * Don't add to this sheet unless you're pretty sure the value will be reused in many places. 480 * For example, don't add rules to this sheet that affect block visuals. It's purely for UI. 481 */ 482 /** 483 * Colors 484 */ 485 /** 486 * Fonts & basic variables. 487 */ 488 /** 489 * Typography 490 */ 491 /** 492 * Grid System. 493 * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/ 494 */ 495 /** 496 * Radius scale. 497 */ 498 /** 499 * Elevation scale. 500 */ 501 /** 502 * Dimensions. 503 */ 504 /** 505 * Mobile specific styles 506 */ 507 /** 508 * Editor styles. 509 */ 510 /** 511 * Block & Editor UI. 512 */ 513 /** 514 * Block paddings. 515 */ 516 /** 517 * React Native specific. 518 * These variables do not appear to be used anywhere else. 519 */ 520 .boot-site-icon-link { 521 width: 64px; 522 height: 64px; 523 display: inline-flex; 524 align-items: center; 525 justify-content: center; 526 background: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0); 527 text-decoration: none; 528 } 529 @media not (prefers-reduced-motion) { 530 .boot-site-icon-link { 531 transition: outline 0.1s ease-out; 532 } 533 } 534 .boot-site-icon-link:focus:not(:active) { 535 outline: var(--wpds-border-width-interactive-focus, 2px) solid var(--wpds-color-stroke-focus-brand, #0073aa); 536 outline-offset: calc(-1 * var(--wpds-border-width-interactive-focus, 2px)); 537 } 538 /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/site-icon-link","sources":["../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../node_modules/@wordpress/base-styles/_colors.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AE/JA;EACC,OF8Fe;EE7Ff,QF6Fe;EE5Ff;EACA;EACA;EACA;EACA;;AAEA;EATD;IAUE;;;AAGD;EACC,SACC;EAED","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","@use \"@wordpress/base-styles/variables\";\n\n$header-height: variables.$header-height;\n\n.boot-site-icon-link {\n\twidth: $header-height;\n\theight: $header-height;\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n\tbackground: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);\n\ttext-decoration: none;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: outline 0.1s ease-out;\n\t}\n\n\t&:focus:not(:active) {\n\t\toutline:\n\t\t\tvar(--wpds-border-width-interactive-focus, 2px) solid\n\t\t\tvar(--wpds-color-stroke-focus-brand, #0073aa);\n\t\toutline-offset: calc(-1 * var(--wpds-border-width-interactive-focus, 2px));\n\t}\n}\n"]} */`; 539 document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css2)); 540 var { useCanGoBack, useRouter } = unlock(routePrivateApis); 541 function SiteIconLink({ 542 to, 543 isBackButton, 544 ...props 545 }) { 546 const router = useRouter(); 547 const canGoBack = useCanGoBack(); 548 return /* @__PURE__ */ (0, import_jsx_runtime15.jsx)( 549 Link, 550 { 551 to, 552 "aria-label": props["aria-label"], 553 className: "boot-site-icon-link", 554 onClick: (event) => { 555 if (canGoBack && isBackButton) { 556 event.preventDefault(); 557 router.history.back(); 558 } 559 }, 560 children: /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(site_icon_default, {}) 561 } 562 ); 563 } 564 var site_icon_link_default = SiteIconLink; 565 566 // packages/boot/build-module/components/site-hub/index.js 567 var import_jsx_runtime16 = __toESM(require_jsx_runtime()); 568 var css3 = `/** 569 * SCSS Variables. 570 * 571 * Please use variables from this sheet to ensure consistency across the UI. 572 * Don't add to this sheet unless you're pretty sure the value will be reused in many places. 573 * For example, don't add rules to this sheet that affect block visuals. It's purely for UI. 574 */ 575 /** 576 * Colors 577 */ 578 /** 579 * Fonts & basic variables. 580 */ 581 /** 582 * Typography 583 */ 584 /** 585 * Grid System. 586 * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/ 587 */ 588 /** 589 * Radius scale. 590 */ 591 /** 592 * Elevation scale. 593 */ 594 /** 595 * Dimensions. 596 */ 597 /** 598 * Mobile specific styles 599 */ 600 /** 601 * Editor styles. 602 */ 603 /** 604 * Block & Editor UI. 605 */ 606 /** 607 * Block paddings. 608 */ 609 /** 610 * React Native specific. 611 * These variables do not appear to be used anywhere else. 612 */ 613 .boot-site-hub { 614 position: sticky; 615 top: 0; 616 background-color: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0); 617 z-index: 1; 618 display: grid; 619 grid-template-columns: 60px 1fr auto; 620 align-items: center; 621 padding-right: 16px; 622 flex-shrink: 0; 623 } 624 625 .boot-site-hub__actions { 626 flex-shrink: 0; 627 } 628 629 .boot-site-hub__title { 630 display: flex; 631 align-items: center; 632 text-decoration: none; 633 } 634 .boot-site-hub__title .components-external-link__contents { 635 text-decoration: none; 636 margin-inline-start: 4px; 637 overflow: hidden; 638 max-width: 140px; 639 } 640 .boot-site-hub__title .components-external-link__icon { 641 opacity: 0; 642 transition: opacity 0.1s ease-out; 643 } 644 .boot-site-hub__title:hover .components-external-link__icon { 645 opacity: 1; 646 } 647 @media not (prefers-reduced-motion) { 648 .boot-site-hub__title { 649 transition: outline 0.1s ease-out; 650 } 651 } 652 .boot-site-hub__title:focus:not(:active) { 653 outline: var(--wpds-border-width-interactive-focus, 2px) solid var(--wpds-color-stroke-focus-brand, #0073aa); 654 outline-offset: calc(-1 * var(--wpds-border-width-interactive-focus, 2px)); 655 } 656 657 .boot-site-hub__title-text { 658 color: var(--wpds-color-fg-content-neutral, #1e1e1e); 659 font-size: 13px; 660 font-weight: 499; 661 overflow: hidden; 662 text-overflow: ellipsis; 663 white-space: nowrap; 664 } 665 666 .boot-site-hub__url { 667 color: var(--wpds-color-fg-content-neutral-weak, #757575); 668 font-size: 12px; 669 overflow: hidden; 670 text-overflow: ellipsis; 671 white-space: nowrap; 672 } 673 /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/site-hub","sources":["../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../node_modules/@wordpress/base-styles/_colors.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEjKA;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA,eF6Cc;EE5Cd;;;AAGD;EACC;;;AAGD;EACC;EACA;EACA;;AAEA;EACC;EACA,qBF2Ba;EE1Bb;EACA;;AAID;EACC;EACA;;AAGD;EACC;;AAID;EAvBD;IAwBE;;;AAGD;EACC,SACC;EAED;;;AAIF;EACC;EACA,WF/BkB;EEgClB,aFjBoB;EEkBpB;EACA;EACA;;;AAGD;EACC;EACA,WFzCiB;EE0CjB;EACA;EACA","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","@use \"@wordpress/base-styles/variables\";\n\n.boot-site-hub {\n\tposition: sticky;\n\ttop: 0;\n\tbackground-color: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);\n\tz-index: 1;\n\tdisplay: grid;\n\tgrid-template-columns: 60px 1fr auto;\n\talign-items: center;\n\tpadding-right: variables.$grid-unit-20;\n\tflex-shrink: 0; // Prevent flex parent from shrinking this element.\n}\n\n.boot-site-hub__actions {\n\tflex-shrink: 0;\n}\n\n.boot-site-hub__title {\n\tdisplay: flex;\n\talign-items: center;\n\ttext-decoration: none;\n\n\t.components-external-link__contents {\n\t\ttext-decoration: none;\n\t\tmargin-inline-start: variables.$grid-unit-05;\n\t\toverflow: hidden;\n\t\tmax-width: 140px;\n\t}\n\n\t// Show icon on hover\n\t.components-external-link__icon {\n\t\topacity: 0;\n\t\ttransition: opacity 0.1s ease-out;\n\t}\n\n\t&:hover .components-external-link__icon {\n\t\topacity: 1;\n\t}\n\n\t// Focus styles\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: outline 0.1s ease-out;\n\t}\n\n\t&:focus:not(:active) {\n\t\toutline:\n\t\t\tvar(--wpds-border-width-interactive-focus, 2px) solid\n\t\t\tvar(--wpds-color-stroke-focus-brand, #0073aa);\n\t\toutline-offset: calc(-1 * var(--wpds-border-width-interactive-focus, 2px));\n\t}\n}\n\n.boot-site-hub__title-text {\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n\tfont-size: variables.$font-size-medium;\n\tfont-weight: variables.$font-weight-medium;\n\toverflow: hidden;\n\ttext-overflow: ellipsis;\n\twhite-space: nowrap;\n}\n\n.boot-site-hub__url {\n\tcolor: var(--wpds-color-fg-content-neutral-weak, #757575);\n\tfont-size: variables.$font-size-small;\n\toverflow: hidden;\n\ttext-overflow: ellipsis;\n\twhite-space: nowrap;\n}\n"]} */`; 674 document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css3)); 675 function SiteHub() { 676 const { homeUrl, siteTitle } = (0, import_data2.useSelect)((select) => { 677 const { getEntityRecord } = select(import_core_data2.store); 678 const _base = getEntityRecord( 679 "root", 680 "__unstableBase" 681 ); 682 return { 683 homeUrl: _base?.home, 684 siteTitle: !_base?.name && !!_base?.url ? (0, import_url.filterURLForDisplay)(_base?.url) : _base?.name 685 }; 686 }, []); 687 const { open: openCommandCenter } = (0, import_data2.useDispatch)(import_commands.store); 688 return /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)("div", { className: "boot-site-hub", children: [ 689 /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(site_icon_link_default, { to: "/", "aria-label": (0, import_i18n2.__)("Go to the Dashboard") }), 690 /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)( 691 import_components3.ExternalLink, 692 { 693 href: homeUrl ?? "/", 694 className: "boot-site-hub__title", 695 children: [ 696 /* @__PURE__ */ (0, import_jsx_runtime16.jsx)("div", { className: "boot-site-hub__title-text", children: siteTitle && (0, import_html_entities.decodeEntities)(siteTitle) }), 697 /* @__PURE__ */ (0, import_jsx_runtime16.jsx)("div", { className: "boot-site-hub__url", children: (0, import_url.filterURLForDisplay)(homeUrl ?? "") }) 698 ] 699 } 700 ), 701 /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(import_components3.__experimentalHStack, { className: "boot-site-hub__actions", children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)( 702 import_components3.Button, 703 { 704 variant: "tertiary", 705 icon: search_default, 706 onClick: () => openCommandCenter(), 707 size: "compact", 708 label: (0, import_i18n2.__)("Open command palette"), 709 shortcut: import_keycodes.displayShortcut.primary("k") 710 } 711 ) }) 712 ] }); 713 } 714 var site_hub_default = SiteHub; 715 716 // packages/boot/build-module/components/navigation/index.js 717 var import_element6 = __toESM(require_element()); 718 var import_data6 = __toESM(require_data()); 719 720 // packages/boot/build-module/store/index.js 721 var import_data3 = __toESM(require_data()); 722 723 // packages/boot/build-module/store/reducer.js 724 var initialState = { 725 menuItems: {}, 726 routes: [] 727 }; 728 function reducer(state = initialState, action) { 729 switch (action.type) { 730 case "REGISTER_MENU_ITEM": 731 return { 732 ...state, 733 menuItems: { 734 ...state.menuItems, 735 [action.id]: action.menuItem 736 } 737 }; 738 case "UPDATE_MENU_ITEM": 739 return { 740 ...state, 741 menuItems: { 742 ...state.menuItems, 743 [action.id]: { 744 ...state.menuItems[action.id], 745 ...action.updates 746 } 747 } 748 }; 749 case "REGISTER_ROUTE": 750 return { 751 ...state, 752 routes: [...state.routes, action.route] 753 }; 754 } 755 return state; 756 } 757 758 // packages/boot/build-module/store/actions.js 759 var actions_exports = {}; 760 __export(actions_exports, { 761 registerMenuItem: () => registerMenuItem, 762 registerRoute: () => registerRoute, 763 updateMenuItem: () => updateMenuItem 764 }); 765 function registerMenuItem(id, menuItem) { 766 return { 767 type: "REGISTER_MENU_ITEM", 768 id, 769 menuItem 770 }; 771 } 772 function updateMenuItem(id, updates) { 773 return { 774 type: "UPDATE_MENU_ITEM", 775 id, 776 updates 777 }; 778 } 779 function registerRoute(route) { 780 return { 781 type: "REGISTER_ROUTE", 782 route 783 }; 784 } 785 786 // packages/boot/build-module/store/selectors.js 787 var selectors_exports = {}; 788 __export(selectors_exports, { 789 getMenuItems: () => getMenuItems, 790 getRoutes: () => getRoutes 791 }); 792 function getMenuItems(state) { 793 return Object.values(state.menuItems); 794 } 795 function getRoutes(state) { 796 return state.routes; 797 } 798 799 // packages/boot/build-module/store/index.js 800 var STORE_NAME = "wordpress/boot"; 801 var store = (0, import_data3.createReduxStore)(STORE_NAME, { 802 reducer, 803 actions: actions_exports, 804 selectors: selectors_exports 805 }); 806 (0, import_data3.register)(store); 807 808 // packages/boot/build-module/components/navigation/navigation-item/index.js 809 var import_components6 = __toESM(require_components()); 810 811 // packages/boot/build-module/components/navigation/router-link-item.js 812 var import_element3 = __toESM(require_element()); 813 var import_components4 = __toESM(require_components()); 814 import { privateApis as routePrivateApis2 } from "@wordpress/route"; 815 var import_jsx_runtime17 = __toESM(require_jsx_runtime()); 816 var { createLink } = unlock(routePrivateApis2); 817 function AnchorOnlyItem(props, forwardedRef) { 818 return /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(import_components4.__experimentalItem, { as: "a", ref: forwardedRef, ...props }); 819 } 820 var RouterLinkItem = createLink((0, import_element3.forwardRef)(AnchorOnlyItem)); 821 var router_link_item_default = RouterLinkItem; 822 823 // packages/boot/build-module/components/navigation/items.js 824 var import_element4 = __toESM(require_element()); 825 var import_components5 = __toESM(require_components()); 826 var import_primitives11 = __toESM(require_primitives()); 827 var import_jsx_runtime18 = __toESM(require_jsx_runtime()); 828 function isSvg(element) { 829 return (0, import_element4.isValidElement)(element) && (element.type === import_primitives11.SVG || element.type === "svg"); 830 } 831 function wrapIcon(icon, shouldShowPlaceholder = true) { 832 if (isSvg(icon)) { 833 return /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(import_components5.Icon, { icon }); 834 } 835 if (typeof icon === "string" && icon.startsWith("dashicons-")) { 836 const iconKey = icon.replace( 837 /^dashicons-/, 838 "" 839 ); 840 return /* @__PURE__ */ (0, import_jsx_runtime18.jsx)( 841 import_components5.Dashicon, 842 { 843 style: { padding: "2px" }, 844 icon: iconKey, 845 "aria-hidden": "true" 846 } 847 ); 848 } 849 if (typeof icon === "string" && icon.startsWith("data:")) { 850 return /* @__PURE__ */ (0, import_jsx_runtime18.jsx)( 851 "img", 852 { 853 src: icon, 854 alt: "", 855 "aria-hidden": "true", 856 style: { 857 width: "20px", 858 height: "20px", 859 display: "block", 860 padding: "2px" 861 } 862 } 863 ); 864 } 865 if (icon) { 866 return icon; 867 } 868 if (shouldShowPlaceholder) { 869 return /* @__PURE__ */ (0, import_jsx_runtime18.jsx)( 870 "div", 871 { 872 style: { width: "24px", height: "24px" }, 873 "aria-hidden": "true" 874 } 875 ); 876 } 877 return null; 878 } 879 880 // packages/boot/build-module/components/navigation/navigation-item/index.js 881 var import_jsx_runtime19 = __toESM(require_jsx_runtime()); 882 var css4 = `/** 883 * SCSS Variables. 884 * 885 * Please use variables from this sheet to ensure consistency across the UI. 886 * Don't add to this sheet unless you're pretty sure the value will be reused in many places. 887 * For example, don't add rules to this sheet that affect block visuals. It's purely for UI. 888 */ 889 /** 890 * Colors 891 */ 892 /** 893 * Fonts & basic variables. 894 */ 895 /** 896 * Typography 897 */ 898 /** 899 * Grid System. 900 * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/ 901 */ 902 /** 903 * Radius scale. 904 */ 905 /** 906 * Elevation scale. 907 */ 908 /** 909 * Dimensions. 910 */ 911 /** 912 * Mobile specific styles 913 */ 914 /** 915 * Editor styles. 916 */ 917 /** 918 * Block & Editor UI. 919 */ 920 /** 921 * Block paddings. 922 */ 923 /** 924 * React Native specific. 925 * These variables do not appear to be used anywhere else. 926 */ 927 /** 928 * Typography 929 */ 930 /** 931 * Breakpoints & Media Queries 932 */ 933 /** 934 * Converts a hex value into the rgb equivalent. 935 * 936 * @param {string} hex - the hexadecimal value to convert 937 * @return {string} comma separated rgb values 938 */ 939 /** 940 * Long content fade mixin 941 * 942 * Creates a fading overlay to signify that the content is longer 943 * than the space allows. 944 */ 945 /** 946 * Breakpoint mixins 947 */ 948 /** 949 * Focus styles. 950 */ 951 /** 952 * Applies editor left position to the selector passed as argument 953 */ 954 /** 955 * Styles that are reused verbatim in a few places 956 */ 957 /** 958 * Allows users to opt-out of animations via OS-level preferences. 959 */ 960 /** 961 * Reset default styles for JavaScript UI based pages. 962 * This is a WP-admin agnostic reset 963 */ 964 /** 965 * Reset the WP Admin page styles for Gutenberg-like pages. 966 */ 967 .boot-navigation-item.components-item { 968 color: var(--wpds-color-fg-interactive-neutral, #1e1e1e); 969 padding-inline: 4px; 970 padding-block: 0; 971 margin-inline: 12px; 972 margin-block-end: 4px; 973 width: calc(100% - 24px); 974 border: none; 975 min-height: 32px; 976 display: flex; 977 align-items: center; 978 font-family: -apple-system, "system-ui", "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; 979 font-weight: 400; 980 font-size: 13px; 981 line-height: 20px; 982 } 983 .boot-dropdown-item__children .boot-navigation-item.components-item { 984 min-height: 24px; 985 } 986 .boot-navigation-item.components-item { 987 border-radius: var(--wpds-border-radius-surface-sm, 2px); 988 } 989 .boot-navigation-item.components-item.active, .boot-navigation-item.components-item:hover, .boot-navigation-item.components-item:focus, .boot-navigation-item.components-item[aria-current=true] { 990 color: var(--wpds-color-fg-interactive-brand-active, #0073aa); 991 } 992 .boot-navigation-item.components-item.active { 993 font-weight: 499; 994 } 995 .boot-navigation-item.components-item svg:last-child { 996 padding: 4px; 997 } 998 .boot-navigation-item.components-item[aria-current=true] { 999 color: var(--wpds-color-fg-interactive-brand-active, #0073aa); 1000 font-weight: 499; 1001 } 1002 .boot-navigation-item.components-item:focus-visible { 1003 transform: translateZ(0); 1004 } 1005 .boot-navigation-item.components-item.with-suffix { 1006 padding-right: 16px; 1007 } 1008 /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/navigation/navigation-item","sources":["../../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../../node_modules/@wordpress/base-styles/_colors.scss","../../../../../../node_modules/@wordpress/base-styles/_mixins.scss","../../../../../../node_modules/@wordpress/base-styles/_breakpoints.scss","../../../../../../node_modules/@wordpress/base-styles/_functions.scss","../../../../../../node_modules/@wordpress/base-styles/_long-content-fade.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEnKA;AAAA;AAAA;ACAA;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AH4EA;AAAA;AAAA;AA0DA;AAAA;AAAA;AAgDA;AAAA;AAAA;AAqCA;AAAA;AAAA;AAoBA;AAAA;AAAA;AAwLA;AAAA;AAAA;AAAA;AAgDA;AAAA;AAAA;AIpdA;EACC;EACA,gBN+Cc;EM9Cd;EACA,eN+Cc;EM9Cd,kBN4Cc;EM3Cd;EACA;EACA,YN8Cc;EM7Cd;EACA;EJKA,aFyBkB;EExBlB,aFmBqB;EEsBrB,WFpCkB;EEqClB,aF9BwB;;AMfxB;EACC,YNuCa;;AMrDf;EAkBC;;AAEA;EAIC;;AAGD;EACC,aNQmB;;AMLpB;EACC,SNiBa;;AMdd;EACC;EACA,aNDmB;;AMKpB;EACC;;AAGD;EACC,eNMa","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","/**\n * Typography\n */\n\n@use \"sass:color\";\n@use \"sass:math\";\n@use \"./variables\";\n@use \"./colors\";\n@use \"./breakpoints\";\n@use \"./functions\";\n@use \"./long-content-fade\";\n\n@mixin _text-heading() {\n\tfont-family: variables.$font-family-headings;\n\tfont-weight: variables.$font-weight-medium;\n}\n\n@mixin _text-body() {\n\tfont-family: variables.$font-family-body;\n\tfont-weight: variables.$font-weight-regular;\n}\n\n@mixin heading-small() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-x-small;\n\tline-height: variables.$font-line-height-x-small;\n}\n\n@mixin heading-medium() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-medium;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin heading-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-large;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin heading-x-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-x-large;\n\tline-height: variables.$font-line-height-medium;\n}\n\n@mixin heading-2x-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-2x-large;\n\tline-height: variables.$font-line-height-2x-large;\n}\n\n@mixin body-small() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-small;\n\tline-height: variables.$font-line-height-x-small;\n}\n\n@mixin body-medium() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-medium;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin body-large() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-large;\n\tline-height: variables.$font-line-height-medium;\n}\n\n@mixin body-x-large() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-x-large;\n\tline-height: variables.$font-line-height-x-large;\n}\n\n/**\n * Breakpoint mixins\n */\n\n@mixin break-xhuge() {\n\t@media (min-width: #{ (breakpoints.$break-xhuge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-huge() {\n\t@media (min-width: #{ (breakpoints.$break-huge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-wide() {\n\t@media (min-width: #{ (breakpoints.$break-wide) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-xlarge() {\n\t@media (min-width: #{ (breakpoints.$break-xlarge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-large() {\n\t@media (min-width: #{ (breakpoints.$break-large) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-medium() {\n\t@media (min-width: #{ (breakpoints.$break-medium) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-small() {\n\t@media (min-width: #{ (breakpoints.$break-small) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-mobile() {\n\t@media (min-width: #{ (breakpoints.$break-mobile) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-zoomed-in() {\n\t@media (min-width: #{ (breakpoints.$break-zoomed-in) }) {\n\t\t@content;\n\t}\n}\n\n/**\n * Focus styles.\n */\n\n@mixin block-toolbar-button-style__focus() {\n\tbox-shadow: inset 0 0 0 variables.$border-width colors.$white, 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n// Tabs, Inputs, Square buttons.\n@mixin input-style__neutral() {\n\tbox-shadow: 0 0 0 transparent;\n\tborder-radius: variables.$radius-small;\n\tborder: variables.$border-width solid colors.$gray-600;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: box-shadow 0.1s linear;\n\t}\n}\n\n\n@mixin input-style__focus($accent-color: var(--wp-admin-theme-color)) {\n\tborder-color: $accent-color;\n\t// Expand the default border focus style by .5px to be a total of 1.5px.\n\tbox-shadow: 0 0 0 0.5px $accent-color;\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n@mixin button-style__focus() {\n\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n\n@mixin button-style-outset__focus($focus-color) {\n\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) colors.$white, 0 0 0 calc(2 * var(--wp-admin-border-width-focus)) $focus-color;\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n\toutline-offset: 2px;\n}\n\n\n/**\n * Applies editor left position to the selector passed as argument\n */\n\n@mixin editor-left($selector) {\n\t#{$selector} { /* Set left position when auto-fold is not on the body element. */\n\t\tleft: 0;\n\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width;\n\t\t}\n\t}\n\n\t.auto-fold #{$selector} { /* Auto fold is when on smaller breakpoints, nav menu auto collapses. */\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width-collapsed;\n\t\t}\n\n\t\t@media (min-width: #{ (breakpoints.$break-large + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width;\n\t\t}\n\t}\n\n\t/* Sidebar manually collapsed. */\n\t.folded #{$selector} {\n\t\tleft: 0;\n\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width-collapsed;\n\t\t}\n\t}\n\n\tbody.is-fullscreen-mode #{$selector} {\n\t\tleft: 0 !important;\n\t}\n}\n\n/**\n * Styles that are reused verbatim in a few places\n */\n\n// These are additional styles for all captions, when the theme opts in to block styles.\n@mixin caption-style() {\n\tmargin-top: 0.5em;\n\tmargin-bottom: 1em;\n}\n\n@mixin caption-style-theme() {\n\tcolor: #555;\n\tfont-size: variables.$default-font-size;\n\ttext-align: center;\n\n\t.is-dark-theme & {\n\t\tcolor: colors.$light-gray-placeholder;\n\t}\n}\n\n/**\n * Allows users to opt-out of animations via OS-level preferences.\n */\n\n@mixin reduce-motion($property: \"\") {\n\n\t@if $property == \"transition\" {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\ttransition-duration: 0s;\n\t\t\ttransition-delay: 0s;\n\t\t}\n\t} @else if $property == \"animation\" {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\tanimation-duration: 1ms;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\t} @else {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\ttransition-duration: 0s;\n\t\t\ttransition-delay: 0s;\n\t\t\tanimation-duration: 1ms;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\t}\n}\n\n@mixin input-control($accent-color: var(--wp-admin-theme-color)) {\n\tfont-family: variables.$default-font;\n\tpadding: 6px 8px;\n\t/* Fonts smaller than 16px causes mobile safari to zoom. */\n\tfont-size: variables.$mobile-text-min-font-size;\n\t/* Override core line-height. To be reviewed. */\n\tline-height: normal;\n\t@include input-style__neutral();\n\n\t@include break-small {\n\t\tfont-size: variables.$default-font-size;\n\t\t/* Override core line-height. To be reviewed. */\n\t\tline-height: normal;\n\t}\n\n\t&:focus {\n\t\t@include input-style__focus($accent-color);\n\t}\n\n\t// Use opacity to work in various editor styles.\n\t&::-webkit-input-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n\n\t&::-moz-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n\n\t&:-ms-input-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n}\n\n@mixin checkbox-control {\n\tborder: variables.$border-width solid colors.$gray-900;\n\tmargin-right: variables.$grid-unit-15;\n\ttransition: none;\n\tborder-radius: variables.$radius-small;\n\t@include input-control;\n\n\t&:focus {\n\t\tbox-shadow: 0 0 0 (variables.$border-width * 2) colors.$white, 0 0 0 (variables.$border-width * 2 + variables.$border-width-focus-fallback) var(--wp-admin-theme-color);\n\n\t\t// Only visible in Windows High Contrast mode.\n\t\toutline: 2px solid transparent;\n\t}\n\n\t&:checked {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder-color: var(--wp-admin-theme-color);\n\n\t\t// Hide default checkbox styles in IE.\n\t\t&::-ms-check {\n\t\t\topacity: 0;\n\t\t}\n\t}\n\n\t&:checked::before,\n\t&[aria-checked=\"mixed\"]::before {\n\t\tmargin: -3px -5px;\n\t\tcolor: colors.$white;\n\n\t\t@include break-medium() {\n\t\t\tmargin: -4px 0 0 -5px;\n\t\t}\n\t}\n\n\t&[aria-checked=\"mixed\"] {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder-color: var(--wp-admin-theme-color);\n\n\t\t&::before {\n\t\t\t// Inherited from `forms.css`.\n\t\t\t// See: https://github.com/WordPress/wordpress-develop/tree/5.1.1/src/wp-admin/css/forms.css#L122-L132\n\t\t\tcontent: \"\\f460\";\n\t\t\tfloat: left;\n\t\t\tdisplay: inline-block;\n\t\t\tvertical-align: middle;\n\t\t\twidth: 16px;\n\t\t\t/* stylelint-disable-next-line font-family-no-missing-generic-family-keyword -- dashicons don't need a generic family keyword. */\n\t\t\tfont: normal 30px/1 dashicons;\n\t\t\tspeak: none;\n\t\t\t-webkit-font-smoothing: antialiased;\n\t\t\t-moz-osx-font-smoothing: grayscale;\n\n\t\t\t@include break-medium() {\n\t\t\t\tfloat: none;\n\t\t\t\tfont-size: 21px;\n\t\t\t}\n\t\t}\n\t}\n\n\t&[aria-disabled=\"true\"],\n\t&:disabled {\n\t\tbackground: colors.$gray-100;\n\t\tborder-color: colors.$gray-300;\n\t\tcursor: default;\n\n\t\t// Override style inherited from wp-admin. Required to avoid degraded appearance on different backgrounds.\n\t\topacity: 1;\n\t}\n}\n\n@mixin radio-control {\n\tborder: variables.$border-width solid colors.$gray-900;\n\tmargin-right: variables.$grid-unit-15;\n\ttransition: none;\n\tborder-radius: variables.$radius-round;\n\twidth: variables.$radio-input-size-sm;\n\theight: variables.$radio-input-size-sm;\n\tmin-width: variables.$radio-input-size-sm;\n\tmax-width: variables.$radio-input-size-sm;\n\tposition: relative;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: box-shadow 0.1s linear;\n\t}\n\n\t@include break-small() {\n\t\theight: variables.$radio-input-size;\n\t\twidth: variables.$radio-input-size;\n\t\tmin-width: variables.$radio-input-size;\n\t\tmax-width: variables.$radio-input-size;\n\t}\n\n\t&:checked::before {\n\t\tbox-sizing: inherit;\n\t\twidth: math.div(variables.$radio-input-size-sm, 2);\n\t\theight: math.div(variables.$radio-input-size-sm, 2);\n\t\tposition: absolute;\n\t\ttop: 50%;\n\t\tleft: 50%;\n\t\ttransform: translate(-50%, -50%);\n\t\tmargin: 0;\n\t\tbackground-color: colors.$white;\n\n\t\t// This border serves as a background color in Windows High Contrast mode.\n\t\tborder: 4px solid colors.$white;\n\n\t\t@include break-small() {\n\t\t\twidth: math.div(variables.$radio-input-size, 2);\n\t\t\theight: math.div(variables.$radio-input-size, 2);\n\t\t}\n\t}\n\n\t&:focus {\n\t\tbox-shadow: 0 0 0 (variables.$border-width * 2) colors.$white, 0 0 0 (variables.$border-width * 2 + variables.$border-width-focus-fallback) var(--wp-admin-theme-color);\n\n\t\t// Only visible in Windows High Contrast mode.\n\t\toutline: 2px solid transparent;\n\t}\n\n\t&:checked {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder: none;\n\t}\n}\n\n/**\n * Reset default styles for JavaScript UI based pages.\n * This is a WP-admin agnostic reset\n */\n\n@mixin reset {\n\tbox-sizing: border-box;\n\n\t*,\n\t*::before,\n\t*::after {\n\t\tbox-sizing: inherit;\n\t}\n}\n\n@mixin link-reset {\n\t&:focus {\n\t\tcolor: var(--wp-admin-theme-color--rgb);\n\t\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color, #007cba);\n\t\tborder-radius: variables.$radius-small;\n\t}\n}\n\n// The editor input reset with increased specificity to avoid theme styles bleeding in.\n@mixin editor-input-reset() {\n\tfont-family: variables.$editor-html-font !important;\n\tcolor: colors.$gray-900 !important;\n\tbackground: colors.$white !important;\n\tpadding: variables.$grid-unit-15 !important;\n\tborder: variables.$border-width solid colors.$gray-900 !important;\n\tbox-shadow: none !important;\n\tborder-radius: variables.$radius-small !important;\n\n\t// Fonts smaller than 16px causes mobile safari to zoom.\n\tfont-size: variables.$mobile-text-min-font-size !important;\n\t@include break-small {\n\t\tfont-size: variables.$default-font-size !important;\n\t}\n\n\t&:focus {\n\t\tborder-color: var(--wp-admin-theme-color) !important;\n\t\tbox-shadow: 0 0 0 (variables.$border-width-focus-fallback - variables.$border-width) var(--wp-admin-theme-color) !important;\n\n\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\toutline: 2px solid transparent !important;\n\t}\n}\n\n/**\n * Reset the WP Admin page styles for Gutenberg-like pages.\n */\n\n@mixin wp-admin-reset( $content-container ) {\n\tbackground: colors.$white;\n\n\t#wpcontent {\n\t\tpadding-left: 0;\n\t}\n\n\t#wpbody-content {\n\t\tpadding-bottom: 0;\n\t}\n\n\t/* We hide legacy notices in Gutenberg Based Pages, because they were not designed in a way that scaled well.\n\t   Plugins can use Gutenberg notices if they need to pass on information to the user when they are editing. */\n\t#wpbody-content > div:not(#{ $content-container }):not(#screen-meta) {\n\t\tdisplay: none;\n\t}\n\n\t#wpfooter {\n\t\tdisplay: none;\n\t}\n\n\t.a11y-speak-region {\n\t\tleft: -1px;\n\t\ttop: -1px;\n\t}\n\n\tul#adminmenu a.wp-has-current-submenu::after,\n\tul#adminmenu > li.current > a.current::after {\n\t\tborder-right-color: colors.$white;\n\t}\n\n\t.media-frame select.attachment-filters:last-of-type {\n\t\twidth: auto;\n\t\tmax-width: 100%;\n\t}\n}\n\n@mixin admin-scheme($color-primary) {\n\t// Define RGB equivalents for use in rgba function.\n\t// Hexadecimal css vars do not work in the rgba function.\n\t--wp-admin-theme-color: #{$color-primary};\n\t--wp-admin-theme-color--rgb: #{functions.hex-to-rgb($color-primary)};\n\t// Darker shades.\n\t--wp-admin-theme-color-darker-10: #{color.adjust($color-primary, $lightness: -5%)};\n\t--wp-admin-theme-color-darker-10--rgb: #{functions.hex-to-rgb(color.adjust($color-primary, $lightness: -5%))};\n\t--wp-admin-theme-color-darker-20: #{color.adjust($color-primary, $lightness: -10%)};\n\t--wp-admin-theme-color-darker-20--rgb: #{functions.hex-to-rgb(color.adjust($color-primary, $lightness: -10%))};\n\n\t// Focus style width.\n\t// Avoid rounding issues by showing a whole 2px for 1x screens, and 1.5px on high resolution screens.\n\t--wp-admin-border-width-focus: 2px;\n\t@media ( -webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {\n\t\t--wp-admin-border-width-focus: 1.5px;\n\t}\n}\n\n@mixin wordpress-admin-schemes() {\n\tbody.admin-color-light {\n\t\t@include admin-scheme(#0085ba);\n\t}\n\n\tbody.admin-color-modern {\n\t\t@include admin-scheme(#3858e9);\n\t}\n\n\tbody.admin-color-blue {\n\t\t@include admin-scheme(#096484);\n\t}\n\n\tbody.admin-color-coffee {\n\t\t@include admin-scheme(#46403c);\n\t}\n\n\tbody.admin-color-ectoplasm {\n\t\t@include admin-scheme(#523f6d);\n\t}\n\n\tbody.admin-color-midnight {\n\t\t@include admin-scheme(#e14d43);\n\t}\n\n\tbody.admin-color-ocean {\n\t\t@include admin-scheme(#627c83);\n\t}\n\n\tbody.admin-color-sunrise {\n\t\t@include admin-scheme(#dd823b);\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin background-colors-deprecated() {\n\t.has-very-light-gray-background-color {\n\t\tbackground-color: #eee;\n\t}\n\n\t.has-very-dark-gray-background-color {\n\t\tbackground-color: #313131;\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin foreground-colors-deprecated() {\n\t.has-very-light-gray-color {\n\t\tcolor: #eee;\n\t}\n\n\t.has-very-dark-gray-color {\n\t\tcolor: #313131;\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin gradient-colors-deprecated() {\n\t// Our classes uses the same values we set for gradient value attributes.\n\n\t/* stylelint-disable @stylistic/function-comma-space-after -- We can not use spacing because of WP multi site kses rule. */\n\t.has-vivid-green-cyan-to-vivid-cyan-blue-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgba(0,208,132,1) 0%,rgba(6,147,227,1) 100%);\n\t}\n\n\t.has-purple-crush-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(52,226,228) 0%,rgb(71,33,251) 50%,rgb(171,29,254) 100%);\n\t}\n\n\t.has-hazy-dawn-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(250,172,168) 0%,rgb(218,208,236) 100%);\n\t}\n\n\t.has-subdued-olive-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(250,250,225) 0%,rgb(103,166,113) 100%);\n\t}\n\n\t.has-atomic-cream-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(253,215,154) 0%,rgb(0,74,89) 100%);\n\t}\n\n\t.has-nightshade-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(51,9,104) 0%,rgb(49,205,207) 100%);\n\t}\n\n\t.has-midnight-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(2,3,129) 0%,rgb(40,116,252) 100%);\n\t}\n\t/* stylelint-enable @stylistic/function-comma-space-after */\n}\n\n@mixin custom-scrollbars-on-hover($handle-color, $handle-color-hover) {\n\n\t// WebKit\n\t&::-webkit-scrollbar {\n\t\twidth: 12px;\n\t\theight: 12px;\n\t}\n\t&::-webkit-scrollbar-track {\n\t\tbackground-color: transparent;\n\t}\n\t&::-webkit-scrollbar-thumb {\n\t\tbackground-color: $handle-color;\n\t\tborder-radius: 8px;\n\t\tborder: 3px solid transparent;\n\t\tbackground-clip: padding-box;\n\t}\n\t&:hover::-webkit-scrollbar-thumb, // This needs specificity.\n\t&:focus::-webkit-scrollbar-thumb,\n\t&:focus-within::-webkit-scrollbar-thumb {\n\t\tbackground-color: $handle-color-hover;\n\t}\n\n\t// Firefox 109+ and Chrome 111+\n\tscrollbar-width: thin;\n\tscrollbar-gutter: stable both-edges;\n\tscrollbar-color: $handle-color transparent; // Syntax, \"dark\", \"light\", or \"#handle-color #track-color\"\n\n\t&:hover,\n\t&:focus,\n\t&:focus-within {\n\t\tscrollbar-color: $handle-color-hover transparent;\n\t}\n\n\t// Needed to fix a Safari rendering issue.\n\twill-change: transform;\n\n\t// Always show scrollbar on Mobile devices.\n\t@media (hover: none) {\n\t\t& {\n\t\t\tscrollbar-color: $handle-color-hover transparent;\n\t\t}\n\t}\n}\n\n@mixin selected-block-outline($widthRatio: 1) {\n\toutline-color: var(--wp-admin-theme-color);\n\toutline-style: solid;\n\toutline-width: calc(#{$widthRatio} * (var(--wp-admin-border-width-focus) / var(--wp-block-editor-iframe-zoom-out-scale, 1)));\n\toutline-offset: calc(#{$widthRatio} * ((-1 * var(--wp-admin-border-width-focus) ) / var(--wp-block-editor-iframe-zoom-out-scale, 1)));\n}\n\n@mixin selected-block-focus($widthRatio: 1) {\n\tcontent: \"\";\n\tposition: absolute;\n\tpointer-events: none;\n\ttop: 0;\n\tright: 0;\n\tbottom: 0;\n\tleft: 0;\n\t@include selected-block-outline($widthRatio);\n}\n","/**\n * Breakpoints & Media Queries\n */\n\n// Most used breakpoints\n$break-xhuge: 1920px;\n$break-huge: 1440px;\n$break-wide: 1280px;\n$break-xlarge: 1080px;\n$break-large: 960px;\t// admin sidebar auto folds\n$break-medium: 782px;\t// adminbar goes big\n$break-small: 600px;\n$break-mobile: 480px;\n$break-zoomed-in: 280px;\n\n// All media queries currently in WordPress:\n//\n// min-width: 2000px\n// min-width: 1680px\n// min-width: 1250px\n// max-width: 1120px *\n// max-width: 1000px\n// min-width: 769px and max-width: 1000px\n// max-width: 960px *\n// max-width: 900px\n// max-width: 850px\n// min-width: 800px and max-width: 1499px\n// max-width: 800px\n// max-width: 799px\n// max-width: 782px *\n// max-width: 768px\n// max-width: 640px *\n// max-width: 600px *\n// max-width: 520px\n// max-width: 500px\n// max-width: 480px *\n// max-width: 400px *\n// max-width: 380px\n// max-width: 320px *\n//\n// Those marked * seem to be more commonly used than the others.\n// Let's try and use as few of these as possible, and be mindful about adding new ones, so we don't make the situation worse\n","/**\n*  Converts a hex value into the rgb equivalent.\n*\n* @param {string} hex - the hexadecimal value to convert\n* @return {string} comma separated rgb values\n*/\n\n@use \"sass:color\";\n@use \"sass:meta\";\n\n@function hex-to-rgb($hex) {\n\t/*\n\t * TODO: `color.{red|green|blue}` will trigger a deprecation warning in Dart Sass,\n\t * but the Sass used by the Gutenberg project doesn't support `color.channel()` yet,\n\t * so we can't migrate to it at this time.\n\t * In the future, after the Gutenberg project has been fully migrated to Dart Sass,\n\t * Remove this conditional statement and use only `color.channel()`.\n\t */\n\t@if meta.function-exists(\"channel\", \"color\") {\n\t\t@return color.channel($hex, \"red\"), color.channel($hex, \"green\"), color.channel($hex, \"blue\");\n\t} @else {\n\t\t@return color.red($hex), color.green($hex), color.blue($hex);\n\t}\n}\n","/**\n * Long content fade mixin\n *\n * Creates a fading overlay to signify that the content is longer\n * than the space allows.\n */\n\n@mixin long-content-fade($direction: right, $size: 20%, $color: #fff, $edge: 0, $z-index: false) {\n\tcontent: \"\";\n\tdisplay: block;\n\tposition: absolute;\n\t-webkit-touch-callout: none;\n\t-webkit-user-select: none;\n\t-khtml-user-select: none;\n\t-moz-user-select: none;\n\t-ms-user-select: none;\n\tuser-select: none;\n\tpointer-events: none;\n\n\t@if $z-index {\n\t\tz-index: $z-index;\n\t}\n\n\t@if $direction == \"bottom\" {\n\t\tbackground: linear-gradient(to top, transparent, $color 90%);\n\t\tleft: $edge;\n\t\tright: $edge;\n\t\ttop: $edge;\n\t\tbottom: calc(100% - $size);\n\t\twidth: auto;\n\t}\n\n\t@if $direction == \"top\" {\n\t\tbackground: linear-gradient(to bottom, transparent, $color 90%);\n\t\ttop: calc(100% - $size);\n\t\tleft: $edge;\n\t\tright: $edge;\n\t\tbottom: $edge;\n\t\twidth: auto;\n\t}\n\n\t@if $direction == \"left\" {\n\t\tbackground: linear-gradient(to left, transparent, $color 90%);\n\t\ttop: $edge;\n\t\tleft: $edge;\n\t\tbottom: $edge;\n\t\tright: auto;\n\t\twidth: $size;\n\t\theight: auto;\n\t}\n\n\t@if $direction == \"right\" {\n\t\tbackground: linear-gradient(to right, transparent, $color 90%);\n\t\ttop: $edge;\n\t\tbottom: $edge;\n\t\tright: $edge;\n\t\tleft: auto;\n\t\twidth: $size;\n\t\theight: auto;\n\t}\n}\n","@use \"@wordpress/base-styles/variables\";\n@use \"@wordpress/base-styles/mixins\";\n\n.boot-navigation-item.components-item {\n\tcolor: var(--wpds-color-fg-interactive-neutral, #1e1e1e);\n\tpadding-inline: variables.$grid-unit-05;\n\tpadding-block: 0;\n\tmargin-inline: variables.$grid-unit-15;\n\tmargin-block-end: variables.$grid-unit-05;\n\twidth: calc(100% - variables.$grid-unit-15 * 2);\n\tborder: none;\n\tmin-height: variables.$grid-unit-40;\n\tdisplay: flex;\n\talign-items: center;\n\t@include mixins.body-medium();\n\n\t.boot-dropdown-item__children & {\n\t\tmin-height: variables.$grid-unit-30;\n\t}\n\n\t// Rounded focus ring\n\tborder-radius: var(--wpds-border-radius-surface-sm, 2px);\n\n\t&.active,\n\t&:hover,\n\t&:focus,\n\t&[aria-current=\"true\"] {\n\t\tcolor: var(--wpds-color-fg-interactive-brand-active, #0073aa);\n\t}\n\n\t&.active {\n\t\tfont-weight: variables.$font-weight-medium;\n\t}\n\n\tsvg:last-child {\n\t\tpadding: variables.$grid-unit-05;\n\t}\n\n\t&[aria-current=\"true\"] {\n\t\tcolor: var(--wpds-color-fg-interactive-brand-active, #0073aa);\n\t\tfont-weight: variables.$font-weight-medium;\n\t}\n\n\t// Make sure the focus style is drawn on top of the current item background.\n\t&:focus-visible {\n\t\ttransform: translateZ(0);\n\t}\n\n\t&.with-suffix {\n\t\tpadding-right: variables.$grid-unit-20;\n\t}\n}\n"]} */`; 1009 document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css4)); 1010 function NavigationItem({ 1011 className, 1012 icon, 1013 shouldShowPlaceholder = true, 1014 children, 1015 to 1016 }) { 1017 const isExternal = !String( 1018 new URL(to, window.location.origin) 1019 ).startsWith(window.location.origin); 1020 const content = /* @__PURE__ */ (0, import_jsx_runtime19.jsxs)(import_components6.__experimentalHStack, { justify: "flex-start", spacing: 2, style: { flexGrow: "1" }, children: [ 1021 wrapIcon(icon, shouldShowPlaceholder), 1022 /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(import_components6.FlexBlock, { children }) 1023 ] }); 1024 if (isExternal) { 1025 return /* @__PURE__ */ (0, import_jsx_runtime19.jsx)( 1026 import_components6.__experimentalItem, 1027 { 1028 as: "a", 1029 href: to, 1030 className: clsx_default("boot-navigation-item", className), 1031 children: content 1032 } 1033 ); 1034 } 1035 return /* @__PURE__ */ (0, import_jsx_runtime19.jsx)( 1036 router_link_item_default, 1037 { 1038 to, 1039 className: clsx_default("boot-navigation-item", className), 1040 children: content 1041 } 1042 ); 1043 } 1044 1045 // packages/boot/build-module/components/navigation/drilldown-item/index.js 1046 var import_components7 = __toESM(require_components()); 1047 var import_i18n3 = __toESM(require_i18n()); 1048 var import_jsx_runtime20 = __toESM(require_jsx_runtime()); 1049 function DrilldownItem({ 1050 className, 1051 id, 1052 icon, 1053 shouldShowPlaceholder = true, 1054 children, 1055 onNavigate 1056 }) { 1057 const handleClick = (e) => { 1058 e.preventDefault(); 1059 onNavigate({ id, direction: "forward" }); 1060 }; 1061 return /* @__PURE__ */ (0, import_jsx_runtime20.jsx)( 1062 import_components7.__experimentalItem, 1063 { 1064 className: clsx_default("boot-navigation-item", className), 1065 onClick: handleClick, 1066 children: /* @__PURE__ */ (0, import_jsx_runtime20.jsxs)( 1067 import_components7.__experimentalHStack, 1068 { 1069 justify: "flex-start", 1070 spacing: 2, 1071 style: { flexGrow: "1" }, 1072 children: [ 1073 wrapIcon(icon, shouldShowPlaceholder), 1074 /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(import_components7.FlexBlock, { children }), 1075 /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(import_components7.Icon, { icon: (0, import_i18n3.isRTL)() ? chevron_left_small_default : chevron_right_small_default }) 1076 ] 1077 } 1078 ) 1079 } 1080 ); 1081 } 1082 1083 // packages/boot/build-module/components/navigation/dropdown-item/index.js 1084 var import_components8 = __toESM(require_components()); 1085 var import_compose = __toESM(require_compose()); 1086 var import_data4 = __toESM(require_data()); 1087 var import_jsx_runtime21 = __toESM(require_jsx_runtime()); 1088 var css5 = `/** 1089 * SCSS Variables. 1090 * 1091 * Please use variables from this sheet to ensure consistency across the UI. 1092 * Don't add to this sheet unless you're pretty sure the value will be reused in many places. 1093 * For example, don't add rules to this sheet that affect block visuals. It's purely for UI. 1094 */ 1095 /** 1096 * Colors 1097 */ 1098 /** 1099 * Fonts & basic variables. 1100 */ 1101 /** 1102 * Typography 1103 */ 1104 /** 1105 * Grid System. 1106 * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/ 1107 */ 1108 /** 1109 * Radius scale. 1110 */ 1111 /** 1112 * Elevation scale. 1113 */ 1114 /** 1115 * Dimensions. 1116 */ 1117 /** 1118 * Mobile specific styles 1119 */ 1120 /** 1121 * Editor styles. 1122 */ 1123 /** 1124 * Block & Editor UI. 1125 */ 1126 /** 1127 * Block paddings. 1128 */ 1129 /** 1130 * React Native specific. 1131 * These variables do not appear to be used anywhere else. 1132 */ 1133 .boot-dropdown-item__children { 1134 display: flex; 1135 flex-direction: column; 1136 padding: 2px; 1137 margin-block-start: -2px; 1138 margin-block-end: 2px; 1139 margin-inline-start: 30px; 1140 overflow: hidden; 1141 } 1142 1143 .boot-dropdown-item__chevron.is-up { 1144 transform: rotate(180deg); 1145 } 1146 /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/navigation/dropdown-item","sources":["../../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../../node_modules/@wordpress/base-styles/_colors.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEjKA;EACC;EACA;EAOA,SADsC;EAEtC;EACA,kBAHsC;EAItC,qBACC;EAED;;;AAGD;EACC","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","@use \"@wordpress/base-styles/variables\";\n\n.boot-dropdown-item__children {\n\tdisplay: flex;\n\tflex-direction: column;\n\n\t// In order to avoid the focus ring of each list item from being cut off,\n\t// we add padding around the menu items.\n\t// At the same time, we use the same value to tweak margins so that\n\t// the items still retain the same position and footprint.\n\t$padding-to-avoid-cutting-focus-ring: 2px;\n\tpadding: $padding-to-avoid-cutting-focus-ring;\n\tmargin-block-start: -$padding-to-avoid-cutting-focus-ring;\n\tmargin-block-end: $padding-to-avoid-cutting-focus-ring;\n\tmargin-inline-start:\n\t\tvariables.$grid-unit-40 -\n\t\t$padding-to-avoid-cutting-focus-ring;\n\toverflow: hidden;\n}\n\n.boot-dropdown-item__chevron.is-up {\n\ttransform: rotate(180deg);\n}\n"]} */`; 1147 document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css5)); 1148 var ANIMATION_DURATION = 0.2; 1149 function DropdownItem({ 1150 className, 1151 id, 1152 icon, 1153 children, 1154 isExpanded, 1155 onToggle 1156 }) { 1157 const menuItems = (0, import_data4.useSelect)( 1158 (select) => ( 1159 // @ts-ignore 1160 select(STORE_NAME).getMenuItems() 1161 ), 1162 [] 1163 ); 1164 const items = menuItems.filter((item) => item.parent === id); 1165 const disableMotion = (0, import_compose.useReducedMotion)(); 1166 return /* @__PURE__ */ (0, import_jsx_runtime21.jsxs)("div", { className: "boot-dropdown-item", children: [ 1167 /* @__PURE__ */ (0, import_jsx_runtime21.jsx)( 1168 import_components8.__experimentalItem, 1169 { 1170 className: clsx_default("boot-navigation-item", className), 1171 onClick: (e) => { 1172 e.preventDefault(); 1173 e.stopPropagation(); 1174 onToggle(); 1175 }, 1176 onMouseDown: (e) => e.preventDefault(), 1177 children: /* @__PURE__ */ (0, import_jsx_runtime21.jsxs)( 1178 import_components8.__experimentalHStack, 1179 { 1180 justify: "flex-start", 1181 spacing: 2, 1182 style: { flexGrow: "1" }, 1183 children: [ 1184 wrapIcon(icon, false), 1185 /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(import_components8.FlexBlock, { children }), 1186 /* @__PURE__ */ (0, import_jsx_runtime21.jsx)( 1187 import_components8.Icon, 1188 { 1189 icon: chevron_down_small_default, 1190 className: clsx_default("boot-dropdown-item__chevron", { 1191 "is-up": isExpanded 1192 }) 1193 } 1194 ) 1195 ] 1196 } 1197 ) 1198 } 1199 ), 1200 /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(import_components8.__unstableAnimatePresence, { initial: false, children: isExpanded && /* @__PURE__ */ (0, import_jsx_runtime21.jsx)( 1201 import_components8.__unstableMotion.div, 1202 { 1203 initial: { height: 0 }, 1204 animate: { height: "auto" }, 1205 exit: { height: 0 }, 1206 transition: { 1207 type: "tween", 1208 duration: disableMotion ? 0 : ANIMATION_DURATION, 1209 ease: "easeOut" 1210 }, 1211 className: "boot-dropdown-item__children", 1212 children: items.map((item, index) => /* @__PURE__ */ (0, import_jsx_runtime21.jsx)( 1213 NavigationItem, 1214 { 1215 to: item.to, 1216 shouldShowPlaceholder: false, 1217 children: item.label 1218 }, 1219 index 1220 )) 1221 } 1222 ) }) 1223 ] }); 1224 } 1225 1226 // packages/boot/build-module/components/navigation/navigation-screen/index.js 1227 var import_components9 = __toESM(require_components()); 1228 var import_i18n4 = __toESM(require_i18n()); 1229 var import_compose2 = __toESM(require_compose()); 1230 var import_jsx_runtime22 = __toESM(require_jsx_runtime()); 1231 var css6 = `/** 1232 * SCSS Variables. 1233 * 1234 * Please use variables from this sheet to ensure consistency across the UI. 1235 * Don't add to this sheet unless you're pretty sure the value will be reused in many places. 1236 * For example, don't add rules to this sheet that affect block visuals. It's purely for UI. 1237 */ 1238 /** 1239 * Colors 1240 */ 1241 /** 1242 * Fonts & basic variables. 1243 */ 1244 /** 1245 * Typography 1246 */ 1247 /** 1248 * Grid System. 1249 * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/ 1250 */ 1251 /** 1252 * Radius scale. 1253 */ 1254 /** 1255 * Elevation scale. 1256 */ 1257 /** 1258 * Dimensions. 1259 */ 1260 /** 1261 * Mobile specific styles 1262 */ 1263 /** 1264 * Editor styles. 1265 */ 1266 /** 1267 * Block & Editor UI. 1268 */ 1269 /** 1270 * Block paddings. 1271 */ 1272 /** 1273 * React Native specific. 1274 * These variables do not appear to be used anywhere else. 1275 */ 1276 .boot-navigation-screen { 1277 padding-block-end: 4px; 1278 } 1279 1280 .boot-navigation-screen .components-text { 1281 color: var(--wpds-color-fg-content-neutral, #1e1e1e); 1282 } 1283 1284 .boot-navigation-screen__title-icon { 1285 position: sticky; 1286 top: 0; 1287 padding: 12px 16px 8px 16px; 1288 } 1289 1290 .boot-navigation-screen__title { 1291 flex-grow: 1; 1292 overflow-wrap: break-word; 1293 } 1294 .boot-navigation-screen__title.boot-navigation-screen__title, .boot-navigation-screen__title.boot-navigation-screen__title .boot-navigation-screen__title { 1295 line-height: 32px; 1296 color: var(--wpds-color-fg-content-neutral, #1e1e1e); 1297 } 1298 1299 .boot-navigation-screen__actions { 1300 display: flex; 1301 flex-shrink: 0; 1302 } 1303 /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/navigation/navigation-screen","sources":["../../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../../node_modules/@wordpress/base-styles/_colors.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEjKA;EAEC,mBFgDc;;;AE7Cf;EACC;;;AAGD;EACC;EACA;EACA,SACC;;;AAIF;EACC;EACA;;AAEA;EAEC,aFSyB;EERzB;;;AAIF;EACC;EACA","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","@use \"@wordpress/base-styles/variables\";\n\n.boot-navigation-screen {\n\t// Avoid cutting off focus ring of the last menu item\n\tpadding-block-end: variables.$grid-unit-05;\n}\n\n.boot-navigation-screen .components-text {\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n}\n\n.boot-navigation-screen__title-icon {\n\tposition: sticky;\n\ttop: 0;\n\tpadding:\n\t\tvariables.$grid-unit-15 variables.$grid-unit-20\n\t\tvariables.$grid-unit-10 variables.$grid-unit-20;\n}\n\n.boot-navigation-screen__title {\n\tflex-grow: 1;\n\toverflow-wrap: break-word;\n\n\t&#{&},\n\t&#{&} .boot-navigation-screen__title {\n\t\tline-height: variables.$font-line-height-x-large;\n\t\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n\t}\n}\n\n.boot-navigation-screen__actions {\n\tdisplay: flex;\n\tflex-shrink: 0;\n}\n"]} */`; 1304 document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css6)); 1305 var ANIMATION_DURATION2 = 0.3; 1306 var slideVariants = { 1307 initial: (direction) => ({ 1308 x: direction === "forward" ? 100 : -100, 1309 opacity: 0 1310 }), 1311 animate: { 1312 x: 0, 1313 opacity: 1 1314 }, 1315 exit: (direction) => ({ 1316 x: direction === "forward" ? 100 : -100, 1317 opacity: 0 1318 }) 1319 }; 1320 function NavigationScreen({ 1321 isRoot, 1322 title, 1323 actions, 1324 content, 1325 description, 1326 animationDirection, 1327 backMenuItem, 1328 backButtonRef, 1329 navigationKey, 1330 onNavigate 1331 }) { 1332 const icon = (0, import_i18n4.isRTL)() ? chevron_right_default : chevron_left_default; 1333 const disableMotion = (0, import_compose2.useReducedMotion)(); 1334 const handleBackClick = (e) => { 1335 e.preventDefault(); 1336 onNavigate({ id: backMenuItem, direction: "backward" }); 1337 }; 1338 return /* @__PURE__ */ (0, import_jsx_runtime22.jsx)( 1339 "div", 1340 { 1341 className: "boot-navigation-screen", 1342 style: { 1343 overflow: "hidden", 1344 position: "relative", 1345 display: "grid", 1346 gridTemplateColumns: "1fr", 1347 gridTemplateRows: "1fr" 1348 }, 1349 children: /* @__PURE__ */ (0, import_jsx_runtime22.jsx)(import_components9.__unstableAnimatePresence, { initial: false, children: /* @__PURE__ */ (0, import_jsx_runtime22.jsxs)( 1350 import_components9.__unstableMotion.div, 1351 { 1352 custom: animationDirection, 1353 variants: slideVariants, 1354 initial: "initial", 1355 animate: "animate", 1356 exit: "exit", 1357 transition: { 1358 type: "tween", 1359 duration: disableMotion ? 0 : ANIMATION_DURATION2, 1360 ease: [0.33, 0, 0, 1] 1361 }, 1362 style: { 1363 width: "100%", 1364 gridColumn: "1", 1365 gridRow: "1" 1366 }, 1367 children: [ 1368 /* @__PURE__ */ (0, import_jsx_runtime22.jsxs)( 1369 import_components9.__experimentalHStack, 1370 { 1371 spacing: 2, 1372 className: "boot-navigation-screen__title-icon", 1373 children: [ 1374 !isRoot && /* @__PURE__ */ (0, import_jsx_runtime22.jsx)( 1375 import_components9.Button, 1376 { 1377 ref: backButtonRef, 1378 icon, 1379 onClick: handleBackClick, 1380 label: (0, import_i18n4.__)("Back"), 1381 size: "small", 1382 variant: "tertiary" 1383 } 1384 ), 1385 /* @__PURE__ */ (0, import_jsx_runtime22.jsx)( 1386 import_components9.__experimentalHeading, 1387 { 1388 className: "boot-navigation-screen__title", 1389 level: 1, 1390 size: "15px", 1391 children: title 1392 } 1393 ), 1394 actions && /* @__PURE__ */ (0, import_jsx_runtime22.jsx)("div", { className: "boot-navigation-screen__actions", children: actions }) 1395 ] 1396 } 1397 ), 1398 description && /* @__PURE__ */ (0, import_jsx_runtime22.jsx)("div", { className: "boot-navigation-screen__description", children: description }), 1399 content 1400 ] 1401 }, 1402 navigationKey 1403 ) }) 1404 } 1405 ); 1406 } 1407 1408 // packages/boot/build-module/components/navigation/use-sidebar-parent.js 1409 var import_element5 = __toESM(require_element()); 1410 var import_data5 = __toESM(require_data()); 1411 import { privateApis as routePrivateApis3 } from "@wordpress/route"; 1412 1413 // packages/boot/build-module/components/navigation/path-matching.js 1414 var isValidParentPath = (currentPath, menuPath) => { 1415 if (!menuPath || menuPath === currentPath) { 1416 return false; 1417 } 1418 const normalizePath = (path) => { 1419 const normalized = path.startsWith("/") ? path : "/" + path; 1420 return normalized.endsWith("/") && normalized.length > 1 ? normalized.slice(0, -1) : normalized; 1421 }; 1422 const normalizedCurrent = normalizePath(currentPath); 1423 const normalizedMenu = normalizePath(menuPath); 1424 return normalizedCurrent.startsWith(normalizedMenu) && (normalizedCurrent[normalizedMenu.length] === "/" || normalizedMenu === "/"); 1425 }; 1426 var findClosestMenuItem = (currentPath, menuItems) => { 1427 const exactMatch = menuItems.find((item) => item.to === currentPath); 1428 if (exactMatch) { 1429 return exactMatch; 1430 } 1431 let bestMatch = null; 1432 let bestPathLength = 0; 1433 for (const item of menuItems) { 1434 if (!item.to) { 1435 continue; 1436 } 1437 if (isValidParentPath(currentPath, item.to)) { 1438 if (item.to.length > bestPathLength) { 1439 bestMatch = item; 1440 bestPathLength = item.to.length; 1441 } 1442 } 1443 } 1444 return bestMatch; 1445 }; 1446 var findDrilldownParent = (id, menuItems) => { 1447 if (!id) { 1448 return void 0; 1449 } 1450 const currentItem = menuItems.find((item) => item.id === id); 1451 if (!currentItem) { 1452 return void 0; 1453 } 1454 if (currentItem.parent) { 1455 const parentItem = menuItems.find( 1456 (item) => item.id === currentItem.parent 1457 ); 1458 if (parentItem?.parent_type === "drilldown") { 1459 return parentItem.id; 1460 } 1461 if (parentItem) { 1462 return findDrilldownParent(parentItem.id, menuItems); 1463 } 1464 } 1465 return void 0; 1466 }; 1467 var findDropdownParent = (id, menuItems) => { 1468 if (!id) { 1469 return void 0; 1470 } 1471 const currentItem = menuItems.find((item) => item.id === id); 1472 if (!currentItem) { 1473 return void 0; 1474 } 1475 if (currentItem.parent) { 1476 const parentItem = menuItems.find( 1477 (item) => item.id === currentItem.parent 1478 ); 1479 if (parentItem?.parent_type === "dropdown") { 1480 return parentItem.id; 1481 } 1482 } 1483 return void 0; 1484 }; 1485 1486 // packages/boot/build-module/components/navigation/use-sidebar-parent.js 1487 var { useRouter: useRouter2, useMatches } = unlock(routePrivateApis3); 1488 function useSidebarParent() { 1489 const matches = useMatches(); 1490 const router = useRouter2(); 1491 const menuItems = (0, import_data5.useSelect)( 1492 (select) => ( 1493 // @ts-ignore 1494 select(STORE_NAME).getMenuItems() 1495 ), 1496 [] 1497 ); 1498 const currentPath = matches[matches.length - 1].pathname.slice( 1499 router.options.basepath?.length ?? 0 1500 ); 1501 const currentMenuItem = findClosestMenuItem(currentPath, menuItems); 1502 const [parentId, setParentId] = (0, import_element5.useState)( 1503 findDrilldownParent(currentMenuItem?.id, menuItems) 1504 ); 1505 const [parentDropdownId, setParentDropdownId] = (0, import_element5.useState)(findDropdownParent(currentMenuItem?.id, menuItems)); 1506 (0, import_element5.useEffect)(() => { 1507 const matchedMenuItem = findClosestMenuItem(currentPath, menuItems); 1508 const updatedParentId = findDrilldownParent( 1509 matchedMenuItem?.id, 1510 menuItems 1511 ); 1512 const updatedDropdownParent = findDropdownParent( 1513 matchedMenuItem?.id, 1514 menuItems 1515 ); 1516 setParentId(updatedParentId); 1517 setParentDropdownId(updatedDropdownParent); 1518 }, [currentPath, menuItems]); 1519 return [ 1520 parentId, 1521 setParentId, 1522 parentDropdownId, 1523 setParentDropdownId 1524 ]; 1525 } 1526 1527 // packages/boot/build-module/components/navigation/index.js 1528 var import_jsx_runtime23 = __toESM(require_jsx_runtime()); 1529 function Navigation() { 1530 const backButtonRef = (0, import_element6.useRef)(null); 1531 const [animationDirection, setAnimationDirection] = (0, import_element6.useState)(null); 1532 const [parentId, setParentId, parentDropdownId, setParentDropdownId] = useSidebarParent(); 1533 const menuItems = (0, import_data6.useSelect)( 1534 (select) => ( 1535 // @ts-ignore 1536 select(STORE_NAME).getMenuItems() 1537 ), 1538 [] 1539 ); 1540 const parent = (0, import_element6.useMemo)( 1541 () => menuItems.find((item) => item.id === parentId), 1542 [menuItems, parentId] 1543 ); 1544 const navigationKey = parent ? `drilldown-$parent.id}` : "root"; 1545 const handleNavigate = ({ 1546 id, 1547 direction 1548 }) => { 1549 setAnimationDirection(direction); 1550 setParentId(id); 1551 }; 1552 const handleDropdownToggle = (dropdownId) => { 1553 setParentDropdownId( 1554 parentDropdownId === dropdownId ? void 0 : dropdownId 1555 ); 1556 }; 1557 const items = (0, import_element6.useMemo)( 1558 () => menuItems.filter((item) => item.parent === parentId), 1559 [menuItems, parentId] 1560 ); 1561 const hasRealIcons = items.some((item) => !!item.icon); 1562 return /* @__PURE__ */ (0, import_jsx_runtime23.jsx)( 1563 NavigationScreen, 1564 { 1565 isRoot: !parent, 1566 title: parent ? parent.label : "", 1567 backMenuItem: parent?.parent, 1568 backButtonRef, 1569 animationDirection: animationDirection || void 0, 1570 navigationKey, 1571 onNavigate: handleNavigate, 1572 content: /* @__PURE__ */ (0, import_jsx_runtime23.jsx)(import_jsx_runtime23.Fragment, { children: items.map((item) => { 1573 if (item.parent_type === "dropdown") { 1574 return /* @__PURE__ */ (0, import_jsx_runtime23.jsx)( 1575 DropdownItem, 1576 { 1577 id: item.id, 1578 className: "boot-navigation-item", 1579 icon: item.icon, 1580 shouldShowPlaceholder: hasRealIcons, 1581 isExpanded: parentDropdownId === item.id, 1582 onToggle: () => handleDropdownToggle(item.id), 1583 children: item.label 1584 }, 1585 item.id 1586 ); 1587 } 1588 if (item.parent_type === "drilldown") { 1589 return /* @__PURE__ */ (0, import_jsx_runtime23.jsx)( 1590 DrilldownItem, 1591 { 1592 id: item.id, 1593 icon: item.icon, 1594 shouldShowPlaceholder: hasRealIcons, 1595 onNavigate: handleNavigate, 1596 children: item.label 1597 }, 1598 item.id 1599 ); 1600 } 1601 return /* @__PURE__ */ (0, import_jsx_runtime23.jsx)( 1602 NavigationItem, 1603 { 1604 to: item.to, 1605 icon: item.icon, 1606 shouldShowPlaceholder: hasRealIcons, 1607 children: item.label 1608 }, 1609 item.id 1610 ); 1611 }) }) 1612 } 1613 ); 1614 } 1615 var navigation_default = Navigation; 1616 1617 // packages/boot/build-module/components/save-button/index.js 1618 var import_element8 = __toESM(require_element()); 1619 var import_data8 = __toESM(require_data()); 1620 var import_i18n6 = __toESM(require_i18n()); 1621 var import_core_data4 = __toESM(require_core_data()); 1622 var import_keycodes2 = __toESM(require_keycodes()); 1623 var import_editor2 = __toESM(require_editor()); 1624 var import_components10 = __toESM(require_components()); 1625 1626 // packages/boot/build-module/components/save-panel/use-save-shortcut.js 1627 var import_element7 = __toESM(require_element()); 1628 var import_keyboard_shortcuts = __toESM(require_keyboard_shortcuts()); 1629 var import_i18n5 = __toESM(require_i18n()); 1630 var import_data7 = __toESM(require_data()); 1631 var import_core_data3 = __toESM(require_core_data()); 1632 var import_editor = __toESM(require_editor()); 1633 var shortcutName = "core/boot/save"; 1634 function useSaveShortcut({ 1635 openSavePanel 1636 }) { 1637 const { __experimentalGetDirtyEntityRecords, isSavingEntityRecord } = (0, import_data7.useSelect)(import_core_data3.store); 1638 const { hasNonPostEntityChanges, isPostSavingLocked } = (0, import_data7.useSelect)(import_editor.store); 1639 const { savePost } = (0, import_data7.useDispatch)(import_editor.store); 1640 const { registerShortcut, unregisterShortcut } = (0, import_data7.useDispatch)( 1641 import_keyboard_shortcuts.store 1642 ); 1643 (0, import_element7.useEffect)(() => { 1644 registerShortcut({ 1645 name: shortcutName, 1646 category: "global", 1647 description: (0, import_i18n5.__)("Save your changes."), 1648 keyCombination: { 1649 modifier: "primary", 1650 character: "s" 1651 } 1652 }); 1653 return () => { 1654 unregisterShortcut(shortcutName); 1655 }; 1656 }, [registerShortcut, unregisterShortcut]); 1657 (0, import_keyboard_shortcuts.useShortcut)(shortcutName, (event) => { 1658 event.preventDefault(); 1659 const dirtyEntityRecords = __experimentalGetDirtyEntityRecords(); 1660 const hasDirtyEntities = !!dirtyEntityRecords.length; 1661 const isSaving = dirtyEntityRecords.some( 1662 (record) => isSavingEntityRecord(record.kind, record.name, record.key) 1663 ); 1664 if (!hasDirtyEntities || isSaving) { 1665 return; 1666 } 1667 if (hasNonPostEntityChanges()) { 1668 openSavePanel(); 1669 } else if (!isPostSavingLocked()) { 1670 savePost(); 1671 } 1672 }); 1673 } 1674 1675 // packages/boot/build-module/components/save-button/index.js 1676 var import_jsx_runtime24 = __toESM(require_jsx_runtime()); 1677 var css7 = `.boot-save-button { 1678 width: 100%; 1679 } 1680 /*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VSb290IjoiL2hvbWUvc3ZuL2NoZWNrb3V0cy9kZXZlbG9wLnN2bi53b3JkcHJlc3Mub3JnL3RydW5rL2d1dGVuYmVyZy9wYWNrYWdlcy9ib290L3NyYy9jb21wb25lbnRzL3NhdmUtYnV0dG9uIiwic291cmNlcyI6WyJzdHlsZS5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0VBQ0MiLCJzb3VyY2VzQ29udGVudCI6WyIuYm9vdC1zYXZlLWJ1dHRvbiB7XG5cdHdpZHRoOiAxMDAlO1xufVxuIl19 */`; 1681 document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css7)); 1682 function SaveButton() { 1683 const [isSaveViewOpen, setIsSaveViewOpened] = (0, import_element8.useState)(false); 1684 const { isSaving, dirtyEntityRecordsCount } = (0, import_data8.useSelect)((select) => { 1685 const { isSavingEntityRecord, __experimentalGetDirtyEntityRecords } = select(import_core_data4.store); 1686 const dirtyEntityRecords = __experimentalGetDirtyEntityRecords(); 1687 return { 1688 isSaving: dirtyEntityRecords.some( 1689 (record) => isSavingEntityRecord(record.kind, record.name, record.key) 1690 ), 1691 dirtyEntityRecordsCount: dirtyEntityRecords.length 1692 }; 1693 }, []); 1694 const [showSavedState, setShowSavedState] = (0, import_element8.useState)(false); 1695 (0, import_element8.useEffect)(() => { 1696 if (isSaving) { 1697 setShowSavedState(true); 1698 } 1699 }, [isSaving]); 1700 const hasChanges = dirtyEntityRecordsCount > 0; 1701 (0, import_element8.useEffect)(() => { 1702 if (!isSaving && hasChanges) { 1703 setShowSavedState(false); 1704 } 1705 }, [isSaving, hasChanges]); 1706 function hideSavedState() { 1707 if (showSavedState) { 1708 setShowSavedState(false); 1709 } 1710 } 1711 const shouldShowButton = hasChanges || showSavedState; 1712 useSaveShortcut({ openSavePanel: () => setIsSaveViewOpened(true) }); 1713 if (!shouldShowButton) { 1714 return null; 1715 } 1716 const isInSavedState = showSavedState && !hasChanges; 1717 const disabled = isSaving || isInSavedState; 1718 const getLabel = () => { 1719 if (isInSavedState) { 1720 return (0, import_i18n6.__)("Saved"); 1721 } 1722 return (0, import_i18n6.sprintf)( 1723 // translators: %d: number of unsaved changes (number). 1724 (0, import_i18n6._n)( 1725 "Review %d change\u2026", 1726 "Review %d changes\u2026", 1727 dirtyEntityRecordsCount 1728 ), 1729 dirtyEntityRecordsCount 1730 ); 1731 }; 1732 const label = getLabel(); 1733 return /* @__PURE__ */ (0, import_jsx_runtime24.jsxs)(import_jsx_runtime24.Fragment, { children: [ 1734 /* @__PURE__ */ (0, import_jsx_runtime24.jsx)( 1735 import_components10.Tooltip, 1736 { 1737 text: hasChanges ? label : void 0, 1738 shortcut: import_keycodes2.displayShortcut.primary("s"), 1739 children: /* @__PURE__ */ (0, import_jsx_runtime24.jsx)( 1740 import_components10.Button, 1741 { 1742 variant: "primary", 1743 size: "compact", 1744 onClick: () => setIsSaveViewOpened(true), 1745 onBlur: hideSavedState, 1746 disabled, 1747 accessibleWhenDisabled: true, 1748 isBusy: isSaving, 1749 "aria-keyshortcuts": import_keycodes2.rawShortcut.primary("s"), 1750 className: "boot-save-button", 1751 icon: isInSavedState ? check_default : void 0, 1752 children: label 1753 } 1754 ) 1755 } 1756 ), 1757 isSaveViewOpen && /* @__PURE__ */ (0, import_jsx_runtime24.jsx)( 1758 import_components10.Modal, 1759 { 1760 title: (0, import_i18n6.__)("Review changes"), 1761 onRequestClose: () => setIsSaveViewOpened(false), 1762 size: "small", 1763 children: /* @__PURE__ */ (0, import_jsx_runtime24.jsx)( 1764 import_editor2.EntitiesSavedStates, 1765 { 1766 close: () => setIsSaveViewOpened(false), 1767 variant: "inline" 1768 } 1769 ) 1770 } 1771 ) 1772 ] }); 1773 } 1774 1775 // packages/boot/build-module/components/sidebar/index.js 1776 var import_jsx_runtime25 = __toESM(require_jsx_runtime()); 1777 var css8 = `/** 1778 * SCSS Variables. 1779 * 1780 * Please use variables from this sheet to ensure consistency across the UI. 1781 * Don't add to this sheet unless you're pretty sure the value will be reused in many places. 1782 * For example, don't add rules to this sheet that affect block visuals. It's purely for UI. 1783 */ 1784 /** 1785 * Colors 1786 */ 1787 /** 1788 * Fonts & basic variables. 1789 */ 1790 /** 1791 * Typography 1792 */ 1793 /** 1794 * Grid System. 1795 * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/ 1796 */ 1797 /** 1798 * Radius scale. 1799 */ 1800 /** 1801 * Elevation scale. 1802 */ 1803 /** 1804 * Dimensions. 1805 */ 1806 /** 1807 * Mobile specific styles 1808 */ 1809 /** 1810 * Editor styles. 1811 */ 1812 /** 1813 * Block & Editor UI. 1814 */ 1815 /** 1816 * Block paddings. 1817 */ 1818 /** 1819 * React Native specific. 1820 * These variables do not appear to be used anywhere else. 1821 */ 1822 .boot-sidebar__scrollable { 1823 overflow: auto; 1824 height: 100%; 1825 position: relative; 1826 display: flex; 1827 flex-direction: column; 1828 } 1829 1830 .boot-sidebar__content { 1831 flex-grow: 1; 1832 contain: content; 1833 position: relative; 1834 } 1835 1836 .boot-sidebar__footer { 1837 padding: 16px 8px 8px 16px; 1838 } 1839 /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/sidebar","sources":["../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../node_modules/@wordpress/base-styles/_colors.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEjKA;EACC;EACA;EACA;EACA;EACA;;;AAGD;EACC;EACA;EACA;;;AAGD;EACC","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","@use \"@wordpress/base-styles/variables\";\n\n.boot-sidebar__scrollable {\n\toverflow: auto;\n\theight: 100%;\n\tposition: relative;\n\tdisplay: flex;\n\tflex-direction: column;\n}\n\n.boot-sidebar__content {\n\tflex-grow: 1;\n\tcontain: content;\n\tposition: relative;\n}\n\n.boot-sidebar__footer {\n\tpadding: variables.$grid-unit-20 variables.$grid-unit-10 variables.$grid-unit-10 variables.$grid-unit-20;\n}\n"]} */`; 1840 document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css8)); 1841 function Sidebar() { 1842 return /* @__PURE__ */ (0, import_jsx_runtime25.jsxs)("div", { className: "boot-sidebar__scrollable", children: [ 1843 /* @__PURE__ */ (0, import_jsx_runtime25.jsx)(site_hub_default, {}), 1844 /* @__PURE__ */ (0, import_jsx_runtime25.jsx)("div", { className: "boot-sidebar__content", children: /* @__PURE__ */ (0, import_jsx_runtime25.jsx)(navigation_default, {}) }), 1845 /* @__PURE__ */ (0, import_jsx_runtime25.jsx)("div", { className: "boot-sidebar__footer", children: /* @__PURE__ */ (0, import_jsx_runtime25.jsx)(SaveButton, {}) }) 1846 ] }); 1847 } 1848 1849 // packages/boot/build-module/components/save-panel/index.js 1850 var import_element9 = __toESM(require_element()); 1851 var import_components11 = __toESM(require_components()); 1852 var import_editor3 = __toESM(require_editor()); 1853 var import_i18n7 = __toESM(require_i18n()); 1854 var import_jsx_runtime26 = __toESM(require_jsx_runtime()); 1855 function SavePanel() { 1856 const [isOpen, setIsOpen] = (0, import_element9.useState)(false); 1857 useSaveShortcut({ 1858 openSavePanel: () => setIsOpen(true) 1859 }); 1860 if (!isOpen) { 1861 return false; 1862 } 1863 return /* @__PURE__ */ (0, import_jsx_runtime26.jsx)( 1864 import_components11.Modal, 1865 { 1866 className: "edit-site-save-panel__modal", 1867 onRequestClose: () => setIsOpen(false), 1868 title: (0, import_i18n7.__)("Review changes"), 1869 size: "small", 1870 children: /* @__PURE__ */ (0, import_jsx_runtime26.jsx)( 1871 import_editor3.EntitiesSavedStates, 1872 { 1873 close: () => setIsOpen(false), 1874 variant: "inline" 1875 } 1876 ) 1877 } 1878 ); 1879 } 1880 1881 // packages/boot/build-module/components/canvas-renderer/index.js 1882 var import_element11 = __toESM(require_element()); 1883 1884 // packages/boot/build-module/components/canvas/index.js 1885 var import_element10 = __toESM(require_element()); 1886 var import_components13 = __toESM(require_components()); 1887 import { useNavigate } from "@wordpress/route"; 1888 1889 // packages/boot/build-module/components/canvas/back-button.js 1890 var import_components12 = __toESM(require_components()); 1891 var import_compose3 = __toESM(require_compose()); 1892 var import_i18n8 = __toESM(require_i18n()); 1893 var import_jsx_runtime27 = __toESM(require_jsx_runtime()); 1894 var css9 = `/** 1895 * SCSS Variables. 1896 * 1897 * Please use variables from this sheet to ensure consistency across the UI. 1898 * Don't add to this sheet unless you're pretty sure the value will be reused in many places. 1899 * For example, don't add rules to this sheet that affect block visuals. It's purely for UI. 1900 */ 1901 /** 1902 * Colors 1903 */ 1904 /** 1905 * Fonts & basic variables. 1906 */ 1907 /** 1908 * Typography 1909 */ 1910 /** 1911 * Grid System. 1912 * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/ 1913 */ 1914 /** 1915 * Radius scale. 1916 */ 1917 /** 1918 * Elevation scale. 1919 */ 1920 /** 1921 * Dimensions. 1922 */ 1923 /** 1924 * Mobile specific styles 1925 */ 1926 /** 1927 * Editor styles. 1928 */ 1929 /** 1930 * Block & Editor UI. 1931 */ 1932 /** 1933 * Block paddings. 1934 */ 1935 /** 1936 * React Native specific. 1937 * These variables do not appear to be used anywhere else. 1938 */ 1939 .boot-canvas-back-button { 1940 position: absolute; 1941 top: 0; 1942 left: 0; 1943 height: 64px; 1944 width: 64px; 1945 z-index: 100; 1946 } 1947 1948 .boot-canvas-back-button__container { 1949 position: relative; 1950 width: 100%; 1951 height: 100%; 1952 } 1953 1954 .boot-canvas-back-button__link.components-button { 1955 width: 64px; 1956 height: 64px; 1957 display: inline-flex; 1958 align-items: center; 1959 justify-content: center; 1960 background: var(--wpds-color-bg-surface-neutral-weak); 1961 text-decoration: none; 1962 padding: 0; 1963 border-radius: 0; 1964 } 1965 @media not (prefers-reduced-motion) { 1966 .boot-canvas-back-button__link.components-button { 1967 transition: outline 0.1s ease-out; 1968 } 1969 } 1970 .boot-canvas-back-button__link.components-button:focus:not(:active) { 1971 outline: var(--wpds-border-width-interactive-focus) solid var(--wpds-color-stroke-focus-brand); 1972 outline-offset: calc(-1 * var(--wpds-border-width-interactive-focus)); 1973 } 1974 1975 .boot-canvas-back-button__icon { 1976 position: absolute; 1977 top: 0; 1978 left: 0; 1979 width: 64px; 1980 height: 64px; 1981 display: flex; 1982 align-items: center; 1983 justify-content: center; 1984 background-color: hsl(0, 0%, 80%); 1985 pointer-events: none; 1986 } 1987 .boot-canvas-back-button__icon svg { 1988 fill: currentColor; 1989 } 1990 .boot-canvas-back-button__icon.has-site-icon { 1991 background-color: hsla(0, 0%, 100%, 0.6); 1992 -webkit-backdrop-filter: saturate(180%) blur(15px); 1993 backdrop-filter: saturate(180%) blur(15px); 1994 } 1995 1996 .interface-interface-skeleton__header { 1997 margin-top: 0 !important; 1998 } 1999 /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/canvas","sources":["../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../node_modules/@wordpress/base-styles/_colors.scss","back-button.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEjKA;EACC;EACA;EACA;EACA,QF6Fe;EE5Ff,OF4Fe;EE3Ff;;;AAGD;EACC;EACA;EACA;;;AAGD;EACC,OFiFe;EEhFf,QFgFe;EE/Ef;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EAXD;IAYE;;;AAGD;EACC,SACC;EAED;;;AAIF;EACC;EACA;EACA;EACA,OFuDe;EEtDf,QFsDe;EErDf;EACA;EACA;EACA;EACA;;AAEA;EACC;;AAGD;EACC;EACA;EACA;;;AAKF;EACC","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","@use \"@wordpress/base-styles/variables\";\n\n.boot-canvas-back-button {\n\tposition: absolute;\n\ttop: 0;\n\tleft: 0;\n\theight: variables.$header-height;\n\twidth: variables.$header-height;\n\tz-index: 100;\n}\n\n.boot-canvas-back-button__container {\n\tposition: relative;\n\twidth: 100%;\n\theight: 100%;\n}\n\n.boot-canvas-back-button__link.components-button {\n\twidth: variables.$header-height;\n\theight: variables.$header-height;\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n\tbackground: var(--wpds-color-bg-surface-neutral-weak);\n\ttext-decoration: none;\n\tpadding: 0;\n\tborder-radius: 0;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: outline 0.1s ease-out;\n\t}\n\n\t&:focus:not(:active) {\n\t\toutline:\n\t\t\tvar(--wpds-border-width-interactive-focus) solid\n\t\t\tvar(--wpds-color-stroke-focus-brand);\n\t\toutline-offset: calc(-1 * var(--wpds-border-width-interactive-focus));\n\t}\n}\n\n.boot-canvas-back-button__icon {\n\tposition: absolute;\n\ttop: 0;\n\tleft: 0;\n\twidth: variables.$header-height;\n\theight: variables.$header-height;\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tbackground-color: hsla(0, 0%, 80%);\n\tpointer-events: none;\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n\n\t&.has-site-icon {\n\t\tbackground-color: hsla(0, 0%, 100%, 0.6);\n\t\t-webkit-backdrop-filter: saturate(180%) blur(15px);\n\t\tbackdrop-filter: saturate(180%) blur(15px);\n\t}\n}\n\n// Remove the header slide-in animation so the back logo does not move.\n.interface-interface-skeleton__header {\n\tmargin-top: 0 !important;\n}\n"]} */`; 2000 document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css9)); 2001 var toggleHomeIconVariants = { 2002 edit: { 2003 opacity: 0, 2004 scale: 0.2 2005 }, 2006 hover: { 2007 opacity: 1, 2008 scale: 1, 2009 clipPath: "inset( 22% round 2px )" 2010 } 2011 }; 2012 function BootBackButton({ length }) { 2013 const disableMotion = (0, import_compose3.useReducedMotion)(); 2014 const handleBack = () => { 2015 window.history.back(); 2016 }; 2017 if (length > 1) { 2018 return null; 2019 } 2020 const transition = { 2021 duration: disableMotion ? 0 : 0.3 2022 }; 2023 return /* @__PURE__ */ (0, import_jsx_runtime27.jsxs)( 2024 import_components12.__unstableMotion.div, 2025 { 2026 className: "boot-canvas-back-button", 2027 animate: "edit", 2028 initial: "edit", 2029 whileHover: "hover", 2030 whileTap: "tap", 2031 transition, 2032 children: [ 2033 /* @__PURE__ */ (0, import_jsx_runtime27.jsx)( 2034 import_components12.Button, 2035 { 2036 className: "boot-canvas-back-button__link", 2037 onClick: handleBack, 2038 "aria-label": (0, import_i18n8.__)("Go back"), 2039 __next40pxDefaultSize: true, 2040 children: /* @__PURE__ */ (0, import_jsx_runtime27.jsx)(site_icon_default, {}) 2041 } 2042 ), 2043 /* @__PURE__ */ (0, import_jsx_runtime27.jsx)( 2044 import_components12.__unstableMotion.div, 2045 { 2046 className: "boot-canvas-back-button__icon", 2047 variants: toggleHomeIconVariants, 2048 children: /* @__PURE__ */ (0, import_jsx_runtime27.jsx)(import_components12.Icon, { icon: arrow_up_left_default }) 2049 } 2050 ) 2051 ] 2052 } 2053 ); 2054 } 2055 2056 // packages/boot/build-module/components/canvas/index.js 2057 var import_jsx_runtime28 = __toESM(require_jsx_runtime()); 2058 function Canvas({ canvas }) { 2059 const [Editor, setEditor] = (0, import_element10.useState)(null); 2060 const navigate = useNavigate(); 2061 (0, import_element10.useEffect)(() => { 2062 import("@wordpress/lazy-editor").then((module) => { 2063 setEditor(() => module.Editor); 2064 }).catch((error) => { 2065 console.error("Failed to load lazy editor:", error); 2066 }); 2067 }, []); 2068 if (!Editor) { 2069 return /* @__PURE__ */ (0, import_jsx_runtime28.jsx)( 2070 "div", 2071 { 2072 style: { 2073 display: "flex", 2074 justifyContent: "center", 2075 alignItems: "center", 2076 height: "100%", 2077 padding: "2rem" 2078 }, 2079 children: /* @__PURE__ */ (0, import_jsx_runtime28.jsx)(import_components13.Spinner, {}) 2080 } 2081 ); 2082 } 2083 const backButton = !canvas.isPreview ? ({ length }) => /* @__PURE__ */ (0, import_jsx_runtime28.jsx)(BootBackButton, { length }) : void 0; 2084 return /* @__PURE__ */ (0, import_jsx_runtime28.jsxs)("div", { style: { height: "100%", position: "relative" }, children: [ 2085 /* @__PURE__ */ (0, import_jsx_runtime28.jsx)( 2086 "div", 2087 { 2088 style: { height: "100%" }, 2089 inert: canvas.isPreview ? "true" : void 0, 2090 children: /* @__PURE__ */ (0, import_jsx_runtime28.jsx)( 2091 Editor, 2092 { 2093 postType: canvas.postType, 2094 postId: canvas.postId, 2095 settings: { isPreviewMode: canvas.isPreview }, 2096 backButton 2097 } 2098 ) 2099 } 2100 ), 2101 canvas.isPreview && canvas.editLink && /* @__PURE__ */ (0, import_jsx_runtime28.jsx)( 2102 "div", 2103 { 2104 onClick: () => navigate({ to: canvas.editLink }), 2105 onKeyDown: (e) => { 2106 if (e.key === "Enter" || e.key === " ") { 2107 e.preventDefault(); 2108 navigate({ to: canvas.editLink }); 2109 } 2110 }, 2111 style: { 2112 position: "absolute", 2113 inset: 0, 2114 cursor: "pointer", 2115 zIndex: 1 2116 }, 2117 role: "button", 2118 tabIndex: 0, 2119 "aria-label": "Click to edit" 2120 } 2121 ) 2122 ] }); 2123 } 2124 2125 // packages/boot/build-module/components/canvas-renderer/index.js 2126 var import_jsx_runtime29 = __toESM(require_jsx_runtime()); 2127 function CanvasRenderer({ 2128 canvas, 2129 routeContentModule 2130 }) { 2131 const [CustomCanvas, setCustomCanvas] = (0, import_element11.useState)(null); 2132 (0, import_element11.useEffect)(() => { 2133 if (canvas === null && routeContentModule) { 2134 import(routeContentModule).then((module) => { 2135 setCustomCanvas(() => module.canvas); 2136 }).catch((error) => { 2137 console.error("Failed to load custom canvas:", error); 2138 }); 2139 } else { 2140 setCustomCanvas(null); 2141 } 2142 }, [canvas, routeContentModule]); 2143 if (canvas === void 0) { 2144 return null; 2145 } 2146 if (canvas === null) { 2147 if (!CustomCanvas) { 2148 return null; 2149 } 2150 return /* @__PURE__ */ (0, import_jsx_runtime29.jsx)(CustomCanvas, {}); 2151 } 2152 return /* @__PURE__ */ (0, import_jsx_runtime29.jsx)(Canvas, { canvas }); 2153 } 2154 2155 // packages/boot/build-module/components/app/use-route-title.js 2156 var import_element12 = __toESM(require_element()); 2157 var import_data9 = __toESM(require_data()); 2158 var import_core_data5 = __toESM(require_core_data()); 2159 var import_i18n9 = __toESM(require_i18n()); 2160 var import_html_entities2 = __toESM(require_html_entities()); 2161 import { speak } from "@wordpress/a11y"; 2162 import { privateApis as routePrivateApis4 } from "@wordpress/route"; 2163 var { useLocation, useMatches: useMatches2 } = unlock(routePrivateApis4); 2164 function useRouteTitle() { 2165 const location = useLocation(); 2166 const matches = useMatches2(); 2167 const currentMatch = matches[matches.length - 1]; 2168 const routeTitle = currentMatch?.loaderData?.title; 2169 const siteTitle = (0, import_data9.useSelect)( 2170 (select) => select(import_core_data5.store).getEntityRecord( 2171 "root", 2172 "__unstableBase" 2173 )?.name, 2174 [] 2175 ); 2176 const isInitialLocationRef = (0, import_element12.useRef)(true); 2177 (0, import_element12.useEffect)(() => { 2178 isInitialLocationRef.current = false; 2179 }, [location]); 2180 (0, import_element12.useEffect)(() => { 2181 if (isInitialLocationRef.current) { 2182 return; 2183 } 2184 if (routeTitle && typeof routeTitle === "string" && siteTitle && typeof siteTitle === "string") { 2185 const decodedRouteTitle = (0, import_html_entities2.decodeEntities)(routeTitle); 2186 const decodedSiteTitle = (0, import_html_entities2.decodeEntities)(siteTitle); 2187 const formattedTitle = (0, import_i18n9.sprintf)( 2188 /* translators: Admin document title. 1: Admin screen name, 2: Site name. */ 2189 (0, import_i18n9.__)("%1$s \u2039 %2$s \u2014 WordPress"), 2190 decodedRouteTitle, 2191 decodedSiteTitle 2192 ); 2193 document.title = formattedTitle; 2194 if (decodedRouteTitle) { 2195 speak(decodedRouteTitle, "assertive"); 2196 } 2197 } 2198 }, [routeTitle, siteTitle, location]); 2199 } 2200 2201 // packages/boot/build-module/components/user-theme-provider/index.js 2202 var import_theme = __toESM(require_theme()); 2203 var import_jsx_runtime30 = __toESM(require_jsx_runtime()); 2204 var ThemeProvider = unlock(import_theme.privateApis).ThemeProvider; 2205 var THEME_PRIMARY_COLORS = /* @__PURE__ */ new Map([ 2206 ["light", "#0085ba"], 2207 ["modern", "#3858e9"], 2208 ["blue", "#096484"], 2209 ["coffee", "#46403c"], 2210 ["ectoplasm", "#523f6d"], 2211 ["midnight", "#e14d43"], 2212 ["ocean", "#627c83"], 2213 ["sunrise", "#dd823b"] 2214 ]); 2215 function getAdminThemePrimaryColor() { 2216 const theme = document.body.className.match(/admin-color-([a-z]+)/)?.[1]; 2217 return theme && THEME_PRIMARY_COLORS.get(theme); 2218 } 2219 function UserThemeProvider({ 2220 color, 2221 ...restProps 2222 }) { 2223 const primary = getAdminThemePrimaryColor(); 2224 return /* @__PURE__ */ (0, import_jsx_runtime30.jsx)(ThemeProvider, { ...restProps, color: { primary, ...color } }); 2225 } 2226 2227 // packages/boot/build-module/components/root/index.js 2228 var import_jsx_runtime31 = __toESM(require_jsx_runtime()); 2229 var css10 = `/** 2230 * SCSS Variables. 2231 * 2232 * Please use variables from this sheet to ensure consistency across the UI. 2233 * Don't add to this sheet unless you're pretty sure the value will be reused in many places. 2234 * For example, don't add rules to this sheet that affect block visuals. It's purely for UI. 2235 */ 2236 /** 2237 * Colors 2238 */ 2239 /** 2240 * Fonts & basic variables. 2241 */ 2242 /** 2243 * Typography 2244 */ 2245 /** 2246 * Grid System. 2247 * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/ 2248 */ 2249 /** 2250 * Radius scale. 2251 */ 2252 /** 2253 * Elevation scale. 2254 */ 2255 /** 2256 * Dimensions. 2257 */ 2258 /** 2259 * Mobile specific styles 2260 */ 2261 /** 2262 * Editor styles. 2263 */ 2264 /** 2265 * Block & Editor UI. 2266 */ 2267 /** 2268 * Block paddings. 2269 */ 2270 /** 2271 * React Native specific. 2272 * These variables do not appear to be used anywhere else. 2273 */ 2274 /** 2275 * Typography 2276 */ 2277 /** 2278 * Breakpoints & Media Queries 2279 */ 2280 /** 2281 * Converts a hex value into the rgb equivalent. 2282 * 2283 * @param {string} hex - the hexadecimal value to convert 2284 * @return {string} comma separated rgb values 2285 */ 2286 /** 2287 * Long content fade mixin 2288 * 2289 * Creates a fading overlay to signify that the content is longer 2290 * than the space allows. 2291 */ 2292 /** 2293 * Breakpoint mixins 2294 */ 2295 /** 2296 * Focus styles. 2297 */ 2298 /** 2299 * Applies editor left position to the selector passed as argument 2300 */ 2301 /** 2302 * Styles that are reused verbatim in a few places 2303 */ 2304 /** 2305 * Allows users to opt-out of animations via OS-level preferences. 2306 */ 2307 /** 2308 * Reset default styles for JavaScript UI based pages. 2309 * This is a WP-admin agnostic reset 2310 */ 2311 /** 2312 * Reset the WP Admin page styles for Gutenberg-like pages. 2313 */ 2314 .boot-layout { 2315 height: 100%; 2316 width: 100%; 2317 display: flex; 2318 flex-direction: row; 2319 color: var(--wpds-color-fg-content-neutral, #1e1e1e); 2320 isolation: isolate; 2321 background: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0); 2322 } 2323 2324 .boot-layout__sidebar-backdrop { 2325 position: fixed; 2326 top: 0; 2327 left: 0; 2328 right: 0; 2329 bottom: 0; 2330 background-color: rgba(0, 0, 0, 0.5); 2331 z-index: 100002; 2332 cursor: pointer; 2333 } 2334 2335 .boot-layout__sidebar { 2336 height: 100%; 2337 flex-shrink: 0; 2338 width: 240px; 2339 position: relative; 2340 overflow: hidden; 2341 } 2342 .boot-layout__sidebar.is-mobile { 2343 position: fixed; 2344 top: 0; 2345 bottom: 0; 2346 left: 0; 2347 width: 300px; 2348 max-width: 85vw; 2349 background: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0); 2350 z-index: 100003; 2351 box-shadow: 2px 0 8px rgba(0, 0, 0, 0.2); 2352 } 2353 2354 .boot-layout__mobile-sidebar-drawer { 2355 position: fixed; 2356 top: 0; 2357 left: 0; 2358 right: 0; 2359 z-index: 3; 2360 background: var(--wpds-color-bg-surface-neutral, #fff); 2361 padding: 16px; 2362 border-bottom: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd); 2363 display: flex; 2364 justify-content: flex-start; 2365 align-items: center; 2366 } 2367 2368 .boot-layout__canvas.has-mobile-drawer { 2369 position: relative; 2370 padding-top: 65px; 2371 } 2372 2373 .boot-layout__surfaces { 2374 display: flex; 2375 flex-grow: 1; 2376 margin: 0; 2377 gap: 8px; 2378 } 2379 @media (min-width: 782px) { 2380 .boot-layout__surfaces { 2381 margin: 8px; 2382 } 2383 .boot-layout--single-page .boot-layout__surfaces { 2384 margin-top: 0; 2385 margin-left: 0; 2386 } 2387 } 2388 2389 .boot-layout__stage, 2390 .boot-layout__inspector { 2391 flex: 1; 2392 overflow-y: auto; 2393 background: var(--wpds-color-bg-surface-neutral, #fff); 2394 color: var(--wpds-color-fg-content-neutral, #1e1e1e); 2395 box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1); 2396 border: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd); 2397 position: relative; 2398 position: fixed; 2399 top: 0; 2400 left: 0; 2401 right: 0; 2402 bottom: 0; 2403 width: 100vw; 2404 height: 100vh; 2405 border-radius: 0; 2406 margin: 0; 2407 } 2408 @media (min-width: 782px) { 2409 .boot-layout__stage, 2410 .boot-layout__inspector { 2411 position: static; 2412 width: auto; 2413 height: auto; 2414 border-radius: 8px; 2415 margin: 0; 2416 } 2417 } 2418 2419 .boot-layout__stage { 2420 z-index: 2; 2421 } 2422 @media (min-width: 782px) { 2423 .boot-layout__stage { 2424 z-index: auto; 2425 } 2426 } 2427 2428 .boot-layout__inspector { 2429 z-index: 3; 2430 } 2431 @media (min-width: 782px) { 2432 .boot-layout__inspector { 2433 z-index: auto; 2434 } 2435 } 2436 2437 .boot-layout__canvas { 2438 flex: 1; 2439 overflow-y: auto; 2440 background: var(--wpds-color-bg-surface-neutral, #fff); 2441 color: var(--wpds-color-fg-content-neutral, #1e1e1e); 2442 box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1); 2443 border: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd); 2444 position: relative; 2445 position: fixed; 2446 top: 0; 2447 left: 0; 2448 right: 0; 2449 bottom: 0; 2450 width: 100vw; 2451 height: 100vh; 2452 z-index: 1; 2453 border-radius: 0; 2454 margin: 0; 2455 } 2456 @media (min-width: 782px) { 2457 .boot-layout__canvas { 2458 position: static; 2459 width: auto; 2460 height: auto; 2461 border-radius: 8px; 2462 z-index: auto; 2463 } 2464 } 2465 2466 @media (min-width: 782px) { 2467 .boot-layout.has-canvas .boot-layout__stage, 2468 .boot-layout__inspector { 2469 max-width: 400px; 2470 } 2471 } 2472 2473 .boot-layout__canvas .interface-interface-skeleton { 2474 position: relative; 2475 height: 100%; 2476 top: 0 !important; 2477 left: 0 !important; 2478 } 2479 2480 .boot-layout.has-full-canvas .boot-layout__surfaces { 2481 margin: 0; 2482 gap: 0; 2483 } 2484 2485 .boot-layout.has-full-canvas .boot-layout__stage, 2486 .boot-layout.has-full-canvas .boot-layout__inspector { 2487 display: none; 2488 } 2489 2490 .boot-layout.has-full-canvas .boot-layout__canvas { 2491 position: fixed; 2492 top: 0; 2493 left: 0; 2494 right: 0; 2495 bottom: 0; 2496 max-width: none; 2497 margin: 0; 2498 border-radius: 0; 2499 border: none; 2500 box-shadow: none; 2501 overflow: hidden; 2502 } 2503 /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/root","sources":["../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../node_modules/@wordpress/base-styles/_colors.scss","../../../../../node_modules/@wordpress/base-styles/_mixins.scss","../../../../../node_modules/@wordpress/base-styles/_breakpoints.scss","../../../../../node_modules/@wordpress/base-styles/_functions.scss","../../../../../node_modules/@wordpress/base-styles/_long-content-fade.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEnKA;AAAA;AAAA;ACAA;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AH4EA;AAAA;AAAA;AA0DA;AAAA;AAAA;AAgDA;AAAA;AAAA;AAqCA;AAAA;AAAA;AAoBA;AAAA;AAAA;AAwLA;AAAA;AAAA;AAAA;AAgDA;AAAA;AAAA;AIpdA;EACC;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGD;EACC;EACA;EACA;EACA;EACA;;AAEA;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAIF;EACC;EACA;EACA;EACA;EACA;EACA;EACA,SNIc;EMHd;EACA;EACA;EACA;;;AAGD;EACC;EACA;;;AAGD;EACC;EACA;EACA;EACA,KNdc;;AE0Dd;EIhDD;IAOE,QNjBa;;EMmBb;IACC;IACA;;;;AAKH;AAAA;EAEC;EACA;EACA;EACA;EACA;EACA;EACA;EAGA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AJaA;EIhCD;AAAA;IAuBE;IACA;IACA;IACA;IACA;;;;AAIF;EACC;;AJAA;EIDD;IAIE;;;;AAIF;EACC;;AJRA;EIOD;IAIE;;;;AAIF;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EAGA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AJlCA;EIeD;IAuBE;IACA;IACA;IACA;IACA;;;;AJ1CD;EI8CD;AAAA;IAGE;;;;AAIF;EACC;EACA;EACA;EACA;;;AAID;EACC;EACA;;;AAGD;AAAA;EAEC;;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","/**\n * Typography\n */\n\n@use \"sass:color\";\n@use \"sass:math\";\n@use \"./variables\";\n@use \"./colors\";\n@use \"./breakpoints\";\n@use \"./functions\";\n@use \"./long-content-fade\";\n\n@mixin _text-heading() {\n\tfont-family: variables.$font-family-headings;\n\tfont-weight: variables.$font-weight-medium;\n}\n\n@mixin _text-body() {\n\tfont-family: variables.$font-family-body;\n\tfont-weight: variables.$font-weight-regular;\n}\n\n@mixin heading-small() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-x-small;\n\tline-height: variables.$font-line-height-x-small;\n}\n\n@mixin heading-medium() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-medium;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin heading-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-large;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin heading-x-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-x-large;\n\tline-height: variables.$font-line-height-medium;\n}\n\n@mixin heading-2x-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-2x-large;\n\tline-height: variables.$font-line-height-2x-large;\n}\n\n@mixin body-small() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-small;\n\tline-height: variables.$font-line-height-x-small;\n}\n\n@mixin body-medium() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-medium;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin body-large() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-large;\n\tline-height: variables.$font-line-height-medium;\n}\n\n@mixin body-x-large() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-x-large;\n\tline-height: variables.$font-line-height-x-large;\n}\n\n/**\n * Breakpoint mixins\n */\n\n@mixin break-xhuge() {\n\t@media (min-width: #{ (breakpoints.$break-xhuge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-huge() {\n\t@media (min-width: #{ (breakpoints.$break-huge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-wide() {\n\t@media (min-width: #{ (breakpoints.$break-wide) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-xlarge() {\n\t@media (min-width: #{ (breakpoints.$break-xlarge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-large() {\n\t@media (min-width: #{ (breakpoints.$break-large) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-medium() {\n\t@media (min-width: #{ (breakpoints.$break-medium) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-small() {\n\t@media (min-width: #{ (breakpoints.$break-small) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-mobile() {\n\t@media (min-width: #{ (breakpoints.$break-mobile) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-zoomed-in() {\n\t@media (min-width: #{ (breakpoints.$break-zoomed-in) }) {\n\t\t@content;\n\t}\n}\n\n/**\n * Focus styles.\n */\n\n@mixin block-toolbar-button-style__focus() {\n\tbox-shadow: inset 0 0 0 variables.$border-width colors.$white, 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n// Tabs, Inputs, Square buttons.\n@mixin input-style__neutral() {\n\tbox-shadow: 0 0 0 transparent;\n\tborder-radius: variables.$radius-small;\n\tborder: variables.$border-width solid colors.$gray-600;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: box-shadow 0.1s linear;\n\t}\n}\n\n\n@mixin input-style__focus($accent-color: var(--wp-admin-theme-color)) {\n\tborder-color: $accent-color;\n\t// Expand the default border focus style by .5px to be a total of 1.5px.\n\tbox-shadow: 0 0 0 0.5px $accent-color;\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n@mixin button-style__focus() {\n\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n\n@mixin button-style-outset__focus($focus-color) {\n\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) colors.$white, 0 0 0 calc(2 * var(--wp-admin-border-width-focus)) $focus-color;\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n\toutline-offset: 2px;\n}\n\n\n/**\n * Applies editor left position to the selector passed as argument\n */\n\n@mixin editor-left($selector) {\n\t#{$selector} { /* Set left position when auto-fold is not on the body element. */\n\t\tleft: 0;\n\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width;\n\t\t}\n\t}\n\n\t.auto-fold #{$selector} { /* Auto fold is when on smaller breakpoints, nav menu auto collapses. */\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width-collapsed;\n\t\t}\n\n\t\t@media (min-width: #{ (breakpoints.$break-large + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width;\n\t\t}\n\t}\n\n\t/* Sidebar manually collapsed. */\n\t.folded #{$selector} {\n\t\tleft: 0;\n\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width-collapsed;\n\t\t}\n\t}\n\n\tbody.is-fullscreen-mode #{$selector} {\n\t\tleft: 0 !important;\n\t}\n}\n\n/**\n * Styles that are reused verbatim in a few places\n */\n\n// These are additional styles for all captions, when the theme opts in to block styles.\n@mixin caption-style() {\n\tmargin-top: 0.5em;\n\tmargin-bottom: 1em;\n}\n\n@mixin caption-style-theme() {\n\tcolor: #555;\n\tfont-size: variables.$default-font-size;\n\ttext-align: center;\n\n\t.is-dark-theme & {\n\t\tcolor: colors.$light-gray-placeholder;\n\t}\n}\n\n/**\n * Allows users to opt-out of animations via OS-level preferences.\n */\n\n@mixin reduce-motion($property: \"\") {\n\n\t@if $property == \"transition\" {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\ttransition-duration: 0s;\n\t\t\ttransition-delay: 0s;\n\t\t}\n\t} @else if $property == \"animation\" {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\tanimation-duration: 1ms;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\t} @else {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\ttransition-duration: 0s;\n\t\t\ttransition-delay: 0s;\n\t\t\tanimation-duration: 1ms;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\t}\n}\n\n@mixin input-control($accent-color: var(--wp-admin-theme-color)) {\n\tfont-family: variables.$default-font;\n\tpadding: 6px 8px;\n\t/* Fonts smaller than 16px causes mobile safari to zoom. */\n\tfont-size: variables.$mobile-text-min-font-size;\n\t/* Override core line-height. To be reviewed. */\n\tline-height: normal;\n\t@include input-style__neutral();\n\n\t@include break-small {\n\t\tfont-size: variables.$default-font-size;\n\t\t/* Override core line-height. To be reviewed. */\n\t\tline-height: normal;\n\t}\n\n\t&:focus {\n\t\t@include input-style__focus($accent-color);\n\t}\n\n\t// Use opacity to work in various editor styles.\n\t&::-webkit-input-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n\n\t&::-moz-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n\n\t&:-ms-input-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n}\n\n@mixin checkbox-control {\n\tborder: variables.$border-width solid colors.$gray-900;\n\tmargin-right: variables.$grid-unit-15;\n\ttransition: none;\n\tborder-radius: variables.$radius-small;\n\t@include input-control;\n\n\t&:focus {\n\t\tbox-shadow: 0 0 0 (variables.$border-width * 2) colors.$white, 0 0 0 (variables.$border-width * 2 + variables.$border-width-focus-fallback) var(--wp-admin-theme-color);\n\n\t\t// Only visible in Windows High Contrast mode.\n\t\toutline: 2px solid transparent;\n\t}\n\n\t&:checked {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder-color: var(--wp-admin-theme-color);\n\n\t\t// Hide default checkbox styles in IE.\n\t\t&::-ms-check {\n\t\t\topacity: 0;\n\t\t}\n\t}\n\n\t&:checked::before,\n\t&[aria-checked=\"mixed\"]::before {\n\t\tmargin: -3px -5px;\n\t\tcolor: colors.$white;\n\n\t\t@include break-medium() {\n\t\t\tmargin: -4px 0 0 -5px;\n\t\t}\n\t}\n\n\t&[aria-checked=\"mixed\"] {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder-color: var(--wp-admin-theme-color);\n\n\t\t&::before {\n\t\t\t// Inherited from `forms.css`.\n\t\t\t// See: https://github.com/WordPress/wordpress-develop/tree/5.1.1/src/wp-admin/css/forms.css#L122-L132\n\t\t\tcontent: \"\\f460\";\n\t\t\tfloat: left;\n\t\t\tdisplay: inline-block;\n\t\t\tvertical-align: middle;\n\t\t\twidth: 16px;\n\t\t\t/* stylelint-disable-next-line font-family-no-missing-generic-family-keyword -- dashicons don't need a generic family keyword. */\n\t\t\tfont: normal 30px/1 dashicons;\n\t\t\tspeak: none;\n\t\t\t-webkit-font-smoothing: antialiased;\n\t\t\t-moz-osx-font-smoothing: grayscale;\n\n\t\t\t@include break-medium() {\n\t\t\t\tfloat: none;\n\t\t\t\tfont-size: 21px;\n\t\t\t}\n\t\t}\n\t}\n\n\t&[aria-disabled=\"true\"],\n\t&:disabled {\n\t\tbackground: colors.$gray-100;\n\t\tborder-color: colors.$gray-300;\n\t\tcursor: default;\n\n\t\t// Override style inherited from wp-admin. Required to avoid degraded appearance on different backgrounds.\n\t\topacity: 1;\n\t}\n}\n\n@mixin radio-control {\n\tborder: variables.$border-width solid colors.$gray-900;\n\tmargin-right: variables.$grid-unit-15;\n\ttransition: none;\n\tborder-radius: variables.$radius-round;\n\twidth: variables.$radio-input-size-sm;\n\theight: variables.$radio-input-size-sm;\n\tmin-width: variables.$radio-input-size-sm;\n\tmax-width: variables.$radio-input-size-sm;\n\tposition: relative;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: box-shadow 0.1s linear;\n\t}\n\n\t@include break-small() {\n\t\theight: variables.$radio-input-size;\n\t\twidth: variables.$radio-input-size;\n\t\tmin-width: variables.$radio-input-size;\n\t\tmax-width: variables.$radio-input-size;\n\t}\n\n\t&:checked::before {\n\t\tbox-sizing: inherit;\n\t\twidth: math.div(variables.$radio-input-size-sm, 2);\n\t\theight: math.div(variables.$radio-input-size-sm, 2);\n\t\tposition: absolute;\n\t\ttop: 50%;\n\t\tleft: 50%;\n\t\ttransform: translate(-50%, -50%);\n\t\tmargin: 0;\n\t\tbackground-color: colors.$white;\n\n\t\t// This border serves as a background color in Windows High Contrast mode.\n\t\tborder: 4px solid colors.$white;\n\n\t\t@include break-small() {\n\t\t\twidth: math.div(variables.$radio-input-size, 2);\n\t\t\theight: math.div(variables.$radio-input-size, 2);\n\t\t}\n\t}\n\n\t&:focus {\n\t\tbox-shadow: 0 0 0 (variables.$border-width * 2) colors.$white, 0 0 0 (variables.$border-width * 2 + variables.$border-width-focus-fallback) var(--wp-admin-theme-color);\n\n\t\t// Only visible in Windows High Contrast mode.\n\t\toutline: 2px solid transparent;\n\t}\n\n\t&:checked {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder: none;\n\t}\n}\n\n/**\n * Reset default styles for JavaScript UI based pages.\n * This is a WP-admin agnostic reset\n */\n\n@mixin reset {\n\tbox-sizing: border-box;\n\n\t*,\n\t*::before,\n\t*::after {\n\t\tbox-sizing: inherit;\n\t}\n}\n\n@mixin link-reset {\n\t&:focus {\n\t\tcolor: var(--wp-admin-theme-color--rgb);\n\t\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color, #007cba);\n\t\tborder-radius: variables.$radius-small;\n\t}\n}\n\n// The editor input reset with increased specificity to avoid theme styles bleeding in.\n@mixin editor-input-reset() {\n\tfont-family: variables.$editor-html-font !important;\n\tcolor: colors.$gray-900 !important;\n\tbackground: colors.$white !important;\n\tpadding: variables.$grid-unit-15 !important;\n\tborder: variables.$border-width solid colors.$gray-900 !important;\n\tbox-shadow: none !important;\n\tborder-radius: variables.$radius-small !important;\n\n\t// Fonts smaller than 16px causes mobile safari to zoom.\n\tfont-size: variables.$mobile-text-min-font-size !important;\n\t@include break-small {\n\t\tfont-size: variables.$default-font-size !important;\n\t}\n\n\t&:focus {\n\t\tborder-color: var(--wp-admin-theme-color) !important;\n\t\tbox-shadow: 0 0 0 (variables.$border-width-focus-fallback - variables.$border-width) var(--wp-admin-theme-color) !important;\n\n\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\toutline: 2px solid transparent !important;\n\t}\n}\n\n/**\n * Reset the WP Admin page styles for Gutenberg-like pages.\n */\n\n@mixin wp-admin-reset( $content-container ) {\n\tbackground: colors.$white;\n\n\t#wpcontent {\n\t\tpadding-left: 0;\n\t}\n\n\t#wpbody-content {\n\t\tpadding-bottom: 0;\n\t}\n\n\t/* We hide legacy notices in Gutenberg Based Pages, because they were not designed in a way that scaled well.\n\t   Plugins can use Gutenberg notices if they need to pass on information to the user when they are editing. */\n\t#wpbody-content > div:not(#{ $content-container }):not(#screen-meta) {\n\t\tdisplay: none;\n\t}\n\n\t#wpfooter {\n\t\tdisplay: none;\n\t}\n\n\t.a11y-speak-region {\n\t\tleft: -1px;\n\t\ttop: -1px;\n\t}\n\n\tul#adminmenu a.wp-has-current-submenu::after,\n\tul#adminmenu > li.current > a.current::after {\n\t\tborder-right-color: colors.$white;\n\t}\n\n\t.media-frame select.attachment-filters:last-of-type {\n\t\twidth: auto;\n\t\tmax-width: 100%;\n\t}\n}\n\n@mixin admin-scheme($color-primary) {\n\t// Define RGB equivalents for use in rgba function.\n\t// Hexadecimal css vars do not work in the rgba function.\n\t--wp-admin-theme-color: #{$color-primary};\n\t--wp-admin-theme-color--rgb: #{functions.hex-to-rgb($color-primary)};\n\t// Darker shades.\n\t--wp-admin-theme-color-darker-10: #{color.adjust($color-primary, $lightness: -5%)};\n\t--wp-admin-theme-color-darker-10--rgb: #{functions.hex-to-rgb(color.adjust($color-primary, $lightness: -5%))};\n\t--wp-admin-theme-color-darker-20: #{color.adjust($color-primary, $lightness: -10%)};\n\t--wp-admin-theme-color-darker-20--rgb: #{functions.hex-to-rgb(color.adjust($color-primary, $lightness: -10%))};\n\n\t// Focus style width.\n\t// Avoid rounding issues by showing a whole 2px for 1x screens, and 1.5px on high resolution screens.\n\t--wp-admin-border-width-focus: 2px;\n\t@media ( -webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {\n\t\t--wp-admin-border-width-focus: 1.5px;\n\t}\n}\n\n@mixin wordpress-admin-schemes() {\n\tbody.admin-color-light {\n\t\t@include admin-scheme(#0085ba);\n\t}\n\n\tbody.admin-color-modern {\n\t\t@include admin-scheme(#3858e9);\n\t}\n\n\tbody.admin-color-blue {\n\t\t@include admin-scheme(#096484);\n\t}\n\n\tbody.admin-color-coffee {\n\t\t@include admin-scheme(#46403c);\n\t}\n\n\tbody.admin-color-ectoplasm {\n\t\t@include admin-scheme(#523f6d);\n\t}\n\n\tbody.admin-color-midnight {\n\t\t@include admin-scheme(#e14d43);\n\t}\n\n\tbody.admin-color-ocean {\n\t\t@include admin-scheme(#627c83);\n\t}\n\n\tbody.admin-color-sunrise {\n\t\t@include admin-scheme(#dd823b);\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin background-colors-deprecated() {\n\t.has-very-light-gray-background-color {\n\t\tbackground-color: #eee;\n\t}\n\n\t.has-very-dark-gray-background-color {\n\t\tbackground-color: #313131;\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin foreground-colors-deprecated() {\n\t.has-very-light-gray-color {\n\t\tcolor: #eee;\n\t}\n\n\t.has-very-dark-gray-color {\n\t\tcolor: #313131;\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin gradient-colors-deprecated() {\n\t// Our classes uses the same values we set for gradient value attributes.\n\n\t/* stylelint-disable @stylistic/function-comma-space-after -- We can not use spacing because of WP multi site kses rule. */\n\t.has-vivid-green-cyan-to-vivid-cyan-blue-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgba(0,208,132,1) 0%,rgba(6,147,227,1) 100%);\n\t}\n\n\t.has-purple-crush-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(52,226,228) 0%,rgb(71,33,251) 50%,rgb(171,29,254) 100%);\n\t}\n\n\t.has-hazy-dawn-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(250,172,168) 0%,rgb(218,208,236) 100%);\n\t}\n\n\t.has-subdued-olive-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(250,250,225) 0%,rgb(103,166,113) 100%);\n\t}\n\n\t.has-atomic-cream-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(253,215,154) 0%,rgb(0,74,89) 100%);\n\t}\n\n\t.has-nightshade-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(51,9,104) 0%,rgb(49,205,207) 100%);\n\t}\n\n\t.has-midnight-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(2,3,129) 0%,rgb(40,116,252) 100%);\n\t}\n\t/* stylelint-enable @stylistic/function-comma-space-after */\n}\n\n@mixin custom-scrollbars-on-hover($handle-color, $handle-color-hover) {\n\n\t// WebKit\n\t&::-webkit-scrollbar {\n\t\twidth: 12px;\n\t\theight: 12px;\n\t}\n\t&::-webkit-scrollbar-track {\n\t\tbackground-color: transparent;\n\t}\n\t&::-webkit-scrollbar-thumb {\n\t\tbackground-color: $handle-color;\n\t\tborder-radius: 8px;\n\t\tborder: 3px solid transparent;\n\t\tbackground-clip: padding-box;\n\t}\n\t&:hover::-webkit-scrollbar-thumb, // This needs specificity.\n\t&:focus::-webkit-scrollbar-thumb,\n\t&:focus-within::-webkit-scrollbar-thumb {\n\t\tbackground-color: $handle-color-hover;\n\t}\n\n\t// Firefox 109+ and Chrome 111+\n\tscrollbar-width: thin;\n\tscrollbar-gutter: stable both-edges;\n\tscrollbar-color: $handle-color transparent; // Syntax, \"dark\", \"light\", or \"#handle-color #track-color\"\n\n\t&:hover,\n\t&:focus,\n\t&:focus-within {\n\t\tscrollbar-color: $handle-color-hover transparent;\n\t}\n\n\t// Needed to fix a Safari rendering issue.\n\twill-change: transform;\n\n\t// Always show scrollbar on Mobile devices.\n\t@media (hover: none) {\n\t\t& {\n\t\t\tscrollbar-color: $handle-color-hover transparent;\n\t\t}\n\t}\n}\n\n@mixin selected-block-outline($widthRatio: 1) {\n\toutline-color: var(--wp-admin-theme-color);\n\toutline-style: solid;\n\toutline-width: calc(#{$widthRatio} * (var(--wp-admin-border-width-focus) / var(--wp-block-editor-iframe-zoom-out-scale, 1)));\n\toutline-offset: calc(#{$widthRatio} * ((-1 * var(--wp-admin-border-width-focus) ) / var(--wp-block-editor-iframe-zoom-out-scale, 1)));\n}\n\n@mixin selected-block-focus($widthRatio: 1) {\n\tcontent: \"\";\n\tposition: absolute;\n\tpointer-events: none;\n\ttop: 0;\n\tright: 0;\n\tbottom: 0;\n\tleft: 0;\n\t@include selected-block-outline($widthRatio);\n}\n","/**\n * Breakpoints & Media Queries\n */\n\n// Most used breakpoints\n$break-xhuge: 1920px;\n$break-huge: 1440px;\n$break-wide: 1280px;\n$break-xlarge: 1080px;\n$break-large: 960px;\t// admin sidebar auto folds\n$break-medium: 782px;\t// adminbar goes big\n$break-small: 600px;\n$break-mobile: 480px;\n$break-zoomed-in: 280px;\n\n// All media queries currently in WordPress:\n//\n// min-width: 2000px\n// min-width: 1680px\n// min-width: 1250px\n// max-width: 1120px *\n// max-width: 1000px\n// min-width: 769px and max-width: 1000px\n// max-width: 960px *\n// max-width: 900px\n// max-width: 850px\n// min-width: 800px and max-width: 1499px\n// max-width: 800px\n// max-width: 799px\n// max-width: 782px *\n// max-width: 768px\n// max-width: 640px *\n// max-width: 600px *\n// max-width: 520px\n// max-width: 500px\n// max-width: 480px *\n// max-width: 400px *\n// max-width: 380px\n// max-width: 320px *\n//\n// Those marked * seem to be more commonly used than the others.\n// Let's try and use as few of these as possible, and be mindful about adding new ones, so we don't make the situation worse\n","/**\n*  Converts a hex value into the rgb equivalent.\n*\n* @param {string} hex - the hexadecimal value to convert\n* @return {string} comma separated rgb values\n*/\n\n@use \"sass:color\";\n@use \"sass:meta\";\n\n@function hex-to-rgb($hex) {\n\t/*\n\t * TODO: `color.{red|green|blue}` will trigger a deprecation warning in Dart Sass,\n\t * but the Sass used by the Gutenberg project doesn't support `color.channel()` yet,\n\t * so we can't migrate to it at this time.\n\t * In the future, after the Gutenberg project has been fully migrated to Dart Sass,\n\t * Remove this conditional statement and use only `color.channel()`.\n\t */\n\t@if meta.function-exists(\"channel\", \"color\") {\n\t\t@return color.channel($hex, \"red\"), color.channel($hex, \"green\"), color.channel($hex, \"blue\");\n\t} @else {\n\t\t@return color.red($hex), color.green($hex), color.blue($hex);\n\t}\n}\n","/**\n * Long content fade mixin\n *\n * Creates a fading overlay to signify that the content is longer\n * than the space allows.\n */\n\n@mixin long-content-fade($direction: right, $size: 20%, $color: #fff, $edge: 0, $z-index: false) {\n\tcontent: \"\";\n\tdisplay: block;\n\tposition: absolute;\n\t-webkit-touch-callout: none;\n\t-webkit-user-select: none;\n\t-khtml-user-select: none;\n\t-moz-user-select: none;\n\t-ms-user-select: none;\n\tuser-select: none;\n\tpointer-events: none;\n\n\t@if $z-index {\n\t\tz-index: $z-index;\n\t}\n\n\t@if $direction == \"bottom\" {\n\t\tbackground: linear-gradient(to top, transparent, $color 90%);\n\t\tleft: $edge;\n\t\tright: $edge;\n\t\ttop: $edge;\n\t\tbottom: calc(100% - $size);\n\t\twidth: auto;\n\t}\n\n\t@if $direction == \"top\" {\n\t\tbackground: linear-gradient(to bottom, transparent, $color 90%);\n\t\ttop: calc(100% - $size);\n\t\tleft: $edge;\n\t\tright: $edge;\n\t\tbottom: $edge;\n\t\twidth: auto;\n\t}\n\n\t@if $direction == \"left\" {\n\t\tbackground: linear-gradient(to left, transparent, $color 90%);\n\t\ttop: $edge;\n\t\tleft: $edge;\n\t\tbottom: $edge;\n\t\tright: auto;\n\t\twidth: $size;\n\t\theight: auto;\n\t}\n\n\t@if $direction == \"right\" {\n\t\tbackground: linear-gradient(to right, transparent, $color 90%);\n\t\ttop: $edge;\n\t\tbottom: $edge;\n\t\tright: $edge;\n\t\tleft: auto;\n\t\twidth: $size;\n\t\theight: auto;\n\t}\n}\n","@use \"@wordpress/base-styles/variables\";\n@use \"@wordpress/base-styles/mixins\";\n\n.boot-layout {\n\theight: 100%;\n\twidth: 100%;\n\tdisplay: flex;\n\tflex-direction: row;\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n\tisolation: isolate;\n\tbackground: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);\n}\n\n.boot-layout__sidebar-backdrop {\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\tbackground-color: rgba(0, 0, 0, 0.5);\n\tz-index: 100002;\n\tcursor: pointer;\n}\n\n.boot-layout__sidebar {\n\theight: 100%;\n\tflex-shrink: 0;\n\twidth: 240px;\n\tposition: relative;\n\toverflow: hidden;\n\n\t&.is-mobile {\n\t\tposition: fixed;\n\t\ttop: 0;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\twidth: 300px;\n\t\tmax-width: 85vw;\n\t\tbackground: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);\n\t\tz-index: 100003;\n\t\tbox-shadow: 2px 0 8px rgba(0, 0, 0, 0.2);\n\t}\n}\n\n.boot-layout__mobile-sidebar-drawer {\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tz-index: 3;\n\tbackground: var(--wpds-color-bg-surface-neutral, #fff);\n\tpadding: variables.$grid-unit-20;\n\tborder-bottom: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\talign-items: center;\n}\n\n.boot-layout__canvas.has-mobile-drawer {\n\tposition: relative;\n\tpadding-top: 65px;\n}\n\n.boot-layout__surfaces {\n\tdisplay: flex;\n\tflex-grow: 1;\n\tmargin: 0;\n\tgap: variables.$grid-unit-10;\n\n\t@include mixins.break-medium {\n\t\tmargin: variables.$grid-unit-10;\n\n\t\t.boot-layout--single-page & {\n\t\t\tmargin-top: 0;\n\t\t\tmargin-left: 0;\n\t\t}\n\t}\n}\n\n.boot-layout__stage,\n.boot-layout__inspector {\n\tflex: 1;\n\toverflow-y: auto;\n\tbackground: var(--wpds-color-bg-surface-neutral, #fff);\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n\tbox-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);\n\tborder: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);\n\tposition: relative;\n\n\t// Mobile-first: surfaces take full screen with fixed positioning\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\twidth: 100vw;\n\theight: 100vh;\n\tborder-radius: 0;\n\tmargin: 0;\n\n\t// Desktop: restore original styles\n\t@include mixins.break-medium {\n\t\tposition: static;\n\t\twidth: auto;\n\t\theight: auto;\n\t\tborder-radius: 8px;\n\t\tmargin: 0;\n\t}\n}\n\n.boot-layout__stage {\n\tz-index: 2; // Highest surface priority on mobile\n\n\t@include mixins.break-medium {\n\t\tz-index: auto;\n\t}\n}\n\n.boot-layout__inspector {\n\tz-index: 3; // Medium surface priority on mobile\n\n\t@include mixins.break-medium {\n\t\tz-index: auto;\n\t}\n}\n\n.boot-layout__canvas {\n\tflex: 1;\n\toverflow-y: auto;\n\tbackground: var(--wpds-color-bg-surface-neutral, #fff);\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n\tbox-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);\n\tborder: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);\n\tposition: relative;\n\n\t// Mobile-first: full screen with lowest priority\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\twidth: 100vw;\n\theight: 100vh;\n\tz-index: 1; // Lowest surface priority\n\tborder-radius: 0;\n\tmargin: 0;\n\n\t// Desktop: restore original styles\n\t@include mixins.break-medium {\n\t\tposition: static;\n\t\twidth: auto;\n\t\theight: auto;\n\t\tborder-radius: 8px;\n\t\tz-index: auto;\n\t}\n}\n\n.boot-layout.has-canvas .boot-layout__stage,\n.boot-layout__inspector {\n\t@include mixins.break-medium {\n\t\tmax-width: 400px;\n\t}\n}\n\n.boot-layout__canvas .interface-interface-skeleton {\n\tposition: relative;\n\theight: 100%;\n\ttop: 0 !important;\n\tleft: 0 !important;\n}\n\n// Full-screen canvas mode\n.boot-layout.has-full-canvas .boot-layout__surfaces {\n\tmargin: 0;\n\tgap: 0;\n}\n\n.boot-layout.has-full-canvas .boot-layout__stage,\n.boot-layout.has-full-canvas .boot-layout__inspector {\n\tdisplay: none;\n}\n\n.boot-layout.has-full-canvas .boot-layout__canvas {\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\tmax-width: none;\n\tmargin: 0;\n\tborder-radius: 0;\n\tborder: none;\n\tbox-shadow: none;\n\toverflow: hidden;\n}\n"]} */`; 2504 document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css10)); 2505 var { useLocation: useLocation2, useMatches: useMatches3, Outlet } = unlock(routePrivateApis5); 2506 function Root() { 2507 const matches = useMatches3(); 2508 const location = useLocation2(); 2509 const currentMatch = matches[matches.length - 1]; 2510 const canvas = currentMatch?.loaderData?.canvas; 2511 const routeContentModule = currentMatch?.loaderData?.routeContentModule; 2512 const isFullScreen = canvas && !canvas.isPreview; 2513 useRouteTitle(); 2514 const isMobileViewport = (0, import_compose4.useViewportMatch)("medium", "<"); 2515 const [isMobileSidebarOpen, setIsMobileSidebarOpen] = (0, import_element13.useState)(false); 2516 const disableMotion = (0, import_compose4.useReducedMotion)(); 2517 (0, import_element13.useEffect)(() => { 2518 setIsMobileSidebarOpen(false); 2519 }, [location.pathname, isMobileViewport]); 2520 return /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(import_components14.SlotFillProvider, { children: /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(UserThemeProvider, { isRoot: true, color: { bg: "#f8f8f8" }, children: /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(UserThemeProvider, { color: { bg: "#1d2327" }, children: /* @__PURE__ */ (0, import_jsx_runtime31.jsxs)( 2521 "div", 2522 { 2523 className: clsx_default("boot-layout", { 2524 "has-canvas": !!canvas || canvas === null, 2525 "has-full-canvas": isFullScreen 2526 }), 2527 children: [ 2528 /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(import_commands2.CommandMenu, {}), 2529 /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(SavePanel, {}), 2530 /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(import_editor4.EditorSnackbars, {}), 2531 isMobileViewport && /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(page_default.SidebarToggleFill, { children: /* @__PURE__ */ (0, import_jsx_runtime31.jsx)( 2532 import_components14.Button, 2533 { 2534 icon: menu_default, 2535 onClick: () => setIsMobileSidebarOpen(true), 2536 label: (0, import_i18n10.__)("Open navigation panel"), 2537 size: "compact" 2538 } 2539 ) }), 2540 /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(import_components14.__unstableAnimatePresence, { children: isMobileViewport && isMobileSidebarOpen && !isFullScreen && /* @__PURE__ */ (0, import_jsx_runtime31.jsx)( 2541 import_components14.__unstableMotion.div, 2542 { 2543 initial: { opacity: 0 }, 2544 animate: { opacity: 1 }, 2545 exit: { opacity: 0 }, 2546 transition: { 2547 type: "tween", 2548 duration: disableMotion ? 0 : 0.2, 2549 ease: "easeOut" 2550 }, 2551 className: "boot-layout__sidebar-backdrop", 2552 onClick: () => setIsMobileSidebarOpen(false), 2553 onKeyDown: (event) => { 2554 if (event.key === "Escape") { 2555 setIsMobileSidebarOpen(false); 2556 } 2557 }, 2558 role: "button", 2559 tabIndex: -1, 2560 "aria-label": (0, import_i18n10.__)( 2561 "Close navigation panel" 2562 ) 2563 } 2564 ) }), 2565 /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(import_components14.__unstableAnimatePresence, { children: isMobileViewport && isMobileSidebarOpen && !isFullScreen && /* @__PURE__ */ (0, import_jsx_runtime31.jsx)( 2566 import_components14.__unstableMotion.div, 2567 { 2568 initial: { x: "-100%" }, 2569 animate: { x: 0 }, 2570 exit: { x: "-100%" }, 2571 transition: { 2572 type: "tween", 2573 duration: disableMotion ? 0 : 0.2, 2574 ease: "easeOut" 2575 }, 2576 className: "boot-layout__sidebar is-mobile", 2577 children: /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(Sidebar, {}) 2578 } 2579 ) }), 2580 !isMobileViewport && !isFullScreen && /* @__PURE__ */ (0, import_jsx_runtime31.jsx)("div", { className: "boot-layout__sidebar", children: /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(Sidebar, {}) }), 2581 /* @__PURE__ */ (0, import_jsx_runtime31.jsxs)("div", { className: "boot-layout__surfaces", children: [ 2582 /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(UserThemeProvider, { color: { bg: "#ffffff" }, children: /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(Outlet, {}) }), 2583 (canvas || canvas === null) && /* @__PURE__ */ (0, import_jsx_runtime31.jsxs)( 2584 "div", 2585 { 2586 className: clsx_default("boot-layout__canvas", { 2587 "has-mobile-drawer": canvas?.isPreview && isMobileViewport 2588 }), 2589 children: [ 2590 canvas?.isPreview && isMobileViewport && /* @__PURE__ */ (0, import_jsx_runtime31.jsx)("div", { className: "boot-layout__mobile-sidebar-drawer", children: /* @__PURE__ */ (0, import_jsx_runtime31.jsx)( 2591 import_components14.Button, 2592 { 2593 icon: menu_default, 2594 onClick: () => setIsMobileSidebarOpen( 2595 true 2596 ), 2597 label: (0, import_i18n10.__)( 2598 "Open navigation panel" 2599 ), 2600 size: "compact" 2601 } 2602 ) }), 2603 /* @__PURE__ */ (0, import_jsx_runtime31.jsx)( 2604 CanvasRenderer, 2605 { 2606 canvas, 2607 routeContentModule 2608 } 2609 ) 2610 ] 2611 } 2612 ) 2613 ] }) 2614 ] 2615 } 2616 ) }) }) }); 2617 } 2618 2619 // packages/boot/build-module/components/app/router.js 2620 var import_jsx_runtime32 = __toESM(require_jsx_runtime()); 2621 var { 2622 createLazyRoute, 2623 createRouter, 2624 createRootRoute, 2625 createRoute, 2626 RouterProvider, 2627 createBrowserHistory, 2628 parseHref, 2629 useLoaderData 2630 } = unlock(routePrivateApis6); 2631 function NotFoundComponent() { 2632 return /* @__PURE__ */ (0, import_jsx_runtime32.jsx)("div", { className: "boot-layout__stage", children: /* @__PURE__ */ (0, import_jsx_runtime32.jsx)(page_default, { title: (0, import_i18n11.__)("Route not found"), hasPadding: true, children: (0, import_i18n11.__)("The page you're looking for does not exist") }) }); 2633 } 2634 function createRouteFromDefinition(route, parentRoute) { 2635 let tanstackRoute = createRoute({ 2636 getParentRoute: () => parentRoute, 2637 path: route.path, 2638 beforeLoad: async (opts) => { 2639 if (route.route_module) { 2640 const module = await import(route.route_module); 2641 const routeConfig = module.route || {}; 2642 if (routeConfig.beforeLoad) { 2643 return routeConfig.beforeLoad({ 2644 params: opts.params || {}, 2645 search: opts.search || {} 2646 }); 2647 } 2648 } 2649 }, 2650 loader: async (opts) => { 2651 let routeConfig = {}; 2652 if (route.route_module) { 2653 const module = await import(route.route_module); 2654 routeConfig = module.route || {}; 2655 } 2656 const context = { 2657 params: opts.params || {}, 2658 search: opts.deps || {} 2659 }; 2660 const [, loaderData, canvasData, titleData] = await Promise.all([ 2661 (0, import_data10.resolveSelect)(import_core_data6.store).getEntityRecord( 2662 "root", 2663 "__unstableBase" 2664 ), 2665 routeConfig.loader ? routeConfig.loader(context) : Promise.resolve(void 0), 2666 routeConfig.canvas ? routeConfig.canvas(context) : Promise.resolve(void 0), 2667 routeConfig.title ? routeConfig.title(context) : Promise.resolve(void 0) 2668 ]); 2669 let inspector = true; 2670 if (routeConfig.inspector) { 2671 inspector = await routeConfig.inspector(context); 2672 } 2673 return { 2674 ...loaderData, 2675 canvas: canvasData, 2676 inspector, 2677 title: titleData, 2678 routeContentModule: route.content_module 2679 }; 2680 }, 2681 loaderDeps: (opts) => opts.search 2682 }); 2683 tanstackRoute = tanstackRoute.lazy(async () => { 2684 const module = route.content_module ? await import(route.content_module) : {}; 2685 const Stage = module.stage; 2686 const Inspector = module.inspector; 2687 return createLazyRoute(route.path)({ 2688 component: function RouteComponent() { 2689 const { inspector: showInspector } = useLoaderData({ from: route.path }) ?? {}; 2690 return /* @__PURE__ */ (0, import_jsx_runtime32.jsxs)(import_jsx_runtime32.Fragment, { children: [ 2691 Stage && /* @__PURE__ */ (0, import_jsx_runtime32.jsx)("div", { className: "boot-layout__stage", children: /* @__PURE__ */ (0, import_jsx_runtime32.jsx)(Stage, {}) }), 2692 Inspector && showInspector && /* @__PURE__ */ (0, import_jsx_runtime32.jsx)("div", { className: "boot-layout__inspector", children: /* @__PURE__ */ (0, import_jsx_runtime32.jsx)(Inspector, {}) }) 2693 ] }); 2694 } 2695 }); 2696 }); 2697 return tanstackRoute; 2698 } 2699 function createRouteTree(routes, rootComponent = Root) { 2700 const rootRoute = createRootRoute({ 2701 component: rootComponent, 2702 context: () => ({}) 2703 }); 2704 const dynamicRoutes = routes.map( 2705 (route) => createRouteFromDefinition(route, rootRoute) 2706 ); 2707 return rootRoute.addChildren(dynamicRoutes); 2708 } 2709 function createPathHistory() { 2710 return createBrowserHistory({ 2711 parseLocation: () => { 2712 const url = new URL(window.location.href); 2713 const path = url.searchParams.get("p") || "/"; 2714 const pathHref = `$path}$url.hash}`; 2715 return parseHref(pathHref, window.history.state); 2716 }, 2717 createHref: (href) => { 2718 const searchParams = new URLSearchParams(window.location.search); 2719 searchParams.set("p", href); 2720 return `$window.location.pathname}?$searchParams}`; 2721 } 2722 }); 2723 } 2724 function Router({ 2725 routes, 2726 rootComponent = Root 2727 }) { 2728 const router = (0, import_element14.useMemo)(() => { 2729 const history = createPathHistory(); 2730 const routeTree = createRouteTree(routes, rootComponent); 2731 return createRouter({ 2732 history, 2733 routeTree, 2734 defaultPreload: "intent", 2735 defaultNotFoundComponent: NotFoundComponent, 2736 defaultViewTransition: { 2737 types: ({ 2738 fromLocation 2739 }) => { 2740 if (!fromLocation) { 2741 return false; 2742 } 2743 return ["navigate"]; 2744 } 2745 } 2746 }); 2747 }, [routes, rootComponent]); 2748 return /* @__PURE__ */ (0, import_jsx_runtime32.jsx)(RouterProvider, { router }); 2749 } 2750 2751 // packages/boot/build-module/components/root/single-page.js 2752 var import_commands3 = __toESM(require_commands()); 2753 var import_editor5 = __toESM(require_editor()); 2754 import { privateApis as routePrivateApis7 } from "@wordpress/route"; 2755 var import_jsx_runtime33 = __toESM(require_jsx_runtime()); 2756 var css11 = `/** 2757 * SCSS Variables. 2758 * 2759 * Please use variables from this sheet to ensure consistency across the UI. 2760 * Don't add to this sheet unless you're pretty sure the value will be reused in many places. 2761 * For example, don't add rules to this sheet that affect block visuals. It's purely for UI. 2762 */ 2763 /** 2764 * Colors 2765 */ 2766 /** 2767 * Fonts & basic variables. 2768 */ 2769 /** 2770 * Typography 2771 */ 2772 /** 2773 * Grid System. 2774 * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/ 2775 */ 2776 /** 2777 * Radius scale. 2778 */ 2779 /** 2780 * Elevation scale. 2781 */ 2782 /** 2783 * Dimensions. 2784 */ 2785 /** 2786 * Mobile specific styles 2787 */ 2788 /** 2789 * Editor styles. 2790 */ 2791 /** 2792 * Block & Editor UI. 2793 */ 2794 /** 2795 * Block paddings. 2796 */ 2797 /** 2798 * React Native specific. 2799 * These variables do not appear to be used anywhere else. 2800 */ 2801 /** 2802 * Typography 2803 */ 2804 /** 2805 * Breakpoints & Media Queries 2806 */ 2807 /** 2808 * Converts a hex value into the rgb equivalent. 2809 * 2810 * @param {string} hex - the hexadecimal value to convert 2811 * @return {string} comma separated rgb values 2812 */ 2813 /** 2814 * Long content fade mixin 2815 * 2816 * Creates a fading overlay to signify that the content is longer 2817 * than the space allows. 2818 */ 2819 /** 2820 * Breakpoint mixins 2821 */ 2822 /** 2823 * Focus styles. 2824 */ 2825 /** 2826 * Applies editor left position to the selector passed as argument 2827 */ 2828 /** 2829 * Styles that are reused verbatim in a few places 2830 */ 2831 /** 2832 * Allows users to opt-out of animations via OS-level preferences. 2833 */ 2834 /** 2835 * Reset default styles for JavaScript UI based pages. 2836 * This is a WP-admin agnostic reset 2837 */ 2838 /** 2839 * Reset the WP Admin page styles for Gutenberg-like pages. 2840 */ 2841 .boot-layout { 2842 height: 100%; 2843 width: 100%; 2844 display: flex; 2845 flex-direction: row; 2846 color: var(--wpds-color-fg-content-neutral, #1e1e1e); 2847 isolation: isolate; 2848 background: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0); 2849 } 2850 2851 .boot-layout__sidebar-backdrop { 2852 position: fixed; 2853 top: 0; 2854 left: 0; 2855 right: 0; 2856 bottom: 0; 2857 background-color: rgba(0, 0, 0, 0.5); 2858 z-index: 100002; 2859 cursor: pointer; 2860 } 2861 2862 .boot-layout__sidebar { 2863 height: 100%; 2864 flex-shrink: 0; 2865 width: 240px; 2866 position: relative; 2867 overflow: hidden; 2868 } 2869 .boot-layout__sidebar.is-mobile { 2870 position: fixed; 2871 top: 0; 2872 bottom: 0; 2873 left: 0; 2874 width: 300px; 2875 max-width: 85vw; 2876 background: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0); 2877 z-index: 100003; 2878 box-shadow: 2px 0 8px rgba(0, 0, 0, 0.2); 2879 } 2880 2881 .boot-layout__mobile-sidebar-drawer { 2882 position: fixed; 2883 top: 0; 2884 left: 0; 2885 right: 0; 2886 z-index: 3; 2887 background: var(--wpds-color-bg-surface-neutral, #fff); 2888 padding: 16px; 2889 border-bottom: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd); 2890 display: flex; 2891 justify-content: flex-start; 2892 align-items: center; 2893 } 2894 2895 .boot-layout__canvas.has-mobile-drawer { 2896 position: relative; 2897 padding-top: 65px; 2898 } 2899 2900 .boot-layout__surfaces { 2901 display: flex; 2902 flex-grow: 1; 2903 margin: 0; 2904 gap: 8px; 2905 } 2906 @media (min-width: 782px) { 2907 .boot-layout__surfaces { 2908 margin: 8px; 2909 } 2910 .boot-layout--single-page .boot-layout__surfaces { 2911 margin-top: 0; 2912 margin-left: 0; 2913 } 2914 } 2915 2916 .boot-layout__stage, 2917 .boot-layout__inspector { 2918 flex: 1; 2919 overflow-y: auto; 2920 background: var(--wpds-color-bg-surface-neutral, #fff); 2921 color: var(--wpds-color-fg-content-neutral, #1e1e1e); 2922 box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1); 2923 border: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd); 2924 position: relative; 2925 position: fixed; 2926 top: 0; 2927 left: 0; 2928 right: 0; 2929 bottom: 0; 2930 width: 100vw; 2931 height: 100vh; 2932 border-radius: 0; 2933 margin: 0; 2934 } 2935 @media (min-width: 782px) { 2936 .boot-layout__stage, 2937 .boot-layout__inspector { 2938 position: static; 2939 width: auto; 2940 height: auto; 2941 border-radius: 8px; 2942 margin: 0; 2943 } 2944 } 2945 2946 .boot-layout__stage { 2947 z-index: 2; 2948 } 2949 @media (min-width: 782px) { 2950 .boot-layout__stage { 2951 z-index: auto; 2952 } 2953 } 2954 2955 .boot-layout__inspector { 2956 z-index: 3; 2957 } 2958 @media (min-width: 782px) { 2959 .boot-layout__inspector { 2960 z-index: auto; 2961 } 2962 } 2963 2964 .boot-layout__canvas { 2965 flex: 1; 2966 overflow-y: auto; 2967 background: var(--wpds-color-bg-surface-neutral, #fff); 2968 color: var(--wpds-color-fg-content-neutral, #1e1e1e); 2969 box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1); 2970 border: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd); 2971 position: relative; 2972 position: fixed; 2973 top: 0; 2974 left: 0; 2975 right: 0; 2976 bottom: 0; 2977 width: 100vw; 2978 height: 100vh; 2979 z-index: 1; 2980 border-radius: 0; 2981 margin: 0; 2982 } 2983 @media (min-width: 782px) { 2984 .boot-layout__canvas { 2985 position: static; 2986 width: auto; 2987 height: auto; 2988 border-radius: 8px; 2989 z-index: auto; 2990 } 2991 } 2992 2993 @media (min-width: 782px) { 2994 .boot-layout.has-canvas .boot-layout__stage, 2995 .boot-layout__inspector { 2996 max-width: 400px; 2997 } 2998 } 2999 3000 .boot-layout__canvas .interface-interface-skeleton { 3001 position: relative; 3002 height: 100%; 3003 top: 0 !important; 3004 left: 0 !important; 3005 } 3006 3007 .boot-layout.has-full-canvas .boot-layout__surfaces { 3008 margin: 0; 3009 gap: 0; 3010 } 3011 3012 .boot-layout.has-full-canvas .boot-layout__stage, 3013 .boot-layout.has-full-canvas .boot-layout__inspector { 3014 display: none; 3015 } 3016 3017 .boot-layout.has-full-canvas .boot-layout__canvas { 3018 position: fixed; 3019 top: 0; 3020 left: 0; 3021 right: 0; 3022 bottom: 0; 3023 max-width: none; 3024 margin: 0; 3025 border-radius: 0; 3026 border: none; 3027 box-shadow: none; 3028 overflow: hidden; 3029 } 3030 /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/root","sources":["../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../node_modules/@wordpress/base-styles/_colors.scss","../../../../../node_modules/@wordpress/base-styles/_mixins.scss","../../../../../node_modules/@wordpress/base-styles/_breakpoints.scss","../../../../../node_modules/@wordpress/base-styles/_functions.scss","../../../../../node_modules/@wordpress/base-styles/_long-content-fade.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEnKA;AAAA;AAAA;ACAA;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AH4EA;AAAA;AAAA;AA0DA;AAAA;AAAA;AAgDA;AAAA;AAAA;AAqCA;AAAA;AAAA;AAoBA;AAAA;AAAA;AAwLA;AAAA;AAAA;AAAA;AAgDA;AAAA;AAAA;AIpdA;EACC;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGD;EACC;EACA;EACA;EACA;EACA;;AAEA;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAIF;EACC;EACA;EACA;EACA;EACA;EACA;EACA,SNIc;EMHd;EACA;EACA;EACA;;;AAGD;EACC;EACA;;;AAGD;EACC;EACA;EACA;EACA,KNdc;;AE0Dd;EIhDD;IAOE,QNjBa;;EMmBb;IACC;IACA;;;;AAKH;AAAA;EAEC;EACA;EACA;EACA;EACA;EACA;EACA;EAGA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AJaA;EIhCD;AAAA;IAuBE;IACA;IACA;IACA;IACA;;;;AAIF;EACC;;AJAA;EIDD;IAIE;;;;AAIF;EACC;;AJRA;EIOD;IAIE;;;;AAIF;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EAGA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AJlCA;EIeD;IAuBE;IACA;IACA;IACA;IACA;;;;AJ1CD;EI8CD;AAAA;IAGE;;;;AAIF;EACC;EACA;EACA;EACA;;;AAID;EACC;EACA;;;AAGD;AAAA;EAEC;;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","/**\n * Typography\n */\n\n@use \"sass:color\";\n@use \"sass:math\";\n@use \"./variables\";\n@use \"./colors\";\n@use \"./breakpoints\";\n@use \"./functions\";\n@use \"./long-content-fade\";\n\n@mixin _text-heading() {\n\tfont-family: variables.$font-family-headings;\n\tfont-weight: variables.$font-weight-medium;\n}\n\n@mixin _text-body() {\n\tfont-family: variables.$font-family-body;\n\tfont-weight: variables.$font-weight-regular;\n}\n\n@mixin heading-small() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-x-small;\n\tline-height: variables.$font-line-height-x-small;\n}\n\n@mixin heading-medium() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-medium;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin heading-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-large;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin heading-x-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-x-large;\n\tline-height: variables.$font-line-height-medium;\n}\n\n@mixin heading-2x-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-2x-large;\n\tline-height: variables.$font-line-height-2x-large;\n}\n\n@mixin body-small() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-small;\n\tline-height: variables.$font-line-height-x-small;\n}\n\n@mixin body-medium() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-medium;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin body-large() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-large;\n\tline-height: variables.$font-line-height-medium;\n}\n\n@mixin body-x-large() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-x-large;\n\tline-height: variables.$font-line-height-x-large;\n}\n\n/**\n * Breakpoint mixins\n */\n\n@mixin break-xhuge() {\n\t@media (min-width: #{ (breakpoints.$break-xhuge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-huge() {\n\t@media (min-width: #{ (breakpoints.$break-huge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-wide() {\n\t@media (min-width: #{ (breakpoints.$break-wide) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-xlarge() {\n\t@media (min-width: #{ (breakpoints.$break-xlarge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-large() {\n\t@media (min-width: #{ (breakpoints.$break-large) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-medium() {\n\t@media (min-width: #{ (breakpoints.$break-medium) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-small() {\n\t@media (min-width: #{ (breakpoints.$break-small) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-mobile() {\n\t@media (min-width: #{ (breakpoints.$break-mobile) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-zoomed-in() {\n\t@media (min-width: #{ (breakpoints.$break-zoomed-in) }) {\n\t\t@content;\n\t}\n}\n\n/**\n * Focus styles.\n */\n\n@mixin block-toolbar-button-style__focus() {\n\tbox-shadow: inset 0 0 0 variables.$border-width colors.$white, 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n// Tabs, Inputs, Square buttons.\n@mixin input-style__neutral() {\n\tbox-shadow: 0 0 0 transparent;\n\tborder-radius: variables.$radius-small;\n\tborder: variables.$border-width solid colors.$gray-600;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: box-shadow 0.1s linear;\n\t}\n}\n\n\n@mixin input-style__focus($accent-color: var(--wp-admin-theme-color)) {\n\tborder-color: $accent-color;\n\t// Expand the default border focus style by .5px to be a total of 1.5px.\n\tbox-shadow: 0 0 0 0.5px $accent-color;\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n@mixin button-style__focus() {\n\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n\n@mixin button-style-outset__focus($focus-color) {\n\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) colors.$white, 0 0 0 calc(2 * var(--wp-admin-border-width-focus)) $focus-color;\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n\toutline-offset: 2px;\n}\n\n\n/**\n * Applies editor left position to the selector passed as argument\n */\n\n@mixin editor-left($selector) {\n\t#{$selector} { /* Set left position when auto-fold is not on the body element. */\n\t\tleft: 0;\n\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width;\n\t\t}\n\t}\n\n\t.auto-fold #{$selector} { /* Auto fold is when on smaller breakpoints, nav menu auto collapses. */\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width-collapsed;\n\t\t}\n\n\t\t@media (min-width: #{ (breakpoints.$break-large + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width;\n\t\t}\n\t}\n\n\t/* Sidebar manually collapsed. */\n\t.folded #{$selector} {\n\t\tleft: 0;\n\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width-collapsed;\n\t\t}\n\t}\n\n\tbody.is-fullscreen-mode #{$selector} {\n\t\tleft: 0 !important;\n\t}\n}\n\n/**\n * Styles that are reused verbatim in a few places\n */\n\n// These are additional styles for all captions, when the theme opts in to block styles.\n@mixin caption-style() {\n\tmargin-top: 0.5em;\n\tmargin-bottom: 1em;\n}\n\n@mixin caption-style-theme() {\n\tcolor: #555;\n\tfont-size: variables.$default-font-size;\n\ttext-align: center;\n\n\t.is-dark-theme & {\n\t\tcolor: colors.$light-gray-placeholder;\n\t}\n}\n\n/**\n * Allows users to opt-out of animations via OS-level preferences.\n */\n\n@mixin reduce-motion($property: \"\") {\n\n\t@if $property == \"transition\" {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\ttransition-duration: 0s;\n\t\t\ttransition-delay: 0s;\n\t\t}\n\t} @else if $property == \"animation\" {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\tanimation-duration: 1ms;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\t} @else {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\ttransition-duration: 0s;\n\t\t\ttransition-delay: 0s;\n\t\t\tanimation-duration: 1ms;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\t}\n}\n\n@mixin input-control($accent-color: var(--wp-admin-theme-color)) {\n\tfont-family: variables.$default-font;\n\tpadding: 6px 8px;\n\t/* Fonts smaller than 16px causes mobile safari to zoom. */\n\tfont-size: variables.$mobile-text-min-font-size;\n\t/* Override core line-height. To be reviewed. */\n\tline-height: normal;\n\t@include input-style__neutral();\n\n\t@include break-small {\n\t\tfont-size: variables.$default-font-size;\n\t\t/* Override core line-height. To be reviewed. */\n\t\tline-height: normal;\n\t}\n\n\t&:focus {\n\t\t@include input-style__focus($accent-color);\n\t}\n\n\t// Use opacity to work in various editor styles.\n\t&::-webkit-input-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n\n\t&::-moz-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n\n\t&:-ms-input-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n}\n\n@mixin checkbox-control {\n\tborder: variables.$border-width solid colors.$gray-900;\n\tmargin-right: variables.$grid-unit-15;\n\ttransition: none;\n\tborder-radius: variables.$radius-small;\n\t@include input-control;\n\n\t&:focus {\n\t\tbox-shadow: 0 0 0 (variables.$border-width * 2) colors.$white, 0 0 0 (variables.$border-width * 2 + variables.$border-width-focus-fallback) var(--wp-admin-theme-color);\n\n\t\t// Only visible in Windows High Contrast mode.\n\t\toutline: 2px solid transparent;\n\t}\n\n\t&:checked {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder-color: var(--wp-admin-theme-color);\n\n\t\t// Hide default checkbox styles in IE.\n\t\t&::-ms-check {\n\t\t\topacity: 0;\n\t\t}\n\t}\n\n\t&:checked::before,\n\t&[aria-checked=\"mixed\"]::before {\n\t\tmargin: -3px -5px;\n\t\tcolor: colors.$white;\n\n\t\t@include break-medium() {\n\t\t\tmargin: -4px 0 0 -5px;\n\t\t}\n\t}\n\n\t&[aria-checked=\"mixed\"] {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder-color: var(--wp-admin-theme-color);\n\n\t\t&::before {\n\t\t\t// Inherited from `forms.css`.\n\t\t\t// See: https://github.com/WordPress/wordpress-develop/tree/5.1.1/src/wp-admin/css/forms.css#L122-L132\n\t\t\tcontent: \"\\f460\";\n\t\t\tfloat: left;\n\t\t\tdisplay: inline-block;\n\t\t\tvertical-align: middle;\n\t\t\twidth: 16px;\n\t\t\t/* stylelint-disable-next-line font-family-no-missing-generic-family-keyword -- dashicons don't need a generic family keyword. */\n\t\t\tfont: normal 30px/1 dashicons;\n\t\t\tspeak: none;\n\t\t\t-webkit-font-smoothing: antialiased;\n\t\t\t-moz-osx-font-smoothing: grayscale;\n\n\t\t\t@include break-medium() {\n\t\t\t\tfloat: none;\n\t\t\t\tfont-size: 21px;\n\t\t\t}\n\t\t}\n\t}\n\n\t&[aria-disabled=\"true\"],\n\t&:disabled {\n\t\tbackground: colors.$gray-100;\n\t\tborder-color: colors.$gray-300;\n\t\tcursor: default;\n\n\t\t// Override style inherited from wp-admin. Required to avoid degraded appearance on different backgrounds.\n\t\topacity: 1;\n\t}\n}\n\n@mixin radio-control {\n\tborder: variables.$border-width solid colors.$gray-900;\n\tmargin-right: variables.$grid-unit-15;\n\ttransition: none;\n\tborder-radius: variables.$radius-round;\n\twidth: variables.$radio-input-size-sm;\n\theight: variables.$radio-input-size-sm;\n\tmin-width: variables.$radio-input-size-sm;\n\tmax-width: variables.$radio-input-size-sm;\n\tposition: relative;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: box-shadow 0.1s linear;\n\t}\n\n\t@include break-small() {\n\t\theight: variables.$radio-input-size;\n\t\twidth: variables.$radio-input-size;\n\t\tmin-width: variables.$radio-input-size;\n\t\tmax-width: variables.$radio-input-size;\n\t}\n\n\t&:checked::before {\n\t\tbox-sizing: inherit;\n\t\twidth: math.div(variables.$radio-input-size-sm, 2);\n\t\theight: math.div(variables.$radio-input-size-sm, 2);\n\t\tposition: absolute;\n\t\ttop: 50%;\n\t\tleft: 50%;\n\t\ttransform: translate(-50%, -50%);\n\t\tmargin: 0;\n\t\tbackground-color: colors.$white;\n\n\t\t// This border serves as a background color in Windows High Contrast mode.\n\t\tborder: 4px solid colors.$white;\n\n\t\t@include break-small() {\n\t\t\twidth: math.div(variables.$radio-input-size, 2);\n\t\t\theight: math.div(variables.$radio-input-size, 2);\n\t\t}\n\t}\n\n\t&:focus {\n\t\tbox-shadow: 0 0 0 (variables.$border-width * 2) colors.$white, 0 0 0 (variables.$border-width * 2 + variables.$border-width-focus-fallback) var(--wp-admin-theme-color);\n\n\t\t// Only visible in Windows High Contrast mode.\n\t\toutline: 2px solid transparent;\n\t}\n\n\t&:checked {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder: none;\n\t}\n}\n\n/**\n * Reset default styles for JavaScript UI based pages.\n * This is a WP-admin agnostic reset\n */\n\n@mixin reset {\n\tbox-sizing: border-box;\n\n\t*,\n\t*::before,\n\t*::after {\n\t\tbox-sizing: inherit;\n\t}\n}\n\n@mixin link-reset {\n\t&:focus {\n\t\tcolor: var(--wp-admin-theme-color--rgb);\n\t\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color, #007cba);\n\t\tborder-radius: variables.$radius-small;\n\t}\n}\n\n// The editor input reset with increased specificity to avoid theme styles bleeding in.\n@mixin editor-input-reset() {\n\tfont-family: variables.$editor-html-font !important;\n\tcolor: colors.$gray-900 !important;\n\tbackground: colors.$white !important;\n\tpadding: variables.$grid-unit-15 !important;\n\tborder: variables.$border-width solid colors.$gray-900 !important;\n\tbox-shadow: none !important;\n\tborder-radius: variables.$radius-small !important;\n\n\t// Fonts smaller than 16px causes mobile safari to zoom.\n\tfont-size: variables.$mobile-text-min-font-size !important;\n\t@include break-small {\n\t\tfont-size: variables.$default-font-size !important;\n\t}\n\n\t&:focus {\n\t\tborder-color: var(--wp-admin-theme-color) !important;\n\t\tbox-shadow: 0 0 0 (variables.$border-width-focus-fallback - variables.$border-width) var(--wp-admin-theme-color) !important;\n\n\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\toutline: 2px solid transparent !important;\n\t}\n}\n\n/**\n * Reset the WP Admin page styles for Gutenberg-like pages.\n */\n\n@mixin wp-admin-reset( $content-container ) {\n\tbackground: colors.$white;\n\n\t#wpcontent {\n\t\tpadding-left: 0;\n\t}\n\n\t#wpbody-content {\n\t\tpadding-bottom: 0;\n\t}\n\n\t/* We hide legacy notices in Gutenberg Based Pages, because they were not designed in a way that scaled well.\n\t   Plugins can use Gutenberg notices if they need to pass on information to the user when they are editing. */\n\t#wpbody-content > div:not(#{ $content-container }):not(#screen-meta) {\n\t\tdisplay: none;\n\t}\n\n\t#wpfooter {\n\t\tdisplay: none;\n\t}\n\n\t.a11y-speak-region {\n\t\tleft: -1px;\n\t\ttop: -1px;\n\t}\n\n\tul#adminmenu a.wp-has-current-submenu::after,\n\tul#adminmenu > li.current > a.current::after {\n\t\tborder-right-color: colors.$white;\n\t}\n\n\t.media-frame select.attachment-filters:last-of-type {\n\t\twidth: auto;\n\t\tmax-width: 100%;\n\t}\n}\n\n@mixin admin-scheme($color-primary) {\n\t// Define RGB equivalents for use in rgba function.\n\t// Hexadecimal css vars do not work in the rgba function.\n\t--wp-admin-theme-color: #{$color-primary};\n\t--wp-admin-theme-color--rgb: #{functions.hex-to-rgb($color-primary)};\n\t// Darker shades.\n\t--wp-admin-theme-color-darker-10: #{color.adjust($color-primary, $lightness: -5%)};\n\t--wp-admin-theme-color-darker-10--rgb: #{functions.hex-to-rgb(color.adjust($color-primary, $lightness: -5%))};\n\t--wp-admin-theme-color-darker-20: #{color.adjust($color-primary, $lightness: -10%)};\n\t--wp-admin-theme-color-darker-20--rgb: #{functions.hex-to-rgb(color.adjust($color-primary, $lightness: -10%))};\n\n\t// Focus style width.\n\t// Avoid rounding issues by showing a whole 2px for 1x screens, and 1.5px on high resolution screens.\n\t--wp-admin-border-width-focus: 2px;\n\t@media ( -webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {\n\t\t--wp-admin-border-width-focus: 1.5px;\n\t}\n}\n\n@mixin wordpress-admin-schemes() {\n\tbody.admin-color-light {\n\t\t@include admin-scheme(#0085ba);\n\t}\n\n\tbody.admin-color-modern {\n\t\t@include admin-scheme(#3858e9);\n\t}\n\n\tbody.admin-color-blue {\n\t\t@include admin-scheme(#096484);\n\t}\n\n\tbody.admin-color-coffee {\n\t\t@include admin-scheme(#46403c);\n\t}\n\n\tbody.admin-color-ectoplasm {\n\t\t@include admin-scheme(#523f6d);\n\t}\n\n\tbody.admin-color-midnight {\n\t\t@include admin-scheme(#e14d43);\n\t}\n\n\tbody.admin-color-ocean {\n\t\t@include admin-scheme(#627c83);\n\t}\n\n\tbody.admin-color-sunrise {\n\t\t@include admin-scheme(#dd823b);\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin background-colors-deprecated() {\n\t.has-very-light-gray-background-color {\n\t\tbackground-color: #eee;\n\t}\n\n\t.has-very-dark-gray-background-color {\n\t\tbackground-color: #313131;\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin foreground-colors-deprecated() {\n\t.has-very-light-gray-color {\n\t\tcolor: #eee;\n\t}\n\n\t.has-very-dark-gray-color {\n\t\tcolor: #313131;\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin gradient-colors-deprecated() {\n\t// Our classes uses the same values we set for gradient value attributes.\n\n\t/* stylelint-disable @stylistic/function-comma-space-after -- We can not use spacing because of WP multi site kses rule. */\n\t.has-vivid-green-cyan-to-vivid-cyan-blue-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgba(0,208,132,1) 0%,rgba(6,147,227,1) 100%);\n\t}\n\n\t.has-purple-crush-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(52,226,228) 0%,rgb(71,33,251) 50%,rgb(171,29,254) 100%);\n\t}\n\n\t.has-hazy-dawn-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(250,172,168) 0%,rgb(218,208,236) 100%);\n\t}\n\n\t.has-subdued-olive-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(250,250,225) 0%,rgb(103,166,113) 100%);\n\t}\n\n\t.has-atomic-cream-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(253,215,154) 0%,rgb(0,74,89) 100%);\n\t}\n\n\t.has-nightshade-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(51,9,104) 0%,rgb(49,205,207) 100%);\n\t}\n\n\t.has-midnight-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(2,3,129) 0%,rgb(40,116,252) 100%);\n\t}\n\t/* stylelint-enable @stylistic/function-comma-space-after */\n}\n\n@mixin custom-scrollbars-on-hover($handle-color, $handle-color-hover) {\n\n\t// WebKit\n\t&::-webkit-scrollbar {\n\t\twidth: 12px;\n\t\theight: 12px;\n\t}\n\t&::-webkit-scrollbar-track {\n\t\tbackground-color: transparent;\n\t}\n\t&::-webkit-scrollbar-thumb {\n\t\tbackground-color: $handle-color;\n\t\tborder-radius: 8px;\n\t\tborder: 3px solid transparent;\n\t\tbackground-clip: padding-box;\n\t}\n\t&:hover::-webkit-scrollbar-thumb, // This needs specificity.\n\t&:focus::-webkit-scrollbar-thumb,\n\t&:focus-within::-webkit-scrollbar-thumb {\n\t\tbackground-color: $handle-color-hover;\n\t}\n\n\t// Firefox 109+ and Chrome 111+\n\tscrollbar-width: thin;\n\tscrollbar-gutter: stable both-edges;\n\tscrollbar-color: $handle-color transparent; // Syntax, \"dark\", \"light\", or \"#handle-color #track-color\"\n\n\t&:hover,\n\t&:focus,\n\t&:focus-within {\n\t\tscrollbar-color: $handle-color-hover transparent;\n\t}\n\n\t// Needed to fix a Safari rendering issue.\n\twill-change: transform;\n\n\t// Always show scrollbar on Mobile devices.\n\t@media (hover: none) {\n\t\t& {\n\t\t\tscrollbar-color: $handle-color-hover transparent;\n\t\t}\n\t}\n}\n\n@mixin selected-block-outline($widthRatio: 1) {\n\toutline-color: var(--wp-admin-theme-color);\n\toutline-style: solid;\n\toutline-width: calc(#{$widthRatio} * (var(--wp-admin-border-width-focus) / var(--wp-block-editor-iframe-zoom-out-scale, 1)));\n\toutline-offset: calc(#{$widthRatio} * ((-1 * var(--wp-admin-border-width-focus) ) / var(--wp-block-editor-iframe-zoom-out-scale, 1)));\n}\n\n@mixin selected-block-focus($widthRatio: 1) {\n\tcontent: \"\";\n\tposition: absolute;\n\tpointer-events: none;\n\ttop: 0;\n\tright: 0;\n\tbottom: 0;\n\tleft: 0;\n\t@include selected-block-outline($widthRatio);\n}\n","/**\n * Breakpoints & Media Queries\n */\n\n// Most used breakpoints\n$break-xhuge: 1920px;\n$break-huge: 1440px;\n$break-wide: 1280px;\n$break-xlarge: 1080px;\n$break-large: 960px;\t// admin sidebar auto folds\n$break-medium: 782px;\t// adminbar goes big\n$break-small: 600px;\n$break-mobile: 480px;\n$break-zoomed-in: 280px;\n\n// All media queries currently in WordPress:\n//\n// min-width: 2000px\n// min-width: 1680px\n// min-width: 1250px\n// max-width: 1120px *\n// max-width: 1000px\n// min-width: 769px and max-width: 1000px\n// max-width: 960px *\n// max-width: 900px\n// max-width: 850px\n// min-width: 800px and max-width: 1499px\n// max-width: 800px\n// max-width: 799px\n// max-width: 782px *\n// max-width: 768px\n// max-width: 640px *\n// max-width: 600px *\n// max-width: 520px\n// max-width: 500px\n// max-width: 480px *\n// max-width: 400px *\n// max-width: 380px\n// max-width: 320px *\n//\n// Those marked * seem to be more commonly used than the others.\n// Let's try and use as few of these as possible, and be mindful about adding new ones, so we don't make the situation worse\n","/**\n*  Converts a hex value into the rgb equivalent.\n*\n* @param {string} hex - the hexadecimal value to convert\n* @return {string} comma separated rgb values\n*/\n\n@use \"sass:color\";\n@use \"sass:meta\";\n\n@function hex-to-rgb($hex) {\n\t/*\n\t * TODO: `color.{red|green|blue}` will trigger a deprecation warning in Dart Sass,\n\t * but the Sass used by the Gutenberg project doesn't support `color.channel()` yet,\n\t * so we can't migrate to it at this time.\n\t * In the future, after the Gutenberg project has been fully migrated to Dart Sass,\n\t * Remove this conditional statement and use only `color.channel()`.\n\t */\n\t@if meta.function-exists(\"channel\", \"color\") {\n\t\t@return color.channel($hex, \"red\"), color.channel($hex, \"green\"), color.channel($hex, \"blue\");\n\t} @else {\n\t\t@return color.red($hex), color.green($hex), color.blue($hex);\n\t}\n}\n","/**\n * Long content fade mixin\n *\n * Creates a fading overlay to signify that the content is longer\n * than the space allows.\n */\n\n@mixin long-content-fade($direction: right, $size: 20%, $color: #fff, $edge: 0, $z-index: false) {\n\tcontent: \"\";\n\tdisplay: block;\n\tposition: absolute;\n\t-webkit-touch-callout: none;\n\t-webkit-user-select: none;\n\t-khtml-user-select: none;\n\t-moz-user-select: none;\n\t-ms-user-select: none;\n\tuser-select: none;\n\tpointer-events: none;\n\n\t@if $z-index {\n\t\tz-index: $z-index;\n\t}\n\n\t@if $direction == \"bottom\" {\n\t\tbackground: linear-gradient(to top, transparent, $color 90%);\n\t\tleft: $edge;\n\t\tright: $edge;\n\t\ttop: $edge;\n\t\tbottom: calc(100% - $size);\n\t\twidth: auto;\n\t}\n\n\t@if $direction == \"top\" {\n\t\tbackground: linear-gradient(to bottom, transparent, $color 90%);\n\t\ttop: calc(100% - $size);\n\t\tleft: $edge;\n\t\tright: $edge;\n\t\tbottom: $edge;\n\t\twidth: auto;\n\t}\n\n\t@if $direction == \"left\" {\n\t\tbackground: linear-gradient(to left, transparent, $color 90%);\n\t\ttop: $edge;\n\t\tleft: $edge;\n\t\tbottom: $edge;\n\t\tright: auto;\n\t\twidth: $size;\n\t\theight: auto;\n\t}\n\n\t@if $direction == \"right\" {\n\t\tbackground: linear-gradient(to right, transparent, $color 90%);\n\t\ttop: $edge;\n\t\tbottom: $edge;\n\t\tright: $edge;\n\t\tleft: auto;\n\t\twidth: $size;\n\t\theight: auto;\n\t}\n}\n","@use \"@wordpress/base-styles/variables\";\n@use \"@wordpress/base-styles/mixins\";\n\n.boot-layout {\n\theight: 100%;\n\twidth: 100%;\n\tdisplay: flex;\n\tflex-direction: row;\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n\tisolation: isolate;\n\tbackground: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);\n}\n\n.boot-layout__sidebar-backdrop {\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\tbackground-color: rgba(0, 0, 0, 0.5);\n\tz-index: 100002;\n\tcursor: pointer;\n}\n\n.boot-layout__sidebar {\n\theight: 100%;\n\tflex-shrink: 0;\n\twidth: 240px;\n\tposition: relative;\n\toverflow: hidden;\n\n\t&.is-mobile {\n\t\tposition: fixed;\n\t\ttop: 0;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\twidth: 300px;\n\t\tmax-width: 85vw;\n\t\tbackground: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);\n\t\tz-index: 100003;\n\t\tbox-shadow: 2px 0 8px rgba(0, 0, 0, 0.2);\n\t}\n}\n\n.boot-layout__mobile-sidebar-drawer {\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tz-index: 3;\n\tbackground: var(--wpds-color-bg-surface-neutral, #fff);\n\tpadding: variables.$grid-unit-20;\n\tborder-bottom: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\talign-items: center;\n}\n\n.boot-layout__canvas.has-mobile-drawer {\n\tposition: relative;\n\tpadding-top: 65px;\n}\n\n.boot-layout__surfaces {\n\tdisplay: flex;\n\tflex-grow: 1;\n\tmargin: 0;\n\tgap: variables.$grid-unit-10;\n\n\t@include mixins.break-medium {\n\t\tmargin: variables.$grid-unit-10;\n\n\t\t.boot-layout--single-page & {\n\t\t\tmargin-top: 0;\n\t\t\tmargin-left: 0;\n\t\t}\n\t}\n}\n\n.boot-layout__stage,\n.boot-layout__inspector {\n\tflex: 1;\n\toverflow-y: auto;\n\tbackground: var(--wpds-color-bg-surface-neutral, #fff);\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n\tbox-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);\n\tborder: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);\n\tposition: relative;\n\n\t// Mobile-first: surfaces take full screen with fixed positioning\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\twidth: 100vw;\n\theight: 100vh;\n\tborder-radius: 0;\n\tmargin: 0;\n\n\t// Desktop: restore original styles\n\t@include mixins.break-medium {\n\t\tposition: static;\n\t\twidth: auto;\n\t\theight: auto;\n\t\tborder-radius: 8px;\n\t\tmargin: 0;\n\t}\n}\n\n.boot-layout__stage {\n\tz-index: 2; // Highest surface priority on mobile\n\n\t@include mixins.break-medium {\n\t\tz-index: auto;\n\t}\n}\n\n.boot-layout__inspector {\n\tz-index: 3; // Medium surface priority on mobile\n\n\t@include mixins.break-medium {\n\t\tz-index: auto;\n\t}\n}\n\n.boot-layout__canvas {\n\tflex: 1;\n\toverflow-y: auto;\n\tbackground: var(--wpds-color-bg-surface-neutral, #fff);\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n\tbox-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);\n\tborder: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);\n\tposition: relative;\n\n\t// Mobile-first: full screen with lowest priority\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\twidth: 100vw;\n\theight: 100vh;\n\tz-index: 1; // Lowest surface priority\n\tborder-radius: 0;\n\tmargin: 0;\n\n\t// Desktop: restore original styles\n\t@include mixins.break-medium {\n\t\tposition: static;\n\t\twidth: auto;\n\t\theight: auto;\n\t\tborder-radius: 8px;\n\t\tz-index: auto;\n\t}\n}\n\n.boot-layout.has-canvas .boot-layout__stage,\n.boot-layout__inspector {\n\t@include mixins.break-medium {\n\t\tmax-width: 400px;\n\t}\n}\n\n.boot-layout__canvas .interface-interface-skeleton {\n\tposition: relative;\n\theight: 100%;\n\ttop: 0 !important;\n\tleft: 0 !important;\n}\n\n// Full-screen canvas mode\n.boot-layout.has-full-canvas .boot-layout__surfaces {\n\tmargin: 0;\n\tgap: 0;\n}\n\n.boot-layout.has-full-canvas .boot-layout__stage,\n.boot-layout.has-full-canvas .boot-layout__inspector {\n\tdisplay: none;\n}\n\n.boot-layout.has-full-canvas .boot-layout__canvas {\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\tmax-width: none;\n\tmargin: 0;\n\tborder-radius: 0;\n\tborder: none;\n\tbox-shadow: none;\n\toverflow: hidden;\n}\n"]} */`; 3031 document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css11)); 3032 var { useMatches: useMatches4, Outlet: Outlet2 } = unlock(routePrivateApis7); 3033 function RootSinglePage() { 3034 const matches = useMatches4(); 3035 const currentMatch = matches[matches.length - 1]; 3036 const canvas = currentMatch?.loaderData?.canvas; 3037 const routeContentModule = currentMatch?.loaderData?.routeContentModule; 3038 const isFullScreen = canvas && !canvas.isPreview; 3039 useRouteTitle(); 3040 return /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(UserThemeProvider, { isRoot: true, color: { bg: "#f8f8f8" }, children: /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(UserThemeProvider, { color: { bg: "#1d2327" }, children: /* @__PURE__ */ (0, import_jsx_runtime33.jsxs)( 3041 "div", 3042 { 3043 className: clsx_default("boot-layout boot-layout--single-page", { 3044 "has-canvas": !!canvas || canvas === null, 3045 "has-full-canvas": isFullScreen 3046 }), 3047 children: [ 3048 /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(import_commands3.CommandMenu, {}), 3049 /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(SavePanel, {}), 3050 /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(import_editor5.EditorSnackbars, {}), 3051 /* @__PURE__ */ (0, import_jsx_runtime33.jsxs)("div", { className: "boot-layout__surfaces", children: [ 3052 /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(UserThemeProvider, { color: { bg: "#ffffff" }, children: /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(Outlet2, {}) }), 3053 (canvas || canvas === null) && /* @__PURE__ */ (0, import_jsx_runtime33.jsx)("div", { className: "boot-layout__canvas", children: /* @__PURE__ */ (0, import_jsx_runtime33.jsx)( 3054 CanvasRenderer, 3055 { 3056 canvas, 3057 routeContentModule 3058 } 3059 ) }) 3060 ] }) 3061 ] 3062 } 3063 ) }) }); 3064 } 3065 3066 // packages/boot/build-module/components/app/index.js 3067 var import_jsx_runtime34 = __toESM(require_jsx_runtime()); 3068 function App({ rootComponent }) { 3069 const routes = (0, import_data11.useSelect)((select) => select(store).getRoutes(), []); 3070 return /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(Router, { routes, rootComponent }); 3071 } 3072 async function init({ 3073 mountId, 3074 menuItems, 3075 routes, 3076 initModules 3077 }) { 3078 (menuItems ?? []).forEach((menuItem) => { 3079 (0, import_data11.dispatch)(store).registerMenuItem(menuItem.id, menuItem); 3080 }); 3081 (routes ?? []).forEach((route) => { 3082 (0, import_data11.dispatch)(store).registerRoute(route); 3083 }); 3084 for (const moduleId of initModules ?? []) { 3085 const module = await import(moduleId); 3086 await module.init(); 3087 } 3088 const rootElement = document.getElementById(mountId); 3089 if (rootElement) { 3090 const root = (0, import_element15.createRoot)(rootElement); 3091 root.render( 3092 /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(import_element15.StrictMode, { children: /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(App, {}) }) 3093 ); 3094 } 3095 } 3096 async function initSinglePage({ 3097 mountId, 3098 routes 3099 }) { 3100 (routes ?? []).forEach((route) => { 3101 (0, import_data11.dispatch)(store).registerRoute(route); 3102 }); 3103 const rootElement = document.getElementById(mountId); 3104 if (rootElement) { 3105 const root = (0, import_element15.createRoot)(rootElement); 3106 root.render( 3107 /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(import_element15.StrictMode, { children: /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(App, { rootComponent: RootSinglePage }) }) 3108 ); 3109 } 3110 } 3111 3112 // packages/boot/build-module/index.js 3113 var css12 = `@charset "UTF-8"; 3114 /* ------------------------------------------- 3115 * Autogenerated by \u26CB Terrazzo. DO NOT EDIT! 3116 * ------------------------------------------- */ 3117 :root { 3118 --wpds-border-radius-surface-lg: 8px; /* Large radius for surfaces */ 3119 --wpds-border-radius-surface-md: 4px; /* Medium radius for surfaces */ 3120 --wpds-border-radius-surface-sm: 2px; /* Small radius for surfaces */ 3121 --wpds-border-radius-surface-xs: 1px; /* Extra small radius for surfaces */ 3122 --wpds-border-width-interactive-focus: 2px; /* Border width for focus ring */ 3123 --wpds-border-width-surface-lg: 8px; /* Large width for surfaces */ 3124 --wpds-border-width-surface-md: 4px; /* Medium width for surfaces */ 3125 --wpds-border-width-surface-sm: 2px; /* Small width for surfaces */ 3126 --wpds-border-width-surface-xs: 1px; /* Extra small width for surfaces */ 3127 --wpds-color-bg-interactive-brand: #00000000; /* Background color for interactive elements with brand tone and normal emphasis. */ 3128 --wpds-color-bg-interactive-brand-active: #f6f8fd; /* Background color for interactive elements with brand tone and normal emphasis that are hovered, focused, or active. */ 3129 --wpds-color-bg-interactive-brand-disabled: #e2e2e2; /* Background color for interactive elements with brand tone and normal emphasis, in their disabled state. */ 3130 --wpds-color-bg-interactive-brand-strong: #3858e9; /* Background color for interactive elements with brand tone and strong emphasis. */ 3131 --wpds-color-bg-interactive-brand-strong-active: #2e49d9; /* Background color for interactive elements with brand tone and strong emphasis that are hovered, focused, or active. */ 3132 --wpds-color-bg-interactive-brand-strong-disabled: #d2d2d2; /* Background color for interactive elements with brand tone and strong emphasis, in their disabled state. */ 3133 --wpds-color-bg-interactive-brand-weak: #00000000; /* Background color for interactive elements with brand tone and weak emphasis. */ 3134 --wpds-color-bg-interactive-brand-weak-active: #e6eaf4; /* Background color for interactive elements with brand tone and weak emphasis that are hovered, focused, or active. */ 3135 --wpds-color-bg-interactive-brand-weak-disabled: #e2e2e2; /* Background color for interactive elements with brand tone and weak emphasis, in their disabled state. */ 3136 --wpds-color-bg-interactive-error: #00000000; /* Background color for interactive elements with error tone and normal emphasis. */ 3137 --wpds-color-bg-interactive-error-active: #fff6f4; /* Background color for interactive elements with error tone and normal emphasis that are hovered, focused, or active. */ 3138 --wpds-color-bg-interactive-error-disabled: #e2e2e2; /* Background color for interactive elements with error tone and normal emphasis, in their disabled state. */ 3139 --wpds-color-bg-interactive-error-strong: #cc1818; /* Background color for interactive elements with error tone and strong emphasis. */ 3140 --wpds-color-bg-interactive-error-strong-active: #b90000; /* Background color for interactive elements with error tone and strong emphasis that are hovered, focused, or active. */ 3141 --wpds-color-bg-interactive-error-strong-disabled: #d2d2d2; /* Background color for interactive elements with error tone and strong emphasis, in their disabled state. */ 3142 --wpds-color-bg-interactive-error-weak: #00000000; /* Background color for interactive elements with error tone and weak emphasis. */ 3143 --wpds-color-bg-interactive-error-weak-active: #f6e6e3; /* Background color for interactive elements with error tone and weak emphasis that are hovered, focused, or active. */ 3144 --wpds-color-bg-interactive-error-weak-disabled: #e2e2e2; /* Background color for interactive elements with error tone and weak emphasis, in their disabled state. */ 3145 --wpds-color-bg-interactive-neutral: #00000000; /* Background color for interactive elements with neutral tone and normal emphasis. */ 3146 --wpds-color-bg-interactive-neutral-active: #eaeaea; /* Background color for interactive elements with neutral tone and normal emphasis that are hovered, focused, or active. */ 3147 --wpds-color-bg-interactive-neutral-disabled: #e2e2e2; /* Background color for interactive elements with neutral tone and normal emphasis, in their disabled state. */ 3148 --wpds-color-bg-interactive-neutral-strong: #2d2d2d; /* Background color for interactive elements with neutral tone and strong emphasis. */ 3149 --wpds-color-bg-interactive-neutral-strong-active: #1e1e1e; /* Background color for interactive elements with neutral tone and strong emphasis that are hovered, focused, or active. */ 3150 --wpds-color-bg-interactive-neutral-strong-disabled: #d2d2d2; /* Background color for interactive elements with neutral tone and strong emphasis, in their disabled state. */ 3151 --wpds-color-bg-interactive-neutral-weak: #00000000; /* Background color for interactive elements with neutral tone and weak emphasis. */ 3152 --wpds-color-bg-interactive-neutral-weak-active: #eaeaea; /* Background color for interactive elements with neutral tone and weak emphasis that are hovered, focused, or active. */ 3153 --wpds-color-bg-interactive-neutral-weak-disabled: #e2e2e2; /* Background color for interactive elements with neutral tone and weak emphasis, in their disabled state. */ 3154 --wpds-color-bg-surface-brand: #ecf0f9; /* Background color for surfaces with brand tone and normal emphasis. */ 3155 --wpds-color-bg-surface-caution: #fee994; /* Background color for surfaces with caution tone and normal emphasis. */ 3156 --wpds-color-bg-surface-caution-weak: #fff9c9; /* Background color for surfaces with caution tone and weak emphasis. */ 3157 --wpds-color-bg-surface-error: #f6e6e3; /* Background color for surfaces with error tone and normal emphasis. */ 3158 --wpds-color-bg-surface-error-weak: #fff6f4; /* Background color for surfaces with error tone and weak emphasis. */ 3159 --wpds-color-bg-surface-info: #deebfa; /* Background color for surfaces with info tone and normal emphasis. */ 3160 --wpds-color-bg-surface-info-weak: #f3f9ff; /* Background color for surfaces with info tone and weak emphasis. */ 3161 --wpds-color-bg-surface-neutral: #f8f8f8; /* Background color for surfaces with normal emphasis. */ 3162 --wpds-color-bg-surface-neutral-strong: #ffffff; /* Background color for surfaces with strong emphasis. */ 3163 --wpds-color-bg-surface-neutral-weak: #f0f0f0; /* Background color for surfaces with weak emphasis. */ 3164 --wpds-color-bg-surface-success: #c5f7cc; /* Background color for surfaces with success tone and normal emphasis. */ 3165 --wpds-color-bg-surface-success-weak: #eaffed; /* Background color for surfaces with success tone and weak emphasis. */ 3166 --wpds-color-bg-surface-warning: #fde6bd; /* Background color for surfaces with warning tone and normal emphasis. */ 3167 --wpds-color-bg-surface-warning-weak: #fff7e0; /* Background color for surfaces with warning tone and weak emphasis. */ 3168 --wpds-color-bg-thumb-brand: #3858e9; /* Background color for thumbs with a brand tone and normal emphasis (eg. slider thumb and filled track). */ 3169 --wpds-color-bg-thumb-brand-active: #3858e9; /* Background color for thumbs with a brand tone and normal emphasis (eg. slider thumb and filled track) that are hovered, focused, or active. */ 3170 --wpds-color-bg-thumb-brand-disabled: #d8d8d8; /* Background color for thumbs with a brand tone and normal emphasis (eg. slider thumb and filled track), in their disabled state. */ 3171 --wpds-color-bg-thumb-neutral-weak: #8a8a8a; /* Background color for thumbs with a neutral tone and weak emphasis (eg. scrollbar thumb). */ 3172 --wpds-color-bg-thumb-neutral-weak-active: #6c6c6c; /* Background color for thumbs with a neutral tone and weak emphasis (eg. scrollbar thumb) that are hovered, focused, or active. */ 3173 --wpds-color-bg-track-neutral: #d8d8d8; /* Background color for tracks with a neutral tone and normal emphasis (eg. slider or progressbar track). */ 3174 --wpds-color-bg-track-neutral-weak: #e0e0e0; /* Background color for tracks with a neutral tone and weak emphasis (eg. scrollbar track). */ 3175 --wpds-color-fg-content-caution: #281d00; /* Foreground color for content like text with caution tone and normal emphasis. */ 3176 --wpds-color-fg-content-caution-weak: #826a00; /* Foreground color for content like text with caution tone and weak emphasis. */ 3177 --wpds-color-fg-content-error: #470000; /* Foreground color for content like text with error tone and normal emphasis. */ 3178 --wpds-color-fg-content-error-weak: #cc1818; /* Foreground color for content like text with error tone and weak emphasis. */ 3179 --wpds-color-fg-content-info: #001b4f; /* Foreground color for content like text with info tone and normal emphasis. */ 3180 --wpds-color-fg-content-info-weak: #006bd7; /* Foreground color for content like text with info tone and weak emphasis. */ 3181 --wpds-color-fg-content-neutral: #1e1e1e; /* Foreground color for content like text with normal emphasis. */ 3182 --wpds-color-fg-content-neutral-weak: #6d6d6d; /* Foreground color for content like text with weak emphasis. */ 3183 --wpds-color-fg-content-success: #002900; /* Foreground color for content like text with success tone and normal emphasis. */ 3184 --wpds-color-fg-content-success-weak: #007f30; /* Foreground color for content like text with success tone and weak emphasis. */ 3185 --wpds-color-fg-content-warning: #2e1900; /* Foreground color for content like text with warning tone and normal emphasis. */ 3186 --wpds-color-fg-content-warning-weak: #926300; /* Foreground color for content like text with warning tone and weak emphasis. */ 3187 --wpds-color-fg-interactive-brand: #3858e9; /* Foreground color for interactive elements with brand tone and normal emphasis. */ 3188 --wpds-color-fg-interactive-brand-active: #3858e9; /* Foreground color for interactive elements with brand tone and normal emphasis that are hovered, focused, or active. */ 3189 --wpds-color-fg-interactive-brand-disabled: #8a8a8a; /* Foreground color for interactive elements with brand tone and normal emphasis, in their disabled state. */ 3190 --wpds-color-fg-interactive-brand-strong: #eff0f2; /* Foreground color for interactive elements with brand tone and strong emphasis. */ 3191 --wpds-color-fg-interactive-brand-strong-active: #eff0f2; /* Foreground color for interactive elements with brand tone and strong emphasis that are hovered, focused, or active. */ 3192 --wpds-color-fg-interactive-brand-strong-disabled: #6d6d6d; /* Foreground color for interactive elements with brand tone and strong emphasis, in their disabled state. */ 3193 --wpds-color-fg-interactive-error: #cc1818; /* Foreground color for interactive elements with error tone and normal emphasis. */ 3194 --wpds-color-fg-interactive-error-active: #cc1818; /* Foreground color for interactive elements with error tone and normal emphasis that are hovered, focused, or active. */ 3195 --wpds-color-fg-interactive-error-disabled: #8a8a8a; /* Foreground color for interactive elements with error tone and normal emphasis, in their disabled state. */ 3196 --wpds-color-fg-interactive-error-strong: #f2efef; /* Foreground color for interactive elements with error tone and strong emphasis. */ 3197 --wpds-color-fg-interactive-error-strong-active: #f2efef; /* Foreground color for interactive elements with error tone and strong emphasis that are hovered, focused, or active. */ 3198 --wpds-color-fg-interactive-error-strong-disabled: #6d6d6d; /* Foreground color for interactive elements with error tone and strong emphasis, in their disabled state. */ 3199 --wpds-color-fg-interactive-neutral: #1e1e1e; /* Foreground color for interactive elements with neutral tone and normal emphasis. */ 3200 --wpds-color-fg-interactive-neutral-active: #1e1e1e; /* Foreground color for interactive elements with neutral tone and normal emphasis that are hovered, focused, or active. */ 3201 --wpds-color-fg-interactive-neutral-disabled: #8a8a8a; /* Foreground color for interactive elements with neutral tone and normal emphasis, in their disabled state. */ 3202 --wpds-color-fg-interactive-neutral-strong: #f0f0f0; /* Foreground color for interactive elements with neutral tone and strong emphasis. */ 3203 --wpds-color-fg-interactive-neutral-strong-active: #f0f0f0; /* Foreground color for interactive elements with neutral tone and strong emphasis that are hovered, focused, or active. */ 3204 --wpds-color-fg-interactive-neutral-strong-disabled: #6d6d6d; /* Foreground color for interactive elements with neutral tone and strong emphasis, in their disabled state. */ 3205 --wpds-color-fg-interactive-neutral-weak: #6d6d6d; /* Foreground color for interactive elements with neutral tone and weak emphasis. */ 3206 --wpds-color-fg-interactive-neutral-weak-disabled: #8a8a8a; /* Foreground color for interactive elements with neutral tone and weak emphasis, in their disabled state. */ 3207 --wpds-color-stroke-focus-brand: #3858e9; /* Accessible stroke color applied to focus rings. */ 3208 --wpds-color-stroke-interactive-brand: #3858e9; /* Accessible stroke color used for interactive brand-toned elements with normal emphasis. */ 3209 --wpds-color-stroke-interactive-brand-active: #2337c8; /* Accessible stroke color used for interactive brand-toned elements with normal emphasis that are hovered, focused, or active. */ 3210 --wpds-color-stroke-interactive-error: #cc1818; /* Accessible stroke color used for interactive error-toned elements with normal emphasis. */ 3211 --wpds-color-stroke-interactive-error-active: #9d0000; /* Accessible stroke color used for interactive error-toned elements with normal emphasis that are hovered, focused, or active. */ 3212 --wpds-color-stroke-interactive-error-strong: #cc1818; /* Accessible stroke color used for interactive error-toned elements with strong emphasis. */ 3213 --wpds-color-stroke-interactive-neutral: #8a8a8a; /* Accessible stroke color used for interactive neutrally-toned elements with normal emphasis. */ 3214 --wpds-color-stroke-interactive-neutral-active: #6c6c6c; /* Accessible stroke color used for interactive neutrally-toned elements with normal emphasis that are hovered, focused, or active. */ 3215 --wpds-color-stroke-interactive-neutral-disabled: #d8d8d8; /* Accessible stroke color used for interactive neutrally-toned elements with normal emphasis, in their disabled state. */ 3216 --wpds-color-stroke-interactive-neutral-strong: #6c6c6c; /* Accessible stroke color used for interactive neutrally-toned elements with strong emphasis. */ 3217 --wpds-color-stroke-surface-brand: #a3b1d4; /* Decorative stroke color used to define brand-toned surface boundaries with normal emphasis. */ 3218 --wpds-color-stroke-surface-brand-strong: #3858e9; /* Decorative stroke color used to define brand-toned surface boundaries with strong emphasis. */ 3219 --wpds-color-stroke-surface-error: #daa39b; /* Decorative stroke color used to define error-toned surface boundaries with normal emphasis. */ 3220 --wpds-color-stroke-surface-error-strong: #cc1818; /* Decorative stroke color used to define error-toned surface boundaries with strong emphasis. */ 3221 --wpds-color-stroke-surface-info: #9fbcdc; /* Decorative stroke color used to define info-toned surface boundaries with normal emphasis. */ 3222 --wpds-color-stroke-surface-info-strong: #006bd7; /* Decorative stroke color used to define info-toned surface boundaries with strong emphasis. */ 3223 --wpds-color-stroke-surface-neutral: #d8d8d8; /* Decorative stroke color used to define neutrally-toned surface boundaries with normal emphasis. */ 3224 --wpds-color-stroke-surface-neutral-strong: #8a8a8a; /* Decorative stroke color used to define neutrally-toned surface boundaries with strong emphasis. */ 3225 --wpds-color-stroke-surface-neutral-weak: #e0e0e0; /* Decorative stroke color used to define neutrally-toned surface boundaries with weak emphasis. */ 3226 --wpds-color-stroke-surface-success: #8ac894; /* Decorative stroke color used to define success-toned surface boundaries with normal emphasis. */ 3227 --wpds-color-stroke-surface-success-strong: #007f30; /* Decorative stroke color used to define success-toned surface boundaries with strong emphasis. */ 3228 --wpds-color-stroke-surface-warning: #d0b381; /* Decorative stroke color used to define warning-toned surface boundaries with normal emphasis. */ 3229 --wpds-color-stroke-surface-warning-strong: #926300; /* Decorative stroke color used to define warning-toned surface boundaries with strong emphasis. */ 3230 --wpds-dimension-base: 4px; /* Base dimension unit */ 3231 --wpds-dimension-gap-2xs: 4px; /* 2x extra small gap */ 3232 --wpds-dimension-gap-lg: 24px; /* Large gap */ 3233 --wpds-dimension-gap-md: 16px; /* Medium gap */ 3234 --wpds-dimension-gap-sm: 12px; /* Small gap */ 3235 --wpds-dimension-gap-xl: 40px; /* Extra large gap */ 3236 --wpds-dimension-gap-xs: 8px; /* Extra small gap */ 3237 --wpds-dimension-padding-surface-2xs: 4px; /* 2x extra small spacing for surfaces */ 3238 --wpds-dimension-padding-surface-lg: 32px; /* Large spacing for surfaces */ 3239 --wpds-dimension-padding-surface-md: 24px; /* Medium spacing for surfaces */ 3240 --wpds-dimension-padding-surface-sm: 16px; /* Small spacing for surfaces */ 3241 --wpds-dimension-padding-surface-xs: 8px; /* Extra small spacing for surfaces */ 3242 --wpds-elevation-large: 0 5px 15px 0 #00000014, 0 15px 27px 0 #00000012, 3243 0 30px 36px 0 #0000000a, 0 50px 43px 0 #00000005; /* For components that confirm decisions or handle necessary interruptions. Example: Modals. */ 3244 --wpds-elevation-medium: 0 2px 3px 0 #0000000d, 0 4px 5px 0 #0000000a, 3245 0 12px 12px 0 #00000008, 0 16px 16px 0 #00000005; /* For components that offer additional actions. Example: Menus, Command Palette */ 3246 --wpds-elevation-small: 0 1px 2px 0 #0000000d, 0 2px 3px 0 #0000000a, 3247 0 6px 6px 0 #00000008, 0 8px 8px 0 #00000005; /* For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar. */ 3248 --wpds-elevation-x-small: 0 1px 1px 0 #00000008, 0 1px 2px 0 #00000005, 3249 0 3px 3px 0 #00000005, 0 4px 4px 0 #00000003; /* For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame. */ 3250 --wpds-font-family-body: -apple-system, system-ui, "Segoe UI", "Roboto", 3251 "Oxygen-Sans", "Ubuntu", "Cantarell", "Helvetica Neue", sans-serif; /* Body font family */ 3252 --wpds-font-family-heading: -apple-system, system-ui, "Segoe UI", "Roboto", 3253 "Oxygen-Sans", "Ubuntu", "Cantarell", "Helvetica Neue", sans-serif; /* Headings font family */ 3254 --wpds-font-family-mono: "Menlo", "Consolas", monaco, monospace; /* Monospace font family */ 3255 --wpds-font-line-height-2x-large: 40px; /* 2X large line height */ 3256 --wpds-font-line-height-large: 28px; /* Large line height */ 3257 --wpds-font-line-height-medium: 24px; /* Medium line height */ 3258 --wpds-font-line-height-small: 20px; /* Small line height */ 3259 --wpds-font-line-height-x-large: 32px; /* Extra large line height */ 3260 --wpds-font-line-height-x-small: 16px; /* Extra small line height */ 3261 --wpds-font-size-2x-large: 32px; /* 2X large font size */ 3262 --wpds-font-size-large: 15px; /* Large font size */ 3263 --wpds-font-size-medium: 13px; /* Medium font size */ 3264 --wpds-font-size-small: 12px; /* Small font size */ 3265 --wpds-font-size-x-large: 20px; /* Extra large font size */ 3266 --wpds-font-size-x-small: 11px; /* Extra small font size */ 3267 } 3268 3269 [data-wpds-theme-provider-id][data-wpds-density=default] { 3270 --wpds-dimension-base: 4px; /* Base dimension unit */ 3271 --wpds-dimension-gap-2xs: 4px; /* 2x extra small gap */ 3272 --wpds-dimension-gap-lg: 24px; /* Large gap */ 3273 --wpds-dimension-gap-md: 16px; /* Medium gap */ 3274 --wpds-dimension-gap-sm: 12px; /* Small gap */ 3275 --wpds-dimension-gap-xl: 40px; /* Extra large gap */ 3276 --wpds-dimension-gap-xs: 8px; /* Extra small gap */ 3277 --wpds-dimension-padding-surface-2xs: 4px; /* 2x extra small spacing for surfaces */ 3278 --wpds-dimension-padding-surface-lg: 32px; /* Large spacing for surfaces */ 3279 --wpds-dimension-padding-surface-md: 24px; /* Medium spacing for surfaces */ 3280 --wpds-dimension-padding-surface-sm: 16px; /* Small spacing for surfaces */ 3281 --wpds-dimension-padding-surface-xs: 8px; /* Extra small spacing for surfaces */ 3282 } 3283 3284 [data-wpds-theme-provider-id][data-wpds-density=compact] { 3285 --wpds-dimension-gap-2xs: 4px; /* 2x extra small gap */ 3286 --wpds-dimension-gap-lg: 20px; /* Large gap */ 3287 --wpds-dimension-gap-md: 12px; /* Medium gap */ 3288 --wpds-dimension-gap-sm: 8px; /* Small gap */ 3289 --wpds-dimension-gap-xl: 32px; /* Extra large gap */ 3290 --wpds-dimension-gap-xs: 4px; /* Extra small gap */ 3291 --wpds-dimension-padding-surface-2xs: 4px; /* 2x extra small spacing for surfaces */ 3292 --wpds-dimension-padding-surface-lg: 24px; /* Large spacing for surfaces */ 3293 --wpds-dimension-padding-surface-md: 20px; /* Medium spacing for surfaces */ 3294 --wpds-dimension-padding-surface-sm: 12px; /* Small spacing for surfaces */ 3295 --wpds-dimension-padding-surface-xs: 4px; /* Extra small spacing for surfaces */ 3296 } 3297 3298 [data-wpds-theme-provider-id][data-wpds-density=comfortable] { 3299 --wpds-dimension-gap-2xs: 8px; /* 2x extra small gap */ 3300 --wpds-dimension-gap-lg: 32px; /* Large gap */ 3301 --wpds-dimension-gap-md: 20px; /* Medium gap */ 3302 --wpds-dimension-gap-sm: 16px; /* Small gap */ 3303 --wpds-dimension-gap-xl: 48px; /* Extra large gap */ 3304 --wpds-dimension-gap-xs: 12px; /* Extra small gap */ 3305 --wpds-dimension-padding-surface-2xs: 8px; /* 2x extra small spacing for surfaces */ 3306 --wpds-dimension-padding-surface-lg: 40px; /* Large spacing for surfaces */ 3307 --wpds-dimension-padding-surface-md: 32px; /* Medium spacing for surfaces */ 3308 --wpds-dimension-padding-surface-sm: 20px; /* Small spacing for surfaces */ 3309 --wpds-dimension-padding-surface-xs: 12px; /* Extra small spacing for surfaces */ 3310 } 3311 3312 @media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) { 3313 :root { 3314 --wpds-border-width-interactive-focus: 1.5px; /* Border width for focus ring */ 3315 } 3316 } 3317 /** 3318 * Colors 3319 */ 3320 /** 3321 * SCSS Variables. 3322 * 3323 * Please use variables from this sheet to ensure consistency across the UI. 3324 * Don't add to this sheet unless you're pretty sure the value will be reused in many places. 3325 * For example, don't add rules to this sheet that affect block visuals. It's purely for UI. 3326 */ 3327 /** 3328 * Fonts & basic variables. 3329 */ 3330 /** 3331 * Typography 3332 */ 3333 /** 3334 * Grid System. 3335 * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/ 3336 */ 3337 /** 3338 * Radius scale. 3339 */ 3340 /** 3341 * Elevation scale. 3342 */ 3343 /** 3344 * Dimensions. 3345 */ 3346 /** 3347 * Mobile specific styles 3348 */ 3349 /** 3350 * Editor styles. 3351 */ 3352 /** 3353 * Block & Editor UI. 3354 */ 3355 /** 3356 * Block paddings. 3357 */ 3358 /** 3359 * React Native specific. 3360 * These variables do not appear to be used anywhere else. 3361 */ 3362 /** 3363 * Typography 3364 */ 3365 /** 3366 * Breakpoints & Media Queries 3367 */ 3368 /** 3369 * Converts a hex value into the rgb equivalent. 3370 * 3371 * @param {string} hex - the hexadecimal value to convert 3372 * @return {string} comma separated rgb values 3373 */ 3374 /** 3375 * Long content fade mixin 3376 * 3377 * Creates a fading overlay to signify that the content is longer 3378 * than the space allows. 3379 */ 3380 /** 3381 * Breakpoint mixins 3382 */ 3383 /** 3384 * Focus styles. 3385 */ 3386 /** 3387 * Applies editor left position to the selector passed as argument 3388 */ 3389 /** 3390 * Styles that are reused verbatim in a few places 3391 */ 3392 /** 3393 * Allows users to opt-out of animations via OS-level preferences. 3394 */ 3395 /** 3396 * Reset default styles for JavaScript UI based pages. 3397 * This is a WP-admin agnostic reset 3398 */ 3399 /** 3400 * Reset the WP Admin page styles for Gutenberg-like pages. 3401 */ 3402 .admin-ui-page { 3403 display: flex; 3404 height: 100%; 3405 background-color: #fff; 3406 color: #2f2f2f; 3407 position: relative; 3408 z-index: 1; 3409 flex-flow: column; 3410 } 3411 3412 .admin-ui-page__header { 3413 padding: 16px 24px; 3414 border-bottom: 1px solid #f0f0f0; 3415 background: #fff; 3416 position: sticky; 3417 top: 0; 3418 z-index: 1; 3419 } 3420 3421 .admin-ui-page__sidebar-toggle-slot:empty { 3422 display: none; 3423 } 3424 3425 .admin-ui-page__header-subtitle { 3426 padding-block-end: 8px; 3427 color: #757575; 3428 font-family: -apple-system, "system-ui", "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; 3429 font-weight: 400; 3430 font-size: 13px; 3431 line-height: 20px; 3432 margin: 0; 3433 } 3434 3435 .admin-ui-page__content { 3436 flex-grow: 1; 3437 overflow: auto; 3438 display: flex; 3439 flex-direction: column; 3440 } 3441 3442 .admin-ui-page__content.has-padding { 3443 padding: 16px 24px; 3444 } 3445 3446 .show-icon-labels .admin-ui-page__header-actions .components-button.has-icon { 3447 width: auto; 3448 padding: 0 8px; 3449 } 3450 3451 .show-icon-labels .admin-ui-page__header-actions .components-button.has-icon svg { 3452 display: none; 3453 } 3454 3455 .show-icon-labels .admin-ui-page__header-actions .components-button.has-icon::after { 3456 content: attr(aria-label); 3457 font-size: 12px; 3458 } 3459 3460 .admin-ui-breadcrumbs__list { 3461 list-style: none; 3462 padding: 0; 3463 margin: 0; 3464 gap: 0; 3465 font-size: 15px; 3466 min-height: 32px; 3467 font-weight: 500; 3468 } 3469 3470 .admin-ui-breadcrumbs__list li:not(:last-child)::after { 3471 content: "/"; 3472 margin: 0 8px; 3473 } 3474 3475 .admin-ui-breadcrumbs__list h1 { 3476 font-size: inherit; 3477 line-height: inherit; 3478 } 3479 3480 /** 3481 * Typography 3482 */ 3483 /** 3484 * SCSS Variables. 3485 * 3486 * Please use variables from this sheet to ensure consistency across the UI. 3487 * Don't add to this sheet unless you're pretty sure the value will be reused in many places. 3488 * For example, don't add rules to this sheet that affect block visuals. It's purely for UI. 3489 */ 3490 /** 3491 * Colors 3492 */ 3493 /** 3494 * Fonts & basic variables. 3495 */ 3496 /** 3497 * Typography 3498 */ 3499 /** 3500 * Grid System. 3501 * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/ 3502 */ 3503 /** 3504 * Radius scale. 3505 */ 3506 /** 3507 * Elevation scale. 3508 */ 3509 /** 3510 * Dimensions. 3511 */ 3512 /** 3513 * Mobile specific styles 3514 */ 3515 /** 3516 * Editor styles. 3517 */ 3518 /** 3519 * Block & Editor UI. 3520 */ 3521 /** 3522 * Block paddings. 3523 */ 3524 /** 3525 * React Native specific. 3526 * These variables do not appear to be used anywhere else. 3527 */ 3528 /** 3529 * Breakpoints & Media Queries 3530 */ 3531 /** 3532 * Converts a hex value into the rgb equivalent. 3533 * 3534 * @param {string} hex - the hexadecimal value to convert 3535 * @return {string} comma separated rgb values 3536 */ 3537 /** 3538 * Long content fade mixin 3539 * 3540 * Creates a fading overlay to signify that the content is longer 3541 * than the space allows. 3542 */ 3543 /** 3544 * Breakpoint mixins 3545 */ 3546 /** 3547 * Focus styles. 3548 */ 3549 /** 3550 * Applies editor left position to the selector passed as argument 3551 */ 3552 /** 3553 * Styles that are reused verbatim in a few places 3554 */ 3555 /** 3556 * Allows users to opt-out of animations via OS-level preferences. 3557 */ 3558 /** 3559 * Reset default styles for JavaScript UI based pages. 3560 * This is a WP-admin agnostic reset 3561 */ 3562 /** 3563 * Reset the WP Admin page styles for Gutenberg-like pages. 3564 */ 3565 @media (min-width: 600px) { 3566 .boot-layout-container .boot-layout { 3567 position: absolute; 3568 top: 0; 3569 right: 0; 3570 bottom: 0; 3571 left: 0; 3572 min-height: calc(100vh - 46px); 3573 } 3574 } 3575 @media (min-width: 782px) { 3576 .boot-layout-container .boot-layout { 3577 min-height: calc(100vh - 32px); 3578 } 3579 body:has(.boot-layout.has-full-canvas) .boot-layout-container .boot-layout { 3580 min-height: 100vh; 3581 } 3582 } 3583 .boot-layout-container .boot-layout img { 3584 max-width: 100%; 3585 height: auto; 3586 } 3587 3588 .boot-layout .components-editor-notices__snackbar { 3589 position: fixed; 3590 right: 0; 3591 bottom: 16px; 3592 padding-left: 16px; 3593 padding-right: 16px; 3594 } 3595 /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src","sources":["../../../node_modules/@wordpress/theme/src/prebuilt/css/design-tokens.css","../../../node_modules/@wordpress/admin-ui/build-style/style.css","../../../node_modules/@wordpress/base-styles/_mixins.scss","../../../node_modules/@wordpress/base-styles/_variables.scss","../../../node_modules/@wordpress/base-styles/_colors.scss","../../../node_modules/@wordpress/base-styles/_breakpoints.scss","../../../node_modules/@wordpress/base-styles/_functions.scss","../../../node_modules/@wordpress/base-styles/_long-content-fade.scss","style.scss"],"names":[],"mappings":";AAAA;AAAA;AAAA;AAIA;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AAAA,qDACmD;EACnD;AAAA,qDACmD;EACnD;AAAA,iDAC+C;EAC/C;AAAA,iDAC+C;EAC/C;AAAA,uEACqE;EACrE;AAAA,uEACqE;EACrE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGD;EACC;IACC;;;ACzMF;AAAA;AAAA;AAGA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAOA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAAA;AAIA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAAA;AAIA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAAA;AAIA;AAAA;AAAA;AAGA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;;;AAEF;EACE;;;AAGF;EACE;EACA;;;AAEF;EACE;;;AAEF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;;AAEF;EACE;EACA;;;AAEF;EACE;EACA;;;AC3JF;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEnKA;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AL4EA;AAAA;AAAA;AA0DA;AAAA;AAAA;AAgDA;AAAA;AAAA;AAqCA;AAAA;AAAA;AAoBA;AAAA;AAAA;AAwLA;AAAA;AAAA;AAAA;AAgDA;AAAA;AAAA;AAlWC;EMhHD;IAIE;IACA;IACA;IACA;IACA;IACA;;;ANiGD;EM1GD;IAcE;;EAEA;IACC;;;AAIF;EACC;EACA;;;AAIF;EACC;EACA;EACA;EACA;EACA","sourcesContent":["/* -------------------------------------------\n *  Autogenerated by ⛋ Terrazzo. DO NOT EDIT!\n * ------------------------------------------- */\n\n:root {\n\t--wpds-border-radius-surface-lg: 8px; /* Large radius for surfaces */\n\t--wpds-border-radius-surface-md: 4px; /* Medium radius for surfaces */\n\t--wpds-border-radius-surface-sm: 2px; /* Small radius for surfaces */\n\t--wpds-border-radius-surface-xs: 1px; /* Extra small radius for surfaces */\n\t--wpds-border-width-interactive-focus: 2px; /* Border width for focus ring */\n\t--wpds-border-width-surface-lg: 8px; /* Large width for surfaces */\n\t--wpds-border-width-surface-md: 4px; /* Medium width for surfaces */\n\t--wpds-border-width-surface-sm: 2px; /* Small width for surfaces */\n\t--wpds-border-width-surface-xs: 1px; /* Extra small width for surfaces */\n\t--wpds-color-bg-interactive-brand: #00000000; /* Background color for interactive elements with brand tone and normal emphasis. */\n\t--wpds-color-bg-interactive-brand-active: #f6f8fd; /* Background color for interactive elements with brand tone and normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-brand-disabled: #e2e2e2; /* Background color for interactive elements with brand tone and normal emphasis, in their disabled state. */\n\t--wpds-color-bg-interactive-brand-strong: #3858e9; /* Background color for interactive elements with brand tone and strong emphasis. */\n\t--wpds-color-bg-interactive-brand-strong-active: #2e49d9; /* Background color for interactive elements with brand tone and strong emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-brand-strong-disabled: #d2d2d2; /* Background color for interactive elements with brand tone and strong emphasis, in their disabled state. */\n\t--wpds-color-bg-interactive-brand-weak: #00000000; /* Background color for interactive elements with brand tone and weak emphasis. */\n\t--wpds-color-bg-interactive-brand-weak-active: #e6eaf4; /* Background color for interactive elements with brand tone and weak emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-brand-weak-disabled: #e2e2e2; /* Background color for interactive elements with brand tone and weak emphasis, in their disabled state. */\n\t--wpds-color-bg-interactive-error: #00000000; /* Background color for interactive elements with error tone and normal emphasis. */\n\t--wpds-color-bg-interactive-error-active: #fff6f4; /* Background color for interactive elements with error tone and normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-error-disabled: #e2e2e2; /* Background color for interactive elements with error tone and normal emphasis, in their disabled state. */\n\t--wpds-color-bg-interactive-error-strong: #cc1818; /* Background color for interactive elements with error tone and strong emphasis. */\n\t--wpds-color-bg-interactive-error-strong-active: #b90000; /* Background color for interactive elements with error tone and strong emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-error-strong-disabled: #d2d2d2; /* Background color for interactive elements with error tone and strong emphasis, in their disabled state. */\n\t--wpds-color-bg-interactive-error-weak: #00000000; /* Background color for interactive elements with error tone and weak emphasis. */\n\t--wpds-color-bg-interactive-error-weak-active: #f6e6e3; /* Background color for interactive elements with error tone and weak emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-error-weak-disabled: #e2e2e2; /* Background color for interactive elements with error tone and weak emphasis, in their disabled state. */\n\t--wpds-color-bg-interactive-neutral: #00000000; /* Background color for interactive elements with neutral tone and normal emphasis. */\n\t--wpds-color-bg-interactive-neutral-active: #eaeaea; /* Background color for interactive elements with neutral tone and normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-neutral-disabled: #e2e2e2; /* Background color for interactive elements with neutral tone and normal emphasis, in their disabled state. */\n\t--wpds-color-bg-interactive-neutral-strong: #2d2d2d; /* Background color for interactive elements with neutral tone and strong emphasis. */\n\t--wpds-color-bg-interactive-neutral-strong-active: #1e1e1e; /* Background color for interactive elements with neutral tone and strong emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-neutral-strong-disabled: #d2d2d2; /* Background color for interactive elements with neutral tone and strong emphasis, in their disabled state. */\n\t--wpds-color-bg-interactive-neutral-weak: #00000000; /* Background color for interactive elements with neutral tone and weak emphasis. */\n\t--wpds-color-bg-interactive-neutral-weak-active: #eaeaea; /* Background color for interactive elements with neutral tone and weak emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-neutral-weak-disabled: #e2e2e2; /* Background color for interactive elements with neutral tone and weak emphasis, in their disabled state. */\n\t--wpds-color-bg-surface-brand: #ecf0f9; /* Background color for surfaces with brand tone and normal emphasis. */\n\t--wpds-color-bg-surface-caution: #fee994; /* Background color for surfaces with caution tone and normal emphasis. */\n\t--wpds-color-bg-surface-caution-weak: #fff9c9; /* Background color for surfaces with caution tone and weak emphasis. */\n\t--wpds-color-bg-surface-error: #f6e6e3; /* Background color for surfaces with error tone and normal emphasis. */\n\t--wpds-color-bg-surface-error-weak: #fff6f4; /* Background color for surfaces with error tone and weak emphasis. */\n\t--wpds-color-bg-surface-info: #deebfa; /* Background color for surfaces with info tone and normal emphasis. */\n\t--wpds-color-bg-surface-info-weak: #f3f9ff; /* Background color for surfaces with info tone and weak emphasis. */\n\t--wpds-color-bg-surface-neutral: #f8f8f8; /* Background color for surfaces with normal emphasis. */\n\t--wpds-color-bg-surface-neutral-strong: #ffffff; /* Background color for surfaces with strong emphasis. */\n\t--wpds-color-bg-surface-neutral-weak: #f0f0f0; /* Background color for surfaces with weak emphasis. */\n\t--wpds-color-bg-surface-success: #c5f7cc; /* Background color for surfaces with success tone and normal emphasis. */\n\t--wpds-color-bg-surface-success-weak: #eaffed; /* Background color for surfaces with success tone and weak emphasis. */\n\t--wpds-color-bg-surface-warning: #fde6bd; /* Background color for surfaces with warning tone and normal emphasis. */\n\t--wpds-color-bg-surface-warning-weak: #fff7e0; /* Background color for surfaces with warning tone and weak emphasis. */\n\t--wpds-color-bg-thumb-brand: #3858e9; /* Background color for thumbs with a brand tone and normal emphasis (eg. slider thumb and filled track). */\n\t--wpds-color-bg-thumb-brand-active: #3858e9; /* Background color for thumbs with a brand tone and normal emphasis (eg. slider thumb and filled track) that are hovered, focused, or active. */\n\t--wpds-color-bg-thumb-brand-disabled: #d8d8d8; /* Background color for thumbs with a brand tone and normal emphasis (eg. slider thumb and filled track), in their disabled state. */\n\t--wpds-color-bg-thumb-neutral-weak: #8a8a8a; /* Background color for thumbs with a neutral tone and weak emphasis (eg. scrollbar thumb). */\n\t--wpds-color-bg-thumb-neutral-weak-active: #6c6c6c; /* Background color for thumbs with a neutral tone and weak emphasis (eg. scrollbar thumb) that are hovered, focused, or active. */\n\t--wpds-color-bg-track-neutral: #d8d8d8; /* Background color for tracks with a neutral tone and normal emphasis (eg. slider or progressbar track). */\n\t--wpds-color-bg-track-neutral-weak: #e0e0e0; /* Background color for tracks with a neutral tone and weak emphasis (eg. scrollbar track). */\n\t--wpds-color-fg-content-caution: #281d00; /* Foreground color for content like text with caution tone and normal emphasis. */\n\t--wpds-color-fg-content-caution-weak: #826a00; /* Foreground color for content like text with caution tone and weak emphasis. */\n\t--wpds-color-fg-content-error: #470000; /* Foreground color for content like text with error tone and normal emphasis. */\n\t--wpds-color-fg-content-error-weak: #cc1818; /* Foreground color for content like text with error tone and weak emphasis. */\n\t--wpds-color-fg-content-info: #001b4f; /* Foreground color for content like text with info tone and normal emphasis. */\n\t--wpds-color-fg-content-info-weak: #006bd7; /* Foreground color for content like text with info tone and weak emphasis. */\n\t--wpds-color-fg-content-neutral: #1e1e1e; /* Foreground color for content like text with normal emphasis. */\n\t--wpds-color-fg-content-neutral-weak: #6d6d6d; /* Foreground color for content like text with weak emphasis. */\n\t--wpds-color-fg-content-success: #002900; /* Foreground color for content like text with success tone and normal emphasis. */\n\t--wpds-color-fg-content-success-weak: #007f30; /* Foreground color for content like text with success tone and weak emphasis. */\n\t--wpds-color-fg-content-warning: #2e1900; /* Foreground color for content like text with warning tone and normal emphasis. */\n\t--wpds-color-fg-content-warning-weak: #926300; /* Foreground color for content like text with warning tone and weak emphasis. */\n\t--wpds-color-fg-interactive-brand: #3858e9; /* Foreground color for interactive elements with brand tone and normal emphasis. */\n\t--wpds-color-fg-interactive-brand-active: #3858e9; /* Foreground color for interactive elements with brand tone and normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-fg-interactive-brand-disabled: #8a8a8a; /* Foreground color for interactive elements with brand tone and normal emphasis, in their disabled state. */\n\t--wpds-color-fg-interactive-brand-strong: #eff0f2; /* Foreground color for interactive elements with brand tone and strong emphasis. */\n\t--wpds-color-fg-interactive-brand-strong-active: #eff0f2; /* Foreground color for interactive elements with brand tone and strong emphasis that are hovered, focused, or active. */\n\t--wpds-color-fg-interactive-brand-strong-disabled: #6d6d6d; /* Foreground color for interactive elements with brand tone and strong emphasis, in their disabled state. */\n\t--wpds-color-fg-interactive-error: #cc1818; /* Foreground color for interactive elements with error tone and normal emphasis. */\n\t--wpds-color-fg-interactive-error-active: #cc1818; /* Foreground color for interactive elements with error tone and normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-fg-interactive-error-disabled: #8a8a8a; /* Foreground color for interactive elements with error tone and normal emphasis, in their disabled state. */\n\t--wpds-color-fg-interactive-error-strong: #f2efef; /* Foreground color for interactive elements with error tone and strong emphasis. */\n\t--wpds-color-fg-interactive-error-strong-active: #f2efef; /* Foreground color for interactive elements with error tone and strong emphasis that are hovered, focused, or active. */\n\t--wpds-color-fg-interactive-error-strong-disabled: #6d6d6d; /* Foreground color for interactive elements with error tone and strong emphasis, in their disabled state. */\n\t--wpds-color-fg-interactive-neutral: #1e1e1e; /* Foreground color for interactive elements with neutral tone and normal emphasis. */\n\t--wpds-color-fg-interactive-neutral-active: #1e1e1e; /* Foreground color for interactive elements with neutral tone and normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-fg-interactive-neutral-disabled: #8a8a8a; /* Foreground color for interactive elements with neutral tone and normal emphasis, in their disabled state. */\n\t--wpds-color-fg-interactive-neutral-strong: #f0f0f0; /* Foreground color for interactive elements with neutral tone and strong emphasis. */\n\t--wpds-color-fg-interactive-neutral-strong-active: #f0f0f0; /* Foreground color for interactive elements with neutral tone and strong emphasis that are hovered, focused, or active. */\n\t--wpds-color-fg-interactive-neutral-strong-disabled: #6d6d6d; /* Foreground color for interactive elements with neutral tone and strong emphasis, in their disabled state. */\n\t--wpds-color-fg-interactive-neutral-weak: #6d6d6d; /* Foreground color for interactive elements with neutral tone and weak emphasis. */\n\t--wpds-color-fg-interactive-neutral-weak-disabled: #8a8a8a; /* Foreground color for interactive elements with neutral tone and weak emphasis, in their disabled state. */\n\t--wpds-color-stroke-focus-brand: #3858e9; /* Accessible stroke color applied to focus rings. */\n\t--wpds-color-stroke-interactive-brand: #3858e9; /* Accessible stroke color used for interactive brand-toned elements with normal emphasis. */\n\t--wpds-color-stroke-interactive-brand-active: #2337c8; /* Accessible stroke color used for interactive brand-toned elements with normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-stroke-interactive-error: #cc1818; /* Accessible stroke color used for interactive error-toned elements with normal emphasis. */\n\t--wpds-color-stroke-interactive-error-active: #9d0000; /* Accessible stroke color used for interactive error-toned elements with normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-stroke-interactive-error-strong: #cc1818; /* Accessible stroke color used for interactive error-toned elements with strong emphasis. */\n\t--wpds-color-stroke-interactive-neutral: #8a8a8a; /* Accessible stroke color used for interactive neutrally-toned elements with normal emphasis. */\n\t--wpds-color-stroke-interactive-neutral-active: #6c6c6c; /* Accessible stroke color used for interactive neutrally-toned elements with normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-stroke-interactive-neutral-disabled: #d8d8d8; /* Accessible stroke color used for interactive neutrally-toned elements with normal emphasis, in their disabled state. */\n\t--wpds-color-stroke-interactive-neutral-strong: #6c6c6c; /* Accessible stroke color used for interactive neutrally-toned elements with strong emphasis. */\n\t--wpds-color-stroke-surface-brand: #a3b1d4; /* Decorative stroke color used to define brand-toned surface boundaries with normal emphasis. */\n\t--wpds-color-stroke-surface-brand-strong: #3858e9; /* Decorative stroke color used to define brand-toned surface boundaries with strong emphasis. */\n\t--wpds-color-stroke-surface-error: #daa39b; /* Decorative stroke color used to define error-toned surface boundaries with normal emphasis. */\n\t--wpds-color-stroke-surface-error-strong: #cc1818; /* Decorative stroke color used to define error-toned surface boundaries with strong emphasis. */\n\t--wpds-color-stroke-surface-info: #9fbcdc; /* Decorative stroke color used to define info-toned surface boundaries with normal emphasis. */\n\t--wpds-color-stroke-surface-info-strong: #006bd7; /* Decorative stroke color used to define info-toned surface boundaries with strong emphasis. */\n\t--wpds-color-stroke-surface-neutral: #d8d8d8; /* Decorative stroke color used to define neutrally-toned surface boundaries with normal emphasis. */\n\t--wpds-color-stroke-surface-neutral-strong: #8a8a8a; /* Decorative stroke color used to define neutrally-toned surface boundaries with strong emphasis. */\n\t--wpds-color-stroke-surface-neutral-weak: #e0e0e0; /* Decorative stroke color used to define neutrally-toned surface boundaries with weak emphasis. */\n\t--wpds-color-stroke-surface-success: #8ac894; /* Decorative stroke color used to define success-toned surface boundaries with normal emphasis. */\n\t--wpds-color-stroke-surface-success-strong: #007f30; /* Decorative stroke color used to define success-toned surface boundaries with strong emphasis. */\n\t--wpds-color-stroke-surface-warning: #d0b381; /* Decorative stroke color used to define warning-toned surface boundaries with normal emphasis. */\n\t--wpds-color-stroke-surface-warning-strong: #926300; /* Decorative stroke color used to define warning-toned surface boundaries with strong emphasis. */\n\t--wpds-dimension-base: 4px; /* Base dimension unit */\n\t--wpds-dimension-gap-2xs: 4px; /* 2x extra small gap */\n\t--wpds-dimension-gap-lg: 24px; /* Large gap */\n\t--wpds-dimension-gap-md: 16px; /* Medium gap */\n\t--wpds-dimension-gap-sm: 12px; /* Small gap */\n\t--wpds-dimension-gap-xl: 40px; /* Extra large gap */\n\t--wpds-dimension-gap-xs: 8px; /* Extra small gap */\n\t--wpds-dimension-padding-surface-2xs: 4px; /* 2x extra small spacing for surfaces */\n\t--wpds-dimension-padding-surface-lg: 32px; /* Large spacing for surfaces */\n\t--wpds-dimension-padding-surface-md: 24px; /* Medium spacing for surfaces */\n\t--wpds-dimension-padding-surface-sm: 16px; /* Small spacing for surfaces */\n\t--wpds-dimension-padding-surface-xs: 8px; /* Extra small spacing for surfaces */\n\t--wpds-elevation-large: 0 5px 15px 0 #00000014, 0 15px 27px 0 #00000012,\n\t\t0 30px 36px 0 #0000000a, 0 50px 43px 0 #00000005; /* For components that confirm decisions or handle necessary interruptions. Example: Modals. */\n\t--wpds-elevation-medium: 0 2px 3px 0 #0000000d, 0 4px 5px 0 #0000000a,\n\t\t0 12px 12px 0 #00000008, 0 16px 16px 0 #00000005; /* For components that offer additional actions. Example: Menus, Command Palette */\n\t--wpds-elevation-small: 0 1px 2px 0 #0000000d, 0 2px 3px 0 #0000000a,\n\t\t0 6px 6px 0 #00000008, 0 8px 8px 0 #00000005; /* For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar. */\n\t--wpds-elevation-x-small: 0 1px 1px 0 #00000008, 0 1px 2px 0 #00000005,\n\t\t0 3px 3px 0 #00000005, 0 4px 4px 0 #00000003; /* For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame. */\n\t--wpds-font-family-body: -apple-system, system-ui, 'Segoe UI', 'Roboto',\n\t\t'Oxygen-Sans', 'Ubuntu', 'Cantarell', 'Helvetica Neue', sans-serif; /* Body font family */\n\t--wpds-font-family-heading: -apple-system, system-ui, 'Segoe UI', 'Roboto',\n\t\t'Oxygen-Sans', 'Ubuntu', 'Cantarell', 'Helvetica Neue', sans-serif; /* Headings font family */\n\t--wpds-font-family-mono: 'Menlo', 'Consolas', monaco, monospace; /* Monospace font family */\n\t--wpds-font-line-height-2x-large: 40px; /* 2X large line height */\n\t--wpds-font-line-height-large: 28px; /* Large line height */\n\t--wpds-font-line-height-medium: 24px; /* Medium line height */\n\t--wpds-font-line-height-small: 20px; /* Small line height */\n\t--wpds-font-line-height-x-large: 32px; /* Extra large line height */\n\t--wpds-font-line-height-x-small: 16px; /* Extra small line height */\n\t--wpds-font-size-2x-large: 32px; /* 2X large font size */\n\t--wpds-font-size-large: 15px; /* Large font size */\n\t--wpds-font-size-medium: 13px; /* Medium font size */\n\t--wpds-font-size-small: 12px; /* Small font size */\n\t--wpds-font-size-x-large: 20px; /* Extra large font size */\n\t--wpds-font-size-x-small: 11px; /* Extra small font size */\n}\n\n[data-wpds-theme-provider-id][data-wpds-density='default'] {\n\t--wpds-dimension-base: 4px; /* Base dimension unit */\n\t--wpds-dimension-gap-2xs: 4px; /* 2x extra small gap */\n\t--wpds-dimension-gap-lg: 24px; /* Large gap */\n\t--wpds-dimension-gap-md: 16px; /* Medium gap */\n\t--wpds-dimension-gap-sm: 12px; /* Small gap */\n\t--wpds-dimension-gap-xl: 40px; /* Extra large gap */\n\t--wpds-dimension-gap-xs: 8px; /* Extra small gap */\n\t--wpds-dimension-padding-surface-2xs: 4px; /* 2x extra small spacing for surfaces */\n\t--wpds-dimension-padding-surface-lg: 32px; /* Large spacing for surfaces */\n\t--wpds-dimension-padding-surface-md: 24px; /* Medium spacing for surfaces */\n\t--wpds-dimension-padding-surface-sm: 16px; /* Small spacing for surfaces */\n\t--wpds-dimension-padding-surface-xs: 8px; /* Extra small spacing for surfaces */\n}\n\n[data-wpds-theme-provider-id][data-wpds-density='compact'] {\n\t--wpds-dimension-gap-2xs: 4px; /* 2x extra small gap */\n\t--wpds-dimension-gap-lg: 20px; /* Large gap */\n\t--wpds-dimension-gap-md: 12px; /* Medium gap */\n\t--wpds-dimension-gap-sm: 8px; /* Small gap */\n\t--wpds-dimension-gap-xl: 32px; /* Extra large gap */\n\t--wpds-dimension-gap-xs: 4px; /* Extra small gap */\n\t--wpds-dimension-padding-surface-2xs: 4px; /* 2x extra small spacing for surfaces */\n\t--wpds-dimension-padding-surface-lg: 24px; /* Large spacing for surfaces */\n\t--wpds-dimension-padding-surface-md: 20px; /* Medium spacing for surfaces */\n\t--wpds-dimension-padding-surface-sm: 12px; /* Small spacing for surfaces */\n\t--wpds-dimension-padding-surface-xs: 4px; /* Extra small spacing for surfaces */\n}\n\n[data-wpds-theme-provider-id][data-wpds-density='comfortable'] {\n\t--wpds-dimension-gap-2xs: 8px; /* 2x extra small gap */\n\t--wpds-dimension-gap-lg: 32px; /* Large gap */\n\t--wpds-dimension-gap-md: 20px; /* Medium gap */\n\t--wpds-dimension-gap-sm: 16px; /* Small gap */\n\t--wpds-dimension-gap-xl: 48px; /* Extra large gap */\n\t--wpds-dimension-gap-xs: 12px; /* Extra small gap */\n\t--wpds-dimension-padding-surface-2xs: 8px; /* 2x extra small spacing for surfaces */\n\t--wpds-dimension-padding-surface-lg: 40px; /* Large spacing for surfaces */\n\t--wpds-dimension-padding-surface-md: 32px; /* Medium spacing for surfaces */\n\t--wpds-dimension-padding-surface-sm: 20px; /* Small spacing for surfaces */\n\t--wpds-dimension-padding-surface-xs: 12px; /* Extra small spacing for surfaces */\n}\n\n@media ( -webkit-min-device-pixel-ratio: 2 ), ( min-resolution: 192dpi ) {\n\t:root {\n\t\t--wpds-border-width-interactive-focus: 1.5px; /* Border width for focus ring */\n\t}\n}\n","/**\n * Colors\n */\n/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n/**\n * Fonts & basic variables.\n */\n/**\n * Typography\n */\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n/**\n * Radius scale.\n */\n/**\n * Elevation scale.\n */\n/**\n * Dimensions.\n */\n/**\n * Mobile specific styles\n */\n/**\n * Editor styles.\n */\n/**\n * Block & Editor UI.\n */\n/**\n * Block paddings.\n */\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n/**\n * Typography\n */\n/**\n * Breakpoints & Media Queries\n */\n/**\n*  Converts a hex value into the rgb equivalent.\n*\n* @param {string} hex - the hexadecimal value to convert\n* @return {string} comma separated rgb values\n*/\n/**\n * Long content fade mixin\n *\n * Creates a fading overlay to signify that the content is longer\n * than the space allows.\n */\n/**\n * Breakpoint mixins\n */\n/**\n * Focus styles.\n */\n/**\n * Applies editor left position to the selector passed as argument\n */\n/**\n * Styles that are reused verbatim in a few places\n */\n/**\n * Allows users to opt-out of animations via OS-level preferences.\n */\n/**\n * Reset default styles for JavaScript UI based pages.\n * This is a WP-admin agnostic reset\n */\n/**\n * Reset the WP Admin page styles for Gutenberg-like pages.\n */\n.admin-ui-page {\n  display: flex;\n  height: 100%;\n  background-color: #fff;\n  color: #2f2f2f;\n  position: relative;\n  z-index: 1;\n  flex-flow: column;\n}\n\n.admin-ui-page__header {\n  padding: 16px 24px;\n  border-bottom: 1px solid #f0f0f0;\n  background: #fff;\n  position: sticky;\n  top: 0;\n  z-index: 1;\n}\n\n.admin-ui-page__sidebar-toggle-slot:empty {\n  display: none;\n}\n\n.admin-ui-page__header-subtitle {\n  padding-block-end: 8px;\n  color: #757575;\n  font-family: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n  font-weight: 400;\n  font-size: 13px;\n  line-height: 20px;\n  margin: 0;\n}\n\n.admin-ui-page__content {\n  flex-grow: 1;\n  overflow: auto;\n  display: flex;\n  flex-direction: column;\n}\n.admin-ui-page__content.has-padding {\n  padding: 16px 24px;\n}\n\n.show-icon-labels .admin-ui-page__header-actions .components-button.has-icon {\n  width: auto;\n  padding: 0 8px;\n}\n.show-icon-labels .admin-ui-page__header-actions .components-button.has-icon svg {\n  display: none;\n}\n.show-icon-labels .admin-ui-page__header-actions .components-button.has-icon::after {\n  content: attr(aria-label);\n  font-size: 12px;\n}\n\n.admin-ui-breadcrumbs__list {\n  list-style: none;\n  padding: 0;\n  margin: 0;\n  gap: 0;\n  font-size: 15px;\n  min-height: 32px;\n  font-weight: 500;\n}\n.admin-ui-breadcrumbs__list li:not(:last-child)::after {\n  content: \"/\";\n  margin: 0 8px;\n}\n.admin-ui-breadcrumbs__list h1 {\n  font-size: inherit;\n  line-height: inherit;\n}","/**\n * Typography\n */\n\n@use \"sass:color\";\n@use \"sass:math\";\n@use \"./variables\";\n@use \"./colors\";\n@use \"./breakpoints\";\n@use \"./functions\";\n@use \"./long-content-fade\";\n\n@mixin _text-heading() {\n\tfont-family: variables.$font-family-headings;\n\tfont-weight: variables.$font-weight-medium;\n}\n\n@mixin _text-body() {\n\tfont-family: variables.$font-family-body;\n\tfont-weight: variables.$font-weight-regular;\n}\n\n@mixin heading-small() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-x-small;\n\tline-height: variables.$font-line-height-x-small;\n}\n\n@mixin heading-medium() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-medium;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin heading-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-large;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin heading-x-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-x-large;\n\tline-height: variables.$font-line-height-medium;\n}\n\n@mixin heading-2x-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-2x-large;\n\tline-height: variables.$font-line-height-2x-large;\n}\n\n@mixin body-small() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-small;\n\tline-height: variables.$font-line-height-x-small;\n}\n\n@mixin body-medium() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-medium;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin body-large() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-large;\n\tline-height: variables.$font-line-height-medium;\n}\n\n@mixin body-x-large() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-x-large;\n\tline-height: variables.$font-line-height-x-large;\n}\n\n/**\n * Breakpoint mixins\n */\n\n@mixin break-xhuge() {\n\t@media (min-width: #{ (breakpoints.$break-xhuge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-huge() {\n\t@media (min-width: #{ (breakpoints.$break-huge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-wide() {\n\t@media (min-width: #{ (breakpoints.$break-wide) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-xlarge() {\n\t@media (min-width: #{ (breakpoints.$break-xlarge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-large() {\n\t@media (min-width: #{ (breakpoints.$break-large) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-medium() {\n\t@media (min-width: #{ (breakpoints.$break-medium) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-small() {\n\t@media (min-width: #{ (breakpoints.$break-small) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-mobile() {\n\t@media (min-width: #{ (breakpoints.$break-mobile) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-zoomed-in() {\n\t@media (min-width: #{ (breakpoints.$break-zoomed-in) }) {\n\t\t@content;\n\t}\n}\n\n/**\n * Focus styles.\n */\n\n@mixin block-toolbar-button-style__focus() {\n\tbox-shadow: inset 0 0 0 variables.$border-width colors.$white, 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n// Tabs, Inputs, Square buttons.\n@mixin input-style__neutral() {\n\tbox-shadow: 0 0 0 transparent;\n\tborder-radius: variables.$radius-small;\n\tborder: variables.$border-width solid colors.$gray-600;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: box-shadow 0.1s linear;\n\t}\n}\n\n\n@mixin input-style__focus($accent-color: var(--wp-admin-theme-color)) {\n\tborder-color: $accent-color;\n\t// Expand the default border focus style by .5px to be a total of 1.5px.\n\tbox-shadow: 0 0 0 0.5px $accent-color;\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n@mixin button-style__focus() {\n\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n\n@mixin button-style-outset__focus($focus-color) {\n\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) colors.$white, 0 0 0 calc(2 * var(--wp-admin-border-width-focus)) $focus-color;\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n\toutline-offset: 2px;\n}\n\n\n/**\n * Applies editor left position to the selector passed as argument\n */\n\n@mixin editor-left($selector) {\n\t#{$selector} { /* Set left position when auto-fold is not on the body element. */\n\t\tleft: 0;\n\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width;\n\t\t}\n\t}\n\n\t.auto-fold #{$selector} { /* Auto fold is when on smaller breakpoints, nav menu auto collapses. */\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width-collapsed;\n\t\t}\n\n\t\t@media (min-width: #{ (breakpoints.$break-large + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width;\n\t\t}\n\t}\n\n\t/* Sidebar manually collapsed. */\n\t.folded #{$selector} {\n\t\tleft: 0;\n\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width-collapsed;\n\t\t}\n\t}\n\n\tbody.is-fullscreen-mode #{$selector} {\n\t\tleft: 0 !important;\n\t}\n}\n\n/**\n * Styles that are reused verbatim in a few places\n */\n\n// These are additional styles for all captions, when the theme opts in to block styles.\n@mixin caption-style() {\n\tmargin-top: 0.5em;\n\tmargin-bottom: 1em;\n}\n\n@mixin caption-style-theme() {\n\tcolor: #555;\n\tfont-size: variables.$default-font-size;\n\ttext-align: center;\n\n\t.is-dark-theme & {\n\t\tcolor: colors.$light-gray-placeholder;\n\t}\n}\n\n/**\n * Allows users to opt-out of animations via OS-level preferences.\n */\n\n@mixin reduce-motion($property: \"\") {\n\n\t@if $property == \"transition\" {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\ttransition-duration: 0s;\n\t\t\ttransition-delay: 0s;\n\t\t}\n\t} @else if $property == \"animation\" {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\tanimation-duration: 1ms;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\t} @else {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\ttransition-duration: 0s;\n\t\t\ttransition-delay: 0s;\n\t\t\tanimation-duration: 1ms;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\t}\n}\n\n@mixin input-control($accent-color: var(--wp-admin-theme-color)) {\n\tfont-family: variables.$default-font;\n\tpadding: 6px 8px;\n\t/* Fonts smaller than 16px causes mobile safari to zoom. */\n\tfont-size: variables.$mobile-text-min-font-size;\n\t/* Override core line-height. To be reviewed. */\n\tline-height: normal;\n\t@include input-style__neutral();\n\n\t@include break-small {\n\t\tfont-size: variables.$default-font-size;\n\t\t/* Override core line-height. To be reviewed. */\n\t\tline-height: normal;\n\t}\n\n\t&:focus {\n\t\t@include input-style__focus($accent-color);\n\t}\n\n\t// Use opacity to work in various editor styles.\n\t&::-webkit-input-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n\n\t&::-moz-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n\n\t&:-ms-input-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n}\n\n@mixin checkbox-control {\n\tborder: variables.$border-width solid colors.$gray-900;\n\tmargin-right: variables.$grid-unit-15;\n\ttransition: none;\n\tborder-radius: variables.$radius-small;\n\t@include input-control;\n\n\t&:focus {\n\t\tbox-shadow: 0 0 0 (variables.$border-width * 2) colors.$white, 0 0 0 (variables.$border-width * 2 + variables.$border-width-focus-fallback) var(--wp-admin-theme-color);\n\n\t\t// Only visible in Windows High Contrast mode.\n\t\toutline: 2px solid transparent;\n\t}\n\n\t&:checked {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder-color: var(--wp-admin-theme-color);\n\n\t\t// Hide default checkbox styles in IE.\n\t\t&::-ms-check {\n\t\t\topacity: 0;\n\t\t}\n\t}\n\n\t&:checked::before,\n\t&[aria-checked=\"mixed\"]::before {\n\t\tmargin: -3px -5px;\n\t\tcolor: colors.$white;\n\n\t\t@include break-medium() {\n\t\t\tmargin: -4px 0 0 -5px;\n\t\t}\n\t}\n\n\t&[aria-checked=\"mixed\"] {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder-color: var(--wp-admin-theme-color);\n\n\t\t&::before {\n\t\t\t// Inherited from `forms.css`.\n\t\t\t// See: https://github.com/WordPress/wordpress-develop/tree/5.1.1/src/wp-admin/css/forms.css#L122-L132\n\t\t\tcontent: \"\\f460\";\n\t\t\tfloat: left;\n\t\t\tdisplay: inline-block;\n\t\t\tvertical-align: middle;\n\t\t\twidth: 16px;\n\t\t\t/* stylelint-disable-next-line font-family-no-missing-generic-family-keyword -- dashicons don't need a generic family keyword. */\n\t\t\tfont: normal 30px/1 dashicons;\n\t\t\tspeak: none;\n\t\t\t-webkit-font-smoothing: antialiased;\n\t\t\t-moz-osx-font-smoothing: grayscale;\n\n\t\t\t@include break-medium() {\n\t\t\t\tfloat: none;\n\t\t\t\tfont-size: 21px;\n\t\t\t}\n\t\t}\n\t}\n\n\t&[aria-disabled=\"true\"],\n\t&:disabled {\n\t\tbackground: colors.$gray-100;\n\t\tborder-color: colors.$gray-300;\n\t\tcursor: default;\n\n\t\t// Override style inherited from wp-admin. Required to avoid degraded appearance on different backgrounds.\n\t\topacity: 1;\n\t}\n}\n\n@mixin radio-control {\n\tborder: variables.$border-width solid colors.$gray-900;\n\tmargin-right: variables.$grid-unit-15;\n\ttransition: none;\n\tborder-radius: variables.$radius-round;\n\twidth: variables.$radio-input-size-sm;\n\theight: variables.$radio-input-size-sm;\n\tmin-width: variables.$radio-input-size-sm;\n\tmax-width: variables.$radio-input-size-sm;\n\tposition: relative;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: box-shadow 0.1s linear;\n\t}\n\n\t@include break-small() {\n\t\theight: variables.$radio-input-size;\n\t\twidth: variables.$radio-input-size;\n\t\tmin-width: variables.$radio-input-size;\n\t\tmax-width: variables.$radio-input-size;\n\t}\n\n\t&:checked::before {\n\t\tbox-sizing: inherit;\n\t\twidth: math.div(variables.$radio-input-size-sm, 2);\n\t\theight: math.div(variables.$radio-input-size-sm, 2);\n\t\tposition: absolute;\n\t\ttop: 50%;\n\t\tleft: 50%;\n\t\ttransform: translate(-50%, -50%);\n\t\tmargin: 0;\n\t\tbackground-color: colors.$white;\n\n\t\t// This border serves as a background color in Windows High Contrast mode.\n\t\tborder: 4px solid colors.$white;\n\n\t\t@include break-small() {\n\t\t\twidth: math.div(variables.$radio-input-size, 2);\n\t\t\theight: math.div(variables.$radio-input-size, 2);\n\t\t}\n\t}\n\n\t&:focus {\n\t\tbox-shadow: 0 0 0 (variables.$border-width * 2) colors.$white, 0 0 0 (variables.$border-width * 2 + variables.$border-width-focus-fallback) var(--wp-admin-theme-color);\n\n\t\t// Only visible in Windows High Contrast mode.\n\t\toutline: 2px solid transparent;\n\t}\n\n\t&:checked {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder: none;\n\t}\n}\n\n/**\n * Reset default styles for JavaScript UI based pages.\n * This is a WP-admin agnostic reset\n */\n\n@mixin reset {\n\tbox-sizing: border-box;\n\n\t*,\n\t*::before,\n\t*::after {\n\t\tbox-sizing: inherit;\n\t}\n}\n\n@mixin link-reset {\n\t&:focus {\n\t\tcolor: var(--wp-admin-theme-color--rgb);\n\t\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color, #007cba);\n\t\tborder-radius: variables.$radius-small;\n\t}\n}\n\n// The editor input reset with increased specificity to avoid theme styles bleeding in.\n@mixin editor-input-reset() {\n\tfont-family: variables.$editor-html-font !important;\n\tcolor: colors.$gray-900 !important;\n\tbackground: colors.$white !important;\n\tpadding: variables.$grid-unit-15 !important;\n\tborder: variables.$border-width solid colors.$gray-900 !important;\n\tbox-shadow: none !important;\n\tborder-radius: variables.$radius-small !important;\n\n\t// Fonts smaller than 16px causes mobile safari to zoom.\n\tfont-size: variables.$mobile-text-min-font-size !important;\n\t@include break-small {\n\t\tfont-size: variables.$default-font-size !important;\n\t}\n\n\t&:focus {\n\t\tborder-color: var(--wp-admin-theme-color) !important;\n\t\tbox-shadow: 0 0 0 (variables.$border-width-focus-fallback - variables.$border-width) var(--wp-admin-theme-color) !important;\n\n\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\toutline: 2px solid transparent !important;\n\t}\n}\n\n/**\n * Reset the WP Admin page styles for Gutenberg-like pages.\n */\n\n@mixin wp-admin-reset( $content-container ) {\n\tbackground: colors.$white;\n\n\t#wpcontent {\n\t\tpadding-left: 0;\n\t}\n\n\t#wpbody-content {\n\t\tpadding-bottom: 0;\n\t}\n\n\t/* We hide legacy notices in Gutenberg Based Pages, because they were not designed in a way that scaled well.\n\t   Plugins can use Gutenberg notices if they need to pass on information to the user when they are editing. */\n\t#wpbody-content > div:not(#{ $content-container }):not(#screen-meta) {\n\t\tdisplay: none;\n\t}\n\n\t#wpfooter {\n\t\tdisplay: none;\n\t}\n\n\t.a11y-speak-region {\n\t\tleft: -1px;\n\t\ttop: -1px;\n\t}\n\n\tul#adminmenu a.wp-has-current-submenu::after,\n\tul#adminmenu > li.current > a.current::after {\n\t\tborder-right-color: colors.$white;\n\t}\n\n\t.media-frame select.attachment-filters:last-of-type {\n\t\twidth: auto;\n\t\tmax-width: 100%;\n\t}\n}\n\n@mixin admin-scheme($color-primary) {\n\t// Define RGB equivalents for use in rgba function.\n\t// Hexadecimal css vars do not work in the rgba function.\n\t--wp-admin-theme-color: #{$color-primary};\n\t--wp-admin-theme-color--rgb: #{functions.hex-to-rgb($color-primary)};\n\t// Darker shades.\n\t--wp-admin-theme-color-darker-10: #{color.adjust($color-primary, $lightness: -5%)};\n\t--wp-admin-theme-color-darker-10--rgb: #{functions.hex-to-rgb(color.adjust($color-primary, $lightness: -5%))};\n\t--wp-admin-theme-color-darker-20: #{color.adjust($color-primary, $lightness: -10%)};\n\t--wp-admin-theme-color-darker-20--rgb: #{functions.hex-to-rgb(color.adjust($color-primary, $lightness: -10%))};\n\n\t// Focus style width.\n\t// Avoid rounding issues by showing a whole 2px for 1x screens, and 1.5px on high resolution screens.\n\t--wp-admin-border-width-focus: 2px;\n\t@media ( -webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {\n\t\t--wp-admin-border-width-focus: 1.5px;\n\t}\n}\n\n@mixin wordpress-admin-schemes() {\n\tbody.admin-color-light {\n\t\t@include admin-scheme(#0085ba);\n\t}\n\n\tbody.admin-color-modern {\n\t\t@include admin-scheme(#3858e9);\n\t}\n\n\tbody.admin-color-blue {\n\t\t@include admin-scheme(#096484);\n\t}\n\n\tbody.admin-color-coffee {\n\t\t@include admin-scheme(#46403c);\n\t}\n\n\tbody.admin-color-ectoplasm {\n\t\t@include admin-scheme(#523f6d);\n\t}\n\n\tbody.admin-color-midnight {\n\t\t@include admin-scheme(#e14d43);\n\t}\n\n\tbody.admin-color-ocean {\n\t\t@include admin-scheme(#627c83);\n\t}\n\n\tbody.admin-color-sunrise {\n\t\t@include admin-scheme(#dd823b);\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin background-colors-deprecated() {\n\t.has-very-light-gray-background-color {\n\t\tbackground-color: #eee;\n\t}\n\n\t.has-very-dark-gray-background-color {\n\t\tbackground-color: #313131;\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin foreground-colors-deprecated() {\n\t.has-very-light-gray-color {\n\t\tcolor: #eee;\n\t}\n\n\t.has-very-dark-gray-color {\n\t\tcolor: #313131;\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin gradient-colors-deprecated() {\n\t// Our classes uses the same values we set for gradient value attributes.\n\n\t/* stylelint-disable @stylistic/function-comma-space-after -- We can not use spacing because of WP multi site kses rule. */\n\t.has-vivid-green-cyan-to-vivid-cyan-blue-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgba(0,208,132,1) 0%,rgba(6,147,227,1) 100%);\n\t}\n\n\t.has-purple-crush-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(52,226,228) 0%,rgb(71,33,251) 50%,rgb(171,29,254) 100%);\n\t}\n\n\t.has-hazy-dawn-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(250,172,168) 0%,rgb(218,208,236) 100%);\n\t}\n\n\t.has-subdued-olive-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(250,250,225) 0%,rgb(103,166,113) 100%);\n\t}\n\n\t.has-atomic-cream-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(253,215,154) 0%,rgb(0,74,89) 100%);\n\t}\n\n\t.has-nightshade-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(51,9,104) 0%,rgb(49,205,207) 100%);\n\t}\n\n\t.has-midnight-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(2,3,129) 0%,rgb(40,116,252) 100%);\n\t}\n\t/* stylelint-enable @stylistic/function-comma-space-after */\n}\n\n@mixin custom-scrollbars-on-hover($handle-color, $handle-color-hover) {\n\n\t// WebKit\n\t&::-webkit-scrollbar {\n\t\twidth: 12px;\n\t\theight: 12px;\n\t}\n\t&::-webkit-scrollbar-track {\n\t\tbackground-color: transparent;\n\t}\n\t&::-webkit-scrollbar-thumb {\n\t\tbackground-color: $handle-color;\n\t\tborder-radius: 8px;\n\t\tborder: 3px solid transparent;\n\t\tbackground-clip: padding-box;\n\t}\n\t&:hover::-webkit-scrollbar-thumb, // This needs specificity.\n\t&:focus::-webkit-scrollbar-thumb,\n\t&:focus-within::-webkit-scrollbar-thumb {\n\t\tbackground-color: $handle-color-hover;\n\t}\n\n\t// Firefox 109+ and Chrome 111+\n\tscrollbar-width: thin;\n\tscrollbar-gutter: stable both-edges;\n\tscrollbar-color: $handle-color transparent; // Syntax, \"dark\", \"light\", or \"#handle-color #track-color\"\n\n\t&:hover,\n\t&:focus,\n\t&:focus-within {\n\t\tscrollbar-color: $handle-color-hover transparent;\n\t}\n\n\t// Needed to fix a Safari rendering issue.\n\twill-change: transform;\n\n\t// Always show scrollbar on Mobile devices.\n\t@media (hover: none) {\n\t\t& {\n\t\t\tscrollbar-color: $handle-color-hover transparent;\n\t\t}\n\t}\n}\n\n@mixin selected-block-outline($widthRatio: 1) {\n\toutline-color: var(--wp-admin-theme-color);\n\toutline-style: solid;\n\toutline-width: calc(#{$widthRatio} * (var(--wp-admin-border-width-focus) / var(--wp-block-editor-iframe-zoom-out-scale, 1)));\n\toutline-offset: calc(#{$widthRatio} * ((-1 * var(--wp-admin-border-width-focus) ) / var(--wp-block-editor-iframe-zoom-out-scale, 1)));\n}\n\n@mixin selected-block-focus($widthRatio: 1) {\n\tcontent: \"\";\n\tposition: absolute;\n\tpointer-events: none;\n\ttop: 0;\n\tright: 0;\n\tbottom: 0;\n\tleft: 0;\n\t@include selected-block-outline($widthRatio);\n}\n","/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","/**\n * Breakpoints & Media Queries\n */\n\n// Most used breakpoints\n$break-xhuge: 1920px;\n$break-huge: 1440px;\n$break-wide: 1280px;\n$break-xlarge: 1080px;\n$break-large: 960px;\t// admin sidebar auto folds\n$break-medium: 782px;\t// adminbar goes big\n$break-small: 600px;\n$break-mobile: 480px;\n$break-zoomed-in: 280px;\n\n// All media queries currently in WordPress:\n//\n// min-width: 2000px\n// min-width: 1680px\n// min-width: 1250px\n// max-width: 1120px *\n// max-width: 1000px\n// min-width: 769px and max-width: 1000px\n// max-width: 960px *\n// max-width: 900px\n// max-width: 850px\n// min-width: 800px and max-width: 1499px\n// max-width: 800px\n// max-width: 799px\n// max-width: 782px *\n// max-width: 768px\n// max-width: 640px *\n// max-width: 600px *\n// max-width: 520px\n// max-width: 500px\n// max-width: 480px *\n// max-width: 400px *\n// max-width: 380px\n// max-width: 320px *\n//\n// Those marked * seem to be more commonly used than the others.\n// Let's try and use as few of these as possible, and be mindful about adding new ones, so we don't make the situation worse\n","/**\n*  Converts a hex value into the rgb equivalent.\n*\n* @param {string} hex - the hexadecimal value to convert\n* @return {string} comma separated rgb values\n*/\n\n@use \"sass:color\";\n@use \"sass:meta\";\n\n@function hex-to-rgb($hex) {\n\t/*\n\t * TODO: `color.{red|green|blue}` will trigger a deprecation warning in Dart Sass,\n\t * but the Sass used by the Gutenberg project doesn't support `color.channel()` yet,\n\t * so we can't migrate to it at this time.\n\t * In the future, after the Gutenberg project has been fully migrated to Dart Sass,\n\t * Remove this conditional statement and use only `color.channel()`.\n\t */\n\t@if meta.function-exists(\"channel\", \"color\") {\n\t\t@return color.channel($hex, \"red\"), color.channel($hex, \"green\"), color.channel($hex, \"blue\");\n\t} @else {\n\t\t@return color.red($hex), color.green($hex), color.blue($hex);\n\t}\n}\n","/**\n * Long content fade mixin\n *\n * Creates a fading overlay to signify that the content is longer\n * than the space allows.\n */\n\n@mixin long-content-fade($direction: right, $size: 20%, $color: #fff, $edge: 0, $z-index: false) {\n\tcontent: \"\";\n\tdisplay: block;\n\tposition: absolute;\n\t-webkit-touch-callout: none;\n\t-webkit-user-select: none;\n\t-khtml-user-select: none;\n\t-moz-user-select: none;\n\t-ms-user-select: none;\n\tuser-select: none;\n\tpointer-events: none;\n\n\t@if $z-index {\n\t\tz-index: $z-index;\n\t}\n\n\t@if $direction == \"bottom\" {\n\t\tbackground: linear-gradient(to top, transparent, $color 90%);\n\t\tleft: $edge;\n\t\tright: $edge;\n\t\ttop: $edge;\n\t\tbottom: calc(100% - $size);\n\t\twidth: auto;\n\t}\n\n\t@if $direction == \"top\" {\n\t\tbackground: linear-gradient(to bottom, transparent, $color 90%);\n\t\ttop: calc(100% - $size);\n\t\tleft: $edge;\n\t\tright: $edge;\n\t\tbottom: $edge;\n\t\twidth: auto;\n\t}\n\n\t@if $direction == \"left\" {\n\t\tbackground: linear-gradient(to left, transparent, $color 90%);\n\t\ttop: $edge;\n\t\tleft: $edge;\n\t\tbottom: $edge;\n\t\tright: auto;\n\t\twidth: $size;\n\t\theight: auto;\n\t}\n\n\t@if $direction == \"right\" {\n\t\tbackground: linear-gradient(to right, transparent, $color 90%);\n\t\ttop: $edge;\n\t\tbottom: $edge;\n\t\tright: $edge;\n\t\tleft: auto;\n\t\twidth: $size;\n\t\theight: auto;\n\t}\n}\n","@use \"@wordpress/theme/src/prebuilt/css/design-tokens.css\" as *;\n@use \"@wordpress/admin-ui/build-style/style.css\" as *;\n@use \"@wordpress/base-styles/mixins\" as *;\n@use \"@wordpress/base-styles/variables\" as *;\n\n.boot-layout-container .boot-layout {\n\t// On mobile the main content area has to scroll, otherwise you can invoke\n\t// the overscroll bounce on the non-scrolling container, for a bad experience.\n\t@include break-small {\n\t\tposition: absolute;\n\t\ttop: 0;\n\t\tright: 0;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmin-height: calc(100vh - #{$admin-bar-height-big});\n\t}\n\n\t// The WP header height changes at this breakpoint.\n\t@include break-medium {\n\t\tmin-height: calc(100vh - #{$admin-bar-height});\n\n\t\tbody:has(.boot-layout.has-full-canvas) & {\n\t\t\tmin-height: 100vh;\n\t\t}\n\t}\n\n\timg {\n\t\tmax-width: 100%;\n\t\theight: auto;\n\t}\n}\n\n.boot-layout .components-editor-notices__snackbar {\n\tposition: fixed;\n\tright: 0;\n\tbottom: 16px;\n\tpadding-left: 16px;\n\tpadding-right: 16px;\n}\n"]} */`; 3596 document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css12)); 3597 var css22 = `/** 3598 * Colors 3599 */ 3600 @media (max-width: 782px) { 3601 * { 3602 view-transition-name: none !important; 3603 } 3604 } 3605 ::view-transition-old(root), 3606 ::view-transition-new(root) { 3607 animation-duration: 250ms; 3608 } 3609 3610 @media not (prefers-reduced-motion: reduce) { 3611 .boot-layout__canvas .interface-interface-skeleton__header { 3612 view-transition-name: boot--canvas-header; 3613 } 3614 .boot-layout__canvas .interface-interface-skeleton__sidebar { 3615 view-transition-name: boot--canvas-sidebar; 3616 } 3617 .boot-layout.has-full-canvas .boot-layout__canvas .boot-site-icon-link, 3618 .boot-layout:not(.has-full-canvas) .boot-site-hub .boot-site-icon-link { 3619 view-transition-name: boot--site-icon-link; 3620 } 3621 .boot-layout__stage { 3622 view-transition-name: boot--stage; 3623 } 3624 .boot-layout__inspector { 3625 view-transition-name: boot--inspector; 3626 } 3627 .boot-layout__canvas:not(.is-full-canvas), 3628 .boot-layout__canvas.is-full-canvas .interface-interface-skeleton__content { 3629 view-transition-name: boot--canvas; 3630 } 3631 @supports (-webkit-hyphens: none) and (not (-moz-appearance: none)) { 3632 .boot-layout__stage { 3633 view-transition-name: boot-safari--stage; 3634 } 3635 .boot-layout__inspector { 3636 view-transition-name: boot-safari--inspector; 3637 } 3638 .boot-layout__canvas:not(.is-full-canvas), 3639 .boot-layout__canvas.is-full-canvas .interface-interface-skeleton__content { 3640 view-transition-name: boot-safari--canvas; 3641 } 3642 } 3643 .components-popover:first-of-type { 3644 view-transition-name: boot--components-popover; 3645 } 3646 } 3647 ::view-transition-group(boot--canvas-header), 3648 ::view-transition-group(boot--canvas-sidebar), 3649 ::view-transition-group(boot-safari--canvas), 3650 ::view-transition-group(boot--canvas) { 3651 z-index: 1; 3652 } 3653 3654 ::view-transition-group(boot--site-icon-link) { 3655 z-index: 2; 3656 } 3657 3658 ::view-transition-new(boot--site-icon-link), 3659 ::view-transition-old(boot--site-icon-link) { 3660 animation: none; 3661 } 3662 3663 ::view-transition-new(boot-safari--canvas), 3664 ::view-transition-old(boot-safari--canvas), 3665 ::view-transition-new(boot-safari--stage), 3666 ::view-transition-old(boot-safari--stage), 3667 ::view-transition-old(boot-safari--inspector), 3668 ::view-transition-new(boot-safari--inspector) { 3669 width: auto; 3670 } 3671 3672 ::view-transition-new(boot--canvas), 3673 ::view-transition-old(boot--canvas), 3674 ::view-transition-new(boot--stage), 3675 ::view-transition-old(boot--stage), 3676 ::view-transition-new(boot--inspector), 3677 ::view-transition-old(boot--inspector) { 3678 background: #fff; 3679 border-radius: 8px; 3680 width: 100%; 3681 height: 100%; 3682 object-fit: none; 3683 object-position: left top; 3684 overflow: hidden; 3685 } 3686 3687 ::view-transition-new(boot--canvas), 3688 ::view-transition-old(boot--canvas) { 3689 object-position: center top; 3690 } 3691 3692 ::view-transition-old(boot-safari--inspector):only-child, 3693 ::view-transition-old(boot--inspector):only-child, 3694 ::view-transition-old(boot-safari--stage):only-child, 3695 ::view-transition-old(boot--stage):only-child { 3696 animation-name: zoomOut; 3697 will-change: transform, opacity; 3698 } 3699 3700 ::view-transition-new(boot-safari--inspector):only-child, 3701 ::view-transition-new(boot--inspector):only-child, 3702 ::view-transition-new(boot-safari--stage):only-child, 3703 ::view-transition-new(boot--stage):only-child { 3704 animation-name: zoomIn; 3705 will-change: transform, opacity; 3706 } 3707 3708 @keyframes zoomOut { 3709 from { 3710 transform: scale(1); 3711 opacity: 1; 3712 } 3713 to { 3714 transform: scale(0.9); 3715 opacity: 0; 3716 } 3717 } 3718 @keyframes zoomIn { 3719 from { 3720 transform: scale(0.95); 3721 opacity: 0; 3722 } 3723 to { 3724 transform: scale(1); 3725 opacity: 1; 3726 } 3727 } 3728 ::view-transition-new(boot-safari--canvas):only-child, 3729 ::view-transition-new(boot--canvas):only-child { 3730 animation-name: slideFromRight; 3731 will-change: transform; 3732 } 3733 3734 ::view-transition-old(boot-safari--canvas):only-child, 3735 ::view-transition-old(boot--canvas):only-child { 3736 animation-name: slideToRight; 3737 will-change: transform; 3738 } 3739 3740 @keyframes slideFromRight { 3741 from { 3742 transform: translateX(100vw); 3743 } 3744 to { 3745 transform: translateX(0); 3746 } 3747 } 3748 @keyframes slideToRight { 3749 from { 3750 transform: translateX(0); 3751 } 3752 to { 3753 transform: translateX(100vw); 3754 } 3755 } 3756 ::view-transition-new(boot--canvas-header):only-child { 3757 animation-name: slideHeaderFromTop; 3758 will-change: transform; 3759 } 3760 3761 ::view-transition-old(boot--canvas-header):only-child { 3762 animation-name: slideHeaderToTop; 3763 will-change: transform; 3764 } 3765 3766 @keyframes slideHeaderFromTop { 3767 from { 3768 transform: translateY(-100%); 3769 } 3770 } 3771 @keyframes slideHeaderToTop { 3772 to { 3773 transform: translateY(-100%); 3774 } 3775 } 3776 ::view-transition-new(boot--canvas-sidebar):only-child { 3777 animation-name: slideSidebarFromRight; 3778 will-change: transform; 3779 } 3780 3781 ::view-transition-old(boot--canvas-sidebar):only-child { 3782 animation-name: slideSidebarToRight; 3783 will-change: transform; 3784 } 3785 3786 @keyframes slideSidebarFromRight { 3787 from { 3788 transform: translateX(100%); 3789 } 3790 } 3791 @keyframes slideSidebarToRight { 3792 to { 3793 transform: translateX(100%); 3794 } 3795 } 3796 /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src","sources":["../../../node_modules/@wordpress/base-styles/_colors.scss","view-transitions.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;ACIA;EACC;IACC;;;AAIF;AAAA;EAEC;;;AAGD;EACC;IACC;;EAGD;IACC;;EAGD;AAAA;IAMC;;EAID;IACC;;EAGD;IACC;;EAGD;AAAA;IAGC;;EAKD;IACC;MACC;;IAGD;MACC;;IAGD;AAAA;MAGC;;;EAMF;IACC;;;AAIF;AAAA;AAAA;AAAA;EAIC;;;AAGD;EACC;;;AAGD;AAAA;EAEC;;;AAID;AAAA;AAAA;AAAA;AAAA;AAAA;EAMC;;;AAKD;AAAA;AAAA;AAAA;AAAA;AAAA;EAMC,YD7FO;EC8FP;EACA;EACA;EACA;EACA;EACA;;;AAGD;AAAA;EAEC;;;AAGD;AAAA;AAAA;AAAA;EAIC;EACA;;;AAGD;AAAA;AAAA;AAAA;EAIC;EACA;;;AAGD;EACC;IACC;IACA;;EAGD;IACC;IACA;;;AAIF;EACC;IACC;IACA;;EAGD;IACC;IACA;;;AAIF;AAAA;EAEC;EACA;;;AAGD;AAAA;EAEC;EACA;;;AAGD;EACC;IAIC;;EAGD;IACC;;;AAIF;EACC;IACC;;EAGD;IACC;;;AAIF;EACC;EACA;;;AAGD;EACC;EACA;;;AAGD;EACC;IACC;;;AAIF;EACC;IACC;;;AAIF;EACC;EACA;;;AAGD;EACC;EACA;;;AAGD;EACC;IACC;;;AAIF;EACC;IACC","sourcesContent":["/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","@use \"@wordpress/base-styles/colors\";\n\n// Disable view transitions on mobile devices\n// to avoid conflicts with sidebar navigation.\n@media (max-width: 782px) {\n\t* {\n\t\tview-transition-name: none !important;\n\t}\n}\n\n::view-transition-old(root),\n::view-transition-new(root) {\n\tanimation-duration: 250ms;\n}\n\n@media not (prefers-reduced-motion: reduce) {\n\t.boot-layout__canvas .interface-interface-skeleton__header {\n\t\tview-transition-name: boot--canvas-header;\n\t}\n\n\t.boot-layout__canvas .interface-interface-skeleton__sidebar {\n\t\tview-transition-name: boot--canvas-sidebar;\n\t}\n\n\t.boot-layout.has-full-canvas\n\t.boot-layout__canvas\n\t.boot-site-icon-link,\n\t.boot-layout:not(.has-full-canvas)\n\t.boot-site-hub\n\t.boot-site-icon-link {\n\t\tview-transition-name: boot--site-icon-link;\n\t}\n\n\t// Default (non-Safari) view transition names\n\t.boot-layout__stage {\n\t\tview-transition-name: boot--stage;\n\t}\n\n\t.boot-layout__inspector {\n\t\tview-transition-name: boot--inspector;\n\t}\n\n\t.boot-layout__canvas:not(.is-full-canvas),\n\t.boot-layout__canvas.is-full-canvas\n\t.interface-interface-skeleton__content {\n\t\tview-transition-name: boot--canvas;\n\t}\n\n\t// Safari-specific view transition names\n\t// Uses CSS feature detection instead of .is-safari class\n\t@supports (-webkit-hyphens:none) and (not (-moz-appearance:none)) {\n\t\t.boot-layout__stage {\n\t\t\tview-transition-name: boot-safari--stage;\n\t\t}\n\n\t\t.boot-layout__inspector {\n\t\t\tview-transition-name: boot-safari--inspector;\n\t\t}\n\n\t\t.boot-layout__canvas:not(.is-full-canvas),\n\t\t.boot-layout__canvas.is-full-canvas\n\t\t.interface-interface-skeleton__content {\n\t\t\tview-transition-name: boot-safari--canvas;\n\t\t}\n\t}\n\n\t// For any popover that stays open across a query change.\n\t// Naming it avoids the stage overlaying it.\n\t.components-popover:first-of-type {\n\t\tview-transition-name: boot--components-popover;\n\t}\n}\n\n::view-transition-group(boot--canvas-header),\n::view-transition-group(boot--canvas-sidebar),\n::view-transition-group(boot-safari--canvas),\n::view-transition-group(boot--canvas) {\n\tz-index: 1;\n}\n\n::view-transition-group(boot--site-icon-link) {\n\tz-index: 2;\n}\n\n::view-transition-new(boot--site-icon-link),\n::view-transition-old(boot--site-icon-link) {\n\tanimation: none;\n}\n\n// Safari-specific pseudo-element styles with width: auto fix\n::view-transition-new(boot-safari--canvas),\n::view-transition-old(boot-safari--canvas),\n::view-transition-new(boot-safari--stage),\n::view-transition-old(boot-safari--stage),\n::view-transition-old(boot-safari--inspector),\n::view-transition-new(boot-safari--inspector) {\n\twidth: auto;\n}\n\n// Safari trips up with using object fit on the pseudo images and filling out\n// background.\n::view-transition-new(boot--canvas),\n::view-transition-old(boot--canvas),\n::view-transition-new(boot--stage),\n::view-transition-old(boot--stage),\n::view-transition-new(boot--inspector),\n::view-transition-old(boot--inspector) {\n\tbackground: colors.$white;\n\tborder-radius: 8px;\n\twidth: 100%;\n\theight: 100%;\n\tobject-fit: none;\n\tobject-position: left top;\n\toverflow: hidden;\n}\n\n::view-transition-new(boot--canvas),\n::view-transition-old(boot--canvas) {\n\tobject-position: center top;\n}\n\n::view-transition-old(boot-safari--inspector):only-child,\n::view-transition-old(boot--inspector):only-child,\n::view-transition-old(boot-safari--stage):only-child,\n::view-transition-old(boot--stage):only-child {\n\tanimation-name: zoomOut;\n\twill-change: transform, opacity;\n}\n\n::view-transition-new(boot-safari--inspector):only-child,\n::view-transition-new(boot--inspector):only-child,\n::view-transition-new(boot-safari--stage):only-child,\n::view-transition-new(boot--stage):only-child {\n\tanimation-name: zoomIn;\n\twill-change: transform, opacity;\n}\n\n@keyframes zoomOut {\n\tfrom {\n\t\ttransform: scale(1);\n\t\topacity: 1;\n\t}\n\n\tto {\n\t\ttransform: scale(0.9);\n\t\topacity: 0;\n\t}\n}\n\n@keyframes zoomIn {\n\tfrom {\n\t\ttransform: scale(0.95);\n\t\topacity: 0;\n\t}\n\n\tto {\n\t\ttransform: scale(1);\n\t\topacity: 1;\n\t}\n}\n\n::view-transition-new(boot-safari--canvas):only-child,\n::view-transition-new(boot--canvas):only-child {\n\tanimation-name: slideFromRight;\n\twill-change: transform;\n}\n\n::view-transition-old(boot-safari--canvas):only-child,\n::view-transition-old(boot--canvas):only-child {\n\tanimation-name: slideToRight;\n\twill-change: transform;\n}\n\n@keyframes slideFromRight {\n\tfrom {\n\t\t// Should ideally be 100% + 16px, but we also need to take into account\n\t\t// that the canvas can be the editor-interface-skeleton__content, which\n\t\t// not placed on the right side.\n\t\ttransform: translateX(100vw);\n\t}\n\n\tto {\n\t\ttransform: translateX(0);\n\t}\n}\n\n@keyframes slideToRight {\n\tfrom {\n\t\ttransform: translateX(0);\n\t}\n\n\tto {\n\t\ttransform: translateX(100vw);\n\t}\n}\n\n::view-transition-new(boot--canvas-header):only-child {\n\tanimation-name: slideHeaderFromTop;\n\twill-change: transform;\n}\n\n::view-transition-old(boot--canvas-header):only-child {\n\tanimation-name: slideHeaderToTop;\n\twill-change: transform;\n}\n\n@keyframes slideHeaderFromTop {\n\tfrom {\n\t\ttransform: translateY(-100%);\n\t}\n}\n\n@keyframes slideHeaderToTop {\n\tto {\n\t\ttransform: translateY(-100%);\n\t}\n}\n\n::view-transition-new(boot--canvas-sidebar):only-child {\n\tanimation-name: slideSidebarFromRight;\n\twill-change: transform;\n}\n\n::view-transition-old(boot--canvas-sidebar):only-child {\n\tanimation-name: slideSidebarToRight;\n\twill-change: transform;\n}\n\n@keyframes slideSidebarFromRight {\n\tfrom {\n\t\ttransform: translateX(100%);\n\t}\n}\n\n@keyframes slideSidebarToRight {\n\tto {\n\t\ttransform: translateX(100%);\n\t}\n}\n"]} */`; 3797 document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css22)); 3798 export { 3799 init, 3800 initSinglePage, 3801 store 3802 };
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
| Generated : Wed Apr 15 08:20:10 2026 | Cross-referenced by PHPXref |