From 551f56f4a48b284c70e30876ba16b59695d895dd Mon Sep 17 00:00:00 2001 From: Rowan Hogan Date: Sun, 12 Jul 2020 21:45:33 +1000 Subject: [PATCH] Tabs improvements --- src/components/page/index.js | 22 ++++++++++-------- src/components/tabs/index.js | 44 +++++++++++++++++++++++++----------- src/store/index.js | 2 ++ src/store/pages/index.js | 22 ++++++++++++++++++ src/store/tabs/index.js | 5 ++++ src/styles/_layout.scss | 6 ++++- src/styles/styles.css | 8 +++++-- 7 files changed, 84 insertions(+), 25 deletions(-) create mode 100644 src/store/pages/index.js diff --git a/src/components/page/index.js b/src/components/page/index.js index adc058d..2421a15 100644 --- a/src/components/page/index.js +++ b/src/components/page/index.js @@ -5,6 +5,7 @@ import { withRouter } from 'react-router-dom' import { fetchPage } from '../../lib/api' import { stripTags } from '../../lib/html' import { addTab } from '../../store/tabs' +import { storePage } from '../../store/pages' import Loading from '../loading' import Sections from '../sections' @@ -34,18 +35,21 @@ class Page extends Component { } fetchPage (title) { + const { pages, storePage } = this.props + const pageIsCached = !!pages[title] + this.setState({ loading: true }) - return fetchPage(title) - .then(({ title, content, sections }) => { - document.title = `${stripTags(title)} - Wikipadia` + return Promise.resolve() + .then(() => pageIsCached ? pages[title] : fetchPage(title)) + .then(page => { + document.title = `${title} - Wikipadia` + storePage(title, page) this.setState( { loading: false, - title, - content, - sections + ...page }, () => { const { location: { hash } } = this.props @@ -78,7 +82,7 @@ class Page extends Component { const url = e.target.href.replace(window.location.origin, '') if (tabs.length === 0) { - this.props.addTab(title, `/${encodeURIComponent(title.replace(/ /g, '_'))}`) + this.props.addTab(stripTags(title), `/${encodeURIComponent(stripTags(title).replace(/ /g, '_'))}`) } this.props.addTab(decodeURIComponent(url.split('/')[1].replace(/_/g, ' ')), url) @@ -114,9 +118,9 @@ class Page extends Component { } } -const mapStateToProps = ({ tabs }) => ({ tabs }) +const mapStateToProps = ({ pages, tabs }) => ({ pages, tabs }) export default compose( - connect(mapStateToProps, { addTab }), + connect(mapStateToProps, { addTab, storePage }), withRouter )(Page) diff --git a/src/components/tabs/index.js b/src/components/tabs/index.js index 8b2be06..078f9cf 100644 --- a/src/components/tabs/index.js +++ b/src/components/tabs/index.js @@ -1,36 +1,51 @@ import React, { useState } from 'react' +import { compose } from 'redux' import { connect } from 'react-redux' +import { withRouter } from 'react-router-dom' import { removeTab } from '../../store/tabs' import { Link } from 'react-router-dom' -const Tabs = ({ tabs, removeTab }) => { +const Tabs = ({ tabs, removeTab, history }) => { if (tabs.length) { const [active, setActive] = useState(tabs[0].id) + const handleClick = tab => e => { + window.scrollTo(0, 0) + return setActive(tab.id) + } + + const handleRemove = tab => e => { + e.preventDefault() + + const currentIndex = tabs.indexOf(tab) + const newTab = tabs[currentIndex + 1] || tabs[currentIndex - 1] + + if (newTab) { + setActive(newTab.id) + window.scrollTo(0, 0) + history.push(newTab.path) + } + + return removeTab(tab.id) + } + return (