From 51b01c6eb166dbc9e3dc51996a4176745166befc Mon Sep 17 00:00:00 2001 From: melloware Date: Wed, 16 Aug 2023 11:37:45 -0400 Subject: [PATCH] Fix #4777: Datatable typescript improvements --- .../datatable/cellselection/multipledoc.js | 25 ++- .../doc/datatable/cellselection/singledoc.js | 25 ++- components/doc/datatable/pt/ptdoc.js | 1 - .../doc/datatable/rowselection/checkboxdoc.js | 25 ++- .../doc/datatable/rowselection/disableddoc.js | 25 ++- .../doc/datatable/rowselection/eventsdoc.js | 25 ++- .../doc/datatable/rowselection/multipledoc.js | 26 ++-- .../datatable/rowselection/radiobuttondoc.js | 25 ++- .../doc/datatable/rowselection/singledoc.js | 25 ++- components/lib/datatable/datatable.d.ts | 146 ++++++++++++++---- 10 files changed, 207 insertions(+), 141 deletions(-) diff --git a/components/doc/datatable/cellselection/multipledoc.js b/components/doc/datatable/cellselection/multipledoc.js index f073cdeb27..408a0e6e2f 100644 --- a/components/doc/datatable/cellselection/multipledoc.js +++ b/components/doc/datatable/cellselection/multipledoc.js @@ -70,16 +70,16 @@ import { InputSwitch, InputSwitchChangeEvent } from 'primereact/inputswitch'; import { ProductService } from './service/ProductService'; interface Product { - id: string; - code: string; - name: string; - description: string; - image: string; - price: number; - category: string; - quantity: number; - inventoryStatus: string; - rating: number; + id?: string; + code?: string; + name?: string; + description?: string; + image?: string; + price?: number; + category?: string; + quantity?: number; + inventoryStatus?: string; + rating?: number; } export default function MultipleCellsSelectionDemo() { @@ -98,10 +98,7 @@ export default function MultipleCellsSelectionDemo() { { - const value = e.value as DataTableCellSelection; - setSelectedCells(value); - }} + onSelectionChange={(e) => setSelectedCells(e.value)} metaKeySelection={metaKey} dragSelection tableStyle={{ minWidth: '50rem' }}> diff --git a/components/doc/datatable/cellselection/singledoc.js b/components/doc/datatable/cellselection/singledoc.js index 7fb26a0b53..ac73bed13e 100644 --- a/components/doc/datatable/cellselection/singledoc.js +++ b/components/doc/datatable/cellselection/singledoc.js @@ -68,16 +68,16 @@ import { InputSwitch, InputSwitchChangeEvent } from 'primereact/inputswitch'; import { ProductService } from './service/ProductService'; interface Product { - id: string; - code: string; - name: string; - description: string; - image: string; - price: number; - category: string; - quantity: number; - inventoryStatus: string; - rating: number; + id?: string; + code?: string; + name?: string; + description?: string; + image?: string; + price?: number; + category?: string; + quantity?: number; + inventoryStatus?: string; + rating?: number; } export default function SingleCellSelectionDemo() { @@ -96,10 +96,7 @@ export default function SingleCellSelectionDemo() { { - const value = e.value as DataTableCellSelection; - setSelectedCell(value); - }} metaKeySelection={metaKey} tableStyle={{ minWidth: '50rem' }}> + onSelectionChange={(e) => setSelectedCell(e.value)} metaKeySelection={metaKey} tableStyle={{ minWidth: '50rem' }}> diff --git a/components/doc/datatable/pt/ptdoc.js b/components/doc/datatable/pt/ptdoc.js index c90e079df9..173412e4f0 100644 --- a/components/doc/datatable/pt/ptdoc.js +++ b/components/doc/datatable/pt/ptdoc.js @@ -192,7 +192,6 @@ export default function PTDemo() { }} > - ); } `, diff --git a/components/doc/datatable/rowselection/checkboxdoc.js b/components/doc/datatable/rowselection/checkboxdoc.js index ac1b242ed5..22f392fec6 100644 --- a/components/doc/datatable/rowselection/checkboxdoc.js +++ b/components/doc/datatable/rowselection/checkboxdoc.js @@ -68,16 +68,16 @@ import { InputSwitch, InputSwitchChangeEvent } from 'primereact/inputswitch'; import { ProductService } from './service/ProductService'; interface Product { - id: string; - code: string; - name: string; - description: string; - image: string; - price: number; - category: string; - quantity: number; - inventoryStatus: string; - rating: number; + id?: string; + code?: string; + name?: string; + description?: string; + image?: string; + price?: number; + category?: string; + quantity?: number; + inventoryStatus?: string; + rating?: number; } export default function CheckboxRowSelectionDemo() { @@ -96,10 +96,7 @@ export default function CheckboxRowSelectionDemo() { { - const value = e.value as Product[]; - setSelectedProducts(value); - }} dataKey="id" tableStyle={{ minWidth: '50rem' }}> + onSelectionChange={(e) => setSelectedProducts(e.value)} dataKey="id" tableStyle={{ minWidth: '50rem' }}> diff --git a/components/doc/datatable/rowselection/disableddoc.js b/components/doc/datatable/rowselection/disableddoc.js index 0db7bfc208..46c720c0e3 100644 --- a/components/doc/datatable/rowselection/disableddoc.js +++ b/components/doc/datatable/rowselection/disableddoc.js @@ -69,16 +69,16 @@ import { Column } from 'primereact/column'; import { ProductService } from './service/ProductService'; interface Product { - id: string; - code: string; - name: string; - description: string; - image: string; - price: number; - category: string; - quantity: number; - inventoryStatus: string; - rating: number; + id?: string; + code?: string; + name?: string; + description?: string; + image?: string; + price?: number; + category?: string; + quantity?: number; + inventoryStatus?: string; + rating?: number; } export default function DisabledRowSelectionDemo() { @@ -98,10 +98,7 @@ export default function DisabledRowSelectionDemo() { return (
{ - const value = e.value as Product; - setSelectedProduct(value); - }} dataKey="id" isDataSelectable={isRowSelectable} rowClassName={rowClassName} tableStyle={{ minWidth: '50rem' }}> + onSelectionChange={(e) => setSelectedProduct(e.value)} dataKey="id" isDataSelectable={isRowSelectable} rowClassName={rowClassName} tableStyle={{ minWidth: '50rem' }}> diff --git a/components/doc/datatable/rowselection/eventsdoc.js b/components/doc/datatable/rowselection/eventsdoc.js index 9f22f3ff3a..0ffb299313 100644 --- a/components/doc/datatable/rowselection/eventsdoc.js +++ b/components/doc/datatable/rowselection/eventsdoc.js @@ -79,16 +79,16 @@ import { Toast } from 'primereact/toast'; import { ProductService } from './service/ProductService'; interface Product { - id: string; - code: string; - name: string; - description: string; - image: string; - price: number; - category: string; - quantity: number; - inventoryStatus: string; - rating: number; + id?: string; + code?: string; + name?: string; + description?: string; + image?: string; + price?: number; + category?: string; + quantity?: number; + inventoryStatus?: string; + rating?: number; } export default function RowSelectEventsDemo() { @@ -112,10 +112,7 @@ export default function RowSelectEventsDemo() {
{ - const value = e.value as Product; - setSelectedProduct(value); - }} dataKey="id" onRowSelect={onRowSelect} onRowUnselect={onRowUnselect} metaKeySelection={false} tableStyle={{ minWidth: '50rem' }}> + onSelectionChange={(e) => setSelectedProduct(e.value)} dataKey="id" onRowSelect={onRowSelect} onRowUnselect={onRowUnselect} metaKeySelection={false} tableStyle={{ minWidth: '50rem' }}> diff --git a/components/doc/datatable/rowselection/multipledoc.js b/components/doc/datatable/rowselection/multipledoc.js index 353cd86917..035c772d1c 100644 --- a/components/doc/datatable/rowselection/multipledoc.js +++ b/components/doc/datatable/rowselection/multipledoc.js @@ -68,16 +68,16 @@ import { InputSwitch, InputSwitchChangeEvent } from 'primereact/inputswitch'; import { ProductService } from './service/ProductService'; interface Product { - id: string; - code: string; - name: string; - description: string; - image: string; - price: number; - category: string; - quantity: number; - inventoryStatus: string; - rating: number; + id?: string; + code?: string; + name?: string; + description?: string; + image?: string; + price?: number; + category?: string; + quantity?: number; + inventoryStatus?: string; + rating?: number; } export default function MultipleRowsSelectionDemo() { @@ -96,11 +96,7 @@ export default function MultipleRowsSelectionDemo() {
{ - if (Array.isArray(e.value)) { - setSelectedProducts(e.value); - } - }} + onSelectionChange={(e) => setSelectedProducts(e.value)} dataKey="id" metaKeySelection={metaKey} dragSelection tableStyle={{ minWidth: '50rem' }}> diff --git a/components/doc/datatable/rowselection/radiobuttondoc.js b/components/doc/datatable/rowselection/radiobuttondoc.js index f86e848245..844bddda60 100644 --- a/components/doc/datatable/rowselection/radiobuttondoc.js +++ b/components/doc/datatable/rowselection/radiobuttondoc.js @@ -68,16 +68,16 @@ import { InputSwitch, InputSwitchChangeEvent } from 'primereact/inputswitch'; import { ProductService } from './service/ProductService'; interface Product { - id: string; - code: string; - name: string; - description: string; - image: string; - price: number; - category: string; - quantity: number; - inventoryStatus: string; - rating: number; + id?: string; + code?: string; + name?: string; + description?: string; + image?: string; + price?: number; + category?: string; + quantity?: number; + inventoryStatus?: string; + rating?: number; } export default function RadioButtonRowSelectionDemo() { @@ -96,10 +96,7 @@ export default function RadioButtonRowSelectionDemo() {
{ - const value = e.value as Product; - setSelectedProduct(value); - }} dataKey="id" tableStyle={{ minWidth: '50rem' }}> + onSelectionChange={(e) => setSelectedProduct(e.value)} dataKey="id" tableStyle={{ minWidth: '50rem' }}> diff --git a/components/doc/datatable/rowselection/singledoc.js b/components/doc/datatable/rowselection/singledoc.js index ed8dd22ce9..b11176ef7b 100644 --- a/components/doc/datatable/rowselection/singledoc.js +++ b/components/doc/datatable/rowselection/singledoc.js @@ -67,16 +67,16 @@ import { InputSwitch, InputSwitchChangeEvent } from 'primereact/inputswitch'; import { ProductService } from './service/ProductService'; interface Product { - id: string; - code: string; - name: string; - description: string; - image: string; - price: number; - category: string; - quantity: number; - inventoryStatus: string; - rating: number; + id?: string; + code?: string; + name?: string; + description?: string; + image?: string; + price?: number; + category?: string; + quantity?: number; + inventoryStatus?: string; + rating?: number; } export default function SingleRowSelectionDemo() { @@ -95,10 +95,7 @@ export default function SingleRowSelectionDemo() { { - const value = e.value as Product; - setSelectedProduct(value); - }} dataKey="id" metaKeySelection={metaKey} tableStyle={{ minWidth: '50rem' }}> + onSelectionChange={(e) => setSelectedProduct(e.value)} dataKey="id" metaKeySelection={metaKey} tableStyle={{ minWidth: '50rem' }}> diff --git a/components/lib/datatable/datatable.d.ts b/components/lib/datatable/datatable.d.ts index c1256c86ed..ede5d5345a 100644 --- a/components/lib/datatable/datatable.d.ts +++ b/components/lib/datatable/datatable.d.ts @@ -291,15 +291,39 @@ interface DataTableContextMenuSelectionChangeEvent; + value: TValue; } /** - * Custom selection change event. + * Custom multiple selection change event. * @see {@link DataTableProps.onSelectionChange} * @event */ -interface DataTableSelectionChangeEvent { +interface DataTableSelectionMultipleChangeEvent { + /** + * Browser event. + */ + originalEvent: React.SyntheticEvent; + /** + * Selection objects. + */ + value: TValue; + /** + * Type of the selection. + */ + type?: 'multiple' | 'all' | 'checkbox' | 'row' | undefined; + /** + * Extra options. + */ + [key: string]: any; +} + +/** + * Custom single selection change event. + * @see {@link DataTableProps.onSelectionChange} + * @event + */ +interface DataTableSelectionSingleChangeEvent { /** * Browser event. */ @@ -307,11 +331,35 @@ interface DataTableSelectionChangeEvent { /** * Selection object. */ - value: DataTableSelection; + value: TValue[number]; + /** + * Type of the selection. + */ + type?: 'single' | 'radio' | 'row'; + /** + * Extra options. + */ + [key: string]: any; +} + +/** + * Custom cell selection change event. + * @see {@link DataTableProps.onSelectionChange} + * @event + */ +interface DataTableSelectionCellChangeEvent { + /** + * Browser event. + */ + originalEvent: React.SyntheticEvent; + /** + * Selection objects. + */ + value: DataTableCellSelection; /** * Type of the selection. */ - type?: string; + type?: 'cell'; /** * Extra options. */ @@ -699,8 +747,6 @@ type DataTableCellSelection = { value: TValue[number][keyof TValue[number]]; }; -type DataTableSelection = DataTableRowData | DataTableRowDataArray | DataTableCellSelection; - export declare type DataTablePassThroughType = PassThroughType>; /** @@ -887,7 +933,7 @@ export interface DataTablePassThroughOptions { * Defines valid properties in DataTable component. In addition to these, all properties of HTMLDivElement can be used in this component. * @group Properties */ -export interface DataTableProps extends Omit, HTMLDivElement>, 'size' | 'onContextMenu' | 'ref' | 'value'> { +interface DataTableBaseProps extends Omit, HTMLDivElement>, 'size' | 'onContextMenu' | 'ref' | 'value'> { /** * Unique identifier of the element. */ @@ -910,11 +956,6 @@ export interface DataTableProps extends Omit * Icon to display in the checkbox. */ checkIcon?: IconType> | undefined; - /** - * Whether to cell selection is enabled or not. - * @defaultValue false - */ - cellSelection?: boolean | undefined; /** * Style class of the component. */ @@ -1215,11 +1256,6 @@ export interface DataTableProps extends Omit * @defaultValue true */ selectOnEdit?: boolean | undefined; - /** - * Selected row in single mode or an array of values in multiple mode. - * @defaultValue true - */ - selection?: DataTableSelection | undefined; /** * When a selectable row is clicked on RadioButton and Checkbox selection, it automatically decides whether to focus on elements such as checkbox or radio. * @defaultValue true @@ -1229,10 +1265,6 @@ export interface DataTableProps extends Omit * A field property from the row to add Select {field} and Unselect {field} ARIA labels to checkbox/radio buttons. */ selectionAriaLabel?: string | undefined; - /** - * Specifies the selection mode, valid values are "single", "multiple", "radiobutton" and "checkbox". - */ - selectionMode?: 'single' | 'multiple' | 'checkbox' | 'radiobutton' | undefined; /** * When enabled with paginator and checkbox selection mode, the select all checkbox in the header will select all rows on the current page. * @defaultValue false @@ -1486,11 +1518,6 @@ export interface DataTableProps extends Omit * @param {DataTableSelectAllChangeEvent} event - Custom select all change event. */ onSelectAllChange?(event: DataTableSelectAllChangeEvent): void; - /** - * Callback to invoke when selection changes. - * @param {DataTableSelectionChangeEvent} event - Custom selection change event. - */ - onSelectionChange?(event: DataTableSelectionChangeEvent): void; /** * Callback to invoke on sort. * @param {DataTableStateEvent} event - Custom state event. @@ -1551,6 +1578,71 @@ export interface DataTableProps extends Omit pt?: DataTablePassThroughOptions; } +interface DataTablePropsSingle extends DataTableBaseProps { + /** + * Whether to cell selection is enabled or not. + * @defaultValue false + */ + cellSelection?: false | undefined; + /** + * Specifies the selection mode, valid values are "single", "multiple", "radiobutton" and "checkbox". + */ + selectionMode?: 'single' | 'radiobutton' | undefined; + /** + * Selected single value. + */ + selection?: TValue[number] | undefined | null; + /** + * Callback to invoke when selection changes. + * @param {DataTableSelectionSingleChangeEvent} event - Custom selection change event. + */ + onSelectionChange?(event: DataTableSelectionSingleChangeEvent): void; +} + +interface DataTablePropsMultiple extends DataTableBaseProps { + /** + * Whether to cell selection is enabled or not. + * @defaultValue false + */ + cellSelection?: false | undefined; + /** + * Specifies the selection mode, valid values are "single", "multiple", "radiobutton" and "checkbox". + */ + selectionMode: 'multiple' | 'checkbox' | null; + /** + * Selected array of values. + */ + selection: TValue; + /** + * Callback to invoke when selection changes. + * @param {DataTableSelectionMultipleChangeEvent} event - Custom selection change event. + */ + onSelectionChange?(event: DataTableSelectionMultipleChangeEvent): void; +} + +interface DataTablePropsCell extends DataTableBaseProps { + /** + * Whether to cell selection is enabled or not. + * @defaultValue false + */ + cellSelection: true; + /** + * Specifies the selection mode, valid values are "single", "multiple", "radiobutton" and "checkbox". + */ + selectionMode: 'single' | 'multiple'; + /** + * Selected cells. + */ + selection: DataTableCellSelection | null; + /** + * Callback to invoke when selection changes. + * @param {DataTableSelectionCellChangeEvent} event - Custom selection change event. + */ + onSelectionChange?(event: DataTableSelectionCellChangeEvent): void; +} + +export type DataTableProps = DataTablePropsSingle | DataTablePropsMultiple | DataTablePropsCell; + /** * **PrimeReact - DataTable