@flatbiz/antd 3.2.0 → 4.0.2

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/index.d.ts CHANGED
@@ -3,14 +3,16 @@
3
3
 
4
4
  import { API, ModelType } from '@dimjs/model';
5
5
  import { ButtonProps, CascaderProps, DrawerProps, DropdownProps, FormInstance, FormItemProps, InputNumberProps, InputProps, ModalProps, PopconfirmProps, RadioGroupProps, RowProps, SelectProps, SpaceProps, SwitchProps, TableProps, TimePickerProps, TimeRangePickerProps, TooltipProps, TreeProps, TreeSelectProps, UploadProps } from 'antd';
6
+ import { ConfigProviderProps } from 'antd/es/config-provider';
7
+ import { PickerDateProps } from 'antd/es/date-picker/generatePicker';
6
8
  import { CheckboxGroupProps } from 'antd/lib/checkbox';
7
- import { ConfigProviderProps } from 'antd/lib/config-provider';
8
- import { PickerDateProps, RangePickerDateProps } from 'antd/lib/date-picker/generatePicker';
9
+ import { RangePickerDateProps } from 'antd/lib/date-picker/generatePicker';
9
10
  import { FormListFieldData, FormListOperation, FormListProps } from 'antd/lib/form/FormList';
10
11
  import { SearchProps, TextAreaProps } from 'antd/lib/input';
11
12
  import { ColumnsType } from 'antd/lib/table';
12
13
  import { UploadChangeParam } from 'antd/lib/upload';
13
14
  import { UploadFile } from 'antd/lib/upload/interface';
15
+ import dayjs from 'dayjs';
14
16
  import { CSSProperties, DependencyList, Dispatch, EffectCallback, FC, ReactElement, ReactNode, SetStateAction } from 'react';
15
17
 
16
18
  export declare const styles: () => void;
@@ -28,7 +30,7 @@ export interface ButtonOperateItem extends ButtonProps {
28
30
  export interface ButtonOperateProps {
29
31
  /**
30
32
  * 如果数组中使用ReactElement类型
31
- * 1. 一般为antd Button组件,可设置type=link,会有设置的hover效果
33
+ * 1. 一般为antd Button组件,如果组件存在属性hidden=true,则会隐藏
32
34
  * 2. 可配置 v-permission 权限值,例如 v-permission="add"
33
35
  * 3. 任何confirm、disabled等状态在外部控制
34
36
  * 3. 不支持fold效果
@@ -42,7 +44,7 @@ export interface ButtonOperateProps {
42
44
  }
43
45
  export declare const ButtonOperate: FC<ButtonOperateProps>;
44
46
  export declare type ButtonWrapperProps = Omit<ButtonProps, "onClick" | "loading"> & {
45
- onClick: (event: React.MouseEvent<HTMLElement>) => Promise<void> | void;
47
+ onClick: (e: any) => Promise<void> | void;
46
48
  debounceDuration?: number;
47
49
  permission?: string;
48
50
  };
@@ -118,6 +120,10 @@ export declare const CascaderWrapper: import("react").ForwardRefExoticComponent<
118
120
  onChange?: ((value: string | number, selectedList: TPlainObject[]) => void) | undefined;
119
121
  requestMessageConfig?: RequestStatusRenderProps["messageConfig"];
120
122
  } & import("react").RefAttributes<CascaderWrapperRefApi>>;
123
+ export declare type ConfigProviderWrapperProps = Omit<ConfigProviderProps, "locale"> & {
124
+ locale?: "en" | "zh-cn";
125
+ };
126
+ export declare const ConfigProviderWrapper: (props: ConfigProviderWrapperProps) => JSX.Element;
121
127
  export interface CommonPropsWithChildren<S extends TPlainObject = TPlainObject> {
122
128
  className?: string;
123
129
  style?: CSSProperties & Partial<S>;
@@ -139,7 +145,7 @@ export declare type CssHoverProps = {
139
145
  * @returns
140
146
  */
141
147
  export declare const CssNodeHover: (props: CssHoverProps) => JSX.Element;
142
- export declare type DatePickerWrapperProps = Omit<PickerDateProps<moment.Moment>, "value" | "onChange"> & {
148
+ export declare type DatePickerWrapperProps = Omit<PickerDateProps<dayjs.Dayjs>, "value" | "onChange"> & {
143
149
  value?: string;
144
150
  onChange?: (value?: string) => void;
145
151
  /**
@@ -161,7 +167,7 @@ export declare type DatePickerWrapperProps = Omit<PickerDateProps<moment.Moment>
161
167
  * ```
162
168
  */
163
169
  export declare const DatePickerWrapper: (props: DatePickerWrapperProps) => JSX.Element;
164
- export declare type DateRangePickerWrapperProps = Omit<RangePickerDateProps<moment.Moment>, "value" | "onChange" | "onOpenChange" | "onCalendarChange" | "disabledDate"> & {
170
+ export declare type DateRangePickerWrapperProps = Omit<RangePickerDateProps<dayjs.Dayjs>, "value" | "onChange" | "onOpenChange" | "onCalendarChange" | "disabledDate"> & {
165
171
  value?: [
166
172
  string,
167
173
  string
@@ -218,7 +224,7 @@ export declare type DateRangePickerWrapperFormItemProps = Omit<FormItemProps, "n
218
224
  * ```
219
225
  */
220
226
  export declare const DateRangePickerWrapperFormItem: (props: DateRangePickerWrapperFormItemProps) => JSX.Element;
221
- export declare type DialogDrawerProps = Omit<DrawerProps, "onOk" | "onCancel" | "getContainer" | "visible" | "open" | "footer"> & {
227
+ export declare type DialogDrawerProps = Omit<DrawerProps, "onOk" | "onCancel" | "getContainer" | "open" | "open" | "footer"> & {
222
228
  okText?: string | ReactElement;
223
229
  cancelText?: string | ReactElement;
224
230
  onOk?: (form: FormInstance, e: React.MouseEvent<HTMLElement>) => void | Promise<void>;
@@ -226,7 +232,7 @@ export declare type DialogDrawerProps = Omit<DrawerProps, "onOk" | "onCancel" |
226
232
  content: string | ReactElement | ((form: FormInstance, operate: {
227
233
  onClose: TNoopDefine;
228
234
  }) => ReactElement);
229
- configProviderProps?: ConfigProviderProps;
235
+ configProviderProps?: ConfigProviderWrapperProps;
230
236
  okButtonExtraProps?: Omit<ButtonProps, "onClick" | "children" | "loading">;
231
237
  cancelButtonExtraProps?: Omit<ButtonProps, "onClick" | "children">;
232
238
  operatePosition?: "header" | "footer";
@@ -269,13 +275,13 @@ export declare const dialogDrawer: {
269
275
  close: () => void;
270
276
  };
271
277
  };
272
- export declare type DialogModalProps = Omit<ModalProps, "onOk" | "onCancel" | "getContainer" | "visible" | "open"> & {
278
+ export declare type DialogModalProps = Omit<ModalProps, "onOk" | "onCancel" | "getContainer" | "open" | "open"> & {
273
279
  onOk?: (form: FormInstance, e: React.MouseEvent<HTMLElement>) => void | Promise<void>;
274
280
  onCancel?: (form: FormInstance, e: React.MouseEvent<HTMLElement>) => void | Promise<void>;
275
281
  content: string | ReactElement | ((form: FormInstance, operate: {
276
282
  onClose: TNoopDefine;
277
283
  }) => ReactElement);
278
- configProviderProps?: ConfigProviderProps;
284
+ configProviderProps?: ConfigProviderWrapperProps;
279
285
  };
280
286
  /**
281
287
  * 函数式调用弹框;初始化后,内容无法更新
@@ -317,63 +323,7 @@ export interface DrawerStateType {
317
323
  /**
318
324
  * 显示drawer
319
325
  */
320
- visible: boolean;
321
- /**
322
- * 用来处理form, `更新`的时候的传递当前item列表行的数据, 当`创建`的时候强制设置为 `undefined`
323
- */
324
- itemData?: Record<string, any>;
325
- operateType: "create" | "update" | "view" | null;
326
- pageLoading?: boolean;
327
- }
328
- export interface DrawerActionsParamType {
329
- openDrawerForm: Pick<DrawerStateType, "title" | "itemData" | "operateType" | "pageLoading">;
330
- closeDrawer: void;
331
- setDrawerItemData: Record<string, any>;
332
- }
333
- export interface DrawerOperationOldProps {
334
- loading?: boolean;
335
- okText?: string;
336
- cancelText?: string;
337
- onOk?: () => void;
338
- onCancel?: () => void;
339
- hideOkBtn?: boolean;
340
- okButtonProps?: Omit<ButtonProps, "onClick" | "loading" | "className">;
341
- cancelButtonProps?: Omit<ButtonProps, "onClick" | "loading" | "className">;
342
- }
343
- export declare type DrawerFormProps = {
344
- className?: string;
345
- /**
346
- * 整个drawer页面级的spinning <Page loading />
347
- */
348
- pageLoading?: boolean;
349
- operationProps?: DrawerOperationOldProps;
350
- } & DrawerProps;
351
- /**
352
- * 弹窗机制
353
- * @deprecated 请使用【dialogDrawer】组件替换
354
- * ```
355
- * 1. 默认 destroyOnClose = true
356
- * 2. 默认 forceRender = false
357
- * ```
358
- */
359
- export declare const DrawerWraper: (props: DrawerFormProps) => JSX.Element;
360
- /**
361
- * drawer弹窗模型
362
- * @param key 唯一值必传
363
- * @returns
364
- *
365
- * ```
366
- * 使用方式
367
- * const [drawerState, drawerActions] = createDrawerWraperModel('key值').useStore();
368
- * ```
369
- */
370
- export declare const createDrawerWraperModel: (key: string) => API<ModelType<DrawerStateType, DrawerActionsParamType, any>>;
371
- export interface DrawerStateType {
372
- title: string;
373
- /**
374
- * 显示drawer
375
- */
376
- visible: boolean;
326
+ open: boolean;
377
327
  /**
378
328
  * 用来处理form, `更新`的时候的传递当前item列表行的数据, 当`创建`的时候强制设置为 `undefined`
379
329
  */
@@ -447,7 +397,7 @@ export interface DropdownMenuItem extends ButtonProps {
447
397
  hidden?: boolean;
448
398
  popconfirmProps?: Pick<PopconfirmProps, "placement" | "okText" | "cancelText" | "trigger">;
449
399
  }
450
- export interface DropdownMenuWrapperProps extends Omit<DropdownProps, "overlay"> {
400
+ export interface DropdownMenuWrapperProps extends Omit<DropdownProps, "menu"> {
451
401
  menuList: Array<DropdownMenuItem | null>;
452
402
  }
453
403
  export declare const DropdownMenuWrapper: (props: DropdownMenuWrapperProps) => JSX.Element;
@@ -462,7 +412,9 @@ export declare type SelectorServiceConfig = {
462
412
  */
463
413
  onRequestResultAdapter?: (respData: TAny) => TPlainObject[];
464
414
  };
465
- export declare type SelectorWrapperProps = Omit<SelectProps, "filterOption" | "onSearch" | "notFoundContent" | "options" | "fieldNames" | "onChange" | "value" | "loading"> & {
415
+ export declare type SelectorWrapperProps = Omit<SelectProps, "filterOption" | "onSearch" | "notFoundContent" | "options" | "fieldNames" | "onChange" | "value" | "loading" | "mode"> & {
416
+ /** 不支持 tags 模式,tags模式请使用antd Select 组件 */
417
+ mode?: "multiple";
466
418
  modelKey: string;
467
419
  fieldNames?: {
468
420
  label: string;
@@ -661,6 +613,7 @@ export declare type EditableCustomConfig = {
661
613
  name: Array<number | string>;
662
614
  editable?: boolean;
663
615
  completeName: Array<number | string>;
616
+ tableRowIndex: number;
664
617
  }) => ReactElement;
665
618
  };
666
619
  export declare type EditableTypeConfig = EditableCustomConfig | EditableInputConfig | EditableSelectWrapperConfig | EditableDatePickerWrapperConfig | EditableDateRangePickerWrapperConfig | EditableCheckboxGroupConfig | EditableTextareaConfig | EditableInputNumberConfig | EditableRadioGroupConfig | EditableFileUploadConfig;
@@ -792,49 +745,6 @@ export declare const FileImport: {
792
745
  accept: string;
793
746
  };
794
747
  };
795
- export declare type FileUploadItem = {
796
- fileKey: string;
797
- fileName: string;
798
- };
799
- export declare type FileUploadProps = {
800
- onChange?: (value?: FileUploadItem[]) => void;
801
- onUploadError?: (message?: string) => void;
802
- value?: FileUploadItem[];
803
- onPreview?: (item: FileUploadItem) => void;
804
- onUploadChange?: (info: UploadChangeParam<UploadFile>) => void;
805
- /**
806
- * 属性映射
807
- */
808
- fieldNames?: {
809
- fileKey?: string;
810
- fileName?: string;
811
- };
812
- } & Omit<UploadProps, "onChange" | "fileList" | "onPreview">;
813
- /**
814
- * 文件上传,结合Form使用最佳
815
- * @deprecated 请使用【UploadWrapper】组件替换
816
- * ```
817
- * 接口返回结构:
818
- * formData上传接口必须返回fileKey值
819
- * {
820
- * code: '0000',
821
- * data: {
822
- * fileKey: '预览文件对应的fileKey'
823
- * }
824
- * }
825
- * 可通过fieldNames配置接口返回值属性名称映射
826
- * ```
827
- * ```
828
- * 最佳使用方式:
829
- * <Form.Item name="attachmentList" label="附件">
830
- * <FileUpload action={uploadUrl} onPreview={onPreviewFile}>
831
- * <Button type="primary">选择文件导入</Button>
832
- * </FileUpload>
833
- * </Form.Item>
834
- * ```
835
- *
836
- */
837
- export declare const FileUpload: (props: FileUploadProps) => JSX.Element;
838
748
  export declare type FlexLayoutProps = {
839
749
  className?: string;
840
750
  fullIndex?: number | number[];
@@ -1033,61 +943,7 @@ export interface ModalStateType {
1033
943
  /**
1034
944
  * 显示modal
1035
945
  */
1036
- visible: boolean;
1037
- /**
1038
- * 用来处理form, `更新`的时候的传递当前item列表行的数据, 当`创建`的时候强制设置为 `undefined`
1039
- */
1040
- itemData?: Record<string, unknown> | null;
1041
- operateType: "create" | "update" | "view";
1042
- pageLoading?: boolean;
1043
- }
1044
- export interface ModalActionsParamType {
1045
- openModalForm: Pick<ModalStateType, "title" | "itemData" | "operateType" | "pageLoading">;
1046
- closeModal: void;
1047
- setModalItemData: Record<string, unknown>;
1048
- }
1049
- export interface ModalOperationProps {
1050
- loading?: boolean;
1051
- okText?: string;
1052
- cancelText?: string;
1053
- onOk?: () => void;
1054
- onCancel?: () => void;
1055
- hideOkBtn?: boolean;
1056
- okButtonProps?: Omit<ButtonProps, "onClick" | "loading" | "className">;
1057
- cancelButtonProps?: Omit<ButtonProps, "onClick" | "loading" | "className">;
1058
- }
1059
- export declare type ModalFormProps = {
1060
- className?: string;
1061
- pageLoading?: boolean;
1062
- operationProps?: ModalOperationProps;
1063
- footer?: null | React.ReactNode;
1064
- } & Omit<ModalProps, "footer" | "onOk" | "okText" | "cancelText" | "okButtonProps" | "cancelButtonProps" | "okType" | "confirmLoading">;
1065
- /**
1066
- * 弹窗机制
1067
- * ```
1068
- * 1. 默认 destroyOnClose = true
1069
- * 2. 默认 forceRender = false
1070
- * @deprecated 请使用【dialogModal】组件替换
1071
- * ```
1072
- */
1073
- export declare const ModalWraper: (props: ModalFormProps) => JSX.Element;
1074
- /**
1075
- * modal弹窗模型
1076
- * @param key 唯一值必传
1077
- * @returns
1078
- *
1079
- * ```
1080
- * 使用方式
1081
- * const [modalState, modalActions] = createModalWraperModel('key值').useStore();
1082
- * ```
1083
- */
1084
- export declare const createModalWraperModel: (key: string) => API<ModelType<ModalStateType, ModalActionsParamType, any>>;
1085
- export interface ModalStateType {
1086
- title?: string;
1087
- /**
1088
- * 显示modal
1089
- */
1090
- visible: boolean;
946
+ open: boolean;
1091
947
  /**
1092
948
  * 用来处理form, `更新`的时候的传递当前item列表行的数据, 当`创建`的时候强制设置为 `undefined`
1093
949
  */
@@ -1154,7 +1010,10 @@ export declare type PageFixedFooterProps = {
1154
1010
  children?: ReactNode | ReactNode[];
1155
1011
  };
1156
1012
  export declare const PageFixedFooter: (props: PageFixedFooterProps) => JSX.Element;
1157
- export declare const Page404: () => JSX.Element;
1013
+ export declare type Page404Props = {
1014
+ message?: string;
1015
+ };
1016
+ export declare const Page404: (props: Page404Props) => JSX.Element;
1158
1017
  export declare const getPermissionList: () => string[];
1159
1018
  export declare const hasPermission: (name?: string) => boolean;
1160
1019
  export interface PermissionProps {
@@ -1630,19 +1489,19 @@ export declare type TreeWrapperValue = string | number | Array<string | number>
1630
1489
  export declare type TreeServiceConfig = {
1631
1490
  params?: TPlainObject;
1632
1491
  requiredParamsKeys?: string[];
1633
- onRequest?: (params?: any) => any;
1492
+ onRequest?: (params?: TAny) => TAny;
1634
1493
  /**
1635
1494
  * 响应数据适配器
1636
1495
  */
1637
- onRequestResultAdapter?: (respData: any) => TPlainObject[];
1496
+ onRequestResultAdapter?: (respData: TAny) => TPlainObject[];
1638
1497
  };
1639
1498
  export declare type TreeLoadDataServiceConfig = {
1640
1499
  getParams: (dataItem: TPlainObject) => TPlainObject;
1641
- onRequest: (params: TPlainObject) => any;
1500
+ onRequest: (params: TPlainObject) => TAny;
1642
1501
  /**
1643
1502
  * 响应数据适配器
1644
1503
  */
1645
- onRequestResultAdapter?: (respData: any) => TPlainObject[];
1504
+ onRequestResultAdapter?: (respData: TAny) => TPlainObject[];
1646
1505
  };
1647
1506
  export declare type TreeWrapperMenuItem = {
1648
1507
  title: string;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@flatbiz/antd",
3
- "version": "3.2.0",
3
+ "version": "4.0.2",
4
4
  "description": "flat-biz oss ui components",
5
5
  "main": "index.js",
6
6
  "typings": "index.d.ts",
@@ -26,15 +26,15 @@
26
26
  "node": ">=13.8.0"
27
27
  },
28
28
  "peerDependencies": {
29
- "@ant-design/icons": ">=4.7.0",
29
+ "@ant-design/icons": ">=4.8.0",
30
30
  "@dimjs/lang": ">=1.2.23",
31
31
  "@dimjs/model": ">=1.1.8",
32
32
  "@dimjs/model-react": ">=1.1.8",
33
33
  "@dimjs/utils": ">=1.2.23",
34
- "@flatbiz/utils": ">=3.0.15",
34
+ "@flatbiz/utils": ">=3.1.4",
35
35
  "@wove/react": ">=1.2.22",
36
- "antd": ">=4.22.2 < 5.0.0",
37
- "moment": ">=2.29.4",
36
+ "antd": ">=5.0.4",
37
+ "dayjs": ">=1.11.6",
38
38
  "react": ">=18.2.0",
39
39
  "react-dom": ">=18.2.0"
40
40
  },
@@ -44,13 +44,13 @@
44
44
  "@dimjs/model": "^1.1.8",
45
45
  "@dimjs/model-react": "^1.1.8",
46
46
  "@dimjs/utils": "^1.2.23",
47
- "@flatbiz/utils": "^3.2.0",
48
- "@wove/react": "^1.2.21",
49
- "antd": "4.22.2",
47
+ "@flatbiz/utils": "^4.0.0",
48
+ "@wove/react": "^1.2.22",
49
+ "antd": "^5.0.4",
50
+ "dayjs": ">=1.11.6",
50
51
  "dequal": "^2.0.3",
51
- "moment": "^2.29.4",
52
52
  "react": "18.2.0",
53
53
  "react-dom": "18.2.0"
54
54
  },
55
- "gitHead": "63fe35407a413d07ac636203c31825442065f3f6"
55
+ "gitHead": "4378d433b73ee28fd7cb4c64bed8571f993eb5a9"
56
56
  }