mirror of
https://github.com/XFox111/TabsAsideExtension.git
synced 2026-04-22 07:58:01 +03:00
e21022d985
* Some features are now optional (#148) * fix(dev): yarn.lock tree fix * feat: bookmarks moved to optional permissions * fix: analytics not working in firefox * feat!: ability to turn off analytics (uses permissions on firefox) * feat: analytics tracker for bookmark export * feat: add privacy policy link in about section * docs: privacy policy update * feat: ability to chain multiple dialogs * fix(loc): analytics option translation * feat: settings review dialog * fix: background script fails to load because of frontend code * chore: use analytics permission as storage value * fix: inverted analytics value * feat!: option to disable thumbnail capture * fix(ci): sed typo * fix: minor fixes * fix(firefox): web-ext lint error fix * chore(ci): switch web-ext action * chore(lint): fix eslint warnings * chore(deps): monthly dependency bump (September 2025) (#149) * chore: 3.1.0 version bump * chore: minor cleanup * fix: allow analytics checkbox stays inactive after denying permission on firefox * fix(deps): yarn.lock rebuild * fix: type assertion for userId * fix: settings review dialog not showing if welcome dialog is not required * fix: analytics and thumbnail capture toggles react incorrectly if permission is denied
78 lines
2.1 KiB
TypeScript
78 lines
2.1 KiB
TypeScript
import { Unwatch, WatchCallback, WxtStorageItem } from "wxt/storage";
|
|
import { analytics } from "./analytics";
|
|
import { Permissions } from "wxt/browser";
|
|
|
|
const analyticsPermission: Pick<WxtStorageItem<boolean, Record<string, unknown>>, "getValue" | "watch" | "setValue"> =
|
|
{
|
|
getValue: async (): Promise<boolean> =>
|
|
{
|
|
const isGranted: boolean = import.meta.env.FIREFOX
|
|
? await browser.permissions.contains({
|
|
// @ts-expect-error Introduced in Firefox 139
|
|
data_collection: ["technicalAndInteraction"]
|
|
})
|
|
: await allowAnalytics.getValue();
|
|
|
|
analytics.setEnabled(isGranted);
|
|
|
|
return isGranted;
|
|
},
|
|
|
|
setValue: async (value: boolean) =>
|
|
{
|
|
if (!import.meta.env.FIREFOX)
|
|
{
|
|
await allowAnalytics.setValue(value);
|
|
return;
|
|
}
|
|
|
|
let result: boolean = false;
|
|
|
|
if (value)
|
|
result = await browser.permissions.request({
|
|
// @ts-expect-error Introduced in Firefox 139
|
|
data_collection: ["technicalAndInteraction"]
|
|
});
|
|
else
|
|
result = await browser.permissions.remove({
|
|
// @ts-expect-error Introduced in Firefox 139
|
|
data_collection: ["technicalAndInteraction"]
|
|
});
|
|
|
|
if (!result)
|
|
throw new Error("Permission request was denied");
|
|
},
|
|
|
|
watch: (cb: WatchCallback<boolean>): Unwatch =>
|
|
{
|
|
if (!import.meta.env.FIREFOX)
|
|
return allowAnalytics.watch(cb);
|
|
|
|
const listener = async (permissions: Permissions.Permissions): Promise<void> =>
|
|
{
|
|
// @ts-expect-error Introduced in Firefox 139
|
|
if (permissions.data_collection?.includes("technicalAndInteraction"))
|
|
{
|
|
// @ts-expect-error Introduced in Firefox 139
|
|
const isGranted: boolean = await browser.permissions.contains({ data_collection: ["technicalAndInteraction"] });
|
|
cb(isGranted, !isGranted);
|
|
}
|
|
};
|
|
|
|
browser.permissions.onAdded.addListener(listener);
|
|
browser.permissions.onRemoved.addListener(listener);
|
|
|
|
return (): void =>
|
|
{
|
|
browser.permissions.onAdded.removeListener(listener);
|
|
browser.permissions.onRemoved.removeListener(listener);
|
|
};
|
|
}
|
|
};
|
|
|
|
export default analyticsPermission;
|
|
|
|
const allowAnalytics = storage.defineItem<boolean>("local:analytics", {
|
|
fallback: true
|
|
});
|