Skip to content
forked from tutors-sdk/tutors

Tutors is a collection of open source components & services supporting the creation of transformative learning experiences using open web standards.

License

Notifications You must be signed in to change notification settings

Irhutchi/tutors

Repository files navigation

Text changing depending on mode. Light: 'Tutors Light Mode Logo' Dark: 'Tutors Dark Mode Logo'

Tutors: An Open Learning Web Toolkit

Website | Documentation | Coming Soon

What is Tutors?

A collection of open source components & services supporting the creation of transformative learning experiences using open web standards. Some representative examples:

Getting Started

Make sure you have Node 16 + installed, and start by cloning this repo:

git clone https://github.com/tutors-sdk/tutors.git

Open a shell and...

cd tutors
npm install
npm run build

This may take a few minutes, and should conclude with:

...
Tasks:    6 successful, 6 total
Cached:   0 cached, 6 total

Change directory into sites/tutors-course-reader

cd apps/course

and copy the file .env.example to .env

cp .env.example .env

Now to start our reader with this command:

npm run dev

You should see an output similar to below:

> [email protected] dev
> vite dev --port 3000 --open



  VITE v4.0.4  ready in 1344 ms

  ➜  Local:   http://localhost:3000/
  ➜  Network: use --host to expose
  ➜  press h to show help
18:16:18 [vite-plugin-svelte] ssr compile in progress ...
Using browser-only version of superagent in non-browser environment
18:16:30 [vite-plugin-svelte] ssr compile done.
package                 files    time      avg
@skeletonlabs/skeleton     45   0.33s    7.4ms
tutors-course              19   0.22s   11.3ms
tutors-ui                  21   0.11s    5.4ms
@iconify/svelte             1   8.8ms    8.8ms

Now our Reader is up and running and you can browse to it by opening the local location in your browser. You should see a holding page informing you that you are running a reader with no content. The reader relies on a segment of the url to locate the course to display. Any of the samples above can be 'read' with an appropriate url segments appended to the local url you now have running. So for instance:

https://reader.tutors.dev/course/tutors-reference

... can be loaded locally by:

http://localhost:3000/course/tutors-reference

(Note the port number may vary - for example 3000)

The 'source' for the above course is here:

You could try any of the other sample courses above.

If you would like to build your own course then this workshop here would be a good place to start. In particular, this lab here will get you up and running with a sample course in a few minutes. More guidance and examples are on our Educator documentation site. To learn more about the project, explore the core principles at https://tutors.dev/.

If you have VSCode, you should be able to open project.

Project Structure

This is a monorepo for all of the components & services of the Tutors Open Source Project. There are three categories of independent sub-projects:

Sites

These are the student facing web applications for browsing a course, an application inspecting course analytics + a storybook encapsulation of UX elements. The principles embodied in the learner experience are presented here.

The main tutors user experience - demonstrated in the links above. This can be built and launched via the instructions above. It is a SvelteKit application that renders a course in an appealing, context sensitive user experience. An overview of the user experience is presented here. This is deployed to https://reader.tutors.dev

Also a Svelte application, this application presents the educational analytics gathered by the application. There is a student + an educator perspective. This is deployed to https://time.tutors.dev

The homepage of the Tutors project built with Astro. This is deployed at https://tutors.dev

Apps

These are command line applications used by educators to generate courses. The principles embodied in the educator experience are presented here.

The primary static site generator for tutors courses. It will injest a folder adhering to a prescribed format and generate a static site that can be rendered by the course reader. The overall approach + example folder structure is presented here. A tutorial on building a new course can be accessed here.

An alternative to tutors-json, this command line application generates a static site independent of the course reader. This presents a subset of the user experience, and is useful as an offline version of the course for backup purposes.

Components

Reusable components used in the apps & sites.

A shared set of config files which is used as a base for all sites, apps and components.

The parser library for a course. This component embodies the data structures constructed when in-jesting a course from a folder. Comparable to an Abstract Syntax Tree in a compiler, this tree is traversed to generate JSON and HTML versions by the apps above.

Comparable to tutors-lib, but intended for use in Svelte applications. Constructs a modified AST-like representation of a course as retrieved from a web-hosted, JSON version of a course. Also includes additional tools and utilities used in the readers.

A shared library of UI components which can be used to build Tutors.

Contributing

Please ensure to read the Code of Conduct before contributing to the Tutors project.

When contributing, pull requests should be opened to the 'development' branch, and once tested this will be merged to main.

Sponsors

This project is powered by Netlify Open Source.

Deploys by Netlify

License

license

This project is licensed under the terms of the MIT License.

About

Tutors is a collection of open source components & services supporting the creation of transformative learning experiences using open web standards.

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 48.6%
  • Svelte 34.1%
  • CSS 7.6%
  • Nunjucks 5.5%
  • JavaScript 2.8%
  • HTML 1.2%
  • Shell 0.2%