From c268acdb120ba8fc92b9280baf5690bae693f200 Mon Sep 17 00:00:00 2001 From: takasuka_takumi Date: Wed, 20 Sep 2023 13:08:46 +0900 Subject: [PATCH 1/3] =?UTF-8?q?=E3=83=A1=E3=83=B3=E3=83=90=E3=83=BC?= =?UTF-8?q?=E8=A9=B3=E7=B4=B0=E3=83=A2=E3=83=BC=E3=83=80=E3=83=AB=E3=81=AE?= =?UTF-8?q?=E4=BD=9C=E6=88=90?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../next-project/public/MemberModalFooter.svg | 47 +++ .../next-project/public/MemberModalHeader.svg | 17 ++ view/next-project/public/NoUser.svg | 3 + .../UserDetailModal.module.css | 283 ++++++++++++++++++ .../UserDetailModal/UserDetailModal.tsx | 165 ++++++++++ .../common/UserDetailModal/index.ts | 1 + view/next-project/src/pages/users/index.tsx | 65 ++-- 7 files changed, 564 insertions(+), 17 deletions(-) create mode 100644 view/next-project/public/MemberModalFooter.svg create mode 100644 view/next-project/public/MemberModalHeader.svg create mode 100644 view/next-project/public/NoUser.svg create mode 100644 view/next-project/src/components/common/UserDetailModal/UserDetailModal.module.css create mode 100644 view/next-project/src/components/common/UserDetailModal/UserDetailModal.tsx create mode 100644 view/next-project/src/components/common/UserDetailModal/index.ts diff --git a/view/next-project/public/MemberModalFooter.svg b/view/next-project/public/MemberModalFooter.svg new file mode 100644 index 0000000..38ae6dd --- /dev/null +++ b/view/next-project/public/MemberModalFooter.svg @@ -0,0 +1,47 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/view/next-project/public/MemberModalHeader.svg b/view/next-project/public/MemberModalHeader.svg new file mode 100644 index 0000000..5c2ad64 --- /dev/null +++ b/view/next-project/public/MemberModalHeader.svg @@ -0,0 +1,17 @@ + + + + + + + + + + + + + + + + + diff --git a/view/next-project/public/NoUser.svg b/view/next-project/public/NoUser.svg new file mode 100644 index 0000000..c869be2 --- /dev/null +++ b/view/next-project/public/NoUser.svg @@ -0,0 +1,3 @@ + + + diff --git a/view/next-project/src/components/common/UserDetailModal/UserDetailModal.module.css b/view/next-project/src/components/common/UserDetailModal/UserDetailModal.module.css new file mode 100644 index 0000000..3a19346 --- /dev/null +++ b/view/next-project/src/components/common/UserDetailModal/UserDetailModal.module.css @@ -0,0 +1,283 @@ + +.modalContainer { + top: 0; + left: 0; + position: fixed; + padding: 100px; + height: 100vh; + width: 100%; + z-index: 11; + background-color: rgba(51, 51, 51, 0.3); + } + + .modalInnerContainer { + width: 100%; + min-height: 100%; + display: flex; + justify-content: center; + align-items: center; + pointer-events: none; + } + + .modalTakumi { + position: absolute; + width: 50vw; + height: 80vh; + } + + .imgg { + vertical-align:top; + } + + .modalContent { + position: absolute; + width: 50vw; + height: 80vh; + display: flex; + flex-flow: column; + padding: 50px 70px 150px 70px; + color: var(--accent-7); + border-radius: var(--card-radius); + background: #FFF9F5; + backdrop-filter: blur(10px); + gap: 30px; + overflow-y: auto; + overscroll-behavior-y: none; + pointer-events:auto; + /*スクロールバー非表示(IE・Edge)*/ + -ms-overflow-style: none; + /*スクロールバー非表示(Firefox)*/ + scrollbar-width: none; + } + + /*スクロールバー非表示(Chrome・Safari)*/ + .modalContent::-webkit-scrollbar{ + display:none; + } + + .contentsTitle { + width: 100%; + display: flex; + justify-content: start; + align-items: start; + flex-flow: row; + flex-wrap: nowrap; + } + + .modalContentContents { + width: 100%; + display: flex; + justify-content: start; + align-items: start; + flex-flow: row; + flex-wrap: nowrap; + } + + .graduationAssignmentMde { + width: 100%; + } + + .graduationAssignmentMde span { + font-size: 16px; + background-color: #fff; + } + + .modalContent input { + font-size: 1.6rem; + width: 100%; + letter-spacing: 1px; + color: var(--accent-6); + background: none; + border: 1px solid var(--accent-4); + padding: 10px; + } + + .modalContent input:focus { + border: 1px solid var(--button-secondary); + z-index: 10; + outline: 0; + } + + .modalContent textarea { + font-size: 1.6rem; + width: 50%; + height: 50rem; + color: var(--accent-6); + background: none; + border: 1px solid var(--accent-4); + padding: 10px; + } + + .modalContent textarea:focus { + border: 1px solid var(--button-secondary); + z-index: 10; + outline: 0; + } + + .modalContent select { + font-size: 1.6rem; + width: 100%; + letter-spacing: 1px; + color: var(--accent-6); + background: none; + border: 1px solid var(--accent-4); + padding: 10px; + } + + .modalContent select:focus { + border: 1px solid var(--button-secondary); + z-index: 10; + outline: 0; + } + + .modalName { + display: flex; + justify-content: center; + align-items: center; + } + + .modalContentClose { + display: flex; + justify-content: start; + align-items: start; + } + + .modalContentCloseIcon { + background: none; + border: none; + margin: -20px; + border-radius: var(--button-radius); + text-align: center; + font-size: 2.8rem; + color: var(--button-secondary); + display: flex; + justify-content: center; + align-items: center; + } + + .modalSubmitButton { + display: flex; + justify-content: center; + align-items: center; + } + + .modalDetail { + margin-top: 50px; + } + + .img { + border-radius: 50%; + width: 180px; + height: 180px; + } + + .wrapper { + display: flex; + justify-content: center + } + + .box1 { + grid-column: 2 / 4; + grid-row: 1; + margin-right:50px; + } + + .box2 { + grid-column: 1; + grid-row: 1 / 3; + display: flex; + flex-direction: column; + justify-content: center; + } + + .username { + border-bottom: solid 2px #000000; + font-size: 40px; + font-weight: bold; + } + + .userrole { + margin-top: 10px; + font-size: 20px; + font-weight: bold; + } + + .userProjects h3 { + font-size: 20px; + font-weight: bold; + } + + .userProjects p { + font-size: 16px; + font-weight: lighter; + } + + .userSkills h3 { + font-size: 20px; + font-weight: bold; + } + + .userSkills p { + font-size: 16px; + font-weight: lighter; + } + + .userRecords h3 { + font-size: 20px; + font-weight: bold; + } + + .userRecords p { + font-size: 16px; + font-weight: lighter; + } + + .box3 { + display: flex; + width: 90%; + margin: 0 auto; + } + + .box4 { + display: flex; + width: 90%; + margin: 0 auto; + } + + .card { + padding: 0.5em 1em; + margin: 2em 1rem; + font-weight: bold; + color: #505050; + background: #FFF9F5; + border: solid 4px #FFAC5D; + border-radius: 10px; + display: flex; + justify-content: center; + align-items: center + } + + .card p { + margin: 0; + padding: 0; + } + + .box5 { + width: 86%; + margin: 0 auto; + } + + .record_card { + padding: 0.5em 1em; + margin: 2em 0; + font-weight: bold; + color: #505050; + background: #FFF9F5; + border-bottom: dashed 2px #FFAC5D; + width: 100%; + } + + .record_card p { + margin: 0; + padding: 0; + } \ No newline at end of file diff --git a/view/next-project/src/components/common/UserDetailModal/UserDetailModal.tsx b/view/next-project/src/components/common/UserDetailModal/UserDetailModal.tsx new file mode 100644 index 0000000..3c2133e --- /dev/null +++ b/view/next-project/src/components/common/UserDetailModal/UserDetailModal.tsx @@ -0,0 +1,165 @@ +import React from 'react'; +import s from './UserDetailModal.module.css'; +import styled from 'styled-components'; + +type User = { + id: number; + provider: string; + uid: string; + allow_password_change: boolean; + name: string; + email: string; + created_at: string; + updated_at: string; +} + +interface Type { + id: string; + name: string; + created_at: string; + updated_at: string; + } + +type UserDetail = { + icon_name: string; + github: string; + slack: string; + biography: string; + pc_name: string; + pc_os: string; + pc_cpu: string; + pc_ram: string; + pc_storage: string; + type: Type; +}; + +type Project = { + id: number; + project: string; + role: string; +}; + +type Record = { + id: number; + title: string; + teacher: User; +}; + +type Skill = { + id: number; + name: string; + category: string; +}; + +type UserDetailModalProps = { + onClose: () => void; + user: User; + userDetail: UserDetail; + userProject?: Project[] | null; + userSkill?: Skill[] | null; + userRecord?: Record[] | null; +}; + +const UserDetailModal: React.FC = (props) => { + const { user, userDetail, userProject, userSkill, userRecord } = props; + + const handleOutsideClick = (e: React.MouseEvent) => { + if (e.target === e.currentTarget) { + props.onClose(); + } + } + const MemberHeaderContainer = styled.div` + z-index: 30; + position: absolute; + top: 0; + left: 0; + text-align:center; + `; + const MemberFooterContainer = styled.div` + z-index: 30; + position: absolute; + right: 0; + bottom: 0; + text-align:center; + `; + + return ( +
+ +
+ +
+ + + + + +
+ +
+ +
+
+ +
+
+

{user.name}

+

{userDetail.type.name}

+
+
+ + {userProject && ( +
+

Projects

+
+ {userProject.map(project => ( +
+

{project.project}

+
+ ))} +
+
+ )} + + {userSkill && ( +
+

Skills

+
+ {userSkill.map(skill => ( +
+

{skill.name}

+
+ ))} +
+
+ )} + + {userRecord && ( +
+

Records

+
+ {userRecord.map(record => ( +
+

{record.title}

+
+ ))} +
+
+ )} +
+ +
+ + + + + +
+ +
+ +
+ ); +} + +export default UserDetailModal; diff --git a/view/next-project/src/components/common/UserDetailModal/index.ts b/view/next-project/src/components/common/UserDetailModal/index.ts new file mode 100644 index 0000000..2c75cc4 --- /dev/null +++ b/view/next-project/src/components/common/UserDetailModal/index.ts @@ -0,0 +1 @@ +export { default } from './UserDetailModal' \ No newline at end of file diff --git a/view/next-project/src/pages/users/index.tsx b/view/next-project/src/pages/users/index.tsx index de708c4..bb0cec2 100644 --- a/view/next-project/src/pages/users/index.tsx +++ b/view/next-project/src/pages/users/index.tsx @@ -5,16 +5,37 @@ import styled from 'styled-components'; import AccountCircle from '@components/icons/AccountCircle'; import UserBackgroundAnimation from '@components/common/UsersBackgroundAnimation/UsersBackgroundAnimation'; import MemberSearchButton from '@components/common/MemberSearchButton'; - +import React, { useState } from 'react'; +import OpenUserDetailModal from '@components/common/UserDetailModal/UserDetailModal'; interface Props { userDetails: UserDetails[]; } - interface UserDetails { user: User; detail: UserDetail; + type: Type; + projects: Project[]; + records: Record[]; + skills: Skill[]; +} + +interface Project { + id: number; + project: string; + role: string; } +interface Record { + id: number; + title: string; + teacher: User; +} + +interface Skill { + id: number; + name: string; + category: string; +} interface User { id: number; provider: string; @@ -25,35 +46,30 @@ interface User { created_at: string; updated_at: string; } - interface Grade { id: string; name: string; created_at: string; updated_at: string; } - interface Department { id: string; name: string; created_at: string; updated_at: string; } - interface Bureau { id: string; name: string; created_at: string; updated_at: string; } - interface Type { id: string; name: string; created_at: string; updated_at: string; } - interface UserDetail { grade: Grade; department: Department; @@ -69,9 +85,8 @@ interface UserDetail { pc_storage: string; type: Type; } - export async function getServerSideProps() { - const getUrl = process.env.SSR_API_URI + '/api/v1/get_users_for_user_page'; + const getUrl = process.env.SSR_API_URI + '/api/v1/get_users_for_member_page'; const json = await get(getUrl); return { props: { @@ -79,10 +94,8 @@ export async function getServerSideProps() { }, }; } - export default function UserList(props: Props) { const accountCircleColor = '#636363'; - const UserListContainer = styled.div` display: flex; flex-wrap: wrap; @@ -165,7 +178,6 @@ export default function UserList(props: Props) { z-index: 2; display: flex; `; - const MemberPageTitle = styled.div` position: fixed; top: 11%; @@ -179,7 +191,6 @@ export default function UserList(props: Props) { color: #ffffff; text-align: center; `; - const TopSearchButton = styled.div` position: fixed; top: 15%; @@ -194,8 +205,28 @@ export default function UserList(props: Props) { transform: translate(-50%, -50%); z-index: 9; `; - const router = useRouter(); + const [isOpenUserDetailModal, setIsOpenUserDetailModal] = useState(false); + const [currentUser, setCurrentUser] = useState(null); + const [currentDetail, setCurrentDetail] = useState(null); + const [currentProjects, setCurrentProjects] = useState(null); + const [currentRecords, setCurrentRecords] = useState(null); + const [currentSkills, setCurrentSkills] = useState(null); + const onOpen = () => { + setIsOpenUserDetailModal(true); + }; + const onClose = () => { + setIsOpenUserDetailModal(false); + }; + + const handleCardClick = (userDetail: UserDetails) => { + setCurrentUser(userDetail.user); + setCurrentDetail(userDetail.detail); + setCurrentProjects(userDetail.projects); + setCurrentRecords(userDetail.records); + setCurrentSkills(userDetail.skills); + setIsOpenUserDetailModal(true); + }; const userContent = (userDetail: any) => { return ( @@ -211,7 +242,6 @@ export default function UserList(props: Props) { - {userDetail.user.name ? userDetail.user.name : ''} {userDetail.detail.type.name ? userDetail.detail.type.name : ''} @@ -222,7 +252,6 @@ export default function UserList(props: Props) { ); }; - return ( Members @@ -234,11 +263,13 @@ export default function UserList(props: Props) { {props.userDetails.map((userDetail) => ( -
router.push(`users/${userDetail.user.id}`)}> +
handleCardClick(userDetail)}> {userContent(userDetail)}
))} + {isOpenUserDetailModal && currentUser && currentDetail && + } From 1e0a8a8a80f1121d44ba3a3ab5ccf67382a92888 Mon Sep 17 00:00:00 2001 From: takasuka_takumi Date: Wed, 20 Sep 2023 21:59:26 +0900 Subject: [PATCH 2/3] =?UTF-8?q?=E8=BF=BD=E5=8A=A0=E8=A8=82=E6=AD=A3?= =?UTF-8?q?=E3=80=81=E3=83=A1=E3=83=B3=E3=83=90=E3=83=BC=E8=A9=B3=E7=B4=B0?= =?UTF-8?q?=E3=83=A2=E3=83=BC=E3=83=80=E3=83=AB=E3=81=AE=E4=BD=9C=E6=88=90?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../UserDetailModal.module.css | 577 +++++++++--------- .../UserDetailModal/UserDetailModal.tsx | 121 ++-- 2 files changed, 346 insertions(+), 352 deletions(-) diff --git a/view/next-project/src/components/common/UserDetailModal/UserDetailModal.module.css b/view/next-project/src/components/common/UserDetailModal/UserDetailModal.module.css index 3a19346..277ad87 100644 --- a/view/next-project/src/components/common/UserDetailModal/UserDetailModal.module.css +++ b/view/next-project/src/components/common/UserDetailModal/UserDetailModal.module.css @@ -1,283 +1,296 @@ - .modalContainer { - top: 0; - left: 0; - position: fixed; - padding: 100px; - height: 100vh; - width: 100%; - z-index: 11; - background-color: rgba(51, 51, 51, 0.3); - } - - .modalInnerContainer { - width: 100%; - min-height: 100%; - display: flex; - justify-content: center; - align-items: center; - pointer-events: none; - } - - .modalTakumi { - position: absolute; - width: 50vw; - height: 80vh; - } - - .imgg { - vertical-align:top; - } - - .modalContent { - position: absolute; - width: 50vw; - height: 80vh; - display: flex; - flex-flow: column; - padding: 50px 70px 150px 70px; - color: var(--accent-7); - border-radius: var(--card-radius); - background: #FFF9F5; - backdrop-filter: blur(10px); - gap: 30px; - overflow-y: auto; - overscroll-behavior-y: none; - pointer-events:auto; - /*スクロールバー非表示(IE・Edge)*/ - -ms-overflow-style: none; - /*スクロールバー非表示(Firefox)*/ - scrollbar-width: none; - } - - /*スクロールバー非表示(Chrome・Safari)*/ - .modalContent::-webkit-scrollbar{ - display:none; - } - - .contentsTitle { - width: 100%; - display: flex; - justify-content: start; - align-items: start; - flex-flow: row; - flex-wrap: nowrap; - } - - .modalContentContents { - width: 100%; - display: flex; - justify-content: start; - align-items: start; - flex-flow: row; - flex-wrap: nowrap; - } - - .graduationAssignmentMde { - width: 100%; - } - - .graduationAssignmentMde span { - font-size: 16px; - background-color: #fff; - } - - .modalContent input { - font-size: 1.6rem; - width: 100%; - letter-spacing: 1px; - color: var(--accent-6); - background: none; - border: 1px solid var(--accent-4); - padding: 10px; - } - - .modalContent input:focus { - border: 1px solid var(--button-secondary); - z-index: 10; - outline: 0; - } - - .modalContent textarea { - font-size: 1.6rem; - width: 50%; - height: 50rem; - color: var(--accent-6); - background: none; - border: 1px solid var(--accent-4); - padding: 10px; - } - - .modalContent textarea:focus { - border: 1px solid var(--button-secondary); - z-index: 10; - outline: 0; - } - - .modalContent select { - font-size: 1.6rem; - width: 100%; - letter-spacing: 1px; - color: var(--accent-6); - background: none; - border: 1px solid var(--accent-4); - padding: 10px; - } - - .modalContent select:focus { - border: 1px solid var(--button-secondary); - z-index: 10; - outline: 0; - } - - .modalName { - display: flex; - justify-content: center; - align-items: center; - } - - .modalContentClose { - display: flex; - justify-content: start; - align-items: start; - } - - .modalContentCloseIcon { - background: none; - border: none; - margin: -20px; - border-radius: var(--button-radius); - text-align: center; - font-size: 2.8rem; - color: var(--button-secondary); - display: flex; - justify-content: center; - align-items: center; - } - - .modalSubmitButton { - display: flex; - justify-content: center; - align-items: center; - } - - .modalDetail { - margin-top: 50px; - } - - .img { - border-radius: 50%; - width: 180px; - height: 180px; - } - - .wrapper { - display: flex; - justify-content: center - } - - .box1 { - grid-column: 2 / 4; - grid-row: 1; - margin-right:50px; - } - - .box2 { - grid-column: 1; - grid-row: 1 / 3; - display: flex; - flex-direction: column; - justify-content: center; - } - - .username { - border-bottom: solid 2px #000000; - font-size: 40px; - font-weight: bold; - } - - .userrole { - margin-top: 10px; - font-size: 20px; - font-weight: bold; - } - - .userProjects h3 { - font-size: 20px; - font-weight: bold; - } - - .userProjects p { - font-size: 16px; - font-weight: lighter; - } - - .userSkills h3 { - font-size: 20px; - font-weight: bold; - } - - .userSkills p { - font-size: 16px; - font-weight: lighter; - } - - .userRecords h3 { - font-size: 20px; - font-weight: bold; - } - - .userRecords p { - font-size: 16px; - font-weight: lighter; - } - - .box3 { - display: flex; - width: 90%; - margin: 0 auto; - } - - .box4 { - display: flex; - width: 90%; - margin: 0 auto; - } - - .card { - padding: 0.5em 1em; - margin: 2em 1rem; - font-weight: bold; - color: #505050; - background: #FFF9F5; - border: solid 4px #FFAC5D; - border-radius: 10px; - display: flex; - justify-content: center; - align-items: center - } - - .card p { - margin: 0; - padding: 0; - } - - .box5 { - width: 86%; - margin: 0 auto; - } - - .record_card { - padding: 0.5em 1em; - margin: 2em 0; - font-weight: bold; - color: #505050; - background: #FFF9F5; - border-bottom: dashed 2px #FFAC5D; - width: 100%; - } - - .record_card p { - margin: 0; - padding: 0; - } \ No newline at end of file + top: 0; + left: 0; + position: fixed; + padding: 100px; + height: 100vh; + width: 100%; + z-index: 11; + background-color: rgba(51, 51, 51, 0.3); +} + +.modalInnerContainer { + width: 100%; + min-height: 100%; + display: flex; + justify-content: center; + align-items: center; + pointer-events: none; +} + +.modalTakumi { + position: absolute; + width: 50vw; + height: 80vh; +} + +.img_header { + vertical-align:top; + z-index: 30; + position: absolute; + top: 0; + left: 0; + text-align:center; +} + +.img_footer { + vertical-align:top; + z-index: 30; + position: absolute; + right: 0; + bottom: 0; + text-align:center; +} + +.modalContent { + position: absolute; + width: 50vw; + height: 80vh; + display: flex; + flex-flow: column; + padding: 50px 70px 150px 70px; + color: var(--accent-7); + border-radius: var(--card-radius); + background: #FFF9F5; + backdrop-filter: blur(10px); + gap: 30px; + overflow-y: auto; + overscroll-behavior-y: none; + pointer-events:auto; + /*スクロールバー非表示(IE・Edge)*/ + -ms-overflow-style: none; + /*スクロールバー非表示(Firefox)*/ + scrollbar-width: none; +} + +/*スクロールバー非表示(Chrome・Safari)*/ +.modalContent::-webkit-scrollbar{ + display:none; +} + +.contentsTitle { + width: 100%; + display: flex; + justify-content: start; + align-items: start; + flex-flow: row; + flex-wrap: nowrap; +} + +.modalContentContents { + width: 100%; + display: flex; + justify-content: start; + align-items: start; + flex-flow: row; + flex-wrap: nowrap; +} + +.graduationAssignmentMde { + width: 100%; +} + +.graduationAssignmentMde span { + font-size: 16px; + background-color: #fff; +} + +.modalContent input { + font-size: 1.6rem; + width: 100%; + letter-spacing: 1px; + color: var(--accent-6); + background: none; + border: 1px solid var(--accent-4); + padding: 10px; +} + +.modalContent input:focus { + border: 1px solid var(--button-secondary); + z-index: 10; + outline: 0; +} + +.modalContent textarea { + font-size: 1.6rem; + width: 50%; + height: 50rem; + color: var(--accent-6); + background: none; + border: 1px solid var(--accent-4); + padding: 10px; +} + +.modalContent textarea:focus { + border: 1px solid var(--button-secondary); + z-index: 10; + outline: 0; +} + +.modalContent select { + font-size: 1.6rem; + width: 100%; + letter-spacing: 1px; + color: var(--accent-6); + background: none; + border: 1px solid var(--accent-4); + padding: 10px; +} + +.modalContent select:focus { + border: 1px solid var(--button-secondary); + z-index: 10; + outline: 0; +} + +.modalName { + display: flex; + justify-content: center; + align-items: center; +} + +.modalContentClose { + display: flex; + justify-content: start; + align-items: start; +} + +.modalContentCloseIcon { + background: none; + border: none; + margin: -20px; + border-radius: var(--button-radius); + text-align: center; + font-size: 2.8rem; + color: var(--button-secondary); + display: flex; + justify-content: center; + align-items: center; +} + +.modalSubmitButton { + display: flex; + justify-content: center; + align-items: center; +} + +.modalDetail { + margin-top: 50px; +} + +.img { + border-radius: 50%; + width: 180px; + height: 180px; +} + +.wrapper { + display: flex; + justify-content: center +} + +.box1 { + grid-column: 2 / 4; + grid-row: 1; + margin-right:50px; +} + +.box2 { + grid-column: 1; + grid-row: 1 / 3; + display: flex; + flex-direction: column; + justify-content: center; +} + +.username { + border-bottom: solid 2px #000000; + font-size: 40px; + font-weight: bold; +} + +.userrole { + margin-top: 10px; + font-size: 20px; + font-weight: bold; +} + +.userProjects h3 { + font-size: 20px; + font-weight: bold; +} + +.userProjects p { + font-size: 16px; + font-weight: lighter; +} + +.userSkills h3 { + font-size: 20px; + font-weight: bold; +} + +.userSkills p { + font-size: 16px; + font-weight: lighter; +} + +.userRecords h3 { + font-size: 20px; + font-weight: bold; +} + +.userRecords p { + font-size: 16px; + font-weight: lighter; +} + +.box3 { + display: flex; + width: 90%; + margin: 0 auto; +} + +.box4 { + display: flex; + width: 90%; + margin: 0 auto; +} + +.card { + padding: 0.5em 1em; + margin: 2em 1rem; + font-weight: bold; + color: #505050; + background: #FFF9F5; + border: solid 4px #FFAC5D; + border-radius: 10px; + display: flex; + justify-content: center; + align-items: center +} + +.card p { + margin: 0; + padding: 0; +} + +.box5 { + width: 86%; + margin: 0 auto; +} + +.record_card { + padding: 0.5em 1em; + margin: 2em 0; + font-weight: bold; + color: #505050; + background: #FFF9F5; + border-bottom: dashed 2px #FFAC5D; + width: 100%; +} + +.record_card p { + margin: 0; + padding: 0; +} \ No newline at end of file diff --git a/view/next-project/src/components/common/UserDetailModal/UserDetailModal.tsx b/view/next-project/src/components/common/UserDetailModal/UserDetailModal.tsx index 3c2133e..e162cac 100644 --- a/view/next-project/src/components/common/UserDetailModal/UserDetailModal.tsx +++ b/view/next-project/src/components/common/UserDetailModal/UserDetailModal.tsx @@ -1,63 +1,62 @@ import React from 'react'; import s from './UserDetailModal.module.css'; -import styled from 'styled-components'; - -type User = { - id: number; - provider: string; - uid: string; - allow_password_change: boolean; - name: string; - email: string; - created_at: string; - updated_at: string; -} + +interface User { + id: number; + provider: string; + uid: string; + allow_password_change: boolean; + name: string; + email: string; + created_at: string; + updated_at: string; +}; interface Type { - id: string; - name: string; - created_at: string; - updated_at: string; - } - -type UserDetail = { - icon_name: string; - github: string; - slack: string; - biography: string; - pc_name: string; - pc_os: string; - pc_cpu: string; - pc_ram: string; - pc_storage: string; - type: Type; + id: string; + name: string; + created_at: string; + updated_at: string; }; -type Project = { - id: number; - project: string; - role: string; +interface UserDetail { + icon_name: string; + github: string; + slack: string; + biography: string; + pc_name: string; + pc_os: string; + pc_cpu: string; + pc_ram: string; + pc_storage: string; + type: Type; }; -type Record = { - id: number; - title: string; - teacher: User; +interface Project { + id: number; + project: string; + role: string; }; -type Skill = { - id: number; - name: string; - category: string; +interface Record { + id: number; + title: string; + teacher: User; }; -type UserDetailModalProps = { - onClose: () => void; - user: User; - userDetail: UserDetail; - userProject?: Project[] | null; - userSkill?: Skill[] | null; - userRecord?: Record[] | null; +interface Skill { + id: number; + name: string; + category: string; +}; + +interface UserDetailModalProps { + onClose: () => void; + user: User; + userDetail: UserDetail; + userProject?: Project[] | null; + userSkill?: Skill[] | null; + userRecord?: Record[] | null; }; const UserDetailModal: React.FC = (props) => { @@ -67,21 +66,7 @@ const UserDetailModal: React.FC = (props) => { if (e.target === e.currentTarget) { props.onClose(); } - } - const MemberHeaderContainer = styled.div` - z-index: 30; - position: absolute; - top: 0; - left: 0; - text-align:center; - `; - const MemberFooterContainer = styled.div` - z-index: 30; - position: absolute; - right: 0; - bottom: 0; - text-align:center; - `; + }; return (
@@ -89,10 +74,8 @@ const UserDetailModal: React.FC = (props) => {
- - - - + +
@@ -150,9 +133,7 @@ const UserDetailModal: React.FC = (props) => {
- - - +
From 5d8fe35e2e142b756da971b46583e97ed3bddcf8 Mon Sep 17 00:00:00 2001 From: takasuka_takumi Date: Thu, 21 Sep 2023 09:02:29 +0900 Subject: [PATCH 3/3] =?UTF-8?q?=E8=BF=BD=E5=8A=A0=E8=A8=82=E6=AD=A32?= =?UTF-8?q?=E3=80=81=E3=83=A1=E3=83=B3=E3=83=90=E3=83=BC=E8=A9=B3=E7=B4=B0?= =?UTF-8?q?=E3=83=A2=E3=83=BC=E3=83=80=E3=83=AB=E3=81=AE=E4=BD=9C=E6=88=90?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../common/UserDetailModal/UserDetailModal.module.css | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/view/next-project/src/components/common/UserDetailModal/UserDetailModal.module.css b/view/next-project/src/components/common/UserDetailModal/UserDetailModal.module.css index 277ad87..4065329 100644 --- a/view/next-project/src/components/common/UserDetailModal/UserDetailModal.module.css +++ b/view/next-project/src/components/common/UserDetailModal/UserDetailModal.module.css @@ -249,17 +249,19 @@ display: flex; width: 90%; margin: 0 auto; + flex-wrap: wrap; } .box4 { display: flex; width: 90%; margin: 0 auto; + flex-wrap: wrap; } .card { padding: 0.5em 1em; - margin: 2em 1rem; + margin: 0.75em 1rem; font-weight: bold; color: #505050; background: #FFF9F5;