From 3436270b7f8dbfbf16607c3e0b9c38c8a84b4afc Mon Sep 17 00:00:00 2001 From: jaimeatrhea Date: Tue, 26 Sep 2023 12:34:55 +0200 Subject: [PATCH] Add improvements to the MultiComboBox component --- .../Components/BookEditor/InputEditor.razor | 1 - .../BookEditor/InputEditor.razor.cs | 20 ++++++++++++++---- .../Components/MultiComboBox.razor | 18 ++++++++++++---- .../Components/MultiComboBox.razor.cs | 21 ++++++++++++++++++- .../Components/MultiComboBox.razor.css | 20 ++++++++++++++++-- .../wwwroot/css/SVG/icons/close.svg | 1 + COMET.Web.Common/wwwroot/css/styles.css | 4 ++++ 7 files changed, 73 insertions(+), 12 deletions(-) create mode 100644 COMET.Web.Common/wwwroot/css/SVG/icons/close.svg diff --git a/COMET.Web.Common/Components/BookEditor/InputEditor.razor b/COMET.Web.Common/Components/BookEditor/InputEditor.razor index 0f57520c1..37eda25a2 100644 --- a/COMET.Web.Common/Components/BookEditor/InputEditor.razor +++ b/COMET.Web.Common/Components/BookEditor/InputEditor.razor @@ -74,7 +74,6 @@ @context.Name diff --git a/COMET.Web.Common/Components/BookEditor/InputEditor.razor.cs b/COMET.Web.Common/Components/BookEditor/InputEditor.razor.cs index a4aa91330..35cd9c7b1 100644 --- a/COMET.Web.Common/Components/BookEditor/InputEditor.razor.cs +++ b/COMET.Web.Common/Components/BookEditor/InputEditor.razor.cs @@ -31,6 +31,7 @@ namespace COMET.Web.Common.Components.BookEditor using CDP4Common.SiteDirectoryData; using COMET.Web.Common.Model; + using COMET.Web.Common.Services.SessionManagement; using COMET.Web.Common.Utilities; using Microsoft.AspNetCore.Components; @@ -46,20 +47,26 @@ public partial class InputEditor /// Gets or sets the /// [Inject] - ILogger> Logger { get; set; } + public ILogger> Logger { get; set; } /// /// Gets or sets the /// [Inject] - HttpClient HttpClient { get; set; } + public HttpClient HttpClient { get; set; } - /// - /// Gets or sets the + /// + /// Gets or sets the /// [Inject] public IOptions Options { get; set; } + /// + /// Gets or sets the + /// + [Inject] + public ISessionService SessionService { get; set; } + /// /// Gets or sets the item for which the input is being provided /// @@ -117,6 +124,11 @@ protected override async Task OnInitializedAsync() { this.showShortName = showShortNameValue; } + + if (this.Item is IOwnedThing ownedThing) + { + ownedThing.Owner = this.SessionService.Session.ActivePerson.DefaultDomain; + } } catch (Exception e) { diff --git a/COMET.Web.Common/Components/MultiComboBox.razor b/COMET.Web.Common/Components/MultiComboBox.razor index 29d4d824d..af62e64f3 100644 --- a/COMET.Web.Common/Components/MultiComboBox.razor +++ b/COMET.Web.Common/Components/MultiComboBox.razor @@ -26,6 +26,8 @@ Data="@this.Data" ValueChanged="@this.ItemSelected" Enabled="@this.Enabled" + Value="@this.lastSelectedValue" + ClearButtonDisplayMode="DataEditorClearButtonDisplayMode.Auto" CssClass="w-100">
@@ -47,12 +49,12 @@ - @if(this.Values.Count <= 2) + @if(this.Values.Count <= this.MaxNumberOfChips) {
@foreach(var value in this.Values) { - + +
}
} else { -
@(this.Values.Count) items are selected
+ if (this.EditorTextTemplate != null) + { + @this.EditorTextTemplate + } + else + { +
@(this.Values.Count) items are selected
+ } } \ No newline at end of file diff --git a/COMET.Web.Common/Components/MultiComboBox.razor.cs b/COMET.Web.Common/Components/MultiComboBox.razor.cs index 5b904a2f3..cc06144cb 100644 --- a/COMET.Web.Common/Components/MultiComboBox.razor.cs +++ b/COMET.Web.Common/Components/MultiComboBox.razor.cs @@ -20,11 +20,22 @@ namespace COMET.Web.Common.Components ///
public partial class MultiComboBox { + /// + /// The last selected value of the combobox + /// + private TItem lastSelectedValue; + + /// + /// Gets or sets the maximum number of chips that the combo should show + /// + [Parameter] + public int MaxNumberOfChips { get; set; } = 3; + /// /// Gets or sets if the checkboxes for the selected items should be drawn /// [Parameter] - public bool ShowCheckBoxes { get; set; } + public bool ShowCheckBoxes { get; set; } = true; /// /// Gets or sets the item template for the selected items @@ -32,6 +43,12 @@ public partial class MultiComboBox [Parameter] public RenderFragment RowTemplate { get; set; } + /// + /// Gets or sets item template to show when the number of selected items is greater or equal to the + /// + [Parameter] + public RenderFragment EditorTextTemplate { get; set; } + /// /// Gets or sets the data of the combobox /// @@ -63,6 +80,8 @@ public partial class MultiComboBox /// an asynchronous operation private async Task ItemSelected(TItem newValue) { + this.lastSelectedValue = default; + if(this.Values.Contains(newValue)) { this.Values.Remove(newValue); diff --git a/COMET.Web.Common/Components/MultiComboBox.razor.css b/COMET.Web.Common/Components/MultiComboBox.razor.css index 9ad30922a..bf7ef31ba 100644 --- a/COMET.Web.Common/Components/MultiComboBox.razor.css +++ b/COMET.Web.Common/Components/MultiComboBox.razor.css @@ -1,17 +1,33 @@ ::deep.chip { border: 0; background-color: #EEEEEE; - border-radius: 15px; - padding: 2.5% 5%; + border-radius: 30px; + padding: 2%; box-shadow: 0px 0px 0px 1px rgba(0,0,0,0.2); + color: #555; + display: flex; + align-items:center; + justify-content:center; + column-gap: 5px; } +::deep.chip-button { + border: 0; + border-radius: 30px; +} + + ::deep.chip-button:hover { + box-shadow: 0px 0px 0px 2px rgba(0,0,0,0.2); + } + ::deep.chips-container { display: flex; flex-direction: row; flex-wrap: wrap; row-gap: 5px; column-gap: 5px; + width: 100%; + height: 100%; } ::deep.dxbl-listbox-item{ diff --git a/COMET.Web.Common/wwwroot/css/SVG/icons/close.svg b/COMET.Web.Common/wwwroot/css/SVG/icons/close.svg new file mode 100644 index 000000000..3c5977774 --- /dev/null +++ b/COMET.Web.Common/wwwroot/css/SVG/icons/close.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/COMET.Web.Common/wwwroot/css/styles.css b/COMET.Web.Common/wwwroot/css/styles.css index ee7b7cc89..d05981b90 100644 --- a/COMET.Web.Common/wwwroot/css/styles.css +++ b/COMET.Web.Common/wwwroot/css/styles.css @@ -60,6 +60,10 @@ background-image: url(SVG/icons/trash.svg) } +.icon-close { + background-image: url(SVG/icons/close.svg) +} + .logo-size { max-width: 95px; height: auto;