* [Frontend] Viewport metatag updated Fixes #2008 - Added shrink-to-fit=no; * [Frontend] Fix to Time Conductor for Safari Fixes #2008 - CSS mod for gradient blockers in TC * [Frontend] Remove data visualization element in TC Fixes #2008 - Note: this element holds the TOI indicator! * [Frontend] Hide TC ticks when on mobile Fixes #2008 - Added class `mobile-hide` to <conductor-axis> * [Frontend] Significant mobile fixes for panes and viewport Fixes #2008 Fixes #1770 Fixes #1928 - Left and right panes now positioning properly in mobile; - Fixed body overflow problem for #2008 "viewport" issue; * fixes multiple issues related to 2008 context menu firing too often - fixed by setting a isDragging flag Add and Remove respective classes on mobile orientation change by using mathMedia Close tree pane when navigating in mobile portrait only * [Frontend] Various Fixes #2008 - Always show Timeline zoom controls; - Prevent inline editing of object names in the main view when in mobile; * Add touch functionality to mct-drag it allows users to use the splitter in mobile and include appropriate tests * remove couchdb and reinstall localStorage * [Frontend] Mods to imagery CSS Fixes #2008 - Reduced size of image thumbnails; - Changed min-heights of image and thumbnail holders for .mobile.phone * [Frontend] Add Advanced CSS property to Display Layouts - WIP! - Add property to bundle; - Add CSS for column, row and fit-all classes; * [Frontend] Grid holder and class prefixing - WIP! - Edit grid-holder set to position: absolute - Added "fl-" prefix to fluid layout class names; * [Frontend] More CSS tweaks - WIP! * [Frontend] Added .drag-vertical - For use in Elements pool; - Applied in elements.html; * fix: check if stats is present before reseting zoom (#2029) * [Timer] Fix regression in timer visual indication and add tests * [TimeConductor] Fixes Issue #925 (#2020) * [TimeConductor] Fixes Issue #925` - Pressing enter in date field will update bounds properly in Safari * [Copyright] Update copyright year across platform code references Fixes #2034. * fixes issue #1999 - Use Object name as default export filename (#2001) * fixes issue #1999 add dynamic name(object name) to exportAsCSV filename * make requested changes * [Frontend] Add Advanced CSS property to Display Layouts - WIP! - Add property to bundle; - Add CSS for column, row and fit-all classes; * [Frontend] Grid holder and class prefixing - WIP! - Edit grid-holder set to position: absolute - Added "fl-" prefix to fluid layout class names; * [Frontend] More CSS tweaks - WIP! * [Frontend] Added .drag-vertical - For use in Elements pool; - Applied in elements.html; * [Frontend] More CSS tweaks - WIP! - Added .fl-phone-best-fit * working drag and switch, need to mutate * fix conflict * add ability to rearrange composition using drag gestures * add maxHeight and maxWidth to layout frames * [Frontend] Added fl-mobile-best-fit * [Frontend] Allow editor to set mins dimensions for fluid layout - Cleanups in CSS; - Mod to LayoutController.js to use minWidth and minHeight; * [Frontend] Styles for reordering in Elements pool - Changed class "dragging" to "reordering"; - Visual styling WIP; - TODO: style "reorder-actor" when implemented; * add reorder-actor class to draggable item in elements pool when selected and remove class when dropped * stacked plots reload on composition change * [Frontend] Tweaks to Elements pool reordering styles - "reorder-actor" added/removed from parent tree item; - Refined styling for drag in process in list; * [Frontend] Added new 12px list view glyph - Font files and CSS updates; * [Frontend] Added new 12px grippy glyph - Font files and CSS updates for Elements pool sorting styling; * fix failing test * make reviewer requested changes * remove create dialog from mobile
250 lines
7.2 KiB
SCSS
250 lines
7.2 KiB
SCSS
/*****************************************************************************
|
|
* Open MCT, Copyright (c) 2014-2018, 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.
|
|
*****************************************************************************/
|
|
.frame {
|
|
$ohH: $btnFrameH;
|
|
$bc: $colorInteriorBorder;
|
|
|
|
position: absolute;
|
|
|
|
&.child-frame.panel {
|
|
z-index: 0; // Needed to prevent child-frame controls from showing through when another child-frame is above
|
|
&:not(.no-frame) {
|
|
background: $colorBodyBg;
|
|
border-color: $bc;
|
|
}
|
|
}
|
|
|
|
.object-browse-bar {
|
|
font-size: 0.75em;
|
|
height: $ohH;
|
|
line-height: $ohH;
|
|
.right {
|
|
@include trans-prop-nice-fade($controlFadeMs);
|
|
padding-left: $interiorMargin;
|
|
}
|
|
}
|
|
|
|
&.t-object-type-timer,
|
|
&.t-object-type-clock,
|
|
&.t-object-type-hyperlink,
|
|
&.t-object-type-summary-widget {
|
|
// Hide the right side buttons for objects where they don't make sense
|
|
// Note that this will hide the view Switcher button if applied
|
|
// to an object that has it.
|
|
.object-browse-bar .right { display: none; }
|
|
}
|
|
|
|
> .object-holder.abs {
|
|
top: $ohH + $interiorMargin;
|
|
}
|
|
.contents {
|
|
$m: $interiorMargin;
|
|
top: $m;
|
|
right: $m;
|
|
bottom: $m;
|
|
left: $m;
|
|
}
|
|
&.frame-template {
|
|
.s-button,
|
|
.s-menu-button {
|
|
height: $ohH;
|
|
line-height: $ohH;
|
|
padding: 0 $interiorMargin;
|
|
> span,
|
|
&:before {
|
|
font-size: 0.65rem;
|
|
}
|
|
}
|
|
|
|
.s-menu-button:after {
|
|
font-size: 8px;
|
|
}
|
|
|
|
.view-switcher {
|
|
z-index: 10;
|
|
}
|
|
}
|
|
.view-switcher {
|
|
margin-right: $interiorMargin; // Kick other top bar elements away when I'm present.
|
|
// Hide the name when the view switcher is in a frame context
|
|
.title-label {
|
|
display: none;
|
|
}
|
|
}
|
|
|
|
&.no-frame {
|
|
background: transparent !important;
|
|
border-color: transparent;
|
|
.object-browse-bar .right {
|
|
$m: 0;
|
|
background: rgba(black, 0.3);
|
|
border-radius: $basicCr;
|
|
padding: $interiorMarginSm;
|
|
position: absolute;
|
|
top: $m; right: $m;
|
|
z-index: 2;
|
|
}
|
|
&.t-frame-outer > .t-rep-frame {
|
|
&.contents {
|
|
$m: 0px;
|
|
top: $m;
|
|
right: $m;
|
|
bottom: $m;
|
|
left: $m;
|
|
}
|
|
> .t-frame-inner {
|
|
> .object-browse-bar .left {
|
|
display: none;
|
|
}
|
|
> .object-holder.abs {
|
|
overflow: hidden;
|
|
top: 0 !important;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
&.t-frame-outer .s-input-inline {
|
|
// Prevent inline inputs from being edited when nested in a Layout
|
|
pointer-events: none !important;
|
|
}
|
|
|
|
/********************************************************** OBJECT TYPES */
|
|
.t-object-type-hyperlink,
|
|
.t-object-type-summary-widget {
|
|
.object-holder {
|
|
overflow: hidden;
|
|
}
|
|
.w-summary-widget,
|
|
.l-summary-widget,
|
|
.l-hyperlink.s-button {
|
|
// Some object types expand to the full size of the object-holder.
|
|
@extend .abs;
|
|
}
|
|
|
|
.l-summary-widget,
|
|
.l-hyperlink.s-button {
|
|
.label {
|
|
@include ellipsize();
|
|
transform: translateY(-50%);
|
|
padding: 0 $interiorMargin;
|
|
position: absolute;
|
|
min-width: 0;
|
|
left: 0; right: 0;
|
|
text-align: center;
|
|
top: 50%;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
body.desktop .frame {
|
|
// Hide local controls initially and show it them on hover when they're in an element that's in a frame context
|
|
// Frame template is used because we need to target the lowest nested frame
|
|
.object-browse-bar .btn-bar {
|
|
opacity: 0;
|
|
pointer-events: none;
|
|
}
|
|
|
|
// Target the first descendant so that we only show the elements in the outermost container.
|
|
// Handles the case where we have layouts in layouts.
|
|
&:hover > .object-browse-bar {
|
|
.btn-bar {
|
|
opacity: 1;
|
|
pointer-events: inherit;
|
|
}
|
|
}
|
|
}
|
|
|
|
.holder-object:not(.s-status-editing) {
|
|
.l-layout {
|
|
&.fl-column,
|
|
&.fl-row,
|
|
&.fl-wrap,
|
|
&.fl-phone-best-fit,
|
|
&.fl-mobile-best-fit {
|
|
display: flex;
|
|
flex-wrap: nowrap;
|
|
align-content: stretch;
|
|
align-items: stretch;
|
|
> .frame {
|
|
display: block;
|
|
flex: 1 1 auto;
|
|
width: auto !important;
|
|
height: auto !important;
|
|
&.t-object-type-summary-widget {
|
|
&.no-frame.t-frame-outer > .t-rep-frame {
|
|
&.contents {
|
|
// When frame is hidden, add a bit of margin to the contents
|
|
$m: $interiorMargin;
|
|
top: $m; right: $m; bottom: $m; left: $m;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
&.fl-column {
|
|
flex-direction: column;
|
|
padding-right: $interiorMargin;
|
|
}
|
|
&.fl-row {
|
|
flex-direction: row;
|
|
padding-bottom: $interiorMargin;
|
|
}
|
|
|
|
&.fl-wrap {
|
|
align-content: flex-start;
|
|
align-items: flex-start;
|
|
flex-wrap: wrap;
|
|
}
|
|
}
|
|
}
|
|
|
|
.holder-object {
|
|
.l-layout {
|
|
&.fl-column,
|
|
&.fl-row,
|
|
&.fl-wrap,
|
|
&.fl-phone-best-fit,
|
|
&.fl-mobile-best-fit {
|
|
> .frame {
|
|
top: auto !important;
|
|
left: auto !important;
|
|
position: relative;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
body.mobile {
|
|
.l-layout.fl-mobile-best-fit {
|
|
flex-wrap: wrap !important;
|
|
padding: 0 !important;
|
|
}
|
|
&.portrait .l-layout.fl-mobile-best-fit {
|
|
flex-direction: column !important;
|
|
}
|
|
&.landscape .l-layout.fl-mobile-best-fit {
|
|
flex-direction: row !important;
|
|
}
|
|
}
|