// @ts-nocheck /* eslint-disable */ // Components import VIcon from "../VIcon/index.mjs"; // Mixins import Colorable from "../../mixins/colorable.mjs"; import { inject as RegistrableInject } from "../../mixins/registrable.mjs"; // Directives import ripple from "../../directives/ripple/index.mjs"; // Utilities import mixins from "../../util/mixins.mjs"; import { keyCodes } from "../../util/helpers.mjs"; // Types const baseMixins = mixins(Colorable, RegistrableInject('stepper', 'v-stepper-step', 'v-stepper')); /* @vue/component */ export default baseMixins.extend().extend({ name: 'v-stepper-step', directives: { ripple }, inject: ['stepClick'], props: { color: { type: String, default: 'primary' }, complete: Boolean, completeIcon: { type: String, default: '$complete' }, editable: Boolean, editIcon: { type: String, default: '$edit' }, errorIcon: { type: String, default: '$error' }, rules: { type: Array, default: () => [] }, step: [Number, String] }, data() { return { isActive: false, isInactive: true }; }, computed: { classes() { return { 'v-stepper__step--active': this.isActive, 'v-stepper__step--editable': this.editable, 'v-stepper__step--inactive': this.isInactive, 'v-stepper__step--error error--text': this.hasError, 'v-stepper__step--complete': this.complete }; }, hasError() { return this.rules.some(validate => validate() !== true); } }, mounted() { this.stepper && this.stepper.register(this); }, beforeDestroy() { this.stepper && this.stepper.unregister(this); }, methods: { click(e) { e.stopPropagation(); this.$emit('click', e); if (this.editable) { this.stepClick(this.step); } }, genIcon(icon) { return this.$createElement(VIcon, icon); }, genLabel() { return this.$createElement('div', { staticClass: 'v-stepper__label' }, this.$slots.default); }, genStep() { const color = !this.hasError && (this.complete || this.isActive) ? this.color : false; return this.$createElement('span', this.setBackgroundColor(color, { staticClass: 'v-stepper__step__step' }), this.genStepContent()); }, genStepContent() { const children = []; if (this.hasError) { children.push(this.genIcon(this.errorIcon)); } else if (this.complete) { if (this.editable) { children.push(this.genIcon(this.editIcon)); } else { children.push(this.genIcon(this.completeIcon)); } } else { children.push(String(this.step)); } return children; }, keyboardClick(e) { if (e.keyCode === keyCodes.space) { this.click(e); } }, toggle(step) { this.isActive = step.toString() === this.step.toString(); this.isInactive = Number(step) < Number(this.step); } }, render(h) { return h('div', { attrs: { tabindex: this.editable ? 0 : -1 }, staticClass: 'v-stepper__step', class: this.classes, directives: [{ name: 'ripple', value: this.editable }], on: { click: this.click, keydown: this.keyboardClick } }, [this.genStep(), this.genLabel()]); } }); //# sourceMappingURL=VStepperStep.mjs.map