axlsx-builder 0.0.1

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.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 4f38f6a8ca59c2a6971a1ad62df33a076c3a26c4
4
+ data.tar.gz: 067d8b0173c37e20be040fbd89ff484365b122b4
5
+ SHA512:
6
+ metadata.gz: 00afcc89be4cf37f54909fef245e8ddb3fbbe2b01de9a5bfa34710a6971080bf83e69c19b429308fa1245b158e2265d2ae3d6ce1714b675dee980a4b24bf7bb8
7
+ data.tar.gz: 8f81725e1dc5538b0ad93e504602144b884c61b5caa42a2ffd20ceb51b35957c46f6d6fe4e5b67ec8572d65a7ccbe5166d6d31f3292e1b0457741c225791493b
@@ -0,0 +1,9 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /Gemfile.lock
4
+ /_yardoc/
5
+ /coverage/
6
+ /doc/
7
+ /pkg/
8
+ /spec/reports/
9
+ /tmp/
@@ -0,0 +1,7 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <Settings><!--This file was automatically generated by Ruby plugin.
3
+ You are allowed to:
4
+ 1. Remove rake task
5
+ 2. Add existing rake tasks
6
+ To add existing rake tasks automatically delete this file and reload the project.
7
+ --><RakeGroup description="" fullCmd="" taksId="rake"><RakeTask description="Build axlsx-builder-0.1.0.gem into the pkg directory" fullCmd="build" taksId="build" /><RakeTask description="Remove any temporary products" fullCmd="clean" taksId="clean" /><RakeTask description="Remove any generated files" fullCmd="clobber" taksId="clobber" /><RakeTask description="Build and install axlsx-builder-0.1.0.gem into system gems" fullCmd="install" taksId="install" /><RakeGroup description="" fullCmd="" taksId="install"><RakeTask description="Build and install axlsx-builder-0.1.0.gem into system gems without network access" fullCmd="install:local" taksId="local" /></RakeGroup><RakeTask description="Create tag v0.1.0 and build and push axlsx-builder-0.1.0.gem to Rubygems" fullCmd="release[remote]" taksId="release[remote]" /><RakeTask description="Run RSpec code examples" fullCmd="spec" taksId="spec" /><RakeTask description="" fullCmd="default" taksId="default" /><RakeTask description="" fullCmd="release" taksId="release" /><RakeGroup description="" fullCmd="" taksId="release"><RakeTask description="" fullCmd="release:guard_clean" taksId="guard_clean" /><RakeTask description="" fullCmd="release:rubygem_push" taksId="rubygem_push" /><RakeTask description="" fullCmd="release:source_control_push" taksId="source_control_push" /></RakeGroup></RakeGroup></Settings>
@@ -0,0 +1,27 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <module type="RUBY_MODULE" version="4">
3
+ <component name="FacetManager">
4
+ <facet type="gem" name="New Gem">
5
+ <configuration>
6
+ <option name="GEM_APP_ROOT_PATH" value="$MODULE_DIR$" />
7
+ <option name="GEM_APP_TEST_PATH" value="" />
8
+ <option name="GEM_APP_LIB_PATH" value="$MODULE_DIR$/lib" />
9
+ </configuration>
10
+ </facet>
11
+ </component>
12
+ <component name="NewModuleRootManager">
13
+ <content url="file://$MODULE_DIR$">
14
+ <excludeFolder url="file://$MODULE_DIR$/.bundle" />
15
+ <excludeFolder url="file://$MODULE_DIR$/vendor/bundle" />
16
+ </content>
17
+ <orderEntry type="inheritedJdk" />
18
+ <orderEntry type="sourceFolder" forTests="false" />
19
+ <orderEntry type="library" scope="PROVIDED" name="axlsx (v2.0.1, rbenv: 2.2.3) [gem]" level="application" />
20
+ <orderEntry type="library" scope="PROVIDED" name="bundler (v1.12.1, rbenv: 2.2.3) [gem]" level="application" />
21
+ <orderEntry type="library" scope="PROVIDED" name="htmlentities (v4.3.4, rbenv: 2.2.3) [gem]" level="application" />
22
+ <orderEntry type="library" scope="PROVIDED" name="mini_portile2 (v2.0.0, rbenv: 2.2.3) [gem]" level="application" />
23
+ <orderEntry type="library" scope="PROVIDED" name="nokogiri (v1.6.7.2, rbenv: 2.2.3) [gem]" level="application" />
24
+ <orderEntry type="library" scope="PROVIDED" name="rake (v10.3.2, rbenv: 2.2.3) [gem]" level="application" />
25
+ <orderEntry type="library" scope="PROVIDED" name="rubyzip (v1.0.0, rbenv: 2.2.3) [gem]" level="application" />
26
+ </component>
27
+ </module>
@@ -0,0 +1,14 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <project version="4">
3
+ <component name="ProjectLevelVcsManager" settingsEditedManually="false">
4
+ <OptionsSetting value="true" id="Add" />
5
+ <OptionsSetting value="true" id="Remove" />
6
+ <OptionsSetting value="true" id="Checkout" />
7
+ <OptionsSetting value="true" id="Update" />
8
+ <OptionsSetting value="true" id="Status" />
9
+ <OptionsSetting value="true" id="Edit" />
10
+ <ConfirmationsSetting value="0" id="Add" />
11
+ <ConfirmationsSetting value="0" id="Remove" />
12
+ </component>
13
+ <component name="ProjectRootManager" version="2" project-jdk-name="rbenv: 2.2.3" project-jdk-type="RUBY_SDK" />
14
+ </project>
@@ -0,0 +1,8 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <project version="4">
3
+ <component name="ProjectModuleManager">
4
+ <modules>
5
+ <module fileurl="file://$PROJECT_DIR$/.idea/axlsx-builder.iml" filepath="$PROJECT_DIR$/.idea/axlsx-builder.iml" />
6
+ </modules>
7
+ </component>
8
+ </project>
@@ -0,0 +1,6 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <project version="4">
3
+ <component name="VcsDirectoryMappings">
4
+ <mapping directory="$PROJECT_DIR$" vcs="Git" />
5
+ </component>
6
+ </project>
@@ -0,0 +1,252 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <project version="4">
3
+ <component name="ChangeListManager">
4
+ <list default="true" id="1ec5680b-db0f-4fa9-b451-9b67268db70c" name="Default" comment="">
5
+ <change type="MODIFICATION" beforePath="$PROJECT_DIR$/.idea/workspace.xml" afterPath="$PROJECT_DIR$/.idea/workspace.xml" />
6
+ <change type="MODIFICATION" beforePath="$PROJECT_DIR$/axlsx-builder.gemspec" afterPath="$PROJECT_DIR$/axlsx-builder.gemspec" />
7
+ <change type="MODIFICATION" beforePath="$PROJECT_DIR$/lib/axlsx/builder/version.rb" afterPath="$PROJECT_DIR$/lib/axlsx/builder/version.rb" />
8
+ </list>
9
+ <ignored path="axlsx-builder.iws" />
10
+ <ignored path=".idea/workspace.xml" />
11
+ <ignored path="$PROJECT_DIR$/.bundle/" />
12
+ <ignored path="$PROJECT_DIR$/vendor/bundle/" />
13
+ <ignored path=".idea/dataSources.local.xml" />
14
+ <option name="EXCLUDED_CONVERTED_TO_IGNORED" value="true" />
15
+ <option name="TRACKING_ENABLED" value="true" />
16
+ <option name="SHOW_DIALOG" value="false" />
17
+ <option name="HIGHLIGHT_CONFLICTS" value="true" />
18
+ <option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
19
+ <option name="LAST_RESOLUTION" value="IGNORE" />
20
+ </component>
21
+ <component name="ChangesViewManager" flattened_view="true" show_ignored="false" />
22
+ <component name="CreatePatchCommitExecutor">
23
+ <option name="PATCH_PATH" value="" />
24
+ </component>
25
+ <component name="FavoritesManager">
26
+ <favorites_list name="axlsx-builder" />
27
+ </component>
28
+ <component name="FileEditorManager">
29
+ <leaf>
30
+ <file leaf-file-name="builder.rb" pinned="false" current-in-tab="false">
31
+ <entry file="file://$PROJECT_DIR$/lib/axlsx/builder.rb">
32
+ <provider selected="true" editor-type-id="text-editor">
33
+ <state relative-caret-position="644">
34
+ <caret line="496" column="0" selection-start-line="496" selection-start-column="0" selection-end-line="496" selection-end-column="0" />
35
+ <folding />
36
+ </state>
37
+ </provider>
38
+ </entry>
39
+ </file>
40
+ <file leaf-file-name="axlsx-builder.gemspec" pinned="false" current-in-tab="false">
41
+ <entry file="file://$PROJECT_DIR$/axlsx-builder.gemspec">
42
+ <provider selected="true" editor-type-id="text-editor">
43
+ <state relative-caret-position="390">
44
+ <caret line="26" column="3" selection-start-line="26" selection-start-column="3" selection-end-line="26" selection-end-column="3" />
45
+ <folding />
46
+ </state>
47
+ </provider>
48
+ </entry>
49
+ </file>
50
+ <file leaf-file-name="version.rb" pinned="false" current-in-tab="true">
51
+ <entry file="file://$PROJECT_DIR$/lib/axlsx/builder/version.rb">
52
+ <provider selected="true" editor-type-id="text-editor">
53
+ <state relative-caret-position="75">
54
+ <caret line="5" column="0" selection-start-line="5" selection-start-column="0" selection-end-line="5" selection-end-column="0" />
55
+ <folding />
56
+ </state>
57
+ </provider>
58
+ </entry>
59
+ </file>
60
+ </leaf>
61
+ </component>
62
+ <component name="Git.Settings">
63
+ <option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$" />
64
+ </component>
65
+ <component name="IdeDocumentHistory">
66
+ <option name="CHANGED_PATHS">
67
+ <list>
68
+ <option value="$PROJECT_DIR$/lib/axlsx/builder.rb" />
69
+ <option value="$PROJECT_DIR$/axlsx-builder.gemspec" />
70
+ <option value="$PROJECT_DIR$/lib/axlsx/builder/version.rb" />
71
+ </list>
72
+ </option>
73
+ </component>
74
+ <component name="JsBuildToolGruntFileManager" detection-done="true" sorting="DEFINITION_ORDER" />
75
+ <component name="JsBuildToolPackageJson" detection-done="true" sorting="DEFINITION_ORDER" />
76
+ <component name="JsGulpfileManager">
77
+ <detection-done>true</detection-done>
78
+ <sorting>DEFINITION_ORDER</sorting>
79
+ </component>
80
+ <component name="ProjectFrameBounds">
81
+ <option name="x" value="73" />
82
+ <option name="y" value="23" />
83
+ <option name="width" value="1200" />
84
+ <option name="height" value="745" />
85
+ </component>
86
+ <component name="ProjectLevelVcsManager" settingsEditedManually="false">
87
+ <OptionsSetting value="true" id="Add" />
88
+ <OptionsSetting value="true" id="Remove" />
89
+ <OptionsSetting value="true" id="Checkout" />
90
+ <OptionsSetting value="true" id="Update" />
91
+ <OptionsSetting value="true" id="Status" />
92
+ <OptionsSetting value="true" id="Edit" />
93
+ <ConfirmationsSetting value="0" id="Add" />
94
+ <ConfirmationsSetting value="0" id="Remove" />
95
+ </component>
96
+ <component name="ProjectView">
97
+ <navigator currentView="ProjectPane" proportions="" version="1">
98
+ <flattenPackages />
99
+ <showMembers />
100
+ <showModules />
101
+ <showLibraryContents />
102
+ <hideEmptyPackages />
103
+ <abbreviatePackageNames />
104
+ <autoscrollToSource />
105
+ <autoscrollFromSource />
106
+ <sortByType />
107
+ <manualOrder />
108
+ <foldersAlwaysOnTop value="true" />
109
+ </navigator>
110
+ <panes>
111
+ <pane id="ProjectPane">
112
+ <subPane>
113
+ <PATH>
114
+ <PATH_ELEMENT>
115
+ <option name="myItemId" value="axlsx-builder" />
116
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
117
+ </PATH_ELEMENT>
118
+ </PATH>
119
+ <PATH>
120
+ <PATH_ELEMENT>
121
+ <option name="myItemId" value="axlsx-builder" />
122
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
123
+ </PATH_ELEMENT>
124
+ <PATH_ELEMENT>
125
+ <option name="myItemId" value="axlsx-builder" />
126
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
127
+ </PATH_ELEMENT>
128
+ </PATH>
129
+ <PATH>
130
+ <PATH_ELEMENT>
131
+ <option name="myItemId" value="axlsx-builder" />
132
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
133
+ </PATH_ELEMENT>
134
+ <PATH_ELEMENT>
135
+ <option name="myItemId" value="axlsx-builder" />
136
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
137
+ </PATH_ELEMENT>
138
+ <PATH_ELEMENT>
139
+ <option name="myItemId" value="lib" />
140
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
141
+ </PATH_ELEMENT>
142
+ <PATH_ELEMENT>
143
+ <option name="myItemId" value="axlsx" />
144
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
145
+ </PATH_ELEMENT>
146
+ </PATH>
147
+ <PATH>
148
+ <PATH_ELEMENT>
149
+ <option name="myItemId" value="axlsx-builder" />
150
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
151
+ </PATH_ELEMENT>
152
+ <PATH_ELEMENT>
153
+ <option name="myItemId" value="axlsx-builder" />
154
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
155
+ </PATH_ELEMENT>
156
+ <PATH_ELEMENT>
157
+ <option name="myItemId" value="lib" />
158
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
159
+ </PATH_ELEMENT>
160
+ <PATH_ELEMENT>
161
+ <option name="myItemId" value="axlsx" />
162
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
163
+ </PATH_ELEMENT>
164
+ <PATH_ELEMENT>
165
+ <option name="myItemId" value="builder" />
166
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
167
+ </PATH_ELEMENT>
168
+ </PATH>
169
+ </subPane>
170
+ </pane>
171
+ <pane id="Scratches" />
172
+ <pane id="Scope" />
173
+ </panes>
174
+ </component>
175
+ <component name="PropertiesComponent">
176
+ <property name="last_opened_file_path" value="$PROJECT_DIR$" />
177
+ <property name="WebServerToolWindowFactoryState" value="false" />
178
+ </component>
179
+ <component name="ShelveChangesManager" show_recycled="false">
180
+ <option name="remove_strategy" value="false" />
181
+ </component>
182
+ <component name="TaskManager">
183
+ <task active="true" id="Default" summary="Default task">
184
+ <changelist id="1ec5680b-db0f-4fa9-b451-9b67268db70c" name="Default" comment="" />
185
+ <created>1467385833150</created>
186
+ <option name="number" value="Default" />
187
+ <option name="presentableId" value="Default" />
188
+ <updated>1467385833150</updated>
189
+ <workItem from="1467385834420" duration="432000" />
190
+ </task>
191
+ <servers />
192
+ </component>
193
+ <component name="TimeTrackingManager">
194
+ <option name="totallyTimeSpent" value="432000" />
195
+ </component>
196
+ <component name="ToolWindowManager">
197
+ <frame x="73" y="23" width="1200" height="745" extended-state="0" />
198
+ <editor active="true" />
199
+ <layout>
200
+ <window_info id="Project" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" show_stripe_button="true" weight="0.25" sideWeight="0.5" order="0" side_tool="false" content_ui="combo" />
201
+ <window_info id="TODO" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.33" sideWeight="0.5" order="6" side_tool="false" content_ui="tabs" />
202
+ <window_info id="Event Log" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.33" sideWeight="0.5" order="-1" side_tool="true" content_ui="tabs" />
203
+ <window_info id="Database" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
204
+ <window_info id="Version Control" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
205
+ <window_info id="Structure" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
206
+ <window_info id="Terminal" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.33" sideWeight="0.5" order="-1" side_tool="false" content_ui="tabs" />
207
+ <window_info id="Favorites" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.33" sideWeight="0.5" order="-1" side_tool="true" content_ui="tabs" />
208
+ <window_info id="Cvs" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.25" sideWeight="0.5" order="4" side_tool="false" content_ui="tabs" />
209
+ <window_info id="Hierarchy" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.25" sideWeight="0.5" order="2" side_tool="false" content_ui="combo" />
210
+ <window_info id="Message" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.33" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
211
+ <window_info id="Commander" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.4" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
212
+ <window_info id="Find" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.33" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
213
+ <window_info id="Inspection" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.4" sideWeight="0.5" order="5" side_tool="false" content_ui="tabs" />
214
+ <window_info id="Run" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.33" sideWeight="0.5" order="2" side_tool="false" content_ui="tabs" />
215
+ <window_info id="Ant Build" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.25" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
216
+ <window_info id="Debug" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" show_stripe_button="true" weight="0.4" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
217
+ </layout>
218
+ </component>
219
+ <component name="VcsContentAnnotationSettings">
220
+ <option name="myLimit" value="2678400000" />
221
+ </component>
222
+ <component name="XDebuggerManager">
223
+ <breakpoint-manager />
224
+ <watches-manager />
225
+ </component>
226
+ <component name="editorHistoryManager">
227
+ <entry file="file://$PROJECT_DIR$/lib/axlsx/builder.rb">
228
+ <provider selected="true" editor-type-id="text-editor">
229
+ <state relative-caret-position="644">
230
+ <caret line="496" column="0" selection-start-line="496" selection-start-column="0" selection-end-line="496" selection-end-column="0" />
231
+ <folding />
232
+ </state>
233
+ </provider>
234
+ </entry>
235
+ <entry file="file://$PROJECT_DIR$/axlsx-builder.gemspec">
236
+ <provider selected="true" editor-type-id="text-editor">
237
+ <state relative-caret-position="390">
238
+ <caret line="26" column="3" selection-start-line="26" selection-start-column="3" selection-end-line="26" selection-end-column="3" />
239
+ <folding />
240
+ </state>
241
+ </provider>
242
+ </entry>
243
+ <entry file="file://$PROJECT_DIR$/lib/axlsx/builder/version.rb">
244
+ <provider selected="true" editor-type-id="text-editor">
245
+ <state relative-caret-position="75">
246
+ <caret line="5" column="0" selection-start-line="5" selection-start-column="0" selection-end-line="5" selection-end-column="0" />
247
+ <folding />
248
+ </state>
249
+ </provider>
250
+ </entry>
251
+ </component>
252
+ </project>
data/.rspec ADDED
@@ -0,0 +1,2 @@
1
+ --format documentation
2
+ --color
@@ -0,0 +1,5 @@
1
+ sudo: false
2
+ language: ruby
3
+ rvm:
4
+ - 2.3.0
5
+ before_install: gem install bundler -v 1.12.5
@@ -0,0 +1,49 @@
1
+ # Contributor Code of Conduct
2
+
3
+ As contributors and maintainers of this project, and in the interest of
4
+ fostering an open and welcoming community, we pledge to respect all people who
5
+ contribute through reporting issues, posting feature requests, updating
6
+ documentation, submitting pull requests or patches, and other activities.
7
+
8
+ We are committed to making participation in this project a harassment-free
9
+ experience for everyone, regardless of level of experience, gender, gender
10
+ identity and expression, sexual orientation, disability, personal appearance,
11
+ body size, race, ethnicity, age, religion, or nationality.
12
+
13
+ Examples of unacceptable behavior by participants include:
14
+
15
+ * The use of sexualized language or imagery
16
+ * Personal attacks
17
+ * Trolling or insulting/derogatory comments
18
+ * Public or private harassment
19
+ * Publishing other's private information, such as physical or electronic
20
+ addresses, without explicit permission
21
+ * Other unethical or unprofessional conduct
22
+
23
+ Project maintainers have the right and responsibility to remove, edit, or
24
+ reject comments, commits, code, wiki edits, issues, and other contributions
25
+ that are not aligned to this Code of Conduct, or to ban temporarily or
26
+ permanently any contributor for other behaviors that they deem inappropriate,
27
+ threatening, offensive, or harmful.
28
+
29
+ By adopting this Code of Conduct, project maintainers commit themselves to
30
+ fairly and consistently applying these principles to every aspect of managing
31
+ this project. Project maintainers who do not follow or enforce the Code of
32
+ Conduct may be permanently removed from the project team.
33
+
34
+ This code of conduct applies both within project spaces and in public spaces
35
+ when an individual is representing the project or its community.
36
+
37
+ Instances of abusive, harassing, or otherwise unacceptable behavior may be
38
+ reported by contacting a project maintainer at shaynetremblay@hotmail.com. All
39
+ complaints will be reviewed and investigated and will result in a response that
40
+ is deemed necessary and appropriate to the circumstances. Maintainers are
41
+ obligated to maintain confidentiality with regard to the reporter of an
42
+ incident.
43
+
44
+ This Code of Conduct is adapted from the [Contributor Covenant][homepage],
45
+ version 1.3.0, available at
46
+ [http://contributor-covenant.org/version/1/3/0/][version]
47
+
48
+ [homepage]: http://contributor-covenant.org
49
+ [version]: http://contributor-covenant.org/version/1/3/0/
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in axlsx-builder.gemspec
4
+ gemspec
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2016 MainShayne233
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in
13
+ all copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21
+ THE SOFTWARE.
@@ -0,0 +1,41 @@
1
+ # Axlsx::Builder
2
+
3
+ Welcome to your new gem! In this directory, you'll find the files you need to be able to package up your Ruby library into a gem. Put your Ruby code in the file `lib/axlsx/builder`. To experiment with that code, run `bin/console` for an interactive prompt.
4
+
5
+ TODO: Delete this and the text above, and describe your gem
6
+
7
+ ## Installation
8
+
9
+ Add this line to your application's Gemfile:
10
+
11
+ ```ruby
12
+ gem 'axlsx-builder'
13
+ ```
14
+
15
+ And then execute:
16
+
17
+ $ bundle
18
+
19
+ Or install it yourself as:
20
+
21
+ $ gem install axlsx-builder
22
+
23
+ ## Usage
24
+
25
+ TODO: Write usage instructions here
26
+
27
+ ## Development
28
+
29
+ After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake spec` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
30
+
31
+ To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org).
32
+
33
+ ## Contributing
34
+
35
+ Bug reports and pull requests are welcome on GitHub at https://github.com/[USERNAME]/axlsx-builder. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [Contributor Covenant](http://contributor-covenant.org) code of conduct.
36
+
37
+
38
+ ## License
39
+
40
+ The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).
41
+
@@ -0,0 +1,6 @@
1
+ require "bundler/gem_tasks"
2
+ require "rspec/core/rake_task"
3
+
4
+ RSpec::Core::RakeTask.new(:spec)
5
+
6
+ task :default => :spec
@@ -0,0 +1,27 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'axlsx/builder/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "axlsx-builder"
8
+ spec.version = Axlsx::Builder::VERSION
9
+ spec.authors = ["MainShayne233"]
10
+ spec.email = ["shaynetremblay@hotmail.com"]
11
+
12
+ spec.summary = 'An extension of Axlsx that allows you create spreadsheets blueprints for '\
13
+ 'easy sheet generation, manipulation, and data input.'
14
+ spec.homepage = 'https://github.com/MainShayne233/axlsx-builder'
15
+ spec.license = 'MIT'
16
+
17
+
18
+ spec.files = `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
19
+ spec.bindir = "exe"
20
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
21
+ spec.require_paths = ["lib"]
22
+
23
+ spec.add_development_dependency 'bundler', '~> 1.12'
24
+ spec.add_development_dependency 'rake', '~> 10.0'
25
+ spec.add_development_dependency 'rspec', '~> 3.0'
26
+ spec.add_dependency 'axlsx', '~> 2.0.1.pre'
27
+ end
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require "bundler/setup"
4
+ require "axlsx/builder"
5
+
6
+ # You can add fixtures and/or initialization code here to make experimenting
7
+ # with your gem easier. You can also use a different console, if you like.
8
+
9
+ # (If you use this, don't forget to add pry to your Gemfile!)
10
+ # require "pry"
11
+ # Pry.start
12
+
13
+ require "irb"
14
+ IRB.start
@@ -0,0 +1,8 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+ IFS=$'\n\t'
4
+ set -vx
5
+
6
+ bundle install
7
+
8
+ # Do any other automated setup that you need to do here
@@ -0,0 +1,496 @@
1
+ module Axlsx
2
+ module Builder
3
+ class Object
4
+ def initialize(attrs={})
5
+ attrs.each { |key, val| send("#{key.to_s}=", val) }
6
+ end
7
+ end
8
+
9
+ class Cell < Object
10
+ attr_accessor :text
11
+ attr_accessor :title
12
+ attr_accessor :row
13
+ attr_accessor :col
14
+ end
15
+
16
+ class Alignment
17
+ attr_accessor :horizontal, :vertical
18
+
19
+ def initialize(horizontal: :left, vertical: :center)
20
+ @horizontal = horizontal
21
+ @vertical = vertical
22
+ end
23
+ end
24
+
25
+ class Font < Object
26
+ attr_accessor :name, :size, :color
27
+
28
+ def initialize(attrs={})
29
+ @name = 'Liberation Sans'
30
+ @size = 10
31
+ super
32
+ end
33
+ end
34
+
35
+ class Format < Object
36
+ attr_accessor :color, :font, :style, :borders, :border_thickness, :alignment
37
+
38
+ def initialize(attrs={})
39
+ @font = Font.new
40
+ @alignment = Alignment.new
41
+ super
42
+ end
43
+ end
44
+
45
+ class Position
46
+ attr_writer :col
47
+ attr_accessor :row
48
+
49
+ def initialize(row: 0, col: 0)
50
+ @row = row
51
+ @col = col
52
+ end
53
+
54
+ # Must subtract 1 from col as it is 0 based, not 1 based.
55
+ def col
56
+ @col-1
57
+ end
58
+ end
59
+
60
+ class Element < Object
61
+ attr_reader :pos
62
+ attr_accessor :text, :format, :borders, :border_thickness,
63
+ :merge, :comment
64
+
65
+ def initialize(attrs={})
66
+ @pos = Position.new
67
+ @format = Format.new
68
+ super
69
+ end
70
+
71
+ def pos=(pos)
72
+ @pos = Position.new(row: pos[0], col: pos[1])
73
+ end
74
+
75
+ def row; pos.row; end
76
+ def col; pos.col; end
77
+ def style; format.style; end
78
+ def font; format.font; end
79
+ def color; format.color; end
80
+ def h_align; format.alignment.horizontal; end
81
+ def v_align; format.alignment.vertical; end
82
+
83
+ def combined_style
84
+ combined_style = {}
85
+ if self.style
86
+ combined_style.merge!(b: true) if self.style.include? :bold
87
+ combined_style.merge!(i: true) if self.style.include? :italic
88
+ combined_style.merge!(u: true) if self.style.include? :underline
89
+ combined_style.merge!(alignment: {horizontal: :center}) if self.style.include? :center
90
+ combined_style.merge!(sz: 12) if self.style.include? :lg_font
91
+ end
92
+ combined_style.merge!(sz: self.font.size)
93
+ combined_style.merge!(font_name: self.font.name)
94
+ combined_style.merge!(bg_color: self.color) if self.color
95
+ combined_style.merge!(fg_color: self.font.color)
96
+ combined_style.merge!(alignment: {horizontal: h_align, vertical: v_align})
97
+ if self.borders == true
98
+ combined_style.merge! border: {style: self.border_thickness || :medium, color: '00000000'}
99
+ elsif self.borders
100
+ combined_style.merge! border: {style: self.border_thickness || :medium, color: '00000000', edges: self.borders}
101
+ end
102
+ combined_style
103
+ end
104
+ end
105
+
106
+ class Title < Element
107
+ attr_accessor :list, :hyperlink
108
+
109
+ def initialize attrs
110
+ h_align = :center # Default
111
+ v_align = :center # Default
112
+ attrs.each {|key, val| self.send("#{key.to_s}=", val)}
113
+ super
114
+ end
115
+
116
+ def combined_style
117
+ combined_style = super
118
+ combined_style.merge!(b: true, border: {style: :thick, color: '00000000'})
119
+ combined_style.merge!(bg_color: self.color) if self.color
120
+ combined_style
121
+ end
122
+ end
123
+
124
+
125
+ class Blueprint
126
+ attr_accessor :sheet, :elements, :column_titles, :row_titles, :column_titles_start,
127
+ :row_titles_start, :row_data, :column_data, :max, :column_title_row_height, :format
128
+
129
+ def initialize options = {}
130
+ options[:format] ||= Format.new
131
+
132
+ self.elements = if options[:elements]
133
+ options[:elements].map do |elem|
134
+ elem.merge!(format: options[:format]) unless elem[:format]
135
+ Element.new(elem)
136
+ end
137
+ else
138
+ []
139
+ end
140
+ self.column_titles = options[:column_titles] ? options[:column_titles].map{|elem| Title.new(elem)} : []
141
+ self.row_titles = options[:row_titles] ? options[:row_titles].map{|elem| Title.new(elem)} : []
142
+ self.column_titles_start = options[:column_titles_start] || [1,1]
143
+ self.row_titles_start = options[:row_titles_start] || [1,1]
144
+ self.column_title_row_height = options[:column_title_row_height]
145
+ end
146
+ end
147
+ end
148
+
149
+
150
+
151
+
152
+
153
+ class Worksheet
154
+ attr_accessor :column_title_indexes, :row_title_indexes, :blueprint, :column_data, :row_data
155
+
156
+ def build!
157
+ if self.column_data
158
+ self.blueprint.column_data = self.column_data.map{|elem| Builder::Cell.new(elem)}
159
+ end
160
+
161
+ if self.row_data
162
+ self.blueprint.row_data = self.row_data.map{|elem| Builder::Cell.new(elem)}
163
+ end
164
+
165
+ set_column_title_indexes
166
+
167
+ set_max_row_and_column
168
+
169
+ set_row_title_indexes
170
+
171
+ set_column_widths
172
+
173
+ set_row_heights
174
+
175
+ place_elements
176
+
177
+ place_column_titles
178
+
179
+ set_lists_for_column_titles
180
+
181
+ place_row_titles
182
+
183
+ set_lists_for_row_titles
184
+
185
+ set_column_title_row_height
186
+
187
+ place_column_data if self.blueprint.column_data
188
+
189
+ place_row_data if self.blueprint.row_data
190
+
191
+ move_lists_sheet_to_end
192
+
193
+ self
194
+ end
195
+
196
+ def set_column_title_indexes
197
+ self.column_title_indexes = {}
198
+ self.blueprint.column_titles.each_with_index {|elem, index| self.column_title_indexes[elem.text] = index+self.blueprint.column_titles_start[1]-1}
199
+ end
200
+
201
+ def set_row_title_indexes
202
+ self.row_title_indexes = {}
203
+ self.blueprint.row_titles.each_with_index {|elem, index| self.row_title_indexes[elem.text] = index+self.blueprint.row_titles_start[0]-1}
204
+ end
205
+
206
+ def set_column_widths
207
+ col_widths = {}
208
+
209
+ element_strings = []
210
+
211
+ self.blueprint.elements.each do |element|
212
+ longest_line = element.text.split("\n").max_by{|line| line.length}
213
+ element_strings.push [element.col, longest_line || '']
214
+ (1..element.merge).each {|column| col_widths[column] = 0} if element.merge
215
+ end
216
+
217
+ element_strings.each do |col, text|
218
+ col_widths[col] ||= 0
219
+ col_widths[col] = text.length if text.length > col_widths[col]
220
+ end
221
+
222
+ self.blueprint.column_titles.each_with_index do |elem, index|
223
+ col_widths[index+self.blueprint.column_titles_start[1]-1] ||= 0
224
+ col_widths[index+self.blueprint.column_titles_start[1]-1] = elem.text.length if elem.text.length > col_widths[index+self.blueprint.column_titles_start[1]-1]
225
+ end
226
+
227
+ unless self.blueprint.row_titles.empty?
228
+ col_widths[self.blueprint.row_titles_start[1]-1] ||= 0
229
+ max_row_title = self.blueprint.row_titles.max_by{|elem| elem.text.length}.text.length
230
+ col_widths[self.blueprint.row_titles_start[1]-1] = max_row_title if max_row_title > col_widths[self.blueprint.row_titles_start[1]-1]
231
+ end
232
+
233
+ if self.blueprint.column_data
234
+ self.blueprint.column_data.each do |elem|
235
+ title_column = self.column_title_indexes[elem.title]
236
+ col_widths[title_column] ||= 0
237
+ col_widths[title_column] = elem.text.length if elem.text.length > col_widths[title_column]
238
+ end
239
+ end
240
+
241
+ if self.blueprint.row_data
242
+ self.blueprint.row_data.each do |elem|
243
+ self.blueprint.row_data.select{|data| data.text == elem.text}.each_with_index do |title_data, index|
244
+ column = self.blueprint.row_titles_start[1] + 1 + index
245
+ col_widths[column] ||= 0
246
+ col_widths[column] = title_data.text.length if title_data.text.length > col_widths[column]
247
+ end
248
+ end
249
+ end
250
+
251
+ widths = (0..self.blueprint.max[:col].to_i).map{|col| col_widths[col] ? col_widths[col]+4 : 0}
252
+ self.column_widths *widths
253
+ end
254
+
255
+ def set_row_heights
256
+ row_heights = {}
257
+
258
+ self.blueprint.elements.each do |elem|
259
+ row_heights[elem.row] ||= 0
260
+ height = elem.text.split("\n").count * 10 + (elem.font.size / 3)
261
+ row_heights[elem.row] = height if height > row_heights[elem.row]
262
+ end
263
+
264
+ unless self.blueprint.column_titles.empty?
265
+ max_column_title_height = self.blueprint.column_titles.map{|elem| elem.text.split("\n").size}.max * 10 + 10
266
+ row_heights[self.blueprint.column_titles_start[0]] ||= 0
267
+ row_heights[self.blueprint.column_titles_start[0]] = max_column_title_height if max_column_title_height > row_heights[self.blueprint.column_titles_start[0]]
268
+ end
269
+
270
+
271
+ (0..self.blueprint.max[:row].to_i).each {|row| self.rows[row-1].height = row_heights[row] || 20}
272
+ end
273
+
274
+ def place_elements
275
+ self.blueprint.elements.each do |elem|
276
+ self.name_to_cell("#{column(elem.col)}#{elem.row}").value = elem.text
277
+ style = self.styles.add_style elem.combined_style
278
+ self.name_to_cell("#{column(elem.col)}#{elem.row}").style = style
279
+ self.add_comment ref: "#{column(elem.col)}#{elem.row}", text: "#{elem.comment}", author: elem.text, visible: false if elem.comment
280
+ self.merge_cells "#{column(elem.col)}#{elem.row}:#{column(elem.col+elem.merge)}#{elem.row}" if elem.merge
281
+ end
282
+ end
283
+
284
+ def set_max_row_and_column
285
+ self.blueprint.max = {col: 0, row: 0}
286
+ self.blueprint.max[:row] = self.blueprint.elements.max_by{|elem| elem.row}.row unless self.blueprint.elements.empty?
287
+ self.blueprint.max[:col] = self.blueprint.elements.max_by{|elem| elem.col}.col unless self.blueprint.elements.empty?
288
+ self.blueprint.max[:col] = self.blueprint.column_titles.count if self.blueprint.column_titles and self.blueprint.column_titles.count > self.blueprint.max[:col]
289
+ self.blueprint.max[:row] = self.blueprint.row_titles.count if self.blueprint.row_titles and self.blueprint.row_titles.count > self.blueprint.max[:row]
290
+ self.blueprint.max[:row] += self.blueprint.column_titles_start[0] if self.blueprint.column_titles_start
291
+ self.blueprint.max[:col] += self.blueprint.column_titles_start[1] if self.blueprint.column_titles_start
292
+ self.blueprint.max[:row] += self.blueprint.row_titles_start[0] if self.blueprint.row_titles_start
293
+ self.blueprint.max[:col] += self.blueprint.row_titles_start[1] if self.blueprint.row_titles_start
294
+ self.blueprint.max[:row] += self.blueprint.column_data.size if self.blueprint.column_data
295
+ self.blueprint.max[:col] += self.blueprint.row_data.size if self.blueprint.row_data
296
+ self.blueprint.max[:col] += self.blueprint.column_titles.select{|elem| elem.list}.size + self.blueprint.row_titles.select{|elem| elem.list}.size
297
+ (0..self.blueprint.max[:row]+1).each {self.add_row(Array.new(self.blueprint.max[:col].to_i, nil))}
298
+ end
299
+
300
+ def place_column_titles
301
+ self.blueprint.column_titles.each_with_index do |elem, index|
302
+ cell = self.name_to_cell("#{column(index+self.blueprint.column_titles_start[1]-1)}#{self.blueprint.column_titles_start[0]}")
303
+ cell.value = elem.text
304
+ style = self.styles.add_style elem.combined_style
305
+ cell.style = style
306
+ self.add_hyperlink location: elem.hyperlink, ref: cell if elem.hyperlink
307
+ self.add_comment ref: "#{column(index+self.blueprint.column_titles_start[1]-1)}#{self.blueprint.column_titles_start[0]}", text: "#{elem.comment}", author: elem.text, visible: false if elem.comment
308
+ end
309
+ end
310
+
311
+ def set_lists_for_column_titles
312
+ existing_titles_with_lists = self.blueprint.column_titles.select{|elem| elem.list}
313
+ return false if existing_titles_with_lists.empty?
314
+ if lists_sheet = current_lists_sheet
315
+ pre_existing_titles_with_lists = []
316
+ lists_sheet.column_title_indexes.each do |title, column|
317
+ row = 2
318
+ list = []
319
+ while cell = lists_sheet.name_to_cell("#{column column}#{row}") and cell.value
320
+ list << cell.value
321
+ row += 1
322
+ end
323
+ pre_existing_titles_with_lists << Axlsx::Builder::Title.new(text: title, list: list)
324
+ end
325
+ titles_with_lists = pre_existing_titles_with_lists + existing_titles_with_lists
326
+ lists_sheet_index = self.workbook.worksheets.index {|sheet| sheet.name == 'Lists'}
327
+ self.workbook.worksheets.delete_at lists_sheet_index
328
+ else
329
+ titles_with_lists = existing_titles_with_lists
330
+ end
331
+ list_titles = []
332
+ list_data = []
333
+ titles_with_lists.each do |elem|
334
+ list_titles = titles_with_lists.map{|elem| {text: elem.text}}
335
+ elem.list.each {|list_item| list_data << {text: list_item, title: elem.text}}
336
+ end
337
+ list_titles.uniq!
338
+ list_data.uniq!
339
+ blueprint = Axlsx::Builder::Blueprint.new column_titles: list_titles
340
+ lists_sheet = self.workbook.add_worksheet name: 'Lists', blueprint: blueprint
341
+ lists_sheet.column_data= list_data
342
+ existing_titles_with_lists.each do |elem|
343
+ 100.times do |row|
344
+ list_column = current_lists_sheet.column_title_indexes[elem.text]
345
+ self.add_data_validation("#{column (self.column_title_indexes[elem.text])}#{self.blueprint.column_titles_start[0]+row+1}", {
346
+ type: :list,
347
+ formula1: "Lists!#{column list_column}2:#{column list_column}#{elem.list.size+1}",
348
+ showDropDown: false,
349
+ showErrorMessage: true,
350
+ errorTitle: '',
351
+ errorStyle: :stop,
352
+ showInputMessage: true})
353
+ end
354
+ end
355
+ end
356
+
357
+ def place_row_titles
358
+ self.blueprint.row_titles.each_with_index do |elem, index|
359
+ cell = self.name_to_cell("#{column(self.blueprint.row_titles_start[1]-1)}#{self.blueprint.row_titles_start[0]+index}")
360
+ cell.value = elem.text
361
+ style = self.styles.add_style elem.combined_style
362
+ cell.style = style
363
+ self.add_hyperlink location: elem.hyperlink, ref: cell if elem.hyperlink
364
+ self.add_comment ref: "#{column(self.blueprint.row_titles_start[1]-1)}#{self.blueprint.row_titles_start[0]+index}", text: "#{elem.comment}", author: elem.text, visible: false if elem.comment
365
+ end
366
+ end
367
+
368
+ def set_lists_for_row_titles
369
+ existing_titles_with_lists = self.blueprint.row_titles.select{|elem| elem.list}
370
+ return false if existing_titles_with_lists.empty?
371
+ if lists_sheet = current_lists_sheet
372
+ pre_existing_titles_with_lists = []
373
+ lists_sheet.column_title_indexes.each do |title, column|
374
+ row = 2
375
+ list = []
376
+ while cell = lists_sheet.name_to_cell("#{column column}#{row}") and cell.value
377
+ list << cell.value
378
+ row += 1
379
+ end
380
+ pre_existing_titles_with_lists << Builder::Title.new(text: title, list: list)
381
+ end
382
+ titles_with_lists = pre_existing_titles_with_lists + existing_titles_with_lists
383
+ lists_sheet_index = self.workbook.worksheets.index {|sheet| sheet.name == 'Lists'}
384
+ self.workbook.worksheets.delete_at lists_sheet_index
385
+ else
386
+ titles_with_lists = existing_titles_with_lists
387
+ end
388
+ list_titles = []
389
+ list_data = []
390
+ titles_with_lists.each do |elem|
391
+ list_titles = titles_with_lists.map{|elem| {text: elem.text}}
392
+ elem.list.each {|list_item| list_data << {text: list_item, title: elem.text}}
393
+ end
394
+ list_titles.uniq!
395
+ list_data.uniq!
396
+ blueprint = Axlsx::Builder::Blueprint.new column_titles: list_titles
397
+ lists_sheet = self.workbook.add_worksheet name: 'Lists', blueprint: blueprint
398
+ lists_sheet.data column: list_data
399
+ existing_titles_with_lists.each do |elem|
400
+ 100.times do |column|
401
+ list_column = current_lists_sheet.column_title_indexes[elem.text]
402
+ self.add_data_validation("#{column self.blueprint.row_titles_start[1]+column}#{self.row_title_indexes[elem.text]+1}", {
403
+ type: :list,
404
+ formula1: "Lists!#{column list_column}2:#{column list_column}#{elem.list.size+1}",
405
+ showDropDown: false,
406
+ showErrorMessage: true,
407
+ errorTitle: '',
408
+ errorStyle: :stop,
409
+ showInputMessage: true})
410
+ end
411
+ end
412
+ end
413
+
414
+
415
+ def set_column_title_row_height
416
+ return false if self.blueprint.column_titles.empty?
417
+ if self.blueprint.column_title_row_height
418
+ self.rows[self.blueprint.column_titles_start[0]-1].height = column_title_row_height
419
+ else
420
+ most_lines = self.blueprint.column_titles.max_by{|elem| elem.text.split("\n").size}.text.split("\n").size
421
+ self.rows[self.blueprint.column_titles_start[0]-1].height = most_lines * 10 + 10
422
+ end
423
+ end
424
+
425
+ def place_column_data
426
+ self.blueprint.column_data.each do |elem|
427
+ index = self.column_title_indexes[elem.title]
428
+ next unless index
429
+ title_column = column index
430
+ if elem.row
431
+ self.blueprint.name_to_cell("#{title_column}#{elem.row + self.blueprint.column_titles_start[0] + 1}").value = elem.text
432
+ else
433
+ row = self.blueprint.column_titles_start[0] + 1
434
+ while self.name_to_cell("#{title_column}#{row}").value
435
+ row += 1
436
+ end
437
+ self.name_to_cell("#{title_column}#{row}").value = elem.text
438
+ end
439
+ end
440
+ end
441
+
442
+ def place_row_data
443
+ self.blueprint.row_data.each do |elem|
444
+ title_row = self.row_title_indexes[elem.title]
445
+ column = self.blueprint.row_titles_start[1]
446
+ while self.name_to_cell("#{column column}#{title_row+1}").value
447
+ column += 1
448
+ end
449
+ self.name_to_cell("#{column column}#{title_row+1}").value = elem.text
450
+ end
451
+ end
452
+
453
+ def move_lists_sheet_to_end
454
+ return false if self.name == 'Lists'
455
+ sheets = self.workbook.worksheets
456
+ lists_sheet_index = sheets.index { |sheet| sheet.name == 'Lists' }
457
+ if lists_sheet_index
458
+ lists_sheet = sheets[lists_sheet_index]
459
+ sheets.delete_at lists_sheet_index
460
+ sheets << lists_sheet
461
+ sheets.each_with_index {|sheet, index| sheet.workbook.worksheets[index] = sheet}
462
+ end
463
+ end
464
+
465
+ def column index
466
+ column = (index % 26 + 65).chr
467
+ column << (index / 26 + 64).chr if index > 25
468
+ column.reverse
469
+ end
470
+
471
+ def current_lists_sheet
472
+ self.workbook.sheet_by_name 'Lists'
473
+ end
474
+
475
+
476
+
477
+ def data column: nil, row: nil
478
+ self.column_data = column
479
+ self.row_data = row
480
+ self.build!
481
+ end
482
+
483
+ end
484
+
485
+ class Workbook
486
+ def add_worksheet(options={})
487
+ worksheet = Worksheet.new(self, options)
488
+ yield worksheet if block_given?
489
+ worksheet.build! if worksheet.blueprint
490
+ end
491
+ end
492
+
493
+ end
494
+
495
+
496
+
@@ -0,0 +1,5 @@
1
+ module Axlsx
2
+ module Builder
3
+ VERSION = '0.0.1'
4
+ end
5
+ end
metadata ADDED
@@ -0,0 +1,120 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: axlsx-builder
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - MainShayne233
8
+ autorequire:
9
+ bindir: exe
10
+ cert_chain: []
11
+ date: 2016-07-01 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: bundler
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '1.12'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '1.12'
27
+ - !ruby/object:Gem::Dependency
28
+ name: rake
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '10.0'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '10.0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: rspec
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: '3.0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: '3.0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: axlsx
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - "~>"
60
+ - !ruby/object:Gem::Version
61
+ version: 2.0.1.pre
62
+ type: :runtime
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - "~>"
67
+ - !ruby/object:Gem::Version
68
+ version: 2.0.1.pre
69
+ description:
70
+ email:
71
+ - shaynetremblay@hotmail.com
72
+ executables: []
73
+ extensions: []
74
+ extra_rdoc_files: []
75
+ files:
76
+ - ".gitignore"
77
+ - ".idea/.rakeTasks"
78
+ - ".idea/axlsx-builder.iml"
79
+ - ".idea/misc.xml"
80
+ - ".idea/modules.xml"
81
+ - ".idea/vcs.xml"
82
+ - ".idea/workspace.xml"
83
+ - ".rspec"
84
+ - ".travis.yml"
85
+ - CODE_OF_CONDUCT.md
86
+ - Gemfile
87
+ - LICENSE.txt
88
+ - README.md
89
+ - Rakefile
90
+ - axlsx-builder.gemspec
91
+ - bin/console
92
+ - bin/setup
93
+ - lib/axlsx/builder.rb
94
+ - lib/axlsx/builder/version.rb
95
+ homepage: https://github.com/MainShayne233/axlsx-builder
96
+ licenses:
97
+ - MIT
98
+ metadata: {}
99
+ post_install_message:
100
+ rdoc_options: []
101
+ require_paths:
102
+ - lib
103
+ required_ruby_version: !ruby/object:Gem::Requirement
104
+ requirements:
105
+ - - ">="
106
+ - !ruby/object:Gem::Version
107
+ version: '0'
108
+ required_rubygems_version: !ruby/object:Gem::Requirement
109
+ requirements:
110
+ - - ">="
111
+ - !ruby/object:Gem::Version
112
+ version: '0'
113
+ requirements: []
114
+ rubyforge_project:
115
+ rubygems_version: 2.5.1
116
+ signing_key:
117
+ specification_version: 4
118
+ summary: An extension of Axlsx that allows you create spreadsheets blueprints for
119
+ easy sheet generation, manipulation, and data input.
120
+ test_files: []