| (function (angular) { | 
|     'use strict'; | 
|   | 
|     angular.module('oc.lazyLoad').config(["$provide", function ($provide) { | 
|         $provide.decorator('$ocLazyLoad', ["$delegate", "$q", function ($delegate, $q) { | 
|             /** | 
|              * cssLoader function | 
|              * @type Function | 
|              * @param paths array list of css files to load | 
|              * @param callback to call when everything is loaded. We use a callback and not a promise | 
|              * @param params object config parameters | 
|              * because the user can overwrite cssLoader and it will probably not use promises :( | 
|              */ | 
|             $delegate.cssLoader = function (paths, callback, params) { | 
|                 var promises = []; | 
|                 angular.forEach(paths, function (path) { | 
|                     promises.push($delegate.buildElement('css', path, params)); | 
|                 }); | 
|                 $q.all(promises).then(function () { | 
|                     callback(); | 
|                 }, function (err) { | 
|                     callback(err); | 
|                 }); | 
|             }; | 
|             $delegate.cssLoader.ocLazyLoadLoader = true; | 
|   | 
|             return $delegate; | 
|         }]); | 
|     }]); | 
| })(angular); |