2023-08-28 09:16:17 +00:00
|
|
|
import {TableData} from 'app/common/TableData';
|
|
|
|
import {UIRowId} from 'app/plugin/GristAPI';
|
2021-10-04 23:52:20 +00:00
|
|
|
|
|
|
|
/**
|
2022-07-06 07:41:09 +00:00
|
|
|
* Return whether a table (identified by the rowId of its metadata record) should
|
|
|
|
* normally be hidden from the user (e.g. as an option in the page-widget picker).
|
2021-10-04 23:52:20 +00:00
|
|
|
*/
|
2022-02-04 11:13:03 +00:00
|
|
|
export function isHiddenTable(tablesData: TableData, tableRef: UIRowId): boolean {
|
2021-10-04 23:52:20 +00:00
|
|
|
const tableId = tablesData.getValue(tableRef, 'tableId') as string|undefined;
|
2022-09-02 13:21:03 +00:00
|
|
|
// The `!tableId` check covers the case of censored tables (see isTableCensored() below).
|
2022-07-21 13:46:29 +00:00
|
|
|
return !tableId || isSummaryTable(tablesData, tableRef) || tableId.startsWith('GristHidden_');
|
2022-04-27 17:46:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2022-07-06 07:41:09 +00:00
|
|
|
* Return whether a table (identified by the rowId of its metadata record) is a
|
|
|
|
* summary table.
|
2022-04-27 17:46:24 +00:00
|
|
|
*/
|
2022-07-06 07:41:09 +00:00
|
|
|
export function isSummaryTable(tablesData: TableData, tableRef: UIRowId): boolean {
|
|
|
|
return tablesData.getValue(tableRef, 'summarySourceTable') !== 0;
|
2021-10-04 23:52:20 +00:00
|
|
|
}
|
2022-09-02 13:21:03 +00:00
|
|
|
|
|
|
|
// Check if a table record (from _grist_Tables) is censored.
|
|
|
|
// Metadata records get censored by clearing certain of their fields, so it's expected that a
|
|
|
|
// record may exist even though various code should consider it as hidden.
|
|
|
|
export function isTableCensored(tablesData: TableData, tableRef: UIRowId): boolean {
|
|
|
|
const tableId = tablesData.getValue(tableRef, 'tableId');
|
|
|
|
return !tableId;
|
|
|
|
}
|