File size: 1,916 Bytes
246d201
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
import { ModalButton } from "#/components/shared/buttons/modal-button";
import {
  BaseModalTitle,
  BaseModalDescription,
} from "#/components/shared/modals/confirmation-modals/base-modal";
import { ModalBackdrop } from "#/components/shared/modals/modal-backdrop";
import { ModalBody } from "#/components/shared/modals/modal-body";
import { handleCaptureConsent } from "#/utils/handle-capture-consent";

interface AnalyticsConsentFormModalProps {
  onClose: () => void;
}

export function AnalyticsConsentFormModal({

  onClose,

}: AnalyticsConsentFormModalProps) {
  const handleSubmit = (e: React.FormEvent<HTMLFormElement>) => {
    e.preventDefault();
    const formData = new FormData(e.currentTarget);
    const analytics = formData.get("analytics") === "on";

    handleCaptureConsent(analytics);
    localStorage.setItem("analytics-consent", analytics.toString());

    onClose();
  };

  return (
    <ModalBackdrop>

      <form

        data-testid="user-capture-consent-form"

        onSubmit={handleSubmit}

        className="flex flex-col gap-2"

      >

        <ModalBody>

          <BaseModalTitle title="Your Privacy Preferences" />

          <BaseModalDescription>

            We use tools to understand how our application is used to improve

            your experience. You can enable or disable analytics. Your

            preferences will be stored and can be updated anytime.

          </BaseModalDescription>



          <label className="flex gap-2 items-center self-start">

            <input name="analytics" type="checkbox" defaultChecked />

            Send anonymous usage data

          </label>



          <ModalButton

            type="submit"

            text="Confirm Preferences"

            className="bg-primary text-white w-full hover:opacity-80"

          />

        </ModalBody>

      </form>

    </ModalBackdrop>
  );
}