-
Notifications
You must be signed in to change notification settings - Fork 65
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
Adicionando Firebase como base de dados. #95
base: master
Are you sure you want to change the base?
Changes from all commits
fb05691
b755f72
f19eecb
feeba82
85d2ac0
d36b2ae
506530d
605d517
8d497f9
2e9b744
afe770b
cc68c51
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1,8 @@ | ||
REACT_APP_DEVCHALLENGE_API=http://localhost:3333 | ||
REACT_APP_DEVCHALLENGE_API=http://localhost:3333 | ||
REACT_APP_FIREBASE_APIKEY=AIzaSyDlSDvVRBTuEBULLJ7F1Zny9uEKvm34U8I | ||
REACT_APP_FIREBASE_AUTHDOMAIN=devchallenge-16edf.firebaseapp.com | ||
REACT_APP_FIREBASE_PROJECTID=devchallenge-16edf | ||
REACT_APP_FIREBASE_STORAGEBUCKET=devchallenge-16edf.appspot.com | ||
REACT_APP_FIREBASE_MESSAGINGSENDERID=457450543508 | ||
REACT_APP_FIREBASE_APPID=1:457450543508:web:6afbe9416f72e9830b5781 | ||
REACT_APP_FIREBASE_MEASUREMENTID=G-KKVZ30J836 | ||
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
REACT_APP_DEVCHALLENGE_API=http://localhost:3333 | ||
REACT_APP_FIREBASE_APIKEY= | ||
REACT_APP_FIREBASE_AUTHDOMAIN= | ||
REACT_APP_FIREBASE_PROJECTID= | ||
REACT_APP_FIREBASE_STORAGEBUCKET= | ||
REACT_APP_FIREBASE_MESSAGINGSENDERID= | ||
REACT_APP_FIREBASE_APPID= | ||
REACT_APP_FIREBASE_MEASUREMENTID= |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,61 +1,64 @@ | ||
{ | ||
"name": "frontend", | ||
"version": "0.1.0", | ||
"private": true, | ||
"dependencies": { | ||
"@fortawesome/fontawesome-svg-core": "^1.2.28", | ||
"@fortawesome/free-brands-svg-icons": "^5.13.0", | ||
"@fortawesome/free-solid-svg-icons": "^5.13.0", | ||
"@fortawesome/react-fontawesome": "^0.1.9", | ||
"@lottiefiles/react-lottie-player": "^1.0.2", | ||
"@testing-library/jest-dom": "^4.2.4", | ||
"@testing-library/react": "^9.3.2", | ||
"@testing-library/user-event": "^7.1.2", | ||
"axios": "^0.21.2", | ||
"dotenv": "^8.2.0", | ||
"react": "^16.13.1", | ||
"react-awesome-slider": "^4.1.0", | ||
"react-dom": "^16.13.1", | ||
"react-icons": "^3.11.0", | ||
"react-loading-skeleton": "^2.0.1", | ||
"react-router-dom": "^5.2.0", | ||
"react-scripts": "3.4.1", | ||
"react-toastify": "^6.0.5", | ||
"react-web-vector-icons": "^1.0.2", | ||
"styled-components": "^5.1.1", | ||
"styled-media-query": "^2.1.2" | ||
}, | ||
"scripts": { | ||
"start": "react-scripts start", | ||
"build": "react-scripts build", | ||
"test": "react-scripts test", | ||
"eject": "react-scripts eject" | ||
}, | ||
"eslintConfig": { | ||
"extends": "react-app" | ||
}, | ||
"browserslist": { | ||
"production": [ | ||
">0.2%", | ||
"not dead", | ||
"not op_mini all" | ||
], | ||
"development": [ | ||
"last 1 chrome version", | ||
"last 1 firefox version", | ||
"last 1 safari version" | ||
] | ||
}, | ||
"devDependencies": { | ||
"babel-eslint": "^10.1.0", | ||
"eslint": "^6.8.0", | ||
"eslint-config-airbnb": "^18.1.0", | ||
"eslint-config-prettier": "^6.11.0", | ||
"eslint-plugin-import": "^2.20.2", | ||
"eslint-plugin-jsx-a11y": "^6.2.3", | ||
"eslint-plugin-prettier": "^3.1.3", | ||
"eslint-plugin-react": "^7.20.0", | ||
"eslint-plugin-react-hooks": "^2.5.1", | ||
"prettier": "^2.0.5" | ||
} | ||
"name": "frontend", | ||
"version": "0.1.0", | ||
"private": true, | ||
"dependencies": { | ||
"@fortawesome/fontawesome-svg-core": "^1.2.28", | ||
"@fortawesome/free-brands-svg-icons": "^5.13.0", | ||
"@fortawesome/free-solid-svg-icons": "^5.13.0", | ||
"@fortawesome/react-fontawesome": "^0.1.9", | ||
"@lottiefiles/react-lottie-player": "^1.0.2", | ||
"@testing-library/jest-dom": "^4.2.4", | ||
"@testing-library/react": "^9.3.2", | ||
"@testing-library/user-event": "^7.1.2", | ||
"axios": "^0.21.2", | ||
"dotenv": "^8.2.0", | ||
"firebase": "^10.4.0", | ||
"formik": "^2.4.4", | ||
"react": "^16.13.1", | ||
"react-awesome-slider": "^4.1.0", | ||
"react-dom": "^16.13.1", | ||
"react-icons": "^3.11.0", | ||
"react-loading-skeleton": "^2.0.1", | ||
"react-router-dom": "^5.2.0", | ||
"react-scripts": "3.4.1", | ||
"react-toastify": "^6.0.5", | ||
"react-web-vector-icons": "^1.0.2", | ||
"styled-components": "^5.1.1", | ||
"styled-media-query": "^2.1.2", | ||
"yup": "^1.2.0" | ||
}, | ||
"scripts": { | ||
"start": "react-scripts --openssl-legacy-provider start ", | ||
"build": "react-scripts --openssl-legacy-provider build", | ||
"test": "react-scripts test", | ||
"eject": "react-scripts eject" | ||
}, | ||
"eslintConfig": { | ||
"extends": "react-app" | ||
}, | ||
"browserslist": { | ||
"production": [ | ||
">0.2%", | ||
"not dead", | ||
"not op_mini all" | ||
], | ||
"development": [ | ||
"last 1 chrome version", | ||
"last 1 firefox version", | ||
"last 1 safari version" | ||
] | ||
}, | ||
"devDependencies": { | ||
"babel-eslint": "^10.1.0", | ||
"eslint": "^6.8.0", | ||
"eslint-config-airbnb": "^18.1.0", | ||
"eslint-config-prettier": "^6.11.0", | ||
"eslint-plugin-import": "^2.20.2", | ||
"eslint-plugin-jsx-a11y": "^6.2.3", | ||
"eslint-plugin-prettier": "^3.1.3", | ||
"eslint-plugin-react": "^7.20.0", | ||
"eslint-plugin-react-hooks": "^2.5.1", | ||
"prettier": "^2.0.5" | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,8 +1,17 @@ | ||
import './services/firebase-config'; | ||
import React from 'react'; | ||
import Routes from './routes'; | ||
import { ChallengesContextProvider } from './contexts/ChallengesContext'; | ||
import { AuthContextProvider } from './contexts/AuthContext'; | ||
|
||
function App() { | ||
return <Routes />; | ||
return ( | ||
<AuthContextProvider> | ||
<ChallengesContextProvider> | ||
<Routes /> | ||
</ChallengesContextProvider> | ||
</AuthContextProvider> | ||
); | ||
} | ||
|
||
export default App; |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -6,4 +6,5 @@ export const Techs = styled.section` | |
flex-wrap: wrap; | ||
align-items: center; | ||
justify-content: center; | ||
gap: 16px; | ||
`; |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,13 +2,23 @@ import React, { useState, useEffect } from 'react'; | |
|
||
import * as S from './styled'; | ||
|
||
const colorMatch = { | ||
beginner: 'nephritis', | ||
intermediate: 'pumpkin', | ||
advanced: 'pomegranate', | ||
Mobile: 'blue', | ||
Frontend: 'red', | ||
Backend: 'light-purple', | ||
const colorMatch = (option) => { | ||
switch (option) { | ||
case 'Iniciante': | ||
return 'nephritis'; | ||
case 'Intermediário': | ||
return 'pumpkin'; | ||
case 'Avançado': | ||
return 'pomegranate'; | ||
case 'Mobile': | ||
return 'blue'; | ||
case 'Front-end': | ||
return 'red'; | ||
case 'Back-end': | ||
return 'light-purple'; | ||
default: | ||
return 'green'; | ||
} | ||
Comment on lines
+5
to
+21
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Acho que seria uma boa manter o objeto para fazer o matching, apenas para fins de simplicidade, já que podemos acessar com |
||
}; | ||
|
||
function ChallengeCard({ challenge, progress, redirect, buttonText }) { | ||
|
@@ -34,24 +44,21 @@ function ChallengeCard({ challenge, progress, redirect, buttonText }) { | |
}, [challenge.techs]); | ||
|
||
return ( | ||
<S.ChallengeCard key={challenge._id}> | ||
<S.Anchor to={`/challenges/${challenge._id}/details`}> | ||
<S.ChallengeCard key={challenge.id}> | ||
<S.Anchor to={`/challenges/${challenge.id}/details`}> | ||
<S.CardImage> | ||
<S.CardTechs> | ||
{techs.map((item) => ( | ||
<p | ||
className="tech" | ||
key={`${item}-${challenge._id}`} | ||
> | ||
<p className="tech" key={`${item}-${challenge.id}`}> | ||
{item} | ||
</p> | ||
))} | ||
</S.CardTechs> | ||
<S.CardPlatforms> | ||
<S.Level color={colorMatch[challenge.type]}> | ||
<S.Level color={colorMatch(challenge.type)}> | ||
{challenge.type} | ||
</S.Level> | ||
<S.Level color={colorMatch[challenge.level]}> | ||
<S.Level color={colorMatch(challenge.level)}> | ||
{challenge.level} | ||
</S.Level> | ||
</S.CardPlatforms> | ||
|
@@ -60,10 +67,14 @@ function ChallengeCard({ challenge, progress, redirect, buttonText }) { | |
{progress && <S.ProgressBar progress={progress} />} | ||
</S.Anchor> | ||
<S.CardContent> | ||
<S.Anchor to={`/challenges/${challenge._id}/details`}> | ||
<S.Anchor to={`/challenges/${challenge.id}/details`}> | ||
<h1>{challenge.name}</h1> | ||
</S.Anchor> | ||
<p>{challenge.description}</p>{' '} | ||
<p> | ||
{challenge.description.length > 120 | ||
? challenge.description.substr(0, 120) + '...' | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
|
||
: challenge.description} | ||
</p>{' '} | ||
</S.CardContent> | ||
<S.Anchor to={`${redirect}`}> | ||
<S.Button>{buttonText}</S.Button> | ||
|
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.
acho que isso está aqui por engano!