matrix-react-sdk
Version:
SDK for matrix.org using React
219 lines (202 loc) • 30.4 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.FontWatcher = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _dispatcher = _interopRequireDefault(require("../../dispatcher/dispatcher"));
var _SettingsStore = _interopRequireDefault(require("../SettingsStore"));
var _units = require("../../utils/units");
var _actions = require("../../dispatcher/actions");
var _SettingLevel = require("../SettingLevel");
/*
Copyright 2024 New Vector Ltd.
Copyright 2020-2023 The Matrix.org Foundation C.I.C.
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
class FontWatcher {
constructor() {
(0, _defineProperty2.default)(this, "dispatcherRef", void 0);
(0, _defineProperty2.default)(this, "onAction", payload => {
if (payload.action === _actions.Action.MigrateBaseFontSize) {
this.migrateBaseFontSize();
} else if (payload.action === _actions.Action.UpdateFontSizeDelta) {
this.setRootFontSize(payload.delta);
} else if (payload.action === _actions.Action.UpdateSystemFont) {
this.setSystemFont(payload);
} else if (payload.action === _actions.Action.OnLoggedOut) {
// Clear font overrides when logging out
this.setRootFontSize(FontWatcher.DEFAULT_DELTA);
this.setSystemFont({
useBundledEmojiFont: false,
useSystemFont: false,
font: ""
});
} else if (payload.action === _actions.Action.OnLoggedIn) {
// Font size can be saved on the account, so grab value when logging in
this.updateFont();
}
});
/**
* Set the root font size of the document
* @param delta {number} the delta to add to the default font size
*/
(0, _defineProperty2.default)(this, "setRootFontSize", async delta => {
// Add the delta to the browser default font size
document.querySelector(":root").style.fontSize = `calc(${FontWatcher.DEFAULT_SIZE} + ${(0, _units.toPx)(delta)})`;
});
(0, _defineProperty2.default)(this, "setSystemFont", ({
useBundledEmojiFont,
useSystemFont,
font
}) => {
if (useSystemFont) {
let fontString = font.split(",").map(font => {
font = font.trim();
if (!font.startsWith('"') && !font.endsWith('"')) {
font = `"${font}"`;
}
return font;
}).join(",");
if (useBundledEmojiFont) {
fontString += ", " + FontWatcher.BUNDLED_EMOJI_FONT;
}
/**
* Overrides the default font family from Compound
* Make sure that fonts with spaces in their names get interpreted properly
*/
document.body.style.setProperty(FontWatcher.FONT_FAMILY_CUSTOM_PROPERTY, fontString);
} else {
document.body.style.removeProperty(FontWatcher.FONT_FAMILY_CUSTOM_PROPERTY);
if (useBundledEmojiFont) {
document.body.style.setProperty(FontWatcher.EMOJI_FONT_FAMILY_CUSTOM_PROPERTY, FontWatcher.BUNDLED_EMOJI_FONT);
} else {
document.body.style.removeProperty(FontWatcher.EMOJI_FONT_FAMILY_CUSTOM_PROPERTY);
}
}
});
this.dispatcherRef = null;
}
async start() {
this.updateFont();
this.dispatcherRef = _dispatcher.default.register(this.onAction);
/**
* baseFontSize is an account level setting which is loaded after the initial
* sync. Hence why we can't do that in the `constructor`
*/
await this.migrateBaseFontSize();
}
/**
* Migrate the base font size from the V1 and V2 version to the V3 version
* @private
*/
async migrateBaseFontSize() {
await this.migrateBaseFontV1toFontSizeDelta();
await this.migrateBaseFontV2toFontSizeDelta();
}
/**
* Migrating from the V1 version of the base font size to the new delta system.
* The delta system is using the default browser font size as a base
* Everything will become slightly larger, and getting rid of the `SIZE_DIFF`
* weirdness for locally persisted values
* @private
*/
async migrateBaseFontV1toFontSizeDelta() {
const legacyBaseFontSize = _SettingsStore.default.getValue("baseFontSize");
// No baseFontV1 found, nothing to migrate
if (!legacyBaseFontSize) return;
console.log("Migrating base font size -> base font size V2 -> font size delta for Compound, current value", legacyBaseFontSize);
// Compute the V1 to V2 version before migrating to fontSizeDelta
const baseFontSizeV2 = this.computeBaseFontSizeV1toV2(legacyBaseFontSize);
// Compute the difference between the V2 and the fontSizeDelta
const delta = this.computeFontSizeDeltaFromV2BaseFontSize(baseFontSizeV2);
await _SettingsStore.default.setValue("fontSizeDelta", null, _SettingLevel.SettingLevel.DEVICE, delta);
await _SettingsStore.default.setValue("baseFontSize", null, _SettingLevel.SettingLevel.DEVICE, 0);
console.log("Migration complete, deleting legacy `baseFontSize`");
}
/**
* Migrating from the V2 version of the base font size to the new delta system
* @private
*/
async migrateBaseFontV2toFontSizeDelta() {
const legacyBaseFontV2Size = _SettingsStore.default.getValue("baseFontSizeV2");
// No baseFontV2 found, nothing to migrate
if (!legacyBaseFontV2Size) return;
console.log("Migrating base font size V2 for Compound, current value", legacyBaseFontV2Size);
// Compute the difference between the V2 and the fontSizeDelta
const delta = this.computeFontSizeDeltaFromV2BaseFontSize(legacyBaseFontV2Size);
await _SettingsStore.default.setValue("fontSizeDelta", null, _SettingLevel.SettingLevel.DEVICE, delta);
await _SettingsStore.default.setValue("baseFontSizeV2", null, _SettingLevel.SettingLevel.DEVICE, 0);
console.log("Migration complete, deleting legacy `baseFontSizeV2`");
}
/**
* Compute the V2 font size from the V1 font size
* @param legacyBaseFontSize
* @private
*/
computeBaseFontSizeV1toV2(legacyBaseFontSize) {
// For some odd reason, the persisted value in user storage has an offset
// of 5 pixels for all values stored under `baseFontSize`
const LEGACY_SIZE_DIFF = 5;
// Compound uses a base font size of `16px`, whereas the old Element
// styles based their calculations off a `15px` root font size.
const ROOT_FONT_SIZE_INCREASE = 1;
// Compute the font size of the V2 version before migrating to V3
return legacyBaseFontSize + ROOT_FONT_SIZE_INCREASE + LEGACY_SIZE_DIFF;
}
/**
* Compute the difference between the V2 font size and the default browser font size
* @param legacyBaseFontV2Size
* @private
*/
computeFontSizeDeltaFromV2BaseFontSize(legacyBaseFontV2Size) {
const browserDefaultFontSize = FontWatcher.getRootFontSize();
// Compute the difference between the V2 font size and the default browser font size
return legacyBaseFontV2Size - browserDefaultFontSize;
}
/**
* Get the root font size of the document
* Fallback to 16px if the value is not found
* @returns {number}
*/
static getRootFontSize() {
return parseInt(window.getComputedStyle(document.documentElement).getPropertyValue("font-size"), 10) || 16;
}
/**
* Get the browser default font size
* @returns {number} the default font size of the browser
*/
static getBrowserDefaultFontSize() {
return this.getRootFontSize() - _SettingsStore.default.getValue("fontSizeDelta");
}
stop() {
if (!this.dispatcherRef) return;
_dispatcher.default.unregister(this.dispatcherRef);
}
updateFont() {
this.setRootFontSize(_SettingsStore.default.getValue("fontSizeDelta"));
this.setSystemFont({
useBundledEmojiFont: _SettingsStore.default.getValue("useBundledEmojiFont"),
useSystemFont: _SettingsStore.default.getValue("useSystemFont"),
font: _SettingsStore.default.getValue("systemFont")
});
}
}
exports.FontWatcher = FontWatcher;
/**
* This Compound value is using `100%` of the default browser font size.
* It allows EW to use the browser's default font size instead of a fixed value.
* All the Compound font size are using `rem`, they are relative to the root font size
* and therefore of the browser font size.
*/
(0, _defineProperty2.default)(FontWatcher, "DEFAULT_SIZE", "var(--cpd-font-size-root)");
/**
* Default delta added to the ${@link DEFAULT_SIZE}
*/
(0, _defineProperty2.default)(FontWatcher, "DEFAULT_DELTA", 0);
(0, _defineProperty2.default)(FontWatcher, "FONT_FAMILY_CUSTOM_PROPERTY", "--cpd-font-family-sans");
(0, _defineProperty2.default)(FontWatcher, "EMOJI_FONT_FAMILY_CUSTOM_PROPERTY", "--emoji-font-family");
(0, _defineProperty2.default)(FontWatcher, "BUNDLED_EMOJI_FONT", "Twemoji");
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_dispatcher","_interopRequireDefault","require","_SettingsStore","_units","_actions","_SettingLevel","FontWatcher","constructor","_defineProperty2","default","payload","action","Action","MigrateBaseFontSize","migrateBaseFontSize","UpdateFontSizeDelta","setRootFontSize","delta","UpdateSystemFont","setSystemFont","OnLoggedOut","DEFAULT_DELTA","useBundledEmojiFont","useSystemFont","font","OnLoggedIn","updateFont","document","querySelector","style","fontSize","DEFAULT_SIZE","toPx","fontString","split","map","trim","startsWith","endsWith","join","BUNDLED_EMOJI_FONT","body","setProperty","FONT_FAMILY_CUSTOM_PROPERTY","removeProperty","EMOJI_FONT_FAMILY_CUSTOM_PROPERTY","dispatcherRef","start","dis","register","onAction","migrateBaseFontV1toFontSizeDelta","migrateBaseFontV2toFontSizeDelta","legacyBaseFontSize","SettingsStore","getValue","console","log","baseFontSizeV2","computeBaseFontSizeV1toV2","computeFontSizeDeltaFromV2BaseFontSize","setValue","SettingLevel","DEVICE","legacyBaseFontV2Size","LEGACY_SIZE_DIFF","ROOT_FONT_SIZE_INCREASE","browserDefaultFontSize","getRootFontSize","parseInt","window","getComputedStyle","documentElement","getPropertyValue","getBrowserDefaultFontSize","stop","unregister","exports"],"sources":["../../../src/settings/watchers/FontWatcher.ts"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2020-2023 The Matrix.org Foundation C.I.C.\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport dis from \"../../dispatcher/dispatcher\";\nimport SettingsStore from \"../SettingsStore\";\nimport IWatcher from \"./Watcher\";\nimport { toPx } from \"../../utils/units\";\nimport { Action } from \"../../dispatcher/actions\";\nimport { SettingLevel } from \"../SettingLevel\";\nimport { UpdateSystemFontPayload } from \"../../dispatcher/payloads/UpdateSystemFontPayload\";\nimport { ActionPayload } from \"../../dispatcher/payloads\";\n\nexport class FontWatcher implements IWatcher {\n    /**\n     * This Compound value is using `100%` of the default browser font size.\n     * It allows EW to use the browser's default font size instead of a fixed value.\n     * All the Compound font size are using `rem`, they are relative to the root font size\n     * and therefore of the browser font size.\n     */\n    private static readonly DEFAULT_SIZE = \"var(--cpd-font-size-root)\";\n    /**\n     * Default delta added to the ${@link DEFAULT_SIZE}\n     */\n    public static readonly DEFAULT_DELTA = 0;\n\n    private dispatcherRef: string | null;\n\n    public constructor() {\n        this.dispatcherRef = null;\n    }\n\n    public async start(): Promise<void> {\n        this.updateFont();\n        this.dispatcherRef = dis.register(this.onAction);\n        /**\n         * baseFontSize is an account level setting which is loaded after the initial\n         * sync. Hence why we can't do that in the `constructor`\n         */\n        await this.migrateBaseFontSize();\n    }\n\n    /**\n     * Migrate the base font size from the V1 and V2 version to the V3 version\n     * @private\n     */\n    private async migrateBaseFontSize(): Promise<void> {\n        await this.migrateBaseFontV1toFontSizeDelta();\n        await this.migrateBaseFontV2toFontSizeDelta();\n    }\n\n    /**\n     * Migrating from the V1 version of the base font size to the new delta system.\n     * The delta system is using the default browser font size as a base\n     * Everything will become slightly larger, and getting rid of the `SIZE_DIFF`\n     * weirdness for locally persisted values\n     * @private\n     */\n    private async migrateBaseFontV1toFontSizeDelta(): Promise<void> {\n        const legacyBaseFontSize = SettingsStore.getValue<number>(\"baseFontSize\");\n        // No baseFontV1 found, nothing to migrate\n        if (!legacyBaseFontSize) return;\n\n        console.log(\n            \"Migrating base font size -> base font size V2 -> font size delta for Compound, current value\",\n            legacyBaseFontSize,\n        );\n\n        // Compute the V1 to V2 version before migrating to fontSizeDelta\n        const baseFontSizeV2 = this.computeBaseFontSizeV1toV2(legacyBaseFontSize);\n\n        // Compute the difference between the V2 and the fontSizeDelta\n        const delta = this.computeFontSizeDeltaFromV2BaseFontSize(baseFontSizeV2);\n\n        await SettingsStore.setValue(\"fontSizeDelta\", null, SettingLevel.DEVICE, delta);\n        await SettingsStore.setValue(\"baseFontSize\", null, SettingLevel.DEVICE, 0);\n        console.log(\"Migration complete, deleting legacy `baseFontSize`\");\n    }\n\n    /**\n     * Migrating from the V2 version of the base font size to the new delta system\n     * @private\n     */\n    private async migrateBaseFontV2toFontSizeDelta(): Promise<void> {\n        const legacyBaseFontV2Size = SettingsStore.getValue<number>(\"baseFontSizeV2\");\n        // No baseFontV2 found, nothing to migrate\n        if (!legacyBaseFontV2Size) return;\n\n        console.log(\"Migrating base font size V2 for Compound, current value\", legacyBaseFontV2Size);\n\n        // Compute the difference between the V2 and the fontSizeDelta\n        const delta = this.computeFontSizeDeltaFromV2BaseFontSize(legacyBaseFontV2Size);\n\n        await SettingsStore.setValue(\"fontSizeDelta\", null, SettingLevel.DEVICE, delta);\n        await SettingsStore.setValue(\"baseFontSizeV2\", null, SettingLevel.DEVICE, 0);\n        console.log(\"Migration complete, deleting legacy `baseFontSizeV2`\");\n    }\n\n    /**\n     * Compute the V2 font size from the V1 font size\n     * @param legacyBaseFontSize\n     * @private\n     */\n    private computeBaseFontSizeV1toV2(legacyBaseFontSize: number): number {\n        // For some odd reason, the persisted value in user storage has an offset\n        // of 5 pixels for all values stored under `baseFontSize`\n        const LEGACY_SIZE_DIFF = 5;\n\n        // Compound uses a base font size of `16px`, whereas the old Element\n        // styles based their calculations off a `15px` root font size.\n        const ROOT_FONT_SIZE_INCREASE = 1;\n\n        // Compute the font size of the V2 version before migrating to V3\n        return legacyBaseFontSize + ROOT_FONT_SIZE_INCREASE + LEGACY_SIZE_DIFF;\n    }\n\n    /**\n     * Compute the difference between the V2 font size and the default browser font size\n     * @param legacyBaseFontV2Size\n     * @private\n     */\n    private computeFontSizeDeltaFromV2BaseFontSize(legacyBaseFontV2Size: number): number {\n        const browserDefaultFontSize = FontWatcher.getRootFontSize();\n\n        // Compute the difference between the V2 font size and the default browser font size\n        return legacyBaseFontV2Size - browserDefaultFontSize;\n    }\n\n    /**\n     * Get the root font size of the document\n     * Fallback to 16px if the value is not found\n     * @returns {number}\n     */\n    public static getRootFontSize(): number {\n        return parseInt(window.getComputedStyle(document.documentElement).getPropertyValue(\"font-size\"), 10) || 16;\n    }\n\n    /**\n     * Get the browser default font size\n     * @returns {number} the default font size of the browser\n     */\n    public static getBrowserDefaultFontSize(): number {\n        return this.getRootFontSize() - SettingsStore.getValue<number>(\"fontSizeDelta\");\n    }\n\n    public stop(): void {\n        if (!this.dispatcherRef) return;\n        dis.unregister(this.dispatcherRef);\n    }\n\n    private updateFont(): void {\n        this.setRootFontSize(SettingsStore.getValue<number>(\"fontSizeDelta\"));\n        this.setSystemFont({\n            useBundledEmojiFont: SettingsStore.getValue(\"useBundledEmojiFont\"),\n            useSystemFont: SettingsStore.getValue(\"useSystemFont\"),\n            font: SettingsStore.getValue(\"systemFont\"),\n        });\n    }\n\n    private onAction = (payload: ActionPayload): void => {\n        if (payload.action === Action.MigrateBaseFontSize) {\n            this.migrateBaseFontSize();\n        } else if (payload.action === Action.UpdateFontSizeDelta) {\n            this.setRootFontSize(payload.delta);\n        } else if (payload.action === Action.UpdateSystemFont) {\n            this.setSystemFont(payload as UpdateSystemFontPayload);\n        } else if (payload.action === Action.OnLoggedOut) {\n            // Clear font overrides when logging out\n            this.setRootFontSize(FontWatcher.DEFAULT_DELTA);\n            this.setSystemFont({\n                useBundledEmojiFont: false,\n                useSystemFont: false,\n                font: \"\",\n            });\n        } else if (payload.action === Action.OnLoggedIn) {\n            // Font size can be saved on the account, so grab value when logging in\n            this.updateFont();\n        }\n    };\n\n    /**\n     * Set the root font size of the document\n     * @param delta {number} the delta to add to the default font size\n     */\n    private setRootFontSize = async (delta: number): Promise<void> => {\n        // Add the delta to the browser default font size\n        document.querySelector<HTMLElement>(\":root\")!.style.fontSize =\n            `calc(${FontWatcher.DEFAULT_SIZE} + ${toPx(delta)})`;\n    };\n\n    public static readonly FONT_FAMILY_CUSTOM_PROPERTY = \"--cpd-font-family-sans\";\n    public static readonly EMOJI_FONT_FAMILY_CUSTOM_PROPERTY = \"--emoji-font-family\";\n    public static readonly BUNDLED_EMOJI_FONT = \"Twemoji\";\n\n    private setSystemFont = ({\n        useBundledEmojiFont,\n        useSystemFont,\n        font,\n    }: Pick<UpdateSystemFontPayload, \"useBundledEmojiFont\" | \"useSystemFont\" | \"font\">): void => {\n        if (useSystemFont) {\n            let fontString = font\n                .split(\",\")\n                .map((font) => {\n                    font = font.trim();\n                    if (!font.startsWith('\"') && !font.endsWith('\"')) {\n                        font = `\"${font}\"`;\n                    }\n                    return font;\n                })\n                .join(\",\");\n\n            if (useBundledEmojiFont) {\n                fontString += \", \" + FontWatcher.BUNDLED_EMOJI_FONT;\n            }\n\n            /**\n             * Overrides the default font family from Compound\n             * Make sure that fonts with spaces in their names get interpreted properly\n             */\n            document.body.style.setProperty(FontWatcher.FONT_FAMILY_CUSTOM_PROPERTY, fontString);\n        } else {\n            document.body.style.removeProperty(FontWatcher.FONT_FAMILY_CUSTOM_PROPERTY);\n\n            if (useBundledEmojiFont) {\n                document.body.style.setProperty(\n                    FontWatcher.EMOJI_FONT_FAMILY_CUSTOM_PROPERTY,\n                    FontWatcher.BUNDLED_EMOJI_FONT,\n                );\n            } else {\n                document.body.style.removeProperty(FontWatcher.EMOJI_FONT_FAMILY_CUSTOM_PROPERTY);\n            }\n        }\n    };\n}\n"],"mappings":"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","ignoreList":[]}