diff --git a/static/js/vue-cdr-access/src/components/full_record/aggregateRecord.vue b/static/js/vue-cdr-access/src/components/full_record/aggregateRecord.vue index 0f6efdfb38..8f3659e6d6 100644 --- a/static/js/vue-cdr-access/src/components/full_record/aggregateRecord.vue +++ b/static/js/vue-cdr-access/src/components/full_record/aggregateRecord.vue @@ -69,7 +69,8 @@

{{ $t('full_record.item_list') }} ({{ childCount }})

+ :work-id="recordData.briefObject.id" + :child-count="childCount">
- - - - + + + + {{ $t('full_record.bulk_download') }} ({{ formatFilesize(totalDownloadSize) }}) @@ -35,10 +38,19 @@ export default { default: false, type: Boolean }, + childCount: { + default: null, + type: Number + }, workId: String }, computed: { + hasTooManyChildren() { + // Based off of the limit set in DownloadBulkService + return this.childCount > 100; + }, + hasDownloadableContent() { return this.hasBulkDownloadAccess && this.totalDownloadSize !== null; }, @@ -46,6 +58,21 @@ export default { showTotalFilesize() { return this.hasBulkDownloadAccess && this.totalDownloadSize <= ONE_GIGABYTE; } + }, + + methods: { + handleDownload(event) { + if (this.hasTooManyChildren) { + // Prevent navigation if user cancels + if (!confirm("Number of files exceeds the download limit, only the first 100 will be exported. Do you want to continue?")) { + return; + } + } + + // Trigger the download + const link = event.target.closest('a'); + window.location.href = link.href; + } } } - \ No newline at end of file + diff --git a/static/js/vue-cdr-access/tests/unit/bulkDownload.spec.js b/static/js/vue-cdr-access/tests/unit/bulkDownload.spec.js index 26323bdff5..f6e895bb33 100644 --- a/static/js/vue-cdr-access/tests/unit/bulkDownload.spec.js +++ b/static/js/vue-cdr-access/tests/unit/bulkDownload.spec.js @@ -22,6 +22,7 @@ describe('bulkDownload.vue', () => { totalDownloadSize: 8193, hasBulkDownloadAccess: true, workId: work_id, + childCount: 5 } }); }); @@ -68,4 +69,49 @@ describe('bulkDownload.vue', () => { let download_link = wrapper.find('.actionlink'); expect(download_link.exists()).toBe(false); }); -}); \ No newline at end of file + + it ("prompts user for confirmation if there are more than 100 files", async () => { + // Mock window.confirm + const confirmMock = jest.spyOn(window, 'confirm'); + + // Mock return values for confirm + confirmMock.mockImplementationOnce(() => false); // Simulate "No" click + confirmMock.mockImplementationOnce(() => true); // Simulate "Yes" click + + // Mock navigation + const locationMock = jest.spyOn(window, 'location', 'get'); + const mockLocation = { href: '' }; + locationMock.mockReturnValue(mockLocation); + + await wrapper.setProps({ + childCount: 200 + }); + + let download_link = wrapper.find('.bulk-download-link'); + let download_email = wrapper.find('.bulk-download-email'); + + expect(download_link.exists()).toBe(true); + expect(download_email.exists()).toBe(false); + expect(download_link.attributes('href')).toEqual(expect.stringContaining(`/services/api/bulkDownload/${work_id}`)); + expect(download_link.text()).toEqual(expect.stringContaining('Download All Files (8 KB)')); + + // Trigger the click (simulating user action) + await download_link.trigger('click'); + expect(window.confirm).toHaveBeenCalledWith( + "Number of files exceeds the download limit, only the first 100 will be exported. Do you want to continue?" + ); + + // Verify that "No" prevents navigation + expect(mockLocation.href).toBe(''); + + // Simulate another click with "Yes" + await download_link.trigger('click'); + expect(window.confirm).toBeCalledTimes(2); + // Download should occur this time + expect(mockLocation.href).toContain(`/services/api/bulkDownload/${work_id}`); + + // Cleanup mocks + confirmMock.mockRestore(); + locationMock.mockRestore(); + }); +});