2015-05-13 23:42:35 +00:00
|
|
|
/*****************************************************************************
|
2016-07-12 23:21:58 +00:00
|
|
|
* Open MCT, Copyright (c) 2014-2016, United States Government
|
2015-05-13 23:42:35 +00:00
|
|
|
* as represented by the Administrator of the National Aeronautics and Space
|
|
|
|
* Administration. All rights reserved.
|
|
|
|
*
|
2016-07-12 23:21:58 +00:00
|
|
|
* Open MCT is licensed under the Apache License, Version 2.0 (the
|
2015-05-13 23:42:35 +00:00
|
|
|
* "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.
|
|
|
|
*
|
2016-07-12 23:21:58 +00:00
|
|
|
* Open MCT includes source code licensed under additional open source
|
2015-05-13 23:42:35 +00:00
|
|
|
* 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.
|
|
|
|
*****************************************************************************/
|
2014-12-05 20:48:21 +00:00
|
|
|
|
|
|
|
define(
|
|
|
|
[],
|
|
|
|
function () {
|
|
|
|
|
2014-12-06 02:01:38 +00:00
|
|
|
/**
|
|
|
|
* The EditRepresenter is responsible for implementing
|
|
|
|
* representation-level behavior relevant to Edit mode.
|
|
|
|
* Specifically, this listens for changes to view configuration
|
|
|
|
* or to domain object models, and triggers persistence when
|
|
|
|
* these are detected.
|
|
|
|
*
|
|
|
|
* This is exposed as an extension of category `representers`,
|
|
|
|
* which mct-representation will utilize to add additional
|
|
|
|
* behavior to each representation.
|
|
|
|
*
|
|
|
|
* This will be called once per mct-representation directive,
|
|
|
|
* and may be reused for different domain objects and/or
|
|
|
|
* representations resulting from changes there.
|
|
|
|
*
|
2015-08-07 18:44:54 +00:00
|
|
|
* @memberof platform/commonUI/edit
|
2015-08-10 23:38:13 +00:00
|
|
|
* @implements {Representer}
|
2014-12-06 02:01:38 +00:00
|
|
|
* @constructor
|
|
|
|
*/
|
2014-12-06 17:38:28 +00:00
|
|
|
function EditRepresenter($q, $log, scope) {
|
2015-08-10 23:38:13 +00:00
|
|
|
var self = this;
|
2014-12-05 20:48:21 +00:00
|
|
|
|
2015-11-25 18:40:37 +00:00
|
|
|
this.scope = scope;
|
2016-01-27 05:47:19 +00:00
|
|
|
this.listenHandle = undefined;
|
2015-11-25 18:40:37 +00:00
|
|
|
|
2014-12-06 02:01:38 +00:00
|
|
|
// Mutate and persist a new version of a domain object's model.
|
2016-04-29 18:35:00 +00:00
|
|
|
function doMutate(model) {
|
2015-08-10 23:38:13 +00:00
|
|
|
var domainObject = self.domainObject;
|
|
|
|
|
2014-12-06 02:01:38 +00:00
|
|
|
// First, mutate; then, persist.
|
2014-12-06 00:27:32 +00:00
|
|
|
return $q.when(domainObject.useCapability("mutation", function () {
|
|
|
|
return model;
|
2016-04-29 18:35:00 +00:00
|
|
|
}));
|
2014-12-05 20:48:21 +00:00
|
|
|
}
|
|
|
|
|
2014-12-06 02:01:38 +00:00
|
|
|
// Handle changes to model and/or view configuration
|
2014-12-06 17:38:28 +00:00
|
|
|
function commit(message) {
|
2014-12-06 02:01:38 +00:00
|
|
|
// Look up from scope; these will have been populated by
|
|
|
|
// mct-representation.
|
2014-12-05 20:48:21 +00:00
|
|
|
var model = scope.model,
|
2015-08-10 23:38:13 +00:00
|
|
|
configuration = scope.configuration,
|
|
|
|
domainObject = self.domainObject;
|
2014-12-05 20:48:21 +00:00
|
|
|
|
2014-12-06 17:38:28 +00:00
|
|
|
// Log the commit message
|
|
|
|
$log.debug([
|
|
|
|
"Committing ",
|
|
|
|
domainObject && domainObject.getModel().name,
|
|
|
|
"(" + (domainObject && domainObject.getId()) + "):",
|
|
|
|
message
|
|
|
|
].join(" "));
|
|
|
|
|
2014-12-06 02:01:38 +00:00
|
|
|
// Update the configuration stored in the model, and persist.
|
2016-04-29 18:35:00 +00:00
|
|
|
if (domainObject) {
|
2014-12-06 02:01:38 +00:00
|
|
|
// Configurations for specific views are stored by
|
|
|
|
// key in the "configuration" field of the model.
|
2015-08-10 23:38:13 +00:00
|
|
|
if (self.key && configuration) {
|
2014-12-06 00:27:32 +00:00
|
|
|
model.configuration = model.configuration || {};
|
2015-08-10 23:38:13 +00:00
|
|
|
model.configuration[self.key] = configuration;
|
2014-12-06 00:27:32 +00:00
|
|
|
}
|
2016-04-29 18:35:00 +00:00
|
|
|
doMutate(model);
|
2014-12-05 20:48:21 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-12-06 17:38:28 +00:00
|
|
|
// Place the "commit" method in the scope
|
|
|
|
scope.commit = commit;
|
2016-01-27 05:47:19 +00:00
|
|
|
|
2016-02-27 01:12:35 +00:00
|
|
|
// Clean up when the scope is destroyed
|
|
|
|
scope.$on("$destroy", function () {
|
|
|
|
self.destroy();
|
|
|
|
});
|
|
|
|
|
2014-12-05 20:48:21 +00:00
|
|
|
}
|
|
|
|
|
2015-08-10 23:38:13 +00:00
|
|
|
// Handle a specific representation of a specific domain object
|
|
|
|
EditRepresenter.prototype.represent = function represent(representation, representedObject) {
|
2016-03-04 19:41:48 +00:00
|
|
|
var scope = this.scope;
|
|
|
|
|
2015-08-10 23:38:13 +00:00
|
|
|
// Track the key, to know which view configuration to save to.
|
|
|
|
this.key = (representation || {}).key;
|
|
|
|
// Track the represented object
|
|
|
|
this.domainObject = representedObject;
|
2015-11-25 18:40:37 +00:00
|
|
|
|
2015-08-10 23:38:13 +00:00
|
|
|
// Ensure existing watches are released
|
|
|
|
this.destroy();
|
2016-01-27 05:47:19 +00:00
|
|
|
|
2016-05-19 18:29:13 +00:00
|
|
|
function setEditing() {
|
2016-02-27 01:12:35 +00:00
|
|
|
scope.viewObjectTemplate = 'edit-object';
|
2016-01-27 06:05:18 +00:00
|
|
|
}
|
|
|
|
|
2016-01-27 05:47:19 +00:00
|
|
|
/**
|
|
|
|
* Listen for changes in object state. If the object becomes
|
|
|
|
* editable then change the view and inspector regions
|
|
|
|
* object representation accordingly
|
|
|
|
*/
|
2016-05-19 18:29:13 +00:00
|
|
|
this.listenHandle = this.domainObject.getCapability('status').listen(function (statuses) {
|
|
|
|
if (statuses.indexOf('editing') !== -1) {
|
2016-01-27 06:05:18 +00:00
|
|
|
setEditing();
|
2016-01-27 05:47:19 +00:00
|
|
|
} else {
|
2016-02-27 01:12:35 +00:00
|
|
|
delete scope.viewObjectTemplate;
|
2016-01-27 05:47:19 +00:00
|
|
|
}
|
|
|
|
});
|
2016-01-27 06:05:18 +00:00
|
|
|
|
2016-05-19 18:29:13 +00:00
|
|
|
if (representedObject.hasCapability('editor') && representedObject.getCapability('editor').isEditContextRoot()) {
|
2016-01-27 06:05:18 +00:00
|
|
|
setEditing();
|
|
|
|
}
|
2015-08-10 23:38:13 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// Respond to the destruction of the current representation.
|
|
|
|
EditRepresenter.prototype.destroy = function destroy() {
|
2016-02-27 01:12:35 +00:00
|
|
|
return this.listenHandle && this.listenHandle();
|
2015-08-10 23:38:13 +00:00
|
|
|
};
|
|
|
|
|
2014-12-05 20:48:21 +00:00
|
|
|
return EditRepresenter;
|
|
|
|
}
|
2015-08-07 18:44:54 +00:00
|
|
|
);
|