-
Notifications
You must be signed in to change notification settings - Fork 1
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. Weβll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Sign up form/#7 #50
Sign up form/#7 #50
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
κ³ μνμ
¨μ΅λλ€!
error handlerμ λν΄μλ μ νμΈνμ΅λλ€:) νμ¬λ fetch μμ responseλ₯Ό λ°μμ¨ ν ν¨μλ₯Ό ν΅ν΄μ μ²λ¦¬ν΄μ£Όλλ° fetchλ₯Ό custom νλ©΄ fetch λ΄λΆμμ μ²λ¦¬ν΄μ£Όλ©΄ μ’μ κ² κ°λ€μ!
μ΄ λΆλΆμ λν΄μλ fetch custom ν λ λ κ³ λ―Όν΄λ³΄κ² μ΅λλ€!
κ³μΈ΅μ λ°λΌ error handlingμ ν΄μ£Όλ λΆλΆλ μ’μ κ² κ°μ΅λλ€!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
routerλ‘ λ°λ‘ κ΄λ¦¬νμ§ μκΈ° λλ¬Έμ νμκ°μ
νΌμμ λ€λ‘κ°κΈ° λ²νΌ ν΄λ¦ μ μ½κ΄ λͺ¨λ¬μ΄ λμ€μ§ μλ κ±Έ νμΈνμ΅λλ€!
λ°λ‘ μ΄μ κ° μμκΉμ©?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
νμΈνꡬ 리뷰 λ¨κ²Όμ΅λλ€!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
sign-up-successλ sign-up-terms κ° νμ΄μ§ μ»΄ν¬λνΈμ μλ μ΄μ κ° λ°μ΄ν°κ° μ μ λλ©μΈμ μμ‘΄νκΈ° λ³΄λ¨ νμ΄μ§μ μμ‘΄ν΄μκ° λ§μκΉμ!?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
- μ λ μ¬μ€ μ½κ΄μ λ΄μ©μ΄ μ μ λλ©μΈμ μνλ κ²μ΄ λ§κΈ°μ μ΄ λΆλΆμ λν΄μ κ³ λ―Όμ μ’ νμ΅λλ€.
- μ£Όμ μμ μ λ΄μ©μ λ°μ΄ν°λ μνλ‘ κ΄λ¦¬νμ§ μκ³ μ μ ν μ€νΈλ‘ κ΄λ¦¬νλ κ²½μ°μλ λλ©μΈ μ»΄ν¬λνΈλ‘ λ³Ό κ²μΈμ§ μ΄μλλ°μ.
- λ§μ½ μ½κ΄ λ΄μ©μ΄ λ°μ΄ν°λ² μ΄μ€μ μ μ₯λκ±°λ ν΄λΌμ΄μΈνΈμμ μνλ‘ κ΄λ¦¬νλ€λ©΄ λλ©μΈ μ»΄ν¬λνΈλ‘ λΆλ¦¬νλκ² λ§μΌλ, νμ¬μ²λΌ μ μ ν μ€νΈλ‘ μ²λ¦¬νλ€λ©΄ νμ΄μ§ μ»΄ν¬λνΈλ‘ ꡬμ±νκΈ°λ‘ κ²°μ νμ΅λλ€.
- μμΌλ‘ λΉμ·ν μν©μλ μ΄ μ»¨λ²€μ μ μ μ§ν κ² κ°μμ.
app/business/user/user.type.ts
Outdated
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
μ λ type μ type ν΄λμ λΆλ¦¬νλλ° business ν΄λμ λΆλ¦¬νμ μ΄μ κ° μμκΉμ!?
λ§μΆλ©΄ μ’μ κ² κ°μμ!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
μ΄ λΆλΆμ λν΄μλ λ κ°μ§ μ΄μ κ° μμ΅λλ€.
- μ°μ , μ λ κΈ°λ³Έμ μΌλ‘ κ·Όμ ν μ½λλ₯Ό κ°μ μμΉμ λλ 'colocate' λ°©μμ μ νΈν©λλ€.
- https://koenvangilst.nl/blog/code-colocation-is-king
- μ λ§ν¬μμ 'κ·Όμ μ±'μ΄λ ν¨κ» λ³νλ μ±μ§μ μλ―Έν©λλ€. κ·Έλμ 'colocate' λ°©μμ΄ λ§€λ ₯μ μΈλ°, μ΄λ μ½λμ μμΉ κ²°μ λ₯Ό κ²°μ νλ μ¬λ¬ λ°©λ² μ€ κ°μ₯ λ³νμ κ°νλ€κ³ λκ»΄μ§λλ€.
- λ λ²μ§Έ μ΄μ λ 'μΌλ° νμ
'μΈμ§ 'Response νμ
'μΈμ§μ λν λ¬Έμ μ
λλ€.
- μ λ μλ²κ° 보λ΄λ μμ²μ΄λ μλ΅μ λͺ¨λ 'Request'λ 'Response'λΌλ μ λμ¬λ₯Ό λΆμ λλ€.
- μλ₯Ό λ€μ΄ 'TakenLectures'μ κ²½μ° 'TakenLecturesResponse'κ° λκ² μ£ ?
- μ΄λ κ² νλ μ΄μ λ, μλ²μμ λ°λ‘ 보λ΄μ£Όλ λ°μ΄ν°λ₯Ό κΈ°λ°μΌλ‘ 'TakenLectures' νμ μ λ§λ€κ³ μ΄λ₯Ό μ»΄ν¬λνΈμμ μ¬μ©ν κ²½μ°, μλ²μμ 보λ΄μ£Όλ λ°μ΄ν°κ° λ³κ²½λ λ μ»΄ν¬λνΈκΉμ§ λ³κ²½λμ΄μΌ νλ λ¬Έμ κ° μκΉλλ€.
- κ·Έλμ, μλ²μμ 보λ΄λ μλ΅κ°μλ 'Response'λ₯Ό λΆμ΄κ³ , μ»΄ν¬λνΈμμ μ¬μ©νλ λ°μ΄ν°λ 'TakenLectures'λ‘ μ§μ νμ¬ λμ λΆλ¦¬ν©λλ€.
- μν€ν μ² κ΅¬μ‘° μ 'TakenLectures'λ₯Ό λ°λ‘ λ§λ€μ§ μκ³ 'TakenLecturesResponse'λ₯Ό λ°λ‘ μ¬μ©ν μλ μμ§λ§(νμ¬ μ°λ¦¬μ κ΅¬μ‘°κ° μ΄λ μ΅λλ€), μ΅μν νκΈ°λ₯Ό ν΅ν΄ λ°μ΄ν°μ μΆμ²λ₯Ό λ°νκ³ λ³κ²½μΌλ‘ μΈν λ¬Έμ κ° μμ μ μμμ λλ¬λ΄λ ν¨κ³Όκ° μμ΅λλ€.
- BEμμ λ Όμλλ 맀νμ λν λ Όμμ λΉμ·ν μΈ‘λ©΄μ΄ μλ κ² κ°λ€μ. λ¬Όλ‘ typescriptλ λ νμ΄νμ΄κΈ° λλ¬Έμ 맀νμμ μ’ λ μμ λ‘κΈ΄ νμ§λ§, λ³κ²½μ λν 리μ€ν¬λ μ¬μ ν μ‘΄μ¬ν©λλ€.
μ 리νλ©΄, μ κ° μ μν νμ νμΌμ μλ²μ μμ²κ³Ό μλ΅μ λν νμ μ΄λ©°, μ΄λ query λλ commandμ κ°νκ² μ°κ²°λμ΄ μμΌλ―λ‘ 'colocate' μ² νμ λ°λΌ κ°μ ν΄λμ μμΉνλ κ²μ΄ μ’λ€κ³ μκ°ν©λλ€.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
'TakenLectures' νμ μ λ§λ€κ³ μ΄λ₯Ό μ»΄ν¬λνΈμμ μ¬μ©ν κ²½μ°, μλ²μμ 보λ΄μ£Όλ λ°μ΄ν°κ° λ³κ²½λ λ μ»΄ν¬λνΈκΉμ§ λ³κ²½λμ΄μΌ νλ λ¬Έμ κ° μκΉλλ€.
κ²°κ΅ typeμ λν λ³κ²½μ΄ μΌμ΄λ¬μλ TakenLecturesResponse
μ λ³κ²½μ νμμ μ΄λ©°, μ°κ²°μ μν κ³μΈ΅μ΄ νλ λ μμ±λλ κ²μ΄λ―λ‘ μ»΄ν¬λνΈμμ μ§μ λ³κ²½νλ κ²κ³Ό λΉκ΅ν΄μ λͺ
ννκ² μ₯μ μΌλ‘ λλ¬λλμ§μ λν 곡κ°μ λ€μ§μμ΅λλ€. κ°κ°μΈμ λ°λΌμ κ³μΈ΅μ΄ νλ μΆκ°λλ€λ κ²μ λν΄ λΆνΈνλ€λ μκ²¬μ΄ μ‘΄μ¬ν μ μμ κ² κ°μμ.
νμ§λ§ μ»΄ν¬λνΈμ μμ μ±μ λμΌ μ μλ€λ μ견μ λμνμ¬ ν΄λΉ ꡬ쑰λ₯Ό μ±ννκ³ μΆμ΅λλ€. λλΆμ΄ μμ μ± λ° μ μ°μ±μ λͺ©μ μΌλ‘ μ¬μ©νλ λ§νΌ colocateλ°©μμ ν΅ν response typeκ΄λ¦¬κ° μ μ©ν κ² κ°λ€λ μ견μλ λμν©λλ€.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
μλ΅κ° νμ
μ Responseλ₯Ό λΆμ΄λ κ²κ³Ό ν¨κ» λ³νλ κ²μ λν΄ κ·Όμ νκ² λλ κ² μ’μ κ² κ°μ΅λλ€!
λ€λ§, μλ²μμ 보λ΄μ£Όλ λ°μ΄ν° νμ
κ³Ό μ»΄ν¬λνΈμμ μ¬μ©νλ λ°μ΄ν° νμ
μ λΆλ¦¬νμ λ ( λμ νμ
μ΄ κ°λ€λ κ°μ ν )μλ²μμ 보λ΄μ£Όλ λ°μ΄ν°κ° λ³κ²½λ λ μ»΄ν¬λνΈκΉμ§ λ³κ²½λμ΄μΌ νλ λ¬Έμ κ° μκΈ°λ κ±Έ λ°©μ§νκ³ μμ μ±μ΄ λμμ§λ€λ κ²μ 곡κ°μ΄ μλλλ° μ΄ λΆλΆμ λν΄μ μ€νλ¦°νΈ νμλ μ‘°κΈ λ μ€λͺ
ν΄μ£Όμ€ μ μλμ??
.storybook/preview.ts
Outdated
@@ -1,7 +1,12 @@ | |||
import type { Preview } from '@storybook/react'; | |||
import '../app/globals.css'; | |||
|
|||
import { initialize, mswDecorator } from 'msw-storybook-addon'; | |||
|
|||
initialize(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
https://storybook.js.org/addons/msw-storybook-addon
parameters λμ initializeμμ ν λ²μ handlers λ₯Ό μ€μ ν΄μ€ μ μμ κ² κ°μμ!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
9c49969
μ’λ€μ. κ³ λ§μμ
await delay(500); | ||
|
||
if (!isSuccess) { | ||
return HttpResponse.json({ status: 400, message: 'μ΄λ―Έ κ°μ λ νλ²μ λλ€.' }, { status: 400 }); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
νΉμ status:400 κ°μ²΄λ₯Ό λ μ λ¬νλ μ΄μ κ° λ°λ‘ μμκΉμ©?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
- νμμ statusλ MSWμ μλ΅μ κ²°μ νλ κ²μ΄κ³ ,
- μ μλ μ‘ΈλΆμ μ€μ μλ΅μ λͺ¨λ°©ν κ²μ λλ€.
- μ‘ΈλΆ APIλ₯Ό νμΈν΄λ³΄λ, μ€ν¨ μ dataμλ μ λ κ² λ³΄λ΄μ£Όλ κ² κ°μ΅λλ€. 'status'λΌλ μ΄λ¦λ§ κ°μ λΏ, μλ§ μ€μ μλ΅μ½λλ λ³κ°μΈ κ² κ°μ΅λλ€.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
μκ³ νμ ¨μ΅λλ€ !
experimental: { | ||
serverActions: { | ||
// https://github.com/vercel/next.js/issues/58295 | ||
allowedOrigins: ['localhost:3000', 'ideal-waddle-5xwrj5ppjvxhvq7x-3000.app.github.dev'], |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
μ΄μλ₯Ό νμΈν΄λ³΄μμ§λ§ λͺ ννκ² μ΄λ€ μ΄μ μμ μΆκ° λ μ€μ μΈμ§ λͺ¨λ₯΄κ² μ΅λλ€. μ€λͺ μ λ§λΆμ¬μ£Όμ€ μ μμκΉμ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
- μ κ° μ¬μ©νλ codespaceμμλ λ‘컬μμ νΈμ€ν νλ κ²μ΄ μλλΌ λ€λ₯Έ λλ©μΈμ νλ‘μλ₯Ό μ°κ²°νμ¬ νΈμ€ν ν©λλ€. μ¦, localhost:3000μ ideal-waddle-5xwrj5ppjvxhvq7x-3000.appμμ μ€ννλ κ²μ λλ€.
- κ·Έλ¬λ μ΄λ κ² νλ©΄ μλ² μ‘μ μ΄ cors μ€λ₯λ‘ μΈν΄ λ°μνλ―λ‘, νμ© λλ©μΈμ μΆκ°νμμ΅λλ€.
- μ κ°λ° νκ²½μμ λμνκΈ° μν΄ μ€μ ν κ²μΌλ‘ μ΄ν΄νμλ©΄ λ©λλ€.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
κ·Έλ κ΅°μ. λ‘컬μμ νΈμ€ν νλ κ²μ΄ μλλΌ λ€λ₯Έ λλ©μΈμ νλ‘μλ₯Ό μ°κ²°νμ¬ νΈμ€ν νμλ μ΄μ λ 무μμΈμ§ κΆκΈν©λλ€!
Co-authored-by: yougyung <[email protected]>
β¦ sign-up-form.stories.tsx
|
||
const stepQueryKey = options?.stepQueryKey ?? DEFAULT_STEP_QUERY_KEY; | ||
|
||
const step = searchParams.get(stepQueryKey) as Steps | undefined; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
λ¨μΈμ ν΄μ£Όμ§ μμΌλ©΄ stepμ΄ null λλ string νμ μΈ κ±Έ νμΈνμ΅λλ€ ! μ΄λ undefined λ‘λ λ¨μΈν΄μ£Όμ μ΄μ κ° κΆκΈν©λλ€!
πstorybook: https://65ccb85d5afe55a024495bc0-kbqxvmbrmd.chromatic.com/ |
π μμ λ΄μ©
π€ κ³ λ―Ό νλ λΆλΆ
π λμμ΄ νμν λΆλΆ
리뷰 μ΄ν μμ