asposewordsjavaforruby 0.0.4 → 0.0.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/Gempackage +2 -2
- data/LICENSE +20 -20
- data/README.md +28 -2
- data/Rakefile +2 -2
- data/asposewordsjavaforruby.gemspec +27 -27
- data/config/aspose.yml +5 -5
- data/data/LoadTxt.txt +14 -14
- data/lib/asposewordsjavaforruby.rb +71 -71
- data/lib/asposewordsjavaforruby/addwatermark.rb +84 -84
- data/lib/asposewordsjavaforruby/appenddoc.rb +24 -24
- data/lib/asposewordsjavaforruby/appenddocument.rb +229 -229
- data/lib/asposewordsjavaforruby/applylicense.rb +16 -16
- data/lib/asposewordsjavaforruby/asposewordsjava.rb +23 -23
- data/lib/asposewordsjavaforruby/autofittables.rb +123 -123
- data/lib/asposewordsjavaforruby/bookmarks.rb +132 -132
- data/lib/asposewordsjavaforruby/checkformat.rb +70 -70
- data/lib/asposewordsjavaforruby/compressimages.rb +53 -53
- data/lib/asposewordsjavaforruby/doc2pdf.rb +15 -15
- data/lib/asposewordsjavaforruby/doctohtml.rb +26 -26
- data/lib/asposewordsjavaforruby/extractcontent.rb +395 -395
- data/lib/asposewordsjavaforruby/findandreplace.rb +29 -29
- data/lib/asposewordsjavaforruby/helloworld.rb +26 -26
- data/lib/asposewordsjavaforruby/imagetopdf.rb +71 -71
- data/lib/asposewordsjavaforruby/insertnestedfields.rb +39 -39
- data/lib/asposewordsjavaforruby/loadandsavetodisk.rb +20 -20
- data/lib/asposewordsjavaforruby/loadandsavetostream.rb +32 -32
- data/lib/asposewordsjavaforruby/loadtxt.rb +14 -14
- data/lib/asposewordsjavaforruby/mergefield.rb +45 -45
- data/lib/asposewordsjavaforruby/nodes.rb +29 -29
- data/lib/asposewordsjavaforruby/processcomments.rb +72 -72
- data/lib/asposewordsjavaforruby/removebreaks.rb +65 -65
- data/lib/asposewordsjavaforruby/removefield.rb +23 -23
- data/lib/asposewordsjavaforruby/saveasmultipagetiff.rb +26 -26
- data/lib/asposewordsjavaforruby/simplemailmerge.rb +23 -23
- data/lib/asposewordsjavaforruby/styles.rb +77 -77
- data/lib/asposewordsjavaforruby/updatefields.rb +62 -62
- data/lib/asposewordsjavaforruby/version.rb +3 -3
- metadata +18 -28
@@ -1,16 +1,16 @@
|
|
1
|
-
module Asposewordsjavaforruby
|
2
|
-
module ApplyLicense
|
3
|
-
def initialize()
|
4
|
-
apply_license()
|
5
|
-
end
|
6
|
-
|
7
|
-
def apply_license()
|
8
|
-
# This line attempts to set a license from several locations relative to the executable and Aspose.Words.dll.
|
9
|
-
# You can also use the additional overload to load a license from a stream, this is useful for instance when the
|
10
|
-
# license is stored as an embedded resource
|
11
|
-
license = Rjb::import('com.aspose.words.License').new()
|
12
|
-
license.setLicense('Aspose.Words.lic')
|
13
|
-
end
|
14
|
-
|
15
|
-
end
|
16
|
-
end
|
1
|
+
module Asposewordsjavaforruby
|
2
|
+
module ApplyLicense
|
3
|
+
def initialize()
|
4
|
+
apply_license()
|
5
|
+
end
|
6
|
+
|
7
|
+
def apply_license()
|
8
|
+
# This line attempts to set a license from several locations relative to the executable and Aspose.Words.dll.
|
9
|
+
# You can also use the additional overload to load a license from a stream, this is useful for instance when the
|
10
|
+
# license is stored as an embedded resource
|
11
|
+
license = Rjb::import('com.aspose.words.License').new()
|
12
|
+
license.setLicense('Aspose.Words.lic')
|
13
|
+
end
|
14
|
+
|
15
|
+
end
|
16
|
+
end
|
@@ -1,24 +1,24 @@
|
|
1
|
-
require_relative 'helloworld'
|
2
|
-
require_relative 'appenddoc'
|
3
|
-
require_relative 'applylicense'
|
4
|
-
require_relative 'findandreplace'
|
5
|
-
require_relative 'loadandsavetodisk'
|
6
|
-
require_relative 'loadandsavetostream'
|
7
|
-
require_relative 'simplemailmerge'
|
8
|
-
require_relative 'updatefields'
|
9
|
-
require_relative 'nodes'
|
10
|
-
require_relative 'processcomments'
|
11
|
-
require_relative 'addwatermark'
|
12
|
-
require_relative 'autofittables'
|
13
|
-
require_relative 'bookmarks'
|
14
|
-
require_relative 'compressimages'
|
15
|
-
require_relative 'insertnestedfields'
|
16
|
-
require_relative 'appenddocument'
|
17
|
-
require_relative 'styles'
|
18
|
-
require_relative 'removebreaks'
|
19
|
-
require_relative 'extractcontent'
|
20
|
-
require_relative 'checkformat'
|
21
|
-
require_relative 'loadtxt'
|
22
|
-
require_relative 'saveasmultipagetiff'
|
23
|
-
require_relative 'mergefield'
|
1
|
+
require_relative 'helloworld'
|
2
|
+
require_relative 'appenddoc'
|
3
|
+
require_relative 'applylicense'
|
4
|
+
require_relative 'findandreplace'
|
5
|
+
require_relative 'loadandsavetodisk'
|
6
|
+
require_relative 'loadandsavetostream'
|
7
|
+
require_relative 'simplemailmerge'
|
8
|
+
require_relative 'updatefields'
|
9
|
+
require_relative 'nodes'
|
10
|
+
require_relative 'processcomments'
|
11
|
+
require_relative 'addwatermark'
|
12
|
+
require_relative 'autofittables'
|
13
|
+
require_relative 'bookmarks'
|
14
|
+
require_relative 'compressimages'
|
15
|
+
require_relative 'insertnestedfields'
|
16
|
+
require_relative 'appenddocument'
|
17
|
+
require_relative 'styles'
|
18
|
+
require_relative 'removebreaks'
|
19
|
+
require_relative 'extractcontent'
|
20
|
+
require_relative 'checkformat'
|
21
|
+
require_relative 'loadtxt'
|
22
|
+
require_relative 'saveasmultipagetiff'
|
23
|
+
require_relative 'mergefield'
|
24
24
|
require_relative 'doctohtml'
|
@@ -1,123 +1,123 @@
|
|
1
|
-
module Asposewordsjavaforruby
|
2
|
-
module AutoFitTables
|
3
|
-
def initialize()
|
4
|
-
# The path to the documents directory.
|
5
|
-
@data_dir = File.dirname(File.dirname(File.dirname(__FILE__))) + '/data/'
|
6
|
-
|
7
|
-
# Demonstrate autofitting a table to the window.
|
8
|
-
autofit_table_to_window()
|
9
|
-
|
10
|
-
# Demonstrate autofitting a table to its contents.
|
11
|
-
autofit_table_to_contents()
|
12
|
-
|
13
|
-
# Demonstrate autofitting a table to fixed column widths.
|
14
|
-
autofit_table_to_fixed_column_widths()
|
15
|
-
end
|
16
|
-
|
17
|
-
=begin
|
18
|
-
ExStart
|
19
|
-
ExFor:Table.AutoFit
|
20
|
-
ExFor:AutoFitBehavior
|
21
|
-
ExId:FitTableToPageWidth
|
22
|
-
ExSummary:Autofits a table to fit the page width.
|
23
|
-
=end
|
24
|
-
def autofit_table_to_window()
|
25
|
-
#data_dir = File.dirname(File.dirname(File.dirname(__FILE__))) + '/data/'
|
26
|
-
# Open the document
|
27
|
-
doc = Rjb::import('com.aspose.words.Document').new(@data_dir + "TestFile.doc")
|
28
|
-
|
29
|
-
node_type = Rjb::import('com.aspose.words.NodeType')
|
30
|
-
table = doc.getChild(node_type.TABLE, 0, true)
|
31
|
-
|
32
|
-
# Autofit the first table to the page width.
|
33
|
-
autofit_behavior = Rjb::import("com.aspose.words.AutoFitBehavior")
|
34
|
-
table.autoFit(autofit_behavior.AUTO_FIT_TO_WINDOW)
|
35
|
-
|
36
|
-
# Save the document to disk.
|
37
|
-
doc.save(@data_dir + "TestFile.AutoFitToWindow Out.doc")
|
38
|
-
# ExEnd
|
39
|
-
preferred_width_type = Rjb::import("com.aspose.words.PreferredWidthType")
|
40
|
-
|
41
|
-
if (doc.getFirstSection().getBody().getTables().get(0).getPreferredWidth().getType() == preferred_width_type.PERCENT) then
|
42
|
-
puts "PreferredWidth type is not percent."
|
43
|
-
end
|
44
|
-
|
45
|
-
if (doc.getFirstSection().getBody().getTables().get(0).getPreferredWidth().getValue() == 100) then
|
46
|
-
puts "PreferredWidth value is different than 100."
|
47
|
-
end
|
48
|
-
end
|
49
|
-
|
50
|
-
=begin
|
51
|
-
ExStart
|
52
|
-
ExFor:Table.AutoFit
|
53
|
-
ExFor:AutoFitBehavior
|
54
|
-
ExId:FitTableToContents
|
55
|
-
ExSummary:Autofits a table in the document to its contents.
|
56
|
-
=end
|
57
|
-
def autofit_table_to_contents()
|
58
|
-
# Open the document
|
59
|
-
doc = Rjb::import('com.aspose.words.Document').new(@data_dir + "TestFile.doc")
|
60
|
-
|
61
|
-
node_type = Rjb::import('com.aspose.words.NodeType')
|
62
|
-
table = doc.getChild(node_type.TABLE, 0, true)
|
63
|
-
|
64
|
-
# Autofit the table to the cell contents
|
65
|
-
autofit_behavior = Rjb::import("com.aspose.words.AutoFitBehavior")
|
66
|
-
table.autoFit(autofit_behavior.AUTO_FIT_TO_CONTENTS)
|
67
|
-
|
68
|
-
# Save the document to disk.
|
69
|
-
doc.save(@data_dir + "TestFile.AutoFitToContents Out.doc")
|
70
|
-
# ExEnd
|
71
|
-
preferred_width_type = Rjb::import("com.aspose.words.PreferredWidthType")
|
72
|
-
|
73
|
-
if (doc.getFirstSection().getBody().getTables().get(0).getPreferredWidth().getType() == preferred_width_type.AUTO) then
|
74
|
-
puts "PreferredWidth type is not auto."
|
75
|
-
end
|
76
|
-
|
77
|
-
if (doc.getFirstSection().getBody().getTables().get(0).getFirstRow().getFirstCell().getCellFormat().getPreferredWidth().getType() == preferred_width_type.AUTO) then
|
78
|
-
puts "PrefferedWidth on cell is not auto."
|
79
|
-
end
|
80
|
-
|
81
|
-
if(doc.getFirstSection().getBody().getTables().get(0).getFirstRow().getFirstCell().getCellFormat().getPreferredWidth().getValue() == 0) then
|
82
|
-
puts "PreferredWidth value is not 0."
|
83
|
-
end
|
84
|
-
end
|
85
|
-
|
86
|
-
=begin
|
87
|
-
ExStart
|
88
|
-
ExFor:Table.AutoFit
|
89
|
-
ExFor:AutoFitBehavior
|
90
|
-
ExId:DisableAutoFitAndUseFixedWidths
|
91
|
-
ExSummary:Disables autofitting and enables fixed widths for the specified table.
|
92
|
-
=end
|
93
|
-
def autofit_table_to_fixed_column_widths()
|
94
|
-
# Open the document
|
95
|
-
doc = Rjb::import('com.aspose.words.Document').new(@data_dir + "TestFile.doc")
|
96
|
-
|
97
|
-
node_type = Rjb::import('com.aspose.words.NodeType')
|
98
|
-
table = doc.getChild(node_type.TABLE, 0, true)
|
99
|
-
|
100
|
-
# Disable autofitting on this table.
|
101
|
-
autofit_behavior = Rjb::import("com.aspose.words.AutoFitBehavior")
|
102
|
-
table.autoFit(autofit_behavior.AUTO_FIT_TO_CONTENTS)
|
103
|
-
|
104
|
-
# Save the document to disk.
|
105
|
-
doc.save(@data_dir + "TestFile.FixedWidth Out.doc")
|
106
|
-
# ExEnd
|
107
|
-
preferred_width_type = Rjb::import("com.aspose.words.PreferredWidthType")
|
108
|
-
|
109
|
-
if (doc.getFirstSection().getBody().getTables().get(0).getPreferredWidth().getType() == preferred_width_type.AUTO) then
|
110
|
-
puts "PreferredWidth type is not auto."
|
111
|
-
end
|
112
|
-
|
113
|
-
if (doc.getFirstSection().getBody().getTables().get(0).getPreferredWidth().getValue() == 0) then
|
114
|
-
puts "PreferredWidth value is not 0."
|
115
|
-
end
|
116
|
-
|
117
|
-
if (doc.getFirstSection().getBody().getTables().get(0).getFirstRow().getFirstCell().getCellFormat().getWidth() == 0) then
|
118
|
-
puts "Cell width is not correct."
|
119
|
-
end
|
120
|
-
end
|
121
|
-
|
122
|
-
end
|
123
|
-
end
|
1
|
+
module Asposewordsjavaforruby
|
2
|
+
module AutoFitTables
|
3
|
+
def initialize()
|
4
|
+
# The path to the documents directory.
|
5
|
+
@data_dir = File.dirname(File.dirname(File.dirname(__FILE__))) + '/data/'
|
6
|
+
|
7
|
+
# Demonstrate autofitting a table to the window.
|
8
|
+
autofit_table_to_window()
|
9
|
+
|
10
|
+
# Demonstrate autofitting a table to its contents.
|
11
|
+
autofit_table_to_contents()
|
12
|
+
|
13
|
+
# Demonstrate autofitting a table to fixed column widths.
|
14
|
+
autofit_table_to_fixed_column_widths()
|
15
|
+
end
|
16
|
+
|
17
|
+
=begin
|
18
|
+
ExStart
|
19
|
+
ExFor:Table.AutoFit
|
20
|
+
ExFor:AutoFitBehavior
|
21
|
+
ExId:FitTableToPageWidth
|
22
|
+
ExSummary:Autofits a table to fit the page width.
|
23
|
+
=end
|
24
|
+
def autofit_table_to_window()
|
25
|
+
#data_dir = File.dirname(File.dirname(File.dirname(__FILE__))) + '/data/'
|
26
|
+
# Open the document
|
27
|
+
doc = Rjb::import('com.aspose.words.Document').new(@data_dir + "TestFile.doc")
|
28
|
+
|
29
|
+
node_type = Rjb::import('com.aspose.words.NodeType')
|
30
|
+
table = doc.getChild(node_type.TABLE, 0, true)
|
31
|
+
|
32
|
+
# Autofit the first table to the page width.
|
33
|
+
autofit_behavior = Rjb::import("com.aspose.words.AutoFitBehavior")
|
34
|
+
table.autoFit(autofit_behavior.AUTO_FIT_TO_WINDOW)
|
35
|
+
|
36
|
+
# Save the document to disk.
|
37
|
+
doc.save(@data_dir + "TestFile.AutoFitToWindow Out.doc")
|
38
|
+
# ExEnd
|
39
|
+
preferred_width_type = Rjb::import("com.aspose.words.PreferredWidthType")
|
40
|
+
|
41
|
+
if (doc.getFirstSection().getBody().getTables().get(0).getPreferredWidth().getType() == preferred_width_type.PERCENT) then
|
42
|
+
puts "PreferredWidth type is not percent."
|
43
|
+
end
|
44
|
+
|
45
|
+
if (doc.getFirstSection().getBody().getTables().get(0).getPreferredWidth().getValue() == 100) then
|
46
|
+
puts "PreferredWidth value is different than 100."
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
=begin
|
51
|
+
ExStart
|
52
|
+
ExFor:Table.AutoFit
|
53
|
+
ExFor:AutoFitBehavior
|
54
|
+
ExId:FitTableToContents
|
55
|
+
ExSummary:Autofits a table in the document to its contents.
|
56
|
+
=end
|
57
|
+
def autofit_table_to_contents()
|
58
|
+
# Open the document
|
59
|
+
doc = Rjb::import('com.aspose.words.Document').new(@data_dir + "TestFile.doc")
|
60
|
+
|
61
|
+
node_type = Rjb::import('com.aspose.words.NodeType')
|
62
|
+
table = doc.getChild(node_type.TABLE, 0, true)
|
63
|
+
|
64
|
+
# Autofit the table to the cell contents
|
65
|
+
autofit_behavior = Rjb::import("com.aspose.words.AutoFitBehavior")
|
66
|
+
table.autoFit(autofit_behavior.AUTO_FIT_TO_CONTENTS)
|
67
|
+
|
68
|
+
# Save the document to disk.
|
69
|
+
doc.save(@data_dir + "TestFile.AutoFitToContents Out.doc")
|
70
|
+
# ExEnd
|
71
|
+
preferred_width_type = Rjb::import("com.aspose.words.PreferredWidthType")
|
72
|
+
|
73
|
+
if (doc.getFirstSection().getBody().getTables().get(0).getPreferredWidth().getType() == preferred_width_type.AUTO) then
|
74
|
+
puts "PreferredWidth type is not auto."
|
75
|
+
end
|
76
|
+
|
77
|
+
if (doc.getFirstSection().getBody().getTables().get(0).getFirstRow().getFirstCell().getCellFormat().getPreferredWidth().getType() == preferred_width_type.AUTO) then
|
78
|
+
puts "PrefferedWidth on cell is not auto."
|
79
|
+
end
|
80
|
+
|
81
|
+
if(doc.getFirstSection().getBody().getTables().get(0).getFirstRow().getFirstCell().getCellFormat().getPreferredWidth().getValue() == 0) then
|
82
|
+
puts "PreferredWidth value is not 0."
|
83
|
+
end
|
84
|
+
end
|
85
|
+
|
86
|
+
=begin
|
87
|
+
ExStart
|
88
|
+
ExFor:Table.AutoFit
|
89
|
+
ExFor:AutoFitBehavior
|
90
|
+
ExId:DisableAutoFitAndUseFixedWidths
|
91
|
+
ExSummary:Disables autofitting and enables fixed widths for the specified table.
|
92
|
+
=end
|
93
|
+
def autofit_table_to_fixed_column_widths()
|
94
|
+
# Open the document
|
95
|
+
doc = Rjb::import('com.aspose.words.Document').new(@data_dir + "TestFile.doc")
|
96
|
+
|
97
|
+
node_type = Rjb::import('com.aspose.words.NodeType')
|
98
|
+
table = doc.getChild(node_type.TABLE, 0, true)
|
99
|
+
|
100
|
+
# Disable autofitting on this table.
|
101
|
+
autofit_behavior = Rjb::import("com.aspose.words.AutoFitBehavior")
|
102
|
+
table.autoFit(autofit_behavior.AUTO_FIT_TO_CONTENTS)
|
103
|
+
|
104
|
+
# Save the document to disk.
|
105
|
+
doc.save(@data_dir + "TestFile.FixedWidth Out.doc")
|
106
|
+
# ExEnd
|
107
|
+
preferred_width_type = Rjb::import("com.aspose.words.PreferredWidthType")
|
108
|
+
|
109
|
+
if (doc.getFirstSection().getBody().getTables().get(0).getPreferredWidth().getType() == preferred_width_type.AUTO) then
|
110
|
+
puts "PreferredWidth type is not auto."
|
111
|
+
end
|
112
|
+
|
113
|
+
if (doc.getFirstSection().getBody().getTables().get(0).getPreferredWidth().getValue() == 0) then
|
114
|
+
puts "PreferredWidth value is not 0."
|
115
|
+
end
|
116
|
+
|
117
|
+
if (doc.getFirstSection().getBody().getTables().get(0).getFirstRow().getFirstCell().getCellFormat().getWidth() == 0) then
|
118
|
+
puts "Cell width is not correct."
|
119
|
+
end
|
120
|
+
end
|
121
|
+
|
122
|
+
end
|
123
|
+
end
|
@@ -1,132 +1,132 @@
|
|
1
|
-
module Asposewordsjavaforruby
|
2
|
-
module Bookmarks
|
3
|
-
def initialize()
|
4
|
-
# The path to the documents directory.
|
5
|
-
@data_dir = File.dirname(File.dirname(File.dirname(__FILE__))) + '/data/bookmarks/'
|
6
|
-
|
7
|
-
# Open the document.
|
8
|
-
doc = Rjb::import('com.aspose.words.Document').new(@data_dir + 'TestDefect1352.doc')
|
9
|
-
|
10
|
-
append_bookmark_text()
|
11
|
-
|
12
|
-
# This perform the custom task of putting the row bookmark ends into the same row with the bookmark starts.
|
13
|
-
untangle_row_bookmark(doc)
|
14
|
-
|
15
|
-
# Now we can easily delete rows by a bookmark without damaging any other row's bookmarks.
|
16
|
-
delete_row_by_bookmark(doc, 'ROW2')
|
17
|
-
end
|
18
|
-
|
19
|
-
def append_bookmark_text()
|
20
|
-
data_dir = File.dirname(File.dirname(File.dirname(__FILE__))) + '/data/bookmarks/'
|
21
|
-
|
22
|
-
# Load the source document.
|
23
|
-
src_doc = Rjb::import('com.aspose.words.Document').new(data_dir + "Template.doc")
|
24
|
-
|
25
|
-
# This is the bookmark whose content we want to copy.
|
26
|
-
src_bookmark = src_doc.getRange().getBookmarks().get("ntf010145060")
|
27
|
-
|
28
|
-
# We will be adding to this document.
|
29
|
-
dst_doc = Rjb::import('com.aspose.words.Document').new()
|
30
|
-
|
31
|
-
# Let's say we will be appending to the end of the body of the last section.
|
32
|
-
#node_type = Rjb::import('com.aspose.words.NodeType')
|
33
|
-
dst_node = dst_doc.getLastSection().getBody()
|
34
|
-
|
35
|
-
# It is a good idea to use this import context object because multiple nodes are being imported.
|
36
|
-
# If you import multiple times without a single context, it will result in many styles created.
|
37
|
-
import_format_mode = Rjb::import('com.aspose.words.ImportFormatMode')
|
38
|
-
importer = Rjb::import("com.aspose.words.NodeImporter").new(src_doc, dst_doc, import_format_mode.KEEP_SOURCE_FORMATTING)
|
39
|
-
|
40
|
-
# This is the paragraph that contains the beginning of the bookmark.
|
41
|
-
start_para = src_bookmark.getBookmarkStart().getParentNode()
|
42
|
-
|
43
|
-
# This is the paragraph that contains the end of the bookmark.
|
44
|
-
end_para = src_bookmark.getBookmarkEnd().getParentNode()
|
45
|
-
|
46
|
-
if (start_para == "" || end_para == "") then
|
47
|
-
raise "Parent of the bookmark start or end is not a paragraph, cannot handle this scenario yet."
|
48
|
-
end
|
49
|
-
|
50
|
-
util = Rjb::import("java.io.InputStream")
|
51
|
-
# Limit ourselves to a reasonably simple scenario.
|
52
|
-
spara = (start_para.getParentNode()).to_string
|
53
|
-
epara = (end_para.getParentNode()).to_string
|
54
|
-
#p spara.strip
|
55
|
-
#abort('spara')
|
56
|
-
|
57
|
-
|
58
|
-
if spara.strip != epara.strip then
|
59
|
-
#if (start_para.getParentNode() != end_para.getParentNode()) then
|
60
|
-
raise "Start and end paragraphs have different parents, cannot handle this scenario yet."
|
61
|
-
end
|
62
|
-
|
63
|
-
# We want to copy all paragraphs from the start paragraph up to (and including) the end paragraph,
|
64
|
-
# therefore the node at which we stop is one after the end paragraph.
|
65
|
-
endNode = end_para.getNextSibling()
|
66
|
-
|
67
|
-
# This is the loop to go through all paragraph-level nodes in the bookmark.
|
68
|
-
curNode = start_para
|
69
|
-
cNode = curNode
|
70
|
-
eNode = endNode
|
71
|
-
|
72
|
-
while (cNode != eNode) do
|
73
|
-
# This creates a copy of the current node and imports it (makes it valid) in the context
|
74
|
-
# of the destination document. Importing means adjusting styles and list identifiers correctly.
|
75
|
-
newNode = importer.importNode(curNode, true)
|
76
|
-
curNode = curNode.getNextSibling()
|
77
|
-
cNode = curNode
|
78
|
-
dst_node.appendChild(newNode)
|
79
|
-
end
|
80
|
-
|
81
|
-
# Save the finished document.
|
82
|
-
dst_doc.save(data_dir + "Template Out.doc");
|
83
|
-
end
|
84
|
-
|
85
|
-
def untangle_row_bookmark(doc)
|
86
|
-
bookmarks = doc.getRange().getBookmarks()
|
87
|
-
bookmarks_count = bookmarks.getCount()
|
88
|
-
|
89
|
-
i = 0
|
90
|
-
while i < bookmarks_count do
|
91
|
-
bookmark = bookmarks.get(i)
|
92
|
-
row1 = bookmark.getBookmarkStart().getAncestor(Rjb::import("com.aspose.words.Row"))
|
93
|
-
row2 = bookmark.getBookmarkEnd().getAncestor(Rjb::import("com.aspose.words.Row"))
|
94
|
-
|
95
|
-
# If both rows are found okay and the bookmark start and end are contained
|
96
|
-
# in adjacent rows, then just move the bookmark end node to the end
|
97
|
-
# of the last paragraph in the last cell of the top row.
|
98
|
-
if ((row1 != "") && (row2 != "") && (row1.getNextSibling() == row2)) then
|
99
|
-
row1.getLastCell().getLastParagraph().appendChild(bookmark.getBookmarkEnd())
|
100
|
-
end
|
101
|
-
$i +=1
|
102
|
-
end
|
103
|
-
|
104
|
-
# Save the document.
|
105
|
-
doc.save(@data_dir + "TestDefect1352 Out.doc")
|
106
|
-
end
|
107
|
-
|
108
|
-
def delete_row_by_bookmark(doc, bookmark_name)
|
109
|
-
raise 'bookmark_name not specified.' if bookmark_name.empty?
|
110
|
-
|
111
|
-
bookmark = doc.getRange().getBookmarks().get(bookmark_name)
|
112
|
-
|
113
|
-
if bookmark.nil? then
|
114
|
-
return
|
115
|
-
end
|
116
|
-
|
117
|
-
# Get the parent row of the bookmark. Exit if the bookmark is not in a row.
|
118
|
-
row = bookmark.getBookmarkStart().getAncestor(Rjb::import('com.aspose.words.Row'))
|
119
|
-
|
120
|
-
if row.nil? then
|
121
|
-
return
|
122
|
-
end
|
123
|
-
|
124
|
-
# Remove the row.
|
125
|
-
row.remove()
|
126
|
-
|
127
|
-
# Save the document.
|
128
|
-
doc.save(@data_dir + "TestDefect1352 Out.doc")
|
129
|
-
end
|
130
|
-
|
131
|
-
end
|
132
|
-
end
|
1
|
+
module Asposewordsjavaforruby
|
2
|
+
module Bookmarks
|
3
|
+
def initialize()
|
4
|
+
# The path to the documents directory.
|
5
|
+
@data_dir = File.dirname(File.dirname(File.dirname(__FILE__))) + '/data/bookmarks/'
|
6
|
+
|
7
|
+
# Open the document.
|
8
|
+
doc = Rjb::import('com.aspose.words.Document').new(@data_dir + 'TestDefect1352.doc')
|
9
|
+
|
10
|
+
append_bookmark_text()
|
11
|
+
|
12
|
+
# This perform the custom task of putting the row bookmark ends into the same row with the bookmark starts.
|
13
|
+
untangle_row_bookmark(doc)
|
14
|
+
|
15
|
+
# Now we can easily delete rows by a bookmark without damaging any other row's bookmarks.
|
16
|
+
delete_row_by_bookmark(doc, 'ROW2')
|
17
|
+
end
|
18
|
+
|
19
|
+
def append_bookmark_text()
|
20
|
+
data_dir = File.dirname(File.dirname(File.dirname(__FILE__))) + '/data/bookmarks/'
|
21
|
+
|
22
|
+
# Load the source document.
|
23
|
+
src_doc = Rjb::import('com.aspose.words.Document').new(data_dir + "Template.doc")
|
24
|
+
|
25
|
+
# This is the bookmark whose content we want to copy.
|
26
|
+
src_bookmark = src_doc.getRange().getBookmarks().get("ntf010145060")
|
27
|
+
|
28
|
+
# We will be adding to this document.
|
29
|
+
dst_doc = Rjb::import('com.aspose.words.Document').new()
|
30
|
+
|
31
|
+
# Let's say we will be appending to the end of the body of the last section.
|
32
|
+
#node_type = Rjb::import('com.aspose.words.NodeType')
|
33
|
+
dst_node = dst_doc.getLastSection().getBody()
|
34
|
+
|
35
|
+
# It is a good idea to use this import context object because multiple nodes are being imported.
|
36
|
+
# If you import multiple times without a single context, it will result in many styles created.
|
37
|
+
import_format_mode = Rjb::import('com.aspose.words.ImportFormatMode')
|
38
|
+
importer = Rjb::import("com.aspose.words.NodeImporter").new(src_doc, dst_doc, import_format_mode.KEEP_SOURCE_FORMATTING)
|
39
|
+
|
40
|
+
# This is the paragraph that contains the beginning of the bookmark.
|
41
|
+
start_para = src_bookmark.getBookmarkStart().getParentNode()
|
42
|
+
|
43
|
+
# This is the paragraph that contains the end of the bookmark.
|
44
|
+
end_para = src_bookmark.getBookmarkEnd().getParentNode()
|
45
|
+
|
46
|
+
if (start_para == "" || end_para == "") then
|
47
|
+
raise "Parent of the bookmark start or end is not a paragraph, cannot handle this scenario yet."
|
48
|
+
end
|
49
|
+
|
50
|
+
util = Rjb::import("java.io.InputStream")
|
51
|
+
# Limit ourselves to a reasonably simple scenario.
|
52
|
+
spara = (start_para.getParentNode()).to_string
|
53
|
+
epara = (end_para.getParentNode()).to_string
|
54
|
+
#p spara.strip
|
55
|
+
#abort('spara')
|
56
|
+
|
57
|
+
|
58
|
+
if spara.strip != epara.strip then
|
59
|
+
#if (start_para.getParentNode() != end_para.getParentNode()) then
|
60
|
+
raise "Start and end paragraphs have different parents, cannot handle this scenario yet."
|
61
|
+
end
|
62
|
+
|
63
|
+
# We want to copy all paragraphs from the start paragraph up to (and including) the end paragraph,
|
64
|
+
# therefore the node at which we stop is one after the end paragraph.
|
65
|
+
endNode = end_para.getNextSibling()
|
66
|
+
|
67
|
+
# This is the loop to go through all paragraph-level nodes in the bookmark.
|
68
|
+
curNode = start_para
|
69
|
+
cNode = curNode
|
70
|
+
eNode = endNode
|
71
|
+
|
72
|
+
while (cNode != eNode) do
|
73
|
+
# This creates a copy of the current node and imports it (makes it valid) in the context
|
74
|
+
# of the destination document. Importing means adjusting styles and list identifiers correctly.
|
75
|
+
newNode = importer.importNode(curNode, true)
|
76
|
+
curNode = curNode.getNextSibling()
|
77
|
+
cNode = curNode
|
78
|
+
dst_node.appendChild(newNode)
|
79
|
+
end
|
80
|
+
|
81
|
+
# Save the finished document.
|
82
|
+
dst_doc.save(data_dir + "Template Out.doc");
|
83
|
+
end
|
84
|
+
|
85
|
+
def untangle_row_bookmark(doc)
|
86
|
+
bookmarks = doc.getRange().getBookmarks()
|
87
|
+
bookmarks_count = bookmarks.getCount()
|
88
|
+
|
89
|
+
i = 0
|
90
|
+
while i < bookmarks_count do
|
91
|
+
bookmark = bookmarks.get(i)
|
92
|
+
row1 = bookmark.getBookmarkStart().getAncestor(Rjb::import("com.aspose.words.Row"))
|
93
|
+
row2 = bookmark.getBookmarkEnd().getAncestor(Rjb::import("com.aspose.words.Row"))
|
94
|
+
|
95
|
+
# If both rows are found okay and the bookmark start and end are contained
|
96
|
+
# in adjacent rows, then just move the bookmark end node to the end
|
97
|
+
# of the last paragraph in the last cell of the top row.
|
98
|
+
if ((row1 != "") && (row2 != "") && (row1.getNextSibling() == row2)) then
|
99
|
+
row1.getLastCell().getLastParagraph().appendChild(bookmark.getBookmarkEnd())
|
100
|
+
end
|
101
|
+
$i +=1
|
102
|
+
end
|
103
|
+
|
104
|
+
# Save the document.
|
105
|
+
doc.save(@data_dir + "TestDefect1352 Out.doc")
|
106
|
+
end
|
107
|
+
|
108
|
+
def delete_row_by_bookmark(doc, bookmark_name)
|
109
|
+
raise 'bookmark_name not specified.' if bookmark_name.empty?
|
110
|
+
|
111
|
+
bookmark = doc.getRange().getBookmarks().get(bookmark_name)
|
112
|
+
|
113
|
+
if bookmark.nil? then
|
114
|
+
return
|
115
|
+
end
|
116
|
+
|
117
|
+
# Get the parent row of the bookmark. Exit if the bookmark is not in a row.
|
118
|
+
row = bookmark.getBookmarkStart().getAncestor(Rjb::import('com.aspose.words.Row'))
|
119
|
+
|
120
|
+
if row.nil? then
|
121
|
+
return
|
122
|
+
end
|
123
|
+
|
124
|
+
# Remove the row.
|
125
|
+
row.remove()
|
126
|
+
|
127
|
+
# Save the document.
|
128
|
+
doc.save(@data_dir + "TestDefect1352 Out.doc")
|
129
|
+
end
|
130
|
+
|
131
|
+
end
|
132
|
+
end
|