Twice Baked Photos
TB Photos is an engine for creating and managing photo galleries, designed for use with Twice Baked.
Installation/Usage
-
In your Gemfile add the following
gem 'tb_photos'
-
Run bundle install
-
Copy in database migrations to your new rails project
bundle exec rake railties:install:migrations
rake db:migrate
-
Run a rails server instance and point your browser to /admin
Configuration
TB Photos accepts the following configuration options:
Spud::Photos.configure do |config|
config.base_layout = 'application'
config.galleries_enabled = false
config.base_path = 'photos'
config.photo_styles = {
:small => '50x50#',
:medium => '200x200#',
:large => '400x400#',
:huge => '600x600'
}
config.max_image_upload_size = 2.megabytes
config.paperclip_storage = :filesystem #use :s3 to use s3 storage (aws gem required)
config.s3_credentials = "#{Rails.root}/config/s3.yml"
config.storage_path = ":rails_root/public/system/spud_photos/:id/:style/:basename.:extension"
config.storage_url = "/system/spud_photos/:id/:style/:basename.:extension"
end
The max_image_upload_size
should match with the apache/nginx max upload size for the public directory. Set the config to 0 for no size limit.
The photo_styles
option will be passed to Paperclip, so any valid paperclip styles can be added here.
Galleries
A Gallery is just an additional layer of organization above the Album layer. For example, a Gallery called "Vacations" might include Albums titled "Europe", "Hawaii", and "Florida". Galleries are turned off by default.
Customizing Views
A number of built-in views have been provided to help you get started with the frontend display. Customizing these views will require you to copy them into your local application, which can be accomplished by using the views generator.
rails generate spud:photos:views
NOTE: The built-in views are likely to undergo changes as features are added to the photos engine. If a new version of TB Photos does not play nicely with your customized views, try backing up your views to an alternate location and running the views generator again to see what has changed.
Testing
Twice Baked uses RSpec for testing. Get the tests running with a few short commands:
-
Create and migrate the databases:
rake db:create
rake db:migrate
-
Load the schema in to the test database:
rake app:db:test:prepare
-
Run the tests with RSpec
rspec spec
After the tests have completed the current code coverage stats is available by opening /coverage/index.html
in a browser.