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.
- checksums.yaml +4 -4
- data/app/pb_kits/playbook/pb_advanced_table/Utilities/types.ts +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +0 -70
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +85 -168
- data/app/pb_kits/playbook/pb_advanced_table/advanced_table.test.jsx +2 -15
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_pagination.jsx +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +1 -2
- data/app/pb_kits/playbook/pb_advanced_table/docs/index.js +1 -2
- data/app/pb_kits/playbook/pb_button/_button.scss +5 -5
- data/app/pb_kits/playbook/pb_date_picker/_date_picker.tsx +34 -34
- data/app/pb_kits/playbook/pb_date_picker/date_picker.html.erb +2 -2
- data/app/pb_kits/playbook/pb_date_picker/date_picker_helper.ts +0 -16
- data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_inline.html.erb +11 -0
- data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_inline.jsx +7 -0
- data/app/pb_kits/playbook/pb_date_picker/sass_partials/_inline_styles.scss +24 -28
- 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_tooltip/floating_ui.js +282 -0
- data/app/pb_kits/playbook/pb_tooltip/index.js +56 -183
- 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-HN7DWIZV.js +22 -0
- data/dist/chunks/_weekday_stacked-CEWwCgZj.js +45 -0
- data/dist/chunks/lib-Co5y3V4K.js +29 -0
- data/dist/chunks/{pb_form_validation-BvNy9Bd6.js → pb_form_validation-DMajaRt3.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 -8
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_fullscreen.jsx +0 -90
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_fullscreen.md +0 -3
- data/dist/chunks/_typeahead-Djo6qCne.js +0 -22
- data/dist/chunks/_weekday_stacked-CON3AkXi.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: dd82bb6f3ee44ed655fa00a9063867e0bf1b2475e14053635cfa045d9eabc19c
|
4
|
+
data.tar.gz: 17de2ee4fb645c07918923b762f2c4195ff451056c85e4dd41fd7655fd1004a7
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: e798db2746cc1381cdf2a6bf3d988f784a133ad65cddc0e6cc5085eb7586e28808b461d1d9aae1e5ad4b579474698380765c393a3ab6ff9b8537541ca8d299a5
|
7
|
+
data.tar.gz: 5bee6ba2e97346c45b8b38df8839d6f2e0ad481eb8c4f2299cdb01eb3b8b79a6df40c919236a4f765b0de50d9a29a8a4c877ed9a1374348f3ab14cb92f45e302
|
@@ -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
|
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
|
-
|
251
|
-
|
252
|
-
|
253
|
-
|
254
|
-
|
255
|
-
|
256
|
-
|
257
|
-
|
258
|
-
|
259
|
-
|
260
|
-
|
261
|
-
|
262
|
-
|
263
|
-
|
264
|
-
|
265
|
-
|
266
|
-
|
267
|
-
|
268
|
-
|
269
|
-
|
270
|
-
|
271
|
-
|
272
|
-
|
273
|
-
|
274
|
-
|
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
|
-
|
277
|
-
|
278
|
-
|
279
|
-
|
280
|
-
|
281
|
-
|
282
|
-
|
283
|
-
|
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
|
-
|
309
|
-
|
310
|
-
|
311
|
-
|
312
|
-
|
313
|
-
|
314
|
-
|
315
|
-
|
316
|
-
|
317
|
-
|
318
|
-
|
319
|
-
|
320
|
-
|
321
|
-
|
322
|
-
|
323
|
-
|
324
|
-
|
325
|
-
|
326
|
-
|
327
|
-
|
328
|
-
|
329
|
-
|
330
|
-
|
331
|
-
|
332
|
-
|
333
|
-
|
334
|
-
|
335
|
-
|
336
|
-
|
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
|
+
})
|
@@ -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
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
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={
|
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={
|
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 %>
|
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 %>
|
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
|
/>
|