mirror of
https://github.com/urbit/shrub.git
synced 2025-01-02 01:25:55 +03:00
chat: refactor for new sidebar
This commit is contained in:
parent
4c5bffaef0
commit
62e2dc6cb0
108
pkg/interface/src/views/apps/chat/ChatResource.tsx
Normal file
108
pkg/interface/src/views/apps/chat/ChatResource.tsx
Normal file
@ -0,0 +1,108 @@
|
||||
import React from "react";
|
||||
import { RouteComponentProps } from "react-router-dom";
|
||||
import { Col } from "@tlon/indigo-react";
|
||||
|
||||
import { Association } from "~/types/metadata-update";
|
||||
import { StoreState } from "~/logic/store/type";
|
||||
import { ChatScreen } from "./components/chat";
|
||||
import { ChatWindow } from "./components/lib/chat-window";
|
||||
import { ChatHeader } from "./components/lib/chat-header";
|
||||
import { ChatInput } from "./components/lib/chat-input";
|
||||
import GlobalApi from "~/logic/api/global";
|
||||
import { deSig } from "~/logic/lib/util";
|
||||
|
||||
type ChatResourceProps = StoreState & {
|
||||
association: Association;
|
||||
api: GlobalApi;
|
||||
baseUrl: string;
|
||||
} & RouteComponentProps;
|
||||
|
||||
export function ChatResource(props: ChatResourceProps) {
|
||||
const station = props.association["app-path"];
|
||||
if (!props.chatInitialized) {
|
||||
return null;
|
||||
}
|
||||
|
||||
const { envelopes, config } = props.inbox[station];
|
||||
const { read, length } = config;
|
||||
|
||||
const groupPath = props.association["group-path"];
|
||||
const group = props.groups[groupPath] || groupBunts.group();
|
||||
const contacts = props.contacts[groupPath];
|
||||
|
||||
const pendingMessages = (props.pendingMessages.get(props.station) || []).map(
|
||||
(value) => ({
|
||||
...value,
|
||||
pending: true,
|
||||
})
|
||||
);
|
||||
|
||||
const isChatMissing =
|
||||
props.chatInitialized &&
|
||||
!(station in props.inbox) &&
|
||||
props.chatSynced &&
|
||||
!(station in props.chatSynced);
|
||||
|
||||
const isChatLoading =
|
||||
props.chatInitialized &&
|
||||
!(station in props.inbox) &&
|
||||
props.chatSynced &&
|
||||
station in props.chatSynced;
|
||||
|
||||
const isChatUnsynced =
|
||||
props.chatSynced && !(station in props.chatSynced) && envelopes.length > 0;
|
||||
|
||||
const unreadCount = length - read;
|
||||
const unreadMsg = unreadCount > 0 && envelopes[unreadCount - 1];
|
||||
|
||||
|
||||
|
||||
const roomContacts = contacts[groupPath] || {};
|
||||
|
||||
const popout = props.match.url.includes("/popout/");
|
||||
const [, owner, name] = station.split("/");
|
||||
const ownerContact = contacts?.[deSig(owner)];
|
||||
const lastMsgNum = 0;
|
||||
|
||||
return (
|
||||
<Col overflow="hidden" position="relative">
|
||||
<ChatWindow
|
||||
history={props.history}
|
||||
isChatMissing={isChatMissing}
|
||||
isChatLoading={isChatLoading}
|
||||
isChatUnsynced={isChatUnsynced}
|
||||
unreadCount={unreadCount}
|
||||
unreadMsg={unreadMsg}
|
||||
pendingMessages={pendingMessages}
|
||||
messages={envelopes}
|
||||
length={length}
|
||||
contacts={roomContacts}
|
||||
association={props.association}
|
||||
group={group}
|
||||
ship={owner}
|
||||
station={station}
|
||||
api={props.api}
|
||||
hideNicknames={props.hideNicknames}
|
||||
hideAvatars={props.hideAvatars}
|
||||
/>
|
||||
<ChatInput
|
||||
api={props.api}
|
||||
numMsgs={lastMsgNum}
|
||||
station={station}
|
||||
owner={deSig(owner)}
|
||||
ownerContact={ownerContact}
|
||||
envelopes={envelopes}
|
||||
contacts={roomContacts}
|
||||
onUnmount={(msg: string) => {
|
||||
/*this.setState({
|
||||
messages: this.state.messages.set(props.station, msg),
|
||||
}) */
|
||||
}}
|
||||
s3={props.s3}
|
||||
placeholder="Message..."
|
||||
message={"" || ""}
|
||||
deleteMessage={() => {}}
|
||||
/>
|
||||
</Col>
|
||||
);
|
||||
}
|
@ -136,7 +136,7 @@ export class ChatScreen extends Component<ChatScreenProps, ChatScreenState> {
|
||||
api={props.api}
|
||||
numMsgs={lastMsgNum}
|
||||
station={props.station}
|
||||
owner={deSig(props.match.params.ship)}
|
||||
owner={deSig(props.match.params.ship || "")}
|
||||
ownerContact={ownerContact}
|
||||
envelopes={props.envelopes}
|
||||
contacts={props.contacts}
|
||||
|
Loading…
Reference in New Issue
Block a user