playbook_ui 14.16.0.pre.alpha.PBNTR881advancedtablefullscreen6934 → 14.16.0.pre.alpha.PBNTR924reacttablecustomheaders6846

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 (46) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/pb_advanced_table/Utilities/types.ts +1 -1
  3. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +0 -70
  4. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +85 -168
  5. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.test.jsx +2 -15
  6. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_pagination.jsx +1 -0
  7. data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +1 -2
  8. data/app/pb_kits/playbook/pb_advanced_table/docs/index.js +1 -2
  9. data/app/pb_kits/playbook/pb_button/_button.scss +5 -5
  10. data/app/pb_kits/playbook/pb_date_picker/_date_picker.tsx +34 -34
  11. data/app/pb_kits/playbook/pb_date_picker/date_picker.html.erb +2 -2
  12. data/app/pb_kits/playbook/pb_date_picker/date_picker_helper.ts +0 -16
  13. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_inline.html.erb +11 -0
  14. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_inline.jsx +7 -0
  15. data/app/pb_kits/playbook/pb_date_picker/sass_partials/_inline_styles.scss +24 -28
  16. data/app/pb_kits/playbook/pb_filter/Filter/CurrentFilters.tsx +4 -3
  17. data/app/pb_kits/playbook/pb_filter/Filter/SortMenu.tsx +3 -2
  18. data/app/pb_kits/playbook/pb_form/pb_form_validation.js +1 -1
  19. data/app/pb_kits/playbook/pb_lightbox/hooks/useVisibility.js +1 -1
  20. data/app/pb_kits/playbook/pb_multi_level_select/_multi_level_select.tsx +1 -2
  21. data/app/pb_kits/playbook/pb_rich_text_editor/_rich_text_editor.tsx +11 -29
  22. data/app/pb_kits/playbook/pb_rich_text_editor/docs/_rich_text_editor_default.html.erb +1 -1
  23. data/app/pb_kits/playbook/pb_rich_text_editor/rich_text_editor.html.erb +4 -4
  24. data/app/pb_kits/playbook/pb_rich_text_editor/rich_text_editor.rb +0 -2
  25. data/app/pb_kits/playbook/pb_tooltip/floating_ui.js +282 -0
  26. data/app/pb_kits/playbook/pb_tooltip/index.js +56 -183
  27. data/app/pb_kits/playbook/pb_typeahead/index.ts +2 -2
  28. data/app/pb_kits/playbook/utilities/globalProps.ts +1 -1
  29. data/app/pb_kits/playbook/utilities/object.test.js +1 -149
  30. data/app/pb_kits/playbook/utilities/object.ts +42 -124
  31. data/dist/chunks/_typeahead-HN7DWIZV.js +22 -0
  32. data/dist/chunks/_weekday_stacked-CEWwCgZj.js +45 -0
  33. data/dist/chunks/lib-Co5y3V4K.js +29 -0
  34. data/dist/chunks/{pb_form_validation-BvNy9Bd6.js → pb_form_validation-DMajaRt3.js} +1 -1
  35. data/dist/chunks/vendor.js +1 -1
  36. data/dist/playbook-doc.js +1 -1
  37. data/dist/playbook-rails-react-bindings.js +1 -1
  38. data/dist/playbook-rails.js +1 -1
  39. data/dist/playbook.css +1 -1
  40. data/lib/playbook/version.rb +1 -1
  41. metadata +7 -8
  42. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_fullscreen.jsx +0 -90
  43. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_fullscreen.md +0 -3
  44. data/dist/chunks/_typeahead-Djo6qCne.js +0 -22
  45. data/dist/chunks/_weekday_stacked-CON3AkXi.js +0 -45
  46. data/dist/chunks/lib-BGzBzFZX.js +0 -29
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 7e6ae8dabe0a1aa24faea68ee263457d677481e8fb49058ef3bf98cb34d13509
4
- data.tar.gz: aea28cf93c519443b913371efb9f7e36399b55ead106a9914698077d78df686f
3
+ metadata.gz: dd82bb6f3ee44ed655fa00a9063867e0bf1b2475e14053635cfa045d9eabc19c
4
+ data.tar.gz: 17de2ee4fb645c07918923b762f2c4195ff451056c85e4dd41fd7655fd1004a7
5
5
  SHA512:
6
- metadata.gz: da72830c3590d1df9419ecb3d6310ef1513b16186c5bb12fcd42fdb6bca29b293c10f422ca18e618587f384bd618fe3b1487e7b90f8b7d8eaf1960f880a380ab
7
- data.tar.gz: d75d70f4ae579220897598329343fa90978182a202efa1c29e46ccf51cdafc9b70a7b08624a89c5cda1b5a729519b5a58b9e2ca340136b87188079d0dea54f22
6
+ metadata.gz: e798db2746cc1381cdf2a6bf3d988f784a133ad65cddc0e6cc5085eb7586e28808b461d1d9aae1e5ad4b579474698380765c393a3ab6ff9b8537541ca8d299a5
7
+ data.tar.gz: 5bee6ba2e97346c45b8b38df8839d6f2e0ad481eb8c4f2299cdb01eb3b8b79a6df40c919236a4f765b0de50d9a29a8a4c877ed9a1374348f3ab14cb92f45e302
@@ -3,4 +3,4 @@ import { ExpandedState } from "@tanstack/react-table"
3
3
  export type ExpandedStateObject = Extract<
4
4
  ExpandedState,
5
5
  Record<string, boolean>
6
- >
6
+ >
@@ -7,7 +7,6 @@
7
7
  @import "./scss_partials/chrome_styles";
8
8
  @import "../tokens/screen_sizes";
9
9
  @import "../tokens/shadows";
10
- @import "../tokens/positioning";
11
10
 
12
11
  .pb_advanced_table {
13
12
  $border-color: 1px solid $border_light;
@@ -230,53 +229,6 @@
230
229
  max-height: 1920px;
231
230
  overflow-y: auto;
232
231
  }
233
-
234
- // Fullscreen
235
- &.advanced-table-allow-fullscreen {
236
- transition: all 0.3s ease;
237
- }
238
-
239
- &.advanced-table-fullscreen {
240
- background-color: $border_light;
241
- box-sizing: border-box;
242
- height: 100vh;
243
- left: 0;
244
- overflow: auto;
245
- position: fixed;
246
- top: 0;
247
- width: 100%;
248
- z-index: $z_10;
249
-
250
- .pb_table {
251
- th, td, div, button {
252
- font-size: calc(100%);
253
- }
254
- box-sizing: border-box;
255
- margin: $space_lg;
256
- max-width: calc(100% - 64px);
257
- width: calc(100% - 64px);
258
- }
259
-
260
- .pb_table.sticky-header {
261
- thead,
262
- .pb_advanced_table_header {
263
- position: sticky !important;
264
- top: 44px !important;
265
- z-index: $z_10;
266
- }
267
- }
268
- }
269
-
270
- .advanced-table-fullscreen-header {
271
- background-color: $white;
272
- height: 44px;
273
- padding: 13px 20px;
274
- position: sticky;
275
- top: 0;
276
- width: 100%;
277
- z-index: $z_10;
278
- }
279
-
280
232
  // Icons
281
233
  .button-icon {
282
234
  display: flex;
@@ -325,16 +277,6 @@
325
277
  }
326
278
  }
327
279
 
328
- .fullscreen-icon {
329
- @extend .button-icon;
330
- @extend %primary-color-pseudo;
331
- padding: 2px 0;
332
-
333
- &:focus-visible {
334
- border-radius: $border_rad_lighter;
335
- }
336
- }
337
-
338
280
  // Vertical separator
339
281
  .table-header-cells:first-child,
340
282
  .table-header-cells-custom:first-child,
@@ -524,18 +466,6 @@
524
466
  box-shadow: 1px 0px 0px 0px $border_dark !important;
525
467
  }
526
468
 
527
- // Fullscreen
528
- &.advanced-table-fullscreen {
529
- background: $border_dark;
530
- }
531
-
532
- .advanced-table-fullscreen-header {
533
- background-color: $bg_dark_card;
534
- position: sticky;
535
- top: 0;
536
- z-index: $z_10;
537
- }
538
-
539
469
  // Dark Mode Responsive Styles
540
470
  @media only screen and (max-width: $screen-xl-min) {
541
471
  &[class*="advanced-table-responsive-scroll"] {
@@ -1,4 +1,4 @@
1
- import React, { useRef, useEffect, useState, useCallback } from "react";
1
+ import React, { useRef, useEffect } from "react";
2
2
  import classnames from "classnames";
3
3
 
4
4
  import { GenericObject } from "../types";
@@ -19,15 +19,6 @@ import TableActionBar from "./Components/TableActionBar";
19
19
  import { useTableState } from "./Hooks/useTableState";
20
20
  import { useTableActions } from "./Hooks/useTableActions";
21
21
 
22
- import Card from "../pb_card/_card"
23
- import Flex from "../pb_flex/_flex"
24
- import Icon from "../pb_icon/_icon"
25
-
26
- type FullscreenControls = {
27
- toggleFullscreen: () => void;
28
- isFullscreen: boolean;
29
- };
30
-
31
22
  type AdvancedTableProps = {
32
23
  aria?: { [key: string]: string }
33
24
  actions?: React.ReactNode[] | React.ReactNode
@@ -58,8 +49,6 @@ type AdvancedTableProps = {
58
49
  toggleExpansionIcon?: string | string[]
59
50
  onRowSelectionChange?: (arg: RowSelectionState) => void
60
51
  virtualizedRows?: boolean
61
- allowFullScreen?: boolean
62
- fullScreenControl?: (controls: FullscreenControls) => void
63
52
  } & GlobalProps;
64
53
 
65
54
  const AdvancedTable = (props: AdvancedTableProps) => {
@@ -93,8 +82,6 @@ const AdvancedTable = (props: AdvancedTableProps) => {
93
82
  toggleExpansionIcon = "arrows-from-line",
94
83
  onRowSelectionChange,
95
84
  virtualizedRows = false,
96
- allowFullScreen = false,
97
- fullScreenControl,
98
85
  } = props;
99
86
 
100
87
  // Component refs
@@ -159,68 +146,6 @@ const AdvancedTable = (props: AdvancedTableProps) => {
159
146
  );
160
147
  }, [fetchMoreOnBottomReached, fetchNextPage, isFetching, totalFetched, fullData.length]);
161
148
 
162
- // Fullscreen
163
- const [isFullscreen, setIsFullscreen] = useState(false)
164
-
165
- const toggleFullscreen = useCallback(() => {
166
- setIsFullscreen(prevState => !prevState)
167
- }, [])
168
-
169
- useEffect(() => {
170
- if (allowFullScreen && fullScreenControl) {
171
- fullScreenControl({
172
- toggleFullscreen,
173
- isFullscreen
174
- })
175
- }
176
- }, [allowFullScreen, fullScreenControl, toggleFullscreen, isFullscreen])
177
-
178
- const renderFullscreenHeader = () => {
179
- if (!isFullscreen) return null
180
-
181
- const defaultMinimizeIcon = (
182
- <button
183
- className="gray-icon fullscreen-icon"
184
- onClick={toggleFullscreen}
185
- >
186
- <Icon
187
- cursor="pointer"
188
- fixedWidth
189
- icon="grid-2"
190
- {...props}
191
- />
192
- </button>
193
- )
194
-
195
- return (
196
- <Card
197
- borderNone
198
- borderRadius="none"
199
- className="advanced-table-fullscreen-header"
200
- {...props}
201
- >
202
- <Flex justify="end">
203
- {defaultMinimizeIcon}
204
- </Flex>
205
- </Card>
206
- )
207
- }
208
-
209
- useEffect(() => {
210
- if (!allowFullScreen) return
211
-
212
- const handleKeyDown = (event: KeyboardEvent) => {
213
- if (event.key === 'Escape' && isFullscreen) {
214
- event.preventDefault()
215
- toggleFullscreen()
216
- }
217
- }
218
- document.addEventListener('keydown', handleKeyDown)
219
- return () => {
220
- document.removeEventListener('keydown', handleKeyDown)
221
- }
222
- }, [allowFullScreen, toggleFullscreen, isFullscreen])
223
-
224
149
  // Build CSS classes and props
225
150
  const ariaProps = buildAriaProps(aria);
226
151
  const dataProps = buildDataProps(data);
@@ -229,10 +154,6 @@ const AdvancedTable = (props: AdvancedTableProps) => {
229
154
  buildCss("pb_advanced_table"),
230
155
  `advanced-table-responsive-${responsive}`,
231
156
  maxHeight ? `advanced-table-max-height-${maxHeight}` : '',
232
- {
233
- 'advanced-table-fullscreen': isFullscreen,
234
- 'advanced-table-allow-fullscreen': allowFullScreen
235
- },
236
157
  globalProps(props),
237
158
  className
238
159
  );
@@ -246,97 +167,93 @@ const AdvancedTable = (props: AdvancedTableProps) => {
246
167
  const isActionBarVisible = selectableRows && showActionsBar && selectedRowsLength > 0;
247
168
 
248
169
  return (
249
- <>
250
- {/* Top Pagination */}
251
- {pagination && (
252
- <TablePagination
253
- onChange={onPageChange}
254
- position="top"
255
- range={paginationProps?.range}
256
- table={table}
257
- />
258
- )}
259
-
260
- <div
261
- {...ariaProps}
262
- {...dataProps}
263
- {...htmlProps}
264
- className={classes}
265
- id={id}
266
- onScroll={virtualizedRows ? e => fetchMoreOnBottomReached(
267
- e.currentTarget,
268
- fetchNextPage,
269
- isFetching,
270
- totalFetched,
271
- fullData.length
272
- ) : undefined}
273
- ref={tableWrapperRef}
274
- style={tableWrapperStyle as React.CSSProperties}
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}
275
207
  >
276
- {renderFullscreenHeader()}
277
- <AdvancedTableProvider
278
- columnDefinitions={columnDefinitions}
279
- enableToggleExpansion={enableToggleExpansion}
280
- enableVirtualization={virtualizedRows}
281
- expanded={expanded}
282
- expandedControl={expandedControl}
283
- handleExpandOrCollapse={handleExpandOrCollapse}
284
- hasAnySubRows={hasAnySubRows}
285
- inlineRowLoading={inlineRowLoading}
286
- isActionBarVisible={isActionBarVisible}
287
- isFullscreen={isFullscreen}
288
- loading={loading}
289
- responsive={responsive}
290
- selectableRows={selectableRows}
291
- setExpanded={setExpanded}
292
- showActionsBar={showActionsBar}
293
- sortControl={sortControl}
294
- subRowHeaders={tableOptions?.subRowHeaders}
295
- table={table}
296
- tableContainerRef={tableWrapperRef}
297
- toggleExpansionIcon={toggleExpansionIcon}
298
- virtualizedRows={virtualizedRows}
299
- >
300
- <React.Fragment>
301
- {/* Selection Action Bar */}
302
- <TableActionBar
303
- actions={actions}
304
- isVisible={isActionBarVisible}
305
- 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}
306
216
  />
217
+ )}
218
+
219
+ {/* Selection Action Bar */}
220
+ <TableActionBar
221
+ actions={actions}
222
+ isVisible={isActionBarVisible}
223
+ selectedCount={selectedRowsLength}
224
+ />
307
225
 
308
- {/* Main Table */}
309
- <Table
310
- className={`${loading ? "content-loading" : ""}`}
311
- dark={dark}
312
- dataTable
313
- numberSpacing="tabular"
314
- responsive="none"
315
- {...tableProps}
316
- >
317
- {children ? (
318
- children
319
- ) : (
320
- <>
321
- <TableHeader />
322
- <TableBody />
323
- </>
324
- )}
325
- </Table>
326
- </React.Fragment>
327
- </AdvancedTableProvider>
328
-
329
- </div>
330
- {/* Bottom Pagination */}
331
- {pagination && (
332
- <TablePagination
333
- onChange={onPageChange}
334
- position="bottom"
335
- range={paginationProps?.range}
336
- table={table}
337
- />
338
- )}
339
- </>
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>
340
257
  );
341
258
  };
342
259
 
@@ -149,7 +149,7 @@ return (
149
149
  data={{testid: testId}}
150
150
  sortControl={sortControl}
151
151
  tableData={MOCK_DATA}
152
- >
152
+ >
153
153
  <AdvancedTable.Header enableSorting />
154
154
  <AdvancedTable.Body />
155
155
  </AdvancedTable>
@@ -498,17 +498,4 @@ test("customRenderer prop functions as expected", () => {
498
498
  const kit = screen.getByTestId(testId)
499
499
  const pill = kit.querySelector(".pb_pill_kit_success_lowercase")
500
500
  expect(pill).toBeInTheDocument()
501
- })
502
-
503
- test("allowFullScreen prop adds fullscreen class", () => {
504
- render(
505
- <AdvancedTable
506
- allowFullScreen
507
- columnDefinitions={columnDefinitions}
508
- tableData={MOCK_DATA}
509
- />
510
- )
511
-
512
- const tableContainer = screen.getByRole("table").closest("div")
513
- expect(tableContainer).toHaveClass("advanced-table-allow-fullscreen")
514
- })
501
+ })
@@ -40,6 +40,7 @@ const AdvancedTablePagination = (props) => {
40
40
  <AdvancedTable
41
41
  columnDefinitions={columnDefinitions}
42
42
  pagination
43
+ responsive="none"
43
44
  tableData={PAGINATION_MOCK_DATA}
44
45
  {...props}
45
46
  />
@@ -39,5 +39,4 @@ examples:
39
39
  - advanced_table_selectable_rows_no_subrows: Selectable Rows (No Subrows)
40
40
  - advanced_table_selectable_rows_actions: Selectable Rows (With Actions)
41
41
  - advanced_table_selectable_rows_header: Selectable Rows (No Actions Bar)
42
- - advanced_table_inline_editing: Inline Cell Editing
43
- - advanced_table_fullscreen: Fullscreen
42
+ - advanced_table_inline_editing: Inline Cell Editing
@@ -21,5 +21,4 @@ export { default as AdvancedTableSelectableRowsHeader } from './_advanced_table_
21
21
  export { default as AdvancedTableSelectableRowsActions } from './_advanced_table_selectable_rows_actions.jsx'
22
22
  export { default as AdvancedTableTablePropsStickyHeader } from './_advanced_table_table_props_sticky_header.jsx'
23
23
  export { default as AdvancedTableColumnHeadersCustomCell } from './_advanced_table_column_headers_custom_cell.jsx'
24
- export { default as AdvancedTableInlineEditing } from './_advanced_table_inline_editing.jsx'
25
- export { default as AdvancedTableFullscreen } from './_advanced_table_fullscreen.jsx'
24
+ export { default as AdvancedTableInlineEditing } from './_advanced_table_inline_editing.jsx'
@@ -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] {
@@ -106,41 +106,41 @@ const DatePicker = (props: DatePickerProps): React.ReactElement => {
106
106
  const inputAriaProps = buildAriaProps(inputAria)
107
107
  const inputDataProps = buildDataProps(inputData)
108
108
 
109
- useEffect(() => {
110
- datePickerHelper({
111
- allowInput,
112
- customQuickPickDates,
113
- defaultDate,
114
- disableDate,
115
- disableRange,
116
- disableWeekdays,
117
- enableTime,
118
- format,
119
- hideIcon,
120
- inLine,
121
- maxDate,
122
- minDate,
123
- mode,
124
- onChange,
125
- onClose,
126
- pickerId,
127
- plugins,
128
- // eslint-disable-next-line @typescript-eslint/ban-ts-comment
129
- // @ts-ignore
130
- position,
131
- positionElement,
132
- selectionType,
133
- showTimezone,
134
- staticPosition,
135
- thisRangesEndToday,
136
- yearRange,
137
- required: false,
138
- }, scrollContainer)
139
- }, initializeOnce ? [] : undefined)
109
+ useEffect(() => {
110
+ datePickerHelper({
111
+ allowInput,
112
+ customQuickPickDates,
113
+ defaultDate,
114
+ disableDate,
115
+ disableRange,
116
+ disableWeekdays,
117
+ enableTime,
118
+ format,
119
+ hideIcon,
120
+ inLine,
121
+ maxDate,
122
+ minDate,
123
+ mode,
124
+ onChange,
125
+ onClose,
126
+ pickerId,
127
+ plugins,
128
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
129
+ // @ts-ignore
130
+ position,
131
+ positionElement,
132
+ selectionType,
133
+ showTimezone,
134
+ staticPosition,
135
+ thisRangesEndToday,
136
+ yearRange,
137
+ required: false,
138
+ }, scrollContainer)
139
+ }, initializeOnce ? [] : undefined)
140
140
  const filteredProps = {...props}
141
141
  if (filteredProps.marginBottom === undefined) {
142
142
  filteredProps.marginBottom = "sm"
143
- }
143
+ }
144
144
  delete filteredProps?.position
145
145
 
146
146
  const classes = classnames(
@@ -221,7 +221,7 @@ const DatePicker = (props: DatePickerProps): React.ReactElement => {
221
221
  {hideIcon && inLine ?
222
222
  <div>
223
223
  <div
224
- className={`${iconWrapperClass()} date-picker-inline-icon-plus`}
224
+ className={iconWrapperClass()}
225
225
  id={`${pickerId}-icon-plus`}
226
226
  >
227
227
  <Icon
@@ -230,7 +230,7 @@ const DatePicker = (props: DatePickerProps): React.ReactElement => {
230
230
  />
231
231
  </div>
232
232
  <div
233
- className={`${iconWrapperClass()} date-picker-inline-angle-down`}
233
+ className={iconWrapperClass()}
234
234
  id={`${pickerId}-angle-down`}
235
235
  >
236
236
  <Icon
@@ -44,7 +44,7 @@
44
44
  <% if object.hide_icon && object.inline %>
45
45
  <!-- Plus Icon -->
46
46
  <div
47
- class="<%= object.icon_wrapper_class %> date-picker-inline-icon-plus"
47
+ class="<%= object.icon_wrapper_class %>"
48
48
  id="<%= object.picker_id %>-icon-plus"
49
49
  >
50
50
  <%= pb_rails("icon", props: {
@@ -55,7 +55,7 @@
55
55
 
56
56
  <!-- Angle Down Icon -->
57
57
  <div
58
- class="<%= object.icon_wrapper_class %> date-picker-inline-angle-down"
58
+ class="<%= object.icon_wrapper_class %>"
59
59
  id="<%= object.picker_id %>-angle-down"
60
60
  >
61
61
  <%= pb_rails("icon", props: {
@@ -174,21 +174,6 @@ const datePickerHelper = (config: DatePickerConfig, scrollContainer: string | HT
174
174
  yearInput.value = fp.currentYear?.toString()
175
175
  }
176
176
 
177
- const handleDatePickerChange = (fp: Instance, selectedDates: Date[]) => {
178
- const inputEl = fp.input
179
-
180
- if (inputEl) {
181
- const inlineDatePickerElem = inputEl.closest('.inline-date-picker')
182
- if (inlineDatePickerElem) {
183
- if (selectedDates && selectedDates.length > 0) {
184
- inlineDatePickerElem.classList.add('show-angle-down-icon')
185
- } else {
186
- inlineDatePickerElem.classList.remove('show-angle-down-icon')
187
- }
188
- }
189
- }
190
- }
191
-
192
177
  // ===========================================================
193
178
  // | Flatpickr initializer w/ config |
194
179
  // ===========================================================
@@ -219,7 +204,6 @@ const datePickerHelper = (config: DatePickerConfig, scrollContainer: string | HT
219
204
  onClose(selectedDates, dateStr)
220
205
  }],
221
206
  onChange: [(selectedDates, dateStr, fp) => {
222
- handleDatePickerChange(fp, selectedDates)
223
207
  yearChangeHook(fp)
224
208
  onChange(dateStr, selectedDates)
225
209
  }],
@@ -4,3 +4,14 @@
4
4
  inline: true,
5
5
  picker_id: "date-picker-inline"
6
6
  }) %>
7
+
8
+ <%= javascript_tag do %>
9
+ window.addEventListener("DOMContentLoaded", (event) => {
10
+ const fpInline = document.querySelector("#date-picker-inline")._flatpickr
11
+ <!-- Display the angle-down icon when a date has been selected -->
12
+ const showAngleDownHandler = () => {
13
+ document.querySelector('.inline-date-picker').classList.add('show-angle-down-icon')
14
+ }
15
+ fpInline.config.onChange.push(showAngleDownHandler)
16
+ })
17
+ <% end %>
@@ -3,12 +3,19 @@ import React from 'react'
3
3
  import DatePicker from '../_date_picker'
4
4
 
5
5
  const DatePickerInline = (props) => {
6
+ const showAngleDownHandler = (dateSelected) => {
7
+ if (dateSelected) {
8
+ document.querySelector('.inline-date-picker').classList.add('show-angle-down-icon')
9
+ }
10
+ }
11
+
6
12
  return (
7
13
  <div>
8
14
  <DatePicker
9
15
  className="inline-date-picker"
10
16
  hideIcon
11
17
  inLine
18
+ onChange={showAngleDownHandler}
12
19
  pickerId="date-picker-inline"
13
20
  {...props}
14
21
  />