A tool for creating amazing, customizable front-end tutorials with ease
This is an alfa version of the package. It may not work as expected without minor tweaks just yet. Sorry for the inconvinience!
KIE is and acronym for Koduje's Interactive E-book - which was originally created as a new form of providing the content for the audience of Koduje.
It's goal was to provide an interactive form of learning-by-doing combined with ability to watch a video tutorial and seeing the preview of the code at glance - and It's goal hasn't changed.
The only thing that chagned is that now the KIE is an Open Source Project and anyone can use it to provide this kind of content to their audience
Checkout an example tutorial available online - Flexbox tutorial by Wojciech Połowniak (polish) or see kie-tutorials-repository for more examples
- Live preview of your code snippets in the browser
- Snippets are editable by default
- Ability to download the code from the exercise to zip file
- Customizable size of content/preview/video sections so the user can customize the layout of the exercise
- Ability to hide specific sections completely
- Multi monitor support - user can open the preview in new window and set editor into fullscreen mode. That provides a simple yet efficient web-based developing setup.
- Tooltips with explanation to various text fragments
- Built in Discuss support per each exercise
- Various plugins for easier understanding the issue you want to talk about (see Flexbox tutorial and axis highlightning)
- Links for specific parts of Youtube video from within tutorial contents
- Basic mobile support
- Building to static files HTML files
- Snippet creator as a Brackets extension
- Ability to select parts of code as hidden
- Ability to select parts of code as locked (not editable)
- Live preview during development via Browsersync
- Microlanguage for creating new exercises
$ npm install -g kie
or clone the repository if you're willing to help with development:
$ git clone git@github.com:Worie/kie.git --recursive [destination path]
and then initialize the repository while in your cloned, local repository:
$ npm install -g
Simply run
$ kie
Running kie
command will start a server with browsersync in which you'll find an example content.
Custom content can be easly created with kie-creator, which is a brackets extension that'll allow you to create snippets and content of your tutorial.
The kie
command will also start few watchers that'll update the project on every change in your tutorial source code and if you ever need to, the front end part.
You can start development of your own tutorial by passing a contentPath
argument to kie
which should point out to the root of your tutorial content, like so:
$ kie --contentPath="/absolute/path/to/your/content"
There are also other npm variables
that you can override with custom parameters passed to kie
.
See package.json
for available options for now.
KIE project purpose is to provide easy to use tool that'll allow creators creating rich, meaningful content about overall web development.
That being said I kindly encourage you to create tutorials that are checked when it comes to substantivity, teach good practices and follows the specification of technologies its about.
All tutorials created with this the help of this tool must contain the default copyright notice generated in each compiled, ready to use page.
Keep in mind that kie is licensed with MPL 2.0. I encourage to keep the source of exercises as a git repository, named in following pattern:
`kie/tutorial-${nameOfTutorial}`
That way other people can contribute to your tutorials, translate it and update it to follow the latest standards. Also it might be easier for other people to reach your content :)
Those can be later linked to tutorials (kie-tutorials) repository.
PRs are always welcome!
There are no tests written at this point - feel free to start!
We're using this Trello board for managing the issues, their importance and related topics.
This package consists a few modules (further modularization is probable in the future). Those are probably insteresting for people who are willing to help with development of KIE project.
- kie - a binder for all submodules. Builds front, copies it to backend and runs browser-sync. Watches content directory for changes and runs static-builder to update the contents.
- kie-example-content - contains an example content for KIE project, built by kie-creator
- kie-creator - Brackets extension for creating custom exercises
- kie-front - Module related to front-end stuff - such as displaying the panes, live preview in the browser etc.
- kie-backend - Module that's hosting the static files during development, as well as serving the API for kie-front.
- kie-lang - package containing custom markup language that can be used when developing new tutorials. (ultimately, we'd like to fork something like showdown instead of developing it completely from scratch)
- kie-common - common files for submodules
- kie-static-builder - builds the static files basing on kie-front and kie-example-content modules (or your custom content)
- kie-editor - that's where editor for the snippets is going to be stored once it's extracted from kie-front submodule
- kie-creator - Brackets extension for creating the contents of your tutorials
- kie-tutorials - place where you can store your tutorials
Those are separate repos to provide the ability to develop all of them in pararel and easier maintainance (perhaps)
There's a little technical debt in the initial stage of the project. For now, my vision of the project consists of:
- kie
- Clean up npm scripts (!)
- Fix browsersync
- Rebrand to devebook
- kie-front
- Refactor to Vue.js
- Webpack, TS, Vuex
- Use Carbon Design System for main components
- Redesign UI
- kie-creator
- rewrite to use async/await (!)
- kie-node
- kie-example-content
And lots of minor features, improvements once above is done.
You can track Trello for more details.
Enourmous thanks to Damian Wielgosik for forming the overall Koduje project, ignition of the original KIE idea and initial funding of the project.
Big thanks to Jarosław Rencz for implementing the initial PoC of core functionality and to all of Functionite crew for overall support in the early stages of development.
Big thanks to Jerzy Górski for beautiful graphics and animations made for Koduje project.
Big thanks to Mateusz Wierzbicki for UX and overall design support and feedback.
Big thanks to Jakub Maksimowicz for being a one-man circus during creation process in Koduje (video editing, recording, development)
kie by Wojciech Połowniak is licensed under MPL 2.0 (read more).