This repository has been archived on 2025-09-14. You can view files and clone it, but cannot push or open issues or pull requests.
Files
nezha-nezha-fronted/nezha-fronted/src/components/common/bottomBox/tabs/issueTab.vue
2022-09-06 16:12:03 +08:00

282 lines
10 KiB
Vue

<template>
<div>
<el-container>
<el-container class="issuetab-container">
<el-header class="issuetab-header">
<span class="title">this is a title</span>
<div>
<ul id="menu">
<li class="menu-li">
<i class="nz-icon nz-icon-label menu-i"></i>
<div class="menu-div">
<span>{{ this.issuedetailsData.type }}</span>
<span class="describe">Type</span>
</div>
</li>
<li class="menu-li">
<i class="nz-icon nz-icon-label menu-i"></i>
<div class="menu-div">
<span>{{ priorityEnums(issuedetailsData.priority) }}</span>
<span class="describe">Priority</span>
</div>
</li>
<li class="menu-li">
<i class="nz-icon nz-icon-label menu-i"></i>
<div class="menu-div">
<span>{{ stateEnums(this.issuedetailsData.state) }}</span>
<span class="describe">state</span>
</div>
</li>
<li class="menu-li">
<i class="nz-icon nz-icon-user menu-i"></i>
<div class="menu-div">
<span>{{ this.issuedetailsData.reporter.username }}</span>
<span class="describe" >Reporter</span>
</div>
</li>
<li class="menu-li">
<i class="nz-icon nz-icon-user menu-i"></i>
<div class="menu-div">
<span>{{ this.issuedetailsData.assignee.username }}</span>
<span class="describe">Assignee</span>
</div>
</li>
</ul>
</div>
</el-header>
<el-main class="issuetab-main">
<div>
<span class="description" >
<i class="nz-icon nz-icon-arrow-right fold" v-if="foldShow" @click="foldFun"></i>
<i class="nz-icon nz-icon-arrow-down open" v-if="openShow" @click="openFun"></i>
</span>
<span class="description-title">Description</span>
<div class="description-content" v-if="openShow" v-html="this.contents">
</div>
</div>
<div class="relate-assets-box">
<span class="relate-assets" >
<i class="nz-icon nz-icon-arrow-right fold" v-if="assetsfoldShow" @click="assetsfoldFun"></i>
<i class="nz-icon nz-icon-arrow-down open" v-if="assetsopenShow" @click="assetsopenFun"></i>
</span>
<span class="relate-assets-title">Relate-assets</span>
<div class="relate-assets-content" v-if="assetsopenShow " >
<div v-for="(item, index) in this.assets" :key="index" >{{item.name}}</div>
</div>
</div>
</el-main>
<!-- <el-footer>Footer</el-footer> -->
</el-container>
<el-aside width="400px" class="issuetab-aside">
<span>{{$t("issueTab.dynamic")}} </span>
<template>
<el-tabs v-model="activeName" @tab-click="handleClick" class="issuetab-eltabs">
<el-tab-pane :label="$t('issueTab.whole')" name="first" class="tab-pane">
<div class="change ">
<i class="nz-icon nz-icon-edit"></i>
<span>老王</span>
<span>Created issue</span>
<span>2022-09-02</span>
<!-- <div v-for="(item, index) in changeData" :key="index" v-html="item.content" ></div> -->
</div>
<div class="content first-content" >
<div v-for="(item, index) in this.contentData" :key="index">
<i class="nz-icon nz-icon-edit"></i>
<span>{{item.createUser.name}}</span>
<span>{{typeEnums(item.type)}}</span>
<span>{{timezoneToUtcTimeStr(item.cts)}}</span>
<div class="content-data" v-for="(item, index) in contentData" :key="index" v-html="item.content" ></div>
</div>
</div>
</el-tab-pane>
<el-tab-pane :label="$t('issueTab.comment')" name="content" class="tab-pane">
<div class="content " >
<div v-for="(item, index) in this.contentData" :key="index">
<i class="nz-icon nz-icon-edit"></i>
<span>{{item.createUser.name}}</span>
<span>{{typeEnums(item.type)}}</span>
<span>{{timezoneToUtcTimeStr(item.cts)}}</span>
<div class="content-data" v-for="(item, index) in contentData" :key="index" v-html="item.content" ></div>
</div>
</div>
</el-tab-pane>
<el-tab-pane :label="$t('issueTab.changeRecord')" name="change" class="tab-pane">
<div class="change">
<i class="nz-icon nz-icon-edit"></i>
<span>老王</span>
<span>Created issue</span>
<span>2022-09-02</span>
</div>
</el-tab-pane>
</el-tabs>
</template>
<div class="add-comment-btn">
<el-button type="text" v-if="addcommentShow" @click="addcommentBtn">{{$t("issueTab.addComment")}}</el-button>
</div>
<div v-if="textareaShow" class="textareas">
<el-input
class="textareas-input"
type="textarea"
:autosize="{ minRows: 2, maxRows: 4}"
placeholder="多行输入"
v-model="textarea">
</el-input>
<div class="btn-box">
<el-button size="mini" @click="addFun">{{$t("issueTab.Add")}}</el-button>
<el-button size="mini" @click="cancelBtn">{{$t("overall.cancel")}}</el-button>
</div>
</div>
</el-aside>
</el-container>
</div>
</template>
<script>
import mainMixinFun from '@/components/common/mixin/mainMixinFun'
export default {
name: 'issueTab',
mixins: [mainMixinFun],
data () {
return {
url: '/issue',
activeName: 'first',
textareaShow: false, // 底部输入框显示状态
addcommentShow: true, // 底部按钮显示状态
openShow: false, // 展开折叠图标显示状态
foldShow: true, // 展开折叠图标显示状态
assetsopenShow: false, // 展开折叠图标显示状态
assetsfoldShow: true, // 展开折叠图标显示状态
textarea: '', // 底部输入框内容
issuedetailsData: [], // issue详情data
changeData: [], // 变更data
contentData: [], // 评论data
assets: [],
contents: [],
createUser: [],
updateUser: [],
time: '',
defaultProps: {
children: 'children',
label: 'label'
}
}
},
created () {
this.axiosss()
},
methods: {
handleNodeClick (data) {
console.log(data)
},
handleClick (tab, event) {
console.log(tab, event)
},
addcommentBtn () {
this.textareaShow = true
this.addcommentShow = false
},
cancelBtn () {
this.textareaShow = false
this.addcommentShow = true
},
// 处理后台返回的html特殊标签 ----已经弃用 之前有插件处理
delHtmlTag (str) {
return str.replace(/<[^>]+>/g, '').replace(/&nbsp;/ig, '')
},
addFun () {
const params = {
issueId: 1,
content: this.textarea
}
this.$post('/issue/activity', params).then(response => { // 问题动态 新增
if (response.code === 200) {
// console.log(response, 1)
this.axiosss()
}
})
},
axiosss () {
this.$get(`${this.url}/${1}`).then(response => { // issue详情接口
if (response.code === 200) {
this.issuedetailsData = response.data
this.contents = this.issuedetailsData.content
this.assets = this.issuedetailsData.assets
// console.log(this.issuedetailsData, 3)
}
})
this.$get(`${this.url}/activity?issueId=1&type=1&pageSize=-1`).then(response => { // issue动态详情接口-变更记录
if (response.code === 200) {
this.changeData = response.data.list
this.time = response.time
console.log(response.time)
console.log(response.data, 1)
// console.log(response.data, 2)
}
})
this.$get(`${this.url}/activity?issueId=1&type=2&pageSize=-1`).then(response => { // issue动态详情接口-评论
if (response.code === 200) {
this.contentData = response.data.list
this.time = response.time
}
})
},
// priority 枚举转换
priorityEnums (data) {
if (data == 1) {
data = '高'
} else if (data == 2) {
data = '中'
} else {
data = '低'
}
return data
},
// state 枚举转换
stateEnums (data) {
if (data == 1) {
data = '打开'
} else if (data == 2) {
data = '已指派'
} else if (data == 3) {
data = '处理中'
} else if (data == 4) {
data = '挂起'
} else if (data == 5) {
data = '已解决'
} else if (data == 6) {
data = '关闭'
} else if (data == 7) {
data = '取消'
}
return data
},
// type 处理
typeEnums (data) {
if (data == 1) {
data = 'changed issue'
} else if (data == 2) {
data = 'created issue'
}
return data
},
foldFun () {
this.openShow = true
this.foldShow = false
},
openFun () {
this.openShow = false
this.foldShow = true
},
assetsfoldFun () {
this.assetsopenShow = true
this.assetsfoldShow = false
},
assetsopenFun () {
this.assetsopenShow = false
this.assetsfoldShow = true
}
}
}
</script>