@shopify/react-native-skia
Version:
High-performance React Native Graphics using Skia
61 lines (60 loc) • 1.71 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.Mock = void 0;
var _web = require("../skia/web");
// eslint-disable-next-line @typescript-eslint/no-explicit-any
const Noop = () => undefined;
const NoopValue = () => ({
current: 0
});
const NoopSharedValue = () => ({
value: 0
});
const Mock = CanvasKit => {
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
global.SkiaApi = (0, _web.JsiSkApi)(CanvasKit);
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
const Skia = global.SkiaApi;
return {
Skia,
...require("../renderer/components"),
...require("../skia"),
...require("../animation"),
...require("../dom/types"),
...require("../dom/nodes"),
Canvas: require("react-native").View,
// Skia Animations
useValue: NoopValue,
useComputedValue: NoopValue,
useTiming: NoopValue,
useLoop: NoopValue,
useSpring: NoopValue,
useClockValue: NoopValue,
useValueEffect: Noop,
// Reanimated hooks
useClock: NoopSharedValue,
usePathInterpolation: NoopSharedValue,
useImageAsTexture: NoopSharedValue,
useTextureValue: NoopSharedValue,
useTextureValueFromPicture: NoopSharedValue,
useRSXformBuffer: NoopSharedValue,
usePointBuffer: NoopSharedValue,
useColorBuffer: NoopSharedValue,
useRectBuffer: NoopSharedValue,
useBuffer: NoopSharedValue,
useRawData: Noop,
useData: Noop,
useFont: () => Skia.Font(undefined, 0),
useFonts: Noop,
useTypeface: () => null,
useImage: () => null,
useSVG: () => null,
useVideo: () => null
};
};
exports.Mock = Mock;
//# sourceMappingURL=index.js.map
;