105 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Markdown
		
	
	
			
		
		
	
	
			105 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			Markdown
		
	
	
| ---
 | |
| category: Components
 | |
| type: Data Entry
 | |
| title: Transfer
 | |
| cover: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*EAApQ5ephigAAAAAAAAAAAAADrJ8AQ/original
 | |
| coverDark: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*yv12S4sSRAEAAAAAAAAAAAAADrJ8AQ/original
 | |
| ---
 | |
| 
 | |
| Alert component for feedback.
 | |
| 
 | |
| ## When To Use
 | |
| 
 | |
| - When you need to show alert messages to users.
 | |
| - When you need a persistent static container which is closable by user actions.
 | |
| 
 | |
| Transfer the elements between two columns in an intuitive and efficient way.
 | |
| 
 | |
| One or more elements can be selected from either column, one click on the proper `direction` button, and the transfer is done. The left column is considered the `source` and the right column is considered the `target`. As you can see in the API description, these names are reflected in.
 | |
| 
 | |
| ## API
 | |
| 
 | |
| | Property | Description | Type | Default | Version |
 | |
| | --- | --- | --- | --- | --- |
 | |
| | dataSource | Used for setting the source data. The elements that are part of this array will be present the left column. Except the elements whose keys are included in `targetKeys` prop. | \[{key: string.isRequired,title: string.isRequired,description: string,disabled: bool}] | \[] |  |
 | |
| | disabled | Whether disabled transfer | boolean | false |  |
 | |
| | filterOption | A function to determine whether an item should show in search result list | (inputValue, option): boolean |  |  |
 | |
| | footer | customize the progress dot by setting a scoped slot | slot="footer" slot-scope="props" |  |  |
 | |
| | listStyle | A custom CSS style used for rendering the transfer columns. | CSSProperties |  |  |
 | |
| | locale | i18n text including filter, empty text, item unit, etc | object | `{ itemUnit: 'item', itemsUnit: 'items', notFoundContent: 'The list is empty', searchPlaceholder: 'Search here' }` |  |
 | |
| | oneWay | Display as single direction style | boolean | false | 3.0.0 |
 | |
| | operations | A set of operations that are sorted from top to bottom. | string\[] | \['>', '<'] |  |
 | |
| | operationStyle | A custom CSS style used for rendering the operations column | CSSProperties | - | 3.0.0 |
 | |
| | pagination | Use pagination. Not work in render props | boolean \| { pageSize: number, simple: boolean, showSizeChanger?: boolean, showLessItems?: boolean } | false | 3.0.0 |
 | |
| | render | The function to generate the item shown on a column. Based on an record (element of the dataSource array), this function should return a element which is generated from that record. Also, it can return a plain object with `value` and `label`, `label` is a element and `value` is for title | Function(record) \| slot |  |  |
 | |
| | selectAllLabels | A set of customized labels for select all checkboxes on the header | VueNode \| ((info: { selectedCount: number; totalCount: number }) => VueNode); | - | 3.0.0 |
 | |
| | selectedKeys(v-model) | A set of keys of selected items. | string\[] | \[] |  |
 | |
| | showSearch | If included, a search box is shown on each column. | boolean | false |  |
 | |
| | showSelectAll | Show select all checkbox on the header | boolean | true |  |
 | |
| | status | Set validation status | 'error' \| 'warning' | - | 3.3.0 |
 | |
| | targetKeys(v-model) | A set of keys of elements that are listed on the right column. | string\[] | \[] |  |
 | |
| | titles | A set of titles that are sorted from left to right. | string\[] | - |  |
 | |
| 
 | |
| ### events
 | |
| 
 | |
| | Events Name | Description | Arguments | Version |
 | |
| | --- | --- | --- | --- |
 | |
| | change | A callback function that is executed when the transfer between columns is complete. | (targetKeys, direction, moveKeys): void |  |
 | |
| | scroll | A callback function which is executed when scroll options list | (direction, event): void |  |
 | |
| | search | A callback function which is executed when search field are changed | (direction: 'left'\|'right', value: string): void | - |
 | |
| | selectChange | A callback function which is executed when selected items are changed. | (sourceSelectedKeys, targetSelectedKeys): void |  |
 | |
| 
 | |
| ### Render Props
 | |
| 
 | |
| Transfer accept `children` to customize render list, using follow props:
 | |
| 
 | |
| ```json
 | |
| {
 | |
|   "direction": String,
 | |
|   "disabled": Boolean,
 | |
|   "filteredItems": Array,
 | |
|   "selectedKeys": Array,
 | |
|   "onItemSelect": Function,
 | |
|   "onItemSelectAll": Function
 | |
| }
 | |
| ```
 | |
| 
 | |
| | Property        | Description             | Type                                 | Version |
 | |
| | --------------- | ----------------------- | ------------------------------------ | ------- |
 | |
| | direction       | List render direction   | 'left' \| 'right'                    |         |
 | |
| | disabled        | Disable list or not     | boolean                              |         |
 | |
| | filteredItems   | Filtered items          | TransferItem\[]                      |         |
 | |
| | selectedKeys    | Selected items          | string\[]                            |         |
 | |
| | onItemSelect    | Select item             | (key: string, selected: boolean)     |         |
 | |
| | onItemSelectAll | Select a group of items | (keys: string\[], selected: boolean) |         |
 | |
| 
 | |
| #### example
 | |
| 
 | |
| ```html
 | |
| <a-transfer>
 | |
|   <template
 | |
|     #children="{
 | |
|       direction,
 | |
|       filteredItems,
 | |
|       selectedKeys,
 | |
|       disabled: listDisabled,
 | |
|       onItemSelectAll,
 | |
|       onItemSelect,
 | |
|     }"
 | |
|   >
 | |
|     <your-component />
 | |
|   <template>
 | |
| </a-transfer>
 | |
| ```
 | |
| 
 | |
| ## Warning
 | |
| 
 | |
| According the standard of Vue, the key should always be supplied directly to the elements in the array. In Transfer, the keys should be set on the elements included in `dataSource` array. By default, `key` property is used as an unique identifier.
 | |
| 
 | |
| If there's no `key` in your data, you should use `rowKey` to specify the key that will be used for uniquely identify each element.
 | |
| 
 | |
| ```jsx
 | |
| // eg. your primary key is `uid`
 | |
| return <Transfer :rowKey="record => record.uid" />;
 | |
| ```
 |