angular-state-view
Version:
Provides nested view management with template support.
330 lines (265 loc) • 23.7 kB
JavaScript
(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){
;
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){
;
/* 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){
;
/* 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){
;
/**
* 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"]}