mirror of
https://github.com/discourse/discourse.git
synced 2025-02-10 14:30:45 +08:00
72 lines
1.9 KiB
JavaScript
72 lines
1.9 KiB
JavaScript
import { createWidget } from "discourse/widgets/widget";
|
|
import { h } from "virtual-dom";
|
|
import { iconNode } from "discourse-common/lib/icon-library";
|
|
import { wantsNewWindow } from "discourse/lib/intercept-click";
|
|
import DiscourseURL from "discourse/lib/url";
|
|
|
|
export default createWidget("home-logo", {
|
|
tagName: "div.title",
|
|
|
|
settings: {
|
|
href: Discourse.getURL("/")
|
|
},
|
|
|
|
href() {
|
|
const href = this.settings.href;
|
|
return typeof href === "function" ? href() : href;
|
|
},
|
|
|
|
logo() {
|
|
const { siteSettings } = this;
|
|
const mobileView = this.site.mobileView;
|
|
|
|
const mobileLogoUrl = siteSettings.mobile_logo_url || "";
|
|
const showMobileLogo = mobileView && mobileLogoUrl.length > 0;
|
|
|
|
const logoUrl = siteSettings.logo_url || "";
|
|
const title = siteSettings.title;
|
|
|
|
if (!mobileView && this.attrs.minimized) {
|
|
const logoSmallUrl = siteSettings.logo_small_url || "";
|
|
if (logoSmallUrl.length) {
|
|
return h("img#site-logo.logo-small", {
|
|
key: "logo-small",
|
|
attributes: { src: logoSmallUrl, width: 33, height: 33, alt: title }
|
|
});
|
|
} else {
|
|
return iconNode("home");
|
|
}
|
|
} else if (showMobileLogo) {
|
|
return h("img#site-logo.logo-big", {
|
|
key: "logo-mobile",
|
|
attributes: { src: mobileLogoUrl, alt: title }
|
|
});
|
|
} else if (logoUrl.length) {
|
|
return h("img#site-logo.logo-big", {
|
|
key: "logo-big",
|
|
attributes: { src: logoUrl, alt: title }
|
|
});
|
|
} else {
|
|
return h("h1#site-text-logo.text-logo", { key: "logo-text" }, title);
|
|
}
|
|
},
|
|
|
|
html() {
|
|
return h(
|
|
"a",
|
|
{ attributes: { href: this.href(), "data-auto-route": true } },
|
|
this.logo()
|
|
);
|
|
},
|
|
|
|
click(e) {
|
|
if (wantsNewWindow(e)) {
|
|
return false;
|
|
}
|
|
e.preventDefault();
|
|
|
|
DiscourseURL.routeToTag($(e.target).closest("a")[0]);
|
|
return false;
|
|
}
|
|
});
|