mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-01-11 10:47:27 +03:00
38 lines
1.4 KiB
TypeScript
38 lines
1.4 KiB
TypeScript
import { createContext, useContext, useMemo } from 'react';
|
|
import type { SemVer } from '../../src/utils/helpers/version';
|
|
import { versionMatch } from '../../src/utils/helpers/version';
|
|
|
|
const supportedFeatures = {
|
|
domainVisits: '3.1.0',
|
|
excludeBotsOnShortUrls: '3.4.0',
|
|
filterDisabledUrls: '3.4.0',
|
|
deviceLongUrls: '3.5.0',
|
|
} as const satisfies Record<string, SemVer>;
|
|
|
|
Object.freeze(supportedFeatures);
|
|
|
|
export type Feature = keyof typeof supportedFeatures;
|
|
|
|
export const isFeatureEnabledForVersion = (feature: Feature, serverVersion: SemVer): boolean =>
|
|
versionMatch(serverVersion, { minVersion: supportedFeatures[feature] });
|
|
|
|
const getFeaturesForVersion = (serverVersion: SemVer): Record<Feature, boolean> => ({
|
|
domainVisits: isFeatureEnabledForVersion('domainVisits', serverVersion),
|
|
excludeBotsOnShortUrls: isFeatureEnabledForVersion('excludeBotsOnShortUrls', serverVersion),
|
|
filterDisabledUrls: isFeatureEnabledForVersion('filterDisabledUrls', serverVersion),
|
|
deviceLongUrls: isFeatureEnabledForVersion('deviceLongUrls', serverVersion),
|
|
});
|
|
|
|
export const useFeatures = (serverVersion: SemVer) => useMemo(
|
|
() => getFeaturesForVersion(serverVersion),
|
|
[serverVersion],
|
|
);
|
|
|
|
const FeaturesContext = createContext(getFeaturesForVersion('0.0.0'));
|
|
|
|
export const FeaturesProvider = FeaturesContext.Provider;
|
|
|
|
export const useFeature = (feature: Feature) => {
|
|
const features = useContext(FeaturesContext);
|
|
return features[feature];
|
|
};
|