Skip to content

Commit

Permalink
Restore simplified mobile support
Browse files Browse the repository at this point in the history
  • Loading branch information
arnautov-anton committed Oct 1, 2024
1 parent 08e38e5 commit e88d5a2
Show file tree
Hide file tree
Showing 2 changed files with 69 additions and 85 deletions.
147 changes: 63 additions & 84 deletions examples/vite/src/index.scss
Original file line number Diff line number Diff line change
Expand Up @@ -12,112 +12,91 @@ body,
height: 100%;
}

#root {
display: flex;
height: 100%;

& > div.str-chat {
height: 100%;
width: 100%;
display: flex;
}

.str-chat__channel-list {
position: fixed;
z-index: 1;
height: 100%;
width: 0;
flex-shrink: 0;
box-shadow: 0 0 8px rgba(0, 0, 0, 0.15);

&--open {
.str-chat__chat-view {
.str-chat__chat-view__channels {
.str-chat__channel {
width: 100%;
}
.str-chat__channel-list {
width: 350px;
min-width: 350px;
}
.str-chat__thread {
min-width: 350px;
width: 30%;
position: fixed;
}
transition: width 0.3s ease-out;
}

.str-chat__channel {
flex: 1;
min-width: 0;
}

.str-chat__main-panel {
min-width: 0;
flex: 1;

&--thread-open {
display: none;
.str-chat__chat-view__threads {
.str-chat__thread-list-container {
width: 350px;
min-width: 350px;
}
}

.str-chat__thread {
flex: 1;
height: 100%;
position: absolute;
z-index: 1;
.str-chat__channel {
width: 100%;
}
}
}

.str-chat__channel-header .str-chat__header-hamburger {
width: 30px;
height: 38px;
padding: var(--xxs-p);
margin-right: var(--xs-m);
@media screen and (max-width: 1024px) {
.str-chat__chat-view {
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
border: none;
background: transparent;
flex-direction: column-reverse;

.str-chat__chat-view__selector {
border-right: none;
border-top: 1px solid var(--str-chat-selector-border-color);
flex-direction: row;
justify-content: center;
padding-block: 8px;
}

.str-chat__chat-view__channels {
position: relative;

&:hover {
svg path {
fill: var(--primary-color);
.str-chat__channel-header .str-chat__header-hamburger {
background-color: unset;
margin: unset;
border: unset;
padding-inline: 8px;
display: flex;
color: var(--str-chat__text-low-emphasis-color);
& > svg {
width: 25px;
}
}
}
}

@media screen and (min-width: 768px) {
.str-chat__channel-list {
width: 30%;
position: initial;
z-index: 0;
}
.str-chat__channel-list {
display: none;
}

.str-chat__chat-view__channels {
.str-chat__thread {
position: initial;
z-index: 0;
position: absolute;
width: 100%;
}
}

.str-chat__channel-header .str-chat__header-hamburger {
display: none;
.str-chat__channel-list.str-chat__channel-list--open {
position: absolute;
width: 100%;
display: block;
z-index: 1;
}
}
}

@media screen and (min-width: 1024px) {
.str-chat__main-panel {
min-width: 0;
.str-chat__chat-view__threads {
position: relative;

&--thread-open {
max-width: 55%;
display: flex;
.str-chat__thread-list-container:has(~ .str-chat__channel .str-chat__container:empty) {
position: absolute;
height: 100%;
width: 100%;
z-index: 1;
}
}

.str-chat__chat-view__channels {
.str-chat__thread {
max-width: 45%;
.str-chat__thread-list-container:has(~ .str-chat__channel .str-chat__container:not(:empty)) {
display: none;
}
}

.str-chat__channel-header .str-chat__header-hamburger {
display: none;
}
}

.str-chat__thread-list-container {
max-width: 350px;
}
}
7 changes: 6 additions & 1 deletion src/components/Thread/Thread.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ import {
} from '../../context';
import { useThreadContext } from '../Threads';
import { useStateStore } from '../../store';
import { useThreadsViewContext } from '../ChatView';

import type { MessageProps, MessageUIComponentProps } from '../Message/types';
import type { MessageActionsArray } from '../Message/utils';
Expand Down Expand Up @@ -113,6 +114,7 @@ const ThreadInner = <
threadSuppressAutoscroll,
} = useChannelStateContext<StreamChatGenerics>('Thread');
const { closeThread, loadMoreThread } = useChannelActionContext<StreamChatGenerics>('Thread');
const { setActiveThread } = useThreadsViewContext();
const { customClasses } = useChatContext<StreamChatGenerics>('Thread');
const {
ThreadInput: ContextInput,
Expand Down Expand Up @@ -184,7 +186,10 @@ const ThreadInner = <

return (
<div className={threadClass}>
<ThreadHeader closeThread={closeThread} thread={messageAsThread} />
<ThreadHeader
closeThread={threadInstance ? () => setActiveThread(undefined) : closeThread}
thread={messageAsThread}
/>
<ThreadMessageList
disableDateSeparator={!enableDateSeparator}
head={head}
Expand Down

0 comments on commit e88d5a2

Please sign in to comment.