63 lines
1.2 KiB
Vue
Raw Normal View History

<template>
2018-08-24 16:38:34 +05:30
<div class="item-cards-container">
<empty-state
v-if="items.length === 0"
:message="empty_state_message"
:action="empty_state_action"
:bordered="true"
:height="empty_state_height"
/>
<item-card
v-for="item in items"
:key="container_name + '_' +item[item_id_fieldname]"
:item="item"
2018-08-24 16:38:34 +05:30
:item_id_fieldname="item_id_fieldname"
:is_local="is_local"
2018-08-24 16:38:34 +05:30
:on_click="on_click"
:allow_clear="editable"
:seen="item.hasOwnProperty('seen') ? item.seen : true"
2018-08-24 16:38:34 +05:30
@remove-item="$emit('remove-item', item[item_id_fieldname])"
>
</item-card>
</div>
</template>
<script>
import ItemCard from './ItemCard.vue';
import EmptyState from './EmptyState.vue';
export default {
name: 'item-cards-container',
props: {
container_name: String,
2018-08-24 16:38:34 +05:30
items: Array,
item_id_fieldname: String,
is_local: Boolean,
2018-08-24 16:38:34 +05:30
on_click: Function,
editable: Boolean,
2018-08-24 16:38:34 +05:30
empty_state_message: String,
empty_state_action: Object,
2018-08-24 16:38:34 +05:30
empty_state_height: Number,
empty_state_bordered: Boolean
},
components: {
ItemCard,
EmptyState
},
2018-08-23 13:52:41 +05:30
watch: {
items() {
2018-08-24 16:38:34 +05:30
// TODO: handling doesn't work
2018-08-23 13:52:41 +05:30
frappe.dom.handle_broken_images($(this.$el));
}
}
}
</script>
2018-08-24 16:38:34 +05:30
<style scoped>
.item-cards-container {
margin: 0 -15px;
overflow: overlay;
}
</style>