add.vue 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. <template>
  2. <BasicModal v-bind="$attrs" @register="register" @ok="confirm" :title="title">
  3. <BasicForm @register="registerForm" :model="model" />
  4. <!-- <MenuTree /> -->
  5. </BasicModal>
  6. </template>
  7. <script lang="ts">
  8. import { Tree } from 'ant-design-vue';
  9. import { defineComponent, PropType, reactive, ref, toRefs, watch } from 'vue';
  10. import { BasicModal, useModalInner } from '/@/components/Modal';
  11. import { BasicForm, FormSchema, useForm } from '/@/components/Form/index';
  12. import { adapt } from '/@/utils/adapt'
  13. import { formSchema, } from './data'
  14. interface ModelData {
  15. title: string,
  16. treeData: object[],
  17. checkedKeys: string[],
  18. selectedKeys: string[],
  19. expandedKeys: string[]
  20. }
  21. interface Role {
  22. id: string|number
  23. }
  24. export default defineComponent({
  25. components: { BasicModal, BasicForm, [Tree.name]: Tree },
  26. props: {
  27. modelData: {
  28. type: Object as PropType<ModelData>,
  29. default: {},
  30. },
  31. },
  32. setup(props, { emit }) {
  33. const role = reactive<Role>({
  34. id:0
  35. })
  36. const modelData:ModelData = props.modelData
  37. console.log(modelData)
  38. const modelRef = ref({});
  39. const adaptWidth = adapt()
  40. watch(modelData, () => {
  41. console.log('expandedKeys', modelData.expandedKeys);
  42. console.log('selectedKeys', modelData.selectedKeys);
  43. console.log('checkedKeys', modelData.checkedKeys);
  44. });
  45. const schemas: FormSchema[] = formSchema
  46. const [
  47. registerForm,
  48. {
  49. getFieldsValue,
  50. // setProps
  51. },
  52. ] = useForm({
  53. labelWidth: 120,
  54. schemas,
  55. showActionButtonGroup: false,
  56. actionColOptions: {
  57. span: 24,
  58. },
  59. });
  60. const [register, { closeModal } ] = useModalInner((data) => {
  61. // 方式1
  62. // setFieldsValue({
  63. // field2: data.data,
  64. // field1: data.info,
  65. // });
  66. // 方式2
  67. modelRef.value = {
  68. username: data.username,
  69. nickname: data.nickname,
  70. status: data.status,
  71. menus: data.menus
  72. };
  73. // setProps({
  74. // model:{ field2: data.data, field1: data.info }
  75. // })
  76. role.id = data.id
  77. });
  78. function confirm() {
  79. console.log('确定')
  80. const data = getFieldsValue()
  81. if(role.id) {
  82. data.id = role.id
  83. }
  84. // const data = {
  85. // info,
  86. data.menus = [...modelData.checkedKeys]
  87. // }
  88. // console.log(data)
  89. // console.log(getFieldsValue()) // 表单数据
  90. // console.log('------ 菜单key ------')
  91. // console.log(modelData.checkedKeys)
  92. emit('saveData', data)
  93. closeModal() // 关闭弹窗
  94. }
  95. return {
  96. register,
  97. schemas,
  98. registerForm,
  99. model: modelRef,
  100. confirm,
  101. adaptWidth,
  102. ...toRefs(modelData)
  103. };
  104. },
  105. });
  106. </script>
  107. <style lang='less'>
  108. .ant-form-item-label {
  109. text-align: center !important;
  110. }
  111. .tree-label {
  112. width: 20.6%;
  113. margin-top: 8px;
  114. margin-bottom: 1em;
  115. text-align: center;
  116. }
  117. @media (max-width: 639px) {
  118. .ant-form-item-label {
  119. line-height: 2.5715 !important;
  120. text-align: center !important;
  121. }
  122. .tree-label {
  123. width: 33%;
  124. margin-top: 8px;
  125. margin-bottom: 1em;
  126. text-align: center;
  127. }
  128. }
  129. </style>