UNPKG

@googlemaps/places

Version:
1,033 lines (950 loc) 2.4 MB
// Copyright 2025 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) { 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(); 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) { 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(); 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) { 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(); 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.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 * @memberof google.type.Money * @instance */ Money.prototype.units = $util.Long ? $util.Long.fromBits(0,0,false) : 0; /** * Money nanos. * @member {number} nanos * @memberof google.type.Money * @instance */ Money.prototype.nanos = 0; /** * Creates a new Money instance using the specified properties. * @function create * @memberof google.type.Money * @static * @param {google.type.IMoney=} [properties] Properties to set * @returns {google.type.Money} Money instance */ Money.create = function create(properties) { return new Money(properties); }; /** * Encodes the specified Money message. Does not implicitly {@link google.type.Money.verify|verify} messages. * @function encode * @memberof google.type.Money * @static * @param {google.type.IMoney} message Money message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ Money.encode = function encode(message, writer) { if (!writer) writer = $Writer.create(); if (message.currencyCode != null && Object.hasOwnProperty.call(message, "currencyCode")) writer.uint32(/* id 1, wireType 2 =*/10).string(message.currencyCode); if (message.units != null && Object.hasOwnProperty.call(message, "units")) writer.uint32(/* id 2, wireType 0 =*/16).int64(message.units); if (message.nanos != null && Object.hasOwnProperty.call(message, "nanos")) writer.uint32(/* id 3, wireType 0 =*/24).int32(message.nanos); return writer; }; /** * Encodes the specified Money message, length delimited. Does not implicitly {@link google.type.Money.verify|verify} messages. * @function encodeDelimited * @memberof google.type.Money * @static * @param {google.type.IMoney} message Money message or plain object to encode * @param {$protobuf.Writer} [writer] Writer to encode to * @returns {$protobuf.Writer} Writer */ Money.encodeDelimited = function encodeDelimited(message, writer) { return this.encode(message, writer).ldelim(); }; /** * Decodes a Money message from the specified reader or buffer. * @function decode * @memberof google.type.Money * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @param {number} [length] Message length if known beforehand * @returns {google.type.Money} Money * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ Money.decode = function decode(reader, length) { if (!(reader instanceof $Reader)) reader = $Reader.create(reader); var end = length === undefined ? reader.len : reader.pos + length, message = new $root.google.type.Money(); while (reader.pos < end) { var tag = reader.uint32(); switch (tag >>> 3) { case 1: { message.currencyCode = reader.string(); break; } case 2: { message.units = reader.int64(); break; } case 3: { message.nanos = reader.int32(); break; } default: reader.skipType(tag & 7); break; } } return message; }; /** * Decodes a Money message from the specified reader or buffer, length delimited. * @function decodeDelimited * @memberof google.type.Money * @static * @param {$protobuf.Reader|Uint8Array} reader Reader or buffer to decode from * @returns {google.type.Money} Money * @throws {Error} If the payload is not a reader or valid buffer * @throws {$protobuf.util.ProtocolError} If required fields are missing */ Money.decodeDelimited = function decodeDelimited(reader) { if (!(reader instanceof $Reader)) reader = new $Reader(reader); return this.decode(reader, reader.uint32()); }; /** * Verifies a Money message. * @function verify * @memberof google.type.Money * @static * @param {Object.<string,*>} message Plain object to verify * @returns {string|null} `null` if valid, otherwise the reason why it is not */ Money.verify = function verify(message) { if (typeof message !== "object" || message === null) return "object expected"; if (message.currencyCode != null && message.hasOwnProperty("currencyCode")) if (!$util.isString(message.currencyCode)) return "currencyCode: string expected"; if (message.units != null && message.hasOwnProperty("units")) if (!$util.isInteger(message.units) && !(message.units && $util.isInteger(message.units.low) && $util.isInteger(message.units.high))) return "units: integer|Long expected"; if (message.nanos != null && message.hasOwnProperty("nanos")) if (!$util.isInteger(message.nanos)) return "nanos: integer expected"; return null; }; /** * Creates a Money message from a plain object. Also converts values to their respective internal types. * @function fromObject * @memberof google.type.Money * @static * @param {Object.<string,*>} object Plain object * @returns {google.type.Money} Money */ Money.fromObject = function fromObject(object) { if (object instanceof $root.google.type.Money) return object; var message = new $root.google.type.Money(); if (object.currencyCode != null) message.currencyCode = String(object.currencyCode); if (object.units != null) if ($util.Long) (message.units = $util.Long.fromValue(object.units)).unsigned = false; else if (typeof object.units === "string") message.units = parseInt(object.units, 10); else if (typeof object.units === "number") message.units = object.units; else if (typeof object.units === "object") message.units = new $util.LongBits(object.units.low >>> 0, object.units.high >>> 0).toNumber(); if (object.nanos != null) message.nanos = object.nanos | 0; return message; }; /** * Creates a plain object from a Money message. Also converts values to other types if specified. * @function toObject * @memberof google.type.Money * @static * @param {google.type.Money} message Money * @param {$protobuf.IConversionOptions} [options] Conversion options * @returns {Object.<string,*>} Plain object */ Money.toObject = function toObject(message, options) { if (!options) options = {}; var object = {}; if (options.defaults) { object.currencyCode = ""; if ($util.Long) { var long = new $util.Long(0, 0, false); object.units = options.longs === String ? long.toString() : options.longs === Number ? long.toNumber() : long; } else object.units = options.longs === String ? "0" : 0; object.nanos = 0; } if (message.currencyCode != null && message.hasOwnProperty("currencyCode")) object.currencyCode = message.currencyCode; if (message.units != null && message.hasOwnProperty("units")) if (typeof message.units === "number") object.units = options.longs === String ? String(message.units) : message.units; else object.units = options.longs === String ? $util.Long.prototype.toString.call(message.units) : options.longs === Number ? new $util.LongBits(message.units.low >>> 0, message.units.high >>> 0).toNumber() : message.units; if (message.nanos != null && message.hasOwnProperty("nanos")) object.nanos = message.nanos; return object; }; /** * Converts this Money to JSON. * @function toJSON * @memberof google.type.Money * @instance * @returns {Object.<string,*>} JSON object */ Money.prototype.toJSON = function toJSON() { return this.constructor.toObject(this, $protobuf.util.toJSONOptions); }; /** * Gets the default type url for Money * @function getTypeUrl * @memberof google.type.Money * @static * @param {string} [typeUrlPrefix] your custom typeUrlPrefix(default "type.googleapis.com") * @returns {string} The default type url */ Money.getTypeUrl = function getTypeUrl(typeUrlPrefix) { if (typeUrlPrefix === undefined) { typeUrlPrefix = "type.googleapis.com"; } return typeUrlPrefix + "/google.type.Money"; }; return Money; })(); type.Date = (function() { /** * Properties o