mirror of
https://github.com/nasa/openmct.git
synced 2025-06-13 12:48:14 +00:00
Merge remote-tracking branch 'origin/open1031'
This commit is contained in:
@ -23,6 +23,7 @@
|
|||||||
define([
|
define([
|
||||||
"./src/BrowseController",
|
"./src/BrowseController",
|
||||||
"./src/PaneController",
|
"./src/PaneController",
|
||||||
|
"./src/InspectorPaneController",
|
||||||
"./src/BrowseObjectController",
|
"./src/BrowseObjectController",
|
||||||
"./src/MenuArrowController",
|
"./src/MenuArrowController",
|
||||||
"./src/navigation/NavigationService",
|
"./src/navigation/NavigationService",
|
||||||
@ -44,6 +45,7 @@ define([
|
|||||||
], function (
|
], function (
|
||||||
BrowseController,
|
BrowseController,
|
||||||
PaneController,
|
PaneController,
|
||||||
|
InspectorPaneController,
|
||||||
BrowseObjectController,
|
BrowseObjectController,
|
||||||
MenuArrowController,
|
MenuArrowController,
|
||||||
NavigationService,
|
NavigationService,
|
||||||
@ -124,6 +126,17 @@ define([
|
|||||||
"depends": [
|
"depends": [
|
||||||
"$scope"
|
"$scope"
|
||||||
]
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"key": "InspectorPaneController",
|
||||||
|
"implementation": InspectorPaneController,
|
||||||
|
"priority": "preferred",
|
||||||
|
"depends": [
|
||||||
|
"$scope",
|
||||||
|
"agentService",
|
||||||
|
"$window",
|
||||||
|
"navigationService"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"representations": [
|
"representations": [
|
||||||
|
@ -57,7 +57,7 @@
|
|||||||
ng-class="{ collapsed : !modelPaneTree.visible() }"></a>
|
ng-class="{ collapsed : !modelPaneTree.visible() }"></a>
|
||||||
|
|
||||||
<div class='holder holder-object-and-inspector abs' id='content-area'
|
<div class='holder holder-object-and-inspector abs' id='content-area'
|
||||||
ng-controller="PaneController as modelPaneInspect"
|
ng-controller="InspectorPaneController as modelPaneInspect"
|
||||||
ng-class="modelPaneInspect.visible() ? 'pane-inspect-showing' : 'pane-inspect-hidden'">
|
ng-class="modelPaneInspect.visible() ? 'pane-inspect-showing' : 'pane-inspect-hidden'">
|
||||||
|
|
||||||
<mct-split-pane class='l-object-and-inspector contents abs' anchor='right'>
|
<mct-split-pane class='l-object-and-inspector contents abs' anchor='right'>
|
||||||
|
79
platform/commonUI/browse/src/InspectorPaneController.js
Normal file
79
platform/commonUI/browse/src/InspectorPaneController.js
Normal file
@ -0,0 +1,79 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* Open MCT Web, Copyright (c) 2014-2015, United States Government
|
||||||
|
* as represented by the Administrator of the National Aeronautics and Space
|
||||||
|
* Administration. All rights reserved.
|
||||||
|
*
|
||||||
|
* Open MCT Web is licensed under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0.
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
* License for the specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*
|
||||||
|
* Open MCT Web includes source code licensed under additional open source
|
||||||
|
* licenses. See the Open Source Licenses file (LICENSES.md) included with
|
||||||
|
* this source code distribution or the Licensing information page available
|
||||||
|
* at runtime from the About dialog for additional information.
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
define(
|
||||||
|
["./PaneController"],
|
||||||
|
function (PaneController) {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Pane controller that reveals inspector, if hidden, when object
|
||||||
|
* switches to edit mode.
|
||||||
|
*
|
||||||
|
* @param $scope
|
||||||
|
* @param agentService
|
||||||
|
* @param $window
|
||||||
|
* @param navigationService
|
||||||
|
* @constructor
|
||||||
|
*/
|
||||||
|
function InspectorPaneController($scope, agentService, $window, navigationService) {
|
||||||
|
PaneController.call(this, $scope, agentService, $window);
|
||||||
|
|
||||||
|
var statusListener,
|
||||||
|
self = this;
|
||||||
|
|
||||||
|
function showInspector(statuses) {
|
||||||
|
if (statuses.indexOf('editing') !== -1 && !self.visible()) {
|
||||||
|
self.toggle();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function attachStatusListener(domainObject) {
|
||||||
|
// Remove existing status listener if existing
|
||||||
|
if (statusListener) {
|
||||||
|
statusListener();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (domainObject.hasCapability("status")) {
|
||||||
|
statusListener = domainObject.getCapability("status").listen(showInspector);
|
||||||
|
}
|
||||||
|
return statusListener;
|
||||||
|
}
|
||||||
|
|
||||||
|
var domainObject = navigationService.getNavigation();
|
||||||
|
if (domainObject) {
|
||||||
|
attachStatusListener(domainObject);
|
||||||
|
}
|
||||||
|
|
||||||
|
var navigationListener = navigationService.addListener(attachStatusListener);
|
||||||
|
|
||||||
|
$scope.$on("$destroy", function () {
|
||||||
|
statusListener();
|
||||||
|
navigationListener();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
InspectorPaneController.prototype = Object.create(PaneController.prototype);
|
||||||
|
|
||||||
|
return InspectorPaneController;
|
||||||
|
}
|
||||||
|
);
|
96
platform/commonUI/browse/test/InspectorPaneControllerSpec.js
Normal file
96
platform/commonUI/browse/test/InspectorPaneControllerSpec.js
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
/*****************************************************************************
|
||||||
|
* Open MCT Web, Copyright (c) 2014-2015, United States Government
|
||||||
|
* as represented by the Administrator of the National Aeronautics and Space
|
||||||
|
* Administration. All rights reserved.
|
||||||
|
*
|
||||||
|
* Open MCT Web is licensed under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0.
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
* License for the specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*
|
||||||
|
* Open MCT Web includes source code licensed under additional open source
|
||||||
|
* licenses. See the Open Source Licenses file (LICENSES.md) included with
|
||||||
|
* this source code distribution or the Licensing information page available
|
||||||
|
* at runtime from the About dialog for additional information.
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
define(
|
||||||
|
["../src/InspectorPaneController"],
|
||||||
|
function (InspectorPaneController) {
|
||||||
|
|
||||||
|
describe("The InspectorPaneController", function () {
|
||||||
|
var mockScope,
|
||||||
|
mockAgentService,
|
||||||
|
mockDomainObject,
|
||||||
|
mockWindow,
|
||||||
|
mockStatusCapability,
|
||||||
|
mockNavigationService,
|
||||||
|
mockNavigationUnlistener,
|
||||||
|
mockStatusUnlistener,
|
||||||
|
controller;
|
||||||
|
|
||||||
|
beforeEach(function () {
|
||||||
|
mockScope = jasmine.createSpyObj("$scope", ["$on"]);
|
||||||
|
mockWindow = jasmine.createSpyObj("$window", ["open"]);
|
||||||
|
mockAgentService = jasmine.createSpyObj(
|
||||||
|
"agentService",
|
||||||
|
["isMobile", "isPhone", "isTablet", "isPortrait", "isLandscape"]
|
||||||
|
);
|
||||||
|
|
||||||
|
mockNavigationUnlistener = jasmine.createSpy("navigationUnlistener");
|
||||||
|
mockNavigationService = jasmine.createSpyObj(
|
||||||
|
"navigationService",
|
||||||
|
["getNavigation", "addListener"]
|
||||||
|
);
|
||||||
|
mockNavigationService.addListener.andReturn(mockNavigationUnlistener);
|
||||||
|
|
||||||
|
mockStatusUnlistener = jasmine.createSpy("statusUnlistener");
|
||||||
|
mockStatusCapability = jasmine.createSpyObj(
|
||||||
|
"statusCapability",
|
||||||
|
["listen"]
|
||||||
|
);
|
||||||
|
mockStatusCapability.listen.andReturn(mockStatusUnlistener);
|
||||||
|
|
||||||
|
mockDomainObject = jasmine.createSpyObj(
|
||||||
|
'domainObject',
|
||||||
|
[
|
||||||
|
'getId',
|
||||||
|
'getModel',
|
||||||
|
'getCapability',
|
||||||
|
'hasCapability'
|
||||||
|
]
|
||||||
|
);
|
||||||
|
mockDomainObject.getId.andReturn("domainObject");
|
||||||
|
mockDomainObject.getModel.andReturn({});
|
||||||
|
mockDomainObject.hasCapability.andReturn(true);
|
||||||
|
mockDomainObject.getCapability.andReturn(mockStatusCapability);
|
||||||
|
|
||||||
|
controller = new InspectorPaneController(mockScope, mockAgentService, mockWindow, mockNavigationService);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("listens for changes to navigation and attaches a status" +
|
||||||
|
" listener", function () {
|
||||||
|
expect(mockNavigationService.addListener).toHaveBeenCalledWith(jasmine.any(Function));
|
||||||
|
mockNavigationService.addListener.mostRecentCall.args[0](mockDomainObject);
|
||||||
|
expect(mockStatusCapability.listen).toHaveBeenCalledWith(jasmine.any(Function));
|
||||||
|
});
|
||||||
|
|
||||||
|
it("if hidden, shows the inspector when domain object switches to" +
|
||||||
|
" edit mode", function () {
|
||||||
|
controller.toggle();
|
||||||
|
// test pre-condition that inspector is hidden
|
||||||
|
expect(controller.visible()).toBe(false);
|
||||||
|
mockNavigationService.addListener.mostRecentCall.args[0](mockDomainObject);
|
||||||
|
mockStatusCapability.listen.mostRecentCall.args[0](["editing"]);
|
||||||
|
expect(controller.visible()).toBe(true);
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
Reference in New Issue
Block a user