Archived
Template
1
Fork 0
This repository has been archived on 2024-09-04. You can view files and clone it, but cannot push or open issues or pull requests.
Contour/public/@shoelace-style/shoelace/cdn/chunks/chunk.NXCO3ZAK.js

157 lines
4 KiB
JavaScript
Raw Normal View History

2024-01-30 10:59:28 -05:00
import {
image_comparer_styles_default
} from "./chunk.ATEI77YH.js";
import {
drag
} from "./chunk.ESELY2US.js";
import {
o
} from "./chunk.FQQ5K3WY.js";
import {
clamp
} from "./chunk.HF7GESMZ.js";
import {
LocalizeController
} from "./chunk.NH3SRVOC.js";
import {
e
} from "./chunk.UZVKBFXH.js";
import {
SlIcon
} from "./chunk.UZYAV5H6.js";
import {
watch
} from "./chunk.FA5RT4K4.js";
import {
ShoelaceElement,
e as e2,
n
} from "./chunk.SEXBCYCU.js";
import {
x
} from "./chunk.CXZZ2LVK.js";
import {
__decorateClass
} from "./chunk.KIILAQWQ.js";
// src/components/image-comparer/image-comparer.component.ts
var SlImageComparer = class extends ShoelaceElement {
constructor() {
super(...arguments);
this.localize = new LocalizeController(this);
this.position = 50;
}
handleDrag(event) {
const { width } = this.base.getBoundingClientRect();
const isRtl = this.localize.dir() === "rtl";
event.preventDefault();
drag(this.base, {
onMove: (x2) => {
this.position = parseFloat(clamp(x2 / width * 100, 0, 100).toFixed(2));
if (isRtl)
this.position = 100 - this.position;
},
initialEvent: event
});
}
handleKeyDown(event) {
const isLtr = this.localize.dir() === "ltr";
const isRtl = this.localize.dir() === "rtl";
if (["ArrowLeft", "ArrowRight", "Home", "End"].includes(event.key)) {
const incr = event.shiftKey ? 10 : 1;
let newPosition = this.position;
event.preventDefault();
if (isLtr && event.key === "ArrowLeft" || isRtl && event.key === "ArrowRight") {
newPosition -= incr;
}
if (isLtr && event.key === "ArrowRight" || isRtl && event.key === "ArrowLeft") {
newPosition += incr;
}
if (event.key === "Home") {
newPosition = 0;
}
if (event.key === "End") {
newPosition = 100;
}
newPosition = clamp(newPosition, 0, 100);
this.position = newPosition;
}
}
handlePositionChange() {
this.emit("sl-change");
}
render() {
const isRtl = this.localize.dir() === "rtl";
return x`
<div
part="base"
id="image-comparer"
class=${e({
"image-comparer": true,
"image-comparer--rtl": isRtl
})}
@keydown=${this.handleKeyDown}
>
<div class="image-comparer__image">
<div part="before" class="image-comparer__before">
<slot name="before"></slot>
</div>
<div
part="after"
class="image-comparer__after"
style=${o({
clipPath: isRtl ? `inset(0 0 0 ${100 - this.position}%)` : `inset(0 ${100 - this.position}% 0 0)`
})}
>
<slot name="after"></slot>
</div>
</div>
<div
part="divider"
class="image-comparer__divider"
style=${o({
left: isRtl ? `${100 - this.position}%` : `${this.position}%`
})}
@mousedown=${this.handleDrag}
@touchstart=${this.handleDrag}
>
<div
part="handle"
class="image-comparer__handle"
role="scrollbar"
aria-valuenow=${this.position}
aria-valuemin="0"
aria-valuemax="100"
aria-controls="image-comparer"
tabindex="0"
>
<slot name="handle">
<sl-icon library="system" name="grip-vertical"></sl-icon>
</slot>
</div>
</div>
</div>
`;
}
};
SlImageComparer.styles = image_comparer_styles_default;
SlImageComparer.scopedElement = { "sl-icon": SlIcon };
__decorateClass([
e2(".image-comparer")
], SlImageComparer.prototype, "base", 2);
__decorateClass([
e2(".image-comparer__handle")
], SlImageComparer.prototype, "handle", 2);
__decorateClass([
n({ type: Number, reflect: true })
], SlImageComparer.prototype, "position", 2);
__decorateClass([
watch("position", { waitUntilFirstUpdate: true })
], SlImageComparer.prototype, "handlePositionChange", 1);
export {
SlImageComparer
};