feat(config): show / hide info on load
This commit is contained in:
parent
ce16a9d999
commit
dbc7e8c2f9
@ -9,9 +9,12 @@ backend:
|
|||||||
whiteboardInfoBroadcastFreq: 1
|
whiteboardInfoBroadcastFreq: 1
|
||||||
|
|
||||||
frontend:
|
frontend:
|
||||||
# When an editable whiteboard is loading in a client,
|
# When a whiteboard is loading in a client
|
||||||
# should it be started in read-only mode.
|
onWhiteboardLoad:
|
||||||
readOnlyOnWhiteboardLoad: false
|
# should an (editable) whiteboard be started in read-only mode by default
|
||||||
|
setReadOnly: false
|
||||||
|
# should the whiteboard info be displayed by default
|
||||||
|
displayInfo: false
|
||||||
# Show smallest screen indicator
|
# Show smallest screen indicator
|
||||||
showSmallestScreenIndicator: true
|
showSmallestScreenIndicator: true
|
||||||
performance:
|
performance:
|
||||||
|
@ -30,11 +30,21 @@
|
|||||||
"frontend": {
|
"frontend": {
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"additionalProperties": false,
|
"additionalProperties": false,
|
||||||
"required": ["readOnlyOnWhiteboardLoad", "showSmallestScreenIndicator", "performance"],
|
"required": ["onWhiteboardLoad", "showSmallestScreenIndicator", "performance"],
|
||||||
"properties": {
|
"properties": {
|
||||||
"readOnlyOnWhiteboardLoad": {
|
"onWhiteboardLoad": {
|
||||||
|
"type": "object",
|
||||||
|
"additionalProperties": false,
|
||||||
|
"required": ["displayInfo", "setReadOnly"],
|
||||||
|
"properties": {
|
||||||
|
"setReadOnly": {
|
||||||
"type": "boolean"
|
"type": "boolean"
|
||||||
},
|
},
|
||||||
|
"displayInfo": {
|
||||||
|
"type": "boolean"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"showSmallestScreenIndicator": {
|
"showSmallestScreenIndicator": {
|
||||||
"type": "boolean"
|
"type": "boolean"
|
||||||
},
|
},
|
||||||
|
@ -31,11 +31,11 @@ test("Complex object config override", () => {
|
|||||||
|
|
||||||
test("Override default config", () => {
|
test("Override default config", () => {
|
||||||
const defaultConfig = getDefaultConfig();
|
const defaultConfig = getDefaultConfig();
|
||||||
const overrideConfig1 = { frontend: { readOnlyOnWhiteboardLoad: true } };
|
const overrideConfig1 = { frontend: { onWhiteboardLoad: { setReadOnly: true } } };
|
||||||
|
|
||||||
expect(deepMergeConfigs(defaultConfig, overrideConfig1).frontend.readOnlyOnWhiteboardLoad).toBe(
|
expect(
|
||||||
true
|
deepMergeConfigs(defaultConfig, overrideConfig1).frontend.onWhiteboardLoad.setReadOnly
|
||||||
);
|
).toBe(true);
|
||||||
});
|
});
|
||||||
|
|
||||||
test("Dumb config is not valid", () => {
|
test("Dumb config is not valid", () => {
|
||||||
|
@ -603,10 +603,14 @@ function initWhiteboard() {
|
|||||||
// fix bug cursor not showing up
|
// fix bug cursor not showing up
|
||||||
whiteboard.refreshCursorAppearance();
|
whiteboard.refreshCursorAppearance();
|
||||||
|
|
||||||
if (process.env.NODE_ENV === "production" && ConfigService.readOnlyOnWhiteboardLoad) {
|
if (process.env.NODE_ENV === "production") {
|
||||||
ReadOnlyService.activateReadOnlyMode();
|
if (ConfigService.readOnlyOnWhiteboardLoad) ReadOnlyService.activateReadOnlyMode();
|
||||||
InfoService.hideInfo();
|
else ReadOnlyService.deactivateReadOnlyMode();
|
||||||
|
|
||||||
|
if (ConfigService.displayInfoOnWhiteboardLoad) InfoService.displayInfo();
|
||||||
|
else InfoService.hideInfo();
|
||||||
} else {
|
} else {
|
||||||
|
// in dev
|
||||||
ReadOnlyService.deactivateReadOnlyMode();
|
ReadOnlyService.deactivateReadOnlyMode();
|
||||||
InfoService.displayInfo();
|
InfoService.displayInfo();
|
||||||
}
|
}
|
||||||
|
@ -10,11 +10,15 @@ class ConfigService {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @type {boolean}
|
* @type {{displayInfo: boolean, setReadOnly: boolean}}
|
||||||
|
* @readonly
|
||||||
*/
|
*/
|
||||||
#readOnlyOnWhiteboardLoad = false;
|
#onWhiteboardLoad = { setReadOnly: false, displayInfo: false };
|
||||||
get readOnlyOnWhiteboardLoad() {
|
get readOnlyOnWhiteboardLoad() {
|
||||||
return this.#readOnlyOnWhiteboardLoad;
|
return this.#onWhiteboardLoad.setReadOnly;
|
||||||
|
}
|
||||||
|
get displayInfoOnWhiteboardLoad() {
|
||||||
|
return this.#onWhiteboardLoad.displayInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -50,9 +54,9 @@ class ConfigService {
|
|||||||
this.#configFromServer = configFromServer;
|
this.#configFromServer = configFromServer;
|
||||||
|
|
||||||
const { common } = configFromServer;
|
const { common } = configFromServer;
|
||||||
const { readOnlyOnWhiteboardLoad, showSmallestScreenIndicator, performance } = common;
|
const { onWhiteboardLoad, showSmallestScreenIndicator, performance } = common;
|
||||||
|
|
||||||
this.#readOnlyOnWhiteboardLoad = readOnlyOnWhiteboardLoad;
|
this.#onWhiteboardLoad = onWhiteboardLoad;
|
||||||
this.#showSmallestScreenIndicator = showSmallestScreenIndicator;
|
this.#showSmallestScreenIndicator = showSmallestScreenIndicator;
|
||||||
this.#refreshInfoInterval = 1000 / performance.refreshInfoFreq;
|
this.#refreshInfoInterval = 1000 / performance.refreshInfoFreq;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user