Skip to content

Commit

Permalink
fix(types): fix canvas types after merging
Browse files Browse the repository at this point in the history
  • Loading branch information
setsun committed Apr 20, 2019
1 parent eba50d5 commit b714712
Show file tree
Hide file tree
Showing 4 changed files with 93 additions and 54 deletions.
18 changes: 9 additions & 9 deletions .size-snapshot.json
Original file line number Diff line number Diff line change
@@ -1,21 +1,21 @@
{
"dist/index.js": {
"bundled": 25161,
"minified": 11960,
"gzipped": 4353,
"bundled": 25732,
"minified": 12281,
"gzipped": 4371,
"treeshaked": {
"rollup": {
"code": 9733,
"import_statements": 602
"code": 10072,
"import_statements": 615
},
"webpack": {
"code": 11292
"code": 11615
}
}
},
"dist/index.cjs.js": {
"bundled": 28174,
"minified": 13680,
"gzipped": 4567
"bundled": 28782,
"minified": 13991,
"gzipped": 4583
}
}
82 changes: 78 additions & 4 deletions src/canvas.tsx
Original file line number Diff line number Diff line change
@@ -1,18 +1,92 @@
import * as THREE from 'three'
import React, { useRef, useEffect, useMemo, useState, useCallback, useContext } from 'react'
import * as React from 'react'
import { useRef, useEffect, useMemo, useState, useCallback } from 'react'
import ResizeObserver from 'resize-observer-polyfill'
import { invalidate, applyProps, render, unmountComponentAtNode } from './reconciler'

export const stateContext = React.createContext()
export type CanvasContext = {
canvas?: React.MutableRefObject<any>,
subscribers: Array<Function>,
frames: 0,
aspect: 0,
gl?: THREE.WebGLRenderer,
camera?: THREE.Camera,
scene?: THREE.Scene,
canvasRect?: DOMRectReadOnly,
viewport?: { width: number, height: number },
size?: { left: number, top: number, width: number, height: number },
ready: boolean,
manual: boolean,
active: boolean,
captured: boolean,
invalidateFrameloop: boolean,
subscribe?: (callback: Function, main: any) => () => any,
setManual: (takeOverRenderloop: boolean) => any,
setDefaultCamera: (camera: THREE.Camera) => any,
invalidate: () => any,
}

export type CanvasProps = {
children: React.ReactNode;
gl: THREE.WebGLRenderer;
orthographic: THREE.OrthographicCamera | THREE.PerspectiveCamera;
raycaster: THREE.Raycaster;
camera?: THREE.Camera;
style?: React.CSSProperties;
pixelRatio?: number;
invalidateFrameloop?: boolean;
onCreated: Function;
}

export type Measure = [
{ ref: React.MutableRefObject<any> },
{ left: number, top: number, width: number, height: number }
]

export type IntersectObject = Event & THREE.Intersection & {
ray: THREE.Raycaster;
stopped: { current: boolean };
uuid: string;
transform: {
x: Function,
y: Function
};
}

function useMeasure() {
const defaultRef = {
ready: false,
subscribers: [],
manual: false,
active: true,
canvas: undefined,
gl: undefined,
camera: undefined,
scene: undefined,
size: undefined,
canvasRect: undefined,
frames: 0,
aspect: 0,
viewport: undefined,
captured: undefined,
invalidateFrameloop: false,
subscribe: (fn, main) => () => {},
setManual: (takeOverRenderloop) => {},
setDefaultCamera: (cam) => {},
invalidate: () => {}
}

export const stateContext = React.createContext(defaultRef)

function useMeasure(): Measure {
const ref = useRef()

const [bounds, set] = useState({ left: 0, top: 0, width: 0, height: 0 })
const [ro] = useState(() => new ResizeObserver(([entry]) => set(entry.contentRect)))
useEffect(() => {
if (ref.current) ro.observe(ref.current)
return () => ro.disconnect()
}, [ref.current])

return [{ ref }, bounds]
}

Expand All @@ -28,7 +102,7 @@ export const Canvas = React.memo(
invalidateFrameloop = false,
onCreated,
...rest
}) => {
}: CanvasProps) => {
// Local, reactive state
const canvas = useRef()
const [ready, setReady] = useState(false)
Expand Down
28 changes: 5 additions & 23 deletions types/canvas.d.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import * as THREE from 'three';
import * as React from 'react';
import React from 'react';
export declare type CanvasContext = {
canvas?: React.MutableRefObject<any>;
subscribers: Array<Function>;
Expand Down Expand Up @@ -32,6 +32,8 @@ export declare type CanvasContext = {
export declare type CanvasProps = {
children: React.ReactNode;
gl: THREE.WebGLRenderer;
orthographic: THREE.OrthographicCamera | THREE.PerspectiveCamera;
raycaster: THREE.Raycaster;
camera?: THREE.Camera;
style?: React.CSSProperties;
pixelRatio?: number;
Expand All @@ -57,25 +59,5 @@ export declare type IntersectObject = Event & THREE.Intersection & {
y: Function;
};
};
export declare const stateContext: React.Context<{
ready: boolean;
subscribers: any[];
manual: boolean;
active: boolean;
canvas: any;
gl: any;
camera: any;
scene: any;
size: any;
canvasRect: any;
frames: number;
aspect: number;
viewport: any;
captured: any;
invalidateFrameloop: boolean;
subscribe: (fn: any, main: any) => () => void;
setManual: (takeOverRenderloop: any) => void;
setDefaultCamera: (cam: any) => void;
invalidate: () => void;
}>;
export declare const Canvas: React.MemoExoticComponent<({ children, gl, camera, style, pixelRatio, invalidateFrameloop, onCreated, ...rest }: CanvasProps) => JSX.Element>;
export declare const stateContext: any;
export declare const Canvas: any;
19 changes: 1 addition & 18 deletions types/hooks.d.ts
Original file line number Diff line number Diff line change
@@ -1,24 +1,7 @@
/// <reference types="react" />
export declare function useRender(fn: Function, takeOverRenderloop: boolean): any;
export declare function useThree(): {
ready: boolean;
subscribers: any[];
manual: boolean;
active: boolean;
canvas: any;
gl: any;
camera: any;
scene: any;
size: any;
canvasRect: any;
frames: number;
aspect: number;
viewport: any;
captured: any;
invalidateFrameloop: boolean;
setManual: (takeOverRenderloop: any) => void;
setDefaultCamera: (cam: any) => void;
invalidate: () => void;
[x: string]: any;
};
export declare function useUpdate(callback: Function, dependents: [], optionalRef: React.MutableRefObject<any>): React.MutableRefObject<any>;
export declare function useResource(optionalRef: React.MutableRefObject<any>): React.MutableRefObject<any>;

0 comments on commit b714712

Please sign in to comment.