Skip to content

Commit

Permalink
Merge branch 'master' into feat/relativeTimeDescription-add-to-placeR…
Browse files Browse the repository at this point in the history
…eview
  • Loading branch information
wangela authored Dec 1, 2023
2 parents ba70421 + 907d741 commit 21b3b25
Show file tree
Hide file tree
Showing 9 changed files with 393 additions and 227 deletions.
3 changes: 3 additions & 0 deletions .github/workflows/dependabot.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,10 @@ permissions:
contents: write

jobs:
test:
uses: ./.github/workflows/test.yml
dependabot:
needs: test
runs-on: ubuntu-latest
if: ${{ github.actor == 'dependabot[bot]' }}
env:
Expand Down
18 changes: 11 additions & 7 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -21,16 +21,20 @@ jobs:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v2
uses: actions/checkout@v3
with:
token: ${{ secrets.SYNCED_GITHUB_TOKEN_REPO }}
token: ${{ secrets.SYNCED_GITHUB_TOKEN_REPO }}

- uses: actions/setup-node@v2
with:
node-version: '14'
- name: Semantic Release
uses: cycjimmy/semantic-release-action@v2
uses: cycjimmy/semantic-release-action@v3.4.1
with:
extra_plugins: |
"@semantic-release/commit-analyzer"
"@semantic-release/release-notes-generator"
"@semantic-release/git
"@semantic-release/github
"@semantic-release/commit-analyzer@8.0.1"
"@semantic-release/release-notes-generator@9.0.3"
"@semantic-release/git@9.0.1"
"@semantic-release/github@7.2.3"
env:
GH_TOKEN: ${{ secrets.SYNCED_GITHUB_TOKEN_REPO }}
8 changes: 4 additions & 4 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,11 +18,11 @@ jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/setup-go@v1
- uses: actions/setup-go@v3
with:
go-version: 1.13
go-version: 'stable'
id: go
- uses: actions/checkout@v2
- uses: actions/checkout@v3
- run: go build -v ./...
- run: go test -v -race -coverprofile=coverage.txt -covermode=atomic ./...
- uses: codecov/codecov-action@v1
- uses: codecov/codecov-action@v3
5 changes: 4 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,9 @@ Go Client for Google Maps Services

[![Build Status](https://travis-ci.org/googlemaps/google-maps-services-go.svg?branch=master)](https://travis-ci.org/googlemaps/google-maps-services-go)
[![GoDoc](https://godoc.org/googlemaps.github.io/maps?status.svg)](https://godoc.org/googlemaps.github.io/maps)
[![Go Report Card](https://goreportcard.com/badge/github.com/googlemaps/google-maps-services-go)](https://goreportcard.com/report/github.com/googlemaps/google-maps-services-go)
![GitHub go.mod Go version](https://img.shields.io/github/go-mod/go-version/googlemaps/google-maps-services-go)
[![License](https://img.shields.io/badge/License-Apache_2.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)

## Description

Expand Down Expand Up @@ -78,7 +81,7 @@ For even more information, see the guide to [API keys][apikey].
To install the Go Client for Google Maps Services, please execute the following `go get` command.

```bash
go get googlemaps.github.io/maps
go get googlemaps.github.io/maps
```

## Developer Documentation
Expand Down
2 changes: 2 additions & 0 deletions examples/staticmap/cmdline/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ var (
scale = flag.Int("scale", -1, "Scale affects the number of pixels that are returned.")
format = flag.String("format", "", "Format defines the format of the resulting image.")
maptype = flag.String("maptype", "", "Maptype defines the type of map to construct.")
mapid = flag.String("mapid", "", "MapId defines the mapid to use.")
language = flag.String("language", "", "Language defines the language to use for display of labels on map tiles.")
region = flag.String("region", "", "Region the appropriate borders to display, based on geo-political sensitivities.")
)
Expand Down Expand Up @@ -81,6 +82,7 @@ func main() {
Language: *language,
Region: *region,
MapType: maps.MapType(*maptype),
MapId: *mapid,
}

resp, err := client.StaticMap(context.Background(), r)
Expand Down
136 changes: 108 additions & 28 deletions places.go
Original file line number Diff line number Diff line change
Expand Up @@ -400,6 +400,14 @@ func (r *PlaceDetailsRequest) params() url.Values {
q.Set("region", r.Region)
}

if r.ReviewsNoTranslations {
q.Set("reviews_no_translations", "true")
}

if r.ReviewsSort != "" {
q.Set("reviews_sort", r.ReviewsSort)
}

return q
}

Expand All @@ -413,7 +421,7 @@ type PlaceDetailsRequest struct {
Language string
// Fields allows you to select which parts of the returned details structure
// should be filled in. For more detail, please see the following URL:
// https://cloud.google.com/maps-platform/user-guide/product-changes/#places
// https://developers.google.com/maps/documentation/places/web-service/details#fields
Fields []PlaceDetailsFieldMask
// SessionToken is a token that marks this request as part of a Place Autocomplete
// Session. Optional.
Expand All @@ -422,6 +430,28 @@ type PlaceDetailsRequest struct {
// two-character value. Most ccTLD codes are identical to ISO 3166-1 codes, with
// some exceptions. This parameter will only influence, not fully restrict, results.
Region string
// ReviewsNoTranslations specifies whether to translate reviews. Specify
// ReviewsNoTranslations=true to disable translation of reviews; specify
// ReviewsNoTranslations=false to enable translation of reviews. Reviews
// are returned in their original language.
//
// If omitted, or passed with no value, translation of reviews is enabled. If
// the language parameter was specified in the request, use the specified
// language as the preferred language for translation. If language is
// omitted, the API attempts to use the Accept-Language header as the
// preferred language.
ReviewsNoTranslations bool
// ReviewsSort specifies the sorting method to use when returning reviews.
// Can be set to most_relevant (default) or newest.
//
//For most_relevant (default), reviews are sorted by relevance; the service
// will bias the results to return reviews originally written in the
// preferred language.
// For newest, reviews are sorted in chronological order; the preferred
// language does not affect the sort order.
// Google recommends that you display how the reviews are being sorted to the
// end user.
ReviewsSort string
}

// PlaceDetailsResult is an individual Places API Place Details result
Expand All @@ -433,6 +463,20 @@ type PlaceDetailsResult struct {
FormattedAddress string `json:"formatted_address,omitempty"`
// AdrAddress is the address in the "adr" microformat.
AdrAddress string `json:"adr_address,omitempty"`
// BusinessStatus is a string indicating the operational status of the
// place, if it is a business.
BusinessStatus string `json:"business_status,omitempty"`
// CurbsidePickup specifies if the business supports curbside pickup.
CurbsidePickup bool `json:"curbside_pickup,omitempty"`
// Delivery specifies if the business supports delivery.
Delivery bool `json:"delivery,omitempty"`
// DineIn specifies if the business supports seating options.
DineIn bool `json:"dine_in,omitempty"`
// EditorialSummary contains a summary of the place. A summary is comprised
// of a textual overview, and also includes the language code for these if
// applicable. Summary text must be presented as-is and can not be modified
// or altered.
EditorialSummary *PlaceEditorialSummary `json:"editorial_summary,omitempty"`
// FormattedPhoneNumber contains the place's phone number in its local format. For
// example, the formatted_phone_number for Google's Sydney, Australia office is
// (02) 9374 4000.
Expand All @@ -446,54 +490,90 @@ type PlaceDetailsResult struct {
// location (geocode) of the place and (optionally) the viewport identifying its
// general area of coverage.
Geometry AddressGeometry `json:"geometry,omitempty"`
// Name contains the human-readable name for the returned result. For establishment
// results, this is usually the business name.
Name string `json:"name,omitempty"`
// Icon contains the URL of a recommended icon which may be displayed to the user
// when indicating this result.
Icon string `json:"icon,omitempty"`
// PlaceID is a textual identifier that uniquely identifies a place.
PlaceID string `json:"place_id,omitempty"`
// Rating contains the place's rating, from 1.0 to 5.0, based on aggregated user
// reviews.
Rating float32 `json:"rating,omitempty"`
// UserRatingsTotal contains total number of the place's ratings
UserRatingsTotal int `json:"user_ratings_total,omitempty"`
// Types contains an array of feature types describing the given result.
Types []string `json:"types,omitempty"`
// Name contains the human-readable name for the returned result. For establishment
// results, this is usually the business name.
Name string `json:"name,omitempty"`
// OpeningHours may contain whether the place is open now or not.
OpeningHours *OpeningHours `json:"opening_hours,omitempty"`
// Photos is an array of photo objects, each containing a reference to an image.
Photos []Photo `json:"photos,omitempty"`
// PriceLevel is the price level of the place, on a scale of 0 to 4.
PriceLevel int `json:"price_level,omitempty"`
// Vicinity contains a feature name of a nearby location.
Vicinity string `json:"vicinity,omitempty"`
// CurrentOpeningHours may contain the hours of operation for the next seven
// days (including today). The time period starts at midnight on the date of
// the request and ends at 11:59 pm six days later. This field includes the
// special_days subfield of all hours, set for dates that have exceptional
// hours.
CurrentOpeningHours *OpeningHours `json:"current_opening_hours,omitempty"`
// SecondaryOpeningHours may contain an array of entries for the next seven
// days including information about secondary hours of a business. Secondary
// hours are different from a business's main hours. For example, a
// restaurant can specify drive through hours or delivery hours as its
// secondary hours. This field populates the type subfield, which draws from
// a predefined list of opening hours types (such as DRIVE_THROUGH, PICKUP,
// or TAKEOUT) based on the types of the place. This field includes the
// special_days subfield of all hours, set for dates that have exceptional
// hours.
SecondaryOpeningHours []OpeningHours `json:"secondary_opening_hours,omitempty"`
// PermanentlyClosed is a boolean flag indicating whether the place has permanently
// shut down (value true). If the place is not permanently closed, the flag is
// absent from the response.
//
// Deprecated: Use BusinessStatus instead.
PermanentlyClosed bool `json:"permanently_closed,omitempty"`
// BusinessStatus is a string indicating the operational status of the
// place, if it is a business.
BusinessStatus string `json:"business_status,omitempty"`
// Photos is an array of photo objects, each containing a reference to an image.
Photos []Photo `json:"photos,omitempty"`
// PlaceID is a textual identifier that uniquely identifies a place.
PlaceID string `json:"place_id,omitempty"`
// PriceLevel is the price level of the place, on a scale of 0 to 4.
PriceLevel int `json:"price_level,omitempty"`
// Rating contains the place's rating, from 1.0 to 5.0, based on aggregated user
// reviews.
Rating float32 `json:"rating,omitempty"`
// Reservable specifies if the place supports reservations.
Reservable bool `json:"reservable,omitempty"`
// Reviews is an array of up to five reviews. If a language parameter was specified
// in the Place Details request, the Places Service will bias the results to prefer
// reviews written in that language.
Reviews []PlaceReview `json:"reviews,omitempty"`
// ServesBeer specifies if the place serves beer.
ServesBeer bool `json:"serves_beer,omitempty"`
// ServesBreakfast specifies if the place serves breakfast.
ServesBreakfast bool `json:"serves_breakfast,omitempty"`
// ServesBrunch specifies if the place serves brunch.
ServesBrunch bool `json:"serves_brunch,omitempty"`
// ServesDinner specifies if the place serves dinner.
ServesDinner bool `json:"serves_dinner,omitempty"`
// ServesLunch specifies if the place serves lunch.
ServesLunch bool `json:"serves_lunch,omitempty"`
// ServesVegetarianFood specifies if the place serves vegetarian food.
ServesVegetarianFood bool `json:"serves_vegetarian_food,omitempty"`
// ServesWine specifies if the place serves wine.
ServesWine bool `json:"serves_wine,omitempty"`
// Takeout specifies if the business supports takeout.
Takeout bool `json:"takeout,omitempty"`
// Types contains an array of feature types describing the given result.
Types []string `json:"types,omitempty"`
// URL contains the URL of the official Google page for this place. This will be the
// establishment's Google+ page if the Google+ page exists, otherwise it will be the
// Google-owned page that contains the best available information about the place.
// Applications must link to or embed this page on any screen that shows detailed
// results about the place to the user.
URL string `json:"url,omitempty"`
// UserRatingsTotal contains total number of the place's ratings
UserRatingsTotal int `json:"user_ratings_total,omitempty"`
// UTCOffset contains the number of minutes this place’s current timezone is offset
// from UTC. For example, for places in Sydney, Australia during daylight saving
// time this would be 660 (+11 hours from UTC), and for places in California outside
// of daylight saving time this would be -480 (-8 hours from UTC).
UTCOffset *int `json:"utc_offset,omitempty"`
// Vicinity contains a feature name of a nearby location.
Vicinity string `json:"vicinity,omitempty"`
// Website lists the authoritative website for this place, such as a business'
// homepage.
Website string `json:"website,omitempty"`
// URL contains the URL of the official Google page for this place. This will be the
// establishment's Google+ page if the Google+ page exists, otherwise it will be the
// Google-owned page that contains the best available information about the place.
// Applications must link to or embed this page on any screen that shows detailed
// results about the place to the user.
URL string `json:"url,omitempty"`
// WheelchairAccessibleEntrance specifies if the place has an entrance that
// is wheelchair-accessible.
WheelchairAccessibleEntrance bool `json:"wheelchair_accessible_entrance,omitempty"`
// HTMLAttributions contain a set of attributions about this listing which must be
// displayed to the user.
HTMLAttributions []string `json:"html_attributions,omitempty"`
Expand Down
Loading

0 comments on commit 21b3b25

Please sign in to comment.