Skip to content

Latest commit

 

History

History
152 lines (102 loc) · 4.79 KB

README.md

File metadata and controls

152 lines (102 loc) · 4.79 KB

lea.online core library

Test suite built with Meteor Project Status: Active – The project has reached a stable, usable state and is being actively developed. JavaScript Style Guide GitHub

This library includes the most common reusable components, which are involved across (nearly) all lea.online applications.

The package is splitted into server and client exports, so they won't interfere with one another. However, there is also common (shared) contents, that is part of both exports.

Table of Contents

Architecture overview

The following overview tries to summarize this relationship:

package overview

Doesn't this design create coupling?

Yes and no. On the one hand it clearly couples apps to this library. On the other hand this is just a reference implementation for common behavior in the apps. Many apps will have to use the same TTS engine but are not forced to, they could also implement their own. Since our apps currently all run on NodeJs + Meteor we use this library in all of them.

Second, the apps don't import the whole library but only those modules that are used in separate files.

Domain model

Summary

The domain of LEA is shaped by a "Competency Model" that is realized by executing certain actionable "Units". These Units contain several tasks and items, that are in turn linked to the competencies.

Scoring the items leads to estimations of fulfilled competencies and alpha-levels, where thresholds define the level of accomplishment.

Units are grouped in UnitSets, which usually group Units with same contextual background (story, characters) together.

Users will work through one or more UnitSets in a TestCycle, which bundles these UnitSets in regards to a certain Dimension, Level or Field (of work).

Installation and initialization

Install this on your lea.online app via

meteor add leaonline:corelib

Beware to import (export) files separately, for example:

imports/contexts/Unit.js

import { Unit } from 'meteor/leaonline:corelib/contexts/Unit'

Unit.methods = Unit.methods || {}

// add a custom, app-specific method definition


Unit.methods.foo = {
  name: 'unit.methods.foo',
  schema: { bar: String },
  run: function ({ bar }) {
    // ... logic
  }
}

export { Unit }

or simply export (in case there are no additions to make) via

export { Unit } from 'meteor/leaonline:corelib/contexts/Unit'

Component overview

Common / isomporph

Common refers to code, that is shared among server and client.

Errors

We use for common / generic errors some custom classes that extend Meteor.Error to increase DRY

i18n

Translation wrapper (currently using ostrio:i18n) including default translations for labels that are used in this core library. Use Meteor.settings to define a "system language" that defaults on the server.

utils

Some utilities are shared accross architectures to ensure a good fullstack experience. The mostly include accounts and architectural utils or check-matchers.

Client-only

The client part of this package consists of the common / shared

TTSCLient

  • Wrapper library for the browser's SpeechSynth API, provides a fallback, where a certain tts is synthesized on the server and sent to the client as audio stream.

Testing

We use a proxy project for testing. Please follow the steps for setup and run:

$ cd test-proxy
$ meteor npm install
$ meteor npm run setup
$ meteor npm run test:watch

License

All components of this library are released under MIT license, see LICENSE