From a814c05af146b925383d571019a0c4e1c7ba904e Mon Sep 17 00:00:00 2001 From: Arek Zaluski Date: Wed, 18 Oct 2023 15:02:03 +0100 Subject: [PATCH] Advanced Settings as popover (#40) --- media/memory-inspector.css | 102 ++++++++++---------- src/webview/components/multi-select-bar.tsx | 85 ---------------- src/webview/components/multi-select.tsx | 61 ++++++++++++ src/webview/components/options-widget.tsx | 68 ++++++------- 4 files changed, 139 insertions(+), 177 deletions(-) delete mode 100644 src/webview/components/multi-select-bar.tsx create mode 100644 src/webview/components/multi-select.tsx diff --git a/media/memory-inspector.css b/media/memory-inspector.css index 9da4a96..877abc8 100644 --- a/media/memory-inspector.css +++ b/media/memory-inspector.css @@ -66,46 +66,16 @@ margin-bottom: 8px; } -.multi-select-bar { - display: flex; - flex-flow: row nowrap; - box-sizing: border-box; - user-select: none; - -moz-user-select: none; - -webkit-user-select: none; -} - -.multi-select-checkbox-wrapper { +.multi-select { + width: 160px; display: flex; - position: relative; - flex: auto; - text-align: center; + flex-direction: column; + text-align: left; } -.multi-select-label { - height: 100%; - flex: auto; +.multi-select-bar { display: flex; - align-items: center; - justify-content: center; - border: 1px solid; - padding: 0 6; - background-color: var(--vscode-editor-background); - border-color: var(--vscode-dropdown-border); - box-sizing: border-box; - text-transform: uppercase; -} - -.multi-select-label.active { - background-color: var(--vscode-input-background); - border-color: var(--vscode-sideBar-foreground); - text-decoration: underline; - font-weight: bold; -} - -.multi-select-label.inactive { - font-style: italic; - opacity: 0.7; + flex-direction: column; } .multi-select-checkbox { @@ -127,34 +97,60 @@ } .advanced-options-toggle { - cursor: pointer; + margin-left: auto; +} + +.advanced-options-content { + position: absolute; + z-index: 1; + margin: 20px -165px; + width: 160px; + padding: 12px; + border-radius: 1px; + background-color: var(--vscode-dropdown-background); + box-shadow: var(--vscode-dropdown-border) 0 2px 4px; + text-align: left; + display: none; + flex-direction: column; +} + +.advanced-options-toggle:focus .advanced-options-content, .advanced-options-content:active, .advanced-options-content:focus-within { display: flex; - flex-flow: row nowrap; - align-items: center; } -.advanced-options-toggle i.codicon { - padding-right: 3px; +.options-dropdown { + width: 70px; + min-width: 70px; +} + +.options-label { + margin: 10px 0px 2px 0px; + font-weight: bold; +} + +.multi-select-label { + margin-bottom: 2px; + font-weight: bold; } .core-options { - display: grid; - column-gap: 6px; - grid-template-columns: 4fr 4fr 2fr 1fr; + display: flex; + flex-direction: row; + align-items: end; + column-gap: 12px; margin: 6px 0; } +.options-textfield { + width: 100px; +} + +.options-texfield-long { + width: 200px; +} + .go-button { /* Match height of inputs */ height: calc(var(--input-height) * 1px); align-self: end; } - -.advanced-options { - display: grid; - column-gap: 6px; - row-gap: 3px; - grid-template-columns: max-content 1fr; - align-items: center; - margin: 6px 0; -} \ No newline at end of file diff --git a/src/webview/components/multi-select-bar.tsx b/src/webview/components/multi-select-bar.tsx deleted file mode 100644 index 8f70280..0000000 --- a/src/webview/components/multi-select-bar.tsx +++ /dev/null @@ -1,85 +0,0 @@ -/******************************************************************************** - * Copyright (C) 2023 Ericsson and others. - * - * This program and the accompanying materials are made available under the - * terms of the Eclipse Public License v. 2.0 which is available at - * http://www.eclipse.org/legal/epl-2.0. - * - * This Source Code may also be made available under the following Secondary - * Licenses when the conditions for such availability set forth in the Eclipse - * Public License v. 2.0 are satisfied: GNU General Public License, version 2 - * with the GNU Classpath Exception which is available at - * https://www.gnu.org/software/classpath/license.html. - * - * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 - ********************************************************************************/ - -import * as React from 'react'; - -export interface SingleSelectItemProps { - id: string; - label: string; - checked: boolean; -} - -interface MultiSelectBarProps { - items: SingleSelectItemProps[]; - id?: string; - onSelectionChanged: (labelSelected: string, newSelectionState: boolean) => unknown; -} - -export const MultiSelectBar: React.FC = ({ items, onSelectionChanged, id }) => { - const changeHandler: React.ChangeEventHandler = React.useCallback(e => { - onSelectionChanged(e.target.id, e.target.checked); - }, [onSelectionChanged]); - - return ( -
- {items.map(({ label, id: itemId, checked }) => ())} -
- ); -}; - -interface LabeledCheckboxProps { - label: string; - id: string; - onChange: React.ChangeEventHandler; - checked: boolean; -} - -export interface LabelProps { id: string; label: string; disabled?: boolean; classNames?: string[], style?: React.CSSProperties } - -export const Label: React.FC = ({ id, label, disabled, classNames, style }) => { - const additionalClassNames = classNames ? classNames.join(' ') : ''; - return ; -}; - -const LabeledCheckbox: React.FC = ({ checked, label, onChange, id }) => ( -
- -
-); - -export const MultiSelectWithLabel: React.FC = ({ id, label, items, onSelectionChanged }) => ( - <> - - - -); diff --git a/src/webview/components/multi-select.tsx b/src/webview/components/multi-select.tsx new file mode 100644 index 0000000..8e583b6 --- /dev/null +++ b/src/webview/components/multi-select.tsx @@ -0,0 +1,61 @@ +/******************************************************************************** + * Copyright (C) 2023 Ericsson and others. + * + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v. 2.0 which is available at + * http://www.eclipse.org/legal/epl-2.0. + * + * This Source Code may also be made available under the following Secondary + * Licenses when the conditions for such availability set forth in the Eclipse + * Public License v. 2.0 are satisfied: GNU General Public License, version 2 + * with the GNU Classpath Exception which is available at + * https://www.gnu.org/software/classpath/license.html. + * + * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0 + ********************************************************************************/ + +import { VSCodeCheckbox } from '@vscode/webview-ui-toolkit/react'; +import * as React from 'react'; + +export interface SingleSelectItemProps { + id: string; + label: string; + checked: boolean; +} + +interface MultiSelectProps { + items: SingleSelectItemProps[]; + label: string; + id?: string; + onSelectionChanged: (labelSelected: string, newSelectionState: boolean) => unknown; +} + +const MultiSelectBar: React.FC = ({ items, onSelectionChanged, id }) => { + const changeHandler: ((e: Event) => unknown) & React.FormEventHandler = React.useCallback(e => { + const target = e.target as HTMLInputElement; + if (target) { + onSelectionChanged(target.id, target.checked); + } + }, [onSelectionChanged]); + return ( +
+ {items.map(({ label, id: itemId, checked }) => ( + {label} + + ))} +
+ ); +}; + +export const MultiSelectWithLabel: React.FC = ({ id, label, items, onSelectionChanged }) => ( +
+ + +
+); diff --git a/src/webview/components/options-widget.tsx b/src/webview/components/options-widget.tsx index 5ff6497..650cce1 100644 --- a/src/webview/components/options-widget.tsx +++ b/src/webview/components/options-widget.tsx @@ -18,11 +18,11 @@ import React from 'react'; import type { DebugProtocol } from '@vscode/debugprotocol'; import { MemoryDisplayConfigurationChangeRequest, SerializedTableRenderOptions } from '../utils/view-types'; import { VSCodeButton, VSCodeDivider, VSCodeDropdown, VSCodeOption, VSCodeTextField } from '@vscode/webview-ui-toolkit/react'; -import { MultiSelectWithLabel } from './multi-select-bar'; import { messenger } from '../view-messenger'; import { setMemoryDisplayConfigurationType } from '../../common/messaging'; import { HOST_EXTENSION } from 'vscode-messenger-common'; import { TableRenderOptions } from '../columns/column-contribution-service'; +import { MultiSelectWithLabel } from './multi-select'; export interface OptionsWidgetProps extends Omit, Required { updateRenderOptions: (options: Partial) => void; @@ -31,10 +31,6 @@ export interface OptionsWidgetProps extends Omit { +export class OptionsWidget extends React.Component { constructor(props: OptionsWidgetProps) { super(props); - this.state = { showRenderOptions: false }; } override render(): React.ReactNode { + return
-
- - {this.state.showRenderOptions ? 'Hide Settings' : 'Show Settings'} -
- Address - Offset - Length + + Address + + Offset + Length Go -
- { - this.state.showRenderOptions && <> - -
- - + +
+
+ {!!this.props.columnOptions.length && configurable) + .map(column => ({ id: column.contribution.id, label: column.contribution.label, checked: column.active }))} + onSelectionChanged={this.props.toggleColumn} + />} + + 1 2 4 8 16 - - + + 1 2 4 @@ -85,17 +89,9 @@ export class OptionsWidget extends React.Component16 32 - {!!this.props.columnOptions.length && configurable) - .map(column => ({ id: column.contribution.id, label: column.contribution.label, checked: column.active }))} - onSelectionChanged={this.props.toggleColumn} - />}
- - } +
+
; } @@ -117,10 +113,4 @@ export class OptionsWidget extends React.Component this.doToggleRenderOptions(); - - protected doToggleRenderOptions(): void { - this.setState(prevState => ({ ...prevState, showRenderOptions: !prevState.showRenderOptions })); - } }