Skip to content

rafabernad/ng-websql

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

29 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

angular-websql

An easy to use webSQL wrapper for AngularJS

As easy as creating your factories to define your database structure and your resource methods:

.factory('samples', ['db', function(db) {
  return db.resource({
    name: "samples",
    columns: [{
        name: 'id',
        type: db.types.INTEGER,
        primaryKey: true,
        autoincrement: false
      }, {
        name: 'name',
        type: db.types.TEXT,
        unique: true
      }, {
        name: 'key',
        type: db.types.INTEGER,
    }],
    foreignKeys: {
        'key': {
          'parentTable': 'id'
        }
    },
    //get all records
    query: function() {
      return db.query('SELECT * FROM samples')
        .then(function(result) {
          return db.fetchAll(result);
        });
    },
    //get a record by id
    get: function(id) {
      return db.query('SELECT * FROM samples WHERE id= ?', [id])
        .then(function(result) {
          return db.fetch(result);
        });
    },
    //and so on
  });
}])

It supports all the basic stuff anyone would need on a daily basis:

Foreign Keys

foreignKeys: {
    'key': {
        'parentTable': 'id'
    }
},

Constrains

{
    name: 'value',
    type: db.types.INTEGER,
    check: '> 2'
}

Triggers

{
    name: 'value',
    type: db.types.INTEGER,
    check: '> 2',
    triggers: {
        update: {
            name: "value-update", // optional, if not provided will generate with FIEL_NAME + '-' + INSERT|DELETE|UPDATE 
            before: false, //so 'AFTER',
            query: 'whatever sql statement'
        }
    }
}

Installation

You can use bower:

bower install ng-websql

Or npm:

npm install ng-websql

That's it!

Configuration

The only thing you need is the database details:

.constant('dbConfig', {
    name: "sampleDb",
    version: '1.0',
    description: 'sample database',
    size: -1
})