# frozen_string_literal: true module Axlsx # A PieSeries defines the data and labels and explosion for pie charts series. # @note The recommended way to manage series is to use Chart#add_series # @see Worksheet#add_chart # @see Chart#add_series class PieSeries < Series # The data for this series. # @return [SimpleTypedList] attr_reader :data # The labels for this series. # @return [SimpleTypedList] attr_reader :labels # The explosion for this series # @return [Integert] attr_reader :explosion # An array of rgb colors to apply to your bar chart. attr_reader :colors # Creates a new series # @option options [Array, SimpleTypedList] data # @option options [Array, SimpleTypedList] labels # @option options [String] title # @option options [Integer] explosion # @param [Chart] chart def initialize(chart, options = {}) @explosion = nil @colors = [] super(chart, options) self.labels = AxDataSource.new(data: options[:labels]) unless options[:labels].nil? self.data = NumDataSource.new(options) unless options[:data].nil? end # @see colors def colors=(v) DataTypeValidator.validate "BarSeries.colors", [Array], v @colors = v end # @see explosion def explosion=(v) Axlsx.validate_unsigned_int(v) @explosion = v end # Serializes the object # @param [String] str # @return [String] def to_xml_string(str = +'') super(str) do str << '' unless @explosion.nil? colors.each_with_index do |c, index| str << '' str << '' str << '' str << '' str << '' end @labels.to_xml_string str unless @labels.nil? @data.to_xml_string str unless @data.nil? end str end private # assigns the data for this series def data=(v) DataTypeValidator.validate "Series.data", [NumDataSource], v @data = v end # assigns the labels for this series def labels=(v) DataTypeValidator.validate "Series.labels", [AxDataSource], v @labels = v end end end