Skip to content

Instantly share code, notes, and snippets.

@houfeng0923
Forked from k-fish/breakpoint.js
Created May 12, 2017 02:01
Show Gist options
  • Save houfeng0923/2aedf526b3cc31841f2ab5ba88ec69f5 to your computer and use it in GitHub Desktop.
Save houfeng0923/2aedf526b3cc31841f2ab5ba88ec69f5 to your computer and use it in GitHub Desktop.
Example Ember Responsive
export default {
mobile: '(max-width: 480px)',
tablet: '(min-width: 481px) and (max-width: 768px)',
desktop: '(min-width: 769px) and (max-width: 1366px)'
};
import Ember from 'ember';
export default Ember.Component.extend({
});
import Ember from 'ember';
var count = 1;
window.log = function(msg){
$('body').append('<div>'+msg+'</div>')
}
export default Ember.Component.extend({
didInsertElement(){
window.log('inserted:'+count++);
}
});
import Ember from 'ember';
export default Ember.Controller.extend({
appName: 'Ember Twiddle'
});
export function initialize() {
const application = arguments[1] || arguments[0];
application.inject('controller', 'media', 'service:media');
application.inject('component', 'media', 'service:media');
application.inject('route', 'media', 'service:media');
application.inject('view', 'media', 'service:media');
}
export default {
name: 'responsive',
initialize
};
{{responsive-component}}
<div style="border: 1px solid black; border-radius: 5px; padding: 5px; text-align: center">
<h4>This is a responsive component</h4>
<div class="js-responsive-text" style="padding: 5px; border-radius: 5px; {{if media.isMobile 'background: #d9534f' 'background: #5cb85c'}}">This text is styled responsively for <strong>{{if media.isMobile 'mobile' 'desktop/tablet'}}</strong></div>
</div>
{{#if media.isMobile}}
{{sub-component}}
{{/if}}
import Ember from 'ember';
export default function destroyApp(application) {
Ember.run(application, 'destroy');
}
import Resolver from '../../resolver';
import config from '../../config/environment';
const resolver = Resolver.create();
resolver.namespace = {
modulePrefix: config.modulePrefix,
podModulePrefix: config.podModulePrefix
};
export default resolver;
import Ember from 'ember';
import Application from '../../app';
import config from '../../config/environment';
const { run } = Ember;
const assign = Ember.assign || Ember.merge;
export default function startApp(attrs) {
let application;
let attributes = assign({rootElement: "#test-root"}, config.APP);
attributes = assign(attributes, attrs); // use defaults, but you can override;
run(() => {
application = Application.create(attributes);
application.setupForTesting();
application.injectTestHelpers();
});
return application;
}
import resolver from './helpers/resolver';
import {
setResolver
} from 'ember-qunit';
setResolver(resolver);
{
"version": "0.11.0",
"EmberENV": {
"FEATURES": {}
},
"options": {
"use_pods": false,
"enable-testing": false
},
"dependencies": {
"jquery": "https://cdnjs.cloudflare.com/ajax/libs/jquery/1.11.3/jquery.js",
"ember": "2.10.2",
"ember-data": "2.11.0",
"ember-template-compiler": "2.10.2",
"ember-testing": "2.10.2",
"skeleton-css": "https://cdnjs.cloudflare.com/ajax/libs/skeleton/2.0.4/skeleton.min.css"
},
"addons": {
"ember-responsive": "2.0.2"
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment