@vknext/shared 1.6.37 → 1.6.38

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- class e{scope;swUrl;swAbsoluteUrl;messages=[];keepAliveInterval;constructor(e){this.swUrl=e.swUrl,this.scope=e.scope,this.swAbsoluteUrl=new URL(e.swUrl,location.href).href,this.init()}init(){window.onmessage=e=>this.messages.push(e),window.opener&&window.opener.postMessage("VKNext/StreamSaver::loadedPopup","*"),navigator.serviceWorker&&this.getServiceWorker().then((()=>{window.onmessage=e=>this.onMessage(e),this.messages.forEach((e=>this.onMessage(e))),this.messages=[]})),this.keepAlive()}keepAlive(){if(this.keepAliveInterval)return;const e=location.href.substring(0,location.href.lastIndexOf("/"))+"/ping";this.keepAliveInterval=window.setInterval((async()=>{const t=await this.getServiceWorker();t?t.postMessage("ping"):fetch(e).then((e=>(!e.ok&&this.keepAliveInterval&&clearInterval(this.keepAliveInterval),e.text())))}),1e4)}async getServiceWorker(){if(!navigator.serviceWorker)return null;let e=await navigator.serviceWorker.getRegistration(this.swUrl);e&&e.active?.scriptURL===this.swAbsoluteUrl||(e=await navigator.serviceWorker.register(this.swUrl,{scope:this.scope})),this.scope=e.scope;const t=e.active;if(t&&"redundant"!==t.state)return t;const a=e.installing||e.waiting;return a?new Promise((t=>{const r=()=>{"activated"===a.state&&(a.removeEventListener("statechange",r),t(e.active))};a.addEventListener("statechange",r)})):null}async onMessage(e){let{data:t,ports:a,origin:r}=e;if(!a||!a.length)throw new TypeError("[VK Next/StreamSaver] You didn't send a messageChannel");if("object"!=typeof t)throw new TypeError("[VK Next/StreamSaver] You didn't send a object");const s=t;s.origin=r,s.referrer=s.referrer||document.referrer||r,s.headers?new Headers(s.headers):console.warn("[VK Next/StreamSaver] pass `data.headers`..."),"string"==typeof s.filename&&(console.warn("[VK Next/StreamSaver] You shouldn't send `data.filename` anymore..."),s.filename=s.filename.replace(/\//g,":")),s.size&&console.warn("[VK Next/StreamSaver] You shouldn't send `data.size` anymore..."),s.readableStream&&console.warn("[VK Next/StreamSaver] You should send the readableStream in the messageChannel..."),s.pathname||(console.warn("[VK Next/StreamSaver] Please send `data.pathname`"),s.pathname=Math.random().toString().slice(-6)+"/"+s.filename),s.pathname=s.pathname.replace(/^\/+/g,"");let n=r.replace(/(^\w+:|^)\/\//,"");if(s.url=new URL(`${this.scope+n}/${s.pathname}`).toString(),!s.url.startsWith(`${this.scope+n}/`))throw new TypeError("[StreamSaver] bad `data.pathname`");const i=s.readableStream?[a[0],s.readableStream]:[a[0]];s.readableStream||s.transferringReadable||this.keepAlive();const o=await this.getServiceWorker();o?o.postMessage(s,i):console.warn("[VK Next/StreamSaver] No active service worker to handle message")}}export{e as StreamSaverMitm};
1
+ class e{scope;swUrl;swAbsoluteUrl;messages=[];keepAliveInterval;constructor(e){this.swUrl=e.swUrl,this.scope=e.scope,this.swAbsoluteUrl=new URL(e.swUrl,location.href).href,this.init()}init(){window.onmessage=e=>this.messages.push(e),window.opener&&window.opener.postMessage("VKNext/StreamSaver::loadedPopup","*"),navigator.serviceWorker&&this.getServiceWorker().then((e=>{if(e)window.onmessage=e=>this.onMessage(e),this.messages.forEach((e=>this.onMessage(e))),this.messages=[];else{const e=window.opener||window.parent;e&&e!==window&&e.postMessage({type:"VKNext/StreamSaver::sw-error"},"*")}})),this.keepAlive()}keepAlive(){if(this.keepAliveInterval)return;const e=location.href.substring(0,location.href.lastIndexOf("/"))+"/ping";this.keepAliveInterval=window.setInterval((async()=>{const t=await this.getServiceWorker();t?t.postMessage("ping"):fetch(e).then((e=>(!e.ok&&this.keepAliveInterval&&clearInterval(this.keepAliveInterval),e.text())))}),1e4)}async getServiceWorker(){if(!navigator.serviceWorker)return null;try{let e=await navigator.serviceWorker.getRegistration(this.swUrl);e&&e.active?.scriptURL===this.swAbsoluteUrl||(e=await navigator.serviceWorker.register(this.swUrl,{scope:this.scope})),this.scope=e.scope;const t=e.active;if(t&&"redundant"!==t.state)return t;const r=e.installing||e.waiting;return r?new Promise((t=>{const a=()=>{"activated"===r.state&&(r.removeEventListener("statechange",a),t(e.active))};r.addEventListener("statechange",a)})):null}catch(e){return console.warn("[VK Next/StreamSaver] Service Worker registration failed:",e),null}}async onMessage(e){let{data:t,ports:r,origin:a}=e;if(!r||!r.length)throw new TypeError("[VK Next/StreamSaver] You didn't send a messageChannel");if("object"!=typeof t)throw new TypeError("[VK Next/StreamSaver] You didn't send a object");const s=t;s.origin=a,s.referrer=s.referrer||document.referrer||a,s.headers?new Headers(s.headers):console.warn("[VK Next/StreamSaver] pass `data.headers`..."),"string"==typeof s.filename&&(console.warn("[VK Next/StreamSaver] You shouldn't send `data.filename` anymore..."),s.filename=s.filename.replace(/\//g,":")),s.size&&console.warn("[VK Next/StreamSaver] You shouldn't send `data.size` anymore..."),s.readableStream&&console.warn("[VK Next/StreamSaver] You should send the readableStream in the messageChannel..."),s.pathname||(console.warn("[VK Next/StreamSaver] Please send `data.pathname`"),s.pathname=Math.random().toString().slice(-6)+"/"+s.filename),s.pathname=s.pathname.replace(/^\/+/g,"");let n=a.replace(/(^\w+:|^)\/\//,"");if(s.url=new URL(`${this.scope+n}/${s.pathname}`).toString(),!s.url.startsWith(`${this.scope+n}/`))throw new TypeError("[StreamSaver] bad `data.pathname`");const o=s.readableStream?[r[0],s.readableStream]:[r[0]];s.readableStream||s.transferringReadable||this.keepAlive();const i=await this.getServiceWorker();i?i.postMessage(s,o):console.warn("[VK Next/StreamSaver] No active service worker to handle message")}}export{e as StreamSaverMitm};
@@ -1 +1 @@
1
- class e{downloadIframe=null;mitm=null;mitmTransporter=null;supportsTransferable=!1;useBlobFallback=!1;downloadStrategy="iframe";options;constructor(e){this.options=e,globalThis.HTMLElement||console.warn("[VK Next/StreamSaver] is meant to run on browsers main thread");const t=globalThis,a=t.isSecureContext;this.useBlobFallback=/constructor/i.test(String(t.HTMLElement))||!!t.safari||!!t.WebKitPoint;try{new Response(new ReadableStream),(a&&!("serviceWorker"in navigator)||!navigator.serviceWorker)&&(this.useBlobFallback=!0)}catch(e){this.useBlobFallback=!0}this.downloadStrategy=a||"MozAppearance"in document.documentElement.style?"iframe":"navigate",this.test((()=>{const{readable:e}=new TransformStream,t=new MessageChannel;t.port1.postMessage(e,[e]),t.port1.close(),t.port2.close(),this.supportsTransferable=!0})),this.resolveMitmUrl()}test(e){try{e()}catch(e){}}resolveMitmUrl(){this.options.getMitmUrl().then((e=>{this.mitm=e,this.mitmTransporter&&this.mitmTransporter.loadUrl&&this.mitmTransporter.loadUrl(e)}))}makeIframe(e,t){const a=document.createElement("iframe");a.hidden=!0,a.name=`VK Next Saver | ${t||Math.random()}`,e&&(a.src=e);const r={isPopup:!1,isIframe:!0,loaded:!1,postMessage:(e,t,r)=>{a.contentWindow&&a.contentWindow.postMessage(e,t,r||[])},loadUrl:e=>{a.src=e},addEventListener:(...e)=>a.addEventListener(...e),removeEventListener:(...e)=>a.removeEventListener(...e),dispatchEvent:(...e)=>a.dispatchEvent(...e),remove:()=>a.remove()};return a.addEventListener("load",(()=>{a.src&&"about:blank"!==a.src&&(r.loaded=!0)}),{once:!0}),(document.body||document.documentElement).appendChild(a),r}getDownloadIframe(){if(!this.downloadIframe){const e=document.createElement("iframe");e.hidden=!0,e.style.display="none",e.name="VK Next Saver | downloader",document.body.appendChild(e),this.downloadIframe=e}return this.downloadIframe}makePopup(e){const t=document.createDocumentFragment(),a={frame:window.open(e||"","popup","width=200,height=100"),loaded:!1,isIframe:!1,isPopup:!0,remove(){a.frame&&a.frame.close()},addEventListener(...e){t.addEventListener(...e)},dispatchEvent:(...e)=>t.dispatchEvent(...e),removeEventListener(...e){t.removeEventListener(...e)},postMessage(e,t,r){a.frame&&a.frame.postMessage(e,t,r||[])},loadUrl(e){a.frame&&(a.frame.location.href=e)}},r=e=>{e.source===a.frame&&(a.loaded=!0,window.removeEventListener("message",r),a.dispatchEvent(new Event("load")))};return window.addEventListener("message",r),a}loadTransporter(){this.mitmTransporter||(this.mitmTransporter=window.isSecureContext?this.makeIframe(this.mitm,"transporter"):this.makePopup(this.mitm))}createWriteStream(e,t,a){let r={size:void 0,pathname:void 0,writableStrategy:void 0,readableStrategy:void 0},o=0,s=null,n=null,i=null,l=!1;if(t&&("highWaterMark"in t||"function"==typeof t.size)?(console.warn("[VK Next/StreamSaver] Deprecated pass an object as 2nd argument when creating a write stream"),r.size=a,r.writableStrategy=t):r=t||{},!this.useBlobFallback){this.loadTransporter(),n=new MessageChannel,e=encodeURIComponent(e.replace(/\//g,":")).replace(/['()]/g,escape).replace(/\*/g,"%2A");const t={transferringReadable:this.supportsTransferable,pathname:r.pathname||Math.random().toString().slice(-6)+"/"+e,headers:{"Content-Type":"application/octet-stream; charset=utf-8","Content-Disposition":"attachment; filename*=UTF-8''"+e}};r.size&&(t.headers["Content-Length"]=r.size);const a=[t,"*",[n.port2]];if(this.supportsTransferable){const e="iframe"===this.downloadStrategy?void 0:{transform(e,t){if(!(e instanceof Uint8Array))throw new TypeError("Can only write Uint8Arrays");o+=e.length,t.enqueue(e),s&&(location.href=s,s=null)},flush(){s&&(location.href=s)}};i=new TransformStream(e,r.writableStrategy,r.readableStrategy);const t=i.readable;n.port1.postMessage({readableStream:t},[t])}n.port1.onmessage=e=>{if(e.data.download){if("navigate"===this.downloadStrategy)this.mitmTransporter&&(this.mitmTransporter.remove(),this.mitmTransporter=null),o?location.href=e.data.download:s=e.data.download;else if(this.mitmTransporter&&this.mitmTransporter.isPopup&&(this.mitmTransporter.remove(),this.mitmTransporter=null,"iframe"===this.downloadStrategy&&this.makeIframe(this.mitm,"transporter")),!l){this.getDownloadIframe().src=e.data.download}}else e.data.abort&&(m=[],n&&(n.port1.postMessage("abort"),n.port1.onmessage=null,n.port1.close(),n.port2.close(),n=null))},this.mitmTransporter.loaded?this.mitmTransporter.postMessage(...a):this.mitmTransporter.addEventListener("load",(()=>{this.mitmTransporter.postMessage(...a)}),{once:!0})}let m=[];if(!this.useBlobFallback&&i&&i.writable){const e=i.writable.getWriter();return new WritableStream({write:t=>e.write(t),close:async()=>{l=!0,await e.close()},abort:async t=>{l=!0,await e.abort(t)}})}return new WritableStream({write:e=>{if(!(e instanceof Uint8Array))throw new TypeError("Can only write Uint8Arrays");this.useBlobFallback?m.push(e):(n&&n.port1.postMessage(e),o+=e.length,s&&(location.href=s,s=null))},close:()=>{if(l=!0,this.useBlobFallback){const t=new Blob(m,{type:"application/octet-stream; charset=utf-8"}),a=document.createElement("a");a.href=URL.createObjectURL(t),a.download=e,a.click()}else n&&n.port1.postMessage("end")},abort:()=>{l=!0,m=[],n&&(n.port1.postMessage("abort"),n.port1.onmessage=null,n.port1.close(),n.port2.close(),n=null)}},r.writableStrategy)}}export{e as StreamSaver};
1
+ class e{downloadIframe=null;mitm=null;mitmTransporter=null;supportsTransferable=!1;useBlobFallback=!1;downloadStrategy="iframe";options;constructor(e){this.options=e,globalThis.HTMLElement||console.warn("[VK Next/StreamSaver] is meant to run on browsers main thread"),"undefined"!=typeof window&&window.addEventListener("message",(e=>{"VKNext/StreamSaver::sw-error"===e.data?.type&&(console.warn("[VK Next/StreamSaver] Switching to blob fallback due to SW error"),this.useBlobFallback=!0,this.mitmTransporter&&(this.mitmTransporter.remove(),this.mitmTransporter=null))}));const t=globalThis,r=t.isSecureContext;this.useBlobFallback=/constructor/i.test(String(t.HTMLElement))||!!t.safari||!!t.WebKitPoint;try{new Response(new ReadableStream),(r&&!("serviceWorker"in navigator)||!navigator.serviceWorker)&&(this.useBlobFallback=!0)}catch(e){this.useBlobFallback=!0}this.downloadStrategy=r||"MozAppearance"in document.documentElement.style?"iframe":"navigate",this.test((()=>{const{readable:e}=new TransformStream,t=new MessageChannel;t.port1.postMessage(e,[e]),t.port1.close(),t.port2.close(),this.supportsTransferable=!0})),this.resolveMitmUrl()}test(e){try{e()}catch(e){}}resolveMitmUrl(){this.options.getMitmUrl().then((e=>{this.mitm=e,this.mitmTransporter&&this.mitmTransporter.loadUrl&&this.mitmTransporter.loadUrl(e)}))}makeIframe(e,t){const r=document.createElement("iframe");r.hidden=!0,r.name=`VK Next Saver | ${t||Math.random()}`,e&&(r.src=e);const a={isPopup:!1,isIframe:!0,loaded:!1,postMessage:(e,t,a)=>{r.contentWindow&&r.contentWindow.postMessage(e,t,a||[])},loadUrl:e=>{r.src=e},addEventListener:(...e)=>r.addEventListener(...e),removeEventListener:(...e)=>r.removeEventListener(...e),dispatchEvent:(...e)=>r.dispatchEvent(...e),remove:()=>r.remove()};return r.addEventListener("load",(()=>{r.src&&"about:blank"!==r.src&&(a.loaded=!0)}),{once:!0}),(document.body||document.documentElement).appendChild(r),a}getDownloadIframe(){if(!this.downloadIframe){const e=document.createElement("iframe");e.hidden=!0,e.style.display="none",e.name="VK Next Saver | downloader",document.body.appendChild(e),this.downloadIframe=e}return this.downloadIframe}makePopup(e){const t=document.createDocumentFragment(),r={frame:window.open(e||"","popup","width=200,height=100"),loaded:!1,isIframe:!1,isPopup:!0,remove(){r.frame&&r.frame.close()},addEventListener(...e){t.addEventListener(...e)},dispatchEvent:(...e)=>t.dispatchEvent(...e),removeEventListener(...e){t.removeEventListener(...e)},postMessage(e,t,a){r.frame&&r.frame.postMessage(e,t,a||[])},loadUrl(e){r.frame&&(r.frame.location.href=e)}},a=e=>{e.source===r.frame&&(r.loaded=!0,window.removeEventListener("message",a),r.dispatchEvent(new Event("load")))};return window.addEventListener("message",a),r}loadTransporter(){this.mitmTransporter||(this.mitmTransporter=window.isSecureContext?this.makeIframe(this.mitm,"transporter"):this.makePopup(this.mitm))}createWriteStream(e,t,r){let a={size:void 0,pathname:void 0,writableStrategy:void 0,readableStrategy:void 0},o=0,s=null,n=null,i=null,l=!1;if(t&&("highWaterMark"in t||"function"==typeof t.size)?(console.warn("[VK Next/StreamSaver] Deprecated pass an object as 2nd argument when creating a write stream"),a.size=r,a.writableStrategy=t):a=t||{},!this.useBlobFallback){this.loadTransporter(),n=new MessageChannel,e=encodeURIComponent(e.replace(/\//g,":")).replace(/['()]/g,escape).replace(/\*/g,"%2A");const t={transferringReadable:this.supportsTransferable,pathname:a.pathname||Math.random().toString().slice(-6)+"/"+e,headers:{"Content-Type":"application/octet-stream; charset=utf-8","Content-Disposition":"attachment; filename*=UTF-8''"+e}};a.size&&(t.headers["Content-Length"]=a.size);const r=[t,"*",[n.port2]];if(this.supportsTransferable){const e="iframe"===this.downloadStrategy?void 0:{transform(e,t){if(!(e instanceof Uint8Array))throw new TypeError("Can only write Uint8Arrays");o+=e.length,t.enqueue(e),s&&(location.href=s,s=null)},flush(){s&&(location.href=s)}};i=new TransformStream(e,a.writableStrategy,a.readableStrategy);const t=i.readable;n.port1.postMessage({readableStream:t},[t])}n.port1.onmessage=e=>{if(e.data.download){if("navigate"===this.downloadStrategy)this.mitmTransporter&&(this.mitmTransporter.remove(),this.mitmTransporter=null),o?location.href=e.data.download:s=e.data.download;else if(this.mitmTransporter&&this.mitmTransporter.isPopup&&(this.mitmTransporter.remove(),this.mitmTransporter=null,"iframe"===this.downloadStrategy&&this.makeIframe(this.mitm,"transporter")),!l){this.getDownloadIframe().src=e.data.download}}else e.data.abort&&(m=[],n&&(n.port1.postMessage("abort"),n.port1.onmessage=null,n.port1.close(),n.port2.close(),n=null))},this.mitmTransporter.loaded?this.mitmTransporter.postMessage(...r):this.mitmTransporter.addEventListener("load",(()=>{this.mitmTransporter.postMessage(...r)}),{once:!0})}let m=[];if(!this.useBlobFallback&&i&&i.writable){const e=i.writable.getWriter();return new WritableStream({write:t=>e.write(t),close:async()=>{l=!0,await e.close()},abort:async t=>{l=!0,await e.abort(t)}})}return new WritableStream({write:e=>{if(!(e instanceof Uint8Array))throw new TypeError("Can only write Uint8Arrays");this.useBlobFallback?m.push(e):(n&&n.port1.postMessage(e),o+=e.length,s&&(location.href=s,s=null))},close:()=>{if(l=!0,this.useBlobFallback){const t=new Blob(m,{type:"application/octet-stream; charset=utf-8"}),r=document.createElement("a");r.href=URL.createObjectURL(t),r.download=e,r.click()}else n&&n.port1.postMessage("end")},abort:()=>{l=!0,m=[],n&&(n.port1.postMessage("abort"),n.port1.onmessage=null,n.port1.close(),n.port2.close(),n=null)}},a.writableStrategy)}}export{e as StreamSaver};
@@ -0,0 +1,14 @@
1
+ export interface ConvertTrackToBlobOptions {
2
+ url: string;
3
+ filename?: string;
4
+ /**
5
+ *
6
+ * @param progress значение от 0 до 1
7
+ */
8
+ onProgress?: (progress: number) => void;
9
+ forceHls?: boolean;
10
+ }
11
+ /**
12
+ * @deprecated use convertTrackToStream
13
+ */
14
+ export declare const convertTrackToBlob: ({ url, filename, onProgress, forceHls, }: ConvertTrackToBlobOptions) => Promise<Blob>;
@@ -0,0 +1 @@
1
+ import{createPromise as e}from"../../utils/createPromise.js";import"../../utils/parseSvg.js";import{getHlsInstance as r}from"./utils/getHlsInstance.js";import{sendMessage as o}from"./utils/sendMessage.js";const t=async({url:t,filename:s,onProgress:n,forceHls:a})=>{if(!a)try{return await o({url:t,filename:s,type:"convertHlsToMp3",onProgress:n})}catch(e){console.error(e)}const{promise:i,resolve:l,reject:c}=e(),d=await r(),u=new d,E=new Audio;let p=null;const m=[];let f,g,v=0;const y=e=>{c(e),u.stopLoad(),u.destroy()};return u.on(d.Events.MANIFEST_PARSED,((e,r)=>{const o=r.levels[0]?.details;o&&(g=o.fragments.length)})),u.on(d.Events.BUFFER_CODECS,((e,r)=>{r.audio&&"audio/mp4"!==r.audio.container||(f=r.audio)})),u.on(d.Events.BUFFER_APPENDING,((e,r)=>{p=r.data})),u.on(d.Events.ERROR,((e,r)=>{if(!["bufferFullError","fragLoadError"].includes(r.details))return r.type==d.ErrorTypes.MEDIA_ERROR&&v<2?(++v>1&&u.swapAudioCodec(),void u.recoverMediaError()):void y(e);y(e)})),u.on(d.Events.FRAG_BUFFERED,(async(e,r)=>{p&&m.push(f?p.slice(8,p.length):p),E.currentTime=r.frag.start+r.frag.duration;try{n&&n(m.length/g)}catch(e){console.error(e)}if(m.length>=g){u.stopLoad(),u.destroy();const e=m.map((e=>new Uint8Array(e))),r=new Blob(e,{type:"audio/mp3"});l(r)}})),u.loadSource(t),u.attachMedia(E),await i};export{t as convertTrackToBlob};
@@ -1,4 +1,4 @@
1
1
  export * from "./audioUnmaskSource";
2
- export * from "./convertTrackToStream";
2
+ export * from "./convertTrackToBlob";
3
3
  export * from "./getTrackDetails";
4
4
  export * from "./utils/sendMessage";
@@ -1 +1 @@
1
- export{audioUnmaskSource}from"./audioUnmaskSource.js";export{convertTrackToStream}from"./convertTrackToStream.js";export{getTrackDetails}from"./getTrackDetails.js";export{sendMessage}from"./utils/sendMessage.js";
1
+ export{audioUnmaskSource}from"./audioUnmaskSource.js";export{convertTrackToBlob}from"./convertTrackToBlob.js";export{getTrackDetails}from"./getTrackDetails.js";export{sendMessage}from"./utils/sendMessage.js";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vknext/shared",
3
- "version": "1.6.37",
3
+ "version": "1.6.38",
4
4
  "description": "vk next shared",
5
5
  "type": "module",
6
6
  "files": [
@@ -39,10 +39,6 @@
39
39
  "types": "./dist/vkcom/audio/index.d.ts",
40
40
  "default": "./dist/vkcom/audio/index.js"
41
41
  },
42
- "./vkcom/video": {
43
- "types": "./dist/vkcom/audio/index.d.ts",
44
- "default": "./dist/vkcom/audio/index.js"
45
- },
46
42
  "./vkcom/globalVars": {
47
43
  "types": "./dist/vkcom/globalVars/index.d.ts",
48
44
  "default": "./dist/vkcom/globalVars/index.js"
@@ -1,10 +0,0 @@
1
- export interface ConvertVideoToStreamOptions {
2
- url: string;
3
- /**
4
- * индекс из getVideoQualities.
5
- * если не передан — будет выбрано максимальное качество, но не больше 1080p
6
- */
7
- levelIndex?: number;
8
- onProgress?: (progress: number) => void;
9
- }
10
- export declare const convertVideoToStream: ({ url, levelIndex, onProgress, }: ConvertVideoToStreamOptions) => ReadableStream<Uint8Array>;
@@ -1 +0,0 @@
1
- import{attachHlsErrorHandlers as e}from"../audio/utils/attachHlsErrorHandlers.js";import{getHlsInstance as t}from"../audio/utils/getHlsInstance.js";const r=({url:r,levelIndex:n,onProgress:a})=>{let o=null,l=null;const s=()=>{o&&(o.stopLoad(),o.destroy()),l&&(l.pause(),l.remove())};return new ReadableStream({async start(i){const c=await t();o=new c({maxBufferHole:.5,maxBufferLength:300,maxBufferSize:12e7,backBufferLength:0,fragLoadingRetryDelay:500,fragLoadingMaxRetry:20,enableWorker:!0,startLevel:void 0!==n?n:-1}),l=document.createElement("video"),l.muted=!0;let d=0,u=0;o.on(c.Events.MANIFEST_PARSED,((e,t)=>{if(!o)return;if(void 0===n){let e=-1;for(let t=o.levels.length-1;t>=0;t--){const r=o.levels[t];if(!r)continue;if(Math.min(r.width,r.height)<=1080){e=t;break}}o.currentLevel=-1!==e?e:o.levels.length-1}else o.currentLevel=n;const r=o?.currentLevel??0,a=t.levels[r]?.details;a&&(d=a.fragments.length),l?.play().catch((()=>{}))})),o.on(c.Events.LEVEL_LOADED,((e,t)=>{t.details&&(d=t.details.fragments.length)})),o.on(c.Events.BUFFER_APPENDING,((e,t)=>{"video"===t.type||"audiovideo"===t.type?i.enqueue(t.data):console.warn("[convertVideoToStream] при загрузке фрагмента пришел неожиданный тип",t)})),o.on(c.Events.FRAG_BUFFERED,(async(e,t)=>{u++,l&&(l.currentTime=Math.max(0,t.frag.start+t.frag.duration-.5));try{a&&d>0&&a(Math.min(.99,u/d))}catch(e){console.error(e)}u>=d&&(a&&a(1),s(),i.close())})),e({Hls:c,hlsInstance:o,onError:e=>{i.error(new Error(e||"HLS Error")),s()}}),o.loadSource(r),o.attachMedia(l)},cancel(){s()}})};export{r as convertVideoToStream};
@@ -1,15 +0,0 @@
1
- export interface VideoQuality {
2
- /**
3
- * передавать в convertVideoToStream
4
- */
5
- levelIndex: number;
6
- height: number;
7
- width: number;
8
- bitrate: number;
9
- /**
10
- * используется для подсчета размера видео
11
- */
12
- averageBitrate: number | null;
13
- frameRate: number;
14
- }
15
- export declare const getVideoQualities: (url: string) => Promise<VideoQuality[]>;
@@ -1 +0,0 @@
1
- import{getHlsInstance as t}from"../audio/utils/getHlsInstance.js";const e=async e=>{const r=await t();return new Promise(((t,a)=>{const n=new r({enableWorker:!1});n.on(r.Events.MANIFEST_PARSED,((e,r)=>{const a=r.levels.map(((t,e)=>{const r=t.attrs["AVERAGE-BANDWIDTH"]?parseInt(t.attrs["AVERAGE-BANDWIDTH"],10):null;return{levelIndex:e,height:t.height,width:t.width,bitrate:t.bitrate,averageBitrate:r,frameRate:t.frameRate}}));a.sort(((t,e)=>e.bitrate-t.bitrate)),n.destroy(),t(a)})),n.on(r.Events.ERROR,((t,e)=>{e.fatal&&(n.destroy(),a(new Error(`HLS Error: ${e.details}`)))})),n.loadSource(e)}))};export{e as getVideoQualities};
@@ -1,2 +0,0 @@
1
- export * from "./convertVideoToStream";
2
- export * from "./getVideoQualities";
@@ -1 +0,0 @@
1
- export{convertVideoToStream}from"./convertVideoToStream.js";export{getVideoQualities}from"./getVideoQualities.js";