umya_spreadsheet/structs/vml/spreadsheet/
visible.rs1use crate::reader::driver::*;
2use crate::structs::TrueFalseBlankValue;
3use crate::writer::driver::*;
4use quick_xml::events::{BytesStart, Event};
5use quick_xml::Reader;
6use quick_xml::Writer;
7use std::io::Cursor;
8
9#[derive(Clone, Default, Debug)]
10pub struct Visible {
11 value: TrueFalseBlankValue,
12}
13
14impl Visible {
15 #[inline]
16 pub fn get_value(&self) -> Option<&bool> {
17 self.value.get_value()
18 }
19
20 #[inline]
21 pub fn set_value(&mut self, value: bool) -> &mut Self {
22 self.value.set_value(value);
23 self
24 }
25
26 #[inline]
27 pub(crate) fn set_attributes<R: std::io::BufRead>(
28 &mut self,
29 reader: &mut Reader<R>,
30 _e: &BytesStart,
31 empty_flag: bool,
32 ) {
33 if empty_flag {
34 return;
35 }
36
37 xml_read_loop!(
38 reader,
39 Event::Text(e) => {
40 self.value.set_value_string(e.unescape().unwrap());
41 },
42 Event::End(ref e) => {
43 if e.name().0 == b"x:Visible" {
44 return
45 }
46 },
47 Event::Eof => panic!("Error: Could not find {} end element", "x:Visible")
48 );
49 }
50
51 #[inline]
52 pub(crate) fn write_to(&self, writer: &mut Writer<Cursor<Vec<u8>>>) {
53 if self.value.has_value() {
55 write_start_tag(writer, "x:Visible", vec![], false);
56 write_text_node(writer, self.value.get_value_string2());
57 write_end_tag(writer, "x:Visible");
58 } else {
59 write_start_tag(writer, "x:Visible", vec![], true);
60 }
61 }
62}