Skip to content

Commit

Permalink
feat: migrating base-rating component using defineComponent sintax (#…
Browse files Browse the repository at this point in the history
  • Loading branch information
albertjcuac authored Feb 21, 2024
1 parent ae3bb29 commit 3fb116a
Showing 1 changed file with 50 additions and 40 deletions.
90 changes: 50 additions & 40 deletions packages/x-components/src/components/base-rating.vue
Original file line number Diff line number Diff line change
Expand Up @@ -24,8 +24,7 @@
</template>

<script lang="ts">
import Vue from 'vue';
import { Component, Prop } from 'vue-property-decorator';
import { computed, defineComponent } from 'vue';
import StarIcon from './icons/star.vue';
/**
Expand All @@ -34,49 +33,60 @@
*
* @public
*/
@Component({
export default defineComponent({
name: 'BaseRating',
components: {
DefaultIcon: StarIcon
}
})
export default class BaseRating extends Vue {
/**
* Numeric value used to calculates the width of the filled elements.
*
* @public
*/
@Prop({ required: true })
protected value!: number;
/**
* Maximum number of elements to paint.
*
* @public
*/
@Prop({ default: 5 })
protected max!: number;
},
props: {
/**
* Numeric value used to calculates the width of the filled elements.
*
* @public
*/
value: {
type: Number,
required: true
},
/**
* Maximum number of elements to paint.
*
* @public
*/
max: {
type: Number,
default: 5
}
},
setup(props) {
/**
* Calculates the width of the filled elements wrapper.
*
* @returns The % of the wrapper width.
*
* @internal
*/
const calculateFilledWrapperWidth = computed(() => {
return props.value < 0 ? '0%' : `${(props.value * 100) / props.max}%`;
});
/**
* Calculates the width of the filled elements wrapper.
*
* @returns The % of the wrapper width.
*
* @internal
*/
protected get calculateFilledWrapperWidth(): string {
return this.value < 0 ? '0%' : `${(this.value * 100) / this.max}%`;
}
/**
* Creates the aria label for accessibility purpose.
*
* @returns The aria label.
*
* @internal
*/
const ariaLabel = computed(() => {
return `${props.value}/${props.max}`;
});
/**
* Creates the aria label for accessibility purpose.
*
* @returns The aria label.
*
* @internal
*/
protected get ariaLabel(): string {
return `${this.value}/${this.max}`;
return {
calculateFilledWrapperWidth,
ariaLabel
};
}
}
});
</script>

<style lang="scss" scoped>
Expand Down

0 comments on commit 3fb116a

Please sign in to comment.