Skip to content

Commit

Permalink
Added JavaScript reactjs build template to the repository
Browse files Browse the repository at this point in the history
  • Loading branch information
vazzanag committed Apr 26, 2024
1 parent 0a34869 commit f988749
Show file tree
Hide file tree
Showing 2 changed files with 115 additions and 0 deletions.
62 changes: 62 additions & 0 deletions .github/workflows/deploy.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
name: React JS Deploy

on:
push:
branches:
- "**generated-build_**"
pull_request:
branches:
- "**generated-build_**"

permissions:
contents: write

jobs:
generate-and-deploy:
runs-on: ubuntu-latest

steps:
- name: Checkout repository
uses: actions/checkout@v2

- name: Create React App
run: npx create-react-app my-app

- name: Find and rename generated code file
run: |
generated_file=$(find . -type f -name 'generated_code_*.js')
if [ -n "$generated_file" ]; then
mv "$generated_file" generated_code.js
fi
- name: Replace existing app.js with generated code
run: |
if [ -f "generated_code.js" ]; then
cat generated_code.js > my-app/src/App.js
fi
# Remove the generated code file
rm generated_code.js
- name: Build React app
run: |
cd my-app
npm install
npm run build
- name: Commit and push changes
if: success()
run: |
git config --global user.email "placeholder"
git config --global user.name "placeholder"
git add .
git commit -m "Update app.js with generated code and build React app"
git push origin ${{ github.ref_name }}
- name: Deploy 🚀
id: deploy
uses: JamesIves/github-pages-deploy-action@v4
with:
folder: my-app/build # The folder containing the built React app
branch : github-pages-${{ github.ref_name }} # The branch the action should deploy to.

53 changes: 53 additions & 0 deletions generated_code_26_04_2024_17_08_54.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@

import React, { useState } from 'react';
import { makeStyles } from '@material-ui/core/styles';
import TextField from '@material-ui/core/TextField';
import Button from '@material-ui/core/Button';

const useStyles = makeStyles((theme) => ({
root: {
display: 'flex',
flexDirection: 'column',
alignItems: 'center',
padding: '32px 0',
},
form: {
display: 'flex',
flexDirection: 'column',
alignItems: 'center',
padding: '32px 0',
},
input: {
margin: '0 16px',
},
}));

const App = () => {
const [name, setName] = useState('');

const handleSubmit = (event) => {
event.preventDefault();
console.log('Submitting form with name:', name);
};

return (
<form onSubmit={handleSubmit}>
<div className={classes.root}>
<TextField
id="name"
label="What is your name?"
margin="normal"
type="text"
value={name}
onChange={(event) => setName(event.target.value)}
/>
<Button variant="contained" color="primary" type="submit">
Submit
</Button>
</div>
</form>
);
};

export default App;

0 comments on commit f988749

Please sign in to comment.