mirror of
https://github.com/danog/telegram-tt.git
synced 2025-01-23 05:41:14 +01:00
1 line
26 KiB
Plaintext
1 line
26 KiB
Plaintext
{"version":3,"file":"7941.c16f7302196aa916c103.js","mappings":"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","sources":["webpack://telegram-t/./src/util/WorkerConnector.ts","webpack://telegram-t/./src/lib/rlottie/RLottie.ts","webpack://telegram-t/./src/util/cycleRestrict.ts"],"sourcesContent":["import generateIdFor from './generateIdFor';\n\nexport interface CancellableCallback {\n (\n ...args: any[]\n ): void;\n\n isCanceled?: boolean;\n acceptsBuffer?: boolean;\n}\n\ntype CallMethodData = {\n type: 'callMethod';\n messageId?: string;\n name: string;\n args: any;\n};\n\ntype OriginMessageData = CallMethodData | {\n type: 'cancelProgress';\n messageId: string;\n};\n\nexport interface OriginMessageEvent {\n data: OriginMessageData;\n}\n\nexport type WorkerMessageData = {\n type: 'methodResponse';\n messageId: string;\n response?: any;\n error?: { message: string };\n} | {\n type: 'methodCallback';\n messageId: string;\n callbackArgs: any[];\n} | {\n type: 'unhandledError';\n error?: { message: string };\n};\n\nexport interface WorkerMessageEvent {\n data: WorkerMessageData;\n}\n\ninterface RequestStates {\n messageId: string;\n resolve: Function;\n reject: Function;\n callback: AnyToVoidFunction;\n}\n\n// TODO Replace `any` with proper generics\nexport default class WorkerConnector {\n private requestStates = new Map<string, RequestStates>();\n\n private requestStatesByCallback = new Map<AnyToVoidFunction, RequestStates>();\n\n constructor(private worker: Worker) {\n this.subscribe();\n }\n\n request(messageData: { name: string; args: any }) {\n const { worker, requestStates, requestStatesByCallback } = this;\n\n const messageId = generateIdFor(requestStates);\n const payload: CallMethodData = {\n type: 'callMethod',\n messageId,\n ...messageData,\n };\n\n const requestState = { messageId } as RequestStates;\n\n // Re-wrap type because of `postMessage`\n const promise: Promise<any> = new Promise((resolve, reject) => {\n Object.assign(requestState, { resolve, reject });\n });\n\n if (typeof payload.args[payload.args.length - 1] === 'function') {\n const callback = payload.args.pop() as AnyToVoidFunction;\n requestState.callback = callback;\n requestStatesByCallback.set(callback, requestState);\n }\n\n requestStates.set(messageId, requestState);\n promise\n .catch(() => undefined)\n .finally(() => {\n requestStates.delete(messageId);\n\n if (requestState.callback) {\n requestStatesByCallback.delete(requestState.callback);\n }\n });\n\n worker.postMessage(payload);\n\n return promise;\n }\n\n cancelCallback(progressCallback: CancellableCallback) {\n progressCallback.isCanceled = true;\n\n const { messageId } = this.requestStatesByCallback.get(progressCallback) || {};\n if (!messageId) {\n return;\n }\n\n this.worker.postMessage({\n type: 'cancelProgress',\n messageId,\n });\n }\n\n private subscribe() {\n const { worker, requestStates } = this;\n\n worker.addEventListener('message', ({ data }: WorkerMessageEvent) => {\n if (data.type === 'methodResponse') {\n const requestState = requestStates.get(data.messageId);\n if (requestState) {\n if (data.error) {\n requestState.reject(data.error);\n } else {\n requestState.resolve(data.response);\n }\n }\n } else if (data.type === 'methodCallback') {\n const requestState = requestStates.get(data.messageId);\n requestState?.callback?.(...data.callbackArgs);\n } else if (data.type === 'unhandledError') {\n throw new Error(data.error?.message);\n }\n });\n }\n}\n","import {\n DPR,\n IS_SINGLE_COLUMN_LAYOUT,\n IS_SAFARI,\n IS_ANDROID,\n} from '../../util/environment';\nimport WorkerConnector from '../../util/WorkerConnector';\nimport { animate } from '../../util/animation';\nimport cycleRestrict from '../../util/cycleRestrict';\nimport generateIdFor from '../../util/generateIdFor';\n\ninterface Params {\n noLoop?: boolean;\n size?: number;\n quality?: number;\n isLowPriority?: boolean;\n}\n\ntype Frames = ArrayBuffer[];\ntype Chunks = (Frames | undefined)[];\n\n// TODO Consider removing chunks\nconst CHUNK_SIZE = 1;\nconst MAX_WORKERS = 4;\nconst HIGH_PRIORITY_QUALITY = IS_SINGLE_COLUMN_LAYOUT ? 0.75 : 1;\nconst LOW_PRIORITY_QUALITY = IS_ANDROID ? 0.5 : 0.75;\nconst HIGH_PRIORITY_CACHE_MODULO = IS_SAFARI ? 2 : 4;\nconst LOW_PRIORITY_CACHE_MODULO = 0;\nconst KEY_STORE = {};\n\nconst workers = new Array(MAX_WORKERS).fill(undefined).map(\n () => new WorkerConnector(new Worker(new URL('./rlottie.worker.ts', import.meta.url))),\n);\nlet lastWorkerIndex = -1;\n\nclass RLottie {\n // Config\n\n private imgSize!: number;\n\n private key = generateIdFor(KEY_STORE);\n\n private msPerFrame = 1000 / 60;\n\n private reduceFactor = 1;\n\n private cacheModulo!: number;\n\n private chunkSize!: number;\n\n private workerIndex!: number;\n\n private chunks: Chunks = [];\n\n private framesCount?: number;\n\n private chunksCount?: number;\n\n // Container\n\n private canvas = document.createElement('canvas');\n\n private ctx = this.canvas.getContext('2d')!;\n\n // State\n\n private isAnimating = false;\n\n private isWaiting = true;\n\n private isEnded = false;\n\n private isOnLoadFired = false;\n\n private isDestroyed = false;\n\n private approxFrameIndex = 0;\n\n private prevFrameIndex = -1;\n\n private stopFrameIndex? = 0;\n\n private speed = 1;\n\n private direction: 1 | -1 = 1;\n\n private lastRenderAt?: number;\n\n constructor(\n private container: HTMLDivElement,\n private tgsUrl: string,\n private params: Params = {},\n private onLoad?: () => void,\n private customColor?: [number, number, number],\n private onEnded?: (isDestroyed?: boolean) => void,\n ) {\n this.initContainer();\n this.initConfig();\n this.initRenderer();\n }\n\n isPlaying() {\n return this.isAnimating || this.isWaiting;\n }\n\n play(forceRestart = false) {\n if (this.isEnded && forceRestart) {\n this.approxFrameIndex = Math.floor(0);\n }\n\n this.stopFrameIndex = undefined;\n this.direction = 1;\n this.doPlay();\n }\n\n pause() {\n if (this.isWaiting) {\n this.stopFrameIndex = this.approxFrameIndex;\n } else {\n this.isAnimating = false;\n }\n\n const currentChunkIndex = this.getChunkIndex(this.approxFrameIndex);\n this.chunks = this.chunks.map((chunk, i) => (i === currentChunkIndex ? chunk : undefined));\n }\n\n playSegment([startFrameIndex, stopFrameIndex]: [number, number]) {\n this.approxFrameIndex = Math.floor(startFrameIndex / this.reduceFactor);\n this.stopFrameIndex = Math.floor(stopFrameIndex / this.reduceFactor);\n this.direction = startFrameIndex < stopFrameIndex ? 1 : -1;\n this.doPlay();\n }\n\n setSpeed(speed: number) {\n this.speed = speed;\n }\n\n destroy() {\n this.isDestroyed = true;\n this.pause();\n this.destroyRenderer();\n this.destroyContainer();\n }\n\n private initContainer() {\n if (!(this.container.parentNode instanceof HTMLElement)) {\n throw new Error('[RLottie] Container is not mounted');\n }\n\n let { size } = this.params;\n\n if (!size) {\n size = (\n this.container.offsetWidth\n || parseInt(this.container.style.width, 10)\n || this.container.parentNode.offsetWidth\n );\n\n if (!size) {\n throw new Error('[RLottie] Failed to detect width from container');\n }\n }\n\n this.canvas.style.width = `${size}px`;\n this.canvas.style.height = `${size}px`;\n\n const { isLowPriority, quality = isLowPriority ? LOW_PRIORITY_QUALITY : HIGH_PRIORITY_QUALITY } = this.params;\n // Reduced quality only looks acceptable on high DPR screens\n const imgSize = Math.round(size * Math.max(DPR * quality, 1));\n\n this.canvas.width = imgSize;\n this.canvas.height = imgSize;\n\n this.container.appendChild(this.canvas);\n\n this.imgSize = imgSize;\n }\n\n private initConfig() {\n const { isLowPriority } = this.params;\n\n this.cacheModulo = isLowPriority ? LOW_PRIORITY_CACHE_MODULO : HIGH_PRIORITY_CACHE_MODULO;\n this.chunkSize = CHUNK_SIZE;\n }\n\n private destroyContainer() {\n this.canvas.remove();\n }\n\n setColor(newColor: [number, number, number] | undefined) {\n this.customColor = newColor;\n\n // TODO Remove?\n if (this.customColor) {\n const imageData = this.ctx.getImageData(0, 0, this.imgSize, this.imgSize);\n const arr = imageData.data;\n for (let i = 0; i < arr.length; i += 4) {\n /* eslint-disable prefer-destructuring */\n arr[i] = this.customColor[0];\n arr[i + 1] = this.customColor[1];\n arr[i + 2] = this.customColor[2];\n /* eslint-enable prefer-destructuring */\n }\n this.ctx.putImageData(imageData, 0, 0);\n }\n }\n\n private initRenderer() {\n this.workerIndex = cycleRestrict(MAX_WORKERS, ++lastWorkerIndex);\n\n workers[this.workerIndex].request({\n name: 'init',\n args: [\n this.key,\n this.tgsUrl,\n this.imgSize,\n this.params.isLowPriority,\n this.onRendererInit.bind(this),\n ],\n });\n }\n\n private destroyRenderer() {\n workers[this.workerIndex].request({\n name: 'destroy',\n args: [this.key],\n });\n }\n\n private onRendererInit(reduceFactor: number, msPerFrame: number, framesCount: number) {\n this.reduceFactor = reduceFactor;\n this.msPerFrame = msPerFrame;\n this.framesCount = framesCount;\n this.chunksCount = Math.ceil(framesCount / this.chunkSize);\n\n if (this.isWaiting) {\n this.doPlay();\n }\n }\n\n changeData(tgsUrl: string) {\n this.pause();\n this.tgsUrl = tgsUrl;\n this.initConfig();\n\n workers[this.workerIndex].request({\n name: 'changeData',\n args: [\n this.key,\n this.tgsUrl,\n this.params.isLowPriority,\n this.onChangeData.bind(this),\n ],\n });\n }\n\n private onChangeData(reduceFactor: number, msPerFrame: number, framesCount: number) {\n this.reduceFactor = reduceFactor;\n this.msPerFrame = msPerFrame;\n this.framesCount = framesCount;\n this.chunksCount = Math.ceil(framesCount / this.chunkSize);\n this.isWaiting = false;\n this.isAnimating = false;\n\n this.doPlay();\n }\n\n private doPlay() {\n if (!this.framesCount) {\n return;\n }\n\n if (this.isDestroyed) {\n return;\n }\n\n if (this.isAnimating) {\n return;\n }\n\n if (!this.isWaiting) {\n this.lastRenderAt = undefined;\n }\n\n this.isEnded = false;\n this.isAnimating = true;\n this.isWaiting = false;\n\n animate(() => {\n if (this.isDestroyed) {\n return false;\n }\n\n // Paused from outside\n if (!this.isAnimating && this.isOnLoadFired) {\n return false;\n }\n\n const frameIndex = Math.round(this.approxFrameIndex);\n const chunkIndex = this.getChunkIndex(frameIndex);\n const chunk = this.chunks[chunkIndex];\n\n if (!chunk || chunk.length === 0) {\n this.requestChunk(chunkIndex);\n this.isAnimating = false;\n this.isWaiting = true;\n return false;\n }\n\n if (this.cacheModulo && chunkIndex % this.cacheModulo === 0) {\n this.cleanupPrevChunk(chunkIndex);\n }\n\n if (frameIndex !== this.prevFrameIndex) {\n const frame = this.getFrame(frameIndex);\n if (!frame) {\n this.isAnimating = false;\n this.isWaiting = true;\n return false;\n }\n\n const arr = new Uint8ClampedArray(frame);\n if (this.customColor) {\n for (let i = 0; i < arr.length; i += 4) {\n /* eslint-disable prefer-destructuring */\n arr[i] = this.customColor[0];\n arr[i + 1] = this.customColor[1];\n arr[i + 2] = this.customColor[2];\n /* eslint-enable prefer-destructuring */\n }\n }\n const imageData = new ImageData(arr, this.imgSize, this.imgSize);\n this.ctx.putImageData(imageData, 0, 0);\n\n if (this.onLoad && !this.isOnLoadFired) {\n this.isOnLoadFired = true;\n this.onLoad();\n }\n\n this.prevFrameIndex = frameIndex;\n }\n\n const now = Date.now();\n const currentSpeed = this.lastRenderAt ? this.msPerFrame / (now - this.lastRenderAt) : 1;\n const delta = Math.min(1, (this.direction * this.speed) / currentSpeed);\n const expectedNextFrameIndex = Math.round(this.approxFrameIndex + delta);\n\n this.lastRenderAt = now;\n\n // Forward animation finished\n if (delta > 0 && (frameIndex === this.framesCount! - 1 || expectedNextFrameIndex > this.framesCount! - 1)) {\n if (this.params.noLoop) {\n this.isAnimating = false;\n this.isEnded = true;\n this.onEnded?.();\n return false;\n }\n\n this.approxFrameIndex = 0;\n\n // Backward animation finished\n } else if (delta < 0 && (frameIndex === 0 || expectedNextFrameIndex < 0)) {\n if (this.params.noLoop) {\n this.isAnimating = false;\n this.isEnded = true;\n this.onEnded?.();\n return false;\n }\n\n this.approxFrameIndex = this.framesCount! - 1;\n\n // Stop frame reached\n } else if (\n this.stopFrameIndex !== undefined\n && (frameIndex === this.stopFrameIndex\n || (\n (delta > 0 && expectedNextFrameIndex > this.stopFrameIndex)\n || (delta < 0 && expectedNextFrameIndex < this.stopFrameIndex)\n ))\n ) {\n this.stopFrameIndex = undefined;\n this.isAnimating = false;\n return false;\n\n // Preparing next frame\n } else {\n this.approxFrameIndex += delta;\n }\n\n const nextFrameIndex = Math.round(this.approxFrameIndex);\n\n if (!this.getFrame(nextFrameIndex)) {\n this.requestChunk(this.getChunkIndex(nextFrameIndex));\n this.isWaiting = true;\n this.isAnimating = false;\n return false;\n }\n\n return true;\n });\n }\n\n private getFrame(frameIndex: number) {\n const chunkIndex = this.getChunkIndex(frameIndex);\n const indexInChunk = this.getFrameIndexInChunk(frameIndex);\n const chunk = this.chunks[chunkIndex];\n if (!chunk) {\n return undefined;\n }\n\n return chunk[indexInChunk];\n }\n\n private getFrameIndexInChunk(frameIndex: number) {\n const chunkIndex = this.getChunkIndex(frameIndex);\n return frameIndex - chunkIndex * this.chunkSize;\n }\n\n private getChunkIndex(frameIndex: number) {\n return Math.floor(frameIndex / this.chunkSize);\n }\n\n private requestChunk(chunkIndex: number) {\n if (this.chunks[chunkIndex] && this.chunks[chunkIndex]?.length !== 0) {\n return;\n }\n\n this.chunks[chunkIndex] = [];\n\n const fromIndex = chunkIndex * this.chunkSize;\n const toIndex = Math.min(fromIndex + this.chunkSize - 1, this.framesCount! - 1);\n\n workers[this.workerIndex].request({\n name: 'renderFrames',\n args: [this.key, fromIndex, toIndex, this.onFrameLoad.bind(this)],\n });\n }\n\n private cleanupPrevChunk(chunkIndex: number) {\n if (this.chunksCount! < 3) {\n return;\n }\n\n const prevChunkIndex = cycleRestrict(this.chunksCount!, chunkIndex - 1);\n this.chunks[prevChunkIndex] = undefined;\n }\n\n private requestNextChunk(chunkIndex: number) {\n if (this.chunksCount === 1) {\n return;\n }\n\n const nextChunkIndex = cycleRestrict(this.chunksCount!, chunkIndex + 1);\n\n if (!this.chunks[nextChunkIndex]) {\n this.requestChunk(nextChunkIndex);\n }\n }\n\n private onFrameLoad(frameIndex: number, arrayBuffer: ArrayBuffer) {\n const chunkIndex = this.getChunkIndex(frameIndex);\n const chunk = this.chunks[chunkIndex];\n // Frame can be skipped and chunk can be already cleaned up\n if (!chunk) {\n return;\n }\n\n chunk[this.getFrameIndexInChunk(frameIndex)] = arrayBuffer;\n\n if (this.isWaiting) {\n this.doPlay();\n }\n }\n}\n\nexport default RLottie;\n","export default function cycleRestrict(length: number, index: number) {\n return index - Math.floor(index / length) * length;\n}\n"],"names":["WorkerConnector","constructor","worker","Map","this","subscribe","request","messageData","requestStates","requestStatesByCallback","messageId","generateIdFor","payload","type","requestState","promise","Promise","resolve","reject","Object","assign","args","length","callback","pop","set","catch","finally","delete","postMessage","cancelCallback","progressCallback","isCanceled","get","addEventListener","data","error","response","callbackArgs","Error","message","HIGH_PRIORITY_QUALITY","IS_SINGLE_COLUMN_LAYOUT","LOW_PRIORITY_QUALITY","IS_ANDROID","HIGH_PRIORITY_CACHE_MODULO","IS_SAFARI","KEY_STORE","workers","Array","fill","undefined","map","Worker","URL","lastWorkerIndex","container","tgsUrl","params","onLoad","customColor","onEnded","document","createElement","canvas","getContext","initContainer","initConfig","initRenderer","isPlaying","isAnimating","isWaiting","play","forceRestart","isEnded","approxFrameIndex","Math","floor","stopFrameIndex","direction","doPlay","pause","currentChunkIndex","getChunkIndex","chunks","chunk","i","playSegment","startFrameIndex","reduceFactor","setSpeed","speed","destroy","isDestroyed","destroyRenderer","destroyContainer","parentNode","HTMLElement","size","offsetWidth","parseInt","style","width","height","isLowPriority","quality","imgSize","round","max","DPR","appendChild","cacheModulo","chunkSize","remove","setColor","newColor","imageData","ctx","getImageData","arr","putImageData","workerIndex","cycleRestrict","name","key","onRendererInit","bind","msPerFrame","framesCount","chunksCount","ceil","changeData","onChangeData","lastRenderAt","animate","isOnLoadFired","frameIndex","chunkIndex","requestChunk","cleanupPrevChunk","prevFrameIndex","frame","getFrame","Uint8ClampedArray","ImageData","now","Date","currentSpeed","delta","min","expectedNextFrameIndex","noLoop","nextFrameIndex","indexInChunk","getFrameIndexInChunk","fromIndex","toIndex","onFrameLoad","prevChunkIndex","requestNextChunk","nextChunkIndex","arrayBuffer","index"],"sourceRoot":""} |