[improvement] AddressList: jsx (#2504)

This commit is contained in:
neverland
2019-01-12 12:06:49 +08:00
committed by GitHub
parent 25c00b1023
commit 05e85f2eb0
5 changed files with 137 additions and 147 deletions

View File

@@ -0,0 +1,63 @@
import { use } from '../utils';
import Button from '../button';
import RadioGroup from '../radio-group';
import AddressItem from './Item';
const [sfc, bem, t] = use('address-list');
export default sfc({
props: {
list: Array,
disabledList: Array,
disabledText: String,
addButtonText: String,
value: [String, Number],
switchable: {
type: Boolean,
default: true
}
},
render(h) {
const getList = (list, disabled) =>
list.map((item, index) => (
<AddressItem
data={item}
key={item.id}
disabled={disabled}
switchable={this.switchable && !disabled}
onSelect={() => {
this.$emit(disabled ? 'select-disabled' : 'select', item, index);
}}
onEdit={() => {
this.$emit(disabled ? 'edit-disabled' : 'edit', item, index);
}}
/>
));
const List = getList(this.list);
const DisabledList = getList(this.disabledList, true);
return (
<div class={bem()}>
{this.$slots.top}
<RadioGroup value={this.value} onInput={event => this.$emit('input', event)}>
{List}
</RadioGroup>
{this.disabledText && <div class={bem('disabled-text')}>{this.disabledText}</div>}
{DisabledList}
{this.$slots.default}
<Button
square
size="large"
type="danger"
class={bem('add')}
text={this.addButtonText || t('add')}
onClick={() => {
this.$emit('add');
}}
/>
</div>
);
}
});