diff --git a/addon/components/pix-toggle-button.hbs b/addon/components/pix-toggle-button.hbs index 8922963de..f940f6526 100644 --- a/addon/components/pix-toggle-button.hbs +++ b/addon/components/pix-toggle-button.hbs @@ -13,11 +13,11 @@ type="button" {{on "click" this.onToggle}} > - - {{yield to="on"}} + + {{yield to="viewA"}} - - {{yield to="off"}} + + {{yield to="viewB"}} \ No newline at end of file diff --git a/addon/styles/_pix-toggle-button.scss b/addon/styles/_pix-toggle-button.scss index 3e39007cd..0f3cb5ea9 100644 --- a/addon/styles/_pix-toggle-button.scss +++ b/addon/styles/_pix-toggle-button.scss @@ -25,37 +25,32 @@ } } - &__with-icon > svg { - width: 1.4rem; - height: 1.4rem; - } - - &__on, - &__off { + &__view-a, + &__view-b { display: inline-block; padding: var(--pix-spacing-1x) var(--pix-spacing-2x); border-radius: 4px; } - &__on { + &__view-a { color: var(--pix-neutral-800); font-weight: var(--pix-font-normal); } - &__off { + &__view-b { color: var(--pix-neutral-20); background-color: var(--pix-neutral-800); } &--pressed { .pix-toggle-button { - &__on { + &__view-a { color: var(--pix-neutral-20); font-weight: inherit; background-color: var(--pix-neutral-800); } - &__off { + &__view-b { color: var(--pix-neutral-800); font-weight: var(--pix-font-normal); background-color: transparent; diff --git a/app/stories/pix-toggle-button.mdx b/app/stories/pix-toggle-button.mdx index d1f337fb1..6889ec5c3 100644 --- a/app/stories/pix-toggle-button.mdx +++ b/app/stories/pix-toggle-button.mdx @@ -12,8 +12,8 @@ Affiche un bouton à deux états. <:label>Mon super toggle - <:on>Option 1 - <:off>Option 2 + <:viewA>Option 1 + <:viewB>Option 2 ``` @@ -32,7 +32,7 @@ Affiche un bouton à deux états. ## WithYields - + ## Arguments diff --git a/app/stories/pix-toggle-button.stories.js b/app/stories/pix-toggle-button.stories.js index 42ae4b47f..6cd597089 100644 --- a/app/stories/pix-toggle-button.stories.js +++ b/app/stories/pix-toggle-button.stories.js @@ -29,15 +29,13 @@ export default { description: "Définit si l'on utilise des icons dans le PixToggleButton", type: { name: 'boolean', required: true }, }, - onLabel: { - name: 'onLabel', - description: "Le label de l'état actif du PixToggleButton à placer dans les yield <:on>", - type: { name: 'string', required: false }, + viewALabel: { + name: '<:viewA>', + description: "Yield où l'on place le label ou l'icône de l'état actif du PixToggleButton", }, - offLabel: { - name: 'offLabel', - description: "Le label de l'état non actif du PixToggleButton à placer dans les yield <:off>", - type: { name: 'string', required: false }, + viewBLabel: { + name: '<:viewB>', + description: "Yield où l'on place le label ou l'icône de l'état non actif du PixToggleButton", }, toggled: { name: 'toggled', @@ -85,22 +83,22 @@ const Template = (args) => { @screenReaderOnly={{this.screenReaderOnly}} > <:label>{{this.label}} - <:on>{{this.onLabel}} - <:off>{{this.offLabel}} + <:viewA>{{this.viewALabel}} + <:viewB>{{this.viewBLabel}} `, context: args, }; }; -const TemplateWithYields = (args) => { +const TemplateWithIcons = (args) => { return { template: hbs` <:label>{{this.label}} {{! template-lint-disable no-inline-styles }} - <:on> + <:viewA> {{! template-lint-disable no-inline-styles }} - <:off> + <:viewB> `, context: args, }; @@ -109,18 +107,18 @@ const TemplateWithYields = (args) => { export const Default = Template.bind({}); Default.args = { label: 'Mon toggle', - onLabel: 'Option A', - offLabel: 'Option B', + viewALabel: 'Option A', + viewBLabel: 'Option B', toggled: false, onChange: action('onChange'), }; export const Inline = Template.bind({}); Inline.args = { - inline: true, + inlineLabel: true, label: 'Mon toggle', - onLabel: 'Option A', - offLabel: 'Option B', + viewALabel: 'Option A', + viewBLabel: 'Option B', toggled: false, onChange: action('onChange'), }; @@ -129,14 +127,14 @@ export const ScreenReaderOnly = Template.bind({}); ScreenReaderOnly.args = { screenReaderOnly: true, label: 'Mon toggle', - onLabel: 'Option A', - offLabel: 'Option B', + viewALabel: 'Option A', + viewBLabel: 'Option B', toggled: false, onChange: action('onChange'), }; -export const WithYields = TemplateWithYields.bind({}); -WithYields.args = { +export const WithIcons = TemplateWithIcons.bind({}); +WithIcons.args = { label: 'Mon toggle', toggled: false, useIcons: true, diff --git a/tests/integration/components/pix-toggle-button-test.js b/tests/integration/components/pix-toggle-button-test.js index 689d99664..9814d70c1 100644 --- a/tests/integration/components/pix-toggle-button-test.js +++ b/tests/integration/components/pix-toggle-button-test.js @@ -10,28 +10,28 @@ module('Integration | Component | PixToggleButton', function (hooks) { setupRenderingTest(hooks); this.label = 'Mon bouton toggle'; - this.onLabel = 'Oui'; - this.offLabel = 'Non'; + this.viewALabel = 'Oui'; + this.viewBLabel = 'Non'; test('it renders PixToggleButton', async function (assert) { // given & when const screen = await render(hbs` <:label>{{this.label}} - <:on>{{this.onLabel}} - <:off>{{this.offLabel}} + <:viewA>{{this.viewALabel}} + <:viewB>{{this.viewBLabel}} `); assert.dom(screen.getByText(this.label)).exists(); - assert.dom(screen.getByText(this.onLabel)).exists(); - assert.dom(screen.getByText(this.offLabel)).exists(); + assert.dom(screen.getByText(this.viewALabel)).exists(); + assert.dom(screen.getByText(this.viewBLabel)).exists(); }); test('it pressed PixToggleButton', async function (assert) { // given & when const screen = await render(hbs` <:label>{{this.label}} - <:on>{{this.onLabel}} - <:off>{{this.offLabel}} + <:viewA>{{this.viewALabel}} + <:viewB>{{this.viewBLabel}} `); // then @@ -42,8 +42,8 @@ module('Integration | Component | PixToggleButton', function (hooks) { // given & when const screen = await render(hbs` <:label>{{this.label}} - <:on>{{this.onLabel}} - <:off>{{this.offLabel}} + <:viewA>{{this.viewALabel}} + <:viewB>{{this.viewBLabel}} `); // then @@ -56,8 +56,8 @@ module('Integration | Component | PixToggleButton', function (hooks) { const screen = await render(hbs` <:label>{{this.label}} - <:on>{{this.onLabel}} - <:off>{{this.offLabel}} + <:viewA>{{this.viewALabel}} + <:viewB>{{this.viewBLabel}} `); @@ -74,8 +74,8 @@ module('Integration | Component | PixToggleButton', function (hooks) { const screen = await render(hbs` <:label>{{this.label}} - <:on>{{this.onLabel}} - <:off>{{this.offLabel}} + <:viewA>{{this.viewALabel}} + <:viewB>{{this.viewBLabel}} `); await click(screen.getByRole('button')); @@ -91,8 +91,8 @@ module('Integration | Component | PixToggleButton', function (hooks) { const screen = await render(hbs` <:label>{{this.label}} - <:on>{{this.onLabel}} - <:off>{{this.offLabel}} + <:viewA>{{this.viewALabel}} + <:viewB>{{this.viewBLabel}} `); @@ -109,8 +109,8 @@ module('Integration | Component | PixToggleButton', function (hooks) { const screen = await render(hbs` <:label>{{this.label}} - <:on>{{this.onLabel}} - <:off>{{this.offLabel}} + <:viewA>{{this.viewALabel}} + <:viewB>{{this.viewBLabel}} `);