@spectrum-css/colorslider
Advanced tools
Comparing version 7.0.0-s2-foundations.10 to 7.0.0-s2-foundations.11
# Change Log | ||
## 7.0.0-s2-foundations.11 | ||
### Major Changes | ||
- [#2786](https://github.com/adobe/spectrum-css/pull/2786) [`8e772ef`](https://github.com/adobe/spectrum-css/commit/8e772efd757f5e88fd4048a5c0229472f9bf90cf) Thanks [@pfulton](https://github.com/pfulton)! - Updated build to set cssnano to discardUnused: false | ||
### Patch Changes | ||
- Updated dependencies [[`8e772ef`](https://github.com/adobe/spectrum-css/commit/8e772efd757f5e88fd4048a5c0229472f9bf90cf)]: | ||
- @spectrum-css/opacitycheckerboard@3.0.0-s2-foundations.11 | ||
- @spectrum-css/colorhandle@9.0.0-s2-foundations.11 | ||
- @spectrum-css/tokens@15.0.0-s2-foundations.12 | ||
## 7.0.0-s2-foundations.10 | ||
@@ -7,7 +20,7 @@ | ||
- [#2786](https://github.com/adobe/spectrum-css/pull/2786) [`54c5625`](https://github.com/adobe/spectrum-css/commit/54c56257bcca5872567a2bf0c5737e35b8190b05) Thanks [@pfulton](https://github.com/pfulton)! - Fixes to index.css imports to ensure appropriate system mappings get loaded | ||
- [#2786](https://github.com/adobe/spectrum-css/pull/2786) [`0844aad`](https://github.com/adobe/spectrum-css/commit/0844aadba2fefb844a66370ff6e9b4704f6c1543) Thanks [@pfulton](https://github.com/pfulton)! - Fixes to index.css imports to ensure appropriate system mappings get loaded | ||
### Patch Changes | ||
- Updated dependencies [[`54c5625`](https://github.com/adobe/spectrum-css/commit/54c56257bcca5872567a2bf0c5737e35b8190b05)]: | ||
- Updated dependencies [[`0844aad`](https://github.com/adobe/spectrum-css/commit/0844aadba2fefb844a66370ff6e9b4704f6c1543)]: | ||
- @spectrum-css/opacitycheckerboard@3.0.0-s2-foundations.10 | ||
@@ -14,0 +27,0 @@ - @spectrum-css/colorhandle@9.0.0-s2-foundations.10 |
{ | ||
"name": "@spectrum-css/colorslider", | ||
"version": "7.0.0-s2-foundations.10", | ||
"version": "7.0.0-s2-foundations.11", | ||
"description": "The Spectrum CSS Color slider component", | ||
@@ -5,0 +5,0 @@ "license": "Apache-2.0", |
import { Template as ColorHandle } from "@spectrum-css/colorhandle/stories/template.js"; | ||
import { Template as OpacityCheckerboard } from "@spectrum-css/opacitycheckerboard/stories/template.js"; | ||
import { Variants } from "@spectrum-css/preview/decorators"; | ||
import { html } from "lit"; | ||
@@ -9,30 +10,25 @@ import { classMap } from "lit/directives/class-map.js"; | ||
import "../index.css"; | ||
import "../themes/express.css"; | ||
import "../themes/spectrum.css"; | ||
export const Template = ( | ||
{ | ||
rootClass = "spectrum-ColorSlider", | ||
customClasses = [], | ||
customStyles = {}, | ||
isDisabled = false, | ||
isFocused = false, | ||
vertical = false, | ||
gradientStops = [ | ||
"rgb(255, 0, 0) 0%", | ||
"rgb(255, 255, 0) 17%", | ||
"rgb(0, 255, 0) 33%", | ||
"rgb(0, 255, 255) 50%", | ||
"rgb(0, 0, 255) 67%", | ||
"rgb(255, 0, 255) 83%", | ||
"rgb(255, 0, 0)", | ||
], | ||
gradientType = "gradient", | ||
selectedColor = "rgb(255, 0, 0)", | ||
colorHandleStyle = {}, | ||
} = {}, | ||
context = {} | ||
) => { | ||
export const Template = ({ | ||
rootClass = "spectrum-ColorSlider", | ||
customClasses = [], | ||
customStyles = {}, | ||
isDisabled = false, | ||
isFocused = false, | ||
vertical = false, | ||
gradientStops = [ | ||
"rgb(255, 0, 0) 0%", | ||
"rgb(255, 255, 0) 17%", | ||
"rgb(0, 255, 0) 33%", | ||
"rgb(0, 255, 255) 50%", | ||
"rgb(0, 0, 255) 67%", | ||
"rgb(255, 0, 255) 83%", | ||
"rgb(255, 0, 0)", | ||
], | ||
gradientType = "gradient", | ||
colorHandleStyle = { | ||
"--spectrum-picked-color": "rgba(255, 0, 0)", | ||
}, | ||
} = {}, context = {}) => { | ||
const { updateArgs } = context; | ||
return html` | ||
@@ -55,49 +51,74 @@ <div | ||
> | ||
${OpacityCheckerboard( | ||
{ | ||
customClasses: [`${rootClass}-checkerboard`], | ||
content: [ | ||
when( | ||
gradientType === "image", | ||
() => html`<img | ||
class="${rootClass}-gradient" | ||
role="presentation" | ||
src="" | ||
/>`, | ||
() => html`<div | ||
class="${rootClass}-gradient" | ||
role="presentation" | ||
style=${when(gradientStops && gradientStops.length, () => | ||
styleMap({ | ||
background: `linear-gradient(to ${ | ||
vertical ? "bottom" : "right" | ||
}, ${gradientStops.join(", ")})`, | ||
}) | ||
)} | ||
></div>` | ||
), | ||
], | ||
role: "presentation", | ||
}, | ||
context | ||
)} | ||
${ColorHandle( | ||
{ | ||
isDisabled, | ||
isFocused, | ||
selectedColor, | ||
customClasses: [`${rootClass}-handle`], | ||
customStyles: colorHandleStyle, | ||
}, | ||
context | ||
)} | ||
<input | ||
type="color" | ||
value=${selectedColor} | ||
class=${classMap({ | ||
[`${rootClass}-slider`]: true, | ||
})} | ||
/> | ||
${OpacityCheckerboard({ | ||
customClasses: [`${rootClass}-checkerboard`], | ||
content: [ | ||
when( | ||
gradientType === "image", | ||
() => html`<img | ||
class="${rootClass}-gradient" | ||
role="presentation" | ||
src="" | ||
/>`, | ||
() => html`<div | ||
class="${rootClass}-gradient" | ||
role="presentation" | ||
style=${when(gradientStops && gradientStops.length, () => | ||
styleMap({ | ||
background: `linear-gradient(to ${ | ||
vertical ? "bottom" : "right" | ||
}, ${gradientStops.join(", ")})`, | ||
}) | ||
)} | ||
></div>` | ||
), | ||
], | ||
role: "presentation", | ||
}, context)} | ||
${ColorHandle({ | ||
isDisabled, | ||
isFocused, | ||
customClasses: [`${rootClass}-handle`], | ||
customStyles: colorHandleStyle, | ||
}, context)} | ||
<input type="range" class="${rootClass}-slider" min="0" max="100" step="1" /> | ||
</div> | ||
`; | ||
`; | ||
}; | ||
export const ColorSliderGroup = Variants({ | ||
Template, | ||
testData: [ | ||
{ | ||
testHeading: "Default", | ||
}, | ||
{ | ||
testHeading: "Vertical", | ||
vertical: true, | ||
}, | ||
{ | ||
testHeading: "Alpha", | ||
gradientStops: ["rgba(0, 0, 0, 1) 0%", "rgba(0, 0, 0, 0) 100%"], | ||
colorHandleStyle: { | ||
"--spectrum-picked-color": "rgba(0, 0, 0, 1)", | ||
}, | ||
}, | ||
{ | ||
testHeading: "With Image", | ||
gradientType: "image", | ||
colorHandleStyle: { | ||
"--spectrum-picked-color": "#df6a7d", | ||
"inset-inline-start": "50%", | ||
}, | ||
}, | ||
], | ||
stateData: [ | ||
{ | ||
testHeading: "Disabled", | ||
isDisabled: true, | ||
}, | ||
{ | ||
testHeading: "Focused", | ||
isFocused: true, | ||
}, | ||
], | ||
}); |
74950
566