This repository has been archived on 2024-07-27. You can view files and clone it, but cannot push or open issues or pull requests.
keksAccountGUI/node_modulesOLD/vuetify/lib/components/VCard/VCard.js
2019-08-11 20:48:02 +02:00

81 lines
No EOL
1.9 KiB
JavaScript

// Styles
import "../../../src/components/VCard/VCard.sass"; // Extensions
import VSheet from '../VSheet'; // Mixins
import Loadable from '../../mixins/loadable';
import Routable from '../../mixins/routable'; // Helpers
import mixins from '../../util/mixins';
/* @vue/component */
export default mixins(Loadable, Routable, VSheet).extend({
name: 'v-card',
props: {
flat: Boolean,
hover: Boolean,
img: String,
link: Boolean,
loaderHeight: {
type: [Number, String],
default: 4
},
outlined: Boolean,
raised: Boolean
},
computed: {
classes() {
return {
'v-card': true,
...Routable.options.computed.classes.call(this),
'v-card--flat': this.flat,
'v-card--hover': this.hover,
'v-card--link': this.isClickable,
'v-card--loading': this.loading,
'v-card--disabled': this.loading || this.disabled,
'v-card--outlined': this.outlined,
'v-card--raised': this.raised,
...VSheet.options.computed.classes.call(this)
};
},
styles() {
const style = { ...VSheet.options.computed.styles.call(this)
};
if (this.img) {
style.background = `url("${this.img}") center center / cover no-repeat`;
}
return style;
}
},
methods: {
genProgress() {
const render = Loadable.options.methods.genProgress.call(this);
if (!render) return null;
return this.$createElement('div', {
staticClass: 'v-card__progress'
}, [render]);
}
},
render(h) {
const {
tag,
data
} = this.generateRouteLink();
data.style = this.styles;
if (this.isClickable) {
data.attrs = data.attrs || {};
data.attrs.tabindex = 0;
}
return h(tag, this.setBackgroundColor(this.color, data), [this.genProgress(), this.$slots.default]);
}
});
//# sourceMappingURL=VCard.js.map