aaa
This commit is contained in:
@ -7,6 +7,7 @@ import Register from './components/Register';
|
||||
import Home from './components/Home';
|
||||
import Dog from './components/Dog';
|
||||
import {UserCtx, UserCtxT} from './context/UserContext';
|
||||
import Qr from './components/Qr';
|
||||
|
||||
|
||||
function App()
|
||||
@ -20,8 +21,9 @@ function App()
|
||||
<Routes>
|
||||
{user && <Route path="/" element={<Home/>} />}
|
||||
{!user && <Route path="/" element={<Login/>} />}
|
||||
<Route path="/:qr_id" element={<Dog/>} />
|
||||
{user && <Route path="/qr" element={<Qr/>} />}
|
||||
{user && <Route path="/d" element={<Dog/>} />}
|
||||
<Route path="/:qr_id" element={<Dog/>} />
|
||||
<Route path="/login" element={<Login/>} />
|
||||
<Route path="/reg" element={<Register/>} />
|
||||
</Routes>
|
||||
|
||||
@ -4,7 +4,7 @@ export default function Img({pth}: {pth: string})
|
||||
{
|
||||
return (
|
||||
<div>
|
||||
<img src={'./uploads' + pth} width="300" />
|
||||
<img src={'./uploads' + pth} />
|
||||
</div>
|
||||
)
|
||||
}
|
||||
|
||||
49
src/components/Qr.css
Normal file
49
src/components/Qr.css
Normal file
@ -0,0 +1,49 @@
|
||||
|
||||
img
|
||||
{
|
||||
width: 2.4cm;
|
||||
background: #ffffff;
|
||||
}
|
||||
.qrCode
|
||||
{
|
||||
align-items: center;
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
height: 3.7cm;
|
||||
justify-content: space-evenly;
|
||||
background: #fff;
|
||||
width: 2.4cm;
|
||||
}
|
||||
.qrCodeBackFront
|
||||
{
|
||||
display: flex;
|
||||
flex-direction: row;
|
||||
|
||||
}
|
||||
|
||||
.vertFont
|
||||
{
|
||||
writing-mode: vertical-lr;
|
||||
}
|
||||
|
||||
.qrCodeVert
|
||||
{
|
||||
align-items: center;
|
||||
display: flex;
|
||||
flex-direction: row-reverse;
|
||||
height: 3.7cm;
|
||||
justify-content: space-evenly;
|
||||
background: #fff;
|
||||
width: 2.4cm;
|
||||
}
|
||||
.frame
|
||||
{
|
||||
border-style: solid;
|
||||
border-width: 1px;
|
||||
}
|
||||
.blockRepeat
|
||||
{
|
||||
display: flex;
|
||||
flex-direction: row;
|
||||
flex-wrap: wrap;
|
||||
}
|
||||
120
src/components/Qr.tsx
Normal file
120
src/components/Qr.tsx
Normal file
@ -0,0 +1,120 @@
|
||||
import React, { useContext } from 'react'
|
||||
import { UserCtx, UserCtxT, DogT } from '../context/UserContext';
|
||||
import Img from './Img';
|
||||
import './Qr.css';
|
||||
|
||||
export default function Qr()
|
||||
{
|
||||
const {dog, getDog, user} = useContext<UserCtxT | null>(UserCtx) as UserCtxT;
|
||||
var needData = dog.success === undefined;
|
||||
if(needData)
|
||||
{
|
||||
if(user)
|
||||
{
|
||||
getDog(user?.qr_id); // await not allowed?! => workaraound
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
return (
|
||||
<>
|
||||
{user && dog.data &&
|
||||
<div>
|
||||
<h1>Qr-Code Druck</h1>
|
||||
{/* <div>Logged in als:</div>
|
||||
<div>{user?.email}</div>
|
||||
<div>{user?.qr_id}</div>
|
||||
<div>{dog.data.qr_code}</div> */}
|
||||
|
||||
<div className='blockRepeat'>
|
||||
<div className='qrCodeBackFront'>
|
||||
<div className='qrCode frame'>
|
||||
<div className='qrCode__'>SCAN ME</div>
|
||||
<Img pth={dog.data.qr_code}/>
|
||||
</div>
|
||||
<div className='qrCodeVert frame'>
|
||||
{/* <div className='vertFont'>{dog.data.phone}</div>
|
||||
<div className='vertFont'>{dog.data.email}</div> */}
|
||||
<div className='vertFont'>{dog.data.name}</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
<div className='qrCodeBackFront'>
|
||||
<div className='qrCode frame'>
|
||||
<div className='qrCode__'>SCAN ME</div>
|
||||
<Img pth={dog.data.qr_code}/>
|
||||
</div>
|
||||
<div className='qrCodeVert frame'>
|
||||
<div className='vertFont'>{dog.data.phone}</div>
|
||||
{/* <div className='vertFont'>{dog.data.email}</div> */}
|
||||
<div className='vertFont'>{dog.data.name}</div>
|
||||
</div>
|
||||
</div>
|
||||
<div className='qrCodeBackFront'>
|
||||
<div className='qrCode frame'>
|
||||
<div className='qrCode__'>SCAN ME</div>
|
||||
<Img pth={dog.data.qr_code}/>
|
||||
</div>
|
||||
<div className='qrCodeVert frame'>
|
||||
{/* <div className='vertFont'>{dog.data.phone}</div> */}
|
||||
<div className='vertFont'>{dog.data.email}</div>
|
||||
<div className='vertFont'>{dog.data.name}</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
<div className='qrCodeBackFront'>
|
||||
<div className='qrCode frame'>
|
||||
<div className='qrCode__'>SCAN ME</div>
|
||||
<Img pth={dog.data.qr_code}/>
|
||||
</div>
|
||||
<div className='qrCodeVert frame'>
|
||||
<div className='vertFont'>{dog.data.phone}</div>
|
||||
{/* <div className='vertFont'>{dog.data.email}</div>
|
||||
<div className='vertFont'>{dog.data.name}</div> */}
|
||||
</div>
|
||||
</div>
|
||||
<div className='qrCodeBackFront'>
|
||||
<div className='qrCode frame'>
|
||||
<div className='qrCode__'>SCAN ME</div>
|
||||
<Img pth={dog.data.qr_code}/>
|
||||
</div>
|
||||
<div className='qrCodeVert frame'>
|
||||
<div className='vertFont'>{dog.data.phone}</div>
|
||||
<div className='vertFont'>{dog.data.email}</div>
|
||||
{/* <div className='vertFont'>{dog.data.name}</div> */}
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
<div className='qrCodeBackFront'>
|
||||
<div className='qrCode frame'>
|
||||
<div className='qrCode__'>SCAN ME</div>
|
||||
<Img pth={dog.data.qr_code}/>
|
||||
</div>
|
||||
<div className='qrCodeVert frame'>
|
||||
<div className='vertFont'>{dog.data.phone}</div>
|
||||
<div className='vertFont'>{dog.data.email}</div>
|
||||
<div className='vertFont'>{dog.data.name}</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div> }
|
||||
{/* { !dog.data && user &&
|
||||
<>
|
||||
<h1>Qr-Code Druck</h1>
|
||||
<div>Logged in als:</div>
|
||||
<div>{user?.email}</div>
|
||||
<div>{user?.qr_id}</div>
|
||||
</>
|
||||
} */}
|
||||
{ !dog.data && !user &&
|
||||
<>
|
||||
<h1>Qr-Code Druck</h1>
|
||||
<div>nothing</div>
|
||||
</>
|
||||
}
|
||||
</>
|
||||
)
|
||||
}
|
||||
@ -74,8 +74,9 @@ export type UserCtxT =
|
||||
export const UserCtx = createContext<UserCtxT | null>(null);
|
||||
|
||||
export const Axios = axios.create({
|
||||
baseURL: 'http://localhost/dog/php-dog/',
|
||||
// baseURL: 'https://hope-fly.de/dog/php-dog/',
|
||||
// baseURL: 'http://localhost/dog/php-dog/',
|
||||
baseURL: 'https://hope-fly.de/dog/php-dog/',
|
||||
// baseURL: process.env.REACT_APP_PHP_ROOT,
|
||||
});
|
||||
|
||||
export const UserCtxProvider = ({children}:TUserContextProviderProps) => {
|
||||
|
||||
Reference in New Issue
Block a user