mirror of
https://github.com/nasa/openmct.git
synced 2025-05-02 08:43:17 +00:00
Conflicts: main.js platform/commonUI/edit/src/policies/EditableMovePolicy.js platform/commonUI/general/src/directives/MCTTree.js platform/commonUI/general/src/ui/ToggleView.js platform/core/src/actions/ActionCapability.js platform/core/test/models/CachingModelDecoratorSpec.js platform/core/test/services/InstantiateSpec.js platform/features/events/bundle.js platform/features/events/src/DomainColumn.js platform/features/events/src/EventListController.js platform/features/events/src/EventListPopulator.js platform/features/events/src/RangeColumn.js platform/features/events/src/directives/MCTDataTable.js platform/features/events/src/policies/MessagesViewPolicy.js platform/features/events/test/DomainColumnSpec.js platform/features/events/test/EventListControllerSpec.js platform/features/events/test/EventListPopulatorSpec.js platform/features/events/test/RangeColumnSpec.js platform/features/events/test/policies/MessagesViewPolicySpec.js platform/features/rtevents/bundle.js platform/features/rtevents/src/DomainColumn.js platform/features/rtevents/src/RTEventListController.js platform/features/rtevents/src/RangeColumn.js platform/features/rtevents/src/directives/MCTRTDataTable.js platform/features/rtevents/src/policies/RTMessagesViewPolicy.js platform/features/rtevents/test/DomainColumnSpec.js platform/features/rtevents/test/RTEventListControllerSpec.js platform/features/rtevents/test/RangeColumnSpec.js platform/features/rtevents/test/policies/RTMessagesViewPolicySpec.js platform/features/rtscrolling/bundle.js platform/features/rtscrolling/src/DomainColumn.js platform/features/rtscrolling/src/NameColumn.js platform/features/rtscrolling/src/RTScrollingListController.js platform/features/rtscrolling/src/RangeColumn.js platform/features/scrolling/src/DomainColumn.js platform/features/scrolling/src/RangeColumn.js platform/features/scrolling/src/ScrollingListController.js platform/features/scrolling/src/ScrollingListPopulator.js platform/features/scrolling/test/DomainColumnSpec.js platform/features/scrolling/test/RangeColumnSpec.js platform/features/scrolling/test/ScrollingListControllerSpec.js platform/features/scrolling/test/ScrollingListPopulatorSpec.js platform/features/table/src/directives/MCTTable.js platform/features/table/test/controllers/TelemetryTableControllerSpec.js platform/representation/src/gestures/DropGesture.js platform/telemetry/src/TelemetryFormatter.js test-main.js
93 lines
3.4 KiB
JavaScript
93 lines
3.4 KiB
JavaScript
/*****************************************************************************
|
|
* 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(
|
|
[],
|
|
function () {
|
|
|
|
/**
|
|
* Notes on implementation of plot options
|
|
*
|
|
* Multiple y-axes will have to be handled with multiple forms as
|
|
* they will need to be stored on distinct model object
|
|
*
|
|
* Likewise plot series options per-child will need to be separate
|
|
* forms.
|
|
*/
|
|
|
|
/**
|
|
* The LayoutController is responsible for supporting the
|
|
* Layout view. It arranges frames according to saved configuration
|
|
* and provides methods for updating these based on mouse
|
|
* movement.
|
|
* @memberof platform/features/plot
|
|
* @constructor
|
|
* @param {Scope} $scope the controller's Angular scope
|
|
*/
|
|
function TableOptionsController($scope) {
|
|
|
|
var self = this;
|
|
|
|
this.$scope = $scope;
|
|
this.domainObject = $scope.domainObject;
|
|
|
|
$scope.columnsForm = {};
|
|
|
|
this.domainObject.getCapability('mutation').listen(function (model) {
|
|
self.populateForm(model);
|
|
});
|
|
|
|
$scope.$watchCollection('configuration.table.columns', function (columns){
|
|
if (columns){
|
|
self.domainObject.useCapability('mutation', function (model) {
|
|
model.configuration.table.columns = columns;
|
|
});
|
|
self.domainObject.getCapability('persistence').persist();
|
|
}
|
|
});
|
|
|
|
}
|
|
|
|
TableOptionsController.prototype.populateForm = function (model) {
|
|
var columnsDefinition = (((model.configuration || {}).table || {}).columns || {}),
|
|
rows = [];
|
|
this.$scope.columnsForm = {
|
|
'name':'Columns',
|
|
'sections': [{
|
|
'name': 'Columns',
|
|
'rows': rows
|
|
}]};
|
|
|
|
Object.keys(columnsDefinition).forEach(function (key){
|
|
rows.push({
|
|
'name': key,
|
|
'control': 'checkbox',
|
|
'key': key
|
|
});
|
|
});
|
|
this.$scope.configuration = JSON.parse(JSON.stringify(model.configuration));
|
|
};
|
|
|
|
return TableOptionsController;
|
|
}
|
|
);
|