@fairys/pc-valtio-form-basic 0.0.12 → 0.0.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/esm/form.d.ts CHANGED
@@ -1,18 +1,26 @@
1
1
  import { FairysPCValtioFormItem, FairysPCValtioFormHideItem, FairysPCValtioFormItemBase } from './form.item';
2
2
  import { useFairysValtioFormInstance, useFairysValtioFormInstanceContext, useFairysValtioFormInstanceContextState, useFairysValtioFormInstanceContextHideState } from '@fairys/valtio-form-basic';
3
- import type { FairysValtioFormAttrsProps, MObject } from '@fairys/valtio-form-basic';
3
+ import type { FairysValtioFormAttrsProps, FairysValtioFormInstance, MObject } from '@fairys/valtio-form-basic';
4
+ import React from 'react';
4
5
  export * from '@fairys/valtio-form-basic';
5
6
  export * from './form.item';
6
7
  export * from './layout';
7
8
  export interface FairysPCValtioFormProps<T extends MObject<T> = object> extends FairysValtioFormAttrsProps<T> {
8
9
  }
9
- export declare function FairysPCValtioForm<T extends MObject<T> = object>(props: FairysPCValtioFormProps<T>): import("react/jsx-runtime").JSX.Element;
10
- export declare namespace FairysPCValtioForm {
11
- var useForm: typeof useFairysValtioFormInstance;
12
- var useFormState: typeof useFairysValtioFormInstanceContextState;
13
- var useFormHideState: typeof useFairysValtioFormInstanceContextHideState;
14
- var useFormInstance: typeof useFairysValtioFormInstanceContext;
15
- var FormItemBase: typeof FairysPCValtioFormItemBase;
16
- var FormItem: typeof FairysPCValtioFormItem;
17
- var FormHideItem: typeof FairysPCValtioFormHideItem;
18
- }
10
+ declare function FairysPCValtioFormBase<T extends MObject<T> = object>(props: FairysPCValtioFormProps<T>, ref: React.Ref<FairysValtioFormInstance<T>>): import("react/jsx-runtime").JSX.Element;
11
+ export declare const FairysPCValtioForm: typeof FairysPCValtioFormBase & {
12
+ /**初始化实例*/
13
+ useForm: typeof useFairysValtioFormInstance;
14
+ /**获取状态*/
15
+ useFormState: typeof useFairysValtioFormInstanceContextState;
16
+ /**获取隐藏状态*/
17
+ useFormHideState: typeof useFairysValtioFormInstanceContextHideState;
18
+ /**获取上下文实例*/
19
+ useFormInstance: typeof useFairysValtioFormInstanceContext;
20
+ /**表单项基础组件*/
21
+ FormItemBase: typeof FairysPCValtioFormItemBase;
22
+ /**表单项组件*/
23
+ FormItem: typeof FairysPCValtioFormItem;
24
+ /**隐藏表单项组件*/
25
+ FormHideItem: typeof FairysPCValtioFormHideItem;
26
+ };
package/esm/form.js CHANGED
@@ -2,11 +2,12 @@ import { jsx } from "react/jsx-runtime";
2
2
  import { FairysPCValtioFormLayout } from "./layout.js";
3
3
  import { FairysPCValtioFormHideItem, FairysPCValtioFormItem, FairysPCValtioFormItemBase } from "./form.item.js";
4
4
  import { FairysValtioFormInstanceContext, useFairysValtioForm, useFairysValtioFormInstance, useFairysValtioFormInstanceContext, useFairysValtioFormInstanceContextHideState, useFairysValtioFormInstanceContextState } from "@fairys/valtio-form-basic";
5
+ import react from "react";
5
6
  export * from "@fairys/valtio-form-basic";
6
7
  export * from "./form.item.js";
7
8
  export * from "./layout.js";
8
- function FairysPCValtioForm(props) {
9
- const { formInstance, children, colCount = 4, labelMode = 'top', errorLayout = 'bottom-left', itemBorderType = 'none', platform = 'pc', ...rest } = useFairysValtioForm(props);
9
+ function FairysPCValtioFormBase(props, ref) {
10
+ const { formInstance, children, colCount = 4, labelMode = 'top', errorLayout = 'bottom-left', itemBorderType = 'none', platform = 'pc', ...rest } = useFairysValtioForm(props, ref);
10
11
  return /*#__PURE__*/ jsx(FairysValtioFormInstanceContext.Provider, {
11
12
  value: formInstance,
12
13
  children: /*#__PURE__*/ jsx(FairysPCValtioFormLayout, {
@@ -20,6 +21,7 @@ function FairysPCValtioForm(props) {
20
21
  })
21
22
  });
22
23
  }
24
+ const FairysPCValtioForm = /*#__PURE__*/ react.forwardRef(FairysPCValtioFormBase);
23
25
  FairysPCValtioForm.useForm = useFairysValtioFormInstance;
24
26
  FairysPCValtioForm.useFormState = useFairysValtioFormInstanceContextState;
25
27
  FairysPCValtioForm.useFormHideState = useFairysValtioFormInstanceContextHideState;
package/package.json CHANGED
@@ -3,7 +3,7 @@
3
3
  "author": "SunLxy <1011771396@qq.com>",
4
4
  "description": "pc表单框架组件",
5
5
  "homepage": "https://github.com/autumn-fairy-tales/valtio-form-basic",
6
- "version": "0.0.12",
6
+ "version": "0.0.13",
7
7
  "main": "lib/index.js",
8
8
  "types": "esm/index.d.ts",
9
9
  "module": "esm/index.js",
@@ -25,10 +25,10 @@
25
25
  "esm"
26
26
  ],
27
27
  "dependencies": {
28
- "@fairys/valtio-form-basic": "^0.0.12"
28
+ "@fairys/valtio-form-basic": "^0.0.13"
29
29
  },
30
30
  "devDependencies": {
31
31
  "@types/react": "~18.2.21",
32
32
  "react": "^18.0.0"
33
33
  }
34
- }
34
+ }
package/src/form.tsx CHANGED
@@ -8,13 +8,17 @@ import {
8
8
  useFairysValtioFormInstanceContextState,
9
9
  useFairysValtioFormInstanceContextHideState,
10
10
  } from '@fairys/valtio-form-basic';
11
- import type { FairysValtioFormAttrsProps, MObject } from '@fairys/valtio-form-basic';
11
+ import type { FairysValtioFormAttrsProps, FairysValtioFormInstance, MObject } from '@fairys/valtio-form-basic';
12
+ import React from 'react';
12
13
  export * from '@fairys/valtio-form-basic';
13
14
  export * from './form.item';
14
15
  export * from './layout';
15
16
  export interface FairysPCValtioFormProps<T extends MObject<T> = object> extends FairysValtioFormAttrsProps<T> {}
16
17
 
17
- export function FairysPCValtioForm<T extends MObject<T> = object>(props: FairysPCValtioFormProps<T>) {
18
+ function FairysPCValtioFormBase<T extends MObject<T> = object>(
19
+ props: FairysPCValtioFormProps<T>,
20
+ ref: React.Ref<FairysValtioFormInstance<T>>,
21
+ ) {
18
22
  const {
19
23
  formInstance,
20
24
  children,
@@ -24,7 +28,7 @@ export function FairysPCValtioForm<T extends MObject<T> = object>(props: FairysP
24
28
  itemBorderType = 'none',
25
29
  platform = 'pc',
26
30
  ...rest
27
- } = useFairysValtioForm(props);
31
+ } = useFairysValtioForm(props, ref);
28
32
  return (
29
33
  <FairysValtioFormInstanceContext.Provider value={formInstance}>
30
34
  <FairysPCValtioFormLayout
@@ -40,6 +44,25 @@ export function FairysPCValtioForm<T extends MObject<T> = object>(props: FairysP
40
44
  </FairysValtioFormInstanceContext.Provider>
41
45
  );
42
46
  }
47
+
48
+ export const FairysPCValtioForm = React.forwardRef(
49
+ FairysPCValtioFormBase,
50
+ ) as unknown as typeof FairysPCValtioFormBase & {
51
+ /**初始化实例*/
52
+ useForm: typeof useFairysValtioFormInstance;
53
+ /**获取状态*/
54
+ useFormState: typeof useFairysValtioFormInstanceContextState;
55
+ /**获取隐藏状态*/
56
+ useFormHideState: typeof useFairysValtioFormInstanceContextHideState;
57
+ /**获取上下文实例*/
58
+ useFormInstance: typeof useFairysValtioFormInstanceContext;
59
+ /**表单项基础组件*/
60
+ FormItemBase: typeof FairysPCValtioFormItemBase;
61
+ /**表单项组件*/
62
+ FormItem: typeof FairysPCValtioFormItem;
63
+ /**隐藏表单项组件*/
64
+ FormHideItem: typeof FairysPCValtioFormHideItem;
65
+ };
43
66
  /**初始化实例*/
44
67
  FairysPCValtioForm.useForm = useFairysValtioFormInstance;
45
68
  /**获取状态*/