brotherton-erpnext/erpnext/public/js/hub/hub_page.js

160 lines
3.6 KiB
JavaScript
Raw Normal View History

2017-12-10 16:32:41 +00:00
frappe.provide('erpnext.hub');
erpnext.hub.ItemListing = class ItemListing extends frappe.views.BaseList {
2017-12-10 16:32:41 +00:00
setup_defaults() {
super.setup_defaults();
this.page_title = __('Hub');
this.method = 'erpnext.hub_node.get_items';
const route = frappe.get_route();
this.page_name = route[1];
2018-01-25 03:48:32 +00:00
return this.get_hub_item_meta()
.then(r => {
this.meta = r.message || this.meta;
this.doctype = 'Hub Item';
frappe.model.sync(this.meta);
});
2017-12-10 16:32:41 +00:00
}
2018-01-25 03:48:32 +00:00
get_hub_item_meta() {
return new Promise(resolve =>
frappe.call('erpnext.hub_node.get_hub_item_meta', {}, resolve));
}
2017-12-10 16:32:41 +00:00
2018-01-25 03:48:32 +00:00
setup_fields() {
this.fields = ['name', 'hub_item_code', 'image', 'item_name', 'item_code', 'company_name'];
2017-12-10 16:32:41 +00:00
}
set_breadcrumbs() { }
2017-12-10 16:32:41 +00:00
setup_side_bar() { }
2017-12-10 16:32:41 +00:00
setup_filter_area() {
2018-01-25 03:48:32 +00:00
this.custom_filter_configs = [
{
fieldtype: 'Data',
label: 'Company',
condition: 'like',
fieldname: 'company_name',
},
{
fieldtype: 'Link',
label: 'Country',
options: 'Country',
condition: 'like',
fieldname: 'country'
}
];
this.filter_area = new FilterArea(this);
2017-12-10 16:32:41 +00:00
}
setup_sort_selector() { }
2017-12-10 16:32:41 +00:00
setup_view() { }
2018-01-25 03:48:32 +00:00
get_filters_for_args() {
let filters = {};
this.filter_area.get().forEach(f => {
let field = f[1] !== 'name' ? f[1] : 'item_name';
filters[field] = [f[2], f[3]];
});
if(this.current_category) {
filters['hub_category'] = this.current_category;
}
return filters;
2018-01-25 03:48:32 +00:00
}
2017-12-10 16:32:41 +00:00
get_args() {
console.log('filters', this.get_filters_for_args());
2017-12-10 16:32:41 +00:00
return {
doctype: 'Hub Item'
2017-12-10 16:32:41 +00:00
start: this.start,
limit: this.page_length,
order_by: this.order_by,
fields: this.fields,
filters: this.get_filters_for_args()
// category: this.category || '',
// company: this.company || '',
// text: this.search_text || '',
2017-12-10 16:32:41 +00:00
};
}
update_data(r) {
const data = r.message;
// console.log('update data', data);
2017-12-10 16:32:41 +00:00
if (this.start === 0) {
this.data = data;
} else {
this.data = this.data.concat(data);
}
2018-01-25 03:48:32 +00:00
}
freeze(toggle) {
this.$freeze.toggle(toggle);
if (this.$freeze.find('.image-view-container').length) return;
const html = Array.from(new Array(4)).map(d => this.card_html({
name: 'freeze',
item_name: 'freeze'
})).join('');
this.$freeze.html(`<div class="image-view-container border-top">${html}</div>`);
2017-12-10 16:32:41 +00:00
}
render() {
this.render_image_view();
}
render_image_view() {
2018-01-25 03:48:32 +00:00
let data = this.data;
// console.log('this.data render', this.data);
2018-01-25 03:48:32 +00:00
if (this.start === 0) {
this.$result.html('<div class="image-view-container small padding-top">');
data = this.data.slice(this.start);
}
2017-12-10 16:32:41 +00:00
2018-01-25 03:48:32 +00:00
var html = data.map(this.card_html.bind(this)).join("");
this.$result.find('.image-view-container').append(html);
2017-12-10 16:32:41 +00:00
}
card_html(item) {
item._name = encodeURI(item.name);
const encoded_name = item._name;
const title = strip_html(item['item_name' || 'item_code']);
console.log(item);
const company_name = item['company_name'];
2017-12-10 16:32:41 +00:00
2018-01-25 03:48:32 +00:00
const route = `#Hub/Item/${item.hub_item_code}`;
const image_html = item.image ?
`<img src="${item.image}">
<span class="helper"></span>` :
`<div class="standard-image">${frappe.get_abbr(title)}</div>`;
2017-12-10 16:32:41 +00:00
return `
2018-01-25 03:48:32 +00:00
<div class="hub-item-wrapper margin-bottom" style="width: 200px;">
<a href="${route}">
<div class="hub-item-image">
<div class="img-wrapper" style="height: 200px; width: 200px">
${image_html}
2017-12-10 16:32:41 +00:00
</div>
</div>
2018-01-25 03:48:32 +00:00
<div class="hub-item-title">
<h5 class="bold">
${ title }
</h5>
<p>${ company_name }</p>
2018-01-25 03:48:32 +00:00
</div>
</a>
2017-12-10 16:32:41 +00:00
</div>
`;
}
};
erpnext.hub.CompanyListing = class CompanyListing extends frappe.views.BaseList {
2018-01-25 03:48:32 +00:00
};