@hw-component/form 1.6.6 → 1.6.8

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.
@@ -0,0 +1,10 @@
1
+ import React from "react";
2
+ import { HDialogFormInstance } from "@/components/DialogForm/modal";
3
+ interface IProps<P = any> {
4
+ contentRender?: (dom: React.ReactNode, form: HDialogFormInstance, params: P) => React.ReactNode;
5
+ dialogForm: HDialogFormInstance;
6
+ params: P;
7
+ formNode: React.ReactNode;
8
+ }
9
+ declare const Index: React.FC<IProps>;
10
+ export default Index;
@@ -0,0 +1,22 @@
1
+ // welcome to hoo hoo hoo
2
+ import { jsx, Fragment } from 'react/jsx-runtime';
3
+ import React from 'react';
4
+
5
+ var Index = function Index(_ref) {
6
+ var contentRender = _ref.contentRender,
7
+ formNode = _ref.formNode,
8
+ params = _ref.params,
9
+ dialogForm = _ref.dialogForm,
10
+ children = _ref.children;
11
+ var cuNode = children ? /*#__PURE__*/React.cloneElement(children, {
12
+ dialogForm: dialogForm,
13
+ params: params,
14
+ formNode: formNode
15
+ }) : formNode;
16
+ return jsx(Fragment, {
17
+ children: contentRender ? contentRender(cuNode, dialogForm, params) : cuNode
18
+ });
19
+ };
20
+
21
+ export { Index as default };
22
+ // powered by hdj
@@ -1,3 +1,4 @@
1
1
  import type { DialogFormProps } from "../modal";
2
- declare const _default: ({ visible, title, onCancel, configData, infoRequest, request, afterClose, dialogForm, closable, initialValues, labelWidth, onOk, onFinish, size, form, footer, params, onValuesChange, autoClear, contentRender, ...props }: DialogFormProps) => JSX.Element;
3
- export default _default;
2
+ import React from "react";
3
+ declare const Index: React.FC<DialogFormProps>;
4
+ export default Index;
@@ -16,12 +16,13 @@ import { useCurrentForm, useModifyProps, useSub } from '../hooks.js';
16
16
  import HForm from '../../Form/index.js';
17
17
  import Title from './Title.js';
18
18
  import Footer from './Footer.js';
19
- import Index, { useFormConfigContext } from '../../Form/Context/FormConfigProvider.js';
19
+ import Index$1, { useFormConfigContext } from '../../Form/Context/FormConfigProvider.js';
20
+ import Index$2 from '../ChildComponent.js';
20
21
 
21
- var _excluded = ["visible", "title", "onCancel", "configData", "infoRequest", "request", "afterClose", "dialogForm", "closable", "initialValues", "labelWidth", "onOk", "onFinish", "size", "form", "footer", "params", "onValuesChange", "autoClear", "contentRender"];
22
+ var _excluded = ["visible", "title", "onCancel", "configData", "infoRequest", "request", "afterClose", "dialogForm", "closable", "initialValues", "labelWidth", "onOk", "onFinish", "size", "form", "footer", "params", "onValuesChange", "autoClear", "contentRender", "children"];
22
23
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
23
24
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
24
- var DrawerForm = (function (_ref) {
25
+ var Index = function Index(_ref) {
25
26
  var visible = _ref.visible,
26
27
  title = _ref.title,
27
28
  onCancel = _ref.onCancel,
@@ -44,6 +45,7 @@ var DrawerForm = (function (_ref) {
44
45
  _ref$autoClear = _ref.autoClear,
45
46
  autoClear = _ref$autoClear === void 0 ? true : _ref$autoClear,
46
47
  contentRender = _ref.contentRender,
48
+ children = _ref.children,
47
49
  props = _objectWithoutProperties(_ref, _excluded);
48
50
  var currentForm = useCurrentForm(dialogForm);
49
51
  var providerConfig = useFormConfigContext();
@@ -139,11 +141,17 @@ var DrawerForm = (function (_ref) {
139
141
  closable: false,
140
142
  destroyOnClose: true,
141
143
  footer: footerComponent(),
142
- children: jsx(Index, _objectSpread(_objectSpread({}, providerConfig), {}, {
143
- children: contentRender ? contentRender(node, currentForm, params) : node
144
+ children: jsx(Index$1, _objectSpread(_objectSpread({}, providerConfig), {}, {
145
+ children: jsx(Index$2, {
146
+ dialogForm: currentForm,
147
+ contentRender: contentRender,
148
+ params: params,
149
+ formNode: node,
150
+ children: children
151
+ })
144
152
  }))
145
153
  }));
146
- });
154
+ };
147
155
 
148
- export { DrawerForm as default };
156
+ export { Index as default };
149
157
  // powered by hdj
@@ -1,3 +1,4 @@
1
1
  import type { DialogFormProps } from "./modal";
2
- declare const _default: ({ visible, title, onCancel, configData, infoRequest, request, afterClose, dialogForm, initialValues, onFinish, params, onOk, onValuesChange, autoClear, contentRender, footer, ...props }: DialogFormProps) => JSX.Element;
3
- export default _default;
2
+ import React from "react";
3
+ declare const Index: React.FC<DialogFormProps>;
4
+ export default Index;
@@ -13,13 +13,14 @@ import _regeneratorRuntime from '@babel/runtime-corejs3/regenerator';
13
13
  import { jsx } from 'react/jsx-runtime';
14
14
  import { Modal } from 'antd';
15
15
  import HForm from '../Form/index.js';
16
- import Index, { useFormConfigContext } from '../Form/Context/FormConfigProvider.js';
16
+ import Index$1, { useFormConfigContext } from '../Form/Context/FormConfigProvider.js';
17
17
  import { useCurrentForm, useModifyProps, useSub, useFooterRender } from './hooks.js';
18
+ import Index$2 from './ChildComponent.js';
18
19
 
19
- var _excluded = ["visible", "title", "onCancel", "configData", "infoRequest", "request", "afterClose", "dialogForm", "initialValues", "onFinish", "params", "onOk", "onValuesChange", "autoClear", "contentRender", "footer"];
20
+ var _excluded = ["visible", "title", "onCancel", "configData", "infoRequest", "request", "afterClose", "dialogForm", "initialValues", "onFinish", "params", "onOk", "onValuesChange", "autoClear", "contentRender", "footer", "children"];
20
21
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
21
22
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
22
- var ModalForm = (function (_ref) {
23
+ var Index = function Index(_ref) {
23
24
  var visible = _ref.visible,
24
25
  title = _ref.title,
25
26
  onCancel = _ref.onCancel,
@@ -37,6 +38,7 @@ var ModalForm = (function (_ref) {
37
38
  autoClear = _ref$autoClear === void 0 ? true : _ref$autoClear,
38
39
  contentRender = _ref.contentRender,
39
40
  footer = _ref.footer,
41
+ children = _ref.children,
40
42
  props = _objectWithoutProperties(_ref, _excluded);
41
43
  var currentForm = useCurrentForm(dialogForm);
42
44
  var providerConfig = useFormConfigContext();
@@ -126,11 +128,17 @@ var ModalForm = (function (_ref) {
126
128
  onOk: currentForm.submit,
127
129
  destroyOnClose: true,
128
130
  footer: defaultFooter,
129
- children: jsx(Index, _objectSpread(_objectSpread({}, providerConfig), {}, {
130
- children: contentRender ? contentRender === null || contentRender === void 0 ? void 0 : contentRender(node, currentForm, formParams) : node
131
+ children: jsx(Index$1, _objectSpread(_objectSpread({}, providerConfig), {}, {
132
+ children: jsx(Index$2, {
133
+ dialogForm: currentForm,
134
+ contentRender: contentRender,
135
+ formNode: node,
136
+ params: params,
137
+ children: children
138
+ })
131
139
  }))
132
140
  }));
133
- });
141
+ };
134
142
 
135
- export { ModalForm as default };
143
+ export { Index as default };
136
144
  // powered by hdj
@@ -9,12 +9,23 @@ import 'core-js/modules/es.object.get-own-property-descriptors.js';
9
9
  import _defineProperty from '@babel/runtime-corejs3/helpers/defineProperty';
10
10
  import { jsx } from 'react/jsx-runtime';
11
11
  import { useFormItemDomControl } from './hooks.js';
12
+ import { useFormContext } from '../Context/index.js';
12
13
 
13
14
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
14
15
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
15
16
  var Item = (function (props) {
17
+ var _useFormContext = useFormContext(),
18
+ formLabelWidth = _useFormContext.labelWidth,
19
+ formLabelAlign = _useFormContext.labelAlign;
20
+ var _props$labelWidth = props.labelWidth,
21
+ labelWidth = _props$labelWidth === void 0 ? formLabelWidth : _props$labelWidth,
22
+ _props$labelAlign = props.labelAlign,
23
+ labelAlign = _props$labelAlign === void 0 ? formLabelAlign : _props$labelAlign;
16
24
  var Component = useFormItemDomControl(props);
17
- return jsx(Component, _objectSpread({}, props));
25
+ return jsx(Component, _objectSpread(_objectSpread({}, props), {}, {
26
+ labelAlign: labelAlign,
27
+ labelWidth: labelWidth
28
+ }));
18
29
  });
19
30
 
20
31
  export { Item as default };
package/es/Form/index.js CHANGED
@@ -94,7 +94,9 @@ var HForm = (function (_ref) {
94
94
  value: {
95
95
  loading: submitLoading || loading,
96
96
  form: hForm,
97
- valueType: valueType
97
+ valueType: valueType,
98
+ labelAlign: formLabelAlign,
99
+ labelWidth: labelWidth
98
100
  },
99
101
  children: jsxs(Form, _objectSpread(_objectSpread({
100
102
  form: hForm,
@@ -81,6 +81,8 @@ export interface FormContextProps {
81
81
  loading?: boolean;
82
82
  form: HFormInstance;
83
83
  valueType?: string;
84
+ labelAlign?: LabelAlignModal;
85
+ labelWidth?: number;
84
86
  }
85
87
  interface ConfigUploadProps {
86
88
  exFiles?: string[];
package/es/index.d.ts CHANGED
@@ -22,8 +22,8 @@ export declare const HInputNumber: ({ style, ...props }: import("antd").InputNum
22
22
  export declare const HPageHandler: import("react").FC<import("./PageHandler/modal").IHPageHandler<any>>;
23
23
  export declare const HTextArea: ({ autoSize, ...props }: import("antd/es/input").TextAreaProps) => JSX.Element;
24
24
  export declare const HColorInput: ({ value, onChange, defaultColor, ...props }: import("./Input/modal").HInputProps<any>) => JSX.Element;
25
- export declare const HModalForm: ({ visible, title, onCancel, configData, infoRequest, request, afterClose, dialogForm, initialValues, onFinish, params, onOk, onValuesChange, autoClear, contentRender, footer, ...props }: import("./DialogForm/modal").DialogFormProps<any, any>) => JSX.Element;
26
- export declare const HDrawerForm: ({ visible, title, onCancel, configData, infoRequest, request, afterClose, dialogForm, closable, initialValues, labelWidth, onOk, onFinish, size, form, footer, params, onValuesChange, autoClear, contentRender, ...props }: import("./DialogForm/modal").DialogFormProps<any, any>) => JSX.Element;
25
+ export declare const HModalForm: import("react").FC<import("./DialogForm/modal").DialogFormProps<any, any>>;
26
+ export declare const HDrawerForm: import("react").FC<import("./DialogForm/modal").DialogFormProps<any, any>>;
27
27
  export declare const HCascader: ({ request, options, fieldNames: propsFieldNames, ...props }: import("./Cascader").HCascaderProps) => JSX.Element;
28
28
  export declare const HVerificationCodeInput: import("react").ForwardRefExoticComponent<import("./Form/modal").HFormItemProps & import("react").RefAttributes<any>>;
29
29
  export declare const HTrimInput: import("react").ForwardRefExoticComponent<import("./Form/modal").HFormItemProps & import("react").RefAttributes<any>>;
package/es/index.js CHANGED
@@ -6,8 +6,8 @@ export { default as useHForm } from './Form/hooks/useHForm.js';
6
6
  export { useHDialogForm } from './DialogForm/hooks.js';
7
7
  export { default as HFormConnect } from './Form/HFormConnect.js';
8
8
  export { default as HFormConfigProvider } from './Form/Context/FormConfigProvider.js';
9
- import ModalForm from './DialogForm/ModalForm.js';
10
- import DrawerForm from './DialogForm/DrawerForm/index.js';
9
+ import Index$1 from './DialogForm/ModalForm.js';
10
+ import Index$2 from './DialogForm/DrawerForm/index.js';
11
11
 
12
12
  var HSelect = componentConfig.select;
13
13
  var HInput = componentConfig.input;
@@ -26,8 +26,8 @@ var HInputNumber = componentConfig.inputNumber;
26
26
  var HPageHandler = Index;
27
27
  var HTextArea = componentConfig.textArea;
28
28
  var HColorInput = componentConfig.colorInput;
29
- var HModalForm = ModalForm;
30
- var HDrawerForm = DrawerForm;
29
+ var HModalForm = Index$1;
30
+ var HDrawerForm = Index$2;
31
31
  var HCascader = componentConfig.cascader;
32
32
  var HVerificationCodeInput = componentConfig.verificationCodeInput;
33
33
  var HTrimInput = componentConfig.trimInput;
@@ -0,0 +1,10 @@
1
+ import React from "react";
2
+ import { HDialogFormInstance } from "@/components/DialogForm/modal";
3
+ interface IProps<P = any> {
4
+ contentRender?: (dom: React.ReactNode, form: HDialogFormInstance, params: P) => React.ReactNode;
5
+ dialogForm: HDialogFormInstance;
6
+ params: P;
7
+ formNode: React.ReactNode;
8
+ }
9
+ declare const Index: React.FC<IProps>;
10
+ export default Index;
@@ -0,0 +1,25 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var React = require('react');
7
+
8
+ var Index = function Index(_ref) {
9
+ var contentRender = _ref.contentRender,
10
+ formNode = _ref.formNode,
11
+ params = _ref.params,
12
+ dialogForm = _ref.dialogForm,
13
+ children = _ref.children;
14
+ var cuNode = children ? /*#__PURE__*/React.cloneElement(children, {
15
+ dialogForm: dialogForm,
16
+ params: params,
17
+ formNode: formNode
18
+ }) : formNode;
19
+ return jsxRuntime.jsx(jsxRuntime.Fragment, {
20
+ children: contentRender ? contentRender(cuNode, dialogForm, params) : cuNode
21
+ });
22
+ };
23
+
24
+ exports.default = Index;
25
+ // powered by h
@@ -1,3 +1,4 @@
1
1
  import type { DialogFormProps } from "../modal";
2
- declare const _default: ({ visible, title, onCancel, configData, infoRequest, request, afterClose, dialogForm, closable, initialValues, labelWidth, onOk, onFinish, size, form, footer, params, onValuesChange, autoClear, contentRender, ...props }: DialogFormProps) => JSX.Element;
3
- export default _default;
2
+ import React from "react";
3
+ declare const Index: React.FC<DialogFormProps>;
4
+ export default Index;
@@ -20,11 +20,12 @@ var index = require('../../Form/index.js');
20
20
  var Title = require('./Title.js');
21
21
  var Footer = require('./Footer.js');
22
22
  var FormConfigProvider = require('../../Form/Context/FormConfigProvider.js');
23
+ var ChildComponent = require('../ChildComponent.js');
23
24
 
24
- var _excluded = ["visible", "title", "onCancel", "configData", "infoRequest", "request", "afterClose", "dialogForm", "closable", "initialValues", "labelWidth", "onOk", "onFinish", "size", "form", "footer", "params", "onValuesChange", "autoClear", "contentRender"];
25
+ var _excluded = ["visible", "title", "onCancel", "configData", "infoRequest", "request", "afterClose", "dialogForm", "closable", "initialValues", "labelWidth", "onOk", "onFinish", "size", "form", "footer", "params", "onValuesChange", "autoClear", "contentRender", "children"];
25
26
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
26
27
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
27
- var DrawerForm = (function (_ref) {
28
+ var Index = function Index(_ref) {
28
29
  var visible = _ref.visible,
29
30
  title = _ref.title,
30
31
  onCancel = _ref.onCancel,
@@ -47,6 +48,7 @@ var DrawerForm = (function (_ref) {
47
48
  _ref$autoClear = _ref.autoClear,
48
49
  autoClear = _ref$autoClear === void 0 ? true : _ref$autoClear,
49
50
  contentRender = _ref.contentRender,
51
+ children = _ref.children,
50
52
  props = _objectWithoutProperties(_ref, _excluded);
51
53
  var currentForm = hooks.useCurrentForm(dialogForm);
52
54
  var providerConfig = FormConfigProvider.useFormConfigContext();
@@ -143,10 +145,16 @@ var DrawerForm = (function (_ref) {
143
145
  destroyOnClose: true,
144
146
  footer: footerComponent(),
145
147
  children: jsxRuntime.jsx(FormConfigProvider.default, _objectSpread(_objectSpread({}, providerConfig), {}, {
146
- children: contentRender ? contentRender(node, currentForm, params) : node
148
+ children: jsxRuntime.jsx(ChildComponent.default, {
149
+ dialogForm: currentForm,
150
+ contentRender: contentRender,
151
+ params: params,
152
+ formNode: node,
153
+ children: children
154
+ })
147
155
  }))
148
156
  }));
149
- });
157
+ };
150
158
 
151
- exports.default = DrawerForm;
159
+ exports.default = Index;
152
160
  // powered by h
@@ -1,3 +1,4 @@
1
1
  import type { DialogFormProps } from "./modal";
2
- declare const _default: ({ visible, title, onCancel, configData, infoRequest, request, afterClose, dialogForm, initialValues, onFinish, params, onOk, onValuesChange, autoClear, contentRender, footer, ...props }: DialogFormProps) => JSX.Element;
3
- export default _default;
2
+ import React from "react";
3
+ declare const Index: React.FC<DialogFormProps>;
4
+ export default Index;
@@ -18,11 +18,12 @@ var antd = require('antd');
18
18
  var index = require('../Form/index.js');
19
19
  var FormConfigProvider = require('../Form/Context/FormConfigProvider.js');
20
20
  var hooks = require('./hooks.js');
21
+ var ChildComponent = require('./ChildComponent.js');
21
22
 
22
- var _excluded = ["visible", "title", "onCancel", "configData", "infoRequest", "request", "afterClose", "dialogForm", "initialValues", "onFinish", "params", "onOk", "onValuesChange", "autoClear", "contentRender", "footer"];
23
+ var _excluded = ["visible", "title", "onCancel", "configData", "infoRequest", "request", "afterClose", "dialogForm", "initialValues", "onFinish", "params", "onOk", "onValuesChange", "autoClear", "contentRender", "footer", "children"];
23
24
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
24
25
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
25
- var ModalForm = (function (_ref) {
26
+ var Index = function Index(_ref) {
26
27
  var visible = _ref.visible,
27
28
  title = _ref.title,
28
29
  onCancel = _ref.onCancel,
@@ -40,6 +41,7 @@ var ModalForm = (function (_ref) {
40
41
  autoClear = _ref$autoClear === void 0 ? true : _ref$autoClear,
41
42
  contentRender = _ref.contentRender,
42
43
  footer = _ref.footer,
44
+ children = _ref.children,
43
45
  props = _objectWithoutProperties(_ref, _excluded);
44
46
  var currentForm = hooks.useCurrentForm(dialogForm);
45
47
  var providerConfig = FormConfigProvider.useFormConfigContext();
@@ -130,10 +132,16 @@ var ModalForm = (function (_ref) {
130
132
  destroyOnClose: true,
131
133
  footer: defaultFooter,
132
134
  children: jsxRuntime.jsx(FormConfigProvider.default, _objectSpread(_objectSpread({}, providerConfig), {}, {
133
- children: contentRender ? contentRender === null || contentRender === void 0 ? void 0 : contentRender(node, currentForm, formParams) : node
135
+ children: jsxRuntime.jsx(ChildComponent.default, {
136
+ dialogForm: currentForm,
137
+ contentRender: contentRender,
138
+ formNode: node,
139
+ params: params,
140
+ children: children
141
+ })
134
142
  }))
135
143
  }));
136
- });
144
+ };
137
145
 
138
- exports.default = ModalForm;
146
+ exports.default = Index;
139
147
  // powered by h
@@ -12,12 +12,23 @@ require('core-js/modules/es.object.get-own-property-descriptors.js');
12
12
  var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
13
13
  var jsxRuntime = require('react/jsx-runtime');
14
14
  var hooks = require('./hooks.js');
15
+ var index = require('../Context/index.js');
15
16
 
16
17
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
17
18
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
18
19
  var Item = (function (props) {
20
+ var _useFormContext = index.useFormContext(),
21
+ formLabelWidth = _useFormContext.labelWidth,
22
+ formLabelAlign = _useFormContext.labelAlign;
23
+ var _props$labelWidth = props.labelWidth,
24
+ labelWidth = _props$labelWidth === void 0 ? formLabelWidth : _props$labelWidth,
25
+ _props$labelAlign = props.labelAlign,
26
+ labelAlign = _props$labelAlign === void 0 ? formLabelAlign : _props$labelAlign;
19
27
  var Component = hooks.useFormItemDomControl(props);
20
- return jsxRuntime.jsx(Component, _objectSpread({}, props));
28
+ return jsxRuntime.jsx(Component, _objectSpread(_objectSpread({}, props), {}, {
29
+ labelAlign: labelAlign,
30
+ labelWidth: labelWidth
31
+ }));
21
32
  });
22
33
 
23
34
  exports.default = Item;
package/lib/Form/index.js CHANGED
@@ -97,7 +97,9 @@ var HForm = (function (_ref) {
97
97
  value: {
98
98
  loading: submitLoading || loading,
99
99
  form: hForm,
100
- valueType: valueType
100
+ valueType: valueType,
101
+ labelAlign: formLabelAlign,
102
+ labelWidth: labelWidth
101
103
  },
102
104
  children: jsxRuntime.jsxs(antd.Form, _objectSpread(_objectSpread({
103
105
  form: hForm,
@@ -81,6 +81,8 @@ export interface FormContextProps {
81
81
  loading?: boolean;
82
82
  form: HFormInstance;
83
83
  valueType?: string;
84
+ labelAlign?: LabelAlignModal;
85
+ labelWidth?: number;
84
86
  }
85
87
  interface ConfigUploadProps {
86
88
  exFiles?: string[];
package/lib/index.d.ts CHANGED
@@ -22,8 +22,8 @@ export declare const HInputNumber: ({ style, ...props }: import("antd").InputNum
22
22
  export declare const HPageHandler: import("react").FC<import("./PageHandler/modal").IHPageHandler<any>>;
23
23
  export declare const HTextArea: ({ autoSize, ...props }: import("antd/es/input").TextAreaProps) => JSX.Element;
24
24
  export declare const HColorInput: ({ value, onChange, defaultColor, ...props }: import("./Input/modal").HInputProps<any>) => JSX.Element;
25
- export declare const HModalForm: ({ visible, title, onCancel, configData, infoRequest, request, afterClose, dialogForm, initialValues, onFinish, params, onOk, onValuesChange, autoClear, contentRender, footer, ...props }: import("./DialogForm/modal").DialogFormProps<any, any>) => JSX.Element;
26
- export declare const HDrawerForm: ({ visible, title, onCancel, configData, infoRequest, request, afterClose, dialogForm, closable, initialValues, labelWidth, onOk, onFinish, size, form, footer, params, onValuesChange, autoClear, contentRender, ...props }: import("./DialogForm/modal").DialogFormProps<any, any>) => JSX.Element;
25
+ export declare const HModalForm: import("react").FC<import("./DialogForm/modal").DialogFormProps<any, any>>;
26
+ export declare const HDrawerForm: import("react").FC<import("./DialogForm/modal").DialogFormProps<any, any>>;
27
27
  export declare const HCascader: ({ request, options, fieldNames: propsFieldNames, ...props }: import("./Cascader").HCascaderProps) => JSX.Element;
28
28
  export declare const HVerificationCodeInput: import("react").ForwardRefExoticComponent<import("./Form/modal").HFormItemProps & import("react").RefAttributes<any>>;
29
29
  export declare const HTrimInput: import("react").ForwardRefExoticComponent<import("./Form/modal").HFormItemProps & import("react").RefAttributes<any>>;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@hw-component/form",
3
- "version": "1.6.6",
3
+ "version": "1.6.8",
4
4
  "description": "基于antd二次开发",
5
5
  "repository": {
6
6
  "type": "git",
@@ -0,0 +1,20 @@
1
+ import React from "react";
2
+ import {HDialogFormInstance} from "@/components/DialogForm/modal";
3
+
4
+ interface IProps<P=any> {
5
+ contentRender?: (
6
+ dom: React.ReactNode,
7
+ form: HDialogFormInstance,
8
+ params: P
9
+ ) => React.ReactNode;
10
+ dialogForm:HDialogFormInstance;
11
+ params:P;
12
+ formNode:React.ReactNode
13
+ }
14
+ const Index:React.FC<IProps>=({contentRender,formNode,params,dialogForm,children})=>{
15
+ const cuNode=children?React.cloneElement((children as any),{dialogForm,params,formNode}):formNode;
16
+ return <>{contentRender?contentRender(cuNode,dialogForm,params):cuNode}</>;
17
+ }
18
+
19
+
20
+ export default Index;
@@ -7,29 +7,32 @@ import Footer from "./Footer";
7
7
  import FormConfigProvider, {
8
8
  useFormConfigContext,
9
9
  } from "../../Form/Context/FormConfigProvider";
10
- export default ({
11
- visible,
12
- title,
13
- onCancel,
14
- configData,
15
- infoRequest,
16
- request,
17
- afterClose,
18
- dialogForm,
19
- closable = true,
20
- initialValues,
21
- labelWidth,
22
- onOk,
23
- onFinish,
24
- size,
25
- form,
26
- footer,
27
- params,
28
- onValuesChange,
29
- autoClear = true,
30
- contentRender,
31
- ...props
32
- }: DialogFormProps) => {
10
+ import React from "react";
11
+ import ChildComponent from '../ChildComponent'
12
+ const Index:React.FC<DialogFormProps>=({
13
+ visible,
14
+ title,
15
+ onCancel,
16
+ configData,
17
+ infoRequest,
18
+ request,
19
+ afterClose,
20
+ dialogForm,
21
+ closable = true,
22
+ initialValues,
23
+ labelWidth,
24
+ onOk,
25
+ onFinish,
26
+ size,
27
+ form,
28
+ footer,
29
+ params,
30
+ onValuesChange,
31
+ autoClear = true,
32
+ contentRender,
33
+ children,
34
+ ...props
35
+ }: DialogFormProps) => {
33
36
  const currentForm = useCurrentForm(dialogForm);
34
37
  const providerConfig = useFormConfigContext();
35
38
  const {
@@ -64,48 +67,56 @@ export default ({
64
67
  return null;
65
68
  }
66
69
  return (
67
- footer || (
68
- <Footer
69
- onCancel={cancel}
70
- onOk={currentForm.submit}
71
- confirmLoading={loading}
72
- />
73
- )
70
+ footer || (
71
+ <Footer
72
+ onCancel={cancel}
73
+ onOk={currentForm.submit}
74
+ confirmLoading={loading}
75
+ />
76
+ )
74
77
  );
75
78
  };
76
79
  const node = (
77
- <HForm
78
- configData={modalFormData}
79
- initialValues={initValue}
80
- onValuesChange={onValuesChange}
81
- {...props}
82
- form={currentForm}
83
- params={formParams}
84
- onFinish={async (values, subParams) => {
85
- const result = await run(values, subParams);
86
- const close = onOk?.(result, subParams);
87
- if (close === false) {
88
- return;
89
- }
90
- cancel();
91
- }}
92
- infoRequest={infoRequest}
93
- labelWidth={labelWidth}
94
- />
80
+ <HForm
81
+ configData={modalFormData}
82
+ initialValues={initValue}
83
+ onValuesChange={onValuesChange}
84
+ {...props}
85
+ form={currentForm}
86
+ params={formParams}
87
+ onFinish={async (values, subParams) => {
88
+ const result = await run(values, subParams);
89
+ const close = onOk?.(result, subParams);
90
+ if (close === false) {
91
+ return;
92
+ }
93
+ cancel();
94
+ }}
95
+ infoRequest={infoRequest}
96
+ labelWidth={labelWidth}
97
+ />
95
98
  );
96
99
  return (
97
- <Drawer
98
- visible={modalVisible}
99
- title={<Title title={modalTitle} closable={closable} onCancel={cancel} />}
100
- {...props}
101
- onClose={cancel}
102
- closable={false}
103
- destroyOnClose={true}
104
- footer={footerComponent()}
105
- >
106
- <FormConfigProvider {...providerConfig}>
107
- {contentRender ? contentRender(node, currentForm, params) : node}
108
- </FormConfigProvider>
109
- </Drawer>
100
+ <Drawer
101
+ visible={modalVisible}
102
+ title={<Title title={modalTitle} closable={closable} onCancel={cancel} />}
103
+ {...props}
104
+ onClose={cancel}
105
+ closable={false}
106
+ destroyOnClose={true}
107
+ footer={footerComponent()}
108
+ >
109
+ <FormConfigProvider {...providerConfig}>
110
+ <ChildComponent dialogForm={currentForm}
111
+ contentRender={contentRender}
112
+ params={params}
113
+ formNode={node}
114
+ >
115
+ {children}
116
+ </ChildComponent>
117
+ </FormConfigProvider>
118
+ </Drawer>
110
119
  );
111
120
  };
121
+
122
+ export default Index;
@@ -10,27 +10,31 @@ import {
10
10
  useModifyProps,
11
11
  useSub,
12
12
  } from "./hooks";
13
- export default ({
14
- visible,
15
- title,
16
- onCancel,
17
- configData,
18
- infoRequest,
19
- request,
20
- afterClose,
21
- dialogForm,
22
- initialValues,
23
- onFinish,
24
- params,
25
- onOk,
26
- onValuesChange,
27
- autoClear = true,
28
- contentRender,
29
- footer,
30
- ...props
31
- }: DialogFormProps) => {
13
+ import ChildComponent from './ChildComponent'
14
+ import React from "react";
15
+ const Index:React.FC<DialogFormProps>= ({
16
+ visible,
17
+ title,
18
+ onCancel,
19
+ configData,
20
+ infoRequest,
21
+ request,
22
+ afterClose,
23
+ dialogForm,
24
+ initialValues,
25
+ onFinish,
26
+ params,
27
+ onOk,
28
+ onValuesChange,
29
+ autoClear = true,
30
+ contentRender,
31
+ footer,
32
+ children,
33
+ ...props
34
+ }) => {
32
35
  const currentForm = useCurrentForm(dialogForm);
33
36
  const providerConfig = useFormConfigContext();
37
+
34
38
  const {
35
39
  modalVisible,
36
40
  modalFormData,
@@ -55,23 +59,23 @@ export default ({
55
59
  };
56
60
  const { loading, run } = useSub({ request, onFinish });
57
61
  const node = (
58
- <HForm
59
- configData={modalFormData}
60
- initialValues={initValue}
61
- onValuesChange={onValuesChange}
62
- onFinish={async (values, outParams) => {
63
- const result = await run(values, outParams);
64
- const close = onOk?.(result, outParams);
65
- if (close === false) {
66
- return;
67
- }
68
- cancel();
69
- }}
70
- {...props}
71
- params={formParams}
72
- form={currentForm}
73
- infoRequest={infoRequest}
74
- />
62
+ <HForm
63
+ configData={modalFormData}
64
+ initialValues={initValue}
65
+ onValuesChange={onValuesChange}
66
+ onFinish={async (values, outParams) => {
67
+ const result = await run(values, outParams);
68
+ const close = onOk?.(result, outParams);
69
+ if (close === false) {
70
+ return;
71
+ }
72
+ cancel();
73
+ }}
74
+ {...props}
75
+ params={formParams}
76
+ form={currentForm}
77
+ infoRequest={infoRequest}
78
+ />
75
79
  );
76
80
  const defaultFooter = useFooterRender({
77
81
  dialogForm,
@@ -79,27 +83,33 @@ export default ({
79
83
  confirmLoading: loading,
80
84
  params: formParams,
81
85
  });
82
-
83
86
  return (
84
- <Modal
85
- title={modalTitle}
86
- visible={modalVisible}
87
- onCancel={cancel}
88
- confirmLoading={loading}
89
- afterClose={() => {
90
- if (autoClear) {
91
- currentForm.clear();
92
- }
93
- afterClose?.();
94
- }}
95
- {...props}
96
- onOk={currentForm.submit}
97
- destroyOnClose={true}
98
- footer={defaultFooter}
99
- >
100
- <FormConfigProvider {...providerConfig}>
101
- {contentRender ? contentRender?.(node, currentForm, formParams) : node}
102
- </FormConfigProvider>
103
- </Modal>
87
+ <Modal
88
+ title={modalTitle}
89
+ visible={modalVisible}
90
+ onCancel={cancel}
91
+ confirmLoading={loading}
92
+ afterClose={() => {
93
+ if (autoClear) {
94
+ currentForm.clear();
95
+ }
96
+ afterClose?.();
97
+ }}
98
+ {...props}
99
+ onOk={currentForm.submit}
100
+ destroyOnClose={true}
101
+ footer={defaultFooter}
102
+ >
103
+ <FormConfigProvider {...providerConfig}>
104
+ <ChildComponent dialogForm={currentForm}
105
+ contentRender={contentRender}
106
+ formNode={node}
107
+ params={params}>
108
+ {children}
109
+ </ChildComponent>
110
+ </FormConfigProvider>
111
+ </Modal>
104
112
  );
105
113
  };
114
+
115
+ export default Index;
@@ -1,8 +1,11 @@
1
1
  import { useFormItemDomControl } from "./hooks";
2
2
  import React from "react";
3
3
  import type { HItemProps } from "../modal";
4
+ import {useFormContext} from "../Context";
4
5
 
5
6
  export default (props: HItemProps) => {
7
+ const {labelWidth:formLabelWidth,labelAlign:formLabelAlign}=useFormContext();
8
+ const {labelWidth=formLabelWidth,labelAlign=formLabelAlign}=props;
6
9
  const Component = useFormItemDomControl(props);
7
- return <Component {...props} />;
10
+ return <Component {...props} labelAlign={labelAlign} labelWidth={labelWidth}/>;
8
11
  };
@@ -73,7 +73,12 @@ export default ({
73
73
  reload={infoRun}
74
74
  >
75
75
  <FormContext.Provider
76
- value={{ loading: submitLoading || loading, form: hForm, valueType }}
76
+ value={{
77
+ loading: submitLoading || loading,
78
+ form: hForm, valueType ,
79
+ labelAlign:formLabelAlign,
80
+ labelWidth
81
+ }}
77
82
  >
78
83
  <Form
79
84
  form={hForm}
@@ -130,6 +130,8 @@ export interface FormContextProps {
130
130
  loading?: boolean;
131
131
  form: HFormInstance;
132
132
  valueType?: string;
133
+ labelAlign?:LabelAlignModal;
134
+ labelWidth?:number
133
135
  }
134
136
  interface ConfigUploadProps {
135
137
  exFiles?: string[];
@@ -1,6 +1,7 @@
1
1
  import { Button } from "antd";
2
2
  import { HDrawerForm, useHDialogForm } from "../../components";
3
3
  import { MediaTypeEnum } from "../../components/Upload/enums";
4
+ import {useEffect} from "react";
4
5
  const data = [
5
6
  {
6
7
  label: "选择",
@@ -56,6 +57,15 @@ const data = [
56
57
  },
57
58
  ];
58
59
  let num = 0;
60
+ const Test1=({formNode,dialogForm,params})=>{
61
+ useEffect(() => {
62
+ console.log("渲染")
63
+ }, []);
64
+ return <div>
65
+ <div>测试一些</div>
66
+ {formNode}
67
+ </div>
68
+ }
59
69
  export default () => {
60
70
  const modalForm = useHDialogForm();
61
71
  return (
@@ -98,14 +108,20 @@ export default () => {
98
108
  labelWidth={88}
99
109
  labelAlign={"left"}
100
110
  dialogForm={modalForm}
111
+ request={(values)=>{
112
+ console.log(values)
113
+ }}
101
114
  afterClose={() => {
102
115
  console.log("afterClose");
103
116
  }}
104
117
  contentRender={(node) => {
118
+ console.log("contentRender");
105
119
  return <div>{node}</div>;
106
120
  }}
107
121
  title="测试"
108
- />
122
+ >
123
+ <Test1/>
124
+ </HDrawerForm>
109
125
  </>
110
126
  );
111
127
  };
@@ -5,7 +5,7 @@ import {
5
5
  HFormConfigProvider,
6
6
  HUrlUpload,
7
7
  } from "../../components";
8
- import { useState } from "react";
8
+ import {useEffect, useState} from "react";
9
9
  import { ShowParamsModal } from "@/components/DialogForm/modal";
10
10
 
11
11
  const Test = (props) => {
@@ -144,6 +144,15 @@ const data = [
144
144
  },
145
145
  ];
146
146
  let num = 0;
147
+ const Test1=({formNode})=>{
148
+ useEffect(() => {
149
+ console.log("渲染")
150
+ }, []);
151
+ return <div>
152
+ <div>测试一些</div>
153
+ {formNode}
154
+ </div>
155
+ }
147
156
  export default () => {
148
157
  const modalForm = useHDialogForm();
149
158
  return (
@@ -190,33 +199,14 @@ export default () => {
190
199
  configData={data}
191
200
  labelWidth={88}
192
201
  labelAlign={"left"}
193
- footer={(dialogForm, loading, params = {}) => {
194
- const { name } = params;
195
- return (
196
- <Button
197
- loading={loading}
198
- onClick={() => {
199
- dialogForm?.submit();
200
- }}
201
- >
202
- {name}
203
- </Button>
204
- );
205
- }}
206
202
  request={(values, params) => {
207
203
  console.log(values, params);
208
204
  }}
209
- contentRender={(node, form) => {
210
- return (
211
- <div>
212
- <div>测试一些</div>
213
- {node}
214
- </div>
215
- );
216
- }}
217
205
  dialogForm={modalForm}
218
206
  title={<div>fff</div>}
219
- />
207
+ >
208
+ <Test1/>
209
+ </HModalForm>
220
210
  </HFormConfigProvider>
221
211
  </>
222
212
  );
@@ -46,18 +46,18 @@ export default () => {
46
46
  labelInValue
47
47
  mode="multiple"
48
48
  value={["21321312"]}
49
- request={(params) => {
49
+ request={async (params) => {
50
50
  const { page, size } = params;
51
51
  const op = [];
52
52
  for (let i = 0; i < size; i += 1) {
53
53
  op.push({ label: `第${page}页第${i}条`, value: i + page });
54
54
  }
55
- return {
56
- page,
57
- size: 100,
58
- total: 1000,
59
- data: op,
60
- };
55
+ return Promise.resolve({
56
+ page,
57
+ size: 100,
58
+ total: 1000,
59
+ data: op,
60
+ })
61
61
  }}
62
62
  isList
63
63
  />