mig-schema-table 3.0.68 → 3.0.70
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.
|
@@ -24,6 +24,10 @@ function getSortByValue(propSchema, propConfig) {
|
|
|
24
24
|
propSchema.type === "integer" ||
|
|
25
25
|
!!(propConfig === null || propConfig === void 0 ? void 0 : propConfig.renderCell));
|
|
26
26
|
}
|
|
27
|
+
function getIsColumnSortable(isTableSortable, propSchema, propConfig) {
|
|
28
|
+
return !!(isTableSortable &&
|
|
29
|
+
(propSchema || (propConfig === null || propConfig === void 0 ? void 0 : propConfig.renderData) || (propConfig === null || propConfig === void 0 ? void 0 : propConfig.sort)));
|
|
30
|
+
}
|
|
27
31
|
function SchemaTable({ Heading = VariableSizeList, checkedIndexes, config, customElement, data, defaultColumnFilters = {}, defaultSortAsc = false, defaultSortColumn, disabledCheckedIndexes, enableAutoFocus, getRowClassName, getRowSelected, isColumnFilterable, isSearchable, isSortable, maxHeight, onCheckedIndexesChange, onRowClick, onRowDoubleClick, rowHeight = 36, schema, searchPlaceholder, style, useFilterStateHash, width, }) {
|
|
28
32
|
const [sortColumn, setSortColumn] = React.useState(defaultSortColumn);
|
|
29
33
|
const [sortAsc, setSortAsc] = React.useState(defaultSortAsc);
|
|
@@ -381,13 +385,9 @@ function SchemaTable({ Heading = VariableSizeList, checkedIndexes, config, custo
|
|
|
381
385
|
if (columnFilterMap[propName] !== undefined) {
|
|
382
386
|
columnFilterStatus = EColumnFilterStatus.ACTIVE;
|
|
383
387
|
}
|
|
384
|
-
const isColumnSortable = !!(isSortable &&
|
|
385
|
-
(propSchema ||
|
|
386
|
-
((propConfig === null || propConfig === void 0 ? void 0 : propConfig.sortByValue) && propConfig.renderData) ||
|
|
387
|
-
(propConfig === null || propConfig === void 0 ? void 0 : propConfig.sort)));
|
|
388
388
|
return (_jsx(SchemaTableTh, { columnFilterStatus: columnFilterStatus,
|
|
389
389
|
// disableColumnFilter={disableColumnFilter}
|
|
390
|
-
isAllChecked: isAllRowsChecked, isSortable:
|
|
390
|
+
isAllChecked: isAllRowsChecked, isSortable: getIsColumnSortable(!!isSortable, propSchema, propConfig), numberOfSelectedRows: checkedIndexes === null || checkedIndexes === void 0 ? void 0 : checkedIndexes.length, onSelectAllIndexesHandler: onSelectAllIndexesHandler, propConfig: propConfig, propIsRequired: required.includes(propName), propName: propName, schema: propSchema, setMenuConfig: setSchemaTableThMenuConfig, setSortAsc: onSetSortAsc, setSortColumn: onSetSortColumn, sortAsc: sortColumn === propName ? sortAsc : undefined, style: style }));
|
|
391
391
|
}, [
|
|
392
392
|
checkedIndexes === null || checkedIndexes === void 0 ? void 0 : checkedIndexes.length,
|
|
393
393
|
columnFilterMap,
|
|
@@ -533,6 +533,6 @@ function SchemaTable({ Heading = VariableSizeList, checkedIndexes, config, custo
|
|
|
533
533
|
backgroundColor: "#CCC",
|
|
534
534
|
alignItems: "center",
|
|
535
535
|
justifyContent: "center",
|
|
536
|
-
} }, { children: isDirty ? (_jsx("button", Object.assign({ onClick: refreshData, className: "btn border" }, { children: "Refresh data" }))) : (_jsx("div", { children: "\u231B Loading..." })) }))), schemaTableThMenuConfig ? (_jsx(SchemaTableThMenu, { isFilterable: !!isColumnFilterable, isSortable: !!isSortable, onChange: onSchemaColumnFilterChange, onClose: onPopoverClose, onInputKeyDown: onInputKeyDown, propConfig: schemaTableThMenuConfig.propConfig, propIsRequired: schemaTableThMenuConfig.propIsRequired, propName: schemaTableThMenuConfig.propName, propSchema: schema.properties[schemaTableThMenuConfig.propName], referenceElement: schemaTableThMenuConfig.referenceElement, setSortAsc: setSortAsc, setSortColumn: setSortColumn, value: columnFilterMap[schemaTableThMenuConfig.propName] })) : null] })));
|
|
536
|
+
} }, { children: isDirty ? (_jsx("button", Object.assign({ onClick: refreshData, className: "btn border" }, { children: "Refresh data" }))) : (_jsx("div", { children: "\u231B Loading..." })) }))), schemaTableThMenuConfig ? (_jsx(SchemaTableThMenu, { isFilterable: !!isColumnFilterable, isSortable: getIsColumnSortable(!!isSortable, schema.properties[schemaTableThMenuConfig.propName], schemaTableThMenuConfig.propConfig), onChange: onSchemaColumnFilterChange, onClose: onPopoverClose, onInputKeyDown: onInputKeyDown, propConfig: schemaTableThMenuConfig.propConfig, propIsRequired: schemaTableThMenuConfig.propIsRequired, propName: schemaTableThMenuConfig.propName, propSchema: schema.properties[schemaTableThMenuConfig.propName], referenceElement: schemaTableThMenuConfig.referenceElement, setSortAsc: setSortAsc, setSortColumn: setSortColumn, value: columnFilterMap[schemaTableThMenuConfig.propName] })) : null] })));
|
|
537
537
|
}
|
|
538
538
|
export default React.memo(SchemaTable);
|