From a357bec1831611758a19bf23ff0fa5a5fe99ca52 Mon Sep 17 00:00:00 2001 From: TheArcaneBrony Date: Sun, 28 May 2023 11:30:53 +0200 Subject: Add changes --- .../Shared/SimpleComponents/DictionaryEditor.razor | 41 +++++++++++++ .../Shared/SimpleComponents/FancyTextBox.razor | 35 +++++++++++ .../Shared/SimpleComponents/StringListEditor.razor | 31 ++++++++++ .../Shared/SimpleComponents/ToggleSlider.razor | 70 ++++++++++++++++++++++ 4 files changed, 177 insertions(+) create mode 100644 MatrixRoomUtils.Web/Shared/SimpleComponents/DictionaryEditor.razor create mode 100644 MatrixRoomUtils.Web/Shared/SimpleComponents/FancyTextBox.razor create mode 100644 MatrixRoomUtils.Web/Shared/SimpleComponents/StringListEditor.razor create mode 100644 MatrixRoomUtils.Web/Shared/SimpleComponents/ToggleSlider.razor (limited to 'MatrixRoomUtils.Web/Shared/SimpleComponents') diff --git a/MatrixRoomUtils.Web/Shared/SimpleComponents/DictionaryEditor.razor b/MatrixRoomUtils.Web/Shared/SimpleComponents/DictionaryEditor.razor new file mode 100644 index 0000000..4d90c57 --- /dev/null +++ b/MatrixRoomUtils.Web/Shared/SimpleComponents/DictionaryEditor.razor @@ -0,0 +1,41 @@ +@using MatrixRoomUtils.Core.Extensions + + @foreach(var i in Items.Keys) + { + var key = i; + + +
+ } +
+ + +@code { + + [Parameter] + public Dictionary Items { get; set; } = new(); + + [Parameter, EditorRequired] + public EventCallback ItemsChanged { get; set; } + + [Parameter] + public Func? KeyFormatter { get; set; } + + [Parameter] + public Action? OnFocusLost { get; set; } + + + protected override Task OnInitializedAsync() + { + Console.WriteLine($"DictionaryEditor initialized with {Items.Count} items: {Items.ToJson()}"); + return base.OnInitializedAsync(); + } + + private void inputChanged(ChangeEventArgs obj, string key) + { + Console.WriteLine($"StringListEditor inputChanged {key} {obj.Value}"); + Items[key] = obj.Value.ToString(); + ItemsChanged.InvokeAsync(); + } + +} \ No newline at end of file diff --git a/MatrixRoomUtils.Web/Shared/SimpleComponents/FancyTextBox.razor b/MatrixRoomUtils.Web/Shared/SimpleComponents/FancyTextBox.razor new file mode 100644 index 0000000..9c325a7 --- /dev/null +++ b/MatrixRoomUtils.Web/Shared/SimpleComponents/FancyTextBox.razor @@ -0,0 +1,35 @@ +@inject IJSRuntime JsRuntime +@if (isVisible) +{ + +} +else +{ + @(Formatter?.Invoke(Value) ?? (IsPassword ? string.Join("", Value.Select(x=>'*')) : Value)) +} + +@code { + + [Parameter] + public string Value { get; set; } + + [Parameter] + public bool IsPassword { get; set; } = false; + + [Parameter] + public EventCallback ValueChanged { get; set; } + + [Parameter] + public Func? Formatter { get; set; } + + + private bool isVisible { get; set; } = false; + + private ElementReference elementToFocus; + + protected override async Task OnAfterRenderAsync(bool firstRender) + { + await JsRuntime.InvokeVoidAsync("BlazorFocusElement", elementToFocus); + } + +} \ No newline at end of file diff --git a/MatrixRoomUtils.Web/Shared/SimpleComponents/StringListEditor.razor b/MatrixRoomUtils.Web/Shared/SimpleComponents/StringListEditor.razor new file mode 100644 index 0000000..fe3a938 --- /dev/null +++ b/MatrixRoomUtils.Web/Shared/SimpleComponents/StringListEditor.razor @@ -0,0 +1,31 @@ +@for (int i = 0; i < Items.Count; i++) +{ + var self = i; + + +
+} + + +@code { + + [Parameter] + public List Items { get; set; } = new List(); + + [Parameter, EditorRequired] + public EventCallback ItemsChanged { get; set; } + + protected override Task OnInitializedAsync() + { + Console.WriteLine($"StringListEditor initialized with {Items.Count} items: {string.Join(",", Items)}"); + return base.OnInitializedAsync(); + } + + private void inputChanged(string obj, int i) + { + Console.WriteLine($"StringListEditor inputChanged {i} {obj}"); + Items[i] = obj; + ItemsChanged.InvokeAsync(); + } + +} \ No newline at end of file diff --git a/MatrixRoomUtils.Web/Shared/SimpleComponents/ToggleSlider.razor b/MatrixRoomUtils.Web/Shared/SimpleComponents/ToggleSlider.razor new file mode 100644 index 0000000..49a363d --- /dev/null +++ b/MatrixRoomUtils.Web/Shared/SimpleComponents/ToggleSlider.razor @@ -0,0 +1,70 @@ +@ChildContent + +
+ +
+ + + +@code { + [Parameter] + public RenderFragment? ChildContent { get; set; } + + [Parameter] + public bool Value { get; set; } + [Parameter] + public EventCallback ValueChanged { get; set; } + +} \ No newline at end of file -- cgit 1.5.1