From b0ac5ff1ce42e9da80a2afa58b972eabe471d907 Mon Sep 17 00:00:00 2001 From: Somya Sharma Date: Wed, 17 Apr 2024 16:56:59 -0700 Subject: [PATCH 1/5] Support svg xml data --- .../lib/AdaptiveImageRenderer.cpp | 27 ++++++++++++++----- source/uwp/SharedRenderer/lib/Util.cpp | 10 +++++++ source/uwp/SharedRenderer/lib/Util.h | 2 ++ 3 files changed, 33 insertions(+), 6 deletions(-) diff --git a/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp b/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp index b1576d387e..a4e92d6fc4 100644 --- a/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp +++ b/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp @@ -9,6 +9,7 @@ #include "AdaptiveBase64Util.h" #include "AdaptiveCardGetResourceStreamArgs.h" #include +#include "Util.h" #include "WholeItemsPanel.h" namespace winrt::AdaptiveCards::Rendering::Xaml_Rendering::implementation @@ -356,14 +357,23 @@ namespace AdaptiveCards::Rendering::Xaml_Rendering if (schemeName == L"data") { - // Decode base 64 string - winrt::hstring dataPath = imageUrl.Path(); - std::string data = AdaptiveBase64Util::ExtractDataFromUri(HStringToUTF8(dataPath)); - std::vector decodedData = AdaptiveBase64Util::Decode(data); - winrt::DataWriter dataWriter{winrt::InMemoryRandomAccessStream{}}; - dataWriter.WriteBytes(std::vector{decodedData.begin(), decodedData.end()}); + auto foundBase64 = HStringToUTF8(imageUrl.Path()).find("base64"); + if (!(foundBase64 == std::string::npos)) + { + // Decode base 64 string + winrt::hstring dataPath = imageUrl.Path(); + std::string data = AdaptiveBase64Util::ExtractDataFromUri(HStringToUTF8(dataPath)); + std::vector decodedData = AdaptiveBase64Util::Decode(data); + dataWriter.WriteBytes(std::vector{decodedData.begin(), decodedData.end()}); + } + else + { + // ... string + std::string data = ExtractSvgDataFromUri(imageUrl); + dataWriter.WriteBytes(std::vector{data.begin(), data.end()}); + } auto image = CreateImageSource(imgProperties.isImageSvg); @@ -428,6 +438,11 @@ namespace AdaptiveCards::Rendering::Xaml_Rendering strongThis->SetSvgUriSource(strongImageSource, imageUrl); } } + else if (status == winrt::AsyncStatus::Error) + { + // Handle error + winrt::hresult error = operation.ErrorCode(); + } } }); } diff --git a/source/uwp/SharedRenderer/lib/Util.cpp b/source/uwp/SharedRenderer/lib/Util.cpp index 9a012648e7..555b518b6e 100644 --- a/source/uwp/SharedRenderer/lib/Util.cpp +++ b/source/uwp/SharedRenderer/lib/Util.cpp @@ -643,3 +643,13 @@ namespace AdaptiveCards::Rendering::Xaml_Rendering registration->Set(L"Action.Execute", winrt::make()); } } + +std::string ExtractSvgDataFromUri(winrt::Windows::Foundation::Uri const& imageUrl) +{ + winrt::Windows::Foundation::Uri uriObj(imageUrl); + winrt::hstring unescapedUri = uriObj.UnescapeComponent(uriObj.AbsoluteUri()); + std::string dataUri = HStringToUTF8(unescapedUri); + size_t comaPosition = dataUri.find_first_of(","); + std::string data = dataUri.substr(comaPosition + 1); + return data; +} diff --git a/source/uwp/SharedRenderer/lib/Util.h b/source/uwp/SharedRenderer/lib/Util.h index 9f17f891f6..f013476f38 100644 --- a/source/uwp/SharedRenderer/lib/Util.h +++ b/source/uwp/SharedRenderer/lib/Util.h @@ -223,3 +223,5 @@ namespace AdaptiveCards::Rendering::Xaml_Rendering void RegisterDefaultActionRenderers(winrt::implementation::AdaptiveActionRendererRegistration* registration); } + +std::string ExtractSvgDataFromUri(winrt::Windows::Foundation::Uri const& imageUrl); From dc2cbc7a11825613753c111000b1cb970ba7c8c6 Mon Sep 17 00:00:00 2001 From: Somya Sharma Date: Wed, 17 Apr 2024 17:35:24 -0700 Subject: [PATCH 2/5] Clean up extraction --- source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp | 4 ++-- source/uwp/SharedRenderer/lib/Util.cpp | 8 ++++++-- 2 files changed, 8 insertions(+), 4 deletions(-) diff --git a/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp b/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp index a4e92d6fc4..9d3c224a96 100644 --- a/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp +++ b/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp @@ -360,7 +360,7 @@ namespace AdaptiveCards::Rendering::Xaml_Rendering winrt::DataWriter dataWriter{winrt::InMemoryRandomAccessStream{}}; auto foundBase64 = HStringToUTF8(imageUrl.Path()).find("base64"); - if (!(foundBase64 == std::string::npos)) + if (foundBase64 != std::string::npos) { // Decode base 64 string winrt::hstring dataPath = imageUrl.Path(); @@ -370,7 +370,7 @@ namespace AdaptiveCards::Rendering::Xaml_Rendering } else { - // ... string + // Extract ... string std::string data = ExtractSvgDataFromUri(imageUrl); dataWriter.WriteBytes(std::vector{data.begin(), data.end()}); } diff --git a/source/uwp/SharedRenderer/lib/Util.cpp b/source/uwp/SharedRenderer/lib/Util.cpp index 555b518b6e..f8af698534 100644 --- a/source/uwp/SharedRenderer/lib/Util.cpp +++ b/source/uwp/SharedRenderer/lib/Util.cpp @@ -649,7 +649,11 @@ std::string ExtractSvgDataFromUri(winrt::Windows::Foundation::Uri const& imageUr winrt::Windows::Foundation::Uri uriObj(imageUrl); winrt::hstring unescapedUri = uriObj.UnescapeComponent(uriObj.AbsoluteUri()); std::string dataUri = HStringToUTF8(unescapedUri); - size_t comaPosition = dataUri.find_first_of(","); - std::string data = dataUri.substr(comaPosition + 1); + size_t svgPosition = dataUri.find(" Date: Thu, 18 Apr 2024 14:58:15 -0700 Subject: [PATCH 3/5] Updated image svg sample --- samples/v1.5/Tests/Image.Svg.json | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/samples/v1.5/Tests/Image.Svg.json b/samples/v1.5/Tests/Image.Svg.json index 2b79c89ff4..8764012062 100644 --- a/samples/v1.5/Tests/Image.Svg.json +++ b/samples/v1.5/Tests/Image.Svg.json @@ -60,6 +60,11 @@ "backgroundColor": "#eeeeee", "style": "person", "url": "" + }, + { + "type": "Image", + "url": "data:image/svg+xml;utf8, ", + "size": "medium" } ] } From 32a2b5bebf4aa32ad9f7672d3ac055789db6b560 Mon Sep 17 00:00:00 2001 From: Somya Sharma Date: Fri, 19 Apr 2024 11:48:57 -0700 Subject: [PATCH 4/5] Additional check for svg --- source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp b/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp index 9d3c224a96..5bbc9706f5 100644 --- a/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp +++ b/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp @@ -368,7 +368,7 @@ namespace AdaptiveCards::Rendering::Xaml_Rendering std::vector decodedData = AdaptiveBase64Util::Decode(data); dataWriter.WriteBytes(std::vector{decodedData.begin(), decodedData.end()}); } - else + else if (imgProperties.isImageSvg) { // Extract ... string std::string data = ExtractSvgDataFromUri(imageUrl); From 41f226e9c159b1aa71d4c735ea1c762ac9dff40b Mon Sep 17 00:00:00 2001 From: Somya Sharma Date: Mon, 22 Apr 2024 17:43:09 -0700 Subject: [PATCH 5/5] PR feedback --- source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp b/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp index 5bbc9706f5..d7277deb6c 100644 --- a/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp +++ b/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp @@ -358,13 +358,12 @@ namespace AdaptiveCards::Rendering::Xaml_Rendering if (schemeName == L"data") { winrt::DataWriter dataWriter{winrt::InMemoryRandomAccessStream{}}; - - auto foundBase64 = HStringToUTF8(imageUrl.Path()).find("base64"); + auto imagePath = HStringToUTF8(imageUrl.Path()); + auto foundBase64 = imagePath.find("base64"); if (foundBase64 != std::string::npos) { // Decode base 64 string - winrt::hstring dataPath = imageUrl.Path(); - std::string data = AdaptiveBase64Util::ExtractDataFromUri(HStringToUTF8(dataPath)); + std::string data = AdaptiveBase64Util::ExtractDataFromUri(imagePath); std::vector decodedData = AdaptiveBase64Util::Decode(data); dataWriter.WriteBytes(std::vector{decodedData.begin(), decodedData.end()}); }