Turn components into puppets. Calling their actions or even functions from parent components / controllers.
ember install ember-cli-puppet
Assuming you mix in ember-cli-puppet/mixins/puppet into your-component
, this addon allows you to do:
{{your-component onPuppet=(action (mut instance))}}
<button {{action (puppet-call instance 'func_name')}}>Call the func_name function of the component</button>
<button {{action (puppet-send instance 'act_name')}}>Invoke the act_name action of the component</button>
- ember-component-inbound-actions - okay but can lead to rerender issues
- Modifying parameters and having the component monitor for changes - pure ugliness
- Doesn't this break the DDAU principle? Absolutely! Use at your own risk.
- When should I handle the
offPuppet
event? If you modify a controller's state during theonPuppet
event, then it makes sense to clean up duringoffPuppet
. You can skip that for components since they clean up after themselves once they get destroyed.
git clone <repository-url>
cd ember-cli-puppet
npm install
npm run lint:js
npm run lint:js -- --fix
ember test
– Runs the test suite on the current Ember versionember test --server
– Runs the test suite in "watch mode"npm test
– Runsember try:each
to test your addon against multiple Ember versions
ember serve
- Visit the dummy application at http://localhost:4200.
For more information on using ember-cli, visit https://ember-cli.com/.
This project is licensed under the MIT License.