Skip to content

Commit

Permalink
[ts-sdk] Add ESM + CJS support for live-compositor and `@live-compo…
Browse files Browse the repository at this point in the history
…sitor/core` (#802)
  • Loading branch information
wkozyra95 authored Oct 3, 2024
1 parent 03f766d commit 5c765d9
Show file tree
Hide file tree
Showing 43 changed files with 310 additions and 102 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/ts_sdk_check.yml
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ jobs:

- name: Build
working-directory: ./ts
run: npm run build
run: npm run build:all

- name: Lint code
working-directory: ./ts
Expand Down
12 changes: 12 additions & 0 deletions ts/.eslintrc.base.json
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
"prettier"
],
"plugins": [
"import",
"prettier"
],
"parser": "@typescript-eslint/parser",
Expand All @@ -16,6 +17,17 @@
"tsconfig.json"
]
},
"settings": {
"import/parsers": {
"@typescript-eslint/parser": [".ts", ".tsx"]
},
"import/resolver": {
"typescript": {
"alwaysTryTypes": true,
"project": "**/tsconfig.json"
}
}
},
"rules": {
"prettier/prettier": ["error"],
"@typescript-eslint/no-explicit-any": [0, {}],
Expand Down
9 changes: 0 additions & 9 deletions ts/@live-compositor/browser-render/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -23,14 +23,5 @@
},
"peerDependencies": {
"live-compositor": "^0.1.0"
},
"nx": {
"targets": {
"build": {
"dependsOn": [
"build-wasm"
]
}
}
}
}
3 changes: 2 additions & 1 deletion ts/@live-compositor/core/.eslintignore
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
dist
esm
cjs
3 changes: 3 additions & 0 deletions ts/@live-compositor/core/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
node_modules
cjs
esm
21 changes: 16 additions & 5 deletions ts/@live-compositor/core/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,19 +2,30 @@
"name": "@live-compositor/core",
"version": "0.1.0",
"description": "",
"main": "dist/index.js",
"type": "module",
"main": "cjs/index.js",
"exports": {
"import": "./esm/index.js",
"require": "./cjs/index.js",
"types": "./esm/index.d.ts"
},
"scripts": {
"lint": "eslint .",
"typecheck": "tsc --noEmit",
"watch": "tsc --watch --preserveWatchOutput",
"build": "tsc",
"clean": "rimraf dist",
"watch": "concurrently \"npm run watch:esm\" \"npm run watch:cjs\"",
"watch:esm": "tsc --watch --preserveWatchOutput",
"watch:cjs": "tsc --watch --preserveWatchOutput -p ./tsconfig.cjs.json",
"build": "npm run build:esm && npm run build:cjs",
"build:esm": "tsc && echo '{\"type\": \"module\"}' > esm/package.json",
"build:cjs": "tsc -p ./tsconfig.cjs.json && echo '{\"type\": \"commonjs\"}' > cjs/package.json",
"clean": "rimraf esm cjs",
"prepublishOnly": "npm run clean && npm run build"
},
"author": "",
"license": "MIT",
"files": [
"/dist"
"/esm",
"/cjs"
],
"devDependencies": {
"@types/react-reconciler": "0.28.8"
Expand Down
2 changes: 1 addition & 1 deletion ts/@live-compositor/core/src/api.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { Api } from 'live-compositor';
import { CompositorManager } from './compositorManager';
import { CompositorManager } from './compositorManager.js';

export { Api };

Expand Down
2 changes: 1 addition & 1 deletion ts/@live-compositor/core/src/api/input.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Api } from '../api';
import { Api } from '../api.js';
import { RegisterInput, Inputs } from 'live-compositor';

export function intoRegisterInput(input: RegisterInput): Api.RegisterInput {
Expand Down
2 changes: 1 addition & 1 deletion ts/@live-compositor/core/src/api/renderer.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Api } from '../api';
import { Api } from '../api.js';
import { Renderers } from 'live-compositor';

export function intoRegisterImage(image: Renderers.RegisterImage): Api.ImageSpec {
Expand Down
14 changes: 7 additions & 7 deletions ts/@live-compositor/core/src/compositor.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,13 @@ import {
RegisterOutput,
Renderers,
} from 'live-compositor';
import { ApiClient } from './api';
import Output from './output';
import { CompositorManager } from './compositorManager';
import { intoRegisterOutput } from './api/output';
import { intoRegisterInput } from './api/input';
import { onCompositorEvent } from './event';
import { intoRegisterImage, intoRegisterWebRenderer } from './api/renderer';
import { ApiClient } from './api.js';
import Output from './output.js';
import { CompositorManager } from './compositorManager.js';
import { intoRegisterOutput } from './api/output.js';
import { intoRegisterInput } from './api/input.js';
import { onCompositorEvent } from './event.js';
import { intoRegisterImage, intoRegisterWebRenderer } from './api/renderer.js';

export class LiveCompositor {
private manager: CompositorManager;
Expand Down
2 changes: 1 addition & 1 deletion ts/@live-compositor/core/src/compositorManager.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { ApiRequest } from './api';
import { ApiRequest } from './api.js';

export interface CompositorManager {
setupInstance(): Promise<void>;
Expand Down
6 changes: 3 additions & 3 deletions ts/@live-compositor/core/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
export { ApiClient, ApiRequest } from './api';
export { LiveCompositor } from './compositor';
export { CompositorManager } from './compositorManager';
export { ApiClient, ApiRequest } from './api.js';
export { LiveCompositor } from './compositor.js';
export { CompositorManager } from './compositorManager.js';
8 changes: 4 additions & 4 deletions ts/@live-compositor/core/src/output.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
import { _liveCompositorInternals, RegisterOutput, View, Outputs } from 'live-compositor';
import React, { useSyncExternalStore } from 'react';
import { ApiClient, Api } from './api';
import Renderer from './renderer';
import { intoAudioInputsConfiguration } from './api/output';
import { throttle } from './utils';
import { ApiClient, Api } from './api.js';
import Renderer from './renderer.js';
import { intoAudioInputsConfiguration } from './api/output.js';
import { throttle } from './utils.js';

type OutputContext = _liveCompositorInternals.OutputContext;
type InstanceContextStore = _liveCompositorInternals.InstanceContextStore;
Expand Down
4 changes: 2 additions & 2 deletions ts/@live-compositor/core/src/renderer.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import Reconciler from 'react-reconciler';
import { DefaultEventPriority, LegacyRoot } from 'react-reconciler/constants';
import { Api } from './api';
import { DefaultEventPriority, LegacyRoot } from 'react-reconciler/constants.js';
import { Api } from './api.js';
import { _liveCompositorInternals } from 'live-compositor';
import React from 'react';

Expand Down
9 changes: 9 additions & 0 deletions ts/@live-compositor/core/tsconfig.cjs.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
{
"extends": "./tsconfig.json",
"compilerOptions": {
"outDir": "cjs",
"module": "commonjs",
"moduleResolution": "node",
"esModuleInterop": true
}
}
2 changes: 1 addition & 1 deletion ts/@live-compositor/core/tsconfig.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"extends": "../../tsconfig.base.json",
"compilerOptions": {
"outDir": "dist"
"outDir": "esm"
}
}
3 changes: 2 additions & 1 deletion ts/live-compositor/.eslintignore
Original file line number Diff line number Diff line change
@@ -1 +1,2 @@
dist
esm
cjs
3 changes: 2 additions & 1 deletion ts/live-compositor/.gitignore
Original file line number Diff line number Diff line change
@@ -1,2 +1,3 @@
node_modules
dist
esm
cjs
21 changes: 16 additions & 5 deletions ts/live-compositor/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,23 @@
"name": "live-compositor",
"version": "0.1.0",
"description": "",
"main": "dist/index.js",
"type": "module",
"main": "cjs/index.js",
"exports": {
"import": "./esm/index.js",
"require": "./cjs/index.js",
"types": "./esm/index.d.ts"
},
"scripts": {
"lint": "eslint .",
"typecheck": "tsc --noEmit",
"watch": "tsc --watch --preserveWatchOutput",
"build": "tsc",
"clean": "rimraf dist",
"watch": "concurrently \"npm run watch:esm\" \"npm run watch:cjs\"",
"watch:esm": "tsc --watch --preserveWatchOutput",
"watch:cjs": "tsc --watch --preserveWatchOutput -p ./tsconfig.cjs.json",
"build": "npm run build:esm && npm run build:cjs",
"build:esm": "tsc && echo '{\"type\": \"module\"}' > esm/package.json",
"build:cjs": "tsc -p ./tsconfig.cjs.json && echo '{\"type\": \"commonjs\"}' > cjs/package.json",
"clean": "rimraf esm cjs",
"prepublishOnly": "npm run clean && npm run build"
},
"author": "",
Expand All @@ -18,7 +28,8 @@
},
"homepage": "https://github.com/software-mansion/live-compositor",
"files": [
"/dist"
"/esm",
"/cjs"
],
"devDependencies": {
"@types/react": "^18.3.3"
Expand Down
2 changes: 1 addition & 1 deletion ts/live-compositor/src/api.ts
Original file line number Diff line number Diff line change
@@ -1 +1 @@
export * from './api.generated';
export * from './api.generated.js';
2 changes: 1 addition & 1 deletion ts/live-compositor/src/component.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import React, { useId } from 'react';
import * as Api from './api';
import * as Api from './api.js';

type ComponentProps<P> = { children?: React.ReactNode; id?: Api.ComponentId } & P;

Expand Down
4 changes: 2 additions & 2 deletions ts/live-compositor/src/components/Image.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import * as Api from '../api';
import { createCompositorComponent, SceneComponent } from '../component';
import * as Api from '../api.js';
import { createCompositorComponent, SceneComponent } from '../component.js';

export type ImageProps = {
children?: undefined;
Expand Down
10 changes: 5 additions & 5 deletions ts/live-compositor/src/components/InputStream.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import React from 'react';
import * as Api from '../api';
import { createCompositorComponent, SceneComponent } from '../component';
import { useAudioInput } from '../hooks';
import { createElement } from 'react';
import * as Api from '../api.js';
import { createCompositorComponent, SceneComponent } from '../component.js';
import { useAudioInput } from '../hooks.js';

export type InputStreamProps = {
children?: undefined;
Expand Down Expand Up @@ -34,7 +34,7 @@ function InputStream(props: InputStreamProps) {
useAudioInput(props.inputId, {
volume: mute ? 0 : (volume ?? 1),
});
return React.createElement(InnerInputStream, otherProps);
return createElement(InnerInputStream, otherProps);
}

function sceneBuilder(props: InputStreamProps, _children: SceneComponent[]): Api.Component {
Expand Down
6 changes: 3 additions & 3 deletions ts/live-compositor/src/components/Rescaler.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import React from 'react';
import * as Api from '../api';
import { intoApiTransition, Transition } from './common';
import { createCompositorComponent, SceneComponent, sceneComponentIntoApi } from '../component';
import * as Api from '../api.js';
import { intoApiTransition, Transition } from './common.js';
import { createCompositorComponent, SceneComponent, sceneComponentIntoApi } from '../component.js';

export type RescalerProps = {
children: React.ReactElement | string | number;
Expand Down
4 changes: 2 additions & 2 deletions ts/live-compositor/src/components/Shader.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import * as Api from '../api';
import { createCompositorComponent, SceneComponent, sceneComponentIntoApi } from '../component';
import * as Api from '../api.js';
import { createCompositorComponent, SceneComponent, sceneComponentIntoApi } from '../component.js';

export type ShaderProps = {
/**
Expand Down
6 changes: 3 additions & 3 deletions ts/live-compositor/src/components/Text.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import * as Api from '../api';
import { createCompositorComponent, SceneComponent } from '../component';
import { intoApiRgbaColor } from './common';
import * as Api from '../api.js';
import { createCompositorComponent, SceneComponent } from '../component.js';
import { intoApiRgbaColor } from './common.js';

export type TextProps = {
children?: (string | number)[] | string | number;
Expand Down
6 changes: 3 additions & 3 deletions ts/live-compositor/src/components/Tiles.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import * as Api from '../api';
import { intoApiRgbaColor, intoApiTransition, Transition } from './common';
import { createCompositorComponent, SceneComponent, sceneComponentIntoApi } from '../component';
import * as Api from '../api.js';
import { intoApiRgbaColor, intoApiTransition, Transition } from './common.js';
import { createCompositorComponent, SceneComponent, sceneComponentIntoApi } from '../component.js';

export type TilesProps = {
/**
Expand Down
6 changes: 3 additions & 3 deletions ts/live-compositor/src/components/View.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import * as Api from '../api';
import { createCompositorComponent, SceneComponent, sceneComponentIntoApi } from '../component';
import { intoApiRgbaColor, intoApiTransition, Transition } from './common';
import * as Api from '../api.js';
import { createCompositorComponent, SceneComponent, sceneComponentIntoApi } from '../component.js';
import { intoApiRgbaColor, intoApiTransition, Transition } from './common.js';

export type ViewProps = {
/**
Expand Down
4 changes: 2 additions & 2 deletions ts/live-compositor/src/components/WebView.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import * as Api from '../api';
import { createCompositorComponent, SceneComponent, sceneComponentIntoApi } from '../component';
import * as Api from '../api.js';
import { createCompositorComponent, SceneComponent, sceneComponentIntoApi } from '../component.js';

export type WebViewProps = {
/**
Expand Down
2 changes: 1 addition & 1 deletion ts/live-compositor/src/components/common.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import * as Api from '../api';
import * as Api from '../api.js';

export interface Transition {
/**
Expand Down
4 changes: 2 additions & 2 deletions ts/live-compositor/src/context/index.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { createContext } from 'react';
import { InstanceContextStore } from './instanceContextStore';
import { OutputContext } from './outputContext';
import { InstanceContextStore } from './instanceContextStore.js';
import { OutputContext } from './outputContext.js';

type CompositorOutputContext = {
// global store for the entire LiveCompositor instance
Expand Down
2 changes: 1 addition & 1 deletion ts/live-compositor/src/context/instanceContextStore.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import * as Api from '../api';
import * as Api from '../api.js';

export type StreamState = 'ready' | 'playing' | 'finished';

Expand Down
2 changes: 1 addition & 1 deletion ts/live-compositor/src/context/outputContext.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { AudioInputsConfiguration } from '../types/registerOutput';
import { AudioInputsConfiguration } from '../types/registerOutput.js';

export type ContextAudioOptions = {
volume: number;
Expand Down
6 changes: 3 additions & 3 deletions ts/live-compositor/src/hooks.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
import { useContext, useEffect, useSyncExternalStore } from 'react';

import * as Api from './api';
import { LiveCompositorContext } from './context';
import { InputStreamInfo } from './context/instanceContextStore';
import * as Api from './api.js';
import { LiveCompositorContext } from './context/index.js';
import { InputStreamInfo } from './context/instanceContextStore.js';

export function useInputStreams(): Record<Api.InputId, InputStreamInfo> {
const ctx = useContext(LiveCompositorContext);
Expand Down
Loading

0 comments on commit 5c765d9

Please sign in to comment.