@wordpress/components 29.12.0 → 29.13.1-next.719a03cbe.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +12 -0
- package/build/box-control/input-control.js +2 -2
- package/build/box-control/input-control.js.map +1 -1
- package/build/calendar/date-calendar/index.js +60 -0
- package/build/calendar/date-calendar/index.js.map +1 -0
- package/build/calendar/date-range-calendar/index.js +168 -0
- package/build/calendar/date-range-calendar/index.js.map +1 -0
- package/build/calendar/index.js +27 -0
- package/build/calendar/index.js.map +1 -0
- package/build/calendar/types.js +6 -0
- package/build/calendar/types.js.map +1 -0
- package/build/calendar/utils/constants.js +68 -0
- package/build/calendar/utils/constants.js.map +1 -0
- package/build/calendar/utils/day-cell.js +137 -0
- package/build/calendar/utils/day-cell.js.map +1 -0
- package/build/calendar/utils/misc.js +10 -0
- package/build/calendar/utils/misc.js.map +1 -0
- package/build/calendar/utils/use-controlled-value.js +58 -0
- package/build/calendar/utils/use-controlled-value.js.map +1 -0
- package/build/calendar/utils/use-localization-props.js +162 -0
- package/build/calendar/utils/use-localization-props.js.map +1 -0
- package/build/custom-gradient-picker/gradient-bar/control-points.js +1 -1
- package/build/custom-gradient-picker/gradient-bar/control-points.js.map +1 -1
- package/build/custom-select-control-v2/custom-select.js +3 -3
- package/build/custom-select-control-v2/custom-select.js.map +1 -1
- package/build/date-time/date/index.js +1 -1
- package/build/date-time/date/index.js.map +1 -1
- package/build/form-token-field/index.js +11 -1
- package/build/form-token-field/index.js.map +1 -1
- package/build/form-token-field/token.js +1 -1
- package/build/form-token-field/token.js.map +1 -1
- package/build/index.js +19 -0
- package/build/index.js.map +1 -1
- package/build/mobile/bottom-sheet/cell.native.js +2 -2
- package/build/mobile/bottom-sheet/cell.native.js.map +1 -1
- package/build/mobile/link-picker/index.native.js +1 -1
- package/build/mobile/link-picker/index.native.js.map +1 -1
- package/build/navigation/menu/menu-title-search.js +1 -1
- package/build/navigation/menu/menu-title-search.js.map +1 -1
- package/build/palette-edit/index.js +4 -4
- package/build/palette-edit/index.js.map +1 -1
- package/build-module/box-control/input-control.js +2 -2
- package/build-module/box-control/input-control.js.map +1 -1
- package/build-module/calendar/date-calendar/index.js +51 -0
- package/build-module/calendar/date-calendar/index.js.map +1 -0
- package/build-module/calendar/date-range-calendar/index.js +157 -0
- package/build-module/calendar/date-range-calendar/index.js.map +1 -0
- package/build-module/calendar/index.js +4 -0
- package/build-module/calendar/index.js.map +1 -0
- package/build-module/calendar/types.js +2 -0
- package/build-module/calendar/types.js.map +1 -0
- package/build-module/calendar/utils/constants.js +61 -0
- package/build-module/calendar/utils/constants.js.map +1 -0
- package/build-module/calendar/utils/day-cell.js +131 -0
- package/build-module/calendar/utils/day-cell.js.map +1 -0
- package/build-module/calendar/utils/misc.js +4 -0
- package/build-module/calendar/utils/misc.js.map +1 -0
- package/build-module/calendar/utils/use-controlled-value.js +51 -0
- package/build-module/calendar/utils/use-controlled-value.js.map +1 -0
- package/build-module/calendar/utils/use-localization-props.js +154 -0
- package/build-module/calendar/utils/use-localization-props.js.map +1 -0
- package/build-module/custom-gradient-picker/gradient-bar/control-points.js +1 -1
- package/build-module/custom-gradient-picker/gradient-bar/control-points.js.map +1 -1
- package/build-module/custom-select-control-v2/custom-select.js +4 -4
- package/build-module/custom-select-control-v2/custom-select.js.map +1 -1
- package/build-module/date-time/date/index.js +1 -1
- package/build-module/date-time/date/index.js.map +1 -1
- package/build-module/form-token-field/index.js +11 -1
- package/build-module/form-token-field/index.js.map +1 -1
- package/build-module/form-token-field/token.js +1 -1
- package/build-module/form-token-field/token.js.map +1 -1
- package/build-module/index.js +1 -0
- package/build-module/index.js.map +1 -1
- package/build-module/mobile/bottom-sheet/cell.native.js +2 -2
- package/build-module/mobile/bottom-sheet/cell.native.js.map +1 -1
- package/build-module/mobile/link-picker/index.native.js +1 -1
- package/build-module/mobile/link-picker/index.native.js.map +1 -1
- package/build-module/navigation/menu/menu-title-search.js +1 -1
- package/build-module/navigation/menu/menu-title-search.js.map +1 -1
- package/build-module/palette-edit/index.js +4 -4
- package/build-module/palette-edit/index.js.map +1 -1
- package/build-style/style-rtl.css +358 -5
- package/build-style/style.css +358 -5
- package/build-types/box-control/input-control.d.ts.map +1 -1
- package/build-types/box-control/utils.d.ts +7 -7
- package/build-types/calendar/date-calendar/index.d.ts +11 -0
- package/build-types/calendar/date-calendar/index.d.ts.map +1 -0
- package/build-types/calendar/date-range-calendar/index.d.ts +14 -0
- package/build-types/calendar/date-range-calendar/index.d.ts.map +1 -0
- package/build-types/calendar/index.d.ts +4 -0
- package/build-types/calendar/index.d.ts.map +1 -0
- package/build-types/calendar/stories/date-calendar.story.d.ts +16 -0
- package/build-types/calendar/stories/date-calendar.story.d.ts.map +1 -0
- package/build-types/calendar/stories/date-range-calendar.story.d.ts +16 -0
- package/build-types/calendar/stories/date-range-calendar.story.d.ts.map +1 -0
- package/build-types/calendar/test/__utils__/index.d.ts +10 -0
- package/build-types/calendar/test/__utils__/index.d.ts.map +1 -0
- package/build-types/calendar/test/date-calendar.d.ts +2 -0
- package/build-types/calendar/test/date-calendar.d.ts.map +1 -0
- package/build-types/calendar/test/date-range-calendar.d.ts +2 -0
- package/build-types/calendar/test/date-range-calendar.d.ts.map +1 -0
- package/build-types/calendar/types.d.ts +317 -0
- package/build-types/calendar/types.d.ts.map +1 -0
- package/build-types/calendar/utils/constants.d.ts +52 -0
- package/build-types/calendar/utils/constants.d.ts.map +1 -0
- package/build-types/calendar/utils/day-cell.d.ts +21 -0
- package/build-types/calendar/utils/day-cell.d.ts.map +1 -0
- package/build-types/calendar/utils/misc.d.ts +2 -0
- package/build-types/calendar/utils/misc.d.ts.map +1 -0
- package/build-types/calendar/utils/use-controlled-value.d.ts +27 -0
- package/build-types/calendar/utils/use-controlled-value.d.ts.map +1 -0
- package/build-types/calendar/utils/use-localization-props.d.ts +64 -0
- package/build-types/calendar/utils/use-localization-props.d.ts.map +1 -0
- package/build-types/custom-gradient-picker/constants.d.ts +6 -3
- package/build-types/custom-gradient-picker/constants.d.ts.map +1 -1
- package/build-types/custom-select-control-v2/custom-select.d.ts.map +1 -1
- package/build-types/dimension-control/sizes.d.ts +15 -3
- package/build-types/dimension-control/sizes.d.ts.map +1 -1
- package/build-types/font-size-picker/constants.d.ts +2 -2
- package/build-types/font-size-picker/constants.d.ts.map +1 -1
- package/build-types/form-token-field/index.d.ts.map +1 -1
- package/build-types/index.d.ts +1 -0
- package/build-types/index.d.ts.map +1 -1
- package/build-types/popover/overlay-middlewares.d.ts +6 -1
- package/build-types/popover/overlay-middlewares.d.ts.map +1 -1
- package/package.json +21 -20
- package/src/box-control/input-control.tsx +14 -5
- package/src/calendar/date-calendar/README.md +250 -0
- package/src/calendar/date-calendar/index.tsx +55 -0
- package/src/calendar/date-range-calendar/README.md +287 -0
- package/src/calendar/date-range-calendar/index.tsx +203 -0
- package/src/calendar/index.tsx +3 -0
- package/src/calendar/stories/date-calendar.story.tsx +221 -0
- package/src/calendar/stories/date-range-calendar.story.tsx +230 -0
- package/src/calendar/style.scss +431 -0
- package/src/calendar/test/__utils__/index.ts +56 -0
- package/src/calendar/test/date-calendar.tsx +975 -0
- package/src/calendar/test/date-range-calendar.tsx +1701 -0
- package/src/calendar/types.ts +342 -0
- package/src/calendar/utils/constants.ts +62 -0
- package/src/calendar/utils/day-cell.tsx +133 -0
- package/src/calendar/utils/misc.ts +3 -0
- package/src/calendar/utils/use-controlled-value.ts +61 -0
- package/src/calendar/utils/use-localization-props.ts +169 -0
- package/src/custom-gradient-picker/gradient-bar/control-points.tsx +1 -1
- package/src/custom-select-control-v2/custom-select.tsx +6 -3
- package/src/date-time/date/index.tsx +1 -1
- package/src/form-token-field/index.tsx +12 -1
- package/src/form-token-field/token.tsx +1 -1
- package/src/index.ts +1 -0
- package/src/mobile/bottom-sheet/cell.native.js +2 -2
- package/src/mobile/link-picker/index.native.js +1 -1
- package/src/navigation/menu/menu-title-search.tsx +1 -1
- package/src/palette-edit/index.tsx +4 -4
- package/src/select-control/style.scss +0 -6
- package/src/style.scss +1 -0
- package/tsconfig.tsbuildinfo +1 -1
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WordPress dependencies
|
|
3
|
+
*/
|
|
4
|
+
import { __, sprintf } from '@wordpress/i18n';
|
|
5
|
+
import { useMemo } from '@wordpress/element';
|
|
6
|
+
/**
|
|
7
|
+
* Internal dependencies
|
|
8
|
+
*/
|
|
9
|
+
import type { Modifiers, BaseProps } from '../types';
|
|
10
|
+
|
|
11
|
+
function isLocaleRTL( localeCode: string ) {
|
|
12
|
+
const localeObj = new Intl.Locale( localeCode );
|
|
13
|
+
if ( 'getTextInfo' in localeObj ) {
|
|
14
|
+
// @ts-expect-error - getTextInfo is not typed yet
|
|
15
|
+
// see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/Locale/getTextInfo
|
|
16
|
+
return localeObj.getTextInfo().direction === 'rtl';
|
|
17
|
+
}
|
|
18
|
+
return [
|
|
19
|
+
'ar', // Arabic
|
|
20
|
+
'he', // Hebrew
|
|
21
|
+
'fa', // Persian (Farsi)
|
|
22
|
+
'ur', // Urdu
|
|
23
|
+
'ps', // Pashto
|
|
24
|
+
'syr', // Syriac
|
|
25
|
+
'dv', // Divehi
|
|
26
|
+
'ku', // Kurdish (Sorani)
|
|
27
|
+
'yi', // Yiddish
|
|
28
|
+
].includes( localeObj.language );
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* Returns localization props for the calendar components.
|
|
33
|
+
*
|
|
34
|
+
* Notes:
|
|
35
|
+
* - the following props should be intended as defaults, and should
|
|
36
|
+
* be overridden by consumer props if listed as public props.
|
|
37
|
+
* - It is possible for the translated strings to use a different locale
|
|
38
|
+
* than the formatted dates and the computed `dir`. This is because the
|
|
39
|
+
* translation function doesn't expose the locale used for the translated
|
|
40
|
+
* strings, meaning that the dates are formatted using the `locale` prop.
|
|
41
|
+
* For a correct localized experience, consumers should make sure that
|
|
42
|
+
* translation context and `locale` prop are consistent.
|
|
43
|
+
* @param props
|
|
44
|
+
* @param props.locale
|
|
45
|
+
* @param props.timeZone
|
|
46
|
+
* @param props.mode
|
|
47
|
+
*/
|
|
48
|
+
export const useLocalizationProps = ( {
|
|
49
|
+
locale,
|
|
50
|
+
timeZone,
|
|
51
|
+
mode,
|
|
52
|
+
}: {
|
|
53
|
+
locale: NonNullable< BaseProps[ 'locale' ] >;
|
|
54
|
+
timeZone: BaseProps[ 'timeZone' ];
|
|
55
|
+
mode: 'single' | 'range';
|
|
56
|
+
} ) => {
|
|
57
|
+
return useMemo( () => {
|
|
58
|
+
// ie. April 2025
|
|
59
|
+
const monthNameFormatter = new Intl.DateTimeFormat( locale.code, {
|
|
60
|
+
year: 'numeric',
|
|
61
|
+
month: 'long',
|
|
62
|
+
timeZone,
|
|
63
|
+
} );
|
|
64
|
+
// ie. M, T, W, T, F, S, S
|
|
65
|
+
const weekdayNarrowFormatter = new Intl.DateTimeFormat( locale.code, {
|
|
66
|
+
weekday: 'narrow',
|
|
67
|
+
timeZone,
|
|
68
|
+
} );
|
|
69
|
+
// ie. Monday, Tuesday, Wednesday, Thursday, Friday, Saturday, Sunday
|
|
70
|
+
const weekdayLongFormatter = new Intl.DateTimeFormat( locale.code, {
|
|
71
|
+
weekday: 'long',
|
|
72
|
+
timeZone,
|
|
73
|
+
} );
|
|
74
|
+
// ie. Monday, April 29, 2025
|
|
75
|
+
const fullDateFormatter = new Intl.DateTimeFormat( locale.code, {
|
|
76
|
+
weekday: 'long',
|
|
77
|
+
year: 'numeric',
|
|
78
|
+
month: 'long',
|
|
79
|
+
day: 'numeric',
|
|
80
|
+
timeZone,
|
|
81
|
+
} );
|
|
82
|
+
|
|
83
|
+
// Note: the following props should be intended as defaults, and should
|
|
84
|
+
// be overridden by consumer props if listed as public props.
|
|
85
|
+
return {
|
|
86
|
+
'aria-label':
|
|
87
|
+
mode === 'single'
|
|
88
|
+
? __( 'Date calendar' )
|
|
89
|
+
: __( 'Date range calendar' ),
|
|
90
|
+
labels: {
|
|
91
|
+
/**
|
|
92
|
+
* The label for the month grid.
|
|
93
|
+
* @param date
|
|
94
|
+
*/
|
|
95
|
+
labelGrid: ( date: Date ) => monthNameFormatter.format( date ),
|
|
96
|
+
/**
|
|
97
|
+
* The label for the gridcell, when the calendar is not interactive.
|
|
98
|
+
* @param date
|
|
99
|
+
* @param modifiers
|
|
100
|
+
*/
|
|
101
|
+
labelGridcell: (
|
|
102
|
+
date: Date,
|
|
103
|
+
/** The modifiers for the day. */
|
|
104
|
+
modifiers?: Modifiers
|
|
105
|
+
) => {
|
|
106
|
+
const formattedDate = fullDateFormatter.format( date );
|
|
107
|
+
let label = formattedDate;
|
|
108
|
+
if ( modifiers?.today ) {
|
|
109
|
+
label = sprintf(
|
|
110
|
+
// translators: %s is the full date (e.g. "Monday, April 29, 2025")
|
|
111
|
+
__( 'Today, %s' ),
|
|
112
|
+
formattedDate
|
|
113
|
+
);
|
|
114
|
+
}
|
|
115
|
+
return label;
|
|
116
|
+
},
|
|
117
|
+
/** The label for the "next month" button. */
|
|
118
|
+
labelNext: () => __( 'Go to the Next Month' ),
|
|
119
|
+
/** The label for the "previous month" button. */
|
|
120
|
+
labelPrevious: () => __( 'Go to the Previous Month' ),
|
|
121
|
+
/**
|
|
122
|
+
* The label for the day button.
|
|
123
|
+
* @param date
|
|
124
|
+
* @param modifiers
|
|
125
|
+
*/
|
|
126
|
+
labelDayButton: (
|
|
127
|
+
date: Date,
|
|
128
|
+
/** The modifiers for the day. */
|
|
129
|
+
modifiers?: Modifiers
|
|
130
|
+
) => {
|
|
131
|
+
const formattedDate = fullDateFormatter.format( date );
|
|
132
|
+
let label = formattedDate;
|
|
133
|
+
if ( modifiers?.today ) {
|
|
134
|
+
label = sprintf(
|
|
135
|
+
// translators: %s is the full date (e.g. "Monday, April 29, 2025")
|
|
136
|
+
__( 'Today, %s' ),
|
|
137
|
+
formattedDate
|
|
138
|
+
);
|
|
139
|
+
}
|
|
140
|
+
if ( modifiers?.selected ) {
|
|
141
|
+
label = sprintf(
|
|
142
|
+
// translators: %s is the full date (e.g. "Monday, April 29, 2025")
|
|
143
|
+
__( '%s, selected' ),
|
|
144
|
+
formattedDate
|
|
145
|
+
);
|
|
146
|
+
}
|
|
147
|
+
return label;
|
|
148
|
+
},
|
|
149
|
+
/**
|
|
150
|
+
* The label for the weekday.
|
|
151
|
+
* @param date
|
|
152
|
+
*/
|
|
153
|
+
labelWeekday: ( date: Date ) =>
|
|
154
|
+
weekdayLongFormatter.format( date ),
|
|
155
|
+
},
|
|
156
|
+
locale,
|
|
157
|
+
dir: isLocaleRTL( locale.code ) ? 'rtl' : 'ltr',
|
|
158
|
+
formatters: {
|
|
159
|
+
formatWeekdayName: ( date: Date ) => {
|
|
160
|
+
return weekdayNarrowFormatter.format( date );
|
|
161
|
+
},
|
|
162
|
+
formatCaption: ( date: Date ) => {
|
|
163
|
+
return monthNameFormatter.format( date );
|
|
164
|
+
},
|
|
165
|
+
},
|
|
166
|
+
timeZone,
|
|
167
|
+
} as const;
|
|
168
|
+
}, [ locale, timeZone, mode ] );
|
|
169
|
+
};
|
|
@@ -58,7 +58,7 @@ function ControlPointButton( {
|
|
|
58
58
|
aria-label={ sprintf(
|
|
59
59
|
// translators: 1: gradient position e.g: 70. 2: gradient color code e.g: rgb(52,121,151).
|
|
60
60
|
__(
|
|
61
|
-
'Gradient control point at position %1$
|
|
61
|
+
'Gradient control point at position %1$d%% with color code %2$s.'
|
|
62
62
|
),
|
|
63
63
|
position,
|
|
64
64
|
color
|
|
@@ -7,7 +7,7 @@ import * as Ariakit from '@ariakit/react';
|
|
|
7
7
|
* WordPress dependencies
|
|
8
8
|
*/
|
|
9
9
|
import { createContext, useCallback, useMemo } from '@wordpress/element';
|
|
10
|
-
import { __, sprintf } from '@wordpress/i18n';
|
|
10
|
+
import { __, _n, sprintf } from '@wordpress/i18n';
|
|
11
11
|
|
|
12
12
|
/**
|
|
13
13
|
* Internal dependencies
|
|
@@ -43,8 +43,11 @@ function defaultRenderSelectedValue(
|
|
|
43
43
|
if ( Array.isArray( value ) ) {
|
|
44
44
|
return value.length === 1
|
|
45
45
|
? value[ 0 ]
|
|
46
|
-
:
|
|
47
|
-
|
|
46
|
+
: sprintf(
|
|
47
|
+
// translators: %d: number of items selected (it will always be 2 or more items)
|
|
48
|
+
_n( '%d item selected', '%d items selected', value.length ),
|
|
49
|
+
value.length
|
|
50
|
+
);
|
|
48
51
|
}
|
|
49
52
|
|
|
50
53
|
return value;
|
|
@@ -344,7 +344,7 @@ function getDayLabel( date: Date, isSelected: boolean, numEvents: number ) {
|
|
|
344
344
|
);
|
|
345
345
|
} else if ( isSelected ) {
|
|
346
346
|
return sprintf(
|
|
347
|
-
// translators:
|
|
347
|
+
// translators: 1: The calendar date.
|
|
348
348
|
__( '%1$s. Selected' ),
|
|
349
349
|
localizedDate
|
|
350
350
|
);
|
|
@@ -241,6 +241,9 @@ export function FormTokenField( props: FormTokenFieldProps ) {
|
|
|
241
241
|
case 'Escape':
|
|
242
242
|
preventDefault = handleEscapeKey( event );
|
|
243
243
|
break;
|
|
244
|
+
case 'Tab':
|
|
245
|
+
preventDefault = handleTabKey( event );
|
|
246
|
+
break;
|
|
244
247
|
default:
|
|
245
248
|
break;
|
|
246
249
|
}
|
|
@@ -372,17 +375,25 @@ export function FormTokenField( props: FormTokenFieldProps ) {
|
|
|
372
375
|
return true; // PreventDefault.
|
|
373
376
|
}
|
|
374
377
|
|
|
375
|
-
function
|
|
378
|
+
function collapseSuggestionsList( event: KeyboardEvent ) {
|
|
376
379
|
if ( event.target instanceof HTMLInputElement ) {
|
|
377
380
|
setIncompleteTokenValue( event.target.value );
|
|
378
381
|
setIsExpanded( false );
|
|
379
382
|
setSelectedSuggestionIndex( -1 );
|
|
380
383
|
setSelectedSuggestionScroll( false );
|
|
381
384
|
}
|
|
385
|
+
}
|
|
382
386
|
|
|
387
|
+
function handleEscapeKey( event: KeyboardEvent ) {
|
|
388
|
+
collapseSuggestionsList( event );
|
|
383
389
|
return true; // PreventDefault.
|
|
384
390
|
}
|
|
385
391
|
|
|
392
|
+
function handleTabKey( event: KeyboardEvent ) {
|
|
393
|
+
collapseSuggestionsList( event );
|
|
394
|
+
return false; // Do not prevent the default behavior.
|
|
395
|
+
}
|
|
396
|
+
|
|
386
397
|
function handleCommaKey() {
|
|
387
398
|
if ( inputHasValidValue() ) {
|
|
388
399
|
addNewToken( incompleteTokenValue );
|
|
@@ -47,7 +47,7 @@ export default function Token( {
|
|
|
47
47
|
const transformedValue = displayTransform( value );
|
|
48
48
|
const termPositionAndCount = sprintf(
|
|
49
49
|
/* translators: 1: term name, 2: term position in a set of terms, 3: total term set count. */
|
|
50
|
-
__( '%1$s (%2$
|
|
50
|
+
__( '%1$s (%2$d of %3$d)' ),
|
|
51
51
|
transformedValue,
|
|
52
52
|
termPosition,
|
|
53
53
|
termsCount
|
package/src/index.ts
CHANGED
|
@@ -57,6 +57,7 @@ export {
|
|
|
57
57
|
CardHeader,
|
|
58
58
|
CardMedia,
|
|
59
59
|
} from './card';
|
|
60
|
+
export { DateCalendar, DateRangeCalendar, TZDate } from './calendar';
|
|
60
61
|
export { default as CheckboxControl } from './checkbox-control';
|
|
61
62
|
export { default as ClipboardButton } from './clipboard-button';
|
|
62
63
|
export { default as __experimentalPaletteEdit } from './palette-edit';
|
|
@@ -304,13 +304,13 @@ class BottomSheetCell extends Component {
|
|
|
304
304
|
}
|
|
305
305
|
return ! help
|
|
306
306
|
? sprintf(
|
|
307
|
-
/* translators: accessibility text. Inline textinput title and value
|
|
307
|
+
/* translators: accessibility text. Inline textinput title and value. %1: Cell title, %2: cell value. */
|
|
308
308
|
_x( '%1$s, %2$s', 'inline textinput cell' ),
|
|
309
309
|
label,
|
|
310
310
|
value
|
|
311
311
|
) // Separating by ',' is necessary to make a pause on urls (non-capitalized text)
|
|
312
312
|
: sprintf(
|
|
313
|
-
/* translators: accessibility text. Inline textinput title, value and help text
|
|
313
|
+
/* translators: accessibility text. Inline textinput title, value and help text. %1: Cell title, %2: cell value, , %3: cell help. */
|
|
314
314
|
_x( '%1$s, %2$s, %3$s', 'inline textinput cell' ),
|
|
315
315
|
label,
|
|
316
316
|
value,
|
|
@@ -135,7 +135,7 @@ export const LinkPicker = ( {
|
|
|
135
135
|
<BottomSheet.LinkSuggestionItemCell
|
|
136
136
|
accessible
|
|
137
137
|
accessibilityLabel={ sprintf(
|
|
138
|
-
/* translators: Copy URL from the clipboard, https://sample.url */
|
|
138
|
+
/* translators: %s: Copy URL from the clipboard, https://sample.url */
|
|
139
139
|
__( 'Copy URL from the clipboard, %s' ),
|
|
140
140
|
clipboardUrl
|
|
141
141
|
) }
|
|
@@ -122,8 +122,8 @@ export function getNameAndSlugForPosition(
|
|
|
122
122
|
|
|
123
123
|
return {
|
|
124
124
|
name: sprintf(
|
|
125
|
-
/* translators: %
|
|
126
|
-
__( 'Color %
|
|
125
|
+
/* translators: %d: is an id for a custom color */
|
|
126
|
+
__( 'Color %d' ),
|
|
127
127
|
position
|
|
128
128
|
),
|
|
129
129
|
slug: `${ slugPrefix }color-${ position }`,
|
|
@@ -223,7 +223,7 @@ function Option< T extends PaletteElement >( {
|
|
|
223
223
|
aria-label={ sprintf(
|
|
224
224
|
// translators: %s is a color or gradient name, e.g. "Red".
|
|
225
225
|
__( 'Edit: %s' ),
|
|
226
|
-
element.name.trim().length ? element.name : value
|
|
226
|
+
element.name.trim().length ? element.name : value || ''
|
|
227
227
|
) }
|
|
228
228
|
style={ { padding: 0 } }
|
|
229
229
|
>
|
|
@@ -267,7 +267,7 @@ function Option< T extends PaletteElement >( {
|
|
|
267
267
|
__( 'Remove color: %s' ),
|
|
268
268
|
element.name.trim().length
|
|
269
269
|
? element.name
|
|
270
|
-
: value
|
|
270
|
+
: value || ''
|
|
271
271
|
) }
|
|
272
272
|
onClick={ onRemove }
|
|
273
273
|
/>
|
package/src/style.scss
CHANGED
|
@@ -13,6 +13,7 @@
|
|
|
13
13
|
@import "./badge/styles.scss";
|
|
14
14
|
@import "./button-group/style.scss";
|
|
15
15
|
@import "./button/style.scss";
|
|
16
|
+
@import "./calendar/style.scss";
|
|
16
17
|
@import "./checkbox-control/style.scss";
|
|
17
18
|
@import "./circular-option-picker/style.scss";
|
|
18
19
|
@import "./palette-edit/style.scss";
|