Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin/v1/contrib' into v1/storybook8-u…
Browse files Browse the repository at this point in the history
…pgrade
  • Loading branch information
iOvergaard committed Oct 10, 2024
2 parents b370514 + 4d296a4 commit 9197a8d
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 5 deletions.
30 changes: 25 additions & 5 deletions packages/uui-color-slider/lib/uui-color-slider.element.ts
Original file line number Diff line number Diff line change
Expand Up @@ -84,12 +84,22 @@ export class UUIColorSliderElement extends LabelMixin('label', LitElement) {
@property() value = 0;

/**
* Disables the color slider.
* Sets the color slider to readonly mode.
* @type {boolean}
* @attr
* @default false
*/
@property({ type: Boolean, reflect: true })
readonly = false;

/**
* Sets the color slider to disabled.
* @type {boolean}
* @attr
* @default false
**/
@property({ type: Boolean, reflect: true }) disabled = false;
@property({ type: Boolean, reflect: true })
disabled = false;

private container!: HTMLElement;
private handle!: HTMLElement;
Expand All @@ -115,7 +125,8 @@ export class UUIColorSliderElement extends LabelMixin('label', LitElement) {
}

handleDrag(event: PointerEvent) {
if (this.disabled || !this.container || !this.handle) return;
if (this.disabled || this.readonly || !this.container || !this.handle)
return;

const { width, height } = this.container.getBoundingClientRect();

Expand All @@ -140,7 +151,7 @@ export class UUIColorSliderElement extends LabelMixin('label', LitElement) {
}

handleClick(event: MouseEvent) {
if (this.disabled) return;
if (this.disabled || this.readonly) return;

this.value = this.getValueFromMousePosition(event);
this.syncValues();
Expand Down Expand Up @@ -258,7 +269,8 @@ export class UUIColorSliderElement extends LabelMixin('label', LitElement) {
<span
id="color-slider__handle"
style="--current-value: ${this.cssPropCurrentValue}%;"
tabindex=${ifDefined(this.disabled ? undefined : '0')}></span>
tabindex=${ifDefined(this.disabled ? undefined : '0')}>
</span>
</div>
${Math.round(this.value)}`;
}
Expand Down Expand Up @@ -340,6 +352,14 @@ export class UUIColorSliderElement extends LabelMixin('label', LitElement) {
opacity: 0.55;
}
:host([readonly]) {
cursor: default;
}
:host([readonly]) #color-slider {
pointer-events: none;
}
#color-slider__handle {
position: absolute;
top: calc(50% - var(--uui-slider-handle-size) / 2);
Expand Down
8 changes: 8 additions & 0 deletions packages/uui-color-slider/lib/uui-color-slider.story.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,14 @@ export const Default: Story = {};
export const Disabled: Story = {
args: {
disabled: true,
value: 50,
},
};

export const Readonly: Story = {
args: {
readonly: true,
value: 50,
},
};

Expand Down

0 comments on commit 9197a8d

Please sign in to comment.