From ed307fc6a68cd6592589a4bafb7717c0fe7f74cd Mon Sep 17 00:00:00 2001 From: litian <2804272236@qq.com> Date: 星期四, 30 五月 2024 09:21:04 +0800 Subject: [PATCH] Merge branch 'master' of http://182.92.203.7:2001/r/TextbookReader --- src/views/home.vue | 4315 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 4,110 insertions(+), 205 deletions(-) diff --git a/src/views/home.vue b/src/views/home.vue index 4d72ddf..515ecca 100644 --- a/src/views/home.vue +++ b/src/views/home.vue @@ -1,281 +1,4186 @@ <template> <div class="homeBox"> - <div class="herderBox"> - <p>鏂囦欢</p> - <div class="viewChangeBox"> - <el-icon :size="16" v-if="viewMode == 0" @click="setViewMode"><Calendar /></el-icon> - <el-icon :size="16" v-if="viewMode == 1" @click="setViewMode"><Menu /></el-icon> - </div> - <div class="search"> - <el-input v-model="searchKey" size="small" placeholder="鍏抽敭瀛楁悳绱�"> - <template #append> - <el-button :icon="Search" /> - </template> - </el-input> + <div class="headerBox"> + <img :src="logo" v-if="bookConfig.textbookOwnership == '鍖椾含甯堣寖澶у鍑虹増闆嗗洟'" /> + <!-- <span class="logoTxt" v-else>閾侀亾鍑虹増绀�</span> --> + <span></span> + <div class="userInfoBox"> + <div class="userName" v-if="userInfo.name">{{ userInfo.name }}</div> + <div><div class="layout hover" @click="layoutBtn">閫�鍑�</div></div> </div> </div> - <div class="toolBox"> - <div class="checkBox" v-if="viewMode == 0"> - <el-checkbox - v-model="checkBoxState.check" - :indeterminate="checkBoxState.indeterminate" - @change="handleCheckAllChange" - /> - <span class="checkText">{{ - checkBoxState.selectCount > 0 - ? `宸查�� ${checkBoxState.selectCount} 椤筦 - : `鍏� ${checkBoxState.totalCount} 椤筦 - }}</span> - </div> - <div class="sortBox" v-if="viewMode == 0"> - <el-dropdown trigger="click" @command="sortChange"> - <span class="sortText"> - <el-icon :size="16"><Sort /></el-icon> - <span> - 鎸墈{ sortState.fields[sortState.selectFieldIndex].name - }}{{ sortState.types[sortState.selectTypeIndex].name }}鎺掑簭 - </span> - </span> - <template #dropdown> - <el-dropdown-menu> - <el-dropdown-item - v-for="(item, index) in sortState.fields" - :key="item.value" - :command="'fields.' + item.value" - > - <p> - <span> - <el-icon v-if="sortState.selectFieldIndex == index" :size="16" color="#409EFF"> - <Check /> - </el-icon> - </span> - <span>{{ item.name }}</span> - </p> - </el-dropdown-item> - <el-dropdown-item - v-for="(item, index) in sortState.types" - :key="item.value" - :divided="index == 0" - :command="'types.' + item.value" - > - <p> - <span> - <el-icon v-if="sortState.selectTypeIndex == index" :size="16" color="#409EFF"> - <Check /> - </el-icon> - </span> - <span>{{ item.name }}</span> - </p> - </el-dropdown-item> - </el-dropdown-menu> - </template> - </el-dropdown> - </div> - </div> - <div class="fileList"> - <div v-if="viewMode == 0" class="blockBox"> - <div class="fileItem" v-for="item in tableData"> - <div class="iconBox"> - <img :src="item.img" alt="" /> + <div class="contentBox"> + <!-- 鑿滃崟 --> + <div class="menuBox"> + <div v-for="(item, index) in menuData" :key="index" @click="menuItemClick(item.name)"> + <div :class="['menuItem', activeMenu == item.name ? 'active' : '']" v-if="item.isShow"> + <div class="menuIcon imgBox"> + <img :src="item.icon" /> + </div> + <div class="name">{{ item.name }}</div> </div> - <p class="name">{{ item.name }}</p> - <p class="time">{{ item.createDate }}</p> + </div> + <!-- <div class="reload hover" @click="reload()">鍒锋柊</div> --> + <!-- 璁剧疆 --> + <el-popover placement="right" :width="300" trigger="click"> + <div class="settingBox"> + <el-form :model="settingForm" label-width="auto" style="max-width: 400px"> + <el-form-item label="瀛椾綋澶у皬"> + <div class="lineStyle"> + <div class="lineTypeBox"> + <div + v-for="item in settingForm.fontSizeList" + :key="item.key" + :class=" + settingForm.fontSizeActive == item.key + ? 'typeItem lineTypeActive' + : 'typeItem' + " + @click="fontSizeSelect(item)" + > + {{ item.lable }} + <div class="activeIcon" v-if="settingForm.fontSizeActive == item.key"> + <img :src="xuanzhong" /> + </div> + </div> + </div> + </div> + </el-form-item> + <!-- <div class="inline"> + <el-form-item label="绛旈闊虫晥"> + <el-switch v-model="settingForm.acoustics" /> + </el-form-item> + <el-form-item label="绛旈鍔ㄧ敾"> + <el-switch v-model="settingForm.animation" /> + </el-form-item> + </div> --> + <el-form-item label="搴曡壊"> + <div class="bgColor"> + <div + v-for="item in settingForm.bgColorList" + :key="item.key" + class="flex1 hover" + @click="bgColorSelect(item)" + > + <div + :style="{ + background: item.key, + 'border-color': + item.key == settingForm.bgColorActive ? '#0093FF' : '#EBEBEB' + }" + class="scribeItem" + > + <img :src="xuanzhong1" v-if="item.key == settingForm.bgColorActive" /> + </div> + </div> + </div> + </el-form-item> + </el-form> + </div> + <template #reference> + <div class="setting hover"> + <img :src="setting" /> + <div>璁剧疆</div> + </div> + </template> + </el-popover> + </div> + <!-- 鑿滃崟鍐呭 --> + <div class="menuContent" v-if="menuState.open"> + <div class="searchBox"> + <div class="inputBox" v-if="activeMenu !== '璧勬簮'"> + <el-input + class="custom-input" + placeholder="璇疯緭鍏ュ唴瀹�" + v-model="searchText" + @keyup.enter="searchBook" + > + <template #prefix> + <el-icon><Search /></el-icon> + </template> + <template #suffix> + <svg + @click="searchBook" + xmlns="http://www.w3.org/2000/svg" + width="24" + height="24" + viewBox="0 0 24 24" + fill="none" + stroke="currentColor" + stroke-width="2" + stroke-linecap="round" + stroke-linejoin="round" + class="icon icon-tabler icons-tabler-outline icon-tabler-list-search hover" + > + <path stroke="none" d="M0 0h24v24H0z" fill="none" /> + <path d="M15 15m-4 0a4 4 0 1 0 8 0a4 4 0 1 0 -8 0" /> + <path d="M18.5 18.5l2.5 2.5" /> + <path d="M4 6h16" /> + <path d="M4 12h4" /> + <path d="M4 18h4" /> + </svg> + </template> + </el-input> + </div> + <div v-else class="resourceTab"> + <div class="tabItem hover" @click="selectResourceType('default')"> + <div>榛樿璧勬簮</div> + <div :class="resourceType == 'default' ? 'text' : 'line'"></div> + </div> + <hr class="hr" /> + <div class="tabItem hover" @click="selectResourceType('teacher')"> + <div>鏁欏笀璧勬簮</div> + <div :class="resourceType == 'teacher' ? 'text' : 'line'"></div> + </div> + </div> + </div> + <!-- 鐩綍 --> + <div class="menuList" v-if="activeMenu == '鐩綍'"> + <el-tree + ref="catalogTree" + default-expand-all="true" + :expand-on-click-node="false" + highlight-current + node-key="start" + :data="catalogueData" + :props="defaultProps" + v-if="catalogueData.length > 0" + @node-click="handleNodeClick" + :filter-node-method="filterNode" + > + <template #default="{ node, data }"> + <div class="custom-tree-node"> + <div class="catalogueLabel" :title="node.label">{{ node.label }}</div> + <span class="pageNum">{{ data.page }}</span> + </div> + </template> + </el-tree> + <div v-else> + <el-empty :image-size="60" description="鏆傛棤鏁版嵁" /> + </div> + </div> + <!-- 绗旇 --> + <div class="notesBox" v-if="activeMenu == '绗旇'"> + <div class="screenBox"> + <div class="title">绛涢��</div> + <div class="flex1 hover" @click="searchClick('all')"> + <div :class="menuState.notesColor == 'all' ? ' allActive' : 'all'">鍏ㄩ儴</div> + </div> + <div + v-for="item in colorSelectList" + :key="item.key" + class="flex1 hover" + @click="searchClick(item)" + > + <div + :style="{ background: item.key }" + :class="item.key == menuState.notesColor ? 'activeScribe scribeItem' : 'scribeItem'" + ></div> + </div> + </div> + <div class="list-box"> + <div v-if="scribeData.noteList.length > 0"> + <div v-for="(noteItem, index) in scribeData.noteList" :key="noteItem"> + <div class="chapterName"> + <el-icon + @click="noteClose(index)" + v-if="scribeData.isShow && scribeData.openIndex == index" + class="hover" + ><ArrowDown + /></el-icon> + <el-icon @click="noteOpen(index)" v-else class="hover"><ArrowRight /></el-icon> + <span>{{ noteItem.chapterName }}</span> + </div> + <div + v-for="(item, index1) in noteItem.noteList" + :key="item.key" + class="listItem" + v-show="scribeData.isShow && scribeData.openIndex == index" + > + <div class="textBox"> + <div class="title"> + <div class="title-con"> + <div + class="border-left" + :style="{ 'border-right-color': item.color }" + ></div> + <span>{{ moment(item.createDate).format('YYYY-MM-DD') }}</span> + </div> + <div> + <img :src="bianji" @click="update(item)" class="hover" /> + <img :src="shanchu" @click="deleteBtn(item)" class="hover" /> + </div> + </div> + <div + class="noteText hover 123456" + @click="jumpContent(item)" + :style="{ + background: + item.color == '#F5E12A' + ? 'rgba(255,234,41,0.1)' + : item.color == '#76F0AE' + ? 'rgba(83,255,162,0.1)' + : item.color == '#59CFF5' + ? 'rgba(93,216,255,0.1)' + : item.color == '#CAA5FC' + ? 'rgba(205,167,255,0.1)' + : item.color == '#F5A0B9' + ? 'rgba(255,167,193,0.1)' + : item.color + }" + > + <div class="con hover"> + {{ item.note }} + </div> + </div> + <div class="chapter">{{ item.txt }}</div> + </div> + </div> + </div> + </div> + <div v-if="scribeData.noteList.length == 0"> + <el-empty :image-size="60" description="鏆傛棤鏁版嵁" /> + </div> + </div> + </div> + <!-- 璧勬簮 --> + <div class="" v-if="activeMenu == '璧勬簮'"> + <div class="resourceBox" v-if="classifySelectList.length > 0"> + <div class="classification"> + <div + v-for="item in classifySelectList" + :key="item.key" + class="flex1 hover" + @click="classifyClick(item)" + > + <div + :class=" + item.key == activeClassify ? 'activeClassify classifyItem' : 'classifyItem' + " + > + <div class="title">{{ item.title }}</div> + <div class="count">{{ item.count }}</div> + </div> + </div> + <div class="showSearch flex1 hover"> + <div :class="searchShow ? 'imgBox' : 'imgBox activeSearch'" @click="searchBtn"> + <img :src="searchShow ? search : search1" /> + </div> + </div> + </div> + <div class="inputBox" v-if="!searchShow"> + <el-input + class="custom-input" + placeholder="璇疯緭鍏ュ唴瀹�" + v-model="searchText" + @keyup.enter="searchBook" + > + <template #prefix> + <el-icon><Search /></el-icon> + </template> + <template #suffix> + <svg + @click="searchBook" + xmlns="http://www.w3.org/2000/svg" + width="20" + height="20" + viewBox="0 0 20 20" + fill="none" + stroke="currentColor" + stroke-width="2" + stroke-linecap="round" + stroke-linejoin="round" + class="icon icon-tabler icons-tabler-outline icon-tabler-list-search hover" + > + <path stroke="none" d="M0 0h24v24H0z" fill="none" /> + <path d="M15 15m-4 0a4 4 0 1 0 8 0a4 4 0 1 0 -8 0" /> + <path d="M18.5 18.5l2.5 2.5" /> + <path d="M4 6h16" /> + <path d="M4 12h4" /> + <path d="M4 18h4" /> + </svg> + </template> + </el-input> + </div> + </div> + <div class="list-box"> + <div v-if="resourceDataList.length > 0" class="resourceList"> + <el-row :gutter="20"> + <el-col :span="12" v-for="(item, index) in resourceDataList" :key="item"> + <div class="resourceItem"> + <div + class="resourceImg" + @mouseover="showHandle = index" + @mouseleave="showHandle = null" + > + <img :src="item.resourcePath" mode="" v-if="activeClassify == 'image'"/> + <img :src="item.icon" mode="" v-else-if="item.icon && activeClassify != 'image'" /> + <!-- <el-icon v-else-if="activeClassify == 'image'" size="30"></el-icon> --> + <el-icon v-else-if="activeClassify == 'audio'" size="30"><Headset /></el-icon> + <el-icon v-else-if="activeClassify == 'video'" size="30" + ><VideoCamera + /></el-icon> + <el-icon v-else-if="activeClassify == 'other'" size="30"><Files /></el-icon> + <el-icon v-else-if="activeClassify == 'exercises'" size="30" + ><Tickets + /></el-icon> + <div class="handleBox" v-if="showHandle == index"> + <div class="delImg"> + <el-icon + class="icon hover" + size="20" + @click="JumpPosition(item)" + v-if="resourceType == 'default'" + ><LocationInformation + /></el-icon> + <el-icon + @click="goPlay(item)" + size="20" + class="icon hover" + v-if="item.resourceType == '瑙嗛'" + ><VideoPlay + /></el-icon> + <el-icon + @click="goPlay(item)" + size="20" + class="icon hover" + v-if="item.resourceType == '闊抽'" + ><Headset + /></el-icon> + <el-icon + @click="getCapture(item, index)" + size="20" + class="icon hover" + v-if="item.resourceType == '鍥剧墖'" + ><View + /></el-icon> + <el-icon + size="20" + class="icon hover" + @click="goPlay(item)" + v-if=" + !( + item.resourceType == '瑙嗛' || + item.resourceType == '闊抽' || + item.resourceType == '涔犻' || + item.resourceType == '鍥剧墖' + ) + " + ><Download + /></el-icon> + </div> + </div> + </div> + <div class="rName" :title="item.resourceName">{{ item.resourceName }}</div> + </div> + </el-col> + </el-row> + </div> + <div v-else> + <el-empty :image-size="60" description="鏆傛棤鏁版嵁" /> + </div> + </div> + </div> + <!-- 鐭ヨ瘑鍥捐氨 --> + <div class="" v-if="activeMenu == '鐭ヨ瘑鍥捐氨'"> + <div class="list-box"> + <div> + <el-empty :image-size="60" description="鏆傛棤鏁版嵁" /> + </div> + </div> + </div> + <!-- 鎴浘 --> + <div class="" v-if="activeMenu == '鎴浘'"> + <div class="list-box"> + <div class="screenshot" v-if="screenshotList.length > 0"> + <div v-for="(item, index) in screenshotList" :key="item" class="captureItem"> + <div class="imgBox" @mouseover="showDelete = index" @mouseleave="showDelete = null"> + <img :src="item.imgUrl" class="capture hover" mode="aspectFill" /> + <div class="deleteBox" v-if="showDelete == index"> + <div class="delImg"> + <el-icon @click="getCapture(item, index)" size="18" class="icon hover" + ><View + /></el-icon> + <img :src="bianji" class="icon hover" @click="updateScreenshot(item)" /> + <img :src="shanchu" class="icon hover" @click="deleteScreenshot(item)" /> + </div> + </div> + </div> + <div class="captureName" :title="item.name">{{ item.name }}</div> + </div> + </div> + <div v-else> + <el-empty :image-size="60" description="鏆傛棤鏁版嵁" /> + </div> + </div> + </div> + <!-- 鏍囩 --> + <div class="" v-if="activeMenu == '涔︾'"> + <div class="list-box"> + <div v-if="reMarkList.length > 0"> + <div v-for="(item, index) in reMarkList" :key="index" class="reMarkItem"> + <div class="reMarkCon"> + <span class="con">{{ item.content }}</span> <span>P{{ item.page }}</span> + </div> + <div class="deleteReMarkImg"> + <img :src="shanchu" class="icon hover" @click="deleteReMark(item)" /> + </div> + </div> + </div> + <div v-else> + <el-empty :image-size="60" description="鏆傛棤鏁版嵁" /> + </div> + </div> + </div> + <!-- 鑿滃崟鍐呭鏀惰捣 --> + <div class="menuStateBox" v-if="menuState.open"> + <svg + @click="menuState.open = false" + xmlns="http://www.w3.org/2000/svg" + width="20" + height="20" + viewBox="0 0 20 20" + fill="none" + stroke="currentColor" + stroke-width="2" + stroke-linecap="round" + stroke-linejoin="round" + class="icon icon-tabler icons-tabler-outline icon-tabler-arrow-bar-to-left" + > + <path stroke="none" d="M0 0h24v24H0z" fill="none" /> + <path d="M10 12l10 0" /> + <path d="M10 12l4 4" /> + <path d="M10 12l4 -4" /> + <path d="M4 4l0 16" /> + </svg> + <!-- <img :src="shouqiL" @click="menuState.open = false" /> --> </div> </div> - <el-table v-if="viewMode == 1" :data="tableData" style="width: 100%"> - <el-table-column type="selection" width="55" /> - <el-table-column type="index" width="80" /> - <el-table-column prop="name" label="鍚嶇О" sortable /> - <el-table-column prop="createDate" label="鍒涘缓鏃堕棿" width="200" sortable /> - <el-table-column prop="size" label="澶у皬" width="200" sortable /> - </el-table> + + <!-- 涓棿鍐呭 --> + <div class="pageBox"> + <!-- 澶撮儴鏄剧ず --> + <div class="pageBox-header"> + <!-- <div class="classTime"> --> + <div style="width: 150px"> + <!-- <div class="qureIcon"></div> + <div class="">宸蹭笂璇撅細{{ headerData.classTime }}</div> --> + </div> + <div class="progress"> + <div class="bookName">{{ bookConfig.bookName }}</div> + <div v-if="headerData.totlePage && bookConfig.bookName"> + {{ headerData.process }}/{{ headerData.totlePage }} + </div> + </div> + <div class="rightBox"> + <div class="pageSizeBox"> + <div><img :src="zoomOut" @click="changePageSize('reduce')" /></div> + <div>{{ headerData.pageSize }}%</div> + <div><img :src="zoomIn" @click="changePageSize('add')" /></div> + </div> + <!-- <div class="brushImgBox"> + <div @click="jumpContent('note' + index)"> + <img :src="huabi2" class="brushImg" />鐢荤瑪 + </div> + </div> --> + </div> + </div> + <!-- 寰簲鐢ㄧ洅瀛� --> + <div class="pageBox-content"> + <div class="content-box"> + <div id="container" :style="{ background: settingForm.bgColorActive }"></div> + <!-- 鐢荤瑪鐢诲竷 --> + <div class="canvas-box" v-show="canvasShow"> + <canvas id="canvasRef" :width="canvasWith" :height="canvasheight"></canvas> + </div> + </div> + </div> + <!-- 鐢荤瑪缁勪欢 --> + <div class="brushBox" v-if="floatingToolData.activeToolData == '鐢荤瑪'"> + <div class="toolList"> + <el-popover placement="top" width="250" trigger="click"> + <div class="popinnerBox"> + <div class="brush"> + <div class="thickness"> + <div + :class="toolSelectData.thicknessActive == '1' ? 'small active' : 'small'" + @click="selectThickness('1')" + ></div> + <div + :class="toolSelectData.thicknessActive == '3' ? 'middle active' : 'middle'" + @click="selectThickness('3')" + ></div> + <div + :class="toolSelectData.thicknessActive == '5' ? 'large active' : 'large'" + @click="selectThickness('5')" + ></div> + </div> + <div class="lineStyle"> + <div class="lineTypeBox"> + <div + :class=" + toolSelectData.lineTypeActive == 'solid' + ? 'typeItem lineTypeActive' + : 'typeItem' + " + @click="selectLineType('solid')" + > + <div class="solid"></div> + <div class="activeIcon" v-if="toolSelectData.lineTypeActive == 'solid'"> + <img :src="xuanzhong" /> + </div> + </div> + <div + :class=" + toolSelectData.lineTypeActive == 'dashed' + ? 'typeItem lineTypeActive' + : 'typeItem' + " + @click="selectLineType('dashed')" + > + <div class="dashed"></div> + <div class="activeIcon" v-if="toolSelectData.lineTypeActive == 'dashed'"> + <img :src="xuanzhong" /> + </div> + </div> + </div> + <div class="colorSelectBox"> + <div + v-for="item in colorSelectList" + :key="item.key" + class="flex1 hover" + @click="lineColorSelect(item)" + > + <div :style="{ background: item.key }" class="scribeItem"> + <img :src="xuanzhong" v-if="item.key == toolSelectData.lineColorActive" /> + </div> + </div> + </div> + </div> + </div> + </div> + <template #reference> + <div class="floatToolItem hover" @click="toolSelectHandle('huabi')"> + <el-tooltip class="box-item" effect="dark" content="鐢荤瑪" placement="bottom"> + <img :src="huabi2" alt="" class="imgBox" /> + </el-tooltip> + <!-- <div class="text">鐢荤瑪</div> --> + </div> + </template> + </el-popover> + <el-popover placement="top" width="250" trigger="click"> + <div class="popinnerBox"> + <div class="lineStyle"> + <div class="lineTypeBox"> + <div + :class=" + toolSelectData.fontSizeActive == '14' + ? 'typeItem lineTypeActive' + : 'typeItem' + " + @click="selectfontSize('14')" + > + 灏� + <div class="activeIcon" v-if="toolSelectData.fontSizeActive == '14'"> + <img :src="xuanzhong" /> + </div> + </div> + <div + :class=" + toolSelectData.fontSizeActive == '16' + ? 'typeItem lineTypeActive' + : 'typeItem' + " + @click="selectfontSize('16')" + > + 涓� + <div class="activeIcon" v-if="toolSelectData.fontSizeActive == '16'"> + <img :src="xuanzhong" /> + </div> + </div> + <div + :class=" + toolSelectData.fontSizeActive == '18' + ? 'typeItem lineTypeActive' + : 'typeItem' + " + @click="selectfontSize('18')" + > + 澶� + <div class="activeIcon" v-if="toolSelectData.fontSizeActive == '18'"> + <img :src="xuanzhong" /> + </div> + </div> + </div> + <div class="lineStyle"> + <div class="colorSelectBox"> + <div + v-for="item in colorSelectList" + :key="item.key" + class="flex1 hover" + @click="lineColorSelect(item)" + > + <div :style="{ background: item.key }" class="scribeItem"> + <img :src="xuanzhong" v-if="item.key == toolSelectData.lineColorActive" /> + </div> + </div> + </div> + </div> + </div> + </div> + <template #reference> + <div class="floatToolItem hover" @click="toolSelectHandle('wenzi')"> + <el-tooltip class="box-item" effect="dark" content="鏂囧瓧" placement="bottom"> + <img :src="wenzi2" alt="" class="imgBox" /> + </el-tooltip> + </div> + </template> + </el-popover> + <el-popover placement="top" width="250" trigger="click"> + <div class="popinnerBox"> + <div class="graphBox"> + <div class="graphSelect"> + <div class="flex1"> + <div class="square hover" @click="graphSelect('square')"></div> + </div> + <div class="flex1"> + <div class="rotundity hover" @click="graphSelect('rotundity')"></div> + </div> + <div class="flex1"> + <div class="triangle hover" @click="graphSelect('triangle')"></div> + </div> + <div class="flex1"> + <div class="lineSegment hover" @click="graphSelect('lineSegment')">/</div> + </div> + </div> + <div class="lineStyle"> + <div class="colorSelectBox"> + <div + v-for="item in colorSelectList" + :key="item.key" + class="flex1 hover" + @click="lineColorSelect(item)" + > + <div :style="{ background: item.key }" class="scribeItem"> + <img :src="xuanzhong" v-if="item.key == toolSelectData.lineColorActive" /> + </div> + </div> + </div> + </div> + </div> + </div> + <template #reference> + <div class="floatToolItem hover" @click="toolSelectHandle('tuxing')"> + <el-tooltip class="box-item" effect="dark" content="鍥惧舰" placement="bottom"> + <img :src="tuxing" alt="" class="imgBox" /> + </el-tooltip> + </div> + </template> + </el-popover> + <!-- <div class="floatToolItem" @click="toolSelectHandle('xiangpi')"> + <div class="imgBox"> + <img :src="clear" alt="" /> + </div> + <div class="text">姗$毊鎿�</div> + </div> --> + <div class="floatToolItem hover" @click="toolSelectHandle('chexiao')"> + <el-tooltip class="box-item" effect="dark" content="鎾ら攢" placement="bottom"> + <img :src="clearPrevious" alt="" class="imgBox" /> + </el-tooltip> + </div> + <!-- <div class="floatToolItem" @click="toolSelectHandle('chongzuo')"> + <div class="imgBox"> + <img :src="chongzuo" alt="" /> + </div> + <div class="text">閲嶅仛</div> + </div> --> + <div class="floatToolItem hover" @click="toolSelectHandle('qingchu')"> + <el-tooltip class="box-item" effect="dark" content="娓呴櫎" placement="bottom"> + <img :src="qingchu2" alt="" class="imgBox" /> + </el-tooltip> + </div> + <div class="layOutTool"></div> + <div class="floatToolItem hover" @click="toolSelectHandle('tuichu')"> + <el-tooltip class="box-item" effect="dark" content="閫�鍑�" placement="bottom"> + <img :src="tuichu" alt="" class="imgBox" /> + </el-tooltip> + </div> + </div> + </div> + </div> + <!-- 鏁欏缁勪欢 --> + <div class="toolBox"> + <div class="toolTitle"> + <span>{{ toolState.open ? '瀛︿範缁勪欢' : '缁勪欢' }}</span> + <div class="text"></div> + </div> + <div class="menuList"> + <ul class="menu" v-if="teachToolsMenuData.length > 0"> + <li v-for="item in teachToolsMenuData" :key="item.key"> + <div + :class="item.name === activeTool ? 'activeItem hover' : 'menuItem hover'" + :style="!toolState.open ? 'padding:10px 15px' : ''" + v-if="item.isShow" + @click="selectTeachTools(item)" + > + <img :src="item.icon" alt="" /> + <span v-if="toolState.open">{{ item.name }}</span> + </div> + </li> + </ul> + </div> + <div + :class="['openBox', toolState.open ? 'right' : '']" + v-if="teachToolsMenuData.length > 0" + > + <!-- <img :src="shouqiR" v-if="toolState.open" @click="toolState.open = false" /> --> + <!-- <img :src="shouqiL" v-if="!toolState.open" @click="toolState.open = true" /> --> + <svg + v-if="!toolState.open" + @click="toolState.open = true" + xmlns="http://www.w3.org/2000/svg" + width="24" + height="24" + viewBox="0 0 24 24" + fill="none" + stroke="currentColor" + stroke-width="2" + stroke-linecap="round" + stroke-linejoin="round" + class="icon icon-tabler icons-tabler-outline icon-tabler-arrow-bar-to-left" + > + <path stroke="none" d="M0 0h24v24H0z" fill="none" /> + <path d="M10 12l10 0" /> + <path d="M10 12l4 4" /> + <path d="M10 12l4 -4" /> + <path d="M4 4l0 16" /> + </svg> + <svg + v-if="toolState.open" + @click="toolState.open = false" + xmlns="http://www.w3.org/2000/svg" + width="24" + height="24" + viewBox="0 0 24 24" + fill="none" + stroke="currentColor" + stroke-width="2" + stroke-linecap="round" + stroke-linejoin="round" + class="icon icon-tabler icons-tabler-outline icon-tabler-arrow-bar-to-right" + > + <path stroke="none" d="M0 0h24v24H0z" fill="none" /> + <path d="M14 12l-10 0" /> + <path d="M14 12l-4 4" /> + <path d="M14 12l-4 -4" /> + <path d="M20 4l0 16" /> + </svg> + </div> + <div class="classRoomBox" v-if="false"> + <el-tabs v-model="activeName" class="demo-tabs" @tab-click="handleClick"> + <el-tab-pane label="澶囪缁勪欢" name="first"> + <div class="tabBox"> + <div class="insertSelect"> + <div + :class="selectType == 'resource' ? 'typeActive' : 'selectItem hover'" + @click="selectTypeClick('resource')" + > + <img :src="selectType == 'resource' ? charuziyuan_blue : charuziyuan" /> + <div>鎻掑叆璧勬簮</div> + </div> + <div + :class="selectType == 'answer' ? 'typeActive' : 'selectItem hover'" + @click="selectTypeClick('answer')" + > + <img :src="selectType == 'answer' ? dati_charu_blue : dati_charu" /> + <div>鎻掑叆绛旈</div> + </div> + </div> + </div> + </el-tab-pane> + <el-tab-pane label="涓婅缁勪欢" name="second"> + <div class="tabBox"> + <div class="giveLessons hover" @click="giveLessonsClick()"> + <img :src="xiake" /> + <span>{{ classStart ? '涓婅' : '涓嬭' }}</span> + </div> + </div> + </el-tab-pane> + </el-tabs> + </div> + </div> + <!-- 鐢荤瑪宸ュ叿鏍� --> + <div + draggable="true" + class="draggableBox" + :style="`left:${floatingToolData.elLeft}px`" + v-if="floatingToolBox.length > 0" + > + <div + class="hover" + v-for="item in floatingToolBox" + :key="item.name" + @click="floatItemHandle(item)" + > + <div v-if="item.isShow"> + <el-popover + placement="right" + width="120" + trigger="click" + v-if="floatingToolData.activeToolData == '鏍囪'" + > + <div class="popinnerBox"> + <div class="label" v-if="floatingToolData.activeToolData == '鏍囪'"> + <div class="labelItem hover" @click="labelShow('hide')"> + <img :src="hide" /> + <div>闅愯棌</div> + </div> + <div class="labelItem hover" @click="labelShow('show')"> + <img :src="show" /> + <div>鏄剧ず</div> + </div> + </div> + </div> + <template #reference> + <div + :class=" + floatingToolData.activeToolData == item.name + ? 'floatToolActive floatToolItem' + : 'floatToolItem' + " + > + <el-tooltip class="box-item" effect="dark" :content="item.name" placement="right"> + <div class="imgBox"> + <img :src="item.icon" alt="" /> + </div> + </el-tooltip> + <!-- <div class="text">{{ item.name }}</div> --> + </div> + </template> + </el-popover> + <div class="floatToolItem mark" + v-if="floatingToolData.activeToolData == '涔︾'" + > + <el-tooltip class="box-item" effect="dark" :content="item.name" placement="right"> + <div class="imgBox"> + <img :src="tagW" alt="" v-if="floatingToolData.activeToolData == item.name"/> + <img :src="item.icon" alt="" v-else/> + </div> + </el-tooltip> + </div> + <div + :class=" + floatingToolData.activeToolData == item.name + ? 'floatToolActive floatToolItem' + : 'floatToolItem' + " + v-else + > + <el-tooltip class="box-item" effect="dark" :content="item.name" placement="right"> + <div class="imgBox"> + <img :src="item.icon" alt=""/> + </div> + </el-tooltip> + <!-- <div class="text">{{ item.name }}</div> --> + </div> + </div> + </div> + </div> + + <!-- 閫変腑宸ュ叿鏍� --> + <div + class="dialogToolBox" + id="dialogToolBox" + v-show="showToolBox" + :style="{ top: `${dialogToolData.top}px`, left: `${dialogToolData.left}px` }" + > + <div class="colorSelectBox" v-show="toolActive == '楂樹寒' || toolActive == '鍒掔嚎'"> + <div + v-for="item in colorSelectList" + :key="item.key" + class="flex1 hover" + @click="clickSelect(item)" + > + <div :style="{ background: item.key }" class="scribeItem"> + <img :src="xuanzhong1" v-if="item.key == colorActive" /> + </div> + </div> + </div> + <div class="toolSelectBox" v-show="!(toolActive == '楂樹寒' || toolActive == '鍒掔嚎')"> + <div v-for="item in dialogToolList" :key="item.icon" @click="dialogToolHandle(item)"> + <div + :class="item.name == toolActive ? 'dialogToolItem active' : 'dialogToolItem'" + v-if="item.isShow" + > + <el-tooltip class="box-item" effect="dark" :content="item.name" placement="bottom"> + <img :src="item.icon" alt="" /> + </el-tooltip> + </div> + <!-- <span>{{ item.name }}</span> --> + </div> + </div> + </div> </div> </div> + <!-- 鍒掔嚎锛岄珮浜垹闄� --> + <div + class="lineDeleteBox" + v-show="lineDelete.showLineDelete" + :style="{ top: `${lineDelete.top}px`, left: `${lineDelete.left}px` }" + > + <!-- <el-button @click="delUserKey">鍒犻櫎</el-button> --> + <div class="dialogToolItem"> + <el-tooltip class="box-item" effect="dark" content="鍒犻櫎" placement="bottom"> + <img :src="trash" @click="delUserKey" /> + </el-tooltip> + </div> + <div class="dialogToolItem"> + <el-tooltip class="box-item" effect="dark" content="绗旇" placement="bottom" v-if="isUpdate"> + <img :src="noteUpdate" @click="updateNote" /> + </el-tooltip> + </div> + </div> + <!-- 绗旇鎮诞妗� --> + <div + class="noteContentBox" + v-show="noteContent.show" + :style="{ + top: `${noteContent.top}px`, + left: `${noteContent.left}px`, + background: noteContent.color + }" + > + <div>{{ noteContent.note }}</div> + </div> + <!-- 鑻辨枃涔﹂�変腑鍗曡瘝璇嶅吀鍐呭 --> + <div + class="dictionaryDataBox" + v-if="dictionaryData.showContent" + :style="{ top: `${dialogToolData.top}px`, left: `${dialogToolData.left}px` }" + > + <div class="content"> + <div class="word">{{ dictionaryData.data.word }}</div> + <div class="phone_con"> + <div class="per-phone"> + 鑻� <span>/{{ dictionaryData.data.ukPhone }}/</span + ><img + :src="sound" + class="soundBtn hover" + @click="soundWord(dictionaryData.data.word, 'en-UK')" + /> + </div> + <div class="per-phone"> + 缇� <span>/{{ dictionaryData.data.usPhone }}/</span + ><img + :src="sound" + class="soundBtn hover" + @click="soundWord(dictionaryData.data.word, 'en-US')" + /> + </div> + </div> + <div class="trans"> + <div v-for="item in dictionaryData.data.trans" :key="item"> + <div class="itemList"> + <div class="pos">{{ item.pos }}.</div> + <div class="tranCn">{{ item.tranCn }}</div> + </div> + </div> + </div> + </div> + </div> + + <el-dialog title="璧勬簮" align-center v-model="resourVisble" width="845" class="resourDialog"> + <div class="videoBox" v-if="resourType == '瑙嗛'"> + <video controls controlslist="nodownload" :src="testVideo"></video> + </div> + <div class="videoBox" v-if="resourType == '闊抽'"> + <!-- <video controls controlslist="nodownload" :src="testVideo"></video> --> + <audio ref="audioPlayer" :src="testVideo" controls></audio> + </div> + <!-- <div class="wordBox" v-if="resourType == 'word'"> + <vue-office-docx :src="testWord" /> + </div> --> + </el-dialog> + <!-- 鍥剧墖 --> + <el-image-viewer + v-if="confirmDialog" + :zoom-rate="1.2" + @close="closePreview" + :initial-index="previewIndex" + :url-list="imgPreviewList" + /> + <el-dialog + title="娣诲姞绗旇" + align-center + v-model="addNoteVisble" + :before-close="handleClose" + class="myNoteDialogs" + > + <div class="formBox"> + <el-input + type="textarea" + :rows="4" + v-model="formData.desc" + placeholder="璇疯緭鍏ョ瑪璁板唴瀹�" + ></el-input> + </div> + <div class="noteColorSelectBox"> + <div + v-for="item in colorSelectList" + :key="item.key" + class="flex1 hover" + @click="clickSelectColor(item)" + > + <div :style="{ background: item.key }" class="scribeItem"> + <img :src="xuanzhong" v-if="item.key == noteColorActive" /> + </div> + </div> + </div> + <template #footer> + <span class="dialog-footer"> + <el-button @click="handleClose">鍙� 娑�</el-button> + <el-button type="primary" @click="addUserKey" v-if="!isUpdate">纭� 瀹�</el-button> + <el-button type="primary" @click="updateUserKey" v-if="isUpdate">纭� 瀹�</el-button> + </span> + </template> + </el-dialog> + <el-dialog + title="淇濆瓨鎴浘" + align-center + v-model="screenshotVisble" + :before-close="screenshotClose" + width="400" + class="resourDialog screenshotDialog" + > + <div class="formBox"> + <el-input v-model="nameData" placeholder="璇疯緭鍏ユ埅鍥惧悕绉�"></el-input> + </div> + <template #footer> + <span class="dialog-footer"> + <el-button @click="screenshotClose">鍙� 娑�</el-button> + <el-button type="primary" @click="addScreenshot" :loading="screenshotLoading" + >纭� 瀹�</el-button + > + </span> + </template> + </el-dialog> + <el-dialog title="鐧惧害鐧剧" align-center v-model="baiduVisible" width="80%" class="baiduDialog"> + <div class="wendabox"> + <iframe :src="'https://baike.baidu.com/item/' + dialogToolData.txt" frameborder="0"></iframe> + </div> + </el-dialog> + <el-dialog + title="AI鏅鸿兘闂瓟" + align-center + v-model="wendaVisible" + width="60%" + class="myAnserDialogs" + > + <div class="wendabox"> + <iframe src="https://yiyan.baidu.com/" frameborder="0"></iframe> + </div> + </el-dialog> + <el-dialog title="璇嶅吀" align-center v-model="cidianVisible" width="60%" class="myAnserDialogs"> + <div class="wendabox"> + <!-- <iframe src="https://www.vocabulary.com/" frameborder="0"></iframe> --> + <dictionary /> + </div> + </el-dialog> + <el-dialog + title="GGB鍑芥暟宸ュ叿" + align-center + v-model="functionVisible" + width="80%" + class="myDialogs" + > + <div class="wendabox"> + <iframe src="https://www.geogebra.org/calculator" frameborder="0"></iframe> + </div> + </el-dialog> + <el-dialog title="鎬濈淮瀵煎浘" align-center v-model="siweiVisble" width="80%" class="myDialogs"> + <div class="wendabox"> + <iframe src="https://www.iodraw.com/mind" frameborder="0"></iframe> + </div> + </el-dialog> + <el-dialog title="妯″瀷宸ュ叿" align-center v-model="modelToolVisble" width="80%" class="myDialogs"> + <div class="wendabox"> + <iframe src="https://adjam93.github.io/threejs-model-viewer/#" frameborder="0"></iframe> + </div> + </el-dialog> </template> <script setup lang="ts"> -import { ref, reactive } from 'vue' -import { Search, Check } from '@element-plus/icons-vue' -import { useRouter, RouterView } from 'vue-router' -const router = useRouter() +import { ref, reactive, watch, onMounted, onBeforeMount, inject } from 'vue' +import { ctxUrl } from '@/assets/js/config' +import { useRouter, useRoute } from 'vue-router' +import useClipboard from 'vue-clipboard3' +const { toClipboard } = useClipboard() +const MG: any = inject('MG') +const toolClass = inject('toolClass') +const qiankunActions = inject('qiankunActions') +//鑾峰彇璺敱鍣� +let router = useRouter() +//鑾峰彇褰撳墠璺敱鐨勪俊鎭� +let route = useRoute() +import moment from 'moment' +import dictionary from '@/views/components/dictionary.vue' +import { ElMessage, ElMessageBox, valueEquals } from 'element-plus' +import logo from '@/assets/images/header/logo.png' +import mulu from '@/assets/images/menu/mulu.png' +import biji from '@/assets/images/menu/biji.png' +import ziyuan from '@/assets/images/menu/ziyuan.png' +import zhishitupu from '@/assets/images/menu/zhishitupu.png' +import jietu from '@/assets/images/menu/jietu.png' +import biaoqian from '@/assets/images/menu/biaoqian.png' +import topbg from '@/assets/images/header/top-bg.png' +import setting from '@/assets/images/operation/setting.png' +import search from '@/assets/images/operation/search.png' +import search1 from '@/assets/images/operation/search1.png' +import sound from '@/assets/images/operation/sound.png' -// 鎼滅储 -const searchKey = ref('') +import aIzhinengwenda from '@/assets/images/menu/AIzhinengwenda.png' +import aIyuyinyuedu from '@/assets/images/menu/AIyuyinyuedu.png' +import cidian from '@/assets/images/menu/cidian.png' +import shengzikapian from '@/assets/images/menu/shengzikapian.png' +import hudongwenda from '@/assets/images/menu/hudongwenda.png' +import siweidaotu from '@/assets/images/menu/siweidaotu.png' +import GGB from '@/assets/images/menu/GGB.png' +import jihe from '@/assets/images/menu/jihe.png' +import python from '@/assets/images/menu/python.png' +import cjiajia from '@/assets/images/menu/C++.png' +import javascript from '@/assets/images/menu/Javascript.png' +import moxinggongju from '@/assets/images/menu/moxinggongju.png' +import jisuanqi from '@/assets/images/menu/jisuanqi.png' +import fanqiezhong from '@/assets/images/menu/fanqiezhong.png' +import daiban from '@/assets/images/menu/daiban.png' +import shouqiR from '@/assets/images/menu/shouqi-R.png' +import shouqiL from '@/assets/images/menu/shouqi-L.png' +import charuziyuan from '@/assets/images/operation/charuziyuan.png' +import charuziyuan_blue from '@/assets/images/operation/charuziyuan_blue.png' +import dati_charu from '@/assets/images/operation/dati_charu.png' +import dati_charu_blue from '@/assets/images/operation/dati_charu_blue.png' +import xiake from '@/assets/images/operation/xiake.png' -// 閫夋嫨妗� -const checkBoxState = reactive({ - selectCount: 0, - totalCount: 0, - check: false, - indeterminate: false +import huabi from '../assets/images/operation/huabi-w.png' +import wenzi2 from '../assets/images/operation/wenzi.png' +import biaoqianw from '../assets/images/operation/biaoqian-w.png' +import tagW from '../assets/images/operation/tag-w.svg' +import baiban from '../assets/images/operation/baiban-w.png' +import biaozhu from '../assets/images/operation/pencil-minus.svg' +import jieping from '../assets/images/operation/screenshot-w.png' +import clearPrevious from '../assets/images/operation/clearPrevious.png' +import hide from '../assets/images/operation/hide.png' +import show from '../assets/images/operation/show.png' +import tuichu from '../assets/images/operation/tuichu.png' +import tuxing from '../assets/images/operation/tuxing.png' +import chongzuo from '../assets/images/operation/chongzuo.png' +import qingchu2 from '../assets/images/operation/qingchu.png' + +import gaoliang from '../assets/images/operation/gaoliang.png' +import gaoliang1 from '../assets/images/operation/gaoliang-b.png' +import huaxian from '../assets/images/operation/huaxian.png' +import huaxian1 from '../assets/images/operation/huaxian1.png' +import biji2 from '../assets/images/operation/biji.png' +import biji1 from '../assets/images/operation/biji-b.png' +import biaozhu2 from '../assets/images/operation/biaozhu.png' +import biaozhu3 from '../assets/images/operation/biaozhu1.png' +import fuzhi from '../assets/images/operation/fuzhi.png' +import fuzhi1 from '../assets/images/operation/fuzhi-b.png' +import AIyuedu from '../assets/images/operation/AIyuedu.png' +import AIyuedu1 from '../assets/images/operation/AIyuedu-b.png' +import cidian2 from '../assets/images/operation/cidian.png' +import cidian1 from '../assets/images/operation/cidian-b.png' +import baidu from '../assets/images/operation/baidu.png' +import baidu1 from '../assets/images/operation/baidu-b.png' +import yuyinyuedu from '../assets/images/operation/yuyinyuedu.png' +import yuyinyuedu1 from '../assets/images/operation/yuyinyuedu-b.png' +import xuanzhong from '../assets/images/operation/xuanzhong.png' +import xuanzhong1 from '../assets/images/operation/xuanzhong1.png' + +import zoomIn from '../assets/images/operation/zoomIn.png' +import zoomOut from '../assets/images/operation/zoomOut.png' +import huabi2 from '../assets/images/operation/huabi.svg' +import trash from '../assets/images/operation/trash.svg' +import noteUpdate from '../assets/images/operation/Note-b.svg' + +import shanchu from '../assets/images/operation/delete.png' +import bianji from '../assets/images/operation/bianji.png' +import video from '../assets/images/content/resource.png' +//寮曞叆VueOfficeDocx缁勪欢 +import VueOfficeDocx from '@vue-office/docx' +//寮曞叆鐩稿叧鏍峰紡 +import '@vue-office/docx/lib/index.css' +//鎴睆 +import ScreenShort from 'js-web-screen-shot' +import { start } from 'qiankun' +import axios from 'axios' +import { fabric } from 'fabric' + +import { loadMicroApp } from 'qiankun' +import { microApps } from '@/child.ts' +const canvasWith = ref(1000) +const canvasheight = ref(3000) +const screenWidth = ref( + window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth +) +let userInfo = ref({}) +let microApp = null // 寰簲鐢ㄥ疄渚� +const bookConfig = ref({}) +const activeCatalog = ref() +const reMarResult = ref() +onMounted(() => { + getUserInfo() + setTimeout(() => { + canvasWith.value = document.querySelector('.content-box').offsetWidth + canvasheight.value = document.querySelector('.content-box').offsetHeight + }, 5000) + if (screenWidth.value < 1180) { + menuState.open = false + toolState.open = false + if (!menuState.open) { + floatingToolData.elLeft = 90 + } + } + window.onresize = () => { + return (() => { + screenWidth.value = + window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth + })() + } + + // 鍔犺浇寰簲鐢� + microApp = loadMicroApp(microApps.book1, { + sandbox: { + strictStyleIsolation: true, + experimentalStyleIsolation: true + }, + singular: true + }) + + window.qiankunActions.onGlobalStateChange((state, prev) => { + console.log('鐖跺眰state鍙樺寲', state) + window.qiankunState = state + if (window.qiankunState && window.qiankunState.initTestBook) { + window.qiankunState.initTestBook( + localStorage.getItem('bookId') + '', + localStorage.getItem('tryPageCount') + ) + } + }) + + // 瀹氫箟鐖跺眰鏂规硶 + window.qiankunActions.setGlobalState({ + state: 1, // 鍔犺浇瀛愬簲鐢� + + windowSelection: (data) => { + // 缁戝畾瀛愬簲鐢ㄩ�夋嫨鐩戝惉浜嬩欢 + console.log(data, '瀛愬簲鐢ㄩ�夋嫨') + if (data.txt) { + getSelection(data) + } else { + showToolBox.value = false + lineDelete.showLineDelete = false + dictionaryData.showContent = false + toolActive.value = '' + lineDelete.top = data.y + 20 + lineDelete.left = data.x + } + }, + chooseWords: (data) => { + console.log(data, '鑻辫鐢熻瘝') + if (data) { + dialogToolData.txt = data.word + dialogToolData.left = data.x + dialogToolData.top = data.y + 20 + getSearchResult() + } + }, + getBookConfig: (data) => { + console.log(data.bookConfig, '鍥句功閰嶇疆') + bookConfig.value = data.bookConfig + getCatalogueData() + // getResourceData() + getTextbookComponents() + // getReMarkList() + }, + catalogChange: (data) => { + activeCatalog.value = data.showCatalogList + getSignData() + console.log(data, '绔犺妭鍒囨崲锛氱洰鍓嶆樉绀虹殑涓変釜绔犺妭') + }, + pageChange: (data) => { + headerData.process = Number(data.page) + currentChapter.value = data.catalog + console.log(data, '椤甸潰鍒囨崲锛氱洰鍓嶆樉绀洪〉闈㈠拰瀵瑰簲鐨勭珷鑺備俊鎭�') + if (catalogTree.value) { + catalogTree.value.setCurrentKey(Number(data.page)) + } + showToolBox.value = false + lineDelete.showLineDelete = false + dictionaryData.showContent = false + + reMarkCon.value = data.text + reMarResult.value = reMarkData.value.find((item) => { + return item.chapterNum == data.catalog && item.page == data.page + }) + if (reMarResult.value) { + floatingToolData.activeToolData = '涔︾' + } else { + floatingToolData.activeToolData = '' + } + } + }) + // 璋冪敤瀛愬眰鏂规硶 + // if (window.qiankunState && window.qiankunState.aa) window.qiankunState.aa(1) }) -const handleCheckAllChange = (val) => { - if (val) { - checkBoxState.check = true - } else { - checkBoxState.check = false - } - checkBoxState.indeterminate = false +// watch( +// () => screenWidth.value, +// (val) => { +// screenWidth.value = val +// if (screenWidth.value < 1180) { +// menuState.open = false +// toolState.open = false +// if (!menuState.open) { +// floatingToolData.elLeft = 90 +// } +// } else { +// } +// } +// ) + +const getUserInfo = () => { + MG.identity.getCurrentAppUser().then((res) => { + console.log(res, '鐢ㄦ埛淇℃伅') + if (res) { + let teacherRole = res.roleLinks.find((item) => item.role.refCode == 'teacher') + let teacherInfos = res.infoList.find((item) => item.type == 'teacherInfo') + let phoneInfo = res.secretList.find((item) => item.type == 'MobilePhone') + let nameAndPassword = res.secretList.find((item) => item.type == 'LoginNameAndPassword') + + if (nameAndPassword) { + userInfo.value = { + name: nameAndPassword.credential + } + localStorage.setItem('userInfo', JSON.stringify(userInfo.value)) + } else if (teacherRole && teacherInfos) { + userInfo.value = { + name: teacherInfos.name, + role: 'Teacher', + roleId: teacherRole.role.id + } + localStorage.setItem('userInfo', JSON.stringify(userInfo.value)) + } else if (phoneInfo) { + userInfo.value = { + name: phoneInfo.credential + } + localStorage.setItem('userInfo', JSON.stringify(userInfo.value)) + } + } + }) } -// 鎺掑簭 -const sortState = reactive({ - fields: [ +let menuData = [] //鑿滃崟 +let teachToolsMenuData = [] //鍙充晶瀛︿範缁勪欢 +let floatingToolBox = [] //涓棿鎮诞缁勪欢 +let dialogToolList = [] //閫変腑鏂囧瓧鎿嶄綔 +//鑾峰彇褰撳墠涔︾睄鎵�闇�缁勪欢 +const getTextbookComponents = () => { + menuData = [] + teachToolsMenuData = [] + floatingToolBox = [] + menuData = [ { - name: '鍚嶇О', - value: 'Name' + name: '鐩綍', + icon: mulu, + isShow: bookConfig.value.textbookComponents.indexOf('1E16353F') > -1 }, { - name: '鍒涘缓鏃堕棿', - value: 'CreateDate' + name: '绗旇', + icon: biji, + isShow: bookConfig.value.textbookComponents.indexOf('A3298FCF') > -1 }, { - name: '鏂囦欢澶у皬', - value: 'Size' + name: '璧勬簮', + icon: ziyuan, + isShow: bookConfig.value.textbookComponents.indexOf('A04689E6') > -1 + }, + { + name: '鐭ヨ瘑鍥捐氨', + icon: zhishitupu, + isShow: bookConfig.value.textbookComponents.indexOf('6BE6A3DC') > -1 + }, + { + name: '鎴浘', + icon: jietu, + isShow: bookConfig.value.textbookComponents.indexOf('CB0EACEC') > -1 + }, + { + name: '涔︾', + icon: biaoqian, + isShow: bookConfig.value.textbookComponents.indexOf('CF2E1400') > -1 } - ], - types: [ + ] + teachToolsMenuData = [ { - name: '鍗囧簭', - value: 'Asc' + name: 'AI鏅鸿兘闂瓟', + icon: aIzhinengwenda, + isShow: bookConfig.value.textbookComponents.indexOf('E30C0843') > -1 }, { - name: '闄嶅簭', - value: 'Desc' + name: '璇嶅吀', + icon: cidian, + isShow: bookConfig.value.textbookComponents.indexOf('83FB80FD') > -1 + }, + { + name: '鐢熷瓧鍗$墖', + icon: shengzikapian, + isShow: bookConfig.value.textbookComponents.indexOf('38D32EE3') > -1 + }, + { + name: '浜掑姩闂瓟', + icon: hudongwenda, + isShow: bookConfig.value.textbookComponents.indexOf('31F123A4') > -1 + }, + { + name: '鎬濈淮瀵煎浘', + icon: siweidaotu, + isShow: bookConfig.value.textbookComponents.indexOf('94FF5E48') > -1 + }, + { + name: 'GGB鍑芥暟宸ュ叿', + icon: GGB, + isShow: bookConfig.value.textbookComponents.indexOf('43C805B2') > -1 + }, + { + name: '鍑犱綍宸ュ叿', + icon: jihe, + isShow: bookConfig.value.textbookComponents.indexOf('FFFED2EF') > -1 + }, + { + name: 'Python', + icon: python, + isShow: bookConfig.value.textbookComponents.indexOf('1D48E00E') > -1 + }, + { + name: 'C++', + icon: cjiajia, + isShow: bookConfig.value.textbookComponents.indexOf('8E953BF7') > -1 + }, + { + name: 'Javascript', + icon: javascript, + isShow: bookConfig.value.textbookComponents.indexOf('25AC6CC2') > -1 + }, + { + name: '妯″瀷宸ュ叿', + icon: moxinggongju, + isShow: bookConfig.value.textbookComponents.indexOf('366F6CF3') > -1 + }, + { + name: '璁$畻鍣�', + icon: jisuanqi, + isShow: bookConfig.value.textbookComponents.indexOf('E9202857') > -1 + }, + { + name: '寰呭姙浜嬮」', + icon: daiban, + isShow: bookConfig.value.textbookComponents.indexOf('FA3A4284') > -1 + }, + { + name: '鐣寗闂归挓', + icon: fanqiezhong, + isShow: bookConfig.value.textbookComponents.indexOf('E4DC9777') > -1 } - ], - selectFieldIndex: 1, - selectTypeIndex: 1 + ] + floatingToolBox = [ + { + icon: huabi, + name: '鐢荤瑪', + isShow: bookConfig.value.textbookComponents.indexOf('800109C0') > -1 + }, + { + icon: baiban, + name: '鐧芥澘', + isShow: bookConfig.value.textbookComponents.indexOf('029DB3E0') > -1 + }, + { + icon: biaozhu, + name: '鏍囪', + isShow: bookConfig.value.textbookComponents.indexOf('2E613A8F') > -1 + }, + { + icon: biaoqianw, + name: '涔︾', + isShow: bookConfig.value.textbookComponents.indexOf('D2D30448') > -1 + }, + { + icon: jieping, + name: '鎴睆', + isShow: bookConfig.value.textbookComponents.indexOf('86F0A1B8') > -1 + } + ] + dialogToolList = [ + { + icon: gaoliang, + name: '楂樹寒', + isShow: bookConfig.value.textbookComponents.indexOf('395B91FC') > -1 + }, + { + icon: huaxian, + name: '鍒掔嚎', + isShow: bookConfig.value.textbookComponents.indexOf('229EC161') > -1 + }, + { + icon: biji2, + name: '绗旇', + isShow: bookConfig.value.textbookComponents.indexOf('BC9B0CBD') > -1 + }, + { + icon: biaozhu2, + name: '鏍囨敞', + isShow: bookConfig.value.textbookComponents.indexOf('A63EE24F') > -1 + }, + { + icon: fuzhi, + name: '澶嶅埗', + isShow: bookConfig.value.textbookComponents.indexOf('7D5594B3') > -1 + }, + { + icon: AIyuedu, + name: 'AI闃呰', + isShow: bookConfig.value.textbookComponents.indexOf('C05AA457') > -1 + }, + { + icon: cidian2, + name: '璇嶅吀', + isShow: bookConfig.value.textbookComponents.indexOf('83FB80FD') > -1 + }, + { + icon: baidu, + name: '鐧剧', + isShow: bookConfig.value.textbookComponents.indexOf('65F95274') > -1 + } + ] +} + +//鑾峰彇鐩綍 +const catalogueData = ref([]) + +const getCatalogueData = () => { + axios + .get(bookConfig.value.resourceUrl + '/information.json') + .then(function (response) { + var json = response.data + // 澶勭悊鑾峰彇鍒扮殑json鏁版嵁 + console.log(json, '鐩綍') + catalogueData.value = json.data + headerData.totlePage = json.data[json.data.length - 1].end + }) + .catch(function (error) { + console.log(error) + }) +} +const defaultProps = { + children: 'children', + label: 'label', + start: 'start' +} + +const filterNode = (value, data) => { + if (!value) return true + return data.label.indexOf(value) !== -1 +} + +const handleNodeClick = (data) => { + console.log(data) + headerData.process = data.start + if (window.qiankunState && window.qiankunState.gotoPage) + window.qiankunState.gotoPage(data.chapter, data.start) +} + +//鑾峰彇璧勬簮 +//璧勬簮鍒嗙被 +const classifySelectList = ref([]) +//璧勬簮绫诲瀷 +const resourceType = ref('default') //榛樿/鏁欏笀 +const activeClassify = ref('') +const searchShow = ref(true) +const defaultResourceList = ref([]) +const teacherResourceList = ref([]) +const resourceDataList = ref([]) +const resourVisble = ref(false) +const resourType = ref('') //璧勬簮绫诲瀷鍥剧墖/闊抽 +const testVideo = ref('') //瑙嗛閾炬帴 +const testWord = ref('') //word閾炬帴 +const showHandle = ref(null) + +const getResourceData = () => { + imgPreviewList.value = [] + axios + .get(bookConfig.value.resourceUrl + '/resource.json?t=12') + .then(function (response) { + var json = response.data + // 澶勭悊鑾峰彇鍒扮殑json鏁版嵁 + if (json.length > 0) { + defaultResourceList.value = [] + teacherResourceList.value = [] + // 鑾峰彇鏁扮粍涓墍鏈夊璞$殑age灞炴�х殑鏁伴噺 + json.forEach((item) => { + if(item.iconPath){ + item.icon = bookConfig.value.resourceUrl + '/' + item.iconPath + }else{ + item.icon = '' + } + if (resourceType.value == 'default') { + if (item.isTeacherResource == '鍚�') { + defaultResourceList.value.push(item) + } + } else { + if (item.isTeacherResource == '鏄�') { + teacherResourceList.value.push(item) + } + } + }) + if (defaultResourceList.value.length > 0) { + let imgCount = 0 + let audioCount = 0 + let videoCount = 0 + let exercisesCount = 0 + let otherCount = 0 + resourceDataList.value = [] + defaultResourceList.value.forEach((resItem) => { + if (resItem.resourceType == '鍥剧墖') { + if(resItem.resourcePath){ + resItem.resourcePath = bookConfig.value.resourceUrl + '/' + resItem.resourcePath + }else{ + resItem.resourcePath = bookConfig.value.requestCtx + '/file/GetPreViewImage?md5=' + resItem.md5 + } + + imgPreviewList.value.push(resItem.resourcePath) + if (activeClassify.value == 'image') { + resourceDataList.value.push(resItem) + } + imgCount++ + } else if (resItem.resourceType == '闊抽') { + if (activeClassify.value == 'audio') { + resourceDataList.value.push(resItem) + } + audioCount++ + } else if (resItem.resourceType == '瑙嗛') { + if (activeClassify.value == 'video') { + resourceDataList.value.push(resItem) + } + videoCount++ + } else if (resItem.resourceType == '涔犻') { + if (activeClassify.value == 'exercises') { + resourceDataList.value.push(resItem) + } + exercisesCount++ + } else { + if (activeClassify.value == 'other') { + resourceDataList.value.push(resItem) + } + otherCount++ + } + }) + classifySelectList.value = [] + if (imgCount > 0) { + classifySelectList.value.push({ + title: '鍥剧墖', + count: imgCount, + key: 'image' + }) + + } + if (audioCount > 0) { + classifySelectList.value.push({ + title: '闊抽', + count: audioCount, + key: 'audio' + }) + } + if (videoCount > 0) { + classifySelectList.value.push({ + title: '瑙嗛', + count: videoCount, + key: 'video' + }) + } + if (exercisesCount > 0) { + classifySelectList.value.push({ + title: '涔犻', + count: exercisesCount, + key: 'exercises' + }) + } + if (otherCount > 0) { + classifySelectList.value.push({ + title: '鍏朵粬', + count: otherCount, + key: 'other' + }) + } + if (!activeClassify.value) { + activeClassify.value = classifySelectList.value[0].key + defaultResourceList.value.forEach((resItem1) => { + if (resItem1.resourceType == classifySelectList.value[0].title) { + resourceDataList.value.push(resItem1) + } + }) + } + console.log(resourceDataList.value,"鍥剧墖") + // if(activeClassify.value == "video"){ + // resourceDataList.value.forEach((item,index)=>{ + // console.log(item,"item") + // let video = document.createElement("video"); + // video.src = bookConfig.value.requestCtx + '/file/api/ApiDownload?md5=' + item.md5; + // const canvas = document.createElement('canvas') + // canvas.width = 130 + // canvas.height = 80 + // const ctx:any = canvas.getContext('2d'); + // video.crossOrigin = 'anonymous' // 瑙e喅璺ㄥ煙闂锛屼篃灏辨槸鎻愮ず姹℃煋璧勬簮鏃犳硶杞崲瑙嗛 + // video.currentTime = 1 // 绗竴甯� + + // video.oncanplay = () => { //瑙嗛鍑嗗鎾斁 + // ctx.drawImage(video, 0, 0, canvas.width, canvas.height) + // item.icon = canvas.toDataURL("image/png"); //鑾峰彇base64鏍煎紡鐨勫浘鐗� + // } + // }) + + // } + } else { + let imgCount = 0 + let audioCount = 0 + let videoCount = 0 + let exercisesCount = 0 + let otherCount = 0 + resourceDataList.value = [] + teacherResourceList.value.forEach((resItem) => { + if (resItem.resourceType == '鍥剧墖') { + if(resItem.resourcePath){ + resItem.resourcePath = bookConfig.value.resourceUrl + '/' + resItem.resourcePath + }else{ + resItem.resourcePath = bookConfig.value.requestCtx + '/file/GetPreViewImage?md5=' + resItem.md5 + } + imgPreviewList.value.push(resItem.resourcePath) + if (activeClassify.value == 'image') { + resourceDataList.value.push(resItem) + } + imgCount++ + } else if (resItem.resourceType == '闊抽') { + if (activeClassify.value == 'audio') { + resourceDataList.value.push(resItem) + } + audioCount++ + } else if (resItem.resourceType == '瑙嗛') { + if (activeClassify.value == 'video') { + resourceDataList.value.push(resItem) + } + videoCount++ + } else if (resItem.resourceType == '涔犻') { + if (activeClassify.value == 'exercises') { + resourceDataList.value.push(resItem) + } + exercisesCount++ + } else { + if (activeClassify.value == 'other') { + resourceDataList.value.push(resItem) + } + otherCount++ + } + }) + classifySelectList.value = [] + if (imgCount > 0) { + classifySelectList.value.push({ + title: '鍥剧墖', + count: imgCount, + key: 'image' + }) + } + if (audioCount > 0) { + classifySelectList.value.push({ + title: '闊抽', + count: audioCount, + key: 'audio' + }) + } + if (videoCount > 0) { + classifySelectList.value.push({ + title: '瑙嗛', + count: videoCount, + key: 'video' + }) + } + if (exercisesCount > 0) { + classifySelectList.value.push({ + title: '涔犻', + count: exercisesCount, + key: 'exercises' + }) + } + if (otherCount > 0) { + classifySelectList.value.push({ + title: '鍏朵粬', + count: otherCount, + key: 'other' + }) + } + if (!activeClassify.value) { + activeClassify.value = classifySelectList.value[0].key + teacherResourceList.value.forEach((resItem1) => { + if (resItem1.resourceType == classifySelectList.value[0].title) { + resourceDataList.value.push(resItem1) + } + }) + } + } + } + }) + .catch(function (error) { + console.log(error) + }) +} +//璧勬簮鎾斁瑙嗛 +const goPlay = (data) => { + resourType.value = data.resourceType + if (data.resourceType == '瑙嗛' || data.resourceType == '闊抽') { + resourVisble.value = true + if (data.md5) { + testVideo.value = bookConfig.value.requestCtx + '/file/api/ApiDownload?md5=' + data.md5 + } else { + testVideo.value = bookConfig.value.resourceUrl + '/' + data.resourcePath + } + } else { + if (data.md5) { + window.open(bookConfig.value.requestCtx + '/file/api/ApiDownload?md5=' + data.md5) + } else if (data.resourcePath) { + window.open(bookConfig.value.resourceUrl + '/' + data.resourcePath) + } + } + + // else if (data.resourceType == 'word') { + // testWord.value = bookConfig.value.resourceUrl + '/' + data.resourcePath + // } +} + +//璧勬簮璺宠浆鍒版寚瀹氫綅缃� +const JumpPosition = (data) => { + console.log(data,"璺宠浆") + if (window.qiankunState && window.qiankunState.gotoPage) { + window.qiankunState.gotoPage(Number(data.chapterNum), Number(data.pagination)) + } +} + +//璧勬簮绫诲瀷閫夋嫨榛樿/鏁欏笀 +const selectResourceType = (type) => { + resourceType.value = type + searchText.value = '' + getResourceData() +} +//璧勬簮绫诲瀷鍥剧墖/瑙嗛/闊抽/涔犻/鍏朵粬 +const classifyClick = (item) => { + activeClassify.value = item.key + resourceDataList.value = [] + searchText.value = '' + getResourceData() +} +const searchBtn = () => { + if (searchShow.value) { + searchShow.value = false + } else { + searchShow.value = true + } +} + +// 閫変腑鑿滃崟 +const activeMenu = ref('鐩綍') + +// 鑿滃崟鐐瑰嚮 +const menuItemClick = (name) => { + searchText.value = '' + if (menuState.open && activeMenu.value == name) { + menuState.open = false + } else { + activeMenu.value = name + menuState.open = true + } + switch (name) { + case '鐩綍': + break + case '绗旇': + getNotesList() + break + case '璧勬簮': + getResourceData() + break + case '鐭ヨ瘑鍥捐氨': + break + case '鎴浘': + getScreenshotList() + break + case '涔︾': + getReMarkList() + break + } +} +//鍒锋柊褰撳墠椤甸潰 +const reload = () => { + location.reload() + // if (microApp) { + // microApp.unmount() // 鍗歌浇寰簲鐢� + // microApp = loadMicroApp(microApps.book1, { + // sandbox: { + // strictStyleIsolation: true, + // experimentalStyleIsolation: true + // } + // }) + // } else { + // location.reload() + // } +} + +const searchText = ref<string>('') //绛涢�� +const menuState = reactive({ + open: true, + notesColor: 'all' //绗旇棰滆壊 }) -const sortChange = (command) => { - const type = command.split('.')[0] - const data = command.split('.')[1] - if (type == 'fields') { - sortState.selectFieldIndex = sortState.fields.findIndex((item) => item.value == data) +const settingForm = reactive({ + fontSizeList: [ + { + lable: '灏�', + key: 14 + }, + { + lable: '涓�', + key: 16 + }, + + { + lable: '澶�', + key: 18 + } + ], + fontSizeActive: 16, + acoustics: false, + animation: false, + bgColorList: [ + { + lable: '榛�', + key: '#FBF9F4' + }, + { + lable: '缁�', + key: '#F2FFF7' + }, + { + lable: '绱�', + key: '#F6F4FC' + }, + { + lable: '绮�', + key: '#FFFAF9' + } + ], + bgColorActive: '#FBF9F4' +}) + +watch( + () => menuState.open, + (val) => { + if (menuState.open == false) { + floatingToolData.elLeft = 90 + } else { + floatingToolData.elLeft = 390 + } + } +) + +const fontSizeSelect = (item) => { + settingForm.fontSizeActive = item.key + window.qiankunActions.setGlobalState({ + fontSize: item.key + }) +} +const bgColorSelect = (item) => { + settingForm.bgColorActive = item.key +} +//绗旇棰滆壊绛涢�� +const searchClick = (item) => { + if (item != 'all') { + menuState.notesColor = item.key } else { - sortState.selectTypeIndex = sortState.types.findIndex((item) => item.value == data) + menuState.notesColor = 'all' + } + getNotesList() +} +//绗旇绔犺妭鏀惰捣 +const noteOpen = (index) => { + console.log(scribeData.isShow, index) + scribeData.isShow = true + scribeData.openIndex = index +} +//绗旇绔犺妭鎵撳紑 +const noteClose = (index) => { + scribeData.isShow = false + scribeData.openIndex = index +} + +const catalogTree = ref() +const searchBook = async () => { + switch (activeMenu.value) { + case '鐩綍': + if (catalogTree) catalogTree.value.filter(searchText.value) + break + case '绗旇': + getNotesList() + break + case '璧勬簮': + let dataList = JSON.parse(JSON.stringify(resourceDataList.value)) + if (searchText.value) { + resourceDataList.value = [] + searchText.value = searchText.value.replace(/^\s*|\s*$/g, '') + let text = searchText.value.replace(/^\s*|\s*$/g, '') + dataList.forEach((item) => { + if (item.resourceName.indexOf(text) > -1) { + resourceDataList.value.push(item) + } + }) + } else { + getResourceData() + } + break + case '鐭ヨ瘑鍥捐氨': + break + case '鎴浘': + getScreenshotList() + break + case '涔︾': + getReMarkList() + break } } -// 瑙嗗浘妯″紡 0:鍧楃姸瑙嗗浘 1:琛ㄦ牸瑙嗗浘 -const viewMode = ref(0) -const setViewMode = () => { - if (viewMode.value == 0) { - viewMode.value = 1 - } else { - viewMode.value = 0 +const baiduVisible = ref(false) +const wendaVisible = ref(false) +const cidianVisible = ref(false) +const functionVisible = ref(false) +const siweiVisble = ref(false) +const modelToolVisble = ref(false) +const activeTool = ref(0) +const toolState = reactive({ + open: true +}) + +const selectTeachTools = (item) => { + activeTool.value = item.name + switch (item.name) { + case 'AI鏅鸿兘闂瓟': + wendaVisible.value = true + break + case 'GGB鍑芥暟宸ュ叿': + functionVisible.value = true + break + case '鎬濈淮瀵煎浘': + siweiVisble.value = true + break + case '妯″瀷宸ュ叿': + modelToolVisble.value = true + break + case '璇嶅吀': + cidianVisible.value = true + break } } -// 鏂囦欢鍒楄〃 -const tableData = ref([]) +const activeName = ref('first') +const handleClick = (tab: TabsPaneContext, event: Event) => { + console.log(tab, event) +} +const selectType = ref('') +const selectTypeClick = (type) => { + if (selectType.value == 'resource' || selectType.value == 'answer') { + selectType.value = '' + } else { + selectType.value = type + } +} +const classStart = ref(true) +const giveLessonsClick = () => { + if (classStart.value) { + classStart.value = false + // 鍚姩璁℃椂鍣� + updateTimer() + } else { + classStart.value = true + stopTimer() + } +} + +//鐢诲竷鎮诞鎿嶄綔 + +let canvas = null +const floatingToolData = reactive({ + activeToolData: '', //閫変腑宸ュ叿 + elLeft: 390, + startclientx: 0, + startclienty: 0 +}) + +//鐢诲竷 +const canvasShow = ref(false) + +//鎴浘浜嬩欢 +const nameRef = ref() +const imgUrl = ref() +const confirmDialog = ref<Boolean>(false) +const screenshotVisble = ref<Boolean>(false) +const nameData = ref('') //鎴浘鍚嶇О +const screenshotLoading = ref(false) +const urlData = ref('') //鎴浘base64 +const screenshotList = ref([]) +const screenshotData = ref([]) +const imgPreviewList = ref([]) +const previewIndex = ref(0) +const showDelete = ref(null) +const isUpdateImg = ref(false) +const screenshotId = ref(0) + +//娴獥宸ュ叿鏍忕偣鍑讳簨浠� +const floatItemHandle = (item) => { + console.log(floatingToolData.activeToolData, 'floatingToolData.activeToolData') + if (floatingToolData.activeToolData == '鐢荤瑪') { + floatingToolData.activeToolData = '' + } else if (floatingToolData.activeToolData == '涔︾') { + delReMark() + floatingToolData.activeToolData = '' + } else { + floatingToolData.activeToolData = item.name + } + + canvasShow.value = false + switch (floatingToolData.activeToolData) { + case '鐢荤瑪': + canvasShow.value = true + toolSelectData.activeTool = 'huabi' + break + case '鏍囪': + break + case '涔︾': + reMark() + break + case '鎴睆': + jitT() + break + } +} + +//鐢荤瑪鎿嶄綔鏍忎簨浠� +const toolSelectData = reactive({ + activeTool: '', + fontSizeActive: '16', // 鏂囧瓧鎿嶄綔鏂囧瓧澶у皬 + thicknessActive: '3', //鐢荤瑪閫変腑绮楃粏 + lineTypeActive: 'solid', //鐢荤瑪閫変腑绾跨被鍨� + lineColorActive: '#333', //鐢荤瑪閫変腑绾块鑹� + graphType: '' //鍥惧舰绫诲瀷锛屾柟褰紝鍦嗗舰... +}) +const toolSelectHandle = (title) => { + toolSelectData.activeTool = title + toolSelectData.lineColorActive = '' + switch (title) { + case 'huabi': + init() + break + case 'wenzi': + break + case 'tuichu': + canvasShow.value = false + floatingToolData.activeToolData = '' + break + case 'qingchu': + canvas.clear() + break + } +} + +//閫変腑鐢荤瑪绮楃粏 +const selectThickness = (str) => { + toolSelectData.thicknessActive = str + canvas.freeDrawingBrush.color = toolSelectData.thicknessActive +} + +const selectLineType = (str) => { + toolSelectData.lineTypeActive = str + init() +} +//鐢荤瑪棰滆壊閫夋嫨 +const lineColorSelect = (item) => { + toolSelectData.lineColorActive = item.key + canvas.freeDrawingBrush.color = item.key +} +//鐢诲竷灞炴�� +const isDrawing = ref(true) // 鏄惁寮�鍚粯鍥撅紝true 寮�鍚紱false 鍏抽棴 +const init = () => { + canvas = new fabric.Canvas('canvasRef', { + isDrawingMode: isDrawing.value // 鍚敤缁樼敾妯″紡 + }) + canvas.freeDrawingBrush.color = toolSelectData.lineColorActive + canvas.freeDrawingBrush.width = toolSelectData.thicknessActive +} + +//鏂囧瓧澶у皬 +const selectfontSize = (str) => { + toolSelectData.fontSizeActive = str +} + +//閫夋嫨鍥惧舰 +const graphSelect = (type) => { + toolSelectData.graphType = type + switch (type) { + case 'square': + break + case 'rotundity': + break + case 'triangle': + break + case 'lineSegment': + break + } +} +//鏍囪鏄剧ず闅愯棌 +const labelShow = (str) => { + console.log(str, '鏍囪') + if (str == 'hide') { + if (window.qiankunState && window.qiankunState.delSign) { + window.qiankunState.delSign({ ids: [] }) + } + } +} + +//涔︾ +const currentChapter = ref(1) +const reMarkList = ref([]) +const reMarkData = ref([]) +const reMarkId = ref([]) +const reMarkCon = ref('') + +const reMark = () => { + let chapterData = catalogueData.value.find((item) => item.chapter == Number(currentChapter.value)) + if (catalogueData.value.length > 0) { + catalogueData.value.forEach((item1) => { + if (item1.chapter == Number(currentChapter.value) && item1.start == headerData.process) { + chapterData.label = item1.label + } + }) + } + + if (chapterData) { + reMarkData.value.push({ + id: toolClass.uuid(8), + createDate: new Date(), + page: headerData.process, + chapterNum: currentChapter.value, + chapterName: chapterData.label, + content: reMarkCon.value || chapterData.label + }) + MG.identity + .setUserKey({ + setKeyRequests: [ + { + domain: 'reMark', + key: bookConfig.value.bookId, + value: JSON.stringify(reMarkData.value) + } + ] + }) + .then((res) => { + // floatingToolData.activeToolData = '' + ElMessage({ + message: '娣诲姞涔︾鎴愬姛!', + type: 'success' + }) + getReMarkList() + }) + .catch(function (error) {}) + } +} +const getReMarkList = () => { + reMarkList.value = [] + reMarkData.value = [] + MG.identity + .getUserKey({ + domain: 'reMark', + keys: [bookConfig.value.bookId] + }) + .then((res) => { + if (res && res.length > 0 && res[0].value) { + reMarkData.value = JSON.parse(res[0].value) + let list = JSON.parse(res[0].value) + list.forEach((item) => { + let text = searchText.value.replace(/^\s*|\s*$/g, '') + if (searchText.value) { + if (item.name.indexOf(text) > -1) { + reMarkList.value.push(item) + } + } else { + reMarkList.value.push(item) + } + }) + } + }) +} +// 鍐呭椤靛垹闄や功绛� +const delReMark = () => { + let list = reMarkList.value.filter((itemData) => itemData.id !== reMarResult.value.id) + MG.identity + .setUserKey({ + setKeyRequests: [ + { + domain: 'reMark', + key: bookConfig.value.bookId, + value: JSON.stringify(list) + } + ] + }) + .then((res) => { + ElMessage({ + message: '鍒犻櫎涔︾鎴愬姛!', + type: 'success' + }) + getReMarkList() + }) +} +//涔︾鍒楄〃鍒犻櫎涔︾ +const deleteReMark = (item) => { + let list = reMarkList.value.filter((itemData) => itemData.id !== item.id) + MG.identity + .setUserKey({ + setKeyRequests: [ + { + domain: 'reMark', + key: bookConfig.value.bookId, + value: JSON.stringify(list) + } + ] + }) + .then((res) => { + ElMessage({ + message: '鍒犻櫎涔︾鎴愬姛!', + type: 'success' + }) + getReMarkList() + }) +} + +//鎴浘 +//鎴浘浜嬩欢 +function jitT() { + const screenShotHandler = new ScreenShort({ + enableWebRtc: false, // 鏄惁鏄剧ず閫夐」妗� + level: 99, // 灞傜骇绾у埆 + completeCallback: callback, //纭鍥炶皟 + closeCallback: closeFn //鍙栨秷鍥炶皟 + } as any) +} +//纭鍥炶皟 +const callback = (val: any) => { + screenshotVisble.value = true + nameData.value = moment(new Date()).format('YYYY-MM-DD HH:mm:ss') + urlData.value = val.base64 +} +//鍙栨秷鍥炶皟 +const closeFn = (base64: any) => { + console.log(base64) + floatingToolData.activeToolData = '' +} +//淇濆瓨鎴浘 +const addScreenshot = () => { + if (nameData.value) { + if (isUpdateImg.value) { + screenshotData.value = [] + screenshotList.value.forEach((itemNote) => { + if ((itemNote.id == screenshotId.value)) { + itemNote.name = nameData.value + } + }) + screenshotData.value = screenshotList.value + } else { + screenshotData.value.push({ + id: toolClass.uuid(8), + createDate: new Date(), + imgUrl: urlData.value, + name: nameData.value + }) + } + + screenshotLoading.value = true + MG.identity + .setUserKey({ + setKeyRequests: [ + { + domain: 'screenshot', + key: bookConfig.value.bookId, + value: JSON.stringify(screenshotData.value) + } + ] + }) + .then((res) => { + screenshotLoading.value = false + getScreenshotList() + nameData.value = '' + urlData.value = '' + floatingToolData.activeToolData = '' + screenshotVisble.value = false + isUpdateImg.value = false + }) + .catch(function (error) { + screenshotLoading.value = false + }) + } else { + ElMessage.error('鎴浘鍚嶇О涓嶈兘涓虹┖!') + } +} +const screenshotClose = () => { + screenshotVisble.value = false +} + +const getScreenshotList = () => { + screenshotData.value = [] + screenshotList.value = [] + imgPreviewList.value = [] + MG.identity + .getUserKey({ + domain: 'screenshot', + keys: [bookConfig.value.bookId] + }) + .then((res) => { + if (res && res.length > 0 && res[0].value) { + screenshotData.value = JSON.parse(res[0].value) + let list = JSON.parse(res[0].value) + list.forEach((item) => { + let text = searchText.value.replace(/^\s*|\s*$/g, '') + if (searchText.value) { + if (item.name.indexOf(text) > -1) { + screenshotList.value.push(item) + imgPreviewList.value.push(item.imgUrl) + } + } else { + screenshotList.value.push(item) + imgPreviewList.value.push(item.imgUrl) + } + }) + } + }) +} +//鏌ョ湅鎴浘 +const getCapture = (item, index) => { + imgUrl.value = item.imgUrl + previewIndex.value = index + confirmDialog.value = true +} +const closePreview = () => { + imgPreviewList.value = [] + confirmDialog.value = false +} +// 缂栬緫鎴浘鍚嶇О +const updateScreenshot = (item) => { + nameData.value = item.name + screenshotId.value = item.id + isUpdateImg.value = true + screenshotVisble.value = true +} + +//鍒犻櫎鎴浘 +const deleteScreenshot = (item) => { + let list = screenshotList.value.filter((itemData) => itemData.id !== item.id) + ElMessageBox.confirm('纭畾瑕佸垹闄ゆ鎴浘鍚楋紵', { + confirmButtonText: '纭畾', + cancelButtonText: '鍙栨秷', + autofocus: false, + type: 'warning' + }) + .then(() => { + MG.identity + .setUserKey({ + setKeyRequests: [ + { + domain: 'screenshot', + key: bookConfig.value.bookId, + value: JSON.stringify(list) + } + ] + }) + .then((res) => { + ElMessage({ + message: '鍒犻櫎鎴浘鎴愬姛!', + type: 'success' + }) + getScreenshotList() + }) + }) + .catch(() => {}) +} + +//閫変腑鏂囧瓧宸ュ叿鏍� +const showToolBox = ref(false) +const dialogToolData = reactive({ + left: 500, + top: 300, + txt: '', + page: '', + chapter: '', //閫変腑鏂囧瓧鎵�鍦ㄧ珷鑺� + lineHeight: [], //楂樹寒 + scribeList: [], //鍒掔嚎 + notesList: [] //绗旇 +}) + +///鍐呭閫変腑 +const getSelection = (data) => { + if (data.txt) { + toolActive.value = '' + dialogToolData.txt = data.txt + dialogToolData.page = data.page + dialogToolData.chapter = data.chapterNum + dialogToolData.left = data.x + dialogToolData.top = data.y + showToolBox.value = true + } +} + +const toolActive = ref('') +const colorActive = ref('') +const noteColorActive = ref('') + +const colorSelectList = reactive([ + { + label: '榛勮壊', + key: '#F5E12A' + }, + { + label: '缁胯壊', + key: '#76F0AE' + }, + { + label: '钃濊壊', + key: '#59CFF5' + }, + { + label: '绱壊', + key: '#CAA5FC' + }, + { + label: '绮夎壊', + key: '#F5A0B9' + } +]) + +//绗旇寮圭獥 +const addNoteVisble = ref(false) +const isUpdate = ref(false) +const formData = reactive({ + id: '', + desc: '' +}) +//绗旇寮圭獥鍏抽棴 +const handleClose = () => { + addNoteVisble.value = false + showToolBox.value = false + colorActive.value = '' +} + +//绗旇锛岄珮浜紝鍒掔嚎 +const scribeData = reactive({ + isShow: true, + openIndex: 0, + loading: false, + scribeDataList: [], //鍒掔嚎鑿滃崟鍒楄〃 + lineHeightList: [], //楂樹寒鑿滃崟鍒楄〃 + noteList: [] //绗旇鑿滃崟鍒楄〃 +}) +//璇嶅吀 +const dictionaryData = reactive({ + showContent: false, + data: null, + id: '' +}) + +const synth = window.speechSynthesis +const dialogToolHandle = async (item) => { + toolActive.value = item.name + colorActive.value = '' + switch (item.name) { + case 'AI闃呰': + window.speechSynthesis.cancel() + const synth = window.speechSynthesis + const utterance = new SpeechSynthesisUtterance(dialogToolData.txt) + console.log(utterance, 1) + utterance.lang = 'zh-CN' // 璁剧疆璇█涓轰腑鏂� + synth.speak(utterance) + showToolBox.value = false + break + case '鍒掔嚎': + break + case '楂樹寒': + break + case '绗旇': + formData.desc = '' + noteColorActive.value = '#F5E12A' + addNoteVisble.value = true + showToolBox.value = false + break + case '鏍囨敞': + break + case '澶嶅埗': + try { + //澶嶅埗 + await toClipboard(dialogToolData.txt) + //涓嬮潰鍙互璁剧疆澶嶅埗鎴愬姛鐨勬彁绀烘绛夋搷浣� + ElMessage({ + message: '澶嶅埗鎴愬姛', + type: 'success' + }) + } catch (err) { + ElMessage.error('鏃犳硶澶嶅埗鏂囨湰锛�' + err) + } + showToolBox.value = false + toolActive.value = '' + break + case '璇嶅吀': + getSearchResult() + + showToolBox.value = false + // cidianVisible.value = true + console.log(dialogToolData.txt) + break + case '鐧剧': + console.log('https://baike.baidu.com/item/' + dialogToolData.txt) + baiduVisible.value = true + break + } +} + +const clickSelect = (item) => { + colorActive.value = item.key + addUserKey() +} +//绗旇閫夐鑹� +const clickSelectColor = (item) => { + noteColorActive.value = item.key +} + +const addUserKey = () => { + let dom = '' + let data = null + switch (toolActive.value) { + case '楂樹寒': + dom = 'highLightData-' + bookConfig.value.bookId + data = dialogToolData.lineHeight[dialogToolData.chapter] + if (!data) data = [] + data.push({ + id: toolClass.uuid(8), + txt: dialogToolData.txt, + page: dialogToolData.page, + chapterNum: dialogToolData.chapter, + type: 'Highlight', + color: colorActive.value + }) + break + case '鍒掔嚎': + dom = 'underline-' + bookConfig.value.bookId + data = dialogToolData.scribeList[dialogToolData.chapter] + if (!data) data = [] + data.push({ + id: toolClass.uuid(8), + txt: dialogToolData.txt, + page: dialogToolData.page, + chapterNum: dialogToolData.chapter, + type: 'Dashing', + color: colorActive.value + }) + break + case '绗旇': + if (!formData.desc.replace(/^\s*|\s*$/g, '')) { + ElMessage.error('绗旇鍐呭涓嶈兘涓虹┖!') + return + } + if (!noteColorActive.value) { + ElMessage.error('璇烽�夋嫨绗旇棰滆壊!') + return + } + dom = 'notes-' + bookConfig.value.bookId + data = dialogToolData.notesList[dialogToolData.chapter] + if (!data) data = [] + data.push({ + id: toolClass.uuid(8), + txt: dialogToolData.txt, + page: dialogToolData.page, + chapterNum: dialogToolData.chapter, + type: 'Note', + color: noteColorActive.value, + createDate: new Date(), + note: formData.desc.replace(/^\s*|\s*$/g, '') + }) + + break + } + MG.identity + .setUserKey({ + setKeyRequests: [ + { + domain: dom, + key: dialogToolData.chapter, + value: JSON.stringify(data) + } + ] + }) + .then((res) => { + showToolBox.value = false + addNoteVisble.value = false + colorActive.value = '' + noteColorActive.value = '' + toolActive.value = '' + getSignData() + getNotesList() + }) +} + +const getSignData = () => { + MG.identity + .getUserKey({ + domain: 'highLightData-' + bookConfig.value.bookId, + keys: activeCatalog.value.map((item) => item + '') + }) + .then((res) => { + if (res && res.length > 0) { + for (let i = 0; i < res.length; i++) { + const item = res[i] + const data = JSON.parse(item.value) + // 鍌ㄥ�� + dialogToolData.lineHeight[item.key] = data + // 娓叉煋 + for (let j = 0; j < data.length; j++) { + const citem = data[j] + if (window.qiankunState && window.qiankunState.renderSign) + window.qiankunState.renderSign(citem.type, citem) + } + } + } + }) + MG.identity + .getUserKey({ + domain: 'underline-' + bookConfig.value.bookId, + keys: activeCatalog.value.map((item) => item + '') + }) + .then((res) => { + if (res && res.length > 0) { + for (let i = 0; i < res.length; i++) { + const item = res[i] + const data = JSON.parse(item.value) + // 鍌ㄥ�� + dialogToolData.scribeList[item.key] = data + + // 娓叉煋 + if (data.length > 0) { + for (let j = 0; j < data.length; j++) { + const citem = data[j] + if (window.qiankunState && window.qiankunState.renderSign) + window.qiankunState.renderSign(citem.type, citem) + } + } + } + } + }) + MG.identity + .getUserKey({ + domain: 'notes-' + bookConfig.value.bookId, + keys: activeCatalog.value.map((item) => item + '') + }) + .then((res) => { + if (res && res.length > 0) { + for (let i = 0; i < res.length; i++) { + const item = res[i] + const data = JSON.parse(item.value) + // 鍌ㄥ�� + dialogToolData.notesList[item.key] = data + // 娓叉煋 + if (data.length > 0) { + for (let j = 0; j < data.length; j++) { + const citem = data[j] + if (window.qiankunState && window.qiankunState.renderSign) + window.qiankunState.renderSign(citem.type, citem) + } + } + } + } + }) +} + +//鑿滃崟绗旇鍒楄〃 +const getNotesList = () => { + let chapterList = [] + catalogueData.value.forEach((item) => { + chapterList.push(item.chapter + '') + }) + let uniqueArray = [...new Set(chapterList)] + scribeData.noteList = [] + MG.identity + .getUserKey({ + domain: 'notes-' + bookConfig.value.bookId, + keys: uniqueArray + }) + .then((res) => { + if (res && res.length > 0) { + for (let i = 0; i < res.length; i++) { + const item = res[i] + // 鍌ㄥ�� + let data = catalogueData.value.find((item1) => item1.chapter == Number(item.key)) + // console.log(data,'666') + let dataList = [] + if (catalogueData.value.length > 0) { + catalogueData.value.forEach((item1) => { + if (item1.chapter == Number(item.key)) { + dataList.push(item1) + } + }) + } + let labels = '' + if (dataList.length > 1) labels = dataList.map((item) => item.label).join('/') + + let list = JSON.parse(item.value) + let itemList = [] + if (list.length > 0) { + list.forEach((item) => { + if (searchText.value) { + let text = searchText.value.replace(/^\s*|\s*$/g, '') + if (item.note.indexOf(text) > -1 || item.txt.indexOf(text) > -1) { + if (menuState.notesColor == 'all') { + itemList = list + } else if (item.color == menuState.notesColor) { + itemList.push(item) + } + } + } else { + if (menuState.notesColor == 'all') { + itemList = list + } else if (item.color == menuState.notesColor) { + itemList.push(item) + } + } + }) + } + if (dataList[0].chapter == Number(item.key) && itemList.length > 0) { + scribeData.noteList.push({ + chapter: dataList[0].chapter, + chapterName: labels ? labels : dataList[0].label, + noteList: itemList + }) + } + } + console.log(scribeData.noteList, 'scribeData.noteList') + } + }) +} + +//姝f枃涓垹闄ら珮浜紝鍒掔嚎锛岀瑪璁版搷浣滄 +const lineDelete = reactive({ + showLineDelete: false, + top: 0, + left: 0, + deleteType: '', + id: '' +}) + +// 鍒掔嚎銆佺瑪璁般�侀珮浜偣鍑诲洖璋� +window.signClick = (type, id, chapterNum) => { + console.log('signClick鐐瑰嚮浜嬩欢鍥炶皟鐨勫疄渚�', type, id, chapterNum) + dialogToolData.chapter = chapterNum + lineDelete.deleteType = type + lineDelete.id = id + lineDelete.showLineDelete = true + if (type == 'Note') { + noteContent.show = false + let list = dialogToolData.notesList[chapterNum] + let data = list.find((item) => item.id == id) + formData.id = id + formData.desc = data.note + noteColorActive.value = data.color + // addNoteVisble.value = true + isUpdate.value = true + } +} + +const updateNote = () => { + addNoteVisble.value = true + lineDelete.showLineDelete = false +} + +// 绗旇榧犳爣绉诲叆 +const noteContent = reactive({ + show: false, + top: 0, + left: 0, + note: '', + color: '' +}) +window.noteHover = (type, id, chapterNum) => { + console.log(type, 'typetype') + let list = dialogToolData.notesList[chapterNum] + let data = list.find((item) => item.id == id) + noteContent.note = data.note + noteContent.color = data.color + noteContent.show = true + document.addEventListener('mousemove', function (event) { + var x = event.offsetX + var y = event.offsetY + // console.log('榧犳爣鍧愭爣浣嶇疆锛�', x, y) + noteContent.top = event.clientY + 20 + noteContent.left = event.clientX + }) +} +window.noteOut = (type) => { + console.log(type, 123) + noteContent.show = false +} + +const delUserKey = () => { + let type = lineDelete.deleteType + let ids = lineDelete.id + let dom = '' + let data = null + switch (type) { + case 'Highlight': + dom = 'highLightData-' + bookConfig.value.bookId + data = dialogToolData.lineHeight + break + case 'Dashing': + dom = 'underline-' + bookConfig.value.bookId + data = dialogToolData.scribeList + break + case 'Note': + dom = 'notes-' + bookConfig.value.bookId + data = dialogToolData.notesList + break + } + let list = data[dialogToolData.chapter].filter((item) => item.id != ids) + MG.identity + .setUserKey({ + setKeyRequests: [ + { + domain: dom, + key: dialogToolData.chapter, + value: JSON.stringify(list) + } + ] + }) + .then((res) => { + lineDelete.showLineDelete = false + if (window.qiankunState && window.qiankunState.delSign) { + window.qiankunState.delSign({ ids: [ids] }) + } + getSignData() + if (type == 'Note') { + getNotesList() + } + }) +} + +//绗旇璺宠浆 +const jumpContent = (item) => { + console.log(item) + if (window.qiankunState && window.qiankunState.gotoPage) { + window.qiankunState.gotoPage(Number(item.chapterNum), Number(item.page)) + } +} + +//鑿滃崟绗旇缂栬緫 +const update = (item) => { + console.log(item) + dialogToolData.chapter = item.chapterNum + noteColorActive.value = item.color + formData.id = item.id + formData.desc = item.note + addNoteVisble.value = true + isUpdate.value = true +} +const updateUserKey = () => { + let data = scribeData.noteList.find((item1) => item1.chapter == dialogToolData.chapter) + data.noteList.forEach((itemNote) => { + if ((itemNote.id = formData.id)) { + itemNote.note = formData.desc + itemNote.color = noteColorActive.value + } + }) + MG.identity + .setUserKey({ + setKeyRequests: [ + { + domain: 'notes-' + bookConfig.value.bookId, + key: dialogToolData.chapter, + value: JSON.stringify(data.noteList) + } + ] + }) + .then((res) => { + addNoteVisble.value = false + isUpdate.value = false + getNotesList() + getSignData() + }) +} + +//鑿滃崟鍒犻櫎绗旇 +const deleteBtn = (item) => { + let data = scribeData.noteList.find((item1) => item1.chapter == Number(item.chapterNum)) + // 绉婚櫎 + let list = data.noteList.filter((itemData) => itemData.id !== item.id) + ElMessageBox.confirm('纭畾瑕佸垹闄ゆ绗旇鍚楋紵', { + confirmButtonText: '纭畾', + cancelButtonText: '鍙栨秷', + autofocus: false, + type: 'warning' + }) + .then(() => { + MG.identity + .setUserKey({ + setKeyRequests: [ + { + domain: 'notes-' + bookConfig.value.bookId, + key: item.chapterNum, + value: JSON.stringify(list) + } + ] + }) + .then((res) => { + ElMessage({ + message: '鍒犻櫎绗旇鎴愬姛!', + type: 'success' + }) + getNotesList() + if (window.qiankunState && window.qiankunState.delSign) { + window.qiankunState.delSign({ ids: [item.id] }) + } + }) + }) + .catch(() => {}) +} + +//鑾峰彇閫変腑鑻辨枃璇嶅吀 +const getSearchResult = () => { + if (dialogToolData.txt) { + MG.edu + .findWords([ + { + word: dialogToolData.txt, + isFull: false + } + ]) + .then((res) => { + console.log(res[0][0], 'cid') + if (res.length > 0 && res[0].length > 0) { + res[0].map((item) => { + item.trans = JSON.parse(item.trans) + }) + dictionaryData.data = res[0][0] + console.log(dictionaryData.data, '14') + dictionaryData.showContent = true + } + }) + } +} + +//鍗曡瘝闃呰 +const soundWord = (word, en) => { + window.speechSynthesis.cancel() + const synth = window.speechSynthesis + const utterances = new SpeechSynthesisUtterance(word) + // utterances.lang = en // 璁剧疆璇█涓轰腑鏂� + synth.speak(utterances) +} +//鍐呭鍖哄煙椤堕儴鏄剧ず + +const headerData = reactive({ + classTime: '00:00:00', + seconds: 0, + minutes: 0, + hours: 0, + process: 0, + totlePage: 0, + pageSize: 100 +}) +//涓婅鏃堕暱璁℃椂鍣� +const timer = ref(null) +const updateTimer = () => { + // 娓呴櫎涔嬪墠鐨勫畾鏃跺櫒锛岄槻姝㈠涓畾鏃跺櫒鍚屾椂杩愯 + stopTimer() + timer.value = setInterval(() => { + headerData.seconds++ + if (headerData.seconds === 60) { + headerData.seconds = 0 + headerData.minutes++ + } + if (headerData.minutes === 60) { + headerData.minutes = 0 + headerData.hours++ + } + // 鏍煎紡鍖栨椂闂� + const formattedTime = `${headerData.hours.toString().padStart(2, '0')}:${headerData.minutes.toString().padStart(2, '0')}:${headerData.seconds.toString().padStart(2, '0')}` + headerData.classTime = formattedTime + }, 1000) // 闂撮殧1绉� +} +const stopTimer = () => { + if (timer.value) { + clearInterval(timer.value) + timer.value = null + headerData.classTime = '00:00:00' + } +} + +const changePageSize = (str) => { + if (str == 'add' && headerData.pageSize < 150) { + headerData.pageSize = Number(headerData.pageSize) + 10 + window.qiankunActions.setGlobalState({ + scale: headerData.pageSize + }) + } else if (str == 'reduce' && headerData.pageSize > 50) { + headerData.pageSize = Number(headerData.pageSize) - 10 + window.qiankunActions.setGlobalState({ + scale: headerData.pageSize + }) + } +} + +const layoutBtn = () => { + localStorage.clear() + router.push('/login') +} </script> <style lang="less"> .homeBox { width: 100%; height: 100%; - padding: 50px; - box-sizing: border-box; + background: #87ccff; + border-radius: 10px; display: flex; flex-direction: column; - .herderBox { - overflow: hidden; - margin-bottom: 20px; - p { - float: left; - font-size: 20px; + padding: 0 15px; + .headerBox { + height: 48px; + // background-image: url('@/assets/images/header/top-bg.png'); + background-size: 100% 100%; + background-repeat: no-repeat; + padding: 0 20px; + display: flex; + justify-content: space-between; + align-items: center; + .logoTxt { + font-size: 24px; + color: #333; + letter-spacing: 2px; font-weight: bold; - line-height: 32px; } - .search { - float: right; - margin-right: 20px; - } - .viewChangeBox { - float: right; - line-height: 32px; - i { - cursor: pointer; - vertical-align: sub; + .userInfoBox { + display: flex; + align-items: center; + .userName { + font-size: 18px; + margin-right: 15px; + padding-right: 15px; + border-right: 1px solid #e0e0e0; + color: #2c2c2c; + } + .layout { + width: 69px; + height: 30px; + background: #0093ff; + border-radius: 15px; + color: #fff; + text-align: center; + line-height: 30px; } } } - .toolBox { + .contentBox { overflow: hidden; - margin-bottom: 10px; - line-height: 32px; - .checkBox { - float: left; - .checkText { - display: inline-block; - line-height: 32px; - vertical-align: top; - margin-left: 8px; - } - } - .sortBox { - float: right; - .sortText { - width: 150px; - line-height: 32px; - cursor: pointer; - i, - span { - vertical-align: middle; - } - } - } - } - .fileList { flex: 1; - overflow: auto; - .blockBox { - overflow: hidden; - .fileItem { - width: 140px; - float: left; - margin: 20px; - padding: 15px; + display: flex; + position: relative; + .menuBox { + width: 80px; + flex-shrink: 0; + border-right: 1px solid #e6e7e8; + padding-bottom: 20px; + box-sizing: border-box; + position: relative; + box-shadow: 10px 0 10px -10px rgba(0, 0, 0, 0.07); + background: #fff; + border-radius: 16px 0px 0px 0px; + .menuItem { + text-align: center; + line-height: 1; + cursor: pointer; + padding: 5px 0 10px 0; + width: 63px; + margin: 10px auto; border-radius: 10px; - cursor: context-menu; + &.active, &:hover { - background-color: #f1f1f1; + background-color: rgba(0, 147, 255, 0.1); + p { + color: #0093ff; + } } - .iconBox { + .menuIcon { + display: inline-block; + width: 32px; + height: 32px; + } + .name { + text-align: center; + line-height: 1; + color: #2c3e50; + } + } + .reload { + width: 80px; + position: absolute; + bottom: 100px; + text-align: center; + } + .setting { + width: 80px; + position: absolute; + bottom: 30px; + text-align: center; + } + } + .menuContent { + width: 300px; + flex-shrink: 0; + height: calc(100vh - 48px); + overflow-y: auto; + background: #e0f2ff; + .searchBox { + width: 100%; + height: 60px; + background: #ffffff; + display: flex; + justify-content: center; + align-items: center; + border-bottom: 1px solid #efefef; + } + .resourceBox { + padding: 10px 0; + margin: 0 20px; + border-bottom: 1px solid rgba(204, 204, 204, 0.32); + .classification { width: 100%; - height: 140px; - margin-bottom: 10px; + display: flex; + justify-content: space-between; + align-items: center; + .flex1 { + flex: 1; + text-align: center; + } + .title { + color: #999999; + } + .count { + width: 35px; + margin: 0 auto; + margin-top: 5px; + border-radius: 10px; + background: #fff; + color: #c8c8c8; + height: 18px; + font-size: 12px; + } + .activeClassify, + .classifyItem:hover { + .title { + color: #0093ff; + } + .count { + background: #0093ff; + color: #fff; + } + } + .showSearch { + .imgBox { + width: 39px; + height: 24px; + border-radius: 16px; + margin: 0 auto; + } + .imgBox:hover, + .activeSearch { + border: 1px solid #0093ff; + } + } + } + .inputBox { + margin-top: 10px; + width: 100% !important; + } + } + .resourceTab { + width: 100%; + height: 60px; + display: flex; + justify-content: center; + align-items: center; + font-size: 16px; + .hr { + height: 25px; + color: #dbdbdb !important; + } + .tabItem:first-child(1) { + border-right: 1px solid #707070; + } + .tabItem { + flex: 1; + text-align: center; + line-height: 57px; + } + .text { + width: 43px; + height: 3px; + margin: 0 auto; + background: #0093ff; + border-radius: 3px 3px 0px 0px; + } + .line { + height: 3px; + } + } + .inputBox { + width: 85%; + .custom-input { + border: 1px solid #0093ff !important; + border-radius: 50px; + overflow: hidden; + background: #fff; + height: 34px; + } + .is-focus, + .el-input__wrapper { + box-shadow: none !important; + .el-input__inner { + border: none !important; + height: 34px !important; + } + } + } + .screenBox { + display: flex; + padding: 0 10px; + .title { + margin: 10px 0; + line-height: 40px; + padding: 0 10px; + border: none; + } + + .flex1 { + flex: 1; + display: flex; + align-items: center; + justify-content: space-between; + } + + .all { + width: 50px; + height: 22px; + border-radius: 17px; + margin: 10px 10px 10px 0; + border: 1px solid #d8d8d8; + text-align: center; + line-height: 20px; + font-size: 12px; + } + + .allActive { + width: 50px; + height: 22px; + border-radius: 17px; + margin: 10px 10px 10px 0; + text-align: center; + line-height: 20px; + color: #fff; + background: #0093ff; + border: 1px solid #0093ff; + font-size: 12px; + } + + .scribeItem { + width: 18px; + height: 18px; + border-radius: 3px; + margin: 10px auto; + border: none; + } + + .activeScribe { + border: 1px solid #0093ff; + } + } + .menuList { + height: calc(100% - 60px); + overflow-y: auto; + padding: 10px 0; + } + .list-box { + .resourceList { + padding: 10px; + .resourceItem { + padding: 10px 0; + align-items: center; + + .resourceImg { + // width: 130px; + height: 80px; + background: #fff; + border-radius: 5px; + overflow: hidden; + display: flex; + align-items: center; + justify-content: center; + position: relative; + img { + height: 100%; + width: 100%; + object-fit: contain; + } + .handleBox { + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; + background: rgba(44, 44, 44, 0.6); + text-align: center; + padding: 2px; + .delImg { + height: 100%; + display: flex; + align-items: center; + justify-content: center; + .icon { + position: static; + margin: 5px; + color: #fff; + } + } + } + } + + .rName { + margin-top: 10px; + line-height: 20px; + } + } + } + .screenshot { + padding: 20px; + display: flex; + flex-wrap: wrap; + justify-content: space-between; + .captureItem { + margin-bottom: 10px; + width: 46%; + position: relative; + .imgBox { + border: 1px solid #d8d8d8; + width: 100%; + height: 80px; + margin-bottom: 5px; + } + .deleteBox { + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; + background: rgba(44, 44, 44, 0.6); + text-align: center; + padding: 2px; + .delImg { + height: 100%; + display: flex; + align-items: center; + justify-content: center; + .icon { + position: static; + margin: 5px; + color: #fff; + } + } + } + // .capture { + // width: 100%; + // } + .captureName { + height: 20px; + line-height: 20px; + width: 120px; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + color: #000; + } + } + } + + .listItem { + border-bottom: 1px solid rgba(212, 212, 212, 0.16); + position: relative; + margin: 10px; + line-height: 20px; + background: #fff; + border-radius: 5px; + padding: 10px 0; + .textBox { + .title { + display: flex; + justify-content: space-between; + align-items: center; + margin-right: 10px; + .border-left { + height: 25px; + border-right: 4px solid; + border-radius: 0 5px 5px 0; + margin-right: 10px; + } + .title-con { + display: flex; + align-items: center; + color: #949494; + .round { + width: 10px; + height: 10px; + border-radius: 50%; + margin-right: 5px; + } + } + + img { + margin-left: 5px; + } + } + .chapter { + color: #b7b7b7; + margin: 5px 5px 5px 14px; + display: -webkit-box; + -webkit-box-orient: vertical; + -webkit-line-clamp: 1; + overflow: hidden; + border-left: 3px solid #b7b7b7; + border-left-radius: 20px; + padding: 0 5px; + } + } + .noteText { + margin: 10px 10px 10px 15px; + border-radius: 3px; + padding: 2px 5px; + .con { + max-height: 65px; + display: -webkit-box; + -webkit-box-orient: vertical; + -webkit-line-clamp: 3; + overflow: hidden; + } + } + } + .chapterName { + margin: 15px; + display: flex; + align-items: center; + span { + margin-left: 5px; + } + } + .reMarkItem { + margin: 15px; + background: #fff; + border-radius: 10px; + padding: 10px; + display: flex; + justify-content: space-between; + .reMarkCon { + // width: 240px; + // white-space: nowrap; + // overflow: hidden; + // text-overflow: ellipsis; + // margin-right: 8px; + display: flex; + .con { + width: 200px; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + margin-right: 8px; + } + } + .deleteReMarkImg { + display: flex; + align-items: center; + } + } + } + } + .menuStateBox { + width: 25px; + height: 25px; + border-radius: 3px 0px 0px 3px; + position: absolute; + line-height: 22px; + top: 50%; + left: 380px; + text-align: center; + box-shadow: 0px 0px 6px 1px rgba(0, 0, 0, 0.3); + z-index: 2; + img { + height: 10px; + width: 18px; + } + } + + .pageBox { + flex: 1; + font-size: 16px; + position: relative; + .pageBox-header { + height: 57px; + padding: 0 20px; + background: #fff; + display: flex; + z-index: 99; + align-items: center; + justify-content: space-between; + .classTime { + display: flex; + align-items: center; + background: rgba(0, 147, 255, 0.1); + border-radius: 20px 20px 20px 20px; + color: #0093ff; + padding: 8px; + .qureIcon { + width: 9px; + height: 9px; + border-radius: 50%; + background: #0093ff; + margin: 0 5px; + } + } + .progress { + text-align: center; + .bookName { + font-weight: 800; + margin-bottom: 5px; + color: #333; + } + } + .rightBox { + display: flex; + .pageSizeBox { + display: flex; + align-items: center; + padding: 0 20px; + + div { + padding: 5px; + img { + width: 18px; + height: 18px; + } + } + } + .brushImgBox { + display: flex; + align-items: center; + border-left: 1px solid #d8d8d8; + div { + padding: 5px; + display: flex; + align-items: center; + } + .brushImg { + width: 22px; + margin-left: 20px; + margin-right: 5px; + } + } + } + } + .pageBox-content { + height: calc(100% - 57px); + background: #fbf9f4; + padding: 10px 0; + .content-box { + height: 100%; + position: relative; + #container { + background: #fbf9f4; + height: 100%; + #__qiankun_microapp_wrapper_for_app_content__ { + height: 100%; + } + } + } + .canvas-box { + height: 100%; + width: 100%; + position: absolute; + top: 0; + left: 0; + z-index: 96; + background: rgba(255, 255, 255, 0.2); + } + } + } + .toolBox { + position: relative; + box-shadow: -3px 0px 6px 1px rgba(0, 0, 0, 0.07); + background: #fff; + border-radius: 0px 16px 0px 0px; + .toolTitle { + height: 57px; + line-height: 53px; + text-align: center; + border-bottom: 1px solid #efefef; + .text { + width: 43px; + height: 3px; + margin: 0 auto; + background: #0093ff; + border-radius: 3px 3px 0px 0px; + } + } + .menu { + padding-top: 20px; + li > div { + // height: 50px; + padding: 10px 36px; + font-size: 16px; + display: flex; + align-items: center; + color: #333; + + img { + width: 29px; + height: 29px; + } + + span { + width: 80px; + margin-left: 10px; + } + } + } + .openBox { + width: 25px; + height: 25px; + background: #fff; + border-radius: 3px 0px 0px 3px; + position: absolute; + top: 50%; + right: 67px; + box-shadow: 0px 0px 6px 1px rgba(0, 0, 0, 0.3); + display: flex; + align-items: center; + justify-content: center; + + img { + height: 10px; + width: 18px; + } + } + .right { + right: 198px !important; + border-radius: 0px 3px 3px 0px !important; + } + .classRoomBox { + position: absolute; + bottom: 0; + width: 100%; + .el-tabs__nav { + width: 100% !important; + } + .el-tabs__item { + flex: 1 !important; + padding: 0 !important; + text-align: center; + } + .el-tabs__active-bar { + width: 43px !important; + left: 30px !important; + height: 3px; + bottom: 1px; + border-radius: 3px 3px 0px 0px; + } + .tabBox { + height: 100px; + padding: 10px 17px; + text-align: center; + .insertSelect { + display: flex; + justify-content: space-between; + .selectItem { + text-align: center; + background: rgba(207, 207, 207, 0.13); + padding: 10px; + border-radius: 5px; + border: 2px solid #cfcfcf; + } + .typeActive { + text-align: center; + color: #0093ff; + border: 2px solid #0093ff; + padding: 10px; + border-radius: 5px; + background: rgba(0, 147, 255, 0.13); + } + } + .giveLessons { + color: #0093ff; + width: 90px; + margin: 10px auto; + padding: 5px; + border-radius: 20px; + border: 1px solid #0093ff; + display: flex; + align-items: center; + justify-content: center; + span { + margin-left: 10px; + } + } + } + } + } + + .draggableBox { + width: 40px; + background-image: linear-gradient(to bottom, #65bbf9, #1299fb); + // background-color: rgba(44, 44, 44, 0.5); + position: absolute; + // height: 310px; + top: 70px; + left: 380px; + z-index: 2000; + border-radius: 10px; + padding: 6px; + overflow: hidden; + .floatToolItem { + margin: 10px 0; + height: 30px; + display: flex; + justify-content: center; + align-items: center; + border-radius: 5px; + color: #fff; + cursor: pointer; + .imgBox { + width: 24px; + height: 24px; + margin: 0 auto; position: relative; img { + width: 100%; + height: 100%; width: auto; height: auto; max-width: 100%; max-height: 100%; position: absolute; top: 0; + left: 0; right: 0; bottom: 0; - left: 0; margin: auto; - border-radius: 6px; } } - .name { - display: -webkit-box; - -webkit-box-orient: vertical; - -webkit-line-clamp: 2; - overflow: hidden; - margin-bottom: 8px; + .text { + margin-right: 5px; } - .time { - font-size: 12px; - color: #999; + } + .floatToolItem:hover, + .floatToolActive { + background-color: rgba(255, 255, 255, 0.3); + } + } + + .brushBox { + position: absolute; + width: 290px; + bottom: 40px; + left: 0; + right: 0; + z-index: 99; + margin: auto; + border-radius: 5px; + background: #fff; + overflow: hidden; + box-shadow: 0px 0px 6px 1px rgba(0, 0, 0, 0.3); + .toolList { + display: flex; + justify-content: center; + align-items: center; + .floatToolItem { + margin: 6px 8px; + padding: 5px; + width: 30px; + border-radius: 5px; + display: flex; + justify-content: center; + align-items: center; + // flex: 1; + font-size: 14px; + .imgBox { + height: 18px; + width: 18px; + text-align: center; + margin: 0 auto; + } + } + .floatToolItem:hover { + background-color: rgba(44, 44, 44, 0.2); + } + .layOutTool { + height: 20px; + margin-right: 5px; + border-left: 1px solid #e0e0e0; } } } + + .dialogToolBox { + position: fixed; + z-index: 2; + .toolSelectBox { + height: 40px; + display: flex; + justify-content: center; + align-items: center; + border-radius: 12px; + overflow: hidden; + padding: 5px; + background-color: rgba(90, 90, 90, 0.9); + // background-image: linear-gradient(to right, #0093ff, #005dff); + .dialogToolItem { + user-select: none; + width: 26px; + font-size: 12px; + border-radius: 5px; + padding: 3px; + margin: 0 5px; + cursor: pointer; + text-align: center; + span { + color: #fff; + } + } + .dialogToolItem:hover, + .active { + background-color: rgba(255, 255, 255, 0.2); + // span { + // color: #0093ff; + // } + } + } + } + .colorSelectBox { + padding: 5px 10px; + width: 190px; + display: flex; + background: #ffffff; + box-shadow: 0px 0px 10px 1px rgba(0, 0, 0, 0.16); + border-radius: 5px; + margin-bottom: 10px; + .flex1 { + flex: 1; + .scribeItem { + width: 18px; + height: 18px; + border-radius: 3px; + margin: 10px auto; + border: none; + display: flex; + justify-content: center; + align-items: center; + } + } + } + } +} +.lineDeleteBox { + position: fixed; + z-index: 2; + box-shadow: 0px 0px 6px 1px rgba(0, 0, 0, 0.3); + padding: 5px 10px; + background: #fff; + border-radius: 5px; + display: flex; + .dialogToolItem { + padding: 3px; + margin: 0 10px; + border-radius: 5px; + display: flex; + justify-content: center; + align-items: center; + } + .dialogToolItem:hover { + background-color: rgba(44, 44, 44, 0.2); + } +} +.noteContentBox { + max-width: 240px; + position: fixed; + z-index: 2; + padding: 10px; + border-radius: 5px; +} +.dictionaryDataBox { + position: fixed; + z-index: 2; + box-shadow: 0px 0px 6px 1px rgba(0, 0, 0, 0.3); + padding: 5px 20px; + background: #fff; + border-radius: 5px; + .word { + font-weight: bold; + } + .phone_con { + .per-phone { + min-width: 150px; + align-items: center; + // justify-content: space-between; + background: #f4f5f7; + border-radius: 15px; + box-sizing: border-box; + color: #666; + display: flex; + font-weight: 500; + margin-right: 10px; + margin-top: 10px; + padding: 8px 10px; + span { + margin: 0 10px; + flex: 1; + } + } + .soundBtn { + width: 16px; + height: 14px; + } + } + .trans { + padding: 20px 0; + .itemList { + display: flex; + padding: 10px 0; + .index { + margin-right: 15px; + } + .pos { + margin-right: 30px; + } + } + } +} +.wendabox { + width: 100%; + height: 700px; + iframe { + width: 100%; + height: 100%; + } +} + +.myDialogs, +.myNoteDialogs, +.resourDialog, +.baiduDialog, +.myAnserDialogs { + padding: 0 !important; + border-radius: 10px !important; + overflow: hidden; + + .el-dialog__header { + padding: 10px; + text-align: center; + background: #f4f5f9; + } + + .el-dialog__title { + font-weight: bold; + font-size: 16px; + } + + .el-dialog__headerbtn { + top: 0px !important; + right: 0px !important; + } + .el-dialog__body { + padding: 20px !important; + } + .el-dialog__footer { + padding: 10px 20px 20px !important; + text-align: right; + box-sizing: border-box; + } +} +.myAnserDialogs { + width: 628px; +} +.myNoteDialogs { + width: 500px !important; +} +.screenshotDialog { + width: 400px !important; +} +.baiduDialog { + width: 90vw; + height: 90vh; +} +.noteColorSelectBox { + margin-top: 10px; + width: 190px; + display: flex; + .flex1 { + flex: 1; + .scribeItem { + width: 18px; + height: 18px; + border-radius: 3px; + margin: 10px auto; + border: none; + display: flex; + justify-content: center; + align-items: center; + } + } +} +.videoBox { + text-align: center; + video { + width: 100%; + } + audio { + width: 100%; + } +} + +.wordBox { + height: 600px; +} +.imgUrlBox { + width: 100%; + text-align: center; + img { + width: 100%; } } </style> -- Gitblit v1.9.1