places-autocomplete-svelte 2.0.0 → 2.0.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -13,8 +13,6 @@ This Svelte component leverages the [Google Maps Places Autocomplete API](https:
13
13
 
14
14
  ![Places Autocomplete Svelte](places-autocomplete-svelte.gif)
15
15
 
16
-
17
-
18
16
  ## Requirements
19
17
 
20
18
  - **Google Maps API Key:** Create an API key with the Places API (New) enabled. Refer to [Use API Keys](https://developers.google.com/maps/documentation/javascript/get-api-key) for detailed instructions.
@@ -31,11 +29,6 @@ npm i places-autocomplete-svelte
31
29
  npm i places-autocomplete-svelte@1.0.1
32
30
  ```
33
31
 
34
- ## Import Component
35
-
36
- ```javascript
37
- import PlaceAutocomplete from 'places-autocomplete-svelte';
38
- ```
39
32
 
40
33
  ## Basic Usage
41
34
 
@@ -44,39 +37,33 @@ import PlaceAutocomplete from 'places-autocomplete-svelte';
44
37
 
45
38
  ```svelte
46
39
  <script>
47
- import { PlaceAutocomplete } from 'places-autocomplete-svelte';
40
+ import { PlaceAutocomplete } from 'places-autocomplete-svelte';
48
41
 
49
- let formattedAddress = '';
50
- let PUBLIC_GOOGLE_MAPS_API_KEY = '--YOUR_API_KEY--';
42
+ let formattedAddress = '';
43
+ let PUBLIC_GOOGLE_MAPS_API_KEY = '--YOUR_API_KEY--';
51
44
  </script>
52
45
 
53
- <PlaceAutocomplete
54
- bind:PUBLIC_GOOGLE_MAPS_API_KEY
55
- bind:formattedAddress />
46
+ <PlaceAutocomplete bind:PUBLIC_GOOGLE_MAPS_API_KEY bind:formattedAddress />
56
47
 
57
- <p>Formatted Address: {formattedAddress}</p>
48
+ <p>Formatted Address: {formattedAddress}</p>
58
49
  ```
59
50
 
60
-
61
51
  ## Specifying Countries/Regions
62
52
 
63
53
  Use the `countries` property to refine search by region:
64
54
 
65
55
  ```svelte
66
56
  <script>
67
- // ... other imports
57
+ // ... other imports
68
58
 
69
- let countries = [
70
- { name: 'United Kingdom', region: 'GB' , language:'en-GB'},
71
- { name: 'United States', region: 'US',language:'en-US' },
72
- // ... more countries
73
- ];
59
+ let countries = [
60
+ { name: 'United Kingdom', region: 'GB', language: 'en-GB' },
61
+ { name: 'United States', region: 'US', language: 'en-US' }
62
+ // ... more countries
63
+ ];
74
64
  </script>
75
65
 
76
- <PlaceAutocomplete
77
- bind:PUBLIC_GOOGLE_MAPS_API_KEY
78
- bind:formattedAddress
79
- bind:countries />
66
+ <PlaceAutocomplete bind:PUBLIC_GOOGLE_MAPS_API_KEY bind:formattedAddress bind:countries />
80
67
  ```
81
68
 
82
69
  - The `region` code follows the [CLDR two-character format](https://developers.google.com/maps/documentation/javascript/reference/autocomplete-data#AutocompleteRequest).
@@ -88,8 +75,8 @@ For maximum flexibility, access the complete unformatted response from the Googl
88
75
 
89
76
  ```svelte
90
77
  <script>
91
- // ... other imports
92
- let fullResponse = {};
78
+ // ... other imports
79
+ let fullResponse = {};
93
80
  </script>
94
81
 
95
82
  <PlaceAutocomplete bind:PUBLIC_GOOGLE_MAPS_API_KEY bind:fullResponse />
@@ -98,6 +85,7 @@ For maximum flexibility, access the complete unformatted response from the Googl
98
85
  ```
99
86
 
100
87
  ## Example
88
+
101
89
  ```svelte
102
90
  <script>
103
91
  import { PlaceAutocomplete } from 'places-autocomplete-svelte';
@@ -113,8 +101,8 @@ For maximum flexibility, access the complete unformatted response from the Googl
113
101
  ];
114
102
  </script>
115
103
 
116
- <PlaceAutocomplete
117
- bind:PUBLIC_GOOGLE_MAPS_API_KEY
104
+ <PlaceAutocomplete
105
+ bind:PUBLIC_GOOGLE_MAPS_API_KEY
118
106
  bind:formattedAddress
119
107
  bind:fullResponse
120
108
  bind:formattedAddressObj
@@ -122,6 +110,7 @@ For maximum flexibility, access the complete unformatted response from the Googl
122
110
  placeholder="Enter your address...">
123
111
 
124
112
  ```
113
+
125
114
  - The `formattedAddress` - selected address as string.
126
115
  - The `fullResponse` - the complete unformatted response from the Google Maps API.
127
116
  - The `formattedAddressObj` - parsed address components, containing individual elements like street number, town, and postcode.
@@ -135,41 +124,34 @@ The `formattedAddressObj` mapping corresponds to the following component types:
135
124
  - `formattedAddressObj.country_iso2`: shortText property of the country
136
125
  - `formattedAddressObj.postcode`: longText property of the postal_code
137
126
 
138
-
139
-
140
127
  ## Error Handling
141
128
 
142
129
  The component will throw an error if:
143
- - The Google Maps API key is invalid or missing.
144
- - There are network issues connecting to the Google Maps service.
130
+
131
+ - The Google Maps API key is invalid or missing.
132
+ - There are network issues connecting to the Google Maps service.
145
133
 
146
134
  Handle these errors gracefully in your application:
147
135
 
148
136
  ```svelte
149
137
  <script>
150
- // ... other imports
138
+ // ... other imports
151
139
 
152
- // Error handler
153
- let pacError = '';
154
- let onError = (error:string) => {
140
+ // Error handler
141
+ let pacError = '';
142
+ let onError = (error: string) => {
155
143
  console.error(error);
156
- pacError = error;
144
+ pacError = error;
157
145
  };
158
146
  </script>
159
147
 
160
148
  <PlaceAutocomplete bind:PUBLIC_GOOGLE_MAPS_API_KEY {onError} />
161
149
 
162
150
  {#if pacError}
163
- <p class="error">{pacError}</p>
151
+ <p class="error">{pacError}</p>
164
152
  {/if}
165
153
  ```
166
154
 
167
-
168
-
169
-
170
-
171
-
172
-
173
155
  ## Contributing
174
156
 
175
157
  Contributions are welcome! Please open an issue or submit a pull request on the [GitHub repository](https://github.com/alexpechkarev/places-autocomplete-svelte/).
@@ -177,5 +159,3 @@ Contributions are welcome! Please open an issue or submit a pull request on the
177
159
  ## License
178
160
 
179
161
  [MIT](LICENSE)
180
-
181
-
@@ -3,52 +3,68 @@
3
3
  import * as GMaps from '@googlemaps/js-api-loader';
4
4
  const { Loader } = GMaps;
5
5
 
6
+ // Props Interface
7
+ interface Props {
8
+ PUBLIC_GOOGLE_MAPS_API_KEY: string;
9
+ fetchFields: string[];
10
+ countries: { name: string; region: string }[];
11
+ formattedAddress: string;
12
+ fullResponse: { longText: string; shortText: string; types: Array<string> }[];
13
+ formattedAddressObj: {
14
+ street_number: string;
15
+ street: string;
16
+ town: string;
17
+ county: string;
18
+ country_iso2: string;
19
+ postcode: string;
20
+ };
21
+ onError: (error: string) => void;
22
+ }
23
+ // Bindable Props
24
+ let {
25
+ PUBLIC_GOOGLE_MAPS_API_KEY = $bindable(''),
26
+ /**
27
+ * By default using SKU: Place Detals (Location Only) - 0.005 USD per each
28
+ * @see https://developers.google.com/maps/documentation/javascript/usage-and-billing#location-placedetails
29
+ */
30
+ fetchFields = $bindable(['formattedAddress', 'addressComponents']),
31
+ countries = $bindable([]),
32
+ formattedAddress = $bindable(''),
33
+ fullResponse = $bindable([]),
34
+ formattedAddressObj = $bindable({
35
+ street_number: '',
36
+ street: '',
37
+ town: '',
38
+ county: '',
39
+ country_iso2: '',
40
+ postcode: ''
41
+ }),
42
+ onError = $bindable((error: string) => {})
43
+ }: Props = $props();
6
44
 
7
-
8
- export let PUBLIC_GOOGLE_MAPS_API_KEY: string = '';
9
- export let fetchFields: string[] = ['displayName', 'formattedAddress', 'addressComponents'];
10
- export let countries: { name: string; region: string }[] = [];
45
+ // Check if countries are available
11
46
  let hasCountries = countries.length > 0;
12
-
13
- export let formattedAddress: string = '';
14
- export let fullResponse: { longText: string; shortText: string; types: Array<string> }[] = [];
15
- export let formattedAddressObj: {
16
- street_number: string;
17
- street: string;
18
- town: string;
19
- county: string;
20
- country_iso2: string;
21
- postcode: string;
22
- } = {
23
- street_number: '',
24
- street: '',
25
- town: '',
26
- county: '',
27
- country_iso2: '',
28
- postcode: ''
29
- };
30
- export let onError: (error: string) => void = (error: string) => {};
31
-
47
+ // Local variables
32
48
  let inputRef: HTMLInputElement;
33
- let currentSuggestion = -1;
34
- let title: string = '';
35
- let results: any[] = [];
49
+ let currentSuggestion = $state(-1);
50
+ let title: string = $state('');
51
+ let results: any[] = $state([]);
36
52
  let token;
37
53
  let loader: GMaps.Loader;
38
54
  let placesApi: { [key: string]: any } = {};
39
55
  //https://developers.google.com/maps/documentation/javascript/reference/autocomplete-data#AutocompleteRequest.includedPrimaryTypes
40
- let request = {
56
+ let request = $state({
41
57
  input: '',
42
58
  language: 'en-GB',
43
59
  region: 'GB',
44
60
  sessionToken: ''
45
- };
61
+ });
46
62
 
47
- $: {
63
+ $effect(() => {
48
64
  if (request.input == '') {
49
65
  results = [];
50
66
  }
51
- }
67
+ });
52
68
 
53
69
  /**
54
70
  * Reset search input and results.
@@ -88,7 +104,7 @@
88
104
  text: suggestion.placePrediction.text.toString()
89
105
  });
90
106
  }
91
- } catch (e) {
107
+ } catch (e: any) {
92
108
  onError((e.name || 'An error occurred') + ' - ' + (e.message || 'see console for details.'));
93
109
  }
94
110
  };
@@ -104,7 +120,6 @@
104
120
  formattedAddress: string;
105
121
  }): Promise<void> => {
106
122
  try {
107
-
108
123
  await place.fetchFields({
109
124
  fields: fetchFields
110
125
  });
@@ -147,8 +162,10 @@
147
162
  break;
148
163
  }
149
164
  }
150
- } catch (e) {
151
- onError((e.name || 'An error occurred') + ' - ' + (e.message || 'error fetching place details'));
165
+ } catch (e: any) {
166
+ onError(
167
+ (e.name || 'An error occurred') + ' - ' + (e.message || 'error fetching place details')
168
+ );
152
169
  }
153
170
 
154
171
  // reset srarch input and results
@@ -165,12 +182,11 @@
165
182
  region?: string;
166
183
  sessionToken?: any;
167
184
  }): Promise<{ input?: string; language?: string; region?: string; sessionToken?: any }> => {
168
- try{
185
+ try {
169
186
  token = new placesApi.AutocompleteSessionToken();
170
187
  request.sessionToken = token;
171
188
  return request;
172
-
173
- }catch(e){
189
+ } catch (e: any) {
174
190
  onError((e.name || 'An error occurred') + ' - ' + (e.message || 'error fetch token'));
175
191
  return request;
176
192
  }
@@ -187,14 +203,14 @@
187
203
  version: 'weekly',
188
204
  libraries: ['places']
189
205
  });
190
-
206
+
191
207
  const { AutocompleteSessionToken, AutocompleteSuggestion } =
192
208
  await loader.importLibrary('places');
193
209
  placesApi.AutocompleteSessionToken = AutocompleteSessionToken;
194
210
  placesApi.AutocompleteSuggestion = AutocompleteSuggestion;
195
211
  token = new placesApi.AutocompleteSessionToken();
196
212
  request.sessionToken = token;
197
- } catch (e) {
213
+ } catch (e: any) {
198
214
  onError(
199
215
  (e.name || 'An error occurred') + ' - ' + (e.message || 'Error loading Google Maps API')
200
216
  );
@@ -241,7 +257,7 @@
241
257
  stroke-linejoin="round"><circle cx="11" cy="11" r="8" /><path d="m21 21-4.3-4.3" /></svg
242
258
  >
243
259
  </div>
244
-
260
+
245
261
  <input
246
262
  type="text"
247
263
  name="search"
@@ -250,7 +266,7 @@
250
266
  placeholder="Search..."
251
267
  aria-controls="options"
252
268
  bind:value={request.input}
253
- on:input={makeAcRequest}
269
+ oninput={makeAcRequest}
254
270
  />
255
271
 
256
272
  {#if results.length > 0}
@@ -273,19 +289,22 @@
273
289
  id="options"
274
290
  >
275
291
  {#each results as place, i}
276
- <!-- svelte-ignore a11y-click-events-have-key-events -->
277
- <!-- svelte-ignore a11y-no-noninteractive-tabindex -->
278
- <!-- svelte-ignore a11y-no-noninteractive-element-interactions -->
279
292
  <li
280
293
  class="z-50 cursor-default select-none py-2 pl-4 text-gray-900 hover:bg-indigo-500 hover:text-white"
281
294
  class:bg-indigo-500={i === currentSuggestion}
282
295
  class:bg-white={i !== currentSuggestion}
283
296
  class:text-white={i === currentSuggestion}
284
297
  id="option-{i + 1}"
285
- tabindex={i + 1}
286
- on:click={() => onPlaceSelected(place.to_pace)}
287
298
  >
288
- {place.text}
299
+ <!-- svelte-ignore a11y_invalid_attribute -->
300
+ <a
301
+ href="javascript:void(0)"
302
+ class="block w-full"
303
+ tabindex={i + 1}
304
+ onclick={() => onPlaceSelected(place.to_pace)}
305
+ >
306
+ {place.text}
307
+ </a>
289
308
  </li>
290
309
  {/each}
291
310
  </ul>
@@ -310,8 +329,11 @@
310
329
  </div>
311
330
  </div>
312
331
 
313
- <div class="lg:col-span-6">
332
+ <div class="lg:col-span-6 mt-2">
314
333
  <div class="text-sm font-medium leading-6 text-gray-500">{title}</div>
315
334
  </div>
316
335
  </div>
317
- </section>
336
+ </section>
337
+ <style>
338
+ input,select,ul{margin:0;padding:0}.absolute,.sr-only{position:absolute}.block,svg{display:block}*,.border-gray-300{--tw-border-opacity:1}.text-gray-500,.text-gray-900,.text-white{--tw-text-opacity:1}*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb;--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }:after,:before{--tw-content:''}:host,section{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:system-ui,sans-serif,apple color emoji,segoe ui emoji,Segoe UI Symbol,noto color emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}kbd{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}input,select{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}ul{list-style:none}.cursor-default,:disabled{cursor:default}svg{vertical-align:middle}[type=text],input:where(:not([type])),select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;border-color:#6b7280;border-width:1px;border-radius:0;padding:.5rem .75rem;font-size:1rem;line-height:1.5rem;--tw-shadow:0 0 #0000}[type=text]:focus,input:where(:not([type])):focus,select:focus{outline:transparent solid 2px;outline-offset:2px;--tw-ring-inset:var(--tw-empty,);--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#2563eb;--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow);border-color:#2563eb}input::-moz-placeholder{color:#6b7280;opacity:1}input::placeholder{color:#6b7280;opacity:1}select{text-transform:none;background-image:url();background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem;-webkit-print-color-adjust:exact;print-color-adjust:exact}:root{--background:0 0% 100%;--foreground:222.2 84% 4.9%;--muted:210 40% 96.1%;--muted-foreground:215.4 16.3% 46.9%;--popover:0 0% 100%;--popover-foreground:222.2 84% 4.9%;--card:0 0% 100%;--card-foreground:222.2 84% 4.9%;--border:214.3 31.8% 91.4%;--input:214.3 31.8% 91.4%;--primary:222.2 47.4% 11.2%;--primary-foreground:210 40% 98%;--secondary:210 40% 96.1%;--secondary-foreground:222.2 47.4% 11.2%;--accent:210 40% 96.1%;--accent-foreground:222.2 47.4% 11.2%;--destructive:0 72.2% 50.6%;--destructive-foreground:210 40% 98%;--ring:222.2 84% 4.9%;--radius:0.5rem}*{border-color:hsl(var(--border) / var(--tw-border-opacity))}::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }.sr-only{width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.pointer-events-none{pointer-events:none}.relative{position:relative}.inset-y-0{top:0;bottom:0}.left-0{left:0}.right-0{right:0}.z-50{z-index:50}.-mb-2{margin-bottom:-.5rem}.mr-1{margin-right:.25rem}.mt-4{margin-top:1rem}.flex{display:flex}.inline-flex{display:inline-flex}.hidden{display:none}.h-10{height:2.5rem}.h-5{height:1.25rem}.max-h-60{max-height:15rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-full{width:100%}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr));grid-template-columns:1fr}.items-center{align-items:center}.gap-x-4{-moz-column-gap:1rem;column-gap:1rem;row-gap:1rem}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-gray-300{border-color:rgb(209 213 219 / var(--tw-border-opacity))}.bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246 / var(--tw-bg-opacity))}.bg-indigo-500,.hover\:bg-indigo-500:hover{--tw-bg-opacity:1;background-color:rgb(99 102 241 / var(--tw-bg-opacity))}.bg-transparent{background-color:transparent}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255 / var(--tw-bg-opacity))}.px-1{padding-left:.25rem;padding-right:.25rem}.px-4{padding-left:1rem;padding-right:1rem}.py-0{padding-top:0;padding-bottom:0}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.pl-10{padding-left:2.5rem}.pl-2{padding-left:.5rem}.pl-3{padding-left:.75rem}.pl-4{padding-left:1rem}.pr-1\.5{padding-right:.375rem}.pr-20{padding-right:5rem}.pr-7{padding-right:1.75rem}.text-base{font-size:1rem;line-height:1.5rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.text-gray-500{color:rgb(107 114 128 / var(--tw-text-opacity))}.text-gray-900{color:rgb(17 24 39 / var(--tw-text-opacity))}.text-white{color:rgb(255 255 255 / var(--tw-text-opacity))}.shadow-lg{--tw-shadow:0 10px 15px -3px rgb(0 0 0 / 0.1),0 4px 6px -4px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.focus\:ring-2:focus,.ring-1{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-1{--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-black{--tw-ring-opacity:1;--tw-ring-color:rgb(0 0 0 / var(--tw-ring-opacity))}.focus\:outline-none:focus{outline:transparent solid 2px;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-inset:focus{--tw-ring-inset:inset}@media (min-width:640px){.sm\:text-sm{font-size:.875rem;line-height:1.25rem}}@media (min-width:1024px){.lg\:col-span-2{grid-column:span 2/span 2}}@keyframes swipe-out{0%{transform:translateY(calc(var(--lift) * var(--offset) + var(--swipe-amount)));opacity:1}to{transform:translateY(calc(var(--lift) * var(--offset) + var(--swipe-amount) + var(--lift) * -100%));opacity:0}}.grid{display:grid}@media (min-width:768px){.lg\:grid-cols-6{grid-template-columns:repeat(6,1fr)}.lg\:col-span-6{grid-column-start:span 6}.lg\:col-span-4{grid-column-start:span 4}.lg\:col-span-2{grid-column-start:span 2}}.my-10{margin-top:2.5rem;margin-bottom:2.5rem} .justify-center {justify-content: center;} .hover\:text-white:hover{color:rgb(255 255 255 / var(--tw-text-opacity))}
339
+ </style>
@@ -1,30 +1,17 @@
1
- interface $$__sveltets_2_IsomorphicComponent<Props extends Record<string, any> = any, Events extends Record<string, any> = any, Slots extends Record<string, any> = any, Exports = {}, Bindings = string> {
2
- new (options: import('svelte').ComponentConstructorOptions<Props>): import('svelte').SvelteComponent<Props, Events, Slots> & {
3
- $$bindings?: Bindings;
4
- } & Exports;
5
- (internal: unknown, props: Props & {
6
- $$events?: Events;
7
- $$slots?: Slots;
8
- }): Exports & {
9
- $set?: any;
10
- $on?: any;
11
- };
12
- z_$$bindings?: Bindings;
13
- }
14
- declare const PlaceAutocomplete: $$__sveltets_2_IsomorphicComponent<{
15
- PUBLIC_GOOGLE_MAPS_API_KEY?: string;
16
- fetchFields?: string[];
17
- countries?: {
1
+ declare const PlaceAutocomplete: import("svelte").Component<{
2
+ PUBLIC_GOOGLE_MAPS_API_KEY: string;
3
+ fetchFields: string[];
4
+ countries: {
18
5
  name: string;
19
6
  region: string;
20
7
  }[];
21
- formattedAddress?: string;
22
- fullResponse?: {
8
+ formattedAddress: string;
9
+ fullResponse: {
23
10
  longText: string;
24
11
  shortText: string;
25
12
  types: Array<string>;
26
13
  }[];
27
- formattedAddressObj?: {
14
+ formattedAddressObj: {
28
15
  street_number: string;
29
16
  street: string;
30
17
  town: string;
@@ -32,9 +19,6 @@ declare const PlaceAutocomplete: $$__sveltets_2_IsomorphicComponent<{
32
19
  country_iso2: string;
33
20
  postcode: string;
34
21
  };
35
- onError?: (error: string) => void;
36
- }, {
37
- [evt: string]: CustomEvent<any>;
38
- }, {}, {}, string>;
39
- type PlaceAutocomplete = InstanceType<typeof PlaceAutocomplete>;
22
+ onError: (error: string) => void;
23
+ }, {}, "PUBLIC_GOOGLE_MAPS_API_KEY" | "fetchFields" | "formattedAddress" | "countries" | "fullResponse" | "formattedAddressObj" | "onError">;
40
24
  export default PlaceAutocomplete;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "places-autocomplete-svelte",
3
3
  "license": "MIT",
4
- "version": "2.0.0",
4
+ "version": "2.0.7",
5
5
  "description": "A Svelte component that leverages the power of Google Places New API to provide a user-friendly autocomplete experience for location searches.",
6
6
  "keywords": [
7
7
  "svelte",
@@ -56,10 +56,11 @@
56
56
  "!dist/**/*.spec.*"
57
57
  ],
58
58
  "publishConfig": {
59
- "@alexpechkarev:registry": "https://npm.pkg.github.com"
59
+ "@alexpechkarev:registry": "https://npm.pkg.github.com",
60
+ "provenance": true
60
61
  },
61
62
  "peerDependencies": {
62
- "svelte": "^4.0.0"
63
+ "svelte": "^5.1.4"
63
64
  },
64
65
  "devDependencies": {
65
66
  "@sveltejs/adapter-auto": "^3.3.1",
@@ -77,12 +78,12 @@
77
78
  "prettier": "^3.3.3",
78
79
  "prettier-plugin-svelte": "^3.2.7",
79
80
  "publint": "^0.2.12",
80
- "svelte": "^5.1.3",
81
+ "svelte": "^5.1.4",
81
82
  "svelte-check": "^4.0.5",
82
83
  "tailwindcss": "^3.4.14",
83
84
  "tslib": "^2.8.0",
84
85
  "typescript": "^5.6.3",
85
- "typescript-eslint": "^8.11.0",
86
+ "typescript-eslint": "^8.12.2",
86
87
  "vite": "^5.4.10"
87
88
  },
88
89
  "svelte": "./dist/index.js",
@@ -91,4 +92,4 @@
91
92
  "dependencies": {
92
93
  "@googlemaps/js-api-loader": "^1.16.8"
93
94
  }
94
- }
95
+ }