mirror of
https://github.com/nasa/openmct.git
synced 2025-01-18 02:39:56 +00:00
filter comparison list based on field selected
This commit is contained in:
parent
53b785269b
commit
a7fc9b3caa
@ -18,7 +18,9 @@
|
|||||||
<span v-if="criterion.telemetry"
|
<span v-if="criterion.telemetry"
|
||||||
class="controls"
|
class="controls"
|
||||||
>
|
>
|
||||||
<select v-model="criterion.metadata">
|
<select v-model="criterion.metadata"
|
||||||
|
@change="updateOperations"
|
||||||
|
>
|
||||||
<option value="">- Select Field -</option>
|
<option value="">- Select Field -</option>
|
||||||
<option v-for="option in telemetryMetadataOptions"
|
<option v-for="option in telemetryMetadataOptions"
|
||||||
:key="option.key"
|
:key="option.key"
|
||||||
@ -35,7 +37,7 @@
|
|||||||
@change="updateOperationInputVisibility"
|
@change="updateOperationInputVisibility"
|
||||||
>
|
>
|
||||||
<option value="">- Select Comparison -</option>
|
<option value="">- Select Comparison -</option>
|
||||||
<option v-for="option in operations"
|
<option v-for="option in filteredOps"
|
||||||
:key="option.name"
|
:key="option.name"
|
||||||
:value="option.name"
|
:value="option.name"
|
||||||
>
|
>
|
||||||
@ -83,6 +85,7 @@ export default {
|
|||||||
telemetryMetadata: {},
|
telemetryMetadata: {},
|
||||||
telemetryMetadataOptions: {},
|
telemetryMetadataOptions: {},
|
||||||
operations: OPERATIONS,
|
operations: OPERATIONS,
|
||||||
|
filteredOps: [],
|
||||||
isInputOperation: false,
|
isInputOperation: false,
|
||||||
rowLabel: ''
|
rowLabel: ''
|
||||||
}
|
}
|
||||||
@ -96,27 +99,46 @@ export default {
|
|||||||
mounted() {
|
mounted() {
|
||||||
this.updateMetadataOptions();
|
this.updateMetadataOptions();
|
||||||
this.updateOperationInputVisibility();
|
this.updateOperationInputVisibility();
|
||||||
console.log('this.criterion.metadata', this.criterion.metadata);
|
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
updateMetadataOptions() {
|
updateMetadataOptions() {
|
||||||
if (this.criterion.telemetry) {
|
if (this.criterion.telemetry) {
|
||||||
this.openmct.objects.get(this.criterion.telemetry).then((telemetryObject) => {
|
this.openmct.objects.get(this.criterion.telemetry).then((telemetryObject) => {
|
||||||
this.telemetryMetadata = this.openmct.telemetry.getMetadata(telemetryObject);
|
this.telemetryMetadata = this.openmct.telemetry.getMetadata(telemetryObject);
|
||||||
this.telemetryMetadataOptions = this.openmct.telemetry.getMetadata(telemetryObject).values();
|
this.telemetryMetadataOptions = this.telemetryMetadata.values();
|
||||||
// console.log('this.openmct.telemetry.getFormatMap(telemetryObject)', this.openmct.telemetry.getFormatMap(this.openmct.telemetry.getMetadata(telemetryObject)));
|
|
||||||
console.log('this.telemetryMetadata', this.openmct.telemetry.getMetadata(telemetryObject));
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
this.persist();
|
this.persist();
|
||||||
},
|
},
|
||||||
|
updateOperations(ev) {
|
||||||
|
let operationFormat = 'string';
|
||||||
|
this.telemetryMetadata.valueMetadatas.forEach((value, index) => {
|
||||||
|
if (value.key === ev.target.value) {
|
||||||
|
let valueMetadata = this.telemetryMetadataOptions[index];
|
||||||
|
if (valueMetadata.formatString) {
|
||||||
|
operationFormat = 'number';
|
||||||
|
} else if (valueMetadata.format) {
|
||||||
|
if (valueMetadata.format === 'utc') {
|
||||||
|
operationFormat = 'number';
|
||||||
|
} else if (valueMetadata.format === 'enum') {
|
||||||
|
operationFormat = 'enum';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
this.filteredOps = [...this.operations.filter(op => op.appliesTo.indexOf(operationFormat) !== -1)];
|
||||||
|
},
|
||||||
updateOperationInputVisibility() {
|
updateOperationInputVisibility() {
|
||||||
for (let i=0; i < this.operations.length; i++) {
|
if (this.criterion.operation === '') {
|
||||||
if (this.criterion.operation === this.operations[i].name) {
|
this.isInputOperation = false;
|
||||||
this.isInputOperation = this.operations[i].inputCount > 0;
|
} else {
|
||||||
|
for (let i = 0; i < this.filteredOps.length; i++) {
|
||||||
|
if (this.criterion.operation === this.filteredOps[i].name) {
|
||||||
|
this.isInputOperation = this.filteredOps[i].inputCount > 0;
|
||||||
if (!this.isInputOperation) {this.criterion.input = ''}
|
if (!this.isInputOperation) {this.criterion.input = ''}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
this.persist();
|
this.persist();
|
||||||
},
|
},
|
||||||
updateMetadataSelection() {
|
updateMetadataSelection() {
|
||||||
|
Loading…
Reference in New Issue
Block a user