diff --git a/cypress/e2e/cps-table.cy.ts b/cypress/e2e/cps-table.cy.ts new file mode 100644 index 00000000..a1104afe --- /dev/null +++ b/cypress/e2e/cps-table.cy.ts @@ -0,0 +1,25 @@ +import path = require('path'); + +describe('cps-table page', () => { + describe('export to xlsx', () => { + beforeEach(() => { + cy.visit('/table'); + }); + + it('should properly download valid xlsx', () => { + cy.contains('Table 6').click({ force: true }); + cy.get('.cps-table-tbar-export-btn cps-icon').click(); + cy.contains('XLSX').click(); + + const downloadsFolder = Cypress.config('downloadsFolder'); + const downloadedFilePath = path.join(downloadsFolder, 'table_6.xlsx'); + cy.readFile(downloadedFilePath).should('exist'); + + cy.fixture('table_6_fixture.xlsx').then((fixtureContent) => { + cy.readFile(downloadedFilePath).then((downloadedFileContent) => { + expect(downloadedFileContent).equals(fixtureContent); + }); + }); + }); + }); +}); diff --git a/cypress/fixtures/table_6_fixture.xlsx b/cypress/fixtures/table_6_fixture.xlsx new file mode 100644 index 00000000..65dabcf9 Binary files /dev/null and b/cypress/fixtures/table_6_fixture.xlsx differ diff --git a/package-lock.json b/package-lock.json index 3c7011a0..3e9c3a9a 100644 --- a/package-lock.json +++ b/package-lock.json @@ -17,13 +17,13 @@ "@angular/platform-browser-dynamic": "^19.1.4", "@angular/platform-server": "^19.1.4", "@angular/router": "^19.1.4", + "@e965/xlsx": "^0.20.3", "@types/lodash-es": "^4.17.12", "eslint-plugin-cypress": "^3.6.0", "lodash-es": "^4.17.21", "primeng": "^19.0.5", "rxjs": "~7.8.1", "tslib": "^2.8.1", - "xlsx": "^0.18.5", "zone.js": "^0.15.0" }, "devDependencies": { @@ -2582,6 +2582,18 @@ "node": ">=14.17.0" } }, + "node_modules/@e965/xlsx": { + "version": "0.20.3", + "resolved": "https://registry.npmjs.org/@e965/xlsx/-/xlsx-0.20.3.tgz", + "integrity": "sha512-703RN/3OdsRD5mtse2HBX7Um7xwaP9tlswEG6svOtjqokXoX7rJdQj7DyabD2I+xk22RgaIIU+R6BHgkpZGB/w==", + "license": "Apache-2.0", + "bin": { + "xlsx": "bin/xlsx.njs" + }, + "engines": { + "node": ">=0.8" + } + }, "node_modules/@esbuild/aix-ppc64": { "version": "0.24.2", "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.24.2.tgz", @@ -6962,15 +6974,6 @@ "node": ">=8.9.0" } }, - "node_modules/adler-32": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/adler-32/-/adler-32-1.3.1.tgz", - "integrity": "sha512-ynZ4w/nUUv5rrsR8UUGoe1VC9hZj6V5hU9Qw1HlMDJGEJw5S7TfTErWTjMys6M7vr0YWcPqs3qAr4ss0nDfP+A==", - "license": "Apache-2.0", - "engines": { - "node": ">=0.8" - } - }, "node_modules/agent-base": { "version": "7.1.3", "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.3.tgz", @@ -8397,19 +8400,6 @@ "url": "https://github.com/sponsors/wooorm" } }, - "node_modules/cfb": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/cfb/-/cfb-1.2.2.tgz", - "integrity": "sha512-KfdUZsSOw19/ObEWasvBP/Ac4reZvAGauZhs6S/gqNhXhI7cKwvlH7ulj+dOEYnca4bm4SGo8C1bTAQvnTjgQA==", - "license": "Apache-2.0", - "dependencies": { - "adler-32": "~1.3.0", - "crc-32": "~1.2.0" - }, - "engines": { - "node": ">=0.8" - } - }, "node_modules/chalk": { "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", @@ -8749,15 +8739,6 @@ "node": ">= 0.12.0" } }, - "node_modules/codepage": { - "version": "1.15.0", - "resolved": "https://registry.npmjs.org/codepage/-/codepage-1.15.0.tgz", - "integrity": "sha512-3g6NUTPd/YtuuGrhMnOMRjFc+LJw/bnMp3+0r/Wcz3IXUuCosKRJvMphm5+Q+bvTVGcJJuRvVLuYba+WojaFaA==", - "license": "Apache-2.0", - "engines": { - "node": ">=0.8" - } - }, "node_modules/collect-v8-coverage": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.2.tgz", @@ -9150,18 +9131,6 @@ } } }, - "node_modules/crc-32": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/crc-32/-/crc-32-1.2.2.tgz", - "integrity": "sha512-ROmzCKrTnOwybPcJApAA6WBWij23HVfGVNKqqrZpuyZOHqK2CwHSvpGuyt/UNNvaIjEd8X5IFGp4Mh+Ie1IHJQ==", - "license": "Apache-2.0", - "bin": { - "crc32": "bin/crc32.njs" - }, - "engines": { - "node": ">=0.8" - } - }, "node_modules/create-jest": { "version": "29.7.0", "resolved": "https://registry.npmjs.org/create-jest/-/create-jest-29.7.0.tgz", @@ -12224,15 +12193,6 @@ "node": ">= 0.6" } }, - "node_modules/frac": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/frac/-/frac-1.1.2.tgz", - "integrity": "sha512-w/XBfkibaTl3YDqASwfDUqkna4Z2p9cFSr1aHDt0WoMTECnRfBOv2WArlZILlqgWlmdIlALXGpM2AOhEk5W3IA==", - "license": "Apache-2.0", - "engines": { - "node": ">=0.8" - } - }, "node_modules/fraction.js": { "version": "4.3.7", "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.3.7.tgz", @@ -20200,18 +20160,6 @@ "dev": true, "license": "BSD-3-Clause" }, - "node_modules/ssf": { - "version": "0.11.2", - "resolved": "https://registry.npmjs.org/ssf/-/ssf-0.11.2.tgz", - "integrity": "sha512-+idbmIXoYET47hH+d7dfm2epdOMUDjqcB4648sTZ+t2JwoyBFL/insLfB/racrDmsKB3diwsDA696pZMieAC5g==", - "license": "Apache-2.0", - "dependencies": { - "frac": "~1.1.2" - }, - "engines": { - "node": ">=0.8" - } - }, "node_modules/sshpk": { "version": "1.18.0", "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.18.0.tgz", @@ -22458,24 +22406,6 @@ "dev": true, "license": "MIT" }, - "node_modules/wmf": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/wmf/-/wmf-1.0.2.tgz", - "integrity": "sha512-/p9K7bEh0Dj6WbXg4JG0xvLQmIadrner1bi45VMJTfnbVHsc7yIajZyoSoK60/dtVBs12Fm6WkUI5/3WAVsNMw==", - "license": "Apache-2.0", - "engines": { - "node": ">=0.8" - } - }, - "node_modules/word": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/word/-/word-0.3.0.tgz", - "integrity": "sha512-OELeY0Q61OXpdUfTp+oweA/vtLVg5VDOXh+3he3PNzLGG/y0oylSOC1xRVj0+l4vQ3tj/bB1HVHv1ocXkQceFA==", - "license": "Apache-2.0", - "engines": { - "node": ">=0.8" - } - }, "node_modules/word-wrap": { "version": "1.2.5", "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", @@ -22577,27 +22507,6 @@ "node": ">= 6" } }, - "node_modules/xlsx": { - "version": "0.18.5", - "resolved": "https://registry.npmjs.org/xlsx/-/xlsx-0.18.5.tgz", - "integrity": "sha512-dmg3LCjBPHZnQp5/F/+nnTa+miPJxUXB6vtk42YjBBKayDNagxGEeIdWApkYPOf3Z3pm3k62Knjzp7lMeTEtFQ==", - "license": "Apache-2.0", - "dependencies": { - "adler-32": "~1.3.0", - "cfb": "~1.2.1", - "codepage": "~1.15.0", - "crc-32": "~1.2.1", - "ssf": "~0.11.2", - "wmf": "~1.0.1", - "word": "~0.3.0" - }, - "bin": { - "xlsx": "bin/xlsx.njs" - }, - "engines": { - "node": ">=0.8" - } - }, "node_modules/xml-name-validator": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-4.0.0.tgz", diff --git a/package.json b/package.json index dccb2695..0c89e9d6 100644 --- a/package.json +++ b/package.json @@ -24,13 +24,13 @@ "@angular/platform-browser-dynamic": "^19.1.4", "@angular/platform-server": "^19.1.4", "@angular/router": "^19.1.4", + "@e965/xlsx": "^0.20.3", "@types/lodash-es": "^4.17.12", "eslint-plugin-cypress": "^3.6.0", "lodash-es": "^4.17.21", "primeng": "^19.0.5", "rxjs": "~7.8.1", "tslib": "^2.8.1", - "xlsx": "^0.18.5", "zone.js": "^0.15.0" }, "devDependencies": { diff --git a/projects/cps-ui-kit/package.json b/projects/cps-ui-kit/package.json index e32000de..bf909871 100644 --- a/projects/cps-ui-kit/package.json +++ b/projects/cps-ui-kit/package.json @@ -10,7 +10,7 @@ "@types/lodash-es": "^4.17.12", "lodash-es": "^4.17.21", "primeng": "^19.0.5", - "xlsx": "^0.18.5" + "@e965/xlsx": "^0.20.3" }, "repository": { "type": "git", diff --git a/projects/cps-ui-kit/src/lib/components/cps-table/cps-table.component.ts b/projects/cps-ui-kit/src/lib/components/cps-table/cps-table.component.ts index 00248411..6132eb95 100644 --- a/projects/cps-ui-kit/src/lib/components/cps-table/cps-table.component.ts +++ b/projects/cps-ui-kit/src/lib/components/cps-table/cps-table.component.ts @@ -981,7 +981,7 @@ export class CpsTableComponent implements OnInit, AfterViewChecked, OnChanges { } exportXLSX() { - import('xlsx').then((xlsx) => { + import('@e965/xlsx').then((xlsx) => { const sheetData = [ this.selectedColumns.map( (c: { [key: string]: any }) => c[this.colHeaderName]