SetPriority.vue 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. <template>
  2. <base-dialog @cancel="cancelDialog">
  3. <div slot="header">{{title}}</div>
  4. <div slot="body">
  5. <dialog-selected-tips :count="params.data.length" :action="title" :name="name" />
  6. <dialog-table :data="params.data" :columns="params.columns.slice(0, 3)" />
  7. <a-form-model
  8. ref="form"
  9. :model="fd"
  10. :rules="rules">
  11. <a-form-model-item prop="priority" :label="$t('cloudenv.priority')" v-bind="formItemLayout" :extra="$t('cloudenv.priority_extra')">
  12. <a-input-number v-model="fd.priority" :min="0" :precision="0" />
  13. </a-form-model-item>
  14. </a-form-model>
  15. </div>
  16. <div slot="footer">
  17. <a-button type="primary" @click="handleConfirm" :loading="loading">{{ $t('dialog.ok') }}</a-button>
  18. <a-button @click="cancelDialog">{{ $t('dialog.cancel') }}</a-button>
  19. </div>
  20. </base-dialog>
  21. </template>
  22. <script>
  23. import { mapGetters } from 'vuex'
  24. import DialogMixin from '@/mixins/dialog'
  25. import WindowsMixin from '@/mixins/windows'
  26. export default {
  27. name: 'ExternalProjectSetPriorityDialog',
  28. mixins: [DialogMixin, WindowsMixin],
  29. data () {
  30. return {
  31. loading: false,
  32. fd: {
  33. priority: this.params.data[0].priority || 0,
  34. },
  35. rules: {
  36. priority: [
  37. { required: true, message: this.$t('common.tips.input', [this.$t('cloudenv.priority')]) },
  38. ],
  39. },
  40. formItemLayout: this.params.formItemLayout || {
  41. wrapperCol: {
  42. span: 21,
  43. },
  44. labelCol: {
  45. span: 3,
  46. },
  47. },
  48. }
  49. },
  50. computed: {
  51. ...mapGetters(['userInfo', 'l3PermissionEnable', 'isAdminMode']),
  52. isBatch () {
  53. return this.params.data.length > 1
  54. },
  55. name () {
  56. return this.params.name
  57. },
  58. title () {
  59. return this.params.title
  60. },
  61. },
  62. watch: {
  63. },
  64. destroyed () {
  65. },
  66. created () {
  67. },
  68. methods: {
  69. async doSetPriority (values) {
  70. return this.params.onManager('update', {
  71. id: this.params.data[0].id,
  72. managerArgs: {
  73. data: values,
  74. },
  75. })
  76. },
  77. async handleConfirm () {
  78. this.loading = true
  79. try {
  80. await this.$refs.form.validate()
  81. this.loading = true
  82. await this.doSetPriority(this.fd)
  83. this.loading = false
  84. this.cancelDialog()
  85. } catch (error) {
  86. this.loading = false
  87. throw error
  88. }
  89. },
  90. },
  91. }
  92. </script>