You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
56 lines
1.3 KiB
56 lines
1.3 KiB
import { useParent } from '../common/relation'; |
|
import { VantComponent } from '../common/component'; |
|
VantComponent({ |
|
relation: useParent('tabs'), |
|
props: { |
|
dot: { |
|
type: Boolean, |
|
observer: 'update', |
|
}, |
|
info: { |
|
type: null, |
|
observer: 'update', |
|
}, |
|
title: { |
|
type: String, |
|
observer: 'update', |
|
}, |
|
disabled: { |
|
type: Boolean, |
|
observer: 'update', |
|
}, |
|
titleStyle: { |
|
type: String, |
|
observer: 'update', |
|
}, |
|
name: { |
|
type: null, |
|
value: '', |
|
}, |
|
}, |
|
data: { |
|
active: false, |
|
}, |
|
methods: { |
|
getComputedName() { |
|
if (this.data.name !== '') { |
|
return this.data.name; |
|
} |
|
return this.index; |
|
}, |
|
updateRender(active, parent) { |
|
const { data: parentData } = parent; |
|
this.inited = this.inited || active; |
|
this.setData({ |
|
active, |
|
shouldRender: this.inited || !parentData.lazyRender, |
|
shouldShow: active || parentData.animated, |
|
}); |
|
}, |
|
update() { |
|
if (this.parent) { |
|
this.parent.updateTabs(); |
|
} |
|
}, |
|
}, |
|
});
|
|
|