playbook_ui 14.16.0.pre.alpha.play1881removelodash6986 → 14.16.0.pre.alpha.play1957inlinedatepickericonbugfix6872
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/_advanced_table.tsx +84 -86
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_pagination.jsx +1 -0
- data/app/pb_kits/playbook/pb_button/_button.scss +5 -5
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete.jsx +6 -6
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_and_custom_display.jsx +6 -6
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.jsx +6 -6
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display_rails.html.erb +8 -8
- data/app/pb_kits/playbook/pb_filter/Filter/CurrentFilters.tsx +4 -3
- data/app/pb_kits/playbook/pb_filter/Filter/SortMenu.tsx +3 -2
- data/app/pb_kits/playbook/pb_form/pb_form_validation.js +1 -1
- data/app/pb_kits/playbook/pb_lightbox/hooks/useVisibility.js +1 -1
- data/app/pb_kits/playbook/pb_multi_level_select/_multi_level_select.tsx +1 -2
- data/app/pb_kits/playbook/pb_rich_text_editor/_rich_text_editor.tsx +11 -29
- data/app/pb_kits/playbook/pb_rich_text_editor/docs/_rich_text_editor_default.html.erb +1 -1
- data/app/pb_kits/playbook/pb_rich_text_editor/rich_text_editor.html.erb +4 -4
- data/app/pb_kits/playbook/pb_rich_text_editor/rich_text_editor.rb +0 -2
- data/app/pb_kits/playbook/pb_table/_table.tsx +0 -4
- data/app/pb_kits/playbook/pb_table/docs/example.yml +0 -2
- data/app/pb_kits/playbook/pb_table/docs/index.js +0 -2
- data/app/pb_kits/playbook/pb_table/styles/_headers.scss +0 -76
- data/app/pb_kits/playbook/pb_table/styles/_striped.scss +3 -3
- data/app/pb_kits/playbook/pb_table/subcomponents/_table_head.tsx +1 -11
- data/app/pb_kits/playbook/pb_table/subcomponents/_table_header.tsx +1 -11
- data/app/pb_kits/playbook/pb_table/subcomponents/_table_row.tsx +0 -5
- data/app/pb_kits/playbook/pb_table/table.test.js +0 -17
- data/app/pb_kits/playbook/pb_tooltip/floating_ui.js +282 -0
- data/app/pb_kits/playbook/pb_tooltip/index.js +56 -183
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_highlight.jsx +4 -4
- data/app/pb_kits/playbook/pb_typeahead/index.ts +2 -2
- data/app/pb_kits/playbook/utilities/globalProps.ts +1 -1
- data/app/pb_kits/playbook/utilities/object.test.js +1 -149
- data/app/pb_kits/playbook/utilities/object.ts +42 -124
- data/dist/chunks/_typeahead-BniHPQq8.js +22 -0
- data/dist/chunks/_weekday_stacked-CuaFaMk8.js +45 -0
- data/dist/chunks/lib-UIelzz2O.js +29 -0
- data/dist/chunks/{pb_form_validation-BvNy9Bd6.js → pb_form_validation-EUv1tqtI.js} +1 -1
- data/dist/chunks/vendor.js +1 -1
- data/dist/playbook-doc.js +1 -1
- 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 +7 -10
- data/app/pb_kits/playbook/pb_table/docs/_table_with_header_style_borderless.jsx +0 -50
- data/app/pb_kits/playbook/pb_table/docs/_table_with_header_style_borderless_react.md +0 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_with_header_style_floating.jsx +0 -59
- data/app/pb_kits/playbook/pb_table/docs/_table_with_header_style_floating_react.md +0 -1
- data/dist/chunks/_typeahead-Djo6qCne.js +0 -22
- data/dist/chunks/_weekday_stacked-DIIHW0OV.js +0 -45
- data/dist/chunks/lib-BGzBzFZX.js +0 -29
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 6ac4260b02869cad3eaa3d0c49e523d9f4a4463cfccf98858f504172eaf1d601
|
4
|
+
data.tar.gz: 1f91664b626b1362cf6b61ebf15ae1681830e96a3fb6d2bcd8601a2c50ea4a7a
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 1176546d1665cfe26fa78e48ad632470539f9b5bef9be47c28f60b238901c6237e236b413d09856ecde5d8f1166b3f9cc22e0c45e3e1d96c170b68d28dc2eeef
|
7
|
+
data.tar.gz: 327c8ebe3c86777bffeb9af8b56ba1ab2ff2033b2245d728170ae3d86a164881abd90a0bbf691a01bce8c000a2bef515609e3c463313a4869ec36915e9e396c7
|
@@ -167,95 +167,93 @@ const AdvancedTable = (props: AdvancedTableProps) => {
|
|
167
167
|
const isActionBarVisible = selectableRows && showActionsBar && selectedRowsLength > 0;
|
168
168
|
|
169
169
|
return (
|
170
|
-
|
171
|
-
|
172
|
-
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
|
180
|
-
|
181
|
-
|
182
|
-
|
183
|
-
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
|
189
|
-
|
190
|
-
|
191
|
-
|
192
|
-
|
193
|
-
|
194
|
-
|
195
|
-
|
170
|
+
<div
|
171
|
+
{...ariaProps}
|
172
|
+
{...dataProps}
|
173
|
+
{...htmlProps}
|
174
|
+
className={classes}
|
175
|
+
id={id}
|
176
|
+
onScroll={virtualizedRows ? e => fetchMoreOnBottomReached(
|
177
|
+
e.currentTarget,
|
178
|
+
fetchNextPage,
|
179
|
+
isFetching,
|
180
|
+
totalFetched,
|
181
|
+
fullData.length
|
182
|
+
) : undefined}
|
183
|
+
ref={tableWrapperRef}
|
184
|
+
style={tableWrapperStyle as React.CSSProperties}
|
185
|
+
>
|
186
|
+
<AdvancedTableProvider
|
187
|
+
columnDefinitions={columnDefinitions}
|
188
|
+
enableToggleExpansion={enableToggleExpansion}
|
189
|
+
enableVirtualization={virtualizedRows}
|
190
|
+
expanded={expanded}
|
191
|
+
expandedControl={expandedControl}
|
192
|
+
handleExpandOrCollapse={handleExpandOrCollapse}
|
193
|
+
hasAnySubRows={hasAnySubRows}
|
194
|
+
inlineRowLoading={inlineRowLoading}
|
195
|
+
isActionBarVisible={isActionBarVisible}
|
196
|
+
loading={loading}
|
197
|
+
responsive={responsive}
|
198
|
+
selectableRows={selectableRows}
|
199
|
+
setExpanded={setExpanded}
|
200
|
+
showActionsBar={showActionsBar}
|
201
|
+
sortControl={sortControl}
|
202
|
+
subRowHeaders={tableOptions?.subRowHeaders}
|
203
|
+
table={table}
|
204
|
+
tableContainerRef={tableWrapperRef}
|
205
|
+
toggleExpansionIcon={toggleExpansionIcon}
|
206
|
+
virtualizedRows={virtualizedRows}
|
196
207
|
>
|
197
|
-
<
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
|
204
|
-
|
205
|
-
inlineRowLoading={inlineRowLoading}
|
206
|
-
isActionBarVisible={isActionBarVisible}
|
207
|
-
loading={loading}
|
208
|
-
responsive={responsive}
|
209
|
-
selectableRows={selectableRows}
|
210
|
-
setExpanded={setExpanded}
|
211
|
-
showActionsBar={showActionsBar}
|
212
|
-
sortControl={sortControl}
|
213
|
-
subRowHeaders={tableOptions?.subRowHeaders}
|
214
|
-
table={table}
|
215
|
-
tableContainerRef={tableWrapperRef}
|
216
|
-
toggleExpansionIcon={toggleExpansionIcon}
|
217
|
-
virtualizedRows={virtualizedRows}
|
218
|
-
>
|
219
|
-
<React.Fragment>
|
220
|
-
{/* Selection Action Bar */}
|
221
|
-
<TableActionBar
|
222
|
-
actions={actions}
|
223
|
-
isVisible={isActionBarVisible}
|
224
|
-
selectedCount={selectedRowsLength}
|
208
|
+
<React.Fragment>
|
209
|
+
{/* Top Pagination */}
|
210
|
+
{pagination && (
|
211
|
+
<TablePagination
|
212
|
+
onChange={onPageChange}
|
213
|
+
position="top"
|
214
|
+
range={paginationProps?.range}
|
215
|
+
table={table}
|
225
216
|
/>
|
217
|
+
)}
|
218
|
+
|
219
|
+
{/* Selection Action Bar */}
|
220
|
+
<TableActionBar
|
221
|
+
actions={actions}
|
222
|
+
isVisible={isActionBarVisible}
|
223
|
+
selectedCount={selectedRowsLength}
|
224
|
+
/>
|
226
225
|
|
227
|
-
|
228
|
-
|
229
|
-
|
230
|
-
|
231
|
-
|
232
|
-
|
233
|
-
|
234
|
-
|
235
|
-
|
236
|
-
|
237
|
-
|
238
|
-
|
239
|
-
|
240
|
-
|
241
|
-
|
242
|
-
|
243
|
-
|
244
|
-
|
245
|
-
|
246
|
-
|
247
|
-
|
248
|
-
|
249
|
-
|
250
|
-
|
251
|
-
|
252
|
-
|
253
|
-
|
254
|
-
|
255
|
-
|
256
|
-
|
257
|
-
|
258
|
-
</>
|
226
|
+
{/* Main Table */}
|
227
|
+
<Table
|
228
|
+
className={`${loading ? "content-loading" : ""}`}
|
229
|
+
dark={dark}
|
230
|
+
dataTable
|
231
|
+
numberSpacing="tabular"
|
232
|
+
responsive="none"
|
233
|
+
{...tableProps}
|
234
|
+
>
|
235
|
+
{children ? (
|
236
|
+
children
|
237
|
+
) : (
|
238
|
+
<>
|
239
|
+
<TableHeader />
|
240
|
+
<TableBody />
|
241
|
+
</>
|
242
|
+
)}
|
243
|
+
</Table>
|
244
|
+
|
245
|
+
{/* Bottom Pagination */}
|
246
|
+
{pagination && (
|
247
|
+
<TablePagination
|
248
|
+
onChange={onPageChange}
|
249
|
+
position="bottom"
|
250
|
+
range={paginationProps?.range}
|
251
|
+
table={table}
|
252
|
+
/>
|
253
|
+
)}
|
254
|
+
</React.Fragment>
|
255
|
+
</AdvancedTableProvider>
|
256
|
+
</div>
|
259
257
|
);
|
260
258
|
};
|
261
259
|
|
@@ -63,6 +63,11 @@ $pb_button_sizes: (
|
|
63
63
|
color: $text_lt_lighter;
|
64
64
|
}
|
65
65
|
|
66
|
+
// Disabled =================
|
67
|
+
&[class*=_disabled] {
|
68
|
+
@include pb_button_disabled;
|
69
|
+
}
|
70
|
+
|
66
71
|
// Block ====================
|
67
72
|
&[class*=_block] {
|
68
73
|
@include pb_button_block;
|
@@ -78,11 +83,6 @@ $pb_button_sizes: (
|
|
78
83
|
@include pb_button_danger;
|
79
84
|
}
|
80
85
|
|
81
|
-
// Disabled =================
|
82
|
-
&[class*=_disabled] {
|
83
|
-
@include pb_button_disabled;
|
84
|
-
}
|
85
|
-
|
86
86
|
// Dark Variants =============
|
87
87
|
&.dark {
|
88
88
|
&[class*=_primary] {
|
@@ -12,7 +12,7 @@ const DropdownWithAutocomplete = (props) => {
|
|
12
12
|
label: "Jasper Furniss",
|
13
13
|
value: "Jasper Furniss",
|
14
14
|
territory: "PHL",
|
15
|
-
title: "
|
15
|
+
title: "Senior UX Engineer",
|
16
16
|
id: "jasper-furniss",
|
17
17
|
status: "Offline"
|
18
18
|
},
|
@@ -25,18 +25,18 @@ const DropdownWithAutocomplete = (props) => {
|
|
25
25
|
status: "Away"
|
26
26
|
},
|
27
27
|
{
|
28
|
-
label: "
|
29
|
-
value: "
|
28
|
+
label: "Jason Cypret",
|
29
|
+
value: "Jason Cypret",
|
30
30
|
territory: "PHL",
|
31
|
-
title: "
|
32
|
-
id: "
|
31
|
+
title: "VP of User Experience",
|
32
|
+
id: "jason-cypret",
|
33
33
|
status: "Online"
|
34
34
|
},
|
35
35
|
{
|
36
36
|
label: "Courtney Long",
|
37
37
|
value: "Courtney Long",
|
38
38
|
territory: "PHL",
|
39
|
-
title: "
|
39
|
+
title: "UX Design Mentor",
|
40
40
|
id: "courtney-long",
|
41
41
|
status: "Online"
|
42
42
|
}
|
data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_and_custom_display.jsx
CHANGED
@@ -15,7 +15,7 @@ const DropdownWithAutocompleteAndCustomDisplay = (props) => {
|
|
15
15
|
label: "Jasper Furniss",
|
16
16
|
value: "Jasper Furniss",
|
17
17
|
territory: "PHL",
|
18
|
-
title: "
|
18
|
+
title: "Senior UX Engineer",
|
19
19
|
id: "jasper-furniss",
|
20
20
|
status: "Offline"
|
21
21
|
},
|
@@ -28,18 +28,18 @@ const DropdownWithAutocompleteAndCustomDisplay = (props) => {
|
|
28
28
|
status: "Away"
|
29
29
|
},
|
30
30
|
{
|
31
|
-
label: "
|
32
|
-
value: "
|
31
|
+
label: "Jason Cypret",
|
32
|
+
value: "Jason Cypret",
|
33
33
|
territory: "PHL",
|
34
|
-
title: "
|
35
|
-
id: "
|
34
|
+
title: "VP of User Experience",
|
35
|
+
id: "jason-cypret",
|
36
36
|
status: "Online"
|
37
37
|
},
|
38
38
|
{
|
39
39
|
label: "Courtney Long",
|
40
40
|
value: "Courtney Long",
|
41
41
|
territory: "PHL",
|
42
|
-
title: "
|
42
|
+
title: "UX Design Mentor",
|
43
43
|
id: "courtney-long",
|
44
44
|
status: "Online"
|
45
45
|
}
|
@@ -15,7 +15,7 @@ const DropdownWithCustomDisplay = (props) => {
|
|
15
15
|
label: "Jasper Furniss",
|
16
16
|
value: "Jasper Furniss",
|
17
17
|
territory: "PHL",
|
18
|
-
title: "
|
18
|
+
title: "Senior UX Engineer",
|
19
19
|
id: "jasper-furniss",
|
20
20
|
status: "Offline"
|
21
21
|
},
|
@@ -28,18 +28,18 @@ const DropdownWithCustomDisplay = (props) => {
|
|
28
28
|
status: "Away"
|
29
29
|
},
|
30
30
|
{
|
31
|
-
label: "
|
32
|
-
value: "
|
31
|
+
label: "Jason Cypret",
|
32
|
+
value: "Jason Cypret",
|
33
33
|
territory: "PHL",
|
34
|
-
title: "
|
35
|
-
id: "
|
34
|
+
title: "VP of User Experience",
|
35
|
+
id: "jason-cypret",
|
36
36
|
status: "Online"
|
37
37
|
},
|
38
38
|
{
|
39
39
|
label: "Courtney Long",
|
40
40
|
value: "Courtney Long",
|
41
41
|
territory: "PHL",
|
42
|
-
title: "
|
42
|
+
title: "UX Design Mentor",
|
43
43
|
id: "courtney-long",
|
44
44
|
status: "Online"
|
45
45
|
}
|
@@ -1,10 +1,10 @@
|
|
1
1
|
<%
|
2
|
-
|
2
|
+
options = [
|
3
3
|
{
|
4
4
|
label: "Jasper Furniss",
|
5
5
|
value: "Jasper Furniss",
|
6
6
|
territory: "PHL",
|
7
|
-
title: "
|
7
|
+
title: "Senior UX Engineer",
|
8
8
|
id: "jasper-furniss",
|
9
9
|
status: "Offline"
|
10
10
|
},
|
@@ -17,22 +17,22 @@
|
|
17
17
|
status: "Away"
|
18
18
|
},
|
19
19
|
{
|
20
|
-
label: "
|
21
|
-
value: "
|
20
|
+
label: "Jason Cypret",
|
21
|
+
value: "Jason Cypret",
|
22
22
|
territory: "PHL",
|
23
|
-
title: "
|
24
|
-
id: "
|
23
|
+
title: "VP of User Experience",
|
24
|
+
id: "jason-cypret",
|
25
25
|
status: "Online"
|
26
26
|
},
|
27
27
|
{
|
28
28
|
label: "Courtney Long",
|
29
29
|
value: "Courtney Long",
|
30
30
|
territory: "PHL",
|
31
|
-
title: "
|
31
|
+
title: "UX Design Mentor",
|
32
32
|
id: "courtney-long",
|
33
33
|
status: "Online"
|
34
34
|
}
|
35
|
-
]
|
35
|
+
]
|
36
36
|
|
37
37
|
%>
|
38
38
|
|
@@ -1,5 +1,6 @@
|
|
1
1
|
import React from 'react'
|
2
|
-
import {
|
2
|
+
import { map } from 'lodash'
|
3
|
+
import { isEmpty, omitBy } from '../../utilities/object'
|
3
4
|
|
4
5
|
import Body from '../../pb_body/_body'
|
5
6
|
import Caption from '../../pb_caption/_caption'
|
@@ -45,12 +46,12 @@ const CurrentFilters = ({ dark, filters }: CurrentFiltersProps): React.ReactElem
|
|
45
46
|
dark={dark}
|
46
47
|
size={4}
|
47
48
|
tag="h4"
|
48
|
-
text={
|
49
|
+
text={name}
|
49
50
|
/> :
|
50
51
|
<div>
|
51
52
|
<Caption
|
52
53
|
dark={dark}
|
53
|
-
text={
|
54
|
+
text={name}
|
54
55
|
/>
|
55
56
|
<Title
|
56
57
|
dark={dark}
|
@@ -1,5 +1,6 @@
|
|
1
1
|
import React, { useState } from 'react'
|
2
|
-
import {
|
2
|
+
import { map } from 'lodash'
|
3
|
+
import { find, partial } from '../../utilities/object'
|
3
4
|
|
4
5
|
import Button from '../../pb_button/_button'
|
5
6
|
import Icon from '../../pb_icon/_icon'
|
@@ -26,7 +27,7 @@ const directionIcon = (dir: Direction) => (
|
|
26
27
|
|
27
28
|
const renderOptions = (options: SortOptions, value: SortValue[], handleChange: (arg0: SortValue) => void) => (
|
28
29
|
map(options, (label, name) => {
|
29
|
-
const next = nextValue(value,
|
30
|
+
const next = nextValue(value, name)
|
30
31
|
return (
|
31
32
|
<ListItem key={`option-${next.name}-${next.dir}`}>
|
32
33
|
<Button
|
@@ -7,12 +7,11 @@ import {
|
|
7
7
|
buildDataProps,
|
8
8
|
buildHtmlProps,
|
9
9
|
} from "../utilities/props";
|
10
|
-
import { cloneDeep } from "../utilities/object";
|
11
|
-
|
12
10
|
import Icon from "../pb_icon/_icon";
|
13
11
|
import FormPill from "../pb_form_pill/_form_pill";
|
14
12
|
import Body from "../pb_body/_body";
|
15
13
|
import Caption from "../pb_caption/_caption";
|
14
|
+
import { cloneDeep } from "lodash";
|
16
15
|
import MultiLevelSelectOptions from "./multi_level_select_options";
|
17
16
|
import MultiLevelSelectContext from "./context";
|
18
17
|
|
@@ -32,12 +32,11 @@ type RichTextEditorProps = {
|
|
32
32
|
advancedEditor?: any,
|
33
33
|
advancedEditorToolbar?: boolean,
|
34
34
|
toolbarBottom?: boolean,
|
35
|
-
children?: React.ReactNode | React.ReactNode[]
|
35
|
+
children?: React.ReactNode | React.ReactNode[]
|
36
36
|
className?: string,
|
37
37
|
data?: { [key: string]: string },
|
38
38
|
focus?: boolean,
|
39
|
-
htmlOptions?: {
|
40
|
-
inputOptions?: { [key: string]: string | number | boolean | (() => void) },
|
39
|
+
htmlOptions?: {[key: string]: string | number | boolean | (() => void)},
|
41
40
|
id?: string,
|
42
41
|
inline?: boolean,
|
43
42
|
extensions?: { [key: string]: string }[],
|
@@ -62,7 +61,6 @@ const RichTextEditor = (props: RichTextEditorProps): React.ReactElement => {
|
|
62
61
|
data = {},
|
63
62
|
focus = false,
|
64
63
|
htmlOptions = {},
|
65
|
-
inputOptions = {},
|
66
64
|
inline = false,
|
67
65
|
extensions,
|
68
66
|
name,
|
@@ -72,7 +70,7 @@ const RichTextEditor = (props: RichTextEditorProps): React.ReactElement => {
|
|
72
70
|
sticky = false,
|
73
71
|
template = '',
|
74
72
|
value = '',
|
75
|
-
maxWidth
|
73
|
+
maxWidth="md"
|
76
74
|
} = props
|
77
75
|
|
78
76
|
const ariaProps = buildAriaProps(aria),
|
@@ -81,28 +79,12 @@ const RichTextEditor = (props: RichTextEditorProps): React.ReactElement => {
|
|
81
79
|
|
82
80
|
const htmlProps = buildHtmlProps(htmlOptions)
|
83
81
|
|
84
|
-
const handleOnEditorReady = (editorInstance: Editor) =>
|
85
|
-
|
86
|
-
setTimeout(() => {
|
87
|
-
const oldId = editorInstance.element.getAttribute('input')
|
88
|
-
if (oldId) {
|
89
|
-
const hiddenInput = document.getElementById(oldId)
|
90
|
-
if (hiddenInput) {
|
91
|
-
const newId = (inputOptions.id as string) || oldId
|
92
|
-
hiddenInput.id = newId
|
93
|
-
editorInstance.element.setAttribute('input', newId)
|
94
|
-
|
95
|
-
if (inputOptions.name) {
|
96
|
-
hiddenInput.setAttribute('name', inputOptions.name as string)
|
97
|
-
}
|
98
|
-
}
|
99
|
-
}
|
100
|
-
})
|
101
|
-
}
|
82
|
+
const handleOnEditorReady = (editorInstance: Editor) => setEditor(editorInstance),
|
83
|
+
element = editor?.element
|
102
84
|
|
103
85
|
// DOM manipulation must wait for editor to be ready
|
104
|
-
if (editor
|
105
|
-
const toolbarElement =
|
86
|
+
if (editor) {
|
87
|
+
const toolbarElement = element.parentElement.querySelector('trix-toolbar') as HTMLElement,
|
106
88
|
blockCodeButton = toolbarElement.querySelector('[data-trix-attribute=code]') as HTMLElement
|
107
89
|
|
108
90
|
// replace default trix "block code" button with "inline code" button
|
@@ -136,8 +118,8 @@ const RichTextEditor = (props: RichTextEditorProps): React.ReactElement => {
|
|
136
118
|
}, [editor, template])
|
137
119
|
|
138
120
|
useEffect(() => {
|
139
|
-
if (!
|
140
|
-
|
121
|
+
if (!element) return
|
122
|
+
element.addEventListener('click', ({ target }: Event) => {
|
141
123
|
const trixEditorContainer = (target as Element).closest('.pb_rich_text_editor_kit')
|
142
124
|
if (!trixEditorContainer) return
|
143
125
|
|
@@ -146,7 +128,7 @@ const RichTextEditor = (props: RichTextEditorProps): React.ReactElement => {
|
|
146
128
|
|
147
129
|
if (anchorElement.hasAttribute('href')) window.open(anchorElement.href)
|
148
130
|
})
|
149
|
-
}, [
|
131
|
+
}, [element])
|
150
132
|
|
151
133
|
const richTextEditorClass = 'pb_rich_text_editor_kit',
|
152
134
|
simpleClass = simple ? 'simple' : '',
|
@@ -155,7 +137,7 @@ const RichTextEditor = (props: RichTextEditorProps): React.ReactElement => {
|
|
155
137
|
inlineClass = inline ? 'inline' : '',
|
156
138
|
toolbarBottomClass = toolbarBottom ? 'toolbar-bottom' : ''
|
157
139
|
|
158
|
-
let css = classnames(globalProps(props, {
|
140
|
+
let css = classnames(globalProps(props, {maxWidth}), className)
|
159
141
|
css = classnames(
|
160
142
|
richTextEditorClass,
|
161
143
|
simpleClass,
|
@@ -1 +1 @@
|
|
1
|
-
<%= pb_rails("rich_text_editor", props: {
|
1
|
+
<%= pb_rails("rich_text_editor", props: {id: "default", value: "Add your text here. You can format your text, add links, quotes, and bullets."}) %>
|
@@ -1,5 +1,5 @@
|
|
1
1
|
<%= react_component('RichTextEditor',
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
2
|
+
object.rich_text_options,
|
3
|
+
aria: object.aria,
|
4
|
+
data: object.data
|
5
|
+
) %>
|
@@ -20,7 +20,6 @@ module Playbook
|
|
20
20
|
prop :value
|
21
21
|
prop :template
|
22
22
|
prop :placeholder
|
23
|
-
prop :input_options
|
24
23
|
|
25
24
|
def classname
|
26
25
|
generate_classname("pb_rich_text_editor_kit", simple_class, focus_class, sticky_class, separator: " ")
|
@@ -50,7 +49,6 @@ module Playbook
|
|
50
49
|
value: value,
|
51
50
|
template: template,
|
52
51
|
placeholder: placeholder,
|
53
|
-
inputOptions: input_options,
|
54
52
|
}
|
55
53
|
end
|
56
54
|
end
|
@@ -21,7 +21,6 @@ type TableProps = {
|
|
21
21
|
data?: { [key: string]: string },
|
22
22
|
dataTable: boolean,
|
23
23
|
disableHover?: boolean,
|
24
|
-
headerStyle?: "default" | "borderless" | "floating"
|
25
24
|
htmlOptions?: { [key: string]: string | number | boolean | (() => void) },
|
26
25
|
id?: string,
|
27
26
|
outerPadding?: "none" | "xxs" | "xs" | "sm" | "md" | "lg" | "xl",
|
@@ -47,7 +46,6 @@ const Table = (props: TableProps): React.ReactElement => {
|
|
47
46
|
data = {},
|
48
47
|
dataTable = false,
|
49
48
|
disableHover = false,
|
50
|
-
headerStyle = "default",
|
51
49
|
htmlOptions = {},
|
52
50
|
id,
|
53
51
|
outerPadding = '',
|
@@ -87,8 +85,6 @@ const Table = (props: TableProps): React.ReactElement => {
|
|
87
85
|
'sticky-left-column': stickyLeftColumn,
|
88
86
|
'sticky-right-column': stickyRightColumn,
|
89
87
|
'striped': striped,
|
90
|
-
'header-borderless': headerStyle === 'borderless',
|
91
|
-
'header-floating': headerStyle === 'floating',
|
92
88
|
[outerPaddingCss]: outerPadding !== '',
|
93
89
|
},
|
94
90
|
globalProps(props),
|
@@ -75,5 +75,3 @@ examples:
|
|
75
75
|
- table_with_collapsible_with_nested_table: Table with Collapsible with Nested Table
|
76
76
|
- table_with_clickable_rows: Table with Clickable Rows
|
77
77
|
- table_with_selectable_rows: Table with Selectable Rows
|
78
|
-
- table_with_header_style_borderless: Header Style Borderless
|
79
|
-
- table_with_header_style_floating: Header Style Floating
|
@@ -35,5 +35,3 @@ export { default as TableWithCollapsibleWithNestedRows } from './_table_with_col
|
|
35
35
|
export { default as TableWithCollapsibleWithCustomClick } from './_table_with_collapsible_with_custom_click.jsx'
|
36
36
|
export { default as TableWithSelectableRows } from './_table_with_selectable_rows.jsx'
|
37
37
|
export { default as TableWithClickableRows } from './_table_with_clickable_rows.jsx'
|
38
|
-
export { default as TableWithHeaderStyleBorderless } from './_table_with_header_style_borderless.jsx'
|
39
|
-
export { default as TableWithHeaderStyleFloating } from './_table_with_header_style_floating.jsx'
|