Skip to content

Commit

Permalink
Allow displaying third part opt in/opt out info for iframeEmbed
Browse files Browse the repository at this point in the history
REDMINE-20438
  • Loading branch information
tf committed Sep 20, 2023
1 parent b6501ce commit 735c2ac
Show file tree
Hide file tree
Showing 5 changed files with 88 additions and 7 deletions.
16 changes: 16 additions & 0 deletions entry_types/scrolled/config/locales/new/iframe_consent.de.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
de:
pageflow_scrolled:
editor:
content_elements:
iframeEmbed:
attributes:
requireConsent:
label: "Datenschutz-Einwilligung aktivieren"
inline_help: |-
iframe erst laden, nachdem Besucher der
Datenverarbeitung durch die eingebettete Seite
zugestimmt hat.
help_texts:
missingConsentVendor: |-
Für den Anbieter der angegeben URL stehen keine
Datenschutzangaben zur Verfügung.
15 changes: 15 additions & 0 deletions entry_types/scrolled/config/locales/new/iframe_consent.en.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
en:
pageflow_scrolled:
editor:
content_elements:
iframeEmbed:
attributes:
requireConsent:
label: "Display privacy opt-in"
inline_help: |
Only load iframe after the visitor has given
consent to the data processing by the embedded page.
help_texts:
missingConsentVendor: |-
No privacy policy information available for the provider
of the given URL.
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,8 @@ import {
ContentElementBox,
ContentElementFigure,
FitViewport,
ThirdPartyOptIn,
ThirdPartyOptOutInfo,
useContentElementEditorState,
useContentElementLifecycle,
usePortraitOrientation,
Expand Down Expand Up @@ -37,15 +39,28 @@ export function IframeEmbed({configuration}) {
<ContentElementBox>
<ContentElementFigure configuration={configuration}>
<FitViewport.Content>
{shouldLoad &&
<iframe className={classNames(styles.iframe,
styles[`scale-${configuration.scale}`])}
title={configuration.title}
src={configuration.source} />}
<ThirdPartyOptIn>
{shouldLoad &&
<iframe className={classNames(styles.iframe,
styles[`scale-${configuration.scale}`])}
title={configuration.title}
src={configuration.source} />}
</ThirdPartyOptIn>
</FitViewport.Content>
<OptOutInfo configuration={configuration} />
</ContentElementFigure>
</ContentElementBox>
</FitViewport>
</div>
);
}

function OptOutInfo({configuration}) {
if (!configuration.requireConsent) {
return null;
}

return (
<ThirdPartyOptOutInfo />
);
}
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
import I18n from 'i18n-js';
import {editor} from 'pageflow-scrolled/editor';
import {TextInputView, SelectInputView} from 'pageflow/ui';
import {InfoBoxView} from 'pageflow/editor';
import {TextInputView, SelectInputView, CheckBoxInputView} from 'pageflow/ui';

import pictogram from './pictogram.svg';

Expand All @@ -12,9 +14,19 @@ editor.contentElementTypes.register('iframeEmbed', {
supportedPositions: ['inline', 'sticky', 'left', 'right'],
supportedWidthRange: ['xxs', 'full'],

configurationEditor() {
configurationEditor({entry}) {
this.tab('general', function() {
this.input('source', TextInputView);
this.input('requireConsent', CheckBoxInputView);
this.view(InfoBoxView, {
level: 'error',
text: I18n.t(
'pageflow_scrolled.editor.content_elements.iframeEmbed.help_texts.missingConsentVendor'
),
visibleBinding: ['source', 'requireConsent'],
visible: ([source, requireConsent]) =>
source && requireConsent && !entry.consentVendors.fromUrl(source),
});
this.input('title', TextInputView);
this.input('aspectRatio', SelectInputView, {
values: aspectRatios
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
import '../frontend';
import {storiesOfContentElement} from 'pageflow-scrolled/spec/support/stories';

storiesOfContentElement(module, {
typeName: 'iframeEmbed',
baseConfiguration: {
source: 'https://example.com',
caption: 'Some caption'
},
consent: {
configuration: {
requireConsent: true
}
},
variants: [
{
name: 'With Consent',
configuration: {
requireConsent: true
}
}
]
});

0 comments on commit 735c2ac

Please sign in to comment.