v1.0 with SW PWA enabled
This commit is contained in:
5
frontend/node_modules/use-sidecar/dist/es2015/config.d.ts
generated
vendored
Normal file
5
frontend/node_modules/use-sidecar/dist/es2015/config.d.ts
generated
vendored
Normal file
@ -0,0 +1,5 @@
|
||||
export interface IConfig {
|
||||
onError(e: Error): void;
|
||||
}
|
||||
export declare const config: IConfig;
|
||||
export declare const setConfig: (conf: Partial<IConfig>) => void;
|
||||
6
frontend/node_modules/use-sidecar/dist/es2015/config.js
generated
vendored
Normal file
6
frontend/node_modules/use-sidecar/dist/es2015/config.js
generated
vendored
Normal file
@ -0,0 +1,6 @@
|
||||
export var config = {
|
||||
onError: function (e) { return console.error(e); },
|
||||
};
|
||||
export var setConfig = function (conf) {
|
||||
Object.assign(config, conf);
|
||||
};
|
||||
4
frontend/node_modules/use-sidecar/dist/es2015/env.d.ts
generated
vendored
Normal file
4
frontend/node_modules/use-sidecar/dist/es2015/env.d.ts
generated
vendored
Normal file
@ -0,0 +1,4 @@
|
||||
export declare const env: {
|
||||
isNode: boolean;
|
||||
forceCache: boolean;
|
||||
};
|
||||
5
frontend/node_modules/use-sidecar/dist/es2015/env.js
generated
vendored
Normal file
5
frontend/node_modules/use-sidecar/dist/es2015/env.js
generated
vendored
Normal file
@ -0,0 +1,5 @@
|
||||
import { isNode } from 'detect-node-es';
|
||||
export var env = {
|
||||
isNode: isNode,
|
||||
forceCache: false,
|
||||
};
|
||||
3
frontend/node_modules/use-sidecar/dist/es2015/exports.d.ts
generated
vendored
Normal file
3
frontend/node_modules/use-sidecar/dist/es2015/exports.d.ts
generated
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
import * as React from 'react';
|
||||
import { SideCarComponent, SideCarMedium } from './types';
|
||||
export declare function exportSidecar<T>(medium: SideCarMedium<T>, exported: React.ComponentType<T>): SideCarComponent<T>;
|
||||
18
frontend/node_modules/use-sidecar/dist/es2015/exports.js
generated
vendored
Normal file
18
frontend/node_modules/use-sidecar/dist/es2015/exports.js
generated
vendored
Normal file
@ -0,0 +1,18 @@
|
||||
import { __assign, __rest } from "tslib";
|
||||
import * as React from 'react';
|
||||
var SideCar = function (_a) {
|
||||
var sideCar = _a.sideCar, rest = __rest(_a, ["sideCar"]);
|
||||
if (!sideCar) {
|
||||
throw new Error('Sidecar: please provide `sideCar` property to import the right car');
|
||||
}
|
||||
var Target = sideCar.read();
|
||||
if (!Target) {
|
||||
throw new Error('Sidecar medium not found');
|
||||
}
|
||||
return React.createElement(Target, __assign({}, rest));
|
||||
};
|
||||
SideCar.isSideCarExport = true;
|
||||
export function exportSidecar(medium, exported) {
|
||||
medium.useMedium(exported);
|
||||
return SideCar;
|
||||
}
|
||||
3
frontend/node_modules/use-sidecar/dist/es2015/hoc.d.ts
generated
vendored
Normal file
3
frontend/node_modules/use-sidecar/dist/es2015/hoc.d.ts
generated
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
import * as React from 'react';
|
||||
import { Importer, SideCarHOC } from './types';
|
||||
export declare function sidecar<T>(importer: Importer<T>, errorComponent?: React.ReactNode): React.FunctionComponent<Omit<T, 'sideCar'> & SideCarHOC<Omit<T, 'sideCar'>>>;
|
||||
15
frontend/node_modules/use-sidecar/dist/es2015/hoc.js
generated
vendored
Normal file
15
frontend/node_modules/use-sidecar/dist/es2015/hoc.js
generated
vendored
Normal file
@ -0,0 +1,15 @@
|
||||
import { __assign } from "tslib";
|
||||
import * as React from 'react';
|
||||
import { useSidecar } from './hook';
|
||||
// eslint-disable-next-line @typescript-eslint/ban-types
|
||||
export function sidecar(importer, errorComponent) {
|
||||
var ErrorCase = function () { return errorComponent; };
|
||||
return function Sidecar(props) {
|
||||
var _a = useSidecar(importer, props.sideCar), Car = _a[0], error = _a[1];
|
||||
if (error && errorComponent) {
|
||||
return ErrorCase;
|
||||
}
|
||||
// @ts-expect-error type shenanigans
|
||||
return Car ? React.createElement(Car, __assign({}, props)) : null;
|
||||
};
|
||||
}
|
||||
2
frontend/node_modules/use-sidecar/dist/es2015/hook.d.ts
generated
vendored
Normal file
2
frontend/node_modules/use-sidecar/dist/es2015/hook.d.ts
generated
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
import { Importer, SideMedium } from './types';
|
||||
export declare function useSidecar<T>(importer: Importer<T>, effect?: SideMedium<any>): [React.ComponentType<T> | null, Error | null];
|
||||
41
frontend/node_modules/use-sidecar/dist/es2015/hook.js
generated
vendored
Normal file
41
frontend/node_modules/use-sidecar/dist/es2015/hook.js
generated
vendored
Normal file
@ -0,0 +1,41 @@
|
||||
import { useState, useEffect } from 'react';
|
||||
import { env } from './env';
|
||||
var cache = new WeakMap();
|
||||
var NO_OPTIONS = {};
|
||||
export function useSidecar(importer, effect) {
|
||||
var options = (effect && effect.options) || NO_OPTIONS;
|
||||
if (env.isNode && !options.ssr) {
|
||||
return [null, null];
|
||||
}
|
||||
// eslint-disable-next-line react-hooks/rules-of-hooks
|
||||
return useRealSidecar(importer, effect);
|
||||
}
|
||||
function useRealSidecar(importer, effect) {
|
||||
var options = (effect && effect.options) || NO_OPTIONS;
|
||||
var couldUseCache = env.forceCache || (env.isNode && !!options.ssr) || !options.async;
|
||||
var _a = useState(couldUseCache ? function () { return cache.get(importer); } : undefined), Car = _a[0], setCar = _a[1];
|
||||
var _b = useState(null), error = _b[0], setError = _b[1];
|
||||
useEffect(function () {
|
||||
if (!Car) {
|
||||
importer().then(function (car) {
|
||||
var resolved = effect ? effect.read() : car.default || car;
|
||||
if (!resolved) {
|
||||
console.error('Sidecar error: with importer', importer);
|
||||
var error_1;
|
||||
if (effect) {
|
||||
console.error('Sidecar error: with medium', effect);
|
||||
error_1 = new Error('Sidecar medium was not found');
|
||||
}
|
||||
else {
|
||||
error_1 = new Error('Sidecar was not found in exports');
|
||||
}
|
||||
setError(function () { return error_1; });
|
||||
throw error_1;
|
||||
}
|
||||
cache.set(importer, resolved);
|
||||
setCar(function () { return resolved; });
|
||||
}, function (e) { return setError(function () { return e; }); });
|
||||
}
|
||||
}, []);
|
||||
return [Car, error];
|
||||
}
|
||||
7
frontend/node_modules/use-sidecar/dist/es2015/index.d.ts
generated
vendored
Normal file
7
frontend/node_modules/use-sidecar/dist/es2015/index.d.ts
generated
vendored
Normal file
@ -0,0 +1,7 @@
|
||||
export { sidecar } from './hoc';
|
||||
export { useSidecar } from './hook';
|
||||
export { setConfig } from './config';
|
||||
export { createMedium, createSidecarMedium } from './medium';
|
||||
export { renderCar } from './renderProp';
|
||||
export { exportSidecar } from './exports';
|
||||
export type { SideCarComponent } from './types';
|
||||
6
frontend/node_modules/use-sidecar/dist/es2015/index.js
generated
vendored
Normal file
6
frontend/node_modules/use-sidecar/dist/es2015/index.js
generated
vendored
Normal file
@ -0,0 +1,6 @@
|
||||
export { sidecar } from './hoc';
|
||||
export { useSidecar } from './hook';
|
||||
export { setConfig } from './config';
|
||||
export { createMedium, createSidecarMedium } from './medium';
|
||||
export { renderCar } from './renderProp';
|
||||
export { exportSidecar } from './exports';
|
||||
3
frontend/node_modules/use-sidecar/dist/es2015/medium.d.ts
generated
vendored
Normal file
3
frontend/node_modules/use-sidecar/dist/es2015/medium.d.ts
generated
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
import { MiddlewareCallback, SideCarMedium, SideCarMediumOptions, SideMedium } from './types';
|
||||
export declare function createMedium<T>(defaults?: T, middleware?: MiddlewareCallback<T>): Readonly<SideMedium<T>>;
|
||||
export declare function createSidecarMedium<T = {}>(options?: SideCarMediumOptions): Readonly<SideCarMedium<T>>;
|
||||
78
frontend/node_modules/use-sidecar/dist/es2015/medium.js
generated
vendored
Normal file
78
frontend/node_modules/use-sidecar/dist/es2015/medium.js
generated
vendored
Normal file
@ -0,0 +1,78 @@
|
||||
import { __assign } from "tslib";
|
||||
function ItoI(a) {
|
||||
return a;
|
||||
}
|
||||
function innerCreateMedium(defaults, middleware) {
|
||||
if (middleware === void 0) { middleware = ItoI; }
|
||||
var buffer = [];
|
||||
var assigned = false;
|
||||
var medium = {
|
||||
read: function () {
|
||||
if (assigned) {
|
||||
throw new Error('Sidecar: could not `read` from an `assigned` medium. `read` could be used only with `useMedium`.');
|
||||
}
|
||||
if (buffer.length) {
|
||||
return buffer[buffer.length - 1];
|
||||
}
|
||||
return defaults;
|
||||
},
|
||||
useMedium: function (data) {
|
||||
var item = middleware(data, assigned);
|
||||
buffer.push(item);
|
||||
return function () {
|
||||
buffer = buffer.filter(function (x) { return x !== item; });
|
||||
};
|
||||
},
|
||||
assignSyncMedium: function (cb) {
|
||||
assigned = true;
|
||||
while (buffer.length) {
|
||||
var cbs = buffer;
|
||||
buffer = [];
|
||||
cbs.forEach(cb);
|
||||
}
|
||||
buffer = {
|
||||
push: function (x) { return cb(x); },
|
||||
filter: function () { return buffer; },
|
||||
};
|
||||
},
|
||||
assignMedium: function (cb) {
|
||||
assigned = true;
|
||||
var pendingQueue = [];
|
||||
if (buffer.length) {
|
||||
var cbs = buffer;
|
||||
buffer = [];
|
||||
cbs.forEach(cb);
|
||||
pendingQueue = buffer;
|
||||
}
|
||||
var executeQueue = function () {
|
||||
var cbs = pendingQueue;
|
||||
pendingQueue = [];
|
||||
cbs.forEach(cb);
|
||||
};
|
||||
var cycle = function () { return Promise.resolve().then(executeQueue); };
|
||||
cycle();
|
||||
buffer = {
|
||||
push: function (x) {
|
||||
pendingQueue.push(x);
|
||||
cycle();
|
||||
},
|
||||
filter: function (filter) {
|
||||
pendingQueue = pendingQueue.filter(filter);
|
||||
return buffer;
|
||||
},
|
||||
};
|
||||
},
|
||||
};
|
||||
return medium;
|
||||
}
|
||||
export function createMedium(defaults, middleware) {
|
||||
if (middleware === void 0) { middleware = ItoI; }
|
||||
return innerCreateMedium(defaults, middleware);
|
||||
}
|
||||
// eslint-disable-next-line @typescript-eslint/ban-types
|
||||
export function createSidecarMedium(options) {
|
||||
if (options === void 0) { options = {}; }
|
||||
var medium = innerCreateMedium(null);
|
||||
medium.options = __assign({ async: true, ssr: false }, options);
|
||||
return medium;
|
||||
}
|
||||
9
frontend/node_modules/use-sidecar/dist/es2015/renderProp.d.ts
generated
vendored
Normal file
9
frontend/node_modules/use-sidecar/dist/es2015/renderProp.d.ts
generated
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
import * as React from 'react';
|
||||
import { FC } from 'react';
|
||||
import { SideCarHOC } from './types';
|
||||
declare type CombinedProps<T extends any[], K> = {
|
||||
children: (...prop: T) => any;
|
||||
} & K;
|
||||
declare type RenderPropComponent<T extends any[], K> = React.ComponentType<CombinedProps<T, K>>;
|
||||
export declare function renderCar<T extends any[], K, C = RenderPropComponent<T, K & Partial<SideCarHOC>>>(WrappedComponent: C, defaults: (props: K) => T): FC<CombinedProps<T, K>>;
|
||||
export {};
|
||||
35
frontend/node_modules/use-sidecar/dist/es2015/renderProp.js
generated
vendored
Normal file
35
frontend/node_modules/use-sidecar/dist/es2015/renderProp.js
generated
vendored
Normal file
@ -0,0 +1,35 @@
|
||||
import { __assign } from "tslib";
|
||||
import * as React from 'react';
|
||||
import { useState, useCallback, useEffect, useLayoutEffect } from 'react';
|
||||
export function renderCar(WrappedComponent, defaults) {
|
||||
function State(_a) {
|
||||
var stateRef = _a.stateRef, props = _a.props;
|
||||
var renderTarget = useCallback(function SideTarget() {
|
||||
var args = [];
|
||||
for (var _i = 0; _i < arguments.length; _i++) {
|
||||
args[_i] = arguments[_i];
|
||||
}
|
||||
useLayoutEffect(function () {
|
||||
stateRef.current(args);
|
||||
});
|
||||
return null;
|
||||
}, []);
|
||||
// @ts-ignore
|
||||
return React.createElement(WrappedComponent, __assign({}, props, { children: renderTarget }));
|
||||
}
|
||||
var Children = React.memo(function (_a) {
|
||||
var stateRef = _a.stateRef, defaultState = _a.defaultState, children = _a.children;
|
||||
var _b = useState(defaultState.current), state = _b[0], setState = _b[1];
|
||||
useEffect(function () {
|
||||
stateRef.current = setState;
|
||||
}, []);
|
||||
return children.apply(void 0, state);
|
||||
}, function () { return true; });
|
||||
return function Combiner(props) {
|
||||
var defaultState = React.useRef(defaults(props));
|
||||
var ref = React.useRef(function (state) { return (defaultState.current = state); });
|
||||
return (React.createElement(React.Fragment, null,
|
||||
React.createElement(State, { stateRef: ref, props: props }),
|
||||
React.createElement(Children, { stateRef: ref, defaultState: defaultState, children: props.children })));
|
||||
};
|
||||
}
|
||||
47
frontend/node_modules/use-sidecar/dist/es2015/types.d.ts
generated
vendored
Normal file
47
frontend/node_modules/use-sidecar/dist/es2015/types.d.ts
generated
vendored
Normal file
@ -0,0 +1,47 @@
|
||||
import * as React from 'react';
|
||||
export declare type removeCb = () => void;
|
||||
export declare type MediumCallback<T> = (data: T) => any;
|
||||
export declare type MiddlewareCallback<T> = (data: T, assigned: boolean) => T;
|
||||
export declare type SidePush<T> = {
|
||||
length?: number;
|
||||
push(data: T): void;
|
||||
filter(cb: (x: T) => boolean): SidePush<T>;
|
||||
};
|
||||
/**
|
||||
* An object describing side medium
|
||||
*/
|
||||
export interface SideMedium<T> {
|
||||
/**
|
||||
* Pushes effect to the medium
|
||||
* @param effect any information for real handler
|
||||
*/
|
||||
useMedium(effect: T): removeCb;
|
||||
/**
|
||||
* Assigns effect handler to the medium
|
||||
* @param {Function(effect: T)} handler effect handler
|
||||
*/
|
||||
assignMedium(handler: MediumCallback<T>): void;
|
||||
/**
|
||||
* Assigns a synchronous effect handler to the medium, which would be executed right on call
|
||||
* @param {Function(effect: T)} handler effect handler
|
||||
*/
|
||||
assignSyncMedium(handler: MediumCallback<T>): void;
|
||||
/**
|
||||
* reads the data stored in the medium
|
||||
*/
|
||||
read(): T | undefined;
|
||||
options?: Record<string, any>;
|
||||
}
|
||||
export declare type DefaultOrNot<T> = {
|
||||
default: T;
|
||||
} | T;
|
||||
export declare type Importer<T> = () => Promise<DefaultOrNot<React.ComponentType<T>>>;
|
||||
export declare type SideCarMedium<T = {}> = SideMedium<React.ComponentType<T>>;
|
||||
export declare type SideCarHOC<T = {}> = {
|
||||
readonly sideCar: SideCarMedium<T>;
|
||||
};
|
||||
export declare type SideCarComponent<T> = React.FunctionComponent<T & SideCarHOC<T>>;
|
||||
export declare type SideCarMediumOptions = {
|
||||
async?: boolean;
|
||||
ssr?: boolean;
|
||||
};
|
||||
1
frontend/node_modules/use-sidecar/dist/es2015/types.js
generated
vendored
Normal file
1
frontend/node_modules/use-sidecar/dist/es2015/types.js
generated
vendored
Normal file
@ -0,0 +1 @@
|
||||
export {};
|
||||
5
frontend/node_modules/use-sidecar/dist/es2019/config.d.ts
generated
vendored
Normal file
5
frontend/node_modules/use-sidecar/dist/es2019/config.d.ts
generated
vendored
Normal file
@ -0,0 +1,5 @@
|
||||
export interface IConfig {
|
||||
onError(e: Error): void;
|
||||
}
|
||||
export declare const config: IConfig;
|
||||
export declare const setConfig: (conf: Partial<IConfig>) => void;
|
||||
6
frontend/node_modules/use-sidecar/dist/es2019/config.js
generated
vendored
Normal file
6
frontend/node_modules/use-sidecar/dist/es2019/config.js
generated
vendored
Normal file
@ -0,0 +1,6 @@
|
||||
export const config = {
|
||||
onError: e => console.error(e),
|
||||
};
|
||||
export const setConfig = (conf) => {
|
||||
Object.assign(config, conf);
|
||||
};
|
||||
4
frontend/node_modules/use-sidecar/dist/es2019/env.d.ts
generated
vendored
Normal file
4
frontend/node_modules/use-sidecar/dist/es2019/env.d.ts
generated
vendored
Normal file
@ -0,0 +1,4 @@
|
||||
export declare const env: {
|
||||
isNode: boolean;
|
||||
forceCache: boolean;
|
||||
};
|
||||
5
frontend/node_modules/use-sidecar/dist/es2019/env.js
generated
vendored
Normal file
5
frontend/node_modules/use-sidecar/dist/es2019/env.js
generated
vendored
Normal file
@ -0,0 +1,5 @@
|
||||
import { isNode } from 'detect-node-es';
|
||||
export const env = {
|
||||
isNode,
|
||||
forceCache: false,
|
||||
};
|
||||
3
frontend/node_modules/use-sidecar/dist/es2019/exports.d.ts
generated
vendored
Normal file
3
frontend/node_modules/use-sidecar/dist/es2019/exports.d.ts
generated
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
import * as React from 'react';
|
||||
import { SideCarComponent, SideCarMedium } from './types';
|
||||
export declare function exportSidecar<T>(medium: SideCarMedium<T>, exported: React.ComponentType<T>): SideCarComponent<T>;
|
||||
16
frontend/node_modules/use-sidecar/dist/es2019/exports.js
generated
vendored
Normal file
16
frontend/node_modules/use-sidecar/dist/es2019/exports.js
generated
vendored
Normal file
@ -0,0 +1,16 @@
|
||||
import * as React from 'react';
|
||||
const SideCar = ({ sideCar, ...rest }) => {
|
||||
if (!sideCar) {
|
||||
throw new Error('Sidecar: please provide `sideCar` property to import the right car');
|
||||
}
|
||||
const Target = sideCar.read();
|
||||
if (!Target) {
|
||||
throw new Error('Sidecar medium not found');
|
||||
}
|
||||
return React.createElement(Target, { ...rest });
|
||||
};
|
||||
SideCar.isSideCarExport = true;
|
||||
export function exportSidecar(medium, exported) {
|
||||
medium.useMedium(exported);
|
||||
return SideCar;
|
||||
}
|
||||
3
frontend/node_modules/use-sidecar/dist/es2019/hoc.d.ts
generated
vendored
Normal file
3
frontend/node_modules/use-sidecar/dist/es2019/hoc.d.ts
generated
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
import * as React from 'react';
|
||||
import { Importer, SideCarHOC } from './types';
|
||||
export declare function sidecar<T>(importer: Importer<T>, errorComponent?: React.ReactNode): React.FunctionComponent<Omit<T, 'sideCar'> & SideCarHOC<Omit<T, 'sideCar'>>>;
|
||||
14
frontend/node_modules/use-sidecar/dist/es2019/hoc.js
generated
vendored
Normal file
14
frontend/node_modules/use-sidecar/dist/es2019/hoc.js
generated
vendored
Normal file
@ -0,0 +1,14 @@
|
||||
import * as React from 'react';
|
||||
import { useSidecar } from './hook';
|
||||
// eslint-disable-next-line @typescript-eslint/ban-types
|
||||
export function sidecar(importer, errorComponent) {
|
||||
const ErrorCase = () => errorComponent;
|
||||
return function Sidecar(props) {
|
||||
const [Car, error] = useSidecar(importer, props.sideCar);
|
||||
if (error && errorComponent) {
|
||||
return ErrorCase;
|
||||
}
|
||||
// @ts-expect-error type shenanigans
|
||||
return Car ? React.createElement(Car, { ...props }) : null;
|
||||
};
|
||||
}
|
||||
2
frontend/node_modules/use-sidecar/dist/es2019/hook.d.ts
generated
vendored
Normal file
2
frontend/node_modules/use-sidecar/dist/es2019/hook.d.ts
generated
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
import { Importer, SideMedium } from './types';
|
||||
export declare function useSidecar<T>(importer: Importer<T>, effect?: SideMedium<any>): [React.ComponentType<T> | null, Error | null];
|
||||
41
frontend/node_modules/use-sidecar/dist/es2019/hook.js
generated
vendored
Normal file
41
frontend/node_modules/use-sidecar/dist/es2019/hook.js
generated
vendored
Normal file
@ -0,0 +1,41 @@
|
||||
import { useState, useEffect } from 'react';
|
||||
import { env } from './env';
|
||||
const cache = new WeakMap();
|
||||
const NO_OPTIONS = {};
|
||||
export function useSidecar(importer, effect) {
|
||||
const options = (effect && effect.options) || NO_OPTIONS;
|
||||
if (env.isNode && !options.ssr) {
|
||||
return [null, null];
|
||||
}
|
||||
// eslint-disable-next-line react-hooks/rules-of-hooks
|
||||
return useRealSidecar(importer, effect);
|
||||
}
|
||||
function useRealSidecar(importer, effect) {
|
||||
const options = (effect && effect.options) || NO_OPTIONS;
|
||||
const couldUseCache = env.forceCache || (env.isNode && !!options.ssr) || !options.async;
|
||||
const [Car, setCar] = useState(couldUseCache ? () => cache.get(importer) : undefined);
|
||||
const [error, setError] = useState(null);
|
||||
useEffect(() => {
|
||||
if (!Car) {
|
||||
importer().then((car) => {
|
||||
const resolved = effect ? effect.read() : car.default || car;
|
||||
if (!resolved) {
|
||||
console.error('Sidecar error: with importer', importer);
|
||||
let error;
|
||||
if (effect) {
|
||||
console.error('Sidecar error: with medium', effect);
|
||||
error = new Error('Sidecar medium was not found');
|
||||
}
|
||||
else {
|
||||
error = new Error('Sidecar was not found in exports');
|
||||
}
|
||||
setError(() => error);
|
||||
throw error;
|
||||
}
|
||||
cache.set(importer, resolved);
|
||||
setCar(() => resolved);
|
||||
}, (e) => setError(() => e));
|
||||
}
|
||||
}, []);
|
||||
return [Car, error];
|
||||
}
|
||||
7
frontend/node_modules/use-sidecar/dist/es2019/index.d.ts
generated
vendored
Normal file
7
frontend/node_modules/use-sidecar/dist/es2019/index.d.ts
generated
vendored
Normal file
@ -0,0 +1,7 @@
|
||||
export { sidecar } from './hoc';
|
||||
export { useSidecar } from './hook';
|
||||
export { setConfig } from './config';
|
||||
export { createMedium, createSidecarMedium } from './medium';
|
||||
export { renderCar } from './renderProp';
|
||||
export { exportSidecar } from './exports';
|
||||
export type { SideCarComponent } from './types';
|
||||
6
frontend/node_modules/use-sidecar/dist/es2019/index.js
generated
vendored
Normal file
6
frontend/node_modules/use-sidecar/dist/es2019/index.js
generated
vendored
Normal file
@ -0,0 +1,6 @@
|
||||
export { sidecar } from './hoc';
|
||||
export { useSidecar } from './hook';
|
||||
export { setConfig } from './config';
|
||||
export { createMedium, createSidecarMedium } from './medium';
|
||||
export { renderCar } from './renderProp';
|
||||
export { exportSidecar } from './exports';
|
||||
3
frontend/node_modules/use-sidecar/dist/es2019/medium.d.ts
generated
vendored
Normal file
3
frontend/node_modules/use-sidecar/dist/es2019/medium.d.ts
generated
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
import { MiddlewareCallback, SideCarMedium, SideCarMediumOptions, SideMedium } from './types';
|
||||
export declare function createMedium<T>(defaults?: T, middleware?: MiddlewareCallback<T>): Readonly<SideMedium<T>>;
|
||||
export declare function createSidecarMedium<T = {}>(options?: SideCarMediumOptions): Readonly<SideCarMedium<T>>;
|
||||
78
frontend/node_modules/use-sidecar/dist/es2019/medium.js
generated
vendored
Normal file
78
frontend/node_modules/use-sidecar/dist/es2019/medium.js
generated
vendored
Normal file
@ -0,0 +1,78 @@
|
||||
function ItoI(a) {
|
||||
return a;
|
||||
}
|
||||
function innerCreateMedium(defaults, middleware = ItoI) {
|
||||
let buffer = [];
|
||||
let assigned = false;
|
||||
const medium = {
|
||||
read() {
|
||||
if (assigned) {
|
||||
throw new Error('Sidecar: could not `read` from an `assigned` medium. `read` could be used only with `useMedium`.');
|
||||
}
|
||||
if (buffer.length) {
|
||||
return buffer[buffer.length - 1];
|
||||
}
|
||||
return defaults;
|
||||
},
|
||||
useMedium(data) {
|
||||
const item = middleware(data, assigned);
|
||||
buffer.push(item);
|
||||
return () => {
|
||||
buffer = buffer.filter((x) => x !== item);
|
||||
};
|
||||
},
|
||||
assignSyncMedium(cb) {
|
||||
assigned = true;
|
||||
while (buffer.length) {
|
||||
const cbs = buffer;
|
||||
buffer = [];
|
||||
cbs.forEach(cb);
|
||||
}
|
||||
buffer = {
|
||||
push: (x) => cb(x),
|
||||
filter: () => buffer,
|
||||
};
|
||||
},
|
||||
assignMedium(cb) {
|
||||
assigned = true;
|
||||
let pendingQueue = [];
|
||||
if (buffer.length) {
|
||||
const cbs = buffer;
|
||||
buffer = [];
|
||||
cbs.forEach(cb);
|
||||
pendingQueue = buffer;
|
||||
}
|
||||
const executeQueue = () => {
|
||||
const cbs = pendingQueue;
|
||||
pendingQueue = [];
|
||||
cbs.forEach(cb);
|
||||
};
|
||||
const cycle = () => Promise.resolve().then(executeQueue);
|
||||
cycle();
|
||||
buffer = {
|
||||
push: (x) => {
|
||||
pendingQueue.push(x);
|
||||
cycle();
|
||||
},
|
||||
filter: (filter) => {
|
||||
pendingQueue = pendingQueue.filter(filter);
|
||||
return buffer;
|
||||
},
|
||||
};
|
||||
},
|
||||
};
|
||||
return medium;
|
||||
}
|
||||
export function createMedium(defaults, middleware = ItoI) {
|
||||
return innerCreateMedium(defaults, middleware);
|
||||
}
|
||||
// eslint-disable-next-line @typescript-eslint/ban-types
|
||||
export function createSidecarMedium(options = {}) {
|
||||
const medium = innerCreateMedium(null);
|
||||
medium.options = {
|
||||
async: true,
|
||||
ssr: false,
|
||||
...options,
|
||||
};
|
||||
return medium;
|
||||
}
|
||||
9
frontend/node_modules/use-sidecar/dist/es2019/renderProp.d.ts
generated
vendored
Normal file
9
frontend/node_modules/use-sidecar/dist/es2019/renderProp.d.ts
generated
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
import * as React from 'react';
|
||||
import { FC } from 'react';
|
||||
import { SideCarHOC } from './types';
|
||||
declare type CombinedProps<T extends any[], K> = {
|
||||
children: (...prop: T) => any;
|
||||
} & K;
|
||||
declare type RenderPropComponent<T extends any[], K> = React.ComponentType<CombinedProps<T, K>>;
|
||||
export declare function renderCar<T extends any[], K, C = RenderPropComponent<T, K & Partial<SideCarHOC>>>(WrappedComponent: C, defaults: (props: K) => T): FC<CombinedProps<T, K>>;
|
||||
export {};
|
||||
28
frontend/node_modules/use-sidecar/dist/es2019/renderProp.js
generated
vendored
Normal file
28
frontend/node_modules/use-sidecar/dist/es2019/renderProp.js
generated
vendored
Normal file
@ -0,0 +1,28 @@
|
||||
import * as React from 'react';
|
||||
import { useState, useCallback, useEffect, useLayoutEffect } from 'react';
|
||||
export function renderCar(WrappedComponent, defaults) {
|
||||
function State({ stateRef, props }) {
|
||||
const renderTarget = useCallback(function SideTarget(...args) {
|
||||
useLayoutEffect(() => {
|
||||
stateRef.current(args);
|
||||
});
|
||||
return null;
|
||||
}, []);
|
||||
// @ts-ignore
|
||||
return React.createElement(WrappedComponent, { ...props, children: renderTarget });
|
||||
}
|
||||
const Children = React.memo(({ stateRef, defaultState, children }) => {
|
||||
const [state, setState] = useState(defaultState.current);
|
||||
useEffect(() => {
|
||||
stateRef.current = setState;
|
||||
}, []);
|
||||
return children(...state);
|
||||
}, () => true);
|
||||
return function Combiner(props) {
|
||||
const defaultState = React.useRef(defaults(props));
|
||||
const ref = React.useRef((state) => (defaultState.current = state));
|
||||
return (React.createElement(React.Fragment, null,
|
||||
React.createElement(State, { stateRef: ref, props: props }),
|
||||
React.createElement(Children, { stateRef: ref, defaultState: defaultState, children: props.children })));
|
||||
};
|
||||
}
|
||||
47
frontend/node_modules/use-sidecar/dist/es2019/types.d.ts
generated
vendored
Normal file
47
frontend/node_modules/use-sidecar/dist/es2019/types.d.ts
generated
vendored
Normal file
@ -0,0 +1,47 @@
|
||||
import * as React from 'react';
|
||||
export declare type removeCb = () => void;
|
||||
export declare type MediumCallback<T> = (data: T) => any;
|
||||
export declare type MiddlewareCallback<T> = (data: T, assigned: boolean) => T;
|
||||
export declare type SidePush<T> = {
|
||||
length?: number;
|
||||
push(data: T): void;
|
||||
filter(cb: (x: T) => boolean): SidePush<T>;
|
||||
};
|
||||
/**
|
||||
* An object describing side medium
|
||||
*/
|
||||
export interface SideMedium<T> {
|
||||
/**
|
||||
* Pushes effect to the medium
|
||||
* @param effect any information for real handler
|
||||
*/
|
||||
useMedium(effect: T): removeCb;
|
||||
/**
|
||||
* Assigns effect handler to the medium
|
||||
* @param {Function(effect: T)} handler effect handler
|
||||
*/
|
||||
assignMedium(handler: MediumCallback<T>): void;
|
||||
/**
|
||||
* Assigns a synchronous effect handler to the medium, which would be executed right on call
|
||||
* @param {Function(effect: T)} handler effect handler
|
||||
*/
|
||||
assignSyncMedium(handler: MediumCallback<T>): void;
|
||||
/**
|
||||
* reads the data stored in the medium
|
||||
*/
|
||||
read(): T | undefined;
|
||||
options?: Record<string, any>;
|
||||
}
|
||||
export declare type DefaultOrNot<T> = {
|
||||
default: T;
|
||||
} | T;
|
||||
export declare type Importer<T> = () => Promise<DefaultOrNot<React.ComponentType<T>>>;
|
||||
export declare type SideCarMedium<T = {}> = SideMedium<React.ComponentType<T>>;
|
||||
export declare type SideCarHOC<T = {}> = {
|
||||
readonly sideCar: SideCarMedium<T>;
|
||||
};
|
||||
export declare type SideCarComponent<T> = React.FunctionComponent<T & SideCarHOC<T>>;
|
||||
export declare type SideCarMediumOptions = {
|
||||
async?: boolean;
|
||||
ssr?: boolean;
|
||||
};
|
||||
1
frontend/node_modules/use-sidecar/dist/es2019/types.js
generated
vendored
Normal file
1
frontend/node_modules/use-sidecar/dist/es2019/types.js
generated
vendored
Normal file
@ -0,0 +1 @@
|
||||
export {};
|
||||
5
frontend/node_modules/use-sidecar/dist/es5/config.d.ts
generated
vendored
Normal file
5
frontend/node_modules/use-sidecar/dist/es5/config.d.ts
generated
vendored
Normal file
@ -0,0 +1,5 @@
|
||||
export interface IConfig {
|
||||
onError(e: Error): void;
|
||||
}
|
||||
export declare const config: IConfig;
|
||||
export declare const setConfig: (conf: Partial<IConfig>) => void;
|
||||
10
frontend/node_modules/use-sidecar/dist/es5/config.js
generated
vendored
Normal file
10
frontend/node_modules/use-sidecar/dist/es5/config.js
generated
vendored
Normal file
@ -0,0 +1,10 @@
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.setConfig = exports.config = void 0;
|
||||
exports.config = {
|
||||
onError: function (e) { return console.error(e); },
|
||||
};
|
||||
var setConfig = function (conf) {
|
||||
Object.assign(exports.config, conf);
|
||||
};
|
||||
exports.setConfig = setConfig;
|
||||
4
frontend/node_modules/use-sidecar/dist/es5/env.d.ts
generated
vendored
Normal file
4
frontend/node_modules/use-sidecar/dist/es5/env.d.ts
generated
vendored
Normal file
@ -0,0 +1,4 @@
|
||||
export declare const env: {
|
||||
isNode: boolean;
|
||||
forceCache: boolean;
|
||||
};
|
||||
8
frontend/node_modules/use-sidecar/dist/es5/env.js
generated
vendored
Normal file
8
frontend/node_modules/use-sidecar/dist/es5/env.js
generated
vendored
Normal file
@ -0,0 +1,8 @@
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.env = void 0;
|
||||
var detect_node_es_1 = require("detect-node-es");
|
||||
exports.env = {
|
||||
isNode: detect_node_es_1.isNode,
|
||||
forceCache: false,
|
||||
};
|
||||
3
frontend/node_modules/use-sidecar/dist/es5/exports.d.ts
generated
vendored
Normal file
3
frontend/node_modules/use-sidecar/dist/es5/exports.d.ts
generated
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
import * as React from 'react';
|
||||
import { SideCarComponent, SideCarMedium } from './types';
|
||||
export declare function exportSidecar<T>(medium: SideCarMedium<T>, exported: React.ComponentType<T>): SideCarComponent<T>;
|
||||
22
frontend/node_modules/use-sidecar/dist/es5/exports.js
generated
vendored
Normal file
22
frontend/node_modules/use-sidecar/dist/es5/exports.js
generated
vendored
Normal file
@ -0,0 +1,22 @@
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.exportSidecar = void 0;
|
||||
var tslib_1 = require("tslib");
|
||||
var React = tslib_1.__importStar(require("react"));
|
||||
var SideCar = function (_a) {
|
||||
var sideCar = _a.sideCar, rest = tslib_1.__rest(_a, ["sideCar"]);
|
||||
if (!sideCar) {
|
||||
throw new Error('Sidecar: please provide `sideCar` property to import the right car');
|
||||
}
|
||||
var Target = sideCar.read();
|
||||
if (!Target) {
|
||||
throw new Error('Sidecar medium not found');
|
||||
}
|
||||
return React.createElement(Target, tslib_1.__assign({}, rest));
|
||||
};
|
||||
SideCar.isSideCarExport = true;
|
||||
function exportSidecar(medium, exported) {
|
||||
medium.useMedium(exported);
|
||||
return SideCar;
|
||||
}
|
||||
exports.exportSidecar = exportSidecar;
|
||||
3
frontend/node_modules/use-sidecar/dist/es5/hoc.d.ts
generated
vendored
Normal file
3
frontend/node_modules/use-sidecar/dist/es5/hoc.d.ts
generated
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
import * as React from 'react';
|
||||
import { Importer, SideCarHOC } from './types';
|
||||
export declare function sidecar<T>(importer: Importer<T>, errorComponent?: React.ReactNode): React.FunctionComponent<Omit<T, 'sideCar'> & SideCarHOC<Omit<T, 'sideCar'>>>;
|
||||
19
frontend/node_modules/use-sidecar/dist/es5/hoc.js
generated
vendored
Normal file
19
frontend/node_modules/use-sidecar/dist/es5/hoc.js
generated
vendored
Normal file
@ -0,0 +1,19 @@
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.sidecar = void 0;
|
||||
var tslib_1 = require("tslib");
|
||||
var React = tslib_1.__importStar(require("react"));
|
||||
var hook_1 = require("./hook");
|
||||
// eslint-disable-next-line @typescript-eslint/ban-types
|
||||
function sidecar(importer, errorComponent) {
|
||||
var ErrorCase = function () { return errorComponent; };
|
||||
return function Sidecar(props) {
|
||||
var _a = (0, hook_1.useSidecar)(importer, props.sideCar), Car = _a[0], error = _a[1];
|
||||
if (error && errorComponent) {
|
||||
return ErrorCase;
|
||||
}
|
||||
// @ts-expect-error type shenanigans
|
||||
return Car ? React.createElement(Car, tslib_1.__assign({}, props)) : null;
|
||||
};
|
||||
}
|
||||
exports.sidecar = sidecar;
|
||||
2
frontend/node_modules/use-sidecar/dist/es5/hook.d.ts
generated
vendored
Normal file
2
frontend/node_modules/use-sidecar/dist/es5/hook.d.ts
generated
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
import { Importer, SideMedium } from './types';
|
||||
export declare function useSidecar<T>(importer: Importer<T>, effect?: SideMedium<any>): [React.ComponentType<T> | null, Error | null];
|
||||
45
frontend/node_modules/use-sidecar/dist/es5/hook.js
generated
vendored
Normal file
45
frontend/node_modules/use-sidecar/dist/es5/hook.js
generated
vendored
Normal file
@ -0,0 +1,45 @@
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.useSidecar = void 0;
|
||||
var react_1 = require("react");
|
||||
var env_1 = require("./env");
|
||||
var cache = new WeakMap();
|
||||
var NO_OPTIONS = {};
|
||||
function useSidecar(importer, effect) {
|
||||
var options = (effect && effect.options) || NO_OPTIONS;
|
||||
if (env_1.env.isNode && !options.ssr) {
|
||||
return [null, null];
|
||||
}
|
||||
// eslint-disable-next-line react-hooks/rules-of-hooks
|
||||
return useRealSidecar(importer, effect);
|
||||
}
|
||||
exports.useSidecar = useSidecar;
|
||||
function useRealSidecar(importer, effect) {
|
||||
var options = (effect && effect.options) || NO_OPTIONS;
|
||||
var couldUseCache = env_1.env.forceCache || (env_1.env.isNode && !!options.ssr) || !options.async;
|
||||
var _a = (0, react_1.useState)(couldUseCache ? function () { return cache.get(importer); } : undefined), Car = _a[0], setCar = _a[1];
|
||||
var _b = (0, react_1.useState)(null), error = _b[0], setError = _b[1];
|
||||
(0, react_1.useEffect)(function () {
|
||||
if (!Car) {
|
||||
importer().then(function (car) {
|
||||
var resolved = effect ? effect.read() : car.default || car;
|
||||
if (!resolved) {
|
||||
console.error('Sidecar error: with importer', importer);
|
||||
var error_1;
|
||||
if (effect) {
|
||||
console.error('Sidecar error: with medium', effect);
|
||||
error_1 = new Error('Sidecar medium was not found');
|
||||
}
|
||||
else {
|
||||
error_1 = new Error('Sidecar was not found in exports');
|
||||
}
|
||||
setError(function () { return error_1; });
|
||||
throw error_1;
|
||||
}
|
||||
cache.set(importer, resolved);
|
||||
setCar(function () { return resolved; });
|
||||
}, function (e) { return setError(function () { return e; }); });
|
||||
}
|
||||
}, []);
|
||||
return [Car, error];
|
||||
}
|
||||
7
frontend/node_modules/use-sidecar/dist/es5/index.d.ts
generated
vendored
Normal file
7
frontend/node_modules/use-sidecar/dist/es5/index.d.ts
generated
vendored
Normal file
@ -0,0 +1,7 @@
|
||||
export { sidecar } from './hoc';
|
||||
export { useSidecar } from './hook';
|
||||
export { setConfig } from './config';
|
||||
export { createMedium, createSidecarMedium } from './medium';
|
||||
export { renderCar } from './renderProp';
|
||||
export { exportSidecar } from './exports';
|
||||
export type { SideCarComponent } from './types';
|
||||
16
frontend/node_modules/use-sidecar/dist/es5/index.js
generated
vendored
Normal file
16
frontend/node_modules/use-sidecar/dist/es5/index.js
generated
vendored
Normal file
@ -0,0 +1,16 @@
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.exportSidecar = exports.renderCar = exports.createSidecarMedium = exports.createMedium = exports.setConfig = exports.useSidecar = exports.sidecar = void 0;
|
||||
var hoc_1 = require("./hoc");
|
||||
Object.defineProperty(exports, "sidecar", { enumerable: true, get: function () { return hoc_1.sidecar; } });
|
||||
var hook_1 = require("./hook");
|
||||
Object.defineProperty(exports, "useSidecar", { enumerable: true, get: function () { return hook_1.useSidecar; } });
|
||||
var config_1 = require("./config");
|
||||
Object.defineProperty(exports, "setConfig", { enumerable: true, get: function () { return config_1.setConfig; } });
|
||||
var medium_1 = require("./medium");
|
||||
Object.defineProperty(exports, "createMedium", { enumerable: true, get: function () { return medium_1.createMedium; } });
|
||||
Object.defineProperty(exports, "createSidecarMedium", { enumerable: true, get: function () { return medium_1.createSidecarMedium; } });
|
||||
var renderProp_1 = require("./renderProp");
|
||||
Object.defineProperty(exports, "renderCar", { enumerable: true, get: function () { return renderProp_1.renderCar; } });
|
||||
var exports_1 = require("./exports");
|
||||
Object.defineProperty(exports, "exportSidecar", { enumerable: true, get: function () { return exports_1.exportSidecar; } });
|
||||
3
frontend/node_modules/use-sidecar/dist/es5/medium.d.ts
generated
vendored
Normal file
3
frontend/node_modules/use-sidecar/dist/es5/medium.d.ts
generated
vendored
Normal file
@ -0,0 +1,3 @@
|
||||
import { MiddlewareCallback, SideCarMedium, SideCarMediumOptions, SideMedium } from './types';
|
||||
export declare function createMedium<T>(defaults?: T, middleware?: MiddlewareCallback<T>): Readonly<SideMedium<T>>;
|
||||
export declare function createSidecarMedium<T = {}>(options?: SideCarMediumOptions): Readonly<SideCarMedium<T>>;
|
||||
83
frontend/node_modules/use-sidecar/dist/es5/medium.js
generated
vendored
Normal file
83
frontend/node_modules/use-sidecar/dist/es5/medium.js
generated
vendored
Normal file
@ -0,0 +1,83 @@
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.createSidecarMedium = exports.createMedium = void 0;
|
||||
var tslib_1 = require("tslib");
|
||||
function ItoI(a) {
|
||||
return a;
|
||||
}
|
||||
function innerCreateMedium(defaults, middleware) {
|
||||
if (middleware === void 0) { middleware = ItoI; }
|
||||
var buffer = [];
|
||||
var assigned = false;
|
||||
var medium = {
|
||||
read: function () {
|
||||
if (assigned) {
|
||||
throw new Error('Sidecar: could not `read` from an `assigned` medium. `read` could be used only with `useMedium`.');
|
||||
}
|
||||
if (buffer.length) {
|
||||
return buffer[buffer.length - 1];
|
||||
}
|
||||
return defaults;
|
||||
},
|
||||
useMedium: function (data) {
|
||||
var item = middleware(data, assigned);
|
||||
buffer.push(item);
|
||||
return function () {
|
||||
buffer = buffer.filter(function (x) { return x !== item; });
|
||||
};
|
||||
},
|
||||
assignSyncMedium: function (cb) {
|
||||
assigned = true;
|
||||
while (buffer.length) {
|
||||
var cbs = buffer;
|
||||
buffer = [];
|
||||
cbs.forEach(cb);
|
||||
}
|
||||
buffer = {
|
||||
push: function (x) { return cb(x); },
|
||||
filter: function () { return buffer; },
|
||||
};
|
||||
},
|
||||
assignMedium: function (cb) {
|
||||
assigned = true;
|
||||
var pendingQueue = [];
|
||||
if (buffer.length) {
|
||||
var cbs = buffer;
|
||||
buffer = [];
|
||||
cbs.forEach(cb);
|
||||
pendingQueue = buffer;
|
||||
}
|
||||
var executeQueue = function () {
|
||||
var cbs = pendingQueue;
|
||||
pendingQueue = [];
|
||||
cbs.forEach(cb);
|
||||
};
|
||||
var cycle = function () { return Promise.resolve().then(executeQueue); };
|
||||
cycle();
|
||||
buffer = {
|
||||
push: function (x) {
|
||||
pendingQueue.push(x);
|
||||
cycle();
|
||||
},
|
||||
filter: function (filter) {
|
||||
pendingQueue = pendingQueue.filter(filter);
|
||||
return buffer;
|
||||
},
|
||||
};
|
||||
},
|
||||
};
|
||||
return medium;
|
||||
}
|
||||
function createMedium(defaults, middleware) {
|
||||
if (middleware === void 0) { middleware = ItoI; }
|
||||
return innerCreateMedium(defaults, middleware);
|
||||
}
|
||||
exports.createMedium = createMedium;
|
||||
// eslint-disable-next-line @typescript-eslint/ban-types
|
||||
function createSidecarMedium(options) {
|
||||
if (options === void 0) { options = {}; }
|
||||
var medium = innerCreateMedium(null);
|
||||
medium.options = tslib_1.__assign({ async: true, ssr: false }, options);
|
||||
return medium;
|
||||
}
|
||||
exports.createSidecarMedium = createSidecarMedium;
|
||||
9
frontend/node_modules/use-sidecar/dist/es5/renderProp.d.ts
generated
vendored
Normal file
9
frontend/node_modules/use-sidecar/dist/es5/renderProp.d.ts
generated
vendored
Normal file
@ -0,0 +1,9 @@
|
||||
import * as React from 'react';
|
||||
import { FC } from 'react';
|
||||
import { SideCarHOC } from './types';
|
||||
declare type CombinedProps<T extends any[], K> = {
|
||||
children: (...prop: T) => any;
|
||||
} & K;
|
||||
declare type RenderPropComponent<T extends any[], K> = React.ComponentType<CombinedProps<T, K>>;
|
||||
export declare function renderCar<T extends any[], K, C = RenderPropComponent<T, K & Partial<SideCarHOC>>>(WrappedComponent: C, defaults: (props: K) => T): FC<CombinedProps<T, K>>;
|
||||
export {};
|
||||
39
frontend/node_modules/use-sidecar/dist/es5/renderProp.js
generated
vendored
Normal file
39
frontend/node_modules/use-sidecar/dist/es5/renderProp.js
generated
vendored
Normal file
@ -0,0 +1,39 @@
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
exports.renderCar = void 0;
|
||||
var tslib_1 = require("tslib");
|
||||
var React = tslib_1.__importStar(require("react"));
|
||||
var react_1 = require("react");
|
||||
function renderCar(WrappedComponent, defaults) {
|
||||
function State(_a) {
|
||||
var stateRef = _a.stateRef, props = _a.props;
|
||||
var renderTarget = (0, react_1.useCallback)(function SideTarget() {
|
||||
var args = [];
|
||||
for (var _i = 0; _i < arguments.length; _i++) {
|
||||
args[_i] = arguments[_i];
|
||||
}
|
||||
(0, react_1.useLayoutEffect)(function () {
|
||||
stateRef.current(args);
|
||||
});
|
||||
return null;
|
||||
}, []);
|
||||
// @ts-ignore
|
||||
return React.createElement(WrappedComponent, tslib_1.__assign({}, props, { children: renderTarget }));
|
||||
}
|
||||
var Children = React.memo(function (_a) {
|
||||
var stateRef = _a.stateRef, defaultState = _a.defaultState, children = _a.children;
|
||||
var _b = (0, react_1.useState)(defaultState.current), state = _b[0], setState = _b[1];
|
||||
(0, react_1.useEffect)(function () {
|
||||
stateRef.current = setState;
|
||||
}, []);
|
||||
return children.apply(void 0, state);
|
||||
}, function () { return true; });
|
||||
return function Combiner(props) {
|
||||
var defaultState = React.useRef(defaults(props));
|
||||
var ref = React.useRef(function (state) { return (defaultState.current = state); });
|
||||
return (React.createElement(React.Fragment, null,
|
||||
React.createElement(State, { stateRef: ref, props: props }),
|
||||
React.createElement(Children, { stateRef: ref, defaultState: defaultState, children: props.children })));
|
||||
};
|
||||
}
|
||||
exports.renderCar = renderCar;
|
||||
47
frontend/node_modules/use-sidecar/dist/es5/types.d.ts
generated
vendored
Normal file
47
frontend/node_modules/use-sidecar/dist/es5/types.d.ts
generated
vendored
Normal file
@ -0,0 +1,47 @@
|
||||
import * as React from 'react';
|
||||
export declare type removeCb = () => void;
|
||||
export declare type MediumCallback<T> = (data: T) => any;
|
||||
export declare type MiddlewareCallback<T> = (data: T, assigned: boolean) => T;
|
||||
export declare type SidePush<T> = {
|
||||
length?: number;
|
||||
push(data: T): void;
|
||||
filter(cb: (x: T) => boolean): SidePush<T>;
|
||||
};
|
||||
/**
|
||||
* An object describing side medium
|
||||
*/
|
||||
export interface SideMedium<T> {
|
||||
/**
|
||||
* Pushes effect to the medium
|
||||
* @param effect any information for real handler
|
||||
*/
|
||||
useMedium(effect: T): removeCb;
|
||||
/**
|
||||
* Assigns effect handler to the medium
|
||||
* @param {Function(effect: T)} handler effect handler
|
||||
*/
|
||||
assignMedium(handler: MediumCallback<T>): void;
|
||||
/**
|
||||
* Assigns a synchronous effect handler to the medium, which would be executed right on call
|
||||
* @param {Function(effect: T)} handler effect handler
|
||||
*/
|
||||
assignSyncMedium(handler: MediumCallback<T>): void;
|
||||
/**
|
||||
* reads the data stored in the medium
|
||||
*/
|
||||
read(): T | undefined;
|
||||
options?: Record<string, any>;
|
||||
}
|
||||
export declare type DefaultOrNot<T> = {
|
||||
default: T;
|
||||
} | T;
|
||||
export declare type Importer<T> = () => Promise<DefaultOrNot<React.ComponentType<T>>>;
|
||||
export declare type SideCarMedium<T = {}> = SideMedium<React.ComponentType<T>>;
|
||||
export declare type SideCarHOC<T = {}> = {
|
||||
readonly sideCar: SideCarMedium<T>;
|
||||
};
|
||||
export declare type SideCarComponent<T> = React.FunctionComponent<T & SideCarHOC<T>>;
|
||||
export declare type SideCarMediumOptions = {
|
||||
async?: boolean;
|
||||
ssr?: boolean;
|
||||
};
|
||||
2
frontend/node_modules/use-sidecar/dist/es5/types.js
generated
vendored
Normal file
2
frontend/node_modules/use-sidecar/dist/es5/types.js
generated
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", { value: true });
|
||||
Reference in New Issue
Block a user