Skip to content

Commit

Permalink
Convert SwappableEvent to typescript
Browse files Browse the repository at this point in the history
  • Loading branch information
tsov committed Oct 4, 2023
1 parent fb5354f commit 74c35e5
Show file tree
Hide file tree
Showing 3 changed files with 36 additions and 5 deletions.
5 changes: 5 additions & 0 deletions .changeset/grumpy-zebras-move.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'@shopify/draggable': patch
---

Convert SwappableEvent to typescript
Original file line number Diff line number Diff line change
@@ -1,14 +1,31 @@
import AbstractEvent from 'shared/AbstractEvent';

import {DragEvent, DragEventData} from '../../Draggable/DragEvent';

interface SwappableEventData {
dragEvent: DragEvent<DragEventData>;
}

/**
* Base swappable event
* @class SwappableEvent
* @module SwappableEvent
* @extends AbstractEvent
*/
export class SwappableEvent extends AbstractEvent {
export class SwappableEvent<
T extends SwappableEventData,
> extends AbstractEvent<SwappableEventData> {
static type = 'swappable';

/**
* SwappableEvent constructor.
* @constructs SwappableEvent
* @param {SwappableEventData} data - Event data
*/
constructor(public data: T) {
super(data);
}

/**
* Original drag event that triggered this swappable event
* @property dragEvent
Expand All @@ -26,18 +43,23 @@ export class SwappableEvent extends AbstractEvent {
* @module SwappableStartEvent
* @extends SwappableEvent
*/
export class SwappableStartEvent extends SwappableEvent {
export class SwappableStartEvent extends SwappableEvent<SwappableEventData> {
static type = 'swappable:start';
static cancelable = true;
}

interface SwappableSwapEventData extends SwappableEventData {
over: HTMLElement;
overContainer: HTMLElement;
}

/**
* Swappable swap event
* @class SwappableSwapEvent
* @module SwappableSwapEvent
* @extends SwappableEvent
*/
export class SwappableSwapEvent extends SwappableEvent {
export class SwappableSwapEvent extends SwappableEvent<SwappableSwapEventData> {
static type = 'swappable:swap';
static cancelable = true;

Expand All @@ -62,13 +84,17 @@ export class SwappableSwapEvent extends SwappableEvent {
}
}

interface SwappableSwappedEventData extends SwappableEventData {
swappedElement: HTMLElement;
}

/**
* Swappable swapped event
* @class SwappableSwappedEvent
* @module SwappableSwappedEvent
* @extends SwappableEvent
*/
export class SwappableSwappedEvent extends SwappableEvent {
export class SwappableSwappedEvent extends SwappableEvent<SwappableSwappedEventData> {
static type = 'swappable:swapped';

/**
Expand All @@ -88,6 +114,6 @@ export class SwappableSwappedEvent extends SwappableEvent {
* @module SwappableStopEvent
* @extends SwappableEvent
*/
export class SwappableStopEvent extends SwappableEvent {
export class SwappableStopEvent extends SwappableEvent<SwappableEventData> {
static type = 'swappable:stop';
}
File renamed without changes.

0 comments on commit 74c35e5

Please sign in to comment.