summaryrefslogtreecommitdiff
path: root/src/routes/contact/index.svelte
blob: 84d9621fbf385f1f4d0b540d0dc550da48e799a1 (plain)
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
<script context="module">
  import { browser } from '$app/env';
  import { toast } from '@zerodevx/svelte-toast'
  import HCaptcha from 'svelte-hcaptcha';

  let submission = {
    name: '',
    email: '',
    message: '',
    captchaToken: '',
  };

  let captcha;

  function handleSubmit (e) {
    e.preventDefault();

    if (browser) {
      const sendToast = toast.push('Sending...', {
        duration: 300,
        initial: 0,
        next: 0.2,
        dismissable: false
      });
      fetch('/contact/submit', {
        method: "POST",
        body: JSON.stringify(submission)
      })
        .then((x) => x.json())
        .then((x) => {
          toast.set(sendToast, { next: 1 });

          if (x.success) {
            toast.push('Success! Reloading...', {
              theme: {
                '--toastBackground': '#48BB78',
                '--toastBarBackground': '#2F855A'
              },
              duration: 1000,
              onpop: () => { window.location.reload(); },
            });
          } else if (x.error) {
            toast.push(x.error, {
              theme: {
                '--toastBackground': '#F56565',
                '--toastBarBackground': '#C53030'
              }
            });
          }
        })
        .catch((err) => console.log(err));
    }
  }

  function onCaptchaError () {
    toast.push('Failed to verify captcha, try again.', {
      theme: {
        '--toastBackground': '#F56565',
        '--toastBarBackground': '#C53030'
      }
    });
    captcha.reset();
  }

  function onCaptchaSuccess ({ detail: { token } }) {
    submission.captchaToken = token;
  }
</script>

<main>
  <h1 class="text-center">Let's get in touch</h1>
  <div class="d-flex justify-content-center flex-row row">
    <div class="border shadow bg-light py-2 col-lg-3 d-flex align-items-center flex-column m-2">
      <h1><i class="bi bi-map-fill"></i></h1>
      <p style="hyphens: auto;">
        <a href="https://goo.gl/maps/DdkzDQTRHBTtG8ys6">534 Trejo Street, Suite 200F
        <br>
        Rexburg, ID, 83440
        </a>
      </p>
    </div>
    <div class="border shadow bg-light py-2 col-lg-2 d-flex align-items-center flex-column m-2">
      <h1><i class="bi bi-phone-fill"></i></h1>
      <p style="hyphens: auto;">
        Call or text
        <br>
        <a href="tel:15306383546">(530) 638 - 3546</a>
      </p>
    </div>
    <div class="border shadow bg-light py-2 col-lg-3 d-flex align-items-center flex-column m-2">
      <h1><i class="bi bi-envelope-fill"></i></h1>
      <p style="hyphens: auto;">
        Email
        <br>
        <a href="mailto:jeffer@mistymountainsthreapy.com">jeffer@mistymountainstherapy.com</a>
      </p>
    </div>
  </div>
  <br>
  <h3>Or send us a message</h3>
  <form class="bg-light border shadow p-4" on:submit|preventDefault={handleSubmit}>
    <div class="row mb-2">
      <div class="form-group col-md-6">
        <label>Email *</label>
        <input type="email" class="form-control" bind:value={submission.email} placeholder="johnnyappleseed@example.com" required>
      </div>
      <div class="form-group col-md-6">
        <label>Name *</label>
        <input type="text" class="form-control" bind:value={submission.name} placeholder="Johnny Appleseed" required>
      </div>
    </div>
    <div class="form-group">
      <label>Message *</label>
      <textarea class="form-control" bind:value={submission.message} rows="3" placeholder="Hello! I would like to schedule a free 15-minute consultation..." required></textarea>
    </div>
    <div class="pt-2">
      <HCaptcha 
        sitekey={import.meta.env.VITE_HCAPTCHA_KEY} 
        bind:this={captcha}
        on:success={onCaptchaSuccess}
        on:error={onCaptchaError}
      />
    </div>
    <button type="submit" class="btn btn-primary">Submit</button>
  </form>
  <br>
</main>