summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArmand Philippot <git@armandphilippot.com>2022-01-29 23:17:49 +0100
committerArmand Philippot <git@armandphilippot.com>2022-01-29 23:21:14 +0100
commitb2686521cf2ca6bb0b5c5164de72d3d39d5c510e (patch)
treeba18ca4612460017ec7dae1f0471d0972457681c
parent657d11ce72c905832b9b169354352f521f42207a (diff)
refactor(widgets): move sharing websites from config to sharing widget
I only use these websites inside the sharing widget so it makes more sense to gather them. In addition, I can translate the website name if needed.
-rw-r--r--src/components/Widgets/Sharing/Sharing.tsx91
-rw-r--r--src/config/sharing.ts70
-rw-r--r--src/i18n/en.json24
-rw-r--r--src/i18n/fr.json24
4 files changed, 136 insertions, 73 deletions
diff --git a/src/components/Widgets/Sharing/Sharing.tsx b/src/components/Widgets/Sharing/Sharing.tsx
index 1025717..dd2d2a0 100644
--- a/src/components/Widgets/Sharing/Sharing.tsx
+++ b/src/components/Widgets/Sharing/Sharing.tsx
@@ -1,5 +1,5 @@
import { ExpandableWidget } from '@components/WidgetParts';
-import sharingMedia from '@config/sharing';
+import { getIntlInstance } from '@utils/helpers/i18n';
import { useRouter } from 'next/router';
import { useEffect, useState } from 'react';
import { useIntl } from 'react-intl';
@@ -95,9 +95,94 @@ const Sharing = ({ excerpt, title }: { excerpt: string; title: string }) => {
return sharingUrl;
};
- const getItems = () => {
- const websites: Website[] = sharingMedia;
+ const websites = [
+ {
+ id: 'diaspora',
+ name: intl.formatMessage({
+ defaultMessage: 'Diaspora',
+ description: 'Sharing: Diaspora',
+ }),
+ parameters: {
+ content: '',
+ image: '',
+ title: 'title',
+ url: 'url',
+ },
+ url: 'https://share.diasporafoundation.org/',
+ },
+ {
+ id: 'facebook',
+ name: intl.formatMessage({
+ defaultMessage: 'Facebook',
+ description: 'Sharing: Facebook',
+ }),
+ parameters: {
+ content: '',
+ image: '',
+ title: '',
+ url: 'u',
+ },
+ url: 'https://www.facebook.com/sharer/sharer.php',
+ },
+ {
+ id: 'linkedin',
+ name: intl.formatMessage({
+ defaultMessage: 'LinkedIn',
+ description: 'Sharing: LinkedIn',
+ }),
+ parameters: {
+ content: '',
+ image: '',
+ title: '',
+ url: 'url',
+ },
+ url: 'https://www.linkedin.com/sharing/share-offsite/',
+ },
+ {
+ id: 'twitter',
+ name: intl.formatMessage({
+ defaultMessage: 'Twitter',
+ description: 'Sharing: Twitter',
+ }),
+ parameters: {
+ content: '',
+ image: '',
+ title: 'text',
+ url: 'url',
+ },
+ url: 'https://twitter.com/intent/tweet',
+ },
+ {
+ id: 'journal-du-hacker',
+ name: intl.formatMessage({
+ defaultMessage: 'Journal du hacker',
+ description: 'Sharing: Journal du hacker',
+ }),
+ parameters: {
+ content: '',
+ image: '',
+ title: 'title',
+ url: 'url',
+ },
+ url: 'https://www.journalduhacker.net/stories/new',
+ },
+ {
+ id: 'email',
+ name: intl.formatMessage({
+ defaultMessage: 'Email',
+ description: 'Sharing: Email',
+ }),
+ parameters: {
+ content: 'body',
+ image: '',
+ title: 'subject',
+ url: '',
+ },
+ url: 'mailto:',
+ },
+ ];
+ const getItems = () => {
return websites.map((website) => {
const { id, name } = website;
const sharingUrl = getSharingUrl(website);
diff --git a/src/config/sharing.ts b/src/config/sharing.ts
deleted file mode 100644
index 9e84801..0000000
--- a/src/config/sharing.ts
+++ /dev/null
@@ -1,70 +0,0 @@
-const sharingMedia = [
- {
- id: 'diaspora',
- name: 'Diaspora',
- parameters: {
- content: '',
- image: '',
- title: 'title',
- url: 'url',
- },
- url: 'https://share.diasporafoundation.org/',
- },
- {
- id: 'facebook',
- name: 'Facebook',
- parameters: {
- content: '',
- image: '',
- title: '',
- url: 'u',
- },
- url: 'https://www.facebook.com/sharer/sharer.php',
- },
- {
- id: 'linkedin',
- name: 'LinkedIn',
- parameters: {
- content: '',
- image: '',
- title: '',
- url: 'url',
- },
- url: 'https://www.linkedin.com/sharing/share-offsite/',
- },
- {
- id: 'twitter',
- name: 'Twitter',
- parameters: {
- content: '',
- image: '',
- title: 'text',
- url: 'url',
- },
- url: 'https://twitter.com/intent/tweet',
- },
- {
- id: 'journal-du-hacker',
- name: 'Journal du Hacker',
- parameters: {
- content: '',
- image: '',
- title: 'title',
- url: 'url',
- },
- url: 'https://www.journalduhacker.net/stories/new',
- },
- {
- id: 'email',
- name: 'Email',
- parameters: {
- content: 'body',
- image: '',
- title: 'subject',
- url: '',
- },
- url: 'mailto:',
- },
-];
-
-export default sharingMedia;
diff --git a/src/i18n/en.json b/src/i18n/en.json
index 23f5278..2faabe0 100644
--- a/src/i18n/en.json
+++ b/src/i18n/en.json
@@ -67,6 +67,10 @@
"defaultMessage": "Blog",
"description": "BlogPage: page title"
},
+ "7iiaRx": {
+ "defaultMessage": "Facebook",
+ "description": "Sharing: Facebook"
+ },
"8Ls2mD": {
"defaultMessage": "Please fill the form to contact me.",
"description": "ContactPage: page introduction"
@@ -107,6 +111,10 @@
"defaultMessage": "Contact",
"description": "ContactPage: breadcrumb item"
},
+ "Dhow1m": {
+ "defaultMessage": "Diaspora",
+ "description": "Sharing: Diaspora"
+ },
"Dq6+WH": {
"defaultMessage": "Thematics",
"description": "SearchPage: thematics list widget title"
@@ -227,6 +235,10 @@
"defaultMessage": "{commentCount, plural, =0 {No comments} one {# comment} other {# comments}}",
"description": "PostMeta: comment count value"
},
+ "P0I+Xm": {
+ "defaultMessage": "Journal du hacker",
+ "description": "Sharing: Journal du hacker"
+ },
"P7fxX2": {
"defaultMessage": "All posts in {name}",
"description": "ThematicPage: posts list title"
@@ -295,6 +307,10 @@
"defaultMessage": "Collapse",
"description": "ExpandableWidget: collapse text"
},
+ "WjVBnY": {
+ "defaultMessage": "Twitter",
+ "description": "Sharing: Twitter"
+ },
"X3PDXO": {
"defaultMessage": "Animations:",
"description": "ReduceMotion: toggle label"
@@ -363,6 +379,10 @@
"defaultMessage": "Subject",
"description": "ContactPage: subject field label"
},
+ "csCQQk": {
+ "defaultMessage": "LinkedIn",
+ "description": "Sharing: LinkedIn"
+ },
"dE8xxV": {
"defaultMessage": "Close menu",
"description": "MainNav: close button"
@@ -439,6 +459,10 @@
"defaultMessage": "{thematicsCount, plural, =0 {Thematics:} one {Thematic:} other {Thematics:}}",
"description": "PostMeta: thematics list label"
},
+ "lKZm9t": {
+ "defaultMessage": "Email",
+ "description": "Sharing: Email"
+ },
"mC21ht": {
"defaultMessage": "Number of articles loaded out of the total available.",
"description": "PaginationCursor: loaded articles count aria-label"
diff --git a/src/i18n/fr.json b/src/i18n/fr.json
index a3f5756..6289433 100644
--- a/src/i18n/fr.json
+++ b/src/i18n/fr.json
@@ -67,6 +67,10 @@
"defaultMessage": "Blog",
"description": "BlogPage: page title"
},
+ "7iiaRx": {
+ "defaultMessage": "Facebook",
+ "description": "Sharing: Facebook"
+ },
"8Ls2mD": {
"defaultMessage": "Veuillez remplir le formulaire pour me contacter.",
"description": "ContactPage: page introduction"
@@ -107,6 +111,10 @@
"defaultMessage": "Contact",
"description": "ContactPage: breadcrumb item"
},
+ "Dhow1m": {
+ "defaultMessage": "Diaspora",
+ "description": "Sharing: Diaspora"
+ },
"Dq6+WH": {
"defaultMessage": "Thématiques",
"description": "SearchPage: thematics list widget title"
@@ -227,6 +235,10 @@
"defaultMessage": "{commentCount, plural, =0 {Aucun commentaire} one {# commentaire} other {# commentaires}}",
"description": "PostMeta: comment count value"
},
+ "P0I+Xm": {
+ "defaultMessage": "Journal du hacker",
+ "description": "Sharing: Journal du hacker"
+ },
"P7fxX2": {
"defaultMessage": "Tous les articles dans {name}",
"description": "ThematicPage: posts list title"
@@ -295,6 +307,10 @@
"defaultMessage": "Replier",
"description": "ExpandableWidget: collapse text"
},
+ "WjVBnY": {
+ "defaultMessage": "Twitter",
+ "description": "Sharing: Twitter"
+ },
"X3PDXO": {
"defaultMessage": "Animations :",
"description": "ReduceMotion: toggle label"
@@ -363,6 +379,10 @@
"defaultMessage": "Sujet",
"description": "ContactPage: subject field label"
},
+ "csCQQk": {
+ "defaultMessage": "LinkedIn",
+ "description": "Sharing: LinkedIn"
+ },
"dE8xxV": {
"defaultMessage": "Fermer le menu",
"description": "MainNav: close button"
@@ -439,6 +459,10 @@
"defaultMessage": "{thematicsCount, plural, =0 {Thématiques :} one {Thématique :} other {Thématiques :}}",
"description": "PostMeta: thematics list label"
},
+ "lKZm9t": {
+ "defaultMessage": "Email",
+ "description": "Sharing: Email"
+ },
"mC21ht": {
"defaultMessage": "Nombre d'articles chargés sur le total disponible.",
"description": "PaginationCursor: loaded articles count aria-label"