✨ Features: - App iOS completa para leer manga sin publicidad - Scraper con WKWebView para manhwaweb.com - Sistema de descargas offline - Lector con zoom y navegación - Favoritos y progreso de lectura - Compatible con iOS 15+ y Sideloadly/3uTools 📦 Contenido: - Backend Node.js con Puppeteer (opcional) - App iOS con SwiftUI - Scraper de capítulos e imágenes - Sistema de almacenamiento local - Testing completo - Documentación exhaustiva 🧪 Prueba: Capítulo 789 de One Piece descargado exitosamente - 21 páginas descargadas - 4.68 MB total - URLs verificadas y funcionales 🎉 Generated with Claude Code (https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
80 lines
1.6 KiB
TypeScript
80 lines
1.6 KiB
TypeScript
interface AbortSignal extends EventTarget {}
|
|
|
|
export interface EventOptions {
|
|
bubbles?: boolean
|
|
cancelable?: boolean
|
|
composed?: boolean
|
|
}
|
|
|
|
export interface Event {
|
|
readonly type: string
|
|
readonly target: EventTarget | null
|
|
readonly currentTarget: EventTarget | null
|
|
readonly bubbles: boolean
|
|
readonly cancelable: boolean
|
|
readonly composed: boolean
|
|
readonly defaultPrevented: boolean
|
|
readonly isTrusted: boolean
|
|
|
|
preventDefault(): void
|
|
stopPropagation(): void
|
|
stopImmediatePropagation(): void
|
|
}
|
|
|
|
export class Event {
|
|
constructor(type: string, options?: EventOptions)
|
|
}
|
|
|
|
export interface CustomEventOptions<T = any> extends EventOptions {
|
|
detail?: T
|
|
}
|
|
|
|
export interface CustomEvent<T = any> extends Event {
|
|
readonly detail: T
|
|
}
|
|
|
|
export class CustomEvent<T = any> {
|
|
constructor(type: string, options?: CustomEventOptions<T>)
|
|
}
|
|
|
|
export interface AddEventListenerOptions {
|
|
capture?: boolean
|
|
passive?: boolean
|
|
once?: boolean
|
|
signal?: AbortSignal | null
|
|
}
|
|
|
|
export interface RemoveEventListenerOptions {
|
|
capture?: boolean
|
|
}
|
|
|
|
export interface EventTarget {
|
|
addEventListener(
|
|
type: string,
|
|
callback: EventListener,
|
|
options?: AddEventListenerOptions | boolean
|
|
): void
|
|
|
|
removeEventListener(
|
|
type: string,
|
|
callback: EventListener,
|
|
options?: RemoveEventListenerOptions | boolean
|
|
): void
|
|
|
|
dispatchEvent(event: Event): boolean
|
|
}
|
|
|
|
export class EventTarget {
|
|
constructor()
|
|
}
|
|
|
|
export type EventListener = EventCallback | EventHandler
|
|
|
|
export interface EventCallback {
|
|
(event: Event): void
|
|
}
|
|
|
|
export interface EventHandler {
|
|
handleEvent(event: Event): void
|
|
}
|