import $ from 'jquery'; import dt from 'datatables.net'; import resp from 'datatables.net-responsive'; import resp2 from 'datatables.net-responsive-dt'; import {setting, getAPiUrl, getAssetURL, } from './utils.js'; import {i18n} from './i18n'; import {html, LitElement} from 'lit-element'; import JSONLD from 'vpu-common/jsonld'; import commonUtils from 'vpu-common/utils'; import {unsafeHTML} from 'lit-html/directives/unsafe-html.js'; dt(window, $); resp(window, $); class DataTableView extends LitElement { constructor() { super(); this.lang = 'de'; this.entryPointUrl = getAPiUrl(); this.jsonld = null; this.value = null; this.filter = null; this.apiUrl = null; this.whitelist_cols = '*'; this.blacklist_cols = ''; this.table_columns = []; // all possible columns, defined by API entity this.show_columns = []; // all columns visible in table, defined by property whhitelist/blacklist this.display_columns = []; // all possible columns, in desired order for the table // datatable properties this.table = null; this.responsive = null; this.paging = 1; this.searching = 1; // this.is_loading = false; } static get properties() { return { lang: { type: String }, value: { type: String }, entryPointUrl: { type: String, attribute: 'entry-point-url' }, filter: { type: String }, apiUrl: { type: String, attribute: false }, whitelist_cols: { type: String, attribute: 'whitelisted-columns' }, blacklist_cols: { type: String, attribute: 'blacklisted-columns' }, table_columns: { type: Array, attribute: false }, show_columns: { type: Array, attribute: false }, display_columns: { type: Array, attribute: false }, table: { type: Object, attribute: false }, paging: { type: String }, searching: { type: String }, is_loading: { type: Boolean }, }; } connectedCallback() { super.connectedCallback(); const that = this; JSONLD.initialize(this.entryPointUrl, function (jsonld) { that.jsonld = jsonld; that.apiUrl = that.jsonld.getApiUrlForIdentifier("http://schema.org/" + that.value); that.table_columns = that.jsonld.entities[that.value]['hydra:supportedProperty'].map(obj => obj['hydra:title']); // display empty table that.setup_columns(); let columns = []; for (let i = 0; i < that.display_columns.length; ++i) { columns[i] = { title: that.display_columns[i], visible: that.show_columns.indexOf(that.display_columns[i]) > -1 }; } that.set_datatable(columns); if (that.filter) { that.loadWebPageElement(); } }); // disabled, load first on toggle to visible window.addEventListener("vpu-auth-init", () => that.loadWebPageElement()); } setup_columns() { //let cols = this.table_columns.slice(); if (this.whitelist_cols === '*') { const blacklist_cols = this.blacklist_cols.split(' '); this.show_columns = this.table_columns.filter(col => blacklist_cols.indexOf(col) === -1); } else { this.show_columns = this.whitelist_cols.split(' '); } this.display_columns = this.show_columns.slice(); for(let i=0; i < this.table_columns.length; ++i) { if (this.display_columns.indexOf(this.table_columns[i]) === -1) this.display_columns.push(this.table_columns[i]); } } set_datatable(columns) { const lang_de_url = 'datatables/i18n/German.json'; const lang_en_url = 'datatables/i18n/English.json'; this.table = $(this.shadowRoot.querySelector('#dt')).DataTable({ destroy: true, autoWidth: false, language: { url: this.lang === 'de' ? lang_de_url : lang_en_url, }, columns: columns, data: [], paging: this.paging > 0, searching: this.searching > 0, }); } update_datatable(columns, rows) { //console.log('rows = ' + rows); const that = this; if (this.table) { this.table.clear(); columns.forEach(function (item, index) { that.table.columns([index]).visible(item.visible === true); }); rows.forEach(row => this.table.row.add(row)); // missing responsive? if (this.responsive === null) { console.log('update_datatable(), responsive:'); this.responsive = new $.fn.dataTable.Responsive(this.table, { details: true }); console.dir(this.responsive); } // now ready to draw this.table.draw(); } } loadWebPageElement() { if (window.VPUAuthToken === undefined || window.VPUAuthToken === "") { return; } if (this.apiUrl === null || this.jsonld === null) { return; } const apiUrlWithFilter = this.apiUrl + '?search=' + this.filter; console.log('apiUrlWithFilter = ' + apiUrlWithFilter); const that = this; this.is_loading = true; fetch(apiUrlWithFilter, { headers: { 'Content-Type': 'application/ld+json', 'Authorization': 'Bearer ' + window.VPUAuthToken, }, }) .then(res => res.json()) .then(function (data) { // TODO that.setup_columns(); const items = data['hydra:member']; let rows = []; let columns = []; for(let i=0; i < that.display_columns.length; ++i) { columns[i] = { title: that.display_columns[i], visible: that.show_columns.indexOf(that.display_columns[i]) > -1 }; for(let j=0; j < items.length; ++j) { if (rows[j] === undefined) { rows[j] = []; } rows[j][i] = items[j][that.display_columns[i]] || ''; } } that.update_datatable(columns, rows); that.is_loading = false; }) .catch(); } update(changedProperties) { changedProperties.forEach((oldValue, propName) => { // noinspection FallThroughInSwitchStatementJS switch (propName) { case "lang": i18n.changeLanguage(this.lang); break; case "filter": case "whitelist_cols": case "blacklist_cols": case "paging": case "searching": this.loadWebPageElement(); break; case "value": case "entryPointUrl": const that = this; JSONLD.initialize(this.entryPointUrl, function (jsonld) { that.jsonld = jsonld; that.apiUrl = that.jsonld.getApiUrlForIdentifier("http://schema.org/" + that.value); }); this.loadWebPageElement(); break; } }); super.update(changedProperties); } render() { let dt_css = getAssetURL('datatables/css/jquery.dataTables.min.css'); let rs_css = getAssetURL('datatables/css/responsive.dataTables.css'); return html` <link rel="stylesheet" href="${dt_css}"> <link rel="stylesheet" href="${rs_css}"> <style> #dt-parent { display: block; width: 100%; min-height: 50px; position: relative; } #cover { display: ${this.is_loading ? 'block' : 'none'}; position: absolute; left: 0; top: 0; width: 100%; height: 100%; /* margin: 0 auto; */ z-index: 999; background: white url("") center center no-repeat; opacity: .9; } #dt { min-width: 100px; width: 100%; } </style> <div id="dt-parent"> ${unsafeHTML('<div><table id="dt" class="display"></table></div>')} <div id="cover"></div> </div> `; } } commonUtils.defineCustomElement('vpu-data-table-view', DataTableView);