2014-11-23 23:41:20 +00:00
|
|
|
/*global define,Promise*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Module defining BrowseController. Created by vwoeltje on 11/7/14.
|
|
|
|
*/
|
|
|
|
define(
|
|
|
|
[],
|
|
|
|
function () {
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
var ROOT_OBJECT = "ROOT";
|
|
|
|
|
|
|
|
/**
|
2014-11-24 02:03:48 +00:00
|
|
|
* The BrowseController is used to populate the initial scope in Browse
|
|
|
|
* mode. It loads the root object from the objectService and makes it
|
|
|
|
* available in the scope for Angular template's; this is the point at
|
|
|
|
* which Angular templates first have access to the domain object
|
|
|
|
* hierarchy.
|
2014-11-23 23:41:20 +00:00
|
|
|
*
|
|
|
|
* @constructor
|
|
|
|
*/
|
|
|
|
function BrowseController($scope, objectService, navigationService) {
|
2014-11-24 02:03:48 +00:00
|
|
|
// Callback for updating the in-scope reference to the object
|
|
|
|
// that is currently navigated-to.
|
2014-11-23 23:41:20 +00:00
|
|
|
function setNavigation(domainObject) {
|
|
|
|
$scope.navigatedObject = domainObject;
|
|
|
|
}
|
|
|
|
|
2014-11-24 02:03:48 +00:00
|
|
|
// Load the root object, put it in the scope.
|
|
|
|
// Also, load its immediate children, and (possibly)
|
|
|
|
// navigate to one of them, so that navigation state has
|
|
|
|
// a useful initial value.
|
2014-11-23 23:41:20 +00:00
|
|
|
objectService.getObjects([ROOT_OBJECT]).then(function (objects) {
|
|
|
|
var composition = objects[ROOT_OBJECT].useCapability("composition");
|
|
|
|
$scope.domainObject = objects[ROOT_OBJECT];
|
|
|
|
if (composition) {
|
|
|
|
composition.then(function (c) {
|
2014-11-24 02:03:48 +00:00
|
|
|
// Check if an object has been navigated-to already...
|
2014-11-23 23:41:20 +00:00
|
|
|
if (!navigationService.getNavigation()) {
|
2014-11-24 02:03:48 +00:00
|
|
|
// If not, pick a default as the last
|
|
|
|
// root-level component (usually "mine")
|
2014-11-23 23:41:20 +00:00
|
|
|
navigationService.setNavigation(c[c.length - 1]);
|
|
|
|
} else {
|
2014-11-24 02:03:48 +00:00
|
|
|
// Otherwise, just expose it in the scope
|
2014-11-23 23:41:20 +00:00
|
|
|
$scope.navigatedObject = navigationService.getNavigation();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2014-11-24 02:03:48 +00:00
|
|
|
// Listen for changes in navigation state.
|
|
|
|
navigationService.addListener(setNavigation);
|
|
|
|
|
|
|
|
// Clean up when the scope is destroyed
|
2014-11-23 23:41:20 +00:00
|
|
|
$scope.$on("$destroy", function () {
|
|
|
|
navigationService.removeListener(setNavigation);
|
|
|
|
});
|
|
|
|
|
|
|
|
return {
|
2014-11-24 02:03:48 +00:00
|
|
|
/**
|
|
|
|
* Navigate to a specific domain object.
|
|
|
|
*
|
|
|
|
* This is exposed so that the browse tree has a callback
|
|
|
|
* to invoke when the user clicks on a new object to navigate
|
|
|
|
* to it.
|
|
|
|
*
|
|
|
|
* @method
|
|
|
|
* @memberof BrowseController
|
|
|
|
* @param {DomainObject} domainObject the object to navigate to
|
|
|
|
*/
|
2014-11-23 23:41:20 +00:00
|
|
|
setNavigation: function (domainObject) {
|
|
|
|
navigationService.setNavigation(domainObject);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
return BrowseController;
|
|
|
|
}
|
|
|
|
);
|