Move profile conflict notice to its own component

parent a22c7bc5
...@@ -37,6 +37,7 @@ import { ...@@ -37,6 +37,7 @@ import {
SCANNER_PROFILES_QUERY, SCANNER_PROFILES_QUERY,
SITE_PROFILES_QUERY, SITE_PROFILES_QUERY,
} from '../settings'; } from '../settings';
import ProfileConflictAlert from './profile_selector/profile_conflict_alert.vue';
import ScannerProfileSelector from './profile_selector/scanner_profile_selector.vue'; import ScannerProfileSelector from './profile_selector/scanner_profile_selector.vue';
import SiteProfileSelector from './profile_selector/site_profile_selector.vue'; import SiteProfileSelector from './profile_selector/site_profile_selector.vue';
import ScanSchedule from './scan_schedule.vue'; import ScanSchedule from './scan_schedule.vue';
...@@ -69,6 +70,7 @@ export default { ...@@ -69,6 +70,7 @@ export default {
saveScanBtnId: 'scan-save-button', saveScanBtnId: 'scan-save-button',
components: { components: {
RefSelector, RefSelector,
ProfileConflictAlert,
ScannerProfileSelector, ScannerProfileSelector,
SiteProfileSelector, SiteProfileSelector,
ScanSchedule, ScanSchedule,
...@@ -102,7 +104,7 @@ export default { ...@@ -102,7 +104,7 @@ export default {
SITE_PROFILES_QUERY, SITE_PROFILES_QUERY,
), ),
}, },
inject: ['projectPath', 'helpPagePath', 'dastSiteValidationDocsPath', 'profilesLibraryPath'], inject: ['projectPath', 'helpPagePath', 'profilesLibraryPath'],
props: { props: {
defaultBranch: { defaultBranch: {
type: String, type: String,
...@@ -454,25 +456,10 @@ export default { ...@@ -454,25 +456,10 @@ export default {
<scan-schedule v-if="glFeatures.dastOnDemandScansScheduler" v-model="profileSchedule" /> <scan-schedule v-if="glFeatures.dastOnDemandScansScheduler" v-model="profileSchedule" />
<gl-alert <profile-conflict-alert
v-if="hasProfilesConflict" v-if="hasProfilesConflict"
:title="s__('OnDemandScans|You cannot run an active scan against an unvalidated site.')"
:dismissible="false"
variant="danger"
data-testid="on-demand-scans-profiles-conflict-alert" data-testid="on-demand-scans-profiles-conflict-alert"
> />
<gl-sprintf
:message="
s__(
'OnDemandScans|You can either choose a passive scan or validate the target site in your chosen site profile. %{docsLinkStart}Learn more about site validation.%{docsLinkEnd}',
)
"
>
<template #docsLink="{ content }">
<gl-link :href="dastSiteValidationDocsPath">{{ content }}</gl-link>
</template>
</gl-sprintf>
</gl-alert>
<div class="gl-mt-6 gl-pt-6"> <div class="gl-mt-6 gl-pt-6">
<gl-button <gl-button
......
<script> <script>
import { GlCard, GlSkeletonLoader, GlAlert, GlSprintf, GlLink } from '@gitlab/ui'; import { GlCard, GlSkeletonLoader } from '@gitlab/ui';
import * as Sentry from '@sentry/browser'; import * as Sentry from '@sentry/browser';
import { SCAN_TYPE } from 'ee/security_configuration/dast_profiles/dast_scanner_profiles/constants'; import { SCAN_TYPE } from 'ee/security_configuration/dast_profiles/dast_scanner_profiles/constants';
import { DAST_SITE_VALIDATION_STATUS } from 'ee/security_configuration/dast_site_validation/constants'; import { DAST_SITE_VALIDATION_STATUS } from 'ee/security_configuration/dast_site_validation/constants';
import { TYPE_SCANNER_PROFILE, TYPE_SITE_PROFILE } from '~/graphql_shared/constants'; import { TYPE_SCANNER_PROFILE, TYPE_SITE_PROFILE } from '~/graphql_shared/constants';
import { convertToGraphQLId } from '~/graphql_shared/utils'; import { convertToGraphQLId } from '~/graphql_shared/utils';
import { helpPagePath } from '~/helpers/help_page_helper';
import { queryToObject } from '~/lib/utils/url_utility'; import { queryToObject } from '~/lib/utils/url_utility';
import { ERROR_MESSAGES, SCANNER_PROFILES_QUERY, SITE_PROFILES_QUERY } from '../../settings'; import { ERROR_MESSAGES, SCANNER_PROFILES_QUERY, SITE_PROFILES_QUERY } from '../../settings';
import ProfileConflictAlert from './profile_conflict_alert.vue';
import ScannerProfileSelector from './scanner_profile_selector.vue'; import ScannerProfileSelector from './scanner_profile_selector.vue';
import SiteProfileSelector from './site_profile_selector.vue'; import SiteProfileSelector from './site_profile_selector.vue';
...@@ -36,11 +36,9 @@ export default { ...@@ -36,11 +36,9 @@ export default {
components: { components: {
GlCard, GlCard,
GlSkeletonLoader, GlSkeletonLoader,
GlAlert, ProfileConflictAlert,
GlSprintf,
ScannerProfileSelector, ScannerProfileSelector,
SiteProfileSelector, SiteProfileSelector,
GlLink,
}, },
inject: ['fullPath'], inject: ['fullPath'],
apollo: { apollo: {
...@@ -63,9 +61,6 @@ export default { ...@@ -63,9 +61,6 @@ export default {
selectedSiteProfileId: null, selectedSiteProfileId: null,
errorType: null, errorType: null,
errors: [], errors: [],
dastSiteValidationDocsPath: helpPagePath('user/application_security/dast/index', {
anchor: 'site-profile-validation',
}),
}; };
}, },
computed: { computed: {
...@@ -158,26 +153,11 @@ export default { ...@@ -158,26 +153,11 @@ export default {
:has-conflict="hasProfilesConflict" :has-conflict="hasProfilesConflict"
/> />
<gl-alert <profile-conflict-alert
v-if="hasProfilesConflict" v-if="hasProfilesConflict"
:title="s__('DastProfiles|You cannot run an active scan against an unvalidated site.')"
class="gl-mb-5" class="gl-mb-5"
:dismissible="false"
variant="danger"
data-testid="dast-profiles-conflict-alert" data-testid="dast-profiles-conflict-alert"
> />
<gl-sprintf
:message="
s__(
'DastProfiles|You can either choose a passive scan or validate the target site in your chosen site profile. %{docsLinkStart}Learn more about site validation.%{docsLinkEnd}',
)
"
>
<template #docsLink="{ content }">
<gl-link :href="dastSiteValidationDocsPath">{{ content }}</gl-link>
</template>
</gl-sprintf>
</gl-alert>
</template> </template>
</div> </div>
</template> </template>
<script>
import { GlAlert, GlSprintf, GlLink } from '@gitlab/ui';
import { helpPagePath } from '~/helpers/help_page_helper';
export default {
components: {
GlAlert,
GlSprintf,
GlLink,
},
dastSiteValidationDocsPath: helpPagePath('user/application_security/dast/index', {
anchor: 'site-profile-validation',
}),
};
</script>
<template>
<gl-alert
:title="s__('DastProfiles|You cannot run an active scan against an unvalidated site.')"
:dismissible="false"
variant="danger"
>
<gl-sprintf
:message="
s__(
'DastProfiles|You can either choose a passive scan or validate the target site in your chosen site profile. %{docsLinkStart}Learn more about site validation.%{docsLinkEnd}',
)
"
>
<template #docsLink="{ content }">
<gl-link :href="dastSiteValidationDocsPath">{{ content }}</gl-link>
</template>
</gl-sprintf>
</gl-alert>
</template>
...@@ -9,7 +9,6 @@ export default () => { ...@@ -9,7 +9,6 @@ export default () => {
} }
const { const {
dastSiteValidationDocsPath,
projectPath, projectPath,
defaultBranch, defaultBranch,
profilesLibraryPath, profilesLibraryPath,
...@@ -33,7 +32,6 @@ export default () => { ...@@ -33,7 +32,6 @@ export default () => {
siteProfilesLibraryPath, siteProfilesLibraryPath,
newScannerProfilePath, newScannerProfilePath,
newSiteProfilePath, newSiteProfilePath,
dastSiteValidationDocsPath,
timezones, timezones,
}, },
render(h) { render(h) {
......
...@@ -4,7 +4,6 @@ module Projects::OnDemandScansHelper ...@@ -4,7 +4,6 @@ module Projects::OnDemandScansHelper
def on_demand_scans_data(project) def on_demand_scans_data(project)
{ {
'help-page-path' => help_page_path('user/application_security/dast/index', anchor: 'on-demand-scans'), 'help-page-path' => help_page_path('user/application_security/dast/index', anchor: 'on-demand-scans'),
'dast-site-validation-docs-path' => help_page_path('user/application_security/dast/index', anchor: 'dast-site-validation'),
'empty-state-svg-path' => image_path('illustrations/empty-state/ondemand-scan-empty.svg'), 'empty-state-svg-path' => image_path('illustrations/empty-state/ondemand-scan-empty.svg'),
'default-branch' => project.default_branch, 'default-branch' => project.default_branch,
'project-path' => project.path_with_namespace, 'project-path' => project.path_with_namespace,
......
...@@ -9,7 +9,6 @@ RSpec.describe Projects::OnDemandScansHelper do ...@@ -9,7 +9,6 @@ RSpec.describe Projects::OnDemandScansHelper do
it 'returns proper data' do it 'returns proper data' do
expect(helper.on_demand_scans_data(project)).to match( expect(helper.on_demand_scans_data(project)).to match(
'help-page-path' => help_page_path('user/application_security/dast/index', anchor: 'on-demand-scans'), 'help-page-path' => help_page_path('user/application_security/dast/index', anchor: 'on-demand-scans'),
'dast-site-validation-docs-path' => help_page_path('user/application_security/dast/index', anchor: 'dast-site-validation'),
'empty-state-svg-path' => match_asset_path('/assets/illustrations/empty-state/ondemand-scan-empty.svg'), 'empty-state-svg-path' => match_asset_path('/assets/illustrations/empty-state/ondemand-scan-empty.svg'),
'default-branch' => project.default_branch, 'default-branch' => project.default_branch,
'project-path' => project.path_with_namespace, 'project-path' => project.path_with_namespace,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment