Skip to content

Commit f6d41a2

Browse files
committed
add front end
1 parent 7b610fb commit f6d41a2

File tree

19 files changed

+3612
-68
lines changed

19 files changed

+3612
-68
lines changed

.github/workflows/front-end.yml

Lines changed: 62 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,62 @@
1+
name: Frontend CI/CD
2+
3+
on:
4+
push:
5+
branches: [main]
6+
paths:
7+
- "front-end/**"
8+
9+
jobs:
10+
build-frontend:
11+
runs-on: ubuntu-latest
12+
defaults:
13+
run:
14+
working-directory: front-end
15+
steps:
16+
- name: Checkout code
17+
uses: actions/checkout@v4
18+
19+
- name: Setup Node.js
20+
uses: actions/setup-node@v4
21+
with:
22+
node-version: "24.8.0"
23+
cache: "npm"
24+
25+
- name: Install dependencies
26+
run: npm install
27+
28+
- name: Build frontend
29+
run: npm run build
30+
31+
- name: Upload build artifact
32+
uses: actions/upload-artifact@v4
33+
with:
34+
name: frontend-build
35+
path: dist/
36+
37+
deploy-frontend:
38+
runs-on: ubuntu-latest
39+
needs: build-frontend
40+
steps:
41+
- name: Checkout code
42+
uses: actions/checkout@v4
43+
44+
- name: Download build artifact
45+
uses: actions/download-artifact@v4
46+
with:
47+
name: frontend-build
48+
path: dist/
49+
50+
- name: Log in to Docker Hub
51+
uses: docker/login-action@v3
52+
with:
53+
username: ${{ secrets.DOCKER_HUB_USERNAME }}
54+
password: ${{ secrets.DOCKER_HUB_ACCESS_TOKEN }}
55+
56+
- name: Build Docker image
57+
uses: docker/build-push-action@v5
58+
with:
59+
context: ./front-end
60+
file: ./front-end/Dockerfile
61+
push: true
62+
tags: ${{ secrets.DOCKER_HUB_USERNAME }}/frontend-aws-integration:latest

.github/workflows/main.yml

Lines changed: 68 additions & 68 deletions
Original file line numberDiff line numberDiff line change
@@ -1,85 +1,85 @@
11
name: Java CI/CD with Docker
22
on:
3-
push:
4-
branches: [main]
5-
pull_request:
6-
branches: [main]
3+
push:
4+
branches: [main]
5+
paths-ignore:
6+
- "front-end/**"
77

88
jobs:
9-
test:
10-
runs-on: ubuntu-latest
11-
steps:
12-
- uses: actions/checkout@v4
9+
test:
10+
runs-on: ubuntu-latest
11+
steps:
12+
- uses: actions/checkout@v4
1313

14-
- name: Set up JDK 21
15-
uses: actions/setup-java@v4
16-
with:
17-
distribution: temurin
18-
java-version: "21"
19-
cache: maven
14+
- name: Set up JDK 21
15+
uses: actions/setup-java@v4
16+
with:
17+
distribution: temurin
18+
java-version: "21"
19+
cache: maven
2020

21-
- name: Run unit tests
22-
run: mvn test
21+
- name: Run unit tests
22+
run: mvn test
2323

24-
build:
25-
runs-on: ubuntu-latest
26-
steps:
27-
- uses: actions/checkout@v4
24+
build:
25+
runs-on: ubuntu-latest
26+
steps:
27+
- uses: actions/checkout@v4
2828

29-
- name: Set up JDK 21
30-
uses: actions/setup-java@v4
31-
with:
32-
distribution: temurin
33-
java-version: "21"
34-
cache: maven
29+
- name: Set up JDK 21
30+
uses: actions/setup-java@v4
31+
with:
32+
distribution: temurin
33+
java-version: "21"
34+
cache: maven
3535

36-
- name: Compile project
37-
run: mvn compile
36+
- name: Compile project
37+
run: mvn compile
3838

39-
package-jar:
40-
runs-on: ubuntu-latest
41-
needs: [test, build]
42-
steps:
43-
- uses: actions/checkout@v4
39+
package-jar:
40+
runs-on: ubuntu-latest
41+
needs: [test, build]
42+
steps:
43+
- uses: actions/checkout@v4
4444

45-
- name: Set up JDK 21
46-
uses: actions/setup-java@v4
47-
with:
48-
distribution: temurin
49-
java-version: "21"
50-
cache: maven
45+
- name: Set up JDK 21
46+
uses: actions/setup-java@v4
47+
with:
48+
distribution: temurin
49+
java-version: "21"
50+
cache: maven
5151

52-
- name: Package JAR
53-
run: mvn package -DskipTests
52+
- name: Package JAR
53+
run: mvn package -DskipTests
5454

55-
- name: Upload build artifact
56-
uses: actions/upload-artifact@v4
57-
with:
58-
name: app-jar
59-
path: target/aws-integration-0.0.1-SNAPSHOT.jar
55+
- name: Upload build artifact
56+
uses: actions/upload-artifact@v4
57+
with:
58+
name: app-jar
59+
path: target/aws-integration-0.0.1-SNAPSHOT.jar
6060

61-
build-docker-image:
62-
runs-on: ubuntu-latest
63-
needs: [package-jar]
64-
steps:
65-
- uses: actions/checkout@v4
61+
build-docker-image:
62+
runs-on: ubuntu-latest
63+
needs: [package-jar]
64+
steps:
65+
- uses: actions/checkout@v4
6666

67-
- name: Download built jar
68-
uses: actions/download-artifact@v4
69-
with:
70-
name: app-jar
71-
path: target
67+
- name: Download built jar
68+
uses: actions/download-artifact@v4
69+
with:
70+
name: app-jar
71+
path: target
7272

73-
- name: Log in to Docker Hub
74-
uses: docker/login-action@v3
75-
with:
76-
username: ${{ secrets.DOCKER_HUB_USERNAME }}
77-
password: ${{ secrets.DOCKER_HUB_ACCESS_TOKEN }}
73+
- name: Log in to Docker Hub
74+
uses: docker/login-action@v3
75+
with:
76+
username: ${{ secrets.DOCKER_HUB_USERNAME }}
77+
password: ${{ secrets.DOCKER_HUB_ACCESS_TOKEN }}
7878

79-
- name: Build Docker image
80-
uses: docker/build-push-action@v5
81-
with:
82-
context: .
83-
file: ./Dockerfile
84-
push: true
85-
tags: ${{ secrets.DOCKER_HUB_USERNAME }}/aws-integration:latest
79+
- name: Build Docker image
80+
uses: docker/build-push-action@v5
81+
with:
82+
context: .
83+
file: ./Dockerfile
84+
push: true
85+
tags: ${{ secrets.DOCKER_HUB_USERNAME }}/aws-integration:latest

front-end/.gitignore

Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
# Logs
2+
logs
3+
*.log
4+
npm-debug.log*
5+
yarn-debug.log*
6+
yarn-error.log*
7+
pnpm-debug.log*
8+
lerna-debug.log*
9+
10+
node_modules
11+
dist
12+
dist-ssr
13+
*.local
14+
15+
# Editor directories and files
16+
.vscode/*
17+
!.vscode/extensions.json
18+
.idea
19+
.DS_Store
20+
*.suo
21+
*.ntvs*
22+
*.njsproj
23+
*.sln
24+
*.sw?

front-end/Dockerfile

Lines changed: 20 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,20 @@
1+
FROM node:24.8.0 AS build
2+
3+
WORKDIR /app
4+
5+
COPY package*.json ./
6+
7+
RUN npm install
8+
9+
COPY . .
10+
11+
RUN npm run build # assumes output goes to /app/dist
12+
13+
14+
FROM nginx:alpine
15+
16+
COPY --from=build /app/dist /usr/share/nginx/html/
17+
18+
EXPOSE 80
19+
20+
CMD ["nginx", "-g", "daemon off;"]

front-end/README.md

Lines changed: 73 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,73 @@
1+
# React + TypeScript + Vite
2+
3+
This template provides a minimal setup to get React working in Vite with HMR and some ESLint rules.
4+
5+
Currently, two official plugins are available:
6+
7+
- [@vitejs/plugin-react](https://github.com/vitejs/vite-plugin-react/blob/main/packages/plugin-react) uses [Babel](https://babeljs.io/) (or [oxc](https://oxc.rs) when used in [rolldown-vite](https://vite.dev/guide/rolldown)) for Fast Refresh
8+
- [@vitejs/plugin-react-swc](https://github.com/vitejs/vite-plugin-react/blob/main/packages/plugin-react-swc) uses [SWC](https://swc.rs/) for Fast Refresh
9+
10+
## React Compiler
11+
12+
The React Compiler is currently not compatible with SWC. See [this issue](https://github.com/vitejs/vite-plugin-react/issues/428) for tracking the progress.
13+
14+
## Expanding the ESLint configuration
15+
16+
If you are developing a production application, we recommend updating the configuration to enable type-aware lint rules:
17+
18+
```js
19+
export default defineConfig([
20+
globalIgnores(['dist']),
21+
{
22+
files: ['**/*.{ts,tsx}'],
23+
extends: [
24+
// Other configs...
25+
26+
// Remove tseslint.configs.recommended and replace with this
27+
tseslint.configs.recommendedTypeChecked,
28+
// Alternatively, use this for stricter rules
29+
tseslint.configs.strictTypeChecked,
30+
// Optionally, add this for stylistic rules
31+
tseslint.configs.stylisticTypeChecked,
32+
33+
// Other configs...
34+
],
35+
languageOptions: {
36+
parserOptions: {
37+
project: ['./tsconfig.node.json', './tsconfig.app.json'],
38+
tsconfigRootDir: import.meta.dirname,
39+
},
40+
// other options...
41+
},
42+
},
43+
])
44+
```
45+
46+
You can also install [eslint-plugin-react-x](https://github.com/Rel1cx/eslint-react/tree/main/packages/plugins/eslint-plugin-react-x) and [eslint-plugin-react-dom](https://github.com/Rel1cx/eslint-react/tree/main/packages/plugins/eslint-plugin-react-dom) for React-specific lint rules:
47+
48+
```js
49+
// eslint.config.js
50+
import reactX from 'eslint-plugin-react-x'
51+
import reactDom from 'eslint-plugin-react-dom'
52+
53+
export default defineConfig([
54+
globalIgnores(['dist']),
55+
{
56+
files: ['**/*.{ts,tsx}'],
57+
extends: [
58+
// Other configs...
59+
// Enable lint rules for React
60+
reactX.configs['recommended-typescript'],
61+
// Enable lint rules for React DOM
62+
reactDom.configs.recommended,
63+
],
64+
languageOptions: {
65+
parserOptions: {
66+
project: ['./tsconfig.node.json', './tsconfig.app.json'],
67+
tsconfigRootDir: import.meta.dirname,
68+
},
69+
// other options...
70+
},
71+
},
72+
])
73+
```

front-end/eslint.config.js

Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
import js from '@eslint/js'
2+
import globals from 'globals'
3+
import reactHooks from 'eslint-plugin-react-hooks'
4+
import reactRefresh from 'eslint-plugin-react-refresh'
5+
import tseslint from 'typescript-eslint'
6+
import { defineConfig, globalIgnores } from 'eslint/config'
7+
8+
export default defineConfig([
9+
globalIgnores(['dist']),
10+
{
11+
files: ['**/*.{ts,tsx}'],
12+
extends: [
13+
js.configs.recommended,
14+
tseslint.configs.recommended,
15+
reactHooks.configs['recommended-latest'],
16+
reactRefresh.configs.vite,
17+
],
18+
languageOptions: {
19+
ecmaVersion: 2020,
20+
globals: globals.browser,
21+
},
22+
},
23+
])

front-end/index.html

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
<!doctype html>
2+
<html lang="en">
3+
<head>
4+
<meta charset="UTF-8" />
5+
<link rel="icon" type="image/svg+xml" href="/vite.svg" />
6+
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
7+
<title>front-end</title>
8+
</head>
9+
<body>
10+
<div id="root"></div>
11+
<script type="module" src="/src/main.tsx"></script>
12+
</body>
13+
</html>

0 commit comments

Comments
 (0)