docx-rs/docx-core/src/documents/elements/paragraph_property.rs

113 lines
3.2 KiB
Rust
Raw Normal View History

2019-12-06 12:18:48 +02:00
use super::{
Indent, IndentLevel, Justification, NumberingId, NumberingProperty, ParagraphStyle, RunProperty,
};
2019-11-06 12:17:49 +02:00
use crate::documents::BuildXML;
2019-11-11 09:48:28 +02:00
use crate::types::{AlignmentType, SpecialIndentType};
2019-11-06 12:17:49 +02:00
use crate::xml_builder::*;
2019-11-12 11:57:16 +02:00
#[derive(Debug, Clone)]
2019-12-06 19:15:21 +02:00
pub struct ParagraphProperty {
2019-11-11 07:39:22 +02:00
run_property: RunProperty,
2019-11-11 08:36:26 +02:00
style: ParagraphStyle,
2019-12-06 19:15:21 +02:00
numbering_property: Option<NumberingProperty>,
2019-11-11 09:48:28 +02:00
alignment: Option<Justification>,
indent: Option<Indent>,
2019-11-11 06:05:07 +02:00
}
2019-12-06 19:15:21 +02:00
impl Default for ParagraphProperty {
2019-11-11 06:05:07 +02:00
fn default() -> Self {
2019-11-11 08:36:26 +02:00
let s: Option<&str> = None;
2019-11-11 07:39:22 +02:00
ParagraphProperty {
run_property: RunProperty::new(),
2019-11-11 08:36:26 +02:00
style: ParagraphStyle::new(s),
2019-12-06 12:18:48 +02:00
numbering_property: None,
2019-11-11 09:48:28 +02:00
alignment: None,
indent: None,
2019-11-11 07:39:22 +02:00
}
2019-11-11 06:05:07 +02:00
}
}
2019-11-06 12:17:49 +02:00
// 17.3.1.26
// pPr (Paragraph Properties)
// This element specifies a set of paragraph properties which shall be applied to the contents of the parent
// paragraph after all style/numbering/table properties have been applied to the text. These properties are defined
// as direct formatting, since they are directly applied to the paragraph and supersede any formatting from styles.
2019-12-06 19:15:21 +02:00
impl ParagraphProperty {
pub fn new() -> ParagraphProperty {
2019-11-11 06:05:07 +02:00
Default::default()
}
2019-12-06 12:18:48 +02:00
pub fn align(mut self, alignment_type: AlignmentType) -> Self {
2019-11-11 06:05:07 +02:00
self.alignment = Some(Justification::new(alignment_type.to_string()));
self
2019-11-06 12:17:49 +02:00
}
2019-11-11 08:36:26 +02:00
2019-12-06 12:18:48 +02:00
pub fn style(mut self, style_id: &str) -> Self {
2019-11-11 08:36:26 +02:00
self.style = ParagraphStyle::new(Some(style_id));
self
}
2019-11-11 09:48:28 +02:00
2019-12-06 12:18:48 +02:00
pub fn indent(mut self, left: usize, special_indent: Option<SpecialIndentType>) -> Self {
2019-11-11 09:48:28 +02:00
self.indent = Some(Indent::new(left, special_indent));
self
}
2019-12-06 12:18:48 +02:00
2019-12-06 19:15:21 +02:00
pub fn numbering(mut self, id: NumberingId, level: IndentLevel) -> Self {
2019-12-06 12:18:48 +02:00
self.numbering_property = Some(NumberingProperty::new(id, level));
self
}
2019-11-06 12:17:49 +02:00
}
2019-12-06 19:15:21 +02:00
impl BuildXML for ParagraphProperty {
2019-11-06 12:17:49 +02:00
fn build(&self) -> Vec<u8> {
2019-11-11 08:36:26 +02:00
XMLBuilder::new()
2019-11-11 06:05:07 +02:00
.open_paragraph_property()
2019-11-11 09:48:28 +02:00
.add_child(&self.style)
.add_child(&self.run_property)
2019-12-06 12:18:48 +02:00
.add_optional_child(&self.numbering_property)
2019-11-11 08:36:26 +02:00
.add_optional_child(&self.alignment)
2019-11-11 09:48:28 +02:00
.add_optional_child(&self.indent)
2019-11-11 08:36:26 +02:00
.close()
.build()
2019-11-06 12:17:49 +02:00
}
}
#[cfg(test)]
mod tests {
use super::*;
2019-11-07 06:57:58 +02:00
#[cfg(test)]
use pretty_assertions::assert_eq;
2019-11-06 12:17:49 +02:00
use std::str;
#[test]
2019-11-11 08:36:26 +02:00
fn test_default() {
2019-11-06 12:17:49 +02:00
let c = ParagraphProperty::new();
let b = c.build();
2019-11-11 09:48:28 +02:00
assert_eq!(
str::from_utf8(&b).unwrap(),
r#"<w:pPr><w:pStyle w:val="Normal" /><w:rPr /></w:pPr>"#
);
2019-11-06 12:17:49 +02:00
}
2019-11-11 08:36:26 +02:00
#[test]
fn test_alignment() {
let c = ParagraphProperty::new();
let b = c.align(AlignmentType::Right).build();
assert_eq!(
str::from_utf8(&b).unwrap(),
2019-11-11 09:48:28 +02:00
r#"<w:pPr><w:pStyle w:val="Normal" /><w:rPr /><w:jc w:val="right" /></w:pPr>"#
);
}
#[test]
fn test_indent() {
let c = ParagraphProperty::new();
let b = c.indent(20, None).build();
assert_eq!(
str::from_utf8(&b).unwrap(),
r#"<w:pPr><w:pStyle w:val="Normal" /><w:rPr /><w:ind w:left="20" /></w:pPr>"#
2019-11-11 08:36:26 +02:00
);
}
2019-11-06 12:17:49 +02:00
}