summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/packages/details/components/app.vue
diff options
context:
space:
mode:
Diffstat (limited to 'app/assets/javascripts/packages/details/components/app.vue')
-rw-r--r--app/assets/javascripts/packages/details/components/app.vue101
1 files changed, 75 insertions, 26 deletions
diff --git a/app/assets/javascripts/packages/details/components/app.vue b/app/assets/javascripts/packages/details/components/app.vue
index bcfb17a1529..55ffe10a608 100644
--- a/app/assets/javascripts/packages/details/components/app.vue
+++ b/app/assets/javascripts/packages/details/components/app.vue
@@ -13,7 +13,7 @@ import {
import { mapActions, mapState } from 'vuex';
import { objectToQueryString } from '~/lib/utils/common_utils';
import { numberToHumanSize } from '~/lib/utils/number_utils';
-import { s__ } from '~/locale';
+import { s__, __ } from '~/locale';
import Tracking from '~/tracking';
import PackageListRow from '../../shared/components/package_list_row.vue';
import PackagesListLoader from '../../shared/components/packages_list_loader.vue';
@@ -24,7 +24,6 @@ import DependencyRow from './dependency_row.vue';
import InstallationCommands from './installation_commands.vue';
import PackageFiles from './package_files.vue';
import PackageHistory from './package_history.vue';
-import PackageTitle from './package_title.vue';
export default {
name: 'PackagesApp',
@@ -36,7 +35,9 @@ export default {
GlTab,
GlTabs,
GlSprintf,
- PackageTitle,
+ PackageTitle: () => import('./package_title.vue'),
+ TerraformTitle: () =>
+ import('~/packages_and_registries/infrastructure_registry/components/details_title.vue'),
PackagesListLoader,
PackageListRow,
DependencyRow,
@@ -50,7 +51,18 @@ export default {
GlModal: GlModalDirective,
},
mixins: [Tracking.mixin()],
+ inject: {
+ titleComponent: {
+ default: 'PackageTitle',
+ from: 'titleComponent',
+ },
+ },
trackingActions: { ...TrackingActions },
+ data() {
+ return {
+ fileToDelete: null,
+ };
+ },
computed: {
...mapState([
'projectName',
@@ -86,13 +98,10 @@ export default {
},
},
methods: {
- ...mapActions(['deletePackage', 'fetchPackageVersions']),
+ ...mapActions(['deletePackage', 'fetchPackageVersions', 'deletePackageFile']),
formatSize(size) {
return numberToHumanSize(size);
},
- cancelDelete() {
- this.$refs.deleteModal.hide();
- },
getPackageVersions() {
if (!this.packageEntity.versions) {
this.fetchPackageVersions();
@@ -108,12 +117,43 @@ export default {
const modalQuery = objectToQueryString({ [SHOW_DELETE_SUCCESS_ALERT]: true });
window.location.replace(`${returnTo}?${modalQuery}`);
},
+ handleFileDelete(file) {
+ this.track(TrackingActions.REQUEST_DELETE_PACKAGE_FILE);
+ this.fileToDelete = { ...file };
+ this.$refs.deleteFileModal.show();
+ },
+ confirmFileDelete() {
+ this.track(TrackingActions.DELETE_PACKAGE_FILE);
+ this.deletePackageFile(this.fileToDelete.id);
+ this.fileToDelete = null;
+ },
},
i18n: {
deleteModalTitle: s__(`PackageRegistry|Delete Package Version`),
deleteModalContent: s__(
`PackageRegistry|You are about to delete version %{version} of %{name}. Are you sure?`,
),
+ deleteFileModalTitle: s__(`PackageRegistry|Delete Package File`),
+ deleteFileModalContent: s__(
+ `PackageRegistry|You are about to delete %{filename}. This is a destructive action that may render your package unusable. Are you sure?`,
+ ),
+ },
+ modal: {
+ packageDeletePrimaryAction: {
+ text: __('Delete'),
+ attributes: [
+ { variant: 'danger' },
+ { category: 'primary' },
+ { 'data-qa-selector': 'delete_modal_button' },
+ ],
+ },
+ fileDeletePrimaryAction: {
+ text: __('Delete'),
+ attributes: [{ variant: 'danger' }, { category: 'primary' }],
+ },
+ cancelAction: {
+ text: __('Cancel'),
+ },
},
};
</script>
@@ -127,7 +167,7 @@ export default {
/>
<div v-else class="packages-app">
- <package-title>
+ <component :is="titleComponent">
<template #delete-button>
<gl-button
v-if="canDelete"
@@ -140,7 +180,7 @@ export default {
{{ __('Delete') }}
</gl-button>
</template>
- </package-title>
+ </component>
<gl-tabs>
<gl-tab :title="__('Detail')">
@@ -159,7 +199,9 @@ export default {
<package-files
v-if="showFiles"
:package-files="packageFiles"
+ :can-delete="canDelete"
@download-file="track($options.trackingActions.PULL_PACKAGE)"
+ @delete-file="handleFileDelete"
/>
</gl-tab>
@@ -210,7 +252,15 @@ export default {
</gl-tab>
</gl-tabs>
- <gl-modal ref="deleteModal" class="js-delete-modal" modal-id="delete-modal">
+ <gl-modal
+ ref="deleteModal"
+ class="js-delete-modal"
+ modal-id="delete-modal"
+ :action-primary="$options.modal.packageDeletePrimaryAction"
+ :action-cancel="$options.modal.cancelAction"
+ @primary="confirmPackageDeletion"
+ @canceled="track($options.trackingActions.CANCEL_DELETE_PACKAGE)"
+ >
<template #modal-title>{{ $options.i18n.deleteModalTitle }}</template>
<gl-sprintf :message="$options.i18n.deleteModalContent">
<template #version>
@@ -221,23 +271,22 @@ export default {
<strong>{{ packageEntity.name }}</strong>
</template>
</gl-sprintf>
+ </gl-modal>
- <template #modal-footer>
- <div class="gl-w-full">
- <div class="float-right">
- <gl-button @click="cancelDelete">{{ __('Cancel') }}</gl-button>
- <gl-button
- ref="modal-delete-button"
- variant="danger"
- category="primary"
- data-qa-selector="delete_modal_button"
- @click="confirmPackageDeletion"
- >
- {{ __('Delete') }}
- </gl-button>
- </div>
- </div>
- </template>
+ <gl-modal
+ ref="deleteFileModal"
+ modal-id="delete-file-modal"
+ :action-primary="$options.modal.fileDeletePrimaryAction"
+ :action-cancel="$options.modal.cancelAction"
+ @primary="confirmFileDelete"
+ @canceled="track($options.trackingActions.CANCEL_DELETE_PACKAGE_FILE)"
+ >
+ <template #modal-title>{{ $options.i18n.deleteFileModalTitle }}</template>
+ <gl-sprintf v-if="fileToDelete" :message="$options.i18n.deleteFileModalContent">
+ <template #filename>
+ <strong>{{ fileToDelete.file_name }}</strong>
+ </template>
+ </gl-sprintf>
</gl-modal>
</div>
</template>