Git Product home page Git Product logo

te-emprego's Introduction

Te Emprego

O Te Emprego é um projeto criado por @danielbonifacio que consiste em uma plataforma 100% gratuita e funcional para a procura e divulgação de qualquer tipo de emprego/serviço.

Knowledge necessário para contribuir

  • ES6
  • React
  • Styled Components

Não pretende dar suporte a Internet Explorer, independente da versão.

Design

Abaixo algumas especificações de design.

Download do pacote de identidade visual em pdf ou ai

Cores

  • Primaria: #673AB7 (available at: config.colors.primary)
  • Texto escuro: #646464 (available at: config.colors.darkText)
  • Texto claro: #707070 (available at: config.colors.lightText)
  • Branco: #707070 (available at: config.colors.white)

Espaçamentos

Espaçamentos por escala:

  1. 20px (default)
  2. 40px
  3. 60px

Raio de borda

  1. 10px (default)
  2. 5px

This project was bootstrapped with Create React App.

Available Scripts

In the project directory, you can run:

npm start

Runs the app in the development mode.
Open http://localhost:3000 to view it in the browser.

The page will reload if you make edits.
You will also see any lint errors in the console.

npm test

Launches the test runner in the interactive watch mode.
See the section about running tests for more information.

npm run build

Builds the app for production to the build folder.
It correctly bundles React in production mode and optimizes the build for the best performance.

The build is minified and the filenames include the hashes.
Your app is ready to be deployed!

See the section about deployment for more information.

npm run eject

Note: this is a one-way operation. Once you eject, you can’t go back!

If you aren’t satisfied with the build tool and configuration choices, you can eject at any time. This command will remove the single build dependency from your project.

Instead, it will copy all the configuration files and the transitive dependencies (Webpack, Babel, ESLint, etc) right into your project so you have full control over them. All of the commands except eject will still work, but they will point to the copied scripts so you can tweak them. At this point you’re on your own.

You don’t have to ever use eject. The curated feature set is suitable for small and middle deployments, and you shouldn’t feel obligated to use this feature. However we understand that this tool wouldn’t be useful if you couldn’t customize it when you are ready for it.

Learn More

You can learn more in the Create React App documentation.

To learn React, check out the React documentation.

Code Splitting

This section has moved here: https://facebook.github.io/create-react-app/docs/code-splitting

Analyzing the Bundle Size

This section has moved here: https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size

Making a Progressive Web App

This section has moved here: https://facebook.github.io/create-react-app/docs/making-a-progressive-web-app

Advanced Configuration

This section has moved here: https://facebook.github.io/create-react-app/docs/advanced-configuration

Deployment

This section has moved here: https://facebook.github.io/create-react-app/docs/deployment

npm run build fails to minify

This section has moved here: https://facebook.github.io/create-react-app/docs/troubleshooting#npm-run-build-fails-to-minify

te-emprego's People

Contributors

brunogcpinheiro avatar danielbonifacio avatar hugo-cardoso avatar vdurante avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

te-emprego's Issues

Tela: Cadastro Usuário

Desenvolver tela de cadastro de usuários.

  • Web
  • Mobile a critério do desenvolvedor

Gradiente

  • #8F54F8
  • #673AB7

Fontes

(ambas disponíveis no Google Fonts, padrões do projeto)

  • Raleway
  • Nunito

Tela: Validar Token

Desenvolver tela de validacao de token.

  • Web
  • Mobile a critério do desenvolvedor

Gradiente

  • #8F54F8
  • #673AB7

Fontes

(ambas disponíveis no Google Fonts, padrões do projeto)

  • Raleway
  • Nunito

Tela: Listagem de Jobs

Desenvolver tela de listagem de jobs.

Gradiente

  • #8F54F8
  • #673AB7

Fontes

(ambas disponíveis no Google Fonts, padrões do projeto)

  • Raleway
  • Nunito

Contribuição

Não vi nenhum topico a respeito, como funciona a contribuição para o projeto?

Sou dev front-end, alem do projeto contribuir no meu aprendizado, vou poder contribuir bastante com o projeto

Components

Sugestão de components baseada no layout.

  • Botão fixo no lado direito para criar as ofertas.
  • Evento click na oferta.
  • Modal com resumo da oferta do pretendente.
  • Registrar de tempo de trabalho.

Seria interessante adaptação para mobile.

Post: Cadastro de usuário

Ao cadastrar um usuário, utilizar o schema abaixo:

{
  "user": {
    "email": "[email protected]",
    "password": "password123",
    "name": "Daniel Bonifacio",
    "address": {
      "city": "Vila Velha",
      "state": "ES",
      "country": "BR"
    },
    "experienceLevel": 3,
    "jobSearchingStatus": 1,
    "avatar": "default.png", // should be an base64
    "phone": "27992699969"
  }
}

Validação na API:
https://github.com/te-emprego/api/blob/a45d96ee87a938d35f5d44f0a93560b6f6be753d/src/modules/Users/methods/Create.method.ts#L7-L37

Tela: Visualizar job

Desenvolver tela de visualizacão de job.

Gradiente

  • #8F54F8
  • #673AB7

Fontes

(ambas disponíveis no Google Fonts, padrões do projeto)

  • Raleway
  • Nunito

Site Institucional

O institucional deverá conter informações de lançamento, e, posteriormente, irá trazer algumas vagas da API com base no usuário.

Por hora, basta:

  • Vue
  • Nuxt
  • Bootstrap (grid-only)

Tela: Perfil [App]

Tela de edição de perfil dentro do App.

JSON:

perfil = {
  nome: 'Fulano de Tal',
  idade: 42,
  tipo: 'empregado' || 'empregador',
  interessesProfissionais: [1, 4], // relação de interesses profissionais (consultar API de interesses)
  interessesPessoais: [
    'Tocar Violão',
    'Jogar Futebol',
    'Andar de Skate',
    'Ler livros',
  ],
  idiomas: [
    {
      nivel: 'Nativo' || 4,
      idioma: 'Português',
      curso: false,
    },
    {
      nivel: 'Avançado',
      idioma: 'Inglês',
      curso: false,
    },
    {
      nivel: 'Fluente',
      idioma: 'Alemão',
      curso: true,
    },
  ],
  contato: {
    email: '[email protected]',
    telefone: '27999001143',
    whatsApp: true,
    telegram: false,
    endereco: 'Rua X, numero Y, Bairro Z',
    cidade: 'Osasco',
    estado: 'São Paulo',
    cep: '00000000'
  },
  curriculo: {
    formado: false,
    autodidata: false,
    experiencia: [
      {
        autonomo: false,
        de: '2018-03-21',
        ate: '2018-04-21' || null,
        empresa: 'Pota Toe' || 212 || null, // a gente vai ter um cadastro de empresas, ele pode relacionar ou não
        cargo: 'Descascador de batata',
        descricao: 'A principal responsabilidade do cargo era descascar batatas...',
      },
      {
        autonomo: true,
        de: '2019-01-01',
        ate: null,
        empresa: null,
        cargo: 'Cozinheiro',
        descricao: 'Tenho um pequeno restaurante na zona sul...',
      },
    ],
    ensino: [
      {
        tipo: 'Ensino médio', // tem que ser relacionado isso aqui
        local: 'EEEM Escolinha do Gugu',
        emAndamento: false,
        conclusao: '2000' || false,
      },
      {
        tipo: 'Ensino superior',
        local: 'EEEM Escolinha do Gugu',
        emAndamento: true,
        conclusao: '2019',
      },
    ]
  }
}

Tela: Cadastro

Desenvolver tela de login.

  • Web
  • Mobile a critério do desenvolvedor

Gradiente

  • #8F54F8
  • #673AB7

Fontes

(ambas disponíveis no Google Fonts, padrões do projeto)

  • Raleway
  • Nunito

isso não é um issue

Parabéns pelo projeto! bem bacana.. Vi seus outros projetos pessoais também, e achei bem bacanas! Continue assim ;)

Reporte de documentação

  • Seria interessante oferece uma documentação em português e inglês, visto o alcance nacional.
  • Documentação de como contribuir para teemprego.
  • Documentação de código de conduta.

Overlay em menu mobile

Quando abrimos o menu mobile através do icone de hamburguer, temos que fechar através do mesmo ícone. Acho que uma boa solução para isso seria a inclusão de um overlay que fica abaixo do menu mas cobrindo toda a tela. Esse overlay pode pegar os eventos de click fora da região do menu para alterar o estado do menu para fechado e do overlay para desabilitado.
Captura de tela de 2019-09-14 16-26-10

Structure: Alias imports

Habilitar alias do Webapck

Para poder configurar, é necessário fazer o eject das configurações.

  • Extrar scripts do react-scripts npm run eject
  • Adicionar o diretório config aos ignores do ESLint
  • Configurar os aliases no arquivo do Webpack
  • Habilitar os aliases no arquivo jsconfig.json para que a IDE reconheça
  • Refatorar todos os imports para os alias, e não relative paths.

Webpack:

As configurações do Webpack ficam disponíveis em config/webpack.config.js.

webpackConfig: {
  resolve: {
    alias: {
    alias: {
        'react-native': 'react-native-web',
        '@components': path.resolve(__dirname, '../src/components'),
        '@config': path.resolve(__dirname, '../src/config'),
        '@views': path.resolve(__dirname, '../src/views'),
        '@app': path.resolve(__dirname, '../src/App'),
        '@': path.resolve(__dirname, '../src')
      }
    }
  }
}

JSConfig:

{
  "compilerOptions": {
    "target": "es2017",
    "allowSyntheticDefaultImports": false,
    "baseUrl": "./src",
    "paths": {
      "@components/*": ["./components/*"],
      "@config/*": ["./config/*"],
      "@views/*": ["./views/*"],
      "@app/*": ["./App/*"],
      "@/*": ["./*"]
    }
  },
  "exclude": ["node_modules", "build"]
}

Componente: Menu mobile

Desenvolver componente de menu para mobile.

Lembrando que o menu lateral deverá extender o componente da sidebar, de filtros.

Tela: Cadastro Empregador

Desenvolver tela de cadastro de empregador.

  • Web
  • Mobile a critério do desenvolvedor

Gradiente

  • #8F54F8
  • #673AB7

Fontes

(ambas disponíveis no Google Fonts, padrões do projeto)

  • Raleway
  • Nunito

Code refacotr/beautify

Precisamos de padronizar o código:

  • Instalar o ESLint (standard ou airbnb, de preferência, sem semicolons)
  • Mover o padrão de importação de components de acordo com o informado na issue

Padrão de components

Atualmente, os componentes precisam ser importados com redundância de código.
Exemplo: import Header from '@components/Header/Header.component'

A ideia é que ele possa ser importado via
import Header from '@components/Header'

Tela: Home [App]

Esta tela precisa ser desenvolvida pensando no Redux.

Será necessário:

  • Instalar o Redux no projeto
  • Colocar a tela para ler state do redux
  • Desenvolver os componentes da tela

Home

Source:

[
  {
    _id: Object.Id, // id do banco
    title: String,
    description: String, // limitado
    
    details: {
      period: String, // Full Time, etc.
      contract: String, // CLT, PJ, etc.
      remote: Boolean,
      salary: Number, // mascarado em reais por mês
      englishLevel: Number // 0 a 3
    },

    employer: {
      name: String,
      avatar: String // link da imagem de avatar
    }
  }
]

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.