Below is a page for a product in an e-commerce application. We’d like to add an image of the product to this page and modify the admin system so that an image can be uploaded when a product is created or modified. In this episode we’ll show you how to use a plugin called Paperclip to do this.
Paperclip makes adding attachments to a model simple. We’re going to use it to add a field to ourProduct model so that each product can have an image.
Paperclip is installed in the same way as any other plugin. From our application’s directory we can install it from Github.
Product model.
The generator takes two arguments. The first is the name of the model, in our case ourProduct model, and the second is the name of the model’s new attachment field. The generator will create a migration that will add four new fields to the model.
The four new fields added by the Paperclip generator.
We’ll then need to runrake db:migrate to update the products table in the database.
The next step is to update the model code. We need to usehas_attached_file to tell it the name of the attachment field we specified when we ran the migration.
The form that creates or updates a product will need a file upload field adding to it.
As well as adding afile_field to the form we need to modify the form_for so that the form will accept file attachments. This is done by adding :multipart => true to the :html hash, which will add the attribute enctype="multipart/form-data" to the form’s opening tag.
Of course there’s no point uploading images if we don’t then show them, so we’ll need to make a change to theshow view. To add the image we just need to add an image_tag to the page. Our Product model will now have a photo object as a property with a url method that will give us the correct path to the image.
That done we can edit a product, add an image to it and see the results.
It’s worked! Our product now has an image, but it’s a bit too big. While we could make sure that we only upload pictures of the correct size, it would be easier if we could resize the images on the server and with Paperclip there’s a way to do just that.
Thehas_attached_file method that we added to our Product model takes a number of options. One of these is styles which allows us to define different sizes for our image. To create a thumbnail for each image we just need to define a style and specify the size.
With the new style added, Paperclip will now generate a thumbnail of each image that fits within 150x150 pixels. The greater than sign at the end tells Paperclip to keep the aspect ratio of the picture so that it isn’t distorted when its resized. Note that to enable resizing you’ll need to have ImageMagick installed on your server.
To display the resized image in the product’sshow view we’ll have to change the image_tag so that the url points to the smaller version.
If we pass the style to theurl method the appropriate image will be returned. The smaller image is only generated when an image is uploaded, so to resize our picture we’ll have to edit our product and upload the file again. Once we’ve done that our product’s photo will now appear at the thumbnail size we specified.
By default Paperclip will store attachments in asystem directory under our application’s public directory.
Paperclip creates its own hierarchy to store attachments, creating directories based on the theid of the product and style we set in the model. Most of the time the default directory is fine, but if we want to store the images elsewhere then we can change it.
To store the images elsewhere we just add two more options to the has_attached_file method, url and path.
The url and path shown above are the defaults that Paperclip uses. The url is specified relative to thepublic directory and there are placeholders in the string for the name of the attachment field, the model’s id and the style. There are similar placeholders in the string for the path. We want to store our images in an assets directory, so we’ll change the url and the path to suit.
Any images we upload now will be stored in the assets directory rather than in system/photos.
One final useful part of Paperclip is that it can validate the attachments that are uploaded. To validate the photos that are uploaded we could add validators like these to ourProduct model:
With the validators above we’re checking that an attachment has been uploaded, that it is no bigger than five megabytes in size and that it is either a JPEG or PNG image. Using these we can validate an attachment as easily as any other form field. One thing to take care with if you’re checking the content type is that Internet Explorer can report different MIME types from other browsers. For example it can treat JPEG files asimage/pjpeg rather than image/jpeg .
Note: This topic is taken from RailsCasts and shared here so that you can discuss any problems that you may face during implementing
Paperclip makes adding attachments to a model simple. We’re going to use it to add a field to our
Paperclip is installed in the same way as any other plugin. From our application’s directory we can install it from Github.
Updating The Model
Now that we have Paperclip installed we can run its generator to add an attachment field to the
The generator takes two arguments. The first is the name of the model, in our case our
The four new fields added by the Paperclip generator.
We’ll then need to run
The next step is to update the model code. We need to use
Modifying The Views
The form that creates or updates a product will need a file upload field adding to it.
As well as adding a
Of course there’s no point uploading images if we don’t then show them, so we’ll need to make a change to the
That done we can edit a product, add an image to it and see the results.
It’s worked! Our product now has an image, but it’s a bit too big. While we could make sure that we only upload pictures of the correct size, it would be easier if we could resize the images on the server and with Paperclip there’s a way to do just that.
Resizing Images
The
With the new style added, Paperclip will now generate a thumbnail of each image that fits within 150x150 pixels. The greater than sign at the end tells Paperclip to keep the aspect ratio of the picture so that it isn’t distorted when its resized. Note that to enable resizing you’ll need to have ImageMagick installed on your server.
To display the resized image in the product’s
If we pass the style to the
Setting Paperclip’s Path
By default Paperclip will store attachments in a
Paperclip creates its own hierarchy to store attachments, creating directories based on the the
To store the images elsewhere we just add two more options to the has_attached_file method, url and path.
The url and path shown above are the defaults that Paperclip uses. The url is specified relative to the
Any images we upload now will be stored in the assets directory rather than in system/photos.
Validating Attachments
One final useful part of Paperclip is that it can validate the attachments that are uploaded. To validate the photos that are uploaded we could add validators like these to our
With the validators above we’re checking that an attachment has been uploaded, that it is no bigger than five megabytes in size and that it is either a JPEG or PNG image. Using these we can validate an attachment as easily as any other form field. One thing to take care with if you’re checking the content type is that Internet Explorer can report different MIME types from other browsers. For example it can treat JPEG files as
No comments:
Post a Comment