Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add a way of marking articles as deprecated #3912

Merged
merged 6 commits into from
Sep 5, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions adminSiteClient/gdocsDeploy.ts
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,7 @@ export const checkIsLightningUpdate = (
"atom-excerpt": false, // requires updating the atom feed / blog roll
"atom-title": false, // requires updating the atom feed / blog roll
"featured-image": false, // requires updating references to this article
"deprecation-notice": false, // requires updating references to this article
authors: false, // requires updating references to this article
excerpt: false, // requires updating references to this article
faqs: false, // requires updating datapages
Expand Down
15 changes: 11 additions & 4 deletions baker/algolia/algoliaUtils.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -157,6 +157,16 @@ async function generateWordpressRecords(
return records
}

function gdocThumbnailUrl(gdoc: OwidGdocPostInterface): string {
rakyi marked this conversation as resolved.
Show resolved Hide resolved
if (gdoc.content["deprecation-notice"]) {
return "/archived-thumbnail.jpg"
}
if (gdoc.content["featured-image"]) {
return getThumbnailPath(gdoc.content["featured-image"])
}
return "/default-thumbnail.jpg"
}

function generateGdocRecords(
gdocs: OwidGdocPostInterface[],
pageviews: Record<string, RawPageview>
Expand Down Expand Up @@ -199,10 +209,7 @@ function generateGdocRecords(
const chunks = generateChunksFromHtmlText(renderedPostContent)
const postTypeAndImportance = getPostTypeAndImportance(gdoc)
let i = 0

const thumbnailUrl = gdoc.content["featured-image"]
? getThumbnailPath(gdoc.content["featured-image"])
: "/default-thumbnail.jpg"
const thumbnailUrl = gdocThumbnailUrl(gdoc)

for (const chunk of chunks) {
const record = {
Expand Down
8 changes: 6 additions & 2 deletions db/model/Gdoc/GdocBase.ts
Original file line number Diff line number Diff line change
Expand Up @@ -866,6 +866,7 @@ export async function getMinimalGdocPostsByIds(
excerpt: string
type: string
"featured-image": string
isDeprecated: number
rakyi marked this conversation as resolved.
Show resolved Hide resolved
}>(
knex,
`-- sql
Expand All @@ -879,7 +880,8 @@ export async function getMinimalGdocPostsByIds(
content ->> '$.subtitle' as subtitle,
content ->> '$.excerpt' as excerpt,
type,
content ->> '$."featured-image"' as "featured-image"
content ->> '$."featured-image"' as "featured-image",
(content ->> '$."deprecation-notice"' IS NOT NULL) as isDeprecated
FROM posts_gdocs
WHERE id in (:ids)`,
{ ids }
Expand All @@ -895,7 +897,9 @@ export async function getMinimalGdocPostsByIds(
subtitle: row.subtitle,
excerpt: row.excerpt,
type: row.type as OwidGdocType,
"featured-image": row["featured-image"],
"featured-image": row.isDeprecated
? "/archived-thumbnail.jpg"
: row["featured-image"],
} satisfies OwidGdocMinimalPostInterface
})
}
Expand Down
8 changes: 6 additions & 2 deletions db/model/Gdoc/GdocFactory.ts
Original file line number Diff line number Diff line change
Expand Up @@ -197,6 +197,7 @@ export async function getAllMinimalGdocBaseObjects(
excerpt: string
type: string
"featured-image": string
isDeprecated: number
}>(
knex,
`-- sql
Expand All @@ -210,7 +211,8 @@ export async function getAllMinimalGdocBaseObjects(
content ->> '$.subtitle' as subtitle,
content ->> '$.excerpt' as excerpt,
type,
content ->> '$."featured-image"' as "featured-image"
content ->> '$."featured-image"' as "featured-image",
(content ->> '$."deprecation-notice"' IS NOT NULL) as isDeprecated
FROM posts_gdocs
WHERE published = 1
AND publishedAt <= NOW()`,
Expand All @@ -227,7 +229,9 @@ export async function getAllMinimalGdocBaseObjects(
subtitle: row.subtitle,
excerpt: row.excerpt,
type: row.type as OwidGdocType,
"featured-image": row["featured-image"],
"featured-image": row.isDeprecated
? "/archived-thumbnail.jpg"
: row["featured-image"],
} satisfies OwidGdocMinimalPostInterface
})
}
Expand Down
5 changes: 5 additions & 0 deletions db/model/Gdoc/GdocPost.ts
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,11 @@ export class GdocPost extends GdocBase implements OwidGdocPostInterface {
enrichedBlocks.push(...refBlocks)
}

const deprecationNotice = gdoc.content["deprecation-notice"]
if (deprecationNotice) {
enrichedBlocks.push(...deprecationNotice)
}

return enrichedBlocks
}

Expand Down
10 changes: 9 additions & 1 deletion db/model/Gdoc/archieToEnriched.ts
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,11 @@ import {
isEmpty,
} from "@ourworldindata/utils"
import { convertHeadingTextToId } from "@ourworldindata/components"
import { parseRawBlocksToEnrichedBlocks, parseRefs } from "./rawToEnriched.js"
import {
parseRawBlocksToEnrichedBlocks,
parseRefs,
parseText,
} from "./rawToEnriched.js"
import urlSlug from "url-slug"
import { extractUrl, parseAuthors, spansToSimpleString } from "./gdocUtils.js"
import { htmlToSimpleTextBlock } from "./htmlToEnriched.js"
Expand Down Expand Up @@ -316,6 +320,10 @@ export const archieToEnriched = (

// Parse elements of the ArchieML into enrichedBlocks
parsed.body = compact(parsed.body.map(parseRawBlocksToEnrichedBlocks))
const deprecationNotice = parsed["deprecation-notice"]
if (deprecationNotice) {
parsed["deprecation-notice"] = compact(deprecationNotice.map(parseText))
rakyi marked this conversation as resolved.
Show resolved Hide resolved
}

const parsedRefs = parseRefs({
refs: [...(parsed.refs ?? []), ...rawInlineRefs],
Expand Down
15 changes: 12 additions & 3 deletions db/model/Post.ts
Original file line number Diff line number Diff line change
Expand Up @@ -307,6 +307,16 @@ export const getBlogIndex = memoize(
}
)

function gdocThumbnail(gdoc: OwidGdocPostInterface): string {
rakyi marked this conversation as resolved.
Show resolved Hide resolved
let thumbnailPath = "/default-thumbnail.jpg"
if (gdoc.content["deprecation-notice"]) {
thumbnailPath = "/archived-thumbnail.jpg"
} else if (gdoc.content["featured-image"]) {
thumbnailPath = `${IMAGES_DIRECTORY}${gdoc.content["featured-image"]}`
}
return `${BAKED_BASE_URL}${thumbnailPath}`
}

export const mapGdocsToWordpressPosts = (
gdocs: OwidGdocPostInterface[]
): IndexPost[] => {
Expand All @@ -318,9 +328,7 @@ export const mapGdocsToWordpressPosts = (
modifiedDate: gdoc.updatedAt as Date,
authors: gdoc.content.authors,
excerpt: gdoc.content["atom-excerpt"] || gdoc.content.excerpt,
imageUrl: gdoc.content["featured-image"]
? `${BAKED_BASE_URL}${IMAGES_DIRECTORY}${gdoc.content["featured-image"]}`
: `${BAKED_BASE_URL}/default-thumbnail.jpg`,
imageUrl: gdocThumbnail(gdoc),
}))
}

Expand Down Expand Up @@ -619,6 +627,7 @@ export const getLatestWorkByAuthor = async (
pg.content->>'$.subtitle' AS subtitle,
pg.content->>'$.authors' AS authors,
pg.content->>'$."featured-image"' AS "featured-image",
(pg.content->>'$."deprecation-notice"' IS NOT NULL) AS isDeprecated,
pg.publishedAt
FROM
posts_gdocs pg
Expand Down
4 changes: 4 additions & 0 deletions packages/@ourworldindata/types/src/domainTypes/Author.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ export interface DbRawLatestWork {
subtitle: string | null
authors: string
"featured-image": string | null
isDeprecated: number
rakyi marked this conversation as resolved.
Show resolved Hide resolved
publishedAt: string | null
}

Expand All @@ -24,5 +25,8 @@ export const parseLatestWork = (
return {
...latestWork,
authors: JSON.parse(latestWork.authors),
"featured-image": latestWork.isDeprecated
? "/archived-thumbnail.jpg"
: latestWork["featured-image"],
}
}
1 change: 1 addition & 0 deletions packages/@ourworldindata/types/src/gdocTypes/Gdoc.ts
Original file line number Diff line number Diff line change
Expand Up @@ -285,6 +285,7 @@ export interface OwidGdocPostContent {
excerpt?: string
refs?: { definitions: RefDictionary; errors: OwidGdocErrorMessage[] }
summary?: EnrichedBlockText[]
"deprecation-notice"?: EnrichedBlockText[]
"hide-citation"?: boolean
toc?: TocHeadingWithTitleSupertitle[]
"cover-image"?: string
Expand Down
Binary file added public/archived-thumbnail.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
17 changes: 11 additions & 6 deletions site/gdocs/OwidGdocPage.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -89,18 +89,23 @@ export default function OwidGdocPage({
const isDataInsight = gdoc.content.type === OwidGdocType.DataInsight
const isAuthor = gdoc.content.type === OwidGdocType.Author

let imageUrl
if (
gdoc.content.type === OwidGdocType.Article &&
rakyi marked this conversation as resolved.
Show resolved Hide resolved
gdoc.content["deprecation-notice"]
) {
imageUrl = `${baseUrl}/archived-thumbnail.jpg`
} else if (featuredImageFilename) {
imageUrl = `${baseUrl}${IMAGES_DIRECTORY}${featuredImageFilename}`
}

return (
<Html>
<Head
pageTitle={pageTitle}
pageDesc={pageDesc}
canonicalUrl={canonicalUrl}
imageUrl={
// uriEncoding is taken care of inside the Head component
featuredImageFilename
? `${baseUrl}${IMAGES_DIRECTORY}${featuredImageFilename}`
: undefined
}
imageUrl={imageUrl} // uriEncoding is taken care of inside the Head component
atom={isDataInsight ? DATA_INSIGHT_ATOM_FEED_PROPS : undefined}
baseUrl={baseUrl}
>
Expand Down
45 changes: 28 additions & 17 deletions site/gdocs/components/OwidGdocHeader.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -18,10 +18,12 @@ function OwidArticleHeader({
content,
publishedAt,
breadcrumbs,
isDeprecated,
}: {
content: OwidGdocPostContent
publishedAt: Date | null
breadcrumbs?: BreadcrumbItem[]
isDeprecated?: boolean
}) {
const coverStyle = content["cover-color"]
? { backgroundColor: `var(--${content["cover-color"]})` }
Expand Down Expand Up @@ -75,7 +77,13 @@ function OwidArticleHeader({
</h2>
) : null}
<div className="centered-article-header__meta-container col-start-2 span-cols-6 span-md-cols-10 col-md-start-2 grid grid-cols-2 ">
<div className="span-cols-1 span-sm-cols-2">
<div
className={
isDeprecated
? "span-cols-2"
: "span-cols-1 span-sm-cols-2"
}
>
{content.authors.length > 0 && (
<div className="centered-article-header__byline">
<Byline names={content.authors} />
Expand All @@ -86,25 +94,27 @@ function OwidArticleHeader({
(publishedAt && formatDate(publishedAt))}
</div>
</div>
<div className="span-cols-1 span-sm-cols-2">
{!content["hide-citation"] && (
{!isDeprecated && (
<div className="span-cols-1 span-sm-cols-2">
{!content["hide-citation"] && (
<a
href="#article-citation"
className="body-1-regular display-block"
>
<FontAwesomeIcon icon={faBook} />
Cite this article
</a>
)}

<a
href="#article-citation"
className="body-1-regular display-block"
href="#article-licence"
className="body-3-medium display-block"
>
<FontAwesomeIcon icon={faBook} />
Cite this article
<FontAwesomeIcon icon={faCreativeCommons} />
Reuse our work freely
</a>
)}

<a
href="#article-licence"
className="body-3-medium display-block"
>
<FontAwesomeIcon icon={faCreativeCommons} />
Reuse our work freely
</a>
</div>
</div>
)}
</div>
</header>
</>
Expand Down Expand Up @@ -158,6 +168,7 @@ export function OwidGdocHeader(props: {
content: OwidGdocPostContent
publishedAt: Date | null
breadcrumbs?: BreadcrumbItem[]
isDeprecated?: boolean
}) {
if (props.content.type === OwidGdocType.Article)
return <OwidArticleHeader {...props} />
Expand Down
1 change: 1 addition & 0 deletions site/gdocs/components/ProminentLink.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,7 @@ export const ProminentLink = (props: {
const Thumbnail = ({ thumbnail }: { thumbnail: string }) => {
if (
thumbnail.startsWith(BAKED_GRAPHER_EXPORTS_BASE_URL) ||
thumbnail.endsWith("archived-thumbnail.jpg") ||
thumbnail.endsWith("default-thumbnail.jpg")
) {
return <img src={thumbnail} />
Expand Down
61 changes: 58 additions & 3 deletions site/gdocs/components/centered-article.scss
Original file line number Diff line number Diff line change
Expand Up @@ -195,6 +195,62 @@ $banner-height: 200px;
margin-bottom: 32px;
}

.deprecation-notice {
--bg-color: #fff5d8;
rakyi marked this conversation as resolved.
Show resolved Hide resolved
position: sticky;
top: 0;
left: 0;
right: 0;
background-color: var(--bg-color);
border-radius: 4px;
padding: 16px;
padding-bottom: 0;
margin-bottom: 24px;

&::before {
content: "";
position: absolute;
top: 0;
left: 50%;
right: 50%;
height: 100%;
background-color: var(--bg-color);
transition: all 0.3s ease;
z-index: -1;
}

&--sticky::before {
left: -50vw;
right: -50vw;
}

.article-block__text,
.article-block__list,
.article-block__html,
.article-block__numbered-list {
@include body-3-regular;
}
}

.deprecation-notice__heading {
@include h4-semibold;
margin-top: 0;
margin-bottom: 8px;
color: $vermillion;
}

.deprecation-notice__icon {
margin-right: 8px;
}

.citation-deprecated-notice {
font-weight: 700;

&__highlight {
color: $vermillion;
}
}

.centered-article-header {
background: $white;
margin: 80px 0 24px;
Expand Down Expand Up @@ -470,14 +526,14 @@ h3.article-block__heading.has-supertitle {
}

@include sm-up {
> div:first-child {
> div:not(:last-child) {
border-right: 1px solid $blue-10;
}
}

@include sm-only {
padding: 16px 0;
> div:first-child {
> div:not(:last-child) {
border-bottom: 1px solid $blue-10;
padding-bottom: 16px;
margin-bottom: 16px;
Expand Down Expand Up @@ -557,7 +613,6 @@ h3.article-block__heading.has-supertitle {
padding-top: 48px;
h3 {
margin-top: 0;
text-align: center;
}
p {
margin-bottom: 16px;
Expand Down
Loading