服装智能制造软件平台V3.0
http://182.92.169.222/hhxy/#/user/login
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
333 lines
11 KiB
333 lines
11 KiB
<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> |