Create state/container for share modals
This commit is contained in:
parent
aabe66f202
commit
76a6f40e77
@ -14,7 +14,7 @@ const eslintConfig = [
|
|||||||
rules: {
|
rules: {
|
||||||
'@next/next/no-img-element': 'off',
|
'@next/next/no-img-element': 'off',
|
||||||
'@typescript-eslint/no-explicit-any': 'off',
|
'@typescript-eslint/no-explicit-any': 'off',
|
||||||
'no-unused-expressions': 'warn',
|
'no-unused-expressions': ['warn'],
|
||||||
'@typescript-eslint/no-unused-vars': [
|
'@typescript-eslint/no-unused-vars': [
|
||||||
'warn', {
|
'warn', {
|
||||||
'argsIgnorePattern': '^_',
|
'argsIgnorePattern': '^_',
|
||||||
|
|||||||
@ -19,6 +19,7 @@ import Footer from '@/site/Footer';
|
|||||||
import CommandK from '@/site/CommandK';
|
import CommandK from '@/site/CommandK';
|
||||||
import SwrConfigClient from '../state/SwrConfigClient';
|
import SwrConfigClient from '../state/SwrConfigClient';
|
||||||
import AdminBatchEditPanel from '@/admin/AdminBatchEditPanel';
|
import AdminBatchEditPanel from '@/admin/AdminBatchEditPanel';
|
||||||
|
import ShareModals from '@/share/ShareModals';
|
||||||
|
|
||||||
import '../site/globals.css';
|
import '../site/globals.css';
|
||||||
import '../site/sonner.css';
|
import '../site/sonner.css';
|
||||||
@ -97,6 +98,7 @@ export default function RootLayout({
|
|||||||
'min-h-[16rem] sm:min-h-[30rem]',
|
'min-h-[16rem] sm:min-h-[30rem]',
|
||||||
'mb-12',
|
'mb-12',
|
||||||
)}>
|
)}>
|
||||||
|
<ShareModals />
|
||||||
{children}
|
{children}
|
||||||
</div>
|
</div>
|
||||||
<Footer />
|
<Footer />
|
||||||
|
|||||||
38
src/share/ShareModals.tsx
Normal file
38
src/share/ShareModals.tsx
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
'use client';
|
||||||
|
|
||||||
|
import PhotoShareModal from '@/photo/PhotoShareModal';
|
||||||
|
import TagShareModal from '@/tag/TagShareModal';
|
||||||
|
import CameraShareModal from '@/camera/CameraShareModal';
|
||||||
|
import FilmSimulationShareModal from '@/simulation/FilmSimulationShareModal';
|
||||||
|
import FocalLengthShareModal from '@/focal/FocalLengthShareModal';
|
||||||
|
import { useAppState } from '@/state/AppState';
|
||||||
|
|
||||||
|
export default function ShareModals() {
|
||||||
|
const { shareModalProps = {} } = useAppState();
|
||||||
|
|
||||||
|
const {
|
||||||
|
photo,
|
||||||
|
photos,
|
||||||
|
count,
|
||||||
|
dateRange,
|
||||||
|
tag,
|
||||||
|
camera,
|
||||||
|
simulation,
|
||||||
|
focal,
|
||||||
|
} = shareModalProps;
|
||||||
|
|
||||||
|
if (photo) {
|
||||||
|
return <PhotoShareModal {...{photo, tag, camera, simulation, focal}} />;
|
||||||
|
} else if (photos) {
|
||||||
|
const attributes = {photos, count, dateRange};
|
||||||
|
if (tag) {
|
||||||
|
return <TagShareModal {...{tag, ...attributes}} />;
|
||||||
|
} else if (camera) {
|
||||||
|
return <CameraShareModal {...{camera, ...attributes}} />;
|
||||||
|
} else if (simulation) {
|
||||||
|
return <FilmSimulationShareModal {...{simulation, ...attributes}} />;
|
||||||
|
} else if (focal !== undefined) {
|
||||||
|
return <FocalLengthShareModal {...{focal, ...attributes}} />;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
6
src/share/index.ts
Normal file
6
src/share/index.ts
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
import { Photo, PhotoSetAttributes, PhotoSetCategory } from '@/photo';
|
||||||
|
|
||||||
|
export type ShareModalProps = Omit<PhotoSetAttributes, 'photos'> & {
|
||||||
|
photo?: Photo
|
||||||
|
photos?: Photo[]
|
||||||
|
} & PhotoSetCategory;
|
||||||
@ -1,5 +1,6 @@
|
|||||||
import { Dispatch, SetStateAction, createContext, useContext } from 'react';
|
import { Dispatch, SetStateAction, createContext, useContext } from 'react';
|
||||||
import { AnimationConfig } from '@/components/AnimateItems';
|
import { AnimationConfig } from '@/components/AnimateItems';
|
||||||
|
import { ShareModalProps } from '@/share';
|
||||||
|
|
||||||
export interface AppStateContext {
|
export interface AppStateContext {
|
||||||
// GLOBAL
|
// GLOBAL
|
||||||
@ -16,6 +17,8 @@ export interface AppStateContext {
|
|||||||
// MODAL
|
// MODAL
|
||||||
isCommandKOpen?: boolean
|
isCommandKOpen?: boolean
|
||||||
setIsCommandKOpen?: Dispatch<SetStateAction<boolean>>
|
setIsCommandKOpen?: Dispatch<SetStateAction<boolean>>
|
||||||
|
shareModalProps?: ShareModalProps
|
||||||
|
setShareModalProps?: Dispatch<SetStateAction<ShareModalProps | undefined>>
|
||||||
// ADMIN
|
// ADMIN
|
||||||
userEmail?: string
|
userEmail?: string
|
||||||
setUserEmail?: Dispatch<SetStateAction<string | undefined>>
|
setUserEmail?: Dispatch<SetStateAction<string | undefined>>
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user