62 lines
2.0 KiB
Vue
62 lines
2.0 KiB
Vue
<template>
|
|
<div>
|
|
<div class="flex justify-content-end mt-1 mb-3">
|
|
<Button icon="pi pi-external-link" label="Nested Dialog" class="p-button-outlined p-button-success" @click="showInfo" />
|
|
</div>
|
|
<DataTable :value="products" responsiveLayout="scroll">
|
|
<Column field="code" header="Code"></Column>
|
|
<Column field="name" header="Name"></Column>
|
|
<Column header="Image">
|
|
<template #body="slotProps">
|
|
<img :src="'demo/images/product/' + slotProps.data.image" :alt="slotProps.data.name" class="shadow-2 w-4rem" />
|
|
</template>
|
|
</Column>
|
|
<Column field="category" header="Category"></Column>
|
|
<Column field="quantity" header="Quantity"></Column>
|
|
<Column style="width: 5rem">
|
|
<template #body="slotProps">
|
|
<Button type="button" icon="pi pi-plus" class="p-button-text p-button-rounded" @click="selectProduct(slotProps.data)"></Button>
|
|
</template>
|
|
</Column>
|
|
</DataTable>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import ProductService from '../../service/ProductService';
|
|
import InfoDemo from './InfoDemo.vue';
|
|
|
|
export default {
|
|
inject: ['dialogRef'],
|
|
data() {
|
|
return {
|
|
products: null
|
|
};
|
|
},
|
|
productService: null,
|
|
created() {
|
|
this.productService = new ProductService();
|
|
},
|
|
mounted() {
|
|
this.productService.getProductsSmall().then((data) => (this.products = data.slice(0, 5)));
|
|
},
|
|
methods: {
|
|
selectProduct(data) {
|
|
this.dialogRef.close(data);
|
|
},
|
|
showInfo() {
|
|
this.$dialog.open(InfoDemo, {
|
|
props: {
|
|
header: 'Information',
|
|
modal: true,
|
|
dismissableMask: true
|
|
},
|
|
data: {
|
|
totalProducts: this.products ? this.products.length : 0
|
|
}
|
|
});
|
|
}
|
|
}
|
|
};
|
|
</script>
|