SetPolicies.vue 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. <template>
  2. <base-dialog @cancel="cancelDialog">
  3. <div slot="header">{{ $t('role.action.set_policies') }}</div>
  4. <div slot="body">
  5. <dialog-selected-tips :name="$t('dictionary.role')" :count="params.data.length" :action="$t('role.action.set_policies')" />
  6. <dialog-table :data="params.data" :columns="columns" />
  7. <set-policies-form ref="setPoliciesForm" :data="params.data" />
  8. </div>
  9. <div slot="footer">
  10. <a-button type="primary" @click="handleConfirm" :loading="loading">{{ $t('dialog.ok') }}</a-button>
  11. <a-button @click="cancelDialog">{{ $t('dialog.cancel') }}</a-button>
  12. </div>
  13. </base-dialog>
  14. </template>
  15. <script>
  16. import DialogMixin from '@/mixins/dialog'
  17. import WindowsMixin from '@/mixins/windows'
  18. import SetPoliciesForm from '../components/SetPolicies'
  19. export default {
  20. name: 'RoleSetPoliciesDialog',
  21. components: {
  22. SetPoliciesForm,
  23. },
  24. mixins: [DialogMixin, WindowsMixin],
  25. data () {
  26. return {
  27. loading: false,
  28. }
  29. },
  30. computed: {
  31. columns () {
  32. return this.params.columns.filter(item => item.field === 'project_domain' || item.field === 'name')
  33. },
  34. },
  35. methods: {
  36. async handleConfirm () {
  37. this.loading = true
  38. try {
  39. await this.$refs.setPoliciesForm.set(this.params.data[0].id, this.params.setPoliciesAction)
  40. this.cancelDialog()
  41. this.params.success && this.params.success()
  42. } finally {
  43. this.loading = false
  44. }
  45. },
  46. },
  47. }
  48. </script>