| | |
| | | </div> |
| | | </div> |
| | | <div |
| | | class="noteText hover" |
| | | class="noteText hover 123456" |
| | | @click="jumpContent('note' + index)" |
| | | :style="{ |
| | | background: |
| | |
| | | : item.color |
| | | }" |
| | | > |
| | | <div class="con">{{ item.note }}</div> |
| | | <div class="con hover" @click="jumpContent('note' + index)"> |
| | | {{ item.note }} |
| | | </div> |
| | | </div> |
| | | <div class="chapter">{{ item.selectText }}</div> |
| | | </div> |
| | |
| | | <el-col :span="12" v-for="(item, index) in resourceDataList" :key="item"> |
| | | <div class="resourceItem hover" @click="goResourceDetail(item)"> |
| | | <div class="resourceImg"> |
| | | <img :src="video" mode="" /> |
| | | <img :src="item.icon" mode="" v-if="item.icon" /> |
| | | <el-icon v-else-if="activeClassify == 'image'" size="30"><Picture /></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' && item.fileType == 'PDF'" |
| | | size="30" |
| | | ><Files |
| | | /></el-icon> |
| | | <el-icon |
| | | v-else-if="activeClassify == 'other' && item.fileType == ''" |
| | | size="30" |
| | | ><Tickets |
| | | /></el-icon> |
| | | </div> |
| | | <div class="rName" v-if="searchText != ''" v-html="item.name"></div> |
| | | <div class="rName" v-else>{{ item.name }}</div> |
| | | <div class="rName" v-else :title="item.resourceName"> |
| | | {{ item.resourceName }} |
| | | </div> |
| | | </div> |
| | | </el-col> |
| | | </el-row> |
| | |
| | | <div class="" v-if="activeMenu == 4"> |
| | | <div class="list-box"> |
| | | <div class="screenshot" v-if="screenshotList.length > 0"> |
| | | <div |
| | | v-for="(item, index) in screenshotList" |
| | | :key="item" |
| | | class="captureItem" |
| | | @click="getCapture(item)" |
| | | > |
| | | <div v-for="(item, index) in screenshotList" :key="item" class="captureItem"> |
| | | <div class="imgBox"> |
| | | <img :src="item.imgUrl" class="capture" mode="aspectFill" /> |
| | | <img |
| | | :src="item.imgUrl" |
| | | class="capture" |
| | | mode="aspectFill" |
| | | @click="getCapture(item)" |
| | | /> |
| | | <div class="deleteBox hover" @click="deleteScreenshot(item, 'capture')"> |
| | | <img :src="shanchu" /> |
| | | </div> |
| | | </div> |
| | | <div class="captureName">{{ item.name }}</div> |
| | | <div class="captureName" :title="item.name">{{ item.name }}</div> |
| | | </div> |
| | | </div> |
| | | <div v-else> |
| | |
| | | <div class="">已上课:{{ headerData.classTime }}</div> |
| | | </div> |
| | | <div class="progress"> |
| | | <div class="bookName">{{bookName}}</div> |
| | | <div class="bookName">{{ bookName }}</div> |
| | | <div>{{ headerData.process }}%</div> |
| | | </div> |
| | | <div class="rightBox"> |
| | |
| | | <div><img :src="zoomOut" @click="changePageSize('reduce')" /></div> |
| | | </div> |
| | | <div class="brushImgBox"> |
| | | <div><img :src="huabi2" class="brushImg" />画笔</div> |
| | | <div @click="jumpContent('note' + index)"> |
| | | <img :src="huabi2" class="brushImg" />画笔 |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <!-- 微应用盒子 --> |
| | | <div class="pageBox-content" @scroll="pageScroll"> |
| | | <div class="content-box"> |
| | | <div id="container" @mousedown="handleMouseDown" @mousemove="handleMousemove" ></div> |
| | | <div |
| | | id="container" |
| | | @mousedown="handleMouseDown" |
| | | @mousemove="handleMousemove" |
| | | :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="lineDeleteBox" |
| | | v-show="lineDelete.showLineDelete" |
| | | :style="{ top: `${lineDelete.top}px`, left: `${lineDelete.left}px` }" |
| | | > |
| | | <el-button @click="lineDeleteBtn">删除</el-button> |
| | | </div> |
| | | |
| | | <el-dialog title="资源" align-center v-model="resourVisble" width="845" class="resourDialog"> |
| | | <div class="videoBox" v-if="resourType == 'video'"> |
| | | <video controls object-fit="fill" :src="testVideo"></video> |
| | | <div class="videoBox" v-if="resourType == '视频'"> |
| | | <video controls controlslist="nodownload" :src="testVideo"></video> |
| | | </div> |
| | | <div class="wordBox" v-if="resourType == 'word'"> |
| | | <vue-office-docx :src="testWord" /> |
| | |
| | | v-model="screenshotVisble" |
| | | :before-close="screenshotClose" |
| | | width="400" |
| | | class="resourDialog" |
| | | class="resourDialog screenshotDialog" |
| | | > |
| | | <div class="formBox"> |
| | | <el-input v-model="nameData" placeholder="请输入截图名称"></el-input> |
| | |
| | | </template> |
| | | |
| | | <script setup lang="ts"> |
| | | import { ref, reactive, watch, onMounted, onBeforeMount,inject } from 'vue' |
| | | import { ctxUrl,resourceUrl } from '@/assets/js/config' |
| | | import { ref, reactive, watch, onMounted, onBeforeMount, inject } from 'vue' |
| | | import { ctxUrl, resourceUrl, requestCtx } from '@/assets/js/config' |
| | | import { useRouter, useRoute } from 'vue-router' |
| | | import useClipboard from 'vue-clipboard3' |
| | | const { toClipboard } = useClipboard() |
| | | const request = inject('request') |
| | | 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 } from 'element-plus' |
| | | 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' |
| | |
| | | let microApp = null // 微应用实例 |
| | | const bookName = ref('') |
| | | const bookId = ref(1) |
| | | const activeCatalog = ref() |
| | | onMounted(() => { |
| | | // canvasWith.value = window.innerWidth - 540 |
| | | // canvasheight.value = window.innerHeight - 110 |
| | | getCatalogueData() |
| | | getResourceData() |
| | | // setTimeout(() => { |
| | | // canvasWith.value = document.getElementById('container').offsetWidth |
| | | // canvasheight.value = document.getElementById('container').offsetHeight |
| | | // }, 5000) |
| | | 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 |
| | |
| | | // 加载微应用 |
| | | microApp = loadMicroApp(microApps.book1, { |
| | | sandbox: { |
| | | // strictStyleIsolation: true, |
| | | strictStyleIsolation: true |
| | | // experimentalStyleIsolation: true |
| | | } |
| | | }, |
| | | singular: true |
| | | }) |
| | | window.qiankunActions.onGlobalStateChange((state, prev) => { |
| | | console.log('父层state变化', state) |
| | | bookName.value = state.bookName |
| | | bookId.value = state.bookId |
| | | |
| | | window.qiankunState = state |
| | | }) |
| | | |
| | | |
| | | // 定义父层方法 |
| | | console.log(window.qiankunActions) |
| | | window.qiankunActions.setGlobalState({ |
| | | state: 1, // 加载子应用 |
| | | windowSelection: (data) => { |
| | | // 绑定子应用选择监听事件 |
| | | console.log(data, '子应用选择') |
| | | getSelection(data) |
| | | }, |
| | | catalogChange: (data) => { |
| | | activeCatalog.value = data.showCatalogList |
| | | getSignData() |
| | | console.log(data, '章节切换:目前显示的三个章节') |
| | | }, |
| | | pageChange: (data) => { |
| | | // { |
| | | // page: 100, |
| | | // catalog: 5, |
| | | // catalogId: "", |
| | | // catalogName: "", |
| | | // } |
| | | console.log(data, '页面切换:目前显示页面和对应的章节信息') |
| | | } |
| | | }) |
| | | |
| | | |
| | | // 调用子层方法 |
| | | // if (window.qiankunState && window.qiankunState.aa) window.qiankunState.aa(1) |
| | | }) |
| | | |
| | | watch( |
| | |
| | | watch( |
| | | () => bookId.value, |
| | | (val) => { |
| | | getNotesList() // 获取笔记 |
| | | getlineHeightList() //获取高亮 |
| | | getScribeList() //获取划线 |
| | | getScreenshotList() //截图 |
| | | // getNotesList() // 获取笔记 |
| | | // getlineHeightList() //获取高亮 |
| | | // getScribeList() //获取划线 |
| | | // getScreenshotList() //截图 |
| | | } |
| | | ) |
| | | //获取目录 |
| | | const catalogueData = ref([]) |
| | | const getCatalogueData = () => { |
| | | axios |
| | | .get(ctxUrl + '/information.json') |
| | | .get(ctxUrl + '/catalog.json') |
| | | .then(function (response) { |
| | | var json = response.data |
| | | // 处理获取到的json数据 |
| | |
| | | const searchShow = ref(true) |
| | | const resourceData = ref({}) |
| | | const resourceDataList = ref([]) |
| | | const resourceImgList = ref([]) |
| | | const resourceVideoList = ref([]) |
| | | const resourceAudioList = ref([]) |
| | | const resourceDocList = ref([]) |
| | | const resourVisble = ref(false) |
| | | const resourType = ref('') |
| | | const testVideo = ref('') //视频链接 |
| | |
| | | .then(function (response) { |
| | | var json = response.data |
| | | // 处理获取到的json数据 |
| | | console.log(json, '资源') |
| | | resourceData.value = json |
| | | resourceDataList.value = json.imgList |
| | | classifySelectList[0].count = json.imgList.length |
| | | classifySelectList[1].count = json.audioList.length |
| | | classifySelectList[2].count = json.videoList.length |
| | | classifySelectList[3].count = json.attachmentList.length |
| | | if (json.length > 0) { |
| | | json.forEach((item) => { |
| | | if (item.fileType == '图片') { |
| | | resourceImgList.value.push(item) |
| | | } else if (item.fileType == '视频') { |
| | | resourceVideoList.value.push(item) |
| | | } else if (item.fileType == '音频') { |
| | | resourceAudioList.value.push(item) |
| | | } else { |
| | | resourceDocList.value.push(item) |
| | | } |
| | | }) |
| | | } |
| | | resourceDataList.value = resourceImgList.value |
| | | classifySelectList[0].count = resourceImgList.value.length |
| | | classifySelectList[1].count = resourceAudioList.value.length |
| | | classifySelectList[2].count = resourceVideoList.value.length |
| | | classifySelectList[3].count = resourceDocList.value.length |
| | | }) |
| | | .catch(function (error) { |
| | | console.log(error) |
| | |
| | | } |
| | | |
| | | const goResourceDetail = (data) => { |
| | | resourVisble.value = true |
| | | resourType.value = data.type |
| | | if (data.type == 'video') { |
| | | testVideo.value = resourceUrl + '/resourceData/' + data.name |
| | | } else if (data.type == 'word') { |
| | | testWord.value = resourceUrl + '/resourceData/' + data.name |
| | | resourType.value = data.fileType |
| | | if (data.fileType == '视频') { |
| | | resourVisble.value = true |
| | | testVideo.value = requestCtx + '/file/api/ApiDownload?md5=' + data.md5 |
| | | } else if (data.fileType == 'PDF') { |
| | | window.open(requestCtx + '/file/api/ApiDownload?md5=' + data.md5) |
| | | // testWord.value = resourceUrl + '/resourceData/' + data.name |
| | | } |
| | | } |
| | | |
| | |
| | | searchText.value = '' |
| | | switch (item.key) { |
| | | case 'image': |
| | | resourceDataList.value = resourceData.value.imgList |
| | | resourceDataList.value = resourceImgList.value |
| | | break |
| | | case 'audio': |
| | | resourceDataList.value = resourceData.value.audioList |
| | | resourceDataList.value = resourceAudioList.value |
| | | break |
| | | case 'video': |
| | | resourceDataList.value = resourceData.value.videoList |
| | | resourceDataList.value = resourceVideoList.value |
| | | break |
| | | case 'other': |
| | | resourceDataList.value = resourceData.value.attachmentList |
| | | resourceDataList.value = resourceDocList.value |
| | | break |
| | | } |
| | | } |
| | |
| | | |
| | | { |
| | | lable: '大', |
| | | key: '20' |
| | | key: '18' |
| | | } |
| | | ], |
| | | fontSizeActive: '16', |
| | |
| | | }) |
| | | const fontSizeSelect = (item) => { |
| | | settingForm.fontSizeActive = item.key |
| | | window.qiankunActions.setGlobalState({ |
| | | fontSizeNum: settingForm.fontSizeActive, // 加载子应用 |
| | | }) |
| | | document.getElementById('app').style.fontSize = item.key + 'px' |
| | | } |
| | | const bgColorSelect = (item) => { |
| | | settingForm.bgColorActive = item.key |
| | | window.qiankunActions.setGlobalState({ |
| | | bgColor: settingForm.bgColorActive, // 加载子应用 |
| | | }) |
| | | } |
| | | //笔记颜色筛选 |
| | | const searchClick = (item) => { |
| | |
| | | name: '截屏' |
| | | } |
| | | ]) |
| | | const canvas = ref(null) |
| | | let canvas = null |
| | | const floatingToolData = reactive({ |
| | | activeToolData: '', //选中工具 |
| | | elLeft: 400, |
| | |
| | | switch (item.name) { |
| | | case '画笔': |
| | | canvasShow.value = true |
| | | toolSelectData.activeTool = 'huabi' |
| | | break |
| | | case '标签': |
| | | break |
| | | case '截屏': |
| | | jitT() |
| | |
| | | case 'wenzi': |
| | | break |
| | | case 'tuichu': |
| | | canvasShow.value = false |
| | | floatingToolData.activeToolData = '' |
| | | canvasShow.value = false |
| | | floatingToolData.activeToolData = '' |
| | | break |
| | | case 'qingchu': |
| | | canvas.clear() |
| | | break |
| | | } |
| | | } |
| | |
| | | //选中画笔粗细 |
| | | const selectThickness = (str) => { |
| | | toolSelectData.thicknessActive = str |
| | | init() |
| | | canvas.freeDrawingBrush.color = toolSelectData.thicknessActive |
| | | } |
| | | |
| | | const selectLineType = (str) => { |
| | |
| | | //画笔颜色选择 |
| | | const lineColorSelect = (item) => { |
| | | toolSelectData.lineColorActive = item.key |
| | | init() |
| | | canvas.freeDrawingBrush.color = item.key |
| | | } |
| | | //画布属性 |
| | | const isDrawing = ref(true) // 是否开启绘图,true 开启;false 关闭 |
| | | const init = () => { |
| | | canvas.value = new fabric.Canvas('canvasRef', { |
| | | isDrawingMode: true // 启用绘画模式 |
| | | canvas = new fabric.Canvas('canvasRef', { |
| | | isDrawingMode: isDrawing.value // 启用绘画模式 |
| | | }) |
| | | canvas.value.freeDrawingBrush.color = toolSelectData.lineColorActive |
| | | canvas.value.freeDrawingBrush.width = toolSelectData.thicknessActive |
| | | canvas.freeDrawingBrush.color = toolSelectData.lineColorActive |
| | | canvas.freeDrawingBrush.width = toolSelectData.thicknessActive |
| | | } |
| | | |
| | | //标签显示隐藏 |
| | | const labelShow = (str) => {} |
| | | |
| | | //文字大小 |
| | | const selectfontSize = (str) => { |
| | | toolSelectData.fontSizeActive = str |
| | | } |
| | | |
| | | //标签显示隐藏 |
| | | const labelShow = (str) => {} |
| | | |
| | | //截图 |
| | | //截图事件 |
| | |
| | | //取消回调 |
| | | const closeFn = (base64: any) => { |
| | | console.log(base64) |
| | | floatingToolData.activeToolData = '' |
| | | } |
| | | const addScreenshot = () => { |
| | | if (nameData.value) { |
| | |
| | | } |
| | | }).then((res) => { |
| | | getScreenshotList() |
| | | nameData.value = '' |
| | | urlData.value = '' |
| | | floatingToolData.activeToolData = '' |
| | | screenshotVisble.value = false |
| | | }) |
| | | } else { |
| | |
| | | |
| | | //选中文字工具栏 |
| | | const selectText = ref('') //选中文字 |
| | | const selectNode = ref(null) |
| | | const selectPage = ref(1) |
| | | const showToolBox = ref(false) |
| | | const dialogToolData = reactive({ |
| | | left: 500, |
| | | top: 300, |
| | | txt: '', |
| | | page: '', |
| | | chapter: '', //选中文字所在章节 |
| | | parentNode: null, |
| | | lineHeight: [], //高亮 |
| | | scribeList: [], //划线 |
| | | notesList: [] //笔记 |
| | | }) |
| | | |
| | | ///内容选中 |
| | | const isMouseDown = ref(false) |
| | | const move = ref(false) |
| | | const handleMouseDown = () => { |
| | | isMouseDown.value = true |
| | | showToolBox.value = false |
| | | colorActive.value = '' |
| | | toolActive.value = '' |
| | | } |
| | | const handleMousemove = () => { |
| | | if (isMouseDown.value) { |
| | | move.value = true |
| | | } |
| | | } |
| | | |
| | | const handleMouseUp = (e) => { |
| | | if (move.value) { |
| | | const txt = window.getSelection()?.toString() |
| | | selectText.value = txt |
| | | const node = window.getSelection() |
| | | let html = node.anchorNode.parentNode.parentNode |
| | | dialogToolData.chapter = html.firstChild.innerHTML |
| | | if (txt) { |
| | | showToolBox.value = true |
| | | dialogToolData.top = e.y |
| | | dialogToolData.left = e.x |
| | | } |
| | | isMouseDown.value = false |
| | | } |
| | | move.value = false |
| | | } |
| | | |
| | | const getSelection =(data)=>{ |
| | | const getSelection = (data) => { |
| | | if (data.txt) { |
| | | console.log(data.node,"data") |
| | | showToolBox.value = true |
| | | selectText.value = data.txt |
| | | selectNode.value = data.node.innerHTML |
| | | selectPage.value = data.page |
| | | dialogToolData.top = data.y |
| | | dialogToolData.left = data.x |
| | | } |
| | | dialogToolData.txt = data.txt |
| | | dialogToolData.page = data.page |
| | | dialogToolData.chapter = data.chapterNum |
| | | dialogToolData.left = data.x |
| | | dialogToolData.top = data.y |
| | | showToolBox.value = true |
| | | } |
| | | } |
| | | |
| | | const pageScroll = (e) => { |
| | | // window.qiankunActions.setGlobalState({ |
| | | // gotoPage: (t, s) => { |
| | | // // 绑定子应用选择监听事件 |
| | | // console.log(t, s, '子应用滚动') |
| | | // } |
| | | // }) |
| | | showToolBox.value = false |
| | | let scroll = e.target.scrollTop |
| | | let offsetHeight = document.getElementById('container').offsetHeight |
| | | headerData.process = Math.round((scroll / offsetHeight) * 100) |
| | | lineDelete.showLineDelete = false |
| | | // let scroll = e.target.scrollTop |
| | | // let offsetHeight = document.getElementById('container').offsetHeight |
| | | // headerData.process = Math.round((scroll / offsetHeight) * 100) |
| | | } |
| | | |
| | | const toolActive = ref('') |
| | |
| | | |
| | | const clickSelect = (item) => { |
| | | colorActive.value = item.key |
| | | if (toolActive.value == '高亮') { |
| | | let lineHeightData = { |
| | | selectNode: selectNode.value, |
| | | selectText: selectText.value, |
| | | selectPage: selectPage.value, |
| | | color: colorActive.value, |
| | | chapter: dialogToolData.chapter, |
| | | createDate: new Date() |
| | | } |
| | | dialogToolData.lineHeight.push(lineHeightData) |
| | | console.log(dialogToolData.lineHeight,"前node") |
| | | request({ |
| | | url: '/identity/api/ApiAppUserSetKey', |
| | | method: 'post', |
| | | data: { |
| | | setKeyRequests: [ |
| | | { |
| | | domain: 'highLight', |
| | | key: bookId.value, |
| | | value: JSON.stringify(dialogToolData.lineHeight) |
| | | } |
| | | ] |
| | | } |
| | | }).then((res) => { |
| | | showToolBox.value = false |
| | | colorActive.value = '' |
| | | toolActive.value = '' |
| | | getlineHeightList() |
| | | }) |
| | | } |
| | | if (toolActive.value == '划线') { |
| | | dialogToolData.scribeList.push({ |
| | | selectNode: selectNode.value, |
| | | selectText: selectText.value, |
| | | selectPage: selectPage.value, |
| | | color: colorActive.value, |
| | | chapter: dialogToolData.chapter, |
| | | createDate: new Date() |
| | | }) |
| | | request({ |
| | | url: '/identity/api/ApiAppUserSetKey', |
| | | method: 'post', |
| | | data: { |
| | | setKeyRequests: [ |
| | | { |
| | | domain: 'underline', |
| | | key: bookId.value, |
| | | value: JSON.stringify(dialogToolData.scribeList) |
| | | } |
| | | ] |
| | | } |
| | | }).then((res) => { |
| | | colorActive.value = '' |
| | | showToolBox.value = false |
| | | toolActive.value = '' |
| | | getScribeList() |
| | | }) |
| | | } |
| | | addUserKey() |
| | | } |
| | | |
| | | const addUserKey = () => { |
| | | let dom = '' |
| | | let data = null |
| | | switch (toolActive.value) { |
| | | case '高亮': |
| | | dom = 'highLightData-' + bookId.value |
| | | data = dialogToolData.lineHeight[dialogToolData.chapter] |
| | | data.push({ |
| | | id: toolClass.uuid(8), |
| | | txt: dialogToolData.txt, |
| | | page: dialogToolData.page, |
| | | type: 'Highlight', |
| | | color: colorActive.value |
| | | }) |
| | | break |
| | | case '划线': |
| | | dom = 'underline-' + bookId.value |
| | | data = dialogToolData.scribeList[dialogToolData.chapter] |
| | | data.push({ |
| | | id: toolClass.uuid(8), |
| | | txt: dialogToolData.txt, |
| | | page: dialogToolData.page, |
| | | type: 'Dashing', |
| | | color: colorActive.value |
| | | }) |
| | | break |
| | | } |
| | | request({ |
| | | url: '/identity/api/ApiAppUserSetKey', |
| | | method: 'post', |
| | | data: { |
| | | setKeyRequests: [ |
| | | { |
| | | domain: dom, |
| | | key: dialogToolData.chapter, |
| | | value: JSON.stringify(data) |
| | | } |
| | | ] |
| | | } |
| | | }).then((res) => { |
| | | showToolBox.value = false |
| | | colorActive.value = '' |
| | | toolActive.value = '' |
| | | getSignData() |
| | | }) |
| | | } |
| | | |
| | | const delUserKey = (type, ids) => { |
| | | switch (type) { |
| | | case 'Highlight': |
| | | dom = 'highLightData-' + bookId.value |
| | | data = dialogToolData.lineHeight |
| | | break |
| | | case 'Dashing': |
| | | dom = 'underline-' + bookId.value |
| | | data = dialogToolData.scribeList |
| | | break |
| | | } |
| | | data = data.filter((item) => ids.indexOf(item.id) == -1) |
| | | request({ |
| | | url: '/identity/api/ApiAppUserSetKey', |
| | | method: 'post', |
| | | data: { |
| | | setKeyRequests: [ |
| | | { |
| | | domain: dom, |
| | | key: '', |
| | | value: JSON.stringify(data) |
| | | } |
| | | ] |
| | | } |
| | | }).then((res) => {}) |
| | | } |
| | | const lock = ref(false) |
| | | |
| | | const getSignData = () => { |
| | | request({ |
| | | url: '/identity/api/ApiGetAppUserKey', |
| | | method: 'post', |
| | | data: { |
| | | domain: 'highLightData-' + bookId.value, |
| | | 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) |
| | | } |
| | | } |
| | | } |
| | | }) |
| | | request({ |
| | | url: '/identity/api/ApiGetAppUserKey', |
| | | method: 'post', |
| | | data: { |
| | | domain: 'underline-' + bookId.value, |
| | | 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 |
| | | // 渲染 |
| | | 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 addNote = () => { |
| | | const obj = { |
| | | desc: formData.desc |
| | | } |
| | | if(!colorActive.value){ |
| | | if (!colorActive.value) { |
| | | ElMessage.error('请选择笔记颜色!') |
| | | return |
| | | } |
| | |
| | | let nHtml1 = '' |
| | | nHtml1 = nHtmlText1.replace( |
| | | rReg1, |
| | | `<span style="padding-bottom:2px; border-bottom: 2px solid;border-bottom-color:${item.color}" class="underline">${item.selectText}</span><img src="${biji1}" style="cursor: pointer" onclick="notesVisbleShow('${item.selectText}')"/>` |
| | | `<span style="padding-bottom:2px; border-bottom: 2px solid;border-bottom-color:${item.color}" class="notesline">${item.selectText}</span><img src="${biji1}" style="cursor: pointer" onclick="notesVisbleShow('${item.selectText}')"/>` |
| | | ) |
| | | let rHtml1 = '' |
| | | rHtml1 = text1.replace( |
| | | nHtmlText1, |
| | | nHtml1 |
| | | ) |
| | | rHtml1 = text1.replace(nHtmlText1, nHtml1) |
| | | textDom1.innerHTML = rHtml1 |
| | | }) |
| | | } |
| | |
| | | let rReg1 = new RegExp(`${item.selectText}`, 'ig') |
| | | let text1 = textDom1.innerHTML |
| | | let nHtmlText1 = item.selectNode |
| | | |
| | | |
| | | let nHtml1 = '' |
| | | nHtml1 = nHtmlText1.replace( |
| | | rReg1, |
| | | `<span style="text-decoration:underline;text-decoration-style: wavy;text-underline-thickness:2px;text-decoration-color:${item.color};cursor: pointer">${item.selectText}</span>` |
| | | `<span style="text-decoration:underline;text-decoration-style: wavy;text-underline-thickness:2px;text-decoration-color:${item.color};cursor: pointer" class="underline" onclick="deleteScribeShow('${item.selectText}')">${item.selectText}</span>` |
| | | ) |
| | | let rHtml1 = '' |
| | | rHtml1 = text1.replace( |
| | | nHtmlText1, |
| | | nHtml1 |
| | | ) |
| | | rHtml1 = text1.replace(nHtmlText1, nHtml1) |
| | | textDom1.innerHTML = rHtml1 |
| | | } |
| | | } |
| | |
| | | if (res && res.length > 0 && res[0].value) { |
| | | dialogToolData.lineHeight = JSON.parse(res[0].value) |
| | | scribeData.lineHeightList = JSON.parse(res[0].value) |
| | | console.log(scribeData.lineHeightList, '高亮') |
| | | let textDom = document.querySelector('.temp-book') |
| | | console.log(textDom) |
| | | if (scribeData.lineHeightList.length > 0) { |
| | | for (let i = 0; i < scribeData.lineHeightList.length; i++) { |
| | | let item = scribeData.lineHeightList[i] |
| | |
| | | let nHtml = '' |
| | | nHtml = nHtmlText.replace( |
| | | rReg, |
| | | `<span style="background: ${item.color};padding: 2px;cursor: pointer">${item.selectText}</span>` |
| | | `<span style="background: ${item.color};padding:3px;cursor: pointer" class="highLight" onclick="deletelineHeightShow('${item.selectText}')">${item.selectText}</span>` |
| | | ) |
| | | // nHtmlText = nHtml |
| | | let rHtml = '' |
| | | rHtml = text.replace( |
| | | nHtmlText, |
| | | nHtml |
| | | ) |
| | | rHtml = text.replace(nHtmlText, nHtml) |
| | | textDom.innerHTML = rHtml |
| | | } |
| | | } |
| | |
| | | } |
| | | |
| | | //正文中删除高亮,划线,笔记操作框 |
| | | const lineDelete = reactive({ |
| | | showLineDelete: false, |
| | | top: 0, |
| | | left: 0, |
| | | deleteType: '', |
| | | deleteTxt: '' |
| | | }) |
| | | |
| | | window.notesVisbleShow = function (txt) { |
| | | addNoteVisble.value = true |
| | | let notes = dialogToolData.notesList.find((item) => item.selectText == txt) |
| | |
| | | } |
| | | |
| | | window.deleteScribeShow = function (txt) { |
| | | console.log(txt, 2) |
| | | let list = scribeData.scribeDataList.filter((item) => item.selectText != txt) |
| | | request({ |
| | | url: '/identity/api/ApiAppUserSetKey', |
| | | method: 'post', |
| | | data: { |
| | | setKeyRequests: [ |
| | | { |
| | | domain: 'underline', |
| | | key: bookId.value, |
| | | value: JSON.stringify(list) |
| | | } |
| | | ] |
| | | } |
| | | }).then((res) => { |
| | | getScribeList() |
| | | }) |
| | | let lines = scribeData.scribeDataList.find((item) => item.selectText == txt) |
| | | lineDelete.deleteType = 'underline' |
| | | lineDelete.deleteTxt = txt |
| | | lineDelete.top = event.screenY |
| | | lineDelete.left = event.screenX |
| | | lineDelete.showLineDelete = true |
| | | } |
| | | |
| | | window.deletelineHeightShow = function (txt) { |
| | | console.log(txt, 1) |
| | | let list = scribeData.lineHeightList.filter((item) => item.selectText != txt) |
| | | request({ |
| | | url: '/identity/api/ApiAppUserSetKey', |
| | | method: 'post', |
| | | data: { |
| | | setKeyRequests: [ |
| | | { |
| | | domain: 'highLight', |
| | | key: bookId.value, |
| | | value: JSON.stringify(list) |
| | | let lines = scribeData.lineHeightList.find((item) => item.selectText == txt) |
| | | lineDelete.deleteType = 'highLight' |
| | | lineDelete.deleteTxt = txt |
| | | lineDelete.top = event.screenY |
| | | lineDelete.left = event.screenX |
| | | lineDelete.showLineDelete = true |
| | | } |
| | | |
| | | const lineDeleteBtn = () => { |
| | | if (lineDelete.deleteType == 'underline') { |
| | | let list = scribeData.scribeDataList.filter((item) => item.selectText != lineDelete.deleteTxt) |
| | | request({ |
| | | url: '/identity/api/ApiAppUserSetKey', |
| | | method: 'post', |
| | | data: { |
| | | setKeyRequests: [ |
| | | { |
| | | domain: 'underline', |
| | | key: bookId.value, |
| | | value: JSON.stringify(list) |
| | | } |
| | | ] |
| | | } |
| | | }).then((res) => { |
| | | lineDelete.showLineDelete = false |
| | | let list = document.querySelectorAll('.underline') |
| | | list.forEach((itemNode) => { |
| | | if (itemNode.innerText == lineDelete.deleteTxt) { |
| | | itemNode.removeAttribute('style') |
| | | itemNode.className = '' |
| | | itemNode.removeAttribute('onclick') |
| | | } |
| | | ] |
| | | } |
| | | }).then((res) => { |
| | | getlineHeightList() |
| | | }) |
| | | }) |
| | | getScribeList() |
| | | }) |
| | | } else if (lineDelete.deleteType == 'highLight') { |
| | | let list = scribeData.lineHeightList.filter((item) => item.selectText != lineDelete.deleteTxt) |
| | | request({ |
| | | url: '/identity/api/ApiAppUserSetKey', |
| | | method: 'post', |
| | | data: { |
| | | setKeyRequests: [ |
| | | { |
| | | domain: 'highLight', |
| | | key: bookId.value, |
| | | value: JSON.stringify(list) |
| | | } |
| | | ] |
| | | } |
| | | }).then((res) => { |
| | | lineDelete.showLineDelete = false |
| | | let list = document.querySelectorAll('.highLight') |
| | | list.forEach((itemNode) => { |
| | | if (itemNode.innerText == lineDelete.deleteTxt) { |
| | | itemNode.removeAttribute('style') |
| | | itemNode.className = '' |
| | | itemNode.removeAttribute('onclick') |
| | | } |
| | | }) |
| | | getlineHeightList() |
| | | }) |
| | | } |
| | | } |
| | | |
| | | const jumpContent = (id) => { |
| | | document.getElementById(id).scrollIntoView() |
| | | if (window.qiankunState && window.qiankunState.gotoPage) window.qiankunState.gotoPage(5, 100) |
| | | } |
| | | |
| | | const update = (item, type) => { |
| | |
| | | message: '删除笔记成功!', |
| | | type: 'success' |
| | | }) |
| | | console.log(document.querySelectorAll('.underline')) |
| | | let list = document.querySelectorAll('.underline') |
| | | list.forEach(itemNode =>{ |
| | | console.log(itemNode.nextSibling) |
| | | if(itemNode.innerText == item.selectText){ |
| | | itemNode.removeAttribute('style'); |
| | | console.log(document.querySelectorAll('.notesline')) |
| | | let list = document.querySelectorAll('.notesline') |
| | | list.forEach((itemNode) => { |
| | | if (itemNode.innerText == item.selectText) { |
| | | console.log(itemNode.nextSibling) |
| | | itemNode.removeAttribute('style') |
| | | itemNode.nextSibling?.remove() |
| | | } |
| | | }) |
| | |
| | | } |
| | | } |
| | | |
| | | //删除截图 |
| | | const deleteScreenshot = (item) => { |
| | | let list = screenshotList.value.filter((itemData) => itemData.imgUrl !== item.imgUrl) |
| | | request({ |
| | | url: '/identity/api/ApiAppUserSetKey', |
| | | method: 'post', |
| | | data: { |
| | | setKeyRequests: [ |
| | | { |
| | | domain: 'screenshot', |
| | | key: bookId.value, |
| | | value: JSON.stringify(list) |
| | | } |
| | | ] |
| | | } |
| | | }).then((res) => { |
| | | ElMessage({ |
| | | message: '删除截图成功!', |
| | | type: 'success' |
| | | }) |
| | | getScreenshotList() |
| | | }) |
| | | } |
| | | //内容区域顶部显示 |
| | | |
| | | const headerData = reactive({ |
| | |
| | | padding: 10px 0; |
| | | align-items: center; |
| | | .resourceImg { |
| | | width: 130px; |
| | | // width: 130px; |
| | | height: 80px; |
| | | background: #fff; |
| | | border-radius: 5px; |
| | | overflow: hidden; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: center; |
| | | img { |
| | | height: 100%; |
| | | width: 100%; |
| | |
| | | .captureItem { |
| | | margin-bottom: 10px; |
| | | width: 46%; |
| | | position: relative; |
| | | .imgBox { |
| | | border: 1px solid #d8d8d8; |
| | | width: 100%; |
| | | height: 80px; |
| | | margin-bottom: 5px; |
| | | } |
| | | .deleteBox { |
| | | position: absolute; |
| | | top: 2px; |
| | | right: 2px; |
| | | width: 20px; |
| | | height: 20px; |
| | | background: rgba(44, 44, 44, 0.3); |
| | | text-align: center; |
| | | padding: 2px; |
| | | } |
| | | // .capture { |
| | | // width: 100%; |
| | |
| | | margin: 10px 10px 10px 15px; |
| | | border-radius: 3px; |
| | | padding: 2px 5px; |
| | | // opacity: 0.1; |
| | | .con { |
| | | all: initial; |
| | | max-height: 65px; |
| | | display: -webkit-box; |
| | | -webkit-box-orient: vertical; |
| | |
| | | } |
| | | .pageBox-content { |
| | | height: calc(100% - 57px); |
| | | overflow-y: auto; |
| | | background: #fbf9f4; |
| | | .content-box { |
| | | height: 100%; |
| | | position: relative; |
| | | } |
| | | #container { |
| | | background: #fbf9f4; |
| | | // height: 100%; |
| | | #container { |
| | | background: #fbf9f4; |
| | | height: 100%; |
| | | #__qiankun_microapp_wrapper_for_app_content__ { |
| | | height: 100%; |
| | | } |
| | | } |
| | | } |
| | | .canvas-box { |
| | | height: 100%; |
| | |
| | | .dialogToolBox { |
| | | position: fixed; |
| | | z-index: 2; |
| | | |
| | | .toolSelectBox { |
| | | height: 57px; |
| | | display: flex; |
| | |
| | | } |
| | | } |
| | | } |
| | | .lineDeleteBox { |
| | | position: fixed; |
| | | z-index: 2; |
| | | border: 1px solid #0093ff; |
| | | padding: 20px 8px; |
| | | background: #fff; |
| | | border-radius: 5px; |
| | | } |
| | | .wendabox { |
| | | width: 100%; |
| | | height: 700px; |
| | |
| | | .myNoteDialogs { |
| | | width: 500px !important; |
| | | } |
| | | .screenshotDialog { |
| | | width: 400px !important; |
| | | } |
| | | .noteColorSelectBox { |
| | | margin-top: 10px; |
| | | width: 190px; |