89 lines
2.4 KiB
Plaintext
89 lines
2.4 KiB
Plaintext
import Component from "@glimmer/component";
|
|
import { tracked } from "@glimmer/tracking";
|
|
import { action } from "@ember/object";
|
|
import { service } from "@ember/service";
|
|
import { and } from "truth-helpers";
|
|
import concatClass from "discourse/helpers/concat-class";
|
|
import { getMaxAnimationTimeMs } from "discourse/lib/swipe-events";
|
|
import swipe from "discourse/modifiers/swipe";
|
|
import autoCloseToast from "float-kit/modifiers/auto-close-toast";
|
|
|
|
const VELOCITY_THRESHOLD = -1.2;
|
|
|
|
export default class DToast extends Component {
|
|
@service site;
|
|
|
|
@tracked progressBar;
|
|
|
|
@action
|
|
registerProgressBar(element) {
|
|
this.progressBar = element;
|
|
}
|
|
|
|
@action
|
|
async didSwipe(state) {
|
|
if (state.deltaY >= 0) {
|
|
this.#animateWrapperPosition(state.element, 0);
|
|
return;
|
|
}
|
|
|
|
if (state.velocityY < VELOCITY_THRESHOLD) {
|
|
await this.#close(state.element);
|
|
} else {
|
|
await this.#animateWrapperPosition(state.element, state.deltaY);
|
|
}
|
|
}
|
|
|
|
@action
|
|
async didEndSwipe(state) {
|
|
if (state.velocityY < VELOCITY_THRESHOLD) {
|
|
await this.#close(state.element);
|
|
} else {
|
|
await this.#animateWrapperPosition(state.element, 0);
|
|
}
|
|
}
|
|
|
|
async #close(element) {
|
|
await this.#closeWrapperAnimation(element);
|
|
this.args.toast.close();
|
|
}
|
|
|
|
async #closeWrapperAnimation(element) {
|
|
await element.animate([{ transform: "translateY(-150px)" }], {
|
|
fill: "forwards",
|
|
duration: getMaxAnimationTimeMs(),
|
|
}).finished;
|
|
}
|
|
|
|
async #animateWrapperPosition(element, position) {
|
|
await element.animate([{ transform: `translateY(${position}px)` }], {
|
|
fill: "forwards",
|
|
}).finished;
|
|
}
|
|
|
|
<template>
|
|
<output
|
|
role={{if @toast.options.autoClose "status" "log"}}
|
|
key={{@toast.id}}
|
|
class={{concatClass "fk-d-toast" @toast.options.class}}
|
|
{{autoCloseToast
|
|
close=@toast.close
|
|
duration=@toast.options.duration
|
|
progressBar=this.progressBar
|
|
enabled=@toast.options.autoClose
|
|
}}
|
|
{{swipe onDidSwipe=this.didSwipe onDidEndSwipe=this.didEndSwipe}}
|
|
>
|
|
<@toast.options.component
|
|
@data={{@toast.options.data}}
|
|
@close={{@toast.close}}
|
|
@showProgressBar={{and
|
|
@toast.options.showProgressBar
|
|
@toast.options.autoClose
|
|
}}
|
|
@onRegisterProgressBar={{this.registerProgressBar}}
|
|
/>
|
|
</output>
|
|
</template>
|
|
}
|