diff --git a/public/locales/bg/common.json b/public/locales/bg/common.json
index 9d892fcdc..77ccfdcd4 100644
--- a/public/locales/bg/common.json
+++ b/public/locales/bg/common.json
@@ -56,17 +56,22 @@
"link": "Линк",
"components": {
"footer": {
- "about-us": "За доброволците",
+ "donatе": "Дарете",
+ "about-us": "За нас",
+ "resources": "Ресурси",
+ "others": "Други",
+ "all-campaigns": "Всички кампании",
+ "suggest-campaign": "Предложете кампания",
+ "who-are-we": "Кои сме ние?",
"about-project": "За проекта",
- "docs": "Документация",
- "dev-docs": "Техническа Документация",
- "support": "Станете доброволец",
+ "support-us": "Подкрепете ни",
+ "become-a-volunteer": "Станете доброволец",
+ "reports": "Отчети",
"contact": "Контакти",
+ "faq": "Често задавани въпроси",
"privacy-policy": "Защита на лични данни",
"terms-of-service": "Общи условия",
- "hosting-partner": "Хостинг партньор:",
- "copyrights": "Podkrepi.bg ©2022 Всички права запазени.",
- "version": "Версия"
+ "copyrights": "Podkrepi.bg ©2022 Всички права запазени."
}
},
"or": "или",
diff --git a/public/locales/en/common.json b/public/locales/en/common.json
index 13d10913c..221140550 100644
--- a/public/locales/en/common.json
+++ b/public/locales/en/common.json
@@ -2,7 +2,7 @@
"nav": {
"home": "Home",
"about": {
- "about-project": "The Project",
+ "about-project": "The project",
"about-us": "About us",
"who-are-we": "Who are we?",
"support_us": "Support us",
@@ -14,7 +14,7 @@
"index": "Campaigns",
"all-campaigns": "All campaigns",
"create": "Suggest a campaign",
- "faq": "Frequently Asked Questions"
+ "faq": "Frequently asked questions"
},
"admin": {
"index": "Administration",
@@ -56,17 +56,22 @@
"support": "Donate",
"components": {
"footer": {
+ "donatе": "Donate",
"about-us": "About us",
- "about-project": "The project",
- "docs": "Documentation",
- "dev-docs": "Technical Documentation",
- "support": "Support us",
+ "resources": "Resources",
+ "others": "Others",
+ "all-campaigns": "All campaigns",
+ "who-are-we": "Who are we?",
+ "suggest-campaign": "Suggest a campaign",
+ "about-project": "About the project",
+ "support-us": "Support us",
+ "become-a-volunteer": "Become a volunteer",
+ "reports": "Reports",
"contact": "Contact",
+ "faq": "Frequently asked questions",
"privacy-policy": "Privacy Policy",
- "terms-of-service": "Terms of service",
- "hosting-partner": "Hosting partner:",
- "copyrights": "Podkrepi.bg ©2022 All rights reserved.",
- "version": "Version"
+ "terms-of-service": "Terms of Service",
+ "copyrights": "Podkrepi.bg ©2022 All rights reserved."
}
},
"or": "or",
diff --git a/src/components/layout/Footer.tsx b/src/components/layout/Footer.tsx
deleted file mode 100644
index ae1894652..000000000
--- a/src/components/layout/Footer.tsx
+++ /dev/null
@@ -1,156 +0,0 @@
-import { Grid, Container, lighten, useTheme, useMediaQuery } from '@mui/material'
-import Link from 'next/link'
-import { useRouter } from 'next/router'
-import { useTranslation } from 'next-i18next'
-import { Facebook, Instagram, LinkedIn, YouTube } from '@mui/icons-material'
-import PodkrepiLogo from 'components/brand/PodkrepiLogo'
-import ExternalLink from 'components/common/ExternalLink'
-import { routes, socialUrls, staticUrls } from 'common/routes'
-
-type FooterLink = {
- label: string
- href: string
- external?: boolean
-}
-const footerItems: FooterLink[][] = [
- [
- { label: 'components.footer.about-us', href: routes.about },
- { label: 'components.footer.about-project', href: routes.aboutProject },
- { label: 'components.footer.support', href: routes.support },
- { label: 'components.footer.contact', href: routes.contact },
- { external: true, label: 'nav.blog', href: staticUrls.blog },
- ],
- [
- { external: true, label: 'GitHub', href: staticUrls.github },
- { external: true, label: 'components.footer.docs', href: staticUrls.projectDocs },
- { external: true, label: 'components.footer.dev-docs', href: staticUrls.devDocs },
- ],
- [
- { label: 'components.footer.privacy-policy', href: routes.privacyPolicy },
- { label: 'components.footer.terms-of-service', href: routes.termsOfService },
- ],
-]
-
-export default function Footer() {
- return (
- ({
- backgroundColor: theme.palette.primary.dark,
- color: lighten(theme.palette.primary.main, 0.75),
- '& a': {
- color: lighten(theme.palette.primary.main, 0.75),
- '&:hover': {
- color: lighten(theme.palette.primary.main, 0.55),
- },
- },
- })}>
-
- ({
- xs: {
- textAlign: 'center',
- padding: theme.spacing(5, 0),
- },
- textAlign: 'left',
- padding: theme.spacing(5),
- })}>
-
-
-
-
-
-
-
-
-
- )
-}
-
-const InfoGrid = () => {
- const { t } = useTranslation()
- const { locale } = useRouter()
-
- return (
-
-
-
-
-
-
-
-
-
-
-
- {t('components.footer.copyrights')}
-
- {t('components.footer.hosting-partner')}{' '}
-
- SuperHosting.BG
-
-
- {process.env.APP_VERSION && (
-
- {t('components.footer.version')} {process.env.APP_VERSION}
-
- )}
-
- )
-}
-
-const SocialIcons = () => {
- const theme = useTheme()
- const sm = useMediaQuery(theme.breakpoints.up('sm'))
- return (
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- )
-}
-const FooterLinks = () => {
- const { t } = useTranslation()
- return (
-
- {footerItems.map((links, column) => (
-
-
- {links.map(({ label, href, external }, row) => (
-
- {external ? (
- {t(label)}
- ) : (
-
- {t(label)}
-
- )}
-
- ))}
-
-
- ))}
-
- )
-}
diff --git a/src/components/layout/Footer/Footer.styled.tsx b/src/components/layout/Footer/Footer.styled.tsx
new file mode 100644
index 000000000..fff0a7ef8
--- /dev/null
+++ b/src/components/layout/Footer/Footer.styled.tsx
@@ -0,0 +1,61 @@
+import { Container, Grid, lighten, Typography } from '@mui/material'
+import { styled } from '@mui/system'
+
+import theme from 'common/theme'
+
+export const Root = styled(Container)(() => ({
+ display: 'flex',
+ justifyContent: 'center',
+ textAlign: 'left',
+ backgroundColor: theme.palette.primary.dark,
+ color: lighten(theme.palette.primary.main, 0.75),
+
+ '& a': {
+ color: lighten(theme.palette.primary.main, 0.75),
+
+ '&:hover': {
+ color: lighten(theme.palette.primary.main, 0.55),
+ },
+ },
+}))
+
+export const FooterWrapper = styled(Grid)(() => ({
+ margin: theme.spacing(5),
+}))
+
+export const FooterLinksWrapper = styled(Grid)(() => ({
+ margin: theme.spacing(6, 0, 3, 0),
+
+ [theme.breakpoints.up('sm')]: {
+ marginTop: 0,
+ },
+
+ [theme.breakpoints.up('md')]: {
+ display: 'inline-flex',
+ gap: theme.spacing(1),
+ },
+}))
+
+export const FooterLinkTitle = styled(Typography)(() => ({
+ fontWeight: 600,
+ fontSize: theme.typography.pxToRem(16),
+ marginBottom: theme.spacing(1),
+ paddingBottom: theme.spacing(0.5),
+ width: 'fit-content',
+ borderBottom: `2px solid ${lighten(theme.palette.primary.main, 0.4)}`,
+}))
+
+export const FooterLink = styled(Grid)(() => ({
+ padding: theme.spacing(0.5, 0),
+}))
+
+export const Copyright = styled(Grid)(() => ({
+ borderTop: `2px solid ${lighten(theme.palette.primary.main, 0.4)}`,
+ paddingTop: theme.spacing(3),
+}))
+
+export const SocialIconsWrapper = styled(Grid)(() => ({
+ display: 'flex',
+ gap: theme.spacing(1),
+ marginTop: theme.spacing(2),
+}))
diff --git a/src/components/layout/Footer/Footer.tsx b/src/components/layout/Footer/Footer.tsx
new file mode 100644
index 000000000..f997e9c7f
--- /dev/null
+++ b/src/components/layout/Footer/Footer.tsx
@@ -0,0 +1,22 @@
+import { useTranslation } from 'next-i18next'
+
+import { LogoSocialIcons } from './LogoSocialIcons'
+import { FooterLinks } from './FooterLinks'
+
+import { Copyright, FooterWrapper, Root } from './Footer.styled'
+
+export default function Footer() {
+ const { t } = useTranslation()
+
+ return (
+
+
+
+
+
+ {t('components.footer.copyrights')}
+
+
+
+ )
+}
diff --git a/src/components/layout/Footer/FooterLinks.tsx b/src/components/layout/Footer/FooterLinks.tsx
new file mode 100644
index 000000000..fa6bff6d2
--- /dev/null
+++ b/src/components/layout/Footer/FooterLinks.tsx
@@ -0,0 +1,34 @@
+import { useTranslation } from 'next-i18next'
+import Link from 'next/link'
+
+import { Grid } from '@mui/material'
+
+import ExternalLink from 'components/common/ExternalLink'
+import { footerLinks } from './helpers/FooterData'
+
+import { FooterLink, FooterLinksWrapper, FooterLinkTitle } from './Footer.styled'
+
+export const FooterLinks = () => {
+ const { t } = useTranslation()
+
+ return (
+
+ {footerLinks.map((data, index) => (
+
+ {t(data.title)}
+ {data.links.map(({ label, href, external }, linkIndex) => (
+
+ {external ? (
+ {t(label)}
+ ) : (
+
+ {t(label)}
+
+ )}
+
+ ))}
+
+ ))}
+
+ )
+}
diff --git a/src/components/layout/Footer/LogoSocialIcons.tsx b/src/components/layout/Footer/LogoSocialIcons.tsx
new file mode 100644
index 000000000..98c9108fb
--- /dev/null
+++ b/src/components/layout/Footer/LogoSocialIcons.tsx
@@ -0,0 +1,25 @@
+import Link from 'next/link'
+import { useRouter } from 'next/router'
+
+import { Grid } from '@mui/material'
+
+import { routes } from 'common/routes'
+import PodkrepiLogo from 'components/brand/PodkrepiLogo'
+import { SocialIcons } from './SocialIcons'
+
+export const LogoSocialIcons = () => {
+ const { locale } = useRouter()
+
+ return (
+
+
+
+
+
+
+
+
+
+
+ )
+}
diff --git a/src/components/layout/Footer/SocialIcons.tsx b/src/components/layout/Footer/SocialIcons.tsx
new file mode 100644
index 000000000..5c5c2b097
--- /dev/null
+++ b/src/components/layout/Footer/SocialIcons.tsx
@@ -0,0 +1,25 @@
+import { Facebook, LinkedIn, YouTube, Instagram } from '@mui/icons-material'
+
+import { socialUrls } from 'common/routes'
+import ExternalLink from 'components/common/ExternalLink'
+
+import { SocialIconsWrapper } from './Footer.styled'
+
+export const SocialIcons = () => {
+ return (
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ )
+}
diff --git a/src/components/layout/Footer/helpers/FooterData.tsx b/src/components/layout/Footer/helpers/FooterData.tsx
new file mode 100644
index 000000000..76fd74115
--- /dev/null
+++ b/src/components/layout/Footer/helpers/FooterData.tsx
@@ -0,0 +1,48 @@
+import { routes, staticUrls } from 'common/routes'
+
+export type FooterLink = {
+ label: string
+ href: string
+ external?: boolean
+}
+
+type FooterSection = {
+ title: string
+ links: FooterLink[]
+}
+
+export const footerLinks: FooterSection[] = [
+ {
+ title: 'components.footer.donatе',
+ links: [
+ { label: 'components.footer.all-campaigns', href: routes.campaigns.index },
+ { label: 'components.footer.suggest-campaign', href: routes.campaigns.create },
+ ],
+ },
+ {
+ title: 'components.footer.about-us',
+ links: [
+ { label: 'components.footer.who-are-we', href: routes.about },
+ { label: 'components.footer.about-project', href: routes.aboutProject },
+ { label: 'components.footer.support-us', href: routes.support_us },
+ { label: 'components.footer.become-a-volunteer', href: routes.support },
+ { label: 'components.footer.reports', href: routes.reports },
+ ],
+ },
+ {
+ title: 'components.footer.resources',
+ links: [
+ { external: true, label: 'nav.blog', href: staticUrls.blog },
+ { label: 'components.footer.contact', href: routes.contact },
+ { label: 'components.footer.faq', href: routes.faq },
+ ],
+ },
+ {
+ title: 'components.footer.others',
+ links: [
+ { label: 'components.footer.privacy-policy', href: routes.privacyPolicy },
+ { label: 'components.footer.terms-of-service', href: routes.termsOfService },
+ { external: true, label: 'GitHub', href: staticUrls.github },
+ ],
+ },
+]
diff --git a/src/components/layout/Layout.tsx b/src/components/layout/Layout.tsx
index a2a3db914..50cd4bfdb 100644
--- a/src/components/layout/Layout.tsx
+++ b/src/components/layout/Layout.tsx
@@ -3,7 +3,7 @@ import { useMemo, useState } from 'react'
import { useTranslation } from 'next-i18next'
import { Box, BoxProps, Container, ContainerProps, Typography } from '@mui/material'
-import Footer from 'components/layout/Footer'
+import Footer from 'components/layout/Footer/Footer'
import { defaultOgImage } from 'common/routes'
import Snackbar from 'components/layout/Snackbar'
import DetailsModal from 'components/modal/DetailsModal'
diff --git a/yarn.lock b/yarn.lock
index 2dacbb380..d57dc5531 100644
--- a/yarn.lock
+++ b/yarn.lock
@@ -6266,11 +6266,6 @@ pegjs@^0.10.0:
resolved "https://registry.yarnpkg.com/pegjs/-/pegjs-0.10.0.tgz#cf8bafae6eddff4b5a7efb185269eaaf4610ddbd"
integrity sha1-z4uvrm7d/0tafvsYUmnqr0YQ3b0=
-performance-now@^2.1.0:
- version "2.1.0"
- resolved "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz"
- integrity sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=
-
picocolors@^1.0.0:
version "1.0.0"
resolved "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz"
@@ -6595,13 +6590,6 @@ quill@^1.3.7, quill@^1.x:
parchment "^1.1.4"
quill-delta "^3.6.2"
-raf@^3.4.0:
- version "3.4.1"
- resolved "https://registry.npmjs.org/raf/-/raf-3.4.1.tgz"
- integrity sha512-Sq4CW4QhwOHE8ucn6J34MqtZCeWFP2aQSmrlroYgqAV1PjStIhJXxYuTgUIfkEk7zTLjmIjLmU5q+fbD1NnOJA==
- dependencies:
- performance-now "^2.1.0"
-
ramda@^0.26.1:
version "0.26.1"
resolved "https://registry.npmjs.org/ramda/-/ramda-0.26.1.tgz"