Commit 1ac97dcf authored by Stan Hu's avatar Stan Hu

Add validate account button on CI/CD shared runners page

Previously once a user disabled shared runners, the only way to get this
modal to display would be to create a new project with a
`.gitlab-ci.yml`, let the pipeline fail, visit the pipeline, and then
find this same modal.

If credit card validation is required to enable shared runners for a
given project, this change will now display the `Validate account`
button and direct the user to the validation.

Relates to https://gitlab.com/gitlab-org/gitlab/-/issues/334322

Changelog: added
EE: true
parent 22f0a2c7
...@@ -10,6 +10,8 @@ export default { ...@@ -10,6 +10,8 @@ export default {
GlAlert, GlAlert,
GlToggle, GlToggle,
GlTooltip, GlTooltip,
CcValidationRequiredAlert: () =>
import('ee_component/billings/components/cc_validation_required_alert.vue'),
}, },
props: { props: {
isDisabledAndUnoverridable: { isDisabledAndUnoverridable: {
...@@ -20,6 +22,10 @@ export default { ...@@ -20,6 +22,10 @@ export default {
type: Boolean, type: Boolean,
required: true, required: true,
}, },
isCreditCardValidationRequired: {
type: Boolean,
required: false,
},
updatePath: { updatePath: {
type: String, type: String,
required: true, required: true,
...@@ -34,6 +40,7 @@ export default { ...@@ -34,6 +40,7 @@ export default {
}, },
created() { created() {
this.isSharedRunnerEnabled = this.isEnabled; this.isSharedRunnerEnabled = this.isEnabled;
this.ccValidationRequired = this.isCreditCardValidationRequired;
}, },
methods: { methods: {
toggleSharedRunners() { toggleSharedRunners() {
...@@ -45,6 +52,7 @@ export default { ...@@ -45,6 +52,7 @@ export default {
.then(() => { .then(() => {
this.isLoading = false; this.isLoading = false;
this.isSharedRunnerEnabled = !this.isSharedRunnerEnabled; this.isSharedRunnerEnabled = !this.isSharedRunnerEnabled;
this.ccValidationRequired = this.isCreditCardValidationRequired;
}) })
.catch((error) => { .catch((error) => {
this.isLoading = false; this.isLoading = false;
...@@ -61,7 +69,11 @@ export default { ...@@ -61,7 +69,11 @@ export default {
<gl-alert v-if="errorMessage" class="gl-mb-3" variant="danger" :dismissible="false"> <gl-alert v-if="errorMessage" class="gl-mb-3" variant="danger" :dismissible="false">
{{ errorMessage }} {{ errorMessage }}
</gl-alert> </gl-alert>
<div ref="sharedRunnersToggle">
<div v-if="this.isCreditCardValidationRequired && !this.isSharedRunnerEnabled">
<cc-validation-required-alert class="gl-pb-5" />
</div>
<div v-else ref="sharedRunnersToggle">
<gl-toggle <gl-toggle
:disabled="isDisabledAndUnoverridable" :disabled="isDisabledAndUnoverridable"
:is-loading="isLoading" :is-loading="isLoading"
...@@ -71,6 +83,7 @@ export default { ...@@ -71,6 +83,7 @@ export default {
@change="toggleSharedRunners" @change="toggleSharedRunners"
/> />
</div> </div>
<gl-tooltip v-if="isDisabledAndUnoverridable" :target="() => $refs.sharedRunnersToggle"> <gl-tooltip v-if="isDisabledAndUnoverridable" :target="() => $refs.sharedRunnersToggle">
{{ __('Shared runners are disabled on group level') }} {{ __('Shared runners are disabled on group level') }}
</gl-tooltip> </gl-tooltip>
......
...@@ -4,7 +4,7 @@ import SharedRunnersToggle from '~/projects/settings/components/shared_runners_t ...@@ -4,7 +4,7 @@ import SharedRunnersToggle from '~/projects/settings/components/shared_runners_t
export default (containerId = 'toggle-shared-runners-form') => { export default (containerId = 'toggle-shared-runners-form') => {
const containerEl = document.getElementById(containerId); const containerEl = document.getElementById(containerId);
const { isDisabledAndUnoverridable, isEnabled, updatePath } = containerEl.dataset; const { isDisabledAndUnoverridable, isEnabled, updatePath, isCreditCardValidationRequired } = containerEl.dataset;
return new Vue({ return new Vue({
el: containerEl, el: containerEl,
...@@ -13,6 +13,7 @@ export default (containerId = 'toggle-shared-runners-form') => { ...@@ -13,6 +13,7 @@ export default (containerId = 'toggle-shared-runners-form') => {
props: { props: {
isDisabledAndUnoverridable: parseBoolean(isDisabledAndUnoverridable), isDisabledAndUnoverridable: parseBoolean(isDisabledAndUnoverridable),
isEnabled: parseBoolean(isEnabled), isEnabled: parseBoolean(isEnabled),
isCreditCardValidationRequired: parseBoolean(isCreditCardValidationRequired),
updatePath, updatePath,
}, },
}); });
......
...@@ -3,9 +3,15 @@ module EE ...@@ -3,9 +3,15 @@ module EE
module Ci module Ci
module RunnersHelper module RunnersHelper
include ::Gitlab::Utils::StrongMemoize include ::Gitlab::Utils::StrongMemoize
extend ::Gitlab::Utils::Override
BUY_PIPELINE_MINUTES_NOTIFICATION_DOT = 'buy_pipeline_minutes_notification_dot' BUY_PIPELINE_MINUTES_NOTIFICATION_DOT = 'buy_pipeline_minutes_notification_dot'
override :toggle_shared_runners_settings_data
def toggle_shared_runners_settings_data(project)
super.merge(is_credit_card_validation_required: "#{!current_user&.has_required_credit_card_to_enable_shared_runners?(project)}")
end
def show_buy_pipeline_minutes?(project, namespace) def show_buy_pipeline_minutes?(project, namespace)
return false unless ::Gitlab.dev_env_or_com? return false unless ::Gitlab.dev_env_or_com?
......
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