Skip to content

Instantly share code, notes, and snippets.

@grapho
Last active December 12, 2018 21:53
Show Gist options
  • Save grapho/f80b3c98bf12373bf14139900ca7eb73 to your computer and use it in GitHub Desktop.
Save grapho/f80b3c98bf12373bf14139900ca7eb73 to your computer and use it in GitHub Desktop.
Custom Radio Option
import Ember from 'ember';
import { computed } from '@ember/object';
const radioOptions = [
'Option 1',
'Option 2',
'Option 3',
]
export default Ember.Controller.extend({
appName: 'Ember Twiddle',
radioOptions,
selectedOption: 'Something',
isCustomOption: computed('selectedOption', function() {
let options = this.radioOptions;
let selected = this.selectedOption;
return !options.includes(selected);
})
});
<h1>Welcome to {{appName}}</h1>
<p>{{if selectedOption selectedOption "Nothing selected"}}</p>
{{#each radioOptions as |opt|}}
<p>
<label>
<input
type="radio"
name="select-the-thing"
value={{opt}}
checked={{eq opt selectedOption}}
onchange={{action (mut selectedOption) value="target.value"}}
>
{{opt}}
</label>
</p>
{{/each}}
<p>
<label>
<input
type="radio"
name="select-the-thing"
value=""
checked={{isCustomOption}}
onchange={{action (mut selectedOption) value="target.value"}}
>
Custom
</label>
</p>
{{#if isCustomOption}}
<textarea
value={{selectedOption}}
oninput={{action (mut selectedOption) value="target.value"}}
/>
{{/if}}
{
"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",
"ember-truth-helpers": "2.0.0"
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment