|  |  |  | 
|---|
|  |  |  | <el-input v-model="platform.name"></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item label="SIP服务国标编码" prop="serverGBId"> | 
|---|
|  |  |  | <el-input v-model="platform.serverGBId" clearable></el-input> | 
|---|
|  |  |  | <el-input v-model="platform.serverGBId" clearable @input="serverGBIdChange"></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item label="SIP服务国标域" prop="serverGBDomain"> | 
|---|
|  |  |  | <el-input v-model="platform.serverGBDomain" clearable></el-input> | 
|---|
|  |  |  | 
|---|
|  |  |  | <el-input v-model="platform.serverIP" clearable></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item label="SIP服务端口" prop="serverPort"> | 
|---|
|  |  |  | <el-input v-model="platform.serverPort" clearable></el-input> | 
|---|
|  |  |  | <el-input v-model="platform.serverPort" clearable type="number"></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item label="设备国标编号" prop="deviceGBId"> | 
|---|
|  |  |  | <el-input v-model="platform.deviceGBId" clearable></el-input> | 
|---|
|  |  |  | <el-input v-model="platform.deviceGBId" clearable @input="deviceGBIdChange"></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item label="本地IP" prop="deviceIp"> | 
|---|
|  |  |  | <el-input v-model="platform.deviceIp" :disabled="true"></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item label="本地端口" prop="devicePort"> | 
|---|
|  |  |  | <el-input v-model="platform.devicePort" :disabled="true"></el-input> | 
|---|
|  |  |  | <el-input v-model="platform.devicePort" :disabled="true" type="number"></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | </el-form> | 
|---|
|  |  |  | </el-col> | 
|---|
|  |  |  | 
|---|
|  |  |  | <el-form-item label="其他选项"> | 
|---|
|  |  |  | <el-checkbox label="启用" v-model="platform.enable" @change="checkExpires"></el-checkbox> | 
|---|
|  |  |  | <el-checkbox label="云台控制" v-model="platform.ptz"></el-checkbox> | 
|---|
|  |  |  | <el-checkbox label="RTCP保活" v-model="platform.rtcp"></el-checkbox> | 
|---|
|  |  |  | <el-checkbox label="共享所有直播流" v-model="platform.shareAllLiveStream"></el-checkbox> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item> | 
|---|
|  |  |  | <el-button type="primary" @click="onSubmit">{{ | 
|---|
|  |  |  | 
|---|
|  |  |  | name: "platformEdit", | 
|---|
|  |  |  | props: {}, | 
|---|
|  |  |  | computed: {}, | 
|---|
|  |  |  | created() {}, | 
|---|
|  |  |  | data() { | 
|---|
|  |  |  | var deviceGBIdRules = async (rule, value, callback) => { | 
|---|
|  |  |  | console.log(value); | 
|---|
|  |  |  | 
|---|
|  |  |  | showDialog: false, | 
|---|
|  |  |  | isLoging: false, | 
|---|
|  |  |  | onSubmit_text: "立即创建", | 
|---|
|  |  |  | saveUrl: "/api/platform/save", | 
|---|
|  |  |  |  | 
|---|
|  |  |  | platform: { | 
|---|
|  |  |  | id: null, | 
|---|
|  |  |  | 
|---|
|  |  |  | keepTimeout: 60, | 
|---|
|  |  |  | transport: "UDP", | 
|---|
|  |  |  | characterSet: "GB2312", | 
|---|
|  |  |  | shareAllLiveStream: false, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | rules: { | 
|---|
|  |  |  | name: [{ required: true, message: "请输入平台名称", trigger: "blur" }], | 
|---|
|  |  |  | 
|---|
|  |  |  | var that = this; | 
|---|
|  |  |  | if (platform == null) { | 
|---|
|  |  |  | this.onSubmit_text = "立即创建"; | 
|---|
|  |  |  | this.saveUrl = "/api/platform/add"; | 
|---|
|  |  |  | this.$axios({ | 
|---|
|  |  |  | method: 'get', | 
|---|
|  |  |  | url:`/api/platform/server_config` | 
|---|
|  |  |  | 
|---|
|  |  |  | console.log(error); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | this.platform = platform; | 
|---|
|  |  |  | this.platform.id = platform.id; | 
|---|
|  |  |  | this.platform.enable = platform.enable; | 
|---|
|  |  |  | this.platform.ptz = platform.ptz; | 
|---|
|  |  |  | this.platform.rtcp = platform.rtcp; | 
|---|
|  |  |  | this.platform.name = platform.name; | 
|---|
|  |  |  | this.platform.serverGBId = platform.serverGBId; | 
|---|
|  |  |  | this.platform.serverGBDomain = platform.serverGBDomain; | 
|---|
|  |  |  | this.platform.serverIP = platform.serverIP; | 
|---|
|  |  |  | this.platform.serverPort = platform.serverPort; | 
|---|
|  |  |  | this.platform.deviceGBId = platform.deviceGBId; | 
|---|
|  |  |  | this.platform.deviceIp = platform.deviceIp; | 
|---|
|  |  |  | this.platform.devicePort = platform.devicePort; | 
|---|
|  |  |  | this.platform.username = platform.username; | 
|---|
|  |  |  | this.platform.password = platform.password; | 
|---|
|  |  |  | this.platform.expires = platform.expires; | 
|---|
|  |  |  | this.platform.keepTimeout = platform.keepTimeout; | 
|---|
|  |  |  | this.platform.transport = platform.transport; | 
|---|
|  |  |  | this.platform.characterSet = platform.characterSet; | 
|---|
|  |  |  | this.platform.shareAllLiveStream = platform.shareAllLiveStream; | 
|---|
|  |  |  | this.platform.catalogId = platform.catalogId; | 
|---|
|  |  |  | this.onSubmit_text = "保存"; | 
|---|
|  |  |  | this.saveUrl = "/api/platform/save"; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.showDialog = true; | 
|---|
|  |  |  | this.listChangeCallback = callback; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | serverGBIdChange: function () { | 
|---|
|  |  |  | if (this.platform.serverGBId.length > 10) { | 
|---|
|  |  |  | this.platform.serverGBDomain = this.platform.serverGBId.substr(0, 10); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | deviceGBIdChange: function () { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | this.platform.username = this.platform.deviceGBId ; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | onSubmit: function () { | 
|---|
|  |  |  | console.log("onSubmit"); | 
|---|
|  |  |  | var that = this; | 
|---|
|  |  |  | that.$axios({ | 
|---|
|  |  |  | method: 'post', | 
|---|
|  |  |  | url:`/api/platform/save`, | 
|---|
|  |  |  | url: this.saveUrl, | 
|---|
|  |  |  | data: that.platform | 
|---|
|  |  |  | }).then(function (res) { | 
|---|
|  |  |  | if (res.data == "success") { | 
|---|
|  |  |  | if (res.data.code === 0) { | 
|---|
|  |  |  | that.$message({ | 
|---|
|  |  |  | showClose: true, | 
|---|
|  |  |  | message: "保存成功", | 
|---|
|  |  |  | 
|---|
|  |  |  | if (that.listChangeCallback != null) { | 
|---|
|  |  |  | that.listChangeCallback(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | that.$message({ | 
|---|
|  |  |  | showClose: true, | 
|---|
|  |  |  | message: res.data.msg, | 
|---|
|  |  |  | type: "error", | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }).catch(function (error) { | 
|---|
|  |  |  | console.log(error); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | close: function () { | 
|---|
|  |  |  | console.log("关闭添加视频平台"); | 
|---|
|  |  |  | this.showDialog = false; | 
|---|
|  |  |  | this.$refs.platform1.resetFields(); | 
|---|
|  |  |  | this.$refs.platform2.resetFields(); | 
|---|
|  |  |  | this.platform = { | 
|---|
|  |  |  | id: null, | 
|---|
|  |  |  | enable: true, | 
|---|
|  |  |  | ptz: true, | 
|---|
|  |  |  | rtcp: false, | 
|---|
|  |  |  | name: null, | 
|---|
|  |  |  | serverGBId: null, | 
|---|
|  |  |  | serverGBDomain: null, | 
|---|
|  |  |  | serverIP: null, | 
|---|
|  |  |  | serverPort: null, | 
|---|
|  |  |  | deviceGBId: null, | 
|---|
|  |  |  | deviceIp: null, | 
|---|
|  |  |  | devicePort: null, | 
|---|
|  |  |  | username: null, | 
|---|
|  |  |  | password: null, | 
|---|
|  |  |  | expires: 300, | 
|---|
|  |  |  | keepTimeout: 60, | 
|---|
|  |  |  | transport: "UDP", | 
|---|
|  |  |  | characterSet: "GB2312", | 
|---|
|  |  |  | shareAllLiveStream: false, | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | deviceGBIdExit: async function (deviceGbId) { | 
|---|
|  |  |  | var result = false; | 
|---|
|  |  |  | 
|---|
|  |  |  | </script> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <style> | 
|---|
|  |  |  | /* 谷歌 */ | 
|---|
|  |  |  | input::-webkit-outer-spin-button, | 
|---|
|  |  |  | input::-webkit-inner-spin-button { | 
|---|
|  |  |  | -webkit-appearance: none; | 
|---|
|  |  |  | appearance: none; | 
|---|
|  |  |  | margin: 0; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /* 火狐 */ | 
|---|
|  |  |  | input{ | 
|---|
|  |  |  | -moz-appearance:textfield; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .control-wrapper-not-used { | 
|---|
|  |  |  | position: relative; | 
|---|
|  |  |  | width: 6.25rem; | 
|---|