use super::AreaChartSeries;
use super::AreaChartSeriesList;
use super::AxisId;
use super::DataLabels;
use super::Grouping;
use super::VaryColors;
use quick_xml::events::{BytesStart, Event};
use quick_xml::Reader;
use quick_xml::Writer;
use reader::driver::*;
use std::io::Cursor;
use structs::Spreadsheet;
use writer::driver::*;
#[derive(Clone, Default, Debug)]
pub struct AreaChart {
grouping: Grouping,
vary_colors: VaryColors,
area_chart_series_list: AreaChartSeriesList,
data_labels: DataLabels,
axis_id: Vec<AxisId>,
}
impl AreaChart {
pub fn get_grouping(&self) -> &Grouping {
&self.grouping
}
pub fn get_grouping_mut(&mut self) -> &mut Grouping {
&mut self.grouping
}
pub fn set_grouping(&mut self, value: Grouping) -> &mut AreaChart {
self.grouping = value;
self
}
pub fn get_vary_colors(&self) -> &VaryColors {
&self.vary_colors
}
pub fn get_vary_colors_mut(&mut self) -> &mut VaryColors {
&mut self.vary_colors
}
pub fn set_vary_colors(&mut self, value: VaryColors) -> &mut AreaChart {
self.vary_colors = value;
self
}
pub fn get_area_chart_series_list(&self) -> &AreaChartSeriesList {
&self.area_chart_series_list
}
pub fn get_area_chart_series_list_mut(&mut self) -> &mut AreaChartSeriesList {
&mut self.area_chart_series_list
}
pub fn set_area_chart_series_list(&mut self, value: AreaChartSeriesList) -> &mut Self {
self.area_chart_series_list = value;
self
}
pub fn get_data_labels(&self) -> &DataLabels {
&self.data_labels
}
pub fn get_data_labels_mut(&mut self) -> &mut DataLabels {
&mut self.data_labels
}
pub fn set_data_labels(&mut self, value: DataLabels) -> &mut AreaChart {
self.data_labels = value;
self
}
pub fn get_axis_id(&self) -> &Vec<AxisId> {
&self.axis_id
}
pub fn get_axis_id_mut(&mut self) -> &mut Vec<AxisId> {
&mut self.axis_id
}
pub fn set_axis_id(&mut self, value: Vec<AxisId>) -> &mut AreaChart {
self.axis_id = value;
self
}
pub fn add_axis_id(&mut self, value: AxisId) -> &mut AreaChart {
self.axis_id.push(value);
self
}
pub(crate) fn set_attributes<R: std::io::BufRead>(
&mut self,
reader: &mut Reader<R>,
_e: &BytesStart,
) {
xml_read_loop!(
reader,
Event::Start(ref e) => {
match e.name().into_inner() {
b"c:ser" => {
let mut obj = AreaChartSeries::default();
obj.set_attributes(reader, e);
self.get_area_chart_series_list_mut()
.add_area_chart_series(obj);
}
b"c:dLbls" => {
self.data_labels.set_attributes(reader, e);
}
_ => (),
}
},
Event::Empty(ref e) => {
match e.name().into_inner() {
b"c:grouping" => {
self.grouping.set_attributes(reader, e);
}
b"c:varyColors" => {
self.vary_colors.set_attributes(reader, e);
}
b"c:axId" => {
let mut obj = AxisId::default();
obj.set_attributes(reader, e);
self.add_axis_id(obj);
}
_ => (),
}
},
Event::End(ref e) => {
if e.name().into_inner() == b"c:areaChart" {
return
}
},
Event::Eof => panic!("Error not find {} end element", "c:areaChart")
);
}
pub(crate) fn write_to(&self, writer: &mut Writer<Cursor<Vec<u8>>>, spreadsheet: &Spreadsheet) {
write_start_tag(writer, "c:areaChart", vec![], false);
self.grouping.write_to(writer);
self.vary_colors.write_to(writer);
for v in self.area_chart_series_list.get_area_chart_series() {
v.write_to(writer, spreadsheet);
}
self.data_labels.write_to(writer);
for v in &self.axis_id {
v.write_to(writer);
}
write_end_tag(writer, "c:areaChart");
}
}