mirror of
https://github.com/Frooodle/Stirling-PDF.git
synced 2026-03-04 02:20:19 +01:00
# Description of Changes <!-- Please provide a summary of the changes, including: - What was changed - Why the change was made - Any challenges encountered Closes #(issue_number) --> --- ## Checklist ### General - [ ] I have read the [Contribution Guidelines](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/CONTRIBUTING.md) - [ ] I have read the [Stirling-PDF Developer Guide](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/devGuide/DeveloperGuide.md) (if applicable) - [ ] I have read the [How to add new languages to Stirling-PDF](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/devGuide/HowToAddNewLanguage.md) (if applicable) - [ ] I have performed a self-review of my own code - [ ] My changes generate no new warnings ### Documentation - [ ] I have updated relevant docs on [Stirling-PDF's doc repo](https://github.com/Stirling-Tools/Stirling-Tools.github.io/blob/main/docs/) (if functionality has heavily changed) - [ ] I have read the section [Add New Translation Tags](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/devGuide/HowToAddNewLanguage.md#add-new-translation-tags) (for new translation tags only) ### UI Changes (if applicable) - [ ] Screenshots or videos demonstrating the UI changes are attached (e.g., as comments or direct attachments in the PR) ### Testing (if applicable) - [ ] I have tested my changes locally. Refer to the [Testing Guide](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/devGuide/DeveloperGuide.md#6-testing) for more details. --------- Co-authored-by: Anthony Stirling <77850077+Frooodle@users.noreply.github.com>
38 lines
1.0 KiB
TypeScript
38 lines
1.0 KiB
TypeScript
import type { TFunction } from 'i18next';
|
|
import { SignatureValidationReportEntry } from '../../../../types/validateSignature';
|
|
import { colorPalette } from './pdfPalette';
|
|
|
|
export const deriveEntryStatus = (
|
|
entry: Pick<SignatureValidationReportEntry, 'error' | 'signatures'>,
|
|
t: TFunction<'translation'>
|
|
) => {
|
|
if (entry.error) {
|
|
return {
|
|
text: t('validateSignature.status.invalid', 'Invalid'),
|
|
color: colorPalette.danger,
|
|
};
|
|
}
|
|
|
|
if (entry.signatures.length === 0) {
|
|
return {
|
|
text: t('validateSignature.noSignaturesShort', 'No signatures'),
|
|
color: colorPalette.neutral,
|
|
};
|
|
}
|
|
|
|
// File-level status is Valid only if every signature is cryptographically valid.
|
|
const allValid = entry.signatures.every((sig) => sig.valid);
|
|
|
|
if (allValid) {
|
|
return {
|
|
text: t('validateSignature.status.valid', 'Valid'),
|
|
color: colorPalette.success,
|
|
};
|
|
}
|
|
|
|
return {
|
|
text: t('validateSignature.status.invalid', 'Invalid'),
|
|
color: colorPalette.danger,
|
|
};
|
|
};
|