Browse Source

feat(blog): close draw

Signed-off-by: Muthu Kumar <muthukumar@thefeathers.in>
pull/1/head
Muthu Kumar 3 years ago
parent
commit
42587c7d90
Signed by: mkrhere GPG Key ID: 3FD688398897097E
  1. 169
      src/pages/blog/Home.tsx

169
src/pages/blog/Home.tsx

@ -5,6 +5,7 @@ import { Spacer } from "../../components/Spacer";
import { ArticleSubHeader } from "./components/ArticleSubHeader"; import { ArticleSubHeader } from "./components/ArticleSubHeader";
import { BlogPost } from "./components/BlogContent"; import { BlogPost } from "./components/BlogContent";
import { articles, getBlogPath } from "../../data"; import { articles, getBlogPath } from "../../data";
import { ReactComponent as DrawClose } from "../../assets/draw-close.svg";
const Header: React.FC = () => { const Header: React.FC = () => {
return ( return (
@ -78,12 +79,16 @@ const BlogHome: React.FC = () => {
overflow: hidden; overflow: hidden;
@media screen and (max-width: 80rem) { @media screen and (max-width: 80rem) {
div& > .draw-ctl {
display: none;
}
&:not(.article-open) { &:not(.article-open) {
aside { aside {
min-width: 100vw; min-width: 100vw;
} }
main { main {
display: none; max-width: 0;
} }
} }
&:is(.article-open) { &:is(.article-open) {
@ -91,77 +96,126 @@ const BlogHome: React.FC = () => {
display: none; display: none;
} }
main { main {
min-width: 100vw; max-width: 0;
} }
} }
} }
&:is(.aside-closed) { &:is(.aside-closed) {
aside { aside {
display: none; max-width: 0;
} }
} }
& > aside, & > aside,
& > article { & > article {
transition: all 250ms;
@media screen and (max-width: 50rem) { @media screen and (max-width: 50rem) {
padding-block-start: 4rem; padding-block-start: 4rem;
padding-block-end: 6rem; padding-block-end: 6rem;
} }
} }
& > .draw-ctl {
border: none;
padding: 1rem;
padding-block: 10vw;
display: flex;
min-width: 3.6rem;
max-width: 3.6rem;
}
`, `,
)}> )}>
{isArticleOpen ? (
<button
onClick={() => setAsideClosed(closed => !closed)}
className={cx(
"draw-ctl",
css`
transition: background-color 100ms;
background-color: #262626;
&:hover {
background-color: #323232;
}
`,
)}>
<DrawClose
width="2.6rem"
className={cx(
css`
transition: transform 100ms;
`,
{
[css`
transform: rotate(180deg);
`]: isAsideClosed,
},
)}
/>
</button>
) : (
<div className="draw-ctl"></div>
)}
<aside <aside
className={css` className={css`
height: 100%; height: 100%;
width: 100%; width: 100%;
overflow-y: auto;
flex: 2; flex: 2;
display: flex;
flex-direction: column;
gap: 1rem;
padding: 8vw;
max-width: 45rem; max-width: 45rem;
`}> `}>
<Header /> <div
<Spacer y={2} /> className={css`
{articles.map(article => { height: 100%;
const { title, snippet } = article; width: 100%;
const path = getBlogPath(article); overflow-y: auto;
display: flex;
return ( flex-direction: column;
<div key={path}> gap: 1rem;
<Link padding: 8vw;
to={path} min-width: 30rem;
className={css` `}>
display: flex; <Header />
flex-direction: column; <Spacer y={2} />
gap: 0.25rem; {articles.map(article => {
padding: 1rem; const { title, snippet } = article;
border-radius: 0.5rem; const path = getBlogPath(article);
transition: all 300ms;
return (
&:hover { <div key={path}>
background: #262626; <Link
} to={path}
className={css`
& h3 { display: flex;
padding: 0; flex-direction: column;
font-size: 1.4rem; gap: 0.25rem;
} padding: 1rem;
border-radius: 0.5rem;
& * { transition: all 300ms;
line-height: 1.2em;
} &:hover {
`}> background: #262626;
<h3>{title}</h3> }
<ArticleSubHeader article={article} />
<Spacer /> & h3 {
<p>{snippet}</p> padding: 0;
</Link> font-size: 1.4rem;
</div> }
);
})} & * {
line-height: 1.2em;
}
`}>
<h3>{title}</h3>
<ArticleSubHeader article={article} />
<Spacer />
<p>{snippet}</p>
</Link>
</div>
);
})}
</div>
</aside> </aside>
<article <article
className={cx( className={cx(
@ -169,20 +223,27 @@ const BlogHome: React.FC = () => {
css` css`
height: 100%; height: 100%;
width: 100%; width: 100%;
flex: 3;
z-index: 1000;
`,
)}>
<div
className={css`
height: 100%;
width: 100%;
overflow-y: auto; overflow-y: auto;
overflow-x: hidden; overflow-x: hidden;
padding: 8vw; padding: 8vw;
background-color: #262626; background-color: #262626;
flex: 3;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: 1.5rem; gap: 1.5rem;
`, `}>
)}> <Routes>
<Routes> <Route path="/" element={<div></div>} />
<Route path="/" element={<div></div>} /> <Route path="/*" element={<BlogPost />} />
<Route path="/*" element={<BlogPost />} /> </Routes>
</Routes> </div>
</article> </article>
</div> </div>
); );

Loading…
Cancel
Save