Skip to content

Instantly share code, notes, and snippets.

@locks
Forked from havremunken/controllers.application.js
Created October 27, 2018 10:18
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save locks/2a809541ad913cb9447c06c2e3cbdc86 to your computer and use it in GitHub Desktop.
Save locks/2a809541ad913cb9447c06c2e3cbdc86 to your computer and use it in GitHub Desktop.
New Twiddle
import Ember from 'ember';
import { computed, observer } from '@ember/object';
import { debounce } from '@ember/runloop';
export default Ember.Controller.extend({
appName: 'Ember Twiddle',
init() {
this._super(...arguments);
this.set('debouncedoutput', []);
},
searchText: '',
filter: '',
search() {
console.log(this.get('searchText') + ' @ ' + new Date());
this.set('filter', this.get('searchText'));
},
filterChanged: observer('searchText', function () {
debounce(this, this.search, 5000, false);
})
});
<h1>Welcome to {{appName}}</h1>
<br>
<br>
{{outlet}}
<br>
<br>
{{input
value=searchText
class="form-control form-control-sm"
onchange=(action (mut searchText))
placeholder="Enter text here"
}}
<p>Current value: {{filter}}</p>
<p>Output:</p>
<ul>
{{#each debouncedoutput as |output|}}
<li>{{output}}</li>
{{/each}}
</ul>
({{debouncedoutput.length}} items)
{
"version": "0.15.1",
"EmberENV": {
"FEATURES": {}
},
"options": {
"use_pods": false,
"enable-testing": false
},
"dependencies": {
"jquery": "https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.js",
"ember": "3.4.3",
"ember-template-compiler": "3.4.3",
"ember-testing": "3.4.3"
},
"addons": {
"ember-data": "3.4.2"
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment