2021-11-26 10:43:55 +00:00
|
|
|
/**
|
|
|
|
* Custom widget manifest definition.
|
|
|
|
*/
|
|
|
|
export interface ICustomWidget {
|
|
|
|
/**
|
|
|
|
* Widget friendly name, used on the UI.
|
|
|
|
*/
|
|
|
|
name: string;
|
|
|
|
/**
|
|
|
|
* Widget unique id, probably in npm package format @gristlabs/custom-widget-name.
|
|
|
|
*/
|
|
|
|
widgetId: string;
|
|
|
|
/**
|
|
|
|
* Custom widget main page URL.
|
|
|
|
*/
|
|
|
|
url: string;
|
|
|
|
/**
|
|
|
|
* Optional desired access level.
|
|
|
|
*/
|
|
|
|
accessLevel?: AccessLevel;
|
2023-09-19 18:44:22 +00:00
|
|
|
/**
|
|
|
|
* If set, Grist will render the widget after `grist.ready()`.
|
|
|
|
*
|
2023-10-06 13:17:39 +00:00
|
|
|
* This is used to defer showing a widget on initial load until it has finished
|
|
|
|
* applying the Grist theme.
|
2023-09-19 18:44:22 +00:00
|
|
|
*/
|
|
|
|
renderAfterReady?: boolean;
|
2021-11-26 10:43:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Widget access level.
|
|
|
|
*/
|
|
|
|
export enum AccessLevel {
|
|
|
|
/**
|
|
|
|
* Default, no access to Grist.
|
|
|
|
*/
|
|
|
|
none = "none",
|
|
|
|
/**
|
|
|
|
* Read only access to table the widget is based on.
|
|
|
|
*/
|
|
|
|
read_table = "read table",
|
|
|
|
/**
|
|
|
|
* Full access to document on user's behalf.
|
|
|
|
*/
|
|
|
|
full = "full",
|
|
|
|
}
|
2022-01-12 13:30:51 +00:00
|
|
|
|
|
|
|
export function isSatisfied(current: AccessLevel, minimum: AccessLevel) {
|
|
|
|
function ordered(level: AccessLevel) {
|
|
|
|
switch(level) {
|
|
|
|
case AccessLevel.none: return 0;
|
|
|
|
case AccessLevel.read_table: return 1;
|
|
|
|
case AccessLevel.full: return 2;
|
|
|
|
default: throw new Error(`Unrecognized access level ${level}`);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return ordered(current) >= ordered(minimum);
|
|
|
|
}
|