feat: support to set icon color to the theme color when proxy icon starts with data:image/svg+xml (#1166)

* feat: support to set icon color to the theme color when proxy icon starts with `data:image/svg+xml`

* fix: errors related to set icon color to the theme color
1. remove incorrect CSS properties
2. rearrange these properties
3. use `fallback` property in `Show` component insead of using multiple  `Show` components
4. Add reference link above  `encodeSvg` function

* fix:replace optional attributes with non-null assertions

Co-authored-by: kunish <17328586+kunish@users.noreply.github.com>
Signed-off-by: Michelle Rodriguez <2316892579@qq.com>

---------

Signed-off-by: Michelle Rodriguez <2316892579@qq.com>
Co-authored-by: kunish <17328586+kunish@users.noreply.github.com>
This commit is contained in:
Michelle Rodriguez 2024-11-23 20:53:28 +08:00 committed by GitHub
parent 676a458961
commit 29ed55cf50
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -92,7 +92,26 @@ export default () => {
e.stopPropagation() e.stopPropagation()
void proxyGroupLatencyTest(groupName) void proxyGroupLatencyTest(groupName)
} }
/**
* transform an SVG into a data URI
* @see https://gist.github.com/jennyknuth/222825e315d45a738ed9d6e04c7a88d0
*/
const encodeSvg = (svg: string) => {
return svg
.replace(
'<svg',
~svg.indexOf('xmlns')
? '<svg'
: '<svg xmlns="http://www.w3.org/2000/svg"',
)
.replace(/"/g, "'")
.replace(/%/g, '%25')
.replace(/#/g, '%23')
.replace(/\{/g, '%7B')
.replace(/\}/g, '%7D')
.replace(/</g, '%3C')
.replace(/>/g, '%3E')
}
const onProxyProviderLatencyTestClick = ( const onProxyProviderLatencyTestClick = (
e: MouseEvent, e: MouseEvent,
providerName: string, providerName: string,
@ -193,13 +212,33 @@ export default () => {
<div class="flex items-center justify-between pr-8"> <div class="flex items-center justify-between pr-8">
<div class="flex items-center"> <div class="flex items-center">
<Show when={proxyGroup.icon}> <Show when={proxyGroup.icon}>
<img <Show
src={proxyGroup.icon} when={proxyGroup.icon!.startsWith(
style={{ 'data:image/svg+xml',
height: `${iconHeight()}px`, )}
'margin-right': `${iconMarginRight()}px`, fallback={
}} <img
/> src={proxyGroup.icon}
style={{
height: `${iconHeight()}px`,
'margin-right': `${iconMarginRight()}px`,
}}
/>
}
>
<div
style={{
height: `${iconHeight()}px`,
width: `${iconHeight()}px`,
color:
'oklch(var(--p) / var(--tw-bg-opacity))',
'background-color': 'currentColor',
'margin-right': `${iconMarginRight()}px`,
'mask-image': `url("${encodeSvg(proxyGroup.icon!)}")`,
'mask-size': '100% 100%',
}}
/>
</Show>
</Show> </Show>
<span>{proxyGroup.name}</span> <span>{proxyGroup.name}</span>
<div class="badge badge-sm ml-2"> <div class="badge badge-sm ml-2">