* initial telemetry api updates for staleness support * modifying staleness to a subsription style * fixing variable name * debuggin * put the subscribe in the wrong place * stale class for object views * temp cyan border for testing * added staleness to swg, working on stacked plot staleness * WIP: stacked plot staleness * reverting, going a different route * staleness on stacked plots * plot legend staleness * remove debug code * staleness for alphanumerics * lad table and table set staleness * overlay plot staleness * remove debug code * hardened lad staleness functionality fixed plots without composition bug * adding staleness to gauges * renaming telemetry age check functionality so it does not conflict with new staleness functionality * couple one-off fixes here and there, and WIP for condition sets, moving to telemetry tables to facilitate styling of completed components * small fix on lad tables, added staleness functionality to tables * finishing up condition sets * some cleaning up * adding border to condition sets when an item is stale * fixing dub sub * addressing PR comment, moving repeated code to a function * robustified the SWG stalenes provider, little fixes here and there as far as cleaning up listeners and... whatnot * removing debug code * typo fixes * cleanin up debug code * created a simple stalenes mixin for more basic usage in components * more robustification, if a new staleness subscription happens, will now send the current staleness value if we have it, beefed up example stalenes swg provider * beefed up staleness mixin a bit to give it more use * copyright * cleanin up ladtable code * cleanin up ladtable code * cleaning up lad table sets * some minor updates * Closes #6109 - New staleness glyph and font CSS added. * Closes #6109 - Normalized staleness colors as theme constants. - New mixins for staleness application to view elements. - Applied staleness styling to all relevant view elements. - TODO: smoke-test in Show theme. * adding staleness utils helper, mixin and isStale functionalirty for telemtry api * Closes #6109 - Refined style for Snow theme. * need to have one domainObject per stalenes utility * making sure we handle domains correctly while dealing with staleness * couple fixes * moving abort controller logic to a spot where it makes more sense * added some more info for the StalenesProvider interface docs * returning undefinded for ifStale requests with no provider * debuggin * debuggin * missed "isStale" call in condtioncollections * removing debug code and using mixin unsubscribe in gauge * fixing tests * more targeted tree item click Co-authored-by: Charles Hacskaylo <charlesh88@gmail.com> Co-authored-by: Andrew Henry <akhenry@gmail.com> Co-authored-by: Scott Bell <scott@traclabs.com>
324 lines
7.0 KiB
SCSS
324 lines
7.0 KiB
SCSS
/*****************************************************************************
|
|
* 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.
|
|
*****************************************************************************/
|
|
/***************************** DRAGGING */
|
|
.is-active-dragging {
|
|
.c-condition-h__drop-target {
|
|
height: 3px;
|
|
margin-bottom: $interiorMarginSm;
|
|
}
|
|
}
|
|
|
|
.c-condition-h {
|
|
&__drop-target {
|
|
border-radius: $controlCr;
|
|
height: 0;
|
|
min-height: 0;
|
|
transition: background-color, height;
|
|
transition-duration: 150ms;
|
|
}
|
|
|
|
&.is-drag-target {
|
|
.c-condition > * {
|
|
pointer-events: none; // Keeps the JS drop handler from being intercepted by internal elements
|
|
}
|
|
|
|
.c-condition-h__drop-target {
|
|
background-color: rgba($colorKey, 0.7);
|
|
}
|
|
}
|
|
}
|
|
|
|
.c-cs {
|
|
display: flex;
|
|
flex-direction: column;
|
|
flex: 1 1 auto;
|
|
height: 100%;
|
|
overflow: hidden;
|
|
|
|
&.is-stale {
|
|
@include isStaleHolder();
|
|
}
|
|
|
|
/************************** CONDITION SET LAYOUT */
|
|
&__current-output {
|
|
flex: 0 0 auto;
|
|
}
|
|
|
|
&__test-data-and-conditions-w {
|
|
display: flex;
|
|
flex-direction: column;
|
|
flex: 1 1 auto;
|
|
height: 100%;
|
|
overflow: hidden;
|
|
}
|
|
|
|
&__test-data,
|
|
&__conditions {
|
|
flex: 0 0 auto;
|
|
overflow: hidden;
|
|
}
|
|
|
|
&__test-data {
|
|
flex: 0 0 auto;
|
|
max-height: 50%;
|
|
|
|
&.is-expanded {
|
|
margin-bottom: $interiorMargin * 4;
|
|
}
|
|
}
|
|
|
|
&__conditions {
|
|
flex: 1 1 auto;
|
|
|
|
> * + * {
|
|
margin-top: $interiorMarginSm;
|
|
}
|
|
}
|
|
|
|
&__content {
|
|
display: flex;
|
|
flex-direction: column;
|
|
flex: 0 1 auto;
|
|
overflow: hidden;
|
|
|
|
> * {
|
|
flex: 0 0 auto;
|
|
overflow: hidden;
|
|
+ * {
|
|
margin-top: $interiorMarginSm;
|
|
}
|
|
}
|
|
|
|
.c-button {
|
|
align-self: start;
|
|
}
|
|
}
|
|
|
|
.is-editing & {
|
|
// Add some space to kick away from blue editing border indication
|
|
padding: $interiorMargin;
|
|
}
|
|
|
|
section {
|
|
display: flex;
|
|
flex-direction: column;
|
|
overflow: hidden;
|
|
}
|
|
|
|
&__conditions-h {
|
|
display: flex;
|
|
flex-direction: column;
|
|
flex: 1 1 auto;
|
|
overflow: auto;
|
|
padding-right: $interiorMarginSm;
|
|
|
|
> * + * {
|
|
margin-top: $interiorMarginSm;
|
|
}
|
|
}
|
|
|
|
.hint {
|
|
padding: $interiorMarginSm;
|
|
}
|
|
|
|
/************************** SPECIFIC ITEMS */
|
|
&__current-output-value {
|
|
flex-direction: row;
|
|
align-items: baseline;
|
|
padding: 0 $interiorMargin $interiorMarginLg $interiorMargin;
|
|
|
|
> * {
|
|
padding: $interiorMargin 0; // Must do this to align label and value
|
|
}
|
|
|
|
&__label {
|
|
color: $colorInspectorSectionHeaderFg;
|
|
opacity: 0.9;
|
|
text-transform: uppercase;
|
|
}
|
|
|
|
&__value {
|
|
$p: $interiorMargin * 3;
|
|
font-size: 1.25em;
|
|
margin-left: $interiorMargin;
|
|
padding-left: $p;
|
|
padding-right: $p;
|
|
background: rgba(black, 0.2);
|
|
border-radius: 5px;
|
|
}
|
|
}
|
|
}
|
|
|
|
/***************************** CONDITIONS AND TEST DATUM ELEMENTS */
|
|
.c-condition,
|
|
.c-test-datum {
|
|
@include discreteItem();
|
|
display: flex;
|
|
padding: $interiorMargin;
|
|
line-height: 170%; // Aligns text with controls like selects
|
|
}
|
|
|
|
.c-cdef,
|
|
.c-cs-test {
|
|
&__controls {
|
|
display: flex;
|
|
flex: 1 1 auto;
|
|
flex-wrap: wrap;
|
|
|
|
> * > * {
|
|
margin-right: $interiorMarginSm;
|
|
}
|
|
}
|
|
|
|
&__buttons {
|
|
white-space: nowrap;
|
|
}
|
|
}
|
|
|
|
.c-condition {
|
|
border: 1px solid transparent;
|
|
flex-direction: column;
|
|
min-width: 400px;
|
|
|
|
> * + * {
|
|
margin-top: $interiorMarginSm;
|
|
}
|
|
&--browse {
|
|
.c-condition__summary {
|
|
border-top: 1px solid $colorInteriorBorder;
|
|
padding-top: $interiorMargin;
|
|
}
|
|
}
|
|
|
|
/***************************** HEADER */
|
|
&__header {
|
|
$h: 22px;
|
|
display: flex;
|
|
align-items: start;
|
|
align-content: stretch;
|
|
overflow: hidden;
|
|
min-height: $h;
|
|
line-height: $h;
|
|
|
|
> * {
|
|
flex: 0 0 auto;
|
|
+ * {
|
|
margin-left: $interiorMarginSm;
|
|
}
|
|
}
|
|
}
|
|
|
|
&__drag-grippy {
|
|
transform: translateY(50%);
|
|
}
|
|
|
|
&__name {
|
|
font-weight: bold;
|
|
align-self: baseline; // Fixes bold line-height offset problem
|
|
}
|
|
|
|
&__output,
|
|
&__summary {
|
|
flex: 1 1 auto;
|
|
}
|
|
|
|
&.is-current {
|
|
$c: $colorBodyFg;
|
|
border-color: rgba($c, 0.2);
|
|
background: rgba($c, 0.2);
|
|
}
|
|
}
|
|
|
|
/***************************** CONDITION DEFINITION, EDITING */
|
|
.c-cdef {
|
|
display: grid;
|
|
grid-row-gap: $interiorMarginSm;
|
|
grid-column-gap: $interiorMargin;
|
|
grid-auto-columns: min-content 1fr max-content;
|
|
align-items: start;
|
|
min-width: 150px;
|
|
margin-left: 29px;
|
|
overflow: hidden;
|
|
|
|
&__criteria,
|
|
&__match-and-criteria {
|
|
display: contents;
|
|
}
|
|
|
|
&__label {
|
|
grid-column: 1;
|
|
text-align: right;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
&__separator {
|
|
grid-column: 1 / span 3;
|
|
}
|
|
|
|
&__controls {
|
|
align-items: flex-start;
|
|
grid-column: 2;
|
|
|
|
> * > * {
|
|
margin-right: $interiorMarginSm;
|
|
}
|
|
}
|
|
|
|
&__buttons {
|
|
grid-column: 3;
|
|
}
|
|
}
|
|
|
|
.c-c__drag-ghost {
|
|
width: 100%;
|
|
min-height: $interiorMarginSm;
|
|
|
|
&.dragging {
|
|
min-height: 5em;
|
|
background-color: lightblue;
|
|
border-radius: 2px;
|
|
}
|
|
}
|
|
|
|
/***************************** TEST DATA */
|
|
.c-cs__test-data {
|
|
&__controls {
|
|
flex: 0 0 auto;
|
|
}
|
|
}
|
|
|
|
.c-cs-tests {
|
|
flex: 0 1 auto;
|
|
overflow: auto;
|
|
padding-right: $interiorMarginSm;
|
|
|
|
> * + * {
|
|
margin-top: $interiorMarginSm;
|
|
}
|
|
}
|
|
|
|
.c-cs-test {
|
|
> * + * {
|
|
margin-left: $interiorMargin;
|
|
}
|
|
}
|