vuetify
Version:
Vue.js 2 Semantic Component Framework
77 lines (64 loc) • 1.56 kB
JavaScript
// Styles
require('../../../src/stylus/components/_lists.styl');
// Mixins
import Themeable from '../../mixins/themeable';
import { provide as RegistrableProvide } from '../../mixins/registrable';
export default {
name: 'v-list',
mixins: [RegistrableProvide('list'), Themeable],
provide: function provide() {
return {
'listClick': this.listClick
};
},
data: function data() {
return {
groups: []
};
},
props: {
dense: Boolean,
expand: Boolean,
subheader: Boolean,
threeLine: Boolean,
twoLine: Boolean
},
computed: {
classes: function classes() {
return {
'list--dense': this.dense,
'list--subheader': this.subheader,
'list--two-line': this.twoLine,
'list--three-line': this.threeLine,
'theme--dark': this.dark,
'theme--light': this.light
};
}
},
methods: {
register: function register(uid, cb) {
this.groups.push({ uid: uid, cb: cb });
},
unregister: function unregister(uid) {
var index = this.groups.findIndex(function (g) {
return g.uid === uid;
});
if (index > -1) {
this.groups.splice(index, 1);
}
},
listClick: function listClick(uid, isBooted) {
if (this.expand) return;
for (var i = this.groups.length; i--;) {
this.groups[i].cb(uid);
}
}
},
render: function render(h) {
var data = {
staticClass: 'list',
'class': this.classes
};
return h('ul', data, [this.$slots.default]);
}
};