refactor: 统一确认弹窗调用并优化开发代理配置

pull/350/head
YunaiV 2026-05-28 23:22:44 +08:00
parent 177cf37c1f
commit 0ec301cfb3
17 changed files with 225 additions and 279 deletions

View File

@ -38,24 +38,21 @@ async function handleUpdatePublicStatusChange(
row: AiImageApi.Image,
): Promise<boolean | undefined> {
const text = newStatus ? '公开' : '私有';
return new Promise((resolve, reject) => {
confirm({
try {
await confirm({
content: `确认要将该图片切换为【${text}】吗?`,
})
.then(async () => {
//
await updateImage({
id: row.id,
publicStatus: newStatus,
});
//
message.success($t('ui.actionMessage.operationSuccess'));
resolve(true);
})
.catch(() => {
reject(new Error('取消操作'));
});
});
} catch {
return false;
}
//
await updateImage({
id: row.id,
publicStatus: newStatus,
});
//
message.success($t('ui.actionMessage.operationSuccess'));
return true;
}
const [Grid, gridApi] = useVbenVxeGrid({

View File

@ -76,24 +76,21 @@ async function handleStatusChange(
newStatus: number,
row: AiKnowledgeDocumentApi.KnowledgeDocument,
): Promise<boolean | undefined> {
return new Promise((resolve, reject) => {
confirm({
try {
await confirm({
content: `你要将${row.name}的状态切换为【${getDictLabel(DICT_TYPE.COMMON_STATUS, newStatus)}】吗?`,
})
.then(async () => {
//
await updateKnowledgeDocumentStatus({
id: row.id,
status: newStatus,
});
//
message.success($t('ui.actionMessage.operationSuccess'));
resolve(true);
})
.catch(() => {
reject(new Error('取消操作'));
});
});
} catch {
return false;
}
//
await updateKnowledgeDocumentStatus({
id: row.id,
status: newStatus,
});
//
message.success($t('ui.actionMessage.operationSuccess'));
return true;
}
const [Grid, gridApi] = useVbenVxeGrid({

View File

@ -64,21 +64,18 @@ async function handleStatusChange(
newStatus: number,
row: AiKnowledgeSegmentApi.KnowledgeSegment,
): Promise<boolean | undefined> {
return new Promise((resolve, reject) => {
confirm({
try {
await confirm({
content: `你要将片段 ${row.id} 的状态切换为【${getDictLabel(DICT_TYPE.COMMON_STATUS, newStatus)}】吗?`,
})
.then(async () => {
//
await updateKnowledgeSegmentStatus(row.id!, newStatus);
//
message.success($t('ui.actionMessage.operationSuccess'));
resolve(true);
})
.catch(() => {
reject(new Error('取消操作'));
});
});
});
} catch {
return false;
}
//
await updateKnowledgeSegmentStatus(row.id!, newStatus);
//
message.success($t('ui.actionMessage.operationSuccess'));
return true;
}
const [Grid, gridApi] = useVbenVxeGrid({

View File

@ -38,24 +38,21 @@ async function handleUpdatePublicStatusChange(
row: AiMusicApi.Music,
): Promise<boolean | undefined> {
const text = newStatus ? '公开' : '私有';
return new Promise((resolve, reject) => {
confirm({
try {
await confirm({
content: `确认要将该音乐切换为【${text}】吗?`,
})
.then(async () => {
//
await updateMusic({
id: row.id,
publicStatus: newStatus,
});
//
message.success($t('ui.actionMessage.operationSuccess'));
resolve(true);
})
.catch(() => {
reject(new Error('取消操作'));
});
});
} catch {
return false;
}
//
await updateMusic({
id: row.id,
publicStatus: newStatus,
});
//
message.success($t('ui.actionMessage.operationSuccess'));
return true;
}
const [Grid, gridApi] = useVbenVxeGrid({

View File

@ -74,28 +74,24 @@ async function handleDeleteContactBusinessList() {
message.error('请先选择商机后操作!');
return;
}
return new Promise((resolve, reject) => {
confirm({
try {
await confirm({
content: `确定要将${checkedRows.value.map((item) => item.name).join(',')}解除关联吗?`,
})
.then(async () => {
const res = await deleteContactBusinessList({
contactId: props.bizId,
businessIds: checkedRows.value.map((item) => item.id),
});
if (res) {
//
message.success($t('ui.actionMessage.operationSuccess'));
handleRefresh();
resolve(true);
} else {
reject(new Error($t('ui.actionMessage.operationFailed')));
}
})
.catch(() => {
reject(new Error('取消操作'));
});
});
} catch {
return false;
}
const res = await deleteContactBusinessList({
contactId: props.bizId,
businessIds: checkedRows.value.map((item) => item.id),
});
if (!res) {
throw new Error($t('ui.actionMessage.operationFailed'));
}
//
message.success($t('ui.actionMessage.operationSuccess'));
handleRefresh();
return true;
}
/** 查看商机详情 */

View File

@ -71,28 +71,24 @@ async function handleDeleteContactBusinessList() {
message.error('请先选择联系人后操作!');
return;
}
return new Promise((resolve, reject) => {
confirm({
try {
await confirm({
content: `确定要将${checkedRows.value.map((item) => item.name).join(',')}解除关联吗?`,
})
.then(async () => {
const res = await deleteBusinessContactList({
businessId: props.bizId,
contactIds: checkedRows.value.map((item) => item.id),
});
if (res) {
//
message.success($t('ui.actionMessage.operationSuccess'));
handleRefresh();
resolve(true);
} else {
reject(new Error($t('ui.actionMessage.operationFailed')));
}
})
.catch(() => {
reject(new Error('取消操作'));
});
});
} catch {
return false;
}
const res = await deleteBusinessContactList({
businessId: props.bizId,
contactIds: checkedRows.value.map((item) => item.id),
});
if (!res) {
throw new Error($t('ui.actionMessage.operationFailed'));
}
//
message.success($t('ui.actionMessage.operationSuccess'));
handleRefresh();
return true;
}
/** 创建商机联系人关联 */

View File

@ -94,32 +94,28 @@ function handleEdit() {
}
/** 删除团队成员 */
function handleDelete() {
async function handleDelete() {
if (checkedRows.value.length === 0) {
message.error('请先选择团队成员后操作!');
return;
}
return new Promise((resolve, reject) => {
confirm({
try {
await confirm({
content: `你要将${checkedRows.value.map((item) => item.nickname).join(',')}移出团队吗?`,
})
.then(async () => {
const res = await deletePermissionBatch(
checkedRows.value.map((item) => item.id!),
);
if (res) {
//
message.success($t('ui.actionMessage.operationSuccess'));
handleRefresh();
resolve(true);
} else {
reject(new Error('移出失败'));
}
})
.catch(() => {
reject(new Error('取消操作'));
});
});
});
} catch {
return false;
}
const res = await deletePermissionBatch(
checkedRows.value.map((item) => item.id!),
);
if (!res) {
throw new Error('移出失败');
}
//
message.success($t('ui.actionMessage.operationSuccess'));
handleRefresh();
return true;
}
/** 退出团队 */

View File

@ -65,23 +65,20 @@ async function handleDefaultStatusChange(
newStatus: boolean,
row: ErpAccountApi.Account,
): Promise<boolean | undefined> {
return new Promise((resolve, reject) => {
const text = newStatus ? '设置' : '取消';
confirm({
const text = newStatus ? '设置' : '取消';
try {
await confirm({
content: `确认要${text}"${row.name}"默认吗?`,
})
.then(async () => {
//
await updateAccountDefaultStatus(row.id!, newStatus);
//
message.success(`${text}默认成功`);
handleRefresh();
resolve(true);
})
.catch(() => {
reject(new Error('取消操作'));
});
});
});
} catch {
return false;
}
//
await updateAccountDefaultStatus(row.id!, newStatus);
//
message.success(`${text}默认成功`);
handleRefresh();
return true;
}
const [Grid, gridApi] = useVbenVxeGrid({

View File

@ -63,23 +63,20 @@ async function handleDefaultStatusChange(
newStatus: boolean,
row: ErpWarehouseApi.Warehouse,
): Promise<boolean | undefined> {
return new Promise((resolve, reject) => {
const text = newStatus ? '设置' : '取消';
confirm({
const text = newStatus ? '设置' : '取消';
try {
await confirm({
content: `确认要${text}"${row.name}"默认吗?`,
})
.then(async () => {
//
await updateWarehouseDefaultStatus(row.id!, newStatus);
//
message.success(`${text}默认成功`);
handleRefresh();
resolve(true);
})
.catch(() => {
reject(new Error('取消操作'));
});
});
});
} catch {
return false;
}
//
await updateWarehouseDefaultStatus(row.id!, newStatus);
//
message.success(`${text}默认成功`);
handleRefresh();
return true;
}
const [FormModal, formModalApi] = useVbenModal({

View File

@ -63,25 +63,22 @@ async function handleStatusChange(
newStatus: boolean,
row: MallCommentApi.Comment,
): Promise<boolean | undefined> {
return new Promise((resolve, reject) => {
const text = newStatus ? '展示' : '隐藏';
confirm({
const text = newStatus ? '展示' : '隐藏';
try {
await confirm({
content: `确认要${text}该评论吗?`,
})
.then(async () => {
//
await updateCommentVisible({
id: row.id!,
visible: newStatus,
});
//
message.success(`${text}成功`);
resolve(true);
})
.catch(() => {
reject(new Error('取消操作'));
});
});
} catch {
return false;
}
//
await updateCommentVisible({
id: row.id!,
visible: newStatus,
});
//
message.success(`${text}成功`);
return true;
}
const [Grid, gridApi] = useVbenVxeGrid({

View File

@ -60,21 +60,18 @@ async function handleStatusChange(
newStatus: number,
row: MallCouponTemplateApi.CouponTemplate,
): Promise<boolean | undefined> {
return new Promise((resolve, reject) => {
confirm({
try {
await confirm({
content: `你要将${row.name}的状态切换为【${newStatus === CommonStatusEnum.ENABLE ? '启用' : '停用'}】吗?`,
})
.then(async () => {
//
await updateCouponTemplateStatus(row.id!, newStatus);
//
message.success($t('ui.actionMessage.operationSuccess'));
resolve(true);
})
.catch(() => {
reject(new Error('取消操作'));
});
});
});
} catch {
return false;
}
//
await updateCouponTemplateStatus(row.id!, newStatus);
//
message.success($t('ui.actionMessage.operationSuccess'));
return true;
}
const [Grid, gridApi] = useVbenVxeGrid({

View File

@ -59,23 +59,20 @@ async function handleStatusChange(
newStatus: number,
row: MallSeckillConfigApi.SeckillConfig,
): Promise<boolean | undefined> {
return new Promise((resolve, reject) => {
//
const text = row.status === 0 ? '启用' : '停用';
confirm({
//
const text = row.status === 0 ? '启用' : '停用';
try {
await confirm({
content: `确认要${text + row.name}吗?`,
})
.then(async () => {
//
await updateSeckillConfigStatus(row.id, newStatus);
//
message.success(`${text}成功`);
resolve(true);
})
.catch(() => {
reject(new Error('取消操作'));
});
});
});
} catch {
return false;
}
//
await updateSeckillConfigStatus(row.id, newStatus);
//
message.success(`${text}成功`);
return true;
}
const [Grid, gridApi] = useVbenVxeGrid({

View File

@ -87,26 +87,23 @@ async function handleBrokerageEnabledChange(
newEnabled: boolean,
row: MallBrokerageUserApi.BrokerageUser,
): Promise<boolean | undefined> {
return new Promise((resolve, reject) => {
const text = newEnabled ? '开通' : '关闭';
confirm({
const text = newEnabled ? '开通' : '关闭';
try {
await confirm({
content: `你要将${row.nickname}的推广资格切换为【${text}】吗?`,
})
.then(async () => {
// 广
await updateBrokerageEnabled({
id: row.id!,
enabled: newEnabled,
});
//
message.success($t('ui.actionMessage.operationSuccess'));
handleRefresh();
resolve(true);
})
.catch(() => {
reject(new Error('取消操作'));
});
});
} catch {
return false;
}
// 广
await updateBrokerageEnabled({
id: row.id!,
enabled: newEnabled,
});
//
message.success($t('ui.actionMessage.operationSuccess'));
handleRefresh();
return true;
}
const [Grid, gridApi] = useVbenVxeGrid({

View File

@ -65,25 +65,22 @@ async function handleStatusChange(
newStatus: number,
row: PayAppApi.App,
): Promise<boolean | undefined> {
return new Promise((resolve, reject) => {
const text = newStatus === CommonStatusEnum.ENABLE ? '启用' : '停用';
confirm({
const text = newStatus === CommonStatusEnum.ENABLE ? '启用' : '停用';
try {
await confirm({
content: `确认要${text + row.name}应用吗?`,
})
.then(async () => {
//
await updateAppStatus({
id: row.id!,
status: newStatus,
});
//
message.success(`${text}成功`);
resolve(true);
})
.catch(() => {
reject(new Error('取消操作'));
});
});
} catch {
return false;
}
//
await updateAppStatus({
id: row.id!,
status: newStatus,
});
//
message.success(`${text}成功`);
return true;
}
/** 生成渠道配置按钮 */

View File

@ -138,21 +138,18 @@ async function handleStatusChange(
newStatus: number,
row: SystemUserApi.User,
): Promise<boolean | undefined> {
return new Promise((resolve, reject) => {
confirm({
try {
await confirm({
content: `你要将${row.username}的状态切换为【${getDictLabel(DICT_TYPE.COMMON_STATUS, newStatus)}】吗?`,
})
.then(async () => {
//
await updateUserStatus(row.id!, newStatus);
//
message.success($t('ui.actionMessage.operationSuccess'));
resolve(true);
})
.catch(() => {
reject(new Error('取消操作'));
});
});
});
} catch {
return false;
}
//
await updateUserStatus(row.id!, newStatus);
//
message.success($t('ui.actionMessage.operationSuccess'));
return true;
}
const [Grid, gridApi] = useVbenVxeGrid({

View File

@ -138,21 +138,18 @@ async function handleStatusChange(
newStatus: number,
row: SystemUserApi.User,
): Promise<boolean | undefined> {
return new Promise((resolve, reject) => {
confirm({
try {
await confirm({
content: `你要将${row.username}的状态切换为【${getDictLabel(DICT_TYPE.COMMON_STATUS, newStatus)}】吗?`,
})
.then(async () => {
//
await updateUserStatus(row.id!, newStatus);
//
message.success($t('ui.actionMessage.operationSuccess'));
resolve(true);
})
.catch(() => {
reject(new Error('取消操作'));
});
});
});
} catch {
return false;
}
//
await updateUserStatus(row.id!, newStatus);
//
message.success($t('ui.actionMessage.operationSuccess'));
return true;
}
const [Grid, gridApi] = useVbenVxeGrid({

View File

@ -139,21 +139,18 @@ async function handleStatusChange(
newStatus: number,
row: SystemUserApi.User,
): Promise<boolean | undefined> {
return new Promise((resolve, reject) => {
confirm({
try {
await confirm({
content: `你要将${row.username}的状态切换为【${getDictLabel(DICT_TYPE.COMMON_STATUS, newStatus)}】吗?`,
})
.then(async () => {
//
await updateUserStatus(row.id!, newStatus);
//
message.success($t('ui.actionMessage.operationSuccess'));
resolve(true);
})
.catch(() => {
reject(new Error('取消操作'));
});
});
});
} catch {
return false;
}
//
await updateUserStatus(row.id!, newStatus);
//
message.success($t('ui.actionMessage.operationSuccess'));
return true;
}
const [Grid, gridApi] = useVbenVxeGrid({