Files
outline/app/scenes/Document/components/MarkAsViewed.js

37 lines
681 B
JavaScript

// @flow
import * as React from "react";
import Document from "models/Document";
const MARK_AS_VIEWED_AFTER = 3 * 1000;
type Props = {|
document: Document,
children?: React.Node,
|};
class MarkAsViewed extends React.Component<Props> {
viewTimeout: TimeoutID;
componentDidMount() {
const { document } = this.props;
this.viewTimeout = setTimeout(async () => {
const view = await document.view();
if (view) {
document.updateLastViewed(view);
}
}, MARK_AS_VIEWED_AFTER);
}
componentWillUnmount() {
clearTimeout(this.viewTimeout);
}
render() {
return this.props.children || null;
}
}
export default MarkAsViewed;