* [WEB-5134] refactor: update `web` ESLint configuration and refactor imports to use type imports - Enhanced ESLint configuration by adding new rules for import consistency and type imports. - Refactored multiple files to replace regular imports with type imports for better clarity and performance. - Ensured consistent use of type imports across the application to align with TypeScript best practices. * refactor: standardize type imports across components - Updated multiple files to replace regular imports with type imports for improved clarity and consistency. - Ensured adherence to TypeScript best practices in the rich filters and issue layouts components.
24 lines
701 B
TypeScript
24 lines
701 B
TypeScript
import { useContext } from "react";
|
|
// context
|
|
import { StoreContext } from "@/lib/store-context";
|
|
// mobx store
|
|
import type { IProjectPageStore } from "@/store/pages/project-page.store";
|
|
|
|
export enum EPageStoreType {
|
|
PROJECT = "PROJECT_PAGE",
|
|
}
|
|
|
|
export type TReturnType = {
|
|
[EPageStoreType.PROJECT]: IProjectPageStore;
|
|
};
|
|
|
|
export const usePageStore = <T extends EPageStoreType>(storeType: T): TReturnType[T] => {
|
|
const context = useContext(StoreContext);
|
|
if (context === undefined) throw new Error("usePageStore must be used within StoreProvider");
|
|
|
|
if (storeType === EPageStoreType.PROJECT) {
|
|
return context.projectPages;
|
|
}
|
|
|
|
throw new Error(`Invalid store type: ${storeType}`);
|
|
};
|