Skip to content

Commit

Permalink
set up Flutter listeners and callHandlers
Browse files Browse the repository at this point in the history
  • Loading branch information
gilluminate committed Dec 11, 2024
1 parent dab4de4 commit 838a11a
Show file tree
Hide file tree
Showing 7 changed files with 47 additions and 25 deletions.
23 changes: 12 additions & 11 deletions clients/fides-js/src/components/Overlay.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -69,12 +69,11 @@ const Overlay: FunctionComponent<Props> = ({
isUiBlocking,
}) => {
const { i18n } = useI18n();
const delayBannerMilliseconds = 100;
const delayModalLinkMilliseconds = 200;
const hasMounted = useHasMounted();
const isAutomatedConsent = isConsentOverride(options);

const showBanner = useMemo(
const shouldShowBanner = useMemo(
() =>
!isAutomatedConsent &&
!options.fidesDisableBanner &&
Expand All @@ -84,8 +83,9 @@ const Overlay: FunctionComponent<Props> = ({
);

const [bannerIsOpen, setBannerIsOpen] = useState(
options.fidesEmbed ? showBanner : false,
options.fidesEmbed ? shouldShowBanner : false,
);

const modalLinkRef = useRef<HTMLElement | null>(null);

useEffect(() => {
Expand Down Expand Up @@ -142,15 +142,16 @@ const Overlay: FunctionComponent<Props> = ({
}
}, [options, onOpen, bannerIsOpen]);

// The delay is needed for the banner CSS animation
useEffect(() => {
if (!shouldShowBanner) {
return () => {};
}
// The delay is needed for the banner CSS animation
const delayBanner = setTimeout(() => {
if (showBanner) {
setBannerIsOpen(true);
}
}, delayBannerMilliseconds);
setBannerIsOpen(true);
});
return () => clearTimeout(delayBanner);
}, [showBanner, setBannerIsOpen]);
}, [shouldShowBanner, setBannerIsOpen]);

useEffect(() => {
if (options.fidesEmbed || !experience || options.modalLinkId === "") {
Expand Down Expand Up @@ -234,11 +235,11 @@ const Overlay: FunctionComponent<Props> = ({

return (
<div id={FIDES_OVERLAY_WRAPPER} tabIndex={-1}>
{showBanner && bannerIsOpen && isUiBlocking && (
{shouldShowBanner && bannerIsOpen && isUiBlocking && (
<div className="fides-modal-overlay" />
)}

{showBanner
{shouldShowBanner
? renderBanner({
isOpen: bannerIsOpen,
isEmbedded: options.fidesEmbed,
Expand Down
4 changes: 2 additions & 2 deletions clients/fides-js/src/components/notices/NoticeOverlay.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -258,12 +258,12 @@ const NoticeOverlay: FunctionComponent<OverlayProps> = ({
if (isConsentOverride(options) && experience.privacy_notices) {
if (options.fidesConsentOverride === ConsentMethod.ACCEPT) {
fidesDebugger(
"Consent automatically accepted by fides_accept_all override!",
"Consent automatically accepted by fides_consent_override!",
);
handleAcceptAll(true);
} else if (options.fidesConsentOverride === ConsentMethod.REJECT) {
fidesDebugger(
"Consent automatically rejected by fides_reject_all override!",
"Consent automatically rejected by fides_consent_override!",
);
handleRejectAll(true);
}
Expand Down
8 changes: 4 additions & 4 deletions clients/fides-js/src/components/tcf/TcfOverlay.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -362,12 +362,12 @@ export const TcfOverlay = ({
useEffect(() => {
if (options.fidesConsentOverride === ConsentMethod.ACCEPT) {
fidesDebugger(
"Consent automatically accepted by fides_accept_all override!",
"Consent automatically accepted by fides_consent_override!",
);
handleAcceptAll(true);
} else if (options.fidesConsentOverride === ConsentMethod.REJECT) {
fidesDebugger(
"Consent automatically rejected by fides_reject_all override!",
"Consent automatically rejected by fides_consent_override!",
);
handleRejectAll(true);
}
Expand All @@ -389,7 +389,7 @@ export const TcfOverlay = ({
}, [cookie, options.debug]);

const handleDismiss = useCallback(() => {
handleUpdateAllPreferences(ConsentMethod.DISMISS, draftIds!);
handleUpdateAllPreferences(ConsentMethod.DISMISS, draftIds);
}, [handleUpdateAllPreferences, draftIds]);

const experienceConfig =
Expand Down Expand Up @@ -461,7 +461,7 @@ export const TcfOverlay = ({
: () => (
<TcfTabs
experience={experience}
enabledIds={draftIds!}
enabledIds={draftIds}
onChange={(updatedIds) => {
setDraftIds(updatedIds);
dispatchFidesEvent("FidesUIChanged", cookie, options.debug);
Expand Down
2 changes: 1 addition & 1 deletion clients/sample-app/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion clients/sample-app/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
"react": "18.3.1",
"react-dom": "18.3.1",
"react-hook-form": "7.38.0",
"react-select": "^5.7.3",
"react-select": "^5.8.3",
"sass": "1.55.0"
},
"devDependencies": {
Expand Down
24 changes: 18 additions & 6 deletions clients/sample-app/src/pages/embedded-consent.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -61,14 +61,17 @@ const IndexPage = ({ gtmContainerId, privacyCenterUrl }: Props) => {
<script>{`window.fides_overrides = { fides_embed: true, fides_disable_banner: true }`}</script>
{/* Allow the embedded consent modal to fill the screen */}
<style>{`
#fides-embed-container {
--fides-overlay-width: 'auto'
/* Embedded overlay is set to inherit page styling, but in this case there is no other page information so we'll set these styles the modal defaults. */
body {
font-family: var(--fides-overlay-font-family);
color: var(--fides-overlay-font-color-dark);
font-size: var(--fides-overlay-font-size-body);
background-color: var(--fides-overlay-background-color);
}
body {
font-family: "Inter", sans-serif;
color: #171923;
font-size: 14px;
/* Allow the embedded consent modal to fill the width of the screen */
#fides-embed-container {
--fides-overlay-width: 'auto'
}
`}</style>
</Head>
Expand Down Expand Up @@ -101,6 +104,15 @@ const IndexPage = ({ gtmContainerId, privacyCenterUrl }: Props) => {
`}
</Script>
) : null}
{/* Support for Flutter InAppWebView communication https://inappwebview.dev/docs/webview/javascript/communication */}
{/* eslint-disable-next-line @next/next/no-before-interactive-script-outside-document */}
<Script id="flutter-inappwebview" strategy="beforeInteractive">
{`window.addEventListener("FidesInitialized", function() {
Fides.onFidesEvent("FidesUpdated", (detail) => {
window.flutter_inappwebview?.callHandler('FidesUpdated', detail);
});
}, {once: true});`}
</Script>
<div id="fides-embed-container" />
</>
);
Expand Down
9 changes: 9 additions & 0 deletions clients/sample-app/src/pages/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,15 @@ const IndexPage = ({ gtmContainerId, privacyCenterUrl, products }: Props) => {
`}
</Script>
) : null}
{/* Support for Flutter InAppWebView communication https://inappwebview.dev/docs/webview/javascript/communication */}
{/* eslint-disable-next-line @next/next/no-before-interactive-script-outside-document */}
<Script id="flutter-inappwebview" strategy="beforeInteractive">
{`window.addEventListener("FidesInitialized", function() {
Fides.onFidesEvent("FidesUpdated", (detail) => {
window.flutter_inappwebview?.callHandler('FidesUpdated', detail);
});
}, {once: true});`}
</Script>
<Home privacyCenterUrl={privacyCenterUrl} products={products} />
</>
);
Expand Down

0 comments on commit 838a11a

Please sign in to comment.