@spectrum-web-components/reactive-controllers 1.2.0-beta.8 → 1.2.0

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.
@@ -0,0 +1,208 @@
1
+ "use strict";
2
+ import { expect } from "@open-wc/testing";
3
+ import Color from "colorjs.io";
4
+ import {
5
+ ColorController
6
+ } from "@spectrum-web-components/reactive-controllers/src/ColorController.js";
7
+ describe("ColorController", () => {
8
+ let host;
9
+ let colorController;
10
+ beforeEach(() => {
11
+ host = {};
12
+ host.requestUpdate = () => {
13
+ };
14
+ colorController = new ColorController(host);
15
+ });
16
+ it("should initialize correctly", () => {
17
+ expect(colorController).to.exist;
18
+ expect(colorController.color).to.be.instanceOf(Color);
19
+ });
20
+ it("should validate color strings correctly", () => {
21
+ const validRgba = "rgba(255, 0, 0, 1)";
22
+ const validHsla = "hsla(120, 100%, 50%, 0.5)";
23
+ const validHsva = "hsva(240, 100%, 100%, 0.75)";
24
+ const invalidColor = "invalidColor";
25
+ expect(colorController.validateColorString(validRgba).isValid).to.be.true;
26
+ expect(colorController.validateColorString(validHsla).isValid).to.be.true;
27
+ expect(colorController.validateColorString(validHsva).isValid).to.be.true;
28
+ expect(colorController.validateColorString(invalidColor).isValid).to.be.false;
29
+ });
30
+ it("should process RGB values in percentage correctly", () => {
31
+ const colorString = "rgb(50%, 25%, 75%)";
32
+ const result = colorController.validateColorString(colorString);
33
+ expect(result.isValid).to.be.true;
34
+ expect(result.coords).to.deep.equal([0.5, 0.25, 0.75]);
35
+ expect(result.spaceId).to.equal("srgb");
36
+ });
37
+ it("should default alpha to 1 when alpha is undefined in RGBA", () => {
38
+ const colorString = "rgb(255, 0, 0)";
39
+ const result = colorController.validateColorString(colorString);
40
+ expect(result.alpha).to.equal(1);
41
+ expect(result.isValid).to.be.true;
42
+ expect(result.coords).to.deep.equal([1, 0, 0]);
43
+ expect(result.spaceId).to.equal("srgb");
44
+ });
45
+ it("should handle invalid color strings by trying to create a new Color object with a prefixed #", () => {
46
+ const invalidColorString = "invalidColor";
47
+ const validHexColorString = "ff0000";
48
+ colorController.color = invalidColorString;
49
+ expect(colorController.color.toString()).to.equal(
50
+ new Color("hsv", [0, 100, 100], 1).toString()
51
+ );
52
+ colorController.color = validHexColorString;
53
+ expect(colorController.color.toString()).to.equal(
54
+ new Color(`#${validHexColorString}`).toString()
55
+ );
56
+ });
57
+ it("should set color correctly with string input", () => {
58
+ const colorString = "rgba(255, 0, 0, 1)";
59
+ colorController.color = colorString;
60
+ expect(colorController.color.toString()).to.equal(
61
+ new Color(colorString).toString()
62
+ );
63
+ });
64
+ it("should set color correctly with object input", () => {
65
+ const colorObject = { r: 255, g: 0, b: 0, a: 1 };
66
+ colorController.color = colorObject;
67
+ });
68
+ it("should get color value correctly", () => {
69
+ let colorString = "rgba(255, 0, 0, 0.7)";
70
+ colorController.color = colorString;
71
+ expect(colorController.colorValue).to.equal(colorString);
72
+ colorString = "hsla(120, 100%, 50%, 0.5)";
73
+ colorController.color = colorString;
74
+ expect(colorController.colorValue).to.equal(colorString);
75
+ });
76
+ it("should get and set hue correctly", () => {
77
+ colorController.hue = 180;
78
+ expect(colorController.hue).to.equal(180);
79
+ });
80
+ it("should convert color correctly", () => {
81
+ const colorString = "rgba(255, 0, 0, 1)";
82
+ colorController.color = colorString;
83
+ expect(colorController.getColor("hsl")).to.be.an("object");
84
+ });
85
+ it("should get HSL string correctly", () => {
86
+ const colorString = "rgba(255, 0, 0, 1)";
87
+ colorController.color = colorString;
88
+ expect(colorController.getHslString()).to.equal(
89
+ new Color(colorString).to("hsl").toString()
90
+ );
91
+ });
92
+ it("should process hex color values correctly when alpha is defined", () => {
93
+ const colorString = "#ff573380";
94
+ colorController.color = colorString;
95
+ expect(colorController.color.toString()).to.equal(
96
+ new Color(colorString).toString()
97
+ );
98
+ });
99
+ it("should process hex color values correctly when alpha is not defined", () => {
100
+ const colorString = "#ff5733";
101
+ colorController.color = colorString;
102
+ expect(colorController.color.toString()).to.equal(
103
+ new Color(colorString).toString()
104
+ );
105
+ });
106
+ it("should save and restore previous color correctly", () => {
107
+ const colorString = "rgba(255, 0, 0, 1)";
108
+ colorController.color = colorString;
109
+ colorController.savePreviousColor();
110
+ colorController.color = "rgba(0, 255, 0, 1)";
111
+ colorController.restorePreviousColor();
112
+ expect(colorController.color.toString()).to.equal(
113
+ new Color(colorString).toString()
114
+ );
115
+ });
116
+ it("should return correct color value for hsv spaceId", () => {
117
+ colorController.color = "hsv(120, 100%, 50%)";
118
+ const result = colorController.colorValue;
119
+ expect(result).to.equal("hsv(120, 100%, 50%)");
120
+ });
121
+ it("should return correct color value for hsva spaceId", () => {
122
+ colorController.color = "hsva(120, 100%, 50%, 0.5)";
123
+ const result = colorController.colorValue;
124
+ expect(result).to.equal("hsva(120, 100%, 50%, 0.5)");
125
+ });
126
+ it("should return correct color value for hsl spaceId", () => {
127
+ colorController.color = "hsl(120, 100%, 50%)";
128
+ const result = colorController.colorValue;
129
+ expect(result).to.equal("hsl(120, 100%, 50%)");
130
+ });
131
+ it("should return correct color value for hsla spaceId", () => {
132
+ colorController.color = "hsla(120, 100%, 50%, 0.5)";
133
+ const result = colorController.colorValue;
134
+ expect(result).to.equal("hsla(120, 100%, 50%, 0.5)");
135
+ });
136
+ it("should return correct color value for hex string spaceId", () => {
137
+ colorController.color = "#ff5733";
138
+ const result = colorController.colorValue;
139
+ expect(result).to.equal("#ff5733");
140
+ });
141
+ it("should return correct color value for hex string spaceId with alpha", () => {
142
+ colorController.color = "#ff573380";
143
+ const result = colorController.colorValue;
144
+ expect(result).to.equal("#ff573380");
145
+ });
146
+ it("should return correct color value for default spaceId with hex origin", () => {
147
+ colorController.color = "#ff5733";
148
+ const result = colorController.colorValue;
149
+ expect(result).to.equal("#ff5733");
150
+ });
151
+ it("should return correct color value for default spaceId with hex origin and alpha", () => {
152
+ colorController.color = "#ff573380";
153
+ const result = colorController.colorValue;
154
+ expect(result).to.equal("#ff573380");
155
+ });
156
+ it("should return correct color value for default spaceId with percentage origin", () => {
157
+ colorController.color = "rgb(50%, 25%, 75%)";
158
+ const result = colorController.colorValue;
159
+ expect(result).to.equal("rgb(50%, 25%, 75%)");
160
+ });
161
+ it("should return correct color value for default spaceId with rgba origin", () => {
162
+ colorController.color = "rgba(255, 87, 51, 0.5)";
163
+ const result = colorController.colorValue;
164
+ expect(result).to.equal("rgba(255, 87, 51, 0.5)");
165
+ });
166
+ it("should return correct color values for hsv spaceId", () => {
167
+ colorController.color = new Color("hsv", [120, 100, 50]);
168
+ const result = colorController.colorValue;
169
+ expect(result).to.deep.equal({
170
+ h: 120,
171
+ s: 1,
172
+ v: 0.5,
173
+ a: 1
174
+ });
175
+ });
176
+ it("should return correct color values for hsl spaceId", () => {
177
+ colorController.color = new Color("hsl", [120, 100, 50]);
178
+ const result = colorController.colorValue;
179
+ expect(result).to.deep.equal({
180
+ h: 120,
181
+ s: 1,
182
+ l: 0.5,
183
+ a: 1
184
+ });
185
+ });
186
+ it("should return correct color values for srgb spaceId", () => {
187
+ colorController.color = new Color("srgb", [0.5, 0.25, 0.75]);
188
+ const result = colorController.colorValue;
189
+ expect(result).to.deep.equal({
190
+ r: 128,
191
+ g: 64,
192
+ b: 191,
193
+ a: 1
194
+ });
195
+ });
196
+ it("should return correct color values for srgb spaceId with percentage origin", () => {
197
+ colorController.color = new Color("srgb", [0.5, 0.25, 0.75]);
198
+ colorController.colorOrigin = { r: "50%", g: "25%", b: "75%" };
199
+ const result = colorController.colorValue;
200
+ expect(result).to.deep.equal({
201
+ r: "128%",
202
+ g: "64%",
203
+ b: "191%",
204
+ a: 1
205
+ });
206
+ });
207
+ });
208
+ //# sourceMappingURL=color-controller.test.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["color-controller.test.ts"],
4
+ "sourcesContent": ["/*\nCopyright 2022 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport { expect } from '@open-wc/testing';\nimport { ReactiveElement } from 'lit';\nimport Color from 'colorjs.io';\nimport {\n ColorController,\n ColorTypes,\n} from '@spectrum-web-components/reactive-controllers/src/ColorController.js';\n\ndescribe('ColorController', () => {\n let host: ReactiveElement;\n let colorController: ColorController;\n\n beforeEach(() => {\n host = {} as ReactiveElement;\n host.requestUpdate = () => {};\n colorController = new ColorController(host);\n });\n\n it('should initialize correctly', () => {\n expect(colorController).to.exist;\n expect(colorController.color).to.be.instanceOf(Color);\n });\n\n it('should validate color strings correctly', () => {\n const validRgba = 'rgba(255, 0, 0, 1)';\n const validHsla = 'hsla(120, 100%, 50%, 0.5)';\n const validHsva = 'hsva(240, 100%, 100%, 0.75)';\n const invalidColor = 'invalidColor';\n\n expect(colorController.validateColorString(validRgba).isValid).to.be\n .true;\n expect(colorController.validateColorString(validHsla).isValid).to.be\n .true;\n expect(colorController.validateColorString(validHsva).isValid).to.be\n .true;\n expect(colorController.validateColorString(invalidColor).isValid).to.be\n .false;\n });\n\n it('should process RGB values in percentage correctly', () => {\n const colorString = 'rgb(50%, 25%, 75%)';\n const result = colorController.validateColorString(colorString);\n expect(result.isValid).to.be.true;\n expect(result.coords).to.deep.equal([0.5, 0.25, 0.75]);\n expect(result.spaceId).to.equal('srgb');\n });\n\n it('should default alpha to 1 when alpha is undefined in RGBA', () => {\n const colorString = 'rgb(255, 0, 0)';\n const result = colorController.validateColorString(colorString);\n\n expect(result.alpha).to.equal(1);\n expect(result.isValid).to.be.true;\n expect(result.coords).to.deep.equal([1, 0, 0]);\n expect(result.spaceId).to.equal('srgb');\n });\n\n it('should handle invalid color strings by trying to create a new Color object with a prefixed #', () => {\n const invalidColorString = 'invalidColor';\n const validHexColorString = 'ff0000'; // Equivalent to #ff0000\n\n // Set the invalid color string\n colorController.color = invalidColorString;\n\n // Expect the color to be unchanged (default color)\n expect(colorController.color.toString()).to.equal(\n new Color('hsv', [0, 100, 100], 1).toString()\n );\n\n // Set the valid hex color string without #\n colorController.color = validHexColorString;\n\n // Expect the color to be set correctly\n expect(colorController.color.toString()).to.equal(\n new Color(`#${validHexColorString}`).toString()\n );\n });\n\n it('should set color correctly with string input', () => {\n const colorString = 'rgba(255, 0, 0, 1)';\n colorController.color = colorString;\n expect(colorController.color.toString()).to.equal(\n new Color(colorString).toString()\n );\n });\n\n it('should set color correctly with object input', () => {\n const colorObject: ColorTypes = { r: 255, g: 0, b: 0, a: 1 };\n colorController.color = colorObject;\n //expect(colorController.color.toString()).to.equal(new Color(colorObject).toString());\n });\n\n it('should get color value correctly', () => {\n let colorString = 'rgba(255, 0, 0, 0.7)';\n colorController.color = colorString;\n expect(colorController.colorValue).to.equal(colorString);\n colorString = 'hsla(120, 100%, 50%, 0.5)';\n colorController.color = colorString;\n expect(colorController.colorValue).to.equal(colorString);\n });\n\n it('should get and set hue correctly', () => {\n colorController.hue = 180;\n expect(colorController.hue).to.equal(180);\n });\n\n it('should convert color correctly', () => {\n const colorString = 'rgba(255, 0, 0, 1)';\n colorController.color = colorString;\n expect(colorController.getColor('hsl')).to.be.an('object');\n });\n\n it('should get HSL string correctly', () => {\n const colorString = 'rgba(255, 0, 0, 1)';\n colorController.color = colorString;\n expect(colorController.getHslString()).to.equal(\n new Color(colorString).to('hsl').toString()\n );\n });\n\n it('should process hex color values correctly when alpha is defined', () => {\n const colorString = '#ff573380'; // Equivalent to rgba(255, 87, 51, 0.5)\n colorController.color = colorString;\n expect(colorController.color.toString()).to.equal(\n new Color(colorString).toString()\n );\n });\n\n it('should process hex color values correctly when alpha is not defined', () => {\n const colorString = '#ff5733'; // Equivalent to rgba(255, 87, 51, 1)\n colorController.color = colorString;\n expect(colorController.color.toString()).to.equal(\n new Color(colorString).toString()\n );\n });\n\n it('should save and restore previous color correctly', () => {\n const colorString = 'rgba(255, 0, 0, 1)';\n colorController.color = colorString;\n colorController.savePreviousColor();\n colorController.color = 'rgba(0, 255, 0, 1)';\n colorController.restorePreviousColor();\n expect(colorController.color.toString()).to.equal(\n new Color(colorString).toString()\n );\n });\n it('should return correct color value for hsv spaceId', () => {\n colorController.color = 'hsv(120, 100%, 50%)';\n const result = colorController.colorValue;\n expect(result).to.equal('hsv(120, 100%, 50%)');\n });\n\n it('should return correct color value for hsva spaceId', () => {\n colorController.color = 'hsva(120, 100%, 50%, 0.5)';\n const result = colorController.colorValue;\n expect(result).to.equal('hsva(120, 100%, 50%, 0.5)');\n });\n\n it('should return correct color value for hsl spaceId', () => {\n colorController.color = 'hsl(120, 100%, 50%)';\n const result = colorController.colorValue;\n expect(result).to.equal('hsl(120, 100%, 50%)');\n });\n\n it('should return correct color value for hsla spaceId', () => {\n colorController.color = 'hsla(120, 100%, 50%, 0.5)';\n const result = colorController.colorValue;\n expect(result).to.equal('hsla(120, 100%, 50%, 0.5)');\n });\n\n it('should return correct color value for hex string spaceId', () => {\n colorController.color = '#ff5733';\n const result = colorController.colorValue;\n expect(result).to.equal('#ff5733');\n });\n\n it('should return correct color value for hex string spaceId with alpha', () => {\n colorController.color = '#ff573380'; // Equivalent to rgba(255, 87, 51, 0.5)\n const result = colorController.colorValue;\n expect(result).to.equal('#ff573380');\n });\n\n it('should return correct color value for default spaceId with hex origin', () => {\n colorController.color = '#ff5733';\n const result = colorController.colorValue;\n expect(result).to.equal('#ff5733');\n });\n\n it('should return correct color value for default spaceId with hex origin and alpha', () => {\n colorController.color = '#ff573380'; // Equivalent to rgba(255, 87, 51, 0.5)\n const result = colorController.colorValue;\n expect(result).to.equal('#ff573380');\n });\n\n it('should return correct color value for default spaceId with percentage origin', () => {\n colorController.color = 'rgb(50%, 25%, 75%)';\n const result = colorController.colorValue;\n expect(result).to.equal('rgb(50%, 25%, 75%)');\n });\n\n it('should return correct color value for default spaceId with rgba origin', () => {\n colorController.color = 'rgba(255, 87, 51, 0.5)';\n const result = colorController.colorValue;\n expect(result).to.equal('rgba(255, 87, 51, 0.5)');\n });\n\n it('should return correct color values for hsv spaceId', () => {\n colorController.color = new Color('hsv', [120, 100, 50]);\n const result = colorController.colorValue;\n expect(result).to.deep.equal({\n h: 120,\n s: 1,\n v: 0.5,\n a: 1,\n });\n });\n\n it('should return correct color values for hsl spaceId', () => {\n colorController.color = new Color('hsl', [120, 100, 50]);\n const result = colorController.colorValue;\n expect(result).to.deep.equal({\n h: 120,\n s: 1,\n l: 0.5,\n a: 1,\n });\n });\n\n it('should return correct color values for srgb spaceId', () => {\n colorController.color = new Color('srgb', [0.5, 0.25, 0.75]);\n const result = colorController.colorValue;\n expect(result).to.deep.equal({\n r: 128,\n g: 64,\n b: 191,\n a: 1,\n });\n });\n\n it('should return correct color values for srgb spaceId with percentage origin', () => {\n colorController.color = new Color('srgb', [0.5, 0.25, 0.75]);\n colorController.colorOrigin = { r: '50%', g: '25%', b: '75%' };\n const result = colorController.colorValue;\n expect(result).to.deep.equal({\n r: '128%',\n g: '64%',\n b: '191%',\n a: 1,\n });\n });\n});\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -213,7 +213,7 @@ describe("Action Menu inside of Action Group", () => {
213
213
  });
214
214
  describe("tabIndex is cached properly", () => {
215
215
  it("cache is managed properly", async () => {
216
- var _a, _b, _c, _d, _e;
216
+ var _a, _b, _c;
217
217
  const menuEl = await fixture(html`
218
218
  <sp-action-menu label="More Actions">
219
219
  <sp-menu-item>One</sp-menu-item>
@@ -221,24 +221,22 @@ describe("tabIndex is cached properly", () => {
221
221
  <sp-menu-item>Three</sp-menu-item>
222
222
  </sp-action-menu>
223
223
  `);
224
- expect(menuEl.tabIndex).to.equal(0);
225
- expect((_a = menuEl.focusElement) == null ? void 0 : _a.tabIndex).to.equal(0);
226
- menuEl.tabIndex = 1;
227
- await elementUpdated(menuEl);
228
- expect(menuEl.tabIndex).to.equal(1);
229
- expect((_b = menuEl.focusElement) == null ? void 0 : _b.tabIndex).to.equal(1);
224
+ expect(
225
+ (_a = menuEl.focusElement) == null ? void 0 : _a.tabIndex,
226
+ "button tabindex before disabling"
227
+ ).to.equal(0);
230
228
  menuEl.disabled = true;
231
229
  await elementUpdated(menuEl);
232
- expect(menuEl.tabIndex).to.equal(-1);
233
- expect((_c = menuEl.focusElement) == null ? void 0 : _c.tabIndex).to.equal(-1);
234
- menuEl.tabIndex = 2;
235
- await elementUpdated(menuEl);
236
- expect(menuEl.tabIndex).to.equal(-1);
237
- expect((_d = menuEl.focusElement) == null ? void 0 : _d.tabIndex).to.equal(-1);
230
+ expect(
231
+ (_b = menuEl.focusElement) == null ? void 0 : _b.tabIndex,
232
+ "button tabindex after disabling"
233
+ ).to.equal(-1);
238
234
  menuEl.disabled = false;
239
235
  await elementUpdated(menuEl);
240
- expect(menuEl.tabIndex).to.equal(2);
241
- expect((_e = menuEl.focusElement) == null ? void 0 : _e.tabIndex).to.equal(2);
236
+ expect(
237
+ (_c = menuEl.focusElement) == null ? void 0 : _c.tabIndex,
238
+ "button tabindex after setting to 0"
239
+ ).to.equal(0);
242
240
  });
243
241
  });
244
242
  //# sourceMappingURL=roving-tabindex-integration.test.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["roving-tabindex-integration.test.ts"],
4
- "sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\nimport '@spectrum-web-components/action-button/sp-action-button.js';\nimport { ActionButton } from '@spectrum-web-components/action-button';\nimport '@spectrum-web-components/action-group/sp-action-group.js';\nimport { ActionGroup } from '@spectrum-web-components/action-group';\nimport { ActionMenu } from '@spectrum-web-components/action-menu';\nimport '@spectrum-web-components/tabs/sp-tab-panel.js';\nimport '@spectrum-web-components/tabs/sp-tab.js';\nimport '@spectrum-web-components/tabs/sp-tabs.js';\nimport '@spectrum-web-components/action-menu/sp-action-menu.js';\nimport '@spectrum-web-components/menu/sp-menu.js';\nimport '@spectrum-web-components/menu/sp-menu-item.js';\nimport { Tab, TabPanel, Tabs } from '@spectrum-web-components/tabs';\nimport { elementUpdated, expect, fixture, nextFrame } from '@open-wc/testing';\nimport { html } from '@spectrum-web-components/base';\nimport { sendKeys } from '@web/test-runner-commands';\nimport { sendMouse } from '../../../test/plugins/browser.js';\n\nconst createTabs = async (): Promise<Tabs> => {\n const tabs = await fixture<Tabs>(html`\n <sp-tabs selected=\"second\">\n <sp-tab label=\"Tab 1\" value=\"first\"></sp-tab>\n <sp-tab label=\"Tab 2\" value=\"second\"></sp-tab>\n <sp-tab label=\"Tab 3\" value=\"third\"></sp-tab>\n <sp-tab-panel value=\"first\">\n <sp-action-group selects=\"single\">\n <sp-action-button selected value=\"1\">\n Single Button 1\n </sp-action-button>\n <sp-action-button value=\"2\">\n Single Button 2\n </sp-action-button>\n <sp-action-button value=\"3\">\n Single Button 3\n </sp-action-button>\n </sp-action-group>\n </sp-tab-panel>\n <sp-tab-panel value=\"second\">\n <sp-action-group selects=\"multiple\">\n <sp-action-button value=\"1\">\n Multiple Button 1\n </sp-action-button>\n <sp-action-button selected value=\"2\">\n Multiple Button 2\n </sp-action-button>\n <sp-action-button selected value=\"3\">\n Multiple Button 3\n </sp-action-button>\n </sp-action-group>\n </sp-tab-panel>\n <sp-tab-panel value=\"third\">\n <sp-action-group>\n <sp-action-button value=\"1\">None Button 1</sp-action-button>\n <sp-action-button value=\"2\">None Button 2</sp-action-button>\n <sp-action-button selected value=\"3\">\n None Button 3\n </sp-action-button>\n </sp-action-group>\n </sp-tab-panel>\n </sp-tabs>\n `);\n await elementUpdated(tabs);\n return tabs;\n};\n\nconst createGroup = async (): Promise<ActionGroup> => {\n const group = await fixture<ActionGroup>(html`\n <sp-action-group>\n <sp-action-button>Button 1</sp-action-button>\n <sp-action-button>Longer Button 2</sp-action-button>\n <sp-action-button>Short 3</sp-action-button>\n <sp-action-menu label=\"More Actions\">\n <sp-menu-item>One</sp-menu-item>\n <sp-menu-item>Two</sp-menu-item>\n <sp-menu-item>Three</sp-menu-item>\n <sp-menu-item>\n Select some items\n <sp-menu slot=\"submenu\" selects=\"multiple\">\n <sp-menu-item>A</sp-menu-item>\n <sp-menu-item selected>B</sp-menu-item>\n <sp-menu-item>C</sp-menu-item>\n </sp-menu>\n </sp-menu-item>\n </sp-action-menu>\n </sp-action-group>\n `);\n await elementUpdated(group);\n return group;\n};\n\ndescribe('Action Group inside of Tabs', () => {\n it('accurately navigates the desired element', async () => {\n const el = await createTabs();\n const tab1 = el.querySelector('sp-tab[value=\"first\"]') as Tab;\n const tab2 = el.querySelector('sp-tab[value=\"second\"]');\n const tab3 = el.querySelector('sp-tab[value=\"third\"]') as Tab;\n const tabPanel1 = el.querySelector(\n 'sp-tab-panel[value=\"first\"]'\n ) as TabPanel;\n const tabPanel2 = el.querySelector(\n 'sp-tab-panel[value=\"second\"]'\n ) as TabPanel;\n const tabPanel3 = el.querySelector(\n 'sp-tab-panel[value=\"third\"]'\n ) as TabPanel;\n const actionGroup1 = tabPanel1.querySelector(\n 'sp-action-group'\n ) as ActionGroup;\n const actionGroup2 = tabPanel2.querySelector(\n 'sp-action-group'\n ) as ActionGroup;\n const actionGroup3 = tabPanel3.querySelector(\n 'sp-action-group'\n ) as ActionGroup;\n const actionButton1 = actionGroup1.querySelector(\n '[selected]'\n ) as ActionButton;\n const actionButton2 = actionGroup2.querySelector(\n '[selected]'\n ) as ActionButton;\n const actionButton3 = actionGroup3.querySelector(\n '[selected]'\n ) as ActionButton;\n\n el.focus();\n expect(el.contains(document.activeElement)).to.be.true;\n expect(document.activeElement === tab2).to.be.true;\n\n actionGroup2.focus();\n expect(document.activeElement === actionButton2).to.be.true;\n\n await nextFrame();\n await sendKeys({\n press: 'ArrowLeft',\n });\n\n expect(document.activeElement === tab1).to.be.false;\n expect(actionGroup2.contains(document.activeElement)).to.be.true;\n\n el.focus();\n expect(document.activeElement === tab2).to.be.true;\n\n await sendKeys({\n press: 'ArrowRight',\n });\n\n expect(document.activeElement === tab3).to.be.true;\n\n await sendKeys({\n press: 'Enter',\n });\n\n expect(document.activeElement === tab3).to.be.true;\n\n actionGroup3.focus();\n expect(document.activeElement === actionButton3).to.be.true;\n\n await sendKeys({\n press: 'ArrowLeft',\n });\n\n expect(document.activeElement === tab2).to.be.false;\n expect(actionGroup3.contains(document.activeElement)).to.be.true;\n\n const boundingRect = tab1.getBoundingClientRect();\n // tab1.click() doesn't current reach into the focus management here.\n await sendMouse({\n steps: [\n {\n type: 'click',\n position: [\n boundingRect.left + boundingRect.width / 2,\n boundingRect.top + boundingRect.height / 2,\n ],\n },\n ],\n });\n expect(document.activeElement === tab1).to.be.true;\n\n actionGroup1.focus();\n expect(document.activeElement === actionButton1).to.be.true;\n\n await sendKeys({\n press: 'ArrowRight',\n });\n\n expect(document.activeElement === tab2).to.be.false;\n expect(actionGroup1.contains(document.activeElement)).to.be.true;\n });\n});\n\ndescribe('Action Menu inside of Action Group', () => {\n it('accurately manages the tabindex of all the elements', async () => {\n const el = await createGroup();\n const actionButton1 = el.querySelector(\n 'sp-action-button:nth-child(1)'\n ) as ActionButton;\n const actionButton2 = el.querySelector(\n 'sp-action-button:nth-child(2)'\n ) as ActionButton;\n const actionButton3 = el.querySelector(\n 'sp-action-button:nth-child(3)'\n ) as ActionButton;\n const actionMenu = el.querySelector('sp-action-menu') as ActionMenu;\n\n el.focus();\n expect(document.activeElement === actionButton1).to.be.true;\n\n await sendKeys({\n press: 'ArrowRight',\n });\n\n expect(document.activeElement === actionButton2).to.be.true;\n\n // expect the focused element to have a tabindex of 0 and everyone else to be -1\n expect(actionButton2.tabIndex).to.equal(0);\n expect(actionButton1.tabIndex).to.equal(-1);\n expect(actionButton3.tabIndex).to.equal(-1);\n expect(actionMenu.tabIndex).to.equal(-1);\n\n await sendKeys({\n press: 'ArrowRight',\n });\n\n expect(document.activeElement === actionButton3).to.be.true;\n\n // expect the focused element to have a tabindex of 0 and everyone else to be -1\n expect(actionButton3.tabIndex).to.equal(0);\n expect(actionButton2.tabIndex).to.equal(-1);\n expect(actionButton1.tabIndex).to.equal(-1);\n expect(actionMenu.tabIndex).to.equal(-1);\n\n await sendKeys({\n press: 'ArrowRight',\n });\n\n expect(document.activeElement === actionMenu).to.be.true;\n\n // expect the action-button inside of the shadow root of the action-menu to have a tabindex of 0 and everyone else to be -1\n expect(actionButton3.tabIndex).to.equal(-1);\n expect(actionButton2.tabIndex).to.equal(-1);\n expect(actionButton1.tabIndex).to.equal(-1);\n expect(actionMenu.shadowRoot?.querySelector('sp-action-button')).to\n .exist;\n expect(\n (\n actionMenu.shadowRoot?.querySelector(\n 'sp-action-button'\n ) as ActionButton\n ).tabIndex\n ).to.equal(0);\n });\n});\n\ndescribe('tabIndex is cached properly', () => {\n it('cache is managed properly', async () => {\n const menuEl = await fixture<ActionMenu>(html`\n <sp-action-menu label=\"More Actions\">\n <sp-menu-item>One</sp-menu-item>\n <sp-menu-item>Two</sp-menu-item>\n <sp-menu-item>Three</sp-menu-item>\n </sp-action-menu>\n `);\n\n expect(menuEl.tabIndex).to.equal(0);\n expect(menuEl.focusElement?.tabIndex).to.equal(0);\n\n menuEl.tabIndex = 1;\n\n await elementUpdated(menuEl);\n\n expect(menuEl.tabIndex).to.equal(1);\n expect(menuEl.focusElement?.tabIndex).to.equal(1);\n\n menuEl.disabled = true;\n\n await elementUpdated(menuEl);\n\n expect(menuEl.tabIndex).to.equal(-1);\n expect(menuEl.focusElement?.tabIndex).to.equal(-1);\n\n menuEl.tabIndex = 2;\n\n await elementUpdated(menuEl);\n\n expect(menuEl.tabIndex).to.equal(-1);\n expect(menuEl.focusElement?.tabIndex).to.equal(-1);\n\n menuEl.disabled = false;\n\n await elementUpdated(menuEl);\n\n expect(menuEl.tabIndex).to.equal(2);\n expect(menuEl.focusElement?.tabIndex).to.equal(2);\n });\n});\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["/*\nCopyright 2020 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\nimport '@spectrum-web-components/action-button/sp-action-button.js';\nimport { ActionButton } from '@spectrum-web-components/action-button';\nimport '@spectrum-web-components/action-group/sp-action-group.js';\nimport { ActionGroup } from '@spectrum-web-components/action-group';\nimport { ActionMenu } from '@spectrum-web-components/action-menu';\nimport '@spectrum-web-components/tabs/sp-tab-panel.js';\nimport '@spectrum-web-components/tabs/sp-tab.js';\nimport '@spectrum-web-components/tabs/sp-tabs.js';\nimport '@spectrum-web-components/action-menu/sp-action-menu.js';\nimport '@spectrum-web-components/menu/sp-menu.js';\nimport '@spectrum-web-components/menu/sp-menu-item.js';\nimport { Tab, TabPanel, Tabs } from '@spectrum-web-components/tabs';\nimport { elementUpdated, expect, fixture, nextFrame } from '@open-wc/testing';\nimport { html } from '@spectrum-web-components/base';\nimport { sendKeys } from '@web/test-runner-commands';\nimport { sendMouse } from '../../../test/plugins/browser.js';\n\nconst createTabs = async (): Promise<Tabs> => {\n const tabs = await fixture<Tabs>(html`\n <sp-tabs selected=\"second\">\n <sp-tab label=\"Tab 1\" value=\"first\"></sp-tab>\n <sp-tab label=\"Tab 2\" value=\"second\"></sp-tab>\n <sp-tab label=\"Tab 3\" value=\"third\"></sp-tab>\n <sp-tab-panel value=\"first\">\n <sp-action-group selects=\"single\">\n <sp-action-button selected value=\"1\">\n Single Button 1\n </sp-action-button>\n <sp-action-button value=\"2\">\n Single Button 2\n </sp-action-button>\n <sp-action-button value=\"3\">\n Single Button 3\n </sp-action-button>\n </sp-action-group>\n </sp-tab-panel>\n <sp-tab-panel value=\"second\">\n <sp-action-group selects=\"multiple\">\n <sp-action-button value=\"1\">\n Multiple Button 1\n </sp-action-button>\n <sp-action-button selected value=\"2\">\n Multiple Button 2\n </sp-action-button>\n <sp-action-button selected value=\"3\">\n Multiple Button 3\n </sp-action-button>\n </sp-action-group>\n </sp-tab-panel>\n <sp-tab-panel value=\"third\">\n <sp-action-group>\n <sp-action-button value=\"1\">None Button 1</sp-action-button>\n <sp-action-button value=\"2\">None Button 2</sp-action-button>\n <sp-action-button selected value=\"3\">\n None Button 3\n </sp-action-button>\n </sp-action-group>\n </sp-tab-panel>\n </sp-tabs>\n `);\n await elementUpdated(tabs);\n return tabs;\n};\n\nconst createGroup = async (): Promise<ActionGroup> => {\n const group = await fixture<ActionGroup>(html`\n <sp-action-group>\n <sp-action-button>Button 1</sp-action-button>\n <sp-action-button>Longer Button 2</sp-action-button>\n <sp-action-button>Short 3</sp-action-button>\n <sp-action-menu label=\"More Actions\">\n <sp-menu-item>One</sp-menu-item>\n <sp-menu-item>Two</sp-menu-item>\n <sp-menu-item>Three</sp-menu-item>\n <sp-menu-item>\n Select some items\n <sp-menu slot=\"submenu\" selects=\"multiple\">\n <sp-menu-item>A</sp-menu-item>\n <sp-menu-item selected>B</sp-menu-item>\n <sp-menu-item>C</sp-menu-item>\n </sp-menu>\n </sp-menu-item>\n </sp-action-menu>\n </sp-action-group>\n `);\n await elementUpdated(group);\n return group;\n};\n\ndescribe('Action Group inside of Tabs', () => {\n it('accurately navigates the desired element', async () => {\n const el = await createTabs();\n const tab1 = el.querySelector('sp-tab[value=\"first\"]') as Tab;\n const tab2 = el.querySelector('sp-tab[value=\"second\"]');\n const tab3 = el.querySelector('sp-tab[value=\"third\"]') as Tab;\n const tabPanel1 = el.querySelector(\n 'sp-tab-panel[value=\"first\"]'\n ) as TabPanel;\n const tabPanel2 = el.querySelector(\n 'sp-tab-panel[value=\"second\"]'\n ) as TabPanel;\n const tabPanel3 = el.querySelector(\n 'sp-tab-panel[value=\"third\"]'\n ) as TabPanel;\n const actionGroup1 = tabPanel1.querySelector(\n 'sp-action-group'\n ) as ActionGroup;\n const actionGroup2 = tabPanel2.querySelector(\n 'sp-action-group'\n ) as ActionGroup;\n const actionGroup3 = tabPanel3.querySelector(\n 'sp-action-group'\n ) as ActionGroup;\n const actionButton1 = actionGroup1.querySelector(\n '[selected]'\n ) as ActionButton;\n const actionButton2 = actionGroup2.querySelector(\n '[selected]'\n ) as ActionButton;\n const actionButton3 = actionGroup3.querySelector(\n '[selected]'\n ) as ActionButton;\n\n el.focus();\n expect(el.contains(document.activeElement)).to.be.true;\n expect(document.activeElement === tab2).to.be.true;\n\n actionGroup2.focus();\n expect(document.activeElement === actionButton2).to.be.true;\n\n await nextFrame();\n await sendKeys({\n press: 'ArrowLeft',\n });\n\n expect(document.activeElement === tab1).to.be.false;\n expect(actionGroup2.contains(document.activeElement)).to.be.true;\n\n el.focus();\n expect(document.activeElement === tab2).to.be.true;\n\n await sendKeys({\n press: 'ArrowRight',\n });\n\n expect(document.activeElement === tab3).to.be.true;\n\n await sendKeys({\n press: 'Enter',\n });\n\n expect(document.activeElement === tab3).to.be.true;\n\n actionGroup3.focus();\n expect(document.activeElement === actionButton3).to.be.true;\n\n await sendKeys({\n press: 'ArrowLeft',\n });\n\n expect(document.activeElement === tab2).to.be.false;\n expect(actionGroup3.contains(document.activeElement)).to.be.true;\n\n const boundingRect = tab1.getBoundingClientRect();\n // tab1.click() doesn't current reach into the focus management here.\n await sendMouse({\n steps: [\n {\n type: 'click',\n position: [\n boundingRect.left + boundingRect.width / 2,\n boundingRect.top + boundingRect.height / 2,\n ],\n },\n ],\n });\n expect(document.activeElement === tab1).to.be.true;\n\n actionGroup1.focus();\n expect(document.activeElement === actionButton1).to.be.true;\n\n await sendKeys({\n press: 'ArrowRight',\n });\n\n expect(document.activeElement === tab2).to.be.false;\n expect(actionGroup1.contains(document.activeElement)).to.be.true;\n });\n});\n\ndescribe('Action Menu inside of Action Group', () => {\n it('accurately manages the tabindex of all the elements', async () => {\n const el = await createGroup();\n const actionButton1 = el.querySelector(\n 'sp-action-button:nth-child(1)'\n ) as ActionButton;\n const actionButton2 = el.querySelector(\n 'sp-action-button:nth-child(2)'\n ) as ActionButton;\n const actionButton3 = el.querySelector(\n 'sp-action-button:nth-child(3)'\n ) as ActionButton;\n const actionMenu = el.querySelector('sp-action-menu') as ActionMenu;\n\n el.focus();\n expect(document.activeElement === actionButton1).to.be.true;\n\n await sendKeys({\n press: 'ArrowRight',\n });\n\n expect(document.activeElement === actionButton2).to.be.true;\n\n // expect the focused element to have a tabindex of 0 and everyone else to be -1\n expect(actionButton2.tabIndex).to.equal(0);\n expect(actionButton1.tabIndex).to.equal(-1);\n expect(actionButton3.tabIndex).to.equal(-1);\n expect(actionMenu.tabIndex).to.equal(-1);\n\n await sendKeys({\n press: 'ArrowRight',\n });\n\n expect(document.activeElement === actionButton3).to.be.true;\n\n // expect the focused element to have a tabindex of 0 and everyone else to be -1\n expect(actionButton3.tabIndex).to.equal(0);\n expect(actionButton2.tabIndex).to.equal(-1);\n expect(actionButton1.tabIndex).to.equal(-1);\n expect(actionMenu.tabIndex).to.equal(-1);\n\n await sendKeys({\n press: 'ArrowRight',\n });\n\n expect(document.activeElement === actionMenu).to.be.true;\n\n // expect the action-button inside of the shadow root of the action-menu to have a tabindex of 0 and everyone else to be -1\n expect(actionButton3.tabIndex).to.equal(-1);\n expect(actionButton2.tabIndex).to.equal(-1);\n expect(actionButton1.tabIndex).to.equal(-1);\n expect(actionMenu.shadowRoot?.querySelector('sp-action-button')).to\n .exist;\n expect(\n (\n actionMenu.shadowRoot?.querySelector(\n 'sp-action-button'\n ) as ActionButton\n ).tabIndex\n ).to.equal(0);\n });\n});\n\ndescribe('tabIndex is cached properly', () => {\n it('cache is managed properly', async () => {\n const menuEl = await fixture<ActionMenu>(html`\n <sp-action-menu label=\"More Actions\">\n <sp-menu-item>One</sp-menu-item>\n <sp-menu-item>Two</sp-menu-item>\n <sp-menu-item>Three</sp-menu-item>\n </sp-action-menu>\n `);\n\n expect(\n menuEl.focusElement?.tabIndex,\n 'button tabindex before disabling'\n ).to.equal(0);\n\n menuEl.disabled = true;\n\n await elementUpdated(menuEl);\n\n expect(\n menuEl.focusElement?.tabIndex,\n 'button tabindex after disabling'\n ).to.equal(-1);\n\n menuEl.disabled = false;\n\n await elementUpdated(menuEl);\n\n expect(\n menuEl.focusElement?.tabIndex,\n 'button tabindex after setting to 0'\n ).to.equal(0);\n });\n});\n"],
5
+ "mappings": ";AAWA,OAAO;AAEP,OAAO;AAGP,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AAEP,SAAS,gBAAgB,QAAQ,SAAS,iBAAiB;AAC3D,SAAS,YAAY;AACrB,SAAS,gBAAgB;AACzB,SAAS,iBAAiB;AAE1B,MAAM,aAAa,YAA2B;AAC1C,QAAM,OAAO,MAAM,QAAc;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,KAyChC;AACD,QAAM,eAAe,IAAI;AACzB,SAAO;AACX;AAEA,MAAM,cAAc,YAAkC;AAClD,QAAM,QAAQ,MAAM,QAAqB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,KAmBxC;AACD,QAAM,eAAe,KAAK;AAC1B,SAAO;AACX;AAEA,SAAS,+BAA+B,MAAM;AAC1C,KAAG,4CAA4C,YAAY;AACvD,UAAM,KAAK,MAAM,WAAW;AAC5B,UAAM,OAAO,GAAG,cAAc,uBAAuB;AACrD,UAAM,OAAO,GAAG,cAAc,wBAAwB;AACtD,UAAM,OAAO,GAAG,cAAc,uBAAuB;AACrD,UAAM,YAAY,GAAG;AAAA,MACjB;AAAA,IACJ;AACA,UAAM,YAAY,GAAG;AAAA,MACjB;AAAA,IACJ;AACA,UAAM,YAAY,GAAG;AAAA,MACjB;AAAA,IACJ;AACA,UAAM,eAAe,UAAU;AAAA,MAC3B;AAAA,IACJ;AACA,UAAM,eAAe,UAAU;AAAA,MAC3B;AAAA,IACJ;AACA,UAAM,eAAe,UAAU;AAAA,MAC3B;AAAA,IACJ;AACA,UAAM,gBAAgB,aAAa;AAAA,MAC/B;AAAA,IACJ;AACA,UAAM,gBAAgB,aAAa;AAAA,MAC/B;AAAA,IACJ;AACA,UAAM,gBAAgB,aAAa;AAAA,MAC/B;AAAA,IACJ;AAEA,OAAG,MAAM;AACT,WAAO,GAAG,SAAS,SAAS,aAAa,CAAC,EAAE,GAAG,GAAG;AAClD,WAAO,SAAS,kBAAkB,IAAI,EAAE,GAAG,GAAG;AAE9C,iBAAa,MAAM;AACnB,WAAO,SAAS,kBAAkB,aAAa,EAAE,GAAG,GAAG;AAEvD,UAAM,UAAU;AAChB,UAAM,SAAS;AAAA,MACX,OAAO;AAAA,IACX,CAAC;AAED,WAAO,SAAS,kBAAkB,IAAI,EAAE,GAAG,GAAG;AAC9C,WAAO,aAAa,SAAS,SAAS,aAAa,CAAC,EAAE,GAAG,GAAG;AAE5D,OAAG,MAAM;AACT,WAAO,SAAS,kBAAkB,IAAI,EAAE,GAAG,GAAG;AAE9C,UAAM,SAAS;AAAA,MACX,OAAO;AAAA,IACX,CAAC;AAED,WAAO,SAAS,kBAAkB,IAAI,EAAE,GAAG,GAAG;AAE9C,UAAM,SAAS;AAAA,MACX,OAAO;AAAA,IACX,CAAC;AAED,WAAO,SAAS,kBAAkB,IAAI,EAAE,GAAG,GAAG;AAE9C,iBAAa,MAAM;AACnB,WAAO,SAAS,kBAAkB,aAAa,EAAE,GAAG,GAAG;AAEvD,UAAM,SAAS;AAAA,MACX,OAAO;AAAA,IACX,CAAC;AAED,WAAO,SAAS,kBAAkB,IAAI,EAAE,GAAG,GAAG;AAC9C,WAAO,aAAa,SAAS,SAAS,aAAa,CAAC,EAAE,GAAG,GAAG;AAE5D,UAAM,eAAe,KAAK,sBAAsB;AAEhD,UAAM,UAAU;AAAA,MACZ,OAAO;AAAA,QACH;AAAA,UACI,MAAM;AAAA,UACN,UAAU;AAAA,YACN,aAAa,OAAO,aAAa,QAAQ;AAAA,YACzC,aAAa,MAAM,aAAa,SAAS;AAAA,UAC7C;AAAA,QACJ;AAAA,MACJ;AAAA,IACJ,CAAC;AACD,WAAO,SAAS,kBAAkB,IAAI,EAAE,GAAG,GAAG;AAE9C,iBAAa,MAAM;AACnB,WAAO,SAAS,kBAAkB,aAAa,EAAE,GAAG,GAAG;AAEvD,UAAM,SAAS;AAAA,MACX,OAAO;AAAA,IACX,CAAC;AAED,WAAO,SAAS,kBAAkB,IAAI,EAAE,GAAG,GAAG;AAC9C,WAAO,aAAa,SAAS,SAAS,aAAa,CAAC,EAAE,GAAG,GAAG;AAAA,EAChE,CAAC;AACL,CAAC;AAED,SAAS,sCAAsC,MAAM;AACjD,KAAG,uDAAuD,YAAY;AA1M1E;AA2MQ,UAAM,KAAK,MAAM,YAAY;AAC7B,UAAM,gBAAgB,GAAG;AAAA,MACrB;AAAA,IACJ;AACA,UAAM,gBAAgB,GAAG;AAAA,MACrB;AAAA,IACJ;AACA,UAAM,gBAAgB,GAAG;AAAA,MACrB;AAAA,IACJ;AACA,UAAM,aAAa,GAAG,cAAc,gBAAgB;AAEpD,OAAG,MAAM;AACT,WAAO,SAAS,kBAAkB,aAAa,EAAE,GAAG,GAAG;AAEvD,UAAM,SAAS;AAAA,MACX,OAAO;AAAA,IACX,CAAC;AAED,WAAO,SAAS,kBAAkB,aAAa,EAAE,GAAG,GAAG;AAGvD,WAAO,cAAc,QAAQ,EAAE,GAAG,MAAM,CAAC;AACzC,WAAO,cAAc,QAAQ,EAAE,GAAG,MAAM,EAAE;AAC1C,WAAO,cAAc,QAAQ,EAAE,GAAG,MAAM,EAAE;AAC1C,WAAO,WAAW,QAAQ,EAAE,GAAG,MAAM,EAAE;AAEvC,UAAM,SAAS;AAAA,MACX,OAAO;AAAA,IACX,CAAC;AAED,WAAO,SAAS,kBAAkB,aAAa,EAAE,GAAG,GAAG;AAGvD,WAAO,cAAc,QAAQ,EAAE,GAAG,MAAM,CAAC;AACzC,WAAO,cAAc,QAAQ,EAAE,GAAG,MAAM,EAAE;AAC1C,WAAO,cAAc,QAAQ,EAAE,GAAG,MAAM,EAAE;AAC1C,WAAO,WAAW,QAAQ,EAAE,GAAG,MAAM,EAAE;AAEvC,UAAM,SAAS;AAAA,MACX,OAAO;AAAA,IACX,CAAC;AAED,WAAO,SAAS,kBAAkB,UAAU,EAAE,GAAG,GAAG;AAGpD,WAAO,cAAc,QAAQ,EAAE,GAAG,MAAM,EAAE;AAC1C,WAAO,cAAc,QAAQ,EAAE,GAAG,MAAM,EAAE;AAC1C,WAAO,cAAc,QAAQ,EAAE,GAAG,MAAM,EAAE;AAC1C,YAAO,gBAAW,eAAX,mBAAuB,cAAc,mBAAmB,EAAE,GAC5D;AACL;AAAA,QAEQ,gBAAW,eAAX,mBAAuB;AAAA,QACnB;AAAA,SAEN;AAAA,IACN,EAAE,GAAG,MAAM,CAAC;AAAA,EAChB,CAAC;AACL,CAAC;AAED,SAAS,+BAA+B,MAAM;AAC1C,KAAG,6BAA6B,YAAY;AAzQhD;AA0QQ,UAAM,SAAS,MAAM,QAAoB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAMxC;AAED;AAAA,OACI,YAAO,iBAAP,mBAAqB;AAAA,MACrB;AAAA,IACJ,EAAE,GAAG,MAAM,CAAC;AAEZ,WAAO,WAAW;AAElB,UAAM,eAAe,MAAM;AAE3B;AAAA,OACI,YAAO,iBAAP,mBAAqB;AAAA,MACrB;AAAA,IACJ,EAAE,GAAG,MAAM,EAAE;AAEb,WAAO,WAAW;AAElB,UAAM,eAAe,MAAM;AAE3B;AAAA,OACI,YAAO,iBAAP,mBAAqB;AAAA,MACrB;AAAA,IACJ,EAAE,GAAG,MAAM,CAAC;AAAA,EAChB,CAAC;AACL,CAAC;",
6
6
  "names": []
7
7
  }
package/src/Color.d.ts DELETED
@@ -1,46 +0,0 @@
1
- import type { ReactiveElement } from 'lit';
2
- import { HSL, HSLA, HSV, HSVA, RGB, RGBA, TinyColor } from '@ctrl/tinycolor';
3
- export type { HSL, HSLA, HSV, HSVA, RGB, RGBA, TinyColor };
4
- export type ColorValue = string | number | TinyColor | HSVA | HSV | RGB | RGBA | HSL | HSLA;
5
- export declare const extractHueAndSaturationRegExp: RegExp;
6
- export declare const replaceHueAndSaturationRegExp: RegExp;
7
- export declare const replaceHueRegExp: RegExp;
8
- export declare class ColorController {
9
- protected host: ReactiveElement;
10
- protected applyColorToState: ({ h, s, v, }: {
11
- h: number;
12
- s: number;
13
- v: number;
14
- }) => void;
15
- protected extractColorFromState: (controller: ColorController) => ColorValue;
16
- protected setColorProcess(currentColor: TinyColor, nextColor: ColorValue, format: string, isString: boolean): void;
17
- protected setColorMaintainHue(currentColor: TinyColor, nextColor: ColorValue, format: string, isString: boolean): void;
18
- protected setColorMaintainSaturation(currentColor: TinyColor, nextColor: ColorValue, format: string, isString: boolean): void;
19
- protected maintains: 'hue' | 'saturation';
20
- private saturation;
21
- constructor(host: ReactiveElement, { applyColorToState, extractColorFromState, maintains, }: {
22
- applyColorToState({ h, s, v, }: {
23
- h: number;
24
- s: number;
25
- v: number;
26
- }): void;
27
- extractColorFromState(controller: ColorController): ColorValue;
28
- maintains?: 'hue' | 'saturation';
29
- });
30
- applyColorFromState(): void;
31
- get hue(): number;
32
- set hue(value: number);
33
- private _hue;
34
- protected getColorProcesses: Record<string, (color: TinyColor, isString: boolean) => ColorValue>;
35
- get value(): ColorValue;
36
- get color(): ColorValue;
37
- set color(color: ColorValue);
38
- private _color;
39
- getColor(format: string): ColorValue;
40
- setColor(color: TinyColor): void;
41
- getHslString(): string;
42
- private _previousColor;
43
- savePreviousColor(): void;
44
- restorePreviousColor(): void;
45
- private _format;
46
- }
package/src/Color.dev.js DELETED
@@ -1,198 +0,0 @@
1
- "use strict";
2
- import { TinyColor } from "@ctrl/tinycolor";
3
- export const extractHueAndSaturationRegExp = /^hs[v|l]a?\s?\((\d{1,3}\.?\d*?),?\s?(\d{1,3})/;
4
- export const replaceHueAndSaturationRegExp = /(^hs[v|l]a?\s?\()\d{1,3}\.?\d*?(,?\s?)\d{1,3}/;
5
- export const replaceHueRegExp = /(^hs[v|l]a?\()\d{1,3}/;
6
- const getHexValue = (color, isString) => isString ? color.toHexString() : color.toHex();
7
- export class ColorController {
8
- constructor(host, {
9
- applyColorToState,
10
- extractColorFromState,
11
- maintains
12
- }) {
13
- this.maintains = "hue";
14
- this._hue = 0;
15
- this.getColorProcesses = {
16
- rgb: (color, isString) => isString ? color.toRgbString() : color.toRgb(),
17
- prgb: (color, isString) => isString ? color.toPercentageRgbString() : color.toPercentageRgb(),
18
- hex8: (color, isString) => isString ? color.toHex8String() : color.toHex8(),
19
- name: (color) => color.toName() || color.toRgbString(),
20
- hsl: (color, isString) => {
21
- if (this.maintains === "hue") {
22
- if (isString) {
23
- const hslString = color.toHslString();
24
- return hslString.replace(replaceHueRegExp, `$1${this.hue}`);
25
- } else {
26
- const { s, l, a } = color.toHsl();
27
- return { h: this.hue, s, l, a };
28
- }
29
- } else {
30
- if (isString) {
31
- const hslString = color.toHslString();
32
- return hslString.replace(
33
- replaceHueAndSaturationRegExp,
34
- `$1${this.hue}$2${this.saturation}`
35
- );
36
- } else {
37
- const { s, l, a } = color.toHsl();
38
- return { h: this.hue, s, l, a };
39
- }
40
- }
41
- },
42
- hsv: (color, isString) => {
43
- if (this.maintains === "hue") {
44
- if (isString) {
45
- const hsvString = color.toHsvString();
46
- return hsvString.replace(replaceHueRegExp, `$1${this.hue}`);
47
- } else {
48
- const { s, v, a } = color.toHsv();
49
- return { h: this.hue, s, v, a };
50
- }
51
- } else {
52
- if (isString) {
53
- const hsvString = color.toHsvString();
54
- return hsvString.replace(
55
- replaceHueAndSaturationRegExp,
56
- `$1${this.hue}$2${this.saturation}`
57
- );
58
- } else {
59
- const { s, v, a } = color.toHsv();
60
- return { h: this.hue, s, v, a };
61
- }
62
- }
63
- },
64
- hex: getHexValue,
65
- hex3: getHexValue,
66
- hex4: getHexValue,
67
- hex6: getHexValue
68
- };
69
- this._color = new TinyColor({ h: 0, s: 1, v: 1 });
70
- this._previousColor = new TinyColor({ h: 0, s: 1, v: 1 });
71
- this._format = {
72
- format: "",
73
- isString: false
74
- };
75
- this.host = host;
76
- this.applyColorToState = applyColorToState;
77
- this.extractColorFromState = extractColorFromState;
78
- this.maintains = maintains || this.maintains;
79
- }
80
- setColorProcess(currentColor, nextColor, format, isString) {
81
- if (this.maintains === "hue") {
82
- this.setColorMaintainHue(currentColor, nextColor, format, isString);
83
- } else if (this.maintains === "saturation") {
84
- this.setColorMaintainSaturation(
85
- currentColor,
86
- nextColor,
87
- format,
88
- isString
89
- );
90
- }
91
- }
92
- setColorMaintainHue(currentColor, nextColor, format, isString) {
93
- const { h, s, v } = this._color.toHsv();
94
- let originalHue = void 0;
95
- if (isString && format.startsWith("hs")) {
96
- const values = extractHueAndSaturationRegExp.exec(
97
- nextColor
98
- );
99
- if (values !== null) {
100
- const [, h2] = values;
101
- originalHue = Number(h2);
102
- }
103
- } else if (!isString && format.startsWith("hs")) {
104
- const colorInput = currentColor.originalInput;
105
- const colorValues = Object.values(colorInput);
106
- originalHue = colorValues[0];
107
- }
108
- this.hue = originalHue || h;
109
- this.applyColorToState({ h, s, v });
110
- }
111
- setColorMaintainSaturation(currentColor, nextColor, format, isString) {
112
- if (isString && format.startsWith("hs")) {
113
- const values = extractHueAndSaturationRegExp.exec(
114
- nextColor
115
- );
116
- if (values !== null) {
117
- const [, h, s] = values;
118
- this.hue = Number(h);
119
- this.saturation = Number(s);
120
- }
121
- } else if (!isString && format.startsWith("hs")) {
122
- const colorInput = currentColor.originalInput;
123
- const colorValues = Object.values(colorInput);
124
- this.hue = colorValues[0];
125
- this.saturation = colorValues[1];
126
- } else {
127
- const { h } = currentColor.toHsv();
128
- this.hue = h;
129
- }
130
- this.applyColorToState(currentColor.toHsv());
131
- }
132
- applyColorFromState() {
133
- this._color = new TinyColor(this.extractColorFromState(this));
134
- }
135
- get hue() {
136
- return this._hue;
137
- }
138
- set hue(value) {
139
- const hue = Math.min(360, Math.max(0, value));
140
- if (hue === this.hue) {
141
- return;
142
- }
143
- const oldValue = this.hue;
144
- const { s, v } = this._color.toHsv();
145
- this._color = new TinyColor({ h: hue, s, v });
146
- this._hue = hue;
147
- this.host.requestUpdate("hue", oldValue);
148
- }
149
- /* c8 ignore next 3 */
150
- get value() {
151
- return this.color;
152
- }
153
- get color() {
154
- return this.getColorProcesses[this._format.format || "hex"](
155
- this._color,
156
- this._format.isString
157
- );
158
- }
159
- set color(color) {
160
- if (color === this.color) {
161
- return;
162
- }
163
- const oldValue = this._color;
164
- this._color = new TinyColor(color);
165
- const format = this._color.format;
166
- let isString = typeof color === "string" || color instanceof String;
167
- if (format.startsWith("hex")) {
168
- isString = color.startsWith("#");
169
- }
170
- this._format = {
171
- format,
172
- isString
173
- };
174
- this.setColorProcess(this._color, color, format, isString);
175
- this.host.requestUpdate("color", oldValue);
176
- }
177
- getColor(format) {
178
- const formatOptions = {
179
- hsl: "toHsl"
180
- };
181
- return this._color[formatOptions[format]]();
182
- }
183
- setColor(color) {
184
- this._color = color;
185
- const isString = typeof this._color.originalInput === "string" || this._color.originalInput instanceof String;
186
- this.setColorProcess(this._color, color, this._color.format, isString);
187
- }
188
- getHslString() {
189
- return this._color.toHslString();
190
- }
191
- savePreviousColor() {
192
- this._previousColor = this._color.clone();
193
- }
194
- restorePreviousColor() {
195
- this.setColor(this._previousColor);
196
- }
197
- }
198
- //# sourceMappingURL=Color.dev.js.map