68 lines
1.9 KiB
JavaScript
68 lines
1.9 KiB
JavaScript
import { propertyOf } from 'lodash';
|
|
import getDesignListQuery from 'shared_queries/design_management/get_design_list.query.graphql';
|
|
import { createAlert, VARIANT_WARNING } from '~/alert';
|
|
import { s__ } from '~/locale';
|
|
import { DESIGNS_ROUTE_NAME } from '../router/constants';
|
|
import allVersionsMixin from './all_versions';
|
|
|
|
export default {
|
|
mixins: [allVersionsMixin],
|
|
apollo: {
|
|
designCollection: {
|
|
query: getDesignListQuery,
|
|
variables() {
|
|
return {
|
|
fullPath: this.projectPath,
|
|
iid: this.issueIid,
|
|
atVersion: this.designsVersion,
|
|
};
|
|
},
|
|
update: (data) => {
|
|
const designNodes = propertyOf(data)([
|
|
'project',
|
|
'issue',
|
|
'designCollection',
|
|
'designs',
|
|
'nodes',
|
|
]);
|
|
const copyState = propertyOf(data)(['project', 'issue', 'designCollection', 'copyState']);
|
|
return {
|
|
designs: designNodes,
|
|
copyState,
|
|
};
|
|
},
|
|
error() {
|
|
this.error = true;
|
|
},
|
|
result() {
|
|
if (this.$route.query.version && !this.hasValidVersion) {
|
|
createAlert({
|
|
message: s__(
|
|
'DesignManagement|Requested design version does not exist. Showing latest version instead',
|
|
),
|
|
});
|
|
this.$router.replace({ name: DESIGNS_ROUTE_NAME, query: { version: undefined } });
|
|
}
|
|
if (this.designCollection.copyState === 'ERROR') {
|
|
createAlert({
|
|
message: s__(
|
|
'DesignManagement|There was an error moving your designs. Please upload your designs below.',
|
|
),
|
|
variant: VARIANT_WARNING,
|
|
});
|
|
}
|
|
},
|
|
},
|
|
},
|
|
data() {
|
|
return {
|
|
designCollection: null,
|
|
error: false,
|
|
};
|
|
},
|
|
computed: {
|
|
designs() {
|
|
return this.designCollection?.designs || [];
|
|
},
|
|
},
|
|
};
|