/PICKTRE_frontend

환경을 위한 행동, 모두가 참여하는 서비스 "PICKTRE"

Primary LanguageJavaScriptMIT LicenseMIT

PICKTRE_frontend license

소개


환경을 위한 행동, 모두가 참여하는 서비스 (PICKTRE, Pick Trash)

현대 사회에서 쓰레기 문제는 점점 심각해지고 있으며, 쓰레기의 적절한 처리는 환경보호와 지속가능한 발전을 위해 중요한 문제로 인식되고 있습니다.

하지만, 여전히 공공장소에서 쓰레기를 적절하게 버리지 않는 경우가 많아 환경오염과 공공장소의 미관을 해치는문제가 발생하고 있습니다.

이러한 배경에서 PICKTRE는 쓰레기를 적절하게 처리하고, 시민들의 쓰레기 버리기 습관을 개선하여 환경보호와 재활용 문화를 확산 시키는데 목적을 두고 있습니다. 또한, 사용자들이 쓰레기를 버릴 때 보상을 제공하여 쓰레기 문제에 대한 인식과 참여 향상을 목표로 합니다.

PICKTRE 홈페이지

시연 영상

Video Label


아키텍쳐

웹서버 아키텍처

리드미 웹서버

유저 플로우

executeShot0

소스 디렉토리

|   App.css
|   App.jsx
|   main.jsx
|
+---assets
|      
+---components
|   +---benefit
|   |       Benefit.jsx : 이용 혜택 페이지
|   |       Benefit.module.css
|   |       BenefitSection.jsx
|   |       BenefitSection.module.css
|   |       GradeSection.jsx
|   |       GradeSection.module.css
|   |
|   +---camera
|   |       QRcamera.jsx : QR 코드 리더기 스캔 카메라 페이지
|   |       QRcamera.module.css
|   |       TrashCamera.module.css
|   |       TrashCameraEwaste.jsx : 쓰레기 인식 카메라 페이지(Ewaste)
|   |       TrashCameraGlass.jsx : 쓰레기 인식 카메라 페이지(Glass)
|   |       TrashCameraMedical.jsx : 쓰레기 인식 카메라 페이지(Medical)
|   |       TrashCameraMetal.jsx : 쓰레기 인식 카메라 페이지(Metal)
|   |       TrashCameraPaper.jsx : 쓰레기 인식 카메라 페이지(Paper)
|   |       TrashCameraPlastic.jsx : 쓰레기 인식 카메라 페이지(Plastic)
|   |
|   +---common
|   |       AccordionList.jsx
|   |       AccordionList.module.css
|   |       chevron-down.svg
|   |       Footer.jsx : 페이지 내 푸터
|   |       Footer.module.css
|   |       Header.jsx : 페이지 내 헤더
|   |       Header.module.css
|   |       HeaderLayout.jsx : 페이지 내 헤더, 및 페이지 이름
|   |       HeaderLayout.module.css
|   |
|   +---home
|   |   |   Home.jsx : 메인 홈페이지
|   |   |   Home.module.css
|   |   |   HomeButton.jsx
|   |   |   HomeButton.module.css
|   |   |   HomeCard.jsx
|   |   |   HomeCard.module.css
|   |   |   HomeLevel.jsx
|   |   |   HomeLevel.module.css
|   |   |   HomeMainPostText.jsx
|   |   |   HomeMainPostText.module.css
|   |   |   HomeReward.jsx
|   |   |   HomeReward.module.css
|   |   |
|   |   \---dummy
|   |           cardData.json
|   |
|   +---inviteFriends
|   |       InviteFriends.jsx : 친구 초대하기 페이지
|   |       InviteFriends.module.css
|   |       InviteFriendsButton.jsx
|   |       InviteFriendsButton.module.css
|   |
|   +---landingPage
|   |       LandingPage.jsx : 로그인 안 되어 있을 시 로그인 페이지
|   |       LandingPage.module.css
|   |       Logo.jsx
|   |       Logo.module.css
|   |       RedirectPage.jsx
|   |       SocialAccountButton.jsx
|   |       SocialAccountButton.module.css
|   |
|   +---map
|   |       GeoLocation.jsx
|   |       Map.jsx : 지도 페이지
|   |       Map.module.css
|   |
|   +---myPage
|   |       MyList.jsx
|   |       MyList.module.css
|   |       MyPage.jsx : 마이페이지
|   |       MyPage.module.css
|   |       MyProfile.jsx
|   |       MyProfile.module.css
|   |       MySubPost.jsx
|   |       MySubPost.module.css
|   |
|   +---myUseReport
|   |       ActivityGraph.jsx
|   |       activityGraph.module.css
|   |       BadgeTitle.jsx
|   |       badgeTitle.module.css
|   |       MyUseReport.jsx : 이용 리포트 페이지
|   |       MyUseReport.module.css
|   |
|   +---notice
|   |   |   Notice.jsx : 공지사항 페이지
|   |   |   Notice.module.css
|   |   |
|   |   \---dummy
|   |           noticeData.json
|   |
|   +---point
|   |   |   Point.jsx : 포인트 페이지
|   |   |   Point.module.css
|   |   |   PointDropdown.jsx
|   |   |   PointDropdown.module.css
|   |   |   PointList.jsx
|   |   |   PointList.module.css
|   |   |   PointListElement.jsx
|   |   |   PointListElement.module.css
|   |   |   PointProfile.jsx
|   |   |   PointProfile.module.css
|   |   |
|   |   \---dummy
|   |           pointData.json
|   |           profileData.json
|   |
|   +---qna
|   |   |   Qna.jsx : 자주 묻는 질문 페이지
|   |   |   Qna.module.css
|   |   |
|   |   \---dummy
|   |           qnaData.json
|   |
|   +---ranking
|   |       Ranker.jsx
|   |       Ranker.module.css
|   |       Ranking.jsx : 랭킹 페이지
|   |       Ranking.module.css
|   |       RankingList.jsx
|   |
|   +---setting
|   |       Setting.jsx
|   |       Setting.module.css
|   |
|   \---store
|       |   Store.jsx : 스토어 페이지
|       |   Store.module.css
|       |   StoreDividingLine.jsx
|       |   StoreDividingLine.module.css
|       |   StoreGoods.jsx
|       |   StoreGoods.module.css
|       |   StoreOther.jsx
|       |   StoreOther.module.css
|       |   StorePopular.jsx
|       |   StorePopular.module.css
|       |   StoreSearching.jsx
|       |   StoreSearching.module.css
|       |
|       \---modal
|               StoreGoodsModal.jsx : 구매시 안내 모달 창
|               StoreGoodsModal.module.css
|
+---constants
|       OAuth.jsx
|       url.jsx
|
\---service
        cameraReward.jsx
        showProfile.jsx 

프로젝트 시작 (로컬)

  1. 프로젝트를 clone 합니다.
git clone https://github.com/PICKTRE/PICKTRE_frontend.git
  1. clone이 완료되었다면, 다음 명령어로 npm library들을 설치합니다.
npm i
  1. 프로젝트를 실행합니다.
npm run dev

프로젝트 시작

  1. PICKTRE에 접속합니다.
https://picktre.netlify.app

프로젝트 기술 스택

Environment

Config

Development

Deploy

Communication


프로젝트 페이지

executeShot1 executeShot2 executeShot3 executeShot4 executeShot5 executeShot6 executeShot7 executeShot8 executeShot9 executeShot10 executeShot11 executeShot12 executeShot13 executeShot13

프로젝트 QR 코드 스캐너 페이지 내 QR 코드

executeShots1 executeShots1 executeShots1 executeShots1 executeShots1 executeShots1


라이센스

PICKTRE/PICKTRE_frontend

facebook/react

vitejs/vite

googlemaps/google-maps-services-js

tensorflow/tfjs-models

framer/motion

axios/axios

zxing/zxing