-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #34 from team-Ollie/main
fix: api 연결
- Loading branch information
Showing
49 changed files
with
867 additions
and
189 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,91 @@ | ||
# Sample workflow for building and deploying a Next.js site to GitHub Pages | ||
# | ||
# To get started with Next.js see: https://nextjs.org/docs/getting-started | ||
# | ||
name: Test Next Build | ||
|
||
on: | ||
pull_request: | ||
branches: ["main"] | ||
|
||
# Allows you to run this workflow manually from the Actions tab | ||
workflow_dispatch: | ||
|
||
# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages | ||
permissions: | ||
contents: read | ||
pages: write | ||
id-token: write | ||
|
||
# Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued. | ||
# However, do NOT cancel in-progress runs as we want to allow these production deployments to complete. | ||
concurrency: | ||
group: "pages" | ||
cancel-in-progress: false | ||
|
||
jobs: | ||
# Build job | ||
build: | ||
runs-on: ubuntu-latest | ||
|
||
env: | ||
NEXT_PUBLIC_API_URL: ${{secrets.NEXT_PUBLIC_API_URL}} | ||
|
||
steps: | ||
- name: Checkout | ||
uses: actions/checkout@v4 | ||
- name: Detect package manager | ||
id: detect-package-manager | ||
run: | | ||
if [ -f "${{ github.workspace }}/yarn.lock" ]; then | ||
echo "manager=yarn" >> $GITHUB_OUTPUT | ||
echo "command=install" >> $GITHUB_OUTPUT | ||
echo "runner=yarn" >> $GITHUB_OUTPUT | ||
exit 0 | ||
elif [ -f "${{ github.workspace }}/package.json" ]; then | ||
echo "manager=npm" >> $GITHUB_OUTPUT | ||
echo "command=ci" >> $GITHUB_OUTPUT | ||
echo "runner=npx --no-install" >> $GITHUB_OUTPUT | ||
exit 0 | ||
else | ||
echo "Unable to determine package manager" | ||
exit 1 | ||
fi | ||
- name: Setup Node | ||
uses: actions/setup-node@v4 | ||
with: | ||
node-version: "20" | ||
cache: ${{ steps.detect-package-manager.outputs.manager }} | ||
- name: Setup Pages | ||
uses: actions/configure-pages@v5 | ||
with: | ||
# Automatically inject basePath in your Next.js configuration file and disable | ||
# server side image optimization (https://nextjs.org/docs/api-reference/next/image#unoptimized). | ||
# | ||
# You may remove this line if you want to manage the configuration yourself. | ||
static_site_generator: next | ||
- name: Restore cache | ||
uses: actions/cache@v4 | ||
with: | ||
path: | | ||
.next/cache | ||
# Generate a new cache whenever packages or source files change. | ||
key: ${{ runner.os }}-nextjs-${{ hashFiles('**/package-lock.json', '**/yarn.lock') }}-${{ hashFiles('**.[jt]s', '**.[jt]sx') }} | ||
# If source files changed but packages didn't, rebuild from a prior cache. | ||
restore-keys: | | ||
${{ runner.os }}-nextjs-${{ hashFiles('**/package-lock.json', '**/yarn.lock') }}- | ||
- name: Install dependencies | ||
run: ${{ steps.detect-package-manager.outputs.manager }} ${{ steps.detect-package-manager.outputs.command }} | ||
- name: Check environment variable | ||
run: echo NEXT_PUBLIC_API_URL | ||
- name: Create .env file | ||
run: | | ||
echo NEXT_PUBLIC_API_URL=${{ secrets.NEXT_PUBLIC_API_URL }} >> .env | ||
- name: Build with Next.js | ||
run: ${{ steps.detect-package-manager.outputs.runner }} next build | ||
- name: Export with Next.js | ||
run: ${{ steps.detect-package-manager.outputs.runner }} next export | ||
- name: Upload artifact | ||
uses: actions/upload-pages-artifact@v3 | ||
with: | ||
path: ./out |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -13,8 +13,8 @@ | |
/.next/ | ||
/out/ | ||
|
||
# production | ||
/build | ||
# # production | ||
# /build | ||
|
||
# misc | ||
.DS_Store | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
import { CalendarDate } from "./calendar"; | ||
import client, { ResponseBody } from "./client"; | ||
|
||
export interface Program { | ||
name: string; | ||
dueDate: CalendarDate; | ||
openDate: CalendarDate; | ||
location: string; | ||
category: string; | ||
host: string; | ||
schedule: string; | ||
description: string; | ||
} | ||
|
||
async function postAttendanceCode(challengeIdx: number): Promise<ResponseBody> { | ||
const { data } = await client.post(`/challenges/attendance/${challengeIdx}`); | ||
return data; | ||
} | ||
|
||
async function postProgram(body: Program): Promise<ResponseBody> { | ||
const { data } = await client.post(`/programs`, body); | ||
return data; | ||
} | ||
|
||
export { postAttendanceCode, postProgram }; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
import { useMutation, useQueryClient } from "@tanstack/react-query"; | ||
import { Program, postAttendanceCode, postProgram } from "../admin"; | ||
import { useRouter } from "next/router"; | ||
|
||
function usePostAttendanceCode(challengeIdx: number) { | ||
const { mutate } = useMutation({ | ||
mutationKey: ["postAttendanceCode", challengeIdx], | ||
mutationFn: () => postAttendanceCode(challengeIdx), | ||
onSuccess: (data) => window.alert(`인증번호: ${data}`), | ||
onError: () => window.alert("에러 발생. 앱 관리자에게 문의해주세요."), | ||
}); | ||
|
||
return { mutate }; | ||
} | ||
|
||
function usePostProgram() { | ||
const router = useRouter(); | ||
const queryclient = useQueryClient(); | ||
|
||
const { mutate } = useMutation({ | ||
mutationKey: ["postProgram"], | ||
mutationFn: (body: Program) => postProgram(body), | ||
onSuccess: () => { | ||
queryclient.invalidateQueries({ | ||
queryKey: ["getMyChallengeList"], | ||
}); | ||
window.alert("프로그램이 성공적으로 등록되었습니다."); | ||
router.push("/"); | ||
}, | ||
onError: () => router.push("/404"), | ||
}); | ||
|
||
return { mutate }; | ||
} | ||
|
||
export { usePostAttendanceCode, usePostProgram }; |
Oops, something went wrong.