parent
82da29ebb1
commit
edb8843b52
|
@ -3,7 +3,7 @@ use std::fs::*;
|
||||||
use std::io::Read;
|
use std::io::Read;
|
||||||
|
|
||||||
pub fn main() {
|
pub fn main() {
|
||||||
let mut file = File::open("./1/1.docx").unwrap();
|
let mut file = File::open("./1.docx").unwrap();
|
||||||
let mut buf = vec![];
|
let mut buf = vec![];
|
||||||
file.read_to_end(&mut buf).unwrap();
|
file.read_to_end(&mut buf).unwrap();
|
||||||
dbg!(read_docx(&buf).unwrap().json());
|
dbg!(read_docx(&buf).unwrap().json());
|
||||||
|
|
|
@ -7,13 +7,28 @@ use crate::xml_builder::*;
|
||||||
|
|
||||||
#[derive(Debug, Clone, PartialEq)]
|
#[derive(Debug, Clone, PartialEq)]
|
||||||
pub struct NumberingProperty {
|
pub struct NumberingProperty {
|
||||||
pub id: NumberingId,
|
pub id: Option<NumberingId>,
|
||||||
pub level: IndentLevel,
|
pub level: Option<IndentLevel>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Default for NumberingProperty {
|
||||||
|
fn default() -> Self {
|
||||||
|
NumberingProperty {
|
||||||
|
id: None,
|
||||||
|
level: None,
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl NumberingProperty {
|
impl NumberingProperty {
|
||||||
pub fn new(id: NumberingId, level: IndentLevel) -> NumberingProperty {
|
pub fn new() -> NumberingProperty {
|
||||||
Self { id, level }
|
Default::default()
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn add_num(mut self, id: NumberingId, level: IndentLevel) -> NumberingProperty {
|
||||||
|
self.id = Some(id);
|
||||||
|
self.level = Some(level);
|
||||||
|
self
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -21,8 +36,8 @@ impl BuildXML for NumberingProperty {
|
||||||
fn build(&self) -> Vec<u8> {
|
fn build(&self) -> Vec<u8> {
|
||||||
let b = XMLBuilder::new();
|
let b = XMLBuilder::new();
|
||||||
b.open_numbering_property()
|
b.open_numbering_property()
|
||||||
.add_child(&self.id)
|
.add_optional_child(&self.id)
|
||||||
.add_child(&self.level)
|
.add_optional_child(&self.level)
|
||||||
.close()
|
.close()
|
||||||
.build()
|
.build()
|
||||||
}
|
}
|
||||||
|
@ -34,8 +49,17 @@ impl Serialize for NumberingProperty {
|
||||||
S: Serializer,
|
S: Serializer,
|
||||||
{
|
{
|
||||||
let mut t = serializer.serialize_struct("NumberProperty", 2)?;
|
let mut t = serializer.serialize_struct("NumberProperty", 2)?;
|
||||||
t.serialize_field("id", &self.id.id)?;
|
let mut id: Option<usize> = None;
|
||||||
t.serialize_field("level", &self.level.val)?;
|
if let Some(n) = &self.id {
|
||||||
|
id = Some(n.id);
|
||||||
|
}
|
||||||
|
t.serialize_field("id", &id)?;
|
||||||
|
|
||||||
|
let mut level: Option<usize> = None;
|
||||||
|
if let Some(n) = &self.level {
|
||||||
|
level = Some(n.val);
|
||||||
|
}
|
||||||
|
t.serialize_field("level", &level)?;
|
||||||
t.end()
|
t.end()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -50,11 +74,33 @@ mod tests {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_num_property() {
|
fn test_num_property() {
|
||||||
let c = NumberingProperty::new(NumberingId::new(0), IndentLevel::new(3));
|
let c = NumberingProperty::new().add_num(NumberingId::new(0), IndentLevel::new(3));
|
||||||
let b = c.build();
|
let b = c.build();
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
str::from_utf8(&b).unwrap(),
|
str::from_utf8(&b).unwrap(),
|
||||||
r#"<w:numPr><w:numId w:val="0" /><w:ilvl w:val="3" /></w:numPr>"#
|
r#"<w:numPr><w:numId w:val="0" /><w:ilvl w:val="3" /></w:numPr>"#
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_empty_num_property() {
|
||||||
|
let c = NumberingProperty::new();
|
||||||
|
let b = c.build();
|
||||||
|
assert_eq!(str::from_utf8(&b).unwrap(), r#"<w:numPr />"#);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_num_property_json() {
|
||||||
|
let c = NumberingProperty::new().add_num(NumberingId::new(0), IndentLevel::new(3));
|
||||||
|
assert_eq!(serde_json::to_string(&c).unwrap(), r#"{"id":0,"level":3}"#);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_empty_num_property_json() {
|
||||||
|
let c = NumberingProperty::new();
|
||||||
|
assert_eq!(
|
||||||
|
serde_json::to_string(&c).unwrap(),
|
||||||
|
r#"{"id":null,"level":null}"#
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -60,7 +60,7 @@ impl ParagraphProperty {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn numbering(mut self, id: NumberingId, level: IndentLevel) -> Self {
|
pub fn numbering(mut self, id: NumberingId, level: IndentLevel) -> Self {
|
||||||
self.numbering_property = Some(NumberingProperty::new(id, level));
|
self.numbering_property = Some(NumberingProperty::new().add_num(id, level));
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,9 +36,9 @@ impl ElementReader for NumberingProperty {
|
||||||
let e = XMLElement::from_str(&name.local_name).unwrap();
|
let e = XMLElement::from_str(&name.local_name).unwrap();
|
||||||
if e == XMLElement::NumberingProperty {
|
if e == XMLElement::NumberingProperty {
|
||||||
if id.is_none() || level.is_none() {
|
if id.is_none() || level.is_none() {
|
||||||
return Err(ReaderError::XMLReadError);
|
return Ok(NumberingProperty::new());
|
||||||
}
|
}
|
||||||
let np = NumberingProperty::new(
|
let np = NumberingProperty::new().add_num(
|
||||||
NumberingId::new(id.unwrap()),
|
NumberingId::new(id.unwrap()),
|
||||||
IndentLevel::new(level.unwrap()),
|
IndentLevel::new(level.unwrap()),
|
||||||
);
|
);
|
||||||
|
|
|
@ -94,7 +94,9 @@ impl ElementReader for Paragraph {
|
||||||
}
|
}
|
||||||
XMLElement::NumberingProperty => {
|
XMLElement::NumberingProperty => {
|
||||||
let num_pr = NumberingProperty::read(r, attrs)?;
|
let num_pr = NumberingProperty::read(r, attrs)?;
|
||||||
p = p.numbering(num_pr.id, num_pr.level);
|
if num_pr.id.is_some() && num_pr.level.is_some() {
|
||||||
|
p = p.numbering(num_pr.id.unwrap(), num_pr.level.unwrap());
|
||||||
|
}
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
_ => {}
|
_ => {}
|
||||||
|
@ -244,10 +246,9 @@ mod tests {
|
||||||
property: ParagraphProperty {
|
property: ParagraphProperty {
|
||||||
run_property: RunProperty::new(),
|
run_property: RunProperty::new(),
|
||||||
style: ParagraphStyle::new(s),
|
style: ParagraphStyle::new(s),
|
||||||
numbering_property: Some(NumberingProperty::new(
|
numbering_property: Some(
|
||||||
NumberingId::new(1),
|
NumberingProperty::new().add_num(NumberingId::new(1), IndentLevel::new(0),)
|
||||||
IndentLevel::new(0),
|
),
|
||||||
)),
|
|
||||||
alignment: None,
|
alignment: None,
|
||||||
indent: None,
|
indent: None,
|
||||||
},
|
},
|
||||||
|
|
|
@ -9,8 +9,8 @@ export type ParagraphChildJSON =
|
||||||
| BookmarkEndJSON;
|
| BookmarkEndJSON;
|
||||||
|
|
||||||
export type NumberingPropertyJSON = {
|
export type NumberingPropertyJSON = {
|
||||||
id: number;
|
id: number | null;
|
||||||
level: number;
|
level: number | null;
|
||||||
};
|
};
|
||||||
|
|
||||||
export type ParagraphPropertyJSON = {
|
export type ParagraphPropertyJSON = {
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"name": "docx-wasm",
|
"name": "docx-wasm",
|
||||||
"version": "0.0.53",
|
"version": "0.0.54",
|
||||||
"main": "dist/node/index.js",
|
"main": "dist/node/index.js",
|
||||||
"browser": "dist/web/index.js",
|
"browser": "dist/web/index.js",
|
||||||
"author": "bokuweb <bokuweb12@gmail.com>",
|
"author": "bokuweb <bokuweb12@gmail.com>",
|
||||||
|
|
Loading…
Reference in New Issue