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.
Files changed (73) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/pb_advanced_table/Context/AdvancedTableContext.tsx +3 -143
  3. data/app/pb_kits/playbook/pb_advanced_table/SubKits/TableBody.tsx +99 -45
  4. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +7 -123
  5. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +299 -153
  6. data/app/pb_kits/playbook/pb_drawer/_drawer.scss +8 -32
  7. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_default.html.erb +1 -20
  8. data/app/pb_kits/playbook/pb_drawer/docs/example.yml +0 -5
  9. data/app/pb_kits/playbook/pb_drawer/drawer.html.erb +12 -20
  10. data/app/pb_kits/playbook/pb_drawer/drawer.rb +1 -49
  11. data/app/pb_kits/playbook/pb_overlay/_overlay.scss +0 -13
  12. data/app/pb_kits/playbook/pb_overlay/_overlay.tsx +1 -7
  13. data/app/pb_kits/playbook/pb_overlay/docs/example.yml +0 -3
  14. data/app/pb_kits/playbook/pb_overlay/docs/index.js +0 -1
  15. data/app/pb_kits/playbook/pb_overlay/overlay.html.erb +3 -5
  16. data/app/pb_kits/playbook/pb_overlay/overlay.rb +1 -16
  17. data/app/pb_kits/playbook/pb_overlay/overlay.test.jsx +0 -12
  18. data/app/pb_kits/playbook/pb_tooltip/_tooltip.scss +3 -0
  19. data/app/pb_kits/playbook/pb_tooltip/docs/example.yml +0 -2
  20. data/app/pb_kits/playbook/pb_tooltip/index.js +1 -1
  21. data/app/pb_kits/playbook/pb_tooltip/tooltip.rb +2 -10
  22. data/app/pb_kits/playbook/pb_typeahead/_typeahead.tsx +1 -34
  23. data/app/pb_kits/playbook/pb_typeahead/docs/example.yml +0 -2
  24. data/app/pb_kits/playbook/pb_typeahead/index.ts +8 -61
  25. data/app/pb_kits/playbook/pb_typeahead/typeahead.rb +1 -13
  26. data/dist/chunks/_typeahead-PqkcDf1H.js +36 -0
  27. data/dist/chunks/_weekday_stacked-BrSrpj7J.js +45 -0
  28. data/dist/chunks/{lib-Dmay5Z6U.js → lib-D3us1bGD.js} +1 -1
  29. data/dist/chunks/{pb_form_validation-DdP7BnVX.js → pb_form_validation-BpihMSOQ.js} +1 -1
  30. data/dist/chunks/vendor.js +1 -1
  31. data/dist/menu.yml +2 -2
  32. data/dist/playbook-doc.js +1 -1
  33. data/dist/playbook-rails-react-bindings.js +1 -1
  34. data/dist/playbook-rails.js +1 -1
  35. data/dist/playbook.css +1 -1
  36. data/lib/playbook/version.rb +1 -1
  37. metadata +6 -40
  38. data/app/pb_kits/playbook/pb_advanced_table/Components/RegularTableView.tsx +0 -127
  39. data/app/pb_kits/playbook/pb_advanced_table/Components/TableActionBar.tsx +0 -55
  40. data/app/pb_kits/playbook/pb_advanced_table/Components/TablePagination.tsx +0 -33
  41. data/app/pb_kits/playbook/pb_advanced_table/Components/VirtualizedTableView.tsx +0 -275
  42. data/app/pb_kits/playbook/pb_advanced_table/Hooks/useTableActions.ts +0 -66
  43. data/app/pb_kits/playbook/pb_advanced_table/Hooks/useTableState.ts +0 -195
  44. data/app/pb_kits/playbook/pb_advanced_table/Utilities/CellRendererUtils.tsx +0 -73
  45. data/app/pb_kits/playbook/pb_advanced_table/Utilities/RowUtils.ts +0 -52
  46. data/app/pb_kits/playbook/pb_advanced_table/Utilities/TableContainerStyles.ts +0 -80
  47. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_infinite_scroll.jsx +0 -50
  48. data/app/pb_kits/playbook/pb_advanced_table/docs/advanced_table_mock_data_infinite_scroll.json +0 -152002
  49. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_behavior.html.erb +0 -8
  50. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_borders.html.erb +0 -33
  51. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_breakpoints.html.erb +0 -0
  52. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_menu.html.erb +0 -24
  53. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_overlay.html.erb +0 -21
  54. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_overlay.md +0 -1
  55. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_sizes.html.erb +0 -49
  56. data/app/pb_kits/playbook/pb_drawer/index.js +0 -257
  57. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_hide_scroll_bar.html.erb +0 -11
  58. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_hide_scroll_bar.jsx +0 -37
  59. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_hide_scroll_bar_rails.md +0 -1
  60. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_hide_scroll_bar_react.md +0 -1
  61. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_vertical_dynamic_multi_directional.html.erb +0 -11
  62. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_vertical_dynamic_multi_directional.md +0 -1
  63. data/app/pb_kits/playbook/pb_overlay/index.js +0 -61
  64. data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_delay_rails.html.erb +0 -39
  65. data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_delay_rails.md +0 -3
  66. data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_interaction.html.erb +0 -26
  67. data/app/pb_kits/playbook/pb_tooltip/floating_ui.js +0 -282
  68. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_dynamic_options.html.erb +0 -45
  69. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_dynamic_options.md +0 -5
  70. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_dynamic_options_pure_rails.html.erb +0 -33
  71. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_dynamic_options_pure_rails.md +0 -3
  72. data/dist/chunks/_typeahead-BBL6ThPp.js +0 -36
  73. data/dist/chunks/_weekday_stacked-CF_V6Rbs.js +0 -45
@@ -1,23 +1,38 @@
1
- import React, { useRef, useEffect } from "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 { buildAriaProps, buildCss, buildDataProps, buildHtmlProps } from "../utilities/props";
8
- import { globalProps, GlobalProps } from "../utilities/globalProps";
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 Table from "../pb_table/_table";
11
- import { AdvancedTableProvider } from "./Context/AdvancedTableContext";
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 { TableHeader } from "./SubKits/TableHeader";
15
- import { TableBody } from "./SubKits/TableBody";
16
- import TablePagination from "./Components/TablePagination";
17
- import TableActionBar from "./Components/TableActionBar";
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 { useTableState } from "./Hooks/useTableState";
20
- import { useTableActions } from "./Hooks/useTableActions";
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
- virtualizedRows?: boolean
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
- virtualizedRows = false,
85
- } = props;
98
+ } = props
86
99
 
87
- // Component refs
88
- const tableWrapperRef = useRef<HTMLDivElement>(null);
100
+ const [loadingStateRowCount, setLoadingStateRowCount] = useState(
101
+ initialLoadingRowsCount
102
+ )
89
103
 
90
- // Initialize table state
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
- // Initialize table actions
119
- const {
120
- handleExpandOrCollapse,
121
- onPageChange,
122
- fetchMoreOnBottomReached
123
- } = useTableActions({
124
- table,
125
- expanded,
126
- setExpanded,
127
- onToggleExpansionClick,
128
- onRowSelectionChange
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
- // Check for infinite scroll
139
- useEffect(() => {
140
- fetchMoreOnBottomReached(
141
- tableWrapperRef.current,
142
- fetchNextPage,
143
- isFetching,
144
- totalFetched,
145
- fullData.length
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
- // Build CSS classes and props
150
- const ariaProps = buildAriaProps(aria);
151
- const dataProps = buildDataProps(data);
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
- // Table wrapper styling with virtualization support
162
- const tableWrapperStyle = virtualizedRows
163
- ? getVirtualizedContainerStyles(maxHeight)
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
- // Visibility flag for action bar
167
- const isActionBarVisible = selectableRows && showActionsBar && selectedRowsLength > 0;
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
- {...ariaProps}
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
- <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}
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
- <React.Fragment>
209
- {/* Top Pagination */}
210
- {pagination && (
211
- <TablePagination
212
- onChange={onPageChange}
213
- position="top"
214
- range={paginationProps?.range}
215
- table={table}
216
- />
217
- )}
218
-
219
- {/* Selection Action Bar */}
220
- <TableActionBar
221
- actions={actions}
222
- isVisible={isActionBarVisible}
223
- selectedCount={selectedRowsLength}
224
- />
225
-
226
- {/* Main Table */}
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
- {/* Bottom Pagination */}
246
- {pagination && (
247
- <TablePagination
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
- position="bottom"
250
- range={paginationProps?.range}
251
- table={table}
397
+ range={paginationProps?.range ? paginationProps?.range : 5}
398
+ total={table.getPageCount()}
252
399
  />
253
- )}
254
- </React.Fragment>
255
- </AdvancedTableProvider>
400
+ }
401
+ </>
402
+ </AdvancedTableContext.Provider>
256
403
  </div>
257
- );
258
- };
404
+ )
405
+ }
259
406
 
260
- // Re-export sub-components
261
- AdvancedTable.Header = TableHeader;
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("flex") do %>
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") %>
@@ -2,11 +2,6 @@ examples:
2
2
 
3
3
  rails:
4
4
  - drawer_default: Default
5
- - drawer_behavior: Push Behavior
6
- - drawer_menu: Within Element
7
- - drawer_sizes: Sizes
8
- - drawer_overlay: Overlay
9
- - drawer_borders: Borders
10
5
 
11
6
 
12
7
  react:
@@ -1,20 +1,12 @@
1
- <% if within_element %>
2
- <%= pb_content_tag(:div, data: {breakpoint: object.breakpoint} ) do %>
3
- <%= content %>
4
- <% end %>
5
- <% else %>
6
- <div class="pb_drawer_wrapper"
7
- id="drawer-wrapper-<%= object.id %>"
8
- style="display:none;"
9
- data-behavior="<%= object.behavior %>"
10
- data-size="<%= object.size %>"
11
- data-placement="<%= object.placement %>"
12
- data-breakpoint="<%= object.breakpoint %>"
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 %>