Skip to content

Commit

Permalink
[feat] enhance action typings (#7805)
Browse files Browse the repository at this point in the history
Allows a way to tell language tools which additional attributes and events the action brings to the HTML element
Related sveltejs/language-tools#1553
  • Loading branch information
dummdidumm authored Sep 2, 2022
1 parent 0ed453d commit bddd795
Showing 1 changed file with 19 additions and 5 deletions.
24 changes: 19 additions & 5 deletions src/runtime/action/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,17 @@
* immediately after Svelte has applied updates to the markup.
* - destroy: Method that is called after the element is unmounted
*
* Additionally, you can specify which additional attributes and events the action enables on the applied element.
* This applies to TypeScript typings only and has no effect at runtime.
*
* Example usage:
* ```ts
* export function myAction(node: HTMLElement, parameter: Parameter): ActionReturn<Parameter> {
* interface Attributes {
* newprop?: string;
* 'on:event': (e: CustomEvent<boolean>) => void;
* }
*
* export function myAction(node: HTMLElement, parameter: Parameter): ActionReturn<Parameter, Attributes> {
* // ...
* return {
* update: (updatedParameter) => {...},
Expand All @@ -17,9 +25,15 @@
*
* Docs: https://svelte.dev/docs#template-syntax-element-directives-use-action
*/
export interface ActionReturn<Parameter = any> {
export interface ActionReturn<Parameter = any, Attributes extends Record<string, any> = Record<never, any>> {
update?: (parameter: Parameter) => void;
destroy?: () => void;
/**
* ### DO NOT USE THIS
* This exists solely for type-checking and has no effect at runtime.
* Set this through the `Attributes` generic instead.
*/
$$_attributes?: Attributes;
}

/**
Expand All @@ -32,11 +46,11 @@ export interface ActionReturn<Parameter = any> {
* // ...
* }
* ```
* You can return an object with methods `update` and `destroy` from the function.
* You can return an object with methods `update` and `destroy` from the function and type which additional attributes and events it has.
* See interface `ActionReturn` for more details.
*
* Docs: https://svelte.dev/docs#template-syntax-element-directives-use-action
*/
export interface Action<Element = HTMLElement, Parameter = any> {
<Node extends Element>(node: Node, parameter?: Parameter): void | ActionReturn<Parameter>;
export interface Action<Element = HTMLElement, Parameter = any, Attributes extends Record<string, any> = Record<never, any>> {
<Node extends Element>(node: Node, parameter?: Parameter): void | ActionReturn<Parameter, Attributes>;
}

0 comments on commit bddd795

Please sign in to comment.