axlsx_rails 0.4.0 → 0.5.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +6 -0
- data/Gemfile +9 -6
- data/Gemfile.lock +116 -115
- data/Gemfile.lock.4.0 +66 -67
- data/Gemfile.lock.4.1 +90 -91
- data/Gemfile.lock.4.2 +115 -114
- data/Gemfile.lock.5.0 +259 -0
- data/README.md +37 -4
- data/axlsx_rails.gemspec +36 -0
- data/lib/axlsx_rails/action_controller.rb +5 -1
- data/lib/axlsx_rails/template_handler.rb +1 -1
- data/lib/axlsx_rails/version.rb +1 -1
- data/spec/axlsx_builder_spec.rb +2 -2
- data/spec/axlsx_mailer_spec.rb +3 -3
- data/spec/axlsx_renderer_spec.rb +4 -3
- data/spec/axlsx_request_spec.rb +43 -30
- data/spec/ci.rb +4 -1
- data/spec/dummy/app/mailers/notifier.rb +1 -1
- data/spec/dummy/app/views/users/{mailers/instructions.xlsx.axlsx → send_instructions.xlsx.axlsx} +0 -0
- data/spec/dummy/log/test.log +0 -0
- data/spec/dummy_4/app/mailers/notifier.rb +1 -1
- data/spec/dummy_4/app/views/users/noaction.xlsx.axlsx +1 -0
- data/spec/dummy_4/app/views/users/{mailers/instructions.xlsx.axlsx → send_instructions.xlsx.axlsx} +0 -0
- data/spec/dummy_4/config/routes.rb +1 -0
- data/spec/dummy_4/db/schema.rb +2 -2
- data/spec/dummy_4/db/test.sqlite3 +0 -0
- data/spec/dummy_4/log/test.log +14792 -0
- data/spec/dummy_5/Rakefile +6 -0
- data/spec/dummy_5/app/assets/javascripts/application.js +13 -0
- data/spec/dummy_5/app/assets/stylesheets/application.css +15 -0
- data/spec/dummy_5/app/controllers/application_controller.rb +5 -0
- data/spec/dummy_5/app/controllers/home_controller.rb +56 -0
- data/spec/dummy_5/app/controllers/likes_controller.rb +18 -0
- data/spec/dummy_5/app/controllers/users_controller.rb +27 -0
- data/spec/dummy_5/app/helpers/application_helper.rb +2 -0
- data/spec/dummy_5/app/mailers/notifier.rb +14 -0
- data/spec/dummy_5/app/models/like.rb +3 -0
- data/spec/dummy_5/app/models/user.rb +10 -0
- data/spec/dummy_5/app/views/home/_cover_sheet.xlsx.axlsx +3 -0
- data/spec/dummy_5/app/views/home/index.html.erb +4 -0
- data/spec/dummy_5/app/views/home/index.xlsx.axlsx +8 -0
- data/spec/dummy_5/app/views/home/only_html.html.erb +1 -0
- data/spec/dummy_5/app/views/home/useheader.xlsx.axlsx +8 -0
- data/spec/dummy_5/app/views/home/withpartial.xlsx.axlsx +9 -0
- data/spec/dummy_5/app/views/layouts/application.html.erb +12 -0
- data/spec/dummy_5/app/views/likes/index.html.erb +17 -0
- data/spec/dummy_5/app/views/likes/index.xlsx.axlsx +7 -0
- data/spec/dummy_5/app/views/notifier/instructions.html.erb +14 -0
- data/spec/dummy_5/app/views/notifier/instructions.txt.erb +6 -0
- data/spec/dummy_5/app/views/users/index.html.erb +23 -0
- data/spec/dummy_5/app/views/users/index.xlsx.axlsx +1 -0
- data/spec/dummy_5/app/views/users/noaction.xlsx.axlsx +1 -0
- data/spec/dummy_5/app/views/users/respond_with.xlsx.axlsx +8 -0
- data/spec/dummy_5/app/views/users/send_instructions.xlsx.axlsx +5 -0
- data/spec/dummy_5/bin/bundle +3 -0
- data/spec/dummy_5/bin/rails +4 -0
- data/spec/dummy_5/bin/rake +4 -0
- data/spec/dummy_5/config.ru +4 -0
- data/spec/dummy_5/config/application.rb +23 -0
- data/spec/dummy_5/config/boot.rb +5 -0
- data/spec/dummy_5/config/database.yml +25 -0
- data/spec/dummy_5/config/environment.rb +5 -0
- data/spec/dummy_5/config/environments/development.rb +37 -0
- data/spec/dummy_5/config/environments/production.rb +83 -0
- data/spec/dummy_5/config/environments/test.rb +40 -0
- data/spec/dummy_5/config/initializers/backtrace_silencers.rb +7 -0
- data/spec/dummy_5/config/initializers/cookies_serializer.rb +3 -0
- data/spec/dummy_5/config/initializers/filter_parameter_logging.rb +4 -0
- data/spec/dummy_5/config/initializers/inflections.rb +16 -0
- data/spec/dummy_5/config/initializers/mime_types.rb +4 -0
- data/spec/dummy_5/config/initializers/secret_token.rb +2 -0
- data/spec/dummy_5/config/initializers/session_store.rb +3 -0
- data/spec/dummy_5/config/initializers/wrap_parameters.rb +14 -0
- data/spec/dummy_5/config/locales/en.yml +23 -0
- data/spec/dummy_5/config/routes.rb +16 -0
- data/spec/dummy_5/config/secrets.yml +22 -0
- data/spec/dummy_5/db/migrate/20120717192452_create_users.rb +12 -0
- data/spec/dummy_5/db/migrate/20121206210955_create_likes.rb +10 -0
- data/spec/dummy_5/db/schema.rb +31 -0
- data/spec/dummy_5/db/test.sqlite3 +0 -0
- data/spec/dummy_5/log/test.log +5738 -0
- data/spec/dummy_5/public/404.html +67 -0
- data/spec/dummy_5/public/422.html +67 -0
- data/spec/dummy_5/public/500.html +66 -0
- data/spec/dummy_5/public/favicon.ico +0 -0
- data/spec/spec_helper.rb +8 -2
- data/spec/test_5.0.sh +16 -0
- metadata +132 -12
- data/spec/dummy/README.rdoc +0 -261
- data/spec/dummy_4/README.rdoc +0 -28
@@ -0,0 +1,13 @@
|
|
1
|
+
// This is a manifest file that'll be compiled into application.js, which will include all the files
|
2
|
+
// listed below.
|
3
|
+
//
|
4
|
+
// Any JavaScript/Coffee file within this directory, lib/assets/javascripts, vendor/assets/javascripts,
|
5
|
+
// or vendor/assets/javascripts of plugins, if any, can be referenced here using a relative path.
|
6
|
+
//
|
7
|
+
// It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
|
8
|
+
// compiled file.
|
9
|
+
//
|
10
|
+
// Read Sprockets README (https://github.com/sstephenson/sprockets#sprockets-directives) for details
|
11
|
+
// about supported directives.
|
12
|
+
//
|
13
|
+
//= require_tree .
|
@@ -0,0 +1,15 @@
|
|
1
|
+
/*
|
2
|
+
* This is a manifest file that'll be compiled into application.css, which will include all the files
|
3
|
+
* listed below.
|
4
|
+
*
|
5
|
+
* Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets,
|
6
|
+
* or vendor/assets/stylesheets of plugins, if any, can be referenced here using a relative path.
|
7
|
+
*
|
8
|
+
* You're free to add application-wide styles to this file and they'll appear at the bottom of the
|
9
|
+
* compiled file so the styles you add here take precedence over styles defined in any styles
|
10
|
+
* defined in the other CSS/SCSS files in this directory. It is generally better to create a new
|
11
|
+
* file per style scope.
|
12
|
+
*
|
13
|
+
*= require_tree .
|
14
|
+
*= require_self
|
15
|
+
*/
|
@@ -0,0 +1,56 @@
|
|
1
|
+
#---
|
2
|
+
# Excerpted from "Crafting Rails Applications",
|
3
|
+
# published by The Pragmatic Bookshelf.
|
4
|
+
# Copyrights apply to this code. It may not be used to create training material,
|
5
|
+
# courses, books, articles, and the like. Contact us if you are in doubt.
|
6
|
+
# We make no guarantees that this code is fit for any purpose.
|
7
|
+
# Visit http://www.pragmaticprogrammer.com/titles/jvrails for more book information.
|
8
|
+
#---
|
9
|
+
class HomeController < ApplicationController
|
10
|
+
def index
|
11
|
+
respond_to do |format|
|
12
|
+
format.html
|
13
|
+
format.xlsx
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
def only_html; end
|
18
|
+
|
19
|
+
def another
|
20
|
+
render :xlsx => "index", :filename => "filename_test.xlsx"
|
21
|
+
end
|
22
|
+
|
23
|
+
def render_elsewhere
|
24
|
+
case params[:type]
|
25
|
+
when '1'
|
26
|
+
render :xlsx => "home/index", :template => 'users/index'
|
27
|
+
when '2'
|
28
|
+
render :xlsx => "users/index", :template => 'users/index'
|
29
|
+
when '3'
|
30
|
+
render template: "users/index"
|
31
|
+
when '4'
|
32
|
+
render "users/index"
|
33
|
+
else
|
34
|
+
render :xlsx => "index"
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
38
|
+
def render_file_path
|
39
|
+
render :xlsx => Rails.root.join('app','views','users','index')
|
40
|
+
end
|
41
|
+
|
42
|
+
def withpartial
|
43
|
+
end
|
44
|
+
|
45
|
+
def useheader
|
46
|
+
respond_to do |format|
|
47
|
+
format.xlsx {
|
48
|
+
if params[:set_direct]
|
49
|
+
response.headers['Content-Disposition'] = "attachment; filename=\"filename_test.xlsx\""
|
50
|
+
else
|
51
|
+
render xlsx: "useheader", filename: "filename_test.xlsx"
|
52
|
+
end
|
53
|
+
}
|
54
|
+
end
|
55
|
+
end
|
56
|
+
end
|
@@ -0,0 +1,18 @@
|
|
1
|
+
class LikesController < ApplicationController
|
2
|
+
# GET /likes
|
3
|
+
# GET /likes.json
|
4
|
+
def index
|
5
|
+
@user = User.find(params[:user_id])
|
6
|
+
@likes = @user.likes
|
7
|
+
|
8
|
+
respond_to do |format|
|
9
|
+
format.html # index.html.erb
|
10
|
+
format.xlsx
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
14
|
+
def render_elsewhere
|
15
|
+
@user = User.find(params[:user_id])
|
16
|
+
render :xlsx => "index", :template => 'users/index'
|
17
|
+
end
|
18
|
+
end
|
@@ -0,0 +1,27 @@
|
|
1
|
+
class UsersController < ApplicationController
|
2
|
+
respond_to :xlsx, :html
|
3
|
+
|
4
|
+
# GET /users
|
5
|
+
# GET /users.json
|
6
|
+
def index
|
7
|
+
@users = User.all
|
8
|
+
|
9
|
+
respond_to do |format|
|
10
|
+
format.html # index.html.erb
|
11
|
+
format.xlsx
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
def show
|
16
|
+
@user = User.find(params[:id])
|
17
|
+
respond_with(@user) do |format|
|
18
|
+
format.xlsx { render "respond_with.xlsx.axlsx" }
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
def send_instructions
|
23
|
+
@user = User.find(params[:user_id])
|
24
|
+
@user.send_instructions
|
25
|
+
render plain: "Email sent"
|
26
|
+
end
|
27
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
class Notifier < ActionMailer::Base
|
2
|
+
default :from => 'noreply@company.com'
|
3
|
+
|
4
|
+
def instructions(user)
|
5
|
+
@user = user
|
6
|
+
|
7
|
+
# normal syntax
|
8
|
+
xlsx = render_to_string handlers: [:axlsx], template: 'users/send_instructions', layout: false, formats: [:xlsx]
|
9
|
+
attachments["user_#{user.id}.xlsx"] = {mime_type: Mime[:xlsx], content: xlsx}
|
10
|
+
|
11
|
+
mail :to => user.email, :subject => 'Instructions'
|
12
|
+
end
|
13
|
+
|
14
|
+
end
|
@@ -0,0 +1,8 @@
|
|
1
|
+
wb = xlsx_package.workbook
|
2
|
+
style_shout = wb.styles.add_style sz: 16, b: true, alignment: { horizontal: :center }
|
3
|
+
wb.add_worksheet(name: "Foobar") do |sheet|
|
4
|
+
sheet.add_row ['Bad', 'spellers', 'of', 'the', 'world', '...']
|
5
|
+
sheet.add_row ['Untie!']
|
6
|
+
sheet.merge_cells("A2:E2")
|
7
|
+
sheet["A2"].style = style_shout
|
8
|
+
end
|
@@ -0,0 +1 @@
|
|
1
|
+
<p>Foo, bar</p>
|
@@ -0,0 +1,8 @@
|
|
1
|
+
wb = xlsx_package.workbook
|
2
|
+
style_shout = wb.styles.add_style sz: 16, b: true, alignment: { horizontal: :center }
|
3
|
+
wb.add_worksheet(name: "Foobar") do |sheet|
|
4
|
+
sheet.add_row ['Bad', 'spellers', 'of', 'the', 'world', '...']
|
5
|
+
sheet.add_row ['Untie!']
|
6
|
+
sheet.merge_cells("A2:E2")
|
7
|
+
sheet["A2"].style = style_shout
|
8
|
+
end
|
@@ -0,0 +1,9 @@
|
|
1
|
+
wb = xlsx_package.workbook
|
2
|
+
render :partial => 'cover_sheet', :locals => {:wb => wb}
|
3
|
+
style_shout = wb.styles.add_style sz: 16, b: true, alignment: { horizontal: :center }
|
4
|
+
wb.add_worksheet(name: "Foobar") do |sheet|
|
5
|
+
sheet.add_row ['Bad', 'spellers', 'of', 'the', 'world', '...']
|
6
|
+
sheet.add_row ['Untie!']
|
7
|
+
sheet.merge_cells("A2:E2")
|
8
|
+
sheet["A2"].style = style_shout
|
9
|
+
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
<h1>Listing likes for <%= @user.name %></h1>
|
2
|
+
|
3
|
+
<table>
|
4
|
+
<tr>
|
5
|
+
<th>Name</th>
|
6
|
+
</tr>
|
7
|
+
|
8
|
+
<% @likes.each do |like| %>
|
9
|
+
<tr>
|
10
|
+
<td><%= like.name %></td>
|
11
|
+
</tr>
|
12
|
+
<% end %>
|
13
|
+
</table>
|
14
|
+
|
15
|
+
<br />
|
16
|
+
|
17
|
+
<%= link_to 'New Like', new_like_path %>
|
@@ -0,0 +1,14 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html>
|
3
|
+
<head>
|
4
|
+
<meta content='text/html; charset=UTF-8' http-equiv='Content-Type' />
|
5
|
+
</head>
|
6
|
+
<body>
|
7
|
+
<h1>Instructions</h1>
|
8
|
+
<p>
|
9
|
+
You have successfully signed up to example.com,
|
10
|
+
your username is: <%= @user.email %>.<br/>
|
11
|
+
</p>
|
12
|
+
<p>Thanks for joining and have a great day!</p>
|
13
|
+
</body>
|
14
|
+
</html>
|
@@ -0,0 +1,23 @@
|
|
1
|
+
<h1>Listing users</h1>
|
2
|
+
|
3
|
+
<table>
|
4
|
+
<tr>
|
5
|
+
<th>Name</th>
|
6
|
+
<th>Last name</th>
|
7
|
+
<th>Address</th>
|
8
|
+
<th>Email</th>
|
9
|
+
</tr>
|
10
|
+
|
11
|
+
<% @users.each do |user| %>
|
12
|
+
<tr>
|
13
|
+
<td><%= user.name %></td>
|
14
|
+
<td><%= user.last_name %></td>
|
15
|
+
<td><%= user.address %></td>
|
16
|
+
<td><%= user.email %></td>
|
17
|
+
</tr>
|
18
|
+
<% end %>
|
19
|
+
</table>
|
20
|
+
|
21
|
+
<br />
|
22
|
+
|
23
|
+
<%= link_to 'New User', new_user_path %>
|
@@ -0,0 +1 @@
|
|
1
|
+
User.to_xlsx package: xlsx_package
|
@@ -0,0 +1 @@
|
|
1
|
+
User.to_xlsx package: xlsx_package
|
@@ -0,0 +1,8 @@
|
|
1
|
+
wb = xlsx_package.workbook
|
2
|
+
style_shout = wb.styles.add_style sz: 16, b: true, alignment: { horizontal: :center }
|
3
|
+
wb.add_worksheet(name: "Foobar") do |sheet|
|
4
|
+
sheet.add_row ['Bad', 'spellers', 'of', 'the', 'world', '...']
|
5
|
+
sheet.add_row ['Untie!']
|
6
|
+
sheet.merge_cells("A2:E2")
|
7
|
+
sheet["A2"].style = style_shout
|
8
|
+
end
|
@@ -0,0 +1,23 @@
|
|
1
|
+
require File.expand_path('../boot', __FILE__)
|
2
|
+
|
3
|
+
require 'rails/all'
|
4
|
+
|
5
|
+
Bundler.require(*Rails.groups)
|
6
|
+
require "axlsx_rails"
|
7
|
+
|
8
|
+
module Dummy
|
9
|
+
class Application < Rails::Application
|
10
|
+
# Settings in config/environments/* take precedence over those specified here.
|
11
|
+
# Application configuration should go into files in config/initializers
|
12
|
+
# -- all .rb files in that directory are automatically loaded.
|
13
|
+
|
14
|
+
# Set Time.zone default to the specified zone and make Active Record auto-convert to this zone.
|
15
|
+
# Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC.
|
16
|
+
# config.time_zone = 'Central Time (US & Canada)'
|
17
|
+
|
18
|
+
# The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded.
|
19
|
+
# config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s]
|
20
|
+
# config.i18n.default_locale = :de
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
@@ -0,0 +1,25 @@
|
|
1
|
+
# SQLite version 3.x
|
2
|
+
# gem install sqlite3
|
3
|
+
#
|
4
|
+
# Ensure the SQLite 3 gem is defined in your Gemfile
|
5
|
+
# gem 'sqlite3'
|
6
|
+
#
|
7
|
+
default: &default
|
8
|
+
adapter: sqlite3
|
9
|
+
pool: 5
|
10
|
+
timeout: 5000
|
11
|
+
|
12
|
+
development:
|
13
|
+
<<: *default
|
14
|
+
database: db/development.sqlite3
|
15
|
+
|
16
|
+
# Warning: The database defined as "test" will be erased and
|
17
|
+
# re-generated from your development database when you run "rake".
|
18
|
+
# Do not set this db to the same as development or production.
|
19
|
+
test:
|
20
|
+
<<: *default
|
21
|
+
database: db/test.sqlite3
|
22
|
+
|
23
|
+
production:
|
24
|
+
<<: *default
|
25
|
+
database: db/production.sqlite3
|
@@ -0,0 +1,37 @@
|
|
1
|
+
Rails.application.configure do
|
2
|
+
# Settings specified here will take precedence over those in config/application.rb.
|
3
|
+
|
4
|
+
# In the development environment your application's code is reloaded on
|
5
|
+
# every request. This slows down response time but is perfect for development
|
6
|
+
# since you don't have to restart the web server when you make code changes.
|
7
|
+
config.cache_classes = false
|
8
|
+
|
9
|
+
# Do not eager load code on boot.
|
10
|
+
config.eager_load = false
|
11
|
+
|
12
|
+
# Show full error reports and disable caching.
|
13
|
+
config.consider_all_requests_local = true
|
14
|
+
config.action_controller.perform_caching = false
|
15
|
+
|
16
|
+
# Don't care if the mailer can't send.
|
17
|
+
config.action_mailer.raise_delivery_errors = false
|
18
|
+
|
19
|
+
# Print deprecation notices to the Rails logger.
|
20
|
+
config.active_support.deprecation = :log
|
21
|
+
|
22
|
+
# Raise an error on page load if there are pending migrations.
|
23
|
+
config.active_record.migration_error = :page_load
|
24
|
+
|
25
|
+
# Debug mode disables concatenation and preprocessing of assets.
|
26
|
+
# This option may cause significant delays in view rendering with a large
|
27
|
+
# number of complex assets.
|
28
|
+
config.assets.debug = true
|
29
|
+
|
30
|
+
# Adds additional error checking when serving assets at runtime.
|
31
|
+
# Checks for improperly declared sprockets dependencies.
|
32
|
+
# Raises helpful error messages.
|
33
|
+
config.assets.raise_runtime_errors = true
|
34
|
+
|
35
|
+
# Raises error for missing translations
|
36
|
+
# config.action_view.raise_on_missing_translations = true
|
37
|
+
end
|