Skip to content

Latest commit

 

History

History
81 lines (58 loc) · 3.01 KB

README.md

File metadata and controls

81 lines (58 loc) · 3.01 KB

angular-relational

Library to add basic relational constructs to AngularJS $resource objects.

Usage

  1. Add dependencies ('relational') to your app, and a module 'relational.config' module to configure relationships:

    app.js

    angular.module('myApp', ['relational']);
    
    
    var mod = angular.module('relational.config', []);
    mod.value('relational.config', {
        'child':{id:'childId',
                 relationships: {'parentId':'parent'},
                 backref:'children'},
       'parent':{id: 'parentId',
                 relationships: {}}
    });

    Each top level item defines an object type.

    • id points to the primary key for that object
    • relationships maps from fields on the object to the names of other relational objects
    • backref (optional) allows parent objects to reference the collection of children
  2. Declare your RelationalResource objects using the same identifiers in the config:

    var module = angular.module('myApp.services', ['relational']);
    
    module.factory('Child', function(RelationalResource){
    
        // parameters for RelationalResource are same as for $resource, but with addition of the
        // identifier as the first argument
        return RelationalResource('child', '/api/:childId', {childId:'@childId'});
    });
    
    module.factory('Parent', function(RelationalResource){
        return RelationalResource('parent', '/api/:parentId', {parentId:'@parentId'},
                                            {update:  {method:'PUT', isArray:false}});
    });
  3. Reference relationships through the associated functions

    child.parent();    // returns the parent matching the parentId
    parent.children(); // returns an array of 'Child' objects with the matching parentId
    
    //all the usual $resource constructs work as well
    child.$save();   // automatically adds child to parent.children();
    child.$delete(); // if successful, this child will no longer appear in parent.children()
  4. When loading JSON, nested objects will be deconstructed into Relational objects

    // note that the parentId must still be set on the nested objects for the
    // for the related objects to link correctly.  The relationship is not
    // inferred
    var parent = new Parent({parentId: 1,
                             children: [{childId:1, name:'John', parentId: 1},
                                        {childId:2, name:'Becky', parentId: 1}]});
    
    parent.children();  // returns an arry of 'Child' objects matching parentId
    

Current status

Alpha. Lacking tests. Searches for back-references aren't optimized, no good mechanism for garbage collection, circular references will probably break things.

Immediate Next Steps

  • Tests
  • Better mechanism for clearing out the relational cache
  • Better Nested Relationships/Composite Primary Keys
  • Make attached relational functions hybrid getter/setters