[240910] ์˜ค๋กœ๋ผ ์Šคํ‚จ ์Šคํ„ฐ๋””, web component, template, slot, handlebarsJS (feat. ์˜ค๋กœ๋ผ ์Šคํ‚จ ๋ฆฌ์•กํŠธ ์ปดํฌ๋„ŒํŠธ๋ฅผ ์‚ฌ์šฉํ•˜๋ฉด, ์ข€ ๋” ๋‚˜์€ ๋ฆฌ์•กํŠธ ์ฝ”๋“œ๋ฅผ ์งค ์ˆ˜ ์žˆ์„ ๊ฒƒ ๊ฐ™๋‹ค)
ยท
[ํ”„๋ก ํŠธ์—”๋“œ(FE) ๊ฐœ๋ฐœ]/TIL
์ข‹์•˜๋˜ ์ K ์‚ฌ ํ”„๋กœ์ ํŠธ๋ฅผ ํ•˜๊ฒŒ ๋˜๋ฉด, ์˜ค๋กœ๋ผ ์Šคํ‚จ์—์„œ web component, template, slot, handlebarsJS ๋ผ๋Š” ๊ฐœ๋…์— ๋Œ€ํ•ด ๋ฐฐ์šธ ์ˆ˜ ์žˆ๋Š” ๊ธฐํšŒ๊ฐ€ ๋  ๊ฒƒ ์ด๋ผ๋Š” ์  ์˜ˆ์‹œ ์ฝ”๋“œ๋ฅผ ํ†ตํ•ด์„œ ๋А๋‚€ '์˜ค๋กœ๋ผ ์Šคํ‚จ react' ์—์„œ๋Š”, ๋ฐฐ์šฐ๊ณ  ์‹ถ์€ ์ฝ”๋“œ๋“ค์ด ๋งŽ์ด ๋…น์•„์žˆ์—ˆ๋‹ค.์–ด๋–ป๊ฒŒ ๋ฐ”๋กœ ์—ฌ๊ธฐ๋กœ ๋””๋ฒ„๊น… ํ•˜๋Ÿฌ ์˜จ๊ฑฐ์ง€storybook ์—์„œ, currentTab ์— ๊ฐ’์„ ๋„ฃ์œผ๋ฉด -> ์œ„์— ์ฒ˜๋Ÿผ ๋ณ€ํ•ด storybook ์—์„œ, tabs ์— ๋Œ€ํ•œ ์„ค๋ช…์„ ๋„ฃ์œผ๋ ค๋ฉด ์–ด๋–ป๊ฒŒ ํ•ด์•ผ ํ•˜์ง€?'storybook ์—์„œ, currentTab ์— ๊ฐ’์„ ๋„ฃ์œผ๋ฉด -> ์œ„์— ์ฒ˜๋Ÿผ ๋ณ€ํ•ด' ๋ผ๋Š” ๊ธ€์„ ๋„ฃ์–ด์ฃผ๊ณ  ์‹ถ์€๋ฐ [์ฃผ์˜์‚ฌํ•ญ] 1. build ๋ช…๋ น์–ด๋งŒ ์œ ํšจํ•จ! (#โญโญโญโญโญ)https://youtu.be/4zeusLdLizs?..
240815-์ธ์ˆ˜์ธ๊ณ„์ค€๋น„-์ƒŒ๋“œ๋ฒ„๋“œ ์ฑ„ํŒ…
ยท
[ํ”„๋ก ํŠธ์—”๋“œ(FE) ๊ฐœ๋ฐœ]/TIL
TODO์ธ์ˆ˜ ์ธ๊ณ„ ์ค€๋น„๋นŒ๋“œ ํ„ฐ์ง€๋Š”๊ฑฐ ์ˆ˜์ •SecureRoute ์— ๋Œ€ํ•ด์„œ ๊ณต๋ถ€์ฑ„ํŒ…๋ฐฉ ์ƒ์„ฑํ•˜๊ฒŒ ํ•˜๊ธฐ โญโญโญโญโญํฌ๋กค๋ง ๋ด‡์ด ๋‹ต๋ณ€ํ•˜๊ฒŒ ํ•˜๊ธฐ โญโญโญโญโญDO์ธ์ˆ˜ ์ธ๊ณ„ ์ค€๋น„_test\์ธ์ˆ˜์ธ๊ณ„ ๋ฏธํŒ… ๊ด€๋ จ\240814-์ธ์ˆ˜์ธ๊ณ„์ค€๋น„.mdSecureRoute ์ด๊ฑธ๋กœ ํ† ํฐ ์—ฌ๋ถ€ ํŒ๋‹จํ•ด์„œ ๋ฆฌ๋””๋ ‰์…˜ โญโญโญโญโญimport { ComponentProps, createElement, FC } from "react";import { Redirect, Route } from "react-router-dom";import { getAccessToken } from "@/src/lib/jwt";const SecureRoute: FC> = ({ component = "div", ...rest }) => { return ( { ..
[240814] ์ƒŒ๋“œ๋ฒ„๋“œ ์ฑ„ํŒ… ์ธ์ˆ˜ ์ธ๊ณ„
ยท
[ํ”„๋ก ํŠธ์—”๋“œ(FE) ๊ฐœ๋ฐœ]/TIL
์ƒŒ๋“œ๋ฒ„๋“œ ์ฑ„ํŒ…[240814] ์ฑ„ํŒ… ๋ฐฉ ์ƒ์„ฑ ๊ด€๋ จ[๐Ÿ“›๐Ÿ“›]์ฒ˜์Œ์— /chat ์œผ๋กœ ๋“ค์–ด๊ฐ”์„ ๋•Œ ๋Œ€ํ™”ํ™”๋ฉด์ด ๋ณด์ด์ง€ ์•Š๋‹ค๊ฐ€, ๋ฐฉ ์ƒ์„ฑ ํ›„ ๋ณด์ž„์ƒˆ๋กœ๊ณ ์นจ์„ ํ•ด๋„, ๋นˆ ํ™”๋ฉด์ด ๋‚˜์˜ด [๐Ÿ”ต๐Ÿ”ต]์ƒˆ๋กœ ์ƒ์„ฑํ•œ ๋ฐฉ์— gpt ๋ฅผ ์ดˆ๋Œ€ํ•˜๋ ค๋ฉด?์ด๋ ‡๊ฒŒ invite ๋ฅผ ๋ˆŒ๋Ÿฌ์„œ ์ดˆ๋Œ€ํ•˜๋Š” ๋ฐฉ๋ฒ•๋น„์Šทํ•˜๊ฒŒ, ์ฑ„ํŒ…๋ฐฉ ์ƒ์„ฑ์‹œ gpt ๋ฅผ ์ดˆ๋Œ€ [โ“โ“] ๊ทธ๋Ÿฐ๋ฐ, gpt ๊ฐ€ ์–ด๋–ป๊ฒŒ ์—ฌ๊ธฐ์— ์ดˆ๋Œ€ ๋œ ๊ฑฐ์ง€? gpt ๊ณ„์ •์€ ์–ด๋””์— ์ž…๋ ฅํ•ด์ค˜์•ผ ํ•˜๋Š”๊ฑฐ์ง€?[240815] URL - ๋””๋ ‰ํ† ๋ฆฌ ๊ตฌ์กฐ - ํŽ˜์ด์ง€ ํŒŒ์•…์šฐ์„ , ์•ฑ ๋ฉ”๋‰ด ๊ตฌ์กฐ๋„ ๊ธฐ์žฌํ•˜๊ธฐ'https://docs.google.com/spreadsheets/d/10TIAwV6-1nm8wPSyMDjnKH_DFAQ759zD/edit?usp=sharing&ouid=107144623538128050099&rtpof=..
240813 ์ผ์ผ ๊ฐœ๋ฐœ ์ผ์ง€
ยท
[ํ”„๋ก ํŠธ์—”๋“œ(FE) ๊ฐœ๋ฐœ]/TIL
done ํ•œ task ๊ธฐ๋ก[240813] ์บ˜๋ฆฐ๋” ๊ฐ€์ ธ์˜ค๋Š” ๊ตฌ์กฐ 1. ์‚ฌ์šฉ์ž๊ฐ€ ์ €์žฅํ•˜๋ฉด -> DB ๋ฅผ ๊ฑฐ์ณค๋‹ค๊ฐ€ -> ๊ทธ๋ ค์ง€๊ฒŒ ํ•  ๊ฒƒ ์ธ๊ฐ€ 2. ๊ตฌ๊ธ€ ์บ˜๋ฆฐ๋”์— ์ €์žฅ๋œ ๊ฒƒ์„ ๊ฐ€์ ธ์™€์„œ -> ๊ทธ๋ ค์ง€๊ฒŒ ํ•  ๊ฒƒ ์ธ๊ฐ€ ์ด ์ค‘ 2๊ฐ€์ง€๋ฅผ ๋‹ค ํ•œ๋‹ค.์‚ฌ์‹ค, full calendar ์ž์ฒด์— 'ํœด์ผ' ์„ ๊ฐ€์ ธ์˜ค๋Š” ๊ธฐ๋Šฅ์ด ์žˆ์œผ๋ฉด, ๊ตณ์ด google api ์—ฐ๋™์„ ์•ˆ ํ•ด๋„ ๋œ๋‹ค.[240813-1340] ๋”๋ฏธdate ์— event ์ƒ๊ธฐ๊ฒŒ ํ•˜๊ธฐ์ฐธ๊ณ https://bit.ly/3YGzr81views\fullcalendar.ejsํฌ์ธํŠธ```bash์ผ์ • ์ƒ์„ฑ ๋ฒ„ํŠผ ํด๋ฆญ -> addEvent(calendarRef) ์ด ์‹คํ–‰๋จ๋งŒ๋“ค์–ด๋†“๊ณ  -> ๋ชจ๋“ˆ๋กœ ๋นผ๋‹ˆ๊นŒ ์ข‹์Œ โญโญโญโญโญโญโญโญโญ์ด๊ฑฐ๋ฅผ ์ด์ œ ํ…Œ์ŠคํŠธ ํŒŒ์ผ์—์„œ ๋นผ์„œ -> ํ”„๋กœ์ ํŠธ์— ์ ์šฉํ•  ..