diff --git a/app/src/assets/branding/CQEN-background.png b/app/src/assets/branding/CQEN-background.png new file mode 100644 index 00000000..9df91894 Binary files /dev/null and b/app/src/assets/branding/CQEN-background.png differ diff --git a/app/src/assets/branding/QC-credential-branding.ts b/app/src/assets/branding/QC-credential-branding.ts index 56b4860a..f96316bf 100644 --- a/app/src/assets/branding/QC-credential-branding.ts +++ b/app/src/assets/branding/QC-credential-branding.ts @@ -1,6 +1,6 @@ import { types } from 'aries-bifold' -type CardLayoutOverlay10 = types.oca.CardLayoutOverlay10 +type CardLayoutOverlay11 = types.oca.CardLayoutOverlay11 type MetaOverlay = types.oca.MetaOverlay type FormatOverlay = types.oca.FormatOverlay type LabelOverlay = types.oca.LabelOverlay @@ -9,6 +9,7 @@ type CharacterEncodingOverlay = types.oca.CharacterEncodingOverlay export enum CREDENTIALS { ANIG_TEST = "Ep31SvFAetugFPe5CGzJxt:2:Attestation numérique d'identité gouvernemental (EXP):1.0", + CQEN_DEMO = 'FUKLxsjrYSHgScLbHuPTo4:2:CQENDroitAccesVirtuel:0.1', } const ANIGCaptureBase: CaptureBaseOverlay = { @@ -27,6 +28,15 @@ const ANIGCaptureBase: CaptureBaseOverlay = { }, } as CharacterEncodingOverlay +const CQENCaptureBase: CaptureBaseOverlay = { + type: 'spec/overlays/character_encoding/1.0', + captureBase: '', + attributeCharacterEncoding: { + email: 'utf-8', + time: 'utf-8', + }, +} as CharacterEncodingOverlay + const ANIGLabelOverlayFr: LabelOverlay = { type: 'spec/overlays/label/1.0', captureBase: '', @@ -55,6 +65,26 @@ const ANIGLabelOverlayEn: LabelOverlay = { }, } as LabelOverlay +const CQENLabelOverlayFr: LabelOverlay = { + type: 'spec/overlays/label/1.0', + capture_base: '', + language: 'fr', + attributeLabels: { + email: 'Courriel', + time: "Date d'émission", + }, +} + +const CQENLabelOverlayEn: LabelOverlay = { + type: 'spec/overlays/label/1.0', + captureBase: '', + language: 'en', + attributeLabels: { + email: 'Email', + time: 'Issuing date', + }, +} + const ANIGFormatOverlay: FormatOverlay = { type: 'spec/overlays/format/1.0', captureBase: '', @@ -68,20 +98,40 @@ const ANIGFormatOverlay: FormatOverlay = { }, } as FormatOverlay -const ANIGCardOverlay: CardLayoutOverlay10 = { - type: 'spec/overlays/card_layout/1.0', - imageSource: - '', - header: { - imageSource: - '', - color: '#FFFFFF', - backgroundColor: '#052D4F', +const CQENFormatOverlay: FormatOverlay = { + captureBase: '', + type: 'spec/overlays/format/1.0', + attributeFormats: { + email: '[A-Z0-9._%+-]+@[A-Z0-9.-]+\\.[A-Z]{2,}', + time: 'YY-MM-DD [0-9]{2}:[0-9]{2}:[0-9]{2}.[0-9]{6}', + }, +} + +const ANIGCardOverlay: CardLayoutOverlay11 = { + type: 'spec/overlays/card_layout/1.1', + captureBase: '', + logo: { + src: require('./logo-quebec.png'), + }, + primaryBackgroundColor: '#FFFFFF', + secondaryBackgroundColor: '#095797', + backgroundImage: { + src: require('./carte-anig-demo.png'), + }, +} as CardLayoutOverlay11 + +const CQENCardOverlay: CardLayoutOverlay11 = { + type: 'spec/overlays/card_layout/1.1', + captureBase: '', + logo: { + src: require('./logo-quebec.png'), }, - footer: { - color: '#FFFFFF', + primaryBackgroundColor: '#F9F9F9', + secondaryBackgroundColor: '#757575', + backgroundImage: { + src: require('./CQEN-background.png'), }, -} as CardLayoutOverlay10 +} as CardLayoutOverlay11 const ANIGBundle = { captureBase: { @@ -121,6 +171,37 @@ const ANIGBundle = { ], } +const CQENBundle = { + captureBase: { + captureBase: '', + type: 'spec/capture_base/1.0', + attributes: { + email: 'Email', + time: 'Issuance timestamp', + }, + } as CaptureBaseOverlay, + overlays: [ + { + type: 'spec/overlays/meta/1.0', + language: 'fr', + name: 'Port-E', + issuerName: "Centre Québécois d'Excellence Numérique", + } as MetaOverlay, + { + type: 'spec/overlays/meta/1.0', + language: 'en', + name: 'Port-E', + issuerName: "Quebec's Digital Center of Excellence", + } as MetaOverlay, + CQENCaptureBase, + CQENLabelOverlayFr, + CQENLabelOverlayEn, + CQENFormatOverlay, + CQENCardOverlay, + ], +} + export default { [CREDENTIALS.ANIG_TEST]: ANIGBundle, + [CREDENTIALS.CQEN_DEMO]: CQENBundle, } diff --git a/app/src/assets/branding/carte-anig-demo.png b/app/src/assets/branding/carte-anig-demo.png new file mode 100644 index 00000000..ba276bf6 Binary files /dev/null and b/app/src/assets/branding/carte-anig-demo.png differ diff --git a/app/src/assets/branding/logo-quebec.png b/app/src/assets/branding/logo-quebec.png new file mode 100644 index 00000000..f77ada45 Binary files /dev/null and b/app/src/assets/branding/logo-quebec.png differ diff --git a/app/src/assets/branding/quebec.png b/app/src/assets/branding/quebec.png new file mode 100644 index 00000000..2eee950b Binary files /dev/null and b/app/src/assets/branding/quebec.png differ diff --git a/app/src/index.ts b/app/src/index.ts index 749632b0..ae368115 100644 --- a/app/src/index.ts +++ b/app/src/index.ts @@ -47,7 +47,7 @@ const configuration: ConfigurationContext = { OCABundleResolver: new types.oca.OCABundleResolver( // eslint-disable-next-line @typescript-eslint/no-var-requires bundle as unknown as types.oca.Bundles, - { cardOverlayType: types.oca.CardOverlayType.CardLayout10 } + { cardOverlayType: types.oca.CardOverlayType.CardLayoutOverlay11 } ), record: Record, PINSecurity: { rules: PINValidationRules, displayHelper: true },