169 похожих чатов

Накропал типизированный EventTarget, покритикуйте /** * Factory constructs EventTarget with typed

methods according given EventMap
*/
export default function typedEventTargetFactory<EventMap extends { [K: string]: any }, EM extends { [K: string]: any } = EventMap & { all: EventMap[keyof EventMap] }>() {
const symbol = Symbol("ownCustomEvent");

class TypedEvent<K extends keyof EM = keyof EM> extends CustomEvent<EM[K]> {
[symbol] = true;

constructor(type: K, ...eventInitDict: EM[K] extends Record<string, never> | null | undefined ? [undefined?] : [CustomEventInit<EM[K]>]) {
super(type as string, ...eventInitDict);
}
}

class TypedEventTarget extends EventTarget {
static TypedEvent = TypedEvent;

addEventListener<K extends keyof EM>(type: K, listener: ((this: typeof this, ev: TypedEvent<K>) => any) | { handleEvent: (ev: CustomEvent<EM[K]>) => any } | null, options?: boolean | EventListenerOptions) {
return super.addEventListener(type as string, listener as EventListenerOrEventListenerObject, options);
}

removeEventListener<K extends keyof EM>(type: K, listener: ((this: typeof this, ev: TypedEvent<K>) => any) | { handleEvent: (ev: CustomEvent<EM[K]>) => any } | null, options?: boolean | EventListenerOptions) {
return super.removeEventListener(type as string, listener as EventListenerOrEventListenerObject, options);
}

dispatchEvent(event: TypedEvent) {
super.dispatchEvent(new CustomEvent("all", {detail: event.detail}));
return super.dispatchEvent(event as Event);
}
}

return TypedEventTarget;
}

class SomeTargetEvent extends typedEventTargetFactory<{ myEvent: { flag: boolean } }>() {}

const someTargetEvent = new SomeTargetEvent();

someTargetEvent.addEventListener("myEvent", (event) => event.detail.flag); // OK

someTargetEvent.addEventListener("all", (event) => event.detail.flag); // OK

someTargetEvent.dispatchEvent(new SomeTargetEvent.TypedEvent("myEvent", {detail: {flag: true}})); // OK

someTargetEvent.addEventListener("myEvent11111", null); // Argument of type "myEvent11111" is not assignable to parameter of type "all" | "myEvent"

someTargetEvent.addEventListener("myEvent", (event) => event.detail.noFlag); // Property noFlag does not exist on type { flag: boolean; }

someTargetEvent.dispatchEvent(new SomeTargetEvent.TypedEvent("myEvent", {detail: {noFlag: true}})); // Type { noFlag: true; } is not assignable to type { flag: boolean; }

1 ответов

29 просмотров

ок я понял теперь о чём ты

Похожие вопросы

Обсуждают сегодня

а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Привет всем. Подскажите где можно посмотреть, какая версия электрон, поддерживает версии windows? Некий changelog. Мне бы желательно, поддержку 7,8,10... latest, как понимаю и...
Anonym Squad
21
Портфолио: Зовут меня Александр, мне 36 лет. Город Пушкино. Общий рабочий стаж: ~14 лет Уровень квалификации: Senior Full-stack developer Где прочесть мой код? https://github....
Magic
10
Не ну фпц - это уже просто троллинг какой-то. Элементарный код нельзя собрать. ЧЯДНТ? program Project1; {$mode delphi} uses SysUtils, Classes, Generics.Collections; var...
Peter
4
а где есть mysql cloud кроме яндекс-клауд?
Oleg Nosov
13
Есть ли смысл устраиваться на 1с ? Даст это плюс в дальнейшем трудоустройстве на php? Просто у меня в городе вакансий на пхп нету. Или лучше удаленно искать. Опыта работы нету...
Azamat
14
hi im a cs student. i need some advice from people who have enough experience in Embedded Software. I need to know whether this profession is suitable for me. I have watched s...
Sahand 🏔️
8
А кто-нибудь запихивал сборку перловых модулей/образов с perl приложениями в окружения без интернета (в специализированном CI/CD)? У меня сейчас есть ряд cpanfile, которые н...
Andrey Smirnov / 𝓪𝓵𝓵𝓽𝓮𝓻 /
14
Кстати а покупал кто-нибудь ЭЦП для подписи кода? А то у меня на некоторых компах и ОС иногда SmartScreen винды программу за вирус принимал. Если купить такую ЭЦП и подписыват...
Дмитрий Завгородний
15
Карта сайта