umya_spreadsheet/structs/
print_options.rs1use super::BooleanValue;
2use crate::reader::driver::*;
3use crate::writer::driver::*;
4use quick_xml::events::BytesStart;
5use quick_xml::Reader;
6use quick_xml::Writer;
7use std::io::Cursor;
8
9#[derive(Clone, Default, Debug)]
10pub struct PrintOptions {
11 horizontal_centered: BooleanValue,
12 vertical_centered: BooleanValue,
13}
14
15impl PrintOptions {
16 #[inline]
17 pub fn get_horizontal_centered(&self) -> &bool {
18 self.horizontal_centered.get_value()
19 }
20
21 #[inline]
22 pub fn set_horizontal_centered(&mut self, value: bool) -> &mut Self {
23 self.horizontal_centered.set_value(value);
24 self
25 }
26
27 #[inline]
28 pub fn get_vertical_centered(&self) -> &bool {
29 self.vertical_centered.get_value()
30 }
31
32 #[inline]
33 pub fn set_vertical_centered(&mut self, value: bool) -> &mut Self {
34 self.vertical_centered.set_value(value);
35 self
36 }
37
38 #[inline]
39 pub(crate) fn has_param(&self) -> bool {
40 self.horizontal_centered.has_value() || self.vertical_centered.has_value()
41 }
42
43 #[inline]
44 pub(crate) fn set_attributes<R: std::io::BufRead>(
45 &mut self,
46 _reader: &mut Reader<R>,
47 e: &BytesStart,
48 ) {
49 set_string_from_xml!(self, e, horizontal_centered, "horizontalCentered");
50 set_string_from_xml!(self, e, vertical_centered, "verticalCentered");
51 }
52
53 pub(crate) fn write_to(&self, writer: &mut Writer<Cursor<Vec<u8>>>) {
54 if self.has_param() {
55 let mut attributes: Vec<(&str, &str)> = Vec::new();
57 if self.horizontal_centered.has_value() {
58 attributes.push((
59 "horizontalCentered",
60 self.horizontal_centered.get_value_string(),
61 ));
62 }
63 if self.vertical_centered.has_value() {
64 attributes.push((
65 "verticalCentered",
66 self.vertical_centered.get_value_string(),
67 ));
68 }
69 write_start_tag(writer, "printOptions", attributes, true);
70 }
71 }
72}