0.0.1 • Published 7 years ago

sos-workflow-steps v0.0.1

Weekly downloads
1
License
MIT
Repository
-
Last release
7 years ago

FeedHenry WFM workflow

This module contains a workflow model representation and its related services :

  • Backend services
  • Frontend services
  • Frontend UI templates

Client-side usage

Client-side usage (via broswerify)

Setup

This module is packaged in a CommonJS format, exporting the name of the Angular namespace. The module can be included in an angular.js as follows:

angular.module('app', [
, require('fh-wfm-workflow')
...
])

Integration

Angular controller

A sync manager must first be initialized using the workflowSync.createManager(). This can be placed, for instance, in the resolve config of a ui-router controlled application.

resolve: {
  workflowManager: function(workflowSync) {
    return workflowSync.createManager();
  }
}

For a more complete example, please check the demo portal app.

workflowSync API

These workflowSync API methods all return Promises:

workflowSync methodDescription
workflowSync.manager.listlist all workflows
workflowSync.manager.create(workflow)create a workflow
workflowSync.manager.read(workflowId)read a workflow
workflowSync.manager.update(workflow)update a workflow

workflow directives

NameAttributes
workflow-progressstepIndex, workflow
workflow-stepstep, workflow
workflow-resultworkflow, result
workflow-formvalue
workflow-step-formworkflow, step, forms
workflow-step-detailstep

Usage in an express backend

Setup

The server-side component of this WFM module exports a function that takes express and mediator instances as parameters, as in:

var express = require('express')
  , app = express()
  , mbaasExpress = mbaasApi.mbaasExpress()
  , mediator = require('fh-wfm-mediator/lib/mediator')
  ;

// configure the express app
...

// setup the wfm workflow sync server
require('fh-wfm-workflow/server')(mediator, app, mbaasExpress);

Server side events

the module broadcasts, and listens for the following events

Listens forResponds with
wfm:workflow:listdone:wfm:workflow:list
wfm:workflow:readdone:wfm:workflow:read
wfm:workflow:updatedone:wfm:workflow:update
wfm:workflow:createdone:wfm:workflow:create

Integration

Check this demo cloud application

workflow data structure example

  {
    id: 1338,
    title: 'App forms',
    steps: [
      {code: 'identification', name: 'Identification', formId: '56c1fce7c0a909d74e823317'},
      {code: 'signoff', name: 'Signoff', formId: '56bdf252206b0cba6f35837b'}
    ]
  }