Merge branch 'topic-conditionals' of https://github.com/nasa/openmct into conditionals-refactor

This commit is contained in:
Joshi 2020-02-28 11:09:41 -08:00
commit ba780981a5
4 changed files with 18 additions and 7 deletions

View File

@ -113,7 +113,6 @@ export default class ConditionManager extends EventEmitter {
conditionObj = { conditionObj = {
isDefault: isDefault, isDefault: isDefault,
type: 'condition', type: 'condition',
name: isDefault ? 'Default' : 'Unnamed Condition',
identifier: { identifier: {
...this.domainObject.identifier, ...this.domainObject.identifier,
key: uuid() key: uuid()
@ -121,7 +120,7 @@ export default class ConditionManager extends EventEmitter {
configuration: { configuration: {
name: isDefault ? 'Default' : 'Unnamed Condition', name: isDefault ? 'Default' : 'Unnamed Condition',
output: 'false', output: 'false',
trigger: 'any', trigger: 'all',
criteria: isDefault ? [] : [{ criteria: isDefault ? [] : [{
telemetry: '', telemetry: '',
operation: '', operation: '',

View File

@ -102,7 +102,9 @@
<li class="has-local-controls t-condition"> <li class="has-local-controls t-condition">
<label>Match when</label> <label>Match when</label>
<span class="controls"> <span class="controls">
<select v-model="trigger"> <select v-model="domainObject.configuration.trigger"
@change="persist"
>
<option value="all">all criteria are met</option> <option value="all">all criteria are met</option>
<option value="any">any criteria are met</option> <option value="any">any criteria are met</option>
</select> </select>
@ -119,7 +121,7 @@
<Criterion :telemetry="telemetry" <Criterion :telemetry="telemetry"
:criterion="criterion" :criterion="criterion"
:index="index" :index="index"
:trigger="trigger" :trigger="domainObject.configuration.trigger"
:is-default="domainObject.configuration.criteria.length === 1" :is-default="domainObject.configuration.criteria.length === 1"
@persist="persist" @persist="persist"
/> />
@ -210,7 +212,6 @@ export default {
domainObject: this.domainObject, domainObject: this.domainObject,
currentCriteria: this.currentCriteria, currentCriteria: this.currentCriteria,
expanded: true, expanded: true,
trigger: 'all',
selectedOutputKey: '', selectedOutputKey: '',
stringOutputField: false, stringOutputField: false,
outputOptions: ['false', 'true', 'string'], outputOptions: ['false', 'true', 'string'],

View File

@ -38,19 +38,22 @@
<div v-show="isEditing" <div v-show="isEditing"
class="help" class="help"
> >
<span>The first condition to match is the one that wins. Drag conditions to rearrange.</span> <span v-if="!telemetryObjs.length">Drag telemetry into Condition Set in order to add conditions.</span>
<span v-else>The first condition to match is the one that wins. Drag conditions to rearrange.</span>
</div> </div>
<div class="holder add-condition-button-wrapper align-left"> <div class="holder add-condition-button-wrapper align-left">
<button <button
v-show="isEditing" v-show="isEditing"
id="addCondition" id="addCondition"
class="c-cs-button c-cs-button--major add-condition-button" class="c-cs-button c-cs-button--major add-condition-button"
:class="{ 'is-disabled': !telemetryObjs.length}"
:disabled="!telemetryObjs.length"
@click="addCondition" @click="addCondition"
> >
<span class="c-cs-button__label">Add Condition</span> <span class="c-cs-button__label">Add Condition</span>
</button> </button>
</div> </div>
<div class="c-c condition-collection"> <div class="c-c__condition-collection">
<ul class="c-c__container-holder"> <ul class="c-c__container-holder">
<li v-for="(conditionIdentifier, index) in conditionCollection" <li v-for="(conditionIdentifier, index) in conditionCollection"
:key="conditionIdentifier.key" :key="conditionIdentifier.key"

View File

@ -64,6 +64,10 @@ section {
margin-top: 5px; margin-top: 5px;
} }
.c-c__condition-collection.is-disabled {
opacity: 0.5;
}
.widget-condition form { .widget-condition form {
padding: 0.5em; padding: 0.5em;
display: flex; display: flex;
@ -91,6 +95,10 @@ section {
font-weight: bold; font-weight: bold;
color: #eee; color: #eee;
border-radius: 6px; border-radius: 6px;
&.is-disabled {
opacity: 0.5;
}
} }
.c-cs__disclosure-triangle, .c-cs__disclosure-triangle,