Compare commits

..

No commits in common. "6ea3246428673432db73ea5cb4ef90b5f5d52a63" and "877c971415e2fc7a45a9c663aaae81b8cf359f75" have entirely different histories.

15 changed files with 92 additions and 258 deletions

View File

@ -8,7 +8,7 @@
http-equiv="Content-Security-Policy" http-equiv="Content-Security-Policy"
content="default-src 'self'; script-src 'self'; style-src 'self' 'unsafe-inline'; img-src 'self' data:" content="default-src 'self'; script-src 'self'; style-src 'self' 'unsafe-inline'; img-src 'self' data:"
/> --> /> -->
<meta http-equiv="Content-Security-Policy" content="connect-src * blob:; default-src 'self'; script-src 'self' 'unsafe-eval'; style-src 'self' 'unsafe-inline'; media-src * blob:;img-src * 'self' data: blob:" /> <meta http-equiv="Content-Security-Policy" content="connect-src * blob:; default-src 'self'; script-src 'self' 'unsafe-eval'; style-src 'self' 'unsafe-inline'; media-src *;img-src * 'self' data: blob:" />
</head> </head>

View File

@ -1,8 +1,8 @@
@font-face { @font-face {
font-family: "iconfont"; /* Project id 4723712 */ font-family: "iconfont"; /* Project id 4723712 */
src: url('iconfont.woff2?t=1732173266977') format('woff2'), src: url('iconfont.woff2?t=1731913617367') format('woff2'),
url('iconfont.woff?t=1732173266977') format('woff'), url('iconfont.woff?t=1731913617367') format('woff'),
url('iconfont.ttf?t=1732173266977') format('truetype'); url('iconfont.ttf?t=1731913617367') format('truetype');
} }
.iconfont { .iconfont {
@ -13,26 +13,6 @@
-moz-osx-font-smoothing: grayscale; -moz-osx-font-smoothing: grayscale;
} }
.icon-jiqiren_o:before {
content: "\eb62";
}
.icon-zhaoxiangji:before {
content: "\e679";
}
.icon-huaban:before {
content: "\e6e2";
}
.icon-tubiao_wuxing-:before {
content: "\e612";
}
.icon-soutibao-:before {
content: "\e605";
}
.icon-baocun:before { .icon-baocun:before {
content: "\e60e"; content: "\e60e";
} }

File diff suppressed because one or more lines are too long

View File

@ -5,41 +5,6 @@
"css_prefix_text": "icon-", "css_prefix_text": "icon-",
"description": "", "description": "",
"glyphs": [ "glyphs": [
{
"icon_id": "5387814",
"name": "机器人_o",
"font_class": "jiqiren_o",
"unicode": "eb62",
"unicode_decimal": 60258
},
{
"icon_id": "630128",
"name": "照相机",
"font_class": "zhaoxiangji",
"unicode": "e679",
"unicode_decimal": 59001
},
{
"icon_id": "12592146",
"name": "画板",
"font_class": "huaban",
"unicode": "e6e2",
"unicode_decimal": 59106
},
{
"icon_id": "6025688",
"name": "图标_五星-2",
"font_class": "tubiao_wuxing-",
"unicode": "e612",
"unicode_decimal": 58898
},
{
"icon_id": "11756625",
"name": "搜题宝-37",
"font_class": "soutibao-",
"unicode": "e605",
"unicode_decimal": 58885
},
{ {
"icon_id": "11467388", "icon_id": "11467388",
"name": "保存", "name": "保存",

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.8 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.0 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.0 KiB

View File

@ -1,5 +1,5 @@
<template> <template>
<div class="whiteboart-container" :style="{ height: height + 'px' }"> <div class="whiteboart-container">
<div class="canvasBox" ref="box"></div> <div class="canvasBox" ref="box"></div>
<div class="footerLeft" @click.stop <div class="footerLeft" @click.stop
@ -15,7 +15,7 @@
</el-tooltip> </el-tooltip>
</div> </div>
<div class="blockBox"> <div class="blockBox">
<el-button @click="currentType = 'selection'"><el-image src="/src/assets/images/mouse-pointer.png" <el-button @click="currentType = 'selection'"><el-image src="/src/assets/icons/pngjpg/mouse-pointer.png"
style="width: 14px; height: 14px; color: silver" /></el-button> style="width: 14px; height: 14px; color: silver" /></el-button>
</div> </div>
<template v-if="type == 'design'"> <template v-if="type == 'design'">
@ -53,8 +53,7 @@
</el-radio-group> </el-radio-group>
</template> </template>
<div class="blockBox"> <div class="blockBox">
<!-- <el-button @click="currentType = 'selection'" style="color:#848282" :icon="Camera" disabled></el-button> --> <el-button @click="currentType = 'selection'" style="color:#848282" :icon="Camera" disabled></el-button>
<el-button @click="handleToolTypeChange('image')">图片</el-button>
</div> </div>
<div class="blockBox" v-if="!readonly"> <div class="blockBox" v-if="!readonly">
<el-dropdown @command="handleToolTypeChange" placement="top"> <el-dropdown @command="handleToolTypeChange" placement="top">
@ -72,7 +71,7 @@
<template v-if="type != 'design'"> <template v-if="type != 'design'">
<el-dropdown-item command="freedraw">画笔</el-dropdown-item> <el-dropdown-item command="freedraw">画笔</el-dropdown-item>
<el-dropdown-item command="text">文字</el-dropdown-item> <el-dropdown-item command="text">文字</el-dropdown-item>
<!-- <el-dropdown-item command="image">图片</el-dropdown-item> --> <el-dropdown-item command="image">图片</el-dropdown-item>
</template> </template>
</el-dropdown-menu> </el-dropdown-menu>
</template> </template>
@ -123,7 +122,7 @@
<!-- 边框样式 --> <!-- 边框样式 -->
<div class="blockBox"> <div class="blockBox">
<el-dropdown @command="updateStyle('lineDash', $event)" placement="top"> <el-dropdown @command="updateStyle('lineDash', $event)" placement="top">
<el-button><el-image src="/src/assets/images/borderstyle.png" <el-button><el-image src="/src/assets/icons/pngjpg/borderstyle.png"
style="width: 14px; height: 14px"></el-image></el-button> style="width: 14px; height: 14px"></el-image></el-button>
<template #dropdown> <template #dropdown>
<el-dropdown-menu> <el-dropdown-menu>
@ -135,7 +134,8 @@
</el-dropdown> </el-dropdown>
</div> </div>
<!--透明度--> <!--透明度-->
<div class="blockBox" style="width: 120px"> <div class="blockBox" style="width: 120px"
v-if="type == 'design' ? true : ['image'].includes(activeElement?.type) || hasSelectedElements">
<el-tooltip effect="light" content="透明度" placement="top"> <el-tooltip effect="light" content="透明度" placement="top">
<el-input-number v-model="globalAlpha" :min="0" :max="1" :step="0.1" <el-input-number v-model="globalAlpha" :min="0" :max="1" :step="0.1"
@change="updateStyle('globalAlpha', $event)"></el-input-number> @change="updateStyle('globalAlpha', $event)"></el-input-number>
@ -145,7 +145,7 @@
<!-- 边框粗细 --> <!-- 边框粗细 -->
<div class="blockBox"> <div class="blockBox">
<el-dropdown @command="updateStyle('lineWidth', $event)" placement="top"> <el-dropdown @command="updateStyle('lineWidth', $event)" placement="top">
<el-button><el-image src="/src/assets/images/borderwidth.png" <el-button><el-image src="/src/assets/icons/pngjpg/borderwidth.png"
style="width: 14px; height: 14px"></el-image></el-button> style="width: 14px; height: 14px"></el-image></el-button>
<template #dropdown> <template #dropdown>
<el-dropdown-menu> <el-dropdown-menu>
@ -309,11 +309,11 @@ const props = defineProps({
default: true default: true
}, },
height: { height: {
type: [Number,String], type: Number,
default: 700, default: 700,
}, },
width: { width: {
type: [Number,String], type: Number,
default: 1000, default: 1000,
}, },
data: { data: {
@ -685,20 +685,6 @@ const getCanvasBase64 = async () =>{
return base64 return base64
} }
const getCanvasBlob = async () =>{
return await app.exportImage({
type: 'image/jpeg',
renderBg: exportRenderBackground.value,
paddingX: exportImagePaddingX.value,
paddingY: exportImagePaddingY.value,
onlySelected: exportOnlySelected.value,
useBlob: true,
backgroundColor: '#ffffff'
})
}
watch(() => props.data, (newVal) => { watch(() => props.data, (newVal) => {
if (newVal) { if (newVal) {
setCanvasData(newVal) setCanvasData(newVal)
@ -787,8 +773,7 @@ defineExpose({
showFit, showFit,
getCanvasJson, getCanvasJson,
getCanvasBase64, getCanvasBase64,
setCanvasData, setCanvasData
getCanvasBlob
}) })
</script> </script>
@ -910,7 +895,7 @@ ol {
font-size: 14px; font-size: 14px;
color: #000; color: #000;
/deep/ .jsontree_tree { :deep(.jsontree_tree) {
font-family: 'Trebuchet MS', Arial, sans-serif !important; font-family: 'Trebuchet MS', Arial, sans-serif !important;
} }
} }

View File

@ -1,23 +1,12 @@
<template> <template>
<div class="list-content"> <div class="list-container">
<div class="list-container"> <div class="content-list" v-for="(item, index) in items" :key="index" @click="handleClick(item)">
<div class="content-list" v-for="(item, index) in items" :key="index" @click="handleClick(item)"> <div class="item-content">
<div class="item-content"> <div class="item-text">
<div class="item-text"> <div class="item-title">{{ item.title }}</div>
<div class="title-header"> <div class="item-description">{{ item.description }}</div>
<div class="item-title">{{ item.title }}</div>
<div class="icon-box">
<svg class="icon iconfont" aria-hidden="true" style="font-size: 35px;">
<use :xlink:href="item.icon"></use>
</svg>
</div>
</div>
<div class="item-description">{{ item.description }}</div>
<div class="item-bottom">
<el-tag :type="item.type" size="default">{{ item.title }}</el-tag>
</div>
</div>
</div> </div>
<el-icon class="item-icon"><component :is="item.icon" /></el-icon>
</div> </div>
</div> </div>
</div> </div>
@ -26,16 +15,17 @@
<script setup> <script setup>
import { shallowRef } from 'vue'; import { shallowRef } from 'vue';
import { ElMessage } from 'element-plus' import { ElMessage } from 'element-plus'
import { Plus, ArrowDown, Document, User, Setting } from '@element-plus/icons-vue';
const emit = defineEmits(['itemClick']) const emit = defineEmits(['itemClick'])
const items = shallowRef([ const items = shallowRef([
{ title: '自主搜题', description: '1111111111111111111111111111111111111', icon: '#icon-soutibao-',type:'primary' }, { title: '自主搜题', description: '1111111', icon: Document },
{ title: '校本题库', description: '222222', icon: '#icon-soutibao-',type:'success' }, { title: '校本题库', description: '222222', icon: User },
{ title: '个人题库', description: '333333', icon: '#icon-soutibao-',type:'default' }, { title: '个人题库', description: '333333', icon: Setting },
{ title: '智能推荐', description: '444444', icon: '#icon-tubiao_wuxing-',type:'default' }, { title: '智能推荐', description: '444444', icon: Plus },
{ title: '课堂展示', description: '555555', icon: '#icon-huaban',type:'primary' }, { title: '课堂展示', description: '555555', icon: ArrowDown },
{ title: '常规作业', description: '555555', icon: '#icon-zhaoxiangji',type:'primary' }, { title: '常规作业', description: '555555', icon: ArrowDown },
{ title: 'AI设计作业', description: '555555', icon: '#icon-jiqiren_o',type:'danger' }, { title: 'AI设计作业', description: '555555', icon: ArrowDown },
]); ]);
const handleClick = (item) => { const handleClick = (item) => {
@ -52,25 +42,20 @@ const handleClick = (item) => {
</script> </script>
<style scoped> <style scoped>
.list-content{
padding: 8px;
background-color: #f5f5f5;
border-radius: 8px;
height: 100%;
margin-left: 10px
}
.list-container { .list-container {
display: flex; display: flex;
flex-wrap: wrap; flex-wrap: wrap;
gap: 16px; gap: 16px;
padding: 16px;
/* background-color: #f5f5f5; */
} }
.content-list { .content-list {
background-color: #fff; background-color: #fff;
border-radius: 8px; border-radius: 8px;
box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1); box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
padding: 8px; padding: 16px;
width: calc(25% - 16px); width: calc(33.333% - 32px); /* 3列布局每列减去gap */
cursor: pointer; cursor: pointer;
transition: all 0.3s ease; transition: all 0.3s ease;
} }
@ -83,7 +68,6 @@ const handleClick = (item) => {
.item-content { .item-content {
display: flex; display: flex;
align-items: center; align-items: center;
height: 100%;
} }
.item-icon { .item-icon {
@ -94,10 +78,6 @@ const handleClick = (item) => {
.item-text { .item-text {
flex: 1; flex: 1;
justify-content: space-between;
display: flex;
flex-direction: column;
height: 100%;
} }
.item-title { .item-title {
@ -105,38 +85,10 @@ const handleClick = (item) => {
font-weight: 500; font-weight: 500;
color: #303133; color: #303133;
margin-bottom: 4px; margin-bottom: 4px;
font-weight: bold;
} }
.item-description { .item-description {
font-size: 14px; font-size: 14px;
color: #909399; color: #909399;
text-align: left;
display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2; /* 设置最大行数 */
overflow: hidden;
text-overflow: ellipsis;
word-break: break-all;
} }
.title-header {
display: flex;
justify-content: space-between;
align-items: center;
}
.item-bottom {
text-align: right;
}
/* 过渡动画 */
.fade-enter-active, .fade-leave-active {
transition: opacity 0.3s;
}
.fade-enter, .fade-leave-to {
opacity: 0;
}
</style> </style>

View File

@ -6,14 +6,14 @@
<el-button type="success" @click="handleTaskAssignToAllClass()">批量推送</el-button> <el-button type="success" @click="handleTaskAssignToAllClass()">批量推送</el-button>
</div> </div>
<div v-if="currentRow.id > 0" class="page-top-right"> <div v-if="currentRow.id > 0" class="page-top-right">
<el-button type="primary" @click="handleNewAllClass" :icon="Plus">设计新作业</el-button> <el-button type="primary" @click="handleNewAllClass">设计新作业</el-button>
</div> </div>
</div> </div>
<div class="page-resource"> <div class="page-resource">
<div class="page-left"> <div class="page-left">
<el-table <el-table
ref="taskTable" ref="taskTable"
v-loading="tasklist_loading" v-loading="loading"
:data="taskList" :data="taskList"
:tree-props="{checkStrictly: true}" :tree-props="{checkStrictly: true}"
row-key="id" row-key="id"
@ -22,22 +22,15 @@
@current-change="handleCurrentChange" @current-change="handleCurrentChange"
> >
<el-table-column type="selection" min-width="2%" align="center" :selectable="selectable"/> <el-table-column type="selection" min-width="2%" align="center" :selectable="selectable"/>
<el-table-column label="作业布置" min-width="15%" align="center"> <el-table-column label="作业布置" min-width="18%" align="center">
<template #default="scope"> <template #default="scope">
<div style="height: 100px;cursor: pointer"> <div style="height: 100px;">
<div style="display: flex;align-items: center;justify-content: space-between;"> <div class="pageleft-table-top">
<div style="width: 100%;"> <span>{{ scope.row.uniquekey }}</span>
<div class="pageleft-table-top"> </div>
<span>{{ scope.row.uniquekey }}</span> <div class="pageleft-table-top">
</div> <el-tag :type="scope.row.workclass" size="default">{{ scope.row.worktype }}</el-tag>
<div class="pageleft-table-top" style="display: flex;justify-content: space-between"> <span>{{ scope.row.timestamp }}</span>
<el-tag style="padding:0 2px" :type="scope.row.workclass" size="default">{{ scope.row.worktype }}</el-tag>
<el-text size="small" style="color:#ccc;white-space:nowrap">{{ scope.row.timestamp }}</el-text>
</div>
</div>
<svg class="icon iconfont" aria-hidden="true">
<use xlink:href="#icon-xiangyou"></use>
</svg>
</div> </div>
<div class="pageleft-table-cont"> <div class="pageleft-table-cont">
<p class="ellipsis "> {{ scope.row.worktype == "课堂展示" ? scope.row.worktag : scope.row.title }}</p> <p class="ellipsis "> {{ scope.row.worktype == "课堂展示" ? scope.row.worktag : scope.row.title }}</p>
@ -69,7 +62,7 @@
<div v-if="(currentRow.worktype == '课堂展示' || classWorkForm.worktype == '课堂展示') && currentRow.id>0" class="page-center"> <div v-if="(currentRow.worktype == '课堂展示' || classWorkForm.worktype == '课堂展示') && currentRow.id>0" class="page-center">
<div v-loading="boardLoading" class="board-wrap" style="height: 100%; flex: 1; overflow: hidden;"> <div v-loading="boardLoading" class="board-wrap" style="height: 100%; flex: 1; overflow: hidden;">
<!-- <whiteboard v-if="isShowBoard" ref="boardref" :height="mainHeight - 150" :isShowSave="false" :data="whiteboardObj"/> --> <!-- <whiteboard v-if="isShowBoard" ref="boardref" :height="mainHeight - 150" :isShowSave="false" :data="whiteboardObj"/> -->
<whiteboard ref="boardref" height="100%" width="100%" :isShowSave="false" :data="classWorkForm.whiteboardObj"/> <whiteboard ref="boardref" height=" 100%" :isShowSave="false" :data="classWorkForm.whiteboardObj"/>
</div> </div>
</div> </div>
<div v-if="(currentRow.worktype == '常规作业' || classWorkForm.worktype == '常规作业')&& currentRow.id>0" class="page-center"> <div v-if="(currentRow.worktype == '常规作业' || classWorkForm.worktype == '常规作业')&& currentRow.id>0" class="page-center">
@ -129,7 +122,6 @@
import { onMounted, ref,watch, reactive, getCurrentInstance,nextTick } from 'vue' import { onMounted, ref,watch, reactive, getCurrentInstance,nextTick } from 'vue'
import { ElMessage } from 'element-plus' import { ElMessage } from 'element-plus'
import { cloneDeep } from 'lodash' import { cloneDeep } from 'lodash'
import { Plus } from '@element-plus/icons-vue'
import { delClasswork } from '@/api/teaching/classwork' import { delClasswork } from '@/api/teaching/classwork'
import {listEntpcoursework, listEntpcourseworkNew, getEntpcoursework} from '@/api/education/entpCourseWork' import {listEntpcoursework, listEntpcourseworkNew, getEntpcoursework} from '@/api/education/entpCourseWork'
import { addClassworkReturnId } from '@/api/teaching/classwork' import { addClassworkReturnId } from '@/api/teaching/classwork'
@ -144,10 +136,6 @@ import whiteboard from '@/components/whiteboard/whiteboard.vue'
import FileUpload from "@/components/FileUpload/index.vue"; import FileUpload from "@/components/FileUpload/index.vue";
import Right from './Right/index.vue' import Right from './Right/index.vue'
import {
Delete
} from '@element-plus/icons-vue'
import SetHomework from '@/components/set-homework/index.vue' import SetHomework from '@/components/set-homework/index.vue'
import { useGetHomework } from '@/hooks/useGetHomework' import { useGetHomework } from '@/hooks/useGetHomework'
import { sessionStore } from '@/utils/store' import { sessionStore } from '@/utils/store'
@ -367,13 +355,13 @@ const handleCurrentChange = (val) => {
console.log(val,'???????????') console.log(val,'???????????')
if(val && val.id >0 ) { if(val && val.id >0 ) {
currentRow.value = val; currentRow.value = val;
classWorkForm.worktype = val.worktype; //
editListItem(val, courseObj).then((obj) => { editListItem(val, courseObj).then((obj) => {
if(obj){ if(obj){
propsformobj = obj; propsformobj = obj;
// //
classWorkForm.id = obj.id; classWorkForm.id = obj.id;
classWorkForm.uniquekey = cloneDeep(obj.uniquekey); // classWorkForm.uniquekey = cloneDeep(obj.uniquekey); //
classWorkForm.worktype = cloneDeep(obj.worktype); //
classWorkForm.title = cloneDeep(obj.title); // classWorkForm.title = cloneDeep(obj.title); //
classWorkForm.quizlist = cloneDeep(obj.quizlist); // classWorkForm.quizlist = cloneDeep(obj.quizlist); //
classWorkForm.chooseWorkLists = cloneDeep(obj.chooseWorkLists); // list classWorkForm.chooseWorkLists = cloneDeep(obj.chooseWorkLists); // list
@ -724,7 +712,7 @@ const editWork = async (cform) =>{
} }
} }
.page-left { .page-left {
width: 240px; width: 300px;
background-color: white; background-color: white;
border-radius: 10px; border-radius: 10px;
box-shadow: 0px 0px 20px 0px rgba(99, 99, 99, 0.06); box-shadow: 0px 0px 20px 0px rgba(99, 99, 99, 0.06);
@ -756,7 +744,7 @@ const editWork = async (cform) =>{
} }
.page-center{ .page-center{
flex: 1; flex: 1;
//min-width: calc(100% - 675px); // width: 100%;
height: 100%; height: 100%;
padding: 0 5px; padding: 0 5px;
margin: 0 5px; margin: 0 5px;

View File

@ -127,6 +127,7 @@ onMounted(() => {
.title-header{ .title-header{
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
align-items: center;
flex-direction: column; flex-direction: column;
} }

View File

@ -1,22 +1,16 @@
<template> <template>
<div> <div>
<div class="page-resource flex"> <div class="mb-4">
<!-- 左侧 教材 目录 --> <el-button type="primary" @click="onchange('/model/curriculum')">课标研读</el-button>
<ChooseTextbook @change-book="getData" @node-click="getData" /> <el-button type="primary" @click="onchange('/model/management')">作业管理1</el-button>
<el-button type="primary" @click="onchange('/model/newClassTaskAssign')">作业管理2</el-button>
<div class="page-right"> <el-button type="success" @click="onchange('/model/teaching')">教材研读</el-button>
<div class="button-container"> <el-button type="info" @click="onchange('/model/design')">教学框架设计</el-button>
<el-button style="margin-left: 12px;" type="primary" @click="onchange('/model/curriculum')">课标研读</el-button> <el-button type="success" @click="openPPTist">打开PPTist</el-button>
<el-button type="primary" @click="onchange('/model/management')">作业管理1</el-button> <!-- <el-button type="info" @click="onchange('/model/examination')">考试分析</el-button> -->
<el-button type="primary" @click="onchange('/model/newClassTaskAssign')">作业管理2</el-button> </div>
<el-button type="success" @click="onchange('/model/teaching')">教材研读</el-button> <ChooseTextbook @change-book="getData" @node-click="getData" />
<el-button type="info" @click="onchange('/model/design')">教学框架设计</el-button>
<el-button type="success" @click="openPPTist">打开PPTist</el-button>
<!-- <el-button type="info" @click="onchange('/model/examination')">考试分析</el-button> -->
</div>
</div>
</div> </div>
</div>
</template> </template>
<script setup> <script setup>
@ -32,10 +26,10 @@ const courseObj = reactive({
textbookId: '', textbookId: '',
levelFirstId: '', levelFirstId: '',
levelSecondId: '', levelSecondId: '',
coursetitle: '', coursetitle:'',
node: null, // node: null, //
//
}) })
// //
const getData = (data) => { const getData = (data) => {
const { textBook, node } = data const { textBook, node } = data
@ -56,53 +50,22 @@ const getData = (data) => {
courseObj.node = node; // courseObj.node = node; //
// ID // ID
localStorage.setItem('unitId', JSON.stringify({ levelFirstId, levelSecondId })) localStorage.setItem('unitId', JSON.stringify({ levelFirstId, levelSecondId}))
} }
const openPPTist = () => {
createWindow('open-win', { url: '/pptist' }) const openPPTist = () =>{
createWindow('open-win', {url: '/pptist'})
} }
const onchange = (path) => { const onchange = (path) =>{
if (path == '/model/newClassTaskAssign') { if(path == '/model/newClassTaskAssign'){
// //
router.push({ path, query: { courseObj: JSON.stringify(courseObj) } }) router.push({path, query: { courseObj: JSON.stringify(courseObj)}})
} else { }else{
router.push(path) router.push(path)
} }
} }
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped></style>
.page-resource {
height: 100%;
padding: 10px 15px 0;
.page-right {
min-width: 0;
display: flex;
flex-direction: column;
flex: 1;
margin-left: 20px;
height: 100%;
background: #ffffff;
border-radius: 10px;
box-shadow: 0px 0px 20px 0px rgba(99, 99, 99, 0.06);
}
.button-container {
display: flex;
flex-wrap: wrap;
gap: 10px;
margin: 1rem 0;
justify-content: flex-start;
.el-button {
flex: 1 1 15%;
max-width: 15%;
min-width: 15%;
box-sizing: border-box;
}
}
}
</style>