8735 lines
		
	
	
		
			347 KiB
		
	
	
	
		
			Ruby
		
	
	
	
			
		
		
	
	
			8735 lines
		
	
	
		
			347 KiB
		
	
	
	
		
			Ruby
		
	
	
	
# Copyright 2015 Google Inc.
 | 
						|
#
 | 
						|
# 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.
 | 
						|
 | 
						|
require 'date'
 | 
						|
require 'google/apis/core/base_service'
 | 
						|
require 'google/apis/core/json_representation'
 | 
						|
require 'google/apis/core/hashable'
 | 
						|
require 'google/apis/errors'
 | 
						|
 | 
						|
module Google
 | 
						|
  module Apis
 | 
						|
    module SheetsV4
 | 
						|
      
 | 
						|
      # Adds a new banded range to the spreadsheet.
 | 
						|
      class AddBandingRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A banded (alternating colors) range in a sheet.
 | 
						|
        # Corresponds to the JSON property `bandedRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::BandedRange]
 | 
						|
        attr_accessor :banded_range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @banded_range = args[:banded_range] if args.key?(:banded_range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The result of adding a banded range.
 | 
						|
      class AddBandingResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A banded (alternating colors) range in a sheet.
 | 
						|
        # Corresponds to the JSON property `bandedRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::BandedRange]
 | 
						|
        attr_accessor :banded_range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @banded_range = args[:banded_range] if args.key?(:banded_range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Adds a chart to a sheet in the spreadsheet.
 | 
						|
      class AddChartRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A chart embedded in a sheet.
 | 
						|
        # Corresponds to the JSON property `chart`
 | 
						|
        # @return [Google::Apis::SheetsV4::EmbeddedChart]
 | 
						|
        attr_accessor :chart
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @chart = args[:chart] if args.key?(:chart)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The result of adding a chart to a spreadsheet.
 | 
						|
      class AddChartResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A chart embedded in a sheet.
 | 
						|
        # Corresponds to the JSON property `chart`
 | 
						|
        # @return [Google::Apis::SheetsV4::EmbeddedChart]
 | 
						|
        attr_accessor :chart
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @chart = args[:chart] if args.key?(:chart)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Adds a new conditional format rule at the given index.
 | 
						|
      # All subsequent rules' indexes are incremented.
 | 
						|
      class AddConditionalFormatRuleRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The zero-based index where the rule should be inserted.
 | 
						|
        # Corresponds to the JSON property `index`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :index
 | 
						|
      
 | 
						|
        # A rule describing a conditional format.
 | 
						|
        # Corresponds to the JSON property `rule`
 | 
						|
        # @return [Google::Apis::SheetsV4::ConditionalFormatRule]
 | 
						|
        attr_accessor :rule
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @index = args[:index] if args.key?(:index)
 | 
						|
          @rule = args[:rule] if args.key?(:rule)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Adds a filter view.
 | 
						|
      class AddFilterViewRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A filter view.
 | 
						|
        # Corresponds to the JSON property `filter`
 | 
						|
        # @return [Google::Apis::SheetsV4::FilterView]
 | 
						|
        attr_accessor :filter
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @filter = args[:filter] if args.key?(:filter)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The result of adding a filter view.
 | 
						|
      class AddFilterViewResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A filter view.
 | 
						|
        # Corresponds to the JSON property `filter`
 | 
						|
        # @return [Google::Apis::SheetsV4::FilterView]
 | 
						|
        attr_accessor :filter
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @filter = args[:filter] if args.key?(:filter)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Adds a named range to the spreadsheet.
 | 
						|
      class AddNamedRangeRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A named range.
 | 
						|
        # Corresponds to the JSON property `namedRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::NamedRange]
 | 
						|
        attr_accessor :named_range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @named_range = args[:named_range] if args.key?(:named_range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The result of adding a named range.
 | 
						|
      class AddNamedRangeResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A named range.
 | 
						|
        # Corresponds to the JSON property `namedRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::NamedRange]
 | 
						|
        attr_accessor :named_range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @named_range = args[:named_range] if args.key?(:named_range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Adds a new protected range.
 | 
						|
      class AddProtectedRangeRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A protected range.
 | 
						|
        # Corresponds to the JSON property `protectedRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::ProtectedRange]
 | 
						|
        attr_accessor :protected_range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @protected_range = args[:protected_range] if args.key?(:protected_range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The result of adding a new protected range.
 | 
						|
      class AddProtectedRangeResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A protected range.
 | 
						|
        # Corresponds to the JSON property `protectedRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::ProtectedRange]
 | 
						|
        attr_accessor :protected_range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @protected_range = args[:protected_range] if args.key?(:protected_range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Adds a new sheet.
 | 
						|
      # When a sheet is added at a given index,
 | 
						|
      # all subsequent sheets' indexes are incremented.
 | 
						|
      # To add an object sheet, use AddChartRequest instead and specify
 | 
						|
      # EmbeddedObjectPosition.sheetId or
 | 
						|
      # EmbeddedObjectPosition.newSheet.
 | 
						|
      class AddSheetRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Properties of a sheet.
 | 
						|
        # Corresponds to the JSON property `properties`
 | 
						|
        # @return [Google::Apis::SheetsV4::SheetProperties]
 | 
						|
        attr_accessor :properties
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @properties = args[:properties] if args.key?(:properties)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The result of adding a sheet.
 | 
						|
      class AddSheetResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Properties of a sheet.
 | 
						|
        # Corresponds to the JSON property `properties`
 | 
						|
        # @return [Google::Apis::SheetsV4::SheetProperties]
 | 
						|
        attr_accessor :properties
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @properties = args[:properties] if args.key?(:properties)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Adds new cells after the last row with data in a sheet,
 | 
						|
      # inserting new rows into the sheet if necessary.
 | 
						|
      class AppendCellsRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The fields of CellData that should be updated.
 | 
						|
        # At least one field must be specified.
 | 
						|
        # The root is the CellData; 'row.values.' should not be specified.
 | 
						|
        # A single `"*"` can be used as short-hand for listing every field.
 | 
						|
        # Corresponds to the JSON property `fields`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :fields
 | 
						|
      
 | 
						|
        # The data to append.
 | 
						|
        # Corresponds to the JSON property `rows`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::RowData>]
 | 
						|
        attr_accessor :rows
 | 
						|
      
 | 
						|
        # The sheet ID to append the data to.
 | 
						|
        # Corresponds to the JSON property `sheetId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :sheet_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @fields = args[:fields] if args.key?(:fields)
 | 
						|
          @rows = args[:rows] if args.key?(:rows)
 | 
						|
          @sheet_id = args[:sheet_id] if args.key?(:sheet_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Appends rows or columns to the end of a sheet.
 | 
						|
      class AppendDimensionRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Whether rows or columns should be appended.
 | 
						|
        # Corresponds to the JSON property `dimension`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :dimension
 | 
						|
      
 | 
						|
        # The number of rows or columns to append.
 | 
						|
        # Corresponds to the JSON property `length`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :length
 | 
						|
      
 | 
						|
        # The sheet to append rows or columns to.
 | 
						|
        # Corresponds to the JSON property `sheetId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :sheet_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @dimension = args[:dimension] if args.key?(:dimension)
 | 
						|
          @length = args[:length] if args.key?(:length)
 | 
						|
          @sheet_id = args[:sheet_id] if args.key?(:sheet_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The response when updating a range of values in a spreadsheet.
 | 
						|
      class AppendValuesResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The spreadsheet the updates were applied to.
 | 
						|
        # Corresponds to the JSON property `spreadsheetId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :spreadsheet_id
 | 
						|
      
 | 
						|
        # The range (in A1 notation) of the table that values are being appended to
 | 
						|
        # (before the values were appended).
 | 
						|
        # Empty if no table was found.
 | 
						|
        # Corresponds to the JSON property `tableRange`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :table_range
 | 
						|
      
 | 
						|
        # The response when updating a range of values in a spreadsheet.
 | 
						|
        # Corresponds to the JSON property `updates`
 | 
						|
        # @return [Google::Apis::SheetsV4::UpdateValuesResponse]
 | 
						|
        attr_accessor :updates
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @spreadsheet_id = args[:spreadsheet_id] if args.key?(:spreadsheet_id)
 | 
						|
          @table_range = args[:table_range] if args.key?(:table_range)
 | 
						|
          @updates = args[:updates] if args.key?(:updates)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Fills in more data based on existing data.
 | 
						|
      class AutoFillRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        # A combination of a source range and how to extend that source.
 | 
						|
        # Corresponds to the JSON property `sourceAndDestination`
 | 
						|
        # @return [Google::Apis::SheetsV4::SourceAndDestination]
 | 
						|
        attr_accessor :source_and_destination
 | 
						|
      
 | 
						|
        # True if we should generate data with the "alternate" series.
 | 
						|
        # This differs based on the type and amount of source data.
 | 
						|
        # Corresponds to the JSON property `useAlternateSeries`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :use_alternate_series
 | 
						|
        alias_method :use_alternate_series?, :use_alternate_series
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
          @source_and_destination = args[:source_and_destination] if args.key?(:source_and_destination)
 | 
						|
          @use_alternate_series = args[:use_alternate_series] if args.key?(:use_alternate_series)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Automatically resizes one or more dimensions based on the contents
 | 
						|
      # of the cells in that dimension.
 | 
						|
      class AutoResizeDimensionsRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A range along a single dimension on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open: the start index is inclusive
 | 
						|
        # and the end index is exclusive.
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # Corresponds to the JSON property `dimensions`
 | 
						|
        # @return [Google::Apis::SheetsV4::DimensionRange]
 | 
						|
        attr_accessor :dimensions
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @dimensions = args[:dimensions] if args.key?(:dimensions)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A banded (alternating colors) range in a sheet.
 | 
						|
      class BandedRange
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The id of the banded range.
 | 
						|
        # Corresponds to the JSON property `bandedRangeId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :banded_range_id
 | 
						|
      
 | 
						|
        # Properties referring a single dimension (either row or column). If both
 | 
						|
        # BandedRange.row_properties and BandedRange.column_properties are
 | 
						|
        # set, the fill colors are applied to cells according to the following rules:
 | 
						|
        # * header_color and footer_color take priority over band colors.
 | 
						|
        # * first_band_color takes priority over second_band_color.
 | 
						|
        # * row_properties takes priority over column_properties.
 | 
						|
        # For example, the first row color takes priority over the first column
 | 
						|
        # color, but the first column color takes priority over the second row color.
 | 
						|
        # Similarly, the row header takes priority over the column header in the
 | 
						|
        # top left cell, but the column header takes priority over the first row
 | 
						|
        # color if the row header is not set.
 | 
						|
        # Corresponds to the JSON property `columnProperties`
 | 
						|
        # @return [Google::Apis::SheetsV4::BandingProperties]
 | 
						|
        attr_accessor :column_properties
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        # Properties referring a single dimension (either row or column). If both
 | 
						|
        # BandedRange.row_properties and BandedRange.column_properties are
 | 
						|
        # set, the fill colors are applied to cells according to the following rules:
 | 
						|
        # * header_color and footer_color take priority over band colors.
 | 
						|
        # * first_band_color takes priority over second_band_color.
 | 
						|
        # * row_properties takes priority over column_properties.
 | 
						|
        # For example, the first row color takes priority over the first column
 | 
						|
        # color, but the first column color takes priority over the second row color.
 | 
						|
        # Similarly, the row header takes priority over the column header in the
 | 
						|
        # top left cell, but the column header takes priority over the first row
 | 
						|
        # color if the row header is not set.
 | 
						|
        # Corresponds to the JSON property `rowProperties`
 | 
						|
        # @return [Google::Apis::SheetsV4::BandingProperties]
 | 
						|
        attr_accessor :row_properties
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @banded_range_id = args[:banded_range_id] if args.key?(:banded_range_id)
 | 
						|
          @column_properties = args[:column_properties] if args.key?(:column_properties)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
          @row_properties = args[:row_properties] if args.key?(:row_properties)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Properties referring a single dimension (either row or column). If both
 | 
						|
      # BandedRange.row_properties and BandedRange.column_properties are
 | 
						|
      # set, the fill colors are applied to cells according to the following rules:
 | 
						|
      # * header_color and footer_color take priority over band colors.
 | 
						|
      # * first_band_color takes priority over second_band_color.
 | 
						|
      # * row_properties takes priority over column_properties.
 | 
						|
      # For example, the first row color takes priority over the first column
 | 
						|
      # color, but the first column color takes priority over the second row color.
 | 
						|
      # Similarly, the row header takes priority over the column header in the
 | 
						|
      # top left cell, but the column header takes priority over the first row
 | 
						|
      # color if the row header is not set.
 | 
						|
      class BandingProperties
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Represents a color in the RGBA color space. This representation is designed
 | 
						|
        # for simplicity of conversion to/from color representations in various
 | 
						|
        # languages over compactness; for example, the fields of this representation
 | 
						|
        # can be trivially provided to the constructor of "java.awt.Color" in Java; it
 | 
						|
        # can also be trivially provided to UIColor's "+colorWithRed:green:blue:alpha"
 | 
						|
        # method in iOS; and, with just a little work, it can be easily formatted into
 | 
						|
        # a CSS "rgba()" string in JavaScript, as well. Here are some examples:
 | 
						|
        # Example (Java):
 | 
						|
        # import com.google.type.Color;
 | 
						|
        # // ...
 | 
						|
        # public static java.awt.Color fromProto(Color protocolor) `
 | 
						|
        # float alpha = protocolor.hasAlpha()
 | 
						|
        # ? protocolor.getAlpha().getValue()
 | 
						|
        # : 1.0;
 | 
						|
        # return new java.awt.Color(
 | 
						|
        # protocolor.getRed(),
 | 
						|
        # protocolor.getGreen(),
 | 
						|
        # protocolor.getBlue(),
 | 
						|
        # alpha);
 | 
						|
        # `
 | 
						|
        # public static Color toProto(java.awt.Color color) `
 | 
						|
        # float red = (float) color.getRed();
 | 
						|
        # float green = (float) color.getGreen();
 | 
						|
        # float blue = (float) color.getBlue();
 | 
						|
        # float denominator = 255.0;
 | 
						|
        # Color.Builder resultBuilder =
 | 
						|
        # Color
 | 
						|
        # .newBuilder()
 | 
						|
        # .setRed(red / denominator)
 | 
						|
        # .setGreen(green / denominator)
 | 
						|
        # .setBlue(blue / denominator);
 | 
						|
        # int alpha = color.getAlpha();
 | 
						|
        # if (alpha != 255) `
 | 
						|
        # result.setAlpha(
 | 
						|
        # FloatValue
 | 
						|
        # .newBuilder()
 | 
						|
        # .setValue(((float) alpha) / denominator)
 | 
						|
        # .build());
 | 
						|
        # `
 | 
						|
        # return resultBuilder.build();
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (iOS / Obj-C):
 | 
						|
        # // ...
 | 
						|
        # static UIColor* fromProto(Color* protocolor) `
 | 
						|
        # float red = [protocolor red];
 | 
						|
        # float green = [protocolor green];
 | 
						|
        # float blue = [protocolor blue];
 | 
						|
        # FloatValue* alpha_wrapper = [protocolor alpha];
 | 
						|
        # float alpha = 1.0;
 | 
						|
        # if (alpha_wrapper != nil) `
 | 
						|
        # alpha = [alpha_wrapper value];
 | 
						|
        # `
 | 
						|
        # return [UIColor colorWithRed:red green:green blue:blue alpha:alpha];
 | 
						|
        # `
 | 
						|
        # static Color* toProto(UIColor* color) `
 | 
						|
        # CGFloat red, green, blue, alpha;
 | 
						|
        # if (![color getRed:&red green:&green blue:&blue alpha:&alpha]) `
 | 
						|
        # return nil;
 | 
						|
        # `
 | 
						|
        # Color* result = [Color alloc] init];
 | 
						|
        # [result setRed:red];
 | 
						|
        # [result setGreen:green];
 | 
						|
        # [result setBlue:blue];
 | 
						|
        # if (alpha <= 0.9999) `
 | 
						|
        # [result setAlpha:floatWrapperWithValue(alpha)];
 | 
						|
        # `
 | 
						|
        # [result autorelease];
 | 
						|
        # return result;
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (JavaScript):
 | 
						|
        # // ...
 | 
						|
        # var protoToCssColor = function(rgb_color) `
 | 
						|
        # var redFrac = rgb_color.red || 0.0;
 | 
						|
        # var greenFrac = rgb_color.green || 0.0;
 | 
						|
        # var blueFrac = rgb_color.blue || 0.0;
 | 
						|
        # var red = Math.floor(redFrac * 255);
 | 
						|
        # var green = Math.floor(greenFrac * 255);
 | 
						|
        # var blue = Math.floor(blueFrac * 255);
 | 
						|
        # if (!('alpha' in rgb_color)) `
 | 
						|
        # return rgbToCssColor_(red, green, blue);
 | 
						|
        # `
 | 
						|
        # var alphaFrac = rgb_color.alpha.value || 0.0;
 | 
						|
        # var rgbParams = [red, green, blue].join(',');
 | 
						|
        # return ['rgba(', rgbParams, ',', alphaFrac, ')'].join('');
 | 
						|
        # `;
 | 
						|
        # var rgbToCssColor_ = function(red, green, blue) `
 | 
						|
        # var rgbNumber = new Number((red << 16) | (green << 8) | blue);
 | 
						|
        # var hexString = rgbNumber.toString(16);
 | 
						|
        # var missingZeros = 6 - hexString.length;
 | 
						|
        # var resultBuilder = ['#'];
 | 
						|
        # for (var i = 0; i < missingZeros; i++) `
 | 
						|
        # resultBuilder.push('0');
 | 
						|
        # `
 | 
						|
        # resultBuilder.push(hexString);
 | 
						|
        # return resultBuilder.join('');
 | 
						|
        # `;
 | 
						|
        # // ...
 | 
						|
        # Corresponds to the JSON property `firstBandColor`
 | 
						|
        # @return [Google::Apis::SheetsV4::Color]
 | 
						|
        attr_accessor :first_band_color
 | 
						|
      
 | 
						|
        # Represents a color in the RGBA color space. This representation is designed
 | 
						|
        # for simplicity of conversion to/from color representations in various
 | 
						|
        # languages over compactness; for example, the fields of this representation
 | 
						|
        # can be trivially provided to the constructor of "java.awt.Color" in Java; it
 | 
						|
        # can also be trivially provided to UIColor's "+colorWithRed:green:blue:alpha"
 | 
						|
        # method in iOS; and, with just a little work, it can be easily formatted into
 | 
						|
        # a CSS "rgba()" string in JavaScript, as well. Here are some examples:
 | 
						|
        # Example (Java):
 | 
						|
        # import com.google.type.Color;
 | 
						|
        # // ...
 | 
						|
        # public static java.awt.Color fromProto(Color protocolor) `
 | 
						|
        # float alpha = protocolor.hasAlpha()
 | 
						|
        # ? protocolor.getAlpha().getValue()
 | 
						|
        # : 1.0;
 | 
						|
        # return new java.awt.Color(
 | 
						|
        # protocolor.getRed(),
 | 
						|
        # protocolor.getGreen(),
 | 
						|
        # protocolor.getBlue(),
 | 
						|
        # alpha);
 | 
						|
        # `
 | 
						|
        # public static Color toProto(java.awt.Color color) `
 | 
						|
        # float red = (float) color.getRed();
 | 
						|
        # float green = (float) color.getGreen();
 | 
						|
        # float blue = (float) color.getBlue();
 | 
						|
        # float denominator = 255.0;
 | 
						|
        # Color.Builder resultBuilder =
 | 
						|
        # Color
 | 
						|
        # .newBuilder()
 | 
						|
        # .setRed(red / denominator)
 | 
						|
        # .setGreen(green / denominator)
 | 
						|
        # .setBlue(blue / denominator);
 | 
						|
        # int alpha = color.getAlpha();
 | 
						|
        # if (alpha != 255) `
 | 
						|
        # result.setAlpha(
 | 
						|
        # FloatValue
 | 
						|
        # .newBuilder()
 | 
						|
        # .setValue(((float) alpha) / denominator)
 | 
						|
        # .build());
 | 
						|
        # `
 | 
						|
        # return resultBuilder.build();
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (iOS / Obj-C):
 | 
						|
        # // ...
 | 
						|
        # static UIColor* fromProto(Color* protocolor) `
 | 
						|
        # float red = [protocolor red];
 | 
						|
        # float green = [protocolor green];
 | 
						|
        # float blue = [protocolor blue];
 | 
						|
        # FloatValue* alpha_wrapper = [protocolor alpha];
 | 
						|
        # float alpha = 1.0;
 | 
						|
        # if (alpha_wrapper != nil) `
 | 
						|
        # alpha = [alpha_wrapper value];
 | 
						|
        # `
 | 
						|
        # return [UIColor colorWithRed:red green:green blue:blue alpha:alpha];
 | 
						|
        # `
 | 
						|
        # static Color* toProto(UIColor* color) `
 | 
						|
        # CGFloat red, green, blue, alpha;
 | 
						|
        # if (![color getRed:&red green:&green blue:&blue alpha:&alpha]) `
 | 
						|
        # return nil;
 | 
						|
        # `
 | 
						|
        # Color* result = [Color alloc] init];
 | 
						|
        # [result setRed:red];
 | 
						|
        # [result setGreen:green];
 | 
						|
        # [result setBlue:blue];
 | 
						|
        # if (alpha <= 0.9999) `
 | 
						|
        # [result setAlpha:floatWrapperWithValue(alpha)];
 | 
						|
        # `
 | 
						|
        # [result autorelease];
 | 
						|
        # return result;
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (JavaScript):
 | 
						|
        # // ...
 | 
						|
        # var protoToCssColor = function(rgb_color) `
 | 
						|
        # var redFrac = rgb_color.red || 0.0;
 | 
						|
        # var greenFrac = rgb_color.green || 0.0;
 | 
						|
        # var blueFrac = rgb_color.blue || 0.0;
 | 
						|
        # var red = Math.floor(redFrac * 255);
 | 
						|
        # var green = Math.floor(greenFrac * 255);
 | 
						|
        # var blue = Math.floor(blueFrac * 255);
 | 
						|
        # if (!('alpha' in rgb_color)) `
 | 
						|
        # return rgbToCssColor_(red, green, blue);
 | 
						|
        # `
 | 
						|
        # var alphaFrac = rgb_color.alpha.value || 0.0;
 | 
						|
        # var rgbParams = [red, green, blue].join(',');
 | 
						|
        # return ['rgba(', rgbParams, ',', alphaFrac, ')'].join('');
 | 
						|
        # `;
 | 
						|
        # var rgbToCssColor_ = function(red, green, blue) `
 | 
						|
        # var rgbNumber = new Number((red << 16) | (green << 8) | blue);
 | 
						|
        # var hexString = rgbNumber.toString(16);
 | 
						|
        # var missingZeros = 6 - hexString.length;
 | 
						|
        # var resultBuilder = ['#'];
 | 
						|
        # for (var i = 0; i < missingZeros; i++) `
 | 
						|
        # resultBuilder.push('0');
 | 
						|
        # `
 | 
						|
        # resultBuilder.push(hexString);
 | 
						|
        # return resultBuilder.join('');
 | 
						|
        # `;
 | 
						|
        # // ...
 | 
						|
        # Corresponds to the JSON property `footerColor`
 | 
						|
        # @return [Google::Apis::SheetsV4::Color]
 | 
						|
        attr_accessor :footer_color
 | 
						|
      
 | 
						|
        # Represents a color in the RGBA color space. This representation is designed
 | 
						|
        # for simplicity of conversion to/from color representations in various
 | 
						|
        # languages over compactness; for example, the fields of this representation
 | 
						|
        # can be trivially provided to the constructor of "java.awt.Color" in Java; it
 | 
						|
        # can also be trivially provided to UIColor's "+colorWithRed:green:blue:alpha"
 | 
						|
        # method in iOS; and, with just a little work, it can be easily formatted into
 | 
						|
        # a CSS "rgba()" string in JavaScript, as well. Here are some examples:
 | 
						|
        # Example (Java):
 | 
						|
        # import com.google.type.Color;
 | 
						|
        # // ...
 | 
						|
        # public static java.awt.Color fromProto(Color protocolor) `
 | 
						|
        # float alpha = protocolor.hasAlpha()
 | 
						|
        # ? protocolor.getAlpha().getValue()
 | 
						|
        # : 1.0;
 | 
						|
        # return new java.awt.Color(
 | 
						|
        # protocolor.getRed(),
 | 
						|
        # protocolor.getGreen(),
 | 
						|
        # protocolor.getBlue(),
 | 
						|
        # alpha);
 | 
						|
        # `
 | 
						|
        # public static Color toProto(java.awt.Color color) `
 | 
						|
        # float red = (float) color.getRed();
 | 
						|
        # float green = (float) color.getGreen();
 | 
						|
        # float blue = (float) color.getBlue();
 | 
						|
        # float denominator = 255.0;
 | 
						|
        # Color.Builder resultBuilder =
 | 
						|
        # Color
 | 
						|
        # .newBuilder()
 | 
						|
        # .setRed(red / denominator)
 | 
						|
        # .setGreen(green / denominator)
 | 
						|
        # .setBlue(blue / denominator);
 | 
						|
        # int alpha = color.getAlpha();
 | 
						|
        # if (alpha != 255) `
 | 
						|
        # result.setAlpha(
 | 
						|
        # FloatValue
 | 
						|
        # .newBuilder()
 | 
						|
        # .setValue(((float) alpha) / denominator)
 | 
						|
        # .build());
 | 
						|
        # `
 | 
						|
        # return resultBuilder.build();
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (iOS / Obj-C):
 | 
						|
        # // ...
 | 
						|
        # static UIColor* fromProto(Color* protocolor) `
 | 
						|
        # float red = [protocolor red];
 | 
						|
        # float green = [protocolor green];
 | 
						|
        # float blue = [protocolor blue];
 | 
						|
        # FloatValue* alpha_wrapper = [protocolor alpha];
 | 
						|
        # float alpha = 1.0;
 | 
						|
        # if (alpha_wrapper != nil) `
 | 
						|
        # alpha = [alpha_wrapper value];
 | 
						|
        # `
 | 
						|
        # return [UIColor colorWithRed:red green:green blue:blue alpha:alpha];
 | 
						|
        # `
 | 
						|
        # static Color* toProto(UIColor* color) `
 | 
						|
        # CGFloat red, green, blue, alpha;
 | 
						|
        # if (![color getRed:&red green:&green blue:&blue alpha:&alpha]) `
 | 
						|
        # return nil;
 | 
						|
        # `
 | 
						|
        # Color* result = [Color alloc] init];
 | 
						|
        # [result setRed:red];
 | 
						|
        # [result setGreen:green];
 | 
						|
        # [result setBlue:blue];
 | 
						|
        # if (alpha <= 0.9999) `
 | 
						|
        # [result setAlpha:floatWrapperWithValue(alpha)];
 | 
						|
        # `
 | 
						|
        # [result autorelease];
 | 
						|
        # return result;
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (JavaScript):
 | 
						|
        # // ...
 | 
						|
        # var protoToCssColor = function(rgb_color) `
 | 
						|
        # var redFrac = rgb_color.red || 0.0;
 | 
						|
        # var greenFrac = rgb_color.green || 0.0;
 | 
						|
        # var blueFrac = rgb_color.blue || 0.0;
 | 
						|
        # var red = Math.floor(redFrac * 255);
 | 
						|
        # var green = Math.floor(greenFrac * 255);
 | 
						|
        # var blue = Math.floor(blueFrac * 255);
 | 
						|
        # if (!('alpha' in rgb_color)) `
 | 
						|
        # return rgbToCssColor_(red, green, blue);
 | 
						|
        # `
 | 
						|
        # var alphaFrac = rgb_color.alpha.value || 0.0;
 | 
						|
        # var rgbParams = [red, green, blue].join(',');
 | 
						|
        # return ['rgba(', rgbParams, ',', alphaFrac, ')'].join('');
 | 
						|
        # `;
 | 
						|
        # var rgbToCssColor_ = function(red, green, blue) `
 | 
						|
        # var rgbNumber = new Number((red << 16) | (green << 8) | blue);
 | 
						|
        # var hexString = rgbNumber.toString(16);
 | 
						|
        # var missingZeros = 6 - hexString.length;
 | 
						|
        # var resultBuilder = ['#'];
 | 
						|
        # for (var i = 0; i < missingZeros; i++) `
 | 
						|
        # resultBuilder.push('0');
 | 
						|
        # `
 | 
						|
        # resultBuilder.push(hexString);
 | 
						|
        # return resultBuilder.join('');
 | 
						|
        # `;
 | 
						|
        # // ...
 | 
						|
        # Corresponds to the JSON property `headerColor`
 | 
						|
        # @return [Google::Apis::SheetsV4::Color]
 | 
						|
        attr_accessor :header_color
 | 
						|
      
 | 
						|
        # Represents a color in the RGBA color space. This representation is designed
 | 
						|
        # for simplicity of conversion to/from color representations in various
 | 
						|
        # languages over compactness; for example, the fields of this representation
 | 
						|
        # can be trivially provided to the constructor of "java.awt.Color" in Java; it
 | 
						|
        # can also be trivially provided to UIColor's "+colorWithRed:green:blue:alpha"
 | 
						|
        # method in iOS; and, with just a little work, it can be easily formatted into
 | 
						|
        # a CSS "rgba()" string in JavaScript, as well. Here are some examples:
 | 
						|
        # Example (Java):
 | 
						|
        # import com.google.type.Color;
 | 
						|
        # // ...
 | 
						|
        # public static java.awt.Color fromProto(Color protocolor) `
 | 
						|
        # float alpha = protocolor.hasAlpha()
 | 
						|
        # ? protocolor.getAlpha().getValue()
 | 
						|
        # : 1.0;
 | 
						|
        # return new java.awt.Color(
 | 
						|
        # protocolor.getRed(),
 | 
						|
        # protocolor.getGreen(),
 | 
						|
        # protocolor.getBlue(),
 | 
						|
        # alpha);
 | 
						|
        # `
 | 
						|
        # public static Color toProto(java.awt.Color color) `
 | 
						|
        # float red = (float) color.getRed();
 | 
						|
        # float green = (float) color.getGreen();
 | 
						|
        # float blue = (float) color.getBlue();
 | 
						|
        # float denominator = 255.0;
 | 
						|
        # Color.Builder resultBuilder =
 | 
						|
        # Color
 | 
						|
        # .newBuilder()
 | 
						|
        # .setRed(red / denominator)
 | 
						|
        # .setGreen(green / denominator)
 | 
						|
        # .setBlue(blue / denominator);
 | 
						|
        # int alpha = color.getAlpha();
 | 
						|
        # if (alpha != 255) `
 | 
						|
        # result.setAlpha(
 | 
						|
        # FloatValue
 | 
						|
        # .newBuilder()
 | 
						|
        # .setValue(((float) alpha) / denominator)
 | 
						|
        # .build());
 | 
						|
        # `
 | 
						|
        # return resultBuilder.build();
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (iOS / Obj-C):
 | 
						|
        # // ...
 | 
						|
        # static UIColor* fromProto(Color* protocolor) `
 | 
						|
        # float red = [protocolor red];
 | 
						|
        # float green = [protocolor green];
 | 
						|
        # float blue = [protocolor blue];
 | 
						|
        # FloatValue* alpha_wrapper = [protocolor alpha];
 | 
						|
        # float alpha = 1.0;
 | 
						|
        # if (alpha_wrapper != nil) `
 | 
						|
        # alpha = [alpha_wrapper value];
 | 
						|
        # `
 | 
						|
        # return [UIColor colorWithRed:red green:green blue:blue alpha:alpha];
 | 
						|
        # `
 | 
						|
        # static Color* toProto(UIColor* color) `
 | 
						|
        # CGFloat red, green, blue, alpha;
 | 
						|
        # if (![color getRed:&red green:&green blue:&blue alpha:&alpha]) `
 | 
						|
        # return nil;
 | 
						|
        # `
 | 
						|
        # Color* result = [Color alloc] init];
 | 
						|
        # [result setRed:red];
 | 
						|
        # [result setGreen:green];
 | 
						|
        # [result setBlue:blue];
 | 
						|
        # if (alpha <= 0.9999) `
 | 
						|
        # [result setAlpha:floatWrapperWithValue(alpha)];
 | 
						|
        # `
 | 
						|
        # [result autorelease];
 | 
						|
        # return result;
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (JavaScript):
 | 
						|
        # // ...
 | 
						|
        # var protoToCssColor = function(rgb_color) `
 | 
						|
        # var redFrac = rgb_color.red || 0.0;
 | 
						|
        # var greenFrac = rgb_color.green || 0.0;
 | 
						|
        # var blueFrac = rgb_color.blue || 0.0;
 | 
						|
        # var red = Math.floor(redFrac * 255);
 | 
						|
        # var green = Math.floor(greenFrac * 255);
 | 
						|
        # var blue = Math.floor(blueFrac * 255);
 | 
						|
        # if (!('alpha' in rgb_color)) `
 | 
						|
        # return rgbToCssColor_(red, green, blue);
 | 
						|
        # `
 | 
						|
        # var alphaFrac = rgb_color.alpha.value || 0.0;
 | 
						|
        # var rgbParams = [red, green, blue].join(',');
 | 
						|
        # return ['rgba(', rgbParams, ',', alphaFrac, ')'].join('');
 | 
						|
        # `;
 | 
						|
        # var rgbToCssColor_ = function(red, green, blue) `
 | 
						|
        # var rgbNumber = new Number((red << 16) | (green << 8) | blue);
 | 
						|
        # var hexString = rgbNumber.toString(16);
 | 
						|
        # var missingZeros = 6 - hexString.length;
 | 
						|
        # var resultBuilder = ['#'];
 | 
						|
        # for (var i = 0; i < missingZeros; i++) `
 | 
						|
        # resultBuilder.push('0');
 | 
						|
        # `
 | 
						|
        # resultBuilder.push(hexString);
 | 
						|
        # return resultBuilder.join('');
 | 
						|
        # `;
 | 
						|
        # // ...
 | 
						|
        # Corresponds to the JSON property `secondBandColor`
 | 
						|
        # @return [Google::Apis::SheetsV4::Color]
 | 
						|
        attr_accessor :second_band_color
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @first_band_color = args[:first_band_color] if args.key?(:first_band_color)
 | 
						|
          @footer_color = args[:footer_color] if args.key?(:footer_color)
 | 
						|
          @header_color = args[:header_color] if args.key?(:header_color)
 | 
						|
          @second_band_color = args[:second_band_color] if args.key?(:second_band_color)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # An axis of the chart.
 | 
						|
      # A chart may not have more than one axis per
 | 
						|
      # axis position.
 | 
						|
      class BasicChartAxis
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The format of a run of text in a cell.
 | 
						|
        # Absent values indicate that the field isn't specified.
 | 
						|
        # Corresponds to the JSON property `format`
 | 
						|
        # @return [Google::Apis::SheetsV4::TextFormat]
 | 
						|
        attr_accessor :format
 | 
						|
      
 | 
						|
        # The position of this axis.
 | 
						|
        # Corresponds to the JSON property `position`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :position
 | 
						|
      
 | 
						|
        # The title of this axis. If set, this overrides any title inferred
 | 
						|
        # from headers of the data.
 | 
						|
        # Corresponds to the JSON property `title`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :title
 | 
						|
      
 | 
						|
        # Position settings for text.
 | 
						|
        # Corresponds to the JSON property `titleTextPosition`
 | 
						|
        # @return [Google::Apis::SheetsV4::TextPosition]
 | 
						|
        attr_accessor :title_text_position
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @format = args[:format] if args.key?(:format)
 | 
						|
          @position = args[:position] if args.key?(:position)
 | 
						|
          @title = args[:title] if args.key?(:title)
 | 
						|
          @title_text_position = args[:title_text_position] if args.key?(:title_text_position)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The domain of a chart.
 | 
						|
      # For example, if charting stock prices over time, this would be the date.
 | 
						|
      class BasicChartDomain
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The data included in a domain or series.
 | 
						|
        # Corresponds to the JSON property `domain`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartData]
 | 
						|
        attr_accessor :domain
 | 
						|
      
 | 
						|
        # True to reverse the order of the domain values (horizontal axis).
 | 
						|
        # Corresponds to the JSON property `reversed`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :reversed
 | 
						|
        alias_method :reversed?, :reversed
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @domain = args[:domain] if args.key?(:domain)
 | 
						|
          @reversed = args[:reversed] if args.key?(:reversed)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A single series of data in a chart.
 | 
						|
      # For example, if charting stock prices over time, multiple series may exist,
 | 
						|
      # one for the "Open Price", "High Price", "Low Price" and "Close Price".
 | 
						|
      class BasicChartSeries
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Properties that describe the style of a line.
 | 
						|
        # Corresponds to the JSON property `lineStyle`
 | 
						|
        # @return [Google::Apis::SheetsV4::LineStyle]
 | 
						|
        attr_accessor :line_style
 | 
						|
      
 | 
						|
        # The data included in a domain or series.
 | 
						|
        # Corresponds to the JSON property `series`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartData]
 | 
						|
        attr_accessor :series
 | 
						|
      
 | 
						|
        # The minor axis that will specify the range of values for this series.
 | 
						|
        # For example, if charting stocks over time, the "Volume" series
 | 
						|
        # may want to be pinned to the right with the prices pinned to the left,
 | 
						|
        # because the scale of trading volume is different than the scale of
 | 
						|
        # prices.
 | 
						|
        # It is an error to specify an axis that isn't a valid minor axis
 | 
						|
        # for the chart's type.
 | 
						|
        # Corresponds to the JSON property `targetAxis`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :target_axis
 | 
						|
      
 | 
						|
        # The type of this series. Valid only if the
 | 
						|
        # chartType is
 | 
						|
        # COMBO.
 | 
						|
        # Different types will change the way the series is visualized.
 | 
						|
        # Only LINE, AREA,
 | 
						|
        # and COLUMN are supported.
 | 
						|
        # Corresponds to the JSON property `type`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :type
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @line_style = args[:line_style] if args.key?(:line_style)
 | 
						|
          @series = args[:series] if args.key?(:series)
 | 
						|
          @target_axis = args[:target_axis] if args.key?(:target_axis)
 | 
						|
          @type = args[:type] if args.key?(:type)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The specification for a basic chart.  See BasicChartType for the list
 | 
						|
      # of charts this supports.
 | 
						|
      class BasicChartSpec
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The axis on the chart.
 | 
						|
        # Corresponds to the JSON property `axis`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::BasicChartAxis>]
 | 
						|
        attr_accessor :axis
 | 
						|
      
 | 
						|
        # The type of the chart.
 | 
						|
        # Corresponds to the JSON property `chartType`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :chart_type
 | 
						|
      
 | 
						|
        # The behavior of tooltips and data highlighting when hovering on data and
 | 
						|
        # chart area.
 | 
						|
        # Corresponds to the JSON property `compareMode`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :compare_mode
 | 
						|
      
 | 
						|
        # The domain of data this is charting.
 | 
						|
        # Only a single domain is supported.
 | 
						|
        # Corresponds to the JSON property `domains`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::BasicChartDomain>]
 | 
						|
        attr_accessor :domains
 | 
						|
      
 | 
						|
        # The number of rows or columns in the data that are "headers".
 | 
						|
        # If not set, Google Sheets will guess how many rows are headers based
 | 
						|
        # on the data.
 | 
						|
        # (Note that BasicChartAxis.title may override the axis title
 | 
						|
        # inferred from the header values.)
 | 
						|
        # Corresponds to the JSON property `headerCount`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :header_count
 | 
						|
      
 | 
						|
        # If some values in a series are missing, gaps may appear in the chart (e.g,
 | 
						|
        # segments of lines in a line chart will be missing).  To eliminate these
 | 
						|
        # gaps set this to true.
 | 
						|
        # Applies to Line, Area, and Combo charts.
 | 
						|
        # Corresponds to the JSON property `interpolateNulls`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :interpolate_nulls
 | 
						|
        alias_method :interpolate_nulls?, :interpolate_nulls
 | 
						|
      
 | 
						|
        # The position of the chart legend.
 | 
						|
        # Corresponds to the JSON property `legendPosition`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :legend_position
 | 
						|
      
 | 
						|
        # Gets whether all lines should be rendered smooth or straight by default.
 | 
						|
        # Applies to Line charts.
 | 
						|
        # Corresponds to the JSON property `lineSmoothing`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :line_smoothing
 | 
						|
        alias_method :line_smoothing?, :line_smoothing
 | 
						|
      
 | 
						|
        # The data this chart is visualizing.
 | 
						|
        # Corresponds to the JSON property `series`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::BasicChartSeries>]
 | 
						|
        attr_accessor :series
 | 
						|
      
 | 
						|
        # The stacked type for charts that support vertical stacking.
 | 
						|
        # Applies to Area, Bar, Column, and Stepped Area charts.
 | 
						|
        # Corresponds to the JSON property `stackedType`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :stacked_type
 | 
						|
      
 | 
						|
        # True to make the chart 3D.
 | 
						|
        # Applies to Bar and Column charts.
 | 
						|
        # Corresponds to the JSON property `threeDimensional`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :three_dimensional
 | 
						|
        alias_method :three_dimensional?, :three_dimensional
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @axis = args[:axis] if args.key?(:axis)
 | 
						|
          @chart_type = args[:chart_type] if args.key?(:chart_type)
 | 
						|
          @compare_mode = args[:compare_mode] if args.key?(:compare_mode)
 | 
						|
          @domains = args[:domains] if args.key?(:domains)
 | 
						|
          @header_count = args[:header_count] if args.key?(:header_count)
 | 
						|
          @interpolate_nulls = args[:interpolate_nulls] if args.key?(:interpolate_nulls)
 | 
						|
          @legend_position = args[:legend_position] if args.key?(:legend_position)
 | 
						|
          @line_smoothing = args[:line_smoothing] if args.key?(:line_smoothing)
 | 
						|
          @series = args[:series] if args.key?(:series)
 | 
						|
          @stacked_type = args[:stacked_type] if args.key?(:stacked_type)
 | 
						|
          @three_dimensional = args[:three_dimensional] if args.key?(:three_dimensional)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The default filter associated with a sheet.
 | 
						|
      class BasicFilter
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The criteria for showing/hiding values per column.
 | 
						|
        # The map's key is the column index, and the value is the criteria for
 | 
						|
        # that column.
 | 
						|
        # Corresponds to the JSON property `criteria`
 | 
						|
        # @return [Hash<String,Google::Apis::SheetsV4::FilterCriteria>]
 | 
						|
        attr_accessor :criteria
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        # The sort order per column. Later specifications are used when values
 | 
						|
        # are equal in the earlier specifications.
 | 
						|
        # Corresponds to the JSON property `sortSpecs`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::SortSpec>]
 | 
						|
        attr_accessor :sort_specs
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @criteria = args[:criteria] if args.key?(:criteria)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
          @sort_specs = args[:sort_specs] if args.key?(:sort_specs)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The request for clearing more than one range selected by a
 | 
						|
      # DataFilter in a spreadsheet.
 | 
						|
      class BatchClearValuesByDataFilterRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The DataFilters used to determine which ranges to clear.
 | 
						|
        # Corresponds to the JSON property `dataFilters`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::DataFilter>]
 | 
						|
        attr_accessor :data_filters
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data_filters = args[:data_filters] if args.key?(:data_filters)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The response when clearing a range of values selected with
 | 
						|
      # DataFilters in a spreadsheet.
 | 
						|
      class BatchClearValuesByDataFilterResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The ranges that were cleared, in A1 notation.
 | 
						|
        # (If the requests were for an unbounded range or a ranger larger
 | 
						|
        # than the bounds of the sheet, this will be the actual ranges
 | 
						|
        # that were cleared, bounded to the sheet's limits.)
 | 
						|
        # Corresponds to the JSON property `clearedRanges`
 | 
						|
        # @return [Array<String>]
 | 
						|
        attr_accessor :cleared_ranges
 | 
						|
      
 | 
						|
        # The spreadsheet the updates were applied to.
 | 
						|
        # Corresponds to the JSON property `spreadsheetId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :spreadsheet_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @cleared_ranges = args[:cleared_ranges] if args.key?(:cleared_ranges)
 | 
						|
          @spreadsheet_id = args[:spreadsheet_id] if args.key?(:spreadsheet_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The request for clearing more than one range of values in a spreadsheet.
 | 
						|
      class BatchClearValuesRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The ranges to clear, in A1 notation.
 | 
						|
        # Corresponds to the JSON property `ranges`
 | 
						|
        # @return [Array<String>]
 | 
						|
        attr_accessor :ranges
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @ranges = args[:ranges] if args.key?(:ranges)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The response when clearing a range of values in a spreadsheet.
 | 
						|
      class BatchClearValuesResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The ranges that were cleared, in A1 notation.
 | 
						|
        # (If the requests were for an unbounded range or a ranger larger
 | 
						|
        # than the bounds of the sheet, this will be the actual ranges
 | 
						|
        # that were cleared, bounded to the sheet's limits.)
 | 
						|
        # Corresponds to the JSON property `clearedRanges`
 | 
						|
        # @return [Array<String>]
 | 
						|
        attr_accessor :cleared_ranges
 | 
						|
      
 | 
						|
        # The spreadsheet the updates were applied to.
 | 
						|
        # Corresponds to the JSON property `spreadsheetId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :spreadsheet_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @cleared_ranges = args[:cleared_ranges] if args.key?(:cleared_ranges)
 | 
						|
          @spreadsheet_id = args[:spreadsheet_id] if args.key?(:spreadsheet_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The request for retrieving a range of values in a spreadsheet selected by a
 | 
						|
      # set of DataFilters.
 | 
						|
      class BatchGetValuesByDataFilterRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The data filters used to match the ranges of values to retrieve.  Ranges
 | 
						|
        # that match any of the specified data filters will be included in the
 | 
						|
        # response.
 | 
						|
        # Corresponds to the JSON property `dataFilters`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::DataFilter>]
 | 
						|
        attr_accessor :data_filters
 | 
						|
      
 | 
						|
        # How dates, times, and durations should be represented in the output.
 | 
						|
        # This is ignored if value_render_option is
 | 
						|
        # FORMATTED_VALUE.
 | 
						|
        # The default dateTime render option is [DateTimeRenderOption.SERIAL_NUMBER].
 | 
						|
        # Corresponds to the JSON property `dateTimeRenderOption`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :date_time_render_option
 | 
						|
      
 | 
						|
        # The major dimension that results should use.
 | 
						|
        # For example, if the spreadsheet data is: `A1=1,B1=2,A2=3,B2=4`,
 | 
						|
        # then a request that selects that range and sets `majorDimension=ROWS` will
 | 
						|
        # return `[[1,2],[3,4]]`,
 | 
						|
        # whereas a request that sets `majorDimension=COLUMNS` will return
 | 
						|
        # `[[1,3],[2,4]]`.
 | 
						|
        # Corresponds to the JSON property `majorDimension`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :major_dimension
 | 
						|
      
 | 
						|
        # How values should be represented in the output.
 | 
						|
        # The default render option is ValueRenderOption.FORMATTED_VALUE.
 | 
						|
        # Corresponds to the JSON property `valueRenderOption`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :value_render_option
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data_filters = args[:data_filters] if args.key?(:data_filters)
 | 
						|
          @date_time_render_option = args[:date_time_render_option] if args.key?(:date_time_render_option)
 | 
						|
          @major_dimension = args[:major_dimension] if args.key?(:major_dimension)
 | 
						|
          @value_render_option = args[:value_render_option] if args.key?(:value_render_option)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The response when retrieving more than one range of values in a spreadsheet
 | 
						|
      # selected by DataFilters.
 | 
						|
      class BatchGetValuesByDataFilterResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The ID of the spreadsheet the data was retrieved from.
 | 
						|
        # Corresponds to the JSON property `spreadsheetId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :spreadsheet_id
 | 
						|
      
 | 
						|
        # The requested values with the list of data filters that matched them.
 | 
						|
        # Corresponds to the JSON property `valueRanges`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::MatchedValueRange>]
 | 
						|
        attr_accessor :value_ranges
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @spreadsheet_id = args[:spreadsheet_id] if args.key?(:spreadsheet_id)
 | 
						|
          @value_ranges = args[:value_ranges] if args.key?(:value_ranges)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The response when retrieving more than one range of values in a spreadsheet.
 | 
						|
      class BatchGetValuesResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The ID of the spreadsheet the data was retrieved from.
 | 
						|
        # Corresponds to the JSON property `spreadsheetId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :spreadsheet_id
 | 
						|
      
 | 
						|
        # The requested values. The order of the ValueRanges is the same as the
 | 
						|
        # order of the requested ranges.
 | 
						|
        # Corresponds to the JSON property `valueRanges`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::ValueRange>]
 | 
						|
        attr_accessor :value_ranges
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @spreadsheet_id = args[:spreadsheet_id] if args.key?(:spreadsheet_id)
 | 
						|
          @value_ranges = args[:value_ranges] if args.key?(:value_ranges)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The request for updating any aspect of a spreadsheet.
 | 
						|
      class BatchUpdateSpreadsheetRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Determines if the update response should include the spreadsheet
 | 
						|
        # resource.
 | 
						|
        # Corresponds to the JSON property `includeSpreadsheetInResponse`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :include_spreadsheet_in_response
 | 
						|
        alias_method :include_spreadsheet_in_response?, :include_spreadsheet_in_response
 | 
						|
      
 | 
						|
        # A list of updates to apply to the spreadsheet.
 | 
						|
        # Requests will be applied in the order they are specified.
 | 
						|
        # If any request is not valid, no requests will be applied.
 | 
						|
        # Corresponds to the JSON property `requests`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::Request>]
 | 
						|
        attr_accessor :requests
 | 
						|
      
 | 
						|
        # True if grid data should be returned. Meaningful only if
 | 
						|
        # if include_spreadsheet_response is 'true'.
 | 
						|
        # This parameter is ignored if a field mask was set in the request.
 | 
						|
        # Corresponds to the JSON property `responseIncludeGridData`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :response_include_grid_data
 | 
						|
        alias_method :response_include_grid_data?, :response_include_grid_data
 | 
						|
      
 | 
						|
        # Limits the ranges included in the response spreadsheet.
 | 
						|
        # Meaningful only if include_spreadsheet_response is 'true'.
 | 
						|
        # Corresponds to the JSON property `responseRanges`
 | 
						|
        # @return [Array<String>]
 | 
						|
        attr_accessor :response_ranges
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @include_spreadsheet_in_response = args[:include_spreadsheet_in_response] if args.key?(:include_spreadsheet_in_response)
 | 
						|
          @requests = args[:requests] if args.key?(:requests)
 | 
						|
          @response_include_grid_data = args[:response_include_grid_data] if args.key?(:response_include_grid_data)
 | 
						|
          @response_ranges = args[:response_ranges] if args.key?(:response_ranges)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The reply for batch updating a spreadsheet.
 | 
						|
      class BatchUpdateSpreadsheetResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The reply of the updates.  This maps 1:1 with the updates, although
 | 
						|
        # replies to some requests may be empty.
 | 
						|
        # Corresponds to the JSON property `replies`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::Response>]
 | 
						|
        attr_accessor :replies
 | 
						|
      
 | 
						|
        # The spreadsheet the updates were applied to.
 | 
						|
        # Corresponds to the JSON property `spreadsheetId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :spreadsheet_id
 | 
						|
      
 | 
						|
        # Resource that represents a spreadsheet.
 | 
						|
        # Corresponds to the JSON property `updatedSpreadsheet`
 | 
						|
        # @return [Google::Apis::SheetsV4::Spreadsheet]
 | 
						|
        attr_accessor :updated_spreadsheet
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @replies = args[:replies] if args.key?(:replies)
 | 
						|
          @spreadsheet_id = args[:spreadsheet_id] if args.key?(:spreadsheet_id)
 | 
						|
          @updated_spreadsheet = args[:updated_spreadsheet] if args.key?(:updated_spreadsheet)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The request for updating more than one range of values in a spreadsheet.
 | 
						|
      class BatchUpdateValuesByDataFilterRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The new values to apply to the spreadsheet.  If more than one range is
 | 
						|
        # matched by the specified DataFilter the specified values will be
 | 
						|
        # applied to all of those ranges.
 | 
						|
        # Corresponds to the JSON property `data`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::DataFilterValueRange>]
 | 
						|
        attr_accessor :data
 | 
						|
      
 | 
						|
        # Determines if the update response should include the values
 | 
						|
        # of the cells that were updated. By default, responses
 | 
						|
        # do not include the updated values. The `updatedData` field within
 | 
						|
        # each of the BatchUpdateValuesResponse.responses will contain
 | 
						|
        # the updated values. If the range to write was larger than than the range
 | 
						|
        # actually written, the response will include all values in the requested
 | 
						|
        # range (excluding trailing empty rows and columns).
 | 
						|
        # Corresponds to the JSON property `includeValuesInResponse`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :include_values_in_response
 | 
						|
        alias_method :include_values_in_response?, :include_values_in_response
 | 
						|
      
 | 
						|
        # Determines how dates, times, and durations in the response should be
 | 
						|
        # rendered. This is ignored if response_value_render_option is
 | 
						|
        # FORMATTED_VALUE.
 | 
						|
        # The default dateTime render option is
 | 
						|
        # DateTimeRenderOption.SERIAL_NUMBER.
 | 
						|
        # Corresponds to the JSON property `responseDateTimeRenderOption`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :response_date_time_render_option
 | 
						|
      
 | 
						|
        # Determines how values in the response should be rendered.
 | 
						|
        # The default render option is ValueRenderOption.FORMATTED_VALUE.
 | 
						|
        # Corresponds to the JSON property `responseValueRenderOption`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :response_value_render_option
 | 
						|
      
 | 
						|
        # How the input data should be interpreted.
 | 
						|
        # Corresponds to the JSON property `valueInputOption`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :value_input_option
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data = args[:data] if args.key?(:data)
 | 
						|
          @include_values_in_response = args[:include_values_in_response] if args.key?(:include_values_in_response)
 | 
						|
          @response_date_time_render_option = args[:response_date_time_render_option] if args.key?(:response_date_time_render_option)
 | 
						|
          @response_value_render_option = args[:response_value_render_option] if args.key?(:response_value_render_option)
 | 
						|
          @value_input_option = args[:value_input_option] if args.key?(:value_input_option)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The response when updating a range of values in a spreadsheet.
 | 
						|
      class BatchUpdateValuesByDataFilterResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The response for each range updated.
 | 
						|
        # Corresponds to the JSON property `responses`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::UpdateValuesByDataFilterResponse>]
 | 
						|
        attr_accessor :responses
 | 
						|
      
 | 
						|
        # The spreadsheet the updates were applied to.
 | 
						|
        # Corresponds to the JSON property `spreadsheetId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :spreadsheet_id
 | 
						|
      
 | 
						|
        # The total number of cells updated.
 | 
						|
        # Corresponds to the JSON property `totalUpdatedCells`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :total_updated_cells
 | 
						|
      
 | 
						|
        # The total number of columns where at least one cell in the column was
 | 
						|
        # updated.
 | 
						|
        # Corresponds to the JSON property `totalUpdatedColumns`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :total_updated_columns
 | 
						|
      
 | 
						|
        # The total number of rows where at least one cell in the row was updated.
 | 
						|
        # Corresponds to the JSON property `totalUpdatedRows`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :total_updated_rows
 | 
						|
      
 | 
						|
        # The total number of sheets where at least one cell in the sheet was
 | 
						|
        # updated.
 | 
						|
        # Corresponds to the JSON property `totalUpdatedSheets`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :total_updated_sheets
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @responses = args[:responses] if args.key?(:responses)
 | 
						|
          @spreadsheet_id = args[:spreadsheet_id] if args.key?(:spreadsheet_id)
 | 
						|
          @total_updated_cells = args[:total_updated_cells] if args.key?(:total_updated_cells)
 | 
						|
          @total_updated_columns = args[:total_updated_columns] if args.key?(:total_updated_columns)
 | 
						|
          @total_updated_rows = args[:total_updated_rows] if args.key?(:total_updated_rows)
 | 
						|
          @total_updated_sheets = args[:total_updated_sheets] if args.key?(:total_updated_sheets)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The request for updating more than one range of values in a spreadsheet.
 | 
						|
      class BatchUpdateValuesRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The new values to apply to the spreadsheet.
 | 
						|
        # Corresponds to the JSON property `data`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::ValueRange>]
 | 
						|
        attr_accessor :data
 | 
						|
      
 | 
						|
        # Determines if the update response should include the values
 | 
						|
        # of the cells that were updated. By default, responses
 | 
						|
        # do not include the updated values. The `updatedData` field within
 | 
						|
        # each of the BatchUpdateValuesResponse.responses will contain
 | 
						|
        # the updated values. If the range to write was larger than than the range
 | 
						|
        # actually written, the response will include all values in the requested
 | 
						|
        # range (excluding trailing empty rows and columns).
 | 
						|
        # Corresponds to the JSON property `includeValuesInResponse`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :include_values_in_response
 | 
						|
        alias_method :include_values_in_response?, :include_values_in_response
 | 
						|
      
 | 
						|
        # Determines how dates, times, and durations in the response should be
 | 
						|
        # rendered. This is ignored if response_value_render_option is
 | 
						|
        # FORMATTED_VALUE.
 | 
						|
        # The default dateTime render option is
 | 
						|
        # DateTimeRenderOption.SERIAL_NUMBER.
 | 
						|
        # Corresponds to the JSON property `responseDateTimeRenderOption`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :response_date_time_render_option
 | 
						|
      
 | 
						|
        # Determines how values in the response should be rendered.
 | 
						|
        # The default render option is ValueRenderOption.FORMATTED_VALUE.
 | 
						|
        # Corresponds to the JSON property `responseValueRenderOption`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :response_value_render_option
 | 
						|
      
 | 
						|
        # How the input data should be interpreted.
 | 
						|
        # Corresponds to the JSON property `valueInputOption`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :value_input_option
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data = args[:data] if args.key?(:data)
 | 
						|
          @include_values_in_response = args[:include_values_in_response] if args.key?(:include_values_in_response)
 | 
						|
          @response_date_time_render_option = args[:response_date_time_render_option] if args.key?(:response_date_time_render_option)
 | 
						|
          @response_value_render_option = args[:response_value_render_option] if args.key?(:response_value_render_option)
 | 
						|
          @value_input_option = args[:value_input_option] if args.key?(:value_input_option)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The response when updating a range of values in a spreadsheet.
 | 
						|
      class BatchUpdateValuesResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # One UpdateValuesResponse per requested range, in the same order as
 | 
						|
        # the requests appeared.
 | 
						|
        # Corresponds to the JSON property `responses`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::UpdateValuesResponse>]
 | 
						|
        attr_accessor :responses
 | 
						|
      
 | 
						|
        # The spreadsheet the updates were applied to.
 | 
						|
        # Corresponds to the JSON property `spreadsheetId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :spreadsheet_id
 | 
						|
      
 | 
						|
        # The total number of cells updated.
 | 
						|
        # Corresponds to the JSON property `totalUpdatedCells`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :total_updated_cells
 | 
						|
      
 | 
						|
        # The total number of columns where at least one cell in the column was
 | 
						|
        # updated.
 | 
						|
        # Corresponds to the JSON property `totalUpdatedColumns`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :total_updated_columns
 | 
						|
      
 | 
						|
        # The total number of rows where at least one cell in the row was updated.
 | 
						|
        # Corresponds to the JSON property `totalUpdatedRows`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :total_updated_rows
 | 
						|
      
 | 
						|
        # The total number of sheets where at least one cell in the sheet was
 | 
						|
        # updated.
 | 
						|
        # Corresponds to the JSON property `totalUpdatedSheets`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :total_updated_sheets
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @responses = args[:responses] if args.key?(:responses)
 | 
						|
          @spreadsheet_id = args[:spreadsheet_id] if args.key?(:spreadsheet_id)
 | 
						|
          @total_updated_cells = args[:total_updated_cells] if args.key?(:total_updated_cells)
 | 
						|
          @total_updated_columns = args[:total_updated_columns] if args.key?(:total_updated_columns)
 | 
						|
          @total_updated_rows = args[:total_updated_rows] if args.key?(:total_updated_rows)
 | 
						|
          @total_updated_sheets = args[:total_updated_sheets] if args.key?(:total_updated_sheets)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A condition that can evaluate to true or false.
 | 
						|
      # BooleanConditions are used by conditional formatting,
 | 
						|
      # data validation, and the criteria in filters.
 | 
						|
      class BooleanCondition
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The type of condition.
 | 
						|
        # Corresponds to the JSON property `type`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :type
 | 
						|
      
 | 
						|
        # The values of the condition. The number of supported values depends
 | 
						|
        # on the condition type.  Some support zero values,
 | 
						|
        # others one or two values,
 | 
						|
        # and ConditionType.ONE_OF_LIST supports an arbitrary number of values.
 | 
						|
        # Corresponds to the JSON property `values`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::ConditionValue>]
 | 
						|
        attr_accessor :values
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @type = args[:type] if args.key?(:type)
 | 
						|
          @values = args[:values] if args.key?(:values)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A rule that may or may not match, depending on the condition.
 | 
						|
      class BooleanRule
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A condition that can evaluate to true or false.
 | 
						|
        # BooleanConditions are used by conditional formatting,
 | 
						|
        # data validation, and the criteria in filters.
 | 
						|
        # Corresponds to the JSON property `condition`
 | 
						|
        # @return [Google::Apis::SheetsV4::BooleanCondition]
 | 
						|
        attr_accessor :condition
 | 
						|
      
 | 
						|
        # The format of a cell.
 | 
						|
        # Corresponds to the JSON property `format`
 | 
						|
        # @return [Google::Apis::SheetsV4::CellFormat]
 | 
						|
        attr_accessor :format
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @condition = args[:condition] if args.key?(:condition)
 | 
						|
          @format = args[:format] if args.key?(:format)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A border along a cell.
 | 
						|
      class Border
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Represents a color in the RGBA color space. This representation is designed
 | 
						|
        # for simplicity of conversion to/from color representations in various
 | 
						|
        # languages over compactness; for example, the fields of this representation
 | 
						|
        # can be trivially provided to the constructor of "java.awt.Color" in Java; it
 | 
						|
        # can also be trivially provided to UIColor's "+colorWithRed:green:blue:alpha"
 | 
						|
        # method in iOS; and, with just a little work, it can be easily formatted into
 | 
						|
        # a CSS "rgba()" string in JavaScript, as well. Here are some examples:
 | 
						|
        # Example (Java):
 | 
						|
        # import com.google.type.Color;
 | 
						|
        # // ...
 | 
						|
        # public static java.awt.Color fromProto(Color protocolor) `
 | 
						|
        # float alpha = protocolor.hasAlpha()
 | 
						|
        # ? protocolor.getAlpha().getValue()
 | 
						|
        # : 1.0;
 | 
						|
        # return new java.awt.Color(
 | 
						|
        # protocolor.getRed(),
 | 
						|
        # protocolor.getGreen(),
 | 
						|
        # protocolor.getBlue(),
 | 
						|
        # alpha);
 | 
						|
        # `
 | 
						|
        # public static Color toProto(java.awt.Color color) `
 | 
						|
        # float red = (float) color.getRed();
 | 
						|
        # float green = (float) color.getGreen();
 | 
						|
        # float blue = (float) color.getBlue();
 | 
						|
        # float denominator = 255.0;
 | 
						|
        # Color.Builder resultBuilder =
 | 
						|
        # Color
 | 
						|
        # .newBuilder()
 | 
						|
        # .setRed(red / denominator)
 | 
						|
        # .setGreen(green / denominator)
 | 
						|
        # .setBlue(blue / denominator);
 | 
						|
        # int alpha = color.getAlpha();
 | 
						|
        # if (alpha != 255) `
 | 
						|
        # result.setAlpha(
 | 
						|
        # FloatValue
 | 
						|
        # .newBuilder()
 | 
						|
        # .setValue(((float) alpha) / denominator)
 | 
						|
        # .build());
 | 
						|
        # `
 | 
						|
        # return resultBuilder.build();
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (iOS / Obj-C):
 | 
						|
        # // ...
 | 
						|
        # static UIColor* fromProto(Color* protocolor) `
 | 
						|
        # float red = [protocolor red];
 | 
						|
        # float green = [protocolor green];
 | 
						|
        # float blue = [protocolor blue];
 | 
						|
        # FloatValue* alpha_wrapper = [protocolor alpha];
 | 
						|
        # float alpha = 1.0;
 | 
						|
        # if (alpha_wrapper != nil) `
 | 
						|
        # alpha = [alpha_wrapper value];
 | 
						|
        # `
 | 
						|
        # return [UIColor colorWithRed:red green:green blue:blue alpha:alpha];
 | 
						|
        # `
 | 
						|
        # static Color* toProto(UIColor* color) `
 | 
						|
        # CGFloat red, green, blue, alpha;
 | 
						|
        # if (![color getRed:&red green:&green blue:&blue alpha:&alpha]) `
 | 
						|
        # return nil;
 | 
						|
        # `
 | 
						|
        # Color* result = [Color alloc] init];
 | 
						|
        # [result setRed:red];
 | 
						|
        # [result setGreen:green];
 | 
						|
        # [result setBlue:blue];
 | 
						|
        # if (alpha <= 0.9999) `
 | 
						|
        # [result setAlpha:floatWrapperWithValue(alpha)];
 | 
						|
        # `
 | 
						|
        # [result autorelease];
 | 
						|
        # return result;
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (JavaScript):
 | 
						|
        # // ...
 | 
						|
        # var protoToCssColor = function(rgb_color) `
 | 
						|
        # var redFrac = rgb_color.red || 0.0;
 | 
						|
        # var greenFrac = rgb_color.green || 0.0;
 | 
						|
        # var blueFrac = rgb_color.blue || 0.0;
 | 
						|
        # var red = Math.floor(redFrac * 255);
 | 
						|
        # var green = Math.floor(greenFrac * 255);
 | 
						|
        # var blue = Math.floor(blueFrac * 255);
 | 
						|
        # if (!('alpha' in rgb_color)) `
 | 
						|
        # return rgbToCssColor_(red, green, blue);
 | 
						|
        # `
 | 
						|
        # var alphaFrac = rgb_color.alpha.value || 0.0;
 | 
						|
        # var rgbParams = [red, green, blue].join(',');
 | 
						|
        # return ['rgba(', rgbParams, ',', alphaFrac, ')'].join('');
 | 
						|
        # `;
 | 
						|
        # var rgbToCssColor_ = function(red, green, blue) `
 | 
						|
        # var rgbNumber = new Number((red << 16) | (green << 8) | blue);
 | 
						|
        # var hexString = rgbNumber.toString(16);
 | 
						|
        # var missingZeros = 6 - hexString.length;
 | 
						|
        # var resultBuilder = ['#'];
 | 
						|
        # for (var i = 0; i < missingZeros; i++) `
 | 
						|
        # resultBuilder.push('0');
 | 
						|
        # `
 | 
						|
        # resultBuilder.push(hexString);
 | 
						|
        # return resultBuilder.join('');
 | 
						|
        # `;
 | 
						|
        # // ...
 | 
						|
        # Corresponds to the JSON property `color`
 | 
						|
        # @return [Google::Apis::SheetsV4::Color]
 | 
						|
        attr_accessor :color
 | 
						|
      
 | 
						|
        # The style of the border.
 | 
						|
        # Corresponds to the JSON property `style`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :style
 | 
						|
      
 | 
						|
        # The width of the border, in pixels.
 | 
						|
        # Deprecated; the width is determined by the "style" field.
 | 
						|
        # Corresponds to the JSON property `width`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :width
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @color = args[:color] if args.key?(:color)
 | 
						|
          @style = args[:style] if args.key?(:style)
 | 
						|
          @width = args[:width] if args.key?(:width)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The borders of the cell.
 | 
						|
      class Borders
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A border along a cell.
 | 
						|
        # Corresponds to the JSON property `bottom`
 | 
						|
        # @return [Google::Apis::SheetsV4::Border]
 | 
						|
        attr_accessor :bottom
 | 
						|
      
 | 
						|
        # A border along a cell.
 | 
						|
        # Corresponds to the JSON property `left`
 | 
						|
        # @return [Google::Apis::SheetsV4::Border]
 | 
						|
        attr_accessor :left
 | 
						|
      
 | 
						|
        # A border along a cell.
 | 
						|
        # Corresponds to the JSON property `right`
 | 
						|
        # @return [Google::Apis::SheetsV4::Border]
 | 
						|
        attr_accessor :right
 | 
						|
      
 | 
						|
        # A border along a cell.
 | 
						|
        # Corresponds to the JSON property `top`
 | 
						|
        # @return [Google::Apis::SheetsV4::Border]
 | 
						|
        attr_accessor :top
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @bottom = args[:bottom] if args.key?(:bottom)
 | 
						|
          @left = args[:left] if args.key?(:left)
 | 
						|
          @right = args[:right] if args.key?(:right)
 | 
						|
          @top = args[:top] if args.key?(:top)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A <a href="/chart/interactive/docs/gallery/bubblechart">bubble chart</a>.
 | 
						|
      class BubbleChartSpec
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Represents a color in the RGBA color space. This representation is designed
 | 
						|
        # for simplicity of conversion to/from color representations in various
 | 
						|
        # languages over compactness; for example, the fields of this representation
 | 
						|
        # can be trivially provided to the constructor of "java.awt.Color" in Java; it
 | 
						|
        # can also be trivially provided to UIColor's "+colorWithRed:green:blue:alpha"
 | 
						|
        # method in iOS; and, with just a little work, it can be easily formatted into
 | 
						|
        # a CSS "rgba()" string in JavaScript, as well. Here are some examples:
 | 
						|
        # Example (Java):
 | 
						|
        # import com.google.type.Color;
 | 
						|
        # // ...
 | 
						|
        # public static java.awt.Color fromProto(Color protocolor) `
 | 
						|
        # float alpha = protocolor.hasAlpha()
 | 
						|
        # ? protocolor.getAlpha().getValue()
 | 
						|
        # : 1.0;
 | 
						|
        # return new java.awt.Color(
 | 
						|
        # protocolor.getRed(),
 | 
						|
        # protocolor.getGreen(),
 | 
						|
        # protocolor.getBlue(),
 | 
						|
        # alpha);
 | 
						|
        # `
 | 
						|
        # public static Color toProto(java.awt.Color color) `
 | 
						|
        # float red = (float) color.getRed();
 | 
						|
        # float green = (float) color.getGreen();
 | 
						|
        # float blue = (float) color.getBlue();
 | 
						|
        # float denominator = 255.0;
 | 
						|
        # Color.Builder resultBuilder =
 | 
						|
        # Color
 | 
						|
        # .newBuilder()
 | 
						|
        # .setRed(red / denominator)
 | 
						|
        # .setGreen(green / denominator)
 | 
						|
        # .setBlue(blue / denominator);
 | 
						|
        # int alpha = color.getAlpha();
 | 
						|
        # if (alpha != 255) `
 | 
						|
        # result.setAlpha(
 | 
						|
        # FloatValue
 | 
						|
        # .newBuilder()
 | 
						|
        # .setValue(((float) alpha) / denominator)
 | 
						|
        # .build());
 | 
						|
        # `
 | 
						|
        # return resultBuilder.build();
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (iOS / Obj-C):
 | 
						|
        # // ...
 | 
						|
        # static UIColor* fromProto(Color* protocolor) `
 | 
						|
        # float red = [protocolor red];
 | 
						|
        # float green = [protocolor green];
 | 
						|
        # float blue = [protocolor blue];
 | 
						|
        # FloatValue* alpha_wrapper = [protocolor alpha];
 | 
						|
        # float alpha = 1.0;
 | 
						|
        # if (alpha_wrapper != nil) `
 | 
						|
        # alpha = [alpha_wrapper value];
 | 
						|
        # `
 | 
						|
        # return [UIColor colorWithRed:red green:green blue:blue alpha:alpha];
 | 
						|
        # `
 | 
						|
        # static Color* toProto(UIColor* color) `
 | 
						|
        # CGFloat red, green, blue, alpha;
 | 
						|
        # if (![color getRed:&red green:&green blue:&blue alpha:&alpha]) `
 | 
						|
        # return nil;
 | 
						|
        # `
 | 
						|
        # Color* result = [Color alloc] init];
 | 
						|
        # [result setRed:red];
 | 
						|
        # [result setGreen:green];
 | 
						|
        # [result setBlue:blue];
 | 
						|
        # if (alpha <= 0.9999) `
 | 
						|
        # [result setAlpha:floatWrapperWithValue(alpha)];
 | 
						|
        # `
 | 
						|
        # [result autorelease];
 | 
						|
        # return result;
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (JavaScript):
 | 
						|
        # // ...
 | 
						|
        # var protoToCssColor = function(rgb_color) `
 | 
						|
        # var redFrac = rgb_color.red || 0.0;
 | 
						|
        # var greenFrac = rgb_color.green || 0.0;
 | 
						|
        # var blueFrac = rgb_color.blue || 0.0;
 | 
						|
        # var red = Math.floor(redFrac * 255);
 | 
						|
        # var green = Math.floor(greenFrac * 255);
 | 
						|
        # var blue = Math.floor(blueFrac * 255);
 | 
						|
        # if (!('alpha' in rgb_color)) `
 | 
						|
        # return rgbToCssColor_(red, green, blue);
 | 
						|
        # `
 | 
						|
        # var alphaFrac = rgb_color.alpha.value || 0.0;
 | 
						|
        # var rgbParams = [red, green, blue].join(',');
 | 
						|
        # return ['rgba(', rgbParams, ',', alphaFrac, ')'].join('');
 | 
						|
        # `;
 | 
						|
        # var rgbToCssColor_ = function(red, green, blue) `
 | 
						|
        # var rgbNumber = new Number((red << 16) | (green << 8) | blue);
 | 
						|
        # var hexString = rgbNumber.toString(16);
 | 
						|
        # var missingZeros = 6 - hexString.length;
 | 
						|
        # var resultBuilder = ['#'];
 | 
						|
        # for (var i = 0; i < missingZeros; i++) `
 | 
						|
        # resultBuilder.push('0');
 | 
						|
        # `
 | 
						|
        # resultBuilder.push(hexString);
 | 
						|
        # return resultBuilder.join('');
 | 
						|
        # `;
 | 
						|
        # // ...
 | 
						|
        # Corresponds to the JSON property `bubbleBorderColor`
 | 
						|
        # @return [Google::Apis::SheetsV4::Color]
 | 
						|
        attr_accessor :bubble_border_color
 | 
						|
      
 | 
						|
        # The data included in a domain or series.
 | 
						|
        # Corresponds to the JSON property `bubbleLabels`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartData]
 | 
						|
        attr_accessor :bubble_labels
 | 
						|
      
 | 
						|
        # The max radius size of the bubbles, in pixels.
 | 
						|
        # If specified, the field must be a positive value.
 | 
						|
        # Corresponds to the JSON property `bubbleMaxRadiusSize`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :bubble_max_radius_size
 | 
						|
      
 | 
						|
        # The minimum radius size of the bubbles, in pixels.
 | 
						|
        # If specific, the field must be a positive value.
 | 
						|
        # Corresponds to the JSON property `bubbleMinRadiusSize`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :bubble_min_radius_size
 | 
						|
      
 | 
						|
        # The opacity of the bubbles between 0 and 1.0.
 | 
						|
        # 0 is fully transparent and 1 is fully opaque.
 | 
						|
        # Corresponds to the JSON property `bubbleOpacity`
 | 
						|
        # @return [Float]
 | 
						|
        attr_accessor :bubble_opacity
 | 
						|
      
 | 
						|
        # The data included in a domain or series.
 | 
						|
        # Corresponds to the JSON property `bubbleSizes`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartData]
 | 
						|
        attr_accessor :bubble_sizes
 | 
						|
      
 | 
						|
        # The format of a run of text in a cell.
 | 
						|
        # Absent values indicate that the field isn't specified.
 | 
						|
        # Corresponds to the JSON property `bubbleTextStyle`
 | 
						|
        # @return [Google::Apis::SheetsV4::TextFormat]
 | 
						|
        attr_accessor :bubble_text_style
 | 
						|
      
 | 
						|
        # The data included in a domain or series.
 | 
						|
        # Corresponds to the JSON property `domain`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartData]
 | 
						|
        attr_accessor :domain
 | 
						|
      
 | 
						|
        # The data included in a domain or series.
 | 
						|
        # Corresponds to the JSON property `groupIds`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartData]
 | 
						|
        attr_accessor :group_ids
 | 
						|
      
 | 
						|
        # Where the legend of the chart should be drawn.
 | 
						|
        # Corresponds to the JSON property `legendPosition`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :legend_position
 | 
						|
      
 | 
						|
        # The data included in a domain or series.
 | 
						|
        # Corresponds to the JSON property `series`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartData]
 | 
						|
        attr_accessor :series
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @bubble_border_color = args[:bubble_border_color] if args.key?(:bubble_border_color)
 | 
						|
          @bubble_labels = args[:bubble_labels] if args.key?(:bubble_labels)
 | 
						|
          @bubble_max_radius_size = args[:bubble_max_radius_size] if args.key?(:bubble_max_radius_size)
 | 
						|
          @bubble_min_radius_size = args[:bubble_min_radius_size] if args.key?(:bubble_min_radius_size)
 | 
						|
          @bubble_opacity = args[:bubble_opacity] if args.key?(:bubble_opacity)
 | 
						|
          @bubble_sizes = args[:bubble_sizes] if args.key?(:bubble_sizes)
 | 
						|
          @bubble_text_style = args[:bubble_text_style] if args.key?(:bubble_text_style)
 | 
						|
          @domain = args[:domain] if args.key?(:domain)
 | 
						|
          @group_ids = args[:group_ids] if args.key?(:group_ids)
 | 
						|
          @legend_position = args[:legend_position] if args.key?(:legend_position)
 | 
						|
          @series = args[:series] if args.key?(:series)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A <a href="/chart/interactive/docs/gallery/candlestickchart">candlestick chart<
 | 
						|
      # /a>.
 | 
						|
      class CandlestickChartSpec
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The Candlestick chart data.
 | 
						|
        # Only one CandlestickData is supported.
 | 
						|
        # Corresponds to the JSON property `data`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::CandlestickData>]
 | 
						|
        attr_accessor :data
 | 
						|
      
 | 
						|
        # The domain of a CandlestickChart.
 | 
						|
        # Corresponds to the JSON property `domain`
 | 
						|
        # @return [Google::Apis::SheetsV4::CandlestickDomain]
 | 
						|
        attr_accessor :domain
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data = args[:data] if args.key?(:data)
 | 
						|
          @domain = args[:domain] if args.key?(:domain)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The Candlestick chart data, each containing the low, open, close, and high
 | 
						|
      # values for a series.
 | 
						|
      class CandlestickData
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The series of a CandlestickData.
 | 
						|
        # Corresponds to the JSON property `closeSeries`
 | 
						|
        # @return [Google::Apis::SheetsV4::CandlestickSeries]
 | 
						|
        attr_accessor :close_series
 | 
						|
      
 | 
						|
        # The series of a CandlestickData.
 | 
						|
        # Corresponds to the JSON property `highSeries`
 | 
						|
        # @return [Google::Apis::SheetsV4::CandlestickSeries]
 | 
						|
        attr_accessor :high_series
 | 
						|
      
 | 
						|
        # The series of a CandlestickData.
 | 
						|
        # Corresponds to the JSON property `lowSeries`
 | 
						|
        # @return [Google::Apis::SheetsV4::CandlestickSeries]
 | 
						|
        attr_accessor :low_series
 | 
						|
      
 | 
						|
        # The series of a CandlestickData.
 | 
						|
        # Corresponds to the JSON property `openSeries`
 | 
						|
        # @return [Google::Apis::SheetsV4::CandlestickSeries]
 | 
						|
        attr_accessor :open_series
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @close_series = args[:close_series] if args.key?(:close_series)
 | 
						|
          @high_series = args[:high_series] if args.key?(:high_series)
 | 
						|
          @low_series = args[:low_series] if args.key?(:low_series)
 | 
						|
          @open_series = args[:open_series] if args.key?(:open_series)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The domain of a CandlestickChart.
 | 
						|
      class CandlestickDomain
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The data included in a domain or series.
 | 
						|
        # Corresponds to the JSON property `data`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartData]
 | 
						|
        attr_accessor :data
 | 
						|
      
 | 
						|
        # True to reverse the order of the domain values (horizontal axis).
 | 
						|
        # Corresponds to the JSON property `reversed`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :reversed
 | 
						|
        alias_method :reversed?, :reversed
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data = args[:data] if args.key?(:data)
 | 
						|
          @reversed = args[:reversed] if args.key?(:reversed)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The series of a CandlestickData.
 | 
						|
      class CandlestickSeries
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The data included in a domain or series.
 | 
						|
        # Corresponds to the JSON property `data`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartData]
 | 
						|
        attr_accessor :data
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data = args[:data] if args.key?(:data)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Data about a specific cell.
 | 
						|
      class CellData
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A data validation rule.
 | 
						|
        # Corresponds to the JSON property `dataValidation`
 | 
						|
        # @return [Google::Apis::SheetsV4::DataValidationRule]
 | 
						|
        attr_accessor :data_validation
 | 
						|
      
 | 
						|
        # The format of a cell.
 | 
						|
        # Corresponds to the JSON property `effectiveFormat`
 | 
						|
        # @return [Google::Apis::SheetsV4::CellFormat]
 | 
						|
        attr_accessor :effective_format
 | 
						|
      
 | 
						|
        # The kinds of value that a cell in a spreadsheet can have.
 | 
						|
        # Corresponds to the JSON property `effectiveValue`
 | 
						|
        # @return [Google::Apis::SheetsV4::ExtendedValue]
 | 
						|
        attr_accessor :effective_value
 | 
						|
      
 | 
						|
        # The formatted value of the cell.
 | 
						|
        # This is the value as it's shown to the user.
 | 
						|
        # This field is read-only.
 | 
						|
        # Corresponds to the JSON property `formattedValue`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :formatted_value
 | 
						|
      
 | 
						|
        # A hyperlink this cell points to, if any.
 | 
						|
        # This field is read-only.  (To set it, use a `=HYPERLINK` formula
 | 
						|
        # in the userEnteredValue.formulaValue
 | 
						|
        # field.)
 | 
						|
        # Corresponds to the JSON property `hyperlink`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :hyperlink
 | 
						|
      
 | 
						|
        # Any note on the cell.
 | 
						|
        # Corresponds to the JSON property `note`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :note
 | 
						|
      
 | 
						|
        # A pivot table.
 | 
						|
        # Corresponds to the JSON property `pivotTable`
 | 
						|
        # @return [Google::Apis::SheetsV4::PivotTable]
 | 
						|
        attr_accessor :pivot_table
 | 
						|
      
 | 
						|
        # Runs of rich text applied to subsections of the cell.  Runs are only valid
 | 
						|
        # on user entered strings, not formulas, bools, or numbers.
 | 
						|
        # Runs start at specific indexes in the text and continue until the next
 | 
						|
        # run. Properties of a run will continue unless explicitly changed
 | 
						|
        # in a subsequent run (and properties of the first run will continue
 | 
						|
        # the properties of the cell unless explicitly changed).
 | 
						|
        # When writing, the new runs will overwrite any prior runs.  When writing a
 | 
						|
        # new user_entered_value, previous runs will be erased.
 | 
						|
        # Corresponds to the JSON property `textFormatRuns`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::TextFormatRun>]
 | 
						|
        attr_accessor :text_format_runs
 | 
						|
      
 | 
						|
        # The format of a cell.
 | 
						|
        # Corresponds to the JSON property `userEnteredFormat`
 | 
						|
        # @return [Google::Apis::SheetsV4::CellFormat]
 | 
						|
        attr_accessor :user_entered_format
 | 
						|
      
 | 
						|
        # The kinds of value that a cell in a spreadsheet can have.
 | 
						|
        # Corresponds to the JSON property `userEnteredValue`
 | 
						|
        # @return [Google::Apis::SheetsV4::ExtendedValue]
 | 
						|
        attr_accessor :user_entered_value
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data_validation = args[:data_validation] if args.key?(:data_validation)
 | 
						|
          @effective_format = args[:effective_format] if args.key?(:effective_format)
 | 
						|
          @effective_value = args[:effective_value] if args.key?(:effective_value)
 | 
						|
          @formatted_value = args[:formatted_value] if args.key?(:formatted_value)
 | 
						|
          @hyperlink = args[:hyperlink] if args.key?(:hyperlink)
 | 
						|
          @note = args[:note] if args.key?(:note)
 | 
						|
          @pivot_table = args[:pivot_table] if args.key?(:pivot_table)
 | 
						|
          @text_format_runs = args[:text_format_runs] if args.key?(:text_format_runs)
 | 
						|
          @user_entered_format = args[:user_entered_format] if args.key?(:user_entered_format)
 | 
						|
          @user_entered_value = args[:user_entered_value] if args.key?(:user_entered_value)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The format of a cell.
 | 
						|
      class CellFormat
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Represents a color in the RGBA color space. This representation is designed
 | 
						|
        # for simplicity of conversion to/from color representations in various
 | 
						|
        # languages over compactness; for example, the fields of this representation
 | 
						|
        # can be trivially provided to the constructor of "java.awt.Color" in Java; it
 | 
						|
        # can also be trivially provided to UIColor's "+colorWithRed:green:blue:alpha"
 | 
						|
        # method in iOS; and, with just a little work, it can be easily formatted into
 | 
						|
        # a CSS "rgba()" string in JavaScript, as well. Here are some examples:
 | 
						|
        # Example (Java):
 | 
						|
        # import com.google.type.Color;
 | 
						|
        # // ...
 | 
						|
        # public static java.awt.Color fromProto(Color protocolor) `
 | 
						|
        # float alpha = protocolor.hasAlpha()
 | 
						|
        # ? protocolor.getAlpha().getValue()
 | 
						|
        # : 1.0;
 | 
						|
        # return new java.awt.Color(
 | 
						|
        # protocolor.getRed(),
 | 
						|
        # protocolor.getGreen(),
 | 
						|
        # protocolor.getBlue(),
 | 
						|
        # alpha);
 | 
						|
        # `
 | 
						|
        # public static Color toProto(java.awt.Color color) `
 | 
						|
        # float red = (float) color.getRed();
 | 
						|
        # float green = (float) color.getGreen();
 | 
						|
        # float blue = (float) color.getBlue();
 | 
						|
        # float denominator = 255.0;
 | 
						|
        # Color.Builder resultBuilder =
 | 
						|
        # Color
 | 
						|
        # .newBuilder()
 | 
						|
        # .setRed(red / denominator)
 | 
						|
        # .setGreen(green / denominator)
 | 
						|
        # .setBlue(blue / denominator);
 | 
						|
        # int alpha = color.getAlpha();
 | 
						|
        # if (alpha != 255) `
 | 
						|
        # result.setAlpha(
 | 
						|
        # FloatValue
 | 
						|
        # .newBuilder()
 | 
						|
        # .setValue(((float) alpha) / denominator)
 | 
						|
        # .build());
 | 
						|
        # `
 | 
						|
        # return resultBuilder.build();
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (iOS / Obj-C):
 | 
						|
        # // ...
 | 
						|
        # static UIColor* fromProto(Color* protocolor) `
 | 
						|
        # float red = [protocolor red];
 | 
						|
        # float green = [protocolor green];
 | 
						|
        # float blue = [protocolor blue];
 | 
						|
        # FloatValue* alpha_wrapper = [protocolor alpha];
 | 
						|
        # float alpha = 1.0;
 | 
						|
        # if (alpha_wrapper != nil) `
 | 
						|
        # alpha = [alpha_wrapper value];
 | 
						|
        # `
 | 
						|
        # return [UIColor colorWithRed:red green:green blue:blue alpha:alpha];
 | 
						|
        # `
 | 
						|
        # static Color* toProto(UIColor* color) `
 | 
						|
        # CGFloat red, green, blue, alpha;
 | 
						|
        # if (![color getRed:&red green:&green blue:&blue alpha:&alpha]) `
 | 
						|
        # return nil;
 | 
						|
        # `
 | 
						|
        # Color* result = [Color alloc] init];
 | 
						|
        # [result setRed:red];
 | 
						|
        # [result setGreen:green];
 | 
						|
        # [result setBlue:blue];
 | 
						|
        # if (alpha <= 0.9999) `
 | 
						|
        # [result setAlpha:floatWrapperWithValue(alpha)];
 | 
						|
        # `
 | 
						|
        # [result autorelease];
 | 
						|
        # return result;
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (JavaScript):
 | 
						|
        # // ...
 | 
						|
        # var protoToCssColor = function(rgb_color) `
 | 
						|
        # var redFrac = rgb_color.red || 0.0;
 | 
						|
        # var greenFrac = rgb_color.green || 0.0;
 | 
						|
        # var blueFrac = rgb_color.blue || 0.0;
 | 
						|
        # var red = Math.floor(redFrac * 255);
 | 
						|
        # var green = Math.floor(greenFrac * 255);
 | 
						|
        # var blue = Math.floor(blueFrac * 255);
 | 
						|
        # if (!('alpha' in rgb_color)) `
 | 
						|
        # return rgbToCssColor_(red, green, blue);
 | 
						|
        # `
 | 
						|
        # var alphaFrac = rgb_color.alpha.value || 0.0;
 | 
						|
        # var rgbParams = [red, green, blue].join(',');
 | 
						|
        # return ['rgba(', rgbParams, ',', alphaFrac, ')'].join('');
 | 
						|
        # `;
 | 
						|
        # var rgbToCssColor_ = function(red, green, blue) `
 | 
						|
        # var rgbNumber = new Number((red << 16) | (green << 8) | blue);
 | 
						|
        # var hexString = rgbNumber.toString(16);
 | 
						|
        # var missingZeros = 6 - hexString.length;
 | 
						|
        # var resultBuilder = ['#'];
 | 
						|
        # for (var i = 0; i < missingZeros; i++) `
 | 
						|
        # resultBuilder.push('0');
 | 
						|
        # `
 | 
						|
        # resultBuilder.push(hexString);
 | 
						|
        # return resultBuilder.join('');
 | 
						|
        # `;
 | 
						|
        # // ...
 | 
						|
        # Corresponds to the JSON property `backgroundColor`
 | 
						|
        # @return [Google::Apis::SheetsV4::Color]
 | 
						|
        attr_accessor :background_color
 | 
						|
      
 | 
						|
        # The borders of the cell.
 | 
						|
        # Corresponds to the JSON property `borders`
 | 
						|
        # @return [Google::Apis::SheetsV4::Borders]
 | 
						|
        attr_accessor :borders
 | 
						|
      
 | 
						|
        # The horizontal alignment of the value in the cell.
 | 
						|
        # Corresponds to the JSON property `horizontalAlignment`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :horizontal_alignment
 | 
						|
      
 | 
						|
        # How a hyperlink, if it exists, should be displayed in the cell.
 | 
						|
        # Corresponds to the JSON property `hyperlinkDisplayType`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :hyperlink_display_type
 | 
						|
      
 | 
						|
        # The number format of a cell.
 | 
						|
        # Corresponds to the JSON property `numberFormat`
 | 
						|
        # @return [Google::Apis::SheetsV4::NumberFormat]
 | 
						|
        attr_accessor :number_format
 | 
						|
      
 | 
						|
        # The amount of padding around the cell, in pixels.
 | 
						|
        # When updating padding, every field must be specified.
 | 
						|
        # Corresponds to the JSON property `padding`
 | 
						|
        # @return [Google::Apis::SheetsV4::Padding]
 | 
						|
        attr_accessor :padding
 | 
						|
      
 | 
						|
        # The direction of the text in the cell.
 | 
						|
        # Corresponds to the JSON property `textDirection`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :text_direction
 | 
						|
      
 | 
						|
        # The format of a run of text in a cell.
 | 
						|
        # Absent values indicate that the field isn't specified.
 | 
						|
        # Corresponds to the JSON property `textFormat`
 | 
						|
        # @return [Google::Apis::SheetsV4::TextFormat]
 | 
						|
        attr_accessor :text_format
 | 
						|
      
 | 
						|
        # The rotation applied to text in a cell.
 | 
						|
        # Corresponds to the JSON property `textRotation`
 | 
						|
        # @return [Google::Apis::SheetsV4::TextRotation]
 | 
						|
        attr_accessor :text_rotation
 | 
						|
      
 | 
						|
        # The vertical alignment of the value in the cell.
 | 
						|
        # Corresponds to the JSON property `verticalAlignment`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :vertical_alignment
 | 
						|
      
 | 
						|
        # The wrap strategy for the value in the cell.
 | 
						|
        # Corresponds to the JSON property `wrapStrategy`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :wrap_strategy
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @background_color = args[:background_color] if args.key?(:background_color)
 | 
						|
          @borders = args[:borders] if args.key?(:borders)
 | 
						|
          @horizontal_alignment = args[:horizontal_alignment] if args.key?(:horizontal_alignment)
 | 
						|
          @hyperlink_display_type = args[:hyperlink_display_type] if args.key?(:hyperlink_display_type)
 | 
						|
          @number_format = args[:number_format] if args.key?(:number_format)
 | 
						|
          @padding = args[:padding] if args.key?(:padding)
 | 
						|
          @text_direction = args[:text_direction] if args.key?(:text_direction)
 | 
						|
          @text_format = args[:text_format] if args.key?(:text_format)
 | 
						|
          @text_rotation = args[:text_rotation] if args.key?(:text_rotation)
 | 
						|
          @vertical_alignment = args[:vertical_alignment] if args.key?(:vertical_alignment)
 | 
						|
          @wrap_strategy = args[:wrap_strategy] if args.key?(:wrap_strategy)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The data included in a domain or series.
 | 
						|
      class ChartData
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Source ranges for a chart.
 | 
						|
        # Corresponds to the JSON property `sourceRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartSourceRange]
 | 
						|
        attr_accessor :source_range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @source_range = args[:source_range] if args.key?(:source_range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Source ranges for a chart.
 | 
						|
      class ChartSourceRange
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The ranges of data for a series or domain.
 | 
						|
        # Exactly one dimension must have a length of 1,
 | 
						|
        # and all sources in the list must have the same dimension
 | 
						|
        # with length 1.
 | 
						|
        # The domain (if it exists) & all series must have the same number
 | 
						|
        # of source ranges. If using more than one source range, then the source
 | 
						|
        # range at a given offset must be contiguous across the domain and series.
 | 
						|
        # For example, these are valid configurations:
 | 
						|
        # domain sources: A1:A5
 | 
						|
        # series1 sources: B1:B5
 | 
						|
        # series2 sources: D6:D10
 | 
						|
        # domain sources: A1:A5, C10:C12
 | 
						|
        # series1 sources: B1:B5, D10:D12
 | 
						|
        # series2 sources: C1:C5, E10:E12
 | 
						|
        # Corresponds to the JSON property `sources`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::GridRange>]
 | 
						|
        attr_accessor :sources
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @sources = args[:sources] if args.key?(:sources)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The specifications of a chart.
 | 
						|
      class ChartSpec
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The alternative text that describes the chart.  This is often used
 | 
						|
        # for accessibility.
 | 
						|
        # Corresponds to the JSON property `altText`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :alt_text
 | 
						|
      
 | 
						|
        # Represents a color in the RGBA color space. This representation is designed
 | 
						|
        # for simplicity of conversion to/from color representations in various
 | 
						|
        # languages over compactness; for example, the fields of this representation
 | 
						|
        # can be trivially provided to the constructor of "java.awt.Color" in Java; it
 | 
						|
        # can also be trivially provided to UIColor's "+colorWithRed:green:blue:alpha"
 | 
						|
        # method in iOS; and, with just a little work, it can be easily formatted into
 | 
						|
        # a CSS "rgba()" string in JavaScript, as well. Here are some examples:
 | 
						|
        # Example (Java):
 | 
						|
        # import com.google.type.Color;
 | 
						|
        # // ...
 | 
						|
        # public static java.awt.Color fromProto(Color protocolor) `
 | 
						|
        # float alpha = protocolor.hasAlpha()
 | 
						|
        # ? protocolor.getAlpha().getValue()
 | 
						|
        # : 1.0;
 | 
						|
        # return new java.awt.Color(
 | 
						|
        # protocolor.getRed(),
 | 
						|
        # protocolor.getGreen(),
 | 
						|
        # protocolor.getBlue(),
 | 
						|
        # alpha);
 | 
						|
        # `
 | 
						|
        # public static Color toProto(java.awt.Color color) `
 | 
						|
        # float red = (float) color.getRed();
 | 
						|
        # float green = (float) color.getGreen();
 | 
						|
        # float blue = (float) color.getBlue();
 | 
						|
        # float denominator = 255.0;
 | 
						|
        # Color.Builder resultBuilder =
 | 
						|
        # Color
 | 
						|
        # .newBuilder()
 | 
						|
        # .setRed(red / denominator)
 | 
						|
        # .setGreen(green / denominator)
 | 
						|
        # .setBlue(blue / denominator);
 | 
						|
        # int alpha = color.getAlpha();
 | 
						|
        # if (alpha != 255) `
 | 
						|
        # result.setAlpha(
 | 
						|
        # FloatValue
 | 
						|
        # .newBuilder()
 | 
						|
        # .setValue(((float) alpha) / denominator)
 | 
						|
        # .build());
 | 
						|
        # `
 | 
						|
        # return resultBuilder.build();
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (iOS / Obj-C):
 | 
						|
        # // ...
 | 
						|
        # static UIColor* fromProto(Color* protocolor) `
 | 
						|
        # float red = [protocolor red];
 | 
						|
        # float green = [protocolor green];
 | 
						|
        # float blue = [protocolor blue];
 | 
						|
        # FloatValue* alpha_wrapper = [protocolor alpha];
 | 
						|
        # float alpha = 1.0;
 | 
						|
        # if (alpha_wrapper != nil) `
 | 
						|
        # alpha = [alpha_wrapper value];
 | 
						|
        # `
 | 
						|
        # return [UIColor colorWithRed:red green:green blue:blue alpha:alpha];
 | 
						|
        # `
 | 
						|
        # static Color* toProto(UIColor* color) `
 | 
						|
        # CGFloat red, green, blue, alpha;
 | 
						|
        # if (![color getRed:&red green:&green blue:&blue alpha:&alpha]) `
 | 
						|
        # return nil;
 | 
						|
        # `
 | 
						|
        # Color* result = [Color alloc] init];
 | 
						|
        # [result setRed:red];
 | 
						|
        # [result setGreen:green];
 | 
						|
        # [result setBlue:blue];
 | 
						|
        # if (alpha <= 0.9999) `
 | 
						|
        # [result setAlpha:floatWrapperWithValue(alpha)];
 | 
						|
        # `
 | 
						|
        # [result autorelease];
 | 
						|
        # return result;
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (JavaScript):
 | 
						|
        # // ...
 | 
						|
        # var protoToCssColor = function(rgb_color) `
 | 
						|
        # var redFrac = rgb_color.red || 0.0;
 | 
						|
        # var greenFrac = rgb_color.green || 0.0;
 | 
						|
        # var blueFrac = rgb_color.blue || 0.0;
 | 
						|
        # var red = Math.floor(redFrac * 255);
 | 
						|
        # var green = Math.floor(greenFrac * 255);
 | 
						|
        # var blue = Math.floor(blueFrac * 255);
 | 
						|
        # if (!('alpha' in rgb_color)) `
 | 
						|
        # return rgbToCssColor_(red, green, blue);
 | 
						|
        # `
 | 
						|
        # var alphaFrac = rgb_color.alpha.value || 0.0;
 | 
						|
        # var rgbParams = [red, green, blue].join(',');
 | 
						|
        # return ['rgba(', rgbParams, ',', alphaFrac, ')'].join('');
 | 
						|
        # `;
 | 
						|
        # var rgbToCssColor_ = function(red, green, blue) `
 | 
						|
        # var rgbNumber = new Number((red << 16) | (green << 8) | blue);
 | 
						|
        # var hexString = rgbNumber.toString(16);
 | 
						|
        # var missingZeros = 6 - hexString.length;
 | 
						|
        # var resultBuilder = ['#'];
 | 
						|
        # for (var i = 0; i < missingZeros; i++) `
 | 
						|
        # resultBuilder.push('0');
 | 
						|
        # `
 | 
						|
        # resultBuilder.push(hexString);
 | 
						|
        # return resultBuilder.join('');
 | 
						|
        # `;
 | 
						|
        # // ...
 | 
						|
        # Corresponds to the JSON property `backgroundColor`
 | 
						|
        # @return [Google::Apis::SheetsV4::Color]
 | 
						|
        attr_accessor :background_color
 | 
						|
      
 | 
						|
        # The specification for a basic chart.  See BasicChartType for the list
 | 
						|
        # of charts this supports.
 | 
						|
        # Corresponds to the JSON property `basicChart`
 | 
						|
        # @return [Google::Apis::SheetsV4::BasicChartSpec]
 | 
						|
        attr_accessor :basic_chart
 | 
						|
      
 | 
						|
        # A <a href="/chart/interactive/docs/gallery/bubblechart">bubble chart</a>.
 | 
						|
        # Corresponds to the JSON property `bubbleChart`
 | 
						|
        # @return [Google::Apis::SheetsV4::BubbleChartSpec]
 | 
						|
        attr_accessor :bubble_chart
 | 
						|
      
 | 
						|
        # A <a href="/chart/interactive/docs/gallery/candlestickchart">candlestick chart<
 | 
						|
        # /a>.
 | 
						|
        # Corresponds to the JSON property `candlestickChart`
 | 
						|
        # @return [Google::Apis::SheetsV4::CandlestickChartSpec]
 | 
						|
        attr_accessor :candlestick_chart
 | 
						|
      
 | 
						|
        # The name of the font to use by default for all chart text (e.g. title,
 | 
						|
        # axis labels, legend).  If a font is specified for a specific part of the
 | 
						|
        # chart it will override this font name.
 | 
						|
        # Corresponds to the JSON property `fontName`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :font_name
 | 
						|
      
 | 
						|
        # Determines how the charts will use hidden rows or columns.
 | 
						|
        # Corresponds to the JSON property `hiddenDimensionStrategy`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :hidden_dimension_strategy
 | 
						|
      
 | 
						|
        # A <a href="/chart/interactive/docs/gallery/histogram">histogram chart</a>.
 | 
						|
        # A histogram chart groups data items into bins, displaying each bin as a
 | 
						|
        # column of stacked items.  Histograms are used to display the distribution
 | 
						|
        # of a dataset.  Each column of items represents a range into which those
 | 
						|
        # items fall.  The number of bins can be chosen automatically or specified
 | 
						|
        # explicitly.
 | 
						|
        # Corresponds to the JSON property `histogramChart`
 | 
						|
        # @return [Google::Apis::SheetsV4::HistogramChartSpec]
 | 
						|
        attr_accessor :histogram_chart
 | 
						|
      
 | 
						|
        # True to make a chart fill the entire space in which it's rendered with
 | 
						|
        # minimum padding.  False to use the default padding.
 | 
						|
        # (Not applicable to Geo and Org charts.)
 | 
						|
        # Corresponds to the JSON property `maximized`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :maximized
 | 
						|
        alias_method :maximized?, :maximized
 | 
						|
      
 | 
						|
        # An <a href="/chart/interactive/docs/gallery/orgchart">org chart</a>.
 | 
						|
        # Org charts require a unique set of labels in labels and may
 | 
						|
        # optionally include parent_labels and tooltips.
 | 
						|
        # parent_labels contain, for each node, the label identifying the parent
 | 
						|
        # node.  tooltips contain, for each node, an optional tooltip.
 | 
						|
        # For example, to describe an OrgChart with Alice as the CEO, Bob as the
 | 
						|
        # President (reporting to Alice) and Cathy as VP of Sales (also reporting to
 | 
						|
        # Alice), have labels contain "Alice", "Bob", "Cathy",
 | 
						|
        # parent_labels contain "", "Alice", "Alice" and tooltips contain
 | 
						|
        # "CEO", "President", "VP Sales".
 | 
						|
        # Corresponds to the JSON property `orgChart`
 | 
						|
        # @return [Google::Apis::SheetsV4::OrgChartSpec]
 | 
						|
        attr_accessor :org_chart
 | 
						|
      
 | 
						|
        # A <a href="/chart/interactive/docs/gallery/piechart">pie chart</a>.
 | 
						|
        # Corresponds to the JSON property `pieChart`
 | 
						|
        # @return [Google::Apis::SheetsV4::PieChartSpec]
 | 
						|
        attr_accessor :pie_chart
 | 
						|
      
 | 
						|
        # The subtitle of the chart.
 | 
						|
        # Corresponds to the JSON property `subtitle`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :subtitle
 | 
						|
      
 | 
						|
        # The format of a run of text in a cell.
 | 
						|
        # Absent values indicate that the field isn't specified.
 | 
						|
        # Corresponds to the JSON property `subtitleTextFormat`
 | 
						|
        # @return [Google::Apis::SheetsV4::TextFormat]
 | 
						|
        attr_accessor :subtitle_text_format
 | 
						|
      
 | 
						|
        # Position settings for text.
 | 
						|
        # Corresponds to the JSON property `subtitleTextPosition`
 | 
						|
        # @return [Google::Apis::SheetsV4::TextPosition]
 | 
						|
        attr_accessor :subtitle_text_position
 | 
						|
      
 | 
						|
        # The title of the chart.
 | 
						|
        # Corresponds to the JSON property `title`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :title
 | 
						|
      
 | 
						|
        # The format of a run of text in a cell.
 | 
						|
        # Absent values indicate that the field isn't specified.
 | 
						|
        # Corresponds to the JSON property `titleTextFormat`
 | 
						|
        # @return [Google::Apis::SheetsV4::TextFormat]
 | 
						|
        attr_accessor :title_text_format
 | 
						|
      
 | 
						|
        # Position settings for text.
 | 
						|
        # Corresponds to the JSON property `titleTextPosition`
 | 
						|
        # @return [Google::Apis::SheetsV4::TextPosition]
 | 
						|
        attr_accessor :title_text_position
 | 
						|
      
 | 
						|
        # A waterfall chart.
 | 
						|
        # Corresponds to the JSON property `waterfallChart`
 | 
						|
        # @return [Google::Apis::SheetsV4::WaterfallChartSpec]
 | 
						|
        attr_accessor :waterfall_chart
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @alt_text = args[:alt_text] if args.key?(:alt_text)
 | 
						|
          @background_color = args[:background_color] if args.key?(:background_color)
 | 
						|
          @basic_chart = args[:basic_chart] if args.key?(:basic_chart)
 | 
						|
          @bubble_chart = args[:bubble_chart] if args.key?(:bubble_chart)
 | 
						|
          @candlestick_chart = args[:candlestick_chart] if args.key?(:candlestick_chart)
 | 
						|
          @font_name = args[:font_name] if args.key?(:font_name)
 | 
						|
          @hidden_dimension_strategy = args[:hidden_dimension_strategy] if args.key?(:hidden_dimension_strategy)
 | 
						|
          @histogram_chart = args[:histogram_chart] if args.key?(:histogram_chart)
 | 
						|
          @maximized = args[:maximized] if args.key?(:maximized)
 | 
						|
          @org_chart = args[:org_chart] if args.key?(:org_chart)
 | 
						|
          @pie_chart = args[:pie_chart] if args.key?(:pie_chart)
 | 
						|
          @subtitle = args[:subtitle] if args.key?(:subtitle)
 | 
						|
          @subtitle_text_format = args[:subtitle_text_format] if args.key?(:subtitle_text_format)
 | 
						|
          @subtitle_text_position = args[:subtitle_text_position] if args.key?(:subtitle_text_position)
 | 
						|
          @title = args[:title] if args.key?(:title)
 | 
						|
          @title_text_format = args[:title_text_format] if args.key?(:title_text_format)
 | 
						|
          @title_text_position = args[:title_text_position] if args.key?(:title_text_position)
 | 
						|
          @waterfall_chart = args[:waterfall_chart] if args.key?(:waterfall_chart)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Clears the basic filter, if any exists on the sheet.
 | 
						|
      class ClearBasicFilterRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The sheet ID on which the basic filter should be cleared.
 | 
						|
        # Corresponds to the JSON property `sheetId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :sheet_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @sheet_id = args[:sheet_id] if args.key?(:sheet_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The request for clearing a range of values in a spreadsheet.
 | 
						|
      class ClearValuesRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The response when clearing a range of values in a spreadsheet.
 | 
						|
      class ClearValuesResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The range (in A1 notation) that was cleared.
 | 
						|
        # (If the request was for an unbounded range or a ranger larger
 | 
						|
        # than the bounds of the sheet, this will be the actual range
 | 
						|
        # that was cleared, bounded to the sheet's limits.)
 | 
						|
        # Corresponds to the JSON property `clearedRange`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :cleared_range
 | 
						|
      
 | 
						|
        # The spreadsheet the updates were applied to.
 | 
						|
        # Corresponds to the JSON property `spreadsheetId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :spreadsheet_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @cleared_range = args[:cleared_range] if args.key?(:cleared_range)
 | 
						|
          @spreadsheet_id = args[:spreadsheet_id] if args.key?(:spreadsheet_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Represents a color in the RGBA color space. This representation is designed
 | 
						|
      # for simplicity of conversion to/from color representations in various
 | 
						|
      # languages over compactness; for example, the fields of this representation
 | 
						|
      # can be trivially provided to the constructor of "java.awt.Color" in Java; it
 | 
						|
      # can also be trivially provided to UIColor's "+colorWithRed:green:blue:alpha"
 | 
						|
      # method in iOS; and, with just a little work, it can be easily formatted into
 | 
						|
      # a CSS "rgba()" string in JavaScript, as well. Here are some examples:
 | 
						|
      # Example (Java):
 | 
						|
      # import com.google.type.Color;
 | 
						|
      # // ...
 | 
						|
      # public static java.awt.Color fromProto(Color protocolor) `
 | 
						|
      # float alpha = protocolor.hasAlpha()
 | 
						|
      # ? protocolor.getAlpha().getValue()
 | 
						|
      # : 1.0;
 | 
						|
      # return new java.awt.Color(
 | 
						|
      # protocolor.getRed(),
 | 
						|
      # protocolor.getGreen(),
 | 
						|
      # protocolor.getBlue(),
 | 
						|
      # alpha);
 | 
						|
      # `
 | 
						|
      # public static Color toProto(java.awt.Color color) `
 | 
						|
      # float red = (float) color.getRed();
 | 
						|
      # float green = (float) color.getGreen();
 | 
						|
      # float blue = (float) color.getBlue();
 | 
						|
      # float denominator = 255.0;
 | 
						|
      # Color.Builder resultBuilder =
 | 
						|
      # Color
 | 
						|
      # .newBuilder()
 | 
						|
      # .setRed(red / denominator)
 | 
						|
      # .setGreen(green / denominator)
 | 
						|
      # .setBlue(blue / denominator);
 | 
						|
      # int alpha = color.getAlpha();
 | 
						|
      # if (alpha != 255) `
 | 
						|
      # result.setAlpha(
 | 
						|
      # FloatValue
 | 
						|
      # .newBuilder()
 | 
						|
      # .setValue(((float) alpha) / denominator)
 | 
						|
      # .build());
 | 
						|
      # `
 | 
						|
      # return resultBuilder.build();
 | 
						|
      # `
 | 
						|
      # // ...
 | 
						|
      # Example (iOS / Obj-C):
 | 
						|
      # // ...
 | 
						|
      # static UIColor* fromProto(Color* protocolor) `
 | 
						|
      # float red = [protocolor red];
 | 
						|
      # float green = [protocolor green];
 | 
						|
      # float blue = [protocolor blue];
 | 
						|
      # FloatValue* alpha_wrapper = [protocolor alpha];
 | 
						|
      # float alpha = 1.0;
 | 
						|
      # if (alpha_wrapper != nil) `
 | 
						|
      # alpha = [alpha_wrapper value];
 | 
						|
      # `
 | 
						|
      # return [UIColor colorWithRed:red green:green blue:blue alpha:alpha];
 | 
						|
      # `
 | 
						|
      # static Color* toProto(UIColor* color) `
 | 
						|
      # CGFloat red, green, blue, alpha;
 | 
						|
      # if (![color getRed:&red green:&green blue:&blue alpha:&alpha]) `
 | 
						|
      # return nil;
 | 
						|
      # `
 | 
						|
      # Color* result = [Color alloc] init];
 | 
						|
      # [result setRed:red];
 | 
						|
      # [result setGreen:green];
 | 
						|
      # [result setBlue:blue];
 | 
						|
      # if (alpha <= 0.9999) `
 | 
						|
      # [result setAlpha:floatWrapperWithValue(alpha)];
 | 
						|
      # `
 | 
						|
      # [result autorelease];
 | 
						|
      # return result;
 | 
						|
      # `
 | 
						|
      # // ...
 | 
						|
      # Example (JavaScript):
 | 
						|
      # // ...
 | 
						|
      # var protoToCssColor = function(rgb_color) `
 | 
						|
      # var redFrac = rgb_color.red || 0.0;
 | 
						|
      # var greenFrac = rgb_color.green || 0.0;
 | 
						|
      # var blueFrac = rgb_color.blue || 0.0;
 | 
						|
      # var red = Math.floor(redFrac * 255);
 | 
						|
      # var green = Math.floor(greenFrac * 255);
 | 
						|
      # var blue = Math.floor(blueFrac * 255);
 | 
						|
      # if (!('alpha' in rgb_color)) `
 | 
						|
      # return rgbToCssColor_(red, green, blue);
 | 
						|
      # `
 | 
						|
      # var alphaFrac = rgb_color.alpha.value || 0.0;
 | 
						|
      # var rgbParams = [red, green, blue].join(',');
 | 
						|
      # return ['rgba(', rgbParams, ',', alphaFrac, ')'].join('');
 | 
						|
      # `;
 | 
						|
      # var rgbToCssColor_ = function(red, green, blue) `
 | 
						|
      # var rgbNumber = new Number((red << 16) | (green << 8) | blue);
 | 
						|
      # var hexString = rgbNumber.toString(16);
 | 
						|
      # var missingZeros = 6 - hexString.length;
 | 
						|
      # var resultBuilder = ['#'];
 | 
						|
      # for (var i = 0; i < missingZeros; i++) `
 | 
						|
      # resultBuilder.push('0');
 | 
						|
      # `
 | 
						|
      # resultBuilder.push(hexString);
 | 
						|
      # return resultBuilder.join('');
 | 
						|
      # `;
 | 
						|
      # // ...
 | 
						|
      class Color
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The fraction of this color that should be applied to the pixel. That is,
 | 
						|
        # the final pixel color is defined by the equation:
 | 
						|
        # pixel color = alpha * (this color) + (1.0 - alpha) * (background color)
 | 
						|
        # This means that a value of 1.0 corresponds to a solid color, whereas
 | 
						|
        # a value of 0.0 corresponds to a completely transparent color. This
 | 
						|
        # uses a wrapper message rather than a simple float scalar so that it is
 | 
						|
        # possible to distinguish between a default value and the value being unset.
 | 
						|
        # If omitted, this color object is to be rendered as a solid color
 | 
						|
        # (as if the alpha value had been explicitly given with a value of 1.0).
 | 
						|
        # Corresponds to the JSON property `alpha`
 | 
						|
        # @return [Float]
 | 
						|
        attr_accessor :alpha
 | 
						|
      
 | 
						|
        # The amount of blue in the color as a value in the interval [0, 1].
 | 
						|
        # Corresponds to the JSON property `blue`
 | 
						|
        # @return [Float]
 | 
						|
        attr_accessor :blue
 | 
						|
      
 | 
						|
        # The amount of green in the color as a value in the interval [0, 1].
 | 
						|
        # Corresponds to the JSON property `green`
 | 
						|
        # @return [Float]
 | 
						|
        attr_accessor :green
 | 
						|
      
 | 
						|
        # The amount of red in the color as a value in the interval [0, 1].
 | 
						|
        # Corresponds to the JSON property `red`
 | 
						|
        # @return [Float]
 | 
						|
        attr_accessor :red
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @alpha = args[:alpha] if args.key?(:alpha)
 | 
						|
          @blue = args[:blue] if args.key?(:blue)
 | 
						|
          @green = args[:green] if args.key?(:green)
 | 
						|
          @red = args[:red] if args.key?(:red)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The value of the condition.
 | 
						|
      class ConditionValue
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A relative date (based on the current date).
 | 
						|
        # Valid only if the type is
 | 
						|
        # DATE_BEFORE,
 | 
						|
        # DATE_AFTER,
 | 
						|
        # DATE_ON_OR_BEFORE or
 | 
						|
        # DATE_ON_OR_AFTER.
 | 
						|
        # Relative dates are not supported in data validation.
 | 
						|
        # They are supported only in conditional formatting and
 | 
						|
        # conditional filters.
 | 
						|
        # Corresponds to the JSON property `relativeDate`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :relative_date
 | 
						|
      
 | 
						|
        # A value the condition is based on.
 | 
						|
        # The value will be parsed as if the user typed into a cell.
 | 
						|
        # Formulas are supported (and must begin with an `=`).
 | 
						|
        # Corresponds to the JSON property `userEnteredValue`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :user_entered_value
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @relative_date = args[:relative_date] if args.key?(:relative_date)
 | 
						|
          @user_entered_value = args[:user_entered_value] if args.key?(:user_entered_value)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A rule describing a conditional format.
 | 
						|
      class ConditionalFormatRule
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A rule that may or may not match, depending on the condition.
 | 
						|
        # Corresponds to the JSON property `booleanRule`
 | 
						|
        # @return [Google::Apis::SheetsV4::BooleanRule]
 | 
						|
        attr_accessor :boolean_rule
 | 
						|
      
 | 
						|
        # A rule that applies a gradient color scale format, based on
 | 
						|
        # the interpolation points listed. The format of a cell will vary
 | 
						|
        # based on its contents as compared to the values of the interpolation
 | 
						|
        # points.
 | 
						|
        # Corresponds to the JSON property `gradientRule`
 | 
						|
        # @return [Google::Apis::SheetsV4::GradientRule]
 | 
						|
        attr_accessor :gradient_rule
 | 
						|
      
 | 
						|
        # The ranges that will be formatted if the condition is true.
 | 
						|
        # All the ranges must be on the same grid.
 | 
						|
        # Corresponds to the JSON property `ranges`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::GridRange>]
 | 
						|
        attr_accessor :ranges
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @boolean_rule = args[:boolean_rule] if args.key?(:boolean_rule)
 | 
						|
          @gradient_rule = args[:gradient_rule] if args.key?(:gradient_rule)
 | 
						|
          @ranges = args[:ranges] if args.key?(:ranges)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Copies data from the source to the destination.
 | 
						|
      class CopyPasteRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `destination`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :destination
 | 
						|
      
 | 
						|
        # How that data should be oriented when pasting.
 | 
						|
        # Corresponds to the JSON property `pasteOrientation`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :paste_orientation
 | 
						|
      
 | 
						|
        # What kind of data to paste.
 | 
						|
        # Corresponds to the JSON property `pasteType`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :paste_type
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `source`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :source
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @destination = args[:destination] if args.key?(:destination)
 | 
						|
          @paste_orientation = args[:paste_orientation] if args.key?(:paste_orientation)
 | 
						|
          @paste_type = args[:paste_type] if args.key?(:paste_type)
 | 
						|
          @source = args[:source] if args.key?(:source)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The request to copy a sheet across spreadsheets.
 | 
						|
      class CopySheetToAnotherSpreadsheetRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The ID of the spreadsheet to copy the sheet to.
 | 
						|
        # Corresponds to the JSON property `destinationSpreadsheetId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :destination_spreadsheet_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @destination_spreadsheet_id = args[:destination_spreadsheet_id] if args.key?(:destination_spreadsheet_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A request to create developer metadata.
 | 
						|
      class CreateDeveloperMetadataRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Developer metadata associated with a location or object in a spreadsheet.
 | 
						|
        # Developer metadata may be used to associate arbitrary data with various
 | 
						|
        # parts of a spreadsheet and will remain associated at those locations as they
 | 
						|
        # move around and the spreadsheet is edited.  For example, if developer
 | 
						|
        # metadata is associated with row 5 and another row is then subsequently
 | 
						|
        # inserted above row 5, that original metadata will still be associated with
 | 
						|
        # the row it was first associated with (what is now row 6). If the associated
 | 
						|
        # object is deleted its metadata will be deleted too.
 | 
						|
        # Corresponds to the JSON property `developerMetadata`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeveloperMetadata]
 | 
						|
        attr_accessor :developer_metadata
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @developer_metadata = args[:developer_metadata] if args.key?(:developer_metadata)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The response from creating developer metadata.
 | 
						|
      class CreateDeveloperMetadataResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Developer metadata associated with a location or object in a spreadsheet.
 | 
						|
        # Developer metadata may be used to associate arbitrary data with various
 | 
						|
        # parts of a spreadsheet and will remain associated at those locations as they
 | 
						|
        # move around and the spreadsheet is edited.  For example, if developer
 | 
						|
        # metadata is associated with row 5 and another row is then subsequently
 | 
						|
        # inserted above row 5, that original metadata will still be associated with
 | 
						|
        # the row it was first associated with (what is now row 6). If the associated
 | 
						|
        # object is deleted its metadata will be deleted too.
 | 
						|
        # Corresponds to the JSON property `developerMetadata`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeveloperMetadata]
 | 
						|
        attr_accessor :developer_metadata
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @developer_metadata = args[:developer_metadata] if args.key?(:developer_metadata)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Moves data from the source to the destination.
 | 
						|
      class CutPasteRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A coordinate in a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Corresponds to the JSON property `destination`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridCoordinate]
 | 
						|
        attr_accessor :destination
 | 
						|
      
 | 
						|
        # What kind of data to paste.  All the source data will be cut, regardless
 | 
						|
        # of what is pasted.
 | 
						|
        # Corresponds to the JSON property `pasteType`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :paste_type
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `source`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :source
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @destination = args[:destination] if args.key?(:destination)
 | 
						|
          @paste_type = args[:paste_type] if args.key?(:paste_type)
 | 
						|
          @source = args[:source] if args.key?(:source)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Filter that describes what data should be selected or returned from a
 | 
						|
      # request.
 | 
						|
      class DataFilter
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Selects data that matches the specified A1 range.
 | 
						|
        # Corresponds to the JSON property `a1Range`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :a1_range
 | 
						|
      
 | 
						|
        # Selects DeveloperMetadata that matches all of the specified fields.  For
 | 
						|
        # example, if only a metadata ID is specified this considers the
 | 
						|
        # DeveloperMetadata with that particular unique ID. If a metadata key is
 | 
						|
        # specified, this considers all developer metadata with that key.  If a
 | 
						|
        # key, visibility, and location type are all specified, this considers all
 | 
						|
        # developer metadata with that key and visibility that are associated with a
 | 
						|
        # location of that type.  In general, this
 | 
						|
        # selects all DeveloperMetadata that matches the intersection of all the
 | 
						|
        # specified fields; any field or combination of fields may be specified.
 | 
						|
        # Corresponds to the JSON property `developerMetadataLookup`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeveloperMetadataLookup]
 | 
						|
        attr_accessor :developer_metadata_lookup
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `gridRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :grid_range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @a1_range = args[:a1_range] if args.key?(:a1_range)
 | 
						|
          @developer_metadata_lookup = args[:developer_metadata_lookup] if args.key?(:developer_metadata_lookup)
 | 
						|
          @grid_range = args[:grid_range] if args.key?(:grid_range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A range of values whose location is specified by a DataFilter.
 | 
						|
      class DataFilterValueRange
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Filter that describes what data should be selected or returned from a
 | 
						|
        # request.
 | 
						|
        # Corresponds to the JSON property `dataFilter`
 | 
						|
        # @return [Google::Apis::SheetsV4::DataFilter]
 | 
						|
        attr_accessor :data_filter
 | 
						|
      
 | 
						|
        # The major dimension of the values.
 | 
						|
        # Corresponds to the JSON property `majorDimension`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :major_dimension
 | 
						|
      
 | 
						|
        # The data to be written.  If the provided values exceed any of the ranges
 | 
						|
        # matched by the data filter then the request will fail.  If the provided
 | 
						|
        # values are less than the matched ranges only the specified values will be
 | 
						|
        # written, existing values in the matched ranges will remain unaffected.
 | 
						|
        # Corresponds to the JSON property `values`
 | 
						|
        # @return [Array<Array<Object>>]
 | 
						|
        attr_accessor :values
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data_filter = args[:data_filter] if args.key?(:data_filter)
 | 
						|
          @major_dimension = args[:major_dimension] if args.key?(:major_dimension)
 | 
						|
          @values = args[:values] if args.key?(:values)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A data validation rule.
 | 
						|
      class DataValidationRule
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A condition that can evaluate to true or false.
 | 
						|
        # BooleanConditions are used by conditional formatting,
 | 
						|
        # data validation, and the criteria in filters.
 | 
						|
        # Corresponds to the JSON property `condition`
 | 
						|
        # @return [Google::Apis::SheetsV4::BooleanCondition]
 | 
						|
        attr_accessor :condition
 | 
						|
      
 | 
						|
        # A message to show the user when adding data to the cell.
 | 
						|
        # Corresponds to the JSON property `inputMessage`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :input_message
 | 
						|
      
 | 
						|
        # True if the UI should be customized based on the kind of condition.
 | 
						|
        # If true, "List" conditions will show a dropdown.
 | 
						|
        # Corresponds to the JSON property `showCustomUi`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :show_custom_ui
 | 
						|
        alias_method :show_custom_ui?, :show_custom_ui
 | 
						|
      
 | 
						|
        # True if invalid data should be rejected.
 | 
						|
        # Corresponds to the JSON property `strict`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :strict
 | 
						|
        alias_method :strict?, :strict
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @condition = args[:condition] if args.key?(:condition)
 | 
						|
          @input_message = args[:input_message] if args.key?(:input_message)
 | 
						|
          @show_custom_ui = args[:show_custom_ui] if args.key?(:show_custom_ui)
 | 
						|
          @strict = args[:strict] if args.key?(:strict)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Removes the banded range with the given ID from the spreadsheet.
 | 
						|
      class DeleteBandingRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The ID of the banded range to delete.
 | 
						|
        # Corresponds to the JSON property `bandedRangeId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :banded_range_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @banded_range_id = args[:banded_range_id] if args.key?(:banded_range_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Deletes a conditional format rule at the given index.
 | 
						|
      # All subsequent rules' indexes are decremented.
 | 
						|
      class DeleteConditionalFormatRuleRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The zero-based index of the rule to be deleted.
 | 
						|
        # Corresponds to the JSON property `index`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :index
 | 
						|
      
 | 
						|
        # The sheet the rule is being deleted from.
 | 
						|
        # Corresponds to the JSON property `sheetId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :sheet_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @index = args[:index] if args.key?(:index)
 | 
						|
          @sheet_id = args[:sheet_id] if args.key?(:sheet_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The result of deleting a conditional format rule.
 | 
						|
      class DeleteConditionalFormatRuleResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A rule describing a conditional format.
 | 
						|
        # Corresponds to the JSON property `rule`
 | 
						|
        # @return [Google::Apis::SheetsV4::ConditionalFormatRule]
 | 
						|
        attr_accessor :rule
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @rule = args[:rule] if args.key?(:rule)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A request to delete developer metadata.
 | 
						|
      class DeleteDeveloperMetadataRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Filter that describes what data should be selected or returned from a
 | 
						|
        # request.
 | 
						|
        # Corresponds to the JSON property `dataFilter`
 | 
						|
        # @return [Google::Apis::SheetsV4::DataFilter]
 | 
						|
        attr_accessor :data_filter
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data_filter = args[:data_filter] if args.key?(:data_filter)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The response from deleting developer metadata.
 | 
						|
      class DeleteDeveloperMetadataResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The metadata that was deleted.
 | 
						|
        # Corresponds to the JSON property `deletedDeveloperMetadata`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::DeveloperMetadata>]
 | 
						|
        attr_accessor :deleted_developer_metadata
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @deleted_developer_metadata = args[:deleted_developer_metadata] if args.key?(:deleted_developer_metadata)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Deletes the dimensions from the sheet.
 | 
						|
      class DeleteDimensionRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A range along a single dimension on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open: the start index is inclusive
 | 
						|
        # and the end index is exclusive.
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::DimensionRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Deletes the embedded object with the given ID.
 | 
						|
      class DeleteEmbeddedObjectRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The ID of the embedded object to delete.
 | 
						|
        # Corresponds to the JSON property `objectId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :object_id_prop
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @object_id_prop = args[:object_id_prop] if args.key?(:object_id_prop)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Deletes a particular filter view.
 | 
						|
      class DeleteFilterViewRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The ID of the filter to delete.
 | 
						|
        # Corresponds to the JSON property `filterId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :filter_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @filter_id = args[:filter_id] if args.key?(:filter_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Removes the named range with the given ID from the spreadsheet.
 | 
						|
      class DeleteNamedRangeRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The ID of the named range to delete.
 | 
						|
        # Corresponds to the JSON property `namedRangeId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :named_range_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @named_range_id = args[:named_range_id] if args.key?(:named_range_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Deletes the protected range with the given ID.
 | 
						|
      class DeleteProtectedRangeRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The ID of the protected range to delete.
 | 
						|
        # Corresponds to the JSON property `protectedRangeId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :protected_range_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @protected_range_id = args[:protected_range_id] if args.key?(:protected_range_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Deletes a range of cells, shifting other cells into the deleted area.
 | 
						|
      class DeleteRangeRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        # The dimension from which deleted cells will be replaced with.
 | 
						|
        # If ROWS, existing cells will be shifted upward to
 | 
						|
        # replace the deleted cells. If COLUMNS, existing cells
 | 
						|
        # will be shifted left to replace the deleted cells.
 | 
						|
        # Corresponds to the JSON property `shiftDimension`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :shift_dimension
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
          @shift_dimension = args[:shift_dimension] if args.key?(:shift_dimension)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Deletes the requested sheet.
 | 
						|
      class DeleteSheetRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The ID of the sheet to delete.
 | 
						|
        # Corresponds to the JSON property `sheetId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :sheet_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @sheet_id = args[:sheet_id] if args.key?(:sheet_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Developer metadata associated with a location or object in a spreadsheet.
 | 
						|
      # Developer metadata may be used to associate arbitrary data with various
 | 
						|
      # parts of a spreadsheet and will remain associated at those locations as they
 | 
						|
      # move around and the spreadsheet is edited.  For example, if developer
 | 
						|
      # metadata is associated with row 5 and another row is then subsequently
 | 
						|
      # inserted above row 5, that original metadata will still be associated with
 | 
						|
      # the row it was first associated with (what is now row 6). If the associated
 | 
						|
      # object is deleted its metadata will be deleted too.
 | 
						|
      class DeveloperMetadata
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A location where metadata may be associated in a spreadsheet.
 | 
						|
        # Corresponds to the JSON property `location`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeveloperMetadataLocation]
 | 
						|
        attr_accessor :location
 | 
						|
      
 | 
						|
        # The spreadsheet-scoped unique ID that identifies the metadata. IDs may be
 | 
						|
        # specified when metadata is created, otherwise one will be randomly
 | 
						|
        # generated and assigned. Must be positive.
 | 
						|
        # Corresponds to the JSON property `metadataId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :metadata_id
 | 
						|
      
 | 
						|
        # The metadata key. There may be multiple metadata in a spreadsheet with the
 | 
						|
        # same key.  Developer metadata must always have a key specified.
 | 
						|
        # Corresponds to the JSON property `metadataKey`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :metadata_key
 | 
						|
      
 | 
						|
        # Data associated with the metadata's key.
 | 
						|
        # Corresponds to the JSON property `metadataValue`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :metadata_value
 | 
						|
      
 | 
						|
        # The metadata visibility.  Developer metadata must always have a visibility
 | 
						|
        # specified.
 | 
						|
        # Corresponds to the JSON property `visibility`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :visibility
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @location = args[:location] if args.key?(:location)
 | 
						|
          @metadata_id = args[:metadata_id] if args.key?(:metadata_id)
 | 
						|
          @metadata_key = args[:metadata_key] if args.key?(:metadata_key)
 | 
						|
          @metadata_value = args[:metadata_value] if args.key?(:metadata_value)
 | 
						|
          @visibility = args[:visibility] if args.key?(:visibility)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A location where metadata may be associated in a spreadsheet.
 | 
						|
      class DeveloperMetadataLocation
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A range along a single dimension on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open: the start index is inclusive
 | 
						|
        # and the end index is exclusive.
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # Corresponds to the JSON property `dimensionRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::DimensionRange]
 | 
						|
        attr_accessor :dimension_range
 | 
						|
      
 | 
						|
        # The type of location this object represents.  This field is read-only.
 | 
						|
        # Corresponds to the JSON property `locationType`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :location_type
 | 
						|
      
 | 
						|
        # The ID of the sheet when metadata is associated with an entire sheet.
 | 
						|
        # Corresponds to the JSON property `sheetId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :sheet_id
 | 
						|
      
 | 
						|
        # True when metadata is associated with an entire spreadsheet.
 | 
						|
        # Corresponds to the JSON property `spreadsheet`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :spreadsheet
 | 
						|
        alias_method :spreadsheet?, :spreadsheet
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @dimension_range = args[:dimension_range] if args.key?(:dimension_range)
 | 
						|
          @location_type = args[:location_type] if args.key?(:location_type)
 | 
						|
          @sheet_id = args[:sheet_id] if args.key?(:sheet_id)
 | 
						|
          @spreadsheet = args[:spreadsheet] if args.key?(:spreadsheet)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Selects DeveloperMetadata that matches all of the specified fields.  For
 | 
						|
      # example, if only a metadata ID is specified this considers the
 | 
						|
      # DeveloperMetadata with that particular unique ID. If a metadata key is
 | 
						|
      # specified, this considers all developer metadata with that key.  If a
 | 
						|
      # key, visibility, and location type are all specified, this considers all
 | 
						|
      # developer metadata with that key and visibility that are associated with a
 | 
						|
      # location of that type.  In general, this
 | 
						|
      # selects all DeveloperMetadata that matches the intersection of all the
 | 
						|
      # specified fields; any field or combination of fields may be specified.
 | 
						|
      class DeveloperMetadataLookup
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Determines how this lookup matches the location.  If this field is
 | 
						|
        # specified as EXACT, only developer metadata associated on the exact
 | 
						|
        # location specified is matched.  If this field is specified to INTERSECTING,
 | 
						|
        # developer metadata associated on intersecting locations is also
 | 
						|
        # matched.  If left unspecified, this field assumes a default value of
 | 
						|
        # INTERSECTING.
 | 
						|
        # If this field is specified, a metadataLocation
 | 
						|
        # must also be specified.
 | 
						|
        # Corresponds to the JSON property `locationMatchingStrategy`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :location_matching_strategy
 | 
						|
      
 | 
						|
        # Limits the selected developer metadata to those entries which are
 | 
						|
        # associated with locations of the specified type.  For example, when this
 | 
						|
        # field is specified as ROW this lookup
 | 
						|
        # only considers developer metadata associated on rows.  If the field is left
 | 
						|
        # unspecified, all location types are considered.  This field cannot be
 | 
						|
        # specified as SPREADSHEET when
 | 
						|
        # the locationMatchingStrategy
 | 
						|
        # is specified as INTERSECTING or when the
 | 
						|
        # metadataLocation is specified as a
 | 
						|
        # non-spreadsheet location: spreadsheet metadata cannot intersect any other
 | 
						|
        # developer metadata location.  This field also must be left unspecified when
 | 
						|
        # the locationMatchingStrategy
 | 
						|
        # is specified as EXACT.
 | 
						|
        # Corresponds to the JSON property `locationType`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :location_type
 | 
						|
      
 | 
						|
        # Limits the selected developer metadata to that which has a matching
 | 
						|
        # DeveloperMetadata.metadata_id.
 | 
						|
        # Corresponds to the JSON property `metadataId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :metadata_id
 | 
						|
      
 | 
						|
        # Limits the selected developer metadata to that which has a matching
 | 
						|
        # DeveloperMetadata.metadata_key.
 | 
						|
        # Corresponds to the JSON property `metadataKey`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :metadata_key
 | 
						|
      
 | 
						|
        # A location where metadata may be associated in a spreadsheet.
 | 
						|
        # Corresponds to the JSON property `metadataLocation`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeveloperMetadataLocation]
 | 
						|
        attr_accessor :metadata_location
 | 
						|
      
 | 
						|
        # Limits the selected developer metadata to that which has a matching
 | 
						|
        # DeveloperMetadata.metadata_value.
 | 
						|
        # Corresponds to the JSON property `metadataValue`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :metadata_value
 | 
						|
      
 | 
						|
        # Limits the selected developer metadata to that which has a matching
 | 
						|
        # DeveloperMetadata.visibility.  If left unspecified, all developer
 | 
						|
        # metadata visibile to the requesting project is considered.
 | 
						|
        # Corresponds to the JSON property `visibility`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :visibility
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @location_matching_strategy = args[:location_matching_strategy] if args.key?(:location_matching_strategy)
 | 
						|
          @location_type = args[:location_type] if args.key?(:location_type)
 | 
						|
          @metadata_id = args[:metadata_id] if args.key?(:metadata_id)
 | 
						|
          @metadata_key = args[:metadata_key] if args.key?(:metadata_key)
 | 
						|
          @metadata_location = args[:metadata_location] if args.key?(:metadata_location)
 | 
						|
          @metadata_value = args[:metadata_value] if args.key?(:metadata_value)
 | 
						|
          @visibility = args[:visibility] if args.key?(:visibility)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Properties about a dimension.
 | 
						|
      class DimensionProperties
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The developer metadata associated with a single row or column.
 | 
						|
        # Corresponds to the JSON property `developerMetadata`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::DeveloperMetadata>]
 | 
						|
        attr_accessor :developer_metadata
 | 
						|
      
 | 
						|
        # True if this dimension is being filtered.
 | 
						|
        # This field is read-only.
 | 
						|
        # Corresponds to the JSON property `hiddenByFilter`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :hidden_by_filter
 | 
						|
        alias_method :hidden_by_filter?, :hidden_by_filter
 | 
						|
      
 | 
						|
        # True if this dimension is explicitly hidden.
 | 
						|
        # Corresponds to the JSON property `hiddenByUser`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :hidden_by_user
 | 
						|
        alias_method :hidden_by_user?, :hidden_by_user
 | 
						|
      
 | 
						|
        # The height (if a row) or width (if a column) of the dimension in pixels.
 | 
						|
        # Corresponds to the JSON property `pixelSize`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :pixel_size
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @developer_metadata = args[:developer_metadata] if args.key?(:developer_metadata)
 | 
						|
          @hidden_by_filter = args[:hidden_by_filter] if args.key?(:hidden_by_filter)
 | 
						|
          @hidden_by_user = args[:hidden_by_user] if args.key?(:hidden_by_user)
 | 
						|
          @pixel_size = args[:pixel_size] if args.key?(:pixel_size)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A range along a single dimension on a sheet.
 | 
						|
      # All indexes are zero-based.
 | 
						|
      # Indexes are half open: the start index is inclusive
 | 
						|
      # and the end index is exclusive.
 | 
						|
      # Missing indexes indicate the range is unbounded on that side.
 | 
						|
      class DimensionRange
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The dimension of the span.
 | 
						|
        # Corresponds to the JSON property `dimension`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :dimension
 | 
						|
      
 | 
						|
        # The end (exclusive) of the span, or not set if unbounded.
 | 
						|
        # Corresponds to the JSON property `endIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :end_index
 | 
						|
      
 | 
						|
        # The sheet this span is on.
 | 
						|
        # Corresponds to the JSON property `sheetId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :sheet_id
 | 
						|
      
 | 
						|
        # The start (inclusive) of the span, or not set if unbounded.
 | 
						|
        # Corresponds to the JSON property `startIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :start_index
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @dimension = args[:dimension] if args.key?(:dimension)
 | 
						|
          @end_index = args[:end_index] if args.key?(:end_index)
 | 
						|
          @sheet_id = args[:sheet_id] if args.key?(:sheet_id)
 | 
						|
          @start_index = args[:start_index] if args.key?(:start_index)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Duplicates a particular filter view.
 | 
						|
      class DuplicateFilterViewRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The ID of the filter being duplicated.
 | 
						|
        # Corresponds to the JSON property `filterId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :filter_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @filter_id = args[:filter_id] if args.key?(:filter_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The result of a filter view being duplicated.
 | 
						|
      class DuplicateFilterViewResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A filter view.
 | 
						|
        # Corresponds to the JSON property `filter`
 | 
						|
        # @return [Google::Apis::SheetsV4::FilterView]
 | 
						|
        attr_accessor :filter
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @filter = args[:filter] if args.key?(:filter)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Duplicates the contents of a sheet.
 | 
						|
      class DuplicateSheetRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The zero-based index where the new sheet should be inserted.
 | 
						|
        # The index of all sheets after this are incremented.
 | 
						|
        # Corresponds to the JSON property `insertSheetIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :insert_sheet_index
 | 
						|
      
 | 
						|
        # If set, the ID of the new sheet. If not set, an ID is chosen.
 | 
						|
        # If set, the ID must not conflict with any existing sheet ID.
 | 
						|
        # If set, it must be non-negative.
 | 
						|
        # Corresponds to the JSON property `newSheetId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :new_sheet_id
 | 
						|
      
 | 
						|
        # The name of the new sheet.  If empty, a new name is chosen for you.
 | 
						|
        # Corresponds to the JSON property `newSheetName`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :new_sheet_name
 | 
						|
      
 | 
						|
        # The sheet to duplicate.
 | 
						|
        # Corresponds to the JSON property `sourceSheetId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :source_sheet_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @insert_sheet_index = args[:insert_sheet_index] if args.key?(:insert_sheet_index)
 | 
						|
          @new_sheet_id = args[:new_sheet_id] if args.key?(:new_sheet_id)
 | 
						|
          @new_sheet_name = args[:new_sheet_name] if args.key?(:new_sheet_name)
 | 
						|
          @source_sheet_id = args[:source_sheet_id] if args.key?(:source_sheet_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The result of duplicating a sheet.
 | 
						|
      class DuplicateSheetResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Properties of a sheet.
 | 
						|
        # Corresponds to the JSON property `properties`
 | 
						|
        # @return [Google::Apis::SheetsV4::SheetProperties]
 | 
						|
        attr_accessor :properties
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @properties = args[:properties] if args.key?(:properties)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The editors of a protected range.
 | 
						|
      class Editors
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # True if anyone in the document's domain has edit access to the protected
 | 
						|
        # range.  Domain protection is only supported on documents within a domain.
 | 
						|
        # Corresponds to the JSON property `domainUsersCanEdit`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :domain_users_can_edit
 | 
						|
        alias_method :domain_users_can_edit?, :domain_users_can_edit
 | 
						|
      
 | 
						|
        # The email addresses of groups with edit access to the protected range.
 | 
						|
        # Corresponds to the JSON property `groups`
 | 
						|
        # @return [Array<String>]
 | 
						|
        attr_accessor :groups
 | 
						|
      
 | 
						|
        # The email addresses of users with edit access to the protected range.
 | 
						|
        # Corresponds to the JSON property `users`
 | 
						|
        # @return [Array<String>]
 | 
						|
        attr_accessor :users
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @domain_users_can_edit = args[:domain_users_can_edit] if args.key?(:domain_users_can_edit)
 | 
						|
          @groups = args[:groups] if args.key?(:groups)
 | 
						|
          @users = args[:users] if args.key?(:users)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A chart embedded in a sheet.
 | 
						|
      class EmbeddedChart
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The ID of the chart.
 | 
						|
        # Corresponds to the JSON property `chartId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :chart_id
 | 
						|
      
 | 
						|
        # The position of an embedded object such as a chart.
 | 
						|
        # Corresponds to the JSON property `position`
 | 
						|
        # @return [Google::Apis::SheetsV4::EmbeddedObjectPosition]
 | 
						|
        attr_accessor :position
 | 
						|
      
 | 
						|
        # The specifications of a chart.
 | 
						|
        # Corresponds to the JSON property `spec`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartSpec]
 | 
						|
        attr_accessor :spec
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @chart_id = args[:chart_id] if args.key?(:chart_id)
 | 
						|
          @position = args[:position] if args.key?(:position)
 | 
						|
          @spec = args[:spec] if args.key?(:spec)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The position of an embedded object such as a chart.
 | 
						|
      class EmbeddedObjectPosition
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # If true, the embedded object will be put on a new sheet whose ID
 | 
						|
        # is chosen for you. Used only when writing.
 | 
						|
        # Corresponds to the JSON property `newSheet`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :new_sheet
 | 
						|
        alias_method :new_sheet?, :new_sheet
 | 
						|
      
 | 
						|
        # The location an object is overlaid on top of a grid.
 | 
						|
        # Corresponds to the JSON property `overlayPosition`
 | 
						|
        # @return [Google::Apis::SheetsV4::OverlayPosition]
 | 
						|
        attr_accessor :overlay_position
 | 
						|
      
 | 
						|
        # The sheet this is on. Set only if the embedded object
 | 
						|
        # is on its own sheet. Must be non-negative.
 | 
						|
        # Corresponds to the JSON property `sheetId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :sheet_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @new_sheet = args[:new_sheet] if args.key?(:new_sheet)
 | 
						|
          @overlay_position = args[:overlay_position] if args.key?(:overlay_position)
 | 
						|
          @sheet_id = args[:sheet_id] if args.key?(:sheet_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # An error in a cell.
 | 
						|
      class ErrorValue
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A message with more information about the error
 | 
						|
        # (in the spreadsheet's locale).
 | 
						|
        # Corresponds to the JSON property `message`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :message
 | 
						|
      
 | 
						|
        # The type of error.
 | 
						|
        # Corresponds to the JSON property `type`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :type
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @message = args[:message] if args.key?(:message)
 | 
						|
          @type = args[:type] if args.key?(:type)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The kinds of value that a cell in a spreadsheet can have.
 | 
						|
      class ExtendedValue
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Represents a boolean value.
 | 
						|
        # Corresponds to the JSON property `boolValue`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :bool_value
 | 
						|
        alias_method :bool_value?, :bool_value
 | 
						|
      
 | 
						|
        # An error in a cell.
 | 
						|
        # Corresponds to the JSON property `errorValue`
 | 
						|
        # @return [Google::Apis::SheetsV4::ErrorValue]
 | 
						|
        attr_accessor :error_value
 | 
						|
      
 | 
						|
        # Represents a formula.
 | 
						|
        # Corresponds to the JSON property `formulaValue`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :formula_value
 | 
						|
      
 | 
						|
        # Represents a double value.
 | 
						|
        # Note: Dates, Times and DateTimes are represented as doubles in
 | 
						|
        # "serial number" format.
 | 
						|
        # Corresponds to the JSON property `numberValue`
 | 
						|
        # @return [Float]
 | 
						|
        attr_accessor :number_value
 | 
						|
      
 | 
						|
        # Represents a string value.
 | 
						|
        # Leading single quotes are not included. For example, if the user typed
 | 
						|
        # `'123` into the UI, this would be represented as a `stringValue` of
 | 
						|
        # `"123"`.
 | 
						|
        # Corresponds to the JSON property `stringValue`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :string_value
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @bool_value = args[:bool_value] if args.key?(:bool_value)
 | 
						|
          @error_value = args[:error_value] if args.key?(:error_value)
 | 
						|
          @formula_value = args[:formula_value] if args.key?(:formula_value)
 | 
						|
          @number_value = args[:number_value] if args.key?(:number_value)
 | 
						|
          @string_value = args[:string_value] if args.key?(:string_value)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Criteria for showing/hiding rows in a filter or filter view.
 | 
						|
      class FilterCriteria
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A condition that can evaluate to true or false.
 | 
						|
        # BooleanConditions are used by conditional formatting,
 | 
						|
        # data validation, and the criteria in filters.
 | 
						|
        # Corresponds to the JSON property `condition`
 | 
						|
        # @return [Google::Apis::SheetsV4::BooleanCondition]
 | 
						|
        attr_accessor :condition
 | 
						|
      
 | 
						|
        # Values that should be hidden.
 | 
						|
        # Corresponds to the JSON property `hiddenValues`
 | 
						|
        # @return [Array<String>]
 | 
						|
        attr_accessor :hidden_values
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @condition = args[:condition] if args.key?(:condition)
 | 
						|
          @hidden_values = args[:hidden_values] if args.key?(:hidden_values)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A filter view.
 | 
						|
      class FilterView
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The criteria for showing/hiding values per column.
 | 
						|
        # The map's key is the column index, and the value is the criteria for
 | 
						|
        # that column.
 | 
						|
        # Corresponds to the JSON property `criteria`
 | 
						|
        # @return [Hash<String,Google::Apis::SheetsV4::FilterCriteria>]
 | 
						|
        attr_accessor :criteria
 | 
						|
      
 | 
						|
        # The ID of the filter view.
 | 
						|
        # Corresponds to the JSON property `filterViewId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :filter_view_id
 | 
						|
      
 | 
						|
        # The named range this filter view is backed by, if any.
 | 
						|
        # When writing, only one of range or named_range_id
 | 
						|
        # may be set.
 | 
						|
        # Corresponds to the JSON property `namedRangeId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :named_range_id
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        # The sort order per column. Later specifications are used when values
 | 
						|
        # are equal in the earlier specifications.
 | 
						|
        # Corresponds to the JSON property `sortSpecs`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::SortSpec>]
 | 
						|
        attr_accessor :sort_specs
 | 
						|
      
 | 
						|
        # The name of the filter view.
 | 
						|
        # Corresponds to the JSON property `title`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :title
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @criteria = args[:criteria] if args.key?(:criteria)
 | 
						|
          @filter_view_id = args[:filter_view_id] if args.key?(:filter_view_id)
 | 
						|
          @named_range_id = args[:named_range_id] if args.key?(:named_range_id)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
          @sort_specs = args[:sort_specs] if args.key?(:sort_specs)
 | 
						|
          @title = args[:title] if args.key?(:title)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Finds and replaces data in cells over a range, sheet, or all sheets.
 | 
						|
      class FindReplaceRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # True to find/replace over all sheets.
 | 
						|
        # Corresponds to the JSON property `allSheets`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :all_sheets
 | 
						|
        alias_method :all_sheets?, :all_sheets
 | 
						|
      
 | 
						|
        # The value to search.
 | 
						|
        # Corresponds to the JSON property `find`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :find
 | 
						|
      
 | 
						|
        # True if the search should include cells with formulas.
 | 
						|
        # False to skip cells with formulas.
 | 
						|
        # Corresponds to the JSON property `includeFormulas`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :include_formulas
 | 
						|
        alias_method :include_formulas?, :include_formulas
 | 
						|
      
 | 
						|
        # True if the search is case sensitive.
 | 
						|
        # Corresponds to the JSON property `matchCase`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :match_case
 | 
						|
        alias_method :match_case?, :match_case
 | 
						|
      
 | 
						|
        # True if the find value should match the entire cell.
 | 
						|
        # Corresponds to the JSON property `matchEntireCell`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :match_entire_cell
 | 
						|
        alias_method :match_entire_cell?, :match_entire_cell
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        # The value to use as the replacement.
 | 
						|
        # Corresponds to the JSON property `replacement`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :replacement
 | 
						|
      
 | 
						|
        # True if the find value is a regex.
 | 
						|
        # The regular expression and replacement should follow Java regex rules
 | 
						|
        # at https://docs.oracle.com/javase/8/docs/api/java/util/regex/Pattern.html.
 | 
						|
        # The replacement string is allowed to refer to capturing groups.
 | 
						|
        # For example, if one cell has the contents `"Google Sheets"` and another
 | 
						|
        # has `"Google Docs"`, then searching for `"o.* (.*)"` with a replacement of
 | 
						|
        # `"$1 Rocks"` would change the contents of the cells to
 | 
						|
        # `"GSheets Rocks"` and `"GDocs Rocks"` respectively.
 | 
						|
        # Corresponds to the JSON property `searchByRegex`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :search_by_regex
 | 
						|
        alias_method :search_by_regex?, :search_by_regex
 | 
						|
      
 | 
						|
        # The sheet to find/replace over.
 | 
						|
        # Corresponds to the JSON property `sheetId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :sheet_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @all_sheets = args[:all_sheets] if args.key?(:all_sheets)
 | 
						|
          @find = args[:find] if args.key?(:find)
 | 
						|
          @include_formulas = args[:include_formulas] if args.key?(:include_formulas)
 | 
						|
          @match_case = args[:match_case] if args.key?(:match_case)
 | 
						|
          @match_entire_cell = args[:match_entire_cell] if args.key?(:match_entire_cell)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
          @replacement = args[:replacement] if args.key?(:replacement)
 | 
						|
          @search_by_regex = args[:search_by_regex] if args.key?(:search_by_regex)
 | 
						|
          @sheet_id = args[:sheet_id] if args.key?(:sheet_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The result of the find/replace.
 | 
						|
      class FindReplaceResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The number of formula cells changed.
 | 
						|
        # Corresponds to the JSON property `formulasChanged`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :formulas_changed
 | 
						|
      
 | 
						|
        # The number of occurrences (possibly multiple within a cell) changed.
 | 
						|
        # For example, if replacing `"e"` with `"o"` in `"Google Sheets"`, this would
 | 
						|
        # be `"3"` because `"Google Sheets"` -> `"Googlo Shoots"`.
 | 
						|
        # Corresponds to the JSON property `occurrencesChanged`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :occurrences_changed
 | 
						|
      
 | 
						|
        # The number of rows changed.
 | 
						|
        # Corresponds to the JSON property `rowsChanged`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :rows_changed
 | 
						|
      
 | 
						|
        # The number of sheets changed.
 | 
						|
        # Corresponds to the JSON property `sheetsChanged`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :sheets_changed
 | 
						|
      
 | 
						|
        # The number of non-formula cells changed.
 | 
						|
        # Corresponds to the JSON property `valuesChanged`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :values_changed
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @formulas_changed = args[:formulas_changed] if args.key?(:formulas_changed)
 | 
						|
          @occurrences_changed = args[:occurrences_changed] if args.key?(:occurrences_changed)
 | 
						|
          @rows_changed = args[:rows_changed] if args.key?(:rows_changed)
 | 
						|
          @sheets_changed = args[:sheets_changed] if args.key?(:sheets_changed)
 | 
						|
          @values_changed = args[:values_changed] if args.key?(:values_changed)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The request for retrieving a Spreadsheet.
 | 
						|
      class GetSpreadsheetByDataFilterRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The DataFilters used to select which ranges to retrieve from
 | 
						|
        # the spreadsheet.
 | 
						|
        # Corresponds to the JSON property `dataFilters`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::DataFilter>]
 | 
						|
        attr_accessor :data_filters
 | 
						|
      
 | 
						|
        # True if grid data should be returned.
 | 
						|
        # This parameter is ignored if a field mask was set in the request.
 | 
						|
        # Corresponds to the JSON property `includeGridData`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :include_grid_data
 | 
						|
        alias_method :include_grid_data?, :include_grid_data
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data_filters = args[:data_filters] if args.key?(:data_filters)
 | 
						|
          @include_grid_data = args[:include_grid_data] if args.key?(:include_grid_data)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A rule that applies a gradient color scale format, based on
 | 
						|
      # the interpolation points listed. The format of a cell will vary
 | 
						|
      # based on its contents as compared to the values of the interpolation
 | 
						|
      # points.
 | 
						|
      class GradientRule
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A single interpolation point on a gradient conditional format.
 | 
						|
        # These pin the gradient color scale according to the color,
 | 
						|
        # type and value chosen.
 | 
						|
        # Corresponds to the JSON property `maxpoint`
 | 
						|
        # @return [Google::Apis::SheetsV4::InterpolationPoint]
 | 
						|
        attr_accessor :maxpoint
 | 
						|
      
 | 
						|
        # A single interpolation point on a gradient conditional format.
 | 
						|
        # These pin the gradient color scale according to the color,
 | 
						|
        # type and value chosen.
 | 
						|
        # Corresponds to the JSON property `midpoint`
 | 
						|
        # @return [Google::Apis::SheetsV4::InterpolationPoint]
 | 
						|
        attr_accessor :midpoint
 | 
						|
      
 | 
						|
        # A single interpolation point on a gradient conditional format.
 | 
						|
        # These pin the gradient color scale according to the color,
 | 
						|
        # type and value chosen.
 | 
						|
        # Corresponds to the JSON property `minpoint`
 | 
						|
        # @return [Google::Apis::SheetsV4::InterpolationPoint]
 | 
						|
        attr_accessor :minpoint
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @maxpoint = args[:maxpoint] if args.key?(:maxpoint)
 | 
						|
          @midpoint = args[:midpoint] if args.key?(:midpoint)
 | 
						|
          @minpoint = args[:minpoint] if args.key?(:minpoint)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A coordinate in a sheet.
 | 
						|
      # All indexes are zero-based.
 | 
						|
      class GridCoordinate
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The column index of the coordinate.
 | 
						|
        # Corresponds to the JSON property `columnIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :column_index
 | 
						|
      
 | 
						|
        # The row index of the coordinate.
 | 
						|
        # Corresponds to the JSON property `rowIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :row_index
 | 
						|
      
 | 
						|
        # The sheet this coordinate is on.
 | 
						|
        # Corresponds to the JSON property `sheetId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :sheet_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @column_index = args[:column_index] if args.key?(:column_index)
 | 
						|
          @row_index = args[:row_index] if args.key?(:row_index)
 | 
						|
          @sheet_id = args[:sheet_id] if args.key?(:sheet_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Data in the grid, as well as metadata about the dimensions.
 | 
						|
      class GridData
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Metadata about the requested columns in the grid, starting with the column
 | 
						|
        # in start_column.
 | 
						|
        # Corresponds to the JSON property `columnMetadata`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::DimensionProperties>]
 | 
						|
        attr_accessor :column_metadata
 | 
						|
      
 | 
						|
        # The data in the grid, one entry per row,
 | 
						|
        # starting with the row in startRow.
 | 
						|
        # The values in RowData will correspond to columns starting
 | 
						|
        # at start_column.
 | 
						|
        # Corresponds to the JSON property `rowData`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::RowData>]
 | 
						|
        attr_accessor :row_data
 | 
						|
      
 | 
						|
        # Metadata about the requested rows in the grid, starting with the row
 | 
						|
        # in start_row.
 | 
						|
        # Corresponds to the JSON property `rowMetadata`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::DimensionProperties>]
 | 
						|
        attr_accessor :row_metadata
 | 
						|
      
 | 
						|
        # The first column this GridData refers to, zero-based.
 | 
						|
        # Corresponds to the JSON property `startColumn`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :start_column
 | 
						|
      
 | 
						|
        # The first row this GridData refers to, zero-based.
 | 
						|
        # Corresponds to the JSON property `startRow`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :start_row
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @column_metadata = args[:column_metadata] if args.key?(:column_metadata)
 | 
						|
          @row_data = args[:row_data] if args.key?(:row_data)
 | 
						|
          @row_metadata = args[:row_metadata] if args.key?(:row_metadata)
 | 
						|
          @start_column = args[:start_column] if args.key?(:start_column)
 | 
						|
          @start_row = args[:start_row] if args.key?(:start_row)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Properties of a grid.
 | 
						|
      class GridProperties
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The number of columns in the grid.
 | 
						|
        # Corresponds to the JSON property `columnCount`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :column_count
 | 
						|
      
 | 
						|
        # The number of columns that are frozen in the grid.
 | 
						|
        # Corresponds to the JSON property `frozenColumnCount`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :frozen_column_count
 | 
						|
      
 | 
						|
        # The number of rows that are frozen in the grid.
 | 
						|
        # Corresponds to the JSON property `frozenRowCount`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :frozen_row_count
 | 
						|
      
 | 
						|
        # True if the grid isn't showing gridlines in the UI.
 | 
						|
        # Corresponds to the JSON property `hideGridlines`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :hide_gridlines
 | 
						|
        alias_method :hide_gridlines?, :hide_gridlines
 | 
						|
      
 | 
						|
        # The number of rows in the grid.
 | 
						|
        # Corresponds to the JSON property `rowCount`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :row_count
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @column_count = args[:column_count] if args.key?(:column_count)
 | 
						|
          @frozen_column_count = args[:frozen_column_count] if args.key?(:frozen_column_count)
 | 
						|
          @frozen_row_count = args[:frozen_row_count] if args.key?(:frozen_row_count)
 | 
						|
          @hide_gridlines = args[:hide_gridlines] if args.key?(:hide_gridlines)
 | 
						|
          @row_count = args[:row_count] if args.key?(:row_count)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A range on a sheet.
 | 
						|
      # All indexes are zero-based.
 | 
						|
      # Indexes are half open, e.g the start index is inclusive
 | 
						|
      # and the end index is exclusive -- [start_index, end_index).
 | 
						|
      # Missing indexes indicate the range is unbounded on that side.
 | 
						|
      # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
      # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
      # start_row_index: 0, end_row_index: 1,
 | 
						|
      # start_column_index: 0, end_column_index: 1`
 | 
						|
      # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
      # start_row_index: 2, end_row_index: 4,
 | 
						|
      # start_column_index: 0, end_column_index: 2`
 | 
						|
      # `Sheet1!A:B == sheet_id: 0,
 | 
						|
      # start_column_index: 0, end_column_index: 2`
 | 
						|
      # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
      # start_row_index: 4,
 | 
						|
      # start_column_index: 0, end_column_index: 2`
 | 
						|
      # `Sheet1 == sheet_id:0`
 | 
						|
      # The start index must always be less than or equal to the end index.
 | 
						|
      # If the start index equals the end index, then the range is empty.
 | 
						|
      # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
      # UI as `#REF!`.
 | 
						|
      class GridRange
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The end column (exclusive) of the range, or not set if unbounded.
 | 
						|
        # Corresponds to the JSON property `endColumnIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :end_column_index
 | 
						|
      
 | 
						|
        # The end row (exclusive) of the range, or not set if unbounded.
 | 
						|
        # Corresponds to the JSON property `endRowIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :end_row_index
 | 
						|
      
 | 
						|
        # The sheet this range is on.
 | 
						|
        # Corresponds to the JSON property `sheetId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :sheet_id
 | 
						|
      
 | 
						|
        # The start column (inclusive) of the range, or not set if unbounded.
 | 
						|
        # Corresponds to the JSON property `startColumnIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :start_column_index
 | 
						|
      
 | 
						|
        # The start row (inclusive) of the range, or not set if unbounded.
 | 
						|
        # Corresponds to the JSON property `startRowIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :start_row_index
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @end_column_index = args[:end_column_index] if args.key?(:end_column_index)
 | 
						|
          @end_row_index = args[:end_row_index] if args.key?(:end_row_index)
 | 
						|
          @sheet_id = args[:sheet_id] if args.key?(:sheet_id)
 | 
						|
          @start_column_index = args[:start_column_index] if args.key?(:start_column_index)
 | 
						|
          @start_row_index = args[:start_row_index] if args.key?(:start_row_index)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A <a href="/chart/interactive/docs/gallery/histogram">histogram chart</a>.
 | 
						|
      # A histogram chart groups data items into bins, displaying each bin as a
 | 
						|
      # column of stacked items.  Histograms are used to display the distribution
 | 
						|
      # of a dataset.  Each column of items represents a range into which those
 | 
						|
      # items fall.  The number of bins can be chosen automatically or specified
 | 
						|
      # explicitly.
 | 
						|
      class HistogramChartSpec
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # By default the bucket size (the range of values stacked in a single
 | 
						|
        # column) is chosen automatically, but it may be overridden here.
 | 
						|
        # E.g., A bucket size of 1.5 results in buckets from 0 - 1.5, 1.5 - 3.0, etc.
 | 
						|
        # Cannot be negative.
 | 
						|
        # This field is optional.
 | 
						|
        # Corresponds to the JSON property `bucketSize`
 | 
						|
        # @return [Float]
 | 
						|
        attr_accessor :bucket_size
 | 
						|
      
 | 
						|
        # The position of the chart legend.
 | 
						|
        # Corresponds to the JSON property `legendPosition`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :legend_position
 | 
						|
      
 | 
						|
        # The outlier percentile is used to ensure that outliers do not adversely
 | 
						|
        # affect the calculation of bucket sizes.  For example, setting an outlier
 | 
						|
        # percentile of 0.05 indicates that the top and bottom 5% of values when
 | 
						|
        # calculating buckets.  The values are still included in the chart, they will
 | 
						|
        # be added to the first or last buckets instead of their own buckets.
 | 
						|
        # Must be between 0.0 and 0.5.
 | 
						|
        # Corresponds to the JSON property `outlierPercentile`
 | 
						|
        # @return [Float]
 | 
						|
        attr_accessor :outlier_percentile
 | 
						|
      
 | 
						|
        # The series for a histogram may be either a single series of values to be
 | 
						|
        # bucketed or multiple series, each of the same length, containing the name
 | 
						|
        # of the series followed by the values to be bucketed for that series.
 | 
						|
        # Corresponds to the JSON property `series`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::HistogramSeries>]
 | 
						|
        attr_accessor :series
 | 
						|
      
 | 
						|
        # Whether horizontal divider lines should be displayed between items in each
 | 
						|
        # column.
 | 
						|
        # Corresponds to the JSON property `showItemDividers`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :show_item_dividers
 | 
						|
        alias_method :show_item_dividers?, :show_item_dividers
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @bucket_size = args[:bucket_size] if args.key?(:bucket_size)
 | 
						|
          @legend_position = args[:legend_position] if args.key?(:legend_position)
 | 
						|
          @outlier_percentile = args[:outlier_percentile] if args.key?(:outlier_percentile)
 | 
						|
          @series = args[:series] if args.key?(:series)
 | 
						|
          @show_item_dividers = args[:show_item_dividers] if args.key?(:show_item_dividers)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A histogram series containing the series color and data.
 | 
						|
      class HistogramSeries
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Represents a color in the RGBA color space. This representation is designed
 | 
						|
        # for simplicity of conversion to/from color representations in various
 | 
						|
        # languages over compactness; for example, the fields of this representation
 | 
						|
        # can be trivially provided to the constructor of "java.awt.Color" in Java; it
 | 
						|
        # can also be trivially provided to UIColor's "+colorWithRed:green:blue:alpha"
 | 
						|
        # method in iOS; and, with just a little work, it can be easily formatted into
 | 
						|
        # a CSS "rgba()" string in JavaScript, as well. Here are some examples:
 | 
						|
        # Example (Java):
 | 
						|
        # import com.google.type.Color;
 | 
						|
        # // ...
 | 
						|
        # public static java.awt.Color fromProto(Color protocolor) `
 | 
						|
        # float alpha = protocolor.hasAlpha()
 | 
						|
        # ? protocolor.getAlpha().getValue()
 | 
						|
        # : 1.0;
 | 
						|
        # return new java.awt.Color(
 | 
						|
        # protocolor.getRed(),
 | 
						|
        # protocolor.getGreen(),
 | 
						|
        # protocolor.getBlue(),
 | 
						|
        # alpha);
 | 
						|
        # `
 | 
						|
        # public static Color toProto(java.awt.Color color) `
 | 
						|
        # float red = (float) color.getRed();
 | 
						|
        # float green = (float) color.getGreen();
 | 
						|
        # float blue = (float) color.getBlue();
 | 
						|
        # float denominator = 255.0;
 | 
						|
        # Color.Builder resultBuilder =
 | 
						|
        # Color
 | 
						|
        # .newBuilder()
 | 
						|
        # .setRed(red / denominator)
 | 
						|
        # .setGreen(green / denominator)
 | 
						|
        # .setBlue(blue / denominator);
 | 
						|
        # int alpha = color.getAlpha();
 | 
						|
        # if (alpha != 255) `
 | 
						|
        # result.setAlpha(
 | 
						|
        # FloatValue
 | 
						|
        # .newBuilder()
 | 
						|
        # .setValue(((float) alpha) / denominator)
 | 
						|
        # .build());
 | 
						|
        # `
 | 
						|
        # return resultBuilder.build();
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (iOS / Obj-C):
 | 
						|
        # // ...
 | 
						|
        # static UIColor* fromProto(Color* protocolor) `
 | 
						|
        # float red = [protocolor red];
 | 
						|
        # float green = [protocolor green];
 | 
						|
        # float blue = [protocolor blue];
 | 
						|
        # FloatValue* alpha_wrapper = [protocolor alpha];
 | 
						|
        # float alpha = 1.0;
 | 
						|
        # if (alpha_wrapper != nil) `
 | 
						|
        # alpha = [alpha_wrapper value];
 | 
						|
        # `
 | 
						|
        # return [UIColor colorWithRed:red green:green blue:blue alpha:alpha];
 | 
						|
        # `
 | 
						|
        # static Color* toProto(UIColor* color) `
 | 
						|
        # CGFloat red, green, blue, alpha;
 | 
						|
        # if (![color getRed:&red green:&green blue:&blue alpha:&alpha]) `
 | 
						|
        # return nil;
 | 
						|
        # `
 | 
						|
        # Color* result = [Color alloc] init];
 | 
						|
        # [result setRed:red];
 | 
						|
        # [result setGreen:green];
 | 
						|
        # [result setBlue:blue];
 | 
						|
        # if (alpha <= 0.9999) `
 | 
						|
        # [result setAlpha:floatWrapperWithValue(alpha)];
 | 
						|
        # `
 | 
						|
        # [result autorelease];
 | 
						|
        # return result;
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (JavaScript):
 | 
						|
        # // ...
 | 
						|
        # var protoToCssColor = function(rgb_color) `
 | 
						|
        # var redFrac = rgb_color.red || 0.0;
 | 
						|
        # var greenFrac = rgb_color.green || 0.0;
 | 
						|
        # var blueFrac = rgb_color.blue || 0.0;
 | 
						|
        # var red = Math.floor(redFrac * 255);
 | 
						|
        # var green = Math.floor(greenFrac * 255);
 | 
						|
        # var blue = Math.floor(blueFrac * 255);
 | 
						|
        # if (!('alpha' in rgb_color)) `
 | 
						|
        # return rgbToCssColor_(red, green, blue);
 | 
						|
        # `
 | 
						|
        # var alphaFrac = rgb_color.alpha.value || 0.0;
 | 
						|
        # var rgbParams = [red, green, blue].join(',');
 | 
						|
        # return ['rgba(', rgbParams, ',', alphaFrac, ')'].join('');
 | 
						|
        # `;
 | 
						|
        # var rgbToCssColor_ = function(red, green, blue) `
 | 
						|
        # var rgbNumber = new Number((red << 16) | (green << 8) | blue);
 | 
						|
        # var hexString = rgbNumber.toString(16);
 | 
						|
        # var missingZeros = 6 - hexString.length;
 | 
						|
        # var resultBuilder = ['#'];
 | 
						|
        # for (var i = 0; i < missingZeros; i++) `
 | 
						|
        # resultBuilder.push('0');
 | 
						|
        # `
 | 
						|
        # resultBuilder.push(hexString);
 | 
						|
        # return resultBuilder.join('');
 | 
						|
        # `;
 | 
						|
        # // ...
 | 
						|
        # Corresponds to the JSON property `barColor`
 | 
						|
        # @return [Google::Apis::SheetsV4::Color]
 | 
						|
        attr_accessor :bar_color
 | 
						|
      
 | 
						|
        # The data included in a domain or series.
 | 
						|
        # Corresponds to the JSON property `data`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartData]
 | 
						|
        attr_accessor :data
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @bar_color = args[:bar_color] if args.key?(:bar_color)
 | 
						|
          @data = args[:data] if args.key?(:data)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Inserts rows or columns in a sheet at a particular index.
 | 
						|
      class InsertDimensionRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Whether dimension properties should be extended from the dimensions
 | 
						|
        # before or after the newly inserted dimensions.
 | 
						|
        # True to inherit from the dimensions before (in which case the start
 | 
						|
        # index must be greater than 0), and false to inherit from the dimensions
 | 
						|
        # after.
 | 
						|
        # For example, if row index 0 has red background and row index 1
 | 
						|
        # has a green background, then inserting 2 rows at index 1 can inherit
 | 
						|
        # either the green or red background.  If `inheritFromBefore` is true,
 | 
						|
        # the two new rows will be red (because the row before the insertion point
 | 
						|
        # was red), whereas if `inheritFromBefore` is false, the two new rows will
 | 
						|
        # be green (because the row after the insertion point was green).
 | 
						|
        # Corresponds to the JSON property `inheritFromBefore`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :inherit_from_before
 | 
						|
        alias_method :inherit_from_before?, :inherit_from_before
 | 
						|
      
 | 
						|
        # A range along a single dimension on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open: the start index is inclusive
 | 
						|
        # and the end index is exclusive.
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::DimensionRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @inherit_from_before = args[:inherit_from_before] if args.key?(:inherit_from_before)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Inserts cells into a range, shifting the existing cells over or down.
 | 
						|
      class InsertRangeRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        # The dimension which will be shifted when inserting cells.
 | 
						|
        # If ROWS, existing cells will be shifted down.
 | 
						|
        # If COLUMNS, existing cells will be shifted right.
 | 
						|
        # Corresponds to the JSON property `shiftDimension`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :shift_dimension
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
          @shift_dimension = args[:shift_dimension] if args.key?(:shift_dimension)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A single interpolation point on a gradient conditional format.
 | 
						|
      # These pin the gradient color scale according to the color,
 | 
						|
      # type and value chosen.
 | 
						|
      class InterpolationPoint
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Represents a color in the RGBA color space. This representation is designed
 | 
						|
        # for simplicity of conversion to/from color representations in various
 | 
						|
        # languages over compactness; for example, the fields of this representation
 | 
						|
        # can be trivially provided to the constructor of "java.awt.Color" in Java; it
 | 
						|
        # can also be trivially provided to UIColor's "+colorWithRed:green:blue:alpha"
 | 
						|
        # method in iOS; and, with just a little work, it can be easily formatted into
 | 
						|
        # a CSS "rgba()" string in JavaScript, as well. Here are some examples:
 | 
						|
        # Example (Java):
 | 
						|
        # import com.google.type.Color;
 | 
						|
        # // ...
 | 
						|
        # public static java.awt.Color fromProto(Color protocolor) `
 | 
						|
        # float alpha = protocolor.hasAlpha()
 | 
						|
        # ? protocolor.getAlpha().getValue()
 | 
						|
        # : 1.0;
 | 
						|
        # return new java.awt.Color(
 | 
						|
        # protocolor.getRed(),
 | 
						|
        # protocolor.getGreen(),
 | 
						|
        # protocolor.getBlue(),
 | 
						|
        # alpha);
 | 
						|
        # `
 | 
						|
        # public static Color toProto(java.awt.Color color) `
 | 
						|
        # float red = (float) color.getRed();
 | 
						|
        # float green = (float) color.getGreen();
 | 
						|
        # float blue = (float) color.getBlue();
 | 
						|
        # float denominator = 255.0;
 | 
						|
        # Color.Builder resultBuilder =
 | 
						|
        # Color
 | 
						|
        # .newBuilder()
 | 
						|
        # .setRed(red / denominator)
 | 
						|
        # .setGreen(green / denominator)
 | 
						|
        # .setBlue(blue / denominator);
 | 
						|
        # int alpha = color.getAlpha();
 | 
						|
        # if (alpha != 255) `
 | 
						|
        # result.setAlpha(
 | 
						|
        # FloatValue
 | 
						|
        # .newBuilder()
 | 
						|
        # .setValue(((float) alpha) / denominator)
 | 
						|
        # .build());
 | 
						|
        # `
 | 
						|
        # return resultBuilder.build();
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (iOS / Obj-C):
 | 
						|
        # // ...
 | 
						|
        # static UIColor* fromProto(Color* protocolor) `
 | 
						|
        # float red = [protocolor red];
 | 
						|
        # float green = [protocolor green];
 | 
						|
        # float blue = [protocolor blue];
 | 
						|
        # FloatValue* alpha_wrapper = [protocolor alpha];
 | 
						|
        # float alpha = 1.0;
 | 
						|
        # if (alpha_wrapper != nil) `
 | 
						|
        # alpha = [alpha_wrapper value];
 | 
						|
        # `
 | 
						|
        # return [UIColor colorWithRed:red green:green blue:blue alpha:alpha];
 | 
						|
        # `
 | 
						|
        # static Color* toProto(UIColor* color) `
 | 
						|
        # CGFloat red, green, blue, alpha;
 | 
						|
        # if (![color getRed:&red green:&green blue:&blue alpha:&alpha]) `
 | 
						|
        # return nil;
 | 
						|
        # `
 | 
						|
        # Color* result = [Color alloc] init];
 | 
						|
        # [result setRed:red];
 | 
						|
        # [result setGreen:green];
 | 
						|
        # [result setBlue:blue];
 | 
						|
        # if (alpha <= 0.9999) `
 | 
						|
        # [result setAlpha:floatWrapperWithValue(alpha)];
 | 
						|
        # `
 | 
						|
        # [result autorelease];
 | 
						|
        # return result;
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (JavaScript):
 | 
						|
        # // ...
 | 
						|
        # var protoToCssColor = function(rgb_color) `
 | 
						|
        # var redFrac = rgb_color.red || 0.0;
 | 
						|
        # var greenFrac = rgb_color.green || 0.0;
 | 
						|
        # var blueFrac = rgb_color.blue || 0.0;
 | 
						|
        # var red = Math.floor(redFrac * 255);
 | 
						|
        # var green = Math.floor(greenFrac * 255);
 | 
						|
        # var blue = Math.floor(blueFrac * 255);
 | 
						|
        # if (!('alpha' in rgb_color)) `
 | 
						|
        # return rgbToCssColor_(red, green, blue);
 | 
						|
        # `
 | 
						|
        # var alphaFrac = rgb_color.alpha.value || 0.0;
 | 
						|
        # var rgbParams = [red, green, blue].join(',');
 | 
						|
        # return ['rgba(', rgbParams, ',', alphaFrac, ')'].join('');
 | 
						|
        # `;
 | 
						|
        # var rgbToCssColor_ = function(red, green, blue) `
 | 
						|
        # var rgbNumber = new Number((red << 16) | (green << 8) | blue);
 | 
						|
        # var hexString = rgbNumber.toString(16);
 | 
						|
        # var missingZeros = 6 - hexString.length;
 | 
						|
        # var resultBuilder = ['#'];
 | 
						|
        # for (var i = 0; i < missingZeros; i++) `
 | 
						|
        # resultBuilder.push('0');
 | 
						|
        # `
 | 
						|
        # resultBuilder.push(hexString);
 | 
						|
        # return resultBuilder.join('');
 | 
						|
        # `;
 | 
						|
        # // ...
 | 
						|
        # Corresponds to the JSON property `color`
 | 
						|
        # @return [Google::Apis::SheetsV4::Color]
 | 
						|
        attr_accessor :color
 | 
						|
      
 | 
						|
        # How the value should be interpreted.
 | 
						|
        # Corresponds to the JSON property `type`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :type
 | 
						|
      
 | 
						|
        # The value this interpolation point uses.  May be a formula.
 | 
						|
        # Unused if type is MIN or
 | 
						|
        # MAX.
 | 
						|
        # Corresponds to the JSON property `value`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :value
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @color = args[:color] if args.key?(:color)
 | 
						|
          @type = args[:type] if args.key?(:type)
 | 
						|
          @value = args[:value] if args.key?(:value)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Settings to control how circular dependencies are resolved with iterative
 | 
						|
      # calculation.
 | 
						|
      class IterativeCalculationSettings
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # When iterative calculation is enabled and successive results differ by
 | 
						|
        # less than this threshold value, the calculation rounds stop.
 | 
						|
        # Corresponds to the JSON property `convergenceThreshold`
 | 
						|
        # @return [Float]
 | 
						|
        attr_accessor :convergence_threshold
 | 
						|
      
 | 
						|
        # When iterative calculation is enabled, the maximum number of calculation
 | 
						|
        # rounds to perform.
 | 
						|
        # Corresponds to the JSON property `maxIterations`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :max_iterations
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @convergence_threshold = args[:convergence_threshold] if args.key?(:convergence_threshold)
 | 
						|
          @max_iterations = args[:max_iterations] if args.key?(:max_iterations)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Properties that describe the style of a line.
 | 
						|
      class LineStyle
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The dash type of the line.
 | 
						|
        # Corresponds to the JSON property `type`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :type
 | 
						|
      
 | 
						|
        # The thickness of the line, in px.
 | 
						|
        # Corresponds to the JSON property `width`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :width
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @type = args[:type] if args.key?(:type)
 | 
						|
          @width = args[:width] if args.key?(:width)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A developer metadata entry and the data filters specified in the original
 | 
						|
      # request that matched it.
 | 
						|
      class MatchedDeveloperMetadata
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # All filters matching the returned developer metadata.
 | 
						|
        # Corresponds to the JSON property `dataFilters`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::DataFilter>]
 | 
						|
        attr_accessor :data_filters
 | 
						|
      
 | 
						|
        # Developer metadata associated with a location or object in a spreadsheet.
 | 
						|
        # Developer metadata may be used to associate arbitrary data with various
 | 
						|
        # parts of a spreadsheet and will remain associated at those locations as they
 | 
						|
        # move around and the spreadsheet is edited.  For example, if developer
 | 
						|
        # metadata is associated with row 5 and another row is then subsequently
 | 
						|
        # inserted above row 5, that original metadata will still be associated with
 | 
						|
        # the row it was first associated with (what is now row 6). If the associated
 | 
						|
        # object is deleted its metadata will be deleted too.
 | 
						|
        # Corresponds to the JSON property `developerMetadata`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeveloperMetadata]
 | 
						|
        attr_accessor :developer_metadata
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data_filters = args[:data_filters] if args.key?(:data_filters)
 | 
						|
          @developer_metadata = args[:developer_metadata] if args.key?(:developer_metadata)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A value range that was matched by one or more data filers.
 | 
						|
      class MatchedValueRange
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The DataFilters from the request that matched the range of
 | 
						|
        # values.
 | 
						|
        # Corresponds to the JSON property `dataFilters`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::DataFilter>]
 | 
						|
        attr_accessor :data_filters
 | 
						|
      
 | 
						|
        # Data within a range of the spreadsheet.
 | 
						|
        # Corresponds to the JSON property `valueRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::ValueRange]
 | 
						|
        attr_accessor :value_range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data_filters = args[:data_filters] if args.key?(:data_filters)
 | 
						|
          @value_range = args[:value_range] if args.key?(:value_range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Merges all cells in the range.
 | 
						|
      class MergeCellsRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # How the cells should be merged.
 | 
						|
        # Corresponds to the JSON property `mergeType`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :merge_type
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @merge_type = args[:merge_type] if args.key?(:merge_type)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Moves one or more rows or columns.
 | 
						|
      class MoveDimensionRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The zero-based start index of where to move the source data to,
 | 
						|
        # based on the coordinates *before* the source data is removed
 | 
						|
        # from the grid.  Existing data will be shifted down or right
 | 
						|
        # (depending on the dimension) to make room for the moved dimensions.
 | 
						|
        # The source dimensions are removed from the grid, so the
 | 
						|
        # the data may end up in a different index than specified.
 | 
						|
        # For example, given `A1..A5` of `0, 1, 2, 3, 4` and wanting to move
 | 
						|
        # `"1"` and `"2"` to between `"3"` and `"4"`, the source would be
 | 
						|
        # `ROWS [1..3)`,and the destination index would be `"4"`
 | 
						|
        # (the zero-based index of row 5).
 | 
						|
        # The end result would be `A1..A5` of `0, 3, 1, 2, 4`.
 | 
						|
        # Corresponds to the JSON property `destinationIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :destination_index
 | 
						|
      
 | 
						|
        # A range along a single dimension on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open: the start index is inclusive
 | 
						|
        # and the end index is exclusive.
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # Corresponds to the JSON property `source`
 | 
						|
        # @return [Google::Apis::SheetsV4::DimensionRange]
 | 
						|
        attr_accessor :source
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @destination_index = args[:destination_index] if args.key?(:destination_index)
 | 
						|
          @source = args[:source] if args.key?(:source)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A named range.
 | 
						|
      class NamedRange
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The name of the named range.
 | 
						|
        # Corresponds to the JSON property `name`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :name
 | 
						|
      
 | 
						|
        # The ID of the named range.
 | 
						|
        # Corresponds to the JSON property `namedRangeId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :named_range_id
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @name = args[:name] if args.key?(:name)
 | 
						|
          @named_range_id = args[:named_range_id] if args.key?(:named_range_id)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The number format of a cell.
 | 
						|
      class NumberFormat
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Pattern string used for formatting.  If not set, a default pattern based on
 | 
						|
        # the user's locale will be used if necessary for the given type.
 | 
						|
        # See the [Date and Number Formats guide](/sheets/api/guides/formats) for more
 | 
						|
        # information about the supported patterns.
 | 
						|
        # Corresponds to the JSON property `pattern`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :pattern
 | 
						|
      
 | 
						|
        # The type of the number format.
 | 
						|
        # When writing, this field must be set.
 | 
						|
        # Corresponds to the JSON property `type`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :type
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @pattern = args[:pattern] if args.key?(:pattern)
 | 
						|
          @type = args[:type] if args.key?(:type)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # An <a href="/chart/interactive/docs/gallery/orgchart">org chart</a>.
 | 
						|
      # Org charts require a unique set of labels in labels and may
 | 
						|
      # optionally include parent_labels and tooltips.
 | 
						|
      # parent_labels contain, for each node, the label identifying the parent
 | 
						|
      # node.  tooltips contain, for each node, an optional tooltip.
 | 
						|
      # For example, to describe an OrgChart with Alice as the CEO, Bob as the
 | 
						|
      # President (reporting to Alice) and Cathy as VP of Sales (also reporting to
 | 
						|
      # Alice), have labels contain "Alice", "Bob", "Cathy",
 | 
						|
      # parent_labels contain "", "Alice", "Alice" and tooltips contain
 | 
						|
      # "CEO", "President", "VP Sales".
 | 
						|
      class OrgChartSpec
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The data included in a domain or series.
 | 
						|
        # Corresponds to the JSON property `labels`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartData]
 | 
						|
        attr_accessor :labels
 | 
						|
      
 | 
						|
        # Represents a color in the RGBA color space. This representation is designed
 | 
						|
        # for simplicity of conversion to/from color representations in various
 | 
						|
        # languages over compactness; for example, the fields of this representation
 | 
						|
        # can be trivially provided to the constructor of "java.awt.Color" in Java; it
 | 
						|
        # can also be trivially provided to UIColor's "+colorWithRed:green:blue:alpha"
 | 
						|
        # method in iOS; and, with just a little work, it can be easily formatted into
 | 
						|
        # a CSS "rgba()" string in JavaScript, as well. Here are some examples:
 | 
						|
        # Example (Java):
 | 
						|
        # import com.google.type.Color;
 | 
						|
        # // ...
 | 
						|
        # public static java.awt.Color fromProto(Color protocolor) `
 | 
						|
        # float alpha = protocolor.hasAlpha()
 | 
						|
        # ? protocolor.getAlpha().getValue()
 | 
						|
        # : 1.0;
 | 
						|
        # return new java.awt.Color(
 | 
						|
        # protocolor.getRed(),
 | 
						|
        # protocolor.getGreen(),
 | 
						|
        # protocolor.getBlue(),
 | 
						|
        # alpha);
 | 
						|
        # `
 | 
						|
        # public static Color toProto(java.awt.Color color) `
 | 
						|
        # float red = (float) color.getRed();
 | 
						|
        # float green = (float) color.getGreen();
 | 
						|
        # float blue = (float) color.getBlue();
 | 
						|
        # float denominator = 255.0;
 | 
						|
        # Color.Builder resultBuilder =
 | 
						|
        # Color
 | 
						|
        # .newBuilder()
 | 
						|
        # .setRed(red / denominator)
 | 
						|
        # .setGreen(green / denominator)
 | 
						|
        # .setBlue(blue / denominator);
 | 
						|
        # int alpha = color.getAlpha();
 | 
						|
        # if (alpha != 255) `
 | 
						|
        # result.setAlpha(
 | 
						|
        # FloatValue
 | 
						|
        # .newBuilder()
 | 
						|
        # .setValue(((float) alpha) / denominator)
 | 
						|
        # .build());
 | 
						|
        # `
 | 
						|
        # return resultBuilder.build();
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (iOS / Obj-C):
 | 
						|
        # // ...
 | 
						|
        # static UIColor* fromProto(Color* protocolor) `
 | 
						|
        # float red = [protocolor red];
 | 
						|
        # float green = [protocolor green];
 | 
						|
        # float blue = [protocolor blue];
 | 
						|
        # FloatValue* alpha_wrapper = [protocolor alpha];
 | 
						|
        # float alpha = 1.0;
 | 
						|
        # if (alpha_wrapper != nil) `
 | 
						|
        # alpha = [alpha_wrapper value];
 | 
						|
        # `
 | 
						|
        # return [UIColor colorWithRed:red green:green blue:blue alpha:alpha];
 | 
						|
        # `
 | 
						|
        # static Color* toProto(UIColor* color) `
 | 
						|
        # CGFloat red, green, blue, alpha;
 | 
						|
        # if (![color getRed:&red green:&green blue:&blue alpha:&alpha]) `
 | 
						|
        # return nil;
 | 
						|
        # `
 | 
						|
        # Color* result = [Color alloc] init];
 | 
						|
        # [result setRed:red];
 | 
						|
        # [result setGreen:green];
 | 
						|
        # [result setBlue:blue];
 | 
						|
        # if (alpha <= 0.9999) `
 | 
						|
        # [result setAlpha:floatWrapperWithValue(alpha)];
 | 
						|
        # `
 | 
						|
        # [result autorelease];
 | 
						|
        # return result;
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (JavaScript):
 | 
						|
        # // ...
 | 
						|
        # var protoToCssColor = function(rgb_color) `
 | 
						|
        # var redFrac = rgb_color.red || 0.0;
 | 
						|
        # var greenFrac = rgb_color.green || 0.0;
 | 
						|
        # var blueFrac = rgb_color.blue || 0.0;
 | 
						|
        # var red = Math.floor(redFrac * 255);
 | 
						|
        # var green = Math.floor(greenFrac * 255);
 | 
						|
        # var blue = Math.floor(blueFrac * 255);
 | 
						|
        # if (!('alpha' in rgb_color)) `
 | 
						|
        # return rgbToCssColor_(red, green, blue);
 | 
						|
        # `
 | 
						|
        # var alphaFrac = rgb_color.alpha.value || 0.0;
 | 
						|
        # var rgbParams = [red, green, blue].join(',');
 | 
						|
        # return ['rgba(', rgbParams, ',', alphaFrac, ')'].join('');
 | 
						|
        # `;
 | 
						|
        # var rgbToCssColor_ = function(red, green, blue) `
 | 
						|
        # var rgbNumber = new Number((red << 16) | (green << 8) | blue);
 | 
						|
        # var hexString = rgbNumber.toString(16);
 | 
						|
        # var missingZeros = 6 - hexString.length;
 | 
						|
        # var resultBuilder = ['#'];
 | 
						|
        # for (var i = 0; i < missingZeros; i++) `
 | 
						|
        # resultBuilder.push('0');
 | 
						|
        # `
 | 
						|
        # resultBuilder.push(hexString);
 | 
						|
        # return resultBuilder.join('');
 | 
						|
        # `;
 | 
						|
        # // ...
 | 
						|
        # Corresponds to the JSON property `nodeColor`
 | 
						|
        # @return [Google::Apis::SheetsV4::Color]
 | 
						|
        attr_accessor :node_color
 | 
						|
      
 | 
						|
        # The size of the org chart nodes.
 | 
						|
        # Corresponds to the JSON property `nodeSize`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :node_size
 | 
						|
      
 | 
						|
        # The data included in a domain or series.
 | 
						|
        # Corresponds to the JSON property `parentLabels`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartData]
 | 
						|
        attr_accessor :parent_labels
 | 
						|
      
 | 
						|
        # Represents a color in the RGBA color space. This representation is designed
 | 
						|
        # for simplicity of conversion to/from color representations in various
 | 
						|
        # languages over compactness; for example, the fields of this representation
 | 
						|
        # can be trivially provided to the constructor of "java.awt.Color" in Java; it
 | 
						|
        # can also be trivially provided to UIColor's "+colorWithRed:green:blue:alpha"
 | 
						|
        # method in iOS; and, with just a little work, it can be easily formatted into
 | 
						|
        # a CSS "rgba()" string in JavaScript, as well. Here are some examples:
 | 
						|
        # Example (Java):
 | 
						|
        # import com.google.type.Color;
 | 
						|
        # // ...
 | 
						|
        # public static java.awt.Color fromProto(Color protocolor) `
 | 
						|
        # float alpha = protocolor.hasAlpha()
 | 
						|
        # ? protocolor.getAlpha().getValue()
 | 
						|
        # : 1.0;
 | 
						|
        # return new java.awt.Color(
 | 
						|
        # protocolor.getRed(),
 | 
						|
        # protocolor.getGreen(),
 | 
						|
        # protocolor.getBlue(),
 | 
						|
        # alpha);
 | 
						|
        # `
 | 
						|
        # public static Color toProto(java.awt.Color color) `
 | 
						|
        # float red = (float) color.getRed();
 | 
						|
        # float green = (float) color.getGreen();
 | 
						|
        # float blue = (float) color.getBlue();
 | 
						|
        # float denominator = 255.0;
 | 
						|
        # Color.Builder resultBuilder =
 | 
						|
        # Color
 | 
						|
        # .newBuilder()
 | 
						|
        # .setRed(red / denominator)
 | 
						|
        # .setGreen(green / denominator)
 | 
						|
        # .setBlue(blue / denominator);
 | 
						|
        # int alpha = color.getAlpha();
 | 
						|
        # if (alpha != 255) `
 | 
						|
        # result.setAlpha(
 | 
						|
        # FloatValue
 | 
						|
        # .newBuilder()
 | 
						|
        # .setValue(((float) alpha) / denominator)
 | 
						|
        # .build());
 | 
						|
        # `
 | 
						|
        # return resultBuilder.build();
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (iOS / Obj-C):
 | 
						|
        # // ...
 | 
						|
        # static UIColor* fromProto(Color* protocolor) `
 | 
						|
        # float red = [protocolor red];
 | 
						|
        # float green = [protocolor green];
 | 
						|
        # float blue = [protocolor blue];
 | 
						|
        # FloatValue* alpha_wrapper = [protocolor alpha];
 | 
						|
        # float alpha = 1.0;
 | 
						|
        # if (alpha_wrapper != nil) `
 | 
						|
        # alpha = [alpha_wrapper value];
 | 
						|
        # `
 | 
						|
        # return [UIColor colorWithRed:red green:green blue:blue alpha:alpha];
 | 
						|
        # `
 | 
						|
        # static Color* toProto(UIColor* color) `
 | 
						|
        # CGFloat red, green, blue, alpha;
 | 
						|
        # if (![color getRed:&red green:&green blue:&blue alpha:&alpha]) `
 | 
						|
        # return nil;
 | 
						|
        # `
 | 
						|
        # Color* result = [Color alloc] init];
 | 
						|
        # [result setRed:red];
 | 
						|
        # [result setGreen:green];
 | 
						|
        # [result setBlue:blue];
 | 
						|
        # if (alpha <= 0.9999) `
 | 
						|
        # [result setAlpha:floatWrapperWithValue(alpha)];
 | 
						|
        # `
 | 
						|
        # [result autorelease];
 | 
						|
        # return result;
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (JavaScript):
 | 
						|
        # // ...
 | 
						|
        # var protoToCssColor = function(rgb_color) `
 | 
						|
        # var redFrac = rgb_color.red || 0.0;
 | 
						|
        # var greenFrac = rgb_color.green || 0.0;
 | 
						|
        # var blueFrac = rgb_color.blue || 0.0;
 | 
						|
        # var red = Math.floor(redFrac * 255);
 | 
						|
        # var green = Math.floor(greenFrac * 255);
 | 
						|
        # var blue = Math.floor(blueFrac * 255);
 | 
						|
        # if (!('alpha' in rgb_color)) `
 | 
						|
        # return rgbToCssColor_(red, green, blue);
 | 
						|
        # `
 | 
						|
        # var alphaFrac = rgb_color.alpha.value || 0.0;
 | 
						|
        # var rgbParams = [red, green, blue].join(',');
 | 
						|
        # return ['rgba(', rgbParams, ',', alphaFrac, ')'].join('');
 | 
						|
        # `;
 | 
						|
        # var rgbToCssColor_ = function(red, green, blue) `
 | 
						|
        # var rgbNumber = new Number((red << 16) | (green << 8) | blue);
 | 
						|
        # var hexString = rgbNumber.toString(16);
 | 
						|
        # var missingZeros = 6 - hexString.length;
 | 
						|
        # var resultBuilder = ['#'];
 | 
						|
        # for (var i = 0; i < missingZeros; i++) `
 | 
						|
        # resultBuilder.push('0');
 | 
						|
        # `
 | 
						|
        # resultBuilder.push(hexString);
 | 
						|
        # return resultBuilder.join('');
 | 
						|
        # `;
 | 
						|
        # // ...
 | 
						|
        # Corresponds to the JSON property `selectedNodeColor`
 | 
						|
        # @return [Google::Apis::SheetsV4::Color]
 | 
						|
        attr_accessor :selected_node_color
 | 
						|
      
 | 
						|
        # The data included in a domain or series.
 | 
						|
        # Corresponds to the JSON property `tooltips`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartData]
 | 
						|
        attr_accessor :tooltips
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @labels = args[:labels] if args.key?(:labels)
 | 
						|
          @node_color = args[:node_color] if args.key?(:node_color)
 | 
						|
          @node_size = args[:node_size] if args.key?(:node_size)
 | 
						|
          @parent_labels = args[:parent_labels] if args.key?(:parent_labels)
 | 
						|
          @selected_node_color = args[:selected_node_color] if args.key?(:selected_node_color)
 | 
						|
          @tooltips = args[:tooltips] if args.key?(:tooltips)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The location an object is overlaid on top of a grid.
 | 
						|
      class OverlayPosition
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A coordinate in a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Corresponds to the JSON property `anchorCell`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridCoordinate]
 | 
						|
        attr_accessor :anchor_cell
 | 
						|
      
 | 
						|
        # The height of the object, in pixels. Defaults to 371.
 | 
						|
        # Corresponds to the JSON property `heightPixels`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :height_pixels
 | 
						|
      
 | 
						|
        # The horizontal offset, in pixels, that the object is offset
 | 
						|
        # from the anchor cell.
 | 
						|
        # Corresponds to the JSON property `offsetXPixels`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :offset_x_pixels
 | 
						|
      
 | 
						|
        # The vertical offset, in pixels, that the object is offset
 | 
						|
        # from the anchor cell.
 | 
						|
        # Corresponds to the JSON property `offsetYPixels`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :offset_y_pixels
 | 
						|
      
 | 
						|
        # The width of the object, in pixels. Defaults to 600.
 | 
						|
        # Corresponds to the JSON property `widthPixels`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :width_pixels
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @anchor_cell = args[:anchor_cell] if args.key?(:anchor_cell)
 | 
						|
          @height_pixels = args[:height_pixels] if args.key?(:height_pixels)
 | 
						|
          @offset_x_pixels = args[:offset_x_pixels] if args.key?(:offset_x_pixels)
 | 
						|
          @offset_y_pixels = args[:offset_y_pixels] if args.key?(:offset_y_pixels)
 | 
						|
          @width_pixels = args[:width_pixels] if args.key?(:width_pixels)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The amount of padding around the cell, in pixels.
 | 
						|
      # When updating padding, every field must be specified.
 | 
						|
      class Padding
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The bottom padding of the cell.
 | 
						|
        # Corresponds to the JSON property `bottom`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :bottom
 | 
						|
      
 | 
						|
        # The left padding of the cell.
 | 
						|
        # Corresponds to the JSON property `left`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :left
 | 
						|
      
 | 
						|
        # The right padding of the cell.
 | 
						|
        # Corresponds to the JSON property `right`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :right
 | 
						|
      
 | 
						|
        # The top padding of the cell.
 | 
						|
        # Corresponds to the JSON property `top`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :top
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @bottom = args[:bottom] if args.key?(:bottom)
 | 
						|
          @left = args[:left] if args.key?(:left)
 | 
						|
          @right = args[:right] if args.key?(:right)
 | 
						|
          @top = args[:top] if args.key?(:top)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Inserts data into the spreadsheet starting at the specified coordinate.
 | 
						|
      class PasteDataRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A coordinate in a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Corresponds to the JSON property `coordinate`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridCoordinate]
 | 
						|
        attr_accessor :coordinate
 | 
						|
      
 | 
						|
        # The data to insert.
 | 
						|
        # Corresponds to the JSON property `data`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :data
 | 
						|
      
 | 
						|
        # The delimiter in the data.
 | 
						|
        # Corresponds to the JSON property `delimiter`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :delimiter
 | 
						|
      
 | 
						|
        # True if the data is HTML.
 | 
						|
        # Corresponds to the JSON property `html`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :html
 | 
						|
        alias_method :html?, :html
 | 
						|
      
 | 
						|
        # How the data should be pasted.
 | 
						|
        # Corresponds to the JSON property `type`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :type
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @coordinate = args[:coordinate] if args.key?(:coordinate)
 | 
						|
          @data = args[:data] if args.key?(:data)
 | 
						|
          @delimiter = args[:delimiter] if args.key?(:delimiter)
 | 
						|
          @html = args[:html] if args.key?(:html)
 | 
						|
          @type = args[:type] if args.key?(:type)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A <a href="/chart/interactive/docs/gallery/piechart">pie chart</a>.
 | 
						|
      class PieChartSpec
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The data included in a domain or series.
 | 
						|
        # Corresponds to the JSON property `domain`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartData]
 | 
						|
        attr_accessor :domain
 | 
						|
      
 | 
						|
        # Where the legend of the pie chart should be drawn.
 | 
						|
        # Corresponds to the JSON property `legendPosition`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :legend_position
 | 
						|
      
 | 
						|
        # The size of the hole in the pie chart.
 | 
						|
        # Corresponds to the JSON property `pieHole`
 | 
						|
        # @return [Float]
 | 
						|
        attr_accessor :pie_hole
 | 
						|
      
 | 
						|
        # The data included in a domain or series.
 | 
						|
        # Corresponds to the JSON property `series`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartData]
 | 
						|
        attr_accessor :series
 | 
						|
      
 | 
						|
        # True if the pie is three dimensional.
 | 
						|
        # Corresponds to the JSON property `threeDimensional`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :three_dimensional
 | 
						|
        alias_method :three_dimensional?, :three_dimensional
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @domain = args[:domain] if args.key?(:domain)
 | 
						|
          @legend_position = args[:legend_position] if args.key?(:legend_position)
 | 
						|
          @pie_hole = args[:pie_hole] if args.key?(:pie_hole)
 | 
						|
          @series = args[:series] if args.key?(:series)
 | 
						|
          @three_dimensional = args[:three_dimensional] if args.key?(:three_dimensional)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Criteria for showing/hiding rows in a pivot table.
 | 
						|
      class PivotFilterCriteria
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Values that should be included.  Values not listed here are excluded.
 | 
						|
        # Corresponds to the JSON property `visibleValues`
 | 
						|
        # @return [Array<String>]
 | 
						|
        attr_accessor :visible_values
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @visible_values = args[:visible_values] if args.key?(:visible_values)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A single grouping (either row or column) in a pivot table.
 | 
						|
      class PivotGroup
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # True if the pivot table should include the totals for this grouping.
 | 
						|
        # Corresponds to the JSON property `showTotals`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :show_totals
 | 
						|
        alias_method :show_totals?, :show_totals
 | 
						|
      
 | 
						|
        # The order the values in this group should be sorted.
 | 
						|
        # Corresponds to the JSON property `sortOrder`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :sort_order
 | 
						|
      
 | 
						|
        # The column offset of the source range that this grouping is based on.
 | 
						|
        # For example, if the source was `C10:E15`, a `sourceColumnOffset` of `0`
 | 
						|
        # means this group refers to column `C`, whereas the offset `1` would refer
 | 
						|
        # to column `D`.
 | 
						|
        # Corresponds to the JSON property `sourceColumnOffset`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :source_column_offset
 | 
						|
      
 | 
						|
        # Information about which values in a pivot group should be used for sorting.
 | 
						|
        # Corresponds to the JSON property `valueBucket`
 | 
						|
        # @return [Google::Apis::SheetsV4::PivotGroupSortValueBucket]
 | 
						|
        attr_accessor :value_bucket
 | 
						|
      
 | 
						|
        # Metadata about values in the grouping.
 | 
						|
        # Corresponds to the JSON property `valueMetadata`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::PivotGroupValueMetadata>]
 | 
						|
        attr_accessor :value_metadata
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @show_totals = args[:show_totals] if args.key?(:show_totals)
 | 
						|
          @sort_order = args[:sort_order] if args.key?(:sort_order)
 | 
						|
          @source_column_offset = args[:source_column_offset] if args.key?(:source_column_offset)
 | 
						|
          @value_bucket = args[:value_bucket] if args.key?(:value_bucket)
 | 
						|
          @value_metadata = args[:value_metadata] if args.key?(:value_metadata)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Information about which values in a pivot group should be used for sorting.
 | 
						|
      class PivotGroupSortValueBucket
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Determines the bucket from which values are chosen to sort.
 | 
						|
        # For example, in a pivot table with one row group & two column groups,
 | 
						|
        # the row group can list up to two values. The first value corresponds
 | 
						|
        # to a value within the first column group, and the second value
 | 
						|
        # corresponds to a value in the second column group.  If no values
 | 
						|
        # are listed, this would indicate that the row should be sorted according
 | 
						|
        # to the "Grand Total" over the column groups. If a single value is listed,
 | 
						|
        # this would correspond to using the "Total" of that bucket.
 | 
						|
        # Corresponds to the JSON property `buckets`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::ExtendedValue>]
 | 
						|
        attr_accessor :buckets
 | 
						|
      
 | 
						|
        # The offset in the PivotTable.values list which the values in this
 | 
						|
        # grouping should be sorted by.
 | 
						|
        # Corresponds to the JSON property `valuesIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :values_index
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @buckets = args[:buckets] if args.key?(:buckets)
 | 
						|
          @values_index = args[:values_index] if args.key?(:values_index)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Metadata about a value in a pivot grouping.
 | 
						|
      class PivotGroupValueMetadata
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # True if the data corresponding to the value is collapsed.
 | 
						|
        # Corresponds to the JSON property `collapsed`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :collapsed
 | 
						|
        alias_method :collapsed?, :collapsed
 | 
						|
      
 | 
						|
        # The kinds of value that a cell in a spreadsheet can have.
 | 
						|
        # Corresponds to the JSON property `value`
 | 
						|
        # @return [Google::Apis::SheetsV4::ExtendedValue]
 | 
						|
        attr_accessor :value
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @collapsed = args[:collapsed] if args.key?(:collapsed)
 | 
						|
          @value = args[:value] if args.key?(:value)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A pivot table.
 | 
						|
      class PivotTable
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Each column grouping in the pivot table.
 | 
						|
        # Corresponds to the JSON property `columns`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::PivotGroup>]
 | 
						|
        attr_accessor :columns
 | 
						|
      
 | 
						|
        # An optional mapping of filters per source column offset.
 | 
						|
        # The filters will be applied before aggregating data into the pivot table.
 | 
						|
        # The map's key is the column offset of the source range that you want to
 | 
						|
        # filter, and the value is the criteria for that column.
 | 
						|
        # For example, if the source was `C10:E15`, a key of `0` will have the filter
 | 
						|
        # for column `C`, whereas the key `1` is for column `D`.
 | 
						|
        # Corresponds to the JSON property `criteria`
 | 
						|
        # @return [Hash<String,Google::Apis::SheetsV4::PivotFilterCriteria>]
 | 
						|
        attr_accessor :criteria
 | 
						|
      
 | 
						|
        # Each row grouping in the pivot table.
 | 
						|
        # Corresponds to the JSON property `rows`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::PivotGroup>]
 | 
						|
        attr_accessor :rows
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `source`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :source
 | 
						|
      
 | 
						|
        # Whether values should be listed horizontally (as columns)
 | 
						|
        # or vertically (as rows).
 | 
						|
        # Corresponds to the JSON property `valueLayout`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :value_layout
 | 
						|
      
 | 
						|
        # A list of values to include in the pivot table.
 | 
						|
        # Corresponds to the JSON property `values`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::PivotValue>]
 | 
						|
        attr_accessor :values
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @columns = args[:columns] if args.key?(:columns)
 | 
						|
          @criteria = args[:criteria] if args.key?(:criteria)
 | 
						|
          @rows = args[:rows] if args.key?(:rows)
 | 
						|
          @source = args[:source] if args.key?(:source)
 | 
						|
          @value_layout = args[:value_layout] if args.key?(:value_layout)
 | 
						|
          @values = args[:values] if args.key?(:values)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The definition of how a value in a pivot table should be calculated.
 | 
						|
      class PivotValue
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A custom formula to calculate the value.  The formula must start
 | 
						|
        # with an `=` character.
 | 
						|
        # Corresponds to the JSON property `formula`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :formula
 | 
						|
      
 | 
						|
        # A name to use for the value.
 | 
						|
        # Corresponds to the JSON property `name`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :name
 | 
						|
      
 | 
						|
        # The column offset of the source range that this value reads from.
 | 
						|
        # For example, if the source was `C10:E15`, a `sourceColumnOffset` of `0`
 | 
						|
        # means this value refers to column `C`, whereas the offset `1` would
 | 
						|
        # refer to column `D`.
 | 
						|
        # Corresponds to the JSON property `sourceColumnOffset`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :source_column_offset
 | 
						|
      
 | 
						|
        # A function to summarize the value.
 | 
						|
        # If formula is set, the only supported values are
 | 
						|
        # SUM and
 | 
						|
        # CUSTOM.
 | 
						|
        # If sourceColumnOffset is set, then `CUSTOM`
 | 
						|
        # is not supported.
 | 
						|
        # Corresponds to the JSON property `summarizeFunction`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :summarize_function
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @formula = args[:formula] if args.key?(:formula)
 | 
						|
          @name = args[:name] if args.key?(:name)
 | 
						|
          @source_column_offset = args[:source_column_offset] if args.key?(:source_column_offset)
 | 
						|
          @summarize_function = args[:summarize_function] if args.key?(:summarize_function)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A protected range.
 | 
						|
      class ProtectedRange
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The description of this protected range.
 | 
						|
        # Corresponds to the JSON property `description`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :description
 | 
						|
      
 | 
						|
        # The editors of a protected range.
 | 
						|
        # Corresponds to the JSON property `editors`
 | 
						|
        # @return [Google::Apis::SheetsV4::Editors]
 | 
						|
        attr_accessor :editors
 | 
						|
      
 | 
						|
        # The named range this protected range is backed by, if any.
 | 
						|
        # When writing, only one of range or named_range_id
 | 
						|
        # may be set.
 | 
						|
        # Corresponds to the JSON property `namedRangeId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :named_range_id
 | 
						|
      
 | 
						|
        # The ID of the protected range.
 | 
						|
        # This field is read-only.
 | 
						|
        # Corresponds to the JSON property `protectedRangeId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :protected_range_id
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        # True if the user who requested this protected range can edit the
 | 
						|
        # protected area.
 | 
						|
        # This field is read-only.
 | 
						|
        # Corresponds to the JSON property `requestingUserCanEdit`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :requesting_user_can_edit
 | 
						|
        alias_method :requesting_user_can_edit?, :requesting_user_can_edit
 | 
						|
      
 | 
						|
        # The list of unprotected ranges within a protected sheet.
 | 
						|
        # Unprotected ranges are only supported on protected sheets.
 | 
						|
        # Corresponds to the JSON property `unprotectedRanges`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::GridRange>]
 | 
						|
        attr_accessor :unprotected_ranges
 | 
						|
      
 | 
						|
        # True if this protected range will show a warning when editing.
 | 
						|
        # Warning-based protection means that every user can edit data in the
 | 
						|
        # protected range, except editing will prompt a warning asking the user
 | 
						|
        # to confirm the edit.
 | 
						|
        # When writing: if this field is true, then editors is ignored.
 | 
						|
        # Additionally, if this field is changed from true to false and the
 | 
						|
        # `editors` field is not set (nor included in the field mask), then
 | 
						|
        # the editors will be set to all the editors in the document.
 | 
						|
        # Corresponds to the JSON property `warningOnly`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :warning_only
 | 
						|
        alias_method :warning_only?, :warning_only
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @description = args[:description] if args.key?(:description)
 | 
						|
          @editors = args[:editors] if args.key?(:editors)
 | 
						|
          @named_range_id = args[:named_range_id] if args.key?(:named_range_id)
 | 
						|
          @protected_range_id = args[:protected_range_id] if args.key?(:protected_range_id)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
          @requesting_user_can_edit = args[:requesting_user_can_edit] if args.key?(:requesting_user_can_edit)
 | 
						|
          @unprotected_ranges = args[:unprotected_ranges] if args.key?(:unprotected_ranges)
 | 
						|
          @warning_only = args[:warning_only] if args.key?(:warning_only)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Randomizes the order of the rows in a range.
 | 
						|
      class RandomizeRangeRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Updates all cells in the range to the values in the given Cell object.
 | 
						|
      # Only the fields listed in the fields field are updated; others are
 | 
						|
      # unchanged.
 | 
						|
      # If writing a cell with a formula, the formula's ranges will automatically
 | 
						|
      # increment for each field in the range.
 | 
						|
      # For example, if writing a cell with formula `=A1` into range B2:C4,
 | 
						|
      # B2 would be `=A1`, B3 would be `=A2`, B4 would be `=A3`,
 | 
						|
      # C2 would be `=B1`, C3 would be `=B2`, C4 would be `=B3`.
 | 
						|
      # To keep the formula's ranges static, use the `$` indicator.
 | 
						|
      # For example, use the formula `=$A$1` to prevent both the row and the
 | 
						|
      # column from incrementing.
 | 
						|
      class RepeatCellRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Data about a specific cell.
 | 
						|
        # Corresponds to the JSON property `cell`
 | 
						|
        # @return [Google::Apis::SheetsV4::CellData]
 | 
						|
        attr_accessor :cell
 | 
						|
      
 | 
						|
        # The fields that should be updated.  At least one field must be specified.
 | 
						|
        # The root `cell` is implied and should not be specified.
 | 
						|
        # A single `"*"` can be used as short-hand for listing every field.
 | 
						|
        # Corresponds to the JSON property `fields`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :fields
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @cell = args[:cell] if args.key?(:cell)
 | 
						|
          @fields = args[:fields] if args.key?(:fields)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A single kind of update to apply to a spreadsheet.
 | 
						|
      class Request
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Adds a new banded range to the spreadsheet.
 | 
						|
        # Corresponds to the JSON property `addBanding`
 | 
						|
        # @return [Google::Apis::SheetsV4::AddBandingRequest]
 | 
						|
        attr_accessor :add_banding
 | 
						|
      
 | 
						|
        # Adds a chart to a sheet in the spreadsheet.
 | 
						|
        # Corresponds to the JSON property `addChart`
 | 
						|
        # @return [Google::Apis::SheetsV4::AddChartRequest]
 | 
						|
        attr_accessor :add_chart
 | 
						|
      
 | 
						|
        # Adds a new conditional format rule at the given index.
 | 
						|
        # All subsequent rules' indexes are incremented.
 | 
						|
        # Corresponds to the JSON property `addConditionalFormatRule`
 | 
						|
        # @return [Google::Apis::SheetsV4::AddConditionalFormatRuleRequest]
 | 
						|
        attr_accessor :add_conditional_format_rule
 | 
						|
      
 | 
						|
        # Adds a filter view.
 | 
						|
        # Corresponds to the JSON property `addFilterView`
 | 
						|
        # @return [Google::Apis::SheetsV4::AddFilterViewRequest]
 | 
						|
        attr_accessor :add_filter_view
 | 
						|
      
 | 
						|
        # Adds a named range to the spreadsheet.
 | 
						|
        # Corresponds to the JSON property `addNamedRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::AddNamedRangeRequest]
 | 
						|
        attr_accessor :add_named_range
 | 
						|
      
 | 
						|
        # Adds a new protected range.
 | 
						|
        # Corresponds to the JSON property `addProtectedRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::AddProtectedRangeRequest]
 | 
						|
        attr_accessor :add_protected_range
 | 
						|
      
 | 
						|
        # Adds a new sheet.
 | 
						|
        # When a sheet is added at a given index,
 | 
						|
        # all subsequent sheets' indexes are incremented.
 | 
						|
        # To add an object sheet, use AddChartRequest instead and specify
 | 
						|
        # EmbeddedObjectPosition.sheetId or
 | 
						|
        # EmbeddedObjectPosition.newSheet.
 | 
						|
        # Corresponds to the JSON property `addSheet`
 | 
						|
        # @return [Google::Apis::SheetsV4::AddSheetRequest]
 | 
						|
        attr_accessor :add_sheet
 | 
						|
      
 | 
						|
        # Adds new cells after the last row with data in a sheet,
 | 
						|
        # inserting new rows into the sheet if necessary.
 | 
						|
        # Corresponds to the JSON property `appendCells`
 | 
						|
        # @return [Google::Apis::SheetsV4::AppendCellsRequest]
 | 
						|
        attr_accessor :append_cells
 | 
						|
      
 | 
						|
        # Appends rows or columns to the end of a sheet.
 | 
						|
        # Corresponds to the JSON property `appendDimension`
 | 
						|
        # @return [Google::Apis::SheetsV4::AppendDimensionRequest]
 | 
						|
        attr_accessor :append_dimension
 | 
						|
      
 | 
						|
        # Fills in more data based on existing data.
 | 
						|
        # Corresponds to the JSON property `autoFill`
 | 
						|
        # @return [Google::Apis::SheetsV4::AutoFillRequest]
 | 
						|
        attr_accessor :auto_fill
 | 
						|
      
 | 
						|
        # Automatically resizes one or more dimensions based on the contents
 | 
						|
        # of the cells in that dimension.
 | 
						|
        # Corresponds to the JSON property `autoResizeDimensions`
 | 
						|
        # @return [Google::Apis::SheetsV4::AutoResizeDimensionsRequest]
 | 
						|
        attr_accessor :auto_resize_dimensions
 | 
						|
      
 | 
						|
        # Clears the basic filter, if any exists on the sheet.
 | 
						|
        # Corresponds to the JSON property `clearBasicFilter`
 | 
						|
        # @return [Google::Apis::SheetsV4::ClearBasicFilterRequest]
 | 
						|
        attr_accessor :clear_basic_filter
 | 
						|
      
 | 
						|
        # Copies data from the source to the destination.
 | 
						|
        # Corresponds to the JSON property `copyPaste`
 | 
						|
        # @return [Google::Apis::SheetsV4::CopyPasteRequest]
 | 
						|
        attr_accessor :copy_paste
 | 
						|
      
 | 
						|
        # A request to create developer metadata.
 | 
						|
        # Corresponds to the JSON property `createDeveloperMetadata`
 | 
						|
        # @return [Google::Apis::SheetsV4::CreateDeveloperMetadataRequest]
 | 
						|
        attr_accessor :create_developer_metadata
 | 
						|
      
 | 
						|
        # Moves data from the source to the destination.
 | 
						|
        # Corresponds to the JSON property `cutPaste`
 | 
						|
        # @return [Google::Apis::SheetsV4::CutPasteRequest]
 | 
						|
        attr_accessor :cut_paste
 | 
						|
      
 | 
						|
        # Removes the banded range with the given ID from the spreadsheet.
 | 
						|
        # Corresponds to the JSON property `deleteBanding`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeleteBandingRequest]
 | 
						|
        attr_accessor :delete_banding
 | 
						|
      
 | 
						|
        # Deletes a conditional format rule at the given index.
 | 
						|
        # All subsequent rules' indexes are decremented.
 | 
						|
        # Corresponds to the JSON property `deleteConditionalFormatRule`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeleteConditionalFormatRuleRequest]
 | 
						|
        attr_accessor :delete_conditional_format_rule
 | 
						|
      
 | 
						|
        # A request to delete developer metadata.
 | 
						|
        # Corresponds to the JSON property `deleteDeveloperMetadata`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeleteDeveloperMetadataRequest]
 | 
						|
        attr_accessor :delete_developer_metadata
 | 
						|
      
 | 
						|
        # Deletes the dimensions from the sheet.
 | 
						|
        # Corresponds to the JSON property `deleteDimension`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeleteDimensionRequest]
 | 
						|
        attr_accessor :delete_dimension
 | 
						|
      
 | 
						|
        # Deletes the embedded object with the given ID.
 | 
						|
        # Corresponds to the JSON property `deleteEmbeddedObject`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeleteEmbeddedObjectRequest]
 | 
						|
        attr_accessor :delete_embedded_object
 | 
						|
      
 | 
						|
        # Deletes a particular filter view.
 | 
						|
        # Corresponds to the JSON property `deleteFilterView`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeleteFilterViewRequest]
 | 
						|
        attr_accessor :delete_filter_view
 | 
						|
      
 | 
						|
        # Removes the named range with the given ID from the spreadsheet.
 | 
						|
        # Corresponds to the JSON property `deleteNamedRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeleteNamedRangeRequest]
 | 
						|
        attr_accessor :delete_named_range
 | 
						|
      
 | 
						|
        # Deletes the protected range with the given ID.
 | 
						|
        # Corresponds to the JSON property `deleteProtectedRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeleteProtectedRangeRequest]
 | 
						|
        attr_accessor :delete_protected_range
 | 
						|
      
 | 
						|
        # Deletes a range of cells, shifting other cells into the deleted area.
 | 
						|
        # Corresponds to the JSON property `deleteRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeleteRangeRequest]
 | 
						|
        attr_accessor :delete_range
 | 
						|
      
 | 
						|
        # Deletes the requested sheet.
 | 
						|
        # Corresponds to the JSON property `deleteSheet`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeleteSheetRequest]
 | 
						|
        attr_accessor :delete_sheet
 | 
						|
      
 | 
						|
        # Duplicates a particular filter view.
 | 
						|
        # Corresponds to the JSON property `duplicateFilterView`
 | 
						|
        # @return [Google::Apis::SheetsV4::DuplicateFilterViewRequest]
 | 
						|
        attr_accessor :duplicate_filter_view
 | 
						|
      
 | 
						|
        # Duplicates the contents of a sheet.
 | 
						|
        # Corresponds to the JSON property `duplicateSheet`
 | 
						|
        # @return [Google::Apis::SheetsV4::DuplicateSheetRequest]
 | 
						|
        attr_accessor :duplicate_sheet
 | 
						|
      
 | 
						|
        # Finds and replaces data in cells over a range, sheet, or all sheets.
 | 
						|
        # Corresponds to the JSON property `findReplace`
 | 
						|
        # @return [Google::Apis::SheetsV4::FindReplaceRequest]
 | 
						|
        attr_accessor :find_replace
 | 
						|
      
 | 
						|
        # Inserts rows or columns in a sheet at a particular index.
 | 
						|
        # Corresponds to the JSON property `insertDimension`
 | 
						|
        # @return [Google::Apis::SheetsV4::InsertDimensionRequest]
 | 
						|
        attr_accessor :insert_dimension
 | 
						|
      
 | 
						|
        # Inserts cells into a range, shifting the existing cells over or down.
 | 
						|
        # Corresponds to the JSON property `insertRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::InsertRangeRequest]
 | 
						|
        attr_accessor :insert_range
 | 
						|
      
 | 
						|
        # Merges all cells in the range.
 | 
						|
        # Corresponds to the JSON property `mergeCells`
 | 
						|
        # @return [Google::Apis::SheetsV4::MergeCellsRequest]
 | 
						|
        attr_accessor :merge_cells
 | 
						|
      
 | 
						|
        # Moves one or more rows or columns.
 | 
						|
        # Corresponds to the JSON property `moveDimension`
 | 
						|
        # @return [Google::Apis::SheetsV4::MoveDimensionRequest]
 | 
						|
        attr_accessor :move_dimension
 | 
						|
      
 | 
						|
        # Inserts data into the spreadsheet starting at the specified coordinate.
 | 
						|
        # Corresponds to the JSON property `pasteData`
 | 
						|
        # @return [Google::Apis::SheetsV4::PasteDataRequest]
 | 
						|
        attr_accessor :paste_data
 | 
						|
      
 | 
						|
        # Randomizes the order of the rows in a range.
 | 
						|
        # Corresponds to the JSON property `randomizeRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::RandomizeRangeRequest]
 | 
						|
        attr_accessor :randomize_range
 | 
						|
      
 | 
						|
        # Updates all cells in the range to the values in the given Cell object.
 | 
						|
        # Only the fields listed in the fields field are updated; others are
 | 
						|
        # unchanged.
 | 
						|
        # If writing a cell with a formula, the formula's ranges will automatically
 | 
						|
        # increment for each field in the range.
 | 
						|
        # For example, if writing a cell with formula `=A1` into range B2:C4,
 | 
						|
        # B2 would be `=A1`, B3 would be `=A2`, B4 would be `=A3`,
 | 
						|
        # C2 would be `=B1`, C3 would be `=B2`, C4 would be `=B3`.
 | 
						|
        # To keep the formula's ranges static, use the `$` indicator.
 | 
						|
        # For example, use the formula `=$A$1` to prevent both the row and the
 | 
						|
        # column from incrementing.
 | 
						|
        # Corresponds to the JSON property `repeatCell`
 | 
						|
        # @return [Google::Apis::SheetsV4::RepeatCellRequest]
 | 
						|
        attr_accessor :repeat_cell
 | 
						|
      
 | 
						|
        # Sets the basic filter associated with a sheet.
 | 
						|
        # Corresponds to the JSON property `setBasicFilter`
 | 
						|
        # @return [Google::Apis::SheetsV4::SetBasicFilterRequest]
 | 
						|
        attr_accessor :set_basic_filter
 | 
						|
      
 | 
						|
        # Sets a data validation rule to every cell in the range.
 | 
						|
        # To clear validation in a range, call this with no rule specified.
 | 
						|
        # Corresponds to the JSON property `setDataValidation`
 | 
						|
        # @return [Google::Apis::SheetsV4::SetDataValidationRequest]
 | 
						|
        attr_accessor :set_data_validation
 | 
						|
      
 | 
						|
        # Sorts data in rows based on a sort order per column.
 | 
						|
        # Corresponds to the JSON property `sortRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::SortRangeRequest]
 | 
						|
        attr_accessor :sort_range
 | 
						|
      
 | 
						|
        # Splits a column of text into multiple columns,
 | 
						|
        # based on a delimiter in each cell.
 | 
						|
        # Corresponds to the JSON property `textToColumns`
 | 
						|
        # @return [Google::Apis::SheetsV4::TextToColumnsRequest]
 | 
						|
        attr_accessor :text_to_columns
 | 
						|
      
 | 
						|
        # Unmerges cells in the given range.
 | 
						|
        # Corresponds to the JSON property `unmergeCells`
 | 
						|
        # @return [Google::Apis::SheetsV4::UnmergeCellsRequest]
 | 
						|
        attr_accessor :unmerge_cells
 | 
						|
      
 | 
						|
        # Updates properties of the supplied banded range.
 | 
						|
        # Corresponds to the JSON property `updateBanding`
 | 
						|
        # @return [Google::Apis::SheetsV4::UpdateBandingRequest]
 | 
						|
        attr_accessor :update_banding
 | 
						|
      
 | 
						|
        # Updates the borders of a range.
 | 
						|
        # If a field is not set in the request, that means the border remains as-is.
 | 
						|
        # For example, with two subsequent UpdateBordersRequest:
 | 
						|
        # 1. range: A1:A5 `` top: RED, bottom: WHITE ``
 | 
						|
        # 2. range: A1:A5 `` left: BLUE ``
 | 
						|
        # That would result in A1:A5 having a borders of
 | 
						|
        # `` top: RED, bottom: WHITE, left: BLUE ``.
 | 
						|
        # If you want to clear a border, explicitly set the style to
 | 
						|
        # NONE.
 | 
						|
        # Corresponds to the JSON property `updateBorders`
 | 
						|
        # @return [Google::Apis::SheetsV4::UpdateBordersRequest]
 | 
						|
        attr_accessor :update_borders
 | 
						|
      
 | 
						|
        # Updates all cells in a range with new data.
 | 
						|
        # Corresponds to the JSON property `updateCells`
 | 
						|
        # @return [Google::Apis::SheetsV4::UpdateCellsRequest]
 | 
						|
        attr_accessor :update_cells
 | 
						|
      
 | 
						|
        # Updates a chart's specifications.
 | 
						|
        # (This does not move or resize a chart. To move or resize a chart, use
 | 
						|
        # UpdateEmbeddedObjectPositionRequest.)
 | 
						|
        # Corresponds to the JSON property `updateChartSpec`
 | 
						|
        # @return [Google::Apis::SheetsV4::UpdateChartSpecRequest]
 | 
						|
        attr_accessor :update_chart_spec
 | 
						|
      
 | 
						|
        # Updates a conditional format rule at the given index,
 | 
						|
        # or moves a conditional format rule to another index.
 | 
						|
        # Corresponds to the JSON property `updateConditionalFormatRule`
 | 
						|
        # @return [Google::Apis::SheetsV4::UpdateConditionalFormatRuleRequest]
 | 
						|
        attr_accessor :update_conditional_format_rule
 | 
						|
      
 | 
						|
        # A request to update properties of developer metadata.
 | 
						|
        # Updates the properties of the developer metadata selected by the filters to
 | 
						|
        # the values provided in the DeveloperMetadata resource.  Callers must
 | 
						|
        # specify the properties they wish to update in the fields parameter, as well
 | 
						|
        # as specify at least one DataFilter matching the metadata they wish to
 | 
						|
        # update.
 | 
						|
        # Corresponds to the JSON property `updateDeveloperMetadata`
 | 
						|
        # @return [Google::Apis::SheetsV4::UpdateDeveloperMetadataRequest]
 | 
						|
        attr_accessor :update_developer_metadata
 | 
						|
      
 | 
						|
        # Updates properties of dimensions within the specified range.
 | 
						|
        # Corresponds to the JSON property `updateDimensionProperties`
 | 
						|
        # @return [Google::Apis::SheetsV4::UpdateDimensionPropertiesRequest]
 | 
						|
        attr_accessor :update_dimension_properties
 | 
						|
      
 | 
						|
        # Update an embedded object's position (such as a moving or resizing a
 | 
						|
        # chart or image).
 | 
						|
        # Corresponds to the JSON property `updateEmbeddedObjectPosition`
 | 
						|
        # @return [Google::Apis::SheetsV4::UpdateEmbeddedObjectPositionRequest]
 | 
						|
        attr_accessor :update_embedded_object_position
 | 
						|
      
 | 
						|
        # Updates properties of the filter view.
 | 
						|
        # Corresponds to the JSON property `updateFilterView`
 | 
						|
        # @return [Google::Apis::SheetsV4::UpdateFilterViewRequest]
 | 
						|
        attr_accessor :update_filter_view
 | 
						|
      
 | 
						|
        # Updates properties of the named range with the specified
 | 
						|
        # namedRangeId.
 | 
						|
        # Corresponds to the JSON property `updateNamedRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::UpdateNamedRangeRequest]
 | 
						|
        attr_accessor :update_named_range
 | 
						|
      
 | 
						|
        # Updates an existing protected range with the specified
 | 
						|
        # protectedRangeId.
 | 
						|
        # Corresponds to the JSON property `updateProtectedRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::UpdateProtectedRangeRequest]
 | 
						|
        attr_accessor :update_protected_range
 | 
						|
      
 | 
						|
        # Updates properties of the sheet with the specified
 | 
						|
        # sheetId.
 | 
						|
        # Corresponds to the JSON property `updateSheetProperties`
 | 
						|
        # @return [Google::Apis::SheetsV4::UpdateSheetPropertiesRequest]
 | 
						|
        attr_accessor :update_sheet_properties
 | 
						|
      
 | 
						|
        # Updates properties of a spreadsheet.
 | 
						|
        # Corresponds to the JSON property `updateSpreadsheetProperties`
 | 
						|
        # @return [Google::Apis::SheetsV4::UpdateSpreadsheetPropertiesRequest]
 | 
						|
        attr_accessor :update_spreadsheet_properties
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @add_banding = args[:add_banding] if args.key?(:add_banding)
 | 
						|
          @add_chart = args[:add_chart] if args.key?(:add_chart)
 | 
						|
          @add_conditional_format_rule = args[:add_conditional_format_rule] if args.key?(:add_conditional_format_rule)
 | 
						|
          @add_filter_view = args[:add_filter_view] if args.key?(:add_filter_view)
 | 
						|
          @add_named_range = args[:add_named_range] if args.key?(:add_named_range)
 | 
						|
          @add_protected_range = args[:add_protected_range] if args.key?(:add_protected_range)
 | 
						|
          @add_sheet = args[:add_sheet] if args.key?(:add_sheet)
 | 
						|
          @append_cells = args[:append_cells] if args.key?(:append_cells)
 | 
						|
          @append_dimension = args[:append_dimension] if args.key?(:append_dimension)
 | 
						|
          @auto_fill = args[:auto_fill] if args.key?(:auto_fill)
 | 
						|
          @auto_resize_dimensions = args[:auto_resize_dimensions] if args.key?(:auto_resize_dimensions)
 | 
						|
          @clear_basic_filter = args[:clear_basic_filter] if args.key?(:clear_basic_filter)
 | 
						|
          @copy_paste = args[:copy_paste] if args.key?(:copy_paste)
 | 
						|
          @create_developer_metadata = args[:create_developer_metadata] if args.key?(:create_developer_metadata)
 | 
						|
          @cut_paste = args[:cut_paste] if args.key?(:cut_paste)
 | 
						|
          @delete_banding = args[:delete_banding] if args.key?(:delete_banding)
 | 
						|
          @delete_conditional_format_rule = args[:delete_conditional_format_rule] if args.key?(:delete_conditional_format_rule)
 | 
						|
          @delete_developer_metadata = args[:delete_developer_metadata] if args.key?(:delete_developer_metadata)
 | 
						|
          @delete_dimension = args[:delete_dimension] if args.key?(:delete_dimension)
 | 
						|
          @delete_embedded_object = args[:delete_embedded_object] if args.key?(:delete_embedded_object)
 | 
						|
          @delete_filter_view = args[:delete_filter_view] if args.key?(:delete_filter_view)
 | 
						|
          @delete_named_range = args[:delete_named_range] if args.key?(:delete_named_range)
 | 
						|
          @delete_protected_range = args[:delete_protected_range] if args.key?(:delete_protected_range)
 | 
						|
          @delete_range = args[:delete_range] if args.key?(:delete_range)
 | 
						|
          @delete_sheet = args[:delete_sheet] if args.key?(:delete_sheet)
 | 
						|
          @duplicate_filter_view = args[:duplicate_filter_view] if args.key?(:duplicate_filter_view)
 | 
						|
          @duplicate_sheet = args[:duplicate_sheet] if args.key?(:duplicate_sheet)
 | 
						|
          @find_replace = args[:find_replace] if args.key?(:find_replace)
 | 
						|
          @insert_dimension = args[:insert_dimension] if args.key?(:insert_dimension)
 | 
						|
          @insert_range = args[:insert_range] if args.key?(:insert_range)
 | 
						|
          @merge_cells = args[:merge_cells] if args.key?(:merge_cells)
 | 
						|
          @move_dimension = args[:move_dimension] if args.key?(:move_dimension)
 | 
						|
          @paste_data = args[:paste_data] if args.key?(:paste_data)
 | 
						|
          @randomize_range = args[:randomize_range] if args.key?(:randomize_range)
 | 
						|
          @repeat_cell = args[:repeat_cell] if args.key?(:repeat_cell)
 | 
						|
          @set_basic_filter = args[:set_basic_filter] if args.key?(:set_basic_filter)
 | 
						|
          @set_data_validation = args[:set_data_validation] if args.key?(:set_data_validation)
 | 
						|
          @sort_range = args[:sort_range] if args.key?(:sort_range)
 | 
						|
          @text_to_columns = args[:text_to_columns] if args.key?(:text_to_columns)
 | 
						|
          @unmerge_cells = args[:unmerge_cells] if args.key?(:unmerge_cells)
 | 
						|
          @update_banding = args[:update_banding] if args.key?(:update_banding)
 | 
						|
          @update_borders = args[:update_borders] if args.key?(:update_borders)
 | 
						|
          @update_cells = args[:update_cells] if args.key?(:update_cells)
 | 
						|
          @update_chart_spec = args[:update_chart_spec] if args.key?(:update_chart_spec)
 | 
						|
          @update_conditional_format_rule = args[:update_conditional_format_rule] if args.key?(:update_conditional_format_rule)
 | 
						|
          @update_developer_metadata = args[:update_developer_metadata] if args.key?(:update_developer_metadata)
 | 
						|
          @update_dimension_properties = args[:update_dimension_properties] if args.key?(:update_dimension_properties)
 | 
						|
          @update_embedded_object_position = args[:update_embedded_object_position] if args.key?(:update_embedded_object_position)
 | 
						|
          @update_filter_view = args[:update_filter_view] if args.key?(:update_filter_view)
 | 
						|
          @update_named_range = args[:update_named_range] if args.key?(:update_named_range)
 | 
						|
          @update_protected_range = args[:update_protected_range] if args.key?(:update_protected_range)
 | 
						|
          @update_sheet_properties = args[:update_sheet_properties] if args.key?(:update_sheet_properties)
 | 
						|
          @update_spreadsheet_properties = args[:update_spreadsheet_properties] if args.key?(:update_spreadsheet_properties)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A single response from an update.
 | 
						|
      class Response
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The result of adding a banded range.
 | 
						|
        # Corresponds to the JSON property `addBanding`
 | 
						|
        # @return [Google::Apis::SheetsV4::AddBandingResponse]
 | 
						|
        attr_accessor :add_banding
 | 
						|
      
 | 
						|
        # The result of adding a chart to a spreadsheet.
 | 
						|
        # Corresponds to the JSON property `addChart`
 | 
						|
        # @return [Google::Apis::SheetsV4::AddChartResponse]
 | 
						|
        attr_accessor :add_chart
 | 
						|
      
 | 
						|
        # The result of adding a filter view.
 | 
						|
        # Corresponds to the JSON property `addFilterView`
 | 
						|
        # @return [Google::Apis::SheetsV4::AddFilterViewResponse]
 | 
						|
        attr_accessor :add_filter_view
 | 
						|
      
 | 
						|
        # The result of adding a named range.
 | 
						|
        # Corresponds to the JSON property `addNamedRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::AddNamedRangeResponse]
 | 
						|
        attr_accessor :add_named_range
 | 
						|
      
 | 
						|
        # The result of adding a new protected range.
 | 
						|
        # Corresponds to the JSON property `addProtectedRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::AddProtectedRangeResponse]
 | 
						|
        attr_accessor :add_protected_range
 | 
						|
      
 | 
						|
        # The result of adding a sheet.
 | 
						|
        # Corresponds to the JSON property `addSheet`
 | 
						|
        # @return [Google::Apis::SheetsV4::AddSheetResponse]
 | 
						|
        attr_accessor :add_sheet
 | 
						|
      
 | 
						|
        # The response from creating developer metadata.
 | 
						|
        # Corresponds to the JSON property `createDeveloperMetadata`
 | 
						|
        # @return [Google::Apis::SheetsV4::CreateDeveloperMetadataResponse]
 | 
						|
        attr_accessor :create_developer_metadata
 | 
						|
      
 | 
						|
        # The result of deleting a conditional format rule.
 | 
						|
        # Corresponds to the JSON property `deleteConditionalFormatRule`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeleteConditionalFormatRuleResponse]
 | 
						|
        attr_accessor :delete_conditional_format_rule
 | 
						|
      
 | 
						|
        # The response from deleting developer metadata.
 | 
						|
        # Corresponds to the JSON property `deleteDeveloperMetadata`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeleteDeveloperMetadataResponse]
 | 
						|
        attr_accessor :delete_developer_metadata
 | 
						|
      
 | 
						|
        # The result of a filter view being duplicated.
 | 
						|
        # Corresponds to the JSON property `duplicateFilterView`
 | 
						|
        # @return [Google::Apis::SheetsV4::DuplicateFilterViewResponse]
 | 
						|
        attr_accessor :duplicate_filter_view
 | 
						|
      
 | 
						|
        # The result of duplicating a sheet.
 | 
						|
        # Corresponds to the JSON property `duplicateSheet`
 | 
						|
        # @return [Google::Apis::SheetsV4::DuplicateSheetResponse]
 | 
						|
        attr_accessor :duplicate_sheet
 | 
						|
      
 | 
						|
        # The result of the find/replace.
 | 
						|
        # Corresponds to the JSON property `findReplace`
 | 
						|
        # @return [Google::Apis::SheetsV4::FindReplaceResponse]
 | 
						|
        attr_accessor :find_replace
 | 
						|
      
 | 
						|
        # The result of updating a conditional format rule.
 | 
						|
        # Corresponds to the JSON property `updateConditionalFormatRule`
 | 
						|
        # @return [Google::Apis::SheetsV4::UpdateConditionalFormatRuleResponse]
 | 
						|
        attr_accessor :update_conditional_format_rule
 | 
						|
      
 | 
						|
        # The response from updating developer metadata.
 | 
						|
        # Corresponds to the JSON property `updateDeveloperMetadata`
 | 
						|
        # @return [Google::Apis::SheetsV4::UpdateDeveloperMetadataResponse]
 | 
						|
        attr_accessor :update_developer_metadata
 | 
						|
      
 | 
						|
        # The result of updating an embedded object's position.
 | 
						|
        # Corresponds to the JSON property `updateEmbeddedObjectPosition`
 | 
						|
        # @return [Google::Apis::SheetsV4::UpdateEmbeddedObjectPositionResponse]
 | 
						|
        attr_accessor :update_embedded_object_position
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @add_banding = args[:add_banding] if args.key?(:add_banding)
 | 
						|
          @add_chart = args[:add_chart] if args.key?(:add_chart)
 | 
						|
          @add_filter_view = args[:add_filter_view] if args.key?(:add_filter_view)
 | 
						|
          @add_named_range = args[:add_named_range] if args.key?(:add_named_range)
 | 
						|
          @add_protected_range = args[:add_protected_range] if args.key?(:add_protected_range)
 | 
						|
          @add_sheet = args[:add_sheet] if args.key?(:add_sheet)
 | 
						|
          @create_developer_metadata = args[:create_developer_metadata] if args.key?(:create_developer_metadata)
 | 
						|
          @delete_conditional_format_rule = args[:delete_conditional_format_rule] if args.key?(:delete_conditional_format_rule)
 | 
						|
          @delete_developer_metadata = args[:delete_developer_metadata] if args.key?(:delete_developer_metadata)
 | 
						|
          @duplicate_filter_view = args[:duplicate_filter_view] if args.key?(:duplicate_filter_view)
 | 
						|
          @duplicate_sheet = args[:duplicate_sheet] if args.key?(:duplicate_sheet)
 | 
						|
          @find_replace = args[:find_replace] if args.key?(:find_replace)
 | 
						|
          @update_conditional_format_rule = args[:update_conditional_format_rule] if args.key?(:update_conditional_format_rule)
 | 
						|
          @update_developer_metadata = args[:update_developer_metadata] if args.key?(:update_developer_metadata)
 | 
						|
          @update_embedded_object_position = args[:update_embedded_object_position] if args.key?(:update_embedded_object_position)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Data about each cell in a row.
 | 
						|
      class RowData
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The values in the row, one per column.
 | 
						|
        # Corresponds to the JSON property `values`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::CellData>]
 | 
						|
        attr_accessor :values
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @values = args[:values] if args.key?(:values)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A request to retrieve all developer metadata matching the set of specified
 | 
						|
      # criteria.
 | 
						|
      class SearchDeveloperMetadataRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The data filters describing the criteria used to determine which
 | 
						|
        # DeveloperMetadata entries to return.  DeveloperMetadata matching any of the
 | 
						|
        # specified filters will be included in the response.
 | 
						|
        # Corresponds to the JSON property `dataFilters`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::DataFilter>]
 | 
						|
        attr_accessor :data_filters
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data_filters = args[:data_filters] if args.key?(:data_filters)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A reply to a developer metadata search request.
 | 
						|
      class SearchDeveloperMetadataResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The metadata matching the criteria of the search request.
 | 
						|
        # Corresponds to the JSON property `matchedDeveloperMetadata`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::MatchedDeveloperMetadata>]
 | 
						|
        attr_accessor :matched_developer_metadata
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @matched_developer_metadata = args[:matched_developer_metadata] if args.key?(:matched_developer_metadata)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Sets the basic filter associated with a sheet.
 | 
						|
      class SetBasicFilterRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The default filter associated with a sheet.
 | 
						|
        # Corresponds to the JSON property `filter`
 | 
						|
        # @return [Google::Apis::SheetsV4::BasicFilter]
 | 
						|
        attr_accessor :filter
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @filter = args[:filter] if args.key?(:filter)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Sets a data validation rule to every cell in the range.
 | 
						|
      # To clear validation in a range, call this with no rule specified.
 | 
						|
      class SetDataValidationRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        # A data validation rule.
 | 
						|
        # Corresponds to the JSON property `rule`
 | 
						|
        # @return [Google::Apis::SheetsV4::DataValidationRule]
 | 
						|
        attr_accessor :rule
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
          @rule = args[:rule] if args.key?(:rule)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A sheet in a spreadsheet.
 | 
						|
      class Sheet
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The banded (i.e. alternating colors) ranges on this sheet.
 | 
						|
        # Corresponds to the JSON property `bandedRanges`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::BandedRange>]
 | 
						|
        attr_accessor :banded_ranges
 | 
						|
      
 | 
						|
        # The default filter associated with a sheet.
 | 
						|
        # Corresponds to the JSON property `basicFilter`
 | 
						|
        # @return [Google::Apis::SheetsV4::BasicFilter]
 | 
						|
        attr_accessor :basic_filter
 | 
						|
      
 | 
						|
        # The specifications of every chart on this sheet.
 | 
						|
        # Corresponds to the JSON property `charts`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::EmbeddedChart>]
 | 
						|
        attr_accessor :charts
 | 
						|
      
 | 
						|
        # The conditional format rules in this sheet.
 | 
						|
        # Corresponds to the JSON property `conditionalFormats`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::ConditionalFormatRule>]
 | 
						|
        attr_accessor :conditional_formats
 | 
						|
      
 | 
						|
        # Data in the grid, if this is a grid sheet.
 | 
						|
        # The number of GridData objects returned is dependent on the number of
 | 
						|
        # ranges requested on this sheet. For example, if this is representing
 | 
						|
        # `Sheet1`, and the spreadsheet was requested with ranges
 | 
						|
        # `Sheet1!A1:C10` and `Sheet1!D15:E20`, then the first GridData will have a
 | 
						|
        # startRow/startColumn of `0`,
 | 
						|
        # while the second one will have `startRow 14` (zero-based row 15),
 | 
						|
        # and `startColumn 3` (zero-based column D).
 | 
						|
        # Corresponds to the JSON property `data`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::GridData>]
 | 
						|
        attr_accessor :data
 | 
						|
      
 | 
						|
        # The developer metadata associated with a sheet.
 | 
						|
        # Corresponds to the JSON property `developerMetadata`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::DeveloperMetadata>]
 | 
						|
        attr_accessor :developer_metadata
 | 
						|
      
 | 
						|
        # The filter views in this sheet.
 | 
						|
        # Corresponds to the JSON property `filterViews`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::FilterView>]
 | 
						|
        attr_accessor :filter_views
 | 
						|
      
 | 
						|
        # The ranges that are merged together.
 | 
						|
        # Corresponds to the JSON property `merges`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::GridRange>]
 | 
						|
        attr_accessor :merges
 | 
						|
      
 | 
						|
        # Properties of a sheet.
 | 
						|
        # Corresponds to the JSON property `properties`
 | 
						|
        # @return [Google::Apis::SheetsV4::SheetProperties]
 | 
						|
        attr_accessor :properties
 | 
						|
      
 | 
						|
        # The protected ranges in this sheet.
 | 
						|
        # Corresponds to the JSON property `protectedRanges`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::ProtectedRange>]
 | 
						|
        attr_accessor :protected_ranges
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @banded_ranges = args[:banded_ranges] if args.key?(:banded_ranges)
 | 
						|
          @basic_filter = args[:basic_filter] if args.key?(:basic_filter)
 | 
						|
          @charts = args[:charts] if args.key?(:charts)
 | 
						|
          @conditional_formats = args[:conditional_formats] if args.key?(:conditional_formats)
 | 
						|
          @data = args[:data] if args.key?(:data)
 | 
						|
          @developer_metadata = args[:developer_metadata] if args.key?(:developer_metadata)
 | 
						|
          @filter_views = args[:filter_views] if args.key?(:filter_views)
 | 
						|
          @merges = args[:merges] if args.key?(:merges)
 | 
						|
          @properties = args[:properties] if args.key?(:properties)
 | 
						|
          @protected_ranges = args[:protected_ranges] if args.key?(:protected_ranges)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Properties of a sheet.
 | 
						|
      class SheetProperties
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Properties of a grid.
 | 
						|
        # Corresponds to the JSON property `gridProperties`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridProperties]
 | 
						|
        attr_accessor :grid_properties
 | 
						|
      
 | 
						|
        # True if the sheet is hidden in the UI, false if it's visible.
 | 
						|
        # Corresponds to the JSON property `hidden`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :hidden
 | 
						|
        alias_method :hidden?, :hidden
 | 
						|
      
 | 
						|
        # The index of the sheet within the spreadsheet.
 | 
						|
        # When adding or updating sheet properties, if this field
 | 
						|
        # is excluded then the sheet will be added or moved to the end
 | 
						|
        # of the sheet list. When updating sheet indices or inserting
 | 
						|
        # sheets, movement is considered in "before the move" indexes.
 | 
						|
        # For example, if there were 3 sheets (S1, S2, S3) in order to
 | 
						|
        # move S1 ahead of S2 the index would have to be set to 2. A sheet
 | 
						|
        # index update request will be ignored if the requested index is
 | 
						|
        # identical to the sheets current index or if the requested new
 | 
						|
        # index is equal to the current sheet index + 1.
 | 
						|
        # Corresponds to the JSON property `index`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :index
 | 
						|
      
 | 
						|
        # True if the sheet is an RTL sheet instead of an LTR sheet.
 | 
						|
        # Corresponds to the JSON property `rightToLeft`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :right_to_left
 | 
						|
        alias_method :right_to_left?, :right_to_left
 | 
						|
      
 | 
						|
        # The ID of the sheet. Must be non-negative.
 | 
						|
        # This field cannot be changed once set.
 | 
						|
        # Corresponds to the JSON property `sheetId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :sheet_id
 | 
						|
      
 | 
						|
        # The type of sheet. Defaults to GRID.
 | 
						|
        # This field cannot be changed once set.
 | 
						|
        # Corresponds to the JSON property `sheetType`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :sheet_type
 | 
						|
      
 | 
						|
        # Represents a color in the RGBA color space. This representation is designed
 | 
						|
        # for simplicity of conversion to/from color representations in various
 | 
						|
        # languages over compactness; for example, the fields of this representation
 | 
						|
        # can be trivially provided to the constructor of "java.awt.Color" in Java; it
 | 
						|
        # can also be trivially provided to UIColor's "+colorWithRed:green:blue:alpha"
 | 
						|
        # method in iOS; and, with just a little work, it can be easily formatted into
 | 
						|
        # a CSS "rgba()" string in JavaScript, as well. Here are some examples:
 | 
						|
        # Example (Java):
 | 
						|
        # import com.google.type.Color;
 | 
						|
        # // ...
 | 
						|
        # public static java.awt.Color fromProto(Color protocolor) `
 | 
						|
        # float alpha = protocolor.hasAlpha()
 | 
						|
        # ? protocolor.getAlpha().getValue()
 | 
						|
        # : 1.0;
 | 
						|
        # return new java.awt.Color(
 | 
						|
        # protocolor.getRed(),
 | 
						|
        # protocolor.getGreen(),
 | 
						|
        # protocolor.getBlue(),
 | 
						|
        # alpha);
 | 
						|
        # `
 | 
						|
        # public static Color toProto(java.awt.Color color) `
 | 
						|
        # float red = (float) color.getRed();
 | 
						|
        # float green = (float) color.getGreen();
 | 
						|
        # float blue = (float) color.getBlue();
 | 
						|
        # float denominator = 255.0;
 | 
						|
        # Color.Builder resultBuilder =
 | 
						|
        # Color
 | 
						|
        # .newBuilder()
 | 
						|
        # .setRed(red / denominator)
 | 
						|
        # .setGreen(green / denominator)
 | 
						|
        # .setBlue(blue / denominator);
 | 
						|
        # int alpha = color.getAlpha();
 | 
						|
        # if (alpha != 255) `
 | 
						|
        # result.setAlpha(
 | 
						|
        # FloatValue
 | 
						|
        # .newBuilder()
 | 
						|
        # .setValue(((float) alpha) / denominator)
 | 
						|
        # .build());
 | 
						|
        # `
 | 
						|
        # return resultBuilder.build();
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (iOS / Obj-C):
 | 
						|
        # // ...
 | 
						|
        # static UIColor* fromProto(Color* protocolor) `
 | 
						|
        # float red = [protocolor red];
 | 
						|
        # float green = [protocolor green];
 | 
						|
        # float blue = [protocolor blue];
 | 
						|
        # FloatValue* alpha_wrapper = [protocolor alpha];
 | 
						|
        # float alpha = 1.0;
 | 
						|
        # if (alpha_wrapper != nil) `
 | 
						|
        # alpha = [alpha_wrapper value];
 | 
						|
        # `
 | 
						|
        # return [UIColor colorWithRed:red green:green blue:blue alpha:alpha];
 | 
						|
        # `
 | 
						|
        # static Color* toProto(UIColor* color) `
 | 
						|
        # CGFloat red, green, blue, alpha;
 | 
						|
        # if (![color getRed:&red green:&green blue:&blue alpha:&alpha]) `
 | 
						|
        # return nil;
 | 
						|
        # `
 | 
						|
        # Color* result = [Color alloc] init];
 | 
						|
        # [result setRed:red];
 | 
						|
        # [result setGreen:green];
 | 
						|
        # [result setBlue:blue];
 | 
						|
        # if (alpha <= 0.9999) `
 | 
						|
        # [result setAlpha:floatWrapperWithValue(alpha)];
 | 
						|
        # `
 | 
						|
        # [result autorelease];
 | 
						|
        # return result;
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (JavaScript):
 | 
						|
        # // ...
 | 
						|
        # var protoToCssColor = function(rgb_color) `
 | 
						|
        # var redFrac = rgb_color.red || 0.0;
 | 
						|
        # var greenFrac = rgb_color.green || 0.0;
 | 
						|
        # var blueFrac = rgb_color.blue || 0.0;
 | 
						|
        # var red = Math.floor(redFrac * 255);
 | 
						|
        # var green = Math.floor(greenFrac * 255);
 | 
						|
        # var blue = Math.floor(blueFrac * 255);
 | 
						|
        # if (!('alpha' in rgb_color)) `
 | 
						|
        # return rgbToCssColor_(red, green, blue);
 | 
						|
        # `
 | 
						|
        # var alphaFrac = rgb_color.alpha.value || 0.0;
 | 
						|
        # var rgbParams = [red, green, blue].join(',');
 | 
						|
        # return ['rgba(', rgbParams, ',', alphaFrac, ')'].join('');
 | 
						|
        # `;
 | 
						|
        # var rgbToCssColor_ = function(red, green, blue) `
 | 
						|
        # var rgbNumber = new Number((red << 16) | (green << 8) | blue);
 | 
						|
        # var hexString = rgbNumber.toString(16);
 | 
						|
        # var missingZeros = 6 - hexString.length;
 | 
						|
        # var resultBuilder = ['#'];
 | 
						|
        # for (var i = 0; i < missingZeros; i++) `
 | 
						|
        # resultBuilder.push('0');
 | 
						|
        # `
 | 
						|
        # resultBuilder.push(hexString);
 | 
						|
        # return resultBuilder.join('');
 | 
						|
        # `;
 | 
						|
        # // ...
 | 
						|
        # Corresponds to the JSON property `tabColor`
 | 
						|
        # @return [Google::Apis::SheetsV4::Color]
 | 
						|
        attr_accessor :tab_color
 | 
						|
      
 | 
						|
        # The name of the sheet.
 | 
						|
        # Corresponds to the JSON property `title`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :title
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @grid_properties = args[:grid_properties] if args.key?(:grid_properties)
 | 
						|
          @hidden = args[:hidden] if args.key?(:hidden)
 | 
						|
          @index = args[:index] if args.key?(:index)
 | 
						|
          @right_to_left = args[:right_to_left] if args.key?(:right_to_left)
 | 
						|
          @sheet_id = args[:sheet_id] if args.key?(:sheet_id)
 | 
						|
          @sheet_type = args[:sheet_type] if args.key?(:sheet_type)
 | 
						|
          @tab_color = args[:tab_color] if args.key?(:tab_color)
 | 
						|
          @title = args[:title] if args.key?(:title)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Sorts data in rows based on a sort order per column.
 | 
						|
      class SortRangeRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        # The sort order per column. Later specifications are used when values
 | 
						|
        # are equal in the earlier specifications.
 | 
						|
        # Corresponds to the JSON property `sortSpecs`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::SortSpec>]
 | 
						|
        attr_accessor :sort_specs
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
          @sort_specs = args[:sort_specs] if args.key?(:sort_specs)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A sort order associated with a specific column or row.
 | 
						|
      class SortSpec
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The dimension the sort should be applied to.
 | 
						|
        # Corresponds to the JSON property `dimensionIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :dimension_index
 | 
						|
      
 | 
						|
        # The order data should be sorted.
 | 
						|
        # Corresponds to the JSON property `sortOrder`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :sort_order
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @dimension_index = args[:dimension_index] if args.key?(:dimension_index)
 | 
						|
          @sort_order = args[:sort_order] if args.key?(:sort_order)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A combination of a source range and how to extend that source.
 | 
						|
      class SourceAndDestination
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The dimension that data should be filled into.
 | 
						|
        # Corresponds to the JSON property `dimension`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :dimension
 | 
						|
      
 | 
						|
        # The number of rows or columns that data should be filled into.
 | 
						|
        # Positive numbers expand beyond the last row or last column
 | 
						|
        # of the source.  Negative numbers expand before the first row
 | 
						|
        # or first column of the source.
 | 
						|
        # Corresponds to the JSON property `fillLength`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :fill_length
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `source`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :source
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @dimension = args[:dimension] if args.key?(:dimension)
 | 
						|
          @fill_length = args[:fill_length] if args.key?(:fill_length)
 | 
						|
          @source = args[:source] if args.key?(:source)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Resource that represents a spreadsheet.
 | 
						|
      class Spreadsheet
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The developer metadata associated with a spreadsheet.
 | 
						|
        # Corresponds to the JSON property `developerMetadata`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::DeveloperMetadata>]
 | 
						|
        attr_accessor :developer_metadata
 | 
						|
      
 | 
						|
        # The named ranges defined in a spreadsheet.
 | 
						|
        # Corresponds to the JSON property `namedRanges`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::NamedRange>]
 | 
						|
        attr_accessor :named_ranges
 | 
						|
      
 | 
						|
        # Properties of a spreadsheet.
 | 
						|
        # Corresponds to the JSON property `properties`
 | 
						|
        # @return [Google::Apis::SheetsV4::SpreadsheetProperties]
 | 
						|
        attr_accessor :properties
 | 
						|
      
 | 
						|
        # The sheets that are part of a spreadsheet.
 | 
						|
        # Corresponds to the JSON property `sheets`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::Sheet>]
 | 
						|
        attr_accessor :sheets
 | 
						|
      
 | 
						|
        # The ID of the spreadsheet.
 | 
						|
        # This field is read-only.
 | 
						|
        # Corresponds to the JSON property `spreadsheetId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :spreadsheet_id
 | 
						|
      
 | 
						|
        # The url of the spreadsheet.
 | 
						|
        # This field is read-only.
 | 
						|
        # Corresponds to the JSON property `spreadsheetUrl`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :spreadsheet_url
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @developer_metadata = args[:developer_metadata] if args.key?(:developer_metadata)
 | 
						|
          @named_ranges = args[:named_ranges] if args.key?(:named_ranges)
 | 
						|
          @properties = args[:properties] if args.key?(:properties)
 | 
						|
          @sheets = args[:sheets] if args.key?(:sheets)
 | 
						|
          @spreadsheet_id = args[:spreadsheet_id] if args.key?(:spreadsheet_id)
 | 
						|
          @spreadsheet_url = args[:spreadsheet_url] if args.key?(:spreadsheet_url)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Properties of a spreadsheet.
 | 
						|
      class SpreadsheetProperties
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The amount of time to wait before volatile functions are recalculated.
 | 
						|
        # Corresponds to the JSON property `autoRecalc`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :auto_recalc
 | 
						|
      
 | 
						|
        # The format of a cell.
 | 
						|
        # Corresponds to the JSON property `defaultFormat`
 | 
						|
        # @return [Google::Apis::SheetsV4::CellFormat]
 | 
						|
        attr_accessor :default_format
 | 
						|
      
 | 
						|
        # Settings to control how circular dependencies are resolved with iterative
 | 
						|
        # calculation.
 | 
						|
        # Corresponds to the JSON property `iterativeCalculationSettings`
 | 
						|
        # @return [Google::Apis::SheetsV4::IterativeCalculationSettings]
 | 
						|
        attr_accessor :iterative_calculation_settings
 | 
						|
      
 | 
						|
        # The locale of the spreadsheet in one of the following formats:
 | 
						|
        # * an ISO 639-1 language code such as `en`
 | 
						|
        # * an ISO 639-2 language code such as `fil`, if no 639-1 code exists
 | 
						|
        # * a combination of the ISO language code and country code, such as `en_US`
 | 
						|
        # Note: when updating this field, not all locales/languages are supported.
 | 
						|
        # Corresponds to the JSON property `locale`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :locale
 | 
						|
      
 | 
						|
        # The time zone of the spreadsheet, in CLDR format such as
 | 
						|
        # `America/New_York`. If the time zone isn't recognized, this may
 | 
						|
        # be a custom time zone such as `GMT-07:00`.
 | 
						|
        # Corresponds to the JSON property `timeZone`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :time_zone
 | 
						|
      
 | 
						|
        # The title of the spreadsheet.
 | 
						|
        # Corresponds to the JSON property `title`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :title
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @auto_recalc = args[:auto_recalc] if args.key?(:auto_recalc)
 | 
						|
          @default_format = args[:default_format] if args.key?(:default_format)
 | 
						|
          @iterative_calculation_settings = args[:iterative_calculation_settings] if args.key?(:iterative_calculation_settings)
 | 
						|
          @locale = args[:locale] if args.key?(:locale)
 | 
						|
          @time_zone = args[:time_zone] if args.key?(:time_zone)
 | 
						|
          @title = args[:title] if args.key?(:title)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The format of a run of text in a cell.
 | 
						|
      # Absent values indicate that the field isn't specified.
 | 
						|
      class TextFormat
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # True if the text is bold.
 | 
						|
        # Corresponds to the JSON property `bold`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :bold
 | 
						|
        alias_method :bold?, :bold
 | 
						|
      
 | 
						|
        # The font family.
 | 
						|
        # Corresponds to the JSON property `fontFamily`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :font_family
 | 
						|
      
 | 
						|
        # The size of the font.
 | 
						|
        # Corresponds to the JSON property `fontSize`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :font_size
 | 
						|
      
 | 
						|
        # Represents a color in the RGBA color space. This representation is designed
 | 
						|
        # for simplicity of conversion to/from color representations in various
 | 
						|
        # languages over compactness; for example, the fields of this representation
 | 
						|
        # can be trivially provided to the constructor of "java.awt.Color" in Java; it
 | 
						|
        # can also be trivially provided to UIColor's "+colorWithRed:green:blue:alpha"
 | 
						|
        # method in iOS; and, with just a little work, it can be easily formatted into
 | 
						|
        # a CSS "rgba()" string in JavaScript, as well. Here are some examples:
 | 
						|
        # Example (Java):
 | 
						|
        # import com.google.type.Color;
 | 
						|
        # // ...
 | 
						|
        # public static java.awt.Color fromProto(Color protocolor) `
 | 
						|
        # float alpha = protocolor.hasAlpha()
 | 
						|
        # ? protocolor.getAlpha().getValue()
 | 
						|
        # : 1.0;
 | 
						|
        # return new java.awt.Color(
 | 
						|
        # protocolor.getRed(),
 | 
						|
        # protocolor.getGreen(),
 | 
						|
        # protocolor.getBlue(),
 | 
						|
        # alpha);
 | 
						|
        # `
 | 
						|
        # public static Color toProto(java.awt.Color color) `
 | 
						|
        # float red = (float) color.getRed();
 | 
						|
        # float green = (float) color.getGreen();
 | 
						|
        # float blue = (float) color.getBlue();
 | 
						|
        # float denominator = 255.0;
 | 
						|
        # Color.Builder resultBuilder =
 | 
						|
        # Color
 | 
						|
        # .newBuilder()
 | 
						|
        # .setRed(red / denominator)
 | 
						|
        # .setGreen(green / denominator)
 | 
						|
        # .setBlue(blue / denominator);
 | 
						|
        # int alpha = color.getAlpha();
 | 
						|
        # if (alpha != 255) `
 | 
						|
        # result.setAlpha(
 | 
						|
        # FloatValue
 | 
						|
        # .newBuilder()
 | 
						|
        # .setValue(((float) alpha) / denominator)
 | 
						|
        # .build());
 | 
						|
        # `
 | 
						|
        # return resultBuilder.build();
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (iOS / Obj-C):
 | 
						|
        # // ...
 | 
						|
        # static UIColor* fromProto(Color* protocolor) `
 | 
						|
        # float red = [protocolor red];
 | 
						|
        # float green = [protocolor green];
 | 
						|
        # float blue = [protocolor blue];
 | 
						|
        # FloatValue* alpha_wrapper = [protocolor alpha];
 | 
						|
        # float alpha = 1.0;
 | 
						|
        # if (alpha_wrapper != nil) `
 | 
						|
        # alpha = [alpha_wrapper value];
 | 
						|
        # `
 | 
						|
        # return [UIColor colorWithRed:red green:green blue:blue alpha:alpha];
 | 
						|
        # `
 | 
						|
        # static Color* toProto(UIColor* color) `
 | 
						|
        # CGFloat red, green, blue, alpha;
 | 
						|
        # if (![color getRed:&red green:&green blue:&blue alpha:&alpha]) `
 | 
						|
        # return nil;
 | 
						|
        # `
 | 
						|
        # Color* result = [Color alloc] init];
 | 
						|
        # [result setRed:red];
 | 
						|
        # [result setGreen:green];
 | 
						|
        # [result setBlue:blue];
 | 
						|
        # if (alpha <= 0.9999) `
 | 
						|
        # [result setAlpha:floatWrapperWithValue(alpha)];
 | 
						|
        # `
 | 
						|
        # [result autorelease];
 | 
						|
        # return result;
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (JavaScript):
 | 
						|
        # // ...
 | 
						|
        # var protoToCssColor = function(rgb_color) `
 | 
						|
        # var redFrac = rgb_color.red || 0.0;
 | 
						|
        # var greenFrac = rgb_color.green || 0.0;
 | 
						|
        # var blueFrac = rgb_color.blue || 0.0;
 | 
						|
        # var red = Math.floor(redFrac * 255);
 | 
						|
        # var green = Math.floor(greenFrac * 255);
 | 
						|
        # var blue = Math.floor(blueFrac * 255);
 | 
						|
        # if (!('alpha' in rgb_color)) `
 | 
						|
        # return rgbToCssColor_(red, green, blue);
 | 
						|
        # `
 | 
						|
        # var alphaFrac = rgb_color.alpha.value || 0.0;
 | 
						|
        # var rgbParams = [red, green, blue].join(',');
 | 
						|
        # return ['rgba(', rgbParams, ',', alphaFrac, ')'].join('');
 | 
						|
        # `;
 | 
						|
        # var rgbToCssColor_ = function(red, green, blue) `
 | 
						|
        # var rgbNumber = new Number((red << 16) | (green << 8) | blue);
 | 
						|
        # var hexString = rgbNumber.toString(16);
 | 
						|
        # var missingZeros = 6 - hexString.length;
 | 
						|
        # var resultBuilder = ['#'];
 | 
						|
        # for (var i = 0; i < missingZeros; i++) `
 | 
						|
        # resultBuilder.push('0');
 | 
						|
        # `
 | 
						|
        # resultBuilder.push(hexString);
 | 
						|
        # return resultBuilder.join('');
 | 
						|
        # `;
 | 
						|
        # // ...
 | 
						|
        # Corresponds to the JSON property `foregroundColor`
 | 
						|
        # @return [Google::Apis::SheetsV4::Color]
 | 
						|
        attr_accessor :foreground_color
 | 
						|
      
 | 
						|
        # True if the text is italicized.
 | 
						|
        # Corresponds to the JSON property `italic`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :italic
 | 
						|
        alias_method :italic?, :italic
 | 
						|
      
 | 
						|
        # True if the text has a strikethrough.
 | 
						|
        # Corresponds to the JSON property `strikethrough`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :strikethrough
 | 
						|
        alias_method :strikethrough?, :strikethrough
 | 
						|
      
 | 
						|
        # True if the text is underlined.
 | 
						|
        # Corresponds to the JSON property `underline`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :underline
 | 
						|
        alias_method :underline?, :underline
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @bold = args[:bold] if args.key?(:bold)
 | 
						|
          @font_family = args[:font_family] if args.key?(:font_family)
 | 
						|
          @font_size = args[:font_size] if args.key?(:font_size)
 | 
						|
          @foreground_color = args[:foreground_color] if args.key?(:foreground_color)
 | 
						|
          @italic = args[:italic] if args.key?(:italic)
 | 
						|
          @strikethrough = args[:strikethrough] if args.key?(:strikethrough)
 | 
						|
          @underline = args[:underline] if args.key?(:underline)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A run of a text format. The format of this run continues until the start
 | 
						|
      # index of the next run.
 | 
						|
      # When updating, all fields must be set.
 | 
						|
      class TextFormatRun
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The format of a run of text in a cell.
 | 
						|
        # Absent values indicate that the field isn't specified.
 | 
						|
        # Corresponds to the JSON property `format`
 | 
						|
        # @return [Google::Apis::SheetsV4::TextFormat]
 | 
						|
        attr_accessor :format
 | 
						|
      
 | 
						|
        # The character index where this run starts.
 | 
						|
        # Corresponds to the JSON property `startIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :start_index
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @format = args[:format] if args.key?(:format)
 | 
						|
          @start_index = args[:start_index] if args.key?(:start_index)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Position settings for text.
 | 
						|
      class TextPosition
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Horizontal alignment setting for the piece of text.
 | 
						|
        # Corresponds to the JSON property `horizontalAlignment`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :horizontal_alignment
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @horizontal_alignment = args[:horizontal_alignment] if args.key?(:horizontal_alignment)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The rotation applied to text in a cell.
 | 
						|
      class TextRotation
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The angle between the standard orientation and the desired orientation.
 | 
						|
        # Measured in degrees. Valid values are between -90 and 90. Positive
 | 
						|
        # angles are angled upwards, negative are angled downwards.
 | 
						|
        # Note: For LTR text direction positive angles are in the counterclockwise
 | 
						|
        # direction, whereas for RTL they are in the clockwise direction
 | 
						|
        # Corresponds to the JSON property `angle`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :angle
 | 
						|
      
 | 
						|
        # If true, text reads top to bottom, but the orientation of individual
 | 
						|
        # characters is unchanged.
 | 
						|
        # For example:
 | 
						|
        # | V |
 | 
						|
        # | e |
 | 
						|
        # | r |
 | 
						|
        # | t |
 | 
						|
        # | i |
 | 
						|
        # | c |
 | 
						|
        # | a |
 | 
						|
        # | l |
 | 
						|
        # Corresponds to the JSON property `vertical`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :vertical
 | 
						|
        alias_method :vertical?, :vertical
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @angle = args[:angle] if args.key?(:angle)
 | 
						|
          @vertical = args[:vertical] if args.key?(:vertical)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Splits a column of text into multiple columns,
 | 
						|
      # based on a delimiter in each cell.
 | 
						|
      class TextToColumnsRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The delimiter to use. Used only if delimiterType is
 | 
						|
        # CUSTOM.
 | 
						|
        # Corresponds to the JSON property `delimiter`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :delimiter
 | 
						|
      
 | 
						|
        # The delimiter type to use.
 | 
						|
        # Corresponds to the JSON property `delimiterType`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :delimiter_type
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `source`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :source
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @delimiter = args[:delimiter] if args.key?(:delimiter)
 | 
						|
          @delimiter_type = args[:delimiter_type] if args.key?(:delimiter_type)
 | 
						|
          @source = args[:source] if args.key?(:source)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Unmerges cells in the given range.
 | 
						|
      class UnmergeCellsRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Updates properties of the supplied banded range.
 | 
						|
      class UpdateBandingRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A banded (alternating colors) range in a sheet.
 | 
						|
        # Corresponds to the JSON property `bandedRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::BandedRange]
 | 
						|
        attr_accessor :banded_range
 | 
						|
      
 | 
						|
        # The fields that should be updated.  At least one field must be specified.
 | 
						|
        # The root `bandedRange` is implied and should not be specified.
 | 
						|
        # A single `"*"` can be used as short-hand for listing every field.
 | 
						|
        # Corresponds to the JSON property `fields`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :fields
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @banded_range = args[:banded_range] if args.key?(:banded_range)
 | 
						|
          @fields = args[:fields] if args.key?(:fields)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Updates the borders of a range.
 | 
						|
      # If a field is not set in the request, that means the border remains as-is.
 | 
						|
      # For example, with two subsequent UpdateBordersRequest:
 | 
						|
      # 1. range: A1:A5 `` top: RED, bottom: WHITE ``
 | 
						|
      # 2. range: A1:A5 `` left: BLUE ``
 | 
						|
      # That would result in A1:A5 having a borders of
 | 
						|
      # `` top: RED, bottom: WHITE, left: BLUE ``.
 | 
						|
      # If you want to clear a border, explicitly set the style to
 | 
						|
      # NONE.
 | 
						|
      class UpdateBordersRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A border along a cell.
 | 
						|
        # Corresponds to the JSON property `bottom`
 | 
						|
        # @return [Google::Apis::SheetsV4::Border]
 | 
						|
        attr_accessor :bottom
 | 
						|
      
 | 
						|
        # A border along a cell.
 | 
						|
        # Corresponds to the JSON property `innerHorizontal`
 | 
						|
        # @return [Google::Apis::SheetsV4::Border]
 | 
						|
        attr_accessor :inner_horizontal
 | 
						|
      
 | 
						|
        # A border along a cell.
 | 
						|
        # Corresponds to the JSON property `innerVertical`
 | 
						|
        # @return [Google::Apis::SheetsV4::Border]
 | 
						|
        attr_accessor :inner_vertical
 | 
						|
      
 | 
						|
        # A border along a cell.
 | 
						|
        # Corresponds to the JSON property `left`
 | 
						|
        # @return [Google::Apis::SheetsV4::Border]
 | 
						|
        attr_accessor :left
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        # A border along a cell.
 | 
						|
        # Corresponds to the JSON property `right`
 | 
						|
        # @return [Google::Apis::SheetsV4::Border]
 | 
						|
        attr_accessor :right
 | 
						|
      
 | 
						|
        # A border along a cell.
 | 
						|
        # Corresponds to the JSON property `top`
 | 
						|
        # @return [Google::Apis::SheetsV4::Border]
 | 
						|
        attr_accessor :top
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @bottom = args[:bottom] if args.key?(:bottom)
 | 
						|
          @inner_horizontal = args[:inner_horizontal] if args.key?(:inner_horizontal)
 | 
						|
          @inner_vertical = args[:inner_vertical] if args.key?(:inner_vertical)
 | 
						|
          @left = args[:left] if args.key?(:left)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
          @right = args[:right] if args.key?(:right)
 | 
						|
          @top = args[:top] if args.key?(:top)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Updates all cells in a range with new data.
 | 
						|
      class UpdateCellsRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The fields of CellData that should be updated.
 | 
						|
        # At least one field must be specified.
 | 
						|
        # The root is the CellData; 'row.values.' should not be specified.
 | 
						|
        # A single `"*"` can be used as short-hand for listing every field.
 | 
						|
        # Corresponds to the JSON property `fields`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :fields
 | 
						|
      
 | 
						|
        # A range on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open, e.g the start index is inclusive
 | 
						|
        # and the end index is exclusive -- [start_index, end_index).
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # For example, if `"Sheet1"` is sheet ID 0, then:
 | 
						|
        # `Sheet1!A1:A1 == sheet_id: 0,
 | 
						|
        # start_row_index: 0, end_row_index: 1,
 | 
						|
        # start_column_index: 0, end_column_index: 1`
 | 
						|
        # `Sheet1!A3:B4 == sheet_id: 0,
 | 
						|
        # start_row_index: 2, end_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A:B == sheet_id: 0,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1!A5:B == sheet_id: 0,
 | 
						|
        # start_row_index: 4,
 | 
						|
        # start_column_index: 0, end_column_index: 2`
 | 
						|
        # `Sheet1 == sheet_id:0`
 | 
						|
        # The start index must always be less than or equal to the end index.
 | 
						|
        # If the start index equals the end index, then the range is empty.
 | 
						|
        # Empty ranges are typically not meaningful and are usually rendered in the
 | 
						|
        # UI as `#REF!`.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        # The data to write.
 | 
						|
        # Corresponds to the JSON property `rows`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::RowData>]
 | 
						|
        attr_accessor :rows
 | 
						|
      
 | 
						|
        # A coordinate in a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Corresponds to the JSON property `start`
 | 
						|
        # @return [Google::Apis::SheetsV4::GridCoordinate]
 | 
						|
        attr_accessor :start
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @fields = args[:fields] if args.key?(:fields)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
          @rows = args[:rows] if args.key?(:rows)
 | 
						|
          @start = args[:start] if args.key?(:start)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Updates a chart's specifications.
 | 
						|
      # (This does not move or resize a chart. To move or resize a chart, use
 | 
						|
      # UpdateEmbeddedObjectPositionRequest.)
 | 
						|
      class UpdateChartSpecRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The ID of the chart to update.
 | 
						|
        # Corresponds to the JSON property `chartId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :chart_id
 | 
						|
      
 | 
						|
        # The specifications of a chart.
 | 
						|
        # Corresponds to the JSON property `spec`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartSpec]
 | 
						|
        attr_accessor :spec
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @chart_id = args[:chart_id] if args.key?(:chart_id)
 | 
						|
          @spec = args[:spec] if args.key?(:spec)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Updates a conditional format rule at the given index,
 | 
						|
      # or moves a conditional format rule to another index.
 | 
						|
      class UpdateConditionalFormatRuleRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The zero-based index of the rule that should be replaced or moved.
 | 
						|
        # Corresponds to the JSON property `index`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :index
 | 
						|
      
 | 
						|
        # The zero-based new index the rule should end up at.
 | 
						|
        # Corresponds to the JSON property `newIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :new_index
 | 
						|
      
 | 
						|
        # A rule describing a conditional format.
 | 
						|
        # Corresponds to the JSON property `rule`
 | 
						|
        # @return [Google::Apis::SheetsV4::ConditionalFormatRule]
 | 
						|
        attr_accessor :rule
 | 
						|
      
 | 
						|
        # The sheet of the rule to move.  Required if new_index is set,
 | 
						|
        # unused otherwise.
 | 
						|
        # Corresponds to the JSON property `sheetId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :sheet_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @index = args[:index] if args.key?(:index)
 | 
						|
          @new_index = args[:new_index] if args.key?(:new_index)
 | 
						|
          @rule = args[:rule] if args.key?(:rule)
 | 
						|
          @sheet_id = args[:sheet_id] if args.key?(:sheet_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The result of updating a conditional format rule.
 | 
						|
      class UpdateConditionalFormatRuleResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The index of the new rule.
 | 
						|
        # Corresponds to the JSON property `newIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :new_index
 | 
						|
      
 | 
						|
        # A rule describing a conditional format.
 | 
						|
        # Corresponds to the JSON property `newRule`
 | 
						|
        # @return [Google::Apis::SheetsV4::ConditionalFormatRule]
 | 
						|
        attr_accessor :new_rule
 | 
						|
      
 | 
						|
        # The old index of the rule. Not set if a rule was replaced
 | 
						|
        # (because it is the same as new_index).
 | 
						|
        # Corresponds to the JSON property `oldIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :old_index
 | 
						|
      
 | 
						|
        # A rule describing a conditional format.
 | 
						|
        # Corresponds to the JSON property `oldRule`
 | 
						|
        # @return [Google::Apis::SheetsV4::ConditionalFormatRule]
 | 
						|
        attr_accessor :old_rule
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @new_index = args[:new_index] if args.key?(:new_index)
 | 
						|
          @new_rule = args[:new_rule] if args.key?(:new_rule)
 | 
						|
          @old_index = args[:old_index] if args.key?(:old_index)
 | 
						|
          @old_rule = args[:old_rule] if args.key?(:old_rule)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A request to update properties of developer metadata.
 | 
						|
      # Updates the properties of the developer metadata selected by the filters to
 | 
						|
      # the values provided in the DeveloperMetadata resource.  Callers must
 | 
						|
      # specify the properties they wish to update in the fields parameter, as well
 | 
						|
      # as specify at least one DataFilter matching the metadata they wish to
 | 
						|
      # update.
 | 
						|
      class UpdateDeveloperMetadataRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The filters matching the developer metadata entries to update.
 | 
						|
        # Corresponds to the JSON property `dataFilters`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::DataFilter>]
 | 
						|
        attr_accessor :data_filters
 | 
						|
      
 | 
						|
        # Developer metadata associated with a location or object in a spreadsheet.
 | 
						|
        # Developer metadata may be used to associate arbitrary data with various
 | 
						|
        # parts of a spreadsheet and will remain associated at those locations as they
 | 
						|
        # move around and the spreadsheet is edited.  For example, if developer
 | 
						|
        # metadata is associated with row 5 and another row is then subsequently
 | 
						|
        # inserted above row 5, that original metadata will still be associated with
 | 
						|
        # the row it was first associated with (what is now row 6). If the associated
 | 
						|
        # object is deleted its metadata will be deleted too.
 | 
						|
        # Corresponds to the JSON property `developerMetadata`
 | 
						|
        # @return [Google::Apis::SheetsV4::DeveloperMetadata]
 | 
						|
        attr_accessor :developer_metadata
 | 
						|
      
 | 
						|
        # The fields that should be updated.  At least one field must be specified.
 | 
						|
        # The root `developerMetadata` is implied and should not be specified.
 | 
						|
        # A single `"*"` can be used as short-hand for listing every field.
 | 
						|
        # Corresponds to the JSON property `fields`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :fields
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data_filters = args[:data_filters] if args.key?(:data_filters)
 | 
						|
          @developer_metadata = args[:developer_metadata] if args.key?(:developer_metadata)
 | 
						|
          @fields = args[:fields] if args.key?(:fields)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The response from updating developer metadata.
 | 
						|
      class UpdateDeveloperMetadataResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The updated developer metadata.
 | 
						|
        # Corresponds to the JSON property `developerMetadata`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::DeveloperMetadata>]
 | 
						|
        attr_accessor :developer_metadata
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @developer_metadata = args[:developer_metadata] if args.key?(:developer_metadata)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Updates properties of dimensions within the specified range.
 | 
						|
      class UpdateDimensionPropertiesRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The fields that should be updated.  At least one field must be specified.
 | 
						|
        # The root `properties` is implied and should not be specified.
 | 
						|
        # A single `"*"` can be used as short-hand for listing every field.
 | 
						|
        # Corresponds to the JSON property `fields`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :fields
 | 
						|
      
 | 
						|
        # Properties about a dimension.
 | 
						|
        # Corresponds to the JSON property `properties`
 | 
						|
        # @return [Google::Apis::SheetsV4::DimensionProperties]
 | 
						|
        attr_accessor :properties
 | 
						|
      
 | 
						|
        # A range along a single dimension on a sheet.
 | 
						|
        # All indexes are zero-based.
 | 
						|
        # Indexes are half open: the start index is inclusive
 | 
						|
        # and the end index is exclusive.
 | 
						|
        # Missing indexes indicate the range is unbounded on that side.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [Google::Apis::SheetsV4::DimensionRange]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @fields = args[:fields] if args.key?(:fields)
 | 
						|
          @properties = args[:properties] if args.key?(:properties)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Update an embedded object's position (such as a moving or resizing a
 | 
						|
      # chart or image).
 | 
						|
      class UpdateEmbeddedObjectPositionRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The fields of OverlayPosition
 | 
						|
        # that should be updated when setting a new position. Used only if
 | 
						|
        # newPosition.overlayPosition
 | 
						|
        # is set, in which case at least one field must
 | 
						|
        # be specified.  The root `newPosition.overlayPosition` is implied and
 | 
						|
        # should not be specified.
 | 
						|
        # A single `"*"` can be used as short-hand for listing every field.
 | 
						|
        # Corresponds to the JSON property `fields`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :fields
 | 
						|
      
 | 
						|
        # The position of an embedded object such as a chart.
 | 
						|
        # Corresponds to the JSON property `newPosition`
 | 
						|
        # @return [Google::Apis::SheetsV4::EmbeddedObjectPosition]
 | 
						|
        attr_accessor :new_position
 | 
						|
      
 | 
						|
        # The ID of the object to moved.
 | 
						|
        # Corresponds to the JSON property `objectId`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :object_id_prop
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @fields = args[:fields] if args.key?(:fields)
 | 
						|
          @new_position = args[:new_position] if args.key?(:new_position)
 | 
						|
          @object_id_prop = args[:object_id_prop] if args.key?(:object_id_prop)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The result of updating an embedded object's position.
 | 
						|
      class UpdateEmbeddedObjectPositionResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The position of an embedded object such as a chart.
 | 
						|
        # Corresponds to the JSON property `position`
 | 
						|
        # @return [Google::Apis::SheetsV4::EmbeddedObjectPosition]
 | 
						|
        attr_accessor :position
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @position = args[:position] if args.key?(:position)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Updates properties of the filter view.
 | 
						|
      class UpdateFilterViewRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The fields that should be updated.  At least one field must be specified.
 | 
						|
        # The root `filter` is implied and should not be specified.
 | 
						|
        # A single `"*"` can be used as short-hand for listing every field.
 | 
						|
        # Corresponds to the JSON property `fields`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :fields
 | 
						|
      
 | 
						|
        # A filter view.
 | 
						|
        # Corresponds to the JSON property `filter`
 | 
						|
        # @return [Google::Apis::SheetsV4::FilterView]
 | 
						|
        attr_accessor :filter
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @fields = args[:fields] if args.key?(:fields)
 | 
						|
          @filter = args[:filter] if args.key?(:filter)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Updates properties of the named range with the specified
 | 
						|
      # namedRangeId.
 | 
						|
      class UpdateNamedRangeRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The fields that should be updated.  At least one field must be specified.
 | 
						|
        # The root `namedRange` is implied and should not be specified.
 | 
						|
        # A single `"*"` can be used as short-hand for listing every field.
 | 
						|
        # Corresponds to the JSON property `fields`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :fields
 | 
						|
      
 | 
						|
        # A named range.
 | 
						|
        # Corresponds to the JSON property `namedRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::NamedRange]
 | 
						|
        attr_accessor :named_range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @fields = args[:fields] if args.key?(:fields)
 | 
						|
          @named_range = args[:named_range] if args.key?(:named_range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Updates an existing protected range with the specified
 | 
						|
      # protectedRangeId.
 | 
						|
      class UpdateProtectedRangeRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The fields that should be updated.  At least one field must be specified.
 | 
						|
        # The root `protectedRange` is implied and should not be specified.
 | 
						|
        # A single `"*"` can be used as short-hand for listing every field.
 | 
						|
        # Corresponds to the JSON property `fields`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :fields
 | 
						|
      
 | 
						|
        # A protected range.
 | 
						|
        # Corresponds to the JSON property `protectedRange`
 | 
						|
        # @return [Google::Apis::SheetsV4::ProtectedRange]
 | 
						|
        attr_accessor :protected_range
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @fields = args[:fields] if args.key?(:fields)
 | 
						|
          @protected_range = args[:protected_range] if args.key?(:protected_range)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Updates properties of the sheet with the specified
 | 
						|
      # sheetId.
 | 
						|
      class UpdateSheetPropertiesRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The fields that should be updated.  At least one field must be specified.
 | 
						|
        # The root `properties` is implied and should not be specified.
 | 
						|
        # A single `"*"` can be used as short-hand for listing every field.
 | 
						|
        # Corresponds to the JSON property `fields`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :fields
 | 
						|
      
 | 
						|
        # Properties of a sheet.
 | 
						|
        # Corresponds to the JSON property `properties`
 | 
						|
        # @return [Google::Apis::SheetsV4::SheetProperties]
 | 
						|
        attr_accessor :properties
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @fields = args[:fields] if args.key?(:fields)
 | 
						|
          @properties = args[:properties] if args.key?(:properties)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Updates properties of a spreadsheet.
 | 
						|
      class UpdateSpreadsheetPropertiesRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The fields that should be updated.  At least one field must be specified.
 | 
						|
        # The root 'properties' is implied and should not be specified.
 | 
						|
        # A single `"*"` can be used as short-hand for listing every field.
 | 
						|
        # Corresponds to the JSON property `fields`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :fields
 | 
						|
      
 | 
						|
        # Properties of a spreadsheet.
 | 
						|
        # Corresponds to the JSON property `properties`
 | 
						|
        # @return [Google::Apis::SheetsV4::SpreadsheetProperties]
 | 
						|
        attr_accessor :properties
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @fields = args[:fields] if args.key?(:fields)
 | 
						|
          @properties = args[:properties] if args.key?(:properties)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The response when updating a range of values by a data filter in a
 | 
						|
      # spreadsheet.
 | 
						|
      class UpdateValuesByDataFilterResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Filter that describes what data should be selected or returned from a
 | 
						|
        # request.
 | 
						|
        # Corresponds to the JSON property `dataFilter`
 | 
						|
        # @return [Google::Apis::SheetsV4::DataFilter]
 | 
						|
        attr_accessor :data_filter
 | 
						|
      
 | 
						|
        # The number of cells updated.
 | 
						|
        # Corresponds to the JSON property `updatedCells`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :updated_cells
 | 
						|
      
 | 
						|
        # The number of columns where at least one cell in the column was updated.
 | 
						|
        # Corresponds to the JSON property `updatedColumns`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :updated_columns
 | 
						|
      
 | 
						|
        # Data within a range of the spreadsheet.
 | 
						|
        # Corresponds to the JSON property `updatedData`
 | 
						|
        # @return [Google::Apis::SheetsV4::ValueRange]
 | 
						|
        attr_accessor :updated_data
 | 
						|
      
 | 
						|
        # The range (in A1 notation) that updates were applied to.
 | 
						|
        # Corresponds to the JSON property `updatedRange`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :updated_range
 | 
						|
      
 | 
						|
        # The number of rows where at least one cell in the row was updated.
 | 
						|
        # Corresponds to the JSON property `updatedRows`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :updated_rows
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data_filter = args[:data_filter] if args.key?(:data_filter)
 | 
						|
          @updated_cells = args[:updated_cells] if args.key?(:updated_cells)
 | 
						|
          @updated_columns = args[:updated_columns] if args.key?(:updated_columns)
 | 
						|
          @updated_data = args[:updated_data] if args.key?(:updated_data)
 | 
						|
          @updated_range = args[:updated_range] if args.key?(:updated_range)
 | 
						|
          @updated_rows = args[:updated_rows] if args.key?(:updated_rows)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The response when updating a range of values in a spreadsheet.
 | 
						|
      class UpdateValuesResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The spreadsheet the updates were applied to.
 | 
						|
        # Corresponds to the JSON property `spreadsheetId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :spreadsheet_id
 | 
						|
      
 | 
						|
        # The number of cells updated.
 | 
						|
        # Corresponds to the JSON property `updatedCells`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :updated_cells
 | 
						|
      
 | 
						|
        # The number of columns where at least one cell in the column was updated.
 | 
						|
        # Corresponds to the JSON property `updatedColumns`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :updated_columns
 | 
						|
      
 | 
						|
        # Data within a range of the spreadsheet.
 | 
						|
        # Corresponds to the JSON property `updatedData`
 | 
						|
        # @return [Google::Apis::SheetsV4::ValueRange]
 | 
						|
        attr_accessor :updated_data
 | 
						|
      
 | 
						|
        # The range (in A1 notation) that updates were applied to.
 | 
						|
        # Corresponds to the JSON property `updatedRange`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :updated_range
 | 
						|
      
 | 
						|
        # The number of rows where at least one cell in the row was updated.
 | 
						|
        # Corresponds to the JSON property `updatedRows`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :updated_rows
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @spreadsheet_id = args[:spreadsheet_id] if args.key?(:spreadsheet_id)
 | 
						|
          @updated_cells = args[:updated_cells] if args.key?(:updated_cells)
 | 
						|
          @updated_columns = args[:updated_columns] if args.key?(:updated_columns)
 | 
						|
          @updated_data = args[:updated_data] if args.key?(:updated_data)
 | 
						|
          @updated_range = args[:updated_range] if args.key?(:updated_range)
 | 
						|
          @updated_rows = args[:updated_rows] if args.key?(:updated_rows)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Data within a range of the spreadsheet.
 | 
						|
      class ValueRange
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The major dimension of the values.
 | 
						|
        # For output, if the spreadsheet data is: `A1=1,B1=2,A2=3,B2=4`,
 | 
						|
        # then requesting `range=A1:B2,majorDimension=ROWS` will return
 | 
						|
        # `[[1,2],[3,4]]`,
 | 
						|
        # whereas requesting `range=A1:B2,majorDimension=COLUMNS` will return
 | 
						|
        # `[[1,3],[2,4]]`.
 | 
						|
        # For input, with `range=A1:B2,majorDimension=ROWS` then `[[1,2],[3,4]]`
 | 
						|
        # will set `A1=1,B1=2,A2=3,B2=4`. With `range=A1:B2,majorDimension=COLUMNS`
 | 
						|
        # then `[[1,2],[3,4]]` will set `A1=1,B1=3,A2=2,B2=4`.
 | 
						|
        # When writing, if this field is not set, it defaults to ROWS.
 | 
						|
        # Corresponds to the JSON property `majorDimension`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :major_dimension
 | 
						|
      
 | 
						|
        # The range the values cover, in A1 notation.
 | 
						|
        # For output, this range indicates the entire requested range,
 | 
						|
        # even though the values will exclude trailing rows and columns.
 | 
						|
        # When appending values, this field represents the range to search for a
 | 
						|
        # table, after which values will be appended.
 | 
						|
        # Corresponds to the JSON property `range`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :range
 | 
						|
      
 | 
						|
        # The data that was read or to be written.  This is an array of arrays,
 | 
						|
        # the outer array representing all the data and each inner array
 | 
						|
        # representing a major dimension. Each item in the inner array
 | 
						|
        # corresponds with one cell.
 | 
						|
        # For output, empty trailing rows and columns will not be included.
 | 
						|
        # For input, supported value types are: bool, string, and double.
 | 
						|
        # Null values will be skipped.
 | 
						|
        # To set a cell to an empty value, set the string value to an empty string.
 | 
						|
        # Corresponds to the JSON property `values`
 | 
						|
        # @return [Array<Array<Object>>]
 | 
						|
        attr_accessor :values
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @major_dimension = args[:major_dimension] if args.key?(:major_dimension)
 | 
						|
          @range = args[:range] if args.key?(:range)
 | 
						|
          @values = args[:values] if args.key?(:values)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Styles for a waterfall chart column.
 | 
						|
      class WaterfallChartColumnStyle
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Represents a color in the RGBA color space. This representation is designed
 | 
						|
        # for simplicity of conversion to/from color representations in various
 | 
						|
        # languages over compactness; for example, the fields of this representation
 | 
						|
        # can be trivially provided to the constructor of "java.awt.Color" in Java; it
 | 
						|
        # can also be trivially provided to UIColor's "+colorWithRed:green:blue:alpha"
 | 
						|
        # method in iOS; and, with just a little work, it can be easily formatted into
 | 
						|
        # a CSS "rgba()" string in JavaScript, as well. Here are some examples:
 | 
						|
        # Example (Java):
 | 
						|
        # import com.google.type.Color;
 | 
						|
        # // ...
 | 
						|
        # public static java.awt.Color fromProto(Color protocolor) `
 | 
						|
        # float alpha = protocolor.hasAlpha()
 | 
						|
        # ? protocolor.getAlpha().getValue()
 | 
						|
        # : 1.0;
 | 
						|
        # return new java.awt.Color(
 | 
						|
        # protocolor.getRed(),
 | 
						|
        # protocolor.getGreen(),
 | 
						|
        # protocolor.getBlue(),
 | 
						|
        # alpha);
 | 
						|
        # `
 | 
						|
        # public static Color toProto(java.awt.Color color) `
 | 
						|
        # float red = (float) color.getRed();
 | 
						|
        # float green = (float) color.getGreen();
 | 
						|
        # float blue = (float) color.getBlue();
 | 
						|
        # float denominator = 255.0;
 | 
						|
        # Color.Builder resultBuilder =
 | 
						|
        # Color
 | 
						|
        # .newBuilder()
 | 
						|
        # .setRed(red / denominator)
 | 
						|
        # .setGreen(green / denominator)
 | 
						|
        # .setBlue(blue / denominator);
 | 
						|
        # int alpha = color.getAlpha();
 | 
						|
        # if (alpha != 255) `
 | 
						|
        # result.setAlpha(
 | 
						|
        # FloatValue
 | 
						|
        # .newBuilder()
 | 
						|
        # .setValue(((float) alpha) / denominator)
 | 
						|
        # .build());
 | 
						|
        # `
 | 
						|
        # return resultBuilder.build();
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (iOS / Obj-C):
 | 
						|
        # // ...
 | 
						|
        # static UIColor* fromProto(Color* protocolor) `
 | 
						|
        # float red = [protocolor red];
 | 
						|
        # float green = [protocolor green];
 | 
						|
        # float blue = [protocolor blue];
 | 
						|
        # FloatValue* alpha_wrapper = [protocolor alpha];
 | 
						|
        # float alpha = 1.0;
 | 
						|
        # if (alpha_wrapper != nil) `
 | 
						|
        # alpha = [alpha_wrapper value];
 | 
						|
        # `
 | 
						|
        # return [UIColor colorWithRed:red green:green blue:blue alpha:alpha];
 | 
						|
        # `
 | 
						|
        # static Color* toProto(UIColor* color) `
 | 
						|
        # CGFloat red, green, blue, alpha;
 | 
						|
        # if (![color getRed:&red green:&green blue:&blue alpha:&alpha]) `
 | 
						|
        # return nil;
 | 
						|
        # `
 | 
						|
        # Color* result = [Color alloc] init];
 | 
						|
        # [result setRed:red];
 | 
						|
        # [result setGreen:green];
 | 
						|
        # [result setBlue:blue];
 | 
						|
        # if (alpha <= 0.9999) `
 | 
						|
        # [result setAlpha:floatWrapperWithValue(alpha)];
 | 
						|
        # `
 | 
						|
        # [result autorelease];
 | 
						|
        # return result;
 | 
						|
        # `
 | 
						|
        # // ...
 | 
						|
        # Example (JavaScript):
 | 
						|
        # // ...
 | 
						|
        # var protoToCssColor = function(rgb_color) `
 | 
						|
        # var redFrac = rgb_color.red || 0.0;
 | 
						|
        # var greenFrac = rgb_color.green || 0.0;
 | 
						|
        # var blueFrac = rgb_color.blue || 0.0;
 | 
						|
        # var red = Math.floor(redFrac * 255);
 | 
						|
        # var green = Math.floor(greenFrac * 255);
 | 
						|
        # var blue = Math.floor(blueFrac * 255);
 | 
						|
        # if (!('alpha' in rgb_color)) `
 | 
						|
        # return rgbToCssColor_(red, green, blue);
 | 
						|
        # `
 | 
						|
        # var alphaFrac = rgb_color.alpha.value || 0.0;
 | 
						|
        # var rgbParams = [red, green, blue].join(',');
 | 
						|
        # return ['rgba(', rgbParams, ',', alphaFrac, ')'].join('');
 | 
						|
        # `;
 | 
						|
        # var rgbToCssColor_ = function(red, green, blue) `
 | 
						|
        # var rgbNumber = new Number((red << 16) | (green << 8) | blue);
 | 
						|
        # var hexString = rgbNumber.toString(16);
 | 
						|
        # var missingZeros = 6 - hexString.length;
 | 
						|
        # var resultBuilder = ['#'];
 | 
						|
        # for (var i = 0; i < missingZeros; i++) `
 | 
						|
        # resultBuilder.push('0');
 | 
						|
        # `
 | 
						|
        # resultBuilder.push(hexString);
 | 
						|
        # return resultBuilder.join('');
 | 
						|
        # `;
 | 
						|
        # // ...
 | 
						|
        # Corresponds to the JSON property `color`
 | 
						|
        # @return [Google::Apis::SheetsV4::Color]
 | 
						|
        attr_accessor :color
 | 
						|
      
 | 
						|
        # The label of the column's legend.
 | 
						|
        # Corresponds to the JSON property `label`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :label
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @color = args[:color] if args.key?(:color)
 | 
						|
          @label = args[:label] if args.key?(:label)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A custom subtotal column for a waterfall chart series.
 | 
						|
      class WaterfallChartCustomSubtotal
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # True if the data point at subtotal_index is the subtotal. If false,
 | 
						|
        # the subtotal will be computed and appear after the data point.
 | 
						|
        # Corresponds to the JSON property `dataIsSubtotal`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :data_is_subtotal
 | 
						|
        alias_method :data_is_subtotal?, :data_is_subtotal
 | 
						|
      
 | 
						|
        # A label for the subtotal column.
 | 
						|
        # Corresponds to the JSON property `label`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :label
 | 
						|
      
 | 
						|
        # The 0-based index of a data point within the series. If
 | 
						|
        # data_is_subtotal is true, the data point at this index is the
 | 
						|
        # subtotal. Otherwise, the subtotal appears after the data point with
 | 
						|
        # this index. A series can have multiple subtotals at arbitrary indices,
 | 
						|
        # but subtotals do not affect the indices of the data points. For
 | 
						|
        # example, if a series has 3 data points, their indices will always be 0,
 | 
						|
        # 1, and 2, regardless of how many subtotals exist on the series or what
 | 
						|
        # data points they are associated with.
 | 
						|
        # Corresponds to the JSON property `subtotalIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :subtotal_index
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data_is_subtotal = args[:data_is_subtotal] if args.key?(:data_is_subtotal)
 | 
						|
          @label = args[:label] if args.key?(:label)
 | 
						|
          @subtotal_index = args[:subtotal_index] if args.key?(:subtotal_index)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The domain of a waterfall chart.
 | 
						|
      class WaterfallChartDomain
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The data included in a domain or series.
 | 
						|
        # Corresponds to the JSON property `data`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartData]
 | 
						|
        attr_accessor :data
 | 
						|
      
 | 
						|
        # True to reverse the order of the domain values (horizontal axis).
 | 
						|
        # Corresponds to the JSON property `reversed`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :reversed
 | 
						|
        alias_method :reversed?, :reversed
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data = args[:data] if args.key?(:data)
 | 
						|
          @reversed = args[:reversed] if args.key?(:reversed)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A single series of data for a waterfall chart.
 | 
						|
      class WaterfallChartSeries
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Custom subtotal columns appearing in this series. The order in which
 | 
						|
        # subtotals are defined is not significant. Only one subtotal may be
 | 
						|
        # defined for each data point.
 | 
						|
        # Corresponds to the JSON property `customSubtotals`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::WaterfallChartCustomSubtotal>]
 | 
						|
        attr_accessor :custom_subtotals
 | 
						|
      
 | 
						|
        # The data included in a domain or series.
 | 
						|
        # Corresponds to the JSON property `data`
 | 
						|
        # @return [Google::Apis::SheetsV4::ChartData]
 | 
						|
        attr_accessor :data
 | 
						|
      
 | 
						|
        # True to hide the subtotal column from the end of the series. By default,
 | 
						|
        # a subtotal column will appear at the end of each series. Setting this
 | 
						|
        # field to true will hide that subtotal column for this series.
 | 
						|
        # Corresponds to the JSON property `hideTrailingSubtotal`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :hide_trailing_subtotal
 | 
						|
        alias_method :hide_trailing_subtotal?, :hide_trailing_subtotal
 | 
						|
      
 | 
						|
        # Styles for a waterfall chart column.
 | 
						|
        # Corresponds to the JSON property `negativeColumnsStyle`
 | 
						|
        # @return [Google::Apis::SheetsV4::WaterfallChartColumnStyle]
 | 
						|
        attr_accessor :negative_columns_style
 | 
						|
      
 | 
						|
        # Styles for a waterfall chart column.
 | 
						|
        # Corresponds to the JSON property `positiveColumnsStyle`
 | 
						|
        # @return [Google::Apis::SheetsV4::WaterfallChartColumnStyle]
 | 
						|
        attr_accessor :positive_columns_style
 | 
						|
      
 | 
						|
        # Styles for a waterfall chart column.
 | 
						|
        # Corresponds to the JSON property `subtotalColumnsStyle`
 | 
						|
        # @return [Google::Apis::SheetsV4::WaterfallChartColumnStyle]
 | 
						|
        attr_accessor :subtotal_columns_style
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @custom_subtotals = args[:custom_subtotals] if args.key?(:custom_subtotals)
 | 
						|
          @data = args[:data] if args.key?(:data)
 | 
						|
          @hide_trailing_subtotal = args[:hide_trailing_subtotal] if args.key?(:hide_trailing_subtotal)
 | 
						|
          @negative_columns_style = args[:negative_columns_style] if args.key?(:negative_columns_style)
 | 
						|
          @positive_columns_style = args[:positive_columns_style] if args.key?(:positive_columns_style)
 | 
						|
          @subtotal_columns_style = args[:subtotal_columns_style] if args.key?(:subtotal_columns_style)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A waterfall chart.
 | 
						|
      class WaterfallChartSpec
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Properties that describe the style of a line.
 | 
						|
        # Corresponds to the JSON property `connectorLineStyle`
 | 
						|
        # @return [Google::Apis::SheetsV4::LineStyle]
 | 
						|
        attr_accessor :connector_line_style
 | 
						|
      
 | 
						|
        # The domain of a waterfall chart.
 | 
						|
        # Corresponds to the JSON property `domain`
 | 
						|
        # @return [Google::Apis::SheetsV4::WaterfallChartDomain]
 | 
						|
        attr_accessor :domain
 | 
						|
      
 | 
						|
        # True to interpret the first value as a total.
 | 
						|
        # Corresponds to the JSON property `firstValueIsTotal`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :first_value_is_total
 | 
						|
        alias_method :first_value_is_total?, :first_value_is_total
 | 
						|
      
 | 
						|
        # True to hide connector lines between columns.
 | 
						|
        # Corresponds to the JSON property `hideConnectorLines`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :hide_connector_lines
 | 
						|
        alias_method :hide_connector_lines?, :hide_connector_lines
 | 
						|
      
 | 
						|
        # The data this waterfall chart is visualizing.
 | 
						|
        # Corresponds to the JSON property `series`
 | 
						|
        # @return [Array<Google::Apis::SheetsV4::WaterfallChartSeries>]
 | 
						|
        attr_accessor :series
 | 
						|
      
 | 
						|
        # The stacked type.
 | 
						|
        # Corresponds to the JSON property `stackedType`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :stacked_type
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @connector_line_style = args[:connector_line_style] if args.key?(:connector_line_style)
 | 
						|
          @domain = args[:domain] if args.key?(:domain)
 | 
						|
          @first_value_is_total = args[:first_value_is_total] if args.key?(:first_value_is_total)
 | 
						|
          @hide_connector_lines = args[:hide_connector_lines] if args.key?(:hide_connector_lines)
 | 
						|
          @series = args[:series] if args.key?(:series)
 | 
						|
          @stacked_type = args[:stacked_type] if args.key?(:stacked_type)
 | 
						|
        end
 | 
						|
      end
 | 
						|
    end
 | 
						|
  end
 | 
						|
end
 |