Skip to content

Latest commit

 

History

History
243 lines (177 loc) · 8.5 KB

README.md

File metadata and controls

243 lines (177 loc) · 8.5 KB

FinMetrics: Ometman

logo

FinMetrics Application: by Ometman

"FinMetrics" is an SPA(Sinple-Page Application) that shows the World Bank metrics on Indicators for Sub-Saharan African countries. It serves information for politicians, journalists and all regional economic data lovers. As a Redux-React app state is manage by Redux. Its functionality consumes a World Bank Indicator API and dynamically populates the home page. Addtionally, detail metrics can be accessed through buttons on the home page for each country. This typically is a way 'prop-drilling'. Currently, it has only two pages, the home page and the details page. On the frontend, the React framework is employed to display contents the components, as Redux manages the consumption of the API coming from the Backend of the World Bank API services.

It was setup with 'create-react-app' with Redux and employs components, props, routing and Redux states, including Jest testing and other related libraries. Enjoy it!

📗 Table of Contents

📖 FinMetrics Web Application

A Demo Video: Introduction to this Project --View here>>>> FinMetrics Demo

The project includes designs for two different screen sizes.

  • Mobile: up to 768px wide.
  • Desktop: 768px or wider, with a maximum width of 600px;

Project Brief :

  • It is built on a design by Nelson Sakwa on Behance.
  • It is a single page App
  • It displays 2 pages: Home and Details.
  • Content is dynamic, using React components routes and Redux state management.
  • Use of Axios within Redux-ThunkAPI for data fetch.
  • Employed Jest testing framework for testing components.

🛠 Built With

Tech Stack

Client
  • Pure JSX
  • CSS
  • Webpack
  • Behance-based design from Nelson Sakwa
  • Jest Testing Framework
  • Base public Economic Indicator API from World Bank
  • Axios
Server
  • Optionally: Deployable Using GitHub Pages, Netlify, Render
  • Uses API and Github Servers
  • Databases
  • Currently, utilizes Public API Service entities.
  • Key Features

    • Conversion of a Behance real design using Pure JSX*
    • Uses Jest testing and webpack bundled in the 'create-react-app
    • Uses Redux for fetching data from API using 'createReduxThunk' and state management*
    • *A simple home page with 18 countries from Sub-Saharan Africa with flag images
    • A details page giving detail metrics on each country accessed through the home page*
    • Responsive Web Design: Desktop & Mobile
    • Consummes a World Bank Economic Indicator API for dynamic content

    (back to top)

    (back to top)

    💻 Getting Started

    To get a local copy up and running, follow these steps.

    Prerequisites

    In order to run this project you need:

    • Git
    • An IDE (e.g. VS Code)
    • A good modern Browser (eg: Chrome, Edge).

    Setup

    • Using Git Bash or any integrated terminal of you choice:
      • Open your code editor (e.g. VS Code).
      • At the terminal, clone this repository to your desired directory.
      • Make sure you have node (www.nodejs.org)
      • Run npm intall at the prompt
        • Make sure all dependencies( eg: webpack, webpack dev server, css-loader, sass-loader)

    Usage

    To run the project locally, execute the following command:

    • Run npm run server (You should see a success result)
    • Now access the app on port 3000 by entering the following in your browser:
    • http://localhost:3000

    Run tests

    To run tests, run the following command:


    Initial Step:


    • mkdir .github/workflows
    • copy the linters.yml file to the directory created above.
    • touch .gitignore if not created already and add node_modules/ to it.
    • initialize npm to create package.json file by running the command:

    npm i -y

    (here i for install & -y for saying yes to all)


    For Stylelint


    • Run

    npm install --save-dev stylelint@13.x stylelint-scss@3.x stylelint-config-standard@21.x stylelint-csstree-validator@1.x

    • Copy .stylelintrc.json to the root directory of your project.

    • Run

    npx stylelint "**/*.{css,scss}" on the root of your directory of your project.

    • Fix linter errors.

    ESLint


    • Run

    npm install --save-dev eslint@7.x eslint-config-airbnb@18.x eslint-plugin-import@2.x eslint-plugin-jsx-a11y@6.x eslint-plugin-react@7.x eslint-plugin-react-hooks@4.x @babel/eslint-parser@7.x @babel/core@7.x @babel/plugin-syntax-jsx@7.x @babel/preset-env@7.x @babel/preset-react@7.x

    • Copy .eslintrc.json to the root directory of your project.

    • Copy .babelrc.json to the root directory of your project.

    • Run

    npx eslint .
    on the root of your directory of your project.

    • Fix linter errors.

    • For functionality testing, Run

    npm test or npm run test All test must pass without error

    Deployment

    You can deploy this project using:

    • GitHub Pages from a specific branch (e.g. main).
    • You can also used any cloud service like gcloud or Azure.
    • A deployed version can be found here: [https://https://finmetrics.onrender.com/]

    (back to top)

    👥 Author

    Developed by: Omet Omeni (Ometman)

    Authors

    (back to top)

    🔭 Future Features

    • Improving voice and setting functionalities
    • Improving interactivity
    • Adding additional Economic data from another API
    • Changing UI - look and feel
    • Improved Aesthetics & Design
    • Adding 'help' and contact info pages

    (back to top)

    🤝 Contributing

    Contributions, issues, and feature requests are welcome!

    Feel free to check the issues page.

    (back to top)

    ⭐️ Show your support

    As a tech enthusiast, your support is always appreciated. If you like this project please do let us know with your support in any way you see fit.

    (back to top)

    🙏 Acknowledgments

    I would like to thank especially Microverse for inspiring this project & project guidelines. A special thanks also goes to Nelson Sakwa for the design on Behance.

    (back to top)

    ❓ FAQ

    • Can I fork this project?

      • Yes, feel free to fork and knock yourself out :) .
    • Can I share this project with others?

      • Yes, you can share this project for any educational purposes.

    (back to top)

    📝 License

    This project is MIT licensed.

    (back to top)