summaryrefslogtreecommitdiff
path: root/src/lib
diff options
context:
space:
mode:
Diffstat (limited to 'src/lib')
-rw-r--r--src/lib/consts.ts2
-rw-r--r--src/lib/contexts/Auth.context.tsx37
-rw-r--r--src/lib/contexts/Global.context.tsx8
-rw-r--r--src/lib/contexts/index.ts2
-rw-r--r--src/lib/utils.ts6
5 files changed, 55 insertions, 0 deletions
diff --git a/src/lib/consts.ts b/src/lib/consts.ts
new file mode 100644
index 0000000..7dea370
--- /dev/null
+++ b/src/lib/consts.ts
@@ -0,0 +1,2 @@
+export const PUBLISH_DISCLAIMER =
+ 'Прочитайте правила, прежде чем загружать. После публикации требуется одобрение модератора. Одобрение может занять до 14 дней, не связывайтесь с модерацией по этому поводу. Нажимая "опубликовать", вы подтверждаете, что прочитали наши правила и понимаете, что не можете удалить свою собственную загрузку, если вы не являетесь автором контента.';
diff --git a/src/lib/contexts/Auth.context.tsx b/src/lib/contexts/Auth.context.tsx
new file mode 100644
index 0000000..ff2d369
--- /dev/null
+++ b/src/lib/contexts/Auth.context.tsx
@@ -0,0 +1,37 @@
+'use client';
+
+import React, { createContext, use } from 'react';
+
+type User = {
+ id: string;
+ avatar?: string;
+ // Чёто там ещё
+};
+
+interface AuthContext {
+ user: User | null;
+}
+
+const AuthContext = createContext<AuthContext | null>(null);
+
+export const AuthContextProvider = ({ children }: React.PropsWithChildren) => {
+ // TODO: подключить бэк
+ const user = null;
+ return (
+ <AuthContext.Provider value={{ user }}>{children}</AuthContext.Provider>
+ );
+};
+
+export const useAuthContext = () => {
+ const context = use(AuthContext);
+
+ if (!context) {
+ throw new Error(
+ 'useAuthContext must be used within AuthContextProvider',
+ );
+ }
+
+ return context;
+};
+
+export const useUser = () => useAuthContext().user;
diff --git a/src/lib/contexts/Global.context.tsx b/src/lib/contexts/Global.context.tsx
new file mode 100644
index 0000000..3f8b61b
--- /dev/null
+++ b/src/lib/contexts/Global.context.tsx
@@ -0,0 +1,8 @@
+import React from 'react';
+import { AuthContextProvider } from './Auth.context';
+
+export const GlobalContextProvider = ({
+ children,
+}: React.PropsWithChildren) => {
+ return <AuthContextProvider>{children}</AuthContextProvider>;
+};
diff --git a/src/lib/contexts/index.ts b/src/lib/contexts/index.ts
new file mode 100644
index 0000000..61ebbe8
--- /dev/null
+++ b/src/lib/contexts/index.ts
@@ -0,0 +1,2 @@
+export * from './Auth.context';
+export * from './Global.context';
diff --git a/src/lib/utils.ts b/src/lib/utils.ts
new file mode 100644
index 0000000..bd0c391
--- /dev/null
+++ b/src/lib/utils.ts
@@ -0,0 +1,6 @@
+import { clsx, type ClassValue } from "clsx"
+import { twMerge } from "tailwind-merge"
+
+export function cn(...inputs: ClassValue[]) {
+ return twMerge(clsx(inputs))
+}