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();
+ });
+});