Fixed #1845 - Add data param to exportCSV method on DataTable

pull/1770/head
mertsincan 2021-12-06 10:18:55 +03:00
parent 8f8c97f8ad
commit e08fd2d1d0
4 changed files with 39 additions and 30 deletions

View File

@ -1032,9 +1032,10 @@ export declare type DataTableEmits = {
declare class DataTable extends ClassComponent<DataTableProps, DataTableSlots, DataTableEmits> {
/**
* Exports the data to CSV format.
* @param {DataTableExportCSVOptions} options - Export options.
* @param {DataTableExportCSVOptions} [options] - Export options.
* @param {Object[]} [data] - Custom exportable data. This param can be used on lazy dataTable.
*/
exportCSV: (options?: DataTableExportCSVOptions) => void;
exportCSV: (options?: DataTableExportCSVOptions, data?: any[]) => void;
}
declare module '@vue/runtime-core' {

View File

@ -997,14 +997,17 @@ export default {
this.$emit('update:selection', _selection);
},
exportCSV(options) {
let data = this.processedData;
exportCSV(options, data) {
let csv = '\ufeff';
if (!data) {
data = this.processedData;
if (options && options.selectionOnly)
data = this.selection || [];
else if (this.frozenValue)
data = data ? [...this.frozenValue, ...data] : this.frozenValue;
}
//headers
let headerInitiated = false;
@ -1055,28 +1058,7 @@ export default {
});
}
let blob = new Blob([csv], {
type: 'text/csv;charset=utf-8;'
});
if (window.navigator.msSaveOrOpenBlob) {
navigator.msSaveOrOpenBlob(blob, this.exportFilename + '.csv');
}
else {
let link = document.createElement("a");
link.style.display = 'none';
document.body.appendChild(link);
if (link.download !== undefined) {
link.setAttribute('href', URL.createObjectURL(blob));
link.setAttribute('download', this.exportFilename + '.csv');
link.click();
}
else {
csv = 'data:text/csv;charset=utf-8,' + csv;
window.open(encodeURI(csv));
}
document.body.removeChild(link);
}
DomHandler.exportCSV(csv, this.exportFilename);
},
resetPage() {
this.d_first = 0;

View File

@ -507,5 +507,30 @@ export default {
isTouchDevice() {
return (('ontouchstart' in window) || (navigator.maxTouchPoints > 0) || (navigator.msMaxTouchPoints > 0));
},
exportCSV(csv, filename) {
let blob = new Blob([csv], {
type: 'application/csv;charset=utf-8;'
});
if (window.navigator.msSaveOrOpenBlob) {
navigator.msSaveOrOpenBlob(blob, filename + '.csv');
}
else {
let link = document.createElement("a");
if (link.download !== undefined) {
link.setAttribute('href', URL.createObjectURL(blob));
link.setAttribute('download', filename + '.csv');
link.style.display = 'none';
document.body.appendChild(link);
link.click();
document.body.removeChild(link);
}
else {
csv = 'data:text/csv;charset=utf-8,' + csv;
window.open(encodeURI(csv));
}
}
}
}

View File

@ -49,6 +49,7 @@ export declare class DomHandler {
static isIOS(): boolean;
static isAndroid(): boolean;
static isTouchDevice(): boolean;
static exportCSV(csv: any, filename: string): void;
}
export declare class ObjectUtils {