Files
SaaS-PDF/frontend/src/pages/TermsPage.tsx
Your Name f933ffa8a0 chore: update project branding from SaaS-PDF to Dociva
- Updated robots.txt to reflect new site name and sitemap URL.
- Modified sitemap.xml to change all URLs from saas-pdf.com to dociva.io.
- Changed storage key for site assistant in SiteAssistant.tsx.
- Updated SEOHead.tsx to change site name in meta tags.
- Translated app name and related text in Arabic, English, and French JSON files.
- Updated contact email in ContactPage.tsx, PrivacyPage.tsx, and TermsPage.tsx.
- Changed internal admin page title to reflect new branding.
- Updated pricing page meta description to reference Dociva.
- Adjusted Nginx configuration for new domain.
- Modified deployment script to reflect new branding.
- Updated sitemap generation script to use new domain.
2026-03-16 21:51:12 +02:00

69 lines
2.1 KiB
TypeScript

import { useTranslation } from 'react-i18next';
import SEOHead from '@/components/seo/SEOHead';
import { generateWebPage } from '@/utils/seo';
import { FILE_RETENTION_MINUTES } from '@/config/toolLimits';
const LAST_UPDATED = '2026-03-06';
const CONTACT_EMAIL = 'support@dociva.io';
export default function TermsPage() {
const { t } = useTranslation();
const useItems = t('pages.terms.useItems', { returnObjects: true }) as string[];
const fileItems = t('pages.terms.fileItems', { minutes: FILE_RETENTION_MINUTES, returnObjects: true }) as string[];
return (
<>
<SEOHead
title={t('pages.terms.title')}
description={t('pages.terms.metaDescription')}
path="/terms"
jsonLd={generateWebPage({
name: t('pages.terms.title'),
description: t('pages.terms.metaDescription'),
url: `${window.location.origin}/terms`,
})}
/>
<div className="prose mx-auto max-w-2xl dark:prose-invert">
<h1>{t('pages.terms.title')}</h1>
<p><em>{t('pages.terms.lastUpdated', { date: LAST_UPDATED })}</em></p>
<h2>{t('pages.terms.acceptanceTitle')}</h2>
<p>{t('pages.terms.acceptanceText')}</p>
<h2>{t('pages.terms.serviceTitle')}</h2>
<p>{t('pages.terms.serviceText')}</p>
<h2>{t('pages.terms.useTitle')}</h2>
{Array.isArray(useItems) && (
<ul>
{useItems.map((item, idx) => <li key={idx}>{item}</li>)}
</ul>
)}
<h2>{t('pages.terms.fileTitle')}</h2>
{Array.isArray(fileItems) && (
<ul>
{fileItems.map((item, idx) => <li key={idx}>{item}</li>)}
</ul>
)}
<h2>{t('pages.terms.liabilityTitle')}</h2>
<p>{t('pages.terms.liabilityText')}</p>
<h2>{t('pages.terms.ipTitle')}</h2>
<p>{t('pages.terms.ipText')}</p>
<h2>{t('pages.terms.changesTitle')}</h2>
<p>{t('pages.terms.changesText')}</p>
<h2>{t('pages.terms.contactTitle')}</h2>
<p>
{t('pages.terms.contactText')}{' '}
<a href={`mailto:${CONTACT_EMAIL}`}>{CONTACT_EMAIL}</a>.
</p>
</div>
</>
);
}