@spectrum-web-components/color-area 0.43.0 → 0.45.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.
- package/README.md +0 -2
- package/custom-elements.json +0 -16
- package/package.json +7 -7
- package/src/ColorArea.d.ts +0 -1
- package/src/ColorArea.dev.js +3 -16
- package/src/ColorArea.dev.js.map +2 -2
- package/src/ColorArea.js +9 -9
- package/src/ColorArea.js.map +3 -3
- package/test/color-area.test.js +102 -147
- package/test/color-area.test.js.map +2 -2
package/README.md
CHANGED
|
@@ -69,8 +69,6 @@ An `<sp-color-area>`’s height and width can be customized appropriately for it
|
|
|
69
69
|
An `<sp-color-area>` renders accessible labels for each axis: _"saturation"_ and _"luminosity"_.
|
|
70
70
|
Specify `label-x` and `label-y` attributes to override these defaults.
|
|
71
71
|
|
|
72
|
-
The `label` attribute is **deprecated** in favor of separately labeling each axis.
|
|
73
|
-
|
|
74
72
|
```html
|
|
75
73
|
<sp-color-area
|
|
76
74
|
label-x="Color intensity"
|
package/custom-elements.json
CHANGED
|
@@ -64,15 +64,6 @@
|
|
|
64
64
|
"attribute": "focused",
|
|
65
65
|
"reflects": true
|
|
66
66
|
},
|
|
67
|
-
{
|
|
68
|
-
"kind": "field",
|
|
69
|
-
"name": "label",
|
|
70
|
-
"type": {
|
|
71
|
-
"text": "string | undefined"
|
|
72
|
-
},
|
|
73
|
-
"privacy": "public",
|
|
74
|
-
"attribute": "label"
|
|
75
|
-
},
|
|
76
67
|
{
|
|
77
68
|
"kind": "field",
|
|
78
69
|
"name": "labelX",
|
|
@@ -528,13 +519,6 @@
|
|
|
528
519
|
"default": "false",
|
|
529
520
|
"fieldName": "focused"
|
|
530
521
|
},
|
|
531
|
-
{
|
|
532
|
-
"name": "label",
|
|
533
|
-
"type": {
|
|
534
|
-
"text": "string | undefined"
|
|
535
|
-
},
|
|
536
|
-
"fieldName": "label"
|
|
537
|
-
},
|
|
538
522
|
{
|
|
539
523
|
"name": "label-x",
|
|
540
524
|
"type": {
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@spectrum-web-components/color-area",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.45.0",
|
|
4
4
|
"publishConfig": {
|
|
5
5
|
"access": "public"
|
|
6
6
|
},
|
|
@@ -62,11 +62,11 @@
|
|
|
62
62
|
],
|
|
63
63
|
"dependencies": {
|
|
64
64
|
"@ctrl/tinycolor": "^4.0.3",
|
|
65
|
-
"@spectrum-web-components/base": "^0.
|
|
66
|
-
"@spectrum-web-components/color-handle": "^0.
|
|
67
|
-
"@spectrum-web-components/opacity-checkerboard": "^0.
|
|
68
|
-
"@spectrum-web-components/reactive-controllers": "^0.
|
|
69
|
-
"@spectrum-web-components/shared": "^0.
|
|
65
|
+
"@spectrum-web-components/base": "^0.45.0",
|
|
66
|
+
"@spectrum-web-components/color-handle": "^0.45.0",
|
|
67
|
+
"@spectrum-web-components/opacity-checkerboard": "^0.45.0",
|
|
68
|
+
"@spectrum-web-components/reactive-controllers": "^0.45.0",
|
|
69
|
+
"@spectrum-web-components/shared": "^0.45.0"
|
|
70
70
|
},
|
|
71
71
|
"devDependencies": {
|
|
72
72
|
"@spectrum-css/colorarea": "^5.1.0"
|
|
@@ -77,5 +77,5 @@
|
|
|
77
77
|
"./sp-*.js",
|
|
78
78
|
"./**/*.dev.js"
|
|
79
79
|
],
|
|
80
|
-
"gitHead": "
|
|
80
|
+
"gitHead": "8cfbac84735f6b97180d39150b4849f0aa1f1a45"
|
|
81
81
|
}
|
package/src/ColorArea.d.ts
CHANGED
package/src/ColorArea.dev.js
CHANGED
|
@@ -318,19 +318,9 @@ export class ColorArea extends SpectrumElement {
|
|
|
318
318
|
}
|
|
319
319
|
render() {
|
|
320
320
|
const { width = 0, height = 0 } = this.boundingClientRect || {};
|
|
321
|
-
if (true) {
|
|
322
|
-
if (this.label) {
|
|
323
|
-
window.__swc.warn(
|
|
324
|
-
this,
|
|
325
|
-
`The "label" property in <${this.localName}> has been deprecated and will be removed in a future release. Please leverage "labelX" and "labelY" instead.`,
|
|
326
|
-
"https://opensource.adobe.com/spectrum-web-components/components/color-area/#labels",
|
|
327
|
-
{ level: "deprecation" }
|
|
328
|
-
);
|
|
329
|
-
}
|
|
330
|
-
}
|
|
331
321
|
const isMobile = isAndroid() || isIOS();
|
|
332
322
|
const defaultAriaLabel = "Color Picker";
|
|
333
|
-
const ariaLabel =
|
|
323
|
+
const ariaLabel = defaultAriaLabel;
|
|
334
324
|
const ariaRoleDescription = ifDefined(
|
|
335
325
|
isMobile ? void 0 : "2d slider"
|
|
336
326
|
);
|
|
@@ -389,7 +379,7 @@ export class ColorArea extends SpectrumElement {
|
|
|
389
379
|
type="range"
|
|
390
380
|
class="slider"
|
|
391
381
|
name="x"
|
|
392
|
-
aria-label=${isMobile ? ariaLabelX : ariaLabel}
|
|
382
|
+
aria-label=${isMobile ? ariaLabelX : `${ariaLabelX} ${ariaLabel}`}
|
|
393
383
|
aria-roledescription=${ariaRoleDescription}
|
|
394
384
|
aria-orientation="horizontal"
|
|
395
385
|
aria-valuetext=${isMobile ? ariaValueX : `${ariaValueX}, ${ariaLabelX}${this._valueChanged ? "" : `, ${ariaValueY}, ${ariaLabelY}`}`}
|
|
@@ -407,7 +397,7 @@ export class ColorArea extends SpectrumElement {
|
|
|
407
397
|
type="range"
|
|
408
398
|
class="slider"
|
|
409
399
|
name="y"
|
|
410
|
-
aria-label=${isMobile ? ariaLabelY : ariaLabel}
|
|
400
|
+
aria-label=${isMobile ? ariaLabelY : `${ariaLabelY} ${ariaLabel}`}
|
|
411
401
|
aria-roledescription=${ariaRoleDescription}
|
|
412
402
|
aria-orientation="vertical"
|
|
413
403
|
aria-valuetext=${isMobile ? ariaValueY : `${ariaValueY}, ${ariaLabelY}${this._valueChanged ? "" : `, ${ariaValueX}, ${ariaLabelX}`}`}
|
|
@@ -480,9 +470,6 @@ __decorateClass([
|
|
|
480
470
|
__decorateClass([
|
|
481
471
|
property({ type: Boolean, reflect: true })
|
|
482
472
|
], ColorArea.prototype, "focused", 2);
|
|
483
|
-
__decorateClass([
|
|
484
|
-
property({ type: String })
|
|
485
|
-
], ColorArea.prototype, "label", 2);
|
|
486
473
|
__decorateClass([
|
|
487
474
|
property({ type: String, attribute: "label-x" })
|
|
488
475
|
], ColorArea.prototype, "labelX", 2);
|
package/src/ColorArea.dev.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["ColorArea.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*/\n\nimport {\n CSSResultArray,\n html,\n PropertyValues,\n SpectrumElement,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n ifDefined,\n styleMap,\n} from '@spectrum-web-components/base/src/directives.js';\nimport {\n property,\n query,\n} from '@spectrum-web-components/base/src/decorators.js';\nimport { streamingListener } from '@spectrum-web-components/base/src/streaming-listener.js';\nimport { SWCResizeObserverEntry, WithSWCResizeObserver } from './types';\nimport type { ColorHandle } from '@spectrum-web-components/color-handle';\nimport '@spectrum-web-components/color-handle/sp-color-handle.js';\nimport {\n ColorController,\n ColorValue,\n} from '@spectrum-web-components/reactive-controllers/src/Color.js';\nimport { LanguageResolutionController } from '@spectrum-web-components/reactive-controllers/src/LanguageResolution.js';\nimport {\n isAndroid,\n isIOS,\n} from '@spectrum-web-components/shared/src/platform.js';\n\nimport styles from './color-area.css.js';\n\n/**\n * @element sp-color-area\n * @slot gradient - a custom gradient visually outlining the available color values\n * @fires input - The value of the Color Area has changed.\n * @fires change - An alteration to the value of the Color Area has been committed by the user.\n */\nexport class ColorArea extends SpectrumElement {\n public static override get styles(): CSSResultArray {\n return [styles];\n }\n\n @property({ type: String, reflect: true })\n public override dir!: 'ltr' | 'rtl';\n\n @property({ type: Boolean, reflect: true })\n public disabled = false;\n\n @property({ type: Boolean, reflect: true })\n public focused = false;\n\n @property({ type: String })\n public label: string | undefined;\n\n @property({ type: String, attribute: 'label-x' })\n public labelX = 'saturation';\n\n @property({ type: String, attribute: 'label-y' })\n public labelY = 'luminosity';\n\n @query('.handle')\n private handle!: ColorHandle;\n\n private languageResolver = new LanguageResolutionController(this);\n\n private colorController = new ColorController(this, {\n extractColorFromState: () => ({\n h: this.hue,\n s: this.x,\n v: this.y,\n }),\n applyColorToState: ({ s, v }) => {\n this._x = s;\n this._y = v;\n this.requestUpdate();\n },\n });\n\n @property({ type: Number })\n public get hue(): number {\n return this.colorController.hue;\n }\n\n public set hue(value: number) {\n this.colorController.hue = value;\n }\n\n @property({ type: String })\n public get value(): ColorValue {\n return this.colorController.color;\n }\n\n @property({ type: String })\n public get color(): ColorValue {\n return this.colorController.color;\n }\n\n public set color(color: ColorValue) {\n this.colorController.color = color;\n }\n\n @property({ attribute: false })\n private activeAxis = 'x';\n\n @property({ type: Number })\n public get x(): number {\n return this._x;\n }\n\n public set x(x: number) {\n if (x === this.x) {\n return;\n }\n const oldValue = this.x;\n if (this.inputX) {\n // Use the native `input[type='range']` control to validate this value after `firstUpdate`\n this.inputX.value = x.toString();\n this._x = this.inputX.valueAsNumber;\n } else {\n this._x = x;\n }\n this.requestUpdate('x', oldValue);\n this.colorController.applyColorFromState();\n }\n\n private _x = 1;\n\n @property({ type: Number })\n public get y(): number {\n return this._y;\n }\n\n public set y(y: number) {\n if (y === this.y) {\n return;\n }\n const oldValue = this.y;\n if (this.inputY) {\n // Use the native `input[type='range']` control to validate this value after `firstUpdate`\n this.inputY.value = y.toString();\n this._y = this.inputY.valueAsNumber;\n } else {\n this._y = y;\n }\n this.requestUpdate('y', oldValue);\n this.colorController.applyColorFromState();\n }\n\n private _y = 1;\n\n @property({ type: Number })\n public step = 0.01;\n\n @query('[name=\"x\"]')\n public inputX!: HTMLInputElement;\n\n @query('[name=\"y\"]')\n public inputY!: HTMLInputElement;\n\n private altered = 0;\n\n private activeKeys = new Set();\n\n private _valueChanged = false;\n\n public override focus(focusOptions: FocusOptions = {}): void {\n super.focus(focusOptions);\n this.forwardFocus();\n }\n\n private forwardFocus(): void {\n this.focused = this.hasVisibleFocusInTree();\n if (this.activeAxis === 'x') {\n this.inputX.focus();\n } else {\n this.inputY.focus();\n }\n }\n\n private handleFocus(): void {\n this.focused = true;\n this._valueChanged = false;\n }\n\n private handleBlur(): void {\n if (this._pointerDown) {\n return;\n }\n this.altered = 0;\n this.focused = false;\n this._valueChanged = false;\n }\n\n private handleKeydown(event: KeyboardEvent): void {\n const { code } = event;\n this.focused = true;\n this.altered = [event.shiftKey, event.ctrlKey, event.altKey].filter(\n (key) => !!key\n ).length;\n const isArrowKey =\n code.search('Arrow') === 0 ||\n code.search('Page') === 0 ||\n code.search('Home') === 0 ||\n code.search('End') === 0;\n if (isArrowKey) {\n event.preventDefault();\n this.activeKeys.add(code);\n this.handleKeypress();\n }\n }\n\n private handleKeypress(): void {\n let deltaX = 0;\n let deltaY = 0;\n const step = Math.max(this.step, this.altered * 5 * this.step);\n this.activeKeys.forEach((code) => {\n switch (code) {\n case 'ArrowUp':\n deltaY = step;\n break;\n case 'ArrowDown':\n deltaY = step * -1;\n break;\n case 'ArrowLeft':\n deltaX = this.step * (this.isLTR ? -1 : 1);\n break;\n case 'ArrowRight':\n deltaX = this.step * (this.isLTR ? 1 : -1);\n break;\n case 'PageUp':\n deltaY = step * 10;\n break;\n case 'PageDown':\n deltaY = step * -10;\n break;\n case 'Home':\n deltaX = step * (this.isLTR ? -10 : 10);\n break;\n case 'End':\n deltaX = step * (this.isLTR ? 10 : -10);\n break;\n /* c8 ignore next 2 */\n default:\n break;\n }\n });\n if (deltaX != 0) {\n this.activeAxis = 'x';\n this.inputX.focus();\n } else if (deltaY != 0) {\n this.activeAxis = 'y';\n this.inputY.focus();\n }\n this.x = Math.min(1, Math.max(this.x + deltaX, 0));\n this.y = Math.min(1, Math.max(this.y + deltaY, 0));\n\n this.colorController.savePreviousColor();\n this.colorController.applyColorFromState();\n\n if (deltaX != 0 || deltaY != 0) {\n this._valueChanged = true;\n this.dispatchEvent(\n new Event('input', {\n bubbles: true,\n composed: true,\n })\n );\n const applyDefault = this.dispatchEvent(\n new Event('change', {\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n if (!applyDefault) {\n this.colorController.restorePreviousColor();\n }\n }\n }\n\n private handleKeyup(event: KeyboardEvent): void {\n event.preventDefault();\n const { code } = event;\n this.activeKeys.delete(code);\n }\n\n private handleInput(event: Event & { target: HTMLInputElement }): void {\n const { valueAsNumber, name } = event.target;\n\n this[name as 'x' | 'y'] = valueAsNumber;\n this.colorController.applyColorFromState();\n }\n\n private handleChange(event: Event & { target: HTMLInputElement }): void {\n this.handleInput(event);\n this.dispatchEvent(\n new Event('change', {\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n }\n\n private boundingClientRect!: DOMRect;\n private _pointerDown = false;\n\n private handlePointerdown(event: PointerEvent): void {\n if (event.button !== 0) {\n event.preventDefault();\n return;\n }\n this._pointerDown = true;\n this.colorController.savePreviousColor();\n this.boundingClientRect = this.getBoundingClientRect();\n (event.target as HTMLElement).setPointerCapture(event.pointerId);\n if (event.pointerType === 'mouse') {\n this.focused = true;\n }\n }\n\n private handlePointermove(event: PointerEvent): void {\n const [x, y] = this.calculateHandlePosition(event);\n\n this._valueChanged = false;\n\n this.x = x;\n this.y = 1 - y;\n this.colorController.applyColorFromState();\n this.dispatchEvent(\n new Event('input', {\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n }\n\n private handlePointerup(event: PointerEvent): void {\n event.preventDefault();\n this._pointerDown = false;\n (event.target as HTMLElement).releasePointerCapture(event.pointerId);\n const applyDefault = this.dispatchEvent(\n new Event('change', {\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n this.inputX.focus();\n if (event.pointerType === 'mouse') {\n this.focused = false;\n }\n if (!applyDefault) {\n this.colorController.restorePreviousColor();\n }\n }\n\n /**\n * Returns the value under the cursor\n * @param: PointerEvent on slider\n * @return: Slider value that correlates to the position under the pointer\n */\n private calculateHandlePosition(event: PointerEvent): [number, number] {\n /* c8 ignore next 3 */\n if (!this.boundingClientRect) {\n return [this.x, this.y];\n }\n const rect = this.boundingClientRect;\n const minOffsetX = rect.left;\n const minOffsetY = rect.top;\n const offsetX = event.clientX;\n const offsetY = event.clientY;\n const width = rect.width;\n const height = rect.height;\n\n const percentX = Math.max(\n 0,\n Math.min(1, (offsetX - minOffsetX) / width)\n );\n const percentY = Math.max(\n 0,\n Math.min(1, (offsetY - minOffsetY) / height)\n );\n\n return [this.isLTR ? percentX : 1 - percentX, percentY];\n }\n\n private handleAreaPointerdown(event: PointerEvent): void {\n if (event.button !== 0) {\n return;\n }\n event.stopPropagation();\n event.preventDefault();\n this.handle.dispatchEvent(new PointerEvent('pointerdown', event));\n this.handlePointermove(event);\n }\n\n protected override render(): TemplateResult {\n const { width = 0, height = 0 } = this.boundingClientRect || {};\n\n if (window.__swc.DEBUG) {\n if (this.label) {\n window.__swc.warn(\n this,\n `The \"label\" property in <${this.localName}> has been deprecated and will be removed in a future release. Please leverage \"labelX\" and \"labelY\" instead.`,\n 'https://opensource.adobe.com/spectrum-web-components/components/color-area/#labels',\n { level: 'deprecation' }\n );\n }\n }\n\n const isMobile = isAndroid() || isIOS();\n const defaultAriaLabel = 'Color Picker';\n const ariaLabel = this.label\n ? `${this.label} ${defaultAriaLabel}`\n : defaultAriaLabel;\n const ariaRoleDescription = ifDefined(\n isMobile ? undefined : '2d slider'\n );\n\n const ariaLabelX = this.labelX;\n const ariaLabelY = this.labelY;\n const ariaValueX = new Intl.NumberFormat(\n this.languageResolver.language,\n {\n style: 'percent',\n unitDisplay: 'narrow',\n }\n ).format(this.x);\n const ariaValueY = new Intl.NumberFormat(\n this.languageResolver.language,\n {\n style: 'percent',\n unitDisplay: 'narrow',\n }\n ).format(this.y);\n\n const style = {\n background: `linear-gradient(to top, black 0%, hsla(${this.hue}, 100%, 0.01%, 0) 100%),linear-gradient(to right, white 0%, hsla(${this.hue}, 100%, 0.01%, 0) 100%), hsl(${this.hue}, 100%, 50%);`,\n };\n\n return html`\n <div\n @pointerdown=${this.handleAreaPointerdown}\n class=\"gradient\"\n style=${styleMap(style)}\n >\n <slot name=\"gradient\"></slot>\n </div>\n\n <sp-color-handle\n tabindex=${ifDefined(this.focused ? undefined : '0')}\n @focus=${this.forwardFocus}\n ?focused=${this.focused}\n class=\"handle\"\n color=${this.colorController.getHslString()}\n ?disabled=${this.disabled}\n style=${`transform: translate(${\n (this.isLTR ? this.x : 1 - this.x) * width\n }px, ${height - this.y * height}px);`}\n ${streamingListener({\n start: ['pointerdown', this.handlePointerdown],\n streamInside: ['pointermove', this.handlePointermove],\n end: [\n ['pointerup', 'pointercancel', 'pointerleave'],\n this.handlePointerup,\n ],\n })}\n ></sp-color-handle>\n\n <fieldset\n class=\"fieldset\"\n aria-label=${ifDefined(isMobile ? ariaLabel : undefined)}\n >\n <div role=\"presentation\">\n <input\n type=\"range\"\n class=\"slider\"\n name=\"x\"\n aria-label=${isMobile ? ariaLabelX : ariaLabel}\n aria-roledescription=${ariaRoleDescription}\n aria-orientation=\"horizontal\"\n aria-valuetext=${isMobile\n ? ariaValueX\n : `${ariaValueX}, ${ariaLabelX}${\n this._valueChanged\n ? ''\n : `, ${ariaValueY}, ${ariaLabelY}`\n }`}\n min=\"0\"\n max=\"1\"\n step=${this.step}\n tabindex=\"-1\"\n .value=${String(this.x)}\n @input=${this.handleInput}\n @change=${this.handleChange}\n />\n </div>\n <div role=\"presentation\">\n <input\n type=\"range\"\n class=\"slider\"\n name=\"y\"\n aria-label=${isMobile ? ariaLabelY : ariaLabel}\n aria-roledescription=${ariaRoleDescription}\n aria-orientation=\"vertical\"\n aria-valuetext=${isMobile\n ? ariaValueY\n : `${ariaValueY}, ${ariaLabelY}${\n this._valueChanged\n ? ''\n : `, ${ariaValueX}, ${ariaLabelX}`\n }`}\n orient=\"vertical\"\n min=\"0\"\n max=\"1\"\n step=${this.step}\n tabindex=\"-1\"\n .value=${String(this.y)}\n @input=${this.handleInput}\n @change=${this.handleChange}\n />\n </div>\n </fieldset>\n `;\n }\n\n protected override firstUpdated(changed: PropertyValues): void {\n super.firstUpdated(changed);\n this.boundingClientRect = this.getBoundingClientRect();\n\n this.addEventListener('focus', this.handleFocus);\n this.addEventListener('blur', this.handleBlur);\n this.addEventListener('keyup', this.handleKeyup);\n this.addEventListener('keydown', this.handleKeydown);\n }\n\n protected override updated(changed: PropertyValues): void {\n super.updated(changed);\n if (this.x !== this.inputX.valueAsNumber) {\n this._x = this.inputX.valueAsNumber;\n }\n if (this.y !== this.inputY.valueAsNumber) {\n this._y = this.inputY.valueAsNumber;\n }\n if (changed.has('focused') && this.focused) {\n // Lazily bind the `input[type=\"range\"]` elements in shadow roots\n // so that browsers with certain settings (Webkit) aren't allowed\n // multiple tab stops within the Color Area.\n const parentX = this.inputX.parentElement as HTMLDivElement;\n const parentY = this.inputY.parentElement as HTMLDivElement;\n if (!parentX.shadowRoot && !parentY.shadowRoot) {\n parentX.attachShadow({ mode: 'open' });\n parentY.attachShadow({ mode: 'open' });\n const slot = '<div tabindex=\"-1\"><slot></slot></div>';\n (parentX.shadowRoot as unknown as ShadowRoot).innerHTML = slot;\n (parentY.shadowRoot as unknown as ShadowRoot).innerHTML = slot;\n }\n }\n }\n\n private observer?: WithSWCResizeObserver['ResizeObserver'];\n\n public override connectedCallback(): void {\n super.connectedCallback();\n if (\n !this.observer &&\n (window as unknown as WithSWCResizeObserver).ResizeObserver\n ) {\n this.observer = new (\n window as unknown as WithSWCResizeObserver\n ).ResizeObserver((entries: SWCResizeObserverEntry[]) => {\n for (const entry of entries) {\n this.boundingClientRect = entry.contentRect;\n }\n this.requestUpdate();\n });\n }\n this.observer?.observe(this);\n }\n\n public override disconnectedCallback(): void {\n this.observer?.unobserve(this);\n super.disconnectedCallback();\n }\n}\n"],
|
|
5
|
-
"mappings": ";;;;;;;;;;;AAYA;AAAA,EAEI;AAAA,EAEA;AAAA,OAEG;AACP;AAAA,EACI;AAAA,EACA;AAAA,OACG;AACP;AAAA,EACI;AAAA,EACA;AAAA,OACG;AACP,SAAS,yBAAyB;AAGlC,OAAO;AACP;AAAA,EACI;AAAA,OAEG;AACP,SAAS,oCAAoC;AAC7C;AAAA,EACI;AAAA,EACA;AAAA,OACG;AAEP,OAAO,YAAY;AAQZ,aAAM,kBAAkB,gBAAgB;AAAA,EAAxC;AAAA;AASH,SAAO,WAAW;AAGlB,SAAO,UAAU;
|
|
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*/\n\nimport {\n CSSResultArray,\n html,\n PropertyValues,\n SpectrumElement,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n ifDefined,\n styleMap,\n} from '@spectrum-web-components/base/src/directives.js';\nimport {\n property,\n query,\n} from '@spectrum-web-components/base/src/decorators.js';\nimport { streamingListener } from '@spectrum-web-components/base/src/streaming-listener.js';\nimport { SWCResizeObserverEntry, WithSWCResizeObserver } from './types';\nimport type { ColorHandle } from '@spectrum-web-components/color-handle';\nimport '@spectrum-web-components/color-handle/sp-color-handle.js';\nimport {\n ColorController,\n ColorValue,\n} from '@spectrum-web-components/reactive-controllers/src/Color.js';\nimport { LanguageResolutionController } from '@spectrum-web-components/reactive-controllers/src/LanguageResolution.js';\nimport {\n isAndroid,\n isIOS,\n} from '@spectrum-web-components/shared/src/platform.js';\n\nimport styles from './color-area.css.js';\n\n/**\n * @element sp-color-area\n * @slot gradient - a custom gradient visually outlining the available color values\n * @fires input - The value of the Color Area has changed.\n * @fires change - An alteration to the value of the Color Area has been committed by the user.\n */\nexport class ColorArea extends SpectrumElement {\n public static override get styles(): CSSResultArray {\n return [styles];\n }\n\n @property({ type: String, reflect: true })\n public override dir!: 'ltr' | 'rtl';\n\n @property({ type: Boolean, reflect: true })\n public disabled = false;\n\n @property({ type: Boolean, reflect: true })\n public focused = false;\n\n @property({ type: String, attribute: 'label-x' })\n public labelX = 'saturation';\n\n @property({ type: String, attribute: 'label-y' })\n public labelY = 'luminosity';\n\n @query('.handle')\n private handle!: ColorHandle;\n\n private languageResolver = new LanguageResolutionController(this);\n\n private colorController = new ColorController(this, {\n extractColorFromState: () => ({\n h: this.hue,\n s: this.x,\n v: this.y,\n }),\n applyColorToState: ({ s, v }) => {\n this._x = s;\n this._y = v;\n this.requestUpdate();\n },\n });\n\n @property({ type: Number })\n public get hue(): number {\n return this.colorController.hue;\n }\n\n public set hue(value: number) {\n this.colorController.hue = value;\n }\n\n @property({ type: String })\n public get value(): ColorValue {\n return this.colorController.color;\n }\n\n @property({ type: String })\n public get color(): ColorValue {\n return this.colorController.color;\n }\n\n public set color(color: ColorValue) {\n this.colorController.color = color;\n }\n\n @property({ attribute: false })\n private activeAxis = 'x';\n\n @property({ type: Number })\n public get x(): number {\n return this._x;\n }\n\n public set x(x: number) {\n if (x === this.x) {\n return;\n }\n const oldValue = this.x;\n if (this.inputX) {\n // Use the native `input[type='range']` control to validate this value after `firstUpdate`\n this.inputX.value = x.toString();\n this._x = this.inputX.valueAsNumber;\n } else {\n this._x = x;\n }\n this.requestUpdate('x', oldValue);\n this.colorController.applyColorFromState();\n }\n\n private _x = 1;\n\n @property({ type: Number })\n public get y(): number {\n return this._y;\n }\n\n public set y(y: number) {\n if (y === this.y) {\n return;\n }\n const oldValue = this.y;\n if (this.inputY) {\n // Use the native `input[type='range']` control to validate this value after `firstUpdate`\n this.inputY.value = y.toString();\n this._y = this.inputY.valueAsNumber;\n } else {\n this._y = y;\n }\n this.requestUpdate('y', oldValue);\n this.colorController.applyColorFromState();\n }\n\n private _y = 1;\n\n @property({ type: Number })\n public step = 0.01;\n\n @query('[name=\"x\"]')\n public inputX!: HTMLInputElement;\n\n @query('[name=\"y\"]')\n public inputY!: HTMLInputElement;\n\n private altered = 0;\n\n private activeKeys = new Set();\n\n private _valueChanged = false;\n\n public override focus(focusOptions: FocusOptions = {}): void {\n super.focus(focusOptions);\n this.forwardFocus();\n }\n\n private forwardFocus(): void {\n this.focused = this.hasVisibleFocusInTree();\n if (this.activeAxis === 'x') {\n this.inputX.focus();\n } else {\n this.inputY.focus();\n }\n }\n\n private handleFocus(): void {\n this.focused = true;\n this._valueChanged = false;\n }\n\n private handleBlur(): void {\n if (this._pointerDown) {\n return;\n }\n this.altered = 0;\n this.focused = false;\n this._valueChanged = false;\n }\n\n private handleKeydown(event: KeyboardEvent): void {\n const { code } = event;\n this.focused = true;\n this.altered = [event.shiftKey, event.ctrlKey, event.altKey].filter(\n (key) => !!key\n ).length;\n const isArrowKey =\n code.search('Arrow') === 0 ||\n code.search('Page') === 0 ||\n code.search('Home') === 0 ||\n code.search('End') === 0;\n if (isArrowKey) {\n event.preventDefault();\n this.activeKeys.add(code);\n this.handleKeypress();\n }\n }\n\n private handleKeypress(): void {\n let deltaX = 0;\n let deltaY = 0;\n const step = Math.max(this.step, this.altered * 5 * this.step);\n this.activeKeys.forEach((code) => {\n switch (code) {\n case 'ArrowUp':\n deltaY = step;\n break;\n case 'ArrowDown':\n deltaY = step * -1;\n break;\n case 'ArrowLeft':\n deltaX = this.step * (this.isLTR ? -1 : 1);\n break;\n case 'ArrowRight':\n deltaX = this.step * (this.isLTR ? 1 : -1);\n break;\n case 'PageUp':\n deltaY = step * 10;\n break;\n case 'PageDown':\n deltaY = step * -10;\n break;\n case 'Home':\n deltaX = step * (this.isLTR ? -10 : 10);\n break;\n case 'End':\n deltaX = step * (this.isLTR ? 10 : -10);\n break;\n /* c8 ignore next 2 */\n default:\n break;\n }\n });\n if (deltaX != 0) {\n this.activeAxis = 'x';\n this.inputX.focus();\n } else if (deltaY != 0) {\n this.activeAxis = 'y';\n this.inputY.focus();\n }\n this.x = Math.min(1, Math.max(this.x + deltaX, 0));\n this.y = Math.min(1, Math.max(this.y + deltaY, 0));\n\n this.colorController.savePreviousColor();\n this.colorController.applyColorFromState();\n\n if (deltaX != 0 || deltaY != 0) {\n this._valueChanged = true;\n this.dispatchEvent(\n new Event('input', {\n bubbles: true,\n composed: true,\n })\n );\n const applyDefault = this.dispatchEvent(\n new Event('change', {\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n if (!applyDefault) {\n this.colorController.restorePreviousColor();\n }\n }\n }\n\n private handleKeyup(event: KeyboardEvent): void {\n event.preventDefault();\n const { code } = event;\n this.activeKeys.delete(code);\n }\n\n private handleInput(event: Event & { target: HTMLInputElement }): void {\n const { valueAsNumber, name } = event.target;\n\n this[name as 'x' | 'y'] = valueAsNumber;\n this.colorController.applyColorFromState();\n }\n\n private handleChange(event: Event & { target: HTMLInputElement }): void {\n this.handleInput(event);\n this.dispatchEvent(\n new Event('change', {\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n }\n\n private boundingClientRect!: DOMRect;\n private _pointerDown = false;\n\n private handlePointerdown(event: PointerEvent): void {\n if (event.button !== 0) {\n event.preventDefault();\n return;\n }\n this._pointerDown = true;\n this.colorController.savePreviousColor();\n this.boundingClientRect = this.getBoundingClientRect();\n (event.target as HTMLElement).setPointerCapture(event.pointerId);\n if (event.pointerType === 'mouse') {\n this.focused = true;\n }\n }\n\n private handlePointermove(event: PointerEvent): void {\n const [x, y] = this.calculateHandlePosition(event);\n\n this._valueChanged = false;\n\n this.x = x;\n this.y = 1 - y;\n this.colorController.applyColorFromState();\n this.dispatchEvent(\n new Event('input', {\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n }\n\n private handlePointerup(event: PointerEvent): void {\n event.preventDefault();\n this._pointerDown = false;\n (event.target as HTMLElement).releasePointerCapture(event.pointerId);\n const applyDefault = this.dispatchEvent(\n new Event('change', {\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n this.inputX.focus();\n if (event.pointerType === 'mouse') {\n this.focused = false;\n }\n if (!applyDefault) {\n this.colorController.restorePreviousColor();\n }\n }\n\n /**\n * Returns the value under the cursor\n * @param: PointerEvent on slider\n * @return: Slider value that correlates to the position under the pointer\n */\n private calculateHandlePosition(event: PointerEvent): [number, number] {\n /* c8 ignore next 3 */\n if (!this.boundingClientRect) {\n return [this.x, this.y];\n }\n const rect = this.boundingClientRect;\n const minOffsetX = rect.left;\n const minOffsetY = rect.top;\n const offsetX = event.clientX;\n const offsetY = event.clientY;\n const width = rect.width;\n const height = rect.height;\n\n const percentX = Math.max(\n 0,\n Math.min(1, (offsetX - minOffsetX) / width)\n );\n const percentY = Math.max(\n 0,\n Math.min(1, (offsetY - minOffsetY) / height)\n );\n\n return [this.isLTR ? percentX : 1 - percentX, percentY];\n }\n\n private handleAreaPointerdown(event: PointerEvent): void {\n if (event.button !== 0) {\n return;\n }\n event.stopPropagation();\n event.preventDefault();\n this.handle.dispatchEvent(new PointerEvent('pointerdown', event));\n this.handlePointermove(event);\n }\n\n protected override render(): TemplateResult {\n const { width = 0, height = 0 } = this.boundingClientRect || {};\n\n const isMobile = isAndroid() || isIOS();\n const defaultAriaLabel = 'Color Picker';\n const ariaLabel = defaultAriaLabel;\n const ariaRoleDescription = ifDefined(\n isMobile ? undefined : '2d slider'\n );\n\n const ariaLabelX = this.labelX;\n const ariaLabelY = this.labelY;\n const ariaValueX = new Intl.NumberFormat(\n this.languageResolver.language,\n {\n style: 'percent',\n unitDisplay: 'narrow',\n }\n ).format(this.x);\n const ariaValueY = new Intl.NumberFormat(\n this.languageResolver.language,\n {\n style: 'percent',\n unitDisplay: 'narrow',\n }\n ).format(this.y);\n\n const style = {\n background: `linear-gradient(to top, black 0%, hsla(${this.hue}, 100%, 0.01%, 0) 100%),linear-gradient(to right, white 0%, hsla(${this.hue}, 100%, 0.01%, 0) 100%), hsl(${this.hue}, 100%, 50%);`,\n };\n\n return html`\n <div\n @pointerdown=${this.handleAreaPointerdown}\n class=\"gradient\"\n style=${styleMap(style)}\n >\n <slot name=\"gradient\"></slot>\n </div>\n\n <sp-color-handle\n tabindex=${ifDefined(this.focused ? undefined : '0')}\n @focus=${this.forwardFocus}\n ?focused=${this.focused}\n class=\"handle\"\n color=${this.colorController.getHslString()}\n ?disabled=${this.disabled}\n style=${`transform: translate(${\n (this.isLTR ? this.x : 1 - this.x) * width\n }px, ${height - this.y * height}px);`}\n ${streamingListener({\n start: ['pointerdown', this.handlePointerdown],\n streamInside: ['pointermove', this.handlePointermove],\n end: [\n ['pointerup', 'pointercancel', 'pointerleave'],\n this.handlePointerup,\n ],\n })}\n ></sp-color-handle>\n\n <fieldset\n class=\"fieldset\"\n aria-label=${ifDefined(isMobile ? ariaLabel : undefined)}\n >\n <div role=\"presentation\">\n <input\n type=\"range\"\n class=\"slider\"\n name=\"x\"\n aria-label=${isMobile\n ? ariaLabelX\n : `${ariaLabelX} ${ariaLabel}`}\n aria-roledescription=${ariaRoleDescription}\n aria-orientation=\"horizontal\"\n aria-valuetext=${isMobile\n ? ariaValueX\n : `${ariaValueX}, ${ariaLabelX}${\n this._valueChanged\n ? ''\n : `, ${ariaValueY}, ${ariaLabelY}`\n }`}\n min=\"0\"\n max=\"1\"\n step=${this.step}\n tabindex=\"-1\"\n .value=${String(this.x)}\n @input=${this.handleInput}\n @change=${this.handleChange}\n />\n </div>\n <div role=\"presentation\">\n <input\n type=\"range\"\n class=\"slider\"\n name=\"y\"\n aria-label=${isMobile\n ? ariaLabelY\n : `${ariaLabelY} ${ariaLabel}`}\n aria-roledescription=${ariaRoleDescription}\n aria-orientation=\"vertical\"\n aria-valuetext=${isMobile\n ? ariaValueY\n : `${ariaValueY}, ${ariaLabelY}${\n this._valueChanged\n ? ''\n : `, ${ariaValueX}, ${ariaLabelX}`\n }`}\n orient=\"vertical\"\n min=\"0\"\n max=\"1\"\n step=${this.step}\n tabindex=\"-1\"\n .value=${String(this.y)}\n @input=${this.handleInput}\n @change=${this.handleChange}\n />\n </div>\n </fieldset>\n `;\n }\n\n protected override firstUpdated(changed: PropertyValues): void {\n super.firstUpdated(changed);\n this.boundingClientRect = this.getBoundingClientRect();\n\n this.addEventListener('focus', this.handleFocus);\n this.addEventListener('blur', this.handleBlur);\n this.addEventListener('keyup', this.handleKeyup);\n this.addEventListener('keydown', this.handleKeydown);\n }\n\n protected override updated(changed: PropertyValues): void {\n super.updated(changed);\n if (this.x !== this.inputX.valueAsNumber) {\n this._x = this.inputX.valueAsNumber;\n }\n if (this.y !== this.inputY.valueAsNumber) {\n this._y = this.inputY.valueAsNumber;\n }\n if (changed.has('focused') && this.focused) {\n // Lazily bind the `input[type=\"range\"]` elements in shadow roots\n // so that browsers with certain settings (Webkit) aren't allowed\n // multiple tab stops within the Color Area.\n const parentX = this.inputX.parentElement as HTMLDivElement;\n const parentY = this.inputY.parentElement as HTMLDivElement;\n if (!parentX.shadowRoot && !parentY.shadowRoot) {\n parentX.attachShadow({ mode: 'open' });\n parentY.attachShadow({ mode: 'open' });\n const slot = '<div tabindex=\"-1\"><slot></slot></div>';\n (parentX.shadowRoot as unknown as ShadowRoot).innerHTML = slot;\n (parentY.shadowRoot as unknown as ShadowRoot).innerHTML = slot;\n }\n }\n }\n\n private observer?: WithSWCResizeObserver['ResizeObserver'];\n\n public override connectedCallback(): void {\n super.connectedCallback();\n if (\n !this.observer &&\n (window as unknown as WithSWCResizeObserver).ResizeObserver\n ) {\n this.observer = new (\n window as unknown as WithSWCResizeObserver\n ).ResizeObserver((entries: SWCResizeObserverEntry[]) => {\n for (const entry of entries) {\n this.boundingClientRect = entry.contentRect;\n }\n this.requestUpdate();\n });\n }\n this.observer?.observe(this);\n }\n\n public override disconnectedCallback(): void {\n this.observer?.unobserve(this);\n super.disconnectedCallback();\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
package/src/ColorArea.js
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
"use strict";var
|
|
1
|
+
"use strict";var m=Object.defineProperty;var y=Object.getOwnPropertyDescriptor;var s=(c,u,e,t)=>{for(var i=t>1?void 0:t?y(u,e):u,r=c.length-1,n;r>=0;r--)(n=c[r])&&(i=(t?n(u,e,i):n(i))||i);return t&&i&&m(u,e,i),i};import{html as g,SpectrumElement as w}from"@spectrum-web-components/base";import{ifDefined as v,styleMap as C}from"@spectrum-web-components/base/src/directives.js";import{property as o,query as b}from"@spectrum-web-components/base/src/decorators.js";import{streamingListener as x}from"@spectrum-web-components/base/src/streaming-listener.js";import"@spectrum-web-components/color-handle/sp-color-handle.js";import{ColorController as $}from"@spectrum-web-components/reactive-controllers/src/Color.js";import{LanguageResolutionController as R}from"@spectrum-web-components/reactive-controllers/src/LanguageResolution.js";import{isAndroid as E,isIOS as S}from"@spectrum-web-components/shared/src/platform.js";import P from"./color-area.css.js";export class ColorArea extends w{constructor(){super(...arguments);this.disabled=!1;this.focused=!1;this.labelX="saturation";this.labelY="luminosity";this.languageResolver=new R(this);this.colorController=new $(this,{extractColorFromState:()=>({h:this.hue,s:this.x,v:this.y}),applyColorToState:({s:e,v:t})=>{this._x=e,this._y=t,this.requestUpdate()}});this.activeAxis="x";this._x=1;this._y=1;this.step=.01;this.altered=0;this.activeKeys=new Set;this._valueChanged=!1;this._pointerDown=!1}static get styles(){return[P]}get hue(){return this.colorController.hue}set hue(e){this.colorController.hue=e}get value(){return this.colorController.color}get color(){return this.colorController.color}set color(e){this.colorController.color=e}get x(){return this._x}set x(e){if(e===this.x)return;const t=this.x;this.inputX?(this.inputX.value=e.toString(),this._x=this.inputX.valueAsNumber):this._x=e,this.requestUpdate("x",t),this.colorController.applyColorFromState()}get y(){return this._y}set y(e){if(e===this.y)return;const t=this.y;this.inputY?(this.inputY.value=e.toString(),this._y=this.inputY.valueAsNumber):this._y=e,this.requestUpdate("y",t),this.colorController.applyColorFromState()}focus(e={}){super.focus(e),this.forwardFocus()}forwardFocus(){this.focused=this.hasVisibleFocusInTree(),this.activeAxis==="x"?this.inputX.focus():this.inputY.focus()}handleFocus(){this.focused=!0,this._valueChanged=!1}handleBlur(){this._pointerDown||(this.altered=0,this.focused=!1,this._valueChanged=!1)}handleKeydown(e){const{code:t}=e;this.focused=!0,this.altered=[e.shiftKey,e.ctrlKey,e.altKey].filter(r=>!!r).length,(t.search("Arrow")===0||t.search("Page")===0||t.search("Home")===0||t.search("End")===0)&&(e.preventDefault(),this.activeKeys.add(t),this.handleKeypress())}handleKeypress(){let e=0,t=0;const i=Math.max(this.step,this.altered*5*this.step);this.activeKeys.forEach(r=>{switch(r){case"ArrowUp":t=i;break;case"ArrowDown":t=i*-1;break;case"ArrowLeft":e=this.step*(this.isLTR?-1:1);break;case"ArrowRight":e=this.step*(this.isLTR?1:-1);break;case"PageUp":t=i*10;break;case"PageDown":t=i*-10;break;case"Home":e=i*(this.isLTR?-10:10);break;case"End":e=i*(this.isLTR?10:-10);break;default:break}}),e!=0?(this.activeAxis="x",this.inputX.focus()):t!=0&&(this.activeAxis="y",this.inputY.focus()),this.x=Math.min(1,Math.max(this.x+e,0)),this.y=Math.min(1,Math.max(this.y+t,0)),this.colorController.savePreviousColor(),this.colorController.applyColorFromState(),(e!=0||t!=0)&&(this._valueChanged=!0,this.dispatchEvent(new Event("input",{bubbles:!0,composed:!0})),this.dispatchEvent(new Event("change",{bubbles:!0,composed:!0,cancelable:!0}))||this.colorController.restorePreviousColor())}handleKeyup(e){e.preventDefault();const{code:t}=e;this.activeKeys.delete(t)}handleInput(e){const{valueAsNumber:t,name:i}=e.target;this[i]=t,this.colorController.applyColorFromState()}handleChange(e){this.handleInput(e),this.dispatchEvent(new Event("change",{bubbles:!0,composed:!0,cancelable:!0}))}handlePointerdown(e){if(e.button!==0){e.preventDefault();return}this._pointerDown=!0,this.colorController.savePreviousColor(),this.boundingClientRect=this.getBoundingClientRect(),e.target.setPointerCapture(e.pointerId),e.pointerType==="mouse"&&(this.focused=!0)}handlePointermove(e){const[t,i]=this.calculateHandlePosition(e);this._valueChanged=!1,this.x=t,this.y=1-i,this.colorController.applyColorFromState(),this.dispatchEvent(new Event("input",{bubbles:!0,composed:!0,cancelable:!0}))}handlePointerup(e){e.preventDefault(),this._pointerDown=!1,e.target.releasePointerCapture(e.pointerId);const t=this.dispatchEvent(new Event("change",{bubbles:!0,composed:!0,cancelable:!0}));this.inputX.focus(),e.pointerType==="mouse"&&(this.focused=!1),t||this.colorController.restorePreviousColor()}calculateHandlePosition(e){if(!this.boundingClientRect)return[this.x,this.y];const t=this.boundingClientRect,i=t.left,r=t.top,n=e.clientX,d=e.clientY,a=t.width,l=t.height,h=Math.max(0,Math.min(1,(n-i)/a)),p=Math.max(0,Math.min(1,(d-r)/l));return[this.isLTR?h:1-h,p]}handleAreaPointerdown(e){e.button===0&&(e.stopPropagation(),e.preventDefault(),this.handle.dispatchEvent(new PointerEvent("pointerdown",e)),this.handlePointermove(e))}render(){const{width:e=0,height:t=0}=this.boundingClientRect||{},i=E()||S(),n="Color Picker",d=v(i?void 0:"2d slider"),a=this.labelX,l=this.labelY,h=new Intl.NumberFormat(this.languageResolver.language,{style:"percent",unitDisplay:"narrow"}).format(this.x),p=new Intl.NumberFormat(this.languageResolver.language,{style:"percent",unitDisplay:"narrow"}).format(this.y),f={background:`linear-gradient(to top, black 0%, hsla(${this.hue}, 100%, 0.01%, 0) 100%),linear-gradient(to right, white 0%, hsla(${this.hue}, 100%, 0.01%, 0) 100%), hsl(${this.hue}, 100%, 50%);`};return g`
|
|
2
2
|
<div
|
|
3
3
|
@pointerdown=${this.handleAreaPointerdown}
|
|
4
4
|
class="gradient"
|
|
5
|
-
style=${C(
|
|
5
|
+
style=${C(f)}
|
|
6
6
|
>
|
|
7
7
|
<slot name="gradient"></slot>
|
|
8
8
|
</div>
|
|
9
9
|
|
|
10
10
|
<sp-color-handle
|
|
11
|
-
tabindex=${
|
|
11
|
+
tabindex=${v(this.focused?void 0:"0")}
|
|
12
12
|
@focus=${this.forwardFocus}
|
|
13
13
|
?focused=${this.focused}
|
|
14
14
|
class="handle"
|
|
@@ -20,17 +20,17 @@
|
|
|
20
20
|
|
|
21
21
|
<fieldset
|
|
22
22
|
class="fieldset"
|
|
23
|
-
aria-label=${
|
|
23
|
+
aria-label=${v(i?n:void 0)}
|
|
24
24
|
>
|
|
25
25
|
<div role="presentation">
|
|
26
26
|
<input
|
|
27
27
|
type="range"
|
|
28
28
|
class="slider"
|
|
29
29
|
name="x"
|
|
30
|
-
aria-label=${i?
|
|
30
|
+
aria-label=${i?a:`${a} ${n}`}
|
|
31
31
|
aria-roledescription=${d}
|
|
32
32
|
aria-orientation="horizontal"
|
|
33
|
-
aria-valuetext=${i?
|
|
33
|
+
aria-valuetext=${i?h:`${h}, ${a}${this._valueChanged?"":`, ${p}, ${l}`}`}
|
|
34
34
|
min="0"
|
|
35
35
|
max="1"
|
|
36
36
|
step=${this.step}
|
|
@@ -45,10 +45,10 @@
|
|
|
45
45
|
type="range"
|
|
46
46
|
class="slider"
|
|
47
47
|
name="y"
|
|
48
|
-
aria-label=${i?
|
|
48
|
+
aria-label=${i?l:`${l} ${n}`}
|
|
49
49
|
aria-roledescription=${d}
|
|
50
50
|
aria-orientation="vertical"
|
|
51
|
-
aria-valuetext=${i?p:`${p}, ${
|
|
51
|
+
aria-valuetext=${i?p:`${p}, ${l}${this._valueChanged?"":`, ${h}, ${a}`}`}
|
|
52
52
|
orient="vertical"
|
|
53
53
|
min="0"
|
|
54
54
|
max="1"
|
|
@@ -60,5 +60,5 @@
|
|
|
60
60
|
/>
|
|
61
61
|
</div>
|
|
62
62
|
</fieldset>
|
|
63
|
-
`}firstUpdated(e){super.firstUpdated(e),this.boundingClientRect=this.getBoundingClientRect(),this.addEventListener("focus",this.handleFocus),this.addEventListener("blur",this.handleBlur),this.addEventListener("keyup",this.handleKeyup),this.addEventListener("keydown",this.handleKeydown)}updated(e){if(super.updated(e),this.x!==this.inputX.valueAsNumber&&(this._x=this.inputX.valueAsNumber),this.y!==this.inputY.valueAsNumber&&(this._y=this.inputY.valueAsNumber),e.has("focused")&&this.focused){const t=this.inputX.parentElement,i=this.inputY.parentElement;if(!t.shadowRoot&&!i.shadowRoot){t.attachShadow({mode:"open"}),i.attachShadow({mode:"open"});const r='<div tabindex="-1"><slot></slot></div>';t.shadowRoot.innerHTML=r,i.shadowRoot.innerHTML=r}}}connectedCallback(){var e;super.connectedCallback(),!this.observer&&window.ResizeObserver&&(this.observer=new window.ResizeObserver(t=>{for(const i of t)this.boundingClientRect=i.contentRect;this.requestUpdate()})),(e=this.observer)==null||e.observe(this)}disconnectedCallback(){var e;(e=this.observer)==null||e.unobserve(this),super.disconnectedCallback()}}s([o({type:String,reflect:!0})],ColorArea.prototype,"dir",2),s([o({type:Boolean,reflect:!0})],ColorArea.prototype,"disabled",2),s([o({type:Boolean,reflect:!0})],ColorArea.prototype,"focused",2),s([o({type:String
|
|
63
|
+
`}firstUpdated(e){super.firstUpdated(e),this.boundingClientRect=this.getBoundingClientRect(),this.addEventListener("focus",this.handleFocus),this.addEventListener("blur",this.handleBlur),this.addEventListener("keyup",this.handleKeyup),this.addEventListener("keydown",this.handleKeydown)}updated(e){if(super.updated(e),this.x!==this.inputX.valueAsNumber&&(this._x=this.inputX.valueAsNumber),this.y!==this.inputY.valueAsNumber&&(this._y=this.inputY.valueAsNumber),e.has("focused")&&this.focused){const t=this.inputX.parentElement,i=this.inputY.parentElement;if(!t.shadowRoot&&!i.shadowRoot){t.attachShadow({mode:"open"}),i.attachShadow({mode:"open"});const r='<div tabindex="-1"><slot></slot></div>';t.shadowRoot.innerHTML=r,i.shadowRoot.innerHTML=r}}}connectedCallback(){var e;super.connectedCallback(),!this.observer&&window.ResizeObserver&&(this.observer=new window.ResizeObserver(t=>{for(const i of t)this.boundingClientRect=i.contentRect;this.requestUpdate()})),(e=this.observer)==null||e.observe(this)}disconnectedCallback(){var e;(e=this.observer)==null||e.unobserve(this),super.disconnectedCallback()}}s([o({type:String,reflect:!0})],ColorArea.prototype,"dir",2),s([o({type:Boolean,reflect:!0})],ColorArea.prototype,"disabled",2),s([o({type:Boolean,reflect:!0})],ColorArea.prototype,"focused",2),s([o({type:String,attribute:"label-x"})],ColorArea.prototype,"labelX",2),s([o({type:String,attribute:"label-y"})],ColorArea.prototype,"labelY",2),s([b(".handle")],ColorArea.prototype,"handle",2),s([o({type:Number})],ColorArea.prototype,"hue",1),s([o({type:String})],ColorArea.prototype,"value",1),s([o({type:String})],ColorArea.prototype,"color",1),s([o({attribute:!1})],ColorArea.prototype,"activeAxis",2),s([o({type:Number})],ColorArea.prototype,"x",1),s([o({type:Number})],ColorArea.prototype,"y",1),s([o({type:Number})],ColorArea.prototype,"step",2),s([b('[name="x"]')],ColorArea.prototype,"inputX",2),s([b('[name="y"]')],ColorArea.prototype,"inputY",2);
|
|
64
64
|
//# sourceMappingURL=ColorArea.js.map
|
package/src/ColorArea.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["ColorArea.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*/\n\nimport {\n CSSResultArray,\n html,\n PropertyValues,\n SpectrumElement,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n ifDefined,\n styleMap,\n} from '@spectrum-web-components/base/src/directives.js';\nimport {\n property,\n query,\n} from '@spectrum-web-components/base/src/decorators.js';\nimport { streamingListener } from '@spectrum-web-components/base/src/streaming-listener.js';\nimport { SWCResizeObserverEntry, WithSWCResizeObserver } from './types';\nimport type { ColorHandle } from '@spectrum-web-components/color-handle';\nimport '@spectrum-web-components/color-handle/sp-color-handle.js';\nimport {\n ColorController,\n ColorValue,\n} from '@spectrum-web-components/reactive-controllers/src/Color.js';\nimport { LanguageResolutionController } from '@spectrum-web-components/reactive-controllers/src/LanguageResolution.js';\nimport {\n isAndroid,\n isIOS,\n} from '@spectrum-web-components/shared/src/platform.js';\n\nimport styles from './color-area.css.js';\n\n/**\n * @element sp-color-area\n * @slot gradient - a custom gradient visually outlining the available color values\n * @fires input - The value of the Color Area has changed.\n * @fires change - An alteration to the value of the Color Area has been committed by the user.\n */\nexport class ColorArea extends SpectrumElement {\n public static override get styles(): CSSResultArray {\n return [styles];\n }\n\n @property({ type: String, reflect: true })\n public override dir!: 'ltr' | 'rtl';\n\n @property({ type: Boolean, reflect: true })\n public disabled = false;\n\n @property({ type: Boolean, reflect: true })\n public focused = false;\n\n @property({ type: String })\n public label: string | undefined;\n\n @property({ type: String, attribute: 'label-x' })\n public labelX = 'saturation';\n\n @property({ type: String, attribute: 'label-y' })\n public labelY = 'luminosity';\n\n @query('.handle')\n private handle!: ColorHandle;\n\n private languageResolver = new LanguageResolutionController(this);\n\n private colorController = new ColorController(this, {\n extractColorFromState: () => ({\n h: this.hue,\n s: this.x,\n v: this.y,\n }),\n applyColorToState: ({ s, v }) => {\n this._x = s;\n this._y = v;\n this.requestUpdate();\n },\n });\n\n @property({ type: Number })\n public get hue(): number {\n return this.colorController.hue;\n }\n\n public set hue(value: number) {\n this.colorController.hue = value;\n }\n\n @property({ type: String })\n public get value(): ColorValue {\n return this.colorController.color;\n }\n\n @property({ type: String })\n public get color(): ColorValue {\n return this.colorController.color;\n }\n\n public set color(color: ColorValue) {\n this.colorController.color = color;\n }\n\n @property({ attribute: false })\n private activeAxis = 'x';\n\n @property({ type: Number })\n public get x(): number {\n return this._x;\n }\n\n public set x(x: number) {\n if (x === this.x) {\n return;\n }\n const oldValue = this.x;\n if (this.inputX) {\n // Use the native `input[type='range']` control to validate this value after `firstUpdate`\n this.inputX.value = x.toString();\n this._x = this.inputX.valueAsNumber;\n } else {\n this._x = x;\n }\n this.requestUpdate('x', oldValue);\n this.colorController.applyColorFromState();\n }\n\n private _x = 1;\n\n @property({ type: Number })\n public get y(): number {\n return this._y;\n }\n\n public set y(y: number) {\n if (y === this.y) {\n return;\n }\n const oldValue = this.y;\n if (this.inputY) {\n // Use the native `input[type='range']` control to validate this value after `firstUpdate`\n this.inputY.value = y.toString();\n this._y = this.inputY.valueAsNumber;\n } else {\n this._y = y;\n }\n this.requestUpdate('y', oldValue);\n this.colorController.applyColorFromState();\n }\n\n private _y = 1;\n\n @property({ type: Number })\n public step = 0.01;\n\n @query('[name=\"x\"]')\n public inputX!: HTMLInputElement;\n\n @query('[name=\"y\"]')\n public inputY!: HTMLInputElement;\n\n private altered = 0;\n\n private activeKeys = new Set();\n\n private _valueChanged = false;\n\n public override focus(focusOptions: FocusOptions = {}): void {\n super.focus(focusOptions);\n this.forwardFocus();\n }\n\n private forwardFocus(): void {\n this.focused = this.hasVisibleFocusInTree();\n if (this.activeAxis === 'x') {\n this.inputX.focus();\n } else {\n this.inputY.focus();\n }\n }\n\n private handleFocus(): void {\n this.focused = true;\n this._valueChanged = false;\n }\n\n private handleBlur(): void {\n if (this._pointerDown) {\n return;\n }\n this.altered = 0;\n this.focused = false;\n this._valueChanged = false;\n }\n\n private handleKeydown(event: KeyboardEvent): void {\n const { code } = event;\n this.focused = true;\n this.altered = [event.shiftKey, event.ctrlKey, event.altKey].filter(\n (key) => !!key\n ).length;\n const isArrowKey =\n code.search('Arrow') === 0 ||\n code.search('Page') === 0 ||\n code.search('Home') === 0 ||\n code.search('End') === 0;\n if (isArrowKey) {\n event.preventDefault();\n this.activeKeys.add(code);\n this.handleKeypress();\n }\n }\n\n private handleKeypress(): void {\n let deltaX = 0;\n let deltaY = 0;\n const step = Math.max(this.step, this.altered * 5 * this.step);\n this.activeKeys.forEach((code) => {\n switch (code) {\n case 'ArrowUp':\n deltaY = step;\n break;\n case 'ArrowDown':\n deltaY = step * -1;\n break;\n case 'ArrowLeft':\n deltaX = this.step * (this.isLTR ? -1 : 1);\n break;\n case 'ArrowRight':\n deltaX = this.step * (this.isLTR ? 1 : -1);\n break;\n case 'PageUp':\n deltaY = step * 10;\n break;\n case 'PageDown':\n deltaY = step * -10;\n break;\n case 'Home':\n deltaX = step * (this.isLTR ? -10 : 10);\n break;\n case 'End':\n deltaX = step * (this.isLTR ? 10 : -10);\n break;\n /* c8 ignore next 2 */\n default:\n break;\n }\n });\n if (deltaX != 0) {\n this.activeAxis = 'x';\n this.inputX.focus();\n } else if (deltaY != 0) {\n this.activeAxis = 'y';\n this.inputY.focus();\n }\n this.x = Math.min(1, Math.max(this.x + deltaX, 0));\n this.y = Math.min(1, Math.max(this.y + deltaY, 0));\n\n this.colorController.savePreviousColor();\n this.colorController.applyColorFromState();\n\n if (deltaX != 0 || deltaY != 0) {\n this._valueChanged = true;\n this.dispatchEvent(\n new Event('input', {\n bubbles: true,\n composed: true,\n })\n );\n const applyDefault = this.dispatchEvent(\n new Event('change', {\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n if (!applyDefault) {\n this.colorController.restorePreviousColor();\n }\n }\n }\n\n private handleKeyup(event: KeyboardEvent): void {\n event.preventDefault();\n const { code } = event;\n this.activeKeys.delete(code);\n }\n\n private handleInput(event: Event & { target: HTMLInputElement }): void {\n const { valueAsNumber, name } = event.target;\n\n this[name as 'x' | 'y'] = valueAsNumber;\n this.colorController.applyColorFromState();\n }\n\n private handleChange(event: Event & { target: HTMLInputElement }): void {\n this.handleInput(event);\n this.dispatchEvent(\n new Event('change', {\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n }\n\n private boundingClientRect!: DOMRect;\n private _pointerDown = false;\n\n private handlePointerdown(event: PointerEvent): void {\n if (event.button !== 0) {\n event.preventDefault();\n return;\n }\n this._pointerDown = true;\n this.colorController.savePreviousColor();\n this.boundingClientRect = this.getBoundingClientRect();\n (event.target as HTMLElement).setPointerCapture(event.pointerId);\n if (event.pointerType === 'mouse') {\n this.focused = true;\n }\n }\n\n private handlePointermove(event: PointerEvent): void {\n const [x, y] = this.calculateHandlePosition(event);\n\n this._valueChanged = false;\n\n this.x = x;\n this.y = 1 - y;\n this.colorController.applyColorFromState();\n this.dispatchEvent(\n new Event('input', {\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n }\n\n private handlePointerup(event: PointerEvent): void {\n event.preventDefault();\n this._pointerDown = false;\n (event.target as HTMLElement).releasePointerCapture(event.pointerId);\n const applyDefault = this.dispatchEvent(\n new Event('change', {\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n this.inputX.focus();\n if (event.pointerType === 'mouse') {\n this.focused = false;\n }\n if (!applyDefault) {\n this.colorController.restorePreviousColor();\n }\n }\n\n /**\n * Returns the value under the cursor\n * @param: PointerEvent on slider\n * @return: Slider value that correlates to the position under the pointer\n */\n private calculateHandlePosition(event: PointerEvent): [number, number] {\n /* c8 ignore next 3 */\n if (!this.boundingClientRect) {\n return [this.x, this.y];\n }\n const rect = this.boundingClientRect;\n const minOffsetX = rect.left;\n const minOffsetY = rect.top;\n const offsetX = event.clientX;\n const offsetY = event.clientY;\n const width = rect.width;\n const height = rect.height;\n\n const percentX = Math.max(\n 0,\n Math.min(1, (offsetX - minOffsetX) / width)\n );\n const percentY = Math.max(\n 0,\n Math.min(1, (offsetY - minOffsetY) / height)\n );\n\n return [this.isLTR ? percentX : 1 - percentX, percentY];\n }\n\n private handleAreaPointerdown(event: PointerEvent): void {\n if (event.button !== 0) {\n return;\n }\n event.stopPropagation();\n event.preventDefault();\n this.handle.dispatchEvent(new PointerEvent('pointerdown', event));\n this.handlePointermove(event);\n }\n\n protected override render(): TemplateResult {\n const { width = 0, height = 0 } = this.boundingClientRect || {};\n\n if (window.__swc.DEBUG) {\n if (this.label) {\n window.__swc.warn(\n this,\n `The \"label\" property in <${this.localName}> has been deprecated and will be removed in a future release. Please leverage \"labelX\" and \"labelY\" instead.`,\n 'https://opensource.adobe.com/spectrum-web-components/components/color-area/#labels',\n { level: 'deprecation' }\n );\n }\n }\n\n const isMobile = isAndroid() || isIOS();\n const defaultAriaLabel = 'Color Picker';\n const ariaLabel = this.label\n ? `${this.label} ${defaultAriaLabel}`\n : defaultAriaLabel;\n const ariaRoleDescription = ifDefined(\n isMobile ? undefined : '2d slider'\n );\n\n const ariaLabelX = this.labelX;\n const ariaLabelY = this.labelY;\n const ariaValueX = new Intl.NumberFormat(\n this.languageResolver.language,\n {\n style: 'percent',\n unitDisplay: 'narrow',\n }\n ).format(this.x);\n const ariaValueY = new Intl.NumberFormat(\n this.languageResolver.language,\n {\n style: 'percent',\n unitDisplay: 'narrow',\n }\n ).format(this.y);\n\n const style = {\n background: `linear-gradient(to top, black 0%, hsla(${this.hue}, 100%, 0.01%, 0) 100%),linear-gradient(to right, white 0%, hsla(${this.hue}, 100%, 0.01%, 0) 100%), hsl(${this.hue}, 100%, 50%);`,\n };\n\n return html`\n <div\n @pointerdown=${this.handleAreaPointerdown}\n class=\"gradient\"\n style=${styleMap(style)}\n >\n <slot name=\"gradient\"></slot>\n </div>\n\n <sp-color-handle\n tabindex=${ifDefined(this.focused ? undefined : '0')}\n @focus=${this.forwardFocus}\n ?focused=${this.focused}\n class=\"handle\"\n color=${this.colorController.getHslString()}\n ?disabled=${this.disabled}\n style=${`transform: translate(${\n (this.isLTR ? this.x : 1 - this.x) * width\n }px, ${height - this.y * height}px);`}\n ${streamingListener({\n start: ['pointerdown', this.handlePointerdown],\n streamInside: ['pointermove', this.handlePointermove],\n end: [\n ['pointerup', 'pointercancel', 'pointerleave'],\n this.handlePointerup,\n ],\n })}\n ></sp-color-handle>\n\n <fieldset\n class=\"fieldset\"\n aria-label=${ifDefined(isMobile ? ariaLabel : undefined)}\n >\n <div role=\"presentation\">\n <input\n type=\"range\"\n class=\"slider\"\n name=\"x\"\n aria-label=${isMobile ? ariaLabelX : ariaLabel}\n aria-roledescription=${ariaRoleDescription}\n aria-orientation=\"horizontal\"\n aria-valuetext=${isMobile\n ? ariaValueX\n : `${ariaValueX}, ${ariaLabelX}${\n this._valueChanged\n ? ''\n : `, ${ariaValueY}, ${ariaLabelY}`\n }`}\n min=\"0\"\n max=\"1\"\n step=${this.step}\n tabindex=\"-1\"\n .value=${String(this.x)}\n @input=${this.handleInput}\n @change=${this.handleChange}\n />\n </div>\n <div role=\"presentation\">\n <input\n type=\"range\"\n class=\"slider\"\n name=\"y\"\n aria-label=${isMobile ? ariaLabelY : ariaLabel}\n aria-roledescription=${ariaRoleDescription}\n aria-orientation=\"vertical\"\n aria-valuetext=${isMobile\n ? ariaValueY\n : `${ariaValueY}, ${ariaLabelY}${\n this._valueChanged\n ? ''\n : `, ${ariaValueX}, ${ariaLabelX}`\n }`}\n orient=\"vertical\"\n min=\"0\"\n max=\"1\"\n step=${this.step}\n tabindex=\"-1\"\n .value=${String(this.y)}\n @input=${this.handleInput}\n @change=${this.handleChange}\n />\n </div>\n </fieldset>\n `;\n }\n\n protected override firstUpdated(changed: PropertyValues): void {\n super.firstUpdated(changed);\n this.boundingClientRect = this.getBoundingClientRect();\n\n this.addEventListener('focus', this.handleFocus);\n this.addEventListener('blur', this.handleBlur);\n this.addEventListener('keyup', this.handleKeyup);\n this.addEventListener('keydown', this.handleKeydown);\n }\n\n protected override updated(changed: PropertyValues): void {\n super.updated(changed);\n if (this.x !== this.inputX.valueAsNumber) {\n this._x = this.inputX.valueAsNumber;\n }\n if (this.y !== this.inputY.valueAsNumber) {\n this._y = this.inputY.valueAsNumber;\n }\n if (changed.has('focused') && this.focused) {\n // Lazily bind the `input[type=\"range\"]` elements in shadow roots\n // so that browsers with certain settings (Webkit) aren't allowed\n // multiple tab stops within the Color Area.\n const parentX = this.inputX.parentElement as HTMLDivElement;\n const parentY = this.inputY.parentElement as HTMLDivElement;\n if (!parentX.shadowRoot && !parentY.shadowRoot) {\n parentX.attachShadow({ mode: 'open' });\n parentY.attachShadow({ mode: 'open' });\n const slot = '<div tabindex=\"-1\"><slot></slot></div>';\n (parentX.shadowRoot as unknown as ShadowRoot).innerHTML = slot;\n (parentY.shadowRoot as unknown as ShadowRoot).innerHTML = slot;\n }\n }\n }\n\n private observer?: WithSWCResizeObserver['ResizeObserver'];\n\n public override connectedCallback(): void {\n super.connectedCallback();\n if (\n !this.observer &&\n (window as unknown as WithSWCResizeObserver).ResizeObserver\n ) {\n this.observer = new (\n window as unknown as WithSWCResizeObserver\n ).ResizeObserver((entries: SWCResizeObserverEntry[]) => {\n for (const entry of entries) {\n this.boundingClientRect = entry.contentRect;\n }\n this.requestUpdate();\n });\n }\n this.observer?.observe(this);\n }\n\n public override disconnectedCallback(): void {\n this.observer?.unobserve(this);\n super.disconnectedCallback();\n }\n}\n"],
|
|
5
|
-
"mappings": "qNAYA,OAEI,QAAAA,EAEA,mBAAAC,MAEG,gCACP,OACI,aAAAC,EACA,YAAAC,MACG,kDACP,OACI,YAAAC,EACA,SAAAC,MACG,kDACP,OAAS,qBAAAC,MAAyB,0DAGlC,MAAO,2DACP,OACI,mBAAAC,MAEG,6DACP,OAAS,gCAAAC,MAAoC,0EAC7C,OACI,aAAAC,EACA,SAAAC,MACG,kDAEP,OAAOC,MAAY,sBAQZ,aAAM,kBAAkBV,CAAgB,CAAxC,kCASH,KAAO,SAAW,GAGlB,KAAO,QAAU,
|
|
6
|
-
"names": ["html", "SpectrumElement", "ifDefined", "styleMap", "property", "query", "streamingListener", "ColorController", "LanguageResolutionController", "isAndroid", "isIOS", "styles", "s", "v", "value", "color", "x", "oldValue", "y", "focusOptions", "event", "code", "key", "deltaX", "deltaY", "step", "valueAsNumber", "name", "applyDefault", "rect", "minOffsetX", "minOffsetY", "offsetX", "offsetY", "width", "height", "percentX", "percentY", "isMobile", "
|
|
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*/\n\nimport {\n CSSResultArray,\n html,\n PropertyValues,\n SpectrumElement,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport {\n ifDefined,\n styleMap,\n} from '@spectrum-web-components/base/src/directives.js';\nimport {\n property,\n query,\n} from '@spectrum-web-components/base/src/decorators.js';\nimport { streamingListener } from '@spectrum-web-components/base/src/streaming-listener.js';\nimport { SWCResizeObserverEntry, WithSWCResizeObserver } from './types';\nimport type { ColorHandle } from '@spectrum-web-components/color-handle';\nimport '@spectrum-web-components/color-handle/sp-color-handle.js';\nimport {\n ColorController,\n ColorValue,\n} from '@spectrum-web-components/reactive-controllers/src/Color.js';\nimport { LanguageResolutionController } from '@spectrum-web-components/reactive-controllers/src/LanguageResolution.js';\nimport {\n isAndroid,\n isIOS,\n} from '@spectrum-web-components/shared/src/platform.js';\n\nimport styles from './color-area.css.js';\n\n/**\n * @element sp-color-area\n * @slot gradient - a custom gradient visually outlining the available color values\n * @fires input - The value of the Color Area has changed.\n * @fires change - An alteration to the value of the Color Area has been committed by the user.\n */\nexport class ColorArea extends SpectrumElement {\n public static override get styles(): CSSResultArray {\n return [styles];\n }\n\n @property({ type: String, reflect: true })\n public override dir!: 'ltr' | 'rtl';\n\n @property({ type: Boolean, reflect: true })\n public disabled = false;\n\n @property({ type: Boolean, reflect: true })\n public focused = false;\n\n @property({ type: String, attribute: 'label-x' })\n public labelX = 'saturation';\n\n @property({ type: String, attribute: 'label-y' })\n public labelY = 'luminosity';\n\n @query('.handle')\n private handle!: ColorHandle;\n\n private languageResolver = new LanguageResolutionController(this);\n\n private colorController = new ColorController(this, {\n extractColorFromState: () => ({\n h: this.hue,\n s: this.x,\n v: this.y,\n }),\n applyColorToState: ({ s, v }) => {\n this._x = s;\n this._y = v;\n this.requestUpdate();\n },\n });\n\n @property({ type: Number })\n public get hue(): number {\n return this.colorController.hue;\n }\n\n public set hue(value: number) {\n this.colorController.hue = value;\n }\n\n @property({ type: String })\n public get value(): ColorValue {\n return this.colorController.color;\n }\n\n @property({ type: String })\n public get color(): ColorValue {\n return this.colorController.color;\n }\n\n public set color(color: ColorValue) {\n this.colorController.color = color;\n }\n\n @property({ attribute: false })\n private activeAxis = 'x';\n\n @property({ type: Number })\n public get x(): number {\n return this._x;\n }\n\n public set x(x: number) {\n if (x === this.x) {\n return;\n }\n const oldValue = this.x;\n if (this.inputX) {\n // Use the native `input[type='range']` control to validate this value after `firstUpdate`\n this.inputX.value = x.toString();\n this._x = this.inputX.valueAsNumber;\n } else {\n this._x = x;\n }\n this.requestUpdate('x', oldValue);\n this.colorController.applyColorFromState();\n }\n\n private _x = 1;\n\n @property({ type: Number })\n public get y(): number {\n return this._y;\n }\n\n public set y(y: number) {\n if (y === this.y) {\n return;\n }\n const oldValue = this.y;\n if (this.inputY) {\n // Use the native `input[type='range']` control to validate this value after `firstUpdate`\n this.inputY.value = y.toString();\n this._y = this.inputY.valueAsNumber;\n } else {\n this._y = y;\n }\n this.requestUpdate('y', oldValue);\n this.colorController.applyColorFromState();\n }\n\n private _y = 1;\n\n @property({ type: Number })\n public step = 0.01;\n\n @query('[name=\"x\"]')\n public inputX!: HTMLInputElement;\n\n @query('[name=\"y\"]')\n public inputY!: HTMLInputElement;\n\n private altered = 0;\n\n private activeKeys = new Set();\n\n private _valueChanged = false;\n\n public override focus(focusOptions: FocusOptions = {}): void {\n super.focus(focusOptions);\n this.forwardFocus();\n }\n\n private forwardFocus(): void {\n this.focused = this.hasVisibleFocusInTree();\n if (this.activeAxis === 'x') {\n this.inputX.focus();\n } else {\n this.inputY.focus();\n }\n }\n\n private handleFocus(): void {\n this.focused = true;\n this._valueChanged = false;\n }\n\n private handleBlur(): void {\n if (this._pointerDown) {\n return;\n }\n this.altered = 0;\n this.focused = false;\n this._valueChanged = false;\n }\n\n private handleKeydown(event: KeyboardEvent): void {\n const { code } = event;\n this.focused = true;\n this.altered = [event.shiftKey, event.ctrlKey, event.altKey].filter(\n (key) => !!key\n ).length;\n const isArrowKey =\n code.search('Arrow') === 0 ||\n code.search('Page') === 0 ||\n code.search('Home') === 0 ||\n code.search('End') === 0;\n if (isArrowKey) {\n event.preventDefault();\n this.activeKeys.add(code);\n this.handleKeypress();\n }\n }\n\n private handleKeypress(): void {\n let deltaX = 0;\n let deltaY = 0;\n const step = Math.max(this.step, this.altered * 5 * this.step);\n this.activeKeys.forEach((code) => {\n switch (code) {\n case 'ArrowUp':\n deltaY = step;\n break;\n case 'ArrowDown':\n deltaY = step * -1;\n break;\n case 'ArrowLeft':\n deltaX = this.step * (this.isLTR ? -1 : 1);\n break;\n case 'ArrowRight':\n deltaX = this.step * (this.isLTR ? 1 : -1);\n break;\n case 'PageUp':\n deltaY = step * 10;\n break;\n case 'PageDown':\n deltaY = step * -10;\n break;\n case 'Home':\n deltaX = step * (this.isLTR ? -10 : 10);\n break;\n case 'End':\n deltaX = step * (this.isLTR ? 10 : -10);\n break;\n /* c8 ignore next 2 */\n default:\n break;\n }\n });\n if (deltaX != 0) {\n this.activeAxis = 'x';\n this.inputX.focus();\n } else if (deltaY != 0) {\n this.activeAxis = 'y';\n this.inputY.focus();\n }\n this.x = Math.min(1, Math.max(this.x + deltaX, 0));\n this.y = Math.min(1, Math.max(this.y + deltaY, 0));\n\n this.colorController.savePreviousColor();\n this.colorController.applyColorFromState();\n\n if (deltaX != 0 || deltaY != 0) {\n this._valueChanged = true;\n this.dispatchEvent(\n new Event('input', {\n bubbles: true,\n composed: true,\n })\n );\n const applyDefault = this.dispatchEvent(\n new Event('change', {\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n if (!applyDefault) {\n this.colorController.restorePreviousColor();\n }\n }\n }\n\n private handleKeyup(event: KeyboardEvent): void {\n event.preventDefault();\n const { code } = event;\n this.activeKeys.delete(code);\n }\n\n private handleInput(event: Event & { target: HTMLInputElement }): void {\n const { valueAsNumber, name } = event.target;\n\n this[name as 'x' | 'y'] = valueAsNumber;\n this.colorController.applyColorFromState();\n }\n\n private handleChange(event: Event & { target: HTMLInputElement }): void {\n this.handleInput(event);\n this.dispatchEvent(\n new Event('change', {\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n }\n\n private boundingClientRect!: DOMRect;\n private _pointerDown = false;\n\n private handlePointerdown(event: PointerEvent): void {\n if (event.button !== 0) {\n event.preventDefault();\n return;\n }\n this._pointerDown = true;\n this.colorController.savePreviousColor();\n this.boundingClientRect = this.getBoundingClientRect();\n (event.target as HTMLElement).setPointerCapture(event.pointerId);\n if (event.pointerType === 'mouse') {\n this.focused = true;\n }\n }\n\n private handlePointermove(event: PointerEvent): void {\n const [x, y] = this.calculateHandlePosition(event);\n\n this._valueChanged = false;\n\n this.x = x;\n this.y = 1 - y;\n this.colorController.applyColorFromState();\n this.dispatchEvent(\n new Event('input', {\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n }\n\n private handlePointerup(event: PointerEvent): void {\n event.preventDefault();\n this._pointerDown = false;\n (event.target as HTMLElement).releasePointerCapture(event.pointerId);\n const applyDefault = this.dispatchEvent(\n new Event('change', {\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n this.inputX.focus();\n if (event.pointerType === 'mouse') {\n this.focused = false;\n }\n if (!applyDefault) {\n this.colorController.restorePreviousColor();\n }\n }\n\n /**\n * Returns the value under the cursor\n * @param: PointerEvent on slider\n * @return: Slider value that correlates to the position under the pointer\n */\n private calculateHandlePosition(event: PointerEvent): [number, number] {\n /* c8 ignore next 3 */\n if (!this.boundingClientRect) {\n return [this.x, this.y];\n }\n const rect = this.boundingClientRect;\n const minOffsetX = rect.left;\n const minOffsetY = rect.top;\n const offsetX = event.clientX;\n const offsetY = event.clientY;\n const width = rect.width;\n const height = rect.height;\n\n const percentX = Math.max(\n 0,\n Math.min(1, (offsetX - minOffsetX) / width)\n );\n const percentY = Math.max(\n 0,\n Math.min(1, (offsetY - minOffsetY) / height)\n );\n\n return [this.isLTR ? percentX : 1 - percentX, percentY];\n }\n\n private handleAreaPointerdown(event: PointerEvent): void {\n if (event.button !== 0) {\n return;\n }\n event.stopPropagation();\n event.preventDefault();\n this.handle.dispatchEvent(new PointerEvent('pointerdown', event));\n this.handlePointermove(event);\n }\n\n protected override render(): TemplateResult {\n const { width = 0, height = 0 } = this.boundingClientRect || {};\n\n const isMobile = isAndroid() || isIOS();\n const defaultAriaLabel = 'Color Picker';\n const ariaLabel = defaultAriaLabel;\n const ariaRoleDescription = ifDefined(\n isMobile ? undefined : '2d slider'\n );\n\n const ariaLabelX = this.labelX;\n const ariaLabelY = this.labelY;\n const ariaValueX = new Intl.NumberFormat(\n this.languageResolver.language,\n {\n style: 'percent',\n unitDisplay: 'narrow',\n }\n ).format(this.x);\n const ariaValueY = new Intl.NumberFormat(\n this.languageResolver.language,\n {\n style: 'percent',\n unitDisplay: 'narrow',\n }\n ).format(this.y);\n\n const style = {\n background: `linear-gradient(to top, black 0%, hsla(${this.hue}, 100%, 0.01%, 0) 100%),linear-gradient(to right, white 0%, hsla(${this.hue}, 100%, 0.01%, 0) 100%), hsl(${this.hue}, 100%, 50%);`,\n };\n\n return html`\n <div\n @pointerdown=${this.handleAreaPointerdown}\n class=\"gradient\"\n style=${styleMap(style)}\n >\n <slot name=\"gradient\"></slot>\n </div>\n\n <sp-color-handle\n tabindex=${ifDefined(this.focused ? undefined : '0')}\n @focus=${this.forwardFocus}\n ?focused=${this.focused}\n class=\"handle\"\n color=${this.colorController.getHslString()}\n ?disabled=${this.disabled}\n style=${`transform: translate(${\n (this.isLTR ? this.x : 1 - this.x) * width\n }px, ${height - this.y * height}px);`}\n ${streamingListener({\n start: ['pointerdown', this.handlePointerdown],\n streamInside: ['pointermove', this.handlePointermove],\n end: [\n ['pointerup', 'pointercancel', 'pointerleave'],\n this.handlePointerup,\n ],\n })}\n ></sp-color-handle>\n\n <fieldset\n class=\"fieldset\"\n aria-label=${ifDefined(isMobile ? ariaLabel : undefined)}\n >\n <div role=\"presentation\">\n <input\n type=\"range\"\n class=\"slider\"\n name=\"x\"\n aria-label=${isMobile\n ? ariaLabelX\n : `${ariaLabelX} ${ariaLabel}`}\n aria-roledescription=${ariaRoleDescription}\n aria-orientation=\"horizontal\"\n aria-valuetext=${isMobile\n ? ariaValueX\n : `${ariaValueX}, ${ariaLabelX}${\n this._valueChanged\n ? ''\n : `, ${ariaValueY}, ${ariaLabelY}`\n }`}\n min=\"0\"\n max=\"1\"\n step=${this.step}\n tabindex=\"-1\"\n .value=${String(this.x)}\n @input=${this.handleInput}\n @change=${this.handleChange}\n />\n </div>\n <div role=\"presentation\">\n <input\n type=\"range\"\n class=\"slider\"\n name=\"y\"\n aria-label=${isMobile\n ? ariaLabelY\n : `${ariaLabelY} ${ariaLabel}`}\n aria-roledescription=${ariaRoleDescription}\n aria-orientation=\"vertical\"\n aria-valuetext=${isMobile\n ? ariaValueY\n : `${ariaValueY}, ${ariaLabelY}${\n this._valueChanged\n ? ''\n : `, ${ariaValueX}, ${ariaLabelX}`\n }`}\n orient=\"vertical\"\n min=\"0\"\n max=\"1\"\n step=${this.step}\n tabindex=\"-1\"\n .value=${String(this.y)}\n @input=${this.handleInput}\n @change=${this.handleChange}\n />\n </div>\n </fieldset>\n `;\n }\n\n protected override firstUpdated(changed: PropertyValues): void {\n super.firstUpdated(changed);\n this.boundingClientRect = this.getBoundingClientRect();\n\n this.addEventListener('focus', this.handleFocus);\n this.addEventListener('blur', this.handleBlur);\n this.addEventListener('keyup', this.handleKeyup);\n this.addEventListener('keydown', this.handleKeydown);\n }\n\n protected override updated(changed: PropertyValues): void {\n super.updated(changed);\n if (this.x !== this.inputX.valueAsNumber) {\n this._x = this.inputX.valueAsNumber;\n }\n if (this.y !== this.inputY.valueAsNumber) {\n this._y = this.inputY.valueAsNumber;\n }\n if (changed.has('focused') && this.focused) {\n // Lazily bind the `input[type=\"range\"]` elements in shadow roots\n // so that browsers with certain settings (Webkit) aren't allowed\n // multiple tab stops within the Color Area.\n const parentX = this.inputX.parentElement as HTMLDivElement;\n const parentY = this.inputY.parentElement as HTMLDivElement;\n if (!parentX.shadowRoot && !parentY.shadowRoot) {\n parentX.attachShadow({ mode: 'open' });\n parentY.attachShadow({ mode: 'open' });\n const slot = '<div tabindex=\"-1\"><slot></slot></div>';\n (parentX.shadowRoot as unknown as ShadowRoot).innerHTML = slot;\n (parentY.shadowRoot as unknown as ShadowRoot).innerHTML = slot;\n }\n }\n }\n\n private observer?: WithSWCResizeObserver['ResizeObserver'];\n\n public override connectedCallback(): void {\n super.connectedCallback();\n if (\n !this.observer &&\n (window as unknown as WithSWCResizeObserver).ResizeObserver\n ) {\n this.observer = new (\n window as unknown as WithSWCResizeObserver\n ).ResizeObserver((entries: SWCResizeObserverEntry[]) => {\n for (const entry of entries) {\n this.boundingClientRect = entry.contentRect;\n }\n this.requestUpdate();\n });\n }\n this.observer?.observe(this);\n }\n\n public override disconnectedCallback(): void {\n this.observer?.unobserve(this);\n super.disconnectedCallback();\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["html", "SpectrumElement", "ifDefined", "styleMap", "property", "query", "streamingListener", "ColorController", "LanguageResolutionController", "isAndroid", "isIOS", "styles", "s", "v", "value", "color", "x", "oldValue", "y", "focusOptions", "event", "code", "key", "deltaX", "deltaY", "step", "valueAsNumber", "name", "applyDefault", "rect", "minOffsetX", "minOffsetY", "offsetX", "offsetY", "width", "height", "percentX", "percentY", "isMobile", "ariaLabel", "ariaRoleDescription", "ariaLabelX", "ariaLabelY", "ariaValueX", "ariaValueY", "style", "changed", "parentX", "parentY", "slot", "_a", "entries", "entry", "__decorateClass"]
|
|
7
7
|
}
|
package/test/color-area.test.js
CHANGED
|
@@ -14,31 +14,25 @@ import { spy } from "sinon";
|
|
|
14
14
|
import { testForLitDevWarnings } from "../../../test/testing-helpers.js";
|
|
15
15
|
describe("ColorArea", () => {
|
|
16
16
|
testForLitDevWarnings(
|
|
17
|
-
async () => await fixture(
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
`
|
|
21
|
-
)
|
|
17
|
+
async () => await fixture(html`
|
|
18
|
+
<sp-color-area></sp-color-area>
|
|
19
|
+
`)
|
|
22
20
|
);
|
|
23
21
|
it("loads default color-area accessibly", async () => {
|
|
24
|
-
const el = await fixture(
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
`
|
|
28
|
-
);
|
|
22
|
+
const el = await fixture(html`
|
|
23
|
+
<sp-color-area></sp-color-area>
|
|
24
|
+
`);
|
|
29
25
|
await elementUpdated(el);
|
|
30
26
|
await expect(el).to.be.accessible();
|
|
31
27
|
});
|
|
32
28
|
it("manages a single tab stop", async () => {
|
|
33
|
-
const test = await fixture(
|
|
34
|
-
|
|
35
|
-
<
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
`
|
|
41
|
-
);
|
|
29
|
+
const test = await fixture(html`
|
|
30
|
+
<div>
|
|
31
|
+
<input type="text" />
|
|
32
|
+
<sp-color-area color="hsl(100, 50%, 50%)"></sp-color-area>
|
|
33
|
+
<input type="text" />
|
|
34
|
+
</div>
|
|
35
|
+
`);
|
|
42
36
|
const el = test.querySelector("sp-color-area");
|
|
43
37
|
const input1 = test.querySelector(
|
|
44
38
|
"input:nth-of-type(1)"
|
|
@@ -81,15 +75,17 @@ describe("ColorArea", () => {
|
|
|
81
75
|
expect(document.activeElement, "before input again").to.equal(input1);
|
|
82
76
|
});
|
|
83
77
|
it("provides separate aria-labels for X and Y inputs", async () => {
|
|
84
|
-
const el = await fixture(
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
`
|
|
88
|
-
);
|
|
78
|
+
const el = await fixture(html`
|
|
79
|
+
<sp-color-area color="hsl(100, 50%, 50%)"></sp-color-area>
|
|
80
|
+
`);
|
|
89
81
|
const inputX = el.shadowRoot.querySelector('input[name="x"]');
|
|
90
82
|
const inputY = el.shadowRoot.querySelector('input[name="y"]');
|
|
91
|
-
expect(inputX == null ? void 0 : inputX.getAttribute("aria-label")).to.equal(
|
|
92
|
-
|
|
83
|
+
expect(inputX == null ? void 0 : inputX.getAttribute("aria-label")).to.equal(
|
|
84
|
+
"saturation Color Picker"
|
|
85
|
+
);
|
|
86
|
+
expect(inputY == null ? void 0 : inputY.getAttribute("aria-label")).to.equal(
|
|
87
|
+
"luminosity Color Picker"
|
|
88
|
+
);
|
|
93
89
|
expect(inputX == null ? void 0 : inputX.getAttribute("aria-roledescription")).to.equal(
|
|
94
90
|
"2d slider"
|
|
95
91
|
);
|
|
@@ -103,30 +99,27 @@ describe("ColorArea", () => {
|
|
|
103
99
|
"75%, luminosity, 67%, saturation"
|
|
104
100
|
);
|
|
105
101
|
});
|
|
106
|
-
it('overrides
|
|
107
|
-
const el = await fixture(
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
);
|
|
102
|
+
it('overrides X and Y labels with provided "labelX" and "labelY" attributes', async () => {
|
|
103
|
+
const el = await fixture(html`
|
|
104
|
+
<sp-color-area
|
|
105
|
+
color="hsl(100, 50%, 50%)"
|
|
106
|
+
label-X="custom X label"
|
|
107
|
+
label-Y="custom Y label"
|
|
108
|
+
></sp-color-area>
|
|
109
|
+
`);
|
|
115
110
|
const inputX = el.shadowRoot.querySelector('input[name="x"]');
|
|
116
111
|
const inputY = el.shadowRoot.querySelector('input[name="y"]');
|
|
117
112
|
expect(inputX == null ? void 0 : inputX.getAttribute("aria-label")).to.equal(
|
|
118
|
-
"
|
|
113
|
+
"custom X label Color Picker"
|
|
119
114
|
);
|
|
120
115
|
expect(inputY == null ? void 0 : inputY.getAttribute("aria-label")).to.equal(
|
|
121
|
-
"
|
|
116
|
+
"custom Y label Color Picker"
|
|
122
117
|
);
|
|
123
118
|
});
|
|
124
119
|
it("updates color when x value changes", async () => {
|
|
125
|
-
const el = await fixture(
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
`
|
|
129
|
-
);
|
|
120
|
+
const el = await fixture(html`
|
|
121
|
+
<sp-color-area></sp-color-area>
|
|
122
|
+
`);
|
|
130
123
|
await el.updateComplete;
|
|
131
124
|
const handle = el.shadowRoot.querySelector(".handle");
|
|
132
125
|
expect(handle.color).to.equal("hsl(0, 100%, 50%)");
|
|
@@ -135,11 +128,9 @@ describe("ColorArea", () => {
|
|
|
135
128
|
expect(handle.color).to.equal("hsl(0, 100%, 85%)");
|
|
136
129
|
});
|
|
137
130
|
it("updates color when y value changes", async () => {
|
|
138
|
-
const el = await fixture(
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
`
|
|
142
|
-
);
|
|
131
|
+
const el = await fixture(html`
|
|
132
|
+
<sp-color-area></sp-color-area>
|
|
133
|
+
`);
|
|
143
134
|
await el.updateComplete;
|
|
144
135
|
const handle = el.shadowRoot.querySelector(".handle");
|
|
145
136
|
expect(handle.color).to.equal("hsl(0, 100%, 50%)");
|
|
@@ -148,11 +139,9 @@ describe("ColorArea", () => {
|
|
|
148
139
|
expect(handle.color).to.equal("hsl(0, 100%, 35%)");
|
|
149
140
|
});
|
|
150
141
|
it("accepts `hue` values", async () => {
|
|
151
|
-
const el = await fixture(
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
`
|
|
155
|
-
);
|
|
142
|
+
const el = await fixture(html`
|
|
143
|
+
<sp-color-area></sp-color-area>
|
|
144
|
+
`);
|
|
156
145
|
await elementUpdated(el);
|
|
157
146
|
const { handle } = el;
|
|
158
147
|
expect(handle.color).to.equal("hsl(0, 100%, 50%)");
|
|
@@ -161,22 +150,18 @@ describe("ColorArea", () => {
|
|
|
161
150
|
expect(handle.color).to.equal("hsl(125, 100%, 50%)");
|
|
162
151
|
});
|
|
163
152
|
it('accepts "color" values as hsl', async () => {
|
|
164
|
-
const el = await fixture(
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
`
|
|
168
|
-
);
|
|
153
|
+
const el = await fixture(html`
|
|
154
|
+
<sp-color-area color="hsl(100, 50%, 50%)"></sp-color-area>
|
|
155
|
+
`);
|
|
169
156
|
await elementUpdated(el);
|
|
170
157
|
expect(el.hue, "hue").to.equal(100);
|
|
171
158
|
expect(el.x, "x").to.equal(0.67);
|
|
172
159
|
expect(el.y, "y").to.equal(0.75);
|
|
173
160
|
});
|
|
174
161
|
it('accepts "color" values as hsla', async () => {
|
|
175
|
-
const el = await fixture(
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
`
|
|
179
|
-
);
|
|
162
|
+
const el = await fixture(html`
|
|
163
|
+
<sp-color-area color="hsla(100, 50%, 50%, 1)"></sp-color-area>
|
|
164
|
+
`);
|
|
180
165
|
await elementUpdated(el);
|
|
181
166
|
expect(el.hue, "hugh").to.equal(100);
|
|
182
167
|
expect(el.x, "ex").to.equal(0.67);
|
|
@@ -188,33 +173,27 @@ describe("ColorArea", () => {
|
|
|
188
173
|
expect(el.y, "y 2").to.equal(0);
|
|
189
174
|
});
|
|
190
175
|
it('accepts "color" values as rgb', async () => {
|
|
191
|
-
const el = await fixture(
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
`
|
|
195
|
-
);
|
|
176
|
+
const el = await fixture(html`
|
|
177
|
+
<sp-color-area color="rgb(0,255,0)"></sp-color-area>
|
|
178
|
+
`);
|
|
196
179
|
await elementUpdated(el);
|
|
197
180
|
expect(el.hue).to.equal(120);
|
|
198
181
|
expect(el.x).to.equal(1);
|
|
199
182
|
expect(el.y).to.equal(1);
|
|
200
183
|
});
|
|
201
184
|
it('accepts "color" values as hex', async () => {
|
|
202
|
-
const el = await fixture(
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
`
|
|
206
|
-
);
|
|
185
|
+
const el = await fixture(html`
|
|
186
|
+
<sp-color-area color="#00ff00"></sp-color-area>
|
|
187
|
+
`);
|
|
207
188
|
await elementUpdated(el);
|
|
208
189
|
expect(el.hue).to.equal(120);
|
|
209
190
|
expect(el.x).to.equal(1);
|
|
210
191
|
expect(el.y).to.equal(1);
|
|
211
192
|
});
|
|
212
193
|
it('accepts "Arrow*" keypresses', async () => {
|
|
213
|
-
const el = await fixture(
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
`
|
|
217
|
-
);
|
|
194
|
+
const el = await fixture(html`
|
|
195
|
+
<sp-color-area color="hsla(100, 50%, 50%, 1)"></sp-color-area>
|
|
196
|
+
`);
|
|
218
197
|
expect(el.hue, "hue").to.equal(100);
|
|
219
198
|
expect(el.x, "x").to.equal(0.67);
|
|
220
199
|
expect(el.y, "y").to.equal(0.75);
|
|
@@ -270,11 +249,9 @@ describe("ColorArea", () => {
|
|
|
270
249
|
expect(el.y).to.equal(0.75);
|
|
271
250
|
});
|
|
272
251
|
it('accepts "Arrow*" keypresses with alteration', async () => {
|
|
273
|
-
const el = await fixture(
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
`
|
|
277
|
-
);
|
|
252
|
+
const el = await fixture(html`
|
|
253
|
+
<sp-color-area color="hsla(100, 50%, 50%, 1)"></sp-color-area>
|
|
254
|
+
`);
|
|
278
255
|
await elementUpdated(el);
|
|
279
256
|
el.focus();
|
|
280
257
|
expect(el.hue, "hue").to.equal(100);
|
|
@@ -334,13 +311,11 @@ describe("ColorArea", () => {
|
|
|
334
311
|
expect(el.y).to.equal(0.75);
|
|
335
312
|
});
|
|
336
313
|
it("accepts pointer events", async () => {
|
|
337
|
-
const el = await fixture(
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
`
|
|
343
|
-
);
|
|
314
|
+
const el = await fixture(html`
|
|
315
|
+
<sp-color-area
|
|
316
|
+
style="--mod-colorarea-height: 192px; --mod-colorarea-width: 192px;"
|
|
317
|
+
></sp-color-area>
|
|
318
|
+
`);
|
|
344
319
|
await elementUpdated(el);
|
|
345
320
|
await elementUpdated(el);
|
|
346
321
|
const { handle } = el;
|
|
@@ -427,15 +402,13 @@ describe("ColorArea", () => {
|
|
|
427
402
|
it("responds to events on the internal input element", async () => {
|
|
428
403
|
const inputSpy = spy();
|
|
429
404
|
const changeSpy = spy();
|
|
430
|
-
const el = await fixture(
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
`
|
|
438
|
-
);
|
|
405
|
+
const el = await fixture(html`
|
|
406
|
+
<sp-color-area
|
|
407
|
+
color="hsla(100, 50%, 50%, 1)"
|
|
408
|
+
@change=${() => changeSpy()}
|
|
409
|
+
@input=${() => inputSpy()}
|
|
410
|
+
></sp-color-area>
|
|
411
|
+
`);
|
|
439
412
|
await elementUpdated(el);
|
|
440
413
|
el.inputX.focus();
|
|
441
414
|
el.inputX.dispatchEvent(
|
|
@@ -473,15 +446,13 @@ describe("ColorArea", () => {
|
|
|
473
446
|
it('dispatches input and change events in response to "Arrow*" keypresses', async () => {
|
|
474
447
|
const inputSpy = spy();
|
|
475
448
|
const changeSpy = spy();
|
|
476
|
-
const el = await fixture(
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
`
|
|
484
|
-
);
|
|
449
|
+
const el = await fixture(html`
|
|
450
|
+
<sp-color-area
|
|
451
|
+
color="hsla(100, 50%, 50%, 1)"
|
|
452
|
+
@change=${() => changeSpy()}
|
|
453
|
+
@input=${() => inputSpy()}
|
|
454
|
+
></sp-color-area>
|
|
455
|
+
`);
|
|
485
456
|
await elementUpdated(el);
|
|
486
457
|
const Xvalue = Number(Number(el.inputX.value).toFixed(2));
|
|
487
458
|
const Yvalue = Number(Number(el.inputY.value).toFixed(2));
|
|
@@ -575,11 +546,9 @@ describe("ColorArea", () => {
|
|
|
575
546
|
);
|
|
576
547
|
});
|
|
577
548
|
it("retains `hue` value when s = 0 in HSL string format", async () => {
|
|
578
|
-
const el = await fixture(
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
`
|
|
582
|
-
);
|
|
549
|
+
const el = await fixture(html`
|
|
550
|
+
<sp-color-area color="hsl(100, 50%, 50%)"></sp-color-area>
|
|
551
|
+
`);
|
|
583
552
|
await elementUpdated(el);
|
|
584
553
|
expect(el.hue, "hue").to.equal(100);
|
|
585
554
|
expect(el.x, "x").to.equal(0.67);
|
|
@@ -594,11 +563,9 @@ describe("ColorArea", () => {
|
|
|
594
563
|
});
|
|
595
564
|
it("retains `hue` value when s = 0 in HSL object format", async () => {
|
|
596
565
|
let inputColor = { h: 100, s: 0.5, l: 0.5 };
|
|
597
|
-
const el = await fixture(
|
|
598
|
-
|
|
599
|
-
|
|
600
|
-
`
|
|
601
|
-
);
|
|
566
|
+
const el = await fixture(html`
|
|
567
|
+
<sp-color-area .color=${inputColor}></sp-color-area>
|
|
568
|
+
`);
|
|
602
569
|
await elementUpdated(el);
|
|
603
570
|
let outputColor = el.color;
|
|
604
571
|
const variance = 5e-5;
|
|
@@ -620,11 +587,9 @@ describe("ColorArea", () => {
|
|
|
620
587
|
expect(Math.abs(outputColor.l - inputColor.l)).to.be.lessThan(variance);
|
|
621
588
|
});
|
|
622
589
|
it("retains `hue` value when s = 0 in HSV string format", async () => {
|
|
623
|
-
const el = await fixture(
|
|
624
|
-
|
|
625
|
-
|
|
626
|
-
`
|
|
627
|
-
);
|
|
590
|
+
const el = await fixture(html`
|
|
591
|
+
<sp-color-area color="hsv(100, 50%, 50%)"></sp-color-area>
|
|
592
|
+
`);
|
|
628
593
|
await elementUpdated(el);
|
|
629
594
|
expect(el.hue, "hue").to.equal(100);
|
|
630
595
|
expect(el.x, "x").to.equal(0.5);
|
|
@@ -639,11 +604,9 @@ describe("ColorArea", () => {
|
|
|
639
604
|
});
|
|
640
605
|
it("retains `hue` value when s = 0 in HSV object format", async () => {
|
|
641
606
|
let inputColor = { h: 100, s: 0.5, v: 0.5 };
|
|
642
|
-
const el = await fixture(
|
|
643
|
-
|
|
644
|
-
|
|
645
|
-
`
|
|
646
|
-
);
|
|
607
|
+
const el = await fixture(html`
|
|
608
|
+
<sp-color-area .color=${inputColor}></sp-color-area>
|
|
609
|
+
`);
|
|
647
610
|
await elementUpdated(el);
|
|
648
611
|
let outputColor = el.color;
|
|
649
612
|
const variance = 5e-5;
|
|
@@ -688,11 +651,9 @@ describe("ColorArea", () => {
|
|
|
688
651
|
];
|
|
689
652
|
colorFormats.map((format) => {
|
|
690
653
|
it(`maintains \`color\` format as ${format.name}`, async () => {
|
|
691
|
-
const el = await fixture(
|
|
692
|
-
|
|
693
|
-
|
|
694
|
-
`
|
|
695
|
-
);
|
|
654
|
+
const el = await fixture(html`
|
|
655
|
+
<sp-color-area></sp-color-area>
|
|
656
|
+
`);
|
|
696
657
|
el.color = format.color;
|
|
697
658
|
if (format.name.startsWith("Hex")) {
|
|
698
659
|
expect(el.color).to.equal(format.color);
|
|
@@ -700,32 +661,26 @@ describe("ColorArea", () => {
|
|
|
700
661
|
});
|
|
701
662
|
});
|
|
702
663
|
it(`maintains \`color\` format as TinyColor`, async () => {
|
|
703
|
-
const el = await fixture(
|
|
704
|
-
|
|
705
|
-
|
|
706
|
-
`
|
|
707
|
-
);
|
|
664
|
+
const el = await fixture(html`
|
|
665
|
+
<sp-color-area></sp-color-area>
|
|
666
|
+
`);
|
|
708
667
|
const color = new TinyColor("rgb(204, 51, 204)");
|
|
709
668
|
el.color = color;
|
|
710
669
|
expect(color.equals(el.color));
|
|
711
670
|
});
|
|
712
671
|
it(`resolves Hex3 format to Hex6 format`, async () => {
|
|
713
|
-
const el = await fixture(
|
|
714
|
-
|
|
715
|
-
|
|
716
|
-
`
|
|
717
|
-
);
|
|
672
|
+
const el = await fixture(html`
|
|
673
|
+
<sp-color-area></sp-color-area>
|
|
674
|
+
`);
|
|
718
675
|
el.color = "0f0";
|
|
719
676
|
expect(el.color).to.equal("00ff00");
|
|
720
677
|
el.color = "#1e0";
|
|
721
678
|
expect(el.color).to.equal("#11ee00");
|
|
722
679
|
});
|
|
723
680
|
it(`resolves Hex4 format to Hex8 format`, async () => {
|
|
724
|
-
const el = await fixture(
|
|
725
|
-
|
|
726
|
-
|
|
727
|
-
`
|
|
728
|
-
);
|
|
681
|
+
const el = await fixture(html`
|
|
682
|
+
<sp-color-area></sp-color-area>
|
|
683
|
+
`);
|
|
729
684
|
el.color = "f3af";
|
|
730
685
|
expect(el.color).to.equal("ff33aaff");
|
|
731
686
|
el.color = "#f3af";
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["color-area.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*/\n\nimport {\n elementUpdated,\n expect,\n fixture,\n html,\n nextFrame,\n oneEvent,\n} from '@open-wc/testing';\nimport { HSL, HSLA, HSV, HSVA, RGB, RGBA, TinyColor } from '@ctrl/tinycolor';\n\nimport '@spectrum-web-components/color-area/sp-color-area.js';\nimport { ColorArea } from '@spectrum-web-components/color-area';\nimport { sendKeys } from '@web/test-runner-commands';\nimport { spy } from 'sinon';\nimport { ColorHandle } from '@spectrum-web-components/color-handle';\nimport { testForLitDevWarnings } from '../../../test/testing-helpers.js';\n\ndescribe('ColorArea', () => {\n testForLitDevWarnings(\n async () =>\n await fixture<ColorArea>(\n html`\n <sp-color-area></sp-color-area>\n `\n )\n );\n it('loads default color-area accessibly', async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area></sp-color-area>\n `\n );\n\n await elementUpdated(el);\n\n await expect(el).to.be.accessible();\n });\n it('manages a single tab stop', async () => {\n const test = await fixture<HTMLDivElement>(\n html`\n <div>\n <input type=\"text\" />\n <sp-color-area color=\"hsl(100, 50%, 50%)\"></sp-color-area>\n <input type=\"text\" />\n </div>\n `\n );\n const el = test.querySelector('sp-color-area') as ColorArea;\n const input1 = test.querySelector(\n 'input:nth-of-type(1)'\n ) as HTMLInputElement;\n const input2 = test.querySelector(\n 'input:nth-of-type(2)'\n ) as HTMLInputElement;\n\n await elementUpdated(el);\n\n input1.focus();\n\n expect(document.activeElement, 'before input').to.equal(input1);\n\n await sendKeys({\n press: 'Tab',\n });\n await elementUpdated(el);\n\n expect(document.activeElement, 'element').to.equal(el);\n let value = el.value;\n await sendKeys({\n press: 'ArrowRight',\n });\n await elementUpdated(el);\n expect(el.value).to.not.equal(value);\n await sendKeys({\n press: 'Tab',\n });\n await elementUpdated(el);\n\n expect(document.activeElement, 'after input').to.equal(input2);\n\n await sendKeys({\n press: 'Shift+Tab',\n });\n await elementUpdated(el);\n\n expect(document.activeElement, 'element again').to.equal(el);\n\n value = el.value;\n await sendKeys({\n press: 'ArrowDown',\n });\n expect(el.value).to.not.equal(value);\n await sendKeys({\n press: 'Shift+Tab',\n });\n expect(document.activeElement, 'before input again').to.equal(input1);\n });\n it('provides separate aria-labels for X and Y inputs', async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area color=\"hsl(100, 50%, 50%)\"></sp-color-area>\n `\n );\n const inputX = el.shadowRoot.querySelector('input[name=\"x\"]');\n const inputY = el.shadowRoot.querySelector('input[name=\"y\"]');\n\n expect(inputX?.getAttribute('aria-label')).to.equal('Color Picker');\n expect(inputY?.getAttribute('aria-label')).to.equal('Color Picker');\n expect(inputX?.getAttribute('aria-roledescription')).to.equal(\n '2d slider'\n );\n expect(inputY?.getAttribute('aria-roledescription')).to.equal(\n '2d slider'\n );\n expect(inputX?.getAttribute('aria-valuetext')).to.equal(\n '67%, saturation, 75%, luminosity'\n );\n expect(inputY?.getAttribute('aria-valuetext')).to.equal(\n '75%, luminosity, 67%, saturation'\n );\n });\n it('overrides both X and Y labels with a provided \"label\" attribute', async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area\n color=\"hsl(100, 50%, 50%)\"\n label=\"something custom\"\n ></sp-color-area>\n `\n );\n const inputX = el.shadowRoot.querySelector('input[name=\"x\"]');\n const inputY = el.shadowRoot.querySelector('input[name=\"y\"]');\n\n expect(inputX?.getAttribute('aria-label')).to.equal(\n 'something custom Color Picker'\n );\n expect(inputY?.getAttribute('aria-label')).to.equal(\n 'something custom Color Picker'\n );\n });\n it('updates color when x value changes', async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area></sp-color-area>\n `\n );\n\n await el.updateComplete;\n\n const handle = el.shadowRoot.querySelector('.handle') as ColorHandle;\n\n expect(handle.color).to.equal('hsl(0, 100%, 50%)');\n el.x = 0.3;\n await el.updateComplete;\n expect(handle.color).to.equal('hsl(0, 100%, 85%)');\n });\n it('updates color when y value changes', async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area></sp-color-area>\n `\n );\n\n await el.updateComplete;\n\n const handle = el.shadowRoot.querySelector('.handle') as ColorHandle;\n\n expect(handle.color).to.equal('hsl(0, 100%, 50%)');\n el.y = 0.7;\n await el.updateComplete;\n expect(handle.color).to.equal('hsl(0, 100%, 35%)');\n });\n it('accepts `hue` values', async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area></sp-color-area>\n `\n );\n\n await elementUpdated(el);\n\n const { handle } = el as unknown as { handle: ColorHandle };\n\n expect(handle.color).to.equal('hsl(0, 100%, 50%)');\n\n el.hue = 125;\n\n await elementUpdated(el);\n\n expect(handle.color).to.equal('hsl(125, 100%, 50%)');\n });\n it('accepts \"color\" values as hsl', async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area color=\"hsl(100, 50%, 50%)\"></sp-color-area>\n `\n );\n\n await elementUpdated(el);\n\n expect(el.hue, 'hue').to.equal(100);\n expect(el.x, 'x').to.equal(0.67);\n expect(el.y, 'y').to.equal(0.75);\n });\n it('accepts \"color\" values as hsla', async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area color=\"hsla(100, 50%, 50%, 1)\"></sp-color-area>\n `\n );\n\n await elementUpdated(el);\n\n expect(el.hue, 'hugh').to.equal(100);\n expect(el.x, 'ex').to.equal(0.67);\n expect(el.y, 'why').to.equal(0.75);\n\n el.color = 'hsla(120, 100%, 0, 1)';\n await elementUpdated(el);\n\n expect(el.hue, 'hue 2').to.equal(120);\n expect(el.x, 'x 2').to.equal(0);\n expect(el.y, 'y 2').to.equal(0);\n });\n it('accepts \"color\" values as rgb', async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area color=\"rgb(0,255,0)\"></sp-color-area>\n `\n );\n\n await elementUpdated(el);\n\n expect(el.hue).to.equal(120);\n expect(el.x).to.equal(1);\n expect(el.y).to.equal(1);\n });\n it('accepts \"color\" values as hex', async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area color=\"#00ff00\"></sp-color-area>\n `\n );\n\n await elementUpdated(el);\n\n expect(el.hue).to.equal(120);\n expect(el.x).to.equal(1);\n expect(el.y).to.equal(1);\n });\n it('accepts \"Arrow*\" keypresses', async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area color=\"hsla(100, 50%, 50%, 1)\"></sp-color-area>\n `\n );\n\n expect(el.hue, 'hue').to.equal(100);\n expect(el.x, 'x').to.equal(0.67);\n expect(el.y, 'y').to.equal(0.75);\n\n el.inputX.focus();\n await nextFrame();\n\n let changeEvent = oneEvent(el, 'change');\n await sendKeys({\n press: 'ArrowUp',\n });\n await changeEvent;\n changeEvent = oneEvent(el, 'change');\n await sendKeys({\n press: 'ArrowUp',\n });\n await changeEvent;\n\n expect(el.x).to.equal(0.67);\n expect(el.y).to.equal(0.77);\n\n changeEvent = oneEvent(el, 'change');\n await sendKeys({\n press: 'ArrowRight',\n });\n await changeEvent;\n changeEvent = oneEvent(el, 'change');\n await sendKeys({\n press: 'ArrowRight',\n });\n await changeEvent;\n\n expect(el.x).to.equal(0.69);\n expect(el.y).to.equal(0.77);\n\n changeEvent = oneEvent(el, 'change');\n await sendKeys({\n press: 'ArrowDown',\n });\n await changeEvent;\n changeEvent = oneEvent(el, 'change');\n await sendKeys({\n press: 'ArrowDown',\n });\n await changeEvent;\n\n expect(el.x).to.equal(0.69);\n expect(el.y).to.equal(0.75);\n\n changeEvent = oneEvent(el, 'change');\n await sendKeys({\n press: 'ArrowLeft',\n });\n await changeEvent;\n changeEvent = oneEvent(el, 'change');\n await sendKeys({\n press: 'ArrowLeft',\n });\n await changeEvent;\n\n expect(el.x).to.equal(0.67);\n expect(el.y).to.equal(0.75);\n });\n it('accepts \"Arrow*\" keypresses with alteration', async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area color=\"hsla(100, 50%, 50%, 1)\"></sp-color-area>\n `\n );\n\n await elementUpdated(el);\n el.focus();\n expect(el.hue, 'hue').to.equal(100);\n expect(el.x, 'x').to.equal(0.67);\n expect(el.y, 'y').to.equal(0.75);\n\n await sendKeys({\n down: 'Shift',\n });\n await elementUpdated(el);\n await sendKeys({\n press: 'ArrowUp',\n });\n // This ensures that all the keystrokes are processed seperately\n await elementUpdated(el);\n await sendKeys({\n press: 'ArrowUp',\n });\n\n await elementUpdated(el);\n\n expect(el.color).to.equal('hsl(100, 65%, 57%)');\n expect(el.x, 'first').to.equal(0.67);\n expect(el.y).to.equal(0.85);\n\n await sendKeys({\n press: 'ArrowRight',\n });\n await elementUpdated(el);\n await sendKeys({\n press: 'ArrowRight',\n });\n await elementUpdated(el);\n\n expect(el.color).to.equal('hsl(100, 66%, 56%)');\n expect(el.x).to.equal(0.69);\n expect(el.y).to.equal(0.85);\n\n await sendKeys({\n press: 'ArrowDown',\n });\n await elementUpdated(el);\n await sendKeys({\n press: 'ArrowDown',\n });\n\n await elementUpdated(el);\n\n expect(el.color).to.equal('hsl(100, 53%, 49%)');\n expect(el.x).to.equal(0.69);\n expect(el.y).to.equal(0.75);\n\n await sendKeys({\n press: 'ArrowLeft',\n });\n await elementUpdated(el);\n await sendKeys({\n press: 'ArrowLeft',\n });\n await elementUpdated(el);\n await sendKeys({\n up: 'Shift',\n });\n\n await elementUpdated(el);\n\n expect(el.color).to.equal('hsl(100, 50%, 50%)');\n expect(el.x, 'last').to.equal(0.67);\n expect(el.y).to.equal(0.75);\n });\n it('accepts pointer events', async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area\n style=\"--mod-colorarea-height: 192px; --mod-colorarea-width: 192px;\"\n ></sp-color-area>\n `\n );\n\n await elementUpdated(el);\n await elementUpdated(el);\n\n const { handle } = el as unknown as { handle: HTMLElement };\n\n handle.setPointerCapture = () => {\n return;\n };\n handle.releasePointerCapture = () => {\n return;\n };\n\n expect(el.hue).to.equal(0);\n expect(el.x).to.equal(1);\n expect(el.y).to.equal(1);\n\n handle.dispatchEvent(\n new PointerEvent('pointerdown', {\n button: 1,\n pointerId: 1,\n clientX: 100,\n clientY: 100,\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n\n await elementUpdated(el);\n\n expect(el.hue).to.equal(0);\n expect(el.x).to.equal(1);\n expect(el.y).to.equal(1);\n\n const root = el.shadowRoot ? el.shadowRoot : el;\n const gradient = root.querySelector('.gradient') as HTMLElement;\n gradient.dispatchEvent(\n new PointerEvent('pointerdown', {\n button: 1,\n pointerId: 1,\n clientX: 100,\n clientY: 100,\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n\n await elementUpdated(el);\n\n expect(el.hue).to.equal(0);\n expect(el.x).to.equal(1);\n expect(el.y).to.equal(1);\n\n gradient.dispatchEvent(\n new PointerEvent('pointerdown', {\n pointerId: 1,\n clientX: 100,\n clientY: 100,\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n\n await elementUpdated(el);\n\n expect(el.hue).to.equal(0);\n expect(el.x, 'pointerdown x').to.equal(0.48);\n expect(el.y, 'pointerdown y').to.equal(0.52);\n\n handle.dispatchEvent(\n new PointerEvent('pointermove', {\n pointerId: 1,\n clientX: 110,\n clientY: 110,\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n handle.dispatchEvent(\n new PointerEvent('pointerup', {\n pointerId: 1,\n clientX: 110,\n clientY: 110,\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n\n await elementUpdated(el);\n\n expect(el.hue).to.equal(0);\n expect(el.x).to.equal(0.53);\n expect(el.y).to.equal(0.47);\n });\n it('responds to events on the internal input element', async () => {\n const inputSpy = spy();\n const changeSpy = spy();\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area\n color=\"hsla(100, 50%, 50%, 1)\"\n @change=${() => changeSpy()}\n @input=${() => inputSpy()}\n ></sp-color-area>\n `\n );\n\n await elementUpdated(el);\n\n el.inputX.focus();\n\n el.inputX.dispatchEvent(\n new Event('input', {\n bubbles: true,\n composed: true,\n })\n );\n el.inputX.dispatchEvent(\n new Event('change', {\n bubbles: true,\n composed: false, // native change events do not compose themselves by default\n })\n );\n\n expect(inputSpy.callCount).to.equal(1);\n expect(changeSpy.callCount).to.equal(1);\n\n el.inputY.focus();\n\n el.inputY.dispatchEvent(\n new Event('input', {\n bubbles: true,\n composed: true,\n })\n );\n el.inputY.dispatchEvent(\n new Event('change', {\n bubbles: true,\n composed: false, // native change events do not compose themselves by default\n })\n );\n\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n });\n it('dispatches input and change events in response to \"Arrow*\" keypresses', async () => {\n const inputSpy = spy();\n const changeSpy = spy();\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area\n color=\"hsla(100, 50%, 50%, 1)\"\n @change=${() => changeSpy()}\n @input=${() => inputSpy()}\n ></sp-color-area>\n `\n );\n\n await elementUpdated(el);\n const Xvalue = Number(Number(el.inputX.value).toFixed(2));\n const Yvalue = Number(Number(el.inputY.value).toFixed(2));\n\n el.inputX.focus();\n inputSpy.resetHistory();\n changeSpy.resetHistory();\n await sendKeys({ press: 'ArrowRight' });\n await sendKeys({ press: 'ArrowRight' });\n\n await elementUpdated(el);\n\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n expect(parseFloat(el.inputX.value).toFixed(2)).to.equal(\n (Xvalue + 0.02).toFixed(2)\n );\n\n el.inputY.focus();\n inputSpy.resetHistory();\n changeSpy.resetHistory();\n await sendKeys({ press: 'ArrowUp' });\n await sendKeys({ press: 'ArrowUp' });\n\n await elementUpdated(el);\n\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n expect(parseFloat(el.inputY.value).toFixed(2)).to.equal(\n (Yvalue + 0.02).toFixed(2)\n );\n\n el.inputY.focus();\n inputSpy.resetHistory();\n changeSpy.resetHistory();\n await sendKeys({ press: 'ArrowDown' });\n await sendKeys({ press: 'ArrowDown' });\n\n await elementUpdated(el);\n\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n expect(parseFloat(el.inputY.value).toFixed(2)).to.equal(\n Yvalue.toFixed(2)\n );\n\n el.inputX.focus();\n inputSpy.resetHistory();\n changeSpy.resetHistory();\n\n await sendKeys({ press: 'ArrowLeft' });\n await sendKeys({ press: 'ArrowLeft' });\n\n await elementUpdated(el);\n //expect(el.x).to.be.equal(0.98);\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n expect(parseFloat(el.inputX.value).toFixed(2)).to.equal(\n Xvalue.toFixed(2)\n );\n\n el.inputX.focus();\n inputSpy.resetHistory();\n changeSpy.resetHistory();\n await sendKeys({ press: 'End' });\n await sendKeys({ press: 'End' });\n\n await elementUpdated(el);\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n expect(parseFloat(el.inputX.value).toFixed(2)).to.equal(\n (Xvalue + 0.2).toFixed(2)\n );\n\n el.inputX.focus();\n inputSpy.resetHistory();\n changeSpy.resetHistory();\n await sendKeys({ press: 'Home' });\n await sendKeys({ press: 'Home' });\n\n await elementUpdated(el);\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n expect(parseFloat(el.inputX.value).toFixed(2)).to.equal(\n Xvalue.toFixed(2)\n );\n\n el.inputY.focus();\n inputSpy.resetHistory();\n changeSpy.resetHistory();\n await sendKeys({ press: 'PageUp' });\n await sendKeys({ press: 'PageUp' });\n\n await elementUpdated(el);\n\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n expect(parseFloat(el.inputY.value).toFixed(2)).to.equal(\n (Yvalue + 0.2).toFixed(2)\n );\n\n el.inputY.focus();\n inputSpy.resetHistory();\n changeSpy.resetHistory();\n await sendKeys({ press: 'PageDown' });\n await sendKeys({ press: 'PageDown' });\n\n await elementUpdated(el);\n\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n expect(parseFloat(el.inputY.value).toFixed(2)).to.equal(\n Yvalue.toFixed(2)\n );\n });\n it('retains `hue` value when s = 0 in HSL string format', async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area color=\"hsl(100, 50%, 50%)\"></sp-color-area>\n `\n );\n\n await elementUpdated(el);\n\n expect(el.hue, 'hue').to.equal(100);\n expect(el.x, 'x').to.equal(0.67);\n expect(el.y, 'y').to.equal(0.75);\n expect(el.color).to.equal('hsl(100, 50%, 50%)');\n\n el.color = 'hsl(100, 0%, 50%)';\n await elementUpdated(el);\n\n expect(el.hue, 'new hue').to.equal(100);\n expect(el.x, 'new x').to.equal(0);\n expect(el.y, 'new y').to.equal(0.5);\n expect(el.color).to.equal('hsl(100, 0%, 50%)');\n });\n it('retains `hue` value when s = 0 in HSL object format', async () => {\n let inputColor = { h: 100, s: 0.5, l: 0.5 };\n\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area .color=${inputColor}></sp-color-area>\n `\n );\n\n await elementUpdated(el);\n\n let outputColor = el.color as { h: number; s: number; l: number };\n const variance = 0.00005;\n\n expect(el.hue).to.equal(100);\n expect(el.x, 'x').to.equal(0.67);\n expect(el.y, 'y').to.equal(0.75);\n\n expect(Math.abs(outputColor.h - inputColor.h)).to.be.lessThan(variance);\n expect(Math.abs(outputColor.s - inputColor.s)).to.be.lessThan(variance);\n expect(Math.abs(outputColor.l - inputColor.l)).to.be.lessThan(variance);\n\n inputColor = { h: 100, s: 0, l: 0.5 };\n el.color = inputColor;\n\n await elementUpdated(el);\n outputColor = el.color as { h: number; s: number; l: number };\n\n expect(el.hue).to.equal(100);\n expect(el.x, 'x').to.equal(0);\n expect(el.y, 'y').to.equal(0.5);\n\n expect(Math.abs(outputColor.h - inputColor.h)).to.be.lessThan(variance);\n expect(Math.abs(outputColor.s - inputColor.s)).to.be.lessThan(variance);\n expect(Math.abs(outputColor.l - inputColor.l)).to.be.lessThan(variance);\n });\n it('retains `hue` value when s = 0 in HSV string format', async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area color=\"hsv(100, 50%, 50%)\"></sp-color-area>\n `\n );\n\n await elementUpdated(el);\n\n expect(el.hue, 'hue').to.equal(100);\n expect(el.x, 'x').to.equal(0.5);\n expect(el.y, 'y').to.equal(0.5);\n expect(el.color).to.equal('hsv(100, 50%, 50%)');\n\n el.color = 'hsv(100, 0%, 50%)';\n await elementUpdated(el);\n\n expect(el.hue, 'new hue').to.equal(100);\n expect(el.x, 'new x').to.equal(0);\n expect(el.y, 'new y').to.equal(0.5);\n expect(el.color).to.equal('hsv(100, 0%, 50%)');\n });\n it('retains `hue` value when s = 0 in HSV object format', async () => {\n let inputColor = { h: 100, s: 0.5, v: 0.5 };\n\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area .color=${inputColor}></sp-color-area>\n `\n );\n\n await elementUpdated(el);\n\n let outputColor = el.color as { h: number; s: number; v: number };\n const variance = 0.00005;\n\n expect(el.hue).to.equal(100);\n expect(el.x, 'x').to.equal(0.5);\n expect(el.y, 'y').to.equal(0.5);\n\n expect(Math.abs(outputColor.h - inputColor.h)).to.be.lessThan(variance);\n expect(Math.abs(outputColor.s - inputColor.s)).to.be.lessThan(variance);\n expect(Math.abs(outputColor.v - inputColor.v)).to.be.lessThan(variance);\n\n inputColor = { h: 100, s: 0, v: 0.5 };\n el.color = inputColor;\n\n await elementUpdated(el);\n outputColor = el.color as { h: number; s: number; v: number };\n\n expect(el.hue).to.equal(100);\n expect(el.x, 'x').to.equal(0);\n expect(el.y, 'y').to.equal(0.5);\n\n expect(Math.abs(outputColor.h - inputColor.h)).to.be.lessThan(variance);\n expect(Math.abs(outputColor.s - inputColor.s)).to.be.lessThan(variance);\n expect(Math.abs(outputColor.v - inputColor.v)).to.be.lessThan(variance);\n });\n const colorFormats: {\n name: string;\n color:\n | string\n | number\n | TinyColor\n | HSVA\n | HSV\n | RGB\n | RGBA\n | HSL\n | HSLA;\n }[] = [\n //rgb\n { name: 'RGB String', color: 'rgb(204, 51, 204)' },\n { name: 'RGB', color: { r: 204, g: 51, b: 204, a: 1 } },\n //prgb\n { name: 'PRGB String', color: 'rgb(80%, 20%, 80%)' },\n { name: 'PRGB', color: { r: '80%', g: '20%', b: '80%', a: 1 } },\n // hex\n { name: 'Hex', color: 'cc33cc' },\n { name: 'Hex String', color: '#cc33cc' },\n // hex8\n { name: 'Hex8', color: 'cc33ccff' },\n { name: 'Hex8 String', color: '#cc33ccff' },\n // name\n { name: 'string', color: 'red' },\n // hsl\n { name: 'HSL String', color: 'hsl(300, 60%, 50%)' },\n { name: 'HSL', color: { h: 300, s: 0.6000000000000001, l: 0.5, a: 1 } },\n // hsv\n { name: 'HSV String', color: 'hsv(300, 75%, 100%)' },\n { name: 'HSV', color: { h: 300, s: 0.75, v: 1, a: 1 } },\n ];\n colorFormats.map((format) => {\n it(`maintains \\`color\\` format as ${format.name}`, async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area></sp-color-area>\n `\n );\n\n el.color = format.color;\n if (format.name.startsWith('Hex')) {\n expect(el.color).to.equal(format.color);\n } else expect(el.color).to.deep.equal(format.color);\n });\n });\n it(`maintains \\`color\\` format as TinyColor`, async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area></sp-color-area>\n `\n );\n const color = new TinyColor('rgb(204, 51, 204)');\n el.color = color;\n expect(color.equals(el.color));\n });\n it(`resolves Hex3 format to Hex6 format`, async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area></sp-color-area>\n `\n );\n el.color = '0f0';\n expect(el.color).to.equal('00ff00');\n\n el.color = '#1e0';\n expect(el.color).to.equal('#11ee00');\n });\n it(`resolves Hex4 format to Hex8 format`, async () => {\n const el = await fixture<ColorArea>(\n html`\n <sp-color-area></sp-color-area>\n `\n );\n el.color = 'f3af';\n expect(el.color).to.equal('ff33aaff');\n\n el.color = '#f3af';\n expect(el.color).to.equal('#ff33aaff');\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*/\n\nimport {\n elementUpdated,\n expect,\n fixture,\n html,\n nextFrame,\n oneEvent,\n} from '@open-wc/testing';\nimport { HSL, HSLA, HSV, HSVA, RGB, RGBA, TinyColor } from '@ctrl/tinycolor';\n\nimport '@spectrum-web-components/color-area/sp-color-area.js';\nimport { ColorArea } from '@spectrum-web-components/color-area';\nimport { sendKeys } from '@web/test-runner-commands';\nimport { spy } from 'sinon';\nimport { ColorHandle } from '@spectrum-web-components/color-handle';\nimport { testForLitDevWarnings } from '../../../test/testing-helpers.js';\n\ndescribe('ColorArea', () => {\n testForLitDevWarnings(\n async () =>\n await fixture<ColorArea>(html`\n <sp-color-area></sp-color-area>\n `)\n );\n it('loads default color-area accessibly', async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area></sp-color-area>\n `);\n\n await elementUpdated(el);\n\n await expect(el).to.be.accessible();\n });\n it('manages a single tab stop', async () => {\n const test = await fixture<HTMLDivElement>(html`\n <div>\n <input type=\"text\" />\n <sp-color-area color=\"hsl(100, 50%, 50%)\"></sp-color-area>\n <input type=\"text\" />\n </div>\n `);\n const el = test.querySelector('sp-color-area') as ColorArea;\n const input1 = test.querySelector(\n 'input:nth-of-type(1)'\n ) as HTMLInputElement;\n const input2 = test.querySelector(\n 'input:nth-of-type(2)'\n ) as HTMLInputElement;\n\n await elementUpdated(el);\n\n input1.focus();\n\n expect(document.activeElement, 'before input').to.equal(input1);\n\n await sendKeys({\n press: 'Tab',\n });\n await elementUpdated(el);\n\n expect(document.activeElement, 'element').to.equal(el);\n let value = el.value;\n await sendKeys({\n press: 'ArrowRight',\n });\n await elementUpdated(el);\n expect(el.value).to.not.equal(value);\n await sendKeys({\n press: 'Tab',\n });\n await elementUpdated(el);\n\n expect(document.activeElement, 'after input').to.equal(input2);\n\n await sendKeys({\n press: 'Shift+Tab',\n });\n await elementUpdated(el);\n\n expect(document.activeElement, 'element again').to.equal(el);\n\n value = el.value;\n await sendKeys({\n press: 'ArrowDown',\n });\n expect(el.value).to.not.equal(value);\n await sendKeys({\n press: 'Shift+Tab',\n });\n expect(document.activeElement, 'before input again').to.equal(input1);\n });\n it('provides separate aria-labels for X and Y inputs', async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area color=\"hsl(100, 50%, 50%)\"></sp-color-area>\n `);\n const inputX = el.shadowRoot.querySelector('input[name=\"x\"]');\n const inputY = el.shadowRoot.querySelector('input[name=\"y\"]');\n\n expect(inputX?.getAttribute('aria-label')).to.equal(\n 'saturation Color Picker'\n );\n expect(inputY?.getAttribute('aria-label')).to.equal(\n 'luminosity Color Picker'\n );\n expect(inputX?.getAttribute('aria-roledescription')).to.equal(\n '2d slider'\n );\n expect(inputY?.getAttribute('aria-roledescription')).to.equal(\n '2d slider'\n );\n expect(inputX?.getAttribute('aria-valuetext')).to.equal(\n '67%, saturation, 75%, luminosity'\n );\n expect(inputY?.getAttribute('aria-valuetext')).to.equal(\n '75%, luminosity, 67%, saturation'\n );\n });\n it('overrides X and Y labels with provided \"labelX\" and \"labelY\" attributes', async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area\n color=\"hsl(100, 50%, 50%)\"\n label-X=\"custom X label\"\n label-Y=\"custom Y label\"\n ></sp-color-area>\n `);\n const inputX = el.shadowRoot.querySelector('input[name=\"x\"]');\n const inputY = el.shadowRoot.querySelector('input[name=\"y\"]');\n\n expect(inputX?.getAttribute('aria-label')).to.equal(\n 'custom X label Color Picker'\n );\n expect(inputY?.getAttribute('aria-label')).to.equal(\n 'custom Y label Color Picker'\n );\n });\n it('updates color when x value changes', async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area></sp-color-area>\n `);\n\n await el.updateComplete;\n\n const handle = el.shadowRoot.querySelector('.handle') as ColorHandle;\n\n expect(handle.color).to.equal('hsl(0, 100%, 50%)');\n el.x = 0.3;\n await el.updateComplete;\n expect(handle.color).to.equal('hsl(0, 100%, 85%)');\n });\n it('updates color when y value changes', async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area></sp-color-area>\n `);\n\n await el.updateComplete;\n\n const handle = el.shadowRoot.querySelector('.handle') as ColorHandle;\n\n expect(handle.color).to.equal('hsl(0, 100%, 50%)');\n el.y = 0.7;\n await el.updateComplete;\n expect(handle.color).to.equal('hsl(0, 100%, 35%)');\n });\n it('accepts `hue` values', async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area></sp-color-area>\n `);\n\n await elementUpdated(el);\n\n const { handle } = el as unknown as { handle: ColorHandle };\n\n expect(handle.color).to.equal('hsl(0, 100%, 50%)');\n\n el.hue = 125;\n\n await elementUpdated(el);\n\n expect(handle.color).to.equal('hsl(125, 100%, 50%)');\n });\n it('accepts \"color\" values as hsl', async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area color=\"hsl(100, 50%, 50%)\"></sp-color-area>\n `);\n\n await elementUpdated(el);\n\n expect(el.hue, 'hue').to.equal(100);\n expect(el.x, 'x').to.equal(0.67);\n expect(el.y, 'y').to.equal(0.75);\n });\n it('accepts \"color\" values as hsla', async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area color=\"hsla(100, 50%, 50%, 1)\"></sp-color-area>\n `);\n\n await elementUpdated(el);\n\n expect(el.hue, 'hugh').to.equal(100);\n expect(el.x, 'ex').to.equal(0.67);\n expect(el.y, 'why').to.equal(0.75);\n\n el.color = 'hsla(120, 100%, 0, 1)';\n await elementUpdated(el);\n\n expect(el.hue, 'hue 2').to.equal(120);\n expect(el.x, 'x 2').to.equal(0);\n expect(el.y, 'y 2').to.equal(0);\n });\n it('accepts \"color\" values as rgb', async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area color=\"rgb(0,255,0)\"></sp-color-area>\n `);\n\n await elementUpdated(el);\n\n expect(el.hue).to.equal(120);\n expect(el.x).to.equal(1);\n expect(el.y).to.equal(1);\n });\n it('accepts \"color\" values as hex', async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area color=\"#00ff00\"></sp-color-area>\n `);\n\n await elementUpdated(el);\n\n expect(el.hue).to.equal(120);\n expect(el.x).to.equal(1);\n expect(el.y).to.equal(1);\n });\n it('accepts \"Arrow*\" keypresses', async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area color=\"hsla(100, 50%, 50%, 1)\"></sp-color-area>\n `);\n\n expect(el.hue, 'hue').to.equal(100);\n expect(el.x, 'x').to.equal(0.67);\n expect(el.y, 'y').to.equal(0.75);\n\n el.inputX.focus();\n await nextFrame();\n\n let changeEvent = oneEvent(el, 'change');\n await sendKeys({\n press: 'ArrowUp',\n });\n await changeEvent;\n changeEvent = oneEvent(el, 'change');\n await sendKeys({\n press: 'ArrowUp',\n });\n await changeEvent;\n\n expect(el.x).to.equal(0.67);\n expect(el.y).to.equal(0.77);\n\n changeEvent = oneEvent(el, 'change');\n await sendKeys({\n press: 'ArrowRight',\n });\n await changeEvent;\n changeEvent = oneEvent(el, 'change');\n await sendKeys({\n press: 'ArrowRight',\n });\n await changeEvent;\n\n expect(el.x).to.equal(0.69);\n expect(el.y).to.equal(0.77);\n\n changeEvent = oneEvent(el, 'change');\n await sendKeys({\n press: 'ArrowDown',\n });\n await changeEvent;\n changeEvent = oneEvent(el, 'change');\n await sendKeys({\n press: 'ArrowDown',\n });\n await changeEvent;\n\n expect(el.x).to.equal(0.69);\n expect(el.y).to.equal(0.75);\n\n changeEvent = oneEvent(el, 'change');\n await sendKeys({\n press: 'ArrowLeft',\n });\n await changeEvent;\n changeEvent = oneEvent(el, 'change');\n await sendKeys({\n press: 'ArrowLeft',\n });\n await changeEvent;\n\n expect(el.x).to.equal(0.67);\n expect(el.y).to.equal(0.75);\n });\n it('accepts \"Arrow*\" keypresses with alteration', async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area color=\"hsla(100, 50%, 50%, 1)\"></sp-color-area>\n `);\n\n await elementUpdated(el);\n el.focus();\n expect(el.hue, 'hue').to.equal(100);\n expect(el.x, 'x').to.equal(0.67);\n expect(el.y, 'y').to.equal(0.75);\n\n await sendKeys({\n down: 'Shift',\n });\n await elementUpdated(el);\n await sendKeys({\n press: 'ArrowUp',\n });\n // This ensures that all the keystrokes are processed seperately\n await elementUpdated(el);\n await sendKeys({\n press: 'ArrowUp',\n });\n\n await elementUpdated(el);\n\n expect(el.color).to.equal('hsl(100, 65%, 57%)');\n expect(el.x, 'first').to.equal(0.67);\n expect(el.y).to.equal(0.85);\n\n await sendKeys({\n press: 'ArrowRight',\n });\n await elementUpdated(el);\n await sendKeys({\n press: 'ArrowRight',\n });\n await elementUpdated(el);\n\n expect(el.color).to.equal('hsl(100, 66%, 56%)');\n expect(el.x).to.equal(0.69);\n expect(el.y).to.equal(0.85);\n\n await sendKeys({\n press: 'ArrowDown',\n });\n await elementUpdated(el);\n await sendKeys({\n press: 'ArrowDown',\n });\n\n await elementUpdated(el);\n\n expect(el.color).to.equal('hsl(100, 53%, 49%)');\n expect(el.x).to.equal(0.69);\n expect(el.y).to.equal(0.75);\n\n await sendKeys({\n press: 'ArrowLeft',\n });\n await elementUpdated(el);\n await sendKeys({\n press: 'ArrowLeft',\n });\n await elementUpdated(el);\n await sendKeys({\n up: 'Shift',\n });\n\n await elementUpdated(el);\n\n expect(el.color).to.equal('hsl(100, 50%, 50%)');\n expect(el.x, 'last').to.equal(0.67);\n expect(el.y).to.equal(0.75);\n });\n it('accepts pointer events', async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area\n style=\"--mod-colorarea-height: 192px; --mod-colorarea-width: 192px;\"\n ></sp-color-area>\n `);\n\n await elementUpdated(el);\n await elementUpdated(el);\n\n const { handle } = el as unknown as { handle: HTMLElement };\n\n handle.setPointerCapture = () => {\n return;\n };\n handle.releasePointerCapture = () => {\n return;\n };\n\n expect(el.hue).to.equal(0);\n expect(el.x).to.equal(1);\n expect(el.y).to.equal(1);\n\n handle.dispatchEvent(\n new PointerEvent('pointerdown', {\n button: 1,\n pointerId: 1,\n clientX: 100,\n clientY: 100,\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n\n await elementUpdated(el);\n\n expect(el.hue).to.equal(0);\n expect(el.x).to.equal(1);\n expect(el.y).to.equal(1);\n\n const root = el.shadowRoot ? el.shadowRoot : el;\n const gradient = root.querySelector('.gradient') as HTMLElement;\n gradient.dispatchEvent(\n new PointerEvent('pointerdown', {\n button: 1,\n pointerId: 1,\n clientX: 100,\n clientY: 100,\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n\n await elementUpdated(el);\n\n expect(el.hue).to.equal(0);\n expect(el.x).to.equal(1);\n expect(el.y).to.equal(1);\n\n gradient.dispatchEvent(\n new PointerEvent('pointerdown', {\n pointerId: 1,\n clientX: 100,\n clientY: 100,\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n\n await elementUpdated(el);\n\n expect(el.hue).to.equal(0);\n expect(el.x, 'pointerdown x').to.equal(0.48);\n expect(el.y, 'pointerdown y').to.equal(0.52);\n\n handle.dispatchEvent(\n new PointerEvent('pointermove', {\n pointerId: 1,\n clientX: 110,\n clientY: 110,\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n handle.dispatchEvent(\n new PointerEvent('pointerup', {\n pointerId: 1,\n clientX: 110,\n clientY: 110,\n bubbles: true,\n composed: true,\n cancelable: true,\n })\n );\n\n await elementUpdated(el);\n\n expect(el.hue).to.equal(0);\n expect(el.x).to.equal(0.53);\n expect(el.y).to.equal(0.47);\n });\n it('responds to events on the internal input element', async () => {\n const inputSpy = spy();\n const changeSpy = spy();\n const el = await fixture<ColorArea>(html`\n <sp-color-area\n color=\"hsla(100, 50%, 50%, 1)\"\n @change=${() => changeSpy()}\n @input=${() => inputSpy()}\n ></sp-color-area>\n `);\n\n await elementUpdated(el);\n\n el.inputX.focus();\n\n el.inputX.dispatchEvent(\n new Event('input', {\n bubbles: true,\n composed: true,\n })\n );\n el.inputX.dispatchEvent(\n new Event('change', {\n bubbles: true,\n composed: false, // native change events do not compose themselves by default\n })\n );\n\n expect(inputSpy.callCount).to.equal(1);\n expect(changeSpy.callCount).to.equal(1);\n\n el.inputY.focus();\n\n el.inputY.dispatchEvent(\n new Event('input', {\n bubbles: true,\n composed: true,\n })\n );\n el.inputY.dispatchEvent(\n new Event('change', {\n bubbles: true,\n composed: false, // native change events do not compose themselves by default\n })\n );\n\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n });\n it('dispatches input and change events in response to \"Arrow*\" keypresses', async () => {\n const inputSpy = spy();\n const changeSpy = spy();\n const el = await fixture<ColorArea>(html`\n <sp-color-area\n color=\"hsla(100, 50%, 50%, 1)\"\n @change=${() => changeSpy()}\n @input=${() => inputSpy()}\n ></sp-color-area>\n `);\n\n await elementUpdated(el);\n const Xvalue = Number(Number(el.inputX.value).toFixed(2));\n const Yvalue = Number(Number(el.inputY.value).toFixed(2));\n\n el.inputX.focus();\n inputSpy.resetHistory();\n changeSpy.resetHistory();\n await sendKeys({ press: 'ArrowRight' });\n await sendKeys({ press: 'ArrowRight' });\n\n await elementUpdated(el);\n\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n expect(parseFloat(el.inputX.value).toFixed(2)).to.equal(\n (Xvalue + 0.02).toFixed(2)\n );\n\n el.inputY.focus();\n inputSpy.resetHistory();\n changeSpy.resetHistory();\n await sendKeys({ press: 'ArrowUp' });\n await sendKeys({ press: 'ArrowUp' });\n\n await elementUpdated(el);\n\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n expect(parseFloat(el.inputY.value).toFixed(2)).to.equal(\n (Yvalue + 0.02).toFixed(2)\n );\n\n el.inputY.focus();\n inputSpy.resetHistory();\n changeSpy.resetHistory();\n await sendKeys({ press: 'ArrowDown' });\n await sendKeys({ press: 'ArrowDown' });\n\n await elementUpdated(el);\n\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n expect(parseFloat(el.inputY.value).toFixed(2)).to.equal(\n Yvalue.toFixed(2)\n );\n\n el.inputX.focus();\n inputSpy.resetHistory();\n changeSpy.resetHistory();\n\n await sendKeys({ press: 'ArrowLeft' });\n await sendKeys({ press: 'ArrowLeft' });\n\n await elementUpdated(el);\n //expect(el.x).to.be.equal(0.98);\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n expect(parseFloat(el.inputX.value).toFixed(2)).to.equal(\n Xvalue.toFixed(2)\n );\n\n el.inputX.focus();\n inputSpy.resetHistory();\n changeSpy.resetHistory();\n await sendKeys({ press: 'End' });\n await sendKeys({ press: 'End' });\n\n await elementUpdated(el);\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n expect(parseFloat(el.inputX.value).toFixed(2)).to.equal(\n (Xvalue + 0.2).toFixed(2)\n );\n\n el.inputX.focus();\n inputSpy.resetHistory();\n changeSpy.resetHistory();\n await sendKeys({ press: 'Home' });\n await sendKeys({ press: 'Home' });\n\n await elementUpdated(el);\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n expect(parseFloat(el.inputX.value).toFixed(2)).to.equal(\n Xvalue.toFixed(2)\n );\n\n el.inputY.focus();\n inputSpy.resetHistory();\n changeSpy.resetHistory();\n await sendKeys({ press: 'PageUp' });\n await sendKeys({ press: 'PageUp' });\n\n await elementUpdated(el);\n\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n expect(parseFloat(el.inputY.value).toFixed(2)).to.equal(\n (Yvalue + 0.2).toFixed(2)\n );\n\n el.inputY.focus();\n inputSpy.resetHistory();\n changeSpy.resetHistory();\n await sendKeys({ press: 'PageDown' });\n await sendKeys({ press: 'PageDown' });\n\n await elementUpdated(el);\n\n expect(inputSpy.callCount).to.equal(2);\n expect(changeSpy.callCount).to.equal(2);\n expect(parseFloat(el.inputY.value).toFixed(2)).to.equal(\n Yvalue.toFixed(2)\n );\n });\n it('retains `hue` value when s = 0 in HSL string format', async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area color=\"hsl(100, 50%, 50%)\"></sp-color-area>\n `);\n\n await elementUpdated(el);\n\n expect(el.hue, 'hue').to.equal(100);\n expect(el.x, 'x').to.equal(0.67);\n expect(el.y, 'y').to.equal(0.75);\n expect(el.color).to.equal('hsl(100, 50%, 50%)');\n\n el.color = 'hsl(100, 0%, 50%)';\n await elementUpdated(el);\n\n expect(el.hue, 'new hue').to.equal(100);\n expect(el.x, 'new x').to.equal(0);\n expect(el.y, 'new y').to.equal(0.5);\n expect(el.color).to.equal('hsl(100, 0%, 50%)');\n });\n it('retains `hue` value when s = 0 in HSL object format', async () => {\n let inputColor = { h: 100, s: 0.5, l: 0.5 };\n\n const el = await fixture<ColorArea>(html`\n <sp-color-area .color=${inputColor}></sp-color-area>\n `);\n\n await elementUpdated(el);\n\n let outputColor = el.color as { h: number; s: number; l: number };\n const variance = 0.00005;\n\n expect(el.hue).to.equal(100);\n expect(el.x, 'x').to.equal(0.67);\n expect(el.y, 'y').to.equal(0.75);\n\n expect(Math.abs(outputColor.h - inputColor.h)).to.be.lessThan(variance);\n expect(Math.abs(outputColor.s - inputColor.s)).to.be.lessThan(variance);\n expect(Math.abs(outputColor.l - inputColor.l)).to.be.lessThan(variance);\n\n inputColor = { h: 100, s: 0, l: 0.5 };\n el.color = inputColor;\n\n await elementUpdated(el);\n outputColor = el.color as { h: number; s: number; l: number };\n\n expect(el.hue).to.equal(100);\n expect(el.x, 'x').to.equal(0);\n expect(el.y, 'y').to.equal(0.5);\n\n expect(Math.abs(outputColor.h - inputColor.h)).to.be.lessThan(variance);\n expect(Math.abs(outputColor.s - inputColor.s)).to.be.lessThan(variance);\n expect(Math.abs(outputColor.l - inputColor.l)).to.be.lessThan(variance);\n });\n it('retains `hue` value when s = 0 in HSV string format', async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area color=\"hsv(100, 50%, 50%)\"></sp-color-area>\n `);\n\n await elementUpdated(el);\n\n expect(el.hue, 'hue').to.equal(100);\n expect(el.x, 'x').to.equal(0.5);\n expect(el.y, 'y').to.equal(0.5);\n expect(el.color).to.equal('hsv(100, 50%, 50%)');\n\n el.color = 'hsv(100, 0%, 50%)';\n await elementUpdated(el);\n\n expect(el.hue, 'new hue').to.equal(100);\n expect(el.x, 'new x').to.equal(0);\n expect(el.y, 'new y').to.equal(0.5);\n expect(el.color).to.equal('hsv(100, 0%, 50%)');\n });\n it('retains `hue` value when s = 0 in HSV object format', async () => {\n let inputColor = { h: 100, s: 0.5, v: 0.5 };\n\n const el = await fixture<ColorArea>(html`\n <sp-color-area .color=${inputColor}></sp-color-area>\n `);\n\n await elementUpdated(el);\n\n let outputColor = el.color as { h: number; s: number; v: number };\n const variance = 0.00005;\n\n expect(el.hue).to.equal(100);\n expect(el.x, 'x').to.equal(0.5);\n expect(el.y, 'y').to.equal(0.5);\n\n expect(Math.abs(outputColor.h - inputColor.h)).to.be.lessThan(variance);\n expect(Math.abs(outputColor.s - inputColor.s)).to.be.lessThan(variance);\n expect(Math.abs(outputColor.v - inputColor.v)).to.be.lessThan(variance);\n\n inputColor = { h: 100, s: 0, v: 0.5 };\n el.color = inputColor;\n\n await elementUpdated(el);\n outputColor = el.color as { h: number; s: number; v: number };\n\n expect(el.hue).to.equal(100);\n expect(el.x, 'x').to.equal(0);\n expect(el.y, 'y').to.equal(0.5);\n\n expect(Math.abs(outputColor.h - inputColor.h)).to.be.lessThan(variance);\n expect(Math.abs(outputColor.s - inputColor.s)).to.be.lessThan(variance);\n expect(Math.abs(outputColor.v - inputColor.v)).to.be.lessThan(variance);\n });\n const colorFormats: {\n name: string;\n color:\n | string\n | number\n | TinyColor\n | HSVA\n | HSV\n | RGB\n | RGBA\n | HSL\n | HSLA;\n }[] = [\n //rgb\n { name: 'RGB String', color: 'rgb(204, 51, 204)' },\n { name: 'RGB', color: { r: 204, g: 51, b: 204, a: 1 } },\n //prgb\n { name: 'PRGB String', color: 'rgb(80%, 20%, 80%)' },\n { name: 'PRGB', color: { r: '80%', g: '20%', b: '80%', a: 1 } },\n // hex\n { name: 'Hex', color: 'cc33cc' },\n { name: 'Hex String', color: '#cc33cc' },\n // hex8\n { name: 'Hex8', color: 'cc33ccff' },\n { name: 'Hex8 String', color: '#cc33ccff' },\n // name\n { name: 'string', color: 'red' },\n // hsl\n { name: 'HSL String', color: 'hsl(300, 60%, 50%)' },\n { name: 'HSL', color: { h: 300, s: 0.6000000000000001, l: 0.5, a: 1 } },\n // hsv\n { name: 'HSV String', color: 'hsv(300, 75%, 100%)' },\n { name: 'HSV', color: { h: 300, s: 0.75, v: 1, a: 1 } },\n ];\n colorFormats.map((format) => {\n it(`maintains \\`color\\` format as ${format.name}`, async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area></sp-color-area>\n `);\n\n el.color = format.color;\n if (format.name.startsWith('Hex')) {\n expect(el.color).to.equal(format.color);\n } else expect(el.color).to.deep.equal(format.color);\n });\n });\n it(`maintains \\`color\\` format as TinyColor`, async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area></sp-color-area>\n `);\n const color = new TinyColor('rgb(204, 51, 204)');\n el.color = color;\n expect(color.equals(el.color));\n });\n it(`resolves Hex3 format to Hex6 format`, async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area></sp-color-area>\n `);\n el.color = '0f0';\n expect(el.color).to.equal('00ff00');\n\n el.color = '#1e0';\n expect(el.color).to.equal('#11ee00');\n });\n it(`resolves Hex4 format to Hex8 format`, async () => {\n const el = await fixture<ColorArea>(html`\n <sp-color-area></sp-color-area>\n `);\n el.color = 'f3af';\n expect(el.color).to.equal('ff33aaff');\n\n el.color = '#f3af';\n expect(el.color).to.equal('#ff33aaff');\n });\n});\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|