11

An experiment to create a community-driven language learning platform

 4 years ago
source link: https://github.com/kantord/LibreLingo
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

logo_for_readme.svg?sanitize=true

an experiment to create a community-driven language-learning platform

Click here for live demo

Project goal

My goal is to start a community-driven language-learning platform that gives it's users and contributors a way to influence it's future and adapt it to special requirements.

To achieve that, I release all source code under the GPLv3 free software license, which guarantees end users the freedom to run, study, share, and modify the software.

In addition to licensing the software under a free software license, the course content will be decoupled from the software itself, and the development of GPLv3 or public domain course content will be encouraged. This should allow course developers to retain the freedom to choose how they use their work.

Once course content is properly decoupled from the software, it should be possible to experiment with alternative ways of using course content: for example, the creation of audiobooks or print material.

Screenshots

screenshot1.pngscreenshot2.pngscreenshot3.pngscreenshot4.png

Milestones

Here's a rough sketch of how I imagine the milestones of this project:

First demo

  • :ballot_box_with_check: Demo course content in Spanish for English speakers
  • :ballot_box_with_check: Some basic building blocks of course content implemented
  • :ballot_box_with_check: Developers can use course editor
  • :ballot_box_with_check: Basic theme/branding

Alpha release

  • ☐ Course progress can be properly syncronised across devices
  • ☐ Course editor can be accessed by all course contributors
  • ☐ Statistics about course controbutors are collected and published
  • ☐ At least the basics of the Spanish course are ready
  • ☐ Most of the course building blocks are implemented

Beta release

  • ☐ All of the basic building blocks of courses are implemented
  • ☐ More advanced learning features (reading exercises)
  • ☐ Spaced repetition implemented
  • ☐ Spanish course is stable and useful

Stable release(s)

  • ☐ Any user can build their own course
  • ☐ Users can suggest changes to course content
  • ☐ There's a marketplace for "unofficial" courses
  • ☐ Multiple stable courses available
  • ☐ Mobile apps available
  • ☐ Wiki features
  • ☐ Dictionary
  • ☐ Speaking exercises

Become a contributor

Contribute to course material

If you are interested in contributing to course development, please fill the following form: https://danielkantor196881.typeform.com/to/V00Paz . The project is in a very early stage right now, so you might not be able to contribute right away. Your work will be released in this GitHub repository and you will show up as a contributor here.

Contribute to software development

If you are interested in writing code for LibreLingo, you can simply start submitting pull requests. You can also use this form to get in touch: https://danielkantor196881.typeform.com/to/jTe9jX . You don't need to fill this form. You can just start submitting issues and pull requests if your wish!

Other forms of contribution

You can help LibreLingo by testing it and submitting feature requests or bug reports: https://github.com/kantord/LibreLingo/issues/new . If you want to get in touch, you can simply the contacts on my GitHub profile .

There is also a Matrix/FreeNode IRC channel #LibreLingo , instructions for joining:

  • Matrix: #LibreLingo on matrix.org
  • IRC: connect to irc.freenode.net with your favourite client and join #LibreLingo

Tech stack

​ Web app/PWA Course editor Frontend Svelte Django Admin* Backend CouchDB

* Djando Admin might be replaced in the future

Testing is done using Jest and Cypress. Other technology in use include: bulma, webpack, etc.

License

Development

Development documentation is available on Read the Docs

Contributors :sparkles:

Thanks goes to these wonderful people ( emoji key ):

3704904?v=4Daniel Kantor
:computer: 50620416?v=4Klemen Skerbiš 7361228?v=4Mirek Mazel 12728?v=4Chris Babcock 7890201?v=4Liaizon Wakest 1479555?v=4Trolli Schmittlauch 7600265?v=4Jérôme Deuchnord 1044450?v=4Felix Ableitner
:bug: 29234112?v=4Navan Chauhan
:computer: 8488446?v=4Roshan Jossy
:computer: :book: 57244557?v=4ledgelight 449545?v=4Francis Tyers
:book: 7551116?v=4titanix 139841?v=4Michael Moroni

This project follows the all-contributors specification. Contributions of any kind welcome!


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK