From 3a82a0cfbf08b0a512b5bad26a8926fffc5dd98c Mon Sep 17 00:00:00 2001 From: leonardosfl Date: Tue, 4 Aug 2020 23:59:21 -0300 Subject: [PATCH 1/7] Fix PDF fallback when the preprint is not in the database --- src/components/extension-fallback.js | 2 ++ src/components/pdf-viewer.js | 4 ++-- src/routes/api-routes.js | 23 ++++++++++++++--------- 3 files changed, 18 insertions(+), 11 deletions(-) diff --git a/src/components/extension-fallback.js b/src/components/extension-fallback.js index 5023fee..e4c3409 100644 --- a/src/components/extension-fallback.js +++ b/src/components/extension-fallback.js @@ -66,6 +66,7 @@ export default function ExtensionFallback() { Loading PDF}> Loading PDF} /> @@ -80,6 +81,7 @@ export default function ExtensionFallback() { Loading PDF}> Loading PDF} /> diff --git a/src/components/pdf-viewer.js b/src/components/pdf-viewer.js index 77b3ac4..37d1a5a 100644 --- a/src/components/pdf-viewer.js +++ b/src/components/pdf-viewer.js @@ -11,7 +11,7 @@ const CSS_MAX_WIDTH = 900; // keep in sync with CSS * This implement an infinite scroll mechanism so that we never load more than a * few pages at the time */ -export default function PdfViewer({ docId, loading }) { +export default function PdfViewer({ docId, pdfUrl, loading }) { const containerEl = useRef(null); const getWidth = () => { const el = containerEl.current; @@ -79,7 +79,7 @@ export default function PdfViewer({ docId, loading }) { { let dims = []; diff --git a/src/routes/api-routes.js b/src/routes/api-routes.js index f308e76..ed0a772 100644 --- a/src/routes/api-routes.js +++ b/src/routes/api-routes.js @@ -375,16 +375,21 @@ router.get( * due to cross origin restriction we need to proxy the PDF */ router.get('/pdf', async (req, res, next) => { - let pdfUrl; - const preprintId = req.query.preprintId; - try { - const body = await req.db.get(`preprint:${preprintId}`); - pdfUrl = getPdfUrl(body); - if (!pdfUrl) { - return next(createError(500, `Could not determine PDF from prereview: ${JSON.stringify(body)}`)); + let { preprintId, pdfUrl } = req.query; + + // If we already have the pdfUrl, there's no need to look in the database. + // The pdfUrl is present in the case where the preprint is not in the database yet, + // but we were able to resolve it. + if (!pdfUrl) { + try { + const body = await req.db.get(`preprint:${preprintId}`); + pdfUrl = getPdfUrl(body); + if (!pdfUrl) { + return next(createError(500, `Could not determine PDF from prereview: ${JSON.stringify(body)}`)); + } + } catch (err) { + return next(createError(500, `Prereview query failed: ${preprintId} ${JSON.stringify(err)}`)); } - } catch (err) { - return next(createError(500, `Prereview query failed: ${preprintId} ${JSON.stringify(err)}`)); } if (!pdfUrl) { From eb31c92ee3120ba9a5c32070fc4097523e4d0c15 Mon Sep 17 00:00:00 2001 From: leonardosfl Date: Wed, 5 Aug 2020 00:35:16 -0300 Subject: [PATCH 2/7] Show login required modal on dashboard Fix #158 --- src/components/dashboard.js | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/src/components/dashboard.js b/src/components/dashboard.js index 48afc7b..cd12d5b 100644 --- a/src/components/dashboard.js +++ b/src/components/dashboard.js @@ -27,6 +27,7 @@ import AddButton from './add-button'; import Banner from "./banner.js"; import Button from './button'; +import LoginRequiredModal from './login-required-modal'; import Checkbox from './checkbox'; import SortOptions from './sort-options'; import HeaderBar from './header-bar'; @@ -167,6 +168,14 @@ export default function Dashboard() { setShowLeftPanel(!showLeftPanel); }} /> + {loginModalOpenNext && ( + { + setLoginModalOpenNext(null); + }} + /> + )}
From c4970a014efb545cf789f09203a0880bc1bf67fe Mon Sep 17 00:00:00 2001 From: leonardosfl Date: Fri, 7 Aug 2020 10:19:18 -0300 Subject: [PATCH 3/7] Delete only the identifier param instead of everything. --- src/components/new-preprint.js | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/components/new-preprint.js b/src/components/new-preprint.js index 0ab7e4d..217d87e 100644 --- a/src/components/new-preprint.js +++ b/src/components/new-preprint.js @@ -214,7 +214,8 @@ function StepPreprint({ if (location.search) { const qs = new URLSearchParams(location.search); if (qs.get('identifier')) { - history.replace('/new'); + qs.delete('identifier'); + history.replace({ pathname: location.pathname, search: qs.toString() }); } } From 79ae729500ac7c01be4e4ade8c6b664bc63ecbad Mon Sep 17 00:00:00 2001 From: leonardosfl Date: Fri, 7 Aug 2020 10:29:12 -0300 Subject: [PATCH 4/7] Allow to add new preprints from dashboard. --- src/components/app.js | 2 +- src/components/dashboard.js | 126 ++++++++++++++++++++++++++------ src/components/preprint-card.js | 5 +- 3 files changed, 106 insertions(+), 27 deletions(-) diff --git a/src/components/app.js b/src/components/app.js index 3ef86e2..ea6e34a 100644 --- a/src/components/app.js +++ b/src/components/app.js @@ -58,7 +58,7 @@ export default function App({ user }) { - + diff --git a/src/components/dashboard.js b/src/components/dashboard.js index ab24e62..44c3fdf 100644 --- a/src/components/dashboard.js +++ b/src/components/dashboard.js @@ -11,12 +11,13 @@ import Org from './org'; // hooks import { usePreprintSearchResults } from '../hooks/api-hooks'; +import { useNewPreprints } from '../hooks/ui-hooks'; // utils import { checkIfIsModerated } from '../utils/actions'; import { getUsersRank, isYes } from '../utils/stats'; import { createPreprintQs, apifyPreprintQs } from '../utils/search'; -import { getId } from '../utils/jsonld' +import { getId, unprefix } from '../utils/jsonld' // contexts @@ -36,6 +37,9 @@ import SearchBar from './search-bar'; import XLink from './xlink'; import RecentActivity from './recent-activity' import ActiveUser from './active-user' +import PrivateRoute from './private-route'; +import NewPreprint from './new-preprint'; +import Modal from './modal'; export default function Dashboard() { @@ -44,6 +48,7 @@ export default function Dashboard() { const [user] = useUser(); const [loginModalOpenNext, setLoginModalOpenNext] = useState(null); + const [newPreprints, setNewPreprints] = useNewPreprints(); const apiQs = apifyPreprintQs( location.search, @@ -55,7 +60,7 @@ export default function Dashboard() { useEffect(() => { if (location.search === "") { - history.replace({ search: createPreprintQs({ text: covidTerms }, location.search) }); + history.replace({ search: createPreprintQs({ text: covidTerms }, location.search), state: location.state }); } }, [apiQs]); @@ -112,15 +117,21 @@ export default function Dashboard() { const handleNewRequest = useCallback( preprint => { if (user) { - history.push('/new', { - preprint: omit(preprint, ['potentialAction']), - tab: 'request', - isSingleStep: true + history.push({ + pathname: '/dashboard/new', + search: history.location.search, + state: { + preprint: omit(preprint, ['potentialAction']), + tab: 'request', + isSingleStep: true + } }); } else { - setLoginModalOpenNext( - `/new?identifier=${preprint.doi || preprint.arXivId}&tab=request` - ); + const search = new URLSearchParams(location.search); + search.set('identifier', preprint.doi || preprint.arXivId); + search.set('tab', 'request'); + + setLoginModalOpenNext(`/dashboard/new?${search}`); } }, [user, history] @@ -129,13 +140,18 @@ export default function Dashboard() { const handleNew = useCallback( preprint => { if (user) { - history.push('/new', { - preprint: omit(preprint, ['potentialAction']) + history.push({ + pathname: '/dashboard/new', + search: history.location.search, + state: { + preprint: omit(preprint, ['potentialAction']) + } }); } else { - setLoginModalOpenNext( - `/new?identifier=${preprint.doi || preprint.arXivId}` - ); + const search = new URLSearchParams(location.search); + search.set('identifier', preprint.doi || preprint.arXivId); + + setLoginModalOpenNext(`/dashboard/new?${search}`); } }, [user, history] @@ -144,15 +160,21 @@ export default function Dashboard() { const handleNewReview = useCallback( preprint => { if (user) { - history.push('/new', { - preprint: omit(preprint, ['potentialAction']), - tab: 'review', - isSingleStep: true + history.push({ + pathname: '/dashboard/new', + search: history.location.search, + state: { + preprint: omit(preprint, ['potentialAction']), + tab: 'review', + isSingleStep: true + } }); } else { - setLoginModalOpenNext( - `/new?identifier=${preprint.doi || preprint.arXivId}&tab=review` - ); + const search = new URLSearchParams(location.search); + search.set('identifier', preprint.doi || preprint.arXivId); + search.set('tab', 'review'); + + setLoginModalOpenNext(`/dashboard/new?${search}`); } }, [user, history] @@ -177,6 +199,45 @@ export default function Dashboard() { }} /> )} + + { + history.push({ pathname: '/dashboard', search: location.search }); + }} + > + + Rapid PREreview • Add entry + + { + history.push({ pathname: '/dashboard', search: location.search }); + }} + onSuccess={(preprint, isNew) => { + history.push({ pathname: '/dashboard', search: location.search }); + if ( + isNew && + !newPreprints.some( + _preprint => getId(_preprint) === getId(preprint) + ) + ) { + setNewPreprints(newPreprints.concat(preprint)); + } + }} + onViewInContext={({ preprint, tab }, isNew) => { + history.push( + `/${unprefix(preprint.doi || preprint.arXivId)}`, + { + preprint: omit(preprint, ['potentialAction']), + tab + } + ); + }} + /> + +
@@ -333,6 +394,23 @@ export default function Dashboard() {
No more preprints.
) : (
    + {newPreprints.length > 0 && ( + newPreprints.map(preprint => ( +
  • + +
  • + )) + )} {preprints.rows.length ? preprints.rows.map(row => (
  • { if (user) { - history.push('/new'); + history.push({ pathname: '/dashboard/new', search: location.search }); } else { - setLoginModalOpenNext('/new'); + setLoginModalOpenNext(`/dashboard/new?${location.search}`); } }} - disabled={location.pathname === '/new'} + disabled={location.pathname === '/dashboard/new'} />
diff --git a/src/components/preprint-card.js b/src/components/preprint-card.js index ca0f0b7..703b241 100644 --- a/src/components/preprint-card.js +++ b/src/components/preprint-card.js @@ -39,7 +39,8 @@ export default function PreprintCard({ onNew, sortOption, hoveredSortOption, - isNew = false + isNew = false, + isDashboardCard = false, }) { const [isOpened, setIsOpened] = useState(false); @@ -93,7 +94,7 @@ export default function PreprintCard({ return (
From 649f7257e6f9923d5267e016d162a8c197d369b0 Mon Sep 17 00:00:00 2001 From: leonardosfl Date: Wed, 12 Aug 2020 22:02:24 -0300 Subject: [PATCH 5/7] Update banner message --- src/components/banner.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/components/banner.js b/src/components/banner.js index 0f8f94a..01cd5d6 100644 --- a/src/components/banner.js +++ b/src/components/banner.js @@ -7,8 +7,8 @@ export default function Banner() { return (
-

Click here to find preprints on COVID-19 with reviews or requests for reviews.

-

Click here to read OASPA's open letter of intent to ensure rapid review of key work related to COVID-19.

+

Get involved with rapidly reviewing COVID-19 preprints and then view our COVID-19 Dashboard of review activities and recommendations.

+

Read about the OASPA’s initiative to ensure rapid review of key COVID-19 work.

) From c9ee3c1787948d5459a0ec7f182f87cbcaead38b Mon Sep 17 00:00:00 2001 From: Harum Helmy Date: Mon, 24 Aug 2020 16:20:18 -0400 Subject: [PATCH 6/7] Remove banner soliciting feedback --- src/components/header-bar.js | 10 ---------- 1 file changed, 10 deletions(-) diff --git a/src/components/header-bar.js b/src/components/header-bar.js index 391b323..8c96152 100644 --- a/src/components/header-bar.js +++ b/src/components/header-bar.js @@ -176,16 +176,6 @@ export default function HeaderBar({ onClickMenuButton, closeGap }) { )}
- {/* TODO link to feedback form */} -
); } From 019cbcd5e6f8e960e653fe3e89e88893ada405df Mon Sep 17 00:00:00 2001 From: Harum Helmy Date: Mon, 24 Aug 2020 16:28:06 -0400 Subject: [PATCH 7/7] removed feedback banner styling --- src/components/header-bar.css | 24 ------------------------ 1 file changed, 24 deletions(-) diff --git a/src/components/header-bar.css b/src/components/header-bar.css index eba291f..b8bd9da 100644 --- a/src/components/header-bar.css +++ b/src/components/header-bar.css @@ -28,30 +28,6 @@ } } - & .header-bar__give-feedback { - position: fixed; - font: var(--ui-basic-font); - line-height: 1.25em; - background-color: var(--prereview-red); - color: white; - text-shadow: 0px 0px 10px #eb0000; /* improve contrast for accessability */ - right: 0px; - bottom: var(--xlgrd); - width: 56px; - padding: var(--xsgrd); - padding-right: var(--mgrd); - border-top-left-radius: var(--xsgrd); - border-bottom-left-radius: var(--xsgrd); - box-shadow: 0px 2px 4px rgba(0, 0, 0, 0.2); - & :any-link { - color: white; - text-decoration: none; - &:hover { - text-decoration: underline; - } - } - } - /* the hamburder is only visible on narrow screens */ & .header-bar__menu-button { display: none;