mirror of https://github.com/sveltejs/svelte
breaking: conditional ActionReturn type if Parameter is void (#7442)
--------- Co-authored-by: Ivan Hofer <ivan.hofer@outlook.com> Co-authored-by: Simon H <5968653+dummdidumm@users.noreply.github.com> Co-authored-by: Ignatius Bagus <ignatius.mbs@gmail.com> Co-authored-by: Ben McCann <322311+benmccann@users.noreply.github.com> Co-authored-by: Simon Holthausen <simon.holthausen@vercel.com>pull/8515/head
parent
8e51b51dfc
commit
c81522f992
@ -0,0 +1,153 @@
|
|||||||
|
import type { Action, ActionReturn } from '$runtime/action';
|
||||||
|
|
||||||
|
// ---------------- Action
|
||||||
|
|
||||||
|
const href: Action<HTMLAnchorElement> = (node) => {
|
||||||
|
node.href = '';
|
||||||
|
// @ts-expect-error
|
||||||
|
node.href = 1;
|
||||||
|
};
|
||||||
|
href;
|
||||||
|
|
||||||
|
const required: Action<HTMLElement, boolean> = (node, param) => {
|
||||||
|
node;
|
||||||
|
param;
|
||||||
|
};
|
||||||
|
required(null as any, true);
|
||||||
|
// @ts-expect-error (only in strict mode) boolean missing
|
||||||
|
required(null as any);
|
||||||
|
// @ts-expect-error no boolean
|
||||||
|
required(null as any, 'string');
|
||||||
|
|
||||||
|
const required1: Action<HTMLElement, boolean> = (node, param) => {
|
||||||
|
node;
|
||||||
|
param;
|
||||||
|
return {
|
||||||
|
update: (p) => p === true,
|
||||||
|
destroy: () => {}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
required1;
|
||||||
|
|
||||||
|
const required2: Action<HTMLElement, boolean> = (node) => {
|
||||||
|
node;
|
||||||
|
};
|
||||||
|
required2;
|
||||||
|
|
||||||
|
const required3: Action<HTMLElement, boolean> = (node, param) => {
|
||||||
|
node;
|
||||||
|
param;
|
||||||
|
return {
|
||||||
|
// @ts-expect-error comparison always resolves to false
|
||||||
|
update: (p) => p === 'd',
|
||||||
|
destroy: () => {}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
required3;
|
||||||
|
|
||||||
|
const optional: Action<HTMLElement, boolean | undefined> = (node, param?) => {
|
||||||
|
node;
|
||||||
|
param;
|
||||||
|
};
|
||||||
|
optional(null as any, true);
|
||||||
|
optional(null as any);
|
||||||
|
// @ts-expect-error no boolean
|
||||||
|
optional(null as any, 'string');
|
||||||
|
|
||||||
|
const optional1: Action<HTMLElement, boolean | undefined> = (node, param?) => {
|
||||||
|
node;
|
||||||
|
param;
|
||||||
|
return {
|
||||||
|
update: (p) => p === true,
|
||||||
|
destroy: () => {}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
optional1;
|
||||||
|
|
||||||
|
const optional2: Action<HTMLElement, boolean | undefined> = (node) => {
|
||||||
|
node;
|
||||||
|
};
|
||||||
|
optional2;
|
||||||
|
|
||||||
|
const optional3: Action<HTMLElement, boolean | undefined> = (node, param) => {
|
||||||
|
node;
|
||||||
|
param;
|
||||||
|
};
|
||||||
|
optional3;
|
||||||
|
|
||||||
|
const optional4: Action<HTMLElement, boolean | undefined> = (node, param?) => {
|
||||||
|
node;
|
||||||
|
param;
|
||||||
|
return {
|
||||||
|
// @ts-expect-error comparison always resolves to false
|
||||||
|
update: (p) => p === 'd',
|
||||||
|
destroy: () => {}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
optional4;
|
||||||
|
|
||||||
|
const no: Action<HTMLElement, never> = (node) => {
|
||||||
|
node;
|
||||||
|
};
|
||||||
|
// @ts-expect-error second param
|
||||||
|
no(null as any, true);
|
||||||
|
no(null as any);
|
||||||
|
// @ts-expect-error second param
|
||||||
|
no(null as any, 'string');
|
||||||
|
|
||||||
|
const no1: Action<HTMLElement, never> = (node) => {
|
||||||
|
node;
|
||||||
|
return {
|
||||||
|
destroy: () => {}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
no1;
|
||||||
|
|
||||||
|
// @ts-expect-error param given
|
||||||
|
const no2: Action<HTMLElement, never> = (node, param?) => {};
|
||||||
|
no2;
|
||||||
|
|
||||||
|
// @ts-expect-error param given
|
||||||
|
const no3: Action<HTMLElement, never> = (node, param) => {};
|
||||||
|
no3;
|
||||||
|
|
||||||
|
// @ts-expect-error update method given
|
||||||
|
const no4: Action<HTMLElement, never> = (node) => {
|
||||||
|
return {
|
||||||
|
update: () => {},
|
||||||
|
destroy: () => {}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
no4;
|
||||||
|
|
||||||
|
// ---------------- ActionReturn
|
||||||
|
|
||||||
|
const requiredReturn: ActionReturn<string> = {
|
||||||
|
update: (p) => p.toString()
|
||||||
|
};
|
||||||
|
requiredReturn;
|
||||||
|
|
||||||
|
const optionalReturn: ActionReturn<boolean | undefined> = {
|
||||||
|
update: (p) => {
|
||||||
|
p === true;
|
||||||
|
// @ts-expect-error could be undefined
|
||||||
|
p.toString();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
optionalReturn;
|
||||||
|
|
||||||
|
const invalidProperty: ActionReturn = {
|
||||||
|
// @ts-expect-error invalid property
|
||||||
|
invalid: () => {}
|
||||||
|
};
|
||||||
|
invalidProperty;
|
||||||
|
|
||||||
|
type Attributes = ActionReturn<never, { a: string; }>['$$_attributes'];
|
||||||
|
const attributes: Attributes = { a: 'a' };
|
||||||
|
attributes;
|
||||||
|
// @ts-expect-error wrong type
|
||||||
|
const invalidAttributes1: Attributes = { a: 1 };
|
||||||
|
invalidAttributes1;
|
||||||
|
// @ts-expect-error missing prop
|
||||||
|
const invalidAttributes2: Attributes = {};
|
||||||
|
invalidAttributes2;
|
Loading…
Reference in new issue