Merge branch 'abp' of https://gitee.com/ccnetcore/Yi into abp
This commit is contained in:
13
Yi.Bbs.Vue3/src/apis/dictionaryApi.js
Normal file
13
Yi.Bbs.Vue3/src/apis/dictionaryApi.js
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
import request from "@/config/axios/service";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 根据字典类型获取字典列表
|
||||||
|
* @param {*} dicType 字典类型
|
||||||
|
* @returns
|
||||||
|
*/
|
||||||
|
export function getDictionaryList(dicType) {
|
||||||
|
return request({
|
||||||
|
url: `/dictionary/dic-type/${dicType}`,
|
||||||
|
method: "get",
|
||||||
|
});
|
||||||
|
}
|
||||||
@@ -1,28 +1,51 @@
|
|||||||
<template>
|
<template>
|
||||||
<el-scrollbar>
|
<el-scrollbar>
|
||||||
<div class="scrollbar-flex-content">
|
<div class="scrollbar-flex-content">
|
||||||
<p v-for="item in 50" :key="item" class="scrollbar-item">
|
<div v-for="item in recommendList" :key="item.id" class="scrollbar-item">
|
||||||
推荐
|
<el-tooltip
|
||||||
</p>
|
class="box-item"
|
||||||
|
effect="dark"
|
||||||
|
:content="item.dictLabel"
|
||||||
|
placement="top"
|
||||||
|
v-if="item.dictLabel.length > 5"
|
||||||
|
>
|
||||||
|
{{ item.dictLabel.slice(0, 5) + "..." }}
|
||||||
|
</el-tooltip>
|
||||||
|
<span v-else>
|
||||||
|
{{ item.dictLabel }}
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</el-scrollbar>
|
</el-scrollbar>
|
||||||
</template>
|
</template>
|
||||||
<style scoped>
|
|
||||||
|
|
||||||
|
<script setup>
|
||||||
|
import { onMounted, ref } from "vue";
|
||||||
|
import { getDictionaryList } from "@/apis/dictionaryApi.js";
|
||||||
|
|
||||||
|
const recommendList = ref([]);
|
||||||
|
onMounted(async () => {
|
||||||
|
const { data } = await getDictionaryList("bbs_type_lable");
|
||||||
|
recommendList.value = data;
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
.scrollbar-flex-content {
|
.scrollbar-flex-content {
|
||||||
display: flex;
|
display: flex;
|
||||||
}
|
}
|
||||||
.scrollbar-item {
|
.scrollbar-item {
|
||||||
|
cursor: pointer;
|
||||||
flex-shrink: 0;
|
flex-shrink: 0;
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
width: 4rem;
|
width: 4rem;
|
||||||
height: 2.6rem;
|
height: 2.6rem;
|
||||||
margin: 0 0.2rem ;
|
margin: 0 0.2rem;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
border-radius: 4px;
|
border-radius: 4px;
|
||||||
background-color:#FAFAFA;
|
background-color: #fafafa;
|
||||||
font-size: 14px;
|
font-size: 14px;
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
|
import router from "@/router";
|
||||||
import { ElMessage } from "element-plus";
|
import { ElMessage } from "element-plus";
|
||||||
import { config } from "@/config/axios/config";
|
import { config } from "@/config/axios/config";
|
||||||
import { Session } from "@/utils/storage";
|
import { Session } from "@/utils/storage";
|
||||||
@@ -57,11 +58,14 @@ service.interceptors.response.use(
|
|||||||
} else {
|
} else {
|
||||||
const res = error.response || {};
|
const res = error.response || {};
|
||||||
const status = Number(res.status) || 200;
|
const status = Number(res.status) || 200;
|
||||||
const message = res.data.error.message;
|
const message = res?.data?.error?.message;
|
||||||
if (status === 401) {
|
if (status === 401) {
|
||||||
ElMessage({
|
ElMessageBox.confirm("该功能需要登陆后享有,是否立即登录?", "提示", {
|
||||||
type: "danger",
|
confirmButtonText: "确认",
|
||||||
message,
|
cancelButtonText: "取消",
|
||||||
|
type: "warning",
|
||||||
|
}).then(() => {
|
||||||
|
router.push("/login");
|
||||||
});
|
});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ import App from "./App.vue";
|
|||||||
import router from "./router";
|
import router from "./router";
|
||||||
import piniaPluginPersistedstate from "pinia-plugin-persistedstate";
|
import piniaPluginPersistedstate from "pinia-plugin-persistedstate";
|
||||||
|
|
||||||
|
import "element-plus/dist/index.css";
|
||||||
import "./assets/main.css";
|
import "./assets/main.css";
|
||||||
import "@/assets/styles/index.scss"; // global css
|
import "@/assets/styles/index.scss"; // global css
|
||||||
|
|
||||||
|
|||||||
@@ -24,7 +24,7 @@
|
|||||||
</el-form-item>
|
</el-form-item>
|
||||||
</div>
|
</div>
|
||||||
</el-form>
|
</el-form>
|
||||||
<RouterLink to="/register"> 没有账号?前往注册</RouterLink>
|
<!-- <RouterLink to="/register"> 没有账号?前往注册</RouterLink> -->
|
||||||
<button class="login-btn" @click="login(loginFormRef)">登 录</button>
|
<button class="login-btn" @click="login(loginFormRef)">登 录</button>
|
||||||
<button class="login-btn" @click="guestlogin">访客</button>
|
<button class="login-btn" @click="guestlogin">访客</button>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
Reference in New Issue
Block a user