diff --git a/package-lock.json b/package-lock.json index 7b7b87289b..97b48732d2 100644 --- a/package-lock.json +++ b/package-lock.json @@ -26588,7 +26588,6 @@ "version": "0.40.2", "license": "Apache-2.0", "dependencies": { - "@deephaven/components": "file:../components", "jquery": "^3.6.0" }, "devDependencies": { @@ -28473,7 +28472,6 @@ "@deephaven/golden-layout": { "version": "file:packages/golden-layout", "requires": { - "@deephaven/components": "file:../components", "browserify": "^17.0.0", "esmify": "^2.1.1", "jquery": "^3.6.0", diff --git a/packages/dashboard/src/PanelPlaceholder.scss b/packages/dashboard/src/PanelPlaceholder.scss index 1b77207852..284c222a09 100644 --- a/packages/dashboard/src/PanelPlaceholder.scss +++ b/packages/dashboard/src/PanelPlaceholder.scss @@ -4,13 +4,9 @@ display: flex; flex-direction: column; justify-content: center; + padding: $spacer-3; min-height: 100%; max-height: 100%; text-align: center; overflow: hidden; - - // add padding on an inner wrapper so it is included in max height of parent - div { - padding: $spacer-3; - } } diff --git a/packages/dashboard/src/PanelPlaceholder.tsx b/packages/dashboard/src/PanelPlaceholder.tsx index d0684500aa..b659523ccf 100644 --- a/packages/dashboard/src/PanelPlaceholder.tsx +++ b/packages/dashboard/src/PanelPlaceholder.tsx @@ -11,7 +11,7 @@ const PanelPlaceholder = React.forwardRef( const component = LayoutUtils.getComponentNameFromPanel({ props }); return (
-
Component "{component}" is not registered.
+ Component "{component}" is not registered.
); } diff --git a/packages/dashboard/src/layout/GoldenLayout.module.scss b/packages/dashboard/src/layout/GoldenLayout.module.scss new file mode 100644 index 0000000000..681a0b118a --- /dev/null +++ b/packages/dashboard/src/layout/GoldenLayout.module.scss @@ -0,0 +1,9 @@ +@import '@deephaven/components/scss/custom.scss'; +@import './GoldenLayout.scss'; + +// Exported variables for use in GoldenLayoutThemeExport.js +/* stylelint-disable property-no-unknown */ +:export { + tab-height: $tab-height; + drag-border-width: $drag-border-width; +} diff --git a/packages/dashboard/src/layout/GoldenLayout.scss b/packages/dashboard/src/layout/GoldenLayout.scss index 0392db293d..d3dce8bee2 100644 --- a/packages/dashboard/src/layout/GoldenLayout.scss +++ b/packages/dashboard/src/layout/GoldenLayout.scss @@ -2,22 +2,344 @@ @import '@deephaven/golden-layout/scss/goldenlayout-base.scss'; @import '@deephaven/golden-layout/scss/goldenlayout-dark-theme.scss'; -// Styling for behaviours not part of the default golden layout package +$tab-height: 28px; +$drag-border-width: 5px; +$close-button-height: 8px; +$tab-font-size: 12px; -.lm_tab .editor-unsaved-indicator { +$lm-tab-color: $gray-400; +$lm-tab-hover-color: $gray-300; +$lm-tab-active-color: $white; +$lm-tab-icon-color: $gray-200; + +//make some subtle tab background colors relative to our defined color +$lm-tab-active-background: $content-bg; +$lm-tab-background: darken($lm-tab-active-background, 3.5); +$lm-header-background: darken($lm-tab-active-background, 5); + +$lm-close-button-hover-color: $gray-100; +$lm-close-button-active-color: $gray-400; + +$lm-splitter-hover-color: $gray-400; +$lm-splitter-active-color: $gray-300; + +.lm_goldenlayout { + background: $background; + position: absolute; + + .lm_header { + box-sizing: content-box; // golden-layout sets a js height using a content box model + height: $tab-height; + padding-top: 0; + background: $lm-header-background; + box-shadow: inset 0 -1px 0 0 $background; + // inset box shadows with 0-blur used to draw borders without impacting spacing or GL size calculations. + // golden layout default styling doesnt have the same border styling we want + // this trick is used elsewhere in the header as well for the same purpose + + .lm_controls { + > li { + height: 100%; + width: 24px; + } + } + } +} + +.lm_maximised { + border: 15px solid rgba($black, 0.85); + height: 100% !important; + width: 100% !important; + .lm_items { + box-shadow: $box-shadow-900; + } +} + +.lm_header .lm_controls .lm_tabpreviousbutton { + background-size: 16px; + // vsChevronLeft + background-image: str-replace( + url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='#{$lm-tab-icon-color}' d='M5.928 7.976l4.357 4.357-.618.62L5 8.284v-.618L9.667 3l.618.619-4.357 4.357z'/%3E%3C/svg%3E"), + '#', + '%23' + ); +} + +.lm_header .lm_controls .lm_tabnextbutton { + background-size: 16px; + // vsChevronRight + background-image: str-replace( + url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='#{$lm-tab-icon-color}' d='M10.072 8.024L5.715 3.667l.618-.62L11 7.716v.618L6.333 13l-.618-.619 4.357-4.357z'/%3E%3C/svg%3E"), + '#', + '%23' + ); +} + +.lm_header .lm_controls .lm_tabdropdown { + background-size: 16px; + // vsChevronDown + background-image: str-replace( + url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='#{$lm-tab-icon-color}' d='M7.976 10.072l4.357-4.357.62.618L8.284 11h-.618L3 6.333l.619-.618 4.357 4.357z'/%3E%3C/svg%3E"), + '#', + '%23' + ); + + &::before { + display: none; + } +} + +.lm_header .lm_controls .lm_maximise { + background-size: 16px; + // vsChromeMaximize + background-image: str-replace( + url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='#{$lm-tab-icon-color}' d='M3 3v10h10V3H3zm9 9H4V4h8v8z'/%3E%3C/svg%3E"), + '#', + '%23' + ); +} + +.lm_tabs:empty + .lm_controls .lm_maximise { display: none; - margin-right: 5px; - width: 8px; - height: 8px; - border-radius: 50%; - background: $primary; +} + +.lm_maximised .lm_header .lm_controls .lm_maximise { + opacity: 0.7; + // vsChromeMinimize + background-image: str-replace( + url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='#{$gray-100}' d='M14 8v1H3V8h11z'/%3E%3C/svg%3E"), + '#', + '%23' + ); + + &:hover { + opacity: 1; + } +} + +.lm_header .lm_tab { + display: flex; + align-items: center; + font-family: $font-family-sans-serif; + background-color: $lm-tab-background; + color: $lm-tab-color; + height: $tab-height; + font-size: $tab-font-size; + min-width: 5rem; + margin: 0; + padding: 0 $spacer-1 0 $spacer-2; + box-shadow: inset -1px -1px 0 0 $background; // acting as bottom and right border + transition: color $transition, background-color $transition; + max-width: 12rem; + white-space: nowrap; + overflow: hidden; + + .lm_title { + flex-grow: 1; + padding-right: $spacer-1; + // add equalized spacing for tabs without close buttons + // so that when a tab is longer then min-width it still + // is balanced with equal padding. Extra padding is then + // removed from tabs with close buttons via negative margin + } + + .lm_title_before { + display: flex; + align-items: center; + } + + .editor-unsaved-indicator { + display: none; + margin-right: 5px; + width: 8px; + height: 8px; + border-radius: 50%; + background: $primary; + + &.is-unsaved { + display: inline-block; + } + } +} + +.lm_header .lm_tab.lm_active, +.lm_header .lm_tab.lm_active:hover { + height: $tab-height; + background-color: $lm-tab-active-background; + color: $lm-tab-active-color; + padding-bottom: 0; + box-shadow: inset -1px 0 0 0 $background; // act as right border only when active + // also kills the default shadow, doesn't work well with our design + &.lm_focusin { + box-shadow: inset 0 1px $primary, inset -1px 0 0 0 $background; // top focus indicator, right border + } +} + +.lm_window_blur { + .lm_header .lm_tab.lm_active.lm_focusin { + box-shadow: none; + } +} + +.lm_content { + background: $content-bg; + overflow: visible; +} + +.lm_header .lm_tab .lm_close_tab { + $lm-close-button-padding: 4px; - &.is-unsaved { - display: inline-block; + cursor: pointer; + position: relative; + top: unset; + right: unset; + width: $close-button-height; + height: $close-button-height; + padding: $lm-close-button-padding; + margin-left: -$spacer-1; // undo padding on title + background-image: none; //remove the golden-layout image url + //fa-times-light url svg encoded as a background mask + background-color: $lm-tab-background; //set the backgroun color to nothing + mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 320 512'%3E%3Cpath d='M193.94 256L296.5 153.44l21.15-21.15c3.12-3.12 3.12-8.19 0-11.31l-22.63-22.63c-3.12-3.12-8.19-3.12-11.31 0L160 222.06 36.29 98.34c-3.12-3.12-8.19-3.12-11.31 0L2.34 120.97c-3.12 3.12-3.12 8.19 0 11.31L126.06 256 2.34 379.71c-3.12 3.12-3.12 8.19 0 11.31l22.63 22.63c3.12 3.12 8.19 3.12 11.31 0L160 289.94 262.56 392.5l21.15 21.15c3.12 3.12 8.19 3.12 11.31 0l22.63-22.63c3.12-3.12 3.12-8.19 0-11.31L193.94 256z'/%3E%3C/svg%3E"); + mask-position: center center; + mask-repeat: no-repeat; + mask-size: $close-button-height; + opacity: 1; //overide the opacity change + transition: background-color $transition; +} + +.lm_splitter, +.lm_splitter:hover { + background: $lm-splitter-hover-color; +} + +.lm_splitter.lm_dragging { + background: $lm-splitter-active-color; +} + +.lm_dragProxy { + .lm_content { + height: 100%; + width: 100%; + box-shadow: $box-shadow; + } + + .lm_header { + height: $tab-height; + + .lm_tab { + border: 0; + } } } +.lm_header .lm_tabdropdown_list { + z-index: $zindex-dropdown; + background: $lm-tab-background; + top: 22px; + right: 24px; + box-shadow: $box-shadow-900; + border-radius: $border-radius; + max-width: 12rem; + + .lm_tabdropdown_search { + padding: $spacer-1; + input { + padding: $input-padding-y $input-padding-x; + line-height: $input-line-height; + color: $input-color; + background-color: $input-bg; + border: $input-border-width solid $input-border-color; + border-radius: $border-radius; + max-width: 100%; + + &::placeholder { + color: $input-placeholder-color; + opacity: 1; + } + + &:focus { + border-color: $input-focus-border-color; + box-shadow: $input-btn-focus-box-shadow; + outline: 0; + } + } + } + + .lm_tab { + background: $lm-tab-background; + color: $lm-tab-hover-color; + box-shadow: none; + + .editor-unsaved-indicator { + width: 10px; + height: 10px; + border: 1px solid $lm-tab-background; + } + + &.lm_keyboard_active { + color: $lm-tab-hover-color; + background-color: $primary-dark; + } + + &:hover { + color: $lm-tab-active-color; + background-color: $primary; + } + } +} + +// disable hover styling during drag (pointer-events still needed) +body:not(.lm_dragging) .lm_header .lm_tab:not(.lm_active):hover { + color: $lm-tab-hover-color; +} + +.lm_header .lm_tab.lm_active .lm_close_tab { + background-color: $lm-tab-active-background; +} + +body:not(.lm_dragging) .lm_header .lm_tab:hover .lm_close_tab { + background-color: $lm-close-button-active-color; +} + +body:not(.lm_dragging) .lm_header .lm_tab .lm_close_tab:hover { + background-color: $lm-close-button-hover-color; +} + +.lm_dropTargetIndicator { + @include ants-base($white, $black); //replace with ants + + box-sizing: border-box; + outline: 0; //clear the normal dotted line + box-shadow: none; //get rid of standard dropshadow as it overlapps ants now, and re-apply to exsising inner element +} + +.lm_dropTargetIndicator .lm_inner { + box-sizing: border-box; + border: $ant-thickness solid transparent; //offset shadow using a transparent border + box-shadow: inset 0 0 1rem 1px rgba(black, 0.45); //true black for this shadow + opacity: 1; //set opacity back to 1, default 0.2 and backroudn was solid. + background: rgba($primary, 0.1); //apply scrim as rgba background now instead +} + +//is added to the body class, prevents overflow in our app context .lm_dragging { + overflow: hidden; +} + +.lm_dragging .app { + pointer-events: none; + + // disable other control buttons during drag + .lm_controls > li { + &.lm_tabpreviousbutton, + &.lm_tabnextbutton { + pointer-events: auto; + } + + pointer-events: none; + } + //disable plotly pointer events while dragging golden layout .js-plotly-plot .plotly { svg, @@ -27,4 +349,9 @@ pointer-events: none !important; } } + + // we still need events on our header for scroll while dragging to work + .lm_header { + pointer-events: auto; + } } diff --git a/packages/golden-layout/src/GoldenLayoutThemeExport.ts b/packages/dashboard/src/layout/GoldenLayoutThemeExport.ts similarity index 77% rename from packages/golden-layout/src/GoldenLayoutThemeExport.ts rename to packages/dashboard/src/layout/GoldenLayoutThemeExport.ts index 624034d821..a0b606d2ea 100644 --- a/packages/golden-layout/src/GoldenLayoutThemeExport.ts +++ b/packages/dashboard/src/layout/GoldenLayoutThemeExport.ts @@ -1,4 +1,4 @@ -import GoldenLayout from '../scss/GoldenLayout.module.scss'; +import GoldenLayout from './GoldenLayout.module.scss'; // parseInt for unitless values, stripping "px" export default Object.freeze({ diff --git a/packages/dashboard/src/layout/LayoutUtils.ts b/packages/dashboard/src/layout/LayoutUtils.ts index baedbc14b4..e1e2d9dfa7 100644 --- a/packages/dashboard/src/layout/LayoutUtils.ts +++ b/packages/dashboard/src/layout/LayoutUtils.ts @@ -1,13 +1,10 @@ import deepEqual from 'deep-equal'; import shortid from 'shortid'; import isMatch from 'lodash.ismatch'; +import { DragEvent } from 'react'; import Log from '@deephaven/log'; -import GoldenLayout, { - isComponent, - isRoot, - isStack, - GoldenLayoutThemeExport, -} from '@deephaven/golden-layout'; +import { isComponent, isRoot, isStack } from '@deephaven/golden-layout'; +import type GoldenLayout from '@deephaven/golden-layout'; import type { ComponentConfig, Config, @@ -19,9 +16,9 @@ import type { Stack, Tab, CloseOptions, - DragSourceEvent, } from '@deephaven/golden-layout'; import { assertNotNull } from '@deephaven/utils'; +import GoldenLayoutThemeExport from './GoldenLayoutThemeExport'; import { DashboardLayoutConfig } from '../DashboardLayout'; import { PanelConfig } from '../DashboardPlugin'; @@ -468,7 +465,7 @@ class LayoutUtils { replaceConfig?: Partial; createNewStack?: boolean; focusElement?: string; - dragEvent?: DragSourceEvent; + dragEvent?: DragEvent; } = {}): void { // attempt to retain focus after dom manipulation, which can break focus const maintainFocusElement = document.activeElement; @@ -478,7 +475,7 @@ class LayoutUtils { config.id = shortid.generate(); } - if (dragEvent !== undefined) { + if (dragEvent) { root?.layoutManager.createDragSourceFromEvent(config, dragEvent); return; } diff --git a/packages/dashboard/src/layout/index.ts b/packages/dashboard/src/layout/index.ts index 3912df26bb..38249a807b 100644 --- a/packages/dashboard/src/layout/index.ts +++ b/packages/dashboard/src/layout/index.ts @@ -1,3 +1,4 @@ +export { default as GoldenLayoutThemeExport } from './GoldenLayoutThemeExport'; export { default as LayoutUtils } from './LayoutUtils'; export { default as GLPropTypes } from './GLPropTypes'; diff --git a/packages/golden-layout/karma.conf.cjs b/packages/golden-layout/karma.conf.cjs index 5e32f6a81c..7a401373f1 100644 --- a/packages/golden-layout/karma.conf.cjs +++ b/packages/golden-layout/karma.conf.cjs @@ -24,14 +24,7 @@ module.exports = function (config) { }, browserify: { - debug: true, plugin: ['esmify'], - // ignored because it doesn't understand the scss import in GoldenLayoutThemeExport - configure: function (bundle) { - bundle.on('prebundle', function () { - bundle.ignore('./dist/GoldenLayoutThemeExport.js'); - }); - }, }, // test results reporter to use diff --git a/packages/golden-layout/package.json b/packages/golden-layout/package.json index 4a95a892b0..924e174b8e 100644 --- a/packages/golden-layout/package.json +++ b/packages/golden-layout/package.json @@ -10,7 +10,6 @@ "source": "src/index.ts", "type": "module", "dependencies": { - "@deephaven/components": "file:../components", "jquery": "^3.6.0" }, "peerDependencies": { @@ -19,7 +18,7 @@ }, "scripts": { "build": "cross-env NODE_ENV=production run-p build:*", - "build:sass": "sass --embed-sources --load-path=../../node_modules --style=compressed ./scss:./css", + "build:sass": "sass --embed-sources --style=compressed ./scss:./css", "build:babel": "babel ./src --out-dir ./dist --extensions \".ts,.js,.tsx,.jsx\" --source-maps --root-mode upward", "pretest": "npm run build", "test": "karma start karma.conf.cjs", diff --git a/packages/golden-layout/scss/GoldenLayout.module.scss b/packages/golden-layout/scss/GoldenLayout.module.scss deleted file mode 100644 index 64149be6ef..0000000000 --- a/packages/golden-layout/scss/GoldenLayout.module.scss +++ /dev/null @@ -1,8 +0,0 @@ -@use './goldenlayout-dark-theme.scss' as theme; - -// Exported variables for use in GoldenLayoutThemeExport.js -/* stylelint-disable property-no-unknown */ -:export { - tab-height: theme.$tab-height; - drag-border-width: theme.$drag-border-width; -} diff --git a/packages/golden-layout/scss/goldenlayout-base.scss b/packages/golden-layout/scss/goldenlayout-base.scss index cbfdcde5fe..52f2e6e4a6 100644 --- a/packages/golden-layout/scss/goldenlayout-base.scss +++ b/packages/golden-layout/scss/goldenlayout-base.scss @@ -259,6 +259,18 @@ $height6: 15px; // Appears 1 time // Dropdown arrow for additional tabs when too many to be displayed .lm_header { + .lm_controls .lm_tabdropdown:before { + content: ''; + width: 0; + height: 0; + vertical-align: middle; + display: inline-block; + border-top: 5px dashed; + border-right: 5px solid transparent; + border-left: 5px solid transparent; + color: white; // Overriden in specific Themes + } + .lm_tabdropdown_list { position: absolute; top: 20px; diff --git a/packages/golden-layout/scss/goldenlayout-dark-theme.scss b/packages/golden-layout/scss/goldenlayout-dark-theme.scss index 3acce7d53a..e993886d53 100644 --- a/packages/golden-layout/scss/goldenlayout-dark-theme.scss +++ b/packages/golden-layout/scss/goldenlayout-dark-theme.scss @@ -1,234 +1,150 @@ -@import '@deephaven/components/scss/custom.scss'; - -$tab-height: 28px; -$drag-border-width: 5px; - -$close-button-height: 8px; -$tab-font-size: 12px; - -$lm-tab-color: $gray-400; -$lm-tab-hover-color: $gray-300; -$lm-tab-active-color: $white; -$lm-tab-icon-color: $gray-200; - -//make some subtle tab background colors relative to our defined color -$lm-tab-active-background: $content-bg; -$lm-tab-background: darken($lm-tab-active-background, 3.5); -$lm-header-background: darken($lm-tab-active-background, 5); - -$lm-close-button-hover-color: $gray-100; -$lm-close-button-active-color: $gray-400; - -$lm-splitter-hover-color: $gray-400; -$lm-splitter-active-color: $gray-300; +// Color variables (appears count calculates by raw css) +$color0: #000000; // Appears 7 times +$color1: #222222; // Appears 3 times +$color2: #eeeeee; // Appears 2 times +$color3: #dddddd; // Appears 2 times + +$color4: #cccccc; // Appears 1 time +$color5: #444444; // Appears 1 time +$color6: #999999; // Appears 1 time +$color7: #111111; // Appears 1 time +$color8: #452500; // Appears 1 time +$color9: #555555; // Appears 1 time +$color10: #ffffff; // Appears 2 time // ".lm_dragging" is applied to BODY tag during Drag and is also directly applied to the root of the object being dragged -//is added to the body class, prevents overflow in our app context -.lm_dragging { - overflow: hidden; - pointer-events: none; - - // we still need events on our header for scroll while dragging to work - .lm_goldenlayout .lm_header { - pointer-events: auto; - - // disable other control buttons during drag - .lm_controls > li { - pointer-events: none; - - &.lm_tabpreviousbutton, - &.lm_tabnextbutton { - pointer-events: auto; - } - } - } -} - -// disable hover styling during drag (pointer-events still needed) -body:not(.lm_dragging) .lm_header .lm_tab:not(.lm_active):hover { - color: $lm-tab-hover-color; -} - -.lm_header .lm_tab.lm_active .lm_close_tab { - background-color: $lm-tab-active-background; -} - -body:not(.lm_dragging) .lm_header .lm_tab:hover .lm_close_tab { - background-color: $lm-close-button-active-color; -} - -body:not(.lm_dragging) .lm_header .lm_tab .lm_close_tab:hover { - background-color: $lm-close-button-hover-color; -} // Entire GoldenLayout Container, if a background is set, it is visible as color of "pane header" and "splitters" (if these latest has opacity very low) .lm_goldenlayout { - background: $background; - position: absolute; + background: $color0; } // Single Pane content (area in which final dragged content is contained) .lm_content { - background: $content-bg; - overflow: visible; + background: $color1; } // Single Pane content during Drag (style of moving window following mouse) .lm_dragProxy { .lm_content { - height: 100%; - width: 100%; - box-shadow: $box-shadow; - } - .lm_header { - height: $tab-height; - box-shadow: none; - - .lm_tab, - .lm_tab.lm_active { - border: 0; - box-shadow: $box-shadow; - } + box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.9); } } // Placeholder Container of target position .lm_dropTargetIndicator { - @include ants-base($white, $black); //replace with ants - box-sizing: border-box; - transition: all $transition-mid ease; + box-shadow: inset 0 0 30px $color0; + outline: 1px dashed $color4; + transition: all 200ms ease; // Inner Placeholder .lm_inner { - box-sizing: border-box; - border: $ant-thickness solid transparent; //offset shadow using a transparent border - box-shadow: inset 0 0 1rem 1px rgba(black, 0.45); //true black for this shadow - opacity: 1; //set opacity back to 1, default 0.2 and backroudn was solid. - background: rgba( - $primary, - 0.1 - ); //apply scrim as rgba background now instead + background: $color0; + opacity: 0.2; } } // Separator line (handle to change pane size) .lm_splitter { - background: $lm-splitter-hover-color; + background: $color0; opacity: 0.001; - transition: opacity $transition ease; + transition: opacity 200ms ease; &:hover, // When hovered by mouse... &.lm_dragging { - background: $lm-splitter-active-color; + background: $color5; opacity: 1; } } // Pane Header (container of Tabs for each pane) .lm_header { - box-sizing: content-box; // golden-layout sets a js height using a content box model - height: $tab-height; - padding-top: 0; - background: $lm-header-background; - box-shadow: inset 0 -1px 0 0 $background; - // inset box shadows with 0-blur used to draw borders without impacting spacing or GL size calculations. - // golden layout default styling doesnt have the same border styling we want - // this trick is used elsewhere in the header as well for the same purpose + height: 20px; user-select: none; - .lm_controls { - > li { - height: 100%; - width: 24px; - } - } - &.lm_selectable { cursor: pointer; } // Single Tab container. A single Tab is set for each pane, a group of Tabs are contained in ".lm_header" .lm_tab { - display: flex; - align-items: center; - font-family: $font-family-sans-serif; - background-color: $lm-tab-background; - color: $lm-tab-color; - height: $tab-height; - font-size: $tab-font-size; - min-width: 5rem; - margin: 0; - padding: 0 $spacer-1 0 $spacer-2; - box-shadow: inset -1px -1px 0 0 $background; // acting as bottom and right border - transition: color $transition, background-color $transition; - max-width: 12rem; - white-space: nowrap; - overflow: hidden; - - .lm_title { - flex-grow: 1; - padding-right: $spacer-1; - // add equalized spacing for tabs without close buttons - // so that when a tab is longer then min-width it still - // is balanced with equal padding. Extra padding is then - // removed from tabs with close buttons via negative margin - } - - .lm_title_before { - display: flex; - align-items: center; - } + font-family: Arial, sans-serif; + font-size: 12px; + color: $color6; + background: $color7; + box-shadow: 2px -2px 2px rgba(0, 0, 0, 0.3); + margin-right: 2px; + padding-bottom: 2px; + padding-top: 2px; + + /*.lm_title // Present in LIGHT Theme + { + padding-top:1px; + }*/ // Close Tab Icon .lm_close_tab { - $lm-close-button-padding: 4px; - - cursor: pointer; - position: relative; - width: $close-button-height; - height: $close-button-height; - padding: $lm-close-button-padding; - margin-left: -$spacer-1; // undo padding on title - //fa-times-light url svg encoded as a background mask - background-color: $lm-tab-background; //set the backgroun color to nothing - mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 320 512'%3E%3Cpath d='M193.94 256L296.5 153.44l21.15-21.15c3.12-3.12 3.12-8.19 0-11.31l-22.63-22.63c-3.12-3.12-8.19-3.12-11.31 0L160 222.06 36.29 98.34c-3.12-3.12-8.19-3.12-11.31 0L2.34 120.97c-3.12 3.12-3.12 8.19 0 11.31L126.06 256 2.34 379.71c-3.12 3.12-3.12 8.19 0 11.31l22.63 22.63c3.12 3.12 8.19 3.12 11.31 0L160 289.94 262.56 392.5l21.15 21.15c3.12 3.12 8.19 3.12 11.31 0l22.63-22.63c3.12-3.12 3.12-8.19 0-11.31L193.94 256z'/%3E%3C/svg%3E"); - mask-position: center center; - mask-repeat: no-repeat; - mask-size: $close-button-height; - opacity: 1; - transition: background-color $transition; + width: 11px; + height: 11px; + background-image: url(); + background-position: center center; + background-repeat: no-repeat; + top: 4px; + right: 6px; + opacity: 0.4; &:hover { opacity: 1; } } + + // If Tab is active, so if it's in foreground + &.lm_active { + border-bottom: none; + box-shadow: 0 -2px 2px $color0; + padding-bottom: 3px; + + .lm_close_tab { + opacity: 1; + } + } + } +} + +.lm_dragProxy.lm_bottom, +.lm_stack.lm_bottom { + .lm_header .lm_tab { + box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.3); + &.lm_active { + box-shadow: 0 2px 2px $color0; + } } } // If Pane Header (container of Tabs for each pane) is selected (used only if addition of new Contents is made "by selection" and not "by drag") .lm_selected { .lm_header { - background-color: $lm-tab-active-background; + background-color: $color8; } } -.lm_header .lm_tab.lm_active, -.lm_header .lm_tab.lm_active:hover { - height: $tab-height; - background-color: $lm-tab-active-background; - color: $lm-tab-active-color; - padding-bottom: 0; - box-shadow: inset -1px 0 0 0 $background; // act as right border only when active - // also kills the default shadow, doesn't work well with our design - &.lm_focusin { - box-shadow: inset 0 1px $primary, inset -1px 0 0 0 $background; // top focus indicator, right border +.lm_tab { + &:hover, // If Tab is hovered + &.lm_active // If Tab is active, so if it's in foreground + { + background: $color1; + color: $color3; } } -.lm_window_blur { - .lm_header .lm_tab.lm_active.lm_focusin { - box-shadow: none; - } +.lm_header .lm_tabs .lm_tab.lm_keyboard_active { + color: $color0; + background: $color3; +} + +// Dropdown arrow for additional tabs when too many to be displayed +.lm_header .lm_controls .lm_tabdropdown:before { + color: $color10; } // Pane controls (popout, maximize, minimize, close) @@ -253,23 +169,7 @@ body:not(.lm_dragging) .lm_header .lm_tab .lm_close_tab:hover { // Icon to Maximize Pane, so it will fill the entire GoldenLayout Container .lm_maximise { - background-size: 16px; - // vsChromeMaximize - background-image: str-replace( - url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='#{$lm-tab-icon-color}' d='M3 3v10h10V3H3zm9 9H4V4h8v8z'/%3E%3C/svg%3E"), - '#', - '%23' - ); - } - - .lm_tabdropdown { - background-size: 16px; - // vsChevronDown - background-image: str-replace( - url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='#{$lm-tab-icon-color}' d='M7.976 10.072l4.357-4.357.62.618L8.284 11h-.618L3 6.333l.619-.618 4.357 4.357z'/%3E%3C/svg%3E"), - '#', - '%23' - ); + background-image: url(); } // Icon to Close Pane and so remove it from GoldenLayout Container @@ -278,103 +178,52 @@ body:not(.lm_dragging) .lm_header .lm_tab .lm_close_tab:hover { } .lm_tabnextbutton { - background-size: 16px; - // vsChevronRight - background-image: str-replace( - url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='#{$lm-tab-icon-color}' d='M10.072 8.024L5.715 3.667l.618-.62L11 7.716v.618L6.333 13l-.618-.619 4.357-4.357z'/%3E%3C/svg%3E"), - '#', - '%23' - ); + background-image: url(); } .lm_tabpreviousbutton { - background-size: 16px; - // vsChevronLeft - background-image: str-replace( - url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='#{$lm-tab-icon-color}' d='M5.928 7.976l4.357 4.357-.618.62L5 8.284v-.618L9.667 3l.618.619-4.357 4.357z'/%3E%3C/svg%3E"), - '#', - '%23' - ); - } -} - -.lm_header .lm_tabdropdown_list { - z-index: $zindex-dropdown; - background: $lm-tab-background; - top: 22px; - right: 24px; - box-shadow: $box-shadow-900; - border-radius: $border-radius; - max-width: 12rem; - - .lm_tabdropdown_search { - padding: $spacer-1; - input { - padding: $input-padding-y $input-padding-x; - line-height: $input-line-height; - color: $input-color; - background-color: $input-bg; - border: $input-border-width solid $input-border-color; - border-radius: $border-radius; - max-width: 100%; - - &::placeholder { - color: $input-placeholder-color; - opacity: 1; - } - - &:focus { - border-color: $input-focus-border-color; - box-shadow: $input-btn-focus-box-shadow; - outline: 0; - } - } - } - - .lm_tab { - background: $lm-tab-background; - color: $lm-tab-hover-color; - box-shadow: none; - - &.lm_keyboard_active { - color: $lm-tab-hover-color; - background-color: $primary-dark; - } - - &:hover { - color: $lm-tab-active-color; - background-color: $primary; - } + background-image: url(); } } // If a specific Pane is maximized .lm_maximised { - border: 15px solid rgba($black, 0.85); - height: 100% !important; - width: 100% !important; - .lm_items { - box-shadow: $box-shadow-900; + // Pane Header (container of Tabs for each pane) can have different style when is Maximized + .lm_header { + background-color: $color0; } // Pane controls are different in Maximized Mode, especially the old Icon "Maximise" that now has a different meaning, so "Minimize" (even if CSS Class did not change) .lm_controls { .lm_maximise { - opacity: 0.7; - // vsChromeMinimize - background-image: str-replace( - url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='#{$gray-100}' d='M14 8v1H3V8h11z'/%3E%3C/svg%3E"), - '#', - '%23' - ); - - &:hover { - opacity: 1; - } + background-image: url(); } } } -.lm_tabs:empty + .lm_controls .lm_maximise { - display: none; +// If a specific Pane is Popped Out, so move it to a different Browser Window, Icon to restore original position is: +.lm_popin { + cursor: pointer; + + // Background of Icon + .lm_bg { + background: $color10; + opacity: 0.3; + } + + // Icon to Restore original position in Golden Layout Container + .lm_icon { + background-image: url(); + background-position: center center; + background-repeat: no-repeat; + border-left: 1px solid $color2; + border-top: 1px solid $color2; + opacity: 0.7; + } + + &:hover { + .lm_icon { + opacity: 1; + } + } } diff --git a/packages/golden-layout/src/LayoutManager.ts b/packages/golden-layout/src/LayoutManager.ts index 6386ba7466..af7df0deeb 100644 --- a/packages/golden-layout/src/LayoutManager.ts +++ b/packages/golden-layout/src/LayoutManager.ts @@ -43,8 +43,6 @@ export type ComponentConstructor< new (container: ItemContainer, state: unknown): unknown; }; -export type DragSourceEvent = JQuery.TriggeredEvent; - /** * The main class that will be exposed as GoldenLayout. * diff --git a/packages/golden-layout/src/declaration.d.ts b/packages/golden-layout/src/declaration.d.ts deleted file mode 100644 index a10272fac6..0000000000 --- a/packages/golden-layout/src/declaration.d.ts +++ /dev/null @@ -1,6 +0,0 @@ -declare module '*.module.scss' { - const content: Record; - export default content; -} - -declare module '*.scss'; diff --git a/packages/golden-layout/src/index.ts b/packages/golden-layout/src/index.ts index 6f3d0f26bb..50772dcb89 100644 --- a/packages/golden-layout/src/index.ts +++ b/packages/golden-layout/src/index.ts @@ -7,5 +7,3 @@ export * from './controls'; export * from './errors'; export * from './items'; export * from './utils'; -export { default as GoldenLayoutThemeExport } from './GoldenLayoutThemeExport'; -export type { DragSourceEvent } from './LayoutManager'; diff --git a/tests/golden-layout.spec.ts b/tests/golden-layout.spec.ts index 0bf4079f3b..d4fed1d301 100644 --- a/tests/golden-layout.spec.ts +++ b/tests/golden-layout.spec.ts @@ -10,7 +10,7 @@ test.describe('tests golden-layout operations', () => { page = await browser.newPage(); await page.goto(''); - // load a custom layout for the tests + // reset the layout before each test await page.getByTestId('app-main-panels-button').click(); // start listener before click const fileChooserPromise = page.waitForEvent('filechooser'); diff --git a/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-2-chromium-linux.png b/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-2-chromium-linux.png index 095bd7a4d8..cdb413555e 100644 Binary files a/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-2-chromium-linux.png and b/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-2-chromium-linux.png differ diff --git a/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-2-firefox-linux.png b/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-2-firefox-linux.png index 31fe902c63..e95c068a8d 100644 Binary files a/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-2-firefox-linux.png and b/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-2-firefox-linux.png differ diff --git a/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-2-webkit-linux.png b/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-2-webkit-linux.png index a29cffd8aa..3f555d588a 100644 Binary files a/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-2-webkit-linux.png and b/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-2-webkit-linux.png differ diff --git a/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-3-chromium-linux.png b/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-3-chromium-linux.png index 311331039b..6e661d72e4 100644 Binary files a/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-3-chromium-linux.png and b/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-3-chromium-linux.png differ diff --git a/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-3-firefox-linux.png b/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-3-firefox-linux.png index f45cbb78e3..00c4897e0a 100644 Binary files a/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-3-firefox-linux.png and b/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-3-firefox-linux.png differ diff --git a/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-3-webkit-linux.png b/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-3-webkit-linux.png index ab218a640c..0c2f0d06f1 100644 Binary files a/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-3-webkit-linux.png and b/tests/golden-layout.spec.ts-snapshots/tests-golden-layout-operations-golden-layout-can-drag-tab-to-left-edge-3-webkit-linux.png differ