Skip to content

Commit

Permalink
fix: add fixes + tests
Browse files Browse the repository at this point in the history
  • Loading branch information
bocembocem committed Mar 27, 2023
1 parent c664193 commit e9cdf34
Show file tree
Hide file tree
Showing 31 changed files with 15,580 additions and 8,265 deletions.
6 changes: 6 additions & 0 deletions jest.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,4 +8,10 @@ module.exports = {
transformIgnorePatterns: ['node_modules/(?!(@gravity-ui)/)'],
coverageDirectory: './coverage',
collectCoverageFrom: ['src/**/*.{ts,tsx}', '!**/__stories__/**/*', '!**/*/*.stories.{ts,tsx}'],
testEnvironment: 'jsdom',
setupFilesAfterEnv: ['<rootDir>/test-utils/setup-tests-after.ts'],
moduleNameMapper: {
'\\.(css|less|scss|sass)$': 'jest-transform-css',
},
testMatch: ['**/*.test.[jt]s?(x)'],
};
21,428 changes: 13,246 additions & 8,182 deletions package-lock.json

Large diffs are not rendered by default.

12 changes: 10 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@
"lint:js": "eslint src --quiet",
"lint:prettier": "prettier --check 'src/**/*.{js,jsx,ts,tsx,css,scss}'",
"lint:styles": "stylelint 'src/**/*.scss'",
"test": "jest",
"typecheck": "tsc -p src --noEmit",
"build": "gulp",
"build-storybook": "build-storybook",
Expand All @@ -42,10 +43,10 @@
"lodash": "^4.17.20"
},
"devDependencies": {
"@commitlint/cli": "^17.0.0",
"@commitlint/config-conventional": "^17.0.0",
"@babel/preset-env": "^7.20.2",
"@babel/preset-typescript": "^7.18.6",
"@commitlint/cli": "^17.0.0",
"@commitlint/config-conventional": "^17.0.0",
"@gravity-ui/eslint-config": "^2.0.0",
"@gravity-ui/prettier-config": "^1.0.1",
"@gravity-ui/stylelint-config": "^2.0.0",
Expand All @@ -54,6 +55,9 @@
"@storybook/addon-essentials": "^6.5.16",
"@storybook/preset-scss": "^1.0.3",
"@storybook/react": "^6.5.16",
"@testing-library/jest-dom": "^5.16.5",
"@testing-library/react": "^14.0.0",
"@types/jest": "^29.5.0",
"@types/lodash": "^4.14.180",
"@types/react": "^18.0.28",
"@types/react-dom": "^18.0.11",
Expand All @@ -67,6 +71,9 @@
"gulp-replace": "^1.1.4",
"gulp-typescript": "^6.0.0-alpha.1",
"husky": "^7.0.4",
"jest": "^29.5.0",
"jest-environment-jsdom": "^29.5.0",
"jest-transform-css": "^6.0.1",
"monaco-editor": "^0.30.1",
"monaco-editor-webpack-plugin": "^6.0.0",
"npm-run-all": "^4.1.5",
Expand All @@ -83,6 +90,7 @@
"style-loader": "^2.0.0",
"stylelint": "^14.15.0",
"stylelint-scss": "^4.2.0",
"ts-jest": "^29.0.5",
"typescript": "^4.9.5"
},
"peerDependencies": {
Expand Down
27 changes: 23 additions & 4 deletions src/lib/core/components/Form/Controller.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,16 @@ import _ from 'lodash';
import {isCorrectSpec} from '../../helpers';
import {Spec} from '../../types';

import {useComponents, useDynamicFormsCtx, useField, useRender, useValidate} from './hooks';
import {useSearch} from './hooks/useSearch';
import {FieldValue, ValidateError} from './types';
import {
useComponents,
useControllerMirror,
useDynamicFormsCtx,
useField,
useRender,
useSearch,
useValidate,
} from './hooks';
import {ControllerMirror, FieldValue, ValidateError} from './types';

export interface ControllerProps<Value extends FieldValue, SpecType extends Spec> {
spec: SpecType;
Expand All @@ -28,7 +35,7 @@ export const Controller = <Value extends FieldValue, SpecType extends Spec>({
parentOnChange,
parentOnUnmount,
}: ControllerProps<Value, SpecType>) => {
const {tools} = useDynamicFormsCtx();
const {tools, __mirror} = useDynamicFormsCtx();
const {inputEntity, Layout} = useComponents(spec);
const render = useRender({name, spec, inputEntity, Layout});
const validate = useValidate(spec);
Expand All @@ -43,6 +50,18 @@ export const Controller = <Value extends FieldValue, SpecType extends Spec>({
});
const withSearch = useSearch(spec, renderProps.input.value, name);

useControllerMirror(
name,
{
useComponents: {inputEntity, Layout},
useRender: render,
useValidate: validate,
useField: renderProps,
useSearch: withSearch,
} as ControllerMirror,
__mirror,
);

if (_.isString(name) && isCorrectSpec(spec)) {
return withSearch(render(renderProps));
}
Expand Down
39 changes: 32 additions & 7 deletions src/lib/core/components/Form/DynamicField.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,15 @@ import {isCorrectSpec} from '../../helpers';
import {Spec} from '../../types';

import {Controller} from './Controller';
import {useCreateContext, useCreateSearchContext, useSearchStore, useStore} from './hooks';
import {DynamicFormConfig, FieldValue} from './types';
import {
useCreateContext,
useCreateSearchContext,
useDynamicFieldMirror,
useIntegrationFF,
useSearchStore,
useStore,
} from './hooks';
import {DynamicFormConfig, FieldValue, WonderMirror} from './types';
import {getDefaultSearchFunction, isCorrectConfig} from './utils';

export interface DynamicFieldProps {
Expand All @@ -18,22 +25,31 @@ export interface DynamicFieldProps {
config: DynamicFormConfig;
Monaco?: React.ComponentType<MonacoEditorProps>;
search?: string | ((spec: Spec, input: FieldValue, name: string) => boolean);
__mirror?: WonderMirror;
}

export const DynamicField: React.FC<DynamicFieldProps> = ({name, spec, config, Monaco, search}) => {
export const DynamicField: React.FC<DynamicFieldProps> = ({
name,
spec,
config,
Monaco,
search,
__mirror,
}) => {
const DynamicFormsCtx = useCreateContext();
const SearchContext = useCreateSearchContext();
const {tools, watcher} = useStore(name);

const {setField, removeField, isHiddenField} = useSearchStore(name);
const {tools, store} = useStore(name);
const watcher = useIntegrationFF(store);
const {store: searchStore, setField, removeField, isHiddenField} = useSearchStore();

const context = React.useMemo(
() => ({
config,
Monaco: isValidElementType(Monaco) ? Monaco : undefined,
tools,
__mirror,
}),
[tools, config, Monaco],
[tools, config, Monaco, __mirror],
);

const searchContext = React.useMemo(
Expand All @@ -51,6 +67,15 @@ export const DynamicField: React.FC<DynamicFieldProps> = ({name, spec, config, M
[name, spec, config],
);

useDynamicFieldMirror(
{
useStore: {tools, store},
useIntegrationFF: watcher,
useSearchStore: {store: searchStore, setField, removeField, isHiddenField},
},
__mirror,
);

if (correctParams) {
return (
<DynamicFormsCtx.Provider value={context}>
Expand Down
Loading

0 comments on commit e9cdf34

Please sign in to comment.