最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - Google Maps API Deprecation Error in VueJS web app: utc_offset is deprecated as of November 2019 and will be turned

programmeradmin1浏览0评论

I'm currently receiving the following error in my VueJS web application.

utc_offset is deprecated as of November 2019 and will be turned off in November 2020. Use utc_offset_minutes instead.

As per Google Maps API documentation:

The Places fields opening_hours.open_now and utc_offset are deprecated as of November 20, 2019, and will be turned off on November 20, 2020. These fields are deprecated ONLY in the Places Library, Maps JavaScript API. This guide shows you how to update your code to stop using these fields.

The only problem is, I am definitely not using utc_offset anywhere in my Vue application directly. I verified this by doing a global find for the word "utc_offset" in my application. I also don't ever recall accessing that specific property.

Why am I receiving this deprecation warning if I didn't use that property?

Below is what my stack trace looks like:

The following code snippet shows what the clearAllCardsAndFilters method does.

methods: {
    clearAllCardsAndFilters() {
        this.clearActiveCardListingId();
        this.clearFilterCards();
    },
    clearActiveCardListingId() {
        this.$storemit('clearActiveCardListingId');
    },

The following code snippet shows what the clearActiveCardListingId mutation in Vuex does. It simply sets the activeCardListingId property in Vuex to null.

    clearActiveCardListingId(state) {
        state.activeCardListingId = null;
    },

I'm currently receiving the following error in my VueJS web application.

utc_offset is deprecated as of November 2019 and will be turned off in November 2020. Use utc_offset_minutes instead.

As per Google Maps API documentation:

The Places fields opening_hours.open_now and utc_offset are deprecated as of November 20, 2019, and will be turned off on November 20, 2020. These fields are deprecated ONLY in the Places Library, Maps JavaScript API. This guide shows you how to update your code to stop using these fields.

The only problem is, I am definitely not using utc_offset anywhere in my Vue application directly. I verified this by doing a global find for the word "utc_offset" in my application. I also don't ever recall accessing that specific property.

Why am I receiving this deprecation warning if I didn't use that property?

Below is what my stack trace looks like:

The following code snippet shows what the clearAllCardsAndFilters method does.

methods: {
    clearAllCardsAndFilters() {
        this.clearActiveCardListingId();
        this.clearFilterCards();
    },
    clearActiveCardListingId() {
        this.$store.mit('clearActiveCardListingId');
    },

The following code snippet shows what the clearActiveCardListingId mutation in Vuex does. It simply sets the activeCardListingId property in Vuex to null.

    clearActiveCardListingId(state) {
        state.activeCardListingId = null;
    },
Share Improve this question asked Jan 13, 2020 at 12:38 ptkptk 7,66317 gold badges53 silver badges106 bronze badges 1
  • 1 Maybe if you request place details without specifying any fields which would return all the fields (which you should probably avoid because of billing). Without seeing your code, it's impossible to say anyway so I'll vote to close your question... – MrUpsidown Commented Jan 13, 2020 at 14:08
Add a ment  | 

3 Answers 3

Reset to default 7

If you are using VUE2-google-maps, then you can use google map ponent in following way:

<GmapAutoplete
 @place_changed="setPlace"
 :options="{fields: ['geometry', 'formatted_address', 'address_ponents']}">
</GmapAutoplete>

I was using the Google Places API without specifying any fields. This deprecation warning goes away once you specify fields in the following manner. Make sure you avoid specifying "utc_offset" as a field or the message will e back.

new google.maps.places.PlacesService(attrContainer).getDetails({
  placeId: '...',
  fields: ['opening_hours','utc_offset_minutes'],
  }, function (place, status) {
    if (status !== 'OK') return; // something went wrong
    const isOpenAtTime = place.opening_hours.isOpen(new Date('December 17, 2020 03:24:00'));
    if (isOpenAtTime) {
        // We know it's open.
    }

    const isOpenNow = place.opening_hours.isOpen();
    if (isOpenNow) {
        // We know it's open.
    }
});

It worked for me without :options

:fields="['geometry', 'opening_hours', 'business_status']"

与本文相关的文章

发布评论

评论列表(0)

  1. 暂无评论