Skip to content

Latest commit

 

History

History
214 lines (175 loc) · 4.87 KB

README.md

File metadata and controls

214 lines (175 loc) · 4.87 KB

Tsore.js - Flux-like store micro-library

The library is designed to realized simple Flux-like store interface.

The code is based on Riot.js, Loot.js, and RiotControl.js libraries.

Tsore was a Freighter Type C belonging to the Rebel Alliance during the Galactic Civil War.
[Source](http://starwars.wikia.com/wiki/Tsore)

Examples

Plese see the following examples:

ToDo demo (based in RiotControl todo demo).

Initializing

In browser:

<script src="tsore.js"></script>

With require.js:

   define(['tsore.js'],function(flux){

   });

In Node.js

   var tsore = require('tsore');

Example

Create new Store in simple way:

    var store = tsore.observable();
    store.name = undefined;
    store.on('login',function(name){
    	this.name = name;
    	tsore.on('name_changed');
    });
    store.on('logout',function(name){
    	this.name = undefined;
    	tsore.on('name_changed');
    });

Or you can create new store with tsore.Store class constructor:

    var store  = new tsore.Store({
        // Here we define actions
        login: function(name,password) {
        	this.name = name;
        	this.password = password;
    		return 'change'; 
    	},
    	logout: function() {
    		this.name = undefined;
    		return 'change';
    	},
    },
    // And here - functions and open default values
    {
        name: 'Andrey',
    	getName: function(){
    		return this.name;
    	}
    });

You also can create store manually with constructor function:

   tsore.register('TrafficLight', function(){
        var state = 'red';
        on('Trigger', function(){
            state = state == 'red'?'green':'red';
            tsore.trigger('change');
        });
   })


Register new store with Tsore controller:
```js
    tsore.register(store);
    tsore.action('login','Andrey');
    console.log(store.getName);

API

Functions for tsore:

	tsore.register(store) or register('name',store)
	tsore.action('action',parameters)
	tsore.store('name')
	tsore.on('event',function(){})
	tsore.one('event',function(){})
	tsore.off('event',function(){})
	tsore.trigger('event',parameters);

Functions for tsore.observable:

    tsore.observable(obj);

Alternative way to create new object:

    var obj = tsore.observable({});
    // or
    var obj = tsore.observable();

This add following functions:

    obj.on()
    obj.one()
    obj.off()
    obj.trigger()

See Riot.js documentation for more detailes.

Changes from Riot.js

Now you can define your own dispatcher function to process all events.

    this.on('Action1 Action2 Action3'); // Registration of actions
    this.on(function(action){
    	if(action == 'Action1') {
    		// Do Action 1
    	} else if(action == 'Action2') {
    		// Do Action 2
    	} else if(action == 'Action3') {
    		// Do Action 3
    	}
    })

tsore object

tsore is the main object of the library. It plays the role of main dispatcher for the page.

Flux Pattern

  1. User creates and register the store
    tsore.register('userStore',{
        Login:function(auth) {
            this.name = auth.name;
            this.passord = auth.password;
            tsore.trigger('change');
        }
    },{name:'',password:''});

2. View calls for action
```js
    tsore.action('Login',{name:'Andrey',password:'123'});
  1. Dispatcher calls all registred stores for the action 'login'.

  2. Store 'userStore' processes login in the Login action

            this.name = auth.name;
            this.passord = auth.password;
  1. At the end Store emit 'change' event:
             tsore.trigger('change');
  1. This event will be catched by the view. It uodate fields and call 'update' event:
    tsore.on('change', function(){
        this.name = tsore.store('userStore').name;
        this.password = ''; // Hide the password
        this.update();
    })

Riot.js and Tsore.js

You can use the both libraries together with Tsore mixin:

	mixin('tsore');
	this.attach('storeName', updateFunction);

For example, you can link Riot element and Tsore store:

	mixin('tsore');
	this.attach('trafficLight', function(store){
		this.color = store.getState();
	});

This function will be called after each time the storage fires change event. After the function run, Tsore will call this.update() after each call.