 425655bae0
			
		
	
	425655bae0
	
	
	
		
			
			Updates to sub object selection, first cut of selection APIs. * [API] Add inspector view registry to register inspector view providers and show a view in the inspector. [API] Modify the selection API to register the click event and handle the event. The API will add a class to the selected object and the immediate parent of the selected object. [Directive] Implemenet mct-selectable directive for making an element selectable. [Layout] Update the layout controller to use the Selection API. Also, add double click gesture to allow drilling into a selected object. Populate the Elements pool with contained elements of the selected object. Update toolbar and inspector to listen for the changes in selection. * [Frontend] Mods to markup and CSS for sub-object selection * MCTSelectable allows selection in initialization, use to select on navigation [Frontend] Show grid in first nested layout, hide from deeper nesting. Only show grids when applicable to relative selection. * Fix checkstyle and lint errors * Bring back the change that made mct-init-select work * [Inspector] Make sure the right content is displayed based on whether a view provider exists or not. * Only show table options when editing * Make reviewers' requested changes * Fix broken tests * [Frontend] Cleanups and tweaks Fixes #1811 - Cleanups between frame, editor and selecting.scss; - Hover and selected borders visually pumped up a bit; - Solid borders on hover and selecting when browsing; - Dashed borders for layouts when editing; - Fixed cursor to only show move capability when element is selected; * [Frontend] Tweaks to frame.no-frame layout Fixes #1811 - Margin set to 0; - Overflow set to hidden; * [Frontend] Fixed position items border width fixed Fixes #1811 - Set to 1px; * Add tests for inspector controller and fix broken tests. Clean up code. * [Fixed Position] Stop event propagation on click handlers in fixed position to avoid the event reaching the selection click handlers which caused issues with toolbar and selection." * Fix tests * Add tests * Add test * Remove element from document
		
			
				
	
	
		
			121 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			121 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /*****************************************************************************
 | |
|  * Open MCT, Copyright (c) 2014-2017, United States Government
 | |
|  * as represented by the Administrator of the National Aeronautics and Space
 | |
|  * Administration. All rights reserved.
 | |
|  *
 | |
|  * Open MCT 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 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/InspectorController'],
 | |
|     function (InspectorController) {
 | |
| 
 | |
|         describe("The inspector controller ", function () {
 | |
|             var mockScope,
 | |
|                 mockDomainObject,
 | |
|                 mockOpenMCT,
 | |
|                 mockSelection,
 | |
|                 mockInspectorViews,
 | |
|                 mockTypeDef,
 | |
|                 controller,
 | |
|                 container,
 | |
|                 $document = [],
 | |
|                 selectable = [];
 | |
| 
 | |
|             beforeEach(function () {
 | |
|                 mockTypeDef = {
 | |
|                     typeDef: {
 | |
|                         inspector: "some-key"
 | |
|                     }
 | |
|                 };
 | |
| 
 | |
|                 mockDomainObject = jasmine.createSpyObj('domainObject', [
 | |
|                     'getCapability'
 | |
|                 ]);
 | |
|                 mockDomainObject.getCapability.andReturn(mockTypeDef);
 | |
| 
 | |
|                 mockScope = jasmine.createSpyObj('$scope',
 | |
|                     ['$on', 'selection']
 | |
|                 );
 | |
| 
 | |
|                 selectable[0] = {
 | |
|                     context: {
 | |
|                         oldItem: mockDomainObject
 | |
|                     }
 | |
|                 };
 | |
| 
 | |
|                 mockSelection = jasmine.createSpyObj("selection", [
 | |
|                     'on',
 | |
|                     'off',
 | |
|                     'get'
 | |
|                 ]);
 | |
|                 mockSelection.get.andReturn(selectable);
 | |
| 
 | |
|                 mockInspectorViews = jasmine.createSpyObj('inspectorViews', ['get']);
 | |
|                 mockOpenMCT = {
 | |
|                     selection: mockSelection,
 | |
|                     inspectorViews: mockInspectorViews
 | |
|                 };
 | |
| 
 | |
|                 container = jasmine.createSpy('container', ['innerHTML']);
 | |
|                 $document[0] = jasmine.createSpyObj("$document", ['querySelectorAll']);
 | |
|                 $document[0].querySelectorAll.andReturn([container]);
 | |
| 
 | |
|                 controller = new InspectorController(mockScope, mockOpenMCT, $document);
 | |
|             });
 | |
| 
 | |
|             it("listens for selection change event", function () {
 | |
|                 expect(mockOpenMCT.selection.on).toHaveBeenCalledWith(
 | |
|                     'change',
 | |
|                     jasmine.any(Function)
 | |
|                 );
 | |
| 
 | |
|                 expect(controller.selectedItem()).toEqual(mockDomainObject);
 | |
| 
 | |
|                 var mockItem = jasmine.createSpyObj('domainObject', [
 | |
|                     'getCapability'
 | |
|                 ]);
 | |
|                 mockItem.getCapability.andReturn(mockTypeDef);
 | |
|                 selectable[0].context.oldItem = mockItem;
 | |
| 
 | |
|                 mockOpenMCT.selection.on.mostRecentCall.args[1](selectable);
 | |
| 
 | |
|                 expect(controller.selectedItem()).toEqual(mockItem);
 | |
|             });
 | |
| 
 | |
|             it("cleans up on scope destroy", function () {
 | |
|                 expect(mockScope.$on).toHaveBeenCalledWith(
 | |
|                     '$destroy',
 | |
|                     jasmine.any(Function)
 | |
|                 );
 | |
| 
 | |
|                 mockScope.$on.calls[0].args[1]();
 | |
| 
 | |
|                 expect(mockOpenMCT.selection.off).toHaveBeenCalledWith(
 | |
|                     'change',
 | |
|                     jasmine.any(Function)
 | |
|                 );
 | |
|             });
 | |
| 
 | |
|             it("adds selection object to scope", function () {
 | |
|                 expect(mockScope.selection).toEqual(selectable);
 | |
|                 expect(controller.selectedItem()).toEqual(mockDomainObject);
 | |
|             });
 | |
|         });
 | |
|     }
 | |
| );
 |