ny
23 小时以前 282fbc6488f4e8ceb5fda759f963ee88fbf7b999
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
<script lang="ts" setup>
import type { TreeActionType } from '@jnpf/ui';
 
import { reactive, ref, toRefs, unref } from 'vue';
 
import { useMessage } from '@jnpf/hooks';
import { BasicTree, ScrollContainer } from '@jnpf/ui';
import { BasicModal, useModalInner } from '@jnpf/ui/modal';
 
import { DeleteOutlined } from '@ant-design/icons-vue';
 
import { getDataInterfaceSelector } from '#/api/systemData/dataInterface';
import { getInfo, saveInterfaceList } from '#/api/systemData/interfaceOauth';
import { $t } from '#/locales';
 
interface State {
  treeData: any[];
  dataForm: any;
  keyword: string;
  selectedData: any[];
}
 
defineEmits(['register']);
 
const { createMessage } = useMessage();
const treeRef = ref<Nullable<TreeActionType>>(null);
const [registerModal, { changeLoading, changeOkLoading, closeModal }] = useModalInner(init);
const state = reactive<State>({
  treeData: [],
  dataForm: {
    interfaceIdentId: '',
    dataInterfaceIds: [],
  },
  keyword: '',
  selectedData: [],
});
const { treeData, selectedData, keyword } = toRefs(state);
 
function init(data) {
  changeLoading(true);
  state.dataForm.interfaceIdentId = data.id;
  state.dataForm.dataInterfaceIds = [];
  state.treeData = [];
  state.selectedData = [];
  state.keyword = '';
  initData();
}
function initData() {
  getDataInterfaceSelector().then((res) => {
    state.treeData = res.data;
    handleSearch('');
    getInfo(state.dataForm.interfaceIdentId).then((res) => {
      state.selectedData = res.data.list || [];
      changeLoading(false);
    });
  });
}
function handleSelect(keys) {
  if (!keys.length) return;
  const data = getTree().getSelectedNode(keys[0]);
  if (data?.hasChildren) return;
  const boo = selectedData.value.some((o) => o.id === data?.id);
  if (boo) return;
  selectedData.value.push(data);
}
function handleSearch(value) {
  getTree().setSearchValue(value);
}
function getTree() {
  const tree = unref(treeRef);
  if (!tree) throw new Error('tree is null!');
  return tree;
}
function removeAll() {
  state.selectedData = [];
}
function removeData(index: number) {
  state.selectedData.splice(index, 1);
}
function handleSubmit() {
  changeOkLoading(true);
  const arr = state.selectedData.map((o) => o.id);
  state.dataForm.dataInterfaceIds = arr.join(',');
  saveInterfaceList(state.dataForm)
    .then((res) => {
      createMessage.success(res.msg);
      changeOkLoading(false);
      closeModal();
    })
    .catch(() => {
      changeOkLoading(false);
    });
}
</script>
<template>
  <BasicModal v-bind="$attrs" @register="registerModal" title="接口授权" :width="800" @ok="handleSubmit" class="transfer-modal">
    <div class="transfer__body">
      <div class="transfer-pane left-pane">
        <div class="transfer-pane__tool">
          <a-input-search :placeholder="$t('common.enterKeyword')" allow-clear v-model:value="keyword" @search="handleSearch" />
        </div>
        <div class="transfer-pane__body transfer-pane__body-tab">
          <BasicTree class="tree-main" :tree-data="treeData" @select="handleSelect" ref="treeRef" default-expand-all />
        </div>
      </div>
      <div class="transfer-pane right-pane">
        <div class="transfer-pane__tool">
          <span>{{ $t('component.jnpf.common.selected') }}</span>
          <span class="remove-all-btn" @click="removeAll">清空列表</span>
        </div>
        <div class="transfer-pane__body">
          <ScrollContainer>
            <div v-for="(item, i) in selectedData" :key="i" class="selected-item">
              <div class="selected-item-text">
                <p class="name">{{ item.fullName }}</p>
              </div>
              <DeleteOutlined class="delete-btn" @click="removeData(i)" />
            </div>
            <jnpf-empty v-if="!selectedData?.length" />
          </ScrollContainer>
        </div>
      </div>
    </div>
  </BasicModal>
</template>