@secretstache/wordpress-gutenberg 0.3.17 → 0.4.1

Sign up to get free protection for your applications and to get access to all the features.
@@ -5,6 +5,7 @@
5
5
  }
6
6
 
7
7
  .bc-selected-media {
8
+ display: block;
8
9
  width: 100%;
9
10
 
10
11
  &--image {
@@ -1,10 +1,3 @@
1
- .editor-visual-editor.is-resizable {
2
- // Hide then editing a pattern/reusable block
3
- .root-block-appender {
4
- display: none;
5
- }
6
- }
7
-
8
1
  .root-block-appender {
9
2
  position: absolute;
10
3
  bottom: 30px;
@@ -1,12 +1,85 @@
1
1
  .block-editor__container {
2
- @import "editor-base";
3
- @import "animation-file-renderer";
4
- @import "icon-picker";
5
- @import "image-wrapper";
6
- @import "link-control";
7
- @import "media-picker";
8
- @import "sortable-select";
9
- @import "responsive-spacing";
10
- @import "new-child-btn";
11
- @import "root-block-appender";
2
+ .editor-visual-editor {
3
+ z-index: 1;
4
+
5
+ &:not(.is-resizable) {
6
+ .editor-styles-wrapper::after {
7
+ display: none;
8
+ }
9
+ }
10
+
11
+ &.is-resizable {
12
+ // Hide then editing a pattern/reusable block
13
+ .root-block-appender {
14
+ display: none;
15
+ }
16
+
17
+ & + .edit-post-layout__metaboxes {
18
+ display: none;
19
+ }
20
+ }
21
+
22
+ .editor-styles-wrapper {
23
+ .edit-post-visual-editor__post-title-wrapper {
24
+ margin-top: 10px;
25
+ margin-bottom: 10px;
26
+
27
+ h1.editor-post-title {
28
+ margin: 0;
29
+ border-bottom: 1px dashed #ddd;
30
+ padding-bottom: 10px;
31
+ font-weight: normal;
32
+ font-size: 30px;
33
+ font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
34
+ text-align: center;
35
+ }
36
+ }
37
+
38
+ .is-root-container {
39
+ @import "root-block-appender";
40
+ @import "empty-block-appender";
41
+
42
+ margin-bottom: 0;
43
+ padding-bottom: 0;
44
+
45
+ &:has(.root-block-appender) {
46
+ margin-bottom: 3rem;
47
+ padding-bottom: 200px;
48
+ }
49
+
50
+ &.has-background {
51
+ transition:
52
+ background 1s,
53
+ color 1s;
54
+ }
55
+
56
+ & > .block-list-appender.wp-block:only-child {
57
+ p {
58
+ margin-top: 0;
59
+ margin-bottom: 0;
60
+ }
61
+ }
62
+
63
+ & > .block-list-appender.wp-block:only-child,
64
+ & > p.wp-block:only-child {
65
+ margin: 2rem 0;
66
+ }
67
+ }
68
+ }
69
+ }
70
+
71
+ .editor-sidebar {
72
+ @import "link-control";
73
+ @import "animation-file-renderer";
74
+ @import "icon-picker";
75
+ @import "image-wrapper";
76
+ @import "media-picker";
77
+ @import "sortable-select";
78
+ @import "responsive-spacing";
79
+ @import "new-child-btn";
80
+ }
81
+ }
82
+
83
+ .block-editor-inserter__quick-inserter-results .block-editor-block-types-list > [role=presentation] {
84
+ justify-content: center;
12
85
  }
@@ -43,7 +43,6 @@ export const cleanSvgString = (svgString) => {
43
43
  return svgString;
44
44
  };
45
45
 
46
-
47
46
  const SVG_MIME_TYPE = 'image/svg+xml';
48
47
 
49
48
  export const getImage = async (mediaData) => {
@@ -0,0 +1,13 @@
1
+ const warnedMessages = new Set();
2
+
3
+ /**
4
+ * Logs a deprecation warning, ensuring each message is only logged once.
5
+ *
6
+ * @param {string} message - The deprecation warning message.
7
+ */
8
+ export const deprecationWarning = (message) => {
9
+ if (!warnedMessages.has(message)) {
10
+ console.warn(message);
11
+ warnedMessages.add(message);
12
+ }
13
+ }
@@ -1,71 +1,156 @@
1
1
  ## setRootBlock
2
2
 
3
- The `setRootBlock` function configures a root block in the Gutenberg editor and optionally customizes the tooltip text for the root appender.
4
- This function ensures that only the specified root block can be inserted at the root level.
5
- Additionally, it allows for optional initialization of the root appender with customizable tooltip text and makes the click on the appender insert the specified block.
3
+ The `setRootBlock` function configures a root block in the Gutenberg editor for specific post types. It ensures that only the specified root block can be inserted at the root level for those post types. The function dynamically applies or removes the root block restriction based on the current post type. Optionally, it initializes a custom root block appender with customizable tooltip text and allows specifying callbacks for when the post type matches or does not match.
6
4
 
7
5
  ### Function Signature
8
6
 
9
7
  ```javascript
10
8
  /**
11
- * Sets the root block in the Gutenberg editor and optionally customizes the tooltip text for the root appender.
9
+ * Sets the root block in the Gutenberg editor for specific post types and optionally customizes the tooltip text for the root appender.
10
+ * The function dynamically applies or removes the root block restriction based on the current post type.
12
11
  *
13
12
  * @param {string} rootBlockName - The name of the block to be set as the root block.
13
+ * @param {string[]} [postTypes=['page', 'ssm_design_system']] - An array of post types where the root block should be set.
14
14
  * @param {boolean} [initAppender=true] - Flag to indicate whether to initialize the root appender.
15
15
  * @param {string} [appenderTooltipText='Add Row'] - The tooltip text to be displayed on the root appender.
16
+ * @param {Function} [matchPostTypeCallback=null] - A callback function to execute when the current post type matches the specified post types.
17
+ * @param {Function} [notMatchPostTypeCallback=null] - A callback function to execute when the current post type does not match the specified post types.
16
18
  */
17
- export const setRootBlock = (rootBlockName, initAppender = true, appenderTooltipText = 'Add Row');
19
+ export const setRootBlock = (
20
+ rootBlockName,
21
+ postTypes = ['page', 'ssm_design_system'],
22
+ initAppender = true,
23
+ appenderTooltipText = 'Add Row',
24
+ matchPostTypeCallback = null,
25
+ notMatchPostTypeCallback = null,
26
+ );
18
27
  ```
19
28
 
20
29
  #### Parameters
21
30
 
22
31
  - **rootBlockName** (`string`): The name of the block to be set as the root block. This parameter is mandatory.
32
+ - **postTypes** (`string[]`, optional): An array of post types where the root block should be set. Default is `['page', 'ssm_design_system']`.
23
33
  - **initAppender** (`boolean`, optional): Flag to indicate whether to initialize the root appender. Default is `true`.
24
- - **appenderTooltipText** (`string`, optional): The tooltip text to be displayed on the appender. Default is 'Add Row'.
34
+ - **appenderTooltipText** (`string`, optional): The tooltip text to be displayed on the root appender. Default is `'Add Row'`.
35
+ - **matchPostTypeCallback** (`Function`, optional): A callback function to execute when the current post type matches the specified post types. Default is `null`.
36
+ - **notMatchPostTypeCallback** (`Function`, optional): A callback function to execute when the current post type does not match the specified post types. Default is `null`.
25
37
 
26
- ### Usage example
38
+ ### Usage Example
27
39
 
28
40
  To use the `setRootBlock` function, import it into your script and pass the necessary parameters:
29
41
 
30
42
  ```javascript
43
+ import domReady from '@wordpress/dom-ready';
31
44
  import { setRootBlock } from '@secretstache/wordpress-gutenberg';
32
45
 
33
- setRootBlock('ssm/section-wrapper', true, 'Custom Tooltip Text');
46
+ domReady(() => {
47
+ setRootBlock(
48
+ 'ssm/section-wrapper',
49
+ ['page', 'post'],
50
+ true,
51
+ 'Add Section',
52
+ () => {
53
+ console.log('Root block set for matching post type.');
54
+ },
55
+ () => {
56
+ console.log('Root block unset for non-matching post type.');
57
+ }
58
+ );
59
+ });
34
60
  ```
35
61
 
36
- In this example, the function will set `ssm/section-wrapper` as the root block, customize the tooltip text of the appender to 'Custom Tooltip Text', and initialize the root appender.
62
+ In this example, the function will:
63
+
64
+ - Set `'ssm/section-wrapper'` as the root block for 'page' and 'post' post types.
65
+ - Initialize the root appender with the tooltip text 'Add Section'.
66
+ - Execute the `matchPostTypeCallback` when the current post type matches 'page' or 'post'.
67
+ - Execute the `notMatchPostTypeCallback` when the current post type does not match.
68
+
69
+ The function monitors the current post type and dynamically applies or removes the root block restriction as needed.
37
70
 
38
71
  ---
39
72
 
40
- ## initRootBlockAppender
73
+ ## setRootBlockAppender
41
74
 
42
- The `initRootBlockAppender` function creates a new top-level block appender. It allows to specify the block name to be
43
- created when the appender is clicked and customize the tooltip text displayed on the appender.
75
+ The `setRootBlockAppender` function creates a new top-level block appender in the Gutenberg editor. It allows you to specify the block name to be created when the appender is clicked and customize the tooltip text displayed on the appender.
44
76
 
45
77
  ### Function Signature
46
78
 
47
79
  ```javascript
48
80
  /**
49
- * Creates a new top-level block appender. It allows to specify the block name to be
50
- * created when the appender is clicked and customize the tooltip text displayed on the appender.
81
+ * Creates a new top-level block appender. It allows specifying the block name to be
82
+ * created when the appender is clicked and customizing the tooltip text displayed on the appender.
51
83
  *
52
84
  * @param {string} blockName - The name of the block to be created when the appender is clicked.
53
85
  * @param {string} [tooltipText='Add Row'] - The tooltip text displayed on the appender.
54
86
  */
55
- export const initRootBlockAppender = (blockName, tooltipText = 'Add Row');
87
+ export const setRootBlockAppender = (blockName, tooltipText = 'Add Row');
56
88
  ```
57
89
 
58
90
  #### Parameters
59
91
 
60
92
  - **blockName** (`string`): The name of the block to be created when the appender is clicked. This parameter is mandatory.
61
- - **tooltipText** (`string`, optional): The tooltip text displayed on the appender. Default is 'Add Row'.
93
+ - **tooltipText** (`string`, optional): The tooltip text displayed on the appender. Default is `'Add Row'`.
94
+
95
+ ### Usage Example
96
+
97
+ In your custom theme or plugin, you can import and initialize the function with the desired block name and tooltip text:
98
+
99
+ ```javascript
100
+ import domReady from '@wordpress/dom-ready';
101
+ import { setRootBlockAppender } from '@secretstache/wordpress-gutenberg';
102
+
103
+ domReady(() => {
104
+ setRootBlockAppender('ssm/section-wrapper', 'Add Section');
105
+ });
106
+ ```
107
+
108
+ In this example, clicking the appender will insert the `'ssm/section-wrapper'` block, and the tooltip on the appender will display 'Add Section'.
109
+
110
+ ---
111
+
112
+ ## unsetRootBlockAppender
113
+
114
+ The `unsetRootBlockAppender` function removes the custom root block appender from the Gutenberg editor.
115
+
116
+ ### Function Signature
117
+
118
+ ```javascript
119
+ /**
120
+ * Removes the custom root block appender from the Gutenberg editor.
121
+ */
122
+ export const unsetRootBlockAppender = () => {};
123
+ ```
124
+
125
+ ### Usage Example
126
+
127
+ To remove the custom root block appender, simply call the function:
128
+
129
+ ```javascript
130
+ import { unsetRootBlockAppender } from '@secretstache/wordpress-gutenberg';
62
131
 
63
- ### Usage example
132
+ unsetRootBlockAppender();
133
+ ```
134
+
135
+ ---
136
+
137
+ ### Notes
64
138
 
65
- In your custom theme, you can import and initialize the function with the desired block name and tooltip text:
139
+ - The `setRootBlock` function internally manages the application and removal of the root block restrictions based on the current post type. It also handles the initialization and removal of the root block appender if `initAppender` is set to `true`.
140
+ - The `matchPostTypeCallback` and `notMatchPostTypeCallback` parameters allow you to execute custom logic when the post type matches or does not match the specified `postTypes` array. This can be useful for additional configurations or side effects needed in your application.
141
+ - The functions `setRootBlockAppender` and `unsetRootBlockAppender` can be used independently if you need to manually control the appender outside of the `setRootBlock` function.
142
+
143
+ ### Additional Example
144
+
145
+ If you want to set a root block without initializing the appender and without specifying callbacks:
66
146
 
67
147
  ```javascript
68
- import { initRootBlockAppender } from '@secretstache/wordpress-gutenberg';
148
+ import domReady from '@wordpress/dom-ready';
149
+ import { setRootBlock } from '@secretstache/wordpress-gutenberg';
69
150
 
70
- initRootBlockAppender('ssm/section-wrapper', 'Add Row');
151
+ domReady(() => {
152
+ setRootBlock('ssm/section-wrapper', ['page'], false);
153
+ });
71
154
  ```
155
+
156
+ In this case, the root block `'ssm/section-wrapper'` will be set for the 'page' post type, but the root appender will not be initialized.
@@ -1,9 +1,12 @@
1
+ const styleElementId = 'ssm-hide-root-block-for-inline-inserter';
2
+
1
3
  export const hideRootBlockForInlineInserter = (blockName) => {
2
4
  // Construct the CSS rule
3
5
  const cssRule = `[id*="-block-${blockName}"] { display: none !important; }`;
4
6
 
5
7
  // Create a style element
6
8
  const styleElement = document.createElement('style');
9
+ styleElement.id = styleElementId;
7
10
 
8
11
  // Set the CSS rule as the content of the style element
9
12
  styleElement.appendChild(document.createTextNode(cssRule));
@@ -11,3 +14,11 @@ export const hideRootBlockForInlineInserter = (blockName) => {
11
14
  // Append the style element to the document's head
12
15
  document.head.appendChild(styleElement);
13
16
  };
17
+
18
+ export const showRootBlockForInlineInserter = (blockName) => {
19
+ const styleElement = document.getElementById(styleElementId);
20
+
21
+ if (styleElement) {
22
+ document.head.removeChild(styleElement);
23
+ }
24
+ };
@@ -5,7 +5,7 @@ import { dispatch } from '@wordpress/data';
5
5
  export const hideRootBlockForOtherBlocks = (rootBlockName) => {
6
6
  addFilter(
7
7
  'blocks.registerBlockType',
8
- 'ssm/with-root-block',
8
+ 'ssm/hide-root-block-for-other-blocks',
9
9
  (blockSettings, blockName) => {
10
10
  const isRootBlock = blockName === rootBlockName;
11
11
  const hasOwnAllowedBlocks = !!blockSettings?.allowedBlocks;
@@ -1,4 +1,4 @@
1
1
  export * from './setRootBlock.js';
2
- export * from './initRootBlockAppender.js';
2
+ export * from './setRootBlockAppender.js';
3
3
  export * from './hideRootBlockForInlineInserter.js';
4
4
  export * from './hideRootBlockForOtherBlocks.js';
@@ -1,21 +1,18 @@
1
- import { addFilter } from '@wordpress/hooks';
2
- import { initRootBlockAppender } from './initRootBlockAppender.js';
1
+ import { addFilter, removeFilter } from '@wordpress/hooks';
2
+ import { setRootBlockAppender, unsetRootBlockAppender } from './setRootBlockAppender.js';
3
+ import { dispatch, select, subscribe } from '@wordpress/data';
3
4
 
4
5
  /**
5
- * Sets the root block in the Gutenberg editor and optionally adds the root appender.
6
- *
7
- * This function registers a filter to override the inserter support for blocks that are not the specified root block name.
8
- * It also optionally initializes the root appender with the provided block name and tooltip text, and makes the click
9
- * on the appender insert the specified block.
6
+ * Adds a filter to set the specified block as the root block by modifying block settings during registration.
7
+ * Blocks other than the root block will have their 'ancestor' property set to the root block name,
8
+ * making them only insertable within the root block.
10
9
  *
11
10
  * @param {string} rootBlockName - The name of the block to be set as the root block.
12
- * @param {boolean} [initAppender=true] - Flag to indicate whether to initialize the root appender.
13
- * @param {string} [appenderTooltipText='Add Row'] - The tooltip text to be displayed on the root appender.
14
11
  */
15
- export const setRootBlock = (rootBlockName, initAppender = true, appenderTooltipText = 'Add Row') => {
12
+ export const addSetRootBlockFilter = (rootBlockName) => {
16
13
  addFilter(
17
14
  'blocks.registerBlockType',
18
- 'ssm/with-root-block',
15
+ 'ssm/set-root-block',
19
16
  (settings, name) => {
20
17
  const isRootBlock = name === rootBlockName;
21
18
  const isBaseBlock = name === 'core/block';
@@ -28,8 +25,91 @@ export const setRootBlock = (rootBlockName, initAppender = true, appenderTooltip
28
25
  return settings;
29
26
  },
30
27
  );
28
+ };
29
+
30
+ /**
31
+ * Adds a filter to unset the root block restrictions by removing the 'ancestor' property from block settings
32
+ * if it includes the specified root block name.
33
+ *
34
+ * @param {string} rootBlockName - The name of the block previously set as the root block.
35
+ */
36
+ export const addUnsetRootBlockFilter = (rootBlockName) => {
37
+ addFilter(
38
+ 'blocks.registerBlockType',
39
+ 'ssm/unset-root-block',
40
+ (settings) => {
41
+ const hasRootAncestor = settings.ancestor && settings.ancestor.includes(rootBlockName);
42
+
43
+ if (hasRootAncestor) {
44
+ settings.ancestor = null;
45
+ }
46
+
47
+ return settings;
48
+ },
49
+ );
50
+ };
31
51
 
32
- if (initAppender) {
33
- initRootBlockAppender(rootBlockName, appenderTooltipText);
34
- }
52
+ /**
53
+ * Configures the Gutenberg editor to use a specified block as the root block for certain post types.
54
+ * It dynamically applies or removes the root block restriction based on the current post type.
55
+ * Optionally initializes a custom root block appender and provides callbacks for post type matching.
56
+ *
57
+ * @param {string} rootBlockName - The name of the block to set as the root block.
58
+ * @param {string[]} [postTypes=['page', 'ssm_design_system']] - Array of post types where the root block should be set.
59
+ * @param {boolean} [initAppender=true] - Whether to initialize the root block appender.
60
+ * @param {string} [appenderTooltipText='Add Row'] - Tooltip text for the root block appender.
61
+ * @param {Function} [matchPostTypeCallback=null] - Callback function when the post type matches.
62
+ * @param {Function} [notMatchPostTypeCallback=null] - Callback function when the post type does not match.
63
+ */
64
+ export const setRootBlock = (
65
+ rootBlockName,
66
+ postTypes = ['page', 'ssm_design_system'],
67
+ initAppender = true,
68
+ appenderTooltipText = 'Add Row',
69
+ matchPostTypeCallback = null,
70
+ notMatchPostTypeCallback = null,
71
+ ) => {
72
+ let isRootBlockEnabled = false;
73
+
74
+ subscribe(() => {
75
+ const currentPostType = select('core/editor').getCurrentPostType();
76
+
77
+ if (!currentPostType) return;
78
+
79
+ const isMatchPostType = postTypes.includes(currentPostType);
80
+
81
+ if (isMatchPostType) {
82
+ if (!isRootBlockEnabled) {
83
+ removeFilter('blocks.registerBlockType', 'ssm/unset-root-block');
84
+ addSetRootBlockFilter(rootBlockName);
85
+ dispatch('core/blocks').reapplyBlockTypeFilters();
86
+
87
+ if (initAppender) {
88
+ setRootBlockAppender(rootBlockName, appenderTooltipText);
89
+ }
90
+
91
+ if (matchPostTypeCallback) {
92
+ matchPostTypeCallback();
93
+ }
94
+
95
+ isRootBlockEnabled = true;
96
+ }
97
+ } else {
98
+ if (isRootBlockEnabled) {
99
+ removeFilter('blocks.registerBlockType', 'ssm/set-root-block');
100
+ addUnsetRootBlockFilter(rootBlockName);
101
+ dispatch('core/blocks').reapplyBlockTypeFilters();
102
+
103
+ if (initAppender) {
104
+ unsetRootBlockAppender(rootBlockName);
105
+ }
106
+
107
+ if (notMatchPostTypeCallback) {
108
+ notMatchPostTypeCallback();
109
+ }
110
+
111
+ isRootBlockEnabled = false;
112
+ }
113
+ }
114
+ }, 'core/editor');
35
115
  };
@@ -1,10 +1,10 @@
1
1
  import { createBlock } from '@wordpress/blocks';
2
2
  import { dispatch } from '@wordpress/data';
3
- import domReady from '@wordpress/dom-ready';
4
3
 
5
4
  import { waitForContainer } from '../waitForContainer/index.js';
6
5
 
7
6
  const ROOT_CONTAINER_SELECTOR = '.is-root-container';
7
+ const ROOT_BLOCK_APPENDER_SELECTOR = '.is-root-container .root-block-appender';
8
8
 
9
9
  /**
10
10
  * Initializes the custom button for the root appender.
@@ -13,6 +13,7 @@ const ROOT_CONTAINER_SELECTOR = '.is-root-container';
13
13
  */
14
14
  const initialize = (blockName, tooltipText) => {
15
15
  const rootContainer = document.querySelector(ROOT_CONTAINER_SELECTOR);
16
+
16
17
  if (!rootContainer) {
17
18
  console.error('Root container not found');
18
19
 
@@ -40,6 +41,14 @@ const initialize = (blockName, tooltipText) => {
40
41
  * @param {string} blockName - The name of the block to be created when the appender is clicked.
41
42
  * @param {string} [tooltipText='Add Row'] - The tooltip text displayed on the appender.
42
43
  */
43
- export const initRootBlockAppender = (blockName, tooltipText = 'Add Row') => {
44
- domReady(() => waitForContainer(() => initialize(blockName, tooltipText), ROOT_CONTAINER_SELECTOR));
44
+ export const setRootBlockAppender = (blockName, tooltipText = 'Add Row') => {
45
+ waitForContainer(() => initialize(blockName, tooltipText), ROOT_CONTAINER_SELECTOR);
45
46
  };
47
+
48
+ export const unsetRootBlockAppender = () => {
49
+ const appender = document.querySelector(ROOT_BLOCK_APPENDER_SELECTOR);
50
+
51
+ if (appender) {
52
+ appender.remove();
53
+ }
54
+ }
@@ -11,6 +11,7 @@ export const waitForContainer = (initializeFn, containerClass = '.is-root-contai
11
11
  let attempts = 0;
12
12
  const checkInterval = setInterval(() => {
13
13
  const rootContainer = document.querySelector(containerClass);
14
+
14
15
  if (rootContainer) {
15
16
  clearInterval(checkInterval);
16
17
  initializeFn(rootContainer);
@@ -1,4 +0,0 @@
1
- export const useUpdateAttribute = (setAttributes) => (attributeName, value) => {
2
- setAttributes({ [attributeName]: value });
3
- };
4
-
@@ -1,56 +0,0 @@
1
- .editor-styles-wrapper {
2
- .edit-post-visual-editor__post-title-wrapper {
3
- margin-top: 10px !important;
4
- margin-bottom: 10px !important;
5
-
6
- h1.editor-post-title {
7
- margin: 0;
8
- border-bottom: 1px dashed #ddd;
9
- padding-bottom: 10px;
10
- font-weight: normal;
11
- font-size: 30px !important;
12
- font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
13
- text-align: center;
14
- }
15
- }
16
-
17
- .block-editor-block-list__layout.is-root-container {
18
- margin-bottom: 3rem;
19
- padding-bottom: 100px;
20
-
21
- &.has-background {
22
- transition:
23
- background 1s,
24
- color 1s;
25
- }
26
-
27
- & > .block-list-appender.wp-block:only-child {
28
- p {
29
- margin-top: 0;
30
- margin-bottom: 0;
31
- }
32
- }
33
-
34
- & > .block-list-appender.wp-block:only-child,
35
- & > p.wp-block:only-child {
36
- margin: 2rem 0;
37
- }
38
-
39
- }
40
- }
41
-
42
- .block-editor-block-types-list>[role=presentation] {
43
- justify-content: center;
44
- }
45
-
46
- .components-base-control {
47
- .block-editor-url-input {
48
- input.block-editor-url-input__input {
49
- width: 100%;
50
- }
51
- }
52
- }
53
-
54
- .components-range-control__mark-label {
55
- margin-top: 7px !important;
56
- }