playbook_ui 14.14.0.pre.alpha.PBNTR866finalizecssendlessscroll6486 → 14.14.0.pre.alpha.PBNTR888selectvaliditymessage6348
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/Context/AdvancedTableContext.tsx +3 -143
- data/app/pb_kits/playbook/pb_advanced_table/SubKits/TableBody.tsx +99 -45
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +7 -123
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +299 -153
- data/app/pb_kits/playbook/pb_drawer/_drawer.scss +8 -32
- data/app/pb_kits/playbook/pb_drawer/docs/_drawer_default.html.erb +1 -20
- data/app/pb_kits/playbook/pb_drawer/docs/example.yml +0 -5
- data/app/pb_kits/playbook/pb_drawer/drawer.html.erb +12 -20
- data/app/pb_kits/playbook/pb_drawer/drawer.rb +1 -49
- data/app/pb_kits/playbook/pb_overlay/_overlay.scss +0 -13
- data/app/pb_kits/playbook/pb_overlay/_overlay.tsx +1 -7
- data/app/pb_kits/playbook/pb_overlay/docs/example.yml +0 -3
- data/app/pb_kits/playbook/pb_overlay/docs/index.js +0 -1
- data/app/pb_kits/playbook/pb_overlay/overlay.html.erb +3 -5
- data/app/pb_kits/playbook/pb_overlay/overlay.rb +1 -16
- data/app/pb_kits/playbook/pb_overlay/overlay.test.jsx +0 -12
- data/app/pb_kits/playbook/pb_tooltip/_tooltip.scss +3 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/example.yml +0 -2
- data/app/pb_kits/playbook/pb_tooltip/index.js +1 -1
- data/app/pb_kits/playbook/pb_tooltip/tooltip.rb +2 -10
- data/app/pb_kits/playbook/pb_typeahead/_typeahead.tsx +1 -34
- data/app/pb_kits/playbook/pb_typeahead/docs/example.yml +0 -2
- data/app/pb_kits/playbook/pb_typeahead/index.ts +8 -61
- data/app/pb_kits/playbook/pb_typeahead/typeahead.rb +1 -13
- data/dist/chunks/_typeahead-PqkcDf1H.js +36 -0
- data/dist/chunks/_weekday_stacked-BrSrpj7J.js +45 -0
- data/dist/chunks/{lib-Dmay5Z6U.js → lib-D3us1bGD.js} +1 -1
- data/dist/chunks/{pb_form_validation-DdP7BnVX.js → pb_form_validation-BpihMSOQ.js} +1 -1
- data/dist/chunks/vendor.js +1 -1
- data/dist/menu.yml +2 -2
- 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 +6 -40
- data/app/pb_kits/playbook/pb_advanced_table/Components/RegularTableView.tsx +0 -127
- data/app/pb_kits/playbook/pb_advanced_table/Components/TableActionBar.tsx +0 -55
- data/app/pb_kits/playbook/pb_advanced_table/Components/TablePagination.tsx +0 -33
- data/app/pb_kits/playbook/pb_advanced_table/Components/VirtualizedTableView.tsx +0 -275
- data/app/pb_kits/playbook/pb_advanced_table/Hooks/useTableActions.ts +0 -66
- data/app/pb_kits/playbook/pb_advanced_table/Hooks/useTableState.ts +0 -195
- data/app/pb_kits/playbook/pb_advanced_table/Utilities/CellRendererUtils.tsx +0 -73
- data/app/pb_kits/playbook/pb_advanced_table/Utilities/RowUtils.ts +0 -52
- data/app/pb_kits/playbook/pb_advanced_table/Utilities/TableContainerStyles.ts +0 -80
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_infinite_scroll.jsx +0 -50
- data/app/pb_kits/playbook/pb_advanced_table/docs/advanced_table_mock_data_infinite_scroll.json +0 -152002
- data/app/pb_kits/playbook/pb_drawer/docs/_drawer_behavior.html.erb +0 -8
- data/app/pb_kits/playbook/pb_drawer/docs/_drawer_borders.html.erb +0 -33
- data/app/pb_kits/playbook/pb_drawer/docs/_drawer_breakpoints.html.erb +0 -0
- data/app/pb_kits/playbook/pb_drawer/docs/_drawer_menu.html.erb +0 -24
- data/app/pb_kits/playbook/pb_drawer/docs/_drawer_overlay.html.erb +0 -21
- data/app/pb_kits/playbook/pb_drawer/docs/_drawer_overlay.md +0 -1
- data/app/pb_kits/playbook/pb_drawer/docs/_drawer_sizes.html.erb +0 -49
- data/app/pb_kits/playbook/pb_drawer/index.js +0 -257
- data/app/pb_kits/playbook/pb_overlay/docs/_overlay_hide_scroll_bar.html.erb +0 -11
- data/app/pb_kits/playbook/pb_overlay/docs/_overlay_hide_scroll_bar.jsx +0 -37
- data/app/pb_kits/playbook/pb_overlay/docs/_overlay_hide_scroll_bar_rails.md +0 -1
- data/app/pb_kits/playbook/pb_overlay/docs/_overlay_hide_scroll_bar_react.md +0 -1
- data/app/pb_kits/playbook/pb_overlay/docs/_overlay_vertical_dynamic_multi_directional.html.erb +0 -11
- data/app/pb_kits/playbook/pb_overlay/docs/_overlay_vertical_dynamic_multi_directional.md +0 -1
- data/app/pb_kits/playbook/pb_overlay/index.js +0 -61
- data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_delay_rails.html.erb +0 -39
- data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_delay_rails.md +0 -3
- data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_interaction.html.erb +0 -26
- data/app/pb_kits/playbook/pb_tooltip/floating_ui.js +0 -282
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_dynamic_options.html.erb +0 -45
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_dynamic_options.md +0 -5
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_dynamic_options_pure_rails.html.erb +0 -33
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_dynamic_options_pure_rails.md +0 -3
- data/dist/chunks/_typeahead-BBL6ThPp.js +0 -36
- data/dist/chunks/_weekday_stacked-CF_V6Rbs.js +0 -45
@@ -1,23 +1,38 @@
|
|
1
|
-
import React, {
|
2
|
-
import classnames from "classnames"
|
1
|
+
import React, { useState, useEffect, useCallback, useRef } from "react"
|
2
|
+
import classnames from "classnames"
|
3
3
|
|
4
|
-
import { GenericObject } from "../types"
|
5
|
-
import { Row, RowSelectionState } from "@tanstack/react-table";
|
4
|
+
import { GenericObject } from "../types"
|
6
5
|
|
7
|
-
import {
|
8
|
-
|
6
|
+
import {
|
7
|
+
createColumnHelper,
|
8
|
+
getCoreRowModel,
|
9
|
+
getExpandedRowModel,
|
10
|
+
getPaginationRowModel,
|
11
|
+
getSortedRowModel,
|
12
|
+
Row,
|
13
|
+
useReactTable,
|
14
|
+
Getter,
|
15
|
+
RowSelectionState
|
16
|
+
} from "@tanstack/react-table"
|
9
17
|
|
10
|
-
import
|
11
|
-
import {
|
12
|
-
import { getVirtualizedContainerStyles } from "./Utilities/TableContainerStyles";
|
18
|
+
import { buildAriaProps, buildCss, buildDataProps, buildHtmlProps } from "../utilities/props"
|
19
|
+
import { globalProps, GlobalProps } from "../utilities/globalProps"
|
13
20
|
|
14
|
-
import
|
15
|
-
import
|
16
|
-
import
|
17
|
-
import
|
21
|
+
import Table from "../pb_table/_table"
|
22
|
+
import Card from "../pb_card/_card"
|
23
|
+
import Caption from "../pb_caption/_caption"
|
24
|
+
import Flex from "../pb_flex/_flex"
|
25
|
+
import FlexItem from "../pb_flex/_flex_item"
|
18
26
|
|
19
|
-
import
|
20
|
-
|
27
|
+
import AdvancedTableContext from "./Context/AdvancedTableContext"
|
28
|
+
|
29
|
+
import { updateExpandAndCollapseState } from "./Utilities/ExpansionControlHelpers"
|
30
|
+
import { showActionBar, hideActionBar } from "./Utilities/ActionBarAnimationHelper"
|
31
|
+
|
32
|
+
import { CustomCell } from "./Components/CustomCell"
|
33
|
+
import { TableHeader } from "./SubKits/TableHeader"
|
34
|
+
import { TableBody } from "./SubKits/TableBody"
|
35
|
+
import Pagination from "../pb_pagination/_pagination"
|
21
36
|
|
22
37
|
type AdvancedTableProps = {
|
23
38
|
aria?: { [key: string]: string }
|
@@ -48,8 +63,7 @@ type AdvancedTableProps = {
|
|
48
63
|
tableProps?: GenericObject
|
49
64
|
toggleExpansionIcon?: string | string[]
|
50
65
|
onRowSelectionChange?: (arg: RowSelectionState) => void
|
51
|
-
|
52
|
-
} & GlobalProps;
|
66
|
+
} & GlobalProps
|
53
67
|
|
54
68
|
const AdvancedTable = (props: AdvancedTableProps) => {
|
55
69
|
const {
|
@@ -81,149 +95,282 @@ const AdvancedTable = (props: AdvancedTableProps) => {
|
|
81
95
|
tableProps,
|
82
96
|
toggleExpansionIcon = "arrows-from-line",
|
83
97
|
onRowSelectionChange,
|
84
|
-
|
85
|
-
} = props;
|
98
|
+
} = props
|
86
99
|
|
87
|
-
|
88
|
-
|
100
|
+
const [loadingStateRowCount, setLoadingStateRowCount] = useState(
|
101
|
+
initialLoadingRowsCount
|
102
|
+
)
|
89
103
|
|
90
|
-
//
|
91
|
-
const {
|
92
|
-
table,
|
93
|
-
expanded,
|
94
|
-
setExpanded,
|
95
|
-
hasAnySubRows,
|
96
|
-
selectedRowsLength,
|
97
|
-
fetchNextPage,
|
98
|
-
updateLoadingStateRowCount,
|
99
|
-
fullData,
|
100
|
-
totalFetched,
|
101
|
-
isFetching
|
102
|
-
} = useTableState({
|
103
|
-
tableData,
|
104
|
-
columnDefinitions,
|
105
|
-
expandedControl,
|
106
|
-
sortControl,
|
107
|
-
onRowToggleClick,
|
108
|
-
selectableRows,
|
109
|
-
initialLoadingRowsCount,
|
110
|
-
loading,
|
111
|
-
pagination,
|
112
|
-
paginationProps,
|
113
|
-
virtualizedRows,
|
114
|
-
tableOptions,
|
115
|
-
onRowSelectionChange
|
116
|
-
});
|
104
|
+
// Create a local state for expanded and setExpanded if expandedControl not used
|
105
|
+
const [localExpanded, setLocalExpanded] = useState({})
|
117
106
|
|
118
|
-
//
|
119
|
-
const
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
107
|
+
// Determine whether to use the prop or the local state
|
108
|
+
const expanded = expandedControl ? expandedControl.value : localExpanded
|
109
|
+
const setExpanded = expandedControl
|
110
|
+
? expandedControl.onChange
|
111
|
+
: setLocalExpanded
|
112
|
+
|
113
|
+
const columnHelper = createColumnHelper()
|
114
|
+
|
115
|
+
//Row Selection
|
116
|
+
const [rowSelection, setRowSelection] = useState<RowSelectionState>({})
|
117
|
+
|
118
|
+
//Create cells for columns, with customization for first column
|
119
|
+
const createCellFunction = (cellAccessors: string[], customRenderer?: (row: Row<GenericObject>, value: any) => JSX.Element, isFirstColumn?: boolean) => {
|
120
|
+
const columnCells = ({
|
121
|
+
row,
|
122
|
+
getValue,
|
123
|
+
}: {
|
124
|
+
row: Row<GenericObject>
|
125
|
+
getValue: Getter<string>
|
126
|
+
}) => {
|
127
|
+
const rowData = row.original
|
128
|
+
|
129
|
+
if (isFirstColumn) {
|
130
|
+
switch (row.depth) {
|
131
|
+
case 0: {
|
132
|
+
return (
|
133
|
+
<CustomCell
|
134
|
+
customRenderer={customRenderer}
|
135
|
+
getValue={getValue}
|
136
|
+
onRowToggleClick={onRowToggleClick}
|
137
|
+
row={row}
|
138
|
+
selectableRows={selectableRows}
|
139
|
+
/>
|
140
|
+
)
|
141
|
+
}
|
142
|
+
default: {
|
143
|
+
// Handle other depths based on cellAccessors
|
144
|
+
const depthAccessor = cellAccessors[row.depth - 1] // Adjust index for depth
|
145
|
+
const accessorValue = rowData[depthAccessor]
|
146
|
+
return accessorValue ? (
|
147
|
+
<CustomCell
|
148
|
+
customRenderer={customRenderer}
|
149
|
+
onRowToggleClick={onRowToggleClick}
|
150
|
+
row={row}
|
151
|
+
selectableRows={selectableRows}
|
152
|
+
value={accessorValue}
|
153
|
+
/>
|
154
|
+
) : (
|
155
|
+
"N/A"
|
156
|
+
)
|
157
|
+
}
|
158
|
+
}
|
159
|
+
}
|
160
|
+
return customRenderer
|
161
|
+
? customRenderer(row, getValue())
|
162
|
+
: getValue()
|
163
|
+
}
|
164
|
+
return columnCells
|
165
|
+
}
|
166
|
+
|
167
|
+
const buildColumns = (columnDefinitions: GenericObject[], isRoot= true): any => {
|
168
|
+
return (
|
169
|
+
columnDefinitions &&
|
170
|
+
columnDefinitions.map((column, index) => {
|
171
|
+
const isFirstColumn = isRoot && index === 0;
|
172
|
+
//Checking to see if grouped column or not
|
173
|
+
if (column.columns && column.columns.length > 0) {
|
174
|
+
return {
|
175
|
+
header: column.label || "",
|
176
|
+
columns: buildColumns(column.columns, false),
|
177
|
+
};
|
178
|
+
} else {
|
179
|
+
// Define the base column structure
|
180
|
+
const columnStructure = {
|
181
|
+
...columnHelper.accessor(column.accessor, {
|
182
|
+
header: column.label || "",
|
183
|
+
}),
|
184
|
+
};
|
185
|
+
|
186
|
+
if (column.cellAccessors || column.customRenderer) {
|
187
|
+
columnStructure.cell = createCellFunction(
|
188
|
+
column.cellAccessors,
|
189
|
+
column.customRenderer,
|
190
|
+
isFirstColumn
|
191
|
+
);
|
192
|
+
}
|
193
|
+
|
194
|
+
return columnStructure;
|
195
|
+
}
|
196
|
+
})
|
197
|
+
);
|
198
|
+
};
|
199
|
+
|
200
|
+
//Create column array in format needed by Tanstack
|
201
|
+
const columns = buildColumns(columnDefinitions);
|
202
|
+
|
203
|
+
//Syntax for sorting Array if we want to manage state ourselves
|
204
|
+
const sorting = [
|
205
|
+
{
|
206
|
+
id: columnDefinitions[0].accessor,
|
207
|
+
desc:
|
208
|
+
sortControl && sortControl.value !== null
|
209
|
+
? !sortControl.value.desc
|
210
|
+
: false,
|
211
|
+
},
|
212
|
+
]
|
213
|
+
|
214
|
+
const customState = () => {
|
215
|
+
if (sortControl && selectableRows) {
|
216
|
+
return { state: { expanded, sorting, rowSelection } }
|
217
|
+
} else if (sortControl) {
|
218
|
+
return { state: { expanded, sorting } }
|
219
|
+
} else if (selectableRows) {
|
220
|
+
return { state: { expanded, rowSelection } }
|
221
|
+
} else {
|
222
|
+
return { state: { expanded } }
|
223
|
+
}
|
224
|
+
}
|
225
|
+
|
226
|
+
const paginationInitializer = pagination ? {
|
227
|
+
getPaginationRowModel: getPaginationRowModel(),
|
228
|
+
paginateExpandedRows: false,
|
229
|
+
initialState: {
|
230
|
+
pagination: {
|
231
|
+
pageIndex: paginationProps?.pageIndex ?? 0,
|
232
|
+
pageSize: paginationProps?.pageSize ?? 20,
|
233
|
+
},
|
234
|
+
},
|
235
|
+
} : {}
|
236
|
+
|
237
|
+
//initialize table
|
238
|
+
const table = useReactTable({
|
239
|
+
data: loading ? Array(loadingStateRowCount).fill({}) : tableData,
|
240
|
+
columns,
|
241
|
+
onExpandedChange: setExpanded,
|
242
|
+
getSubRows: (row: GenericObject) => row.children,
|
243
|
+
getCoreRowModel: getCoreRowModel(),
|
244
|
+
getExpandedRowModel: getExpandedRowModel(),
|
245
|
+
getSortedRowModel: getSortedRowModel(),
|
246
|
+
enableSortingRemoval: false,
|
247
|
+
sortDescFirst: true,
|
248
|
+
onRowSelectionChange: setRowSelection,
|
249
|
+
getRowId: selectableRows ? row => row.id : undefined,
|
250
|
+
...customState(),
|
251
|
+
...paginationInitializer,
|
252
|
+
...tableOptions,
|
253
|
+
})
|
254
|
+
|
255
|
+
const tableRows = table.getRowModel()
|
256
|
+
|
257
|
+
const hasAnySubRows = tableRows.rows.some(row => row.subRows && row.subRows.length > 0);
|
258
|
+
const selectedRowsLength = Object.keys(table.getState().rowSelection).length
|
259
|
+
|
260
|
+
useEffect(() => {
|
261
|
+
if (onRowSelectionChange) {
|
262
|
+
onRowSelectionChange(table.getState().rowSelection)
|
263
|
+
}
|
264
|
+
} , [table.getState().rowSelection, onRowSelectionChange])
|
130
265
|
|
131
266
|
// Set table row count for loading state
|
267
|
+
const updateLoadingStateRowCount = useCallback(() => {
|
268
|
+
const rowsCount = table.getRowModel().rows.length
|
269
|
+
if (rowsCount !== loadingStateRowCount && rowsCount !== 0) {
|
270
|
+
setLoadingStateRowCount(rowsCount)
|
271
|
+
}
|
272
|
+
}, [tableData, loadingStateRowCount])
|
273
|
+
|
132
274
|
useEffect(() => {
|
133
275
|
if (!loading) {
|
134
|
-
updateLoadingStateRowCount()
|
276
|
+
updateLoadingStateRowCount()
|
135
277
|
}
|
136
|
-
}, [loading, updateLoadingStateRowCount])
|
278
|
+
}, [loading, updateLoadingStateRowCount])
|
137
279
|
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
146
|
-
);
|
147
|
-
}, [fetchMoreOnBottomReached, fetchNextPage, isFetching, totalFetched, fullData.length]);
|
280
|
+
const handleExpandOrCollapse = async (row: Row<GenericObject>) => {
|
281
|
+
onToggleExpansionClick && onToggleExpansionClick(row)
|
282
|
+
|
283
|
+
const expandedState = expanded;
|
284
|
+
const targetParent = row?.parentId;
|
285
|
+
const updatedRows = await updateExpandAndCollapseState(tableRows, expandedState, targetParent)
|
286
|
+
setExpanded(updatedRows)
|
287
|
+
}
|
148
288
|
|
149
|
-
|
150
|
-
const
|
151
|
-
const
|
152
|
-
const htmlProps = buildHtmlProps(htmlOptions);
|
289
|
+
const ariaProps = buildAriaProps(aria)
|
290
|
+
const dataProps = buildDataProps(data)
|
291
|
+
const htmlProps = buildHtmlProps(htmlOptions)
|
153
292
|
const classes = classnames(
|
154
293
|
buildCss("pb_advanced_table"),
|
155
294
|
`advanced-table-responsive-${responsive}`,
|
156
|
-
maxHeight ? `advanced-table-max-height-${maxHeight}` : '',
|
295
|
+
maxHeight ? `advanced-table-max-height-${maxHeight}` : '', // max height as kit prop not global prop to control overflow-y
|
157
296
|
globalProps(props),
|
158
297
|
className
|
159
|
-
)
|
298
|
+
)
|
160
299
|
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
|
300
|
+
const onPageChange = (page: number) => {
|
301
|
+
table.setPageIndex(page - 1)
|
302
|
+
}
|
303
|
+
//When to show the actions bar as a whole
|
304
|
+
const isActionBarVisible = selectableRows && showActionsBar && selectedRowsLength > 0
|
165
305
|
|
166
|
-
//
|
167
|
-
const
|
306
|
+
//Ref and useEffect for animating the actions bar
|
307
|
+
const cardRef = useRef(null);
|
308
|
+
useEffect(() => {
|
309
|
+
if (cardRef.current) {
|
310
|
+
if (isActionBarVisible) {
|
311
|
+
showActionBar(cardRef.current);
|
312
|
+
} else {
|
313
|
+
hideActionBar(cardRef.current);
|
314
|
+
}
|
315
|
+
}
|
316
|
+
}, [isActionBarVisible]);
|
168
317
|
|
169
318
|
return (
|
170
|
-
<div
|
171
|
-
{...
|
172
|
-
{...dataProps}
|
319
|
+
<div {...ariaProps}
|
320
|
+
{...dataProps}
|
173
321
|
{...htmlProps}
|
174
|
-
className={classes}
|
322
|
+
className={classes}
|
175
323
|
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
324
|
>
|
186
|
-
<
|
187
|
-
|
188
|
-
|
189
|
-
|
190
|
-
|
191
|
-
|
192
|
-
|
193
|
-
|
194
|
-
|
195
|
-
|
196
|
-
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
|
204
|
-
|
205
|
-
toggleExpansionIcon={toggleExpansionIcon}
|
206
|
-
virtualizedRows={virtualizedRows}
|
325
|
+
<AdvancedTableContext.Provider
|
326
|
+
value={{
|
327
|
+
columnDefinitions,
|
328
|
+
enableToggleExpansion,
|
329
|
+
expanded,
|
330
|
+
expandedControl,
|
331
|
+
handleExpandOrCollapse,
|
332
|
+
inlineRowLoading,
|
333
|
+
isActionBarVisible,
|
334
|
+
loading,
|
335
|
+
responsive,
|
336
|
+
setExpanded,
|
337
|
+
sortControl,
|
338
|
+
table,
|
339
|
+
toggleExpansionIcon,
|
340
|
+
showActionsBar,
|
341
|
+
selectableRows,
|
342
|
+
hasAnySubRows
|
343
|
+
}}
|
207
344
|
>
|
208
|
-
|
209
|
-
{
|
210
|
-
|
211
|
-
|
212
|
-
|
213
|
-
|
214
|
-
|
215
|
-
|
216
|
-
|
217
|
-
|
218
|
-
|
219
|
-
|
220
|
-
|
221
|
-
|
222
|
-
|
223
|
-
|
224
|
-
|
225
|
-
|
226
|
-
|
345
|
+
<>
|
346
|
+
{pagination &&
|
347
|
+
<Pagination
|
348
|
+
current={table.getState().pagination.pageIndex + 1}
|
349
|
+
key={`pagination-top-${table.getState().pagination.pageIndex + 1}`}
|
350
|
+
marginBottom="xs"
|
351
|
+
onChange={onPageChange}
|
352
|
+
range={paginationProps?.range ? paginationProps?.range : 5}
|
353
|
+
total={table.getPageCount()}
|
354
|
+
/>
|
355
|
+
}
|
356
|
+
<Card
|
357
|
+
borderNone={!isActionBarVisible}
|
358
|
+
className={`${isActionBarVisible && "show-action-card row-selection-actions-card"}`}
|
359
|
+
htmlOptions={{ ref: cardRef as any }}
|
360
|
+
padding={`${isActionBarVisible ? "xs" : "none"}`}
|
361
|
+
>
|
362
|
+
<Flex alignItems="center"
|
363
|
+
justify="between"
|
364
|
+
>
|
365
|
+
<Caption color="light"
|
366
|
+
paddingLeft="xs"
|
367
|
+
size="xs"
|
368
|
+
>
|
369
|
+
{selectedRowsLength} Selected
|
370
|
+
</Caption>
|
371
|
+
<FlexItem>{actions}</FlexItem>
|
372
|
+
</Flex>
|
373
|
+
</Card>
|
227
374
|
<Table
|
228
375
|
className={`${loading ? "content-loading" : ""}`}
|
229
376
|
dark={dark}
|
@@ -241,24 +388,23 @@ const AdvancedTable = (props: AdvancedTableProps) => {
|
|
241
388
|
</>
|
242
389
|
)}
|
243
390
|
</Table>
|
244
|
-
|
245
|
-
|
246
|
-
|
247
|
-
|
391
|
+
{pagination &&
|
392
|
+
<Pagination
|
393
|
+
current={table.getState().pagination.pageIndex + 1}
|
394
|
+
key={`pagination-bottom-${table.getState().pagination.pageIndex + 1}`}
|
395
|
+
marginTop="xs"
|
248
396
|
onChange={onPageChange}
|
249
|
-
|
250
|
-
|
251
|
-
table={table}
|
397
|
+
range={paginationProps?.range ? paginationProps?.range : 5}
|
398
|
+
total={table.getPageCount()}
|
252
399
|
/>
|
253
|
-
|
254
|
-
|
255
|
-
</
|
400
|
+
}
|
401
|
+
</>
|
402
|
+
</AdvancedTableContext.Provider>
|
256
403
|
</div>
|
257
|
-
)
|
258
|
-
}
|
404
|
+
)
|
405
|
+
}
|
259
406
|
|
260
|
-
|
261
|
-
AdvancedTable.
|
262
|
-
AdvancedTable.Body = TableBody;
|
407
|
+
AdvancedTable.Header = TableHeader
|
408
|
+
AdvancedTable.Body = TableBody
|
263
409
|
|
264
|
-
export default AdvancedTable
|
410
|
+
export default AdvancedTable
|
@@ -134,6 +134,14 @@ body.PBDrawer__Body--close {
|
|
134
134
|
transition: margin-left $animation-duration ease-out, margin-right $animation-duration ease-out;
|
135
135
|
}
|
136
136
|
|
137
|
+
.pb_drawer_lg_left.pb_drawer {
|
138
|
+
transform: translateX(-100%);
|
139
|
+
}
|
140
|
+
|
141
|
+
.pb_drawer_lg_right.pb_drawer {
|
142
|
+
transform: translateX(100%);
|
143
|
+
}
|
144
|
+
|
137
145
|
.pb_drawer.pb_drawer_after_open {
|
138
146
|
pointer-events: auto;
|
139
147
|
transform: translate3d(0, 0, 0);
|
@@ -149,34 +157,6 @@ body.PBDrawer__Body--close {
|
|
149
157
|
animation-duration: $animation-duration;
|
150
158
|
outline: none;
|
151
159
|
|
152
|
-
&.pb_drawer_within_element_rails {
|
153
|
-
position: relative;
|
154
|
-
width: 100%;
|
155
|
-
display: block;
|
156
|
-
background-color: $white;
|
157
|
-
overflow: hidden;
|
158
|
-
|
159
|
-
// Use max-height for a smooth accordion-like animation
|
160
|
-
max-height: 0;
|
161
|
-
transition: max-height $animation-duration ease-in-out;
|
162
|
-
z-index: 1;
|
163
|
-
|
164
|
-
&.open {
|
165
|
-
max-height: 1000px;
|
166
|
-
}
|
167
|
-
|
168
|
-
&::before {
|
169
|
-
content: '';
|
170
|
-
position: absolute;
|
171
|
-
top: 0;
|
172
|
-
left: 0;
|
173
|
-
right: 0;
|
174
|
-
bottom: 0;
|
175
|
-
background-color: inherit;
|
176
|
-
z-index: -1;
|
177
|
-
}
|
178
|
-
}
|
179
|
-
|
180
160
|
&.pb_drawer_within_element {
|
181
161
|
position: relative;
|
182
162
|
width: 100%;
|
@@ -349,10 +329,6 @@ body.PBDrawer__Body--close {
|
|
349
329
|
opacity: 1;
|
350
330
|
pointer-events: none;
|
351
331
|
|
352
|
-
& .pb_drawer {
|
353
|
-
pointer-events: auto;
|
354
|
-
}
|
355
|
-
|
356
332
|
&_before_close {
|
357
333
|
height: 0;
|
358
334
|
}
|
@@ -1,20 +1 @@
|
|
1
|
-
<%= pb_rails("
|
2
|
-
<%= pb_rails("button", props: { text: "Left Drawer", margin_right: "sm", data: {"open-drawer": "drawer-1"} }) %>
|
3
|
-
|
4
|
-
<%= pb_rails("drawer", props: {
|
5
|
-
id:"drawer-1",
|
6
|
-
}) do %>
|
7
|
-
Test me (Left Drawer)
|
8
|
-
<% end %>
|
9
|
-
|
10
|
-
|
11
|
-
<%= pb_rails("button", props: { text: "Right Drawer", data: {"open-drawer": "drawer-2"} }) %>
|
12
|
-
|
13
|
-
<%= pb_rails("drawer", props: {
|
14
|
-
id:"drawer-2",
|
15
|
-
placement: "right"
|
16
|
-
}) do %>
|
17
|
-
Test me (Right Drawer)
|
18
|
-
<% end %>
|
19
|
-
<% end %>
|
20
|
-
|
1
|
+
<%= pb_rails("drawer") %>
|
@@ -1,20 +1,12 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
>
|
14
|
-
<div class="<%= overlay_classes %>" style="display:none;" id="drawer-overlay-<%= object.id %>">
|
15
|
-
<%= pb_content_tag do %>
|
16
|
-
<%= content %>
|
17
|
-
<% end %>
|
18
|
-
</div>
|
19
|
-
</div>
|
20
|
-
<% end %>
|
1
|
+
<!-- Go to pb_content_tag definition in kit_base.rb for usage information. Commented out options are default (showing the default shape), and each can be deleted if not customizing that param. -->
|
2
|
+
<!-- If using nonstandard params please un-comment out and replace with your custom params. -->
|
3
|
+
<%= pb_content_tag(
|
4
|
+
# :div,
|
5
|
+
# aria: object.aria,
|
6
|
+
# class: object.classname,
|
7
|
+
# data: object.data,
|
8
|
+
# id: object.id,
|
9
|
+
# **combined_html_options
|
10
|
+
) do %>
|
11
|
+
<span>DRAWER CONTENT</span>
|
12
|
+
<% end %>
|