From: Dessalines Date: Mon, 15 Nov 2021 18:13:36 +0000 (-0500) Subject: Fixing nav-link X-Git-Url: http://these/git/readmes/%24%7B%60data:application/README.md?a=commitdiff_plain;h=b4837add6e0d8394508ea34c50e317540dc0ae6e;p=lemmy-ui.git Fixing nav-link --- b4837add6e0d8394508ea34c50e317540dc0ae6e diff --cc src/shared/components/app/footer.tsx index de70ac5,d447cc3..d4edd78 --- a/src/shared/components/app/footer.tsx +++ b/src/shared/components/app/footer.tsx @@@ -1,9 -1,8 +1,9 @@@ import { Component } from "inferno"; - import { Link } from "inferno-router"; + import { NavLink } from "inferno-router"; -import { i18n } from "../i18next"; -import { repoUrl, joinLemmyUrl, docsUrl } from "../utils"; import { GetSiteResponse } from "lemmy-js-client"; +import { i18n } from "../../i18next"; +import { docsUrl, joinLemmyUrl, repoUrl } from "../../utils"; +import { VERSION } from "../../version"; interface FooterProps { site: GetSiteResponse; @@@ -19,18 -18,13 +19,18 @@@ export class Footer extends Component
+ + ) : ( + + )} +
+ + + ); + } + + handleToggleExpandNavbar(i: Navbar) { + i.state.expanded = !i.state.expanded; + i.setState(i.state); + } + + handleHideExpandNavbar(i: Navbar) { + i.setState({ expanded: false, showDropdown: false }); + } + + handleSearchParam(i: Navbar, event: any) { + i.state.searchParam = event.target.value; + i.setState(i.state); + } + + handleSearchSubmit(i: Navbar, event: any) { + event.preventDefault(); + i.updateUrl(); + } + + handleSearchBtn(i: Navbar, event: any) { + event.preventDefault(); + i.setState({ toggleSearch: true }); + + i.searchTextField.current.focus(); + const offsetWidth = i.searchTextField.current.offsetWidth; + if (i.state.searchParam && offsetWidth > 100) { + i.updateUrl(); + } + } + + handleSearchBlur(i: Navbar, event: any) { + if (!(event.relatedTarget && event.relatedTarget.name !== "search-btn")) { + i.state.toggleSearch = false; + i.setState(i.state); + } + } + + handleLogoutClick(i: Navbar) { + i.setState({ showDropdown: false, expanded: false }); + UserService.Instance.logout(); + window.location.href = "/"; + location.reload(); + } + + handleToggleDropdown(i: Navbar) { + i.state.showDropdown = !i.state.showDropdown; + i.setState(i.state); + } + + parseMessage(msg: any) { + let op = wsUserOp(msg); + console.log(msg); + if (msg.error) { + if (msg.error == "not_logged_in") { + UserService.Instance.logout(); + location.reload(); + } + return; + } else if (msg.reconnect) { + console.log(i18n.t("websocket_reconnected")); + WebSocketService.Instance.send( + wsClient.userJoin({ + auth: authField(), + }) + ); + this.fetchUnreads(); + } else if (op == UserOperation.GetUnreadCount) { + let data = wsJsonToRes(msg).data; + this.state.unreadInboxCount = + data.replies + data.mentions + data.private_messages; + this.setState(this.state); + this.sendUnreadCount(); + } else if (op == UserOperation.GetReportCount) { + let data = wsJsonToRes(msg).data; + this.state.unreadReportCount = data.post_reports + data.comment_reports; + this.setState(this.state); + this.sendReportUnread(); + } else if (op == UserOperation.GetSite) { + // This is only called on a successful login + let data = wsJsonToRes(msg).data; + console.log(data.my_user); + UserService.Instance.myUserInfo = data.my_user; + setTheme( + UserService.Instance.myUserInfo.local_user_view.local_user.theme + ); + i18n.changeLanguage(getLanguage()); + this.state.isLoggedIn = true; + this.setState(this.state); + } else if (op == UserOperation.CreateComment) { + let data = wsJsonToRes(msg).data; + + if (this.state.isLoggedIn) { + if ( + data.recipient_ids.includes( + UserService.Instance.myUserInfo.local_user_view.local_user.id + ) + ) { + this.state.unreadInboxCount++; + this.setState(this.state); + this.sendUnreadCount(); + notifyComment(data.comment_view, this.context.router); + } + } + } else if (op == UserOperation.CreatePrivateMessage) { + let data = wsJsonToRes(msg).data; + + if (this.state.isLoggedIn) { + if ( + data.private_message_view.recipient.id == + UserService.Instance.myUserInfo.local_user_view.person.id + ) { + this.state.unreadInboxCount++; + this.setState(this.state); + this.sendUnreadCount(); + notifyPrivateMessage(data.private_message_view, this.context.router); + } + } + } + } + + fetchUnreads() { + console.log("Fetching inbox unreads..."); + + let unreadForm: GetUnreadCount = { + auth: authField(), + }; + + WebSocketService.Instance.send(wsClient.getUnreadCount(unreadForm)); + + console.log("Fetching reports..."); + + let reportCountForm: GetReportCount = { + auth: authField(), + }; + + WebSocketService.Instance.send(wsClient.getReportCount(reportCountForm)); + } + + get currentLocation() { + return this.context.router.history.location.pathname; + } + + sendUnreadCount() { + UserService.Instance.unreadInboxCountSub.next(this.state.unreadInboxCount); + } + + sendReportUnread() { + UserService.Instance.unreadReportCountSub.next( + this.state.unreadReportCount + ); + } + + get canAdmin(): boolean { + return ( + UserService.Instance.myUserInfo && + this.props.site_res.admins + .map(a => a.person.id) + .includes(UserService.Instance.myUserInfo.local_user_view.person.id) + ); + } + + get canCreateCommunity(): boolean { + let adminOnly = + this.props.site_res.site_view?.site.community_creation_admin_only; + return !adminOnly || this.canAdmin; + } + + /// Listens for some websocket errors + websocketEvents() { + let msg = i18n.t("websocket_disconnected"); + WebSocketService.Instance.closeEventListener(() => { + console.error(msg); + }); + } + + requestNotificationPermission() { + if (UserService.Instance.myUserInfo) { + document.addEventListener("DOMContentLoaded", function () { + if (!Notification) { + toast(i18n.t("notifications_error"), "danger"); + return; + } + + if (Notification.permission !== "granted") + Notification.requestPermission(); + }); + } + } +}