import { VantComponent } from '../common/component';
|
|
import { useParent } from '../common/relation';
|
|
import { link } from '../mixins/link';
|
|
VantComponent({
|
|
relation: useParent('grid'),
|
|
classes: ['content-class', 'icon-class', 'text-class'],
|
|
mixins: [link],
|
|
props: {
|
|
icon: String,
|
|
iconColor: String,
|
|
iconPrefix: {
|
|
type: String,
|
|
value: 'van-icon',
|
|
},
|
|
dot: Boolean,
|
|
info: null,
|
|
badge: null,
|
|
text: String,
|
|
useSlot: Boolean,
|
|
},
|
|
data: {
|
|
viewStyle: '',
|
|
},
|
|
mounted() {
|
|
this.updateStyle();
|
|
},
|
|
methods: {
|
|
updateStyle() {
|
|
if (!this.parent) {
|
|
return;
|
|
}
|
|
const { data, children } = this.parent;
|
|
const { columnNum, border, square, gutter, clickable, center, direction, reverse, iconSize, } = data;
|
|
this.setData({
|
|
center,
|
|
border,
|
|
square,
|
|
gutter,
|
|
clickable,
|
|
direction,
|
|
reverse,
|
|
iconSize,
|
|
index: children.indexOf(this),
|
|
columnNum,
|
|
});
|
|
},
|
|
onClick() {
|
|
this.$emit('click');
|
|
this.jumpLink();
|
|
},
|
|
},
|
|
});
|