sp-excel-loader 0.3.40

Sign up to get free protection for your applications and to get access to all the features.
Files changed (39) hide show
  1. checksums.yaml +7 -0
  2. data/Gemfile +4 -0
  3. data/LICENSE +661 -0
  4. data/README.md +8 -0
  5. data/lib/sp-excel-loader.rb +6 -0
  6. data/lib/sp/excel/loader.rb +61 -0
  7. data/lib/sp/excel/loader/jrxml/band.rb +80 -0
  8. data/lib/sp/excel/loader/jrxml/band_container.rb +229 -0
  9. data/lib/sp/excel/loader/jrxml/box.rb +75 -0
  10. data/lib/sp/excel/loader/jrxml/casper_checkbox.rb +97 -0
  11. data/lib/sp/excel/loader/jrxml/casper_combo.rb +86 -0
  12. data/lib/sp/excel/loader/jrxml/casper_date.rb +54 -0
  13. data/lib/sp/excel/loader/jrxml/casper_radio_button.rb +48 -0
  14. data/lib/sp/excel/loader/jrxml/casper_text_field.rb +157 -0
  15. data/lib/sp/excel/loader/jrxml/client_combo_text_field.rb +72 -0
  16. data/lib/sp/excel/loader/jrxml/excel_to_jrxml.rb +1183 -0
  17. data/lib/sp/excel/loader/jrxml/extensions.rb +330 -0
  18. data/lib/sp/excel/loader/jrxml/field.rb +65 -0
  19. data/lib/sp/excel/loader/jrxml/group.rb +71 -0
  20. data/lib/sp/excel/loader/jrxml/image.rb +63 -0
  21. data/lib/sp/excel/loader/jrxml/jasper.rb +228 -0
  22. data/lib/sp/excel/loader/jrxml/parameter.rb +73 -0
  23. data/lib/sp/excel/loader/jrxml/pen.rb +97 -0
  24. data/lib/sp/excel/loader/jrxml/property.rb +52 -0
  25. data/lib/sp/excel/loader/jrxml/property_expression.rb +52 -0
  26. data/lib/sp/excel/loader/jrxml/report_element.rb +92 -0
  27. data/lib/sp/excel/loader/jrxml/static_text.rb +59 -0
  28. data/lib/sp/excel/loader/jrxml/style.rb +99 -0
  29. data/lib/sp/excel/loader/jrxml/text_field.rb +83 -0
  30. data/lib/sp/excel/loader/jrxml/variable.rb +77 -0
  31. data/lib/sp/excel/loader/json_to_xlsx.rb +159 -0
  32. data/lib/sp/excel/loader/model_exporter.rb +249 -0
  33. data/lib/sp/excel/loader/payrollexporter.rb +168 -0
  34. data/lib/sp/excel/loader/rubyxl_table_patch.rb +91 -0
  35. data/lib/sp/excel/loader/version.rb +26 -0
  36. data/lib/sp/excel/loader/workbookloader.rb +480 -0
  37. data/spec/calc_spec.rb +87 -0
  38. data/spec/model.xls +0 -0
  39. metadata +151 -0
@@ -0,0 +1,87 @@
1
+
2
+ require 'sp-excel-loader'
3
+
4
+ RSpec.describe Sp::Excel::Loader do
5
+
6
+ we = nil
7
+
8
+ def clean_files
9
+ File.delete('./spec/json/mcalc_spec.rb') if File.file?('./spec/json/mcalc_spec.rb')
10
+ File.delete('./spec/json/model.json') if File.file?('./spec/json/model.json')
11
+ File.delete('./spec/json/tables/payroll_grant_types.json') if File.file?('./spec/json/tables/payroll_grant_types.json')
12
+ Dir.rmdir('./spec/json/tables') if File.exists?('./spec/json/tables')
13
+ Dir.rmdir('./spec/json') if File.exists?('./spec/json')
14
+ end
15
+
16
+ it 'create exporter instance' do
17
+ clean_files()
18
+ we = Sp::Excel::Loader::PayrollExporter.new('./spec/model.xls', false)
19
+ we.export './spec/json/'
20
+ expect(we).to be_an_instance_of(Sp::Excel::Loader::PayrollExporter)
21
+ end
22
+
23
+ context 'check model json files' do
24
+
25
+ model = nil;
26
+
27
+ it 'model.json was created' do
28
+ expect(File.file?('./spec/json/model.json')).to eq(true)
29
+ json = File.read('./spec/json/model.json')
30
+ model = JSON.parse(json)
31
+ end
32
+
33
+ it 'model has correct structure' do
34
+ expect(model['values']).to be_an_instance_of(Hash)
35
+ expect(model['formulas']).to be_an_instance_of(Hash)
36
+ expect(model['lines']['header']).to be_an_instance_of(Hash)
37
+ expect(model['lines']['formulas']).to be_an_instance_of(Array)
38
+ expect(model['lines']['values']).to be_an_instance_of(Array)
39
+ end
40
+
41
+ it 'model has expected information' do
42
+ expect(model['values']['I8']).to eq('COD_FUNC=12')
43
+ expect(model['formulas']['I21']).to eq('DIAS_ANO_CALENDARIO=(DT_FIM_ANO)-(DATE(ANO_PROC,1,1))+1')
44
+ expect(model['lines']['header']['I27']).to eq('UNIT_VALUE')
45
+ expect(model['lines']['header'].size).to eq(16)
46
+ expect(model['lines']['formulas'].size).to eq(6)
47
+ expect(model['lines']['values'].size).to eq(6)
48
+ expect(model['lines']['formulas'][0]['DESCRICAO']).to eq('D28=2+2')
49
+ expect(model['lines']['values'][5]['COD']).to eq('COD_SUBS_FERIAS_50="A006"')
50
+ end
51
+
52
+ end
53
+
54
+ context 'check table json files' do
55
+
56
+ table = nil;
57
+
58
+ it 'table json was created' do
59
+ expect(File.file?('./spec/json/tables/payroll_grant_types.json')).to eq(true)
60
+ json = File.read('./spec/json/tables/payroll_grant_types.json')
61
+ table = JSON.parse(json)
62
+ end
63
+
64
+ it 'table has correct structure' do
65
+ expect(table).to be_an_instance_of(Array)
66
+ expect(table[0]).to be_an_instance_of(Hash)
67
+ expect(table[0]['data']).to be_an_instance_of(Array)
68
+ expect(table.size).to eq(7)
69
+ expect(table[0]['data'].size).to eq(12)
70
+ expect(table[6]['data'].size).to eq(12)
71
+ end
72
+
73
+ it 'table has expected data' do
74
+ expect(table[0]['name']).to eq('id')
75
+ expect(table[0]['type']).to eq('text')
76
+ expect(table[0]['data'][0]).to eq('P_LIM_SREF_NUM')
77
+ expect(table[0]['data'][11]).to eq('LIM_AC_I_MGESP')
78
+ expect(table[6]['name']).to eq('exemption_limit_social_security')
79
+ expect(table[6]['type']).to eq('number')
80
+ expect(table[6]['data'][0]).to eq(4.27)
81
+ expect(table[6]['data'][11]).to eq(100.24)
82
+ clean_files()
83
+ end
84
+
85
+ end
86
+
87
+ end
Binary file
metadata ADDED
@@ -0,0 +1,151 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: sp-excel-loader
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.3.40
5
+ platform: ruby
6
+ authors:
7
+ - Vitor Pinho
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2012-10-17 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.6'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '1.6'
27
+ - !ruby/object:Gem::Dependency
28
+ name: rake
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '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: '0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - ">="
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: rubyXL
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - ">="
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ type: :runtime
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - ">="
67
+ - !ruby/object:Gem::Version
68
+ version: '0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: json
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ">="
74
+ - !ruby/object:Gem::Version
75
+ version: '0'
76
+ type: :runtime
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - ">="
81
+ - !ruby/object:Gem::Version
82
+ version: '0'
83
+ description: Extends RubyXL adding handling of excel tables and other conversion utilies
84
+ email:
85
+ - vitor.@servicepartner.pt
86
+ executables: []
87
+ extensions: []
88
+ extra_rdoc_files: []
89
+ files:
90
+ - Gemfile
91
+ - LICENSE
92
+ - README.md
93
+ - lib/sp-excel-loader.rb
94
+ - lib/sp/excel/loader.rb
95
+ - lib/sp/excel/loader/jrxml/band.rb
96
+ - lib/sp/excel/loader/jrxml/band_container.rb
97
+ - lib/sp/excel/loader/jrxml/box.rb
98
+ - lib/sp/excel/loader/jrxml/casper_checkbox.rb
99
+ - lib/sp/excel/loader/jrxml/casper_combo.rb
100
+ - lib/sp/excel/loader/jrxml/casper_date.rb
101
+ - lib/sp/excel/loader/jrxml/casper_radio_button.rb
102
+ - lib/sp/excel/loader/jrxml/casper_text_field.rb
103
+ - lib/sp/excel/loader/jrxml/client_combo_text_field.rb
104
+ - lib/sp/excel/loader/jrxml/excel_to_jrxml.rb
105
+ - lib/sp/excel/loader/jrxml/extensions.rb
106
+ - lib/sp/excel/loader/jrxml/field.rb
107
+ - lib/sp/excel/loader/jrxml/group.rb
108
+ - lib/sp/excel/loader/jrxml/image.rb
109
+ - lib/sp/excel/loader/jrxml/jasper.rb
110
+ - lib/sp/excel/loader/jrxml/parameter.rb
111
+ - lib/sp/excel/loader/jrxml/pen.rb
112
+ - lib/sp/excel/loader/jrxml/property.rb
113
+ - lib/sp/excel/loader/jrxml/property_expression.rb
114
+ - lib/sp/excel/loader/jrxml/report_element.rb
115
+ - lib/sp/excel/loader/jrxml/static_text.rb
116
+ - lib/sp/excel/loader/jrxml/style.rb
117
+ - lib/sp/excel/loader/jrxml/text_field.rb
118
+ - lib/sp/excel/loader/jrxml/variable.rb
119
+ - lib/sp/excel/loader/json_to_xlsx.rb
120
+ - lib/sp/excel/loader/model_exporter.rb
121
+ - lib/sp/excel/loader/payrollexporter.rb
122
+ - lib/sp/excel/loader/rubyxl_table_patch.rb
123
+ - lib/sp/excel/loader/version.rb
124
+ - lib/sp/excel/loader/workbookloader.rb
125
+ - spec/calc_spec.rb
126
+ - spec/model.xls
127
+ homepage: https://github.com/vpfpinho/sp-excel-loader.git
128
+ licenses:
129
+ - AGPL 3.0
130
+ metadata: {}
131
+ post_install_message:
132
+ rdoc_options: []
133
+ require_paths:
134
+ - lib
135
+ required_ruby_version: !ruby/object:Gem::Requirement
136
+ requirements:
137
+ - - ">="
138
+ - !ruby/object:Gem::Version
139
+ version: '0'
140
+ required_rubygems_version: !ruby/object:Gem::Requirement
141
+ requirements:
142
+ - - ">="
143
+ - !ruby/object:Gem::Version
144
+ version: '0'
145
+ requirements: []
146
+ rubyforge_project:
147
+ rubygems_version: 2.4.8
148
+ signing_key:
149
+ specification_version: 4
150
+ summary: Excelloader
151
+ test_files: []