Skip to content

Commit

Permalink
Merge branch 'formily_next' of github.com:alibaba/formily into formil…
Browse files Browse the repository at this point in the history
…y_next
  • Loading branch information
janryWang committed May 26, 2021
2 parents 70852e9 + 43e79a6 commit 5a85314
Show file tree
Hide file tree
Showing 4 changed files with 117 additions and 15 deletions.
106 changes: 98 additions & 8 deletions packages/antd/docs/components/ArrayCollapse.md
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,9 @@ export default () => {
maxItems={3}
x-decorator="FormItem"
x-component="ArrayCollapse"
x-component-props={{
defaultOpenPanelCount: 3,
}}
>
<SchemaField.Object
x-component="ArrayCollapse.CollapsePanel"
Expand Down Expand Up @@ -90,6 +93,41 @@ export default () => {
title="添加条目"
/>
</SchemaField.Array>
<SchemaField.Array
name="string_array_unshift"
maxItems={3}
x-decorator="FormItem"
x-component="ArrayCollapse"
x-component-props={{
defaultOpenPanelCount: 3,
}}
>
<SchemaField.Object
x-component="ArrayCollapse.CollapsePanel"
x-component-props={{
header: '字符串数组',
}}
>
<SchemaField.Void x-component="ArrayCollapse.Index" />
<SchemaField.String
name="input"
x-decorator="FormItem"
title="Input"
required
x-component="Input"
/>
<SchemaField.Void x-component="ArrayCollapse.Remove" />
<SchemaField.Void x-component="ArrayCollapse.MoveUp" />
<SchemaField.Void x-component="ArrayCollapse.MoveDown" />
</SchemaField.Object>
<SchemaField.Void
x-component="ArrayCollapse.Addition"
title="添加条目(unshift)"
x-component-props={{
method: 'unshift',
}}
/>
</SchemaField.Array>
</SchemaField>
<FormButtonGroup>
<Submit onSubmit={console.log}>提交</Submit>
Expand Down Expand Up @@ -216,6 +254,54 @@ const schema = {
},
},
},
array_unshift: {
type: 'array',
'x-component': 'ArrayCollapse',
maxItems: 3,
'x-decorator': 'FormItem',
items: {
type: 'object',
'x-component': 'ArrayCollapse.CollapsePanel',
'x-component-props': {
header: '对象数组',
},
properties: {
index: {
type: 'void',
'x-component': 'ArrayCollapse.Index',
},
input: {
type: 'string',
'x-decorator': 'FormItem',
title: 'Input',
required: true,
'x-component': 'Input',
},
remove: {
type: 'void',
'x-component': 'ArrayCollapse.Remove',
},
moveUp: {
type: 'void',
'x-component': 'ArrayCollapse.MoveUp',
},
moveDown: {
type: 'void',
'x-component': 'ArrayCollapse.MoveDown',
},
},
},
properties: {
addition: {
type: 'void',
title: '添加条目(unshift)',
'x-component': 'ArrayCollapse.Addition',
'x-component-props': {
method: 'unshift',
},
},
},
},
},
}

Expand Down Expand Up @@ -451,11 +537,15 @@ export default () => {

## API

### ArrayCards
### ArrayCollapse

参考 https://ant.design/components/collapse-cn/

### ArrayCollapse.CollapsePanel

参考 https://ant.design/components/card-cn/
参考 https://ant.design/components/collapse-cn/

### ArrayCards.Addition
### ArrayCollapse.Addition

> 添加按钮
Expand All @@ -470,7 +560,7 @@ export default () => {

注意:title 属性可以接收 Field 模型中的 title 映射,也就是在 Field 上传 title 也是生效的

### ArrayCards.Remove
### ArrayCollapse.Remove

> 删除按钮
Expand All @@ -482,7 +572,7 @@ export default () => {

注意:title 属性可以接收 Field 模型中的 title 映射,也就是在 Field 上传 title 也是生效的

### ArrayCards.MoveDown
### ArrayCollapse.MoveDown

> 下移按钮
Expand All @@ -494,7 +584,7 @@ export default () => {

注意:title 属性可以接收 Field 模型中的 title 映射,也就是在 Field 上传 title 也是生效的

### ArrayCards.MoveUp
### ArrayCollapse.MoveUp

> 上移按钮
Expand All @@ -506,12 +596,12 @@ export default () => {

注意:title 属性可以接收 Field 模型中的 title 映射,也就是在 Field 上传 title 也是生效的

### ArrayCards.Index
### ArrayCollapse.Index

> 索引渲染器
无属性

### ArrayItems.useIndex
### ArrayCollapse.useIndex

> 读取当前渲染行索引的 React Hook
19 changes: 14 additions & 5 deletions packages/antd/src/array-collapse/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,11 +13,15 @@ import {
observer,
ISchema,
} from '@formily/react'
import React, { Fragment } from 'react'
import React, { Fragment, useState } from 'react'
import ArrayBase, { ArrayBaseMixins } from '../array-base'
import cls from 'classnames'
import { usePrefixCls } from '../__builtins__'
type ComposedArrayCollapse = React.FC<CollapseProps> &

export interface IArrayCollapseProps extends CollapseProps {
defaultOpenPanelCount?: number
}
type ComposedArrayCollapse = React.FC<IArrayCollapseProps> &
ArrayBaseMixins & {
CollapsePanel?: React.FC<CollapsePanelProps>
}
Expand Down Expand Up @@ -51,7 +55,7 @@ const isOperationComponent = (schema: ISchema) => {
)
}
export const ArrayCollapse: ComposedArrayCollapse = observer(
(props: CollapseProps) => {
(props: IArrayCollapseProps) => {
const field = useField<Formily.Core.Models.ArrayField>()

const schema = useFieldSchema()
Expand All @@ -77,11 +81,16 @@ export const ArrayCollapse: ComposedArrayCollapse = observer(
)
}

const [activeKeys, setActiveKeys] = useState<Array<string | number>>(
Array.from({ length: props?.defaultOpenPanelCount || 1 }).map((_, i) => i)
)

const renderItems = () => {
return (
<Collapse
{...props}
onChange={() => {}}
activeKey={activeKeys}
onChange={(key: string[]) => setActiveKeys(key)}
className={cls(`${prefixCls}-item`, props.className)}
>
{dataSource?.map((item, index) => {
Expand Down Expand Up @@ -168,7 +177,7 @@ export const ArrayCollapse: ComposedArrayCollapse = observer(
)
}
return (
<ArrayBase>
<ArrayBase onAdd={(index) => setActiveKeys(activeKeys.concat(index))}>
{renderEmpty()}
{renderItems()}
{renderAddition()}
Expand Down
5 changes: 4 additions & 1 deletion packages/json-schema/src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -129,7 +129,10 @@ export interface ISchemaTransformerOptions extends ISchemaFieldFactoryOptions {
}

export type Stringify<P extends { [key: string]: any }> = {
[key in keyof P]?: P[key] | string
/**
* Use `string & {}` instead of string to keep Literal Type for ISchema#component and ISchema#decorator
*/
[key in keyof P]?: P[key] | (string & {})
}

export type ISchema<
Expand Down
2 changes: 1 addition & 1 deletion packages/react/src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -144,7 +144,7 @@ export type ReactComponentPropsByPathValue<
? Rest extends ReactComponentPath<T[Key]>
? ReactComponentPropsByPathValue<T[Key], Rest>
: never
: never
: React.ComponentProps<T[P]>
: P extends keyof T
? React.ComponentProps<T[P]>
: never
Expand Down

0 comments on commit 5a85314

Please sign in to comment.