@zappar/mediarecorder 0.0.1 → 0.1.0

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.
@@ -8,7 +8,9 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
8
8
  });
9
9
  };
10
10
  import * as enc from "./encoder";
11
- enc.initialize(new URL("./webmtransmux.wasm", import.meta.url).toString());
11
+ enc.initialize(new URL("./webmtransmux.wasm", import.meta.url).toString()).then(() => {
12
+ postMessage({ 'type': 'converter-worker-loaded' });
13
+ });
12
14
  addEventListener('message', (evt) => __awaiter(void 0, void 0, void 0, function* () {
13
15
  if (evt && evt.data && typeof evt.data['indx'] === 'number') {
14
16
  const webtrans = yield enc.createWebMTrans();
@@ -1,2 +1,3 @@
1
- export declare function getWorker(): Worker;
1
+ export declare function getWorker(): Promise<Worker>;
2
2
  export declare function convert(data: ArrayBuffer): Promise<ArrayBuffer>;
3
+ export declare function load(): Promise<void>;
package/lib/converter.js CHANGED
@@ -1,20 +1,49 @@
1
- let worker;
1
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ let workerPromise;
2
11
  export function getWorker() {
3
- if (!worker)
4
- worker = new Worker(new URL('./converter-worker', import.meta.url), { type: 'module' });
5
- return worker;
12
+ if (!workerPromise) {
13
+ workerPromise = new Promise(resolve => {
14
+ const worker = new Worker(new URL('./converter-worker', import.meta.url), { type: 'module' });
15
+ function handle(evt) {
16
+ if (evt.data && evt.data.type === 'converter-worker-loaded') {
17
+ worker.removeEventListener('message', handle);
18
+ resolve(worker);
19
+ }
20
+ }
21
+ worker.addEventListener('message', handle);
22
+ });
23
+ }
24
+ return workerPromise;
6
25
  }
7
26
  let nextIndex = 0;
8
27
  export function convert(data) {
9
- const worker = getWorker();
10
- const indx = nextIndex++;
11
- return new Promise(resolve => {
12
- function handler(evt) {
13
- worker.removeEventListener('message', handler);
14
- if (evt.data['indx'] === indx)
15
- resolve(evt.data['data']);
28
+ return __awaiter(this, void 0, void 0, function* () {
29
+ const worker = yield getWorker();
30
+ const indx = nextIndex++;
31
+ return yield new Promise(resolve => {
32
+ function handler(evt) {
33
+ worker.removeEventListener('message', handler);
34
+ if (evt.data['indx'] === indx)
35
+ resolve(evt.data['data']);
36
+ }
37
+ worker.addEventListener('message', handler);
38
+ worker.postMessage({ indx, data }, [data]);
39
+ });
40
+ });
41
+ }
42
+ export function load() {
43
+ return __awaiter(this, void 0, void 0, function* () {
44
+ // Preload worker if it's likely to be necessary
45
+ if (!MediaRecorder.isTypeSupported('video/mp4') && MediaRecorder.isTypeSupported('video/webm;codecs="avc1,opus"')) {
46
+ yield getWorker();
16
47
  }
17
- worker.addEventListener('message', handler);
18
- worker.postMessage({ indx, data }, [data]);
19
48
  });
20
49
  }
package/lib/index.d.ts CHANGED
@@ -1,2 +1,2 @@
1
1
  export { ConvertingMediaRecorder as MediaRecorder } from './mediarecorder';
2
- export { convert } from './converter';
2
+ export { convert, load } from './converter';
package/lib/index.js CHANGED
@@ -1,2 +1,2 @@
1
1
  export { ConvertingMediaRecorder as MediaRecorder } from './mediarecorder';
2
- export { convert } from './converter';
2
+ export { convert, load } from './converter';
@@ -7,7 +7,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
7
7
  step((generator = generator.apply(thisArg, _arguments || [])).next());
8
8
  });
9
9
  };
10
- import { convert, getWorker } from "./converter";
10
+ import { convert } from "./converter";
11
11
  export class ConvertingMediaRecorder extends MediaRecorder {
12
12
  static isTypeSupported(type) {
13
13
  if (type === 'video/mp4') {
@@ -105,7 +105,3 @@ export class ConvertingMediaRecorder extends MediaRecorder {
105
105
  return super.ondataavailable;
106
106
  }
107
107
  }
108
- // Preload worker if it's likely to be necessary
109
- if (!MediaRecorder.isTypeSupported('video/mp4') && MediaRecorder.isTypeSupported('video/webm;codecs="avc1,opus"')) {
110
- getWorker();
111
- }
Binary file
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@zappar/mediarecorder",
3
- "version": "0.0.1",
3
+ "version": "0.1.0",
4
4
  "description": "A MediaRecorder polyfill that supports video/mp4 output on both iOS and Android",
5
5
  "main": "./lib/index.js",
6
6
  "types": "./lib/index.d.ts",