@googlemaps/places
Version:
Places API (New) client for Node.js
1,061 lines (974 loc) • 2.62 MB
JavaScript
// Copyright 2026 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
/*eslint-disable block-scoped-var, id-length, no-control-regex, no-magic-numbers, no-prototype-builtins, no-redeclare, no-shadow, no-var, sort-vars*/
(function(global, factory) { /* global define, require, module */
/* AMD */ if (typeof define === 'function' && define.amd)
define(["protobufjs/minimal"], factory);
/* CommonJS */ else if (typeof require === 'function' && typeof module === 'object' && module && module.exports)
module.exports = factory(require("google-gax/build/src/protobuf").protobufMinimal);
})(this, function($protobuf) {
"use strict";
// Common aliases
var $Reader = $protobuf.Reader, $Writer = $protobuf.Writer, $util = $protobuf.util;
// Exported root namespace
var $root = $protobuf.roots._googlemaps_places_protos || ($protobuf.roots._googlemaps_places_protos = {});
$root.google = (function() {
/**
* Namespace google.
* @exports google
* @namespace
*/
var google = {};
google.geo = (function() {
/**
* Namespace geo.
* @memberof google
* @namespace
*/
var geo = {};
geo.type = (function() {
/**
* Namespace type.
* @memberof google.geo
* @namespace
*/
var type = {};
type.Viewport = (function() {
/**
* Properties of a Viewport.
* @memberof google.geo.type
* @interface IViewport
* @property {google.type.ILatLng|null} [low] Viewport low
* @property {google.type.ILatLng|null} [high] Viewport high
*/
/**
* Constructs a new Viewport.
* @memberof google.geo.type
* @classdesc Represents a Viewport.
* @implements IViewport
* @constructor
* @param {google.geo.type.IViewport=} [properties] Properties to set
*/
function Viewport(properties) {
if (properties)
for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)
if (properties[keys[i]] != null)
this[keys[i]] = properties[keys[i]];
}
/**
* Viewport low.
* @member {google.type.ILatLng|null|undefined} low
* @memberof google.geo.type.Viewport
* @instance
*/
Viewport.prototype.low = null;
/**
* Viewport high.
* @member {google.type.ILatLng|null|undefined} high
* @memberof google.geo.type.Viewport
* @instance
*/
Viewport.prototype.high = null;
/**
* Creates a new Viewport instance using the specified properties.
* @function create
* @memberof google.geo.type.Viewport
* @static
* @param {google.geo.type.IViewport=} [properties] Properties to set
* @returns {google.geo.type.Viewport} Viewport instance
*/
Viewport.create = function create(properties) {
return new Viewport(properties);
};
/**
* Encodes the specified Viewport message. Does not implicitly {@link google.geo.type.Viewport.verify|verify} messages.
* @function encode
* @memberof google.geo.type.Viewport
* @static
* @param {google.geo.type.IViewport} message Viewport message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
Viewport.encode = function encode(message, writer) {
if (!writer)
writer = $Writer.create();
if (message.low != null && Object.hasOwnProperty.call(message, "low"))
$root.google.type.LatLng.encode(message.low, writer.uint32(/* id 1, wireType 2 =*/10).fork()).ldelim();
if (message.high != null && Object.hasOwnProperty.call(message, "high"))
$root.google.type.LatLng.encode(message.high, writer.uint32(/* id 2, wireType 2 =*/18).fork()).ldelim();
return writer;
};
/**
* Encodes the specified Viewport message, length delimited. Does not implicitly {@link google.geo.type.Viewport.verify|verify} messages.
* @function encodeDelimited
* @memberof google.geo.type.Viewport
* @static
* @param {google.geo.type.IViewport} message Viewport message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
Viewport.encodeDelimited = function encodeDelimited(message, writer) {
return this.encode(message, writer).ldelim();
};
/**
* Decodes a Viewport message from the specified reader or buffer.
* @function decode
* @memberof google.geo.type.Viewport
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @param {number} [length] Message length if known beforehand
* @returns {google.geo.type.Viewport} Viewport
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
Viewport.decode = function decode(reader, length, error) {
if (!(reader instanceof $Reader))
reader = $Reader.create(reader);
var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.geo.type.Viewport();
while (reader.pos < end) {
var tag = reader.uint32();
if (tag === error)
break;
switch (tag >>> 3) {
case 1: {
message.low = $root.google.type.LatLng.decode(reader, reader.uint32());
break;
}
case 2: {
message.high = $root.google.type.LatLng.decode(reader, reader.uint32());
break;
}
default:
reader.skipType(tag & 7);
break;
}
}
return message;
};
/**
* Decodes a Viewport message from the specified reader or buffer, length delimited.
* @function decodeDelimited
* @memberof google.geo.type.Viewport
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @returns {google.geo.type.Viewport} Viewport
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
Viewport.decodeDelimited = function decodeDelimited(reader) {
if (!(reader instanceof $Reader))
reader = new $Reader(reader);
return this.decode(reader, reader.uint32());
};
/**
* Verifies a Viewport message.
* @function verify
* @memberof google.geo.type.Viewport
* @static
* @param {Object.<string,*>} message Plain object to verify
* @returns {string|null} `null` if valid, otherwise the reason why it is not
*/
Viewport.verify = function verify(message) {
if (typeof message !== "object" || message === null)
return "object expected";
if (message.low != null && message.hasOwnProperty("low")) {
var error = $root.google.type.LatLng.verify(message.low);
if (error)
return "low." + error;
}
if (message.high != null && message.hasOwnProperty("high")) {
var error = $root.google.type.LatLng.verify(message.high);
if (error)
return "high." + error;
}
return null;
};
/**
* Creates a Viewport message from a plain object. Also converts values to their respective internal types.
* @function fromObject
* @memberof google.geo.type.Viewport
* @static
* @param {Object.<string,*>} object Plain object
* @returns {google.geo.type.Viewport} Viewport
*/
Viewport.fromObject = function fromObject(object) {
if (object instanceof $root.google.geo.type.Viewport)
return object;
var message = new $root.google.geo.type.Viewport();
if (object.low != null) {
if (typeof object.low !== "object")
throw TypeError(".google.geo.type.Viewport.low: object expected");
message.low = $root.google.type.LatLng.fromObject(object.low);
}
if (object.high != null) {
if (typeof object.high !== "object")
throw TypeError(".google.geo.type.Viewport.high: object expected");
message.high = $root.google.type.LatLng.fromObject(object.high);
}
return message;
};
/**
* Creates a plain object from a Viewport message. Also converts values to other types if specified.
* @function toObject
* @memberof google.geo.type.Viewport
* @static
* @param {google.geo.type.Viewport} message Viewport
* @param {$protobuf.IConversionOptions} [options] Conversion options
* @returns {Object.<string,*>} Plain object
*/
Viewport.toObject = function toObject(message, options) {
if (!options)
options = {};
var object = {};
if (options.defaults) {
object.low = null;
object.high = null;
}
if (message.low != null && message.hasOwnProperty("low"))
object.low = $root.google.type.LatLng.toObject(message.low, options);
if (message.high != null && message.hasOwnProperty("high"))
object.high = $root.google.type.LatLng.toObject(message.high, options);
return object;
};
/**
* Converts this Viewport to JSON.
* @function toJSON
* @memberof google.geo.type.Viewport
* @instance
* @returns {Object.<string,*>} JSON object
*/
Viewport.prototype.toJSON = function toJSON() {
return this.constructor.toObject(this, $protobuf.util.toJSONOptions);
};
/**
* Gets the default type url for Viewport
* @function getTypeUrl
* @memberof google.geo.type.Viewport
* @static
* @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com")
* @returns {string} The default type url
*/
Viewport.getTypeUrl = function getTypeUrl(typeUrlPrefix) {
if (typeUrlPrefix === undefined) {
typeUrlPrefix = "type.googleapis.com";
}
return typeUrlPrefix + "/google.geo.type.Viewport";
};
return Viewport;
})();
return type;
})();
return geo;
})();
google.type = (function() {
/**
* Namespace type.
* @memberof google
* @namespace
*/
var type = {};
type.LatLng = (function() {
/**
* Properties of a LatLng.
* @memberof google.type
* @interface ILatLng
* @property {number|null} [latitude] LatLng latitude
* @property {number|null} [longitude] LatLng longitude
*/
/**
* Constructs a new LatLng.
* @memberof google.type
* @classdesc Represents a LatLng.
* @implements ILatLng
* @constructor
* @param {google.type.ILatLng=} [properties] Properties to set
*/
function LatLng(properties) {
if (properties)
for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)
if (properties[keys[i]] != null)
this[keys[i]] = properties[keys[i]];
}
/**
* LatLng latitude.
* @member {number} latitude
* @memberof google.type.LatLng
* @instance
*/
LatLng.prototype.latitude = 0;
/**
* LatLng longitude.
* @member {number} longitude
* @memberof google.type.LatLng
* @instance
*/
LatLng.prototype.longitude = 0;
/**
* Creates a new LatLng instance using the specified properties.
* @function create
* @memberof google.type.LatLng
* @static
* @param {google.type.ILatLng=} [properties] Properties to set
* @returns {google.type.LatLng} LatLng instance
*/
LatLng.create = function create(properties) {
return new LatLng(properties);
};
/**
* Encodes the specified LatLng message. Does not implicitly {@link google.type.LatLng.verify|verify} messages.
* @function encode
* @memberof google.type.LatLng
* @static
* @param {google.type.ILatLng} message LatLng message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
LatLng.encode = function encode(message, writer) {
if (!writer)
writer = $Writer.create();
if (message.latitude != null && Object.hasOwnProperty.call(message, "latitude"))
writer.uint32(/* id 1, wireType 1 =*/9).double(message.latitude);
if (message.longitude != null && Object.hasOwnProperty.call(message, "longitude"))
writer.uint32(/* id 2, wireType 1 =*/17).double(message.longitude);
return writer;
};
/**
* Encodes the specified LatLng message, length delimited. Does not implicitly {@link google.type.LatLng.verify|verify} messages.
* @function encodeDelimited
* @memberof google.type.LatLng
* @static
* @param {google.type.ILatLng} message LatLng message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
LatLng.encodeDelimited = function encodeDelimited(message, writer) {
return this.encode(message, writer).ldelim();
};
/**
* Decodes a LatLng message from the specified reader or buffer.
* @function decode
* @memberof google.type.LatLng
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @param {number} [length] Message length if known beforehand
* @returns {google.type.LatLng} LatLng
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
LatLng.decode = function decode(reader, length, error) {
if (!(reader instanceof $Reader))
reader = $Reader.create(reader);
var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.type.LatLng();
while (reader.pos < end) {
var tag = reader.uint32();
if (tag === error)
break;
switch (tag >>> 3) {
case 1: {
message.latitude = reader.double();
break;
}
case 2: {
message.longitude = reader.double();
break;
}
default:
reader.skipType(tag & 7);
break;
}
}
return message;
};
/**
* Decodes a LatLng message from the specified reader or buffer, length delimited.
* @function decodeDelimited
* @memberof google.type.LatLng
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @returns {google.type.LatLng} LatLng
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
LatLng.decodeDelimited = function decodeDelimited(reader) {
if (!(reader instanceof $Reader))
reader = new $Reader(reader);
return this.decode(reader, reader.uint32());
};
/**
* Verifies a LatLng message.
* @function verify
* @memberof google.type.LatLng
* @static
* @param {Object.<string,*>} message Plain object to verify
* @returns {string|null} `null` if valid, otherwise the reason why it is not
*/
LatLng.verify = function verify(message) {
if (typeof message !== "object" || message === null)
return "object expected";
if (message.latitude != null && message.hasOwnProperty("latitude"))
if (typeof message.latitude !== "number")
return "latitude: number expected";
if (message.longitude != null && message.hasOwnProperty("longitude"))
if (typeof message.longitude !== "number")
return "longitude: number expected";
return null;
};
/**
* Creates a LatLng message from a plain object. Also converts values to their respective internal types.
* @function fromObject
* @memberof google.type.LatLng
* @static
* @param {Object.<string,*>} object Plain object
* @returns {google.type.LatLng} LatLng
*/
LatLng.fromObject = function fromObject(object) {
if (object instanceof $root.google.type.LatLng)
return object;
var message = new $root.google.type.LatLng();
if (object.latitude != null)
message.latitude = Number(object.latitude);
if (object.longitude != null)
message.longitude = Number(object.longitude);
return message;
};
/**
* Creates a plain object from a LatLng message. Also converts values to other types if specified.
* @function toObject
* @memberof google.type.LatLng
* @static
* @param {google.type.LatLng} message LatLng
* @param {$protobuf.IConversionOptions} [options] Conversion options
* @returns {Object.<string,*>} Plain object
*/
LatLng.toObject = function toObject(message, options) {
if (!options)
options = {};
var object = {};
if (options.defaults) {
object.latitude = 0;
object.longitude = 0;
}
if (message.latitude != null && message.hasOwnProperty("latitude"))
object.latitude = options.json && !isFinite(message.latitude) ? String(message.latitude) : message.latitude;
if (message.longitude != null && message.hasOwnProperty("longitude"))
object.longitude = options.json && !isFinite(message.longitude) ? String(message.longitude) : message.longitude;
return object;
};
/**
* Converts this LatLng to JSON.
* @function toJSON
* @memberof google.type.LatLng
* @instance
* @returns {Object.<string,*>} JSON object
*/
LatLng.prototype.toJSON = function toJSON() {
return this.constructor.toObject(this, $protobuf.util.toJSONOptions);
};
/**
* Gets the default type url for LatLng
* @function getTypeUrl
* @memberof google.type.LatLng
* @static
* @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com")
* @returns {string} The default type url
*/
LatLng.getTypeUrl = function getTypeUrl(typeUrlPrefix) {
if (typeUrlPrefix === undefined) {
typeUrlPrefix = "type.googleapis.com";
}
return typeUrlPrefix + "/google.type.LatLng";
};
return LatLng;
})();
type.LocalizedText = (function() {
/**
* Properties of a LocalizedText.
* @memberof google.type
* @interface ILocalizedText
* @property {string|null} [text] LocalizedText text
* @property {string|null} [languageCode] LocalizedText languageCode
*/
/**
* Constructs a new LocalizedText.
* @memberof google.type
* @classdesc Represents a LocalizedText.
* @implements ILocalizedText
* @constructor
* @param {google.type.ILocalizedText=} [properties] Properties to set
*/
function LocalizedText(properties) {
if (properties)
for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)
if (properties[keys[i]] != null)
this[keys[i]] = properties[keys[i]];
}
/**
* LocalizedText text.
* @member {string} text
* @memberof google.type.LocalizedText
* @instance
*/
LocalizedText.prototype.text = "";
/**
* LocalizedText languageCode.
* @member {string} languageCode
* @memberof google.type.LocalizedText
* @instance
*/
LocalizedText.prototype.languageCode = "";
/**
* Creates a new LocalizedText instance using the specified properties.
* @function create
* @memberof google.type.LocalizedText
* @static
* @param {google.type.ILocalizedText=} [properties] Properties to set
* @returns {google.type.LocalizedText} LocalizedText instance
*/
LocalizedText.create = function create(properties) {
return new LocalizedText(properties);
};
/**
* Encodes the specified LocalizedText message. Does not implicitly {@link google.type.LocalizedText.verify|verify} messages.
* @function encode
* @memberof google.type.LocalizedText
* @static
* @param {google.type.ILocalizedText} message LocalizedText message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
LocalizedText.encode = function encode(message, writer) {
if (!writer)
writer = $Writer.create();
if (message.text != null && Object.hasOwnProperty.call(message, "text"))
writer.uint32(/* id 1, wireType 2 =*/10).string(message.text);
if (message.languageCode != null && Object.hasOwnProperty.call(message, "languageCode"))
writer.uint32(/* id 2, wireType 2 =*/18).string(message.languageCode);
return writer;
};
/**
* Encodes the specified LocalizedText message, length delimited. Does not implicitly {@link google.type.LocalizedText.verify|verify} messages.
* @function encodeDelimited
* @memberof google.type.LocalizedText
* @static
* @param {google.type.ILocalizedText} message LocalizedText message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
LocalizedText.encodeDelimited = function encodeDelimited(message, writer) {
return this.encode(message, writer).ldelim();
};
/**
* Decodes a LocalizedText message from the specified reader or buffer.
* @function decode
* @memberof google.type.LocalizedText
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @param {number} [length] Message length if known beforehand
* @returns {google.type.LocalizedText} LocalizedText
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
LocalizedText.decode = function decode(reader, length, error) {
if (!(reader instanceof $Reader))
reader = $Reader.create(reader);
var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.type.LocalizedText();
while (reader.pos < end) {
var tag = reader.uint32();
if (tag === error)
break;
switch (tag >>> 3) {
case 1: {
message.text = reader.string();
break;
}
case 2: {
message.languageCode = reader.string();
break;
}
default:
reader.skipType(tag & 7);
break;
}
}
return message;
};
/**
* Decodes a LocalizedText message from the specified reader or buffer, length delimited.
* @function decodeDelimited
* @memberof google.type.LocalizedText
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @returns {google.type.LocalizedText} LocalizedText
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
LocalizedText.decodeDelimited = function decodeDelimited(reader) {
if (!(reader instanceof $Reader))
reader = new $Reader(reader);
return this.decode(reader, reader.uint32());
};
/**
* Verifies a LocalizedText message.
* @function verify
* @memberof google.type.LocalizedText
* @static
* @param {Object.<string,*>} message Plain object to verify
* @returns {string|null} `null` if valid, otherwise the reason why it is not
*/
LocalizedText.verify = function verify(message) {
if (typeof message !== "object" || message === null)
return "object expected";
if (message.text != null && message.hasOwnProperty("text"))
if (!$util.isString(message.text))
return "text: string expected";
if (message.languageCode != null && message.hasOwnProperty("languageCode"))
if (!$util.isString(message.languageCode))
return "languageCode: string expected";
return null;
};
/**
* Creates a LocalizedText message from a plain object. Also converts values to their respective internal types.
* @function fromObject
* @memberof google.type.LocalizedText
* @static
* @param {Object.<string,*>} object Plain object
* @returns {google.type.LocalizedText} LocalizedText
*/
LocalizedText.fromObject = function fromObject(object) {
if (object instanceof $root.google.type.LocalizedText)
return object;
var message = new $root.google.type.LocalizedText();
if (object.text != null)
message.text = String(object.text);
if (object.languageCode != null)
message.languageCode = String(object.languageCode);
return message;
};
/**
* Creates a plain object from a LocalizedText message. Also converts values to other types if specified.
* @function toObject
* @memberof google.type.LocalizedText
* @static
* @param {google.type.LocalizedText} message LocalizedText
* @param {$protobuf.IConversionOptions} [options] Conversion options
* @returns {Object.<string,*>} Plain object
*/
LocalizedText.toObject = function toObject(message, options) {
if (!options)
options = {};
var object = {};
if (options.defaults) {
object.text = "";
object.languageCode = "";
}
if (message.text != null && message.hasOwnProperty("text"))
object.text = message.text;
if (message.languageCode != null && message.hasOwnProperty("languageCode"))
object.languageCode = message.languageCode;
return object;
};
/**
* Converts this LocalizedText to JSON.
* @function toJSON
* @memberof google.type.LocalizedText
* @instance
* @returns {Object.<string,*>} JSON object
*/
LocalizedText.prototype.toJSON = function toJSON() {
return this.constructor.toObject(this, $protobuf.util.toJSONOptions);
};
/**
* Gets the default type url for LocalizedText
* @function getTypeUrl
* @memberof google.type.LocalizedText
* @static
* @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com")
* @returns {string} The default type url
*/
LocalizedText.getTypeUrl = function getTypeUrl(typeUrlPrefix) {
if (typeUrlPrefix === undefined) {
typeUrlPrefix = "type.googleapis.com";
}
return typeUrlPrefix + "/google.type.LocalizedText";
};
return LocalizedText;
})();
type.Date = (function() {
/**
* Properties of a Date.
* @memberof google.type
* @interface IDate
* @property {number|null} [year] Date year
* @property {number|null} [month] Date month
* @property {number|null} [day] Date day
*/
/**
* Constructs a new Date.
* @memberof google.type
* @classdesc Represents a Date.
* @implements IDate
* @constructor
* @param {google.type.IDate=} [properties] Properties to set
*/
function Date(properties) {
if (properties)
for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)
if (properties[keys[i]] != null)
this[keys[i]] = properties[keys[i]];
}
/**
* Date year.
* @member {number} year
* @memberof google.type.Date
* @instance
*/
Date.prototype.year = 0;
/**
* Date month.
* @member {number} month
* @memberof google.type.Date
* @instance
*/
Date.prototype.month = 0;
/**
* Date day.
* @member {number} day
* @memberof google.type.Date
* @instance
*/
Date.prototype.day = 0;
/**
* Creates a new Date instance using the specified properties.
* @function create
* @memberof google.type.Date
* @static
* @param {google.type.IDate=} [properties] Properties to set
* @returns {google.type.Date} Date instance
*/
Date.create = function create(properties) {
return new Date(properties);
};
/**
* Encodes the specified Date message. Does not implicitly {@link google.type.Date.verify|verify} messages.
* @function encode
* @memberof google.type.Date
* @static
* @param {google.type.IDate} message Date message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
Date.encode = function encode(message, writer) {
if (!writer)
writer = $Writer.create();
if (message.year != null && Object.hasOwnProperty.call(message, "year"))
writer.uint32(/* id 1, wireType 0 =*/8).int32(message.year);
if (message.month != null && Object.hasOwnProperty.call(message, "month"))
writer.uint32(/* id 2, wireType 0 =*/16).int32(message.month);
if (message.day != null && Object.hasOwnProperty.call(message, "day"))
writer.uint32(/* id 3, wireType 0 =*/24).int32(message.day);
return writer;
};
/**
* Encodes the specified Date message, length delimited. Does not implicitly {@link google.type.Date.verify|verify} messages.
* @function encodeDelimited
* @memberof google.type.Date
* @static
* @param {google.type.IDate} message Date message or plain object to encode
* @param {$protobuf.Writer} [writer] Writer to encode to
* @returns {$protobuf.Writer} Writer
*/
Date.encodeDelimited = function encodeDelimited(message, writer) {
return this.encode(message, writer).ldelim();
};
/**
* Decodes a Date message from the specified reader or buffer.
* @function decode
* @memberof google.type.Date
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @param {number} [length] Message length if known beforehand
* @returns {google.type.Date} Date
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
Date.decode = function decode(reader, length, error) {
if (!(reader instanceof $Reader))
reader = $Reader.create(reader);
var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.type.Date();
while (reader.pos < end) {
var tag = reader.uint32();
if (tag === error)
break;
switch (tag >>> 3) {
case 1: {
message.year = reader.int32();
break;
}
case 2: {
message.month = reader.int32();
break;
}
case 3: {
message.day = reader.int32();
break;
}
default:
reader.skipType(tag & 7);
break;
}
}
return message;
};
/**
* Decodes a Date message from the specified reader or buffer, length delimited.
* @function decodeDelimited
* @memberof google.type.Date
* @static
* @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from
* @returns {google.type.Date} Date
* @throws {Error} If the payload is not a reader or valid buffer
* @throws {$protobuf.util.ProtocolError} If required fields are missing
*/
Date.decodeDelimited = function decodeDelimited(reader) {
if (!(reader instanceof $Reader))
reader = new $Reader(reader);
return this.decode(reader, reader.uint32());
};
/**
* Verifies a Date message.
* @function verify
* @memberof google.type.Date
* @static
* @param {Object.<string,*>} message Plain object to verify
* @returns {string|null} `null` if valid, otherwise the reason why it is not
*/
Date.verify = function verify(message) {
if (typeof message !== "object" || message === null)
return "object expected";
if (message.year != null && message.hasOwnProperty("year"))
if (!$util.isInteger(message.year))
return "year: integer expected";
if (message.month != null && message.hasOwnProperty("month"))
if (!$util.isInteger(message.month))
return "month: integer expected";
if (message.day != null && message.hasOwnProperty("day"))
if (!$util.isInteger(message.day))
return "day: integer expected";
return null;
};
/**
* Creates a Date message from a plain object. Also converts values to their respective internal types.
* @function fromObject
* @memberof google.type.Date
* @static
* @param {Object.<string,*>} object Plain object
* @returns {google.type.Date} Date
*/
Date.fromObject = function fromObject(object) {
if (object instanceof $root.google.type.Date)
return object;
var message = new $root.google.type.Date();
if (object.year != null)
message.year = object.year | 0;
if (object.month != null)
message.month = object.month | 0;
if (object.day != null)
message.day = object.day | 0;
return message;
};
/**
* Creates a plain object from a Date message. Also converts values to other types if specified.
* @function toObject
* @memberof google.type.Date
* @static
* @param {google.type.Date} message Date
* @param {$protobuf.IConversionOptions} [options] Conversion options
* @returns {Object.<string,*>} Plain object
*/
Date.toObject = function toObject(message, options) {
if (!options)
options = {};
var object = {};
if (options.defaults) {
object.year = 0;
object.month = 0;
object.day = 0;
}
if (message.year != null && message.hasOwnProperty("year"))
object.year = message.year;
if (message.month != null && message.hasOwnProperty("month"))
object.month = message.month;
if (message.day != null && message.hasOwnProperty("day"))
object.day = message.day;
return object;
};
/**
* Converts this Date to JSON.
* @function toJSON
* @memberof google.type.Date
* @instance
* @returns {Object.<string,*>} JSON object
*/
Date.prototype.toJSON = function toJSON() {
return this.constructor.toObject(this, $protobuf.util.toJSONOptions);
};
/**
* Gets the default type url for Date
* @function getTypeUrl
* @memberof google.type.Date
* @static
* @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com")
* @returns {string} The default type url
*/
Date.getTypeUrl = function getTypeUrl(typeUrlPrefix) {
if (typeUrlPrefix === undefined) {
typeUrlPrefix = "type.googleapis.com";
}
return typeUrlPrefix + "/google.type.Date";
};
return Date;
})();
type.Money = (function() {
/**
* Properties of a Money.
* @memberof google.type
* @interface IMoney
* @property {string|null} [currencyCode] Money currencyCode
* @property {number|Long|null} [units] Money units
* @property {number|null} [nanos] Money nanos
*/
/**
* Constructs a new Money.
* @memberof google.type
* @classdesc Represents a Money.
* @implements IMoney
* @constructor
* @param {google.type.IMoney=} [properties] Properties to set
*/
function Money(properties) {
if (properties)
for (var keys = Object.keys(properties), i = 0; i < keys.length; ++i)
if (properties[keys[i]] != null)
this[keys[i]] = properties[keys[i]];
}
/**
* Money currencyCode.
* @member {string} currencyCode
* @memberof google.type.Money
* @instance
*/
Money.prototype.currencyCode = "";
/**
* Money units.
* @member {number|Long} units