auth-web/src/views/system/permission/utils/hooks.tsx

173 lines
4.7 KiB
TypeScript
Raw Normal View History

2025-04-25 16:21:15 +08:00
import { addDialog } from '@/components/ReDialog/index';
import PermissionFromDialog from '@/views/system/permission/components/permission-from-dialog.vue';
2025-04-27 22:16:06 +08:00
import { usePermissionStore } from '@/store/system/power';
2024-10-10 10:32:17 +08:00
import { h, reactive, ref } from 'vue';
2025-04-27 22:16:06 +08:00
import { messageBox } from '@/utils/message';
import type { FormItemProps } from '@/views/system/permission/utils/types';
import { $t } from '@/plugins/i18n';
2024-10-10 10:32:17 +08:00
import { handleTree } from '@pureadmin/utils';
import { powerCascadeProps } from '@/views/system/permission/utils/columns';
2024-10-10 10:32:17 +08:00
import { ElCascader, ElForm, ElFormItem } from 'element-plus';
export const formRef = ref();
2024-10-10 10:32:17 +08:00
// 批量点击id列表
export const powerIds = ref([]);
2025-04-27 22:16:06 +08:00
const powerStore = usePermissionStore();
/** 搜索初始化权限 */
export async function onSearch() {
2025-04-24 13:43:37 +08:00
powerStore.loading = true;
2025-04-27 22:16:06 +08:00
await powerStore.fetchPermissionPage();
2025-04-24 13:43:37 +08:00
powerStore.loading = false;
}
/** 添加权限 */
export function onAdd(parentId = 0) {
const formInline = {
parentId,
powerCode: undefined,
powerName: undefined,
requestUrl: undefined,
requestMethod: undefined,
};
2025-04-24 13:43:37 +08:00
addDialog({
title: `${$t('addNew')}${$t('power')}`,
props: { formInline },
2025-04-24 13:43:37 +08:00
draggable: true,
fullscreenIcon: true,
closeOnClickModal: false,
contentRenderer: () =>
h(PermissionFromDialog, {
ref: formRef,
formInline,
}),
2025-04-24 13:43:37 +08:00
beforeSure: (done, { options }) => {
const form = options.props.formInline as FormItemProps;
formRef.value.formRef.validate(async (valid: any) => {
if (!valid) return;
2025-04-27 22:16:06 +08:00
const result = await powerStore.addPermission(form);
2025-04-24 13:43:37 +08:00
if (!result) return;
done();
await onSearch();
});
},
});
}
2025-04-27 22:16:06 +08:00
/* 更新权限 */
export function onUpdate(row: any) {
const formInline = {
parentId: row.parentId,
powerCode: row.powerCode,
powerName: row.powerName,
requestUrl: row.requestUrl,
requestMethod: row.requestMethod,
};
2025-04-24 13:43:37 +08:00
addDialog({
title: `${$t('modify')}${$t('power')}`,
props: { formInline },
2025-04-24 13:43:37 +08:00
draggable: true,
fullscreenIcon: true,
closeOnClickModal: false,
contentRenderer: () => h(PermissionFromDialog, { ref: formRef, formInline }),
2025-04-24 13:43:37 +08:00
beforeSure: (done, { options }) => {
const form = options.props.formInline as FormItemProps;
formRef.value.formRef.validate(async (valid: any) => {
if (!valid) return;
// 请求方法是否存在,不存在就为空
form.requestMethod = form.requestMethod ? form.requestMethod : '';
2025-04-27 22:16:06 +08:00
const result = await powerStore.editPermission({ ...form, id: row.id });
2025-04-24 13:43:37 +08:00
if (!result) return;
done();
await onSearch();
});
},
});
}
/** 删除权限 */
export const onDelete = async (row: any) => {
2025-04-24 13:43:37 +08:00
const id = row.id;
// 是否确认删除
const result = await messageBox({
title: $t('confirmDelete'),
showMessage: false,
confirmMessage: undefined,
cancelMessage: $t('confirmDelete'),
});
if (!result) return;
// 删除数据
2025-04-27 22:16:06 +08:00
await powerStore.removePermission([id]);
2025-04-24 13:43:37 +08:00
await onSearch();
};
/** 批量删除 */
export const onDeleteBatch = async () => {
2025-04-27 22:16:06 +08:00
// 是否确认删除
const result = await messageBox({
title: $t('confirmDelete'),
showMessage: false,
confirmMessage: undefined,
cancelMessage: $t('cancel_delete'),
2025-04-24 13:43:37 +08:00
});
2025-04-27 22:16:06 +08:00
if (!result) return;
// 删除数据
const ids = powerIds.value;
await powerStore.removePermission(ids);
await onSearch();
};
2024-10-10 10:32:17 +08:00
/** 批量更新父级id */
2024-10-10 10:32:17 +08:00
export const onUpdateBatchParent = async () => {
2025-04-24 13:43:37 +08:00
const formUpdateParentRef = ref();
const form = reactive({
ids: powerIds.value,
parentId: undefined,
});
2025-04-27 22:16:06 +08:00
await powerStore.loadPermissionList();
2025-04-24 13:43:37 +08:00
addDialog({
title: $t('update_batches_parent'),
2025-04-24 13:43:37 +08:00
draggable: true,
fullscreenIcon: true,
closeOnClickModal: false,
contentRenderer: () => (
<ElForm ref={formUpdateParentRef} model={form}>
<ElFormItem
rules={{ required: true, message: `${$t('input')}${$t('power_parentId')}`, trigger: 'blur' }}
label={$t('menuIcon_iconName')}
prop={'parentId'}
>
<ElCascader
v-model={form.parentId}
options={handleTree(powerStore.allPowerList)}
props={powerCascadeProps}
class={'w-full'}
clearable
filterable
show-all-levels
/>
</ElFormItem>
</ElForm>
),
beforeSure: (done, _) => {
formUpdateParentRef.value.validate(async (valid: any) => {
if (!valid) return;
2025-04-27 22:16:06 +08:00
const result = await powerStore.updatePermissionListByParentId(form);
2025-04-24 13:43:37 +08:00
if (!result) return;
done();
await onSearch();
});
},
});
2024-10-10 10:32:17 +08:00
};