mirror of
https://github.com/bubblecup-12/VogelSocialMedia.git
synced 2025-07-07 06:08:54 +00:00
New Componen, Avatar
This commit is contained in:
parent
e1b894452f
commit
1966eddb99
4 changed files with 137 additions and 74 deletions
51
code/frontend/src/components/UserAvatar.tsx
Normal file
51
code/frontend/src/components/UserAvatar.tsx
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
import { Avatar, Box, Typography } from "@mui/material";
|
||||||
|
import api from "../api/axios";
|
||||||
|
import { useState,useEffect } from "react";
|
||||||
|
|
||||||
|
interface UserAvatarProps {
|
||||||
|
username: string|null;
|
||||||
|
src?: string;
|
||||||
|
size?: number | string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export default function UserAvatar({ username, size = 40 }: UserAvatarProps) {
|
||||||
|
const[pb, setPb] = useState<string>();
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
(async () => {
|
||||||
|
try {
|
||||||
|
const res = await api.get(`/profile/getProfilePicture/${username}`)
|
||||||
|
setPb(res.data.url);
|
||||||
|
} catch (error) {
|
||||||
|
console.log(error);
|
||||||
|
}
|
||||||
|
})();
|
||||||
|
}, [username]);
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Box sx={{ display: "flex", alignItems: "center", gap: 1 }}>
|
||||||
|
<Avatar
|
||||||
|
src={pb}
|
||||||
|
sx={{
|
||||||
|
width: size,
|
||||||
|
height: size,
|
||||||
|
bgcolor: pb ? "transparent" : "primary.main",
|
||||||
|
fontWeight: 500,
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
username[0];
|
||||||
|
</Avatar>
|
||||||
|
<Typography
|
||||||
|
component="span"
|
||||||
|
fontWeight={500}
|
||||||
|
sx={{ whiteSpace: "nowrap", overflow: "hidden", textOverflow: "ellipsis"}}
|
||||||
|
>
|
||||||
|
{username}
|
||||||
|
</Typography>
|
||||||
|
</Box>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
// ---------------- Exemplarische Verwendung ----------------
|
||||||
|
// <UserAvatar username={user?.username ?? "Unknown User"} src={user?.avatarUrl} />
|
||||||
|
// ---------------------------------------------------------
|
0
code/frontend/src/components/userAvatar.css
Normal file
0
code/frontend/src/components/userAvatar.css
Normal file
|
@ -1,35 +1,30 @@
|
||||||
import "./postCreation.css";
|
import "./postCreation.css";
|
||||||
import "./loginAndSignUpPage.css";
|
import "./loginAndSignUpPage.css";
|
||||||
import { useState, useEffect } from 'react';
|
import { useState, useEffect, useRef } from 'react';
|
||||||
import { useNavigate } from "react-router-dom";
|
import { useNavigate } from "react-router-dom";
|
||||||
import Chip from '@mui/material/Chip';
|
import Chip from '@mui/material/Chip';
|
||||||
import Autocomplete from '@mui/material/Autocomplete';
|
import Autocomplete from '@mui/material/Autocomplete';
|
||||||
import TextField from '@mui/material/TextField';
|
import TextField from '@mui/material/TextField';
|
||||||
import Avatar from '@mui/material/Avatar';
|
import Avatar from '@mui/material/Avatar';
|
||||||
import Close from '@mui/icons-material/Close';
|
|
||||||
import ButtonPrimary from "../components/ButtonRotkehlchen";
|
import ButtonPrimary from "../components/ButtonRotkehlchen";
|
||||||
|
|
||||||
import "../styles/sizes.css";
|
|
||||||
import "../styles/fonts.css";
|
|
||||||
|
|
||||||
import AspectRatio from '@mui/joy/AspectRatio';
|
|
||||||
|
|
||||||
import api from "../api/axios";
|
import api from "../api/axios";
|
||||||
import { useAuth } from "../api/Auth";
|
import { useAuth } from "../api/Auth";
|
||||||
import {
|
import {Box,Card,CardMedia,CardActionArea,IconButton} from '@mui/material';
|
||||||
Box,
|
|
||||||
Card,
|
|
||||||
CardMedia,
|
|
||||||
CardActionArea,
|
|
||||||
IconButton,
|
|
||||||
Skeleton,
|
|
||||||
StyledEngineProvider,
|
|
||||||
} from '@mui/material';
|
|
||||||
import CloseIcon from '@mui/icons-material/Close';
|
import CloseIcon from '@mui/icons-material/Close';
|
||||||
|
import { createTheme, ThemeProvider } from '@mui/material/styles';
|
||||||
|
import UserAvatar from "../components/UserAvatar";
|
||||||
|
|
||||||
|
const theme = createTheme({
|
||||||
|
palette: {
|
||||||
|
primary: {
|
||||||
|
main:'#e79a0e;'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
function PostCreation(){
|
function PostCreation(){
|
||||||
const {user} = useAuth();
|
const {user} = useAuth();
|
||||||
|
|
||||||
interface ImageItem {
|
interface ImageItem {
|
||||||
src: string;
|
src: string;
|
||||||
title: string;
|
title: string;
|
||||||
|
@ -43,6 +38,7 @@ function PostCreation(){
|
||||||
const navigate = useNavigate();
|
const navigate = useNavigate();
|
||||||
|
|
||||||
const [fileList,setFileList] = useState<FileList|null>(null);
|
const [fileList,setFileList] = useState<FileList|null>(null);
|
||||||
|
const inputFile = useRef<HTMLInputElement | null>(null);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
let cancelled = false;
|
let cancelled = false;
|
||||||
|
@ -85,6 +81,11 @@ function PostCreation(){
|
||||||
}
|
}
|
||||||
setFileList(files);
|
setFileList(files);
|
||||||
};
|
};
|
||||||
|
const onEmptyImgClick = () =>{
|
||||||
|
if(inputFile.current){
|
||||||
|
inputFile.current?.click();
|
||||||
|
}
|
||||||
|
}
|
||||||
const handleDelete = (idx: number) =>{
|
const handleDelete = (idx: number) =>{
|
||||||
setData((prev) => prev.filter((_, i) => i !== idx));
|
setData((prev) => prev.filter((_, i) => i !== idx));
|
||||||
if((idx-1)<0){
|
if((idx-1)<0){
|
||||||
|
@ -123,23 +124,24 @@ function PostCreation(){
|
||||||
const files = fileList ? [...fileList] : [];
|
const files = fileList ? [...fileList] : [];
|
||||||
|
|
||||||
return(
|
return(
|
||||||
<StyledEngineProvider>
|
<ThemeProvider theme={theme}>
|
||||||
<div className="create-display">
|
<div className="create-display">
|
||||||
<div className="create-part">
|
<div className="create-part">
|
||||||
<form onSubmit={onSubmit}>
|
<form onSubmit={onSubmit}>
|
||||||
<h1>Create Post</h1>
|
<h1>Create Post</h1>
|
||||||
<div className="create-layout">
|
<div className="create-layout">
|
||||||
<div className="create-account">
|
<div className="create-post-desc">
|
||||||
<Avatar >OP</Avatar>
|
<UserAvatar username={user? user.username: ""}/>
|
||||||
<span className="create-username">{user?.username}</span>
|
|
||||||
</div>
|
|
||||||
<div className="create-post1">
|
|
||||||
{selectedImage?
|
{selectedImage?
|
||||||
<img src={selectedImage} className="create-post-image" alt="Add an Image"></img>:
|
<img src={selectedImage} className="create-post-image" alt="Add an Image"></img>:
|
||||||
<Skeleton variant="rectangular" width={'100%'} height={"40vh"} animation= {false}></Skeleton>}
|
<label className="create-post-img-layer" onClick={onEmptyImgClick}>
|
||||||
|
<strong>Add Picture</strong>
|
||||||
|
</label>}
|
||||||
|
</div>
|
||||||
|
<div className="create-post-desc">
|
||||||
|
<h2>Description</h2>
|
||||||
<textarea className="create-post-description" value={description} onChange={handleChange} required></textarea>
|
<textarea className="create-post-description" value={description} onChange={handleChange} required></textarea>
|
||||||
</div>
|
</div>
|
||||||
<div className="create-post2">
|
|
||||||
<Box
|
<Box
|
||||||
sx={{
|
sx={{
|
||||||
display: 'flex',
|
display: 'flex',
|
||||||
|
@ -178,6 +180,7 @@ function PostCreation(){
|
||||||
multiple
|
multiple
|
||||||
onChange={handleImageUpload}
|
onChange={handleImageUpload}
|
||||||
style={{ display: 'none' }}
|
style={{ display: 'none' }}
|
||||||
|
ref={inputFile}
|
||||||
/>
|
/>
|
||||||
</label>
|
</label>
|
||||||
</Card>
|
</Card>
|
||||||
|
@ -234,7 +237,7 @@ function PostCreation(){
|
||||||
freeSolo
|
freeSolo
|
||||||
value={tags}
|
value={tags}
|
||||||
onChange={handleTags}
|
onChange={handleTags}
|
||||||
sx={{ width: "90vw" }}
|
sx={{ width: "100%" }}
|
||||||
renderValue={(value: readonly string[], getItemProps) =>
|
renderValue={(value: readonly string[], getItemProps) =>
|
||||||
value.map((tags: string, index: number) => {
|
value.map((tags: string, index: number) => {
|
||||||
const { key, ...itemProps } = getItemProps({ index });
|
const { key, ...itemProps } = getItemProps({ index });
|
||||||
|
@ -254,15 +257,12 @@ function PostCreation(){
|
||||||
)}
|
)}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div className="create-post3">
|
|
||||||
<ButtonPrimary style="primary" label="Post" type="submit" ></ButtonPrimary>
|
|
||||||
<ButtonPrimary style="secondary" label="Cancel" type="button" onClick={onCancel} ></ButtonPrimary>
|
<ButtonPrimary style="secondary" label="Cancel" type="button" onClick={onCancel} ></ButtonPrimary>
|
||||||
</div>
|
<ButtonPrimary style="primary" label="Post" type="submit" ></ButtonPrimary>
|
||||||
</div>
|
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</StyledEngineProvider>
|
</ThemeProvider>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
export default PostCreation;
|
export default PostCreation;
|
|
@ -9,10 +9,11 @@
|
||||||
align-items: center;
|
align-items: center;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
.create-part{
|
.create-part{
|
||||||
display: flex;
|
display: flex;
|
||||||
height: 100vh;
|
width: 100vw;
|
||||||
width: 100%;
|
height: calc(100vh - var(--Header-height));
|
||||||
padding: 29px 40px;
|
padding: 29px 40px;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
@ -21,41 +22,49 @@
|
||||||
border-left: 4px solid var(--Rotkehlchen-gray-hover);
|
border-left: 4px solid var(--Rotkehlchen-gray-hover);
|
||||||
background: #FFF;
|
background: #FFF;
|
||||||
}
|
}
|
||||||
|
|
||||||
.create-layout{
|
.create-layout{
|
||||||
display: grid;
|
display: grid;
|
||||||
grid-template-columns: auto auto auto;
|
grid-template-columns: 1fr;
|
||||||
|
grid-auto-rows: auto;
|
||||||
|
width: 90vw;
|
||||||
|
gap: 0.5rem;
|
||||||
}
|
}
|
||||||
.create-account{
|
.create-account{
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: row;
|
flex-direction: row;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
width: 100%;
|
||||||
}
|
}
|
||||||
.create-post1{
|
.create-post-desc{
|
||||||
|
width: 100%;
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
gap: 9px;
|
|
||||||
width: 90vw;
|
|
||||||
}
|
}
|
||||||
.create-post-description{
|
.create-post-description{
|
||||||
width: 100%;
|
width: 100%;
|
||||||
accent-color: var(--Rotkehlchen-yellow-default);
|
accent-color: var(--Rotkehlchen-yellow-default);
|
||||||
}
|
resize: none;
|
||||||
.create-post2{
|
height: 100%;
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
width: 100%;
|
|
||||||
gap: 10px;
|
|
||||||
align-items: flex-start;
|
|
||||||
}
|
|
||||||
.create-tags{
|
|
||||||
width: 90vw;
|
|
||||||
}
|
}
|
||||||
.create-post-image{
|
.create-post-image{
|
||||||
height: 40vh;
|
height: 40vh;
|
||||||
width: 90vw;
|
width: 100%;
|
||||||
object-fit: cover;
|
object-fit: cover;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
.create-post-img-layer{
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
align-self: center;
|
||||||
|
justify-content: center;
|
||||||
|
height: 40vh;
|
||||||
|
width: 100%;
|
||||||
|
background-position: center;
|
||||||
|
background-size: cover;
|
||||||
|
overflow: hidden;
|
||||||
|
background-image: url("../../public/assets/images/BirdLogin.jpg");
|
||||||
|
filter: grayscale();
|
||||||
}
|
}
|
||||||
input#create-file-upload[type="file"] {
|
input#create-file-upload[type="file"] {
|
||||||
display: none;
|
display: none;
|
||||||
|
@ -64,14 +73,8 @@ input#create-file-upload[type="file"] {
|
||||||
border: 1px solid #ccc;
|
border: 1px solid #ccc;
|
||||||
padding: 6px 12px;
|
padding: 6px 12px;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
width: 90vw;
|
|
||||||
height: 100px;
|
|
||||||
}
|
|
||||||
.create-post3{
|
|
||||||
display: flex;
|
|
||||||
flex-direction: row-reverse;
|
|
||||||
width: 100%;
|
width: 100%;
|
||||||
align-items: flex-end;
|
height: 100px;
|
||||||
}
|
}
|
||||||
|
|
||||||
@media only screen and (min-width: 768px) {
|
@media only screen and (min-width: 768px) {
|
||||||
|
@ -80,27 +83,26 @@ input#create-file-upload[type="file"] {
|
||||||
padding-bottom: 1rem;
|
padding-bottom: 1rem;
|
||||||
}
|
}
|
||||||
.create-part{
|
.create-part{
|
||||||
|
display: flex;
|
||||||
width: 90vw;
|
width: 90vw;
|
||||||
height: calc(100vh - var(--Header-height));
|
height: calc(100vh - var(--Header-height));
|
||||||
}
|
padding: 29px 40px;
|
||||||
.create-post1{
|
flex-direction: column;
|
||||||
width:70vw;
|
|
||||||
flex-direction: row;
|
|
||||||
|
|
||||||
}
|
|
||||||
.create-post2{
|
|
||||||
display: flex;
|
|
||||||
flex-direction: row;
|
|
||||||
width: 70vw;
|
|
||||||
gap: 10px;
|
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
gap: 10px;
|
||||||
|
border-right: 4px solid var(--Rotkehlchen-gray-hover);
|
||||||
|
border-left: 4px solid var(--Rotkehlchen-gray-hover);
|
||||||
|
background: #FFF;
|
||||||
}
|
}
|
||||||
.create-post-image {
|
.create-post-image {
|
||||||
width: 100%;
|
width: 100%s;
|
||||||
max-width: 600px;
|
max-width: 600px;
|
||||||
display: block;
|
display: block;
|
||||||
margin: 0 auto;
|
margin: 0 auto;
|
||||||
}
|
}
|
||||||
|
.create-post-img-layer{
|
||||||
|
max-width: 600px;
|
||||||
|
}
|
||||||
.create-file-upload {
|
.create-file-upload {
|
||||||
border: 1px solid #ccc;
|
border: 1px solid #ccc;
|
||||||
padding: 6px 12px;
|
padding: 6px 12px;
|
||||||
|
@ -111,4 +113,14 @@ input#create-file-upload[type="file"] {
|
||||||
.create-tags{
|
.create-tags{
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
|
.create-layout{
|
||||||
|
display: grid;
|
||||||
|
grid-template-columns: 50% auto;
|
||||||
|
grid-auto-rows: auto;
|
||||||
|
margin: 0 ;
|
||||||
|
width: 88vw;
|
||||||
|
}
|
||||||
|
.create-post-desc{
|
||||||
|
height: 40vh;
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Add table
Add a link
Reference in a new issue