Merge pull request #664 from Snekussaurier/feature-565

Add ability to use custom logo
This commit is contained in:
shamoon 2022-12-11 11:01:54 -08:00 committed by GitHub
commit 4f38c0ee80
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 58 additions and 52 deletions

View File

@ -1,9 +1,9 @@
import Image from "next/future/image"; import Image from "next/future/image";
export default function ResolvedIcon({ icon }) { export default function ResolvedIcon({ icon, width = 32, height = 32 }) {
// direct or relative URLs // direct or relative URLs
if (icon.startsWith("http") || icon.startsWith("/")) { if (icon.startsWith("http") || icon.startsWith("/")) {
return <Image src={`${icon}`} width={32} height={32} alt="logo" />; return <Image src={`${icon}`} width={width} height={height} alt="logo" />;
} }
// mdi- prefixed, material design icons // mdi- prefixed, material design icons
@ -12,8 +12,8 @@ export default function ResolvedIcon({ icon }) {
return ( return (
<div <div
style={{ style={{
width: 32, width,
height: 32, height,
maxWidth: '100%', maxWidth: '100%',
maxHeight: '100%', maxHeight: '100%',
background: "linear-gradient(180deg, rgb(var(--color-logo-start)), rgb(var(--color-logo-stop)))", background: "linear-gradient(180deg, rgb(var(--color-logo-start)), rgb(var(--color-logo-stop)))",
@ -29,8 +29,8 @@ export default function ResolvedIcon({ icon }) {
return ( return (
<Image <Image
src={`https://cdn.jsdelivr.net/gh/walkxcode/dashboard-icons/png/${iconName}.png`} src={`https://cdn.jsdelivr.net/gh/walkxcode/dashboard-icons/png/${iconName}.png`}
width={32} width={width}
height={32} height={height}
alt="logo" alt="logo"
/> />
); );

View File

@ -1,56 +1,62 @@
export default function Logo() { import ResolvedIcon from "components/resolvedicon"
export default function Logo({ options }) {
return ( return (
<div className="w-12 h-12 flex flex-row items-center align-middle mr-3 self-center"> <div className="w-12 h-12 flex flex-row items-center align-middle mr-3 self-center">
<svg {options.icon ?
xmlns="http://www.w3.org/2000/svg" <ResolvedIcon icon={options.icon} width={48} height={48} /> :
viewBox="0 0 1024 1024" // fallback to homepage logo
style={{ <svg
enableBackground: "new 0 0 1024 1024", xmlns="http://www.w3.org/2000/svg"
}} viewBox="0 0 1024 1024"
xmlSpace="preserve" style={{
className="w-full h-full" enableBackground: "new 0 0 1024 1024",
> }}
<style> xmlSpace="preserve"
{ className="w-full h-full"
".st0{display:none}.st3{stroke-linecap:square}.st3,.st4{fill:none;stroke:#fff;stroke-miterlimit:10}.st6{display:inline;fill:#333}.st7{fill:#fff}" >
} <style>
</style> {
<g id="Icon"> ".st0{display:none}.st3{stroke-linecap:square}.st3,.st4{fill:none;stroke:#fff;stroke-miterlimit:10}.st6{display:inline;fill:#333}.st7{fill:#fff}"
<path }
d="M771.9 191c27.7 0 50.1 26.5 50.1 59.3v186.4l-100.2.3V250.3c0-32.8 22.4-59.3 50.1-59.3z" </style>
style={{ <g id="Icon">
fill: "rgba(var(--color-logo-start))", <path
}} d="M771.9 191c27.7 0 50.1 26.5 50.1 59.3v186.4l-100.2.3V250.3c0-32.8 22.4-59.3 50.1-59.3z"
/>
<linearGradient
id="homepage_logo_gradient"
gradientUnits="userSpaceOnUse"
x1={200.746}
y1={225.015}
x2={764.986}
y2={789.255}
>
<stop
offset={0}
style={{ style={{
stopColor: "rgba(var(--color-logo-start))", fill: "rgba(var(--color-logo-start))",
}} }}
/> />
<stop <linearGradient
offset={1} id="homepage_logo_gradient"
gradientUnits="userSpaceOnUse"
x1={200.746}
y1={225.015}
x2={764.986}
y2={789.255}
>
<stop
offset={0}
style={{
stopColor: "rgba(var(--color-logo-start))",
}}
/>
<stop
offset={1}
style={{
stopColor: "rgba(var(--color-logo-stop))",
}}
/>
</linearGradient>
<path
d="M721.8 250.3c0-32.7 22.4-59.3 50.1-59.3H253.1c-27.7 0-50.1 26.5-50.1 59.3v582.2l90.2-75.7-.1-130.3H375v61.8l88-73.8 258.8 217.9V250.6"
style={{ style={{
stopColor: "rgba(var(--color-logo-stop))", fill: "url(#homepage_logo_gradient)",
}} }}
/> />
</linearGradient> </g>
<path </svg>
d="M721.8 250.3c0-32.7 22.4-59.3 50.1-59.3H253.1c-27.7 0-50.1 26.5-50.1 59.3v582.2l90.2-75.7-.1-130.3H375v61.8l88-73.8 258.8 217.9V250.6" }
style={{
fill: "url(#homepage_logo_gradient)",
}}
/>
</g>
</svg>
</div> </div>
); )
} }