feat: Add p style
parent
879189da3c
commit
d92d111aa6
|
@ -1,7 +1,6 @@
|
|||
use super::{DocDefaults, Paragraph, Run, Style};
|
||||
use super::Paragraph;
|
||||
use crate::documents::BuildXML;
|
||||
use crate::xml_builder::*;
|
||||
use crate::StyleType;
|
||||
|
||||
#[derive(Debug)]
|
||||
pub struct Document {
|
||||
|
@ -43,6 +42,7 @@ impl BuildXML for Document {
|
|||
#[cfg(test)]
|
||||
mod tests {
|
||||
|
||||
use super::super::Run;
|
||||
use super::*;
|
||||
#[cfg(test)]
|
||||
use pretty_assertions::assert_eq;
|
||||
|
|
|
@ -6,6 +6,7 @@ mod name;
|
|||
mod next;
|
||||
mod paragraph;
|
||||
mod paragraph_property;
|
||||
mod paragraph_style;
|
||||
mod q_format;
|
||||
mod run;
|
||||
mod run_property;
|
||||
|
@ -22,6 +23,7 @@ pub use name::*;
|
|||
pub use next::*;
|
||||
pub use paragraph::*;
|
||||
pub use paragraph_property::*;
|
||||
pub use paragraph_style::*;
|
||||
pub use q_format::*;
|
||||
pub use run::*;
|
||||
pub use run_property::*;
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
use super::{ParagraphProperty, Run, RunProperty, Text};
|
||||
use super::{ParagraphProperty, ParagraphStyle, Run};
|
||||
use crate::documents::BuildXML;
|
||||
use crate::types::*;
|
||||
use crate::xml_builder::*;
|
||||
|
@ -7,13 +7,16 @@ use crate::xml_builder::*;
|
|||
pub struct Paragraph {
|
||||
runs: Vec<Run>,
|
||||
property: ParagraphProperty,
|
||||
style: ParagraphStyle,
|
||||
}
|
||||
|
||||
impl Default for Paragraph {
|
||||
fn default() -> Self {
|
||||
let s: Option<&str> = None;
|
||||
Self {
|
||||
runs: Vec::new(),
|
||||
property: ParagraphProperty::new(),
|
||||
style: ParagraphStyle::new(s),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -39,6 +42,7 @@ impl BuildXML for Paragraph {
|
|||
XMLBuilder::new()
|
||||
.open_paragraph()
|
||||
.add_child(&self.property)
|
||||
.add_child(&self.style)
|
||||
.add_children(&self.runs)
|
||||
.close()
|
||||
.build()
|
||||
|
@ -58,7 +62,7 @@ mod tests {
|
|||
let b = Paragraph::new().add_run(Run::new("Hello")).build();
|
||||
assert_eq!(
|
||||
str::from_utf8(&b).unwrap(),
|
||||
r#"<w:p><w:r><w:rPr /><w:t>Hello</w:t></w:r></w:p>"#
|
||||
r#"<w:p><w:pPr /><w:pStyle w:val="Normal" /><w:r><w:rPr /><w:t xml:space="preserve">Hello</w:t></w:r></w:p>"#
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
use super::Justification;
|
||||
use super::{Justification, RunProperty};
|
||||
use crate::documents::BuildXML;
|
||||
use crate::types::AlignmentType;
|
||||
use crate::xml_builder::*;
|
||||
|
@ -6,11 +6,15 @@ use crate::xml_builder::*;
|
|||
#[derive(Debug)]
|
||||
pub struct ParagraphProperty {
|
||||
alignment: Option<Justification>,
|
||||
run_property: RunProperty,
|
||||
}
|
||||
|
||||
impl Default for ParagraphProperty {
|
||||
fn default() -> Self {
|
||||
ParagraphProperty { alignment: None }
|
||||
ParagraphProperty {
|
||||
alignment: None,
|
||||
run_property: RunProperty::new(),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -0,0 +1,56 @@
|
|||
use crate::documents::BuildXML;
|
||||
use crate::xml_builder::*;
|
||||
|
||||
#[derive(Debug)]
|
||||
pub struct ParagraphStyle {
|
||||
val: String,
|
||||
}
|
||||
|
||||
impl Default for ParagraphStyle {
|
||||
fn default() -> Self {
|
||||
ParagraphStyle {
|
||||
val: "Normal".to_owned(),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// 17.9.23
|
||||
// pStyle (Paragraph Style's Associated Numbering Level)
|
||||
// This element specifies the name of a paragraph style which shall automatically this numbering level when
|
||||
// applied to the contents of the document. When a paragraph style is defined to include a numbering definition,
|
||||
// any numbering level defined by the numPr element (§17.3.1.19) shall be ignored, and instead this element shall
|
||||
// specify the numbering level associated with that paragraph style.
|
||||
impl ParagraphStyle {
|
||||
pub fn new(val: Option<impl Into<String>>) -> ParagraphStyle {
|
||||
if let Some(v) = val {
|
||||
ParagraphStyle { val: v.into() }
|
||||
} else {
|
||||
Default::default()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl BuildXML for ParagraphStyle {
|
||||
fn build(&self) -> Vec<u8> {
|
||||
XMLBuilder::new().paragraph_style(&self.val).build()
|
||||
}
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
|
||||
use super::*;
|
||||
#[cfg(test)]
|
||||
use pretty_assertions::assert_eq;
|
||||
use std::str;
|
||||
|
||||
#[test]
|
||||
fn test_p_style() {
|
||||
let c = ParagraphStyle::new(Some("Heading"));
|
||||
let b = c.build();
|
||||
assert_eq!(
|
||||
str::from_utf8(&b).unwrap(),
|
||||
r#"<w:pStyle w:val="Heading" />"#
|
||||
);
|
||||
}
|
||||
}
|
|
@ -1,8 +1,6 @@
|
|||
use crate::documents::BuildXML;
|
||||
use crate::xml_builder::*;
|
||||
|
||||
use super::Name;
|
||||
|
||||
#[derive(Debug)]
|
||||
pub struct Sz {
|
||||
val: usize,
|
||||
|
|
|
@ -1,4 +1,3 @@
|
|||
use super::{RunProperty, Sz};
|
||||
use crate::documents::BuildXML;
|
||||
use crate::xml_builder::*;
|
||||
|
||||
|
|
|
@ -7,7 +7,6 @@ mod rels;
|
|||
mod styles;
|
||||
mod xml_docx;
|
||||
|
||||
pub(crate) use crate::xml_builder::*;
|
||||
pub(crate) use build_xml::*;
|
||||
|
||||
pub use content_types::*;
|
||||
|
|
|
@ -1,7 +1,6 @@
|
|||
use super::{DocDefaults, Style};
|
||||
use crate::documents::BuildXML;
|
||||
use crate::xml_builder::*;
|
||||
use crate::StyleType;
|
||||
|
||||
#[derive(Debug)]
|
||||
pub struct Styles {
|
||||
|
@ -44,6 +43,7 @@ impl BuildXML for Styles {
|
|||
mod tests {
|
||||
|
||||
use super::*;
|
||||
use crate::types::StyleType;
|
||||
#[cfg(test)]
|
||||
use pretty_assertions::assert_eq;
|
||||
use std::str;
|
||||
|
|
|
@ -1,5 +1,3 @@
|
|||
use std::fmt;
|
||||
|
||||
use super::XMLBuilder;
|
||||
use super::XmlEvent;
|
||||
|
||||
|
|
|
@ -36,7 +36,7 @@ impl XMLBuilder {
|
|||
// i.e. <w:jc ... >
|
||||
only_str_val_el!(justification, "w:jc");
|
||||
// i.e. <w:pStyle ... >
|
||||
only_str_val_el!(p_style, "w:pStyle");
|
||||
only_str_val_el!(paragraph_style, "w:pStyle");
|
||||
// i.e. <w:sz ... >
|
||||
pub(crate) fn sz(mut self, val: usize) -> Self {
|
||||
self.writer
|
||||
|
|
|
@ -142,6 +142,7 @@ macro_rules! only_str_val_el {
|
|||
};
|
||||
}
|
||||
|
||||
/*
|
||||
macro_rules! only_usize_val_el {
|
||||
($name: ident, $el_name: expr) => {
|
||||
pub(crate) fn $name(mut self, val: usize) -> Self {
|
||||
|
@ -152,3 +153,4 @@ macro_rules! only_usize_val_el {
|
|||
}
|
||||
};
|
||||
}
|
||||
*/
|
||||
|
|
|
@ -1,5 +1,3 @@
|
|||
use std::fmt;
|
||||
|
||||
use super::XMLBuilder;
|
||||
use super::XmlEvent;
|
||||
|
||||
|
|
Loading…
Reference in New Issue