Skip to content

Commit

Permalink
Better date displays - processing level display (#2801)
Browse files Browse the repository at this point in the history
This PR improves the rendering of some dates and time ranges, updates the processing level (minor/major) text and fixes some minor wording issues.

This is related to #2755 and fixes these points:
* [x] Instead of mentioning Twitter (in "How to cite this data"), we should say "social media".
* [x] We should not say "OWID" anywhere (as it happens in "How to cite this data").
* [x] We should show the date of next expected update. This should be based on `dataset.update_period_days` and the current date (if it's passed, increase it by a month).
* [x] Change the wording of "processed" or "adapated" by under the chart to "with minor/major processing by Our World In Data"
* [x] If the time range for an indicator includes negative years (like our long run population data does), then show `10000 BC to 2020 AD` instead of `-10000-2020`
* [x] Last updated date should render as a formatted date instead of a raw date string
  • Loading branch information
danyx23 authored Oct 24, 2023
2 parents fe959a3 + a2623bc commit 64c7ba0
Show file tree
Hide file tree
Showing 2 changed files with 69 additions and 21 deletions.
11 changes: 8 additions & 3 deletions datapage/Datapage.ts
Original file line number Diff line number Diff line change
Expand Up @@ -36,9 +36,14 @@ export const getDatapageDataV2 = async (
let nextUpdate = undefined
if (variableMetadata.updatePeriodDays) {
const date = dayjs(version)
nextUpdate = date
.add(variableMetadata.updatePeriodDays, "day")
.format("MMMM YYYY")
const nextUpdateDate = date.add(
variableMetadata.updatePeriodDays,
"day"
)
// If the next update date is in the past, we set it to the next month
if (nextUpdateDate.isBefore(dayjs()))
nextUpdate = dayjs().add(1, "month").format("MMMM YYYY")
else nextUpdate = nextUpdateDate.format("MMMM YYYY")
}
const datapageJson: DataPageDataV2 = {
status: "draft",
Expand Down
79 changes: 61 additions & 18 deletions site/DataPageV2Content.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,49 @@ declare global {
}
export const OWID_DATAPAGE_CONTENT_ROOT_ID = "owid-datapageJson-root"

const getDateRange = (dateRange: string): string | null => {
// This regex matches:
// Beginning of string
// Ignore whitespace
// a named group called start that matches:
// hyphen aka minus
// 1 or more digits
// Ignore whitespace
// hyphen aka minus OR en dash
// Ignore whitespace
// a named group called end that matches:
// hyphen aka minus
// 1 or more digits
// Ignore whitespace
// End of string
const dateRangeRegex = /^\s*(?<start>(-)?\d+)\s*(-|)\s*(?<end>(-)?\d+)\s*$/
const match = dateRange.match(dateRangeRegex)
if (match) {
const firstYearString = match.groups?.start
const lastYearString = match.groups?.end
if (!firstYearString || !lastYearString) return null

const firstYear = parseInt(firstYearString, 10)
const lastYear = parseInt(lastYearString, 10)
let formattedFirstYear

// if start year is before year 0, add BCE to the end
if (firstYear < 0) formattedFirstYear = `${Math.abs(firstYear)} BCE`
else formattedFirstYear = firstYear

// if end year is before year 0, add BCE to the end or, if start year is after year 0, add CE to the end
let formattedLastYear
if (lastYear < 0) formattedLastYear = `${Math.abs(lastYear)} BCE`
else if (firstYear < 0) formattedLastYear = `${lastYear} CE`
else formattedLastYear = lastYear

if (lastYear < 0 || firstYear < 0)
return `${formattedFirstYear}${formattedLastYear}`
else return `${formattedFirstYear}${formattedLastYear}`
}
return null
}

export const DataPageV2Content = ({
datapageData,
grapherConfig,
Expand Down Expand Up @@ -90,14 +133,10 @@ export const DataPageV2Content = ({
// by Joe. Also, we need the dataset title.
const producers = datapageData.origins.map((o) => o.producer).join("; ")
const processedAdapted =
datapageData.owidProcessingLevel === "minor"
? `Processed by`
: `Adapted by`
const yearOfUpdate = dayjs(datapageData.lastUpdated, [
"YYYY",
"YYYY-MM-DD",
]).year()
const citationShort = `${producers}${processedAdapted} OWID (${yearOfUpdate})`
datapageData.owidProcessingLevel === "minor" ? `minor` : `major`
const lastUpdated = dayjs(datapageData.lastUpdated, ["YYYY", "YYYY-MM-DD"])
const yearOfUpdate = lastUpdated.year()
const citationShort = `${producers} — with ${processedAdapted} processing by Our World In Data (${yearOfUpdate})`
const originsLong = datapageData.origins
.map((o) => `${o.producer}, ${o.title ?? o.titleSnapshot}`)
.join("; ")
Expand All @@ -112,10 +151,6 @@ export const DataPageV2Content = ({
datapageData.origins.length &&
datapageData.origins[0].urlDownload
const citationLong = `${citationShort}. ${datapageData.title}. ${originsLong}, ${processedAdapted} by Our World In Data. Retrieved ${dateAccessed} from ${urlAccessed}`
const processedAdaptedText =
datapageData.owidProcessingLevel === "minor"
? `Processed by Our World In Data`
: `Adapted by Our World In Data`

const {
linkedDocuments = {},
Expand Down Expand Up @@ -153,6 +188,8 @@ export const DataPageV2Content = ({
/>
) : null

const dateRange = getDateRange(datapageData.dateRange)

const citationDatapage = `Our World In Data (${yearOfUpdate}). Data Page: ${datapageData.title}${producers}. Retrieved from {url} [online resource]`
return (
<AttachmentsContext.Provider
Expand Down Expand Up @@ -292,25 +329,30 @@ export const DataPageV2Content = ({
<div>{datapageData.attribution}</div>
{datapageData.owidProcessingLevel && (
<div>
with{" "}
<a
href={`#${DATAPAGE_SOURCES_AND_PROCESSING_SECTION_ID}`}
>
{processedAdaptedText}
</a>
{processedAdapted}
{" processing"}
</a>{" "}
by Our World In Data
</div>
)}
</div>
<div className="key-data span-cols-3 span-lg-cols-4 span-sm-cols-6">
<div className="key-data__title">
Date range
</div>
<div>{datapageData.dateRange}</div>
<div>{dateRange}</div>
</div>
<div className="key-data span-cols-3 span-lg-cols-4 span-sm-cols-6">
<div className="key-data__title">
Last updated
</div>
<div>{datapageData.lastUpdated}</div>
<div>
{lastUpdated.format("MMMM D, YYYY")}
</div>
</div>
{datapageData.nextUpdate && (
<div className="key-data span-cols-3 span-lg-cols-4 span-sm-cols-6">
Expand Down Expand Up @@ -790,8 +832,9 @@ export const DataPageV2Content = ({
limited space
(e.g. in data
visualizations,
on Twitter), you
can use this
on social
media), you can
use this
abbreviated
in-line
citation:
Expand Down

0 comments on commit 64c7ba0

Please sign in to comment.