angular-gem 1.1.5 → 1.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/lib/angular-gem/version.rb +1 -1
- data/lib/tasks/copy.rake +22 -11
- data/lib/tasks/tag.rake +2 -11
- data/vendor/assets/javascripts/1.2.0/angular-animate.js +1226 -0
- data/vendor/assets/javascripts/1.2.0/angular-animate.min.js +21 -0
- data/vendor/assets/javascripts/1.2.0/angular-animate.min.js.map +8 -0
- data/vendor/assets/javascripts/{angular-cookies-unstable.js → 1.2.0/angular-cookies.js} +21 -4
- data/vendor/assets/javascripts/1.2.0/angular-cookies.min.js +8 -0
- data/vendor/assets/javascripts/1.2.0/angular-cookies.min.js.map +8 -0
- data/vendor/assets/javascripts/1.2.0/angular-csp.css +24 -0
- data/vendor/assets/javascripts/{angular-loader-unstable.js → 1.2.0/angular-loader.js} +48 -29
- data/vendor/assets/javascripts/1.2.0/angular-loader.min.js +8 -0
- data/vendor/assets/javascripts/1.2.0/angular-loader.min.js.map +8 -0
- data/vendor/assets/javascripts/{angular-mocks-unstable.js → 1.2.0/angular-mocks.js} +460 -216
- data/vendor/assets/javascripts/{angular-resource-unstable.js → 1.2.0/angular-resource.js} +189 -148
- data/vendor/assets/javascripts/1.2.0/angular-resource.min.js +12 -0
- data/vendor/assets/javascripts/1.2.0/angular-resource.min.js.map +8 -0
- data/vendor/assets/javascripts/1.2.0/angular-route.js +880 -0
- data/vendor/assets/javascripts/1.2.0/angular-route.min.js +14 -0
- data/vendor/assets/javascripts/1.2.0/angular-route.min.js.map +8 -0
- data/vendor/assets/javascripts/{angular-sanitize-unstable.js → 1.2.0/angular-sanitize.js} +142 -123
- data/vendor/assets/javascripts/1.2.0/angular-sanitize.min.js +14 -0
- data/vendor/assets/javascripts/1.2.0/angular-sanitize.min.js.map +8 -0
- data/vendor/assets/javascripts/{angular-scenario-unstable.js → 1.2.0/angular-scenario.js} +15978 -12405
- data/vendor/assets/javascripts/{angular-mobile-unstable.js → 1.2.0/angular-touch.js} +214 -111
- data/vendor/assets/javascripts/1.2.0/angular-touch.min.js +13 -0
- data/vendor/assets/javascripts/1.2.0/angular-touch.min.js.map +8 -0
- data/vendor/assets/javascripts/{angular-unstable.js → 1.2.0/angular.js} +10167 -7012
- data/vendor/assets/javascripts/1.2.0/angular.min.js +200 -0
- data/vendor/assets/javascripts/1.2.0/angular.min.js.map +8 -0
- data/vendor/assets/javascripts/1.2.0/errors.json +1 -0
- data/vendor/assets/javascripts/1.2.0/version.json +1 -0
- data/vendor/assets/javascripts/1.2.0/version.txt +1 -0
- data/vendor/assets/javascripts/angular-animate.js +1226 -0
- data/vendor/assets/javascripts/angular-animate.min.js +21 -0
- data/vendor/assets/javascripts/angular-cookies.js +21 -4
- data/vendor/assets/javascripts/angular-cookies.min.js +8 -0
- data/vendor/assets/javascripts/angular-loader.js +63 -17
- data/vendor/assets/javascripts/angular-loader.min.js +8 -0
- data/vendor/assets/javascripts/angular-mocks.js +553 -211
- data/vendor/assets/javascripts/angular-resource.js +268 -147
- data/vendor/assets/javascripts/angular-resource.min.js +12 -0
- data/vendor/assets/javascripts/angular-route.js +880 -0
- data/vendor/assets/javascripts/angular-route.min.js +14 -0
- data/vendor/assets/javascripts/angular-sanitize.js +165 -125
- data/vendor/assets/javascripts/angular-sanitize.min.js +14 -0
- data/vendor/assets/javascripts/angular-scenario.js +16615 -10889
- data/vendor/assets/javascripts/angular-touch.js +563 -0
- data/vendor/assets/javascripts/angular-touch.min.js +13 -0
- data/vendor/assets/javascripts/angular.js +9717 -4533
- data/vendor/assets/javascripts/angular.min.js +200 -0
- metadata +44 -21
- data/test/dummy/log/test.log +0 -2
- data/test/dummy/tmp/cache/assets/D65/250/sprockets%2F54a960d46bb0b354e8bd46fa03f5e0e4 +0 -0
- data/test/dummy/tmp/cache/assets/D6A/FB0/sprockets%2F92721e9941b77adcfdfba3d060622de2 +0 -0
- data/test/dummy/tmp/cache/assets/E07/040/sprockets%2Ff55b8ce9d0f28ce36b768a1c7aeb2ef3 +0 -0
- data/test/tmp/app/assets/javascripts/application.js +0 -5
@@ -1,15 +1,27 @@
|
|
1
1
|
/**
|
2
|
-
* @license AngularJS v1.
|
2
|
+
* @license AngularJS v1.2.0
|
3
3
|
* (c) 2010-2012 Google, Inc. http://angularjs.org
|
4
4
|
* License: MIT
|
5
5
|
*/
|
6
|
-
(function(window, angular, undefined) {
|
7
|
-
|
6
|
+
(function(window, angular, undefined) {'use strict';
|
7
|
+
|
8
|
+
var $resourceMinErr = angular.$$minErr('$resource');
|
8
9
|
|
9
10
|
/**
|
10
11
|
* @ngdoc overview
|
11
12
|
* @name ngResource
|
12
13
|
* @description
|
14
|
+
*
|
15
|
+
* # ngResource
|
16
|
+
*
|
17
|
+
* The `ngResource` module provides interaction support with RESTful services
|
18
|
+
* via the $resource service.
|
19
|
+
*
|
20
|
+
* {@installModule resource}
|
21
|
+
*
|
22
|
+
* <div doc-module-components="ngResource"></div>
|
23
|
+
*
|
24
|
+
* See {@link ngResource.$resource `$resource`} for usage.
|
13
25
|
*/
|
14
26
|
|
15
27
|
/**
|
@@ -24,25 +36,15 @@
|
|
24
36
|
* The returned resource object has action methods which provide high-level behaviors without
|
25
37
|
* the need to interact with the low level {@link ng.$http $http} service.
|
26
38
|
*
|
27
|
-
*
|
28
|
-
* To use $resource make sure you have included the `angular-resource.js` that comes in Angular
|
29
|
-
* package. You can also find this file on Google CDN, bower as well as at
|
30
|
-
* {@link http://code.angularjs.org/ code.angularjs.org}.
|
31
|
-
*
|
32
|
-
* Finally load the module in your application:
|
33
|
-
*
|
34
|
-
* angular.module('app', ['ngResource']);
|
35
|
-
*
|
36
|
-
* and you are ready to get started!
|
39
|
+
* Requires the {@link ngResource `ngResource`} module to be installed.
|
37
40
|
*
|
38
41
|
* @param {string} url A parametrized URL template with parameters prefixed by `:` as in
|
39
42
|
* `/user/:username`. If you are using a URL with a port number (e.g.
|
40
|
-
* `http://example.com:8080/api`),
|
41
|
-
* number, like this: `$resource('http://example.com\\:8080/api')`.
|
43
|
+
* `http://example.com:8080/api`), it will be respected.
|
42
44
|
*
|
43
|
-
* If you are using a url with a suffix, just add the suffix, like this:
|
44
|
-
* `$resource('http://example.com/resource.json')` or `$resource('http://example.com/:id.json')
|
45
|
-
* or even `$resource('http://example.com/resource/:resource_id.:format')`
|
45
|
+
* If you are using a url with a suffix, just add the suffix, like this:
|
46
|
+
* `$resource('http://example.com/resource.json')` or `$resource('http://example.com/:id.json')`
|
47
|
+
* or even `$resource('http://example.com/resource/:resource_id.:format')`
|
46
48
|
* If the parameter before the suffix is empty, :resource_id in this case, then the `/.` will be
|
47
49
|
* collapsed down to a single `.`. If you need this sequence to appear and not collapse then you
|
48
50
|
* can escape it with `/\.`.
|
@@ -62,7 +64,7 @@
|
|
62
64
|
*
|
63
65
|
* @param {Object.<Object>=} actions Hash with declaration of custom action that should extend the
|
64
66
|
* default set of resource actions. The declaration should be created in the format of {@link
|
65
|
-
* ng.$http#
|
67
|
+
* ng.$http#usage_parameters $http.config}:
|
66
68
|
*
|
67
69
|
* {action1: {method:?, params:?, isArray:?, headers:?, ...},
|
68
70
|
* action2: {method:?, params:?, isArray:?, headers:?, ...},
|
@@ -70,21 +72,23 @@
|
|
70
72
|
*
|
71
73
|
* Where:
|
72
74
|
*
|
73
|
-
* - **`action`** – {string} – The name of action. This name becomes the name of the method on
|
74
|
-
* resource object.
|
75
|
-
* - **`method`** – {string} – HTTP request method. Valid methods are: `GET`, `POST`, `PUT`,
|
76
|
-
* and `JSONP`.
|
77
|
-
* - **`params`** – {Object=} – Optional set of pre-bound parameters for this action. If any of
|
78
|
-
* parameter value is a function, it will be executed every time when a param value needs to
|
79
|
-
* obtained for a request (unless the param was overridden).
|
80
|
-
* - **`url`** – {string} – action specific `url` override. The url templating is supported just
|
81
|
-
* for the resource-level urls.
|
82
|
-
* - **`isArray`** – {boolean=} – If true then the returned object for this action is an array,
|
83
|
-
* `returns` section.
|
84
|
-
* - **`transformRequest`** –
|
75
|
+
* - **`action`** – {string} – The name of action. This name becomes the name of the method on
|
76
|
+
* your resource object.
|
77
|
+
* - **`method`** – {string} – HTTP request method. Valid methods are: `GET`, `POST`, `PUT`,
|
78
|
+
* `DELETE`, and `JSONP`.
|
79
|
+
* - **`params`** – {Object=} – Optional set of pre-bound parameters for this action. If any of
|
80
|
+
* the parameter value is a function, it will be executed every time when a param value needs to
|
81
|
+
* be obtained for a request (unless the param was overridden).
|
82
|
+
* - **`url`** – {string} – action specific `url` override. The url templating is supported just
|
83
|
+
* like for the resource-level urls.
|
84
|
+
* - **`isArray`** – {boolean=} – If true then the returned object for this action is an array,
|
85
|
+
* see `returns` section.
|
86
|
+
* - **`transformRequest`** –
|
87
|
+
* `{function(data, headersGetter)|Array.<function(data, headersGetter)>}` –
|
85
88
|
* transform function or an array of such functions. The transform function takes the http
|
86
89
|
* request body and headers and returns its transformed (typically serialized) version.
|
87
|
-
* - **`transformResponse`** –
|
90
|
+
* - **`transformResponse`** –
|
91
|
+
* `{function(data, headersGetter)|Array.<function(data, headersGetter)>}` –
|
88
92
|
* transform function or an array of such functions. The transform function takes the http
|
89
93
|
* response body and headers and returns its transformed (typically deserialized) version.
|
90
94
|
* - **`cache`** – `{boolean|Cache}` – If true, a default $http cache will be used to cache the
|
@@ -93,11 +97,14 @@
|
|
93
97
|
* caching.
|
94
98
|
* - **`timeout`** – `{number|Promise}` – timeout in milliseconds, or {@link ng.$q promise} that
|
95
99
|
* should abort the request when resolved.
|
96
|
-
* - **`withCredentials`** - `{boolean}` - whether to
|
100
|
+
* - **`withCredentials`** - `{boolean}` - whether to set the `withCredentials` flag on the
|
97
101
|
* XHR object. See {@link https://developer.mozilla.org/en/http_access_control#section_5
|
98
102
|
* requests with credentials} for more information.
|
99
103
|
* - **`responseType`** - `{string}` - see {@link
|
100
104
|
* https://developer.mozilla.org/en-US/docs/DOM/XMLHttpRequest#responseType requestType}.
|
105
|
+
* - **`interceptor`** - `{Object=}` - The interceptor object has two optional methods -
|
106
|
+
* `response` and `responseError`. Both `response` and `responseError` interceptors get called
|
107
|
+
* with `http response` object. See {@link ng.$http $http interceptors}.
|
101
108
|
*
|
102
109
|
* @returns {Object} A resource "class" object with methods for the default set of resource actions
|
103
110
|
* optionally extended with custom `actions`. The default set contains these actions:
|
@@ -136,24 +143,28 @@
|
|
136
143
|
* - non-GET "class" actions: `Resource.action([parameters], postData, [success], [error])`
|
137
144
|
* - non-GET instance actions: `instance.$action([parameters], [success], [error])`
|
138
145
|
*
|
146
|
+
* Success callback is called with (value, responseHeaders) arguments. Error callback is called
|
147
|
+
* with (httpResponse) argument.
|
139
148
|
*
|
140
|
-
*
|
149
|
+
* Class actions return empty instance (with additional properties below).
|
150
|
+
* Instance actions return promise of the action.
|
141
151
|
*
|
142
|
-
*
|
143
|
-
* {@link ng.$http $http} call.
|
152
|
+
* The Resource instances and collection have these additional properties:
|
144
153
|
*
|
145
|
-
*
|
146
|
-
*
|
154
|
+
* - `$promise`: the {@link ng.$q promise} of the original server interaction that created this
|
155
|
+
* instance or collection.
|
147
156
|
*
|
148
|
-
*
|
149
|
-
*
|
150
|
-
*
|
157
|
+
* On success, the promise is resolved with the same resource instance or collection object,
|
158
|
+
* updated with data from server. This makes it easy to use in
|
159
|
+
* {@link ngRoute.$routeProvider resolve section of $routeProvider.when()} to defer view
|
160
|
+
* rendering until the resource(s) are loaded.
|
151
161
|
*
|
152
|
-
*
|
153
|
-
*
|
162
|
+
* On failure, the promise is resolved with the {@link ng.$http http response} object, without
|
163
|
+
* the `resource` property.
|
154
164
|
*
|
155
|
-
* - `$resolved`: true
|
156
|
-
*
|
165
|
+
* - `$resolved`: `true` after first server interaction is completed (either with success or
|
166
|
+
* rejection), `false` before that. Knowing if the Resource has been resolved is useful in
|
167
|
+
* data-binding.
|
157
168
|
*
|
158
169
|
* @example
|
159
170
|
*
|
@@ -197,7 +208,8 @@
|
|
197
208
|
* The object returned from this function execution is a resource "class" which has "static" method
|
198
209
|
* for each action in the definition.
|
199
210
|
*
|
200
|
-
* Calling these methods invoke `$http` on the `url` template with the given `method`, `params` and
|
211
|
+
* Calling these methods invoke `$http` on the `url` template with the given `method`, `params` and
|
212
|
+
* `headers`.
|
201
213
|
* When the data is returned from the server then the object is an instance of the resource type and
|
202
214
|
* all of the non-GET methods are available with `$` prefix. This allows you to easily support CRUD
|
203
215
|
* operations (create, read, update, delete) on server-side data.
|
@@ -210,7 +222,7 @@
|
|
210
222
|
});
|
211
223
|
</pre>
|
212
224
|
*
|
213
|
-
* It's worth noting that the success callback for `get`, `query` and other
|
225
|
+
* It's worth noting that the success callback for `get`, `query` and other methods gets passed
|
214
226
|
* in the response that came from the server as well as $http header getter function, so one
|
215
227
|
* could rewrite the above example and get access to http headers as:
|
216
228
|
*
|
@@ -229,52 +241,56 @@
|
|
229
241
|
|
230
242
|
Let's look at what a buzz client created with the `$resource` service looks like:
|
231
243
|
<doc:example>
|
232
|
-
|
233
|
-
|
234
|
-
|
235
|
-
|
236
|
-
|
237
|
-
|
238
|
-
|
239
|
-
|
240
|
-
|
244
|
+
<doc:source jsfiddle="false">
|
245
|
+
<script>
|
246
|
+
function BuzzController($resource) {
|
247
|
+
this.userId = 'googlebuzz';
|
248
|
+
this.Activity = $resource(
|
249
|
+
'https://www.googleapis.com/buzz/v1/activities/:userId/:visibility/:activityId/:comments',
|
250
|
+
{alt:'json', callback:'JSON_CALLBACK'},
|
251
|
+
{
|
252
|
+
get:{method:'JSONP', params:{visibility:'@self'}},
|
253
|
+
replies: {method:'JSONP', params:{visibility:'@self', comments:'@comments'}}
|
241
254
|
}
|
242
|
-
|
243
|
-
|
244
|
-
|
245
|
-
|
246
|
-
|
247
|
-
|
248
|
-
|
249
|
-
|
250
|
-
};
|
251
|
-
|
252
|
-
|
253
|
-
|
254
|
-
|
255
|
-
|
256
|
-
|
257
|
-
|
258
|
-
|
259
|
-
|
260
|
-
|
261
|
-
|
262
|
-
|
263
|
-
|
264
|
-
|
265
|
-
|
266
|
-
|
267
|
-
|
268
|
-
|
269
|
-
|
255
|
+
);
|
256
|
+
}
|
257
|
+
|
258
|
+
BuzzController.prototype = {
|
259
|
+
fetch: function() {
|
260
|
+
this.activities = this.Activity.get({userId:this.userId});
|
261
|
+
},
|
262
|
+
expandReplies: function(activity) {
|
263
|
+
activity.replies = this.Activity.replies({userId:this.userId, activityId:activity.id});
|
264
|
+
}
|
265
|
+
};
|
266
|
+
BuzzController.$inject = ['$resource'];
|
267
|
+
</script>
|
268
|
+
|
269
|
+
<div ng-controller="BuzzController">
|
270
|
+
<input ng-model="userId"/>
|
271
|
+
<button ng-click="fetch()">fetch</button>
|
272
|
+
<hr/>
|
273
|
+
<div ng-repeat="item in activities.data.items">
|
274
|
+
<h1 style="font-size: 15px;">
|
275
|
+
<img src="{{item.actor.thumbnailUrl}}" style="max-height:30px;max-width:30px;"/>
|
276
|
+
<a href="{{item.actor.profileUrl}}">{{item.actor.name}}</a>
|
277
|
+
<a href ng-click="expandReplies(item)" style="float: right;">Expand replies:
|
278
|
+
{{item.links.replies[0].count}}</a>
|
279
|
+
</h1>
|
280
|
+
{{item.object.content | html}}
|
281
|
+
<div ng-repeat="reply in item.replies.data.items" style="margin-left: 20px;">
|
282
|
+
<img src="{{reply.actor.thumbnailUrl}}" style="max-height:30px;max-width:30px;"/>
|
283
|
+
<a href="{{reply.actor.profileUrl}}">{{reply.actor.name}}</a>: {{reply.content | html}}
|
270
284
|
</div>
|
271
|
-
|
272
|
-
|
273
|
-
|
285
|
+
</div>
|
286
|
+
</div>
|
287
|
+
</doc:source>
|
288
|
+
<doc:scenario>
|
289
|
+
</doc:scenario>
|
274
290
|
</doc:example>
|
275
291
|
*/
|
276
292
|
angular.module('ngResource', ['ng']).
|
277
|
-
factory('$resource', ['$http', '$parse', function($http, $parse) {
|
293
|
+
factory('$resource', ['$http', '$parse', '$q', function($http, $parse, $q) {
|
278
294
|
var DEFAULT_ACTIONS = {
|
279
295
|
'get': {method:'GET'},
|
280
296
|
'save': {method:'POST'},
|
@@ -311,9 +327,9 @@ angular.module('ngResource', ['ng']).
|
|
311
327
|
|
312
328
|
|
313
329
|
/**
|
314
|
-
* This method is intended for encoding *key* or *value* parts of query component. We need a
|
315
|
-
* method because encodeURIComponent is too aggressive and encodes stuff that doesn't
|
316
|
-
* encoded per http://tools.ietf.org/html/rfc3986:
|
330
|
+
* This method is intended for encoding *key* or *value* parts of query component. We need a
|
331
|
+
* custom method because encodeURIComponent is too aggressive and encodes stuff that doesn't
|
332
|
+
* have to be encoded per http://tools.ietf.org/html/rfc3986:
|
317
333
|
* query = *( pchar / "/" / "?" )
|
318
334
|
* pchar = unreserved / pct-encoded / sub-delims / ":" / "@"
|
319
335
|
* unreserved = ALPHA / DIGIT / "-" / "." / "_" / "~"
|
@@ -345,8 +361,12 @@ angular.module('ngResource', ['ng']).
|
|
345
361
|
|
346
362
|
var urlParams = self.urlParams = {};
|
347
363
|
forEach(url.split(/\W/), function(param){
|
348
|
-
if (param
|
349
|
-
|
364
|
+
if (param === 'hasOwnProperty') {
|
365
|
+
throw $resourceMinErr('badname', "hasOwnProperty is not a valid parameter name.");
|
366
|
+
}
|
367
|
+
if (!(new RegExp("^\\d+$").test(param)) && param &&
|
368
|
+
(new RegExp("(^|[^\\\\]):" + param + "(\\W|$)").test(url))) {
|
369
|
+
urlParams[param] = true;
|
350
370
|
}
|
351
371
|
});
|
352
372
|
url = url.replace(/\\:/g, ':');
|
@@ -376,7 +396,7 @@ angular.module('ngResource', ['ng']).
|
|
376
396
|
url = url.replace(/\/\.(?=\w+($|\?))/, '.');
|
377
397
|
// replace escaped `/\.` with `/.`
|
378
398
|
config.url = url.replace(/\/\\\./, '/.');
|
379
|
-
|
399
|
+
|
380
400
|
|
381
401
|
// set params - delegate param encoding to $http
|
382
402
|
forEach(params, function(value, key){
|
@@ -389,7 +409,7 @@ angular.module('ngResource', ['ng']).
|
|
389
409
|
};
|
390
410
|
|
391
411
|
|
392
|
-
function
|
412
|
+
function resourceFactory(url, paramDefaults, actions) {
|
393
413
|
var route = new Route(url);
|
394
414
|
|
395
415
|
actions = extend({}, DEFAULT_ACTIONS, actions);
|
@@ -399,25 +419,27 @@ angular.module('ngResource', ['ng']).
|
|
399
419
|
actionParams = extend({}, paramDefaults, actionParams);
|
400
420
|
forEach(actionParams, function(value, key){
|
401
421
|
if (isFunction(value)) { value = value(); }
|
402
|
-
ids[key] = value && value.charAt && value.charAt(0) == '@' ?
|
422
|
+
ids[key] = value && value.charAt && value.charAt(0) == '@' ?
|
423
|
+
getter(data, value.substr(1)) : value;
|
403
424
|
});
|
404
425
|
return ids;
|
405
426
|
}
|
406
427
|
|
428
|
+
function defaultResponseInterceptor(response) {
|
429
|
+
return response.resource;
|
430
|
+
}
|
431
|
+
|
407
432
|
function Resource(value){
|
408
433
|
copy(value || {}, this);
|
409
434
|
}
|
410
435
|
|
411
436
|
forEach(actions, function(action, name) {
|
412
|
-
|
413
|
-
|
437
|
+
var hasBody = /^(POST|PUT|PATCH)$/i.test(action.method);
|
438
|
+
|
414
439
|
Resource[name] = function(a1, a2, a3, a4) {
|
415
|
-
var params = {};
|
416
|
-
var data;
|
417
|
-
var success = noop;
|
418
|
-
var error = null;
|
419
|
-
var promise;
|
440
|
+
var params = {}, data, success, error;
|
420
441
|
|
442
|
+
/* jshint -W086 */ /* (purposefully fall through case statements) */
|
421
443
|
switch(arguments.length) {
|
422
444
|
case 4:
|
423
445
|
error = a4;
|
@@ -448,33 +470,44 @@ angular.module('ngResource', ['ng']).
|
|
448
470
|
break;
|
449
471
|
case 0: break;
|
450
472
|
default:
|
451
|
-
throw
|
452
|
-
arguments
|
473
|
+
throw $resourceMinErr('badargs',
|
474
|
+
"Expected up to 4 arguments [params, data, success, error], got {0} arguments",
|
475
|
+
arguments.length);
|
453
476
|
}
|
477
|
+
/* jshint +W086 */ /* (purposefully fall through case statements) */
|
454
478
|
|
455
|
-
var
|
456
|
-
var
|
457
|
-
|
479
|
+
var isInstanceCall = data instanceof Resource;
|
480
|
+
var value = isInstanceCall ? data : (action.isArray ? [] : new Resource(data));
|
481
|
+
var httpConfig = {};
|
482
|
+
var responseInterceptor = action.interceptor && action.interceptor.response ||
|
483
|
+
defaultResponseInterceptor;
|
484
|
+
var responseErrorInterceptor = action.interceptor && action.interceptor.responseError ||
|
485
|
+
undefined;
|
458
486
|
|
459
487
|
forEach(action, function(value, key) {
|
460
|
-
if (key != 'params' && key != 'isArray' ) {
|
488
|
+
if (key != 'params' && key != 'isArray' && key != 'interceptor') {
|
461
489
|
httpConfig[key] = copy(value);
|
462
490
|
}
|
463
491
|
});
|
464
|
-
httpConfig.data = data;
|
465
|
-
route.setUrlParams(httpConfig, extend({}, extractParams(data, action.params || {}), params), action.url);
|
466
492
|
|
467
|
-
|
493
|
+
if (hasBody) httpConfig.data = data;
|
494
|
+
route.setUrlParams(httpConfig,
|
495
|
+
extend({}, extractParams(data, action.params || {}), params),
|
496
|
+
action.url);
|
468
497
|
|
469
|
-
promise = $http(httpConfig)
|
470
|
-
|
471
|
-
|
472
|
-
promise.then(markResolved, markResolved);
|
473
|
-
value.$then = promise.then(function(response) {
|
474
|
-
var data = response.data;
|
475
|
-
var then = value.$then, resolved = value.$resolved;
|
498
|
+
var promise = $http(httpConfig).then(function(response) {
|
499
|
+
var data = response.data,
|
500
|
+
promise = value.$promise;
|
476
501
|
|
477
502
|
if (data) {
|
503
|
+
// Need to convert action.isArray to boolean in case it is undefined
|
504
|
+
// jshint -W018
|
505
|
+
if ( angular.isArray(data) !== (!!action.isArray) ) {
|
506
|
+
throw $resourceMinErr('badcfg', 'Error in resource configuration. Expected ' +
|
507
|
+
'response to contain an {0} but got an {1}',
|
508
|
+
action.isArray?'array':'object', angular.isArray(data)?'array':'object');
|
509
|
+
}
|
510
|
+
// jshint +W018
|
478
511
|
if (action.isArray) {
|
479
512
|
value.length = 0;
|
480
513
|
forEach(data, function(item) {
|
@@ -482,55 +515,63 @@ angular.module('ngResource', ['ng']).
|
|
482
515
|
});
|
483
516
|
} else {
|
484
517
|
copy(data, value);
|
485
|
-
value.$
|
486
|
-
value.$resolved = resolved;
|
518
|
+
value.$promise = promise;
|
487
519
|
}
|
488
520
|
}
|
489
521
|
|
490
|
-
|
522
|
+
value.$resolved = true;
|
491
523
|
|
492
524
|
response.resource = value;
|
525
|
+
|
493
526
|
return response;
|
494
|
-
},
|
527
|
+
}, function(response) {
|
528
|
+
value.$resolved = true;
|
495
529
|
|
496
|
-
|
497
|
-
};
|
530
|
+
(error||noop)(response);
|
498
531
|
|
532
|
+
return $q.reject(response);
|
533
|
+
});
|
499
534
|
|
500
|
-
|
501
|
-
|
502
|
-
|
503
|
-
|
535
|
+
promise = promise.then(
|
536
|
+
function(response) {
|
537
|
+
var value = responseInterceptor(response);
|
538
|
+
(success||noop)(value, response.headers);
|
539
|
+
return value;
|
540
|
+
},
|
541
|
+
responseErrorInterceptor);
|
542
|
+
|
543
|
+
if (!isInstanceCall) {
|
544
|
+
// we are creating instance / collection
|
545
|
+
// - set the initial promise
|
546
|
+
// - return the instance / collection
|
547
|
+
value.$promise = promise;
|
548
|
+
value.$resolved = false;
|
549
|
+
|
550
|
+
return value;
|
551
|
+
}
|
504
552
|
|
505
|
-
|
506
|
-
|
507
|
-
|
508
|
-
|
509
|
-
|
510
|
-
|
511
|
-
|
512
|
-
|
513
|
-
params = a1;
|
514
|
-
success = a2 || noop;
|
515
|
-
}
|
516
|
-
case 0: break;
|
517
|
-
default:
|
518
|
-
throw "Expected between 1-3 arguments [params, success, error], got " +
|
519
|
-
arguments.length + " arguments.";
|
553
|
+
// instance call
|
554
|
+
return promise;
|
555
|
+
};
|
556
|
+
|
557
|
+
|
558
|
+
Resource.prototype['$' + name] = function(params, success, error) {
|
559
|
+
if (isFunction(params)) {
|
560
|
+
error = success; success = params; params = {};
|
520
561
|
}
|
521
|
-
var
|
522
|
-
|
562
|
+
var result = Resource[name](params, this, success, error);
|
563
|
+
return result.$promise || result;
|
523
564
|
};
|
524
565
|
});
|
525
566
|
|
526
567
|
Resource.bind = function(additionalParamDefaults){
|
527
|
-
return
|
568
|
+
return resourceFactory(url, extend({}, paramDefaults, additionalParamDefaults), actions);
|
528
569
|
};
|
529
570
|
|
530
571
|
return Resource;
|
531
572
|
}
|
532
573
|
|
533
|
-
return
|
574
|
+
return resourceFactory;
|
534
575
|
}]);
|
535
576
|
|
536
577
|
|