-
Notifications
You must be signed in to change notification settings - Fork 87
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
21 changed files
with
285 additions
and
38 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
{ | ||
"name": "angular-restmod", | ||
"version": "1.1.5", | ||
"version": "1.1.6", | ||
"authors": [ | ||
"Ignacio Baixas <[email protected]>" | ||
], | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
/** | ||
* API Bound Models for AngularJS | ||
* @version v1.1.5 - 2014-12-10 | ||
* @version v1.1.6 - 2015-01-06 | ||
* @link https://github.com/angular-platanus/restmod | ||
* @author Ignacio Baixas <[email protected]> | ||
* @license MIT License, http://www.opensource.org/licenses/MIT | ||
|
@@ -687,8 +687,8 @@ RMModule.factory('RMCommonApi', ['$http', 'RMFastQ', '$log', function($http, $q, | |
if(_for) { | ||
_for = '$' + _for + 'UrlFor'; | ||
if(this.$scope[_for]) return this.$scope[_for](this); | ||
} else if(this.$scope.$cannonicalUrlFor) { | ||
return this.$scope.$cannonicalUrlFor(this); | ||
} else if(this.$scope.$canonicalUrlFor) { | ||
return this.$scope.$canonicalUrlFor(this); | ||
} | ||
|
||
return this.$scope.$urlFor(this); | ||
|
@@ -2394,7 +2394,7 @@ RMModule.factory('RMBuilderRelations', ['$injector', 'inflector', '$log', 'RMUti | |
} | ||
} | ||
|
||
var scope = this.$buildScope(_model, _url || inflector.parameterize(_attr)), col; // TODO: name to url transformation should be a Model strategy | ||
var scope = this.$buildScope(_model, _url || _model.encodeUrlName(_attr)), col; | ||
|
||
// setup collection | ||
col = _model.$collection(_params || null, scope); | ||
|
@@ -2459,7 +2459,7 @@ RMModule.factory('RMBuilderRelations', ['$injector', 'inflector', '$log', 'RMUti | |
} | ||
} | ||
|
||
var scope = this.$buildScope(_model, _url || inflector.parameterize(_attr)), inst; | ||
var scope = this.$buildScope(_model, _url || _model.encodeUrlName(_attr)), inst; | ||
|
||
// setup record | ||
inst = _model.$new(null, scope); | ||
|
@@ -2689,8 +2689,8 @@ RMModule.factory('RMBuilderRelations', ['$injector', 'inflector', '$log', 'RMUti | |
}); | ||
|
||
}]); | ||
RMModule.factory('RMModelFactory', ['$injector', 'inflector', 'RMUtils', 'RMScopeApi', 'RMCommonApi', 'RMRecordApi', 'RMListApi', 'RMCollectionApi', 'RMExtendedApi', 'RMSerializer', 'RMBuilder', | ||
function($injector, inflector, Utils, ScopeApi, CommonApi, RecordApi, ListApi, CollectionApi, ExtendedApi, Serializer, Builder) { | ||
RMModule.factory('RMModelFactory', ['$injector', '$log', 'inflector', 'RMUtils', 'RMScopeApi', 'RMCommonApi', 'RMRecordApi', 'RMListApi', 'RMCollectionApi', 'RMExtendedApi', 'RMSerializer', 'RMBuilder', | ||
function($injector, $log, inflector, Utils, ScopeApi, CommonApi, RecordApi, ListApi, CollectionApi, ExtendedApi, Serializer, Builder) { | ||
|
||
var NAME_RGX = /(.*?)([^\/]+)\/?$/, | ||
extend = Utils.extendOverriden; | ||
|
@@ -3023,7 +3023,25 @@ RMModule.factory('RMModelFactory', ['$injector', 'inflector', 'RMUtils', 'RMScop | |
* @params {string} _name Record name | ||
* @return {string} Response (raw) name | ||
*/ | ||
encodeName: null | ||
encodeName: null, | ||
|
||
/** | ||
* @memberof StaticApi# | ||
* | ||
* @description The model name to url encoding strategy | ||
* | ||
* This method is called when translating a name into an url fragment (mainly by relations). | ||
* | ||
* By default it uses the `inflector.parameterize` method, in 1.2 this will change and the default | ||
* behaviour will be to do nothing. | ||
* | ||
* @params {string} _name local name | ||
* @return {string} url fragment | ||
*/ | ||
encodeUrlName: function(_name) { | ||
$log.warn('Default paremeterization of urls will be disabled in 1.2, override Model.encodeUrlName with inflector.parameterize in your base model to keep the same behaviour.'); | ||
return inflector.parameterize(_name); | ||
} | ||
|
||
}, ScopeApi); | ||
|
||
|
@@ -3302,7 +3320,10 @@ RMModule.factory('RMModelFactory', ['$injector', 'inflector', 'RMUtils', 'RMScop | |
*/ | ||
RMModule.factory('RMFastQ', [function() { | ||
|
||
var isFunction = angular.isFunction; | ||
var isFunction = angular.isFunction, | ||
catchError = function(_error) { | ||
return this.then(null, _error); | ||
}; | ||
|
||
function simpleQ(_val, _withError) { | ||
|
||
|
@@ -3314,6 +3335,7 @@ RMModule.factory('RMFastQ', [function() { | |
then: function(_success, _error) { | ||
return simpleQ(_withError ? _error(_val) : _success(_val)); | ||
}, | ||
'catch': catchError, | ||
'finally': function(_cb) { | ||
var result = _cb(); | ||
if(result && isFunction(_val.then)) { | ||
|
@@ -3347,6 +3369,7 @@ RMModule.factory('RMFastQ', [function() { | |
simple.then(_success, _error) : | ||
wrappedQ(_promise.then(_success, _error)); | ||
}, | ||
'catch': catchError, | ||
'finally': function(_cb) { | ||
return simple ? | ||
simple['finally'](_cb) : | ||
|
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
/** | ||
* API Bound Models for AngularJS | ||
* @version v1.1.5 - 2014-12-10 | ||
* @version v1.1.6 - 2015-01-06 | ||
* @link https://github.com/angular-platanus/restmod | ||
* @author Ignacio Baixas <[email protected]> | ||
* @license MIT License, http://www.opensource.org/licenses/MIT | ||
|
@@ -449,8 +449,8 @@ RMModule.factory('RMCommonApi', ['$http', 'RMFastQ', '$log', function($http, $q, | |
if(_for) { | ||
_for = '$' + _for + 'UrlFor'; | ||
if(this.$scope[_for]) return this.$scope[_for](this); | ||
} else if(this.$scope.$cannonicalUrlFor) { | ||
return this.$scope.$cannonicalUrlFor(this); | ||
} else if(this.$scope.$canonicalUrlFor) { | ||
return this.$scope.$canonicalUrlFor(this); | ||
} | ||
|
||
return this.$scope.$urlFor(this); | ||
|
@@ -2156,7 +2156,7 @@ RMModule.factory('RMBuilderRelations', ['$injector', 'inflector', '$log', 'RMUti | |
} | ||
} | ||
|
||
var scope = this.$buildScope(_model, _url || inflector.parameterize(_attr)), col; // TODO: name to url transformation should be a Model strategy | ||
var scope = this.$buildScope(_model, _url || _model.encodeUrlName(_attr)), col; | ||
|
||
// setup collection | ||
col = _model.$collection(_params || null, scope); | ||
|
@@ -2221,7 +2221,7 @@ RMModule.factory('RMBuilderRelations', ['$injector', 'inflector', '$log', 'RMUti | |
} | ||
} | ||
|
||
var scope = this.$buildScope(_model, _url || inflector.parameterize(_attr)), inst; | ||
var scope = this.$buildScope(_model, _url || _model.encodeUrlName(_attr)), inst; | ||
|
||
// setup record | ||
inst = _model.$new(null, scope); | ||
|
@@ -2451,8 +2451,8 @@ RMModule.factory('RMBuilderRelations', ['$injector', 'inflector', '$log', 'RMUti | |
}); | ||
|
||
}]); | ||
RMModule.factory('RMModelFactory', ['$injector', 'inflector', 'RMUtils', 'RMScopeApi', 'RMCommonApi', 'RMRecordApi', 'RMListApi', 'RMCollectionApi', 'RMExtendedApi', 'RMSerializer', 'RMBuilder', | ||
function($injector, inflector, Utils, ScopeApi, CommonApi, RecordApi, ListApi, CollectionApi, ExtendedApi, Serializer, Builder) { | ||
RMModule.factory('RMModelFactory', ['$injector', '$log', 'inflector', 'RMUtils', 'RMScopeApi', 'RMCommonApi', 'RMRecordApi', 'RMListApi', 'RMCollectionApi', 'RMExtendedApi', 'RMSerializer', 'RMBuilder', | ||
function($injector, $log, inflector, Utils, ScopeApi, CommonApi, RecordApi, ListApi, CollectionApi, ExtendedApi, Serializer, Builder) { | ||
|
||
var NAME_RGX = /(.*?)([^\/]+)\/?$/, | ||
extend = Utils.extendOverriden; | ||
|
@@ -2785,7 +2785,25 @@ RMModule.factory('RMModelFactory', ['$injector', 'inflector', 'RMUtils', 'RMScop | |
* @params {string} _name Record name | ||
* @return {string} Response (raw) name | ||
*/ | ||
encodeName: null | ||
encodeName: null, | ||
|
||
/** | ||
* @memberof StaticApi# | ||
* | ||
* @description The model name to url encoding strategy | ||
* | ||
* This method is called when translating a name into an url fragment (mainly by relations). | ||
* | ||
* By default it uses the `inflector.parameterize` method, in 1.2 this will change and the default | ||
* behaviour will be to do nothing. | ||
* | ||
* @params {string} _name local name | ||
* @return {string} url fragment | ||
*/ | ||
encodeUrlName: function(_name) { | ||
$log.warn('Default paremeterization of urls will be disabled in 1.2, override Model.encodeUrlName with inflector.parameterize in your base model to keep the same behaviour.'); | ||
return inflector.parameterize(_name); | ||
} | ||
|
||
}, ScopeApi); | ||
|
||
|
@@ -3064,7 +3082,10 @@ RMModule.factory('RMModelFactory', ['$injector', 'inflector', 'RMUtils', 'RMScop | |
*/ | ||
RMModule.factory('RMFastQ', [function() { | ||
|
||
var isFunction = angular.isFunction; | ||
var isFunction = angular.isFunction, | ||
catchError = function(_error) { | ||
return this.then(null, _error); | ||
}; | ||
|
||
function simpleQ(_val, _withError) { | ||
|
||
|
@@ -3076,6 +3097,7 @@ RMModule.factory('RMFastQ', [function() { | |
then: function(_success, _error) { | ||
return simpleQ(_withError ? _error(_val) : _success(_val)); | ||
}, | ||
'catch': catchError, | ||
'finally': function(_cb) { | ||
var result = _cb(); | ||
if(result && isFunction(_val.then)) { | ||
|
@@ -3109,6 +3131,7 @@ RMModule.factory('RMFastQ', [function() { | |
simple.then(_success, _error) : | ||
wrappedQ(_promise.then(_success, _error)); | ||
}, | ||
'catch': catchError, | ||
'finally': function(_cb) { | ||
return simple ? | ||
simple['finally'](_cb) : | ||
|
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
/** | ||
* API Bound Models for AngularJS | ||
* @version v1.1.5 - 2014-12-10 | ||
* @version v1.1.6 - 2015-01-06 | ||
* @link https://github.com/angular-platanus/restmod | ||
* @author Ignacio Baixas <[email protected]> | ||
* @license MIT License, http://www.opensource.org/licenses/MIT | ||
|
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
/** | ||
* API Bound Models for AngularJS | ||
* @version v1.1.5 - 2014-12-10 | ||
* @version v1.1.6 - 2015-01-06 | ||
* @link https://github.com/angular-platanus/restmod | ||
* @author Ignacio Baixas <[email protected]> | ||
* @license MIT License, http://www.opensource.org/licenses/MIT | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
/** | ||
* API Bound Models for AngularJS | ||
* @version v1.1.5 - 2014-12-10 | ||
* @version v1.1.6 - 2015-01-06 | ||
* @link https://github.com/angular-platanus/restmod | ||
* @author Ignacio Baixas <[email protected]> | ||
* @license MIT License, http://www.opensource.org/licenses/MIT | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
/** | ||
* API Bound Models for AngularJS | ||
* @version v1.1.5 - 2014-12-10 | ||
* @version v1.1.6 - 2015-01-06 | ||
* @link https://github.com/angular-platanus/restmod | ||
* @author Ignacio Baixas <[email protected]> | ||
* @license MIT License, http://www.opensource.org/licenses/MIT | ||
|
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
Oops, something went wrong.