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/VBottomNavigation/VBottomNavigation.js
2019-08-11 20:48:02 +02:00

120 lines
No EOL
3.1 KiB
JavaScript

// Styles
import "../../../src/components/VBottomNavigation/VBottomNavigation.sass"; // Mixins
import Applicationable from '../../mixins/applicationable';
import ButtonGroup from '../../mixins/button-group';
import Colorable from '../../mixins/colorable';
import Measurable from '../../mixins/measurable';
import Proxyable from '../../mixins/proxyable';
import Scrollable from '../../mixins/scrollable';
import Themeable from '../../mixins/themeable';
import { factory as ToggleableFactory } from '../../mixins/toggleable'; // Utilities
import mixins from '../../util/mixins';
import { breaking } from '../../util/console';
export default mixins(Applicationable('bottom', ['height', 'inputValue']), Colorable, Measurable, ToggleableFactory('inputValue'), Proxyable, Scrollable, Themeable
/* @vue/component */
).extend({
name: 'v-bottom-navigation',
props: {
activeClass: {
type: String,
default: 'v-btn--active'
},
backgroundColor: String,
grow: Boolean,
height: {
type: [Number, String],
default: 56
},
hideOnScroll: Boolean,
horizontal: Boolean,
inputValue: {
type: Boolean,
default: true
},
mandatory: Boolean,
shift: Boolean
},
data() {
return {
isActive: this.inputValue
};
},
computed: {
canScroll() {
return Scrollable.options.computed.canScroll.call(this) && (this.hideOnScroll || !this.inputValue);
},
classes() {
return {
'v-bottom-navigation--absolute': this.absolute,
'v-bottom-navigation--grow': this.grow,
'v-bottom-navigation--fixed': !this.absolute && (this.app || this.fixed),
'v-bottom-navigation--horizontal': this.horizontal,
'v-bottom-navigation--shift': this.shift
};
},
styles() {
return { ...this.measurableStyles,
transform: this.isActive ? 'none' : 'translateY(100%)'
};
}
},
created() {
/* istanbul ignore next */
if (this.$attrs.hasOwnProperty('active')) {
breaking('active.sync', 'value or v-model', this);
}
},
methods: {
thresholdMet() {
this.isActive = !this.isScrollingUp;
this.$emit('update:input-value', this.isActive);
},
updateApplication() {
return this.$el ? this.$el.clientHeight : 0;
},
updateValue(val) {
this.$emit('change', val);
}
},
render(h) {
const data = this.setBackgroundColor(this.backgroundColor, {
staticClass: 'v-bottom-navigation',
class: this.classes,
style: this.styles,
props: {
activeClass: this.activeClass,
mandatory: Boolean(this.mandatory || this.value !== undefined),
value: this.internalValue
},
on: {
change: this.updateValue
}
});
if (this.canScroll) {
data.directives = data.directives || [];
data.directives.push({
arg: this.scrollTarget,
name: 'scroll',
value: this.onScroll
});
}
return h(ButtonGroup, this.setTextColor(this.color, data), this.$slots.default);
}
});
//# sourceMappingURL=VBottomNavigation.js.map