playbook_ui 15.3.0.pre.alpha.PLAY2322popoverconditionalrender11766 → 15.3.0.pre.alpha.PLAY2532flexboxdefaultresponsive12209
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.
- checksums.yaml +4 -4
- data/app/pb_kits/playbook/pb_advanced_table/Components/RegularTableView.tsx +2 -1
- data/app/pb_kits/playbook/pb_advanced_table/Hooks/useTableState.ts +15 -0
- data/app/pb_kits/playbook/pb_advanced_table/Utilities/RowUtils.ts +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +4 -4
- data/app/pb_kits/playbook/pb_advanced_table/advanced_table.test.jsx +68 -5
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_background_control_rails.html.erb +4 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_background_control_rails.md +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_border_color.md +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_border_color_rails.md +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling.jsx +3 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling.md +2 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_column_headers.jsx +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_rails.html.erb +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_rails.md +2 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_padding_control.jsx +9 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_padding_control.md +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_pagination_with_props.jsx +4 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_pagination_with_props.md +3 -2
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sticky_columns_and_header.md +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_sticky_header_rails.md +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_sticky_header_react.md +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header_multi_header.jsx +16 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header_multi_header_rails.html.erb +104 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header_multi_header_rails.md +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header_rails.html.erb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/flat_advanced_table.js +2 -2
- data/app/pb_kits/playbook/pb_advanced_table/index.js +7 -7
- data/app/pb_kits/playbook/pb_advanced_table/scss_partials/advanced_table_sticky_mixin.scss +2 -2
- data/app/pb_kits/playbook/pb_advanced_table/table_header.rb +90 -20
- data/app/pb_kits/playbook/pb_advanced_table/table_row.rb +32 -3
- data/app/pb_kits/playbook/pb_background/background.html.erb +10 -2
- data/app/pb_kits/playbook/pb_background/docs/_background_category.md +1 -1
- data/app/pb_kits/playbook/pb_badge/_badge.tsx +4 -1
- data/app/pb_kits/playbook/pb_badge/badge.test.js +13 -0
- data/app/pb_kits/playbook/pb_card/docs/_card_background.md +1 -1
- data/app/pb_kits/playbook/pb_card/docs/_card_header.md +1 -1
- data/app/pb_kits/playbook/pb_card/docs/_card_highlight.md +1 -1
- data/app/pb_kits/playbook/pb_card/docs/_card_light.md +1 -1
- data/app/pb_kits/playbook/pb_currency/_currency.tsx +20 -7
- data/app/pb_kits/playbook/pb_currency/currency.rb +35 -8
- data/app/pb_kits/playbook/pb_currency/currency.test.js +47 -0
- data/app/pb_kits/playbook/pb_currency/docs/_currency_variants.html.erb +1 -1
- data/app/pb_kits/playbook/pb_currency/docs/_currency_variants.jsx +1 -1
- data/app/pb_kits/playbook/pb_currency/docs/_currency_variants.md +1 -0
- data/app/pb_kits/playbook/pb_date_picker/date_picker.rb +2 -0
- data/app/pb_kits/playbook/pb_date_picker/date_picker_helper.ts +16 -4
- data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_and_dropdown_range.jsx +38 -0
- data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_and_dropdown_range.md +14 -0
- data/app/pb_kits/playbook/pb_date_picker/docs/example.yml +2 -1
- data/app/pb_kits/playbook/pb_date_picker/docs/index.js +2 -1
- data/app/pb_kits/playbook/pb_distribution_bar/docs/_distribution_bar_custom_colors.md +1 -1
- data/app/pb_kits/playbook/pb_dropdown/_dropdown.scss +1 -0
- data/app/pb_kits/playbook/pb_dropdown/_dropdown.tsx +111 -6
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick.jsx +18 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick.md +4 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_default_dates.jsx +18 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_default_dates.md +1 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_range_end.jsx +19 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_range_end.md +1 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_with_date_pickers.jsx +38 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_with_date_pickers.md +14 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_active_style_options_react.md +1 -1
- data/app/pb_kits/playbook/pb_dropdown/docs/example.yml +5 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/index.js +5 -1
- data/app/pb_kits/playbook/pb_dropdown/dropdown.test.jsx +148 -2
- data/app/pb_kits/playbook/pb_dropdown/quickpick/index.ts +60 -0
- data/app/pb_kits/playbook/pb_filter/docs/_filter_max_width.md +1 -1
- data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_auto_close.html.erb +15 -1
- data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_multi_line.html.erb +9 -8
- data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_positions.html.erb +11 -10
- data/app/pb_kits/playbook/pb_form/pb_form_validation.js +44 -11
- data/app/pb_kits/playbook/pb_form_pill/_form_pill.tsx +1 -1
- data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_truncated_text_rails.md +1 -1
- data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_truncated_text_react.md +1 -1
- data/app/pb_kits/playbook/pb_icon/docs/_icon_color.md +1 -1
- data/app/pb_kits/playbook/pb_icon_circle/docs/_icon_circle_color.md +1 -1
- data/app/pb_kits/playbook/pb_icon_stat_value/docs/_icon_stat_value_color.html.erb +7 -14
- data/app/pb_kits/playbook/pb_icon_stat_value/docs/_icon_stat_value_color.jsx +6 -15
- data/app/pb_kits/playbook/pb_layout/docs/_layout_collection.md +1 -1
- data/app/pb_kits/playbook/pb_nav/docs/_collapsible_nav_item_spacing.md +1 -1
- data/app/pb_kits/playbook/pb_nav/docs/_nav_with_spacing_control.md +1 -1
- data/app/pb_kits/playbook/pb_overlay/docs/_overlay_layout.md +1 -1
- data/app/pb_kits/playbook/pb_phone_number_input/_phone_number_input.tsx +110 -17
- data/app/pb_kits/playbook/pb_pill/docs/_description.md +1 -1
- data/app/pb_kits/playbook/pb_popover/_popover.scss +0 -12
- data/app/pb_kits/playbook/pb_popover/_popover.tsx +26 -5
- data/app/pb_kits/playbook/pb_popover/docs/_popover_append_to.jsx +68 -0
- data/app/pb_kits/playbook/pb_popover/docs/_popover_append_to_react.md +1 -0
- data/app/pb_kits/playbook/pb_popover/docs/_popover_close.jsx +0 -7
- data/app/pb_kits/playbook/pb_popover/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_popover/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_popover/popover.test.js +80 -0
- data/app/pb_kits/playbook/pb_rich_text_editor/docs/_description.md +1 -1
- data/app/pb_kits/playbook/pb_section_separator/docs/_description.md +1 -1
- data/app/pb_kits/playbook/pb_selectable_card/_selectable_card.scss +29 -0
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_border_radius_rails.md +1 -1
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_border_radius_react.md +1 -1
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_layout.md +1 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_side_highlight.md +1 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_sm.md +1 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_with_dynamic_collapsible.html.erb +63 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_dynamic_collapsible.jsx +89 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_dynamic_collapsible_rails.md +4 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_dynamic_collapsible_react.md +3 -0
- data/app/pb_kits/playbook/pb_table/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_table/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_text_input/text_input.rb +2 -2
- data/app/pb_kits/playbook/pb_typeahead/_typeahead.scss +7 -0
- data/app/pb_kits/playbook/pb_typeahead/_typeahead.test.jsx +105 -1
- data/app/pb_kits/playbook/pb_typeahead/_typeahead.tsx +23 -9
- data/app/pb_kits/playbook/pb_typeahead/components/MultiValue.tsx +33 -1
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_custom_options.html.erb +64 -0
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_custom_options.jsx +70 -0
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_custom_options.md +1 -0
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_default_options.html.erb +67 -1
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_default_value.jsx +68 -6
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_truncated_text.md +1 -1
- data/app/pb_kits/playbook/pb_typeahead/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_typeahead/docs/index.js +2 -1
- data/app/pb_kits/playbook/utilities/globalProps.ts +26 -8
- data/app/pb_kits/playbook/utilities/test/globalProps/alignContent.test.js +18 -0
- data/app/pb_kits/playbook/utilities/test/globalProps/alignItems.test.js +18 -0
- data/app/pb_kits/playbook/utilities/test/globalProps/alignSelf.test.js +18 -0
- data/app/pb_kits/playbook/utilities/test/globalProps/display.test.js +18 -0
- data/app/pb_kits/playbook/utilities/test/globalProps/flex.test.js +18 -0
- data/app/pb_kits/playbook/utilities/test/globalProps/flexDirection.test.js +18 -0
- data/app/pb_kits/playbook/utilities/test/globalProps/flexGrow.test.js +18 -0
- data/app/pb_kits/playbook/utilities/test/globalProps/flexShrink.test.js +18 -0
- data/app/pb_kits/playbook/utilities/test/globalProps/flexWrap.test.js +18 -0
- data/app/pb_kits/playbook/utilities/test/globalProps/justifyContent.test.js +18 -0
- data/app/pb_kits/playbook/utilities/test/globalProps/justifySelf.test.js +18 -0
- data/app/pb_kits/playbook/utilities/test/globalProps/order.test.js +18 -0
- data/dist/chunks/{_line_graph-BxC7m53J.js → _line_graph-9bI76O2f.js} +1 -1
- data/dist/chunks/_typeahead-By0NwDwL.js +6 -0
- data/dist/chunks/_weekday_stacked-ClJbIaDx.js +37 -0
- data/dist/chunks/{lib-CGxXTQ75.js → lib-BXBHAZMY.js} +1 -1
- data/dist/chunks/pb_form_validation-BNfSnIUF.js +1 -0
- data/dist/chunks/vendor.js +1 -1
- data/dist/playbook-doc.js +2 -2
- data/dist/playbook-rails-react-bindings.js +1 -1
- data/dist/playbook-rails.js +1 -1
- data/dist/playbook.css +1 -1
- data/lib/playbook/version.rb +1 -1
- metadata +31 -9
- data/app/pb_kits/playbook/pb_popover/docs/hook/useSmallScreenIndicator.tsx +0 -27
- data/dist/chunks/_typeahead-B1SiFvbF.js +0 -6
- data/dist/chunks/_weekday_stacked-DxdwXyYM.js +0 -37
- data/dist/chunks/pb_form_validation-DebqlUKZ.js +0 -1
- /data/app/pb_kits/playbook/pb_popover/docs/{_popover_append_to.md → _popover_append_to_rails.md} +0 -0
|
@@ -171,4 +171,108 @@ test('typeahead with defaultValue with focus behavior', async () => {
|
|
|
171
171
|
expect(focusedOption).toBeInTheDocument()
|
|
172
172
|
expect(focusedOption).toHaveTextContent('Red')
|
|
173
173
|
})
|
|
174
|
-
})
|
|
174
|
+
})
|
|
175
|
+
|
|
176
|
+
test('typeahead with grouped options and defaultValue focus behavior', async () => {
|
|
177
|
+
const groupedOptions = [
|
|
178
|
+
{
|
|
179
|
+
label: "Warm Colors",
|
|
180
|
+
options: [
|
|
181
|
+
{ label: "Red", value: "#FF0000" },
|
|
182
|
+
{ label: "Orange", value: "#FFA500" },
|
|
183
|
+
{ label: "Yellow", value: "#FFFF00" }
|
|
184
|
+
]
|
|
185
|
+
},
|
|
186
|
+
{
|
|
187
|
+
label: "Cool Colors",
|
|
188
|
+
options: [
|
|
189
|
+
{ label: "Blue", value: "#0000FF" },
|
|
190
|
+
{ label: "Teal", value: "#008080" },
|
|
191
|
+
{ label: "Cyan", value: "#00FFFF" }
|
|
192
|
+
]
|
|
193
|
+
},
|
|
194
|
+
{
|
|
195
|
+
label: "Fun Shades",
|
|
196
|
+
options: [
|
|
197
|
+
{ label: "Pink", value: "#FFC0CB" },
|
|
198
|
+
{ label: "Magenta", value: "#FF00FF" },
|
|
199
|
+
{ label: "Purple", value: "#800080" }
|
|
200
|
+
]
|
|
201
|
+
}
|
|
202
|
+
]
|
|
203
|
+
|
|
204
|
+
render(
|
|
205
|
+
<Typeahead
|
|
206
|
+
data={{ testid: 'grouped-options-focus-test' }}
|
|
207
|
+
defaultValue={[{ label: "Pink", value: "#FFC0CB" }]}
|
|
208
|
+
options={groupedOptions}
|
|
209
|
+
/>
|
|
210
|
+
)
|
|
211
|
+
|
|
212
|
+
const kit = screen.getByTestId('grouped-options-focus-test')
|
|
213
|
+
const inputDiv = kit.querySelector(".typeahead-kit-select__single-value")
|
|
214
|
+
expect(inputDiv).toHaveTextContent("Pink")
|
|
215
|
+
})
|
|
216
|
+
|
|
217
|
+
test('multi-value pills have tabIndex for keyboard navigation', () => {
|
|
218
|
+
render(
|
|
219
|
+
<Typeahead
|
|
220
|
+
data={{ testid: 'pill-tabindex-test' }}
|
|
221
|
+
defaultValue={[options[0], options[1]]}
|
|
222
|
+
isMulti
|
|
223
|
+
options={options}
|
|
224
|
+
/>
|
|
225
|
+
)
|
|
226
|
+
|
|
227
|
+
const kit = screen.getByTestId('pill-tabindex-test')
|
|
228
|
+
const pills = kit.querySelectorAll('.pb_form_pill_kit')
|
|
229
|
+
|
|
230
|
+
expect(pills.length).toBe(2)
|
|
231
|
+
|
|
232
|
+
pills.forEach(pill => {
|
|
233
|
+
expect(pill).toHaveAttribute('tabIndex', '0')
|
|
234
|
+
})
|
|
235
|
+
})
|
|
236
|
+
|
|
237
|
+
test('multi-value pills show focus indicator when focused', async () => {
|
|
238
|
+
render(
|
|
239
|
+
<Typeahead
|
|
240
|
+
data={{ testid: 'pill-focus-indicator-test' }}
|
|
241
|
+
defaultValue={[options[0], options[1], options[2]]}
|
|
242
|
+
isMulti
|
|
243
|
+
options={options}
|
|
244
|
+
/>
|
|
245
|
+
)
|
|
246
|
+
|
|
247
|
+
const kit = screen.getByTestId('pill-focus-indicator-test')
|
|
248
|
+
const pills = kit.querySelectorAll('.pb_form_pill_kit')
|
|
249
|
+
|
|
250
|
+
expect(pills.length).toBe(3)
|
|
251
|
+
|
|
252
|
+
const firstPill = pills[0]
|
|
253
|
+
firstPill.focus()
|
|
254
|
+
|
|
255
|
+
expect(document.activeElement).toBe(firstPill)
|
|
256
|
+
})
|
|
257
|
+
|
|
258
|
+
test('multi-value badges have tabIndex and focus class when focused', () => {
|
|
259
|
+
render(
|
|
260
|
+
<Typeahead
|
|
261
|
+
data={{ testid: 'badge-focus-test' }}
|
|
262
|
+
defaultValue={[options[0], options[1]]}
|
|
263
|
+
isMulti
|
|
264
|
+
multiKit="badge"
|
|
265
|
+
options={options}
|
|
266
|
+
/>
|
|
267
|
+
)
|
|
268
|
+
|
|
269
|
+
const kit = screen.getByTestId('badge-focus-test')
|
|
270
|
+
const badges = kit.querySelectorAll('.pb_badge_kit_primary')
|
|
271
|
+
|
|
272
|
+
expect(badges.length).toBe(2)
|
|
273
|
+
|
|
274
|
+
badges.forEach(badge => {
|
|
275
|
+
expect(badge).toHaveAttribute('tabIndex', '0')
|
|
276
|
+
})
|
|
277
|
+
})
|
|
278
|
+
|
|
@@ -144,6 +144,18 @@ const Typeahead = forwardRef<HTMLInputElement, TypeaheadProps>(({
|
|
|
144
144
|
// Create a ref to access React Select instance
|
|
145
145
|
const selectRef = useRef<any>(null)
|
|
146
146
|
|
|
147
|
+
// Helper function to flatten grouped options if custom groups are used
|
|
148
|
+
const flattenOptions = (options: any[]): any[] => {
|
|
149
|
+
if (!options) return []
|
|
150
|
+
|
|
151
|
+
return options.reduce((acc, option) => {
|
|
152
|
+
if (option.options && Array.isArray(option.options)) {
|
|
153
|
+
return [...acc, ...option.options]
|
|
154
|
+
}
|
|
155
|
+
return [...acc, option]
|
|
156
|
+
}, [])
|
|
157
|
+
}
|
|
158
|
+
|
|
147
159
|
// Configure focus on selected option using React Select's API
|
|
148
160
|
const handleMenuOpen = () => {
|
|
149
161
|
setTimeout(() => {
|
|
@@ -159,17 +171,18 @@ const Typeahead = forwardRef<HTMLInputElement, TypeaheadProps>(({
|
|
|
159
171
|
|
|
160
172
|
const options = props.options
|
|
161
173
|
if (options) {
|
|
162
|
-
//
|
|
163
|
-
const
|
|
174
|
+
// Flatten grouped options to find the matching option and find matching option
|
|
175
|
+
const flatOptions = flattenOptions(options)
|
|
176
|
+
|
|
177
|
+
const targetOption = flatOptions.find((option: any) => {
|
|
164
178
|
const optionValue = props.getOptionValue ? props.getOptionValue(option) : option.value
|
|
165
179
|
const currentOptionValue = props.getOptionValue ? props.getOptionValue(currentValue) : currentValue.value
|
|
166
180
|
return optionValue === currentOptionValue
|
|
167
181
|
})
|
|
168
182
|
|
|
169
|
-
if (
|
|
183
|
+
if (targetOption) {
|
|
170
184
|
// Use React Select's internal state to set focused option
|
|
171
185
|
if (selectRef.current && selectRef.current.setState) {
|
|
172
|
-
const targetOption = options[focusedIndex]
|
|
173
186
|
selectRef.current.setState({
|
|
174
187
|
focusedOption: targetOption,
|
|
175
188
|
focusedValue: null
|
|
@@ -179,11 +192,12 @@ const Typeahead = forwardRef<HTMLInputElement, TypeaheadProps>(({
|
|
|
179
192
|
setTimeout(() => {
|
|
180
193
|
if (selectRef.current && selectRef.current.menuListRef) {
|
|
181
194
|
const menuElement = selectRef.current.menuListRef
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
const
|
|
195
|
+
// Find the focused option using React Select's class
|
|
196
|
+
const focusedElement = menuElement.querySelector('.typeahead-kit-select__option--is-focused')
|
|
197
|
+
|
|
198
|
+
if (focusedElement) {
|
|
199
|
+
const optionTop = focusedElement.offsetTop
|
|
200
|
+
const optionHeight = focusedElement.offsetHeight
|
|
187
201
|
const menuHeight = menuElement.clientHeight
|
|
188
202
|
|
|
189
203
|
// Set the menu's scrollTop to position the selected option in the middle
|
|
@@ -12,11 +12,12 @@ type Props = {
|
|
|
12
12
|
pillColor?: "primary" | "neutral" | "success" | "warning" | "error" | "info" | "data_1" | "data_2" | "data_3" | "data_4" | "data_5" | "data_6" | "data_7" | "data_8" | "windows" | "siding" | "roofing" | "doors" | "gutters" | "solar" | "insulation" | "accessories",
|
|
13
13
|
removeProps: any,
|
|
14
14
|
selectProps: any,
|
|
15
|
+
isFocused?: boolean,
|
|
15
16
|
}
|
|
16
17
|
|
|
17
18
|
|
|
18
19
|
const MultiValue = (props: Props) => {
|
|
19
|
-
const { removeProps } = props
|
|
20
|
+
const { removeProps, isFocused } = props
|
|
20
21
|
const { imageUrl, label } = props.data
|
|
21
22
|
const { dark, multiKit, pillColor, truncate, wrapped } = props.selectProps
|
|
22
23
|
|
|
@@ -29,6 +30,28 @@ const MultiValue = (props: Props) => {
|
|
|
29
30
|
|
|
30
31
|
if (typeof imageUrl === 'string') formPillProps.avatarUrl = imageUrl
|
|
31
32
|
|
|
33
|
+
// Add className for focus state
|
|
34
|
+
const pillClassName = isFocused ? 'pb_form_pill_or_badge_focused' : ''
|
|
35
|
+
|
|
36
|
+
// Handle keyboard events on the pill itself to enable deletion when using tabIndex
|
|
37
|
+
const handleKeyDown = (event: React.KeyboardEvent<HTMLDivElement>) => {
|
|
38
|
+
if (event.key === 'Backspace' || event.key === 'Delete') {
|
|
39
|
+
event.preventDefault()
|
|
40
|
+
event.stopPropagation()
|
|
41
|
+
// Trigger the remove action from react-select
|
|
42
|
+
if (removeProps && removeProps.onClick) {
|
|
43
|
+
removeProps.onClick(event as any)
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
// if arrow keys used, transfer focus to input so react-select can take over
|
|
47
|
+
else if (event.key === 'ArrowLeft' || event.key === 'ArrowRight') {
|
|
48
|
+
const selectInput = event.currentTarget.closest('.pb_typeahead_kit')?.querySelector('input')
|
|
49
|
+
if (selectInput instanceof HTMLInputElement) {
|
|
50
|
+
selectInput.focus()
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
|
|
32
55
|
return (
|
|
33
56
|
<components.MultiValueContainer
|
|
34
57
|
className="text_input_multivalue_container"
|
|
@@ -36,8 +59,11 @@ const MultiValue = (props: Props) => {
|
|
|
36
59
|
>
|
|
37
60
|
{multiKit === 'badge' &&
|
|
38
61
|
<Badge
|
|
62
|
+
className={pillClassName}
|
|
39
63
|
closeProps={removeProps}
|
|
64
|
+
htmlOptions={{onKeyDown:handleKeyDown}}
|
|
40
65
|
removeIcon
|
|
66
|
+
tabIndex={0}
|
|
41
67
|
text={label}
|
|
42
68
|
variant="primary"
|
|
43
69
|
/>
|
|
@@ -46,12 +72,15 @@ const MultiValue = (props: Props) => {
|
|
|
46
72
|
{multiKit !== 'badge' && imageUrl &&
|
|
47
73
|
<FormPill
|
|
48
74
|
avatarUrl={imageUrl}
|
|
75
|
+
className={pillClassName}
|
|
49
76
|
closeProps={removeProps}
|
|
50
77
|
color={pillColor}
|
|
51
78
|
dark={dark}
|
|
79
|
+
htmlOptions={{onKeyDown:handleKeyDown}}
|
|
52
80
|
marginRight="xs"
|
|
53
81
|
name={label}
|
|
54
82
|
size={multiKit === 'smallPill' ? 'small' : ''}
|
|
83
|
+
tabIndex={0}
|
|
55
84
|
text=''
|
|
56
85
|
truncate={truncate}
|
|
57
86
|
wrapped={wrapped}
|
|
@@ -61,12 +90,15 @@ const MultiValue = (props: Props) => {
|
|
|
61
90
|
|
|
62
91
|
{multiKit !== 'badge' && !imageUrl &&
|
|
63
92
|
<FormPill
|
|
93
|
+
className={pillClassName}
|
|
64
94
|
closeProps={removeProps}
|
|
65
95
|
color={pillColor}
|
|
66
96
|
dark={dark}
|
|
97
|
+
htmlOptions={{onKeyDown:handleKeyDown}}
|
|
67
98
|
marginRight="xs"
|
|
68
99
|
name=''
|
|
69
100
|
size={multiKit === 'smallPill' ? 'small' : ''}
|
|
101
|
+
tabIndex={0}
|
|
70
102
|
text={label}
|
|
71
103
|
truncate={truncate}
|
|
72
104
|
wrapped={wrapped}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
<%
|
|
2
|
+
grouped_options = [
|
|
3
|
+
{
|
|
4
|
+
label: "Warm Colors",
|
|
5
|
+
options: [
|
|
6
|
+
{ label: "Red", value: "#FF0000" },
|
|
7
|
+
{ label: "Orange", value: "#FFA500" },
|
|
8
|
+
{ label: "Yellow", value: "#FFFF00" },
|
|
9
|
+
{ label: "Coral", value: "#FF7F50" },
|
|
10
|
+
{ label: "Gold", value: "#FFD700" }
|
|
11
|
+
]
|
|
12
|
+
},
|
|
13
|
+
{
|
|
14
|
+
label: "Cool Colors",
|
|
15
|
+
options: [
|
|
16
|
+
{ label: "Blue", value: "#0000FF" },
|
|
17
|
+
{ label: "Teal", value: "#008080" },
|
|
18
|
+
{ label: "Cyan", value: "#00FFFF" },
|
|
19
|
+
{ label: "Navy", value: "#000080" },
|
|
20
|
+
{ label: "Turquoise", value: "#40E0D0" }
|
|
21
|
+
]
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
label: "Neutrals",
|
|
25
|
+
options: [
|
|
26
|
+
{ label: "White", value: "#FFFFFF" },
|
|
27
|
+
{ label: "Black", value: "#000000" },
|
|
28
|
+
{ label: "Gray", value: "#808080" },
|
|
29
|
+
{ label: "Beige", value: "#F5F5DC" },
|
|
30
|
+
{ label: "Silver", value: "#C0C0C0" }
|
|
31
|
+
]
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
label: "Earth Tones",
|
|
35
|
+
options: [
|
|
36
|
+
{ label: "Brown", value: "#A52A2A" },
|
|
37
|
+
{ label: "Olive", value: "#808000" },
|
|
38
|
+
{ label: "Forest Green", value: "#228B22" },
|
|
39
|
+
{ label: "Tan", value: "#D2B48C" },
|
|
40
|
+
{ label: "Maroon", value: "#800000" }
|
|
41
|
+
]
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
label: "Fun Shades",
|
|
45
|
+
options: [
|
|
46
|
+
{ label: "Pink", value: "#FFC0CB" },
|
|
47
|
+
{ label: "Magenta", value: "#FF00FF" },
|
|
48
|
+
{ label: "Lime", value: "#00FF00" },
|
|
49
|
+
{ label: "Purple", value: "#800080" },
|
|
50
|
+
{ label: "Indigo", value: "#4B0082" }
|
|
51
|
+
]
|
|
52
|
+
}
|
|
53
|
+
]
|
|
54
|
+
%>
|
|
55
|
+
<br />
|
|
56
|
+
<%= pb_rails("typeahead", props: {
|
|
57
|
+
id: "typeahead-custom-options",
|
|
58
|
+
options: grouped_options,
|
|
59
|
+
label: "Colors",
|
|
60
|
+
name: :foo,
|
|
61
|
+
placeholder: "Select a Color...",
|
|
62
|
+
is_multi: false
|
|
63
|
+
})
|
|
64
|
+
%>
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import React from 'react'
|
|
2
|
+
|
|
3
|
+
import Typeahead from '../_typeahead'
|
|
4
|
+
|
|
5
|
+
const groupedOptions = [
|
|
6
|
+
{
|
|
7
|
+
label: "Warm Colors",
|
|
8
|
+
options: [
|
|
9
|
+
{ label: "Red", value: "#FF0000" },
|
|
10
|
+
{ label: "Orange", value: "#FFA500" },
|
|
11
|
+
{ label: "Yellow", value: "#FFFF00" },
|
|
12
|
+
{ label: "Coral", value: "#FF7F50" },
|
|
13
|
+
{ label: "Gold", value: "#FFD700" }
|
|
14
|
+
]
|
|
15
|
+
},
|
|
16
|
+
{
|
|
17
|
+
label: "Cool Colors",
|
|
18
|
+
options: [
|
|
19
|
+
{ label: "Blue", value: "#0000FF" },
|
|
20
|
+
{ label: "Teal", value: "#008080" },
|
|
21
|
+
{ label: "Cyan", value: "#00FFFF" },
|
|
22
|
+
{ label: "Navy", value: "#000080" },
|
|
23
|
+
{ label: "Turquoise", value: "#40E0D0" }
|
|
24
|
+
]
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
label: "Neutrals",
|
|
28
|
+
options: [
|
|
29
|
+
{ label: "White", value: "#FFFFFF" },
|
|
30
|
+
{ label: "Black", value: "#000000" },
|
|
31
|
+
{ label: "Gray", value: "#808080" },
|
|
32
|
+
{ label: "Beige", value: "#F5F5DC" },
|
|
33
|
+
{ label: "Silver", value: "#C0C0C0" }
|
|
34
|
+
]
|
|
35
|
+
},
|
|
36
|
+
{
|
|
37
|
+
label: "Earth Tones",
|
|
38
|
+
options: [
|
|
39
|
+
{ label: "Brown", value: "#A52A2A" },
|
|
40
|
+
{ label: "Olive", value: "#808000" },
|
|
41
|
+
{ label: "Forest Green", value: "#228B22" },
|
|
42
|
+
{ label: "Tan", value: "#D2B48C" },
|
|
43
|
+
{ label: "Maroon", value: "#800000" }
|
|
44
|
+
]
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
label: "Fun Shades",
|
|
48
|
+
options: [
|
|
49
|
+
{ label: "Pink", value: "#FFC0CB" },
|
|
50
|
+
{ label: "Magenta", value: "#FF00FF" },
|
|
51
|
+
{ label: "Lime", value: "#00FF00" },
|
|
52
|
+
{ label: "Purple", value: "#800080" },
|
|
53
|
+
{ label: "Indigo", value: "#4B0082" }
|
|
54
|
+
]
|
|
55
|
+
}
|
|
56
|
+
]
|
|
57
|
+
|
|
58
|
+
const TypeaheadCustomOptions = (props) => {
|
|
59
|
+
return (
|
|
60
|
+
<Typeahead
|
|
61
|
+
label="Colors"
|
|
62
|
+
options={groupedOptions}
|
|
63
|
+
placeholder="Select a Color..."
|
|
64
|
+
{...props}
|
|
65
|
+
/>
|
|
66
|
+
)
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
export default TypeaheadCustomOptions
|
|
70
|
+
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
Grouped options can be rendered via structuring the options in the way shown in the code snippet below.
|
|
@@ -25,11 +25,77 @@
|
|
|
25
25
|
]
|
|
26
26
|
%>
|
|
27
27
|
|
|
28
|
+
<%
|
|
29
|
+
grouped_options = [
|
|
30
|
+
{
|
|
31
|
+
label: "Warm Colors",
|
|
32
|
+
options: [
|
|
33
|
+
{ label: "Red", value: "#FF0000" },
|
|
34
|
+
{ label: "Orange", value: "#FFA500" },
|
|
35
|
+
{ label: "Yellow", value: "#FFFF00" },
|
|
36
|
+
{ label: "Coral", value: "#FF7F50" },
|
|
37
|
+
{ label: "Gold", value: "#FFD700" }
|
|
38
|
+
]
|
|
39
|
+
},
|
|
40
|
+
{
|
|
41
|
+
label: "Cool Colors",
|
|
42
|
+
options: [
|
|
43
|
+
{ label: "Blue", value: "#0000FF" },
|
|
44
|
+
{ label: "Teal", value: "#008080" },
|
|
45
|
+
{ label: "Cyan", value: "#00FFFF" },
|
|
46
|
+
{ label: "Navy", value: "#000080" },
|
|
47
|
+
{ label: "Turquoise", value: "#40E0D0" }
|
|
48
|
+
]
|
|
49
|
+
},
|
|
50
|
+
{
|
|
51
|
+
label: "Neutrals",
|
|
52
|
+
options: [
|
|
53
|
+
{ label: "White", value: "#FFFFFF" },
|
|
54
|
+
{ label: "Black", value: "#000000" },
|
|
55
|
+
{ label: "Gray", value: "#808080" },
|
|
56
|
+
{ label: "Beige", value: "#F5F5DC" },
|
|
57
|
+
{ label: "Silver", value: "#C0C0C0" }
|
|
58
|
+
]
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
label: "Earth Tones",
|
|
62
|
+
options: [
|
|
63
|
+
{ label: "Brown", value: "#A52A2A" },
|
|
64
|
+
{ label: "Olive", value: "#808000" },
|
|
65
|
+
{ label: "Forest Green", value: "#228B22" },
|
|
66
|
+
{ label: "Tan", value: "#D2B48C" },
|
|
67
|
+
{ label: "Maroon", value: "#800000" }
|
|
68
|
+
]
|
|
69
|
+
},
|
|
70
|
+
{
|
|
71
|
+
label: "Fun Shades",
|
|
72
|
+
options: [
|
|
73
|
+
{ label: "Pink", value: "#FFC0CB" },
|
|
74
|
+
{ label: "Magenta", value: "#FF00FF" },
|
|
75
|
+
{ label: "Lime", value: "#00FF00" },
|
|
76
|
+
{ label: "Purple", value: "#800080" },
|
|
77
|
+
{ label: "Indigo", value: "#4B0082" }
|
|
78
|
+
]
|
|
79
|
+
}
|
|
80
|
+
]
|
|
81
|
+
%>
|
|
82
|
+
|
|
83
|
+
|
|
28
84
|
<%= pb_rails("typeahead", props: {
|
|
29
85
|
default_options: [{ label: 'Gray', value: '#808080' }],
|
|
30
86
|
id: "typeahead-default-value",
|
|
31
87
|
options: options,
|
|
32
|
-
label: "
|
|
88
|
+
label: "Default Value with basic options",
|
|
89
|
+
name: :foo,
|
|
90
|
+
is_multi: false
|
|
91
|
+
})
|
|
92
|
+
%>
|
|
93
|
+
|
|
94
|
+
<%= pb_rails("typeahead", props: {
|
|
95
|
+
default_options:[{ label: "Pink", value: "#FFC0CB" }],
|
|
96
|
+
id: "typeahead-default-value-grouped-options",
|
|
97
|
+
options: grouped_options,
|
|
98
|
+
label: "Default Value with grouped options",
|
|
33
99
|
name: :foo,
|
|
34
100
|
is_multi: false
|
|
35
101
|
})
|
|
@@ -27,14 +27,76 @@ const options = [
|
|
|
27
27
|
{ label: 'Coral', value: '#FF7F50' }
|
|
28
28
|
]
|
|
29
29
|
|
|
30
|
+
const groupedOptions = [
|
|
31
|
+
{
|
|
32
|
+
label: "Warm Colors",
|
|
33
|
+
options: [
|
|
34
|
+
{ label: "Red", value: "#FF0000" },
|
|
35
|
+
{ label: "Orange", value: "#FFA500" },
|
|
36
|
+
{ label: "Yellow", value: "#FFFF00" },
|
|
37
|
+
{ label: "Coral", value: "#FF7F50" },
|
|
38
|
+
{ label: "Gold", value: "#FFD700" }
|
|
39
|
+
]
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
label: "Cool Colors",
|
|
43
|
+
options: [
|
|
44
|
+
{ label: "Blue", value: "#0000FF" },
|
|
45
|
+
{ label: "Teal", value: "#008080" },
|
|
46
|
+
{ label: "Cyan", value: "#00FFFF" },
|
|
47
|
+
{ label: "Navy", value: "#000080" },
|
|
48
|
+
{ label: "Turquoise", value: "#40E0D0" }
|
|
49
|
+
]
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
label: "Neutrals",
|
|
53
|
+
options: [
|
|
54
|
+
{ label: "White", value: "#FFFFFF" },
|
|
55
|
+
{ label: "Black", value: "#000000" },
|
|
56
|
+
{ label: "Gray", value: "#808080" },
|
|
57
|
+
{ label: "Beige", value: "#F5F5DC" },
|
|
58
|
+
{ label: "Silver", value: "#C0C0C0" }
|
|
59
|
+
]
|
|
60
|
+
},
|
|
61
|
+
{
|
|
62
|
+
label: "Earth Tones",
|
|
63
|
+
options: [
|
|
64
|
+
{ label: "Brown", value: "#A52A2A" },
|
|
65
|
+
{ label: "Olive", value: "#808000" },
|
|
66
|
+
{ label: "Forest Green", value: "#228B22" },
|
|
67
|
+
{ label: "Tan", value: "#D2B48C" },
|
|
68
|
+
{ label: "Maroon", value: "#800000" }
|
|
69
|
+
]
|
|
70
|
+
},
|
|
71
|
+
{
|
|
72
|
+
label: "Fun Shades",
|
|
73
|
+
options: [
|
|
74
|
+
{ label: "Pink", value: "#FFC0CB" },
|
|
75
|
+
{ label: "Magenta", value: "#FF00FF" },
|
|
76
|
+
{ label: "Lime", value: "#00FF00" },
|
|
77
|
+
{ label: "Purple", value: "#800080" },
|
|
78
|
+
{ label: "Indigo", value: "#4B0082" }
|
|
79
|
+
]
|
|
80
|
+
}
|
|
81
|
+
]
|
|
82
|
+
|
|
30
83
|
const TypeaheadDefaultValue = (props) => {
|
|
31
84
|
return (
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
85
|
+
<>
|
|
86
|
+
<Typeahead
|
|
87
|
+
defaultValue={options[10]}
|
|
88
|
+
label="Default Value with basic options"
|
|
89
|
+
options={options}
|
|
90
|
+
{...props}
|
|
91
|
+
/>
|
|
92
|
+
<br />
|
|
93
|
+
<Typeahead
|
|
94
|
+
defaultValue={{ label: "Pink", value: "#FFC0CB" }}
|
|
95
|
+
label="Default Value with grouped options"
|
|
96
|
+
options={groupedOptions}
|
|
97
|
+
{...props}
|
|
98
|
+
/>
|
|
99
|
+
</>
|
|
38
100
|
)
|
|
39
101
|
}
|
|
40
102
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
For Form Pills with longer text, the `truncate` global prop can be used to truncate the label within each Form Pill. Hover over the truncated Form Pill and a Tooltip containing the text or tag section of the Form Pill will appear. See [here](https://playbook.powerapp.cloud/
|
|
1
|
+
For Form Pills with longer text, the `truncate` global prop can be used to truncate the label within each Form Pill. Hover over the truncated Form Pill and a Tooltip containing the text or tag section of the Form Pill will appear. See [here](https://playbook.powerapp.cloud/global_props/truncate) for more information on the truncate global prop.
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
examples:
|
|
2
2
|
rails:
|
|
3
3
|
- typeahead_default: Default
|
|
4
|
+
- typeahead_custom_options: With Grouped Options
|
|
4
5
|
- typeahead_default_options: With Default Options
|
|
5
6
|
- typeahead_with_context: With Context
|
|
6
7
|
- typeahead_with_pills: With Pills
|
|
@@ -20,6 +21,7 @@ examples:
|
|
|
20
21
|
|
|
21
22
|
react:
|
|
22
23
|
- typeahead_default: Default
|
|
24
|
+
- typeahead_custom_options: With Grouped Options
|
|
23
25
|
- typeahead_default_value: With Default Value
|
|
24
26
|
- typeahead_react_hook: React Hook
|
|
25
27
|
- typeahead_with_highlight: With Highlight
|
|
@@ -16,4 +16,5 @@ export { default as TypeaheadTruncatedText } from './_typeahead_truncated_text.j
|
|
|
16
16
|
export { default as TypeaheadReactHook } from './_typeahead_react_hook.jsx'
|
|
17
17
|
export { default as TypeaheadDisabled } from './_typeahead_disabled.jsx'
|
|
18
18
|
export { default as TypeaheadPreserveInput } from './_typeahead_preserve_input.jsx'
|
|
19
|
-
export { default as TypeaheadDefaultValue } from './_typeahead_default_value.jsx'
|
|
19
|
+
export { default as TypeaheadDefaultValue } from './_typeahead_default_value.jsx'
|
|
20
|
+
export { default as TypeaheadCustomOptions } from './_typeahead_custom_options.jsx'
|
|
@@ -213,10 +213,24 @@ export type GlobalProps = AlignContent & AlignItems & AlignSelf &
|
|
|
213
213
|
|
|
214
214
|
const getResponsivePropClasses = (prop: {[key: string]: string}, classPrefix: string) => {
|
|
215
215
|
const keys: string[] = Object.keys(prop)
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
216
|
+
const screenSizeValues = ["xs", "sm", "md", "lg", "xl"]
|
|
217
|
+
let classResult = ''
|
|
218
|
+
|
|
219
|
+
// Handle default value separately (generates base class without size prefix)
|
|
220
|
+
if (prop.default !== undefined) {
|
|
221
|
+
const defaultValue: string = typeof(prop.default) === 'string' ? camelToSnakeCase(prop.default) : prop.default
|
|
222
|
+
classResult += `${classPrefix}_${defaultValue} `
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
// Handle responsive sizes (generates classes with size prefix)
|
|
226
|
+
keys.forEach((key) => {
|
|
227
|
+
if (screenSizeValues.includes(key)) {
|
|
228
|
+
const propValue: string = typeof(prop[key]) === 'string' ? camelToSnakeCase(prop[key]) : prop[key]
|
|
229
|
+
classResult += `${classPrefix}_${key}_${propValue} `
|
|
230
|
+
}
|
|
231
|
+
})
|
|
232
|
+
|
|
233
|
+
return classResult.trim()
|
|
220
234
|
}
|
|
221
235
|
|
|
222
236
|
//reusable function for top, bottom, right and left props
|
|
@@ -436,9 +450,11 @@ const PROP_CATEGORIES: {[key:string]: (props: {[key: string]: any}) => string} =
|
|
|
436
450
|
if (typeof zIndexEntry[1] == "number") {
|
|
437
451
|
css += `z_index_${zIndexEntry[1]} `
|
|
438
452
|
} else if (typeof zIndexEntry[1] == "object") {
|
|
439
|
-
|
|
440
|
-
|
|
453
|
+
const responsiveObj: {[key: string]: string} = {}
|
|
454
|
+
Object.entries(zIndexEntry[1]).forEach(([key, value]) => {
|
|
455
|
+
responsiveObj[key] = value.toString()
|
|
441
456
|
})
|
|
457
|
+
css += getResponsivePropClasses(responsiveObj, 'z_index')
|
|
442
458
|
} else if (zIndexEntry[1] === 'max') {
|
|
443
459
|
css += `z_index_max `
|
|
444
460
|
}
|
|
@@ -463,9 +479,11 @@ const PROP_CATEGORIES: {[key:string]: (props: {[key: string]: any}) => string} =
|
|
|
463
479
|
if (typeof displayEntry[1] == "string") {
|
|
464
480
|
css += `display_${displayEntry[1]} `
|
|
465
481
|
} else if (typeof displayEntry[1] == "object") {
|
|
466
|
-
|
|
467
|
-
|
|
482
|
+
const responsiveObj: {[key: string]: string} = {}
|
|
483
|
+
Object.entries(displayEntry[1]).forEach(([key, value]) => {
|
|
484
|
+
responsiveObj[key] = typeof value === 'string' ? value : value.toString()
|
|
468
485
|
})
|
|
486
|
+
css += getResponsivePropClasses(responsiveObj, 'display')
|
|
469
487
|
} else {
|
|
470
488
|
' '
|
|
471
489
|
}
|
|
@@ -35,3 +35,21 @@ test('Global Props: returns proper class name', () => {
|
|
|
35
35
|
})
|
|
36
36
|
}
|
|
37
37
|
})
|
|
38
|
+
|
|
39
|
+
test('Global Props: returns proper class name with default key', () => {
|
|
40
|
+
const testId = `${testSubject}-default-responsive`
|
|
41
|
+
render(
|
|
42
|
+
<Body
|
|
43
|
+
alignContent={{ default: "spaceAround", xs: "center", sm: "spaceAround", md: "center" }}
|
|
44
|
+
data={{ testid: testId }}
|
|
45
|
+
text="Hi"
|
|
46
|
+
/>
|
|
47
|
+
)
|
|
48
|
+
const kit = screen.getByTestId(testId)
|
|
49
|
+
// Should have base class for default value
|
|
50
|
+
expect(kit).toHaveClass(`align_content_space_around`)
|
|
51
|
+
// Should have responsive classes for screen sizes
|
|
52
|
+
expect(kit).toHaveClass(`align_content_xs_center`)
|
|
53
|
+
expect(kit).toHaveClass(`align_content_sm_space_around`)
|
|
54
|
+
expect(kit).toHaveClass(`align_content_md_center`)
|
|
55
|
+
})
|