Herd Ember provides an Ember Data model & adapter infrastructure, to an Ember Application, for easy integration with the Herd Gem.
It also provides an uploader component that can be used to post Assets to your Herd backend.
TODO:
- Drag and drop rearranging for Asset Position (in Uploader)
You'll need Ember Concurrency first!
ember install ember-concurrency
ember install herd-ember
Now, in an assetable model, you can do:
// app/models/post.js
import DS from 'ember-data';
import Assetable from 'herd-ember/mixins/assetable';
export default DS.Model.extend(Assetable, {
name: DS.attr('string')
});
Now, provided your server is setup to pass down assets (and missing assets) as sideloaded data to your Post model, you'll be able to access the Herd assets like so:
post.get('assets');
Currently, Herd Ember only supports Assets with assetClass === 'image'
. We plan to support more Asset Types soon!
{{post.name}}
{{herd-asset assetable=post}}
A big thankyou to Bustle Labs for their excellent ember-cli-image
library. When they cut a release to NPM, we'll
switch to using it directly.
These class names will be updated throughout the lifecycle of the Image asset:
herd-asset
image
loading
error
You can optionally pass the below options to the herd-asset
component:
alt:string
: Alt text for the Imagewidth:integer
: A pixel width for the Imageheight:integer
: A pixel height for the ImagebackgroundImage:boolean
: When true, will render the image as a background imageimageContainer:boolean
: When true, will render the image in a container
Note: When using backgroundImage
or imageContainer
, you can also pass a block to the helper, like so:
{{#herd-asset assetable=post backgroundImage=true}}
<h1>{{post.name}}</h1>
{{/herd-asset}}
You can place the uploader on a page like so:
{{herd-uploader assetable=post}}
Herd Ember is easily customizable for a variety of use cases.
// In app/config/environment.js
ENV['herd'] = {
host: null,
namespace: null,
adapter: 'JSONAPIAdapter'
}
ember test
ember test --server
ember build
For more information on using ember-cli, visit http://www.ember-cli.com/.