Modal for each environment role
This commit is contained in:
parent
5a5d81eb7f
commit
c0bb9e1024
@ -1,23 +1,23 @@
|
||||
export default {
|
||||
methods: {
|
||||
closeModal: function(name) {
|
||||
this.modals[name] = false
|
||||
this.activeModal = null
|
||||
this.$emit('modalOpen', false)
|
||||
},
|
||||
openModal: function (name) {
|
||||
this.modals[name] = true
|
||||
this.activeModal = name
|
||||
this.$emit('modalOpen', true)
|
||||
}
|
||||
},
|
||||
data: function() {
|
||||
return {
|
||||
modals: {
|
||||
styleguideModal: false,
|
||||
rolesModal: false,
|
||||
newProjectConfirmation: false,
|
||||
pendingFinancialVerification: false,
|
||||
pendingCCPOApproval: false,
|
||||
}
|
||||
styleguidemodal: false,
|
||||
newprojectconfirmation: false,
|
||||
pendingfinancialverification: false,
|
||||
pendingccpoapproval: false,
|
||||
},
|
||||
activeModal: null,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,7 +1,7 @@
|
||||
{% from "components/icon.html" import Icon %}
|
||||
|
||||
{% macro Modal(name, dismissable=False) -%}
|
||||
<div v-show='modals.{{name}} === true' v-cloak>
|
||||
<div v-if="activeModal === '{{name}}'" v-cloak>
|
||||
<div class='modal {% if dismissable %}modal--dismissable{% endif%}'>
|
||||
<div class='modal__container'>
|
||||
<div class='modal__dialog' role='dialog' aria-modal='true'>
|
||||
|
@ -51,43 +51,6 @@
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
{% call Modal(name='rolesModal', dismissable=False) %}
|
||||
<div class='block-list'>
|
||||
<ul>
|
||||
{% for choice in form.environment_role.choices %}
|
||||
<li class='block-list__item block-list__item--selectable'>
|
||||
{% if choice[0] != "" %}
|
||||
<input
|
||||
name='environment_role'
|
||||
type='radio'
|
||||
id="environment_role_{{ choice[0] }}"
|
||||
value='{{ choice[0] }}'
|
||||
checked='{{ value == choice[0] }}'
|
||||
/>
|
||||
<label for="environment_role_{{ choice[0] }}">
|
||||
{% if choice[1].description %}
|
||||
<dl>
|
||||
<dt>{{ choice[1].name }}</dt>
|
||||
<dd>{{ choice[1].description }}</dd>
|
||||
</dl>
|
||||
{% else %}
|
||||
{{ choice[1].name }}
|
||||
{% endif %}
|
||||
</label>
|
||||
{% endif %}
|
||||
</li>
|
||||
{% endfor %}
|
||||
</ul>
|
||||
</div>
|
||||
<div class='block-list__footer'>
|
||||
<div class='action-group'>
|
||||
<a v-on:click="closeModal('rolesModal')" class='action-group__action usa-button'>Select Access Role</a>
|
||||
<a class='action-group__action icon-link icon-link--danger' v-on:click="closeModal('rolesModal')">Cancel</a>
|
||||
</div>
|
||||
</div>
|
||||
{% endcall %}
|
||||
|
||||
{% for project in projects %}
|
||||
<div is='toggler' default-visible class='block-list project-list-item'>
|
||||
<template slot-scope='{ isVisible, toggle }'>
|
||||
@ -101,11 +64,48 @@
|
||||
</header>
|
||||
<ul v-show='isVisible'>
|
||||
{% for env in project.environments %}
|
||||
{% call Modal(name=env.name + 'RolesModal', dismissable=False) %}
|
||||
<div class='block-list'>
|
||||
<ul>
|
||||
{% for choice in form.environment_role.choices %}
|
||||
<li class='block-list__item block-list__item--selectable'>
|
||||
{% if choice[0] != "" %}
|
||||
<input
|
||||
name='environment_role'
|
||||
type='radio'
|
||||
id="environment_role_{{ choice[0] }}"
|
||||
value='{{ choice[0] }}'
|
||||
checked='{{ value == choice[0] }}'
|
||||
/>
|
||||
<label for="environment_role_{{ choice[0] }}">
|
||||
{% if choice[1].description %}
|
||||
<dl>
|
||||
<dt>{{ choice[1].name }}</dt>
|
||||
<dd>{{ choice[1].description }}</dd>
|
||||
</dl>
|
||||
{% else %}
|
||||
{{ choice[1].name }}
|
||||
{% endif %}
|
||||
</label>
|
||||
{% endif %}
|
||||
</li>
|
||||
{% endfor %}
|
||||
</ul>
|
||||
</div>
|
||||
<div class='block-list__footer'>
|
||||
<div class='action-group'>
|
||||
<a v-on:click="closeModal('{{ env.name }}RolesModal')" class='action-group__action usa-button'>Select Access Role</a>
|
||||
<a class='action-group__action icon-link icon-link--danger' v-on:click="closeModal('{{ env.name }}RolesModal')">No Access</a>
|
||||
</div>
|
||||
</div>
|
||||
{% endcall %}
|
||||
|
||||
<li class='block-list__item project-list-item__environment'>
|
||||
<span class='project-list-item__environment'>
|
||||
{{ env.name }}
|
||||
</span>
|
||||
<div class='project-list-item__environment__actions'>
|
||||
<input type="hidden" name="{{ env.id }}">
|
||||
{% set role = 'no access' %}
|
||||
{% set label = 'label' %}
|
||||
{% for er in member.user.environment_roles %}
|
||||
@ -114,8 +114,10 @@
|
||||
{% set label = 'label label--success' %}
|
||||
{% endif %}
|
||||
{% endfor %}
|
||||
<span class="{{ label }}">{{ role }}</span><button v-on:click="openModal('rolesModal')" type="button" class="icon-link">set role</button>
|
||||
<span class="label {{ label }}">{{ role }}</span>
|
||||
<button v-on:click="openModal('{{ env.name }}RolesModal')" type="button" class="icon-link">set role</button>
|
||||
</div>
|
||||
|
||||
{% endfor %}
|
||||
</ul>
|
||||
</template>
|
||||
|
Loading…
x
Reference in New Issue
Block a user