Skip to content

Instantly share code, notes, and snippets.

@feanor07
Last active April 26, 2017 19:32
Show Gist options
  • Save feanor07/c2ee6043e056c4da6e8133a62f2346c3 to your computer and use it in GitHub Desktop.
Save feanor07/c2ee6043e056c4da6e8133a62f2346c3 to your computer and use it in GitHub Desktop.
so#43570060
import Ember from 'ember';
export default Ember.Controller.extend({
appName: 'Ember Twiddle'
});
function parseRequest(request) {
let sub = request.substring('/dummies?page='.length);
let page = parseInt(sub.substring(0, sub.indexOf('&')));
let sub2 = request.substring(request.indexOf('per_page='));
let pageSize= parseInt(sub2.substring('per_page='.length));
return {page: page, pageSize: pageSize};
}
export default {ITEM_SIZE: 100, parseRequest: parseRequest};
import Util from './common/util';
export default function() {
//window.server = this;
this.get('dummies', (schema, request)=> {
let json = Util.parseRequest(request.url);
let page = json.page;
let pageSize= json.pageSize;
let startIndex = (page - 1) * pageSize;
let endIndex = startIndex + pageSize;
return schema.dummies.all().slice(startIndex, endIndex);
});
/*this.get('localhost/dummies?page=1&per_page=12', (schema)=> {
return schema.dummies.all();
});*/
};
import { Factory } from 'ember-cli-mirage';
export default Factory.extend({
name(i) { return `Name ${i}`; },
});
import { Model } from 'ember-cli-mirage';
export default Model.extend({
});
import Util from '../common/util';
export default function(server) {
server.createList('dummy', Util.ITEM_SIZE);
}
import { JSONAPISerializer } from 'ember-cli-mirage';
import Util from '../common/util';
export default JSONAPISerializer.extend({
serialize(object, request) {
let pageSize = Util.parseRequest(request.url).pageSize;
let totalSize = Util.ITEM_SIZE;
let pageCount = totalSize / pageSize | 0 + 1;
let json = JSONAPISerializer.prototype.serialize.apply(this, arguments);
json['meta'] = {total_pages : pageCount};
return json;
}
});
import Model from "ember-data/model";
import DS from 'ember-data';
export default Model.extend({
name: DS.attr()
});
import Ember from 'ember';
import config from './config/environment';
const Router = Ember.Router.extend({
location: 'none',
rootURL: config.rootURL
});
Router.map(function() {
this.route('dummy-route');
});
export default Router;
import Ember from 'ember';
import InfinityRoute from "ember-infinity/mixins/route";
export default Ember.Route.extend(InfinityRoute, {
model() {
/* Load pages of the dummy Model, starting from page 1, in groups of 12. */
let inifinityModel = this.infinityModel("dummy", { perPage: 12, startingPage: 1});
return inifinityModel;
},
actions: {
makeInfinityRemoteCall() {
// now update the infinityModel to reflect the changes!!!
// page at 4 will just be appended to the existing model
this.infinityModel("dummy", { perPage: 12, startingPage:5}).then((myModel)=>this.set('controller.model',myModel));
}
}
});
<h1>Welcome to {{appName}}</h1>
<br>
<br>
{{outlet}}
<br>
{{#link-to 'dummy-route'}}dummy route{{/link-to}}
<br>
<br>
<br>
<button onclick={{route-action 'makeInfinityRemoteCall'}}>Make infinity remote call for page 4 via button click</button>
<br>
{{#each model as |item|}}
{{item.name}}<br>
{{/each}}
{{infinity-loader infinityModel=model}}
{
"version": "0.12.1",
"ENV": {
"ember-cli-mirage": {
"enabled": true
}
},
"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.12.0",
"ember-template-compiler": "2.12.0",
"ember-testing": "2.12.0"
},
"addons": {
"ember-data": "2.12.1",
"ember-infinity": "0.2.8",
"ember-cli-mirage": "0.3.1",
"ember-route-action-helper": "2.0.2"
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment