@spectrum-web-components/button 0.18.0 → 0.18.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (161) hide show
  1. package/README.md +193 -34
  2. package/custom-elements.json +90 -90
  3. package/package.json +50 -16
  4. package/sp-button.dev.js +3 -0
  5. package/sp-button.dev.js.map +7 -0
  6. package/sp-button.js +3 -14
  7. package/sp-button.js.map +7 -1
  8. package/sp-clear-button.dev.js +3 -0
  9. package/sp-clear-button.dev.js.map +7 -0
  10. package/sp-clear-button.js +3 -14
  11. package/sp-clear-button.js.map +7 -1
  12. package/sp-close-button.dev.js +3 -0
  13. package/sp-close-button.dev.js.map +7 -0
  14. package/sp-close-button.js +3 -14
  15. package/sp-close-button.js.map +7 -1
  16. package/src/Button.dev.js +79 -0
  17. package/src/Button.dev.js.map +7 -0
  18. package/src/Button.js +72 -87
  19. package/src/Button.js.map +7 -1
  20. package/src/ButtonBase.dev.js +215 -0
  21. package/src/ButtonBase.dev.js.map +7 -0
  22. package/src/ButtonBase.js +198 -201
  23. package/src/ButtonBase.js.map +7 -1
  24. package/src/ClearButton.dev.js +70 -0
  25. package/src/ClearButton.dev.js.map +7 -0
  26. package/src/ClearButton.js +45 -52
  27. package/src/ClearButton.js.map +7 -1
  28. package/src/CloseButton.dev.js +65 -0
  29. package/src/CloseButton.dev.js.map +7 -0
  30. package/src/CloseButton.js +42 -49
  31. package/src/CloseButton.js.map +7 -1
  32. package/src/StyledButton.dev.js +8 -0
  33. package/src/StyledButton.dev.js.map +7 -0
  34. package/src/StyledButton.js +6 -17
  35. package/src/StyledButton.js.map +7 -1
  36. package/src/button-base.css.dev.js +10 -0
  37. package/src/button-base.css.dev.js.map +7 -0
  38. package/src/button-base.css.js +4 -15
  39. package/src/button-base.css.js.map +7 -1
  40. package/src/button.css.dev.js +619 -0
  41. package/src/button.css.dev.js.map +7 -0
  42. package/src/button.css.js +4 -15
  43. package/src/button.css.js.map +7 -1
  44. package/src/index.dev.js +6 -0
  45. package/src/index.dev.js.map +7 -0
  46. package/src/index.js +6 -17
  47. package/src/index.js.map +7 -1
  48. package/src/spectrum-button-base.css.dev.js +6 -0
  49. package/src/spectrum-button-base.css.dev.js.map +7 -0
  50. package/src/spectrum-button-base.css.js +3 -14
  51. package/src/spectrum-button-base.css.js.map +7 -1
  52. package/src/spectrum-button.css.dev.js +587 -0
  53. package/src/spectrum-button.css.dev.js.map +7 -0
  54. package/src/spectrum-button.css.js +4 -15
  55. package/src/spectrum-button.css.js.map +7 -1
  56. package/stories/button-accent-fill-sizes.stories.js +21 -18
  57. package/stories/button-accent-fill-sizes.stories.js.map +7 -1
  58. package/stories/button-accent-fill.stories.js +24 -20
  59. package/stories/button-accent-fill.stories.js.map +7 -1
  60. package/stories/button-accent-outline-sizes.stories.js +21 -18
  61. package/stories/button-accent-outline-sizes.stories.js.map +7 -1
  62. package/stories/button-accent-outline.stories.js +24 -20
  63. package/stories/button-accent-outline.stories.js.map +7 -1
  64. package/stories/button-black-fill-sizes.stories.js +22 -19
  65. package/stories/button-black-fill-sizes.stories.js.map +7 -1
  66. package/stories/button-black-fill.stories.js +26 -21
  67. package/stories/button-black-fill.stories.js.map +7 -1
  68. package/stories/button-black-outline-sizes.stories.js +22 -19
  69. package/stories/button-black-outline-sizes.stories.js.map +7 -1
  70. package/stories/button-black-outline.stories.js +26 -21
  71. package/stories/button-black-outline.stories.js.map +7 -1
  72. package/stories/button-negative-fill-sizes.stories.js +21 -18
  73. package/stories/button-negative-fill-sizes.stories.js.map +7 -1
  74. package/stories/button-negative-fill.stories.js +24 -20
  75. package/stories/button-negative-fill.stories.js.map +7 -1
  76. package/stories/button-negative-outline-sizes.stories.js +21 -18
  77. package/stories/button-negative-outline-sizes.stories.js.map +7 -1
  78. package/stories/button-negative-outline.stories.js +24 -20
  79. package/stories/button-negative-outline.stories.js.map +7 -1
  80. package/stories/button-primary-fill-sizes.stories.js +21 -18
  81. package/stories/button-primary-fill-sizes.stories.js.map +7 -1
  82. package/stories/button-primary-fill.stories.js +24 -20
  83. package/stories/button-primary-fill.stories.js.map +7 -1
  84. package/stories/button-primary-outline-sizes.stories.js +21 -18
  85. package/stories/button-primary-outline-sizes.stories.js.map +7 -1
  86. package/stories/button-primary-outline.stories.js +24 -20
  87. package/stories/button-primary-outline.stories.js.map +7 -1
  88. package/stories/button-secondary-fill-sizes.stories.js +21 -18
  89. package/stories/button-secondary-fill-sizes.stories.js.map +7 -1
  90. package/stories/button-secondary-fill.stories.js +24 -20
  91. package/stories/button-secondary-fill.stories.js.map +7 -1
  92. package/stories/button-secondary-outline-sizes.stories.js +21 -18
  93. package/stories/button-secondary-outline-sizes.stories.js.map +7 -1
  94. package/stories/button-secondary-outline.stories.js +24 -20
  95. package/stories/button-secondary-outline.stories.js.map +7 -1
  96. package/stories/button-white-fill-sizes.stories.js +22 -19
  97. package/stories/button-white-fill-sizes.stories.js.map +7 -1
  98. package/stories/button-white-fill.stories.js +26 -21
  99. package/stories/button-white-fill.stories.js.map +7 -1
  100. package/stories/button-white-outline-sizes.stories.js +22 -19
  101. package/stories/button-white-outline-sizes.stories.js.map +7 -1
  102. package/stories/button-white-outline.stories.js +26 -21
  103. package/stories/button-white-outline.stories.js.map +7 -1
  104. package/stories/index.js +92 -93
  105. package/stories/index.js.map +7 -1
  106. package/test/benchmark/test-basic.js +5 -16
  107. package/test/benchmark/test-basic.js.map +7 -1
  108. package/test/button-accent-fill-sizes.test-vrt.js +4 -15
  109. package/test/button-accent-fill-sizes.test-vrt.js.map +7 -1
  110. package/test/button-accent-fill.test-vrt.js +4 -15
  111. package/test/button-accent-fill.test-vrt.js.map +7 -1
  112. package/test/button-accent-outline-sizes.test-vrt.js +4 -15
  113. package/test/button-accent-outline-sizes.test-vrt.js.map +7 -1
  114. package/test/button-accent-outline.test-vrt.js +4 -15
  115. package/test/button-accent-outline.test-vrt.js.map +7 -1
  116. package/test/button-black-fill-sizes.test-vrt.js +4 -15
  117. package/test/button-black-fill-sizes.test-vrt.js.map +7 -1
  118. package/test/button-black-fill.test-vrt.js +4 -15
  119. package/test/button-black-fill.test-vrt.js.map +7 -1
  120. package/test/button-black-outline-sizes.test-vrt.js +4 -15
  121. package/test/button-black-outline-sizes.test-vrt.js.map +7 -1
  122. package/test/button-black-outline.test-vrt.js +4 -15
  123. package/test/button-black-outline.test-vrt.js.map +7 -1
  124. package/test/button-negative-fill-sizes.test-vrt.js +4 -15
  125. package/test/button-negative-fill-sizes.test-vrt.js.map +7 -1
  126. package/test/button-negative-fill.test-vrt.js +4 -15
  127. package/test/button-negative-fill.test-vrt.js.map +7 -1
  128. package/test/button-negative-outline-sizes.test-vrt.js +4 -15
  129. package/test/button-negative-outline-sizes.test-vrt.js.map +7 -1
  130. package/test/button-negative-outline.test-vrt.js +4 -15
  131. package/test/button-negative-outline.test-vrt.js.map +7 -1
  132. package/test/button-primary-fill-sizes.test-vrt.js +4 -15
  133. package/test/button-primary-fill-sizes.test-vrt.js.map +7 -1
  134. package/test/button-primary-fill.test-vrt.js +4 -15
  135. package/test/button-primary-fill.test-vrt.js.map +7 -1
  136. package/test/button-primary-outline-sizes.test-vrt.js +4 -15
  137. package/test/button-primary-outline-sizes.test-vrt.js.map +7 -1
  138. package/test/button-primary-outline.test-vrt.js +4 -15
  139. package/test/button-primary-outline.test-vrt.js.map +7 -1
  140. package/test/button-secondary-fill-sizes.test-vrt.js +4 -15
  141. package/test/button-secondary-fill-sizes.test-vrt.js.map +7 -1
  142. package/test/button-secondary-fill.test-vrt.js +4 -15
  143. package/test/button-secondary-fill.test-vrt.js.map +7 -1
  144. package/test/button-secondary-outline-sizes.test-vrt.js +4 -15
  145. package/test/button-secondary-outline-sizes.test-vrt.js.map +7 -1
  146. package/test/button-secondary-outline.test-vrt.js +4 -15
  147. package/test/button-secondary-outline.test-vrt.js.map +7 -1
  148. package/test/button-white-fill-sizes.test-vrt.js +4 -15
  149. package/test/button-white-fill-sizes.test-vrt.js.map +7 -1
  150. package/test/button-white-fill.test-vrt.js +4 -15
  151. package/test/button-white-fill.test-vrt.js.map +7 -1
  152. package/test/button-white-outline-sizes.test-vrt.js +4 -15
  153. package/test/button-white-outline-sizes.test-vrt.js.map +7 -1
  154. package/test/button-white-outline.test-vrt.js +4 -15
  155. package/test/button-white-outline.test-vrt.js.map +7 -1
  156. package/test/button.test.js +321 -320
  157. package/test/button.test.js.map +7 -1
  158. package/test/clear-button.test.js +13 -20
  159. package/test/clear-button.test.js.map +7 -1
  160. package/test/close-button.test.js +13 -20
  161. package/test/close-button.test.js.map +7 -1
@@ -1,390 +1,391 @@
1
- /*
2
- Copyright 2020 Adobe. All rights reserved.
3
- This file is licensed to you under the Apache License, Version 2.0 (the "License");
4
- you may not use this file except in compliance with the License. You may obtain a copy
5
- of the License at http://www.apache.org/licenses/LICENSE-2.0
6
-
7
- Unless required by applicable law or agreed to in writing, software distributed under
8
- the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
9
- OF ANY KIND, either express or implied. See the License for the specific language
10
- governing permissions and limitations under the License.
11
- */
12
- import '@spectrum-web-components/button/sp-button.js';
13
- import { elementUpdated, expect, fixture, html, waitUntil, } from '@open-wc/testing';
14
- import { shiftTabEvent } from '../../../test/testing-helpers.js';
15
- import { spy } from 'sinon';
16
- describe('Button', () => {
17
- it('loads default', async () => {
18
- const el = await fixture(html `
1
+ import "@spectrum-web-components/button/sp-button.js";
2
+ import {
3
+ elementUpdated,
4
+ expect,
5
+ fixture,
6
+ html,
7
+ waitUntil
8
+ } from "@open-wc/testing";
9
+ import {
10
+ shiftTabEvent,
11
+ testForLitDevWarnings
12
+ } from "../../../test/testing-helpers.js";
13
+ import { spy } from "sinon";
14
+ describe("Button", () => {
15
+ testForLitDevWarnings(async () => await fixture(html`
16
+ <sp-button tabindex="0">Button</sp-button>
17
+ `));
18
+ it("loads default", async () => {
19
+ const el = await fixture(html`
19
20
  <sp-button tabindex="0">Button</sp-button>
20
21
  `);
21
- await elementUpdated(el);
22
- expect(el).to.not.be.undefined;
23
- expect(el.textContent).to.include('Button');
24
- await expect(el).to.be.accessible();
25
- });
26
- it('loads default w/ element content', async () => {
27
- const el = await fixture(html `
22
+ await elementUpdated(el);
23
+ expect(el).to.not.be.undefined;
24
+ expect(el.textContent).to.include("Button");
25
+ await expect(el).to.be.accessible();
26
+ });
27
+ it("loads default w/ element content", async () => {
28
+ const el = await fixture(html`
28
29
  <sp-button label="Button"><svg></svg></sp-button>
29
30
  `);
30
- await elementUpdated(el);
31
- expect(el).to.not.be.undefined;
32
- await expect(el).to.be.accessible();
33
- });
34
- it('loads default w/ an icon', async () => {
35
- const el = await fixture(html `
31
+ await elementUpdated(el);
32
+ expect(el).to.not.be.undefined;
33
+ await expect(el).to.be.accessible();
34
+ });
35
+ it("loads default w/ an icon", async () => {
36
+ const el = await fixture(html`
36
37
  <sp-button label="">
37
38
  Button
38
39
  <svg slot="icon"></svg>
39
40
  </sp-button>
40
41
  `);
41
- await elementUpdated(el);
42
- expect(el).to.not.be.undefined;
43
- expect(el.textContent).to.include('Button');
44
- expect(!el.hasIcon);
45
- await expect(el).to.be.accessible();
46
- });
47
- it('loads default only icon', async () => {
48
- const el = await fixture(html `
42
+ await elementUpdated(el);
43
+ expect(el).to.not.be.undefined;
44
+ expect(el.textContent).to.include("Button");
45
+ expect(!el.hasIcon);
46
+ await expect(el).to.be.accessible();
47
+ });
48
+ it("loads default only icon", async () => {
49
+ const el = await fixture(html`
49
50
  <sp-button label="Button">
50
51
  <svg slot="icon"></svg>
51
52
  </sp-button>
52
53
  `);
53
- await elementUpdated(el);
54
- expect(el).to.not.be.undefined;
55
- await expect(el).to.be.accessible();
56
- });
57
- it('manages "role"', async () => {
58
- const el = await fixture(html `
54
+ await elementUpdated(el);
55
+ expect(el).to.not.be.undefined;
56
+ await expect(el).to.be.accessible();
57
+ });
58
+ it('manages "role"', async () => {
59
+ const el = await fixture(html`
59
60
  <sp-button>Button</sp-button>
60
61
  `);
61
- await elementUpdated(el);
62
- expect(el.getAttribute('role')).to.equal('button');
63
- el.href = '#';
64
- await elementUpdated(el);
65
- expect(el.getAttribute('role')).to.equal('link');
66
- el.removeAttribute('href');
67
- await elementUpdated(el);
68
- expect(el.getAttribute('role')).to.equal('button');
69
- });
70
- it('allows label to be toggled', async () => {
71
- const testNode = document.createTextNode('Button');
72
- const el = await fixture(html `
62
+ await elementUpdated(el);
63
+ expect(el.getAttribute("role")).to.equal("button");
64
+ el.href = "#";
65
+ await elementUpdated(el);
66
+ expect(el.getAttribute("role")).to.equal("link");
67
+ el.removeAttribute("href");
68
+ await elementUpdated(el);
69
+ expect(el.getAttribute("role")).to.equal("button");
70
+ });
71
+ it("allows label to be toggled", async () => {
72
+ const testNode = document.createTextNode("Button");
73
+ const el = await fixture(html`
73
74
  <sp-button>
74
75
  ${testNode}
75
76
  <svg slot="icon"></svg>
76
77
  </sp-button>
77
78
  `);
78
- await elementUpdated(el);
79
- const labelTestableEl = el;
80
- expect(labelTestableEl.hasLabel, 'starts with label').to.be.true;
81
- testNode.textContent = '';
82
- await elementUpdated(el);
83
- await waitUntil(() => !labelTestableEl.hasLabel, 'label is removed');
84
- testNode.textContent = 'Button';
85
- await elementUpdated(el);
86
- expect(labelTestableEl.hasLabel, 'label is returned').to.be.true;
87
- });
88
- it('loads with href', async () => {
89
- const el = await fixture(html `
79
+ await elementUpdated(el);
80
+ const labelTestableEl = el;
81
+ expect(labelTestableEl.hasLabel, "starts with label").to.be.true;
82
+ testNode.textContent = "";
83
+ await elementUpdated(el);
84
+ await waitUntil(() => !labelTestableEl.hasLabel, "label is removed");
85
+ testNode.textContent = "Button";
86
+ await elementUpdated(el);
87
+ expect(labelTestableEl.hasLabel, "label is returned").to.be.true;
88
+ });
89
+ it("loads with href", async () => {
90
+ const el = await fixture(html`
90
91
  <sp-button href="test_url">With Href</sp-button>
91
92
  `);
92
- await elementUpdated(el);
93
- expect(el).to.not.be.undefined;
94
- expect(el.textContent).to.include('With Href');
95
- });
96
- it('loads with href and target', async () => {
97
- const el = await fixture(html `
93
+ await elementUpdated(el);
94
+ expect(el).to.not.be.undefined;
95
+ expect(el.textContent).to.include("With Href");
96
+ });
97
+ it("loads with href and target", async () => {
98
+ const el = await fixture(html`
98
99
  <sp-button href="test_url" target="_blank">
99
100
  With Target
100
101
  </sp-button>
101
102
  `);
102
- await elementUpdated(el);
103
- expect(el).to.not.be.undefined;
104
- expect(el.textContent).to.include('With Target');
105
- });
106
- it('accepts shit+tab interactions', async () => {
107
- let focusedCount = 0;
108
- const el = await fixture(html `
103
+ await elementUpdated(el);
104
+ expect(el).to.not.be.undefined;
105
+ expect(el.textContent).to.include("With Target");
106
+ });
107
+ it("accepts shit+tab interactions", async () => {
108
+ let focusedCount = 0;
109
+ const el = await fixture(html`
109
110
  <sp-button href="test_url" target="_blank">
110
111
  With Target
111
112
  </sp-button>
112
113
  `);
113
- await elementUpdated(el);
114
- const focusElement = el.focusElement;
115
- focusElement.addEventListener('focus', () => (focusedCount += 1));
116
- expect(focusedCount).to.equal(0);
117
- el.focus();
118
- await elementUpdated(el);
119
- expect(focusedCount).to.equal(1);
120
- el.dispatchEvent(shiftTabEvent());
121
- el.dispatchEvent(new Event('focusin'));
122
- await elementUpdated(el);
123
- expect(focusedCount).to.equal(1);
124
- });
125
- it('manages `disabled`', async () => {
126
- const clickSpy = spy();
127
- const el = await fixture(html `
114
+ await elementUpdated(el);
115
+ const focusElement = el.focusElement;
116
+ focusElement.addEventListener("focus", () => focusedCount += 1);
117
+ expect(focusedCount).to.equal(0);
118
+ el.focus();
119
+ await elementUpdated(el);
120
+ expect(focusedCount).to.equal(1);
121
+ el.dispatchEvent(shiftTabEvent());
122
+ el.dispatchEvent(new Event("focusin"));
123
+ await elementUpdated(el);
124
+ expect(focusedCount).to.equal(1);
125
+ });
126
+ it("manages `disabled`", async () => {
127
+ const clickSpy = spy();
128
+ const el = await fixture(html`
128
129
  <sp-button @click=${() => clickSpy()}>Button</sp-button>
129
130
  `);
130
- await elementUpdated(el);
131
- el.click();
132
- await elementUpdated(el);
133
- expect(clickSpy.calledOnce).to.be.true;
134
- clickSpy.resetHistory();
135
- el.disabled = true;
136
- await elementUpdated(el);
137
- el.click();
138
- await elementUpdated(el);
139
- expect(clickSpy.callCount).to.equal(0);
140
- clickSpy.resetHistory();
141
- await elementUpdated(el);
142
- el.dispatchEvent(new Event('click', {}));
143
- await elementUpdated(el);
144
- expect(clickSpy.callCount).to.equal(0);
145
- clickSpy.resetHistory();
146
- el.disabled = false;
147
- el.click();
148
- await elementUpdated(el);
149
- expect(clickSpy.calledOnce).to.be.true;
150
- });
151
- it('manages `aria-disabled`', async () => {
152
- const el = await fixture(html `
131
+ await elementUpdated(el);
132
+ el.click();
133
+ await elementUpdated(el);
134
+ expect(clickSpy.calledOnce).to.be.true;
135
+ clickSpy.resetHistory();
136
+ el.disabled = true;
137
+ await elementUpdated(el);
138
+ el.click();
139
+ await elementUpdated(el);
140
+ expect(clickSpy.callCount).to.equal(0);
141
+ clickSpy.resetHistory();
142
+ await elementUpdated(el);
143
+ el.dispatchEvent(new Event("click", {}));
144
+ await elementUpdated(el);
145
+ expect(clickSpy.callCount).to.equal(0);
146
+ clickSpy.resetHistory();
147
+ el.disabled = false;
148
+ el.click();
149
+ await elementUpdated(el);
150
+ expect(clickSpy.calledOnce).to.be.true;
151
+ });
152
+ it("manages `aria-disabled`", async () => {
153
+ const el = await fixture(html`
153
154
  <sp-button href="test_url" target="_blank">
154
155
  With Target
155
156
  </sp-button>
156
157
  `);
157
- await elementUpdated(el);
158
- expect(el.hasAttribute('aria-disabled'), 'initially not').to.be.false;
159
- el.disabled = true;
160
- await elementUpdated(el);
161
- expect(el.getAttribute('aria-disabled')).to.equal('true');
162
- el.disabled = false;
163
- await elementUpdated(el);
164
- expect(el.hasAttribute('aria-disabled'), 'finally not').to.be.false;
165
- });
166
- it('manages tabIndex while disabled', async () => {
167
- const el = await fixture(html `
158
+ await elementUpdated(el);
159
+ expect(el.hasAttribute("aria-disabled"), "initially not").to.be.false;
160
+ el.disabled = true;
161
+ await elementUpdated(el);
162
+ expect(el.getAttribute("aria-disabled")).to.equal("true");
163
+ el.disabled = false;
164
+ await elementUpdated(el);
165
+ expect(el.hasAttribute("aria-disabled"), "finally not").to.be.false;
166
+ });
167
+ it("manages tabIndex while disabled", async () => {
168
+ const el = await fixture(html`
168
169
  <sp-button href="test_url" target="_blank">
169
170
  With Target
170
171
  </sp-button>
171
172
  `);
172
- await elementUpdated(el);
173
- expect(el.tabIndex).to.equal(0);
174
- el.disabled = true;
175
- await elementUpdated(el);
176
- expect(el.tabIndex).to.equal(-1);
177
- el.tabIndex = 2;
178
- await elementUpdated(el);
179
- expect(el.tabIndex).to.equal(-1);
180
- el.disabled = false;
181
- await elementUpdated(el);
182
- expect(el.tabIndex).to.equal(2);
183
- });
184
- it('swallows `click` interaction when `[disabled]`', async () => {
185
- const clickSpy = spy();
186
- const el = await fixture(html `
173
+ await elementUpdated(el);
174
+ expect(el.tabIndex).to.equal(0);
175
+ el.disabled = true;
176
+ await elementUpdated(el);
177
+ expect(el.tabIndex).to.equal(-1);
178
+ el.tabIndex = 2;
179
+ await elementUpdated(el);
180
+ expect(el.tabIndex).to.equal(-1);
181
+ el.disabled = false;
182
+ await elementUpdated(el);
183
+ expect(el.tabIndex).to.equal(2);
184
+ });
185
+ it("swallows `click` interaction when `[disabled]`", async () => {
186
+ const clickSpy = spy();
187
+ const el = await fixture(html`
187
188
  <sp-button disabled @click=${() => clickSpy()}>
188
189
  Button
189
190
  </sp-button>
190
191
  `);
191
- await elementUpdated(el);
192
- expect(clickSpy.callCount).to.equal(0);
193
- el.click();
194
- await elementUpdated(el);
195
- expect(clickSpy.callCount).to.equal(0);
196
- });
197
- it('translates keyboard interactions to click', async () => {
198
- const clickSpy = spy();
199
- const el = await fixture(html `
192
+ await elementUpdated(el);
193
+ expect(clickSpy.callCount).to.equal(0);
194
+ el.click();
195
+ await elementUpdated(el);
196
+ expect(clickSpy.callCount).to.equal(0);
197
+ });
198
+ it("translates keyboard interactions to click", async () => {
199
+ const clickSpy = spy();
200
+ const el = await fixture(html`
200
201
  <sp-button @click=${() => clickSpy()}>Button</sp-button>
201
202
  `);
202
- await elementUpdated(el);
203
- el.dispatchEvent(new KeyboardEvent('keypress', {
204
- bubbles: true,
205
- composed: true,
206
- cancelable: true,
207
- code: 'Enter',
208
- key: 'Enter',
209
- }));
210
- await elementUpdated(el);
211
- expect(clickSpy.callCount).to.equal(1);
212
- clickSpy.resetHistory();
213
- el.dispatchEvent(new KeyboardEvent('keypress', {
214
- bubbles: true,
215
- composed: true,
216
- cancelable: true,
217
- code: 'NumpadEnter',
218
- key: 'NumpadEnter',
219
- }));
220
- await elementUpdated(el);
221
- expect(clickSpy.callCount).to.equal(1);
222
- clickSpy.resetHistory();
223
- el.dispatchEvent(new KeyboardEvent('keypress', {
224
- bubbles: true,
225
- composed: true,
226
- cancelable: true,
227
- code: 'Space',
228
- key: 'Space',
229
- }));
230
- await elementUpdated(el);
231
- expect(clickSpy.callCount).to.equal(0);
232
- clickSpy.resetHistory();
233
- el.dispatchEvent(new KeyboardEvent('keydown', {
234
- bubbles: true,
235
- composed: true,
236
- cancelable: true,
237
- code: 'Space',
238
- key: 'Space',
239
- }));
240
- el.dispatchEvent(new KeyboardEvent('keyup', {
241
- bubbles: true,
242
- composed: true,
243
- cancelable: true,
244
- code: 'Space',
245
- key: 'Space',
246
- }));
247
- await elementUpdated(el);
248
- expect(clickSpy.callCount).to.equal(1);
249
- clickSpy.resetHistory();
250
- el.dispatchEvent(new KeyboardEvent('keydown', {
251
- bubbles: true,
252
- composed: true,
253
- cancelable: true,
254
- code: 'Space',
255
- key: 'Space',
256
- }));
257
- el.dispatchEvent(new KeyboardEvent('keyup', {
258
- bubbles: true,
259
- composed: true,
260
- cancelable: true,
261
- code: 'KeyG',
262
- key: 'g',
263
- }));
264
- await elementUpdated(el);
265
- expect(clickSpy.callCount).to.equal(0);
266
- el.dispatchEvent(new KeyboardEvent('keyup', {
267
- bubbles: true,
268
- composed: true,
269
- cancelable: true,
270
- code: 'Space',
271
- key: 'Space',
272
- }));
273
- clickSpy.resetHistory();
274
- el.dispatchEvent(new KeyboardEvent('keydown', {
275
- bubbles: true,
276
- composed: true,
277
- cancelable: true,
278
- code: 'KeyG',
279
- key: 'g',
280
- }));
281
- el.dispatchEvent(new KeyboardEvent('keyup', {
282
- bubbles: true,
283
- composed: true,
284
- cancelable: true,
285
- code: 'Space',
286
- key: 'Space',
287
- }));
288
- await elementUpdated(el);
289
- expect(clickSpy.callCount).to.equal(0);
290
- });
291
- it('proxies clicks by "type"', async () => {
292
- const submitSpy = spy();
293
- const resetSpy = spy();
294
- const test = await fixture(html `
203
+ await elementUpdated(el);
204
+ el.dispatchEvent(new KeyboardEvent("keypress", {
205
+ bubbles: true,
206
+ composed: true,
207
+ cancelable: true,
208
+ code: "Enter",
209
+ key: "Enter"
210
+ }));
211
+ await elementUpdated(el);
212
+ expect(clickSpy.callCount).to.equal(1);
213
+ clickSpy.resetHistory();
214
+ el.dispatchEvent(new KeyboardEvent("keypress", {
215
+ bubbles: true,
216
+ composed: true,
217
+ cancelable: true,
218
+ code: "NumpadEnter",
219
+ key: "NumpadEnter"
220
+ }));
221
+ await elementUpdated(el);
222
+ expect(clickSpy.callCount).to.equal(1);
223
+ clickSpy.resetHistory();
224
+ el.dispatchEvent(new KeyboardEvent("keypress", {
225
+ bubbles: true,
226
+ composed: true,
227
+ cancelable: true,
228
+ code: "Space",
229
+ key: "Space"
230
+ }));
231
+ await elementUpdated(el);
232
+ expect(clickSpy.callCount).to.equal(0);
233
+ clickSpy.resetHistory();
234
+ el.dispatchEvent(new KeyboardEvent("keydown", {
235
+ bubbles: true,
236
+ composed: true,
237
+ cancelable: true,
238
+ code: "Space",
239
+ key: "Space"
240
+ }));
241
+ el.dispatchEvent(new KeyboardEvent("keyup", {
242
+ bubbles: true,
243
+ composed: true,
244
+ cancelable: true,
245
+ code: "Space",
246
+ key: "Space"
247
+ }));
248
+ await elementUpdated(el);
249
+ expect(clickSpy.callCount).to.equal(1);
250
+ clickSpy.resetHistory();
251
+ el.dispatchEvent(new KeyboardEvent("keydown", {
252
+ bubbles: true,
253
+ composed: true,
254
+ cancelable: true,
255
+ code: "Space",
256
+ key: "Space"
257
+ }));
258
+ el.dispatchEvent(new KeyboardEvent("keyup", {
259
+ bubbles: true,
260
+ composed: true,
261
+ cancelable: true,
262
+ code: "KeyG",
263
+ key: "g"
264
+ }));
265
+ await elementUpdated(el);
266
+ expect(clickSpy.callCount).to.equal(0);
267
+ el.dispatchEvent(new KeyboardEvent("keyup", {
268
+ bubbles: true,
269
+ composed: true,
270
+ cancelable: true,
271
+ code: "Space",
272
+ key: "Space"
273
+ }));
274
+ clickSpy.resetHistory();
275
+ el.dispatchEvent(new KeyboardEvent("keydown", {
276
+ bubbles: true,
277
+ composed: true,
278
+ cancelable: true,
279
+ code: "KeyG",
280
+ key: "g"
281
+ }));
282
+ el.dispatchEvent(new KeyboardEvent("keyup", {
283
+ bubbles: true,
284
+ composed: true,
285
+ cancelable: true,
286
+ code: "Space",
287
+ key: "Space"
288
+ }));
289
+ await elementUpdated(el);
290
+ expect(clickSpy.callCount).to.equal(0);
291
+ });
292
+ it('proxies clicks by "type"', async () => {
293
+ const submitSpy = spy();
294
+ const resetSpy = spy();
295
+ const test = await fixture(html`
295
296
  <form
296
297
  @submit=${(event) => {
297
- event.preventDefault();
298
- submitSpy();
299
- }}
298
+ event.preventDefault();
299
+ submitSpy();
300
+ }}
300
301
  @reset=${(event) => {
301
- event.preventDefault();
302
- resetSpy();
303
- }}
302
+ event.preventDefault();
303
+ resetSpy();
304
+ }}
304
305
  >
305
306
  <sp-button>Button</sp-button>
306
307
  </form>
307
308
  `);
308
- const el = test.querySelector('sp-button');
309
- await elementUpdated(el);
310
- el.type = 'submit';
311
- await elementUpdated(el);
312
- el.click();
313
- expect(submitSpy.callCount).to.equal(1);
314
- expect(resetSpy.callCount).to.equal(0);
315
- el.type = 'reset';
316
- await elementUpdated(el);
317
- el.click();
318
- expect(submitSpy.callCount).to.equal(1);
319
- expect(resetSpy.callCount).to.equal(1);
320
- el.type = 'button';
321
- await elementUpdated(el);
322
- el.click();
323
- expect(submitSpy.callCount).to.equal(1);
324
- expect(resetSpy.callCount).to.equal(1);
325
- });
326
- it('proxies click by [href]', async () => {
327
- const clickSpy = spy();
328
- const el = await fixture(html `
309
+ const el = test.querySelector("sp-button");
310
+ await elementUpdated(el);
311
+ el.type = "submit";
312
+ await elementUpdated(el);
313
+ el.click();
314
+ expect(submitSpy.callCount).to.equal(1);
315
+ expect(resetSpy.callCount).to.equal(0);
316
+ el.type = "reset";
317
+ await elementUpdated(el);
318
+ el.click();
319
+ expect(submitSpy.callCount).to.equal(1);
320
+ expect(resetSpy.callCount).to.equal(1);
321
+ el.type = "button";
322
+ await elementUpdated(el);
323
+ el.click();
324
+ expect(submitSpy.callCount).to.equal(1);
325
+ expect(resetSpy.callCount).to.equal(1);
326
+ });
327
+ it("proxies click by [href]", async () => {
328
+ const clickSpy = spy();
329
+ const el = await fixture(html`
329
330
  <sp-button href="test_url">With Href</sp-button>
330
331
  `);
331
- await elementUpdated(el);
332
- el.anchorElement.addEventListener('click', (event) => {
333
- event.preventDefault();
334
- event.stopPropagation();
335
- clickSpy();
336
- });
337
- expect(clickSpy.callCount).to.equal(0);
338
- el.click();
339
- await elementUpdated(el);
340
- expect(clickSpy.callCount).to.equal(1);
332
+ await elementUpdated(el);
333
+ el.anchorElement.addEventListener("click", (event) => {
334
+ event.preventDefault();
335
+ event.stopPropagation();
336
+ clickSpy();
341
337
  });
342
- it('manages "active" while focused', async () => {
343
- const el = await fixture(html `
338
+ expect(clickSpy.callCount).to.equal(0);
339
+ el.click();
340
+ await elementUpdated(el);
341
+ expect(clickSpy.callCount).to.equal(1);
342
+ });
343
+ it('manages "active" while focused', async () => {
344
+ const el = await fixture(html`
344
345
  <sp-button label="Button">
345
346
  <svg slot="icon"></svg>
346
347
  </sp-button>
347
348
  `);
348
- await elementUpdated(el);
349
- el.active = true;
350
- await elementUpdated(el);
351
- el.dispatchEvent(new FocusEvent('focusout'));
352
- await elementUpdated(el);
353
- expect(el.active).to.be.false;
354
- });
355
- describe('deprecated variants and attributes', () => {
356
- it('manages [quiet]', async () => {
357
- const el = await fixture(html `
349
+ await elementUpdated(el);
350
+ el.active = true;
351
+ await elementUpdated(el);
352
+ el.dispatchEvent(new FocusEvent("focusout"));
353
+ await elementUpdated(el);
354
+ expect(el.active).to.be.false;
355
+ });
356
+ describe("deprecated variants and attributes", () => {
357
+ it("manages [quiet]", async () => {
358
+ const el = await fixture(html`
358
359
  <sp-button quiet>Button</sp-button>
359
360
  `);
360
- await elementUpdated(el);
361
- expect(el.treatment).to.equal('outline');
362
- el.quiet = false;
363
- await elementUpdated(el);
364
- expect(el.treatment).to.equal('fill');
365
- });
366
- it('upgrades [variant="cta"] to [variant="accent"]', async () => {
367
- const el = await fixture(html `
361
+ await elementUpdated(el);
362
+ expect(el.treatment).to.equal("outline");
363
+ el.quiet = false;
364
+ await elementUpdated(el);
365
+ expect(el.treatment).to.equal("fill");
366
+ });
367
+ it('upgrades [variant="cta"] to [variant="accent"]', async () => {
368
+ const el = await fixture(html`
368
369
  <sp-button variant="cta">Button</sp-button>
369
370
  `);
370
- await elementUpdated(el);
371
- expect(el.variant).to.equal('accent');
372
- });
373
- it('manages [variant="overBackground"]', async () => {
374
- const el = await fixture(html `
371
+ await elementUpdated(el);
372
+ expect(el.variant).to.equal("accent");
373
+ });
374
+ it('manages [variant="overBackground"]', async () => {
375
+ const el = await fixture(html`
375
376
  <sp-button variant="overBackground">Button</sp-button>
376
377
  `);
377
- await elementUpdated(el);
378
- expect(el.variant).to.equal('white');
379
- expect(el.treatment).to.equal('outline');
380
- });
381
- it('forces [variant="accent"]', async () => {
382
- const el = await fixture(html `
378
+ await elementUpdated(el);
379
+ expect(el.variant).to.equal("white");
380
+ expect(el.treatment).to.equal("outline");
381
+ });
382
+ it('forces [variant="accent"]', async () => {
383
+ const el = await fixture(html`
383
384
  <sp-button variant="not-supported">Button</sp-button>
384
385
  `);
385
- await elementUpdated(el);
386
- expect(el.variant).to.equal('accent');
387
- });
386
+ await elementUpdated(el);
387
+ expect(el.variant).to.equal("accent");
388
388
  });
389
+ });
389
390
  });
390
- //# sourceMappingURL=button.test.js.map
391
+ //# sourceMappingURL=button.test.js.map