use super::FormatCode;
use crate::structs::Address;
use crate::structs::Spreadsheet;
use crate::writer::driver::*;
use crate::xml_read_loop;
use quick_xml::events::{BytesStart, Event};
use quick_xml::Reader;
use quick_xml::Writer;
use std::io::Cursor;
#[derive(Clone, Default, Debug)]
pub struct NumberingCache {
format_code: FormatCode,
}
impl NumberingCache {
pub fn get_format_code(&self) -> &FormatCode {
&self.format_code
}
pub fn get_format_code_mut(&mut self) -> &mut FormatCode {
&mut self.format_code
}
pub fn set_format_code(&mut self, value: FormatCode) -> &mut NumberingCache {
self.format_code = 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) => {
if e.name().0 == b"c:formatCode" {
self.format_code.set_attributes(reader, e);
}
},
Event::End(ref e) => {
if e.name().0 == b"c:numCache" {
return;
}
},
Event::Eof => panic!("Error: Could not find {} end element", "c:numCache"),
);
}
pub(crate) fn write_to(
&self,
writer: &mut Writer<Cursor<Vec<u8>>>,
address: &Address,
spreadsheet: &Spreadsheet,
) {
let cell_value_list = spreadsheet.get_cell_value_by_address_crate(address);
let coll_value_count = cell_value_list.len().to_string();
write_start_tag(writer, "c:numCache", vec![], false);
self.format_code.write_to(writer);
write_start_tag(writer, "c:ptCount", vec![("val", &coll_value_count)], true);
for (idx, cell_value) in cell_value_list.into_iter().enumerate() {
write_start_tag(writer, "c:pt", vec![("idx", &idx.to_string())], false);
write_start_tag(writer, "c:v", vec![], false);
write_text_node(writer, cell_value.get_value());
write_end_tag(writer, "c:v");
write_end_tag(writer, "c:pt");
}
write_end_tag(writer, "c:numCache");
}
}