2018-08-26 20:08:40 +05:30
|
|
|
import Vue from 'vue/dist/vue.js';
|
2018-08-27 10:12:45 +05:30
|
|
|
|
|
|
|
// Global components
|
|
|
|
import ItemCardsContainer from './components/ItemCardsContainer.vue';
|
|
|
|
import SectionHeader from './components/SectionHeader.vue';
|
|
|
|
import SearchInput from './components/SearchInput.vue';
|
|
|
|
import DetailView from './components/DetailView.vue';
|
|
|
|
import DetailHeaderItem from './components/DetailHeaderItem.vue';
|
|
|
|
import EmptyState from './components/EmptyState.vue';
|
|
|
|
|
2018-08-26 20:08:40 +05:30
|
|
|
Vue.prototype.__ = window.__;
|
|
|
|
Vue.prototype.frappe = window.frappe;
|
|
|
|
|
2018-08-27 10:12:45 +05:30
|
|
|
Vue.component('item-cards-container', ItemCardsContainer);
|
|
|
|
Vue.component('section-header', SectionHeader);
|
|
|
|
Vue.component('search-input', SearchInput);
|
|
|
|
Vue.component('detail-view', DetailView);
|
|
|
|
Vue.component('detail-header-item', DetailHeaderItem);
|
|
|
|
Vue.component('empty-state', EmptyState);
|
|
|
|
|
2018-08-26 20:08:40 +05:30
|
|
|
Vue.directive('route', {
|
|
|
|
bind(el, binding) {
|
|
|
|
const route = binding.value;
|
2018-08-26 22:20:16 +05:30
|
|
|
if (!route) return;
|
2018-08-26 20:08:40 +05:30
|
|
|
el.classList.add('cursor-pointer');
|
2018-08-26 22:20:16 +05:30
|
|
|
el.dataset.route = route;
|
2018-08-26 20:08:40 +05:30
|
|
|
el.addEventListener('click', () => frappe.set_route(route));
|
|
|
|
},
|
|
|
|
unbind(el) {
|
|
|
|
el.classList.remove('cursor-pointer');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
const handleImage = (el, src) => {
|
|
|
|
let img = new Image();
|
|
|
|
// add loading class
|
|
|
|
el.src = '';
|
|
|
|
el.classList.add('img-loading');
|
|
|
|
|
|
|
|
img.onload = () => {
|
|
|
|
// image loaded, remove loading class
|
|
|
|
el.classList.remove('img-loading');
|
|
|
|
// set src
|
|
|
|
el.src = src;
|
|
|
|
}
|
|
|
|
img.onerror = () => {
|
|
|
|
el.classList.remove('img-loading');
|
|
|
|
el.classList.add('no-image');
|
|
|
|
el.src = null;
|
|
|
|
}
|
|
|
|
img.src = src;
|
|
|
|
}
|
|
|
|
|
|
|
|
Vue.directive('img-src', {
|
|
|
|
bind(el, binding) {
|
|
|
|
handleImage(el, binding.value);
|
|
|
|
},
|
|
|
|
update(el, binding) {
|
|
|
|
if (binding.value === binding.oldValue) return;
|
|
|
|
handleImage(el, binding.value);
|
|
|
|
}
|
|
|
|
});
|