From d3d926875f137b3b25d7a2beee14e5d73ca9aab9 Mon Sep 17 00:00:00 2001 From: Jake Mannens Date: Fri, 8 Sep 2023 09:03:58 +1000 Subject: Additional data sanitization in media service and keyboard shortcuts --- Pages/TagDefinitions.razor | 2 +- Pages/ViewMedia.razor | 33 +++++++++++++++------------------ Services/MediaService.cs | 7 +++++-- wwwroot/js/keyboard.js | 2 +- 4 files changed, 22 insertions(+), 22 deletions(-) diff --git a/Pages/TagDefinitions.razor b/Pages/TagDefinitions.razor index 95253b7..1a29b40 100644 --- a/Pages/TagDefinitions.razor +++ b/Pages/TagDefinitions.razor @@ -8,7 +8,7 @@
- + diff --git a/Pages/ViewMedia.razor b/Pages/ViewMedia.razor index 26b7988..7823c75 100644 --- a/Pages/ViewMedia.razor +++ b/Pages/ViewMedia.razor @@ -4,7 +4,6 @@ @inject IDbContextFactory dbFactory @inject ITagService tagService @inject IMediaService mediaService -@implements IDisposable @title @@ -30,7 +29,7 @@ - + @@ -83,19 +82,19 @@
- - - + + + @if(infoEditMode) { } else { - + } @if(media.IsIngest) { - + } else { - + }
@@ -143,14 +142,18 @@ private Dialog ocrDialog; private TagSelectDialog tagDialog; - private HBContext db; + private ElementReference shortDescriptionInput; - protected override void OnInitialized() { - db = dbFactory.CreateDbContext(); + protected override void OnInitialized() => LoadMedia(); + + protected override async void OnAfterRender(bool firstRender) { + if(infoEditMode) + await shortDescriptionInput.FocusAsync(); } private void LoadMedia() { + using var db = dbFactory.CreateDbContext(); media = db.Media .Include(m => m.Tags) .ThenInclude(t => t.TagDefinition) @@ -170,7 +173,6 @@ private async void SetIngest(bool ingest) { mediaService.SetIngest(media, ingest); - db.Entry(media).State = EntityState.Detached; LoadMedia(); if(ingest) @@ -191,11 +193,8 @@ private void ApplyInfoEdit(bool apply) { if(apply) { - if(string.IsNullOrEmpty(shortDescription)) shortDescription = null; - if(string.IsNullOrEmpty(longDescription)) longDescription = null; - media.ShortDescription = shortDescription; - media.LongDescription = longDescription; mediaService.SetDescription(media, shortDescription, longDescription); + LoadMedia(); } infoEditMode = false; @@ -205,6 +204,4 @@ mediaService.Delete(media); await jsRuntime.InvokeVoidAsync("history.back"); } - - public void Dispose() => db.Dispose(); } diff --git a/Services/MediaService.cs b/Services/MediaService.cs index e573add..c779d8e 100644 --- a/Services/MediaService.cs +++ b/Services/MediaService.cs @@ -83,13 +83,16 @@ public class MediaService : IMediaService { using var db = dbFactory.CreateDbContext(); var m = db.Media.First(m => m.Guid == media.Guid); + shortDescription = shortDescription?.Trim(); + longDescription = longDescription?.Trim(); + if(string.IsNullOrEmpty(shortDescription)) shortDescription = null; if(string.IsNullOrEmpty(longDescription)) longDescription = null; - m.ShortDescription = shortDescription?.Trim(); - m.LongDescription = longDescription?.Trim(); + m.ShortDescription = shortDescription; + m.LongDescription = longDescription; db.SaveChanges(); } diff --git a/wwwroot/js/keyboard.js b/wwwroot/js/keyboard.js index 5669637..4c8e722 100644 --- a/wwwroot/js/keyboard.js +++ b/wwwroot/js/keyboard.js @@ -6,7 +6,7 @@ async function keyDownHandler(e) { return false; } - if(document.activeElement.tagName == 'INPUT') + if(document.activeElement.tagName == 'INPUT' && e.key != 'Escape') return; var element = Array.from(document.querySelectorAll('div.dialog')) -- cgit v1.3
Title:
Description: