Add env variables and scripts to start it
This commit is contained in:
		
							parent
							
								
									f1940ef7b6
								
							
						
					
					
						commit
						71621cbb0d
					
				
					 8 changed files with 80 additions and 1 deletions
				
			
		
							
								
								
									
										1
									
								
								.env
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.env
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1 @@ | |||
| REACT_APP_VERSION=$npm_package_version | ||||
							
								
								
									
										1
									
								
								.env.dev
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.env.dev
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1 @@ | |||
| REACT_APP_ENVIRONMENT_NAME=dev | ||||
							
								
								
									
										1
									
								
								.env.prod
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.env.prod
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1 @@ | |||
| REACT_APP_ENVIRONMENT_NAME=prod | ||||
							
								
								
									
										40
									
								
								package-lock.json
									
										
									
										generated
									
									
									
								
							
							
						
						
									
										40
									
								
								package-lock.json
									
										
									
										generated
									
									
									
								
							|  | @ -16,6 +16,7 @@ | |||
|         "@testing-library/react": "^13.2.0", | ||||
|         "@testing-library/user-event": "^13.5.0", | ||||
|         "dayjs": "^1.11.3", | ||||
|         "env-cmd": "^10.1.0", | ||||
|         "html-react-parser": "^3.0.4", | ||||
|         "react": "^18.1.0", | ||||
|         "react-dom": "^18.1.0", | ||||
|  | @ -6448,6 +6449,29 @@ | |||
|         "url": "https://github.com/fb55/entities?sponsor=1" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/env-cmd": { | ||||
|       "version": "10.1.0", | ||||
|       "resolved": "https://registry.npmjs.org/env-cmd/-/env-cmd-10.1.0.tgz", | ||||
|       "integrity": "sha512-mMdWTT9XKN7yNth/6N6g2GuKuJTsKMDHlQFUDacb/heQRRWOTIZ42t1rMHnQu4jYxU1ajdTeJM+9eEETlqToMA==", | ||||
|       "dependencies": { | ||||
|         "commander": "^4.0.0", | ||||
|         "cross-spawn": "^7.0.0" | ||||
|       }, | ||||
|       "bin": { | ||||
|         "env-cmd": "bin/env-cmd.js" | ||||
|       }, | ||||
|       "engines": { | ||||
|         "node": ">=8.0.0" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/env-cmd/node_modules/commander": { | ||||
|       "version": "4.1.1", | ||||
|       "resolved": "https://registry.npmjs.org/commander/-/commander-4.1.1.tgz", | ||||
|       "integrity": "sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA==", | ||||
|       "engines": { | ||||
|         "node": ">= 6" | ||||
|       } | ||||
|     }, | ||||
|     "node_modules/error-ex": { | ||||
|       "version": "1.3.2", | ||||
|       "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", | ||||
|  | @ -19891,6 +19915,22 @@ | |||
|       "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz", | ||||
|       "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==" | ||||
|     }, | ||||
|     "env-cmd": { | ||||
|       "version": "10.1.0", | ||||
|       "resolved": "https://registry.npmjs.org/env-cmd/-/env-cmd-10.1.0.tgz", | ||||
|       "integrity": "sha512-mMdWTT9XKN7yNth/6N6g2GuKuJTsKMDHlQFUDacb/heQRRWOTIZ42t1rMHnQu4jYxU1ajdTeJM+9eEETlqToMA==", | ||||
|       "requires": { | ||||
|         "commander": "^4.0.0", | ||||
|         "cross-spawn": "^7.0.0" | ||||
|       }, | ||||
|       "dependencies": { | ||||
|         "commander": { | ||||
|           "version": "4.1.1", | ||||
|           "resolved": "https://registry.npmjs.org/commander/-/commander-4.1.1.tgz", | ||||
|           "integrity": "sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA==" | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     "error-ex": { | ||||
|       "version": "1.3.2", | ||||
|       "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", | ||||
|  |  | |||
|  | @ -11,6 +11,7 @@ | |||
|     "@testing-library/react": "^13.2.0", | ||||
|     "@testing-library/user-event": "^13.5.0", | ||||
|     "dayjs": "^1.11.3", | ||||
|     "env-cmd": "^10.1.0", | ||||
|     "html-react-parser": "^3.0.4", | ||||
|     "react": "^18.1.0", | ||||
|     "react-dom": "^18.1.0", | ||||
|  | @ -26,6 +27,8 @@ | |||
|     "build": "react-scripts build", | ||||
|     "test": "react-scripts test", | ||||
|     "eject": "react-scripts eject", | ||||
|     "start:dev": "env-cmd -f .env.dev npm run start", | ||||
|     "start:prod": "env-cmd -f .env.prod npm run start ", | ||||
|     "deploy:prod": "rsync -avz --progress build/ ifsalas:/home/ifsalas/web/prod --delete", | ||||
|     "deploy:dev": "rsync -avz --progress build/ ifsalas:/home/ifsalas/web/dev --delete" | ||||
|   }, | ||||
|  |  | |||
|  | @ -10,13 +10,16 @@ import { | |||
|   ListItemIcon, | ||||
|   ListItemText, | ||||
|   Toolbar, | ||||
|   Typography, | ||||
| } from '@mui/material'; | ||||
| import { NavLink, useNavigate } from 'react-router-dom'; | ||||
| import logoImage from '../../assets/if-salas-logo.svg'; | ||||
| import styles from './styles'; | ||||
| import { environmentNameDashAppVersion } from '../../utils/env'; | ||||
| 
 | ||||
| function MainMenu({ options, layoutType }) { | ||||
|   const { menuContainer, navigator, item, itemIcon } = styles[layoutType]; | ||||
|   const { menuContainer, envDashVersionTypography, navigator, item, itemIcon } = | ||||
|     styles[layoutType]; | ||||
|   const navigate = useNavigate(); | ||||
|   const [selectedOption, setSelectedOption] = useState( | ||||
|     options.find(option => option.isActive) | ||||
|  | @ -42,6 +45,10 @@ function MainMenu({ options, layoutType }) { | |||
|             </ListItem> | ||||
|           ))} | ||||
|         </List> | ||||
| 
 | ||||
|         <Typography sx={envDashVersionTypography} variant="body2"> | ||||
|           {environmentNameDashAppVersion()} | ||||
|         </Typography> | ||||
|       </Drawer> | ||||
|     ); | ||||
|   } else if (layoutType === 'mobile') { | ||||
|  |  | |||
|  | @ -8,6 +8,16 @@ const desktopMenuContainer = { | |||
|     boxSizing: 'border-box', | ||||
|     backgroundColor: 'secondary.main', | ||||
|   }, | ||||
|   position: 'relative', | ||||
| }; | ||||
| 
 | ||||
| const desktopEnvDashVersionTypography = { | ||||
|   position: 'absolute', | ||||
|   bottom: '0', | ||||
|   textAlign: 'center', | ||||
|   color: '#ffffff', | ||||
|   width: '100%', | ||||
|   marginBottom: '20px', | ||||
| }; | ||||
| 
 | ||||
| const desktopToolbar = { | ||||
|  | @ -35,6 +45,7 @@ const desktopListItemIcon = { | |||
| 
 | ||||
| const desktop = { | ||||
|   menuContainer: desktopMenuContainer, | ||||
|   envDashVersionTypography: desktopEnvDashVersionTypography, | ||||
|   navigator: desktopToolbar, | ||||
|   item: desktopListItem, | ||||
|   itemIcon: desktopListItemIcon, | ||||
|  | @ -50,6 +61,7 @@ const mobileMenuContainer = { | |||
| 
 | ||||
| const mobile = { | ||||
|   menuContainer: mobileMenuContainer, | ||||
|   envDashVersionTypography: null, | ||||
|   navigator: null, | ||||
|   item: null, | ||||
|   itemIcon: null, | ||||
|  | @ -58,6 +70,7 @@ const mobile = { | |||
| // ========== Unset ==========
 | ||||
| const unset = { | ||||
|   menuContainer: null, | ||||
|   envDashVersionTypography: null, | ||||
|   navigator: null, | ||||
|   item: null, | ||||
|   itemIcon: null, | ||||
|  |  | |||
							
								
								
									
										13
									
								
								src/utils/env.js
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								src/utils/env.js
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,13 @@ | |||
| function appVersion() { | ||||
|   return process.env.REACT_APP_VERSION; | ||||
| } | ||||
| 
 | ||||
| function environmentName() { | ||||
|   return process.env.REACT_APP_ENVIRONMENT_NAME; | ||||
| } | ||||
| 
 | ||||
| function environmentNameDashAppVersion() { | ||||
|   return `${environmentName()}-${appVersion()}`; | ||||
| } | ||||
| 
 | ||||
| export { environmentNameDashAppVersion }; | ||||
		Loading…
	
	Add table
		
		Reference in a new issue