You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

126 lines
22 KiB

import React from "react";
import moment from "moment";
import { Link } from "react-router-dom";
export const sourceLink = (story) => {
const url = story.url || story.link;
const urlObj = new URL(url);
const host = urlObj.hostname.replace(/^www\./, "");
return (
<a className="source" href={url}>
{host}
</a>
);
};
export const storyScore = story => {
if (!story.score) {
return null;
}
return (<>{story.score} points</>);
};
export const storyAuthor = story => {
if (!story.author) {
return null;
}
if (story.author_link) {
return (<>by <a href={story.author_link}>{story.author}</a></>);
}
return <>by {story.author}</>;
};
export const storyCommentsLink = story => {
if (!story.num_comments) {
return null;
}
return (<Link
className={story.num_comments > 99 ? "hot" : ""}
to={"/" + story.id + "/c"}>
{story.num_comments} comment{story.num_comments !== 1 && "s"}
</Link>);
};
export const infoLine = (story) => (
<div className="info">
{[
<>{moment.unix(story.date).fromNow()} {storyAuthor(story)}</>,
<><a href={story.link}>{story.source}</a></>,
storyScore(story),/*&#8203;*/
storyCommentsLink(story)
].filter(e => e).map((e, i) => (
<>
{i !== 0 ? <> &bull; </> : <></>}
{e}
</>
))}
</div>
);
export const otherDiscussions = (related) => {
const stories = related.filter(r => r.num_comments > 0);
if (!stories.length) {
return null;
}
return (
<div className='related indented info'>
<span>Other discussions: </span>
{stories.map((story, i) =>
<span id={story.id}>
{i !== 0 ? <> &bull; </> : <></>}
<Link className={story.num_comments > 99 ? "hot" : ""} to={"/" + story.id + "/c"}>
{story.source} ({story.num_comments} comment{story.num_comments !== 1 && "s"})
</Link>
</span>
)}
</div>
);
}
export class ToggleDot extends React.Component {
render() {
const id = this.props.id;
const article = this.props.article;
return (
<div className="toggleDot">
<div className="button">
<Link to={"/" + id + (article ? "" : "/c")}>
{article ? "" : ""}
</Link>
</div>
</div>
);
}
}
export class ForwardDot extends React.Component {
goForward() {
localStorage.setItem("scrollLock", "True");
window.history.forward();
}
render() {
const isMobile = /iPhone|iPad|iPod|Android/i.test(navigator.userAgent);
if (!isMobile) return null;
return (
<div className="forwardDot" onClick={this.goForward}>
<div className="button"></div>
</div>
);
}
}
export const logos = {
hackernews: '',
reddit: '',
tildes: '',
lobsters: '',
manual: '',
substack: "",
"the bulletin": "",
webworm: "",
};
export const getLogoUrl = (story) => {
return logos[story.source] || logos[story.source.split(' ')[0]] || story.icon;
}