Website | Documentation | Coming Soon
A collection of open source components & services supporting the creation of transformative learning experiences using open web standards. Some representative examples:
- Higher Diploma in Computer Science at SETU
- Full Stack Development
- Classic Design Patterns
- Agile Software Development
- Technologische Fähigkeiten
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 sites/tutors-course-reader
and copy the file .env.example
to .env
cp .\.env.example .env
Now navigate back to the root folder for the project:
cd ../../
Now to start our reader with this command:
npm run reader
You should see an output similar to below:
> [email protected] reader
> turbo run dev --filter tutors-course-reader
• Packages in scope: tutors-course-reader
• Running dev in 1 packages
cache bypass, force executing 41ecfc6ec2765918
> [email protected] dev
> vite
VITE v3.1.3 ready in 212 ms
➜ Local: http://localhost:5000/
➜ Network: http://192.168.112.86:5000/
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/full-stack-web-dev-oth-2022.netlify.app
... can be loaded locally by:
http://localhost:5000/#/course/full-stack-web-dev-oth-2022.netlify.app
(Note the port number may vary - for example 5001)
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.
This is a monorepo for all of the components & services of the Tutors Open Source Project. There are three categories of independent sub-projects:
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 Svelte 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
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.
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.
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.
This project is powered by Netlify Open Source.
This project is licensed under the terms of the MIT License.