|
|
|
<template>
|
|
|
|
<a-card :bordered="false">
|
|
|
|
<!-- 查询区域 -->
|
|
|
|
<div class="table-page-search-wrapper">
|
|
|
|
<a-form layout="inline" @keyup.enter.native="searchQuery">
|
|
|
|
<a-row :gutter="24">
|
|
|
|
<a-col :xl="6" :lg="7" :md="8" :sm="24">
|
|
|
|
<a-form-item label="消息">
|
|
|
|
<a-input placeholder="请输入消息" v-model="queryParam.message"></a-input>
|
|
|
|
</a-form-item>
|
|
|
|
</a-col>
|
|
|
|
<a-col :xl="6" :lg="7" :md="8" :sm="24">
|
|
|
|
<a-form-item label="是否已播报">
|
|
|
|
<j-dict-select-tag type="list" v-model="queryParam.status" dictCode="sfjj"
|
|
|
|
placeholder="请选择状态"/>
|
|
|
|
</a-form-item>
|
|
|
|
</a-col>
|
|
|
|
<a-col :xl="6" :lg="7" :md="8" :sm="24">
|
|
|
|
<a-form-item label="工单ID">
|
|
|
|
<a-input placeholder="请输入工单ID" v-model="queryParam.workorderId"></a-input>
|
|
|
|
</a-form-item>
|
|
|
|
</a-col>
|
|
|
|
<a-col :xl="6" :lg="7" :md="8" :sm="24">
|
|
|
|
<a-form-item label="订单商品ID">
|
|
|
|
<a-input placeholder="请输入订单商品ID" v-model="queryParam.ordergoodsId"></a-input>
|
|
|
|
</a-form-item>
|
|
|
|
</a-col>
|
|
|
|
<a-col :xl="6" :lg="7" :md="8" :sm="24">
|
|
|
|
<a-form-item label="生产计划工序ID">
|
|
|
|
<a-input placeholder="请输入生产计划工序ID" v-model="queryParam.zyplanprocessId"></a-input>
|
|
|
|
</a-form-item>
|
|
|
|
</a-col>
|
|
|
|
<a-col :xl="6" :lg="7" :md="8" :sm="24">
|
|
|
|
<span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">
|
|
|
|
<a-button type="primary" @click="searchQuery" icon="search">查询</a-button>
|
|
|
|
<a-button type="primary" @click="searchReset" icon="reload" style="margin-left: 8px">重置</a-button>
|
|
|
|
<!-- <a @click="handleToggleSearch" style="margin-left: 8px">-->
|
|
|
|
<!-- {{ toggleSearchStatus ? '收起' : '展开' }}-->
|
|
|
|
<!-- <a-icon :type="toggleSearchStatus ? 'up' : 'down'"/>-->
|
|
|
|
<!-- </a>-->
|
|
|
|
</span>
|
|
|
|
</a-col>
|
|
|
|
</a-row>
|
|
|
|
</a-form>
|
|
|
|
</div>
|
|
|
|
<!-- 查询区域-END -->
|
|
|
|
|
|
|
|
<!-- 操作按钮区域 -->
|
|
|
|
<div class="table-operator">
|
|
|
|
<!-- <a-button @click="handleAdd" type="primary" icon="plus">新增</a-button>-->
|
|
|
|
<a-button type="primary" icon="download" @click="handleExportXls('生产消息播报')">导出</a-button>
|
|
|
|
<!-- <a-upload name="file" :showUploadList="false" :multiple="false" :headers="tokenHeader" :action="importExcelUrl" @change="handleImportExcel">-->
|
|
|
|
<!-- <a-button type="primary" icon="import">导入</a-button>-->
|
|
|
|
<!-- </a-upload>-->
|
|
|
|
<!-- 高级查询区域 -->
|
|
|
|
<!-- <j-super-query :fieldList="superFieldList" ref="superQueryModal" @handleSuperQuery="handleSuperQuery"></j-super-query>-->
|
|
|
|
<!-- <a-dropdown v-if="selectedRowKeys.length > 0">-->
|
|
|
|
<!-- <a-menu slot="overlay">-->
|
|
|
|
<!-- <a-menu-item key="1" @click="batchDel"><a-icon type="delete"/>删除</a-menu-item>-->
|
|
|
|
<!-- </a-menu>-->
|
|
|
|
<!-- <a-button style="margin-left: 8px"> 批量操作 <a-icon type="down" /></a-button>-->
|
|
|
|
<!-- </a-dropdown>-->
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<!-- table区域-begin -->
|
|
|
|
<div>
|
|
|
|
<div class="ant-alert ant-alert-info" style="margin-bottom: 16px;">
|
|
|
|
<i class="anticon anticon-info-circle ant-alert-icon"></i> 已选择 <a
|
|
|
|
style="font-weight: 600">{{ selectedRowKeys.length }}</a>项
|
|
|
|
<a style="margin-left: 24px" @click="onClearSelected">清空</a>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<a-table
|
|
|
|
ref="table"
|
|
|
|
size="middle"
|
|
|
|
:scroll="{x:true}"
|
|
|
|
bordered
|
|
|
|
rowKey="id"
|
|
|
|
:columns="columns"
|
|
|
|
:dataSource="dataSource"
|
|
|
|
:pagination="ipagination"
|
|
|
|
:loading="loading"
|
|
|
|
:rowSelection="{selectedRowKeys: selectedRowKeys, onChange: onSelectChange}"
|
|
|
|
class="j-table-force-nowrap"
|
|
|
|
@change="handleTableChange">
|
|
|
|
<span slot="action" slot-scope="text, record">
|
|
|
|
<a v-if="record.status ==1" @click="reSetStatus(record.id,'0')">重置
|
|
|
|
<a-divider type="vertical"/>
|
|
|
|
</a>
|
|
|
|
<a @click="MySpeak(record)">播放</a>
|
|
|
|
<a-divider type="vertical"/>
|
|
|
|
<a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record.id)">
|
|
|
|
<a>删除</a>
|
|
|
|
</a-popconfirm>
|
|
|
|
</span>
|
|
|
|
</a-table>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<zy-speech-message-modal ref="modalForm" @ok="modalFormOk"></zy-speech-message-modal>
|
|
|
|
</a-card>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
|
|
|
|
import '@/assets/less/TableExpand.less'
|
|
|
|
import {mixinDevice} from '@/utils/mixin'
|
|
|
|
import {JeecgListMixin} from '@/mixins/JeecgListMixin'
|
|
|
|
import ZySpeechMessageModal from './modules/ZySpeechMessageModal'
|
|
|
|
import Speech from 'speak-tts'
|
|
|
|
import {getAction, putAction} from "@api/manage";
|
|
|
|
|
|
|
|
export default {
|
|
|
|
name: 'ZySpeechMessageList',
|
|
|
|
mixins: [JeecgListMixin, mixinDevice],
|
|
|
|
components: {
|
|
|
|
ZySpeechMessageModal
|
|
|
|
},
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
description: '消息播报管理页面',
|
|
|
|
// 表头
|
|
|
|
columns: [
|
|
|
|
{
|
|
|
|
title: '#',
|
|
|
|
dataIndex: '',
|
|
|
|
key: 'rowIndex',
|
|
|
|
width: 60,
|
|
|
|
align: "center",
|
|
|
|
customRender: function (t, r, index) {
|
|
|
|
return parseInt(index) + 1;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: '消息',
|
|
|
|
align: "center",
|
|
|
|
dataIndex: 'message'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: '已播报',
|
|
|
|
align: "center",
|
|
|
|
dataIndex: 'status_dictText'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: '工单ID',
|
|
|
|
align: "center",
|
|
|
|
dataIndex: 'workorderId'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: '订单商品ID',
|
|
|
|
align: "center",
|
|
|
|
dataIndex: 'ordergoodsId'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: '生产计划工序ID',
|
|
|
|
align: "center",
|
|
|
|
dataIndex: 'zyplanprocessId'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: '操作',
|
|
|
|
dataIndex: 'action',
|
|
|
|
align: "center",
|
|
|
|
fixed: "right",
|
|
|
|
width: 147,
|
|
|
|
scopedSlots: {customRender: 'action'}
|
|
|
|
}
|
|
|
|
],
|
|
|
|
url: {
|
|
|
|
list: "/org.jeecg.modules.message/zySpeechMessage/list",
|
|
|
|
edit: "/org.jeecg.modules.message/zySpeechMessage/edit",
|
|
|
|
getMessageList: "/org.jeecg.modules.message/zySpeechMessage/getMessageList",
|
|
|
|
delete: "/org.jeecg.modules.message/zySpeechMessage/delete",
|
|
|
|
deleteBatch: "/org.jeecg.modules.message/zySpeechMessage/deleteBatch",
|
|
|
|
exportXlsUrl: "/org.jeecg.modules.message/zySpeechMessage/exportXls",
|
|
|
|
|
|
|
|
},
|
|
|
|
dictOptions: {},
|
|
|
|
superFieldList: [],
|
|
|
|
|
|
|
|
speech: null,
|
|
|
|
// 定时器ID
|
|
|
|
timer: null,
|
|
|
|
// 定时器周期
|
|
|
|
millisec: 20000,
|
|
|
|
/* 数据源 */
|
|
|
|
messageList: [],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
mounted() {
|
|
|
|
this.speechInit();
|
|
|
|
this.openTimer()
|
|
|
|
},
|
|
|
|
|
|
|
|
methods: {
|
|
|
|
speechInit() {
|
|
|
|
this.speech = new Speech();
|
|
|
|
if (this.speech.hasBrowserSupport()) { // returns a boolean
|
|
|
|
console.log(">>>this browser,supported TTS")
|
|
|
|
} else {
|
|
|
|
console.log("XXX----------------------sorry,this browser,not supported TTS!!!")
|
|
|
|
}
|
|
|
|
this.speech.init({
|
|
|
|
'volume': 1,
|
|
|
|
'lang': 'zh-CN',
|
|
|
|
'rate': 1,
|
|
|
|
'pitch': 1,
|
|
|
|
'splitSentences': true,
|
|
|
|
}).then((conf) => {
|
|
|
|
console.log('>>>语音播报初始化完成...,Speech配置参数:', conf)
|
|
|
|
}).catch(e => {
|
|
|
|
console.error("XXX------------------------An error occured while init : ", e)
|
|
|
|
})
|
|
|
|
},
|
|
|
|
//语音播报
|
|
|
|
MySpeak(obj) {
|
|
|
|
let mess = obj['message'];
|
|
|
|
console.log("----------speak()接受到的消息-----------【" + mess + "】");
|
|
|
|
this.speech.speak({
|
|
|
|
text: mess,
|
|
|
|
listeners: {
|
|
|
|
//开始播放
|
|
|
|
onstart: () => {
|
|
|
|
console.log("Start utterance")
|
|
|
|
},
|
|
|
|
//判断播放是否完毕
|
|
|
|
onend: () => {
|
|
|
|
// console.log("End utterance");
|
|
|
|
console.log("------------delete----------【" + mess + "】消息播报完成,删除该消息")
|
|
|
|
this.updateMessageStatus(obj['id'], 1);
|
|
|
|
},
|
|
|
|
//恢复播放
|
|
|
|
onresume: () => {
|
|
|
|
console.log("Resume utterance")
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}).then(() => {
|
|
|
|
// console.log("消息" + obj['id'] + "播报完成")
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
getMessageList() {
|
|
|
|
let parma = {
|
|
|
|
"status": '0',
|
|
|
|
}
|
|
|
|
getAction(this.url.list, parma).then((res) => {
|
|
|
|
if (res.success) {
|
|
|
|
console.log("------------getMessageList----------文字转语音消息列表>>>:" + JSON.stringify(res.result.records));
|
|
|
|
this.messageList = res.result.records;
|
|
|
|
this.messageList.forEach(obj => {
|
|
|
|
if (obj['status'] === '0') {
|
|
|
|
this.MySpeak(obj);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
} else {
|
|
|
|
this.$message.warning(res.message)
|
|
|
|
}
|
|
|
|
}).finally(() => {
|
|
|
|
// this.loading = false
|
|
|
|
// this.loadData();
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
reSetStatus(id, ststus) {
|
|
|
|
this.updateMessageStatus(id, ststus);
|
|
|
|
// this.getMessageList();
|
|
|
|
this.loading = false
|
|
|
|
this.loadData();
|
|
|
|
},
|
|
|
|
|
|
|
|
updateMessageStatus(id, status) {
|
|
|
|
// console.log("删除已播报消息:" + id);
|
|
|
|
let parma = {
|
|
|
|
"id": id,
|
|
|
|
"status": status,
|
|
|
|
}
|
|
|
|
putAction(this.url.edit, parma).then((res) => {
|
|
|
|
if (res.success) {
|
|
|
|
for (let i = 0; i < this.messageList.length; i++) {
|
|
|
|
if (this.messageList[i].id === id) {
|
|
|
|
//消息删除成功,从datasource队列中删除消息
|
|
|
|
this.messageList.splice(i, '1');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
this.$message.warning(res.message)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
|
|
|
openTimer() {
|
|
|
|
this.closeTimer()
|
|
|
|
console.log(">>>timer初始化完成【" + new Date().toLocaleString() + "】,---执行周期: " + this.millisec + " 毫秒")
|
|
|
|
//上次播报列表播报完后,再获取新数据
|
|
|
|
this.timer = setInterval(() => {
|
|
|
|
console.log("---未播报消息数量:", this.messageList.length)
|
|
|
|
// console.log("the messageList:", JSON.stringify(this.messageList));
|
|
|
|
if (this.messageList.length === 0) {
|
|
|
|
console.log("--------timer is exec,the current time:" + new Date().toLocaleString())
|
|
|
|
this.getMessageList();
|
|
|
|
} else {
|
|
|
|
console.log("-------上次消息列表未处理完---HOLD ON")
|
|
|
|
}
|
|
|
|
}, this.millisec)
|
|
|
|
},
|
|
|
|
|
|
|
|
/** 关闭定时器 */
|
|
|
|
closeTimer() {
|
|
|
|
if (this.timer) clearInterval(this.timer)
|
|
|
|
},
|
|
|
|
|
|
|
|
//暂停
|
|
|
|
paused() {
|
|
|
|
this.speech.pause();
|
|
|
|
},
|
|
|
|
//从暂停处继续播放
|
|
|
|
goahead() {
|
|
|
|
this.speech.resume();
|
|
|
|
console.log("继续播放-----------------------------")
|
|
|
|
},
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
//离开页面取消语音
|
|
|
|
destroyed() {
|
|
|
|
console.log("-----------关闭Timer、Speech---------------")
|
|
|
|
this.closeTimer();
|
|
|
|
this.speech.cancel();
|
|
|
|
},
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
<style scoped>
|
|
|
|
@import '~@assets/less/common.less';
|
|
|
|
</style>
|