Skip to content

Latest commit

 

History

History
83 lines (54 loc) · 2.71 KB

README.md

File metadata and controls

83 lines (54 loc) · 2.71 KB

Aprendi

Aprendi is a tool built by Libraries Without Borders to help communities curate local resources in a dynamic, reliable, and relevant fashion.

The live site can be found at https://www.aprendi.org/.

This repo contains the client app code, the backend codebase can be found here

Requirements

For development, you will need Node.js installed in your environment and an environment file from the project administrator.


Install

$ git clone https://github.com/librarieswithoutborders/aprendi.git
$ cd aprendi
$ npm install

You will also need to request an environment file from the project administrators and have the backend server running

Development: Start/Watch/Eslint

$ npm run dev

Development: Test Local Build for Production

$ npm run build

Production Deployment

See Deployment Page in Wiki


Languages & tools

HTML

JavaScript

CSS

Autoprefixer is included and use caniuse.com database to avoid outdated prefixes.


Project Structure

  • tools/ : lint, build, and deployment tools
  • src/ : app source code
    • actions/ : action creators split out by content type
    • components/ : React components below the page-level
      • admin-components/ : Admin components
      • sitewide-components/ : Non-admin components
    • pages/ : React page-level components
    • reducers/ : reducers split out by content type
    • static/ : images and svg files
    • styles/ : scss files
      • base/ : document-level styles
      • components/ : component styles
      • mixins/ : breakpoint and text mixins
      • variables/ : breakpoint, color, etc. variables
      • index.scss : entry point for scss files
    • utils/ : helper functions for input validation/processing, etc.
    • constants.js : editor constants
    • index.ejs : template processed by webpack to generate html entrypoint
    • index.js : js entry point, imports styles from /styles/index.scss
    • routes.js : routes for react-router
    • store.js : redux store