mirror of
https://github.com/nasa/openmct.git
synced 2025-05-03 09:12:51 +00:00
* Add an active class to thumbnail to indicate current focused image * Differentiate bg color between real-time and fixed * scrollIntoView inline: center * Added watcher for bounds change to trigger thumbnail scroll * Resolve merge conflict with requestHistory change to telemetry collection * Split thumbnail into sub component * Monitor isFixed value to unpause playback status
172 lines
6.7 KiB
JavaScript
172 lines
6.7 KiB
JavaScript
/*****************************************************************************
|
|
* Open MCT, Copyright (c) 2014-2022, 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.
|
|
*****************************************************************************/
|
|
|
|
const DEFAULT_DURATION_FORMATTER = 'duration';
|
|
|
|
export default {
|
|
inject: ['openmct', 'domainObject', 'objectPath'],
|
|
mounted() {
|
|
// listen
|
|
this.boundsChange = this.boundsChange.bind(this);
|
|
this.timeSystemChange = this.timeSystemChange.bind(this);
|
|
this.setDataTimeContext = this.setDataTimeContext.bind(this);
|
|
this.setDataTimeContext();
|
|
this.openmct.objectViews.on('clearData', this.dataCleared);
|
|
|
|
// set
|
|
this.keyString = this.openmct.objects.makeKeyString(this.domainObject.identifier);
|
|
this.metadata = this.openmct.telemetry.getMetadata(this.domainObject);
|
|
this.imageHints = { ...this.metadata.valuesForHints(['image'])[0] };
|
|
this.durationFormatter = this.getFormatter(this.timeSystem.durationFormat || DEFAULT_DURATION_FORMATTER);
|
|
this.imageFormatter = this.openmct.telemetry.getValueFormatter(this.imageHints);
|
|
this.imageDownloadNameHints = { ...this.metadata.valuesForHints(['imageDownloadName'])[0]};
|
|
|
|
// initialize
|
|
this.timeKey = this.timeSystem.key;
|
|
this.timeFormatter = this.getFormatter(this.timeKey);
|
|
|
|
this.telemetryCollection = this.openmct.telemetry.requestCollection(this.domainObject, {});
|
|
this.telemetryCollection.on('add', this.dataAdded);
|
|
this.telemetryCollection.on('remove', this.dataRemoved);
|
|
this.telemetryCollection.on('clear', this.dataCleared);
|
|
this.telemetryCollection.load();
|
|
},
|
|
beforeDestroy() {
|
|
if (this.unsubscribe) {
|
|
this.unsubscribe();
|
|
delete this.unsubscribe;
|
|
}
|
|
|
|
this.stopFollowingDataTimeContext();
|
|
this.openmct.objectViews.off('clearData', this.dataCleared);
|
|
|
|
this.telemetryCollection.off('add', this.dataAdded);
|
|
this.telemetryCollection.off('remove', this.dataRemoved);
|
|
this.telemetryCollection.off('clear', this.dataCleared);
|
|
|
|
this.telemetryCollection.destroy();
|
|
},
|
|
methods: {
|
|
dataAdded(dataToAdd) {
|
|
const normalizedDataToAdd = dataToAdd.map(datum => this.normalizeDatum(datum));
|
|
this.imageHistory = this.imageHistory.concat(normalizedDataToAdd);
|
|
},
|
|
dataCleared() {
|
|
this.imageHistory = [];
|
|
},
|
|
dataRemoved(dataToRemove) {
|
|
this.imageHistory = this.imageHistory.filter(existingDatum => {
|
|
const shouldKeep = dataToRemove.some(datumToRemove => {
|
|
const existingDatumTimestamp = this.parseTime(existingDatum);
|
|
const datumToRemoveTimestamp = this.parseTime(datumToRemove);
|
|
|
|
return (existingDatumTimestamp !== datumToRemoveTimestamp);
|
|
});
|
|
|
|
return shouldKeep;
|
|
});
|
|
},
|
|
setDataTimeContext() {
|
|
this.stopFollowingDataTimeContext();
|
|
this.timeContext = this.openmct.time.getContextForView(this.objectPath);
|
|
this.timeContext.on('bounds', this.boundsChange);
|
|
this.boundsChange(this.timeContext.bounds());
|
|
this.timeContext.on('timeSystem', this.timeSystemChange);
|
|
},
|
|
stopFollowingDataTimeContext() {
|
|
if (this.timeContext) {
|
|
this.timeContext.off('bounds', this.boundsChange);
|
|
this.timeContext.off('timeSystem', this.timeSystemChange);
|
|
}
|
|
},
|
|
formatImageUrl(datum) {
|
|
if (!datum) {
|
|
return;
|
|
}
|
|
|
|
return this.imageFormatter.format(datum);
|
|
},
|
|
formatTime(datum) {
|
|
if (!datum) {
|
|
return;
|
|
}
|
|
|
|
let dateTimeStr = this.timeFormatter.format(datum);
|
|
|
|
// Replace ISO "T" with a space to allow wrapping
|
|
return dateTimeStr.replace("T", " ");
|
|
},
|
|
getImageDownloadName(datum) {
|
|
let imageDownloadName = '';
|
|
if (datum) {
|
|
const key = this.imageDownloadNameHints.key;
|
|
imageDownloadName = datum[key];
|
|
}
|
|
|
|
return imageDownloadName;
|
|
},
|
|
parseTime(datum) {
|
|
if (!datum) {
|
|
return;
|
|
}
|
|
|
|
return this.timeFormatter.parse(datum);
|
|
},
|
|
boundsChange(bounds, isTick) {
|
|
if (isTick) {
|
|
return;
|
|
}
|
|
|
|
// forcibly reset the imageContainer size to prevent an aspect ratio distortion
|
|
delete this.imageContainerWidth;
|
|
delete this.imageContainerHeight;
|
|
this.bounds = bounds; // setting bounds for ImageryView watcher
|
|
},
|
|
timeSystemChange() {
|
|
this.timeSystem = this.timeContext.timeSystem();
|
|
this.timeKey = this.timeSystem.key;
|
|
this.timeFormatter = this.getFormatter(this.timeKey);
|
|
this.durationFormatter = this.getFormatter(this.timeSystem.durationFormat || DEFAULT_DURATION_FORMATTER);
|
|
},
|
|
normalizeDatum(datum) {
|
|
const formattedTime = this.formatTime(datum);
|
|
const url = this.formatImageUrl(datum);
|
|
const time = this.parseTime(formattedTime);
|
|
const imageDownloadName = this.getImageDownloadName(datum);
|
|
|
|
return {
|
|
...datum,
|
|
formattedTime,
|
|
url,
|
|
time,
|
|
imageDownloadName
|
|
};
|
|
},
|
|
getFormatter(key) {
|
|
let metadataValue = this.metadata.value(key) || { format: key };
|
|
let valueFormatter = this.openmct.telemetry.getValueFormatter(metadataValue);
|
|
|
|
return valueFormatter;
|
|
}
|
|
}
|
|
};
|