UNPKG

angular-state-view

Version:

Provides nested view management with template support.

330 lines (265 loc) 23.7 kB
(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){ 'use strict'; module.exports = ['$state', '$viewManager', '$templateCache', '$compile', '$controller', '$q', function ($state, $viewManager, $templateCache, $compile, $controller, $q) { return { restrict: 'EA', priority: 400, scope: { }, link: function(scope, $element, attrs) { // Create view var _view = $viewManager.create(attrs.id, { // Element $element: $element, /** * Render view * * @param {String} template A template to use * @param {Mixed} controller A controller to attach applied to scope.$parent * @param {Object} locals A data Object to instantiate controller with * @return {Promise} A promise resolved when rendering is complete */ render: function(template, controller, locals) { var deferred = $q.defer(); $element.html(template); // Compile var link = $compile($element.contents()); // Controller if(controller) { var _locals = angular.extend({}, locals || {}, { $scope: scope.$parent }); $controller(controller, _locals); } // Link link(scope.$parent); deferred.resolve(); return deferred.promise; }, /** * Reset view * * @return {Promise} A promise resolved when rendering is complete */ reset: function() { var deferred = $q.defer(); // Empty $element.empty(); deferred.resolve(); return deferred.promise; } }); // Destroy $element.on('$destroy', function() { _view.destroy(); }); } }; }]; },{}],2:[function(require,module,exports){ 'use strict'; /* global angular:false */ // CommonJS if (typeof module !== "undefined" && typeof exports !== "undefined" && module.exports === exports){ module.exports = 'angular-state-view'; } // Assume polyfill used in StateRouter exists // Instantiate module angular.module('angular-state-view', ['angular-state-router']) .factory('$viewManager', require('./services/view-manager')) .directive('sview', require('./directives/state-view')); },{"./directives/state-view":1,"./services/view-manager":3}],3:[function(require,module,exports){ 'use strict'; /* global window:false */ var View = require('../view/view'); module.exports = ['$rootScope', '$state', '$injector', '$q', function($rootScope, $state, $injector, $q) { // Instance var _self = {}; var _viewHash = {}; var _activeSet = {}; /** * Reset active views * * @return {Promise} A promise fulfilled when currently active views are reset */ var _resetActive = function() { // Reset views var resetPromised = {}; angular.forEach(_activeSet, function(view, id) { resetPromised[id] = $q.when(view.reset()); }); // Empty active set _activeSet = {}; return $q.all(resetPromised); }; /** * Get templates * * @param {Mixed} data Template data, String src to include or Function invocation * @return {Promise} A promise fulfilled when templates retireved */ var _getTemplate = function(data) { var template = angular.isString(data) ? '<ng-include src="\''+data+'\'"></ng-include>' : $injector.invoke(data); return $q.when(template); }; /** * Render a view * * @param {String} id Unique identifier for view * @param {View} view A view instance * @param {Mixed} data Template data, String src to include or Function invocation * @return {Promise} A promise fulfilled when currently active view is rendered */ var _renderView = function(id, view, data, controller) { return _getTemplate(data).then(function(template) { // Controller if(controller) { var current = $state.current(); return view.render(template, controller, current.locals); // Template only } else { return view.render(template); } }); }; /** * Update rendered views * * @param {Function} callback A completion callback, function(err) */ var _update = function(callback) { // Activate current var current = $state.current(); if(current) { // Reset _resetActive().then(function() { // Render var viewsPromised = {}; var templates = current.templates || {}; var controllers = current.controllers || {}; angular.forEach(templates, function(template, id) { if(_viewHash[id]) { var view = _viewHash[id]; var controller = controllers[id]; viewsPromised[id] = _renderView(id, view, template, controller); _activeSet[id] = view; } }); $q.all(viewsPromised).then(function() { callback(); }, callback); }, callback); // None } else { callback(); } }; _self.$update = _update; /** * Unregister a view * * @param {String} id Unique identifier for view * @return {$viewManager} Itself, chainable */ var _unregister = function(id) { delete _viewHash[id]; }; /** * Register a view, also implements destroy method on view to unregister from manager * * @param {String} id Unique identifier for view * @param {View} view A view instance * @return {$viewManager} Itself, chainable */ var _register = function(id, view) { // No id if(!id) { throw new Error('View requires an id.'); // Require unique id } else if(_viewHash[id]) { throw new Error('View requires a unique id'); // Add } else { _viewHash[id] = view; } // Check if view is currently active var current = $state.current() || {}; var templates = current.templates || {}; var controllers = current.controllers || {}; if(!!templates[id]) { _renderView(id, view, templates[id], controllers[id]); } // Implement destroy method view.destroy = function() { _unregister(id); }; return view; }; /** * A factory method to create a View instance * * @param {String} id Unique identifier for view * @param {Object} data A data object used to extend abstract methods * @return {View} A View entitity */ _self.create = function(id, data) { data = data || {}; // Create var view = View(id, data); // Register return _register(id, view); }; /** * Get a view by id * * @param {String} id Unique identifier for view * @return {View} A View entitity */ _self.get = function(id) { return _viewHash[id]; }; // Register middleware layer $state.$use(function(request, next) { _update(function(err) { if(err) { $rootScope.$broadcast('$viewError', err); } else { $rootScope.$broadcast('$viewRender'); } next(err); }); }, -1); return _self; }]; },{"../view/view":4}],4:[function(require,module,exports){ 'use strict'; /** * View * * @param {String} id Unique identifier for view * @param {Object} child A data object used to extend abstract methods * @return {View} An abstract view object */ module.exports = function View(id, child) { // Instance var _self; _self = { /** * Abstract render method */ render: function(template) { }, /** * Abstract reset method */ reset: function() { }, /** * Abstract destroy method */ destroy: function() { } }; // Extend to overwrite abstract methods angular.extend(_self, child); return _self; }; },{}]},{},[2]) //# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","/Users/henry/HomeSync/Canvas/projects/angular-state-view/src/directives/state-view.js","/Users/henry/HomeSync/Canvas/projects/angular-state-view/src/index.js","/Users/henry/HomeSync/Canvas/projects/angular-state-view/src/services/view-manager.js","/Users/henry/HomeSync/Canvas/projects/angular-state-view/src/view/view.js"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","'use strict';\n\nmodule.exports = ['$state', '$viewManager', '$templateCache', '$compile', '$controller', '$q', function ($state, $viewManager, $templateCache, $compile, $controller, $q) {\n  return {\n    restrict: 'EA',\n    priority: 400,\n    scope: {\n\n    },\n    link: function(scope, $element, attrs) {\n      // Create view\n      var _view = $viewManager.create(attrs.id, {\n\n        // Element\n        $element: $element,\n\n        /**\n         * Render view\n         * \n         * @param  {String}  template   A template to use\n         * @param  {Mixed}   controller A controller to attach applied to scope.$parent\n         * @param  {Object}  locals     A data Object to instantiate controller with\n         * @return {Promise}            A promise resolved when rendering is complete\n         */\n        render: function(template, controller, locals) {\n          var deferred = $q.defer();\n\n          $element.html(template);\n\n          // Compile\n          var link = $compile($element.contents());\n\n          // Controller\n          if(controller) {\n            var _locals = angular.extend({}, locals || {}, {\n              $scope: scope.$parent\n            });\n            $controller(controller, _locals);\n          }\n\n          // Link\n          link(scope.$parent);\n\n          deferred.resolve();\n          return deferred.promise;\n        },\n\n        /**\n         * Reset view\n         * \n         * @return {Promise} A promise resolved when rendering is complete\n         */\n        reset: function() {\n          var deferred = $q.defer();\n\n          // Empty\n          $element.empty();\n\n          deferred.resolve();\n          return deferred.promise;\n        }\n      });\n\n      // Destroy\n      $element.on('$destroy', function() {\n        _view.destroy();\n      });\n    }\n  };\n}];\n","'use strict';\n\n/* global angular:false */\n\n// CommonJS\nif (typeof module !== \"undefined\" && typeof exports !== \"undefined\" && module.exports === exports){\n  module.exports = 'angular-state-view';\n}\n\n// Assume polyfill used in StateRouter exists\n\n// Instantiate module\nangular.module('angular-state-view', ['angular-state-router'])\n\n  .factory('$viewManager', require('./services/view-manager'))\n\n  .directive('sview', require('./directives/state-view'));\n","'use strict';\n\n/* global window:false */\n\nvar View = require('../view/view');\n\nmodule.exports = ['$rootScope', '$state', '$injector', '$q', function($rootScope, $state, $injector, $q) {\n\n  // Instance\n  var _self = {};\n\n  var _viewHash = {};\n  var _activeSet = {};\n\n  /**\n   * Reset active views\n   * \n   * @return {Promise} A promise fulfilled when currently active views are reset\n   */\n  var _resetActive = function() {\n    // Reset views\n    var resetPromised = {};\n    angular.forEach(_activeSet, function(view, id) {\n      resetPromised[id] = $q.when(view.reset());\n    });\n\n    // Empty active set\n    _activeSet = {};\n\n    return $q.all(resetPromised);\n  };\n\n  /**\n   * Get templates\n   * \n   * @param  {Mixed}   data Template data, String src to include or Function invocation\n   * @return {Promise}      A promise fulfilled when templates retireved\n   */\n  var _getTemplate = function(data) {\n    var template = angular.isString(data) ? '<ng-include src=\"\\''+data+'\\'\"></ng-include>' : $injector.invoke(data);\n    return $q.when(template);\n  };\n\n  /**\n   * Render a view\n   * \n   * @param  {String}  id     Unique identifier for view\n   * @param  {View}    view   A view instance\n   * @param  {Mixed}   data   Template data, String src to include or Function invocation\n   * @return {Promise}        A promise fulfilled when currently active view is rendered\n   */\n  var _renderView = function(id, view, data, controller) {\n    return _getTemplate(data).then(function(template) {\n\n      // Controller\n      if(controller) {\n        var current = $state.current();\n        return view.render(template, controller, current.locals);\n\n      // Template only\n      } else {\n        return view.render(template);\n      }\n    });\n  };\n\n  /**\n   * Update rendered views\n   *\n   * @param {Function} callback A completion callback, function(err)\n   */\n  var _update = function(callback) {\n    // Activate current\n    var current = $state.current();\n\n    if(current) {\n\n      // Reset\n      _resetActive().then(function() {\n\n        // Render\n        var viewsPromised = {};\n        var templates = current.templates || {};\n        var controllers = current.controllers || {};\n        angular.forEach(templates, function(template, id) {\n          if(_viewHash[id]) {\n            var view = _viewHash[id];\n            var controller = controllers[id];\n            viewsPromised[id] = _renderView(id, view, template, controller);\n            _activeSet[id] = view;\n          }\n        });\n\n        $q.all(viewsPromised).then(function() {\n          callback();\n        }, callback);\n\n      }, callback);\n\n    // None\n    } else {\n      callback();\n    }\n  };\n  _self.$update = _update;\n\n  /**\n   * Unregister a view\n   * \n   * @param  {String}       id Unique identifier for view\n   * @return {$viewManager}    Itself, chainable\n   */\n  var _unregister = function(id) {\n    delete _viewHash[id];\n  };\n\n  /**\n   * Register a view, also implements destroy method on view to unregister from manager\n   * \n   * @param  {String}       id   Unique identifier for view\n   * @param  {View}         view A view instance\n   * @return {$viewManager}      Itself, chainable\n   */\n  var _register = function(id, view) {\n    // No id\n    if(!id) {\n      throw new Error('View requires an id.');\n\n    // Require unique id\n    } else if(_viewHash[id]) {\n      throw new Error('View requires a unique id');\n\n    // Add\n    } else {\n      _viewHash[id] = view;\n    }\n\n    // Check if view is currently active\n    var current = $state.current() || {};\n    var templates = current.templates || {};\n    var controllers = current.controllers || {};\n    if(!!templates[id]) {\n      _renderView(id, view, templates[id], controllers[id]);\n    }\n\n    // Implement destroy method\n    view.destroy = function() {\n      _unregister(id);\n    };\n\n    return view;\n  };\n\n  /**\n   * A factory method to create a View instance\n   * \n   * @param  {String} id   Unique identifier for view\n   * @param  {Object} data A data object used to extend abstract methods\n   * @return {View}        A View entitity\n   */\n  _self.create = function(id, data) {\n    data = data || {};\n\n    // Create\n    var view = View(id, data);\n\n    // Register\n    return _register(id, view);\n  };\n\n  /**\n   * Get a view by id\n   * \n   * @param  {String} id Unique identifier for view\n   * @return {View}      A View entitity\n   */\n  _self.get = function(id) {\n    return _viewHash[id];\n  };\n\n  // Register middleware layer\n  $state.$use(function(request, next) {\n    _update(function(err) {\n      if(err) {\n        $rootScope.$broadcast('$viewError', err);\n      } else {\n        $rootScope.$broadcast('$viewRender');\n      }\n\n      next(err);\n    });\n  }, -1);\n\n  return _self;\n}];\n","'use strict';\n\n/**\n * View\n *\n * @param  {String} id      Unique identifier for view\n * @param  {Object} child   A data object used to extend abstract methods\n * @return {View}           An abstract view object\n */\nmodule.exports = function View(id, child) {\n\n  // Instance\n  var _self;\n  _self = {\n\n    /**\n     * Abstract render method\n     */\n    render: function(template) { },\n\n    /**\n     * Abstract reset method\n     */\n    reset: function() { },\n\n    /**\n     * Abstract destroy method\n     */\n    destroy: function() { }\n\n  };\n\n  // Extend to overwrite abstract methods\n  angular.extend(_self, child);\n\n  return _self;\n};\n"]}