slint/tools/lsp/ui/components/widgets/multi-value-widget.slint
Tobias Hunger 647b4650a3 live-preview: Fix widgets in the edit window of the table sticking out on the side
The classic: Layouts distribute 100% of the pixels to their elements
and only then apply padding and spacing... when you use `width: 100%;`.
2025-04-15 18:56:27 +02:00

44 lines
1.3 KiB
Text

// Copyright © SixtyFPS GmbH <info@slint.dev>
// SPDX-License-Identifier: GPL-3.0-only OR LicenseRef-Slint-Royalty-free-2.0 OR LicenseRef-Slint-Software-3.0
import { ChildIndicator, NameLabel, ResettingLineEdit } from "./basics.slint";
import { PropertyValue, PreviewData } from "../../api.slint";
import { EditorSizeSettings, EditorSpaceSettings } from "../../components/styling.slint";
import { Button } from "std-widgets.slint";
export component MultiValueWidget inherits GridLayout {
in property <bool> enabled;
in property <string> property-name: preview-data.name;
in property <PropertyValue> property-value;
in property <PreviewData> preview-data;
in property <string> property-group-id;
callback edit-in-table-editor(property-group-id: string, data: PreviewData);
spacing-vertical: EditorSpaceSettings.default-spacing;
Row {
NameLabel {
col: 1;
property-name: root.property-name;
property-value: root.property-value;
}
}
Row {
ChildIndicator {
horizontal-stretch: 0;
visible: false;
}
Button {
text: preview-data.has-setter ? @tr("Edit") : @tr("View");
clicked => {
root.edit-in-table-editor(root.property-group-id, root.preview-data);
}
}
}
}