From a80286fbef0aea829a6fdea871ac0055c66b8c9f Mon Sep 17 00:00:00 2001 From: Matthew Hartstonge Date: Thu, 31 Oct 2024 16:38:43 +1300 Subject: [PATCH] feat(addon/components/paper-button): converts to a glimmer component. --- addon/components/paper-button.hbs | 48 ++++++++++++++---- addon/components/paper-button.js | 83 +++++++++++++------------------ 2 files changed, 72 insertions(+), 59 deletions(-) diff --git a/addon/components/paper-button.hbs b/addon/components/paper-button.hbs index 79afe4288..50ce9514d 100644 --- a/addon/components/paper-button.hbs +++ b/addon/components/paper-button.hbs @@ -1,11 +1,39 @@ -{{! template-lint-disable no-curly-component-invocation }} -{{#if (has-block)}} - {{yield}} -{{else}} - {{@label}} -{{/if}} +{{#let (element this.tag) as |Tag|}} + + {{#if (has-block)}} + {{yield}} + {{else}} + {{@label}} + {{/if}} - + + +{{/let}} \ No newline at end of file diff --git a/addon/components/paper-button.js b/addon/components/paper-button.js index 3314b6963..abb15c15e 100644 --- a/addon/components/paper-button.js +++ b/addon/components/paper-button.js @@ -1,59 +1,44 @@ -/* eslint-disable ember/no-classic-components, ember/no-mixins, ember/require-tagless-components */ /** * @module ember-paper */ -import { reads } from '@ember/object/computed'; - -import Component from '@ember/component'; -import FocusableMixin from 'ember-paper/mixins/focusable-mixin'; -import ProxiableMixin from 'ember-paper/mixins/proxiable-mixin'; -import { invokeAction } from 'ember-paper/utils/invoke-action'; +import Focusable from './-focusable'; +import { action } from '@ember/object'; /** * @class PaperButton - * @extends Ember.Component - * @uses FocusableMixin - * @uses ProxiableMixin + * @extends Focusable */ -export default Component.extend(FocusableMixin, ProxiableMixin, { - tagName: 'button', - classNames: ['md-default-theme', 'md-button'], - raised: false, - iconButton: false, - - // circular button - fab: reads('mini'), - - mini: false, - type: 'button', - href: null, - target: null, - - attributeBindings: ['type', 'href', 'target', 'title', 'download', 'rel'], - - classNameBindings: [ - 'raised:md-raised', - 'iconButton:md-icon-button', - 'fab:md-fab', - 'mini:md-mini', - 'warn:md-warn', - 'accent:md-accent', - 'primary:md-primary', - ], - - init() { - this._super(...arguments); - if (this.href) { - this.setProperties({ - tagName: 'a', - type: null, - }); +export default class PaperButton extends Focusable { + get tag() { + if (this.args.href) { + return 'a'; + } + + return 'button'; + } + + get type() { + if (this.args.type) { + return this.args.type; + } + + return 'button'; + } + + get fab() { + return this.args.fab || this.args.mini; + } + + @action handleClick(e) { + if (this.args.onClick) { + this.args.onClick(e); } - }, - click(e) { - invokeAction(this, 'onClick', e); // Prevent bubbling, if specified. If undefined, the event will bubble. - return this.bubbles; - }, -}); + if (this.args.bubbles === undefined) { + return true; + } + + return this.args.bubbles; + } +}