Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions dist/samples/place-text-search/app/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,10 @@
<script type="module" src="./index.js"></script>
</head>
<body>
<div id="text-input-card">
<input type="text" id="text-input" placeholder="Search for a place"></input>
<input type="button" id="text-input-button" value="Search"></input>
</div>
<div id="map"></div>

<!-- prettier-ignore -->
Expand Down
72 changes: 55 additions & 17 deletions dist/samples/place-text-search/app/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,58 +6,85 @@

// [START maps_place_text_search]
let map;
let center;
let markers = {};
let infoWindow;

async function initMap() {
const { Map } = await google.maps.importLibrary("maps") as google.maps.MapsLibrary;
const { Map, InfoWindow } = await google.maps.importLibrary("maps") as google.maps.MapsLibrary;

center = { lat: 37.4161493, lng: -122.0812166 };
const center = { lat: 37.4161493, lng: -122.0812166 };
map = new Map(document.getElementById('map') as HTMLElement, {
center: center,
zoom: 11,
mapTypeControl: false,
mapId: 'DEMO_MAP_ID',
});

findPlaces();
const textInput = document.getElementById('text-input') as HTMLInputElement;
const textInputButton = document.getElementById('text-input-button') as HTMLButtonElement;
const card = document.getElementById('text-input-card') as HTMLElement;
map.controls[google.maps.ControlPosition.TOP_LEFT].push(card);

textInputButton.addEventListener('click', () => {
findPlaces(textInput.value);
});

textInput.addEventListener('keydown', (event) => {
if (event.key === 'Enter') {
findPlaces(textInput.value);
}
});

infoWindow = new google.maps.InfoWindow();
}

async function findPlaces() {
async function findPlaces(query) {
const { Place } = await google.maps.importLibrary("places") as google.maps.PlacesLibrary;
const { AdvancedMarkerElement } = await google.maps.importLibrary("marker") as google.maps.MarkerLibrary;
// [START maps_place_text_search_request]
const request = {
textQuery: 'Tacos in Mountain View',
textQuery: query,
fields: ['displayName', 'location', 'businessStatus'],
includedType: 'restaurant',
locationBias: { lat: 37.4161493, lng: -122.0812166 },
includedType: '', // Restrict query to a specific type (leave blank for any).
useStrictTypeFiltering: true,
locationBias: map.center,
isOpenNow: true,
language: 'en-US',
maxResultCount: 8,
minRating: 3.2,
minRating: 1, // Specify a minimum rating.
region: 'us',
useStrictTypeFiltering: false,
};

//@ts-ignore
const { places } = await Place.searchByText(request);
// [END maps_place_text_search_request]

if (places.length) {
console.log(places);

const { LatLngBounds } = await google.maps.importLibrary("core") as google.maps.CoreLibrary;
const bounds = new LatLngBounds();

// First remove all existing markers.
for (const id in markers) {
markers[id].map = null;
};
markers = {};

// Loop through and get all the results.
places.forEach((place) => {
const markerView = new AdvancedMarkerElement({
places.forEach(place => {
const marker = new AdvancedMarkerElement({
map,
position: place.location,
title: place.displayName,
});
markers[place.id] = marker;

marker.addListener('gmp-click', () => {
map.panTo(place.location);
updateInfoWindow(place.displayName, place.id, marker);
});

bounds.extend(place.location as google.maps.LatLng);
console.log(place);
if (place.location != null) {
bounds.extend(place.location);
}
});

map.fitBounds(bounds);
Expand All @@ -67,5 +94,16 @@ async function findPlaces() {
}
}

// Helper function to create an info window.
async function updateInfoWindow(title, content, anchor) {
infoWindow.setContent(content);
infoWindow.setHeaderContent(title);
infoWindow.open({
map,
anchor,
shouldFocus: false,
});
}

initMap();
// [END maps_place_text_search]
35 changes: 35 additions & 0 deletions dist/samples/place-text-search/app/style.css
Original file line number Diff line number Diff line change
Expand Up @@ -22,4 +22,39 @@ body {
padding: 0;
}

#text-input-card {
width: 25%;
background-color: #fff;
border-radius: 5px;
box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;
margin: 10px;
padding: 5px;
font-family: Roboto, sans-serif;
font-size: large;
font-weight: bold;
}

#text-input {
width: 100%;
padding: 10px;
margin: 0;
box-sizing: border-box;
}

#text-input-button {
display: inline-block;
margin-top: .5rem;
width: auto;
padding: .6rem .75rem;
font-size: .875rem;
font-weight: 500;
color: #fff;
background-color: #2563eb;
border: none;
border-radius: .375rem;
cursor: pointer;
transition: background-color .15s ease-in-out;
text-align: center
}

/* [END maps_place_text_search] */
5 changes: 5 additions & 0 deletions dist/samples/place-text-search/dist/assets/index-B0L17ZdS.css

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

5 changes: 0 additions & 5 deletions dist/samples/place-text-search/dist/assets/index-CgrE9OxR.js

This file was deleted.

5 changes: 5 additions & 0 deletions dist/samples/place-text-search/dist/assets/index-D3DoV7sY.js

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

5 changes: 0 additions & 5 deletions dist/samples/place-text-search/dist/assets/index-kz-ac4rW.css

This file was deleted.

8 changes: 6 additions & 2 deletions dist/samples/place-text-search/dist/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,14 @@
<head>
<title>Text Search</title>

<script type="module" crossorigin src="./assets/index-CgrE9OxR.js"></script>
<link rel="stylesheet" crossorigin href="./assets/index-kz-ac4rW.css">
<script type="module" crossorigin src="./assets/index-D3DoV7sY.js"></script>
<link rel="stylesheet" crossorigin href="./assets/index-B0L17ZdS.css">
</head>
<body>
<div id="text-input-card">
<input type="text" id="text-input" placeholder="Search for a place"></input>
<input type="button" id="text-input-button" value="Search"></input>
</div>
<div id="map"></div>

<!-- prettier-ignore -->
Expand Down
4 changes: 4 additions & 0 deletions dist/samples/place-text-search/docs/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,10 @@
<script type="module" src="./index.js"></script>
</head>
<body>
<div id="text-input-card">
<input type="text" id="text-input" placeholder="Search for a place"></input>
<input type="button" id="text-input-button" value="Search"></input>
</div>
<div id="map"></div>

<!-- prettier-ignore -->
Expand Down
66 changes: 50 additions & 16 deletions dist/samples/place-text-search/docs/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,55 +6,89 @@
*/
// [START maps_place_text_search]
let map;
let center;
let markers = {};
let infoWindow;
async function initMap() {
const { Map } = await google.maps.importLibrary("maps");
center = { lat: 37.4161493, lng: -122.0812166 };
const { Map, InfoWindow } = await google.maps.importLibrary("maps");
const center = { lat: 37.4161493, lng: -122.0812166 };
map = new Map(document.getElementById('map'), {
center: center,
zoom: 11,
mapTypeControl: false,
mapId: 'DEMO_MAP_ID',
});
findPlaces();
const textInput = document.getElementById('text-input');
const textInputButton = document.getElementById('text-input-button');
const card = document.getElementById('text-input-card');
map.controls[google.maps.ControlPosition.TOP_LEFT].push(card);
textInputButton.addEventListener('click', () => {
findPlaces(textInput.value);
});
textInput.addEventListener('keydown', (event) => {
if (event.key === 'Enter') {
findPlaces(textInput.value);
}
});
infoWindow = new google.maps.InfoWindow();
}
async function findPlaces() {
async function findPlaces(query) {
const { Place } = await google.maps.importLibrary("places");
const { AdvancedMarkerElement } = await google.maps.importLibrary("marker");
// [START maps_place_text_search_request]
const request = {
textQuery: 'Tacos in Mountain View',
textQuery: query,
fields: ['displayName', 'location', 'businessStatus'],
includedType: 'restaurant',
locationBias: { lat: 37.4161493, lng: -122.0812166 },
includedType: '', // Restrict query to a specific type (leave blank for any).
useStrictTypeFiltering: true,
locationBias: map.center,
isOpenNow: true,
language: 'en-US',
maxResultCount: 8,
minRating: 3.2,
minRating: 1, // Specify a minimum rating.
region: 'us',
useStrictTypeFiltering: false,
};
//@ts-ignore
const { places } = await Place.searchByText(request);
// [END maps_place_text_search_request]
if (places.length) {
console.log(places);
const { LatLngBounds } = await google.maps.importLibrary("core");
const bounds = new LatLngBounds();
// First remove all existing markers.
for (const id in markers) {
markers[id].map = null;
}
;
markers = {};
// Loop through and get all the results.
places.forEach((place) => {
const markerView = new AdvancedMarkerElement({
places.forEach(place => {
const marker = new AdvancedMarkerElement({
map,
position: place.location,
title: place.displayName,
});
bounds.extend(place.location);
console.log(place);
markers[place.id] = marker;
marker.addListener('gmp-click', () => {
map.panTo(place.location);
updateInfoWindow(place.displayName, place.id, marker);
});
if (place.location != null) {
bounds.extend(place.location);
}
});
map.fitBounds(bounds);
}
else {
console.log('No results');
}
}
// Helper function to create an info window.
async function updateInfoWindow(title, content, anchor) {
infoWindow.setContent(content);
infoWindow.setHeaderContent(title);
infoWindow.open({
map,
anchor,
shouldFocus: false,
});
}
initMap();
// [END maps_place_text_search]
Loading