Skip to content
forked from gazpachu/hypatia

Open Realtime Education. A FREE and open source LMS based on Facebook's React, Google's Firebase and Slack

Notifications You must be signed in to change notification settings

suhaizal/hypatia

Repository files navigation

Hypatia: open realtime education

WARNING

The project is currently under development, with countinous changes and some bits and bobs not working. Feel free to test it if you like but don't expect it to be production-ready until mid 2017.

More info

Demo: https://hypatia-8d923.firebaseapp.com

You need to sign up with a valid email address to access some pages.

Project's website: https://theonapps.github.io/hypatia/

Slack group (invitation only): https://hypatialms.slack.com To request for an invitation, please contact hello [@] theon {.} io

Home

Page

Admin

Getting Started

WARNING

This documentation is not stable. Don't test it yet!

npm install
  • Create a new project in your Firebase account

  • Create a file called firebase.jsx in /app/src/constants/ and add the following code with the details from the project you created:

export const firebaseConfig = {
  	apiKey: "",
    authDomain: "",
    databaseURL: "",
	storageBucket: "",
    messagingSenderId: ""
}
  • Import /data/hypatia-export.json into your Firebase database

  • Set the Firebase database rules to:

".read": "true",
".write": "auth != null"
  • Create a posts folder in Firebase storage and upload demo images with the same filename as the posts' slugs (i.e.: /posts/new-virtual-campus.jpg)

  • Set the Firebase storage rules to:

allow read: if true;
allow write: if request.auth != null;
  • Create as many groups (teams) in Slack.com as you want and add a custom integration (BOT) to each one of them

  • Create a file called slack.jsx in /app/src/constants/ with the following structure. Enter the apiToken for each BOT you created and enter the details that make more sense to your groups

export const slackGroups = [{
		name: 'Maths',
		id: 'maths',
		slug: 'MA',
		apiToken: ""
	},
	{
		name: 'English',
		id: 'english',
		slug: 'EL',
		apiToken: ""
	}						
]

Start development server with hot reloading

npm run dev

Testing

Run test once

npm run test

Test watch

npm run test:watch

Linting

Linting is using Airbnb Eslint configuration

npm run lint

Deploy to production

Build for production

npm run build

Install Firebase tools (if you haven't done it yet)

npm install -g firebase-tools

Login and init the project

firebase login
firebase init

Deploy to Firebase

firebase deploy

Credits

Icons from Flaticon.com (Freepik and Madebyoliver), triangles background by rvika from Fotolia and photos from Google Creative Commons search results

Copyright & License

Copyright (c) 2016-2017 Joan Siddharta Mira Martos (Theon.io) - Released under the GPLv2 license.

About

Open Realtime Education. A FREE and open source LMS based on Facebook's React, Google's Firebase and Slack

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 75.6%
  • CSS 23.3%
  • HTML 1.1%