Skip to content

Latest commit

ย 

History

History
165 lines (136 loc) ยท 7.68 KB

README.md

File metadata and controls

165 lines (136 loc) ยท 7.68 KB

๐Ÿณ ๋ง›์ด์Šˆ (MatIssue) : "์„ธ์ƒ์˜ ๋ชจ๋“  ๋ง›์žˆ๋Š” ์ด์Šˆ๋ฅผ ๋‹ด๋‹ค"

logo
๋กœ๊ณ  ํด๋ฆญ ์‹œ ๋ง›์ด์Šˆ ํ™ˆํŽ˜์ด์ง€๋กœ ์ด๋™ํ•ฉ๋‹ˆ๋‹ค ๐Ÿš• =3

๐ŸŽ ํ”„๋กœ์ ํŠธ ์ฃผ์ œ ๋ฐ ๊ธฐํš

แ„‰แ…ณแ†ฏแ„…แ…กแ„‹แ…ตแ„ƒแ…ณ1 แ„‰แ…ณแ†ฏแ„…แ…กแ„‹แ…ตแ„ƒแ…ณ7 แ„‰แ…ณแ†ฏแ„…แ…กแ„‹แ…ตแ„ƒแ…ณ8 แ„‰แ…ณแ†ฏแ„…แ…กแ„‹แ…ตแ„ƒแ…ณ9 แ„‰แ…ณแ†ฏแ„…แ…กแ„‹แ…ตแ„ƒแ…ณ10 แ„‰แ…ณแ†ฏแ„…แ…กแ„‹แ…ตแ„ƒแ…ณ11 แ„‰แ…ณแ†ฏแ„…แ…กแ„‹แ…ตแ„ƒแ…ณ12

๐ŸŠ ํŒ€์› ์†Œ๊ฐœ

แ„‰แ…ณแ†ฏแ„…แ…กแ„‹แ…ตแ„ƒแ…ณ4 แ„‰แ…ณแ†ฏแ„…แ…กแ„‹แ…ตแ„ƒแ…ณ5

โœ”๏ธ Front-End

  • ์žฅ์œค์ˆ˜ (FE ํŒ€์žฅ)
    • ๋ฉ”์ธํŽ˜์ด์ง€, ํ—ค๋” ํ‘ธํ„ฐ ๋ ˆ์ด์•„์›ƒ, ๋กœ๊ทธ์ธ ํŽ˜์ด์ง€, ํšŒ์›๊ฐ€์ž… ํŽ˜์ด์ง€, ์•„์ด๋”” ๋น„๋ฐ€๋ฒˆํ˜ธ์ฐพ๊ธฐ ํŽ˜์ด์ง€, ๊ด€๋ฆฌ์ž ํŽ˜์ด์ง€
  • ์ด์ˆ˜ํ˜„
    • ๋ ˆ์‹œํ”ผ ์กฐํšŒ ํŽ˜์ด์ง€, ๋ ˆ์‹œํ”ผ ์Šคํฌ๋žฉ ํŽ˜์ด์ง€, ์œ ์ € ํŽ˜์ด์ง€ (์œ ์ € ๋ ˆ์‹œํ”ผ / ํŒ”๋กœ์›Œ / ํŒ”๋กœ์ž‰)
    • (์žฌ๋ฃŒ ์ฒดํฌ๋ฆฌ์ŠคํŠธ, ๋ชฉ์ฐจ๋ฐ” & ์Šคํฌ๋กค ์ง„ํ–‰๋ฐ”, ํŒ”๋กœ์šฐ ๊ธฐ๋Šฅ ๋ฐ ๋ชฉ๋ก, ํ”„๋กœํ•„ ์นด๋“œ, ๋Œ“๊ธ€, ์ข‹์•„์š”, ๊ณต์œ , ์Šคํฌ๋žฉ, ์›น ๋ฐ ๋ชจ๋ฐ”์ผ ๋ฐ˜์‘ํ˜•)
  • ์ด๋‚˜ํ˜„
    • ๋งˆ์ดํŽ˜์ด์ง€ (์œ ์ €ํ”„๋กœํ•„, ๋ ˆ์‹œํ”ผ ์กฐํšŒ/์‚ญ์ œ, ํšŒ์›์ •๋ณด์ˆ˜์ •(ํ”„๋กœํ•„์‚ฌ์ง„ ์—…๋กœ๋“œ/ ๋น„๋ฐ€๋ฒˆํ˜ธ ๋ณ€๊ฒฝ / ํšŒ์›ํƒˆํ‡ด), ๋ชจ๋‹ฌ์ฐฝ)
  • ๊น€๋™๊ท 
    • ๋ ˆ์‹œํ”ผ ๋“ฑ๋ก ํŽ˜์ด์ง€, ๋ ˆ์‹œํ”ผ ์ˆ˜์ • ํŽ˜์ด์ง€, ๋ ˆ์‹œํ”ผ ์ด์ƒํ˜• ์›”๋“œ์ปต ๊ฒŒ์ž„ (์›น ๋ฐ ๋ชจ๋ฐ”์ผ) ๊ตฌํ˜„, ๋ง›์ด์Šˆ ํ™๋ณด ์˜์ƒ ์ œ์ž‘
  • ์ž„์ •ํ›ˆ
    • ๊ฒŒ์‹œ๋ฌผ ๊ฒ€์ƒ‰ ํŽ˜์ด์ง€ (์›น ๋ฐ ๋ชจ๋ฐ”์ผ) ๊ตฌํ˜„
    • (๋ ˆ์‹œํ”ผ ์ธ๋„ค์ผ ์ปดํฌ๋„ŒํŠธ, FilterBar ๋ฐ Tag, ์ •๋ ฌ ๋ฒ„ํŠผ, ํŽ˜์ด์ง€๋„ค์ด์…˜, ๋ฌดํ•œ์Šคํฌ๋กค, ๊ด€๋ จ API ์—ฐ๊ฒฐ, MBTI, Kakao API๋ฅผ ์ด์šฉํ•œ ๊ณต์œ  ๊ธฐ๋Šฅ)

โœ”๏ธ Back-End

  • ์‹ ์œ ๋นˆ (ํŒ€์žฅ)
  • ์†กํ˜ธ์ค€ (BE ํŒ€์žฅ)

๐Ÿ‹ ๊ธฐ์ˆ  ์Šคํƒ

แ„‰แ…ณแ†ฏแ„…แ…กแ„‹แ…ตแ„ƒแ…ณ14

๐Ÿฅ‘ API ๋ฌธ์„œ

๐Ÿซ ํŒ€ ์ปจ๋ฒค์…˜

แ„‰แ…ณแ†ฏแ„…แ…กแ„‹แ…ตแ„ƒแ…ณ16 แ„‰แ…ณแ†ฏแ„…แ…กแ„‹แ…ตแ„ƒแ…ณ17

โœ”๏ธ ์ปค๋ฐ‹ ์ปจ๋ฒค์…˜

  • Feat: ์ƒˆ๋กœ์šด ๊ธฐ๋Šฅ ์ถ”๊ฐ€
  • Fix: ๋ฒ„๊ทธ ์ˆ˜์ •
  • Docs: ๋ฌธ์„œ ๋ณ€๊ฒฝ
  • Design: CSS ๋“ฑ ์‚ฌ์šฉ์ž UI ๋””์ž์ธ ๋ณ€๊ฒฝ
  • Style: ์ฝ”๋“œ ํฌ๋งทํŒ…, ์„ธ๋ฏธ์ฝœ๋ก  ๋ˆ„๋ฝ, ์ฝ”๋“œ ๋ณ€๊ฒฝ์ด ์—†๋Š” ๊ฒฝ์šฐ
  • Refactor: ์ฝ”๋“œ ๋ฆฌํŒฉํ† ๋ง
  • Test: ํ…Œ์ŠคํŠธ ์ฝ”๋“œ ์ถ”๊ฐ€, ๋ฆฌํŒฉํ† ๋ง ํ…Œ์ŠคํŠธ ์ฝ”๋“œ ์ถ”๊ฐ€
  • Chore: ๋นŒ๋“œ ์ž‘์—…, ํŒจํ‚ค์ง€ ๋งค๋‹ˆ์ € ์ˆ˜์ •
  • Comment: ํ•„์š”ํ•œ ์ฃผ์„ ์ถ”๊ฐ€ ๋ฐ ๋ณ€๊ฒฝ
  • Rename: ํŒŒ์ผ ๋˜๋Š” ํด๋” ๋ช…์„ ์ˆ˜์ •ํ•˜๊ฑฐ๋‚˜ ์˜ฎ๊ธฐ๋Š” ์ž‘์—…๋งŒ์ธ ๊ฒฝ์šฐ
  • Remove: ํŒŒ์ผ์„ ์‚ญ์ œํ•˜๋Š” ์ž‘์—…๋งŒ ์ˆ˜ํ–‰ํ•œ ๊ฒฝ์šฐ
  • !BREAKING CHANGE: ์ปค๋‹ค๋ž€ API ๋ณ€๊ฒฝ์˜ ๊ฒฝ์šฐ
  • !HOTFIX: ๊ธ‰ํ•˜๊ฒŒ ์น˜๋ช…์ ์ธ ๋ฒ„๊ทธ๋ฅผ ๊ณ ์ณ์•ผ ํ•˜๋Š” ๊ฒฝ์šฐ

โœ”๏ธ ์ปดํฌ๋„ŒํŠธ ๋‚ด ์ฝ”๋“œ ์ž‘์„ฑ ๊ตฌ์กฐ

import { useEffect, useState, useRef } from "react";
import route from "next/navigate"

// file-scope constant
const ONE = 1;
const MY_NAME = "YOONSU";

const Page = (props) => {
	const { a, b, c } = props

  // state
  const [state, setState] = useState();

	// constant
	const route = useRoute();
	const ref = useRef();

  // handler
  const buttonClickHandler = () => {
    console.log("click");
  };

  // useEffect
  useEffect(() => {
    console.log("useEffect");
  }, []);

  return <></>;
};
export default Page;

โœ”๏ธ Git Branch ๊ด€๋ฆฌ

master
โ”œโ”€โ”€ dev-fe
โ”‚   โ”œโ”€โ”€ feature/user
โ”‚   โ”‚   โ”‚feature/postList
โ”‚   โ”‚   โ”‚ feature/main
โ”‚   โ”‚   โ”‚ feature/ViewPage
โ”‚___โ”‚___โ””โ”€โ”€ feature/my-page

feature/(๊ธฐ๋Šฅ๋ช…)์œผ๋กœ ๊ฐœ์ธ ์ž‘์—… ๋ธŒ๋žœ์น˜ ์ƒ์„ฑ, ๊ธฐ๋Šฅ๊ตฌํ˜„ ํ›„ dev์— PR

โœ”๏ธ ํ˜‘์—… ํˆด

  • Figma : ์ดˆ๋ฐ˜ ๊ธฐํš์‹œ ๋น ๋ฅธ ๋ ˆ์ด์•„์›ƒ์„ ์žก๊ธฐ ์œ„ํ•ด ์‚ฌ์šฉ
  • Notion : ํŒ€ ํŽ˜์ด์ง€, ์Šคํฌ๋Ÿผ ์ •๋ฆฌ, ๋ฌธ์„œ ์ •๋ฆฌ
  • Gather : ํŒ€์›๊ฐ„ ์ปค๋ฎค๋‹ˆ์ผ€์ด์…˜ ๋ฐ ์˜จ๋ผ์ธ ์Šคํฌ๋Ÿผ ์ง„ํ–‰
  • Gitlab : Code Repository
  • Discord : ํŒ€์›๊ฐ„ ์ปค๋ฎค๋‹ˆ์ผ€์ด์…˜์„ ์œ„ํ•ด ์‚ฌ์šฉ
  • ๏ฟฝSwagger : API ํ…Œ์ŠคํŠธ ์ง„ํ–‰

๐Ÿ† ๋ฐฐํฌ

โœ”๏ธ Front-End

  • pm2๋ฅผ ์ด์šฉํ•œ ์„œ๋ฒ„ ์˜คํ”ˆ ๋ฐ nginx๋ฅผ ํ™œ์šฉํ•œ ๋ฐฐํฌ

โœ”๏ธ ์„œ๋ฒ„ ์‹คํ–‰ ๋ฐฉ๋ฒ•

git clone {.....repository_name}.git
cd {repository_name}
npm install
npm run dev

โœ”๏ธ .env ์„ค์ •

NEXT_PUBLIC_KAKAO_API_KEY={OUR_KAKAO_KEY}
NEXT_PUBLIC_AWS_ACCESS_KEY_ID={AWS_KEY}
NEXT_PUBLIC_AWS_SECRET_ACCESS_KEY={AWS_ACCESS_KEY}
NEXT_PUBLIC_AWS_BUCKET_NAME={AWS_NAME}

๐Ÿ† ์—˜๋ฆฌ์Šค SW 4๊ธฐ 2์ฐจ ํ”„๋กœ์ ํŠธ ๋Œ€์ƒ ์ˆ˜์ƒ

logo