fix(个人中心): 本地执行支持清空URL
This commit is contained in:
parent
e2190b63c4
commit
f6d5b4c240
|
@ -6,21 +6,22 @@ import jakarta.validation.constraints.Size;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
|
|
||||||
|
import java.io.Serial;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
@EqualsAndHashCode(callSuper = false)
|
@EqualsAndHashCode(callSuper = false)
|
||||||
public class UserLocalConfigUpdateRequest implements Serializable {
|
public class UserLocalConfigUpdateRequest implements Serializable {
|
||||||
|
|
||||||
|
@Serial
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
@Schema(description = "ID", requiredMode = Schema.RequiredMode.REQUIRED)
|
@Schema(description = "ID", requiredMode = Schema.RequiredMode.REQUIRED)
|
||||||
@NotBlank(message = "{user_local_config.id.not_blank}")
|
@NotBlank(message = "{user_local_config.id.not_blank}")
|
||||||
private String id;
|
private String id;
|
||||||
|
|
||||||
@Schema(description = "本地执行程序url", requiredMode = Schema.RequiredMode.REQUIRED)
|
@Schema(description = "本地执行程序url")
|
||||||
@NotBlank(message = "{user_local_config.user_url.not_blank}")
|
@Size( max = 50, message = "{user_local_config.user_url.length_range}")
|
||||||
@Size(min = 1, max = 50, message = "{user_local_config.user_url.length_range}")
|
|
||||||
private String userUrl;
|
private String userUrl;
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -96,10 +96,6 @@ public class UserLocalConfigControllerTests extends BaseTest {
|
||||||
//不存在的
|
//不存在的
|
||||||
request.setId(UUID.randomUUID().toString());
|
request.setId(UUID.randomUUID().toString());
|
||||||
requestPost(UPDATE, request, status().is5xxServerError());
|
requestPost(UPDATE, request, status().is5xxServerError());
|
||||||
//url为空
|
|
||||||
request.setId(userLocalConfig.getId());
|
|
||||||
request.setUserUrl("");
|
|
||||||
requestPost(UPDATE, request, status().is4xxClientError());
|
|
||||||
//id为空
|
//id为空
|
||||||
request.setId("");
|
request.setId("");
|
||||||
request.setUserUrl("https://www.baidu.com");
|
request.setUserUrl("https://www.baidu.com");
|
||||||
|
|
|
@ -25,16 +25,28 @@
|
||||||
@press-enter="testApi"
|
@press-enter="testApi"
|
||||||
></a-input>
|
></a-input>
|
||||||
<div class="config-card-footer">
|
<div class="config-card-footer">
|
||||||
<a-button
|
<div>
|
||||||
type="outline"
|
<a-button
|
||||||
class="px-[8px]"
|
type="outline"
|
||||||
size="mini"
|
class="px-[8px]"
|
||||||
:disabled="apiConfig.userUrl.trim() === ''"
|
size="mini"
|
||||||
:loading="testApiLoading"
|
:disabled="apiConfig.userUrl.trim() === ''"
|
||||||
@click="testApi"
|
:loading="testApiLoading"
|
||||||
>
|
@click="testApi"
|
||||||
{{ t('ms.personal.test') }}
|
>
|
||||||
</a-button>
|
{{ t('ms.personal.test') }}
|
||||||
|
</a-button>
|
||||||
|
<a-button
|
||||||
|
v-if="apiConfig.userUrl.trim()"
|
||||||
|
type="outline"
|
||||||
|
class="arco-btn-outline--secondary px-[8px]"
|
||||||
|
style="margin-left: 10px"
|
||||||
|
size="mini"
|
||||||
|
@click="clearApi"
|
||||||
|
>
|
||||||
|
{{ t('ms.transfer.clear') }}
|
||||||
|
</a-button>
|
||||||
|
</div>
|
||||||
<div class="flex items-center">
|
<div class="flex items-center">
|
||||||
<div class="mr-[4px] text-[12px] leading-[16px] text-[var(--color-text-4)]">
|
<div class="mr-[4px] text-[12px] leading-[16px] text-[var(--color-text-4)]">
|
||||||
{{ t('ms.personal.priorityLocalExec') }}
|
{{ t('ms.personal.priorityLocalExec') }}
|
||||||
|
@ -42,7 +54,7 @@
|
||||||
<a-switch
|
<a-switch
|
||||||
v-model:model-value="apiConfig.enable"
|
v-model:model-value="apiConfig.enable"
|
||||||
size="small"
|
size="small"
|
||||||
:disabled="apiConfig.id === '' || testApiLoading"
|
:disabled="apiConfig.id === '' || testApiLoading || apiConfig.userUrl.trim() === ''"
|
||||||
:before-change="(val) => handleApiPriorityBeforeChange(val)"
|
:before-change="(val) => handleApiPriorityBeforeChange(val)"
|
||||||
type="line"
|
type="line"
|
||||||
/>
|
/>
|
||||||
|
@ -155,6 +167,20 @@
|
||||||
status: 0,
|
status: 0,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
function clearApi() {
|
||||||
|
apiConfig.value.userUrl = '';
|
||||||
|
if (apiConfig.value.id) {
|
||||||
|
// 已经存在配置
|
||||||
|
updateLocalConfig({
|
||||||
|
id: apiConfig.value.id,
|
||||||
|
userUrl: apiConfig.value.userUrl.trim(),
|
||||||
|
});
|
||||||
|
disableLocalConfig(apiConfig.value.id);
|
||||||
|
apiConfig.value.enable = false;
|
||||||
|
Message.success(t('common.updateSuccess'));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
async function testApi() {
|
async function testApi() {
|
||||||
if (apiConfig.value.userUrl.trim() === '') {
|
if (apiConfig.value.userUrl.trim() === '') {
|
||||||
return;
|
return;
|
||||||
|
|
Loading…
Reference in New Issue