Compare commits
No commits in common. "08d02f6013dd04234343f4a9c12810400dd90d91" and "9e9571a3c0605cb2c055c255c0bb23d5b46a77b3" have entirely different histories.
08d02f6013
...
9e9571a3c0
|
@ -3,9 +3,8 @@ import { BrowserRouter as Router, Route, Link, Switch } from 'react-router-dom';
|
||||||
import localForage from 'localforage';
|
import localForage from 'localforage';
|
||||||
import './Style-light.css';
|
import './Style-light.css';
|
||||||
import './Style-dark.css';
|
import './Style-dark.css';
|
||||||
import './Style-red.css';
|
|
||||||
import './fonts/Fonts.css';
|
import './fonts/Fonts.css';
|
||||||
import { BackwardDot, ForwardDot } from './utils.js';
|
import { ForwardDot } from './utils.js';
|
||||||
import Feed from './Feed.js';
|
import Feed from './Feed.js';
|
||||||
import Article from './Article.js';
|
import Article from './Article.js';
|
||||||
import Comments from './Comments.js';
|
import Comments from './Comments.js';
|
||||||
|
@ -39,11 +38,6 @@ class App extends React.Component {
|
||||||
localStorage.setItem('theme', 'dark');
|
localStorage.setItem('theme', 'dark');
|
||||||
}
|
}
|
||||||
|
|
||||||
red() {
|
|
||||||
this.setState({ theme: 'red' });
|
|
||||||
localStorage.setItem('theme', 'red');
|
|
||||||
}
|
|
||||||
|
|
||||||
componentDidMount() {
|
componentDidMount() {
|
||||||
if (!this.cache.length) {
|
if (!this.cache.length) {
|
||||||
localForage.iterate((value, key) => {
|
localForage.iterate((value, key) => {
|
||||||
|
@ -53,26 +47,9 @@ class App extends React.Component {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
goFullScreen() {
|
|
||||||
if ('wakeLock' in navigator) {
|
|
||||||
navigator.wakeLock.request('screen');
|
|
||||||
}
|
|
||||||
|
|
||||||
document.body.requestFullscreen({ navigationUI: 'hide' }).then(() => {
|
|
||||||
window.addEventListener('resize', () => this.forceUpdate());
|
|
||||||
this.forceUpdate();
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
exitFullScreen() {
|
|
||||||
document.exitFullscreen().then(() => {
|
|
||||||
this.forceUpdate();
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
const theme = this.state.theme;
|
const theme = this.state.theme;
|
||||||
document.body.style.backgroundColor = theme ? '#000' : '#eeeeee';
|
document.body.style.backgroundColor = theme === 'dark' ? '#000' : '#eeeeee';
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className={theme}>
|
<div className={theme}>
|
||||||
|
@ -81,17 +58,12 @@ class App extends React.Component {
|
||||||
<p>
|
<p>
|
||||||
<Link to='/'>QotNews</Link>
|
<Link to='/'>QotNews</Link>
|
||||||
|
|
||||||
<span className='theme'><a href='#' onClick={() => this.light()}>Light</a> - <a href='#' onClick={() => this.dark()}>Dark</a> - <a href='#' onClick={() => this.red()}>Red</a></span>
|
<span className='theme'><a href='#' onClick={() => this.light()}>Light</a> - <a href='#' onClick={() => this.dark()}>Dark</a></span>
|
||||||
<br />
|
<br />
|
||||||
<span className='slogan'>Hacker News, Reddit, Lobsters, and Tildes articles rendered in reader mode.</span>
|
<span className='slogan'>Hacker News, Reddit, Lobsters, and Tildes articles rendered in reader mode.</span>
|
||||||
</p>
|
</p>
|
||||||
<Route path='/(|search)' component={Search} />
|
<Route path='/(|search)' component={Search} />
|
||||||
<Route path='/(|search)' component={Submit} />
|
<Route path='/(|search)' component={Submit} />
|
||||||
<Route path='/(|search)' render={() => !document.fullscreenElement ?
|
|
||||||
<button className='fullscreen' onClick={() => this.goFullScreen()}>Enter Fullscreen</button>
|
|
||||||
:
|
|
||||||
<button className='fullscreen' onClick={() => this.exitFullScreen()}>Exit Fullscreen</button>
|
|
||||||
} />
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<Route path='/' exact render={(props) => <Feed {...props} updateCache={this.updateCache} />} />
|
<Route path='/' exact render={(props) => <Feed {...props} updateCache={this.updateCache} />} />
|
||||||
|
@ -101,7 +73,6 @@ class App extends React.Component {
|
||||||
</Switch>
|
</Switch>
|
||||||
<Route path='/:id/c' exact render={(props) => <Comments {...props} cache={this.cache} />} />
|
<Route path='/:id/c' exact render={(props) => <Comments {...props} cache={this.cache} />} />
|
||||||
|
|
||||||
<BackwardDot />
|
|
||||||
<ForwardDot />
|
<ForwardDot />
|
||||||
|
|
||||||
<ScrollToTop />
|
<ScrollToTop />
|
||||||
|
|
|
@ -15,7 +15,6 @@ class ScrollToTop extends React.Component {
|
||||||
}
|
}
|
||||||
|
|
||||||
window.scrollTo(0, 0);
|
window.scrollTo(0, 0);
|
||||||
document.body.scrollTop = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
|
|
|
@ -2,30 +2,9 @@ body {
|
||||||
text-rendering: optimizeLegibility;
|
text-rendering: optimizeLegibility;
|
||||||
font: 1rem/1.3 sans-serif;
|
font: 1rem/1.3 sans-serif;
|
||||||
color: #000000;
|
color: #000000;
|
||||||
|
margin-bottom: 100vh;
|
||||||
word-break: break-word;
|
word-break: break-word;
|
||||||
font-kerning: normal;
|
font-kerning: normal;
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
::backdrop {
|
|
||||||
background-color: rgba(0,0,0,0);
|
|
||||||
}
|
|
||||||
|
|
||||||
body:fullscreen {
|
|
||||||
overflow-y: scroll !important;
|
|
||||||
}
|
|
||||||
body:-ms-fullscreen {
|
|
||||||
overflow-y: scroll !important;
|
|
||||||
}
|
|
||||||
body:-webkit-full-screen {
|
|
||||||
overflow-y: scroll !important;
|
|
||||||
}
|
|
||||||
body:-moz-full-screen {
|
|
||||||
overflow-y: scroll !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
#root {
|
|
||||||
margin: 8px 8px 100vh 8px !important;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
a {
|
a {
|
||||||
|
@ -43,12 +22,6 @@ input {
|
||||||
border-radius: 4px;
|
border-radius: 4px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.fullscreen {
|
|
||||||
margin: 0.25rem;
|
|
||||||
padding: 0.25rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
pre {
|
pre {
|
||||||
overflow: auto;
|
overflow: auto;
|
||||||
}
|
}
|
||||||
|
@ -212,20 +185,16 @@ span.source {
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
|
|
||||||
.dot {
|
.toggleDot {
|
||||||
cursor: pointer;
|
|
||||||
position: fixed;
|
position: fixed;
|
||||||
|
bottom: 1rem;
|
||||||
|
left: 1rem;
|
||||||
height: 3rem;
|
height: 3rem;
|
||||||
width: 3rem;
|
width: 3rem;
|
||||||
background-color: #828282;
|
background-color: #828282;
|
||||||
border-radius: 50%;
|
border-radius: 50%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.toggleDot {
|
|
||||||
bottom: 1rem;
|
|
||||||
left: 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.toggleDot .button {
|
.toggleDot .button {
|
||||||
font: 2rem/1 'icomoon';
|
font: 2rem/1 'icomoon';
|
||||||
position: relative;
|
position: relative;
|
||||||
|
@ -234,27 +203,21 @@ span.source {
|
||||||
}
|
}
|
||||||
|
|
||||||
.forwardDot {
|
.forwardDot {
|
||||||
|
cursor: pointer;
|
||||||
|
position: fixed;
|
||||||
bottom: 1rem;
|
bottom: 1rem;
|
||||||
right: 1rem;
|
right: 1rem;
|
||||||
|
height: 3rem;
|
||||||
|
width: 3rem;
|
||||||
|
background-color: #828282;
|
||||||
|
border-radius: 50%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.forwardDot .button {
|
.forwardDot .button {
|
||||||
font: 2rem/1 'icomoon';
|
font: 2.5rem/1 'icomoon';
|
||||||
position: relative;
|
position: relative;
|
||||||
top: 0.5rem;
|
top: 0.25rem;
|
||||||
left: 0.5rem;
|
left: 0.3rem;
|
||||||
}
|
|
||||||
|
|
||||||
.backwardDot {
|
|
||||||
bottom: 1rem;
|
|
||||||
right: 5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.backwardDot .button {
|
|
||||||
font: 2rem/1 'icomoon';
|
|
||||||
position: relative;
|
|
||||||
top: 0.5rem;
|
|
||||||
left: 0.5rem;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.search form {
|
.search form {
|
||||||
|
|
|
@ -1,81 +0,0 @@
|
||||||
.red {
|
|
||||||
color: #b00;
|
|
||||||
scrollbar-color: #b00 #440000;
|
|
||||||
}
|
|
||||||
|
|
||||||
.red a {
|
|
||||||
color: #b00;
|
|
||||||
}
|
|
||||||
|
|
||||||
.red input {
|
|
||||||
color: #b00;
|
|
||||||
border: 1px solid #690000;
|
|
||||||
}
|
|
||||||
|
|
||||||
.red input::placeholder {
|
|
||||||
color: #690000;
|
|
||||||
}
|
|
||||||
|
|
||||||
.red hr {
|
|
||||||
background-color: #690000;
|
|
||||||
}
|
|
||||||
|
|
||||||
.red button {
|
|
||||||
background-color: #440000;
|
|
||||||
border-color: #b00;
|
|
||||||
color: #b00;
|
|
||||||
}
|
|
||||||
|
|
||||||
.red .item,
|
|
||||||
.red .slogan {
|
|
||||||
color: #690000;
|
|
||||||
}
|
|
||||||
|
|
||||||
.red .item .source-logo {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.red .item a {
|
|
||||||
color: #690000;
|
|
||||||
}
|
|
||||||
|
|
||||||
.red .item a.link {
|
|
||||||
color: #b00;
|
|
||||||
}
|
|
||||||
.red .item a.link:visited {
|
|
||||||
color: #690000;
|
|
||||||
}
|
|
||||||
|
|
||||||
.red .item .info a.hot {
|
|
||||||
color: #cc0000;
|
|
||||||
}
|
|
||||||
|
|
||||||
.red .article a {
|
|
||||||
border-bottom: 1px solid #aa0000;
|
|
||||||
}
|
|
||||||
|
|
||||||
.red .article u {
|
|
||||||
border-bottom: 1px solid #aa0000;
|
|
||||||
text-decoration: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.red .story-text img {
|
|
||||||
filter: grayscale(100%) brightness(20%) sepia(100%) hue-rotate(-50deg) saturate(600%) contrast(0.8);
|
|
||||||
}
|
|
||||||
|
|
||||||
.red .article .info {
|
|
||||||
color: #690000;
|
|
||||||
}
|
|
||||||
|
|
||||||
.red .article .info a {
|
|
||||||
border-bottom: none;
|
|
||||||
color: #690000;
|
|
||||||
}
|
|
||||||
|
|
||||||
.red .comment.lined {
|
|
||||||
border-left: 1px solid #440000;
|
|
||||||
}
|
|
||||||
|
|
||||||
.red .dot {
|
|
||||||
background-color: #440000;
|
|
||||||
}
|
|
Binary file not shown.
|
@ -25,9 +25,8 @@ export class ToggleDot extends React.Component {
|
||||||
render() {
|
render() {
|
||||||
const id = this.props.id;
|
const id = this.props.id;
|
||||||
const article = this.props.article;
|
const article = this.props.article;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className='dot toggleDot'>
|
<div className='toggleDot'>
|
||||||
<div className='button'>
|
<div className='button'>
|
||||||
<Link to={'/' + id + (article ? '' : '/c')}>
|
<Link to={'/' + id + (article ? '' : '/c')}>
|
||||||
{article ? '' : ''}
|
{article ? '' : ''}
|
||||||
|
@ -38,27 +37,6 @@ export class ToggleDot extends React.Component {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export class BackwardDot extends React.Component {
|
|
||||||
goBackward() {
|
|
||||||
localStorage.setItem('scrollLock', 'True');
|
|
||||||
window.history.back();
|
|
||||||
}
|
|
||||||
|
|
||||||
render() {
|
|
||||||
const isMobile = /iPhone|iPad|iPod|Android/i.test(navigator.userAgent);
|
|
||||||
if (!isMobile) return null;
|
|
||||||
if (!document.fullscreenElement) return null;
|
|
||||||
|
|
||||||
return (
|
|
||||||
<div className='dot backwardDot' onClick={this.goBackward}>
|
|
||||||
<div className='button'>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export class ForwardDot extends React.Component {
|
export class ForwardDot extends React.Component {
|
||||||
goForward() {
|
goForward() {
|
||||||
localStorage.setItem('scrollLock', 'True');
|
localStorage.setItem('scrollLock', 'True');
|
||||||
|
@ -70,9 +48,9 @@ export class ForwardDot extends React.Component {
|
||||||
if (!isMobile) return null;
|
if (!isMobile) return null;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className='dot forwardDot' onClick={this.goForward}>
|
<div className='forwardDot' onClick={this.goForward}>
|
||||||
<div className='button'>
|
<div className='button'>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
|
Loading…
Reference in New Issue
Block a user